@cloud-app-dev/vidc 4.0.20 → 4.0.22

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 (234) hide show
  1. package/es/AppContext/Sync.js +42 -0
  2. package/es/AppContext/index.js +141 -0
  3. package/es/AppContext/interface.d.ts +41 -0
  4. package/es/AppContext/static.js +9 -0
  5. package/es/Auth/index.js +14 -0
  6. package/es/AutoExit/index.js +19 -0
  7. package/es/CheckGroupFixed/demo.js +22 -0
  8. package/es/CheckGroupFixed/index.js +140 -0
  9. package/es/CheckGroupFixed/index.less +56 -0
  10. package/es/Config/index.js +77 -0
  11. package/es/Config/interface.d.ts +65 -0
  12. package/es/Config/utils.js +33 -0
  13. package/es/ConfigContext/index.js +21 -0
  14. package/es/CustomRenderSelect/index.js +72 -0
  15. package/es/CustomRenderSelect/index.less +25 -0
  16. package/es/DBTools/index.js +336 -0
  17. package/es/DisableMark/index.js +19 -0
  18. package/es/DisableMark/index.less +9 -0
  19. package/es/DomMove/demo.js +16 -0
  20. package/es/DomMove/index.js +139 -0
  21. package/es/DomMove/utils.js +32 -0
  22. package/es/Drag/DragAndDropItem.js +133 -0
  23. package/es/Drag/DropItem.js +50 -0
  24. package/es/Drag/index.d.ts +9 -0
  25. package/es/Drag/index.js +7 -0
  26. package/es/Drag/interface.d.ts +16 -0
  27. package/es/DynamicGridList/Demo.js +77 -0
  28. package/es/DynamicGridList/index.js +67 -0
  29. package/es/DynamicList/demo.js +44 -0
  30. package/es/DynamicList/index.js +86 -0
  31. package/es/DynamicList/index.less +17 -0
  32. package/es/DynamicList/interface.d.ts +19 -0
  33. package/es/DynamicList/utils.js +6 -0
  34. package/es/ErrorFallback/index.js +31 -0
  35. package/es/ErrorFallback/inerface.d.ts +48 -0
  36. package/es/EventTools/index.js +12 -0
  37. package/es/FrontendPlayer/index.js +2 -0
  38. package/es/FullScreen/index.js +33 -0
  39. package/es/FullScreen/index.less +18 -0
  40. package/es/GridList/Demo.js +80 -0
  41. package/es/GridList/data.js +609 -0
  42. package/es/GridList/hook.js +270 -0
  43. package/es/GridList/index.js +44 -0
  44. package/es/GridList/index.less +8 -0
  45. package/es/GridList/interface.d.ts +59 -0
  46. package/es/GridList/utils.js +42 -0
  47. package/es/HightLevel/index.js +18 -0
  48. package/es/HightLevel/index.less +3 -0
  49. package/es/IconFont/index.js +54 -0
  50. package/es/ImageView/index.js +51 -0
  51. package/es/ImageView/index.less +11 -0
  52. package/es/InstanceHistory/index.js +7 -0
  53. package/es/LabelPlayer/111.png +0 -0
  54. package/es/LabelPlayer/demo.js +115 -0
  55. package/es/LabelPlayer/index.js +160 -0
  56. package/es/LabelPlayer/index.less +24 -0
  57. package/es/LabelValue/index.js +27 -0
  58. package/es/LabelValue/index.less +23 -0
  59. package/es/List/demo.js +23 -0
  60. package/es/List/index.js +28 -0
  61. package/es/List/index.less +20 -0
  62. package/es/ListWithSizeAnimate/demo.js +98 -0
  63. package/es/ListWithSizeAnimate/index.js +85 -0
  64. package/es/ListWithSizeAnimate/index.less +23 -0
  65. package/es/LoaderScript/index.js +34 -0
  66. package/es/LoaderScript/utils.js +179 -0
  67. package/es/Map/AMap.d.ts +7109 -0
  68. package/es/Map/BasicMap/AMapInstance.js +98 -0
  69. package/es/Map/BasicMap/LeafletInstance.js +111 -0
  70. package/es/Map/BasicMap/index.js +90 -0
  71. package/es/Map/BasicMap/index.less +29 -0
  72. package/es/Map/ClusterLayer/demo.js +18 -0
  73. package/es/Map/ClusterLayer/hook.js +123 -0
  74. package/es/Map/ClusterLayer/index.js +28 -0
  75. package/es/Map/ClusterLayer/index.less +29 -0
  76. package/es/Map/ClusterLayer/props.d.ts +8 -0
  77. package/es/Map/Config/index.js +48 -0
  78. package/es/Map/Config/utils.js +65 -0
  79. package/es/Map/Context/index.js +51 -0
  80. package/es/Map/FindPio/index.js +13 -0
  81. package/es/Map/FindPio/index.less +7 -0
  82. package/es/Map/InfoWindow/MakerLikeWindow.js +108 -0
  83. package/es/Map/InfoWindow/demo.js +70 -0
  84. package/es/Map/InfoWindow/index.js +62 -0
  85. package/es/Map/LevelCenter/DragMarker/index.js +42 -0
  86. package/es/Map/LevelCenter/demo.js +38 -0
  87. package/es/Map/LevelCenter/index.js +66 -0
  88. package/es/Map/LoaderMap/index.js +62 -0
  89. package/es/Map/MapDrawSelect/demo.js +71 -0
  90. package/es/Map/MapDrawSelect/index.js +56 -0
  91. package/es/Map/MouseTool/index.js +40 -0
  92. package/es/Map/MouseTool/useMouseTools.js +83 -0
  93. package/es/Map/ResetTools/index.js +57 -0
  94. package/es/Map/ResetTools/index.less +39 -0
  95. package/es/Map/SinglePoint/demo.js +14 -0
  96. package/es/Map/SinglePoint/index.js +52 -0
  97. package/es/Map/SinglePoint/index.less +41 -0
  98. package/es/Map/hook/useMapEvent.js +19 -0
  99. package/es/Map/hook/useMapType.js +12 -0
  100. package/es/Map/icon.js +10 -0
  101. package/es/Map/index.js +25 -0
  102. package/es/Map/interface.d.ts +74 -0
  103. package/es/Map/points.js +1 -0
  104. package/es/Map/useMarker/index.js +71 -0
  105. package/es/Map/withMap/index.js +10 -0
  106. package/es/Picture/component/DefaultRects/RectInfo.js +80 -0
  107. package/es/Picture/component/DefaultRects/index.js +52 -0
  108. package/es/Picture/component/DefaultRects/index.less +211 -0
  109. package/es/Picture/component/DefaultRects/utils.js +11 -0
  110. package/es/Picture/component/DrawRect/index.js +46 -0
  111. package/es/Picture/component/DrawRect/index.less +8 -0
  112. package/es/Picture/component/RectMenu/index.js +76 -0
  113. package/es/Picture/component/RectMenu/index.less +36 -0
  114. package/es/Picture/component/RectMenu/utils.js +19 -0
  115. package/es/Picture/component/Tools/index.js +73 -0
  116. package/es/Picture/component/Tools/index.less +49 -0
  117. package/es/Picture/component/WheelScale/index.js +27 -0
  118. package/es/Picture/demo.js +105 -0
  119. package/es/Picture/index.js +341 -0
  120. package/es/Picture/index.less +20 -0
  121. package/es/Picture/interface.d.ts +196 -0
  122. package/es/Picture/loadCaptureRectImage.js +99 -0
  123. package/es/Picture/useDraw.js +103 -0
  124. package/es/Picture/utils.js +143 -0
  125. package/es/Player/api/index.js +309 -0
  126. package/es/Player/context.js +24 -0
  127. package/es/Player/contraller_bar/bar.js +20 -0
  128. package/es/Player/contraller_bar/contraller_event.js +48 -0
  129. package/es/Player/contraller_bar/index.js +27 -0
  130. package/es/Player/contraller_bar/left_bar.js +83 -0
  131. package/es/Player/contraller_bar/right_bar.js +32 -0
  132. package/es/Player/contraller_bar/time.js +19 -0
  133. package/es/Player/contraller_bar/useBarStatus.js +43 -0
  134. package/es/Player/contraller_bar/volume.js +62 -0
  135. package/es/Player/demo.js +266 -0
  136. package/es/Player/empty.js +4 -0
  137. package/es/Player/event/errorEvent.js +88 -0
  138. package/es/Player/event/eventName.js +29 -0
  139. package/es/Player/event/index.js +205 -0
  140. package/es/Player/fps_play.js +83 -0
  141. package/es/Player/frontend_player.js +64 -0
  142. package/es/Player/frontend_timeline.js +132 -0
  143. package/es/Player/iconfont.js +16 -0
  144. package/es/Player/index.js +2 -0
  145. package/es/Player/live_heart.js +45 -0
  146. package/es/Player/message.js +133 -0
  147. package/es/Player/player.d.ts +233 -0
  148. package/es/Player/segment_player.js +228 -0
  149. package/es/Player/segment_timeline.js +173 -0
  150. package/es/Player/single_player.js +262 -0
  151. package/es/Player/style/bar.less +43 -0
  152. package/es/Player/style/iconfont.js +43 -0
  153. package/es/Player/style/index.less +34 -0
  154. package/es/Player/style/message.less +56 -0
  155. package/es/Player/style/slider.less +106 -0
  156. package/es/Player/style/timeline.less +117 -0
  157. package/es/Player/style/volume.less +24 -0
  158. package/es/Player/timeline.js +95 -0
  159. package/es/Player/util.js +189 -0
  160. package/es/PlayerExt/demo.js +154 -0
  161. package/es/PlayerExt/index.js +188 -0
  162. package/es/PlayerExt/index.less +10 -0
  163. package/es/Progress/index.d.ts +9 -0
  164. package/es/Progress/index.js +53 -0
  165. package/es/Progress/index.less +21 -0
  166. package/es/ROI/demo.js +16 -0
  167. package/es/ROI/index.js +54 -0
  168. package/es/ROI/index.less +33 -0
  169. package/es/RefDrawer/Footer.js +22 -0
  170. package/es/RefDrawer/demo.js +18 -0
  171. package/es/RefDrawer/index.js +71 -0
  172. package/es/RefModal/demo.js +18 -0
  173. package/es/RefModal/index.js +70 -0
  174. package/es/ScreenPlayer/Live.js +212 -0
  175. package/es/ScreenPlayer/LiveTools.js +151 -0
  176. package/es/ScreenPlayer/PlayerWithExt.js +231 -0
  177. package/es/ScreenPlayer/RatePick.js +29 -0
  178. package/es/ScreenPlayer/Record.js +442 -0
  179. package/es/ScreenPlayer/RecordTools.js +169 -0
  180. package/es/ScreenPlayer/ScreenSelect.js +46 -0
  181. package/es/ScreenPlayer/SegmentTimeLine.js +36 -0
  182. package/es/ScreenPlayer/TimeMode.js +26 -0
  183. package/es/ScreenPlayer/TimeSelect.js +88 -0
  184. package/es/ScreenPlayer/demo.js +21 -0
  185. package/es/ScreenPlayer/demo2.js +194 -0
  186. package/es/ScreenPlayer/index.js +9 -0
  187. package/es/ScreenPlayer/index.less +335 -0
  188. package/es/ScreenPlayer/interface.d.ts +216 -0
  189. package/es/ScreenPlayer/useTimeSlider.js +456 -0
  190. package/es/ScreenPlayer/useVideoFit.js +35 -0
  191. package/es/ScreenPlayer/utils.js +85 -0
  192. package/es/SegmentPlayer/index.js +2 -0
  193. package/es/Service/http.js +133 -0
  194. package/es/Service/index.js +11 -0
  195. package/es/Service/interface.d.ts +23 -0
  196. package/es/Service/middleware.js +22 -0
  197. package/es/SocketEmitter/eventEmitter.js +88 -0
  198. package/es/SocketEmitter/index.js +125 -0
  199. package/es/SocketEmitter/interface.d.ts +4 -0
  200. package/es/TableLayout/index.js +27 -0
  201. package/es/TableLayout/index.less +4 -0
  202. package/es/ThemeAntd/demo.js +81 -0
  203. package/es/ThemeAntd/demo.less +20 -0
  204. package/es/ThemeAntd/index.js +21 -0
  205. package/es/ThemeAntd/index.less +4 -0
  206. package/es/Timeout/index.js +65 -0
  207. package/es/bigNumberTransformCN/index.js +58 -0
  208. package/es/cache/index.js +94 -0
  209. package/es/copy/index.js +9 -0
  210. package/es/core.d.ts +0 -0
  211. package/es/getThemeStyle/index.js +5 -0
  212. package/es/index.js +62 -0
  213. package/es/likeGo/index.js +31 -0
  214. package/es/likeGoSync/index.js +10 -0
  215. package/es/logger/index.js +30 -0
  216. package/es/nextTick/index.js +3 -0
  217. package/es/recorder/demo.js +181 -0
  218. package/es/recorder/index.js +992 -0
  219. package/es/submidstr/index.js +14 -0
  220. package/es/treeHelper/index.js +188 -0
  221. package/es/typings.d.ts +2 -0
  222. package/es/useDrawROI/index.js +318 -0
  223. package/es/useEventEmitterHandle/index.js +17 -0
  224. package/es/useFullscreen/demo.js +43 -0
  225. package/es/useFullscreen/index.js +76 -0
  226. package/es/useHistory/index.js +9 -0
  227. package/es/useHistory/interface.d.ts +3 -0
  228. package/es/useInfiniteScroll/index.js +102 -0
  229. package/es/useRafInterval/index.js +70 -0
  230. package/es/useSimpleState/index.js +35 -0
  231. package/es/useVirtualList/index.js +136 -0
  232. package/es/utils.js +46 -0
  233. package/es/uuid/index.js +19 -0
  234. package/package.json +2 -3
@@ -0,0 +1,456 @@
1
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
2
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
3
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
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(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
6
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
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(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
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 _i = 0; _i < minPerStep.length; _i++) {
156
+ if (distance_between_gtitle / px_per_min <= minPerStep[_i]) {
157
+ medium_step = minPerStep[_i];
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 _i2 = 0; _i2 < num_steps; _i2++) {
168
+ graduation_left = px_offset + _i2 * px_per_step; // 距离=开始的偏移距离+格数*px/格
169
+ graduation_time = state.begin + ms_offset + _i2 * 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 _x = graduation_left - (middle_date.length > 5 ? 24 : 12);
186
+ drawText(ctx, {
187
+ fillStyle: normalLineColor,
188
+ font: '10px Arial',
189
+ x: _x,
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
+ var _canvasRef$current, _canvasRef$current2, _canvasRef$current3;
291
+ if (!(canvasRef !== null && canvasRef !== void 0 && (_canvasRef$current = canvasRef.current) !== null && _canvasRef$current !== void 0 && _canvasRef$current.width)) return;
292
+ event.preventDefault();
293
+ var delta = Math.max(-1, Math.min(1, event.wheelDelta || -event.detail));
294
+ var event_time = state.begin + state.hoursPer * 3600 * 1000 * (event.offsetX / (canvasRef === null || canvasRef === void 0 || (_canvasRef$current2 = canvasRef.current) === null || _canvasRef$current2 === void 0 ? void 0 : _canvasRef$current2.width));
295
+ // const middle_time = state.begin + (state.hoursPer * 3600 * 1000) / 2; //ms 记住当前中间的时间
296
+ var new_hoursPer = state.hoursPer;
297
+ var index = hours.indexOf(new_hoursPer);
298
+ if (delta < 0) {
299
+ // 缩小
300
+ if (index === hours.length - 1) {
301
+ new_hoursPer = hours[index];
302
+ } else {
303
+ new_hoursPer = hours[index + 1];
304
+ }
305
+ } else if (delta > 0) {
306
+ // 放大
307
+ if (index === 0) {
308
+ new_hoursPer = hours[0];
309
+ } else {
310
+ new_hoursPer = hours[index - 1];
311
+ }
312
+ }
313
+ var new_event_begin = event_time - new_hoursPer * 3600 * 1000 * (event.offsetX / (canvasRef === null || canvasRef === void 0 || (_canvasRef$current3 = canvasRef.current) === null || _canvasRef$current3 === void 0 ? void 0 : _canvasRef$current3.width));
314
+
315
+ // const new_begin = middle_time - (state.hoursPer * 3600 * 1000) / 2; //new_begin = 当前中间的时间 - hoursPer/2
316
+ setState(function (old) {
317
+ return _objectSpread(_objectSpread({}, old), {}, {
318
+ begin: new_event_begin,
319
+ hoursPer: new_hoursPer
320
+ });
321
+ });
322
+ onTimeChange === null || onTimeChange === void 0 || onTimeChange({
323
+ begin: new_event_begin
324
+ });
325
+ nextTick(function () {
326
+ return onHoursPerChange === null || onHoursPerChange === void 0 ? void 0 : onHoursPerChange(new_hoursPer);
327
+ });
328
+ }, {
329
+ target: canvasRef
330
+ });
331
+
332
+ /**
333
+ * 用于处理canvas移除hover效果
334
+ */
335
+ useEventListener('mouseout', function () {
336
+ return setState(function (old) {
337
+ return _objectSpread(_objectSpread({}, old), {}, {
338
+ hover: {
339
+ x: 0,
340
+ time: undefined
341
+ }
342
+ });
343
+ });
344
+ }, {
345
+ target: canvasRef
346
+ });
347
+
348
+ /**
349
+ * hover效果绘制
350
+ */
351
+ useEventListener('mousemove', function (e) {
352
+ if (extRef.current.mousedownTime) {
353
+ setState(function (old) {
354
+ return _objectSpread(_objectSpread({}, old), {}, {
355
+ hover: old.hover.time ? {
356
+ x: 0,
357
+ time: undefined
358
+ } : old.hover
359
+ });
360
+ });
361
+ } else {
362
+ // 触发绘制hover tips
363
+ var pos_x = get_cursor_x_position(e);
364
+ var ms_per_px = state.hoursPer * 3600 * 1000 / width; // ms/px
365
+ var current_timestamp = state.begin + pos_x * ms_per_px;
366
+ setState(function (old) {
367
+ return _objectSpread(_objectSpread({}, old), {}, {
368
+ hover: {
369
+ x: pos_x,
370
+ time: current_timestamp
371
+ }
372
+ });
373
+ });
374
+ }
375
+ }, {
376
+ target: canvasRef
377
+ });
378
+
379
+ /**
380
+ * 标记点击、拖动的触发器
381
+ */
382
+ useEventListener('mousedown', function (e) {
383
+ extRef.current.mousedownTime = Date.now();
384
+ extRef.current.mousedownX = get_cursor_x_position(e); //记住mousedown的位置
385
+ }, {
386
+ target: canvasRef
387
+ });
388
+
389
+ /**
390
+ * 处理点击、结束拖动的处理
391
+ */
392
+ useEventListener('mouseup', function (e) {
393
+ if (!extRef.current.mousedownTime) {
394
+ // 未在canvas上触发mousedown 过滤
395
+ return;
396
+ }
397
+ var clickDelay = Date.now() - extRef.current.mousedownTime;
398
+ if (clickDelay < 200 && e.target === canvas) {
399
+ // click 事件
400
+ var pos_x = get_cursor_x_position(e); //鼠标距离 px
401
+ var ms_per_px = state.hoursPer * 3600 * 1000 / width; // ms/px
402
+ var new_current = state.begin + pos_x * ms_per_px;
403
+ var segmentItem = segments.find(function (v) {
404
+ return new_current >= v.beginTime && new_current < v.endTime;
405
+ });
406
+ // 当前片段没有录像的时候
407
+ var _outTimeline = segmentItem && !segmentItem.url;
408
+ // const new_begin = new_current - (state.hoursPer * 60 * 60 * 1000) / 2;
409
+
410
+ // setState((old) => ({ ...old, begin: new_begin, current: new_current }));
411
+ setState(function (old) {
412
+ return _objectSpread(_objectSpread({}, old), {}, {
413
+ current: new_current
414
+ });
415
+ });
416
+ nextTick(function () {
417
+ return onTimeChange === null || onTimeChange === void 0 ? void 0 : onTimeChange({
418
+ currentTime: new_current
419
+ }, _outTimeline);
420
+ });
421
+ }
422
+ // 清楚拖拽关联信息
423
+ extRef.current.mousedownTime = undefined;
424
+ extRef.current.mousedownX = 0;
425
+ }, {
426
+ target: document
427
+ });
428
+ var moveTimerRef = useRef();
429
+
430
+ /**
431
+ * 拖动处理
432
+ */
433
+ useEventListener('mousemove', function (e) {
434
+ if (!extRef.current.mousedownTime) {
435
+ return;
436
+ }
437
+ clearTimeout(moveTimerRef.current);
438
+ // 触发拖动
439
+ var pos_x = get_cursor_x_position(e);
440
+ var px_per_ms = width / (state.hoursPer * 60 * 60 * 1000); // px/ms
441
+ var diff_x = pos_x - extRef.current.mousedownX;
442
+ var new_begin = state.begin - Math.round(diff_x / px_per_ms);
443
+ extRef.current.mousedownX = pos_x;
444
+ update({
445
+ begin: new_begin
446
+ });
447
+ moveTimerRef.current = setTimeout(function () {
448
+ return onTimeChange === null || onTimeChange === void 0 ? void 0 : onTimeChange({
449
+ begin: new_begin
450
+ });
451
+ }, 300);
452
+ }, {
453
+ target: document
454
+ });
455
+ }
456
+ export default useTimeSlider;
@@ -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(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
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,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;