@makeswift/runtime 0.26.5 → 0.26.6
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/dist/cjs/api-handler/handlers/manifest.js +1 -1
- package/dist/cjs/client/index.js +3 -3
- package/dist/esm/api-handler/handlers/manifest.js +1 -1
- package/dist/esm/client/index.js +3 -3
- package/package.json +3 -3
- package/dist/cjs/api/client.js +0 -252
- package/dist/cjs/api/client.js.map +0 -1
- package/dist/cjs/api-handler/handlers/webhook/diff-projection.js +0 -62
- package/dist/cjs/api-handler/handlers/webhook/diff-projection.js.map +0 -1
- package/dist/cjs/builder/serialization.js +0 -78
- package/dist/cjs/builder/serialization.js.map +0 -1
- package/dist/cjs/controls/serialization/base/index.js +0 -78
- package/dist/cjs/controls/serialization/base/index.js.map +0 -1
- package/dist/cjs/controls/serialization/base/visitor.js +0 -59
- package/dist/cjs/controls/serialization/base/visitor.js.map +0 -1
- package/dist/cjs/controls/serialization/index.js +0 -55
- package/dist/cjs/controls/serialization/index.js.map +0 -1
- package/dist/cjs/controls/serialization/message-port/function-serialization.js +0 -79
- package/dist/cjs/controls/serialization/message-port/function-serialization.js.map +0 -1
- package/dist/cjs/controls/serialization/message-port/index.js +0 -25
- package/dist/cjs/controls/serialization/message-port/index.js.map +0 -1
- package/dist/cjs/controls/serialization/message-port/visitor.js +0 -48
- package/dist/cjs/controls/serialization/message-port/visitor.js.map +0 -1
- package/dist/cjs/next/fetch.js +0 -30
- package/dist/cjs/next/fetch.js.map +0 -1
- package/dist/cjs/next/runtime.js +0 -35
- package/dist/cjs/next/runtime.js.map +0 -1
- package/dist/cjs/next/testing/react-runtime.js +0 -29
- package/dist/cjs/next/testing/react-runtime.js.map +0 -1
- package/dist/cjs/prop-controllers/serialization.js +0 -355
- package/dist/cjs/prop-controllers/serialization.js.map +0 -1
- package/dist/cjs/runtimes/react/components/GoogleFontLink.js +0 -55
- package/dist/cjs/runtimes/react/components/GoogleFontLink.js.map +0 -1
- package/dist/cjs/runtimes/react/components/MakeswiftFonts.js +0 -33
- package/dist/cjs/runtimes/react/components/MakeswiftFonts.js.map +0 -1
- package/dist/cjs/runtimes/react/hooks/use-async-effect.js +0 -55
- package/dist/cjs/runtimes/react/hooks/use-async-effect.js.map +0 -1
- package/dist/cjs/runtimes/react/hooks/use-current-breakpoint.js +0 -39
- package/dist/cjs/runtimes/react/hooks/use-current-breakpoint.js.map +0 -1
- package/dist/cjs/runtimes/react/hooks/use-is-read-only.js +0 -33
- package/dist/cjs/runtimes/react/hooks/use-is-read-only.js.map +0 -1
- package/dist/cjs/runtimes/react/lib/resolved-style-to-css.js +0 -59
- package/dist/cjs/runtimes/react/lib/resolved-style-to-css.js.map +0 -1
- package/dist/cjs/runtimes/react/testing/react-runtime.js +0 -33
- package/dist/cjs/runtimes/react/testing/react-runtime.js.map +0 -1
- package/dist/cjs/runtimes/react/utils/google-fonts-url.js +0 -49
- package/dist/cjs/runtimes/react/utils/google-fonts-url.js.map +0 -1
- package/dist/cjs/state/actions/internal/index.js +0 -34
- package/dist/cjs/state/actions/internal/index.js.map +0 -1
- package/dist/cjs/state/actions/internal/read-only-actions.js +0 -195
- package/dist/cjs/state/actions/internal/read-only-actions.js.map +0 -1
- package/dist/cjs/state/actions/internal/read-write-actions.js +0 -76
- package/dist/cjs/state/actions/internal/read-write-actions.js.map +0 -1
- package/dist/cjs/state/builder-api/api.js +0 -17
- package/dist/cjs/state/builder-api/api.js.map +0 -1
- package/dist/cjs/state/builder-api/navigation-listener.js +0 -110
- package/dist/cjs/state/builder-api/navigation-listener.js.map +0 -1
- package/dist/cjs/state/middleware/makeswift-api-client-sync.js +0 -37
- package/dist/cjs/state/middleware/makeswift-api-client-sync.js.map +0 -1
- package/dist/cjs/state/middleware/read-only-element-tree.js +0 -52
- package/dist/cjs/state/middleware/read-only-element-tree.js.map +0 -1
- package/dist/cjs/state/middleware/read-write/builder-api/element-size.js +0 -40
- package/dist/cjs/state/middleware/read-write/builder-api/element-size.js.map +0 -1
- package/dist/cjs/state/middleware/read-write/builder-api/index.js +0 -85
- package/dist/cjs/state/middleware/read-write/builder-api/index.js.map +0 -1
- package/dist/cjs/state/middleware/read-write/builder-api/initialize-connection.js +0 -281
- package/dist/cjs/state/middleware/read-write/builder-api/initialize-connection.js.map +0 -1
- package/dist/cjs/state/middleware/read-write/index.js +0 -40
- package/dist/cjs/state/middleware/read-write/index.js.map +0 -1
- package/dist/cjs/state/middleware/read-write/measure-box-models.js +0 -71
- package/dist/cjs/state/middleware/read-write/measure-box-models.js.map +0 -1
- package/dist/cjs/state/middleware/read-write/prop-controller-handles.js +0 -114
- package/dist/cjs/state/middleware/read-write/prop-controller-handles.js.map +0 -1
- package/dist/cjs/state/middleware/read-write/update-element-tree.js +0 -59
- package/dist/cjs/state/middleware/read-write/update-element-tree.js.map +0 -1
- package/dist/cjs/state/mixins/breakpoint-watch.js +0 -72
- package/dist/cjs/state/mixins/breakpoint-watch.js.map +0 -1
- package/dist/cjs/state/modules/is-read-only.js +0 -50
- package/dist/cjs/state/modules/is-read-only.js.map +0 -1
- package/dist/cjs/state/modules/locale.js +0 -50
- package/dist/cjs/state/modules/locale.js.map +0 -1
- package/dist/cjs/state/modules/read-write/box-models.js +0 -144
- package/dist/cjs/state/modules/read-write/box-models.js.map +0 -1
- package/dist/cjs/state/modules/read-write/element-imperative-handles.js +0 -61
- package/dist/cjs/state/modules/read-write/element-imperative-handles.js.map +0 -1
- package/dist/cjs/state/modules/read-write/pointer.js +0 -48
- package/dist/cjs/state/modules/read-write/pointer.js.map +0 -1
- package/dist/cjs/state/modules/read-write/read-write-documents.js +0 -98
- package/dist/cjs/state/modules/read-write/read-write-documents.js.map +0 -1
- package/dist/cjs/state/modules/site-version.js +0 -47
- package/dist/cjs/state/modules/site-version.js.map +0 -1
- package/dist/cjs/state/ops/copy-element-tree.js +0 -67
- package/dist/cjs/state/ops/copy-element-tree.js.map +0 -1
- package/dist/cjs/state/ops/merge-element.js +0 -73
- package/dist/cjs/state/ops/merge-element.js.map +0 -1
- package/dist/cjs/state/read-only-state.js +0 -231
- package/dist/cjs/state/read-only-state.js.map +0 -1
- package/dist/cjs/state/read-write-state.js +0 -128
- package/dist/cjs/state/read-write-state.js.map +0 -1
- package/dist/cjs/state/store.js +0 -219
- package/dist/cjs/state/store.js.map +0 -1
- package/dist/cjs/state/unified-state.js +0 -17
- package/dist/cjs/state/unified-state.js.map +0 -1
- package/dist/cjs/translations/index.js +0 -32
- package/dist/cjs/translations/index.js.map +0 -1
- package/dist/cjs/utils/deferred.js +0 -39
- package/dist/cjs/utils/deferred.js.map +0 -1
- package/dist/cjs/utils/ref-counted-map.js +0 -120
- package/dist/cjs/utils/ref-counted-map.js.map +0 -1
- package/dist/esm/api/client.js +0 -219
- package/dist/esm/api/client.js.map +0 -1
- package/dist/esm/api-handler/handlers/webhook/diff-projection.js +0 -38
- package/dist/esm/api-handler/handlers/webhook/diff-projection.js.map +0 -1
- package/dist/esm/builder/serialization.js +0 -59
- package/dist/esm/builder/serialization.js.map +0 -1
- package/dist/esm/controls/serialization/base/index.js +0 -78
- package/dist/esm/controls/serialization/base/index.js.map +0 -1
- package/dist/esm/controls/serialization/base/visitor.js +0 -39
- package/dist/esm/controls/serialization/base/visitor.js.map +0 -1
- package/dist/esm/controls/serialization/index.js +0 -30
- package/dist/esm/controls/serialization/index.js.map +0 -1
- package/dist/esm/controls/serialization/message-port/function-serialization.js +0 -52
- package/dist/esm/controls/serialization/message-port/function-serialization.js.map +0 -1
- package/dist/esm/controls/serialization/message-port/index.js +0 -3
- package/dist/esm/controls/serialization/message-port/index.js.map +0 -1
- package/dist/esm/controls/serialization/message-port/visitor.js +0 -24
- package/dist/esm/controls/serialization/message-port/visitor.js.map +0 -1
- package/dist/esm/next/fetch.js +0 -6
- package/dist/esm/next/fetch.js.map +0 -1
- package/dist/esm/next/runtime.js +0 -11
- package/dist/esm/next/runtime.js.map +0 -1
- package/dist/esm/next/testing/react-runtime.js +0 -5
- package/dist/esm/next/testing/react-runtime.js.map +0 -1
- package/dist/esm/prop-controllers/serialization.js +0 -338
- package/dist/esm/prop-controllers/serialization.js.map +0 -1
- package/dist/esm/runtimes/react/components/GoogleFontLink.js +0 -35
- package/dist/esm/runtimes/react/components/GoogleFontLink.js.map +0 -1
- package/dist/esm/runtimes/react/components/MakeswiftFonts.js +0 -9
- package/dist/esm/runtimes/react/components/MakeswiftFonts.js.map +0 -1
- package/dist/esm/runtimes/react/hooks/use-async-effect.js +0 -31
- package/dist/esm/runtimes/react/hooks/use-async-effect.js.map +0 -1
- package/dist/esm/runtimes/react/hooks/use-current-breakpoint.js +0 -15
- package/dist/esm/runtimes/react/hooks/use-current-breakpoint.js.map +0 -1
- package/dist/esm/runtimes/react/hooks/use-is-read-only.js +0 -9
- package/dist/esm/runtimes/react/hooks/use-is-read-only.js.map +0 -1
- package/dist/esm/runtimes/react/lib/resolved-style-to-css.js +0 -38
- package/dist/esm/runtimes/react/lib/resolved-style-to-css.js.map +0 -1
- package/dist/esm/runtimes/react/testing/react-runtime.js +0 -9
- package/dist/esm/runtimes/react/testing/react-runtime.js.map +0 -1
- package/dist/esm/runtimes/react/utils/google-fonts-url.js +0 -23
- package/dist/esm/runtimes/react/utils/google-fonts-url.js.map +0 -1
- package/dist/esm/state/actions/internal/index.js +0 -10
- package/dist/esm/state/actions/internal/index.js.map +0 -1
- package/dist/esm/state/actions/internal/read-only-actions.js +0 -153
- package/dist/esm/state/actions/internal/read-only-actions.js.map +0 -1
- package/dist/esm/state/actions/internal/read-write-actions.js +0 -46
- package/dist/esm/state/actions/internal/read-write-actions.js.map +0 -1
- package/dist/esm/state/builder-api/api.js +0 -1
- package/dist/esm/state/builder-api/api.js.map +0 -1
- package/dist/esm/state/builder-api/navigation-listener.js +0 -86
- package/dist/esm/state/builder-api/navigation-listener.js.map +0 -1
- package/dist/esm/state/middleware/makeswift-api-client-sync.js +0 -13
- package/dist/esm/state/middleware/makeswift-api-client-sync.js.map +0 -1
- package/dist/esm/state/middleware/read-only-element-tree.js +0 -28
- package/dist/esm/state/middleware/read-only-element-tree.js.map +0 -1
- package/dist/esm/state/middleware/read-write/builder-api/element-size.js +0 -16
- package/dist/esm/state/middleware/read-write/builder-api/element-size.js.map +0 -1
- package/dist/esm/state/middleware/read-write/builder-api/index.js +0 -61
- package/dist/esm/state/middleware/read-write/builder-api/index.js.map +0 -1
- package/dist/esm/state/middleware/read-write/builder-api/initialize-connection.js +0 -254
- package/dist/esm/state/middleware/read-write/builder-api/initialize-connection.js.map +0 -1
- package/dist/esm/state/middleware/read-write/index.js +0 -16
- package/dist/esm/state/middleware/read-write/index.js.map +0 -1
- package/dist/esm/state/middleware/read-write/measure-box-models.js +0 -37
- package/dist/esm/state/middleware/read-write/measure-box-models.js.map +0 -1
- package/dist/esm/state/middleware/read-write/prop-controller-handles.js +0 -80
- package/dist/esm/state/middleware/read-write/prop-controller-handles.js.map +0 -1
- package/dist/esm/state/middleware/read-write/update-element-tree.js +0 -35
- package/dist/esm/state/middleware/read-write/update-element-tree.js.map +0 -1
- package/dist/esm/state/mixins/breakpoint-watch.js +0 -48
- package/dist/esm/state/mixins/breakpoint-watch.js.map +0 -1
- package/dist/esm/state/modules/is-read-only.js +0 -24
- package/dist/esm/state/modules/is-read-only.js.map +0 -1
- package/dist/esm/state/modules/locale.js +0 -24
- package/dist/esm/state/modules/locale.js.map +0 -1
- package/dist/esm/state/modules/read-write/box-models.js +0 -114
- package/dist/esm/state/modules/read-write/box-models.js.map +0 -1
- package/dist/esm/state/modules/read-write/element-imperative-handles.js +0 -36
- package/dist/esm/state/modules/read-write/element-imperative-handles.js.map +0 -1
- package/dist/esm/state/modules/read-write/pointer.js +0 -23
- package/dist/esm/state/modules/read-write/pointer.js.map +0 -1
- package/dist/esm/state/modules/read-write/read-write-documents.js +0 -60
- package/dist/esm/state/modules/read-write/read-write-documents.js.map +0 -1
- package/dist/esm/state/modules/site-version.js +0 -21
- package/dist/esm/state/modules/site-version.js.map +0 -1
- package/dist/esm/state/ops/copy-element-tree.js +0 -37
- package/dist/esm/state/ops/copy-element-tree.js.map +0 -1
- package/dist/esm/state/ops/merge-element.js +0 -39
- package/dist/esm/state/ops/merge-element.js.map +0 -1
- package/dist/esm/state/read-only-state.js +0 -176
- package/dist/esm/state/read-only-state.js.map +0 -1
- package/dist/esm/state/read-write-state.js +0 -82
- package/dist/esm/state/read-write-state.js.map +0 -1
- package/dist/esm/state/store.js +0 -188
- package/dist/esm/state/store.js.map +0 -1
- package/dist/esm/state/unified-state.js +0 -1
- package/dist/esm/state/unified-state.js.map +0 -1
- package/dist/esm/translations/index.js +0 -7
- package/dist/esm/translations/index.js.map +0 -1
- package/dist/esm/utils/deferred.js +0 -15
- package/dist/esm/utils/deferred.js.map +0 -1
- package/dist/esm/utils/ref-counted-map.js +0 -96
- package/dist/esm/utils/ref-counted-map.js.map +0 -1
- package/dist/types/api/client.d.ts +0 -81
- package/dist/types/api/client.d.ts.map +0 -1
- package/dist/types/api-handler/handlers/webhook/diff-projection.d.ts +0 -201
- package/dist/types/api-handler/handlers/webhook/diff-projection.d.ts.map +0 -1
- package/dist/types/builder/serialization.d.ts +0 -23
- package/dist/types/builder/serialization.d.ts.map +0 -1
- package/dist/types/builder/serialization.test.d.ts +0 -2
- package/dist/types/builder/serialization.test.d.ts.map +0 -1
- package/dist/types/client/tests/client.get-component-snapshots.test.d.ts +0 -2
- package/dist/types/client/tests/client.get-component-snapshots.test.d.ts.map +0 -1
- package/dist/types/client/tests/client.get-fonts.test.d.ts +0 -2
- package/dist/types/client/tests/client.get-fonts.test.d.ts.map +0 -1
- package/dist/types/client/tests/client.introspect-many.test.d.ts +0 -2
- package/dist/types/client/tests/client.introspect-many.test.d.ts.map +0 -1
- package/dist/types/components/hooks/__tests__/useMediaQuery.test.d.ts +0 -3
- package/dist/types/components/hooks/__tests__/useMediaQuery.test.d.ts.map +0 -1
- package/dist/types/controls/serialization/base/index.d.ts +0 -10
- package/dist/types/controls/serialization/base/index.d.ts.map +0 -1
- package/dist/types/controls/serialization/base/visitor.d.ts +0 -7
- package/dist/types/controls/serialization/base/visitor.d.ts.map +0 -1
- package/dist/types/controls/serialization/index.d.ts +0 -10
- package/dist/types/controls/serialization/index.d.ts.map +0 -1
- package/dist/types/controls/serialization/message-port/function-serialization.d.ts +0 -16
- package/dist/types/controls/serialization/message-port/function-serialization.d.ts.map +0 -1
- package/dist/types/controls/serialization/message-port/function-serialization.test.d.ts +0 -2
- package/dist/types/controls/serialization/message-port/function-serialization.test.d.ts.map +0 -1
- package/dist/types/controls/serialization/message-port/index.d.ts +0 -3
- package/dist/types/controls/serialization/message-port/index.d.ts.map +0 -1
- package/dist/types/controls/serialization/message-port/visitor.d.ts +0 -7
- package/dist/types/controls/serialization/message-port/visitor.d.ts.map +0 -1
- package/dist/types/next/api-handler/config/pages-router.test.d.ts +0 -2
- package/dist/types/next/api-handler/config/pages-router.test.d.ts.map +0 -1
- package/dist/types/next/components/tests/controls/code-control.test.d.ts +0 -2
- package/dist/types/next/components/tests/controls/code-control.test.d.ts.map +0 -1
- package/dist/types/next/fetch.d.ts +0 -3
- package/dist/types/next/fetch.d.ts.map +0 -1
- package/dist/types/next/runtime.d.ts +0 -10
- package/dist/types/next/runtime.d.ts.map +0 -1
- package/dist/types/next/testing/react-runtime.d.ts +0 -2
- package/dist/types/next/testing/react-runtime.d.ts.map +0 -1
- package/dist/types/prop-controllers/serialization.d.ts +0 -228
- package/dist/types/prop-controllers/serialization.d.ts.map +0 -1
- package/dist/types/runtimes/react/components/GoogleFontLink.d.ts +0 -14
- package/dist/types/runtimes/react/components/GoogleFontLink.d.ts.map +0 -1
- package/dist/types/runtimes/react/components/MakeswiftFonts.d.ts +0 -7
- package/dist/types/runtimes/react/components/MakeswiftFonts.d.ts.map +0 -1
- package/dist/types/runtimes/react/hooks/__tests__/use-async-effect.test.d.ts +0 -2
- package/dist/types/runtimes/react/hooks/__tests__/use-async-effect.test.d.ts.map +0 -1
- package/dist/types/runtimes/react/hooks/use-async-effect.d.ts +0 -3
- package/dist/types/runtimes/react/hooks/use-async-effect.d.ts.map +0 -1
- package/dist/types/runtimes/react/hooks/use-current-breakpoint.d.ts +0 -3
- package/dist/types/runtimes/react/hooks/use-current-breakpoint.d.ts.map +0 -1
- package/dist/types/runtimes/react/hooks/use-is-read-only.d.ts +0 -2
- package/dist/types/runtimes/react/hooks/use-is-read-only.d.ts.map +0 -1
- package/dist/types/runtimes/react/lib/resolved-style-to-css.d.ts +0 -4
- package/dist/types/runtimes/react/lib/resolved-style-to-css.d.ts.map +0 -1
- package/dist/types/runtimes/react/testing/react-runtime.d.ts +0 -6
- package/dist/types/runtimes/react/testing/react-runtime.d.ts.map +0 -1
- package/dist/types/runtimes/react/utils/google-fonts-url.d.ts +0 -6
- package/dist/types/runtimes/react/utils/google-fonts-url.d.ts.map +0 -1
- package/dist/types/state/__tests__/fixtures/serialized-descriptors-from-builder.d.ts +0 -5
- package/dist/types/state/__tests__/fixtures/serialized-descriptors-from-builder.d.ts.map +0 -1
- package/dist/types/state/__tests__/fixtures/translatable-content-sample.d.ts +0 -3
- package/dist/types/state/__tests__/fixtures/translatable-content-sample.d.ts.map +0 -1
- package/dist/types/state/__tests__/get-translatable-content.test.d.ts +0 -2
- package/dist/types/state/__tests__/get-translatable-content.test.d.ts.map +0 -1
- package/dist/types/state/__tests__/merge-element.test.d.ts +0 -2
- package/dist/types/state/__tests__/merge-element.test.d.ts.map +0 -1
- package/dist/types/state/__tests__/store.read-write-state.test.d.ts +0 -2
- package/dist/types/state/__tests__/store.read-write-state.test.d.ts.map +0 -1
- package/dist/types/state/__tests__/test-store.d.ts +0 -31
- package/dist/types/state/__tests__/test-store.d.ts.map +0 -1
- package/dist/types/state/actions/internal/index.d.ts +0 -29
- package/dist/types/state/actions/internal/index.d.ts.map +0 -1
- package/dist/types/state/actions/internal/read-only-actions.d.ts +0 -171
- package/dist/types/state/actions/internal/read-only-actions.d.ts.map +0 -1
- package/dist/types/state/actions/internal/read-write-actions.d.ts +0 -53
- package/dist/types/state/actions/internal/read-write-actions.d.ts.map +0 -1
- package/dist/types/state/builder-api/api.d.ts +0 -9
- package/dist/types/state/builder-api/api.d.ts.map +0 -1
- package/dist/types/state/builder-api/navigation-listener.d.ts +0 -3
- package/dist/types/state/builder-api/navigation-listener.d.ts.map +0 -1
- package/dist/types/state/middleware/makeswift-api-client-sync.d.ts +0 -5
- package/dist/types/state/middleware/makeswift-api-client-sync.d.ts.map +0 -1
- package/dist/types/state/middleware/read-only-element-tree.d.ts +0 -4
- package/dist/types/state/middleware/read-only-element-tree.d.ts.map +0 -1
- package/dist/types/state/middleware/read-write/builder-api/element-size.d.ts +0 -12
- package/dist/types/state/middleware/read-write/builder-api/element-size.d.ts.map +0 -1
- package/dist/types/state/middleware/read-write/builder-api/index.d.ts +0 -5
- package/dist/types/state/middleware/read-write/builder-api/index.d.ts.map +0 -1
- package/dist/types/state/middleware/read-write/builder-api/initialize-connection.d.ts +0 -6
- package/dist/types/state/middleware/read-write/builder-api/initialize-connection.d.ts.map +0 -1
- package/dist/types/state/middleware/read-write/index.d.ts +0 -5
- package/dist/types/state/middleware/read-write/index.d.ts.map +0 -1
- package/dist/types/state/middleware/read-write/measure-box-models.d.ts +0 -4
- package/dist/types/state/middleware/read-write/measure-box-models.d.ts.map +0 -1
- package/dist/types/state/middleware/read-write/prop-controller-handles.d.ts +0 -4
- package/dist/types/state/middleware/read-write/prop-controller-handles.d.ts.map +0 -1
- package/dist/types/state/middleware/read-write/update-element-tree.d.ts +0 -4
- package/dist/types/state/middleware/read-write/update-element-tree.d.ts.map +0 -1
- package/dist/types/state/mixins/breakpoint-watch.d.ts +0 -11
- package/dist/types/state/mixins/breakpoint-watch.d.ts.map +0 -1
- package/dist/types/state/modules/is-read-only.d.ts +0 -6
- package/dist/types/state/modules/is-read-only.d.ts.map +0 -1
- package/dist/types/state/modules/locale.d.ts +0 -6
- package/dist/types/state/modules/locale.d.ts.map +0 -1
- package/dist/types/state/modules/read-write/box-models.d.ts +0 -26
- package/dist/types/state/modules/read-write/box-models.d.ts.map +0 -1
- package/dist/types/state/modules/read-write/element-imperative-handles.d.ts +0 -6
- package/dist/types/state/modules/read-write/element-imperative-handles.d.ts.map +0 -1
- package/dist/types/state/modules/read-write/pointer.d.ts +0 -11
- package/dist/types/state/modules/read-write/pointer.d.ts.map +0 -1
- package/dist/types/state/modules/read-write/read-write-documents.d.ts +0 -14
- package/dist/types/state/modules/read-write/read-write-documents.d.ts.map +0 -1
- package/dist/types/state/modules/site-version.d.ts +0 -7
- package/dist/types/state/modules/site-version.d.ts.map +0 -1
- package/dist/types/state/ops/copy-element-tree.d.ts +0 -37
- package/dist/types/state/ops/copy-element-tree.d.ts.map +0 -1
- package/dist/types/state/ops/merge-element.d.ts +0 -4
- package/dist/types/state/ops/merge-element.d.ts.map +0 -1
- package/dist/types/state/read-only-state.d.ts +0 -131
- package/dist/types/state/read-only-state.d.ts.map +0 -1
- package/dist/types/state/read-write-state.d.ts +0 -62
- package/dist/types/state/read-write-state.d.ts.map +0 -1
- package/dist/types/state/store.d.ts +0 -86
- package/dist/types/state/store.d.ts.map +0 -1
- package/dist/types/state/unified-state.d.ts +0 -9
- package/dist/types/state/unified-state.d.ts.map +0 -1
- package/dist/types/translations/index.d.ts +0 -6
- package/dist/types/translations/index.d.ts.map +0 -1
- package/dist/types/utils/__tests__/ref-counted-map.test.d.ts +0 -2
- package/dist/types/utils/__tests__/ref-counted-map.test.d.ts.map +0 -1
- package/dist/types/utils/deferred.d.ts +0 -7
- package/dist/types/utils/deferred.d.ts.map +0 -1
- package/dist/types/utils/ref-counted-map.d.ts +0 -32
- package/dist/types/utils/ref-counted-map.d.ts.map +0 -1
|
@@ -1,86 +0,0 @@
|
|
|
1
|
-
const CLICK_NAVIGATION_THRESHOLD_MS = 100;
|
|
2
|
-
const CLICK_NAVIGATION_CHECK_INTERVAL_MS = 200;
|
|
3
|
-
const CLICK_NAVIGATION_MAX_CHECKS = 20;
|
|
4
|
-
function setupNavigationListener(callback) {
|
|
5
|
-
let previousLocation = null;
|
|
6
|
-
const handleNavigate = (event) => {
|
|
7
|
-
if (!event.navigationCompleted && event.url === previousLocation)
|
|
8
|
-
return;
|
|
9
|
-
callback(event);
|
|
10
|
-
previousLocation = event.url;
|
|
11
|
-
};
|
|
12
|
-
handleNavigate({ url: windowLocation(), navigationCompleted: "initial-page-load" });
|
|
13
|
-
if (typeof window === "undefined") {
|
|
14
|
-
return () => {
|
|
15
|
-
};
|
|
16
|
-
}
|
|
17
|
-
const unsubscribes = [];
|
|
18
|
-
if ("navigation" in window && window.navigation) {
|
|
19
|
-
const navigation = window.navigation;
|
|
20
|
-
const navigateHandler = ({ destination }) => handleNavigate({ url: destination.url });
|
|
21
|
-
const navigateSuccessHandler = () => {
|
|
22
|
-
handleNavigate({
|
|
23
|
-
url: navigation.currentEntry.url,
|
|
24
|
-
navigationCompleted: "client-side-navigation"
|
|
25
|
-
});
|
|
26
|
-
};
|
|
27
|
-
navigation.addEventListener("navigate", navigateHandler);
|
|
28
|
-
navigation.addEventListener("navigatesuccess", navigateSuccessHandler);
|
|
29
|
-
unsubscribes.push(() => navigation.removeEventListener("navigate", navigateHandler));
|
|
30
|
-
unsubscribes.push(
|
|
31
|
-
() => navigation.removeEventListener("navigatesuccess", navigateSuccessHandler)
|
|
32
|
-
);
|
|
33
|
-
return () => {
|
|
34
|
-
unsubscribes.forEach((u) => u());
|
|
35
|
-
};
|
|
36
|
-
}
|
|
37
|
-
let lastClickEvent = null;
|
|
38
|
-
const clickHandler = (e) => {
|
|
39
|
-
const a = e.composedPath?.()?.find((n) => n instanceof HTMLAnchorElement) ?? (e.target instanceof Element && e.target.closest?.("a"));
|
|
40
|
-
if (!a)
|
|
41
|
-
return;
|
|
42
|
-
lastClickEvent = { href: a.href, timestamp: Date.now() };
|
|
43
|
-
const pageUrlBeforeClick = windowLocation();
|
|
44
|
-
let navigationCheckCounter = 0;
|
|
45
|
-
const checkIfNavigationOccurred = () => {
|
|
46
|
-
const url = windowLocation();
|
|
47
|
-
if (url !== pageUrlBeforeClick) {
|
|
48
|
-
handleNavigate({ url, polyfilled: true });
|
|
49
|
-
return;
|
|
50
|
-
}
|
|
51
|
-
if (++navigationCheckCounter < CLICK_NAVIGATION_MAX_CHECKS) {
|
|
52
|
-
window.setTimeout(checkIfNavigationOccurred, CLICK_NAVIGATION_CHECK_INTERVAL_MS);
|
|
53
|
-
}
|
|
54
|
-
};
|
|
55
|
-
window.setTimeout(checkIfNavigationOccurred, CLICK_NAVIGATION_CHECK_INTERVAL_MS);
|
|
56
|
-
};
|
|
57
|
-
window.document.addEventListener(
|
|
58
|
-
"click",
|
|
59
|
-
clickHandler,
|
|
60
|
-
{ capture: true }
|
|
61
|
-
// run before bubbling to fortify against `stopPropagation()` calls
|
|
62
|
-
);
|
|
63
|
-
unsubscribes.push(
|
|
64
|
-
() => window.document.removeEventListener("click", clickHandler, { capture: true })
|
|
65
|
-
);
|
|
66
|
-
const unloadHandler = () => {
|
|
67
|
-
if (!lastClickEvent)
|
|
68
|
-
return;
|
|
69
|
-
const msSinceLastClick = Date.now() - lastClickEvent.timestamp;
|
|
70
|
-
handleNavigate({
|
|
71
|
-
url: msSinceLastClick < CLICK_NAVIGATION_THRESHOLD_MS ? lastClickEvent.href ?? null : null,
|
|
72
|
-
polyfilled: true
|
|
73
|
-
});
|
|
74
|
-
lastClickEvent = null;
|
|
75
|
-
};
|
|
76
|
-
window.addEventListener("beforeunload", unloadHandler);
|
|
77
|
-
unsubscribes.push(() => window.removeEventListener("beforeunload", unloadHandler));
|
|
78
|
-
return () => {
|
|
79
|
-
unsubscribes.forEach((u) => u());
|
|
80
|
-
};
|
|
81
|
-
}
|
|
82
|
-
const windowLocation = () => typeof window !== "undefined" ? window.location.href : null;
|
|
83
|
-
export {
|
|
84
|
-
setupNavigationListener
|
|
85
|
-
};
|
|
86
|
-
//# sourceMappingURL=navigation-listener.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/state/builder-api/navigation-listener.ts"],"sourcesContent":["import { type HostNavigationEvent } from './api'\n\ntype ClickEvent = {\n href: string\n timestamp: number\n}\n\nconst CLICK_NAVIGATION_THRESHOLD_MS = 100\nconst CLICK_NAVIGATION_CHECK_INTERVAL_MS = 200\nconst CLICK_NAVIGATION_MAX_CHECKS = 20\n\nexport function setupNavigationListener(\n callback: (args: HostNavigationEvent) => void,\n): VoidFunction {\n let previousLocation: string | null = null\n\n const handleNavigate = (event: HostNavigationEvent) => {\n if (!event.navigationCompleted && event.url === previousLocation) return\n\n callback(event)\n previousLocation = event.url\n }\n\n // trigger navigation callback on initial page load\n handleNavigate({ url: windowLocation(), navigationCompleted: 'initial-page-load' })\n\n if (typeof window === 'undefined') {\n return () => {}\n }\n\n const unsubscribes: (() => void)[] = []\n\n // check for availability of the Navigation API (baseline feature since January 2026),\n // see https://developer.mozilla.org/en-US/docs/Web/API/Navigation_API\n if ('navigation' in window && window.navigation) {\n const navigation = window.navigation\n\n const navigateHandler = ({ destination }: NavigateEvent) =>\n handleNavigate({ url: destination.url })\n\n const navigateSuccessHandler = () => {\n handleNavigate({\n url: navigation.currentEntry.url,\n navigationCompleted: 'client-side-navigation',\n })\n }\n\n // note that in order to capture destination URLs that might not be Makeswift-enabled,\n // we send a `SiteNavigationEvent` at the start of navigation, but do not track whether\n // the navigation was successful or not (possible future improvement)\n navigation.addEventListener('navigate', navigateHandler)\n navigation.addEventListener('navigatesuccess', navigateSuccessHandler)\n unsubscribes.push(() => navigation.removeEventListener('navigate', navigateHandler))\n unsubscribes.push(() =>\n navigation.removeEventListener('navigatesuccess', navigateSuccessHandler),\n )\n\n return () => {\n unsubscribes.forEach(u => u())\n }\n }\n\n // for browsers lacking Navigation API support, we manually track:\n // - link clicks to capture destination URLs\n // - page unload events to detect cross-page navigation\n //\n // this works well enough to keep this polyfill in place for now, but not nearly as\n // reliably as the Navigation API\n let lastClickEvent: ClickEvent | null = null\n\n const clickHandler = (e: MouseEvent) => {\n const a =\n e.composedPath?.()?.find(n => n instanceof HTMLAnchorElement) ??\n (e.target instanceof Element && e.target.closest?.('a'))\n\n if (!a) return\n\n lastClickEvent = { href: a.href, timestamp: Date.now() }\n\n const pageUrlBeforeClick = windowLocation()\n let navigationCheckCounter = 0\n\n // handle navigation between pages in the host; note that we intentionally are\n // not cancelling the timer on cleanup to ensure we report the navigation\n const checkIfNavigationOccurred = () => {\n const url = windowLocation()\n\n if (url !== pageUrlBeforeClick) {\n // the host navigated to a different page, report the new URL to the builder\n handleNavigate({ url, polyfilled: true })\n return\n }\n\n // we're still on the same page, recheck until the max number of checks is reached\n if (++navigationCheckCounter < CLICK_NAVIGATION_MAX_CHECKS) {\n window.setTimeout(checkIfNavigationOccurred, CLICK_NAVIGATION_CHECK_INTERVAL_MS)\n }\n }\n\n window.setTimeout(checkIfNavigationOccurred, CLICK_NAVIGATION_CHECK_INTERVAL_MS)\n }\n\n window.document.addEventListener(\n 'click',\n clickHandler,\n { capture: true }, // run before bubbling to fortify against `stopPropagation()` calls\n )\n\n unsubscribes.push(() =>\n window.document.removeEventListener('click', clickHandler, { capture: true }),\n )\n\n // handle external navigation\n const unloadHandler = () => {\n if (!lastClickEvent) return\n\n const msSinceLastClick = Date.now() - lastClickEvent.timestamp\n handleNavigate({\n url: msSinceLastClick < CLICK_NAVIGATION_THRESHOLD_MS ? (lastClickEvent.href ?? null) : null,\n polyfilled: true,\n })\n\n lastClickEvent = null\n }\n\n window.addEventListener('beforeunload', unloadHandler)\n unsubscribes.push(() => window.removeEventListener('beforeunload', unloadHandler))\n\n return () => {\n unsubscribes.forEach(u => u())\n }\n}\n\nconst windowLocation = (): string | null =>\n typeof window !== 'undefined' ? window.location.href : null\n"],"mappings":"AAOA,MAAM,gCAAgC;AACtC,MAAM,qCAAqC;AAC3C,MAAM,8BAA8B;AAE7B,SAAS,wBACd,UACc;AACd,MAAI,mBAAkC;AAEtC,QAAM,iBAAiB,CAAC,UAA+B;AACrD,QAAI,CAAC,MAAM,uBAAuB,MAAM,QAAQ;AAAkB;AAElE,aAAS,KAAK;AACd,uBAAmB,MAAM;AAAA,EAC3B;AAGA,iBAAe,EAAE,KAAK,eAAe,GAAG,qBAAqB,oBAAoB,CAAC;AAElF,MAAI,OAAO,WAAW,aAAa;AACjC,WAAO,MAAM;AAAA,IAAC;AAAA,EAChB;AAEA,QAAM,eAA+B,CAAC;AAItC,MAAI,gBAAgB,UAAU,OAAO,YAAY;AAC/C,UAAM,aAAa,OAAO;AAE1B,UAAM,kBAAkB,CAAC,EAAE,YAAY,MACrC,eAAe,EAAE,KAAK,YAAY,IAAI,CAAC;AAEzC,UAAM,yBAAyB,MAAM;AACnC,qBAAe;AAAA,QACb,KAAK,WAAW,aAAa;AAAA,QAC7B,qBAAqB;AAAA,MACvB,CAAC;AAAA,IACH;AAKA,eAAW,iBAAiB,YAAY,eAAe;AACvD,eAAW,iBAAiB,mBAAmB,sBAAsB;AACrE,iBAAa,KAAK,MAAM,WAAW,oBAAoB,YAAY,eAAe,CAAC;AACnF,iBAAa;AAAA,MAAK,MAChB,WAAW,oBAAoB,mBAAmB,sBAAsB;AAAA,IAC1E;AAEA,WAAO,MAAM;AACX,mBAAa,QAAQ,OAAK,EAAE,CAAC;AAAA,IAC/B;AAAA,EACF;AAQA,MAAI,iBAAoC;AAExC,QAAM,eAAe,CAAC,MAAkB;AACtC,UAAM,IACJ,EAAE,eAAe,GAAG,KAAK,OAAK,aAAa,iBAAiB,MAC3D,EAAE,kBAAkB,WAAW,EAAE,OAAO,UAAU,GAAG;AAExD,QAAI,CAAC;AAAG;AAER,qBAAiB,EAAE,MAAM,EAAE,MAAM,WAAW,KAAK,IAAI,EAAE;AAEvD,UAAM,qBAAqB,eAAe;AAC1C,QAAI,yBAAyB;AAI7B,UAAM,4BAA4B,MAAM;AACtC,YAAM,MAAM,eAAe;AAE3B,UAAI,QAAQ,oBAAoB;AAE9B,uBAAe,EAAE,KAAK,YAAY,KAAK,CAAC;AACxC;AAAA,MACF;AAGA,UAAI,EAAE,yBAAyB,6BAA6B;AAC1D,eAAO,WAAW,2BAA2B,kCAAkC;AAAA,MACjF;AAAA,IACF;AAEA,WAAO,WAAW,2BAA2B,kCAAkC;AAAA,EACjF;AAEA,SAAO,SAAS;AAAA,IACd;AAAA,IACA;AAAA,IACA,EAAE,SAAS,KAAK;AAAA;AAAA,EAClB;AAEA,eAAa;AAAA,IAAK,MAChB,OAAO,SAAS,oBAAoB,SAAS,cAAc,EAAE,SAAS,KAAK,CAAC;AAAA,EAC9E;AAGA,QAAM,gBAAgB,MAAM;AAC1B,QAAI,CAAC;AAAgB;AAErB,UAAM,mBAAmB,KAAK,IAAI,IAAI,eAAe;AACrD,mBAAe;AAAA,MACb,KAAK,mBAAmB,gCAAiC,eAAe,QAAQ,OAAQ;AAAA,MACxF,YAAY;AAAA,IACd,CAAC;AAED,qBAAiB;AAAA,EACnB;AAEA,SAAO,iBAAiB,gBAAgB,aAAa;AACrD,eAAa,KAAK,MAAM,OAAO,oBAAoB,gBAAgB,aAAa,CAAC;AAEjF,SAAO,MAAM;AACX,iBAAa,QAAQ,OAAK,EAAE,CAAC;AAAA,EAC/B;AACF;AAEA,MAAM,iBAAiB,MACrB,OAAO,WAAW,cAAc,OAAO,SAAS,OAAO;","names":[]}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { actionMiddleware } from "../toolkit";
|
|
2
|
-
function makeswiftApiClientSyncMiddleware(client) {
|
|
3
|
-
return actionMiddleware(() => (next) => {
|
|
4
|
-
return (action) => {
|
|
5
|
-
client.makeswiftApiClient.dispatch(action);
|
|
6
|
-
return next(action);
|
|
7
|
-
};
|
|
8
|
-
});
|
|
9
|
-
}
|
|
10
|
-
export {
|
|
11
|
-
makeswiftApiClientSyncMiddleware
|
|
12
|
-
};
|
|
13
|
-
//# sourceMappingURL=makeswift-api-client-sync.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/state/middleware/makeswift-api-client-sync.ts"],"sourcesContent":["import { type Middleware } from '@reduxjs/toolkit'\n\nimport { MakeswiftHostApiClient } from '../../api/client'\n\nimport { type Action } from '../actions'\nimport { actionMiddleware } from '../toolkit'\nimport { type State, type Dispatch } from '../unified-state'\n\nexport function makeswiftApiClientSyncMiddleware(\n client: MakeswiftHostApiClient,\n): Middleware<Dispatch, State, Dispatch> {\n return actionMiddleware(() => next => {\n return (action: Action) => {\n client.makeswiftApiClient.dispatch(action)\n\n return next(action)\n }\n })\n}\n"],"mappings":"AAKA,SAAS,wBAAwB;AAG1B,SAAS,iCACd,QACuC;AACvC,SAAO,iBAAiB,MAAM,UAAQ;AACpC,WAAO,CAAC,WAAmB;AACzB,aAAO,mBAAmB,SAAS,MAAM;AAEzC,aAAO,KAAK,MAAM;AAAA,IACpB;AAAA,EACF,CAAC;AACH;","names":[]}
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
import { ActionTypes } from "../actions";
|
|
2
|
-
import { createElementTree, deleteElementTree } from "../actions/internal/read-only-actions";
|
|
3
|
-
import { actionMiddleware } from "../toolkit";
|
|
4
|
-
import { getPropControllerDescriptors } from "../read-only-state";
|
|
5
|
-
function readOnlyElementTreeMiddleware() {
|
|
6
|
-
return actionMiddleware(({ dispatch, getState }) => (next) => {
|
|
7
|
-
return (action) => {
|
|
8
|
-
switch (action.type) {
|
|
9
|
-
case ActionTypes.REGISTER_DOCUMENT:
|
|
10
|
-
dispatch(
|
|
11
|
-
createElementTree({
|
|
12
|
-
document: action.payload.document,
|
|
13
|
-
descriptors: getPropControllerDescriptors(getState())
|
|
14
|
-
})
|
|
15
|
-
);
|
|
16
|
-
break;
|
|
17
|
-
case ActionTypes.UNREGISTER_DOCUMENT:
|
|
18
|
-
dispatch(deleteElementTree(action.payload));
|
|
19
|
-
break;
|
|
20
|
-
}
|
|
21
|
-
return next(action);
|
|
22
|
-
};
|
|
23
|
-
});
|
|
24
|
-
}
|
|
25
|
-
export {
|
|
26
|
-
readOnlyElementTreeMiddleware
|
|
27
|
-
};
|
|
28
|
-
//# sourceMappingURL=read-only-element-tree.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../src/state/middleware/read-only-element-tree.ts"],"sourcesContent":["import { type Middleware } from '@reduxjs/toolkit'\n\nimport { ActionTypes } from '../actions'\nimport { createElementTree, deleteElementTree } from '../actions/internal/read-only-actions'\n\nimport { actionMiddleware } from '../toolkit'\n\nimport { type Dispatch, type State, getPropControllerDescriptors } from '../read-only-state'\n\nexport function readOnlyElementTreeMiddleware(): Middleware<Dispatch, State, Dispatch> {\n return actionMiddleware(({ dispatch, getState }) => next => {\n return action => {\n switch (action.type) {\n case ActionTypes.REGISTER_DOCUMENT:\n dispatch(\n createElementTree({\n document: action.payload.document,\n descriptors: getPropControllerDescriptors(getState()),\n }),\n )\n break\n\n case ActionTypes.UNREGISTER_DOCUMENT:\n dispatch(deleteElementTree(action.payload))\n break\n }\n\n return next(action)\n }\n })\n}\n"],"mappings":"AAEA,SAAS,mBAAmB;AAC5B,SAAS,mBAAmB,yBAAyB;AAErD,SAAS,wBAAwB;AAEjC,SAAoC,oCAAoC;AAEjE,SAAS,gCAAuE;AACrF,SAAO,iBAAiB,CAAC,EAAE,UAAU,SAAS,MAAM,UAAQ;AAC1D,WAAO,YAAU;AACf,cAAQ,OAAO,MAAM;AAAA,QACnB,KAAK,YAAY;AACf;AAAA,YACE,kBAAkB;AAAA,cAChB,UAAU,OAAO,QAAQ;AAAA,cACzB,aAAa,6BAA6B,SAAS,CAAC;AAAA,YACtD,CAAC;AAAA,UACH;AACA;AAAA,QAEF,KAAK,YAAY;AACf,mBAAS,kBAAkB,OAAO,OAAO,CAAC;AAC1C;AAAA,MACJ;AAEA,aAAO,KAAK,MAAM;AAAA,IACpB;AAAA,EACF,CAAC;AACH;","names":[]}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
function getElementSize(element) {
|
|
2
|
-
return {
|
|
3
|
-
offsetWidth: element.offsetWidth,
|
|
4
|
-
offsetHeight: element.offsetHeight,
|
|
5
|
-
clientWidth: element.clientWidth,
|
|
6
|
-
clientHeight: element.clientHeight,
|
|
7
|
-
scrollWidth: element.scrollWidth,
|
|
8
|
-
scrollHeight: element.scrollHeight,
|
|
9
|
-
scrollTop: element.scrollTop,
|
|
10
|
-
scrollLeft: element.scrollLeft
|
|
11
|
-
};
|
|
12
|
-
}
|
|
13
|
-
export {
|
|
14
|
-
getElementSize
|
|
15
|
-
};
|
|
16
|
-
//# sourceMappingURL=element-size.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../../../src/state/middleware/read-write/builder-api/element-size.ts"],"sourcesContent":["export type ElementSize = {\n offsetWidth: number\n offsetHeight: number\n clientWidth: number\n clientHeight: number\n scrollWidth: number\n scrollHeight: number\n scrollTop: number\n scrollLeft: number\n}\n\nexport function getElementSize(element: HTMLElement): ElementSize {\n return {\n offsetWidth: element.offsetWidth,\n offsetHeight: element.offsetHeight,\n clientWidth: element.clientWidth,\n clientHeight: element.clientHeight,\n scrollWidth: element.scrollWidth,\n scrollHeight: element.scrollHeight,\n scrollTop: element.scrollTop,\n scrollLeft: element.scrollLeft,\n }\n}\n"],"mappings":"AAWO,SAAS,eAAe,SAAmC;AAChE,SAAO;AAAA,IACL,aAAa,QAAQ;AAAA,IACrB,cAAc,QAAQ;AAAA,IACtB,aAAa,QAAQ;AAAA,IACrB,cAAc,QAAQ;AAAA,IACtB,aAAa,QAAQ;AAAA,IACrB,cAAc,QAAQ;AAAA,IACtB,WAAW,QAAQ;AAAA,IACnB,YAAY,QAAQ;AAAA,EACtB;AACF;","names":[]}
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
import { BuilderActionTypes } from "../../../builder-api/actions";
|
|
2
|
-
import { actionMiddleware } from "../../../toolkit";
|
|
3
|
-
import { HostActionTypes } from "../../../host-api";
|
|
4
|
-
import { initializeBuilderConnection } from "./initialize-connection";
|
|
5
|
-
function builderAPIMiddleware(builderProxy) {
|
|
6
|
-
return actionMiddleware(({ dispatch }) => (next) => {
|
|
7
|
-
if (typeof window === "undefined")
|
|
8
|
-
return (action) => next(action);
|
|
9
|
-
let cleanUp = () => {
|
|
10
|
-
};
|
|
11
|
-
return (action) => {
|
|
12
|
-
switch (action.type) {
|
|
13
|
-
case BuilderActionTypes.CHANGE_ELEMENT_BOX_MODELS:
|
|
14
|
-
case BuilderActionTypes.MOUNT_COMPONENT:
|
|
15
|
-
case BuilderActionTypes.UNMOUNT_COMPONENT:
|
|
16
|
-
case BuilderActionTypes.CHANGE_DOCUMENT_ELEMENT_SIZE:
|
|
17
|
-
case BuilderActionTypes.MESSAGE_BUILDER_PROP_CONTROLLER:
|
|
18
|
-
case BuilderActionTypes.HANDLE_WHEEL:
|
|
19
|
-
case BuilderActionTypes.HANDLE_POINTER_MOVE:
|
|
20
|
-
case BuilderActionTypes.ELEMENT_FROM_POINT_CHANGE:
|
|
21
|
-
case BuilderActionTypes.SET_LOCALE:
|
|
22
|
-
case BuilderActionTypes.SET_BREAKPOINTS:
|
|
23
|
-
case BuilderActionTypes.REGISTER_BUILDER_DOCUMENT:
|
|
24
|
-
case BuilderActionTypes.UNREGISTER_BUILDER_DOCUMENT:
|
|
25
|
-
case BuilderActionTypes.REGISTER_BUILDER_COMPONENT:
|
|
26
|
-
case BuilderActionTypes.UNREGISTER_BUILDER_COMPONENT:
|
|
27
|
-
builderProxy.execute(action);
|
|
28
|
-
break;
|
|
29
|
-
case HostActionTypes.CHANGE_DOCUMENT_ELEMENT_SCROLL_TOP:
|
|
30
|
-
window.document.documentElement.scrollTo({
|
|
31
|
-
top: action.payload.scrollTop,
|
|
32
|
-
behavior: "instant"
|
|
33
|
-
});
|
|
34
|
-
break;
|
|
35
|
-
case HostActionTypes.SCROLL_DOCUMENT_ELEMENT:
|
|
36
|
-
window.document.documentElement.scrollBy({
|
|
37
|
-
top: action.payload.scrollTopDelta,
|
|
38
|
-
behavior: "instant"
|
|
39
|
-
});
|
|
40
|
-
break;
|
|
41
|
-
case HostActionTypes.SET_BUILDER_EDIT_MODE:
|
|
42
|
-
window.getSelection()?.removeAllRanges();
|
|
43
|
-
break;
|
|
44
|
-
case HostActionTypes.INIT:
|
|
45
|
-
cleanUp();
|
|
46
|
-
cleanUp = dispatch(initializeBuilderConnection(builderProxy));
|
|
47
|
-
break;
|
|
48
|
-
case HostActionTypes.CLEAN_UP:
|
|
49
|
-
cleanUp();
|
|
50
|
-
cleanUp = () => {
|
|
51
|
-
};
|
|
52
|
-
break;
|
|
53
|
-
}
|
|
54
|
-
return next(action);
|
|
55
|
-
};
|
|
56
|
-
});
|
|
57
|
-
}
|
|
58
|
-
export {
|
|
59
|
-
builderAPIMiddleware
|
|
60
|
-
};
|
|
61
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../../../src/state/middleware/read-write/builder-api/index.ts"],"sourcesContent":["import { type Middleware } from '@reduxjs/toolkit'\n\nimport { type Action } from '../../../actions'\n\nimport { BuilderActionTypes } from '../../../builder-api/actions'\n\nimport { actionMiddleware } from '../../../toolkit'\n\nimport { type BuilderAPIProxy } from '../../../builder-api/proxy'\nimport { HostActionTypes } from '../../../host-api'\n\nimport { type State, type Dispatch } from '../../../read-write-state'\nimport { initializeBuilderConnection } from './initialize-connection'\n\nexport function builderAPIMiddleware(\n builderProxy: BuilderAPIProxy,\n): Middleware<Dispatch, State, Dispatch> {\n return actionMiddleware(({ dispatch }) => next => {\n if (typeof window === 'undefined') return (action: Action) => next(action)\n\n let cleanUp = () => {}\n return (action: Action) => {\n switch (action.type) {\n case BuilderActionTypes.CHANGE_ELEMENT_BOX_MODELS:\n case BuilderActionTypes.MOUNT_COMPONENT:\n case BuilderActionTypes.UNMOUNT_COMPONENT:\n case BuilderActionTypes.CHANGE_DOCUMENT_ELEMENT_SIZE:\n case BuilderActionTypes.MESSAGE_BUILDER_PROP_CONTROLLER:\n case BuilderActionTypes.HANDLE_WHEEL:\n case BuilderActionTypes.HANDLE_POINTER_MOVE:\n case BuilderActionTypes.ELEMENT_FROM_POINT_CHANGE:\n case BuilderActionTypes.SET_LOCALE:\n case BuilderActionTypes.SET_BREAKPOINTS:\n case BuilderActionTypes.REGISTER_BUILDER_DOCUMENT:\n case BuilderActionTypes.UNREGISTER_BUILDER_DOCUMENT:\n case BuilderActionTypes.REGISTER_BUILDER_COMPONENT:\n case BuilderActionTypes.UNREGISTER_BUILDER_COMPONENT:\n builderProxy.execute(action)\n break\n\n case HostActionTypes.CHANGE_DOCUMENT_ELEMENT_SCROLL_TOP:\n window.document.documentElement.scrollTo({\n top: action.payload.scrollTop,\n behavior: 'instant',\n })\n break\n\n case HostActionTypes.SCROLL_DOCUMENT_ELEMENT:\n window.document.documentElement.scrollBy({\n top: action.payload.scrollTopDelta,\n behavior: 'instant',\n })\n break\n\n case HostActionTypes.SET_BUILDER_EDIT_MODE:\n window.getSelection()?.removeAllRanges()\n break\n\n case HostActionTypes.INIT:\n // dispatched by the parent window after establishing the connection\n // and in response to host's client-side navigation\n cleanUp() // cleanup existing connection setup, if any\n cleanUp = dispatch(initializeBuilderConnection(builderProxy))\n break\n\n case HostActionTypes.CLEAN_UP:\n // dispatched by the parent window on disconnect\n cleanUp()\n cleanUp = () => {}\n break\n }\n\n return next(action)\n }\n })\n}\n"],"mappings":"AAIA,SAAS,0BAA0B;AAEnC,SAAS,wBAAwB;AAGjC,SAAS,uBAAuB;AAGhC,SAAS,mCAAmC;AAErC,SAAS,qBACd,cACuC;AACvC,SAAO,iBAAiB,CAAC,EAAE,SAAS,MAAM,UAAQ;AAChD,QAAI,OAAO,WAAW;AAAa,aAAO,CAAC,WAAmB,KAAK,MAAM;AAEzE,QAAI,UAAU,MAAM;AAAA,IAAC;AACrB,WAAO,CAAC,WAAmB;AACzB,cAAQ,OAAO,MAAM;AAAA,QACnB,KAAK,mBAAmB;AAAA,QACxB,KAAK,mBAAmB;AAAA,QACxB,KAAK,mBAAmB;AAAA,QACxB,KAAK,mBAAmB;AAAA,QACxB,KAAK,mBAAmB;AAAA,QACxB,KAAK,mBAAmB;AAAA,QACxB,KAAK,mBAAmB;AAAA,QACxB,KAAK,mBAAmB;AAAA,QACxB,KAAK,mBAAmB;AAAA,QACxB,KAAK,mBAAmB;AAAA,QACxB,KAAK,mBAAmB;AAAA,QACxB,KAAK,mBAAmB;AAAA,QACxB,KAAK,mBAAmB;AAAA,QACxB,KAAK,mBAAmB;AACtB,uBAAa,QAAQ,MAAM;AAC3B;AAAA,QAEF,KAAK,gBAAgB;AACnB,iBAAO,SAAS,gBAAgB,SAAS;AAAA,YACvC,KAAK,OAAO,QAAQ;AAAA,YACpB,UAAU;AAAA,UACZ,CAAC;AACD;AAAA,QAEF,KAAK,gBAAgB;AACnB,iBAAO,SAAS,gBAAgB,SAAS;AAAA,YACvC,KAAK,OAAO,QAAQ;AAAA,YACpB,UAAU;AAAA,UACZ,CAAC;AACD;AAAA,QAEF,KAAK,gBAAgB;AACnB,iBAAO,aAAa,GAAG,gBAAgB;AACvC;AAAA,QAEF,KAAK,gBAAgB;AAGnB,kBAAQ;AACR,oBAAU,SAAS,4BAA4B,YAAY,CAAC;AAC5D;AAAA,QAEF,KAAK,gBAAgB;AAEnB,kBAAQ;AACR,oBAAU,MAAM;AAAA,UAAC;AACjB;AAAA,MACJ;AAEA,aAAO,KAAK,MAAM;AAAA,IACpB;AAAA,EACF,CAAC;AACH;","names":[]}
|
|
@@ -1,254 +0,0 @@
|
|
|
1
|
-
import deepEqual from "../../../../utils/deepEqual";
|
|
2
|
-
import * as BoxModels from "../../../modules/read-write/box-models";
|
|
3
|
-
import * as BuilderEditMode from "../../../modules/builder-edit-mode";
|
|
4
|
-
import * as ReadOnly from "../../../actions/internal/read-only-actions";
|
|
5
|
-
import * as Builder from "../../../builder-api/actions";
|
|
6
|
-
import { serializeControls } from "../../../../builder";
|
|
7
|
-
import * as ReadOnlyState from "../../../read-only-state";
|
|
8
|
-
import {
|
|
9
|
-
getDocuments,
|
|
10
|
-
getMeasurables,
|
|
11
|
-
getBoxModels,
|
|
12
|
-
getBoxModel,
|
|
13
|
-
getElementImperativeHandlesContainingElement,
|
|
14
|
-
getPointer
|
|
15
|
-
} from "../../../read-write-state";
|
|
16
|
-
import { getElementSize } from "./element-size";
|
|
17
|
-
function measureElements() {
|
|
18
|
-
return (dispatch, getState) => {
|
|
19
|
-
const measurables = getMeasurables(getState());
|
|
20
|
-
const currentBoxModels = getBoxModels(getState());
|
|
21
|
-
const measuredBoxModels = /* @__PURE__ */ new Map();
|
|
22
|
-
measurables.forEach((documentMeasurables, documentKey) => {
|
|
23
|
-
const measuredDocumentBoxModels = /* @__PURE__ */ new Map();
|
|
24
|
-
documentMeasurables.forEach((measurable, elementKey) => {
|
|
25
|
-
const boxModel = BoxModels.measure(measurable);
|
|
26
|
-
if (boxModel != null)
|
|
27
|
-
measuredDocumentBoxModels.set(elementKey, boxModel);
|
|
28
|
-
});
|
|
29
|
-
if (measuredDocumentBoxModels.size > 0) {
|
|
30
|
-
measuredBoxModels.set(documentKey, measuredDocumentBoxModels);
|
|
31
|
-
}
|
|
32
|
-
});
|
|
33
|
-
const changedBoxModels = /* @__PURE__ */ new Map();
|
|
34
|
-
currentBoxModels.forEach((currentDocumentBoxModels, documentKey) => {
|
|
35
|
-
const changedDocumentBoxModels = /* @__PURE__ */ new Map();
|
|
36
|
-
currentDocumentBoxModels.forEach((_boxModel, elementKey) => {
|
|
37
|
-
if (!measuredBoxModels.get(documentKey)?.has(elementKey)) {
|
|
38
|
-
changedDocumentBoxModels.set(elementKey, null);
|
|
39
|
-
}
|
|
40
|
-
if (changedDocumentBoxModels.size > 0) {
|
|
41
|
-
changedBoxModels.set(documentKey, changedDocumentBoxModels);
|
|
42
|
-
}
|
|
43
|
-
});
|
|
44
|
-
});
|
|
45
|
-
measuredBoxModels.forEach((measuredDocumentBoxModels, documentKey) => {
|
|
46
|
-
const changedDocumentBoxModels = /* @__PURE__ */ new Map();
|
|
47
|
-
measuredDocumentBoxModels.forEach((measuredBoxModel, elementKey) => {
|
|
48
|
-
const currentBoxModel = getBoxModel(getState(), documentKey, elementKey);
|
|
49
|
-
if (currentBoxModel == null || !deepEqual(currentBoxModel, measuredBoxModel)) {
|
|
50
|
-
changedDocumentBoxModels.set(elementKey, measuredBoxModel);
|
|
51
|
-
}
|
|
52
|
-
});
|
|
53
|
-
if (changedDocumentBoxModels.size > 0) {
|
|
54
|
-
changedBoxModels.set(documentKey, changedDocumentBoxModels);
|
|
55
|
-
}
|
|
56
|
-
});
|
|
57
|
-
if (changedBoxModels.size > 0)
|
|
58
|
-
dispatch(Builder.changeElementBoxModels(changedBoxModels));
|
|
59
|
-
};
|
|
60
|
-
}
|
|
61
|
-
function startMeasuringElements() {
|
|
62
|
-
return (dispatch) => {
|
|
63
|
-
let animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest);
|
|
64
|
-
return () => {
|
|
65
|
-
cancelAnimationFrame(animationFrameHandle);
|
|
66
|
-
};
|
|
67
|
-
function handleAnimationFrameRequest() {
|
|
68
|
-
dispatch(measureElements());
|
|
69
|
-
animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest);
|
|
70
|
-
}
|
|
71
|
-
};
|
|
72
|
-
}
|
|
73
|
-
function lockDocumentScroll() {
|
|
74
|
-
return (dispatch) => {
|
|
75
|
-
const lastDocumentOverflow = window.document.documentElement.style.overflow;
|
|
76
|
-
window.document.documentElement.style.overflow = "hidden";
|
|
77
|
-
window.document.documentElement.addEventListener("wheel", handleWheelEvent);
|
|
78
|
-
return () => {
|
|
79
|
-
window.document.documentElement.style.overflow = lastDocumentOverflow;
|
|
80
|
-
window.document.documentElement.removeEventListener("wheel", handleWheelEvent);
|
|
81
|
-
};
|
|
82
|
-
function handleWheelEvent({ deltaX, deltaY }) {
|
|
83
|
-
dispatch(Builder.handleWheel({ deltaX, deltaY }));
|
|
84
|
-
}
|
|
85
|
-
};
|
|
86
|
-
}
|
|
87
|
-
function startHandlingPointerMoveEvent() {
|
|
88
|
-
return (dispatch) => {
|
|
89
|
-
window.document.documentElement.addEventListener("pointermove", handlePointerMoveEvent);
|
|
90
|
-
return () => {
|
|
91
|
-
window.document.documentElement.removeEventListener("pointermove", handlePointerMoveEvent);
|
|
92
|
-
};
|
|
93
|
-
function handlePointerMoveEvent({ clientX, clientY }) {
|
|
94
|
-
dispatch(Builder.handlePointerMove({ clientX, clientY }));
|
|
95
|
-
}
|
|
96
|
-
};
|
|
97
|
-
}
|
|
98
|
-
function startHandlingFocusEvents() {
|
|
99
|
-
return (_dispatch, getState) => {
|
|
100
|
-
window.addEventListener("focusin", handleFocusIn);
|
|
101
|
-
window.addEventListener("focusout", handleFocusOut);
|
|
102
|
-
return () => {
|
|
103
|
-
window.removeEventListener("focusin", handleFocusIn);
|
|
104
|
-
window.removeEventListener("focusout", handleFocusOut);
|
|
105
|
-
};
|
|
106
|
-
function handleFocusIn(event) {
|
|
107
|
-
if (ReadOnlyState.getBuilderEditMode(getState()) === BuilderEditMode.BuilderEditMode.INTERACT) {
|
|
108
|
-
return;
|
|
109
|
-
}
|
|
110
|
-
if (!(event.target instanceof window.HTMLElement) || !event.target.isContentEditable) {
|
|
111
|
-
window.parent.focus();
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
function handleFocusOut(event) {
|
|
115
|
-
if (ReadOnlyState.getBuilderEditMode(getState()) === BuilderEditMode.BuilderEditMode.INTERACT) {
|
|
116
|
-
return;
|
|
117
|
-
}
|
|
118
|
-
if (!(event.relatedTarget instanceof window.HTMLElement) || !event.relatedTarget.isContentEditable) {
|
|
119
|
-
window.parent.focus();
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
};
|
|
123
|
-
}
|
|
124
|
-
function startMeasuringDocumentElement() {
|
|
125
|
-
return (dispatch) => {
|
|
126
|
-
let animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest);
|
|
127
|
-
let lastSize;
|
|
128
|
-
return () => {
|
|
129
|
-
cancelAnimationFrame(animationFrameHandle);
|
|
130
|
-
};
|
|
131
|
-
function handleAnimationFrameRequest() {
|
|
132
|
-
const nextSize = getElementSize(window.document.documentElement);
|
|
133
|
-
if (!deepEqual(lastSize, nextSize)) {
|
|
134
|
-
lastSize = nextSize;
|
|
135
|
-
dispatch(Builder.changeDocumentElementSize(nextSize));
|
|
136
|
-
}
|
|
137
|
-
animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest);
|
|
138
|
-
}
|
|
139
|
-
};
|
|
140
|
-
}
|
|
141
|
-
function elementKeysFromElementFromPoint(elementFromPoint) {
|
|
142
|
-
return (_dispatch, getState) => {
|
|
143
|
-
if (elementFromPoint == null)
|
|
144
|
-
return null;
|
|
145
|
-
const elementImperativeHandles = getElementImperativeHandlesContainingElement(
|
|
146
|
-
getState(),
|
|
147
|
-
elementFromPoint
|
|
148
|
-
);
|
|
149
|
-
const ascendingDepthDocumentKeys = ReadOnlyState.getDocumentKeysSortedByDepth(getState());
|
|
150
|
-
const descendingDepthDocumentKeys = ascendingDepthDocumentKeys.slice().reverse();
|
|
151
|
-
let currentElement = elementFromPoint;
|
|
152
|
-
let keys = null;
|
|
153
|
-
while (currentElement != null) {
|
|
154
|
-
for (const documentKey of descendingDepthDocumentKeys) {
|
|
155
|
-
const byElementKey = elementImperativeHandles.get(documentKey);
|
|
156
|
-
if (byElementKey == null)
|
|
157
|
-
continue;
|
|
158
|
-
for (const [elementKey, elementImperativeHandle] of byElementKey) {
|
|
159
|
-
if (elementImperativeHandle.getDomNode() === currentElement) {
|
|
160
|
-
return { documentKey, elementKey };
|
|
161
|
-
}
|
|
162
|
-
}
|
|
163
|
-
}
|
|
164
|
-
currentElement = currentElement.parentElement;
|
|
165
|
-
}
|
|
166
|
-
return keys;
|
|
167
|
-
};
|
|
168
|
-
}
|
|
169
|
-
function startPollingElementFromPoint() {
|
|
170
|
-
return (dispatch, getState) => {
|
|
171
|
-
let lastElementFromPoint = null;
|
|
172
|
-
let animationFrameRequestId = requestAnimationFrame(handleAnimationFrameRequest);
|
|
173
|
-
return () => {
|
|
174
|
-
cancelAnimationFrame(animationFrameRequestId);
|
|
175
|
-
};
|
|
176
|
-
function handleAnimationFrameRequest() {
|
|
177
|
-
const pointer = getPointer(getState());
|
|
178
|
-
const elementFromPoint = pointer == null ? null : document.elementFromPoint(pointer.x, pointer.y);
|
|
179
|
-
if (elementFromPoint !== lastElementFromPoint) {
|
|
180
|
-
lastElementFromPoint = elementFromPoint;
|
|
181
|
-
const keys = dispatch(elementKeysFromElementFromPoint(elementFromPoint));
|
|
182
|
-
dispatch(Builder.elementFromPointChange(keys));
|
|
183
|
-
}
|
|
184
|
-
animationFrameRequestId = requestAnimationFrame(handleAnimationFrameRequest);
|
|
185
|
-
}
|
|
186
|
-
};
|
|
187
|
-
}
|
|
188
|
-
function registerBuilderComponents() {
|
|
189
|
-
return (dispatch, getState) => {
|
|
190
|
-
const state = getState();
|
|
191
|
-
const componentsMeta = ReadOnlyState.getComponentsMeta(state);
|
|
192
|
-
componentsMeta.forEach((meta, type) => {
|
|
193
|
-
const descriptors = ReadOnlyState.getComponentPropControllerDescriptors(state, type);
|
|
194
|
-
if (descriptors != null) {
|
|
195
|
-
const [serializedControls, transferables] = serializeControls(descriptors);
|
|
196
|
-
dispatch(
|
|
197
|
-
Builder.registerBuilderComponent({ type, meta, serializedControls }, transferables)
|
|
198
|
-
);
|
|
199
|
-
}
|
|
200
|
-
});
|
|
201
|
-
return () => {
|
|
202
|
-
componentsMeta.forEach((_, type) => {
|
|
203
|
-
dispatch(Builder.unregisterBuilderComponent({ type }));
|
|
204
|
-
});
|
|
205
|
-
};
|
|
206
|
-
};
|
|
207
|
-
}
|
|
208
|
-
function registerBuilderDocuments() {
|
|
209
|
-
return (dispatch, getState) => {
|
|
210
|
-
const documents = getDocuments(getState());
|
|
211
|
-
documents.forEach((document2) => {
|
|
212
|
-
dispatch(Builder.registerBuilderDocument(document2));
|
|
213
|
-
});
|
|
214
|
-
return () => {
|
|
215
|
-
documents.forEach((_document, documentKey) => {
|
|
216
|
-
dispatch(Builder.unregisterBuilderDocument(documentKey));
|
|
217
|
-
});
|
|
218
|
-
};
|
|
219
|
-
};
|
|
220
|
-
}
|
|
221
|
-
function initializeBuilderConnection(builderProxy) {
|
|
222
|
-
return (dispatch, getState) => {
|
|
223
|
-
const unregisterBuilderDocuments = dispatch(registerBuilderDocuments());
|
|
224
|
-
const stopMeasuringElements = dispatch(startMeasuringElements());
|
|
225
|
-
const stopMeasuringDocumentElement = dispatch(startMeasuringDocumentElement());
|
|
226
|
-
const stopHandlingFocusEvent = dispatch(startHandlingFocusEvents());
|
|
227
|
-
const unlockDocumentScroll = dispatch(lockDocumentScroll());
|
|
228
|
-
const stopHandlingPointerMoveEvent = dispatch(startHandlingPointerMoveEvent());
|
|
229
|
-
const stopPollingElementFromPoint = dispatch(startPollingElementFromPoint());
|
|
230
|
-
const unregisterBuilderComponents = dispatch(registerBuilderComponents());
|
|
231
|
-
const breakpoints = ReadOnlyState.getBreakpoints(getState());
|
|
232
|
-
dispatch(Builder.setBreakpoints(breakpoints));
|
|
233
|
-
const locale = ReadOnlyState.getLocale(getState());
|
|
234
|
-
if (locale != null)
|
|
235
|
-
dispatch(Builder.setLocale(new Intl.Locale(locale)));
|
|
236
|
-
dispatch(ReadOnly.setIsInBuilder(true));
|
|
237
|
-
builderProxy.dispatchBuffered();
|
|
238
|
-
return () => {
|
|
239
|
-
unregisterBuilderDocuments();
|
|
240
|
-
stopMeasuringElements();
|
|
241
|
-
stopMeasuringDocumentElement();
|
|
242
|
-
stopHandlingFocusEvent();
|
|
243
|
-
unlockDocumentScroll();
|
|
244
|
-
stopHandlingPointerMoveEvent();
|
|
245
|
-
stopPollingElementFromPoint();
|
|
246
|
-
unregisterBuilderComponents();
|
|
247
|
-
dispatch(ReadOnly.setIsInBuilder(false));
|
|
248
|
-
};
|
|
249
|
-
};
|
|
250
|
-
}
|
|
251
|
-
export {
|
|
252
|
-
initializeBuilderConnection
|
|
253
|
-
};
|
|
254
|
-
//# sourceMappingURL=initialize-connection.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../../../src/state/middleware/read-write/builder-api/initialize-connection.ts"],"sourcesContent":["import { type ThunkAction } from '@reduxjs/toolkit'\n\nimport deepEqual from '../../../../utils/deepEqual'\n\nimport * as BoxModels from '../../../modules/read-write/box-models'\nimport * as BuilderEditMode from '../../../modules/builder-edit-mode'\n\nimport { type Action } from '../../../actions'\n\nimport * as ReadOnly from '../../../actions/internal/read-only-actions'\nimport * as Builder from '../../../builder-api/actions'\n\nimport { serializeControls } from '../../../../builder'\nimport { type BuilderAPIProxy } from '../../../builder-api/proxy'\n\nimport * as ReadOnlyState from '../../../read-only-state'\nimport {\n type State,\n getDocuments,\n getMeasurables,\n getBoxModels,\n getBoxModel,\n getElementImperativeHandlesContainingElement,\n getPointer,\n} from '../../../read-write-state'\n\nimport { type ElementSize, getElementSize } from './element-size'\n\nfunction measureElements(): ThunkAction<void, State, unknown, Action> {\n return (dispatch, getState) => {\n const measurables = getMeasurables(getState())\n const currentBoxModels = getBoxModels(getState())\n const measuredBoxModels = new Map<string, Map<string, BoxModels.BoxDisplayModel>>()\n\n measurables.forEach((documentMeasurables, documentKey) => {\n const measuredDocumentBoxModels = new Map<string, BoxModels.BoxDisplayModel>()\n\n documentMeasurables.forEach((measurable, elementKey) => {\n const boxModel = BoxModels.measure(measurable)\n\n if (boxModel != null) measuredDocumentBoxModels.set(elementKey, boxModel)\n })\n\n if (measuredDocumentBoxModels.size > 0) {\n measuredBoxModels.set(documentKey, measuredDocumentBoxModels)\n }\n })\n\n const changedBoxModels = new Map<string, Map<string, BoxModels.BoxDisplayModel | null>>()\n\n currentBoxModels.forEach((currentDocumentBoxModels, documentKey) => {\n const changedDocumentBoxModels = new Map<string, BoxModels.BoxDisplayModel | null>()\n\n currentDocumentBoxModels.forEach((_boxModel, elementKey) => {\n if (!measuredBoxModels.get(documentKey)?.has(elementKey)) {\n changedDocumentBoxModels.set(elementKey, null)\n }\n\n if (changedDocumentBoxModels.size > 0) {\n changedBoxModels.set(documentKey, changedDocumentBoxModels)\n }\n })\n })\n\n measuredBoxModels.forEach((measuredDocumentBoxModels, documentKey) => {\n const changedDocumentBoxModels = new Map<string, BoxModels.BoxDisplayModel | null>()\n\n measuredDocumentBoxModels.forEach((measuredBoxModel, elementKey) => {\n const currentBoxModel = getBoxModel(getState(), documentKey, elementKey)\n\n if (currentBoxModel == null || !deepEqual(currentBoxModel, measuredBoxModel)) {\n changedDocumentBoxModels.set(elementKey, measuredBoxModel)\n }\n })\n\n if (changedDocumentBoxModels.size > 0) {\n changedBoxModels.set(documentKey, changedDocumentBoxModels)\n }\n })\n\n if (changedBoxModels.size > 0) dispatch(Builder.changeElementBoxModels(changedBoxModels))\n }\n}\n\nfunction startMeasuringElements(): ThunkAction<() => void, State, unknown, Action> {\n return dispatch => {\n let animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest)\n\n return () => {\n cancelAnimationFrame(animationFrameHandle)\n }\n\n function handleAnimationFrameRequest() {\n dispatch(measureElements())\n\n animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest)\n }\n }\n}\n\nfunction lockDocumentScroll(): ThunkAction<() => void, State, unknown, Action> {\n return dispatch => {\n const lastDocumentOverflow = window.document.documentElement.style.overflow\n window.document.documentElement.style.overflow = 'hidden'\n\n window.document.documentElement.addEventListener('wheel', handleWheelEvent)\n\n return () => {\n window.document.documentElement.style.overflow = lastDocumentOverflow\n window.document.documentElement.removeEventListener('wheel', handleWheelEvent)\n }\n\n function handleWheelEvent({ deltaX, deltaY }: WheelEvent) {\n dispatch(Builder.handleWheel({ deltaX, deltaY }))\n }\n }\n}\n\nfunction startHandlingPointerMoveEvent(): ThunkAction<() => void, State, unknown, Action> {\n return dispatch => {\n window.document.documentElement.addEventListener('pointermove', handlePointerMoveEvent)\n\n return () => {\n window.document.documentElement.removeEventListener('pointermove', handlePointerMoveEvent)\n }\n\n function handlePointerMoveEvent({ clientX, clientY }: PointerEvent) {\n dispatch(Builder.handlePointerMove({ clientX, clientY }))\n }\n }\n}\n\nfunction startHandlingFocusEvents(): ThunkAction<() => void, State, unknown, Action> {\n return (_dispatch, getState) => {\n window.addEventListener('focusin', handleFocusIn)\n window.addEventListener('focusout', handleFocusOut)\n\n return () => {\n window.removeEventListener('focusin', handleFocusIn)\n window.removeEventListener('focusout', handleFocusOut)\n }\n\n function handleFocusIn(event: FocusEvent) {\n if (\n ReadOnlyState.getBuilderEditMode(getState()) === BuilderEditMode.BuilderEditMode.INTERACT\n ) {\n return\n }\n\n if (!(event.target instanceof window.HTMLElement) || !event.target.isContentEditable) {\n window.parent.focus()\n }\n }\n\n function handleFocusOut(event: FocusEvent) {\n if (\n ReadOnlyState.getBuilderEditMode(getState()) === BuilderEditMode.BuilderEditMode.INTERACT\n ) {\n return\n }\n\n if (\n !(event.relatedTarget instanceof window.HTMLElement) ||\n !event.relatedTarget.isContentEditable\n ) {\n window.parent.focus()\n }\n }\n }\n}\n\nfunction startMeasuringDocumentElement(): ThunkAction<() => void, unknown, unknown, Action> {\n return dispatch => {\n let animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest)\n let lastSize: ElementSize\n\n return () => {\n cancelAnimationFrame(animationFrameHandle)\n }\n\n function handleAnimationFrameRequest() {\n const nextSize = getElementSize(window.document.documentElement)\n\n if (!deepEqual(lastSize, nextSize)) {\n lastSize = nextSize\n\n dispatch(Builder.changeDocumentElementSize(nextSize))\n }\n\n animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest)\n }\n }\n}\n\nfunction elementKeysFromElementFromPoint(\n elementFromPoint: Element | null,\n): ThunkAction<{ documentKey: string; elementKey: string } | null, State, unknown, Action> {\n return (_dispatch, getState) => {\n if (elementFromPoint == null) return null\n\n const elementImperativeHandles = getElementImperativeHandlesContainingElement(\n getState(),\n elementFromPoint,\n )\n const ascendingDepthDocumentKeys = ReadOnlyState.getDocumentKeysSortedByDepth(getState())\n const descendingDepthDocumentKeys = ascendingDepthDocumentKeys.slice().reverse()\n\n let currentElement: Element | null = elementFromPoint\n let keys = null\n\n while (currentElement != null) {\n for (const documentKey of descendingDepthDocumentKeys) {\n const byElementKey = elementImperativeHandles.get(documentKey)\n\n if (byElementKey == null) continue\n\n for (const [elementKey, elementImperativeHandle] of byElementKey) {\n if (elementImperativeHandle.getDomNode() === currentElement) {\n return { documentKey, elementKey }\n }\n }\n }\n\n currentElement = currentElement.parentElement\n }\n\n return keys\n }\n}\n\nfunction startPollingElementFromPoint(): ThunkAction<() => void, State, unknown, Action> {\n return (dispatch, getState) => {\n let lastElementFromPoint: Element | null = null\n let animationFrameRequestId = requestAnimationFrame(handleAnimationFrameRequest)\n\n return () => {\n cancelAnimationFrame(animationFrameRequestId)\n }\n\n function handleAnimationFrameRequest() {\n const pointer = getPointer(getState())\n const elementFromPoint =\n pointer == null ? null : document.elementFromPoint(pointer.x, pointer.y)\n\n if (elementFromPoint !== lastElementFromPoint) {\n lastElementFromPoint = elementFromPoint\n\n const keys = dispatch(elementKeysFromElementFromPoint(elementFromPoint))\n\n dispatch(Builder.elementFromPointChange(keys))\n }\n\n animationFrameRequestId = requestAnimationFrame(handleAnimationFrameRequest)\n }\n }\n}\n\nfunction registerBuilderComponents(): ThunkAction<() => void, State, unknown, Action> {\n return (dispatch, getState) => {\n const state = getState()\n const componentsMeta = ReadOnlyState.getComponentsMeta(state)\n\n componentsMeta.forEach((meta, type) => {\n const descriptors = ReadOnlyState.getComponentPropControllerDescriptors(state, type)\n if (descriptors != null) {\n const [serializedControls, transferables] = serializeControls(descriptors)\n dispatch(\n Builder.registerBuilderComponent({ type, meta, serializedControls }, transferables),\n )\n }\n })\n\n return () => {\n componentsMeta.forEach((_, type) => {\n dispatch(Builder.unregisterBuilderComponent({ type }))\n })\n }\n }\n}\n\nfunction registerBuilderDocuments(): ThunkAction<() => void, State, unknown, Action> {\n return (dispatch, getState) => {\n const documents = getDocuments(getState())\n\n documents.forEach(document => {\n dispatch(Builder.registerBuilderDocument(document))\n })\n\n return () => {\n documents.forEach((_document, documentKey) => {\n dispatch(Builder.unregisterBuilderDocument(documentKey))\n })\n }\n }\n}\n\nexport function initializeBuilderConnection(\n builderProxy: BuilderAPIProxy,\n): ThunkAction<() => void, State, unknown, Action> {\n return (dispatch, getState) => {\n const unregisterBuilderDocuments = dispatch(registerBuilderDocuments())\n const stopMeasuringElements = dispatch(startMeasuringElements())\n const stopMeasuringDocumentElement = dispatch(startMeasuringDocumentElement())\n const stopHandlingFocusEvent = dispatch(startHandlingFocusEvents())\n const unlockDocumentScroll = dispatch(lockDocumentScroll())\n const stopHandlingPointerMoveEvent = dispatch(startHandlingPointerMoveEvent())\n const stopPollingElementFromPoint = dispatch(startPollingElementFromPoint())\n const unregisterBuilderComponents = dispatch(registerBuilderComponents())\n\n const breakpoints = ReadOnlyState.getBreakpoints(getState())\n dispatch(Builder.setBreakpoints(breakpoints))\n\n const locale = ReadOnlyState.getLocale(getState())\n if (locale != null) dispatch(Builder.setLocale(new Intl.Locale(locale)))\n\n dispatch(ReadOnly.setIsInBuilder(true))\n builderProxy.dispatchBuffered()\n\n return () => {\n unregisterBuilderDocuments()\n stopMeasuringElements()\n stopMeasuringDocumentElement()\n stopHandlingFocusEvent()\n unlockDocumentScroll()\n stopHandlingPointerMoveEvent()\n stopPollingElementFromPoint()\n unregisterBuilderComponents()\n dispatch(ReadOnly.setIsInBuilder(false))\n }\n }\n}\n"],"mappings":"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","names":["document"]}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { updateElementTreeMiddleware } from "./update-element-tree";
|
|
2
|
-
import { measureBoxModelsMiddleware } from "./measure-box-models";
|
|
3
|
-
import { builderAPIMiddleware } from "./builder-api";
|
|
4
|
-
import { propControllerHandlesMiddleware } from "./prop-controller-handles";
|
|
5
|
-
function createReadWriteMiddleware({ builderProxy }) {
|
|
6
|
-
return [
|
|
7
|
-
updateElementTreeMiddleware(),
|
|
8
|
-
measureBoxModelsMiddleware(),
|
|
9
|
-
builderAPIMiddleware(builderProxy),
|
|
10
|
-
propControllerHandlesMiddleware()
|
|
11
|
-
];
|
|
12
|
-
}
|
|
13
|
-
export {
|
|
14
|
-
createReadWriteMiddleware
|
|
15
|
-
};
|
|
16
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../../src/state/middleware/read-write/index.ts"],"sourcesContent":["import { type BuilderAPIProxy } from '../../builder-api/proxy'\n\nimport { updateElementTreeMiddleware } from './update-element-tree'\nimport { measureBoxModelsMiddleware } from './measure-box-models'\nimport { builderAPIMiddleware } from './builder-api'\nimport { propControllerHandlesMiddleware } from './prop-controller-handles'\n\nexport function createReadWriteMiddleware({ builderProxy }: { builderProxy: BuilderAPIProxy }) {\n return [\n updateElementTreeMiddleware(),\n measureBoxModelsMiddleware(),\n builderAPIMiddleware(builderProxy),\n propControllerHandlesMiddleware(),\n ]\n}\n"],"mappings":"AAEA,SAAS,mCAAmC;AAC5C,SAAS,kCAAkC;AAC3C,SAAS,4BAA4B;AACrC,SAAS,uCAAuC;AAEzC,SAAS,0BAA0B,EAAE,aAAa,GAAsC;AAC7F,SAAO;AAAA,IACL,4BAA4B;AAAA,IAC5B,2BAA2B;AAAA,IAC3B,qBAAqB,YAAY;AAAA,IACjC,gCAAgC;AAAA,EAClC;AACF;","names":[]}
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
import * as BoxModels from "../../modules/read-write/box-models";
|
|
2
|
-
import { ReadOnlyActionTypes } from "../../actions/internal/read-only-actions";
|
|
3
|
-
import * as ReadWriteActions from "../../actions/internal/read-write-actions";
|
|
4
|
-
import { actionMiddleware } from "../../toolkit";
|
|
5
|
-
function measureBoxModelsMiddleware() {
|
|
6
|
-
return actionMiddleware(({ dispatch }) => (next) => {
|
|
7
|
-
return (action) => {
|
|
8
|
-
switch (action.type) {
|
|
9
|
-
case ReadOnlyActionTypes.REGISTER_COMPONENT_HANDLE: {
|
|
10
|
-
if (BoxModels.isMeasurable(action.payload.componentHandle)) {
|
|
11
|
-
dispatch(
|
|
12
|
-
ReadWriteActions.registerMeasurable(
|
|
13
|
-
action.payload.documentKey,
|
|
14
|
-
action.payload.elementKey,
|
|
15
|
-
action.payload.componentHandle
|
|
16
|
-
)
|
|
17
|
-
);
|
|
18
|
-
}
|
|
19
|
-
break;
|
|
20
|
-
}
|
|
21
|
-
case ReadOnlyActionTypes.UNREGISTER_COMPONENT_HANDLE:
|
|
22
|
-
dispatch(
|
|
23
|
-
ReadWriteActions.unregisterMeasurable(
|
|
24
|
-
action.payload.documentKey,
|
|
25
|
-
action.payload.elementKey
|
|
26
|
-
)
|
|
27
|
-
);
|
|
28
|
-
break;
|
|
29
|
-
}
|
|
30
|
-
return next(action);
|
|
31
|
-
};
|
|
32
|
-
});
|
|
33
|
-
}
|
|
34
|
-
export {
|
|
35
|
-
measureBoxModelsMiddleware
|
|
36
|
-
};
|
|
37
|
-
//# sourceMappingURL=measure-box-models.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../../src/state/middleware/read-write/measure-box-models.ts"],"sourcesContent":["import { type Middleware } from '@reduxjs/toolkit'\n\nimport * as BoxModels from '../../modules/read-write/box-models'\nimport { type Action } from '../../actions'\n\nimport { ReadOnlyActionTypes } from '../../actions/internal/read-only-actions'\nimport * as ReadWriteActions from '../../actions/internal/read-write-actions'\n\nimport { actionMiddleware } from '../../toolkit'\n\nimport { type State, type Dispatch } from '../../read-write-state'\n\nexport function measureBoxModelsMiddleware(): Middleware<Dispatch, State, Dispatch> {\n return actionMiddleware(({ dispatch }) => next => {\n return (action: Action) => {\n switch (action.type) {\n case ReadOnlyActionTypes.REGISTER_COMPONENT_HANDLE: {\n if (BoxModels.isMeasurable(action.payload.componentHandle)) {\n dispatch(\n ReadWriteActions.registerMeasurable(\n action.payload.documentKey,\n action.payload.elementKey,\n action.payload.componentHandle,\n ),\n )\n }\n\n break\n }\n\n case ReadOnlyActionTypes.UNREGISTER_COMPONENT_HANDLE:\n dispatch(\n ReadWriteActions.unregisterMeasurable(\n action.payload.documentKey,\n action.payload.elementKey,\n ),\n )\n break\n }\n\n return next(action)\n }\n })\n}\n"],"mappings":"AAEA,YAAY,eAAe;AAG3B,SAAS,2BAA2B;AACpC,YAAY,sBAAsB;AAElC,SAAS,wBAAwB;AAI1B,SAAS,6BAAoE;AAClF,SAAO,iBAAiB,CAAC,EAAE,SAAS,MAAM,UAAQ;AAChD,WAAO,CAAC,WAAmB;AACzB,cAAQ,OAAO,MAAM;AAAA,QACnB,KAAK,oBAAoB,2BAA2B;AAClD,cAAI,UAAU,aAAa,OAAO,QAAQ,eAAe,GAAG;AAC1D;AAAA,cACE,iBAAiB;AAAA,gBACf,OAAO,QAAQ;AAAA,gBACf,OAAO,QAAQ;AAAA,gBACf,OAAO,QAAQ;AAAA,cACjB;AAAA,YACF;AAAA,UACF;AAEA;AAAA,QACF;AAAA,QAEA,KAAK,oBAAoB;AACvB;AAAA,YACE,iBAAiB;AAAA,cACf,OAAO,QAAQ;AAAA,cACf,OAAO,QAAQ;AAAA,YACjB;AAAA,UACF;AACA;AAAA,MACJ;AAEA,aAAO,KAAK,MAAM;AAAA,IACpB;AAAA,EACF,CAAC;AACH;","names":[]}
|