-
Notifications
You must be signed in to change notification settings - Fork 276
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
7caed56
commit 21793a6
Showing
7 changed files
with
245 additions
and
191 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
330 changes: 166 additions & 164 deletions
330
packages/react/src/components/uiKit/blocks/UiKitModal.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,164 +1,166 @@ | ||
/* eslint-disable react/jsx-no-undef */ | ||
/* eslint-disable import/extensions */ | ||
/* eslint-disable import/no-unresolved */ | ||
/* eslint-disable no-shadow */ | ||
/* eslint-disable react/jsx-no-constructed-context-values */ | ||
import React from 'react'; | ||
import { | ||
useDebouncedCallback, | ||
useMutableCallback, | ||
} from '@rocket.chat/fuselage-hooks'; | ||
import { kitContext } from '../contexts/kitContext'; | ||
|
||
import * as ActionManager from '../../../../app/ui-message/client/ActionManager'; | ||
import { detectEmoji } from '../../../lib/utils/detectEmoji'; | ||
import ModalBlock from './ModalBlock'; | ||
import { useActionManagerState } from './hooks/useActionManagerState'; | ||
import { useValues } from './hooks/useValues'; | ||
|
||
const UiKitModal = (props) => { | ||
const state = useActionManagerState(props); | ||
|
||
const { appId, viewId, mid: _mid, errors, view } = state; | ||
|
||
const [values, updateValues] = useValues(view.blocks); | ||
|
||
const groupStateByBlockId = (values) => | ||
Object.entries(values).reduce((obj, [key, { blockId, value }]) => { | ||
obj[blockId] = obj[blockId] || {}; | ||
obj[blockId][key] = value; | ||
|
||
return obj; | ||
}, {}); | ||
|
||
const prevent = (e) => { | ||
if (e) { | ||
(e.nativeEvent || e).stopImmediatePropagation(); | ||
e.stopPropagation(); | ||
e.preventDefault(); | ||
} | ||
}; | ||
|
||
const debouncedBlockAction = useDebouncedCallback( | ||
(actionId, appId, value, blockId, mid) => { | ||
ActionManager.triggerBlockAction({ | ||
container: { | ||
type: 'view', | ||
id: viewId, | ||
}, | ||
actionId, | ||
appId, | ||
value, | ||
blockId, | ||
mid, | ||
}); | ||
}, | ||
700 | ||
); | ||
|
||
// TODO: this structure is atrociously wrong; we should revisit this | ||
const context = { | ||
// @ts-expect-error Property 'mid' does not exist on type 'ActionParams'. | ||
action: ({ | ||
actionId, | ||
appId, | ||
value, | ||
blockId, | ||
mid = _mid, | ||
dispatchActionConfig, | ||
}) => { | ||
if ( | ||
Array.isArray(dispatchActionConfig) && | ||
dispatchActionConfig.includes('on_character_entered') | ||
) { | ||
debouncedBlockAction(actionId, appId, value, blockId, mid); | ||
} else { | ||
ActionManager.triggerBlockAction({ | ||
container: { | ||
type: 'view', | ||
id: viewId, | ||
}, | ||
actionId, | ||
appId, | ||
value, | ||
blockId, | ||
mid, | ||
}); | ||
} | ||
}, | ||
|
||
state: ({ actionId, value, /* ,appId, */ blockId = 'default' }) => { | ||
updateValues({ | ||
actionId, | ||
payload: { | ||
blockId, | ||
value, | ||
}, | ||
}); | ||
}, | ||
...state, | ||
values, | ||
}; | ||
|
||
const handleSubmit = useMutableCallback((e) => { | ||
prevent(e); | ||
ActionManager.triggerSubmitView({ | ||
viewId, | ||
appId, | ||
payload: { | ||
view: { | ||
...view, | ||
id: viewId, | ||
state: groupStateByBlockId(values), | ||
}, | ||
}, | ||
}); | ||
}); | ||
|
||
const handleCancel = useMutableCallback((e) => { | ||
prevent(e); | ||
ActionManager.triggerCancel({ | ||
viewId, | ||
appId, | ||
view: { | ||
...view, | ||
id: viewId, | ||
state: groupStateByBlockId(values), | ||
}, | ||
}); | ||
}); | ||
|
||
const handleClose = useMutableCallback(() => { | ||
ActionManager.triggerCancel({ | ||
viewId, | ||
appId, | ||
view: { | ||
...view, | ||
id: viewId, | ||
state: groupStateByBlockId(values), | ||
}, | ||
isCleared: true, | ||
}); | ||
}); | ||
|
||
return ( | ||
<kitContext.Provider value={context}> | ||
<MarkupInteractionContext.Provider | ||
value={{ | ||
detectEmoji, | ||
}} | ||
> | ||
<ModalBlock | ||
view={view} | ||
errors={errors} | ||
appId={appId} | ||
onSubmit={handleSubmit} | ||
onCancel={handleCancel} | ||
onClose={handleClose} | ||
/> | ||
</MarkupInteractionContext.Provider> | ||
</kitContext.Provider> | ||
); | ||
}; | ||
|
||
export default UiKitModal; | ||
// File is never used, already implemented a fuselage surface renderer in which everything is defined | ||
|
||
// /* eslint-disable react/jsx-no-undef */ | ||
// /* eslint-disable import/extensions */ | ||
// /* eslint-disable import/no-unresolved */ | ||
// /* eslint-disable no-shadow */ | ||
// /* eslint-disable react/jsx-no-constructed-context-values */ | ||
// import React from 'react'; | ||
// import { | ||
// useDebouncedCallback, | ||
// useMutableCallback, | ||
// } from '@rocket.chat/fuselage-hooks'; | ||
// import { kitContext } from '../contexts/kitContext'; | ||
|
||
// import * as ActionManager from '../../../../app/ui-message/client/ActionManager'; | ||
// import { detectEmoji } from '../../../lib/utils/detectEmoji'; | ||
// import ModalBlock from './ModalBlock'; | ||
// import { useActionManagerState } from './hooks/useActionManagerState'; | ||
// import { useValues } from './hooks/useValues'; | ||
|
||
// const UiKitModal = (props) => { | ||
// const state = useActionManagerState(props); | ||
|
||
// const { appId, viewId, mid: _mid, errors, view } = state; | ||
|
||
// const [values, updateValues] = useValues(view.blocks); | ||
|
||
// const groupStateByBlockId = (values) => | ||
// Object.entries(values).reduce((obj, [key, { blockId, value }]) => { | ||
// obj[blockId] = obj[blockId] || {}; | ||
// obj[blockId][key] = value; | ||
|
||
// return obj; | ||
// }, {}); | ||
|
||
// const prevent = (e) => { | ||
// if (e) { | ||
// (e.nativeEvent || e).stopImmediatePropagation(); | ||
// e.stopPropagation(); | ||
// e.preventDefault(); | ||
// } | ||
// }; | ||
|
||
// const debouncedBlockAction = useDebouncedCallback( | ||
// (actionId, appId, value, blockId, mid) => { | ||
// ActionManager.triggerBlockAction({ | ||
// container: { | ||
// type: 'view', | ||
// id: viewId, | ||
// }, | ||
// actionId, | ||
// appId, | ||
// value, | ||
// blockId, | ||
// mid, | ||
// }); | ||
// }, | ||
// 700 | ||
// ); | ||
|
||
// // TODO: this structure is atrociously wrong; we should revisit this | ||
// const context = { | ||
// // @ts-expect-error Property 'mid' does not exist on type 'ActionParams'. | ||
// action: ({ | ||
// actionId, | ||
// appId, | ||
// value, | ||
// blockId, | ||
// mid = _mid, | ||
// dispatchActionConfig, | ||
// }) => { | ||
// if ( | ||
// Array.isArray(dispatchActionConfig) && | ||
// dispatchActionConfig.includes('on_character_entered') | ||
// ) { | ||
// debouncedBlockAction(actionId, appId, value, blockId, mid); | ||
// } else { | ||
// ActionManager.triggerBlockAction({ | ||
// container: { | ||
// type: 'view', | ||
// id: viewId, | ||
// }, | ||
// actionId, | ||
// appId, | ||
// value, | ||
// blockId, | ||
// mid, | ||
// }); | ||
// } | ||
// }, | ||
|
||
// state: ({ actionId, value, /* ,appId, */ blockId = 'default' }) => { | ||
// updateValues({ | ||
// actionId, | ||
// payload: { | ||
// blockId, | ||
// value, | ||
// }, | ||
// }); | ||
// }, | ||
// ...state, | ||
// values, | ||
// }; | ||
|
||
// const handleSubmit = useMutableCallback((e) => { | ||
// prevent(e); | ||
// ActionManager.triggerSubmitView({ | ||
// viewId, | ||
// appId, | ||
// payload: { | ||
// view: { | ||
// ...view, | ||
// id: viewId, | ||
// state: groupStateByBlockId(values), | ||
// }, | ||
// }, | ||
// }); | ||
// }); | ||
|
||
// const handleCancel = useMutableCallback((e) => { | ||
// prevent(e); | ||
// ActionManager.triggerCancel({ | ||
// viewId, | ||
// appId, | ||
// view: { | ||
// ...view, | ||
// id: viewId, | ||
// state: groupStateByBlockId(values), | ||
// }, | ||
// }); | ||
// }); | ||
|
||
// const handleClose = useMutableCallback(() => { | ||
// ActionManager.triggerCancel({ | ||
// viewId, | ||
// appId, | ||
// view: { | ||
// ...view, | ||
// id: viewId, | ||
// state: groupStateByBlockId(values), | ||
// }, | ||
// isCleared: true, | ||
// }); | ||
// }); | ||
|
||
// return ( | ||
// <kitContext.Provider value={context}> | ||
// <MarkupInteractionContext.Provider | ||
// value={{ | ||
// detectEmoji, | ||
// }} | ||
// > | ||
// <ModalBlock | ||
// view={view} | ||
// errors={errors} | ||
// appId={appId} | ||
// onSubmit={handleSubmit} | ||
// onCancel={handleCancel} | ||
// onClose={handleClose} | ||
// /> | ||
// </MarkupInteractionContext.Provider> | ||
// </kitContext.Provider> | ||
// ); | ||
// }; | ||
|
||
// export default UiKitModal; |
Oops, something went wrong.