markdown-flow-ui 0.1.106-beta.2 → 0.1.106-beta.3

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 (61) hide show
  1. package/dist/_virtual/index.cjs10.js +1 -1
  2. package/dist/_virtual/index.cjs7.js +1 -1
  3. package/dist/_virtual/index.cjs8.js +1 -1
  4. package/dist/_virtual/index.cjs9.js +1 -1
  5. package/dist/_virtual/index.es10.js +2 -2
  6. package/dist/_virtual/index.es7.js +2 -2
  7. package/dist/_virtual/index.es8.js +3 -2
  8. package/dist/_virtual/index.es8.js.map +1 -1
  9. package/dist/_virtual/index.es9.js +2 -3
  10. package/dist/_virtual/index.es9.js.map +1 -1
  11. package/dist/components/Slide/MobilePlayerSettingsSheet.cjs.js +1 -1
  12. package/dist/components/Slide/MobilePlayerSettingsSheet.cjs.js.map +1 -1
  13. package/dist/components/Slide/MobilePlayerSettingsSheet.d.ts +6 -6
  14. package/dist/components/Slide/MobilePlayerSettingsSheet.es.js +26 -26
  15. package/dist/components/Slide/MobilePlayerSettingsSheet.es.js.map +1 -1
  16. package/dist/components/Slide/Player.cjs.js +1 -1
  17. package/dist/components/Slide/Player.cjs.js.map +1 -1
  18. package/dist/components/Slide/Player.d.ts +6 -5
  19. package/dist/components/Slide/Player.es.js +129 -133
  20. package/dist/components/Slide/Player.es.js.map +1 -1
  21. package/dist/components/Slide/Slide.cjs.js +1 -1
  22. package/dist/components/Slide/Slide.cjs.js.map +1 -1
  23. package/dist/components/Slide/Slide.d.ts +4 -4
  24. package/dist/components/Slide/Slide.es.js +555 -523
  25. package/dist/components/Slide/Slide.es.js.map +1 -1
  26. package/dist/components/Slide/Slide.stories.d.ts +6 -5
  27. package/dist/components/Slide/SlideFullscreenHint.cjs.js +2 -0
  28. package/dist/components/Slide/SlideFullscreenHint.cjs.js.map +1 -0
  29. package/dist/components/Slide/SlideFullscreenHint.d.ts +9 -0
  30. package/dist/components/Slide/SlideFullscreenHint.es.js +42 -0
  31. package/dist/components/Slide/SlideFullscreenHint.es.js.map +1 -0
  32. package/dist/components/Slide/constants.cjs.js +2 -0
  33. package/dist/components/Slide/constants.cjs.js.map +1 -0
  34. package/dist/components/Slide/constants.d.ts +8 -0
  35. package/dist/components/Slide/constants.es.js +12 -0
  36. package/dist/components/Slide/constants.es.js.map +1 -0
  37. package/dist/components/Slide/index.d.ts +2 -2
  38. package/dist/components/Slide/utils/mobileScreenMode.cjs.js +1 -1
  39. package/dist/components/Slide/utils/mobileScreenMode.cjs.js.map +1 -1
  40. package/dist/components/Slide/utils/mobileScreenMode.d.ts +14 -14
  41. package/dist/components/Slide/utils/mobileScreenMode.es.js +14 -13
  42. package/dist/components/Slide/utils/mobileScreenMode.es.js.map +1 -1
  43. package/dist/markdown-flow-ui/node_modules/.pnpm/@braintree_sanitize-url@7.1.1/node_modules/@braintree/sanitize-url/dist/index.cjs.js +1 -1
  44. package/dist/markdown-flow-ui/node_modules/.pnpm/@braintree_sanitize-url@7.1.1/node_modules/@braintree/sanitize-url/dist/index.cjs.js.map +1 -1
  45. package/dist/markdown-flow-ui/node_modules/.pnpm/@braintree_sanitize-url@7.1.1/node_modules/@braintree/sanitize-url/dist/index.es.js +1 -1
  46. package/dist/markdown-flow-ui/node_modules/.pnpm/classnames@2.5.1/node_modules/classnames/index.cjs.js +1 -1
  47. package/dist/markdown-flow-ui/node_modules/.pnpm/classnames@2.5.1/node_modules/classnames/index.es.js +1 -1
  48. package/dist/markdown-flow-ui/node_modules/.pnpm/mermaid@11.12.1/node_modules/mermaid/dist/chunks/mermaid.core/c4Diagram-YG6GDRKO.cjs.js +1 -1
  49. package/dist/markdown-flow-ui/node_modules/.pnpm/mermaid@11.12.1/node_modules/mermaid/dist/chunks/mermaid.core/c4Diagram-YG6GDRKO.es.js +1 -1
  50. package/dist/markdown-flow-ui/node_modules/.pnpm/mermaid@11.12.1/node_modules/mermaid/dist/chunks/mermaid.core/chunk-S3R3BYOJ.cjs.js +1 -1
  51. package/dist/markdown-flow-ui/node_modules/.pnpm/mermaid@11.12.1/node_modules/mermaid/dist/chunks/mermaid.core/chunk-S3R3BYOJ.es.js +1 -1
  52. package/dist/markdown-flow-ui/node_modules/.pnpm/mermaid@11.12.1/node_modules/mermaid/dist/chunks/mermaid.core/chunk-TZMSLE5B.cjs.js +1 -1
  53. package/dist/markdown-flow-ui/node_modules/.pnpm/mermaid@11.12.1/node_modules/mermaid/dist/chunks/mermaid.core/chunk-TZMSLE5B.es.js +1 -1
  54. package/dist/markdown-flow-ui/node_modules/.pnpm/mermaid@11.12.1/node_modules/mermaid/dist/chunks/mermaid.core/ganttDiagram-LVOFAZNH.cjs.js +1 -1
  55. package/dist/markdown-flow-ui/node_modules/.pnpm/mermaid@11.12.1/node_modules/mermaid/dist/chunks/mermaid.core/ganttDiagram-LVOFAZNH.es.js +1 -1
  56. package/dist/markdown-flow-ui/node_modules/.pnpm/mermaid@11.12.1/node_modules/mermaid/dist/chunks/mermaid.core/sequenceDiagram-WL72ISMW.cjs.js +1 -1
  57. package/dist/markdown-flow-ui/node_modules/.pnpm/mermaid@11.12.1/node_modules/mermaid/dist/chunks/mermaid.core/sequenceDiagram-WL72ISMW.es.js +1 -1
  58. package/dist/markdown-flow-ui/node_modules/.pnpm/style-to-object@1.0.11/node_modules/style-to-object/cjs/index.cjs.js +1 -1
  59. package/dist/markdown-flow-ui/node_modules/.pnpm/style-to-object@1.0.11/node_modules/style-to-object/cjs/index.es.js +1 -1
  60. package/dist/markdown-flow-ui-lib.css +1 -1
  61. package/package.json +1 -1
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});var e={};exports.__exports=e;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});var e={exports:{}};exports.__module=e;
2
2
  //# sourceMappingURL=index.cjs10.js.map
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});var e={exports:{}};exports.__module=e;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});var e={};exports.__exports=e;
2
2
  //# sourceMappingURL=index.cjs7.js.map
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});var e={};exports.__exports=e;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("../markdown-flow-ui/node_modules/.pnpm/@braintree_sanitize-url@7.1.1/node_modules/@braintree/sanitize-url/dist/index.cjs.js");var r=e.__require();exports.distExports=r;
2
2
  //# sourceMappingURL=index.cjs8.js.map
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("../markdown-flow-ui/node_modules/.pnpm/@braintree_sanitize-url@7.1.1/node_modules/@braintree/sanitize-url/dist/index.cjs.js");var r=e.__require();exports.distExports=r;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});var e={};exports.__exports=e;
2
2
  //# sourceMappingURL=index.cjs9.js.map
@@ -1,5 +1,5 @@
1
- var r = {};
1
+ var s = { exports: {} };
2
2
  export {
3
- r as __exports
3
+ s as __module
4
4
  };
5
5
  //# sourceMappingURL=index.es10.js.map
@@ -1,5 +1,5 @@
1
- var s = { exports: {} };
1
+ var r = {};
2
2
  export {
3
- s as __module
3
+ r as __exports
4
4
  };
5
5
  //# sourceMappingURL=index.es7.js.map
@@ -1,5 +1,6 @@
1
- var r = {};
1
+ import { __require as r } from "../markdown-flow-ui/node_modules/.pnpm/@braintree_sanitize-url@7.1.1/node_modules/@braintree/sanitize-url/dist/index.es.js";
2
+ var i = r();
2
3
  export {
3
- r as __exports
4
+ i as d
4
5
  };
5
6
  //# sourceMappingURL=index.es8.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.es8.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
1
+ {"version":3,"file":"index.es8.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;"}
@@ -1,6 +1,5 @@
1
- import { __require as r } from "../markdown-flow-ui/node_modules/.pnpm/@braintree_sanitize-url@7.1.1/node_modules/@braintree/sanitize-url/dist/index.es.js";
2
- var i = r();
1
+ var r = {};
3
2
  export {
4
- i as d
3
+ r as __exports
5
4
  };
6
5
  //# sourceMappingURL=index.es9.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.es9.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;"}
1
+ {"version":3,"file":"index.es9.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("../../_virtual/jsx-runtime.cjs.js"),d=require("../../markdown-flow-ui/node_modules/.pnpm/@radix-ui_react-dialog@1.1.15_@types_react-dom@19.2.2_@types_react@19.2.2__@types_react_47bb8d90b09b6a0ef5443ddd7a1cb20c/node_modules/@radix-ui/react-dialog/dist/index.cjs.js"),s=require("../../lib/utils.cjs.js"),o=require("../ui/dialog.cjs.js"),c=require("../../markdown-flow-ui/node_modules/.pnpm/lucide-react@0.525.0_react@19.0.1/node_modules/lucide-react/dist/esm/icons/x.cjs.js"),u=({open:i,labels:t,screenMode:r,container:a,onClose:l,onOpenChange:x,onScreenModeChange:n})=>e.jsxRuntimeExports.jsx(o.Dialog,{open:i,onOpenChange:x,children:e.jsxRuntimeExports.jsxs(o.DialogPortal,{container:a,children:[e.jsxRuntimeExports.jsx(o.DialogOverlay,{className:"z-[60] bg-black/35"}),e.jsxRuntimeExports.jsxs(d.Content,{"aria-describedby":void 0,className:s.cn("fixed inset-x-0 bottom-0 z-[61] flex max-h-[min(360px,calc(100dvh-32px))] flex-col overflow-hidden rounded-t-[24px] border-t border-border bg-background shadow-[0_-12px_32px_rgba(28,44,64,0.16)] outline-none","data-[state=open]:animate-in data-[state=closed]:animate-out","data-[state=open]:slide-in-from-bottom-full data-[state=closed]:slide-out-to-bottom-full"),children:[e.jsxRuntimeExports.jsxs("div",{className:"flex min-h-14 items-center justify-between border-b border-border px-6",children:[e.jsxRuntimeExports.jsx(o.DialogTitle,{className:"text-[15px] font-semibold leading-5 text-foreground",children:t.title}),e.jsxRuntimeExports.jsx("button",{"aria-label":"Close settings",className:"inline-flex h-8 w-8 items-center justify-center rounded-full border-none bg-transparent p-0 text-foreground/70 transition-colors hover:text-foreground",onClick:l,type:"button",children:e.jsxRuntimeExports.jsx(c.default,{className:"h-4 w-4"})})]}),e.jsxRuntimeExports.jsxs("div",{className:"flex min-h-[72px] items-center gap-6 px-6",children:[e.jsxRuntimeExports.jsx("span",{className:"shrink-0 text-[15px] font-semibold leading-5 text-foreground",children:t.screen}),e.jsxRuntimeExports.jsxs("div",{"aria-label":"Screen orientation",className:"flex items-center gap-8",role:"radiogroup",children:[e.jsxRuntimeExports.jsx("button",{"aria-checked":r==="portrait",className:s.cn("border-none bg-transparent p-0 text-[15px] leading-5 text-foreground/70 transition-colors",r==="portrait"&&"font-semibold text-primary"),onClick:()=>n("portrait"),role:"radio",type:"button",children:t.portrait}),e.jsxRuntimeExports.jsx("button",{"aria-checked":r==="landscape",className:s.cn("border-none bg-transparent p-0 text-[15px] leading-5 text-foreground/70 transition-colors",r==="landscape"&&"font-semibold text-primary"),onClick:()=>n("landscape"),role:"radio",type:"button",children:t.landscape})]})]})]})]})});exports.default=u;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("../../_virtual/jsx-runtime.cjs.js"),d=require("../../markdown-flow-ui/node_modules/.pnpm/@radix-ui_react-dialog@1.1.15_@types_react-dom@19.2.2_@types_react@19.2.2__@types_react_47bb8d90b09b6a0ef5443ddd7a1cb20c/node_modules/@radix-ui/react-dialog/dist/index.cjs.js"),s=require("../../lib/utils.cjs.js"),r=require("../ui/dialog.cjs.js"),c=require("../../markdown-flow-ui/node_modules/.pnpm/lucide-react@0.525.0_react@19.0.1/node_modules/lucide-react/dist/esm/icons/x.cjs.js"),u=({open:i,labels:t,viewMode:n,container:l,onClose:a,onOpenChange:x,onViewModeChange:o})=>e.jsxRuntimeExports.jsx(r.Dialog,{open:i,onOpenChange:x,children:e.jsxRuntimeExports.jsxs(r.DialogPortal,{container:l,children:[e.jsxRuntimeExports.jsx(r.DialogOverlay,{className:"z-[60] bg-black/35"}),e.jsxRuntimeExports.jsxs(d.Content,{"aria-describedby":void 0,className:s.cn("fixed inset-x-0 bottom-0 z-[61] flex max-h-[min(360px,calc(100dvh-32px))] flex-col overflow-hidden rounded-t-[24px] border-t border-border bg-background shadow-[0_-12px_32px_rgba(28,44,64,0.16)] outline-none","data-[state=open]:animate-in data-[state=closed]:animate-out","data-[state=open]:slide-in-from-bottom-full data-[state=closed]:slide-out-to-bottom-full"),children:[e.jsxRuntimeExports.jsxs("div",{className:"flex min-h-14 items-center justify-between border-b border-border px-6",children:[e.jsxRuntimeExports.jsx(r.DialogTitle,{className:"text-[15px] font-semibold leading-5 text-foreground",children:t.title}),e.jsxRuntimeExports.jsx("button",{"aria-label":"Close settings",className:"inline-flex h-8 w-8 items-center justify-center rounded-full border-none bg-transparent p-0 text-foreground/70 transition-colors hover:text-foreground",onClick:a,type:"button",children:e.jsxRuntimeExports.jsx(c.default,{className:"h-4 w-4"})})]}),e.jsxRuntimeExports.jsxs("div",{className:"flex min-h-[72px] items-center gap-6 px-6",children:[e.jsxRuntimeExports.jsx("span",{className:"shrink-0 text-[15px] font-semibold leading-5 text-foreground",children:t.screen}),e.jsxRuntimeExports.jsxs("div",{"aria-label":"Screen mode",className:"flex items-center gap-8",role:"radiogroup",children:[e.jsxRuntimeExports.jsx("button",{"aria-checked":n==="nonFullscreen",className:s.cn("border-none bg-transparent p-0 text-[15px] leading-5 text-foreground/70 transition-colors",n==="nonFullscreen"&&"font-semibold text-primary"),onClick:()=>o("nonFullscreen"),role:"radio",type:"button",children:t.nonFullscreen}),e.jsxRuntimeExports.jsx("button",{"aria-checked":n==="fullscreen",className:s.cn("border-none bg-transparent p-0 text-[15px] leading-5 text-foreground/70 transition-colors",n==="fullscreen"&&"font-semibold text-primary"),onClick:()=>o("fullscreen"),role:"radio",type:"button",children:t.fullscreen})]})]})]})]})});exports.default=u;
2
2
  //# sourceMappingURL=MobilePlayerSettingsSheet.cjs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"MobilePlayerSettingsSheet.cjs.js","sources":["../../../src/components/Slide/MobilePlayerSettingsSheet.tsx"],"sourcesContent":["import * as DialogPrimitive from \"@radix-ui/react-dialog\";\nimport { X } from \"lucide-react\";\n\nimport { cn } from \"../../lib/utils\";\nimport { Dialog, DialogOverlay, DialogPortal, DialogTitle } from \"../ui/dialog\";\nimport type { MobileScreenMode } from \"./utils/mobileScreenMode\";\n\nexport type MobilePlayerSettingsSheetLabels = {\n title: string;\n screen: string;\n portrait: string;\n landscape: string;\n};\n\nexport type MobilePlayerSettingsSheetProps = {\n open: boolean;\n labels: MobilePlayerSettingsSheetLabels;\n screenMode: MobileScreenMode;\n container?: HTMLElement | null;\n onClose: () => void;\n onOpenChange: (open: boolean) => void;\n onScreenModeChange: (nextScreenMode: MobileScreenMode) => void;\n};\n\nconst MobilePlayerSettingsSheet = ({\n open,\n labels,\n screenMode,\n container,\n onClose,\n onOpenChange,\n onScreenModeChange,\n}: MobilePlayerSettingsSheetProps) => {\n return (\n <Dialog open={open} onOpenChange={onOpenChange}>\n <DialogPortal container={container}>\n <DialogOverlay className=\"z-[60] bg-black/35\" />\n <DialogPrimitive.Content\n aria-describedby={undefined}\n className={cn(\n \"fixed inset-x-0 bottom-0 z-[61] flex max-h-[min(360px,calc(100dvh-32px))] flex-col overflow-hidden rounded-t-[24px] border-t border-border bg-background shadow-[0_-12px_32px_rgba(28,44,64,0.16)] outline-none\",\n \"data-[state=open]:animate-in data-[state=closed]:animate-out\",\n \"data-[state=open]:slide-in-from-bottom-full data-[state=closed]:slide-out-to-bottom-full\"\n )}\n >\n <div className=\"flex min-h-14 items-center justify-between border-b border-border px-6\">\n <DialogTitle className=\"text-[15px] font-semibold leading-5 text-foreground\">\n {labels.title}\n </DialogTitle>\n <button\n aria-label=\"Close settings\"\n className=\"inline-flex h-8 w-8 items-center justify-center rounded-full border-none bg-transparent p-0 text-foreground/70 transition-colors hover:text-foreground\"\n onClick={onClose}\n type=\"button\"\n >\n <X className=\"h-4 w-4\" />\n </button>\n </div>\n\n <div className=\"flex min-h-[72px] items-center gap-6 px-6\">\n <span className=\"shrink-0 text-[15px] font-semibold leading-5 text-foreground\">\n {labels.screen}\n </span>\n <div\n aria-label=\"Screen orientation\"\n className=\"flex items-center gap-8\"\n role=\"radiogroup\"\n >\n <button\n aria-checked={screenMode === \"portrait\"}\n className={cn(\n \"border-none bg-transparent p-0 text-[15px] leading-5 text-foreground/70 transition-colors\",\n screenMode === \"portrait\" && \"font-semibold text-primary\"\n )}\n onClick={() => onScreenModeChange(\"portrait\")}\n role=\"radio\"\n type=\"button\"\n >\n {labels.portrait}\n </button>\n <button\n aria-checked={screenMode === \"landscape\"}\n className={cn(\n \"border-none bg-transparent p-0 text-[15px] leading-5 text-foreground/70 transition-colors\",\n screenMode === \"landscape\" && \"font-semibold text-primary\"\n )}\n onClick={() => onScreenModeChange(\"landscape\")}\n role=\"radio\"\n type=\"button\"\n >\n {labels.landscape}\n </button>\n </div>\n </div>\n </DialogPrimitive.Content>\n </DialogPortal>\n </Dialog>\n );\n};\n\nexport default MobilePlayerSettingsSheet;\n"],"names":["MobilePlayerSettingsSheet","open","labels","screenMode","container","onClose","onOpenChange","onScreenModeChange","Dialog","jsxs","DialogPortal","jsx","DialogOverlay","DialogPrimitive.Content","cn","DialogTitle","X"],"mappings":"ulBAwBMA,EAA4B,CAAC,CACjC,KAAAC,EACA,OAAAC,EACA,WAAAC,EACA,UAAAC,EACA,QAAAC,EACA,aAAAC,EACA,mBAAAC,CACF,4BAEKC,EAAAA,OAAA,CAAO,KAAAP,EAAY,aAAAK,EAClB,SAAAG,EAAAA,kBAAAA,KAACC,EAAAA,cAAa,UAAAN,EACZ,SAAA,CAAAO,EAAAA,kBAAAA,IAACC,EAAAA,cAAA,CAAc,UAAU,oBAAA,CAAqB,EAC9CH,EAAAA,kBAAAA,KAACI,EAAAA,QAAA,CACC,mBAAkB,OAClB,UAAWC,EAAAA,GACT,kNACA,+DACA,0FAAA,EAGF,SAAA,CAAAL,EAAAA,kBAAAA,KAAC,MAAA,CAAI,UAAU,yEACb,SAAA,CAAAE,EAAAA,kBAAAA,IAACI,EAAAA,YAAA,CAAY,UAAU,sDACpB,SAAAb,EAAO,MACV,EACAS,EAAAA,kBAAAA,IAAC,SAAA,CACC,aAAW,iBACX,UAAU,yJACV,QAASN,EACT,KAAK,SAEL,SAAAM,EAAAA,kBAAAA,IAACK,EAAAA,QAAA,CAAE,UAAU,SAAA,CAAU,CAAA,CAAA,CACzB,EACF,EAEAP,EAAAA,kBAAAA,KAAC,MAAA,CAAI,UAAU,4CACb,SAAA,CAAAE,EAAAA,kBAAAA,IAAC,OAAA,CAAK,UAAU,+DACb,SAAAT,EAAO,OACV,EACAO,EAAAA,kBAAAA,KAAC,MAAA,CACC,aAAW,qBACX,UAAU,0BACV,KAAK,aAEL,SAAA,CAAAE,EAAAA,kBAAAA,IAAC,SAAA,CACC,eAAcR,IAAe,WAC7B,UAAWW,EAAAA,GACT,4FACAX,IAAe,YAAc,4BAAA,EAE/B,QAAS,IAAMI,EAAmB,UAAU,EAC5C,KAAK,QACL,KAAK,SAEJ,SAAAL,EAAO,QAAA,CAAA,EAEVS,EAAAA,kBAAAA,IAAC,SAAA,CACC,eAAcR,IAAe,YAC7B,UAAWW,EAAAA,GACT,4FACAX,IAAe,aAAe,4BAAA,EAEhC,QAAS,IAAMI,EAAmB,WAAW,EAC7C,KAAK,QACL,KAAK,SAEJ,SAAAL,EAAO,SAAA,CAAA,CACV,CAAA,CAAA,CACF,CAAA,CACF,CAAA,CAAA,CAAA,CACF,CAAA,CACF,CAAA,CACF"}
1
+ {"version":3,"file":"MobilePlayerSettingsSheet.cjs.js","sources":["../../../src/components/Slide/MobilePlayerSettingsSheet.tsx"],"sourcesContent":["import * as DialogPrimitive from \"@radix-ui/react-dialog\";\nimport { X } from \"lucide-react\";\n\nimport { cn } from \"../../lib/utils\";\nimport { Dialog, DialogOverlay, DialogPortal, DialogTitle } from \"../ui/dialog\";\nimport type { MobileViewMode } from \"./utils/mobileScreenMode\";\n\nexport type MobilePlayerSettingsSheetLabels = {\n title: string;\n screen: string;\n nonFullscreen: string;\n fullscreen: string;\n};\n\nexport type MobilePlayerSettingsSheetProps = {\n open: boolean;\n labels: MobilePlayerSettingsSheetLabels;\n viewMode: MobileViewMode;\n container?: HTMLElement | null;\n onClose: () => void;\n onOpenChange: (open: boolean) => void;\n onViewModeChange: (nextViewMode: MobileViewMode) => void;\n};\n\nconst MobilePlayerSettingsSheet = ({\n open,\n labels,\n viewMode,\n container,\n onClose,\n onOpenChange,\n onViewModeChange,\n}: MobilePlayerSettingsSheetProps) => {\n return (\n <Dialog open={open} onOpenChange={onOpenChange}>\n <DialogPortal container={container}>\n <DialogOverlay className=\"z-[60] bg-black/35\" />\n <DialogPrimitive.Content\n aria-describedby={undefined}\n className={cn(\n \"fixed inset-x-0 bottom-0 z-[61] flex max-h-[min(360px,calc(100dvh-32px))] flex-col overflow-hidden rounded-t-[24px] border-t border-border bg-background shadow-[0_-12px_32px_rgba(28,44,64,0.16)] outline-none\",\n \"data-[state=open]:animate-in data-[state=closed]:animate-out\",\n \"data-[state=open]:slide-in-from-bottom-full data-[state=closed]:slide-out-to-bottom-full\"\n )}\n >\n <div className=\"flex min-h-14 items-center justify-between border-b border-border px-6\">\n <DialogTitle className=\"text-[15px] font-semibold leading-5 text-foreground\">\n {labels.title}\n </DialogTitle>\n <button\n aria-label=\"Close settings\"\n className=\"inline-flex h-8 w-8 items-center justify-center rounded-full border-none bg-transparent p-0 text-foreground/70 transition-colors hover:text-foreground\"\n onClick={onClose}\n type=\"button\"\n >\n <X className=\"h-4 w-4\" />\n </button>\n </div>\n\n <div className=\"flex min-h-[72px] items-center gap-6 px-6\">\n <span className=\"shrink-0 text-[15px] font-semibold leading-5 text-foreground\">\n {labels.screen}\n </span>\n <div\n aria-label=\"Screen mode\"\n className=\"flex items-center gap-8\"\n role=\"radiogroup\"\n >\n <button\n aria-checked={viewMode === \"nonFullscreen\"}\n className={cn(\n \"border-none bg-transparent p-0 text-[15px] leading-5 text-foreground/70 transition-colors\",\n viewMode === \"nonFullscreen\" && \"font-semibold text-primary\"\n )}\n onClick={() => onViewModeChange(\"nonFullscreen\")}\n role=\"radio\"\n type=\"button\"\n >\n {labels.nonFullscreen}\n </button>\n <button\n aria-checked={viewMode === \"fullscreen\"}\n className={cn(\n \"border-none bg-transparent p-0 text-[15px] leading-5 text-foreground/70 transition-colors\",\n viewMode === \"fullscreen\" && \"font-semibold text-primary\"\n )}\n onClick={() => onViewModeChange(\"fullscreen\")}\n role=\"radio\"\n type=\"button\"\n >\n {labels.fullscreen}\n </button>\n </div>\n </div>\n </DialogPrimitive.Content>\n </DialogPortal>\n </Dialog>\n );\n};\n\nexport default MobilePlayerSettingsSheet;\n"],"names":["MobilePlayerSettingsSheet","open","labels","viewMode","container","onClose","onOpenChange","onViewModeChange","Dialog","jsxs","DialogPortal","jsx","DialogOverlay","DialogPrimitive.Content","cn","DialogTitle","X"],"mappings":"ulBAwBMA,EAA4B,CAAC,CACjC,KAAAC,EACA,OAAAC,EACA,SAAAC,EACA,UAAAC,EACA,QAAAC,EACA,aAAAC,EACA,iBAAAC,CACF,4BAEKC,EAAAA,OAAA,CAAO,KAAAP,EAAY,aAAAK,EAClB,SAAAG,EAAAA,kBAAAA,KAACC,EAAAA,cAAa,UAAAN,EACZ,SAAA,CAAAO,EAAAA,kBAAAA,IAACC,EAAAA,cAAA,CAAc,UAAU,oBAAA,CAAqB,EAC9CH,EAAAA,kBAAAA,KAACI,EAAAA,QAAA,CACC,mBAAkB,OAClB,UAAWC,EAAAA,GACT,kNACA,+DACA,0FAAA,EAGF,SAAA,CAAAL,EAAAA,kBAAAA,KAAC,MAAA,CAAI,UAAU,yEACb,SAAA,CAAAE,EAAAA,kBAAAA,IAACI,EAAAA,YAAA,CAAY,UAAU,sDACpB,SAAAb,EAAO,MACV,EACAS,EAAAA,kBAAAA,IAAC,SAAA,CACC,aAAW,iBACX,UAAU,yJACV,QAASN,EACT,KAAK,SAEL,SAAAM,EAAAA,kBAAAA,IAACK,EAAAA,QAAA,CAAE,UAAU,SAAA,CAAU,CAAA,CAAA,CACzB,EACF,EAEAP,EAAAA,kBAAAA,KAAC,MAAA,CAAI,UAAU,4CACb,SAAA,CAAAE,EAAAA,kBAAAA,IAAC,OAAA,CAAK,UAAU,+DACb,SAAAT,EAAO,OACV,EACAO,EAAAA,kBAAAA,KAAC,MAAA,CACC,aAAW,cACX,UAAU,0BACV,KAAK,aAEL,SAAA,CAAAE,EAAAA,kBAAAA,IAAC,SAAA,CACC,eAAcR,IAAa,gBAC3B,UAAWW,EAAAA,GACT,4FACAX,IAAa,iBAAmB,4BAAA,EAElC,QAAS,IAAMI,EAAiB,eAAe,EAC/C,KAAK,QACL,KAAK,SAEJ,SAAAL,EAAO,aAAA,CAAA,EAEVS,EAAAA,kBAAAA,IAAC,SAAA,CACC,eAAcR,IAAa,aAC3B,UAAWW,EAAAA,GACT,4FACAX,IAAa,cAAgB,4BAAA,EAE/B,QAAS,IAAMI,EAAiB,YAAY,EAC5C,KAAK,QACL,KAAK,SAEJ,SAAAL,EAAO,UAAA,CAAA,CACV,CAAA,CAAA,CACF,CAAA,CACF,CAAA,CAAA,CAAA,CACF,CAAA,CACF,CAAA,CACF"}
@@ -1,18 +1,18 @@
1
- import { MobileScreenMode } from './utils/mobileScreenMode';
1
+ import { MobileViewMode } from './utils/mobileScreenMode';
2
2
  export type MobilePlayerSettingsSheetLabels = {
3
3
  title: string;
4
4
  screen: string;
5
- portrait: string;
6
- landscape: string;
5
+ nonFullscreen: string;
6
+ fullscreen: string;
7
7
  };
8
8
  export type MobilePlayerSettingsSheetProps = {
9
9
  open: boolean;
10
10
  labels: MobilePlayerSettingsSheetLabels;
11
- screenMode: MobileScreenMode;
11
+ viewMode: MobileViewMode;
12
12
  container?: HTMLElement | null;
13
13
  onClose: () => void;
14
14
  onOpenChange: (open: boolean) => void;
15
- onScreenModeChange: (nextScreenMode: MobileScreenMode) => void;
15
+ onViewModeChange: (nextViewMode: MobileViewMode) => void;
16
16
  };
17
- declare const MobilePlayerSettingsSheet: ({ open, labels, screenMode, container, onClose, onOpenChange, onScreenModeChange, }: MobilePlayerSettingsSheetProps) => import("react").JSX.Element;
17
+ declare const MobilePlayerSettingsSheet: ({ open, labels, viewMode, container, onClose, onOpenChange, onViewModeChange, }: MobilePlayerSettingsSheetProps) => import("react").JSX.Element;
18
18
  export default MobilePlayerSettingsSheet;
@@ -1,38 +1,38 @@
1
1
  import { j as e } from "../../_virtual/jsx-runtime.es.js";
2
2
  import { Content as d } from "../../markdown-flow-ui/node_modules/.pnpm/@radix-ui_react-dialog@1.1.15_@types_react-dom@19.2.2_@types_react@19.2.2__@types_react_47bb8d90b09b6a0ef5443ddd7a1cb20c/node_modules/@radix-ui/react-dialog/dist/index.es.js";
3
- import { cn as o } from "../../lib/utils.es.js";
4
- import { Dialog as c, DialogPortal as x, DialogOverlay as p, DialogTitle as m } from "../ui/dialog.es.js";
5
- import b from "../../markdown-flow-ui/node_modules/.pnpm/lucide-react@0.525.0_react@19.0.1/node_modules/lucide-react/dist/esm/icons/x.es.js";
3
+ import { cn as n } from "../../lib/utils.es.js";
4
+ import { Dialog as c, DialogPortal as x, DialogOverlay as m, DialogTitle as p } from "../ui/dialog.es.js";
5
+ import u from "../../markdown-flow-ui/node_modules/.pnpm/lucide-react@0.525.0_react@19.0.1/node_modules/lucide-react/dist/esm/icons/x.es.js";
6
6
  const N = ({
7
- open: n,
7
+ open: l,
8
8
  labels: t,
9
- screenMode: r,
10
- container: i,
11
- onClose: s,
12
- onOpenChange: l,
13
- onScreenModeChange: a
14
- }) => /* @__PURE__ */ e.jsx(c, { open: n, onOpenChange: l, children: /* @__PURE__ */ e.jsxs(x, { container: i, children: [
15
- /* @__PURE__ */ e.jsx(p, { className: "z-[60] bg-black/35" }),
9
+ viewMode: r,
10
+ container: s,
11
+ onClose: a,
12
+ onOpenChange: i,
13
+ onViewModeChange: o
14
+ }) => /* @__PURE__ */ e.jsx(c, { open: l, onOpenChange: i, children: /* @__PURE__ */ e.jsxs(x, { container: s, children: [
15
+ /* @__PURE__ */ e.jsx(m, { className: "z-[60] bg-black/35" }),
16
16
  /* @__PURE__ */ e.jsxs(
17
17
  d,
18
18
  {
19
19
  "aria-describedby": void 0,
20
- className: o(
20
+ className: n(
21
21
  "fixed inset-x-0 bottom-0 z-[61] flex max-h-[min(360px,calc(100dvh-32px))] flex-col overflow-hidden rounded-t-[24px] border-t border-border bg-background shadow-[0_-12px_32px_rgba(28,44,64,0.16)] outline-none",
22
22
  "data-[state=open]:animate-in data-[state=closed]:animate-out",
23
23
  "data-[state=open]:slide-in-from-bottom-full data-[state=closed]:slide-out-to-bottom-full"
24
24
  ),
25
25
  children: [
26
26
  /* @__PURE__ */ e.jsxs("div", { className: "flex min-h-14 items-center justify-between border-b border-border px-6", children: [
27
- /* @__PURE__ */ e.jsx(m, { className: "text-[15px] font-semibold leading-5 text-foreground", children: t.title }),
27
+ /* @__PURE__ */ e.jsx(p, { className: "text-[15px] font-semibold leading-5 text-foreground", children: t.title }),
28
28
  /* @__PURE__ */ e.jsx(
29
29
  "button",
30
30
  {
31
31
  "aria-label": "Close settings",
32
32
  className: "inline-flex h-8 w-8 items-center justify-center rounded-full border-none bg-transparent p-0 text-foreground/70 transition-colors hover:text-foreground",
33
- onClick: s,
33
+ onClick: a,
34
34
  type: "button",
35
- children: /* @__PURE__ */ e.jsx(b, { className: "h-4 w-4" })
35
+ children: /* @__PURE__ */ e.jsx(u, { className: "h-4 w-4" })
36
36
  }
37
37
  )
38
38
  ] }),
@@ -41,36 +41,36 @@ const N = ({
41
41
  /* @__PURE__ */ e.jsxs(
42
42
  "div",
43
43
  {
44
- "aria-label": "Screen orientation",
44
+ "aria-label": "Screen mode",
45
45
  className: "flex items-center gap-8",
46
46
  role: "radiogroup",
47
47
  children: [
48
48
  /* @__PURE__ */ e.jsx(
49
49
  "button",
50
50
  {
51
- "aria-checked": r === "portrait",
52
- className: o(
51
+ "aria-checked": r === "nonFullscreen",
52
+ className: n(
53
53
  "border-none bg-transparent p-0 text-[15px] leading-5 text-foreground/70 transition-colors",
54
- r === "portrait" && "font-semibold text-primary"
54
+ r === "nonFullscreen" && "font-semibold text-primary"
55
55
  ),
56
- onClick: () => a("portrait"),
56
+ onClick: () => o("nonFullscreen"),
57
57
  role: "radio",
58
58
  type: "button",
59
- children: t.portrait
59
+ children: t.nonFullscreen
60
60
  }
61
61
  ),
62
62
  /* @__PURE__ */ e.jsx(
63
63
  "button",
64
64
  {
65
- "aria-checked": r === "landscape",
66
- className: o(
65
+ "aria-checked": r === "fullscreen",
66
+ className: n(
67
67
  "border-none bg-transparent p-0 text-[15px] leading-5 text-foreground/70 transition-colors",
68
- r === "landscape" && "font-semibold text-primary"
68
+ r === "fullscreen" && "font-semibold text-primary"
69
69
  ),
70
- onClick: () => a("landscape"),
70
+ onClick: () => o("fullscreen"),
71
71
  role: "radio",
72
72
  type: "button",
73
- children: t.landscape
73
+ children: t.fullscreen
74
74
  }
75
75
  )
76
76
  ]
@@ -1 +1 @@
1
- {"version":3,"file":"MobilePlayerSettingsSheet.es.js","sources":["../../../src/components/Slide/MobilePlayerSettingsSheet.tsx"],"sourcesContent":["import * as DialogPrimitive from \"@radix-ui/react-dialog\";\nimport { X } from \"lucide-react\";\n\nimport { cn } from \"../../lib/utils\";\nimport { Dialog, DialogOverlay, DialogPortal, DialogTitle } from \"../ui/dialog\";\nimport type { MobileScreenMode } from \"./utils/mobileScreenMode\";\n\nexport type MobilePlayerSettingsSheetLabels = {\n title: string;\n screen: string;\n portrait: string;\n landscape: string;\n};\n\nexport type MobilePlayerSettingsSheetProps = {\n open: boolean;\n labels: MobilePlayerSettingsSheetLabels;\n screenMode: MobileScreenMode;\n container?: HTMLElement | null;\n onClose: () => void;\n onOpenChange: (open: boolean) => void;\n onScreenModeChange: (nextScreenMode: MobileScreenMode) => void;\n};\n\nconst MobilePlayerSettingsSheet = ({\n open,\n labels,\n screenMode,\n container,\n onClose,\n onOpenChange,\n onScreenModeChange,\n}: MobilePlayerSettingsSheetProps) => {\n return (\n <Dialog open={open} onOpenChange={onOpenChange}>\n <DialogPortal container={container}>\n <DialogOverlay className=\"z-[60] bg-black/35\" />\n <DialogPrimitive.Content\n aria-describedby={undefined}\n className={cn(\n \"fixed inset-x-0 bottom-0 z-[61] flex max-h-[min(360px,calc(100dvh-32px))] flex-col overflow-hidden rounded-t-[24px] border-t border-border bg-background shadow-[0_-12px_32px_rgba(28,44,64,0.16)] outline-none\",\n \"data-[state=open]:animate-in data-[state=closed]:animate-out\",\n \"data-[state=open]:slide-in-from-bottom-full data-[state=closed]:slide-out-to-bottom-full\"\n )}\n >\n <div className=\"flex min-h-14 items-center justify-between border-b border-border px-6\">\n <DialogTitle className=\"text-[15px] font-semibold leading-5 text-foreground\">\n {labels.title}\n </DialogTitle>\n <button\n aria-label=\"Close settings\"\n className=\"inline-flex h-8 w-8 items-center justify-center rounded-full border-none bg-transparent p-0 text-foreground/70 transition-colors hover:text-foreground\"\n onClick={onClose}\n type=\"button\"\n >\n <X className=\"h-4 w-4\" />\n </button>\n </div>\n\n <div className=\"flex min-h-[72px] items-center gap-6 px-6\">\n <span className=\"shrink-0 text-[15px] font-semibold leading-5 text-foreground\">\n {labels.screen}\n </span>\n <div\n aria-label=\"Screen orientation\"\n className=\"flex items-center gap-8\"\n role=\"radiogroup\"\n >\n <button\n aria-checked={screenMode === \"portrait\"}\n className={cn(\n \"border-none bg-transparent p-0 text-[15px] leading-5 text-foreground/70 transition-colors\",\n screenMode === \"portrait\" && \"font-semibold text-primary\"\n )}\n onClick={() => onScreenModeChange(\"portrait\")}\n role=\"radio\"\n type=\"button\"\n >\n {labels.portrait}\n </button>\n <button\n aria-checked={screenMode === \"landscape\"}\n className={cn(\n \"border-none bg-transparent p-0 text-[15px] leading-5 text-foreground/70 transition-colors\",\n screenMode === \"landscape\" && \"font-semibold text-primary\"\n )}\n onClick={() => onScreenModeChange(\"landscape\")}\n role=\"radio\"\n type=\"button\"\n >\n {labels.landscape}\n </button>\n </div>\n </div>\n </DialogPrimitive.Content>\n </DialogPortal>\n </Dialog>\n );\n};\n\nexport default MobilePlayerSettingsSheet;\n"],"names":["MobilePlayerSettingsSheet","open","labels","screenMode","container","onClose","onOpenChange","onScreenModeChange","Dialog","jsxs","DialogPortal","jsx","DialogOverlay","DialogPrimitive.Content","cn","DialogTitle","X"],"mappings":";;;;;AAwBA,MAAMA,IAA4B,CAAC;AAAA,EACjC,MAAAC;AAAA,EACA,QAAAC;AAAA,EACA,YAAAC;AAAA,EACA,WAAAC;AAAA,EACA,SAAAC;AAAA,EACA,cAAAC;AAAA,EACA,oBAAAC;AACF,4BAEKC,GAAA,EAAO,MAAAP,GAAY,cAAAK,GAClB,UAAAG,gBAAAA,EAAAA,KAACC,KAAa,WAAAN,GACZ,UAAA;AAAA,EAAAO,gBAAAA,EAAAA,IAACC,GAAA,EAAc,WAAU,qBAAA,CAAqB;AAAA,EAC9CH,gBAAAA,EAAAA;AAAAA,IAACI;AAAAA,IAAA;AAAA,MACC,oBAAkB;AAAA,MAClB,WAAWC;AAAA,QACT;AAAA,QACA;AAAA,QACA;AAAA,MAAA;AAAA,MAGF,UAAA;AAAA,QAAAL,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,0EACb,UAAA;AAAA,UAAAE,gBAAAA,EAAAA,IAACI,GAAA,EAAY,WAAU,uDACpB,UAAAb,EAAO,OACV;AAAA,UACAS,gBAAAA,EAAAA;AAAAA,YAAC;AAAA,YAAA;AAAA,cACC,cAAW;AAAA,cACX,WAAU;AAAA,cACV,SAASN;AAAA,cACT,MAAK;AAAA,cAEL,UAAAM,gBAAAA,EAAAA,IAACK,GAAA,EAAE,WAAU,UAAA,CAAU;AAAA,YAAA;AAAA,UAAA;AAAA,QACzB,GACF;AAAA,QAEAP,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,6CACb,UAAA;AAAA,UAAAE,gBAAAA,EAAAA,IAAC,QAAA,EAAK,WAAU,gEACb,UAAAT,EAAO,QACV;AAAA,UACAO,gBAAAA,EAAAA;AAAAA,YAAC;AAAA,YAAA;AAAA,cACC,cAAW;AAAA,cACX,WAAU;AAAA,cACV,MAAK;AAAA,cAEL,UAAA;AAAA,gBAAAE,gBAAAA,EAAAA;AAAAA,kBAAC;AAAA,kBAAA;AAAA,oBACC,gBAAcR,MAAe;AAAA,oBAC7B,WAAWW;AAAA,sBACT;AAAA,sBACAX,MAAe,cAAc;AAAA,oBAAA;AAAA,oBAE/B,SAAS,MAAMI,EAAmB,UAAU;AAAA,oBAC5C,MAAK;AAAA,oBACL,MAAK;AAAA,oBAEJ,UAAAL,EAAO;AAAA,kBAAA;AAAA,gBAAA;AAAA,gBAEVS,gBAAAA,EAAAA;AAAAA,kBAAC;AAAA,kBAAA;AAAA,oBACC,gBAAcR,MAAe;AAAA,oBAC7B,WAAWW;AAAA,sBACT;AAAA,sBACAX,MAAe,eAAe;AAAA,oBAAA;AAAA,oBAEhC,SAAS,MAAMI,EAAmB,WAAW;AAAA,oBAC7C,MAAK;AAAA,oBACL,MAAK;AAAA,oBAEJ,UAAAL,EAAO;AAAA,kBAAA;AAAA,gBAAA;AAAA,cACV;AAAA,YAAA;AAAA,UAAA;AAAA,QACF,EAAA,CACF;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AACF,EAAA,CACF,EAAA,CACF;"}
1
+ {"version":3,"file":"MobilePlayerSettingsSheet.es.js","sources":["../../../src/components/Slide/MobilePlayerSettingsSheet.tsx"],"sourcesContent":["import * as DialogPrimitive from \"@radix-ui/react-dialog\";\nimport { X } from \"lucide-react\";\n\nimport { cn } from \"../../lib/utils\";\nimport { Dialog, DialogOverlay, DialogPortal, DialogTitle } from \"../ui/dialog\";\nimport type { MobileViewMode } from \"./utils/mobileScreenMode\";\n\nexport type MobilePlayerSettingsSheetLabels = {\n title: string;\n screen: string;\n nonFullscreen: string;\n fullscreen: string;\n};\n\nexport type MobilePlayerSettingsSheetProps = {\n open: boolean;\n labels: MobilePlayerSettingsSheetLabels;\n viewMode: MobileViewMode;\n container?: HTMLElement | null;\n onClose: () => void;\n onOpenChange: (open: boolean) => void;\n onViewModeChange: (nextViewMode: MobileViewMode) => void;\n};\n\nconst MobilePlayerSettingsSheet = ({\n open,\n labels,\n viewMode,\n container,\n onClose,\n onOpenChange,\n onViewModeChange,\n}: MobilePlayerSettingsSheetProps) => {\n return (\n <Dialog open={open} onOpenChange={onOpenChange}>\n <DialogPortal container={container}>\n <DialogOverlay className=\"z-[60] bg-black/35\" />\n <DialogPrimitive.Content\n aria-describedby={undefined}\n className={cn(\n \"fixed inset-x-0 bottom-0 z-[61] flex max-h-[min(360px,calc(100dvh-32px))] flex-col overflow-hidden rounded-t-[24px] border-t border-border bg-background shadow-[0_-12px_32px_rgba(28,44,64,0.16)] outline-none\",\n \"data-[state=open]:animate-in data-[state=closed]:animate-out\",\n \"data-[state=open]:slide-in-from-bottom-full data-[state=closed]:slide-out-to-bottom-full\"\n )}\n >\n <div className=\"flex min-h-14 items-center justify-between border-b border-border px-6\">\n <DialogTitle className=\"text-[15px] font-semibold leading-5 text-foreground\">\n {labels.title}\n </DialogTitle>\n <button\n aria-label=\"Close settings\"\n className=\"inline-flex h-8 w-8 items-center justify-center rounded-full border-none bg-transparent p-0 text-foreground/70 transition-colors hover:text-foreground\"\n onClick={onClose}\n type=\"button\"\n >\n <X className=\"h-4 w-4\" />\n </button>\n </div>\n\n <div className=\"flex min-h-[72px] items-center gap-6 px-6\">\n <span className=\"shrink-0 text-[15px] font-semibold leading-5 text-foreground\">\n {labels.screen}\n </span>\n <div\n aria-label=\"Screen mode\"\n className=\"flex items-center gap-8\"\n role=\"radiogroup\"\n >\n <button\n aria-checked={viewMode === \"nonFullscreen\"}\n className={cn(\n \"border-none bg-transparent p-0 text-[15px] leading-5 text-foreground/70 transition-colors\",\n viewMode === \"nonFullscreen\" && \"font-semibold text-primary\"\n )}\n onClick={() => onViewModeChange(\"nonFullscreen\")}\n role=\"radio\"\n type=\"button\"\n >\n {labels.nonFullscreen}\n </button>\n <button\n aria-checked={viewMode === \"fullscreen\"}\n className={cn(\n \"border-none bg-transparent p-0 text-[15px] leading-5 text-foreground/70 transition-colors\",\n viewMode === \"fullscreen\" && \"font-semibold text-primary\"\n )}\n onClick={() => onViewModeChange(\"fullscreen\")}\n role=\"radio\"\n type=\"button\"\n >\n {labels.fullscreen}\n </button>\n </div>\n </div>\n </DialogPrimitive.Content>\n </DialogPortal>\n </Dialog>\n );\n};\n\nexport default MobilePlayerSettingsSheet;\n"],"names":["MobilePlayerSettingsSheet","open","labels","viewMode","container","onClose","onOpenChange","onViewModeChange","Dialog","jsxs","DialogPortal","jsx","DialogOverlay","DialogPrimitive.Content","cn","DialogTitle","X"],"mappings":";;;;;AAwBA,MAAMA,IAA4B,CAAC;AAAA,EACjC,MAAAC;AAAA,EACA,QAAAC;AAAA,EACA,UAAAC;AAAA,EACA,WAAAC;AAAA,EACA,SAAAC;AAAA,EACA,cAAAC;AAAA,EACA,kBAAAC;AACF,4BAEKC,GAAA,EAAO,MAAAP,GAAY,cAAAK,GAClB,UAAAG,gBAAAA,EAAAA,KAACC,KAAa,WAAAN,GACZ,UAAA;AAAA,EAAAO,gBAAAA,EAAAA,IAACC,GAAA,EAAc,WAAU,qBAAA,CAAqB;AAAA,EAC9CH,gBAAAA,EAAAA;AAAAA,IAACI;AAAAA,IAAA;AAAA,MACC,oBAAkB;AAAA,MAClB,WAAWC;AAAA,QACT;AAAA,QACA;AAAA,QACA;AAAA,MAAA;AAAA,MAGF,UAAA;AAAA,QAAAL,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,0EACb,UAAA;AAAA,UAAAE,gBAAAA,EAAAA,IAACI,GAAA,EAAY,WAAU,uDACpB,UAAAb,EAAO,OACV;AAAA,UACAS,gBAAAA,EAAAA;AAAAA,YAAC;AAAA,YAAA;AAAA,cACC,cAAW;AAAA,cACX,WAAU;AAAA,cACV,SAASN;AAAA,cACT,MAAK;AAAA,cAEL,UAAAM,gBAAAA,EAAAA,IAACK,GAAA,EAAE,WAAU,UAAA,CAAU;AAAA,YAAA;AAAA,UAAA;AAAA,QACzB,GACF;AAAA,QAEAP,gBAAAA,EAAAA,KAAC,OAAA,EAAI,WAAU,6CACb,UAAA;AAAA,UAAAE,gBAAAA,EAAAA,IAAC,QAAA,EAAK,WAAU,gEACb,UAAAT,EAAO,QACV;AAAA,UACAO,gBAAAA,EAAAA;AAAAA,YAAC;AAAA,YAAA;AAAA,cACC,cAAW;AAAA,cACX,WAAU;AAAA,cACV,MAAK;AAAA,cAEL,UAAA;AAAA,gBAAAE,gBAAAA,EAAAA;AAAAA,kBAAC;AAAA,kBAAA;AAAA,oBACC,gBAAcR,MAAa;AAAA,oBAC3B,WAAWW;AAAA,sBACT;AAAA,sBACAX,MAAa,mBAAmB;AAAA,oBAAA;AAAA,oBAElC,SAAS,MAAMI,EAAiB,eAAe;AAAA,oBAC/C,MAAK;AAAA,oBACL,MAAK;AAAA,oBAEJ,UAAAL,EAAO;AAAA,kBAAA;AAAA,gBAAA;AAAA,gBAEVS,gBAAAA,EAAAA;AAAAA,kBAAC;AAAA,kBAAA;AAAA,oBACC,gBAAcR,MAAa;AAAA,oBAC3B,WAAWW;AAAA,sBACT;AAAA,sBACAX,MAAa,gBAAgB;AAAA,oBAAA;AAAA,oBAE/B,SAAS,MAAMI,EAAiB,YAAY;AAAA,oBAC5C,MAAK;AAAA,oBACL,MAAK;AAAA,oBAEJ,UAAAL,EAAO;AAAA,kBAAA;AAAA,gBAAA;AAAA,cACV;AAAA,YAAA;AAAA,UAAA;AAAA,QACF,EAAA,CACF;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AACF,EAAA,CACF,EAAA,CACF;"}
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const t=require("../../_virtual/jsx-runtime.cjs.js"),r=require("react"),ie=require("../../lib/utils.cjs.js"),qe=require("./MobilePlayerSettingsSheet.cjs.js"),Te=require("./utils/mobileScreenMode.cjs.js"),Ue=require("./utils/playerCustomActions.cjs.js");;/* empty css */const Pe=require("../../markdown-flow-ui/node_modules/.pnpm/lucide-react@0.525.0_react@19.0.1/node_modules/lucide-react/dist/esm/icons/ellipsis-vertical.cjs.js"),We=require("../../markdown-flow-ui/node_modules/.pnpm/lucide-react@0.525.0_react@19.0.1/node_modules/lucide-react/dist/esm/icons/volume-2.cjs.js"),Be=require("../../markdown-flow-ui/node_modules/.pnpm/lucide-react@0.525.0_react@19.0.1/node_modules/lucide-react/dist/esm/icons/rotate-ccw.cjs.js"),Ve=require("../../markdown-flow-ui/node_modules/.pnpm/lucide-react@0.525.0_react@19.0.1/node_modules/lucide-react/dist/esm/icons/rotate-cw.cjs.js"),Fe=require("../../markdown-flow-ui/node_modules/.pnpm/lucide-react@0.525.0_react@19.0.1/node_modules/lucide-react/dist/esm/icons/scan-line.cjs.js"),Ke=require("../../markdown-flow-ui/node_modules/.pnpm/lucide-react@0.525.0_react@19.0.1/node_modules/lucide-react/dist/esm/icons/maximize.cjs.js"),Ze=require("../../markdown-flow-ui/node_modules/.pnpm/lucide-react@0.525.0_react@19.0.1/node_modules/lucide-react/dist/esm/icons/file-pen-line.cjs.js"),oe=new Map,$e={settingsTitle:"Settings",screenLabel:"Screen",portraitLabel:"Portrait",landscapeLabel:"Landscape"},fe=j=>{if(typeof window>"u"||!j||oe.has(j))return;const M=window.document.createElement("audio");M.preload="auto",M.setAttribute("playsinline","true"),M.src=j,M.load(),oe.set(j,M)},He=()=>t.jsxRuntimeExports.jsxs("svg",{xmlns:"http://www.w3.org/2000/svg",width:"34",height:"34",viewBox:"0 0 34 34",fill:"none",children:[t.jsxRuntimeExports.jsx("path",{d:"M16.6667 33.3333C25.8714 33.3333 33.3333 25.8714 33.3333 16.6667C33.3333 7.46192 25.8714 0 16.6667 0C7.46192 0 0 7.46192 0 16.6667C0 25.8714 7.46192 33.3333 16.6667 33.3333Z",fill:"#0A0A0A"}),t.jsxRuntimeExports.jsx("path",{d:"M12 10H16V24H12V10ZM18 10H22V24H18V10Z",fill:"white"})]}),Oe=()=>t.jsxRuntimeExports.jsxs("svg",{xmlns:"http://www.w3.org/2000/svg",width:"34",height:"34",viewBox:"0 0 34 34",fill:"none",children:[t.jsxRuntimeExports.jsx("path",{d:"M16.6667 33.3333C25.8714 33.3333 33.3333 25.8714 33.3333 16.6667C33.3333 7.46192 25.8714 0 16.6667 0C7.46192 0 0 7.46192 0 16.6667C0 25.8714 7.46192 33.3333 16.6667 33.3333Z",fill:"#0A0A0A"}),t.jsxRuntimeExports.jsx("path",{d:"M13.3333 10L23.3333 16.6667L13.3333 23.3333V10Z",fill:"white"})]}),ze=({audioList:j=[],className:M,currentAudioIndex:o=-1,defaultPlaying:g=!0,isPlaybackPaused:w=!1,isAutoAdvanceEnabled:F=!0,useAutoAdvanceToggle:K=!1,onLoadingChange:O,onPrev:de,onNext:me,onFullscreen:z,isFullscreen:D=!1,mobileScreenMode:pe=Te.DEFAULT_MOBILE_SCREEN_MODE,settingsPortalContainer:xe,onMobileScreenModeChange:X,onEnded:Y,onAutoAdvanceToggle:he,onInteractionToggle:ge,hasInteraction:Re=!1,isInteractionOpen:q=!1,prevDisabled:Ee=!1,nextDisabled:ye=!1,showControls:Z=!0,customActions:G,customActionContext:J,texts:Q,...be})=>{const p=r.useRef(null),I=r.useRef(q),R=r.useRef(null),ee=r.useRef(null),E=r.useRef(0),c=r.useRef(null),P=r.useRef(void 0),_=r.useRef([]),T=r.useRef(!1),re=r.useRef(!1),f=r.useRef(!1),A=r.useRef(null),x=r.useRef(!1),s=r.useRef(!1),d=r.useRef(null),h=r.useRef(!1),S=r.useRef("unknown"),[$,l]=r.useState(g),[te,v]=r.useState(!1),i=o>=0?j[o]:void 0,L=i?.audioUrl,y=r.useMemo(()=>[...i?.audioSegments??[]].sort((e,a)=>e.segment_index-a.segment_index),[i?.audioSegments]),ne=r.useMemo(()=>Ue.toPlayerCustomActionList(G,J),[J,G]),se=ne.length+5,je=r.useMemo(()=>({"--slide-player-mobile-control-count":String(se)}),[se]),W=r.useMemo(()=>({...$e,...Q}),[Q]),H=r.useMemo(()=>i?i.audioKey??`${String(i.sequenceNumber??"none")}:${String(i.audioUrl??"")}`:"none",[i]),_e=K?F:$,Se=K?F?"Pause autoplay":"Play autoplay":$?"Pause":"Play";r.useEffect(()=>{P.current=i},[i]),r.useEffect(()=>{Z||v(!1)},[Z]),r.useEffect(()=>{!I.current&&q&&v(!1),I.current=q},[q]),r.useEffect(()=>{_.current=y},[y]),r.useEffect(()=>{const e=i?.audioUrl,a=o>=0?j[o+1]?.audioUrl:void 0;fe(e),fe(a)},[j,i?.audioUrl,o]);const n=r.useCallback(e=>{re.current!==e&&(re.current=e,O?.(e))},[O]),ue=r.useCallback(e=>e instanceof DOMException?e.name==="NotAllowedError"||e.name==="SecurityError":!1,[]),C=r.useCallback(()=>g&&!w&&!f.current&&S.current!=="blocked",[g,w]),le=r.useCallback(e=>e?e.startsWith("data:")?e:`data:audio/mpeg;base64,${e}`:"",[]),ae=r.useCallback(()=>{const e=c.current;return e==null||e<=0?0:_.current.slice(0,e).reduce((a,u)=>a+Math.max(Number(u.duration_ms??0),0),0)/1e3},[]),U=r.useCallback(()=>{const e=p.current;e&&(s.current=!1,f.current=!1,T.current=!1,A.current=null,d.current=null,x.current=!1,h.current=!1,e.pause(),e.removeAttribute("src"),e.load(),R.current=null,E.current=0,c.current=null,l(!1),n(!1))},[n]),m=r.useCallback(e=>{const a=p.current;if(!a)return!1;const u=a.play();return u&&typeof u.then=="function"&&u.then(()=>{S.current==="unknown"&&(S.current="auto"),s.current=!1,h.current=!1}).catch(N=>{S.current==="unknown"&&ue(N)&&(S.current="blocked",s.current=!1,n(!1)),h.current=!1,l(!1)}),!0},[ue,n]),b=r.useCallback((e,a)=>{const u=p.current,N=_.current[e];if(!u||!N)return!1;const k=le(N.audio_data);E.current=e,c.current=null,x.current=!1,h.current=!0;const V=C();s.current=V,n(!1);const Le=R.current!==k;return A.current="segment",Le&&(u.pause(),u.removeAttribute("src"),u.load(),R.current=k,u.src=k,u.load()),d.current=0,u.readyState>0&&(u.currentTime=0,d.current=null),V?m(`start-segment:${a}`):(s.current=!1,h.current=!1,u.pause(),l(!1),!0)},[C,le,m,n]),B=r.useCallback(e=>{s.current=!1,x.current=!1,h.current=!1,l(!1),n(!1),o>=0&&Y?.(o)},[o,Y,n]),ce=r.useCallback(()=>{const e=E.current+1,a=_.current,u=a[e],N=P.current,k=a.some(V=>V.is_final);if(u){b(e,"ended");return}if(N?.isAudioStreaming||!k){E.current=e,c.current=e,x.current=!0,s.current=g,l(!1),n(!0);return}B("segments-completed")},[g,B,b,n]);r.useEffect(()=>{if(ee.current===H)return;ee.current=H,E.current=0,c.current=null,x.current=!1,f.current=!1,T.current=!1,s.current=!1,h.current=!1,A.current=null,R.current=null,n(!1);const e=p.current;e&&(e.pause(),e.removeAttribute("src"),e.load(),l(!1))},[o,H,y.length,L,n]),r.useEffect(()=>{const e=p.current;if(e){if(w){T.current=!!(P.current&&!f.current&&(!e.paused||s.current||c.current!==null)),s.current=!1,n(!1),e.pause(),l(!1);return}if(!(!T.current||!P.current||f.current)){if(T.current=!1,c.current!==null){if(c.current<_.current.length){b(c.current,"external-resume");return}s.current=!0,n(!0);return}if(!R.current&&_.current.length>0){b(Math.min(E.current,_.current.length-1),"external-resume-init");return}e.paused&&(s.current=!0,m("external-resume"))}}},[w,b,m,n]),r.useEffect(()=>{const e=p.current;if(e){if(!i){U();return}if(w){s.current=!1,n(!1),e.pause(),l(!1);return}if(L){const a=R.current!==L,u=C();if(A.current==="segment"&&!!R.current&&c.current===null){if(!u){s.current=!1,e.pause(),l(!1);return}e.paused&&(s.current=!0,m("keep-segment-source"));return}if(a){const k=c.current!==null?ae():0;e.pause(),e.removeAttribute("src"),e.load(),R.current=L,A.current="url",e.src=L,e.load(),d.current=k,e.readyState>0&&(e.currentTime=k,d.current=null)}if(s.current=u,x.current=!1,h.current=!1,n(!1),!u){s.current=!1,e.pause(),l(!1);return}m(a?"sync-url-init":"sync-url");return}if(c.current!==null){if(c.current<y.length){if(f.current){l(!1),n(!1);return}b(c.current,"wait-resume");return}x.current=!0,s.current=C(),l(!1),n(C());return}if(!y.length){if(i.isAudioStreaming){c.current=E.current,x.current=!0,s.current=C(),l(!1),n(C());return}U();return}if(!R.current){b(Math.min(E.current,y.length-1),"effect-init");return}if(!g||f.current){s.current=!1,e.pause(),l(!1);return}e.paused&&(s.current=!0,m("sync-paused-retry"))}},[i,o,y,L,g,w,C,U,b,m,ae,n]),r.useEffect(()=>U,[U]);const Ce=r.useCallback(()=>{l(!0),n(!1)},[n]),ke=r.useCallback(()=>{x.current||h.current||l(!1)},[o]),Me=r.useCallback(()=>{const e=p.current;e&&d.current!==null&&(e.currentTime=d.current,d.current=null),!(!s.current||!g)&&m("canplay")},[o,g,m]),we=r.useCallback(()=>{const e=p.current;e&&d.current!==null&&(e.currentTime=d.current,d.current=null)},[o]),Ne=r.useCallback(()=>{const e=A.current==="url"||_.current.length===0;if(h.current=!1,e){B("url-ended");return}ce()},[B,ce]),Ae=r.useCallback(()=>{l(!1),n(!1)},[n]),ve=r.useCallback(e=>{X?.(e),v(!1)},[X]);return t.jsxRuntimeExports.jsxs("div",{className:ie.cn("slide-player",M),...be,children:[t.jsxRuntimeExports.jsx("audio",{ref:p,preload:"auto",playsInline:!0,onLoadedMetadata:we,onCanPlay:Me,onPlay:Ce,onPause:ke,onEnded:Ne,onError:Ae}),Z?t.jsxRuntimeExports.jsxs(t.jsxRuntimeExports.Fragment,{children:[t.jsxRuntimeExports.jsx(qe.default,{container:xe,labels:{landscape:W.landscapeLabel,portrait:W.portraitLabel,screen:W.screenLabel,title:W.settingsTitle},onClose:()=>v(!1),onOpenChange:v,onScreenModeChange:ve,open:te,screenMode:pe}),t.jsxRuntimeExports.jsxs("div",{className:"slide-player__controls",style:je,children:[t.jsxRuntimeExports.jsxs("div",{className:"slide-player__group",children:[t.jsxRuntimeExports.jsx("button",{"aria-expanded":te,"aria-haspopup":"dialog","aria-label":"More options",className:"slide-player__action slide-player__action--mobile-more",onClick:()=>{v(e=>!e)},type:"button",children:t.jsxRuntimeExports.jsx(Pe.default,{className:"slide-player__icon",strokeWidth:2.25})}),t.jsxRuntimeExports.jsx("button",{"aria-label":"Volume",className:"hidden",type:"button",children:t.jsxRuntimeExports.jsx(We.default,{className:"slide-player__icon",strokeWidth:2.25})}),t.jsxRuntimeExports.jsx("button",{"aria-label":"Rewind",className:"slide-player__action slide-player__action--prev",disabled:Ee,onClick:de,type:"button",children:t.jsxRuntimeExports.jsx(Be.default,{className:"slide-player__icon",strokeWidth:2.25})}),t.jsxRuntimeExports.jsx("button",{"aria-label":Se,className:"slide-player__toggle slide-player__toggle--playback",onClick:()=>{if(K){he?.(!F);return}const e=p.current;if(!(w||!e||!i)){if(c.current!==null){if($){s.current=!1,f.current=!0,c.current=null,x.current=!1,l(!1),n(!1),e.pause();return}S.current="manual",f.current=!1,s.current=!0,n(!0);return}if(!e.src&&y.length>0){S.current="manual",f.current=!1,b(Math.min(E.current,y.length-1),"toggle");return}if(e.paused){S.current="manual",f.current=!1,s.current=!0,m("toggle-resume");return}s.current=!1,f.current=!0,e.pause()}},type:"button",children:_e?t.jsxRuntimeExports.jsx(He,{}):t.jsxRuntimeExports.jsx(Oe,{})}),t.jsxRuntimeExports.jsx("button",{"aria-label":"Forward",className:"slide-player__action slide-player__action--next",disabled:ye,onClick:me,type:"button",children:t.jsxRuntimeExports.jsx(Ve.default,{className:"slide-player__icon",strokeWidth:2.25})}),z?t.jsxRuntimeExports.jsx("button",{"aria-label":D?"Exit fullscreen":"Enter fullscreen",className:"slide-player__action slide-player__action--fullscreen",onClick:z,type:"button",children:D?t.jsxRuntimeExports.jsx(Fe.default,{className:"slide-player__icon",strokeWidth:2.25}):t.jsxRuntimeExports.jsx(Ke.default,{className:"slide-player__icon",strokeWidth:2.25})}):null]}),t.jsxRuntimeExports.jsx("div",{className:"slide-player__separator"}),t.jsxRuntimeExports.jsxs("div",{className:"slide-player__group",children:[ne.map((e,a)=>t.jsxRuntimeExports.jsx(r.Fragment,{children:e},`custom-action-${a}`)),t.jsxRuntimeExports.jsx("button",{"aria-label":"Notes",className:ie.cn("slide-player__action slide-player__action--notes",q&&"slide-player__action--active"),disabled:!Re,onClick:ge,type:"button",children:t.jsxRuntimeExports.jsx(Ze.default,{className:"slide-player__icon",strokeWidth:2.25})})]})]})]}):null]})};exports.default=ze;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const t=require("../../_virtual/jsx-runtime.cjs.js"),r=require("react"),ie=require("../../lib/utils.cjs.js"),Le=require("./MobilePlayerSettingsSheet.cjs.js"),Te=require("./constants.cjs.js"),Ue=require("./utils/mobileScreenMode.cjs.js"),We=require("./utils/playerCustomActions.cjs.js");;/* empty css */const Pe=require("../../markdown-flow-ui/node_modules/.pnpm/lucide-react@0.525.0_react@19.0.1/node_modules/lucide-react/dist/esm/icons/ellipsis-vertical.cjs.js"),Ve=require("../../markdown-flow-ui/node_modules/.pnpm/lucide-react@0.525.0_react@19.0.1/node_modules/lucide-react/dist/esm/icons/volume-2.cjs.js"),Be=require("../../markdown-flow-ui/node_modules/.pnpm/lucide-react@0.525.0_react@19.0.1/node_modules/lucide-react/dist/esm/icons/rotate-ccw.cjs.js"),Fe=require("../../markdown-flow-ui/node_modules/.pnpm/lucide-react@0.525.0_react@19.0.1/node_modules/lucide-react/dist/esm/icons/rotate-cw.cjs.js"),Ke=require("../../markdown-flow-ui/node_modules/.pnpm/lucide-react@0.525.0_react@19.0.1/node_modules/lucide-react/dist/esm/icons/scan-line.cjs.js"),Ze=require("../../markdown-flow-ui/node_modules/.pnpm/lucide-react@0.525.0_react@19.0.1/node_modules/lucide-react/dist/esm/icons/maximize.cjs.js"),$e=require("../../markdown-flow-ui/node_modules/.pnpm/lucide-react@0.525.0_react@19.0.1/node_modules/lucide-react/dist/esm/icons/file-pen-line.cjs.js"),oe=new Map,fe=_=>{if(typeof window>"u"||!_||oe.has(_))return;const w=window.document.createElement("audio");w.preload="auto",w.setAttribute("playsinline","true"),w.src=_,w.load(),oe.set(_,w)},He=()=>t.jsxRuntimeExports.jsxs("svg",{xmlns:"http://www.w3.org/2000/svg",width:"34",height:"34",viewBox:"0 0 34 34",fill:"none",children:[t.jsxRuntimeExports.jsx("path",{d:"M16.6667 33.3333C25.8714 33.3333 33.3333 25.8714 33.3333 16.6667C33.3333 7.46192 25.8714 0 16.6667 0C7.46192 0 0 7.46192 0 16.6667C0 25.8714 7.46192 33.3333 16.6667 33.3333Z",fill:"#0A0A0A"}),t.jsxRuntimeExports.jsx("path",{d:"M12 10H16V24H12V10ZM18 10H22V24H18V10Z",fill:"white"})]}),Oe=()=>t.jsxRuntimeExports.jsxs("svg",{xmlns:"http://www.w3.org/2000/svg",width:"34",height:"34",viewBox:"0 0 34 34",fill:"none",children:[t.jsxRuntimeExports.jsx("path",{d:"M16.6667 33.3333C25.8714 33.3333 33.3333 25.8714 33.3333 16.6667C33.3333 7.46192 25.8714 0 16.6667 0C7.46192 0 0 7.46192 0 16.6667C0 25.8714 7.46192 33.3333 16.6667 33.3333Z",fill:"#0A0A0A"}),t.jsxRuntimeExports.jsx("path",{d:"M13.3333 10L23.3333 16.6667L13.3333 23.3333V10Z",fill:"white"})]}),De=({audioList:_=[],className:w,currentAudioIndex:o=-1,defaultPlaying:g=!0,isPlaybackPaused:M=!1,isAutoAdvanceEnabled:F=!0,useAutoAdvanceToggle:K=!1,onLoadingChange:O,onPrev:de,onNext:me,onFullscreen:D,isFullscreen:z=!1,mobileViewMode:pe=Ue.DEFAULT_MOBILE_VIEW_MODE,settingsPortalContainer:xe,onMobileViewModeChange:X,onEnded:Y,onAutoAdvanceToggle:he,onInteractionToggle:ge,hasInteraction:Re=!1,isInteractionOpen:L=!1,prevDisabled:Ee=!1,nextDisabled:ye=!1,showControls:Z=!0,customActions:G,customActionContext:J,texts:Q,...je})=>{const p=r.useRef(null),I=r.useRef(L),R=r.useRef(null),ee=r.useRef(null),E=r.useRef(0),c=r.useRef(null),W=r.useRef(void 0),b=r.useRef([]),T=r.useRef(!1),re=r.useRef(!1),f=r.useRef(!1),N=r.useRef(null),x=r.useRef(!1),s=r.useRef(!1),d=r.useRef(null),h=r.useRef(!1),S=r.useRef("unknown"),[$,l]=r.useState(g),[te,v]=r.useState(!1),i=o>=0?_[o]:void 0,q=i?.audioUrl,y=r.useMemo(()=>[...i?.audioSegments??[]].sort((e,a)=>e.segment_index-a.segment_index),[i?.audioSegments]),ne=r.useMemo(()=>We.toPlayerCustomActionList(G,J),[J,G]),se=ne.length+5,_e=r.useMemo(()=>({"--slide-player-mobile-control-count":String(se)}),[se]),P=r.useMemo(()=>({...Te.DEFAULT_SLIDE_PLAYER_TEXTS,...Q}),[Q]),H=r.useMemo(()=>i?i.audioKey??`${String(i.sequenceNumber??"none")}:${String(i.audioUrl??"")}`:"none",[i]),be=K?F:$,Se=K?F?"Pause autoplay":"Play autoplay":$?"Pause":"Play";r.useEffect(()=>{W.current=i},[i]),r.useEffect(()=>{Z||v(!1)},[Z]),r.useEffect(()=>{!I.current&&L&&v(!1),I.current=L},[L]),r.useEffect(()=>{b.current=y},[y]),r.useEffect(()=>{const e=i?.audioUrl,a=o>=0?_[o+1]?.audioUrl:void 0;fe(e),fe(a)},[_,i?.audioUrl,o]);const n=r.useCallback(e=>{re.current!==e&&(re.current=e,O?.(e))},[O]),ue=r.useCallback(e=>e instanceof DOMException?e.name==="NotAllowedError"||e.name==="SecurityError":!1,[]),C=r.useCallback(()=>g&&!M&&!f.current&&S.current!=="blocked",[g,M]),le=r.useCallback(e=>e?e.startsWith("data:")?e:`data:audio/mpeg;base64,${e}`:"",[]),ae=r.useCallback(()=>{const e=c.current;return e==null||e<=0?0:b.current.slice(0,e).reduce((a,u)=>a+Math.max(Number(u.duration_ms??0),0),0)/1e3},[]),U=r.useCallback(()=>{const e=p.current;e&&(s.current=!1,f.current=!1,T.current=!1,N.current=null,d.current=null,x.current=!1,h.current=!1,e.pause(),e.removeAttribute("src"),e.load(),R.current=null,E.current=0,c.current=null,l(!1),n(!1))},[n]),m=r.useCallback(e=>{const a=p.current;if(!a)return!1;const u=a.play();return u&&typeof u.then=="function"&&u.then(()=>{S.current==="unknown"&&(S.current="auto"),s.current=!1,h.current=!1}).catch(A=>{S.current==="unknown"&&ue(A)&&(S.current="blocked",s.current=!1,n(!1)),h.current=!1,l(!1)}),!0},[ue,n]),j=r.useCallback((e,a)=>{const u=p.current,A=b.current[e];if(!u||!A)return!1;const k=le(A.audio_data);E.current=e,c.current=null,x.current=!1,h.current=!0;const B=C();s.current=B,n(!1);const qe=R.current!==k;return N.current="segment",qe&&(u.pause(),u.removeAttribute("src"),u.load(),R.current=k,u.src=k,u.load()),d.current=0,u.readyState>0&&(u.currentTime=0,d.current=null),B?m(`start-segment:${a}`):(s.current=!1,h.current=!1,u.pause(),l(!1),!0)},[C,le,m,n]),V=r.useCallback(e=>{s.current=!1,x.current=!1,h.current=!1,l(!1),n(!1),o>=0&&Y?.(o)},[o,Y,n]),ce=r.useCallback(()=>{const e=E.current+1,a=b.current,u=a[e],A=W.current,k=a.some(B=>B.is_final);if(u){j(e,"ended");return}if(A?.isAudioStreaming||!k){E.current=e,c.current=e,x.current=!0,s.current=g,l(!1),n(!0);return}V("segments-completed")},[g,V,j,n]);r.useEffect(()=>{if(ee.current===H)return;ee.current=H,E.current=0,c.current=null,x.current=!1,f.current=!1,T.current=!1,s.current=!1,h.current=!1,N.current=null,R.current=null,n(!1);const e=p.current;e&&(e.pause(),e.removeAttribute("src"),e.load(),l(!1))},[o,H,y.length,q,n]),r.useEffect(()=>{const e=p.current;if(e){if(M){T.current=!!(W.current&&!f.current&&(!e.paused||s.current||c.current!==null)),s.current=!1,n(!1),e.pause(),l(!1);return}if(!(!T.current||!W.current||f.current)){if(T.current=!1,c.current!==null){if(c.current<b.current.length){j(c.current,"external-resume");return}s.current=!0,n(!0);return}if(!R.current&&b.current.length>0){j(Math.min(E.current,b.current.length-1),"external-resume-init");return}e.paused&&(s.current=!0,m("external-resume"))}}},[M,j,m,n]),r.useEffect(()=>{const e=p.current;if(e){if(!i){U();return}if(M){s.current=!1,n(!1),e.pause(),l(!1);return}if(q){const a=R.current!==q,u=C();if(N.current==="segment"&&!!R.current&&c.current===null){if(!u){s.current=!1,e.pause(),l(!1);return}e.paused&&(s.current=!0,m("keep-segment-source"));return}if(a){const k=c.current!==null?ae():0;e.pause(),e.removeAttribute("src"),e.load(),R.current=q,N.current="url",e.src=q,e.load(),d.current=k,e.readyState>0&&(e.currentTime=k,d.current=null)}if(s.current=u,x.current=!1,h.current=!1,n(!1),!u){s.current=!1,e.pause(),l(!1);return}m(a?"sync-url-init":"sync-url");return}if(c.current!==null){if(c.current<y.length){if(f.current){l(!1),n(!1);return}j(c.current,"wait-resume");return}x.current=!0,s.current=C(),l(!1),n(C());return}if(!y.length){if(i.isAudioStreaming){c.current=E.current,x.current=!0,s.current=C(),l(!1),n(C());return}U();return}if(!R.current){j(Math.min(E.current,y.length-1),"effect-init");return}if(!g||f.current){s.current=!1,e.pause(),l(!1);return}e.paused&&(s.current=!0,m("sync-paused-retry"))}},[i,o,y,q,g,M,C,U,j,m,ae,n]),r.useEffect(()=>U,[U]);const Ce=r.useCallback(()=>{l(!0),n(!1)},[n]),ke=r.useCallback(()=>{x.current||h.current||l(!1)},[o]),we=r.useCallback(()=>{const e=p.current;e&&d.current!==null&&(e.currentTime=d.current,d.current=null),!(!s.current||!g)&&m("canplay")},[o,g,m]),Me=r.useCallback(()=>{const e=p.current;e&&d.current!==null&&(e.currentTime=d.current,d.current=null)},[o]),Ae=r.useCallback(()=>{const e=N.current==="url"||b.current.length===0;if(h.current=!1,e){V("url-ended");return}ce()},[V,ce]),Ne=r.useCallback(()=>{l(!1),n(!1)},[n]),ve=r.useCallback(e=>{X?.(e),v(!1)},[X]);return t.jsxRuntimeExports.jsxs("div",{className:ie.cn("slide-player",w),...je,children:[t.jsxRuntimeExports.jsx("audio",{ref:p,preload:"auto",playsInline:!0,onLoadedMetadata:Me,onCanPlay:we,onPlay:Ce,onPause:ke,onEnded:Ae,onError:Ne}),Z?t.jsxRuntimeExports.jsxs(t.jsxRuntimeExports.Fragment,{children:[t.jsxRuntimeExports.jsx(Le.default,{container:xe,labels:{fullscreen:P.fullscreenLabel,nonFullscreen:P.nonFullscreenLabel,screen:P.screenLabel,title:P.settingsTitle},onClose:()=>v(!1),onOpenChange:v,onViewModeChange:ve,open:te,viewMode:pe}),t.jsxRuntimeExports.jsxs("div",{className:"slide-player__controls",style:_e,children:[t.jsxRuntimeExports.jsxs("div",{className:"slide-player__group",children:[t.jsxRuntimeExports.jsx("button",{"aria-expanded":te,"aria-haspopup":"dialog","aria-label":"More options",className:"slide-player__action slide-player__action--mobile-more",onClick:()=>{v(e=>!e)},type:"button",children:t.jsxRuntimeExports.jsx(Pe.default,{className:"slide-player__icon",strokeWidth:2.25})}),t.jsxRuntimeExports.jsx("button",{"aria-label":"Volume",className:"hidden",type:"button",children:t.jsxRuntimeExports.jsx(Ve.default,{className:"slide-player__icon",strokeWidth:2.25})}),t.jsxRuntimeExports.jsx("button",{"aria-label":"Rewind",className:"slide-player__action slide-player__action--prev",disabled:Ee,onClick:de,type:"button",children:t.jsxRuntimeExports.jsx(Be.default,{className:"slide-player__icon",strokeWidth:2.25})}),t.jsxRuntimeExports.jsx("button",{"aria-label":Se,className:"slide-player__toggle slide-player__toggle--playback",onClick:()=>{if(K){he?.(!F);return}const e=p.current;if(!(M||!e||!i)){if(c.current!==null){if($){s.current=!1,f.current=!0,c.current=null,x.current=!1,l(!1),n(!1),e.pause();return}S.current="manual",f.current=!1,s.current=!0,n(!0);return}if(!e.src&&y.length>0){S.current="manual",f.current=!1,j(Math.min(E.current,y.length-1),"toggle");return}if(e.paused){S.current="manual",f.current=!1,s.current=!0,m("toggle-resume");return}s.current=!1,f.current=!0,e.pause()}},type:"button",children:be?t.jsxRuntimeExports.jsx(He,{}):t.jsxRuntimeExports.jsx(Oe,{})}),t.jsxRuntimeExports.jsx("button",{"aria-label":"Forward",className:"slide-player__action slide-player__action--next",disabled:ye,onClick:me,type:"button",children:t.jsxRuntimeExports.jsx(Fe.default,{className:"slide-player__icon",strokeWidth:2.25})}),D?t.jsxRuntimeExports.jsx("button",{"aria-label":z?"Exit fullscreen":"Enter fullscreen",className:"slide-player__action slide-player__action--fullscreen",onClick:D,type:"button",children:z?t.jsxRuntimeExports.jsx(Ke.default,{className:"slide-player__icon",strokeWidth:2.25}):t.jsxRuntimeExports.jsx(Ze.default,{className:"slide-player__icon",strokeWidth:2.25})}):null]}),t.jsxRuntimeExports.jsx("div",{className:"slide-player__separator"}),t.jsxRuntimeExports.jsxs("div",{className:"slide-player__group",children:[ne.map((e,a)=>t.jsxRuntimeExports.jsx(r.Fragment,{children:e},`custom-action-${a}`)),t.jsxRuntimeExports.jsx("button",{"aria-label":"Notes",className:ie.cn("slide-player__action slide-player__action--notes",L&&"slide-player__action--active"),disabled:!Re,onClick:ge,type:"button",children:t.jsxRuntimeExports.jsx($e.default,{className:"slide-player__icon",strokeWidth:2.25})})]})]})]}):null]})};exports.default=De;
2
2
  //# sourceMappingURL=Player.cjs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Player.cjs.js","sources":["../../../src/components/Slide/Player.tsx"],"sourcesContent":["import React, {\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport {\n EllipsisVertical,\n FilePenLine,\n Maximize,\n RotateCcw,\n RotateCw,\n ScanLine,\n Volume2,\n} from \"lucide-react\";\n\nimport { cn } from \"../../lib/utils\";\nimport MobilePlayerSettingsSheet from \"./MobilePlayerSettingsSheet\";\nimport type { SlideAudioItem } from \"./useSlide\";\nimport type {\n SlidePlayerCustomActionContext,\n SlidePlayerCustomActions,\n} from \"./types\";\nimport {\n DEFAULT_MOBILE_SCREEN_MODE,\n type MobileScreenMode,\n} from \"./utils/mobileScreenMode\";\nimport { toPlayerCustomActionList } from \"./utils/playerCustomActions\";\nimport \"./player.css\";\n\nconst audioPreloadElementCache = new Map<string, HTMLAudioElement>();\n\nexport interface SlidePlayerTexts {\n settingsTitle?: string;\n screenLabel?: string;\n portraitLabel?: string;\n landscapeLabel?: string;\n}\n\nconst DEFAULT_PLAYER_TEXTS: Required<SlidePlayerTexts> = {\n settingsTitle: \"Settings\",\n screenLabel: \"Screen\",\n portraitLabel: \"Portrait\",\n landscapeLabel: \"Landscape\",\n};\n\nconst preloadAudioUrl = (url?: string) => {\n if (typeof window === \"undefined\" || !url) {\n return;\n }\n\n if (audioPreloadElementCache.has(url)) {\n return;\n }\n\n // Use a detached audio element so warm-up follows the same media loading\n // path as the visible player instead of relying on link preload hints.\n const audio = window.document.createElement(\"audio\");\n audio.preload = \"auto\";\n audio.setAttribute(\"playsinline\", \"true\");\n audio.src = url;\n audio.load();\n\n audioPreloadElementCache.set(url, audio);\n};\n\nexport type PlayerProps = Omit<React.ComponentProps<\"div\">, \"onEnded\"> & {\n audioList?: SlideAudioItem[];\n currentAudioIndex?: number;\n defaultPlaying?: boolean;\n isPlaybackPaused?: boolean;\n isAutoAdvanceEnabled?: boolean;\n useAutoAdvanceToggle?: boolean;\n onLoadingChange?: (loading: boolean) => void;\n onPrev?: () => void;\n onNext?: () => void;\n onFullscreen?: () => void;\n isFullscreen?: boolean;\n mobileScreenMode?: MobileScreenMode;\n settingsPortalContainer?: HTMLElement | null;\n onMobileScreenModeChange?: (screenMode: MobileScreenMode) => void;\n onEnded?: (audioIndex: number) => void;\n onAutoAdvanceToggle?: (enabled: boolean) => void;\n onInteractionToggle?: () => void;\n hasInteraction?: boolean;\n isInteractionOpen?: boolean;\n prevDisabled?: boolean;\n nextDisabled?: boolean;\n showControls?: boolean;\n customActions?: SlidePlayerCustomActions;\n customActionContext?: SlidePlayerCustomActionContext;\n texts?: SlidePlayerTexts;\n};\n\nconst PauseIcon = () => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"34\"\n height=\"34\"\n viewBox=\"0 0 34 34\"\n fill=\"none\"\n >\n <path\n d=\"M16.6667 33.3333C25.8714 33.3333 33.3333 25.8714 33.3333 16.6667C33.3333 7.46192 25.8714 0 16.6667 0C7.46192 0 0 7.46192 0 16.6667C0 25.8714 7.46192 33.3333 16.6667 33.3333Z\"\n fill=\"#0A0A0A\"\n />\n <path d=\"M12 10H16V24H12V10ZM18 10H22V24H18V10Z\" fill=\"white\" />\n </svg>\n);\n\nconst PlayIcon = () => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"34\"\n height=\"34\"\n viewBox=\"0 0 34 34\"\n fill=\"none\"\n >\n <path\n d=\"M16.6667 33.3333C25.8714 33.3333 33.3333 25.8714 33.3333 16.6667C33.3333 7.46192 25.8714 0 16.6667 0C7.46192 0 0 7.46192 0 16.6667C0 25.8714 7.46192 33.3333 16.6667 33.3333Z\"\n fill=\"#0A0A0A\"\n />\n <path d=\"M13.3333 10L23.3333 16.6667L13.3333 23.3333V10Z\" fill=\"white\" />\n </svg>\n);\n\nconst Player: React.FC<PlayerProps> = ({\n audioList = [],\n className,\n currentAudioIndex = -1,\n defaultPlaying = true,\n isPlaybackPaused = false,\n isAutoAdvanceEnabled = true,\n useAutoAdvanceToggle = false,\n onLoadingChange,\n onPrev,\n onNext,\n onFullscreen,\n isFullscreen = false,\n mobileScreenMode = DEFAULT_MOBILE_SCREEN_MODE,\n settingsPortalContainer,\n onMobileScreenModeChange,\n onEnded,\n onAutoAdvanceToggle,\n onInteractionToggle,\n hasInteraction = false,\n isInteractionOpen = false,\n prevDisabled = false,\n nextDisabled = false,\n showControls = true,\n customActions,\n customActionContext,\n texts,\n ...props\n}) => {\n const audioRef = useRef<HTMLAudioElement | null>(null);\n const previousInteractionOpenRef = useRef(isInteractionOpen);\n const audioSrcRef = useRef<string | null>(null);\n const currentAudioKeyRef = useRef<string | null>(null);\n const currentSegmentIndexRef = useRef(0);\n const waitingSegmentIndexRef = useRef<number | null>(null);\n const currentAudioRef = useRef<SlideAudioItem | undefined>(undefined);\n const currentAudioSegmentsRef = useRef<\n NonNullable<SlideAudioItem[\"audioSegments\"]>\n >([]);\n const wasPlayingBeforeExternalPauseRef = useRef(false);\n const isLoadingRef = useRef(false);\n const isPausedByUserRef = useRef(false);\n const activeSourceTypeRef = useRef<\"url\" | \"segment\" | null>(null);\n const isWaitingForSegmentRef = useRef(false);\n const pendingAutoPlayRef = useRef(false);\n const pendingSeekTimeRef = useRef<number | null>(null);\n const isSwitchingSegmentRef = useRef(false);\n const playbackAccessModeRef = useRef<\n \"unknown\" | \"auto\" | \"manual\" | \"blocked\"\n >(\"unknown\");\n const [isPlaying, setIsPlaying] = useState(defaultPlaying);\n const [isMobileMoreOpen, setIsMobileMoreOpen] = useState(false);\n const currentAudio =\n currentAudioIndex >= 0 ? audioList[currentAudioIndex] : undefined;\n const currentAudioUrl = currentAudio?.audioUrl;\n const currentAudioSegments = useMemo(\n () =>\n [...(currentAudio?.audioSegments ?? [])].sort(\n (prevSegment, nextSegment) =>\n prevSegment.segment_index - nextSegment.segment_index\n ),\n [currentAudio?.audioSegments]\n );\n const customActionList = useMemo(\n () => toPlayerCustomActionList(customActions, customActionContext),\n [customActionContext, customActions]\n );\n const mobileVisibleActionCount = customActionList.length + 5;\n const controlsStyle = useMemo(\n () =>\n ({\n \"--slide-player-mobile-control-count\": String(mobileVisibleActionCount),\n }) as React.CSSProperties,\n [mobileVisibleActionCount]\n );\n const playerTexts = useMemo(\n () => ({\n ...DEFAULT_PLAYER_TEXTS,\n ...texts,\n }),\n [texts]\n );\n const currentAudioKey = useMemo(() => {\n if (!currentAudio) {\n return \"none\";\n }\n\n return (\n currentAudio.audioKey ??\n `${String(currentAudio.sequenceNumber ?? \"none\")}:${String(currentAudio.audioUrl ?? \"\")}`\n );\n }, [currentAudio]);\n const isTogglePlaying = useAutoAdvanceToggle\n ? isAutoAdvanceEnabled\n : isPlaying;\n const toggleAriaLabel = useAutoAdvanceToggle\n ? isAutoAdvanceEnabled\n ? \"Pause autoplay\"\n : \"Play autoplay\"\n : isPlaying\n ? \"Pause\"\n : \"Play\";\n\n useEffect(() => {\n currentAudioRef.current = currentAudio;\n }, [currentAudio]);\n\n useEffect(() => {\n if (showControls) {\n return;\n }\n\n setIsMobileMoreOpen(false);\n }, [showControls]);\n\n useEffect(() => {\n if (!previousInteractionOpenRef.current && isInteractionOpen) {\n setIsMobileMoreOpen(false);\n }\n\n previousInteractionOpenRef.current = isInteractionOpen;\n }, [isInteractionOpen]);\n\n useEffect(() => {\n currentAudioSegmentsRef.current = currentAudioSegments;\n }, [currentAudioSegments]);\n\n useEffect(() => {\n const currentUrl = currentAudio?.audioUrl;\n const nextUrl =\n currentAudioIndex >= 0\n ? audioList[currentAudioIndex + 1]?.audioUrl\n : undefined;\n\n preloadAudioUrl(currentUrl);\n preloadAudioUrl(nextUrl);\n }, [audioList, currentAudio?.audioUrl, currentAudioIndex]);\n\n const updateLoading = useCallback(\n (loading: boolean) => {\n if (isLoadingRef.current === loading) {\n return;\n }\n\n isLoadingRef.current = loading;\n onLoadingChange?.(loading);\n },\n [onLoadingChange]\n );\n\n const isAutoplayBlockedError = useCallback((error: unknown) => {\n if (!(error instanceof DOMException)) {\n return false;\n }\n\n return error.name === \"NotAllowedError\" || error.name === \"SecurityError\";\n }, []);\n\n const canStartPlaybackAutomatically = useCallback(() => {\n return (\n defaultPlaying &&\n !isPlaybackPaused &&\n !isPausedByUserRef.current &&\n playbackAccessModeRef.current !== \"blocked\"\n );\n }, [defaultPlaying, isPlaybackPaused]);\n\n const getSegmentSrc = useCallback((audioData: string) => {\n if (!audioData) {\n return \"\";\n }\n\n if (audioData.startsWith(\"data:\")) {\n return audioData;\n }\n\n return `data:audio/mpeg;base64,${audioData}`;\n }, []);\n\n const getWaitingSegmentSeekTime = useCallback(() => {\n const waitingSegmentIndex = waitingSegmentIndexRef.current;\n\n if (waitingSegmentIndex == null || waitingSegmentIndex <= 0) {\n return 0;\n }\n\n return (\n currentAudioSegmentsRef.current\n .slice(0, waitingSegmentIndex)\n .reduce(\n (totalDurationMs, segment) =>\n totalDurationMs + Math.max(Number(segment.duration_ms ?? 0), 0),\n 0\n ) / 1000\n );\n }, []);\n\n const resetAudio = useCallback(() => {\n const audioElement = audioRef.current;\n\n if (!audioElement) {\n return;\n }\n\n pendingAutoPlayRef.current = false;\n isPausedByUserRef.current = false;\n wasPlayingBeforeExternalPauseRef.current = false;\n activeSourceTypeRef.current = null;\n pendingSeekTimeRef.current = null;\n isWaitingForSegmentRef.current = false;\n isSwitchingSegmentRef.current = false;\n audioElement.pause();\n audioElement.removeAttribute(\"src\");\n audioElement.load();\n audioSrcRef.current = null;\n currentSegmentIndexRef.current = 0;\n waitingSegmentIndexRef.current = null;\n setIsPlaying(false);\n updateLoading(false);\n }, [updateLoading]);\n\n const tryPlayCurrentAudio = useCallback(\n (_reason: string) => {\n const audioElement = audioRef.current;\n\n if (!audioElement) {\n return false;\n }\n\n const playPromise = audioElement.play();\n\n if (playPromise && typeof playPromise.then === \"function\") {\n void playPromise\n .then(() => {\n if (playbackAccessModeRef.current === \"unknown\") {\n playbackAccessModeRef.current = \"auto\";\n }\n\n pendingAutoPlayRef.current = false;\n isSwitchingSegmentRef.current = false;\n })\n .catch((error: unknown) => {\n if (\n playbackAccessModeRef.current === \"unknown\" &&\n isAutoplayBlockedError(error)\n ) {\n // Lock autoplay after the first browser rejection.\n playbackAccessModeRef.current = \"blocked\";\n pendingAutoPlayRef.current = false;\n updateLoading(false);\n }\n\n isSwitchingSegmentRef.current = false;\n setIsPlaying(false);\n });\n }\n\n return true;\n },\n [isAutoplayBlockedError, updateLoading]\n );\n\n const startSegmentPlayback = useCallback(\n (segmentIndex: number, _reason: string) => {\n const audioElement = audioRef.current;\n const segment = currentAudioSegmentsRef.current[segmentIndex];\n\n if (!audioElement || !segment) {\n return false;\n }\n\n const nextAudioSrc = getSegmentSrc(segment.audio_data);\n\n currentSegmentIndexRef.current = segmentIndex;\n waitingSegmentIndexRef.current = null;\n isWaitingForSegmentRef.current = false;\n isSwitchingSegmentRef.current = true;\n const shouldAutoResume = canStartPlaybackAutomatically();\n\n pendingAutoPlayRef.current = shouldAutoResume;\n updateLoading(false);\n\n const hasNewSrc = audioSrcRef.current !== nextAudioSrc;\n\n activeSourceTypeRef.current = \"segment\";\n\n if (hasNewSrc) {\n audioElement.pause();\n audioElement.removeAttribute(\"src\");\n audioElement.load();\n audioSrcRef.current = nextAudioSrc;\n audioElement.src = nextAudioSrc;\n audioElement.load();\n }\n\n pendingSeekTimeRef.current = 0;\n\n if (audioElement.readyState > 0) {\n audioElement.currentTime = 0;\n pendingSeekTimeRef.current = null;\n }\n\n if (!shouldAutoResume) {\n pendingAutoPlayRef.current = false;\n isSwitchingSegmentRef.current = false;\n audioElement.pause();\n setIsPlaying(false);\n return true;\n }\n\n return tryPlayCurrentAudio(`start-segment:${_reason}`);\n },\n [\n canStartPlaybackAutomatically,\n getSegmentSrc,\n tryPlayCurrentAudio,\n updateLoading,\n ]\n );\n\n const finishAudioItem = useCallback(\n (_reason?: string) => {\n pendingAutoPlayRef.current = false;\n isWaitingForSegmentRef.current = false;\n isSwitchingSegmentRef.current = false;\n setIsPlaying(false);\n updateLoading(false);\n\n if (currentAudioIndex >= 0) {\n onEnded?.(currentAudioIndex);\n }\n },\n [currentAudioIndex, onEnded, updateLoading]\n );\n\n const handleSegmentEnded = useCallback(() => {\n const nextSegmentIndex = currentSegmentIndexRef.current + 1;\n const segments = currentAudioSegmentsRef.current;\n const nextSegment = segments[nextSegmentIndex];\n const activeAudio = currentAudioRef.current;\n const hasFinal = segments.some((segment) => segment.is_final);\n\n if (nextSegment) {\n startSegmentPlayback(nextSegmentIndex, \"ended\");\n return;\n }\n\n if (activeAudio?.isAudioStreaming || !hasFinal) {\n currentSegmentIndexRef.current = nextSegmentIndex;\n waitingSegmentIndexRef.current = nextSegmentIndex;\n isWaitingForSegmentRef.current = true;\n pendingAutoPlayRef.current = defaultPlaying;\n setIsPlaying(false);\n updateLoading(true);\n\n return;\n }\n\n finishAudioItem(\"segments-completed\");\n }, [defaultPlaying, finishAudioItem, startSegmentPlayback, updateLoading]);\n\n useEffect(() => {\n if (currentAudioKeyRef.current === currentAudioKey) {\n return;\n }\n\n currentAudioKeyRef.current = currentAudioKey;\n currentSegmentIndexRef.current = 0;\n waitingSegmentIndexRef.current = null;\n isWaitingForSegmentRef.current = false;\n isPausedByUserRef.current = false;\n wasPlayingBeforeExternalPauseRef.current = false;\n pendingAutoPlayRef.current = false;\n isSwitchingSegmentRef.current = false;\n activeSourceTypeRef.current = null;\n audioSrcRef.current = null;\n updateLoading(false);\n\n const audioElement = audioRef.current;\n\n if (!audioElement) {\n return;\n }\n\n audioElement.pause();\n audioElement.removeAttribute(\"src\");\n audioElement.load();\n setIsPlaying(false);\n }, [\n currentAudioIndex,\n currentAudioKey,\n currentAudioSegments.length,\n currentAudioUrl,\n updateLoading,\n ]);\n\n useEffect(() => {\n const audioElement = audioRef.current;\n\n if (!audioElement) {\n return;\n }\n\n if (isPlaybackPaused) {\n wasPlayingBeforeExternalPauseRef.current = Boolean(\n currentAudioRef.current &&\n !isPausedByUserRef.current &&\n (!audioElement.paused ||\n pendingAutoPlayRef.current ||\n waitingSegmentIndexRef.current !== null)\n );\n\n pendingAutoPlayRef.current = false;\n updateLoading(false);\n audioElement.pause();\n setIsPlaying(false);\n return;\n }\n\n if (\n !wasPlayingBeforeExternalPauseRef.current ||\n !currentAudioRef.current ||\n isPausedByUserRef.current\n ) {\n return;\n }\n\n wasPlayingBeforeExternalPauseRef.current = false;\n\n if (waitingSegmentIndexRef.current !== null) {\n if (\n waitingSegmentIndexRef.current < currentAudioSegmentsRef.current.length\n ) {\n startSegmentPlayback(waitingSegmentIndexRef.current, \"external-resume\");\n return;\n }\n\n pendingAutoPlayRef.current = true;\n updateLoading(true);\n return;\n }\n\n if (!audioSrcRef.current && currentAudioSegmentsRef.current.length > 0) {\n startSegmentPlayback(\n Math.min(\n currentSegmentIndexRef.current,\n currentAudioSegmentsRef.current.length - 1\n ),\n \"external-resume-init\"\n );\n return;\n }\n\n if (!audioElement.paused) {\n return;\n }\n\n pendingAutoPlayRef.current = true;\n tryPlayCurrentAudio(\"external-resume\");\n }, [\n isPlaybackPaused,\n startSegmentPlayback,\n tryPlayCurrentAudio,\n updateLoading,\n ]);\n\n useEffect(() => {\n const audioElement = audioRef.current;\n\n if (!audioElement) {\n return;\n }\n\n if (!currentAudio) {\n resetAudio();\n return;\n }\n\n if (isPlaybackPaused) {\n pendingAutoPlayRef.current = false;\n updateLoading(false);\n audioElement.pause();\n setIsPlaying(false);\n return;\n }\n\n if (currentAudioUrl) {\n const hasNewSrc = audioSrcRef.current !== currentAudioUrl;\n const shouldAutoResume = canStartPlaybackAutomatically();\n const shouldKeepSegmentSource =\n activeSourceTypeRef.current === \"segment\" &&\n Boolean(audioSrcRef.current) &&\n waitingSegmentIndexRef.current === null;\n\n if (shouldKeepSegmentSource) {\n if (!shouldAutoResume) {\n pendingAutoPlayRef.current = false;\n audioElement.pause();\n setIsPlaying(false);\n return;\n }\n\n if (audioElement.paused) {\n pendingAutoPlayRef.current = true;\n tryPlayCurrentAudio(\"keep-segment-source\");\n }\n\n return;\n }\n\n if (hasNewSrc) {\n const nextSeekTime =\n waitingSegmentIndexRef.current !== null\n ? getWaitingSegmentSeekTime()\n : 0;\n\n audioElement.pause();\n audioElement.removeAttribute(\"src\");\n audioElement.load();\n audioSrcRef.current = currentAudioUrl;\n activeSourceTypeRef.current = \"url\";\n audioElement.src = currentAudioUrl;\n audioElement.load();\n pendingSeekTimeRef.current = nextSeekTime;\n\n if (audioElement.readyState > 0) {\n audioElement.currentTime = nextSeekTime;\n pendingSeekTimeRef.current = null;\n }\n }\n\n pendingAutoPlayRef.current = shouldAutoResume;\n isWaitingForSegmentRef.current = false;\n isSwitchingSegmentRef.current = false;\n updateLoading(false);\n\n if (!shouldAutoResume) {\n pendingAutoPlayRef.current = false;\n audioElement.pause();\n setIsPlaying(false);\n return;\n }\n\n tryPlayCurrentAudio(hasNewSrc ? \"sync-url-init\" : \"sync-url\");\n return;\n }\n\n if (waitingSegmentIndexRef.current !== null) {\n if (waitingSegmentIndexRef.current < currentAudioSegments.length) {\n if (isPausedByUserRef.current) {\n setIsPlaying(false);\n updateLoading(false);\n return;\n }\n\n startSegmentPlayback(waitingSegmentIndexRef.current, \"wait-resume\");\n return;\n }\n\n isWaitingForSegmentRef.current = true;\n pendingAutoPlayRef.current = canStartPlaybackAutomatically();\n setIsPlaying(false);\n updateLoading(canStartPlaybackAutomatically());\n return;\n }\n\n if (!currentAudioSegments.length) {\n if (currentAudio.isAudioStreaming) {\n waitingSegmentIndexRef.current = currentSegmentIndexRef.current;\n isWaitingForSegmentRef.current = true;\n pendingAutoPlayRef.current = canStartPlaybackAutomatically();\n setIsPlaying(false);\n updateLoading(canStartPlaybackAutomatically());\n return;\n }\n\n resetAudio();\n return;\n }\n\n if (!audioSrcRef.current) {\n startSegmentPlayback(\n Math.min(\n currentSegmentIndexRef.current,\n currentAudioSegments.length - 1\n ),\n \"effect-init\"\n );\n return;\n }\n\n if (!defaultPlaying || isPausedByUserRef.current) {\n pendingAutoPlayRef.current = false;\n audioElement.pause();\n setIsPlaying(false);\n return;\n }\n\n if (audioElement.paused) {\n pendingAutoPlayRef.current = true;\n tryPlayCurrentAudio(\"sync-paused-retry\");\n }\n }, [\n currentAudio,\n currentAudioIndex,\n currentAudioSegments,\n currentAudioUrl,\n defaultPlaying,\n isPlaybackPaused,\n canStartPlaybackAutomatically,\n resetAudio,\n startSegmentPlayback,\n tryPlayCurrentAudio,\n getWaitingSegmentSeekTime,\n updateLoading,\n ]);\n\n useEffect(() => resetAudio, [resetAudio]);\n\n const handleAudioPlay = useCallback(() => {\n setIsPlaying(true);\n updateLoading(false);\n }, [updateLoading]);\n\n const handleAudioPause = useCallback(() => {\n if (isWaitingForSegmentRef.current || isSwitchingSegmentRef.current) {\n return;\n }\n\n setIsPlaying(false);\n }, [currentAudioIndex]);\n\n const handleAudioCanPlay = useCallback(() => {\n const audioElement = audioRef.current;\n\n if (audioElement && pendingSeekTimeRef.current !== null) {\n audioElement.currentTime = pendingSeekTimeRef.current;\n pendingSeekTimeRef.current = null;\n }\n\n if (!pendingAutoPlayRef.current || !defaultPlaying) {\n return;\n }\n\n tryPlayCurrentAudio(\"canplay\");\n }, [currentAudioIndex, defaultPlaying, tryPlayCurrentAudio]);\n\n const handleLoadedMetadata = useCallback(() => {\n const audioElement = audioRef.current;\n\n if (audioElement && pendingSeekTimeRef.current !== null) {\n audioElement.currentTime = pendingSeekTimeRef.current;\n pendingSeekTimeRef.current = null;\n }\n }, [currentAudioIndex]);\n\n const handleAudioEnded = useCallback(() => {\n const shouldFinishAsUrl =\n activeSourceTypeRef.current === \"url\" ||\n currentAudioSegmentsRef.current.length === 0;\n\n isSwitchingSegmentRef.current = false;\n\n if (shouldFinishAsUrl) {\n finishAudioItem(\"url-ended\");\n return;\n }\n\n handleSegmentEnded();\n }, [finishAudioItem, handleSegmentEnded]);\n\n const handleAudioError = useCallback(() => {\n setIsPlaying(false);\n updateLoading(false);\n }, [updateLoading]);\n const handleMobileScreenModeChange = useCallback(\n (nextScreenMode: MobileScreenMode) => {\n onMobileScreenModeChange?.(nextScreenMode);\n setIsMobileMoreOpen(false);\n },\n [onMobileScreenModeChange]\n );\n\n return (\n <div className={cn(\"slide-player\", className)} {...props}>\n <audio\n ref={audioRef}\n preload=\"auto\"\n playsInline\n onLoadedMetadata={handleLoadedMetadata}\n onCanPlay={handleAudioCanPlay}\n onPlay={handleAudioPlay}\n onPause={handleAudioPause}\n onEnded={handleAudioEnded}\n onError={handleAudioError}\n />\n\n {showControls ? (\n <>\n <MobilePlayerSettingsSheet\n container={settingsPortalContainer}\n labels={{\n landscape: playerTexts.landscapeLabel,\n portrait: playerTexts.portraitLabel,\n screen: playerTexts.screenLabel,\n title: playerTexts.settingsTitle,\n }}\n onClose={() => setIsMobileMoreOpen(false)}\n onOpenChange={setIsMobileMoreOpen}\n onScreenModeChange={handleMobileScreenModeChange}\n open={isMobileMoreOpen}\n screenMode={mobileScreenMode}\n />\n\n <div className=\"slide-player__controls\" style={controlsStyle}>\n <div className=\"slide-player__group\">\n <button\n aria-expanded={isMobileMoreOpen}\n aria-haspopup=\"dialog\"\n aria-label=\"More options\"\n className=\"slide-player__action slide-player__action--mobile-more\"\n onClick={() => {\n setIsMobileMoreOpen((prevOpen) => !prevOpen);\n }}\n type=\"button\"\n >\n <EllipsisVertical\n className=\"slide-player__icon\"\n strokeWidth={2.25}\n />\n </button>\n <button aria-label=\"Volume\" className=\"hidden\" type=\"button\">\n <Volume2 className=\"slide-player__icon\" strokeWidth={2.25} />\n </button>\n <button\n aria-label=\"Rewind\"\n className=\"slide-player__action slide-player__action--prev\"\n disabled={prevDisabled}\n onClick={onPrev}\n type=\"button\"\n >\n <RotateCcw className=\"slide-player__icon\" strokeWidth={2.25} />\n </button>\n <button\n aria-label={toggleAriaLabel}\n className=\"slide-player__toggle slide-player__toggle--playback\"\n onClick={() => {\n if (useAutoAdvanceToggle) {\n onAutoAdvanceToggle?.(!isAutoAdvanceEnabled);\n return;\n }\n\n const audioElement = audioRef.current;\n\n if (isPlaybackPaused || !audioElement || !currentAudio) {\n return;\n }\n\n if (waitingSegmentIndexRef.current !== null) {\n if (isPlaying) {\n pendingAutoPlayRef.current = false;\n isPausedByUserRef.current = true;\n waitingSegmentIndexRef.current = null;\n isWaitingForSegmentRef.current = false;\n setIsPlaying(false);\n updateLoading(false);\n audioElement.pause();\n return;\n }\n\n playbackAccessModeRef.current = \"manual\";\n isPausedByUserRef.current = false;\n pendingAutoPlayRef.current = true;\n updateLoading(true);\n return;\n }\n\n if (!audioElement.src && currentAudioSegments.length > 0) {\n playbackAccessModeRef.current = \"manual\";\n isPausedByUserRef.current = false;\n startSegmentPlayback(\n Math.min(\n currentSegmentIndexRef.current,\n currentAudioSegments.length - 1\n ),\n \"toggle\"\n );\n return;\n }\n\n if (audioElement.paused) {\n playbackAccessModeRef.current = \"manual\";\n isPausedByUserRef.current = false;\n pendingAutoPlayRef.current = true;\n tryPlayCurrentAudio(\"toggle-resume\");\n return;\n }\n\n pendingAutoPlayRef.current = false;\n isPausedByUserRef.current = true;\n audioElement.pause();\n }}\n type=\"button\"\n >\n {isTogglePlaying ? <PauseIcon /> : <PlayIcon />}\n </button>\n <button\n aria-label=\"Forward\"\n className=\"slide-player__action slide-player__action--next\"\n disabled={nextDisabled}\n onClick={onNext}\n type=\"button\"\n >\n <RotateCw className=\"slide-player__icon\" strokeWidth={2.25} />\n </button>\n {onFullscreen ? (\n <button\n aria-label={\n isFullscreen ? \"Exit fullscreen\" : \"Enter fullscreen\"\n }\n className=\"slide-player__action slide-player__action--fullscreen\"\n onClick={onFullscreen}\n type=\"button\"\n >\n {isFullscreen ? (\n <ScanLine\n className=\"slide-player__icon\"\n strokeWidth={2.25}\n />\n ) : (\n <Maximize\n className=\"slide-player__icon\"\n strokeWidth={2.25}\n />\n )}\n </button>\n ) : null}\n </div>\n\n <div className=\"slide-player__separator\" />\n\n <div className=\"slide-player__group\">\n {customActionList.map((customAction, customActionIndex) => (\n <React.Fragment key={`custom-action-${customActionIndex}`}>\n {customAction}\n </React.Fragment>\n ))}\n <button\n aria-label=\"Notes\"\n className={cn(\n \"slide-player__action slide-player__action--notes\",\n isInteractionOpen && \"slide-player__action--active\"\n )}\n disabled={!hasInteraction}\n onClick={onInteractionToggle}\n type=\"button\"\n >\n <FilePenLine\n className=\"slide-player__icon\"\n strokeWidth={2.25}\n />\n </button>\n </div>\n </div>\n </>\n ) : null}\n </div>\n );\n};\n\nexport default Player;\n"],"names":["audioPreloadElementCache","DEFAULT_PLAYER_TEXTS","preloadAudioUrl","url","audio","PauseIcon","jsxs","jsx","PlayIcon","Player","audioList","className","currentAudioIndex","defaultPlaying","isPlaybackPaused","isAutoAdvanceEnabled","useAutoAdvanceToggle","onLoadingChange","onPrev","onNext","onFullscreen","isFullscreen","mobileScreenMode","DEFAULT_MOBILE_SCREEN_MODE","settingsPortalContainer","onMobileScreenModeChange","onEnded","onAutoAdvanceToggle","onInteractionToggle","hasInteraction","isInteractionOpen","prevDisabled","nextDisabled","showControls","customActions","customActionContext","texts","props","audioRef","useRef","previousInteractionOpenRef","audioSrcRef","currentAudioKeyRef","currentSegmentIndexRef","waitingSegmentIndexRef","currentAudioRef","currentAudioSegmentsRef","wasPlayingBeforeExternalPauseRef","isLoadingRef","isPausedByUserRef","activeSourceTypeRef","isWaitingForSegmentRef","pendingAutoPlayRef","pendingSeekTimeRef","isSwitchingSegmentRef","playbackAccessModeRef","isPlaying","setIsPlaying","useState","isMobileMoreOpen","setIsMobileMoreOpen","currentAudio","currentAudioUrl","currentAudioSegments","useMemo","prevSegment","nextSegment","customActionList","toPlayerCustomActionList","mobileVisibleActionCount","controlsStyle","playerTexts","currentAudioKey","isTogglePlaying","toggleAriaLabel","useEffect","currentUrl","nextUrl","updateLoading","useCallback","loading","isAutoplayBlockedError","error","canStartPlaybackAutomatically","getSegmentSrc","audioData","getWaitingSegmentSeekTime","waitingSegmentIndex","totalDurationMs","segment","resetAudio","audioElement","tryPlayCurrentAudio","_reason","playPromise","startSegmentPlayback","segmentIndex","nextAudioSrc","shouldAutoResume","hasNewSrc","finishAudioItem","handleSegmentEnded","nextSegmentIndex","segments","activeAudio","hasFinal","nextSeekTime","handleAudioPlay","handleAudioPause","handleAudioCanPlay","handleLoadedMetadata","handleAudioEnded","shouldFinishAsUrl","handleAudioError","handleMobileScreenModeChange","nextScreenMode","cn","Fragment","MobilePlayerSettingsSheet","prevOpen","EllipsisVertical","Volume2","RotateCcw","RotateCw","ScanLine","Maximize","customAction","customActionIndex","React","FilePenLine"],"mappings":"q6CA+BMA,OAA+B,IAS/BC,GAAmD,CACvD,cAAe,WACf,YAAa,SACb,cAAe,WACf,eAAgB,WAClB,EAEMC,GAAmBC,GAAiB,CAKxC,GAJI,OAAO,OAAW,KAAe,CAACA,GAIlCH,GAAyB,IAAIG,CAAG,EAClC,OAKF,MAAMC,EAAQ,OAAO,SAAS,cAAc,OAAO,EACnDA,EAAM,QAAU,OAChBA,EAAM,aAAa,cAAe,MAAM,EACxCA,EAAM,IAAMD,EACZC,EAAM,KAAA,EAENJ,GAAyB,IAAIG,EAAKC,CAAK,CACzC,EA8BMC,GAAY,IAChBC,EAAAA,kBAAAA,KAAC,MAAA,CACC,MAAM,6BACN,MAAM,KACN,OAAO,KACP,QAAQ,YACR,KAAK,OAEL,SAAA,CAAAC,EAAAA,kBAAAA,IAAC,OAAA,CACC,EAAE,gLACF,KAAK,SAAA,CAAA,EAEPA,EAAAA,kBAAAA,IAAC,OAAA,CAAK,EAAE,yCAAyC,KAAK,OAAA,CAAQ,CAAA,CAAA,CAChE,EAGIC,GAAW,IACfF,EAAAA,kBAAAA,KAAC,MAAA,CACC,MAAM,6BACN,MAAM,KACN,OAAO,KACP,QAAQ,YACR,KAAK,OAEL,SAAA,CAAAC,EAAAA,kBAAAA,IAAC,OAAA,CACC,EAAE,gLACF,KAAK,SAAA,CAAA,EAEPA,EAAAA,kBAAAA,IAAC,OAAA,CAAK,EAAE,kDAAkD,KAAK,OAAA,CAAQ,CAAA,CAAA,CACzE,EAGIE,GAAgC,CAAC,CACrC,UAAAC,EAAY,CAAA,EACZ,UAAAC,EACA,kBAAAC,EAAoB,GACpB,eAAAC,EAAiB,GACjB,iBAAAC,EAAmB,GACnB,qBAAAC,EAAuB,GACvB,qBAAAC,EAAuB,GACvB,gBAAAC,EACA,OAAAC,GACA,OAAAC,GACA,aAAAC,EACA,aAAAC,EAAe,GAAA,iBACfC,GAAmBC,GAAAA,2BACnB,wBAAAC,GACA,yBAAAC,EACA,QAAAC,EACA,oBAAAC,GACA,oBAAAC,GACA,eAAAC,GAAiB,GACjB,kBAAAC,EAAoB,GACpB,aAAAC,GAAe,GACf,aAAAC,GAAe,GACf,aAAAC,EAAe,GACf,cAAAC,EACA,oBAAAC,EACA,MAAAC,EACA,GAAGC,EACL,IAAM,CACJ,MAAMC,EAAWC,EAAAA,OAAgC,IAAI,EAC/CC,EAA6BD,EAAAA,OAAOT,CAAiB,EACrDW,EAAcF,EAAAA,OAAsB,IAAI,EACxCG,GAAqBH,EAAAA,OAAsB,IAAI,EAC/CI,EAAyBJ,EAAAA,OAAO,CAAC,EACjCK,EAAyBL,EAAAA,OAAsB,IAAI,EACnDM,EAAkBN,EAAAA,OAAmC,MAAS,EAC9DO,EAA0BP,EAAAA,OAE9B,EAAE,EACEQ,EAAmCR,EAAAA,OAAO,EAAK,EAC/CS,GAAeT,EAAAA,OAAO,EAAK,EAC3BU,EAAoBV,EAAAA,OAAO,EAAK,EAChCW,EAAsBX,EAAAA,OAAiC,IAAI,EAC3DY,EAAyBZ,EAAAA,OAAO,EAAK,EACrCa,EAAqBb,EAAAA,OAAO,EAAK,EACjCc,EAAqBd,EAAAA,OAAsB,IAAI,EAC/Ce,EAAwBf,EAAAA,OAAO,EAAK,EACpCgB,EAAwBhB,EAAAA,OAE5B,SAAS,EACL,CAACiB,EAAWC,CAAY,EAAIC,EAAAA,SAAS7C,CAAc,EACnD,CAAC8C,GAAkBC,CAAmB,EAAIF,EAAAA,SAAS,EAAK,EACxDG,EACJjD,GAAqB,EAAIF,EAAUE,CAAiB,EAAI,OACpDkD,EAAkBD,GAAc,SAChCE,EAAuBC,EAAAA,QAC3B,IACE,CAAC,GAAIH,GAAc,eAAiB,CAAA,CAAG,EAAE,KACvC,CAACI,EAAaC,IACZD,EAAY,cAAgBC,EAAY,aAAA,EAE9C,CAACL,GAAc,aAAa,CAAA,EAExBM,GAAmBH,EAAAA,QACvB,IAAMI,GAAAA,yBAAyBlC,EAAeC,CAAmB,EACjE,CAACA,EAAqBD,CAAa,CAAA,EAE/BmC,GAA2BF,GAAiB,OAAS,EACrDG,GAAgBN,EAAAA,QACpB,KACG,CACC,sCAAuC,OAAOK,EAAwB,CAAA,GAE1E,CAACA,EAAwB,CAAA,EAErBE,EAAcP,EAAAA,QAClB,KAAO,CACL,GAAG/D,GACH,GAAGmC,CAAA,GAEL,CAACA,CAAK,CAAA,EAEFoC,EAAkBR,EAAAA,QAAQ,IACzBH,EAKHA,EAAa,UACb,GAAG,OAAOA,EAAa,gBAAkB,MAAM,CAAC,IAAI,OAAOA,EAAa,UAAY,EAAE,CAAC,GALhF,OAOR,CAACA,CAAY,CAAC,EACXY,GAAkBzD,EACpBD,EACAyC,EACEkB,GAAkB1D,EACpBD,EACE,iBACA,gBACFyC,EACE,QACA,OAENmB,EAAAA,UAAU,IAAM,CACd9B,EAAgB,QAAUgB,CAC5B,EAAG,CAACA,CAAY,CAAC,EAEjBc,EAAAA,UAAU,IAAM,CACV1C,GAIJ2B,EAAoB,EAAK,CAC3B,EAAG,CAAC3B,CAAY,CAAC,EAEjB0C,EAAAA,UAAU,IAAM,CACV,CAACnC,EAA2B,SAAWV,GACzC8B,EAAoB,EAAK,EAG3BpB,EAA2B,QAAUV,CACvC,EAAG,CAACA,CAAiB,CAAC,EAEtB6C,EAAAA,UAAU,IAAM,CACd7B,EAAwB,QAAUiB,CACpC,EAAG,CAACA,CAAoB,CAAC,EAEzBY,EAAAA,UAAU,IAAM,CACd,MAAMC,EAAaf,GAAc,SAC3BgB,EACJjE,GAAqB,EACjBF,EAAUE,EAAoB,CAAC,GAAG,SAClC,OAENV,GAAgB0E,CAAU,EAC1B1E,GAAgB2E,CAAO,CACzB,EAAG,CAACnE,EAAWmD,GAAc,SAAUjD,CAAiB,CAAC,EAEzD,MAAMkE,EAAgBC,EAAAA,YACnBC,GAAqB,CAChBhC,GAAa,UAAYgC,IAI7BhC,GAAa,QAAUgC,EACvB/D,IAAkB+D,CAAO,EAC3B,EACA,CAAC/D,CAAe,CAAA,EAGZgE,GAAyBF,cAAaG,GACpCA,aAAiB,aAIhBA,EAAM,OAAS,mBAAqBA,EAAM,OAAS,gBAHjD,GAIR,CAAA,CAAE,EAECC,EAAgCJ,EAAAA,YAAY,IAE9ClE,GACA,CAACC,GACD,CAACmC,EAAkB,SACnBM,EAAsB,UAAY,UAEnC,CAAC1C,EAAgBC,CAAgB,CAAC,EAE/BsE,GAAgBL,cAAaM,GAC5BA,EAIDA,EAAU,WAAW,OAAO,EACvBA,EAGF,0BAA0BA,CAAS,GAPjC,GAQR,CAAA,CAAE,EAECC,GAA4BP,EAAAA,YAAY,IAAM,CAClD,MAAMQ,EAAsB3C,EAAuB,QAEnD,OAAI2C,GAAuB,MAAQA,GAAuB,EACjD,EAIPzC,EAAwB,QACrB,MAAM,EAAGyC,CAAmB,EAC5B,OACC,CAACC,EAAiBC,IAChBD,EAAkB,KAAK,IAAI,OAAOC,EAAQ,aAAe,CAAC,EAAG,CAAC,EAChE,CAAA,EACE,GAEV,EAAG,CAAA,CAAE,EAECC,EAAaX,EAAAA,YAAY,IAAM,CACnC,MAAMY,EAAerD,EAAS,QAEzBqD,IAILvC,EAAmB,QAAU,GAC7BH,EAAkB,QAAU,GAC5BF,EAAiC,QAAU,GAC3CG,EAAoB,QAAU,KAC9BG,EAAmB,QAAU,KAC7BF,EAAuB,QAAU,GACjCG,EAAsB,QAAU,GAChCqC,EAAa,MAAA,EACbA,EAAa,gBAAgB,KAAK,EAClCA,EAAa,KAAA,EACblD,EAAY,QAAU,KACtBE,EAAuB,QAAU,EACjCC,EAAuB,QAAU,KACjCa,EAAa,EAAK,EAClBqB,EAAc,EAAK,EACrB,EAAG,CAACA,CAAa,CAAC,EAEZc,EAAsBb,EAAAA,YACzBc,GAAoB,CACnB,MAAMF,EAAerD,EAAS,QAE9B,GAAI,CAACqD,EACH,MAAO,GAGT,MAAMG,EAAcH,EAAa,KAAA,EAEjC,OAAIG,GAAe,OAAOA,EAAY,MAAS,YACxCA,EACF,KAAK,IAAM,CACNvC,EAAsB,UAAY,YACpCA,EAAsB,QAAU,QAGlCH,EAAmB,QAAU,GAC7BE,EAAsB,QAAU,EAClC,CAAC,EACA,MAAO4B,GAAmB,CAEvB3B,EAAsB,UAAY,WAClC0B,GAAuBC,CAAK,IAG5B3B,EAAsB,QAAU,UAChCH,EAAmB,QAAU,GAC7B0B,EAAc,EAAK,GAGrBxB,EAAsB,QAAU,GAChCG,EAAa,EAAK,CACpB,CAAC,EAGE,EACT,EACA,CAACwB,GAAwBH,CAAa,CAAA,EAGlCiB,EAAuBhB,EAAAA,YAC3B,CAACiB,EAAsBH,IAAoB,CACzC,MAAMF,EAAerD,EAAS,QACxBmD,EAAU3C,EAAwB,QAAQkD,CAAY,EAE5D,GAAI,CAACL,GAAgB,CAACF,EACpB,MAAO,GAGT,MAAMQ,EAAeb,GAAcK,EAAQ,UAAU,EAErD9C,EAAuB,QAAUqD,EACjCpD,EAAuB,QAAU,KACjCO,EAAuB,QAAU,GACjCG,EAAsB,QAAU,GAChC,MAAM4C,EAAmBf,EAAA,EAEzB/B,EAAmB,QAAU8C,EAC7BpB,EAAc,EAAK,EAEnB,MAAMqB,GAAY1D,EAAY,UAAYwD,EAoB1C,OAlBA/C,EAAoB,QAAU,UAE1BiD,KACFR,EAAa,MAAA,EACbA,EAAa,gBAAgB,KAAK,EAClCA,EAAa,KAAA,EACblD,EAAY,QAAUwD,EACtBN,EAAa,IAAMM,EACnBN,EAAa,KAAA,GAGftC,EAAmB,QAAU,EAEzBsC,EAAa,WAAa,IAC5BA,EAAa,YAAc,EAC3BtC,EAAmB,QAAU,MAG1B6C,EAQEN,EAAoB,iBAAiBC,CAAO,EAAE,GAPnDzC,EAAmB,QAAU,GAC7BE,EAAsB,QAAU,GAChCqC,EAAa,MAAA,EACblC,EAAa,EAAK,EACX,GAIX,EACA,CACE0B,EACAC,GACAQ,EACAd,CAAA,CACF,EAGIsB,EAAkBrB,EAAAA,YACrBc,GAAqB,CACpBzC,EAAmB,QAAU,GAC7BD,EAAuB,QAAU,GACjCG,EAAsB,QAAU,GAChCG,EAAa,EAAK,EAClBqB,EAAc,EAAK,EAEflE,GAAqB,GACvBc,IAAUd,CAAiB,CAE/B,EACA,CAACA,EAAmBc,EAASoD,CAAa,CAAA,EAGtCuB,GAAqBtB,EAAAA,YAAY,IAAM,CAC3C,MAAMuB,EAAmB3D,EAAuB,QAAU,EACpD4D,EAAWzD,EAAwB,QACnCoB,EAAcqC,EAASD,CAAgB,EACvCE,EAAc3D,EAAgB,QAC9B4D,EAAWF,EAAS,KAAMd,GAAYA,EAAQ,QAAQ,EAE5D,GAAIvB,EAAa,CACf6B,EAAqBO,EAAkB,OAAO,EAC9C,MACF,CAEA,GAAIE,GAAa,kBAAoB,CAACC,EAAU,CAC9C9D,EAAuB,QAAU2D,EACjC1D,EAAuB,QAAU0D,EACjCnD,EAAuB,QAAU,GACjCC,EAAmB,QAAUvC,EAC7B4C,EAAa,EAAK,EAClBqB,EAAc,EAAI,EAElB,MACF,CAEAsB,EAAgB,oBAAoB,CACtC,EAAG,CAACvF,EAAgBuF,EAAiBL,EAAsBjB,CAAa,CAAC,EAEzEH,EAAAA,UAAU,IAAM,CACd,GAAIjC,GAAmB,UAAY8B,EACjC,OAGF9B,GAAmB,QAAU8B,EAC7B7B,EAAuB,QAAU,EACjCC,EAAuB,QAAU,KACjCO,EAAuB,QAAU,GACjCF,EAAkB,QAAU,GAC5BF,EAAiC,QAAU,GAC3CK,EAAmB,QAAU,GAC7BE,EAAsB,QAAU,GAChCJ,EAAoB,QAAU,KAC9BT,EAAY,QAAU,KACtBqC,EAAc,EAAK,EAEnB,MAAMa,EAAerD,EAAS,QAEzBqD,IAILA,EAAa,MAAA,EACbA,EAAa,gBAAgB,KAAK,EAClCA,EAAa,KAAA,EACblC,EAAa,EAAK,EACpB,EAAG,CACD7C,EACA4D,EACAT,EAAqB,OACrBD,EACAgB,CAAA,CACD,EAEDH,EAAAA,UAAU,IAAM,CACd,MAAMgB,EAAerD,EAAS,QAE9B,GAAKqD,EAIL,IAAI7E,EAAkB,CACpBiC,EAAiC,QAAU,GACzCF,EAAgB,SACd,CAACI,EAAkB,UAClB,CAAC0C,EAAa,QACbvC,EAAmB,SACnBR,EAAuB,UAAY,OAGzCQ,EAAmB,QAAU,GAC7B0B,EAAc,EAAK,EACnBa,EAAa,MAAA,EACblC,EAAa,EAAK,EAClB,MACF,CAEA,GACE,GAACV,EAAiC,SAClC,CAACF,EAAgB,SACjBI,EAAkB,SAOpB,IAFAF,EAAiC,QAAU,GAEvCH,EAAuB,UAAY,KAAM,CAC3C,GACEA,EAAuB,QAAUE,EAAwB,QAAQ,OACjE,CACAiD,EAAqBnD,EAAuB,QAAS,iBAAiB,EACtE,MACF,CAEAQ,EAAmB,QAAU,GAC7B0B,EAAc,EAAI,EAClB,MACF,CAEA,GAAI,CAACrC,EAAY,SAAWK,EAAwB,QAAQ,OAAS,EAAG,CACtEiD,EACE,KAAK,IACHpD,EAAuB,QACvBG,EAAwB,QAAQ,OAAS,CAAA,EAE3C,sBAAA,EAEF,MACF,CAEK6C,EAAa,SAIlBvC,EAAmB,QAAU,GAC7BwC,EAAoB,iBAAiB,IACvC,EAAG,CACD9E,EACAiF,EACAH,EACAd,CAAA,CACD,EAEDH,EAAAA,UAAU,IAAM,CACd,MAAMgB,EAAerD,EAAS,QAE9B,GAAKqD,EAIL,IAAI,CAAC9B,EAAc,CACjB6B,EAAA,EACA,MACF,CAEA,GAAI5E,EAAkB,CACpBsC,EAAmB,QAAU,GAC7B0B,EAAc,EAAK,EACnBa,EAAa,MAAA,EACblC,EAAa,EAAK,EAClB,MACF,CAEA,GAAIK,EAAiB,CACnB,MAAMqC,EAAY1D,EAAY,UAAYqB,EACpCoC,EAAmBf,EAAA,EAMzB,GAJEjC,EAAoB,UAAY,WAChC,EAAQT,EAAY,SACpBG,EAAuB,UAAY,KAER,CAC3B,GAAI,CAACsD,EAAkB,CACrB9C,EAAmB,QAAU,GAC7BuC,EAAa,MAAA,EACblC,EAAa,EAAK,EAClB,MACF,CAEIkC,EAAa,SACfvC,EAAmB,QAAU,GAC7BwC,EAAoB,qBAAqB,GAG3C,MACF,CAEA,GAAIO,EAAW,CACb,MAAMO,EACJ9D,EAAuB,UAAY,KAC/B0C,KACA,EAENK,EAAa,MAAA,EACbA,EAAa,gBAAgB,KAAK,EAClCA,EAAa,KAAA,EACblD,EAAY,QAAUqB,EACtBZ,EAAoB,QAAU,MAC9ByC,EAAa,IAAM7B,EACnB6B,EAAa,KAAA,EACbtC,EAAmB,QAAUqD,EAEzBf,EAAa,WAAa,IAC5BA,EAAa,YAAce,EAC3BrD,EAAmB,QAAU,KAEjC,CAOA,GALAD,EAAmB,QAAU8C,EAC7B/C,EAAuB,QAAU,GACjCG,EAAsB,QAAU,GAChCwB,EAAc,EAAK,EAEf,CAACoB,EAAkB,CACrB9C,EAAmB,QAAU,GAC7BuC,EAAa,MAAA,EACblC,EAAa,EAAK,EAClB,MACF,CAEAmC,EAAoBO,EAAY,gBAAkB,UAAU,EAC5D,MACF,CAEA,GAAIvD,EAAuB,UAAY,KAAM,CAC3C,GAAIA,EAAuB,QAAUmB,EAAqB,OAAQ,CAChE,GAAId,EAAkB,QAAS,CAC7BQ,EAAa,EAAK,EAClBqB,EAAc,EAAK,EACnB,MACF,CAEAiB,EAAqBnD,EAAuB,QAAS,aAAa,EAClE,MACF,CAEAO,EAAuB,QAAU,GACjCC,EAAmB,QAAU+B,EAAA,EAC7B1B,EAAa,EAAK,EAClBqB,EAAcK,GAA+B,EAC7C,MACF,CAEA,GAAI,CAACpB,EAAqB,OAAQ,CAChC,GAAIF,EAAa,iBAAkB,CACjCjB,EAAuB,QAAUD,EAAuB,QACxDQ,EAAuB,QAAU,GACjCC,EAAmB,QAAU+B,EAAA,EAC7B1B,EAAa,EAAK,EAClBqB,EAAcK,GAA+B,EAC7C,MACF,CAEAO,EAAA,EACA,MACF,CAEA,GAAI,CAACjD,EAAY,QAAS,CACxBsD,EACE,KAAK,IACHpD,EAAuB,QACvBoB,EAAqB,OAAS,CAAA,EAEhC,aAAA,EAEF,MACF,CAEA,GAAI,CAAClD,GAAkBoC,EAAkB,QAAS,CAChDG,EAAmB,QAAU,GAC7BuC,EAAa,MAAA,EACblC,EAAa,EAAK,EAClB,MACF,CAEIkC,EAAa,SACfvC,EAAmB,QAAU,GAC7BwC,EAAoB,mBAAmB,GAE3C,EAAG,CACD/B,EACAjD,EACAmD,EACAD,EACAjD,EACAC,EACAqE,EACAO,EACAK,EACAH,EACAN,GACAR,CAAA,CACD,EAEDH,EAAAA,UAAU,IAAMe,EAAY,CAACA,CAAU,CAAC,EAExC,MAAMiB,GAAkB5B,EAAAA,YAAY,IAAM,CACxCtB,EAAa,EAAI,EACjBqB,EAAc,EAAK,CACrB,EAAG,CAACA,CAAa,CAAC,EAEZ8B,GAAmB7B,EAAAA,YAAY,IAAM,CACrC5B,EAAuB,SAAWG,EAAsB,SAI5DG,EAAa,EAAK,CACpB,EAAG,CAAC7C,CAAiB,CAAC,EAEhBiG,GAAqB9B,EAAAA,YAAY,IAAM,CAC3C,MAAMY,EAAerD,EAAS,QAE1BqD,GAAgBtC,EAAmB,UAAY,OACjDsC,EAAa,YAActC,EAAmB,QAC9CA,EAAmB,QAAU,MAG3B,GAACD,EAAmB,SAAW,CAACvC,IAIpC+E,EAAoB,SAAS,CAC/B,EAAG,CAAChF,EAAmBC,EAAgB+E,CAAmB,CAAC,EAErDkB,GAAuB/B,EAAAA,YAAY,IAAM,CAC7C,MAAMY,EAAerD,EAAS,QAE1BqD,GAAgBtC,EAAmB,UAAY,OACjDsC,EAAa,YAActC,EAAmB,QAC9CA,EAAmB,QAAU,KAEjC,EAAG,CAACzC,CAAiB,CAAC,EAEhBmG,GAAmBhC,EAAAA,YAAY,IAAM,CACzC,MAAMiC,EACJ9D,EAAoB,UAAY,OAChCJ,EAAwB,QAAQ,SAAW,EAI7C,GAFAQ,EAAsB,QAAU,GAE5B0D,EAAmB,CACrBZ,EAAgB,WAAW,EAC3B,MACF,CAEAC,GAAA,CACF,EAAG,CAACD,EAAiBC,EAAkB,CAAC,EAElCY,GAAmBlC,EAAAA,YAAY,IAAM,CACzCtB,EAAa,EAAK,EAClBqB,EAAc,EAAK,CACrB,EAAG,CAACA,CAAa,CAAC,EACZoC,GAA+BnC,EAAAA,YAClCoC,GAAqC,CACpC1F,IAA2B0F,CAAc,EACzCvD,EAAoB,EAAK,CAC3B,EACA,CAACnC,CAAwB,CAAA,EAG3B,OACEnB,EAAAA,kBAAAA,KAAC,OAAI,UAAW8G,GAAAA,GAAG,eAAgBzG,CAAS,EAAI,GAAG0B,GACjD,SAAA,CAAA9B,EAAAA,kBAAAA,IAAC,QAAA,CACC,IAAK+B,EACL,QAAQ,OACR,YAAW,GACX,iBAAkBwE,GAClB,UAAWD,GACX,OAAQF,GACR,QAASC,GACT,QAASG,GACT,QAASE,EAAA,CAAA,EAGVhF,EACC3B,EAAAA,kBAAAA,KAAA+G,6BAAA,CACE,SAAA,CAAA9G,EAAAA,kBAAAA,IAAC+G,GAAAA,QAAA,CACC,UAAW9F,GACX,OAAQ,CACN,UAAW+C,EAAY,eACvB,SAAUA,EAAY,cACtB,OAAQA,EAAY,YACpB,MAAOA,EAAY,aAAA,EAErB,QAAS,IAAMX,EAAoB,EAAK,EACxC,aAAcA,EACd,mBAAoBsD,GACpB,KAAMvD,GACN,WAAYrC,EAAA,CAAA,EAGdhB,EAAAA,kBAAAA,KAAC,MAAA,CAAI,UAAU,yBAAyB,MAAOgE,GAC7C,SAAA,CAAAhE,EAAAA,kBAAAA,KAAC,MAAA,CAAI,UAAU,sBACb,SAAA,CAAAC,EAAAA,kBAAAA,IAAC,SAAA,CACC,gBAAeoD,GACf,gBAAc,SACd,aAAW,eACX,UAAU,yDACV,QAAS,IAAM,CACbC,EAAqB2D,GAAa,CAACA,CAAQ,CAC7C,EACA,KAAK,SAEL,SAAAhH,EAAAA,kBAAAA,IAACiH,GAAAA,QAAA,CACC,UAAU,qBACV,YAAa,IAAA,CAAA,CACf,CAAA,EAEFjH,EAAAA,kBAAAA,IAAC,SAAA,CAAO,aAAW,SAAS,UAAU,SAAS,KAAK,SAClD,SAAAA,EAAAA,kBAAAA,IAACkH,GAAAA,QAAA,CAAQ,UAAU,qBAAqB,YAAa,KAAM,EAC7D,EACAlH,EAAAA,kBAAAA,IAAC,SAAA,CACC,aAAW,SACX,UAAU,kDACV,SAAUwB,GACV,QAASb,GACT,KAAK,SAEL,SAAAX,EAAAA,kBAAAA,IAACmH,WAAA,CAAU,UAAU,qBAAqB,YAAa,IAAA,CAAM,CAAA,CAAA,EAE/DnH,EAAAA,kBAAAA,IAAC,SAAA,CACC,aAAYmE,GACZ,UAAU,sDACV,QAAS,IAAM,CACb,GAAI1D,EAAsB,CACxBW,KAAsB,CAACZ,CAAoB,EAC3C,MACF,CAEA,MAAM4E,EAAerD,EAAS,QAE9B,GAAI,EAAAxB,GAAoB,CAAC6E,GAAgB,CAAC9B,GAI1C,IAAIjB,EAAuB,UAAY,KAAM,CAC3C,GAAIY,EAAW,CACbJ,EAAmB,QAAU,GAC7BH,EAAkB,QAAU,GAC5BL,EAAuB,QAAU,KACjCO,EAAuB,QAAU,GACjCM,EAAa,EAAK,EAClBqB,EAAc,EAAK,EACnBa,EAAa,MAAA,EACb,MACF,CAEApC,EAAsB,QAAU,SAChCN,EAAkB,QAAU,GAC5BG,EAAmB,QAAU,GAC7B0B,EAAc,EAAI,EAClB,MACF,CAEA,GAAI,CAACa,EAAa,KAAO5B,EAAqB,OAAS,EAAG,CACxDR,EAAsB,QAAU,SAChCN,EAAkB,QAAU,GAC5B8C,EACE,KAAK,IACHpD,EAAuB,QACvBoB,EAAqB,OAAS,CAAA,EAEhC,QAAA,EAEF,MACF,CAEA,GAAI4B,EAAa,OAAQ,CACvBpC,EAAsB,QAAU,SAChCN,EAAkB,QAAU,GAC5BG,EAAmB,QAAU,GAC7BwC,EAAoB,eAAe,EACnC,MACF,CAEAxC,EAAmB,QAAU,GAC7BH,EAAkB,QAAU,GAC5B0C,EAAa,MAAA,EACf,EACA,KAAK,SAEJ,SAAAlB,GAAkBlE,wBAACF,GAAA,CAAA,CAAU,0BAAMG,GAAA,CAAA,CAAS,CAAA,CAAA,EAE/CD,EAAAA,kBAAAA,IAAC,SAAA,CACC,aAAW,UACX,UAAU,kDACV,SAAUyB,GACV,QAASb,GACT,KAAK,SAEL,SAAAZ,EAAAA,kBAAAA,IAACoH,WAAA,CAAS,UAAU,qBAAqB,YAAa,IAAA,CAAM,CAAA,CAAA,EAE7DvG,EACCb,EAAAA,kBAAAA,IAAC,SAAA,CACC,aACEc,EAAe,kBAAoB,mBAErC,UAAU,wDACV,QAASD,EACT,KAAK,SAEJ,SAAAC,EACCd,EAAAA,kBAAAA,IAACqH,GAAAA,QAAA,CACC,UAAU,qBACV,YAAa,IAAA,CAAA,EAGfrH,EAAAA,kBAAAA,IAACsH,GAAAA,QAAA,CACC,UAAU,qBACV,YAAa,IAAA,CAAA,CACf,CAAA,EAGF,IAAA,EACN,EAEAtH,EAAAA,kBAAAA,IAAC,MAAA,CAAI,UAAU,yBAAA,CAA0B,EAEzCD,EAAAA,kBAAAA,KAAC,MAAA,CAAI,UAAU,sBACZ,SAAA,CAAA6D,GAAiB,IAAI,CAAC2D,EAAcC,IACnCxH,EAAAA,kBAAAA,IAACyH,EAAM,SAAN,CACE,SAAAF,CAAA,EADkB,iBAAiBC,CAAiB,EAEvD,CACD,EACDxH,EAAAA,kBAAAA,IAAC,SAAA,CACC,aAAW,QACX,UAAW6G,GAAAA,GACT,mDACAtF,GAAqB,8BAAA,EAEvB,SAAU,CAACD,GACX,QAASD,GACT,KAAK,SAEL,SAAArB,EAAAA,kBAAAA,IAAC0H,GAAAA,QAAA,CACC,UAAU,qBACV,YAAa,IAAA,CAAA,CACf,CAAA,CACF,CAAA,CACF,CAAA,CAAA,CACF,CAAA,CAAA,CACF,EACE,IAAA,EACN,CAEJ"}
1
+ {"version":3,"file":"Player.cjs.js","sources":["../../../src/components/Slide/Player.tsx"],"sourcesContent":["import React, {\n useCallback,\n useEffect,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport {\n EllipsisVertical,\n FilePenLine,\n Maximize,\n RotateCcw,\n RotateCw,\n ScanLine,\n Volume2,\n} from \"lucide-react\";\n\nimport { cn } from \"../../lib/utils\";\nimport MobilePlayerSettingsSheet from \"./MobilePlayerSettingsSheet\";\nimport { DEFAULT_SLIDE_PLAYER_TEXTS } from \"./constants\";\nimport type { SlideAudioItem } from \"./useSlide\";\nimport type {\n SlidePlayerCustomActionContext,\n SlidePlayerCustomActions,\n} from \"./types\";\nimport {\n DEFAULT_MOBILE_VIEW_MODE,\n type MobileViewMode,\n} from \"./utils/mobileScreenMode\";\nimport { toPlayerCustomActionList } from \"./utils/playerCustomActions\";\nimport \"./player.css\";\n\nconst audioPreloadElementCache = new Map<string, HTMLAudioElement>();\n\nexport interface SlidePlayerTexts {\n settingsTitle?: string;\n screenLabel?: string;\n nonFullscreenLabel?: string;\n fullscreenLabel?: string;\n fullscreenHintText?: string;\n}\n\nconst preloadAudioUrl = (url?: string) => {\n if (typeof window === \"undefined\" || !url) {\n return;\n }\n\n if (audioPreloadElementCache.has(url)) {\n return;\n }\n\n // Use a detached audio element so warm-up follows the same media loading\n // path as the visible player instead of relying on link preload hints.\n const audio = window.document.createElement(\"audio\");\n audio.preload = \"auto\";\n audio.setAttribute(\"playsinline\", \"true\");\n audio.src = url;\n audio.load();\n\n audioPreloadElementCache.set(url, audio);\n};\n\nexport type PlayerProps = Omit<React.ComponentProps<\"div\">, \"onEnded\"> & {\n audioList?: SlideAudioItem[];\n currentAudioIndex?: number;\n defaultPlaying?: boolean;\n isPlaybackPaused?: boolean;\n isAutoAdvanceEnabled?: boolean;\n useAutoAdvanceToggle?: boolean;\n onLoadingChange?: (loading: boolean) => void;\n onPrev?: () => void;\n onNext?: () => void;\n onFullscreen?: () => void;\n isFullscreen?: boolean;\n mobileViewMode?: MobileViewMode;\n settingsPortalContainer?: HTMLElement | null;\n onMobileViewModeChange?: (viewMode: MobileViewMode) => void;\n onEnded?: (audioIndex: number) => void;\n onAutoAdvanceToggle?: (enabled: boolean) => void;\n onInteractionToggle?: () => void;\n hasInteraction?: boolean;\n isInteractionOpen?: boolean;\n prevDisabled?: boolean;\n nextDisabled?: boolean;\n showControls?: boolean;\n customActions?: SlidePlayerCustomActions;\n customActionContext?: SlidePlayerCustomActionContext;\n texts?: SlidePlayerTexts;\n};\n\nconst PauseIcon = () => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"34\"\n height=\"34\"\n viewBox=\"0 0 34 34\"\n fill=\"none\"\n >\n <path\n d=\"M16.6667 33.3333C25.8714 33.3333 33.3333 25.8714 33.3333 16.6667C33.3333 7.46192 25.8714 0 16.6667 0C7.46192 0 0 7.46192 0 16.6667C0 25.8714 7.46192 33.3333 16.6667 33.3333Z\"\n fill=\"#0A0A0A\"\n />\n <path d=\"M12 10H16V24H12V10ZM18 10H22V24H18V10Z\" fill=\"white\" />\n </svg>\n);\n\nconst PlayIcon = () => (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"34\"\n height=\"34\"\n viewBox=\"0 0 34 34\"\n fill=\"none\"\n >\n <path\n d=\"M16.6667 33.3333C25.8714 33.3333 33.3333 25.8714 33.3333 16.6667C33.3333 7.46192 25.8714 0 16.6667 0C7.46192 0 0 7.46192 0 16.6667C0 25.8714 7.46192 33.3333 16.6667 33.3333Z\"\n fill=\"#0A0A0A\"\n />\n <path d=\"M13.3333 10L23.3333 16.6667L13.3333 23.3333V10Z\" fill=\"white\" />\n </svg>\n);\n\nconst Player: React.FC<PlayerProps> = ({\n audioList = [],\n className,\n currentAudioIndex = -1,\n defaultPlaying = true,\n isPlaybackPaused = false,\n isAutoAdvanceEnabled = true,\n useAutoAdvanceToggle = false,\n onLoadingChange,\n onPrev,\n onNext,\n onFullscreen,\n isFullscreen = false,\n mobileViewMode = DEFAULT_MOBILE_VIEW_MODE,\n settingsPortalContainer,\n onMobileViewModeChange,\n onEnded,\n onAutoAdvanceToggle,\n onInteractionToggle,\n hasInteraction = false,\n isInteractionOpen = false,\n prevDisabled = false,\n nextDisabled = false,\n showControls = true,\n customActions,\n customActionContext,\n texts,\n ...props\n}) => {\n const audioRef = useRef<HTMLAudioElement | null>(null);\n const previousInteractionOpenRef = useRef(isInteractionOpen);\n const audioSrcRef = useRef<string | null>(null);\n const currentAudioKeyRef = useRef<string | null>(null);\n const currentSegmentIndexRef = useRef(0);\n const waitingSegmentIndexRef = useRef<number | null>(null);\n const currentAudioRef = useRef<SlideAudioItem | undefined>(undefined);\n const currentAudioSegmentsRef = useRef<\n NonNullable<SlideAudioItem[\"audioSegments\"]>\n >([]);\n const wasPlayingBeforeExternalPauseRef = useRef(false);\n const isLoadingRef = useRef(false);\n const isPausedByUserRef = useRef(false);\n const activeSourceTypeRef = useRef<\"url\" | \"segment\" | null>(null);\n const isWaitingForSegmentRef = useRef(false);\n const pendingAutoPlayRef = useRef(false);\n const pendingSeekTimeRef = useRef<number | null>(null);\n const isSwitchingSegmentRef = useRef(false);\n const playbackAccessModeRef = useRef<\n \"unknown\" | \"auto\" | \"manual\" | \"blocked\"\n >(\"unknown\");\n const [isPlaying, setIsPlaying] = useState(defaultPlaying);\n const [isMobileMoreOpen, setIsMobileMoreOpen] = useState(false);\n const currentAudio =\n currentAudioIndex >= 0 ? audioList[currentAudioIndex] : undefined;\n const currentAudioUrl = currentAudio?.audioUrl;\n const currentAudioSegments = useMemo(\n () =>\n [...(currentAudio?.audioSegments ?? [])].sort(\n (prevSegment, nextSegment) =>\n prevSegment.segment_index - nextSegment.segment_index\n ),\n [currentAudio?.audioSegments]\n );\n const customActionList = useMemo(\n () => toPlayerCustomActionList(customActions, customActionContext),\n [customActionContext, customActions]\n );\n const mobileVisibleActionCount = customActionList.length + 5;\n const controlsStyle = useMemo(\n () =>\n ({\n \"--slide-player-mobile-control-count\": String(mobileVisibleActionCount),\n }) as React.CSSProperties,\n [mobileVisibleActionCount]\n );\n const playerTexts = useMemo(\n () => ({\n ...DEFAULT_SLIDE_PLAYER_TEXTS,\n ...texts,\n }),\n [texts]\n );\n const currentAudioKey = useMemo(() => {\n if (!currentAudio) {\n return \"none\";\n }\n\n return (\n currentAudio.audioKey ??\n `${String(currentAudio.sequenceNumber ?? \"none\")}:${String(currentAudio.audioUrl ?? \"\")}`\n );\n }, [currentAudio]);\n const isTogglePlaying = useAutoAdvanceToggle\n ? isAutoAdvanceEnabled\n : isPlaying;\n const toggleAriaLabel = useAutoAdvanceToggle\n ? isAutoAdvanceEnabled\n ? \"Pause autoplay\"\n : \"Play autoplay\"\n : isPlaying\n ? \"Pause\"\n : \"Play\";\n\n useEffect(() => {\n currentAudioRef.current = currentAudio;\n }, [currentAudio]);\n\n useEffect(() => {\n if (showControls) {\n return;\n }\n\n setIsMobileMoreOpen(false);\n }, [showControls]);\n\n useEffect(() => {\n if (!previousInteractionOpenRef.current && isInteractionOpen) {\n setIsMobileMoreOpen(false);\n }\n\n previousInteractionOpenRef.current = isInteractionOpen;\n }, [isInteractionOpen]);\n\n useEffect(() => {\n currentAudioSegmentsRef.current = currentAudioSegments;\n }, [currentAudioSegments]);\n\n useEffect(() => {\n const currentUrl = currentAudio?.audioUrl;\n const nextUrl =\n currentAudioIndex >= 0\n ? audioList[currentAudioIndex + 1]?.audioUrl\n : undefined;\n\n preloadAudioUrl(currentUrl);\n preloadAudioUrl(nextUrl);\n }, [audioList, currentAudio?.audioUrl, currentAudioIndex]);\n\n const updateLoading = useCallback(\n (loading: boolean) => {\n if (isLoadingRef.current === loading) {\n return;\n }\n\n isLoadingRef.current = loading;\n onLoadingChange?.(loading);\n },\n [onLoadingChange]\n );\n\n const isAutoplayBlockedError = useCallback((error: unknown) => {\n if (!(error instanceof DOMException)) {\n return false;\n }\n\n return error.name === \"NotAllowedError\" || error.name === \"SecurityError\";\n }, []);\n\n const canStartPlaybackAutomatically = useCallback(() => {\n return (\n defaultPlaying &&\n !isPlaybackPaused &&\n !isPausedByUserRef.current &&\n playbackAccessModeRef.current !== \"blocked\"\n );\n }, [defaultPlaying, isPlaybackPaused]);\n\n const getSegmentSrc = useCallback((audioData: string) => {\n if (!audioData) {\n return \"\";\n }\n\n if (audioData.startsWith(\"data:\")) {\n return audioData;\n }\n\n return `data:audio/mpeg;base64,${audioData}`;\n }, []);\n\n const getWaitingSegmentSeekTime = useCallback(() => {\n const waitingSegmentIndex = waitingSegmentIndexRef.current;\n\n if (waitingSegmentIndex == null || waitingSegmentIndex <= 0) {\n return 0;\n }\n\n return (\n currentAudioSegmentsRef.current\n .slice(0, waitingSegmentIndex)\n .reduce(\n (totalDurationMs, segment) =>\n totalDurationMs + Math.max(Number(segment.duration_ms ?? 0), 0),\n 0\n ) / 1000\n );\n }, []);\n\n const resetAudio = useCallback(() => {\n const audioElement = audioRef.current;\n\n if (!audioElement) {\n return;\n }\n\n pendingAutoPlayRef.current = false;\n isPausedByUserRef.current = false;\n wasPlayingBeforeExternalPauseRef.current = false;\n activeSourceTypeRef.current = null;\n pendingSeekTimeRef.current = null;\n isWaitingForSegmentRef.current = false;\n isSwitchingSegmentRef.current = false;\n audioElement.pause();\n audioElement.removeAttribute(\"src\");\n audioElement.load();\n audioSrcRef.current = null;\n currentSegmentIndexRef.current = 0;\n waitingSegmentIndexRef.current = null;\n setIsPlaying(false);\n updateLoading(false);\n }, [updateLoading]);\n\n const tryPlayCurrentAudio = useCallback(\n (_reason: string) => {\n const audioElement = audioRef.current;\n\n if (!audioElement) {\n return false;\n }\n\n const playPromise = audioElement.play();\n\n if (playPromise && typeof playPromise.then === \"function\") {\n void playPromise\n .then(() => {\n if (playbackAccessModeRef.current === \"unknown\") {\n playbackAccessModeRef.current = \"auto\";\n }\n\n pendingAutoPlayRef.current = false;\n isSwitchingSegmentRef.current = false;\n })\n .catch((error: unknown) => {\n if (\n playbackAccessModeRef.current === \"unknown\" &&\n isAutoplayBlockedError(error)\n ) {\n // Lock autoplay after the first browser rejection.\n playbackAccessModeRef.current = \"blocked\";\n pendingAutoPlayRef.current = false;\n updateLoading(false);\n }\n\n isSwitchingSegmentRef.current = false;\n setIsPlaying(false);\n });\n }\n\n return true;\n },\n [isAutoplayBlockedError, updateLoading]\n );\n\n const startSegmentPlayback = useCallback(\n (segmentIndex: number, _reason: string) => {\n const audioElement = audioRef.current;\n const segment = currentAudioSegmentsRef.current[segmentIndex];\n\n if (!audioElement || !segment) {\n return false;\n }\n\n const nextAudioSrc = getSegmentSrc(segment.audio_data);\n\n currentSegmentIndexRef.current = segmentIndex;\n waitingSegmentIndexRef.current = null;\n isWaitingForSegmentRef.current = false;\n isSwitchingSegmentRef.current = true;\n const shouldAutoResume = canStartPlaybackAutomatically();\n\n pendingAutoPlayRef.current = shouldAutoResume;\n updateLoading(false);\n\n const hasNewSrc = audioSrcRef.current !== nextAudioSrc;\n\n activeSourceTypeRef.current = \"segment\";\n\n if (hasNewSrc) {\n audioElement.pause();\n audioElement.removeAttribute(\"src\");\n audioElement.load();\n audioSrcRef.current = nextAudioSrc;\n audioElement.src = nextAudioSrc;\n audioElement.load();\n }\n\n pendingSeekTimeRef.current = 0;\n\n if (audioElement.readyState > 0) {\n audioElement.currentTime = 0;\n pendingSeekTimeRef.current = null;\n }\n\n if (!shouldAutoResume) {\n pendingAutoPlayRef.current = false;\n isSwitchingSegmentRef.current = false;\n audioElement.pause();\n setIsPlaying(false);\n return true;\n }\n\n return tryPlayCurrentAudio(`start-segment:${_reason}`);\n },\n [\n canStartPlaybackAutomatically,\n getSegmentSrc,\n tryPlayCurrentAudio,\n updateLoading,\n ]\n );\n\n const finishAudioItem = useCallback(\n (_reason?: string) => {\n pendingAutoPlayRef.current = false;\n isWaitingForSegmentRef.current = false;\n isSwitchingSegmentRef.current = false;\n setIsPlaying(false);\n updateLoading(false);\n\n if (currentAudioIndex >= 0) {\n onEnded?.(currentAudioIndex);\n }\n },\n [currentAudioIndex, onEnded, updateLoading]\n );\n\n const handleSegmentEnded = useCallback(() => {\n const nextSegmentIndex = currentSegmentIndexRef.current + 1;\n const segments = currentAudioSegmentsRef.current;\n const nextSegment = segments[nextSegmentIndex];\n const activeAudio = currentAudioRef.current;\n const hasFinal = segments.some((segment) => segment.is_final);\n\n if (nextSegment) {\n startSegmentPlayback(nextSegmentIndex, \"ended\");\n return;\n }\n\n if (activeAudio?.isAudioStreaming || !hasFinal) {\n currentSegmentIndexRef.current = nextSegmentIndex;\n waitingSegmentIndexRef.current = nextSegmentIndex;\n isWaitingForSegmentRef.current = true;\n pendingAutoPlayRef.current = defaultPlaying;\n setIsPlaying(false);\n updateLoading(true);\n\n return;\n }\n\n finishAudioItem(\"segments-completed\");\n }, [defaultPlaying, finishAudioItem, startSegmentPlayback, updateLoading]);\n\n useEffect(() => {\n if (currentAudioKeyRef.current === currentAudioKey) {\n return;\n }\n\n currentAudioKeyRef.current = currentAudioKey;\n currentSegmentIndexRef.current = 0;\n waitingSegmentIndexRef.current = null;\n isWaitingForSegmentRef.current = false;\n isPausedByUserRef.current = false;\n wasPlayingBeforeExternalPauseRef.current = false;\n pendingAutoPlayRef.current = false;\n isSwitchingSegmentRef.current = false;\n activeSourceTypeRef.current = null;\n audioSrcRef.current = null;\n updateLoading(false);\n\n const audioElement = audioRef.current;\n\n if (!audioElement) {\n return;\n }\n\n audioElement.pause();\n audioElement.removeAttribute(\"src\");\n audioElement.load();\n setIsPlaying(false);\n }, [\n currentAudioIndex,\n currentAudioKey,\n currentAudioSegments.length,\n currentAudioUrl,\n updateLoading,\n ]);\n\n useEffect(() => {\n const audioElement = audioRef.current;\n\n if (!audioElement) {\n return;\n }\n\n if (isPlaybackPaused) {\n wasPlayingBeforeExternalPauseRef.current = Boolean(\n currentAudioRef.current &&\n !isPausedByUserRef.current &&\n (!audioElement.paused ||\n pendingAutoPlayRef.current ||\n waitingSegmentIndexRef.current !== null)\n );\n\n pendingAutoPlayRef.current = false;\n updateLoading(false);\n audioElement.pause();\n setIsPlaying(false);\n return;\n }\n\n if (\n !wasPlayingBeforeExternalPauseRef.current ||\n !currentAudioRef.current ||\n isPausedByUserRef.current\n ) {\n return;\n }\n\n wasPlayingBeforeExternalPauseRef.current = false;\n\n if (waitingSegmentIndexRef.current !== null) {\n if (\n waitingSegmentIndexRef.current < currentAudioSegmentsRef.current.length\n ) {\n startSegmentPlayback(waitingSegmentIndexRef.current, \"external-resume\");\n return;\n }\n\n pendingAutoPlayRef.current = true;\n updateLoading(true);\n return;\n }\n\n if (!audioSrcRef.current && currentAudioSegmentsRef.current.length > 0) {\n startSegmentPlayback(\n Math.min(\n currentSegmentIndexRef.current,\n currentAudioSegmentsRef.current.length - 1\n ),\n \"external-resume-init\"\n );\n return;\n }\n\n if (!audioElement.paused) {\n return;\n }\n\n pendingAutoPlayRef.current = true;\n tryPlayCurrentAudio(\"external-resume\");\n }, [\n isPlaybackPaused,\n startSegmentPlayback,\n tryPlayCurrentAudio,\n updateLoading,\n ]);\n\n useEffect(() => {\n const audioElement = audioRef.current;\n\n if (!audioElement) {\n return;\n }\n\n if (!currentAudio) {\n resetAudio();\n return;\n }\n\n if (isPlaybackPaused) {\n pendingAutoPlayRef.current = false;\n updateLoading(false);\n audioElement.pause();\n setIsPlaying(false);\n return;\n }\n\n if (currentAudioUrl) {\n const hasNewSrc = audioSrcRef.current !== currentAudioUrl;\n const shouldAutoResume = canStartPlaybackAutomatically();\n const shouldKeepSegmentSource =\n activeSourceTypeRef.current === \"segment\" &&\n Boolean(audioSrcRef.current) &&\n waitingSegmentIndexRef.current === null;\n\n if (shouldKeepSegmentSource) {\n if (!shouldAutoResume) {\n pendingAutoPlayRef.current = false;\n audioElement.pause();\n setIsPlaying(false);\n return;\n }\n\n if (audioElement.paused) {\n pendingAutoPlayRef.current = true;\n tryPlayCurrentAudio(\"keep-segment-source\");\n }\n\n return;\n }\n\n if (hasNewSrc) {\n const nextSeekTime =\n waitingSegmentIndexRef.current !== null\n ? getWaitingSegmentSeekTime()\n : 0;\n\n audioElement.pause();\n audioElement.removeAttribute(\"src\");\n audioElement.load();\n audioSrcRef.current = currentAudioUrl;\n activeSourceTypeRef.current = \"url\";\n audioElement.src = currentAudioUrl;\n audioElement.load();\n pendingSeekTimeRef.current = nextSeekTime;\n\n if (audioElement.readyState > 0) {\n audioElement.currentTime = nextSeekTime;\n pendingSeekTimeRef.current = null;\n }\n }\n\n pendingAutoPlayRef.current = shouldAutoResume;\n isWaitingForSegmentRef.current = false;\n isSwitchingSegmentRef.current = false;\n updateLoading(false);\n\n if (!shouldAutoResume) {\n pendingAutoPlayRef.current = false;\n audioElement.pause();\n setIsPlaying(false);\n return;\n }\n\n tryPlayCurrentAudio(hasNewSrc ? \"sync-url-init\" : \"sync-url\");\n return;\n }\n\n if (waitingSegmentIndexRef.current !== null) {\n if (waitingSegmentIndexRef.current < currentAudioSegments.length) {\n if (isPausedByUserRef.current) {\n setIsPlaying(false);\n updateLoading(false);\n return;\n }\n\n startSegmentPlayback(waitingSegmentIndexRef.current, \"wait-resume\");\n return;\n }\n\n isWaitingForSegmentRef.current = true;\n pendingAutoPlayRef.current = canStartPlaybackAutomatically();\n setIsPlaying(false);\n updateLoading(canStartPlaybackAutomatically());\n return;\n }\n\n if (!currentAudioSegments.length) {\n if (currentAudio.isAudioStreaming) {\n waitingSegmentIndexRef.current = currentSegmentIndexRef.current;\n isWaitingForSegmentRef.current = true;\n pendingAutoPlayRef.current = canStartPlaybackAutomatically();\n setIsPlaying(false);\n updateLoading(canStartPlaybackAutomatically());\n return;\n }\n\n resetAudio();\n return;\n }\n\n if (!audioSrcRef.current) {\n startSegmentPlayback(\n Math.min(\n currentSegmentIndexRef.current,\n currentAudioSegments.length - 1\n ),\n \"effect-init\"\n );\n return;\n }\n\n if (!defaultPlaying || isPausedByUserRef.current) {\n pendingAutoPlayRef.current = false;\n audioElement.pause();\n setIsPlaying(false);\n return;\n }\n\n if (audioElement.paused) {\n pendingAutoPlayRef.current = true;\n tryPlayCurrentAudio(\"sync-paused-retry\");\n }\n }, [\n currentAudio,\n currentAudioIndex,\n currentAudioSegments,\n currentAudioUrl,\n defaultPlaying,\n isPlaybackPaused,\n canStartPlaybackAutomatically,\n resetAudio,\n startSegmentPlayback,\n tryPlayCurrentAudio,\n getWaitingSegmentSeekTime,\n updateLoading,\n ]);\n\n useEffect(() => resetAudio, [resetAudio]);\n\n const handleAudioPlay = useCallback(() => {\n setIsPlaying(true);\n updateLoading(false);\n }, [updateLoading]);\n\n const handleAudioPause = useCallback(() => {\n if (isWaitingForSegmentRef.current || isSwitchingSegmentRef.current) {\n return;\n }\n\n setIsPlaying(false);\n }, [currentAudioIndex]);\n\n const handleAudioCanPlay = useCallback(() => {\n const audioElement = audioRef.current;\n\n if (audioElement && pendingSeekTimeRef.current !== null) {\n audioElement.currentTime = pendingSeekTimeRef.current;\n pendingSeekTimeRef.current = null;\n }\n\n if (!pendingAutoPlayRef.current || !defaultPlaying) {\n return;\n }\n\n tryPlayCurrentAudio(\"canplay\");\n }, [currentAudioIndex, defaultPlaying, tryPlayCurrentAudio]);\n\n const handleLoadedMetadata = useCallback(() => {\n const audioElement = audioRef.current;\n\n if (audioElement && pendingSeekTimeRef.current !== null) {\n audioElement.currentTime = pendingSeekTimeRef.current;\n pendingSeekTimeRef.current = null;\n }\n }, [currentAudioIndex]);\n\n const handleAudioEnded = useCallback(() => {\n const shouldFinishAsUrl =\n activeSourceTypeRef.current === \"url\" ||\n currentAudioSegmentsRef.current.length === 0;\n\n isSwitchingSegmentRef.current = false;\n\n if (shouldFinishAsUrl) {\n finishAudioItem(\"url-ended\");\n return;\n }\n\n handleSegmentEnded();\n }, [finishAudioItem, handleSegmentEnded]);\n\n const handleAudioError = useCallback(() => {\n setIsPlaying(false);\n updateLoading(false);\n }, [updateLoading]);\n const handleMobileViewModeChange = useCallback(\n (nextViewMode: MobileViewMode) => {\n onMobileViewModeChange?.(nextViewMode);\n setIsMobileMoreOpen(false);\n },\n [onMobileViewModeChange]\n );\n\n return (\n <div className={cn(\"slide-player\", className)} {...props}>\n <audio\n ref={audioRef}\n preload=\"auto\"\n playsInline\n onLoadedMetadata={handleLoadedMetadata}\n onCanPlay={handleAudioCanPlay}\n onPlay={handleAudioPlay}\n onPause={handleAudioPause}\n onEnded={handleAudioEnded}\n onError={handleAudioError}\n />\n\n {showControls ? (\n <>\n <MobilePlayerSettingsSheet\n container={settingsPortalContainer}\n labels={{\n fullscreen: playerTexts.fullscreenLabel,\n nonFullscreen: playerTexts.nonFullscreenLabel,\n screen: playerTexts.screenLabel,\n title: playerTexts.settingsTitle,\n }}\n onClose={() => setIsMobileMoreOpen(false)}\n onOpenChange={setIsMobileMoreOpen}\n onViewModeChange={handleMobileViewModeChange}\n open={isMobileMoreOpen}\n viewMode={mobileViewMode}\n />\n\n <div className=\"slide-player__controls\" style={controlsStyle}>\n <div className=\"slide-player__group\">\n <button\n aria-expanded={isMobileMoreOpen}\n aria-haspopup=\"dialog\"\n aria-label=\"More options\"\n className=\"slide-player__action slide-player__action--mobile-more\"\n onClick={() => {\n setIsMobileMoreOpen((prevOpen) => !prevOpen);\n }}\n type=\"button\"\n >\n <EllipsisVertical\n className=\"slide-player__icon\"\n strokeWidth={2.25}\n />\n </button>\n <button aria-label=\"Volume\" className=\"hidden\" type=\"button\">\n <Volume2 className=\"slide-player__icon\" strokeWidth={2.25} />\n </button>\n <button\n aria-label=\"Rewind\"\n className=\"slide-player__action slide-player__action--prev\"\n disabled={prevDisabled}\n onClick={onPrev}\n type=\"button\"\n >\n <RotateCcw className=\"slide-player__icon\" strokeWidth={2.25} />\n </button>\n <button\n aria-label={toggleAriaLabel}\n className=\"slide-player__toggle slide-player__toggle--playback\"\n onClick={() => {\n if (useAutoAdvanceToggle) {\n onAutoAdvanceToggle?.(!isAutoAdvanceEnabled);\n return;\n }\n\n const audioElement = audioRef.current;\n\n if (isPlaybackPaused || !audioElement || !currentAudio) {\n return;\n }\n\n if (waitingSegmentIndexRef.current !== null) {\n if (isPlaying) {\n pendingAutoPlayRef.current = false;\n isPausedByUserRef.current = true;\n waitingSegmentIndexRef.current = null;\n isWaitingForSegmentRef.current = false;\n setIsPlaying(false);\n updateLoading(false);\n audioElement.pause();\n return;\n }\n\n playbackAccessModeRef.current = \"manual\";\n isPausedByUserRef.current = false;\n pendingAutoPlayRef.current = true;\n updateLoading(true);\n return;\n }\n\n if (!audioElement.src && currentAudioSegments.length > 0) {\n playbackAccessModeRef.current = \"manual\";\n isPausedByUserRef.current = false;\n startSegmentPlayback(\n Math.min(\n currentSegmentIndexRef.current,\n currentAudioSegments.length - 1\n ),\n \"toggle\"\n );\n return;\n }\n\n if (audioElement.paused) {\n playbackAccessModeRef.current = \"manual\";\n isPausedByUserRef.current = false;\n pendingAutoPlayRef.current = true;\n tryPlayCurrentAudio(\"toggle-resume\");\n return;\n }\n\n pendingAutoPlayRef.current = false;\n isPausedByUserRef.current = true;\n audioElement.pause();\n }}\n type=\"button\"\n >\n {isTogglePlaying ? <PauseIcon /> : <PlayIcon />}\n </button>\n <button\n aria-label=\"Forward\"\n className=\"slide-player__action slide-player__action--next\"\n disabled={nextDisabled}\n onClick={onNext}\n type=\"button\"\n >\n <RotateCw className=\"slide-player__icon\" strokeWidth={2.25} />\n </button>\n {onFullscreen ? (\n <button\n aria-label={\n isFullscreen ? \"Exit fullscreen\" : \"Enter fullscreen\"\n }\n className=\"slide-player__action slide-player__action--fullscreen\"\n onClick={onFullscreen}\n type=\"button\"\n >\n {isFullscreen ? (\n <ScanLine\n className=\"slide-player__icon\"\n strokeWidth={2.25}\n />\n ) : (\n <Maximize\n className=\"slide-player__icon\"\n strokeWidth={2.25}\n />\n )}\n </button>\n ) : null}\n </div>\n\n <div className=\"slide-player__separator\" />\n\n <div className=\"slide-player__group\">\n {customActionList.map((customAction, customActionIndex) => (\n <React.Fragment key={`custom-action-${customActionIndex}`}>\n {customAction}\n </React.Fragment>\n ))}\n <button\n aria-label=\"Notes\"\n className={cn(\n \"slide-player__action slide-player__action--notes\",\n isInteractionOpen && \"slide-player__action--active\"\n )}\n disabled={!hasInteraction}\n onClick={onInteractionToggle}\n type=\"button\"\n >\n <FilePenLine\n className=\"slide-player__icon\"\n strokeWidth={2.25}\n />\n </button>\n </div>\n </div>\n </>\n ) : null}\n </div>\n );\n};\n\nexport default Player;\n"],"names":["audioPreloadElementCache","preloadAudioUrl","url","audio","PauseIcon","jsxs","jsx","PlayIcon","Player","audioList","className","currentAudioIndex","defaultPlaying","isPlaybackPaused","isAutoAdvanceEnabled","useAutoAdvanceToggle","onLoadingChange","onPrev","onNext","onFullscreen","isFullscreen","mobileViewMode","DEFAULT_MOBILE_VIEW_MODE","settingsPortalContainer","onMobileViewModeChange","onEnded","onAutoAdvanceToggle","onInteractionToggle","hasInteraction","isInteractionOpen","prevDisabled","nextDisabled","showControls","customActions","customActionContext","texts","props","audioRef","useRef","previousInteractionOpenRef","audioSrcRef","currentAudioKeyRef","currentSegmentIndexRef","waitingSegmentIndexRef","currentAudioRef","currentAudioSegmentsRef","wasPlayingBeforeExternalPauseRef","isLoadingRef","isPausedByUserRef","activeSourceTypeRef","isWaitingForSegmentRef","pendingAutoPlayRef","pendingSeekTimeRef","isSwitchingSegmentRef","playbackAccessModeRef","isPlaying","setIsPlaying","useState","isMobileMoreOpen","setIsMobileMoreOpen","currentAudio","currentAudioUrl","currentAudioSegments","useMemo","prevSegment","nextSegment","customActionList","toPlayerCustomActionList","mobileVisibleActionCount","controlsStyle","playerTexts","DEFAULT_SLIDE_PLAYER_TEXTS","currentAudioKey","isTogglePlaying","toggleAriaLabel","useEffect","currentUrl","nextUrl","updateLoading","useCallback","loading","isAutoplayBlockedError","error","canStartPlaybackAutomatically","getSegmentSrc","audioData","getWaitingSegmentSeekTime","waitingSegmentIndex","totalDurationMs","segment","resetAudio","audioElement","tryPlayCurrentAudio","_reason","playPromise","startSegmentPlayback","segmentIndex","nextAudioSrc","shouldAutoResume","hasNewSrc","finishAudioItem","handleSegmentEnded","nextSegmentIndex","segments","activeAudio","hasFinal","nextSeekTime","handleAudioPlay","handleAudioPause","handleAudioCanPlay","handleLoadedMetadata","handleAudioEnded","shouldFinishAsUrl","handleAudioError","handleMobileViewModeChange","nextViewMode","cn","Fragment","MobilePlayerSettingsSheet","prevOpen","EllipsisVertical","Volume2","RotateCcw","RotateCw","ScanLine","Maximize","customAction","customActionIndex","React","FilePenLine"],"mappings":"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"}