@configuratorware/configurator-frontendgui 1.28.3 → 1.29.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/App/Constant.js +73 -0
- package/App/Error/DevelopmentErrorPage/index.js +74 -0
- package/App/Error/ErrorBoundary.js +98 -0
- package/App/Error/ProductionErrorPage/Style.scss +47 -0
- package/App/Error/ProductionErrorPage/index.js +43 -0
- package/App/Error/ProductionErrorPage/index.story.js +13 -0
- package/App/Error/ProductionErrorPage/res/error_gears.png +0 -0
- package/App/Frame.js +95 -0
- package/App/Modules/Creator/Components/ConfigurationvariantItem/Styles.scss +33 -0
- package/App/Modules/Creator/Components/ConfigurationvariantItem/index.js +118 -0
- package/App/Modules/Creator/Components/ConfigurationvariantSelection/Styles.scss +47 -0
- package/App/Modules/Creator/Components/ConfigurationvariantSelection/index.js +130 -0
- package/App/Modules/Creator/Components/CustomTitleEditor/Styles.scss +43 -0
- package/App/Modules/Creator/Components/CustomTitleEditor/index.js +144 -0
- package/App/Modules/Creator/Components/ExternalVisualization/index.js +140 -0
- package/App/Modules/Creator/Components/FastConfiguration/SelectableRow.js +128 -0
- package/App/Modules/Creator/Components/FastConfiguration/Styles.scss +53 -0
- package/App/Modules/Creator/Components/FastConfiguration/index.js +280 -0
- package/App/Modules/Creator/Components/FastConfigurationRow/Styles.scss +45 -0
- package/App/Modules/Creator/Components/FastConfigurationRow/index.js +78 -0
- package/App/Modules/Creator/Components/FastConfigurationSelect/Styles.scss +35 -0
- package/App/Modules/Creator/Components/FastConfigurationSelect/index.js +251 -0
- package/App/Modules/Creator/Components/FormattedNumber/index.js +45 -0
- package/App/Modules/Creator/Components/FormattedPrice/index.js +57 -0
- package/App/Modules/Creator/Components/FullScreenView/FullScreenView.js +104 -0
- package/App/Modules/Creator/Components/Incompatibility/OptionRule/index.js +182 -0
- package/App/Modules/Creator/Components/Incompatibility/RuleComponent.js +88 -0
- package/App/Modules/Creator/Components/Incompatibility/index.js +251 -0
- package/App/Modules/Creator/Components/InvalidConfigurationNotice/index.js +164 -0
- package/App/Modules/Creator/Components/LoginForm/Styles.scss +9 -0
- package/App/Modules/Creator/Components/LoginForm/index.js +129 -0
- package/App/Modules/Creator/Components/Option/index.js +545 -0
- package/App/Modules/Creator/Components/Option/index.story.js +154 -0
- package/App/Modules/Creator/Components/OptionAmount/index.js +236 -0
- package/App/Modules/Creator/Components/OptionGroup/index.js +55 -0
- package/App/Modules/Creator/Components/Optiondetail/ZoomImage/index.js +173 -0
- package/App/Modules/Creator/Components/Optiondetail/index.js +499 -0
- package/App/Modules/Creator/Components/Optiondetail/index.story.js +117 -0
- package/App/Modules/Creator/Components/OptionsList/index.js +193 -0
- package/App/Modules/Creator/Components/Price/Styles.scss +3 -0
- package/App/Modules/Creator/Components/Price/index.js +79 -0
- package/App/Modules/Creator/Components/ProductPart/index.js +187 -0
- package/App/Modules/Creator/Components/ProductPart/index.story.js +88 -0
- package/App/Modules/Creator/Components/ProductPartsList/index.js +153 -0
- package/App/Modules/Creator/Components/ProductPartsList/index.story.js +101 -0
- package/App/Modules/Creator/Components/SavedConfiguration/Styles.scss +19 -0
- package/App/Modules/Creator/Components/SavedConfiguration/index.js +82 -0
- package/App/Modules/Creator/Components/ShareConfiguration/Styles.scss +23 -0
- package/App/Modules/Creator/Components/ShareConfiguration/index.js +224 -0
- package/App/Modules/Creator/Components/StockInformation/index.js +93 -0
- package/App/Modules/Creator/Components/StoreConfigurationForm/Styles.scss +5 -0
- package/App/Modules/Creator/Components/StoreConfigurationForm/index.js +123 -0
- package/App/Modules/Creator/Components/Tools/Styles.scss +44 -0
- package/App/Modules/Creator/Components/Tools/index.js +102 -0
- package/App/Modules/Creator/Components/ValidationResult/Styles.scss +45 -0
- package/App/Modules/Creator/Components/ValidationResult/index.js +165 -0
- package/App/Modules/Creator/Components/index.js +84 -0
- package/App/Modules/Creator/Containers/AmountPrice/index.js +26 -0
- package/App/Modules/Creator/Containers/ConfigurationvariantSelection/index.js +60 -0
- package/App/Modules/Creator/Containers/CustomTitleEditor/index.js +52 -0
- package/App/Modules/Creator/Containers/FastConfiguration/index.js +62 -0
- package/App/Modules/Creator/Containers/FormattedPrice/index.js +31 -0
- package/App/Modules/Creator/Containers/Incompatibility/index.js +40 -0
- package/App/Modules/Creator/Containers/InvalidConfigurationNotice/index.js +89 -0
- package/App/Modules/Creator/Containers/LoadingOverlay/index.js +26 -0
- package/App/Modules/Creator/Containers/Optiondetail/index.js +48 -0
- package/App/Modules/Creator/Containers/OptionsList/index.js +49 -0
- package/App/Modules/Creator/Containers/ProductPart/index.js +26 -0
- package/App/Modules/Creator/Containers/ProductPartsList/index.js +50 -0
- package/App/Modules/Creator/Containers/SavedConfigurationContainer/index.js +25 -0
- package/App/Modules/Creator/Containers/ShareConfiguration/index.js +42 -0
- package/App/Modules/Creator/Containers/StockInformation/index.js +33 -0
- package/App/Modules/Creator/Containers/Tools/index.js +44 -0
- package/App/Modules/Creator/Containers/ValidationResult/index.js +34 -0
- package/App/Modules/Creator/Containers/index.js +175 -0
- package/App/Modules/Creator/CreatorScreen.js +307 -0
- package/App/Modules/Creator/Layouts/DefaultLayout.js +260 -0
- package/App/Modules/Creator/Styles.scss +216 -0
- package/App/Modules/Designer/Components/AddGalleryImage/index.js +234 -0
- package/App/Modules/Designer/Components/AddGalleryImage/index.story.js +94 -0
- package/App/Modules/Designer/Components/AddGalleryImage/index.test.js +151 -0
- package/App/Modules/Designer/Components/AddVisualElement/Styles.scss +0 -0
- package/App/Modules/Designer/Components/AddVisualElement/index.js +278 -0
- package/App/Modules/Designer/Components/AddVisualElement/index.story.js +24 -0
- package/App/Modules/Designer/Components/AddVisualElement/index.test.js +47 -0
- package/App/Modules/Designer/Components/CloseDesignEditor/index.js +130 -0
- package/App/Modules/Designer/Components/CloseGraphicsEditorButton/index.js +54 -0
- package/App/Modules/Designer/Components/ColorPalettes/ColorPalettesSearch.js +175 -0
- package/App/Modules/Designer/Components/ColorPalettes/index.js +814 -0
- package/App/Modules/Designer/Components/ColorPalettes/index.story.js +158 -0
- package/App/Modules/Designer/Components/ColorPalettes/index.test.js +150 -0
- package/App/Modules/Designer/Components/DesignAreaControlbox/Styles.scss +0 -0
- package/App/Modules/Designer/Components/DesignAreaControlbox/index.js +467 -0
- package/App/Modules/Designer/Components/DesignAreaControlbox/index.story.js +272 -0
- package/App/Modules/Designer/Components/DesignAreaControlbox/index.test.js +164 -0
- package/App/Modules/Designer/Components/DesignerSelectionToolbox/CustomFontOverlay.js +162 -0
- package/App/Modules/Designer/Components/DesignerSelectionToolbox/DesignerSelectionToolbox.js +425 -0
- package/App/Modules/Designer/Components/DesignerSelectionToolbox/fontItemUtils.js +48 -0
- package/App/Modules/Designer/Components/Dialog/index.js +125 -0
- package/App/Modules/Designer/Components/EditDesignButton/index.js +128 -0
- package/App/Modules/Designer/Components/FeedbackNotice/index.js +110 -0
- package/App/Modules/Designer/Components/FeedbackNotice/index.test.js +16 -0
- package/App/Modules/Designer/Components/FullScreenView/FullScreenView.js +63 -0
- package/App/Modules/Designer/Components/ImageColorPicker/ImageColorPicker.dev.js +32 -0
- package/App/Modules/Designer/Components/ImageColorPicker/ImageColorPicker.js +430 -0
- package/App/Modules/Designer/Components/ImageColorize/index.js +636 -0
- package/App/Modules/Designer/Components/ImageColorize/index.story.js +73 -0
- package/App/Modules/Designer/Components/ImageControlbox/index.js +302 -0
- package/App/Modules/Designer/Components/ImageEditDialog/ImageThumbnail.js +171 -0
- package/App/Modules/Designer/Components/ImageEditDialog/ImageUpload.js +478 -0
- package/App/Modules/Designer/Components/ImageEditDialog/index.js +716 -0
- package/App/Modules/Designer/Components/ImageEditDialog/res/baseline_colorize_black_24dp.png +0 -0
- package/App/Modules/Designer/Components/ImageEditDialog/res/checkers_tile.png +0 -0
- package/App/Modules/Designer/Components/ImageLibraryFilter/index.js +179 -0
- package/App/Modules/Designer/Components/ImageLibraryThumbnail/Styles.scss +14 -0
- package/App/Modules/Designer/Components/ImageLibraryThumbnail/index.js +165 -0
- package/App/Modules/Designer/Components/ObjectTools/index.js +146 -0
- package/App/Modules/Designer/Components/Select/index.js +171 -0
- package/App/Modules/Designer/Components/TextControlbox/TextFormatIcon.js +48 -0
- package/App/Modules/Designer/Components/TextControlbox/index.js +656 -0
- package/App/Modules/Designer/Components/TextControlbox/index.story.js +109 -0
- package/App/Modules/Designer/Components/TextControlbox/index.test.js +172 -0
- package/App/Modules/Designer/Containers/AddGalleryImage.js +90 -0
- package/App/Modules/Designer/Containers/AddVisualElement.js +166 -0
- package/App/Modules/Designer/Containers/CloseDesignEditor.js +32 -0
- package/App/Modules/Designer/Containers/CloseGraphicsEditorButton.js +32 -0
- package/App/Modules/Designer/Containers/ColorPalettes.js +145 -0
- package/App/Modules/Designer/Containers/DesignAreaControlbox.js +54 -0
- package/App/Modules/Designer/Containers/Designer.js +37 -0
- package/App/Modules/Designer/Containers/DesignerSelectionToolbox.js +116 -0
- package/App/Modules/Designer/Containers/EditDesignButton.js +35 -0
- package/App/Modules/Designer/Containers/ImageEditDialog.js +1130 -0
- package/App/Modules/Designer/Designer.js +231 -0
- package/App/Modules/Designer/DesignerScreen.js +255 -0
- package/App/Modules/Designer/DesignerUI.js +241 -0
- package/App/Modules/Designer/Layouts/DefaultLayout.js +221 -0
- package/App/Modules/Designer/Layouts/Mobile/TwoSideBottomBar.js +50 -0
- package/App/Modules/Designer/Layouts/PopupAreaProvider.js +186 -0
- package/App/Modules/Designer/MultilayerComponents/DesignerClickAwayListener.js +53 -0
- package/App/Modules/Designer/MultilayerComponents/InlineToolboxPortal.js +106 -0
- package/App/Modules/Designer/MultilayerComponents/StandardToolboxPortal.js +64 -0
- package/App/Modules/Designer/Utils/FontFaceRepository.js +82 -0
- package/App/Modules/Designer/Utils/ImageEditUtils.js +104 -0
- package/App/Modules/Designer/Utils/Transformers.js +164 -0
- package/App/Modules/Designer/setupDesigner.js +182 -0
- package/App/Modules/Designer/withActiveCanvas.js +136 -0
- package/App/Modules/Visualization/AlignTargetContainer.js +55 -0
- package/App/Modules/Visualization/CreatorAlignTarget.js +41 -0
- package/App/Modules/Visualization/DefaultVisualizationProvider.js +105 -0
- package/App/Modules/Visualization/DesignerAlignTarget.js +45 -0
- package/App/Modules/Visualization/Utils/getFirstDataURLFromScreenshotsObj.js +20 -0
- package/App/Reducers/Actions.js +297 -0
- package/App/Reducers/ConfigurationMode/Actions.js +21 -0
- package/App/Reducers/ConfigurationMode/Reducer.js +80 -0
- package/App/Reducers/ConfigurationMode/Selectors.js +84 -0
- package/App/Reducers/Configurator/Actions.js +1417 -0
- package/App/Reducers/Configurator/AttributeSelectors.js +32 -0
- package/App/Reducers/Configurator/Modifiers.js +35 -0
- package/App/Reducers/Configurator/Reducer.js +639 -0
- package/App/Reducers/Configurator/Selectors.js +242 -0
- package/App/Reducers/Confirm/Actions.js +84 -0
- package/App/Reducers/Confirm/Reducer.js +30 -0
- package/App/Reducers/DesignArea/Actions.js +76 -0
- package/App/Reducers/DesignArea/DesignElementSelectors.js +114 -0
- package/App/Reducers/DesignArea/MaskSelectors.js +101 -0
- package/App/Reducers/DesignArea/Reducer.js +150 -0
- package/App/Reducers/DesignArea/Selectors.js +1304 -0
- package/App/Reducers/DesignArea/Transformers.js +333 -0
- package/App/Reducers/DesignData/Actions.js +232 -0
- package/App/Reducers/DesignData/Modifiers.js +328 -0
- package/App/Reducers/DesignData/Reducer.js +189 -0
- package/App/Reducers/DesignData/Selectors.js +94 -0
- package/App/Reducers/DesignData/Transformers.js +27 -0
- package/App/Reducers/DesignView/Actions.js +19 -0
- package/App/Reducers/DesignView/Reducer.js +165 -0
- package/App/Reducers/DesignView/Selectors.js +130 -0
- package/App/Reducers/DesignView/Transformers.js +32 -0
- package/App/Reducers/Device/Actions.js +16 -0
- package/App/Reducers/Device/Reducer.js +51 -0
- package/App/Reducers/Fonts/Actions.js +137 -0
- package/App/Reducers/Fonts/Reducer.js +39 -0
- package/App/Reducers/Fonts/Selectors.js +98 -0
- package/App/Reducers/GeneralActions.js +16 -0
- package/App/Reducers/ImageGallery/Actions.js +336 -0
- package/App/Reducers/ImageGallery/Modifiers.js +67 -0
- package/App/Reducers/ImageGallery/Reducer.js +320 -0
- package/App/Reducers/ImageGallery/Selectors.js +206 -0
- package/App/Reducers/Reducer.js +107 -0
- package/App/Reducers/UI/Actions.js +191 -0
- package/App/Reducers/UI/Reducer.js +98 -0
- package/App/Reducers/UI/Selectors.js +32 -0
- package/App/Reducers.js +48 -0
- package/App/Routing.js +168 -0
- package/App/Screens/Configurator/CalculationWidgetScreen.js +84 -0
- package/App/Screens/Configurator/Components/AmountSelection/Styles.scss +17 -0
- package/App/Screens/Configurator/Components/AmountSelection/index.js +170 -0
- package/App/Screens/Configurator/Components/AmountSelection/index.story.js +36 -0
- package/App/Screens/Configurator/Components/CalculationWidget/index.js +652 -0
- package/App/Screens/Configurator/Components/CalculationWidget/index.story.js +154 -0
- package/App/Screens/Configurator/Components/CalculationWidget/index.test.js +142 -0
- package/App/Screens/Configurator/Components/ConfigurationModeSwitch/ConfigurationModeSwitch.js +82 -0
- package/App/Screens/Configurator/Components/ConfigurationModeSwitch/index.js +15 -0
- package/App/Screens/Configurator/Components/Confirm/Styles.scss +0 -0
- package/App/Screens/Configurator/Components/Confirm/index.js +105 -0
- package/App/Screens/Configurator/Components/DesignApproval/index.js +76 -0
- package/App/Screens/Configurator/Components/DesignApproval/index.story.js +27 -0
- package/App/Screens/Configurator/Components/DesignApproval/index.test.js +31 -0
- package/App/Screens/Configurator/Components/Error/index.js +106 -0
- package/App/Screens/Configurator/Components/FallbackVisualization/FallbackVisualization.js +96 -0
- package/App/Screens/Configurator/Components/FileUpload/FileUploadBase.js +1 -0
- package/App/Screens/Configurator/Components/FullScreenView/index.js +304 -0
- package/App/Screens/Configurator/Components/FullScreenView/index.test.js +28 -0
- package/App/Screens/Configurator/Components/ImageLoader/ImageLoader.js +96 -0
- package/App/Screens/Configurator/Components/LandscapeInformation/index.js +75 -0
- package/App/Screens/Configurator/Components/NoVisualization/NoVisualization.js +35 -0
- package/App/Screens/Configurator/Components/PreviewPortal/index.js +249 -0
- package/App/Screens/Configurator/Components/Styles.scss +1 -0
- package/App/Screens/Configurator/Components/Thumbnail/index.js +394 -0
- package/App/Screens/Configurator/Components/Thumbnail/index.test.js +50 -0
- package/App/Screens/Configurator/Components/TotalPrice/TotalPrice.js +57 -0
- package/App/Screens/Configurator/Containers/AmountPrice.js +84 -0
- package/App/Screens/Configurator/Containers/CalculationWidget.js +278 -0
- package/App/Screens/Configurator/Containers/ConfigurationModeSwitch.js +81 -0
- package/App/Screens/Configurator/Containers/Confirm.js +37 -0
- package/App/Screens/Configurator/Containers/DesignApproval.js +129 -0
- package/App/Screens/Configurator/Containers/FallbackVisualization.js +32 -0
- package/App/Screens/Configurator/Containers/FullScreenView.js +47 -0
- package/App/Screens/Configurator/Containers/Thumbnail.js +41 -0
- package/App/Screens/Configurator/Containers/Visualization.js +13 -0
- package/App/Screens/Configurator/DynamicComponents.js +40 -0
- package/App/Screens/Configurator/Screen.js +238 -0
- package/App/Screens/Configurator/ScreenPropTypes.js +45 -0
- package/App/Screens/Configurator/ThemeProvider.js +298 -0
- package/App/Screens/DesignerProductPreview/Constants.js +12 -0
- package/App/Screens/DesignerProductPreview/DesignerProductPreviewManager.js +554 -0
- package/App/Screens/DesignerProductPreview/Screen.js +407 -0
- package/App/Screens.js +42 -0
- package/App/ServiceLocator.js +309 -0
- package/App/Services/AdminareaCommunicationService.js +149 -0
- package/App/Services/AnalyticsService.js +403 -0
- package/App/Services/ConfiguratorService.js +1166 -0
- package/App/Services/DesignDataService.js +3249 -0
- package/App/Services/DesignerService.js +496 -0
- package/App/Services/InteractionService.js +784 -0
- package/App/Services/UIService.js +129 -0
- package/App/Services/VisualizationService.js +844 -0
- package/App/Shared/Components/AcceptDesign/index.js +166 -0
- package/App/Shared/Components/AddToBasket/index.js +194 -0
- package/App/Shared/Components/AddToBasket/index.story.js +47 -0
- package/App/Shared/Components/AlertDialog/index.js +138 -0
- package/App/Shared/Components/AmountInput/Styles.scss +6 -0
- package/App/Shared/Components/AmountInput/index.js +296 -0
- package/App/Shared/Components/AmountInput/index.story.js +29 -0
- package/App/Shared/Components/AmountPrice/index.js +925 -0
- package/App/Shared/Components/AmountPrice/index.story.js +112 -0
- package/App/Shared/Components/AmountPrice/index.test.js +125 -0
- package/App/Shared/Components/Analytics/AnalyticsWrapper.js +49 -0
- package/App/Shared/Components/BulkNames/index.js +319 -0
- package/App/Shared/Components/CallToAction/index.js +220 -0
- package/App/Shared/Components/Header/Header.js +150 -0
- package/App/Shared/Components/Header/index.js +15 -0
- package/App/Shared/Components/Header/index.story.js +143 -0
- package/App/Shared/Components/InformationTag/InformationTag.js +155 -0
- package/App/Shared/Components/LicenseNotice/LicenseNotice.js +148 -0
- package/App/Shared/Components/LicenseNotice/index.js +15 -0
- package/App/Shared/Components/LoadConfiguration/index.js +218 -0
- package/App/Shared/Components/MessageBox/index.js +84 -0
- package/App/Shared/Components/MessageBox/index.story.js +49 -0
- package/App/Shared/Components/Notification/index.js +105 -0
- package/App/Shared/Components/Notification/index.story.js +55 -0
- package/App/Shared/Components/PdfDownload/index.js +150 -0
- package/App/Shared/Components/PlusMinusInput/index.js +118 -0
- package/App/Shared/Components/PriceList/index.js +237 -0
- package/App/Shared/Components/PriceList/index.story.js +114 -0
- package/App/Shared/Components/PriceOverview/index.js +177 -0
- package/App/Shared/Components/PriceOverview/index.story.js +215 -0
- package/App/Shared/Components/ProductVariant/Image.js +75 -0
- package/App/Shared/Components/ProductVariant/Styles.scss +11 -0
- package/App/Shared/Components/ProductVariant/index.js +477 -0
- package/App/Shared/Components/ProductVariant/index.story.js +283 -0
- package/App/Shared/Components/Progress/Progress.js +59 -0
- package/App/Shared/Components/ReceiveOfferForm/index.js +432 -0
- package/App/Shared/Components/ReceiveOfferForm/index.story.js +32 -0
- package/App/Shared/Components/ReceiveOfferForm/index.test.js +36 -0
- package/App/Shared/Components/SaveConfiguration/index.js +286 -0
- package/App/Shared/Components/SendEmail/index.js +103 -0
- package/App/Shared/Components/Stepper/index.js +136 -0
- package/App/Shared/Components/Stepper/index.story.js +38 -0
- package/App/Shared/Components/ToolbarList/index.js +231 -0
- package/App/Shared/Components/ToolbarList/index.story.js +33 -0
- package/App/Shared/Components/VariantChooser/index.js +270 -0
- package/App/Shared/Components/VariantChooser/index.story.js +100 -0
- package/App/Shared/Containers/AlertMessages.js +37 -0
- package/App/Shared/Containers/AmountPrice/AmountPriceAdminareaWrapper.js +40 -0
- package/App/Shared/Containers/AmountPrice/index.js +284 -0
- package/App/Shared/Containers/BulkNames.js +310 -0
- package/App/Shared/Containers/Error.js +37 -0
- package/App/Shared/Containers/GlobalLoader.js +25 -0
- package/App/Shared/Containers/Header/index.js +178 -0
- package/App/Shared/Containers/LicenseNotice/LicenseNotice.js +26 -0
- package/App/Shared/Containers/LicenseNotice/index.js +15 -0
- package/App/Shared/Containers/LoadConfiguration/LoadConfiguration.js +146 -0
- package/App/Shared/Containers/LoadConfiguration/index.js +15 -0
- package/App/Shared/Containers/PdfDownload/index.js +39 -0
- package/App/Shared/Containers/ProductVariant/ProductVariant.js +339 -0
- package/App/Shared/Containers/ProductVariant/index.js +15 -0
- package/App/Shared/Containers/SaveConfiguration.js +49 -0
- package/App/Shared/Containers/SendEmail/SendEmail.js +45 -0
- package/App/Shared/Containers/SendEmail/index.js +15 -0
- package/App/Shared/Providers/DefaultCanvasProvider.js +86 -0
- package/App/Storage.js +17 -0
- package/App/Store.js +87 -0
- package/App/Styles.scss +0 -0
- package/App/Translations.js +88 -0
- package/App/Utils/createMessageInterface.js +65 -0
- package/App/Utils/customClassName.js +12 -0
- package/App/Utils/getContrastText.js +27 -0
- package/App/Utils/getImageUrl.js +32 -0
- package/App/Variables.scss +84 -0
- package/App/configuration.js +421 -0
- package/App/index.js +52 -0
- package/App/initServices.js +67 -0
- package/App/setup.js +22 -0
- package/App/versionInfo.js +8 -0
- package/Framework/Api.js +178 -0
- package/Framework/ComponentContainer.js +165 -0
- package/Framework/Components/Carousel/Styles.scss +85 -0
- package/Framework/Components/Carousel/index.js +322 -0
- package/Framework/Components/Dialog/Style.scss +79 -0
- package/Framework/Components/Dialog/index.js +721 -0
- package/Framework/Components/DialogSelect/Styles.scss +53 -0
- package/Framework/Components/DialogSelect/index.js +331 -0
- package/Framework/Components/Input/index.js +147 -0
- package/Framework/Components/LoadingOverlay/Styles.scss +37 -0
- package/Framework/Components/LoadingOverlay/index.js +33 -0
- package/Framework/Components/Markdown/index.js +62 -0
- package/Framework/Components/Mobile/index.js +33 -0
- package/Framework/CustomError.js +51 -0
- package/Framework/Helpers/TransitionDetect.js +116 -0
- package/Framework/Helpers/isLandscapeMobile.js +14 -0
- package/Framework/Helpers/isMobileDevice.js +17 -0
- package/Framework/Helpers/isMobileSize.js +13 -0
- package/Framework/Mixins.scss +235 -0
- package/Framework/Services/AbstractAdminareaCommunicationService.js +48 -0
- package/Framework/Services/AbstractAsyncService.js +44 -0
- package/Framework/Services/AbstractConfiguratorService.js +47 -0
- package/Framework/Services/AbstractInteractionService.js +50 -0
- package/Framework/Services/AbstractStoreService.js +42 -0
- package/Framework/Services/AbstractUIService.js +53 -0
- package/Framework/Services/AbstractVisualizationService.js +47 -0
- package/Framework/Services/AsyncService.js +93 -0
- package/Framework/Services/StoreService.js +237 -0
- package/Framework/Variables.scss +22 -0
- package/Framework/bindDecorator.js +173 -0
- package/Framework/i18n.js +382 -0
- package/README.md +5 -26
- package/Resources/Icons/MaterialUI/Icons/AddCircle.js +13 -0
- package/Resources/Icons/MaterialUI/Icons/RemoveCircle.js +13 -0
- package/Resources/Icons/MaterialUI/fontFace.scss +37 -0
- package/Resources/Icons/MaterialUI/fonts/MaterialIcons-Regular.eot +0 -0
- package/Resources/Icons/MaterialUI/fonts/MaterialIcons-Regular.svg +2373 -0
- package/Resources/Icons/MaterialUI/fonts/MaterialIcons-Regular.ttf +0 -0
- package/Resources/Icons/MaterialUI/fonts/MaterialIcons-Regular.woff +0 -0
- package/Resources/Icons/MaterialUI/fonts/MaterialIcons-Regular.woff2 +0 -0
- package/Resources/Icons/fonts/ionicons.eot +0 -0
- package/Resources/Icons/fonts/ionicons.svg +2230 -0
- package/Resources/Icons/fonts/ionicons.ttf +0 -0
- package/Resources/Icons/fonts/ionicons.woff +0 -0
- package/Resources/Icons/ionicons.scss +1489 -0
- package/Resources/Icons/ioniconsExtend.scss +1469 -0
- package/Resources/Icons/v4/fontFace.scss +11 -0
- package/Resources/Icons/v4/fonts/ionicons.eot +0 -0
- package/Resources/Icons/v4/fonts/ionicons.svg +2090 -0
- package/Resources/Icons/v4/fonts/ionicons.ttf +0 -0
- package/Resources/Icons/v4/fonts/ionicons.woff +0 -0
- package/Resources/Icons/v4/fonts/ionicons.woff2 +0 -0
- package/Resources/Icons/v4/icons.scss +15 -0
- package/Resources/Icons/v4/iconsExtend.scss +7 -0
- package/Resources/Images/designer_placeholder_logo.svg +1 -0
- package/Resources/Masks/circle.svg +4 -0
- package/Shared/Components/CustomDialog.js +133 -0
- package/Shared/Components/CustomDialogSelect.js +161 -0
- package/Shared/Components/MainButton.js +81 -0
- package/Shared/ErrorTypes/DeferredError.js +51 -0
- package/Shared/HOCs/ResizeDetect/ResizeDetect.dev.js +60 -0
- package/Shared/HOCs/ResizeDetect/ResizeDetect.js +217 -0
- package/Shared/HOCs/getDisplayName.js +10 -0
- package/Shared/HOCs/withFixedChangeHandler.js +46 -0
- package/Shared/PropTypes/ReactComponent.js +13 -0
- package/Shared/Styles/absoluteCenter.js +17 -0
- package/Utils/Array/isIdentical.js +38 -0
- package/Utils/Async/AsyncManager.js +128 -0
- package/Utils/Async/Deferred.js +145 -0
- package/Utils/Async/ObjectLock.js +38 -0
- package/Utils/Decorators/Observable.js +130 -0
- package/Utils/Dev/HOCs/withFilePicker.js +101 -0
- package/Utils/Dev/isDev.js +21 -0
- package/Utils/Events/pointerEvent.js +199 -0
- package/Utils/Events/preventEventDoubling.js +23 -0
- package/Utils/Function/cached.js +64 -0
- package/Utils/Function/createDebounceManager.js +77 -0
- package/Utils/Function/createSelector.js +62 -0
- package/Utils/Function/memoize.js +46 -0
- package/Utils/Function/sendMessage.js +22 -0
- package/Utils/Helper/createSelectionRangeMemo.js +45 -0
- package/Utils/Immutable/set.js +81 -0
- package/Utils/Math/conversions.js +13 -0
- package/Utils/Math/isPositiveNumber.js +12 -0
- package/Utils/Redux/createActionWithGlobalState.js +23 -0
- package/Utils/Styles/combineMediaQueries.js +24 -0
- package/Utils/Styles/createCheckerBoardBackground.js +22 -0
- package/Utils/Test/CallOrderChecker.js +29 -0
- package/Utils/Test/createStoreProvider.js +33 -0
- package/Utils/Test/formDataToJSON.js +20 -0
- package/Utils/Test/mountWithState.js +40 -0
- package/index.js +8 -0
- package/package.json +22 -103
- package/scripts/cpPublic.js +3 -3
- package/scripts/getDefaultWebpackConfig.js +11 -10
- package/src/App/Error/ProductionErrorPage/Style.scss +1 -1
- package/src/App/Modules/Creator/Components/Option/index.test.js +1 -1
- package/src/App/Modules/Creator/Components/OptionAmount/index.test.js +1 -1
- package/src/App/Modules/Creator/Components/ProductPart/__snapshots__/index.test.js.snap +33 -10
- package/src/App/Modules/Creator/Components/ProductPart/index.js +5 -1
- package/src/App/Modules/Creator/Components/ProductPart/index.test.js +14 -1
- package/src/App/Modules/Creator/Components/ProductPartsList/index.js +3 -0
- package/src/App/Modules/Creator/Containers/ProductPartsList/index.js +1 -0
- package/src/App/Modules/Designer/Components/AddGalleryImage/index.story.js +1 -1
- package/src/App/Modules/Designer/Components/ColorPalettes/index.test.jsx +1 -1
- package/src/App/Modules/Designer/Components/DesignAreaControlbox/index.js +21 -4
- package/src/App/Modules/Designer/Components/DesignAreaControlbox/index.test.jsx +1 -1
- package/src/App/Modules/Designer/Components/TextControlbox/index.test.jsx +1 -1
- package/src/App/Modules/Designer/Containers/Designer.js +1 -1
- package/src/App/Modules/Designer/DesignerScreen.js +32 -8
- package/src/App/{Screens/Configurator → Modules/Designer}/DesignerUI.js +42 -26
- package/src/App/Modules/Designer/Layouts/DefaultLayout.js +35 -1
- package/src/App/Modules/Designer/MultilayerComponents/DesignerClickAwayListener.js +18 -0
- package/src/App/Modules/Designer/MultilayerComponents/InlineToolboxPortal.js +54 -0
- package/src/App/Modules/Designer/MultilayerComponents/StandardToolboxPortal.js +38 -0
- package/src/App/Reducers/DesignView/Actions.js +1 -2
- package/src/App/Reducers/DesignView/Reducer.js +2 -10
- package/src/App/Reducers/DesignView/__mocks__/designerViewData.js +0 -1
- package/src/App/Reducers/DesignView/__tests__/Reducer.test.js +0 -22
- package/src/App/Reducers/ImageGallery/Actions.js +1 -1
- package/src/App/Screens/Configurator/Components/CalculationWidget/index.test.jsx +1 -1
- package/src/App/Screens/Configurator/Components/DesignApproval/index.test.jsx +1 -1
- package/src/App/Screens/Configurator/Components/FullScreenView/index.js +3 -2
- package/src/App/Screens/Configurator/Components/FullScreenView/index.test.jsx +1 -1
- package/src/App/Screens/Configurator/Components/PreviewPortal/index.js +7 -3
- package/src/App/Screens/Configurator/Containers/AmountPrice.js +1 -1
- package/src/App/Screens/Configurator/Containers/Confirm.js +1 -1
- package/src/App/Screens/Configurator/Containers/FullScreenView.js +1 -0
- package/src/App/Screens/Configurator/Containers/__tests__/Designer.test.js +1 -1
- package/src/App/Screens/Configurator/Screen.js +4 -2
- package/src/App/Screens/Configurator/__tests__/Screen.test.js +3 -0
- package/src/App/Services/ConfiguratorService.js +25 -4
- package/src/App/Services/InteractionService.js +2 -1
- package/src/App/Services/VisualizationService.js +3 -0
- package/src/App/Services/__tests__/DesignDataService.selectViewForComponent.test.js +0 -53
- package/src/App/Shared/Containers/AlertMessages.js +1 -1
- package/src/App/Shared/Containers/AmountPrice/index.test.js +1 -1
- package/src/App/Shared/Containers/Error.js +1 -1
- package/src/App/Shared/Containers/SaveConfiguration.js +1 -1
- package/src/App/Translations.js +1 -1
- package/src/App/Utils/createMessageInterface.js +10 -0
- package/src/App/configuration.js +3 -0
- package/src/Framework/i18n.js +2 -3
- package/babel.config.js +0 -46
- package/public/ConfigurationMessagingDemo.html +0 -55
- package/scripts/cpPath.js +0 -135
- package/scripts/moveLibToPackageRoot.js +0 -40
- package/scripts/rmDir.js +0 -29
- package/scripts/updateLocalPackages.js +0 -68
- package/scripts/utils/process.js +0 -19
- package/tsconfig.json +0 -22
|
@@ -30,7 +30,7 @@ import {
|
|
|
30
30
|
import { withGlobalLoader } from '../Reducers/UI/Actions';
|
|
31
31
|
import { getFontMapping } from '../Reducers/Fonts/Selectors';
|
|
32
32
|
import { Services } from '../ServiceLocator';
|
|
33
|
-
import { getConf } from '../configuration';
|
|
33
|
+
import { getConf, SaveTypes } from '../configuration';
|
|
34
34
|
import { selectMultipleOptions, setCalculationEnabled } from '../Reducers/Configurator/Actions';
|
|
35
35
|
import { setCalculationAutoResolveEnabled } from '../Reducers/Configurator/Actions';
|
|
36
36
|
import { skipNextAutoResolve } from '../Reducers/Configurator/Actions';
|
|
@@ -38,7 +38,12 @@ import { getDesignData } from '../Reducers/DesignData/Reducer';
|
|
|
38
38
|
import { getCached } from '../../Utils/Function/cached';
|
|
39
39
|
import { getFirstDataURLFromScreenshotsObj } from '../Modules/Visualization/Utils/getFirstDataURLFromScreenshotsObj';
|
|
40
40
|
import { isPlaceholderObject } from '../Reducers/DesignData/Selectors';
|
|
41
|
-
import createMessageInterface
|
|
41
|
+
import createMessageInterface, {
|
|
42
|
+
LISTENER_SAVE_CONFIGURATION,
|
|
43
|
+
LISTENER_SWITCH_OPTIONS,
|
|
44
|
+
METHOD_ADD_TO_CART,
|
|
45
|
+
METHOD_CONFIGURATION_SAVED_REMOTELY,
|
|
46
|
+
} from '../Utils/createMessageInterface';
|
|
42
47
|
|
|
43
48
|
const getSelectedAmountsBySizes = (item, selectedAmounts) => {
|
|
44
49
|
const itemGroupMap = (rootItem, fn) => {
|
|
@@ -83,7 +88,7 @@ export default class ConfiguratorService extends AbstractConfiguratorService {
|
|
|
83
88
|
const adminMode = getConf('adminMode');
|
|
84
89
|
if (!adminMode) {
|
|
85
90
|
const messageInterface = createMessageInterface();
|
|
86
|
-
messageInterface.addListener(
|
|
91
|
+
messageInterface.addListener(LISTENER_SWITCH_OPTIONS, async event => {
|
|
87
92
|
const optionsJSON = get(event, 'data.options');
|
|
88
93
|
try {
|
|
89
94
|
const optionsToSelect = JSON.parse(optionsJSON);
|
|
@@ -93,6 +98,19 @@ export default class ConfiguratorService extends AbstractConfiguratorService {
|
|
|
93
98
|
console.error('Wrong JSON provided for switch_options:', optionsJSON);
|
|
94
99
|
}
|
|
95
100
|
});
|
|
101
|
+
messageInterface.addListener(LISTENER_SAVE_CONFIGURATION, async event => {
|
|
102
|
+
const save_id = get(event, 'data.save_id');
|
|
103
|
+
const saveType =
|
|
104
|
+
get(event, 'data.save_type') === SaveTypes.CART ? SaveTypes.CART : SaveTypes.USER;
|
|
105
|
+
try {
|
|
106
|
+
const configuration = await this.captureAndSaveConfiguration(saveType);
|
|
107
|
+
const code = get(configuration, 'data.code');
|
|
108
|
+
messageInterface.dispatch({ method: METHOD_CONFIGURATION_SAVED_REMOTELY, save_id, code });
|
|
109
|
+
} catch (e) {
|
|
110
|
+
// eslint-disable-next-line no-console
|
|
111
|
+
console.error('Saving configuration failed, save_id was ', save_id);
|
|
112
|
+
}
|
|
113
|
+
});
|
|
96
114
|
}
|
|
97
115
|
}
|
|
98
116
|
|
|
@@ -725,7 +743,10 @@ export default class ConfiguratorService extends AbstractConfiguratorService {
|
|
|
725
743
|
const appConf = getConf();
|
|
726
744
|
const targetOrigin = get(appConf, 'addToCartPostMessageTargetOrigin', '*');
|
|
727
745
|
|
|
728
|
-
window.parent.postMessage(
|
|
746
|
+
window.parent.postMessage(
|
|
747
|
+
{ method: METHOD_ADD_TO_CART, code: configuration.code },
|
|
748
|
+
targetOrigin
|
|
749
|
+
);
|
|
729
750
|
} else if (addToCartMethod === 'functionCall' && window.parent.addToCart !== undefined) {
|
|
730
751
|
window.parent.addToCart(configuration.code);
|
|
731
752
|
}
|
|
@@ -5,6 +5,7 @@ import Api from '../../Framework/Api';
|
|
|
5
5
|
import { t } from 'Framework/i18n';
|
|
6
6
|
import { getConfiguration } from '../Reducers/Configurator/Selectors';
|
|
7
7
|
import { EventTypes } from '../Constant';
|
|
8
|
+
import { METHOD_CONFIGURATION_SAVED } from '../Utils/createMessageInterface';
|
|
8
9
|
|
|
9
10
|
export default class InteractionService extends AbstractInteractionService {
|
|
10
11
|
constructor() {
|
|
@@ -44,7 +45,7 @@ export default class InteractionService extends AbstractInteractionService {
|
|
|
44
45
|
await configurator.captureAndSaveConfiguration(SaveTypes.USER);
|
|
45
46
|
const { code } = configurator.state.configuration;
|
|
46
47
|
this.postMessageToContainer({
|
|
47
|
-
method:
|
|
48
|
+
method: METHOD_CONFIGURATION_SAVED,
|
|
48
49
|
code,
|
|
49
50
|
});
|
|
50
51
|
} catch (e) {
|
|
@@ -264,6 +264,9 @@ export default class VisualizationService extends AbstractVisualizationService {
|
|
|
264
264
|
const isAdminMode = getConf('adminMode');
|
|
265
265
|
sendMessage(component, 'clearViewIfEmpty', !!isAdminMode);
|
|
266
266
|
|
|
267
|
+
const visualizationOverlayMode = getConf('visualizationOverlayMode');
|
|
268
|
+
sendMessage(component, 'setOverlayMode', !!visualizationOverlayMode);
|
|
269
|
+
|
|
267
270
|
this.observable.dispatch(EventTypes.ComponentChange, { component });
|
|
268
271
|
|
|
269
272
|
return this;
|
|
@@ -178,57 +178,4 @@ describe('DesignDataService.selectViewForComponent', () => {
|
|
|
178
178
|
|
|
179
179
|
expect(srv.selectDesignView).toHaveBeenCalledWith('front_view', { saveLast: false });
|
|
180
180
|
});
|
|
181
|
-
|
|
182
|
-
it('calls selectDesignView with the identifier of lastSelectedDesignView if no creatorView is referenced by the selected component', () => {
|
|
183
|
-
const componentWithNoCreatorView = {
|
|
184
|
-
identifier: 'id1',
|
|
185
|
-
title: 'title1',
|
|
186
|
-
creatorView: null,
|
|
187
|
-
};
|
|
188
|
-
|
|
189
|
-
ServiceLocator.provide(
|
|
190
|
-
new (class StoreService {
|
|
191
|
-
static serviceName = 'StoreService';
|
|
192
|
-
state = {
|
|
193
|
-
designArea: {
|
|
194
|
-
filteredDesignAreas: mockDesignAreas,
|
|
195
|
-
selectedDesignArea: {},
|
|
196
|
-
},
|
|
197
|
-
designView: {
|
|
198
|
-
designViews: [
|
|
199
|
-
{ identifier: 'front_view' },
|
|
200
|
-
{ identifier: 'side_view' },
|
|
201
|
-
{ identifier: 'top_view' },
|
|
202
|
-
],
|
|
203
|
-
selectedDesignView: {
|
|
204
|
-
identifier: 'side_view',
|
|
205
|
-
},
|
|
206
|
-
lastSelectedDesignView: {
|
|
207
|
-
identifier: 'top_view',
|
|
208
|
-
},
|
|
209
|
-
},
|
|
210
|
-
configurator: {
|
|
211
|
-
configuration: {
|
|
212
|
-
optionclassifications: [
|
|
213
|
-
componentWithNoCreatorView,
|
|
214
|
-
{
|
|
215
|
-
identifier: 'id2',
|
|
216
|
-
title: 'title2',
|
|
217
|
-
creatorView: { identifier: 'side_view' },
|
|
218
|
-
},
|
|
219
|
-
],
|
|
220
|
-
},
|
|
221
|
-
},
|
|
222
|
-
};
|
|
223
|
-
dispatch = v => v;
|
|
224
|
-
})()
|
|
225
|
-
);
|
|
226
|
-
const srv = new DesignDataService();
|
|
227
|
-
|
|
228
|
-
srv.selectDesignView = jest.fn();
|
|
229
|
-
|
|
230
|
-
srv.selectViewForComponent(componentWithNoCreatorView);
|
|
231
|
-
|
|
232
|
-
expect(srv.selectDesignView).toHaveBeenCalledWith('top_view', { saveLast: false });
|
|
233
|
-
});
|
|
234
181
|
});
|
|
@@ -2,7 +2,7 @@ import AmountPrice, {
|
|
|
2
2
|
createAmountPropsFromState,
|
|
3
3
|
createPricePropsFromState,
|
|
4
4
|
showProductVariantsForItem,
|
|
5
|
-
} from '
|
|
5
|
+
} from './index';
|
|
6
6
|
import mountWithState from 'Utils/Test/mountWithState';
|
|
7
7
|
import ServiceLocator from 'App/ServiceLocator';
|
|
8
8
|
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import CircularProgress from '@material-ui/core/CircularProgress/CircularProgress';
|
|
2
2
|
import containerConnect from 'Framework/ComponentContainer';
|
|
3
3
|
import { Services } from 'App/ServiceLocator';
|
|
4
|
-
import SaveConfiguration from '../Components/SaveConfiguration
|
|
4
|
+
import SaveConfiguration from '../Components/SaveConfiguration';
|
|
5
5
|
import { getShareUrl } from '../../Reducers/Configurator/Selectors';
|
|
6
6
|
|
|
7
7
|
const mapStateToProps = ({ ui, configurator }) => ({
|
package/src/App/Translations.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { use } from 'Framework/i18n';
|
|
2
|
-
import { isProduction } from '
|
|
2
|
+
import { isProduction } from './configuration';
|
|
3
3
|
export async function initLanguage(lang) {
|
|
4
4
|
// ensure that the filename always has an underscore and no dash
|
|
5
5
|
const fileKey = lang.replace('-', '_');
|
|
@@ -1,5 +1,15 @@
|
|
|
1
1
|
import get from 'lodash/get';
|
|
2
2
|
|
|
3
|
+
export const METHOD_ADD_TO_CART = 'addtocart';
|
|
4
|
+
|
|
5
|
+
export const METHOD_CONFIGURATION_SAVED = 'configurationsaved';
|
|
6
|
+
|
|
7
|
+
export const METHOD_CONFIGURATION_SAVED_REMOTELY = 'configurationsaved_remotely';
|
|
8
|
+
|
|
9
|
+
export const LISTENER_SWITCH_OPTIONS = 'switch_options';
|
|
10
|
+
|
|
11
|
+
export const LISTENER_SAVE_CONFIGURATION = 'save_configuration';
|
|
12
|
+
|
|
3
13
|
/**
|
|
4
14
|
* Helper interface for bi-directional postMessage API
|
|
5
15
|
*/
|
package/src/App/configuration.js
CHANGED
|
@@ -197,6 +197,9 @@ let applicationConfiguration = {
|
|
|
197
197
|
|
|
198
198
|
// switch to the previously selected view when selecting a component that has no view specified
|
|
199
199
|
switchViewOnComponentSelection: true,
|
|
200
|
+
|
|
201
|
+
// the visualization behaves like it was a mask over the designer canvas
|
|
202
|
+
visualizationOverlayMode: false,
|
|
200
203
|
};
|
|
201
204
|
|
|
202
205
|
/**
|
package/src/Framework/i18n.js
CHANGED
|
@@ -3,7 +3,6 @@ import React, { Component } from 'react';
|
|
|
3
3
|
import ReactDOMServer from 'react-dom/server';
|
|
4
4
|
import { connect } from 'react-redux';
|
|
5
5
|
import _ from 'lodash';
|
|
6
|
-
import * as reactI18nify from 'react-i18nify';
|
|
7
6
|
import Hyphen from 'react-hyphen';
|
|
8
7
|
import { getConf } from '../App/configuration';
|
|
9
8
|
|
|
@@ -231,10 +230,10 @@ export function translateComponent(ComponentToTranslate, mapStateToProps, mapDis
|
|
|
231
230
|
export const t = I18n.t.bind(I18n);
|
|
232
231
|
|
|
233
232
|
export function useTranslationWithoutStore() {
|
|
234
|
-
|
|
233
|
+
I18n.setTranslationsGetter(function() {
|
|
235
234
|
return translations;
|
|
236
235
|
});
|
|
237
|
-
|
|
236
|
+
I18n.setLocaleGetter(function() {
|
|
238
237
|
return 'en-GB';
|
|
239
238
|
});
|
|
240
239
|
}
|
package/babel.config.js
DELETED
|
@@ -1,46 +0,0 @@
|
|
|
1
|
-
module.exports = function(api) {
|
|
2
|
-
const presets = [
|
|
3
|
-
'@babel/preset-env',
|
|
4
|
-
'@babel/preset-typescript',
|
|
5
|
-
'@babel/preset-react', // Transpile React components to JavaScript
|
|
6
|
-
];
|
|
7
|
-
|
|
8
|
-
const plugins = [
|
|
9
|
-
['@babel/plugin-proposal-decorators', { decoratorsBeforeExport: true }],
|
|
10
|
-
'@babel/plugin-proposal-class-properties',
|
|
11
|
-
'@babel/plugin-syntax-dynamic-import',
|
|
12
|
-
|
|
13
|
-
[
|
|
14
|
-
require.resolve('babel-plugin-module-resolver'),
|
|
15
|
-
{
|
|
16
|
-
root: ['./src'],
|
|
17
|
-
},
|
|
18
|
-
],
|
|
19
|
-
];
|
|
20
|
-
|
|
21
|
-
const ignore = [];
|
|
22
|
-
|
|
23
|
-
if (api.env('development')) {
|
|
24
|
-
plugins.push('react-hot-loader/babel'); // Enables React code to work with HMR.
|
|
25
|
-
api.cache(true);
|
|
26
|
-
} else if (api.env('production')) {
|
|
27
|
-
ignore.push(
|
|
28
|
-
'**/__tests__', // ignore the whole test directory
|
|
29
|
-
'**/*.test.js', // ignore test files only
|
|
30
|
-
'**/__mocks__'
|
|
31
|
-
);
|
|
32
|
-
api.cache(false);
|
|
33
|
-
} else if (api.env('test')) {
|
|
34
|
-
// makes possible to import ES modules (by transforming them to CommonJS)
|
|
35
|
-
// in node's current LTS version (12.x) ES modules are only experimental,
|
|
36
|
-
// for the current status check https://nodejs.org/docs/latest/api/esm.html#esm_modules_ecmascript_modules
|
|
37
|
-
plugins.push(['@babel/plugin-transform-modules-commonjs', { allowTopLevelThis: true }]);
|
|
38
|
-
api.cache(true);
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
return {
|
|
42
|
-
presets,
|
|
43
|
-
plugins,
|
|
44
|
-
ignore,
|
|
45
|
-
};
|
|
46
|
-
};
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
<!DOCTYPE html>
|
|
2
|
-
<html lang="en">
|
|
3
|
-
<head>
|
|
4
|
-
<style>
|
|
5
|
-
html, body {
|
|
6
|
-
margin: 0;
|
|
7
|
-
display: flex;
|
|
8
|
-
}
|
|
9
|
-
</style>
|
|
10
|
-
<meta charset="UTF-8">
|
|
11
|
-
<title>Test for configurator messaging</title>
|
|
12
|
-
</head>
|
|
13
|
-
<body>
|
|
14
|
-
<script>
|
|
15
|
-
window.addEventListener('message', (event) => {
|
|
16
|
-
const data = event.data;
|
|
17
|
-
console.log('message posted from the embedded page', data);
|
|
18
|
-
|
|
19
|
-
const method = data.method;
|
|
20
|
-
const code = data.code;
|
|
21
|
-
|
|
22
|
-
switch (method) {
|
|
23
|
-
case 'configurationsaved': {
|
|
24
|
-
console.log('the user clicked the save button in the top right corner, and received the following code: ' + code);
|
|
25
|
-
// do other actions here
|
|
26
|
-
break;
|
|
27
|
-
}
|
|
28
|
-
case 'addtocart': {
|
|
29
|
-
console.log('the user clicked the "add to cart" button in the bottom right corner, and received the following code: ' + code);
|
|
30
|
-
// do other actions here
|
|
31
|
-
break;
|
|
32
|
-
}
|
|
33
|
-
default: {
|
|
34
|
-
console.log('unhandled or unknown method: ' + method);
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
function onButtonClicked() {
|
|
40
|
-
const options = document.getElementById('input_switch_options').value;
|
|
41
|
-
if (options) {
|
|
42
|
-
document.getElementById('configurator_page').contentWindow.postMessage({type: 'switch_options', options });
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
</script>
|
|
46
|
-
<iframe src="/identifier:softshell_creatordesigner_2d" id="configurator_page" style="width: 80vw; height: 100vh; border: 0;"></iframe>
|
|
47
|
-
<div style="width: 20vw; height: 100vh;">
|
|
48
|
-
|
|
49
|
-
<textarea type="text" style="width: 17vw; height: 40vw; margin: 1vw" id="input_switch_options">
|
|
50
|
-
[{"identifier":"softshell_body","selectedoptions":[{"identifier":"softshell_navy","amount":1}]},{"identifier":"softshell_hood","selectedoptions":[{"identifier":"softshell_lime"}]}]
|
|
51
|
-
</textarea>
|
|
52
|
-
<button style="margin-left: 6vw" onclick="onButtonClicked()">Switch Options</button>
|
|
53
|
-
</div>
|
|
54
|
-
</body>
|
|
55
|
-
</html>
|
package/scripts/cpPath.js
DELETED
|
@@ -1,135 +0,0 @@
|
|
|
1
|
-
/* eslint no-console: 0 */
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* This script is made to copy specific files with their folder structure
|
|
5
|
-
*
|
|
6
|
-
* usage: node ./scripts/cpPath.js src dst [filterRegExp]
|
|
7
|
-
*
|
|
8
|
-
* @author boda@redhotmagma.de
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
const fs = require('fs');
|
|
12
|
-
const path = require('path');
|
|
13
|
-
|
|
14
|
-
const { mkDirDeep, walkDir } = require('./utils/fileSystem');
|
|
15
|
-
|
|
16
|
-
let src = null;
|
|
17
|
-
let dst = null;
|
|
18
|
-
let reg = null;
|
|
19
|
-
|
|
20
|
-
process.argv.forEach(function(val, index) {
|
|
21
|
-
switch (index) {
|
|
22
|
-
case 2:
|
|
23
|
-
src = val;
|
|
24
|
-
break;
|
|
25
|
-
case 3:
|
|
26
|
-
dst = val;
|
|
27
|
-
break;
|
|
28
|
-
case 4:
|
|
29
|
-
reg = new RegExp(val);
|
|
30
|
-
}
|
|
31
|
-
});
|
|
32
|
-
|
|
33
|
-
if (!src || !fs.existsSync(src)) {
|
|
34
|
-
throw new Error('src must be an existing directory');
|
|
35
|
-
}
|
|
36
|
-
if (!dst || !fs.existsSync(dst)) {
|
|
37
|
-
throw new Error('dst must be an existing directory');
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
function copyWithParent(src, dst) {
|
|
41
|
-
if (typeof dst === 'function') {
|
|
42
|
-
dst = dst(src);
|
|
43
|
-
}
|
|
44
|
-
mkDirDeep(dst.replace(/[/\\][^/\\]+$/, ''));
|
|
45
|
-
console.log(src + ' -> ' + dst);
|
|
46
|
-
const fileExt = src.replace(/.+\.([\w]+)$/, '$1');
|
|
47
|
-
switch (fileExt) {
|
|
48
|
-
case 'scss':
|
|
49
|
-
fs.readFile(src, 'utf8', function read(err, data) {
|
|
50
|
-
if (err) {
|
|
51
|
-
throw err;
|
|
52
|
-
}
|
|
53
|
-
const modifiedContent = prepareSassFile(src, data);
|
|
54
|
-
fs.writeFile(dst, modifiedContent, 'utf8', function write(err) {
|
|
55
|
-
if (err) {
|
|
56
|
-
throw err;
|
|
57
|
-
}
|
|
58
|
-
});
|
|
59
|
-
});
|
|
60
|
-
break;
|
|
61
|
-
default:
|
|
62
|
-
fs.createReadStream(src).pipe(fs.createWriteStream(dst));
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
function prepareSassFile(relativeSrc, content) {
|
|
67
|
-
const src = path.resolve(relativeSrc).replace(/\\/g, '/');
|
|
68
|
-
if (!content || !content.match) {
|
|
69
|
-
console.log('Strange file: ' + src);
|
|
70
|
-
return content;
|
|
71
|
-
}
|
|
72
|
-
const replaceImports = content.match(/@import ['"][^.~].+/g);
|
|
73
|
-
let output = content;
|
|
74
|
-
if (replaceImports) {
|
|
75
|
-
console.log('Resolving imports in sass file: ' + src);
|
|
76
|
-
const pathUp =
|
|
77
|
-
'..' +
|
|
78
|
-
src
|
|
79
|
-
.match(/src\/.+/)[0]
|
|
80
|
-
.match(/\//g)
|
|
81
|
-
.splice(1)
|
|
82
|
-
.join('..');
|
|
83
|
-
for (let i in replaceImports) {
|
|
84
|
-
const pathToImport = replaceImports[i].replace(/@import ['"][/]?([^'"]+).*/, '$1');
|
|
85
|
-
const resolverPath = pathUp + pathToImport;
|
|
86
|
-
|
|
87
|
-
const srcPathDir = src.replace(/\/[^/]+$/, '/');
|
|
88
|
-
const relativeImportPath = srcPathDir + pathToImport;
|
|
89
|
-
const rootImportPath = srcPathDir + resolverPath;
|
|
90
|
-
|
|
91
|
-
let resolveRootImport = false;
|
|
92
|
-
try {
|
|
93
|
-
fs.accessSync(relativeImportPath);
|
|
94
|
-
} catch (err) {
|
|
95
|
-
try {
|
|
96
|
-
fs.accessSync(relativeImportPath + '.scss');
|
|
97
|
-
} catch (err) {
|
|
98
|
-
try {
|
|
99
|
-
fs.accessSync(rootImportPath);
|
|
100
|
-
resolveRootImport = true;
|
|
101
|
-
} catch (err) {
|
|
102
|
-
try {
|
|
103
|
-
fs.accessSync(rootImportPath + '.scss');
|
|
104
|
-
resolveRootImport = true;
|
|
105
|
-
} catch (err) {
|
|
106
|
-
throw 'Cannot resolve import path: ' + replaceImports[i] + ' in ' + src;
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
if (resolveRootImport) {
|
|
112
|
-
console.log(' ' + pathToImport + ' -> ' + resolverPath);
|
|
113
|
-
const resolvedImport = replaceImports[i].replace(
|
|
114
|
-
/(@import ['"])[^'"]+(.*)/,
|
|
115
|
-
'$1' + resolverPath + '$2'
|
|
116
|
-
);
|
|
117
|
-
output = output.replace(replaceImports[i], resolvedImport);
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
return output;
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
console.log(
|
|
125
|
-
'\x1b[37m\x1b[42m%s\x1b[0m',
|
|
126
|
-
'Copying files from ' + src + ' to ' + dst + (reg ? ' with filter: ' + reg : ' without filter')
|
|
127
|
-
);
|
|
128
|
-
|
|
129
|
-
walkDir(src, function(f) {
|
|
130
|
-
if (reg === null || (reg && reg.test(f))) {
|
|
131
|
-
copyWithParent(f, function(path) {
|
|
132
|
-
return dst + path.replace(src, '');
|
|
133
|
-
});
|
|
134
|
-
}
|
|
135
|
-
});
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
/* eslint no-console: 0 */
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* This script is made to copy the compiled source from lib to the root folder
|
|
5
|
-
*
|
|
6
|
-
* Runs only when installing this package as a dependency in client projects
|
|
7
|
-
*
|
|
8
|
-
* usage: node ./scripts/moveLibToPackageRoot.js
|
|
9
|
-
*
|
|
10
|
-
* @author boda@redhotmagma.de
|
|
11
|
-
*/
|
|
12
|
-
|
|
13
|
-
const fs = require('fs');
|
|
14
|
-
const path = require('path');
|
|
15
|
-
const rimraf = require('rimraf');
|
|
16
|
-
|
|
17
|
-
const { isDependency } = require('./utils/process');
|
|
18
|
-
const { walkDir } = require('./utils/fileSystem');
|
|
19
|
-
|
|
20
|
-
if (isDependency()) {
|
|
21
|
-
console.log('\x1b[37m\x1b[42m%s\x1b[0m', 'Moving content of lib into the root package directory');
|
|
22
|
-
|
|
23
|
-
const src = path.resolve('./lib');
|
|
24
|
-
const dst = path.resolve('./');
|
|
25
|
-
walkDir(src, function(file) {
|
|
26
|
-
const relativePath = file.replace(src, '');
|
|
27
|
-
const tp = path.resolve(dst + relativePath);
|
|
28
|
-
if (fs.statSync(file).isFile()) {
|
|
29
|
-
fs.createReadStream(file).pipe(fs.createWriteStream(tp));
|
|
30
|
-
} else {
|
|
31
|
-
fs.mkdirSync(tp);
|
|
32
|
-
}
|
|
33
|
-
});
|
|
34
|
-
|
|
35
|
-
rimraf(src, function(err) {
|
|
36
|
-
if (err) {
|
|
37
|
-
console.log('Error occured while clearing the directory: ' + src, err);
|
|
38
|
-
}
|
|
39
|
-
});
|
|
40
|
-
}
|
package/scripts/rmDir.js
DELETED
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
/* eslint no-console: 0 */
|
|
2
|
-
|
|
3
|
-
const fs = require('fs');
|
|
4
|
-
|
|
5
|
-
let dir = process.argv[2];
|
|
6
|
-
|
|
7
|
-
if (!dir) {
|
|
8
|
-
throw new Error('src must be an existing directory');
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
function rmDir(dirPath) {
|
|
12
|
-
try {
|
|
13
|
-
const files = fs.readdirSync(dirPath);
|
|
14
|
-
if (files.length > 0) {
|
|
15
|
-
for (let f of files) {
|
|
16
|
-
const filePath = dirPath + '/' + f;
|
|
17
|
-
if (fs.statSync(filePath).isFile()) fs.unlinkSync(filePath);
|
|
18
|
-
else rmDir(filePath);
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
fs.rmdirSync(dirPath);
|
|
22
|
-
} catch (e) {
|
|
23
|
-
return;
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
console.log('\x1b[32m%s\x1b[0m', 'Removing dir: ' + dir);
|
|
28
|
-
|
|
29
|
-
rmDir(dir);
|
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
/* eslint no-console: 0 */
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* A tool to copy local modifications of local packages (graphics editor and visualization component)
|
|
5
|
-
* over to the node_modules of this project in order to test them in the integrated environment.
|
|
6
|
-
* This script is made only for development purposes, does not replace the package version update in package.json.
|
|
7
|
-
*
|
|
8
|
-
* It uses the configuration file localPackages.json (should be placed in the project root)
|
|
9
|
-
* Example for localPackages.json:
|
|
10
|
-
* {
|
|
11
|
-
* "visualization": { // alias of the package
|
|
12
|
-
* "path": "../visualization_component", // location in the local file system, relative to the project path
|
|
13
|
-
* "name": "redhotmagma-visualization" // name of the package in package.json
|
|
14
|
-
* },
|
|
15
|
-
* ...
|
|
16
|
-
* }
|
|
17
|
-
* Usage of the script:
|
|
18
|
-
* node .\scripts\updateLocalPackages.js // update all local dependencies listed in localPackages.json
|
|
19
|
-
* node .\scripts\updateLocalPackages.js visualization // update only a single package identified by its alias
|
|
20
|
-
*
|
|
21
|
-
* @author boda@redhotmagma.de (2019.09.24)
|
|
22
|
-
*/
|
|
23
|
-
|
|
24
|
-
const { resolve } = require('path');
|
|
25
|
-
const { cpDirDeep } = require('./utils/fileSystem');
|
|
26
|
-
|
|
27
|
-
const _alias = process.argv[2];
|
|
28
|
-
|
|
29
|
-
try {
|
|
30
|
-
let items = require('../localPackages.json');
|
|
31
|
-
if (_alias && _alias.length) {
|
|
32
|
-
const selectedItem = items[_alias];
|
|
33
|
-
if (!selectedItem) {
|
|
34
|
-
console.log('Package not found:', _alias);
|
|
35
|
-
console.log('Available packages:');
|
|
36
|
-
console.table(items);
|
|
37
|
-
process.exit(0);
|
|
38
|
-
} else {
|
|
39
|
-
items = { [_alias]: selectedItem };
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
// eslint-disable-next-line no-unused-vars
|
|
43
|
-
for (let [alias, { path, name }] of Object.entries(items)) {
|
|
44
|
-
console.log(`Updating package: ${name} -> ${path}`);
|
|
45
|
-
updatePackage({ name, path });
|
|
46
|
-
}
|
|
47
|
-
} catch (e) {
|
|
48
|
-
console.error(e);
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
function updatePackage(options = {}) {
|
|
52
|
-
const { name, path, buildScript = 'npm run package', libDir = 'lib' } = options;
|
|
53
|
-
const cwd = process.cwd();
|
|
54
|
-
const projectPath = resolve(cwd, path);
|
|
55
|
-
const packagePath = resolve(cwd, 'node_modules', name);
|
|
56
|
-
try {
|
|
57
|
-
const { exec } = require('child_process');
|
|
58
|
-
const childProcess = exec(buildScript, { cwd: projectPath });
|
|
59
|
-
childProcess.stdout.pipe(process.stdout);
|
|
60
|
-
childProcess.stderr.pipe(process.stderr);
|
|
61
|
-
childProcess.on('close', code => {
|
|
62
|
-
console.log(`child process exited with code ${code}`);
|
|
63
|
-
cpDirDeep(resolve(projectPath, libDir), packagePath);
|
|
64
|
-
});
|
|
65
|
-
} catch (e) {
|
|
66
|
-
console.error(e);
|
|
67
|
-
}
|
|
68
|
-
}
|
package/scripts/utils/process.js
DELETED
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* These utils are made to simplify querying process information for the node scripts.
|
|
3
|
-
*
|
|
4
|
-
* @author boda@redhotmagma.de
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* Checks if the current installation process is a dependency installation
|
|
9
|
-
* @return {boolean}
|
|
10
|
-
*/
|
|
11
|
-
function isDependency() {
|
|
12
|
-
// if the path of the initial directory contains 'node_modules', it's probably installed as a dependency
|
|
13
|
-
const { INIT_CWD } = process.env;
|
|
14
|
-
return INIT_CWD.indexOf('node_modules') !== -1;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
module.exports = {
|
|
18
|
-
isDependency,
|
|
19
|
-
};
|
package/tsconfig.json
DELETED
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"compilerOptions": {
|
|
3
|
-
// Target latest version of ECMAScript.
|
|
4
|
-
"target": "esnext",
|
|
5
|
-
// Search under node_modules for non-relative imports.
|
|
6
|
-
"moduleResolution": "node",
|
|
7
|
-
// Process & infer types from .js files.
|
|
8
|
-
"allowJs": true,
|
|
9
|
-
// Don't emit; allow Babel to transform files.
|
|
10
|
-
"noEmit": true,
|
|
11
|
-
// Enable strictest settings like strictNullChecks & noImplicitAny.
|
|
12
|
-
"strict": true,
|
|
13
|
-
// Disallow features that require cross-file information for emit.
|
|
14
|
-
"isolatedModules": true,
|
|
15
|
-
// Import non-ES modules as default imports.
|
|
16
|
-
"esModuleInterop": true
|
|
17
|
-
},
|
|
18
|
-
"include": [
|
|
19
|
-
"./src",
|
|
20
|
-
"./node_modules/redhotmagma-graphics-editor"
|
|
21
|
-
]
|
|
22
|
-
}
|