jamespot-react-core 1.1.189 → 1.1.190
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/593.56c6fcd2db8c13313d75.chunk.js +670 -0
- package/build/593.56c6fcd2db8c13313d75.chunk.js.map +1 -0
- package/build/app.bundle.js +276 -274
- package/build/app.bundle.js.map +1 -1
- package/build/src/components/CommentsBloc.d.ts +2 -1
- package/build/src/components/comments/AddReportModal.d.ts +8 -0
- package/build/src/components/widgets/wrapper/components/OfficeConfigurationPrompt.d.ts +1 -0
- package/build/src/redux/store.d.ts +5 -1
- package/build/src/registry/core-component-list.d.ts +1 -0
- package/build/src/registry/coreComponents.d.ts +1 -0
- package/package.json +4 -4
- package/build/435.ea8eca2f117abb78e1db.chunk.js +0 -654
- package/build/435.ea8eca2f117abb78e1db.chunk.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"435.ea8eca2f117abb78e1db.chunk.js","mappings":"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","sources":["webpack://ReactCore/./src/components/Avatar.tsx","webpack://ReactCore/./src/components/Audience.tsx","webpack://ReactCore/./src/components/tinymce/extension/AIModal.tsx","webpack://ReactCore/./src/components/editors/const.ts","webpack://ReactCore/./src/components/editors/style.tsx","webpack://ReactCore/./src/components/editors/EditorPopup.tsx","webpack://ReactCore/./src/components/editors/Editor.tsx","webpack://ReactCore/./src/components/editors/EditorPosition.tsx","webpack://ReactCore/./src/components/editors/components/EditorInputColor.tsx","webpack://ReactCore/./src/components/editors/components/EditorInputNumber.tsx","webpack://ReactCore/./src/components/editors/components/EditorInputSelect.tsx","webpack://ReactCore/./src/components/editors/EditorTabWrapper.tsx","webpack://ReactCore/./src/components/editors/states/EditorIsBusy.tsx","webpack://ReactCore/./src/components/editors/states/EditorIsLocked.tsx","webpack://ReactCore/./src/components/editors/components/EditorSave.tsx","webpack://ReactCore/./src/components/editors/EditorTabWidgetSelection.tsx","webpack://ReactCore/./src/components/editors/EditorTabDisplayLevel.tsx","webpack://ReactCore/./src/components/editors/EditorWrapper.tsx","webpack://ReactCore/./src/components/editors/EditorsPortal.tsx","webpack://ReactCore/./src/components/widgets/components/WidgetEditorPanel.tsx","webpack://ReactCore/./src/components/widgets/WidgetList/WidgetList.style.tsx","webpack://ReactCore/./src/components/widgets/WidgetList/WidgetList.tsx","webpack://ReactCore/./src/components/widgets/namespace.ts","webpack://ReactCore/./src/components/widgets/components/WidgetUploader.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetArticleAttachmentWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetArticleButtonWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetArticleGalleryWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetArticleImageWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetArticleSliderWrapper.tsx","webpack://ReactCore/./src/hooks/useMarkdownModal.ts","webpack://ReactCore/./src/components/tinymce/extension/MarkdownModal.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetArticleTextWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetArticleTitleWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/components/WidgetRemove.tsx","webpack://ReactCore/./src/components/widgets/wrapper/components/WidgetFooterView.tsx","webpack://ReactCore/./src/components/widgets/wrapper/components/WidgetInlineInputText.tsx","webpack://ReactCore/./src/components/widgets/wrapper/components/WidgetIsPending.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetCheckListWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/utils.ts","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetDatasourceTableWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetExcelDatasourceTableWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetPresenceWrapperClosing.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetPresenceWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetQuickSurveyWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/components/OfficeConfigurationPrompt.tsx","webpack://ReactCore/./src/components/widgets/wrapper/components/WidgetIntranetTitle.tsx","webpack://ReactCore/./src/components/widgets/wrapper/components/WidgetHeader.tsx","webpack://ReactCore/./src/components/widgets/wrapper/WidgetContactCardDav/WidgetContactCardDavHeader.tsx","webpack://ReactCore/./src/components/widgets/wrapper/components/WidgetScroll.tsx","webpack://ReactCore/./src/components/widgets/wrapper/components/WidgetStylePadding.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetContactCardDavWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/WidgetCalendarCalDav/WidgetCalendarCalDavHeader.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetCalendarCalDavWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/WidgetEmailsImap/WidgetEmailsImapHeader.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetEmailsImapWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/components/WidgetTitle.tsx","webpack://ReactCore/./src/components/widgets/wrapper/components/WidgetTitleEdit.tsx","webpack://ReactCore/./src/components/widgets/wrapper/components/WidgetHeaderEdit.tsx","webpack://ReactCore/./src/components/widgets/Widget.tsx","webpack://ReactCore/./src/components/widgets/WidgetLayer/WidgetLayer.style.tsx","webpack://ReactCore/./src/components/widgets/WidgetLayer/WidgetLayer.tsx","webpack://ReactCore/./src/components/widgets/WidgetState.tsx","webpack://ReactCore/./src/components/widgets/WidgetWrapperCoreEditHover.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetIconWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/components/WidgetStyleWrapper.tsx","webpack://ReactCore/./src/components/widgets/WidgetWrapperCore.tsx","webpack://ReactCore/./src/components/comments/CommentsBloc.styles.ts","webpack://ReactCore/./src/components/comments/CommentsBlocAddCommentWidgetsWrapper.tsx","webpack://ReactCore/./src/components/comments/CommentsBlocCommentWidgetsWrapper.tsx","webpack://ReactCore/./src/components/CommentsBloc.tsx","webpack://ReactCore/./src/hooks/useCommentsLikeRT.ts","webpack://ReactCore/./src/displayer/DisplayForm.component.tsx","webpack://ReactCore/./src/components/Empty.tsx","webpack://ReactCore/./src/hooks/useAI.ts","webpack://ReactCore/./src/components/tinymce/JRCInputTinyMCEWithExt.tsx","webpack://ReactCore/./src/components/tinymce/JRCInputTinyMCEWithExtRaw.tsx","webpack://ReactCore/./src/components/modals/ModalAudience.tsx","webpack://ReactCore/./src/components/TwoColLayout.tsx"],"sourcesContent":["import { JRCAvatar, JRCAvatarProps } from 'jamespot-react-components';\r\nimport { Network } from 'jamespot-front-business';\r\nimport React from 'react';\r\nimport { useTheme } from 'styled-components';\r\nimport { commonComponentsRegistry } from '../registry/CommonRegistry';\r\nimport { useAppSelector } from '../redux/store';\r\n\r\nconst JRCIcon = commonComponentsRegistry.getLazyComponent('Icon');\r\n\r\nconst BASE_MULTIPLE = 8;\r\n\r\nexport const Avatar = (props: JRCAvatarProps) => {\r\n const theme = useTheme();\r\n const networkPublic = useAppSelector(Network.selectors.selectNetworkPublic);\r\n\r\n if (props.uri === networkPublic?.uri) {\r\n return (\r\n <JRCIcon\r\n name={'icon-fs-wall'}\r\n size={(props.size ?? 3) * BASE_MULTIPLE}\r\n color={theme.color.primary}\r\n variant={'circle'}\r\n />\r\n );\r\n }\r\n\r\n return <JRCAvatar {...props} />;\r\n};\r\n","import React, { useState } from 'react';\nimport styled, { useTheme } from 'styled-components';\nimport { useIntl } from 'react-intl';\nimport { Utils } from 'jamespot-react-components';\nimport { Avatar } from './Avatar';\nimport { jObjectLittle } from 'jamespot-user-api';\nimport { commonComponentsRegistry } from '../registry/CommonRegistry';\n\nconst JRCFlexBox = commonComponentsRegistry.getLazyComponent('FlexBox');\nconst JRCModalContent = commonComponentsRegistry.getLazyComponent('ModalContent');\nconst JRCModalLayout = commonComponentsRegistry.getLazyComponent('ModalLayout');\nconst JRCStyledHref = commonComponentsRegistry.getLazyComponent('StyledHref');\nconst JRCTooltip = commonComponentsRegistry.getLazyComponent('Tooltip');\nconst JRCTypography = commonComponentsRegistry.getLazyComponent('Typography');\n\nexport type AudienceProps<T extends jObjectLittle> = {\n audience: T[];\n limit?: number;\n};\n\nconst LIMIT = 2;\n\nconst AudienceWrapper = styled.div`\n display: flex;\n flex-direction: column;\n gap: 12px;\n margin-bottom: 24px;\n`;\n\nexport const AvatarLink = styled.a<{ overlap?: boolean }>`\n display: flex;\n justify-content: center;\n align-items: center;\n position: relative;\n width: 40px;\n height: 40px;\n border-radius: 40px;\n overflow: hidden;\n color: ${(props) => props.theme.color.white};\n background-color: ${(props) => props.theme.color.lavender};\n border: 4px solid ${(props) => props.theme.color.white};\n margin-left: ${(props) => (props.overlap ? '-18px' : '0')};\n cursor: pointer;\n`;\n\nexport const Audience = <T extends jObjectLittle>({ audience, limit = LIMIT }: AudienceProps<T>) => {\n const intl = useIntl();\n const theme = useTheme();\n const [isModalOpen, setModalOpen] = useState(false);\n\n return (\n <>\n <JRCFlexBox>\n {[...audience].splice(0, limit).map((item, index) => (\n <AvatarLink overlap={index !== 0} href={item._url} target={'_blank'} key={item.id}>\n <JRCTooltip description={item.title === undefined ? ' ' : item.title} position=\"left\">\n <Avatar\n uri={item.uri}\n size={4}\n variant=\"circle\"\n alt=\"image\"\n timestamp={item.dateModified ? Utils.date.strToTimestamp(item.dateModified) : undefined}\n focusable\n />\n </JRCTooltip>\n </AvatarLink>\n ))}\n {audience.length > limit && (\n <AvatarLink onClick={() => setModalOpen(true)} overlap={true}>\n +{audience.length - limit}\n </AvatarLink>\n )}\n </JRCFlexBox>\n {audience.length > limit && (\n <JRCModalLayout\n closeHandler={() => setModalOpen(false)}\n enableClickAwayCloseModal\n open={isModalOpen}\n variant={'fixed-height'}\n maxHeight={'800px'}>\n <JRCModalContent\n title={intl.formatMessage({ id: 'GLOBAL_Audience' })}\n overflow={'scroll'}\n onClickIconClose={() => setModalOpen(false)}>\n <AudienceWrapper>\n {audience.map((item, i) => (\n <JRCFlexBox key={`audience-${i}`} y={'center'} gap={theme.space.l}>\n <Avatar size={5} uri={`${item.type}/${item.id}`} />\n <JRCStyledHref href={`${item.type}/${item.id}`}>\n <JRCTypography>{item.title}</JRCTypography>\n </JRCStyledHref>\n </JRCFlexBox>\n ))}\n </AudienceWrapper>\n </JRCModalContent>\n </JRCModalLayout>\n )}\n </>\n );\n};\n","import jamespot from 'jamespot-user-api';\nimport React, { useCallback, useEffect, useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport styled, { useTheme } from 'styled-components';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { JiaTextEnhanceQuery } from '../../../hooks/useAI';\n\nconst JRCLoader = commonComponentsRegistry.getLazyComponent('Loader');\nconst JRCModalContent = commonComponentsRegistry.getLazyComponent('ModalContent');\nconst JRCModalLayout = commonComponentsRegistry.getLazyComponent('ModalLayout');\nconst JRCTypography = commonComponentsRegistry.getLazyComponent('Typography');\n\nconst TextWrapper = styled.div`\n padding: ${(props) => props.theme.space.md}px;\n`;\n\nexport type AIModalProps = {\n query: JiaTextEnhanceQuery | undefined;\n};\n\ntype ResponseType = {\n response: string | undefined;\n loading: boolean;\n error: string | undefined;\n};\n\nconst loadingResponse: ResponseType = {\n response: undefined,\n loading: true,\n error: undefined,\n};\n\nexport const AIModal = ({ query }: AIModalProps) => {\n const intl = useIntl();\n const [response, setResponse] = useState<ResponseType>(loadingResponse);\n const theme = useTheme();\n\n const sendAIRequest = useCallback(\n (query: JiaTextEnhanceQuery) => {\n setResponse(loadingResponse);\n jamespot.jia\n .textEnhancement({ text: query.text, capacity: query.capability })\n .then((response) => {\n if (response.error) {\n setResponse({\n error: `${intl.formatMessage({ id: 'JIA_ERROR_AI_CALL' })}${\n response.errorMsg && ': ' + response.errorMsg\n }`,\n loading: false,\n response: undefined,\n });\n return;\n }\n const textResponse = response.result.text;\n setResponse({\n error: undefined,\n loading: false,\n response: textResponse,\n });\n })\n .catch((_err) => {\n setResponse({\n error: intl.formatMessage({ id: 'JIA_ERROR_AI_CALL' }),\n loading: false,\n response: undefined,\n });\n });\n },\n [intl],\n );\n\n useEffect(() => {\n if (query && query.text.trim().length > 0) {\n sendAIRequest(query);\n }\n }, [query, sendAIRequest]);\n\n return (\n <JRCModalLayout\n zIndex={theme.zIndex.tinyMCEModal}\n open={!!query}\n closeHandler={() => {\n query?.reject();\n }}>\n <JRCModalContent\n overflow=\"scroll\"\n buttons={[\n {\n children: intl.formatMessage({ id: 'GLOBAL_Try_Again' }),\n clickHandler: () => {\n query && sendAIRequest(query);\n },\n },\n {\n children: intl.formatMessage({ id: 'GLOBAL_Validation' }),\n clickHandler: () => response.response && query?.resolve(response.response),\n },\n {\n children: intl.formatMessage({ id: 'GLOBAL_Cancel' }),\n clickHandler: () => query?.reject(),\n },\n ]}\n isFull>\n <TextWrapper>\n {response.loading && (\n <>\n <JRCLoader />\n <JRCTypography align=\"center\">\n {intl.formatMessage({ id: 'JIA_WAITING_WARNIG' })}\n </JRCTypography>\n </>\n )}\n {!response.loading && response.error && <p>{response.error}</p>}\n {!response.loading && response.response && <p>{response.response}</p>}\n </TextWrapper>\n </JRCModalContent>\n </JRCModalLayout>\n );\n};\n","export const EDITOR_TOP = 90;\nexport const EDITOR_WIDTH = 440;\nexport const EDITOR_MENU_WIDTH = 50;\nexport const EDITOR_CONTENT_WIDTH = EDITOR_WIDTH - EDITOR_MENU_WIDTH;\n","import styled from 'styled-components';\nimport { EDITOR_MENU_WIDTH, EDITOR_WIDTH } from './const';\nimport { DashedFocusBorder } from 'jamespot-react-components';\n\nconst INPUT_HEIGHT = 50;\nconst RADIUS = 8;\n\nexport const CSSEditorComponentWrapper = styled.div`\n margin-bottom: 24px;\n`;\n\nexport const CSSEditorComponentLabel = styled.div`\n margin-bottom: 4px;\n`;\n\nexport const CSSEditorPortal = styled.div<{ isActive: boolean }>`\n position: absolute;\n background-color: ${(props) => (props.isActive ? 'rgba(0,0,0,.1)' : 'transparent')};\n inset: 0;\n pointer-events: ${(props) => (props.isActive ? 'all' : 'none')};\n flex: 1;\n display: flex;\n overflow: hidden;\n`;\n\nexport const CSSEditorHeader = styled.div`\n flex-direction: row;\n display: flex;\n min-height: 60px;\n border-bottom: 1px solid ${(props) => props.theme.color.grey2};\n`;\n\nexport const CSSEditorAction = styled.div`\n width: 60px;\n display: flex;\n align-items: center;\n justify-content: center;\n`;\n\nexport const CSSEditorLabel = styled.div`\n flex: 1;\n display: flex;\n align-items: center;\n justify-content: center;\n`;\n\n// This is a mask to hide top shadow. EDITOR_WIDTH + 20 is used to keep the left shadow\nexport const CSSEditorMask = styled.div`\n position: relative;\n overflow: hidden;\n top: 0px;\n width: ${EDITOR_WIDTH + 20}px;\n`;\n\nexport const CSSEditor = styled.div<{ position: 'left' | 'right' }>`\n position: absolute;\n top: 0;\n ${(props) => (props.position === 'left' ? 'left: 0px;' : '')}\n ${(props) => (props.position === 'right' ? 'right: -1000px;' : '')}\n width: ${EDITOR_WIDTH}px;\n bottom: 00px;\n display: flex;\n background-color: ${(props) => props.theme.color.white};\n flex-direction: row;\n transition: all 0.4s;\n box-shadow: -4px 0px 20px 0px #00000017;\n\n &.animate {\n right: 0px;\n }\n`;\n\nexport const CSSEditorContent = styled.div`\n flex: 1;\n display: flex;\n flex-direction: column;\n padding: 12px;\n overflow: auto;\n margin-bottom: 12px;\n position: relative;\n`;\n\nexport const CSSEditorTab = styled.div`\n flex: 1;\n display: flex;\n flex-direction: column;\n`;\n\nexport const CSSEditorIsBusy = styled.div`\n position: absolute;\n inset: 0;\n background-color: rgba(255, 255, 255, 0.8);\n display: flex;\n align-items: center;\n justify-content: center;\n`;\n\nexport const CSSEditorIsLocked = styled.div`\n position: absolute;\n inset: 0;\n background-color: ${(props) => props.theme.color.white};\n padding: ${(props) => props.theme.space.md}px;\n`;\n\nexport const CSSEditorMenu = styled.div`\n width: ${EDITOR_MENU_WIDTH}px;\n padding-top: 60px;\n display: flex;\n flex-direction: column;\n border-right: 1px solid ${(props) => props.theme.color.grey2};\n`;\n\nexport const CSSEditorMenuButton = styled.button<{ isActive?: boolean }>`\n border-radius: 4px;\n cursor: pointer;\n height: 42px;\n margin: 4px;\n width: 42px;\n display: flex;\n align-items: center;\n justify-content: center;\n background-color: ${(props) => (props.isActive ? props.theme.color.grey2 : props.theme.color.white)};\n\n ${DashedFocusBorder()}\n\n &:hover {\n background-color: ${(props) => props.theme.color.grey2};\n }\n`;\n\nexport const CSSInputWrapper = styled.div`\n display: flex;\n border: 1px solid ${(props) => props.theme.color.grey1};\n border-radius: ${RADIUS}px;\n margin-bottom: 24px;\n input {\n width: 100%;\n border: 0;\n height: ${INPUT_HEIGHT}px;\n margin: 0;\n }\n`;\n\nexport const CSSEditorWidget = styled.div`\n display: flex;\n flex-direction: row;\n padding: 12px;\n background-color: ${(props) => props.theme.color.grey0};\n border-radius: 8px;\n margin-bottom: 4px;\n`;\n\nexport const CSSEditorWidgetLabel = styled.div`\n display: flex;\n flex: 1;\n align-items: center;\n`;\n\nexport const CSSEditorWidgetOption = styled.div`\n width: 40px;\n display: flex;\n justify-content: center;\n align-items: center;\n`;\n\nexport const CSSEditorLayer = styled.div`\n flex-direction: row;\n display: flex;\n align-items: center;\n`;\n\nexport const CSSEditorLayerTitle = styled.div`\n flex: 1;\n display: flex;\n align-items: center;\n`;\n","import React from 'react';\nimport { CSSEditorAction, CSSEditorHeader, CSSEditorLabel, CSSEditorMenuButton } from './style';\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\nimport { WidgetEditor } from 'jamespot-front-business';\nimport { useAppDispatch, useAppSelector } from '../../redux/store';\n\nconst JRCButton = commonComponentsRegistry.getLazyComponent('Button');\nconst JRCIcon = commonComponentsRegistry.getLazyComponent('Icon');\n\n/*\n Editor popup (center part)\n*/\nexport const EditorPopup = ({ uniqid }: { uniqid: string }) => {\n const dispatch = useAppDispatch();\n const editor = useAppSelector((state) => WidgetEditor.selectors.selectEditor(state, uniqid));\n\n const onClick = () => {\n dispatch(WidgetEditor.slice.actions.flushEditorPopup({ uniqid }));\n };\n\n const onSave = () => {\n dispatch(WidgetEditor.slice.actions.flushEditorPopup({ uniqid }));\n };\n\n if (editor && editor.popup && editor.view) {\n return (\n <div style={{ flex: 1, display: 'flex', flexDirection: 'column', backgroundColor: 'white', marginTop: 90 }}>\n <CSSEditorHeader>\n <CSSEditorAction />\n <CSSEditorLabel>Popup</CSSEditorLabel>\n <CSSEditorAction>\n <CSSEditorMenuButton onClick={onClick}>\n <JRCIcon name=\"icon-times\" color=\"grey2\" size={26.75} />\n </CSSEditorMenuButton>\n </CSSEditorAction>\n </CSSEditorHeader>\n <div style={{ flex: 1, display: 'flex' }}>{editor.view}</div>\n <CSSEditorHeader>\n <JRCButton onClick={onSave}>Save</JRCButton>\n </CSSEditorHeader>\n </div>\n );\n }\n\n return <></>;\n};\n","import { Hook, Toast, updateWidgetContent, Widget, WidgetEditor } from 'jamespot-front-business';\nimport jamespot, {\n CombinedWidgetContent,\n ensureWidgetArticleAttachmentType,\n ensureWidgetArticleButtonType,\n ensureWidgetArticleGalleryType,\n ensureWidgetArticleImageType,\n ensureWidgetArticleSliderType,\n ensureWidgetArticleTextType,\n ensureWidgetArticleTitleType,\n ensureWidgetCalendarCalDavType,\n ensureWidgetCheckListType,\n ensureWidgetContactCardDavType,\n ensureWidgetDatasourceTableType,\n ensureWidgetEmailsImapType,\n ensureWidgetExcelDatasourceTableType,\n ensureWidgetPresenceType,\n ensureWidgetQuickSurveyType,\n HookListType,\n WidgetArticleAttachmentContent,\n WidgetArticleButtonContent,\n WidgetArticleGalleryContent,\n WidgetArticleImageContent,\n WidgetArticleSliderContent,\n WidgetArticleTextContent,\n WidgetArticleTitleContent,\n WidgetCheckListContent,\n WidgetDatasourceTableContent,\n WidgetPresenceContent,\n WidgetQuickSurveyContent,\n WidgetStateProps,\n} from 'jamespot-user-api';\nimport React, { ReactElement } from 'react';\n\nimport { shallowEqual } from 'react-redux';\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\nimport { Utils } from 'jamespot-react-components';\nimport { store } from '../../redux/initStore';\nimport { useAppDispatch, useAppSelector } from '../../redux/store';\n\nconst WidgetArticleTitleEditor = commonComponentsRegistry.getLazyComponent('WidgetArticleTitleEditor');\nconst WidgetArticleTextEditor = commonComponentsRegistry.getLazyComponent('WidgetArticleTextEditor');\nconst WidgetArticleGalleryEditor = commonComponentsRegistry.getLazyComponent('WidgetArticleGalleryEditor');\nconst WidgetArticleAttachmentEditor = commonComponentsRegistry.getLazyComponent('WidgetArticleAttachmentEditor');\nconst WidgetArticleSliderEditor = commonComponentsRegistry.getLazyComponent('WidgetArticleSliderEditor');\n\nconst WidgetArticleImageEditor = commonComponentsRegistry.getLazyComponent('WidgetArticleImageEditor');\nconst WidgetButtonEditor = commonComponentsRegistry.getLazyComponent('WidgetButtonEditor');\nconst WidgetCheckListEditor = commonComponentsRegistry.getLazyComponent('WidgetCheckListEditor');\nconst WidgetQuickSurveyEditor = commonComponentsRegistry.getLazyComponent('WidgetQuickSurveyEditor');\n\nconst WidgetDatasourceTableEditor = commonComponentsRegistry.getLazyComponent('WidgetDatasourceTableEditor');\nconst WidgetExcelDatasourceTableEditor = commonComponentsRegistry.getLazyComponent('WidgetExcelDatasourceTableEditor');\n\nconst WidgetPresenceEditor = commonComponentsRegistry.getLazyComponent('WidgetPresenceEditor');\n\nconst WidgetEmailsImapEditor = commonComponentsRegistry.getLazyComponent('WidgetEmailsImapEditor');\nconst WidgetContactCardDavEditor = commonComponentsRegistry.getLazyComponent('WidgetContactCardDavEditor');\nconst WidgetCalendarCalDavEditor = commonComponentsRegistry.getLazyComponent('WidgetCalendarCalDavEditor');\n\n/*\n Editor Factory\n*/\nexport const Editor = ({ uniqid }: { uniqid: string }) => {\n const dispatch = useAppDispatch();\n const token = useAppSelector(Widget.selectors.selectToken);\n const widgetWrapper = useAppSelector((state) => Widget.selectors.selectWidget(state, uniqid), shallowEqual);\n\n const onSaveCallback = useAppSelector(\n (state) => WidgetEditor.selectors.selectEditor(state, uniqid)?.onSave,\n shallowEqual,\n );\n\n const handleHookIsActive = (name: keyof HookListType) => {\n return Hook.selectors.selectHook(store.getState(), name)?.isActive;\n };\n\n const onSave = (content: Partial<CombinedWidgetContent>) => {\n /*\n Update widget & Flush editor\n */\n if (widgetWrapper) {\n dispatch(Widget.slice.actions.updateWidget({ uniqid, content }));\n }\n\n dispatch(WidgetEditor.slice.actions.flushEditor({ uniqid }));\n\n if (onSaveCallback) {\n onSaveCallback(content);\n }\n };\n\n const onStateChange = (states: WidgetStateProps, id?: string) => {\n /*\n Set widget state (busy, loading, initialized)\n */\n if (id !== undefined) {\n dispatch(Widget.slice.actions.setWidgetState({ uniqid: id, ...states }));\n } else {\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, ...states }));\n }\n };\n\n const onOpen = (view: ReactElement) => {\n /*\n Register popup (central)\n */\n dispatch(WidgetEditor.slice.actions.registerEditorPopup({ uniqid, view }));\n };\n\n const widget = widgetWrapper?.widget;\n\n if (!widget) return null;\n\n if (ensureWidgetArticleButtonType(widget)) {\n return (\n <WidgetButtonEditor\n {...widget.content}\n onChange={(content) => {\n dispatch(updateWidgetContent<WidgetArticleButtonContent>(uniqid, content, false));\n }}\n onSave={() => onSave({})}\n />\n );\n } else if (ensureWidgetArticleGalleryType(widget)) {\n return (\n <WidgetArticleGalleryEditor\n token={token}\n content={widget.content}\n onChange={(content) =>\n dispatch(updateWidgetContent<WidgetArticleGalleryContent>(uniqid, content, false))\n }\n onSave={onSave}\n onStateChange={onStateChange}\n />\n );\n } else if (ensureWidgetArticleAttachmentType(widget)) {\n return (\n <WidgetArticleAttachmentEditor\n token={token}\n content={widget.content}\n onChange={(content) => {\n dispatch(updateWidgetContent<WidgetArticleAttachmentContent>(uniqid, content, false));\n }}\n onSave={onSave}\n onStateChange={onStateChange}\n onOpen={onOpen}\n />\n );\n } else if (ensureWidgetArticleImageType(widget)) {\n return (\n <WidgetArticleImageEditor\n content={widget.content}\n token={token}\n onChange={(content) => {\n dispatch(updateWidgetContent<WidgetArticleImageContent>(uniqid, content, false));\n }}\n onSave={onSave}\n onStateChange={onStateChange}\n />\n );\n } else if (ensureWidgetArticleSliderType(widget)) {\n return token !== undefined ? (\n <WidgetArticleSliderEditor\n slides={widget.content.slides ?? []}\n loop={widget.content.loop ?? false}\n useDots={widget.content.useDots ?? true}\n onChange={(content) => {\n dispatch(updateWidgetContent<WidgetArticleSliderContent>(uniqid, content, false));\n }}\n token={token}\n onSave={onSave}\n />\n ) : (\n <>Token is mandatory</>\n );\n } else if (ensureWidgetArticleTitleType(widget)) {\n return (\n <WidgetArticleTitleEditor\n onChange={(content) => {\n dispatch(updateWidgetContent<WidgetArticleTitleContent>(uniqid, content, false));\n }}\n onSave={onSave}\n content={widget.content}\n onOpen={onOpen}\n />\n );\n } else if (ensureWidgetArticleTextType(widget)) {\n return (\n <WidgetArticleTextEditor\n onChange={(content) => {\n dispatch(updateWidgetContent<WidgetArticleTextContent>(uniqid, content, false));\n }}\n onSave={onSave}\n content={widget.content}\n />\n );\n } else if (ensureWidgetPresenceType(widget)) {\n return (\n <WidgetPresenceEditor\n onChange={(content) => {\n dispatch(updateWidgetContent<WidgetPresenceContent>(uniqid, content, false));\n }}\n onSave={onSave}\n onStateChange={onStateChange}\n {...widget.content}\n />\n );\n } else if (ensureWidgetCheckListType(widget)) {\n return (\n <WidgetCheckListEditor\n token={token}\n uniqid={widget.uniqid}\n content={{\n ...widget.content,\n arr: widget.content.arr?.map((w) => ({\n ...w,\n title: Utils.html.htmlDecodeSpecialChars(w.title),\n })),\n }}\n onChangeContent={(uniqid, content) => {\n dispatch(updateWidgetContent(uniqid, content, false));\n }}\n onChangeWrapper={(content) => {\n dispatch(\n Widget.slice.actions.updateWidgetWrapper({\n ...content,\n title: Utils.html.htmlDecodeSpecialChars(content.title),\n }),\n );\n }}\n handleChange={(content) =>\n dispatch(updateWidgetContent<WidgetCheckListContent>(uniqid, content, false))\n }\n />\n );\n } else if (ensureWidgetQuickSurveyType(widget)) {\n return (\n <WidgetQuickSurveyEditor\n token={token}\n uniqid={widget.uniqid}\n content={widget.content}\n onChangeContent={(uniqid, content) => {\n dispatch(updateWidgetContent<WidgetQuickSurveyContent>(uniqid, content, false));\n }}\n onChangeWrapper={(content) => {\n dispatch(Widget.slice.actions.updateWidgetWrapper({ ...content }));\n }}\n handleChange={(content) =>\n dispatch(updateWidgetContent<WidgetQuickSurveyContent>(uniqid, content, false))\n }\n />\n );\n } else if (ensureWidgetExcelDatasourceTableType(widget)) {\n return (\n <WidgetExcelDatasourceTableEditor\n {...widget.content}\n uri={widget.content.uri}\n limit={widget.content.limit ?? 20}\n hook={{ isActive: handleHookIsActive }}\n handlers={{\n jamespot: {\n datasource: jamespot.datasource,\n network: jamespot.network,\n filebank: jamespot.filebank,\n wedoc: jamespot.wedoc,\n },\n handleStart: () => onStateChange({ busy: true }),\n handleCatch: (err) => dispatch(Toast.actions.error({ label: err.errorMsg })),\n handleFinally: () => onStateChange({ busy: false }),\n }}\n onSave={onSave}\n onChange={(content, override) =>\n dispatch(updateWidgetContent<WidgetDatasourceTableContent>(uniqid, content, override ?? false))\n }\n onStateChange={onStateChange}\n onError={(label) => dispatch(Toast.actions.error({ label }))}\n />\n );\n } else if (ensureWidgetEmailsImapType(widget)) {\n return <WidgetEmailsImapEditor />;\n } else if (ensureWidgetContactCardDavType(widget)) {\n return <WidgetContactCardDavEditor />;\n } else if (ensureWidgetCalendarCalDavType(widget)) {\n return <WidgetCalendarCalDavEditor />;\n } else if (ensureWidgetDatasourceTableType(widget)) {\n return (\n <WidgetDatasourceTableEditor\n {...widget.content}\n uri={widget.content.uri}\n limit={widget.content.limit ?? 20}\n hook={{ isActive: handleHookIsActive }}\n handlers={{\n jamespot: {\n datasource: jamespot.datasource,\n network: jamespot.network,\n application: jamespot.application,\n filebank: jamespot.filebank,\n },\n handleStart: () => onStateChange({ busy: true }),\n handleCatch: (err) => dispatch(Toast.actions.error({ label: err.errorMsg })),\n handleFinally: () => onStateChange({ busy: false }),\n }}\n onSave={onSave}\n onChange={(content, override) =>\n dispatch(updateWidgetContent<WidgetDatasourceTableContent>(uniqid, content, override ?? false))\n }\n onStateChange={onStateChange}\n onError={(label) => {\n dispatch(Toast.actions.error({ label }));\n }}\n />\n );\n } else {\n return <>cannot display editor</>;\n }\n};\n","import React from 'react';\nimport { CSSEditorAction, CSSEditorMenuButton } from './style';\nimport { WidgetEditor } from 'jamespot-front-business';\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\nimport { useAppDispatch } from '../../redux/store';\n\nconst Icon = commonComponentsRegistry.getLazyComponent('Icon');\n\nimport { useTheme } from 'styled-components';\n\nexport const EditorPosition = ({ uniqid, position }: { uniqid: string; position: 'left' | 'right' }) => {\n const dispatch = useAppDispatch();\n const theme = useTheme();\n const onClick = () => {\n dispatch(\n WidgetEditor.slice.actions.setEditorPosition({ uniqid, position: position === 'left' ? 'right' : 'left' }),\n );\n };\n\n return (\n <CSSEditorAction>\n <CSSEditorMenuButton onClick={onClick}>\n <Icon\n name={position === 'left' ? 'icon-angle-right' : 'icon-angle-left'}\n color={theme.color.lavender}\n size={26.75}\n />\n </CSSEditorMenuButton>\n </CSSEditorAction>\n );\n};\n","import React from 'react';\n\nimport styled, { useTheme } from 'styled-components';\nimport { useIntl, FormattedMessage } from 'react-intl';\n\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\n\nconst InputColorRaw = commonComponentsRegistry.getLazyComponent('InputColorRaw');\n\nexport const Label = styled.label`\n margin-left: 2px;\n margin-right: 2px;\n margin-bottom: 8px;\n font-size: 14px;\n width: 100%;\n min-height: 20px;\n`;\n\nexport const Fieldset = styled.fieldset`\n margin: 12px 0px !important;\n width: 100% !important;\n`;\n\nexport const EditorInputColor = ({\n label,\n initialValue,\n handleChange,\n}: {\n label: string;\n initialValue?: string;\n handleChange: (color: string) => void;\n}) => {\n const theme = useTheme();\n const intl = useIntl();\n\n const palettes = [\n {\n name: intl.formatMessage({ id: 'GLOBAL_Platform_Color' }),\n colors: [\n theme.color.primary,\n theme.color.secondary,\n theme.color.headerColor,\n theme.color.lavender,\n theme.color.orange,\n theme.color.green,\n theme.color.navy,\n theme.color.overseas,\n ],\n },\n ];\n\n return (\n <Fieldset>\n <Label>\n <FormattedMessage id={label} />\n </Label>\n <InputColorRaw\n palettes={palettes}\n label={label}\n initialValue={initialValue ?? theme.color.primary}\n name={`background-color`}\n onChange={handleChange}\n />\n </Fieldset>\n );\n};\n","import React from 'react';\n\nimport { useForm } from 'react-hook-form';\nimport { useIntl } from 'react-intl';\n\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\n\nconst JRCInputNumber = commonComponentsRegistry.getLazyComponent('InputNumber');\n\nexport const EditorInputNumber = ({\n label,\n initialValue,\n handleChange,\n}: {\n label: string;\n initialValue?: string;\n handleChange: (value: string) => void;\n}) => {\n const intl = useIntl();\n\n const { control, watch } = useForm({\n defaultValues: { value: initialValue ?? '0' },\n criteriaMode: 'all',\n });\n\n React.useEffect(() => {\n const subscription = watch((data) => {\n handleChange(data.value ?? '');\n });\n return () => subscription.unsubscribe();\n }, [watch, handleChange]);\n\n return (\n <JRCInputNumber\n label={label}\n name={'value'}\n width=\"100%\"\n control={control}\n placeholder={intl.formatMessage({ id: label })}\n />\n );\n};\n","import React, { useMemo } from 'react';\nimport { useForm } from 'react-hook-form';\nimport { useIntl } from 'react-intl';\n\nexport type EditorSelectOption = { label: string; value: string };\nexport type EditorSelectOptions = EditorSelectOption[];\n\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\n\nconst InputSelect = commonComponentsRegistry.getLazyComponent('InputSelect');\n\nexport const EditorInputSelect = ({\n label,\n options = [],\n initialValue,\n required = false,\n handleChange,\n}: {\n label: string;\n options: { label: string; value: string }[];\n initialValue?: string;\n required: boolean;\n handleChange: (value: string) => void;\n}) => {\n const intl = useIntl();\n\n const optionFromInitialValue = useMemo(() => {\n if (initialValue && options.find((el) => el.value === initialValue)) {\n return options.find((el) => el.value === initialValue);\n }\n\n return options[0];\n }, [initialValue, options]);\n\n const { control, watch } = useForm({\n defaultValues: { select: optionFromInitialValue },\n criteriaMode: 'all',\n });\n\n React.useEffect(() => {\n const subscription = watch((data: any) => {\n handleChange(data.select.value);\n });\n return () => subscription.unsubscribe();\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [watch, handleChange]);\n\n return (\n <InputSelect\n options={options}\n label={label}\n components={{\n Option: (o) => <span>{intl.formatMessage({ id: o.option.label })}</span>,\n }}\n getSearch={(o) => intl.formatMessage({ id: o.label })}\n rules={{ required }}\n hideDeleteIcon={true}\n required={required}\n control={control}\n name={'select'}\n />\n );\n};\n","import React, { useCallback, useEffect, useMemo } from 'react';\nimport { Widget } from 'jamespot-front-business';\nimport { useForm } from 'react-hook-form';\nimport { useIntl } from 'react-intl';\n\nimport { EditorInputColor } from './components/EditorInputColor';\nimport { EditorInputNumber } from './components/EditorInputNumber';\nimport { EditorInputSelect } from './components/EditorInputSelect';\n\nimport { useTheme } from 'styled-components';\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\nimport { useAppDispatch, useAppSelector } from '../../redux/store';\nimport { shallowEqual } from 'react-redux';\n\nconst JRCInputText = commonComponentsRegistry.getLazyComponent('InputText');\n\n/*\n Editor tab wrapper (this is all the properties available on a widget wrapper)\n*/\nexport const EditorTabWrapper = ({ uniqid }: { uniqid: string }) => {\n const intl = useIntl();\n const dispatch = useAppDispatch();\n const wrapper = useAppSelector((state) => Widget.selectors.selectWidget(state, uniqid));\n const theme = useTheme();\n\n const styles = useAppSelector((state) => Widget.selectors.selectWidgetTitleStyle(state, uniqid), shallowEqual);\n\n const { control, watch } = useForm({\n defaultValues: { text: wrapper?.title.replace(/&/g, '&') ?? '' },\n criteriaMode: 'all',\n });\n\n useEffect(() => {\n const subscription = watch((data: any) => {\n dispatch(Widget.slice.actions.updateWidgetWrapper({ uniqid, title: data.text }));\n });\n return () => subscription.unsubscribe();\n }, [watch, uniqid, dispatch]);\n\n const initialValues = useMemo(() => {\n return {\n color: styles && styles['color'] ? String(styles['color']) : theme.color.black,\n backgroundColor: styles && styles['background-color'] ? String(styles['background-color']) : 'transparent',\n fontSize: styles && styles['font-size'] ? String(styles['font-size']) : '24',\n fontWeight: styles && styles['font-weight'] ? String(styles['font-weight']) : 'medium',\n textAlign: styles && styles['text-align'] ? String(styles['text-align']) : 'left',\n };\n }, [styles, theme]);\n\n const handleChange = useCallback(\n (name: string, value: string | number) => {\n dispatch(\n Widget.slice.actions.setWidgetTitleStyle({\n uniqid,\n styles: { [name]: value },\n }),\n );\n },\n [dispatch, uniqid],\n );\n\n return wrapper ? (\n <>\n <JRCInputText\n name={'text'}\n label={'WIDGET_Title'}\n width=\"100%\"\n control={control}\n placeholder={intl.formatMessage({ id: 'WIDGET_Title' })}\n />\n <EditorInputColor\n label=\"STYLE_Text_Color\"\n initialValue={initialValues.color}\n handleChange={(colorValue) => handleChange('color', colorValue)}\n />\n <EditorInputColor\n label=\"STYLE_Background_Color\"\n initialValue={initialValues.backgroundColor}\n handleChange={(backgroundColorValue) => handleChange('background-color', backgroundColorValue)}\n />\n <EditorInputNumber\n label={'STYLE_Text_Size'}\n initialValue={initialValues.fontSize}\n handleChange={(fontSizeValue) => handleChange('font-size', fontSizeValue)}\n />\n <EditorInputSelect\n label={'STYLE_Font_Weight'}\n initialValue={initialValues.fontWeight}\n options={[\n { label: intl.formatMessage({ id: 'STYLE_Font_Weight_Normal' }), value: 'normal' },\n { label: intl.formatMessage({ id: 'STYLE_Font_Weight_Medium' }), value: 'medium' },\n { label: intl.formatMessage({ id: 'STYLE_Font_Weight_Bold' }), value: 'bold' },\n ]}\n required={false}\n handleChange={(fontWeightValue) => handleChange('font-weight', fontWeightValue)}\n />\n <EditorInputSelect\n label={'STYLE_Text_Align'}\n initialValue={initialValues.textAlign}\n options={[\n { label: intl.formatMessage({ id: 'STYLE_Text_Align_Left' }), value: 'left' },\n { label: intl.formatMessage({ id: 'STYLE_Text_Align_Center' }), value: 'center' },\n { label: intl.formatMessage({ id: 'STYLE_Text_Align_Justify' }), value: 'justify' },\n { label: intl.formatMessage({ id: 'STYLE_Text_Align_Right' }), value: 'right' },\n ]}\n required={false}\n handleChange={(textAlignValue) => handleChange('text-align', textAlignValue)}\n />\n </>\n ) : (\n <></>\n );\n};\n","import React from 'react';\nimport { shallowEqual } from 'react-redux';\nimport { CSSEditorIsBusy } from '../style';\nimport { Widget } from 'jamespot-front-business';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { useAppSelector } from '../../../redux/store';\n\nconst Loader = commonComponentsRegistry.getLazyComponent('Loader');\n\nexport const EditorIsBusy = ({ uniqid }: { uniqid: string }) => {\n const isBusy = useAppSelector((state) => Widget.selectors.selectWidgetState(state, uniqid), shallowEqual)?.busy;\n return (\n <>\n {isBusy && (\n <CSSEditorIsBusy>\n <Loader size={'l'} />\n </CSSEditorIsBusy>\n )}\n </>\n );\n};\n","import React from 'react';\n\nimport { useIntl } from 'react-intl';\nimport { CSSEditorIsLocked } from '../style';\nimport { shallowEqual } from 'react-redux';\nimport { Widget } from 'jamespot-front-business';\nimport { useAppSelector } from '../../../redux/store';\n\nexport const EditorIsLocked = ({ uniqid }: { uniqid: string }) => {\n const intl = useIntl();\n const isLocked = useAppSelector((state) => Widget.selectors.selectWidgetState(state, uniqid), shallowEqual)?.locked;\n return isLocked ? (\n <CSSEditorIsLocked>{intl.formatMessage({ id: 'INTRANET_Panel_Change_Off' })}</CSSEditorIsLocked>\n ) : (\n <></>\n );\n};\n","import React from 'react';\nimport { shallowEqual } from 'react-redux';\nimport { Toast, Widget, WidgetEditor } from 'jamespot-front-business';\nimport jApi, { CombinedWidgetContent, WidgetDisplayMode } from 'jamespot-user-api';\nimport { useIntl } from 'react-intl';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { useAppDispatch, useAppSelector } from '../../../redux/store';\n\nconst JRCButton = commonComponentsRegistry.getLazyComponent('Button');\n\nexport const EditorSave = ({ uniqid, mode }: { uniqid: string; mode: WidgetDisplayMode }) => {\n const intl = useIntl();\n const dispatch = useAppDispatch();\n const wrapper = useAppSelector((state) => Widget.selectors.selectWidget(state, uniqid), shallowEqual);\n const uri = useAppSelector((state) => Widget.selectors.selectWidgetObjectUri(state, uniqid), shallowEqual);\n\n const handleClick = () => {\n dispatch(WidgetEditor.slice.actions.flushEditor({ uniqid }));\n const content = wrapper && wrapper.widget && wrapper.widget.content;\n if (!uri || !wrapper || !content) return;\n if (mode == 'view') {\n jApi.widget\n .updateWidget<CombinedWidgetContent>({\n uri,\n uniqid: uniqid,\n title: wrapper.title,\n content: content as CombinedWidgetContent,\n v2: true,\n })\n .catch((e: any) => {\n dispatch(\n Toast.actions.error({\n label: e.errorMsg ?? intl.formatMessage({ id: 'GLOBAL_Error' }),\n }),\n );\n });\n }\n\n if (mode === 'edit') {\n dispatch(Widget.slice.actions.updateWidget({ uniqid, content: content as CombinedWidgetContent }));\n }\n };\n\n return (\n <JRCButton color=\"valid\" onClick={handleClick}>\n {intl.formatMessage({ id: 'GLOBAL_Save' })}\n </JRCButton>\n );\n};\n","import React, { useCallback, useMemo } from 'react';\n\nimport { useIntl } from 'react-intl';\n\nimport { useTheme } from 'styled-components';\n\nimport { shallowEqual } from 'react-redux';\nimport { Widget } from 'jamespot-front-business';\nimport { EditorInputNumber } from './components/EditorInputNumber';\nimport { EditorInputSelect } from './components/EditorInputSelect';\nimport { EditorInputColor } from './components/EditorInputColor';\n\nimport { useAppSelector, useAppDispatch } from '../../redux/store';\n\nexport const EditorTabWidgetSelection = ({ uniqid }: { uniqid: string }) => {\n const theme = useTheme();\n const dispatch = useAppDispatch();\n const intl = useIntl();\n\n const styles = useAppSelector((state) => Widget.selectors.selectWidgetWrapperStyle(state, uniqid), shallowEqual);\n\n const initialValues = useMemo(() => {\n return {\n color: styles && styles['color'] ? String(styles['color']) : theme.color.black,\n backgroundColor:\n styles && styles['background-color'] ? String(styles['background-color']) : theme.color.white,\n padding: styles && styles['padding'] ? String(styles['padding']) : '0',\n borderRadius: styles && styles['border-radius'] ? String(styles['border-radius']) : '0',\n borderColor: styles['border-color'] ? String(styles['border-color']) : theme.color.black,\n borderWidth: styles['border-width'] ? String(styles['border-width']) : '0',\n borderStyle: styles['border-style'] ? String(styles['border-style']) : 'none',\n };\n }, [styles, theme]);\n\n const handleChange = useCallback(\n (name: string, value: string) => {\n dispatch(\n Widget.slice.actions.setWidgetWrapperStyle({\n uniqid,\n styles: { [name]: value },\n }),\n );\n },\n [uniqid, dispatch],\n );\n\n return (\n <>\n <EditorInputColor\n label={'STYLE_Background_Color'}\n initialValue={initialValues.backgroundColor}\n handleChange={(backgroundColorValue) => handleChange('background-color', backgroundColorValue)}\n />\n <EditorInputColor\n label={'STYLE_Text_Color'}\n initialValue={initialValues.color}\n handleChange={(color) => handleChange('color', color)}\n />\n <hr />\n <EditorInputNumber\n label={'STYLE_Padding'}\n initialValue={initialValues.padding}\n handleChange={(paddingValue) => handleChange('padding', String(paddingValue))}\n />\n <EditorInputNumber\n label={'STYLE_Radius'}\n initialValue={initialValues.borderRadius}\n handleChange={(borderRadiusValue) => handleChange('border-radius', String(borderRadiusValue))}\n />\n <EditorInputSelect\n label={'STYLE_Border_Style'}\n initialValue={initialValues.borderStyle}\n options={[\n { label: intl.formatMessage({ id: 'STYLE_Border_Style_None' }), value: 'none' },\n { label: intl.formatMessage({ id: 'STYLE_Border_Style_Solid' }), value: 'solid' },\n { label: intl.formatMessage({ id: 'STYLE_Border_Style_Dashed' }), value: 'dashed' },\n { label: intl.formatMessage({ id: 'STYLE_Border_Style_Dotted' }), value: 'dotted' },\n ]}\n required={false}\n handleChange={(borderStyleValue) => {\n handleChange('border-style', borderStyleValue);\n borderStyleValue !== 'none' && handleChange('border-color', theme.color.black);\n borderStyleValue !== 'none' && handleChange('border-width', '1');\n }}\n />\n {styles['border-style'] !== 'none' && (\n <EditorInputColor\n label={'STYLE_Border_Color'}\n initialValue={initialValues.borderColor}\n handleChange={(borderColorValue) => handleChange('border-color', borderColorValue)}\n />\n )}\n {styles['border-style'] !== 'none' && (\n <EditorInputNumber\n label={'STYLE_Border_Width'}\n initialValue={initialValues.borderWidth}\n handleChange={(borderWidthValue) => handleChange('border-width', borderWidthValue)}\n />\n )}\n </>\n );\n};\n","import React, { useCallback } from 'react';\nimport { shallowEqual } from 'react-redux';\nimport { WidgetEditor, Widget } from 'jamespot-front-business';\nimport { useIntl } from 'react-intl';\n\nimport { EditorInputSelect } from './components/EditorInputSelect';\nimport { useAppDispatch, useAppSelector } from '../../redux/store';\n\n/**\n *\n * level 1 : Icon only (iOS like)\n * level 2 : Icon + Notification cell (iOS like)\n * level 3 : Default display\n * Level 4 : ???\n *\n */\nexport const EditorTabDisplayLevel = ({ uniqid }: { uniqid: string }) => {\n const dispatch = useAppDispatch();\n const intl = useIntl();\n const editor = useAppSelector((state) => WidgetEditor.selectors.selectEditor(state, uniqid), shallowEqual);\n const def = Widget.definition(editor?.name);\n const level = useAppSelector((state) => Widget.selectors.selectWidgetLevel(state, uniqid), shallowEqual);\n\n const handleChange = useCallback(\n (level: string) => {\n dispatch(Widget.slice.actions.updateWidgetWrapper({ uniqid, level: Number(level) as 1 | 2 | 3 | 4 }));\n },\n [uniqid, dispatch],\n );\n\n return (\n <EditorInputSelect\n handleChange={handleChange}\n required={true}\n label={'WIDGET_Display_Level_Select'}\n initialValue={level ? String(level) : '3'}\n options={[\n { label: intl.formatMessage({ id: 'WIDGET_Display_Level_1' }), value: '1' },\n { label: intl.formatMessage({ id: 'WIDGET_Display_Level_2' }), value: '2' },\n { label: intl.formatMessage({ id: 'WIDGET_Display_Level_3' }), value: '3' },\n { label: intl.formatMessage({ id: 'WIDGET_Display_Level_4' }), value: '4' },\n ].filter((el) =>\n Array.isArray(def.displayLevel) ? def.displayLevel.includes(Number(el.value) as 1 | 2 | 3 | 4) : [],\n )}\n />\n );\n};\n","import React, { useEffect, useMemo, useRef, useState } from 'react';\nimport { shallowEqual } from 'react-redux';\nimport { Editor } from './Editor';\nimport {\n CSSEditor,\n CSSEditorAction,\n CSSEditorContent,\n CSSEditorTab,\n CSSEditorHeader,\n CSSEditorLabel,\n CSSEditorMask,\n CSSEditorMenu,\n CSSEditorMenuButton,\n} from './style';\nimport { Widget, WidgetEditor } from 'jamespot-front-business';\nimport { useIntl } from 'react-intl';\nimport { EDITOR_CONTENT_WIDTH } from './const';\nimport { EditorPosition } from './EditorPosition';\nimport { EditorTabWrapper } from './EditorTabWrapper';\nimport { EditorIsBusy } from './states/EditorIsBusy';\nimport { EditorIsLocked } from './states/EditorIsLocked';\n\nimport { EditorSave } from './components/EditorSave';\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\nimport { useAppDispatch, useAppSelector } from '../../redux/store';\nimport { useTheme } from 'styled-components';\nimport { EditorTabWidgetSelection } from './EditorTabWidgetSelection';\nimport { EditorTabDisplayLevel } from './EditorTabDisplayLevel';\n\nconst OVERRIDE_SAVE = [\n 'widget-presence',\n 'widget-quick-survey',\n 'widget-check-list',\n 'widget-emails-imap',\n 'widget-contact-cardDav',\n 'widget-calendar-calDav',\n];\n\nconst Icon = commonComponentsRegistry.getLazyComponent('Icon');\nconst Tooltip = commonComponentsRegistry.getLazyComponent('Tooltip');\n\ntype EditorTabs = 'widget-settings' | 'widget-title' | 'widget-selection' | 'widget-level';\ntype EditorTab = {\n name: EditorTabs;\n label: string;\n icon: string;\n enable: boolean;\n};\n\n/*\n Editor wrapper (right part)\n*/\nexport const EditorWrapper = ({ uniqid, position }: { uniqid: string; position: 'left' | 'right' }) => {\n const intl = useIntl();\n const dispatch = useAppDispatch();\n const theme = useTheme();\n const ref = useRef<HTMLDivElement>(null);\n const editor = useAppSelector((state) => WidgetEditor.selectors.selectEditor(state, uniqid), shallowEqual);\n\n const def = Widget.definition(editor?.name);\n\n const enableWidgetLevel = useMemo<boolean>(() => {\n return def.displayLevel !== undefined && Array.isArray(def.displayLevel) && def.displayLevel.length !== 0;\n }, [def]);\n const tabs: EditorTab[] = useMemo(() => {\n return [\n {\n name: 'widget-title',\n label: intl.formatMessage({ id: 'PANEL_Title' }),\n enable: def.panel.useWrapper,\n icon: 'icon-font',\n },\n {\n name: 'widget-selection',\n label: intl.formatMessage({ id: 'PANEL_Widget_Selection' }),\n enable: def.panel.useSelection,\n icon: 'icon-sliders',\n },\n {\n name: 'widget-settings',\n label: intl.formatMessage({ id: 'PANEL_Widget_Settings' }),\n enable: def.panel.useEditor,\n icon: 'icon-pen',\n },\n {\n name: 'widget-level',\n label: intl.formatMessage({ id: 'PANEL_Widget_Level' }),\n enable: enableWidgetLevel,\n icon: 'icon-edit',\n },\n ];\n }, [def, intl, enableWidgetLevel]);\n\n const defaultTab = useMemo<EditorTab | undefined>(() => {\n if (def.panel.useEditor) {\n return tabs.find((el) => el.name === 'widget-settings');\n }\n\n return tabs.filter((el) => el.enable)[0];\n }, [def, tabs]);\n\n const [currentTab, setCurrentTab] = useState<EditorTab | undefined>(defaultTab);\n\n const onClose = () => {\n dispatch(WidgetEditor.slice.actions.flushEditor({ uniqid }));\n };\n\n useEffect(() => {\n setTimeout(() => {\n if (ref && ref.current) {\n ref.current.className = ref.current.className + ' animate';\n }\n }, 0);\n }, []);\n\n return editor ? (\n <CSSEditorMask>\n <CSSEditor ref={ref} position={position}>\n <CSSEditorMenu>\n {tabs.map((tab) => {\n return tab.enable ? (\n <Tooltip key={tab.name} position={'left'} description={tab.label}>\n <CSSEditorMenuButton\n isActive={currentTab && currentTab.name === tab.name}\n onClick={() => setCurrentTab(tab)}>\n <Icon\n name={tab.icon}\n color={\n currentTab && currentTab.name === tab.name\n ? theme.color.white\n : theme.color.lavender\n }\n />\n </CSSEditorMenuButton>\n </Tooltip>\n ) : (\n <></>\n );\n })}\n </CSSEditorMenu>\n <div style={{ flex: 1, display: 'flex', flexDirection: 'column', width: `${EDITOR_CONTENT_WIDTH}px` }}>\n <CSSEditorHeader>\n <EditorPosition uniqid={uniqid} position={editor.position} />\n <CSSEditorLabel>\n <h3>{currentTab ? currentTab.label : intl.formatMessage({ id: def.label })}</h3>\n </CSSEditorLabel>\n <CSSEditorAction>\n <CSSEditorMenuButton onClick={onClose}>\n <Icon name=\"icon-times\" color={theme.color.lavender} size={26.75} />\n </CSSEditorMenuButton>\n </CSSEditorAction>\n </CSSEditorHeader>\n <CSSEditorContent>\n <CSSEditorTab>\n {currentTab && currentTab.name === 'widget-settings' && def.panel.useEditor && (\n <Editor uniqid={editor.uniqid} />\n )}\n {currentTab && currentTab.name === 'widget-title' && def.panel.useWrapper && (\n <EditorTabWrapper uniqid={editor.uniqid} />\n )}\n {currentTab && currentTab.name === 'widget-selection' && (\n <EditorTabWidgetSelection uniqid={uniqid} />\n )}\n {currentTab && currentTab.name === 'widget-level' && enableWidgetLevel && (\n <EditorTabDisplayLevel uniqid={uniqid} />\n )}\n </CSSEditorTab>\n <EditorIsBusy uniqid={uniqid} />\n <EditorIsLocked uniqid={uniqid} />\n {OVERRIDE_SAVE.includes(editor.name) && <EditorSave uniqid={uniqid} mode={editor.mode} />}\n </CSSEditorContent>\n </div>\n </CSSEditor>\n {editor?.popup ? (\n <div style={{ position: 'absolute', inset: 0, backgroundColor: '#000', opacity: '.7' }}></div>\n ) : (\n <></>\n )}\n </CSSEditorMask>\n ) : (\n <></>\n );\n};\n","import React, { useEffect } from 'react';\n\nimport { shallowEqual } from 'react-redux';\n\nimport { EDITOR_TOP, EDITOR_WIDTH } from './const';\nimport { EditorPopup } from './EditorPopup';\nimport { EditorWrapper } from './EditorWrapper';\nimport { CSSEditorPortal } from './style';\nimport { WidgetEditor } from 'jamespot-front-business';\n\nimport styled from 'styled-components';\nimport { useAppDispatch, useAppSelector } from '../../redux/store';\n\nexport const CSSEditorPortalWrapper = styled.div`\n position: absolute;\n inset: 0;\n pointer-events: none;\n z-index: 1;\n`;\n\nexport const CSSEditorPortalPopupWrapper = styled.div<{ isActive: boolean }>`\n flex: 1;\n display: flex;\n margin-top: ${EDITOR_TOP}px;\n pointer-events: ${(props) => (props.isActive ? 'all' : 'none')};\n`;\n\nexport const CSSEditorPortalRow = styled.div`\n flex: 1;\n display: flex;\n flex-direction: row;\n pointer-events: none;\n`;\n\nexport const CSSEditorPortalFreeSpace = styled.div`\n width: ${EDITOR_WIDTH}px;\n pointer-events: none;\n`;\n\n/*\n Editors wrapper (template)\n*/\nexport const EditorsPortal = () => {\n const dispatch = useAppDispatch();\n useEffect(() => {\n const flush = () => {\n dispatch(WidgetEditor.slice.actions.flushAllEditor());\n };\n\n window.addEventListener('NGWidgetEditorFlushAll', flush);\n return () => {\n window.removeEventListener('NGWidgetEditorFlushAll', flush);\n };\n }, [dispatch]);\n\n const editors = useAppSelector(WidgetEditor.selectors.selectEditors, shallowEqual);\n\n return (\n <CSSEditorPortalWrapper className=\"editor-portal-wrapper\">\n {editors.map((editor) => {\n return (\n <CSSEditorPortal isActive={false} key={editor.uniqid}>\n <CSSEditorPortalRow>\n {editor.position === 'left' ? (\n <>\n <EditorWrapper uniqid={editor.uniqid} position={editor.position}></EditorWrapper>\n <CSSEditorPortalPopupWrapper isActive={editor.popup !== undefined}>\n <EditorPopup uniqid={editor.uniqid} />\n </CSSEditorPortalPopupWrapper>\n <CSSEditorPortalFreeSpace />\n </>\n ) : (\n <>\n <CSSEditorPortalFreeSpace />\n <CSSEditorPortalPopupWrapper isActive={editor.popup !== undefined}>\n <EditorPopup uniqid={editor.uniqid} />\n </CSSEditorPortalPopupWrapper>\n <EditorWrapper uniqid={editor.uniqid} position={editor.position}></EditorWrapper>\n </>\n )}\n </CSSEditorPortalRow>\n </CSSEditorPortal>\n );\n })}\n </CSSEditorPortalWrapper>\n );\n};\n","import React, { useMemo } from 'react';\nimport { createPortal } from 'react-dom';\nimport { v4 as uuidv4 } from 'uuid';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { EditorsPortal } from '../../editors/EditorsPortal';\n\nconst JRCThemeProvider = commonComponentsRegistry.getLazyComponent('ThemeProvider');\n\nconst createPortalElement = (parent: HTMLElement): HTMLDivElement => {\n let portal = document.getElementById('react-portals') as HTMLDivElement;\n\n if (!portal) {\n portal = document.createElement('div');\n portal.id = uuidv4();\n parent.appendChild(portal);\n }\n\n return portal;\n};\nexport const EditorsPanel = () => {\n const portalDiv = document.getElementById('react-portals');\n const portal = useMemo(() => portalDiv && createPortalElement(portalDiv), [portalDiv]);\n\n if (!portal) {\n return null;\n }\n return createPortal(\n <JRCThemeProvider>\n <EditorsPortal />\n </JRCThemeProvider>,\n portal,\n );\n};\n","import { DashedFocusBorder } from 'jamespot-react-components';\nimport styled from 'styled-components';\n\nexport const CSSSquareWidgetWrapper = styled.div`\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n gap: 10px;\n justify-content: center;\n`;\n\nexport const CSSSquareWidget = styled.div<{ available: boolean }>`\n border: 1px solid ${(props) => props.theme.color.grey2};\n border-radius: 8px;\n cursor: pointer;\n padding: 12px;\n position: relative;\n opacity: ${(props) => (props.available ? '1' : '.4')};\n pointer-events: ${(props) => (props.available ? 'all' : 'none')};\n\n .show-on-hover {\n position: absolute;\n inset: 0;\n border-radius: 8px;\n justify-content: center;\n align-items: center;\n display: flex;\n opacity: 0;\n background-color: #ffffffe6;\n }\n\n &:hover {\n .show-on-hover {\n opacity: 1;\n }\n }\n`;\n\nexport const CSSWidgetButton = styled.div<{ open: boolean; height: number }>`\n border: 2px solid ${(props) => props.theme.color.primary};\n height: ${(props) => (props.open ? props.height : '54')}px;\n border-radius: 8px;\n display: flex;\n justify-content: top;\n flex-direction: column;\n transition: height 0.4s;\n overflow: hidden;\n flex-direction: column;\n`;\n\nexport const CSSWrapWidgetWrapper = styled.div<{ column?: boolean }>`\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n justify-content: center;\n gap: 10px;\n ${(props) => props.column && `flex-direction: column;`}\n`;\n\nexport const CSSWrapTitle = styled.div`\n min-height: 50px;\n display: flex;\n justify-content: center;\n align-items: center;\n cursor: pointer;\n color: ${(props) => props.theme.color.primary};\n &:hover {\n background-color: ${(props) => props.theme.color.grey0};\n }\n`;\n\nexport const CSSWrapWidget = styled.button<{ open: boolean; index: number; full?: boolean; parentIsColumn?: boolean }>`\n display: flex;\n align-items: center;\n padding: ${(props) => (props.parentIsColumn ? '36px 16px' : '0 10px')};\n gap: 10px;\n width: 40%;\n border: 1px solid ${(props) => props.theme.color.grey1};\n border-radius: 8px;\n transition: opacity 0.4s ease ${(props) => props.index * 40}ms;\n opacity: ${(props) => (props.open ? 1 : 0)};\n img {\n width: 40px;\n }\n ${(props) => props.full && `flex: 1; width: 100%;`}\n ${(props) => props.parentIsColumn && `flex-basis: 72px;`}\n ${(props) => !props.parentIsColumn && `height: 72px;`}\n &:hover {\n background-color: ${(props) => props.theme.color.grey0};\n }\n\n ${DashedFocusBorder()}\n`;\n\nexport const Flex = styled.div<{ direction: 'row' | 'column'; gap?: number }>`\n display: flex;\n flex-direction: ${(props) => (props.direction === 'row' ? 'row' : 'column')};\n align-items: ${(props) => (props.direction === 'row' ? 'center' : 'flex-start')};\n justify-content: ${(props) => (props.direction === 'row' ? 'flex-start' : 'center')};\n flex: 1;\n ${(props) => props.gap && `gap:${props.gap}px`}\n`;\n","import React, { useMemo, useState } from 'react';\nimport { FormattedMessage, useIntl } from 'react-intl';\nimport { WidgetDefinitionProps, WidgetKeys, WidgetWrapperProps } from 'jamespot-user-api';\nimport { Widget } from 'jamespot-front-business';\nimport { JRCModalLayoutProps } from 'jamespot-react-components';\nimport { getBuilderWidgets } from '../namespace';\nimport {\n CSSSquareWidget,\n CSSSquareWidgetWrapper,\n CSSWidgetButton,\n CSSWrapTitle,\n CSSWrapWidget,\n CSSWrapWidgetWrapper,\n Flex,\n} from './WidgetList.style';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\n\nconst JRCButton = commonComponentsRegistry.getLazyComponent('Button');\nconst JRCModalLayout = commonComponentsRegistry.getLazyComponent('ModalLayout');\nconst JRCModalContent = commonComponentsRegistry.getLazyComponent('ModalContent');\nconst JRCTooltip = commonComponentsRegistry.getLazyComponent('Tooltip');\nconst JRCIconButton = commonComponentsRegistry.getLazyComponent('IconButton');\n\ntype WidgetListMode = 'button' | 'list' | 'gallery' | 'custom' | 'article' | 'comment';\n\n/*\n Widget Builder\n*/\nexport const WidgetList = ({\n mode,\n view,\n children,\n namespace = 'default',\n onChange,\n}: {\n mode?: WidgetListMode;\n view?: string;\n children?: any;\n namespace?: string;\n onChange: (widget: WidgetWrapperProps) => void;\n}) => {\n const [isOpen, setOpen] = useState<boolean>(false);\n const widgets = getBuilderWidgets(namespace);\n const intl = useIntl();\n\n const args: JRCModalLayoutProps = {\n open: isOpen,\n portalId: 'react-modal',\n variant: 'full-height',\n closeHandler: () => setOpen(false),\n };\n\n const onClick = (name: WidgetKeys) => {\n onChange(Widget.factory(name));\n setOpen(false);\n };\n return (\n <>\n <JRCModalLayout {...args}>\n <JRCModalContent\n onClickIconClose={args.closeHandler}\n buttons={\n mode === 'comment'\n ? [\n {\n children: <FormattedMessage id=\"GLOBAL_Close\" />,\n color: 'cancel',\n clickHandler: () => setOpen(false),\n },\n ]\n : undefined\n }\n title={intl.formatMessage({ id: 'WIDGET_Builder' })}>\n {mode === 'comment' ? (\n <CSSWrapWidgetWrapper column>\n {widgets.map((widget, index) => (\n <CSSWrapWidget\n key={widget.name}\n open={true}\n full\n parentIsColumn\n index={index}\n onClick={() => onClick(widget.name)}>\n <Flex direction={'row'} gap={12}>\n <img src={widget.img} />\n <Flex direction={'column'}>\n <h3>{intl.formatMessage({ id: widget.label })}</h3>\n <p>{intl.formatMessage({ id: widget.description })}</p>\n </Flex>\n </Flex>\n </CSSWrapWidget>\n ))}\n </CSSWrapWidgetWrapper>\n ) : (\n <CSSSquareWidgetWrapper>\n {widgets.map((widget, index: number) => {\n return (\n <CSSSquareWidget\n key={index}\n onClick={() => onClick(widget.name)}\n available={widget.available}>\n <img src={widget.img} />\n <div className=\"show-on-hover\">{intl.formatMessage({ id: widget.label })}</div>\n </CSSSquareWidget>\n );\n })}\n </CSSSquareWidgetWrapper>\n )}\n </JRCModalContent>\n </JRCModalLayout>\n {mode === 'custom' && children ? <div onClick={() => setOpen(true)}>{children}</div> : <></>}\n {mode === 'button' && view === 'edit' ? (\n <JRCButton onClick={() => setOpen(true)} variant={'outlined'} minWidth={'100%'}>\n {intl.formatMessage({ id: 'WIDGET_Add_Widget' })}\n </JRCButton>\n ) : (\n <></>\n )}\n {mode === 'gallery' && view === 'edit' ? (\n <CSSSquareWidgetWrapper>\n {widgets.map((widget, index: number) => {\n return (\n <CSSSquareWidget\n key={index}\n onClick={() => onClick(widget.name)}\n available={widget.available}>\n <img src={widget.img} />\n <div className=\"show-on-hover\">{intl.formatMessage({ id: widget.label })}</div>\n </CSSSquareWidget>\n );\n })}\n </CSSSquareWidgetWrapper>\n ) : (\n <></>\n )}\n {mode === 'article' && view === 'edit' ? <WidgetModeArticle widgets={widgets} onClick={onClick} /> : <></>}\n {mode === 'comment' && view === 'edit' ? (\n <WidgetModeComment\n onClick={() => {\n setOpen(true);\n }}\n />\n ) : (\n <></>\n )}\n </>\n );\n};\n\nconst HEIGHT_CLOSED = 50;\nconst HEIGHT = 80;\nconst MARGIN_BOTTOM = 10;\n\nconst WidgetModeArticle = ({\n widgets,\n onClick,\n}: {\n widgets: WidgetDefinitionProps[];\n onClick: (name: WidgetKeys) => void;\n}) => {\n const [open, isOpen] = useState(false);\n const intl = useIntl();\n\n const calcHeight = useMemo(() => {\n return Math.ceil(widgets.length / 2) * HEIGHT + HEIGHT_CLOSED + MARGIN_BOTTOM;\n }, [widgets]);\n\n return (\n <>\n <CSSWidgetButton open={open} height={calcHeight}>\n <CSSWrapTitle onClick={() => isOpen(!open)}>\n {intl.formatMessage({ id: 'WIDGET_Add_Widget' })}\n </CSSWrapTitle>\n <CSSWrapWidgetWrapper>\n {widgets.map((widget, index) => {\n return (\n <CSSWrapWidget\n key={widget.name}\n open={open}\n index={index}\n onClick={() => onClick(widget.name)}>\n <img src={widget.img} />\n {intl.formatMessage({ id: widget.label })}\n </CSSWrapWidget>\n );\n })}\n </CSSWrapWidgetWrapper>\n </CSSWidgetButton>\n </>\n );\n};\n\nconst WidgetModeComment = ({ onClick }: { onClick: () => void }) => {\n const intl = useIntl();\n return (\n <>\n <JRCTooltip description={intl.formatMessage({ id: 'COMMENT_Add_Widget' })}>\n <JRCIconButton\n bg={'grey1'}\n bgHover={'grey2'}\n color={'grey5'}\n iconSize={22}\n onClick={() => {\n onClick();\n }}\n icon={'icon-fs-puzzle'}\n />\n </JRCTooltip>\n </>\n );\n};\n","import { Widget } from 'jamespot-front-business';\nimport { WidgetDefinitionProps, WidgetsName } from 'jamespot-user-api';\n\nexport function getBuilderWidgets(namespace: string): WidgetDefinitionProps[] {\n switch (namespace) {\n case 'widget-article-image':\n return [Widget.definition(WidgetsName.ArticleTitle), Widget.definition(WidgetsName.ArticleButton)];\n case 'comment':\n return [\n Widget.definition(WidgetsName.CheckList),\n Widget.definition(WidgetsName.Presence),\n Widget.definition(WidgetsName.QuickSurvey),\n ];\n default:\n return [\n Widget.definition(WidgetsName.ArticleTitle),\n Widget.definition(WidgetsName.ArticleText),\n Widget.definition(WidgetsName.ArticleImage),\n Widget.definition(WidgetsName.ArticleButton),\n Widget.definition(WidgetsName.ArticleSlider),\n Widget.definition(WidgetsName.ArticleAttachment),\n Widget.definition(WidgetsName.Presence),\n ];\n }\n}\n","import React, { ReactNode, useEffect, useRef, useState } from 'react';\nimport { jFileLittle } from 'jamespot-user-api';\nimport { Widget } from 'jamespot-front-business';\nimport styled from 'styled-components';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { useAppSelector } from '../../../redux/store';\n\nconst JRCInputFileAdvancedRaw = commonComponentsRegistry.getLazyComponent('InputFileAdvancedRaw');\n\nexport const CSSHidden = styled.div`\n width: 0;\n height: 0;\n overflow: hidden;\n`;\n\ntype InplaceUploaderProps = {\n children: ReactNode;\n initialFiles: jFileLittle[];\n initialClick?: boolean;\n multiple: boolean;\n accept: string;\n onUploadStart: () => void;\n onUploadEnd: () => void;\n onUploadSuccess: (files: jFileLittle[]) => void;\n};\n\nexport const WidgetUploader = ({\n children,\n initialFiles,\n initialClick,\n multiple,\n accept,\n onUploadStart,\n onUploadEnd,\n onUploadSuccess,\n}: InplaceUploaderProps) => {\n const uploadRef = useRef<HTMLInputElement>(null);\n const token = useAppSelector(Widget.selectors.selectToken);\n const [total, setTotal] = useState<number>(0);\n const [files, setFiles] = useState<jFileLittle[]>(initialFiles);\n\n useEffect(() => {\n if (initialClick) {\n uploadRef.current?.click();\n }\n }, [initialClick]);\n\n useEffect(() => {\n if (initialFiles.length !== files.length) {\n setFiles(initialFiles);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [initialFiles]);\n\n useEffect(() => {\n onUploadSuccess(files);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [files]);\n\n useEffect(() => {\n if (total === 0) {\n onUploadEnd();\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [total]);\n\n return (\n <>\n <div\n onClick={() => {\n if (initialClick) {\n uploadRef.current?.click();\n }\n }}>\n {children}\n </div>\n <CSSHidden>\n <JRCInputFileAdvancedRaw\n ref={uploadRef}\n id=\"widget-upload-file\"\n name=\"editorFiles\"\n content={''}\n accept={accept as any}\n multiple={multiple}\n token={token}\n onUploadStart={(totalFile) => {\n if (totalFile !== undefined) {\n setTotal((prevTotal) => prevTotal + totalFile);\n }\n if (typeof onUploadStart === 'function' && totalFile !== 0) {\n onUploadStart();\n }\n }}\n onUploadSuccess={(fileResponse) => {\n if (fileResponse === undefined) {\n return;\n }\n setTotal((prevTotal) => (prevTotal !== undefined ? prevTotal - 1 : 0));\n setFiles((prevFiles) => (multiple ? [...prevFiles, fileResponse] : [fileResponse]));\n }}\n />\n </CSSHidden>\n </>\n );\n};\n","import React, { useEffect } from 'react';\nimport styled from 'styled-components';\nimport { shallowEqual } from 'react-redux';\nimport { useIntl } from 'react-intl';\nimport jamespot, {\n jFileLittle,\n WidgetArticleAttachmentType,\n WidgetDisplayMode,\n WidgetArticleAttachmentContent,\n} from 'jamespot-user-api';\nimport { Application, Toast, Widget, updateWidgetContent } from 'jamespot-front-business';\nimport { JRCFileViewerOpenWithOptionsType } from 'jamespot-react-components';\nimport { WidgetUploader } from '../components/WidgetUploader';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { useAppDispatch, useAppSelector } from '../../../redux/store';\n\nconst WidgetAttachment = commonComponentsRegistry.getLazyComponent('WidgetAttachment');\nconst JRCWidgetEmptyInplace = commonComponentsRegistry.getLazyComponent('WidgetEmptyInplace');\nconst FileViewer = commonComponentsRegistry.getLazyComponent('FileViewer');\n\n// DUPLICATE FROM WEDOC\nexport const wedocWindowOpen = (idFile: number, hash: string, target?: '_blank') => {\n window.open(getWedocFilePath(idFile, hash), target);\n};\n\n// DUPLICATE FROM WEDOC\nexport function getWedocFilePath(idFile: number, hash: string) {\n return `/ng/rr/file/${idFile}/${hash}`;\n}\n\nexport const CSSWrapper = styled.div`\n flex: 1;\n`;\n\nexport const JRCWidgetArticleAttachmentWrapper = ({\n widget,\n inplace,\n mode,\n}: {\n widget: WidgetArticleAttachmentType;\n inplace?: boolean;\n mode?: WidgetDisplayMode;\n}) => {\n const intl = useIntl();\n const { uniqid } = widget;\n const { files } = widget.content;\n const dispatch = useAppDispatch();\n const isActive = useAppSelector((state) => Widget.selectors.isActive(state, uniqid), shallowEqual);\n\n const onError = (message?: string) => {\n dispatch(Toast.actions.error({ label: message ?? intl.formatMessage({ id: 'GLOBAL_Error' }) }));\n };\n\n useEffect(() => {\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, mounted: true }));\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n useEffect(() => {\n dispatch(\n Widget.slice.actions.setWidgetState({\n uniqid,\n empty: !files || files.length === 0,\n }),\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [files]);\n\n const onlyOffice = useAppSelector((state) => Application.selectors.selectById(state, 'OnlyOfficeHook'));\n\n const onClick = (file: jFileLittle | undefined) => {\n if (!file) {\n return;\n }\n jamespot.object\n .getAccessHash(`fileArticle/${file.id}`)\n .then((response) => {\n if (response.result === '') {\n throw new Error('result empty');\n }\n const hash = response.result;\n wedocWindowOpen(file.id, hash);\n })\n .catch(() => {\n dispatch(Toast.actions.error({ label: 'WIDGET_Open_Failed' }, 6000));\n });\n };\n\n const option = [\n {\n label: intl.formatMessage({ id: 'WIDGET_Open_With_Wedoc' }),\n onClick: onClick,\n },\n ];\n\n const openWithOptions: JRCFileViewerOpenWithOptionsType = onlyOffice\n ? [\n {\n condition: (f) =>\n [\n 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',\n 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',\n 'application/vnd.openxmlformats-officedocument.presentationml.presentation',\n ].includes(f.mimetype),\n options: option,\n },\n ]\n : [];\n\n return files !== undefined ? (\n <CSSWrapper>\n {mode !== 'view' ? (\n <WidgetAttachment files={files} onClick={() => undefined} onError={onError} />\n ) : (\n <FileViewer files={files} openWithOptions={openWithOptions}>\n {(open) => {\n return <WidgetAttachment files={files} onClick={(idFile) => open(idFile)} onError={onError} />;\n }}\n </FileViewer>\n )}\n {inplace && mode !== 'view' && (\n <WidgetUploader\n initialFiles={files}\n initialClick={isActive}\n multiple={true}\n accept={'*'}\n onUploadSuccess={(files) => {\n if (Array.isArray(files)) {\n dispatch(updateWidgetContent<WidgetArticleAttachmentContent>(uniqid, { files }));\n }\n }}\n onUploadStart={() => {\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, loading: true }));\n }}\n onUploadEnd={() => {\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, loading: false }));\n }}>\n {mode === 'edit' ? (\n <JRCWidgetEmptyInplace\n label={'WIDGET_Article_Attachment_Empty_Label'}\n description={'WIDGET_Article_Attachment_Empty_Description'}\n url={'widget-article-image-placeholder.png'}\n onClick={() => undefined}\n />\n ) : (\n <></>\n )}\n </WidgetUploader>\n )}\n </CSSWrapper>\n ) : (\n <></>\n );\n};\n","import React, { useEffect } from 'react';\nimport styled from 'styled-components';\nimport { WidgetArticleButtonType, WidgetDisplayMode } from 'jamespot-user-api';\nimport { Widget, WidgetEditor } from 'jamespot-front-business';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { useAppDispatch } from '../../../redux/store';\n\nconst JRCWidgetButton = commonComponentsRegistry.getLazyComponent('WidgetButton');\n\nconst CSSButtonWrapper = styled.div`\n display: flex;\n flex: 1;\n justify-content: center;\n align-items: center;\n`;\n\nconst CSSPointer = styled.div<{ clickable: boolean }>`\n pointer-events: ${(props) => (props.clickable ? 'all' : 'none')};\n cursor: pointer;\n display: flex;\n flex: 1;\n justify-content: center;\n align-items: center;\n`;\n\nexport const JRCWidgetArticleButtonWrapper = ({\n widget,\n mode,\n}: {\n widget: WidgetArticleButtonType;\n inplace: boolean;\n mode?: WidgetDisplayMode;\n}) => {\n const dispatch = useAppDispatch();\n const { uniqid } = widget;\n const { text, url, target, color, backgroundColor, buttonSize, borderRadius, variant } = widget.content;\n\n useEffect(() => {\n dispatch(\n Widget.slice.actions.setWidgetState({\n uniqid,\n empty: !text || text.length === 0,\n }),\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [text]);\n\n return (\n <CSSButtonWrapper\n onClick={() => {\n if (mode === 'edit') {\n dispatch(WidgetEditor.slice.actions.registerEditor({ uniqid, name: widget.name }));\n }\n }}>\n <CSSPointer clickable={mode !== 'edit'}>\n <JRCWidgetButton\n text={text}\n url={url}\n target={target}\n color={color}\n backgroundColor={backgroundColor}\n buttonSize={buttonSize}\n borderRadius={borderRadius}\n variant={variant}\n />\n </CSSPointer>\n </CSSButtonWrapper>\n );\n};\n","import React, { useEffect } from 'react';\nimport { shallowEqual } from 'react-redux';\nimport styled from 'styled-components';\nimport { WidgetArticleGalleryContent, WidgetArticleGalleryType, WidgetDisplayMode } from 'jamespot-user-api';\nimport { Widget, updateWidgetContent } from 'jamespot-front-business';\nimport { WidgetUploader } from '../components/WidgetUploader';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { useAppDispatch, useAppSelector } from '../../../redux/store';\n\nconst JRCWidgetArticleGallery = commonComponentsRegistry.getLazyComponent('WidgetArticleGallery');\nconst JRCWidgetEmptyInplace = commonComponentsRegistry.getLazyComponent('WidgetEmptyInplace');\nconst FileViewer = commonComponentsRegistry.getLazyComponent('FileViewer');\n\nconst CSSImagePointer = styled.button`\n cursor: pointer;\n`;\n\nexport const JRCWidgetArticleGalleryWrapper = ({\n widget,\n inplace,\n mode,\n}: {\n widget: WidgetArticleGalleryType;\n inplace?: boolean;\n mode?: WidgetDisplayMode;\n}) => {\n const { uniqid } = widget;\n const { files } = widget.content;\n const dispatch = useAppDispatch();\n const isActive = useAppSelector((state) => Widget.selectors.isActive(state, uniqid), shallowEqual);\n\n useEffect(() => {\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, mounted: true }));\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n return files !== undefined ? (\n <>\n {mode === 'edit' ? (\n <JRCWidgetArticleGallery\n files={files}\n maxWidth={800}\n gap={widget.content.gap ?? '10'}\n column={widget.content.column ?? '3'}\n onClick={() => undefined}\n />\n ) : (\n <FileViewer files={files} openWithOptions={[]}>\n {(open) => {\n return (\n <CSSImagePointer>\n <JRCWidgetArticleGallery\n files={files}\n maxWidth={600}\n gap={widget.content.gap ?? '10'}\n column={widget.content.column ?? '3'}\n onClick={(idFile) => open(idFile)}\n />\n </CSSImagePointer>\n );\n }}\n </FileViewer>\n )}\n {inplace && mode === 'edit' ? (\n <WidgetUploader\n initialFiles={files}\n initialClick={isActive}\n accept={'image/png, image/jpeg, image/jpg'}\n multiple={true}\n onUploadSuccess={(files) => {\n if (Array.isArray(files)) {\n dispatch(updateWidgetContent<WidgetArticleGalleryContent>(uniqid, { files }));\n }\n }}\n onUploadStart={() => {\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, loading: true }));\n }}\n onUploadEnd={() => {\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, loading: false }));\n }}>\n <JRCWidgetEmptyInplace\n label={'WIDGET_Article_Gallery_Empty_Label'}\n description={'WIDGET_Article_Gallery_Empty_Description'}\n url={'widget-article-image-placeholder.png'}\n onClick={() => undefined}\n />\n </WidgetUploader>\n ) : (\n <></>\n )}\n </>\n ) : (\n <></>\n );\n};\n","import React, { useEffect, useState } from 'react';\nimport { shallowEqual } from 'react-redux';\nimport {\n WidgetArticleImageContent,\n WidgetArticleImageType,\n WidgetDisplayMode,\n formatImgUrl,\n jFileLittle,\n} from 'jamespot-user-api';\nimport { useIntl } from 'react-intl';\nimport { Widget, updateWidgetContent } from 'jamespot-front-business';\nimport { WidgetUploader } from '../components/WidgetUploader';\n\nconst WidgetImage = commonComponentsRegistry.getLazyComponent('WidgetImage');\nconst FileViewer = commonComponentsRegistry.getLazyComponent('FileViewer');\nconst JRCWidgetEmptyInplace = commonComponentsRegistry.getLazyComponent('WidgetEmptyInplace');\n\nimport styled from 'styled-components';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { useAppDispatch, useAppSelector } from '../../../redux/store';\n\nconst CSSImageWrapperHover = styled.div`\n position: absolute;\n inset: 0;\n background-color: rgba(0, 0, 0, 0.4);\n pointer-events: none;\n display: flex;\n justify-content: center;\n align-items: center;\n opacity: 0;\n color: ${(props) => props.theme.color.white};\n &:hover {\n opacity: 1;\n }\n`;\n\nconst CSSImagePointer = styled.button`\n cursor: pointer;\n`;\n\nconst mockFileLittle: jFileLittle = {\n id: 0,\n type: '',\n title: '',\n uri: '',\n mimetype: 'application/octet-stream',\n mainType: '',\n dateCreation: '',\n dateModified: '',\n _url: '',\n size: 10,\n};\n\nexport const strToTimestamp = (str: string): undefined | number => {\n if (str) {\n const timestamp = Date.parse(str);\n if (!isNaN(timestamp)) {\n return new Date(timestamp).getTime() / 1000;\n }\n }\n return;\n};\n\nexport const JRCWidgetArticleImageWrapper = ({\n widget,\n width,\n inplace,\n mode,\n}: {\n widget: WidgetArticleImageType;\n inplace?: boolean;\n mode?: WidgetDisplayMode;\n width?: number;\n}) => {\n const { uniqid } = widget;\n const { file, useFilter } = widget.content;\n const dispatch = useAppDispatch();\n const isActive = useAppSelector((state) => Widget.selectors.isActive(state, uniqid), shallowEqual);\n const [uri, setUri] = useState<string | undefined>(undefined);\n const intl = useIntl();\n\n useEffect(() => {\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, mounted: true }));\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n useEffect(() => {\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, empty: !file }));\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [file]);\n\n useEffect(() => {\n if (file) {\n setUri(\n formatImgUrl({\n timestamp: file.dateModified ? strToTimestamp(file.dateModified) : Date.now(),\n from: 'imagecache',\n size: 'fitx1200',\n uri: file.uri,\n }),\n );\n }\n }, [file]);\n\n return (\n <>\n {mode === 'edit' ? (\n uri !== undefined ? (\n <WidgetImage maxWidth={width ?? 600} uri={uri} useFilter={useFilter ?? false} />\n ) : (\n <></>\n )\n ) : (\n <FileViewer\n files={[\n {\n ...mockFileLittle,\n path: uri,\n mimetype: 'image/png',\n },\n ]}\n openWithOptions={[]}>\n {(open) => {\n return (\n <CSSImagePointer onClick={() => open(0)}>\n <WidgetImage maxWidth={width ?? 600} uri={uri} useFilter={useFilter ?? false} />\n </CSSImagePointer>\n );\n }}\n </FileViewer>\n )}\n\n {inplace && mode === 'edit' ? (\n <WidgetUploader\n initialFiles={[]}\n initialClick={isActive}\n accept={'image/png, image/jpeg, image/jpg'}\n multiple={false}\n onUploadSuccess={(files) => {\n if (Array.isArray(files) && files[0] !== undefined) {\n dispatch(updateWidgetContent<WidgetArticleImageContent>(uniqid, { file: files[0] }));\n }\n }}\n onUploadStart={() => {\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, loading: true }));\n }}\n onUploadEnd={() => {\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, loading: false }));\n }}>\n {file !== undefined ? (\n <CSSImageWrapperHover>\n {intl.formatMessage({ id: 'ARTICLE_Widget_Image_Change' })}\n </CSSImageWrapperHover>\n ) : (\n <JRCWidgetEmptyInplace\n label={'WIDGET_Article_Image_Empty_Label'}\n description={'WIDGET_Article_Image_Empty_Description'}\n url={'widget-article-image-placeholder.png'}\n onClick={() => undefined}\n />\n )}\n </WidgetUploader>\n ) : (\n <></>\n )}\n </>\n );\n};\n","import React, { useCallback, useEffect, useMemo, useRef, useState } from 'react';\n\nimport { WidgetArticleSliderType, WidgetDisplayMode, formatImgUrl, jFileLittle } from 'jamespot-user-api';\nimport styled from 'styled-components';\nimport { Widget, WidgetEditor } from 'jamespot-front-business';\nimport { shallowEqual } from 'react-redux';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { useAppDispatch, useAppSelector } from '../../../redux/store';\n\nconst FileViewer = commonComponentsRegistry.getLazyComponent('FileViewer');\nconst JRCWidgetEmptyInplace = commonComponentsRegistry.getLazyComponent('WidgetEmptyInplace');\nconst JRCWidgetSlider = commonComponentsRegistry.getLazyComponent('WidgetSlider');\n\nconst Wrapper = styled.div<{ maxWidth: number }>`\n flex: 1;\n display: flex;\n flex-direction: row;\n min-height: 60px;\n align-items: center;\n width: ${(props) => props.maxWidth}px;\n`;\n\nconst mockFileLittle: jFileLittle = {\n id: 0,\n type: '',\n title: '',\n uri: '',\n mimetype: 'application/octet-stream',\n mainType: '',\n dateCreation: '',\n dateModified: '',\n _url: '',\n size: 10,\n};\n\nexport const strToTimestamp = (str: string): undefined | number => {\n if (str) {\n const timestamp = Date.parse(str);\n if (!isNaN(timestamp)) {\n return new Date(timestamp).getTime() / 1000;\n }\n }\n return;\n};\n\nexport const JRCWidgetArticleSliderWrapper = ({\n widget,\n mode,\n width,\n}: {\n widget: WidgetArticleSliderType;\n inplace: boolean;\n mode?: WidgetDisplayMode;\n width?: number;\n}) => {\n const { uniqid } = widget;\n const dispatch = useAppDispatch();\n const isActive = useAppSelector((state) => Widget.selectors.isActive(state, uniqid), shallowEqual);\n const maxWidth = width ?? 600;\n const [dynamicWidth, setDynamicWidth] = useState<number | undefined>(undefined);\n const ref = useRef<HTMLDivElement>(null);\n const fileViewerFiles = useMemo(\n () =>\n widget.content.slides\n ? [\n ...widget.content.slides.map((slide, index) => {\n return {\n ...mockFileLittle,\n id: slide.file ? slide.file.id : index,\n mimetype: slide.file ? slide.file.mimetype : mockFileLittle.mimetype,\n path: formatImgUrl({\n size: 'fitx1200',\n uri: slide.file ? slide.file.uri : '',\n from: 'imagecache',\n timestamp:\n slide.file && slide.file.dateModified\n ? strToTimestamp(slide.file.dateModified)\n : Date.now(),\n }),\n };\n }),\n ]\n : [],\n [widget.content.slides],\n );\n\n const slides = useMemo(\n () =>\n widget.content.slides !== undefined\n ? [\n ...widget.content.slides.map((slide) => {\n if (slide.file) {\n return {\n ...slide,\n uri: formatImgUrl({\n timestamp: slide.file.dateModified\n ? strToTimestamp(slide.file.dateModified)\n : Date.now(),\n size: `fitx${dynamicWidth && dynamicWidth < maxWidth ? dynamicWidth : maxWidth}`,\n from: 'imagecache',\n uri: slide.file.uri,\n }),\n };\n } else {\n return {\n ...slide,\n uri: '',\n };\n }\n }),\n ]\n : [],\n [widget.content.slides, dynamicWidth, maxWidth],\n );\n\n useEffect(() => {\n if (isActive && mode === 'edit') {\n dispatch(WidgetEditor.slice.actions.registerEditor({ uniqid, name: widget.name }));\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isActive]);\n\n useEffect(() => {\n const handleResize = () => {\n if (ref.current) {\n setDynamicWidth(ref.current ? ref.current.offsetWidth : maxWidth);\n }\n };\n window.addEventListener('resize', handleResize);\n\n return () => {\n window.removeEventListener('resize', handleResize);\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [ref]);\n\n useEffect(() => {\n setDynamicWidth(ref.current ? ref.current.offsetWidth : maxWidth);\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [ref]);\n\n useEffect(() => {\n dispatch(\n Widget.slice.actions.setWidgetState({\n uniqid,\n empty: !widget.content.slides || widget.content.slides.length === 0,\n }),\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [widget.content.slides]);\n\n const isEditable = useMemo(\n () => mode === 'edit' && Array.isArray(widget.content.slides) && widget.content.slides.length === 0,\n [widget.content.slides, mode],\n );\n\n const handleEditor = useCallback(() => {\n dispatch(\n WidgetEditor.slice.actions.registerEditor({\n uniqid: widget.uniqid,\n name: widget.name,\n }),\n );\n }, [dispatch, widget.uniqid, widget.name]);\n\n /** small hack to catch the real width of the div */\n if (dynamicWidth === undefined) {\n return <div ref={ref} style={{ width: '100%' }}></div>;\n }\n\n return (\n <Wrapper maxWidth={dynamicWidth && dynamicWidth < maxWidth ? dynamicWidth : maxWidth}>\n <FileViewer files={fileViewerFiles} openWithOptions={[]}>\n {(open) => {\n return (\n <JRCWidgetSlider\n slides={slides}\n maxWidth={dynamicWidth && dynamicWidth < maxWidth ? dynamicWidth : maxWidth}\n useDots={widget.content.useDots ?? true}\n loop={widget.content.loop ?? false}\n startAt={0}\n onClickSlide={(index) => {\n if (mode !== 'edit') {\n if (widget.content.slides) {\n const slide = widget.content.slides[index];\n if (slide && slide.file) {\n open(slide.file.id);\n }\n }\n } else {\n dispatch(WidgetEditor.slice.actions.registerEditor({ uniqid, name: widget.name }));\n }\n }}\n />\n );\n }}\n </FileViewer>\n {isEditable ? (\n <JRCWidgetEmptyInplace\n label={'WIDGET_Article_Slider_Empty_Label'}\n description={'WIDGET_Article_Slider_Empty_Description'}\n url={'widget-article-image-placeholder.png'}\n onClick={handleEditor}\n />\n ) : (\n <></>\n )}\n </Wrapper>\n );\n};\n","import { useMemo, useState } from 'react';\r\nimport { Editor, JTinyMCEExtensionsBuilders } from 'jamespot-react-components';\r\nimport { useIntl } from 'react-intl';\r\n\r\nexport const useMarkdownModal = (): {\r\n open: boolean;\r\n onInsert: (v: string) => void;\r\n close: () => void;\r\n ext: ReturnType<typeof JTinyMCEExtensionsBuilders.markdown>;\r\n isActive?: boolean;\r\n} => {\r\n const intl = useIntl();\r\n const [open, setOpen] = useState(false);\r\n const [editor, setEditor] = useState<Editor>();\r\n const ext = useMemo(\r\n () =>\r\n JTinyMCEExtensionsBuilders.markdown((ed) => {\r\n setEditor(ed);\r\n setOpen(true);\r\n }, intl),\r\n [intl],\r\n );\r\n return {\r\n open,\r\n onInsert: (v: string) => {\r\n editor?.execCommand('InsertHTML', false, v);\r\n },\r\n close: () => setOpen(false),\r\n ext,\r\n isActive: true,\r\n };\r\n};\r\n","import React, { useCallback, useState } from 'react';\r\nimport { FormattedMessage, useIntl } from 'react-intl';\r\nimport { marked } from 'marked';\r\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\r\n\r\nconst InputTextareaRaw = commonComponentsRegistry.getLazyComponent('InputTextareaRaw');\r\nconst Modal = commonComponentsRegistry.getLazyComponent('Modal');\r\n\r\nexport type MarkdownModalProps = {\r\n onInsert: (html: string) => void;\r\n open: boolean;\r\n close: () => void;\r\n};\r\n\r\nexport const MarkdownModal = ({ onInsert, open, close }: MarkdownModalProps) => {\r\n const intl = useIntl();\r\n const [markdown, setMarkdown] = useState('');\r\n\r\n const doClose = useCallback(() => {\r\n setMarkdown('');\r\n close();\r\n }, [close]);\r\n\r\n return (\r\n <Modal\r\n title={intl.formatMessage({ id: 'TINY_MCE_Insert_Markdown' })}\r\n open={open}\r\n closeHandler={doClose}\r\n enableClickAwayCloseModal\r\n buttons={[\r\n {\r\n children: <FormattedMessage id=\"GLOBAL_Cancel\" />,\r\n color: 'cancel',\r\n clickHandler: doClose,\r\n },\r\n {\r\n children: <FormattedMessage id=\"GLOBAL_Insert\" />,\r\n color: 'valid',\r\n disabled: !markdown,\r\n clickHandler: () => {\r\n onInsert(marked.parse(markdown, { async: false }).replace(/<br>/g, '<br><br>'));\r\n doClose();\r\n },\r\n },\r\n ]}>\r\n <InputTextareaRaw value={markdown} onChange={(e) => setMarkdown(e.target.value)} height={'400px'} />\r\n </Modal>\r\n );\r\n};\r\n","import { Model, TinyMCE, Toast, Widget, updateWidgetContent } from 'jamespot-front-business';\nimport { WidgetArticleTextContent, WidgetArticleTextType, WidgetDisplayMode } from 'jamespot-user-api';\nimport React, { useCallback, useEffect, useMemo } from 'react';\nimport { useIntl } from 'react-intl';\nimport { shallowEqual } from 'react-redux';\nimport styled, { useTheme } from 'styled-components';\n\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { getTinyMCEMentionsQueries } from '../../../utils/tinymce';\nimport { useMarkdownModal } from '../../../hooks/useMarkdownModal';\nimport { MarkdownModal } from '../../tinymce/extension/MarkdownModal';\nimport { useAppDispatch, useAppSelector } from '../../../redux/store';\n\nconst WidgetArticleText = commonComponentsRegistry.getLazyComponent('WidgetArticleText');\n\nconst CSSTextWrapper = styled.div`\n width: 100%;\n cursor: text;\n\n p {\n word-wrap: break-word;\n }\n\n a {\n word-wrap: break-word;\n }\n`;\n\nexport const JRCWidgetArticleTextWrapper = ({\n widget,\n mode,\n}: {\n widget: WidgetArticleTextType;\n inplace: boolean;\n mode?: WidgetDisplayMode;\n}) => {\n const { uniqid } = widget;\n const theme = useTheme();\n const { text } = widget.content;\n const dispatch = useAppDispatch();\n const isActive = useAppSelector((state) => Widget.selectors.isActive(state, uniqid), shallowEqual);\n const isBusy = useAppSelector((state) => Widget.selectors.selectWidgetState(state, uniqid)?.busy);\n const token = useAppSelector(Widget.selectors.selectToken);\n const tinyMCECommonOptions = useAppSelector(TinyMCE.selectors.selectTinyMCECommonOptions);\n const models = useAppSelector(Model.selectors.selectAll);\n\n const intl = useIntl();\n\n const {\n open,\n onInsert,\n close: closeMarkdownModal,\n ext: extMarkdown,\n isActive: isMarkdownActive,\n } = useMarkdownModal();\n\n const onError = useCallback(\n (message?: string) => {\n dispatch(Toast.actions.error({ label: message ?? intl.formatMessage({ id: 'GLOBAL_Error' }) }));\n },\n [dispatch, intl],\n );\n\n useEffect(() => {\n dispatch(\n Widget.slice.actions.setWidgetState({\n uniqid,\n empty: !text || text.length === 0,\n }),\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [text]);\n\n const tinyMentionsQueries = useMemo(() => {\n return getTinyMCEMentionsQueries(models, theme, onError);\n }, [models, onError, theme]);\n\n // small hack to hide and redraw tinymce to avoid initialization issue\n if (isBusy) {\n return <></>;\n }\n return (\n <CSSTextWrapper>\n <WidgetArticleText\n autoFocus={isActive}\n text={text ?? ''}\n token={mode === 'edit' && token !== undefined ? token : ''}\n tinyMCECommonOptions={\n mode === 'edit' && tinyMCECommonOptions\n ? {\n commonOptions: tinyMCECommonOptions,\n mentionsQueries: tinyMentionsQueries,\n }\n : undefined\n }\n mode={mode}\n onChange={(text) => {\n dispatch(updateWidgetContent<WidgetArticleTextContent>(uniqid, { text }));\n }}\n additionalExtensions={[extMarkdown]}\n />\n {isMarkdownActive && <MarkdownModal onInsert={onInsert} open={open} close={closeMarkdownModal} />}\n </CSSTextWrapper>\n );\n};\n","import React, { useEffect } from 'react';\nimport { shallowEqual } from 'react-redux';\nimport { WidgetArticleTitleContent, WidgetArticleTitleType, WidgetDisplayMode } from 'jamespot-user-api';\nimport { Widget, updateWidgetContent } from 'jamespot-front-business';\nimport styled from 'styled-components';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { useAppDispatch, useAppSelector } from '../../../redux/store';\n\nconst WidgetArticleTitle = commonComponentsRegistry.getLazyComponent('WidgetArticleTitle');\n\nconst CSSTextWrapper = styled.div`\n flex: 1;\n display: flex;\n flex-direction: row;\n align-items: center;\n cursor: text;\n`;\n\nconst ToolWrapper = styled.div`\n display: flex;\n flex-direction: row;\n border-radius: 8px;\n overflow: hidden;\n margin: 4px;\n border: 1px solid ${(props) => props.theme.color.grey1};\n`;\n\nconst Tool = styled.button<{ isActive: boolean }>`\n display: flex;\n width: 40px;\n height: 40px;\n justify-content: center;\n align-items: center;\n cursor: pointer;\n opacity: ${(props) => (props.isActive ? '1.0' : '.8')};\n background-color: ${(props) => (props.isActive ? props.theme.color.grey1 : props.theme.color.white)};\n &:hover {\n background-color: ${(props) => props.theme.color.grey1};\n }\n`;\n\nexport const JRCWidgetArticleTitleWrapper = ({\n widget,\n inplace,\n mode,\n dataCy,\n}: {\n widget: WidgetArticleTitleType;\n inplace: boolean;\n mode?: WidgetDisplayMode;\n dataCy?: string;\n}) => {\n const { uniqid } = widget;\n const { text, color, heading } = widget.content;\n const dispatch = useAppDispatch();\n const isActive = useAppSelector((state) => Widget.selectors.isActive(state, uniqid), shallowEqual);\n\n useEffect(() => {\n dispatch(\n Widget.slice.actions.setWidgetState({\n uniqid,\n empty: !text || text.length === 0,\n }),\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [text]);\n\n return (\n <CSSTextWrapper>\n <WidgetArticleTitle\n dataCy={dataCy}\n text={text}\n color={color}\n heading={heading}\n autoFocus={isActive}\n inplace={inplace}\n mode={mode}\n onChange={(text) => {\n dispatch(updateWidgetContent<WidgetArticleTitleContent>(uniqid, { text }));\n }}\n />\n {isActive && mode === 'edit' ? (\n <Toolbar\n heading={heading}\n onClick={(heading) => {\n dispatch(updateWidgetContent<WidgetArticleTitleContent>(uniqid, { heading }));\n }}\n />\n ) : (\n <></>\n )}\n </CSSTextWrapper>\n );\n};\n\nexport const Toolbar = ({ heading = 'h1', onClick }: { heading?: string; onClick: (size: string) => void }) => {\n const sizes: string[] = ['h1', 'h2', 'h3', 'h4'];\n return (\n <ToolWrapper>\n {sizes.map((sizeValue, index: number) => (\n <Tool key={index} isActive={heading === sizeValue} onClick={() => onClick(sizeValue)}>\n {sizeValue}\n </Tool>\n ))}\n </ToolWrapper>\n );\n};\n","import React, { useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport jamespot from 'jamespot-user-api';\nimport styled from 'styled-components';\nimport { Toast, Widget } from 'jamespot-front-business';\nimport { JRCIconButton } from 'jamespot-react-components';\nimport { commonComponentsRegistry } from '../../../../registry/CommonRegistry';\nimport { useAppDispatch } from '../../../../redux/store';\n\nconst JRCButton = commonComponentsRegistry.getLazyComponent('Button');\nconst JRCModalLayout = commonComponentsRegistry.getLazyComponent('ModalLayout');\nconst JRCModalContent = commonComponentsRegistry.getLazyComponent('ModalContent');\n\nexport const Button = styled.button`\n padding: ${(props) => props.theme.space.md}px;\n`;\n\nexport const Footer = styled.div`\n padding: ${(props) => props.theme.space.md}px;\n display: flex;\n flex-direction: row-reverse;\n`;\n\nexport const WidgetRemove = ({ id, type, uniqid }: { id: number; type: string; uniqid: string }) => {\n const dispatch = useAppDispatch();\n const intl = useIntl();\n const [isOpen, setIsOpen] = useState<boolean>(false);\n\n const handleRemove = () => {\n jamespot.widget\n .removeWidget({ id, type, uniqid })\n .then(() => {\n dispatch(Widget.slice.actions.flushWidget({ uniqid }));\n })\n .catch(() => dispatch(Toast.actions.error({ label: 'WIDGET_Presence_Error' })));\n };\n\n return (\n <>\n <JRCIconButton iconSize={14} onClick={() => setIsOpen(true)} icon=\"icon-trash\" />\n {isOpen && (\n <JRCModalLayout enableClickAwayCloseModal={true} open={isOpen} closeHandler={() => setIsOpen(false)}>\n <JRCModalContent\n overflow={'scroll'}\n title={intl.formatMessage({ id: 'WIDGET_Remove_Widget' })}\n onClickIconClose={() => setIsOpen(false)}>\n {intl.formatMessage({ id: 'WIDGET_Delete_Widget_Confirmation' })}\n </JRCModalContent>\n <Footer>\n <JRCButton label={intl.formatMessage({ id: 'GLOBAL_Confirm' })} onClick={handleRemove} />\n </Footer>\n </JRCModalLayout>\n )}\n </>\n );\n};\n","import React, { useCallback, useMemo } from 'react';\nimport { useIntl } from 'react-intl';\nimport { WidgetsName, ensureWidgetObjectHasMinimumProperties, Rights, WidgetDisplayMode } from 'jamespot-user-api';\n\nimport { shallowEqual } from 'react-redux';\n\nimport styled from 'styled-components';\nimport { Widget, WidgetEditor } from 'jamespot-front-business';\nimport { WidgetRemove } from './WidgetRemove';\nimport { useAppDispatch, useAppSelector } from '../../../../redux/store';\n\nexport const Footer = styled.div`\n display: flex;\n flex: 1;\n flex-direction: row;\n border-top: 1px solid ${(props) => props.theme.color.grey1};\n`;\n\nexport const Button = styled.button`\n display: flex;\n flex: 1;\n justify-content: center;\n align-items: center;\n background-color: ${(props) => props.theme.color.white};\n &:hover {\n background-color: ${(props) => props.theme.color.grey0};\n }\n`;\n\nexport const WidgetFooterView = ({\n name,\n uniqid,\n mode,\n collaborationRights,\n handleOpenEditor,\n}: {\n name: WidgetsName;\n uniqid: string;\n mode?: WidgetDisplayMode;\n collaborationRights?: Pick<Rights, 'update'>;\n handleOpenEditor?: () => void;\n}) => {\n const intl = useIntl();\n const dispatch = useAppDispatch();\n const widgetObject = useAppSelector((state) => Widget.selectors.selectWidgetObject(state, uniqid), shallowEqual);\n const widgetObjectRights = useAppSelector(\n (state) => Widget.selectors.selectWidgetObjectRights(state, uniqid),\n shallowEqual,\n );\n\n const canUpdate = useMemo(\n () =>\n (widgetObject && widgetObjectRights && widgetObjectRights.update) ||\n (collaborationRights && collaborationRights.update),\n [widgetObject, widgetObjectRights, collaborationRights],\n );\n\n const canDelete = useMemo(\n () => widgetObject && widgetObjectRights && widgetObjectRights.delete,\n [widgetObject, widgetObjectRights],\n );\n\n const handleOnClick = useCallback(() => {\n dispatch(\n WidgetEditor.slice.actions.registerEditor({\n uniqid,\n name,\n mode,\n }),\n );\n }, [uniqid, dispatch, name, mode]);\n\n return canUpdate && ensureWidgetObjectHasMinimumProperties(widgetObject) ? (\n <Footer>\n <Button onClick={handleOpenEditor ?? handleOnClick}>\n {intl.formatMessage({ id: 'WIDGET_Set_Widget' })}\n </Button>\n {canDelete && <WidgetRemove id={widgetObject.id} type={widgetObject.type} uniqid={uniqid} />}\n </Footer>\n ) : (\n <></>\n );\n};\n","import { JRCButton, JRCInputText } from 'jamespot-react-components';\nimport React, { useState, useEffect } from 'react';\nimport { useForm } from 'react-hook-form';\nimport { useIntl } from 'react-intl';\nimport styled from 'styled-components';\nimport { useAppDispatch } from '../../../../redux/store';\n\nexport const CSSWrapper = styled.div`\n padding: ${(props) => props.theme.space.md}px;\n display: flex;\n flex-direction: row;\n fieldset {\n margin: 0.2rem !important;\n }\n`;\n\nexport const WidgetInlineInputText = ({\n placeholder,\n handleClick,\n}: {\n placeholder: string;\n handleClick: (label: string) => void;\n}) => {\n const intl = useIntl();\n const dispatch = useAppDispatch();\n const [label, setLabel] = useState<string>('');\n\n const { control, watch, reset } = useForm({\n defaultValues: { label },\n criteriaMode: 'all',\n });\n\n useEffect(() => {\n const subscription = watch((data) => {\n setLabel(data.label ?? '');\n });\n return () => subscription.unsubscribe();\n }, [watch, dispatch]);\n\n return (\n <CSSWrapper>\n <JRCInputText name={'label'} control={control} placeholder={placeholder} width=\"100%\" />\n <JRCButton\n label={intl.formatMessage({ id: 'GLOBAL_Confirm' })}\n disabled={!label.length}\n onClick={() => {\n handleClick(label);\n setLabel('');\n reset();\n }}\n />\n </CSSWrapper>\n );\n};\n","import React from 'react';\n\nimport styled from 'styled-components';\n\nimport { JRCLoader } from 'jamespot-react-components';\n\nexport const Wrapper = styled.div`\n position: absolute;\n inset: 0;\n display: flex;\n justify-content: center;\n align-items: center;\n background-color: rgba(255, 255, 255, 0.4);\n`;\n\nexport const WidgetIsPending = () => {\n return (\n <Wrapper>\n <JRCLoader size={'m'} />\n </Wrapper>\n );\n};\n","import { Toast, updateWidgetContent, Widget, WidgetEditor } from 'jamespot-front-business';\nimport { JRCFileViewer, JRCWidgetCheckListEntries, Utils } from 'jamespot-react-components';\nimport jApi, {\n CombinedWidgetContent,\n ensureWidgetCheckListType,\n jFileLittle,\n WidgetCheckListContent,\n WidgetCheckListType,\n WidgetDisplayMode,\n WidgetsName,\n} from 'jamespot-user-api';\nimport React, { useCallback, useEffect, useMemo, useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport { shallowEqual } from 'react-redux';\nimport styled from 'styled-components';\nimport { useAppDispatch, useAppSelector } from '../../../redux/store';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { RTProvider } from '../../RTProvider.component';\nimport { useWidgetRT } from '../hooks';\nimport { WidgetFooterView } from './components/WidgetFooterView';\nimport { WidgetInlineInputText } from './components/WidgetInlineInputText';\nimport { WidgetIsPending } from './components/WidgetIsPending';\n\nconst WidgetCheckList = commonComponentsRegistry.getLazyComponent('WidgetCheckList');\nconst WidgetCheckListEditor = commonComponentsRegistry.getLazyComponent('WidgetCheckListEditor');\n\nexport const CSSRowLinkWrapper = styled.div<{ border?: boolean }>`\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n align-items: center;\n border: ${(props) => (props.border ? `1px solid ${props.theme.color.grey2}` : 'none')};\n min-height: 24px;\n border-radius: 4px;\n padding: 4px 8px;\n`;\n\nconst CommentContainer = styled.div`\n width: 100%;\n display: flex;\n gap: 14px;\n padding: 16px;\n`;\n\nexport const CSSWidgetCheckListWrapper = styled.div`\n position: relative;\n`;\n\ntype JRCWidgetCheckListWrapperProps = {\n widget: WidgetCheckListType;\n inplace: boolean;\n mode?: WidgetDisplayMode;\n onWidgetUpdate?: () => void;\n};\n\nexport const JRCWidgetCheckListWrapper = ({\n widget,\n inplace,\n mode,\n onWidgetUpdate,\n}: JRCWidgetCheckListWrapperProps) => {\n const intl = useIntl();\n const { uniqid, content: widgetContent } = widget;\n const dispatch = useAppDispatch();\n const [token, setToken] = useState<string>();\n const [tokenLoading, setTokenLoading] = useState(false);\n\n const [entries, setEntries] = useState<JRCWidgetCheckListEntries | undefined>();\n const [isPending, setIsPending] = useState(false);\n\n const tokenFromStore = useAppSelector(Widget.selectors.selectToken, shallowEqual);\n\n const uri = useAppSelector((state) => Widget.selectors.selectWidgetObjectUri(state, widget.uniqid), shallowEqual);\n\n const widgetObjectRights = useAppSelector(\n (state) => Widget.selectors.selectWidgetObjectRights(state, uniqid),\n shallowEqual,\n );\n\n const allRt = useAppSelector(\n (state) => Widget.selectors.selectAllWidgetRTObject(state, widget.uniqid),\n shallowEqual,\n );\n\n const canEditCollaboration = useMemo(() => {\n return widgetObjectRights && widgetObjectRights.update;\n }, [widgetObjectRights]);\n\n const canAdministrate = useMemo(() => {\n return widgetObjectRights && widgetObjectRights.administrate;\n }, [widgetObjectRights]);\n\n const onError = useCallback(\n (message?: string) => {\n dispatch(Toast.actions.error({ label: message ?? intl.formatMessage({ id: 'GLOBAL_Error' }) }));\n },\n [dispatch, intl],\n );\n\n const fetchToken = useCallback(() => {\n if (!token && !tokenLoading) {\n setTokenLoading(true);\n jApi.network\n .token()\n .then((res) => {\n setToken(res.result);\n setTokenLoading(false);\n\n // set comment token to our widget slice to be able to upload image inside our widgets\n dispatch(Widget.slice.actions.setToken({ token: res.result }));\n })\n .catch((e) => {\n onError(e.errorMsg);\n });\n }\n }, [onError, token, tokenLoading, dispatch]);\n\n if (!tokenFromStore) {\n fetchToken();\n } else if (!token) {\n setToken(tokenFromStore);\n }\n\n const onChange = useCallback(\n (uniqid: string, content: WidgetCheckListContent) => {\n dispatch(updateWidgetContent(uniqid, content));\n },\n [dispatch],\n );\n\n const onChangeWrapper = (content: { uniqid: string; title?: string }) => {\n dispatch(Widget.slice.actions.updateWidgetWrapper({ ...content }));\n };\n\n const handleCheckItem = (id: string, index: number) => {\n if (!uri) return;\n if (isPending) return;\n setIsPending(true);\n jApi.widget\n .checkListRespond({\n uri,\n uniqid: id,\n index: index,\n })\n .then(() => {\n if (onWidgetUpdate) onWidgetUpdate();\n })\n .catch((err) => {\n onError(err.message);\n setIsPending(false);\n });\n };\n\n const handleReloadWidget = useCallback(() => {\n if (!uri) return;\n setIsPending(true);\n jApi.widget\n .getWidget<WidgetCheckListType>({ uri, uniqid })\n .then((response) => {\n if (ensureWidgetCheckListType(response.result)) {\n onChange(uniqid, response.result.content);\n }\n })\n .catch((err) => {\n return !err.aborted && onError;\n })\n .finally(() => setIsPending(false));\n }, [uniqid, onError, uri, onChange]);\n\n const openEditorPanel = (token: string) => {\n dispatch(WidgetEditor.slice.actions.flushAllEditor());\n dispatch(Widget.slice.actions.setToken({ token }));\n dispatch(\n WidgetEditor.slice.actions.registerEditor({\n uniqid: widget.uniqid,\n name: WidgetsName.CheckList,\n mode,\n }),\n );\n };\n\n useEffect(() => {\n if (!token && mode === 'edit') {\n jApi.network.token().then((response) => {\n dispatch(Widget.slice.actions.setToken({ token: response.result }));\n });\n }\n }, [mode, token, dispatch]);\n\n useEffect(() => {\n const finalEntries: JRCWidgetCheckListEntries | undefined = widget.content.arr?.map((item) => ({\n text: item.title ?? '',\n file: item.file ?? undefined,\n checked: item.value ?? false,\n ...(item.links && {\n links: item.links,\n }),\n ...(item.user && { user: item.user ?? undefined }),\n ...(item.id && { id: item.id, mimetype: 'image/png' }),\n }));\n\n setEntries(finalEntries);\n }, [widget.content.arr, widgetContent]);\n\n useEffect(() => {\n if (!Array.isArray(allRt)) return;\n const lastRt = allRt.at(-1);\n if (!lastRt) return;\n if (!uri) return;\n\n if (lastRt.object.uri === uri && lastRt.uniqid === widget.uniqid) {\n if (lastRt.fn === 'check-list-response' || lastRt.fn === 'widget-update') {\n handleReloadWidget();\n }\n }\n }, [allRt, widget.uniqid, uri, onError, dispatch, handleReloadWidget]);\n\n const handleCollabAddEntry = (label: string) => {\n if (!widget.content.arr || !uri) return;\n\n const contentToUpdate = {\n ...widget.content,\n arr: [...widget.content.arr, { title: label, value: false }],\n };\n\n jApi.widget\n .updateWidget<CombinedWidgetContent>({\n uri,\n uniqid: widget.uniqid,\n content: contentToUpdate as CombinedWidgetContent,\n v2: true,\n })\n .then(() => onChange(widget.uniqid, contentToUpdate))\n .catch((err) => onError(err.errorMsg));\n };\n\n const files = useMemo(() => {\n if (!Array.isArray(widgetContent.arr)) return [];\n\n const fs: jFileLittle[] = [];\n widgetContent.arr.forEach((el) => {\n if (el.file) {\n fs.push(el.file);\n }\n });\n\n return fs;\n }, [widgetContent]);\n\n if (mode === 'edit') {\n if (inplace) {\n return (\n <CommentContainer>\n <WidgetCheckListEditor\n token={token}\n uniqid={uniqid}\n content={{\n ...widgetContent,\n arr: widgetContent.arr?.map((w) => ({\n ...w,\n title: Utils.html.htmlDecodeSpecialChars(w.title),\n })),\n }}\n inplace={inplace}\n onChangeContent={onChange}\n onChangeWrapper={onChangeWrapper}\n handleChange={(content) =>\n dispatch(updateWidgetContent<WidgetCheckListContent>(widget.uniqid, content))\n }\n />\n </CommentContainer>\n );\n }\n }\n\n return (\n <RTProvider\n useRT={() => {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useWidgetRT(widget.uniqid);\n }}>\n {entries && (\n <JRCFileViewer files={files} openWithOptions={[]}>\n {(open) => {\n return (\n <CSSWidgetCheckListWrapper key={widget.uniqid}>\n <WidgetCheckList\n limit={10}\n initialEntries={entries}\n onFileClick={(entry) => entry.id && open(entry.id)}\n onItemCheckListChange={(index) => handleCheckItem(widget.uniqid, index)}\n />\n {widgetContent.edit && (\n <WidgetInlineInputText\n handleClick={handleCollabAddEntry}\n placeholder={intl.formatMessage({\n id: 'COMMENT_WIDGET_CHECKLIST_Add_New_Task',\n })}\n />\n )}\n {canAdministrate && token && (\n <WidgetFooterView\n uniqid={widget.uniqid}\n name={widget.name}\n collaborationRights={{\n update: !!(widgetContent.edit || canEditCollaboration),\n }}\n mode={mode}\n handleOpenEditor={() => {\n if (!token) {\n setIsPending(true);\n jApi.network\n .token()\n .then((response) => {\n dispatch(\n Widget.slice.actions.setToken({ token: response.result }),\n );\n openEditorPanel(response.result);\n })\n .finally(() => setIsPending(false));\n } else {\n openEditorPanel(token);\n }\n }}\n />\n )}\n {isPending && <WidgetIsPending />}\n </CSSWidgetCheckListWrapper>\n );\n }}\n </JRCFileViewer>\n )}\n </RTProvider>\n );\n};\n","import { WidgetTableColumn, WidgetTableColumnsData } from 'jamespot-user-api';\n\nexport const getVisibleColumns = (tableColumnsData: WidgetTableColumnsData, columns: WidgetTableColumn[]) => {\n const toRet: WidgetTableColumn[] = [];\n tableColumnsData\n .filter((data) => data.isVisible)\n .forEach((data) => {\n const column = columns.find((el) => el.name === data.name);\n if (column) {\n toRet.push(column);\n }\n });\n\n return toRet;\n};\n","import React, { useCallback, useEffect, useMemo, useState } from 'react';\nimport { useIntl, FormattedMessage } from 'react-intl';\nimport jamespot, {\n DatasourceResultSort,\n DatasourceType,\n Format,\n WidgetDatasourceTableContent,\n WidgetDatasourceValues,\n WidgetDisplayMode,\n WidgetsName,\n WidgetTableColumn,\n} from 'jamespot-user-api';\nimport styled from 'styled-components';\nimport { Widget, WidgetEditor } from 'jamespot-front-business';\nimport { getVisibleColumns } from './utils';\nimport { FitType, useArticleRT } from '../hooks';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { useAppDispatch } from '../../../redux/store';\n\nconst JRCButton = commonComponentsRegistry.getLazyComponent('Button');\nconst JRCHtml = commonComponentsRegistry.getLazyComponent('Html');\nconst WidgetTable = commonComponentsRegistry.getLazyComponent('WidgetTable');\nconst Loader = commonComponentsRegistry.getLazyComponent('Loader');\n\nexport const Wrapper = styled.div``;\n\nexport const AbsoluteWrapper = styled.div`\n position: absolute;\n inset: 0;\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n gap: ${(props) => props.theme.space.md}px;\n`;\n\nexport const WrapperEditMode = styled.div`\n position: absolute;\n inset: 0;\n display: flex;\n flex-direction: row;\n justify-content: center;\n align-items: center;\n gap: ${(props) => props.theme.space.md}px;\n color: ${(props) => props.theme.color.primary};\n cursor: pointer;\n opacity: 0;\n border: 1px solid ${(props) => props.theme.color.primary};\n &:hover {\n background-color: ${(props) => props.theme.color.grey2};\n opacity: 0.9;\n }\n`;\n\nexport const WidgetDatasourceTableWrapper = ({\n uniqid,\n uri,\n limit,\n tableHeadColor,\n tableHeadTextColor,\n tableHeadIconColor,\n tableRowColor,\n tableRowTextColor,\n tableColumnsData = [],\n tableBorderRadius,\n tableSizedColumns,\n tableSizedColumnsWidth,\n mode,\n}: WidgetDatasourceTableContent & { uniqid: string; mode: WidgetDisplayMode }) => {\n const intl = useIntl();\n const dispatch = useAppDispatch();\n const [isEditorOpenOnFirstRender, setIsEditorOpenOnFirstRender] = useState<boolean>(false);\n const [isLoading, setIsLoading] = useState<boolean>(false);\n const [datasourceData, setDatasourceData] = useState<Record<string, WidgetDatasourceValues>[]>([]);\n const [datasourceModel, setDatasourceModel] = useState<WidgetTableColumn[]>([]);\n const [datasourceSort, setDatasourceSort] = useState<DatasourceResultSort>({ order: 'ascending', name: 'unknown' });\n const [datasourceType, setDatasourceType] = useState<DatasourceType | undefined>(undefined);\n const [datasourceIdentifier, setDatasourceIdentifier] = useState<string>('');\n\n const definition = useMemo(() => Widget.definition(WidgetsName.DatasourceTable), []);\n const rtConditions = useMemo<FitType[]>(() => {\n if (datasourceType === 'studio') {\n return [{ type: [datasourceIdentifier] }];\n }\n\n return [];\n }, [datasourceType, datasourceIdentifier]);\n const rtAudience = useMemo<string[]>(() => {\n if (datasourceType === 'doc') {\n return [datasourceIdentifier];\n }\n\n return [];\n }, [datasourceType, datasourceIdentifier]);\n\n const { rtLastObject } = useArticleRT(rtConditions, rtAudience);\n\n const fetchDatasource = useCallback(() => {\n if (!uri) {\n return;\n }\n\n setIsLoading(true);\n jamespot.datasource\n .get(uri, Format.VIEW)\n .then((response) => {\n setDatasourceModel(response.result.model);\n setDatasourceData(response.result.data);\n setDatasourceSort(response.result.sort);\n setDatasourceType(response.result.datasource.datasourceType);\n setDatasourceIdentifier(response.result.datasource.datasourceIdentifier);\n })\n .finally(() => setIsLoading(false));\n }, [uri]);\n\n useEffect(() => {\n if (uri !== undefined && tableColumnsData.length !== 0 && datasourceModel.length === 0) {\n fetchDatasource();\n }\n }, [uri, tableColumnsData, datasourceModel, fetchDatasource]);\n\n useEffect(() => {\n if (!rtLastObject) {\n return;\n }\n\n fetchDatasource();\n }, [rtLastObject, fetchDatasource]);\n\n useEffect(() => {\n if (!uri) {\n setDatasourceModel([]);\n }\n }, [uri]);\n\n const registerEditor = useCallback(() => {\n dispatch(WidgetEditor.slice.actions.flushAllEditor());\n setTimeout(() => {\n dispatch(WidgetEditor.slice.actions.registerEditor({ uniqid, name: WidgetsName.DatasourceTable }));\n }, 0);\n }, [dispatch, uniqid]);\n\n useEffect(() => {\n if (mode === 'view' || mode === 'preview') {\n dispatch(WidgetEditor.slice.actions.flushAllEditor());\n }\n }, [mode, dispatch]);\n\n useEffect(() => {\n if (!isEditorOpenOnFirstRender && !uri && mode === 'edit') {\n registerEditor();\n setIsEditorOpenOnFirstRender(true);\n }\n }, [dispatch, uniqid, isEditorOpenOnFirstRender, uri, registerEditor, mode]);\n\n const columns = useMemo(\n () => getVisibleColumns(tableColumnsData, datasourceModel),\n [tableColumnsData, datasourceModel],\n );\n\n if (tableColumnsData.length === 0 && !isLoading && mode === 'edit') {\n return (\n <>\n <AbsoluteWrapper onClick={registerEditor}>\n <img src={`/img/fast-intranet/${WidgetsName.DatasourceTable}.png`} alt=\"\" />\n <FormattedMessage id={definition.label} />\n <JRCButton label=\"GLOBAL_Settings\" />\n </AbsoluteWrapper>\n <WrapperEditMode onClick={registerEditor}>\n <JRCHtml\n __html={`${intl.formatMessage({ id: 'WIDGET_Set_Widget' })} <b>${intl.formatMessage({\n id: definition.label,\n })}</b>`}\n />\n </WrapperEditMode>\n </>\n );\n }\n\n return isLoading ? (\n <AbsoluteWrapper>\n <Loader />\n </AbsoluteWrapper>\n ) : (\n <>\n {!isLoading && datasourceData.length === 0 ? (\n <AbsoluteWrapper>\n <img src={`/img/fast-intranet/${WidgetsName.DatasourceTable}.png`} alt=\"\" />\n <FormattedMessage id={'WIDGET_Datasource_No_Results'} />\n </AbsoluteWrapper>\n ) : (\n <WidgetTable\n rows={datasourceData}\n columns={columns}\n limit={limit}\n tableHeadColor={tableHeadColor}\n tableHeadTextColor={tableHeadTextColor}\n tableHeadIconColor={tableHeadIconColor}\n tableRowColor={tableRowColor}\n tableRowTextColor={tableRowTextColor}\n tableBorderRadius={tableBorderRadius}\n tableColumnsData={tableColumnsData}\n tableSizedColumns={tableSizedColumns}\n tableSizedColumnsWidth={tableSizedColumnsWidth}\n tableDefaultSortOrder={datasourceSort.order}\n tableDefaultSortName={datasourceSort.name}\n />\n )}\n {mode === 'edit' ? (\n <WrapperEditMode onClick={registerEditor}>\n <JRCHtml\n __html={`${intl.formatMessage({ id: 'WIDGET_Set_Widget' })} <b>${intl.formatMessage({\n id: definition.label,\n })}</b>`}\n />\n </WrapperEditMode>\n ) : (\n <></>\n )}\n </>\n );\n};\n","import React, { useCallback, useEffect, useMemo, useState } from 'react';\nimport { useIntl, FormattedMessage } from 'react-intl';\nimport jamespot, {\n Format,\n WidgetDatasourceValues,\n WidgetDisplayMode,\n WidgetExcelDatasourceTableContent,\n WidgetsName,\n WidgetTableColumn,\n} from 'jamespot-user-api';\nimport styled from 'styled-components';\nimport { Widget, WidgetEditor } from 'jamespot-front-business';\nimport { getVisibleColumns } from './utils';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { useAppDispatch } from '../../../redux/store';\n\nconst JRCButton = commonComponentsRegistry.getLazyComponent('Button');\nconst JRCHtml = commonComponentsRegistry.getLazyComponent('Html');\nconst WidgetTable = commonComponentsRegistry.getLazyComponent('WidgetTable');\nconst Loader = commonComponentsRegistry.getLazyComponent('Loader');\n\nexport const Wrapper = styled.div``;\n\nexport const AbsoluteWrapper = styled.div`\n position: absolute;\n inset: 0;\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n gap: ${(props) => props.theme.space.md}px;\n`;\n\nexport const WrapperEditMode = styled.div`\n position: absolute;\n inset: 0;\n display: flex;\n flex-direction: row;\n justify-content: center;\n align-items: center;\n gap: ${(props) => props.theme.space.md}px;\n color: ${(props) => props.theme.color.primary};\n cursor: pointer;\n opacity: 0;\n border: 1px solid ${(props) => props.theme.color.primary};\n &:hover {\n background-color: ${(props) => props.theme.color.grey2};\n opacity: 0.9;\n }\n`;\n\nexport const WidgetExcelDatasourceTableWrapper = ({\n uniqid,\n uri,\n limit,\n tableHeadColor,\n tableHeadTextColor,\n tableHeadIconColor,\n tableRowColor,\n tableRowTextColor,\n tableColumnsData = [],\n tableBorderRadius,\n tableSizedColumns,\n tableSizedColumnsWidth,\n mode,\n}: WidgetExcelDatasourceTableContent & { uniqid: string; mode: WidgetDisplayMode }) => {\n const intl = useIntl();\n const dispatch = useAppDispatch();\n const [isEditorOpenOnFirstRender, setIsEditorOpenOnFirstRender] = useState<boolean>(false);\n const [isLoading, setIsLoading] = useState<boolean>(false);\n const [datasourceData, setDatasourceData] = useState<Record<string, WidgetDatasourceValues>[]>([]);\n const [datasourceModel, setDatasourceModel] = useState<WidgetTableColumn[]>([]);\n\n const definition = useMemo(() => Widget.definition(WidgetsName.ExcelDatasourceTable), []);\n\n useEffect(() => {\n if (uri !== undefined && tableColumnsData.length !== 0 && datasourceModel.length === 0) {\n setIsLoading(true);\n jamespot.datasource\n .get(uri, Format.VIEW)\n .then((response) => {\n setDatasourceModel(response.result.model);\n setDatasourceData(response.result.data);\n })\n .finally(() => setIsLoading(false));\n }\n }, [uri, tableColumnsData, datasourceModel]);\n\n useEffect(() => {\n if (!uri) {\n setDatasourceModel([]);\n }\n }, [uri]);\n\n const registerEditor = useCallback(() => {\n dispatch(WidgetEditor.slice.actions.flushAllEditor());\n setTimeout(\n () =>\n dispatch(WidgetEditor.slice.actions.registerEditor({ uniqid, name: WidgetsName.ExcelDatasourceTable })),\n 0,\n );\n }, [dispatch, uniqid]);\n\n useEffect(() => {\n if (mode === 'view' || mode === 'preview') {\n dispatch(WidgetEditor.slice.actions.flushAllEditor());\n }\n }, [mode, dispatch]);\n\n useEffect(() => {\n if (!isEditorOpenOnFirstRender && !uri && mode === 'edit') {\n registerEditor();\n setIsEditorOpenOnFirstRender(true);\n }\n }, [dispatch, uniqid, isEditorOpenOnFirstRender, uri, registerEditor, mode]);\n\n const columns = useMemo(\n () => getVisibleColumns(tableColumnsData, datasourceModel),\n [tableColumnsData, datasourceModel],\n );\n\n if (tableColumnsData.length === 0 && !isLoading && mode === 'edit') {\n return (\n <>\n <AbsoluteWrapper onClick={registerEditor}>\n <img src={`/img/fast-intranet/${WidgetsName.ExcelDatasourceTable}.png`} alt=\"\" />\n <FormattedMessage id={definition.label} />\n <JRCButton label=\"GLOBAL_Settings\" />\n </AbsoluteWrapper>\n <WrapperEditMode onClick={registerEditor}>\n <JRCHtml\n __html={`${intl.formatMessage({ id: 'WIDGET_Set_Widget' })} <b>${intl.formatMessage({\n id: definition.label,\n })}</b>`}\n />\n </WrapperEditMode>\n </>\n );\n }\n\n return isLoading ? (\n <AbsoluteWrapper>\n <Loader />\n </AbsoluteWrapper>\n ) : (\n <>\n {!isLoading && datasourceData.length === 0 ? (\n <AbsoluteWrapper>\n <img src={`/img/fast-intranet/${WidgetsName.ExcelDatasourceTable}.png`} alt=\"\" />\n <FormattedMessage id={'WIDGET_Datasource_No_Results'} />\n </AbsoluteWrapper>\n ) : (\n <WidgetTable\n rows={datasourceData}\n columns={columns}\n limit={limit}\n tableHeadColor={tableHeadColor}\n tableHeadTextColor={tableHeadTextColor}\n tableHeadIconColor={tableHeadIconColor}\n tableRowColor={tableRowColor}\n tableRowTextColor={tableRowTextColor}\n tableBorderRadius={tableBorderRadius}\n tableColumnsData={tableColumnsData}\n tableSizedColumns={tableSizedColumns}\n tableSizedColumnsWidth={tableSizedColumnsWidth}\n />\n )}\n {mode === 'edit' ? (\n <WrapperEditMode onClick={registerEditor}>\n <JRCHtml\n __html={`${intl.formatMessage({ id: 'WIDGET_Set_Widget' })} <b>${intl.formatMessage({\n id: definition.label,\n })}</b>`}\n />\n </WrapperEditMode>\n ) : (\n <></>\n )}\n </>\n );\n};\n","import React, { useCallback, useMemo } from 'react';\n\nimport jamespot, { WidgetDisplayMode, WidgetPresenceContent } from 'jamespot-user-api';\n\nimport { shallowEqual } from 'react-redux';\nimport { useIntl } from 'react-intl';\nimport styled from 'styled-components';\n\nexport const CSSPaddingMd = styled.div`\n padding: ${(props) => props.theme.space.md}px;\n`;\n\nexport const CSSHref = styled.a`\n cursor: pointer;\n color: ${(props) => props.theme.color.secondary};\n`;\n\nexport const CSSHorizontalAlign = styled.div`\n display: flex;\n justify-content: center;\n align-items: center;\n`;\n\nimport { Toast, Widget } from 'jamespot-front-business';\nimport { useAppDispatch, useAppSelector } from '../../../redux/store';\n\nexport const WidgetPresenceWrapperClosing = ({\n mode,\n uniqid,\n content,\n}: {\n mode?: WidgetDisplayMode;\n uniqid: string;\n content: WidgetPresenceContent;\n}) => {\n const intl = useIntl();\n const dispatch = useAppDispatch();\n\n const uri = useAppSelector((state) => Widget.selectors.selectWidgetObjectUri(state, uniqid), shallowEqual);\n\n const widgetObjectRights = useAppSelector(\n (state) => Widget.selectors.selectWidgetObjectRights(state, uniqid),\n shallowEqual,\n );\n\n const canUpdate = useMemo<boolean>(() => !!(widgetObjectRights && widgetObjectRights.update), [widgetObjectRights]);\n\n const handleClosing = useCallback(() => {\n if (mode === 'edit' || !canUpdate || !uri) {\n return;\n }\n\n const contentToUpdate = { ...content, isClosed: true };\n\n jamespot.widget\n .updateWidget({\n uri,\n uniqid,\n content: contentToUpdate,\n v2: true,\n })\n .then(() => dispatch(Widget.slice.actions.updateWidget({ uniqid, content: contentToUpdate })))\n .catch(() => dispatch(Toast.actions.error({ label: 'WIDGET_Presence_Error' })));\n }, [mode, uniqid, canUpdate, uri, content, dispatch]);\n\n return (\n <>\n {canUpdate && !content.isClosed && (\n <CSSPaddingMd>\n <CSSHorizontalAlign>\n <CSSHref onClick={handleClosing}>\n {intl.formatMessage({ id: 'WIDGET_Presence_Closing' })}\n </CSSHref>\n </CSSHorizontalAlign>\n </CSSPaddingMd>\n )}\n </>\n );\n};\n","import jApi, {\n WidgetDisplayMode,\n WidgetPresenceResponse,\n WidgetPresenceResponseUserList,\n WidgetPresenceType,\n} from 'jamespot-user-api';\nimport React, { useCallback, useEffect, useMemo, useRef, useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport { shallowEqual } from 'react-redux';\nimport styled from 'styled-components';\nimport { Toast, updateWidgetContent, Widget } from 'jamespot-front-business';\nimport { useWidgetRT } from '../hooks';\nimport { WidgetFooterView } from './components/WidgetFooterView';\nimport { WidgetPresenceWrapperClosing } from './JRCWidgetPresenceWrapperClosing';\nimport { WidgetIsPending } from './components/WidgetIsPending';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { RTProvider } from '../../RTProvider.component';\nimport { useAppDispatch, useAppSelector } from '../../../redux/store';\n\nconst JRCWidgetPresence = commonComponentsRegistry.getLazyComponent('WidgetPresence');\nconst ModalUserList = commonComponentsRegistry.getLazyComponent('ModalUserList');\n\nexport const CSSWidgetPresenceWrapper = styled.div`\n display: flex;\n flex: 1;\n position: relative;\n flex-direction: column;\n`;\n\nexport const CSSWidgetPresenceState = styled.div`\n position: absolute;\n inset: 0;\n background-color: rgba(255, 255, 255, 0.7);\n display: flex;\n flex: 1;\n justify-content: center;\n align-items: center;\n`;\n\nexport const CSSWidgetPresenceIsClosed = styled.div`\n flex: 1;\n display: flex;\n padding: ${(props) => props.theme.space.md}px;\n border: 1px dashed ${(props) => props.theme.color.orange};\n justify-content: center;\n align-items: center;\n border-radius: ${(props) => props.theme.space.sm}px;\n margin: ${(props) => props.theme.space.sm}px;\n`;\n\nexport const JRCWidgetPresenceWrapper = ({\n widget,\n mode,\n}: {\n widget: WidgetPresenceType;\n inplace: boolean;\n mode?: WidgetDisplayMode;\n}) => {\n const intl = useIntl();\n const dispatch = useAppDispatch();\n const { limit, limitValue, closing, isClosed } = widget.content;\n const { uniqid } = widget;\n const [response, setResponse] = useState<WidgetPresenceResponse>({\n userValue: -1,\n userAvailableList: [],\n userUnavailableList: [],\n userAvailableTotal: 0,\n userUnavailableTotal: 0,\n });\n const [isPendingResponse, setIsPendingResponse] = useState<boolean>(false);\n const [abortController] = useState<AbortController>(new AbortController());\n const [openUsersModal, setOpenUsersModal] = useState(false);\n const [usersListIndex, setUsersListIndex] = useState<number>();\n const [usersList, setUsersList] = useState<WidgetPresenceResponseUserList>();\n const ref = useRef<AbortController>(abortController);\n\n const uri = useAppSelector((state) => Widget.selectors.selectWidgetObjectUri(state, uniqid), shallowEqual);\n\n const allRt = useAppSelector((state) => Widget.selectors.selectAllWidgetRTObject(state, uniqid), shallowEqual);\n\n const handleClickAvailable = () => (response.userValue === 1 ? handleCancelRespond() : handleRespond(1));\n const handleClickUnavailable = () => (response.userValue === 0 ? handleCancelRespond() : handleRespond(0));\n\n const handleError = useCallback(\n () => dispatch(Toast.actions.error({ label: 'WIDGET_Presence_Error' })),\n [dispatch],\n );\n\n const canRespond = useMemo<boolean>(\n () => !(limit && limitValue && response.userAvailableTotal >= limitValue),\n [limit, limitValue, response.userAvailableTotal],\n );\n\n const lockedRespondHandler = useMemo(() => {\n return (closing && isClosed) || mode === 'edit';\n }, [closing, isClosed, mode]);\n\n const handleCancelRespond = useCallback(() => {\n if (!uri || lockedRespondHandler) return;\n if (!canRespond) {\n dispatch(Toast.actions.error({ label: 'WIDGET_Presence_Limit_Response_Error' }));\n return;\n }\n\n setIsPendingResponse(true);\n jApi.widget\n .presenceCancel({ uri, uniqid })\n .catch(handleError)\n .finally(() => setIsPendingResponse(false));\n }, [dispatch, uniqid, handleError, uri, canRespond, lockedRespondHandler]);\n\n const handleRespond = useCallback(\n (value: 1 | 0) => {\n if (!uri || lockedRespondHandler) return;\n\n setIsPendingResponse(true);\n jApi.widget\n .presenceRespond(\n {\n uri,\n uniqid,\n value,\n },\n ref.current.signal,\n )\n .catch(handleError)\n .finally(() => setIsPendingResponse(false));\n },\n [uri, uniqid, handleError, lockedRespondHandler],\n );\n\n const handleResponse = useCallback(() => {\n if (mode === 'edit' || !uri) return;\n setIsPendingResponse(true);\n jApi.widget\n .presenceGetResponse({ uri, uniqid }, ref.current.signal)\n .then((response) => {\n setResponse(response.result);\n })\n .catch((err) => !err.aborted && handleError())\n .finally(() => setIsPendingResponse(false));\n }, [uri, handleError, uniqid, mode]);\n\n const handleLoadUsersList = (index: number, page?: number) => {\n if (!uri) return;\n jApi.widget\n .presenceGetResponseUserList({ uri, uniqid, index, page, limit: 8 }, ref.current.signal)\n .then((response) => {\n setUsersList({\n ...response.result,\n data: [...response.result.data],\n cnt: response.result.cnt,\n });\n })\n .catch((err) => {\n return !err.aborted && handleError;\n });\n };\n\n const handleReloadWidget = useCallback(() => {\n if (!uri) return;\n setIsPendingResponse(true);\n jApi.widget\n .getWidget<WidgetPresenceType>({ uri, uniqid })\n .then((response) => {\n dispatch(updateWidgetContent(uniqid, response.result));\n })\n .catch((err) => {\n return !err.aborted && handleError;\n })\n .finally(() => setIsPendingResponse(false));\n }, [dispatch, handleError, uri, uniqid]);\n\n useEffect(() => {\n const elm = ref.current;\n return () => {\n elm.abort();\n };\n }, []);\n\n useEffect(() => {\n handleResponse();\n }, [handleResponse]);\n\n useEffect(() => {\n if (!Array.isArray(allRt)) return;\n const lastRt = allRt.at(-1);\n if (!lastRt || !uri) return;\n\n if (lastRt.object.uri === uri && lastRt.uniqid === uniqid) {\n if (lastRt.fn === 'widget-presence-response') {\n handleResponse();\n }\n if (lastRt.fn === 'widget-update') {\n handleReloadWidget();\n }\n }\n }, [allRt, handleResponse, uniqid, uri, handleReloadWidget]);\n\n return (\n <RTProvider\n useRT={() => {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useWidgetRT(widget.uniqid);\n }}>\n <CSSWidgetPresenceWrapper>\n <JRCWidgetPresence\n limit={limit}\n limitValue={limitValue}\n userAvailableList={response.userAvailableList}\n userUnavailableList={response.userUnavailableList}\n userValue={response.userValue}\n userAvailableTotal={response?.userAvailableTotal}\n userUnavailableTotal={response?.userUnavailableTotal}\n isClosed={closing && isClosed}\n handleClickAvailable={handleClickAvailable}\n handleClickUnavailable={handleClickUnavailable}\n handleOpenUsersModal={(index) => {\n setUsersList({\n limit: 0,\n page: 0,\n data: [],\n cnt: 0,\n });\n setUsersListIndex(index);\n handleLoadUsersList(index);\n setOpenUsersModal(true);\n }}\n />\n {closing && isClosed && (\n <CSSWidgetPresenceIsClosed>\n {intl.formatMessage({ id: 'WIDGET_Presence_Is_Closed' })}\n </CSSWidgetPresenceIsClosed>\n )}\n {closing && !isClosed && (\n <WidgetPresenceWrapperClosing mode={mode} uniqid={widget.uniqid} content={widget.content} />\n )}\n {mode === 'view' && <WidgetFooterView uniqid={widget.uniqid} name={widget.name} mode={mode} />}\n {isPendingResponse && <WidgetIsPending />}\n <ModalUserList\n open={openUsersModal}\n usersList={usersList}\n title={\n usersListIndex === 1\n ? intl.formatMessage({ id: 'WIDGET_Presence_On' })\n : intl.formatMessage({ id: 'WIDGET_Presence_Off' })\n }\n setOpen={setOpenUsersModal}\n onClose={() => {\n setUsersList({\n limit: 0,\n page: 0,\n data: [],\n cnt: 0,\n });\n }}\n handleLoadUsersList={(page) => {\n handleLoadUsersList(usersListIndex ?? 0, page);\n }}\n />\n </CSSWidgetPresenceWrapper>\n </RTProvider>\n );\n};\n","import { Toast, updateWidgetContent, Widget, WidgetEditor } from 'jamespot-front-business';\nimport jApi, {\n CombinedWidgetContent,\n jFileLittle,\n WidgetDisplayMode,\n WidgetQuickSurveyContent,\n WidgetQuickSurveyResponse,\n WidgetQuickSurveyResponseUserList,\n WidgetQuickSurveyType,\n WidgetsName,\n} from 'jamespot-user-api';\nimport React, { useCallback, useEffect, useMemo, useRef, useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport { shallowEqual } from 'react-redux';\nimport styled from 'styled-components';\nimport { WidgetFooterView } from './components/WidgetFooterView';\nimport { WidgetInlineInputText } from './components/WidgetInlineInputText';\nimport { useWidgetRT } from '../hooks';\nimport { WidgetIsPending } from './components/WidgetIsPending';\nimport { JRCFileViewer } from 'jamespot-react-components';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { RTProvider } from '../../RTProvider.component';\nimport { useAppDispatch, useAppSelector } from '../../../redux/store';\n\nconst WidgetQuickSurvey = commonComponentsRegistry.getLazyComponent('WidgetQuickSurvey');\nconst WidgetQuickSurveyEditor = commonComponentsRegistry.getLazyComponent('WidgetQuickSurveyEditor');\nconst ModalUserList = commonComponentsRegistry.getLazyComponent('ModalUserList');\n\nconst WrapperContainer = styled.div<{ withPadding?: boolean }>`\n width: 100%;\n display: flex;\n flex-direction: column;\n gap: 14px;\n ${(props) => props.withPadding && `padding: 0 12px;`}\n padding-top: 16px;\n`;\n\ntype JRCWidgetQuickSurveyWrapperProps = {\n widget: WidgetQuickSurveyType;\n inplace: boolean;\n mode?: WidgetDisplayMode;\n};\n\nexport const JRCWidgetQuickSurveyWrapper = ({ widget, inplace, mode }: JRCWidgetQuickSurveyWrapperProps) => {\n const intl = useIntl();\n const dispatch = useAppDispatch();\n const { uniqid, content: widgetContent } = widget;\n const [response, setResponse] = useState<WidgetQuickSurveyResponse>({\n userResponses: [],\n totalRespondent: 0,\n totalResponse: 0,\n userLoggedResponses: [],\n });\n const [openUsersModal, setOpenUsersModal] = useState(false);\n const [isPending, setIsPending] = useState(false);\n const [usersListIndex, setUsersListIndex] = useState<number>();\n const [usersList, setUsersList] = useState<WidgetQuickSurveyResponseUserList>();\n\n const [abortController] = useState<AbortController>(new AbortController());\n const ref = useRef<AbortController>(abortController);\n\n const token = useAppSelector(Widget.selectors.selectToken, shallowEqual);\n\n const uri = useAppSelector((state) => Widget.selectors.selectWidgetObjectUri(state, widget.uniqid), shallowEqual);\n\n const widgetObjectRights = useAppSelector(\n (state) => Widget.selectors.selectWidgetObjectRights(state, uniqid),\n shallowEqual,\n );\n\n const allRt = useAppSelector(\n (state) => Widget.selectors.selectAllWidgetRTObject(state, widget.uniqid),\n shallowEqual,\n );\n\n const onChange = useCallback(\n (uniqid: string, content: WidgetQuickSurveyContent) => {\n dispatch(updateWidgetContent(uniqid, content));\n },\n [dispatch],\n );\n\n const onChangeWrapper = (content: { uniqid: string; title?: string }) => {\n dispatch(Widget.slice.actions.updateWidgetWrapper({ ...content }));\n };\n\n const openEditorPanel = (token: string) => {\n dispatch(WidgetEditor.slice.actions.flushAllEditor());\n dispatch(Widget.slice.actions.setToken({ token }));\n dispatch(\n WidgetEditor.slice.actions.registerEditor({\n uniqid: widget.uniqid,\n name: WidgetsName.QuickSurvey,\n }),\n );\n };\n\n const handleError = useCallback(\n () => dispatch(Toast.actions.error({ label: 'WIDGET_Presence_Error' })),\n [dispatch],\n );\n\n const handleResponse = useCallback(\n (uniqid: string) => {\n if (mode === 'edit' || !uri) return;\n setIsPending(true);\n jApi.widget\n .quickSurveyGetResponse({ uri, uniqid }, ref.current.signal)\n .then((response) => {\n setResponse(response.result);\n })\n .catch((err) => {\n return !err.aborted && handleError;\n })\n .finally(() => setIsPending(false));\n },\n [handleError, uri, mode],\n );\n\n const handleWidgetGet = useCallback(() => {\n if (!uri) return;\n setIsPending(true);\n jApi.widget\n .getWidget<WidgetQuickSurveyType>({ uri, uniqid }, ref.current.signal)\n .then((response) => {\n onChange(uniqid, response.result.content);\n })\n .catch((err) => {\n return !err.aborted && handleError;\n })\n .finally(() => setIsPending(false));\n }, [uniqid, handleError, uri, onChange]);\n\n const handleRespond = (index: number) => {\n if (mode === 'edit' || !uri) return;\n setIsPending(true);\n jApi.widget\n .quickSurveyRespond({ uri, index, multi: widgetContent.multi ? 1 : 0, uniqid }, ref.current.signal)\n .then(() => {\n handleResponse(widget.uniqid);\n })\n .catch((err) => !err.aborted && handleError)\n .finally(() => setIsPending(false));\n };\n\n const handleCloseSurvey = () => {\n if (!uri) return;\n if (widgetContent.closing) {\n const finalContent = { ...widgetContent, isClosed: true } as CombinedWidgetContent;\n\n jApi.widget\n .updateWidget<WidgetQuickSurveyType>({\n uri,\n uniqid,\n content: finalContent,\n })\n .catch(() => {\n handleError();\n });\n }\n };\n\n const handleProgressBarClick = (index: number) => {\n handleRespond(index);\n };\n\n const handleAddQuickAnswer = (title: string) => {\n if (!uri) return;\n\n const newContent = {\n ...widgetContent,\n arr: [...(widgetContent.arr ?? []), { title }],\n } as CombinedWidgetContent;\n\n jApi.widget\n .quickSurveyAddEnty({ uri, uniqid, label: title })\n .then(() => {\n dispatch(Widget.slice.actions.updateWidget({ uniqid, content: newContent }));\n })\n .catch(handleError);\n };\n\n const handleLoadUsersList = (index: number, page?: number) => {\n if (!uri) return;\n jApi.widget\n .quickSurveyGetResponseUserList({ uri, uniqid, index, page, limit: 8 }, ref.current.signal)\n .then((response) => {\n setUsersList({\n ...response.result,\n data: [...response.result.data],\n cnt: response.result.cnt,\n });\n })\n .catch((err) => {\n return !err.aborted && handleError;\n });\n };\n\n const canUpdate = useMemo(() => widgetObjectRights && widgetObjectRights.update, [widgetObjectRights]);\n\n useEffect(() => {\n handleResponse(widget.uniqid);\n }, [handleResponse, widget.uniqid]);\n\n useEffect(() => {\n if (!Array.isArray(allRt)) return;\n const lastRt = allRt.at(-1);\n if (!lastRt) return;\n if (!uri) return;\n\n if (lastRt.object.uri === uri && lastRt.uniqid === widget.uniqid) {\n if (lastRt.fn === 'widget-quick-survey-response') {\n handleResponse(widget.uniqid);\n }\n if (lastRt.fn === 'widget-update') {\n handleWidgetGet();\n }\n }\n }, [allRt, uri, widget.uniqid, handleWidgetGet, handleResponse]);\n\n const files = useMemo(() => {\n if (!Array.isArray(widgetContent.arr)) return [];\n\n const fs: jFileLittle[] = [];\n widgetContent.arr.forEach((el) => {\n if (el.file) {\n fs.push(el.file);\n }\n });\n\n return fs;\n }, [widgetContent]);\n\n useEffect(() => {\n if (!token && mode === 'edit') {\n jApi.network.token().then((response) => {\n dispatch(Widget.slice.actions.setToken({ token: response.result }));\n });\n }\n }, [mode, token, dispatch]);\n\n if (mode === 'edit') {\n if (inplace) {\n return (\n <WrapperContainer withPadding={true}>\n <WidgetQuickSurveyEditor\n token={token}\n uniqid={uniqid}\n content={widget.content}\n onChangeContent={onChange}\n onChangeWrapper={onChangeWrapper}\n handleChange={(content) => onChange(uniqid, content)}\n inplace={inplace}\n />\n </WrapperContainer>\n );\n }\n }\n\n return (\n <RTProvider\n useRT={() => {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useWidgetRT(widget.uniqid);\n }}>\n <WrapperContainer>\n <JRCFileViewer files={files} openWithOptions={[]}>\n {(open) => {\n return (\n <WidgetQuickSurvey\n limit={response.totalResponse ?? 0}\n values={widgetContent.arr ?? []}\n userResponses={response.userResponses}\n userHasAlreadyVoted={response.userLoggedResponses.length > 0}\n canCloseSurvey={widget.content.closing ?? false}\n isClosed={widget.content.isClosed ?? false}\n open={widget.content.open ?? false}\n anonymize={widget.content.anonymize ?? false}\n seeResponseAfter={widget.content.seeResponseAfter ?? false}\n canUpdate={canUpdate}\n handleClickFile={(entry) => entry.id && open(entry.id)}\n handleCloseSurvey={handleCloseSurvey}\n handleProgressBarClick={handleProgressBarClick}\n setOpenUsersModal={(index) => {\n setUsersListIndex(index);\n handleLoadUsersList(index);\n setOpenUsersModal(true);\n }}\n />\n );\n }}\n </JRCFileViewer>\n\n {widgetContent.open && (\n <WidgetInlineInputText\n handleClick={handleAddQuickAnswer}\n placeholder={intl.formatMessage({ id: 'FIELDS_Add_Option' })}\n />\n )}\n {canUpdate && (\n <WidgetFooterView\n uniqid={widget.uniqid}\n name={widget.name}\n collaborationRights={{\n update: !!canUpdate,\n }}\n mode={mode}\n handleOpenEditor={() => {\n if (!token) {\n setIsPending(true);\n jApi.network\n .token()\n .then((response) => {\n dispatch(Widget.slice.actions.setToken({ token: response.result }));\n openEditorPanel(response.result);\n })\n .finally(() => setIsPending(false));\n } else {\n openEditorPanel(token);\n }\n }}\n />\n )}\n {isPending && <WidgetIsPending />}\n <ModalUserList\n open={openUsersModal}\n usersList={usersList}\n title={widgetContent.arr?.[usersListIndex ?? 0]?.title ?? ''}\n setOpen={setOpenUsersModal}\n handleLoadUsersList={(page) => {\n handleLoadUsersList(usersListIndex ?? 0, page);\n }}\n onClose={() => {\n setUsersList({\n limit: 0,\n page: 0,\n data: [],\n cnt: 0,\n });\n }}\n />\n </WrapperContainer>\n </RTProvider>\n );\n};\n","import jApi, {\n OfficeProvider,\n OfficeSetConfigurationPayload,\n WidgetDisplayMode,\n WidgetEmailsImapType,\n} from 'jamespot-user-api';\nimport React, { useCallback, useEffect, useState } from 'react';\nimport { useForm } from 'react-hook-form';\nimport { useIntl, FormattedMessage } from 'react-intl';\nimport styled from 'styled-components';\nimport { JRCLoader, useAbortController } from 'jamespot-react-components';\nimport { commonComponentsRegistry } from '../../../../registry/CommonRegistry';\nimport { useDispatch } from 'react-redux';\nimport { Toast } from 'jamespot-front-business';\n\nconst ModalLayout = commonComponentsRegistry.getLazyComponent('ModalLayout');\nconst ModalContent = commonComponentsRegistry.getLazyComponent('ModalContent');\nconst Button = commonComponentsRegistry.getLazyComponent('Button');\nconst InputText = commonComponentsRegistry.getLazyComponent('InputText');\nconst InputNumber = commonComponentsRegistry.getLazyComponent('InputNumber');\nconst InputSelect = commonComponentsRegistry.getLazyComponent('InputSelect');\nconst InputPassword = commonComponentsRegistry.getLazyComponent('InputPassword');\nconst Typography = commonComponentsRegistry.getLazyComponent('Typography');\n\nexport const UIForm = styled.div<{ isLocked: boolean }>`\n display: flex;\n flex-direction: column;\n opacity: ${(props) => (props.isLocked ? '.4' : '1.0')};\n`;\n\nexport const UIWrapper = styled.div`\n position: absolute;\n inset: 0;\n display: flex;\n justify-content: center;\n align-items: center;\n`;\n\nexport const UIProviderError = styled.div`\n background-color: ${(props) => props.theme.color.orange};\n color: ${(props) => props.theme.color.white};\n padding: ${(props) => props.theme.space.sm}px;\n border-radius: ${(props) => props.theme.space.sm}px;\n display: flex;\n justify-content: center;\n align-items: center;\n`;\n\nexport type JRCWidgetEmailsImapProps = {\n widget: WidgetEmailsImapType;\n inplace: boolean;\n mode?: WidgetDisplayMode;\n};\n\nexport const officeConfigurationInitialState = {\n username: '',\n password: '',\n hostname: '',\n imapPort: 993,\n imapMailbox: '',\n cardDavAddressBook: '',\n calDavCalendar: '',\n provider: '',\n};\n\nexport const OfficeConfigurationPrompt = () => {\n const intl = useIntl();\n const dispatch = useDispatch();\n const abortController = useAbortController();\n const [isOpen, setIsOpen] = useState<boolean>(false);\n const [isPending, setIsPending] = useState<boolean>(false);\n const {\n control,\n reset,\n setValue,\n getValues,\n watch,\n formState: { isValid },\n } = useForm<OfficeSetConfigurationPayload>({\n defaultValues: officeConfigurationInitialState,\n criteriaMode: 'all',\n });\n\n const refresh = () => window.location.reload();\n const [providerList, setProviderList] = useState<OfficeProvider[]>([]);\n const data = watch();\n\n const fetchConfiguration = useCallback(\n (providers: string[]) => {\n jApi.office.getConfiguration().then(({ result }) => {\n reset({\n ...result,\n provider: !providers.includes(result.provider ?? '') ? providers[0] : result.provider,\n });\n });\n },\n [reset],\n );\n\n const handleSubmit = () => {\n if (isPending) return;\n setIsPending(true);\n jApi.office\n .setConfiguration(data)\n .then(() => refresh())\n .catch((err) => dispatch(Toast.actions.error({ label: err.errorMsg })))\n .finally(() => {\n setIsOpen(false);\n setIsPending(false);\n reset();\n });\n };\n\n useEffect(() => {\n if (!isOpen) return;\n setIsPending(true);\n jApi.office\n .getProviders({ signal: abortController.signal })\n .then(({ result }) => {\n if (!abortController.signal.aborted) {\n setProviderList(result);\n fetchConfiguration(result.map((provider) => provider.id));\n }\n })\n .catch((err) => {\n if (!abortController.signal.aborted) {\n dispatch(Toast.actions.error({ label: err.errorMsg }));\n }\n })\n .finally(() => {\n setIsPending(false);\n });\n }, [isOpen, abortController.signal, dispatch, fetchConfiguration]);\n\n useEffect(() => {\n if (providerList.length === 1) {\n setValue('provider', providerList[0].id);\n }\n }, [providerList, setValue]);\n\n const handleClose = () => setIsOpen(false);\n\n return (\n <>\n <UIWrapper>\n <Button\n label={intl.formatMessage({ id: 'Office_Set_Configuration' })}\n onClick={() => setIsOpen(true)}\n />\n </UIWrapper>\n <ModalLayout open={isOpen} radius=\"small\" closeHandler={handleClose}>\n <ModalContent\n overflow={'scroll'}\n title={intl.formatMessage({ id: 'Office_Set_Configuration' })}\n onClickIconClose={handleClose}>\n {isPending ? (\n <JRCLoader size=\"s\" />\n ) : (\n <>\n {providerList.length === 0 && (\n <UIProviderError>{intl.formatMessage({ id: 'Office_No_Providers' })}</UIProviderError>\n )}\n <UIForm isLocked={providerList.length === 0}>\n {providerList.length > 1 && (\n <Typography size={'s'}>\n <FormattedMessage id=\"OfficeHook_Conf_Provider\" />\n </Typography>\n )}\n {providerList.length > 1 && (\n <SelectProvider\n label=\"OfficeHook_Conf_Select_Provider\"\n initialValue={{ label: providerList[0].label, value: providerList[0].id }}\n options={providerList.map((el) => {\n return { label: el.label, value: el.id };\n })}\n handleChange={(value) => {\n if (getValues('provider') !== value) {\n reset();\n }\n setValue('provider', value);\n }}\n />\n )}\n <Typography size={'s'}>\n <FormattedMessage id=\"OfficeHook_Settings\" />\n </Typography>\n <InputText\n control={control}\n name={'hostname'}\n width={'400'}\n placeholder={intl.formatMessage({ id: 'OfficeHook_Conf_IMap_Hostname' })}\n rules={{ required: true }}\n />\n <InputText\n control={control}\n name={'username'}\n width={'400'}\n placeholder={intl.formatMessage({ id: 'OfficeHook_Conf_Username' })}\n rules={{ required: true }}\n />\n <InputPassword\n control={control}\n name={'password'}\n width={'400'}\n placeholder={intl.formatMessage({ id: 'OfficeHook_Conf_Password' })}\n rules={{ required: true }}\n />\n <Typography size={'s'}>\n <FormattedMessage id=\"OfficeHook_Conf_IMap_Mailbox\" />\n </Typography>\n <InputNumber\n control={control}\n name={'imapPort'}\n width={'400'}\n placeholder={intl.formatMessage({ id: 'OfficeHook_Conf_IMap_Port' })}\n rules={{ required: true }}\n />\n <InputText\n control={control}\n name={'imapMailbox'}\n width={'400'}\n placeholder={intl.formatMessage({ id: 'OfficeHook_Conf_IMap_Mailbox' })}\n rules={{ required: true }}\n />\n <Typography size={'s'}>\n <FormattedMessage id=\"OfficeHook_Conf_CalDav_Calendar\" />\n </Typography>\n <InputText\n control={control}\n name={'calDavCalendar'}\n width={'400'}\n placeholder={intl.formatMessage({ id: 'OfficeHook_Conf_CalDav_Calendar' })}\n rules={{ required: true }}\n />\n <Typography size={'s'}>\n <FormattedMessage id=\"OfficeHook_Conf_CardDav_Address_Book\" />\n </Typography>\n <InputText\n control={control}\n name={'cardDavAddressBook'}\n width={'400'}\n placeholder={intl.formatMessage({ id: 'OfficeHook_Conf_CardDav_Address_Book' })}\n rules={{ required: true }}\n />\n </UIForm>\n <Button\n label={intl.formatMessage({ id: 'OfficeHook_Conf_Prompt_Submit' })}\n loader={isPending}\n disabled={isPending || providerList.length === 0 || !isValid}\n onClick={handleSubmit}\n />\n </>\n )}\n </ModalContent>\n </ModalLayout>\n </>\n );\n};\n\nconst SelectProvider = ({\n label,\n initialValue,\n options,\n handleChange,\n}: {\n label: string;\n initialValue: { label: string; value: string };\n options: { label: string; value: string }[];\n handleChange: (value: string) => void;\n}) => {\n const { control, watch } = useForm<{ provider: { label: string; value: string } }>({\n defaultValues: {\n provider: initialValue,\n },\n criteriaMode: 'all',\n });\n\n useEffect(() => {\n const subscription = watch((data) => {\n if (!data.provider || !data.provider.value) return;\n handleChange(data.provider.value);\n });\n return () => subscription.unsubscribe();\n }, [watch, handleChange]);\n\n return (\n <InputSelect\n label={label}\n name=\"provider\"\n options={options ?? []}\n getValue={(o) => o.value}\n getLabel=\"label\"\n getSearch=\"label\"\n control={control}\n rules={{ required: true }}\n />\n );\n};\n","import React from 'react';\n\nimport { Widget } from 'jamespot-front-business';\n\nimport { shallowEqual } from 'react-redux';\nimport { useAppSelector } from '../../../../redux/store';\nimport styled from 'styled-components';\n\nexport const CSSWidgetTitle = styled.div`\n padding: ${(props) => props.theme.space.md}px;\n padding-right: 0px;\n`;\n\nexport const UITitle = styled.div<{ fontSize: string; fontWeight: string; textAlign: string; color: string }>`\n text-align: ${(props) => props.textAlign};\n font-size: ${(props) => props.fontSize}px;\n font-weight: ${(props) => props.fontWeight};\n color: ${(props) => props.color};\n`;\n\nexport const WidgetIntranetTitle = ({\n uniqid,\n textAlign = 'left',\n fontSize = '16',\n fontWeight = 'medium',\n color,\n}: {\n uniqid: string;\n textAlign: string;\n fontSize: string;\n fontWeight: string;\n color: string;\n}) => {\n const widgetWrapper = useAppSelector((state) => Widget.selectors.selectWidget(state, uniqid), shallowEqual);\n return (\n <>\n {widgetWrapper && typeof widgetWrapper.title === 'string' && widgetWrapper.title.length !== 0 && (\n <CSSWidgetTitle>\n <UITitle textAlign={textAlign} fontSize={fontSize} fontWeight={fontWeight} color={color}>\n {widgetWrapper.title}\n </UITitle>\n </CSSWidgetTitle>\n )}\n </>\n );\n};\n","import { Widget } from 'jamespot-front-business';\nimport React, { useMemo } from 'react';\nimport { shallowEqual } from 'react-redux';\n\nimport styled, { useTheme } from 'styled-components';\nimport { useAppSelector } from '../../../../redux/store';\nimport { WidgetIntranetTitle } from './WidgetIntranetTitle';\n\nexport const UIHeaderWrapper = styled.div<{ backroundColor: string }>`\n background-color: ${(props) => props.backroundColor};\n`;\n\nexport const UIHeader = styled.div`\n display: flex;\n flex-direction: row;\n align-items: center;\n`;\n\nexport const UICount = styled.div`\n padding: ${(props) => props.theme.space.sm}px ${(props) => props.theme.space.md}px;\n color: ${(props) => props.theme.color.grey4};\n`;\n\nexport const UIHeaderFlex = styled.div`\n flex: 1;\n display: flex;\n flex-direction: row;\n gap: ${(props) => props.theme.space.xs}px;\n align-items: center;\n`;\n\nexport const WidgetHeader = ({\n uniqid,\n dropdown,\n subHeader,\n}: {\n uniqid: string;\n dropdown?: () => React.ReactNode;\n subHeader?: (color: string) => React.ReactNode;\n}) => {\n const theme = useTheme();\n const styles = useAppSelector((state) => Widget.selectors.selectWidgetTitleStyle(state, uniqid), shallowEqual);\n\n const styleValues = useMemo(() => {\n return {\n color: styles && styles['color'] ? String(styles['color']) : theme.color.black,\n backgroundColor: styles && styles['background-color'] ? String(styles['background-color']) : 'transparent',\n fontSize: styles && styles['font-size'] ? String(styles['font-size']) : '16',\n fontWeight: styles && styles['font-weight'] ? String(styles['font-weight']) : 'medium',\n textAlign: styles && styles['text-align'] ? String(styles['text-align']) : 'left',\n };\n }, [styles, theme]);\n\n return (\n <UIHeaderWrapper backroundColor={styleValues.backgroundColor}>\n <UIHeader>\n <UIHeaderFlex>\n <WidgetIntranetTitle\n uniqid={uniqid}\n fontWeight={styleValues.fontWeight}\n fontSize={styleValues.fontSize}\n textAlign={styleValues.textAlign}\n color={styleValues.color}\n />\n {subHeader && subHeader(styleValues.color)}\n </UIHeaderFlex>\n {dropdown && dropdown()}\n </UIHeader>\n </UIHeaderWrapper>\n );\n};\n","import jApi from 'jamespot-user-api';\nimport React from 'react';\nimport styled from 'styled-components';\nimport { JRCButtonDropdownOptionProps } from 'jamespot-react-components';\nimport { officeConfigurationInitialState } from '../components/OfficeConfigurationPrompt';\n\nimport { useIntl } from 'react-intl';\nimport { useDispatch } from 'react-redux';\nimport { Widget } from 'jamespot-front-business';\nimport { commonComponentsRegistry } from '../../../../registry/CommonRegistry';\nimport { WidgetHeader } from '../components/WidgetHeader';\n\nconst ButtonDropdown = commonComponentsRegistry.getLazyComponent('ButtonDropdown');\nconst Tooltip = commonComponentsRegistry.getLazyComponent('Tooltip');\n\nexport const UIDropdown = styled.div`\n margin-right: ${(props) => props.theme.space.sm}px;\n button {\n background: ${(props) => props.theme.color.white};\n }\n`;\n\nexport const WidgetContactCardDavHeader = ({\n uniqid,\n isConfigurationValid = false,\n handleLogout,\n}: {\n uniqid: string;\n isConfigurationValid: boolean;\n handleLogout: () => void;\n}) => {\n const intl = useIntl();\n const dispatch = useDispatch();\n const onLogout = () => {\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, loading: true }));\n jApi.office.setConfiguration(officeConfigurationInitialState).finally(handleLogout);\n };\n\n const options: JRCButtonDropdownOptionProps[] = [\n { label: intl.formatMessage({ id: 'WIDGET_Prompt_Logout' }), onClick: onLogout },\n ];\n\n return (\n <WidgetHeader\n uniqid={uniqid}\n dropdown={() => {\n return (\n isConfigurationValid && (\n <UIDropdown>\n <Tooltip\n position={'left'}\n description={intl.formatMessage({ id: 'WIDGET_Prompt_Dropdown' })}>\n <ButtonDropdown\n small\n smallOpenDirection=\"left\"\n options={options}\n icon={'icon-edit'}\n label={''}\n color=\"primary\"\n variant=\"outlined\"\n />\n </Tooltip>\n </UIDropdown>\n )\n );\n }}\n />\n );\n};\n","import React from 'react';\nimport styled from 'styled-components';\n\nexport const UIFlex = styled.div`\n flex-direction: column;\n display: flex;\n flex: 1;\n`;\n\nexport const UIScrollWrapper = styled.div`\n position: relative;\n display: flex;\n flex: 1;\n`;\n\nexport const UIScroll = styled.div`\n overflow: auto;\n position: absolute;\n inset: 0;\n`;\n\n// TODO: BETTER NAMING ?\nexport const WidgetScroll = ({\n header,\n scrollable,\n footer,\n}: {\n header?: () => React.ReactNode;\n scrollable?: () => React.ReactNode;\n footer?: () => React.ReactNode;\n}) => {\n return (\n <UIFlex>\n {header && header()}\n <UIScrollWrapper>\n <UIScroll>{scrollable && scrollable()}</UIScroll>\n </UIScrollWrapper>\n {footer && footer()}\n </UIFlex>\n );\n};\n","import React, { useMemo } from 'react';\nimport { Widget } from 'jamespot-front-business';\n\nimport { shallowEqual } from 'react-redux';\nimport { useAppSelector } from '../../../../redux/store';\nimport styled from 'styled-components';\n\nexport const UIWrapper = styled.div<{\n padding: string;\n}>`\n display: flex;\n flex-direction: column;\n padding: ${(props) => props.padding};\n`;\n\nexport const WidgetStylePadding = ({ uniqid, children }: { uniqid: string; children: React.ReactNode }) => {\n const styles = useAppSelector((state) => Widget.selectors.selectWidgetWrapperStyle(state, uniqid), shallowEqual);\n\n const initialValues = useMemo(() => {\n return {\n padding: styles && styles['padding'] ? String(styles['padding']) : '0',\n };\n }, [styles]);\n\n return <UIWrapper padding={initialValues.padding}>{children}</UIWrapper>;\n};\n","import jApi, {\n DavAddressBookContact,\n WIDGET_LEVEL_1,\n WIDGET_LEVEL_3,\n WidgetContactCardDavType,\n WidgetDisplayMode,\n WidgetWrapperLevel,\n} from 'jamespot-user-api';\nimport { Toast, Widget } from 'jamespot-front-business';\nimport React, { useCallback, useEffect, useState } from 'react';\nimport { shallowEqual } from 'react-redux';\nimport { officeConfigurationInitialState, OfficeConfigurationPrompt } from './components/OfficeConfigurationPrompt';\nimport { WidgetContactCardDavHeader } from './WidgetContactCardDav/WidgetContactCardDavHeader';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { WidgetScroll } from './components/WidgetScroll';\nimport { WidgetStylePadding } from './components/WidgetStylePadding';\nimport { useAppSelector, useAppDispatch } from '../../../redux/store';\n\nconst WidgetContactCardDav = commonComponentsRegistry.getLazyComponent('WidgetContactCardDav');\n\nexport type JRCWidgetContactCardDavProps = {\n widget: WidgetContactCardDavType;\n inplace: boolean;\n mode?: WidgetDisplayMode;\n levelFallback?: (level: WidgetWrapperLevel, url: string) => React.ReactNode | undefined;\n};\n\nconst REFRESH_INTERVAL = 4000;\n\nexport const JRCWidgetContactCardDavWrapper = ({ widget, mode, levelFallback }: JRCWidgetContactCardDavProps) => {\n const { uniqid } = widget;\n const dispatch = useAppDispatch();\n const [isConfigurationValid, setIsConfigurationValid] = useState<boolean | undefined>(undefined);\n const [url, setUrl] = useState<string | undefined>(undefined);\n const [doInterval, setDoInterval] = useState<boolean>(false);\n const level = useAppSelector((state) => Widget.selectors.selectWidgetLevel(state, uniqid), shallowEqual);\n const [list, setList] = useState<DavAddressBookContact[]>([]);\n\n const handleLogout = useCallback(\n (err?: any, reload?: boolean) => {\n if (err && err.error === 400) {\n jApi.office.setConfiguration(officeConfigurationInitialState);\n }\n if (reload) {\n window.location.reload();\n return;\n }\n\n setIsConfigurationValid(false);\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, initialized: true, loading: false }));\n },\n [dispatch, uniqid],\n );\n\n const handleLogin = useCallback(\n (isValid: boolean) => {\n setIsConfigurationValid(isValid);\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, initialized: true }));\n },\n [dispatch, uniqid],\n );\n\n const handleLoading = useCallback(\n (loading: boolean) => dispatch(Widget.slice.actions.setWidgetState({ uniqid, loading })),\n [uniqid, dispatch],\n );\n\n const fetchProviderUrls = useCallback(() => {\n jApi.office\n .getProviderBaseUrls()\n .then(({ result }) => {\n setUrl(result.dav_address_book_url);\n })\n .finally(() => handleLoading(false));\n }, [handleLoading]);\n\n const fetchData = useCallback(() => {\n jApi.office\n .davAddressBookGetContacts({ limit: 10 })\n .then(({ result }) => {\n setList(result);\n setDoInterval(true);\n })\n .catch(() => {\n dispatch(Toast.actions.error({ label: 'PLUGIN_Manager_Connection_Error' }));\n setIsConfigurationValid(false);\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, initialized: true, loading: false }));\n })\n .finally(() => handleLoading(false));\n }, [handleLoading, dispatch, uniqid]);\n\n useEffect(() => {\n if (!doInterval) return;\n if (!isConfigurationValid) return;\n if (level !== WIDGET_LEVEL_3) return;\n const interval = setInterval(fetchData, REFRESH_INTERVAL);\n return () => clearInterval(interval);\n }, [isConfigurationValid, fetchData, doInterval, level]);\n\n useEffect(() => {\n handleLoading(true);\n jApi.office\n .isConfigurationValid()\n .then(({ result }) => handleLogin(result))\n .catch(handleLogout)\n .finally(() => handleLoading(false));\n }, [handleLogin, level, fetchProviderUrls, handleLoading, handleLogout]);\n\n useEffect(() => {\n if (!isConfigurationValid) return;\n if (level === WIDGET_LEVEL_1) {\n handleLoading(true);\n fetchProviderUrls();\n return;\n }\n fetchData();\n }, [isConfigurationValid, fetchProviderUrls, handleLoading, fetchData, level]);\n\n if (isConfigurationValid && level && level !== WIDGET_LEVEL_3 && levelFallback) {\n return <>{levelFallback(level, url ?? '')}</>;\n }\n\n return (\n <WidgetScroll\n header={() => {\n return (\n <>\n <WidgetContactCardDavHeader\n uniqid={uniqid}\n isConfigurationValid={isConfigurationValid !== undefined && isConfigurationValid === true}\n handleLogout={() => handleLogout(undefined, true)}\n />\n </>\n );\n }}\n scrollable={() => {\n return (\n <WidgetStylePadding uniqid={uniqid}>\n {isConfigurationValid && <WidgetContactCardDav contactCardList={list} />}\n {isConfigurationValid === undefined && <></>}\n {isConfigurationValid !== undefined && isConfigurationValid === false && mode === 'view' && (\n <OfficeConfigurationPrompt />\n )}\n </WidgetStylePadding>\n );\n }}\n />\n );\n};\n","import jApi from 'jamespot-user-api';\nimport React from 'react';\nimport { useIntl } from 'react-intl';\nimport styled from 'styled-components';\nimport { JRCButtonDropdownOptionProps } from 'jamespot-react-components';\nimport { officeConfigurationInitialState } from '../components/OfficeConfigurationPrompt';\n\nimport { useDispatch } from 'react-redux';\nimport { Widget } from 'jamespot-front-business';\nimport { commonComponentsRegistry } from '../../../../registry/CommonRegistry';\nimport { WidgetHeader } from '../components/WidgetHeader';\n\nconst ButtonDropdown = commonComponentsRegistry.getLazyComponent('ButtonDropdown');\nconst Tooltip = commonComponentsRegistry.getLazyComponent('Tooltip');\n\nexport const UIDropdown = styled.div`\n margin-right: ${(props) => props.theme.space.sm}px;\n button {\n background: ${(props) => props.theme.color.white};\n }\n`;\n\nexport const WidgetCalendarCalDavHeader = ({\n uniqid,\n isConfigurationValid = false,\n handleLogout,\n}: {\n uniqid: string;\n isConfigurationValid: boolean;\n handleLogout: () => void;\n}) => {\n const intl = useIntl();\n const dispatch = useDispatch();\n const onLogout = () => {\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, loading: true }));\n jApi.office.setConfiguration(officeConfigurationInitialState).finally(handleLogout);\n };\n\n const options: JRCButtonDropdownOptionProps[] = [\n { label: intl.formatMessage({ id: 'WIDGET_Prompt_Logout' }), onClick: onLogout },\n ];\n\n return (\n <WidgetHeader\n uniqid={uniqid}\n dropdown={() => {\n return (\n isConfigurationValid && (\n <UIDropdown>\n <Tooltip\n position={'left'}\n description={intl.formatMessage({ id: 'WIDGET_Prompt_Dropdown' })}>\n <ButtonDropdown\n small\n smallOpenDirection=\"left\"\n options={options}\n icon={'icon-edit'}\n label={''}\n color=\"primary\"\n variant=\"outlined\"\n />\n </Tooltip>\n </UIDropdown>\n )\n );\n }}\n />\n );\n};\n","import { Toast, Widget } from 'jamespot-front-business';\nimport jApi, {\n DavCalendarEvent,\n WIDGET_LEVEL_1,\n WIDGET_LEVEL_3,\n WidgetCalendarCalDavType,\n WidgetDisplayMode,\n WidgetWrapperLevel,\n} from 'jamespot-user-api';\nimport React, { useCallback, useEffect, useState } from 'react';\nimport { shallowEqual } from 'react-redux';\nimport { officeConfigurationInitialState, OfficeConfigurationPrompt } from './components/OfficeConfigurationPrompt';\nimport { WidgetCalendarCalDavHeader } from './WidgetCalendarCalDav/WidgetCalendarCalDavHeader';\nimport { useMoment } from 'jamespot-react-components';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { WidgetScroll } from './components/WidgetScroll';\nimport { WidgetStylePadding } from './components/WidgetStylePadding';\nimport { useAppSelector, useAppDispatch } from '../../../redux/store';\n\nconst WidgetCalendarCalDav = commonComponentsRegistry.getLazyComponent('WidgetCalendarCalDav');\n\nexport type JRCWidgetCalendarCalDavWrapperProps = {\n widget: WidgetCalendarCalDavType;\n inplace: boolean;\n mode?: WidgetDisplayMode;\n levelFallback?: (level: WidgetWrapperLevel, url: string) => React.ReactNode | undefined;\n};\n\nconst REFRESH_INTERVAL = 60 * 1000;\n\nexport const JRCWidgetCalendarCalDavWrapper = ({\n widget,\n mode,\n levelFallback,\n}: JRCWidgetCalendarCalDavWrapperProps) => {\n const { uniqid } = widget;\n const dispatch = useAppDispatch();\n const [isConfigurationValid, setIsConfigurationValid] = useState<boolean | undefined>(undefined);\n const [doInterval, setDoInterval] = useState<boolean>(false);\n const level = useAppSelector((state) => Widget.selectors.selectWidgetLevel(state, uniqid), shallowEqual);\n\n const { moment } = useMoment();\n const [url, setUrl] = useState<string | undefined>(undefined);\n const [list, setList] = useState<DavCalendarEvent[]>([]);\n\n const handleLogout = useCallback(\n (err?: any, reload?: boolean) => {\n if (err && err.error === 400) {\n jApi.office.setConfiguration(officeConfigurationInitialState);\n }\n if (reload) {\n window.location.reload();\n return;\n }\n\n setIsConfigurationValid(false);\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, initialized: true, loading: false }));\n },\n [dispatch, uniqid],\n );\n\n const handleLogin = useCallback(\n (isValid: boolean) => {\n setIsConfigurationValid(isValid);\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, initialized: true }));\n },\n [dispatch, uniqid],\n );\n\n const handleLoading = useCallback(\n (loading: boolean) => dispatch(Widget.slice.actions.setWidgetState({ uniqid, loading })),\n [uniqid, dispatch],\n );\n\n const fetchProviderUrls = useCallback(() => {\n jApi.office\n .getProviderBaseUrls()\n .then(({ result }) => {\n setUrl(result.dav_calendar_url);\n })\n .finally(() => handleLoading(false));\n }, [handleLoading]);\n\n const fetchData = useCallback(() => {\n jApi.office\n .davCalendarGetEvents({\n limit: 10,\n dateStart: moment().format('YYYY-MM-DD hh:mm:ss'),\n dateEnd: moment(moment()).add(1, 'M').format('YYYY-MM-DD hh:mm:ss'),\n })\n .then(({ result }) => {\n setList(result);\n setDoInterval(true);\n })\n .catch(() => {\n dispatch(Toast.actions.error({ label: 'PLUGIN_Manager_Connection_Error' }));\n setIsConfigurationValid(false);\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, initialized: true, loading: false }));\n })\n .finally(() => handleLoading(false));\n }, [handleLoading, dispatch, uniqid, moment]);\n\n useEffect(() => {\n if (!doInterval) return;\n if (!isConfigurationValid) return;\n if (level !== WIDGET_LEVEL_3) return;\n const interval = setInterval(fetchData, REFRESH_INTERVAL);\n return () => clearInterval(interval);\n }, [isConfigurationValid, fetchData, doInterval, level]);\n\n useEffect(() => {\n handleLoading(true);\n jApi.office\n .isConfigurationValid()\n .then(({ result }) => handleLogin(result))\n .catch(handleLogout);\n }, [handleLogout, handleLoading, handleLogin]);\n\n useEffect(() => {\n if (!isConfigurationValid) return;\n if (level === WIDGET_LEVEL_1) {\n handleLoading(true);\n fetchProviderUrls();\n return;\n }\n fetchData();\n }, [isConfigurationValid, fetchProviderUrls, handleLoading, fetchData, moment, level]);\n\n if (isConfigurationValid && level && level !== WIDGET_LEVEL_3 && levelFallback) {\n return <>{levelFallback(level, url ?? '')}</>;\n }\n\n return (\n <WidgetScroll\n header={() => {\n return (\n <>\n <WidgetCalendarCalDavHeader\n uniqid={uniqid}\n isConfigurationValid={isConfigurationValid !== undefined && isConfigurationValid === true}\n handleLogout={() => handleLogout(undefined, true)}\n />\n </>\n );\n }}\n scrollable={() => {\n return (\n <WidgetStylePadding uniqid={uniqid}>\n {isConfigurationValid && <WidgetCalendarCalDav calendarListEvent={list} />}\n {isConfigurationValid === undefined && <></>}\n {isConfigurationValid !== undefined && isConfigurationValid === false && mode === 'view' && (\n <OfficeConfigurationPrompt />\n )}\n </WidgetStylePadding>\n );\n }}\n />\n );\n};\n","import jApi from 'jamespot-user-api';\nimport { Widget } from 'jamespot-front-business';\nimport React from 'react';\nimport { shallowEqual } from 'react-redux';\nimport { useIntl } from 'react-intl';\nimport styled from 'styled-components';\nimport { JRCButtonDropdownOptionProps } from 'jamespot-react-components';\nimport { officeConfigurationInitialState } from '../components/OfficeConfigurationPrompt';\nimport { useAppSelector, useAppDispatch } from '../../../../redux/store';\nimport { commonComponentsRegistry } from '../../../../registry/CommonRegistry';\nimport { WidgetHeader } from '../components/WidgetHeader';\n\nconst ButtonDropdown = commonComponentsRegistry.getLazyComponent('ButtonDropdown');\nconst Tooltip = commonComponentsRegistry.getLazyComponent('Tooltip');\n\nexport const UIDropdown = styled.div`\n margin-right: ${(props) => props.theme.space.sm}px;\n button {\n background: ${(props) => props.theme.color.white};\n }\n`;\n\nexport const UICount = styled.div<{ color: string }>`\n font-size: ${(props) => props.theme.size.sm + 4}px;\n color: ${(props) => props.color};\n`;\n\nexport const WidgetEmailsImapHeader = ({\n uniqid,\n isConfigurationValid = false,\n handleLogout,\n}: {\n uniqid: string;\n isConfigurationValid: boolean;\n handleLogout: () => void;\n}) => {\n const intl = useIntl();\n const dispatch = useAppDispatch();\n\n const count = useAppSelector((state) => Widget.selectors.selectWidgetChipCount(state, uniqid), shallowEqual);\n\n const onLogout = () => {\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, loading: true }));\n jApi.office.setConfiguration(officeConfigurationInitialState).finally(handleLogout);\n };\n\n const options: JRCButtonDropdownOptionProps[] = [\n { label: intl.formatMessage({ id: 'WIDGET_Prompt_Logout' }), onClick: onLogout },\n ];\n\n return (\n <WidgetHeader\n uniqid={uniqid}\n dropdown={() => {\n return (\n isConfigurationValid && (\n <UIDropdown>\n <Tooltip\n position={'left'}\n description={intl.formatMessage({ id: 'WIDGET_Prompt_Dropdown' })}>\n <ButtonDropdown\n small\n smallOpenDirection=\"left\"\n options={options}\n icon={'icon-edit'}\n label={''}\n color=\"primary\"\n variant=\"outlined\"\n />\n </Tooltip>\n </UIDropdown>\n )\n );\n }}\n subHeader={(color: string) => {\n return (\n isConfigurationValid &&\n count !== 0 && (\n <UICount color={color}>\n ({intl.formatMessage({ id: 'WIDGET_Email_IMAP_Unread_Emails' }, { count })})\n </UICount>\n )\n );\n }}\n />\n );\n};\n","import jApi, {\n ImapInboxMail,\n WIDGET_LEVEL_1,\n WIDGET_LEVEL_2,\n WIDGET_LEVEL_3,\n WidgetDisplayMode,\n WidgetEmailsImapType,\n WidgetWrapperLevel,\n} from 'jamespot-user-api';\nimport { Toast, Widget } from 'jamespot-front-business';\nimport React, { useCallback, useEffect, useState } from 'react';\nimport { shallowEqual } from 'react-redux';\nimport { WidgetEmailsImapHeader } from './WidgetEmailsImap/WidgetEmailsImapHeader';\nimport { officeConfigurationInitialState, OfficeConfigurationPrompt } from './components/OfficeConfigurationPrompt';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { WidgetScroll } from './components/WidgetScroll';\nimport { WidgetStylePadding } from './components/WidgetStylePadding';\nimport { useAppSelector, useAppDispatch } from '../../../redux/store';\n\nconst WidgetEmailsImap = commonComponentsRegistry.getLazyComponent('WidgetEmailsImap');\n\nconst REFRESH_INTERVAL = 60 * 1000;\n\nexport type JRCWidgetEmailsImapProps = {\n widget: WidgetEmailsImapType;\n inplace: boolean;\n mode?: WidgetDisplayMode;\n levelFallback?: (level: WidgetWrapperLevel, url: string) => React.ReactNode | undefined;\n};\n\nexport const JRCWidgetEmailsImapWrapper = ({ widget, mode, levelFallback }: JRCWidgetEmailsImapProps) => {\n const { uniqid } = widget;\n const dispatch = useAppDispatch();\n const [isConfigurationValid, setIsConfigurationValid] = useState<boolean | undefined>(undefined);\n const [doInterval, setDoInterval] = useState<boolean>(false);\n const [list, setList] = useState<ImapInboxMail[]>([]);\n const [url, setUrl] = useState<string | undefined>(undefined);\n const level = useAppSelector((state) => Widget.selectors.selectWidgetLevel(state, widget.uniqid), shallowEqual);\n\n const handleLogout = useCallback(\n (err?: any, reload?: boolean) => {\n if (err && err.error === 400) {\n jApi.office.setConfiguration(officeConfigurationInitialState);\n }\n if (reload) {\n window.location.reload();\n return;\n }\n\n setIsConfigurationValid(false);\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, initialized: true, loading: false }));\n },\n [dispatch, uniqid],\n );\n\n const fetchUnreadEmailsCount = useCallback(() => {\n jApi.office\n .imapInboxGetUnreadEmailsCount()\n .then(({ result }) => {\n dispatch(Widget.slice.actions.setWidgetChipCount({ uniqid, count: result }));\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, initialized: true }));\n })\n .catch(handleLogout);\n }, [dispatch, uniqid, handleLogout]);\n\n const handleLoading = useCallback(\n (loading: boolean) => dispatch(Widget.slice.actions.setWidgetState({ uniqid, loading })),\n [uniqid, dispatch],\n );\n\n const fetchProviderUrls = useCallback(() => {\n jApi.office\n .getProviderBaseUrls()\n .then(({ result }) => {\n setUrl(result.imap_inbox_url);\n })\n .finally(() => handleLoading(false));\n }, [handleLoading]);\n\n const handleLogin = useCallback(\n (isValid: boolean) => {\n setIsConfigurationValid(isValid);\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, initialized: true }));\n },\n [dispatch, uniqid],\n );\n\n const fetchData = useCallback(() => {\n jApi.office\n .imapInboxGetEmails({ limit: 10 })\n .then(({ result }) => {\n setList(result);\n setDoInterval(true);\n })\n .catch(() => {\n dispatch(Toast.actions.error({ label: 'PLUGIN_Manager_Connection_Error' }));\n setIsConfigurationValid(false);\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, initialized: true, loading: false }));\n })\n .finally(() => handleLoading(false));\n }, [handleLoading, dispatch, uniqid]);\n\n useEffect(() => {\n if (!doInterval) return;\n if (!isConfigurationValid) return;\n if (level === WIDGET_LEVEL_1) return;\n const interval = setInterval(() => {\n if (level === WIDGET_LEVEL_2) {\n fetchUnreadEmailsCount();\n }\n if (level === WIDGET_LEVEL_3) {\n fetchUnreadEmailsCount();\n fetchData();\n }\n }, REFRESH_INTERVAL);\n return () => clearInterval(interval);\n }, [isConfigurationValid, fetchData, doInterval, fetchUnreadEmailsCount, level]);\n\n useEffect(() => {\n jApi.office\n .isConfigurationValid()\n .then(({ result }) => handleLogin(result))\n .catch(handleLogout);\n }, [handleLogin, handleLogout]);\n\n useEffect(() => {\n if (!isConfigurationValid) return;\n if (level === WIDGET_LEVEL_1) {\n handleLoading(true);\n fetchProviderUrls();\n return;\n }\n if (level === WIDGET_LEVEL_2) {\n handleLoading(true);\n fetchUnreadEmailsCount();\n fetchProviderUrls();\n return;\n }\n\n handleLoading(true);\n fetchUnreadEmailsCount();\n fetchData();\n }, [isConfigurationValid, level, fetchProviderUrls, fetchData, handleLoading, fetchUnreadEmailsCount, dispatch]);\n\n if (isConfigurationValid && level && level !== WIDGET_LEVEL_3 && levelFallback) {\n return <>{levelFallback(level, url ?? '')}</>;\n }\n\n return (\n <WidgetScroll\n header={() => {\n return (\n <>\n <WidgetEmailsImapHeader\n uniqid={uniqid}\n isConfigurationValid={isConfigurationValid !== undefined && isConfigurationValid === true}\n handleLogout={() => handleLogout(undefined, true)}\n />\n </>\n );\n }}\n scrollable={() => {\n return (\n <WidgetStylePadding uniqid={uniqid}>\n {isConfigurationValid === undefined && <></>}\n {isConfigurationValid !== undefined && isConfigurationValid === false && mode === 'view' && (\n <OfficeConfigurationPrompt />\n )}\n {isConfigurationValid && <WidgetEmailsImap emailList={list} />}\n </WidgetStylePadding>\n );\n }}\n />\n );\n};\n","import React from 'react';\nimport { Widget } from 'jamespot-front-business';\nimport { shallowEqual } from 'react-redux';\nimport styled from 'styled-components';\nimport { JRCHtml } from 'jamespot-react-components';\nimport { useAppSelector } from '../../../../redux/store';\n\nexport const CSSWidgetTitle = styled.div`\n padding: ${(props) => props.theme.space.md}px;\n border-bottom: 1px solid ${(props) => props.theme.color.grey1};\n`;\n\nexport const WidgetTitle = ({ uniqid }: { uniqid: string }) => {\n const widgetWrapper = useAppSelector((state) => Widget.selectors.selectWidget(state, uniqid), shallowEqual);\n return (\n <>\n {widgetWrapper && typeof widgetWrapper.title === 'string' && widgetWrapper.title.length !== 0 && (\n <CSSWidgetTitle>\n <JRCHtml __html={widgetWrapper.title ?? ''} />\n </CSSWidgetTitle>\n )}\n </>\n );\n};\n","import { Widget } from 'jamespot-front-business';\nimport { JRCInputText } from 'jamespot-react-components';\nimport React, { useEffect } from 'react';\nimport { useForm } from 'react-hook-form';\nimport { useIntl } from 'react-intl';\nimport { shallowEqual } from 'react-redux';\nimport { useAppDispatch, useAppSelector } from '../../../../redux/store';\n\nexport const WidgetTitleEdit = ({ uniqid }: { uniqid: string }) => {\n const intl = useIntl();\n const dispatch = useAppDispatch();\n const widgetWrapperTitle = useAppSelector(\n (state) => Widget.selectors.selectWidget(state, uniqid)?.title,\n shallowEqual,\n );\n\n const { control, watch } = useForm({\n defaultValues: { widgetTitle: widgetWrapperTitle },\n criteriaMode: 'all',\n });\n\n useEffect(() => {\n const subscription = watch((data) => {\n dispatch(Widget.slice.actions.updateWidgetWrapper({ uniqid, title: data.widgetTitle }));\n });\n return () => subscription.unsubscribe();\n }, [watch, dispatch, uniqid]);\n\n return (\n <JRCInputText\n name={'widgetTitle'}\n control={control}\n placeholder={intl.formatMessage({ id: 'GLOBAL_Title' })}\n width=\"100%\"\n margin=\"0\"\n />\n );\n};\n","import React, { useCallback, useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport styled from 'styled-components';\nimport { WidgetTitleEdit } from './WidgetTitleEdit';\nimport { JRCIconButton } from 'jamespot-react-components';\nimport { Widget, WidgetEditor } from 'jamespot-front-business';\nimport { WidgetsName } from 'jamespot-user-api';\nimport { commonComponentsRegistry } from '../../../../registry/CommonRegistry';\nimport { useAppDispatch } from '../../../../redux/store';\n\nconst JRCButton = commonComponentsRegistry.getLazyComponent('Button');\nconst JRCModalLayout = commonComponentsRegistry.getLazyComponent('ModalLayout');\nconst JRCModalContent = commonComponentsRegistry.getLazyComponent('ModalContent');\n\nexport const CSSModalFooter = styled.div`\n padding: ${(props) => props.theme.space.md}px;\n display: flex;\n flex-direction: row-reverse;\n`;\n\nexport const CSSWidgetHeaderEdit = styled.div`\n flex: 1;\n display: flex;\n flex-direction: row;\n gap: ${(props) => props.theme.space.sm}px;\n padding: ${(props) => props.theme.space.sm}px;\n border-bottom: 1px solid ${(props) => props.theme.color.grey1};\n`;\n\nexport const CSSWidgetHeaderEditTitle = styled.div`\n flex: 1;\n display: flex;\n fieldset:first-of-type {\n margin: 0px !important;\n }\n`;\n\nexport const CSSWidgetHeaderEditActions = styled.div`\n display: flex;\n gap: ${(props) => props.theme.space.sm}px;\n`;\n\nexport const WidgetHeaderEdit = ({\n uniqid,\n name,\n handleOpenEditor,\n}: {\n uniqid: string;\n name: WidgetsName;\n handleOpenEditor?: () => void;\n}) => {\n const dispatch = useAppDispatch();\n const intl = useIntl();\n const [isOpen, setIsOpen] = useState<boolean>(false);\n\n const handleOnClick = useCallback(() => {\n dispatch(\n WidgetEditor.slice.actions.registerEditor({\n uniqid,\n name,\n mode: 'edit',\n }),\n );\n }, [uniqid, dispatch, name]);\n\n const handleRemoveWidget = useCallback(() => {\n dispatch(Widget.slice.actions.flushWidget({ uniqid }));\n }, [uniqid, dispatch]);\n\n return (\n <>\n <CSSWidgetHeaderEdit>\n <CSSWidgetHeaderEditTitle>\n <WidgetTitleEdit uniqid={uniqid} />\n </CSSWidgetHeaderEditTitle>\n <CSSWidgetHeaderEditActions>\n <JRCIconButton\n icon=\"icon-pencil\"\n bg={'grey1'}\n bgHover={'grey2'}\n color={'grey5'}\n iconSize={14}\n onClick={handleOpenEditor ?? handleOnClick}\n title={intl.formatMessage({ id: 'BUTTON_Title_Open_Edit_Panel' })}\n />\n <JRCIconButton\n icon=\"icon-trash\"\n bg={'grey1'}\n bgHover={'grey2'}\n color={'grey5'}\n iconSize={14}\n onClick={() => setIsOpen(true)}\n title={intl.formatMessage({ id: 'BUTTON_Title_Open_Remove_Widget' })}\n />\n </CSSWidgetHeaderEditActions>\n </CSSWidgetHeaderEdit>\n {isOpen && (\n <JRCModalLayout enableClickAwayCloseModal={true} open={isOpen} closeHandler={() => setIsOpen(false)}>\n <JRCModalContent\n overflow={'scroll'}\n title={intl.formatMessage({ id: 'WIDGET_Remove_Widget' })}\n onClickIconClose={() => setIsOpen(false)}>\n {intl.formatMessage({ id: 'WIDGET_Delete_Widget_Confirmation' })}\n </JRCModalContent>\n <CSSModalFooter>\n <JRCButton label={intl.formatMessage({ id: 'GLOBAL_Confirm' })} onClick={handleRemoveWidget} />\n </CSSModalFooter>\n </JRCModalLayout>\n )}\n </>\n );\n};\n","import React, { ReactNode } from 'react';\n\nimport {\n CombinedWidgetType,\n ensureWidgetArticleAttachmentType,\n ensureWidgetArticleButtonType,\n ensureWidgetArticleGalleryType,\n ensureWidgetArticleImageType,\n ensureWidgetArticleSliderType,\n ensureWidgetArticleTextType,\n ensureWidgetArticleTitleType,\n ensureWidgetCalendarCalDavType,\n ensureWidgetCheckListType,\n ensureWidgetContactCardDavType,\n ensureWidgetDatasourceTableType,\n ensureWidgetEmailsImapType,\n ensureWidgetExcelDatasourceTableType,\n ensureWidgetPresenceType,\n ensureWidgetQuickSurveyType,\n WidgetDisplayMode,\n WidgetWrapperLevel,\n} from 'jamespot-user-api';\n\nimport styled from 'styled-components';\n\nexport const CSSWidgetWithTitle = styled.div`\n display: flex;\n flex: 1;\n flex-direction: column;\n`;\n\nimport { JRCWidgetArticleAttachmentWrapper } from './wrapper/JRCWidgetArticleAttachmentWrapper';\nimport { JRCWidgetArticleButtonWrapper } from './wrapper/JRCWidgetArticleButtonWrapper';\nimport { JRCWidgetArticleGalleryWrapper } from './wrapper/JRCWidgetArticleGalleryWrapper';\nimport { JRCWidgetArticleImageWrapper } from './wrapper/JRCWidgetArticleImageWrapper';\nimport { JRCWidgetArticleSliderWrapper } from './wrapper/JRCWidgetArticleSliderWrapper';\nimport { JRCWidgetArticleTextWrapper } from './wrapper/JRCWidgetArticleTextWrapper';\nimport { JRCWidgetArticleTitleWrapper } from './wrapper/JRCWidgetArticleTitleWrapper';\nimport { JRCWidgetCheckListWrapper } from './wrapper/JRCWidgetCheckListWrapper';\nimport { WidgetDatasourceTableWrapper } from './wrapper/JRCWidgetDatasourceTableWrapper';\nimport { WidgetExcelDatasourceTableWrapper } from './wrapper/JRCWidgetExcelDatasourceTableWrapper';\nimport { JRCWidgetPresenceWrapper } from './wrapper/JRCWidgetPresenceWrapper';\nimport { JRCWidgetQuickSurveyWrapper } from './wrapper/JRCWidgetQuickSurveyWrapper';\n\nimport { JRCWidgetContactCardDavWrapper } from './wrapper/JRCWidgetContactCardDavWrapper';\nimport { JRCWidgetCalendarCalDavWrapper } from './wrapper/JRCWidgetCalendarCalDavWrapper';\nimport { JRCWidgetEmailsImapWrapper } from './wrapper/JRCWidgetEmailsImapWrapper';\n\nimport { WidgetTitle } from './wrapper/components/WidgetTitle';\n\nimport { WidgetHeaderEdit } from './wrapper/components/WidgetHeaderEdit';\n\nexport const DisplayWidget = ({\n widget,\n width,\n inplace = false,\n mode = 'view',\n onWidgetUpdate,\n cannotDisplayComponent,\n levelFallback,\n dataCy,\n}: {\n widget: CombinedWidgetType;\n width?: number | undefined;\n inplace: boolean;\n mode: WidgetDisplayMode;\n onWidgetUpdate?: () => void;\n cannotDisplayComponent?: (widget: string) => ReactNode;\n levelFallback?: (level: WidgetWrapperLevel, url: string) => ReactNode | undefined;\n dataCy?: string;\n}) => {\n const { name } = widget;\n\n if (ensureWidgetArticleButtonType(widget)) {\n return <JRCWidgetArticleButtonWrapper widget={widget} inplace={inplace} mode={mode} />;\n } else if (ensureWidgetArticleGalleryType(widget)) {\n return <JRCWidgetArticleGalleryWrapper widget={widget} inplace={inplace} mode={mode} />;\n } else if (ensureWidgetArticleAttachmentType(widget)) {\n return <JRCWidgetArticleAttachmentWrapper widget={widget} inplace={inplace} mode={mode} />;\n } else if (ensureWidgetArticleImageType(widget)) {\n return <JRCWidgetArticleImageWrapper widget={widget} inplace={inplace} mode={mode} />;\n } else if (ensureWidgetArticleSliderType(widget)) {\n return <JRCWidgetArticleSliderWrapper widget={widget} inplace={inplace} mode={mode} width={width ?? 800} />;\n } else if (ensureWidgetArticleTitleType(widget)) {\n return <JRCWidgetArticleTitleWrapper widget={widget} inplace={inplace} mode={mode} dataCy={dataCy} />;\n } else if (ensureWidgetArticleTextType(widget)) {\n return <JRCWidgetArticleTextWrapper widget={widget} inplace={inplace} mode={mode} />;\n } else if (ensureWidgetExcelDatasourceTableType(widget)) {\n return (\n <CSSWidgetWithTitle>\n <WidgetTitle uniqid={widget.uniqid} />\n <WidgetExcelDatasourceTableWrapper {...widget.content} uniqid={widget.uniqid} mode={mode} />\n </CSSWidgetWithTitle>\n );\n } else if (ensureWidgetDatasourceTableType(widget)) {\n return (\n <CSSWidgetWithTitle>\n <WidgetTitle uniqid={widget.uniqid} />\n <WidgetDatasourceTableWrapper {...widget.content} uniqid={widget.uniqid} mode={mode} />\n </CSSWidgetWithTitle>\n );\n } else if (ensureWidgetCheckListType(widget, widget.name === 'widget-check-list')) {\n return (\n <CSSWidgetWithTitle>\n {mode === 'edit' ? (\n <WidgetHeaderEdit name={widget.name} uniqid={widget.uniqid} />\n ) : (\n <WidgetTitle uniqid={widget.uniqid} />\n )}\n <JRCWidgetCheckListWrapper\n widget={widget}\n inplace={inplace}\n mode={mode}\n onWidgetUpdate={onWidgetUpdate}\n />\n </CSSWidgetWithTitle>\n );\n } else if (ensureWidgetPresenceType(widget)) {\n return (\n <CSSWidgetWithTitle>\n {mode === 'edit' ? (\n <WidgetHeaderEdit name={widget.name} uniqid={widget.uniqid} />\n ) : (\n <WidgetTitle uniqid={widget.uniqid} />\n )}\n <JRCWidgetPresenceWrapper widget={widget} inplace={inplace} mode={mode} />\n </CSSWidgetWithTitle>\n );\n } else if (ensureWidgetQuickSurveyType(widget)) {\n return (\n <CSSWidgetWithTitle>\n {mode === 'edit' ? (\n <WidgetHeaderEdit name={widget.name} uniqid={widget.uniqid} />\n ) : (\n <WidgetTitle uniqid={widget.uniqid} />\n )}\n <JRCWidgetQuickSurveyWrapper widget={widget} inplace={inplace} mode={mode} />\n </CSSWidgetWithTitle>\n );\n } else if (ensureWidgetCalendarCalDavType(widget)) {\n return (\n <CSSWidgetWithTitle>\n <JRCWidgetCalendarCalDavWrapper\n widget={widget}\n inplace={inplace}\n mode={mode}\n levelFallback={levelFallback}\n />\n </CSSWidgetWithTitle>\n );\n } else if (ensureWidgetContactCardDavType(widget)) {\n return (\n <CSSWidgetWithTitle>\n <JRCWidgetContactCardDavWrapper\n widget={widget}\n inplace={inplace}\n mode={mode}\n levelFallback={levelFallback}\n />\n </CSSWidgetWithTitle>\n );\n } else if (ensureWidgetEmailsImapType(widget)) {\n return (\n <CSSWidgetWithTitle>\n <JRCWidgetEmailsImapWrapper\n widget={widget}\n inplace={inplace}\n mode={mode}\n levelFallback={levelFallback}\n />\n </CSSWidgetWithTitle>\n );\n } else {\n return cannotDisplayComponent ? <>{cannotDisplayComponent(name)}</> : <>cannot display widget ({name})</>;\n }\n};\n","import styled from 'styled-components';\n\nexport const CSSWidgetLayer = styled.div<{ opacity: number; backgroundColor: string; pointerEvents: string }>`\n position: absolute;\n inset: 0;\n opacity: ${(props) => props.opacity};\n background-color: ${(props) => props.backgroundColor};\n pointer-events: ${(props) => props.pointerEvents};\n`;\n","import React, { ReactElement, useCallback, useEffect, useRef, useState } from 'react';\nimport { shallowEqual } from 'react-redux';\nimport { WidgetVector, WidgetDisplayMode, WidgetKeys } from 'jamespot-user-api';\nimport { WidgetEditor, Widget } from 'jamespot-front-business';\n// eslint-disable-next-line import/no-cycle\nimport WidgetWrapperCore from '../WidgetWrapperCore';\nimport { CSSWidgetLayer } from './WidgetLayer.style';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { useAppDispatch, useAppSelector } from '../../../redux/store';\n\nconst BETA_JRCDoubleClick = commonComponentsRegistry.getLazyComponent('DoubleClick');\n\n/*\n Widget layering\n*/\n\nexport const WidgetLayer = ({ uniqid, mode }: { uniqid: string; mode: WidgetDisplayMode }) => {\n const layers = useAppSelector((state) => state.widgets.ids[uniqid].widget.layers, shallowEqual);\n return (\n <>\n {layers?.map((layer, index) => {\n if (mode === 'edit') {\n return <Layer uniqid={layer} key={index} mode={'edit'} />;\n }\n\n return <Layer uniqid={layer} key={index} mode={'edit'} />;\n })}\n </>\n );\n};\n\nconst Layer = ({ uniqid, mode }: { uniqid: string; mode: WidgetDisplayMode }) => {\n const layer = useAppSelector((state) => state.widgets.layers[uniqid]);\n if (mode === 'view') {\n return (\n <CSSWidgetLayer opacity={1} backgroundColor={'transparent'} pointerEvents={'none'}>\n {layer.widgets.map((widgetWrapper, index) => {\n return (\n <LayerWidget\n key={index}\n layerId={layer.uniqid}\n uniqid={widgetWrapper.widget.uniqid}\n mode={'view'}\n />\n );\n })}\n </CSSWidgetLayer>\n );\n }\n\n return (\n <CSSWidgetLayer\n opacity={layer.visible ? 1 : 0}\n backgroundColor={layer.visible ? 'rgba(255,255,255,.1)' : 'transparent'}\n pointerEvents={layer.locked ? 'none' : 'all'}>\n {layer.widgets.map((widgetWrapper, index) => {\n return (\n <LayerWidget\n key={index}\n layerId={layer.uniqid}\n uniqid={widgetWrapper.widget.uniqid}\n mode={'edit'}\n />\n );\n })}\n </CSSWidgetLayer>\n );\n};\n\n/*\n Widget from the layer\n*/\nconst LayerWidget = ({ uniqid, layerId, mode }: { uniqid: string; layerId: string; mode: WidgetDisplayMode }) => {\n const dispatch = useAppDispatch();\n const widgetWrapper = useAppSelector((state) => state.widgets.ids[uniqid], shallowEqual);\n const layer = useAppSelector((state) => state.widgets.layers[layerId]);\n\n if (!widgetWrapper) {\n return <></>;\n }\n\n if (!layer) {\n return <></>;\n }\n\n if (!layer.position) {\n return <></>;\n }\n\n const onDoubleTap = (uniqid: string, name: WidgetKeys) => {\n /*\n Open editor\n */\n dispatch(WidgetEditor.slice.actions.registerEditor({ uniqid, name }));\n };\n\n const onMouseUp = (position: WidgetVector) => {\n dispatch(Widget.slice.actions.updateLayer({ uniqid: layerId, props: { position } }));\n };\n\n if (mode === 'view') {\n return (\n <div style={{ position: 'absolute', top: layer.position.y, left: layer.position.x }}>\n <WidgetWrapperCore uniqid={uniqid} widget={widgetWrapper} mode={mode} inplace={true} />\n </div>\n );\n }\n\n return (\n <DraggableHandler\n position={{ x: layer.position.x, y: layer.position.y }}\n onMouseUp={(position: WidgetVector) => {\n if (\n (layer.position && layer.position.x !== position.x) ||\n (layer.position && layer.position.y !== position.y)\n ) {\n onMouseUp(position);\n }\n }}>\n <BETA_JRCDoubleClick\n onDoubleTap={() => onDoubleTap(widgetWrapper.widget.uniqid, widgetWrapper.widget.name)}>\n <WidgetWrapperCore uniqid={uniqid} widget={widgetWrapper} mode={mode} inplace={true} />\n </BETA_JRCDoubleClick>\n </DraggableHandler>\n );\n};\n\nexport type Vector = {\n x: number;\n y: number;\n};\n\n// TODO: COMBINE WITH THE ONE USED ON COLOR PICKER\n// TODO: COMBINE WITH THE ONE USED ON COLOR PICKER\n// TODO: COMBINE WITH THE ONE USED ON COLOR PICKER\nexport const DraggableHandler = ({\n position,\n children,\n onMouseUp,\n}: {\n position: Vector;\n children: ReactElement;\n onMouseUp: (position: Vector) => void;\n}) => {\n const [mouseIsDown, setMouseDown] = useState<boolean>(false);\n const [mouse, setMouse] = useState<Vector>({ x: 0, y: 0 });\n const [start, setStart] = useState<Vector>({ x: 0, y: 0 });\n const [child, setChild] = useState<Vector>({ x: position.x, y: position.y });\n\n const ref = useRef<HTMLDivElement>(null);\n\n const handleMouseDown = useCallback(\n (event: any) => {\n setMouseDown(true);\n if (ref.current) {\n setMouse({ x: event.nativeEvent.clientX, y: event.nativeEvent.clientY });\n setStart({ x: child.x, y: child.y });\n }\n },\n [child.x, child.y],\n );\n\n const handleMouseMove = useCallback(\n (event: any) => {\n if (mouseIsDown && ref.current) {\n const dx = start.x + (event.clientX - mouse.x);\n const dy = start.y + (event.clientY - mouse.y);\n\n setChild({ x: dx, y: dy });\n }\n },\n [mouse.x, mouse.y, mouseIsDown, start.x, start.y],\n );\n\n const handleMouseUp = useCallback(() => {\n setMouseDown(false);\n onMouseUp({ x: child.x, y: child.y });\n }, [child.x, child.y, onMouseUp]);\n\n useEffect(() => {\n document.addEventListener('mousemove', handleMouseMove);\n document.addEventListener('mouseup', handleMouseUp);\n return () => {\n document.removeEventListener('mousemove', handleMouseMove);\n document.removeEventListener('mouseup', handleMouseUp);\n };\n }, [handleMouseMove, handleMouseUp]);\n\n return (\n <div style={{ position: 'absolute', top: child.y, left: child.x }} ref={ref} onMouseDown={handleMouseDown}>\n {children}\n </div>\n );\n};\n","import React from 'react';\nimport { WidgetKeys } from 'jamespot-user-api';\nimport { Widget } from 'jamespot-front-business';\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\nimport { useAppSelector } from '../../redux/store';\n\nconst JRCLoader = commonComponentsRegistry.getLazyComponent('Loader');\n\n/*\n Widget state\n*/\n\nexport const WidgetState = ({ name, uniqid, inplace }: { name: WidgetKeys; uniqid: string; inplace: boolean }) => {\n const state = useAppSelector((state) => Widget.selectors.selectWidgetState(state, uniqid));\n const def = Widget.definition(name);\n\n if (state?.loading) {\n return (\n <div\n style={{\n position: 'absolute',\n inset: 0,\n backgroundColor: 'rgba(255,255,255,.7)',\n display: 'flex',\n flex: 1,\n justifyContent: 'center',\n alignItems: 'center',\n }}>\n <JRCLoader />\n </div>\n );\n }\n\n if (state?.hover) {\n return (\n <div\n style={{\n position: 'absolute',\n inset: 0,\n backgroundColor: 'rgba(255,255,255,.7)',\n display: 'flex',\n flex: 1,\n justifyContent: 'center',\n alignItems: 'center',\n }}></div>\n );\n }\n\n if (!state?.initialized && inplace) {\n return <></>;\n }\n\n if (!state?.initialized && !inplace) {\n return (\n <div\n style={{\n position: 'absolute',\n inset: 0,\n backgroundColor: 'rgba(255,255,255,1)',\n display: 'flex',\n flex: 1,\n justifyContent: 'center',\n alignItems: 'center',\n }}>\n <img src={def.img} />\n </div>\n );\n }\n\n return <></>;\n};\n","import React, { useCallback } from 'react';\n\nimport { useIntl } from 'react-intl';\n\nimport { WidgetKeys } from 'jamespot-user-api';\n\nimport styled from 'styled-components';\nimport { DashedFocusBorder, JRCHtml } from 'jamespot-react-components';\nimport { Widget, WidgetEditor } from 'jamespot-front-business';\n\nimport { useAppSelector, useAppDispatch } from '../../redux/store';\n\nexport const WrapperEditMode = styled.button`\n position: absolute;\n inset: 0;\n display: flex;\n flex-direction: row;\n justify-content: center;\n align-items: center;\n gap: ${(props) => props.theme.space.md}px;\n color: ${(props) => props.theme.color.primary};\n cursor: pointer;\n opacity: 0;\n border: 1px solid ${(props) => props.theme.color.primary};\n &:hover {\n background-color: ${(props) => props.theme.color.grey2};\n opacity: 0.9;\n }\n\n ${DashedFocusBorder()}\n`;\n\nexport const WidgetWrapperCoreEditHover = ({ uniqid, name }: { uniqid: string; name: WidgetKeys }) => {\n const dispatch = useAppDispatch();\n const intl = useIntl();\n const isInitialized = useAppSelector((state) => Widget.selectors.selectWidgetState(state, uniqid)?.initialized);\n\n const registerEditor = useCallback(() => {\n if (!isInitialized) return;\n dispatch(WidgetEditor.slice.actions.flushAllEditor());\n dispatch(\n WidgetEditor.slice.actions.registerEditor({\n uniqid,\n name,\n }),\n );\n }, [dispatch, uniqid, isInitialized, name]);\n const def = Widget.definition(name);\n\n return isInitialized ? (\n <WrapperEditMode onClick={registerEditor}>\n <JRCHtml\n __html={`${intl.formatMessage({ id: 'WIDGET_Set_Widget' })} <b>${intl.formatMessage({\n id: def.label,\n })}</b>`}\n />\n </WrapperEditMode>\n ) : (\n <></>\n );\n};\n","import { WidgetKeys, WidgetWrapperLevel } from 'jamespot-user-api';\nimport React from 'react';\nimport { Widget } from 'jamespot-front-business';\nimport { shallowEqual } from 'react-redux';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { useAppSelector } from '../../../redux/store';\nimport styled from 'styled-components';\n\nconst WidgetIcon = commonComponentsRegistry.getLazyComponent('WidgetIcon');\n\nexport const CSSIconAbsoluteA = styled.a<{ color: string | undefined }>`\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n display: flex;\n justify-content: center;\n align-items: center;\n flex-direction: column;\n color: ${(props) => (props.color ? props.color : props.theme.color.black)};\n transition: background-color 0.4s;\n &:hover {\n background-color: rgba(0, 0, 0, 0.1);\n color: ${(props) => (props.color ? props.color : props.theme.color.black)};\n }\n`;\n\nexport const JRCWidgetIconWrapper = ({\n uniqid,\n name,\n url,\n level,\n}: {\n uniqid: string;\n name: WidgetKeys;\n url: string;\n level: WidgetWrapperLevel;\n}) => {\n const def = Widget.definition(name);\n const count = useAppSelector(\n (state) => (level === 2 ? Widget.selectors.selectWidgetChipCount(state, uniqid) : 0),\n shallowEqual,\n );\n const styles = useAppSelector((state) => Widget.selectors.selectWidgetWrapperStyle(state, uniqid), shallowEqual);\n\n return (\n <CSSIconAbsoluteA\n href={url}\n target=\"_blank\"\n color={String(styles.color) ?? undefined}\n rel=\"noreferrer\"\n aria-label={def.label}>\n <WidgetIcon count={count} img={def.img} label={def.label} maxValue={999} />\n </CSSIconAbsoluteA>\n );\n};\n","import React, { useMemo } from 'react';\nimport { Widget } from 'jamespot-front-business';\nimport { shallowEqual } from 'react-redux';\nimport { useAppSelector } from '../../../../redux/store';\nimport styled, { useTheme } from 'styled-components';\n\nexport const UIWrapper = styled.div<{\n backgroundColor: string;\n borderStyle: string;\n borderWidth: string;\n borderColor: string;\n borderRadius: string;\n overflow: string;\n}>`\n display: flex;\n flex-direction: column;\n background-color: ${(props) => props.backgroundColor};\n border-style: ${(props) => props.borderStyle};\n border-color: ${(props) => props.borderColor};\n border-width: ${(props) => props.borderWidth}px;\n border-radius: ${(props) => props.borderRadius}px;\n overflow: ${(props) => props.overflow};\n`;\n\n/*\n DO NOT USE PADDING HERE (LOOK AT WIDGET STYLE PADDING COMPONENT)\n*/\nconst WidgetStyle = ({\n uniqid,\n onClick,\n children,\n}: {\n uniqid: string;\n onClick: () => void;\n children: React.ReactNode;\n}) => {\n const theme = useTheme();\n const styles = useAppSelector((state) => Widget.selectors.selectWidgetWrapperStyle(state, uniqid), shallowEqual);\n\n const initialValues = useMemo(() => {\n return {\n color: styles && styles['color'] ? String(styles['color']) : theme.color.black,\n backgroundColor:\n styles && styles['background-color'] ? String(styles['background-color']) : theme.color.white,\n borderRadius: styles && styles['border-radius'] ? String(styles['border-radius']) : '0',\n borderColor: styles['border-color'] ? String(styles['border-color']) : theme.color.black,\n borderWidth: styles['border-width'] ? String(styles['border-width']) : '0',\n borderStyle: styles['border-style'] ? String(styles['border-style']) : 'none',\n };\n }, [styles, theme]);\n\n return (\n <UIWrapper\n onClick={onClick}\n backgroundColor={initialValues.backgroundColor}\n borderColor={initialValues.borderColor}\n borderStyle={initialValues.borderStyle}\n borderRadius={initialValues.borderRadius}\n overflow={Number(initialValues.borderRadius) > 0 ? 'hidden' : 'initial'}\n borderWidth={initialValues.borderWidth}>\n {children}\n </UIWrapper>\n );\n};\n\nexport const WidgetStyleWrapper = WidgetStyle;\n","import React, { ReactNode, useCallback, useEffect } from 'react';\nimport { shallowEqual } from 'react-redux';\nimport { Widget, WidgetEditor } from 'jamespot-front-business';\nimport { jCommentList, WidgetDisplayMode, WidgetWrapperProps } from 'jamespot-user-api';\nimport { useComponentVisible } from './hooks';\nimport { DisplayWidget } from './Widget';\n\n// eslint-disable-next-line import/no-cycle\nimport { WidgetLayer } from './WidgetLayer/WidgetLayer';\nimport { WidgetState } from './WidgetState';\nimport { WidgetWrapperCoreEditHover } from './WidgetWrapperCoreEditHover';\n\nimport { JRCWidgetIconWrapper } from './wrapper/JRCWidgetIconWrapper';\nimport { WidgetStyleWrapper } from './wrapper/components/WidgetStyleWrapper';\nimport { useAppDispatch, useAppSelector } from '../../redux/store';\ntype WidgetWrapperCoreProps = {\n uniqid: string;\n widgetObject?: Partial<jCommentList>;\n widget: WidgetWrapperProps;\n inplace?: boolean;\n mode: WidgetDisplayMode;\n width?: number | undefined;\n onWidgetUpdate?: () => void;\n cannotDisplayComponent?: (widget: string) => ReactNode;\n dataCy?: string;\n};\n\n/*\n This is a widget wrapper\n*/\nexport const WidgetWrapperCore = ({\n uniqid,\n widgetObject,\n widget,\n inplace = true,\n mode,\n width,\n onWidgetUpdate,\n cannotDisplayComponent,\n dataCy,\n}: WidgetWrapperCoreProps) => {\n const dispatch = useAppDispatch();\n const widgetWrapper = useAppSelector((state) => Widget.selectors.selectWidget(state, uniqid));\n const indexOrder = useAppSelector((state) => state.widgets.editableMap[uniqid], shallowEqual);\n const currentEditableWidgetId = useAppSelector((state) => state.widgets.currentEditableWidgetId, shallowEqual);\n const isActive = useAppSelector((state) => state.widgets.currentEditableWidgetId === uniqid, shallowEqual);\n const { isComponentVisible, setIsComponentVisible } = useComponentVisible(false);\n\n useEffect(() => {\n if (widgetObject) {\n dispatch(Widget.slice.actions.registerWidgetObject({ uniqid, object: widgetObject }));\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n useEffect(() => {\n if (widget) {\n /*\n Register widget\n */\n dispatch(Widget.slice.actions.registerWidget({ uniqid, widget }));\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n useEffect(() => {\n if (!isComponentVisible) {\n if (uniqid === currentEditableWidgetId) {\n dispatch(Widget.slice.actions.setEditableWidgetId({ uniqid: undefined }));\n }\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isComponentVisible]);\n\n useEffect(() => {\n if (isComponentVisible !== isActive) {\n setIsComponentVisible(isActive);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isActive]);\n\n const registerEditor = useCallback(() => {\n if (widgetWrapper === undefined || mode === 'view') {\n return;\n }\n dispatch(WidgetEditor.slice.actions.flushAllEditor());\n /*\n Register editor\n */\n const { widget } = widgetWrapper;\n dispatch(\n WidgetEditor.slice.actions.registerEditor({\n uniqid: widget.uniqid,\n name: widget.name,\n }),\n );\n }, [dispatch, mode, widgetWrapper]);\n\n if (widgetWrapper === undefined) {\n return <>This widget cannot be displayed</>;\n }\n\n if (inplace && mode !== 'view') {\n return (\n <WidgetStyleWrapper\n uniqid={uniqid}\n onClick={() => {\n setIsComponentVisible(true);\n if (indexOrder) {\n dispatch(Widget.slice.actions.setEditableIndex({ index: indexOrder.index }));\n dispatch(Widget.slice.actions.setEditableWidgetId({ uniqid }));\n }\n }}>\n <DisplayWidget\n dataCy={dataCy}\n width={width}\n widget={{\n ...widgetWrapper.widget,\n ...(widgetWrapper.title && {\n title: widgetWrapper.title,\n }),\n }}\n inplace={inplace}\n mode={mode}\n levelFallback={(level, url) => {\n return (\n level <= 2 && (\n <JRCWidgetIconWrapper\n uniqid={widget.widget.uniqid}\n name={widget.widget.name}\n level={level}\n url={url}\n />\n )\n );\n }}\n />\n <WidgetLayer uniqid={uniqid} mode={mode} />\n {mode === 'edit' && <WidgetWrapperCoreEditHover uniqid={uniqid} name={widget.widget.name} />}\n <WidgetState name={widgetWrapper.widget.name} uniqid={widgetWrapper.widget.uniqid} inplace={inplace} />\n </WidgetStyleWrapper>\n );\n }\n\n return (\n <WidgetStyleWrapper uniqid={uniqid} onClick={registerEditor}>\n <DisplayWidget\n dataCy={dataCy}\n widget={{\n ...widgetWrapper.widget,\n ...(widgetWrapper.title && {\n title: widgetWrapper.title,\n }),\n }}\n inplace={inplace}\n mode={mode}\n width={width}\n onWidgetUpdate={onWidgetUpdate}\n cannotDisplayComponent={cannotDisplayComponent}\n levelFallback={(level, url) => {\n return (\n level <= 2 && (\n <JRCWidgetIconWrapper\n uniqid={widget.widget.uniqid}\n name={widget.widget.name}\n level={level}\n url={url}\n />\n )\n );\n }}\n />\n <WidgetLayer uniqid={uniqid} mode={mode} />\n <WidgetState name={widgetWrapper.widget.name} uniqid={widgetWrapper.widget.uniqid} inplace={inplace} />\n </WidgetStyleWrapper>\n );\n};\n\nexport default WidgetWrapperCore;\n","import styled from 'styled-components';\nexport const CSSCommentsBlocWidgetWrapper = styled.div`\n border-radius: ${(props) => props.theme.space.sm}px;\n border: 1px solid ${(props) => props.theme.color.grey1};\n background-color: ${(props) => props.theme.color.white};\n overflow: hidden;\n`;\n","import { Widget } from 'jamespot-front-business';\nimport { WidgetWrapperProps } from 'jamespot-user-api';\nimport React from 'react';\nimport { useIntl } from 'react-intl';\nimport { shallowEqual } from 'react-redux';\nimport WidgetWrapperCore from '../widgets/WidgetWrapperCore';\nimport { CSSCommentsBlocWidgetWrapper } from './CommentsBloc.styles';\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\nimport { useAppSelector } from '../../redux/store';\n\nconst JRCMessage = commonComponentsRegistry.getLazyComponent('Message');\n\nexport const CommentsBlocAddCommentWidgetsWrapper = ({ widgets }: { widgets: WidgetWrapperProps[] }) => {\n const intl = useIntl();\n const flushedWidgets = useAppSelector(Widget.selectors.selectFlushedWidgets, shallowEqual);\n\n return (\n <>\n {widgets\n .filter((el) => !flushedWidgets.includes(el.widget.uniqid))\n .map(\n (widget) =>\n widget &&\n widget.widget && (\n <CSSCommentsBlocWidgetWrapper key={widget.widget.uniqid}>\n <WidgetWrapperCore\n uniqid={widget.widget.uniqid}\n widget={widget}\n inplace\n mode={'edit'}\n cannotDisplayComponent={(widget) => (\n <JRCMessage\n variant={'info'}\n message={intl.formatMessage({ id: 'WIDGET_Cannot_Display' }, { widget })}\n />\n )}\n />\n </CSSCommentsBlocWidgetWrapper>\n ),\n )}\n </>\n );\n};\n","import React from 'react';\nimport { Widget } from 'jamespot-front-business';\nimport { jCommentList, WidgetDisplayMode, WidgetWrapperProps } from 'jamespot-user-api';\nimport { useIntl } from 'react-intl';\nimport { shallowEqual } from 'react-redux';\nimport { CSSCommentsBlocWidgetWrapper } from './CommentsBloc.styles';\nimport WidgetWrapperCore from '../widgets/WidgetWrapperCore';\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\nimport { useAppSelector } from '../../redux/store';\n\nconst JRCMessage = commonComponentsRegistry.getLazyComponent('Message');\n\nexport const CommentsBlocCommentWidgetsWrapper = (props: {\n comment: jCommentList;\n widgets: WidgetWrapperProps[];\n mode: WidgetDisplayMode;\n inplace: boolean;\n handleWidgetUpdate: () => void;\n handleWidgetRemove: () => void;\n}) => {\n const intl = useIntl();\n const { widgets, comment, inplace, mode, handleWidgetUpdate } = props;\n const flushedWidgets = useAppSelector(Widget.selectors.selectFlushedWidgets, shallowEqual);\n\n return (\n <>\n {widgets\n .filter((el) => !flushedWidgets.includes(el.widget.uniqid))\n .map(\n (widget) =>\n widget && (\n <CSSCommentsBlocWidgetWrapper key={widget.widget.uniqid}>\n <WidgetWrapperCore\n uniqid={widget.widget.uniqid}\n widgetObject={comment}\n widget={widget}\n inplace={inplace}\n mode={mode}\n onWidgetUpdate={handleWidgetUpdate}\n cannotDisplayComponent={(widget) => {\n return (\n <JRCMessage\n variant={'info'}\n message={intl.formatMessage(\n { id: 'WIDGET_Cannot_Display' },\n { widget },\n )}\n />\n );\n }}\n />\n </CSSCommentsBlocWidgetWrapper>\n ),\n )}\n </>\n );\n};\n","import {\n Application,\n Comment,\n Hook,\n Model,\n Platform,\n TinyMCE,\n Toast,\n UserCurrent,\n Widget,\n} from 'jamespot-front-business';\nimport { DriveOrFilebank } from 'jamespot-react-components';\nimport jApi, { AddCommentParams, jCommentList, UpdateCommentParams, WidgetWrapperProps } from 'jamespot-user-api';\nimport React, { useCallback, useEffect, useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport styled, { useTheme } from 'styled-components';\nimport useCommentRT from '../hooks/useCommentRT';\nimport useCommentsLikeRT from '../hooks/useCommentsLikeRT';\nimport { EditorsPanel } from './widgets/components/WidgetEditorPanel';\nimport { WidgetList } from './widgets/WidgetList/WidgetList';\n\nimport { CommentsBlocAddCommentWidgetsWrapper } from './comments/CommentsBlocAddCommentWidgetsWrapper';\nimport { CommentsBlocCommentWidgetsWrapper } from './comments/CommentsBlocCommentWidgetsWrapper';\nimport { commonComponentsRegistry } from '../registry/CommonRegistry';\nimport { getTinyMCEMentionsQueries } from '../utils/tinymce';\nimport { useMarkdownModal } from '../hooks/useMarkdownModal';\nimport { MarkdownModal } from './tinymce/extension/MarkdownModal';\nimport { useAppDispatch, useAppSelector } from '../redux/store';\n\nconst JRCCommentsBloc = commonComponentsRegistry.getLazyComponent('JRCCommentsBloc');\n\nexport type CommentsBlocProps = {\n articleId: number;\n variant?: 'modal' | 'inline';\n canComment: boolean;\n commentType?: 'comment' | 'commentResponse';\n socialQuestion?: {\n isResolved: boolean;\n responseId?: number;\n canSelectResponse: boolean;\n };\n};\n\nconst CommentsBlocWrapper = styled.div`\n display: flex;\n flex-direction: column;\n gap: 4px;\n flex: 1;\n width: 100%;\n margin-top: 10px;\n`;\n\nexport const CommentsBloc = ({\n articleId,\n variant = 'inline',\n canComment,\n commentType = 'comment',\n socialQuestion,\n}: CommentsBlocProps) => {\n const intl = useIntl();\n const theme = useTheme();\n const dispatch = useAppDispatch();\n\n const [token, setToken] = useState<string>();\n const [loading, setLoading] = useState(false);\n const [widgets, setWidgets] = useState<WidgetWrapperProps[]>([]);\n\n const [tokenLoading, setTokenLoading] = useState(false);\n\n const currentUser = useAppSelector(UserCurrent.selectors.get);\n const widgetIds = useAppSelector(Widget.selectors.selectWidgets);\n const tinyMCECommonOptions = useAppSelector(TinyMCE.selectors.selectTinyMCECommonOptions);\n const tinyMCEExtendedOptions = useAppSelector(TinyMCE.selectors.selectTinyMCEExtendedOptions);\n const models = useAppSelector(Model.selectors.selectAll);\n const platformConfig = useAppSelector(Platform.selectors.selectPlatformConfig);\n const onlyOffice = useAppSelector((state) => Application.selectors.selectById(state, 'OnlyOfficeHook'));\n const commentsList = useAppSelector((state) => Comment.selectors.commentList(state, articleId));\n const driveHook = useAppSelector((state) => Hook.selectors.selectHook(state, 'DriveHook'));\n const fileBank = useAppSelector((state) => Application.selectors.selectById(state, 'FileBankHook'));\n const widgetHook = useAppSelector((state) => Hook.selectors.selectHook(state, 'WidgetHook'));\n const [socialQuestionOptions, setSocialQuestionOptions] = useState(socialQuestion);\n const {\n open,\n onInsert,\n close: closeMarkdownModal,\n ext: extMarkdown,\n isActive: isMarkdownActive,\n } = useMarkdownModal();\n\n useCommentRT(articleId);\n\n useCommentsLikeRT(\n commentsList.map((c) => c.id),\n articleId,\n );\n\n const onError = useCallback(\n (message?: string) => {\n dispatch(Toast.actions.error({ label: message ?? intl.formatMessage({ id: 'GLOBAL_Error' }) }));\n },\n [dispatch, intl],\n );\n\n const onCommentUpdate = async (args: UpdateCommentParams) => {\n const commentToUpdate: jCommentList | undefined = commentsList.find((item) => item.id === args.idComment);\n if (!commentToUpdate) return;\n return jApi.article\n .updateComment({\n idComment: args.idComment,\n description: args.description ?? commentToUpdate.description ?? undefined,\n token: args.token,\n widgets: args.widgets,\n })\n .then(() => {\n dispatch(Comment.actions.fetchComments({ idArticle: articleId }));\n fetchToken();\n })\n .catch((e) => {\n onError(e.errorMsg);\n });\n };\n\n const onCommentDelete = async (idComment: number) => {\n dispatch(Comment.actions.deleteComment({ idComment, idArticle: articleId }));\n };\n\n const onWidgetUpdate = () => {\n dispatch(Comment.actions.fetchComments({ idArticle: articleId }));\n fetchToken();\n };\n\n const fetchToken = useCallback(() => {\n if (!token && !tokenLoading) {\n setTokenLoading(true);\n jApi.network\n .token()\n .then((res) => {\n setToken(res.result);\n setTokenLoading(false);\n\n // set comment token to our widget slice to be able to upload image inside our widgets\n dispatch(Widget.slice.actions.setToken({ token: res.result }));\n })\n .catch((e) => {\n onError(e.errorMsg);\n });\n }\n }, [onError, token, tokenLoading, dispatch]);\n\n const onComment = useCallback(\n async (params: Pick<AddCommentParams, 'content' | 'alertAuthor' | 'sendAlert'>) => {\n if (token) {\n setLoading(true);\n const finalWidget: WidgetWrapperProps[] = Object.keys(widgetIds)\n .map((id) => {\n if (widgets?.some((w) => w.widget.uniqid === id)) {\n return widgetIds[id];\n }\n return null;\n })\n .filter((w): w is WidgetWrapperProps => w !== null);\n\n try {\n // TODO : passer par le store pour avoir une réactivité directe après ajout (confirmée ensuite par retour RT)\n // -> état intermédiaire PENDING à gérer.\n await jApi.article\n .addComment({\n ...params,\n widgets: finalWidget,\n token,\n idArticle: articleId,\n type: commentType,\n })\n .then(() => {\n setWidgets([]);\n });\n fetchToken();\n } catch (e: any) {\n onError(e.errorMsg);\n } finally {\n setLoading(false);\n }\n }\n },\n [articleId, commentType, fetchToken, onError, token, widgetIds, widgets],\n );\n\n useEffect(() => {\n fetchToken();\n }, [fetchToken]);\n\n useEffect(() => {\n dispatch(Comment.actions.fetchComments({ idArticle: articleId }));\n }, [articleId, dispatch]);\n\n useEffect(() => {\n if (!commentsList) {\n return;\n }\n commentsList.forEach((comment) => {\n comment._widgets?.forEach((widget) => {\n dispatch(Widget.slice.actions.registerWidgetObject({ uniqid: widget.widget.uniqid, object: comment }));\n dispatch(\n Widget.slice.actions.registerWidgetObjectRights({\n uniqid: widget.widget.uniqid,\n rights: comment._right,\n }),\n );\n });\n });\n }, [commentsList, dispatch]);\n\n return (\n <>\n {tinyMCECommonOptions && tinyMCEExtendedOptions && (\n <>\n <CommentsBlocWrapper>\n <JRCCommentsBloc\n canComment={canComment}\n loading={loading}\n token={token}\n comments={commentsList}\n onComment={onComment}\n onCommentUpdate={onCommentUpdate}\n onCommentDelete={onCommentDelete}\n isWidgetActive={\n !!(\n widgetHook?.isActive &&\n widgetHook?.create &&\n widgetHook?.autorize?.includes('comment')\n )\n }\n widgetListComponent={\n <WidgetList\n mode={'comment'}\n namespace={'comment'}\n onChange={(widget) => {\n setWidgets([widget]); // COMMENT DO NOT SUPPORT MULTI WIDGET\n dispatch(\n Widget.slice.actions.registerWidget({\n uniqid: widget.widget.uniqid,\n widget: widget,\n }),\n );\n setToken(undefined);\n fetchToken();\n }}\n view={'edit'}\n />\n }\n newWidgetsWrapperComponent={<CommentsBlocAddCommentWidgetsWrapper widgets={widgets} />}\n existingWidgetsWrapperComponent={(comment, widgets, mode, inplace = true) => (\n <CommentsBlocCommentWidgetsWrapper\n comment={comment}\n widgets={widgets}\n mode={mode}\n inplace={inplace}\n handleWidgetUpdate={onWidgetUpdate}\n handleWidgetRemove={fetchToken}\n />\n )}\n currentUser={currentUser}\n tinyMCEConfig={{\n commonOptions: {\n ...tinyMCECommonOptions,\n toolbar: tinyMCEExtendedOptions.commentsToolbar,\n },\n mentionsQueries: getTinyMCEMentionsQueries(models, theme, onError),\n }}\n onError={onError}\n highlightFields={platformConfig.userHighlightFields}\n userAccountStatus={platformConfig.userAccountStatus}\n userModel={models.find((m) => m.type === 'user')}\n isWedocActive={!!onlyOffice}\n onGetHashError={(message?: string) =>\n dispatch(\n Toast.actions.error({\n label: message ?? intl.formatMessage({ id: 'GLOBAL_Error' }),\n }),\n )\n }\n activeDrives={\n [\n ...(fileBank && driveHook ? ['fileBank'] : []),\n ...Hook.utils.buildDrivesArrayFromObject(driveHook?.drives),\n ] as DriveOrFilebank[]\n }\n variant={variant}\n handlers={{\n drive: jApi.drive,\n filebank: jApi.filebank,\n file: jApi.file,\n user: jApi.user,\n socialAction: jApi.socialAction,\n questionAnswer: jApi.questionAnswer,\n }}\n socialQuestion={\n socialQuestionOptions\n ? {\n ...socialQuestionOptions,\n onSelectResponse: (responseId: number) => {\n setSocialQuestionOptions({\n ...socialQuestionOptions,\n responseId,\n isResolved: true,\n });\n },\n onUnselectResponse: () => {\n setSocialQuestionOptions({\n ...socialQuestionOptions,\n responseId: undefined,\n isResolved: false,\n });\n },\n }\n : undefined\n }\n articleId={articleId}\n additionalExtensions={[extMarkdown]}\n />\n <EditorsPanel />\n </CommentsBlocWrapper>\n </>\n )}\n {isMarkdownActive && <MarkdownModal onInsert={onInsert} open={open} close={closeMarkdownModal} />}\n </>\n );\n};\n","import { useEffect, useMemo } from 'react';\nimport { Comment } from 'jamespot-front-business';\nimport socket from '../utils/socket';\nimport { useAppDispatch } from '../redux/store';\n\nconst useCommentsLikeRT = (idComments: number[] | undefined, idArticle: number) => {\n const dispatch = useAppDispatch();\n const reactSocket = useMemo(() => socket, []);\n const rtHandlers = useMemo(\n () => Comment.getCommentsLikeRTHandlers(dispatch, idComments, idArticle),\n [dispatch, idComments, idArticle],\n );\n\n useEffect(() => {\n rtHandlers.forEach((handler) => {\n reactSocket.onMessage(handler.namespace, handler.function, handler.handler);\n });\n return () => {\n rtHandlers.forEach((handler) => {\n reactSocket.offMessage(handler.namespace, handler.function, handler.handler);\n });\n };\n }, [rtHandlers, reactSocket]);\n};\n\nexport default useCommentsLikeRT;\n","import { DisplayFormFieldsConfig, DisplayFormRef } from './types';\nimport { useForm, Control, FieldValues } from 'react-hook-form';\nimport { useDisplayForm } from './useDisplay';\nimport styled, { css } from 'styled-components';\nimport React, {\n FormEventHandler,\n ForwardedRef,\n forwardRef,\n ReactNode,\n Ref,\n useCallback,\n useImperativeHandle,\n useRef,\n} from 'react';\nimport { AudienceAutocomplete } from 'jamespot-user-api';\n\nconst StretchContainer = css`\n height: 100%;\n display: flex;\n flex-direction: column;\n justify-content: space-between;\n`;\n\nconst Container = styled.div<{ stretch?: boolean }>`\n ${({ stretch }) => stretch && StretchContainer}\n`;\n\nconst Form = styled.form<{ stretch?: boolean }>`\n ${({ stretch }) => stretch && StretchContainer}\n`;\n\nconst FormElement = (\n props: {\n stretch?: boolean;\n onSubmit?: FormEventHandler<HTMLFormElement>;\n children: ReactNode;\n dataCy?: string;\n },\n ref: ForwardedRef<HTMLFormElement | HTMLDivElement>,\n) => {\n return props.onSubmit ? (\n <Form\n stretch={props.stretch}\n onSubmit={props.onSubmit}\n ref={ref as Ref<HTMLFormElement>}\n data-cy={props.dataCy}>\n {props.children}\n </Form>\n ) : (\n <Container stretch={props.stretch} ref={ref as Ref<HTMLDivElement>} data-cy={props.dataCy}>\n {props.children}\n </Container>\n );\n};\nconst FormElm = forwardRef(FormElement);\n\nconst FieldsetWrapper = styled.div<{ stretch?: boolean }>`\n ${(props) =>\n props.stretch &&\n `\n flex: 1;\n`}\n`;\n\nexport type DisplayFormProps<TFieldValues extends FieldValues> = {\n type: string;\n fields: DisplayFormFieldsConfig<TFieldValues>;\n extraInputs?: (control: Control<TFieldValues>) => ReactNode;\n defaultValues?: any;\n onSubmit?: any;\n buttons?: ReactNode;\n readOnly?: boolean;\n dataCy?: string;\n stretch?: boolean;\n children?: ReactNode;\n forceMandatory?: boolean;\n};\n\n/****\n * The jamespot model depend on the platform\n * For example a user can have the size attribute only for a given platform\n * The model specifics of a platform are stored in J.model\n *\n * This component display an array of attributes only if this attribute is activated on the platform\n */\nconst _DisplayForm = <TFieldValues extends FieldValues>(\n props: DisplayFormProps<TFieldValues>,\n ref: ForwardedRef<DisplayFormRef>,\n) => {\n const formRef = useRef<HTMLFormElement | HTMLDivElement>(null);\n\n const [configuration, defaultValues] = useDisplayForm(props.fields, props.type, props.forceMandatory);\n\n const { handleSubmit, control, reset, ...formFn } = useForm({\n defaultValues: {\n ...defaultValues,\n ...props.defaultValues,\n },\n criteriaMode: 'all',\n });\n\n const formatValuesForSubmit = useCallback(\n (values: any) => {\n const toRet: any = {};\n Object.keys(values).forEach((k) => {\n const widget = configuration.find((c) => c.name === k)?.widget;\n switch (widget?.type) {\n case 'audience':\n toRet[k] = values[k].map((v: AudienceAutocomplete) => v.uri).join(',');\n break;\n case 'taxonomy':\n toRet[k] = values[k].map((v: any) => v.title).join(',');\n break;\n case 'toggle':\n toRet[k] = values[k] ? '1' : '0';\n break;\n default:\n toRet[k] = values[k];\n break;\n }\n });\n return toRet;\n },\n [configuration],\n );\n\n useImperativeHandle(\n ref,\n () => ({\n ...formFn,\n handleSubmit,\n control,\n reset: () => {\n // in case the form is scrollable\n formRef?.current?.scrollTo(0, 0);\n // reset react-hook-form form\n reset();\n },\n getFormattedValues: () => {\n return formatValuesForSubmit(formFn.getValues());\n },\n }),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [],\n );\n\n return (\n <FormElm\n dataCy={props.dataCy}\n stretch={props.stretch}\n onSubmit={props.onSubmit ? handleSubmit(props.onSubmit) : undefined}\n ref={formRef}>\n <FieldsetWrapper stretch={props.stretch}>\n {configuration.map(({ Input, ...conf }) => (\n <Input\n key={conf.name}\n control={control}\n {...conf}\n dataCy={`${props.dataCy}-${conf.name}`}\n readOnly={props.readOnly}\n />\n ))}\n {props.extraInputs && props.extraInputs(control)}\n </FieldsetWrapper>\n {props.buttons}\n </FormElm>\n );\n};\n\nexport const DisplayForm = forwardRef<DisplayFormRef>(_DisplayForm as any) as <TFieldValues extends FieldValues>(\n props: DisplayFormProps<TFieldValues> & {\n ref?: ForwardedRef<DisplayFormRef>;\n },\n) => ReturnType<typeof _DisplayForm>;\n","import React from 'react';\n\n// FIXME move to j-react-components + display error if dev mode\nexport const Empty = () => <></>;\n","import { JTinyMCEExtensionsBuilders } from 'jamespot-react-components';\nimport { JIACapabilities } from 'jamespot-user-api';\nimport { useCallback, useMemo, useState } from 'react';\nimport { useIntl } from 'react-intl';\n\nexport type JiaTextEnhanceQuery = {\n resolve: (value: string | PromiseLike<string>) => void;\n reject: (reason?: any) => void;\n capability: JIACapabilities;\n text: string;\n};\n\nexport const useAI = () => {\n const [query, setQuery] = useState<JiaTextEnhanceQuery | undefined>();\n const intl = useIntl();\n\n const isActive = useMemo(() => {\n return J.hooks?.JIAHook?.isActive && J.debug['JIABETA'];\n }, []);\n\n const PrepareAndSetQuery = useCallback((query: JiaTextEnhanceQuery) => {\n const internalResolve = (value: string | PromiseLike<string>) => {\n query.resolve(value);\n setQuery(undefined);\n };\n const internalReject = (value: any) => {\n query.reject(value);\n setQuery(undefined);\n };\n setQuery({\n ...query,\n reject: internalReject,\n resolve: internalResolve,\n });\n }, []);\n\n const fetch = useCallback(\n (text: string, capability: JIACapabilities) => {\n return new Promise<string>((resolve, reject) => {\n PrepareAndSetQuery({\n reject,\n resolve,\n text,\n capability,\n });\n });\n },\n [PrepareAndSetQuery],\n );\n\n const AICapabilities = useMemo(() => {\n return {\n develop: (text: string) => fetch(text, 'develop'),\n summarize: (text: string) => fetch(text, 'summarize'),\n tldr: (text: string) => fetch(text, 'tldr'),\n en: (text: string) => fetch(text, 'en'),\n es: (text: string) => fetch(text, 'es'),\n formal: (text: string) => fetch(text, 'formal'),\n funny: (text: string) => fetch(text, 'funny'),\n };\n }, [fetch]);\n\n const ext = useMemo(() => JTinyMCEExtensionsBuilders.jia(AICapabilities, intl), [intl, AICapabilities]);\n\n return { query, ext, isActive } as const;\n};\n","import { Model, Toast } from 'jamespot-front-business';\nimport React, { useCallback, useMemo } from 'react';\nimport { useIntl } from 'react-intl';\nimport { useTheme } from 'styled-components';\nimport { JRCInputTinyMCEProps } from 'jamespot-react-components';\nimport { FieldValues } from 'react-hook-form';\nimport { AIModal } from './extension/AIModal';\nimport { useMarkdownModal } from '../../hooks/useMarkdownModal';\nimport { MarkdownModal } from './extension/MarkdownModal';\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\nimport { tinymceCommonOptions } from '../../initTinymce';\nimport { getTinyMCEMentionsQueries } from '../../utils/tinymce';\nimport { useAI } from '../../hooks/useAI';\nimport { useAppDispatch, useAppSelector } from '../../redux/store';\n\nconst JRCInputTinyMCE = commonComponentsRegistry.getLazyComponent('InputTinyMCE');\n\nexport type JRCInputTinyMCEWithExtProps<T extends FieldValues> = Omit<\n JRCInputTinyMCEProps<T>,\n 'commonOptions' | 'mentionsQueries' | 'additionalExtensions'\n>;\n\nexport const JRCInputTinyMCEWithExt = <T extends FieldValues = FieldValues>(props: JRCInputTinyMCEWithExtProps<T>) => {\n const intl = useIntl();\n const dispatch = useAppDispatch();\n const theme = useTheme();\n const models = useAppSelector(Model.selectors.selectAll);\n const { query, ext: extAI, isActive: isAIActive } = useAI();\n const {\n open,\n onInsert,\n close: closeMarkdownModal,\n ext: extMarkdown,\n isActive: isMarkdownActive,\n } = useMarkdownModal();\n\n const extArray = useMemo(() => {\n return [...(isMarkdownActive ? [extMarkdown] : []), ...(isAIActive ? [extAI] : [])];\n }, [extAI, extMarkdown, isAIActive, isMarkdownActive]);\n\n const onMentionsQueryError = useCallback(\n (message?: string) => {\n dispatch(Toast.actions.error({ label: message ?? intl.formatMessage({ id: 'GLOBAL_Error' }) }));\n },\n [dispatch, intl],\n );\n\n const tinyMentionsQueries = useMemo(() => {\n return getTinyMCEMentionsQueries(models, theme, onMentionsQueryError);\n }, [models, onMentionsQueryError, theme]);\n\n const commonOptions = useMemo(() => tinymceCommonOptions, []);\n\n return (\n <>\n {commonOptions && (\n <JRCInputTinyMCE\n commonOptions={commonOptions}\n additionalExtensions={extArray}\n mentionsQueries={tinyMentionsQueries}\n {...props}\n />\n )}\n {isAIActive && <AIModal query={query} />}\n {isMarkdownActive && <MarkdownModal onInsert={onInsert} open={open} close={closeMarkdownModal} />}\n </>\n );\n};\n","import { Model, Toast } from 'jamespot-front-business';\nimport React, { useCallback, useMemo } from 'react';\nimport { useIntl } from 'react-intl';\nimport { useTheme } from 'styled-components';\nimport { JRCInputTinyMCERawProps } from 'jamespot-react-components';\nimport { AIModal } from './extension/AIModal';\nimport { MarkdownModal } from './extension/MarkdownModal';\nimport { useMarkdownModal } from '../../hooks/useMarkdownModal';\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\nimport { tinymceCommonOptions } from '../../initTinymce';\nimport { getTinyMCEMentionsQueries } from '../../utils/tinymce';\nimport { useAI } from '../../hooks/useAI';\nimport { useAppDispatch, useAppSelector } from '../../redux/store';\n\nconst JRCInputTinyMCERaw = commonComponentsRegistry.getLazyComponent('InputTinyMCERaw');\n\nexport type JRCInputTinyMCEWithExtProps = Omit<\n JRCInputTinyMCERawProps,\n 'commonOptions' | 'mentionsQueries' | 'additionalExtensions'\n>;\n\nexport const JRCInputTinyMCEWithExtRaw = (props: JRCInputTinyMCEWithExtProps) => {\n const intl = useIntl();\n const dispatch = useAppDispatch();\n const theme = useTheme();\n const models = useAppSelector(Model.selectors.selectAll);\n const { query, ext: extAI, isActive: isAIActive } = useAI();\n const {\n open,\n onInsert,\n close: closeMarkdownModal,\n ext: extMarkdown,\n isActive: isMarkdownActive,\n } = useMarkdownModal();\n\n const extArray = useMemo(() => {\n return [...(isMarkdownActive ? [extMarkdown] : []), ...(isAIActive ? [extAI] : [])];\n }, [extAI, extMarkdown, isAIActive, isMarkdownActive]);\n\n const onMentionsQueryError = useCallback(\n (message?: string) => {\n dispatch(Toast.actions.error({ label: message ?? intl.formatMessage({ id: 'GLOBAL_Error' }) }));\n },\n [dispatch, intl],\n );\n\n const tinyMentionsQueries = useMemo(() => {\n return getTinyMCEMentionsQueries(models, theme, onMentionsQueryError);\n }, [models, onMentionsQueryError, theme]);\n\n const commonOptions = useMemo(() => tinymceCommonOptions, []);\n\n return (\n <>\n {commonOptions && (\n <JRCInputTinyMCERaw\n commonOptions={commonOptions}\n additionalExtensions={extArray}\n mentionsQueries={tinyMentionsQueries}\n {...props}\n />\n )}\n {isAIActive && <AIModal query={query} />}\n {isMarkdownActive && <MarkdownModal onInsert={onInsert} open={open} close={closeMarkdownModal} />}\n </>\n );\n};\n","import React from 'react';\r\nimport { FormattedMessage, useIntl } from 'react-intl';\r\nimport { Control } from 'react-hook-form';\r\nimport jamespot from 'jamespot-user-api';\r\nimport { Network } from 'jamespot-front-business';\r\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\r\nimport { useAppSelector } from '../../redux/store';\r\n\r\nconst JRCInputAudience = commonComponentsRegistry.getLazyComponent('InputAudience');\r\nconst JRCMessage = commonComponentsRegistry.getLazyComponent('Message');\r\nconst JRCModal = commonComponentsRegistry.getLazyComponent('Modal');\r\n\r\nexport type ModalAudienceProps = {\r\n open: boolean;\r\n closeHandler: () => void;\r\n title?: string;\r\n control: Control<any>;\r\n warningMessage?: string;\r\n onSubmit: () => void;\r\n name?: string;\r\n};\r\n\r\nexport const ModalAudience = ({\r\n open,\r\n closeHandler,\r\n title,\r\n control,\r\n warningMessage,\r\n onSubmit,\r\n name = 'publishTo',\r\n}: ModalAudienceProps) => {\r\n const intl = useIntl();\r\n const networkPublic = useAppSelector(Network.selectors.selectNetworkPublic);\r\n\r\n return (\r\n <JRCModal\r\n open={open}\r\n closeHandler={closeHandler}\r\n title={title ?? intl.formatMessage({ id: 'GLOBAL_Audience' })}\r\n buttons={[\r\n {\r\n children: <FormattedMessage id=\"GLOBAL_Cancel\" />,\r\n color: 'cancel',\r\n clickHandler: () => closeHandler(),\r\n },\r\n {\r\n children: <FormattedMessage id=\"GLOBAL_Continue\" />,\r\n color: 'danger',\r\n clickHandler: () => {\r\n closeHandler();\r\n onSubmit();\r\n },\r\n },\r\n ]}>\r\n <JRCMessage\r\n variant={'warning'}\r\n message={warningMessage ?? intl.formatMessage({ id: 'FORM_Audience_Empty' })}\r\n />\r\n <JRCInputAudience\r\n asyncPromise={(inputValue: string) => jamespot.audience.autocomplete(inputValue)}\r\n searchable={true}\r\n control={control}\r\n multiple={true}\r\n placeholder={intl.formatMessage({ id: 'GLOBAL_Audience' })}\r\n name={name}\r\n defaultCustomOptions={\r\n networkPublic\r\n ? [\r\n {\r\n uri: networkPublic.uri,\r\n title: networkPublic.title,\r\n resetOptions: true,\r\n icon: 'icon-fs-wall',\r\n },\r\n ]\r\n : []\r\n }\r\n />\r\n </JRCModal>\r\n );\r\n};\r\n","import React, { Suspense, useEffect, useMemo, useState } from 'react';\nimport { Outlet, matchPath, useLocation } from 'react-router-dom';\nimport { useIntl } from 'react-intl';\nimport { commonComponentsRegistry } from '../registry/CommonRegistry';\nimport { TwoColLayoutProps } from './types';\n\nconst Container = commonComponentsRegistry.getLazyComponent('Container');\nconst AppColumn = commonComponentsRegistry.getLazyComponent('AppColumn');\nconst MainColumn = commonComponentsRegistry.getLazyComponent('MainColumn');\n\nexport function TwoColLayout({ extensionRoute, routes, description, mode = 'center' }: TwoColLayoutProps) {\n const intl = useIntl();\n const { pathname } = useLocation();\n\n const ROUTES_ARRAY = useMemo(() => Object.values(routes), [routes]);\n const [activeTab, setActiveTab] = useState(ROUTES_ARRAY?.[0]?.key);\n\n const tabs = ROUTES_ARRAY.map((tab) => ({\n ...tab,\n label: intl.formatMessage({ id: tab.label }),\n href: tab.absolutePath ? tab.path : `/ng/rr/${extensionRoute}/${tab.path}`,\n group: tab.group ? intl.formatMessage({ id: tab.group }) : undefined,\n }));\n\n useEffect(() => {\n const activeRoute = ROUTES_ARRAY.find((route) => {\n if (`/ng/rr/${extensionRoute}/${route.path}` === pathname) {\n return true;\n }\n\n return route.paths?.reduce<boolean>((previousValue: boolean, currentValue: string) => {\n const pattern = `/ng/rr/${extensionRoute}/${currentValue}`;\n const isMatch = matchPath(pattern, pathname) !== null;\n return previousValue || isMatch;\n }, false);\n });\n if (activeRoute) setActiveTab(activeRoute.key);\n }, [pathname, ROUTES_ARRAY, extensionRoute]);\n\n return (\n <Suspense fallback={<></>}>\n <Container mode={mode}>\n <AppColumn mode={mode} description={description} tabs={tabs} activeTab={activeTab || ''} />\n <MainColumn mode={mode} flex={true}>\n <Outlet />\n </MainColumn>\n </Container>\n </Suspense>\n );\n}\n"],"names":["JRCIcon","getLazyComponent","Avatar","props","theme","useTheme","networkPublic","selectors","selectNetworkPublic","uri","name","size","color","primary","variant","JRCAvatar","JRCFlexBox","JRCModalContent","JRCModalLayout","JRCStyledHref","JRCTooltip","JRCTypography","AudienceWrapper","AvatarLink","white","lavender","overlap","Audience","audience","limit","intl","useIntl","isModalOpen","setModalOpen","useState","splice","map","item","index","href","_url","target","key","id","description","undefined","title","position","alt","timestamp","dateModified","Utils","date","strToTimestamp","focusable","length","onClick","closeHandler","enableClickAwayCloseModal","open","maxHeight","formatMessage","overflow","onClickIconClose","i","y","gap","space","l","type","JRCLoader","TextWrapper","md","loadingResponse","response","loading","error","AIModal","query","setResponse","sendAIRequest","useCallback","textEnhancement","text","capacity","capability","then","errorMsg","textResponse","result","catch","_err","useEffect","trim","zIndex","tinyMCEModal","reject","buttons","children","clickHandler","resolve","isFull","align","CSSEditorPortal","isActive","CSSEditorHeader","grey2","CSSEditorAction","CSSEditorLabel","CSSEditorMask","EDITOR_WIDTH","CSSEditor","CSSEditorContent","CSSEditorTab","CSSEditorIsBusy","CSSEditorIsLocked","CSSEditorMenu","CSSEditorMenuButton","DashedFocusBorder","JRCButton","grey1","grey0","EditorPopup","uniqid","dispatch","editor","state","selectEditor","popup","view","style","flex","display","flexDirection","backgroundColor","marginTop","slice","actions","flushEditorPopup","WidgetArticleTitleEditor","WidgetArticleTextEditor","WidgetArticleGalleryEditor","WidgetArticleAttachmentEditor","WidgetArticleSliderEditor","WidgetArticleImageEditor","WidgetButtonEditor","WidgetCheckListEditor","WidgetQuickSurveyEditor","WidgetDatasourceTableEditor","WidgetExcelDatasourceTableEditor","WidgetPresenceEditor","WidgetEmailsImapEditor","WidgetContactCardDavEditor","WidgetCalendarCalDavEditor","Editor","token","selectToken","widgetWrapper","selectWidget","shallowEqual","onSaveCallback","onSave","handleHookIsActive","selectHook","getState","content","updateWidget","flushEditor","onStateChange","states","setWidgetState","onOpen","registerEditorPopup","widget","ensureWidgetArticleButtonType","onChange","ensureWidgetArticleGalleryType","ensureWidgetArticleAttachmentType","ensureWidgetArticleImageType","ensureWidgetArticleSliderType","slides","loop","useDots","ensureWidgetArticleTitleType","ensureWidgetArticleTextType","ensureWidgetPresenceType","ensureWidgetCheckListType","arr","w","html","htmlDecodeSpecialChars","onChangeContent","onChangeWrapper","updateWidgetWrapper","handleChange","ensureWidgetQuickSurveyType","ensureWidgetExcelDatasourceTableType","hook","handlers","jamespot","datasource","network","filebank","wedoc","handleStart","busy","handleCatch","err","label","handleFinally","override","onError","ensureWidgetEmailsImapType","ensureWidgetContactCardDavType","ensureWidgetCalendarCalDavType","ensureWidgetDatasourceTableType","application","Icon","EditorPosition","setEditorPosition","InputColorRaw","Label","Fieldset","EditorInputColor","initialValue","palettes","colors","secondary","headerColor","orange","green","navy","overseas","FormattedMessage","JRCInputNumber","EditorInputNumber","control","watch","useForm","defaultValues","value","criteriaMode","subscription","data","unsubscribe","width","placeholder","InputSelect","EditorInputSelect","options","required","optionFromInitialValue","useMemo","find","el","select","components","Option","o","option","getSearch","rules","hideDeleteIcon","JRCInputText","EditorTabWrapper","wrapper","styles","selectWidgetTitleStyle","replace","initialValues","String","black","fontSize","fontWeight","textAlign","setWidgetTitleStyle","colorValue","backgroundColorValue","fontSizeValue","fontWeightValue","textAlignValue","Loader","EditorIsBusy","isBusy","selectWidgetState","EditorIsLocked","locked","EditorSave","mode","selectWidgetObjectUri","v2","e","EditorTabWidgetSelection","selectWidgetWrapperStyle","padding","borderRadius","borderColor","borderWidth","borderStyle","setWidgetWrapperStyle","paddingValue","borderRadiusValue","borderStyleValue","borderColorValue","borderWidthValue","EditorTabDisplayLevel","def","definition","level","selectWidgetLevel","Number","filter","Array","isArray","displayLevel","includes","OVERRIDE_SAVE","Tooltip","EditorWrapper","ref","useRef","enableWidgetLevel","tabs","enable","panel","useWrapper","icon","useSelection","useEditor","defaultTab","currentTab","setCurrentTab","setTimeout","current","className","tab","inset","opacity","CSSEditorPortalWrapper","CSSEditorPortalPopupWrapper","CSSEditorPortalRow","CSSEditorPortalFreeSpace","EditorsPortal","flush","flushAllEditor","window","addEventListener","removeEventListener","editors","selectEditors","JRCThemeProvider","EditorsPanel","portalDiv","document","getElementById","portal","parent","createElement","appendChild","createPortalElement","createPortal","CSSSquareWidgetWrapper","CSSSquareWidget","available","CSSWidgetButton","height","CSSWrapWidgetWrapper","column","CSSWrapTitle","CSSWrapWidget","parentIsColumn","full","Flex","direction","JRCIconButton","WidgetList","namespace","isOpen","setOpen","widgets","WidgetsName","ArticleTitle","ArticleButton","CheckList","Presence","QuickSurvey","ArticleText","ArticleImage","ArticleSlider","ArticleAttachment","getBuilderWidgets","args","portalId","factory","src","img","minWidth","WidgetModeArticle","WidgetModeComment","calcHeight","Math","ceil","bg","bgHover","iconSize","JRCInputFileAdvancedRaw","CSSHidden","WidgetUploader","initialFiles","initialClick","multiple","accept","onUploadStart","onUploadEnd","onUploadSuccess","uploadRef","total","setTotal","files","setFiles","click","totalFile","prevTotal","fileResponse","prevFiles","WidgetAttachment","JRCWidgetEmptyInplace","FileViewer","CSSWrapper","JRCWidgetArticleAttachmentWrapper","inplace","message","mounted","empty","onlyOffice","selectById","file","getAccessHash","Error","hash","idFile","getWedocFilePath","wedocWindowOpen","openWithOptions","condition","f","mimetype","url","JRCWidgetButton","CSSButtonWrapper","CSSPointer","clickable","JRCWidgetArticleButtonWrapper","buttonSize","registerEditor","JRCWidgetArticleGallery","CSSImagePointer","JRCWidgetArticleGalleryWrapper","maxWidth","WidgetImage","CSSImageWrapperHover","mockFileLittle","mainType","dateCreation","str","Date","parse","isNaN","getTime","JRCWidgetArticleImageWrapper","useFilter","setUri","formatImgUrl","now","from","path","JRCWidgetSlider","Wrapper","JRCWidgetArticleSliderWrapper","dynamicWidth","setDynamicWidth","fileViewerFiles","slide","handleResize","offsetWidth","isEditable","handleEditor","startAt","onClickSlide","useMarkdownModal","setEditor","onInsert","v","execCommand","close","ext","JTinyMCEExtensionsBuilders","markdown","ed","InputTextareaRaw","Modal","MarkdownModal","setMarkdown","doClose","disabled","async","WidgetArticleText","CSSTextWrapper","JRCWidgetArticleTextWrapper","tinyMCECommonOptions","selectTinyMCECommonOptions","models","selectAll","closeMarkdownModal","extMarkdown","isMarkdownActive","tinyMentionsQueries","autoFocus","commonOptions","mentionsQueries","additionalExtensions","WidgetArticleTitle","ToolWrapper","Tool","JRCWidgetArticleTitleWrapper","dataCy","heading","Toolbar","sizeValue","Footer","WidgetRemove","setIsOpen","removeWidget","flushWidget","WidgetFooterView","collaborationRights","handleOpenEditor","widgetObject","selectWidgetObject","widgetObjectRights","selectWidgetObjectRights","canUpdate","update","canDelete","delete","handleOnClick","ensureWidgetObjectHasMinimumProperties","WidgetInlineInputText","handleClick","setLabel","reset","WidgetIsPending","WidgetCheckList","CommentContainer","border","CSSWidgetCheckListWrapper","JRCWidgetCheckListWrapper","onWidgetUpdate","widgetContent","setToken","tokenLoading","setTokenLoading","entries","setEntries","isPending","setIsPending","tokenFromStore","allRt","selectAllWidgetRTObject","canEditCollaboration","canAdministrate","administrate","fetchToken","res","handleReloadWidget","getWidget","aborted","finally","openEditorPanel","finalEntries","checked","links","user","lastRt","at","object","fn","handleCollabAddEntry","contentToUpdate","fs","forEach","push","useRT","JRCFileViewer","initialEntries","onFileClick","entry","onItemCheckListChange","checkListRespond","handleCheckItem","edit","getVisibleColumns","tableColumnsData","columns","toRet","isVisible","JRCHtml","WidgetTable","AbsoluteWrapper","WrapperEditMode","WidgetDatasourceTableWrapper","tableHeadColor","tableHeadTextColor","tableHeadIconColor","tableRowColor","tableRowTextColor","tableBorderRadius","tableSizedColumns","tableSizedColumnsWidth","isEditorOpenOnFirstRender","setIsEditorOpenOnFirstRender","isLoading","setIsLoading","datasourceData","setDatasourceData","datasourceModel","setDatasourceModel","datasourceSort","setDatasourceSort","order","datasourceType","setDatasourceType","datasourceIdentifier","setDatasourceIdentifier","DatasourceTable","rtConditions","rtAudience","rtLastObject","fetchDatasource","get","Format","VIEW","model","sort","rows","tableDefaultSortOrder","tableDefaultSortName","__html","WidgetExcelDatasourceTableWrapper","ExcelDatasourceTable","CSSPaddingMd","CSSHref","CSSHorizontalAlign","WidgetPresenceWrapperClosing","handleClosing","isClosed","JRCWidgetPresence","ModalUserList","CSSWidgetPresenceWrapper","CSSWidgetPresenceIsClosed","sm","JRCWidgetPresenceWrapper","limitValue","closing","userValue","userAvailableList","userUnavailableList","userAvailableTotal","userUnavailableTotal","isPendingResponse","setIsPendingResponse","abortController","AbortController","openUsersModal","setOpenUsersModal","usersListIndex","setUsersListIndex","usersList","setUsersList","handleError","canRespond","lockedRespondHandler","handleCancelRespond","presenceCancel","handleRespond","presenceRespond","signal","handleResponse","presenceGetResponse","handleLoadUsersList","page","presenceGetResponseUserList","cnt","elm","abort","handleClickAvailable","handleClickUnavailable","handleOpenUsersModal","onClose","WidgetQuickSurvey","WrapperContainer","withPadding","JRCWidgetQuickSurveyWrapper","userResponses","totalRespondent","totalResponse","userLoggedResponses","quickSurveyGetResponse","handleWidgetGet","handleCloseSurvey","finalContent","handleProgressBarClick","quickSurveyRespond","multi","quickSurveyGetResponseUserList","values","userHasAlreadyVoted","canCloseSurvey","anonymize","seeResponseAfter","handleClickFile","newContent","quickSurveyAddEnty","ModalLayout","ModalContent","InputText","InputNumber","InputPassword","Typography","UIForm","isLocked","UIWrapper","UIProviderError","officeConfigurationInitialState","username","password","hostname","imapPort","imapMailbox","cardDavAddressBook","calDavCalendar","provider","OfficeConfigurationPrompt","useDispatch","useAbortController","setValue","getValues","formState","isValid","providerList","setProviderList","fetchConfiguration","providers","getConfiguration","getProviders","handleClose","radius","SelectProvider","loader","setConfiguration","location","reload","getValue","getLabel","CSSWidgetTitle","UITitle","WidgetIntranetTitle","UIHeaderWrapper","backroundColor","UIHeader","UIHeaderFlex","grey4","xs","WidgetHeader","dropdown","subHeader","styleValues","ButtonDropdown","UIDropdown","WidgetContactCardDavHeader","isConfigurationValid","handleLogout","small","smallOpenDirection","UIFlex","UIScrollWrapper","UIScroll","WidgetScroll","header","scrollable","footer","WidgetStylePadding","WidgetContactCardDav","JRCWidgetContactCardDavWrapper","levelFallback","setIsConfigurationValid","setUrl","doInterval","setDoInterval","list","setList","initialized","handleLogin","handleLoading","fetchProviderUrls","getProviderBaseUrls","dav_address_book_url","fetchData","davAddressBookGetContacts","WIDGET_LEVEL_3","interval","setInterval","clearInterval","WIDGET_LEVEL_1","contactCardList","WidgetCalendarCalDavHeader","WidgetCalendarCalDav","JRCWidgetCalendarCalDavWrapper","moment","useMoment","dav_calendar_url","davCalendarGetEvents","dateStart","format","dateEnd","add","calendarListEvent","WidgetEmailsImapHeader","count","selectWidgetChipCount","WidgetEmailsImap","JRCWidgetEmailsImapWrapper","fetchUnreadEmailsCount","imapInboxGetUnreadEmailsCount","setWidgetChipCount","imap_inbox_url","imapInboxGetEmails","WIDGET_LEVEL_2","emailList","WidgetTitle","WidgetTitleEdit","widgetWrapperTitle","widgetTitle","margin","CSSModalFooter","CSSWidgetHeaderEdit","CSSWidgetHeaderEditTitle","CSSWidgetHeaderEditActions","WidgetHeaderEdit","handleRemoveWidget","CSSWidgetWithTitle","DisplayWidget","cannotDisplayComponent","CSSWidgetLayer","pointerEvents","BETA_JRCDoubleClick","WidgetLayer","layers","ids","layer","Layer","LayerWidget","layerId","visible","top","left","x","DraggableHandler","onMouseUp","updateLayer","onDoubleTap","mouseIsDown","setMouseDown","mouse","setMouse","start","setStart","child","setChild","handleMouseDown","event","nativeEvent","clientX","clientY","handleMouseMove","dx","dy","handleMouseUp","onMouseDown","WidgetState","justifyContent","alignItems","hover","WidgetWrapperCoreEditHover","isInitialized","WidgetIcon","CSSIconAbsoluteA","JRCWidgetIconWrapper","rel","maxValue","WidgetStyleWrapper","WidgetWrapperCore","indexOrder","editableMap","currentEditableWidgetId","isComponentVisible","setIsComponentVisible","registerWidgetObject","registerWidget","setEditableWidgetId","setEditableIndex","CSSCommentsBlocWidgetWrapper","JRCMessage","CommentsBlocAddCommentWidgetsWrapper","flushedWidgets","selectFlushedWidgets","CommentsBlocCommentWidgetsWrapper","comment","handleWidgetUpdate","JRCCommentsBloc","CommentsBlocWrapper","CommentsBloc","articleId","canComment","commentType","socialQuestion","setLoading","setWidgets","currentUser","widgetIds","selectWidgets","tinyMCEExtendedOptions","selectTinyMCEExtendedOptions","platformConfig","selectPlatformConfig","commentsList","commentList","driveHook","fileBank","widgetHook","socialQuestionOptions","setSocialQuestionOptions","useCommentRT","idComments","idArticle","reactSocket","socket","rtHandlers","getCommentsLikeRTHandlers","handler","onMessage","function","offMessage","c","fetchComments","onComment","params","finalWidget","Object","keys","some","addComment","_widgets","registerWidgetObjectRights","rights","_right","comments","onCommentUpdate","commentToUpdate","idComment","updateComment","onCommentDelete","deleteComment","isWidgetActive","create","autorize","widgetListComponent","newWidgetsWrapperComponent","existingWidgetsWrapperComponent","handleWidgetRemove","tinyMCEConfig","toolbar","commentsToolbar","highlightFields","userHighlightFields","userAccountStatus","userModel","m","isWedocActive","onGetHashError","activeDrives","utils","buildDrivesArrayFromObject","drives","drive","socialAction","questionAnswer","onSelectResponse","responseId","isResolved","onUnselectResponse","StretchContainer","css","Container","stretch","Form","FormElm","forwardRef","onSubmit","FieldsetWrapper","DisplayForm","formRef","configuration","useDisplay","fields","forceMandatory","handleSubmit","formFn","formatValuesForSubmit","k","join","useImperativeHandle","scrollTo","getFormattedValues","Input","conf","readOnly","extraInputs","Empty","useAI","setQuery","J","hooks","JIAHook","debug","PrepareAndSetQuery","fetch","Promise","AICapabilities","develop","summarize","tldr","en","es","formal","funny","jia","JRCInputTinyMCE","JRCInputTinyMCEWithExt","extAI","isAIActive","extArray","onMentionsQueryError","JRCInputTinyMCERaw","JRCInputTinyMCEWithExtRaw","JRCInputAudience","JRCModal","ModalAudience","warningMessage","asyncPromise","inputValue","autocomplete","searchable","defaultCustomOptions","resetOptions","AppColumn","MainColumn","TwoColLayout","extensionRoute","routes","pathname","useLocation","ROUTES_ARRAY","activeTab","setActiveTab","absolutePath","group","activeRoute","route","paths","reduce","previousValue","currentValue","pattern","isMatch","matchPath","Suspense","fallback","Outlet"],"sourceRoot":""}
|