@mittwald/flow-remote-core 0.2.0-alpha.82 → 0.2.0-alpha.821

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.
Files changed (92) hide show
  1. package/dist/js/core/src/file.mjs +16 -0
  2. package/dist/js/core/src/file.mjs.map +1 -0
  3. package/dist/js/index-node.mjs +16 -0
  4. package/dist/js/index-node.mjs.map +1 -0
  5. package/dist/js/index.mjs +15 -0
  6. package/dist/js/index.mjs.map +1 -0
  7. package/dist/js/remote-core/src/connection/connectHostRenderRoot.mjs +58 -0
  8. package/dist/js/remote-core/src/connection/connectHostRenderRoot.mjs.map +1 -0
  9. package/dist/js/remote-core/src/connection/connectRemoteIframe.mjs +75 -0
  10. package/dist/js/remote-core/src/connection/connectRemoteIframe.mjs.map +1 -0
  11. package/dist/js/remote-core/src/connection/types.mjs +10 -0
  12. package/dist/js/remote-core/src/connection/types.mjs.map +1 -0
  13. package/dist/js/remote-core/src/error.mjs +10 -0
  14. package/dist/js/remote-core/src/error.mjs.map +1 -0
  15. package/dist/js/remote-core/src/ext-bridge/getWithMergedHostConfig.mjs +10 -0
  16. package/dist/js/remote-core/src/ext-bridge/getWithMergedHostConfig.mjs.map +1 -0
  17. package/dist/js/remote-core/src/ext-bridge/implementation.mjs +13 -0
  18. package/dist/js/remote-core/src/ext-bridge/implementation.mjs.map +1 -0
  19. package/dist/js/remote-core/src/serialization/FlowThreadSerialization.mjs +60 -0
  20. package/dist/js/remote-core/src/serialization/FlowThreadSerialization.mjs.map +1 -0
  21. package/dist/js/remote-core/src/serialization/Serializer.mjs +36 -0
  22. package/dist/js/remote-core/src/serialization/Serializer.mjs.map +1 -0
  23. package/dist/js/remote-core/src/serialization/serializers/dataTransferText.mjs +23 -0
  24. package/dist/js/remote-core/src/serialization/serializers/dataTransferText.mjs.map +1 -0
  25. package/dist/js/remote-core/src/serialization/serializers/date.mjs +16 -0
  26. package/dist/js/remote-core/src/serialization/serializers/date.mjs.map +1 -0
  27. package/dist/js/remote-core/src/serialization/serializers/file.mjs +34 -0
  28. package/dist/js/remote-core/src/serialization/serializers/file.mjs.map +1 -0
  29. package/dist/js/remote-core/src/serialization/serializers/fileList.mjs +24 -0
  30. package/dist/js/remote-core/src/serialization/serializers/fileList.mjs.map +1 -0
  31. package/dist/js/remote-core/src/serialization/serializers/formData.mjs +36 -0
  32. package/dist/js/remote-core/src/serialization/serializers/formData.mjs.map +1 -0
  33. package/dist/js/remote-core/src/serialization/serializers/index.mjs +7 -0
  34. package/dist/js/remote-core/src/serialization/serializers/index.mjs.map +1 -0
  35. package/dist/js/remote-core/src/serialization/serializers/passwordPolicy.mjs +16 -0
  36. package/dist/js/remote-core/src/serialization/serializers/passwordPolicy.mjs.map +1 -0
  37. package/dist/js/remote-core/src/shim.mjs +16 -0
  38. package/dist/js/remote-core/src/shim.mjs.map +1 -0
  39. package/dist/types/connection/connectHostRenderRoot.d.ts +10 -6
  40. package/dist/types/connection/connectHostRenderRoot.d.ts.map +1 -1
  41. package/dist/types/connection/connectRemoteIframe.d.ts +12 -9
  42. package/dist/types/connection/connectRemoteIframe.d.ts.map +1 -1
  43. package/dist/types/connection/index.d.ts +4 -0
  44. package/dist/types/connection/index.d.ts.map +1 -0
  45. package/dist/types/connection/types.d.ts +43 -0
  46. package/dist/types/connection/types.d.ts.map +1 -0
  47. package/dist/types/error.d.ts +4 -0
  48. package/dist/types/error.d.ts.map +1 -0
  49. package/dist/types/ext-bridge/getWithMergedHostConfig.d.ts +5 -0
  50. package/dist/types/ext-bridge/getWithMergedHostConfig.d.ts.map +1 -0
  51. package/dist/types/ext-bridge/implementation.d.ts +3 -0
  52. package/dist/types/ext-bridge/implementation.d.ts.map +1 -0
  53. package/dist/types/index-node.d.ts +2 -0
  54. package/dist/types/index-node.d.ts.map +1 -0
  55. package/dist/types/index.d.ts +5 -6
  56. package/dist/types/index.d.ts.map +1 -1
  57. package/dist/types/serialization/FlowThreadSerialization.d.ts +7 -0
  58. package/dist/types/serialization/FlowThreadSerialization.d.ts.map +1 -0
  59. package/dist/types/serialization/FlowThreadSerialization.test.d.ts +2 -0
  60. package/dist/types/serialization/FlowThreadSerialization.test.d.ts.map +1 -0
  61. package/dist/types/serialization/Serialization.test.d.ts +2 -0
  62. package/dist/types/serialization/Serialization.test.d.ts.map +1 -0
  63. package/dist/types/serialization/Serializer.d.ts +28 -0
  64. package/dist/types/serialization/Serializer.d.ts.map +1 -0
  65. package/dist/types/serialization/index.d.ts +4 -0
  66. package/dist/types/serialization/index.d.ts.map +1 -0
  67. package/dist/types/serialization/serializers/dataTransferText.d.ts +3 -0
  68. package/dist/types/serialization/serializers/dataTransferText.d.ts.map +1 -0
  69. package/dist/types/serialization/serializers/date.d.ts +4 -0
  70. package/dist/types/serialization/serializers/date.d.ts.map +1 -0
  71. package/dist/types/serialization/serializers/file.d.ts +12 -0
  72. package/dist/types/serialization/serializers/file.d.ts.map +1 -0
  73. package/dist/types/serialization/serializers/fileList.d.ts +4 -0
  74. package/dist/types/serialization/serializers/fileList.d.ts.map +1 -0
  75. package/dist/types/serialization/serializers/formData.d.ts +3 -0
  76. package/dist/types/serialization/serializers/formData.d.ts.map +1 -0
  77. package/dist/types/serialization/serializers/index.d.ts +7 -0
  78. package/dist/types/serialization/serializers/index.d.ts.map +1 -0
  79. package/dist/types/serialization/serializers/passwordPolicy.d.ts +4 -0
  80. package/dist/types/serialization/serializers/passwordPolicy.d.ts.map +1 -0
  81. package/dist/types/shim.d.ts +2 -0
  82. package/dist/types/shim.d.ts.map +1 -0
  83. package/dist/types/tests/utils.d.ts +2 -0
  84. package/dist/types/tests/utils.d.ts.map +1 -0
  85. package/package.json +37 -19
  86. package/dist/index.js +0 -48
  87. package/dist/types/events/FlowRemoteEvent.d.ts +0 -4
  88. package/dist/types/events/FlowRemoteEvent.d.ts.map +0 -1
  89. package/dist/types/events/index.d.ts +0 -5
  90. package/dist/types/events/index.d.ts.map +0 -1
  91. package/dist/types/events/serializers.d.ts +0 -5
  92. package/dist/types/events/serializers.d.ts.map +0 -1
@@ -0,0 +1,16 @@
1
+ import invariant from 'invariant';
2
+
3
+ const Key = "mittwald.flow-core.file.awaitedArrayBuffer";
4
+ function isFileWithAwaitedArrayBuffer(file) {
5
+ return Key in file && file[Key] instanceof ArrayBuffer && !file[Key].detached;
6
+ }
7
+ const getAwaitArrayBuffer = (file) => {
8
+ invariant(
9
+ isFileWithAwaitedArrayBuffer(file),
10
+ "Could not get awaited ArrayBuffer from file"
11
+ );
12
+ return file[Key];
13
+ };
14
+
15
+ export { getAwaitArrayBuffer, isFileWithAwaitedArrayBuffer };
16
+ //# sourceMappingURL=file.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"file.mjs","sources":["../../../../../core/src/file.ts"],"sourcesContent":["import invariant from \"invariant\";\n\nconst Key = \"mittwald.flow-core.file.awaitedArrayBuffer\";\n\nexport type FileWithAwaitedArrayBuffer = File & {\n [Key]: ArrayBuffer;\n};\n\nexport function isFileWithAwaitedArrayBuffer(\n file: File | FileWithAwaitedArrayBuffer,\n): file is FileWithAwaitedArrayBuffer {\n return Key in file && file[Key] instanceof ArrayBuffer && !file[Key].detached;\n}\n\nexport const addAwaitedArrayBuffer = async (file: File) => {\n if (isFileWithAwaitedArrayBuffer(file)) {\n return file;\n }\n\n const arrayBuffer = await file.arrayBuffer();\n Object.assign(file, { [Key]: arrayBuffer });\n\n return file;\n};\n\nexport const getAwaitArrayBuffer = (\n file: File | FileWithAwaitedArrayBuffer,\n) => {\n invariant(\n isFileWithAwaitedArrayBuffer(file),\n \"Could not get awaited ArrayBuffer from file\",\n );\n return file[Key];\n};\n"],"names":[],"mappings":";;AAEA,MAAM,GAAA,GAAM,4CAAA;AAML,SAAS,6BACd,IAAA,EACoC;AACpC,EAAA,OAAO,GAAA,IAAO,QAAQ,IAAA,CAAK,GAAG,aAAa,WAAA,IAAe,CAAC,IAAA,CAAK,GAAG,CAAA,CAAE,QAAA;AACvE;AAaO,MAAM,mBAAA,GAAsB,CACjC,IAAA,KACG;AACH,EAAA,SAAA;AAAA,IACE,6BAA6B,IAAI,CAAA;AAAA,IACjC;AAAA,GACF;AACA,EAAA,OAAO,KAAK,GAAG,CAAA;AACjB;;;;"}
@@ -0,0 +1,16 @@
1
+ import './remote-core/src/shim.mjs';
2
+ export { RemoteReceiver } from '@mittwald/remote-dom-core/receivers';
3
+ export { RemoteElement, RemoteEvent } from '@mittwald/remote-dom-core/elements';
4
+ export { calendarDateSerializer } from './remote-core/src/serialization/serializers/date.mjs';
5
+ export { fileDeSerialize, fileSerialize, fileSerializer, isSerializedFile } from './remote-core/src/serialization/serializers/file.mjs';
6
+ export { fileListSerializer } from './remote-core/src/serialization/serializers/fileList.mjs';
7
+ export { dataTransferTextSerializer } from './remote-core/src/serialization/serializers/dataTransferText.mjs';
8
+ export { formDataSerializer } from './remote-core/src/serialization/serializers/formData.mjs';
9
+ export { passwordPolicySerializer } from './remote-core/src/serialization/serializers/passwordPolicy.mjs';
10
+ export { FlowThreadSerialization } from './remote-core/src/serialization/FlowThreadSerialization.mjs';
11
+ export { Serializer } from './remote-core/src/serialization/Serializer.mjs';
12
+ export { connectHostRenderRoot, connectHostRenderRootRef, connectRemoteReceiver } from './remote-core/src/connection/connectHostRenderRoot.mjs';
13
+ export { connectRemoteIframe, connectRemoteIframeRef } from './remote-core/src/connection/connectRemoteIframe.mjs';
14
+ export { Version } from './remote-core/src/connection/types.mjs';
15
+ export { RemoteError } from './remote-core/src/error.mjs';
16
+ //# sourceMappingURL=index-node.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-node.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;"}
@@ -0,0 +1,15 @@
1
+ export { RemoteReceiver } from '@mittwald/remote-dom-core/receivers';
2
+ export { RemoteElement, RemoteEvent } from '@mittwald/remote-dom-core/elements';
3
+ export { calendarDateSerializer } from './remote-core/src/serialization/serializers/date.mjs';
4
+ export { fileDeSerialize, fileSerialize, fileSerializer, isSerializedFile } from './remote-core/src/serialization/serializers/file.mjs';
5
+ export { fileListSerializer } from './remote-core/src/serialization/serializers/fileList.mjs';
6
+ export { dataTransferTextSerializer } from './remote-core/src/serialization/serializers/dataTransferText.mjs';
7
+ export { formDataSerializer } from './remote-core/src/serialization/serializers/formData.mjs';
8
+ export { passwordPolicySerializer } from './remote-core/src/serialization/serializers/passwordPolicy.mjs';
9
+ export { FlowThreadSerialization } from './remote-core/src/serialization/FlowThreadSerialization.mjs';
10
+ export { Serializer } from './remote-core/src/serialization/Serializer.mjs';
11
+ export { connectHostRenderRoot, connectHostRenderRootRef, connectRemoteReceiver } from './remote-core/src/connection/connectHostRenderRoot.mjs';
12
+ export { connectRemoteIframe, connectRemoteIframeRef } from './remote-core/src/connection/connectRemoteIframe.mjs';
13
+ export { Version } from './remote-core/src/connection/types.mjs';
14
+ export { RemoteError } from './remote-core/src/error.mjs';
15
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;"}
@@ -0,0 +1,58 @@
1
+ import { Version } from './types.mjs';
2
+ import { RemoteError } from '../error.mjs';
3
+ import { FlowThreadSerialization } from '../serialization/FlowThreadSerialization.mjs';
4
+ import '@mittwald/remote-dom-core/elements';
5
+ import { ThreadNestedIframe } from '@quilted/threads';
6
+
7
+ const incompatibleParentFrameError = () => new RemoteError("Could not find any compatible parent frame");
8
+ const connectRemoteReceiver = (root, receiverConnection) => import('@mittwald/remote-dom-core/elements').then(
9
+ ({ RemoteMutationObserver }) => {
10
+ const observer = new RemoteMutationObserver(receiverConnection);
11
+ observer.observe(root);
12
+ }
13
+ );
14
+ const connectHostRenderRoot = async (options) => {
15
+ const { root, onPathnameChanged } = options;
16
+ const connection = new ThreadNestedIframe({
17
+ serialization: new FlowThreadSerialization(),
18
+ exports: {
19
+ render: (connection2) => connectRemoteReceiver(root, connection2),
20
+ setPathname: async (pathname) => {
21
+ onPathnameChanged?.(pathname);
22
+ }
23
+ }
24
+ });
25
+ if (connection.parent === window) {
26
+ throw incompatibleParentFrameError();
27
+ }
28
+ try {
29
+ await connection.imports.setIsReady(Version.v3);
30
+ if (typeof mwExtBridge !== "undefined") {
31
+ mwExtBridge.connection = connection.imports;
32
+ await mwExtBridge.readiness.setIsReady();
33
+ }
34
+ return connection;
35
+ } catch (error) {
36
+ if (error instanceof Error && /No '.*' method is exported from this thread/.test(error.message)) {
37
+ throw incompatibleParentFrameError();
38
+ }
39
+ throw error;
40
+ }
41
+ };
42
+ const connectHostRenderRootRef = (opts) => (ref) => {
43
+ if (ref === null) {
44
+ return;
45
+ }
46
+ if ("__remoteConnection" in ref) {
47
+ return ref["__remoteConnection"];
48
+ }
49
+ const connection = connectHostRenderRoot({
50
+ root: ref,
51
+ ...opts
52
+ });
53
+ Object.assign(ref, { __remoteConnection: connection });
54
+ return connection;
55
+ };
56
+
57
+ export { connectHostRenderRoot, connectHostRenderRootRef, connectRemoteReceiver };
58
+ //# sourceMappingURL=connectHostRenderRoot.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connectHostRenderRoot.mjs","sources":["../../../../../src/connection/connectHostRenderRoot.ts"],"sourcesContent":["import {\n Version,\n type HostExports,\n type RemoteExports,\n type RemoteToHostConnection,\n} from \"@/connection/types\";\nimport { RemoteError } from \"@/error\";\nimport { FlowThreadSerialization } from \"@/serialization/FlowThreadSerialization\";\nimport { type RemoteConnection } from \"@mittwald/remote-dom-core/elements\";\nimport { ThreadNestedIframe } from \"@quilted/threads\";\n\ninterface Options {\n root: HTMLDivElement;\n onPathnameChanged?: (pathname: string) => void;\n}\n\nconst incompatibleParentFrameError = () =>\n new RemoteError(\"Could not find any compatible parent frame\");\n\nexport const connectRemoteReceiver = (\n root: HTMLDivElement,\n receiverConnection: RemoteConnection,\n) =>\n import(\"@mittwald/remote-dom-core/elements\").then(\n ({ RemoteMutationObserver }) => {\n const observer = new RemoteMutationObserver(receiverConnection);\n observer.observe(root);\n },\n );\n\nexport const connectHostRenderRoot = async (\n options: Options,\n): Promise<RemoteToHostConnection> => {\n const { root, onPathnameChanged } = options;\n\n const connection = new ThreadNestedIframe<HostExports, RemoteExports>({\n serialization: new FlowThreadSerialization(),\n exports: {\n render: (connection: RemoteConnection) =>\n connectRemoteReceiver(root, connection),\n setPathname: async (pathname) => {\n onPathnameChanged?.(pathname);\n },\n },\n });\n\n if (connection.parent === window) {\n throw incompatibleParentFrameError();\n }\n\n try {\n await connection.imports.setIsReady(Version.v3);\n\n if (typeof mwExtBridge !== \"undefined\") {\n mwExtBridge.connection = connection.imports;\n await mwExtBridge.readiness.setIsReady();\n }\n\n return connection;\n } catch (error) {\n if (\n error instanceof Error &&\n /No '.*' method is exported from this thread/.test(error.message)\n ) {\n throw incompatibleParentFrameError();\n }\n throw error;\n }\n};\n\nexport const connectHostRenderRootRef =\n (opts: Omit<Options, \"root\">) => (ref: HTMLDivElement | null) => {\n if (ref === null) {\n return;\n }\n if (\"__remoteConnection\" in ref) {\n return ref[\"__remoteConnection\"] as Promise<RemoteToHostConnection>;\n }\n\n const connection = connectHostRenderRoot({\n root: ref,\n ...opts,\n });\n Object.assign(ref, { __remoteConnection: connection });\n return connection;\n };\n"],"names":["connection"],"mappings":";;;;;;AAgBA,MAAM,4BAAA,GAA+B,MACnC,IAAI,WAAA,CAAY,4CAA4C,CAAA;AAEvD,MAAM,wBAAwB,CACnC,IAAA,EACA,kBAAA,KAEA,OAAO,oCAAoC,CAAA,CAAE,IAAA;AAAA,EAC3C,CAAC,EAAE,sBAAA,EAAuB,KAAM;AAC9B,IAAA,MAAM,QAAA,GAAW,IAAI,sBAAA,CAAuB,kBAAkB,CAAA;AAC9D,IAAA,QAAA,CAAS,QAAQ,IAAI,CAAA;AAAA,EACvB;AACF;AAEK,MAAM,qBAAA,GAAwB,OACnC,OAAA,KACoC;AACpC,EAAA,MAAM,EAAE,IAAA,EAAM,iBAAA,EAAkB,GAAI,OAAA;AAEpC,EAAA,MAAM,UAAA,GAAa,IAAI,kBAAA,CAA+C;AAAA,IACpE,aAAA,EAAe,IAAI,uBAAA,EAAwB;AAAA,IAC3C,OAAA,EAAS;AAAA,MACP,MAAA,EAAQ,CAACA,WAAAA,KACP,qBAAA,CAAsB,MAAMA,WAAU,CAAA;AAAA,MACxC,WAAA,EAAa,OAAO,QAAA,KAAa;AAC/B,QAAA,iBAAA,GAAoB,QAAQ,CAAA;AAAA,MAC9B;AAAA;AACF,GACD,CAAA;AAED,EAAA,IAAI,UAAA,CAAW,WAAW,MAAA,EAAQ;AAChC,IAAA,MAAM,4BAAA,EAA6B;AAAA,EACrC;AAEA,EAAA,IAAI;AACF,IAAA,MAAM,UAAA,CAAW,OAAA,CAAQ,UAAA,CAAW,OAAA,CAAQ,EAAE,CAAA;AAE9C,IAAA,IAAI,OAAO,gBAAgB,WAAA,EAAa;AACtC,MAAA,WAAA,CAAY,aAAa,UAAA,CAAW,OAAA;AACpC,MAAA,MAAM,WAAA,CAAY,UAAU,UAAA,EAAW;AAAA,IACzC;AAEA,IAAA,OAAO,UAAA;AAAA,EACT,SAAS,KAAA,EAAO;AACd,IAAA,IACE,iBAAiB,KAAA,IACjB,6CAAA,CAA8C,IAAA,CAAK,KAAA,CAAM,OAAO,CAAA,EAChE;AACA,MAAA,MAAM,4BAAA,EAA6B;AAAA,IACrC;AACA,IAAA,MAAM,KAAA;AAAA,EACR;AACF;AAEO,MAAM,wBAAA,GACX,CAAC,IAAA,KAAgC,CAAC,GAAA,KAA+B;AAC/D,EAAA,IAAI,QAAQ,IAAA,EAAM;AAChB,IAAA;AAAA,EACF;AACA,EAAA,IAAI,wBAAwB,GAAA,EAAK;AAC/B,IAAA,OAAO,IAAI,oBAAoB,CAAA;AAAA,EACjC;AAEA,EAAA,MAAM,aAAa,qBAAA,CAAsB;AAAA,IACvC,IAAA,EAAM,GAAA;AAAA,IACN,GAAG;AAAA,GACJ,CAAA;AACD,EAAA,MAAA,CAAO,MAAA,CAAO,GAAA,EAAK,EAAE,kBAAA,EAAoB,YAAY,CAAA;AACrD,EAAA,OAAO,UAAA;AACT;;;;"}
@@ -0,0 +1,75 @@
1
+ import { Version } from './types.mjs';
2
+ import { getWithMergedHostConfig } from '../ext-bridge/getWithMergedHostConfig.mjs';
3
+ import { emptyImplementation } from '../ext-bridge/implementation.mjs';
4
+ import { FlowThreadSerialization } from '../serialization/FlowThreadSerialization.mjs';
5
+ import 'invariant';
6
+ import { ThreadIframe } from '@quilted/threads';
7
+
8
+ const connectRemoteIframe = (opts) => {
9
+ const {
10
+ connection,
11
+ iframe,
12
+ onReady,
13
+ onLoadingChanged,
14
+ onError,
15
+ onNavigationStateChanged,
16
+ extBridgeImplementation: extBridgeImplementationProp = emptyImplementation,
17
+ hostConfig
18
+ } = opts;
19
+ const extBridgeImplementation = {
20
+ ...extBridgeImplementationProp,
21
+ getConfig: getWithMergedHostConfig(extBridgeImplementationProp, hostConfig)
22
+ };
23
+ const result = {
24
+ thread: new ThreadIframe(iframe, {
25
+ serialization: new FlowThreadSerialization(),
26
+ exports: {
27
+ ...extBridgeImplementation,
28
+ setIsReady: async (version = Version.v1) => {
29
+ result.version = version;
30
+ onReady?.(result);
31
+ },
32
+ setIsLoading: async (isLoading) => {
33
+ onLoadingChanged?.(isLoading);
34
+ },
35
+ setError: async (error) => {
36
+ onError?.(error);
37
+ },
38
+ setNavigationState: async (state) => {
39
+ onNavigationStateChanged?.(state);
40
+ },
41
+ getHostConfig: async () => {
42
+ return hostConfig;
43
+ }
44
+ }
45
+ }),
46
+ updateHostPathname: (hostPathname) => {
47
+ if (hostPathname === void 0) {
48
+ return;
49
+ }
50
+ if (result.version >= Version.v2) {
51
+ result.thread.imports.setPathname(hostPathname);
52
+ }
53
+ },
54
+ version: 0
55
+ };
56
+ result.thread.imports.render(connection);
57
+ return result;
58
+ };
59
+ const connectRemoteIframeRef = (opts) => (ref) => {
60
+ if (!ref) {
61
+ return;
62
+ }
63
+ if ("__remoteConnection" in ref) {
64
+ return ref["__remoteConnection"];
65
+ }
66
+ const connection = connectRemoteIframe({
67
+ iframe: ref,
68
+ ...opts
69
+ });
70
+ Object.assign(ref, { __remoteConnection: connection });
71
+ return connection;
72
+ };
73
+
74
+ export { connectRemoteIframe, connectRemoteIframeRef };
75
+ //# sourceMappingURL=connectRemoteIframe.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connectRemoteIframe.mjs","sources":["../../../../../src/connection/connectRemoteIframe.ts"],"sourcesContent":["import {\n Version,\n type HostExports,\n type HostToRemoteConnection,\n type NavigationState,\n type RemoteExports,\n type RemoteExtBridgeConnectionApi,\n} from \"@/connection/types\";\nimport { getWithMergedHostConfig } from \"@/ext-bridge/getWithMergedHostConfig\";\nimport { emptyImplementation } from \"@/ext-bridge/implementation\";\nimport { FlowThreadSerialization } from \"@/serialization/FlowThreadSerialization\";\nimport { type HostConfig } from \"@mittwald/flow-core\";\nimport type { RemoteConnection } from \"@mittwald/remote-dom-core/elements\";\nimport { ThreadIframe } from \"@quilted/threads\";\n\ninterface Options {\n connection: RemoteConnection;\n iframe: HTMLIFrameElement;\n hostConfig: HostConfig;\n onReady?: (connection: HostToRemoteConnection) => void;\n onLoadingChanged?: (isLoading: boolean) => void;\n onError?: (error: string) => void;\n onNavigationStateChanged?: (state: NavigationState) => void;\n extBridgeImplementation?: RemoteExtBridgeConnectionApi;\n}\n\nexport const connectRemoteIframe = (opts: Options): HostToRemoteConnection => {\n const {\n connection,\n iframe,\n onReady,\n onLoadingChanged,\n onError,\n onNavigationStateChanged,\n extBridgeImplementation: extBridgeImplementationProp = emptyImplementation,\n hostConfig,\n } = opts;\n\n const extBridgeImplementation = {\n ...extBridgeImplementationProp,\n getConfig: getWithMergedHostConfig(extBridgeImplementationProp, hostConfig),\n };\n\n const result = {\n thread: new ThreadIframe<RemoteExports, HostExports>(iframe, {\n serialization: new FlowThreadSerialization(),\n exports: {\n ...extBridgeImplementation,\n setIsReady: async (version = Version.v1) => {\n result.version = version;\n onReady?.(result);\n },\n setIsLoading: async (isLoading: boolean) => {\n onLoadingChanged?.(isLoading);\n },\n setError: async (error: string) => {\n onError?.(error);\n },\n setNavigationState: async (state) => {\n onNavigationStateChanged?.(state);\n },\n getHostConfig: async () => {\n return hostConfig;\n },\n },\n }),\n updateHostPathname: (hostPathname?: string) => {\n if (hostPathname === undefined) {\n return;\n }\n\n if (result.version >= Version.v2) {\n result.thread.imports.setPathname(hostPathname);\n }\n },\n version: 0,\n };\n\n result.thread.imports.render(connection);\n return result;\n};\n\nexport const connectRemoteIframeRef =\n (opts: Omit<Options, \"iframe\">) => (ref: HTMLIFrameElement | null) => {\n if (!ref) {\n return;\n }\n\n if (\"__remoteConnection\" in ref) {\n return ref[\"__remoteConnection\"] as HostToRemoteConnection;\n }\n\n const connection = connectRemoteIframe({\n iframe: ref,\n ...opts,\n });\n Object.assign(ref, { __remoteConnection: connection });\n return connection;\n };\n"],"names":[],"mappings":";;;;;;;AA0BO,MAAM,mBAAA,GAAsB,CAAC,IAAA,KAA0C;AAC5E,EAAA,MAAM;AAAA,IACJ,UAAA;AAAA,IACA,MAAA;AAAA,IACA,OAAA;AAAA,IACA,gBAAA;AAAA,IACA,OAAA;AAAA,IACA,wBAAA;AAAA,IACA,yBAAyB,2BAAA,GAA8B,mBAAA;AAAA,IACvD;AAAA,GACF,GAAI,IAAA;AAEJ,EAAA,MAAM,uBAAA,GAA0B;AAAA,IAC9B,GAAG,2BAAA;AAAA,IACH,SAAA,EAAW,uBAAA,CAAwB,2BAAA,EAA6B,UAAU;AAAA,GAC5E;AAEA,EAAA,MAAM,MAAA,GAAS;AAAA,IACb,MAAA,EAAQ,IAAI,YAAA,CAAyC,MAAA,EAAQ;AAAA,MAC3D,aAAA,EAAe,IAAI,uBAAA,EAAwB;AAAA,MAC3C,OAAA,EAAS;AAAA,QACP,GAAG,uBAAA;AAAA,QACH,UAAA,EAAY,OAAO,OAAA,GAAU,OAAA,CAAQ,EAAA,KAAO;AAC1C,UAAA,MAAA,CAAO,OAAA,GAAU,OAAA;AACjB,UAAA,OAAA,GAAU,MAAM,CAAA;AAAA,QAClB,CAAA;AAAA,QACA,YAAA,EAAc,OAAO,SAAA,KAAuB;AAC1C,UAAA,gBAAA,GAAmB,SAAS,CAAA;AAAA,QAC9B,CAAA;AAAA,QACA,QAAA,EAAU,OAAO,KAAA,KAAkB;AACjC,UAAA,OAAA,GAAU,KAAK,CAAA;AAAA,QACjB,CAAA;AAAA,QACA,kBAAA,EAAoB,OAAO,KAAA,KAAU;AACnC,UAAA,wBAAA,GAA2B,KAAK,CAAA;AAAA,QAClC,CAAA;AAAA,QACA,eAAe,YAAY;AACzB,UAAA,OAAO,UAAA;AAAA,QACT;AAAA;AACF,KACD,CAAA;AAAA,IACD,kBAAA,EAAoB,CAAC,YAAA,KAA0B;AAC7C,MAAA,IAAI,iBAAiB,MAAA,EAAW;AAC9B,QAAA;AAAA,MACF;AAEA,MAAA,IAAI,MAAA,CAAO,OAAA,IAAW,OAAA,CAAQ,EAAA,EAAI;AAChC,QAAA,MAAA,CAAO,MAAA,CAAO,OAAA,CAAQ,WAAA,CAAY,YAAY,CAAA;AAAA,MAChD;AAAA,IACF,CAAA;AAAA,IACA,OAAA,EAAS;AAAA,GACX;AAEA,EAAA,MAAA,CAAO,MAAA,CAAO,OAAA,CAAQ,MAAA,CAAO,UAAU,CAAA;AACvC,EAAA,OAAO,MAAA;AACT;AAEO,MAAM,sBAAA,GACX,CAAC,IAAA,KAAkC,CAAC,GAAA,KAAkC;AACpE,EAAA,IAAI,CAAC,GAAA,EAAK;AACR,IAAA;AAAA,EACF;AAEA,EAAA,IAAI,wBAAwB,GAAA,EAAK;AAC/B,IAAA,OAAO,IAAI,oBAAoB,CAAA;AAAA,EACjC;AAEA,EAAA,MAAM,aAAa,mBAAA,CAAoB;AAAA,IACrC,MAAA,EAAQ,GAAA;AAAA,IACR,GAAG;AAAA,GACJ,CAAA;AACD,EAAA,MAAA,CAAO,MAAA,CAAO,GAAA,EAAK,EAAE,kBAAA,EAAoB,YAAY,CAAA;AACrD,EAAA,OAAO,UAAA;AACT;;;;"}
@@ -0,0 +1,10 @@
1
+ var Version = /* @__PURE__ */ ((Version2) => {
2
+ Version2[Version2["vUnknown"] = 0] = "vUnknown";
3
+ Version2[Version2["v1"] = 1] = "v1";
4
+ Version2[Version2["v2"] = 2] = "v2";
5
+ Version2[Version2["v3"] = 3] = "v3";
6
+ return Version2;
7
+ })(Version || {});
8
+
9
+ export { Version };
10
+ //# sourceMappingURL=types.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.mjs","sources":["../../../../../src/connection/types.ts"],"sourcesContent":["import type {\n ExtBridgeConfigInput,\n ExtBridgeConnectionApi,\n} from \"@mittwald/ext-bridge\";\nimport type { HostConfig } from \"@mittwald/flow-core\";\nimport type { RemoteConnection } from \"@mittwald/remote-dom-core\";\nimport type { ThreadIframe, ThreadNestedIframe } from \"@quilted/threads\";\nexport type { RemoteConnection } from \"@mittwald/remote-dom-core\";\n\nexport interface NavigationState {\n pathname: string;\n isPending: boolean;\n}\n\nexport type RemoteExtBridgeConfig = Omit<\n ExtBridgeConfigInput,\n keyof HostConfig\n>;\n\nexport interface RemoteExtBridgeConnectionApi extends Omit<\n ExtBridgeConnectionApi,\n \"getConfig\"\n> {\n getConfig: () => Promise<RemoteExtBridgeConfig>;\n}\n\n/**\n * Breaking Change warning: Do not remove/rename/modify existing properties of\n * this interface, as they might be used by existing extensions.\n *\n * When addding properties, make sure to release the host before all clients.\n */\nexport interface HostExports extends ExtBridgeConnectionApi {\n setIsReady: (version?: Version) => Promise<void>;\n setIsLoading: (isLoading: boolean) => Promise<void>;\n setError: (error: string) => Promise<void>;\n setNavigationState: (state: NavigationState) => Promise<void>;\n getHostConfig: () => Promise<HostConfig>;\n}\n\nexport interface RemoteExports {\n render: (connection: RemoteConnection) => Promise<void>;\n setPathname: (pathname: string) => Promise<void>;\n}\n\nexport type RemoteToHostConnection = ThreadNestedIframe<\n HostExports,\n RemoteExports\n>;\n\nexport interface HostToRemoteConnection {\n version: Version;\n thread: ThreadIframe<RemoteExports, HostExports>;\n updateHostPathname: (hostPathname?: string) => void;\n}\n\nexport enum Version {\n vUnknown = 0,\n v1 = 1,\n v2 = 2,\n v3 = 3,\n}\n"],"names":["Version"],"mappings":"AAwDO,IAAK,OAAA,qBAAAA,QAAAA,KAAL;AACL,EAAAA,QAAAA,CAAAA,QAAAA,CAAA,cAAW,CAAA,CAAA,GAAX,UAAA;AACA,EAAAA,QAAAA,CAAAA,QAAAA,CAAA,QAAK,CAAA,CAAA,GAAL,IAAA;AACA,EAAAA,QAAAA,CAAAA,QAAAA,CAAA,QAAK,CAAA,CAAA,GAAL,IAAA;AACA,EAAAA,QAAAA,CAAAA,QAAAA,CAAA,QAAK,CAAA,CAAA,GAAL,IAAA;AAJU,EAAA,OAAAA,QAAAA;AAAA,CAAA,EAAA,OAAA,IAAA,EAAA;;;;"}
@@ -0,0 +1,10 @@
1
+ class RemoteError extends Error {
2
+ constructor(message) {
3
+ super(message);
4
+ this.message = message;
5
+ }
6
+ }
7
+ RemoteError.prototype.name = "RemoteError";
8
+
9
+ export { RemoteError };
10
+ //# sourceMappingURL=error.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"error.mjs","sources":["../../../../src/error.ts"],"sourcesContent":["export class RemoteError extends Error {\n constructor(message: string) {\n super(message);\n this.message = message;\n }\n}\n\nRemoteError.prototype.name = \"RemoteError\";\n"],"names":[],"mappings":"AAAO,MAAM,oBAAoB,KAAA,CAAM;AAAA,EACrC,YAAY,OAAA,EAAiB;AAC3B,IAAA,KAAA,CAAM,OAAO,CAAA;AACb,IAAA,IAAA,CAAK,OAAA,GAAU,OAAA;AAAA,EACjB;AACF;AAEA,WAAA,CAAY,UAAU,IAAA,GAAO,aAAA;;;;"}
@@ -0,0 +1,10 @@
1
+ const getWithMergedHostConfig = (extBridgeConnection, hostConfig) => async () => {
2
+ const baseConfig = await extBridgeConnection.getConfig();
3
+ return {
4
+ ...hostConfig,
5
+ ...baseConfig
6
+ };
7
+ };
8
+
9
+ export { getWithMergedHostConfig };
10
+ //# sourceMappingURL=getWithMergedHostConfig.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getWithMergedHostConfig.mjs","sources":["../../../../../src/ext-bridge/getWithMergedHostConfig.ts"],"sourcesContent":["import type { RemoteExtBridgeConnectionApi } from \"@/connection\";\nimport type { ExtBridgeConfigInput } from \"@mittwald/ext-bridge\";\nimport type { HostConfig } from \"@mittwald/flow-core\";\n\nexport const getWithMergedHostConfig =\n (extBridgeConnection: RemoteExtBridgeConnectionApi, hostConfig: HostConfig) =>\n async (): Promise<ExtBridgeConfigInput> => {\n const baseConfig = await extBridgeConnection.getConfig();\n\n return {\n ...hostConfig,\n ...baseConfig,\n };\n };\n"],"names":[],"mappings":"AAIO,MAAM,uBAAA,GACX,CAAC,mBAAA,EAAmD,UAAA,KACpD,YAA2C;AACzC,EAAA,MAAM,UAAA,GAAa,MAAM,mBAAA,CAAoB,SAAA,EAAU;AAEvD,EAAA,OAAO;AAAA,IACL,GAAG,UAAA;AAAA,IACH,GAAG;AAAA,GACL;AACF;;;;"}
@@ -0,0 +1,13 @@
1
+ import { RemoteError } from '../error.mjs';
2
+
3
+ const emptyImplementation = new Proxy(
4
+ {},
5
+ {
6
+ get() {
7
+ throw new RemoteError("Missing implementation for mittwald.extBridge");
8
+ }
9
+ }
10
+ );
11
+
12
+ export { emptyImplementation };
13
+ //# sourceMappingURL=implementation.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"implementation.mjs","sources":["../../../../../src/ext-bridge/implementation.ts"],"sourcesContent":["import { RemoteError } from \"@/error\";\nimport type { ExtBridgeConnectionApi } from \"@mittwald/ext-bridge\";\n\nexport const emptyImplementation = new Proxy(\n {},\n {\n get() {\n throw new RemoteError(\"Missing implementation for mittwald.extBridge\");\n },\n },\n) as ExtBridgeConnectionApi;\n"],"names":[],"mappings":";;AAGO,MAAM,sBAAsB,IAAI,KAAA;AAAA,EACrC,EAAC;AAAA,EACD;AAAA,IACE,GAAA,GAAM;AACJ,MAAA,MAAM,IAAI,YAAY,+CAA+C,CAAA;AAAA,IACvE;AAAA;AAEJ;;;;"}
@@ -0,0 +1,60 @@
1
+ import { ThreadSerializationStructuredClone, TRANSFERABLE } from '@quilted/threads';
2
+ import * as index from './serializers/index.mjs';
3
+ import { isObjectType } from 'remeda';
4
+ import { Serializer } from './Serializer.mjs';
5
+
6
+ const serializers = Object.values(index).filter(
7
+ (val) => val instanceof Serializer
8
+ );
9
+ class FlowThreadSerialization extends ThreadSerializationStructuredClone {
10
+ constructor() {
11
+ const options = {
12
+ serialize: (val, serialize) => {
13
+ try {
14
+ if (this.isSerializableByBase(val)) {
15
+ return;
16
+ }
17
+ if (this.omitSerialization(val)) {
18
+ return null;
19
+ }
20
+ for (const serializer of serializers) {
21
+ const serialization = serializer.serialize(val);
22
+ if (serialization.applied) {
23
+ return serialize(serialization.result);
24
+ }
25
+ }
26
+ if (isObjectType(val)) {
27
+ return serialize({ ...val });
28
+ }
29
+ } catch (error) {
30
+ console.error("Error while serializing", error);
31
+ throw error;
32
+ }
33
+ },
34
+ deserialize: (val, serialize) => {
35
+ try {
36
+ for (const serializer of serializers) {
37
+ const deserialization = serializer.deserialize(val);
38
+ if (deserialization.applied) {
39
+ return deserialization.result.value;
40
+ }
41
+ }
42
+ return serialize(val);
43
+ } catch (error) {
44
+ console.error("Error while deserializing", error);
45
+ throw error;
46
+ }
47
+ }
48
+ };
49
+ super(options);
50
+ }
51
+ isSerializableByBase(val) {
52
+ return val instanceof Map || val instanceof Set || Array.isArray(val) || typeof val === "function" || isObjectType(val) && TRANSFERABLE in val;
53
+ }
54
+ omitSerialization(val) {
55
+ return val instanceof HTMLElement || val === window;
56
+ }
57
+ }
58
+
59
+ export { FlowThreadSerialization };
60
+ //# sourceMappingURL=FlowThreadSerialization.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FlowThreadSerialization.mjs","sources":["../../../../../src/serialization/FlowThreadSerialization.ts"],"sourcesContent":["import {\n ThreadSerializationStructuredClone,\n type ThreadSerializationOptions,\n TRANSFERABLE,\n} from \"@quilted/threads\";\nimport * as serializerModules from \"./serializers\";\nimport { isObjectType } from \"remeda\";\nimport { Serializer } from \"@/serialization/Serializer\";\n\nconst serializers = Object.values(serializerModules).filter(\n (val) => val instanceof Serializer,\n);\n\nexport class FlowThreadSerialization extends ThreadSerializationStructuredClone {\n public constructor() {\n const options: ThreadSerializationOptions = {\n serialize: (val, serialize) => {\n try {\n if (this.isSerializableByBase(val)) {\n return;\n }\n if (this.omitSerialization(val)) {\n return null;\n }\n for (const serializer of serializers) {\n const serialization = serializer.serialize(val);\n if (serialization.applied) {\n return serialize(serialization.result);\n }\n }\n if (isObjectType(val)) {\n return serialize({ ...val });\n }\n } catch (error) {\n console.error(\"Error while serializing\", error);\n throw error;\n }\n },\n deserialize: (val, serialize) => {\n try {\n for (const serializer of serializers) {\n const deserialization = serializer.deserialize(val);\n if (deserialization.applied) {\n return deserialization.result.value;\n }\n }\n return serialize(val);\n } catch (error) {\n console.error(\"Error while deserializing\", error);\n throw error;\n }\n },\n };\n super(options);\n }\n\n private isSerializableByBase(val: unknown) {\n return (\n val instanceof Map ||\n val instanceof Set ||\n Array.isArray(val) ||\n typeof val === \"function\" ||\n (isObjectType(val) && TRANSFERABLE in val)\n );\n }\n\n private omitSerialization(val: unknown) {\n return val instanceof HTMLElement || val === window;\n }\n}\n"],"names":["serializerModules"],"mappings":";;;;;AASA,MAAM,WAAA,GAAc,MAAA,CAAO,MAAA,CAAOA,KAAiB,CAAA,CAAE,MAAA;AAAA,EACnD,CAAC,QAAQ,GAAA,YAAe;AAC1B,CAAA;AAEO,MAAM,gCAAgC,kCAAA,CAAmC;AAAA,EACvE,WAAA,GAAc;AACnB,IAAA,MAAM,OAAA,GAAsC;AAAA,MAC1C,SAAA,EAAW,CAAC,GAAA,EAAK,SAAA,KAAc;AAC7B,QAAA,IAAI;AACF,UAAA,IAAI,IAAA,CAAK,oBAAA,CAAqB,GAAG,CAAA,EAAG;AAClC,YAAA;AAAA,UACF;AACA,UAAA,IAAI,IAAA,CAAK,iBAAA,CAAkB,GAAG,CAAA,EAAG;AAC/B,YAAA,OAAO,IAAA;AAAA,UACT;AACA,UAAA,KAAA,MAAW,cAAc,WAAA,EAAa;AACpC,YAAA,MAAM,aAAA,GAAgB,UAAA,CAAW,SAAA,CAAU,GAAG,CAAA;AAC9C,YAAA,IAAI,cAAc,OAAA,EAAS;AACzB,cAAA,OAAO,SAAA,CAAU,cAAc,MAAM,CAAA;AAAA,YACvC;AAAA,UACF;AACA,UAAA,IAAI,YAAA,CAAa,GAAG,CAAA,EAAG;AACrB,YAAA,OAAO,SAAA,CAAU,EAAE,GAAG,GAAA,EAAK,CAAA;AAAA,UAC7B;AAAA,QACF,SAAS,KAAA,EAAO;AACd,UAAA,OAAA,CAAQ,KAAA,CAAM,2BAA2B,KAAK,CAAA;AAC9C,UAAA,MAAM,KAAA;AAAA,QACR;AAAA,MACF,CAAA;AAAA,MACA,WAAA,EAAa,CAAC,GAAA,EAAK,SAAA,KAAc;AAC/B,QAAA,IAAI;AACF,UAAA,KAAA,MAAW,cAAc,WAAA,EAAa;AACpC,YAAA,MAAM,eAAA,GAAkB,UAAA,CAAW,WAAA,CAAY,GAAG,CAAA;AAClD,YAAA,IAAI,gBAAgB,OAAA,EAAS;AAC3B,cAAA,OAAO,gBAAgB,MAAA,CAAO,KAAA;AAAA,YAChC;AAAA,UACF;AACA,UAAA,OAAO,UAAU,GAAG,CAAA;AAAA,QACtB,SAAS,KAAA,EAAO;AACd,UAAA,OAAA,CAAQ,KAAA,CAAM,6BAA6B,KAAK,CAAA;AAChD,UAAA,MAAM,KAAA;AAAA,QACR;AAAA,MACF;AAAA,KACF;AACA,IAAA,KAAA,CAAM,OAAO,CAAA;AAAA,EACf;AAAA,EAEQ,qBAAqB,GAAA,EAAc;AACzC,IAAA,OACE,GAAA,YAAe,GAAA,IACf,GAAA,YAAe,GAAA,IACf,MAAM,OAAA,CAAQ,GAAG,CAAA,IACjB,OAAO,GAAA,KAAQ,UAAA,IACd,YAAA,CAAa,GAAG,KAAK,YAAA,IAAgB,GAAA;AAAA,EAE1C;AAAA,EAEQ,kBAAkB,GAAA,EAAc;AACtC,IAAA,OAAO,GAAA,YAAe,eAAe,GAAA,KAAQ,MAAA;AAAA,EAC/C;AACF;;;;"}
@@ -0,0 +1,36 @@
1
+ const Key = "mittwald.flow-remote-core.serializer.name";
2
+ class Serializer {
3
+ constructor(options) {
4
+ this.options = options;
5
+ }
6
+ apply(val, strategy) {
7
+ if (strategy.isApplicable(val)) {
8
+ return {
9
+ applied: true,
10
+ result: {
11
+ [Key]: this.options.name,
12
+ value: strategy.apply(val)
13
+ }
14
+ };
15
+ }
16
+ return {
17
+ applied: false
18
+ };
19
+ }
20
+ serialize(val) {
21
+ return this.apply(val, this.options.serialize);
22
+ }
23
+ deserialize(val) {
24
+ return this.apply(val, {
25
+ apply: (serialization) => {
26
+ return this.options.deserialize.apply(serialization.value);
27
+ },
28
+ isApplicable: (val2) => {
29
+ return !!val2 && typeof val2 === "object" && Key in val2 && val2[Key] === this.options.name;
30
+ }
31
+ });
32
+ }
33
+ }
34
+
35
+ export { Serializer };
36
+ //# sourceMappingURL=Serializer.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Serializer.mjs","sources":["../../../../../src/serialization/Serializer.ts"],"sourcesContent":["interface SerializationStrategy<TIn, TOut> {\n isApplicable: (val: unknown) => val is TIn;\n apply: (val: TIn) => TOut;\n}\n\nconst Key = \"mittwald.flow-remote-core.serializer.name\";\n\nexport interface SuccessfulSerializationResult<T> {\n value: T;\n [Key]: string;\n}\n\nexport type SerializationResult<T> =\n | { applied: true; result: SuccessfulSerializationResult<T> }\n | { applied: false };\n\nexport class Serializer<TIn, TOut> {\n public constructor(\n private options: {\n name: string;\n serialize: SerializationStrategy<TIn, TOut>;\n deserialize: Pick<SerializationStrategy<TOut, TIn>, \"apply\">;\n },\n ) {}\n\n private apply<TIn, TOut>(\n val: unknown,\n strategy: SerializationStrategy<TIn, TOut>,\n ): SerializationResult<TOut> {\n if (strategy.isApplicable(val)) {\n return {\n applied: true,\n result: {\n [Key]: this.options.name,\n value: strategy.apply(val),\n },\n };\n }\n return {\n applied: false,\n };\n }\n\n public serialize(val: unknown): SerializationResult<TOut> {\n return this.apply<TIn, TOut>(val, this.options.serialize);\n }\n\n public deserialize(val: unknown): SerializationResult<TIn> {\n return this.apply(val, {\n apply: (serialization: SuccessfulSerializationResult<TOut>) => {\n return this.options.deserialize.apply(serialization.value);\n },\n isApplicable: (val): val is SuccessfulSerializationResult<TOut> => {\n return (\n !!val &&\n typeof val === \"object\" &&\n Key in val &&\n val[Key] === this.options.name\n );\n },\n });\n }\n}\n"],"names":["val"],"mappings":"AAKA,MAAM,GAAA,GAAM,2CAAA;AAWL,MAAM,UAAA,CAAsB;AAAA,EAC1B,YACG,OAAA,EAKR;AALQ,IAAA,IAAA,CAAA,OAAA,GAAA,OAAA;AAAA,EAKP;AAAA,EAEK,KAAA,CACN,KACA,QAAA,EAC2B;AAC3B,IAAA,IAAI,QAAA,CAAS,YAAA,CAAa,GAAG,CAAA,EAAG;AAC9B,MAAA,OAAO;AAAA,QACL,OAAA,EAAS,IAAA;AAAA,QACT,MAAA,EAAQ;AAAA,UACN,CAAC,GAAG,GAAG,IAAA,CAAK,OAAA,CAAQ,IAAA;AAAA,UACpB,KAAA,EAAO,QAAA,CAAS,KAAA,CAAM,GAAG;AAAA;AAC3B,OACF;AAAA,IACF;AACA,IAAA,OAAO;AAAA,MACL,OAAA,EAAS;AAAA,KACX;AAAA,EACF;AAAA,EAEO,UAAU,GAAA,EAAyC;AACxD,IAAA,OAAO,IAAA,CAAK,KAAA,CAAiB,GAAA,EAAK,IAAA,CAAK,QAAQ,SAAS,CAAA;AAAA,EAC1D;AAAA,EAEO,YAAY,GAAA,EAAwC;AACzD,IAAA,OAAO,IAAA,CAAK,MAAM,GAAA,EAAK;AAAA,MACrB,KAAA,EAAO,CAAC,aAAA,KAAuD;AAC7D,QAAA,OAAO,IAAA,CAAK,OAAA,CAAQ,WAAA,CAAY,KAAA,CAAM,cAAc,KAAK,CAAA;AAAA,MAC3D,CAAA;AAAA,MACA,YAAA,EAAc,CAACA,IAAAA,KAAoD;AACjE,QAAA,OACE,CAAC,CAACA,IAAAA,IACF,OAAOA,IAAAA,KAAQ,QAAA,IACf,GAAA,IAAOA,IAAAA,IACPA,IAAAA,CAAI,GAAG,CAAA,KAAM,IAAA,CAAK,OAAA,CAAQ,IAAA;AAAA,MAE9B;AAAA,KACD,CAAA;AAAA,EACH;AACF;;;;"}
@@ -0,0 +1,23 @@
1
+ import { Serializer } from '../Serializer.mjs';
2
+
3
+ const dataTransferTextSerializer = new Serializer({
4
+ name: "DataTransferText",
5
+ serialize: {
6
+ isApplicable: (val) => {
7
+ return val instanceof DataTransfer && val.types.every((type) => type === "text/plain");
8
+ },
9
+ apply: (dataTransfer) => {
10
+ return dataTransfer.getData("text") || dataTransfer.getData("text/plain");
11
+ }
12
+ },
13
+ deserialize: {
14
+ apply: (asString) => {
15
+ const dataTransfer = new DataTransfer();
16
+ dataTransfer.setData("text", asString);
17
+ return dataTransfer;
18
+ }
19
+ }
20
+ });
21
+
22
+ export { dataTransferTextSerializer };
23
+ //# sourceMappingURL=dataTransferText.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dataTransferText.mjs","sources":["../../../../../../src/serialization/serializers/dataTransferText.ts"],"sourcesContent":["import { Serializer } from \"@/serialization/Serializer\";\n\nexport const dataTransferTextSerializer = new Serializer<DataTransfer, string>({\n name: \"DataTransferText\",\n serialize: {\n isApplicable: (val): val is DataTransfer => {\n return (\n val instanceof DataTransfer &&\n val.types.every((type) => type === \"text/plain\")\n );\n },\n apply: (dataTransfer) => {\n return dataTransfer.getData(\"text\") || dataTransfer.getData(\"text/plain\");\n },\n },\n deserialize: {\n apply: (asString) => {\n const dataTransfer = new DataTransfer();\n dataTransfer.setData(\"text\", asString);\n return dataTransfer;\n },\n },\n});\n"],"names":[],"mappings":";;AAEO,MAAM,0BAAA,GAA6B,IAAI,UAAA,CAAiC;AAAA,EAC7E,IAAA,EAAM,kBAAA;AAAA,EACN,SAAA,EAAW;AAAA,IACT,YAAA,EAAc,CAAC,GAAA,KAA6B;AAC1C,MAAA,OACE,GAAA,YAAe,gBACf,GAAA,CAAI,KAAA,CAAM,MAAM,CAAC,IAAA,KAAS,SAAS,YAAY,CAAA;AAAA,IAEnD,CAAA;AAAA,IACA,KAAA,EAAO,CAAC,YAAA,KAAiB;AACvB,MAAA,OAAO,aAAa,OAAA,CAAQ,MAAM,CAAA,IAAK,YAAA,CAAa,QAAQ,YAAY,CAAA;AAAA,IAC1E;AAAA,GACF;AAAA,EACA,WAAA,EAAa;AAAA,IACX,KAAA,EAAO,CAAC,QAAA,KAAa;AACnB,MAAA,MAAM,YAAA,GAAe,IAAI,YAAA,EAAa;AACtC,MAAA,YAAA,CAAa,OAAA,CAAQ,QAAQ,QAAQ,CAAA;AACrC,MAAA,OAAO,YAAA;AAAA,IACT;AAAA;AAEJ,CAAC;;;;"}
@@ -0,0 +1,16 @@
1
+ import { parseDate, CalendarDate } from '@internationalized/date';
2
+ import { Serializer } from '../Serializer.mjs';
3
+
4
+ const calendarDateSerializer = new Serializer({
5
+ name: "CalendarDate",
6
+ serialize: {
7
+ isApplicable: (val) => val instanceof CalendarDate,
8
+ apply: (date) => date.toString()
9
+ },
10
+ deserialize: {
11
+ apply: (asString) => parseDate(asString)
12
+ }
13
+ });
14
+
15
+ export { calendarDateSerializer };
16
+ //# sourceMappingURL=date.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"date.mjs","sources":["../../../../../../src/serialization/serializers/date.ts"],"sourcesContent":["import { CalendarDate } from \"@internationalized/date\";\nimport { parseDate } from \"@internationalized/date\";\nimport { Serializer } from \"@/serialization/Serializer\";\n\nexport const calendarDateSerializer = new Serializer<CalendarDate, string>({\n name: \"CalendarDate\",\n serialize: {\n isApplicable: (val) => val instanceof CalendarDate,\n apply: (date) => date.toString(),\n },\n deserialize: {\n apply: (asString) => parseDate(asString),\n },\n});\n"],"names":[],"mappings":";;;AAIO,MAAM,sBAAA,GAAyB,IAAI,UAAA,CAAiC;AAAA,EACzE,IAAA,EAAM,cAAA;AAAA,EACN,SAAA,EAAW;AAAA,IACT,YAAA,EAAc,CAAC,GAAA,KAAQ,GAAA,YAAe,YAAA;AAAA,IACtC,KAAA,EAAO,CAAC,IAAA,KAAS,IAAA,CAAK,QAAA;AAAS,GACjC;AAAA,EACA,WAAA,EAAa;AAAA,IACX,KAAA,EAAO,CAAC,QAAA,KAAa,SAAA,CAAU,QAAQ;AAAA;AAE3C,CAAC;;;;"}
@@ -0,0 +1,34 @@
1
+ import { markAsTransferable } from '@quilted/threads';
2
+ import { Serializer } from '../Serializer.mjs';
3
+ import { getAwaitArrayBuffer } from '../../../../core/src/file.mjs';
4
+
5
+ const isSerializedFile = (value) => {
6
+ return !!(value && typeof value === "object" && "name" in value && "type" in value && "lastModified" in value && "content" in value);
7
+ };
8
+ const fileSerialize = (file) => {
9
+ return {
10
+ name: file.name,
11
+ type: file.type,
12
+ lastModified: file.lastModified,
13
+ content: markAsTransferable(getAwaitArrayBuffer(file))
14
+ };
15
+ };
16
+ const fileDeSerialize = (file) => {
17
+ return new File([file.content], file.name, {
18
+ lastModified: file.lastModified,
19
+ type: file.type
20
+ });
21
+ };
22
+ const fileSerializer = new Serializer({
23
+ name: "File",
24
+ serialize: {
25
+ isApplicable: (something) => something instanceof File,
26
+ apply: fileSerialize
27
+ },
28
+ deserialize: {
29
+ apply: fileDeSerialize
30
+ }
31
+ });
32
+
33
+ export { fileDeSerialize, fileSerialize, fileSerializer, isSerializedFile };
34
+ //# sourceMappingURL=file.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"file.mjs","sources":["../../../../../../src/serialization/serializers/file.ts"],"sourcesContent":["import { markAsTransferable } from \"@quilted/threads\";\nimport { Serializer } from \"@/serialization/Serializer\";\nimport { getAwaitArrayBuffer } from \"@mittwald/flow-core\";\n\nexport interface SerializedFile {\n name: string;\n type: string;\n lastModified: number;\n content: ArrayBuffer;\n}\n\nexport const isSerializedFile = (value: unknown): value is SerializedFile => {\n return !!(\n value &&\n typeof value === \"object\" &&\n \"name\" in value &&\n \"type\" in value &&\n \"lastModified\" in value &&\n \"content\" in value\n );\n};\n\nexport const fileSerialize = (file: File): SerializedFile => {\n return {\n name: file.name,\n type: file.type,\n lastModified: file.lastModified,\n content: markAsTransferable(getAwaitArrayBuffer(file)),\n };\n};\n\nexport const fileDeSerialize = (file: SerializedFile) => {\n return new File([file.content], file.name, {\n lastModified: file.lastModified,\n type: file.type,\n });\n};\n\nexport const fileSerializer = new Serializer<File, SerializedFile>({\n name: \"File\",\n serialize: {\n isApplicable: (something) => something instanceof File,\n apply: fileSerialize,\n },\n deserialize: {\n apply: fileDeSerialize,\n },\n});\n"],"names":[],"mappings":";;;;AAWO,MAAM,gBAAA,GAAmB,CAAC,KAAA,KAA4C;AAC3E,EAAA,OAAO,CAAC,EACN,KAAA,IACA,OAAO,KAAA,KAAU,QAAA,IACjB,MAAA,IAAU,KAAA,IACV,MAAA,IAAU,KAAA,IACV,cAAA,IAAkB,KAAA,IAClB,SAAA,IAAa,KAAA,CAAA;AAEjB;AAEO,MAAM,aAAA,GAAgB,CAAC,IAAA,KAA+B;AAC3D,EAAA,OAAO;AAAA,IACL,MAAM,IAAA,CAAK,IAAA;AAAA,IACX,MAAM,IAAA,CAAK,IAAA;AAAA,IACX,cAAc,IAAA,CAAK,YAAA;AAAA,IACnB,OAAA,EAAS,kBAAA,CAAmB,mBAAA,CAAoB,IAAI,CAAC;AAAA,GACvD;AACF;AAEO,MAAM,eAAA,GAAkB,CAAC,IAAA,KAAyB;AACvD,EAAA,OAAO,IAAI,IAAA,CAAK,CAAC,KAAK,OAAO,CAAA,EAAG,KAAK,IAAA,EAAM;AAAA,IACzC,cAAc,IAAA,CAAK,YAAA;AAAA,IACnB,MAAM,IAAA,CAAK;AAAA,GACZ,CAAA;AACH;AAEO,MAAM,cAAA,GAAiB,IAAI,UAAA,CAAiC;AAAA,EACjE,IAAA,EAAM,MAAA;AAAA,EACN,SAAA,EAAW;AAAA,IACT,YAAA,EAAc,CAAC,SAAA,KAAc,SAAA,YAAqB,IAAA;AAAA,IAClD,KAAA,EAAO;AAAA,GACT;AAAA,EACA,WAAA,EAAa;AAAA,IACX,KAAA,EAAO;AAAA;AAEX,CAAC;;;;"}
@@ -0,0 +1,24 @@
1
+ import { Serializer } from '../Serializer.mjs';
2
+ import '@internationalized/date';
3
+ import { fileDeSerialize, fileSerialize } from './file.mjs';
4
+ import '@mittwald/flow-react-components/mittwald-password-tools-js';
5
+
6
+ const fileListSerializer = new Serializer({
7
+ name: "FileList",
8
+ serialize: {
9
+ isApplicable: (something) => {
10
+ return something instanceof FileList;
11
+ },
12
+ apply: (fileList) => Array.from(fileList).map(fileSerialize)
13
+ },
14
+ deserialize: {
15
+ apply: (arrayFiles) => {
16
+ const dataTransfer = new DataTransfer();
17
+ arrayFiles.forEach((f) => dataTransfer.items.add(fileDeSerialize(f)));
18
+ return dataTransfer.files;
19
+ }
20
+ }
21
+ });
22
+
23
+ export { fileListSerializer };
24
+ //# sourceMappingURL=fileList.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fileList.mjs","sources":["../../../../../../src/serialization/serializers/fileList.ts"],"sourcesContent":["import { Serializer } from \"@/serialization/Serializer\";\nimport {\n fileDeSerialize,\n fileSerialize,\n type SerializedFile,\n} from \"@/serialization/serializers\";\n\nexport const fileListSerializer = new Serializer<FileList, SerializedFile[]>({\n name: \"FileList\",\n serialize: {\n isApplicable: (something) => {\n return something instanceof FileList;\n },\n apply: (fileList) => Array.from(fileList).map(fileSerialize),\n },\n deserialize: {\n apply: (arrayFiles) => {\n const dataTransfer = new DataTransfer();\n arrayFiles.forEach((f) => dataTransfer.items.add(fileDeSerialize(f)));\n return dataTransfer.files;\n },\n },\n});\n"],"names":[],"mappings":";;;;;AAOO,MAAM,kBAAA,GAAqB,IAAI,UAAA,CAAuC;AAAA,EAC3E,IAAA,EAAM,UAAA;AAAA,EACN,SAAA,EAAW;AAAA,IACT,YAAA,EAAc,CAAC,SAAA,KAAc;AAC3B,MAAA,OAAO,SAAA,YAAqB,QAAA;AAAA,IAC9B,CAAA;AAAA,IACA,KAAA,EAAO,CAAC,QAAA,KAAa,KAAA,CAAM,KAAK,QAAQ,CAAA,CAAE,IAAI,aAAa;AAAA,GAC7D;AAAA,EACA,WAAA,EAAa;AAAA,IACX,KAAA,EAAO,CAAC,UAAA,KAAe;AACrB,MAAA,MAAM,YAAA,GAAe,IAAI,YAAA,EAAa;AACtC,MAAA,UAAA,CAAW,OAAA,CAAQ,CAAC,CAAA,KAAM,YAAA,CAAa,MAAM,GAAA,CAAI,eAAA,CAAgB,CAAC,CAAC,CAAC,CAAA;AACpE,MAAA,OAAO,YAAA,CAAa,KAAA;AAAA,IACtB;AAAA;AAEJ,CAAC;;;;"}
@@ -0,0 +1,36 @@
1
+ import { Serializer } from '../Serializer.mjs';
2
+ import '@internationalized/date';
3
+ import { isSerializedFile, fileDeSerialize, fileSerialize } from './file.mjs';
4
+ import '@mittwald/flow-react-components/mittwald-password-tools-js';
5
+
6
+ const formDataSerializer = new Serializer({
7
+ name: "FormData",
8
+ serialize: {
9
+ isApplicable: (val) => val instanceof FormData,
10
+ apply: (formData) => {
11
+ return formData.entries().toArray().map(([fieldName, fieldValue]) => {
12
+ if (fieldValue instanceof File) {
13
+ return [fieldName, fileSerialize(fieldValue)];
14
+ }
15
+ return [fieldName, fieldValue];
16
+ });
17
+ }
18
+ },
19
+ deserialize: {
20
+ apply: (array) => {
21
+ const formData = new FormData();
22
+ for (const [name, value] of array) {
23
+ const deserializedValue = isSerializedFile(value) ? fileDeSerialize(value) : value;
24
+ if (!formData.has(name)) {
25
+ formData.set(name, deserializedValue);
26
+ } else {
27
+ formData.append(name, deserializedValue);
28
+ }
29
+ }
30
+ return formData;
31
+ }
32
+ }
33
+ });
34
+
35
+ export { formDataSerializer };
36
+ //# sourceMappingURL=formData.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"formData.mjs","sources":["../../../../../../src/serialization/serializers/formData.ts"],"sourcesContent":["import { Serializer } from \"@/serialization/Serializer\";\nimport {\n fileDeSerialize,\n fileSerialize,\n isSerializedFile,\n} from \"@/serialization/serializers\";\n\nexport const formDataSerializer = new Serializer<\n FormData,\n [string, FormDataEntryValue][]\n>({\n name: \"FormData\",\n serialize: {\n isApplicable: (val) => val instanceof FormData,\n apply: (formData) => {\n return formData\n .entries()\n .toArray()\n .map(([fieldName, fieldValue]) => {\n if (fieldValue instanceof File) {\n return [fieldName, fileSerialize(fieldValue)];\n }\n\n return [fieldName, fieldValue];\n }) as [string, FormDataEntryValue][];\n },\n },\n deserialize: {\n apply: (array) => {\n const formData = new FormData();\n for (const [name, value] of array) {\n const deserializedValue = isSerializedFile(value)\n ? fileDeSerialize(value)\n : value;\n\n if (!formData.has(name)) {\n formData.set(name, deserializedValue);\n } else {\n formData.append(name, deserializedValue);\n }\n }\n return formData;\n },\n },\n});\n"],"names":[],"mappings":";;;;;AAOO,MAAM,kBAAA,GAAqB,IAAI,UAAA,CAGpC;AAAA,EACA,IAAA,EAAM,UAAA;AAAA,EACN,SAAA,EAAW;AAAA,IACT,YAAA,EAAc,CAAC,GAAA,KAAQ,GAAA,YAAe,QAAA;AAAA,IACtC,KAAA,EAAO,CAAC,QAAA,KAAa;AACnB,MAAA,OAAO,QAAA,CACJ,OAAA,EAAQ,CACR,OAAA,EAAQ,CACR,IAAI,CAAC,CAAC,SAAA,EAAW,UAAU,CAAA,KAAM;AAChC,QAAA,IAAI,sBAAsB,IAAA,EAAM;AAC9B,UAAA,OAAO,CAAC,SAAA,EAAW,aAAA,CAAc,UAAU,CAAC,CAAA;AAAA,QAC9C;AAEA,QAAA,OAAO,CAAC,WAAW,UAAU,CAAA;AAAA,MAC/B,CAAC,CAAA;AAAA,IACL;AAAA,GACF;AAAA,EACA,WAAA,EAAa;AAAA,IACX,KAAA,EAAO,CAAC,KAAA,KAAU;AAChB,MAAA,MAAM,QAAA,GAAW,IAAI,QAAA,EAAS;AAC9B,MAAA,KAAA,MAAW,CAAC,IAAA,EAAM,KAAK,CAAA,IAAK,KAAA,EAAO;AACjC,QAAA,MAAM,oBAAoB,gBAAA,CAAiB,KAAK,CAAA,GAC5C,eAAA,CAAgB,KAAK,CAAA,GACrB,KAAA;AAEJ,QAAA,IAAI,CAAC,QAAA,CAAS,GAAA,CAAI,IAAI,CAAA,EAAG;AACvB,UAAA,QAAA,CAAS,GAAA,CAAI,MAAM,iBAAiB,CAAA;AAAA,QACtC,CAAA,MAAO;AACL,UAAA,QAAA,CAAS,MAAA,CAAO,MAAM,iBAAiB,CAAA;AAAA,QACzC;AAAA,MACF;AACA,MAAA,OAAO,QAAA;AAAA,IACT;AAAA;AAEJ,CAAC;;;;"}
@@ -0,0 +1,7 @@
1
+ export { calendarDateSerializer } from './date.mjs';
2
+ export { fileDeSerialize, fileSerialize, fileSerializer, isSerializedFile } from './file.mjs';
3
+ export { fileListSerializer } from './fileList.mjs';
4
+ export { dataTransferTextSerializer } from './dataTransferText.mjs';
5
+ export { formDataSerializer } from './formData.mjs';
6
+ export { passwordPolicySerializer } from './passwordPolicy.mjs';
7
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;"}
@@ -0,0 +1,16 @@
1
+ import { Serializer } from '../Serializer.mjs';
2
+ import { Policy } from '@mittwald/flow-react-components/mittwald-password-tools-js';
3
+
4
+ const passwordPolicySerializer = new Serializer({
5
+ name: "PasswordPolicy",
6
+ serialize: {
7
+ isApplicable: (val) => Policy.isPolicy(val),
8
+ apply: (policy) => policy.toDeclaration()
9
+ },
10
+ deserialize: {
11
+ apply: (policyDeclaration) => Policy.fromDeclaration(policyDeclaration)
12
+ }
13
+ });
14
+
15
+ export { passwordPolicySerializer };
16
+ //# sourceMappingURL=passwordPolicy.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"passwordPolicy.mjs","sources":["../../../../../../src/serialization/serializers/passwordPolicy.ts"],"sourcesContent":["import { Serializer } from \"@/serialization/Serializer\";\nimport {\n Policy,\n type PolicyDeclaration,\n} from \"@mittwald/flow-react-components/mittwald-password-tools-js\";\n\nexport const passwordPolicySerializer = new Serializer<\n Policy,\n PolicyDeclaration\n>({\n name: \"PasswordPolicy\",\n serialize: {\n isApplicable: (val) => Policy.isPolicy(val),\n apply: (policy) => policy.toDeclaration(),\n },\n deserialize: {\n apply: (policyDeclaration) => Policy.fromDeclaration(policyDeclaration),\n },\n});\n"],"names":[],"mappings":";;;AAMO,MAAM,wBAAA,GAA2B,IAAI,UAAA,CAG1C;AAAA,EACA,IAAA,EAAM,gBAAA;AAAA,EACN,SAAA,EAAW;AAAA,IACT,YAAA,EAAc,CAAC,GAAA,KAAQ,MAAA,CAAO,SAAS,GAAG,CAAA;AAAA,IAC1C,KAAA,EAAO,CAAC,MAAA,KAAW,MAAA,CAAO,aAAA;AAAc,GAC1C;AAAA,EACA,WAAA,EAAa;AAAA,IACX,KAAA,EAAO,CAAC,iBAAA,KAAsB,MAAA,CAAO,gBAAgB,iBAAiB;AAAA;AAE1E,CAAC;;;;"}