unified-video-framework 1.4.315 → 1.4.317
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/package.json +1 -1
- package/packages/web/dist/WebPlayer.d.ts.map +1 -1
- package/packages/web/dist/WebPlayer.js +3 -0
- package/packages/web/dist/WebPlayer.js.map +1 -1
- package/packages/web/dist/react/components/commerce/ProductBadge.d.ts.map +1 -1
- package/packages/web/dist/react/components/commerce/ProductBadge.js +2 -1
- package/packages/web/dist/react/components/commerce/ProductBadge.js.map +1 -1
- package/packages/web/dist/react/components/commerce/ProductPanel.d.ts.map +1 -1
- package/packages/web/dist/react/components/commerce/ProductPanel.js +1 -0
- package/packages/web/dist/react/components/commerce/ProductPanel.js.map +1 -1
- package/packages/web/dist/react/hooks/useCommerceSync.d.ts.map +1 -1
- package/packages/web/dist/react/hooks/useCommerceSync.js +12 -2
- package/packages/web/dist/react/hooks/useCommerceSync.js.map +1 -1
- package/packages/web/src/WebPlayer.ts +4 -0
- package/packages/web/src/react/components/commerce/ProductBadge.tsx +2 -1
- package/packages/web/src/react/components/commerce/ProductPanel.tsx +1 -0
- package/packages/web/src/react/hooks/useCommerceSync.ts +12 -2
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ProductBadge.d.ts","sourceRoot":"","sources":["../../../../src/react/components/commerce/ProductBadge.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,SAAS,EAAE,oBAAoB,EAAE,MAAM,gCAAgC,CAAC;AAEjF,KAAK,KAAK,GAAG;IACX,OAAO,EAAE,SAAS,CAAC;IACnB,OAAO,EAAE,oBAAoB,CAAC;IAC9B,OAAO,EAAE,CAAC,CAAC,EAAE,SAAS,KAAK,IAAI,CAAC;CACjC,CAAC;AAEF,MAAM,CAAC,OAAO,UAAU,YAAY,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE,KAAK,
|
|
1
|
+
{"version":3,"file":"ProductBadge.d.ts","sourceRoot":"","sources":["../../../../src/react/components/commerce/ProductBadge.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,SAAS,EAAE,oBAAoB,EAAE,MAAM,gCAAgC,CAAC;AAEjF,KAAK,KAAK,GAAG;IACX,OAAO,EAAE,SAAS,CAAC;IACnB,OAAO,EAAE,oBAAoB,CAAC;IAC9B,OAAO,EAAE,CAAC,CAAC,EAAE,SAAS,KAAK,IAAI,CAAC;CACjC,CAAC;AAEF,MAAM,CAAC,OAAO,UAAU,YAAY,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE,KAAK,qBA4CxE"}
|
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import React from "react";
|
|
2
2
|
export default function ProductBadge({ product, overlay, onClick }) {
|
|
3
|
+
console.log('[COMMERCE] 🎨 Rendering ProductBadge:', product.id, product.title);
|
|
3
4
|
const showPrice = overlay.style?.badge?.showPrice !== false;
|
|
4
5
|
const showThumb = overlay.style?.badge?.showThumb !== false;
|
|
5
6
|
const base = {
|
|
6
|
-
position: "
|
|
7
|
+
position: "fixed",
|
|
7
8
|
bottom: overlay.placement?.mode === "dock" && overlay.placement.edge === "bottom" ? 16 : undefined,
|
|
8
9
|
top: overlay.placement?.mode === "dock" && overlay.placement.edge === "top" ? 16 : undefined,
|
|
9
10
|
left: overlay.placement?.mode === "dock" && overlay.placement.edge === "left" ? 16 : undefined,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ProductBadge.js","sourceRoot":"","sources":["../../../../src/react/components/commerce/ProductBadge.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAS1B,MAAM,CAAC,OAAO,UAAU,YAAY,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAS;IACvE,MAAM,SAAS,GAAG,OAAO,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,KAAK,KAAK,CAAC;IAC5D,MAAM,SAAS,GAAG,OAAO,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,KAAK,KAAK,CAAC;IAE5D,MAAM,IAAI,GAAwB;QAChC,QAAQ,EAAE,
|
|
1
|
+
{"version":3,"file":"ProductBadge.js","sourceRoot":"","sources":["../../../../src/react/components/commerce/ProductBadge.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ProductPanel.d.ts","sourceRoot":"","sources":["../../../../src/react/components/commerce/ProductPanel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,SAAS,EAAE,MAAM,gCAAgC,CAAC;AAE3D,KAAK,KAAK,GAAG;IACX,QAAQ,EAAE,SAAS,EAAE,CAAC;IACtB,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,CAAC,EAAE,OAAO,GAAG,MAAM,GAAG,QAAQ,CAAC;IACvC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,cAAc,EAAE,CAAC,CAAC,EAAE,SAAS,KAAK,IAAI,CAAC;IACvC,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB,CAAC;AAEF,MAAM,CAAC,OAAO,UAAU,YAAY,CAAC,EACnC,QAAQ,EAAE,OAAO,EAAE,QAAkB,EAAE,KAAW,EAAE,cAAc,EAAE,OAAO,EAC5E,EAAE,KAAK,
|
|
1
|
+
{"version":3,"file":"ProductPanel.d.ts","sourceRoot":"","sources":["../../../../src/react/components/commerce/ProductPanel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,SAAS,EAAE,MAAM,gCAAgC,CAAC;AAE3D,KAAK,KAAK,GAAG;IACX,QAAQ,EAAE,SAAS,EAAE,CAAC;IACtB,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,CAAC,EAAE,OAAO,GAAG,MAAM,GAAG,QAAQ,CAAC;IACvC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,cAAc,EAAE,CAAC,CAAC,EAAE,SAAS,KAAK,IAAI,CAAC;IACvC,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB,CAAC;AAEF,MAAM,CAAC,OAAO,UAAU,YAAY,CAAC,EACnC,QAAQ,EAAE,OAAO,EAAE,QAAkB,EAAE,KAAW,EAAE,cAAc,EAAE,OAAO,EAC5E,EAAE,KAAK,qBA8CP"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import React from "react";
|
|
2
2
|
export default function ProductPanel({ products, visible, position = "right", width = 360, onProductClick, onClose }) {
|
|
3
|
+
console.log('[COMMERCE] 📋 ProductPanel:', { visible, products: products.length, position, width });
|
|
3
4
|
const style = {
|
|
4
5
|
position: "fixed",
|
|
5
6
|
top: position === "bottom" ? undefined : 0,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ProductPanel.js","sourceRoot":"","sources":["../../../../src/react/components/commerce/ProductPanel.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAY1B,MAAM,CAAC,OAAO,UAAU,YAAY,CAAC,EACnC,QAAQ,EAAE,OAAO,EAAE,QAAQ,GAAG,OAAO,EAAE,KAAK,GAAG,GAAG,EAAE,cAAc,EAAE,OAAO,EACrE;IACN,MAAM,KAAK,GAAwB;QACjC,QAAQ,EAAE,OAAO;QACjB,GAAG,EAAE,QAAQ,KAAK,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;QAC1C,MAAM,EAAE,CAAC;QACT,KAAK,EAAE,QAAQ,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS;QAC3C,IAAI,EAAE,QAAQ,KAAK,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS;QACrE,KAAK,EAAE,QAAQ,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK;QAC9C,MAAM,EAAE,QAAQ,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO;QAC7C,UAAU,EAAE,qBAAqB;QACjC,cAAc,EAAE,YAAY;QAC5B,UAAU,EAAE,QAAQ,KAAK,OAAO,CAAC,CAAC,CAAC,iCAAiC,CAAC,CAAC,CAAC,SAAS;QAChF,WAAW,EAAE,QAAQ,KAAK,MAAM,CAAC,CAAC,CAAC,iCAAiC,CAAC,CAAC,CAAC,SAAS;QAChF,SAAS,EAAE,QAAQ,KAAK,QAAQ,CAAC,CAAC,CAAC,iCAAiC,CAAC,CAAC,CAAC,SAAS;QAChF,SAAS,EAAE,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,QAAQ,KAAK,OAAO,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,QAAQ,KAAK,MAAM,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,kBAAkB;QACjJ,UAAU,EAAE,sBAAsB;QAClC,MAAM,EAAE,GAAG;QACX,SAAS,EAAE,MAAM;KAClB,CAAC;IAEF,OAAO,CACL,+BAAO,KAAK,EAAE,KAAK,iBAAe,CAAC,OAAO,gBAAa,wBAAwB;QAC7E,6BAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,iCAAiC,EAAE;YAC1H,6BAAK,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,EAAE,eAAgB;YAC9D,gCAAQ,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,EAAE,UAAU,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,gBAAa,gBAAgB,aAAW,CAC9J;QACN,6BAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,mBAAmB,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,IAC9E,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CACjB,gCAAQ,GAAG,EAAE,CAAC,CAAC,EAAE,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE;gBAC1D,OAAO,EAAE,MAAM,EAAE,mBAAmB,EAAE,UAAU,EAAE,GAAG,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM;gBAC5E,UAAU,EAAE,wBAAwB,EAAE,MAAM,EAAE,kCAAkC;gBAChF,YAAY,EAAE,EAAE,EAAE,OAAO,EAAE,CAAC,EAAE,MAAM,EAAE,SAAS;aAChD;YACC,6BAAK,GAAG,EAAE,CAAC,CAAC,UAAU,CAAC,MAAM,EAAE,GAAG,EAAC,EAAE,EAAC,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,YAAY,EAAE,CAAC,EAAE,SAAS,EAAE,OAAO,EAAE,GAAI;YAC/G,6BAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC,EAAE;gBACrC,6BAAK,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAG,CAAC,CAAC,KAAK,CAAO;gBAC7E,6BAAK,KAAK,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,EAAE,IAC3C,CAAC,CAAC,OAAO,CAAC,SAAS,IAAI,GAAG,CAAC,CAAC,OAAO,CAAC,QAAQ,IAAI,CAAC,CAAC,OAAO,CAAC,MAAM,EAAE,CAC/D,CACF,CACC,CACV,CAAC,CACE,CACA,CACT,CAAC;AACJ,CAAC"}
|
|
1
|
+
{"version":3,"file":"ProductPanel.js","sourceRoot":"","sources":["../../../../src/react/components/commerce/ProductPanel.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useCommerceSync.d.ts","sourceRoot":"","sources":["../../../src/react/hooks/useCommerceSync.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,6BAA6B,CAAC;AAEhE,wBAAgB,iBAAiB,CAAC,QAAQ,EAAE,UAAU,GAAG,SAAS,EAAE,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,WAY7F;AAED,wBAAgB,eAAe,CAAC,QAAQ,EAAE,UAAU,GAAG,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO;;;;
|
|
1
|
+
{"version":3,"file":"useCommerceSync.d.ts","sourceRoot":"","sources":["../../../src/react/hooks/useCommerceSync.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,6BAA6B,CAAC;AAEhE,wBAAgB,iBAAiB,CAAC,QAAQ,EAAE,UAAU,GAAG,SAAS,EAAE,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,WAY7F;AAED,wBAAgB,eAAe,CAAC,QAAQ,EAAE,UAAU,GAAG,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO;;;;EA0B9F"}
|
|
@@ -14,7 +14,13 @@ export function resolveActiveCues(manifest, t, paused) {
|
|
|
14
14
|
});
|
|
15
15
|
}
|
|
16
16
|
export function useCommerceSync(manifest, time, paused) {
|
|
17
|
-
const activeCues = useMemo(() =>
|
|
17
|
+
const activeCues = useMemo(() => {
|
|
18
|
+
const cues = resolveActiveCues(manifest, time, paused);
|
|
19
|
+
if (manifest && cues.length > 0) {
|
|
20
|
+
console.log(`[COMMERCE] ✅ Active cues at time ${time.toFixed(2)}s (paused=${paused}):`, cues.map(c => c.id));
|
|
21
|
+
}
|
|
22
|
+
return cues;
|
|
23
|
+
}, [manifest, time, paused]);
|
|
18
24
|
const activeOverlays = useMemo(() => activeCues.flatMap(c => c.overlays), [activeCues]);
|
|
19
25
|
const activeProducts = useMemo(() => {
|
|
20
26
|
if (!manifest)
|
|
@@ -23,7 +29,11 @@ export function useCommerceSync(manifest, time, paused) {
|
|
|
23
29
|
for (const o of activeOverlays)
|
|
24
30
|
for (const r of o.productRefs)
|
|
25
31
|
ids.add(r.productId);
|
|
26
|
-
|
|
32
|
+
const products = manifest.products.filter(p => ids.has(p.id));
|
|
33
|
+
if (products.length > 0) {
|
|
34
|
+
console.log(`[COMMERCE] 🛍️ Active products:`, products.map(p => ({ id: p.id, title: p.title })));
|
|
35
|
+
}
|
|
36
|
+
return products;
|
|
27
37
|
}, [manifest, activeOverlays]);
|
|
28
38
|
return { activeCues, activeOverlays, activeProducts };
|
|
29
39
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useCommerceSync.js","sourceRoot":"","sources":["../../../src/react/hooks/useCommerceSync.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAGhC,MAAM,UAAU,iBAAiB,CAAC,QAAgC,EAAE,CAAS,EAAE,MAAe;IAC5F,IAAI,CAAC,QAAQ;QAAE,OAAO,EAAa,CAAC;IACpC,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE;QAC9B,IAAI,CAAC,CAAC,OAAO,CAAC,IAAI,KAAK,MAAM,IAAI,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE;YAC/C,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC;YACtC,OAAO,CAAC,IAAI,KAAK,IAAI,CAAC,GAAG,IAAI,IAAI,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;SAChD;QACD,IAAI,CAAC,CAAC,OAAO,CAAC,IAAI,KAAK,YAAY,EAAE;YACnC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,KAAK,OAAO,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,KAAK,QAAQ,IAAI,CAAC,MAAM,CAAC,CAAC;SACvG;QACD,OAAO,KAAK,CAAC;IACf,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,QAAgC,EAAE,IAAY,EAAE,MAAe;IAC7F,MAAM,UAAU,GAAG,OAAO,CAAC,GAAG,EAAE,
|
|
1
|
+
{"version":3,"file":"useCommerceSync.js","sourceRoot":"","sources":["../../../src/react/hooks/useCommerceSync.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAGhC,MAAM,UAAU,iBAAiB,CAAC,QAAgC,EAAE,CAAS,EAAE,MAAe;IAC5F,IAAI,CAAC,QAAQ;QAAE,OAAO,EAAa,CAAC;IACpC,OAAO,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE;QAC9B,IAAI,CAAC,CAAC,OAAO,CAAC,IAAI,KAAK,MAAM,IAAI,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE;YAC/C,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC;YACtC,OAAO,CAAC,IAAI,KAAK,IAAI,CAAC,GAAG,IAAI,IAAI,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;SAChD;QACD,IAAI,CAAC,CAAC,OAAO,CAAC,IAAI,KAAK,YAAY,EAAE;YACnC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,KAAK,OAAO,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,KAAK,QAAQ,IAAI,CAAC,MAAM,CAAC,CAAC;SACvG;QACD,OAAO,KAAK,CAAC;IACf,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,QAAgC,EAAE,IAAY,EAAE,MAAe;IAC7F,MAAM,UAAU,GAAG,OAAO,CAAC,GAAG,EAAE;QAC9B,MAAM,IAAI,GAAG,iBAAiB,CAAC,QAAQ,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;QACvD,IAAI,QAAQ,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;YAC/B,OAAO,CAAC,GAAG,CAAC,oCAAoC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,aAAa,MAAM,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;SAC9G;QACD,OAAO,IAAI,CAAC;IACd,CAAC,EAAE,CAAC,QAAQ,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC;IAE7B,MAAM,cAAc,GAAG,OAAO,CAC5B,GAAG,EAAE,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,EACzC,CAAC,UAAU,CAAC,CACb,CAAC;IAEF,MAAM,cAAc,GAAG,OAAO,CAAC,GAAG,EAAE;QAClC,IAAI,CAAC,QAAQ;YAAE,OAAO,EAAE,CAAC;QACzB,MAAM,GAAG,GAAG,IAAI,GAAG,EAAU,CAAC;QAC9B,KAAK,MAAM,CAAC,IAAI,cAAc;YAAE,KAAK,MAAM,CAAC,IAAI,CAAC,CAAC,WAAW;gBAAE,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;QACpF,MAAM,QAAQ,GAAG,QAAQ,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC9D,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;YACvB,OAAO,CAAC,GAAG,CAAC,iCAAiC,EAAE,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC;SACnG;QACD,OAAO,QAAQ,CAAC;IAClB,CAAC,EAAE,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAC,CAAC;IAE/B,OAAO,EAAE,UAAU,EAAE,cAAc,EAAE,cAAc,EAAE,CAAC;AACxD,CAAC"}
|
|
@@ -465,6 +465,10 @@ export class WebPlayer extends BasePlayer {
|
|
|
465
465
|
this.updateTime(t);
|
|
466
466
|
// Emit time update event for React components (e.g., commerce sync)
|
|
467
467
|
this.emit('onTimeUpdate', t);
|
|
468
|
+
// Debug: Log time update every ~5 seconds
|
|
469
|
+
if (Math.floor(t) % 5 === 0 && Math.floor(t) !== Math.floor((this.video?.currentTime || 0) - 0.1)) {
|
|
470
|
+
console.log(`[DEBUG] onTimeUpdate emitted: ${t.toFixed(2)}s`);
|
|
471
|
+
}
|
|
468
472
|
// Enforce free preview gate on local playback
|
|
469
473
|
this.enforceFreePreviewGate(t);
|
|
470
474
|
// Process chapter time updates
|
|
@@ -8,11 +8,12 @@ type Props = {
|
|
|
8
8
|
};
|
|
9
9
|
|
|
10
10
|
export default function ProductBadge({ product, overlay, onClick }: Props) {
|
|
11
|
+
console.log('[COMMERCE] 🎨 Rendering ProductBadge:', product.id, product.title);
|
|
11
12
|
const showPrice = overlay.style?.badge?.showPrice !== false;
|
|
12
13
|
const showThumb = overlay.style?.badge?.showThumb !== false;
|
|
13
14
|
|
|
14
15
|
const base: React.CSSProperties = {
|
|
15
|
-
position: "
|
|
16
|
+
position: "fixed",
|
|
16
17
|
bottom: overlay.placement?.mode === "dock" && overlay.placement.edge === "bottom" ? 16 : undefined,
|
|
17
18
|
top: overlay.placement?.mode === "dock" && overlay.placement.edge === "top" ? 16 : undefined,
|
|
18
19
|
left: overlay.placement?.mode === "dock" && overlay.placement.edge === "left" ? 16 : undefined,
|
|
@@ -13,6 +13,7 @@ type Props = {
|
|
|
13
13
|
export default function ProductPanel({
|
|
14
14
|
products, visible, position = "right", width = 360, onProductClick, onClose
|
|
15
15
|
}: Props) {
|
|
16
|
+
console.log('[COMMERCE] 📋 ProductPanel:', { visible, products: products.length, position, width });
|
|
16
17
|
const style: React.CSSProperties = {
|
|
17
18
|
position: "fixed",
|
|
18
19
|
top: position === "bottom" ? undefined : 0,
|
|
@@ -16,7 +16,13 @@ export function resolveActiveCues(manifest: VCManifest | undefined, t: number, p
|
|
|
16
16
|
}
|
|
17
17
|
|
|
18
18
|
export function useCommerceSync(manifest: VCManifest | undefined, time: number, paused: boolean) {
|
|
19
|
-
const activeCues = useMemo(() =>
|
|
19
|
+
const activeCues = useMemo(() => {
|
|
20
|
+
const cues = resolveActiveCues(manifest, time, paused);
|
|
21
|
+
if (manifest && cues.length > 0) {
|
|
22
|
+
console.log(`[COMMERCE] ✅ Active cues at time ${time.toFixed(2)}s (paused=${paused}):`, cues.map(c => c.id));
|
|
23
|
+
}
|
|
24
|
+
return cues;
|
|
25
|
+
}, [manifest, time, paused]);
|
|
20
26
|
|
|
21
27
|
const activeOverlays = useMemo(
|
|
22
28
|
() => activeCues.flatMap(c => c.overlays),
|
|
@@ -27,7 +33,11 @@ export function useCommerceSync(manifest: VCManifest | undefined, time: number,
|
|
|
27
33
|
if (!manifest) return [];
|
|
28
34
|
const ids = new Set<string>();
|
|
29
35
|
for (const o of activeOverlays) for (const r of o.productRefs) ids.add(r.productId);
|
|
30
|
-
|
|
36
|
+
const products = manifest.products.filter(p => ids.has(p.id));
|
|
37
|
+
if (products.length > 0) {
|
|
38
|
+
console.log(`[COMMERCE] 🛍️ Active products:`, products.map(p => ({ id: p.id, title: p.title })));
|
|
39
|
+
}
|
|
40
|
+
return products;
|
|
31
41
|
}, [manifest, activeOverlays]);
|
|
32
42
|
|
|
33
43
|
return { activeCues, activeOverlays, activeProducts };
|