@roomle/embedding-lib 5.34.0-alpha.1 → 5.34.0-alpha.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/docs/md/web/embedding/CHANGELOG.md +38 -6
- package/index.d.ts +0 -1
- package/package.json +1 -1
- package/packages/common/src/utils/configurations.d.ts +1 -1
- package/packages/common/src/utils/domain.d.ts +17 -0
- package/packages/common/src/utils/id-inferrer.d.ts +1 -1
- package/packages/common/src/utils/init-data.d.ts +3 -2
- package/packages/common/src/utils/noop.d.ts +1 -0
- package/packages/embedding-lib/src/connector.d.ts +1 -0
- package/packages/embedding-lib/src/embedding-lib.d.ts +2 -95
- package/packages/embedding-lib/src/examples/utils/drag-listeners.d.ts +1 -3
- package/packages/embedding-lib/src/examples/utils/homag-intelligence/create-catalog.d.ts +1 -0
- package/packages/embedding-lib/src/examples/utils/homag-intelligence/default-api-options.d.ts +2 -2
- package/packages/embedding-lib/src/examples/utils/homag-intelligence/nobilia-api-options.d.ts +2 -6
- package/packages/embedding-lib/src/examples/utils/homag-intelligence/state.d.ts +5 -5
- package/packages/embedding-lib/src/examples/utils/homag-intelligence/{util.d.ts → utils.d.ts} +0 -7
- package/packages/embedding-lib/src/homag-intelligence/hi-callbacks.d.ts +4 -0
- package/packages/embedding-lib/src/homag-intelligence/hi-requests.d.ts +8 -0
- package/packages/embedding-lib/src/plugins/drag-in.d.ts +1 -1
- package/packages/embedding-lib/src/plugins/strategy/from-custom-view.d.ts +1 -2
- package/packages/embedding-lib/src/plugins/strategy/from-website.d.ts +1 -2
- package/packages/embedding-lib/src/plugins/strategy/types.d.ts +1 -1
- package/packages/embedding-lib/src/types.d.ts +92 -0
- package/packages/web-sdk/packages/common-core/mock/mock-utils.d.ts +2 -2
- package/packages/web-sdk/packages/common-core/src/cameracontrol/camera-control-3d.d.ts +2 -1
- package/packages/web-sdk/packages/common-core/src/configurator-kernel-access.d.ts +3 -4
- package/packages/web-sdk/packages/common-core/src/main.d.ts +3 -3
- package/packages/web-sdk/packages/common-core/src/rapi-access.d.ts +2 -2
- package/packages/web-sdk/packages/common-core/src/roomle-sdk.d.ts +2 -2
- package/packages/web-sdk/packages/common-core/src/services/cache-holder.d.ts +1 -2
- package/packages/web-sdk/packages/common-core/src/services/common-kernel-access.d.ts +2 -2
- package/packages/web-sdk/packages/common-core/src/services/hdr-environment-loader.d.ts +1 -1
- package/packages/web-sdk/packages/common-core/src/services/idb-manager.d.ts +1 -1
- package/packages/web-sdk/packages/common-core/src/utils/browser-helper.d.ts +1 -1
- package/packages/web-sdk/packages/common-core/src/utils/common-utils.d.ts +3 -3
- package/packages/web-sdk/packages/common-core/src/utils/external-objects.d.ts +1 -1
- package/packages/web-sdk/packages/common-core/src/utils/init-data.d.ts +1 -1
- package/packages/web-sdk/packages/common-core/src/utils/shims.d.ts +1 -4
- package/packages/web-sdk/packages/common-core/src/utils/threejs-utils.d.ts +2 -2
- package/packages/web-sdk/packages/common-core/src/view-model/configurator-plan-object-view-model.d.ts +2 -1
- package/packages/web-sdk/packages/common-core/src/view-model/configurator-view-model.d.ts +4 -4
- package/packages/web-sdk/packages/common-core/src/view-model/plan-element-view-model.d.ts +1 -1
- package/packages/web-sdk/packages/common-core/src/view-model/plan-object-view-model.d.ts +2 -2
- package/packages/web-sdk/packages/common-core/src/webgl/mesh-generator.d.ts +1 -1
- package/packages/web-sdk/packages/common-core/src/webgl/renderer/environment-definition.d.ts +1 -1
- package/packages/web-sdk/packages/common-core/src/webgl/renderer/light-source-detection.d.ts +1 -1
- package/packages/web-sdk/packages/common-core/src/webgl/renderer/outline-renderer.d.ts +1 -1
- package/packages/web-sdk/packages/common-core/src/webgl/renderer/pass/baked-ground-contact-shadow-pass.d.ts +1 -1
- package/packages/web-sdk/packages/common-core/src/webgl/renderer/pass/gbuffer-render-pass.d.ts +1 -1
- package/packages/web-sdk/packages/common-core/src/webgl/renderer/pass/ground-reflection-pass.d.ts +1 -1
- package/packages/web-sdk/packages/common-core/src/webgl/renderer/pass/outline-pass.d.ts +1 -1
- package/packages/web-sdk/packages/common-core/src/webgl/renderer/pass/render-pass.d.ts +2 -2
- package/packages/web-sdk/packages/common-core/src/webgl/renderer/pass/scene-render-pass.d.ts +1 -1
- package/packages/web-sdk/packages/common-core/src/webgl/renderer/pass/screen-space-shadow-map-pass.d.ts +1 -1
- package/packages/web-sdk/packages/common-core/src/webgl/renderer/pass/shadow-and-ao-pass.d.ts +1 -1
- package/packages/web-sdk/packages/common-core/src/webgl/renderer/render-pass-manager.d.ts +1 -1
- package/packages/web-sdk/packages/common-core/src/webgl/renderer/render-utility.d.ts +1 -1
- package/packages/web-sdk/packages/common-core/src/webgl/renderer/scene-renderer.d.ts +1 -1
- package/packages/web-sdk/packages/common-core/src/webgl/renderer/shader-utility.d.ts +5 -5
- package/packages/web-sdk/packages/common-core/src/webgl/renderer/shaders/ao-shader.d.ts +5 -5
- package/packages/web-sdk/packages/common-core/src/webgl/renderer/shaders/poisson-denoise-shader.d.ts +4 -4
- package/packages/web-sdk/packages/common-core/src/webgl/roomle-webgl-renderer.d.ts +1 -1
- package/packages/web-sdk/packages/common-core/src/webgl/scene-manager.d.ts +161 -0
- package/packages/web-sdk/packages/configurator-core/src/configurator-main.d.ts +2 -1
- package/packages/web-sdk/packages/configurator-core/src/configurator.d.ts +2 -2
- package/packages/web-sdk/packages/configurator-core/src/roomle-configurator.d.ts +5 -5
- package/packages/web-sdk/packages/configurator-core/src/services/configurator-ui-callback.d.ts +1 -1
- package/packages/web-sdk/packages/configurator-core/src/utils/global-definitions.d.ts +1 -1
- package/packages/web-sdk/packages/configurator-core/src/utils/raycast-helper.d.ts +4 -1
- package/packages/web-sdk/packages/configurator-core/src/webgl/configurator-scene-manager.d.ts +4 -4
- package/packages/web-sdk/packages/glb-viewer-core/src/glb-viewer-main.d.ts +1 -1
- package/packages/web-sdk/packages/glb-viewer-core/src/glb-viewer.d.ts +2 -2
- package/packages/web-sdk/packages/glb-viewer-core/src/roomle-glb-viewer.d.ts +3 -3
- package/packages/web-sdk/packages/glb-viewer-core/src/utils/global-definitions.d.ts +1 -1
- package/packages/web-sdk/packages/homag-intelligence/src/api.d.ts +1 -1
- package/packages/web-sdk/packages/homag-intelligence/src/callbacks.d.ts +1 -1
- package/packages/web-sdk/packages/homag-intelligence/src/debug-logging.d.ts +1 -1
- package/packages/web-sdk/packages/homag-intelligence/src/external-object-api.d.ts +1 -1
- package/packages/web-sdk/packages/homag-intelligence/src/glue-logic.d.ts +1 -1
- package/packages/web-sdk/packages/homag-intelligence/src/{loader.d.ts → hi-api-types.d.ts} +7 -9
- package/packages/web-sdk/packages/homag-intelligence/src/hi-object-selection.d.ts +2 -2
- package/packages/web-sdk/packages/homag-intelligence/src/hi-tag-catalog-callbacks.d.ts +0 -1
- package/packages/web-sdk/packages/homag-intelligence/src/homag-intelligence.d.ts +3 -3
- package/packages/web-sdk/packages/homag-intelligence/src/orders.d.ts +1 -1
- package/packages/web-sdk/packages/index.d.ts +36 -0
- package/packages/web-sdk/packages/material-viewer/src/material-viewer-main.d.ts +2 -1
- package/packages/web-sdk/packages/material-viewer/src/material-viewer.d.ts +1 -1
- package/packages/web-sdk/packages/material-viewer/src/roomle-material-viewer.d.ts +2 -2
- package/packages/web-sdk/packages/planner-core/mock/planner-mock-helper.d.ts +6 -6
- package/packages/web-sdk/packages/planner-core/src/lights/lamp-light.d.ts +1 -1
- package/packages/web-sdk/packages/planner-core/src/lights/point-lamp-light.d.ts +1 -1
- package/packages/web-sdk/packages/planner-core/src/lights/rect-area-light.d.ts +1 -1
- package/packages/web-sdk/packages/planner-core/src/planner-main.d.ts +2 -1
- package/packages/web-sdk/packages/planner-core/src/planner.d.ts +2 -2
- package/packages/web-sdk/packages/planner-core/src/roomle-planner-ui-callback.d.ts +2 -2
- package/packages/web-sdk/packages/planner-core/src/roomle-planner.d.ts +9 -9
- package/packages/web-sdk/packages/planner-core/src/services/planner-kernel-access.d.ts +4 -5
- package/packages/web-sdk/packages/planner-core/src/utils/dimensions-helper.d.ts +1 -1
- package/packages/web-sdk/packages/planner-core/src/utils/global-definitions.d.ts +3 -3
- package/packages/web-sdk/packages/planner-core/src/utils/map-to-ui-plan-objects.d.ts +1 -1
- package/packages/web-sdk/packages/planner-core/src/utils/planner-scene-utils.d.ts +4 -4
- package/packages/web-sdk/packages/planner-core/src/utils/planner-selection-handler.d.ts +4 -2
- package/packages/web-sdk/packages/planner-core/src/view-model/ceiling-plan-element-view-model.d.ts +1 -1
- package/packages/web-sdk/packages/planner-core/src/view-model/construction-plan-object-view-model.d.ts +1 -1
- package/packages/web-sdk/packages/planner-core/src/view-model/floor-plan-element-view-model.d.ts +2 -2
- package/packages/web-sdk/packages/planner-core/src/view-model/measurement-line-plan-element-view-model.d.ts +2 -2
- package/packages/web-sdk/packages/planner-core/src/view-model/node-plan-element-view-model.d.ts +1 -1
- package/packages/web-sdk/packages/planner-core/src/view-model/plan-view-model.d.ts +5 -5
- package/packages/web-sdk/packages/planner-core/src/view-model/static-plan-object-view-model.d.ts +2 -2
- package/packages/web-sdk/packages/planner-core/src/view-model/wall-attic-plan-element-view-model.d.ts +1 -1
- package/packages/web-sdk/packages/planner-core/src/view-model/wall-plan-element-view-model.d.ts +2 -2
- package/packages/web-sdk/packages/planner-core/src/webgl/planner-element-highlighter.d.ts +1 -1
- package/packages/web-sdk/packages/planner-core/src/webgl/planner-scene-event-handler.d.ts +4 -3
- package/packages/web-sdk/packages/planner-core/src/webgl/planner-scene-manager.d.ts +6 -6
- package/packages/web-sdk/packages/tools-core/src/tools-core.d.ts +1 -1
- package/packages/web-sdk/packages/typings/configurator-kernel-container.d.ts +1 -2
- package/packages/web-sdk/packages/typings/external-objects.d.ts +3 -3
- package/packages/web-sdk/packages/typings/global-definitions.d.ts +6 -2
- package/packages/web-sdk/packages/typings/kernel.d.ts +5 -7
- package/packages/web-sdk/packages/typings/planner-kernel-container.d.ts +1 -2
- package/packages/web-sdk/packages/typings/planner.d.ts +2 -2
- package/packages/web-sdk/packages/typings/shims.d.ts +0 -5
- package/roomle-embedding-lib.es.js +49 -54
- package/roomle-embedding-lib.es.min.js +1 -1
- package/roomle-embedding-lib.umd.js +7 -7
- package/roomle-embedding-lib.umd.min.js +1 -1
- package/src/common/components/EmbeddedAdditionalInfo.vue.d.ts +3 -3
- package/src/common/components/EmbeddedExternalCatalog.vue.d.ts +5 -5
- package/src/common/components/EmbeddedInfoWrapper.vue.d.ts +14 -11
- package/src/common/components/ExpandableIcons.vue.d.ts +9 -7
- package/src/common/components/IconButton.vue.d.ts +1 -1
- package/src/common/components/Layer.vue.d.ts +4 -2
- package/src/common/components/Layout.vue.d.ts +8 -6
- package/src/common/components/SelectionButton.vue.d.ts +6 -4
- package/src/common/components/ShowCustomView.vue.d.ts +12 -10
- package/src/common/components/SwitchButton.vue.d.ts +11 -9
- package/src/common/components/Tooltip.vue.d.ts +26 -24
- package/src/common/components/action-buttons/-utils/ActionButton.vue.d.ts +6 -4
- package/src/common/components/flying-menu/FlyingMenu.vue.d.ts +2 -2
- package/src/common/components/helpers.d.ts +1 -0
- package/src/common/components/inputs/NumericInputWrapper.vue.d.ts +6 -4
- package/src/common/components/inputs/SelectDropdown.vue.d.ts +2 -2
- package/src/common/components/notifications/LoadSavedPlanNotification.vue.d.ts +2 -0
- package/src/common/components/notifications/NotificationCard.vue.d.ts +6 -4
- package/src/common/components/overlays/PartList.vue.d.ts +66 -65
- package/src/common/components/overlays/part-list/PartListEntry.vue.d.ts +9 -9
- package/src/common/components/overlays/part-list/PartListHeader.vue.d.ts +3 -2
- package/src/common/components/overlays/part-list/PartListPrint.vue.d.ts +7 -4
- package/src/common/components/overlays/part-list/PartListRow.vue.d.ts +2 -2
- package/src/common/components/overlays/part-list/partlist-setup.d.ts +2 -4
- package/src/common/components/parameters/ColorParameter.vue.d.ts +10 -2208
- package/src/common/components/side-bar/NavigationButtonsWrapper.vue.d.ts +4 -2
- package/src/common/components/side-bar/ResponsiveSidebarWrapper.vue.d.ts +9 -6
- package/src/common/components/side-bar/SidebarItem.vue.d.ts +18 -9
- package/src/common/components/side-bar/SidebarItemLabel.vue.d.ts +8 -2
- package/src/common/components/side-bar/TabbedNav.vue.d.ts +7 -6
- package/src/common/components/side-bar/TabbedNavMenu.vue.d.ts +3 -2
- package/src/common/components/side-bar/utils/configurator-sidebar-components.d.ts +72 -2310
- package/src/common/components/side-bar/utils/types.d.ts +1 -2
- package/src/common/components/tool-tip/MoreInfoTooltipContent.vue.d.ts +9 -4
- package/src/common/components/tool-tip/ParameterTooltip.vue.d.ts +6 -4
- package/src/common/components/utils/-utils/notifications.d.ts +1 -1
- package/src/common/components/utils/CollapsibleButtonsContainer.vue.d.ts +3 -1
- package/src/common/components/utils/HeightToggle.vue.d.ts +3 -1
- package/src/common/composables/use-configurator-actions-visibility.d.ts +1 -1
- package/src/common/composables/use-fetch-root-tag.d.ts +1 -1
- package/src/common/composables/use-item-variants.d.ts +1 -1
- package/src/common/composables/use-keyboard-resize.d.ts +1 -0
- package/src/common/composables/use-materials-and-ral-colors.d.ts +3 -2
- package/src/common/composables/use-materials-grouped.d.ts +1 -1
- package/src/common/composables/use-measurement-styles.d.ts +1 -2
- package/src/common/composables/use-product-price.d.ts +1 -1
- package/src/common/composables/use-sdk-event-emitter-listener.d.ts +1 -7
- package/src/common/composables/use-selected-object-center.d.ts +2 -1
- package/src/common/composables/use-selected-plan-element.d.ts +1 -0
- package/src/common/composables/use-shared-sidebar-setup.d.ts +20 -28
- package/src/common/composables/use-static-item-parameters.d.ts +1 -0
- package/src/common/composables/use-wall-dimensions-cache.d.ts +1 -1
- package/src/common/store/common-ui-store.d.ts +10 -9
- package/src/common/store/index.d.ts +1 -1
- package/src/common/utils/catalog-builder.d.ts +2 -3
- package/src/common/utils/color.d.ts +1 -0
- package/src/common/utils/helper.d.ts +5 -5
- package/src/common/utils/parameters.d.ts +1 -3
- package/src/common/utils/root-tags.d.ts +1 -1
- package/src/common/utils/types.d.ts +1 -3
- package/src/common/utils/ui-actions.d.ts +2 -3
- package/src/configurator/business-logic/roomle-sdk-wrapper.d.ts +1 -8
- package/src/configurator/business-logic/sdk-connector-configurator.d.ts +1 -3
- package/src/configurator/business-logic/sdk-connector.d.ts +1 -10
- package/src/configurator/business-logic/ui-callback.d.ts +1 -1
- package/src/configurator/components/addons/PossibleChildren.vue.d.ts +2 -0
- package/src/configurator/components/grid-view/-utils/CollapsedView.vue.d.ts +25 -22
- package/src/configurator/components/grid-view/-utils/ExpandedHeader.vue.d.ts +8 -6
- package/src/configurator/components/grid-view/-utils/ExpandedView.vue.d.ts +21 -20
- package/src/configurator/components/grid-view/-utils/GridViewElement.vue.d.ts +3 -2
- package/src/configurator/components/grid-view/-utils/GridViewHelper.d.ts +1 -2
- package/src/configurator/components/grid-view/-utils/GridViewMaterialElement.vue.d.ts +4 -2
- package/src/configurator/components/grid-view/-utils/GridViewThumbnailsElement.vue.d.ts +4 -2
- package/src/configurator/components/grid-view/-utils/GridViewTooltipElement.vue.d.ts +4 -2
- package/src/configurator/components/grid-view/GridView.vue.d.ts +15 -13
- package/src/configurator/components/overlays/LoadProduct.vue.d.ts +6 -4
- package/src/configurator/components/overlays/SaveDraft.vue.d.ts +6 -4
- package/src/configurator/components/overlays/ar/OpenARView.vue.d.ts +15 -12
- package/src/configurator/components/parameters/ParameterGroupButton.vue.d.ts +7 -5
- package/src/configurator/components/parameters/ParameterGroups.vue.d.ts +6 -4
- package/src/configurator/components/parameters/types/DisabledParameters.vue.d.ts +2 -2
- package/src/configurator/components/parameters/types/MaterialParameter.vue.d.ts +2 -0
- package/src/configurator/components/parameters/types/OptionsParameter.vue.d.ts +2 -0
- package/src/configurator/components/parameters/types/OptionsParameterValue.vue.d.ts +8 -6
- package/src/configurator/components/parameters/types/ParameterGroupPills.vue.d.ts +9 -7
- package/src/configurator/components/parameters/types/ProductVariant.vue.d.ts +13 -12
- package/src/configurator/components/parameters/types/RangeParameter.vue.d.ts +1 -0
- package/src/configurator/components/parameters/types/ThumbnailsParameter.vue.d.ts +13 -12
- package/src/configurator/components/utils/-utils/SceneOffsetResizer.d.ts +1 -2
- package/src/configurator/components/utils/AspectRatioBox.vue.d.ts +4 -2
- package/src/configurator/components/utils/HeightContainer.vue.d.ts +9 -7
- package/src/configurator/components/utils/InteractionsContainer.vue.d.ts +11 -9
- package/src/configurator/components/utils/PopUp.vue.d.ts +8 -6
- package/src/configurator/components/utils/SearchInput.vue.d.ts +8 -6
- package/src/configurator/components/utils/WordWrap.vue.d.ts +3 -2
- package/src/configurator/embedding/drag-handler.d.ts +1 -1
- package/src/configurator/embedding/example/Embedding.vue.d.ts +5 -4
- package/src/configurator/embedding/example/GlbConfSwitch.vue.d.ts +3 -2
- package/src/configurator/embedding/example/GlbConfSwitchSecret.vue.d.ts +2 -1
- package/src/configurator/embedding/exposed-api.d.ts +1 -9
- package/src/configurator/embedding/exposed-callbacks.d.ts +1 -3
- package/src/configurator/embedding/helper.d.ts +2 -4
- package/src/configurator/embedding/roomle-configurator-api.d.ts +1 -4
- package/src/configurator/embedding/types.d.ts +1 -3
- package/src/configurator/plugins/libs-plugin.d.ts +0 -1
- package/src/configurator/store/core-data-store.d.ts +23 -22
- package/src/configurator/store/ui-state.d.ts +1 -5
- package/src/planner/business-logic/general-room-parameters.d.ts +2 -0
- package/src/planner/business-logic/rooms.d.ts +1 -4
- package/src/planner/business-logic/sdk-connector-planner.d.ts +2 -7
- package/src/planner/components/DraggableButton.vue.d.ts +12 -10
- package/src/planner/components/ObjectList.vue.d.ts +3 -2
- package/src/planner/components/RotationIndicator.vue.d.ts +10 -5
- package/src/planner/components/catalog/CatalogLevels.vue.d.ts +4 -2
- package/src/planner/components/catalog/CatalogNavigation.vue.d.ts +2 -2
- package/src/planner/components/catalog/ProductCard.vue.d.ts +4 -2
- package/src/planner/components/catalog/ProductGrid.vue.d.ts +2 -2
- package/src/planner/components/measurements/MeasurementDisplayComponent.vue.d.ts +25 -20
- package/src/planner/components/measurements/ShowConstructionMeasurements.vue.d.ts +2 -0
- package/src/planner/components/measurements/ShowFloorsAreasData.vue.d.ts +2 -0
- package/src/planner/components/measurements/ShowMeasurementLineDimension.vue.d.ts +2 -0
- package/src/planner/components/measurements/ShowObjectMeasurements.vue.d.ts +7 -4
- package/src/planner/components/measurements/ShowWallAtticMeasurements.vue.d.ts +2 -0
- package/src/planner/components/measurements/ShowWallMeasurements.vue.d.ts +5 -2
- package/src/planner/components/measurements/utils/AtticLine.vue.d.ts +2 -2
- package/src/planner/components/measurements/utils/MeasurementText.vue.d.ts +6 -4
- package/src/planner/components/overlays/ProductList.vue.d.ts +6 -5
- package/src/planner/components/overlays/ProductSettings.vue.d.ts +4 -3
- package/src/planner/components/overlays/RoomSidebar.vue.d.ts +3 -3
- package/src/planner/components/overlays/product-list/ProductListEntry.vue.d.ts +6 -4
- package/src/planner/components/overlays/product-list/ProductListType.vue.d.ts +6 -4
- package/src/planner/components/overlays/product-list/ProductsTotalPrice.vue.d.ts +1 -0
- package/src/planner/components/overlays/product-settings/ProductPositions.vue.d.ts +2 -0
- package/src/planner/components/overlays/product-settings/ProductRangeControl.vue.d.ts +22 -48
- package/src/planner/components/overlays/product-settings/ProductRotation.vue.d.ts +2 -0
- package/src/planner/components/overlays/product-settings/ProductSettingsInfos.vue.d.ts +9 -6
- package/src/planner/components/overlays/product-settings/ProductSize.vue.d.ts +2 -0
- package/src/planner/components/overlays/product-settings/ProductXYZChanger.vue.d.ts +2 -0
- package/src/planner/components/overlays/rooms/ConstructionVariants.vue.d.ts +5 -2
- package/src/planner/components/overlays/rooms/DoorParametersSetting.vue.d.ts +4 -3
- package/src/planner/components/overlays/rooms/ElementLengthScaling.vue.d.ts +22 -57
- package/src/planner/components/overlays/rooms/RoomFloorAndWallSettings.vue.d.ts +8 -7
- package/src/planner/components/overlays/rooms/RoomGeneralSettings.vue.d.ts +4 -3
- package/src/planner/components/overlays/rooms/RoomRangeParameter.vue.d.ts +1 -0
- package/src/planner/components/overlays/rooms/RoomsList.vue.d.ts +5 -4
- package/src/planner/components/overlays/rooms/SampleRooms.vue.d.ts +3 -3
- package/src/planner/components/overlays/rooms/SlopingRoof.vue.d.ts +5 -2
- package/src/planner/components/overlays/rooms/SlopingRoofDirection.vue.d.ts +7 -4
- package/src/planner/components/overlays/rooms/WallGeneralSettings.vue.d.ts +6 -4
- package/src/planner/components/overlays/rooms/WindowParametersSetting.vue.d.ts +4 -3
- package/src/planner/components/utils/ConfiguratorParameter.vue.d.ts +23 -0
- package/src/planner/components/utils/InteractionHeader.vue.d.ts +4 -2
- package/src/planner/components/utils/MeasurementsString.vue.d.ts +10 -6
- package/src/planner/store/planner-core-data.d.ts +1 -1
- package/src/planner/store/planner-ui-state.d.ts +1 -4
- package/src/planner/utils/interaction.d.ts +4 -1
- package/src/planner/utils/planner-sidebar.d.ts +1 -2
- package/src/viewer/business-logic/sdk-connector-viewer.d.ts +1 -1
- package/src/viewer/components/ViewerMain.vue.d.ts +4 -4
- package/src/viewer/components/ViewerSidebar.vue.d.ts +2 -2
- package/packages/web-sdk/packages/benchmark/budgeteer-measure.d.ts +0 -1
- package/src/common/components/flying-menu/FlyingMenuToggles.vue.d.ts +0 -16
- package/src/common/components/flying-menu/MergeProductButtons.vue.d.ts +0 -2
|
@@ -1 +1 @@
|
|
|
1
|
-
var t,e;t=this,e=function(t){"use strict";class e{_side;_incomingMessageBus=null;_outgoingMessageBus=null;_execMessage=null;constructor(t,e,s,n){this._side=t,this._incomingMessageBus=e,this._outgoingMessageBus=s,this._execMessage=n,this._incomingMessageBus&&this._incomingMessageBus.addEventListener("message",this._handleMessage.bind(this))}setOutgoingMessageBus(t){this._outgoingMessageBus=t}setMessageExecution(t){this._execMessage=t}sendMessage(t,e=[]){return new Promise((s,n)=>{if(this._incomingMessageBus===this._outgoingMessageBus)return s(void 0);const r=new MessageChannel;r.port1.onmessage=t=>{if(!t||!t.data)return r.port1.close(),r.port2.close(),n(new Error(this._side+" received message but response can not be interpreted"));let e;try{e=JSON.parse(t.data)}catch(t){return r.port1.close(),r.port2.close(),this._prepareError(t),n(t)}e.error?n(e.error):void 0!==e.result?s(e.result):s(void 0),r.port1.close(),r.port2.close()};let i="";try{i=JSON.stringify({message:t,args:e})}catch{return n(new Error(this._side+": can not create command because it is not JSON.stringify able"))}if(!this._outgoingMessageBus)return n(new Error(this._side+": outgoing bus not set yet"));this._outgoingMessageBus.postMessage(i,"*",[r.port2])})}_handleMessage(t){const e=t.ports&&Array.isArray(t.ports)&&t.ports.length>0?t.ports[0]:null;if(t.data&&("string"==typeof t.data||"connect_hi"!==t.data.type)&&e)try{const s=JSON.parse(t.data);if(!this._execMessage)return e.postMessage(JSON.stringify({error:this._side+" is not ready to handle messages"}));Array.isArray(s.args)||(s.args=[s.args]);const n=this._execMessage(s,t);if(void 0===n)return;n.then((t={})=>{let s,n;"object"==typeof t&&null!==t&&(s=t.error,n=t.result),s?e.postMessage(JSON.stringify({error:s})):void 0!==n?e.postMessage(JSON.stringify({result:n})):e.postMessage(JSON.stringify({result:t}))},t=>{e.postMessage(JSON.stringify({error:this._prepareError(t)}))})}catch(t){e.postMessage(JSON.stringify({error:this._prepareError(t)}))}}_prepareError(t){return"string"==typeof t?this._side+": "+t:(t.message=this._side+": "+t.message,t.message)}}const s=Symbol("Comlink.proxy"),n=Symbol("Comlink.endpoint"),r=Symbol("Comlink.releaseProxy"),i=Symbol("Comlink.finalizer"),a=Symbol("Comlink.thrown"),o=t=>"object"==typeof t&&null!==t||"function"==typeof t,l={canHandle:t=>o(t)&&t[s],serialize(t){const{port1:e,port2:s}=new MessageChannel;return u(t,e),[s,[s]]},deserialize:t=>(t.start(),function(t){const e=new Map;return t.addEventListener("message",function(t){const{data:s}=t;if(!s||!s.id)return;const n=e.get(s.id);if(n)try{n(s)}finally{e.delete(s.id)}}),f(t,e,[],void 0)}(t))},c={canHandle:t=>o(t)&&a in t,serialize({value:t}){let e;return e=t instanceof Error?{isError:!0,value:{message:t.message,name:t.name,stack:t.stack}}:{isError:!1,value:t},[e,[]]},deserialize(t){throw t.isError?Object.assign(new Error(t.value.message),t.value):t.value}},h=new Map([["proxy",l],["throw",c]]);function u(t,e=globalThis,n=["*"]){e.addEventListener("message",function r(o){if(!o||!o.data)return;if(!function(t,e){for(const s of t)if(e===s||"*"===s||s instanceof RegExp&&s.test(e))return!0;return!1}(n,o.origin))return;const{id:l,type:c,path:h}=Object.assign({path:[]},o.data),d=(o.data.argumentList||[]).map(D);let m;try{const e=h.slice(0,-1).reduce((t,e)=>t[e],t),n=h.reduce((t,e)=>t[e],t);switch(c){case"GET":m=n;break;case"SET":e[h.slice(-1)[0]]=D(o.data.value),m=!0;break;case"APPLY":m=n.apply(e,d);break;case"CONSTRUCT":m=function(t){return Object.assign(t,{[s]:!0})}(new n(...d));break;case"ENDPOINT":{const{port1:e,port2:s}=new MessageChannel;u(t,s),m=function(t,e){return v.set(t,e),t}(e,[e])}break;case"RELEASE":m=void 0;break;default:return}}catch(t){m={value:t,[a]:0}}Promise.resolve(m).catch(t=>({value:t,[a]:0})).then(s=>{const[n,a]=w(s);e.postMessage(Object.assign(Object.assign({},n),{id:l}),a),"RELEASE"===c&&(e.removeEventListener("message",r),g(e),i in t&&"function"==typeof t[i]&&t[i]())}).catch(t=>{const[s,n]=w({value:new TypeError("Unserializable return value"),[a]:0});e.postMessage(Object.assign(Object.assign({},s),{id:l}),n)})}),e.start&&e.start()}function g(t){(function(t){return"MessagePort"===t.constructor.name})(t)&&t.close()}function d(t){if(t)throw new Error("Proxy has been released and is not useable")}function m(t){return E(t,new Map,{type:"RELEASE"}).then(()=>{g(t)})}const _=new WeakMap,p="FinalizationRegistry"in globalThis&&new FinalizationRegistry(t=>{const e=(_.get(t)||0)-1;_.set(t,e),0===e&&m(t)});function f(t,e,s=[],i=function(){}){let a=!1;const o=new Proxy(i,{get(n,i){if(d(a),i===r)return()=>{(function(t){p&&p.unregister(t)})(o),m(t),e.clear(),a=!0};if("then"===i){if(0===s.length)return{then:()=>o};const n=E(t,e,{type:"GET",path:s.map(t=>t.toString())}).then(D);return n.then.bind(n)}return f(t,e,[...s,i])},set(n,r,i){d(a);const[o,l]=w(i);return E(t,e,{type:"SET",path:[...s,r].map(t=>t.toString()),value:o},l).then(D)},apply(r,i,o){d(a);const l=s[s.length-1];if(l===n)return E(t,e,{type:"ENDPOINT"}).then(D);if("bind"===l)return f(t,e,s.slice(0,-1));const[c,h]=b(o);return E(t,e,{type:"APPLY",path:s.map(t=>t.toString()),argumentList:c},h).then(D)},construct(n,r){d(a);const[i,o]=b(r);return E(t,e,{type:"CONSTRUCT",path:s.map(t=>t.toString()),argumentList:i},o).then(D)}});return function(t,e){const s=(_.get(e)||0)+1;_.set(e,s),p&&p.register(t,e,t)}(o,t),o}function y(t){return Array.prototype.concat.apply([],t)}function b(t){const e=t.map(w);return[e.map(t=>t[0]),y(e.map(t=>t[1]))]}const v=new WeakMap;function w(t){for(const[e,s]of h)if(s.canHandle(t)){const[n,r]=s.serialize(t);return[{type:"HANDLER",name:e,value:n},r]}return[{type:"RAW",value:t},v.get(t)||[]]}function D(t){switch(t.type){case"HANDLER":return h.get(t.name).deserialize(t.value);case"RAW":return t.value}}function E(t,e,s,n){return new Promise(r=>{const i=new Array(4).fill(0).map(()=>Math.floor(Math.random()*Number.MAX_SAFE_INTEGER).toString(16)).join("-");e.set(i,r),t.start&&t.start(),t.postMessage(Object.assign({id:i},s),n)})}const T=["127.0.0.1","localhost","0.0.0.0"],S=["language","browserLanguage","userLanguage","systemLanguage"],M=(t,e)=>{for(const s in e)try{e[s].constructor===Object?t[s]=M(t[s],e[s]):t[s]=e[s]}catch{t[s]=e[s]}return t};var x,I=((x=I||{}).BOTTOM_BAR="bottom_bar",x.PARTLIST_BOUNDS="partlist_bounds",x.INTERACTION_NOTES="interaction_notes",x.PARAMETER_GROUPS="parameter_groups",x);const C={mobileLandscape:!0,floorMaterialRootTag:"materials_root",buttons:{renderimage:!0,requestproduct:!0,requestplan:!0,load_product:!0,partlist_print:!0},elements:{[I.INTERACTION_NOTES]:!0},helpcenter:{roomdesigner:!0,configurator:!1,disable:!1},firstPersonView:!0,saveToIdb:!0,featureFlags:{mocAr:!0,wallAutoHeight:!1,openCloseAnimation:!0,enableTwoLevelCatalog:!1,webGpu:!1},rotationSnapDegrees:10,interactionsCollapsed:!1},A=t=>{if(!t)return;const e=Object.keys(t);for(const s of e){const e=t[s];if(!Array.isArray(e)&&"object"==typeof e&&null!==e&&A(e),Array.isArray(e))for(const t of e)A(t);("true"===e||"false"===e)&&(t[s]="true"===e)}},L=()=>/(android)/i.test(navigator.userAgent);class O{_messageHandler=null;isSetupDone=!1;viewName="main";plugins={};pluginsLoaded=[];ui={callbacks:null};extended={callbacks:null};configurator={callbacks:null};analytics={callbacks:{}};rapi={callbacks:{}};global={callbacks:{}};setMessageHandler(t){this._messageHandler=t}handleSetup(t){const{methods:e,callbacks:s}=t;e.forEach(t=>{const e=t.split("."),s=e[0],n=e[1];this[s]||(this[s]={}),this[s][n]=function(){if(this._messageHandler)return this._messageHandler.sendMessage(t,[...arguments])}.bind(this)}),s.forEach(t=>{const e=t.split("."),s=e[0],n=e[1],r=e[2];this[s]||(this[s]={}),this[s][n]||(this[s][n]={}),this[s][n][r]=()=>{}}),this.isSetupDone=!0}executeMessage({message:t,args:e}){const s=t.split("."),n=s[0],r=s[1],i=3===s.length?s[2]:null;if(i&&this[n][r][i]){const t=this[n][r][i](...e);return t instanceof Promise?t.then(t=>({result:t})):void 0!==t?Promise.resolve({result:t}):Promise.resolve({result:null})}return Promise.reject('Message "'+t+'" is unkown')}setupPlugins(t,e,s="website"){for(const n of t)"string"==typeof n&&"dragIn"===n?this.pluginsLoaded.push(new Promise((t,n)=>{try{Promise.resolve().then(()=>at).then(({DragIn:r})=>{const i=new r(this.ui,e,s,this.viewName);i.init().then(()=>{this.plugins.dragIn=i,t()},n)})}catch(t){n(t)}})):n.name&&n.loader&&this.pluginsLoaded.push(new Promise((t,r)=>{try{n.loader().then(i=>{const a=new i(this.ui,e,s,this.viewName);a.init().then(()=>{this.plugins[n.name]=a,t()},r)})}catch(t){r(t)}}))}}const P=()=>{let t,e;return{promise:new Promise((s,n)=>{t=s,e=n}),resolve:t,reject:e}},B=(t,e,s)=>{let n=null;Object.defineProperty(t,e,{get:()=>n||s,set(t){n=t?.mute?t.value:t}})},F=()=>.01*window.innerHeight+"px",N=t=>{t&&setTimeout(()=>t.style.setProperty(k,F()),0)},R="rml-styles",k="--rml-full-height",U="rml-container",G="rml-fill",H="rml-pos",X="rml-android-height",j="rml-overflow-hidden",Y=new Map;class z{_mainDomElement;_instance;_mode="website";_viewName="main";constructor(t,e,s,n){this._instance=t,this._mainDomElement=e,this._mode=s,this._viewName=n}async init(){return Promise.resolve()}}const $="rml-drag-in-styles",W="rml-drag-in-drag-element",q="rml-drag-in-overlay",J="rml-drag-in-drag-ghost",K="rml-drag-in-fade-in",V="rml-drag-in-fade-out",Q="rml-display-none",Z="250ms",tt="forwards",et=`@keyframes ${K} {from{opacity: 0;}to {opacity: 0.5;}}`,st=`@keyframes ${V} {from{opacity: 0.5;}to {opacity: 0;}}`,nt=`${K} ${Z} ${tt}`,rt=`${V} ${Z} ${tt}`,it="https://res.cloudinary.com/roomle/image/upload/v1729679975/fallback_afpyqr.jpg",at=Object.freeze(Object.defineProperty({__proto__:null,DragIn:class extends z{options={};_customDragSignal=new AbortController;_injectStyles(){if(!document.getElementById($)){const t=document.createElement("style");t.type="text/css",t.id=$,t.innerHTML=`\n .${Q}{display:none}\n .${q}{position:absolute;top:0;left:0;width:100%;height:100%;z-index:999;}\n .${J}{position:absolute;top:0;left:0;width:1px;height:1px;z-index:999;pointer-events:none;background-color:transparent;}\n ${et}\n ${st}\n `,document.head.appendChild(t)}}_initializeDragGhost(){const t=this._mainDomElement.parentNode;let e=t.querySelector("."+J);e||(e=document.createElement("div"),e.classList.add(J),e.innerText=" ",t.appendChild(e))}constructor(t,e,s,n){super(t,e,s,n),this._mainDomElement=e,this._injectStyles(),this._initializeDragGhost()}async init(){if(await super.init(),"website"===this._mode)try{const{DragInFromWebsiteStrategy:t}=await Promise.resolve().then(()=>wt);this._strategy=new t(this._instance,this._mainDomElement,{settings:this.options,mode:"website"})}catch(t){throw t}else{if("custom-view"!==this._mode)throw new Error("Unsupported mode");try{const{DragInFromCustomViewStrategy:t}=await Promise.resolve().then(()=>Mt);this._strategy=new t(this._instance,this._mainDomElement,this.options,this._viewName)}catch(t){throw t}}}get isDragging(){return this._strategy.isDragging}dragStart(t,e,s="rml_id"){this._strategy.dragStart(t,e,s)}dragUpdate(t){this._strategy.dragUpdate(t)}dragEnd(){this._strategy.dragEnd()}touchStart(t,e,s="rml_id"){this._strategy.touchStart(t,e,s)}touchMove(t){this._strategy.touchMove(t)}touchEnd(){this._strategy.touchEnd()}dispose(){this._strategy.dispose()}beforeUpdateGhost(t){this._strategy.beforeUpdateGhost(t)}registerCustomDrag({customDragStart:t,customDragEnd:e,customDragUpdate:s,beforeUpdateGhost:n}){n&&this._strategy.beforeUpdateGhost(n);const r=this._customDragSignal.signal,i=e=>{"true"===e.target.getAttribute("data-rml-draggable")&&t(e)},a=t=>{this._strategy.releaseInput(t),this._strategy.isDragging&&e(t)},o=t=>{s(t)};document.querySelectorAll('[data-rml-draggable="true"]').forEach(t=>{t.draggable=!1}),document.addEventListener("mousedown",i,{signal:r}),document.addEventListener("mouseup",a,{signal:r}),document.addEventListener("mousemove",o,{signal:r}),document.addEventListener("mouseleave",a,{signal:r}),document.addEventListener("touchstart",i,{signal:r}),document.addEventListener("touchend",a,{signal:r}),document.addEventListener("touchmove",o,{signal:r})}unregisterCustomDrag(){this._customDragSignal.abort(),this._customDragSignal=new AbortController}releaseInput(t){this._strategy.releaseInput(t)}}},Symbol.toStringTag,{value:"Module"}));class ot{_computedStyleCache=new Map;_maxLifetime=16;_cacheCleanInterval=null;constructor(t=16){this._maxLifetime=t}get(t){const e=this._computedStyleCache.get(t),s=Date.now();if(e&&s-e.updated<this._maxLifetime)return e.style;const n=getComputedStyle(t);return this._computedStyleCache.set(t,{style:n,updated:s}),this._cacheCleanInterval||(this._cacheCleanInterval=setInterval(()=>this._cleanUpCache,Math.max(1e3*this._maxLifetime,5e3))),n}_cleanUpCache(){const t=Date.now();for(const[e,{updated:s}]of this._computedStyleCache.entries())t-s>=this._maxLifetime&&this._computedStyleCache.delete(e);0===this._computedStyleCache.size&&this._cacheCleanInterval&&(clearInterval(this._cacheCleanInterval),this._cacheCleanInterval=null)}}const lt=t=>window.TouchEvent&&t instanceof window.TouchEvent;let ct;const ht=t=>(ct||(ct=new ot),ct.get(t)),ut=(t,e,s)=>{const n=parseFloat(t),r=window.devicePixelRatio||1;if("px"===e)return n;if("%"===e)return n/100*(s===document.documentElement?window.innerWidth:s.offsetWidth);if("rem"===e)return n*parseFloat(ht(document.documentElement).fontSize);if("em"===e)return n*parseFloat(ht(s).fontSize);if("vh"===e||"vw"===e||"vmin"===e||"vmax"===e)return n/100*{vh:window.innerHeight,vw:window.innerWidth,vmin:Math.min(window.innerWidth,window.innerHeight),vmax:Math.max(window.innerWidth,window.innerHeight)}[e];const i={cm:37.7952755906,mm:3.77952755906,in:96};return e in i?n*i[e]*r:0},gt=(t,e,s={x:0,y:0})=>{const n=t.getBoundingClientRect(),r=ht(t).transform;let i=0,a=0;if("none"!==r){const e=/translate\(\s*([-+]?\d*\.?\d+|\d+)(px|%)?,?\s*([-+]?\d*\.?\d+|\d+)?(px|%)?\s*\)/,s=r.match(e);s&&(i=ut(s[1],s[2],t),a=ut(s[3],s[4],t))}const{clientX:o,clientY:l}=dt(e,s);return{x:o-n.left-i+t.scrollLeft,y:l-n.top-a+t.scrollTop}},dt=(t,e=null)=>{const{clientX:s,clientY:n}=lt(t)?mt(t):t;return{clientX:s>0?s:e?e.x:s,clientY:n>0?n:e?e.y:n}},mt=t=>{if(t.touches.length){let{clientX:e,clientY:s}=t.touches[0];if(t.touches.length>1){const n=t.touches[1];e=(e+n.clientX)/2,s=(s+n.clientY)/2}return{clientX:e,clientY:s}}const e=t.changedTouches[0];return{clientX:e.clientX,clientY:e.clientY}},_t=(t,e=0)=>lt(t)?{clientX:t.touches[e].clientX,clientY:t.touches[e].clientY}:{clientX:t.clientX,clientY:t.clientY},pt=t=>!t||!lt(t)||t.touches.length>0;class ft{_touchDragTimeOut;_onTouchDragStart;_payload=null;_delay=500;_firstTouch=null;_lastTouch=null;_epsilon=10;constructor(t,{onTouchDragStart:e},s={}){this._payload=t,this._onTouchDragStart=e,this._delay="number"==typeof s.delay?s.delay:500,this._epsilon="number"==typeof s.epsilon?s.epsilon:10}onStart(t){pt(t)&&(this._touchDragTimeOut||(this._firstTouch=_t(t,lt(t)?t.touches.length-1:0),this._touchDragTimeOut=setTimeout(()=>{this._clearTimeout(),this._lastTouch||(this._lastTouch=_t(t)),this._checkXDistance(t)()},this._delay)))}onEnd(){this._resetTouches()}onMove(t){pt(t)&&(this._lastTouch=_t(t))}_clearTimeout(){this._touchDragTimeOut&&(clearTimeout(this._touchDragTimeOut),this._touchDragTimeOut=null)}_resetTouches(){this._clearTimeout(),this._lastTouch=null,this._firstTouch=null,this._payload=null}_checkXDistance(t){return()=>{if(!this._firstTouch||!this._lastTouch)return;let e=!1;e=Math.abs(this._firstTouch.clientX-this._lastTouch.clientX)<this._epsilon,e&&(this._onTouchDragStart(this._payload,t),this._resetTouches())}}}const yt=(t,e,s=0,n=0)=>{const r=e.x+e.width+s,i=e.x-s,a=e.y+e.height+n,o=e.y-n,{x:l,y:c}=t;return l>=i&&l<=r&&c>=o&&c<=a},bt=(t,e,s,n=0,r=0)=>{if(s&&(s.hiddenIn||s.visibleIn))return s.visibleIn?yt({x:t,y:e},s.visibleIn,n,r):!!s.hiddenIn&&!yt({x:t,y:e},s.hiddenIn,-n,-r)};class vt{_dragGhostAnimationFrameId=null;_dragGhostRemoveAnimationFrameId=null;_dragGhostElement=null;constructor(t=null){this._dragGhostElement=t}updateDragGhost(t,e,s){this._dragGhostRemoveAnimationFrameId&&(cancelAnimationFrame(this._dragGhostRemoveAnimationFrameId),this._dragGhostRemoveAnimationFrameId=null),!s.ghost?.external&&s.ghost&&(this._dragGhostAnimationFrameId||(this._dragGhostAnimationFrameId=requestAnimationFrame(()=>{(()=>{if(!document.getElementById($)){const t=document.createElement("style");t.type="text/css",t.id=$,t.innerHTML=`\n ${et}\n ${st}\n `,document.head.appendChild(t)}})();const n={x:t,y:e};!s.ghost&&this._dragGhostElement&&(s.ghost={}),s.ghost&&!s.ghost.element&&this._dragGhostElement&&(s.ghost.element=this._dragGhostElement),(({x:t,y:e},s)=>{let n=document.getElementById(W);if(!n){if(n=document.createElement("div"),s.ghost?.element)n.appendChild(s.ghost.element);else{const t=document.createElement("img");t.src=s.ghost?.url||it,t.width=s.ghost?.width||112,t.height=s.ghost?.height||112,n.appendChild(t)}n.id=W,n.style.position="fixed",n.style.top="0",n.style.left="0",n.style.willChange="transform",n.style.transform="translate3d(0, 0, 0)",n.style.zIndex="9999",n.style.opacity="0.5",bt(t,e,s.ghost||{},s.settings?.dragInOverlapX,s.settings?.dragInOverlapY)||(n.style.display="none"),n.style.pointerEvents="none",document.body.appendChild(n)}})(n,s),(({x:t,y:e},s)=>{const n=document.getElementById(W);if(!n)return;let r=s.ghost?.width,i=s.ghost?.height;typeof r>"u"&&(r=n.getBoundingClientRect().width||112),typeof i>"u"&&(i=n.getBoundingClientRect().height||112);const a=t-r/2,o=e-i/2;n.style.transform=`translate3d(${a}px, ${o}px, 0)`,s.ghost&&(bt(t,e,s.ghost,s.settings?.dragInOverlapX,s.settings?.dragInOverlapY)?n.style.animation!=nt&&(n.style.animation=nt):n.style.animation!=rt&&(n.style.animation=rt))})(n,s),this._dragGhostAnimationFrameId=null})))}removeDragGhost(){this._dragGhostAnimationFrameId&&(cancelAnimationFrame(this._dragGhostAnimationFrameId),this._dragGhostAnimationFrameId=null),this._dragGhostRemoveAnimationFrameId||(this._dragGhostRemoveAnimationFrameId=requestAnimationFrame(()=>{const t=document.getElementById(W);t&&document.body.removeChild(t),this._dragGhostRemoveAnimationFrameId=null}))}}const wt=Object.freeze(Object.defineProperty({__proto__:null,DragInFromWebsiteStrategy:class{_options={};_instance;_mainDomElement;_currentDrag={};_currentTouch=null;_firefoxDragPosition={x:0,y:0};_onBeforeUpdateDrag=()=>({});isDragging=!1;_firefoxFallback=t=>{if(!this._currentDrag.event)return;t.preventDefault();const e=t||window.event;this._firefoxDragPosition.x=e.pageX||0,this._firefoxDragPosition.y=e.pageY||0};constructor(t,e,s){this._instance=t,this._mainDomElement=e,this._options=s||{},this._firefoxFallback=this._firefoxFallback.bind(this),document.addEventListener("dragover",this._firefoxFallback),this._mainDomElement.parentElement?.addEventListener("dragleave",()=>{this._instance.cancelDragIn()})}beforeUpdateGhost(t){this._onBeforeUpdateDrag=t}dragStart(t,e,s="rml_id"){const n=this._mainDomElement.parentNode;if("relative"!==ht(n).position)return;this._mainDomElement.style.pointerEvents="none";let r=n.querySelector("."+q);r||(r=document.createElement("div"),r.classList.add(q),n.appendChild(r)),r.classList.remove(Q),e.target.getAttribute("draggable");const i=n.querySelector("."+J);this._currentDrag.event=e;const a=e.target,o=a.cloneNode(!0),l=a.getBoundingClientRect();o.style.width=`${l.width}px`,o.style.height=`${l.height}px`,this._currentDrag.ghost=new vt(o),this._currentDrag.offset||(this._currentDrag.offset={x:0,y:0});const{clientX:c,clientY:h}=dt(e,this._firefoxDragPosition);this._currentDrag.offset.x=c-l.left,this._currentDrag.offset.y=h-l.top,e instanceof DragEvent&&e.dataTransfer&&e.dataTransfer.setDragImage&&e.dataTransfer.setDragImage(i,0,0);const{x:u,y:g}=gt(n,this._currentDrag.event||e,this._firefoxDragPosition),d=Math.max(1,u),m=Math.max(1,g);this.isDragging=!0,this._instance.dragInObject(t,d,m,s)}dragUpdate(t){const e=this._mainDomElement.parentNode,{x:s,y:n}=gt(e,t,this._firefoxDragPosition);if(0===s&&0===n)return;const r=Math.max(1,s),i=Math.max(1,n);if(1===r&&1===i)return;let a=r,o=i;if(lt(t)){const t=this._options.settings?.fingerSize||0;a=Math.max(2,r+t),o=Math.max(2,i-t)}const{x:l,y:c,options:h}=this._onBeforeUpdateDrag(a,o,{}),u=h||{settings:{},ghost:{}};u.ghost||(u.ghost={}),u.ghost.visibleIn&&u.ghost.hiddenIn||(u.ghost.hiddenIn=this._mainDomElement.getBoundingClientRect());const g="number"==typeof l?l:a,d="number"==typeof c?c:o;if(this._currentDrag.ghost){const{clientX:e,clientY:s}=dt(t,this._firefoxDragPosition);this._currentDrag.ghost.updateDragGhost(e,s,u)}this._instance.updateDrag(g,d,{})}dragEnd(){this._mainDomElement.style.pointerEvents="all";const t=this._mainDomElement.parentNode;this.isDragging=!1,this._instance.dragInObjectEnd(),this._currentDrag.ghost&&(this._currentDrag.ghost.removeDragGhost(),this._currentDrag.ghost=null),this._currentDrag={},this._firefoxDragPosition={x:0,y:0};const e=t.querySelector("."+q);e&&e.classList.add(Q)}touchStart(t,e,s="rml_id"){e.preventDefault();const n={};"number"==typeof this._options?.settings?.touchDragDelay&&(n.delay=this._options.settings.touchDragDelay),this._options?.settings?.touchDragEpsilon&&(n.epsilon=this._options.settings.touchDragEpsilon),this._currentTouch=new ft(void 0,{onTouchDragStart:(e,n)=>{this.dragStart(t,n,s)}},n),this._currentTouch.onStart(e)}touchMove(t){this._currentTouch&&this._currentTouch.onMove(t),this._currentDrag.event&&this.dragUpdate(t)}touchEnd(){this._currentTouch&&this._currentTouch.onEnd(),this._currentTouch=null,this.dragEnd()}dispose(){document.removeEventListener("dragover",this._firefoxFallback)}releaseInput(t){}}},Symbol.toStringTag,{value:"Module"})),Dt=t=>{t.preventDefault(),t.stopPropagation()};class Et{_startX=0;_startY=0;_lastX=0;_lastY=0;_epsilon;_isWaiting=!1;_onCustomDragStart;constructor({onCustomDragStart:t},e={}){this._epsilon="number"==typeof e.epsilon?e.epsilon:15,this._onCustomDragStart=t}onMove(t){this._lastX=t.clientX,this._lastY=t.clientY,this._isWaiting&&((t,e)=>{const s=this._lastX-t,n=this._lastY-e;return Math.sqrt(s*s+n*n)})(this._startX,this._startY)>this._epsilon&&(this._onCustomDragStart(t),this._isWaiting=!1)}onStart(t){this._startX=t.clientX,this._startY=t.clientY,this.onMove(t),this._isWaiting=!0}onEnd(){this._reset()}_reset(){this._startX=0,this._startY=0,this._lastX=0,this._lastY=0,this._isWaiting=!1}}const Tt="data-rml-old-draggable",St=(t,e)=>{const s=lt(t),n={delay:s?500:100,epsilon:s?10:15};if(!e)return n;if(!(s||t instanceof MouseEvent))return n;const{delayKey:r,epsilonKey:i}=s?{delayKey:"touchDragDelay",epsilonKey:"touchDragEpsilon"}:{delayKey:"customDragDelay",epsilonKey:"customDragEpsilon"};return"number"==typeof e[r]&&(n.delay=e.touchDragDelay),"number"==typeof e[i]&&(n.epsilon=e.touchDragEpsilon),n},Mt=Object.freeze(Object.defineProperty({__proto__:null,DragInFromCustomViewStrategy:class{_options={};_instance;_mainDomElement;_viewName;_currentCustomDrag=null;_currentBb=null;_startTarget=null;_onBeforeUpdateDrag=()=>({});isDragging=!1;constructor(t,e,s,n){this._instance=t,this._options=s||{},this._viewName=n,this._mainDomElement=e,this._mainDomElement.parentElement?.addEventListener("dragleave",()=>{this._instance.cancelDragIn()})}beforeUpdateGhost(t){this._onBeforeUpdateDrag=t}async _dragStart(t,e,s="rml_id"){this._startTarget&&(this._startTarget.style.pointerEvents="none",this._startTarget.style.userSelect="none",this._startTarget.setAttribute(Tt,this._startTarget.draggable.toString()),this._startTarget.draggable=!1,this._startTarget.removeEventListener("dragstart",Dt),this._startTarget.addEventListener("dragstart",Dt)),this._currentBb=await this._instance.getBoundingClientRect((()=>`[data-rml-custom-view="${this._viewName}"]`)());const{clientX:n,clientY:r}=dt(e),i=this._currentBb.x+n,a=this._currentBb.y+r;this.isDragging=!0,this._instance.dragInObject(t,i,a,s)}_dragUpdate(t){if(document.body.focus(),this._currentCustomDrag&&this._currentCustomDrag.onMove(t),!this._currentBb||!this.isDragging)return;const{clientX:e,clientY:s}=dt(t),{url:n,width:r,height:i}=(t=>{let e="",s=112,n=112;if(!t)return{url:it,width:s,height:n};const r=t;if(r instanceof HTMLElement){const t=r.getBoundingClientRect(),i=r.getAttribute("data-rml-ghost-url"),a=r.getAttribute("data-rml-ghost-width"),o=r.getAttribute("data-rml-ghost-height");i?e=i:!i&&r instanceof HTMLImageElement&&r.src&&(e=r.src),e?(s=t.width,n=t.height):e=it,s=a?parseInt(a,10):s,n=o?parseInt(o,10):n}return{url:e||it,width:s,height:n}})(this._startTarget),a=this._currentBb.x+e,o=this._currentBb.y+s,l=this._options||{},c={ghost:{visibleIn:{x:this._currentBb.x-(l.dragInOverlapX||0),y:this._currentBb.y+(l.dragInOverlapY||0),width:this._currentBb.width+(l.dragInOverlapX||0),height:this._currentBb.height+(l.dragInOverlapY||0)},url:n,width:r,height:i},mode:"custom-view"},{x:h,y:u,options:g}=this._onBeforeUpdateDrag(a,o,c),d="number"==typeof h?h:a,m="number"==typeof u?u:o,_=g||c;this._instance.updateDrag(d,m,_)}_dragEnd(){this._currentCustomDrag&&this._currentCustomDrag.onEnd(),this._currentCustomDrag=null,this.isDragging=!1,this._currentBb=null,this._resetStartTarget(),this._instance.enableEvents(),this._instance.dragInObjectEnd()}dragStart(t,e,s){this._instance.disableEvents(),this._startTarget=e.target,this._currentCustomDrag=lt(e)?new ft(void 0,{onTouchDragStart:(e,n)=>{this._dragStart(t,n,s)}},St(e,this._options)):new Et({onCustomDragStart:e=>this._dragStart(t,e,s)},St(e,this._options)),this._currentCustomDrag.onStart(e)}dragEnd(){this._dragEnd()}dragUpdate(t){this._dragUpdate(t)}touchStart(t,e,s="rml_id"){this.dragStart(t,e,s)}touchMove(t){this.dragUpdate(t)}touchEnd(){this.dragEnd()}dispose(){}_resetStartTarget(){this._startTarget&&(this._startTarget.style.pointerEvents="",this._startTarget.style.userSelect="",this._startTarget.draggable="true"===this._startTarget.getAttribute(Tt),this._startTarget.removeAttribute(Tt),this._startTarget.removeEventListener("dragstart",Dt))}releaseInput(t){this._currentCustomDrag&&this._currentCustomDrag.onEnd(),this._resetStartTarget()}}},Symbol.toStringTag,{value:"Module"}));t.HI_PANEL_ACTION={HIDE:"hide",SHOW_ATTRIBUTES:"attributes",SHOW_ARTICLES:"articles"},t.default=class extends O{static createPlanner(t,e,s,n=[]){return this._create(t,e,s,n)}static async connect(t,s=[]){const n=new O;n.viewName=t;const{resolve:r,promise:i}=P(),{resolve:a,promise:o}=P(),l=new e("custom-view-"+t,window,window.parent,({message:t,args:e})=>{switch(t){case"registerCustomViewDone":r();break;case"returnMethods":n.handleSetup(e[0]),a();break;default:if(n.isSetupDone)return n.executeMessage({message:t,args:e})}});n.setMessageHandler(l);const c=[t];return l.sendMessage("registerCustomView",c),await i,l.sendMessage("getMethods",c),await o,n.setupPlugins(s,document.body,"custom-view"),await Promise.allSettled(n.pluginsLoaded),n}static createConfigurator(t,e,s,n=[]){return this._create(t,e,s,n)}static create(t,e,s,n){return this._create(t,e,s,n)}static createViewer(t,e,s,n=[]){return this._create(t,e,s,n)}static hiMessageHandler=null;static setupHi(t){this.hiMessageHandler&&window.removeEventListener("message",this.hiMessageHandler),this.hiMessageHandler=e=>{if("connect_hi"===e.data.type&&e.data.port){const s=e.data.port;s.start?.(),u((t=>new Proxy(t,{get(t,e,s){const n=Reflect.get(t,e,s);return void 0!==n?n:(...t)=>{}}}))(t),s)}},window.addEventListener("message",this.hiMessageHandler)}static async _create(t,e,s,n){return new Promise(async(r,i)=>{try{const i=M((()=>{const t=(t=>JSON.parse(JSON.stringify(t)))(C);t.locale||(t.locale=((t=null)=>{const e=window.navigator;if(t)return t.substr(0,2);if(Array.isArray(e.languages)&&e.languages.length>0)return e.languages[0].substr(0,2);for(let t=0,s=S.length;t<s;t++){const s=e[S[t]];if(s)return s.substr(0,2)}return"en"})()),"(idle)"===t.id&&delete t.id;const e=(()=>{const t=(()=>{try{return window.self!==window.top}catch{return!0}})();let e=window.location.href;if(t){if(!document.referrer)return null;e=document.referrer}const{hostname:s}=new URL(e);return s})();return e&&(t=>!!(T.includes(t)||t.endsWith("roomle.com")||t.endsWith("gitlab.io")||t.endsWith("gitlab.com")))(e)&&(t.configuratorId="demoConfigurator"),t.customApiUrl=void 0,t.emails=!1,t})(),(t=>(A(t),t?.customApiUrl&&(t.customApiUrl=decodeURIComponent(t.customApiUrl)),t.shareUrl&&(t.deeplink=t.shareUrl.replace("<CONF_ID>","#CONFIGURATIONID#")),t))(s));(t=>{t.featureFlags||(t.featureFlags={}),"boolean"!=typeof t.featureFlags.realPartList&&(t.featureFlags.realPartList=!0),"boolean"!=typeof t.featureFlags.globalCallbacks&&(t.featureFlags.globalCallbacks=!0),"boolean"!=typeof t.featureFlags.mocAr&&(t.featureFlags.mocAr=!1)})(i);const a=await(async(t,e)=>{if("string"!=typeof t)throw new Error('Configurator ID is not a string type: "'+typeof t+'"');const s=e.customApiUrl?e.customApiUrl:"https://api.roomle.com/v2",n=e.overrideTenant||9,r=s+"/configurators/"+t,i="roomle_portal_v2",a="03-"+window.btoa((new Date).toISOString()+";anonymous;"+i),o=new Request(r,{method:"GET",headers:new Headers({apiKey:i,currentTenant:n,locale:"en",language:"en",device:1,token:a,platform:"web"}),mode:"cors",cache:"default"}),l=await fetch(o),{configurator:c}=await l.json();return c})(t,i);s=((t,e)=>{e.configuratorId=t.id;const s=t.settings||{};return!e.overrideTenant&&t.tenant&&(e.overrideTenant=t.tenant),((t,e)=>{const s=JSON.parse(JSON.stringify(t));return M(s,e)})(s,e)})(a,i);const o=new this(a,e,s,n,r);return await Promise.allSettled(o.pluginsLoaded),o}catch(t){return i(t)}})}_waitForIframe;_container;_configuratorSettings;_initData={};_iframe;constructor(t,s,n,r,i){if(super(),!t||"string"!=typeof t.id)throw new Error("Please provide a correct configuratorId, you get the correct ID from your Roomle Contact Person");if(Y.has(s))throw new Error("There is already an instance on this DOM element");if(!document.getElementById(R)){const t=n.zIndex||9999999,e=document.createElement("style");e.type="text/css",e.id=R;const s="transition:all ease-in-out 450ms;",r=["-webkit-","-o-"].reduce((t,e)=>t+(e+s),"")+s,i=F();e.innerHTML=`\n .${U}{${k}:${i};}\n .${H}{position:fixed;top:0;left:0;z-index:${t};opacity:0}\n .rml-transition{${r}}\n .${G}{width:100%;height:100%;opacity:1}\n .${X}{height:calc(var(${k},1vh)*100)}\n .${j}{overflow:hidden}\n `,document.head.appendChild(e)}this._executeMessage=this._executeMessage.bind(this);const a=new e("website",window,null,this._executeMessage);this.setMessageHandler(a),this._onResize=this._onResize.bind(this),L()&&window.addEventListener("resize",this._onResize),this._container=s,this._initData=n,this._configuratorSettings=t;const o=this._createIframe();this._onUseFullPage=this._onUseFullPage.bind(this),this._onBackToWebsite=this._onBackToWebsite.bind(this),this._waitForIframe=i,this._container.appendChild(o),this._iframe=o,this.setupPlugins(r,this._iframe),Y.set(s,!0)}teardown(){this._container&&Y.delete(this._container);const t=this._container.querySelector("iframe");t&&this._container.removeChild(t),window.removeEventListener("resize",this._onResize)}_createIframe(){const t=document.createElement("iframe");let e=this._configuratorSettings?.url||"https://www.roomle.com/t/cp/";return this._initData.useLocalRoomle&&(e=location.href.replace("embedding.html","")),location.href.includes("roomle.gitlab.io")&&(e=location.href.replace("embedding.html","index.html")),this._initData.overrideServerUrl&&(e=this._initData.overrideServerUrl),t.src=e,t.classList.add(U),t.classList.add(G),t}_onResize(){N(this._iframe)}_onUseFullPage(){this._iframe.classList.add(H),document.documentElement.classList.add(j),window.document.body.classList.add(j),L()&&(N(this._iframe),this._iframe.classList.add(X))}_onBackToWebsite(){this._iframe.classList.remove(H),this._iframe.classList.remove(X),document.documentElement.classList.remove(j),window.document.body.classList.remove(j)}_executeMessage({message:t,args:e},s){if(s.source&&s.source===this._iframe?.contentWindow)return"requestBoot"===t?this._messageHandler?(this._messageHandler.setOutgoingMessageBus(s.source),Promise.resolve({result:this._initData})):Promise.resolve({error:"MessageHandler not set"}):"setup"===t?(this.handleSetup(e[0]),B(this.ui.callbacks,"onUseFullPage",this._onUseFullPage),B(this.ui.callbacks,"onBackToWebsite",this._onBackToWebsite),this._waitForIframe(this),setTimeout(()=>{this._messageHandler&&this._messageHandler.sendMessage("websiteReady")},0),Promise.resolve({result:null})):this.executeMessage({message:t,args:e})}},Object.defineProperties(t,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})},"object"==typeof exports&&typeof module<"u"?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e(((t=typeof globalThis<"u"?globalThis:t||self)["roomle-embedding-lib"]=t["roomle-embedding-lib"]||{},t["roomle-embedding-lib"].umd=t["roomle-embedding-lib"].umd||{},t["roomle-embedding-lib"].umd.min=t["roomle-embedding-lib"].umd.min||{},t["roomle-embedding-lib"].umd.min.js={}));
|
|
1
|
+
var t,e;t=this,e=function(){"use strict";class t{_side;_incomingMessageBus=null;_outgoingMessageBus=null;_execMessage=null;constructor(t,e,s,n){this._side=t,this._incomingMessageBus=e,this._outgoingMessageBus=s,this._execMessage=n,this._incomingMessageBus&&this._incomingMessageBus.addEventListener("message",this._handleMessage.bind(this))}setOutgoingMessageBus(t){this._outgoingMessageBus=t}setMessageExecution(t){this._execMessage=t}sendMessage(t,e=[]){return new Promise((s,n)=>{if(this._incomingMessageBus===this._outgoingMessageBus)return s(void 0);const r=new MessageChannel;r.port1.onmessage=t=>{if(!t||!t.data)return r.port1.close(),r.port2.close(),n(new Error(this._side+" received message but response can not be interpreted"));let e;try{e=JSON.parse(t.data)}catch(t){return r.port1.close(),r.port2.close(),this._prepareError(t),n(t)}e.error?n(e.error):void 0!==e.result?s(e.result):s(void 0),r.port1.close(),r.port2.close()};let i="";try{i=JSON.stringify({message:t,args:e})}catch{return n(new Error(this._side+": can not create command because it is not JSON.stringify able"))}if(!this._outgoingMessageBus)return n(new Error(this._side+": outgoing bus not set yet"));this._outgoingMessageBus.postMessage(i,"*",[r.port2])})}_handleMessage(t){const e=t.ports&&Array.isArray(t.ports)&&t.ports.length>0?t.ports[0]:null;if(t.data&&("string"==typeof t.data||"connect_hi"!==t.data.type)&&e)try{const s=JSON.parse(t.data);if(!this._execMessage)return e.postMessage(JSON.stringify({error:this._side+" is not ready to handle messages"}));Array.isArray(s.args)||(s.args=[s.args]);const n=this._execMessage(s,t);if(void 0===n)return;n.then((t={})=>{let s,n;"object"==typeof t&&null!==t&&(s=t.error,n=t.result),s?e.postMessage(JSON.stringify({error:s})):void 0!==n?e.postMessage(JSON.stringify({result:n})):e.postMessage(JSON.stringify({result:t}))},t=>{e.postMessage(JSON.stringify({error:this._prepareError(t)}))})}catch(t){e.postMessage(JSON.stringify({error:this._prepareError(t)}))}}_prepareError(t){return"string"==typeof t?this._side+": "+t:(t.message=this._side+": "+t.message,t.message)}}const e=Symbol("Comlink.proxy"),s=Symbol("Comlink.endpoint"),n=Symbol("Comlink.releaseProxy"),r=Symbol("Comlink.finalizer"),i=Symbol("Comlink.thrown"),a=t=>"object"==typeof t&&null!==t||"function"==typeof t,o={canHandle:t=>a(t)&&t[e],serialize(t){const{port1:e,port2:s}=new MessageChannel;return h(t,e),[s,[s]]},deserialize:t=>(t.start(),function(t){const e=new Map;return t.addEventListener("message",function(t){const{data:s}=t;if(!s||!s.id)return;const n=e.get(s.id);if(n)try{n(s)}finally{e.delete(s.id)}}),p(t,e,[],void 0)}(t))},l={canHandle:t=>a(t)&&i in t,serialize({value:t}){let e;return e=t instanceof Error?{isError:!0,value:{message:t.message,name:t.name,stack:t.stack}}:{isError:!1,value:t},[e,[]]},deserialize(t){throw t.isError?Object.assign(new Error(t.value.message),t.value):t.value}},c=new Map([["proxy",o],["throw",l]]);function h(t,s=globalThis,n=["*"]){s.addEventListener("message",function a(o){if(!o||!o.data)return;if(!function(t,e){for(const s of t)if(e===s||"*"===s||s instanceof RegExp&&s.test(e))return!0;return!1}(n,o.origin))return;const{id:l,type:c,path:g}=Object.assign({path:[]},o.data),d=(o.data.argumentList||[]).map(w);let m;try{const s=g.slice(0,-1).reduce((t,e)=>t[e],t),n=g.reduce((t,e)=>t[e],t);switch(c){case"GET":m=n;break;case"SET":s[g.slice(-1)[0]]=w(o.data.value),m=!0;break;case"APPLY":m=n.apply(s,d);break;case"CONSTRUCT":m=function(t){return Object.assign(t,{[e]:!0})}(new n(...d));break;case"ENDPOINT":{const{port1:e,port2:s}=new MessageChannel;h(t,s),m=function(t,e){return v.set(t,e),t}(e,[e])}break;case"RELEASE":m=void 0;break;default:return}}catch(t){m={value:t,[i]:0}}Promise.resolve(m).catch(t=>({value:t,[i]:0})).then(e=>{const[n,i]=b(e);s.postMessage(Object.assign(Object.assign({},n),{id:l}),i),"RELEASE"===c&&(s.removeEventListener("message",a),u(s),r in t&&"function"==typeof t[r]&&t[r]())}).catch(t=>{const[e,n]=b({value:new TypeError("Unserializable return value"),[i]:0});s.postMessage(Object.assign(Object.assign({},e),{id:l}),n)})}),s.start&&s.start()}function u(t){(function(t){return"MessagePort"===t.constructor.name})(t)&&t.close()}function g(t){if(t)throw new Error("Proxy has been released and is not useable")}function d(t){return D(t,new Map,{type:"RELEASE"}).then(()=>{u(t)})}const m=new WeakMap,_="FinalizationRegistry"in globalThis&&new FinalizationRegistry(t=>{const e=(m.get(t)||0)-1;m.set(t,e),0===e&&d(t)});function p(t,e,r=[],i=function(){}){let a=!1;const o=new Proxy(i,{get(s,i){if(g(a),i===n)return()=>{(function(t){_&&_.unregister(t)})(o),d(t),e.clear(),a=!0};if("then"===i){if(0===r.length)return{then:()=>o};const s=D(t,e,{type:"GET",path:r.map(t=>t.toString())}).then(w);return s.then.bind(s)}return p(t,e,[...r,i])},set(s,n,i){g(a);const[o,l]=b(i);return D(t,e,{type:"SET",path:[...r,n].map(t=>t.toString()),value:o},l).then(w)},apply(n,i,o){g(a);const l=r[r.length-1];if(l===s)return D(t,e,{type:"ENDPOINT"}).then(w);if("bind"===l)return p(t,e,r.slice(0,-1));const[c,h]=y(o);return D(t,e,{type:"APPLY",path:r.map(t=>t.toString()),argumentList:c},h).then(w)},construct(s,n){g(a);const[i,o]=y(n);return D(t,e,{type:"CONSTRUCT",path:r.map(t=>t.toString()),argumentList:i},o).then(w)}});return function(t,e){const s=(m.get(e)||0)+1;m.set(e,s),_&&_.register(t,e,t)}(o,t),o}function f(t){return Array.prototype.concat.apply([],t)}function y(t){const e=t.map(b);return[e.map(t=>t[0]),f(e.map(t=>t[1]))]}const v=new WeakMap;function b(t){for(const[e,s]of c)if(s.canHandle(t)){const[n,r]=s.serialize(t);return[{type:"HANDLER",name:e,value:n},r]}return[{type:"RAW",value:t},v.get(t)||[]]}function w(t){switch(t.type){case"HANDLER":return c.get(t.name).deserialize(t.value);case"RAW":return t.value}}function D(t,e,s,n){return new Promise(r=>{const i=new Array(4).fill(0).map(()=>Math.floor(Math.random()*Number.MAX_SAFE_INTEGER).toString(16)).join("-");e.set(i,r),t.start&&t.start(),t.postMessage(Object.assign({id:i},s),n)})}const E=["127.0.0.1","localhost","0.0.0.0"],T=["language","browserLanguage","userLanguage","systemLanguage"],S=(t,e)=>{for(const s in e)try{e[s].constructor===Object?t[s]=S(t[s],e[s]):t[s]=e[s]}catch{t[s]=e[s]}return t};var M,x=((M=x||{}).BOTTOM_BAR="bottom_bar",M.PARTLIST_BOUNDS="partlist_bounds",M.INTERACTION_NOTES="interaction_notes",M.PARAMETER_GROUPS="parameter_groups",M);const I={mobileLandscape:!0,floorMaterialRootTag:"materials_root",buttons:{renderimage:!0,requestproduct:!0,requestplan:!0,load_product:!0,partlist_print:!0},elements:{[x.INTERACTION_NOTES]:!0},helpcenter:{roomdesigner:!0,configurator:!1,disable:!1},firstPersonView:!0,saveToIdb:!0,featureFlags:{mocAr:!0,wallAutoHeight:!1,openCloseAnimation:!0,enableTwoLevelCatalog:!1,webGpu:!1},rotationSnapDegrees:10,interactionsCollapsed:!1},C=t=>{if(!t)return;const e=Object.keys(t);for(const s of e){const e=t[s];if(!Array.isArray(e)&&"object"==typeof e&&null!==e&&C(e),Array.isArray(e))for(const t of e)C(t);("true"===e||"false"===e)&&(t[s]="true"===e)}},L=()=>/(android)/i.test(navigator.userAgent);class A{_messageHandler=null;isSetupDone=!1;viewName="main";plugins={};pluginsLoaded=[];ui={callbacks:null};extended={callbacks:null};configurator={callbacks:null};analytics={callbacks:{}};rapi={callbacks:{}};global={callbacks:{}};setMessageHandler(t){this._messageHandler=t}handleSetup(t){const{methods:e,callbacks:s}=t;e.forEach(t=>{const e=t.split("."),s=e[0],n=e[1];this[s]||(this[s]={}),this[s][n]=function(){if(this._messageHandler)return this._messageHandler.sendMessage(t,[...arguments])}.bind(this)}),s.forEach(t=>{const e=t.split("."),s=e[0],n=e[1],r=e[2];this[s]||(this[s]={}),this[s][n]||(this[s][n]={}),this[s][n][r]=()=>{}}),this.isSetupDone=!0}executeMessage({message:t,args:e}){const s=t.split("."),n=s[0],r=s[1],i=3===s.length?s[2]:null;if(i&&this[n][r][i]){const t=this[n][r][i](...e);return t instanceof Promise?t.then(t=>({result:t})):void 0!==t?Promise.resolve({result:t}):Promise.resolve({result:null})}return Promise.reject('Message "'+t+'" is unkown')}setupPlugins(t,e,s="website"){for(const n of t)"string"==typeof n&&"dragIn"===n?this.pluginsLoaded.push(new Promise((t,n)=>{try{Promise.resolve().then(()=>it).then(({DragIn:r})=>{const i=new r(this.ui,e,s,this.viewName);i.init().then(()=>{this.plugins.dragIn=i,t()},n)})}catch(t){n(t)}})):n.name&&n.loader&&this.pluginsLoaded.push(new Promise((t,r)=>{try{n.loader().then(i=>{const a=new i(this.ui,e,s,this.viewName);a.init().then(()=>{this.plugins[n.name]=a,t()},r)})}catch(t){r(t)}}))}}const O=()=>{let t,e;return{promise:new Promise((s,n)=>{t=s,e=n}),resolve:t,reject:e}},P=(t,e,s)=>{let n=null;Object.defineProperty(t,e,{get:()=>n||s,set(t){n=t?.mute?t.value:t}})},B=()=>.01*window.innerHeight+"px",F=t=>{t&&setTimeout(()=>t.style.setProperty(N,B()),0)},k="rml-styles",N="--rml-full-height",R="rml-container",U="rml-fill",G="rml-pos",X="rml-android-height",H="rml-overflow-hidden",j=new Map;class Y{_mainDomElement;_instance;_mode="website";_viewName="main";constructor(t,e,s,n){this._instance=t,this._mainDomElement=e,this._mode=s,this._viewName=n}async init(){return Promise.resolve()}}const z="rml-drag-in-styles",$="rml-drag-in-drag-element",W="rml-drag-in-overlay",q="rml-drag-in-drag-ghost",J="rml-drag-in-fade-in",K="rml-drag-in-fade-out",V="rml-display-none",Q="250ms",Z="forwards",tt=`@keyframes ${J} {from{opacity: 0;}to {opacity: 0.5;}}`,et=`@keyframes ${K} {from{opacity: 0.5;}to {opacity: 0;}}`,st=`${J} ${Q} ${Z}`,nt=`${K} ${Q} ${Z}`,rt="https://res.cloudinary.com/roomle/image/upload/v1729679975/fallback_afpyqr.jpg",it=Object.freeze(Object.defineProperty({__proto__:null,DragIn:class extends Y{options={};_customDragSignal=new AbortController;_injectStyles(){if(!document.getElementById(z)){const t=document.createElement("style");t.type="text/css",t.id=z,t.innerHTML=`\n .${V}{display:none}\n .${W}{position:absolute;top:0;left:0;width:100%;height:100%;z-index:999;}\n .${q}{position:absolute;top:0;left:0;width:1px;height:1px;z-index:999;pointer-events:none;background-color:transparent;}\n ${tt}\n ${et}\n `,document.head.appendChild(t)}}_initializeDragGhost(){const t=this._mainDomElement.parentNode;let e=t.querySelector("."+q);e||(e=document.createElement("div"),e.classList.add(q),e.innerText=" ",t.appendChild(e))}constructor(t,e,s,n){super(t,e,s,n),this._mainDomElement=e,this._injectStyles(),this._initializeDragGhost()}async init(){if(await super.init(),"website"===this._mode)try{const{DragInFromWebsiteStrategy:t}=await Promise.resolve().then(()=>bt);this._strategy=new t(this._instance,this._mainDomElement,{settings:this.options,mode:"website"})}catch(t){throw t}else{if("custom-view"!==this._mode)throw new Error("Unsupported mode");try{const{DragInFromCustomViewStrategy:t}=await Promise.resolve().then(()=>St);this._strategy=new t(this._instance,this._mainDomElement,this.options,this._viewName)}catch(t){throw t}}}get isDragging(){return this._strategy.isDragging}dragStart(t,e,s="rml_id"){this._strategy.dragStart(t,e,s)}dragUpdate(t){this._strategy.dragUpdate(t)}dragEnd(){this._strategy.dragEnd()}touchStart(t,e,s="rml_id"){this._strategy.touchStart(t,e,s)}touchMove(t){this._strategy.touchMove(t)}touchEnd(){this._strategy.touchEnd()}dispose(){this._strategy.dispose()}beforeUpdateGhost(t){this._strategy.beforeUpdateGhost(t)}registerCustomDrag({customDragStart:t,customDragEnd:e,customDragUpdate:s,beforeUpdateGhost:n}){n&&this._strategy.beforeUpdateGhost(n);const r=this._customDragSignal.signal,i=e=>{"true"===e.target.getAttribute("data-rml-draggable")&&t(e)},a=t=>{this._strategy.releaseInput(t),this._strategy.isDragging&&e(t)},o=t=>{s(t)};document.querySelectorAll('[data-rml-draggable="true"]').forEach(t=>{t.draggable=!1}),document.addEventListener("mousedown",i,{signal:r}),document.addEventListener("mouseup",a,{signal:r}),document.addEventListener("mousemove",o,{signal:r}),document.addEventListener("mouseleave",a,{signal:r}),document.addEventListener("touchstart",i,{signal:r}),document.addEventListener("touchend",a,{signal:r}),document.addEventListener("touchmove",o,{signal:r})}unregisterCustomDrag(){this._customDragSignal.abort(),this._customDragSignal=new AbortController}releaseInput(t){this._strategy.releaseInput(t)}}},Symbol.toStringTag,{value:"Module"}));class at{_computedStyleCache=new Map;_maxLifetime=16;_cacheCleanInterval=null;constructor(t=16){this._maxLifetime=t}get(t){const e=this._computedStyleCache.get(t),s=Date.now();if(e&&s-e.updated<this._maxLifetime)return e.style;const n=getComputedStyle(t);return this._computedStyleCache.set(t,{style:n,updated:s}),this._cacheCleanInterval||(this._cacheCleanInterval=setInterval(()=>this._cleanUpCache,Math.max(1e3*this._maxLifetime,5e3))),n}_cleanUpCache(){const t=Date.now();for(const[e,{updated:s}]of this._computedStyleCache.entries())t-s>=this._maxLifetime&&this._computedStyleCache.delete(e);0===this._computedStyleCache.size&&this._cacheCleanInterval&&(clearInterval(this._cacheCleanInterval),this._cacheCleanInterval=null)}}const ot=t=>window.TouchEvent&&t instanceof window.TouchEvent;let lt;const ct=t=>(lt||(lt=new at),lt.get(t)),ht=(t,e,s)=>{const n=parseFloat(t),r=window.devicePixelRatio||1;if("px"===e)return n;if("%"===e)return n/100*(s===document.documentElement?window.innerWidth:s.offsetWidth);if("rem"===e)return n*parseFloat(ct(document.documentElement).fontSize);if("em"===e)return n*parseFloat(ct(s).fontSize);if("vh"===e||"vw"===e||"vmin"===e||"vmax"===e)return n/100*{vh:window.innerHeight,vw:window.innerWidth,vmin:Math.min(window.innerWidth,window.innerHeight),vmax:Math.max(window.innerWidth,window.innerHeight)}[e];const i={cm:37.7952755906,mm:3.77952755906,in:96};return e in i?n*i[e]*r:0},ut=(t,e,s={x:0,y:0})=>{const n=t.getBoundingClientRect(),r=ct(t).transform;let i=0,a=0;if("none"!==r){const e=/translate\(\s*([-+]?\d*\.?\d+|\d+)(px|%)?,?\s*([-+]?\d*\.?\d+|\d+)?(px|%)?\s*\)/,s=r.match(e);s&&(i=ht(s[1],s[2],t),a=ht(s[3],s[4],t))}const{clientX:o,clientY:l}=gt(e,s);return{x:o-n.left-i+t.scrollLeft,y:l-n.top-a+t.scrollTop}},gt=(t,e=null)=>{const{clientX:s,clientY:n}=ot(t)?dt(t):t;return{clientX:s>0?s:e?e.x:s,clientY:n>0?n:e?e.y:n}},dt=t=>{if(t.touches.length){let{clientX:e,clientY:s}=t.touches[0];if(t.touches.length>1){const n=t.touches[1];e=(e+n.clientX)/2,s=(s+n.clientY)/2}return{clientX:e,clientY:s}}const e=t.changedTouches[0];return{clientX:e.clientX,clientY:e.clientY}},mt=(t,e=0)=>ot(t)?{clientX:t.touches[e].clientX,clientY:t.touches[e].clientY}:{clientX:t.clientX,clientY:t.clientY},_t=t=>!t||!ot(t)||t.touches.length>0;class pt{_touchDragTimeOut;_onTouchDragStart;_payload=null;_delay=500;_firstTouch=null;_lastTouch=null;_epsilon=10;constructor(t,{onTouchDragStart:e},s={}){this._payload=t,this._onTouchDragStart=e,this._delay="number"==typeof s.delay?s.delay:500,this._epsilon="number"==typeof s.epsilon?s.epsilon:10}onStart(t){_t(t)&&(this._touchDragTimeOut||(this._firstTouch=mt(t,ot(t)?t.touches.length-1:0),this._touchDragTimeOut=setTimeout(()=>{this._clearTimeout(),this._lastTouch||(this._lastTouch=mt(t)),this._checkXDistance(t)()},this._delay)))}onEnd(){this._resetTouches()}onMove(t){_t(t)&&(this._lastTouch=mt(t))}_clearTimeout(){this._touchDragTimeOut&&(clearTimeout(this._touchDragTimeOut),this._touchDragTimeOut=null)}_resetTouches(){this._clearTimeout(),this._lastTouch=null,this._firstTouch=null,this._payload=null}_checkXDistance(t){return()=>{if(!this._firstTouch||!this._lastTouch)return;let e=!1;e=Math.abs(this._firstTouch.clientX-this._lastTouch.clientX)<this._epsilon,e&&(this._onTouchDragStart(this._payload,t),this._resetTouches())}}}const ft=(t,e,s=0,n=0)=>{const r=e.x+e.width+s,i=e.x-s,a=e.y+e.height+n,o=e.y-n,{x:l,y:c}=t;return l>=i&&l<=r&&c>=o&&c<=a},yt=(t,e,s,n=0,r=0)=>{if(s&&(s.hiddenIn||s.visibleIn))return s.visibleIn?ft({x:t,y:e},s.visibleIn,n,r):!!s.hiddenIn&&!ft({x:t,y:e},s.hiddenIn,-n,-r)};class vt{_dragGhostAnimationFrameId=null;_dragGhostRemoveAnimationFrameId=null;_dragGhostElement=null;constructor(t=null){this._dragGhostElement=t}updateDragGhost(t,e,s){this._dragGhostRemoveAnimationFrameId&&(cancelAnimationFrame(this._dragGhostRemoveAnimationFrameId),this._dragGhostRemoveAnimationFrameId=null),!s.ghost?.external&&s.ghost&&(this._dragGhostAnimationFrameId||(this._dragGhostAnimationFrameId=requestAnimationFrame(()=>{(()=>{if(!document.getElementById(z)){const t=document.createElement("style");t.type="text/css",t.id=z,t.innerHTML=`\n ${tt}\n ${et}\n `,document.head.appendChild(t)}})();const n={x:t,y:e};!s.ghost&&this._dragGhostElement&&(s.ghost={}),s.ghost&&!s.ghost.element&&this._dragGhostElement&&(s.ghost.element=this._dragGhostElement),(({x:t,y:e},s)=>{let n=document.getElementById($);if(!n){if(n=document.createElement("div"),s.ghost?.element)n.appendChild(s.ghost.element);else{const t=document.createElement("img");t.src=s.ghost?.url||rt,t.width=s.ghost?.width||112,t.height=s.ghost?.height||112,n.appendChild(t)}n.id=$,n.style.position="fixed",n.style.top="0",n.style.left="0",n.style.willChange="transform",n.style.transform="translate3d(0, 0, 0)",n.style.zIndex="9999",n.style.opacity="0.5",yt(t,e,s.ghost||{},s.settings?.dragInOverlapX,s.settings?.dragInOverlapY)||(n.style.display="none"),n.style.pointerEvents="none",document.body.appendChild(n)}})(n,s),(({x:t,y:e},s)=>{const n=document.getElementById($);if(!n)return;let r=s.ghost?.width,i=s.ghost?.height;typeof r>"u"&&(r=n.getBoundingClientRect().width||112),typeof i>"u"&&(i=n.getBoundingClientRect().height||112);const a=t-r/2,o=e-i/2;n.style.transform=`translate3d(${a}px, ${o}px, 0)`,s.ghost&&(yt(t,e,s.ghost,s.settings?.dragInOverlapX,s.settings?.dragInOverlapY)?n.style.animation!=st&&(n.style.animation=st):n.style.animation!=nt&&(n.style.animation=nt))})(n,s),this._dragGhostAnimationFrameId=null})))}removeDragGhost(){this._dragGhostAnimationFrameId&&(cancelAnimationFrame(this._dragGhostAnimationFrameId),this._dragGhostAnimationFrameId=null),this._dragGhostRemoveAnimationFrameId||(this._dragGhostRemoveAnimationFrameId=requestAnimationFrame(()=>{const t=document.getElementById($);t&&document.body.removeChild(t),this._dragGhostRemoveAnimationFrameId=null}))}}const bt=Object.freeze(Object.defineProperty({__proto__:null,DragInFromWebsiteStrategy:class{_options={};_instance;_mainDomElement;_currentDrag={};_currentTouch=null;_firefoxDragPosition={x:0,y:0};_onBeforeUpdateDrag=()=>({});isDragging=!1;_firefoxFallback=t=>{if(!this._currentDrag.event)return;t.preventDefault();const e=t||window.event;this._firefoxDragPosition.x=e.pageX||0,this._firefoxDragPosition.y=e.pageY||0};constructor(t,e,s){this._instance=t,this._mainDomElement=e,this._options=s||{},this._firefoxFallback=this._firefoxFallback.bind(this),document.addEventListener("dragover",this._firefoxFallback),this._mainDomElement.parentElement?.addEventListener("dragleave",()=>{this._instance.cancelDragIn()})}beforeUpdateGhost(t){this._onBeforeUpdateDrag=t}dragStart(t,e,s="rml_id"){const n=this._mainDomElement.parentNode;if("relative"!==ct(n).position)return;this._mainDomElement.style.pointerEvents="none";let r=n.querySelector("."+W);r||(r=document.createElement("div"),r.classList.add(W),n.appendChild(r)),r.classList.remove(V),e.target.getAttribute("draggable");const i=n.querySelector("."+q);this._currentDrag.event=e;const a=e.target,o=a.cloneNode(!0),l=a.getBoundingClientRect();o.style.width=`${l.width}px`,o.style.height=`${l.height}px`,this._currentDrag.ghost=new vt(o),this._currentDrag.offset||(this._currentDrag.offset={x:0,y:0});const{clientX:c,clientY:h}=gt(e,this._firefoxDragPosition);this._currentDrag.offset.x=c-l.left,this._currentDrag.offset.y=h-l.top,e instanceof DragEvent&&e.dataTransfer&&e.dataTransfer.setDragImage&&e.dataTransfer.setDragImage(i,0,0);const{x:u,y:g}=ut(n,this._currentDrag.event||e,this._firefoxDragPosition),d=Math.max(1,u),m=Math.max(1,g);this.isDragging=!0,this._instance.dragInObject(t,d,m,s)}dragUpdate(t){const e=this._mainDomElement.parentNode,{x:s,y:n}=ut(e,t,this._firefoxDragPosition);if(0===s&&0===n)return;const r=Math.max(1,s),i=Math.max(1,n);if(1===r&&1===i)return;let a=r,o=i;if(ot(t)){const t=this._options.settings?.fingerSize||0;a=Math.max(2,r+t),o=Math.max(2,i-t)}const{x:l,y:c,options:h}=this._onBeforeUpdateDrag(a,o,{}),u=h||{settings:{},ghost:{}};u.ghost||(u.ghost={}),u.ghost.visibleIn&&u.ghost.hiddenIn||(u.ghost.hiddenIn=this._mainDomElement.getBoundingClientRect());const g="number"==typeof l?l:a,d="number"==typeof c?c:o;if(this._currentDrag.ghost){const{clientX:e,clientY:s}=gt(t,this._firefoxDragPosition);this._currentDrag.ghost.updateDragGhost(e,s,u)}this._instance.updateDrag(g,d,{})}dragEnd(){this._mainDomElement.style.pointerEvents="all";const t=this._mainDomElement.parentNode;this.isDragging=!1,this._instance.dragInObjectEnd(),this._currentDrag.ghost&&(this._currentDrag.ghost.removeDragGhost(),this._currentDrag.ghost=null),this._currentDrag={},this._firefoxDragPosition={x:0,y:0};const e=t.querySelector("."+W);e&&e.classList.add(V)}touchStart(t,e,s="rml_id"){e.preventDefault();const n={};"number"==typeof this._options?.settings?.touchDragDelay&&(n.delay=this._options.settings.touchDragDelay),this._options?.settings?.touchDragEpsilon&&(n.epsilon=this._options.settings.touchDragEpsilon),this._currentTouch=new pt(void 0,{onTouchDragStart:(e,n)=>{this.dragStart(t,n,s)}},n),this._currentTouch.onStart(e)}touchMove(t){this._currentTouch&&this._currentTouch.onMove(t),this._currentDrag.event&&this.dragUpdate(t)}touchEnd(){this._currentTouch&&this._currentTouch.onEnd(),this._currentTouch=null,this.dragEnd()}dispose(){document.removeEventListener("dragover",this._firefoxFallback)}releaseInput(t){}}},Symbol.toStringTag,{value:"Module"})),wt=t=>{t.preventDefault(),t.stopPropagation()};class Dt{_startX=0;_startY=0;_lastX=0;_lastY=0;_epsilon;_isWaiting=!1;_onCustomDragStart;constructor({onCustomDragStart:t},e={}){this._epsilon="number"==typeof e.epsilon?e.epsilon:15,this._onCustomDragStart=t}onMove(t){this._lastX=t.clientX,this._lastY=t.clientY,this._isWaiting&&((t,e)=>{const s=this._lastX-t,n=this._lastY-e;return Math.sqrt(s*s+n*n)})(this._startX,this._startY)>this._epsilon&&(this._onCustomDragStart(t),this._isWaiting=!1)}onStart(t){this._startX=t.clientX,this._startY=t.clientY,this.onMove(t),this._isWaiting=!0}onEnd(){this._reset()}_reset(){this._startX=0,this._startY=0,this._lastX=0,this._lastY=0,this._isWaiting=!1}}const Et="data-rml-old-draggable",Tt=(t,e)=>{const s=ot(t),n={delay:s?500:100,epsilon:s?10:15};if(!e)return n;if(!(s||t instanceof MouseEvent))return n;const{delayKey:r,epsilonKey:i}=s?{delayKey:"touchDragDelay",epsilonKey:"touchDragEpsilon"}:{delayKey:"customDragDelay",epsilonKey:"customDragEpsilon"};return"number"==typeof e[r]&&(n.delay=e.touchDragDelay),"number"==typeof e[i]&&(n.epsilon=e.touchDragEpsilon),n},St=Object.freeze(Object.defineProperty({__proto__:null,DragInFromCustomViewStrategy:class{_options={};_instance;_mainDomElement;_viewName;_currentCustomDrag=null;_currentBb=null;_startTarget=null;_onBeforeUpdateDrag=()=>({});isDragging=!1;constructor(t,e,s,n){this._instance=t,this._options=s||{},this._viewName=n,this._mainDomElement=e,this._mainDomElement.parentElement?.addEventListener("dragleave",()=>{this._instance.cancelDragIn()})}beforeUpdateGhost(t){this._onBeforeUpdateDrag=t}async _dragStart(t,e,s="rml_id"){this._startTarget&&(this._startTarget.style.pointerEvents="none",this._startTarget.style.userSelect="none",this._startTarget.setAttribute(Et,this._startTarget.draggable.toString()),this._startTarget.draggable=!1,this._startTarget.removeEventListener("dragstart",wt),this._startTarget.addEventListener("dragstart",wt)),this._currentBb=await this._instance.getBoundingClientRect((()=>`[data-rml-custom-view="${this._viewName}"]`)());const{clientX:n,clientY:r}=gt(e),i=this._currentBb.x+n,a=this._currentBb.y+r;this.isDragging=!0,this._instance.dragInObject(t,i,a,s)}_dragUpdate(t){if(document.body.focus(),this._currentCustomDrag&&this._currentCustomDrag.onMove(t),!this._currentBb||!this.isDragging)return;const{clientX:e,clientY:s}=gt(t),{url:n,width:r,height:i}=(t=>{let e="",s=112,n=112;if(!t)return{url:rt,width:s,height:n};const r=t;if(r instanceof HTMLElement){const t=r.getBoundingClientRect(),i=r.getAttribute("data-rml-ghost-url"),a=r.getAttribute("data-rml-ghost-width"),o=r.getAttribute("data-rml-ghost-height");i?e=i:!i&&r instanceof HTMLImageElement&&r.src&&(e=r.src),e?(s=t.width,n=t.height):e=rt,s=a?parseInt(a,10):s,n=o?parseInt(o,10):n}return{url:e||rt,width:s,height:n}})(this._startTarget),a=this._currentBb.x+e,o=this._currentBb.y+s,l=this._options||{},c={ghost:{visibleIn:{x:this._currentBb.x-(l.dragInOverlapX||0),y:this._currentBb.y+(l.dragInOverlapY||0),width:this._currentBb.width+(l.dragInOverlapX||0),height:this._currentBb.height+(l.dragInOverlapY||0)},url:n,width:r,height:i},mode:"custom-view"},{x:h,y:u,options:g}=this._onBeforeUpdateDrag(a,o,c),d="number"==typeof h?h:a,m="number"==typeof u?u:o,_=g||c;this._instance.updateDrag(d,m,_)}_dragEnd(){this._currentCustomDrag&&this._currentCustomDrag.onEnd(),this._currentCustomDrag=null,this.isDragging=!1,this._currentBb=null,this._resetStartTarget(),this._instance.enableEvents(),this._instance.dragInObjectEnd()}dragStart(t,e,s){this._instance.disableEvents(),this._startTarget=e.target,this._currentCustomDrag=ot(e)?new pt(void 0,{onTouchDragStart:(e,n)=>{this._dragStart(t,n,s)}},Tt(e,this._options)):new Dt({onCustomDragStart:e=>this._dragStart(t,e,s)},Tt(e,this._options)),this._currentCustomDrag.onStart(e)}dragEnd(){this._dragEnd()}dragUpdate(t){this._dragUpdate(t)}touchStart(t,e,s="rml_id"){this.dragStart(t,e,s)}touchMove(t){this.dragUpdate(t)}touchEnd(){this.dragEnd()}dispose(){}_resetStartTarget(){this._startTarget&&(this._startTarget.style.pointerEvents="",this._startTarget.style.userSelect="",this._startTarget.draggable="true"===this._startTarget.getAttribute(Et),this._startTarget.removeAttribute(Et),this._startTarget.removeEventListener("dragstart",wt))}releaseInput(t){this._currentCustomDrag&&this._currentCustomDrag.onEnd(),this._resetStartTarget()}}},Symbol.toStringTag,{value:"Module"}));return class extends A{static createPlanner(t,e,s,n=[]){return this._create(t,e,s,n)}static async connect(e,s=[]){const n=new A;n.viewName=e;const{resolve:r,promise:i}=O(),{resolve:a,promise:o}=O(),l=new t("custom-view-"+e,window,window.parent,({message:t,args:e})=>{switch(t){case"registerCustomViewDone":r();break;case"returnMethods":n.handleSetup(e[0]),a();break;default:if(n.isSetupDone)return n.executeMessage({message:t,args:e})}});n.setMessageHandler(l);const c=[e];return l.sendMessage("registerCustomView",c),await i,l.sendMessage("getMethods",c),await o,n.setupPlugins(s,document.body,"custom-view"),await Promise.allSettled(n.pluginsLoaded),n}static createConfigurator(t,e,s,n=[]){return this._create(t,e,s,n)}static create(t,e,s,n){return this._create(t,e,s,n)}static createViewer(t,e,s,n=[]){return this._create(t,e,s,n)}static hiMessageHandler=null;static setupHi(t){this.hiMessageHandler&&window.removeEventListener("message",this.hiMessageHandler),this.hiMessageHandler=e=>{if("connect_hi"===e.data.type&&e.data.port){const s=e.data.port;s.start?.(),h((t=>new Proxy(t,{get(t,e,s){const n=Reflect.get(t,e,s);return void 0!==n?n:(...t)=>{}}}))(t),s)}},window.addEventListener("message",this.hiMessageHandler)}static async _create(t,e,s,n){return new Promise(async(r,i)=>{try{const i=S((()=>{const t=(t=>JSON.parse(JSON.stringify(t)))(I);t.locale||(t.locale=((t=null)=>{const e=window.navigator;if(t)return t.substr(0,2);if(Array.isArray(e.languages)&&e.languages.length>0)return e.languages[0].substr(0,2);for(let t=0,s=T.length;t<s;t++){const s=e[T[t]];if(s)return s.substr(0,2)}return"en"})()),"(idle)"===t.id&&delete t.id;const e=(()=>{const t=(()=>{try{return window.self!==window.top}catch{return!0}})();let e=window.location.href;if(t){if(!document.referrer)return null;e=document.referrer}const{hostname:s}=new URL(e);return s})();return e&&(t=>!!(E.includes(t)||t.endsWith("roomle.com")||t.endsWith("gitlab.io")||t.endsWith("gitlab.com")))(e)&&(t.configuratorId="demoConfigurator"),t.customApiUrl=void 0,t.emails=!1,t})(),(t=>(C(t),t?.customApiUrl&&(t.customApiUrl=decodeURIComponent(t.customApiUrl)),t.shareUrl&&(t.deeplink=t.shareUrl.replace("<CONF_ID>","#CONFIGURATIONID#")),t))(s));(t=>{t.featureFlags||(t.featureFlags={}),"boolean"!=typeof t.featureFlags.realPartList&&(t.featureFlags.realPartList=!0),"boolean"!=typeof t.featureFlags.globalCallbacks&&(t.featureFlags.globalCallbacks=!0),"boolean"!=typeof t.featureFlags.mocAr&&(t.featureFlags.mocAr=!1)})(i);const a=await(async(t,e)=>{if("string"!=typeof t)throw new Error('Configurator ID is not a string type: "'+typeof t+'"');const s=e.customApiUrl?e.customApiUrl:"https://api.roomle.com/v2",n=e.overrideTenant||9,r=s+"/configurators/"+t,i="roomle_portal_v2",a="03-"+window.btoa((new Date).toISOString()+";anonymous;"+i),o=new Request(r,{method:"GET",headers:new Headers({apiKey:i,currentTenant:n,locale:"en",language:"en",device:1,token:a,platform:"web"}),mode:"cors",cache:"default"}),l=await fetch(o),{configurator:c}=await l.json();return c})(t,i);s=((t,e)=>{e.configuratorId=t.id;const s=t.settings||{};return!e.overrideTenant&&t.tenant&&(e.overrideTenant=t.tenant),((t,e)=>{const s=JSON.parse(JSON.stringify(t));return S(s,e)})(s,e)})(a,i);const o=new this(a,e,s,n,r);return await Promise.allSettled(o.pluginsLoaded),o}catch(t){return i(t)}})}_waitForIframe;_container;_configuratorSettings;_initData={};_iframe;constructor(e,s,n,r,i){if(super(),!e||"string"!=typeof e.id)throw new Error("Please provide a correct configuratorId, you get the correct ID from your Roomle Contact Person");if(j.has(s))throw new Error("There is already an instance on this DOM element");if(!document.getElementById(k)){const t=n.zIndex||9999999,e=document.createElement("style");e.type="text/css",e.id=k;const s="transition:all ease-in-out 450ms;",r=["-webkit-","-o-"].reduce((t,e)=>t+(e+s),"")+s,i=B();e.innerHTML=`\n .${R}{${N}:${i};}\n .${G}{position:fixed;top:0;left:0;z-index:${t};opacity:0}\n .rml-transition{${r}}\n .${U}{width:100%;height:100%;opacity:1}\n .${X}{height:calc(var(${N},1vh)*100)}\n .${H}{overflow:hidden}\n `,document.head.appendChild(e)}this._executeMessage=this._executeMessage.bind(this);const a=new t("website",window,null,this._executeMessage);this.setMessageHandler(a),this._onResize=this._onResize.bind(this),L()&&window.addEventListener("resize",this._onResize),this._container=s,this._initData=n,this._configuratorSettings=e;const o=this._createIframe();this._onUseFullPage=this._onUseFullPage.bind(this),this._onBackToWebsite=this._onBackToWebsite.bind(this),this._waitForIframe=i,this._container.appendChild(o),this._iframe=o,this.setupPlugins(r,this._iframe),j.set(s,!0)}teardown(){this._container&&j.delete(this._container);const t=this._container.querySelector("iframe");t&&this._container.removeChild(t),window.removeEventListener("resize",this._onResize)}_createIframe(){const t=document.createElement("iframe");let e=this._configuratorSettings?.url||"https://www.roomle.com/t/cp/";return this._initData.useLocalRoomle&&(e=location.href.replace("embedding.html","")),location.href.includes("roomle.gitlab.io")&&(e=location.href.replace("embedding.html","index.html")),this._initData.overrideServerUrl&&(e=this._initData.overrideServerUrl),t.src=e,t.classList.add(R),t.classList.add(U),t}_onResize(){F(this._iframe)}_onUseFullPage(){this._iframe.classList.add(G),document.documentElement.classList.add(H),window.document.body.classList.add(H),L()&&(F(this._iframe),this._iframe.classList.add(X))}_onBackToWebsite(){this._iframe.classList.remove(G),this._iframe.classList.remove(X),document.documentElement.classList.remove(H),window.document.body.classList.remove(H)}_executeMessage({message:t,args:e},s){if(s.source&&s.source===this._iframe?.contentWindow)return"requestBoot"===t?this._messageHandler?(this._messageHandler.setOutgoingMessageBus(s.source),Promise.resolve({result:this._initData})):Promise.resolve({error:"MessageHandler not set"}):"setup"===t?(this.handleSetup(e[0]),P(this.ui.callbacks,"onUseFullPage",this._onUseFullPage),P(this.ui.callbacks,"onBackToWebsite",this._onBackToWebsite),this._waitForIframe(this),setTimeout(()=>{this._messageHandler&&this._messageHandler.sendMessage("websiteReady")},0),Promise.resolve({result:null})):this.executeMessage({message:t,args:e})}}},"object"==typeof exports&&typeof module<"u"?module.exports=e():"function"==typeof define&&define.amd?define(e):((t=typeof globalThis<"u"?globalThis:t||self)["roomle-embedding-lib"]=t["roomle-embedding-lib"]||{},t["roomle-embedding-lib"].umd=t["roomle-embedding-lib"].umd||{},t["roomle-embedding-lib"].umd.min=t["roomle-embedding-lib"].umd.min||{},t["roomle-embedding-lib"].umd.min.js=e());
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { BUTTON_ACTIONS } from '../../configurator/store/ui-state';
|
|
2
2
|
import { EventBus } from '../business-logic/event-bus';
|
|
3
|
-
import { CloseReason, ToggleCallback } from '../utils/types';
|
|
3
|
+
import { CloseReason, Nullable, ToggleCallback } from '../utils/types';
|
|
4
4
|
|
|
5
5
|
declare const _default: import('vue').DefineComponent<{
|
|
6
|
-
onClose: (_action: BUTTON_ACTIONS
|
|
6
|
+
onClose: (_action: Nullable<BUTTON_ACTIONS>, _reason: Nullable<CloseReason>) => void;
|
|
7
7
|
icToggleEvent: EventBus<ToggleCallback>;
|
|
8
8
|
}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{
|
|
9
|
-
onClose: (_action: BUTTON_ACTIONS
|
|
9
|
+
onClose: (_action: Nullable<BUTTON_ACTIONS>, _reason: Nullable<CloseReason>) => void;
|
|
10
10
|
icToggleEvent: EventBus<ToggleCallback>;
|
|
11
11
|
}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
|
|
12
12
|
export default _default;
|
|
@@ -1,15 +1,15 @@
|
|
|
1
1
|
import { BUTTON_ACTIONS } from '../../configurator/store/ui-state';
|
|
2
2
|
import { EventBus } from '../business-logic/event-bus';
|
|
3
|
-
import { CloseReason, ToggleCallback } from '../utils/types';
|
|
3
|
+
import { CloseReason, Nullable, ToggleCallback } from '../utils/types';
|
|
4
4
|
|
|
5
5
|
declare const _default: import('vue').DefineComponent<{
|
|
6
|
-
onClose: (_action: BUTTON_ACTIONS
|
|
7
|
-
embeddedCatalogUrl: string
|
|
6
|
+
onClose: (_action: Nullable<BUTTON_ACTIONS>, _reason: Nullable<CloseReason>) => void;
|
|
7
|
+
embeddedCatalogUrl: Nullable<string>;
|
|
8
8
|
header: string;
|
|
9
9
|
icToggleEvent: EventBus<ToggleCallback>;
|
|
10
10
|
}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{
|
|
11
|
-
onClose: (_action: BUTTON_ACTIONS
|
|
12
|
-
embeddedCatalogUrl: string
|
|
11
|
+
onClose: (_action: Nullable<BUTTON_ACTIONS>, _reason: Nullable<CloseReason>) => void;
|
|
12
|
+
embeddedCatalogUrl: Nullable<string>;
|
|
13
13
|
header: string;
|
|
14
14
|
icToggleEvent: EventBus<ToggleCallback>;
|
|
15
15
|
}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
|
|
@@ -1,24 +1,27 @@
|
|
|
1
1
|
import { BUTTON_ACTIONS } from '../../configurator/store/ui-state';
|
|
2
2
|
import { EventBus } from '../business-logic/event-bus';
|
|
3
|
-
import { CloseReason, ToggleCallback } from '../utils/types';
|
|
3
|
+
import { CloseReason, Nullable, ToggleCallback } from '../utils/types';
|
|
4
|
+
import { PossibleCustomViews } from '../../configurator/embedding/types';
|
|
4
5
|
|
|
5
|
-
declare
|
|
6
|
-
|
|
7
|
-
|
|
6
|
+
declare function __VLS_template(): {
|
|
7
|
+
header?(_: {}): any;
|
|
8
|
+
};
|
|
9
|
+
declare const __VLS_component: import('vue').DefineComponent<{
|
|
10
|
+
onClose: (_action: Nullable<BUTTON_ACTIONS>, _reason: Nullable<CloseReason>) => void;
|
|
11
|
+
embeddedUrl: Nullable<string>;
|
|
8
12
|
icToggleEvent: EventBus<ToggleCallback>;
|
|
9
|
-
customViewName?:
|
|
13
|
+
customViewName?: PossibleCustomViews;
|
|
10
14
|
showHeader?: boolean;
|
|
11
15
|
}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{
|
|
12
|
-
onClose: (_action: BUTTON_ACTIONS
|
|
13
|
-
embeddedUrl: string
|
|
16
|
+
onClose: (_action: Nullable<BUTTON_ACTIONS>, _reason: Nullable<CloseReason>) => void;
|
|
17
|
+
embeddedUrl: Nullable<string>;
|
|
14
18
|
icToggleEvent: EventBus<ToggleCallback>;
|
|
15
|
-
customViewName?:
|
|
19
|
+
customViewName?: PossibleCustomViews;
|
|
16
20
|
showHeader?: boolean;
|
|
17
21
|
}> & Readonly<{}>, {
|
|
18
22
|
showHeader: boolean;
|
|
19
|
-
}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any
|
|
20
|
-
|
|
21
|
-
}>;
|
|
23
|
+
}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
|
|
24
|
+
declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, ReturnType<typeof __VLS_template>>;
|
|
22
25
|
export default _default;
|
|
23
26
|
type __VLS_WithTemplateSlots<T, S> = T & {
|
|
24
27
|
new (): {
|
|
@@ -1,4 +1,10 @@
|
|
|
1
|
-
declare
|
|
1
|
+
declare function __VLS_template(): {
|
|
2
|
+
"placeholder-icon"?(_: {
|
|
3
|
+
runOnClick: (method?: (_expanded?: boolean) => void) => void;
|
|
4
|
+
}): any;
|
|
5
|
+
"expanded-icons"?(_: {}): any;
|
|
6
|
+
};
|
|
7
|
+
declare const __VLS_component: import('vue').DefineComponent<{
|
|
2
8
|
onExpandedChanged?: (_isExpanded: boolean) => void;
|
|
3
9
|
direction?: "right" | "down";
|
|
4
10
|
expandOnClick?: boolean;
|
|
@@ -8,12 +14,8 @@ declare const _default: __VLS_WithTemplateSlots<import('vue').DefineComponent<{
|
|
|
8
14
|
direction?: "right" | "down";
|
|
9
15
|
expandOnClick?: boolean;
|
|
10
16
|
hideIndicatorOnExpand?: boolean;
|
|
11
|
-
}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any
|
|
12
|
-
|
|
13
|
-
runOnClick: (method?: (_expanded?: boolean) => void) => void;
|
|
14
|
-
}): any;
|
|
15
|
-
"expanded-icons"?(_: {}): any;
|
|
16
|
-
}>;
|
|
17
|
+
}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
|
|
18
|
+
declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, ReturnType<typeof __VLS_template>>;
|
|
17
19
|
export default _default;
|
|
18
20
|
type __VLS_WithTemplateSlots<T, S> = T & {
|
|
19
21
|
new (): {
|
|
@@ -9,7 +9,7 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
|
|
|
9
9
|
onClick: PropType<(_payload: MouseEvent) => void>;
|
|
10
10
|
isActive: BooleanConstructor;
|
|
11
11
|
}>> & Readonly<{}>, {
|
|
12
|
-
isActive: boolean;
|
|
13
12
|
isCtaButton: boolean;
|
|
13
|
+
isActive: boolean;
|
|
14
14
|
}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
|
|
15
15
|
export default _default;
|
|
@@ -1,6 +1,8 @@
|
|
|
1
|
-
declare
|
|
1
|
+
declare function __VLS_template(): {
|
|
2
2
|
default?(_: {}): any;
|
|
3
|
-
}
|
|
3
|
+
};
|
|
4
|
+
declare const __VLS_component: import('vue').DefineComponent<{}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
|
|
5
|
+
declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, ReturnType<typeof __VLS_template>>;
|
|
4
6
|
export default _default;
|
|
5
7
|
type __VLS_WithTemplateSlots<T, S> = T & {
|
|
6
8
|
new (): {
|
|
@@ -1,12 +1,14 @@
|
|
|
1
|
-
declare
|
|
2
|
-
environment: string;
|
|
3
|
-
}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{
|
|
4
|
-
environment: string;
|
|
5
|
-
}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>, {
|
|
1
|
+
declare function __VLS_template(): {
|
|
6
2
|
"stage-scene-view-port"?(_: {}): any;
|
|
7
3
|
stage?(_: {}): any;
|
|
8
4
|
bottom?(_: {}): any;
|
|
9
|
-
}
|
|
5
|
+
};
|
|
6
|
+
declare const __VLS_component: import('vue').DefineComponent<{
|
|
7
|
+
environment: string;
|
|
8
|
+
}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{
|
|
9
|
+
environment: string;
|
|
10
|
+
}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
|
|
11
|
+
declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, ReturnType<typeof __VLS_template>>;
|
|
10
12
|
export default _default;
|
|
11
13
|
type __VLS_WithTemplateSlots<T, S> = T & {
|
|
12
14
|
new (): {
|
|
@@ -1,4 +1,7 @@
|
|
|
1
|
-
declare
|
|
1
|
+
declare function __VLS_template(): {
|
|
2
|
+
default?(_: {}): any;
|
|
3
|
+
};
|
|
4
|
+
declare const __VLS_component: import('vue').DefineComponent<{
|
|
2
5
|
onClick?: () => void;
|
|
3
6
|
dark?: boolean;
|
|
4
7
|
red?: boolean;
|
|
@@ -10,9 +13,8 @@ declare const _default: __VLS_WithTemplateSlots<import('vue').DefineComponent<{
|
|
|
10
13
|
red?: boolean;
|
|
11
14
|
svgBigger?: boolean;
|
|
12
15
|
active?: boolean;
|
|
13
|
-
}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any
|
|
14
|
-
|
|
15
|
-
}>;
|
|
16
|
+
}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
|
|
17
|
+
declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, ReturnType<typeof __VLS_template>>;
|
|
16
18
|
export default _default;
|
|
17
19
|
type __VLS_WithTemplateSlots<T, S> = T & {
|
|
18
20
|
new (): {
|
|
@@ -1,19 +1,21 @@
|
|
|
1
|
-
import { CustomViewSettingsForIframe } from '../../configurator/embedding/types';
|
|
1
|
+
import { CustomViewSettingsForIframe, PossibleCustomViews } from '../../configurator/embedding/types';
|
|
2
2
|
|
|
3
|
-
declare
|
|
4
|
-
|
|
3
|
+
declare function __VLS_template(): {
|
|
4
|
+
customView?(_: {
|
|
5
|
+
settings: CustomViewSettingsForIframe<any>;
|
|
6
|
+
}): any;
|
|
7
|
+
regularView?(_: {}): any;
|
|
8
|
+
};
|
|
9
|
+
declare const __VLS_component: import('vue').DefineComponent<{
|
|
10
|
+
customViewName: PossibleCustomViews;
|
|
5
11
|
forceCustomView?: boolean;
|
|
6
12
|
}, {
|
|
7
13
|
checkPromise: Promise<boolean>;
|
|
8
14
|
}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{
|
|
9
|
-
customViewName:
|
|
15
|
+
customViewName: PossibleCustomViews;
|
|
10
16
|
forceCustomView?: boolean;
|
|
11
|
-
}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any
|
|
12
|
-
|
|
13
|
-
settings: CustomViewSettingsForIframe<any>;
|
|
14
|
-
}): any;
|
|
15
|
-
regularView?(_: {}): any;
|
|
16
|
-
}>;
|
|
17
|
+
}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
|
|
18
|
+
declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, ReturnType<typeof __VLS_template>>;
|
|
17
19
|
export default _default;
|
|
18
20
|
type __VLS_WithTemplateSlots<T, S> = T & {
|
|
19
21
|
new (): {
|
|
@@ -1,4 +1,12 @@
|
|
|
1
|
-
declare
|
|
1
|
+
declare function __VLS_template(): {
|
|
2
|
+
firstOption?(_: {
|
|
3
|
+
active: boolean;
|
|
4
|
+
}): any;
|
|
5
|
+
secondOption?(_: {
|
|
6
|
+
active: boolean;
|
|
7
|
+
}): any;
|
|
8
|
+
};
|
|
9
|
+
declare const __VLS_component: import('vue').DefineComponent<{
|
|
2
10
|
switch?: (clickedOption: 1 | 2) => void;
|
|
3
11
|
initialActive?: number;
|
|
4
12
|
hasIcons?: boolean;
|
|
@@ -6,14 +14,8 @@ declare const _default: __VLS_WithTemplateSlots<import('vue').DefineComponent<{
|
|
|
6
14
|
switch?: (clickedOption: 1 | 2) => void;
|
|
7
15
|
initialActive?: number;
|
|
8
16
|
hasIcons?: boolean;
|
|
9
|
-
}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any
|
|
10
|
-
|
|
11
|
-
active: boolean;
|
|
12
|
-
}): any;
|
|
13
|
-
secondOption?(_: {
|
|
14
|
-
active: boolean;
|
|
15
|
-
}): any;
|
|
16
|
-
}>;
|
|
17
|
+
}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
|
|
18
|
+
declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, ReturnType<typeof __VLS_template>>;
|
|
17
19
|
export default _default;
|
|
18
20
|
type __VLS_WithTemplateSlots<T, S> = T & {
|
|
19
21
|
new (): {
|
|
@@ -1,7 +1,28 @@
|
|
|
1
1
|
import { ComponentPublicInstance, CSSProperties } from 'vue';
|
|
2
2
|
|
|
3
|
-
declare
|
|
4
|
-
|
|
3
|
+
declare function __VLS_template(): Readonly<{
|
|
4
|
+
target(_props: {
|
|
5
|
+
setTarget: (_el: ComponentPublicInstance | Element) => void;
|
|
6
|
+
show: () => void;
|
|
7
|
+
toggle: () => void;
|
|
8
|
+
}): any;
|
|
9
|
+
content(_props: {
|
|
10
|
+
name?: string | undefined;
|
|
11
|
+
hide: (_immediate: boolean) => void;
|
|
12
|
+
}): any;
|
|
13
|
+
}> & {
|
|
14
|
+
target(_props: {
|
|
15
|
+
setTarget: (_el: ComponentPublicInstance | Element) => void;
|
|
16
|
+
show: () => void;
|
|
17
|
+
toggle: () => void;
|
|
18
|
+
}): any;
|
|
19
|
+
content(_props: {
|
|
20
|
+
name?: string | undefined;
|
|
21
|
+
hide: (_immediate: boolean) => void;
|
|
22
|
+
}): any;
|
|
23
|
+
};
|
|
24
|
+
declare const __VLS_component: import('vue').DefineComponent<{
|
|
25
|
+
placement?: "top" | "bottom" | "left" | "right";
|
|
5
26
|
offsetPx?: number;
|
|
6
27
|
axisOffsetPx?: number;
|
|
7
28
|
arrowPx?: number;
|
|
@@ -18,7 +39,7 @@ declare const _default: __VLS_WithTemplateSlots<import('vue').DefineComponent<{
|
|
|
18
39
|
noPadding?: boolean;
|
|
19
40
|
autoWidth?: boolean;
|
|
20
41
|
}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{
|
|
21
|
-
placement?: "
|
|
42
|
+
placement?: "top" | "bottom" | "left" | "right";
|
|
22
43
|
offsetPx?: number;
|
|
23
44
|
axisOffsetPx?: number;
|
|
24
45
|
arrowPx?: number;
|
|
@@ -34,27 +55,8 @@ declare const _default: __VLS_WithTemplateSlots<import('vue').DefineComponent<{
|
|
|
34
55
|
disableTeleport?: boolean;
|
|
35
56
|
noPadding?: boolean;
|
|
36
57
|
autoWidth?: boolean;
|
|
37
|
-
}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any
|
|
38
|
-
|
|
39
|
-
setTarget: (_el: Element | ComponentPublicInstance) => void;
|
|
40
|
-
show: () => void;
|
|
41
|
-
toggle: () => void;
|
|
42
|
-
}): any;
|
|
43
|
-
content(_props: {
|
|
44
|
-
name?: string;
|
|
45
|
-
hide: (_immediate: boolean) => void;
|
|
46
|
-
}): any;
|
|
47
|
-
}> & {
|
|
48
|
-
target(_props: {
|
|
49
|
-
setTarget: (_el: Element | ComponentPublicInstance) => void;
|
|
50
|
-
show: () => void;
|
|
51
|
-
toggle: () => void;
|
|
52
|
-
}): any;
|
|
53
|
-
content(_props: {
|
|
54
|
-
name?: string;
|
|
55
|
-
hide: (_immediate: boolean) => void;
|
|
56
|
-
}): any;
|
|
57
|
-
}>;
|
|
58
|
+
}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
|
|
59
|
+
declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, ReturnType<typeof __VLS_template>>;
|
|
58
60
|
export default _default;
|
|
59
61
|
type __VLS_WithTemplateSlots<T, S> = T & {
|
|
60
62
|
new (): {
|
|
@@ -1,4 +1,7 @@
|
|
|
1
|
-
declare
|
|
1
|
+
declare function __VLS_template(): {
|
|
2
|
+
default?(_: {}): any;
|
|
3
|
+
};
|
|
4
|
+
declare const __VLS_component: import('vue').DefineComponent<{
|
|
2
5
|
onClick: (_payload: MouseEvent) => void;
|
|
3
6
|
dark?: boolean;
|
|
4
7
|
circle?: boolean;
|
|
@@ -10,9 +13,8 @@ declare const _default: __VLS_WithTemplateSlots<import('vue').DefineComponent<{
|
|
|
10
13
|
dark?: boolean;
|
|
11
14
|
circle?: boolean;
|
|
12
15
|
svgBigger?: boolean;
|
|
13
|
-
}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any
|
|
14
|
-
|
|
15
|
-
}>;
|
|
16
|
+
}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
|
|
17
|
+
declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, ReturnType<typeof __VLS_template>>;
|
|
16
18
|
export default _default;
|
|
17
19
|
type __VLS_WithTemplateSlots<T, S> = T & {
|
|
18
20
|
new (): {
|
|
@@ -3,9 +3,9 @@ import { CssHash } from '../../utils/types';
|
|
|
3
3
|
|
|
4
4
|
declare const _default: import('vue').DefineComponent<{
|
|
5
5
|
pointerPos: UsePointerPosReturn;
|
|
6
|
-
menuPosition: CssHash;
|
|
6
|
+
menuPosition: CssHash | null;
|
|
7
7
|
}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{
|
|
8
8
|
pointerPos: UsePointerPosReturn;
|
|
9
|
-
menuPosition: CssHash;
|
|
9
|
+
menuPosition: CssHash | null;
|
|
10
10
|
}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
|
|
11
11
|
export default _default;
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { StoreState } from '../store';
|
|
2
2
|
import { ExposedCallbacks } from '../../configurator/embedding/exposed-callbacks';
|
|
3
|
+
import { Store } from 'vuex';
|
|
3
4
|
import { PopUpAlignment } from '../../configurator/components/utils/-utils/popup-types';
|
|
4
5
|
|
|
5
6
|
export declare const startARMode: (embeddingCallbacks: ExposedCallbacks, store: Store<StoreState>, fromTopBar?: boolean) => Promise<void>;
|
|
@@ -1,12 +1,14 @@
|
|
|
1
|
-
declare
|
|
1
|
+
declare function __VLS_template(): {
|
|
2
|
+
default?(_: {}): any;
|
|
3
|
+
};
|
|
4
|
+
declare const __VLS_component: import('vue').DefineComponent<{
|
|
2
5
|
valueLabel: string;
|
|
3
6
|
centerText?: boolean;
|
|
4
7
|
}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{
|
|
5
8
|
valueLabel: string;
|
|
6
9
|
centerText?: boolean;
|
|
7
|
-
}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any
|
|
8
|
-
|
|
9
|
-
}>;
|
|
10
|
+
}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
|
|
11
|
+
declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, ReturnType<typeof __VLS_template>>;
|
|
10
12
|
export default _default;
|
|
11
13
|
type __VLS_WithTemplateSlots<T, S> = T & {
|
|
12
14
|
new (): {
|
|
@@ -6,13 +6,13 @@ export interface SelectDropdownOptions {
|
|
|
6
6
|
}
|
|
7
7
|
declare const _default: import('vue').DefineComponent<{
|
|
8
8
|
options: SelectDropdownOptions[];
|
|
9
|
-
selected: any;
|
|
9
|
+
selected: any | null;
|
|
10
10
|
tabindex: number;
|
|
11
11
|
}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {} & {
|
|
12
12
|
change: (_value: any) => any;
|
|
13
13
|
}, string, import('vue').PublicProps, Readonly<{
|
|
14
14
|
options: SelectDropdownOptions[];
|
|
15
|
-
selected: any;
|
|
15
|
+
selected: any | null;
|
|
16
16
|
tabindex: number;
|
|
17
17
|
}> & Readonly<{
|
|
18
18
|
onChange?: (_value: any) => any;
|
|
@@ -1,4 +1,7 @@
|
|
|
1
|
-
declare
|
|
1
|
+
declare function __VLS_template(): {
|
|
2
|
+
default?(_: {}): any;
|
|
3
|
+
};
|
|
4
|
+
declare const __VLS_component: import('vue').DefineComponent<{
|
|
2
5
|
close: () => void;
|
|
3
6
|
isSwipe?: boolean;
|
|
4
7
|
isNoteCard?: boolean;
|
|
@@ -8,9 +11,8 @@ declare const _default: __VLS_WithTemplateSlots<import('vue').DefineComponent<{
|
|
|
8
11
|
isSwipe?: boolean;
|
|
9
12
|
isNoteCard?: boolean;
|
|
10
13
|
isWarning?: boolean;
|
|
11
|
-
}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any
|
|
12
|
-
|
|
13
|
-
}>;
|
|
14
|
+
}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
|
|
15
|
+
declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, ReturnType<typeof __VLS_template>>;
|
|
14
16
|
export default _default;
|
|
15
17
|
type __VLS_WithTemplateSlots<T, S> = T & {
|
|
16
18
|
new (): {
|