wargerm 0.4.17 → 0.4.20

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.
@@ -27,11 +27,13 @@ declare class Modal extends React.PureComponent<Props> {
27
27
  destory(): void;
28
28
  } | undefined;
29
29
  static hidden: () => void;
30
+ static destory: () => void;
30
31
  renderFooter: () => JSX.Element | null;
31
32
  containerRef: React.RefObject<any>;
32
33
  titleRef: React.RefObject<any>;
33
34
  renderTop: () => JSX.Element;
34
35
  componentDidMount(): void;
36
+ componentWillUnmount(): void;
35
37
  renderContent: () => {} | null;
36
38
  render(): JSX.Element;
37
39
  }
package/dist/index.css CHANGED
@@ -1170,8 +1170,8 @@ button[data-prefers-color='dark'] .swiper-pagination-bullet {
1170
1170
  border-image-slice: 57 166 62 166;
1171
1171
  border-image-width: 57px 166px 62px 166px;
1172
1172
  border-image-repeat: stretch stretch;
1173
- min-height: 500px;
1174
- min-width: 600px;
1173
+ min-height: 300px;
1174
+ min-width: 200px;
1175
1175
  }
1176
1176
  [data-prefers-color='dark'] .model_container .model_wrap {
1177
1177
  position: absolute;
@@ -1182,6 +1182,33 @@ button[data-prefers-color='dark'] .swiper-pagination-bullet {
1182
1182
  transform: translate(-166px, -60px);
1183
1183
  padding: 12px 6px;
1184
1184
  }
1185
+ [data-prefers-color='dark'] .model_container .model_wrap .resizer {
1186
+ width: 10px;
1187
+ height: 100%;
1188
+ position: absolute;
1189
+ right: 0;
1190
+ top: 0;
1191
+ cursor: e-resize;
1192
+ z-index: 100;
1193
+ }
1194
+ [data-prefers-color='dark'] .model_container .model_wrap .resizeb {
1195
+ width: 100%;
1196
+ height: 10px;
1197
+ position: absolute;
1198
+ left: 0;
1199
+ bottom: 0;
1200
+ cursor: n-resize;
1201
+ z-index: 100;
1202
+ }
1203
+ [data-prefers-color='dark'] .model_container .model_wrap .resizerb {
1204
+ width: 20px;
1205
+ height: 20px;
1206
+ position: absolute;
1207
+ right: 0;
1208
+ bottom: 0;
1209
+ cursor: se-resize;
1210
+ z-index: 101;
1211
+ }
1185
1212
  [data-prefers-color='dark'] .model_container .model_wrap .model-header .model-title {
1186
1213
  position: absolute;
1187
1214
  z-index: 99;
@@ -1190,6 +1217,7 @@ button[data-prefers-color='dark'] .swiper-pagination-bullet {
1190
1217
  transform: translate(-50%, -50%);
1191
1218
  background: url('') no-repeat center center;
1192
1219
  width: 630px;
1220
+ width: 60%;
1193
1221
  height: 75px;
1194
1222
  font-size: 18px;
1195
1223
  font-family: Microsoft YaHei Regular, Microsoft YaHei Regular-Regular;
@@ -1200,6 +1228,7 @@ button[data-prefers-color='dark'] .swiper-pagination-bullet {
1200
1228
  display: flex;
1201
1229
  justify-content: center;
1202
1230
  align-items: center;
1231
+ background-size: contain;
1203
1232
  }
1204
1233
  [data-prefers-color='dark'] .model_container .model_wrap .model-header .model-title span {
1205
1234
  font-size: 18px;
@@ -1210,6 +1239,7 @@ button[data-prefers-color='dark'] .swiper-pagination-bullet {
1210
1239
  }
1211
1240
  [data-prefers-color='dark'] .model_container .model_wrap .model-header .model-title.move {
1212
1241
  cursor: move;
1242
+ z-index: 100;
1213
1243
  }
1214
1244
  [data-prefers-color='dark'] .model_container .model_wrap .model-header .model-closeIcon {
1215
1245
  font-size: 26px;
@@ -1411,6 +1441,15 @@ button[data-prefers-color='dark'] .swiper-pagination-bullet {
1411
1441
  background: #0f6ab7;
1412
1442
  }
1413
1443
  [data-prefers-color='dark'] .videoContainer {
1444
+ min-width: 400px;
1445
+ min-height: 400px;
1446
+ width: 100%;
1447
+ height: 100%;
1448
+ display: flex;
1449
+ flex-direction: column;
1450
+ }
1451
+ [data-prefers-color='dark'] .videoContainer .videoContainer-grid {
1452
+ flex: 1;
1414
1453
  width: 100%;
1415
1454
  height: 100%;
1416
1455
  display: grid;
@@ -2826,6 +2865,15 @@ button[data-prefers-color='light'] .swiper-pagination-bullet {
2826
2865
  background: #0f6ab7;
2827
2866
  }
2828
2867
  [data-prefers-color='light'] .videoContainer {
2868
+ min-width: 400px;
2869
+ min-height: 400px;
2870
+ width: 100%;
2871
+ height: 100%;
2872
+ display: flex;
2873
+ flex-direction: column;
2874
+ }
2875
+ [data-prefers-color='light'] .videoContainer .videoContainer-grid {
2876
+ flex: 1;
2829
2877
  width: 100%;
2830
2878
  height: 100%;
2831
2879
  display: grid;
@@ -1170,8 +1170,8 @@ button[data-prefers-color='dark'] .swiper-pagination-bullet {
1170
1170
  border-image-slice: 57 166 62 166;
1171
1171
  border-image-width: 57px 166px 62px 166px;
1172
1172
  border-image-repeat: stretch stretch;
1173
- min-height: 500px;
1174
- min-width: 600px;
1173
+ min-height: 300px;
1174
+ min-width: 200px;
1175
1175
  }
1176
1176
  [data-prefers-color='dark'] .model_container .model_wrap {
1177
1177
  position: absolute;
@@ -1182,6 +1182,33 @@ button[data-prefers-color='dark'] .swiper-pagination-bullet {
1182
1182
  transform: translate(-166px, -60px);
1183
1183
  padding: 12px 6px;
1184
1184
  }
1185
+ [data-prefers-color='dark'] .model_container .model_wrap .resizer {
1186
+ width: 10px;
1187
+ height: 100%;
1188
+ position: absolute;
1189
+ right: 0;
1190
+ top: 0;
1191
+ cursor: e-resize;
1192
+ z-index: 100;
1193
+ }
1194
+ [data-prefers-color='dark'] .model_container .model_wrap .resizeb {
1195
+ width: 100%;
1196
+ height: 10px;
1197
+ position: absolute;
1198
+ left: 0;
1199
+ bottom: 0;
1200
+ cursor: n-resize;
1201
+ z-index: 100;
1202
+ }
1203
+ [data-prefers-color='dark'] .model_container .model_wrap .resizerb {
1204
+ width: 20px;
1205
+ height: 20px;
1206
+ position: absolute;
1207
+ right: 0;
1208
+ bottom: 0;
1209
+ cursor: se-resize;
1210
+ z-index: 101;
1211
+ }
1185
1212
  [data-prefers-color='dark'] .model_container .model_wrap .model-header .model-title {
1186
1213
  position: absolute;
1187
1214
  z-index: 99;
@@ -1190,6 +1217,7 @@ button[data-prefers-color='dark'] .swiper-pagination-bullet {
1190
1217
  transform: translate(-50%, -50%);
1191
1218
  background: url('') no-repeat center center;
1192
1219
  width: 630px;
1220
+ width: 60%;
1193
1221
  height: 75px;
1194
1222
  font-size: 18px;
1195
1223
  font-family: Microsoft YaHei Regular, Microsoft YaHei Regular-Regular;
@@ -1200,6 +1228,7 @@ button[data-prefers-color='dark'] .swiper-pagination-bullet {
1200
1228
  display: flex;
1201
1229
  justify-content: center;
1202
1230
  align-items: center;
1231
+ background-size: contain;
1203
1232
  }
1204
1233
  [data-prefers-color='dark'] .model_container .model_wrap .model-header .model-title span {
1205
1234
  font-size: 18px;
@@ -1210,6 +1239,7 @@ button[data-prefers-color='dark'] .swiper-pagination-bullet {
1210
1239
  }
1211
1240
  [data-prefers-color='dark'] .model_container .model_wrap .model-header .model-title.move {
1212
1241
  cursor: move;
1242
+ z-index: 100;
1213
1243
  }
1214
1244
  [data-prefers-color='dark'] .model_container .model_wrap .model-header .model-closeIcon {
1215
1245
  font-size: 26px;
@@ -1411,6 +1441,15 @@ button[data-prefers-color='dark'] .swiper-pagination-bullet {
1411
1441
  background: #0f6ab7;
1412
1442
  }
1413
1443
  [data-prefers-color='dark'] .videoContainer {
1444
+ min-width: 400px;
1445
+ min-height: 400px;
1446
+ width: 100%;
1447
+ height: 100%;
1448
+ display: flex;
1449
+ flex-direction: column;
1450
+ }
1451
+ [data-prefers-color='dark'] .videoContainer .videoContainer-grid {
1452
+ flex: 1;
1414
1453
  width: 100%;
1415
1454
  height: 100%;
1416
1455
  display: grid;
@@ -2826,6 +2865,15 @@ button[data-prefers-color='light'] .swiper-pagination-bullet {
2826
2865
  background: #0f6ab7;
2827
2866
  }
2828
2867
  [data-prefers-color='light'] .videoContainer {
2868
+ min-width: 400px;
2869
+ min-height: 400px;
2870
+ width: 100%;
2871
+ height: 100%;
2872
+ display: flex;
2873
+ flex-direction: column;
2874
+ }
2875
+ [data-prefers-color='light'] .videoContainer .videoContainer-grid {
2876
+ flex: 1;
2829
2877
  width: 100%;
2830
2878
  height: 100%;
2831
2879
  display: grid;
package/dist/index.esm.js CHANGED
@@ -9639,8 +9639,7 @@ var controlShow = function controlShow(f1, f2, value, timer) {
9639
9639
  };
9640
9640
 
9641
9641
  function DialogModel(props, ref) {
9642
- var _props$width = props.width,
9643
- width = _props$width === void 0 ? 600 : _props$width,
9642
+ var width = props.width,
9644
9643
  visible = props.visible,
9645
9644
  destroyOnClose = props.destroyOnClose,
9646
9645
  closeCb = props.closeCb,
@@ -9702,8 +9701,7 @@ function DialogModel(props, ref) {
9702
9701
  className: classnames((_classNames = {}, _defineProperty(_classNames, className, true), _defineProperty(_classNames, 'model_container', true), _defineProperty(_classNames, "animate__animated", true), _defineProperty(_classNames, flag ? 'animate__bounceInDown' : 'animate__fadeOutRightBig', true), _classNames)),
9703
9702
  style: _objectSpread2({
9704
9703
  opacity: modelShowAync ? 1 : 0,
9705
- width: typeof width == 'number' ? width + 'px' : width,
9706
- left: "calc(50% - ".concat(typeof width == 'number' ? width / 2 : width / 2, "px)")
9704
+ width: typeof width == 'number' ? width + 'px' : width
9707
9705
  }, style)
9708
9706
  }, /*#__PURE__*/React.createElement("div", {
9709
9707
  className: 'model_wrap'
@@ -9732,6 +9730,13 @@ function DialogModel(props, ref) {
9732
9730
  }
9733
9731
  })), document.body);
9734
9732
  }, [modelShowAync, modelShow, props, isDesChild]);
9733
+ useEffect(function () {
9734
+ var containerEl = containerRef.current;
9735
+ var containerElWidth = containerEl.offsetWidth;
9736
+ var containerElHeight = containerEl.offsetHeight;
9737
+ containerEl.style.left = "calc(50% - ".concat(containerElWidth / 2, "px)");
9738
+ containerEl.style.top = "calc(50% - ".concat(containerElHeight / 2, "px)");
9739
+ }, [modelShow]);
9735
9740
  useEffect(function () {
9736
9741
  var containerEl = containerRef.current;
9737
9742
  var rEl = rRef.current;
@@ -9933,6 +9938,11 @@ var Modal = /*#__PURE__*/function (_React$PureComponent) {
9933
9938
  document.onmousemove = null;
9934
9939
  };
9935
9940
  }
9941
+ }, {
9942
+ key: "componentWillUnmount",
9943
+ value: function componentWillUnmount() {
9944
+ Modal.destory();
9945
+ }
9936
9946
  }, {
9937
9947
  key: "render",
9938
9948
  value: function render() {
@@ -9966,18 +9976,19 @@ var Modal = /*#__PURE__*/function (_React$PureComponent) {
9966
9976
 
9967
9977
  Modal.show = void 0;
9968
9978
  Modal.hidden = void 0;
9979
+ Modal.destory = void 0;
9980
+ var Modals = {};
9969
9981
 
9970
9982
  Modal.show = function (config) {
9971
- var ModalContainer = null;
9972
- var modelSysbol = Symbol('$$__model__Container_hidden');
9973
- if (ModalContainer) return;
9983
+ var modelSysbol = Math.random().toString(36).slice(2, 36);
9984
+ if (Modals[modelSysbol]) return;
9974
9985
 
9975
9986
  var props = _objectSpread2(_objectSpread2({}, config), {}, {
9976
9987
  visible: true
9977
9988
  });
9978
9989
 
9979
- var container = ModalContainer = document.createElement('div');
9980
- var manager = container[modelSysbol] = {
9990
+ var container = document.createElement('div');
9991
+ var manager = container[modelSysbol] = Modals[modelSysbol] = {
9981
9992
  setShow: null,
9982
9993
  mounted: false,
9983
9994
  hidden: function hidden() {
@@ -9986,8 +9997,12 @@ Modal.show = function (config) {
9986
9997
  },
9987
9998
  destory: function destory() {
9988
9999
  ReactDOM.unmountComponentAtNode(container);
9989
- document.body.removeChild(container);
9990
- ModalContainer = null;
10000
+
10001
+ if (document.body.contains(container)) {
10002
+ document.body.removeChild(container);
10003
+ }
10004
+
10005
+ delete Modals[modelSysbol];
9991
10006
  }
9992
10007
  };
9993
10008
 
@@ -10019,8 +10034,20 @@ Modal.show = function (config) {
10019
10034
  return manager;
10020
10035
  };
10021
10036
 
10022
- Modal.hidden = function () {// if (!ModalContainer) return;
10023
- // ModalContainer[modelSysbol] && ModalContainer[modelSysbol].hidden();
10037
+ Modal.hidden = function () {
10038
+ if (Object.keys(Modals).length == 0) return;
10039
+
10040
+ for (var key in Modals) {
10041
+ Modals[key].hidden();
10042
+ }
10043
+ };
10044
+
10045
+ Modal.destory = function () {
10046
+ if (Object.keys(Modals).length == 0) return;
10047
+
10048
+ for (var key in Modals) {
10049
+ Modals[key].destory();
10050
+ }
10024
10051
  };
10025
10052
 
10026
10053
  var controlShow$1 = function controlShow(f1, f2, value, timer) {
@@ -11108,15 +11135,9 @@ function Xgplay(_ref, fRef) {
11108
11135
  setRef = _ref.setRef;
11109
11136
  var ref = useRef(null);
11110
11137
  var playerRef = useRef(null);
11111
-
11112
- var _useState = useState(null),
11113
- _useState2 = _slicedToArray(_useState, 2),
11114
- player = _useState2[0],
11115
- setPlayer = _useState2[1];
11116
-
11117
11138
  useEffect(function () {
11118
11139
  if (ref.current) {
11119
- if (type.indexOf('hls') !== -1) {
11140
+ if ((type === null || type === void 0 ? void 0 : type.indexOf('hls')) !== -1) {
11120
11141
  playerRef.current = new HlsJsPlayer(_objectSpread2({
11121
11142
  el: ref.current,
11122
11143
  width: '100%',
@@ -11125,7 +11146,7 @@ function Xgplay(_ref, fRef) {
11125
11146
  isLive: true,
11126
11147
  autoplayMuted: true
11127
11148
  }, config));
11128
- } else if (type.indexOf('flv') !== -1) {
11149
+ } else if ((type === null || type === void 0 ? void 0 : type.indexOf('flv')) !== -1) {
11129
11150
  playerRef.current = new FlvPlayer(_objectSpread2({
11130
11151
  el: ref.current,
11131
11152
  width: '100%',
@@ -11134,7 +11155,7 @@ function Xgplay(_ref, fRef) {
11134
11155
  isLive: true,
11135
11156
  autoplayMuted: true
11136
11157
  }, config));
11137
- } else if (type.indexOf('mp4') !== -1) {
11158
+ } else if ((type === null || type === void 0 ? void 0 : type.indexOf('mp4')) !== -1) {
11138
11159
  playerRef.current = new Player(_objectSpread2({
11139
11160
  el: ref.current,
11140
11161
  width: '100%',
@@ -11199,11 +11220,7 @@ var IconFont = createFromIconfontCN({
11199
11220
  function VideoPlayer(_ref, ref) {
11200
11221
  var _ref$footer = _ref.footer,
11201
11222
  footer = _ref$footer === void 0 ? true : _ref$footer,
11202
- _ref$style = _ref.style,
11203
- style = _ref$style === void 0 ? {
11204
- width: 400,
11205
- height: 400
11206
- } : _ref$style,
11223
+ style = _ref.style,
11207
11224
  _ref$config = _ref.config,
11208
11225
  config = _ref$config === void 0 ? {} : _ref$config,
11209
11226
  layoutIndex = _ref.layoutIndex,
@@ -11247,20 +11264,25 @@ function VideoPlayer(_ref, ref) {
11247
11264
  currentLayoutIndex = _useState2[0],
11248
11265
  setCurrentLayoutIndex = _useState2[1];
11249
11266
 
11267
+ var _useState3 = useState(url),
11268
+ _useState4 = _slicedToArray(_useState3, 2),
11269
+ urls = _useState4[0],
11270
+ setUrls = _useState4[1];
11271
+
11250
11272
  var initPlayerIndex = layouts[layoutIndex || 0].span >= url.length ? url.length - 1 >= 0 ? url.length - 1 : 0 : layouts[layoutIndex || 0].span - 1;
11251
11273
 
11252
- var _useState3 = useState(initPlayerIndex),
11253
- _useState4 = _slicedToArray(_useState3, 2),
11254
- currentPlayerIndex = _useState4[0],
11255
- setCurrentPlayerIndex = _useState4[1];
11274
+ var _useState5 = useState(initPlayerIndex),
11275
+ _useState6 = _slicedToArray(_useState5, 2),
11276
+ currentPlayerIndex = _useState6[0],
11277
+ setCurrentPlayerIndex = _useState6[1];
11256
11278
 
11257
11279
  var domRef = useRef(null);
11258
11280
  var playerRef = useRef({});
11259
11281
 
11260
- var _useState5 = useState([]),
11261
- _useState6 = _slicedToArray(_useState5, 2),
11262
- players = _useState6[0],
11263
- setPlayers = _useState6[1];
11282
+ var _useState7 = useState([]),
11283
+ _useState8 = _slicedToArray(_useState7, 2),
11284
+ players = _useState8[0],
11285
+ setPlayers = _useState8[1];
11264
11286
 
11265
11287
  var renderDom = useMemo(function () {
11266
11288
  var arr = new Array(layouts[currentLayoutIndex].span).fill(0);
@@ -11271,16 +11293,16 @@ function VideoPlayer(_ref, ref) {
11271
11293
  onClickCapture: function onClickCapture() {
11272
11294
  setCurrentPlayerIndex(index);
11273
11295
  }
11274
- }, url[index] ? /*#__PURE__*/React.createElement(Xgplay$1, {
11296
+ }, urls[index] ? /*#__PURE__*/React.createElement(Xgplay$1, {
11275
11297
  setRef: function setRef(ref) {
11276
11298
  return setPlayers(function (players) {
11277
11299
  players[index] = ref;
11278
11300
  return players;
11279
11301
  });
11280
11302
  },
11281
- type: url[index],
11303
+ type: urls[index],
11282
11304
  config: _objectSpread2({
11283
- url: url[index],
11305
+ url: urls[index],
11284
11306
  fluid: true
11285
11307
  }, config)
11286
11308
  }) : /*#__PURE__*/React.createElement("div", {
@@ -11293,7 +11315,7 @@ function VideoPlayer(_ref, ref) {
11293
11315
  }
11294
11316
  }));
11295
11317
  });
11296
- }, [currentLayoutIndex, currentPlayerIndex, playerRef, url]);
11318
+ }, [currentLayoutIndex, currentPlayerIndex, playerRef, urls]);
11297
11319
 
11298
11320
  function exitFullscreen() {
11299
11321
  if (document.exitFullscreen) {
@@ -11320,10 +11342,13 @@ function VideoPlayer(_ref, ref) {
11320
11342
  var currentPlayer = players[currentPlayerIndex];
11321
11343
 
11322
11344
  if (currentPlayer) {
11323
- console.log(currentPlayer, 'currentPlayer');
11324
- currentPlayer.src = url; // debugger
11325
- // currentPlayer.start(url)
11345
+ currentPlayer.src = url;
11326
11346
  }
11347
+
11348
+ setUrls(function (urls) {
11349
+ urls[currentPlayerIndex] = url;
11350
+ return _toConsumableArray(urls);
11351
+ });
11327
11352
  };
11328
11353
 
11329
11354
  useImperativeHandle(ref, function () {
@@ -11331,14 +11356,16 @@ function VideoPlayer(_ref, ref) {
11331
11356
  players: players,
11332
11357
  currentLayoutIndex: currentLayoutIndex,
11333
11358
  currentPlayerIndex: currentPlayerIndex,
11359
+ urls: urls,
11334
11360
  loadCamera: loadCamera
11335
11361
  };
11336
11362
  });
11337
11363
  return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("div", {
11364
+ className: "videoContainer",
11338
11365
  style: style
11339
11366
  }, /*#__PURE__*/React.createElement("div", {
11340
11367
  ref: domRef,
11341
- className: "videoContainer",
11368
+ className: "videoContainer-grid",
11342
11369
  style: layouts[currentLayoutIndex].style
11343
11370
  }, renderDom), footer ? /*#__PURE__*/React.createElement("div", {
11344
11371
  className: "tools"
package/dist/index.js CHANGED
@@ -9677,8 +9677,7 @@ var controlShow = function controlShow(f1, f2, value, timer) {
9677
9677
  };
9678
9678
 
9679
9679
  function DialogModel(props, ref) {
9680
- var _props$width = props.width,
9681
- width = _props$width === void 0 ? 600 : _props$width,
9680
+ var width = props.width,
9682
9681
  visible = props.visible,
9683
9682
  destroyOnClose = props.destroyOnClose,
9684
9683
  closeCb = props.closeCb,
@@ -9740,8 +9739,7 @@ function DialogModel(props, ref) {
9740
9739
  className: classnames__default['default']((_classNames = {}, _defineProperty(_classNames, className, true), _defineProperty(_classNames, 'model_container', true), _defineProperty(_classNames, "animate__animated", true), _defineProperty(_classNames, flag ? 'animate__bounceInDown' : 'animate__fadeOutRightBig', true), _classNames)),
9741
9740
  style: _objectSpread2({
9742
9741
  opacity: modelShowAync ? 1 : 0,
9743
- width: typeof width == 'number' ? width + 'px' : width,
9744
- left: "calc(50% - ".concat(typeof width == 'number' ? width / 2 : width / 2, "px)")
9742
+ width: typeof width == 'number' ? width + 'px' : width
9745
9743
  }, style)
9746
9744
  }, /*#__PURE__*/React__default['default'].createElement("div", {
9747
9745
  className: 'model_wrap'
@@ -9770,6 +9768,13 @@ function DialogModel(props, ref) {
9770
9768
  }
9771
9769
  })), document.body);
9772
9770
  }, [modelShowAync, modelShow, props, isDesChild]);
9771
+ React.useEffect(function () {
9772
+ var containerEl = containerRef.current;
9773
+ var containerElWidth = containerEl.offsetWidth;
9774
+ var containerElHeight = containerEl.offsetHeight;
9775
+ containerEl.style.left = "calc(50% - ".concat(containerElWidth / 2, "px)");
9776
+ containerEl.style.top = "calc(50% - ".concat(containerElHeight / 2, "px)");
9777
+ }, [modelShow]);
9773
9778
  React.useEffect(function () {
9774
9779
  var containerEl = containerRef.current;
9775
9780
  var rEl = rRef.current;
@@ -9971,6 +9976,11 @@ var Modal = /*#__PURE__*/function (_React$PureComponent) {
9971
9976
  document.onmousemove = null;
9972
9977
  };
9973
9978
  }
9979
+ }, {
9980
+ key: "componentWillUnmount",
9981
+ value: function componentWillUnmount() {
9982
+ Modal.destory();
9983
+ }
9974
9984
  }, {
9975
9985
  key: "render",
9976
9986
  value: function render() {
@@ -10004,18 +10014,19 @@ var Modal = /*#__PURE__*/function (_React$PureComponent) {
10004
10014
 
10005
10015
  Modal.show = void 0;
10006
10016
  Modal.hidden = void 0;
10017
+ Modal.destory = void 0;
10018
+ var Modals = {};
10007
10019
 
10008
10020
  Modal.show = function (config) {
10009
- var ModalContainer = null;
10010
- var modelSysbol = Symbol('$$__model__Container_hidden');
10011
- if (ModalContainer) return;
10021
+ var modelSysbol = Math.random().toString(36).slice(2, 36);
10022
+ if (Modals[modelSysbol]) return;
10012
10023
 
10013
10024
  var props = _objectSpread2(_objectSpread2({}, config), {}, {
10014
10025
  visible: true
10015
10026
  });
10016
10027
 
10017
- var container = ModalContainer = document.createElement('div');
10018
- var manager = container[modelSysbol] = {
10028
+ var container = document.createElement('div');
10029
+ var manager = container[modelSysbol] = Modals[modelSysbol] = {
10019
10030
  setShow: null,
10020
10031
  mounted: false,
10021
10032
  hidden: function hidden() {
@@ -10024,8 +10035,12 @@ Modal.show = function (config) {
10024
10035
  },
10025
10036
  destory: function destory() {
10026
10037
  ReactDOM__default['default'].unmountComponentAtNode(container);
10027
- document.body.removeChild(container);
10028
- ModalContainer = null;
10038
+
10039
+ if (document.body.contains(container)) {
10040
+ document.body.removeChild(container);
10041
+ }
10042
+
10043
+ delete Modals[modelSysbol];
10029
10044
  }
10030
10045
  };
10031
10046
 
@@ -10057,8 +10072,20 @@ Modal.show = function (config) {
10057
10072
  return manager;
10058
10073
  };
10059
10074
 
10060
- Modal.hidden = function () {// if (!ModalContainer) return;
10061
- // ModalContainer[modelSysbol] && ModalContainer[modelSysbol].hidden();
10075
+ Modal.hidden = function () {
10076
+ if (Object.keys(Modals).length == 0) return;
10077
+
10078
+ for (var key in Modals) {
10079
+ Modals[key].hidden();
10080
+ }
10081
+ };
10082
+
10083
+ Modal.destory = function () {
10084
+ if (Object.keys(Modals).length == 0) return;
10085
+
10086
+ for (var key in Modals) {
10087
+ Modals[key].destory();
10088
+ }
10062
10089
  };
10063
10090
 
10064
10091
  var controlShow$1 = function controlShow(f1, f2, value, timer) {
@@ -11146,15 +11173,9 @@ function Xgplay(_ref, fRef) {
11146
11173
  setRef = _ref.setRef;
11147
11174
  var ref = React.useRef(null);
11148
11175
  var playerRef = React.useRef(null);
11149
-
11150
- var _useState = React.useState(null),
11151
- _useState2 = _slicedToArray(_useState, 2),
11152
- player = _useState2[0],
11153
- setPlayer = _useState2[1];
11154
-
11155
11176
  React.useEffect(function () {
11156
11177
  if (ref.current) {
11157
- if (type.indexOf('hls') !== -1) {
11178
+ if ((type === null || type === void 0 ? void 0 : type.indexOf('hls')) !== -1) {
11158
11179
  playerRef.current = new HlsJsPlayer__default['default'](_objectSpread2({
11159
11180
  el: ref.current,
11160
11181
  width: '100%',
@@ -11163,7 +11184,7 @@ function Xgplay(_ref, fRef) {
11163
11184
  isLive: true,
11164
11185
  autoplayMuted: true
11165
11186
  }, config));
11166
- } else if (type.indexOf('flv') !== -1) {
11187
+ } else if ((type === null || type === void 0 ? void 0 : type.indexOf('flv')) !== -1) {
11167
11188
  playerRef.current = new FlvPlayer__default['default'](_objectSpread2({
11168
11189
  el: ref.current,
11169
11190
  width: '100%',
@@ -11172,7 +11193,7 @@ function Xgplay(_ref, fRef) {
11172
11193
  isLive: true,
11173
11194
  autoplayMuted: true
11174
11195
  }, config));
11175
- } else if (type.indexOf('mp4') !== -1) {
11196
+ } else if ((type === null || type === void 0 ? void 0 : type.indexOf('mp4')) !== -1) {
11176
11197
  playerRef.current = new Player__default['default'](_objectSpread2({
11177
11198
  el: ref.current,
11178
11199
  width: '100%',
@@ -11237,11 +11258,7 @@ var IconFont = icons.createFromIconfontCN({
11237
11258
  function VideoPlayer(_ref, ref) {
11238
11259
  var _ref$footer = _ref.footer,
11239
11260
  footer = _ref$footer === void 0 ? true : _ref$footer,
11240
- _ref$style = _ref.style,
11241
- style = _ref$style === void 0 ? {
11242
- width: 400,
11243
- height: 400
11244
- } : _ref$style,
11261
+ style = _ref.style,
11245
11262
  _ref$config = _ref.config,
11246
11263
  config = _ref$config === void 0 ? {} : _ref$config,
11247
11264
  layoutIndex = _ref.layoutIndex,
@@ -11285,20 +11302,25 @@ function VideoPlayer(_ref, ref) {
11285
11302
  currentLayoutIndex = _useState2[0],
11286
11303
  setCurrentLayoutIndex = _useState2[1];
11287
11304
 
11305
+ var _useState3 = React.useState(url),
11306
+ _useState4 = _slicedToArray(_useState3, 2),
11307
+ urls = _useState4[0],
11308
+ setUrls = _useState4[1];
11309
+
11288
11310
  var initPlayerIndex = layouts[layoutIndex || 0].span >= url.length ? url.length - 1 >= 0 ? url.length - 1 : 0 : layouts[layoutIndex || 0].span - 1;
11289
11311
 
11290
- var _useState3 = React.useState(initPlayerIndex),
11291
- _useState4 = _slicedToArray(_useState3, 2),
11292
- currentPlayerIndex = _useState4[0],
11293
- setCurrentPlayerIndex = _useState4[1];
11312
+ var _useState5 = React.useState(initPlayerIndex),
11313
+ _useState6 = _slicedToArray(_useState5, 2),
11314
+ currentPlayerIndex = _useState6[0],
11315
+ setCurrentPlayerIndex = _useState6[1];
11294
11316
 
11295
11317
  var domRef = React.useRef(null);
11296
11318
  var playerRef = React.useRef({});
11297
11319
 
11298
- var _useState5 = React.useState([]),
11299
- _useState6 = _slicedToArray(_useState5, 2),
11300
- players = _useState6[0],
11301
- setPlayers = _useState6[1];
11320
+ var _useState7 = React.useState([]),
11321
+ _useState8 = _slicedToArray(_useState7, 2),
11322
+ players = _useState8[0],
11323
+ setPlayers = _useState8[1];
11302
11324
 
11303
11325
  var renderDom = React.useMemo(function () {
11304
11326
  var arr = new Array(layouts[currentLayoutIndex].span).fill(0);
@@ -11309,16 +11331,16 @@ function VideoPlayer(_ref, ref) {
11309
11331
  onClickCapture: function onClickCapture() {
11310
11332
  setCurrentPlayerIndex(index);
11311
11333
  }
11312
- }, url[index] ? /*#__PURE__*/React__default['default'].createElement(Xgplay$1, {
11334
+ }, urls[index] ? /*#__PURE__*/React__default['default'].createElement(Xgplay$1, {
11313
11335
  setRef: function setRef(ref) {
11314
11336
  return setPlayers(function (players) {
11315
11337
  players[index] = ref;
11316
11338
  return players;
11317
11339
  });
11318
11340
  },
11319
- type: url[index],
11341
+ type: urls[index],
11320
11342
  config: _objectSpread2({
11321
- url: url[index],
11343
+ url: urls[index],
11322
11344
  fluid: true
11323
11345
  }, config)
11324
11346
  }) : /*#__PURE__*/React__default['default'].createElement("div", {
@@ -11331,7 +11353,7 @@ function VideoPlayer(_ref, ref) {
11331
11353
  }
11332
11354
  }));
11333
11355
  });
11334
- }, [currentLayoutIndex, currentPlayerIndex, playerRef, url]);
11356
+ }, [currentLayoutIndex, currentPlayerIndex, playerRef, urls]);
11335
11357
 
11336
11358
  function exitFullscreen() {
11337
11359
  if (document.exitFullscreen) {
@@ -11358,10 +11380,13 @@ function VideoPlayer(_ref, ref) {
11358
11380
  var currentPlayer = players[currentPlayerIndex];
11359
11381
 
11360
11382
  if (currentPlayer) {
11361
- console.log(currentPlayer, 'currentPlayer');
11362
- currentPlayer.src = url; // debugger
11363
- // currentPlayer.start(url)
11383
+ currentPlayer.src = url;
11364
11384
  }
11385
+
11386
+ setUrls(function (urls) {
11387
+ urls[currentPlayerIndex] = url;
11388
+ return _toConsumableArray(urls);
11389
+ });
11365
11390
  };
11366
11391
 
11367
11392
  React.useImperativeHandle(ref, function () {
@@ -11369,14 +11394,16 @@ function VideoPlayer(_ref, ref) {
11369
11394
  players: players,
11370
11395
  currentLayoutIndex: currentLayoutIndex,
11371
11396
  currentPlayerIndex: currentPlayerIndex,
11397
+ urls: urls,
11372
11398
  loadCamera: loadCamera
11373
11399
  };
11374
11400
  });
11375
11401
  return /*#__PURE__*/React__default['default'].createElement(React__default['default'].Fragment, null, /*#__PURE__*/React__default['default'].createElement("div", {
11402
+ className: "videoContainer",
11376
11403
  style: style
11377
11404
  }, /*#__PURE__*/React__default['default'].createElement("div", {
11378
11405
  ref: domRef,
11379
- className: "videoContainer",
11406
+ className: "videoContainer-grid",
11380
11407
  style: layouts[currentLayoutIndex].style
11381
11408
  }, renderDom), footer ? /*#__PURE__*/React__default['default'].createElement("div", {
11382
11409
  className: "tools"
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "private": false,
3
3
  "name": "wargerm",
4
- "version": "0.4.17",
4
+ "version": "0.4.20",
5
5
  "scripts": {
6
6
  "dev": "dumi dev",
7
7
  "docs:build": "dumi build",