ublo-lib 1.24.4 → 1.25.1
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/common/components/admin-links/admin-links.js +95 -52
- package/es/common/components/admin-links/index.js +1 -1
- package/es/common/components/breadcrumb.js +78 -21
- package/es/common/components/cross-selling-editor/cross-selling-editor.js +52 -0
- package/es/common/components/cross-selling-editor/cross-selling-editor.module.css +6 -0
- package/es/common/components/cross-selling-editor/editor.js +98 -0
- package/es/common/components/cross-selling-editor/editor.module.css +23 -0
- package/es/common/components/cross-selling-editor/hooks/use-custom-offers.js +52 -0
- package/es/common/components/cross-selling-editor/hooks/use-tunnel-offers.js +35 -0
- package/es/common/components/cross-selling-editor/index.js +2 -0
- package/es/common/components/cross-selling-editor/override-trigger-form.js +156 -0
- package/es/common/components/cross-selling-editor/override-trigger-form.module.css +58 -0
- package/es/common/components/cross-selling-editor/override.js +124 -0
- package/es/common/components/cross-selling-editor/override.module.css +65 -0
- package/es/common/components/cross-selling-editor/overrides-list.js +111 -0
- package/es/common/components/cross-selling-editor/overrides-list.module.css +56 -0
- package/es/common/components/cross-selling-editor/rule.js +105 -0
- package/es/common/components/cross-selling-editor/rule.module.css +37 -0
- package/es/common/components/cross-selling-editor/rules.js +84 -0
- package/es/common/components/cross-selling-editor/rules.module.css +39 -0
- package/es/common/components/cross-selling-editor/services/api.js +36 -0
- package/es/common/components/cross-selling-editor/services/utils.js +199 -0
- package/es/common/components/cross-selling-editor/tester-tunnel-offer.js +53 -0
- package/es/common/components/cross-selling-editor/tester-tunnel-offer.module.css +18 -0
- package/es/common/components/cross-selling-editor/tester.js +188 -0
- package/es/common/components/cross-selling-editor/tester.module.css +106 -0
- package/es/common/components/cross-selling-editor/types.js +1 -0
- package/es/common/components/custom-contact-form/custom-contact-form.js +147 -75
- package/es/common/components/date-picker/calendar.js +1 -1
- package/es/common/components/gesco-contact-form/gesco-contact-form.js +240 -91
- package/es/common/components/gesco-contact-form/hooks/use-params.js +35 -20
- package/es/common/components/gesco-contact-form/index.js +1 -1
- package/es/common/components/gesco-contact-form/phone-code-select.js +76 -56
- package/es/common/components/gesco-contact-form/services/api.js +7 -8
- package/es/common/components/gesco-contact-form/services/form.js +39 -25
- package/es/common/components/gesco-contact-form/services/messages.js +68 -65
- package/es/common/components/gesco-contact-form/services/plausible.js +8 -10
- package/es/common/components/gesco-contact-form/types.js +1 -1
- package/es/common/components/instant-search/hooks/use-constant.js +8 -6
- package/es/common/components/instant-search/hooks/use-debounced-search.js +14 -5
- package/es/common/components/instant-search/hooks/use-search.js +10 -6
- package/es/common/components/instant-search/index.js +1 -1
- package/es/common/components/instant-search/input.js +75 -45
- package/es/common/components/instant-search/instant-search.js +124 -73
- package/es/common/components/instant-search/links.js +74 -23
- package/es/common/components/instant-search/no-product.js +81 -4
- package/es/common/components/instant-search/products.js +118 -31
- package/es/common/components/instant-search/results.js +121 -32
- package/es/common/components/instant-search/services/api.js +12 -10
- package/es/common/components/instant-search/services/messages.js +3 -3
- package/es/common/components/instant-search/services/utils.js +34 -34
- package/es/common/components/msem-preset-editor/components/facet-selector.js +39 -22
- package/es/common/components/msem-preset-editor/components/form.js +54 -5
- package/es/common/components/msem-preset-editor/components/stay-picker.js +72 -33
- package/es/common/components/msem-preset-editor/components/widget-list-item.js +130 -42
- package/es/common/components/msem-preset-editor/components/widget-list.js +54 -29
- package/es/common/components/msem-preset-editor/editor-dialog.js +68 -21
- package/es/common/components/msem-preset-editor/editors/elloha.js +102 -69
- package/es/common/components/msem-preset-editor/editors/index.js +6 -6
- package/es/common/components/msem-preset-editor/editors/lodgings.js +316 -184
- package/es/common/components/msem-preset-editor/editors/ski-passes.js +267 -180
- package/es/common/components/msem-preset-editor/editors/standard-products.js +84 -56
- package/es/common/components/msem-preset-editor/editors/vakario.js +239 -171
- package/es/common/components/msem-preset-editor/msem-preset-editor.js +215 -129
- package/es/common/components/msem-preset-editor/services/api.js +69 -42
- package/es/common/components/msem-preset-editor/services/offers.js +61 -35
- package/es/common/components/msem-preset-editor/services/preset.js +22 -14
- package/es/common/components/msem-preset-editor/services/url-params.js +24 -24
- package/es/common/components/msem-preset-linker/components/actions.js +52 -40
- package/es/common/components/msem-preset-linker/components/overlays.js +57 -41
- package/es/common/components/msem-preset-linker/components/resort-selector.js +21 -11
- package/es/common/components/msem-preset-linker/hooks/use-msem-presets.js +43 -31
- package/es/common/components/msem-preset-linker/index.js +1 -1
- package/es/common/components/msem-preset-linker/msem-preset-linker.js +71 -42
- package/es/common/components/msem-preset-linker/services/url-params.js +10 -13
- package/es/common/components/plausible/hooks/use-plausible.js +22 -18
- package/es/common/components/plausible/index.js +1 -1
- package/es/common/components/plausible/plausible.js +23 -14
- package/es/common/components/plausible/services/callback.js +164 -115
- package/es/common/components/plausible/services/load.js +4 -6
- package/es/common/components/plausible/services/send-goal.js +6 -3
- package/es/common/components/scroll-spy.js +56 -43
- package/es/common/components/scrolling-carousel/index.js +1 -1
- package/es/common/components/scrolling-carousel/scrolling-carousel.js +94 -55
- package/es/common/components/tabbed-zones.js +100 -47
- package/es/common/hooks/use-faq.js +37 -36
- package/es/common/hooks/use-in-view.js +74 -74
- package/es/common/hooks/use-scroll-direction.js +37 -32
- package/es/common/hooks/use-stay.js +16 -13
- package/es/common/hooks/use-sticky.js +35 -35
- package/es/common/hooks/use-tunnel.js +42 -30
- package/es/common/hooks/use-update-effect.js +9 -9
- package/es/common/hooks/use-window-sizes.js +27 -28
- package/es/common/utils/cms.js +15 -17
- package/es/common/utils/cookies.js +10 -11
- package/es/common/utils/copy.js +11 -11
- package/es/common/utils/dates.js +8 -10
- package/es/common/utils/elements.js +14 -15
- package/es/common/utils/events.js +4 -19
- package/es/common/utils/file-manager.js +12 -10
- package/es/common/utils/load-js.js +10 -11
- package/es/common/utils/msem-widget.js +30 -23
- package/es/common/utils/url-parameters.js +11 -7
- package/es/esf/components/magic-box/index.js +1 -1
- package/es/esf/components/magic-box/magic-box.js +164 -102
- package/es/esf/components/parcours-esf/index.js +1 -1
- package/es/esf/components/parcours-esf/parcours-esf.js +45 -30
- package/es/esf/components/period-picker/period-picker.js +5 -5
- package/es/lbm/components/lumiplan/api.js +35 -18
- package/es/lbm/components/lumiplan/domain.js +96 -20
- package/es/lbm/components/lumiplan/i18n/translations.js +24 -15
- package/es/lbm/components/lumiplan/index.js +1 -1
- package/es/lbm/components/lumiplan/lumiplan.js +130 -102
- package/es/lbm/components/lumiplan/opening.js +116 -38
- package/es/lbm/components/lumiplan/pois.js +270 -161
- package/es/lbm/components/lumiplan/resort-selector.js +58 -36
- package/es/lbm/components/lumiplan/road-condition.js +100 -19
- package/es/lbm/components/lumiplan/todays-tips.js +45 -16
- package/es/lbm/components/lumiplan/types.js +1 -1
- package/es/lbm/components/lumiplan/weather/avalanche-risk.js +33 -8
- package/es/lbm/components/lumiplan/weather/index.js +1 -1
- package/es/lbm/components/lumiplan/weather/snow-data.js +71 -5
- package/es/lbm/components/lumiplan/weather/weather-data.js +126 -7
- package/es/lbm/components/lumiplan/weather/weather-days.js +76 -48
- package/es/lbm/components/lumiplan/weather/weather-icon.js +23 -20
- package/es/lbm/components/lumiplan/weather/weather-zones.js +71 -42
- package/es/lbm/components/lumiplan/weather/weather.js +90 -28
- package/package.json +4 -10
- package/es/common/components/admin-links/admin-links.d.ts +0 -11
- package/es/common/components/admin-links/admin-links.d.ts.map +0 -1
- package/es/common/components/admin-links/index.d.ts +0 -3
- package/es/common/components/admin-links/index.d.ts.map +0 -1
- package/es/common/components/breadcrumb.d.ts +0 -16
- package/es/common/components/breadcrumb.d.ts.map +0 -1
- package/es/common/components/custom-contact-form/custom-contact-form.d.ts +0 -25
- package/es/common/components/custom-contact-form/custom-contact-form.d.ts.map +0 -1
- package/es/common/components/gesco-contact-form/gesco-contact-form.d.ts +0 -17
- package/es/common/components/gesco-contact-form/gesco-contact-form.d.ts.map +0 -1
- package/es/common/components/gesco-contact-form/hooks/use-params.d.ts +0 -15
- package/es/common/components/gesco-contact-form/hooks/use-params.d.ts.map +0 -1
- package/es/common/components/gesco-contact-form/index.d.ts +0 -3
- package/es/common/components/gesco-contact-form/index.d.ts.map +0 -1
- package/es/common/components/gesco-contact-form/phone-code-select.d.ts +0 -7
- package/es/common/components/gesco-contact-form/phone-code-select.d.ts.map +0 -1
- package/es/common/components/gesco-contact-form/services/api.d.ts +0 -30
- package/es/common/components/gesco-contact-form/services/api.d.ts.map +0 -1
- package/es/common/components/gesco-contact-form/services/form.d.ts +0 -31
- package/es/common/components/gesco-contact-form/services/form.d.ts.map +0 -1
- package/es/common/components/gesco-contact-form/services/messages.d.ts +0 -34
- package/es/common/components/gesco-contact-form/services/messages.d.ts.map +0 -1
- package/es/common/components/gesco-contact-form/services/plausible.d.ts +0 -3
- package/es/common/components/gesco-contact-form/services/plausible.d.ts.map +0 -1
- package/es/common/components/gesco-contact-form/types.d.ts +0 -34
- package/es/common/components/gesco-contact-form/types.d.ts.map +0 -1
- package/es/common/components/instant-search/hooks/use-constant.d.ts +0 -2
- package/es/common/components/instant-search/hooks/use-constant.d.ts.map +0 -1
- package/es/common/components/instant-search/hooks/use-debounced-search.d.ts +0 -7
- package/es/common/components/instant-search/hooks/use-debounced-search.d.ts.map +0 -1
- package/es/common/components/instant-search/hooks/use-search.d.ts +0 -16
- package/es/common/components/instant-search/hooks/use-search.d.ts.map +0 -1
- package/es/common/components/instant-search/index.d.ts +0 -3
- package/es/common/components/instant-search/index.d.ts.map +0 -1
- package/es/common/components/instant-search/input.d.ts +0 -15
- package/es/common/components/instant-search/input.d.ts.map +0 -1
- package/es/common/components/instant-search/instant-search.d.ts +0 -14
- package/es/common/components/instant-search/instant-search.d.ts.map +0 -1
- package/es/common/components/instant-search/links.d.ts +0 -12
- package/es/common/components/instant-search/links.d.ts.map +0 -1
- package/es/common/components/instant-search/no-product.d.ts +0 -6
- package/es/common/components/instant-search/no-product.d.ts.map +0 -1
- package/es/common/components/instant-search/products.d.ts +0 -14
- package/es/common/components/instant-search/products.d.ts.map +0 -1
- package/es/common/components/instant-search/results.d.ts +0 -76
- package/es/common/components/instant-search/results.d.ts.map +0 -1
- package/es/common/components/instant-search/services/api.d.ts +0 -2
- package/es/common/components/instant-search/services/api.d.ts.map +0 -1
- package/es/common/components/instant-search/services/messages.d.ts +0 -2
- package/es/common/components/instant-search/services/messages.d.ts.map +0 -1
- package/es/common/components/instant-search/services/utils.d.ts +0 -4
- package/es/common/components/instant-search/services/utils.d.ts.map +0 -1
- package/es/common/components/msem-preset-editor/components/facet-selector.d.ts +0 -6
- package/es/common/components/msem-preset-editor/components/facet-selector.d.ts.map +0 -1
- package/es/common/components/msem-preset-editor/components/form.d.ts +0 -8
- package/es/common/components/msem-preset-editor/components/form.d.ts.map +0 -1
- package/es/common/components/msem-preset-editor/components/stay-picker.d.ts +0 -14
- package/es/common/components/msem-preset-editor/components/stay-picker.d.ts.map +0 -1
- package/es/common/components/msem-preset-editor/components/widget-list-item.d.ts +0 -12
- package/es/common/components/msem-preset-editor/components/widget-list-item.d.ts.map +0 -1
- package/es/common/components/msem-preset-editor/components/widget-list.d.ts +0 -17
- package/es/common/components/msem-preset-editor/components/widget-list.d.ts.map +0 -1
- package/es/common/components/msem-preset-editor/editor-dialog.d.ts +0 -30
- package/es/common/components/msem-preset-editor/editor-dialog.d.ts.map +0 -1
- package/es/common/components/msem-preset-editor/editors/elloha.d.ts +0 -15
- package/es/common/components/msem-preset-editor/editors/elloha.d.ts.map +0 -1
- package/es/common/components/msem-preset-editor/editors/index.d.ts +0 -14
- package/es/common/components/msem-preset-editor/editors/index.d.ts.map +0 -1
- package/es/common/components/msem-preset-editor/editors/lodgings.d.ts +0 -17
- package/es/common/components/msem-preset-editor/editors/lodgings.d.ts.map +0 -1
- package/es/common/components/msem-preset-editor/editors/ski-passes.d.ts +0 -16
- package/es/common/components/msem-preset-editor/editors/ski-passes.d.ts.map +0 -1
- package/es/common/components/msem-preset-editor/editors/standard-products.d.ts +0 -16
- package/es/common/components/msem-preset-editor/editors/standard-products.d.ts.map +0 -1
- package/es/common/components/msem-preset-editor/editors/vakario.d.ts +0 -15
- package/es/common/components/msem-preset-editor/editors/vakario.d.ts.map +0 -1
- package/es/common/components/msem-preset-editor/msem-preset-editor.d.ts +0 -28
- package/es/common/components/msem-preset-editor/msem-preset-editor.d.ts.map +0 -1
- package/es/common/components/msem-preset-editor/services/api.d.ts +0 -15
- package/es/common/components/msem-preset-editor/services/api.d.ts.map +0 -1
- package/es/common/components/msem-preset-editor/services/offers.d.ts +0 -47
- package/es/common/components/msem-preset-editor/services/offers.d.ts.map +0 -1
- package/es/common/components/msem-preset-editor/services/preset.d.ts +0 -40
- package/es/common/components/msem-preset-editor/services/preset.d.ts.map +0 -1
- package/es/common/components/msem-preset-editor/services/url-params.d.ts +0 -3
- package/es/common/components/msem-preset-editor/services/url-params.d.ts.map +0 -1
- package/es/common/components/msem-preset-linker/components/actions.d.ts +0 -11
- package/es/common/components/msem-preset-linker/components/actions.d.ts.map +0 -1
- package/es/common/components/msem-preset-linker/components/overlays.d.ts +0 -8
- package/es/common/components/msem-preset-linker/components/overlays.d.ts.map +0 -1
- package/es/common/components/msem-preset-linker/components/resort-selector.d.ts +0 -6
- package/es/common/components/msem-preset-linker/components/resort-selector.d.ts.map +0 -1
- package/es/common/components/msem-preset-linker/hooks/use-msem-presets.d.ts +0 -4
- package/es/common/components/msem-preset-linker/hooks/use-msem-presets.d.ts.map +0 -1
- package/es/common/components/msem-preset-linker/index.d.ts +0 -3
- package/es/common/components/msem-preset-linker/index.d.ts.map +0 -1
- package/es/common/components/msem-preset-linker/msem-preset-linker.d.ts +0 -30
- package/es/common/components/msem-preset-linker/msem-preset-linker.d.ts.map +0 -1
- package/es/common/components/msem-preset-linker/services/url-params.d.ts +0 -2
- package/es/common/components/msem-preset-linker/services/url-params.d.ts.map +0 -1
- package/es/common/components/plausible/hooks/use-plausible.d.ts +0 -12
- package/es/common/components/plausible/hooks/use-plausible.d.ts.map +0 -1
- package/es/common/components/plausible/index.d.ts +0 -8
- package/es/common/components/plausible/index.d.ts.map +0 -1
- package/es/common/components/plausible/plausible.d.ts +0 -7
- package/es/common/components/plausible/plausible.d.ts.map +0 -1
- package/es/common/components/plausible/services/callback.d.ts +0 -24
- package/es/common/components/plausible/services/callback.d.ts.map +0 -1
- package/es/common/components/plausible/services/load.d.ts +0 -2
- package/es/common/components/plausible/services/load.d.ts.map +0 -1
- package/es/common/components/plausible/services/send-goal.d.ts +0 -7
- package/es/common/components/plausible/services/send-goal.d.ts.map +0 -1
- package/es/common/components/scroll-spy.d.ts +0 -14
- package/es/common/components/scroll-spy.d.ts.map +0 -1
- package/es/common/components/scrolling-carousel/index.d.ts +0 -3
- package/es/common/components/scrolling-carousel/index.d.ts.map +0 -1
- package/es/common/components/scrolling-carousel/scrolling-carousel.d.ts +0 -8
- package/es/common/components/scrolling-carousel/scrolling-carousel.d.ts.map +0 -1
- package/es/common/components/tabbed-zones.d.ts +0 -12
- package/es/common/components/tabbed-zones.d.ts.map +0 -1
- package/es/common/hooks/use-faq.d.ts +0 -3
- package/es/common/hooks/use-faq.d.ts.map +0 -1
- package/es/common/hooks/use-in-view.d.ts +0 -5
- package/es/common/hooks/use-in-view.d.ts.map +0 -1
- package/es/common/hooks/use-scroll-direction.d.ts +0 -11
- package/es/common/hooks/use-scroll-direction.d.ts.map +0 -1
- package/es/common/hooks/use-stay.d.ts +0 -4
- package/es/common/hooks/use-stay.d.ts.map +0 -1
- package/es/common/hooks/use-sticky.d.ts +0 -4
- package/es/common/hooks/use-sticky.d.ts.map +0 -1
- package/es/common/hooks/use-tunnel.d.ts +0 -8
- package/es/common/hooks/use-tunnel.d.ts.map +0 -1
- package/es/common/hooks/use-update-effect.d.ts +0 -2
- package/es/common/hooks/use-update-effect.d.ts.map +0 -1
- package/es/common/hooks/use-window-sizes.d.ts +0 -7
- package/es/common/hooks/use-window-sizes.d.ts.map +0 -1
- package/es/common/utils/cms.d.ts +0 -4
- package/es/common/utils/cms.d.ts.map +0 -1
- package/es/common/utils/cookies.d.ts +0 -2
- package/es/common/utils/cookies.d.ts.map +0 -1
- package/es/common/utils/copy.d.ts +0 -2
- package/es/common/utils/copy.d.ts.map +0 -1
- package/es/common/utils/dates.d.ts +0 -2
- package/es/common/utils/dates.d.ts.map +0 -1
- package/es/common/utils/elements.d.ts +0 -5
- package/es/common/utils/elements.d.ts.map +0 -1
- package/es/common/utils/events.d.ts +0 -4
- package/es/common/utils/events.d.ts.map +0 -1
- package/es/common/utils/file-manager.d.ts +0 -13
- package/es/common/utils/file-manager.d.ts.map +0 -1
- package/es/common/utils/load-js.d.ts +0 -3
- package/es/common/utils/load-js.d.ts.map +0 -1
- package/es/common/utils/msem-widget.d.ts +0 -16
- package/es/common/utils/msem-widget.d.ts.map +0 -1
- package/es/common/utils/url-parameters.d.ts +0 -2
- package/es/common/utils/url-parameters.d.ts.map +0 -1
- package/es/esf/components/magic-box/index.d.ts +0 -3
- package/es/esf/components/magic-box/index.d.ts.map +0 -1
- package/es/esf/components/magic-box/magic-box.d.ts +0 -22
- package/es/esf/components/magic-box/magic-box.d.ts.map +0 -1
- package/es/esf/components/parcours-esf/index.d.ts +0 -3
- package/es/esf/components/parcours-esf/index.d.ts.map +0 -1
- package/es/esf/components/parcours-esf/parcours-esf.d.ts +0 -14
- package/es/esf/components/parcours-esf/parcours-esf.d.ts.map +0 -1
- package/es/lbm/components/lumiplan/api.d.ts +0 -8
- package/es/lbm/components/lumiplan/api.d.ts.map +0 -1
- package/es/lbm/components/lumiplan/domain.d.ts +0 -8
- package/es/lbm/components/lumiplan/domain.d.ts.map +0 -1
- package/es/lbm/components/lumiplan/i18n/translations.d.ts +0 -7
- package/es/lbm/components/lumiplan/i18n/translations.d.ts.map +0 -1
- package/es/lbm/components/lumiplan/index.d.ts +0 -3
- package/es/lbm/components/lumiplan/index.d.ts.map +0 -1
- package/es/lbm/components/lumiplan/lumiplan.d.ts +0 -2
- package/es/lbm/components/lumiplan/lumiplan.d.ts.map +0 -1
- package/es/lbm/components/lumiplan/opening.d.ts +0 -9
- package/es/lbm/components/lumiplan/opening.d.ts.map +0 -1
- package/es/lbm/components/lumiplan/pois.d.ts +0 -8
- package/es/lbm/components/lumiplan/pois.d.ts.map +0 -1
- package/es/lbm/components/lumiplan/resort-selector.d.ts +0 -12
- package/es/lbm/components/lumiplan/resort-selector.d.ts.map +0 -1
- package/es/lbm/components/lumiplan/road-condition.d.ts +0 -8
- package/es/lbm/components/lumiplan/road-condition.d.ts.map +0 -1
- package/es/lbm/components/lumiplan/todays-tips.d.ts +0 -8
- package/es/lbm/components/lumiplan/todays-tips.d.ts.map +0 -1
- package/es/lbm/components/lumiplan/types.d.ts +0 -285
- package/es/lbm/components/lumiplan/types.d.ts.map +0 -1
- package/es/lbm/components/lumiplan/weather/avalanche-risk.d.ts +0 -4
- package/es/lbm/components/lumiplan/weather/avalanche-risk.d.ts.map +0 -1
- package/es/lbm/components/lumiplan/weather/index.d.ts +0 -3
- package/es/lbm/components/lumiplan/weather/index.d.ts.map +0 -1
- package/es/lbm/components/lumiplan/weather/snow-data.d.ts +0 -8
- package/es/lbm/components/lumiplan/weather/snow-data.d.ts.map +0 -1
- package/es/lbm/components/lumiplan/weather/weather-data.d.ts +0 -9
- package/es/lbm/components/lumiplan/weather/weather-data.d.ts.map +0 -1
- package/es/lbm/components/lumiplan/weather/weather-days.d.ts +0 -7
- package/es/lbm/components/lumiplan/weather/weather-days.d.ts.map +0 -1
- package/es/lbm/components/lumiplan/weather/weather-icon.d.ts +0 -23
- package/es/lbm/components/lumiplan/weather/weather-icon.d.ts.map +0 -1
- package/es/lbm/components/lumiplan/weather/weather-zones.d.ts +0 -6
- package/es/lbm/components/lumiplan/weather/weather-zones.d.ts.map +0 -1
- package/es/lbm/components/lumiplan/weather/weather.d.ts +0 -8
- package/es/lbm/components/lumiplan/weather/weather.d.ts.map +0 -1
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import Input from "dt-design-system/es/input";
|
|
3
|
+
import * as Icons from "dt-design-system/es/icons";
|
|
4
|
+
import styles from "./override-trigger-form.module.css";
|
|
5
|
+
import Select from "dt-design-system/es/select";
|
|
6
|
+
import Tooltip from "dt-design-system/es/tooltip";
|
|
7
|
+
import NumberPicker from "dt-design-system/es/number-picker";
|
|
8
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
9
|
+
import { Fragment as _Fragment } from "react/jsx-runtime";
|
|
10
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
11
|
+
export default function OverrideTriggerForm({
|
|
12
|
+
currentOffer,
|
|
13
|
+
override,
|
|
14
|
+
setConfig
|
|
15
|
+
}) {
|
|
16
|
+
const triggers = override?.triggers || {};
|
|
17
|
+
const {
|
|
18
|
+
stayFrom,
|
|
19
|
+
stayTo,
|
|
20
|
+
stayDuration = 0,
|
|
21
|
+
merchant,
|
|
22
|
+
skiPassDuration,
|
|
23
|
+
skiPassDurationOperator = ">"
|
|
24
|
+
} = triggers;
|
|
25
|
+
const updateEntry = (key, value) => {
|
|
26
|
+
setConfig((config = {}) => {
|
|
27
|
+
const itemConfig = config[currentOffer] || {};
|
|
28
|
+
const itemOverrides = itemConfig.overrides || [];
|
|
29
|
+
const newConfig = {
|
|
30
|
+
...config,
|
|
31
|
+
[currentOffer]: {
|
|
32
|
+
...itemConfig,
|
|
33
|
+
overrides: [...itemOverrides.map(o => {
|
|
34
|
+
if (o.id === override.id) {
|
|
35
|
+
const triggersConfig = o.triggers || {};
|
|
36
|
+
return {
|
|
37
|
+
...o,
|
|
38
|
+
triggers: {
|
|
39
|
+
...triggersConfig,
|
|
40
|
+
[key]: value
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
return o;
|
|
45
|
+
})]
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
return newConfig;
|
|
49
|
+
});
|
|
50
|
+
};
|
|
51
|
+
const submitForm = e => {
|
|
52
|
+
e.preventDefault();
|
|
53
|
+
e.stopPropagation();
|
|
54
|
+
};
|
|
55
|
+
const stopPropagation = e => {
|
|
56
|
+
e.stopPropagation();
|
|
57
|
+
};
|
|
58
|
+
const operatorOptions = [{
|
|
59
|
+
value: ">",
|
|
60
|
+
label: "Supérieur à"
|
|
61
|
+
}, {
|
|
62
|
+
value: ">=",
|
|
63
|
+
label: "Supérieur ou égal à"
|
|
64
|
+
}, {
|
|
65
|
+
value: "<",
|
|
66
|
+
label: "Inférieur à"
|
|
67
|
+
}, {
|
|
68
|
+
value: "<=>",
|
|
69
|
+
label: "Inférieur ou égal à"
|
|
70
|
+
}, {
|
|
71
|
+
value: "=",
|
|
72
|
+
label: "Égal à"
|
|
73
|
+
}];
|
|
74
|
+
return _jsxs("form", {
|
|
75
|
+
className: styles.form,
|
|
76
|
+
onSubmit: submitForm,
|
|
77
|
+
onClick: stopPropagation,
|
|
78
|
+
children: [_jsx("div", {
|
|
79
|
+
className: styles.title,
|
|
80
|
+
children: "D\xE9clencheur(s)"
|
|
81
|
+
}), _jsx("div", {
|
|
82
|
+
className: styles.subTitle,
|
|
83
|
+
children: "S\xE9jour"
|
|
84
|
+
}), _jsx(Input, {
|
|
85
|
+
className: styles.input,
|
|
86
|
+
type: "date",
|
|
87
|
+
label: "Inclu entre",
|
|
88
|
+
value: stayFrom || "",
|
|
89
|
+
onValueChange: value => updateEntry("stayFrom", value),
|
|
90
|
+
compact: true
|
|
91
|
+
}), _jsx(Input, {
|
|
92
|
+
className: styles.input,
|
|
93
|
+
type: "date",
|
|
94
|
+
label: "et",
|
|
95
|
+
value: stayTo || "",
|
|
96
|
+
onValueChange: value => updateEntry("stayTo", value),
|
|
97
|
+
compact: true
|
|
98
|
+
}), _jsx(NumberPicker, {
|
|
99
|
+
label: _jsxs(_Fragment, {
|
|
100
|
+
children: ["Nombre de jour(s)", _jsx(Tooltip, {
|
|
101
|
+
content: "S\xE9jour d'une dur\xE9e sup\xE9rieur ou \xE9gal \xE0...",
|
|
102
|
+
children: _jsx("span", {
|
|
103
|
+
className: styles.labelIconContainer,
|
|
104
|
+
children: _jsx(Icons.Info, {
|
|
105
|
+
className: styles.labelIcon
|
|
106
|
+
})
|
|
107
|
+
})
|
|
108
|
+
})]
|
|
109
|
+
}),
|
|
110
|
+
min: 0,
|
|
111
|
+
max: 40,
|
|
112
|
+
value: stayDuration || 0,
|
|
113
|
+
onChange: value => updateEntry("stayDuration", value),
|
|
114
|
+
withInput: true,
|
|
115
|
+
compact: true
|
|
116
|
+
}), _jsx("div", {
|
|
117
|
+
className: styles.subTitle,
|
|
118
|
+
children: "G\xE9n\xE9ral"
|
|
119
|
+
}), _jsx(Input, {
|
|
120
|
+
className: styles.input,
|
|
121
|
+
label: _jsxs(_Fragment, {
|
|
122
|
+
children: ["Code(s) marchand(s)", _jsx(Tooltip, {
|
|
123
|
+
content: "Si plusieurs codes marchands, les s\xE9parer par une virgule",
|
|
124
|
+
children: _jsx("span", {
|
|
125
|
+
className: styles.labelIconContainer,
|
|
126
|
+
children: _jsx(Icons.Info, {
|
|
127
|
+
className: styles.labelIcon
|
|
128
|
+
})
|
|
129
|
+
})
|
|
130
|
+
})]
|
|
131
|
+
}),
|
|
132
|
+
value: merchant || "",
|
|
133
|
+
onValueChange: value => updateEntry("merchant", value),
|
|
134
|
+
compact: true
|
|
135
|
+
}), _jsx("div", {
|
|
136
|
+
className: styles.subTitle,
|
|
137
|
+
children: "Forfaits"
|
|
138
|
+
}), _jsx(NumberPicker, {
|
|
139
|
+
className: styles.input,
|
|
140
|
+
label: "Dur\xE9e",
|
|
141
|
+
min: 0,
|
|
142
|
+
max: 40,
|
|
143
|
+
value: skiPassDuration || 0,
|
|
144
|
+
onChange: value => updateEntry("skiPassDuration", value),
|
|
145
|
+
withInput: true,
|
|
146
|
+
compact: true
|
|
147
|
+
}), _jsx(Select, {
|
|
148
|
+
className: styles.input,
|
|
149
|
+
label: "Op\xE9rateur de comparaison",
|
|
150
|
+
options: operatorOptions,
|
|
151
|
+
value: skiPassDurationOperator || ">",
|
|
152
|
+
onValueChange: value => updateEntry("skiPassDurationOperator", value),
|
|
153
|
+
compact: true
|
|
154
|
+
})]
|
|
155
|
+
});
|
|
156
|
+
}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
.form {
|
|
2
|
+
display: flex;
|
|
3
|
+
flex-direction: column;
|
|
4
|
+
gap: 6px;
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
.title {
|
|
8
|
+
font-weight: 700;
|
|
9
|
+
font-size: 14px;
|
|
10
|
+
text-align: center;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
.subTitle {
|
|
14
|
+
display: flex;
|
|
15
|
+
align-items: center;
|
|
16
|
+
gap: 8px;
|
|
17
|
+
font-size: 14px;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
.subTitle::after {
|
|
21
|
+
content: "";
|
|
22
|
+
flex: 1 1 100%;
|
|
23
|
+
height: 1px;
|
|
24
|
+
background-color: var(--ds-grey-200, #ededed);
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
.input > label {
|
|
28
|
+
flex-direction: row;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
.labelIconContainer {
|
|
32
|
+
display: inline-block;
|
|
33
|
+
transform: translate(4px, 3px);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
.input .labelIconContainer {
|
|
37
|
+
transform: translate(-2px, 3px);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
.labelIcon {
|
|
41
|
+
flex: 0 0 13px;
|
|
42
|
+
width: 13px;
|
|
43
|
+
height: 13px;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
.input > label > span {
|
|
47
|
+
flex: 0 0 auto;
|
|
48
|
+
padding-left: 0;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
.input > label > div {
|
|
52
|
+
flex: 1 1 100%;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
.submit {
|
|
56
|
+
align-self: flex-end;
|
|
57
|
+
margin-top: 10px;
|
|
58
|
+
}
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import classNames from "classnames";
|
|
3
|
+
import Popover from "dt-design-system/es/popover";
|
|
4
|
+
import Button from "dt-design-system/es/button";
|
|
5
|
+
import Input from "dt-design-system/es/input";
|
|
6
|
+
import Tooltip from "dt-design-system/es/tooltip";
|
|
7
|
+
import * as Icons from "dt-design-system/es/icons";
|
|
8
|
+
import OverrideTriggerForm from "./override-trigger-form";
|
|
9
|
+
import styles from "./override.module.css";
|
|
10
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
11
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
12
|
+
export default function Override({
|
|
13
|
+
currentOffer,
|
|
14
|
+
override,
|
|
15
|
+
currentOverride,
|
|
16
|
+
setCurrentOverride,
|
|
17
|
+
config,
|
|
18
|
+
setConfig,
|
|
19
|
+
closeCreationForm
|
|
20
|
+
}) {
|
|
21
|
+
const [formOpen, setFormOpen] = React.useState(false);
|
|
22
|
+
const toggleFormOpen = e => {
|
|
23
|
+
e.stopPropagation();
|
|
24
|
+
setFormOpen(formOpen => !formOpen);
|
|
25
|
+
};
|
|
26
|
+
const updateFormOpen = open => {
|
|
27
|
+
setFormOpen(open);
|
|
28
|
+
};
|
|
29
|
+
const updateCurrentOverride = () => {
|
|
30
|
+
const isSelected = currentOverride && override.id === currentOverride.id;
|
|
31
|
+
setCurrentOverride(isSelected ? null : override);
|
|
32
|
+
closeCreationForm();
|
|
33
|
+
};
|
|
34
|
+
const removeOverride = () => {
|
|
35
|
+
if (currentOverride === override) {
|
|
36
|
+
setCurrentOverride(null);
|
|
37
|
+
}
|
|
38
|
+
setConfig((config = {}) => {
|
|
39
|
+
const itemConfig = config[currentOffer] || {};
|
|
40
|
+
const itemOverrides = itemConfig.overrides || [];
|
|
41
|
+
const newConfig = {
|
|
42
|
+
...config,
|
|
43
|
+
[currentOffer]: {
|
|
44
|
+
...itemConfig,
|
|
45
|
+
overrides: itemOverrides.filter(o => o.id !== override.id)
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
return newConfig;
|
|
49
|
+
});
|
|
50
|
+
closeCreationForm();
|
|
51
|
+
};
|
|
52
|
+
const stopPropagation = e => {
|
|
53
|
+
e.stopPropagation();
|
|
54
|
+
};
|
|
55
|
+
const updateOverrideName = e => {
|
|
56
|
+
e.stopPropagation();
|
|
57
|
+
const target = e.target;
|
|
58
|
+
const allOverrides = config[currentOffer].overrides;
|
|
59
|
+
const isADuplicate = allOverrides.some(o => o.name === target.value);
|
|
60
|
+
if (isADuplicate) {
|
|
61
|
+
e.preventDefault();
|
|
62
|
+
} else {
|
|
63
|
+
setConfig((config = {}) => {
|
|
64
|
+
const itemConfig = config[currentOffer] || {};
|
|
65
|
+
const itemOverrides = itemConfig.overrides || [];
|
|
66
|
+
const newConfig = {
|
|
67
|
+
...config,
|
|
68
|
+
[currentOffer]: {
|
|
69
|
+
...itemConfig,
|
|
70
|
+
overrides: itemOverrides.map(o => {
|
|
71
|
+
if (o.id === override.id) {
|
|
72
|
+
return {
|
|
73
|
+
...o,
|
|
74
|
+
name: target.value
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
return o;
|
|
78
|
+
})
|
|
79
|
+
}
|
|
80
|
+
};
|
|
81
|
+
return newConfig;
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
closeCreationForm();
|
|
85
|
+
};
|
|
86
|
+
const classes = classNames(styles.override, {
|
|
87
|
+
[styles.current]: currentOverride && override.id === currentOverride.id
|
|
88
|
+
});
|
|
89
|
+
return _jsxs("div", {
|
|
90
|
+
className: classes,
|
|
91
|
+
onClick: updateCurrentOverride,
|
|
92
|
+
children: [_jsx(Input, {
|
|
93
|
+
className: styles.input,
|
|
94
|
+
value: override.name,
|
|
95
|
+
onChange: updateOverrideName,
|
|
96
|
+
onClick: stopPropagation,
|
|
97
|
+
onBlur: updateOverrideName,
|
|
98
|
+
compact: true
|
|
99
|
+
}), _jsx(Popover, {
|
|
100
|
+
trigger: _jsx(Button, {
|
|
101
|
+
className: styles.edit,
|
|
102
|
+
compact: true,
|
|
103
|
+
onClick: toggleFormOpen,
|
|
104
|
+
children: _jsx(Icons.Tune, {})
|
|
105
|
+
}),
|
|
106
|
+
open: formOpen,
|
|
107
|
+
onOpenChange: updateFormOpen,
|
|
108
|
+
children: _jsx(OverrideTriggerForm, {
|
|
109
|
+
currentOffer: currentOffer,
|
|
110
|
+
override: override,
|
|
111
|
+
setConfig: setConfig
|
|
112
|
+
})
|
|
113
|
+
}), _jsx(Tooltip, {
|
|
114
|
+
content: "Supprimer",
|
|
115
|
+
children: _jsx(Button, {
|
|
116
|
+
className: styles.delete,
|
|
117
|
+
variant: "danger",
|
|
118
|
+
compact: true,
|
|
119
|
+
onClick: removeOverride,
|
|
120
|
+
children: _jsx(Icons.Bin, {})
|
|
121
|
+
})
|
|
122
|
+
})]
|
|
123
|
+
});
|
|
124
|
+
}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
.override {
|
|
2
|
+
--ds-input-font-size: 12px;
|
|
3
|
+
--ds-input-radius: var(--ds-radius-100, 4px);
|
|
4
|
+
--ds-input-compact-padding: 2px;
|
|
5
|
+
--ds-input-border: 0;
|
|
6
|
+
--ds-input-foreground: currentColor;
|
|
7
|
+
--ds-input-background: transparent;
|
|
8
|
+
|
|
9
|
+
position: relative;
|
|
10
|
+
display: flex;
|
|
11
|
+
align-items: center;
|
|
12
|
+
gap: 6px;
|
|
13
|
+
padding: 6px;
|
|
14
|
+
background-color: var(--ds-grey-100, #f8f8f8);
|
|
15
|
+
font-size: 13px;
|
|
16
|
+
cursor: pointer;
|
|
17
|
+
border-radius: var(--ds-radius-100, 4px);
|
|
18
|
+
transition: color 160ms
|
|
19
|
+
var(--ds-transition-easing, cubic-bezier(0.4, 0.1, 0.2, 0.9)),
|
|
20
|
+
background-color 160ms
|
|
21
|
+
var(--ds-transition-easing, cubic-bezier(0.4, 0.1, 0.2, 0.9));
|
|
22
|
+
user-select: none;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
.override:not(.current):hover {
|
|
26
|
+
background-color: var(--ds-grey-200, #ededed);
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
.current {
|
|
30
|
+
color: var(--ds-grey-000, #fff);
|
|
31
|
+
background-color: var(--ds-secondary, var(--ds-blue-400, #0038ff));
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
.override::before {
|
|
35
|
+
content: "";
|
|
36
|
+
position: absolute;
|
|
37
|
+
top: 50%;
|
|
38
|
+
right: 100%;
|
|
39
|
+
width: 18px;
|
|
40
|
+
height: 2px;
|
|
41
|
+
background-color: var(--ds-grey-200, #ededed);
|
|
42
|
+
border-radius: var(--ds-radius-100, 4px);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
.input input {
|
|
46
|
+
font-size: 13px !important;
|
|
47
|
+
user-select: auto;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
.input input:hover {
|
|
51
|
+
background-color: var(--ds-grey-300, #d7d7d7);
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
.current .input input:hover {
|
|
55
|
+
background-color: rgba(255, 255, 255, 0.2);
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
.edit {
|
|
59
|
+
flex: 0 0 auto;
|
|
60
|
+
margin-left: auto;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
.delete {
|
|
64
|
+
flex: 0 0 auto;
|
|
65
|
+
}
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import Button from "dt-design-system/es/button";
|
|
3
|
+
import Collapsible from "dt-design-system/es/collapsible";
|
|
4
|
+
import Popover from "dt-design-system/es/popover";
|
|
5
|
+
import Input from "dt-design-system/es/input";
|
|
6
|
+
import * as Icons from "dt-design-system/es/icons";
|
|
7
|
+
import Override from "./override";
|
|
8
|
+
import styles from "./overrides-list.module.css";
|
|
9
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
10
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
11
|
+
export default function OverridesList({
|
|
12
|
+
currentOffer,
|
|
13
|
+
overrides,
|
|
14
|
+
currentOverride,
|
|
15
|
+
setCurrentOverride,
|
|
16
|
+
config,
|
|
17
|
+
setConfig
|
|
18
|
+
}) {
|
|
19
|
+
const [opened, setOpened] = React.useState(false);
|
|
20
|
+
const [newOverride, setNewOverride] = React.useState("");
|
|
21
|
+
const [creationFormOpened, setCreationFormOpened] = React.useState(false);
|
|
22
|
+
const hasOverrides = overrides.length > 0;
|
|
23
|
+
const newOverrideAlreadyExists = overrides.some(o => o.name === newOverride);
|
|
24
|
+
const newOverrideIsEmpty = newOverride.trim() === "";
|
|
25
|
+
const newOverrideIsInvalid = newOverrideAlreadyExists || newOverrideIsEmpty;
|
|
26
|
+
const error = newOverrideAlreadyExists && "Ce nom est déjà utilisé";
|
|
27
|
+
const closeCreationForm = () => {
|
|
28
|
+
setCreationFormOpened(false);
|
|
29
|
+
};
|
|
30
|
+
const toggleCreationForm = () => {
|
|
31
|
+
setCreationFormOpened(!creationFormOpened);
|
|
32
|
+
};
|
|
33
|
+
const createOverride = e => {
|
|
34
|
+
e.preventDefault();
|
|
35
|
+
e.stopPropagation();
|
|
36
|
+
setConfig((config = {}) => {
|
|
37
|
+
const itemConfig = config[currentOffer] || {};
|
|
38
|
+
const itemOverrides = itemConfig.overrides || [];
|
|
39
|
+
const newId = itemOverrides.length ? Math.max(...itemOverrides.map(({
|
|
40
|
+
id
|
|
41
|
+
}) => id)) + 1 : 0;
|
|
42
|
+
const newOverrideName = newOverride.trim();
|
|
43
|
+
const newConfig = {
|
|
44
|
+
...config,
|
|
45
|
+
[currentOffer]: {
|
|
46
|
+
...itemConfig,
|
|
47
|
+
overrides: [...itemOverrides, {
|
|
48
|
+
id: newId,
|
|
49
|
+
name: newOverrideName,
|
|
50
|
+
trigger: {},
|
|
51
|
+
rules: {}
|
|
52
|
+
}]
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
return newConfig;
|
|
56
|
+
});
|
|
57
|
+
setOpened(true);
|
|
58
|
+
setNewOverride("");
|
|
59
|
+
closeCreationForm();
|
|
60
|
+
};
|
|
61
|
+
return _jsxs("div", {
|
|
62
|
+
className: styles.overrides,
|
|
63
|
+
children: [hasOverrides ? _jsx(Collapsible, {
|
|
64
|
+
title: `${overrides.length} surcharges`,
|
|
65
|
+
className: styles.collapsible,
|
|
66
|
+
compact: true,
|
|
67
|
+
open: opened,
|
|
68
|
+
toggleTooltip: "Afficher toutes les surcharges",
|
|
69
|
+
onOpenChange: setOpened,
|
|
70
|
+
hiddenContent: overrides.map(override => {
|
|
71
|
+
return _jsx(Override, {
|
|
72
|
+
currentOffer: currentOffer,
|
|
73
|
+
override: override,
|
|
74
|
+
currentOverride: currentOverride,
|
|
75
|
+
setCurrentOverride: setCurrentOverride,
|
|
76
|
+
config: config,
|
|
77
|
+
setConfig: setConfig,
|
|
78
|
+
closeCreationForm: closeCreationForm
|
|
79
|
+
}, override.id);
|
|
80
|
+
})
|
|
81
|
+
}) : null, _jsxs("div", {
|
|
82
|
+
className: styles.addOverride,
|
|
83
|
+
children: ["Ajouter une surcharge", " ", _jsx(Popover, {
|
|
84
|
+
className: styles.popover,
|
|
85
|
+
trigger: _jsx(Button, {
|
|
86
|
+
compact: true,
|
|
87
|
+
onClick: toggleCreationForm,
|
|
88
|
+
children: _jsx(Icons.Plus, {})
|
|
89
|
+
}),
|
|
90
|
+
open: creationFormOpened,
|
|
91
|
+
children: _jsxs("form", {
|
|
92
|
+
className: styles.createForm,
|
|
93
|
+
onSubmit: createOverride,
|
|
94
|
+
children: [_jsx(Input, {
|
|
95
|
+
placeholder: "Nom",
|
|
96
|
+
value: newOverride,
|
|
97
|
+
onValueChange: setNewOverride,
|
|
98
|
+
error: error,
|
|
99
|
+
compact: true,
|
|
100
|
+
autoFocus: true
|
|
101
|
+
}), _jsx(Button, {
|
|
102
|
+
className: styles.createSubmit,
|
|
103
|
+
type: "submit",
|
|
104
|
+
disabled: newOverrideIsInvalid,
|
|
105
|
+
children: "Ajouter"
|
|
106
|
+
})]
|
|
107
|
+
})
|
|
108
|
+
})]
|
|
109
|
+
})]
|
|
110
|
+
});
|
|
111
|
+
}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
.overrides {
|
|
2
|
+
display: flex;
|
|
3
|
+
flex-direction: column;
|
|
4
|
+
gap: 4px;
|
|
5
|
+
margin-bottom: 16px;
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
.overrides:not(:has(.addOverride:only-child)) {
|
|
9
|
+
position: relative;
|
|
10
|
+
padding-left: 20px;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
.overrides:not(:has(.addOverride:only-child))::before {
|
|
14
|
+
content: "";
|
|
15
|
+
position: absolute;
|
|
16
|
+
top: 12px;
|
|
17
|
+
left: 2px;
|
|
18
|
+
width: 2px;
|
|
19
|
+
height: calc(100% - 66px);
|
|
20
|
+
background-color: var(--ds-grey-200, #ededed);
|
|
21
|
+
border-radius: var(--ds-radius-100, 4px);
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
.addOverride {
|
|
25
|
+
display: flex;
|
|
26
|
+
align-items: center;
|
|
27
|
+
justify-content: space-between;
|
|
28
|
+
gap: 6px;
|
|
29
|
+
padding: 6px;
|
|
30
|
+
background-color: var(--ds-grey-100, #f8f8f8);
|
|
31
|
+
font-size: 13px;
|
|
32
|
+
border-radius: var(--ds-radius-100, 4px);
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
.collapsible {
|
|
36
|
+
--ds-collapsible-header-font-weight: 700;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
.collapsible > div:last-child {
|
|
40
|
+
display: flex;
|
|
41
|
+
flex-direction: column;
|
|
42
|
+
gap: 4px;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
.popover {
|
|
46
|
+
pointer-events: auto;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
.createForm {
|
|
50
|
+
display: flex;
|
|
51
|
+
align-items: flex-start;
|
|
52
|
+
gap: 4px;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
.createSubmit {
|
|
56
|
+
}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import classNames from "classnames";
|
|
3
|
+
import Checkbox from "dt-design-system/es/checkbox";
|
|
4
|
+
import NumberPicker from "dt-design-system/es/number-picker";
|
|
5
|
+
import styles from "./rule.module.css";
|
|
6
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
7
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
8
|
+
export default function Rule({
|
|
9
|
+
title,
|
|
10
|
+
uuid,
|
|
11
|
+
uuids,
|
|
12
|
+
currentOffer,
|
|
13
|
+
currentOverride,
|
|
14
|
+
config,
|
|
15
|
+
setConfig
|
|
16
|
+
}) {
|
|
17
|
+
const defaultConfig = config[currentOffer]?.default;
|
|
18
|
+
const isDefault = currentOverride === null;
|
|
19
|
+
const override = isDefault ? defaultConfig : config[currentOffer]?.overrides?.find(o => o.id === currentOverride?.id);
|
|
20
|
+
const currentValue = override?.rules?.[uuid]?.weight || 0;
|
|
21
|
+
const currentHidden = override?.rules?.[uuid]?.hidden || false;
|
|
22
|
+
const updateConfig = (key, value) => {
|
|
23
|
+
setConfig((config = {}) => {
|
|
24
|
+
const itemConfig = config[currentOffer] || {};
|
|
25
|
+
const newValue = key === "hidden" ? !value : Number(value);
|
|
26
|
+
if (isDefault) {
|
|
27
|
+
const defaultRules = defaultConfig?.rules || {};
|
|
28
|
+
const newConfig = {
|
|
29
|
+
...config,
|
|
30
|
+
[currentOffer]: {
|
|
31
|
+
...itemConfig,
|
|
32
|
+
default: {
|
|
33
|
+
...defaultConfig,
|
|
34
|
+
rules: {
|
|
35
|
+
...defaultRules,
|
|
36
|
+
[uuid]: {
|
|
37
|
+
...defaultRules?.[uuid],
|
|
38
|
+
[key]: newValue
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
return newConfig;
|
|
45
|
+
} else {
|
|
46
|
+
const itemOverrides = itemConfig.overrides || [];
|
|
47
|
+
const overrideConfig = itemOverrides.find(o => o.id === override.id);
|
|
48
|
+
const rulesConfig = overrideConfig?.rules || {};
|
|
49
|
+
const offerConfig = overrideConfig?.[uuid] || {};
|
|
50
|
+
const cleanedRulesConfig = Object.keys(rulesConfig).reduce((acc, key) => {
|
|
51
|
+
if (uuids.includes(key)) {
|
|
52
|
+
return {
|
|
53
|
+
...acc,
|
|
54
|
+
[key]: rulesConfig[key]
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
return acc;
|
|
58
|
+
}, {});
|
|
59
|
+
const newConfig = {
|
|
60
|
+
...config,
|
|
61
|
+
[currentOffer]: {
|
|
62
|
+
...itemConfig,
|
|
63
|
+
overrides: [...itemOverrides.map(o => {
|
|
64
|
+
if (o.id === override.id) {
|
|
65
|
+
return {
|
|
66
|
+
...o,
|
|
67
|
+
rules: {
|
|
68
|
+
...cleanedRulesConfig,
|
|
69
|
+
[uuid]: {
|
|
70
|
+
...offerConfig,
|
|
71
|
+
[key]: newValue
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
return o;
|
|
77
|
+
})]
|
|
78
|
+
}
|
|
79
|
+
};
|
|
80
|
+
return newConfig;
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
};
|
|
84
|
+
const classes = classNames(styles.rule, {
|
|
85
|
+
[styles.disabled]: currentHidden
|
|
86
|
+
});
|
|
87
|
+
return _jsxs("div", {
|
|
88
|
+
className: classes,
|
|
89
|
+
children: [_jsx(Checkbox, {
|
|
90
|
+
className: styles.checkbox,
|
|
91
|
+
checked: !currentHidden,
|
|
92
|
+
onCheckedChange: value => updateConfig("hidden", value)
|
|
93
|
+
}), _jsx("div", {
|
|
94
|
+
className: styles.title,
|
|
95
|
+
children: title
|
|
96
|
+
}), _jsx(NumberPicker, {
|
|
97
|
+
className: styles.valuePicker,
|
|
98
|
+
value: currentValue,
|
|
99
|
+
onChange: value => updateConfig("weight", value),
|
|
100
|
+
min: -10,
|
|
101
|
+
max: 10,
|
|
102
|
+
disabled: !currentOffer
|
|
103
|
+
})]
|
|
104
|
+
}, uuid);
|
|
105
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
.rule {
|
|
2
|
+
width: 100%;
|
|
3
|
+
display: flex;
|
|
4
|
+
align-items: center;
|
|
5
|
+
gap: 6px;
|
|
6
|
+
padding: 6px 0;
|
|
7
|
+
border-radius: var(--ds-radius-100, 4px);
|
|
8
|
+
transition: background-color 160ms
|
|
9
|
+
var(--ds-transition-easing, cubic-bezier(0.4, 0.1, 0.2, 0.9));
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
.disabled {
|
|
13
|
+
opacity: 0.5;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
.checkbox {
|
|
17
|
+
flex: 0 0 24px;
|
|
18
|
+
margin-right: 4px;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
.title {
|
|
22
|
+
flex: 0 0 100px;
|
|
23
|
+
width: 100px;
|
|
24
|
+
font-size: 13px;
|
|
25
|
+
font-weight: 700;
|
|
26
|
+
line-height: 1;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
.select {
|
|
30
|
+
flex: 0 0 160px;
|
|
31
|
+
width: 160px;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
.valuePicker {
|
|
35
|
+
width: fit-content;
|
|
36
|
+
margin-left: auto;
|
|
37
|
+
}
|