jamespot-react-core 1.2.55 → 1.2.57
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/{836.72e8e6ee836190bf4071.chunk.js → 541.f36879fda62072178a72.chunk.js} +56 -56
- package/build/541.f36879fda62072178a72.chunk.js.map +1 -0
- package/build/app.bundle.js +868 -745
- package/build/app.bundle.js.map +1 -1
- package/build/src/components/widgets/wrapper/JRCWidgetUserProfileWrapper.d.ts +8 -0
- package/build/src/redux/store.d.ts +51 -15
- package/build/src/registry/ext-component-list.d.ts +2 -0
- package/package.json +4 -4
- package/build/836.72e8e6ee836190bf4071.chunk.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"836.72e8e6ee836190bf4071.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/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/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 { 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 />\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 { 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 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';\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 {\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 {\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';\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\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]}\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 </>\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 HookListType,\n WidgetArticleAttachmentContent,\n WidgetArticleButtonContent,\n WidgetArticleGalleryContent,\n WidgetArticleImageContent,\n WidgetArticleSliderContent,\n WidgetArticleTextContent,\n WidgetArticleTitleContent,\n WidgetCheckListContent,\n WidgetDatasourceTableContent,\n WidgetPresenceContent,\n WidgetQuickSurveyContent,\n WidgetStateProps,\n} from 'jamespot-user-api';\nimport { 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\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 {\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 ],\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(/&/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';\n\nconst JRCInputTinyMCE = commonComponentsRegistry.getLazyComponent('InputTinyMCE');\n\nexport type JRCInputTinyMCEWithExtProps<T extends FieldValues> = Omit<\n JRCInputTinyMCEProps<T>,\n 'commonOptions' | 'mentionsQueries' | 'additionalExtensions'\n>;\n\nexport const JRCInputTinyMCEWithExt = <T extends FieldValues = FieldValues>(props: JRCInputTinyMCEWithExtProps<T>) => {\n const intl = useIntl();\n const dispatch = useAppDispatch();\n const theme = useTheme();\n const models = useAppSelector(Model.selectors.selectAll);\n const { query, ext: extAI, isActive: isAIActive } = useAI();\n const {\n open,\n onInsert,\n close: closeMarkdownModal,\n ext: extMarkdown,\n isActive: isMarkdownActive,\n } = useMarkdownModal();\n\n const extArray = useMemo(() => {\n return [...(isMarkdownActive ? [extMarkdown] : []), ...(isAIActive ? [extAI] : [])];\n }, [extAI, extMarkdown, isAIActive, isMarkdownActive]);\n\n const onMentionsQueryError = useCallback(\n (message?: string) => {\n dispatch(Toast.actions.error({ label: message ?? intl.formatMessage({ id: 'GLOBAL_Error' }) }));\n },\n [dispatch, intl],\n );\n\n const tinyMentionsQueries = useMemo(() => {\n return getTinyMCEMentionsQueries(models, theme, onMentionsQueryError);\n }, [models, onMentionsQueryError, theme]);\n\n const commonOptions = useMemo(() => tinymceCommonOptions, []);\n\n return (\n <>\n {commonOptions && (\n <JRCInputTinyMCE\n commonOptions={commonOptions}\n additionalExtensions={extArray}\n mentionsQueries={tinyMentionsQueries}\n {...props}\n />\n )}\n {isAIActive && <AIModal query={query} />}\n {isMarkdownActive && <MarkdownModal onInsert={onInsert} open={open} close={closeMarkdownModal} />}\n </>\n );\n};\n","import { Model, Toast } from 'jamespot-front-business';\nimport { 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","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","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","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","JRCCommentsBloc","CommentsBlocWrapper","CommentsBloc","canComment","commentType","socialQuestion","setLoading","setWidgets","currentUser","widgetIds","selectWidgets","tinyMCEExtendedOptions","selectTinyMCEExtendedOptions","platformConfig","selectPlatformConfig","commentsList","commentList","driveHook","fileBank","widgetHook","socialQuestionOptions","setSocialQuestionOptions","reportProps","setReportProps","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","handlers","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","prev","next","tooltip","noMargin","colorVariant","badgeNumber","labelPosition","checkboxMode","setTypes","Calendar","CommentsContainer","Header","CalendarWrapper","views","withHeader","withToolbar","fluid","onSelect","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","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","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","setQuery","J","hooks","MagicWandHook","menuItems","PrepareAndSetQuery","fetch","AICapabilities","develop","summarize","tldr","en","es","formal","funny","jia","JRCInputTinyMCE","JRCInputTinyMCEWithExt","extAI","isAIActive","extArray","onMentionsQueryError","JRCInputTinyMCERaw","JRCInputTinyMCEWithExtRaw","JRCInputAudience","JRCModal","ModalAudience","warningMessage","asyncPromise","inputValue","autocomplete","searchable","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":""}
|