jamespot-react-core 1.1.186 → 1.1.187
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/{435.5a7eed97dce6a229d701.chunk.js → 435.38154081efc76cefc3ba.chunk.js} +7 -7
- package/build/435.38154081efc76cefc3ba.chunk.js.map +1 -0
- package/build/app.bundle.js +4 -4
- package/build/app.bundle.js.map +1 -1
- package/build/src/components/widgets/Widget.d.ts +2 -1
- package/build/src/components/widgets/WidgetWrapperCore.d.ts +2 -1
- package/build/src/components/widgets/wrapper/JRCWidgetArticleTitleWrapper.d.ts +2 -1
- package/package.json +3 -3
- package/build/435.5a7eed97dce6a229d701.chunk.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"435.5a7eed97dce6a229d701.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/WidgetIsPending.tsx","webpack://ReactCore/./src/components/widgets/wrapper/components/WidgetInlineInputText.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';\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 &: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\" />\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 />\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} />\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 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 { 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 (tamplate)\n*/\nexport const EditorsPortal = () => {\n const editors = useAppSelector(WidgetEditor.selectors.selectEditors, shallowEqual);\n return (\n <CSSEditorPortalWrapper className=\"editor-portal-wrapper\">\n {editors.map((editor, index: number) => {\n if (editor.position === 'left') {\n return (\n <CSSEditorPortal isActive={false} key={index}>\n <CSSEditorPortalRow>\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 </CSSEditorPortalRow>\n </CSSEditorPortal>\n );\n }\n\n return (\n <CSSEditorPortal isActive={false} key={index}>\n <CSSEditorPortalRow>\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 </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}: {\n widget: WidgetArticleTitleType;\n inplace: boolean;\n mode?: WidgetDisplayMode;\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 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 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 { 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 { 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 { WidgetFooterView } from './components/WidgetFooterView';\nimport { useWidgetRT } from '../hooks';\nimport { WidgetIsPending } from './components/WidgetIsPending';\nimport { WidgetInlineInputText } from './components/WidgetInlineInputText';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { RTProvider } from '../../RTProvider.component';\nimport { useAppDispatch, useAppSelector } from '../../../redux/store';\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\n const [entries, setEntries] = useState<JRCWidgetCheckListEntries | undefined>();\n const [isPending, setIsPending] = useState(false);\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 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 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, { useEffect, useState } from 'react';\nimport { useForm } from 'react-hook-form';\nimport { useIntl, FormattedMessage } from 'react-intl';\nimport styled from 'styled-components';\nimport { JRCLoader } 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 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 officeConfigurationInitalState = {\n username: '',\n password: '',\n hostname: 'mail.sogomail.eu',\n imapMailbox: 'INBOX',\n cardDavAddressBook: 'personal',\n calDavCalendar: 'personal',\n provider: 'sogo',\n};\n\nexport const OfficeConfigurationPrompt = ({ handleCallback }: { handleCallback?: (isValid: boolean) => void }) => {\n const intl = useIntl();\n const dispatch = useDispatch();\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: officeConfigurationInitalState,\n criteriaMode: 'all',\n });\n\n const refresh = () => window.location.reload();\n const [providerList, setProviderList] = useState<OfficeProvider[]>([]);\n const enableHardRefresh = true; // keep it truthy plz\n const data = watch();\n const handleSubmit = () => {\n if (isPending) return;\n setIsPending(true);\n jApi.office\n .setConfiguration(data)\n .then(({ result }) => {\n if (enableHardRefresh) {\n refresh();\n } else {\n handleCallback && handleCallback(result);\n }\n })\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()\n .then(({ result }) => setProviderList(result))\n .catch((err) => dispatch(Toast.actions.error({ label: err.errorMsg })))\n .finally(() => setIsPending(false));\n }, [isOpen, dispatch]);\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\" />\n </Typography>\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\" />\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\" />\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`;\n\nexport const UITitle = styled.div<{ fontSize: string; fontWeight: string; textAlign: string }>`\n text-align: ${(props) => props.textAlign};\n font-size: ${(props) => props.fontSize}px;\n font-weight: ${(props) => props.fontWeight};\n`;\n\nexport const WidgetIntranetTitle = ({\n uniqid,\n textAlign = 'left',\n fontSize = '16',\n fontWeight = 'medium',\n}: {\n uniqid: string;\n textAlign: string;\n fontSize: string;\n fontWeight: 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}>\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; color: string }>`\n background-color: ${(props) => props.backroundColor};\n color: ${(props) => props.color};\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`;\n\nexport const WidgetHeader = ({\n uniqid,\n dropdown,\n subHeader,\n}: {\n uniqid: string;\n dropdown?: () => React.ReactNode;\n subHeader?: () => React.ReactNode;\n}) => {\n const theme = useTheme();\n const styles = useAppSelector((state) => Widget.selectors.selectWidgetTitleStyle(state, uniqid), shallowEqual);\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']) : '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={initialValues.backgroundColor} color={initialValues.color}>\n <UIHeader>\n <UIHeaderFlex>\n <WidgetIntranetTitle\n uniqid={uniqid}\n fontWeight={initialValues.fontWeight}\n fontSize={initialValues.fontSize}\n textAlign={initialValues.textAlign}\n />\n </UIHeaderFlex>\n {dropdown && dropdown()}\n </UIHeader>\n {subHeader && subHeader()}\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 { officeConfigurationInitalState } 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 UIHeader = styled.div`\n display: flex;\n flex-direction: row;\n align-items: center;\n`;\n\nexport const UIHeaderFlex = styled.div`\n padding: ${(props) => props.theme.space.md}px 0px;\n flex: 1;\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(officeConfigurationInitalState).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 <Tooltip position={'left'} 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 )\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 { Widget } from 'jamespot-front-business';\nimport React, { useCallback, useEffect, useState } from 'react';\nimport { shallowEqual } from 'react-redux';\nimport { officeConfigurationInitalState, 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(officeConfigurationInitalState);\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()\n .then(({ result }) => {\n setList(result);\n setDoInterval(true);\n })\n .catch(handleLogout)\n .finally(() => handleLoading(false));\n }, [handleLogout, handleLoading]);\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 handleCallback={handleLogin} />\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 { officeConfigurationInitalState } 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 UIHeader = styled.div`\n display: flex;\n flex-direction: row;\n align-items: center;\n`;\n\nexport const UIHeaderFlex = styled.div`\n padding: ${(props) => props.theme.space.md}px 0px;\n flex: 1;\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(officeConfigurationInitalState).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 <Tooltip position={'left'} 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 )\n );\n }}\n />\n );\n};\n","import { 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 { officeConfigurationInitalState, 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(officeConfigurationInitalState);\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(handleLogout)\n .finally(() => handleLoading(false));\n }, [handleLogout, handleLoading, 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 handleCallback={handleLogin} />\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, JRCTypography } from 'jamespot-react-components';\nimport { officeConfigurationInitalState } 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 UIHeaderWrapper = styled.div<{ backroundColor: string; color: string }>`\n background-color: ${(props) => props.backroundColor};\n color: ${(props) => props.color};\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`;\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(officeConfigurationInitalState).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 <Tooltip position={'left'} 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 )\n );\n }}\n subHeader={() => {\n return (\n isConfigurationValid && (\n <UICount>\n <JRCTypography size={'s'}>\n {intl.formatMessage({ id: 'WIDGET_Email_IMAP_Unread_Emails' }, { count })}\n </JRCTypography>\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 { Widget } from 'jamespot-front-business';\nimport React, { useCallback, useEffect, useState } from 'react';\nimport { shallowEqual } from 'react-redux';\nimport { WidgetEmailsImapHeader } from './WidgetEmailsImap/WidgetEmailsImapHeader';\nimport { officeConfigurationInitalState, 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(officeConfigurationInitalState);\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()\n .then(({ result }) => {\n setList(result);\n setDoInterval(true);\n })\n .catch(handleLogout)\n .finally(() => handleLoading(false));\n }, [handleLoading, handleLogout]);\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 handleCallback={handleLogin} />\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}: {\n widget: CombinedWidgetType;\n width?: number | undefined;\n inplace: boolean;\n mode: WidgetDisplayMode;\n onWidgetUpdate?: () => void;\n onClick: () => void;\n cannotDisplayComponent?: (widget: string) => ReactNode;\n levelFallback?: (level: WidgetWrapperLevel, url: string) => ReactNode | undefined;\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} />;\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(\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 = React.forwardRef(WidgetStyle);\n","import React, { ReactNode, useEffect } from 'react';\nimport { shallowEqual } from 'react-redux';\n\nimport { Widget, WidgetEditor } from 'jamespot-front-business';\nimport { ensureWidgetArticleButtonType, 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};\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}: 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 { ref, 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 if (widgetWrapper === undefined) {\n return <>This widget cannot be displayed</>;\n }\n\n const _widget = widgetWrapper.widget;\n\n const onClick = () => {\n if (mode === 'edit') {\n registerEditor();\n } else {\n if (ensureWidgetArticleButtonType(_widget)) {\n switch (_widget.content.openingType) {\n case 'link':\n if (_widget.content.openingTypeLink) {\n window.open(_widget.content.openingTypeLink.url, _widget.content.openingTypeLink.target);\n }\n break;\n }\n }\n }\n };\n\n const registerEditor = () => {\n if (mode === 'view') {\n return;\n }\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 };\n\n if (inplace && mode !== 'view') {\n return (\n <WidgetStyleWrapper\n uniqid={uniqid}\n ref={ref}\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 width={width}\n widget={{\n ...widgetWrapper.widget,\n ...(widgetWrapper.title && {\n title: widgetWrapper.title,\n }),\n }}\n inplace={inplace}\n mode={mode}\n onClick={onClick}\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 widget={{\n ...widgetWrapper.widget,\n ...(widgetWrapper.title && {\n title: widgetWrapper.title,\n }),\n }}\n inplace={inplace}\n mode={mode}\n width={width}\n onClick={onClick}\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 },\n ref: ForwardedRef<HTMLFormElement | HTMLDivElement>,\n) => {\n return props.onSubmit ? (\n <Form stretch={props.stretch} onSubmit={props.onSubmit} ref={ref as Ref<HTMLFormElement>}>\n {props.children}\n </Form>\n ) : (\n <Container stretch={props.stretch} ref={ref as Ref<HTMLDivElement>}>\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 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","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","editors","selectEditors","JRCThemeProvider","EditorsPanel","portalDiv","document","getElementById","portal","parent","createElement","appendChild","createPortalElement","createPortal","CSSSquareWidgetWrapper","CSSSquareWidget","available","CSSWidgetButton","height","CSSWrapWidgetWrapper","column","CSSWrapTitle","CSSWrapWidget","parentIsColumn","full","DashedFocusBorder","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","window","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","addEventListener","removeEventListener","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","heading","Toolbar","sizeValue","Footer","WidgetRemove","setIsOpen","removeWidget","flushWidget","WidgetFooterView","collaborationRights","handleOpenEditor","widgetObject","selectWidgetObject","widgetObjectRights","selectWidgetObjectRights","canUpdate","update","canDelete","delete","handleOnClick","ensureWidgetObjectHasMinimumProperties","WidgetIsPending","WidgetInlineInputText","handleClick","setLabel","reset","WidgetCheckList","CommentContainer","border","CSSWidgetCheckListWrapper","JRCWidgetCheckListWrapper","onWidgetUpdate","widgetContent","entries","setEntries","isPending","setIsPending","allRt","selectAllWidgetRTObject","canEditCollaboration","canAdministrate","administrate","handleReloadWidget","getWidget","aborted","finally","openEditorPanel","flushAllEditor","setToken","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","InputPassword","Typography","UIForm","isLocked","UIWrapper","UIProviderError","officeConfigurationInitalState","username","password","hostname","imapMailbox","cardDavAddressBook","calDavCalendar","provider","OfficeConfigurationPrompt","handleCallback","useDispatch","setValue","getValues","formState","isValid","providerList","setProviderList","getProviders","handleClose","radius","SelectProvider","loader","setConfiguration","location","reload","getValue","getLabel","CSSWidgetTitle","UITitle","WidgetIntranetTitle","UIHeaderWrapper","backroundColor","UIHeader","UIHeaderFlex","grey4","WidgetHeader","dropdown","subHeader","ButtonDropdown","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","_widget","openingType","openingTypeLink","setEditableIndex","CSSCommentsBlocWidgetWrapper","JRCMessage","CommentsBlocAddCommentWidgetsWrapper","flushedWidgets","selectFlushedWidgets","CommentsBlocCommentWidgetsWrapper","comment","handleWidgetUpdate","JRCCommentsBloc","CommentsBlocWrapper","CommentsBloc","articleId","canComment","commentType","socialQuestion","setLoading","setWidgets","tokenLoading","setTokenLoading","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","fetchToken","res","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","dataCy","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":""}
|