wargerm 0.4.14 → 0.4.17

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.
@@ -10,11 +10,14 @@ declare type Props = {
10
10
  okText?: string;
11
11
  cancelText?: string;
12
12
  destroyOnClose?: boolean;
13
+ hiddenMask?: boolean;
14
+ isResize?: boolean;
13
15
  visible?: boolean;
14
16
  width?: number;
15
17
  className?: string;
16
18
  style?: React.CSSProperties;
17
19
  children?: ReactNode;
20
+ ref?: any;
18
21
  };
19
- export default function DialogModel(props: Props): React.ReactPortal;
20
- export {};
22
+ declare const _default: React.ForwardRefExoticComponent<Pick<Props, "width" | "visible" | "destroyOnClose" | "closeCb" | "onClose" | "hiddenMask" | "isResize" | "className" | "style" | "title" | "onOk" | "onCancel" | "footer" | "content" | "okText" | "cancelText" | "children"> & React.RefAttributes<unknown>>;
23
+ export default _default;
@@ -11,8 +11,12 @@ declare type Props = {
11
11
  cancelText?: string;
12
12
  visible?: boolean;
13
13
  destroyOnClose?: boolean;
14
+ hiddenMask?: boolean;
15
+ isDrag?: boolean;
16
+ isResize?: boolean;
14
17
  width?: number;
15
18
  className?: string;
19
+ ref?: any;
16
20
  style?: React.CSSProperties;
17
21
  };
18
22
  declare class Modal extends React.PureComponent<Props> {
@@ -24,7 +28,10 @@ declare class Modal extends React.PureComponent<Props> {
24
28
  } | undefined;
25
29
  static hidden: () => void;
26
30
  renderFooter: () => JSX.Element | null;
31
+ containerRef: React.RefObject<any>;
32
+ titleRef: React.RefObject<any>;
27
33
  renderTop: () => JSX.Element;
34
+ componentDidMount(): void;
28
35
  renderContent: () => {} | null;
29
36
  render(): JSX.Element;
30
37
  }
package/dist/index.css CHANGED
@@ -1162,11 +1162,7 @@ button[data-prefers-color='dark'] .swiper-pagination-bullet {
1162
1162
  [data-prefers-color='dark'] .model_container {
1163
1163
  position: absolute;
1164
1164
  z-index: 1000;
1165
- top: 0;
1166
- left: 0;
1167
- right: 0;
1168
- margin: auto;
1169
- bottom: 0;
1165
+ top: 20%;
1170
1166
  border-width: 57px 166px 62px 166px;
1171
1167
  border-style: solid;
1172
1168
  -o-border-image: url('') round;
@@ -1175,7 +1171,7 @@ button[data-prefers-color='dark'] .swiper-pagination-bullet {
1175
1171
  border-image-width: 57px 166px 62px 166px;
1176
1172
  border-image-repeat: stretch stretch;
1177
1173
  min-height: 500px;
1178
- min-width: 1500px;
1174
+ min-width: 600px;
1179
1175
  }
1180
1176
  [data-prefers-color='dark'] .model_container .model_wrap {
1181
1177
  position: absolute;
@@ -1212,6 +1208,9 @@ button[data-prefers-color='dark'] .swiper-pagination-bullet {
1212
1208
  -webkit-background-clip: text;
1213
1209
  color: transparent;
1214
1210
  }
1211
+ [data-prefers-color='dark'] .model_container .model_wrap .model-header .model-title.move {
1212
+ cursor: move;
1213
+ }
1215
1214
  [data-prefers-color='dark'] .model_container .model_wrap .model-header .model-closeIcon {
1216
1215
  font-size: 26px;
1217
1216
  position: absolute;
@@ -2360,11 +2359,7 @@ button[data-prefers-color='light'] .swiper-pagination-bullet {
2360
2359
  [data-prefers-color='light'] .model_container {
2361
2360
  position: absolute;
2362
2361
  z-index: 1000;
2363
- top: 0;
2364
- left: 0;
2365
- right: 0;
2366
- margin: auto;
2367
- bottom: 0;
2362
+ top: 20%;
2368
2363
  border-width: 57px 166px 62px 166px;
2369
2364
  border-style: solid;
2370
2365
  -o-border-image: url('') round;
@@ -2372,8 +2367,8 @@ button[data-prefers-color='light'] .swiper-pagination-bullet {
2372
2367
  border-image-slice: 57 166 62 166;
2373
2368
  border-image-width: 57px 166px 62px 166px;
2374
2369
  border-image-repeat: stretch stretch;
2375
- min-height: 500px;
2376
- min-width: 1500px;
2370
+ min-height: 300px;
2371
+ min-width: 200px;
2377
2372
  }
2378
2373
  [data-prefers-color='light'] .model_container .model_wrap {
2379
2374
  position: absolute;
@@ -2384,6 +2379,33 @@ button[data-prefers-color='light'] .swiper-pagination-bullet {
2384
2379
  transform: translate(-166px, -60px);
2385
2380
  padding: 12px 6px;
2386
2381
  }
2382
+ [data-prefers-color='light'] .model_container .model_wrap .resizer {
2383
+ width: 10px;
2384
+ height: 100%;
2385
+ position: absolute;
2386
+ right: 0;
2387
+ top: 0;
2388
+ cursor: e-resize;
2389
+ z-index: 100;
2390
+ }
2391
+ [data-prefers-color='light'] .model_container .model_wrap .resizeb {
2392
+ width: 100%;
2393
+ height: 10px;
2394
+ position: absolute;
2395
+ left: 0;
2396
+ bottom: 0;
2397
+ cursor: n-resize;
2398
+ z-index: 100;
2399
+ }
2400
+ [data-prefers-color='light'] .model_container .model_wrap .resizerb {
2401
+ width: 20px;
2402
+ height: 20px;
2403
+ position: absolute;
2404
+ right: 0;
2405
+ bottom: 0;
2406
+ cursor: se-resize;
2407
+ z-index: 101;
2408
+ }
2387
2409
  [data-prefers-color='light'] .model_container .model_wrap .model-header .model-title {
2388
2410
  position: absolute;
2389
2411
  z-index: 99;
@@ -2392,6 +2414,7 @@ button[data-prefers-color='light'] .swiper-pagination-bullet {
2392
2414
  transform: translate(-50%, -50%);
2393
2415
  background: url('') no-repeat center center;
2394
2416
  width: 630px;
2417
+ width: 60%;
2395
2418
  height: 75px;
2396
2419
  font-size: 18px;
2397
2420
  font-family: Microsoft YaHei Regular, Microsoft YaHei Regular-Regular;
@@ -2402,6 +2425,7 @@ button[data-prefers-color='light'] .swiper-pagination-bullet {
2402
2425
  display: flex;
2403
2426
  justify-content: center;
2404
2427
  align-items: center;
2428
+ background-size: contain;
2405
2429
  }
2406
2430
  [data-prefers-color='light'] .model_container .model_wrap .model-header .model-title span {
2407
2431
  font-size: 18px;
@@ -2410,6 +2434,10 @@ button[data-prefers-color='light'] .swiper-pagination-bullet {
2410
2434
  -webkit-background-clip: text;
2411
2435
  color: transparent;
2412
2436
  }
2437
+ [data-prefers-color='light'] .model_container .model_wrap .model-header .model-title.move {
2438
+ cursor: move;
2439
+ z-index: 100;
2440
+ }
2413
2441
  [data-prefers-color='light'] .model_container .model_wrap .model-header .model-closeIcon {
2414
2442
  font-size: 26px;
2415
2443
  position: absolute;
@@ -1162,11 +1162,7 @@ button[data-prefers-color='dark'] .swiper-pagination-bullet {
1162
1162
  [data-prefers-color='dark'] .model_container {
1163
1163
  position: absolute;
1164
1164
  z-index: 1000;
1165
- top: 0;
1166
- left: 0;
1167
- right: 0;
1168
- margin: auto;
1169
- bottom: 0;
1165
+ top: 20%;
1170
1166
  border-width: 57px 166px 62px 166px;
1171
1167
  border-style: solid;
1172
1168
  -o-border-image: url('') round;
@@ -1175,7 +1171,7 @@ button[data-prefers-color='dark'] .swiper-pagination-bullet {
1175
1171
  border-image-width: 57px 166px 62px 166px;
1176
1172
  border-image-repeat: stretch stretch;
1177
1173
  min-height: 500px;
1178
- min-width: 1500px;
1174
+ min-width: 600px;
1179
1175
  }
1180
1176
  [data-prefers-color='dark'] .model_container .model_wrap {
1181
1177
  position: absolute;
@@ -1212,6 +1208,9 @@ button[data-prefers-color='dark'] .swiper-pagination-bullet {
1212
1208
  -webkit-background-clip: text;
1213
1209
  color: transparent;
1214
1210
  }
1211
+ [data-prefers-color='dark'] .model_container .model_wrap .model-header .model-title.move {
1212
+ cursor: move;
1213
+ }
1215
1214
  [data-prefers-color='dark'] .model_container .model_wrap .model-header .model-closeIcon {
1216
1215
  font-size: 26px;
1217
1216
  position: absolute;
@@ -2360,11 +2359,7 @@ button[data-prefers-color='light'] .swiper-pagination-bullet {
2360
2359
  [data-prefers-color='light'] .model_container {
2361
2360
  position: absolute;
2362
2361
  z-index: 1000;
2363
- top: 0;
2364
- left: 0;
2365
- right: 0;
2366
- margin: auto;
2367
- bottom: 0;
2362
+ top: 20%;
2368
2363
  border-width: 57px 166px 62px 166px;
2369
2364
  border-style: solid;
2370
2365
  -o-border-image: url('') round;
@@ -2372,8 +2367,8 @@ button[data-prefers-color='light'] .swiper-pagination-bullet {
2372
2367
  border-image-slice: 57 166 62 166;
2373
2368
  border-image-width: 57px 166px 62px 166px;
2374
2369
  border-image-repeat: stretch stretch;
2375
- min-height: 500px;
2376
- min-width: 1500px;
2370
+ min-height: 300px;
2371
+ min-width: 200px;
2377
2372
  }
2378
2373
  [data-prefers-color='light'] .model_container .model_wrap {
2379
2374
  position: absolute;
@@ -2384,6 +2379,33 @@ button[data-prefers-color='light'] .swiper-pagination-bullet {
2384
2379
  transform: translate(-166px, -60px);
2385
2380
  padding: 12px 6px;
2386
2381
  }
2382
+ [data-prefers-color='light'] .model_container .model_wrap .resizer {
2383
+ width: 10px;
2384
+ height: 100%;
2385
+ position: absolute;
2386
+ right: 0;
2387
+ top: 0;
2388
+ cursor: e-resize;
2389
+ z-index: 100;
2390
+ }
2391
+ [data-prefers-color='light'] .model_container .model_wrap .resizeb {
2392
+ width: 100%;
2393
+ height: 10px;
2394
+ position: absolute;
2395
+ left: 0;
2396
+ bottom: 0;
2397
+ cursor: n-resize;
2398
+ z-index: 100;
2399
+ }
2400
+ [data-prefers-color='light'] .model_container .model_wrap .resizerb {
2401
+ width: 20px;
2402
+ height: 20px;
2403
+ position: absolute;
2404
+ right: 0;
2405
+ bottom: 0;
2406
+ cursor: se-resize;
2407
+ z-index: 101;
2408
+ }
2387
2409
  [data-prefers-color='light'] .model_container .model_wrap .model-header .model-title {
2388
2410
  position: absolute;
2389
2411
  z-index: 99;
@@ -2392,6 +2414,7 @@ button[data-prefers-color='light'] .swiper-pagination-bullet {
2392
2414
  transform: translate(-50%, -50%);
2393
2415
  background: url('') no-repeat center center;
2394
2416
  width: 630px;
2417
+ width: 60%;
2395
2418
  height: 75px;
2396
2419
  font-size: 18px;
2397
2420
  font-family: Microsoft YaHei Regular, Microsoft YaHei Regular-Regular;
@@ -2402,6 +2425,7 @@ button[data-prefers-color='light'] .swiper-pagination-bullet {
2402
2425
  display: flex;
2403
2426
  justify-content: center;
2404
2427
  align-items: center;
2428
+ background-size: contain;
2405
2429
  }
2406
2430
  [data-prefers-color='light'] .model_container .model_wrap .model-header .model-title span {
2407
2431
  font-size: 18px;
@@ -2410,6 +2434,10 @@ button[data-prefers-color='light'] .swiper-pagination-bullet {
2410
2434
  -webkit-background-clip: text;
2411
2435
  color: transparent;
2412
2436
  }
2437
+ [data-prefers-color='light'] .model_container .model_wrap .model-header .model-title.move {
2438
+ cursor: move;
2439
+ z-index: 100;
2440
+ }
2413
2441
  [data-prefers-color='light'] .model_container .model_wrap .model-header .model-closeIcon {
2414
2442
  font-size: 26px;
2415
2443
  position: absolute;
package/dist/index.esm.js CHANGED
@@ -4,7 +4,7 @@ import 'antd/es/dropdown/style';
4
4
  import _Dropdown from 'antd/es/dropdown';
5
5
  import 'antd/es/menu/style';
6
6
  import _Menu from 'antd/es/menu';
7
- import React, { memo, useState, useEffect, useMemo, useImperativeHandle, useRef, forwardRef } from 'react';
7
+ import React, { memo, useState, useEffect, useMemo, useImperativeHandle, useRef, forwardRef, createRef } from 'react';
8
8
  import { createFromIconfontCN, SearchOutlined, ReloadOutlined, CloseCircleOutlined, PlusOutlined, EllipsisOutlined, ExclamationCircleOutlined, EyeOutlined, EditOutlined, DeleteOutlined } from '@ant-design/icons';
9
9
  import 'antd/es/input/style';
10
10
  import _Input from 'antd/es/input';
@@ -9638,12 +9638,15 @@ var controlShow = function controlShow(f1, f2, value, timer) {
9638
9638
  }, timer);
9639
9639
  };
9640
9640
 
9641
- function DialogModel(props) {
9642
- var width = props.width,
9641
+ function DialogModel(props, ref) {
9642
+ var _props$width = props.width,
9643
+ width = _props$width === void 0 ? 600 : _props$width,
9643
9644
  visible = props.visible,
9644
9645
  destroyOnClose = props.destroyOnClose,
9645
9646
  closeCb = props.closeCb,
9646
9647
  onClose = props.onClose,
9648
+ hiddenMask = props.hiddenMask,
9649
+ isResize = props.isResize,
9647
9650
  _props$className = props.className,
9648
9651
  className = _props$className === void 0 ? 'default-dialog' : _props$className,
9649
9652
  style = props.style;
@@ -9673,6 +9676,16 @@ function DialogModel(props) {
9673
9676
  isDesChild = _useState10[0],
9674
9677
  setIsDesChild = _useState10[1];
9675
9678
 
9679
+ var containerRef = useRef();
9680
+ var ltRef = useRef();
9681
+ var rRef = useRef();
9682
+ var bRef = useRef();
9683
+ var rbRef = useRef();
9684
+ useImperativeHandle(ref, function () {
9685
+ return {
9686
+ containerRef: containerRef.current
9687
+ };
9688
+ });
9676
9689
  var renderChildren = useMemo(function () {
9677
9690
  var _classNames;
9678
9691
 
@@ -9685,20 +9698,31 @@ function DialogModel(props) {
9685
9698
  left: 0
9686
9699
  }
9687
9700
  }, /*#__PURE__*/React.createElement("div", {
9701
+ ref: containerRef,
9688
9702
  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)),
9689
9703
  style: _objectSpread2({
9690
9704
  opacity: modelShowAync ? 1 : 0,
9691
- width: typeof width == 'number' ? width + 'px' : width
9705
+ width: typeof width == 'number' ? width + 'px' : width,
9706
+ left: "calc(50% - ".concat(typeof width == 'number' ? width / 2 : width / 2, "px)")
9692
9707
  }, style)
9693
9708
  }, /*#__PURE__*/React.createElement("div", {
9694
9709
  className: 'model_wrap'
9695
- }, /*#__PURE__*/React.createElement("div", {
9710
+ }, isResize && /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("div", {
9711
+ ref: rRef,
9712
+ className: "resizer"
9713
+ }), /*#__PURE__*/React.createElement("div", {
9714
+ ref: bRef,
9715
+ className: "resizeb"
9716
+ }), /*#__PURE__*/React.createElement("div", {
9717
+ ref: rbRef,
9718
+ className: "resizerb"
9719
+ })), /*#__PURE__*/React.createElement("div", {
9696
9720
  style: {
9697
9721
  width: '100%',
9698
9722
  height: '100%',
9699
9723
  position: 'relative'
9700
9724
  }
9701
- }, isDesChild ? null : props.children))), /*#__PURE__*/React.createElement("div", {
9725
+ }, isDesChild ? null : props.children))), !hiddenMask && /*#__PURE__*/React.createElement("div", {
9702
9726
  className: 'mask',
9703
9727
  onClick: function onClick() {
9704
9728
  onClose && onClose();
@@ -9708,6 +9732,66 @@ function DialogModel(props) {
9708
9732
  }
9709
9733
  })), document.body);
9710
9734
  }, [modelShowAync, modelShow, props, isDesChild]);
9735
+ useEffect(function () {
9736
+ var containerEl = containerRef.current;
9737
+ var rEl = rRef.current;
9738
+ var bEl = bRef.current;
9739
+ var rbEl = rbRef.current;
9740
+
9741
+ if (containerEl && isResize) {
9742
+ rEl.onmousedown = function (e) {
9743
+ var disX = e.clientX - rEl.offsetLeft; // const disY = e.clientY - rEl.offsetTop;
9744
+
9745
+ document.onmousemove = function (e) {
9746
+ e.stopPropagation();
9747
+ e.preventDefault();
9748
+ var l = e.clientX - disX; // const h = e.clientY - disY;
9749
+
9750
+ containerEl.style.width = "".concat(l, "px"); // containerEl.style.height = `${h}px`;
9751
+ };
9752
+
9753
+ document.onmouseup = function (e) {
9754
+ document.onmousemove = null;
9755
+ };
9756
+ };
9757
+
9758
+ bEl.onmousedown = function (e) {
9759
+ // const disX = e.clientX - bEl.offsetLeft;
9760
+ var disY = e.clientY - bEl.offsetTop;
9761
+
9762
+ document.onmousemove = function (e) {
9763
+ e.stopPropagation();
9764
+ e.preventDefault(); // const l = e.clientX - disX;
9765
+
9766
+ var h = e.clientY - disY; // containerEl.style.width = `${l}px`;
9767
+
9768
+ containerEl.style.height = "".concat(h, "px");
9769
+ };
9770
+
9771
+ document.onmouseup = function (e) {
9772
+ document.onmousemove = null;
9773
+ };
9774
+ };
9775
+
9776
+ rbEl.onmousedown = function (e) {
9777
+ var disX = e.clientX - rbEl.offsetLeft;
9778
+ var disY = e.clientY - rbEl.offsetTop;
9779
+
9780
+ document.onmousemove = function (e) {
9781
+ e.stopPropagation();
9782
+ e.preventDefault();
9783
+ var l = e.clientX - disX;
9784
+ var h = e.clientY - disY;
9785
+ containerEl.style.width = "".concat(l, "px");
9786
+ containerEl.style.height = "".concat(h, "px");
9787
+ };
9788
+
9789
+ document.onmouseup = function (e) {
9790
+ document.onmousemove = null;
9791
+ };
9792
+ };
9793
+ }
9794
+ }, []);
9711
9795
  useEffect(function () {
9712
9796
  var timer;
9713
9797
  setFlag(visible);
@@ -9740,6 +9824,8 @@ function DialogModel(props) {
9740
9824
  return renderChildren;
9741
9825
  }
9742
9826
 
9827
+ var Dialog = /*#__PURE__*/React.forwardRef(DialogModel);
9828
+
9743
9829
  var _excluded$e = ["visible", "width", "closeCb", "onClose", "className", "style"],
9744
9830
  _excluded2$3 = ["visible"];
9745
9831
 
@@ -9785,18 +9871,25 @@ var Modal = /*#__PURE__*/function (_React$PureComponent) {
9785
9871
  }, cancelText || '取消')));
9786
9872
  };
9787
9873
 
9874
+ _this.containerRef = /*#__PURE__*/createRef();
9875
+ _this.titleRef = /*#__PURE__*/createRef();
9876
+
9788
9877
  _this.renderTop = function () {
9789
9878
  var _this$props2 = _this.props,
9790
9879
  title = _this$props2.title,
9791
- onClose = _this$props2.onClose;
9880
+ onClose = _this$props2.onClose,
9881
+ closeCb = _this$props2.closeCb,
9882
+ isDrag = _this$props2.isDrag;
9792
9883
  return /*#__PURE__*/React.createElement("div", {
9793
9884
  className: "model-header"
9794
9885
  }, /*#__PURE__*/React.createElement("div", {
9795
- className: "model-title"
9886
+ ref: _this.titleRef,
9887
+ className: "model-title ".concat(isDrag ? 'move' : '')
9796
9888
  }, title), /*#__PURE__*/React.createElement(CloseCircleOutlined, {
9797
9889
  className: "model-closeIcon",
9798
9890
  onClick: function onClick() {
9799
- return onClose && onClose();
9891
+ onClose && onClose();
9892
+ closeCb && closeCb();
9800
9893
  }
9801
9894
  }));
9802
9895
  };
@@ -9812,6 +9905,35 @@ var Modal = /*#__PURE__*/function (_React$PureComponent) {
9812
9905
  }
9813
9906
 
9814
9907
  _createClass(Modal, [{
9908
+ key: "componentDidMount",
9909
+ value: function componentDidMount() {
9910
+ var isDrag = this.props.isDrag;
9911
+ if (!isDrag) return;
9912
+ var tltleEl = this.titleRef.current;
9913
+ var containerEl = this.containerRef.current.containerRef;
9914
+
9915
+ tltleEl.onmousedown = function (eventDown) {
9916
+ var left = containerEl.offsetLeft;
9917
+ var top = containerEl.offsetTop;
9918
+ console.log(left, top);
9919
+ var downX = eventDown.clientX;
9920
+ var downY = eventDown.clientY;
9921
+
9922
+ document.onmousemove = function (eventMove) {
9923
+ eventMove.stopPropagation();
9924
+ eventMove.preventDefault();
9925
+ var moveX = eventMove.clientX - downX;
9926
+ var moveY = eventMove.clientY - downY;
9927
+ containerEl.style.left = "".concat(left + moveX, "px");
9928
+ containerEl.style.top = "".concat(top + moveY, "px");
9929
+ };
9930
+ };
9931
+
9932
+ document.onmouseup = function (eventMove) {
9933
+ document.onmousemove = null;
9934
+ };
9935
+ }
9936
+ }, {
9815
9937
  key: "render",
9816
9938
  value: function render() {
9817
9939
  var _this$props4 = this.props,
@@ -9823,7 +9945,8 @@ var Modal = /*#__PURE__*/function (_React$PureComponent) {
9823
9945
  style = _this$props4.style,
9824
9946
  other = _objectWithoutProperties(_this$props4, _excluded$e);
9825
9947
 
9826
- return /*#__PURE__*/React.createElement(DialogModel, _objectSpread2({
9948
+ return /*#__PURE__*/React.createElement(Dialog, _objectSpread2({
9949
+ ref: this.containerRef,
9827
9950
  closeCb: closeCb,
9828
9951
  onClose: onClose,
9829
9952
  visible: visible,
@@ -9843,10 +9966,10 @@ var Modal = /*#__PURE__*/function (_React$PureComponent) {
9843
9966
 
9844
9967
  Modal.show = void 0;
9845
9968
  Modal.hidden = void 0;
9846
- var ModalContainer = null;
9847
- var modelSysbol = Symbol('$$__model__Container_hidden');
9848
9969
 
9849
9970
  Modal.show = function (config) {
9971
+ var ModalContainer = null;
9972
+ var modelSysbol = Symbol('$$__model__Container_hidden');
9850
9973
  if (ModalContainer) return;
9851
9974
 
9852
9975
  var props = _objectSpread2(_objectSpread2({}, config), {}, {
@@ -9896,9 +10019,8 @@ Modal.show = function (config) {
9896
10019
  return manager;
9897
10020
  };
9898
10021
 
9899
- Modal.hidden = function () {
9900
- if (!ModalContainer) return;
9901
- ModalContainer[modelSysbol] && ModalContainer[modelSysbol].hidden();
10022
+ Modal.hidden = function () {// if (!ModalContainer) return;
10023
+ // ModalContainer[modelSysbol] && ModalContainer[modelSysbol].hidden();
9902
10024
  };
9903
10025
 
9904
10026
  var controlShow$1 = function controlShow(f1, f2, value, timer) {
@@ -10093,18 +10215,18 @@ var Modal$1 = /*#__PURE__*/function (_React$PureComponent) {
10093
10215
 
10094
10216
  Modal$1.show = void 0;
10095
10217
  Modal$1.hidden = void 0;
10096
- var ModalContainer$1 = null;
10097
- var modelSysbol$1 = Symbol('$$__model__Container_hidden');
10218
+ var ModalContainer = null;
10219
+ var modelSysbol = Symbol('$$__model__Container_hidden');
10098
10220
 
10099
10221
  Modal$1.show = function (config) {
10100
- if (ModalContainer$1) return;
10222
+ if (ModalContainer) return;
10101
10223
 
10102
10224
  var props = _objectSpread2(_objectSpread2({}, config), {}, {
10103
10225
  visible: true
10104
10226
  });
10105
10227
 
10106
- var container = ModalContainer$1 = document.createElement('div');
10107
- var manager = container[modelSysbol$1] = {
10228
+ var container = ModalContainer = document.createElement('div');
10229
+ var manager = container[modelSysbol] = {
10108
10230
  setShow: null,
10109
10231
  mounted: false,
10110
10232
  hidden: function hidden() {
@@ -10114,7 +10236,7 @@ Modal$1.show = function (config) {
10114
10236
  destory: function destory() {
10115
10237
  ReactDOM.unmountComponentAtNode(container);
10116
10238
  document.body.removeChild(container);
10117
- ModalContainer$1 = null;
10239
+ ModalContainer = null;
10118
10240
  }
10119
10241
  };
10120
10242
 
@@ -10147,8 +10269,8 @@ Modal$1.show = function (config) {
10147
10269
  };
10148
10270
 
10149
10271
  Modal$1.hidden = function () {
10150
- if (!ModalContainer$1) return;
10151
- ModalContainer$1[modelSysbol$1] && ModalContainer$1[modelSysbol$1].hidden();
10272
+ if (!ModalContainer) return;
10273
+ ModalContainer[modelSysbol] && ModalContainer[modelSysbol].hidden();
10152
10274
  };
10153
10275
 
10154
10276
  var _excluded$g = ["columns", "extraColumns", "search", "visible", "setVisible", "disabled", "submitMethod", "onSubmitSuccess", "title", "record", "onFormChange"];
package/dist/index.js CHANGED
@@ -9676,12 +9676,15 @@ var controlShow = function controlShow(f1, f2, value, timer) {
9676
9676
  }, timer);
9677
9677
  };
9678
9678
 
9679
- function DialogModel(props) {
9680
- var width = props.width,
9679
+ function DialogModel(props, ref) {
9680
+ var _props$width = props.width,
9681
+ width = _props$width === void 0 ? 600 : _props$width,
9681
9682
  visible = props.visible,
9682
9683
  destroyOnClose = props.destroyOnClose,
9683
9684
  closeCb = props.closeCb,
9684
9685
  onClose = props.onClose,
9686
+ hiddenMask = props.hiddenMask,
9687
+ isResize = props.isResize,
9685
9688
  _props$className = props.className,
9686
9689
  className = _props$className === void 0 ? 'default-dialog' : _props$className,
9687
9690
  style = props.style;
@@ -9711,6 +9714,16 @@ function DialogModel(props) {
9711
9714
  isDesChild = _useState10[0],
9712
9715
  setIsDesChild = _useState10[1];
9713
9716
 
9717
+ var containerRef = React.useRef();
9718
+ var ltRef = React.useRef();
9719
+ var rRef = React.useRef();
9720
+ var bRef = React.useRef();
9721
+ var rbRef = React.useRef();
9722
+ React.useImperativeHandle(ref, function () {
9723
+ return {
9724
+ containerRef: containerRef.current
9725
+ };
9726
+ });
9714
9727
  var renderChildren = React.useMemo(function () {
9715
9728
  var _classNames;
9716
9729
 
@@ -9723,20 +9736,31 @@ function DialogModel(props) {
9723
9736
  left: 0
9724
9737
  }
9725
9738
  }, /*#__PURE__*/React__default['default'].createElement("div", {
9739
+ ref: containerRef,
9726
9740
  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)),
9727
9741
  style: _objectSpread2({
9728
9742
  opacity: modelShowAync ? 1 : 0,
9729
- width: typeof width == 'number' ? width + 'px' : width
9743
+ width: typeof width == 'number' ? width + 'px' : width,
9744
+ left: "calc(50% - ".concat(typeof width == 'number' ? width / 2 : width / 2, "px)")
9730
9745
  }, style)
9731
9746
  }, /*#__PURE__*/React__default['default'].createElement("div", {
9732
9747
  className: 'model_wrap'
9733
- }, /*#__PURE__*/React__default['default'].createElement("div", {
9748
+ }, isResize && /*#__PURE__*/React__default['default'].createElement(React__default['default'].Fragment, null, /*#__PURE__*/React__default['default'].createElement("div", {
9749
+ ref: rRef,
9750
+ className: "resizer"
9751
+ }), /*#__PURE__*/React__default['default'].createElement("div", {
9752
+ ref: bRef,
9753
+ className: "resizeb"
9754
+ }), /*#__PURE__*/React__default['default'].createElement("div", {
9755
+ ref: rbRef,
9756
+ className: "resizerb"
9757
+ })), /*#__PURE__*/React__default['default'].createElement("div", {
9734
9758
  style: {
9735
9759
  width: '100%',
9736
9760
  height: '100%',
9737
9761
  position: 'relative'
9738
9762
  }
9739
- }, isDesChild ? null : props.children))), /*#__PURE__*/React__default['default'].createElement("div", {
9763
+ }, isDesChild ? null : props.children))), !hiddenMask && /*#__PURE__*/React__default['default'].createElement("div", {
9740
9764
  className: 'mask',
9741
9765
  onClick: function onClick() {
9742
9766
  onClose && onClose();
@@ -9746,6 +9770,66 @@ function DialogModel(props) {
9746
9770
  }
9747
9771
  })), document.body);
9748
9772
  }, [modelShowAync, modelShow, props, isDesChild]);
9773
+ React.useEffect(function () {
9774
+ var containerEl = containerRef.current;
9775
+ var rEl = rRef.current;
9776
+ var bEl = bRef.current;
9777
+ var rbEl = rbRef.current;
9778
+
9779
+ if (containerEl && isResize) {
9780
+ rEl.onmousedown = function (e) {
9781
+ var disX = e.clientX - rEl.offsetLeft; // const disY = e.clientY - rEl.offsetTop;
9782
+
9783
+ document.onmousemove = function (e) {
9784
+ e.stopPropagation();
9785
+ e.preventDefault();
9786
+ var l = e.clientX - disX; // const h = e.clientY - disY;
9787
+
9788
+ containerEl.style.width = "".concat(l, "px"); // containerEl.style.height = `${h}px`;
9789
+ };
9790
+
9791
+ document.onmouseup = function (e) {
9792
+ document.onmousemove = null;
9793
+ };
9794
+ };
9795
+
9796
+ bEl.onmousedown = function (e) {
9797
+ // const disX = e.clientX - bEl.offsetLeft;
9798
+ var disY = e.clientY - bEl.offsetTop;
9799
+
9800
+ document.onmousemove = function (e) {
9801
+ e.stopPropagation();
9802
+ e.preventDefault(); // const l = e.clientX - disX;
9803
+
9804
+ var h = e.clientY - disY; // containerEl.style.width = `${l}px`;
9805
+
9806
+ containerEl.style.height = "".concat(h, "px");
9807
+ };
9808
+
9809
+ document.onmouseup = function (e) {
9810
+ document.onmousemove = null;
9811
+ };
9812
+ };
9813
+
9814
+ rbEl.onmousedown = function (e) {
9815
+ var disX = e.clientX - rbEl.offsetLeft;
9816
+ var disY = e.clientY - rbEl.offsetTop;
9817
+
9818
+ document.onmousemove = function (e) {
9819
+ e.stopPropagation();
9820
+ e.preventDefault();
9821
+ var l = e.clientX - disX;
9822
+ var h = e.clientY - disY;
9823
+ containerEl.style.width = "".concat(l, "px");
9824
+ containerEl.style.height = "".concat(h, "px");
9825
+ };
9826
+
9827
+ document.onmouseup = function (e) {
9828
+ document.onmousemove = null;
9829
+ };
9830
+ };
9831
+ }
9832
+ }, []);
9749
9833
  React.useEffect(function () {
9750
9834
  var timer;
9751
9835
  setFlag(visible);
@@ -9778,6 +9862,8 @@ function DialogModel(props) {
9778
9862
  return renderChildren;
9779
9863
  }
9780
9864
 
9865
+ var Dialog = /*#__PURE__*/React__default['default'].forwardRef(DialogModel);
9866
+
9781
9867
  var _excluded$e = ["visible", "width", "closeCb", "onClose", "className", "style"],
9782
9868
  _excluded2$3 = ["visible"];
9783
9869
 
@@ -9823,18 +9909,25 @@ var Modal = /*#__PURE__*/function (_React$PureComponent) {
9823
9909
  }, cancelText || '取消')));
9824
9910
  };
9825
9911
 
9912
+ _this.containerRef = /*#__PURE__*/React.createRef();
9913
+ _this.titleRef = /*#__PURE__*/React.createRef();
9914
+
9826
9915
  _this.renderTop = function () {
9827
9916
  var _this$props2 = _this.props,
9828
9917
  title = _this$props2.title,
9829
- onClose = _this$props2.onClose;
9918
+ onClose = _this$props2.onClose,
9919
+ closeCb = _this$props2.closeCb,
9920
+ isDrag = _this$props2.isDrag;
9830
9921
  return /*#__PURE__*/React__default['default'].createElement("div", {
9831
9922
  className: "model-header"
9832
9923
  }, /*#__PURE__*/React__default['default'].createElement("div", {
9833
- className: "model-title"
9924
+ ref: _this.titleRef,
9925
+ className: "model-title ".concat(isDrag ? 'move' : '')
9834
9926
  }, title), /*#__PURE__*/React__default['default'].createElement(icons.CloseCircleOutlined, {
9835
9927
  className: "model-closeIcon",
9836
9928
  onClick: function onClick() {
9837
- return onClose && onClose();
9929
+ onClose && onClose();
9930
+ closeCb && closeCb();
9838
9931
  }
9839
9932
  }));
9840
9933
  };
@@ -9850,6 +9943,35 @@ var Modal = /*#__PURE__*/function (_React$PureComponent) {
9850
9943
  }
9851
9944
 
9852
9945
  _createClass(Modal, [{
9946
+ key: "componentDidMount",
9947
+ value: function componentDidMount() {
9948
+ var isDrag = this.props.isDrag;
9949
+ if (!isDrag) return;
9950
+ var tltleEl = this.titleRef.current;
9951
+ var containerEl = this.containerRef.current.containerRef;
9952
+
9953
+ tltleEl.onmousedown = function (eventDown) {
9954
+ var left = containerEl.offsetLeft;
9955
+ var top = containerEl.offsetTop;
9956
+ console.log(left, top);
9957
+ var downX = eventDown.clientX;
9958
+ var downY = eventDown.clientY;
9959
+
9960
+ document.onmousemove = function (eventMove) {
9961
+ eventMove.stopPropagation();
9962
+ eventMove.preventDefault();
9963
+ var moveX = eventMove.clientX - downX;
9964
+ var moveY = eventMove.clientY - downY;
9965
+ containerEl.style.left = "".concat(left + moveX, "px");
9966
+ containerEl.style.top = "".concat(top + moveY, "px");
9967
+ };
9968
+ };
9969
+
9970
+ document.onmouseup = function (eventMove) {
9971
+ document.onmousemove = null;
9972
+ };
9973
+ }
9974
+ }, {
9853
9975
  key: "render",
9854
9976
  value: function render() {
9855
9977
  var _this$props4 = this.props,
@@ -9861,7 +9983,8 @@ var Modal = /*#__PURE__*/function (_React$PureComponent) {
9861
9983
  style = _this$props4.style,
9862
9984
  other = _objectWithoutProperties(_this$props4, _excluded$e);
9863
9985
 
9864
- return /*#__PURE__*/React__default['default'].createElement(DialogModel, _objectSpread2({
9986
+ return /*#__PURE__*/React__default['default'].createElement(Dialog, _objectSpread2({
9987
+ ref: this.containerRef,
9865
9988
  closeCb: closeCb,
9866
9989
  onClose: onClose,
9867
9990
  visible: visible,
@@ -9881,10 +10004,10 @@ var Modal = /*#__PURE__*/function (_React$PureComponent) {
9881
10004
 
9882
10005
  Modal.show = void 0;
9883
10006
  Modal.hidden = void 0;
9884
- var ModalContainer = null;
9885
- var modelSysbol = Symbol('$$__model__Container_hidden');
9886
10007
 
9887
10008
  Modal.show = function (config) {
10009
+ var ModalContainer = null;
10010
+ var modelSysbol = Symbol('$$__model__Container_hidden');
9888
10011
  if (ModalContainer) return;
9889
10012
 
9890
10013
  var props = _objectSpread2(_objectSpread2({}, config), {}, {
@@ -9934,9 +10057,8 @@ Modal.show = function (config) {
9934
10057
  return manager;
9935
10058
  };
9936
10059
 
9937
- Modal.hidden = function () {
9938
- if (!ModalContainer) return;
9939
- ModalContainer[modelSysbol] && ModalContainer[modelSysbol].hidden();
10060
+ Modal.hidden = function () {// if (!ModalContainer) return;
10061
+ // ModalContainer[modelSysbol] && ModalContainer[modelSysbol].hidden();
9940
10062
  };
9941
10063
 
9942
10064
  var controlShow$1 = function controlShow(f1, f2, value, timer) {
@@ -10131,18 +10253,18 @@ var Modal$1 = /*#__PURE__*/function (_React$PureComponent) {
10131
10253
 
10132
10254
  Modal$1.show = void 0;
10133
10255
  Modal$1.hidden = void 0;
10134
- var ModalContainer$1 = null;
10135
- var modelSysbol$1 = Symbol('$$__model__Container_hidden');
10256
+ var ModalContainer = null;
10257
+ var modelSysbol = Symbol('$$__model__Container_hidden');
10136
10258
 
10137
10259
  Modal$1.show = function (config) {
10138
- if (ModalContainer$1) return;
10260
+ if (ModalContainer) return;
10139
10261
 
10140
10262
  var props = _objectSpread2(_objectSpread2({}, config), {}, {
10141
10263
  visible: true
10142
10264
  });
10143
10265
 
10144
- var container = ModalContainer$1 = document.createElement('div');
10145
- var manager = container[modelSysbol$1] = {
10266
+ var container = ModalContainer = document.createElement('div');
10267
+ var manager = container[modelSysbol] = {
10146
10268
  setShow: null,
10147
10269
  mounted: false,
10148
10270
  hidden: function hidden() {
@@ -10152,7 +10274,7 @@ Modal$1.show = function (config) {
10152
10274
  destory: function destory() {
10153
10275
  ReactDOM__default['default'].unmountComponentAtNode(container);
10154
10276
  document.body.removeChild(container);
10155
- ModalContainer$1 = null;
10277
+ ModalContainer = null;
10156
10278
  }
10157
10279
  };
10158
10280
 
@@ -10185,8 +10307,8 @@ Modal$1.show = function (config) {
10185
10307
  };
10186
10308
 
10187
10309
  Modal$1.hidden = function () {
10188
- if (!ModalContainer$1) return;
10189
- ModalContainer$1[modelSysbol$1] && ModalContainer$1[modelSysbol$1].hidden();
10310
+ if (!ModalContainer) return;
10311
+ ModalContainer[modelSysbol] && ModalContainer[modelSysbol].hidden();
10190
10312
  };
10191
10313
 
10192
10314
  var _excluded$g = ["columns", "extraColumns", "search", "visible", "setVisible", "disabled", "submitMethod", "onSubmitSuccess", "title", "record", "onFormChange"];
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "private": false,
3
3
  "name": "wargerm",
4
- "version": "0.4.14",
4
+ "version": "0.4.17",
5
5
  "scripts": {
6
6
  "dev": "dumi dev",
7
7
  "docs:build": "dumi build",