jamespot-react-core 1.2.62 → 1.3.4

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.
@@ -1 +0,0 @@
1
- {"version":3,"file":"306.70047e7323717f3ef108.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/displayer/DisplayForm.component.tsx","webpack://ReactCore/./src/components/comments/AddReportModal.tsx","webpack://ReactCore/./src/hooks/useCommentsLikeRT.ts","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/hooks/useMarkdownModal.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/components/WidgetIntranetTitle.tsx","webpack://ReactCore/./src/components/widgets/wrapper/components/WidgetHeader.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/JRCWidgetLuccaAbsenceWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetArticleImageWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetArticleSliderWrapper.tsx","webpack://ReactCore/./src/components/tinymce/extension/MarkdownModal.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetArticleTextWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetArticleTitleWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/components/WidgetRemove.tsx","webpack://ReactCore/./src/components/widgets/wrapper/components/WidgetFooterView.tsx","webpack://ReactCore/./src/components/widgets/wrapper/components/WidgetInlineInputText.tsx","webpack://ReactCore/./src/components/widgets/wrapper/components/WidgetIsPending.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetCheckListWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/utils.ts","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetDatasourceTableWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetExcelDatasourceTableWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetPresenceWrapperClosing.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetPresenceWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetQuickSurveyWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetUserProfileWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/components/OfficeConfigurationPrompt.tsx","webpack://ReactCore/./src/components/widgets/wrapper/WidgetContactCardDav/WidgetContactCardDavHeader.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/wrapper/WidgetLicenseWrapper.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/components/WidgetStyleWrapper.tsx","webpack://ReactCore/./src/components/widgets/wrapper/JRCWidgetIconWrapper.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/hooks/useGifsModal.ts","webpack://ReactCore/./src/components/tinymce/extension/GifsModal.tsx","webpack://ReactCore/./src/components/CommentsBloc.tsx","webpack://ReactCore/./src/components/calendar/CalendarHeader.tsx","webpack://ReactCore/./src/components/calendar/CalendarToolbar.tsx","webpack://ReactCore/./src/components/calendar/CalendarWrapper.tsx","webpack://ReactCore/./src/hooks/useCalendarRT.ts","webpack://ReactCore/./src/components/editors/style.tsx","webpack://ReactCore/./src/components/editors/const.ts","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/Empty.tsx","webpack://ReactCore/./src/components/FullPageLayout.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/modals/ModalSchedule.tsx","webpack://ReactCore/./src/components/TwoColLayout.tsx"],"sourcesContent":["import { Network } from 'jamespot-front-business';\r\nimport { JRCAvatarProps, SROnly } from 'jamespot-react-components';\r\nimport { useIntl } from 'react-intl';\r\nimport styled, { useTheme } from 'styled-components';\r\nimport { useAppSelector } from '../redux/store';\r\nimport { commonComponentsRegistry } from '../registry/CommonRegistry';\r\n\r\nconst JRCIcon = commonComponentsRegistry.getLazyComponent('Icon');\r\nconst JRCAvatar = commonComponentsRegistry.getLazyComponent('JRCAvatar');\r\n\r\nconst BASE_MULTIPLE = 8;\r\n\r\nconst SR = styled.span`\r\n ${SROnly}\r\n`;\r\n\r\nexport const Avatar = (props: JRCAvatarProps) => {\r\n const theme = useTheme();\r\n const intl = useIntl();\r\n const networkPublic = useAppSelector(Network.selectors.selectNetworkPublic);\r\n\r\n if (props.uri === networkPublic?.uri) {\r\n return (\r\n <>\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 <SR>{intl.formatMessage({ id: 'NETWORK_Public' })}</SR>\r\n </>\r\n );\r\n }\r\n\r\n return <JRCAvatar {...props} />;\r\n};\r\n","import { 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 { 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","import { DisplayFormFieldsConfig, DisplayFormRef } from './types';\nimport { useForm, Control, FieldValues } from 'react-hook-form';\nimport { useDisplayForm } from './useDisplay';\nimport styled, { css } from 'styled-components';\nimport {\n FormEventHandler,\n ForwardedRef,\n forwardRef,\n ReactNode,\n Ref,\n useCallback,\n useEffect,\n useImperativeHandle,\n useRef,\n useState,\n} from 'react';\nimport { AudienceAutocomplete } from 'jamespot-user-api';\n\nconst StretchContainer = css`\n height: 100%;\n display: flex;\n flex-direction: column;\n justify-content: space-between;\n`;\n\nconst Container = styled.div<{ stretch?: boolean }>`\n ${({ stretch }) => stretch && StretchContainer}\n`;\n\nconst Form = styled.form<{ stretch?: boolean }>`\n ${({ stretch }) => stretch && StretchContainer}\n`;\n\nconst FormElement = (\n props: {\n stretch?: boolean;\n onSubmit?: FormEventHandler<HTMLFormElement>;\n children: ReactNode;\n dataCy?: string;\n },\n ref: ForwardedRef<HTMLFormElement | HTMLDivElement>,\n) => {\n return props.onSubmit ? (\n <Form\n stretch={props.stretch}\n onSubmit={props.onSubmit}\n ref={ref as Ref<HTMLFormElement>}\n data-cy={props.dataCy}>\n {props.children}\n </Form>\n ) : (\n <Container stretch={props.stretch} ref={ref as Ref<HTMLDivElement>} data-cy={props.dataCy}>\n {props.children}\n </Container>\n );\n};\nconst FormElm = forwardRef(FormElement);\n\nconst FieldsetWrapper = styled.div<{ stretch?: boolean }>`\n ${(props) =>\n props.stretch &&\n `\n flex: 1;\n`}\n`;\n\ntype FormFn<TFieldValues extends FieldValues> = Omit<\n ReturnType<typeof useForm<TFieldValues>>,\n 'handleSubmit' | 'control' | 'reset'\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 onInit?: (formFn: FormFn<TFieldValues>) => void;\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 { onInit, ...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 const [isInit, setIsInit] = useState(false);\n\n const { handleSubmit, control, reset, ...formFn } = useForm({\n defaultValues: {\n ...defaultValues,\n ...props.defaultValues,\n },\n criteriaMode: 'all',\n });\n\n useEffect(() => {\n if (onInit && !isInit) {\n onInit(formFn);\n setIsInit(true);\n }\n }, [onInit, formFn, isInit]);\n\n const formatValuesForSubmit = useCallback(\n (values: any) => {\n const toRet: any = {};\n Object.keys(values).forEach((k) => {\n const widget = configuration.find((c) => c.name === k)?.widget;\n switch (widget?.type) {\n case 'audience':\n toRet[k] = values[k].map((v: AudienceAutocomplete) => v.uri).join(',');\n break;\n case 'taxonomy':\n toRet[k] = values[k].map((v: any) => v.title).join(',');\n break;\n case 'toggle':\n toRet[k] = values[k] ? '1' : '0';\n break;\n default:\n toRet[k] = values[k];\n break;\n }\n });\n return toRet;\n },\n [configuration],\n );\n\n useImperativeHandle(\n ref,\n () => ({\n ...formFn,\n handleSubmit,\n control,\n reset: () => {\n // in case the form is scrollable\n formRef?.current?.scrollTo(0, 0);\n // reset react-hook-form form\n reset();\n },\n getFormattedValues: () => {\n return formatValuesForSubmit(formFn.getValues());\n },\n }),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n [],\n );\n\n return (\n <FormElm\n dataCy={props.dataCy}\n stretch={props.stretch}\n onSubmit={props.onSubmit ? handleSubmit(props.onSubmit) : undefined}\n ref={formRef}>\n <FieldsetWrapper stretch={props.stretch}>\n {configuration.map(({ Input, ...conf }) => (\n <Input\n key={conf.name}\n control={control}\n {...conf}\n dataCy={`${props.dataCy}-${conf.name}`}\n readOnly={props.readOnly}\n />\n ))}\n {props.extraInputs && props.extraInputs(control)}\n </FieldsetWrapper>\n {props.buttons}\n </FormElm>\n );\n};\n\nexport const DisplayForm = forwardRef<DisplayFormRef>(_DisplayForm as any) as <TFieldValues extends FieldValues>(\n props: DisplayFormProps<TFieldValues> & {\n ref?: ForwardedRef<DisplayFormRef>;\n },\n) => ReturnType<typeof _DisplayForm>;\n","import { Toast } from 'jamespot-front-business';\r\nimport jApi, { ArticlesList, jCommentList } from 'jamespot-user-api';\r\nimport { useCallback, useEffect, useRef, useState } from 'react';\r\nimport { FormattedMessage, useIntl } from 'react-intl';\r\nimport styled from 'styled-components';\r\nimport { DisplayForm } from '../../displayer/DisplayForm.component';\r\nimport { DisplayFormRef } from '../../displayer/types';\r\nimport { useAbortController } from '../../hooks';\r\nimport { useAppDispatch } from '../../redux/store';\r\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\r\n\r\nconst ModalForm = commonComponentsRegistry.getLazyComponent('ModalForm');\r\nconst Loader = commonComponentsRegistry.getLazyComponent('Loader');\r\nconst Icon = commonComponentsRegistry.getLazyComponent('Icon');\r\nconst Typography = commonComponentsRegistry.getLazyComponent('Typography');\r\nconst Ellipsis = commonComponentsRegistry.getLazyComponent('Deprecated_Ellipsis');\r\nconst StyledHref = commonComponentsRegistry.getLazyComponent('StyledHref');\r\n\r\nconst Container = styled.div`\r\n display: flex;\r\n flex-direction: column;\r\n gap: ${({ theme }) => theme.space.md}px;\r\n`;\r\n\r\nconst ContentPreview = styled.div`\r\n display: flex;\r\n gap: ${({ theme }) => theme.space.md}px;\r\n align-items: center;\r\n border: 1px solid ${({ theme }) => theme.color.grey2};\r\n background-color: ${({ theme }) => theme.color.grey0};\r\n border-radius: ${({ theme }) => theme.size.sm}px;\r\n padding: ${({ theme }) => theme.space.md}px;\r\n`;\r\n\r\nconst ContentWrapper = styled.div`\r\n display: flex;\r\n flex-direction: column;\r\n gap: ${({ theme }) => theme.space.sm}px;\r\n`;\r\n\r\nexport type AddReportModalProps = {\r\n onClose: () => void;\r\n articleId: number;\r\n articleUri: string;\r\n commentUri: string;\r\n};\r\n\r\nexport const AddReportModal = ({ onClose, articleId, articleUri, commentUri }: AddReportModalProps) => {\r\n const intl = useIntl();\r\n const formRef = useRef<DisplayFormRef>(null);\r\n const dispatch = useAppDispatch();\r\n const [open, setOpen] = useState(true);\r\n const [article, setArticle] = useState<ArticlesList>();\r\n const [comment, setComment] = useState<jCommentList>();\r\n const [contentLoading, setContentLoading] = useState(true);\r\n const [submitLoading, setSubmitLoading] = useState(false);\r\n const abortController = useAbortController();\r\n\r\n useEffect(() => {\r\n Promise.all([\r\n (async () => {\r\n const res = await jApi.article.get(\r\n { idArticle: articleId },\r\n { signal: abortController.signal, format: 'raw-list' },\r\n );\r\n setArticle(res.result);\r\n })(),\r\n (async () => {\r\n if (commentUri) {\r\n const res = await jApi.article.getComments(\r\n { idArticle: articleId },\r\n {\r\n format: 'raw-list',\r\n signal: abortController.signal,\r\n },\r\n );\r\n setComment(res.result.find((c) => c.uri === commentUri));\r\n }\r\n })(),\r\n ]).then(() => {\r\n setContentLoading(false);\r\n });\r\n }, [abortController, articleId, commentUri]);\r\n\r\n const closeModal = useCallback(() => {\r\n setOpen(false);\r\n onClose();\r\n }, [onClose]);\r\n\r\n const submit = useCallback(\r\n (description?: string) => {\r\n if (!description?.trim()) {\r\n dispatch(\r\n Toast.actions.error({ label: intl.formatMessage({ id: 'CRPT_Report_Description_Required' }) }),\r\n );\r\n } else {\r\n setSubmitLoading(true);\r\n jApi.contentReport\r\n .createReport({\r\n uri: commentUri || articleUri,\r\n description: description,\r\n })\r\n .then(() => {\r\n dispatch(Toast.actions.success({ label: intl.formatMessage({ id: 'CRPT_Report_Sent' }) }));\r\n closeModal();\r\n })\r\n .catch((e) => {\r\n Toast.actions.error({ label: e.errorMsg ?? 'GLOBAL_Error' });\r\n setSubmitLoading(false);\r\n });\r\n }\r\n },\r\n [articleUri, closeModal, commentUri, dispatch, intl],\r\n );\r\n\r\n const submitForm = useCallback(\r\n ({ description }: { description: string }) => {\r\n submit(description);\r\n },\r\n [submit],\r\n );\r\n\r\n return (\r\n <ModalForm\r\n title={intl.formatMessage({ id: 'CRPT_Add_Report' })}\r\n open={open}\r\n closeHandler={closeModal}\r\n onSubmit={async () => submit(formRef.current?.getValues().description)}\r\n enableClickAwayCloseModal\r\n maxHeight={'520px'}\r\n buttons={[\r\n {\r\n children: <FormattedMessage id=\"GLOBAL_Cancel\" />,\r\n color: 'cancel',\r\n clickHandler: closeModal,\r\n },\r\n {\r\n children: <FormattedMessage id=\"GLOBAL_Send\" />,\r\n clickHandler: () => submit(formRef.current?.getValues().description),\r\n color: 'valid',\r\n loading: submitLoading,\r\n },\r\n ]}>\r\n {contentLoading ? (\r\n <Loader size={'l'} />\r\n ) : (\r\n <Container>\r\n <ContentPreview>\r\n <Icon name={commentUri ? 'icon-comment' : 'icon-file'} size={50} variant={'square'} />\r\n <ContentWrapper>\r\n <Typography variant={commentUri ? 'h3' : 'h2'}>\r\n <Ellipsis label={article?.title} length={40} />\r\n </Typography>\r\n {comment && (\r\n <Typography>\r\n {intl.formatMessage({ id: 'CRPT_Comment_Of' })}{' '}\r\n <StyledHref href={comment?._user._url}>{comment?._user.title}</StyledHref>\r\n </Typography>\r\n )}\r\n </ContentWrapper>\r\n </ContentPreview>\r\n <DisplayForm ref={formRef} fields={['description']} type=\"contentReport\" onSubmit={submitForm} />\r\n </Container>\r\n )}\r\n </ModalForm>\r\n );\r\n};\r\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 { 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 { 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 { 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 { 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 { 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 resolveFilePath,\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 weDoc = useAppSelector((state) => Application.selectors.selectById(state, 'WeDocHook'));\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 = weDoc\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 (\n <WidgetAttachment\n files={files.map((f) => ({\n ...f,\n uri: resolveFilePath(f),\n }))}\n onClick={(idFile) => open(idFile)}\n onError={onError}\n />\n );\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(\n updateWidgetContent<WidgetArticleAttachmentContent>(uniqid, {\n files: files.map((f) => ({\n ...f,\n uri: resolveFilePath(f) ?? '',\n })),\n }),\n );\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 { 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 { 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 { Widget } from 'jamespot-front-business';\n\nimport { shallowEqual } from 'react-redux';\nimport { useAppSelector } from '../../../../redux/store';\nimport styled from 'styled-components';\n\nexport const CSSWidgetTitle = styled.div`\n padding: ${(props) => props.theme.space.md}px;\n padding-right: 0px;\n`;\n\nexport const UITitle = styled.div<{ fontSize: string; fontWeight: string; textAlign: string; color: string }>`\n text-align: ${(props) => props.textAlign};\n font-size: ${(props) => props.fontSize}px;\n font-weight: ${(props) => props.fontWeight};\n color: ${(props) => props.color};\n`;\n\nexport const WidgetIntranetTitle = ({\n uniqid,\n textAlign = 'left',\n fontSize = '16',\n fontWeight = 'medium',\n color,\n}: {\n uniqid: string;\n textAlign: string;\n fontSize: string;\n fontWeight: string;\n color: string;\n}) => {\n const widgetWrapper = useAppSelector((state) => Widget.selectors.selectWidget(state, uniqid), shallowEqual);\n return (\n <>\n {widgetWrapper && typeof widgetWrapper.title === 'string' && widgetWrapper.title.length !== 0 && (\n <CSSWidgetTitle>\n <UITitle textAlign={textAlign} fontSize={fontSize} fontWeight={fontWeight} color={color}>\n {widgetWrapper.title}\n </UITitle>\n </CSSWidgetTitle>\n )}\n </>\n );\n};\n","import { Widget } from 'jamespot-front-business';\nimport { ReactNode, useMemo } from 'react';\nimport { shallowEqual } from 'react-redux';\n\nimport styled, { useTheme } from 'styled-components';\nimport { useAppSelector } from '../../../../redux/store';\nimport { WidgetIntranetTitle } from './WidgetIntranetTitle';\n\nexport const UIHeaderWrapper = styled.div<{ backroundColor: string }>`\n background-color: ${(props) => props.backroundColor};\n`;\n\nexport const UIHeader = styled.div`\n display: flex;\n flex-direction: row;\n align-items: center;\n`;\n\nexport const UICount = styled.div`\n padding: ${(props) => props.theme.space.sm}px ${(props) => props.theme.space.md}px;\n color: ${(props) => props.theme.color.grey4};\n`;\n\nexport const UIHeaderFlex = styled.div`\n flex: 1;\n display: flex;\n flex-direction: row;\n gap: ${(props) => props.theme.space.xs}px;\n align-items: center;\n`;\n\nexport const WidgetHeader = ({\n uniqid,\n dropdown,\n subHeader,\n}: {\n uniqid: string;\n dropdown?: () => ReactNode;\n subHeader?: (color: string) => ReactNode;\n}) => {\n const theme = useTheme();\n const styles = useAppSelector((state) => Widget.selectors.selectWidgetTitleStyle(state, uniqid), shallowEqual);\n\n const styleValues = useMemo(() => {\n return {\n color: styles && styles['color'] ? String(styles['color']) : theme.color.black,\n backgroundColor: styles && styles['background-color'] ? String(styles['background-color']) : 'transparent',\n fontSize: styles && styles['font-size'] ? String(styles['font-size']) : '16',\n fontWeight: styles && styles['font-weight'] ? String(styles['font-weight']) : 'medium',\n textAlign: styles && styles['text-align'] ? String(styles['text-align']) : 'left',\n };\n }, [styles, theme]);\n\n return (\n <UIHeaderWrapper backroundColor={styleValues.backgroundColor}>\n <UIHeader>\n <UIHeaderFlex>\n <WidgetIntranetTitle\n uniqid={uniqid}\n fontWeight={styleValues.fontWeight}\n fontSize={styleValues.fontSize}\n textAlign={styleValues.textAlign}\n color={styleValues.color}\n />\n {subHeader && subHeader(styleValues.color)}\n </UIHeaderFlex>\n {dropdown && dropdown()}\n </UIHeader>\n </UIHeaderWrapper>\n );\n};\n","import { ReactNode } 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?: () => ReactNode;\n scrollable?: () => ReactNode;\n footer?: () => 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 { ReactNode, 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 display: flex;\n flex-direction: column;\n`;\n\nexport const WidgetStylePadding = ({ uniqid, children }: { uniqid: string; children: ReactNode }) => {\n const styles = useAppSelector((state) => Widget.selectors.selectWidgetWrapperStyle(state, uniqid), shallowEqual);\n\n const initialValues = useMemo(() => {\n return {\n padding: styles && styles['padding'] ? `${styles['padding']}px` : '0px',\n };\n }, [styles]);\n\n return <UIWrapper style={{ padding: initialValues.padding }}>{children}</UIWrapper>;\n};\n","import jamespot, { WidgetLuccaAbsenceUser } from 'jamespot-user-api';\nimport { useEffect, useMemo, useState } from 'react';\nimport { FormattedMessage } from 'react-intl';\nimport styled from 'styled-components';\nimport { useAbortController } from '../../../hooks';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { WidgetHeader } from './components/WidgetHeader';\nimport { WidgetScroll } from './components/WidgetScroll';\nimport { WidgetStylePadding } from './components/WidgetStylePadding';\n\nexport const UIOverlay = styled.div`\n position: absolute;\n inset: 0;\n display: flex;\n justify-content: center;\n align-items: center;\n`;\n\nconst WidgetLuccaAbsence = commonComponentsRegistry.getLazyComponent('WidgetLuccaAbsence');\nconst JRCLoader = commonComponentsRegistry.getLazyComponent('Loader');\n\nexport const JRCWidgetLuccaAbsenceWrapper = ({ uniqid }: { uniqid: string }) => {\n const [list, setList] = useState<WidgetLuccaAbsenceUser[]>([]);\n const [error, setError] = useState(false);\n const [isLoading, setIsLoading] = useState(true);\n\n const abortController = useAbortController();\n\n const today = useMemo(() => {\n return (\n new Date().getFullYear() +\n '-' +\n (new Date().getMonth() + 1).toString().padStart(2, '0') +\n '-' +\n new Date().getDate().toString().padStart(2, '0') +\n ' 00:00:00'\n );\n }, []);\n\n useEffect(() => {\n jamespot.lucca\n .getAbsence({ date: today }, { signal: abortController.signal })\n .then(({ result }) => setList(result))\n .catch(() => {\n if (!abortController.signal.aborted) {\n setError(true);\n }\n })\n .finally(() => setIsLoading(false));\n }, [today, abortController.signal]);\n\n if (isLoading) {\n return (\n <UIOverlay>\n <JRCLoader size={'m'} />\n </UIOverlay>\n );\n }\n\n if (error) {\n return (\n <UIOverlay>\n <FormattedMessage id={'WIDGET_Lucca_Absence_Url_Error'} />\n </UIOverlay>\n );\n }\n\n return (\n <WidgetScroll\n header={() => {\n return <WidgetHeader uniqid={uniqid} />;\n }}\n scrollable={() => {\n return (\n <WidgetStylePadding uniqid={uniqid}>\n <WidgetLuccaAbsence list={list} />\n </WidgetStylePadding>\n );\n }}\n />\n );\n};\n","import { 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 <FileViewer\n files={[\n {\n ...mockFileLittle,\n ...file,\n path: uri,\n mimetype: 'image/png',\n },\n ]}\n openWithOptions={[]}>\n {(open) => {\n return (\n <CSSImagePointer onClick={() => open(file?.id ?? 0)}>\n <WidgetImage maxWidth={width ?? 600} uri={uri} useFilter={useFilter ?? false} />\n </CSSImagePointer>\n );\n }}\n </FileViewer>\n )}\n\n {mode === 'edit' && (\n <>\n {uri !== undefined && (\n <WidgetImage maxWidth={width ?? 600} uri={uri} useFilter={useFilter ?? false} />\n )}\n {inplace && (\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(\n updateWidgetContent<WidgetArticleImageContent>(uniqid, { file: files[0] }),\n );\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 { 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:\n slide.file && slide.file.uri\n ? formatImgUrl({\n size: 'fitx1200',\n uri: 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 : [],\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 { 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 jApi, { WidgetArticleTextContent, WidgetArticleTextType, WidgetDisplayMode } from 'jamespot-user-api';\nimport { 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 handlers={{ file: jApi.file }}\n />\n {isMarkdownActive && <MarkdownModal onInsert={onInsert} open={open} close={closeMarkdownModal} />}\n </CSSTextWrapper>\n );\n};\n","import { useEffect } from 'react';\nimport { shallowEqual } from 'react-redux';\nimport { WidgetArticleTitleContent, WidgetArticleTitleType, WidgetDisplayMode } from 'jamespot-user-api';\nimport { Widget, updateWidgetContent } from 'jamespot-front-business';\nimport styled from 'styled-components';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { useAppDispatch, useAppSelector } from '../../../redux/store';\n\nconst WidgetArticleTitle = commonComponentsRegistry.getLazyComponent('WidgetArticleTitle');\n\nconst CSSTextWrapper = styled.div`\n flex: 1;\n display: flex;\n flex-direction: row;\n align-items: center;\n cursor: text;\n`;\n\nconst ToolWrapper = styled.div`\n display: flex;\n flex-direction: row;\n border-radius: 8px;\n overflow: hidden;\n margin: 4px;\n border: 1px solid ${(props) => props.theme.color.grey1};\n`;\n\nconst Tool = styled.button<{ isActive: boolean }>`\n display: flex;\n width: 40px;\n height: 40px;\n justify-content: center;\n align-items: center;\n cursor: pointer;\n opacity: ${(props) => (props.isActive ? '1.0' : '.8')};\n background-color: ${(props) => (props.isActive ? props.theme.color.grey1 : props.theme.color.white)};\n &:hover {\n background-color: ${(props) => props.theme.color.grey1};\n }\n`;\n\nexport const JRCWidgetArticleTitleWrapper = ({\n widget,\n inplace,\n mode,\n dataCy,\n}: {\n widget: WidgetArticleTitleType;\n inplace: boolean;\n mode?: WidgetDisplayMode;\n dataCy?: string;\n}) => {\n const { uniqid } = widget;\n const { text, color, heading } = widget.content;\n const dispatch = useAppDispatch();\n const isActive = useAppSelector((state) => Widget.selectors.isActive(state, uniqid), shallowEqual);\n\n useEffect(() => {\n dispatch(\n Widget.slice.actions.setWidgetState({\n uniqid,\n empty: !text || text.length === 0,\n }),\n );\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [text]);\n\n return (\n <CSSTextWrapper>\n <WidgetArticleTitle\n dataCy={dataCy}\n text={text}\n color={color}\n heading={heading}\n autoFocus={isActive}\n inplace={inplace}\n mode={mode}\n onChange={(text) => {\n dispatch(updateWidgetContent<WidgetArticleTitleContent>(uniqid, { text }));\n }}\n />\n {isActive && mode === 'edit' ? (\n <Toolbar\n heading={heading}\n onClick={(heading) => {\n dispatch(updateWidgetContent<WidgetArticleTitleContent>(uniqid, { heading }));\n }}\n />\n ) : (\n <></>\n )}\n </CSSTextWrapper>\n );\n};\n\nexport const Toolbar = ({ heading = 'h1', onClick }: { heading?: string; onClick: (size: string) => void }) => {\n const sizes: string[] = ['h1', 'h2', 'h3', 'h4'];\n return (\n <ToolWrapper>\n {sizes.map((sizeValue, index: number) => (\n <Tool key={index} isActive={heading === sizeValue} onClick={() => onClick(sizeValue)}>\n {sizeValue}\n </Tool>\n ))}\n </ToolWrapper>\n );\n};\n","import { Toast, Widget } from 'jamespot-front-business';\nimport jamespot from 'jamespot-user-api';\nimport { useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport styled from 'styled-components';\nimport { useAppDispatch } from '../../../../redux/store';\nimport { commonComponentsRegistry } from '../../../../registry/CommonRegistry';\n\nconst JRCButton = commonComponentsRegistry.getLazyComponent('Button');\nconst JRCModalLayout = commonComponentsRegistry.getLazyComponent('ModalLayout');\nconst JRCModalContent = commonComponentsRegistry.getLazyComponent('ModalContent');\nconst JRCIconButton = commonComponentsRegistry.getLazyComponent('IconButton');\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 { 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 { useEffect, useState } from 'react';\nimport { useForm } from 'react-hook-form';\nimport { useIntl } from 'react-intl';\nimport styled from 'styled-components';\nimport { useAppDispatch } from '../../../../redux/store';\nimport { commonComponentsRegistry } from '../../../../registry/CommonRegistry';\n\nconst JRCButton = commonComponentsRegistry.getLazyComponent('Button');\nconst JRCInputText = commonComponentsRegistry.getLazyComponent('InputText');\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 styled from 'styled-components';\nimport { commonComponentsRegistry } from '../../../../registry/CommonRegistry';\n\nconst JRCLoader = commonComponentsRegistry.getLazyComponent('Loader');\n\nexport const Wrapper = styled.div`\n position: absolute;\n inset: 0;\n display: flex;\n justify-content: center;\n align-items: center;\n background-color: rgba(255, 255, 255, 0.4);\n`;\n\nexport const WidgetIsPending = () => {\n return (\n <Wrapper>\n <JRCLoader size={'m'} />\n </Wrapper>\n );\n};\n","import { Toast, updateWidgetContent, Widget, WidgetEditor } from 'jamespot-front-business';\nimport { 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 { useCallback, useEffect, useMemo, useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport { shallowEqual } from 'react-redux';\nimport styled from 'styled-components';\nimport { useAppDispatch, useAppSelector } from '../../../redux/store';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { RTProvider } from '../../RTProvider.component';\nimport { useWidgetRT } from '../hooks';\nimport { WidgetFooterView } from './components/WidgetFooterView';\nimport { WidgetInlineInputText } from './components/WidgetInlineInputText';\nimport { WidgetIsPending } from './components/WidgetIsPending';\n\nconst WidgetCheckList = commonComponentsRegistry.getLazyComponent('WidgetCheckList');\nconst WidgetCheckListEditor = commonComponentsRegistry.getLazyComponent('WidgetCheckListEditor');\nconst JRCFileViewer = commonComponentsRegistry.getLazyComponent('FileViewer');\n\nexport const CSSRowLinkWrapper = styled.div<{ border?: boolean }>`\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n align-items: center;\n border: ${(props) => (props.border ? `1px solid ${props.theme.color.grey2}` : 'none')};\n min-height: 24px;\n border-radius: 4px;\n padding: 4px 8px;\n`;\n\nconst CommentContainer = styled.div`\n width: 100%;\n display: flex;\n gap: 14px;\n padding: 16px;\n`;\n\nexport const CSSWidgetCheckListWrapper = styled.div`\n position: relative;\n`;\n\ntype JRCWidgetCheckListWrapperProps = {\n widget: WidgetCheckListType;\n inplace: boolean;\n mode?: WidgetDisplayMode;\n onWidgetUpdate?: () => void;\n};\n\nexport const JRCWidgetCheckListWrapper = ({\n widget,\n inplace,\n mode,\n onWidgetUpdate,\n}: JRCWidgetCheckListWrapperProps) => {\n const intl = useIntl();\n const { uniqid, content: widgetContent } = widget;\n const dispatch = useAppDispatch();\n const [token, setToken] = useState<string>();\n const [tokenLoading, setTokenLoading] = useState(false);\n\n const [entries, setEntries] = useState<JRCWidgetCheckListEntries | undefined>();\n const [isPending, setIsPending] = useState(false);\n\n const tokenFromStore = useAppSelector(Widget.selectors.selectToken, shallowEqual);\n\n const uri = useAppSelector((state) => Widget.selectors.selectWidgetObjectUri(state, widget.uniqid), shallowEqual);\n\n const widgetObjectRights = useAppSelector(\n (state) => Widget.selectors.selectWidgetObjectRights(state, uniqid),\n shallowEqual,\n );\n\n const allRt = useAppSelector(\n (state) => Widget.selectors.selectAllWidgetRTObject(state, widget.uniqid),\n shallowEqual,\n );\n\n const canEditCollaboration = useMemo(() => {\n return widgetObjectRights && widgetObjectRights.update;\n }, [widgetObjectRights]);\n\n const canAdministrate = useMemo(() => {\n return widgetObjectRights && widgetObjectRights.administrate;\n }, [widgetObjectRights]);\n\n const onError = useCallback(\n (message?: string) => {\n dispatch(Toast.actions.error({ label: message ?? intl.formatMessage({ id: 'GLOBAL_Error' }) }));\n },\n [dispatch, intl],\n );\n\n const fetchToken = useCallback(() => {\n if (!token && !tokenLoading) {\n setTokenLoading(true);\n jApi.network\n .token()\n .then((res) => {\n setToken(res.result);\n setTokenLoading(false);\n\n // set comment token to our widget slice to be able to upload image inside our widgets\n dispatch(Widget.slice.actions.setToken({ token: res.result }));\n })\n .catch((e) => {\n onError(e.errorMsg);\n });\n }\n }, [onError, token, tokenLoading, dispatch]);\n\n if (!tokenFromStore) {\n fetchToken();\n } else if (!token) {\n setToken(tokenFromStore);\n }\n\n const onChange = useCallback(\n (uniqid: string, content: WidgetCheckListContent) => {\n dispatch(updateWidgetContent(uniqid, content));\n },\n [dispatch],\n );\n\n const onChangeWrapper = (content: { uniqid: string; title?: string }) => {\n dispatch(Widget.slice.actions.updateWidgetWrapper({ ...content }));\n };\n\n const handleCheckItem = (id: string, index: number) => {\n if (!uri) return;\n if (isPending) return;\n setIsPending(true);\n jApi.widget\n .checkListRespond({\n uri,\n uniqid: id,\n index: index,\n })\n .then(() => {\n if (onWidgetUpdate) onWidgetUpdate();\n })\n .catch((err) => {\n onError(err.message);\n setIsPending(false);\n });\n };\n\n const handleReloadWidget = useCallback(() => {\n if (!uri) return;\n setIsPending(true);\n jApi.widget\n .getWidget<WidgetCheckListType>({ uri, uniqid })\n .then((response) => {\n if (ensureWidgetCheckListType(response.result)) {\n onChange(uniqid, response.result.content);\n }\n })\n .catch((err) => {\n return !err.aborted && onError;\n })\n .finally(() => setIsPending(false));\n }, [uniqid, onError, uri, onChange]);\n\n const openEditorPanel = (token: string) => {\n dispatch(WidgetEditor.slice.actions.flushAllEditor());\n dispatch(Widget.slice.actions.setToken({ token }));\n dispatch(\n WidgetEditor.slice.actions.registerEditor({\n uniqid: widget.uniqid,\n name: WidgetsName.CheckList,\n mode,\n }),\n );\n };\n\n useEffect(() => {\n if (!token && mode === 'edit') {\n jApi.network.token().then((response) => {\n dispatch(Widget.slice.actions.setToken({ token: response.result }));\n });\n }\n }, [mode, token, dispatch]);\n\n useEffect(() => {\n const finalEntries: JRCWidgetCheckListEntries | undefined = widget.content.arr?.map((item) => ({\n text: item.title ?? '',\n file: item.file ?? undefined,\n checked: item.value ?? false,\n ...(item.links && {\n links: item.links,\n }),\n ...(item.user && { user: item.user ?? undefined }),\n ...(item.id && { id: item.id, mimetype: 'image/png' }),\n }));\n\n setEntries(finalEntries);\n }, [widget.content.arr, widgetContent]);\n\n useEffect(() => {\n if (!Array.isArray(allRt)) return;\n const lastRt = allRt.at(-1);\n if (!lastRt) return;\n if (!uri) return;\n\n if (lastRt.object.uri === uri && lastRt.uniqid === widget.uniqid) {\n if (lastRt.fn === 'check-list-response' || lastRt.fn === 'widget-update') {\n handleReloadWidget();\n }\n }\n }, [allRt, widget.uniqid, uri, onError, dispatch, handleReloadWidget]);\n\n const handleCollabAddEntry = (label: string) => {\n if (!widget.content.arr || !uri) return;\n\n const contentToUpdate = {\n ...widget.content,\n arr: [...widget.content.arr, { title: label, value: false }],\n };\n\n jApi.widget\n .updateWidget<CombinedWidgetContent>({\n uri,\n uniqid: widget.uniqid,\n content: contentToUpdate as CombinedWidgetContent,\n v2: true,\n })\n .then(() => onChange(widget.uniqid, contentToUpdate))\n .catch((err) => onError(err.errorMsg));\n };\n\n const files = useMemo(() => {\n if (!Array.isArray(widgetContent.arr)) return [];\n\n const fs: jFileLittle[] = [];\n widgetContent.arr.forEach((el) => {\n if (el.file) {\n fs.push(el.file);\n }\n });\n\n return fs;\n }, [widgetContent]);\n\n if (mode === 'edit') {\n if (inplace) {\n return (\n <CommentContainer>\n <WidgetCheckListEditor\n token={token}\n uniqid={uniqid}\n content={{\n ...widgetContent,\n arr: widgetContent.arr?.map((w) => ({\n ...w,\n title: Utils.html.htmlDecodeSpecialChars(w.title),\n })),\n }}\n inplace={inplace}\n onChangeContent={onChange}\n onChangeWrapper={onChangeWrapper}\n handleChange={(content) =>\n dispatch(updateWidgetContent<WidgetCheckListContent>(widget.uniqid, content))\n }\n />\n </CommentContainer>\n );\n }\n }\n\n return (\n <RTProvider\n useRT={() => {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useWidgetRT(widget.uniqid);\n }}>\n {entries && (\n <JRCFileViewer files={files} openWithOptions={[]}>\n {(open) => {\n return (\n <CSSWidgetCheckListWrapper key={widget.uniqid}>\n <WidgetCheckList\n limit={10}\n initialEntries={entries}\n onFileClick={(entry) => entry.id && open(entry.id)}\n onItemCheckListChange={(index) => handleCheckItem(widget.uniqid, index)}\n />\n {widgetContent.edit && (\n <WidgetInlineInputText\n handleClick={handleCollabAddEntry}\n placeholder={intl.formatMessage({\n id: 'COMMENT_WIDGET_CHECKLIST_Add_New_Task',\n })}\n />\n )}\n {canAdministrate && token && (\n <WidgetFooterView\n uniqid={widget.uniqid}\n name={widget.name}\n collaborationRights={{\n update: !!(widgetContent.edit || canEditCollaboration),\n }}\n mode={mode}\n handleOpenEditor={() => {\n if (!token) {\n setIsPending(true);\n jApi.network\n .token()\n .then((response) => {\n dispatch(\n Widget.slice.actions.setToken({ token: response.result }),\n );\n openEditorPanel(response.result);\n })\n .finally(() => setIsPending(false));\n } else {\n openEditorPanel(token);\n }\n }}\n />\n )}\n {isPending && <WidgetIsPending />}\n </CSSWidgetCheckListWrapper>\n );\n }}\n </JRCFileViewer>\n )}\n </RTProvider>\n );\n};\n","import { WidgetTableColumn, WidgetTableColumnsData } from 'jamespot-user-api';\n\nexport const getVisibleColumns = (tableColumnsData: WidgetTableColumnsData, columns: WidgetTableColumn[]) => {\n const toRet: WidgetTableColumn[] = [];\n tableColumnsData\n .filter((data) => data.isVisible)\n .forEach((data) => {\n const column = columns.find((el) => el.name === data.name);\n if (column) {\n toRet.push(column);\n }\n });\n\n return toRet;\n};\n","import { useCallback, useEffect, useMemo, useState } from 'react';\nimport { 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 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 WidgetDatasourceTableWrapper = ({\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 dispatch = useAppDispatch();\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 useEffect(() => {\n if (mode === 'view' || mode === 'preview') {\n dispatch(WidgetEditor.slice.actions.flushAllEditor());\n }\n }, [mode, dispatch]);\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>\n <img src={`/img/fast-intranet/${WidgetsName.DatasourceTable}.png`} alt=\"\" />\n <FormattedMessage id={definition.label} />\n <JRCButton label=\"GLOBAL_Settings\" />\n </AbsoluteWrapper>\n </>\n );\n }\n\n return isLoading ? (\n <AbsoluteWrapper>\n <Loader />\n </AbsoluteWrapper>\n ) : (\n <>\n {!isLoading && datasourceData.length === 0 && mode !== 'edit' ? (\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 </>\n );\n};\n","import { useEffect, useMemo, useState } from 'react';\nimport { 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');\n\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 WidgetExcelDatasourceTableWrapper = ({\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 dispatch = useAppDispatch();\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 useEffect(() => {\n if (mode === 'view' || mode === 'preview') {\n dispatch(WidgetEditor.slice.actions.flushAllEditor());\n }\n }, [mode, dispatch]);\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>\n <img src={`/img/fast-intranet/${WidgetsName.ExcelDatasourceTable}.png`} alt=\"\" />\n <FormattedMessage id={definition.label} />\n <JRCButton label=\"GLOBAL_Settings\" />\n </AbsoluteWrapper>\n </>\n );\n }\n\n return isLoading ? (\n <AbsoluteWrapper>\n <Loader />\n </AbsoluteWrapper>\n ) : (\n <>\n {!isLoading && datasourceData.length === 0 && mode !== 'edit' ? (\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 </>\n );\n};\n","import { 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 { 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 { 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 { 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');\nconst JRCFileViewer = commonComponentsRegistry.getLazyComponent('FileViewer');\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 { WidgetUserProfileType, WidgetDisplayMode } from 'jamespot-user-api';\nimport { UserCurrent, Widget, WidgetEditor } from 'jamespot-front-business';\n\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { useAppDispatch, useAppSelector } from '../../../redux/store';\nimport { useEffect } from 'react';\n\nconst WidgetUserProfile = commonComponentsRegistry.getLazyComponent('WidgetUserProfile');\n\ntype JRCWidgetUserProfileWrapperProps = {\n widget: WidgetUserProfileType;\n inplace: boolean;\n mode?: WidgetDisplayMode;\n};\n\nexport const JRCWidgetUserProfileWrapper = ({ widget, mode }: JRCWidgetUserProfileWrapperProps) => {\n const dispatch = useAppDispatch();\n const { uniqid, name, content } = widget;\n\n const currentUser = useAppSelector(UserCurrent.selectors.get);\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 if (mode === 'edit') {\n dispatch(WidgetEditor.slice.actions.flushAllEditor());\n dispatch(WidgetEditor.slice.actions.registerEditor({ uniqid, name }));\n }\n }, [dispatch, mode, name, uniqid]);\n\n useEffect(() => {\n if (mode === 'view' || mode === 'preview') {\n dispatch(WidgetEditor.slice.actions.flushAllEditor());\n }\n }, [mode, dispatch]);\n\n return (\n <WidgetUserProfile\n currentUser={currentUser}\n pictureSize={content.pictureSize}\n displayMode={content.buttonName}\n css={content.css}\n />\n );\n};\n","import { Toast } from 'jamespot-front-business';\nimport { useAbortController } from 'jamespot-react-components';\nimport jApi, {\n ImapConnection,\n OfficeProvider,\n OfficeSetConfigurationPayload,\n ValueOf,\n WidgetDisplayMode,\n WidgetEmailsImapType,\n} from 'jamespot-user-api';\nimport { useCallback, useEffect, useMemo, useState } from 'react';\nimport { useForm } from 'react-hook-form';\nimport { FormattedMessage, useIntl } from 'react-intl';\nimport styled from 'styled-components';\nimport { useAppDispatch } from '../../../../redux/store';\nimport { commonComponentsRegistry } from '../../../../registry/CommonRegistry';\n\nconst ModalLayout = commonComponentsRegistry.getLazyComponent('ModalLayout');\nconst ModalContent = commonComponentsRegistry.getLazyComponent('ModalContent');\nconst Button = commonComponentsRegistry.getLazyComponent('Button');\nconst InputText = commonComponentsRegistry.getLazyComponent('InputText');\nconst InputNumber = commonComponentsRegistry.getLazyComponent('InputNumber');\nconst InputSelectExtended = commonComponentsRegistry.getLazyComponent('InputSelectExtended');\nconst InputPassword = commonComponentsRegistry.getLazyComponent('InputPassword');\nconst Typography = commonComponentsRegistry.getLazyComponent('Typography');\nconst JRCLoader = commonComponentsRegistry.getLazyComponent('Loader');\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 const UISection = styled.div`\n margin-bottom: ${(props) => props.theme.space.md}px;\n`;\n\nexport type JRCWidgetEmailsImapProps = {\n widget: WidgetEmailsImapType;\n inplace: boolean;\n mode?: WidgetDisplayMode;\n};\n\nexport const officeConfigurationInitialState = {\n username: '',\n password: '',\n hostname: '',\n imapPort: 993,\n imapConnectionSecurity: ImapConnection.NONE,\n imapMailbox: '',\n cardDavAddressBook: '',\n calDavCalendar: '',\n provider: '',\n};\n\nexport const OfficeConfigurationPrompt = () => {\n const intl = useIntl();\n const dispatch = useAppDispatch();\n const abortController = useAbortController();\n const [isOpen, setIsOpen] = useState<boolean>(false);\n const [isPending, setIsPending] = useState<boolean>(false);\n const {\n control,\n reset,\n setValue,\n getValues,\n watch,\n formState: { isValid },\n } = useForm<OfficeSetConfigurationPayload>({\n defaultValues: officeConfigurationInitialState,\n criteriaMode: 'all',\n });\n\n const refresh = () => window.location.reload();\n const [providerList, setProviderList] = useState<OfficeProvider[]>([]);\n const data = watch();\n\n const imapConnectionSecurityOptions = [\n { label: 'NONE', value: ImapConnection.NONE },\n { label: 'SSL', value: ImapConnection.SSL },\n { label: 'STARTTLS', value: ImapConnection.STARTTLS },\n ];\n\n const fetchConfiguration = useCallback(\n (providers: string[]) => {\n jApi.office.getConfiguration().then(({ result }) => {\n reset({\n ...result,\n provider: !providers.includes(result.provider ?? '') ? providers[0] : result.provider,\n });\n });\n },\n [reset],\n );\n\n const handleSubmit = () => {\n if (isPending) return;\n setIsPending(true);\n jApi.office\n .setConfiguration(data)\n .then(() => refresh())\n .catch((err) => dispatch(Toast.actions.error({ label: err.errorMsg })))\n .finally(() => {\n setIsOpen(false);\n setIsPending(false);\n reset();\n });\n };\n\n useEffect(() => {\n if (!isOpen) return;\n setIsPending(true);\n jApi.office\n .getProviders({ signal: abortController.signal })\n .then(({ result }) => {\n if (!abortController.signal.aborted) {\n setProviderList(result);\n fetchConfiguration(result.map((provider) => provider.id));\n }\n })\n .catch((err) => {\n if (!abortController.signal.aborted) {\n dispatch(Toast.actions.error({ label: err.errorMsg }));\n }\n })\n .finally(() => {\n setIsPending(false);\n });\n }, [isOpen, abortController.signal, dispatch, fetchConfiguration]);\n\n useEffect(() => {\n if (providerList.length === 1) {\n setValue('provider', providerList[0].id);\n }\n }, [providerList, setValue]);\n\n const handleClose = () => setIsOpen(false);\n\n const hasProvider = useMemo(() => providerList.length > 1, [providerList]);\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 {hasProvider && (\n <>\n <UISection>\n <Typography size={'l'}>\n <FormattedMessage id=\"OfficeHook_Conf_Provider\" />\n </Typography>\n <SelectProvider\n label=\"OfficeHook_Conf_Select_Provider\"\n initialValue={{\n label: providerList[0].label,\n value: providerList[0].id,\n }}\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 </UISection>\n </>\n )}\n <UISection>\n <Typography size={'l'}>\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 </UISection>\n <UISection>\n <Typography size={'l'}>\n <FormattedMessage id=\"OfficeHook_Conf_IMap_Mailbox\" />\n </Typography>\n <InputNumber\n control={control}\n name={'imapPort'}\n width={'400'}\n placeholder={intl.formatMessage({ id: 'OfficeHook_Conf_IMap_Port' })}\n rules={{ required: true }}\n />\n <SelectProvider\n label=\"OfficeHook_Conf_Select_Connection_Security\"\n initialValue={imapConnectionSecurityOptions[0]}\n options={imapConnectionSecurityOptions}\n handleChange={(value) =>\n setValue('imapConnectionSecurity', value as ValueOf<typeof ImapConnection>)\n }\n />\n <InputText\n control={control}\n name={'imapMailbox'}\n width={'400'}\n placeholder={intl.formatMessage({ id: 'OfficeHook_Conf_IMap_Mailbox' })}\n rules={{ required: true }}\n />\n </UISection>\n <UISection>\n <Typography size={'l'}>\n <FormattedMessage id=\"OfficeHook_Conf_CalDav_Calendar\" />\n </Typography>\n <InputText\n control={control}\n name={'calDavCalendar'}\n width={'400'}\n placeholder={intl.formatMessage({ id: 'OfficeHook_Conf_CalDav_Calendar' })}\n rules={{ required: true }}\n />\n </UISection>\n <UISection>\n <Typography size={'l'}>\n <FormattedMessage id=\"OfficeHook_Conf_CardDav_Address_Book\" />\n </Typography>\n <InputText\n control={control}\n name={'cardDavAddressBook'}\n width={'400'}\n placeholder={intl.formatMessage({ id: 'OfficeHook_Conf_CardDav_Address_Book' })}\n rules={{ required: true }}\n />\n </UISection>\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 <InputSelectExtended\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 jApi from 'jamespot-user-api';\n\nimport styled from 'styled-components';\nimport { JRCButtonDropdownOptionProps } from 'jamespot-react-components';\nimport { officeConfigurationInitialState } from '../components/OfficeConfigurationPrompt';\n\nimport { useIntl } from 'react-intl';\nimport { useDispatch } from 'react-redux';\nimport { Widget } from 'jamespot-front-business';\nimport { commonComponentsRegistry } from '../../../../registry/CommonRegistry';\nimport { WidgetHeader } from '../components/WidgetHeader';\n\nconst ButtonDropdown = commonComponentsRegistry.getLazyComponent('ButtonDropdown');\nconst Tooltip = commonComponentsRegistry.getLazyComponent('Tooltip');\n\nexport const UIDropdown = styled.div`\n margin-right: ${(props) => props.theme.space.sm}px;\n button {\n background: ${(props) => props.theme.color.white};\n }\n`;\n\nexport const WidgetContactCardDavHeader = ({\n uniqid,\n isConfigurationValid = false,\n handleLogout,\n}: {\n uniqid: string;\n isConfigurationValid: boolean;\n handleLogout: () => void;\n}) => {\n const intl = useIntl();\n const dispatch = useDispatch();\n const onLogout = () => {\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, loading: true }));\n jApi.office.setConfiguration(officeConfigurationInitialState).finally(handleLogout);\n };\n\n const options: JRCButtonDropdownOptionProps[] = [\n { label: intl.formatMessage({ id: 'WIDGET_Prompt_Logout' }), onClick: onLogout },\n ];\n\n return (\n <WidgetHeader\n uniqid={uniqid}\n dropdown={() => {\n return (\n isConfigurationValid && (\n <UIDropdown>\n <Tooltip\n position={'left'}\n description={intl.formatMessage({ id: 'WIDGET_Prompt_Dropdown' })}>\n <ButtonDropdown\n small\n smallOpenDirection=\"left\"\n options={options}\n icon={'icon-cogwheel'}\n label={''}\n color=\"primary\"\n variant=\"outlined\"\n />\n </Tooltip>\n </UIDropdown>\n )\n );\n }}\n />\n );\n};\n","import jApi, {\n DavAddressBookContact,\n WIDGET_LEVEL_1,\n WIDGET_LEVEL_3,\n WidgetContactCardDavType,\n WidgetDisplayMode,\n WidgetWrapperLevel,\n} from 'jamespot-user-api';\nimport { Toast, Widget } from 'jamespot-front-business';\nimport { ReactNode, useCallback, useEffect, useState } from 'react';\nimport { shallowEqual } from 'react-redux';\nimport { officeConfigurationInitialState, OfficeConfigurationPrompt } from './components/OfficeConfigurationPrompt';\nimport { WidgetContactCardDavHeader } from './WidgetContactCardDav/WidgetContactCardDavHeader';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { WidgetScroll } from './components/WidgetScroll';\nimport { WidgetStylePadding } from './components/WidgetStylePadding';\nimport { useAppSelector, useAppDispatch } from '../../../redux/store';\n\nconst WidgetContactCardDav = commonComponentsRegistry.getLazyComponent('WidgetContactCardDav');\n\nexport type JRCWidgetContactCardDavProps = {\n widget: WidgetContactCardDavType;\n inplace: boolean;\n mode?: WidgetDisplayMode;\n levelFallback?: (level: WidgetWrapperLevel, url: string) => ReactNode | undefined;\n};\n\nconst REFRESH_INTERVAL = 4000;\n\nexport const JRCWidgetContactCardDavWrapper = ({ widget, mode, levelFallback }: JRCWidgetContactCardDavProps) => {\n const { uniqid } = widget;\n const dispatch = useAppDispatch();\n const [isConfigurationValid, setIsConfigurationValid] = useState<boolean | undefined>(undefined);\n const [url, setUrl] = useState<string | undefined>(undefined);\n const [doInterval, setDoInterval] = useState<boolean>(false);\n const level = useAppSelector((state) => Widget.selectors.selectWidgetLevel(state, uniqid), shallowEqual);\n const [list, setList] = useState<DavAddressBookContact[]>([]);\n\n const handleLogout = useCallback(\n (err?: any, reload?: boolean) => {\n if (err && err.error === 400) {\n jApi.office.setConfiguration(officeConfigurationInitialState);\n }\n if (reload) {\n window.location.reload();\n return;\n }\n\n setIsConfigurationValid(false);\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, initialized: true, loading: false }));\n },\n [dispatch, uniqid],\n );\n\n const handleLogin = useCallback(\n (isValid: boolean) => {\n setIsConfigurationValid(isValid);\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, initialized: true }));\n },\n [dispatch, uniqid],\n );\n\n const handleLoading = useCallback(\n (loading: boolean) => dispatch(Widget.slice.actions.setWidgetState({ uniqid, loading })),\n [uniqid, dispatch],\n );\n\n const fetchProviderUrls = useCallback(() => {\n jApi.office\n .getProviderBaseUrls()\n .then(({ result }) => {\n setUrl(result.dav_address_book_url);\n })\n .finally(() => handleLoading(false));\n }, [handleLoading]);\n\n const fetchData = useCallback(() => {\n jApi.office\n .davAddressBookGetContacts({ limit: 10 })\n .then(({ result }) => {\n setList(result);\n setDoInterval(true);\n })\n .catch(() => {\n dispatch(Toast.actions.error({ label: 'PLUGIN_Manager_Connection_Error' }));\n setIsConfigurationValid(false);\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, initialized: true, loading: false }));\n })\n .finally(() => handleLoading(false));\n }, [handleLoading, dispatch, uniqid]);\n\n useEffect(() => {\n if (!doInterval) return;\n if (!isConfigurationValid) return;\n if (level !== WIDGET_LEVEL_3) return;\n const interval = setInterval(fetchData, REFRESH_INTERVAL);\n return () => clearInterval(interval);\n }, [isConfigurationValid, fetchData, doInterval, level]);\n\n useEffect(() => {\n handleLoading(true);\n jApi.office\n .isConfigurationValid()\n .then(({ result }) => handleLogin(result))\n .catch(handleLogout)\n .finally(() => handleLoading(false));\n }, [handleLogin, level, fetchProviderUrls, handleLoading, handleLogout]);\n\n useEffect(() => {\n if (!isConfigurationValid) return;\n if (level === WIDGET_LEVEL_1) {\n handleLoading(true);\n fetchProviderUrls();\n return;\n }\n fetchData();\n }, [isConfigurationValid, fetchProviderUrls, handleLoading, fetchData, level]);\n\n if (isConfigurationValid && level && level !== WIDGET_LEVEL_3 && levelFallback) {\n return <>{levelFallback(level, url ?? '')}</>;\n }\n\n return (\n <WidgetScroll\n header={() => {\n return (\n <>\n <WidgetContactCardDavHeader\n uniqid={uniqid}\n isConfigurationValid={isConfigurationValid !== undefined && isConfigurationValid === true}\n handleLogout={() => handleLogout(undefined, true)}\n />\n </>\n );\n }}\n scrollable={() => {\n return (\n <WidgetStylePadding uniqid={uniqid}>\n {isConfigurationValid && <WidgetContactCardDav contactCardList={list} />}\n {isConfigurationValid === undefined && <></>}\n {isConfigurationValid !== undefined && isConfigurationValid === false && mode === 'view' && (\n <OfficeConfigurationPrompt />\n )}\n </WidgetStylePadding>\n );\n }}\n />\n );\n};\n","import jApi from 'jamespot-user-api';\n\nimport { useIntl } from 'react-intl';\nimport styled from 'styled-components';\nimport { JRCButtonDropdownOptionProps } from 'jamespot-react-components';\nimport { officeConfigurationInitialState } from '../components/OfficeConfigurationPrompt';\n\nimport { useDispatch } from 'react-redux';\nimport { Widget } from 'jamespot-front-business';\nimport { commonComponentsRegistry } from '../../../../registry/CommonRegistry';\nimport { WidgetHeader } from '../components/WidgetHeader';\n\nconst ButtonDropdown = commonComponentsRegistry.getLazyComponent('ButtonDropdown');\nconst Tooltip = commonComponentsRegistry.getLazyComponent('Tooltip');\n\nexport const UIDropdown = styled.div`\n margin-right: ${(props) => props.theme.space.sm}px;\n button {\n background: ${(props) => props.theme.color.white};\n }\n`;\n\nexport const WidgetCalendarCalDavHeader = ({\n uniqid,\n isConfigurationValid = false,\n handleLogout,\n}: {\n uniqid: string;\n isConfigurationValid: boolean;\n handleLogout: () => void;\n}) => {\n const intl = useIntl();\n const dispatch = useDispatch();\n const onLogout = () => {\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, loading: true }));\n jApi.office.setConfiguration(officeConfigurationInitialState).finally(handleLogout);\n };\n\n const options: JRCButtonDropdownOptionProps[] = [\n { label: intl.formatMessage({ id: 'WIDGET_Prompt_Logout' }), onClick: onLogout },\n ];\n\n return (\n <WidgetHeader\n uniqid={uniqid}\n dropdown={() => {\n return (\n isConfigurationValid && (\n <UIDropdown>\n <Tooltip\n position={'left'}\n description={intl.formatMessage({ id: 'WIDGET_Prompt_Dropdown' })}>\n <ButtonDropdown\n small\n smallOpenDirection=\"left\"\n options={options}\n icon={'icon-cogwheel'}\n label={''}\n color=\"primary\"\n variant=\"outlined\"\n />\n </Tooltip>\n </UIDropdown>\n )\n );\n }}\n />\n );\n};\n","import { Toast, Widget } from 'jamespot-front-business';\nimport { Utils } from 'jamespot-react-components';\nimport jApi, {\n DavCalendarEvent,\n WIDGET_LEVEL_1,\n WIDGET_LEVEL_3,\n WidgetCalendarCalDavType,\n WidgetDisplayMode,\n WidgetWrapperLevel,\n} from 'jamespot-user-api';\nimport { ReactNode, useCallback, useEffect, useState } from 'react';\nimport { shallowEqual } from 'react-redux';\nimport { useAppDispatch, useAppSelector } from '../../../redux/store';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { officeConfigurationInitialState, OfficeConfigurationPrompt } from './components/OfficeConfigurationPrompt';\nimport { WidgetScroll } from './components/WidgetScroll';\nimport { WidgetStylePadding } from './components/WidgetStylePadding';\nimport { WidgetCalendarCalDavHeader } from './WidgetCalendarCalDav/WidgetCalendarCalDavHeader';\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) => 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 [url, setUrl] = useState<string | undefined>(undefined);\n const [list, setList] = useState<DavCalendarEvent[]>([]);\n\n const handleLogout = useCallback(\n (err?: any, reload?: boolean) => {\n if (err && err.error === 400) {\n jApi.office.setConfiguration(officeConfigurationInitialState);\n }\n if (reload) {\n window.location.reload();\n return;\n }\n\n setIsConfigurationValid(false);\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, initialized: true, loading: false }));\n },\n [dispatch, uniqid],\n );\n\n const handleLogin = useCallback(\n (isValid: boolean) => {\n setIsConfigurationValid(isValid);\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, initialized: true }));\n },\n [dispatch, uniqid],\n );\n\n const handleLoading = useCallback(\n (loading: boolean) => dispatch(Widget.slice.actions.setWidgetState({ uniqid, loading })),\n [uniqid, dispatch],\n );\n\n const fetchProviderUrls = useCallback(() => {\n jApi.office\n .getProviderBaseUrls()\n .then(({ result }) => {\n setUrl(result.dav_calendar_url);\n })\n .finally(() => handleLoading(false));\n }, [handleLoading]);\n\n const fetchData = useCallback(() => {\n const now = new Date();\n const nextMonth = Utils.date.addMonth(new Date(now));\n\n jApi.office\n .davCalendarGetEvents({\n limit: 10,\n dateStart: Utils.date.formatDateTime(now),\n dateEnd: Utils.date.formatDateTime(nextMonth),\n })\n .then(({ result }) => {\n setList(result);\n setDoInterval(true);\n })\n .catch(() => {\n dispatch(Toast.actions.error({ label: 'PLUGIN_Manager_Connection_Error' }));\n setIsConfigurationValid(false);\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, initialized: true, loading: false }));\n })\n .finally(() => handleLoading(false));\n }, [handleLoading, dispatch, uniqid]);\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, level]);\n\n if (isConfigurationValid && level && level !== WIDGET_LEVEL_3 && levelFallback) {\n return <>{levelFallback(level, url ?? '')}</>;\n }\n\n return (\n <WidgetScroll\n header={() => {\n return (\n <>\n <WidgetCalendarCalDavHeader\n uniqid={uniqid}\n isConfigurationValid={isConfigurationValid !== undefined && isConfigurationValid === true}\n handleLogout={() => handleLogout(undefined, true)}\n />\n </>\n );\n }}\n scrollable={() => {\n return (\n <WidgetStylePadding uniqid={uniqid}>\n {isConfigurationValid && <WidgetCalendarCalDav calendarListEvent={list} />}\n {isConfigurationValid === undefined && <></>}\n {isConfigurationValid !== undefined && isConfigurationValid === false && mode === 'view' && (\n <OfficeConfigurationPrompt />\n )}\n </WidgetStylePadding>\n );\n }}\n />\n );\n};\n","import jApi from 'jamespot-user-api';\nimport { Widget } from 'jamespot-front-business';\n\nimport { shallowEqual } from 'react-redux';\nimport { useIntl } from 'react-intl';\nimport styled from 'styled-components';\nimport { JRCButtonDropdownOptionProps } from 'jamespot-react-components';\nimport { officeConfigurationInitialState } from '../components/OfficeConfigurationPrompt';\nimport { useAppSelector, useAppDispatch } from '../../../../redux/store';\nimport { commonComponentsRegistry } from '../../../../registry/CommonRegistry';\nimport { WidgetHeader } from '../components/WidgetHeader';\n\nconst ButtonDropdown = commonComponentsRegistry.getLazyComponent('ButtonDropdown');\nconst Tooltip = commonComponentsRegistry.getLazyComponent('Tooltip');\n\nexport const UIDropdown = styled.div`\n margin-right: ${(props) => props.theme.space.sm}px;\n button {\n background: ${(props) => props.theme.color.white};\n }\n`;\n\nexport const UICount = styled.div<{ color: string }>`\n font-size: ${(props) => props.theme.size.sm + 4}px;\n color: ${(props) => props.color};\n`;\n\nexport const WidgetEmailsImapHeader = ({\n uniqid,\n isConfigurationValid = false,\n handleLogout,\n}: {\n uniqid: string;\n isConfigurationValid: boolean;\n handleLogout: () => void;\n}) => {\n const intl = useIntl();\n const dispatch = useAppDispatch();\n\n const count = useAppSelector((state) => Widget.selectors.selectWidgetChipCount(state, uniqid), shallowEqual);\n\n const onLogout = () => {\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, loading: true }));\n jApi.office.setConfiguration(officeConfigurationInitialState).finally(handleLogout);\n };\n\n const options: JRCButtonDropdownOptionProps[] = [\n { label: intl.formatMessage({ id: 'WIDGET_Prompt_Logout' }), onClick: onLogout },\n ];\n\n return (\n <WidgetHeader\n uniqid={uniqid}\n dropdown={() => {\n return (\n isConfigurationValid && (\n <UIDropdown>\n <Tooltip\n position={'left'}\n description={intl.formatMessage({ id: 'WIDGET_Prompt_Dropdown' })}>\n <ButtonDropdown\n small\n smallOpenDirection=\"left\"\n options={options}\n icon={'icon-cogwheel'}\n label={''}\n color=\"primary\"\n variant=\"outlined\"\n />\n </Tooltip>\n </UIDropdown>\n )\n );\n }}\n subHeader={(color: string) => {\n return (\n isConfigurationValid &&\n count !== 0 && (\n <UICount color={color}>\n ({intl.formatMessage({ id: 'WIDGET_Email_IMAP_Unread_Emails' }, { count })})\n </UICount>\n )\n );\n }}\n />\n );\n};\n","import jApi, {\n ImapInboxMail,\n WIDGET_LEVEL_1,\n WIDGET_LEVEL_2,\n WIDGET_LEVEL_3,\n WidgetDisplayMode,\n WidgetEmailsImapType,\n WidgetWrapperLevel,\n} from 'jamespot-user-api';\nimport { Toast, Widget } from 'jamespot-front-business';\nimport { ReactNode, useCallback, useEffect, useState } from 'react';\nimport { shallowEqual } from 'react-redux';\nimport { WidgetEmailsImapHeader } from './WidgetEmailsImap/WidgetEmailsImapHeader';\nimport { officeConfigurationInitialState, OfficeConfigurationPrompt } from './components/OfficeConfigurationPrompt';\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { WidgetScroll } from './components/WidgetScroll';\nimport { WidgetStylePadding } from './components/WidgetStylePadding';\nimport { useAppSelector, useAppDispatch } from '../../../redux/store';\n\nconst WidgetEmailsImap = commonComponentsRegistry.getLazyComponent('WidgetEmailsImap');\n\nconst REFRESH_INTERVAL = 60 * 1000;\n\nexport type JRCWidgetEmailsImapProps = {\n widget: WidgetEmailsImapType;\n inplace: boolean;\n mode?: WidgetDisplayMode;\n levelFallback?: (level: WidgetWrapperLevel, url: string) => ReactNode | undefined;\n};\n\nexport const JRCWidgetEmailsImapWrapper = ({ widget, mode, levelFallback }: JRCWidgetEmailsImapProps) => {\n const { uniqid } = widget;\n const dispatch = useAppDispatch();\n const [isConfigurationValid, setIsConfigurationValid] = useState<boolean | undefined>(undefined);\n const [doInterval, setDoInterval] = useState<boolean>(false);\n const [list, setList] = useState<ImapInboxMail[]>([]);\n const [url, setUrl] = useState<string | undefined>(undefined);\n const level = useAppSelector((state) => Widget.selectors.selectWidgetLevel(state, widget.uniqid), shallowEqual);\n\n const handleLogout = useCallback(\n (err?: any, reload?: boolean) => {\n if (err && err.error === 400) {\n jApi.office.setConfiguration(officeConfigurationInitialState);\n }\n if (reload) {\n window.location.reload();\n return;\n }\n\n setIsConfigurationValid(false);\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, initialized: true, loading: false }));\n },\n [dispatch, uniqid],\n );\n\n const fetchUnreadEmailsCount = useCallback(() => {\n jApi.office\n .imapInboxGetUnreadEmailsCount()\n .then(({ result }) => {\n dispatch(Widget.slice.actions.setWidgetChipCount({ uniqid, count: result }));\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, initialized: true }));\n })\n .catch(handleLogout);\n }, [dispatch, uniqid, handleLogout]);\n\n const handleLoading = useCallback(\n (loading: boolean) => dispatch(Widget.slice.actions.setWidgetState({ uniqid, loading })),\n [uniqid, dispatch],\n );\n\n const fetchProviderUrls = useCallback(() => {\n jApi.office\n .getProviderBaseUrls()\n .then(({ result }) => {\n setUrl(result.imap_inbox_url);\n })\n .finally(() => handleLoading(false));\n }, [handleLoading]);\n\n const handleLogin = useCallback(\n (isValid: boolean) => {\n setIsConfigurationValid(isValid);\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, initialized: true }));\n },\n [dispatch, uniqid],\n );\n\n const fetchData = useCallback(() => {\n jApi.office\n .imapInboxGetEmails({ limit: 10 })\n .then(({ result }) => {\n setList(result);\n setDoInterval(true);\n })\n .catch(() => {\n dispatch(Toast.actions.error({ label: 'PLUGIN_Manager_Connection_Error' }));\n setIsConfigurationValid(false);\n dispatch(Widget.slice.actions.setWidgetState({ uniqid, initialized: true, loading: false }));\n })\n .finally(() => handleLoading(false));\n }, [handleLoading, dispatch, uniqid]);\n\n useEffect(() => {\n if (!doInterval) return;\n if (!isConfigurationValid) return;\n if (level === WIDGET_LEVEL_1) return;\n const interval = setInterval(() => {\n if (level === WIDGET_LEVEL_2) {\n fetchUnreadEmailsCount();\n }\n if (level === WIDGET_LEVEL_3) {\n fetchUnreadEmailsCount();\n fetchData();\n }\n }, REFRESH_INTERVAL);\n return () => clearInterval(interval);\n }, [isConfigurationValid, fetchData, doInterval, fetchUnreadEmailsCount, level]);\n\n useEffect(() => {\n jApi.office\n .isConfigurationValid()\n .then(({ result }) => handleLogin(result))\n .catch(handleLogout);\n }, [handleLogin, handleLogout]);\n\n useEffect(() => {\n if (!isConfigurationValid) return;\n if (level === WIDGET_LEVEL_1) {\n handleLoading(true);\n fetchProviderUrls();\n return;\n }\n if (level === WIDGET_LEVEL_2) {\n handleLoading(true);\n fetchUnreadEmailsCount();\n fetchProviderUrls();\n return;\n }\n\n handleLoading(true);\n fetchUnreadEmailsCount();\n fetchData();\n }, [isConfigurationValid, level, fetchProviderUrls, fetchData, handleLoading, fetchUnreadEmailsCount, dispatch]);\n\n if (isConfigurationValid && level && level !== WIDGET_LEVEL_3 && levelFallback) {\n return <>{levelFallback(level, url ?? '')}</>;\n }\n\n return (\n <WidgetScroll\n header={() => {\n return (\n <>\n <WidgetEmailsImapHeader\n uniqid={uniqid}\n isConfigurationValid={isConfigurationValid !== undefined && isConfigurationValid === true}\n handleLogout={() => handleLogout(undefined, true)}\n />\n </>\n );\n }}\n scrollable={() => {\n return (\n <WidgetStylePadding uniqid={uniqid}>\n {isConfigurationValid === undefined && <></>}\n {isConfigurationValid !== undefined && isConfigurationValid === false && mode === 'view' && (\n <OfficeConfigurationPrompt />\n )}\n {isConfigurationValid && <WidgetEmailsImap emailList={list} />}\n </WidgetStylePadding>\n );\n }}\n />\n );\n};\n","import { Widget } from 'jamespot-front-business';\nimport { CSSProperties, useMemo } from 'react';\nimport { shallowEqual } from 'react-redux';\nimport styled, { useTheme } from 'styled-components';\nimport { useAppSelector } from '../../../../redux/store';\nimport { commonComponentsRegistry } from '../../../../registry/CommonRegistry';\n\nconst JRCHtml = commonComponentsRegistry.getLazyComponent('Html');\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 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:\n styles && styles['background-color'] ? String(styles['background-color']) : theme.color.white,\n fontSize: styles && styles['font-size'] ? `${styles['font-size']}px` : '24px',\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 title = useMemo(() => {\n return widgetWrapper && typeof widgetWrapper.title === 'string' && widgetWrapper.title.length !== 0\n ? widgetWrapper.title\n : undefined;\n }, [widgetWrapper]);\n\n if (!title) return <></>;\n\n return (\n <CSSWidgetTitle\n style={{\n color: initialValues.color,\n backgroundColor: initialValues.backgroundColor,\n fontSize: initialValues.fontSize,\n fontWeight: initialValues.fontWeight,\n textAlign: initialValues.textAlign as CSSProperties['textAlign'],\n }}>\n <JRCHtml as=\"span\" __html={title} />\n </CSSWidgetTitle>\n );\n};\n","import { Widget } from 'jamespot-front-business';\nimport { 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';\nimport { commonComponentsRegistry } from '../../../../registry/CommonRegistry';\n\nconst JRCInputText = commonComponentsRegistry.getLazyComponent('InputText');\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 { Widget, WidgetEditor } from 'jamespot-front-business';\nimport { WidgetsName } from 'jamespot-user-api';\nimport { useCallback, useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport styled from 'styled-components';\nimport { useAppDispatch } from '../../../../redux/store';\nimport { commonComponentsRegistry } from '../../../../registry/CommonRegistry';\nimport { WidgetTitleEdit } from './WidgetTitleEdit';\n\nconst JRCButton = commonComponentsRegistry.getLazyComponent('Button');\nconst JRCModalLayout = commonComponentsRegistry.getLazyComponent('ModalLayout');\nconst JRCModalContent = commonComponentsRegistry.getLazyComponent('ModalContent');\nconst JRCIconButton = commonComponentsRegistry.getLazyComponent('IconButton');\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 { useAppSelector } from '../../../redux/store';\nimport { Hook } from 'jamespot-front-business';\nimport { LicenseHookListType } from 'jamespot-user-api';\nimport { ReactNode } from 'react';\nimport { useIntl } from 'react-intl';\nimport styled from 'styled-components';\n\nconst UILicenseRequired = styled.div`\n position: absolute;\n inset: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n color: ${(props) => props.theme.color.orange};\n`;\n\nexport const WidgetLicenseWrapper = ({ children, name }: { children: ReactNode; name: keyof LicenseHookListType }) => {\n const hook = useAppSelector((state) => Hook.selectors.selectHook(state, name));\n const intl = useIntl();\n\n if (hook && !hook.hasLicense) {\n return (\n <UILicenseRequired>\n {intl.formatMessage({ id: 'WIDGET_Missing_License' }, { label: 'label' in hook ? hook.label : '' })}\n </UILicenseRequired>\n );\n }\n\n return <>{children}</>;\n};\n","import { 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 ensureWidgetLuccaAbsenceType,\n ensureWidgetPresenceType,\n ensureWidgetQuickSurveyType,\n ensureWidgetUserProfileType,\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 { JRCWidgetLuccaAbsenceWrapper } from './wrapper/JRCWidgetLuccaAbsenceWrapper';\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';\nimport { JRCWidgetUserProfileWrapper } from './wrapper/JRCWidgetUserProfileWrapper';\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';\nimport { WidgetLicenseWrapper } from './wrapper/WidgetLicenseWrapper';\n\nexport const DisplayWidget = ({\n widget,\n width,\n inplace = false,\n mode = 'view',\n onWidgetUpdate,\n cannotDisplayComponent,\n levelFallback,\n dataCy,\n}: {\n widget: CombinedWidgetType;\n width?: number | undefined;\n inplace: boolean;\n mode: WidgetDisplayMode;\n onWidgetUpdate?: () => void;\n cannotDisplayComponent?: (widget: string) => ReactNode;\n levelFallback?: (level: WidgetWrapperLevel, url: string) => ReactNode | undefined;\n dataCy?: string;\n}) => {\n const { name } = widget;\n\n if (ensureWidgetArticleButtonType(widget)) {\n return <JRCWidgetArticleButtonWrapper widget={widget} inplace={inplace} mode={mode} />;\n } else if (ensureWidgetArticleGalleryType(widget)) {\n return <JRCWidgetArticleGalleryWrapper widget={widget} inplace={inplace} mode={mode} />;\n } else if (ensureWidgetLuccaAbsenceType(widget)) {\n return (\n <CSSWidgetWithTitle>\n <WidgetLicenseWrapper name={'LuccaAbsenceHook'}>\n <JRCWidgetLuccaAbsenceWrapper uniqid={widget.uniqid} />\n </WidgetLicenseWrapper>\n </CSSWidgetWithTitle>\n );\n } else if (ensureWidgetArticleAttachmentType(widget)) {\n return <JRCWidgetArticleAttachmentWrapper widget={widget} inplace={inplace} mode={mode} />;\n } else if (ensureWidgetArticleImageType(widget)) {\n return <JRCWidgetArticleImageWrapper widget={widget} inplace={inplace} mode={mode} />;\n } else if (ensureWidgetArticleSliderType(widget)) {\n return <JRCWidgetArticleSliderWrapper widget={widget} inplace={inplace} mode={mode} width={width ?? 800} />;\n } else if (ensureWidgetArticleTitleType(widget)) {\n return <JRCWidgetArticleTitleWrapper widget={widget} inplace={inplace} mode={mode} dataCy={dataCy} />;\n } else if (ensureWidgetArticleTextType(widget)) {\n return <JRCWidgetArticleTextWrapper widget={widget} inplace={inplace} mode={mode} />;\n } else if (ensureWidgetExcelDatasourceTableType(widget)) {\n return (\n <CSSWidgetWithTitle>\n <WidgetTitle uniqid={widget.uniqid} />\n <WidgetExcelDatasourceTableWrapper {...widget.content} uniqid={widget.uniqid} mode={mode} />\n </CSSWidgetWithTitle>\n );\n } else if (ensureWidgetDatasourceTableType(widget)) {\n return (\n <CSSWidgetWithTitle>\n <WidgetTitle uniqid={widget.uniqid} />\n <WidgetDatasourceTableWrapper {...widget.content} uniqid={widget.uniqid} mode={mode} />\n </CSSWidgetWithTitle>\n );\n } else if (ensureWidgetCheckListType(widget, widget.name === 'widget-check-list')) {\n return (\n <CSSWidgetWithTitle>\n {mode === 'edit' ? (\n <WidgetHeaderEdit name={widget.name} uniqid={widget.uniqid} />\n ) : (\n <WidgetTitle uniqid={widget.uniqid} />\n )}\n <JRCWidgetCheckListWrapper\n widget={widget}\n inplace={inplace}\n mode={mode}\n onWidgetUpdate={onWidgetUpdate}\n />\n </CSSWidgetWithTitle>\n );\n } else if (ensureWidgetPresenceType(widget)) {\n return (\n <CSSWidgetWithTitle>\n {mode === 'edit' ? (\n <WidgetHeaderEdit name={widget.name} uniqid={widget.uniqid} />\n ) : (\n <WidgetTitle uniqid={widget.uniqid} />\n )}\n <JRCWidgetPresenceWrapper widget={widget} inplace={inplace} mode={mode} />\n </CSSWidgetWithTitle>\n );\n } else if (ensureWidgetQuickSurveyType(widget)) {\n return (\n <CSSWidgetWithTitle>\n {mode === 'edit' ? (\n <WidgetHeaderEdit name={widget.name} uniqid={widget.uniqid} />\n ) : (\n <WidgetTitle uniqid={widget.uniqid} />\n )}\n <JRCWidgetQuickSurveyWrapper widget={widget} inplace={inplace} mode={mode} />\n </CSSWidgetWithTitle>\n );\n } else if (ensureWidgetCalendarCalDavType(widget)) {\n return (\n <CSSWidgetWithTitle>\n <WidgetLicenseWrapper name={'OfficeHook'}>\n <JRCWidgetCalendarCalDavWrapper\n widget={widget}\n inplace={inplace}\n mode={mode}\n levelFallback={levelFallback}\n />\n </WidgetLicenseWrapper>\n </CSSWidgetWithTitle>\n );\n } else if (ensureWidgetContactCardDavType(widget)) {\n return (\n <CSSWidgetWithTitle>\n <WidgetLicenseWrapper name={'OfficeHook'}>\n <JRCWidgetContactCardDavWrapper\n widget={widget}\n inplace={inplace}\n mode={mode}\n levelFallback={levelFallback}\n />\n </WidgetLicenseWrapper>\n </CSSWidgetWithTitle>\n );\n } else if (ensureWidgetEmailsImapType(widget)) {\n return (\n <CSSWidgetWithTitle>\n <WidgetLicenseWrapper name={'OfficeHook'}>\n <JRCWidgetEmailsImapWrapper\n widget={widget}\n inplace={inplace}\n mode={mode}\n levelFallback={levelFallback}\n />\n </WidgetLicenseWrapper>\n </CSSWidgetWithTitle>\n );\n } else if (ensureWidgetUserProfileType(widget, true)) {\n return (\n <CSSWidgetWithTitle>\n <JRCWidgetUserProfileWrapper widget={widget} inplace={inplace} mode={mode} />\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 { 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\n uniqid={uniqid}\n widget={widgetWrapper}\n mode={mode}\n inplace={true}\n context={'article'}\n />\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\n uniqid={uniqid}\n widget={widgetWrapper}\n mode={mode}\n inplace={true}\n context={'article'}\n />\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 { 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\n//TODO: REFACTORING\nexport const WidgetState = ({ uniqid, inplace }: { name: WidgetKeys; uniqid: string; inplace: boolean }) => {\n const state = useAppSelector((state) => Widget.selectors.selectWidgetState(state, uniqid));\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 return <></>;\n};\n","import { Widget, WidgetEditor } from 'jamespot-front-business';\nimport { DashedFocusBorder } from 'jamespot-react-components';\nimport { WidgetKeys } from 'jamespot-user-api';\nimport { useCallback } from 'react';\nimport { useIntl } from 'react-intl';\nimport styled from 'styled-components';\nimport { useAppDispatch } from '../../redux/store';\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\n\nconst JRCHtml = commonComponentsRegistry.getLazyComponent('Html');\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\n const registerEditor = useCallback(() => {\n dispatch(WidgetEditor.slice.actions.flushAllEditor());\n dispatch(\n WidgetEditor.slice.actions.registerEditor({\n uniqid,\n name,\n }),\n );\n }, [dispatch, uniqid, name]);\n const def = Widget.definition(name);\n\n return (\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","import { ReactNode, 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 display: flex;\n flex-direction: column;\n`;\n\n/*\n DO NOT USE PADDING HERE (LOOK AT WIDGET STYLE PADDING COMPONENT)\n*/\nconst WidgetStyle = ({ uniqid, onClick, children }: { uniqid: string; onClick: () => void; children: ReactNode }) => {\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'] ? `${styles['border-radius']}px` : '0px',\n borderColor: styles['border-color'] ? String(styles['border-color']) : theme.color.black,\n borderWidth: styles['border-width'] ? `${styles['border-width']}px` : '0px',\n borderStyle: styles['border-style'] ? String(styles['border-style']) : 'none',\n };\n }, [styles, theme]);\n\n return (\n <UIWrapper\n onClick={onClick}\n style={{\n color: initialValues.color,\n borderColor: initialValues.borderColor,\n borderStyle: initialValues.borderStyle,\n borderRadius: initialValues.borderRadius,\n borderWidth: initialValues.borderWidth,\n backgroundColor: initialValues.backgroundColor,\n overflow: Number(initialValues.borderRadius) > 0 ? 'hidden' : 'initial',\n }}>\n {children}\n </UIWrapper>\n );\n};\n\nexport const WidgetStyleWrapper = WidgetStyle;\n","import { WidgetKeys, WidgetWrapperLevel } from 'jamespot-user-api';\n\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 { Widget, WidgetEditor } from 'jamespot-front-business';\nimport { jCommentList, WidgetContext, WidgetDisplayMode, WidgetWrapperProps } from 'jamespot-user-api';\nimport { ReactNode, useCallback, useEffect } from 'react';\nimport { shallowEqual } from 'react-redux';\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 { useAppDispatch, useAppSelector } from '../../redux/store';\nimport { WidgetStyleWrapper } from './wrapper/components/WidgetStyleWrapper';\nimport { JRCWidgetIconWrapper } from './wrapper/JRCWidgetIconWrapper';\ntype WidgetWrapperCoreProps = {\n uniqid: string;\n widgetObject?: Partial<jCommentList>;\n widget: WidgetWrapperProps;\n inplace?: boolean;\n mode: WidgetDisplayMode;\n width?: number | undefined;\n context: WidgetContext;\n onWidgetUpdate?: () => void;\n cannotDisplayComponent?: (widget: string) => ReactNode;\n dataCy?: string;\n};\n\n/*\n This is a widget wrapper\n*/\nexport const WidgetWrapperCore = ({\n uniqid,\n widgetObject,\n widget,\n inplace = true,\n mode,\n width,\n context,\n onWidgetUpdate,\n cannotDisplayComponent,\n dataCy,\n}: WidgetWrapperCoreProps) => {\n const dispatch = useAppDispatch();\n const widgetWrapper = useAppSelector((state) => Widget.selectors.selectWidget(state, uniqid));\n const indexOrder = useAppSelector((state) => state.widgets.editableMap[uniqid], shallowEqual);\n const currentEditableWidgetId = useAppSelector((state) => state.widgets.currentEditableWidgetId, shallowEqual);\n const isActive = useAppSelector((state) => state.widgets.currentEditableWidgetId === uniqid, shallowEqual);\n const { isComponentVisible, setIsComponentVisible } = useComponentVisible(false);\n\n useEffect(() => {\n if (widgetObject) {\n dispatch(Widget.slice.actions.registerWidgetObject({ uniqid, object: widgetObject }));\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n useEffect(() => {\n if (widget) {\n /*\n Register widget\n */\n dispatch(Widget.slice.actions.registerWidget({ uniqid, widget, context }));\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n\n useEffect(() => {\n if (!isComponentVisible) {\n if (uniqid === currentEditableWidgetId) {\n dispatch(Widget.slice.actions.setEditableWidgetId({ uniqid: undefined }));\n }\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isComponentVisible]);\n\n useEffect(() => {\n if (isComponentVisible !== isActive) {\n setIsComponentVisible(isActive);\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isActive]);\n\n const registerEditor = useCallback(() => {\n if (widgetWrapper === undefined || mode === 'view') {\n return;\n }\n dispatch(WidgetEditor.slice.actions.flushAllEditor());\n /*\n Register editor\n */\n const { widget } = widgetWrapper;\n dispatch(\n WidgetEditor.slice.actions.registerEditor({\n uniqid: widget.uniqid,\n name: widget.name,\n }),\n );\n }, [dispatch, mode, widgetWrapper]);\n\n if (widgetWrapper === undefined) {\n return <>This widget cannot be displayed</>;\n }\n\n if (inplace && mode !== 'view') {\n return (\n <WidgetStyleWrapper\n uniqid={uniqid}\n onClick={() => {\n setIsComponentVisible(true);\n if (indexOrder) {\n dispatch(Widget.slice.actions.setEditableIndex({ index: indexOrder.index }));\n dispatch(Widget.slice.actions.setEditableWidgetId({ uniqid }));\n }\n }}>\n <DisplayWidget\n dataCy={dataCy}\n width={width}\n widget={{\n ...widgetWrapper.widget,\n ...(widgetWrapper.title && {\n title: widgetWrapper.title,\n }),\n }}\n inplace={inplace}\n mode={mode}\n levelFallback={(level, url) => {\n return (\n level <= 2 && (\n <JRCWidgetIconWrapper\n uniqid={widget.widget.uniqid}\n name={widget.widget.name}\n level={level}\n url={url}\n />\n )\n );\n }}\n />\n <WidgetLayer uniqid={uniqid} mode={mode} />\n <WidgetState name={widgetWrapper.widget.name} uniqid={widgetWrapper.widget.uniqid} inplace={inplace} />\n </WidgetStyleWrapper>\n );\n }\n\n return (\n <WidgetStyleWrapper uniqid={uniqid} onClick={registerEditor}>\n <DisplayWidget\n dataCy={dataCy}\n widget={{\n ...widgetWrapper.widget,\n ...(widgetWrapper.title && {\n title: widgetWrapper.title,\n }),\n }}\n inplace={inplace}\n mode={mode}\n width={width}\n onWidgetUpdate={onWidgetUpdate}\n cannotDisplayComponent={cannotDisplayComponent}\n levelFallback={(level, url) => {\n return (\n level <= 2 && (\n <JRCWidgetIconWrapper\n uniqid={widget.widget.uniqid}\n name={widget.widget.name}\n level={level}\n url={url}\n />\n )\n );\n }}\n />\n <WidgetLayer uniqid={uniqid} mode={mode} />\n {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\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';\n\nimport { useIntl } from 'react-intl';\nimport { shallowEqual } from 'react-redux';\nimport { useAppSelector } from '../../redux/store';\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\nimport WidgetWrapperCore from '../widgets/WidgetWrapperCore';\nimport { CSSCommentsBlocWidgetWrapper } from './CommentsBloc.styles';\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 context={'comment'}\n />\n </CSSCommentsBlocWidgetWrapper>\n ),\n )}\n </>\n );\n};\n","import { Widget } from 'jamespot-front-business';\nimport { jCommentList, WidgetDisplayMode, WidgetWrapperProps } from 'jamespot-user-api';\n\nimport { useIntl } from 'react-intl';\nimport { shallowEqual } from 'react-redux';\nimport { useAppSelector } from '../../redux/store';\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\nimport WidgetWrapperCore from '../widgets/WidgetWrapperCore';\nimport { CSSCommentsBlocWidgetWrapper } from './CommentsBloc.styles';\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 context={'comment'}\n />\n </CSSCommentsBlocWidgetWrapper>\n ),\n )}\n </>\n );\n};\n","import { useMemo, useState } from 'react';\r\nimport { Editor, JTinyMCEExtensionsBuilders } from 'jamespot-react-components';\r\n\r\nexport const useGifsModal = (): {\r\n open: boolean;\r\n onSelect: (v: string) => void;\r\n close: () => void;\r\n ext: ReturnType<typeof JTinyMCEExtensionsBuilders.gifs>;\r\n isActive?: boolean;\r\n} => {\r\n const [open, setOpen] = useState(false);\r\n const [editor, setEditor] = useState<Editor>();\r\n const ext = useMemo(\r\n () =>\r\n JTinyMCEExtensionsBuilders.gifs(\r\n (ed) => setEditor(ed),\r\n () => setOpen(true),\r\n ),\r\n [],\r\n );\r\n return {\r\n open,\r\n onSelect: (v: string) => {\r\n editor?.execCommand('InsertHTML', false, `<img src=\"${v}\" alt=\"\" />`);\r\n setOpen(false);\r\n },\r\n close: () => setOpen(false),\r\n ext,\r\n isActive: true,\r\n };\r\n};\r\n","import { useCallback, useEffect, useState } from 'react';\r\nimport { FormattedMessage } from 'react-intl';\r\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\r\nimport jApi, { Gif } from 'jamespot-user-api';\r\nimport { useAppDispatch } from '../../../redux/store';\r\nimport { Toast } from 'jamespot-front-business';\r\nimport { useAbortController } from '../../../hooks';\r\n\r\nconst GifsSelector = commonComponentsRegistry.getLazyComponent('GifsSelector');\r\nconst Modal = commonComponentsRegistry.getLazyComponent('Modal');\r\n\r\nexport type GifsModalProps = {\r\n onSelect: (url: string) => void;\r\n open: boolean;\r\n close: () => void;\r\n};\r\n\r\nconst nbItemsPerPage = 10;\r\n\r\nexport const GifsModal = ({ onSelect, open, close }: GifsModalProps) => {\r\n const dispatch = useAppDispatch();\r\n const abortController = useAbortController();\r\n const [loading, setLoading] = useState(false);\r\n const [gifs, setGifs] = useState<Gif[]>([]);\r\n const [query, setQuery] = useState<{ q?: string; offset: number }>({ q: undefined, offset: 0 });\r\n\r\n const doClose = useCallback(() => {\r\n close();\r\n setQuery({ q: undefined, offset: 0 });\r\n }, [close]);\r\n\r\n useEffect(() => {\r\n setLoading(true);\r\n jApi.jamespot\r\n .getGifs(\r\n { q: query.q || 'awesome', limit: nbItemsPerPage, offset: query.offset },\r\n { signal: abortController.signal },\r\n )\r\n .then((res) => {\r\n setGifs(query.offset === 0 ? res.result : (prev) => [...prev, ...res.result]);\r\n })\r\n .catch((e) => {\r\n if (!e.aborted) {\r\n dispatch(Toast.actions.error({ label: e.errorMsg ?? 'GLOBAL_Error' }));\r\n }\r\n })\r\n .finally(() => {\r\n setLoading(false);\r\n });\r\n }, [abortController, dispatch, query]);\r\n\r\n return (\r\n <Modal\r\n title={'Gif'}\r\n open={open}\r\n closeHandler={doClose}\r\n enableClickAwayCloseModal\r\n variant={'fixed-height'}\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 <GifsSelector\r\n gifs={gifs}\r\n onSelectGif={onSelect}\r\n loading={loading}\r\n onSearch={(q) => setQuery({ q, offset: 0 })}\r\n onReachEnd={() => {\r\n setQuery((prev) => ({ ...prev, offset: prev.offset + nbItemsPerPage }));\r\n }}\r\n />\r\n </Modal>\r\n );\r\n};\r\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 { 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';\n\nimport { WidgetList } from './widgets/WidgetList/WidgetList';\n\nimport { useMarkdownModal } from '../hooks/useMarkdownModal';\nimport { useAppDispatch, useAppSelector } from '../redux/store';\nimport { commonComponentsRegistry } from '../registry/CommonRegistry';\nimport { getTinyMCEMentionsQueries } from '../utils/tinymce';\nimport { AddReportModal, AddReportModalProps } from './comments/AddReportModal';\nimport { CommentsBlocAddCommentWidgetsWrapper } from './comments/CommentsBlocAddCommentWidgetsWrapper';\nimport { CommentsBlocCommentWidgetsWrapper } from './comments/CommentsBlocCommentWidgetsWrapper';\nimport { MarkdownModal } from './tinymce/extension/MarkdownModal';\nimport { useGifsModal } from '../hooks/useGifsModal';\nimport { GifsModal } from './tinymce/extension/GifsModal';\n\nconst JRCCommentsBloc = commonComponentsRegistry.getLazyComponent('JRCCommentsBloc');\n\nexport type CommentsBlocProps = {\n articleId: number;\n articleUri: string;\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 articleUri,\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 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 [reportProps, setReportProps] = useState<Omit<AddReportModalProps, 'onClose'> | null>(null);\n const {\n open,\n onInsert,\n close: closeMarkdownModal,\n ext: extMarkdown,\n isActive: isMarkdownActive,\n } = useMarkdownModal();\n const {\n open: gifsModalOpen,\n close: closeGifsModal,\n onSelect: onSelectGif,\n ext: extGifs,\n isActive: isGifsActive,\n } = useGifsModal();\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 throw e;\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={!!(widgetHook?.isActive && widgetHook?.autorize?.includes('comment'))}\n canCreateWidget={\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 context: 'comment',\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 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 fileIntegrity: jApi.fileIntegrity,\n user: jApi.user,\n global: jApi.global,\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, extGifs]}\n onReport={(commentUri) => setReportProps({ articleId, commentUri, articleUri })}\n />\n </CommentsBlocWrapper>\n </>\n )}\n {isMarkdownActive && <MarkdownModal onInsert={onInsert} open={open} close={closeMarkdownModal} />}\n {reportProps && <AddReportModal onClose={() => setReportProps(null)} {...reportProps} />}\n {isGifsActive && <GifsModal open={gifsModalOpen} close={closeGifsModal} onSelect={onSelectGif} />}\n </>\n );\n};\n","import { Application } from 'jamespot-front-business';\n\nimport { useIntl } from 'react-intl';\nimport styled, { useTheme } from 'styled-components';\n\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\nimport { useAppSelector } from '../../redux/store';\n\nconst AppsDropdownItem = styled.li`\n list-style: none;\n`;\n\nconst AppsDropdownItemLink = styled.a`\n display: flex;\n align-items: center;\n gap: ${({ theme }) => theme.space.sm}px;\n text-decoration: none;\n color: ${({ theme }) => theme.font.color};\n padding: ${({ theme }) => theme.space.sm}px ${({ theme }) => theme.space.md}px ${({ theme }) => theme.space.sm}px\n ${({ theme }) => theme.space.xs}px;\n border-radius: ${({ theme }) => theme.size.sm}px;\n\n &:hover {\n text-decoration: none;\n background-color: ${({ theme }) => theme.color.grey1};\n color: ${({ theme }) => theme.font.color};\n }\n`;\n\nconst Icon = commonComponentsRegistry.getLazyComponent('Icon');\nconst FlexBox = commonComponentsRegistry.getLazyComponent('FlexBox');\nconst Typography = commonComponentsRegistry.getLazyComponent('Typography');\nconst DropDown = commonComponentsRegistry.getLazyComponent('DropDown');\n\nexport const CalendarHeader = () => {\n const theme = useTheme();\n const intl = useIntl();\n const animatedMeeting = useAppSelector((state) => Application.selectors.selectById(state, 'AnimatedMeetingHook'));\n const calendarApp = useAppSelector((state) => Application.selectors.selectById(state, 'calendar'));\n const surveyDate = useAppSelector((state) => Application.selectors.selectById(state, 'SurveyDateHook'));\n\n if (!calendarApp) {\n return null;\n }\n\n return (\n <FlexBox y={'center'}>\n <Icon name={'icon-' + calendarApp.icon} variant=\"circle\" color={calendarApp.color} size={40} />\n <Typography variant=\"h1\" size=\"xl\" weight=\"medium\">\n {calendarApp.label}\n </Typography>\n {(surveyDate || animatedMeeting) && (\n <>\n <Typography size=\"xl\" color={'grey4'}>\n /\n </Typography>\n <DropDown\n withBorder\n borderColor={'grey3'}\n trigger={\n <FlexBox y={'center'} gap={theme.space.xs}>\n <Typography size=\"xl\" color={'grey4'}>\n {intl.formatMessage({ id: 'CALENDAR_Agenda' })}\n </Typography>\n <Icon name={'icon-chevron-down'} color={'grey4'} size={16} />\n </FlexBox>\n }\n dropdown={() => (\n <FlexBox direction={'column'} gap={theme.space.sm} as={'ul'}>\n {surveyDate && (\n <AppsDropdownItem>\n <AppsDropdownItemLink href={surveyDate.url}>\n <Icon\n name={'icon-' + surveyDate.icon}\n size={25}\n variant={'circle'}\n color={surveyDate.color}\n />\n <Typography size=\"l\">{surveyDate.label}</Typography>\n </AppsDropdownItemLink>\n </AppsDropdownItem>\n )}\n {animatedMeeting && (\n <AppsDropdownItem>\n <AppsDropdownItemLink href={animatedMeeting.url}>\n <Icon\n name={'icon-' + animatedMeeting.icon}\n size={25}\n variant={'circle'}\n color={animatedMeeting.color}\n />\n <Typography size=\"l\">{animatedMeeting.label}</Typography>\n </AppsDropdownItemLink>\n </AppsDropdownItem>\n )}\n </FlexBox>\n )}\n />\n </>\n )}\n </FlexBox>\n );\n};\n","import { Application, Calendar, Hook } from 'jamespot-front-business';\nimport { CalendarApi, CalendarView } from 'jamespot-react-components';\nimport { Fragment, useMemo } from 'react';\nimport { FormattedMessage, useIntl } from 'react-intl';\nimport styled from 'styled-components';\nimport { useAppDispatch, useAppSelector } from '../../redux/store';\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\n\nconst Typography = commonComponentsRegistry.getLazyComponent('Typography');\nconst FlexBox = commonComponentsRegistry.getLazyComponent('FlexBox');\nconst ButtonDropdown = commonComponentsRegistry.getLazyComponent('ButtonDropdown');\nconst Dropdown = commonComponentsRegistry.getLazyComponent('DropDown');\nconst IconButton = commonComponentsRegistry.getLazyComponent('IconButton');\nconst InputSelectRaw = commonComponentsRegistry.getLazyComponent('InputSelectRaw');\nconst InputCheckboxRaw = commonComponentsRegistry.getLazyComponent('InputCheckboxRaw');\nconst StyledHref = commonComponentsRegistry.getLazyComponent('StyledHref');\n\nconst Label = styled(Typography)`\n text-transform: capitalize;\n margin-right: ${({ theme }) => theme.space.md}px;\n`;\n\nconst InputWrapper = styled.div`\n max-width: 200px;\n display: flex;\n align-items: center;\n`;\n\nconst DropdownContainer = styled.div`\n padding: 0 ${({ theme }) => theme.space.md}px;\n`;\n\ntype Filter = ('socialEvent' | 'meeting' | 'animatedMeeting' | 'boardCard')[];\ntype OptionView = {\n label: string;\n value: CalendarView;\n};\n\nexport const CalendarToolbar = ({\n label,\n view,\n viewsOptions,\n calendarApi,\n isLoading,\n navigateWithQuery,\n setView,\n setCreationType,\n setExportModalOpen,\n}: {\n label?: string;\n view: OptionView;\n viewsOptions: { label: string; value: CalendarView }[];\n calendarApi?: CalendarApi;\n isLoading: boolean;\n navigateWithQuery: (queries: { types?: Filter; view?: CalendarView }) => void;\n setView: (view: any) => void;\n setCreationType: (type: 'socialEvent' | 'meeting' | 'animatedMeeting' | null) => void;\n setExportModalOpen: (value: boolean) => void;\n}) => {\n const intl = useIntl();\n const dispatch = useAppDispatch();\n const { types } = useAppSelector(Calendar.selectors.selectCalendarEvents);\n const animatedMeeting = useAppSelector((state) => Application.selectors.selectById(state, 'AnimatedMeetingHook'));\n const animatedMeetingHook = useAppSelector((state) => Hook.selectors.selectHook(state, 'AnimatedMeetingHook'));\n const meeting = useAppSelector((state) => Application.selectors.selectById(state, 'MeetingHook'));\n const boardCard = useAppSelector((state) => Application.selectors.selectById(state, 'BoardcardHook'));\n\n const createCalendarEventOptions = useMemo(\n () => [\n {\n label: intl.formatMessage({ id: 'CALENDAR_Create_SocialEvent' }),\n onClick: () => {\n setCreationType('socialEvent');\n },\n },\n ...(meeting\n ? [\n {\n label: intl.formatMessage({ id: 'CALENDAR_Create_Meeting' }),\n onClick: () => {\n setCreationType('meeting');\n },\n },\n ]\n : []),\n ...(animatedMeeting && animatedMeetingHook?.create\n ? [\n {\n label: intl.formatMessage({ id: 'CALENDAR_Create_AnimatedMeeting' }),\n href: '/?action=spotlight-edit&type=animatedMeeting',\n },\n ]\n : []),\n ],\n [animatedMeeting, animatedMeetingHook?.create, intl, meeting, setCreationType],\n );\n const viewOptionEntries = useMemo(\n () => [\n {\n label: <FormattedMessage id=\"CALENDAR_SocialEvents\" />,\n value: 'socialEvent',\n },\n ...(meeting\n ? [\n {\n label: <FormattedMessage id=\"CALENDAR_Meetings\" />,\n value: 'meeting',\n },\n ]\n : []),\n ...(animatedMeeting\n ? [\n {\n label: <FormattedMessage id=\"CALENDAR_AnimatedMeetings\" />,\n value: 'animatedMeeting',\n },\n ]\n : []),\n ...(boardCard\n ? [\n {\n label: <FormattedMessage id=\"CALENDAR_BoardCards\" />,\n value: 'boardCard',\n },\n ]\n : []),\n ],\n [animatedMeeting, boardCard, meeting],\n );\n\n return (\n <FlexBox y={'center'}>\n {view.value !== 'list' && (\n <Fragment>\n <Label size={'l'} weight={'medium'}>\n {label}\n </Label>\n <FlexBox>\n <IconButton icon={'icon-chevron-left'} onClick={() => calendarApi?.prev()} color={'grey5'} />\n <IconButton icon={'icon-chevron-right'} onClick={() => calendarApi?.next()} color={'grey5'} />\n </FlexBox>\n <IconButton\n icon={'icon-calendar'}\n onClick={() => calendarApi?.today()}\n tooltip={{ description: 'CALENDAR_Today', position: 'bottom' }}\n color={'grey5'}\n />\n </Fragment>\n )}\n <InputWrapper>\n <InputSelectRaw<{ selectView: OptionView }>\n onChange={setView}\n value={view}\n name={'selectView'}\n options={viewsOptions}\n getLabel={(option) => option.label}\n getValue={(option) => option.value}\n required\n minWidth={false}\n loading={isLoading}\n noMargin\n />\n </InputWrapper>\n <ButtonDropdown\n noMargin\n color={'primary'}\n icon={'icon-plus'}\n label={intl.formatMessage({ id: 'GLOBAL_Add' })}\n options={createCalendarEventOptions}\n dataCy={'calendar-create-dropdown'}\n />\n <Dropdown\n trigger={\n <IconButton\n aria-label={intl.formatMessage({ id: 'GLOBAL_Filter' })}\n colorVariant={'light'}\n icon={'icon-filter'}\n badgeNumber={types.length}\n />\n }\n dropdown={() => (\n <DropdownContainer>\n <FlexBox direction={'column'}>\n <Typography weight={'medium'} color={'primary'}>\n {intl.formatMessage({ id: 'GLOBAL_Filter' })}\n </Typography>\n <InputCheckboxRaw<Filter>\n labelPosition={'before'}\n checkboxMode={'checkbox'}\n direction={'column'}\n onChange={(f: Filter) => {\n dispatch(Calendar.actions.setTypes(f));\n navigateWithQuery({ types: f });\n }}\n options={viewOptionEntries}\n value={types}\n name={'0'}\n />\n <StyledHref\n onClick={() => {\n dispatch(Calendar.actions.setTypes([]));\n navigateWithQuery({ types: [] });\n }}\n as={'button'}\n color={'cancel'}\n disabled={types.length === 0}>\n {intl.formatMessage({ id: 'GLOBAL_Reset' })}\n </StyledHref>\n </FlexBox>\n </DropdownContainer>\n )}\n withBorder\n align={'right'}\n />\n <ButtonDropdown\n noMargin\n small\n smallOpenDirection={'left'}\n color={'primary'}\n variant={'outlined'}\n icon={'icon-ellipsis-v'}\n label={intl.formatMessage({ id: 'GLOBAL_Options' })}\n options={[\n {\n label: intl.formatMessage({ id: 'EVENT_Export_Calendar_ICalendar_Format' }),\n onClick: () => setExportModalOpen(true),\n },\n ]}\n />\n </FlexBox>\n );\n};\n","import { Calendar as CalendarSlice, Hook, Toast } from 'jamespot-front-business';\nimport { CalendarApi, CalendarEvent, CalendarView, JRCCalendarProps, Utils } from 'jamespot-react-components';\nimport jApi from 'jamespot-user-api';\nimport { Fragment, ReactNode, useCallback, useEffect, useMemo, useState } from 'react';\nimport { useIntl } from 'react-intl';\nimport { useNavigate } from 'react-router-dom';\nimport styled from 'styled-components';\nimport { CommentsBloc } from '../../components/CommentsBloc';\nimport useCalendarRT from '../../hooks/useCalendarRT';\nimport { useAppDispatch, useAppSelector } from '../../redux/store';\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\nimport { CalendarHeader } from './CalendarHeader';\nimport { CalendarToolbar } from './CalendarToolbar';\n\ntype Filter = ('socialEvent' | 'meeting' | 'animatedMeeting' | 'boardCard')[];\n\nconst Calendar = commonComponentsRegistry.getLazyComponent('Calendar');\n\nconst CommentsContainer = styled.div`\n margin-bottom: ${({ theme }) => theme.space.md}px;\n`;\n\nconst Header = styled.div<{ view: CalendarView }>`\n height: 54px;\n display: flex;\n align-items: center;\n justify-content: space-between;\n ${({ view, theme }) => view === 'list' && `border-bottom: 1px solid ${theme.color.grey2};`}\n padding: 0 ${({ theme }) => theme.space.md}px;\n`;\n\nconst options: { label: string; value: CalendarView }[] = [\n {\n label: 'CALENDAR_dayGridMonth',\n value: 'dayGridMonth',\n },\n {\n label: 'CALENDAR_timeGridWeek',\n value: 'timeGridWeek',\n },\n {\n label: 'CALENDAR_timeGridDay',\n value: 'timeGridDay',\n },\n {\n label: 'CALENDAR_listWeek',\n value: 'list',\n },\n];\n\nexport const CalendarWrapper = ({\n views = ['dayGridMonth', 'list', 'timeGridDay', 'timeGridWeek'],\n mode = 'full',\n withPadding = true,\n withHeader = true,\n withToolbar = true,\n fluid,\n children,\n onSelect,\n}: {\n views: Array<'dayGridMonth' | 'timeGridWeek' | 'timeGridDay' | 'list'>;\n mode?: JRCCalendarProps['mode'];\n fluid?: boolean;\n withPadding?: boolean;\n withHeader?: boolean;\n withToolbar?: boolean;\n onSelect?: (params: { start: Date; end: Date; allDay: boolean } | null) => void;\n children?({\n dates,\n eventToUpdate,\n creationType,\n isExportModalOpen,\n setCreationType,\n setEventToUpdate,\n setExportModalOpen,\n }: {\n dates?: { start: string; end: string };\n eventToUpdate?: CalendarEvent | null;\n creationType: string | null;\n isExportModalOpen: boolean;\n setEventToUpdate: React.Dispatch<React.SetStateAction<CalendarEvent | null>>;\n setCreationType: React.Dispatch<React.SetStateAction<'socialEvent' | 'meeting' | 'animatedMeeting' | null>>;\n setExportModalOpen: React.Dispatch<React.SetStateAction<boolean>>;\n }): ReactNode;\n}) => {\n const intl = useIntl();\n const dispatch = useAppDispatch();\n const navigate = useNavigate();\n useCalendarRT();\n const [label, setLabel] = useState<string>();\n const { dates, loading, list, pendingStatusChanges } = useAppSelector(CalendarSlice.selectors.selectCalendarEvents);\n const [calendarApi, setCalendarApi] = useState<CalendarApi>();\n const [eventToUpdate, setEventToUpdate] = useState<CalendarEvent | null>(null);\n const [isExportModalOpen, setExportModalOpen] = useState(false);\n const globalDefaultView = useAppSelector((state) => Hook.selectors.selectHook(state, 'calendarHook'))?.defaultView;\n const defaultView = useMemo(() => {\n const urlQuery = new URLSearchParams(window.location.search).get('view');\n switch (urlQuery) {\n case 'dayGridMonth':\n case 'timeGridDay':\n case 'timeGridWeek':\n case 'list':\n return urlQuery;\n default:\n return globalDefaultView === 'calendar' ? 'dayGridMonth' : 'list';\n }\n }, [globalDefaultView]);\n\n const viewsOptions = useMemo<{ label: string; value: CalendarView }[]>(\n () =>\n options\n .filter((el) => views.includes(el.value))\n .map((option) => {\n return { label: intl.formatMessage({ id: option.label }), value: option.value };\n }),\n [views, intl],\n );\n const [view, setView] = useState<(typeof viewsOptions)[number]>(\n viewsOptions.find((v) => v.value === defaultView) ?? viewsOptions[0],\n );\n\n const navigateWithQuery = useCallback(\n (queries: { types?: Filter; view?: CalendarView }) => {\n const params = new URLSearchParams(window.location.search);\n if (queries.types !== undefined) {\n if (queries.types.length > 0) {\n params.set('types', queries.types.join(','));\n } else {\n params.delete('types');\n }\n }\n if (queries.view !== undefined) {\n if (queries.view) {\n params.set('view', queries.view);\n } else {\n params.delete('view');\n }\n }\n navigate(`?${params.toString()}`, { replace: true });\n },\n [navigate],\n );\n\n const onError = useCallback(\n (err?: string) => {\n dispatch(Toast.actions.error({ label: err ?? intl.formatMessage({ id: 'GLOBAL_Error' }) }));\n },\n [dispatch, intl],\n );\n\n const onSuccess = useCallback(\n (message: string) => {\n dispatch(Toast.actions.success({ label: message }));\n },\n [dispatch],\n );\n\n const handleChangeView = useCallback(\n (view: { label: string; value: CalendarView }) => {\n setView(view);\n navigateWithQuery({ view: view.value });\n },\n [navigateWithQuery],\n );\n\n const handleChangeDates = useCallback(\n (start: Date, end: Date) => {\n const dates = { start: Utils.date.formatDate(start), end: Utils.date.formatDate(end) };\n dispatch(CalendarSlice.actions.setDates(dates));\n },\n [dispatch],\n );\n\n const [creationType, setCreationType] = useState<'socialEvent' | 'meeting' | 'animatedMeeting' | null>(null);\n\n useEffect(() => {\n dispatch(\n CalendarSlice.actions.setTypes(\n (new URLSearchParams(window.location.search)\n .get('types')\n ?.split(',')\n .filter((type) =>\n ['socialEvent', 'meeting', 'animatedMeeting', 'boardCard'].includes(type),\n ) as Filter) ?? [],\n ),\n );\n }, [dispatch]);\n\n return (\n <Fragment>\n {children &&\n children({\n dates,\n eventToUpdate,\n creationType,\n isExportModalOpen,\n setEventToUpdate,\n setCreationType,\n setExportModalOpen,\n })}\n {(withHeader || withToolbar) && (\n <Header view={view.value}>\n {withHeader && <CalendarHeader />}\n {withToolbar && (\n <CalendarToolbar\n label={label}\n isLoading={loading === 'pending'}\n view={view}\n calendarApi={calendarApi}\n viewsOptions={viewsOptions}\n navigateWithQuery={navigateWithQuery}\n setView={setView}\n setCreationType={setCreationType}\n setExportModalOpen={setExportModalOpen}\n />\n )}\n </Header>\n )}\n <Calendar\n fluid={fluid}\n mode={mode}\n fullScreen\n withPadding={withPadding}\n events={list}\n loading={loading === 'pending'}\n handler={{\n global: jApi.global,\n calendar: jApi.calendar,\n article: jApi.article,\n }}\n defaultView={view.value}\n eventModalExtraComponent={({ id, uri, _right }) => {\n return (\n <CommentsContainer>\n <CommentsBloc articleId={id} articleUri={uri} canComment={_right.comment} />\n </CommentsContainer>\n );\n }}\n deportedToolbar={{\n onChangeLabel: setLabel,\n onCalendarApiInit: setCalendarApi,\n view,\n }}\n onChangeDates={handleChangeDates}\n onError={onError}\n onSuccess={onSuccess}\n onChangeView={handleChangeView}\n onDeleteEvent={() => {\n dispatch(\n Toast.actions.success({ label: intl.formatMessage({ id: 'GLOBAL_Successfully_Deleted' }) }),\n );\n }}\n onClickUpdateEvent={setEventToUpdate}\n onUpdateStatus={(params) => dispatch(CalendarSlice.actions.changeResponse(params))}\n isUpdateStatusLoading={(id) => pendingStatusChanges.some((psc) => psc.eventId === id)}\n onSelect={onSelect}\n />\n </Fragment>\n );\n};\n","import { useEffect, useMemo } from 'react';\nimport { Calendar } from 'jamespot-front-business';\nimport socket from '../utils/socket';\nimport { useAppDispatch } from '../redux/store';\nimport jApi from 'jamespot-user-api';\n\nconst useCalendarRT = () => {\n const dispatch = useAppDispatch();\n const reactSocket = useMemo(() => socket, []);\n const rtHandlers = useMemo(() => Calendar.getCalendarRTHandlers(dispatch, jApi), [dispatch]);\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 useCalendarRT;\n","import styled from 'styled-components';\nimport { EDITOR_MENU_WIDTH, EDITOR_WIDTH } from './const';\nimport { DashedFocusBorder } from 'jamespot-react-components';\n\nconst INPUT_HEIGHT = 50;\nconst RADIUS = 8;\n\nexport const CSSEditorComponentWrapper = styled.div`\n margin-bottom: 24px;\n`;\n\nexport const CSSEditorComponentLabel = styled.div`\n margin-bottom: 4px;\n`;\n\nexport const CSSEditorPortal = styled.div<{ isActive: boolean }>`\n position: absolute;\n background-color: ${(props) => (props.isActive ? 'rgba(0,0,0,.1)' : 'transparent')};\n inset: 0;\n pointer-events: ${(props) => (props.isActive ? 'all' : 'none')};\n flex: 1;\n display: flex;\n overflow: hidden;\n`;\n\nexport const CSSEditorHeader = styled.div`\n flex-direction: row;\n display: flex;\n min-height: 60px;\n border-bottom: 1px solid ${(props) => props.theme.color.grey2};\n`;\n\nexport const CSSEditorAction = styled.div`\n width: 60px;\n display: flex;\n align-items: center;\n justify-content: center;\n`;\n\nexport const CSSEditorLabel = styled.div`\n flex: 1;\n display: flex;\n align-items: center;\n justify-content: center;\n`;\n\n// This is a mask to hide top shadow. EDITOR_WIDTH + 20 is used to keep the left shadow\nexport const CSSEditorMask = styled.div`\n position: relative;\n overflow: hidden;\n top: 0px;\n width: ${EDITOR_WIDTH + 20}px;\n`;\n\nexport const CSSEditor = styled.div<{ position: 'left' | 'right' }>`\n position: absolute;\n top: 0;\n ${(props) => (props.position === 'left' ? 'left: 0px;' : '')}\n ${(props) => (props.position === 'right' ? 'right: -1000px;' : '')}\n width: ${EDITOR_WIDTH}px;\n bottom: 00px;\n display: flex;\n background-color: ${(props) => props.theme.color.white};\n flex-direction: row;\n transition: all 0.4s;\n box-shadow: -4px 0px 20px 0px #00000017;\n\n &.animate {\n right: 0px;\n }\n`;\n\nexport const CSSEditorContent = styled.div`\n flex: 1;\n display: flex;\n flex-direction: column;\n padding: 12px;\n overflow: auto;\n margin-bottom: 12px;\n position: relative;\n`;\n\nexport const CSSEditorTab = styled.div`\n flex: 1;\n display: flex;\n flex-direction: column;\n`;\n\nexport const CSSEditorIsBusy = styled.div`\n position: absolute;\n inset: 0;\n background-color: rgba(255, 255, 255, 0.8);\n display: flex;\n align-items: center;\n justify-content: center;\n`;\n\nexport const CSSEditorIsLocked = styled.div`\n position: absolute;\n inset: 0;\n background-color: ${(props) => props.theme.color.white};\n padding: ${(props) => props.theme.space.md}px;\n`;\n\nexport const CSSEditorMenu = styled.div`\n width: ${EDITOR_MENU_WIDTH}px;\n padding-top: 60px;\n display: flex;\n flex-direction: column;\n border-right: 1px solid ${(props) => props.theme.color.grey2};\n`;\n\nexport const CSSEditorMenuButton = styled.button<{ isActive?: boolean }>`\n border-radius: 4px;\n cursor: pointer;\n height: 42px;\n margin: 4px;\n width: 42px;\n display: flex;\n align-items: center;\n justify-content: center;\n background-color: ${(props) => (props.isActive ? props.theme.color.grey2 : props.theme.color.white)};\n\n ${DashedFocusBorder()}\n\n &:hover {\n background-color: ${(props) => props.theme.color.grey2};\n }\n`;\n\nexport const CSSInputWrapper = styled.div`\n display: flex;\n border: 1px solid ${(props) => props.theme.color.grey1};\n border-radius: ${RADIUS}px;\n margin-bottom: 24px;\n input {\n width: 100%;\n border: 0;\n height: ${INPUT_HEIGHT}px;\n margin: 0;\n }\n`;\n\nexport const CSSEditorWidget = styled.div`\n display: flex;\n flex-direction: row;\n padding: 12px;\n background-color: ${(props) => props.theme.color.grey0};\n border-radius: 8px;\n margin-bottom: 4px;\n`;\n\nexport const CSSEditorWidgetLabel = styled.div`\n display: flex;\n flex: 1;\n align-items: center;\n`;\n\nexport const CSSEditorWidgetOption = styled.div`\n width: 40px;\n display: flex;\n justify-content: center;\n align-items: center;\n`;\n\nexport const CSSEditorLayer = styled.div`\n flex-direction: row;\n display: flex;\n align-items: center;\n`;\n\nexport const CSSEditorLayerTitle = styled.div`\n flex: 1;\n display: flex;\n align-items: center;\n`;\n","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 { CSSEditorAction, CSSEditorHeader, CSSEditorLabel, CSSEditorMenuButton } from './style';\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\nimport { WidgetEditor } from 'jamespot-front-business';\nimport { useAppDispatch, useAppSelector } from '../../redux/store';\n\nconst JRCButton = commonComponentsRegistry.getLazyComponent('Button');\nconst JRCIcon = commonComponentsRegistry.getLazyComponent('Icon');\n\n/*\n Editor popup (center part)\n*/\nexport const EditorPopup = ({ uniqid }: { uniqid: string }) => {\n const dispatch = useAppDispatch();\n const editor = useAppSelector((state) => WidgetEditor.selectors.selectEditor(state, uniqid));\n\n const onClick = () => {\n dispatch(WidgetEditor.slice.actions.flushEditorPopup({ uniqid }));\n };\n\n const onSave = () => {\n dispatch(WidgetEditor.slice.actions.flushEditorPopup({ uniqid }));\n };\n\n if (editor && editor.popup && editor.view) {\n return (\n <div style={{ flex: 1, display: 'flex', flexDirection: 'column', backgroundColor: 'white', marginTop: 90 }}>\n <CSSEditorHeader>\n <CSSEditorAction />\n <CSSEditorLabel>Popup</CSSEditorLabel>\n <CSSEditorAction>\n <CSSEditorMenuButton onClick={onClick}>\n <JRCIcon name=\"icon-times\" color=\"grey2\" size={26.75} />\n </CSSEditorMenuButton>\n </CSSEditorAction>\n </CSSEditorHeader>\n <div style={{ flex: 1, display: 'flex' }}>{editor.view}</div>\n <CSSEditorHeader>\n <JRCButton onClick={onSave}>Save</JRCButton>\n </CSSEditorHeader>\n </div>\n );\n }\n\n return <></>;\n};\n","import { Hook, Toast, updateWidgetContent, Widget, WidgetEditor } from 'jamespot-front-business';\nimport jamespot, {\n CombinedWidgetContent,\n ensureWidgetArticleAttachmentType,\n ensureWidgetArticleButtonType,\n ensureWidgetArticleGalleryType,\n ensureWidgetArticleImageType,\n ensureWidgetArticleSliderType,\n ensureWidgetArticleTextType,\n ensureWidgetArticleTitleType,\n ensureWidgetCalendarCalDavType,\n ensureWidgetCheckListType,\n ensureWidgetContactCardDavType,\n ensureWidgetDatasourceTableType,\n ensureWidgetEmailsImapType,\n ensureWidgetExcelDatasourceTableType,\n ensureWidgetLuccaAbsenceType,\n ensureWidgetPresenceType,\n ensureWidgetQuickSurveyType,\n ensureWidgetUserProfileType,\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 WidgetUserProfileContent,\n} from 'jamespot-user-api';\nimport { 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 WidgetLuccaAbsenceEditor = commonComponentsRegistry.getLazyComponent('WidgetLuccaAbsenceEditor');\n\nconst WidgetEmailsImapEditor = commonComponentsRegistry.getLazyComponent('WidgetEmailsImapEditor');\nconst WidgetContactCardDavEditor = commonComponentsRegistry.getLazyComponent('WidgetContactCardDavEditor');\nconst WidgetCalendarCalDavEditor = commonComponentsRegistry.getLazyComponent('WidgetCalendarCalDavEditor');\n\nconst WidgetUserProfileEditor = commonComponentsRegistry.getLazyComponent('WidgetUserProfileEditor');\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 (ensureWidgetLuccaAbsenceType(widget)) {\n return <WidgetLuccaAbsenceEditor />;\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 if (ensureWidgetUserProfileType(widget)) {\n return (\n <WidgetUserProfileEditor\n uniqid={widget.uniqid}\n content={widget.content}\n onChangeContent={(uniqid, content) => {\n dispatch(updateWidgetContent<WidgetUserProfileContent>(uniqid, content, false));\n }}\n />\n );\n } else {\n return <>cannot display editor</>;\n }\n};\n","import { CSSEditorAction, CSSEditorMenuButton } from './style';\nimport { WidgetEditor } from 'jamespot-front-business';\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\nimport { useAppDispatch } from '../../redux/store';\n\nconst Icon = commonComponentsRegistry.getLazyComponent('Icon');\n\nimport { useTheme } from 'styled-components';\n\nexport const EditorPosition = ({ uniqid, position }: { uniqid: string; position: 'left' | 'right' }) => {\n const dispatch = useAppDispatch();\n const theme = useTheme();\n const onClick = () => {\n dispatch(\n WidgetEditor.slice.actions.setEditorPosition({ uniqid, position: position === 'left' ? 'right' : 'left' }),\n );\n };\n\n return (\n <CSSEditorAction>\n <CSSEditorMenuButton onClick={onClick}>\n <Icon\n name={position === 'left' ? 'icon-angle-right' : 'icon-angle-left'}\n color={theme.color.lavender}\n size={26.75}\n />\n </CSSEditorMenuButton>\n </CSSEditorAction>\n );\n};\n","import 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 theme.color.transparentHexa,\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 { useForm } from 'react-hook-form';\nimport { useIntl } from 'react-intl';\n\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\nimport { useEffect } from 'react';\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 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 { useEffect, useMemo } from 'react';\nimport { useForm } from 'react-hook-form';\n\nexport type EditorSelectOption = { label: string; value: string };\nexport type EditorSelectOptions = EditorSelectOption[];\n\nimport { commonComponentsRegistry } from '../../../registry/CommonRegistry';\n\nconst InputSelectExtended = commonComponentsRegistry.getLazyComponent('InputSelectExtended');\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 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 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 <InputSelectExtended\n options={options}\n label={label}\n getValue={(o) => o.value}\n getLabel=\"label\"\n getSearch=\"label\"\n rules={{ required }}\n hideDeleteIcon={true}\n required={required}\n control={control}\n name={'select'}\n />\n );\n};\n","import { Widget } from 'jamespot-front-business';\nimport { useCallback, useEffect, useMemo } from 'react';\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 { shallowEqual } from 'react-redux';\nimport { useTheme } from 'styled-components';\nimport { useAppDispatch, useAppSelector } from '../../redux/store';\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\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 widgetContext = useAppSelector((state) => Widget.selectors.selectWidgetContext(state, uniqid), shallowEqual);\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(/&amp;/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 {widgetContext !== 'comment' && (\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 );\n};\n","import { 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 { 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 { 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 { 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 {typeof initialValues.borderStyle === 'string' && initialValues.borderStyle !== 'none' && (\n <EditorInputColor\n label={'STYLE_Border_Color'}\n initialValue={initialValues.borderColor}\n handleChange={(borderColorValue) => handleChange('border-color', borderColorValue)}\n />\n )}\n {typeof initialValues.borderStyle === 'string' && initialValues.borderStyle !== '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 { 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 { 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\n .filter((tab) => tab.enable)\n .map((tab) => {\n return (\n <CSSEditorMenuButton\n key={tab.name}\n isActive={currentTab && currentTab.name === tab.name}\n onClick={() => setCurrentTab(tab)}>\n <Tooltip position={'left'} description={tab.label}>\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 </Tooltip>\n </CSSEditorMenuButton>\n );\n })}\n </CSSEditorMenu>\n <div style={{ flex: 1, display: 'flex', flexDirection: 'column', width: `${EDITOR_CONTENT_WIDTH}px` }}>\n <CSSEditorHeader>\n <EditorPosition uniqid={uniqid} position={editor.position} />\n <CSSEditorLabel>\n <h3>{currentTab ? currentTab.label : intl.formatMessage({ id: def.label })}</h3>\n </CSSEditorLabel>\n <CSSEditorAction>\n <CSSEditorMenuButton onClick={onClose}>\n <Icon name=\"icon-times\" color={theme.color.lavender} size={26.75} />\n </CSSEditorMenuButton>\n </CSSEditorAction>\n </CSSEditorHeader>\n <CSSEditorContent>\n <CSSEditorTab>\n {currentTab && currentTab.name === 'widget-settings' && def.panel.useEditor && (\n <Editor uniqid={editor.uniqid} />\n )}\n {currentTab && currentTab.name === 'widget-title' && def.panel.useWrapper && (\n <EditorTabWrapper uniqid={editor.uniqid} />\n )}\n {currentTab && currentTab.name === 'widget-selection' && (\n <EditorTabWidgetSelection uniqid={uniqid} />\n )}\n {currentTab && currentTab.name === 'widget-level' && enableWidgetLevel && (\n <EditorTabDisplayLevel uniqid={uniqid} />\n )}\n </CSSEditorTab>\n <EditorIsBusy uniqid={uniqid} />\n <EditorIsLocked uniqid={uniqid} />\n {OVERRIDE_SAVE.includes(editor.name) && <EditorSave uniqid={uniqid} mode={editor.mode} />}\n </CSSEditorContent>\n </div>\n </CSSEditor>\n {editor?.popup ? (\n <div style={{ position: 'absolute', inset: 0, backgroundColor: '#000', opacity: '.7' }}></div>\n ) : (\n <></>\n )}\n </CSSEditorMask>\n ) : (\n <></>\n );\n};\n","import { useEffect } from 'react';\n\nimport { shallowEqual } from 'react-redux';\n\nimport { EDITOR_TOP, EDITOR_WIDTH } from './const';\nimport { EditorPopup } from './EditorPopup';\nimport { EditorWrapper } from './EditorWrapper';\nimport { CSSEditorPortal } from './style';\nimport { WidgetEditor } from 'jamespot-front-business';\n\nimport styled from 'styled-components';\nimport { useAppDispatch, useAppSelector } from '../../redux/store';\n\nexport const CSSEditorPortalWrapper = styled.div`\n position: absolute;\n inset: 0;\n pointer-events: none;\n z-index: 1;\n`;\n\nexport const CSSEditorPortalPopupWrapper = styled.div<{ isActive: boolean }>`\n flex: 1;\n display: flex;\n margin-top: ${EDITOR_TOP}px;\n pointer-events: ${(props) => (props.isActive ? 'all' : 'none')};\n`;\n\nexport const CSSEditorPortalRow = styled.div`\n flex: 1;\n display: flex;\n flex-direction: row;\n pointer-events: none;\n`;\n\nexport const CSSEditorPortalFreeSpace = styled.div`\n width: ${EDITOR_WIDTH}px;\n pointer-events: none;\n`;\n\n/*\n Editors wrapper (template)\n*/\nexport const EditorsPortal = () => {\n const dispatch = useAppDispatch();\n useEffect(() => {\n const flush = () => {\n dispatch(WidgetEditor.slice.actions.flushAllEditor());\n };\n\n window.addEventListener('NGWidgetEditorFlushAll', flush);\n return () => {\n window.removeEventListener('NGWidgetEditorFlushAll', flush);\n };\n }, [dispatch]);\n\n const editors = useAppSelector(WidgetEditor.selectors.selectEditors, shallowEqual);\n\n return (\n <CSSEditorPortalWrapper className=\"editor-portal-wrapper\">\n {editors.map((editor) => {\n return (\n <CSSEditorPortal isActive={false} key={editor.uniqid}>\n <CSSEditorPortalRow>\n {editor.position === 'left' ? (\n <>\n <EditorWrapper uniqid={editor.uniqid} position={editor.position}></EditorWrapper>\n <CSSEditorPortalPopupWrapper isActive={editor.popup !== undefined}>\n <EditorPopup uniqid={editor.uniqid} />\n </CSSEditorPortalPopupWrapper>\n <CSSEditorPortalFreeSpace />\n </>\n ) : (\n <>\n <CSSEditorPortalFreeSpace />\n <CSSEditorPortalPopupWrapper isActive={editor.popup !== undefined}>\n <EditorPopup uniqid={editor.uniqid} />\n </CSSEditorPortalPopupWrapper>\n <EditorWrapper uniqid={editor.uniqid} position={editor.position}></EditorWrapper>\n </>\n )}\n </CSSEditorPortalRow>\n </CSSEditorPortal>\n );\n })}\n </CSSEditorPortalWrapper>\n );\n};\n","// FIXME move to j-react-components + display error if dev mode\nexport const Empty = () => <></>;\n","import { Suspense } from 'react';\nimport { Outlet } from 'react-router-dom';\nimport { commonComponentsRegistry } from '../registry/CommonRegistry';\n\nconst Container = commonComponentsRegistry.getLazyComponent('Container');\n\n// TODO: when we use it more globally, we will wanted to add a common header to not repeat it.\n// an exemple is in the @TwoColLayout component.\n// Currently (2025-08-20), calendar and accessibility are the only components that use it.\nexport const FullPageLayout = () => {\n return (\n <Suspense fallback={<></>}>\n <Container backgroundColor={'white'} mode={'fluid'} flexDirection={'column'}>\n <Outlet />\n </Container>\n </Suspense>\n );\n};\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 (\n J.hooks?.MagicWandHook?.isActive &&\n J.hooks?.MagicWandHook?.menuItems &&\n J.hooks.MagicWandHook.menuItems.length\n );\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 { 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';\nimport { GifsModal } from './extension/GifsModal';\nimport { useGifsModal } from '../../hooks/useGifsModal';\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 const {\n close: closeGifsModal,\n open: gifsModalOpen,\n isActive: isGifsActive,\n onSelect,\n ext: gifsExt,\n } = useGifsModal();\n\n const extArray = useMemo(() => {\n return [\n ...(isMarkdownActive ? [extMarkdown] : []),\n ...(isAIActive ? [extAI] : []),\n ...(isGifsActive ? [gifsExt] : []),\n ];\n }, [extAI, extMarkdown, gifsExt, isAIActive, isGifsActive, 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 {isGifsActive && <GifsModal onSelect={onSelect} open={gifsModalOpen} close={closeGifsModal} />}\n </>\n );\n};\n","import { Model, Toast } from 'jamespot-front-business';\nimport { 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 { FormattedMessage, useIntl } from 'react-intl';\r\nimport { Control } from 'react-hook-form';\r\nimport jamespot from 'jamespot-user-api';\r\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\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 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 dataCy: 'no-audience-continue',\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 />\r\n </JRCModal>\r\n );\r\n};\r\n","import { useEffect, useMemo } from 'react';\r\nimport { FormattedMessage, useIntl } from 'react-intl';\r\nimport { commonComponentsRegistry } from '../../registry/CommonRegistry';\r\nimport { useForm, useWatch } from 'react-hook-form';\r\nimport { Utils } from 'jamespot-react-components';\r\nimport { v4 as uuid } from 'uuid';\r\nimport { Platform, Toast } from 'jamespot-front-business';\r\nimport { useAppDispatch, useAppSelector } from '../../redux/store';\r\nimport styled from 'styled-components';\r\nimport { padStartTwoDigits } from 'jamespot-user-api';\r\n\r\nconst ModalForm = commonComponentsRegistry.getLazyComponent('ModalForm');\r\nconst InputDateTime = commonComponentsRegistry.getLazyComponent('InputDateTime');\r\nconst InputTextRaw = commonComponentsRegistry.getLazyComponent('InputTextRaw');\r\nconst FlexBox = commonComponentsRegistry.getLazyComponent('FlexBox');\r\nconst IconButton = commonComponentsRegistry.getLazyComponent('IconButton');\r\n\r\ntype ScheduleData = {\r\n scheduleDate: string;\r\n permalinkId: string;\r\n};\r\n\r\nexport type ModalScheduleProps = {\r\n open: boolean;\r\n closeHandler: () => void;\r\n onSubmit: (data: ScheduleData) => void;\r\n};\r\n\r\nconst IconButtonWrapper = styled.div`\r\n margin-bottom: ${({ theme }) => theme.space.xs}px;\r\n`;\r\n\r\nexport const ModalSchedule = ({ open, closeHandler, onSubmit }: ModalScheduleProps) => {\r\n const intl = useIntl();\r\n const dispatch = useAppDispatch();\r\n const urlBase = useAppSelector(Platform.selectors.selectUrlBase);\r\n const form = useForm<ScheduleData>({\r\n defaultValues: async () => {\r\n const now = new Date();\r\n return {\r\n scheduleDate: `${Utils.date.formatDate(now)} ${padStartTwoDigits(now.getHours())}:${padStartTwoDigits(now.getMinutes())}`,\r\n permalinkId: uuid(),\r\n };\r\n },\r\n });\r\n\r\n const onSubmitHandler = form.handleSubmit((data) => {\r\n onSubmit(data);\r\n });\r\n\r\n useEffect(() => {\r\n if (open) {\r\n form.reset();\r\n }\r\n }, [form, open]);\r\n\r\n const permalinkId = useWatch({ control: form.control, name: 'permalinkId' });\r\n const permalink = useMemo(() => {\r\n return `${urlBase}permalink/${permalinkId}`;\r\n }, [permalinkId, urlBase]);\r\n\r\n return (\r\n <ModalForm\r\n open={open}\r\n closeHandler={closeHandler}\r\n onSubmit={onSubmitHandler}\r\n maxHeight={'620px'}\r\n title={intl.formatMessage({ id: 'GLOBAL_Schedule' })}\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_Schedule\" />,\r\n color: 'valid',\r\n clickHandler: () => {\r\n closeHandler();\r\n onSubmitHandler();\r\n },\r\n disabled: !form.watch('scheduleDate'),\r\n },\r\n ]}>\r\n <InputDateTime\r\n rules={{ required: true }}\r\n label={'GLOBAL_Scheduled_Date'}\r\n control={form.control}\r\n name={'scheduleDate'}\r\n />\r\n <FlexBox y={'flex-end'}>\r\n <InputTextRaw\r\n label={intl.formatMessage({ id: 'GLOBAL_Permalink' })}\r\n value={permalink}\r\n onChange={() => null}\r\n margin={'0'}\r\n width={'100%'}\r\n />\r\n <IconButtonWrapper>\r\n <IconButton\r\n srOnly={'GLOBAL_Copy_Link'}\r\n icon={'icon-copy'}\r\n colorVariant={'primary'}\r\n onClick={() => {\r\n navigator.clipboard.writeText(permalink).then(() => {\r\n dispatch(\r\n Toast.actions.success({\r\n label: intl.formatMessage({ id: 'CLIPBOARD_Copy_Success' }),\r\n }),\r\n );\r\n });\r\n }}\r\n />\r\n </IconButtonWrapper>\r\n </FlexBox>\r\n </ModalForm>\r\n );\r\n};\r\n","import { 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({\n extensionRoute,\n routes,\n description,\n mode = 'center',\n mainColumnProps,\n}: 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} {...mainColumnProps}>\n <Outlet />\n </MainColumn>\n </Container>\n </Suspense>\n );\n}\n"],"names":["JRCIcon","getLazyComponent","JRCAvatar","SR","SROnly","Avatar","props","theme","useTheme","intl","useIntl","networkPublic","selectors","selectNetworkPublic","uri","name","size","color","primary","variant","formatMessage","id","JRCFlexBox","JRCModalContent","JRCModalLayout","JRCStyledHref","JRCTooltip","JRCTypography","AudienceWrapper","AvatarLink","white","lavender","overlap","Audience","audience","limit","isModalOpen","setModalOpen","useState","splice","map","item","index","href","_url","target","description","undefined","title","position","alt","timestamp","dateModified","Utils","date","strToTimestamp","focusable","length","onClick","closeHandler","enableClickAwayCloseModal","open","maxHeight","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","StretchContainer","css","Container","stretch","Form","FormElm","forwardRef","ref","onSubmit","dataCy","FieldsetWrapper","DisplayForm","onInit","formRef","useRef","configuration","defaultValues","useDisplay","fields","forceMandatory","isInit","setIsInit","handleSubmit","control","reset","formFn","useForm","criteriaMode","formatValuesForSubmit","values","toRet","Object","keys","forEach","k","widget","find","c","v","join","useImperativeHandle","current","scrollTo","getFormattedValues","getValues","Input","conf","readOnly","extraInputs","ModalForm","Loader","Icon","Typography","Ellipsis","StyledHref","ContentPreview","grey2","grey0","sm","ContentWrapper","AddReportModal","onClose","articleId","articleUri","commentUri","dispatch","setOpen","article","setArticle","comment","setComment","contentLoading","setContentLoading","submitLoading","setSubmitLoading","abortController","Promise","all","res","get","idArticle","signal","format","getComments","closeModal","submit","createReport","actions","success","label","e","submitForm","async","FormattedMessage","_user","CSSSquareWidgetWrapper","CSSSquareWidget","available","CSSWidgetButton","height","CSSWrapWidgetWrapper","column","CSSWrapTitle","CSSWrapWidget","parentIsColumn","grey1","full","DashedFocusBorder","Flex","direction","JRCButton","JRCIconButton","WidgetList","mode","view","namespace","onChange","isOpen","widgets","definition","WidgetsName","ArticleTitle","ArticleButton","CheckList","Presence","QuickSurvey","ArticleText","ArticleImage","ArticleSlider","ArticleAttachment","getBuilderWidgets","args","portalId","factory","src","img","className","minWidth","WidgetModeArticle","WidgetModeComment","calcHeight","useMemo","Math","ceil","bg","bgHover","iconSize","icon","useMarkdownModal","editor","setEditor","onInsert","execCommand","close","ext","JTinyMCEExtensionsBuilders","markdown","ed","isActive","JRCInputFileAdvancedRaw","CSSHidden","WidgetUploader","initialFiles","initialClick","multiple","accept","onUploadStart","onUploadEnd","onUploadSuccess","uploadRef","token","selectToken","total","setTotal","files","setFiles","click","content","totalFile","prevTotal","fileResponse","prevFiles","WidgetAttachment","JRCWidgetEmptyInplace","FileViewer","CSSWrapper","JRCWidgetArticleAttachmentWrapper","inplace","uniqid","state","shallowEqual","onError","message","slice","setWidgetState","mounted","empty","weDoc","selectById","option","file","getAccessHash","Error","hash","idFile","window","getWedocFilePath","wedocWindowOpen","openWithOptions","condition","f","includes","mimetype","options","resolveFilePath","Array","isArray","url","JRCWidgetButton","CSSButtonWrapper","CSSPointer","clickable","JRCWidgetArticleButtonWrapper","backgroundColor","buttonSize","borderRadius","registerEditor","JRCWidgetArticleGallery","CSSImagePointer","JRCWidgetArticleGalleryWrapper","maxWidth","CSSWidgetTitle","UITitle","textAlign","fontSize","fontWeight","WidgetIntranetTitle","widgetWrapper","selectWidget","UIHeaderWrapper","backroundColor","UIHeader","UIHeaderFlex","grey4","xs","WidgetHeader","dropdown","subHeader","styles","selectWidgetTitleStyle","styleValues","String","black","UIFlex","UIScrollWrapper","UIScroll","WidgetScroll","header","scrollable","footer","UIWrapper","WidgetStylePadding","selectWidgetWrapperStyle","initialValues","padding","style","UIOverlay","WidgetLuccaAbsence","JRCWidgetLuccaAbsenceWrapper","list","setList","setError","isLoading","setIsLoading","today","Date","getFullYear","getMonth","toString","padStart","getDate","getAbsence","aborted","finally","WidgetImage","CSSImageWrapperHover","mockFileLittle","mainType","dateCreation","str","parse","isNaN","getTime","JRCWidgetArticleImageWrapper","width","useFilter","setUri","formatImgUrl","now","from","path","JRCWidgetSlider","Wrapper","JRCWidgetArticleSliderWrapper","dynamicWidth","setDynamicWidth","fileViewerFiles","slides","slide","handleResize","offsetWidth","addEventListener","removeEventListener","isEditable","handleEditor","useDots","loop","startAt","onClickSlide","InputTextareaRaw","Modal","MarkdownModal","setMarkdown","doClose","disabled","replace","value","WidgetArticleText","CSSTextWrapper","JRCWidgetArticleTextWrapper","isBusy","selectWidgetState","busy","tinyMCECommonOptions","selectTinyMCECommonOptions","models","selectAll","closeMarkdownModal","extMarkdown","isMarkdownActive","tinyMentionsQueries","autoFocus","commonOptions","mentionsQueries","additionalExtensions","handlers","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","JRCInputText","WidgetInlineInputText","placeholder","handleClick","setLabel","watch","subscription","data","unsubscribe","WidgetIsPending","WidgetCheckList","WidgetCheckListEditor","JRCFileViewer","CommentContainer","border","CSSWidgetCheckListWrapper","JRCWidgetCheckListWrapper","onWidgetUpdate","widgetContent","setToken","tokenLoading","setTokenLoading","entries","setEntries","isPending","setIsPending","tokenFromStore","selectWidgetObjectUri","allRt","selectAllWidgetRTObject","canEditCollaboration","canAdministrate","administrate","fetchToken","handleReloadWidget","getWidget","ensureWidgetCheckListType","err","openEditorPanel","flushAllEditor","finalEntries","arr","checked","links","user","lastRt","at","object","fn","handleCollabAddEntry","contentToUpdate","updateWidget","v2","fs","el","push","w","html","htmlDecodeSpecialChars","onChangeContent","onChangeWrapper","updateWidgetWrapper","handleChange","useRT","initialEntries","onFileClick","entry","onItemCheckListChange","checkListRespond","handleCheckItem","edit","getVisibleColumns","tableColumnsData","columns","filter","isVisible","WidgetTable","AbsoluteWrapper","WidgetDatasourceTableWrapper","tableHeadColor","tableHeadTextColor","tableHeadIconColor","tableRowColor","tableRowTextColor","tableBorderRadius","tableSizedColumns","tableSizedColumnsWidth","datasourceData","setDatasourceData","datasourceModel","setDatasourceModel","datasourceSort","setDatasourceSort","order","datasourceType","setDatasourceType","datasourceIdentifier","setDatasourceIdentifier","DatasourceTable","rtConditions","rtAudience","rtLastObject","fetchDatasource","Format","VIEW","model","sort","datasource","rows","tableDefaultSortOrder","tableDefaultSortName","WidgetExcelDatasourceTableWrapper","ExcelDatasourceTable","CSSPaddingMd","CSSHref","secondary","CSSHorizontalAlign","WidgetPresenceWrapperClosing","handleClosing","isClosed","JRCWidgetPresence","ModalUserList","CSSWidgetPresenceWrapper","CSSWidgetPresenceIsClosed","orange","JRCWidgetPresenceWrapper","limitValue","closing","userValue","userAvailableList","userUnavailableList","userAvailableTotal","userUnavailableTotal","isPendingResponse","setIsPendingResponse","AbortController","openUsersModal","setOpenUsersModal","usersListIndex","setUsersListIndex","usersList","setUsersList","handleError","canRespond","lockedRespondHandler","handleCancelRespond","presenceCancel","handleRespond","presenceRespond","handleResponse","presenceGetResponse","handleLoadUsersList","page","presenceGetResponseUserList","cnt","elm","abort","handleClickAvailable","handleClickUnavailable","handleOpenUsersModal","WidgetQuickSurvey","WidgetQuickSurveyEditor","WrapperContainer","withPadding","JRCWidgetQuickSurveyWrapper","userResponses","totalRespondent","totalResponse","userLoggedResponses","quickSurveyGetResponse","handleWidgetGet","handleCloseSurvey","finalContent","handleProgressBarClick","quickSurveyRespond","multi","quickSurveyGetResponseUserList","userHasAlreadyVoted","canCloseSurvey","anonymize","seeResponseAfter","handleClickFile","newContent","quickSurveyAddEnty","WidgetUserProfile","JRCWidgetUserProfileWrapper","currentUser","pictureSize","displayMode","buttonName","ModalLayout","ModalContent","InputText","InputNumber","InputSelectExtended","InputPassword","UIForm","isLocked","UIProviderError","UISection","officeConfigurationInitialState","username","password","hostname","imapPort","imapConnectionSecurity","ImapConnection","NONE","imapMailbox","cardDavAddressBook","calDavCalendar","provider","OfficeConfigurationPrompt","useAbortController","setValue","formState","isValid","providerList","setProviderList","imapConnectionSecurityOptions","SSL","STARTTLS","fetchConfiguration","providers","getConfiguration","getProviders","handleClose","hasProvider","radius","SelectProvider","initialValue","rules","required","loader","setConfiguration","location","reload","getValue","o","getLabel","getSearch","ButtonDropdown","Tooltip","UIDropdown","WidgetContactCardDavHeader","isConfigurationValid","handleLogout","useDispatch","small","smallOpenDirection","WidgetContactCardDav","JRCWidgetContactCardDavWrapper","levelFallback","setIsConfigurationValid","setUrl","doInterval","setDoInterval","level","selectWidgetLevel","initialized","handleLogin","handleLoading","fetchProviderUrls","getProviderBaseUrls","dav_address_book_url","fetchData","davAddressBookGetContacts","WIDGET_LEVEL_3","interval","setInterval","clearInterval","WIDGET_LEVEL_1","contactCardList","WidgetCalendarCalDavHeader","WidgetCalendarCalDav","JRCWidgetCalendarCalDavWrapper","dav_calendar_url","nextMonth","addMonth","davCalendarGetEvents","dateStart","formatDateTime","dateEnd","calendarListEvent","WidgetEmailsImapHeader","count","selectWidgetChipCount","WidgetEmailsImap","JRCWidgetEmailsImapWrapper","fetchUnreadEmailsCount","imapInboxGetUnreadEmailsCount","setWidgetChipCount","imap_inbox_url","imapInboxGetEmails","WIDGET_LEVEL_2","emailList","JRCHtml","WidgetTitle","as","__html","WidgetTitleEdit","widgetWrapperTitle","widgetTitle","margin","CSSModalFooter","CSSWidgetHeaderEdit","CSSWidgetHeaderEditTitle","CSSWidgetHeaderEditActions","WidgetHeaderEdit","handleRemoveWidget","UILicenseRequired","WidgetLicenseWrapper","hook","selectHook","hasLicense","CSSWidgetWithTitle","DisplayWidget","cannotDisplayComponent","ensureWidgetArticleButtonType","ensureWidgetArticleGalleryType","ensureWidgetLuccaAbsenceType","ensureWidgetArticleAttachmentType","ensureWidgetArticleImageType","ensureWidgetArticleSliderType","ensureWidgetArticleTitleType","ensureWidgetArticleTextType","ensureWidgetExcelDatasourceTableType","ensureWidgetDatasourceTableType","ensureWidgetPresenceType","ensureWidgetQuickSurveyType","ensureWidgetCalendarCalDavType","ensureWidgetContactCardDavType","ensureWidgetEmailsImapType","ensureWidgetUserProfileType","CSSWidgetLayer","opacity","pointerEvents","BETA_JRCDoubleClick","WidgetLayer","layers","ids","layer","Layer","LayerWidget","layerId","visible","locked","top","left","x","context","DraggableHandler","onMouseUp","updateLayer","onDoubleTap","mouseIsDown","setMouseDown","mouse","setMouse","start","setStart","child","setChild","handleMouseDown","event","nativeEvent","clientX","clientY","handleMouseMove","dx","dy","handleMouseUp","document","onMouseDown","WidgetState","inset","display","flex","justifyContent","alignItems","hover","WrapperEditMode","WidgetWrapperCoreEditHover","def","WidgetStyleWrapper","borderColor","borderWidth","borderStyle","Number","WidgetIcon","CSSIconAbsoluteA","JRCWidgetIconWrapper","rel","maxValue","WidgetWrapperCore","indexOrder","editableMap","currentEditableWidgetId","isComponentVisible","setIsComponentVisible","registerWidgetObject","registerWidget","setEditableWidgetId","setEditableIndex","CSSCommentsBlocWidgetWrapper","JRCMessage","CommentsBlocAddCommentWidgetsWrapper","flushedWidgets","selectFlushedWidgets","CommentsBlocCommentWidgetsWrapper","handleWidgetUpdate","useGifsModal","onSelect","gifs","GifsSelector","GifsModal","setLoading","setGifs","setQuery","q","offset","getGifs","prev","onSelectGif","onSearch","onReachEnd","JRCCommentsBloc","CommentsBlocWrapper","CommentsBloc","canComment","commentType","socialQuestion","setWidgets","widgetIds","selectWidgets","tinyMCEExtendedOptions","selectTinyMCEExtendedOptions","platformConfig","selectPlatformConfig","commentsList","commentList","driveHook","fileBank","widgetHook","socialQuestionOptions","setSocialQuestionOptions","reportProps","setReportProps","gifsModalOpen","closeGifsModal","extGifs","isGifsActive","useCommentRT","idComments","reactSocket","socket","rtHandlers","getCommentsLikeRTHandlers","handler","onMessage","function","offMessage","fetchComments","onComment","params","finalWidget","some","addComment","_widgets","registerWidgetObjectRights","rights","_right","comments","onCommentUpdate","commentToUpdate","idComment","updateComment","onCommentDelete","deleteComment","isWidgetActive","autorize","canCreateWidget","create","widgetListComponent","newWidgetsWrapperComponent","existingWidgetsWrapperComponent","handleWidgetRemove","tinyMCEConfig","toolbar","commentsToolbar","highlightFields","userHighlightFields","userAccountStatus","userModel","m","onGetHashError","activeDrives","utils","buildDrivesArrayFromObject","drives","drive","filebank","fileIntegrity","global","questionAnswer","onSelectResponse","responseId","isResolved","onUnselectResponse","onReport","AppsDropdownItem","AppsDropdownItemLink","font","FlexBox","DropDown","CalendarHeader","animatedMeeting","calendarApp","surveyDate","weight","withBorder","trigger","Dropdown","IconButton","InputSelectRaw","InputCheckboxRaw","Label","InputWrapper","DropdownContainer","CalendarToolbar","viewsOptions","calendarApi","navigateWithQuery","setView","setCreationType","setExportModalOpen","types","selectCalendarEvents","animatedMeetingHook","meeting","boardCard","createCalendarEventOptions","viewOptionEntries","Fragment","next","tooltip","noMargin","colorVariant","badgeNumber","labelPosition","checkboxMode","setTypes","Calendar","CommentsContainer","Header","CalendarWrapper","views","withHeader","withToolbar","fluid","navigate","useNavigate","getCalendarRTHandlers","dates","pendingStatusChanges","setCalendarApi","eventToUpdate","setEventToUpdate","isExportModalOpen","globalDefaultView","defaultView","urlQuery","URLSearchParams","search","queries","set","onSuccess","handleChangeView","handleChangeDates","end","formatDate","setDates","creationType","split","fullScreen","events","calendar","eventModalExtraComponent","deportedToolbar","onChangeLabel","onCalendarApiInit","onChangeDates","onChangeView","onDeleteEvent","onClickUpdateEvent","onUpdateStatus","changeResponse","isUpdateStatusLoading","psc","eventId","CSSEditorPortal","CSSEditorHeader","CSSEditorAction","CSSEditorLabel","CSSEditorMask","EDITOR_WIDTH","CSSEditor","CSSEditorContent","CSSEditorTab","CSSEditorIsBusy","CSSEditorIsLocked","CSSEditorMenu","CSSEditorMenuButton","EditorPopup","selectEditor","popup","flexDirection","marginTop","flushEditorPopup","WidgetArticleTitleEditor","WidgetArticleTextEditor","WidgetArticleGalleryEditor","WidgetArticleAttachmentEditor","WidgetArticleSliderEditor","WidgetArticleImageEditor","WidgetButtonEditor","WidgetDatasourceTableEditor","WidgetExcelDatasourceTableEditor","WidgetPresenceEditor","WidgetLuccaAbsenceEditor","WidgetEmailsImapEditor","WidgetContactCardDavEditor","WidgetCalendarCalDavEditor","WidgetUserProfileEditor","Editor","onSaveCallback","onSave","handleHookIsActive","getState","flushEditor","onStateChange","states","onOpen","registerEditorPopup","jamespot","network","wedoc","handleStart","handleCatch","handleFinally","override","application","EditorPosition","setEditorPosition","InputColorRaw","Fieldset","EditorInputColor","palettes","colors","headerColor","green","navy","overseas","transparentHexa","JRCInputNumber","EditorInputNumber","EditorInputSelect","optionFromInitialValue","select","hideDeleteIcon","EditorTabWrapper","wrapper","widgetContext","selectWidgetContext","setWidgetTitleStyle","colorValue","backgroundColorValue","fontSizeValue","fontWeightValue","textAlignValue","EditorIsBusy","EditorIsLocked","EditorSave","EditorTabWidgetSelection","setWidgetWrapperStyle","paddingValue","borderRadiusValue","borderStyleValue","borderColorValue","borderWidthValue","EditorTabDisplayLevel","displayLevel","OVERRIDE_SAVE","EditorWrapper","enableWidgetLevel","tabs","enable","panel","useWrapper","useSelection","useEditor","defaultTab","currentTab","setCurrentTab","setTimeout","tab","CSSEditorPortalWrapper","CSSEditorPortalPopupWrapper","CSSEditorPortalRow","CSSEditorPortalFreeSpace","EditorsPortal","flush","editors","selectEditors","Empty","FullPageLayout","Suspense","fallback","Outlet","useAI","J","hooks","MagicWandHook","menuItems","PrepareAndSetQuery","fetch","AICapabilities","develop","summarize","tldr","en","es","formal","funny","jia","JRCInputTinyMCE","JRCInputTinyMCEWithExt","extAI","isAIActive","gifsExt","extArray","onMentionsQueryError","JRCInputTinyMCERaw","JRCInputTinyMCEWithExtRaw","JRCInputAudience","JRCModal","ModalAudience","warningMessage","asyncPromise","inputValue","autocomplete","searchable","InputDateTime","InputTextRaw","IconButtonWrapper","ModalSchedule","urlBase","selectUrlBase","form","scheduleDate","padStartTwoDigits","getHours","getMinutes","permalinkId","onSubmitHandler","useWatch","permalink","srOnly","navigator","clipboard","writeText","AppColumn","MainColumn","TwoColLayout","extensionRoute","routes","mainColumnProps","pathname","useLocation","ROUTES_ARRAY","activeTab","setActiveTab","key","absolutePath","group","activeRoute","route","paths","reduce","previousValue","currentValue","pattern","isMatch","matchPath"],"sourceRoot":""}