@blocksdiy/react-common 1.3.0 → 1.4.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/iframe-communication/index.d.ts +1 -1
- package/dist/iframe-communication/index.d.ts.map +1 -1
- package/dist/iframe-communication/platform-bridge-provider.d.ts.map +1 -1
- package/dist/iframe-communication/platform-bridge-provider.js +6 -3
- package/dist/iframe-communication/types.d.ts +20 -6
- package/dist/iframe-communication/types.d.ts.map +1 -1
- package/package.json +3 -4
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export type { ThemeMode, AppUpdate, PlatformApi, IframeApi } from "./types.js";
|
|
1
|
+
export type { ThemeMode, AppUpdate, PlatformApi, IframeApi, EditedElement, ElementData } from "./types.js";
|
|
2
2
|
export { BridgeProvider, useBridgeState, type BridgeState } from "./bridge-provider.js";
|
|
3
3
|
export { IframeBridgeProvider, usePlatform } from "./iframe-bridge-provider.js";
|
|
4
4
|
export { PlatformBridgeProvider, PlatformBridgeIframe, useIframe } from "./platform-bridge-provider.js";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/iframe-communication/index.ts"],"names":[],"mappings":"AAAA,YAAY,EAAE,SAAS,EAAE,SAAS,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/iframe-communication/index.ts"],"names":[],"mappings":"AAAA,YAAY,EAAE,SAAS,EAAE,SAAS,EAAE,WAAW,EAAE,SAAS,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AACxG,OAAO,EAAE,cAAc,EAAE,cAAc,EAAE,KAAK,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAErF,OAAO,EAAE,oBAAoB,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAC7E,OAAO,EAAE,sBAAsB,EAAE,oBAAoB,EAAE,SAAS,EAAE,MAAM,4BAA4B,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"platform-bridge-provider.d.ts","sourceRoot":"","sources":["../../src/iframe-communication/platform-bridge-provider.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,SAAS,EAAqB,MAAM,OAAO,CAAC;AAG1D,OAAO,KAAK,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAEtD;;;;;;GAMG;AACH,wBAAgB,sBAAsB,CAAC,EAAE,QAAQ,EAAE,EAAE;IAAE,QAAQ,EAAE,SAAS,CAAA;CAAE,2CAE3E;AAED,KAAK,yBAAyB,GAAG;IAAE,WAAW,EAAE,WAAW,CAAA;CAAE,GAAG,IAAI,CAClE,KAAK,CAAC,oBAAoB,CAAC,iBAAiB,CAAC,EAC7C,KAAK,GAAG,OAAO,CAChB,CAAC;AAEF;;;;;GAKG;AACH,wBAAgB,oBAAoB,CAAC,EAAE,WAAW,EAAE,GAAG,WAAW,EAAE,EAAE,yBAAyB,
|
|
1
|
+
{"version":3,"file":"platform-bridge-provider.d.ts","sourceRoot":"","sources":["../../src/iframe-communication/platform-bridge-provider.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,SAAS,EAAqB,MAAM,OAAO,CAAC;AAG1D,OAAO,KAAK,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAEtD;;;;;;GAMG;AACH,wBAAgB,sBAAsB,CAAC,EAAE,QAAQ,EAAE,EAAE;IAAE,QAAQ,EAAE,SAAS,CAAA;CAAE,2CAE3E;AAED,KAAK,yBAAyB,GAAG;IAAE,WAAW,EAAE,WAAW,CAAA;CAAE,GAAG,IAAI,CAClE,KAAK,CAAC,oBAAoB,CAAC,iBAAiB,CAAC,EAC7C,KAAK,GAAG,OAAO,CAChB,CAAC;AAEF;;;;;GAKG;AACH,wBAAgB,oBAAoB,CAAC,EAAE,WAAW,EAAE,GAAG,WAAW,EAAE,EAAE,yBAAyB,2CA2E9F;AAED;;;;GAIG;AACH,wBAAgB,SAAS;;;;EAQxB"}
|
|
@@ -20,6 +20,7 @@ export function PlatformBridgeProvider({ children }) {
|
|
|
20
20
|
*/
|
|
21
21
|
export function PlatformBridgeIframe({ platformApi, ...iframeProps }) {
|
|
22
22
|
const { onConnectionSuccess, onConnectionError, onConnectionLoading, onConnectionEnded } = useBridgeState("PlatformBridgeIframe", "PlatformBridgeProvider");
|
|
23
|
+
const connectionRef = useRef(null);
|
|
23
24
|
const platformApiRef = useRef(platformApi);
|
|
24
25
|
useEffect(() => {
|
|
25
26
|
platformApiRef.current = platformApi;
|
|
@@ -52,18 +53,20 @@ export function PlatformBridgeIframe({ platformApi, ...iframeProps }) {
|
|
|
52
53
|
remoteWindow: iframe.contentWindow,
|
|
53
54
|
allowedOrigins: [new URL(iframe.src).origin],
|
|
54
55
|
});
|
|
55
|
-
|
|
56
|
+
connectionRef.current?.destroy();
|
|
57
|
+
connectionRef.current = connect({
|
|
56
58
|
messenger,
|
|
57
59
|
methods: platformApiRef.current,
|
|
58
60
|
// log: debug("platform-window"),
|
|
59
61
|
});
|
|
60
|
-
|
|
62
|
+
connectionRef.current.promise
|
|
61
63
|
.then((api) => onConnectionSuccessRef.current(api))
|
|
62
64
|
.catch((error) => {
|
|
65
|
+
connectionRef.current?.destroy();
|
|
63
66
|
onConnectionErrorRef.current(error);
|
|
64
67
|
});
|
|
65
68
|
return () => {
|
|
66
|
-
|
|
69
|
+
connectionRef.current?.destroy();
|
|
67
70
|
onConnectionEndedRef.current();
|
|
68
71
|
};
|
|
69
72
|
}, []);
|
|
@@ -1,5 +1,20 @@
|
|
|
1
1
|
import { type Methods } from "penpal";
|
|
2
2
|
export type ThemeMode = "dark" | "light" | "system";
|
|
3
|
+
export type ElementData = {
|
|
4
|
+
dataId: string;
|
|
5
|
+
dataFilePath: string;
|
|
6
|
+
dataLine: string;
|
|
7
|
+
dataName: string;
|
|
8
|
+
dataStaticText: string | null;
|
|
9
|
+
classAttribute: string | null;
|
|
10
|
+
styleAttribute: string | null;
|
|
11
|
+
};
|
|
12
|
+
export type EditedElement = {
|
|
13
|
+
elementData: ElementData;
|
|
14
|
+
className?: string;
|
|
15
|
+
text?: string;
|
|
16
|
+
removed?: boolean;
|
|
17
|
+
};
|
|
3
18
|
export interface AppUpdate {
|
|
4
19
|
id: string;
|
|
5
20
|
name: string;
|
|
@@ -35,11 +50,7 @@ export interface PlatformApi extends Methods {
|
|
|
35
50
|
}[];
|
|
36
51
|
}) => Promise<void>;
|
|
37
52
|
onLoad: () => Promise<void>;
|
|
38
|
-
chooseElement: (data:
|
|
39
|
-
name: string;
|
|
40
|
-
filePath: string;
|
|
41
|
-
line: string;
|
|
42
|
-
}) => Promise<void>;
|
|
53
|
+
chooseElement: (data: ElementData) => Promise<void>;
|
|
43
54
|
}
|
|
44
55
|
/**
|
|
45
56
|
* Methods the iframe (app-render) exposes to the platform (Remix parent window).
|
|
@@ -55,6 +66,9 @@ export interface IframeApi extends Methods {
|
|
|
55
66
|
role: string | undefined;
|
|
56
67
|
}) => Promise<void>;
|
|
57
68
|
onPlatformThemeModeChange: (themeMode: ThemeMode) => Promise<void>;
|
|
58
|
-
|
|
69
|
+
onChangeIsSelectMode: (isSelectMode: boolean) => Promise<void>;
|
|
70
|
+
onSelectElement: (target: ElementData | null) => Promise<void>;
|
|
71
|
+
onDeselectElement: () => Promise<void>;
|
|
72
|
+
onSetEditedElements: (editedElements: EditedElement[]) => Promise<void>;
|
|
59
73
|
}
|
|
60
74
|
//# sourceMappingURL=types.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/iframe-communication/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,OAAO,EAAE,MAAM,QAAQ,CAAC;AAEtC,MAAM,MAAM,SAAS,GAAG,MAAM,GAAG,OAAO,GAAG,QAAQ,CAAC;AAEpD,MAAM,WAAW,SAAS;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,UAAU,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE;QACL,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QACnC,aAAa,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;KACxC,CAAC;CACH;AAED;;;GAGG;AACH,MAAM,WAAW,WAAY,SAAQ,OAAO;IAC1C,QAAQ,EAAE,MAAM,OAAO,CAAC,MAAM,CAAC,CAAC;IAChC,QAAQ,EAAE,MAAM,IAAI,CAAC;IACrB,kBAAkB,EAAE,CAAC,IAAI,EAAE;QAAE,cAAc,EAAE,MAAM,CAAC;QAAC,YAAY,CAAC,EAAE,MAAM,CAAA;KAAE,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC/F,uBAAuB,EAAE,CAAC,SAAS,EAAE,SAAS,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACjE,eAAe,EAAE,CAAC,SAAS,EAAE;QAAE,KAAK,EAAE,KAAK,CAAC;QAAC,OAAO,CAAC,EAAE,MAAM,CAAC;QAAC,cAAc,CAAC,EAAE,MAAM,CAAA;KAAE,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC3G,kBAAkB,EAAE,CAAC,SAAS,EAAE;QAAE,GAAG,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE;YAAE,EAAE,EAAE,MAAM,CAAC;YAAC,IAAI,EAAE,MAAM,CAAA;SAAE,EAAE,CAAA;KAAE,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACzG,MAAM,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5B,aAAa,EAAE,CAAC,IAAI,EAAE
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/iframe-communication/types.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@blocksdiy/react-common",
|
|
3
|
-
"
|
|
4
|
-
"version": "1.3.0",
|
|
3
|
+
"version": "1.4.1",
|
|
5
4
|
"type": "module",
|
|
6
5
|
"description": "React common",
|
|
7
6
|
"keywords": [],
|
|
@@ -38,14 +37,14 @@
|
|
|
38
37
|
"lint-fix": "pnpm eslint src/ --fix"
|
|
39
38
|
},
|
|
40
39
|
"dependencies": {
|
|
41
|
-
"@blocksdiy/blocks-client-api": "1.2.
|
|
40
|
+
"@blocksdiy/blocks-client-api": "1.2.1",
|
|
42
41
|
"@radix-ui/react-slot": "^1.2.3",
|
|
43
42
|
"penpal": "^7.0.6",
|
|
44
43
|
"@vapi-ai/web": "^2.5.2",
|
|
45
44
|
"react": "^19.2.4"
|
|
46
45
|
},
|
|
47
46
|
"devDependencies": {
|
|
48
|
-
"@blockscom/eslint-config": "4.6.
|
|
47
|
+
"@blockscom/eslint-config": "4.6.4",
|
|
49
48
|
"@types/react": "^19.2.14",
|
|
50
49
|
"babel-plugin-react-compiler": "^1.0.0",
|
|
51
50
|
"eslint-plugin-react": "^7.37.5",
|