@aigamo/nostalgic-diva 1.14.2 → 1.14.4

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 (93) hide show
  1. package/README.md +6 -6
  2. package/dist/AudioPlayer-BQ2Gp2RB.cjs +2 -0
  3. package/dist/AudioPlayer-BQ2Gp2RB.cjs.map +1 -0
  4. package/dist/AudioPlayer-DNXHlZIH.js +35 -0
  5. package/dist/AudioPlayer-DNXHlZIH.js.map +1 -0
  6. package/dist/DailymotionPlayer-CXT7vKuY.cjs +2 -0
  7. package/dist/DailymotionPlayer-CXT7vKuY.cjs.map +1 -0
  8. package/dist/DailymotionPlayer-_t0loHUn.js +65 -0
  9. package/dist/DailymotionPlayer-_t0loHUn.js.map +1 -0
  10. package/dist/NiconicoPlayer-CnpFGMfb.cjs +2 -0
  11. package/dist/NiconicoPlayer-CnpFGMfb.cjs.map +1 -0
  12. package/dist/NiconicoPlayer-DwIPqj04.js +36 -0
  13. package/dist/NiconicoPlayer-DwIPqj04.js.map +1 -0
  14. package/dist/PlayerContainer-D6lZZcOV.js +57 -0
  15. package/dist/PlayerContainer-D6lZZcOV.js.map +1 -0
  16. package/dist/PlayerContainer-DjUsAqJ9.cjs +2 -0
  17. package/dist/PlayerContainer-DjUsAqJ9.cjs.map +1 -0
  18. package/dist/SoundCloudPlayer-BvGSbQ8G.cjs +2 -0
  19. package/dist/SoundCloudPlayer-BvGSbQ8G.cjs.map +1 -0
  20. package/dist/SoundCloudPlayer-T1Wwq5XY.js +43 -0
  21. package/dist/SoundCloudPlayer-T1Wwq5XY.js.map +1 -0
  22. package/dist/TwitchPlayer-BAaGGA_S.cjs +2 -0
  23. package/dist/TwitchPlayer-BAaGGA_S.cjs.map +1 -0
  24. package/dist/TwitchPlayer-yP3VMBNJ.js +40 -0
  25. package/dist/TwitchPlayer-yP3VMBNJ.js.map +1 -0
  26. package/dist/VimeoPlayer-BaKHBuBZ.js +43 -0
  27. package/dist/VimeoPlayer-BaKHBuBZ.js.map +1 -0
  28. package/dist/VimeoPlayer-nBu7bvUc.cjs +2 -0
  29. package/dist/VimeoPlayer-nBu7bvUc.cjs.map +1 -0
  30. package/dist/YouTubePlayer-CMk3QdKb.cjs +2 -0
  31. package/dist/YouTubePlayer-CMk3QdKb.cjs.map +1 -0
  32. package/dist/YouTubePlayer-N4BR2ey5.js +39 -0
  33. package/dist/YouTubePlayer-N4BR2ey5.js.map +1 -0
  34. package/dist/components/AudioPlayer.d.ts +2 -2
  35. package/dist/components/DailymotionPlayer.d.ts +2 -2
  36. package/dist/components/NiconicoPlayer.d.ts +2 -2
  37. package/dist/components/NostalgicDiva.d.ts +3 -3
  38. package/dist/components/NostalgicDivaProvider.d.ts +4 -4
  39. package/dist/components/PlayerContainer.d.ts +3 -3
  40. package/dist/components/SoundCloudPlayer.d.ts +2 -2
  41. package/dist/components/TwitchPlayer.d.ts +2 -2
  42. package/dist/components/VimeoPlayer.d.ts +2 -2
  43. package/dist/components/YouTubePlayer.d.ts +2 -2
  44. package/dist/components/defineNostalgicDiva.d.ts +1 -1
  45. package/dist/controllers/NullPlayerController.d.ts +18 -0
  46. package/dist/{ensureScriptLoaded-3ca22ba1.js → ensureScriptLoaded-BGJeoRZ3.js} +2 -2
  47. package/dist/{ensureScriptLoaded-3ca22ba1.js.map → ensureScriptLoaded-BGJeoRZ3.js.map} +1 -1
  48. package/dist/{ensureScriptLoaded-3ea72c12.cjs → ensureScriptLoaded-bFj2T2cD.cjs} +2 -2
  49. package/dist/{ensureScriptLoaded-3ea72c12.cjs.map → ensureScriptLoaded-bFj2T2cD.cjs.map} +1 -1
  50. package/dist/index-31Npatuy.cjs +2 -0
  51. package/dist/index-31Npatuy.cjs.map +1 -0
  52. package/dist/index-TYv_5PaK.js +1049 -0
  53. package/dist/index-TYv_5PaK.js.map +1 -0
  54. package/dist/index.cjs.js +1 -1
  55. package/dist/index.es.js +17 -19
  56. package/dist/index.es.js.map +1 -1
  57. package/package.json +2 -2
  58. package/dist/AudioPlayer-0fc3aec9.cjs +0 -2
  59. package/dist/AudioPlayer-0fc3aec9.cjs.map +0 -1
  60. package/dist/AudioPlayer-3c9c0ab0.js +0 -38
  61. package/dist/AudioPlayer-3c9c0ab0.js.map +0 -1
  62. package/dist/DailymotionPlayer-2b0ae1d4.js +0 -72
  63. package/dist/DailymotionPlayer-2b0ae1d4.js.map +0 -1
  64. package/dist/DailymotionPlayer-a347455f.cjs +0 -2
  65. package/dist/DailymotionPlayer-a347455f.cjs.map +0 -1
  66. package/dist/NiconicoPlayer-b186513a.cjs +0 -2
  67. package/dist/NiconicoPlayer-b186513a.cjs.map +0 -1
  68. package/dist/NiconicoPlayer-ee3416be.js +0 -39
  69. package/dist/NiconicoPlayer-ee3416be.js.map +0 -1
  70. package/dist/PlayerContainer-d881dad9.cjs +0 -2
  71. package/dist/PlayerContainer-d881dad9.cjs.map +0 -1
  72. package/dist/PlayerContainer-fb66b2d4.js +0 -57
  73. package/dist/PlayerContainer-fb66b2d4.js.map +0 -1
  74. package/dist/SoundCloudPlayer-5c2ff9b5.cjs +0 -2
  75. package/dist/SoundCloudPlayer-5c2ff9b5.cjs.map +0 -1
  76. package/dist/SoundCloudPlayer-a10fbe35.js +0 -46
  77. package/dist/SoundCloudPlayer-a10fbe35.js.map +0 -1
  78. package/dist/TwitchPlayer-34462b63.js +0 -46
  79. package/dist/TwitchPlayer-34462b63.js.map +0 -1
  80. package/dist/TwitchPlayer-482a75c3.cjs +0 -2
  81. package/dist/TwitchPlayer-482a75c3.cjs.map +0 -1
  82. package/dist/VimeoPlayer-98f05ffd.cjs +0 -2
  83. package/dist/VimeoPlayer-98f05ffd.cjs.map +0 -1
  84. package/dist/VimeoPlayer-c47ff6e7.js +0 -46
  85. package/dist/VimeoPlayer-c47ff6e7.js.map +0 -1
  86. package/dist/YouTubePlayer-36d78308.js +0 -42
  87. package/dist/YouTubePlayer-36d78308.js.map +0 -1
  88. package/dist/YouTubePlayer-a968fb4b.cjs +0 -2
  89. package/dist/YouTubePlayer-a968fb4b.cjs.map +0 -1
  90. package/dist/index-1f3c7b69.js +0 -1135
  91. package/dist/index-1f3c7b69.js.map +0 -1
  92. package/dist/index-659ff88f.cjs +0 -2
  93. package/dist/index-659ff88f.cjs.map +0 -1
package/README.md CHANGED
@@ -20,14 +20,14 @@ import {
20
20
  } from '@aigamo/nostalgic-diva';
21
21
 
22
22
  // Callbacks
23
- const handleError = React.useCallback(() => {}, []);
24
- const handlePlay = React.useCallback(() => {}, []);
25
- const handlePause = React.useCallback(() => {}, []);
26
- const handleEnded = React.useCallback(() => {}, []);
27
- const handleTimeUpdate = React.useCallback(() => {}, []);
23
+ const handleError = useCallback(() => {}, []);
24
+ const handlePlay = useCallback(() => {}, []);
25
+ const handlePause = useCallback(() => {}, []);
26
+ const handleEnded = useCallback(() => {}, []);
27
+ const handleTimeUpdate = useCallback(() => {}, []);
28
28
 
29
29
  // Options
30
- const options = React.useMemo(
30
+ const options = useMemo(
31
31
  (): PlayerOptions => ({
32
32
  onError: handleError,
33
33
  onPlay: handlePlay,
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react"),o=require("./index-31Npatuy.cjs"),u=require("./PlayerContainer-DjUsAqJ9.cjs"),c=e.memo(({...t})=>{const{logger:l}=t;l.log(o.LogLevel.Debug,"AudioPlayer");const a=e.useCallback(r=>Promise.resolve(r),[]);return e.createElement(u.PlayerContainer,{...t,loadScript:void 0,playerFactory:a,controllerFactory:o.AudioPlayerController},(r,n)=>e.createElement("audio",{ref:r,src:n,style:{width:"100%",height:"100%"},preload:"auto",autoPlay:!0,controls:!0}))});exports.default=c;
2
+ //# sourceMappingURL=AudioPlayer-BQ2Gp2RB.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AudioPlayer-BQ2Gp2RB.cjs","sources":["../src/components/AudioPlayer.tsx"],"sourcesContent":["import React, { ReactElement, memo, useCallback } from 'react';\n\nimport { AudioPlayerController } from '../controllers/AudioPlayerController';\nimport { LogLevel } from '../controllers/Logger';\nimport { PlayerContainer, PlayerProps } from './PlayerContainer';\n\nconst AudioPlayer = memo(({ ...props }: PlayerProps): ReactElement => {\n\tconst { logger } = props;\n\n\tlogger.log(LogLevel.Debug, 'AudioPlayer');\n\n\tconst playerFactory = useCallback(\n\t\t(element: HTMLAudioElement): Promise<HTMLAudioElement> => {\n\t\t\treturn Promise.resolve(element);\n\t\t},\n\t\t[],\n\t);\n\n\treturn (\n\t\t<PlayerContainer\n\t\t\t{...props}\n\t\t\tloadScript={undefined}\n\t\t\tplayerFactory={playerFactory}\n\t\t\tcontrollerFactory={AudioPlayerController}\n\t\t>\n\t\t\t{(elementRef, videoId): ReactElement => (\n\t\t\t\t<audio\n\t\t\t\t\tref={elementRef}\n\t\t\t\t\tsrc={videoId}\n\t\t\t\t\tstyle={{ width: '100%', height: '100%' }}\n\t\t\t\t\tpreload=\"auto\"\n\t\t\t\t\tautoPlay\n\t\t\t\t\tcontrols\n\t\t\t\t/>\n\t\t\t)}\n\t\t</PlayerContainer>\n\t);\n});\n\nexport default AudioPlayer;\n"],"names":["AudioPlayer","memo","props","logger","LogLevel","playerFactory","useCallback","element","React","PlayerContainer","AudioPlayerController","elementRef","videoId"],"mappings":"uLAMMA,EAAcC,EAAAA,KAAK,CAAC,CAAE,GAAGC,KAAuC,CACrE,KAAM,CAAE,OAAAC,GAAWD,EAEnBC,EAAO,IAAIC,WAAS,MAAO,aAAa,EAExC,MAAMC,EAAgBC,EAAAA,YACpBC,GACO,QAAQ,QAAQA,CAAO,EAE/B,CAAA,CAAC,EAGF,OACCC,EAAA,cAACC,EAAAA,gBAAA,CACC,GAAGP,EACJ,WAAY,OACZ,cAAAG,EACA,kBAAmBK,EAAAA,qBAAA,EAElB,CAACC,EAAYC,IACbJ,EAAA,cAAC,QAAA,CACA,IAAKG,EACL,IAAKC,EACL,MAAO,CAAE,MAAO,OAAQ,OAAQ,MAAA,EAChC,QAAQ,OACR,SAAQ,GACR,SAAQ,EAAA,CAAA,CACT,CAIJ,CAAC"}
@@ -0,0 +1,35 @@
1
+ import o, { memo as c, useCallback as i } from "react";
2
+ import { L as u, A as n } from "./index-TYv_5PaK.js";
3
+ import { P as s } from "./PlayerContainer-D6lZZcOV.js";
4
+ const P = c(({ ...r }) => {
5
+ const { logger: t } = r;
6
+ t.log(u.Debug, "AudioPlayer");
7
+ const a = i(
8
+ (e) => Promise.resolve(e),
9
+ []
10
+ );
11
+ return /* @__PURE__ */ o.createElement(
12
+ s,
13
+ {
14
+ ...r,
15
+ loadScript: void 0,
16
+ playerFactory: a,
17
+ controllerFactory: n
18
+ },
19
+ (e, l) => /* @__PURE__ */ o.createElement(
20
+ "audio",
21
+ {
22
+ ref: e,
23
+ src: l,
24
+ style: { width: "100%", height: "100%" },
25
+ preload: "auto",
26
+ autoPlay: !0,
27
+ controls: !0
28
+ }
29
+ )
30
+ );
31
+ });
32
+ export {
33
+ P as default
34
+ };
35
+ //# sourceMappingURL=AudioPlayer-DNXHlZIH.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AudioPlayer-DNXHlZIH.js","sources":["../src/components/AudioPlayer.tsx"],"sourcesContent":["import React, { ReactElement, memo, useCallback } from 'react';\n\nimport { AudioPlayerController } from '../controllers/AudioPlayerController';\nimport { LogLevel } from '../controllers/Logger';\nimport { PlayerContainer, PlayerProps } from './PlayerContainer';\n\nconst AudioPlayer = memo(({ ...props }: PlayerProps): ReactElement => {\n\tconst { logger } = props;\n\n\tlogger.log(LogLevel.Debug, 'AudioPlayer');\n\n\tconst playerFactory = useCallback(\n\t\t(element: HTMLAudioElement): Promise<HTMLAudioElement> => {\n\t\t\treturn Promise.resolve(element);\n\t\t},\n\t\t[],\n\t);\n\n\treturn (\n\t\t<PlayerContainer\n\t\t\t{...props}\n\t\t\tloadScript={undefined}\n\t\t\tplayerFactory={playerFactory}\n\t\t\tcontrollerFactory={AudioPlayerController}\n\t\t>\n\t\t\t{(elementRef, videoId): ReactElement => (\n\t\t\t\t<audio\n\t\t\t\t\tref={elementRef}\n\t\t\t\t\tsrc={videoId}\n\t\t\t\t\tstyle={{ width: '100%', height: '100%' }}\n\t\t\t\t\tpreload=\"auto\"\n\t\t\t\t\tautoPlay\n\t\t\t\t\tcontrols\n\t\t\t\t/>\n\t\t\t)}\n\t\t</PlayerContainer>\n\t);\n});\n\nexport default AudioPlayer;\n"],"names":["AudioPlayer","memo","props","logger","LogLevel","playerFactory","useCallback","element","React","PlayerContainer","AudioPlayerController","elementRef","videoId"],"mappings":";;;AAMA,MAAMA,IAAcC,EAAK,CAAC,EAAE,GAAGC,QAAuC;AACrE,QAAM,EAAE,QAAAC,MAAWD;AAEnB,EAAAC,EAAO,IAAIC,EAAS,OAAO,aAAa;AAExC,QAAMC,IAAgBC;AAAA,IACrB,CAACC,MACO,QAAQ,QAAQA,CAAO;AAAA,IAE/B,CAAA;AAAA,EAAC;AAGF,SACC,gBAAAC,EAAA;AAAA,IAACC;AAAA,IAAA;AAAA,MACC,GAAGP;AAAA,MACJ,YAAY;AAAA,MACZ,eAAAG;AAAA,MACA,mBAAmBK;AAAA,IAAA;AAAA,IAElB,CAACC,GAAYC,MACb,gBAAAJ,EAAA;AAAA,MAAC;AAAA,MAAA;AAAA,QACA,KAAKG;AAAA,QACL,KAAKC;AAAA,QACL,OAAO,EAAE,OAAO,QAAQ,QAAQ,OAAA;AAAA,QAChC,SAAQ;AAAA,QACR,UAAQ;AAAA,QACR,UAAQ;AAAA,MAAA;AAAA,IAAA;AAAA,EACT;AAIJ,CAAC;"}
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const r=require("react"),o=require("./index-31Npatuy.cjs"),u=require("./ensureScriptLoaded-bFj2T2cD.cjs"),y=require("./PlayerContainer-DjUsAqJ9.cjs"),s=r.memo(({options:e,...n})=>{const{logger:a}=n;a.log(o.LogLevel.Debug,"DailymotionPlayer");const i=r.useCallback(async()=>{await u.ensureScriptLoaded("https://api.dmcdn.net/all.js",a)},[a]),c=r.useCallback((t,l)=>Promise.resolve(new DM.player(t,{video:l,width:"100%",height:"100%",events:{apiready:()=>{e?.onLoaded?.({id:l})},seeked:()=>{e?.onTimeUpdate?.({duration:0,percent:0,seconds:0})},video_end:()=>{e?.onEnded?.()},durationchange:()=>{},pause:()=>{e?.onPause?.()},playing:()=>{e?.onPlay?.()},waiting:()=>{},error:d=>{e?.onError?.(d)}}})),[e]);return r.createElement(y.PlayerContainer,{...n,options:e,loadScript:i,playerFactory:c,controllerFactory:o.DailymotionPlayerController},t=>r.createElement("div",{style:{width:"100%",height:"100%"}},r.createElement("div",{ref:t})))});exports.default=s;
2
+ //# sourceMappingURL=DailymotionPlayer-CXT7vKuY.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DailymotionPlayer-CXT7vKuY.cjs","sources":["../src/components/DailymotionPlayer.tsx"],"sourcesContent":["import React, { ReactElement, memo, useCallback } from 'react';\n\nimport { DailymotionPlayerController } from '../controllers/DailymotionPlayerController';\nimport { LogLevel } from '../controllers/Logger';\nimport { ensureScriptLoaded } from '../controllers/ensureScriptLoaded';\nimport { PlayerContainer, PlayerProps } from './PlayerContainer';\n\nconst DailymotionPlayer = memo(\n\t({ options, ...props }: PlayerProps): ReactElement => {\n\t\tconst { logger } = props;\n\n\t\tlogger.log(LogLevel.Debug, 'DailymotionPlayer');\n\n\t\tconst loadScript = useCallback(async () => {\n\t\t\tawait ensureScriptLoaded('https://api.dmcdn.net/all.js', logger);\n\t\t}, [logger]);\n\n\t\tconst playerFactory = useCallback(\n\t\t\t(element: HTMLDivElement, videoId: string): Promise<DM.player> => {\n\t\t\t\treturn Promise.resolve(\n\t\t\t\t\tnew DM.player(element, {\n\t\t\t\t\t\tvideo: videoId,\n\t\t\t\t\t\twidth: '100%',\n\t\t\t\t\t\theight: '100%',\n\t\t\t\t\t\tevents: {\n\t\t\t\t\t\t\tapiready: (): void => {\n\t\t\t\t\t\t\t\toptions?.onLoaded?.({ id: videoId });\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tseeked: (): void => {\n\t\t\t\t\t\t\t\toptions?.onTimeUpdate?.({\n\t\t\t\t\t\t\t\t\tduration: 0,\n\t\t\t\t\t\t\t\t\tpercent: 0,\n\t\t\t\t\t\t\t\t\tseconds: 0,\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tvideo_end: (): void => {\n\t\t\t\t\t\t\t\toptions?.onEnded?.();\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tdurationchange: (): void => {},\n\t\t\t\t\t\t\tpause: (): void => {\n\t\t\t\t\t\t\t\toptions?.onPause?.();\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tplaying: (): void => {\n\t\t\t\t\t\t\t\toptions?.onPlay?.();\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\twaiting: (): void => {},\n\t\t\t\t\t\t\terror: (error): void => {\n\t\t\t\t\t\t\t\toptions?.onError?.(error);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t}),\n\t\t\t\t);\n\t\t\t},\n\t\t\t[options],\n\t\t);\n\n\t\treturn (\n\t\t\t<PlayerContainer\n\t\t\t\t{...props}\n\t\t\t\toptions={options}\n\t\t\t\tloadScript={loadScript}\n\t\t\t\tplayerFactory={playerFactory}\n\t\t\t\tcontrollerFactory={DailymotionPlayerController}\n\t\t\t>\n\t\t\t\t{(elementRef): ReactElement => (\n\t\t\t\t\t<div style={{ width: '100%', height: '100%' }}>\n\t\t\t\t\t\t<div ref={elementRef} />\n\t\t\t\t\t</div>\n\t\t\t\t)}\n\t\t\t</PlayerContainer>\n\t\t);\n\t},\n);\n\nexport default DailymotionPlayer;\n"],"names":["DailymotionPlayer","memo","options","props","logger","LogLevel","loadScript","useCallback","ensureScriptLoaded","playerFactory","element","videoId","error","React","PlayerContainer","DailymotionPlayerController","elementRef"],"mappings":"sOAOMA,EAAoBC,EAAAA,KACzB,CAAC,CAAE,QAAAC,EAAS,GAAGC,KAAuC,CACrD,KAAM,CAAE,OAAAC,GAAWD,EAEnBC,EAAO,IAAIC,WAAS,MAAO,mBAAmB,EAE9C,MAAMC,EAAaC,EAAAA,YAAY,SAAY,CAC1C,MAAMC,EAAAA,mBAAmB,+BAAgCJ,CAAM,CAChE,EAAG,CAACA,CAAM,CAAC,EAELK,EAAgBF,EAAAA,YACrB,CAACG,EAAyBC,IAClB,QAAQ,QACd,IAAI,GAAG,OAAOD,EAAS,CACtB,MAAOC,EACP,MAAO,OACP,OAAQ,OACR,OAAQ,CACP,SAAU,IAAY,CACrBT,GAAS,WAAW,CAAE,GAAIS,CAAA,CAAS,CACpC,EACA,OAAQ,IAAY,CACnBT,GAAS,eAAe,CACvB,SAAU,EACV,QAAS,EACT,QAAS,CAAA,CACT,CACF,EACA,UAAW,IAAY,CACtBA,GAAS,UAAA,CACV,EACA,eAAgB,IAAY,CAAC,EAC7B,MAAO,IAAY,CAClBA,GAAS,UAAA,CACV,EACA,QAAS,IAAY,CACpBA,GAAS,SAAA,CACV,EACA,QAAS,IAAY,CAAC,EACtB,MAAQU,GAAgB,CACvBV,GAAS,UAAUU,CAAK,CACzB,CAAA,CACD,CACA,CAAA,EAGH,CAACV,CAAO,CAAA,EAGT,OACCW,EAAA,cAACC,EAAAA,gBAAA,CACC,GAAGX,EACJ,QAAAD,EACA,WAAAI,EACA,cAAAG,EACA,kBAAmBM,EAAAA,2BAAA,EAEjBC,GACDH,EAAA,cAAC,MAAA,CAAI,MAAO,CAAE,MAAO,OAAQ,OAAQ,OAAO,EAC3CA,EAAA,cAAC,MAAA,CAAI,IAAKG,EAAY,CACvB,CAAA,CAIJ,CACD"}
@@ -0,0 +1,65 @@
1
+ import t, { memo as m, useCallback as l } from "react";
2
+ import { L as y, D as s } from "./index-TYv_5PaK.js";
3
+ import { e as g } from "./ensureScriptLoaded-BGJeoRZ3.js";
4
+ import { P as u } from "./PlayerContainer-D6lZZcOV.js";
5
+ const v = m(
6
+ ({ options: e, ...o }) => {
7
+ const { logger: r } = o;
8
+ r.log(y.Debug, "DailymotionPlayer");
9
+ const i = l(async () => {
10
+ await g("https://api.dmcdn.net/all.js", r);
11
+ }, [r]), d = l(
12
+ (a, n) => Promise.resolve(
13
+ new DM.player(a, {
14
+ video: n,
15
+ width: "100%",
16
+ height: "100%",
17
+ events: {
18
+ apiready: () => {
19
+ e?.onLoaded?.({ id: n });
20
+ },
21
+ seeked: () => {
22
+ e?.onTimeUpdate?.({
23
+ duration: 0,
24
+ percent: 0,
25
+ seconds: 0
26
+ });
27
+ },
28
+ video_end: () => {
29
+ e?.onEnded?.();
30
+ },
31
+ durationchange: () => {
32
+ },
33
+ pause: () => {
34
+ e?.onPause?.();
35
+ },
36
+ playing: () => {
37
+ e?.onPlay?.();
38
+ },
39
+ waiting: () => {
40
+ },
41
+ error: (c) => {
42
+ e?.onError?.(c);
43
+ }
44
+ }
45
+ })
46
+ ),
47
+ [e]
48
+ );
49
+ return /* @__PURE__ */ t.createElement(
50
+ u,
51
+ {
52
+ ...o,
53
+ options: e,
54
+ loadScript: i,
55
+ playerFactory: d,
56
+ controllerFactory: s
57
+ },
58
+ (a) => /* @__PURE__ */ t.createElement("div", { style: { width: "100%", height: "100%" } }, /* @__PURE__ */ t.createElement("div", { ref: a }))
59
+ );
60
+ }
61
+ );
62
+ export {
63
+ v as default
64
+ };
65
+ //# sourceMappingURL=DailymotionPlayer-_t0loHUn.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DailymotionPlayer-_t0loHUn.js","sources":["../src/components/DailymotionPlayer.tsx"],"sourcesContent":["import React, { ReactElement, memo, useCallback } from 'react';\n\nimport { DailymotionPlayerController } from '../controllers/DailymotionPlayerController';\nimport { LogLevel } from '../controllers/Logger';\nimport { ensureScriptLoaded } from '../controllers/ensureScriptLoaded';\nimport { PlayerContainer, PlayerProps } from './PlayerContainer';\n\nconst DailymotionPlayer = memo(\n\t({ options, ...props }: PlayerProps): ReactElement => {\n\t\tconst { logger } = props;\n\n\t\tlogger.log(LogLevel.Debug, 'DailymotionPlayer');\n\n\t\tconst loadScript = useCallback(async () => {\n\t\t\tawait ensureScriptLoaded('https://api.dmcdn.net/all.js', logger);\n\t\t}, [logger]);\n\n\t\tconst playerFactory = useCallback(\n\t\t\t(element: HTMLDivElement, videoId: string): Promise<DM.player> => {\n\t\t\t\treturn Promise.resolve(\n\t\t\t\t\tnew DM.player(element, {\n\t\t\t\t\t\tvideo: videoId,\n\t\t\t\t\t\twidth: '100%',\n\t\t\t\t\t\theight: '100%',\n\t\t\t\t\t\tevents: {\n\t\t\t\t\t\t\tapiready: (): void => {\n\t\t\t\t\t\t\t\toptions?.onLoaded?.({ id: videoId });\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tseeked: (): void => {\n\t\t\t\t\t\t\t\toptions?.onTimeUpdate?.({\n\t\t\t\t\t\t\t\t\tduration: 0,\n\t\t\t\t\t\t\t\t\tpercent: 0,\n\t\t\t\t\t\t\t\t\tseconds: 0,\n\t\t\t\t\t\t\t\t});\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tvideo_end: (): void => {\n\t\t\t\t\t\t\t\toptions?.onEnded?.();\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tdurationchange: (): void => {},\n\t\t\t\t\t\t\tpause: (): void => {\n\t\t\t\t\t\t\t\toptions?.onPause?.();\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\tplaying: (): void => {\n\t\t\t\t\t\t\t\toptions?.onPlay?.();\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\twaiting: (): void => {},\n\t\t\t\t\t\t\terror: (error): void => {\n\t\t\t\t\t\t\t\toptions?.onError?.(error);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t}),\n\t\t\t\t);\n\t\t\t},\n\t\t\t[options],\n\t\t);\n\n\t\treturn (\n\t\t\t<PlayerContainer\n\t\t\t\t{...props}\n\t\t\t\toptions={options}\n\t\t\t\tloadScript={loadScript}\n\t\t\t\tplayerFactory={playerFactory}\n\t\t\t\tcontrollerFactory={DailymotionPlayerController}\n\t\t\t>\n\t\t\t\t{(elementRef): ReactElement => (\n\t\t\t\t\t<div style={{ width: '100%', height: '100%' }}>\n\t\t\t\t\t\t<div ref={elementRef} />\n\t\t\t\t\t</div>\n\t\t\t\t)}\n\t\t\t</PlayerContainer>\n\t\t);\n\t},\n);\n\nexport default DailymotionPlayer;\n"],"names":["DailymotionPlayer","memo","options","props","logger","LogLevel","loadScript","useCallback","ensureScriptLoaded","playerFactory","element","videoId","error","React","PlayerContainer","DailymotionPlayerController","elementRef"],"mappings":";;;;AAOA,MAAMA,IAAoBC;AAAA,EACzB,CAAC,EAAE,SAAAC,GAAS,GAAGC,QAAuC;AACrD,UAAM,EAAE,QAAAC,MAAWD;AAEnB,IAAAC,EAAO,IAAIC,EAAS,OAAO,mBAAmB;AAE9C,UAAMC,IAAaC,EAAY,YAAY;AAC1C,YAAMC,EAAmB,gCAAgCJ,CAAM;AAAA,IAChE,GAAG,CAACA,CAAM,CAAC,GAELK,IAAgBF;AAAA,MACrB,CAACG,GAAyBC,MAClB,QAAQ;AAAA,QACd,IAAI,GAAG,OAAOD,GAAS;AAAA,UACtB,OAAOC;AAAA,UACP,OAAO;AAAA,UACP,QAAQ;AAAA,UACR,QAAQ;AAAA,YACP,UAAU,MAAY;AACrB,cAAAT,GAAS,WAAW,EAAE,IAAIS,EAAA,CAAS;AAAA,YACpC;AAAA,YACA,QAAQ,MAAY;AACnB,cAAAT,GAAS,eAAe;AAAA,gBACvB,UAAU;AAAA,gBACV,SAAS;AAAA,gBACT,SAAS;AAAA,cAAA,CACT;AAAA,YACF;AAAA,YACA,WAAW,MAAY;AACtB,cAAAA,GAAS,UAAA;AAAA,YACV;AAAA,YACA,gBAAgB,MAAY;AAAA,YAAC;AAAA,YAC7B,OAAO,MAAY;AAClB,cAAAA,GAAS,UAAA;AAAA,YACV;AAAA,YACA,SAAS,MAAY;AACpB,cAAAA,GAAS,SAAA;AAAA,YACV;AAAA,YACA,SAAS,MAAY;AAAA,YAAC;AAAA,YACtB,OAAO,CAACU,MAAgB;AACvB,cAAAV,GAAS,UAAUU,CAAK;AAAA,YACzB;AAAA,UAAA;AAAA,QACD,CACA;AAAA,MAAA;AAAA,MAGH,CAACV,CAAO;AAAA,IAAA;AAGT,WACC,gBAAAW,EAAA;AAAA,MAACC;AAAA,MAAA;AAAA,QACC,GAAGX;AAAA,QACJ,SAAAD;AAAA,QACA,YAAAI;AAAA,QACA,eAAAG;AAAA,QACA,mBAAmBM;AAAA,MAAA;AAAA,MAElB,CAACC,MACD,gBAAAH,EAAA,cAAC,OAAA,EAAI,OAAO,EAAE,OAAO,QAAQ,QAAQ,SAAO,GAC3C,gBAAAA,EAAA,cAAC,OAAA,EAAI,KAAKG,GAAY,CACvB;AAAA,IAAA;AAAA,EAIJ;AACD;"}
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react"),o=require("./index-31Npatuy.cjs"),n=require("./PlayerContainer-DjUsAqJ9.cjs"),i=e.memo(({...t})=>{const{logger:l}=t;l.log(o.LogLevel.Debug,"NiconicoPlayer");const a=e.useCallback(r=>Promise.resolve(r),[]);return e.createElement(n.PlayerContainer,{...t,loadScript:void 0,playerFactory:a,controllerFactory:o.NiconicoPlayerController},(r,c)=>e.createElement("div",{style:{width:"100%",height:"100%"}},e.createElement("iframe",{ref:r,src:`https://embed.nicovideo.jp/watch/${c}?jsapi=1&playerId=1`,width:"100%",height:"100%",allowFullScreen:!0,style:{border:"none"},allow:"autoplay; fullscreen"})))});exports.default=i;
2
+ //# sourceMappingURL=NiconicoPlayer-CnpFGMfb.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NiconicoPlayer-CnpFGMfb.cjs","sources":["../src/components/NiconicoPlayer.tsx"],"sourcesContent":["import React, { ReactElement, memo, useCallback } from 'react';\n\nimport { LogLevel } from '../controllers/Logger';\nimport { NiconicoPlayerController } from '../controllers/NiconicoPlayerController';\nimport { PlayerContainer, PlayerProps } from './PlayerContainer';\n\nconst NiconicoPlayer = memo(({ ...props }: PlayerProps): ReactElement => {\n\tconst { logger } = props;\n\n\tlogger.log(LogLevel.Debug, 'NiconicoPlayer');\n\n\tconst playerFactory = useCallback(\n\t\t(element: HTMLIFrameElement): Promise<HTMLIFrameElement> => {\n\t\t\treturn Promise.resolve(element);\n\t\t},\n\t\t[],\n\t);\n\n\treturn (\n\t\t<PlayerContainer\n\t\t\t{...props}\n\t\t\tloadScript={undefined}\n\t\t\tplayerFactory={playerFactory}\n\t\t\tcontrollerFactory={NiconicoPlayerController}\n\t\t>\n\t\t\t{(elementRef, videoId): ReactElement => (\n\t\t\t\t<div style={{ width: '100%', height: '100%' }}>\n\t\t\t\t\t{/* eslint-disable-next-line jsx-a11y/iframe-has-title */}\n\t\t\t\t\t<iframe\n\t\t\t\t\t\tref={elementRef}\n\t\t\t\t\t\tsrc={`https://embed.nicovideo.jp/watch/${videoId}?jsapi=1&playerId=1`}\n\t\t\t\t\t\twidth=\"100%\"\n\t\t\t\t\t\theight=\"100%\"\n\t\t\t\t\t\tallowFullScreen\n\t\t\t\t\t\tstyle={{ border: 'none' }}\n\t\t\t\t\t\t// The player has to have the allow=\"autoplay\" attribute.\n\t\t\t\t\t\t// Otherwise it throws a NotAllowedError: \"play() failed because the user didn't interact with the document first\".\n\t\t\t\t\t\t// See also: https://github.com/vimeo/player.js/issues/389.\n\t\t\t\t\t\t// NOTE: An iframe element created by `PVPlayerNiconico.playerFactory.create` doesn't have the allow=\"autoplay\" attribute,\n\t\t\t\t\t\t// which causes the above issue when trying to autoplay a video.\n\t\t\t\t\t\tallow=\"autoplay; fullscreen\"\n\t\t\t\t\t/>\n\t\t\t\t</div>\n\t\t\t)}\n\t\t</PlayerContainer>\n\t);\n});\n\nexport default NiconicoPlayer;\n"],"names":["NiconicoPlayer","memo","props","logger","LogLevel","playerFactory","useCallback","element","React","PlayerContainer","NiconicoPlayerController","elementRef","videoId"],"mappings":"uLAMMA,EAAiBC,EAAAA,KAAK,CAAC,CAAE,GAAGC,KAAuC,CACxE,KAAM,CAAE,OAAAC,GAAWD,EAEnBC,EAAO,IAAIC,WAAS,MAAO,gBAAgB,EAE3C,MAAMC,EAAgBC,EAAAA,YACpBC,GACO,QAAQ,QAAQA,CAAO,EAE/B,CAAA,CAAC,EAGF,OACCC,EAAA,cAACC,EAAAA,gBAAA,CACC,GAAGP,EACJ,WAAY,OACZ,cAAAG,EACA,kBAAmBK,EAAAA,wBAAA,EAElB,CAACC,EAAYC,IACbJ,EAAA,cAAC,MAAA,CAAI,MAAO,CAAE,MAAO,OAAQ,OAAQ,MAAA,CAAO,EAE3CA,EAAA,cAAC,SAAA,CACA,IAAKG,EACL,IAAK,oCAAoCC,CAAO,sBAChD,MAAM,OACN,OAAO,OACP,gBAAe,GACf,MAAO,CAAE,OAAQ,MAAA,EAMjB,MAAM,sBAAA,CAAA,CAER,CAAA,CAIJ,CAAC"}
@@ -0,0 +1,36 @@
1
+ import r, { memo as c, useCallback as i } from "react";
2
+ import { L as n, N as s } from "./index-TYv_5PaK.js";
3
+ import { P as m } from "./PlayerContainer-D6lZZcOV.js";
4
+ const u = c(({ ...o }) => {
5
+ const { logger: t } = o;
6
+ t.log(n.Debug, "NiconicoPlayer");
7
+ const l = i(
8
+ (e) => Promise.resolve(e),
9
+ []
10
+ );
11
+ return /* @__PURE__ */ r.createElement(
12
+ m,
13
+ {
14
+ ...o,
15
+ loadScript: void 0,
16
+ playerFactory: l,
17
+ controllerFactory: s
18
+ },
19
+ (e, a) => /* @__PURE__ */ r.createElement("div", { style: { width: "100%", height: "100%" } }, /* @__PURE__ */ r.createElement(
20
+ "iframe",
21
+ {
22
+ ref: e,
23
+ src: `https://embed.nicovideo.jp/watch/${a}?jsapi=1&playerId=1`,
24
+ width: "100%",
25
+ height: "100%",
26
+ allowFullScreen: !0,
27
+ style: { border: "none" },
28
+ allow: "autoplay; fullscreen"
29
+ }
30
+ ))
31
+ );
32
+ });
33
+ export {
34
+ u as default
35
+ };
36
+ //# sourceMappingURL=NiconicoPlayer-DwIPqj04.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"NiconicoPlayer-DwIPqj04.js","sources":["../src/components/NiconicoPlayer.tsx"],"sourcesContent":["import React, { ReactElement, memo, useCallback } from 'react';\n\nimport { LogLevel } from '../controllers/Logger';\nimport { NiconicoPlayerController } from '../controllers/NiconicoPlayerController';\nimport { PlayerContainer, PlayerProps } from './PlayerContainer';\n\nconst NiconicoPlayer = memo(({ ...props }: PlayerProps): ReactElement => {\n\tconst { logger } = props;\n\n\tlogger.log(LogLevel.Debug, 'NiconicoPlayer');\n\n\tconst playerFactory = useCallback(\n\t\t(element: HTMLIFrameElement): Promise<HTMLIFrameElement> => {\n\t\t\treturn Promise.resolve(element);\n\t\t},\n\t\t[],\n\t);\n\n\treturn (\n\t\t<PlayerContainer\n\t\t\t{...props}\n\t\t\tloadScript={undefined}\n\t\t\tplayerFactory={playerFactory}\n\t\t\tcontrollerFactory={NiconicoPlayerController}\n\t\t>\n\t\t\t{(elementRef, videoId): ReactElement => (\n\t\t\t\t<div style={{ width: '100%', height: '100%' }}>\n\t\t\t\t\t{/* eslint-disable-next-line jsx-a11y/iframe-has-title */}\n\t\t\t\t\t<iframe\n\t\t\t\t\t\tref={elementRef}\n\t\t\t\t\t\tsrc={`https://embed.nicovideo.jp/watch/${videoId}?jsapi=1&playerId=1`}\n\t\t\t\t\t\twidth=\"100%\"\n\t\t\t\t\t\theight=\"100%\"\n\t\t\t\t\t\tallowFullScreen\n\t\t\t\t\t\tstyle={{ border: 'none' }}\n\t\t\t\t\t\t// The player has to have the allow=\"autoplay\" attribute.\n\t\t\t\t\t\t// Otherwise it throws a NotAllowedError: \"play() failed because the user didn't interact with the document first\".\n\t\t\t\t\t\t// See also: https://github.com/vimeo/player.js/issues/389.\n\t\t\t\t\t\t// NOTE: An iframe element created by `PVPlayerNiconico.playerFactory.create` doesn't have the allow=\"autoplay\" attribute,\n\t\t\t\t\t\t// which causes the above issue when trying to autoplay a video.\n\t\t\t\t\t\tallow=\"autoplay; fullscreen\"\n\t\t\t\t\t/>\n\t\t\t\t</div>\n\t\t\t)}\n\t\t</PlayerContainer>\n\t);\n});\n\nexport default NiconicoPlayer;\n"],"names":["NiconicoPlayer","memo","props","logger","LogLevel","playerFactory","useCallback","element","React","PlayerContainer","NiconicoPlayerController","elementRef","videoId"],"mappings":";;;AAMA,MAAMA,IAAiBC,EAAK,CAAC,EAAE,GAAGC,QAAuC;AACxE,QAAM,EAAE,QAAAC,MAAWD;AAEnB,EAAAC,EAAO,IAAIC,EAAS,OAAO,gBAAgB;AAE3C,QAAMC,IAAgBC;AAAA,IACrB,CAACC,MACO,QAAQ,QAAQA,CAAO;AAAA,IAE/B,CAAA;AAAA,EAAC;AAGF,SACC,gBAAAC,EAAA;AAAA,IAACC;AAAA,IAAA;AAAA,MACC,GAAGP;AAAA,MACJ,YAAY;AAAA,MACZ,eAAAG;AAAA,MACA,mBAAmBK;AAAA,IAAA;AAAA,IAElB,CAACC,GAAYC,MACb,gBAAAJ,EAAA,cAAC,OAAA,EAAI,OAAO,EAAE,OAAO,QAAQ,QAAQ,OAAA,EAAO,GAE3C,gBAAAA,EAAA;AAAA,MAAC;AAAA,MAAA;AAAA,QACA,KAAKG;AAAA,QACL,KAAK,oCAAoCC,CAAO;AAAA,QAChD,OAAM;AAAA,QACN,QAAO;AAAA,QACP,iBAAe;AAAA,QACf,OAAO,EAAE,QAAQ,OAAA;AAAA,QAMjB,OAAM;AAAA,MAAA;AAAA,IAAA,CAER;AAAA,EAAA;AAIJ,CAAC;"}
@@ -0,0 +1,57 @@
1
+ import y, { useRef as u, useState as C, useEffect as i } from "react";
2
+ import { L as M, n as E, P as d } from "./index-TYv_5PaK.js";
3
+ function D() {
4
+ const t = u(!0);
5
+ return t.current ? (t.current = !1, !0) : t.current;
6
+ }
7
+ const V = (t, e) => t === e;
8
+ function b(t, e = V) {
9
+ const r = u(), n = u(t);
10
+ return !D() && !e(n.current, t) && (r.current = n.current, n.current = t), r.current;
11
+ }
12
+ const w = ({
13
+ logger: t,
14
+ type: e,
15
+ loadScript: r,
16
+ playerFactory: n,
17
+ onControllerChange: l,
18
+ videoId: c,
19
+ options: P,
20
+ controllerFactory: m,
21
+ children: F
22
+ }) => {
23
+ t.log(M.Debug, "PlayerContainer");
24
+ const f = u(c), R = u(void 0), [a, L] = C(), [o, h] = C(E);
25
+ i(() => {
26
+ l?.(o);
27
+ }, [o, l]), i(() => {
28
+ (r?.() ?? Promise.resolve()).then(() => {
29
+ n(R.current, f.current).then(
30
+ (s) => {
31
+ L(s);
32
+ }
33
+ );
34
+ });
35
+ }, [r, n]), i(() => {
36
+ if (a === void 0)
37
+ return;
38
+ const s = new d(
39
+ t,
40
+ e,
41
+ a,
42
+ P,
43
+ m
44
+ );
45
+ return s.attach(f.current).then(() => h(s)), () => {
46
+ s.detach().finally(() => h(E));
47
+ };
48
+ }, [t, e, r, a, P, m]);
49
+ const v = b(c);
50
+ return i(() => {
51
+ v !== void 0 && o.loadVideo(c);
52
+ }, [v, c, o]), /* @__PURE__ */ y.createElement(y.Fragment, null, F(R, f.current));
53
+ };
54
+ export {
55
+ w as P
56
+ };
57
+ //# sourceMappingURL=PlayerContainer-D6lZZcOV.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PlayerContainer-D6lZZcOV.js","sources":["../src/components/useFirstMountState.ts","../src/components/usePreviousDistinct.ts","../src/components/PlayerContainer.tsx"],"sourcesContent":["// https://github.com/streamich/react-use/blob/8ceb4c0f0c5625124f487b435a2fd0d3b3bc2a4f/src/useFirstMountState.ts\nimport { useRef } from 'react';\n\nexport function useFirstMountState(): boolean {\n\tconst isFirst = useRef(true);\n\n\tif (isFirst.current) {\n\t\tisFirst.current = false;\n\n\t\treturn true;\n\t}\n\n\treturn isFirst.current;\n}\n","// https://github.com/streamich/react-use/blob/8ceb4c0f0c5625124f487b435a2fd0d3b3bc2a4f/src/usePreviousDistinct.ts.\nimport { useRef } from 'react';\n\nimport { useFirstMountState } from './useFirstMountState';\n\nexport type Predicate<T> = (prev: T | undefined, next: T) => boolean;\n\nconst strictEquals = <T>(prev: T | undefined, next: T): boolean =>\n\tprev === next;\n\nexport default function usePreviousDistinct<T>(\n\tvalue: T,\n\tcompare: Predicate<T> = strictEquals,\n): T | undefined {\n\tconst prevRef = useRef<T>();\n\tconst curRef = useRef<T>(value);\n\tconst isFirstMount = useFirstMountState();\n\n\tif (!isFirstMount && !compare(curRef.current, value)) {\n\t\tprevRef.current = curRef.current;\n\t\tcurRef.current = value;\n\t}\n\n\treturn prevRef.current;\n}\n","import React, {\n\tMutableRefObject,\n\tReactElement,\n\tReactNode,\n\tuseEffect,\n\tuseRef,\n\tuseState,\n} from 'react';\n\nimport { ILogger, LogLevel } from '../controllers/Logger';\nimport {\n\tIPlayerController,\n\tPlayerController,\n\tPlayerOptions,\n\tPlayerType,\n} from '../controllers/PlayerController';\nimport { PlayerControllerImpl } from '../controllers/PlayerControllerImpl';\nimport usePreviousDistinct from './usePreviousDistinct';\nimport { nullPlayerController } from '@/controllers/NullPlayerController';\n\nexport interface PlayerProps {\n\tlogger: ILogger;\n\ttype: PlayerType;\n\tonControllerChange: ((value: IPlayerController) => void) | undefined;\n\tvideoId: string;\n\toptions: PlayerOptions | undefined;\n}\n\ninterface PlayerContainerProps<\n\tTElement extends HTMLElement,\n\tTPlayer extends object,\n\tTController extends PlayerControllerImpl<TPlayer>,\n> extends PlayerProps {\n\tloadScript: (() => Promise<void>) | undefined;\n\tplayerFactory: (element: TElement, videoId: string) => Promise<TPlayer>;\n\tcontrollerFactory: new (\n\t\tlogger: ILogger,\n\t\tplayer: TPlayer,\n\t\toptions: PlayerOptions | undefined,\n\t) => TController;\n\tchildren: (\n\t\telementRef: MutableRefObject<TElement>,\n\t\tvideoId: string,\n\t) => ReactNode;\n}\n\nexport const PlayerContainer = <\n\tTElement extends HTMLElement,\n\tTPlayer extends object,\n\tTController extends PlayerControllerImpl<TPlayer>,\n>({\n\tlogger,\n\ttype,\n\tloadScript,\n\tplayerFactory,\n\tonControllerChange,\n\tvideoId,\n\toptions,\n\tcontrollerFactory,\n\tchildren,\n}: PlayerContainerProps<TElement, TPlayer, TController>): ReactElement<\n\tPlayerContainerProps<TElement, TPlayer, TController>\n> => {\n\tlogger.log(LogLevel.Debug, 'PlayerContainer');\n\n\tconst videoIdRef = useRef(videoId);\n\n\t// eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n\tconst elementRef = useRef<TElement>(undefined!);\n\n\tconst [player, setPlayer] = useState<TPlayer>();\n\n\tconst [controller, setController] =\n\t\tuseState<IPlayerController>(nullPlayerController);\n\tuseEffect(() => {\n\t\tonControllerChange?.(controller);\n\t}, [controller, onControllerChange]);\n\n\tuseEffect(() => {\n\t\t(loadScript?.() ?? Promise.resolve()).then(() => {\n\t\t\tplayerFactory(elementRef.current, videoIdRef.current).then(\n\t\t\t\t(player) => {\n\t\t\t\t\tsetPlayer(player);\n\t\t\t\t},\n\t\t\t);\n\t\t});\n\t}, [loadScript, playerFactory]);\n\n\t// Make sure that `options` do not change between re-rendering.\n\tuseEffect(() => {\n\t\tif (player === undefined) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst controller = new PlayerController(\n\t\t\tlogger,\n\t\t\ttype,\n\t\t\tplayer,\n\t\t\toptions,\n\t\t\tcontrollerFactory,\n\t\t);\n\n\t\tcontroller\n\t\t\t.attach(videoIdRef.current)\n\t\t\t.then(() => setController(controller));\n\n\t\treturn (): void => {\n\t\t\tcontroller\n\t\t\t\t.detach()\n\t\t\t\t.finally(() => setController(nullPlayerController));\n\t\t};\n\t}, [logger, type, loadScript, player, options, controllerFactory]);\n\n\tconst previousVideoId = usePreviousDistinct(videoId);\n\tuseEffect(() => {\n\t\t// If `previousVideoId` is undefined, then it means that the video has already been loaded by either\n\t\t// 1. `<audio>`s `src` attribute (e.g. `AudioPlayer`),\n\t\t// 2. `<iframe>`'s `src` attribute (e.g. `NiconicoPlayer`, `SoundCloudPlayer` and `VimeoPlayer`), or\n\t\t// 3. the `attach` method of the player API (e.g. `YouTubePlayer`).\n\t\tif (previousVideoId === undefined) {\n\t\t\treturn;\n\t\t}\n\n\t\tcontroller.loadVideo(videoId);\n\t}, [previousVideoId, videoId, controller]);\n\n\t// Make sure that `videoId` does not change between re-rendering.\n\treturn <>{children(elementRef, videoIdRef.current)}</>;\n};\n"],"names":["useFirstMountState","isFirst","useRef","strictEquals","prev","next","usePreviousDistinct","value","compare","prevRef","curRef","PlayerContainer","logger","type","loadScript","playerFactory","onControllerChange","videoId","options","controllerFactory","children","LogLevel","videoIdRef","elementRef","player","setPlayer","useState","controller","setController","nullPlayerController","useEffect","PlayerController","previousVideoId","React"],"mappings":";;AAGO,SAASA,IAA8B;AAC7C,QAAMC,IAAUC,EAAO,EAAI;AAE3B,SAAID,EAAQ,WACXA,EAAQ,UAAU,IAEX,MAGDA,EAAQ;AAChB;ACNA,MAAME,IAAe,CAAIC,GAAqBC,MAC7CD,MAASC;AAEV,SAAwBC,EACvBC,GACAC,IAAwBL,GACR;AAChB,QAAMM,IAAUP,EAAA,GACVQ,IAASR,EAAUK,CAAK;AAG9B,SAAI,CAFiBP,EAAA,KAEA,CAACQ,EAAQE,EAAO,SAASH,CAAK,MAClDE,EAAQ,UAAUC,EAAO,SACzBA,EAAO,UAAUH,IAGXE,EAAQ;AAChB;ACsBO,MAAME,IAAkB,CAI7B;AAAA,EACD,QAAAC;AAAA,EACA,MAAAC;AAAA,EACA,YAAAC;AAAA,EACA,eAAAC;AAAA,EACA,oBAAAC;AAAA,EACA,SAAAC;AAAA,EACA,SAAAC;AAAA,EACA,mBAAAC;AAAA,EACA,UAAAC;AACD,MAEK;AACJ,EAAAR,EAAO,IAAIS,EAAS,OAAO,iBAAiB;AAE5C,QAAMC,IAAapB,EAAOe,CAAO,GAG3BM,IAAarB,EAAiB,MAAU,GAExC,CAACsB,GAAQC,CAAS,IAAIC,EAAA,GAEtB,CAACC,GAAYC,CAAa,IAC/BF,EAA4BG,CAAoB;AACjD,EAAAC,EAAU,MAAM;AACf,IAAAd,IAAqBW,CAAU;AAAA,EAChC,GAAG,CAACA,GAAYX,CAAkB,CAAC,GAEnCc,EAAU,MAAM;AACf,KAAChB,SAAkB,QAAQ,QAAA,GAAW,KAAK,MAAM;AAChD,MAAAC,EAAcQ,EAAW,SAASD,EAAW,OAAO,EAAE;AAAA,QACrD,CAACE,MAAW;AACX,UAAAC,EAAUD,CAAM;AAAA,QACjB;AAAA,MAAA;AAAA,IAEF,CAAC;AAAA,EACF,GAAG,CAACV,GAAYC,CAAa,CAAC,GAG9Be,EAAU,MAAM;AACf,QAAIN,MAAW;AACd;AAGD,UAAMG,IAAa,IAAII;AAAA,MACtBnB;AAAA,MACAC;AAAA,MACAW;AAAA,MACAN;AAAA,MACAC;AAAA,IAAA;AAGDQ,WAAAA,EACE,OAAOL,EAAW,OAAO,EACzB,KAAK,MAAMM,EAAcD,CAAU,CAAC,GAE/B,MAAY;AAClBA,MAAAA,EACE,OAAA,EACA,QAAQ,MAAMC,EAAcC,CAAoB,CAAC;AAAA,IACpD;AAAA,EACD,GAAG,CAACjB,GAAQC,GAAMC,GAAYU,GAAQN,GAASC,CAAiB,CAAC;AAEjE,QAAMa,IAAkB1B,EAAoBW,CAAO;AACnD,SAAAa,EAAU,MAAM;AAKf,IAAIE,MAAoB,UAIxBL,EAAW,UAAUV,CAAO;AAAA,EAC7B,GAAG,CAACe,GAAiBf,GAASU,CAAU,CAAC,GAGlC,gBAAAM,EAAA,cAAAA,EAAA,UAAA,MAAGb,EAASG,GAAYD,EAAW,OAAO,CAAE;AACpD;"}
@@ -0,0 +1,2 @@
1
+ "use strict";const t=require("react"),i=require("./index-31Npatuy.cjs");function v(){const e=t.useRef(!0);return e.current?(e.current=!1,!0):e.current}const d=(e,r)=>e===r;function q(e,r=d){const n=t.useRef(),u=t.useRef(e);return!v()&&!r(u.current,e)&&(n.current=u.current,u.current=e),n.current}const F=({logger:e,type:r,loadScript:n,playerFactory:u,onControllerChange:f,videoId:c,options:R,controllerFactory:P,children:h})=>{e.log(i.LogLevel.Debug,"PlayerContainer");const l=t.useRef(c),E=t.useRef(void 0),[a,m]=t.useState(),[o,y]=t.useState(i.nullPlayerController);t.useEffect(()=>{f?.(o)},[o,f]),t.useEffect(()=>{(n?.()??Promise.resolve()).then(()=>{u(E.current,l.current).then(s=>{m(s)})})},[n,u]),t.useEffect(()=>{if(a===void 0)return;const s=new i.PlayerController(e,r,a,R,P);return s.attach(l.current).then(()=>y(s)),()=>{s.detach().finally(()=>y(i.nullPlayerController))}},[e,r,n,a,R,P]);const C=q(c);return t.useEffect(()=>{C!==void 0&&o.loadVideo(c)},[C,c,o]),t.createElement(t.Fragment,null,h(E,l.current))};exports.PlayerContainer=F;
2
+ //# sourceMappingURL=PlayerContainer-DjUsAqJ9.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PlayerContainer-DjUsAqJ9.cjs","sources":["../src/components/useFirstMountState.ts","../src/components/usePreviousDistinct.ts","../src/components/PlayerContainer.tsx"],"sourcesContent":["// https://github.com/streamich/react-use/blob/8ceb4c0f0c5625124f487b435a2fd0d3b3bc2a4f/src/useFirstMountState.ts\nimport { useRef } from 'react';\n\nexport function useFirstMountState(): boolean {\n\tconst isFirst = useRef(true);\n\n\tif (isFirst.current) {\n\t\tisFirst.current = false;\n\n\t\treturn true;\n\t}\n\n\treturn isFirst.current;\n}\n","// https://github.com/streamich/react-use/blob/8ceb4c0f0c5625124f487b435a2fd0d3b3bc2a4f/src/usePreviousDistinct.ts.\nimport { useRef } from 'react';\n\nimport { useFirstMountState } from './useFirstMountState';\n\nexport type Predicate<T> = (prev: T | undefined, next: T) => boolean;\n\nconst strictEquals = <T>(prev: T | undefined, next: T): boolean =>\n\tprev === next;\n\nexport default function usePreviousDistinct<T>(\n\tvalue: T,\n\tcompare: Predicate<T> = strictEquals,\n): T | undefined {\n\tconst prevRef = useRef<T>();\n\tconst curRef = useRef<T>(value);\n\tconst isFirstMount = useFirstMountState();\n\n\tif (!isFirstMount && !compare(curRef.current, value)) {\n\t\tprevRef.current = curRef.current;\n\t\tcurRef.current = value;\n\t}\n\n\treturn prevRef.current;\n}\n","import React, {\n\tMutableRefObject,\n\tReactElement,\n\tReactNode,\n\tuseEffect,\n\tuseRef,\n\tuseState,\n} from 'react';\n\nimport { ILogger, LogLevel } from '../controllers/Logger';\nimport {\n\tIPlayerController,\n\tPlayerController,\n\tPlayerOptions,\n\tPlayerType,\n} from '../controllers/PlayerController';\nimport { PlayerControllerImpl } from '../controllers/PlayerControllerImpl';\nimport usePreviousDistinct from './usePreviousDistinct';\nimport { nullPlayerController } from '@/controllers/NullPlayerController';\n\nexport interface PlayerProps {\n\tlogger: ILogger;\n\ttype: PlayerType;\n\tonControllerChange: ((value: IPlayerController) => void) | undefined;\n\tvideoId: string;\n\toptions: PlayerOptions | undefined;\n}\n\ninterface PlayerContainerProps<\n\tTElement extends HTMLElement,\n\tTPlayer extends object,\n\tTController extends PlayerControllerImpl<TPlayer>,\n> extends PlayerProps {\n\tloadScript: (() => Promise<void>) | undefined;\n\tplayerFactory: (element: TElement, videoId: string) => Promise<TPlayer>;\n\tcontrollerFactory: new (\n\t\tlogger: ILogger,\n\t\tplayer: TPlayer,\n\t\toptions: PlayerOptions | undefined,\n\t) => TController;\n\tchildren: (\n\t\telementRef: MutableRefObject<TElement>,\n\t\tvideoId: string,\n\t) => ReactNode;\n}\n\nexport const PlayerContainer = <\n\tTElement extends HTMLElement,\n\tTPlayer extends object,\n\tTController extends PlayerControllerImpl<TPlayer>,\n>({\n\tlogger,\n\ttype,\n\tloadScript,\n\tplayerFactory,\n\tonControllerChange,\n\tvideoId,\n\toptions,\n\tcontrollerFactory,\n\tchildren,\n}: PlayerContainerProps<TElement, TPlayer, TController>): ReactElement<\n\tPlayerContainerProps<TElement, TPlayer, TController>\n> => {\n\tlogger.log(LogLevel.Debug, 'PlayerContainer');\n\n\tconst videoIdRef = useRef(videoId);\n\n\t// eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n\tconst elementRef = useRef<TElement>(undefined!);\n\n\tconst [player, setPlayer] = useState<TPlayer>();\n\n\tconst [controller, setController] =\n\t\tuseState<IPlayerController>(nullPlayerController);\n\tuseEffect(() => {\n\t\tonControllerChange?.(controller);\n\t}, [controller, onControllerChange]);\n\n\tuseEffect(() => {\n\t\t(loadScript?.() ?? Promise.resolve()).then(() => {\n\t\t\tplayerFactory(elementRef.current, videoIdRef.current).then(\n\t\t\t\t(player) => {\n\t\t\t\t\tsetPlayer(player);\n\t\t\t\t},\n\t\t\t);\n\t\t});\n\t}, [loadScript, playerFactory]);\n\n\t// Make sure that `options` do not change between re-rendering.\n\tuseEffect(() => {\n\t\tif (player === undefined) {\n\t\t\treturn;\n\t\t}\n\n\t\tconst controller = new PlayerController(\n\t\t\tlogger,\n\t\t\ttype,\n\t\t\tplayer,\n\t\t\toptions,\n\t\t\tcontrollerFactory,\n\t\t);\n\n\t\tcontroller\n\t\t\t.attach(videoIdRef.current)\n\t\t\t.then(() => setController(controller));\n\n\t\treturn (): void => {\n\t\t\tcontroller\n\t\t\t\t.detach()\n\t\t\t\t.finally(() => setController(nullPlayerController));\n\t\t};\n\t}, [logger, type, loadScript, player, options, controllerFactory]);\n\n\tconst previousVideoId = usePreviousDistinct(videoId);\n\tuseEffect(() => {\n\t\t// If `previousVideoId` is undefined, then it means that the video has already been loaded by either\n\t\t// 1. `<audio>`s `src` attribute (e.g. `AudioPlayer`),\n\t\t// 2. `<iframe>`'s `src` attribute (e.g. `NiconicoPlayer`, `SoundCloudPlayer` and `VimeoPlayer`), or\n\t\t// 3. the `attach` method of the player API (e.g. `YouTubePlayer`).\n\t\tif (previousVideoId === undefined) {\n\t\t\treturn;\n\t\t}\n\n\t\tcontroller.loadVideo(videoId);\n\t}, [previousVideoId, videoId, controller]);\n\n\t// Make sure that `videoId` does not change between re-rendering.\n\treturn <>{children(elementRef, videoIdRef.current)}</>;\n};\n"],"names":["useFirstMountState","isFirst","useRef","strictEquals","prev","next","usePreviousDistinct","value","compare","prevRef","curRef","PlayerContainer","logger","type","loadScript","playerFactory","onControllerChange","videoId","options","controllerFactory","children","LogLevel","videoIdRef","elementRef","player","setPlayer","useState","controller","setController","nullPlayerController","useEffect","PlayerController","previousVideoId","React"],"mappings":"wEAGO,SAASA,GAA8B,CAC7C,MAAMC,EAAUC,EAAAA,OAAO,EAAI,EAE3B,OAAID,EAAQ,SACXA,EAAQ,QAAU,GAEX,IAGDA,EAAQ,OAChB,CCNA,MAAME,EAAe,CAAIC,EAAqBC,IAC7CD,IAASC,EAEV,SAAwBC,EACvBC,EACAC,EAAwBL,EACR,CAChB,MAAMM,EAAUP,EAAAA,OAAA,EACVQ,EAASR,EAAAA,OAAUK,CAAK,EAG9B,MAAI,CAFiBP,EAAA,GAEA,CAACQ,EAAQE,EAAO,QAASH,CAAK,IAClDE,EAAQ,QAAUC,EAAO,QACzBA,EAAO,QAAUH,GAGXE,EAAQ,OAChB,CCsBO,MAAME,EAAkB,CAI7B,CACD,OAAAC,EACA,KAAAC,EACA,WAAAC,EACA,cAAAC,EACA,mBAAAC,EACA,QAAAC,EACA,QAAAC,EACA,kBAAAC,EACA,SAAAC,CACD,IAEK,CACJR,EAAO,IAAIS,WAAS,MAAO,iBAAiB,EAE5C,MAAMC,EAAapB,EAAAA,OAAOe,CAAO,EAG3BM,EAAarB,EAAAA,OAAiB,MAAU,EAExC,CAACsB,EAAQC,CAAS,EAAIC,WAAA,EAEtB,CAACC,EAAYC,CAAa,EAC/BF,EAAAA,SAA4BG,EAAAA,oBAAoB,EACjDC,EAAAA,UAAU,IAAM,CACfd,IAAqBW,CAAU,CAChC,EAAG,CAACA,EAAYX,CAAkB,CAAC,EAEnCc,EAAAA,UAAU,IAAM,EACdhB,OAAkB,QAAQ,QAAA,GAAW,KAAK,IAAM,CAChDC,EAAcQ,EAAW,QAASD,EAAW,OAAO,EAAE,KACpDE,GAAW,CACXC,EAAUD,CAAM,CACjB,CAAA,CAEF,CAAC,CACF,EAAG,CAACV,EAAYC,CAAa,CAAC,EAG9Be,EAAAA,UAAU,IAAM,CACf,GAAIN,IAAW,OACd,OAGD,MAAMG,EAAa,IAAII,EAAAA,iBACtBnB,EACAC,EACAW,EACAN,EACAC,CAAA,EAGDQ,OAAAA,EACE,OAAOL,EAAW,OAAO,EACzB,KAAK,IAAMM,EAAcD,CAAU,CAAC,EAE/B,IAAY,CAClBA,EACE,OAAA,EACA,QAAQ,IAAMC,EAAcC,EAAAA,oBAAoB,CAAC,CACpD,CACD,EAAG,CAACjB,EAAQC,EAAMC,EAAYU,EAAQN,EAASC,CAAiB,CAAC,EAEjE,MAAMa,EAAkB1B,EAAoBW,CAAO,EACnDa,OAAAA,EAAAA,UAAU,IAAM,CAKXE,IAAoB,QAIxBL,EAAW,UAAUV,CAAO,CAC7B,EAAG,CAACe,EAAiBf,EAASU,CAAU,CAAC,EAGlCM,EAAA,cAAAA,EAAA,SAAA,KAAGb,EAASG,EAAYD,EAAW,OAAO,CAAE,CACpD"}
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react"),l=require("./index-31Npatuy.cjs"),u=require("./ensureScriptLoaded-bFj2T2cD.cjs"),s=require("./PlayerContainer-DjUsAqJ9.cjs"),d=e.memo(({...t})=>{const{logger:r}=t;r.log(l.LogLevel.Debug,"SoundCloudPlayer");const a=e.useCallback(async()=>{await u.ensureScriptLoaded("https://w.soundcloud.com/player/api.js",r)},[r]),n=e.useCallback(o=>Promise.resolve(SC.Widget(o)),[]);return e.createElement(s.PlayerContainer,{...t,loadScript:a,playerFactory:n,controllerFactory:l.SoundCloudPlayerController},(o,c)=>e.createElement("iframe",{ref:o,src:`https://w.soundcloud.com/player/?url=${c}`,frameBorder:0,allow:"autoplay",style:{width:"100%",height:"100%"}}))});exports.default=d;
2
+ //# sourceMappingURL=SoundCloudPlayer-BvGSbQ8G.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SoundCloudPlayer-BvGSbQ8G.cjs","sources":["../src/components/SoundCloudPlayer.tsx"],"sourcesContent":["import React, { ReactElement, memo, useCallback } from 'react';\n\nimport { LogLevel } from '../controllers/Logger';\nimport { SoundCloudPlayerController } from '../controllers/SoundCloudPlayerController';\nimport { ensureScriptLoaded } from '../controllers/ensureScriptLoaded';\nimport { PlayerContainer, PlayerProps } from './PlayerContainer';\n\nconst SoundCloudPlayer = memo(({ ...props }: PlayerProps): ReactElement => {\n\tconst { logger } = props;\n\n\tlogger.log(LogLevel.Debug, 'SoundCloudPlayer');\n\n\tconst loadScript = useCallback(async () => {\n\t\tawait ensureScriptLoaded(\n\t\t\t'https://w.soundcloud.com/player/api.js',\n\t\t\tlogger,\n\t\t);\n\t}, [logger]);\n\n\tconst playerFactory = useCallback(\n\t\t(element: HTMLIFrameElement): Promise<SC.SoundCloudWidget> => {\n\t\t\treturn Promise.resolve(SC.Widget(element));\n\t\t},\n\t\t[],\n\t);\n\n\treturn (\n\t\t<PlayerContainer\n\t\t\t{...props}\n\t\t\tloadScript={loadScript}\n\t\t\tplayerFactory={playerFactory}\n\t\t\tcontrollerFactory={SoundCloudPlayerController}\n\t\t>\n\t\t\t{(elementRef, videoId): ReactElement => (\n\t\t\t\t// eslint-disable-next-line jsx-a11y/iframe-has-title\n\t\t\t\t<iframe\n\t\t\t\t\tref={elementRef}\n\t\t\t\t\tsrc={`https://w.soundcloud.com/player/?url=${videoId}`}\n\t\t\t\t\tframeBorder={0}\n\t\t\t\t\tallow=\"autoplay\"\n\t\t\t\t\tstyle={{ width: '100%', height: '100%' }}\n\t\t\t\t/>\n\t\t\t)}\n\t\t</PlayerContainer>\n\t);\n});\n\nexport default SoundCloudPlayer;\n"],"names":["SoundCloudPlayer","memo","props","logger","LogLevel","loadScript","useCallback","ensureScriptLoaded","playerFactory","element","React","PlayerContainer","SoundCloudPlayerController","elementRef","videoId"],"mappings":"sOAOMA,EAAmBC,EAAAA,KAAK,CAAC,CAAE,GAAGC,KAAuC,CAC1E,KAAM,CAAE,OAAAC,GAAWD,EAEnBC,EAAO,IAAIC,WAAS,MAAO,kBAAkB,EAE7C,MAAMC,EAAaC,EAAAA,YAAY,SAAY,CAC1C,MAAMC,EAAAA,mBACL,yCACAJ,CAAA,CAEF,EAAG,CAACA,CAAM,CAAC,EAELK,EAAgBF,EAAAA,YACpBG,GACO,QAAQ,QAAQ,GAAG,OAAOA,CAAO,CAAC,EAE1C,CAAA,CAAC,EAGF,OACCC,EAAA,cAACC,EAAAA,gBAAA,CACC,GAAGT,EACJ,WAAAG,EACA,cAAAG,EACA,kBAAmBI,EAAAA,0BAAA,EAElB,CAACC,EAAYC,IAEbJ,EAAA,cAAC,SAAA,CACA,IAAKG,EACL,IAAK,wCAAwCC,CAAO,GACpD,YAAa,EACb,MAAM,WACN,MAAO,CAAE,MAAO,OAAQ,OAAQ,MAAA,CAAO,CAAA,CACxC,CAIJ,CAAC"}
@@ -0,0 +1,43 @@
1
+ import t, { memo as n, useCallback as a } from "react";
2
+ import { L as u, S as d } from "./index-TYv_5PaK.js";
3
+ import { e as m } from "./ensureScriptLoaded-BGJeoRZ3.js";
4
+ import { P as i } from "./PlayerContainer-D6lZZcOV.js";
5
+ const C = n(({ ...r }) => {
6
+ const { logger: e } = r;
7
+ e.log(u.Debug, "SoundCloudPlayer");
8
+ const l = a(async () => {
9
+ await m(
10
+ "https://w.soundcloud.com/player/api.js",
11
+ e
12
+ );
13
+ }, [e]), s = a(
14
+ (o) => Promise.resolve(SC.Widget(o)),
15
+ []
16
+ );
17
+ return /* @__PURE__ */ t.createElement(
18
+ i,
19
+ {
20
+ ...r,
21
+ loadScript: l,
22
+ playerFactory: s,
23
+ controllerFactory: d
24
+ },
25
+ (o, c) => (
26
+ // eslint-disable-next-line jsx-a11y/iframe-has-title
27
+ /* @__PURE__ */ t.createElement(
28
+ "iframe",
29
+ {
30
+ ref: o,
31
+ src: `https://w.soundcloud.com/player/?url=${c}`,
32
+ frameBorder: 0,
33
+ allow: "autoplay",
34
+ style: { width: "100%", height: "100%" }
35
+ }
36
+ )
37
+ )
38
+ );
39
+ });
40
+ export {
41
+ C as default
42
+ };
43
+ //# sourceMappingURL=SoundCloudPlayer-T1Wwq5XY.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SoundCloudPlayer-T1Wwq5XY.js","sources":["../src/components/SoundCloudPlayer.tsx"],"sourcesContent":["import React, { ReactElement, memo, useCallback } from 'react';\n\nimport { LogLevel } from '../controllers/Logger';\nimport { SoundCloudPlayerController } from '../controllers/SoundCloudPlayerController';\nimport { ensureScriptLoaded } from '../controllers/ensureScriptLoaded';\nimport { PlayerContainer, PlayerProps } from './PlayerContainer';\n\nconst SoundCloudPlayer = memo(({ ...props }: PlayerProps): ReactElement => {\n\tconst { logger } = props;\n\n\tlogger.log(LogLevel.Debug, 'SoundCloudPlayer');\n\n\tconst loadScript = useCallback(async () => {\n\t\tawait ensureScriptLoaded(\n\t\t\t'https://w.soundcloud.com/player/api.js',\n\t\t\tlogger,\n\t\t);\n\t}, [logger]);\n\n\tconst playerFactory = useCallback(\n\t\t(element: HTMLIFrameElement): Promise<SC.SoundCloudWidget> => {\n\t\t\treturn Promise.resolve(SC.Widget(element));\n\t\t},\n\t\t[],\n\t);\n\n\treturn (\n\t\t<PlayerContainer\n\t\t\t{...props}\n\t\t\tloadScript={loadScript}\n\t\t\tplayerFactory={playerFactory}\n\t\t\tcontrollerFactory={SoundCloudPlayerController}\n\t\t>\n\t\t\t{(elementRef, videoId): ReactElement => (\n\t\t\t\t// eslint-disable-next-line jsx-a11y/iframe-has-title\n\t\t\t\t<iframe\n\t\t\t\t\tref={elementRef}\n\t\t\t\t\tsrc={`https://w.soundcloud.com/player/?url=${videoId}`}\n\t\t\t\t\tframeBorder={0}\n\t\t\t\t\tallow=\"autoplay\"\n\t\t\t\t\tstyle={{ width: '100%', height: '100%' }}\n\t\t\t\t/>\n\t\t\t)}\n\t\t</PlayerContainer>\n\t);\n});\n\nexport default SoundCloudPlayer;\n"],"names":["SoundCloudPlayer","memo","props","logger","LogLevel","loadScript","useCallback","ensureScriptLoaded","playerFactory","element","React","PlayerContainer","SoundCloudPlayerController","elementRef","videoId"],"mappings":";;;;AAOA,MAAMA,IAAmBC,EAAK,CAAC,EAAE,GAAGC,QAAuC;AAC1E,QAAM,EAAE,QAAAC,MAAWD;AAEnB,EAAAC,EAAO,IAAIC,EAAS,OAAO,kBAAkB;AAE7C,QAAMC,IAAaC,EAAY,YAAY;AAC1C,UAAMC;AAAA,MACL;AAAA,MACAJ;AAAA,IAAA;AAAA,EAEF,GAAG,CAACA,CAAM,CAAC,GAELK,IAAgBF;AAAA,IACrB,CAACG,MACO,QAAQ,QAAQ,GAAG,OAAOA,CAAO,CAAC;AAAA,IAE1C,CAAA;AAAA,EAAC;AAGF,SACC,gBAAAC,EAAA;AAAA,IAACC;AAAA,IAAA;AAAA,MACC,GAAGT;AAAA,MACJ,YAAAG;AAAA,MACA,eAAAG;AAAA,MACA,mBAAmBI;AAAA,IAAA;AAAA,IAElB,CAACC,GAAYC;AAAA;AAAA,MAEb,gBAAAJ,EAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACA,KAAKG;AAAA,UACL,KAAK,wCAAwCC,CAAO;AAAA,UACpD,aAAa;AAAA,UACb,OAAM;AAAA,UACN,OAAO,EAAE,OAAO,QAAQ,QAAQ,OAAA;AAAA,QAAO;AAAA,MAAA;AAAA;AAAA,EACxC;AAIJ,CAAC;"}
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react"),a=require("./index-31Npatuy.cjs"),n=require("./ensureScriptLoaded-bFj2T2cD.cjs"),s=require("./PlayerContainer-DjUsAqJ9.cjs"),d=e.memo(({...o})=>{const{logger:t}=o;t.log(a.LogLevel.Debug,"TwitchPlayer");const c=e.useCallback(async()=>{await n.ensureScriptLoaded("https://embed.twitch.tv/embed/v1.js",t)},[t]),l=e.useCallback(async(r,i)=>Promise.resolve(new Twitch.Player(r,{video:i,width:"100%",height:"100%"})),[]);return e.createElement(s.PlayerContainer,{...o,loadScript:c,playerFactory:l,controllerFactory:a.TwitchPlayerController},r=>e.createElement("div",{ref:r,style:{width:"100%",height:"100%"}}))});exports.default=d;
2
+ //# sourceMappingURL=TwitchPlayer-BAaGGA_S.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TwitchPlayer-BAaGGA_S.cjs","sources":["../src/components/TwitchPlayer.tsx"],"sourcesContent":["import React, { ReactElement, memo, useCallback } from 'react';\n\nimport { LogLevel } from '../controllers/Logger';\nimport { TwitchPlayerController } from '../controllers/TwitchPlayerController';\nimport { ensureScriptLoaded } from '../controllers/ensureScriptLoaded';\nimport { PlayerContainer, PlayerProps } from './PlayerContainer';\n\nconst TwitchPlayer = memo(({ ...props }: PlayerProps): ReactElement => {\n\tconst { logger } = props;\n\n\tlogger.log(LogLevel.Debug, 'TwitchPlayer');\n\n\tconst loadScript = useCallback(async () => {\n\t\tawait ensureScriptLoaded('https://embed.twitch.tv/embed/v1.js', logger);\n\t}, [logger]);\n\n\tconst playerFactory = useCallback(\n\t\tasync (\n\t\t\telement: HTMLDivElement,\n\t\t\tvideoId: string,\n\t\t): Promise<Twitch.Player> => {\n\t\t\treturn Promise.resolve(\n\t\t\t\tnew Twitch.Player(element, {\n\t\t\t\t\tvideo: videoId,\n\t\t\t\t\twidth: '100%',\n\t\t\t\t\theight: '100%',\n\t\t\t\t}),\n\t\t\t);\n\t\t},\n\t\t[],\n\t);\n\n\treturn (\n\t\t<PlayerContainer\n\t\t\t{...props}\n\t\t\tloadScript={loadScript}\n\t\t\tplayerFactory={playerFactory}\n\t\t\tcontrollerFactory={TwitchPlayerController}\n\t\t>\n\t\t\t{(elementRef): ReactElement => (\n\t\t\t\t<div\n\t\t\t\t\tref={elementRef}\n\t\t\t\t\tstyle={{ width: '100%', height: '100%' }}\n\t\t\t\t/>\n\t\t\t)}\n\t\t</PlayerContainer>\n\t);\n});\n\nexport default TwitchPlayer;\n"],"names":["TwitchPlayer","memo","props","logger","LogLevel","loadScript","useCallback","ensureScriptLoaded","playerFactory","element","videoId","React","PlayerContainer","TwitchPlayerController","elementRef"],"mappings":"sOAOMA,EAAeC,EAAAA,KAAK,CAAC,CAAE,GAAGC,KAAuC,CACtE,KAAM,CAAE,OAAAC,GAAWD,EAEnBC,EAAO,IAAIC,WAAS,MAAO,cAAc,EAEzC,MAAMC,EAAaC,EAAAA,YAAY,SAAY,CAC1C,MAAMC,EAAAA,mBAAmB,sCAAuCJ,CAAM,CACvE,EAAG,CAACA,CAAM,CAAC,EAELK,EAAgBF,EAAAA,YACrB,MACCG,EACAC,IAEO,QAAQ,QACd,IAAI,OAAO,OAAOD,EAAS,CAC1B,MAAOC,EACP,MAAO,OACP,OAAQ,MAAA,CACR,CAAA,EAGH,CAAA,CAAC,EAGF,OACCC,EAAA,cAACC,EAAAA,gBAAA,CACC,GAAGV,EACJ,WAAAG,EACA,cAAAG,EACA,kBAAmBK,EAAAA,sBAAA,EAEjBC,GACDH,EAAA,cAAC,MAAA,CACA,IAAKG,EACL,MAAO,CAAE,MAAO,OAAQ,OAAQ,MAAA,CAAO,CAAA,CACxC,CAIJ,CAAC"}
@@ -0,0 +1,40 @@
1
+ import o, { memo as s, useCallback as a } from "react";
2
+ import { L as n, T as m } from "./index-TYv_5PaK.js";
3
+ import { e as h } from "./ensureScriptLoaded-BGJeoRZ3.js";
4
+ import { P as y } from "./PlayerContainer-D6lZZcOV.js";
5
+ const P = s(({ ...r }) => {
6
+ const { logger: e } = r;
7
+ e.log(n.Debug, "TwitchPlayer");
8
+ const l = a(async () => {
9
+ await h("https://embed.twitch.tv/embed/v1.js", e);
10
+ }, [e]), c = a(
11
+ async (t, i) => Promise.resolve(
12
+ new Twitch.Player(t, {
13
+ video: i,
14
+ width: "100%",
15
+ height: "100%"
16
+ })
17
+ ),
18
+ []
19
+ );
20
+ return /* @__PURE__ */ o.createElement(
21
+ y,
22
+ {
23
+ ...r,
24
+ loadScript: l,
25
+ playerFactory: c,
26
+ controllerFactory: m
27
+ },
28
+ (t) => /* @__PURE__ */ o.createElement(
29
+ "div",
30
+ {
31
+ ref: t,
32
+ style: { width: "100%", height: "100%" }
33
+ }
34
+ )
35
+ );
36
+ });
37
+ export {
38
+ P as default
39
+ };
40
+ //# sourceMappingURL=TwitchPlayer-yP3VMBNJ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TwitchPlayer-yP3VMBNJ.js","sources":["../src/components/TwitchPlayer.tsx"],"sourcesContent":["import React, { ReactElement, memo, useCallback } from 'react';\n\nimport { LogLevel } from '../controllers/Logger';\nimport { TwitchPlayerController } from '../controllers/TwitchPlayerController';\nimport { ensureScriptLoaded } from '../controllers/ensureScriptLoaded';\nimport { PlayerContainer, PlayerProps } from './PlayerContainer';\n\nconst TwitchPlayer = memo(({ ...props }: PlayerProps): ReactElement => {\n\tconst { logger } = props;\n\n\tlogger.log(LogLevel.Debug, 'TwitchPlayer');\n\n\tconst loadScript = useCallback(async () => {\n\t\tawait ensureScriptLoaded('https://embed.twitch.tv/embed/v1.js', logger);\n\t}, [logger]);\n\n\tconst playerFactory = useCallback(\n\t\tasync (\n\t\t\telement: HTMLDivElement,\n\t\t\tvideoId: string,\n\t\t): Promise<Twitch.Player> => {\n\t\t\treturn Promise.resolve(\n\t\t\t\tnew Twitch.Player(element, {\n\t\t\t\t\tvideo: videoId,\n\t\t\t\t\twidth: '100%',\n\t\t\t\t\theight: '100%',\n\t\t\t\t}),\n\t\t\t);\n\t\t},\n\t\t[],\n\t);\n\n\treturn (\n\t\t<PlayerContainer\n\t\t\t{...props}\n\t\t\tloadScript={loadScript}\n\t\t\tplayerFactory={playerFactory}\n\t\t\tcontrollerFactory={TwitchPlayerController}\n\t\t>\n\t\t\t{(elementRef): ReactElement => (\n\t\t\t\t<div\n\t\t\t\t\tref={elementRef}\n\t\t\t\t\tstyle={{ width: '100%', height: '100%' }}\n\t\t\t\t/>\n\t\t\t)}\n\t\t</PlayerContainer>\n\t);\n});\n\nexport default TwitchPlayer;\n"],"names":["TwitchPlayer","memo","props","logger","LogLevel","loadScript","useCallback","ensureScriptLoaded","playerFactory","element","videoId","React","PlayerContainer","TwitchPlayerController","elementRef"],"mappings":";;;;AAOA,MAAMA,IAAeC,EAAK,CAAC,EAAE,GAAGC,QAAuC;AACtE,QAAM,EAAE,QAAAC,MAAWD;AAEnB,EAAAC,EAAO,IAAIC,EAAS,OAAO,cAAc;AAEzC,QAAMC,IAAaC,EAAY,YAAY;AAC1C,UAAMC,EAAmB,uCAAuCJ,CAAM;AAAA,EACvE,GAAG,CAACA,CAAM,CAAC,GAELK,IAAgBF;AAAA,IACrB,OACCG,GACAC,MAEO,QAAQ;AAAA,MACd,IAAI,OAAO,OAAOD,GAAS;AAAA,QAC1B,OAAOC;AAAA,QACP,OAAO;AAAA,QACP,QAAQ;AAAA,MAAA,CACR;AAAA,IAAA;AAAA,IAGH,CAAA;AAAA,EAAC;AAGF,SACC,gBAAAC,EAAA;AAAA,IAACC;AAAA,IAAA;AAAA,MACC,GAAGV;AAAA,MACJ,YAAAG;AAAA,MACA,eAAAG;AAAA,MACA,mBAAmBK;AAAA,IAAA;AAAA,IAElB,CAACC,MACD,gBAAAH,EAAA;AAAA,MAAC;AAAA,MAAA;AAAA,QACA,KAAKG;AAAA,QACL,OAAO,EAAE,OAAO,QAAQ,QAAQ,OAAA;AAAA,MAAO;AAAA,IAAA;AAAA,EACxC;AAIJ,CAAC;"}
@@ -0,0 +1,43 @@
1
+ import a, { memo as s, useCallback as t } from "react";
2
+ import { L as c, V as n } from "./index-TYv_5PaK.js";
3
+ import { e as y } from "./ensureScriptLoaded-BGJeoRZ3.js";
4
+ import { P as p } from "./PlayerContainer-D6lZZcOV.js";
5
+ const g = s(({ ...o }) => {
6
+ const { logger: e } = o;
7
+ e.log(c.Debug, "VimeoPlayer");
8
+ const l = t(async () => {
9
+ await y(
10
+ "https://player.vimeo.com/api/player.js",
11
+ e
12
+ );
13
+ }, [e]), m = t(
14
+ (r) => Promise.resolve(new Vimeo.Player(r)),
15
+ []
16
+ );
17
+ return /* @__PURE__ */ a.createElement(
18
+ p,
19
+ {
20
+ ...o,
21
+ loadScript: l,
22
+ playerFactory: m,
23
+ controllerFactory: n
24
+ },
25
+ (r, i) => (
26
+ // eslint-disable-next-line jsx-a11y/iframe-has-title
27
+ /* @__PURE__ */ a.createElement(
28
+ "iframe",
29
+ {
30
+ ref: r,
31
+ src: `https://player.vimeo.com/video/${i}`,
32
+ frameBorder: 0,
33
+ allow: "autoplay",
34
+ style: { width: "100%", height: "100%" }
35
+ }
36
+ )
37
+ )
38
+ );
39
+ });
40
+ export {
41
+ g as default
42
+ };
43
+ //# sourceMappingURL=VimeoPlayer-BaKHBuBZ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"VimeoPlayer-BaKHBuBZ.js","sources":["../src/components/VimeoPlayer.tsx"],"sourcesContent":["import React, { ReactElement, memo, useCallback } from 'react';\n\nimport { LogLevel } from '../controllers/Logger';\nimport { VimeoPlayerController } from '../controllers/VimeoPlayerController';\nimport { ensureScriptLoaded } from '../controllers/ensureScriptLoaded';\nimport { PlayerContainer, PlayerProps } from './PlayerContainer';\n\nconst VimeoPlayer = memo(({ ...props }: PlayerProps): ReactElement => {\n\tconst { logger } = props;\n\n\tlogger.log(LogLevel.Debug, 'VimeoPlayer');\n\n\tconst loadScript = useCallback(async () => {\n\t\tawait ensureScriptLoaded(\n\t\t\t'https://player.vimeo.com/api/player.js',\n\t\t\tlogger,\n\t\t);\n\t}, [logger]);\n\n\tconst playerFactory = useCallback(\n\t\t(element: HTMLIFrameElement): Promise<Vimeo.Player> => {\n\t\t\treturn Promise.resolve(new Vimeo.Player(element));\n\t\t},\n\t\t[],\n\t);\n\n\treturn (\n\t\t<PlayerContainer\n\t\t\t{...props}\n\t\t\tloadScript={loadScript}\n\t\t\tplayerFactory={playerFactory}\n\t\t\tcontrollerFactory={VimeoPlayerController}\n\t\t>\n\t\t\t{(elementRef, videoId): ReactElement => (\n\t\t\t\t// eslint-disable-next-line jsx-a11y/iframe-has-title\n\t\t\t\t<iframe\n\t\t\t\t\tref={elementRef}\n\t\t\t\t\tsrc={`https://player.vimeo.com/video/${videoId}`}\n\t\t\t\t\tframeBorder={0}\n\t\t\t\t\tallow=\"autoplay\"\n\t\t\t\t\tstyle={{ width: '100%', height: '100%' }}\n\t\t\t\t/>\n\t\t\t)}\n\t\t</PlayerContainer>\n\t);\n});\n\nexport default VimeoPlayer;\n"],"names":["VimeoPlayer","memo","props","logger","LogLevel","loadScript","useCallback","ensureScriptLoaded","playerFactory","element","React","PlayerContainer","VimeoPlayerController","elementRef","videoId"],"mappings":";;;;AAOA,MAAMA,IAAcC,EAAK,CAAC,EAAE,GAAGC,QAAuC;AACrE,QAAM,EAAE,QAAAC,MAAWD;AAEnB,EAAAC,EAAO,IAAIC,EAAS,OAAO,aAAa;AAExC,QAAMC,IAAaC,EAAY,YAAY;AAC1C,UAAMC;AAAA,MACL;AAAA,MACAJ;AAAA,IAAA;AAAA,EAEF,GAAG,CAACA,CAAM,CAAC,GAELK,IAAgBF;AAAA,IACrB,CAACG,MACO,QAAQ,QAAQ,IAAI,MAAM,OAAOA,CAAO,CAAC;AAAA,IAEjD,CAAA;AAAA,EAAC;AAGF,SACC,gBAAAC,EAAA;AAAA,IAACC;AAAA,IAAA;AAAA,MACC,GAAGT;AAAA,MACJ,YAAAG;AAAA,MACA,eAAAG;AAAA,MACA,mBAAmBI;AAAA,IAAA;AAAA,IAElB,CAACC,GAAYC;AAAA;AAAA,MAEb,gBAAAJ,EAAA;AAAA,QAAC;AAAA,QAAA;AAAA,UACA,KAAKG;AAAA,UACL,KAAK,kCAAkCC,CAAO;AAAA,UAC9C,aAAa;AAAA,UACb,OAAM;AAAA,UACN,OAAO,EAAE,OAAO,QAAQ,QAAQ,OAAA;AAAA,QAAO;AAAA,MAAA;AAAA;AAAA,EACxC;AAIJ,CAAC;"}
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react"),a=require("./index-31Npatuy.cjs"),n=require("./ensureScriptLoaded-bFj2T2cD.cjs"),s=require("./PlayerContainer-DjUsAqJ9.cjs"),y=e.memo(({...t})=>{const{logger:r}=t;r.log(a.LogLevel.Debug,"VimeoPlayer");const l=e.useCallback(async()=>{await n.ensureScriptLoaded("https://player.vimeo.com/api/player.js",r)},[r]),i=e.useCallback(o=>Promise.resolve(new Vimeo.Player(o)),[]);return e.createElement(s.PlayerContainer,{...t,loadScript:l,playerFactory:i,controllerFactory:a.VimeoPlayerController},(o,c)=>e.createElement("iframe",{ref:o,src:`https://player.vimeo.com/video/${c}`,frameBorder:0,allow:"autoplay",style:{width:"100%",height:"100%"}}))});exports.default=y;
2
+ //# sourceMappingURL=VimeoPlayer-nBu7bvUc.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"VimeoPlayer-nBu7bvUc.cjs","sources":["../src/components/VimeoPlayer.tsx"],"sourcesContent":["import React, { ReactElement, memo, useCallback } from 'react';\n\nimport { LogLevel } from '../controllers/Logger';\nimport { VimeoPlayerController } from '../controllers/VimeoPlayerController';\nimport { ensureScriptLoaded } from '../controllers/ensureScriptLoaded';\nimport { PlayerContainer, PlayerProps } from './PlayerContainer';\n\nconst VimeoPlayer = memo(({ ...props }: PlayerProps): ReactElement => {\n\tconst { logger } = props;\n\n\tlogger.log(LogLevel.Debug, 'VimeoPlayer');\n\n\tconst loadScript = useCallback(async () => {\n\t\tawait ensureScriptLoaded(\n\t\t\t'https://player.vimeo.com/api/player.js',\n\t\t\tlogger,\n\t\t);\n\t}, [logger]);\n\n\tconst playerFactory = useCallback(\n\t\t(element: HTMLIFrameElement): Promise<Vimeo.Player> => {\n\t\t\treturn Promise.resolve(new Vimeo.Player(element));\n\t\t},\n\t\t[],\n\t);\n\n\treturn (\n\t\t<PlayerContainer\n\t\t\t{...props}\n\t\t\tloadScript={loadScript}\n\t\t\tplayerFactory={playerFactory}\n\t\t\tcontrollerFactory={VimeoPlayerController}\n\t\t>\n\t\t\t{(elementRef, videoId): ReactElement => (\n\t\t\t\t// eslint-disable-next-line jsx-a11y/iframe-has-title\n\t\t\t\t<iframe\n\t\t\t\t\tref={elementRef}\n\t\t\t\t\tsrc={`https://player.vimeo.com/video/${videoId}`}\n\t\t\t\t\tframeBorder={0}\n\t\t\t\t\tallow=\"autoplay\"\n\t\t\t\t\tstyle={{ width: '100%', height: '100%' }}\n\t\t\t\t/>\n\t\t\t)}\n\t\t</PlayerContainer>\n\t);\n});\n\nexport default VimeoPlayer;\n"],"names":["VimeoPlayer","memo","props","logger","LogLevel","loadScript","useCallback","ensureScriptLoaded","playerFactory","element","React","PlayerContainer","VimeoPlayerController","elementRef","videoId"],"mappings":"sOAOMA,EAAcC,EAAAA,KAAK,CAAC,CAAE,GAAGC,KAAuC,CACrE,KAAM,CAAE,OAAAC,GAAWD,EAEnBC,EAAO,IAAIC,WAAS,MAAO,aAAa,EAExC,MAAMC,EAAaC,EAAAA,YAAY,SAAY,CAC1C,MAAMC,EAAAA,mBACL,yCACAJ,CAAA,CAEF,EAAG,CAACA,CAAM,CAAC,EAELK,EAAgBF,EAAAA,YACpBG,GACO,QAAQ,QAAQ,IAAI,MAAM,OAAOA,CAAO,CAAC,EAEjD,CAAA,CAAC,EAGF,OACCC,EAAA,cAACC,EAAAA,gBAAA,CACC,GAAGT,EACJ,WAAAG,EACA,cAAAG,EACA,kBAAmBI,EAAAA,qBAAA,EAElB,CAACC,EAAYC,IAEbJ,EAAA,cAAC,SAAA,CACA,IAAKG,EACL,IAAK,kCAAkCC,CAAO,GAC9C,YAAa,EACb,MAAM,WACN,MAAO,CAAE,MAAO,OAAQ,OAAQ,MAAA,CAAO,CAAA,CACxC,CAIJ,CAAC"}
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const r=require("react"),o=require("./index-31Npatuy.cjs"),u=require("./ensureScriptLoaded-bFj2T2cD.cjs"),l=require("./PlayerContainer-DjUsAqJ9.cjs"),c="https://www.youtube-nocookie.com",s=r.memo(({...a})=>{const{logger:t}=a;t.log(o.LogLevel.Debug,"YouTubePlayer");const n=r.useCallback(()=>new Promise(async(e,y)=>{await u.ensureScriptLoaded("https://www.youtube.com/iframe_api",t)?window.onYouTubeIframeAPIReady=()=>{t.log(o.LogLevel.Debug,"YouTube iframe API ready"),e()}:e()}),[t]),i=r.useCallback(e=>Promise.resolve(new YT.Player(e,{host:c,width:"100%",height:"100%"})),[]);return r.createElement(l.PlayerContainer,{...a,loadScript:n,playerFactory:i,controllerFactory:o.YouTubePlayerController},e=>r.createElement("div",{style:{width:"100%",height:"100%"}},r.createElement("div",{ref:e})))});exports.default=s;
2
+ //# sourceMappingURL=YouTubePlayer-CMk3QdKb.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"YouTubePlayer-CMk3QdKb.cjs","sources":["../src/components/YouTubePlayer.tsx"],"sourcesContent":["import React, { ReactElement, memo, useCallback } from 'react';\n\nimport { LogLevel } from '../controllers/Logger';\nimport { YouTubePlayerController } from '../controllers/YouTubePlayerController';\nimport { ensureScriptLoaded } from '../controllers/ensureScriptLoaded';\nimport { PlayerContainer, PlayerProps } from './PlayerContainer';\n\nconst origin = 'https://www.youtube-nocookie.com';\n\nconst YouTubePlayer = memo(({ ...props }: PlayerProps): ReactElement => {\n\tconst { logger } = props;\n\n\tlogger.log(LogLevel.Debug, 'YouTubePlayer');\n\n\tconst loadScript = useCallback((): Promise<void> => {\n\t\treturn new Promise(async (resolve, reject) => {\n\t\t\tconst first = await ensureScriptLoaded(\n\t\t\t\t'https://www.youtube.com/iframe_api',\n\t\t\t\tlogger,\n\t\t\t);\n\n\t\t\tif (first) {\n\t\t\t\t// https://stackoverflow.com/a/18154942.\n\t\t\t\twindow.onYouTubeIframeAPIReady = (): void => {\n\t\t\t\t\tlogger.log(LogLevel.Debug, 'YouTube iframe API ready');\n\t\t\t\t\tresolve();\n\t\t\t\t};\n\t\t\t} else {\n\t\t\t\tresolve();\n\t\t\t}\n\t\t});\n\t}, [logger]);\n\n\tconst playerFactory = useCallback(\n\t\t(element: HTMLDivElement): Promise<YT.Player> => {\n\t\t\treturn Promise.resolve(\n\t\t\t\tnew YT.Player(element, {\n\t\t\t\t\thost: origin,\n\t\t\t\t\twidth: '100%',\n\t\t\t\t\theight: '100%',\n\t\t\t\t}),\n\t\t\t);\n\t\t},\n\t\t[],\n\t);\n\n\treturn (\n\t\t<PlayerContainer\n\t\t\t{...props}\n\t\t\tloadScript={loadScript}\n\t\t\tplayerFactory={playerFactory}\n\t\t\tcontrollerFactory={YouTubePlayerController}\n\t\t>\n\t\t\t{(elementRef): ReactElement => (\n\t\t\t\t<div style={{ width: '100%', height: '100%' }}>\n\t\t\t\t\t<div ref={elementRef} />\n\t\t\t\t</div>\n\t\t\t)}\n\t\t</PlayerContainer>\n\t);\n});\n\nexport default YouTubePlayer;\n"],"names":["origin","YouTubePlayer","memo","props","logger","LogLevel","loadScript","useCallback","resolve","reject","ensureScriptLoaded","playerFactory","element","React","PlayerContainer","YouTubePlayerController","elementRef"],"mappings":"sOAOMA,EAAS,mCAETC,EAAgBC,EAAAA,KAAK,CAAC,CAAE,GAAGC,KAAuC,CACvE,KAAM,CAAE,OAAAC,GAAWD,EAEnBC,EAAO,IAAIC,WAAS,MAAO,eAAe,EAE1C,MAAMC,EAAaC,EAAAA,YAAY,IACvB,IAAI,QAAQ,MAAOC,EAASC,IAAW,CAC/B,MAAMC,EAAAA,mBACnB,qCACAN,CAAA,EAKA,OAAO,wBAA0B,IAAY,CAC5CA,EAAO,IAAIC,WAAS,MAAO,0BAA0B,EACrDG,EAAA,CACD,EAEAA,EAAA,CAEF,CAAC,EACC,CAACJ,CAAM,CAAC,EAELO,EAAgBJ,EAAAA,YACpBK,GACO,QAAQ,QACd,IAAI,GAAG,OAAOA,EAAS,CACtB,KAAMZ,EACN,MAAO,OACP,OAAQ,MAAA,CACR,CAAA,EAGH,CAAA,CAAC,EAGF,OACCa,EAAA,cAACC,EAAAA,gBAAA,CACC,GAAGX,EACJ,WAAAG,EACA,cAAAK,EACA,kBAAmBI,EAAAA,uBAAA,EAEjBC,GACDH,EAAA,cAAC,MAAA,CAAI,MAAO,CAAE,MAAO,OAAQ,OAAQ,OAAO,EAC3CA,EAAA,cAAC,MAAA,CAAI,IAAKG,EAAY,CACvB,CAAA,CAIJ,CAAC"}
@@ -0,0 +1,39 @@
1
+ import r, { memo as s, useCallback as a } from "react";
2
+ import { L as i, Y as u } from "./index-TYv_5PaK.js";
3
+ import { e as c } from "./ensureScriptLoaded-BGJeoRZ3.js";
4
+ import { P as m } from "./PlayerContainer-D6lZZcOV.js";
5
+ const y = "https://www.youtube-nocookie.com", h = s(({ ...t }) => {
6
+ const { logger: o } = t;
7
+ o.log(i.Debug, "YouTubePlayer");
8
+ const n = a(() => new Promise(async (e, w) => {
9
+ await c(
10
+ "https://www.youtube.com/iframe_api",
11
+ o
12
+ ) ? window.onYouTubeIframeAPIReady = () => {
13
+ o.log(i.Debug, "YouTube iframe API ready"), e();
14
+ } : e();
15
+ }), [o]), l = a(
16
+ (e) => Promise.resolve(
17
+ new YT.Player(e, {
18
+ host: y,
19
+ width: "100%",
20
+ height: "100%"
21
+ })
22
+ ),
23
+ []
24
+ );
25
+ return /* @__PURE__ */ r.createElement(
26
+ m,
27
+ {
28
+ ...t,
29
+ loadScript: n,
30
+ playerFactory: l,
31
+ controllerFactory: u
32
+ },
33
+ (e) => /* @__PURE__ */ r.createElement("div", { style: { width: "100%", height: "100%" } }, /* @__PURE__ */ r.createElement("div", { ref: e }))
34
+ );
35
+ });
36
+ export {
37
+ h as default
38
+ };
39
+ //# sourceMappingURL=YouTubePlayer-N4BR2ey5.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"YouTubePlayer-N4BR2ey5.js","sources":["../src/components/YouTubePlayer.tsx"],"sourcesContent":["import React, { ReactElement, memo, useCallback } from 'react';\n\nimport { LogLevel } from '../controllers/Logger';\nimport { YouTubePlayerController } from '../controllers/YouTubePlayerController';\nimport { ensureScriptLoaded } from '../controllers/ensureScriptLoaded';\nimport { PlayerContainer, PlayerProps } from './PlayerContainer';\n\nconst origin = 'https://www.youtube-nocookie.com';\n\nconst YouTubePlayer = memo(({ ...props }: PlayerProps): ReactElement => {\n\tconst { logger } = props;\n\n\tlogger.log(LogLevel.Debug, 'YouTubePlayer');\n\n\tconst loadScript = useCallback((): Promise<void> => {\n\t\treturn new Promise(async (resolve, reject) => {\n\t\t\tconst first = await ensureScriptLoaded(\n\t\t\t\t'https://www.youtube.com/iframe_api',\n\t\t\t\tlogger,\n\t\t\t);\n\n\t\t\tif (first) {\n\t\t\t\t// https://stackoverflow.com/a/18154942.\n\t\t\t\twindow.onYouTubeIframeAPIReady = (): void => {\n\t\t\t\t\tlogger.log(LogLevel.Debug, 'YouTube iframe API ready');\n\t\t\t\t\tresolve();\n\t\t\t\t};\n\t\t\t} else {\n\t\t\t\tresolve();\n\t\t\t}\n\t\t});\n\t}, [logger]);\n\n\tconst playerFactory = useCallback(\n\t\t(element: HTMLDivElement): Promise<YT.Player> => {\n\t\t\treturn Promise.resolve(\n\t\t\t\tnew YT.Player(element, {\n\t\t\t\t\thost: origin,\n\t\t\t\t\twidth: '100%',\n\t\t\t\t\theight: '100%',\n\t\t\t\t}),\n\t\t\t);\n\t\t},\n\t\t[],\n\t);\n\n\treturn (\n\t\t<PlayerContainer\n\t\t\t{...props}\n\t\t\tloadScript={loadScript}\n\t\t\tplayerFactory={playerFactory}\n\t\t\tcontrollerFactory={YouTubePlayerController}\n\t\t>\n\t\t\t{(elementRef): ReactElement => (\n\t\t\t\t<div style={{ width: '100%', height: '100%' }}>\n\t\t\t\t\t<div ref={elementRef} />\n\t\t\t\t</div>\n\t\t\t)}\n\t\t</PlayerContainer>\n\t);\n});\n\nexport default YouTubePlayer;\n"],"names":["origin","YouTubePlayer","memo","props","logger","LogLevel","loadScript","useCallback","resolve","reject","ensureScriptLoaded","playerFactory","element","React","PlayerContainer","YouTubePlayerController","elementRef"],"mappings":";;;;AAOA,MAAMA,IAAS,oCAETC,IAAgBC,EAAK,CAAC,EAAE,GAAGC,QAAuC;AACvE,QAAM,EAAE,QAAAC,MAAWD;AAEnB,EAAAC,EAAO,IAAIC,EAAS,OAAO,eAAe;AAE1C,QAAMC,IAAaC,EAAY,MACvB,IAAI,QAAQ,OAAOC,GAASC,MAAW;AAM7C,IALc,MAAMC;AAAA,MACnB;AAAA,MACAN;AAAA,IAAA,IAKA,OAAO,0BAA0B,MAAY;AAC5C,MAAAA,EAAO,IAAIC,EAAS,OAAO,0BAA0B,GACrDG,EAAA;AAAA,IACD,IAEAA,EAAA;AAAA,EAEF,CAAC,GACC,CAACJ,CAAM,CAAC,GAELO,IAAgBJ;AAAA,IACrB,CAACK,MACO,QAAQ;AAAA,MACd,IAAI,GAAG,OAAOA,GAAS;AAAA,QACtB,MAAMZ;AAAA,QACN,OAAO;AAAA,QACP,QAAQ;AAAA,MAAA,CACR;AAAA,IAAA;AAAA,IAGH,CAAA;AAAA,EAAC;AAGF,SACC,gBAAAa,EAAA;AAAA,IAACC;AAAA,IAAA;AAAA,MACC,GAAGX;AAAA,MACJ,YAAAG;AAAA,MACA,eAAAK;AAAA,MACA,mBAAmBI;AAAA,IAAA;AAAA,IAElB,CAACC,MACD,gBAAAH,EAAA,cAAC,OAAA,EAAI,OAAO,EAAE,OAAO,QAAQ,QAAQ,SAAO,GAC3C,gBAAAA,EAAA,cAAC,OAAA,EAAI,KAAKG,GAAY,CACvB;AAAA,EAAA;AAIJ,CAAC;"}
@@ -1,4 +1,4 @@
1
- import React from 'react';
1
+ import React, { ReactElement } from 'react';
2
2
  import { PlayerProps } from './PlayerContainer';
3
- declare const AudioPlayer: React.MemoExoticComponent<({ ...props }: PlayerProps) => React.ReactElement>;
3
+ declare const AudioPlayer: React.MemoExoticComponent<({ ...props }: PlayerProps) => ReactElement>;
4
4
  export default AudioPlayer;
@@ -1,4 +1,4 @@
1
- import React from 'react';
1
+ import React, { ReactElement } from 'react';
2
2
  import { PlayerProps } from './PlayerContainer';
3
- declare const DailymotionPlayer: React.MemoExoticComponent<({ options, ...props }: PlayerProps) => React.ReactElement>;
3
+ declare const DailymotionPlayer: React.MemoExoticComponent<({ options, ...props }: PlayerProps) => ReactElement>;
4
4
  export default DailymotionPlayer;