ublo-lib 1.42.0 → 1.42.2
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/es/future/components/msem-preset-editor/components/facet-selector.d.ts.map +1 -1
- package/es/future/components/msem-preset-editor/components/form.d.ts.map +1 -1
- package/es/future/components/msem-preset-editor/components/resort-selector.d.ts.map +1 -1
- package/es/future/components/msem-preset-editor/components/stay-picker.d.ts.map +1 -1
- package/es/future/components/msem-preset-linker/msem-preset-linker.d.ts.map +1 -1
- package/es/future/components/msem-preset-linker/msem-preset-linker.js +9 -4
- package/es/future/components/msem-preset-linker/msem-preset-linker.module.css +4 -0
- package/es/future/hooks/use-msem-presets.d.ts.map +1 -1
- package/es/future/hooks/use-msem-presets.js +31 -1
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"facet-selector.d.ts","sourceRoot":"","sources":["../../../../../src/future/components/msem-preset-editor/components/facet-selector.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"facet-selector.d.ts","sourceRoot":"","sources":["../../../../../src/future/components/msem-preset-editor/components/facet-selector.tsx"],"names":[],"mappings":"AAEA,MAAM,CAAC,OAAO,UAAU,aAAa,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,SAAS,EAAE;;;;CAAA,2CA2BnE"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"form.d.ts","sourceRoot":"","sources":["../../../../../src/future/components/msem-preset-editor/components/form.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"form.d.ts","sourceRoot":"","sources":["../../../../../src/future/components/msem-preset-editor/components/form.tsx"],"names":[],"mappings":"AAKA,MAAM,CAAC,OAAO,UAAU,IAAI,CAAC,EAC3B,KAAK,EACL,KAAK,EACL,MAAM,EACN,cAAc,EACd,QAAQ,GACT;;;;;;CAAA,2CA0CA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"resort-selector.d.ts","sourceRoot":"","sources":["../../../../../src/future/components/msem-preset-editor/components/resort-selector.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"resort-selector.d.ts","sourceRoot":"","sources":["../../../../../src/future/components/msem-preset-editor/components/resort-selector.tsx"],"names":[],"mappings":"AAEA,KAAK,MAAM,GAAG;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf,CAAC;AAEF,KAAK,KAAK,GAAG;IACX,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,YAAY,EAAE,MAAM,IAAI,CAAC;CAC1B,CAAC;AAEF,MAAM,CAAC,OAAO,UAAU,cAAc,CAAC,EACrC,OAAO,EACP,MAAM,EACN,SAAS,EACT,YAAY,GACb,EAAE,KAAK,2CAiBP"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"stay-picker.d.ts","sourceRoot":"","sources":["../../../../../src/future/components/msem-preset-editor/components/stay-picker.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"stay-picker.d.ts","sourceRoot":"","sources":["../../../../../src/future/components/msem-preset-editor/components/stay-picker.tsx"],"names":[],"mappings":"AAGA,KAAK,KAAK,GAAG;IACX,IAAI,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,EAAE,EAAE,MAAM,CAAA;KAAE,CAAC;IACnC,OAAO,EAAE,CAAC,IAAI,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,EAAE,EAAE,MAAM,CAAA;KAAE,KAAK,IAAI,CAAC;IACtD,SAAS,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,KAAK,IAAI,CAAC;CAClD,CAAC;AAEF,MAAM,CAAC,OAAO,UAAU,UAAU,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,KAAK,2CAmD1D"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"msem-preset-linker.d.ts","sourceRoot":"","sources":["../../../../src/future/components/msem-preset-linker/msem-preset-linker.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"msem-preset-linker.d.ts","sourceRoot":"","sources":["../../../../src/future/components/msem-preset-linker/msem-preset-linker.tsx"],"names":[],"mappings":"AAQA,KAAK,MAAM,GAAG;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf,CAAC;AAEF,KAAK,KAAK,GAAG;IACX,IAAI,EAAE,IAAI,GAAG,IAAI,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,eAAe,EAAE,MAAM,CAAC;IACxB,MAAM,EAAE,WAAW,GAAG,IAAI,CAAC;IAC3B,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,KAAK,EAAE,MAAM,IAAI,CAAC;CACnB,CAAC;AAIF,MAAM,CAAC,OAAO,UAAU,gBAAgB,CAAC,EACvC,IAAI,EACJ,OAAO,EACP,MAAM,EACN,eAAe,EACf,MAAM,EACN,OAAO,EACP,KAAK,EACL,OAAO,GACR,EAAE,KAAK,2CAgFP"}
|
|
@@ -2,6 +2,7 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
|
2
2
|
import * as React from "react";
|
|
3
3
|
import Dialog from "dt-design-system/es/dialog";
|
|
4
4
|
import Button from "dt-design-system/es/button";
|
|
5
|
+
import Checkbox from "dt-design-system/es/checkbox";
|
|
5
6
|
import MseMPresetEditor from "../msem-preset-editor";
|
|
6
7
|
import css from "./msem-preset-linker.module.css";
|
|
7
8
|
import MseMLogo from "./msem-logo";
|
|
@@ -10,7 +11,10 @@ export default function MseMPresetLinker({ lang, channel, resort, msemServicesUr
|
|
|
10
11
|
const link = target?.querySelector(":scope > a");
|
|
11
12
|
const currentPreset = target?.getAttribute("data-msem-preset") || undefined;
|
|
12
13
|
const urlOverride = link?.getAttribute("href") || undefined;
|
|
13
|
-
const
|
|
14
|
+
const defaultPreset = currentPreset ? JSON.parse(currentPreset) : null;
|
|
15
|
+
const [preset, setPreset] = React.useState(defaultPreset);
|
|
16
|
+
const [groundedTo, setGroundedTo] = React.useState(Boolean(defaultPreset?.groundedTo));
|
|
17
|
+
const allowGroundedTo = Boolean(target?.querySelector("[data-msem-placeholder]"));
|
|
14
18
|
const closeEditor = React.useCallback(() => {
|
|
15
19
|
close();
|
|
16
20
|
}, [close]);
|
|
@@ -22,12 +26,13 @@ export default function MseMPresetLinker({ lang, channel, resort, msemServicesUr
|
|
|
22
26
|
if (!anchorHasHref && preset?.url) {
|
|
23
27
|
delete preset.url;
|
|
24
28
|
}
|
|
25
|
-
|
|
29
|
+
const fullPreset = { ...preset, groundedTo };
|
|
30
|
+
target?.setAttribute(PRESET_ATTRIBUTE, JSON.stringify(fullPreset));
|
|
26
31
|
}
|
|
27
32
|
else {
|
|
28
33
|
target?.removeAttribute(PRESET_ATTRIBUTE);
|
|
29
34
|
}
|
|
30
35
|
closeEditor();
|
|
31
|
-
}, [closeEditor, preset, target]);
|
|
32
|
-
return (_jsxs(Dialog, { className: css.dialog, isOpened: true, close: closeEditor, closeButtonVariant: "transparent", closeOnBackdropClick: false, showAsModal: false, children: [_jsxs("div", { className: css.title, children: [_jsx(MseMLogo, { className: css.logo }), " \u00C9diteur de presets"] }), _jsx("div", { className: css.content, children: _jsx(MseMPresetEditor, { lang: lang, channel: channel, resort: resort, msemServicesUrl: msemServicesUrl, urlOverride: urlOverride, resorts: resorts, currentPreset: preset, onChange: setPreset, showUrl: showUrl }) }), _jsxs("div", { className: css.buttons, children: [_jsx(Button, { variant: "secondary", onClick: closeEditor, children: "Annuler" }), _jsx(Button, { variant: "primary", onClick: updatePreset, children: "Valider" })] })] }));
|
|
36
|
+
}, [closeEditor, groundedTo, preset, target]);
|
|
37
|
+
return (_jsxs(Dialog, { className: css.dialog, isOpened: true, close: closeEditor, closeButtonVariant: "transparent", closeOnBackdropClick: false, showAsModal: false, children: [_jsxs("div", { className: css.title, children: [_jsx(MseMLogo, { className: css.logo }), " \u00C9diteur de presets"] }), _jsx("div", { className: css.content, children: _jsx(MseMPresetEditor, { lang: lang, channel: channel, resort: resort, msemServicesUrl: msemServicesUrl, urlOverride: urlOverride, resorts: resorts, currentPreset: preset, onChange: setPreset, showUrl: showUrl }) }), _jsxs("div", { className: css.buttons, children: [allowGroundedTo && (_jsx(Checkbox, { className: css.groundedTo, label: "Ins\u00E9rer le widget dans la page", checked: groundedTo, onCheckedChange: setGroundedTo })), _jsx(Button, { variant: "secondary", onClick: closeEditor, children: "Annuler" }), _jsx(Button, { variant: "primary", onClick: updatePreset, children: "Valider" })] })] }));
|
|
33
38
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-msem-presets.d.ts","sourceRoot":"","sources":["../../../src/future/hooks/use-msem-presets.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"use-msem-presets.d.ts","sourceRoot":"","sources":["../../../src/future/hooks/use-msem-presets.ts"],"names":[],"mappings":"AAYA,MAAM,CAAC,OAAO,UAAU,cAAc,CAAC,EAAE,cAAc,EAAE;;CAAA,QAqFxD"}
|
|
@@ -2,7 +2,9 @@ import * as React from "react";
|
|
|
2
2
|
import { useUbloContext } from "ublo/with-ublo";
|
|
3
3
|
import * as UrlParameters from "../utils/url-parameters";
|
|
4
4
|
import * as MseM from "../components/msem";
|
|
5
|
+
import * as Cms from "../../common/utils/cms";
|
|
5
6
|
const PRESET_ATTRIBUTE = "data-msem-preset";
|
|
7
|
+
const PRESET_PLACEHOLDER_ATTRIBUTE = "data-msem-placeholder";
|
|
6
8
|
export default function useMseMPresets({ defaultOptions }) {
|
|
7
9
|
const { lang, cmsMode, path } = useUbloContext();
|
|
8
10
|
const isEnabled = cmsMode !== "editing" && cmsMode !== "info";
|
|
@@ -12,7 +14,9 @@ export default function useMseMPresets({ defaultOptions }) {
|
|
|
12
14
|
const preset = section?.getAttribute(PRESET_ATTRIBUTE);
|
|
13
15
|
if (!preset)
|
|
14
16
|
return;
|
|
15
|
-
const { widget, options = {}, presets, url } = JSON.parse(preset);
|
|
17
|
+
const { widget, options = {}, presets, url, groundedTo, } = JSON.parse(preset);
|
|
18
|
+
if (groundedTo)
|
|
19
|
+
return;
|
|
16
20
|
const allOptions = { ...defaultOptions, ...options, lang };
|
|
17
21
|
e.preventDefault();
|
|
18
22
|
e.stopPropagation();
|
|
@@ -33,4 +37,30 @@ export default function useMseMPresets({ defaultOptions }) {
|
|
|
33
37
|
};
|
|
34
38
|
}
|
|
35
39
|
}, [lang, handleSectionClick, isEnabled, path]);
|
|
40
|
+
React.useEffect(() => {
|
|
41
|
+
const sections = Array.from(document.querySelectorAll(`section[${PRESET_ATTRIBUTE}]`));
|
|
42
|
+
if (!Cms.isConnected()) {
|
|
43
|
+
sections.forEach((section) => {
|
|
44
|
+
const preset = section.getAttribute(PRESET_ATTRIBUTE);
|
|
45
|
+
if (!preset)
|
|
46
|
+
return;
|
|
47
|
+
const { widget, options = {}, presets, groundedTo, } = JSON.parse(preset);
|
|
48
|
+
if (!groundedTo)
|
|
49
|
+
return;
|
|
50
|
+
const placeholder = section.querySelector(`[${PRESET_PLACEHOLDER_ATTRIBUTE}]`);
|
|
51
|
+
const isAlreadyLoaded = placeholder.hasAttribute("id");
|
|
52
|
+
if (isAlreadyLoaded)
|
|
53
|
+
return;
|
|
54
|
+
const uniqueId = `msem-${Math.random().toString(36).substring(2, 9)}`;
|
|
55
|
+
const allOptions = {
|
|
56
|
+
...defaultOptions,
|
|
57
|
+
...options,
|
|
58
|
+
groundedTo: `#${uniqueId}`,
|
|
59
|
+
lang,
|
|
60
|
+
};
|
|
61
|
+
placeholder.setAttribute("id", uniqueId);
|
|
62
|
+
MseM.loadWidget(widget, allOptions, presets);
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
}, [defaultOptions, lang]);
|
|
36
66
|
}
|