react-native-theoplayer 2.8.0 → 2.9.0

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 (545) hide show
  1. package/CHANGELOG.md +49 -13
  2. package/README.md +16 -2
  3. package/android/src/main/java/com/theoplayer/media/MediaNotificationBuilder.kt +5 -0
  4. package/android/src/main/java/com/theoplayer/media/MediaPlaybackService.kt +31 -8
  5. package/ios/contentprotection/THEOplayerRCTProxyContentProtectionIntegration.swift +19 -29
  6. package/lib/commonjs/api/cast/Chromecast.js.map +1 -1
  7. package/lib/commonjs/index.js +0 -12
  8. package/lib/commonjs/index.js.map +1 -1
  9. package/lib/module/api/cast/Chromecast.js.map +1 -1
  10. package/lib/module/index.js +0 -1
  11. package/lib/module/index.js.map +1 -1
  12. package/lib/typescript/api/cast/Chromecast.d.ts +1 -1
  13. package/lib/typescript/index.d.ts +0 -1
  14. package/package.json +2 -8
  15. package/react-native-theoplayer.podspec +1 -1
  16. package/src/api/cast/Chromecast.ts +1 -1
  17. package/src/index.tsx +0 -1
  18. package/lib/commonjs/ui/THEOplayerDefaultUi.js +0 -82
  19. package/lib/commonjs/ui/THEOplayerDefaultUi.js.map +0 -1
  20. package/lib/commonjs/ui/THEOplayerTheme.js +0 -48
  21. package/lib/commonjs/ui/THEOplayerTheme.js.map +0 -1
  22. package/lib/commonjs/ui/barrel.js +0 -39
  23. package/lib/commonjs/ui/barrel.js.map +0 -1
  24. package/lib/commonjs/ui/components/activityindicator/CenteredDelayedActivityIndicator.js +0 -99
  25. package/lib/commonjs/ui/components/activityindicator/CenteredDelayedActivityIndicator.js.map +0 -1
  26. package/lib/commonjs/ui/components/activityindicator/DelayedActivityIndicator.js +0 -35
  27. package/lib/commonjs/ui/components/activityindicator/DelayedActivityIndicator.js.map +0 -1
  28. package/lib/commonjs/ui/components/activityindicator/barrel.js +0 -28
  29. package/lib/commonjs/ui/components/activityindicator/barrel.js.map +0 -1
  30. package/lib/commonjs/ui/components/barrel.js +0 -105
  31. package/lib/commonjs/ui/components/barrel.js.map +0 -1
  32. package/lib/commonjs/ui/components/button/AirplayButton.js +0 -81
  33. package/lib/commonjs/ui/components/button/AirplayButton.js.map +0 -1
  34. package/lib/commonjs/ui/components/button/ChromecastButton.js +0 -66
  35. package/lib/commonjs/ui/components/button/ChromecastButton.js.map +0 -1
  36. package/lib/commonjs/ui/components/button/ChromecastButton.web.js +0 -82
  37. package/lib/commonjs/ui/components/button/ChromecastButton.web.js.map +0 -1
  38. package/lib/commonjs/ui/components/button/FullscreenButton.js +0 -72
  39. package/lib/commonjs/ui/components/button/FullscreenButton.js.map +0 -1
  40. package/lib/commonjs/ui/components/button/MuteButton.js +0 -66
  41. package/lib/commonjs/ui/components/button/MuteButton.js.map +0 -1
  42. package/lib/commonjs/ui/components/button/PipButton.js +0 -72
  43. package/lib/commonjs/ui/components/button/PipButton.js.map +0 -1
  44. package/lib/commonjs/ui/components/button/PlayButton.js +0 -113
  45. package/lib/commonjs/ui/components/button/PlayButton.js.map +0 -1
  46. package/lib/commonjs/ui/components/button/SkipButton.js +0 -122
  47. package/lib/commonjs/ui/components/button/SkipButton.js.map +0 -1
  48. package/lib/commonjs/ui/components/button/actionbutton/ActionButton.js +0 -82
  49. package/lib/commonjs/ui/components/button/actionbutton/ActionButton.js.map +0 -1
  50. package/lib/commonjs/ui/components/button/barrel.js +0 -105
  51. package/lib/commonjs/ui/components/button/barrel.js.map +0 -1
  52. package/lib/commonjs/ui/components/button/svg/AirplaySvg.js +0 -22
  53. package/lib/commonjs/ui/components/button/svg/AirplaySvg.js.map +0 -1
  54. package/lib/commonjs/ui/components/button/svg/ArrowForwardSvg.js +0 -22
  55. package/lib/commonjs/ui/components/button/svg/ArrowForwardSvg.js.map +0 -1
  56. package/lib/commonjs/ui/components/button/svg/BackSvg.js +0 -22
  57. package/lib/commonjs/ui/components/button/svg/BackSvg.js.map +0 -1
  58. package/lib/commonjs/ui/components/button/svg/BackwardSvg.js +0 -22
  59. package/lib/commonjs/ui/components/button/svg/BackwardSvg.js.map +0 -1
  60. package/lib/commonjs/ui/components/button/svg/ChromecastSvg.js +0 -22
  61. package/lib/commonjs/ui/components/button/svg/ChromecastSvg.js.map +0 -1
  62. package/lib/commonjs/ui/components/button/svg/ErrorSvg.js +0 -22
  63. package/lib/commonjs/ui/components/button/svg/ErrorSvg.js.map +0 -1
  64. package/lib/commonjs/ui/components/button/svg/ForwardSvg.js +0 -22
  65. package/lib/commonjs/ui/components/button/svg/ForwardSvg.js.map +0 -1
  66. package/lib/commonjs/ui/components/button/svg/FullscreenEnterSvg.js +0 -22
  67. package/lib/commonjs/ui/components/button/svg/FullscreenEnterSvg.js.map +0 -1
  68. package/lib/commonjs/ui/components/button/svg/FullscreenExitSvg.js +0 -22
  69. package/lib/commonjs/ui/components/button/svg/FullscreenExitSvg.js.map +0 -1
  70. package/lib/commonjs/ui/components/button/svg/LanguageSvg.js +0 -22
  71. package/lib/commonjs/ui/components/button/svg/LanguageSvg.js.map +0 -1
  72. package/lib/commonjs/ui/components/button/svg/ListSvg.js +0 -22
  73. package/lib/commonjs/ui/components/button/svg/ListSvg.js.map +0 -1
  74. package/lib/commonjs/ui/components/button/svg/PauseSvg.js +0 -22
  75. package/lib/commonjs/ui/components/button/svg/PauseSvg.js.map +0 -1
  76. package/lib/commonjs/ui/components/button/svg/PipEnterSvg.js +0 -22
  77. package/lib/commonjs/ui/components/button/svg/PipEnterSvg.js.map +0 -1
  78. package/lib/commonjs/ui/components/button/svg/PipExitSvg.js +0 -22
  79. package/lib/commonjs/ui/components/button/svg/PipExitSvg.js.map +0 -1
  80. package/lib/commonjs/ui/components/button/svg/PlaySvg.js +0 -22
  81. package/lib/commonjs/ui/components/button/svg/PlaySvg.js.map +0 -1
  82. package/lib/commonjs/ui/components/button/svg/ReplaySvg.js +0 -22
  83. package/lib/commonjs/ui/components/button/svg/ReplaySvg.js.map +0 -1
  84. package/lib/commonjs/ui/components/button/svg/SettingsSvg.js +0 -22
  85. package/lib/commonjs/ui/components/button/svg/SettingsSvg.js.map +0 -1
  86. package/lib/commonjs/ui/components/button/svg/SvgUtils.js +0 -13
  87. package/lib/commonjs/ui/components/button/svg/SvgUtils.js.map +0 -1
  88. package/lib/commonjs/ui/components/button/svg/VolumeOffSvg.js +0 -22
  89. package/lib/commonjs/ui/components/button/svg/VolumeOffSvg.js.map +0 -1
  90. package/lib/commonjs/ui/components/button/svg/VolumeUpSvg.js +0 -22
  91. package/lib/commonjs/ui/components/button/svg/VolumeUpSvg.js.map +0 -1
  92. package/lib/commonjs/ui/components/button/svg/barrel.js +0 -226
  93. package/lib/commonjs/ui/components/button/svg/barrel.js.map +0 -1
  94. package/lib/commonjs/ui/components/button/svg/res/AirPlayButton.html +0 -6
  95. package/lib/commonjs/ui/components/button/svg/res/Airplay.svg +0 -1
  96. package/lib/commonjs/ui/components/button/svg/res/ChromecastButton.html +0 -25
  97. package/lib/commonjs/ui/components/button/svg/res/arrow_forward.svg +0 -1
  98. package/lib/commonjs/ui/components/button/svg/res/back.svg +0 -1
  99. package/lib/commonjs/ui/components/button/svg/res/backward.svg +0 -1
  100. package/lib/commonjs/ui/components/button/svg/res/chromecast-48px.svg +0 -1
  101. package/lib/commonjs/ui/components/button/svg/res/close.svg +0 -1
  102. package/lib/commonjs/ui/components/button/svg/res/error.svg +0 -1
  103. package/lib/commonjs/ui/components/button/svg/res/forward.svg +0 -1
  104. package/lib/commonjs/ui/components/button/svg/res/fullscreen-enter.svg +0 -1
  105. package/lib/commonjs/ui/components/button/svg/res/fullscreen-exit.svg +0 -1
  106. package/lib/commonjs/ui/components/button/svg/res/language.svg +0 -1
  107. package/lib/commonjs/ui/components/button/svg/res/list.svg +0 -1
  108. package/lib/commonjs/ui/components/button/svg/res/live.svg +0 -1
  109. package/lib/commonjs/ui/components/button/svg/res/pause.svg +0 -1
  110. package/lib/commonjs/ui/components/button/svg/res/pip_enter.svg +0 -1
  111. package/lib/commonjs/ui/components/button/svg/res/pip_exit.svg +0 -1
  112. package/lib/commonjs/ui/components/button/svg/res/play.svg +0 -1
  113. package/lib/commonjs/ui/components/button/svg/res/replay.svg +0 -1
  114. package/lib/commonjs/ui/components/button/svg/res/settings.svg +0 -1
  115. package/lib/commonjs/ui/components/button/svg/res/skip-next.svg +0 -1
  116. package/lib/commonjs/ui/components/button/svg/res/volume-high.svg +0 -1
  117. package/lib/commonjs/ui/components/button/svg/res/volume-low.svg +0 -1
  118. package/lib/commonjs/ui/components/button/svg/res/volume-off.svg +0 -1
  119. package/lib/commonjs/ui/components/controlbar/ControlBar.js +0 -61
  120. package/lib/commonjs/ui/components/controlbar/ControlBar.js.map +0 -1
  121. package/lib/commonjs/ui/components/controlbar/Spacer.js +0 -21
  122. package/lib/commonjs/ui/components/controlbar/Spacer.js.map +0 -1
  123. package/lib/commonjs/ui/components/controlbar/barrel.js +0 -28
  124. package/lib/commonjs/ui/components/controlbar/barrel.js.map +0 -1
  125. package/lib/commonjs/ui/components/menu/LanguageMenuButton.js +0 -175
  126. package/lib/commonjs/ui/components/menu/LanguageMenuButton.js.map +0 -1
  127. package/lib/commonjs/ui/components/menu/PlaybackRateSubMenu.js +0 -91
  128. package/lib/commonjs/ui/components/menu/PlaybackRateSubMenu.js.map +0 -1
  129. package/lib/commonjs/ui/components/menu/QualitySubMenu.js +0 -145
  130. package/lib/commonjs/ui/components/menu/QualitySubMenu.js.map +0 -1
  131. package/lib/commonjs/ui/components/menu/SettingsMenuButton.js +0 -36
  132. package/lib/commonjs/ui/components/menu/SettingsMenuButton.js.map +0 -1
  133. package/lib/commonjs/ui/components/menu/barrel.js +0 -61
  134. package/lib/commonjs/ui/components/menu/barrel.js.map +0 -1
  135. package/lib/commonjs/ui/components/menu/common/MenuButton.js +0 -34
  136. package/lib/commonjs/ui/components/menu/common/MenuButton.js.map +0 -1
  137. package/lib/commonjs/ui/components/menu/common/MenuRadioButton.js +0 -47
  138. package/lib/commonjs/ui/components/menu/common/MenuRadioButton.js.map +0 -1
  139. package/lib/commonjs/ui/components/menu/common/MenuTitle.js +0 -38
  140. package/lib/commonjs/ui/components/menu/common/MenuTitle.js.map +0 -1
  141. package/lib/commonjs/ui/components/menu/common/MenuView.js +0 -75
  142. package/lib/commonjs/ui/components/menu/common/MenuView.js.map +0 -1
  143. package/lib/commonjs/ui/components/menu/common/ScrollableMenu.js +0 -45
  144. package/lib/commonjs/ui/components/menu/common/ScrollableMenu.js.map +0 -1
  145. package/lib/commonjs/ui/components/menu/common/SubMenuWithButton.js +0 -65
  146. package/lib/commonjs/ui/components/menu/common/SubMenuWithButton.js.map +0 -1
  147. package/lib/commonjs/ui/components/menu/common/barrel.js +0 -72
  148. package/lib/commonjs/ui/components/menu/common/barrel.js.map +0 -1
  149. package/lib/commonjs/ui/components/message/CastMessage.js +0 -79
  150. package/lib/commonjs/ui/components/message/CastMessage.js.map +0 -1
  151. package/lib/commonjs/ui/components/message/ErrorDisplay.js +0 -53
  152. package/lib/commonjs/ui/components/message/ErrorDisplay.js.map +0 -1
  153. package/lib/commonjs/ui/components/message/barrel.js +0 -28
  154. package/lib/commonjs/ui/components/message/barrel.js.map +0 -1
  155. package/lib/commonjs/ui/components/seekbar/SeekBar.js +0 -194
  156. package/lib/commonjs/ui/components/seekbar/SeekBar.js.map +0 -1
  157. package/lib/commonjs/ui/components/seekbar/barrel.js +0 -28
  158. package/lib/commonjs/ui/components/seekbar/barrel.js.map +0 -1
  159. package/lib/commonjs/ui/components/seekbar/thumbnail/SingleThumbnailView.js +0 -45
  160. package/lib/commonjs/ui/components/seekbar/thumbnail/SingleThumbnailView.js.map +0 -1
  161. package/lib/commonjs/ui/components/seekbar/thumbnail/Thumbnail.js +0 -18
  162. package/lib/commonjs/ui/components/seekbar/thumbnail/Thumbnail.js.map +0 -1
  163. package/lib/commonjs/ui/components/seekbar/thumbnail/ThumbnailView.js +0 -256
  164. package/lib/commonjs/ui/components/seekbar/thumbnail/ThumbnailView.js.map +0 -1
  165. package/lib/commonjs/ui/components/seekbar/thumbnail/Urlpolyfill.js +0 -17
  166. package/lib/commonjs/ui/components/seekbar/thumbnail/Urlpolyfill.js.map +0 -1
  167. package/lib/commonjs/ui/components/seekbar/thumbnail/Urlpolyfill.web.js +0 -10
  168. package/lib/commonjs/ui/components/seekbar/thumbnail/Urlpolyfill.web.js.map +0 -1
  169. package/lib/commonjs/ui/components/seekbar/thumbnail/barrel.js +0 -28
  170. package/lib/commonjs/ui/components/seekbar/thumbnail/barrel.js.map +0 -1
  171. package/lib/commonjs/ui/components/timelabel/StaticTimeLabel.js +0 -55
  172. package/lib/commonjs/ui/components/timelabel/StaticTimeLabel.js.map +0 -1
  173. package/lib/commonjs/ui/components/timelabel/TimeLabel.js +0 -88
  174. package/lib/commonjs/ui/components/timelabel/TimeLabel.js.map +0 -1
  175. package/lib/commonjs/ui/components/timelabel/barrel.js +0 -28
  176. package/lib/commonjs/ui/components/timelabel/barrel.js.map +0 -1
  177. package/lib/commonjs/ui/components/uicontroller/UiContainer.js +0 -350
  178. package/lib/commonjs/ui/components/uicontroller/UiContainer.js.map +0 -1
  179. package/lib/commonjs/ui/components/uicontroller/UiControls.js +0 -6
  180. package/lib/commonjs/ui/components/uicontroller/UiControls.js.map +0 -1
  181. package/lib/commonjs/ui/components/uicontroller/barrel.js +0 -28
  182. package/lib/commonjs/ui/components/uicontroller/barrel.js.map +0 -1
  183. package/lib/commonjs/ui/components/util/PlayerContext.js +0 -19
  184. package/lib/commonjs/ui/components/util/PlayerContext.js.map +0 -1
  185. package/lib/commonjs/ui/components/util/TrackUtils.js +0 -69
  186. package/lib/commonjs/ui/components/util/TrackUtils.js.map +0 -1
  187. package/lib/commonjs/ui/components/util/barrel.js +0 -17
  188. package/lib/commonjs/ui/components/util/barrel.js.map +0 -1
  189. package/lib/commonjs/ui/utils/ArrayUtils.js +0 -19
  190. package/lib/commonjs/ui/utils/ArrayUtils.js.map +0 -1
  191. package/lib/commonjs/ui/utils/language/Language.js +0 -38
  192. package/lib/commonjs/ui/utils/language/Language.js.map +0 -1
  193. package/lib/commonjs/ui/utils/language/languages.json +0 -1658
  194. package/lib/module/ui/THEOplayerDefaultUi.js +0 -74
  195. package/lib/module/ui/THEOplayerDefaultUi.js.map +0 -1
  196. package/lib/module/ui/THEOplayerTheme.js +0 -41
  197. package/lib/module/ui/THEOplayerTheme.js.map +0 -1
  198. package/lib/module/ui/barrel.js +0 -4
  199. package/lib/module/ui/barrel.js.map +0 -1
  200. package/lib/module/ui/components/activityindicator/CenteredDelayedActivityIndicator.js +0 -90
  201. package/lib/module/ui/components/activityindicator/CenteredDelayedActivityIndicator.js.map +0 -1
  202. package/lib/module/ui/components/activityindicator/DelayedActivityIndicator.js +0 -26
  203. package/lib/module/ui/components/activityindicator/DelayedActivityIndicator.js.map +0 -1
  204. package/lib/module/ui/components/activityindicator/barrel.js +0 -3
  205. package/lib/module/ui/components/activityindicator/barrel.js.map +0 -1
  206. package/lib/module/ui/components/barrel.js +0 -10
  207. package/lib/module/ui/components/barrel.js.map +0 -1
  208. package/lib/module/ui/components/button/AirplayButton.js +0 -72
  209. package/lib/module/ui/components/button/AirplayButton.js.map +0 -1
  210. package/lib/module/ui/components/button/ChromecastButton.js +0 -56
  211. package/lib/module/ui/components/button/ChromecastButton.js.map +0 -1
  212. package/lib/module/ui/components/button/ChromecastButton.web.js +0 -72
  213. package/lib/module/ui/components/button/ChromecastButton.web.js.map +0 -1
  214. package/lib/module/ui/components/button/FullscreenButton.js +0 -63
  215. package/lib/module/ui/components/button/FullscreenButton.js.map +0 -1
  216. package/lib/module/ui/components/button/MuteButton.js +0 -57
  217. package/lib/module/ui/components/button/MuteButton.js.map +0 -1
  218. package/lib/module/ui/components/button/PipButton.js +0 -63
  219. package/lib/module/ui/components/button/PipButton.js.map +0 -1
  220. package/lib/module/ui/components/button/PlayButton.js +0 -104
  221. package/lib/module/ui/components/button/PlayButton.js.map +0 -1
  222. package/lib/module/ui/components/button/SkipButton.js +0 -113
  223. package/lib/module/ui/components/button/SkipButton.js.map +0 -1
  224. package/lib/module/ui/components/button/actionbutton/ActionButton.js +0 -72
  225. package/lib/module/ui/components/button/actionbutton/ActionButton.js.map +0 -1
  226. package/lib/module/ui/components/button/barrel.js +0 -10
  227. package/lib/module/ui/components/button/barrel.js.map +0 -1
  228. package/lib/module/ui/components/button/svg/AirplaySvg.js +0 -12
  229. package/lib/module/ui/components/button/svg/AirplaySvg.js.map +0 -1
  230. package/lib/module/ui/components/button/svg/ArrowForwardSvg.js +0 -12
  231. package/lib/module/ui/components/button/svg/ArrowForwardSvg.js.map +0 -1
  232. package/lib/module/ui/components/button/svg/BackSvg.js +0 -12
  233. package/lib/module/ui/components/button/svg/BackSvg.js.map +0 -1
  234. package/lib/module/ui/components/button/svg/BackwardSvg.js +0 -12
  235. package/lib/module/ui/components/button/svg/BackwardSvg.js.map +0 -1
  236. package/lib/module/ui/components/button/svg/ChromecastSvg.js +0 -12
  237. package/lib/module/ui/components/button/svg/ChromecastSvg.js.map +0 -1
  238. package/lib/module/ui/components/button/svg/ErrorSvg.js +0 -12
  239. package/lib/module/ui/components/button/svg/ErrorSvg.js.map +0 -1
  240. package/lib/module/ui/components/button/svg/ForwardSvg.js +0 -12
  241. package/lib/module/ui/components/button/svg/ForwardSvg.js.map +0 -1
  242. package/lib/module/ui/components/button/svg/FullscreenEnterSvg.js +0 -12
  243. package/lib/module/ui/components/button/svg/FullscreenEnterSvg.js.map +0 -1
  244. package/lib/module/ui/components/button/svg/FullscreenExitSvg.js +0 -12
  245. package/lib/module/ui/components/button/svg/FullscreenExitSvg.js.map +0 -1
  246. package/lib/module/ui/components/button/svg/LanguageSvg.js +0 -12
  247. package/lib/module/ui/components/button/svg/LanguageSvg.js.map +0 -1
  248. package/lib/module/ui/components/button/svg/ListSvg.js +0 -12
  249. package/lib/module/ui/components/button/svg/ListSvg.js.map +0 -1
  250. package/lib/module/ui/components/button/svg/PauseSvg.js +0 -12
  251. package/lib/module/ui/components/button/svg/PauseSvg.js.map +0 -1
  252. package/lib/module/ui/components/button/svg/PipEnterSvg.js +0 -12
  253. package/lib/module/ui/components/button/svg/PipEnterSvg.js.map +0 -1
  254. package/lib/module/ui/components/button/svg/PipExitSvg.js +0 -12
  255. package/lib/module/ui/components/button/svg/PipExitSvg.js.map +0 -1
  256. package/lib/module/ui/components/button/svg/PlaySvg.js +0 -12
  257. package/lib/module/ui/components/button/svg/PlaySvg.js.map +0 -1
  258. package/lib/module/ui/components/button/svg/ReplaySvg.js +0 -12
  259. package/lib/module/ui/components/button/svg/ReplaySvg.js.map +0 -1
  260. package/lib/module/ui/components/button/svg/SettingsSvg.js +0 -12
  261. package/lib/module/ui/components/button/svg/SettingsSvg.js.map +0 -1
  262. package/lib/module/ui/components/button/svg/SvgUtils.js +0 -5
  263. package/lib/module/ui/components/button/svg/SvgUtils.js.map +0 -1
  264. package/lib/module/ui/components/button/svg/VolumeOffSvg.js +0 -12
  265. package/lib/module/ui/components/button/svg/VolumeOffSvg.js.map +0 -1
  266. package/lib/module/ui/components/button/svg/VolumeUpSvg.js +0 -12
  267. package/lib/module/ui/components/button/svg/VolumeUpSvg.js.map +0 -1
  268. package/lib/module/ui/components/button/svg/barrel.js +0 -21
  269. package/lib/module/ui/components/button/svg/barrel.js.map +0 -1
  270. package/lib/module/ui/components/button/svg/res/AirPlayButton.html +0 -6
  271. package/lib/module/ui/components/button/svg/res/Airplay.svg +0 -1
  272. package/lib/module/ui/components/button/svg/res/ChromecastButton.html +0 -25
  273. package/lib/module/ui/components/button/svg/res/arrow_forward.svg +0 -1
  274. package/lib/module/ui/components/button/svg/res/back.svg +0 -1
  275. package/lib/module/ui/components/button/svg/res/backward.svg +0 -1
  276. package/lib/module/ui/components/button/svg/res/chromecast-48px.svg +0 -1
  277. package/lib/module/ui/components/button/svg/res/close.svg +0 -1
  278. package/lib/module/ui/components/button/svg/res/error.svg +0 -1
  279. package/lib/module/ui/components/button/svg/res/forward.svg +0 -1
  280. package/lib/module/ui/components/button/svg/res/fullscreen-enter.svg +0 -1
  281. package/lib/module/ui/components/button/svg/res/fullscreen-exit.svg +0 -1
  282. package/lib/module/ui/components/button/svg/res/language.svg +0 -1
  283. package/lib/module/ui/components/button/svg/res/list.svg +0 -1
  284. package/lib/module/ui/components/button/svg/res/live.svg +0 -1
  285. package/lib/module/ui/components/button/svg/res/pause.svg +0 -1
  286. package/lib/module/ui/components/button/svg/res/pip_enter.svg +0 -1
  287. package/lib/module/ui/components/button/svg/res/pip_exit.svg +0 -1
  288. package/lib/module/ui/components/button/svg/res/play.svg +0 -1
  289. package/lib/module/ui/components/button/svg/res/replay.svg +0 -1
  290. package/lib/module/ui/components/button/svg/res/settings.svg +0 -1
  291. package/lib/module/ui/components/button/svg/res/skip-next.svg +0 -1
  292. package/lib/module/ui/components/button/svg/res/volume-high.svg +0 -1
  293. package/lib/module/ui/components/button/svg/res/volume-low.svg +0 -1
  294. package/lib/module/ui/components/button/svg/res/volume-off.svg +0 -1
  295. package/lib/module/ui/components/controlbar/ControlBar.js +0 -52
  296. package/lib/module/ui/components/controlbar/ControlBar.js.map +0 -1
  297. package/lib/module/ui/components/controlbar/Spacer.js +0 -14
  298. package/lib/module/ui/components/controlbar/Spacer.js.map +0 -1
  299. package/lib/module/ui/components/controlbar/barrel.js +0 -3
  300. package/lib/module/ui/components/controlbar/barrel.js.map +0 -1
  301. package/lib/module/ui/components/menu/LanguageMenuButton.js +0 -165
  302. package/lib/module/ui/components/menu/LanguageMenuButton.js.map +0 -1
  303. package/lib/module/ui/components/menu/PlaybackRateSubMenu.js +0 -80
  304. package/lib/module/ui/components/menu/PlaybackRateSubMenu.js.map +0 -1
  305. package/lib/module/ui/components/menu/QualitySubMenu.js +0 -135
  306. package/lib/module/ui/components/menu/QualitySubMenu.js.map +0 -1
  307. package/lib/module/ui/components/menu/SettingsMenuButton.js +0 -28
  308. package/lib/module/ui/components/menu/SettingsMenuButton.js.map +0 -1
  309. package/lib/module/ui/components/menu/barrel.js +0 -6
  310. package/lib/module/ui/components/menu/barrel.js.map +0 -1
  311. package/lib/module/ui/components/menu/common/MenuButton.js +0 -26
  312. package/lib/module/ui/components/menu/common/MenuButton.js.map +0 -1
  313. package/lib/module/ui/components/menu/common/MenuRadioButton.js +0 -38
  314. package/lib/module/ui/components/menu/common/MenuRadioButton.js.map +0 -1
  315. package/lib/module/ui/components/menu/common/MenuTitle.js +0 -29
  316. package/lib/module/ui/components/menu/common/MenuTitle.js.map +0 -1
  317. package/lib/module/ui/components/menu/common/MenuView.js +0 -65
  318. package/lib/module/ui/components/menu/common/MenuView.js.map +0 -1
  319. package/lib/module/ui/components/menu/common/ScrollableMenu.js +0 -36
  320. package/lib/module/ui/components/menu/common/ScrollableMenu.js.map +0 -1
  321. package/lib/module/ui/components/menu/common/SubMenuWithButton.js +0 -56
  322. package/lib/module/ui/components/menu/common/SubMenuWithButton.js.map +0 -1
  323. package/lib/module/ui/components/menu/common/barrel.js +0 -7
  324. package/lib/module/ui/components/menu/common/barrel.js.map +0 -1
  325. package/lib/module/ui/components/message/CastMessage.js +0 -70
  326. package/lib/module/ui/components/message/CastMessage.js.map +0 -1
  327. package/lib/module/ui/components/message/ErrorDisplay.js +0 -46
  328. package/lib/module/ui/components/message/ErrorDisplay.js.map +0 -1
  329. package/lib/module/ui/components/message/barrel.js +0 -3
  330. package/lib/module/ui/components/message/barrel.js.map +0 -1
  331. package/lib/module/ui/components/seekbar/SeekBar.js +0 -184
  332. package/lib/module/ui/components/seekbar/SeekBar.js.map +0 -1
  333. package/lib/module/ui/components/seekbar/barrel.js +0 -3
  334. package/lib/module/ui/components/seekbar/barrel.js.map +0 -1
  335. package/lib/module/ui/components/seekbar/thumbnail/SingleThumbnailView.js +0 -37
  336. package/lib/module/ui/components/seekbar/thumbnail/SingleThumbnailView.js.map +0 -1
  337. package/lib/module/ui/components/seekbar/thumbnail/Thumbnail.js +0 -11
  338. package/lib/module/ui/components/seekbar/thumbnail/Thumbnail.js.map +0 -1
  339. package/lib/module/ui/components/seekbar/thumbnail/ThumbnailView.js +0 -246
  340. package/lib/module/ui/components/seekbar/thumbnail/ThumbnailView.js.map +0 -1
  341. package/lib/module/ui/components/seekbar/thumbnail/Urlpolyfill.js +0 -2
  342. package/lib/module/ui/components/seekbar/thumbnail/Urlpolyfill.js.map +0 -1
  343. package/lib/module/ui/components/seekbar/thumbnail/Urlpolyfill.web.js +0 -4
  344. package/lib/module/ui/components/seekbar/thumbnail/Urlpolyfill.web.js.map +0 -1
  345. package/lib/module/ui/components/seekbar/thumbnail/barrel.js +0 -3
  346. package/lib/module/ui/components/seekbar/thumbnail/barrel.js.map +0 -1
  347. package/lib/module/ui/components/timelabel/StaticTimeLabel.js +0 -48
  348. package/lib/module/ui/components/timelabel/StaticTimeLabel.js.map +0 -1
  349. package/lib/module/ui/components/timelabel/TimeLabel.js +0 -78
  350. package/lib/module/ui/components/timelabel/TimeLabel.js.map +0 -1
  351. package/lib/module/ui/components/timelabel/barrel.js +0 -3
  352. package/lib/module/ui/components/timelabel/barrel.js.map +0 -1
  353. package/lib/module/ui/components/uicontroller/UiContainer.js +0 -336
  354. package/lib/module/ui/components/uicontroller/UiContainer.js.map +0 -1
  355. package/lib/module/ui/components/uicontroller/UiControls.js +0 -2
  356. package/lib/module/ui/components/uicontroller/UiControls.js.map +0 -1
  357. package/lib/module/ui/components/uicontroller/barrel.js +0 -3
  358. package/lib/module/ui/components/uicontroller/barrel.js.map +0 -1
  359. package/lib/module/ui/components/util/PlayerContext.js +0 -11
  360. package/lib/module/ui/components/util/PlayerContext.js.map +0 -1
  361. package/lib/module/ui/components/util/TrackUtils.js +0 -60
  362. package/lib/module/ui/components/util/TrackUtils.js.map +0 -1
  363. package/lib/module/ui/components/util/barrel.js +0 -2
  364. package/lib/module/ui/components/util/barrel.js.map +0 -1
  365. package/lib/module/ui/utils/ArrayUtils.js +0 -12
  366. package/lib/module/ui/utils/ArrayUtils.js.map +0 -1
  367. package/lib/module/ui/utils/language/Language.js +0 -27
  368. package/lib/module/ui/utils/language/Language.js.map +0 -1
  369. package/lib/module/ui/utils/language/languages.json +0 -1658
  370. package/lib/typescript/ui/THEOplayerDefaultUi.d.ts +0 -35
  371. package/lib/typescript/ui/THEOplayerTheme.d.ts +0 -84
  372. package/lib/typescript/ui/barrel.d.ts +0 -3
  373. package/lib/typescript/ui/components/activityindicator/CenteredDelayedActivityIndicator.d.ts +0 -25
  374. package/lib/typescript/ui/components/activityindicator/DelayedActivityIndicator.d.ts +0 -9
  375. package/lib/typescript/ui/components/activityindicator/barrel.d.ts +0 -2
  376. package/lib/typescript/ui/components/barrel.d.ts +0 -9
  377. package/lib/typescript/ui/components/button/AirplayButton.d.ts +0 -18
  378. package/lib/typescript/ui/components/button/ChromecastButton.d.ts +0 -19
  379. package/lib/typescript/ui/components/button/ChromecastButton.web.d.ts +0 -19
  380. package/lib/typescript/ui/components/button/FullscreenButton.d.ts +0 -17
  381. package/lib/typescript/ui/components/button/MuteButton.d.ts +0 -16
  382. package/lib/typescript/ui/components/button/PipButton.d.ts +0 -17
  383. package/lib/typescript/ui/components/button/PlayButton.d.ts +0 -28
  384. package/lib/typescript/ui/components/button/SkipButton.d.ts +0 -33
  385. package/lib/typescript/ui/components/button/actionbutton/ActionButton.d.ts +0 -41
  386. package/lib/typescript/ui/components/button/barrel.d.ts +0 -9
  387. package/lib/typescript/ui/components/button/svg/AirplaySvg.d.ts +0 -3
  388. package/lib/typescript/ui/components/button/svg/ArrowForwardSvg.d.ts +0 -3
  389. package/lib/typescript/ui/components/button/svg/BackSvg.d.ts +0 -3
  390. package/lib/typescript/ui/components/button/svg/BackwardSvg.d.ts +0 -3
  391. package/lib/typescript/ui/components/button/svg/ChromecastSvg.d.ts +0 -3
  392. package/lib/typescript/ui/components/button/svg/ErrorSvg.d.ts +0 -3
  393. package/lib/typescript/ui/components/button/svg/ForwardSvg.d.ts +0 -3
  394. package/lib/typescript/ui/components/button/svg/FullscreenEnterSvg.d.ts +0 -3
  395. package/lib/typescript/ui/components/button/svg/FullscreenExitSvg.d.ts +0 -3
  396. package/lib/typescript/ui/components/button/svg/LanguageSvg.d.ts +0 -3
  397. package/lib/typescript/ui/components/button/svg/ListSvg.d.ts +0 -3
  398. package/lib/typescript/ui/components/button/svg/PauseSvg.d.ts +0 -3
  399. package/lib/typescript/ui/components/button/svg/PipEnterSvg.d.ts +0 -3
  400. package/lib/typescript/ui/components/button/svg/PipExitSvg.d.ts +0 -3
  401. package/lib/typescript/ui/components/button/svg/PlaySvg.d.ts +0 -3
  402. package/lib/typescript/ui/components/button/svg/ReplaySvg.d.ts +0 -3
  403. package/lib/typescript/ui/components/button/svg/SettingsSvg.d.ts +0 -3
  404. package/lib/typescript/ui/components/button/svg/SvgUtils.d.ts +0 -3
  405. package/lib/typescript/ui/components/button/svg/VolumeOffSvg.d.ts +0 -3
  406. package/lib/typescript/ui/components/button/svg/VolumeUpSvg.d.ts +0 -3
  407. package/lib/typescript/ui/components/button/svg/barrel.d.ts +0 -20
  408. package/lib/typescript/ui/components/controlbar/ControlBar.d.ts +0 -39
  409. package/lib/typescript/ui/components/controlbar/Spacer.d.ts +0 -5
  410. package/lib/typescript/ui/components/controlbar/barrel.d.ts +0 -2
  411. package/lib/typescript/ui/components/menu/LanguageMenuButton.d.ts +0 -40
  412. package/lib/typescript/ui/components/menu/PlaybackRateSubMenu.d.ts +0 -36
  413. package/lib/typescript/ui/components/menu/QualitySubMenu.d.ts +0 -29
  414. package/lib/typescript/ui/components/menu/SettingsMenuButton.d.ts +0 -12
  415. package/lib/typescript/ui/components/menu/barrel.d.ts +0 -5
  416. package/lib/typescript/ui/components/menu/common/MenuButton.d.ts +0 -25
  417. package/lib/typescript/ui/components/menu/common/MenuRadioButton.d.ts +0 -33
  418. package/lib/typescript/ui/components/menu/common/MenuTitle.d.ts +0 -20
  419. package/lib/typescript/ui/components/menu/common/MenuView.d.ts +0 -21
  420. package/lib/typescript/ui/components/menu/common/ScrollableMenu.d.ts +0 -23
  421. package/lib/typescript/ui/components/menu/common/SubMenuWithButton.d.ts +0 -29
  422. package/lib/typescript/ui/components/menu/common/barrel.d.ts +0 -6
  423. package/lib/typescript/ui/components/message/CastMessage.d.ts +0 -16
  424. package/lib/typescript/ui/components/message/ErrorDisplay.d.ts +0 -12
  425. package/lib/typescript/ui/components/message/barrel.d.ts +0 -2
  426. package/lib/typescript/ui/components/seekbar/SeekBar.d.ts +0 -41
  427. package/lib/typescript/ui/components/seekbar/barrel.d.ts +0 -2
  428. package/lib/typescript/ui/components/seekbar/thumbnail/SingleThumbnailView.d.ts +0 -8
  429. package/lib/typescript/ui/components/seekbar/thumbnail/Thumbnail.d.ts +0 -56
  430. package/lib/typescript/ui/components/seekbar/thumbnail/ThumbnailView.d.ts +0 -60
  431. package/lib/typescript/ui/components/seekbar/thumbnail/Urlpolyfill.d.ts +0 -1
  432. package/lib/typescript/ui/components/seekbar/thumbnail/Urlpolyfill.web.d.ts +0 -8
  433. package/lib/typescript/ui/components/seekbar/thumbnail/barrel.d.ts +0 -2
  434. package/lib/typescript/ui/components/timelabel/StaticTimeLabel.d.ts +0 -24
  435. package/lib/typescript/ui/components/timelabel/TimeLabel.d.ts +0 -32
  436. package/lib/typescript/ui/components/timelabel/barrel.d.ts +0 -2
  437. package/lib/typescript/ui/components/uicontroller/UiContainer.d.ts +0 -115
  438. package/lib/typescript/ui/components/uicontroller/UiControls.d.ts +0 -14
  439. package/lib/typescript/ui/components/uicontroller/barrel.d.ts +0 -2
  440. package/lib/typescript/ui/components/util/PlayerContext.d.ts +0 -22
  441. package/lib/typescript/ui/components/util/TrackUtils.d.ts +0 -10
  442. package/lib/typescript/ui/components/util/barrel.d.ts +0 -1
  443. package/lib/typescript/ui/utils/ArrayUtils.d.ts +0 -2
  444. package/lib/typescript/ui/utils/language/Language.d.ts +0 -19
  445. package/src/ui/THEOplayerDefaultUi.tsx +0 -108
  446. package/src/ui/THEOplayerTheme.ts +0 -112
  447. package/src/ui/barrel.ts +0 -3
  448. package/src/ui/components/activityindicator/CenteredDelayedActivityIndicator.tsx +0 -96
  449. package/src/ui/components/activityindicator/DelayedActivityIndicator.tsx +0 -32
  450. package/src/ui/components/activityindicator/barrel.ts +0 -2
  451. package/src/ui/components/barrel.ts +0 -9
  452. package/src/ui/components/button/AirplayButton.tsx +0 -64
  453. package/src/ui/components/button/ChromecastButton.tsx +0 -60
  454. package/src/ui/components/button/ChromecastButton.web.tsx +0 -66
  455. package/src/ui/components/button/FullscreenButton.tsx +0 -60
  456. package/src/ui/components/button/MuteButton.tsx +0 -52
  457. package/src/ui/components/button/PipButton.tsx +0 -61
  458. package/src/ui/components/button/PlayButton.tsx +0 -107
  459. package/src/ui/components/button/SkipButton.tsx +0 -112
  460. package/src/ui/components/button/actionbutton/ActionButton.tsx +0 -105
  461. package/src/ui/components/button/barrel.ts +0 -9
  462. package/src/ui/components/button/svg/AirplaySvg.tsx +0 -18
  463. package/src/ui/components/button/svg/ArrowForwardSvg.tsx +0 -18
  464. package/src/ui/components/button/svg/BackSvg.tsx +0 -18
  465. package/src/ui/components/button/svg/BackwardSvg.tsx +0 -18
  466. package/src/ui/components/button/svg/ChromecastSvg.tsx +0 -18
  467. package/src/ui/components/button/svg/ErrorSvg.tsx +0 -18
  468. package/src/ui/components/button/svg/ForwardSvg.tsx +0 -18
  469. package/src/ui/components/button/svg/FullscreenEnterSvg.tsx +0 -18
  470. package/src/ui/components/button/svg/FullscreenExitSvg.tsx +0 -18
  471. package/src/ui/components/button/svg/LanguageSvg.tsx +0 -18
  472. package/src/ui/components/button/svg/ListSvg.tsx +0 -18
  473. package/src/ui/components/button/svg/PauseSvg.tsx +0 -18
  474. package/src/ui/components/button/svg/PipEnterSvg.tsx +0 -18
  475. package/src/ui/components/button/svg/PipExitSvg.tsx +0 -18
  476. package/src/ui/components/button/svg/PlaySvg.tsx +0 -18
  477. package/src/ui/components/button/svg/ReplaySvg.tsx +0 -18
  478. package/src/ui/components/button/svg/SettingsSvg.tsx +0 -18
  479. package/src/ui/components/button/svg/SvgUtils.ts +0 -4
  480. package/src/ui/components/button/svg/VolumeOffSvg.tsx +0 -18
  481. package/src/ui/components/button/svg/VolumeUpSvg.tsx +0 -18
  482. package/src/ui/components/button/svg/barrel.ts +0 -20
  483. package/src/ui/components/button/svg/res/AirPlayButton.html +0 -6
  484. package/src/ui/components/button/svg/res/Airplay.svg +0 -1
  485. package/src/ui/components/button/svg/res/ChromecastButton.html +0 -25
  486. package/src/ui/components/button/svg/res/arrow_forward.svg +0 -1
  487. package/src/ui/components/button/svg/res/back.svg +0 -1
  488. package/src/ui/components/button/svg/res/backward.svg +0 -1
  489. package/src/ui/components/button/svg/res/chromecast-48px.svg +0 -1
  490. package/src/ui/components/button/svg/res/close.svg +0 -1
  491. package/src/ui/components/button/svg/res/error.svg +0 -1
  492. package/src/ui/components/button/svg/res/forward.svg +0 -1
  493. package/src/ui/components/button/svg/res/fullscreen-enter.svg +0 -1
  494. package/src/ui/components/button/svg/res/fullscreen-exit.svg +0 -1
  495. package/src/ui/components/button/svg/res/language.svg +0 -1
  496. package/src/ui/components/button/svg/res/list.svg +0 -1
  497. package/src/ui/components/button/svg/res/live.svg +0 -1
  498. package/src/ui/components/button/svg/res/pause.svg +0 -1
  499. package/src/ui/components/button/svg/res/pip_enter.svg +0 -1
  500. package/src/ui/components/button/svg/res/pip_exit.svg +0 -1
  501. package/src/ui/components/button/svg/res/play.svg +0 -1
  502. package/src/ui/components/button/svg/res/replay.svg +0 -1
  503. package/src/ui/components/button/svg/res/settings.svg +0 -1
  504. package/src/ui/components/button/svg/res/skip-next.svg +0 -1
  505. package/src/ui/components/button/svg/res/volume-high.svg +0 -1
  506. package/src/ui/components/button/svg/res/volume-low.svg +0 -1
  507. package/src/ui/components/button/svg/res/volume-off.svg +0 -1
  508. package/src/ui/components/controlbar/ControlBar.tsx +0 -69
  509. package/src/ui/components/controlbar/Spacer.tsx +0 -9
  510. package/src/ui/components/controlbar/barrel.ts +0 -2
  511. package/src/ui/components/menu/LanguageMenuButton.tsx +0 -192
  512. package/src/ui/components/menu/PlaybackRateSubMenu.tsx +0 -93
  513. package/src/ui/components/menu/QualitySubMenu.tsx +0 -148
  514. package/src/ui/components/menu/SettingsMenuButton.tsx +0 -25
  515. package/src/ui/components/menu/barrel.ts +0 -5
  516. package/src/ui/components/menu/common/MenuButton.tsx +0 -49
  517. package/src/ui/components/menu/common/MenuRadioButton.tsx +0 -65
  518. package/src/ui/components/menu/common/MenuTitle.tsx +0 -37
  519. package/src/ui/components/menu/common/MenuView.tsx +0 -62
  520. package/src/ui/components/menu/common/ScrollableMenu.tsx +0 -43
  521. package/src/ui/components/menu/common/SubMenuWithButton.tsx +0 -58
  522. package/src/ui/components/menu/common/barrel.ts +0 -6
  523. package/src/ui/components/message/CastMessage.tsx +0 -74
  524. package/src/ui/components/message/ErrorDisplay.tsx +0 -43
  525. package/src/ui/components/message/barrel.ts +0 -2
  526. package/src/ui/components/seekbar/SeekBar.tsx +0 -178
  527. package/src/ui/components/seekbar/barrel.ts +0 -2
  528. package/src/ui/components/seekbar/thumbnail/SingleThumbnailView.tsx +0 -38
  529. package/src/ui/components/seekbar/thumbnail/Thumbnail.ts +0 -72
  530. package/src/ui/components/seekbar/thumbnail/ThumbnailView.tsx +0 -266
  531. package/src/ui/components/seekbar/thumbnail/Urlpolyfill.ts +0 -1
  532. package/src/ui/components/seekbar/thumbnail/Urlpolyfill.web.ts +0 -3
  533. package/src/ui/components/seekbar/thumbnail/barrel.ts +0 -2
  534. package/src/ui/components/timelabel/StaticTimeLabel.tsx +0 -63
  535. package/src/ui/components/timelabel/TimeLabel.tsx +0 -79
  536. package/src/ui/components/timelabel/barrel.ts +0 -2
  537. package/src/ui/components/uicontroller/UiContainer.tsx +0 -355
  538. package/src/ui/components/uicontroller/UiControls.ts +0 -31
  539. package/src/ui/components/uicontroller/barrel.ts +0 -2
  540. package/src/ui/components/util/PlayerContext.ts +0 -29
  541. package/src/ui/components/util/TrackUtils.ts +0 -62
  542. package/src/ui/components/util/barrel.ts +0 -1
  543. package/src/ui/utils/ArrayUtils.ts +0 -12
  544. package/src/ui/utils/language/Language.ts +0 -38
  545. package/src/ui/utils/language/languages.json +0 -1658
@@ -1,65 +0,0 @@
1
- import React, { useContext } from 'react';
2
- import { PlayerContext } from '../../util/PlayerContext';
3
- import { StyleSheet, Text, TouchableOpacity, View } from 'react-native';
4
- import { ControlBar } from '../../controlbar/ControlBar';
5
- import { TOP_UI_CONTAINER_STYLE } from '../../uicontroller/UiContainer';
6
- import { BackSvg } from '../../button/svg/BackSvg';
7
- import { ActionButton } from '../../button/actionbutton/ActionButton';
8
- /**
9
- * The default style for the menu view.
10
- */
11
- export const DEFAULT_MENU_VIEW_STYLE = {
12
- flex: 1,
13
- flexDirection: 'row',
14
- left: 0,
15
- right: 0,
16
- top: 0,
17
- bottom: 0,
18
- paddingVertical: 20,
19
- paddingLeft: 50,
20
- paddingRight: 40
21
- };
22
-
23
- /**
24
- * A component to render a fullscreen menu with a title and back button for the `react-native-theoplayer` UI.
25
- */
26
- export const MenuView = props => {
27
- const {
28
- menu,
29
- style
30
- } = props;
31
- const context = useContext(PlayerContext);
32
- const onClose = () => {
33
- context.ui.closeCurrentMenu_();
34
- };
35
- return /*#__PURE__*/React.createElement(PlayerContext.Consumer, null, context => /*#__PURE__*/React.createElement(View, {
36
- style: StyleSheet.absoluteFill
37
- }, /*#__PURE__*/React.createElement(ControlBar, {
38
- style: TOP_UI_CONTAINER_STYLE
39
- }, /*#__PURE__*/React.createElement(View, {
40
- style: {
41
- flexDirection: 'row'
42
- }
43
- }, /*#__PURE__*/React.createElement(TouchableOpacity, {
44
- style: {
45
- flexDirection: 'row'
46
- },
47
- onPress: onClose
48
- }, /*#__PURE__*/React.createElement(ActionButton, {
49
- touchable: false,
50
- svg: /*#__PURE__*/React.createElement(BackSvg, null)
51
- }), /*#__PURE__*/React.createElement(Text, {
52
- style: {
53
- color: context.style.colors.text,
54
- fontSize: 16,
55
- lineHeight: 30
56
- }
57
- }, "Back"))), /*#__PURE__*/React.createElement(View, {
58
- style: {
59
- flexGrow: 1
60
- }
61
- })), /*#__PURE__*/React.createElement(View, {
62
- style: [DEFAULT_MENU_VIEW_STYLE, style]
63
- }, menu)));
64
- };
65
- //# sourceMappingURL=MenuView.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["React","useContext","PlayerContext","StyleSheet","Text","TouchableOpacity","View","ControlBar","TOP_UI_CONTAINER_STYLE","BackSvg","ActionButton","DEFAULT_MENU_VIEW_STYLE","flex","flexDirection","left","right","top","bottom","paddingVertical","paddingLeft","paddingRight","MenuView","props","menu","style","context","onClose","ui","closeCurrentMenu_","createElement","Consumer","absoluteFill","onPress","touchable","svg","color","colors","text","fontSize","lineHeight","flexGrow"],"sources":["MenuView.tsx"],"sourcesContent":["import React, { ReactNode, useContext } from 'react';\nimport { PlayerContext, UiContext } from '../../util/PlayerContext';\nimport { StyleProp, StyleSheet, Text, TouchableOpacity, View, ViewStyle } from 'react-native';\nimport { ControlBar } from '../../controlbar/ControlBar';\nimport { TOP_UI_CONTAINER_STYLE } from '../../uicontroller/UiContainer';\nimport { BackSvg } from '../../button/svg/BackSvg';\nimport { ActionButton } from '../../button/actionbutton/ActionButton';\n\ninterface MenuViewProps {\n /**\n * The menu to render inside the menu view.\n */\n menu: ReactNode;\n /**\n * The style overrides for the menu view.\n */\n style?: StyleProp<ViewStyle>;\n}\n\n/**\n * The default style for the menu view.\n */\nexport const DEFAULT_MENU_VIEW_STYLE: ViewStyle = {\n flex: 1,\n flexDirection: 'row',\n left: 0,\n right: 0,\n top: 0,\n bottom: 0,\n paddingVertical: 20,\n paddingLeft: 50,\n paddingRight: 40,\n};\n\n/**\n * A component to render a fullscreen menu with a title and back button for the `react-native-theoplayer` UI.\n */\nexport const MenuView = (props: MenuViewProps) => {\n const { menu, style } = props;\n const context = useContext(PlayerContext);\n const onClose = () => {\n context.ui.closeCurrentMenu_();\n };\n return (\n <PlayerContext.Consumer>\n {(context: UiContext) => (\n <View style={StyleSheet.absoluteFill}>\n <ControlBar style={TOP_UI_CONTAINER_STYLE}>\n <View style={{ flexDirection: 'row' }}>\n <TouchableOpacity style={{ flexDirection: 'row' }} onPress={onClose}>\n <ActionButton touchable={false} svg={<BackSvg />} />\n <Text style={{ color: context.style.colors.text, fontSize: 16, lineHeight: 30 }}>Back</Text>\n </TouchableOpacity>\n </View>\n <View style={{ flexGrow: 1 }} />\n </ControlBar>\n <View style={[DEFAULT_MENU_VIEW_STYLE, style]}>{menu}</View>\n </View>\n )}\n </PlayerContext.Consumer>\n );\n};\n"],"mappings":"AAAA,OAAOA,KAAK,IAAeC,UAAU,QAAQ,OAAO;AACpD,SAASC,aAAa,QAAmB,0BAA0B;AACnE,SAAoBC,UAAU,EAAEC,IAAI,EAAEC,gBAAgB,EAAEC,IAAI,QAAmB,cAAc;AAC7F,SAASC,UAAU,QAAQ,6BAA6B;AACxD,SAASC,sBAAsB,QAAQ,gCAAgC;AACvE,SAASC,OAAO,QAAQ,0BAA0B;AAClD,SAASC,YAAY,QAAQ,wCAAwC;AAarE;AACA;AACA;AACA,OAAO,MAAMC,uBAAkC,GAAG;EAChDC,IAAI,EAAE,CAAC;EACPC,aAAa,EAAE,KAAK;EACpBC,IAAI,EAAE,CAAC;EACPC,KAAK,EAAE,CAAC;EACRC,GAAG,EAAE,CAAC;EACNC,MAAM,EAAE,CAAC;EACTC,eAAe,EAAE,EAAE;EACnBC,WAAW,EAAE,EAAE;EACfC,YAAY,EAAE;AAChB,CAAC;;AAED;AACA;AACA;AACA,OAAO,MAAMC,QAAQ,GAAIC,KAAoB,IAAK;EAChD,MAAM;IAAEC,IAAI;IAAEC;EAAM,CAAC,GAAGF,KAAK;EAC7B,MAAMG,OAAO,GAAGxB,UAAU,CAACC,aAAa,CAAC;EACzC,MAAMwB,OAAO,GAAGA,CAAA,KAAM;IACpBD,OAAO,CAACE,EAAE,CAACC,iBAAiB,EAAE;EAChC,CAAC;EACD,oBACE5B,KAAA,CAAA6B,aAAA,CAAC3B,aAAa,CAAC4B,QAAQ,QACnBL,OAAkB,iBAClBzB,KAAA,CAAA6B,aAAA,CAACvB,IAAI;IAACkB,KAAK,EAAErB,UAAU,CAAC4B;EAAa,gBACnC/B,KAAA,CAAA6B,aAAA,CAACtB,UAAU;IAACiB,KAAK,EAAEhB;EAAuB,gBACxCR,KAAA,CAAA6B,aAAA,CAACvB,IAAI;IAACkB,KAAK,EAAE;MAAEX,aAAa,EAAE;IAAM;EAAE,gBACpCb,KAAA,CAAA6B,aAAA,CAACxB,gBAAgB;IAACmB,KAAK,EAAE;MAAEX,aAAa,EAAE;IAAM,CAAE;IAACmB,OAAO,EAAEN;EAAQ,gBAClE1B,KAAA,CAAA6B,aAAA,CAACnB,YAAY;IAACuB,SAAS,EAAE,KAAM;IAACC,GAAG,eAAElC,KAAA,CAAA6B,aAAA,CAACpB,OAAO;EAAI,EAAG,eACpDT,KAAA,CAAA6B,aAAA,CAACzB,IAAI;IAACoB,KAAK,EAAE;MAAEW,KAAK,EAAEV,OAAO,CAACD,KAAK,CAACY,MAAM,CAACC,IAAI;MAAEC,QAAQ,EAAE,EAAE;MAAEC,UAAU,EAAE;IAAG;EAAE,GAAC,MAAI,CAAO,CAC3E,CACd,eACPvC,KAAA,CAAA6B,aAAA,CAACvB,IAAI;IAACkB,KAAK,EAAE;MAAEgB,QAAQ,EAAE;IAAE;EAAE,EAAG,CACrB,eACbxC,KAAA,CAAA6B,aAAA,CAACvB,IAAI;IAACkB,KAAK,EAAE,CAACb,uBAAuB,EAAEa,KAAK;EAAE,GAAED,IAAI,CAAQ,CAE/D,CACsB;AAE7B,CAAC"}
@@ -1,36 +0,0 @@
1
- import React from 'react';
2
- import { SafeAreaView, ScrollView, View } from 'react-native';
3
- import { MenuTitle } from './MenuTitle';
4
- /**
5
- * The default style for the scrollable menu.
6
- */
7
- export const DEFAULT_SCROLLABLE_MENU_STYLE = {
8
- flex: 1,
9
- left: 0,
10
- right: 0,
11
- top: 0,
12
- bottom: 0,
13
- paddingRight: 10
14
- };
15
-
16
- /**
17
- * A menu component that provides a ScrollView for menu items for the `react-native-theoplayer` UI.
18
- * @param props
19
- * @constructor
20
- */
21
- export const ScrollableMenu = props => {
22
- const {
23
- title,
24
- items
25
- } = props;
26
- return /*#__PURE__*/React.createElement(SafeAreaView, {
27
- style: DEFAULT_SCROLLABLE_MENU_STYLE
28
- }, /*#__PURE__*/React.createElement(MenuTitle, {
29
- label: title
30
- }), /*#__PURE__*/React.createElement(ScrollView, null, /*#__PURE__*/React.createElement(View, {
31
- style: {
32
- flexDirection: 'column'
33
- }
34
- }, items)));
35
- };
36
- //# sourceMappingURL=ScrollableMenu.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["React","SafeAreaView","ScrollView","View","MenuTitle","DEFAULT_SCROLLABLE_MENU_STYLE","flex","left","right","top","bottom","paddingRight","ScrollableMenu","props","title","items","createElement","style","label","flexDirection"],"sources":["ScrollableMenu.tsx"],"sourcesContent":["import React, { ReactNode } from 'react';\nimport { SafeAreaView, ScrollView, View, ViewStyle } from 'react-native';\nimport { MenuTitle } from './MenuTitle';\n\ninterface ScrollableMenuProps {\n /**\n * The title of the scrollable menu.\n */\n title: string;\n /**\n * The items to be put in the scrollable menu.\n */\n items?: ReactNode;\n}\n\n/**\n * The default style for the scrollable menu.\n */\nexport const DEFAULT_SCROLLABLE_MENU_STYLE: ViewStyle = {\n flex: 1,\n left: 0,\n right: 0,\n top: 0,\n bottom: 0,\n paddingRight: 10,\n};\n\n/**\n * A menu component that provides a ScrollView for menu items for the `react-native-theoplayer` UI.\n * @param props\n * @constructor\n */\nexport const ScrollableMenu = (props: ScrollableMenuProps) => {\n const { title, items } = props;\n return (\n <SafeAreaView style={DEFAULT_SCROLLABLE_MENU_STYLE}>\n <MenuTitle label={title} />\n <ScrollView>\n <View style={{ flexDirection: 'column' }}>{items}</View>\n </ScrollView>\n </SafeAreaView>\n );\n};\n"],"mappings":"AAAA,OAAOA,KAAK,MAAqB,OAAO;AACxC,SAASC,YAAY,EAAEC,UAAU,EAAEC,IAAI,QAAmB,cAAc;AACxE,SAASC,SAAS,QAAQ,aAAa;AAavC;AACA;AACA;AACA,OAAO,MAAMC,6BAAwC,GAAG;EACtDC,IAAI,EAAE,CAAC;EACPC,IAAI,EAAE,CAAC;EACPC,KAAK,EAAE,CAAC;EACRC,GAAG,EAAE,CAAC;EACNC,MAAM,EAAE,CAAC;EACTC,YAAY,EAAE;AAChB,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA,OAAO,MAAMC,cAAc,GAAIC,KAA0B,IAAK;EAC5D,MAAM;IAAEC,KAAK;IAAEC;EAAM,CAAC,GAAGF,KAAK;EAC9B,oBACEb,KAAA,CAAAgB,aAAA,CAACf,YAAY;IAACgB,KAAK,EAAEZ;EAA8B,gBACjDL,KAAA,CAAAgB,aAAA,CAACZ,SAAS;IAACc,KAAK,EAAEJ;EAAM,EAAG,eAC3Bd,KAAA,CAAAgB,aAAA,CAACd,UAAU,qBACTF,KAAA,CAAAgB,aAAA,CAACb,IAAI;IAACc,KAAK,EAAE;MAAEE,aAAa,EAAE;IAAS;EAAE,GAAEJ,KAAK,CAAQ,CAC7C,CACA;AAEnB,CAAC"}
@@ -1,56 +0,0 @@
1
- import { PlayerContext } from '../../util/PlayerContext';
2
- import { Text, TouchableOpacity, View } from 'react-native';
3
- import React, { useContext } from 'react';
4
- import { ArrowForwardSvg } from '../../button/svg/ArrowForwardSvg';
5
- import { DEFAULT_MENU_BUTTON_STYLE } from './MenuRadioButton';
6
- import { ActionButton } from '../../button/actionbutton/ActionButton';
7
- /**
8
- * A component that can be put inside a SettingsMenuButton to create a sub menu.
9
- */
10
- export const SubMenuWithButton = props => {
11
- const {
12
- style,
13
- textStyle,
14
- menuConstructor,
15
- label,
16
- preview
17
- } = props;
18
- const context = useContext(PlayerContext);
19
- const onTouch = () => {
20
- if (menuConstructor) {
21
- context.ui.openMenu_(menuConstructor);
22
- }
23
- };
24
- return /*#__PURE__*/React.createElement(PlayerContext.Consumer, null, context => /*#__PURE__*/React.createElement(View, {
25
- style: [{
26
- height: 44,
27
- flexDirection: 'row',
28
- width: '100%',
29
- justifyContent: 'center'
30
- }, style]
31
- }, /*#__PURE__*/React.createElement(Text, {
32
- style: [DEFAULT_MENU_BUTTON_STYLE, {
33
- color: context.style.colors.text,
34
- width: '30%'
35
- }, textStyle]
36
- }, label), /*#__PURE__*/React.createElement(View, {
37
- style: {
38
- flexDirection: 'row',
39
- width: '40%',
40
- justifyContent: 'flex-end'
41
- }
42
- }, /*#__PURE__*/React.createElement(TouchableOpacity, {
43
- style: {
44
- flexDirection: 'row'
45
- },
46
- onPress: onTouch
47
- }, /*#__PURE__*/React.createElement(Text, {
48
- style: [DEFAULT_MENU_BUTTON_STYLE, {
49
- color: context.style.colors.text
50
- }, textStyle]
51
- }, preview), /*#__PURE__*/React.createElement(ActionButton, {
52
- touchable: false,
53
- svg: /*#__PURE__*/React.createElement(ArrowForwardSvg, null)
54
- })))));
55
- };
56
- //# sourceMappingURL=SubMenuWithButton.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["PlayerContext","Text","TouchableOpacity","View","React","useContext","ArrowForwardSvg","DEFAULT_MENU_BUTTON_STYLE","ActionButton","SubMenuWithButton","props","style","textStyle","menuConstructor","label","preview","context","onTouch","ui","openMenu_","createElement","Consumer","height","flexDirection","width","justifyContent","color","colors","text","onPress","touchable","svg"],"sources":["SubMenuWithButton.tsx"],"sourcesContent":["import { PlayerContext, UiContext } from '../../util/PlayerContext';\nimport { StyleProp, Text, TextStyle, TouchableOpacity, View, ViewStyle } from 'react-native';\nimport React, { useContext } from 'react';\nimport { ArrowForwardSvg } from '../../button/svg/ArrowForwardSvg';\nimport type { MenuConstructor } from '../../uicontroller/UiControls';\nimport { DEFAULT_MENU_BUTTON_STYLE } from './MenuRadioButton';\nimport { ActionButton } from '../../button/actionbutton/ActionButton';\n\nexport interface SubMenuButtonProps {\n /**\n * The style overrides.\n */\n style?: StyleProp<ViewStyle>;\n /**\n * The style overrides for the text components.\n */\n textStyle?: StyleProp<TextStyle>;\n /**\n * The sub menu that will be opened.\n */\n menuConstructor: MenuConstructor;\n /**\n * The label for the sub menu button.\n */\n label: string;\n /**\n * A preview for the currently selected value before opening the sub menu.\n */\n preview: string;\n}\n\n/**\n * A component that can be put inside a SettingsMenuButton to create a sub menu.\n */\nexport const SubMenuWithButton = (props: SubMenuButtonProps) => {\n const { style, textStyle, menuConstructor, label, preview } = props;\n const context = useContext(PlayerContext);\n const onTouch = () => {\n if (menuConstructor) {\n context.ui.openMenu_(menuConstructor);\n }\n };\n return (\n <PlayerContext.Consumer>\n {(context: UiContext) => (\n <View style={[{ height: 44, flexDirection: 'row', width: '100%', justifyContent: 'center' }, style]}>\n <Text style={[DEFAULT_MENU_BUTTON_STYLE, { color: context.style.colors.text, width: '30%' }, textStyle]}>{label}</Text>\n <View style={{ flexDirection: 'row', width: '40%', justifyContent: 'flex-end' }}>\n <TouchableOpacity style={{ flexDirection: 'row' }} onPress={onTouch}>\n <Text style={[DEFAULT_MENU_BUTTON_STYLE, { color: context.style.colors.text }, textStyle]}>{preview}</Text>\n <ActionButton touchable={false} svg={<ArrowForwardSvg />} />\n </TouchableOpacity>\n </View>\n </View>\n )}\n </PlayerContext.Consumer>\n );\n};\n"],"mappings":"AAAA,SAASA,aAAa,QAAmB,0BAA0B;AACnE,SAAoBC,IAAI,EAAaC,gBAAgB,EAAEC,IAAI,QAAmB,cAAc;AAC5F,OAAOC,KAAK,IAAIC,UAAU,QAAQ,OAAO;AACzC,SAASC,eAAe,QAAQ,kCAAkC;AAElE,SAASC,yBAAyB,QAAQ,mBAAmB;AAC7D,SAASC,YAAY,QAAQ,wCAAwC;AAyBrE;AACA;AACA;AACA,OAAO,MAAMC,iBAAiB,GAAIC,KAAyB,IAAK;EAC9D,MAAM;IAAEC,KAAK;IAAEC,SAAS;IAAEC,eAAe;IAAEC,KAAK;IAAEC;EAAQ,CAAC,GAAGL,KAAK;EACnE,MAAMM,OAAO,GAAGX,UAAU,CAACL,aAAa,CAAC;EACzC,MAAMiB,OAAO,GAAGA,CAAA,KAAM;IACpB,IAAIJ,eAAe,EAAE;MACnBG,OAAO,CAACE,EAAE,CAACC,SAAS,CAACN,eAAe,CAAC;IACvC;EACF,CAAC;EACD,oBACET,KAAA,CAAAgB,aAAA,CAACpB,aAAa,CAACqB,QAAQ,QACnBL,OAAkB,iBAClBZ,KAAA,CAAAgB,aAAA,CAACjB,IAAI;IAACQ,KAAK,EAAE,CAAC;MAAEW,MAAM,EAAE,EAAE;MAAEC,aAAa,EAAE,KAAK;MAAEC,KAAK,EAAE,MAAM;MAAEC,cAAc,EAAE;IAAS,CAAC,EAAEd,KAAK;EAAE,gBAClGP,KAAA,CAAAgB,aAAA,CAACnB,IAAI;IAACU,KAAK,EAAE,CAACJ,yBAAyB,EAAE;MAAEmB,KAAK,EAAEV,OAAO,CAACL,KAAK,CAACgB,MAAM,CAACC,IAAI;MAAEJ,KAAK,EAAE;IAAM,CAAC,EAAEZ,SAAS;EAAE,GAAEE,KAAK,CAAQ,eACvHV,KAAA,CAAAgB,aAAA,CAACjB,IAAI;IAACQ,KAAK,EAAE;MAAEY,aAAa,EAAE,KAAK;MAAEC,KAAK,EAAE,KAAK;MAAEC,cAAc,EAAE;IAAW;EAAE,gBAC9ErB,KAAA,CAAAgB,aAAA,CAAClB,gBAAgB;IAACS,KAAK,EAAE;MAAEY,aAAa,EAAE;IAAM,CAAE;IAACM,OAAO,EAAEZ;EAAQ,gBAClEb,KAAA,CAAAgB,aAAA,CAACnB,IAAI;IAACU,KAAK,EAAE,CAACJ,yBAAyB,EAAE;MAAEmB,KAAK,EAAEV,OAAO,CAACL,KAAK,CAACgB,MAAM,CAACC;IAAK,CAAC,EAAEhB,SAAS;EAAE,GAAEG,OAAO,CAAQ,eAC3GX,KAAA,CAAAgB,aAAA,CAACZ,YAAY;IAACsB,SAAS,EAAE,KAAM;IAACC,GAAG,eAAE3B,KAAA,CAAAgB,aAAA,CAACd,eAAe;EAAI,EAAG,CAC3C,CACd,CAEV,CACsB;AAE7B,CAAC"}
@@ -1,7 +0,0 @@
1
- export * from './MenuButton';
2
- export * from './MenuTitle';
3
- export * from './MenuView';
4
- export * from './MenuRadioButton';
5
- export * from './ScrollableMenu';
6
- export * from './SubMenuWithButton';
7
- //# sourceMappingURL=barrel.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":[],"sources":["barrel.ts"],"sourcesContent":["export * from './MenuButton';\nexport * from './MenuTitle';\nexport * from './MenuView';\nexport * from './MenuRadioButton';\nexport * from './ScrollableMenu';\nexport * from './SubMenuWithButton';\n"],"mappings":"AAAA,cAAc,cAAc;AAC5B,cAAc,aAAa;AAC3B,cAAc,YAAY;AAC1B,cAAc,mBAAmB;AACjC,cAAc,kBAAkB;AAChC,cAAc,qBAAqB"}
@@ -1,70 +0,0 @@
1
- function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
2
- function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
3
- function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
4
- import React, { PureComponent } from 'react';
5
- import { CastEventType, PlayerEventType } from 'react-native-theoplayer';
6
- import { Text } from 'react-native';
7
- import { PlayerContext } from '../util/PlayerContext';
8
- /**
9
- * A simple cast message showing the current state of casting for the `react-native-theoplayer` UI.
10
- */
11
- export class CastMessage extends PureComponent {
12
- constructor(props) {
13
- super(props);
14
- _defineProperty(this, "_processCastState", (state, target) => {
15
- let message;
16
- switch (state) {
17
- case 'connecting':
18
- message = `Connecting to ${target} ...`;
19
- break;
20
- case 'connected':
21
- message = `Playing on ${target}`;
22
- break;
23
- }
24
- this.setState({
25
- message
26
- });
27
- });
28
- _defineProperty(this, "onCastEvent", event => {
29
- if (event.subType !== CastEventType.CHROMECAST_STATE_CHANGE && event.subType !== CastEventType.AIRPLAY_STATE_CHANGE) {
30
- return;
31
- }
32
- const castTarget = event.subType === CastEventType.CHROMECAST_STATE_CHANGE ? 'Chromecast' : 'Airplay';
33
- this._processCastState(event.state, castTarget);
34
- });
35
- this.state = {
36
- message: undefined
37
- };
38
- }
39
- componentDidMount() {
40
- var _player$cast$chromeca, _player$cast$airplay;
41
- const player = this.context.player;
42
- player.addEventListener(PlayerEventType.CAST_EVENT, this.onCastEvent);
43
- const chromecastState = (_player$cast$chromeca = player.cast.chromecast) === null || _player$cast$chromeca === void 0 ? void 0 : _player$cast$chromeca.state;
44
- const airplayState = (_player$cast$airplay = player.cast.airplay) === null || _player$cast$airplay === void 0 ? void 0 : _player$cast$airplay.state;
45
- if (chromecastState === 'connecting' || chromecastState === 'connected') {
46
- this._processCastState(chromecastState, 'Chromecast');
47
- } else if (airplayState === 'connecting' || airplayState === 'connected') {
48
- this._processCastState(airplayState, 'Airplay');
49
- }
50
- }
51
- componentWillUnmount() {
52
- const context = this.context;
53
- context.player.removeEventListener(PlayerEventType.CAST_EVENT, this.onCastEvent);
54
- }
55
- render() {
56
- const {
57
- message
58
- } = this.state;
59
- if (!message) {
60
- return /*#__PURE__*/React.createElement(React.Fragment, null);
61
- }
62
- return /*#__PURE__*/React.createElement(PlayerContext.Consumer, null, context => /*#__PURE__*/React.createElement(Text, {
63
- style: [context.style.text, {
64
- color: context.style.colors.text
65
- }]
66
- }, message));
67
- }
68
- }
69
- CastMessage.contextType = PlayerContext;
70
- //# sourceMappingURL=CastMessage.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["React","PureComponent","CastEventType","PlayerEventType","Text","PlayerContext","CastMessage","constructor","props","_defineProperty","state","target","message","setState","event","subType","CHROMECAST_STATE_CHANGE","AIRPLAY_STATE_CHANGE","castTarget","_processCastState","undefined","componentDidMount","_player$cast$chromeca","_player$cast$airplay","player","context","addEventListener","CAST_EVENT","onCastEvent","chromecastState","cast","chromecast","airplayState","airplay","componentWillUnmount","removeEventListener","render","createElement","Fragment","Consumer","style","text","color","colors","contextType"],"sources":["CastMessage.tsx"],"sourcesContent":["import React, { PureComponent } from 'react';\nimport { CastEvent, CastEventType, CastState, PlayerEventType } from 'react-native-theoplayer';\nimport { Text } from 'react-native';\nimport { PlayerContext, UiContext } from '../util/PlayerContext';\n\ninterface CastMessageState {\n message: string | undefined;\n}\n\n/**\n * A simple cast message showing the current state of casting for the `react-native-theoplayer` UI.\n */\nexport class CastMessage extends PureComponent<unknown, CastMessageState> {\n constructor(props: unknown) {\n super(props);\n this.state = { message: undefined };\n }\n\n componentDidMount() {\n const player = (this.context as UiContext).player;\n player.addEventListener(PlayerEventType.CAST_EVENT, this.onCastEvent);\n const chromecastState = player.cast.chromecast?.state;\n const airplayState = player.cast.airplay?.state;\n if (chromecastState === 'connecting' || chromecastState === 'connected') {\n this._processCastState(chromecastState, 'Chromecast');\n } else if (airplayState === 'connecting' || airplayState === 'connected') {\n this._processCastState(airplayState, 'Airplay');\n }\n }\n\n componentWillUnmount() {\n const context = this.context as UiContext;\n context.player.removeEventListener(PlayerEventType.CAST_EVENT, this.onCastEvent);\n }\n\n private _processCastState = (state: CastState, target: 'Chromecast' | 'Airplay') => {\n let message: string | undefined;\n switch (state) {\n case 'connecting':\n message = `Connecting to ${target} ...`;\n break;\n case 'connected':\n message = `Playing on ${target}`;\n break;\n }\n this.setState({\n message,\n });\n };\n\n private onCastEvent = (event: CastEvent) => {\n if (event.subType !== CastEventType.CHROMECAST_STATE_CHANGE && event.subType !== CastEventType.AIRPLAY_STATE_CHANGE) {\n return;\n }\n const castTarget = event.subType === CastEventType.CHROMECAST_STATE_CHANGE ? 'Chromecast' : 'Airplay';\n this._processCastState(event.state, castTarget);\n };\n\n render() {\n const { message } = this.state;\n\n if (!message) {\n return <></>;\n }\n\n return (\n <PlayerContext.Consumer>\n {(context: UiContext) => <Text style={[context.style.text, { color: context.style.colors.text }]}>{message}</Text>}\n </PlayerContext.Consumer>\n );\n }\n}\n\nCastMessage.contextType = PlayerContext;\n"],"mappings":"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"}
@@ -1,46 +0,0 @@
1
- import React from 'react';
2
- import { Text, View } from 'react-native';
3
- import { PlayerContext } from '../util/PlayerContext';
4
- import { SvgContext } from '../button/svg/SvgUtils';
5
- import { ErrorSvg } from '../button/svg/ErrorSvg';
6
- import { FULLSCREEN_CENTER_STYLE } from '../uicontroller/UiContainer';
7
- /**
8
- * A fullscreen error component for the `react-native-theoplayer` UI.
9
- */
10
- export function ErrorDisplay(props) {
11
- const {
12
- error
13
- } = props;
14
- return /*#__PURE__*/React.createElement(PlayerContext.Consumer, null, context => /*#__PURE__*/React.createElement(View, {
15
- style: [FULLSCREEN_CENTER_STYLE, {
16
- backgroundColor: context.style.colors.errorBackground
17
- }]
18
- }, /*#__PURE__*/React.createElement(View, {
19
- style: {
20
- flexDirection: 'row'
21
- }
22
- }, /*#__PURE__*/React.createElement(SvgContext.Provider, {
23
- value: {
24
- fill: context.style.colors.icon,
25
- height: '100%',
26
- width: '100%'
27
- }
28
- }, /*#__PURE__*/React.createElement(View, {
29
- style: {
30
- height: context.style.dimensions.controlBarHeight,
31
- aspectRatio: 1,
32
- padding: 5
33
- }
34
- }, /*#__PURE__*/React.createElement(ErrorSvg, null))), /*#__PURE__*/React.createElement(Text, {
35
- style: [context.style.text, {
36
- color: context.style.colors.text,
37
- alignSelf: 'center',
38
- paddingLeft: 5
39
- }]
40
- }, "Error:")), /*#__PURE__*/React.createElement(Text, {
41
- style: [context.style.text, {
42
- color: context.style.colors.text
43
- }]
44
- }, error.errorMessage)));
45
- }
46
- //# sourceMappingURL=ErrorDisplay.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["React","Text","View","PlayerContext","SvgContext","ErrorSvg","FULLSCREEN_CENTER_STYLE","ErrorDisplay","props","error","createElement","Consumer","context","style","backgroundColor","colors","errorBackground","flexDirection","Provider","value","fill","icon","height","width","dimensions","controlBarHeight","aspectRatio","padding","text","color","alignSelf","paddingLeft","errorMessage"],"sources":["ErrorDisplay.tsx"],"sourcesContent":["import React from 'react';\nimport { Text, View } from 'react-native';\nimport type { PlayerError } from 'react-native-theoplayer';\nimport { PlayerContext, UiContext } from '../util/PlayerContext';\nimport { SvgContext } from '../button/svg/SvgUtils';\nimport { ErrorSvg } from '../button/svg/ErrorSvg';\nimport { FULLSCREEN_CENTER_STYLE } from '../uicontroller/UiContainer';\n\nexport interface ErrorDisplayProps {\n /**\n * The error that will be displayed.\n */\n error: PlayerError;\n}\n\n/**\n * A fullscreen error component for the `react-native-theoplayer` UI.\n */\nexport function ErrorDisplay(props: ErrorDisplayProps) {\n const { error } = props;\n return (\n <PlayerContext.Consumer>\n {(context: UiContext) => (\n <View style={[FULLSCREEN_CENTER_STYLE, { backgroundColor: context.style.colors.errorBackground }]}>\n <View style={{ flexDirection: 'row' }}>\n <SvgContext.Provider\n value={{\n fill: context.style.colors.icon,\n height: '100%',\n width: '100%',\n }}>\n <View style={{ height: context.style.dimensions.controlBarHeight, aspectRatio: 1, padding: 5 }}>\n <ErrorSvg />\n </View>\n </SvgContext.Provider>\n <Text style={[context.style.text, { color: context.style.colors.text, alignSelf: 'center', paddingLeft: 5 }]}>Error:</Text>\n </View>\n <Text style={[context.style.text, { color: context.style.colors.text }]}>{error.errorMessage}</Text>\n </View>\n )}\n </PlayerContext.Consumer>\n );\n}\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,IAAI,EAAEC,IAAI,QAAQ,cAAc;AAEzC,SAASC,aAAa,QAAmB,uBAAuB;AAChE,SAASC,UAAU,QAAQ,wBAAwB;AACnD,SAASC,QAAQ,QAAQ,wBAAwB;AACjD,SAASC,uBAAuB,QAAQ,6BAA6B;AASrE;AACA;AACA;AACA,OAAO,SAASC,YAAYA,CAACC,KAAwB,EAAE;EACrD,MAAM;IAAEC;EAAM,CAAC,GAAGD,KAAK;EACvB,oBACER,KAAA,CAAAU,aAAA,CAACP,aAAa,CAACQ,QAAQ,QACnBC,OAAkB,iBAClBZ,KAAA,CAAAU,aAAA,CAACR,IAAI;IAACW,KAAK,EAAE,CAACP,uBAAuB,EAAE;MAAEQ,eAAe,EAAEF,OAAO,CAACC,KAAK,CAACE,MAAM,CAACC;IAAgB,CAAC;EAAE,gBAChGhB,KAAA,CAAAU,aAAA,CAACR,IAAI;IAACW,KAAK,EAAE;MAAEI,aAAa,EAAE;IAAM;EAAE,gBACpCjB,KAAA,CAAAU,aAAA,CAACN,UAAU,CAACc,QAAQ;IAClBC,KAAK,EAAE;MACLC,IAAI,EAAER,OAAO,CAACC,KAAK,CAACE,MAAM,CAACM,IAAI;MAC/BC,MAAM,EAAE,MAAM;MACdC,KAAK,EAAE;IACT;EAAE,gBACFvB,KAAA,CAAAU,aAAA,CAACR,IAAI;IAACW,KAAK,EAAE;MAAES,MAAM,EAAEV,OAAO,CAACC,KAAK,CAACW,UAAU,CAACC,gBAAgB;MAAEC,WAAW,EAAE,CAAC;MAAEC,OAAO,EAAE;IAAE;EAAE,gBAC7F3B,KAAA,CAAAU,aAAA,CAACL,QAAQ,OAAG,CACP,CACa,eACtBL,KAAA,CAAAU,aAAA,CAACT,IAAI;IAACY,KAAK,EAAE,CAACD,OAAO,CAACC,KAAK,CAACe,IAAI,EAAE;MAAEC,KAAK,EAAEjB,OAAO,CAACC,KAAK,CAACE,MAAM,CAACa,IAAI;MAAEE,SAAS,EAAE,QAAQ;MAAEC,WAAW,EAAE;IAAE,CAAC;EAAE,GAAC,QAAM,CAAO,CACtH,eACP/B,KAAA,CAAAU,aAAA,CAACT,IAAI;IAACY,KAAK,EAAE,CAACD,OAAO,CAACC,KAAK,CAACe,IAAI,EAAE;MAAEC,KAAK,EAAEjB,OAAO,CAACC,KAAK,CAACE,MAAM,CAACa;IAAK,CAAC;EAAE,GAAEnB,KAAK,CAACuB,YAAY,CAAQ,CAEvG,CACsB;AAE7B"}
@@ -1,3 +0,0 @@
1
- export * from './CastMessage';
2
- export * from './ErrorDisplay';
3
- //# sourceMappingURL=barrel.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":[],"sources":["barrel.ts"],"sourcesContent":["export * from './CastMessage';\nexport * from './ErrorDisplay';\n"],"mappings":"AAAA,cAAc,eAAe;AAC7B,cAAc,gBAAgB"}
@@ -1,184 +0,0 @@
1
- function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
2
- function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
3
- function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
4
- import React, { PureComponent } from 'react';
5
- import { StyleSheet, View } from 'react-native';
6
- import { PlayerEventType } from 'react-native-theoplayer';
7
- import { PlayerContext } from '../util/PlayerContext';
8
- import Slider from '@react-native-community/slider';
9
- import { SingleThumbnailView } from './thumbnail/SingleThumbnailView';
10
- /**
11
- * The default seek bar component for the `react-native-theoplayer` UI.
12
- */
13
- export class SeekBar extends PureComponent {
14
- constructor(props) {
15
- var _this;
16
- super(props);
17
- _this = this;
18
- _defineProperty(this, "_seekBlockingTimeout", void 0);
19
- _defineProperty(this, "_clearIsScrubbingTimout", void 0);
20
- _defineProperty(this, "_onTimeUpdate", event => {
21
- if (!this.state.ignoreTimeupdate) {
22
- this.setState({
23
- sliderTime: event.currentTime
24
- });
25
- }
26
- });
27
- _defineProperty(this, "_onLoadedMetadata", event => this.setState({
28
- duration: event.duration
29
- }));
30
- _defineProperty(this, "_onDurationChange", event => this.setState({
31
- duration: event.duration
32
- }));
33
- _defineProperty(this, "_onProgress", event => this.setState({
34
- seekable: event.seekable
35
- }));
36
- _defineProperty(this, "_onSlidingStart", value => {
37
- this.setState({
38
- sliderTime: value
39
- });
40
- this._prepareSeekStart();
41
- const player = this.context.player;
42
- if (!player.paused) {
43
- this.debounceSeek(value);
44
- player.pause();
45
- this.setState({
46
- pausedDueToScrubbing: true
47
- });
48
- }
49
- });
50
- _defineProperty(this, "_onValueChange", value => {
51
- this.setState({
52
- sliderTime: value
53
- });
54
- if (this.state.ignoreTimeupdate) {
55
- this.debounceSeek(value);
56
- }
57
- });
58
- _defineProperty(this, "_onSlidingComplete", value => {
59
- this.setState({
60
- sliderTime: value
61
- });
62
- this.debounceSeek(value, true);
63
- const player = this.context.player;
64
- const isEnded = player.currentTime === player.duration;
65
- if (this.state.pausedDueToScrubbing && !isEnded) {
66
- player.play();
67
- this.setState({
68
- pausedDueToScrubbing: false
69
- });
70
- }
71
- this._finishSeek();
72
- });
73
- _defineProperty(this, "_prepareSeekStart", () => {
74
- this.setState({
75
- isSeeking: true,
76
- ignoreTimeupdate: true
77
- });
78
- clearTimeout(this._clearIsScrubbingTimout);
79
- });
80
- _defineProperty(this, "_finishSeek", () => {
81
- this.setState({
82
- isSeeking: false
83
- });
84
- // Wait for timeupdate events to settle after seeking, so the Slider does not jump back and forth.
85
- this._clearIsScrubbingTimout = setTimeout(() => {
86
- this.setState({
87
- ignoreTimeupdate: false
88
- });
89
- }, 1000);
90
- });
91
- _defineProperty(this, "debounceSeek", function (value) {
92
- let force = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
93
- // Don't bombard the player with seeks when seeking. Allow only one seek ever X milliseconds:
94
- const MAX_SEEK_INTERVAL = 200;
95
- if (force || _this._seekBlockingTimeout === undefined) {
96
- if (force) {
97
- clearTimeout(_this._seekBlockingTimeout);
98
- _this._seekBlockingTimeout = undefined;
99
- }
100
- _this._seekBlockingTimeout = setTimeout(() => {
101
- _this._seekBlockingTimeout = undefined;
102
- }, MAX_SEEK_INTERVAL);
103
- // Do seek
104
- const player = _this.context.player;
105
- player.currentTime = value;
106
- }
107
- });
108
- this.state = SeekBar.initialState;
109
- }
110
- componentDidMount() {
111
- const player = this.context.player;
112
- player.addEventListener(PlayerEventType.LOADED_METADATA, this._onLoadedMetadata);
113
- player.addEventListener(PlayerEventType.DURATION_CHANGE, this._onDurationChange);
114
- player.addEventListener(PlayerEventType.TIME_UPDATE, this._onTimeUpdate);
115
- player.addEventListener(PlayerEventType.PROGRESS, this._onProgress);
116
- this.setState({
117
- ...SeekBar.initialState,
118
- sliderTime: player.currentTime,
119
- duration: player.duration,
120
- seekable: player.seekable
121
- });
122
- }
123
- componentWillUnmount() {
124
- const context = this.context;
125
- context.player.removeEventListener(PlayerEventType.LOADED_METADATA, this._onLoadedMetadata);
126
- context.player.removeEventListener(PlayerEventType.DURATION_CHANGE, this._onDurationChange);
127
- context.player.removeEventListener(PlayerEventType.TIME_UPDATE, this._onTimeUpdate);
128
- context.player.removeEventListener(PlayerEventType.PROGRESS, this._onProgress);
129
- clearTimeout(this._seekBlockingTimeout);
130
- clearTimeout(this._clearIsScrubbingTimout);
131
- }
132
- render() {
133
- const {
134
- seekable,
135
- sliderTime,
136
- duration,
137
- isSeeking,
138
- width
139
- } = this.state;
140
- const {
141
- style
142
- } = this.props;
143
- const seekableStart = seekable.length > 0 ? seekable[0].start : 0;
144
- const seekableEnd = seekable.length > 0 ? seekable[0].end : 0;
145
- return /*#__PURE__*/React.createElement(PlayerContext.Consumer, null, context => /*#__PURE__*/React.createElement(View, {
146
- style: [StyleSheet.absoluteFill, style],
147
- onLayout: event => {
148
- this.setState({
149
- width: event.nativeEvent.layout.width
150
- });
151
- }
152
- }, isSeeking && /*#__PURE__*/React.createElement(SingleThumbnailView, {
153
- seekableStart: seekableStart,
154
- seekableEnd: seekableEnd,
155
- currentTime: sliderTime,
156
- seekBarWidth: width
157
- }), /*#__PURE__*/React.createElement(Slider, {
158
- disabled: !(duration > 0) && seekable.length > 0,
159
- style: [StyleSheet.absoluteFill, style],
160
- minimumValue: seekableStart,
161
- maximumValue: seekableEnd,
162
- step: 1000,
163
- onSlidingStart: this._onSlidingStart,
164
- onValueChange: this._onValueChange,
165
- onSlidingComplete: this._onSlidingComplete,
166
- value: sliderTime,
167
- focusable: true,
168
- minimumTrackTintColor: context.style.colors.seekBarMinimum,
169
- maximumTrackTintColor: context.style.colors.seekBarMaximum,
170
- thumbTintColor: context.style.colors.seekBarDot
171
- })));
172
- }
173
- }
174
- _defineProperty(SeekBar, "initialState", {
175
- ignoreTimeupdate: false,
176
- isSeeking: false,
177
- sliderTime: 0,
178
- duration: 0,
179
- seekable: [],
180
- pausedDueToScrubbing: false,
181
- width: 0
182
- });
183
- SeekBar.contextType = PlayerContext;
184
- //# sourceMappingURL=SeekBar.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["React","PureComponent","StyleSheet","View","PlayerEventType","PlayerContext","Slider","SingleThumbnailView","SeekBar","constructor","props","_this","this","_defineProperty","event","state","ignoreTimeupdate","setState","sliderTime","currentTime","duration","seekable","value","_prepareSeekStart","player","context","paused","debounceSeek","pause","pausedDueToScrubbing","isEnded","play","_finishSeek","isSeeking","clearTimeout","_clearIsScrubbingTimout","setTimeout","force","arguments","length","undefined","MAX_SEEK_INTERVAL","_seekBlockingTimeout","initialState","componentDidMount","addEventListener","LOADED_METADATA","_onLoadedMetadata","DURATION_CHANGE","_onDurationChange","TIME_UPDATE","_onTimeUpdate","PROGRESS","_onProgress","componentWillUnmount","removeEventListener","render","width","style","seekableStart","start","seekableEnd","end","createElement","Consumer","absoluteFill","onLayout","nativeEvent","layout","seekBarWidth","disabled","minimumValue","maximumValue","step","onSlidingStart","_onSlidingStart","onValueChange","_onValueChange","onSlidingComplete","_onSlidingComplete","focusable","minimumTrackTintColor","colors","seekBarMinimum","maximumTrackTintColor","seekBarMaximum","thumbTintColor","seekBarDot","contextType"],"sources":["SeekBar.tsx"],"sourcesContent":["import React, { PureComponent } from 'react';\nimport { LayoutChangeEvent, StyleProp, StyleSheet, View, ViewStyle } from 'react-native';\nimport { DurationChangeEvent, LoadedMetadataEvent, PlayerEventType, ProgressEvent, TimeRange, TimeUpdateEvent } from 'react-native-theoplayer';\nimport { PlayerContext, UiContext } from '../util/PlayerContext';\nimport Slider from '@react-native-community/slider';\nimport { SingleThumbnailView } from './thumbnail/SingleThumbnailView';\n\nexport interface SeekBarProps {\n /**\n * Optional style applied to the SeekBar.\n */\n style?: StyleProp<ViewStyle>;\n}\n\ninterface SeekBarState {\n ignoreTimeupdate: boolean;\n isSeeking: boolean;\n pausedDueToScrubbing: boolean;\n seekable: TimeRange[];\n duration: number;\n sliderTime: number;\n width: number;\n}\n\n/**\n * The default seek bar component for the `react-native-theoplayer` UI.\n */\nexport class SeekBar extends PureComponent<SeekBarProps, SeekBarState> {\n private static initialState: SeekBarState = {\n ignoreTimeupdate: false,\n isSeeking: false,\n sliderTime: 0,\n duration: 0,\n seekable: [],\n pausedDueToScrubbing: false,\n width: 0,\n };\n\n private _seekBlockingTimeout: NodeJS.Timeout | undefined;\n private _clearIsScrubbingTimout: NodeJS.Timeout | undefined;\n\n constructor(props: SeekBarProps) {\n super(props);\n this.state = SeekBar.initialState;\n }\n\n componentDidMount() {\n const player = (this.context as UiContext).player;\n player.addEventListener(PlayerEventType.LOADED_METADATA, this._onLoadedMetadata);\n player.addEventListener(PlayerEventType.DURATION_CHANGE, this._onDurationChange);\n player.addEventListener(PlayerEventType.TIME_UPDATE, this._onTimeUpdate);\n player.addEventListener(PlayerEventType.PROGRESS, this._onProgress);\n this.setState({\n ...SeekBar.initialState,\n sliderTime: player.currentTime,\n duration: player.duration,\n seekable: player.seekable,\n });\n }\n\n componentWillUnmount() {\n const context = this.context as UiContext;\n context.player.removeEventListener(PlayerEventType.LOADED_METADATA, this._onLoadedMetadata);\n context.player.removeEventListener(PlayerEventType.DURATION_CHANGE, this._onDurationChange);\n context.player.removeEventListener(PlayerEventType.TIME_UPDATE, this._onTimeUpdate);\n context.player.removeEventListener(PlayerEventType.PROGRESS, this._onProgress);\n clearTimeout(this._seekBlockingTimeout);\n clearTimeout(this._clearIsScrubbingTimout);\n }\n\n private _onTimeUpdate = (event: TimeUpdateEvent) => {\n if (!this.state.ignoreTimeupdate) {\n this.setState({ sliderTime: event.currentTime });\n }\n };\n private _onLoadedMetadata = (event: LoadedMetadataEvent) => this.setState({ duration: event.duration });\n private _onDurationChange = (event: DurationChangeEvent) => this.setState({ duration: event.duration });\n private _onProgress = (event: ProgressEvent) => this.setState({ seekable: event.seekable });\n\n private _onSlidingStart = (value: number) => {\n this.setState({ sliderTime: value });\n this._prepareSeekStart();\n const player = (this.context as UiContext).player;\n if (!player.paused) {\n this.debounceSeek(value);\n player.pause();\n this.setState({ pausedDueToScrubbing: true });\n }\n };\n\n private _onValueChange = (value: number) => {\n this.setState({ sliderTime: value });\n if (this.state.ignoreTimeupdate) {\n this.debounceSeek(value);\n }\n };\n\n private _onSlidingComplete = (value: number) => {\n this.setState({ sliderTime: value });\n this.debounceSeek(value, true);\n const player = (this.context as UiContext).player;\n const isEnded = player.currentTime === player.duration;\n if (this.state.pausedDueToScrubbing && !isEnded) {\n player.play();\n this.setState({ pausedDueToScrubbing: false });\n }\n this._finishSeek();\n };\n\n private readonly _prepareSeekStart = () => {\n this.setState({ isSeeking: true, ignoreTimeupdate: true });\n clearTimeout(this._clearIsScrubbingTimout);\n };\n\n private readonly _finishSeek = () => {\n this.setState({ isSeeking: false });\n // Wait for timeupdate events to settle after seeking, so the Slider does not jump back and forth.\n this._clearIsScrubbingTimout = setTimeout(() => {\n this.setState({ ignoreTimeupdate: false });\n }, 1000);\n };\n\n private debounceSeek = (value: number, force = false) => {\n // Don't bombard the player with seeks when seeking. Allow only one seek ever X milliseconds:\n const MAX_SEEK_INTERVAL = 200;\n if (force || this._seekBlockingTimeout === undefined) {\n if (force) {\n clearTimeout(this._seekBlockingTimeout);\n this._seekBlockingTimeout = undefined;\n }\n this._seekBlockingTimeout = setTimeout(() => {\n this._seekBlockingTimeout = undefined;\n }, MAX_SEEK_INTERVAL);\n // Do seek\n const player = (this.context as UiContext).player;\n player.currentTime = value;\n }\n };\n\n render() {\n const { seekable, sliderTime, duration, isSeeking, width } = this.state;\n const { style } = this.props;\n const seekableStart = seekable.length > 0 ? seekable[0].start : 0;\n const seekableEnd = seekable.length > 0 ? seekable[0].end : 0;\n return (\n <PlayerContext.Consumer>\n {(context: UiContext) => (\n <View\n style={[StyleSheet.absoluteFill, style]}\n onLayout={(event: LayoutChangeEvent) => {\n this.setState({ width: event.nativeEvent.layout.width });\n }}>\n {isSeeking && (\n <SingleThumbnailView seekableStart={seekableStart} seekableEnd={seekableEnd} currentTime={sliderTime} seekBarWidth={width} />\n )}\n <Slider\n disabled={!(duration > 0) && seekable.length > 0}\n style={[StyleSheet.absoluteFill, style]}\n minimumValue={seekableStart}\n maximumValue={seekableEnd}\n step={1000}\n onSlidingStart={this._onSlidingStart}\n onValueChange={this._onValueChange}\n onSlidingComplete={this._onSlidingComplete}\n value={sliderTime}\n focusable={true}\n minimumTrackTintColor={context.style.colors.seekBarMinimum}\n maximumTrackTintColor={context.style.colors.seekBarMaximum}\n thumbTintColor={context.style.colors.seekBarDot}\n />\n </View>\n )}\n </PlayerContext.Consumer>\n );\n }\n}\n\nSeekBar.contextType = PlayerContext;\n"],"mappings":"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"}
@@ -1,3 +0,0 @@
1
- export * from './SeekBar';
2
- export * from './thumbnail/barrel';
3
- //# sourceMappingURL=barrel.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":[],"sources":["barrel.ts"],"sourcesContent":["export * from './SeekBar';\nexport * from './thumbnail/barrel';\n"],"mappings":"AAAA,cAAc,WAAW;AACzB,cAAc,oBAAoB"}
@@ -1,37 +0,0 @@
1
- import { Dimensions, View } from 'react-native';
2
- import { filterThumbnailTracks } from 'react-native-theoplayer';
3
- import { PlayerContext } from '../../util/PlayerContext';
4
- import { ThumbnailView } from './ThumbnailView';
5
- import React, { useContext } from 'react';
6
- export function SingleThumbnailView(props) {
7
- const player = useContext(PlayerContext).player;
8
- const thumbnailTrack = filterThumbnailTracks(player.textTracks);
9
- if (!thumbnailTrack) {
10
- return /*#__PURE__*/React.createElement(React.Fragment, null);
11
- }
12
- const window = Dimensions.get('window');
13
- const thumbnailSize = 0.35 * Math.min(window.height, window.width);
14
- const {
15
- seekableStart,
16
- seekableEnd,
17
- currentTime,
18
- seekBarWidth
19
- } = props;
20
- const percentageOffset = (currentTime - seekableStart) / (seekableEnd - seekableStart);
21
- const marginHorizontal = 10;
22
- return /*#__PURE__*/React.createElement(View, {
23
- style: {
24
- position: 'absolute',
25
- top: -(thumbnailSize * 0.6),
26
- left: Math.max(0, Math.min(seekBarWidth - thumbnailSize - marginHorizontal, percentageOffset * seekBarWidth - 0.5 * thumbnailSize)),
27
- marginHorizontal
28
- }
29
- }, /*#__PURE__*/React.createElement(ThumbnailView, {
30
- thumbnailTrack: thumbnailTrack,
31
- duration: player.duration,
32
- time: currentTime,
33
- size: thumbnailSize,
34
- showTimeLabel: false
35
- }));
36
- }
37
- //# sourceMappingURL=SingleThumbnailView.js.map
@@ -1 +0,0 @@
1
- {"version":3,"names":["Dimensions","View","filterThumbnailTracks","PlayerContext","ThumbnailView","React","useContext","SingleThumbnailView","props","player","thumbnailTrack","textTracks","createElement","Fragment","window","get","thumbnailSize","Math","min","height","width","seekableStart","seekableEnd","currentTime","seekBarWidth","percentageOffset","marginHorizontal","style","position","top","left","max","duration","time","size","showTimeLabel"],"sources":["SingleThumbnailView.tsx"],"sourcesContent":["import { Dimensions, View } from 'react-native';\nimport { filterThumbnailTracks } from 'react-native-theoplayer';\nimport { PlayerContext } from '../../util/PlayerContext';\nimport { ThumbnailView } from './ThumbnailView';\nimport React, { useContext } from 'react';\n\nexport interface ThumbnailViewProps {\n seekableStart: number;\n seekableEnd: number;\n currentTime: number;\n seekBarWidth: number;\n}\n\nexport function SingleThumbnailView(props: ThumbnailViewProps) {\n const player = useContext(PlayerContext).player;\n const thumbnailTrack = filterThumbnailTracks(player.textTracks);\n if (!thumbnailTrack) {\n return <></>;\n }\n const window = Dimensions.get('window');\n const thumbnailSize = 0.35 * Math.min(window.height, window.width);\n\n const { seekableStart, seekableEnd, currentTime, seekBarWidth } = props;\n const percentageOffset = (currentTime - seekableStart) / (seekableEnd - seekableStart);\n const marginHorizontal = 10;\n\n return (\n <View\n style={{\n position: 'absolute',\n top: -(thumbnailSize * 0.6),\n left: Math.max(0, Math.min(seekBarWidth - thumbnailSize - marginHorizontal, percentageOffset * seekBarWidth - 0.5 * thumbnailSize)),\n marginHorizontal,\n }}>\n <ThumbnailView thumbnailTrack={thumbnailTrack} duration={player.duration} time={currentTime} size={thumbnailSize} showTimeLabel={false} />\n </View>\n );\n}\n"],"mappings":"AAAA,SAASA,UAAU,EAAEC,IAAI,QAAQ,cAAc;AAC/C,SAASC,qBAAqB,QAAQ,yBAAyB;AAC/D,SAASC,aAAa,QAAQ,0BAA0B;AACxD,SAASC,aAAa,QAAQ,iBAAiB;AAC/C,OAAOC,KAAK,IAAIC,UAAU,QAAQ,OAAO;AASzC,OAAO,SAASC,mBAAmBA,CAACC,KAAyB,EAAE;EAC7D,MAAMC,MAAM,GAAGH,UAAU,CAACH,aAAa,CAAC,CAACM,MAAM;EAC/C,MAAMC,cAAc,GAAGR,qBAAqB,CAACO,MAAM,CAACE,UAAU,CAAC;EAC/D,IAAI,CAACD,cAAc,EAAE;IACnB,oBAAOL,KAAA,CAAAO,aAAA,CAAAP,KAAA,CAAAQ,QAAA,OAAK;EACd;EACA,MAAMC,MAAM,GAAGd,UAAU,CAACe,GAAG,CAAC,QAAQ,CAAC;EACvC,MAAMC,aAAa,GAAG,IAAI,GAAGC,IAAI,CAACC,GAAG,CAACJ,MAAM,CAACK,MAAM,EAAEL,MAAM,CAACM,KAAK,CAAC;EAElE,MAAM;IAAEC,aAAa;IAAEC,WAAW;IAAEC,WAAW;IAAEC;EAAa,CAAC,GAAGhB,KAAK;EACvE,MAAMiB,gBAAgB,GAAG,CAACF,WAAW,GAAGF,aAAa,KAAKC,WAAW,GAAGD,aAAa,CAAC;EACtF,MAAMK,gBAAgB,GAAG,EAAE;EAE3B,oBACErB,KAAA,CAAAO,aAAA,CAACX,IAAI;IACH0B,KAAK,EAAE;MACLC,QAAQ,EAAE,UAAU;MACpBC,GAAG,EAAE,EAAEb,aAAa,GAAG,GAAG,CAAC;MAC3Bc,IAAI,EAAEb,IAAI,CAACc,GAAG,CAAC,CAAC,EAAEd,IAAI,CAACC,GAAG,CAACM,YAAY,GAAGR,aAAa,GAAGU,gBAAgB,EAAED,gBAAgB,GAAGD,YAAY,GAAG,GAAG,GAAGR,aAAa,CAAC,CAAC;MACnIU;IACF;EAAE,gBACFrB,KAAA,CAAAO,aAAA,CAACR,aAAa;IAACM,cAAc,EAAEA,cAAe;IAACsB,QAAQ,EAAEvB,MAAM,CAACuB,QAAS;IAACC,IAAI,EAAEV,WAAY;IAACW,IAAI,EAAElB,aAAc;IAACmB,aAAa,EAAE;EAAM,EAAG,CACrI;AAEX"}
@@ -1,11 +0,0 @@
1
- export function isTileMapThumbnail(thumbnail) {
2
- return thumbnail.tileX !== undefined && thumbnail.tileY !== undefined && thumbnail.tileWidth !== undefined && thumbnail.tileHeight !== undefined;
3
- }
4
- export function isImageThumbnail(thumbnail) {
5
- return !isTileMapThumbnail(thumbnail);
6
- }
7
-
8
- /**
9
- * Description of a thumbnail, which can be either a full image or part of a tile map.
10
- */
11
- //# sourceMappingURL=Thumbnail.js.map