@cloud-app-dev/vidc 4.0.17 → 4.1.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 (299) hide show
  1. package/.dumirc.ts +1 -1
  2. package/.eslintrc.js +3 -0
  3. package/.fatherrc.ts +0 -6
  4. package/es/AppContext/Sync.d.ts +7 -0
  5. package/es/AppContext/Sync.js +44 -0
  6. package/es/AppContext/index.d.ts +17 -0
  7. package/es/AppContext/index.js +154 -0
  8. package/es/AppContext/interface.d.ts +42 -0
  9. package/es/AppContext/static.d.ts +8 -0
  10. package/es/AppContext/static.js +9 -0
  11. package/es/CheckGroupFixed/demo.d.ts +2 -0
  12. package/es/CheckGroupFixed/demo.js +20 -0
  13. package/es/CheckGroupFixed/index.d.ts +22 -0
  14. package/es/CheckGroupFixed/index.js +150 -0
  15. package/es/CheckGroupFixed/style.d.ts +6 -0
  16. package/es/CheckGroupFixed/style.js +9 -0
  17. package/es/Config/index.d.ts +4 -0
  18. package/es/Config/index.js +77 -0
  19. package/es/Config/interface.d.ts +65 -0
  20. package/es/Config/utils.d.ts +4 -0
  21. package/es/Config/utils.js +33 -0
  22. package/es/CustomRenderSelect/index.d.ts +13 -0
  23. package/es/CustomRenderSelect/index.js +86 -0
  24. package/es/DBTools/index.d.ts +25 -0
  25. package/es/DBTools/index.js +336 -0
  26. package/es/DisableMark/index.d.ts +8 -0
  27. package/es/DisableMark/index.js +25 -0
  28. package/es/DomMove/demo.d.ts +1 -0
  29. package/es/DomMove/demo.js +19 -0
  30. package/es/DomMove/index.d.ts +16 -0
  31. package/es/DomMove/index.js +148 -0
  32. package/es/DomMove/utils.d.ts +8 -0
  33. package/es/DomMove/utils.js +33 -0
  34. package/es/Drag/DragAndDropItem.d.ts +4 -0
  35. package/es/Drag/DragAndDropItem.js +133 -0
  36. package/es/Drag/DropItem.d.ts +4 -0
  37. package/es/Drag/DropItem.js +50 -0
  38. package/es/Drag/index.d.ts +7 -0
  39. package/es/Drag/index.js +7 -0
  40. package/es/Drag/interface.d.ts +16 -0
  41. package/es/DynamicGridList/demo.d.ts +2 -0
  42. package/es/DynamicGridList/demo.js +86 -0
  43. package/es/DynamicGridList/index.d.ts +27 -0
  44. package/es/DynamicGridList/index.js +71 -0
  45. package/es/DynamicList/demo.d.ts +1 -0
  46. package/es/DynamicList/demo.js +45 -0
  47. package/es/DynamicList/index.d.ts +30 -0
  48. package/es/DynamicList/index.js +98 -0
  49. package/es/DynamicList/interface.d.ts +19 -0
  50. package/es/DynamicList/utils.d.ts +4 -0
  51. package/es/DynamicList/utils.js +6 -0
  52. package/es/ErrorFallback/index.d.ts +8 -0
  53. package/es/ErrorFallback/index.js +38 -0
  54. package/es/ErrorFallback/inerface.d.ts +48 -0
  55. package/es/EventTools/index.d.ts +3 -0
  56. package/es/EventTools/index.js +12 -0
  57. package/es/FrontendPlayer/index.d.ts +4 -0
  58. package/es/FrontendPlayer/index.js +2 -0
  59. package/es/GridList/data.d.ts +16 -0
  60. package/es/GridList/data.js +609 -0
  61. package/es/GridList/demo.d.ts +2 -0
  62. package/es/GridList/demo.js +89 -0
  63. package/es/GridList/hook.d.ts +13 -0
  64. package/es/GridList/hook.js +270 -0
  65. package/es/GridList/index.d.ts +14 -0
  66. package/es/GridList/index.js +51 -0
  67. package/es/GridList/interface.d.ts +59 -0
  68. package/es/GridList/utils.d.ts +9 -0
  69. package/es/GridList/utils.js +42 -0
  70. package/es/HightLevel/index.d.ts +8 -0
  71. package/es/HightLevel/index.js +20 -0
  72. package/es/IconFont/index.d.ts +12 -0
  73. package/es/IconFont/index.js +63 -0
  74. package/es/InstanceHistory/index.d.ts +3 -0
  75. package/es/InstanceHistory/index.js +7 -0
  76. package/es/LabelValue/index.d.ts +14 -0
  77. package/es/LabelValue/index.js +35 -0
  78. package/es/List/demo.d.ts +2 -0
  79. package/es/List/demo.js +25 -0
  80. package/es/List/index.d.ts +27 -0
  81. package/es/List/index.js +38 -0
  82. package/es/ListWithSizeAnimate/demo.d.ts +1 -0
  83. package/es/ListWithSizeAnimate/demo.js +128 -0
  84. package/es/ListWithSizeAnimate/index.d.ts +13 -0
  85. package/es/ListWithSizeAnimate/index.js +106 -0
  86. package/es/LoaderScript/index.d.ts +47 -0
  87. package/es/LoaderScript/index.js +38 -0
  88. package/es/LoaderScript/utils.d.ts +13 -0
  89. package/es/LoaderScript/utils.js +179 -0
  90. package/es/Picture/component/DefaultRects/RectInfo.d.ts +7 -0
  91. package/es/Picture/component/DefaultRects/RectInfo.js +90 -0
  92. package/es/Picture/component/DefaultRects/index.d.ts +11 -0
  93. package/es/Picture/component/DefaultRects/index.js +58 -0
  94. package/es/Picture/component/DefaultRects/style.d.ts +10 -0
  95. package/es/Picture/component/DefaultRects/style.js +28 -0
  96. package/es/Picture/component/DefaultRects/utils.d.ts +2 -0
  97. package/es/Picture/component/DefaultRects/utils.js +11 -0
  98. package/es/Picture/component/DrawRect/index.d.ts +11 -0
  99. package/es/Picture/component/DrawRect/index.js +54 -0
  100. package/es/Picture/component/RectMenu/index.d.ts +10 -0
  101. package/es/Picture/component/RectMenu/index.js +84 -0
  102. package/es/Picture/component/RectMenu/utils.d.ts +12 -0
  103. package/es/Picture/component/RectMenu/utils.js +19 -0
  104. package/es/Picture/component/Tools/index.d.ts +11 -0
  105. package/es/Picture/component/Tools/index.js +105 -0
  106. package/es/Picture/component/Tools/style.d.ts +2 -0
  107. package/es/Picture/component/Tools/style.js +5 -0
  108. package/es/Picture/component/WheelScale/index.d.ts +6 -0
  109. package/es/Picture/component/WheelScale/index.js +29 -0
  110. package/es/Picture/demo.d.ts +1 -0
  111. package/es/Picture/demo.js +114 -0
  112. package/es/Picture/index.d.ts +17 -0
  113. package/es/Picture/index.js +356 -0
  114. package/es/Picture/interface.d.ts +196 -0
  115. package/es/Picture/loadCaptureRectImage.d.ts +3 -0
  116. package/es/Picture/loadCaptureRectImage.js +99 -0
  117. package/es/Picture/useDraw.d.ts +1 -0
  118. package/es/Picture/useDraw.js +103 -0
  119. package/es/Picture/utils.d.ts +26 -0
  120. package/es/Picture/utils.js +143 -0
  121. package/es/Player/api/index.d.ts +68 -0
  122. package/es/Player/api/index.js +309 -0
  123. package/es/Player/context.d.ts +21 -0
  124. package/es/Player/context.js +25 -0
  125. package/es/Player/contraller_bar/bar.d.ts +8 -0
  126. package/es/Player/contraller_bar/bar.js +32 -0
  127. package/es/Player/contraller_bar/contraller_event.d.ts +6 -0
  128. package/es/Player/contraller_bar/contraller_event.js +52 -0
  129. package/es/Player/contraller_bar/index.d.ts +13 -0
  130. package/es/Player/contraller_bar/index.js +39 -0
  131. package/es/Player/contraller_bar/left_bar.d.ts +10 -0
  132. package/es/Player/contraller_bar/left_bar.js +97 -0
  133. package/es/Player/contraller_bar/right_bar.d.ts +8 -0
  134. package/es/Player/contraller_bar/right_bar.js +36 -0
  135. package/es/Player/contraller_bar/time.d.ts +2 -0
  136. package/es/Player/contraller_bar/time.js +24 -0
  137. package/es/Player/contraller_bar/useBarStatus.d.ts +2 -0
  138. package/es/Player/contraller_bar/useBarStatus.js +43 -0
  139. package/es/Player/contraller_bar/volume.d.ts +8 -0
  140. package/es/Player/contraller_bar/volume.js +70 -0
  141. package/es/Player/demo.d.ts +2 -0
  142. package/es/Player/demo.js +289 -0
  143. package/es/Player/empty.d.ts +1 -0
  144. package/es/Player/empty.js +5 -0
  145. package/es/Player/event/errorEvent.d.ts +14 -0
  146. package/es/Player/event/errorEvent.js +88 -0
  147. package/es/Player/event/eventName.d.ts +18 -0
  148. package/es/Player/event/eventName.js +30 -0
  149. package/es/Player/event/index.d.ts +24 -0
  150. package/es/Player/event/index.js +205 -0
  151. package/es/Player/fps_play.d.ts +10 -0
  152. package/es/Player/fps_play.js +88 -0
  153. package/es/Player/frontend_player.d.ts +7 -0
  154. package/es/Player/frontend_player.js +71 -0
  155. package/es/Player/frontend_timeline.d.ts +8 -0
  156. package/es/Player/frontend_timeline.js +153 -0
  157. package/es/Player/iconfont.d.ts +4 -0
  158. package/es/Player/iconfont.js +21 -0
  159. package/es/Player/index.d.ts +2 -0
  160. package/es/Player/index.js +2 -0
  161. package/es/Player/live_heart.d.ts +8 -0
  162. package/es/Player/live_heart.js +45 -0
  163. package/es/Player/message.d.ts +3 -0
  164. package/es/Player/message.js +147 -0
  165. package/es/Player/player.d.ts +233 -0
  166. package/es/Player/segment_player.d.ts +8 -0
  167. package/es/Player/segment_player.js +229 -0
  168. package/es/Player/segment_timeline.d.ts +10 -0
  169. package/es/Player/segment_timeline.js +200 -0
  170. package/es/Player/single_player.d.ts +4 -0
  171. package/es/Player/single_player.js +278 -0
  172. package/es/Player/style/iconfont.js +43 -0
  173. package/es/Player/timeline.d.ts +7 -0
  174. package/es/Player/timeline.js +104 -0
  175. package/es/Player/util.d.ts +43 -0
  176. package/es/Player/util.js +189 -0
  177. package/es/PlayerExt/demo.d.ts +2 -0
  178. package/es/PlayerExt/demo.js +170 -0
  179. package/es/PlayerExt/index.d.ts +47 -0
  180. package/es/PlayerExt/index.js +212 -0
  181. package/es/Progress/index.d.ts +10 -0
  182. package/es/Progress/index.js +60 -0
  183. package/es/ROI/demo.d.ts +2 -0
  184. package/es/ROI/demo.js +17 -0
  185. package/es/ROI/index.d.ts +32 -0
  186. package/es/ROI/index.js +67 -0
  187. package/es/RefDrawer/Footer.d.ts +9 -0
  188. package/es/RefDrawer/Footer.js +27 -0
  189. package/es/RefDrawer/demo.d.ts +3 -0
  190. package/es/RefDrawer/demo.js +32 -0
  191. package/es/RefDrawer/index.d.ts +26 -0
  192. package/es/RefDrawer/index.js +73 -0
  193. package/es/RefModal/demo.d.ts +2 -0
  194. package/es/RefModal/demo.js +32 -0
  195. package/es/RefModal/index.d.ts +17 -0
  196. package/es/RefModal/index.js +71 -0
  197. package/es/ScreenPlayer/Live.d.ts +8 -0
  198. package/es/ScreenPlayer/Live.js +219 -0
  199. package/es/ScreenPlayer/LiveTools.d.ts +33 -0
  200. package/es/ScreenPlayer/LiveTools.js +172 -0
  201. package/es/ScreenPlayer/PlayerWithExt.d.ts +34 -0
  202. package/es/ScreenPlayer/PlayerWithExt.js +241 -0
  203. package/es/ScreenPlayer/RatePick.d.ts +7 -0
  204. package/es/ScreenPlayer/RatePick.js +35 -0
  205. package/es/ScreenPlayer/Record.d.ts +8 -0
  206. package/es/ScreenPlayer/Record.js +452 -0
  207. package/es/ScreenPlayer/RecordTools.d.ts +38 -0
  208. package/es/ScreenPlayer/RecordTools.js +214 -0
  209. package/es/ScreenPlayer/ScreenSelect.d.ts +6 -0
  210. package/es/ScreenPlayer/ScreenSelect.js +59 -0
  211. package/es/ScreenPlayer/SegmentTimeLine.d.ts +16 -0
  212. package/es/ScreenPlayer/SegmentTimeLine.js +44 -0
  213. package/es/ScreenPlayer/TimeMode.d.ts +6 -0
  214. package/es/ScreenPlayer/TimeMode.js +34 -0
  215. package/es/ScreenPlayer/TimeSelect.d.ts +6 -0
  216. package/es/ScreenPlayer/TimeSelect.js +99 -0
  217. package/es/ScreenPlayer/containerStyle.d.ts +13 -0
  218. package/es/ScreenPlayer/containerStyle.js +32 -0
  219. package/es/ScreenPlayer/demo.d.ts +1 -0
  220. package/es/ScreenPlayer/demo.js +19 -0
  221. package/es/ScreenPlayer/demo2.d.ts +1 -0
  222. package/es/ScreenPlayer/demo2.js +196 -0
  223. package/es/ScreenPlayer/index.d.ts +6 -0
  224. package/es/ScreenPlayer/index.js +9 -0
  225. package/es/ScreenPlayer/interface.d.ts +216 -0
  226. package/es/ScreenPlayer/useTimeSlider.d.ts +25 -0
  227. package/es/ScreenPlayer/useTimeSlider.js +451 -0
  228. package/es/ScreenPlayer/useVideoFit.d.ts +5 -0
  229. package/es/ScreenPlayer/useVideoFit.js +35 -0
  230. package/es/ScreenPlayer/utils.d.ts +17 -0
  231. package/es/ScreenPlayer/utils.js +85 -0
  232. package/es/SegmentPlayer/index.d.ts +2 -0
  233. package/es/SegmentPlayer/index.js +2 -0
  234. package/es/Service/http.d.ts +6 -0
  235. package/es/Service/http.js +125 -0
  236. package/es/Service/index.d.ts +3 -0
  237. package/es/Service/index.js +10 -0
  238. package/es/Service/interface.d.ts +22 -0
  239. package/es/Service/middleware.d.ts +5 -0
  240. package/es/Service/middleware.js +15 -0
  241. package/es/SocketEmitter/eventEmitter.d.ts +27 -0
  242. package/es/SocketEmitter/eventEmitter.js +88 -0
  243. package/es/SocketEmitter/index.d.ts +24 -0
  244. package/es/SocketEmitter/index.js +125 -0
  245. package/es/SocketEmitter/interface.d.ts +4 -0
  246. package/es/TableLayout/index.d.ts +9 -0
  247. package/es/TableLayout/index.js +32 -0
  248. package/es/Timeout/index.d.ts +31 -0
  249. package/es/Timeout/index.js +69 -0
  250. package/es/cache/index.d.ts +34 -0
  251. package/es/cache/index.js +94 -0
  252. package/es/copy/index.d.ts +1 -0
  253. package/es/copy/index.js +9 -0
  254. package/es/core.d.ts +0 -0
  255. package/es/getThemeStyle/index.d.ts +2 -0
  256. package/es/getThemeStyle/index.js +5 -0
  257. package/es/index.d.ts +52 -0
  258. package/es/index.js +52 -0
  259. package/es/likeGo/index.d.ts +2 -0
  260. package/es/likeGo/index.js +31 -0
  261. package/es/likeGoSync/index.d.ts +2 -0
  262. package/es/likeGoSync/index.js +10 -0
  263. package/es/logger/index.d.ts +7 -0
  264. package/es/logger/index.js +30 -0
  265. package/es/nextTick/index.d.ts +1 -0
  266. package/es/nextTick/index.js +3 -0
  267. package/es/recorder/demo.d.ts +2 -0
  268. package/es/recorder/demo.js +200 -0
  269. package/es/recorder/index.d.ts +294 -0
  270. package/es/recorder/index.js +991 -0
  271. package/es/submidstr/index.d.ts +5 -0
  272. package/es/submidstr/index.js +14 -0
  273. package/es/treeHelper/index.d.ts +11 -0
  274. package/es/treeHelper/index.js +189 -0
  275. package/es/typings.d.ts +2 -0
  276. package/es/useDrawROI/index.d.ts +16 -0
  277. package/es/useDrawROI/index.js +318 -0
  278. package/es/useEventEmitterHandle/index.d.ts +2 -0
  279. package/es/useEventEmitterHandle/index.js +17 -0
  280. package/es/useHistory/index.d.ts +3 -0
  281. package/es/useHistory/index.js +9 -0
  282. package/es/useHistory/interface.d.ts +3 -0
  283. package/es/useInfiniteScroll/index.d.ts +16 -0
  284. package/es/useInfiniteScroll/index.js +102 -0
  285. package/es/useRafInterval/index.d.ts +5 -0
  286. package/es/useRafInterval/index.js +70 -0
  287. package/es/useSimpleState/index.d.ts +3 -0
  288. package/es/useSimpleState/index.js +35 -0
  289. package/es/useVirtualList/index.d.ts +13 -0
  290. package/es/useVirtualList/index.js +136 -0
  291. package/es/utils.d.ts +14 -0
  292. package/es/utils.js +46 -0
  293. package/es/uuid/index.d.ts +5 -0
  294. package/es/uuid/index.js +6 -0
  295. package/package.json +16 -21
  296. package/release-build.sh +2 -0
  297. package/scripts/{entry.js → entry.mjs} +4 -6
  298. package/{icon-fix.js → scripts/icon-fix.mjs} +4 -3
  299. package/tsconfig.json +1 -1
@@ -0,0 +1,451 @@
1
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
2
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
3
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
4
+ 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; }
5
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
6
+ 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); }
7
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
8
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
9
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
10
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
11
+ function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
12
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
13
+ import { useEventListener, useSize, useUpdateEffect } from 'ahooks';
14
+ import moment from 'dayjs';
15
+ import { useEffect, useMemo, useRef, useState } from 'react';
16
+ import nextTick from "../nextTick";
17
+ var hours = [1, 6, 12, 24];
18
+ var currentColor = '#FF000A';
19
+ var normalLineColor = '#ffffff';
20
+ var hoverLineColor = '#319BFF';
21
+ var minPerStep = [1, 2, 5, 10, 15, 20, 30, 60, 120, 180, 240, 360, 720, 1440];
22
+ var minStepSize = 20;
23
+ var distance_between_gtitle = 80;
24
+
25
+ /**
26
+ * 下一个刻度
27
+ */
28
+ function ms_to_next_step(timestamp, step) {
29
+ var remainder = timestamp % step;
30
+ return remainder ? step - remainder : 0;
31
+ }
32
+
33
+ /**
34
+ * 返回 2018-01-01 10:00:00 格式时间
35
+ * @param {*} time
36
+ */
37
+ function formartTimestemp(time) {
38
+ return moment(time).format('YYYY-MM-DD HH:mm:ss');
39
+ }
40
+ /**
41
+ * 返回时间轴上刻度的时间
42
+ * @param {*} datetime new Date 格式
43
+ */
44
+ function graduation_title(datetime) {
45
+ var mom = moment(datetime);
46
+ var h = mom.get('hours');
47
+ var m = mom.get('minutes');
48
+ var s = mom.get('seconds');
49
+ if (h === 0 && m === 0 && s === 0) {
50
+ return mom.format('YYYY.MM.DD');
51
+ }
52
+ return mom.format('HH:mm');
53
+ }
54
+
55
+ /**
56
+ * 绘制线条
57
+ */
58
+ function drawLine(ctx, beginX, beginY, endX, endY, color, width) {
59
+ ctx.beginPath();
60
+ ctx.moveTo(beginX, beginY);
61
+ ctx.lineTo(endX, endY);
62
+ ctx.strokeStyle = color;
63
+ ctx.lineWidth = width;
64
+ ctx.stroke();
65
+ }
66
+ function drawText(ctx, _ref) {
67
+ var fillStyle = _ref.fillStyle,
68
+ font = _ref.font,
69
+ text = _ref.text,
70
+ x = _ref.x,
71
+ y = _ref.y;
72
+ ctx.fillStyle = fillStyle;
73
+ ctx.font = font;
74
+ ctx.fillText(text, x, y);
75
+ }
76
+ function useTimeSlider(canvasRef, _ref2) {
77
+ var hoursPer = _ref2.hoursPer,
78
+ begin = _ref2.begin,
79
+ currentTime = _ref2.currentTime,
80
+ _ref2$segments = _ref2.segments,
81
+ segments = _ref2$segments === void 0 ? [] : _ref2$segments,
82
+ onTimeChange = _ref2.onTimeChange,
83
+ onHoursPerChange = _ref2.onHoursPerChange;
84
+ var _useState = useState({
85
+ hoursPer: hoursPer,
86
+ begin: begin,
87
+ currentTime: currentTime,
88
+ hover: {
89
+ x: 0,
90
+ time: undefined
91
+ }
92
+ }),
93
+ _useState2 = _slicedToArray(_useState, 2),
94
+ state = _useState2[0],
95
+ setState = _useState2[1];
96
+ var extRef = useRef({
97
+ mousedownTime: undefined,
98
+ mousedownX: 0
99
+ });
100
+ var size = useSize(canvasRef);
101
+ var canvas = canvasRef.current;
102
+ var _useMemo = useMemo(function () {
103
+ return size ? size : {
104
+ width: 0,
105
+ height: 0
106
+ };
107
+ }, [size]),
108
+ width = _useMemo.width,
109
+ height = _useMemo.height;
110
+ var ctx = canvas === null || canvas === void 0 ? void 0 : canvas.getContext('2d');
111
+ var update = function update() {
112
+ var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
113
+ return setState(function (old) {
114
+ return _objectSpread(_objectSpread({}, old), params);
115
+ });
116
+ };
117
+ var clearCanvas = function clearCanvas() {
118
+ return ctx === null || ctx === void 0 ? void 0 : ctx.clearRect(0, 0, width, height);
119
+ };
120
+
121
+ /**
122
+ * 绘制覆盖时间刻度颜色,表示有录像的部分
123
+ */
124
+ var drawOverlay = function drawOverlay() {
125
+ segments.forEach(function (item) {
126
+ var px_ms = width / (state.hoursPer * 60 * 60 * 1000); // px/ms
127
+ var beginX = (item.beginTime - state.begin) * px_ms;
128
+ var scale_width = (item.endTime - item.beginTime) * px_ms;
129
+ if (ctx) {
130
+ var _item$style;
131
+ ctx.fillStyle = item.url ? ((_item$style = item.style) === null || _item$style === void 0 ? void 0 : _item$style.background) || hoverLineColor : '#242C3D';
132
+ ctx.fillRect(beginX, height - 10, scale_width + 1, height);
133
+ }
134
+ });
135
+ };
136
+
137
+ /**
138
+ * 绘制刻度相关的
139
+ */
140
+ var drawScale = function drawScale() {
141
+ var px_per_min = width / (state.hoursPer * 60); // px/min
142
+ var px_per_ms = width / (state.hoursPer * 60 * 60 * 1000); // px/ms
143
+ var px_per_step = minStepSize; // px/格 默认最小值20px
144
+ var min_per_step = px_per_step / px_per_min; // min/格
145
+
146
+ for (var i = 0; i < minPerStep.length; i++) {
147
+ if (min_per_step <= minPerStep[i]) {
148
+ //让每格时间在minutes_per_step规定的范围内
149
+ min_per_step = minPerStep[i];
150
+ px_per_step = px_per_min * min_per_step;
151
+ break;
152
+ }
153
+ }
154
+ var medium_step = 30;
155
+ for (var _i2 = 0; _i2 < minPerStep.length; _i2++) {
156
+ if (distance_between_gtitle / px_per_min <= minPerStep[_i2]) {
157
+ medium_step = minPerStep[_i2];
158
+ break;
159
+ }
160
+ }
161
+ var num_steps = width / px_per_step; //总格数
162
+ var ms_offset = ms_to_next_step(state.begin, min_per_step * 60 * 1000); //开始的偏移时间 ms
163
+ var px_offset = ms_offset * px_per_ms; //开始的偏移距离 px
164
+ var ms_per_step = px_per_step / px_per_ms; // ms/step
165
+
166
+ var graduation_left, graduation_time, lineH;
167
+ for (var _i3 = 0; _i3 < num_steps; _i3++) {
168
+ graduation_left = px_offset + _i3 * px_per_step; // 距离=开始的偏移距离+格数*px/格
169
+ graduation_time = state.begin + ms_offset + _i3 * ms_per_step; //时间=左侧开始时间+偏移时间+格数*ms/格
170
+ var date = moment(graduation_time);
171
+ if (date.get('hours') === 0 && date.get('minutes') === 0) {
172
+ lineH = 10;
173
+ var big_date = graduation_title(date.valueOf());
174
+ var x = graduation_left - 30;
175
+ drawText(ctx, {
176
+ fillStyle: normalLineColor,
177
+ font: '10px Arial',
178
+ x: x,
179
+ y: 30,
180
+ text: big_date
181
+ });
182
+ } else if (graduation_time / (60 * 1000) % medium_step === 0) {
183
+ lineH = 10;
184
+ var middle_date = graduation_title(date.valueOf());
185
+ var _x2 = graduation_left - (middle_date.length > 5 ? 24 : 12);
186
+ drawText(ctx, {
187
+ fillStyle: normalLineColor,
188
+ font: '10px Arial',
189
+ x: _x2,
190
+ y: 30,
191
+ text: middle_date
192
+ });
193
+ } else {
194
+ lineH = 5;
195
+ }
196
+ drawLine(ctx, graduation_left, height - lineH, graduation_left, height, normalLineColor, 2);
197
+ }
198
+ };
199
+
200
+ /**
201
+ * 绘制当前刻度
202
+ * @returns
203
+ */
204
+ var drawCurrentLine = function drawCurrentLine() {
205
+ var currentTime = state.currentTime,
206
+ begin = state.begin,
207
+ hoursPer = state.hoursPer;
208
+ var time = currentTime;
209
+ var range = [begin, currentTime + hoursPer * 3600 * 1000];
210
+ if (time < range[0] || time > range[1]) {
211
+ return;
212
+ }
213
+ var ms_current = time - begin;
214
+ var px_per_ms = width / (hoursPer * 60 * 60 * 1000); // px/ms
215
+ var left = px_per_ms * ms_current;
216
+ drawText(ctx, {
217
+ fillStyle: '#ffffff',
218
+ font: '12px Arial',
219
+ x: left - 64,
220
+ y: 14,
221
+ text: formartTimestemp(time)
222
+ });
223
+ drawLine(ctx, left, 20, left, height, currentColor, 2); //中间当前点线
224
+ };
225
+
226
+ /**
227
+ * 绘制提示时间
228
+ */
229
+ var drawHoverLine = function drawHoverLine() {
230
+ var _state$hover$x, _state$hover$time, _state$hover$x2, _state$hover$x3;
231
+ drawText(ctx, {
232
+ fillStyle: hoverLineColor,
233
+ font: '12px Arial',
234
+ x: ((_state$hover$x = state.hover.x) !== null && _state$hover$x !== void 0 ? _state$hover$x : 0) - 50,
235
+ y: 12,
236
+ text: formartTimestemp((_state$hover$time = state.hover.time) !== null && _state$hover$time !== void 0 ? _state$hover$time : 0)
237
+ });
238
+ drawLine(ctx, (_state$hover$x2 = state.hover.x) !== null && _state$hover$x2 !== void 0 ? _state$hover$x2 : 0, 20, (_state$hover$x3 = state.hover.x) !== null && _state$hover$x3 !== void 0 ? _state$hover$x3 : 0, height, hoverLineColor, 1);
239
+ };
240
+
241
+ /**
242
+ * 获取鼠标posx
243
+ * @param {*} e
244
+ */
245
+ var get_cursor_x_position = function get_cursor_x_position(e) {
246
+ return e.offsetX;
247
+ };
248
+
249
+ /**
250
+ * 更新画布大小
251
+ */
252
+ useUpdateEffect(function () {
253
+ if (canvas) {
254
+ canvas.width = width;
255
+ canvas.height = height;
256
+ }
257
+ }, [canvas, height, width]);
258
+ useEffect(function () {
259
+ if (canvas) {
260
+ clearCanvas();
261
+ drawOverlay();
262
+ drawScale();
263
+ drawCurrentLine();
264
+ if (state.hover.time) {
265
+ drawHoverLine();
266
+ }
267
+ }
268
+ // eslint-disable-next-line react-hooks/exhaustive-deps
269
+ }, [canvas, state.begin, state.currentTime, state.hoursPer, segments, state.hover, size]);
270
+ useUpdateEffect(function () {
271
+ return update({
272
+ begin: begin
273
+ });
274
+ }, [begin]);
275
+ useUpdateEffect(function () {
276
+ return update({
277
+ hoursPer: hoursPer
278
+ });
279
+ }, [hoursPer]);
280
+ useUpdateEffect(function () {
281
+ return update({
282
+ currentTime: currentTime
283
+ });
284
+ }, [currentTime]);
285
+
286
+ /**
287
+ * 触发绘制范围单位(hour)
288
+ */
289
+ useEventListener('mousewheel', function (event) {
290
+ event.preventDefault();
291
+ var delta = Math.max(-1, Math.min(1, event.wheelDelta || -event.detail));
292
+ var middle_time = state.begin + state.hoursPer * 3600 * 1000 / 2; //ms 记住当前中间的时间
293
+ var new_hoursPer = state.hoursPer;
294
+ var index = hours.indexOf(new_hoursPer);
295
+ if (delta < 0) {
296
+ // 缩小
297
+ if (index === hours.length - 1) {
298
+ new_hoursPer = hours[index];
299
+ } else {
300
+ new_hoursPer = hours[index + 1];
301
+ }
302
+ } else if (delta > 0) {
303
+ // 放大
304
+ if (index === 0) {
305
+ new_hoursPer = hours[0];
306
+ } else {
307
+ new_hoursPer = hours[index - 1];
308
+ }
309
+ }
310
+ var new_begin = middle_time - state.hoursPer * 3600 * 1000 / 2; //new_begin = 当前中间的时间 - hoursPer/2
311
+ setState(function (old) {
312
+ return _objectSpread(_objectSpread({}, old), {}, {
313
+ begin: new_begin,
314
+ hoursPer: new_hoursPer
315
+ });
316
+ });
317
+ onTimeChange === null || onTimeChange === void 0 ? void 0 : onTimeChange({
318
+ begin: new_begin
319
+ });
320
+ nextTick(function () {
321
+ return onHoursPerChange === null || onHoursPerChange === void 0 ? void 0 : onHoursPerChange(new_hoursPer);
322
+ });
323
+ }, {
324
+ target: canvasRef
325
+ });
326
+
327
+ /**
328
+ * 用于处理canvas移除hover效果
329
+ */
330
+ useEventListener('mouseout', function () {
331
+ return setState(function (old) {
332
+ return _objectSpread(_objectSpread({}, old), {}, {
333
+ hover: {
334
+ x: 0,
335
+ time: undefined
336
+ }
337
+ });
338
+ });
339
+ }, {
340
+ target: canvasRef
341
+ });
342
+
343
+ /**
344
+ * hover效果绘制
345
+ */
346
+ useEventListener('mousemove', function (e) {
347
+ if (extRef.current.mousedownTime) {
348
+ setState(function (old) {
349
+ return _objectSpread(_objectSpread({}, old), {}, {
350
+ hover: old.hover.time ? {
351
+ x: 0,
352
+ time: undefined
353
+ } : old.hover
354
+ });
355
+ });
356
+ } else {
357
+ // 触发绘制hover tips
358
+ var pos_x = get_cursor_x_position(e);
359
+ var ms_per_px = state.hoursPer * 3600 * 1000 / width; // ms/px
360
+ var current_timestamp = state.begin + pos_x * ms_per_px;
361
+ setState(function (old) {
362
+ return _objectSpread(_objectSpread({}, old), {}, {
363
+ hover: {
364
+ x: pos_x,
365
+ time: current_timestamp
366
+ }
367
+ });
368
+ });
369
+ }
370
+ }, {
371
+ target: canvasRef
372
+ });
373
+
374
+ /**
375
+ * 标记点击、拖动的触发器
376
+ */
377
+ useEventListener('mousedown', function (e) {
378
+ extRef.current.mousedownTime = Date.now();
379
+ extRef.current.mousedownX = get_cursor_x_position(e); //记住mousedown的位置
380
+ }, {
381
+ target: canvasRef
382
+ });
383
+
384
+ /**
385
+ * 处理点击、结束拖动的处理
386
+ */
387
+ useEventListener('mouseup', function (e) {
388
+ if (!extRef.current.mousedownTime) {
389
+ // 未在canvas上触发mousedown 过滤
390
+ return;
391
+ }
392
+ var clickDelay = Date.now() - extRef.current.mousedownTime;
393
+ if (clickDelay < 200 && e.target === canvas) {
394
+ // click 事件
395
+ var pos_x = get_cursor_x_position(e); //鼠标距离 px
396
+ var ms_per_px = state.hoursPer * 3600 * 1000 / width; // ms/px
397
+ var new_current = state.begin + pos_x * ms_per_px;
398
+ var segmentItem = segments.find(function (v) {
399
+ return new_current >= v.beginTime && new_current < v.endTime;
400
+ });
401
+ // 当前片段没有录像的时候
402
+ var _outTimeline = segmentItem && !segmentItem.url;
403
+ // const new_begin = new_current - (state.hoursPer * 60 * 60 * 1000) / 2;
404
+
405
+ // setState((old) => ({ ...old, begin: new_begin, current: new_current }));
406
+ setState(function (old) {
407
+ return _objectSpread(_objectSpread({}, old), {}, {
408
+ current: new_current
409
+ });
410
+ });
411
+ nextTick(function () {
412
+ return onTimeChange === null || onTimeChange === void 0 ? void 0 : onTimeChange({
413
+ currentTime: new_current
414
+ }, _outTimeline);
415
+ });
416
+ }
417
+ // 清楚拖拽关联信息
418
+ extRef.current.mousedownTime = undefined;
419
+ extRef.current.mousedownX = 0;
420
+ }, {
421
+ target: document
422
+ });
423
+ var moveTimerRef = useRef();
424
+
425
+ /**
426
+ * 拖动处理
427
+ */
428
+ useEventListener('mousemove', function (e) {
429
+ if (!extRef.current.mousedownTime) {
430
+ return;
431
+ }
432
+ clearTimeout(moveTimerRef.current);
433
+ // 触发拖动
434
+ var pos_x = get_cursor_x_position(e);
435
+ var px_per_ms = width / (state.hoursPer * 60 * 60 * 1000); // px/ms
436
+ var diff_x = pos_x - extRef.current.mousedownX;
437
+ var new_begin = state.begin - Math.round(diff_x / px_per_ms);
438
+ extRef.current.mousedownX = pos_x;
439
+ update({
440
+ begin: new_begin
441
+ });
442
+ moveTimerRef.current = setTimeout(function () {
443
+ return onTimeChange === null || onTimeChange === void 0 ? void 0 : onTimeChange({
444
+ begin: new_begin
445
+ });
446
+ }, 300);
447
+ }, {
448
+ target: document
449
+ });
450
+ }
451
+ export default useTimeSlider;
@@ -0,0 +1,5 @@
1
+ import React from 'react';
2
+ export default function useVideoFit(containerRef: React.RefObject<HTMLDivElement>, deps?: any[]): {
3
+ fit: string;
4
+ toggleFit: () => void;
5
+ };
@@ -0,0 +1,35 @@
1
+ function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
2
+ function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
3
+ function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
4
+ function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
5
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
6
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
7
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
8
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
9
+ function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
10
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
11
+ import { useToggle } from 'ahooks';
12
+ import { useEffect, useMemo } from 'react';
13
+ export default function useVideoFit(containerRef) {
14
+ var deps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
15
+ var _useToggle = useToggle('fill', 'contain'),
16
+ _useToggle2 = _slicedToArray(_useToggle, 2),
17
+ fit = _useToggle2[0],
18
+ toggle = _useToggle2[1].toggle;
19
+ useEffect(function () {
20
+ if (!containerRef.current) {
21
+ return;
22
+ }
23
+ var videos = containerRef.current.querySelectorAll('video');
24
+ Array.from(videos).forEach(function (item) {
25
+ item.style.objectFit = fit;
26
+ });
27
+ // eslint-disable-next-line react-hooks/exhaustive-deps
28
+ }, [].concat(_toConsumableArray(deps), [fit]));
29
+ return useMemo(function () {
30
+ return {
31
+ fit: fit,
32
+ toggleFit: toggle
33
+ };
34
+ }, [fit, toggle]);
35
+ }
@@ -0,0 +1,17 @@
1
+ import { ISegmentType } from '../Player/player';
2
+ export declare const ScreenType: {
3
+ name: number;
4
+ icon: string;
5
+ }[];
6
+ export declare const TimeModeLibs: {
7
+ name: number;
8
+ }[];
9
+ export declare function mergeFill<T, S>(len: number, mergeArr: T[] | undefined, fillItem: S): (T | S)[];
10
+ /**
11
+ * unix时间戳
12
+ * @param start
13
+ * @param end
14
+ * @param segments
15
+ */
16
+ export declare const completionSegments: (start: number, end: number, segments: ISegmentType[]) => ISegmentType[];
17
+ export declare function sleep(time: number): Promise<unknown>;
@@ -0,0 +1,85 @@
1
+ export var ScreenType = [{
2
+ name: 1,
3
+ icon: 'lm-player-fenping1'
4
+ }, {
5
+ name: 4,
6
+ icon: 'lm-player-fenping4'
7
+ }, {
8
+ name: 6,
9
+ icon: 'lm-player-fenping6'
10
+ }, {
11
+ name: 8,
12
+ icon: 'lm-player-fenping8'
13
+ }, {
14
+ name: 9,
15
+ icon: 'lm-player-fenping9'
16
+ }, {
17
+ name: 10,
18
+ icon: 'lm-player-fenping10'
19
+ }, {
20
+ name: 13,
21
+ icon: 'lm-player-fenping13'
22
+ }, {
23
+ name: 16,
24
+ icon: 'lm-player-fenping16'
25
+ }];
26
+ export var TimeModeLibs = [{
27
+ name: 1
28
+ }, {
29
+ name: 6
30
+ }, {
31
+ name: 12
32
+ }, {
33
+ name: 24
34
+ }];
35
+ export function mergeFill(len) {
36
+ var mergeArr = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
37
+ var fillItem = arguments.length > 2 ? arguments[2] : undefined;
38
+ return new Array(len).fill(fillItem).map(function (v, i) {
39
+ return mergeArr[i] ? mergeArr[i] : v;
40
+ });
41
+ }
42
+
43
+ /**
44
+ * unix时间戳
45
+ * @param start
46
+ * @param end
47
+ * @param segments
48
+ */
49
+ export var completionSegments = function completionSegments(start, end, segments) {
50
+ var arr = [];
51
+ if (segments.length > 0 && start < +segments[0].beginTime) {
52
+ arr.push({
53
+ beginTime: start,
54
+ endTime: +segments[0].beginTime
55
+ });
56
+ }
57
+ segments.reduce(function (prev, current, idx) {
58
+ if (arr.length === 0 && idx === 0) {
59
+ prev.push(current);
60
+ } else if (idx > 0 && segments[idx - 1].endTime !== current.beginTime) {
61
+ prev.push({
62
+ beginTime: segments[idx - 1].endTime,
63
+ endTime: current.beginTime
64
+ }, current);
65
+ } else {
66
+ prev.push(current);
67
+ }
68
+ return prev;
69
+ }, arr);
70
+ if (end > +segments[segments.length - 1].endTime) {
71
+ arr.push({
72
+ beginTime: segments[segments.length - 1].endTime,
73
+ endTime: end
74
+ });
75
+ }
76
+ return arr;
77
+ };
78
+ export function sleep(time) {
79
+ // eslint-disable-next-line no-promise-executor-return
80
+ return new Promise(function (reslove) {
81
+ return setTimeout(function () {
82
+ return reslove(time);
83
+ }, time);
84
+ });
85
+ }
@@ -0,0 +1,2 @@
1
+ import SegmentPlayer from '../Player/segment_player';
2
+ export default SegmentPlayer;
@@ -0,0 +1,2 @@
1
+ import SegmentPlayer from "../Player/segment_player";
2
+ export default SegmentPlayer;
@@ -0,0 +1,6 @@
1
+ import { AxiosInstance } from 'axios';
2
+ import type { RsponseType, XHRResponse } from './interface';
3
+ declare function http({ cancelHttp, ...newOptions }: RsponseType): Promise<any>;
4
+ declare const httpMultiPartInstance: AxiosInstance;
5
+ declare function httpXMLInstance({ url, method, data, headers, cancelHttp, isAsync }: XHRResponse): Promise<any>;
6
+ export { http as default, http, httpMultiPartInstance, httpXMLInstance };