wargerm 0.4.14 → 0.4.15

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,13 @@ declare type Props = {
10
10
  okText?: string;
11
11
  cancelText?: string;
12
12
  destroyOnClose?: boolean;
13
+ hiddenMask?: boolean;
13
14
  visible?: boolean;
14
15
  width?: number;
15
16
  className?: string;
16
17
  style?: React.CSSProperties;
17
18
  children?: ReactNode;
19
+ ref?: any;
18
20
  };
19
- export default function DialogModel(props: Props): React.ReactPortal;
20
- export {};
21
+ declare const _default: React.ForwardRefExoticComponent<Pick<Props, "width" | "visible" | "destroyOnClose" | "closeCb" | "onClose" | "hiddenMask" | "className" | "style" | "title" | "onOk" | "onCancel" | "footer" | "content" | "okText" | "cancelText" | "children"> & React.RefAttributes<unknown>>;
22
+ export default _default;
@@ -11,8 +11,11 @@ declare type Props = {
11
11
  cancelText?: string;
12
12
  visible?: boolean;
13
13
  destroyOnClose?: boolean;
14
+ hiddenMask?: boolean;
15
+ isDrag?: boolean;
14
16
  width?: number;
15
17
  className?: string;
18
+ ref?: any;
16
19
  style?: React.CSSProperties;
17
20
  };
18
21
  declare class Modal extends React.PureComponent<Props> {
@@ -24,7 +27,10 @@ declare class Modal extends React.PureComponent<Props> {
24
27
  } | undefined;
25
28
  static hidden: () => void;
26
29
  renderFooter: () => JSX.Element | null;
30
+ containerRef: React.RefObject<any>;
31
+ titleRef: React.RefObject<any>;
27
32
  renderTop: () => JSX.Element;
33
+ componentDidMount(): void;
28
34
  renderContent: () => {} | null;
29
35
  render(): JSX.Element;
30
36
  }
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;
@@ -2373,7 +2368,7 @@ button[data-prefers-color='light'] .swiper-pagination-bullet {
2373
2368
  border-image-width: 57px 166px 62px 166px;
2374
2369
  border-image-repeat: stretch stretch;
2375
2370
  min-height: 500px;
2376
- min-width: 1500px;
2371
+ min-width: 600px;
2377
2372
  }
2378
2373
  [data-prefers-color='light'] .model_container .model_wrap {
2379
2374
  position: absolute;
@@ -2410,6 +2405,9 @@ button[data-prefers-color='light'] .swiper-pagination-bullet {
2410
2405
  -webkit-background-clip: text;
2411
2406
  color: transparent;
2412
2407
  }
2408
+ [data-prefers-color='light'] .model_container .model_wrap .model-header .model-title.move {
2409
+ cursor: move;
2410
+ }
2413
2411
  [data-prefers-color='light'] .model_container .model_wrap .model-header .model-closeIcon {
2414
2412
  font-size: 26px;
2415
2413
  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;
@@ -2373,7 +2368,7 @@ button[data-prefers-color='light'] .swiper-pagination-bullet {
2373
2368
  border-image-width: 57px 166px 62px 166px;
2374
2369
  border-image-repeat: stretch stretch;
2375
2370
  min-height: 500px;
2376
- min-width: 1500px;
2371
+ min-width: 600px;
2377
2372
  }
2378
2373
  [data-prefers-color='light'] .model_container .model_wrap {
2379
2374
  position: absolute;
@@ -2410,6 +2405,9 @@ button[data-prefers-color='light'] .swiper-pagination-bullet {
2410
2405
  -webkit-background-clip: text;
2411
2406
  color: transparent;
2412
2407
  }
2408
+ [data-prefers-color='light'] .model_container .model_wrap .model-header .model-title.move {
2409
+ cursor: move;
2410
+ }
2413
2411
  [data-prefers-color='light'] .model_container .model_wrap .model-header .model-closeIcon {
2414
2412
  font-size: 26px;
2415
2413
  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,14 @@ 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,
9647
9649
  _props$className = props.className,
9648
9650
  className = _props$className === void 0 ? 'default-dialog' : _props$className,
9649
9651
  style = props.style;
@@ -9673,6 +9675,12 @@ function DialogModel(props) {
9673
9675
  isDesChild = _useState10[0],
9674
9676
  setIsDesChild = _useState10[1];
9675
9677
 
9678
+ var containerRef = useRef();
9679
+ useImperativeHandle(ref, function () {
9680
+ return {
9681
+ containerRef: containerRef.current
9682
+ };
9683
+ });
9676
9684
  var renderChildren = useMemo(function () {
9677
9685
  var _classNames;
9678
9686
 
@@ -9685,10 +9693,12 @@ function DialogModel(props) {
9685
9693
  left: 0
9686
9694
  }
9687
9695
  }, /*#__PURE__*/React.createElement("div", {
9696
+ ref: containerRef,
9688
9697
  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
9698
  style: _objectSpread2({
9690
9699
  opacity: modelShowAync ? 1 : 0,
9691
- width: typeof width == 'number' ? width + 'px' : width
9700
+ width: typeof width == 'number' ? width + 'px' : width,
9701
+ left: "calc(50% - ".concat(typeof width == 'number' ? width / 2 : width / 2, "px)")
9692
9702
  }, style)
9693
9703
  }, /*#__PURE__*/React.createElement("div", {
9694
9704
  className: 'model_wrap'
@@ -9698,7 +9708,7 @@ function DialogModel(props) {
9698
9708
  height: '100%',
9699
9709
  position: 'relative'
9700
9710
  }
9701
- }, isDesChild ? null : props.children))), /*#__PURE__*/React.createElement("div", {
9711
+ }, isDesChild ? null : props.children))), !hiddenMask && /*#__PURE__*/React.createElement("div", {
9702
9712
  className: 'mask',
9703
9713
  onClick: function onClick() {
9704
9714
  onClose && onClose();
@@ -9740,6 +9750,8 @@ function DialogModel(props) {
9740
9750
  return renderChildren;
9741
9751
  }
9742
9752
 
9753
+ var Dialog = /*#__PURE__*/React.forwardRef(DialogModel);
9754
+
9743
9755
  var _excluded$e = ["visible", "width", "closeCb", "onClose", "className", "style"],
9744
9756
  _excluded2$3 = ["visible"];
9745
9757
 
@@ -9785,14 +9797,19 @@ var Modal = /*#__PURE__*/function (_React$PureComponent) {
9785
9797
  }, cancelText || '取消')));
9786
9798
  };
9787
9799
 
9800
+ _this.containerRef = /*#__PURE__*/createRef();
9801
+ _this.titleRef = /*#__PURE__*/createRef();
9802
+
9788
9803
  _this.renderTop = function () {
9789
9804
  var _this$props2 = _this.props,
9790
9805
  title = _this$props2.title,
9791
- onClose = _this$props2.onClose;
9806
+ onClose = _this$props2.onClose,
9807
+ isDrag = _this$props2.isDrag;
9792
9808
  return /*#__PURE__*/React.createElement("div", {
9793
9809
  className: "model-header"
9794
9810
  }, /*#__PURE__*/React.createElement("div", {
9795
- className: "model-title"
9811
+ ref: _this.titleRef,
9812
+ className: "model-title ".concat(isDrag ? 'move' : '')
9796
9813
  }, title), /*#__PURE__*/React.createElement(CloseCircleOutlined, {
9797
9814
  className: "model-closeIcon",
9798
9815
  onClick: function onClick() {
@@ -9812,6 +9829,35 @@ var Modal = /*#__PURE__*/function (_React$PureComponent) {
9812
9829
  }
9813
9830
 
9814
9831
  _createClass(Modal, [{
9832
+ key: "componentDidMount",
9833
+ value: function componentDidMount() {
9834
+ var isDrag = this.props.isDrag;
9835
+ if (!isDrag) return;
9836
+ var tltleEl = this.titleRef.current;
9837
+ var containerEl = this.containerRef.current.containerRef;
9838
+
9839
+ tltleEl.onmousedown = function (eventDown) {
9840
+ var left = containerEl.offsetLeft;
9841
+ var top = containerEl.offsetTop;
9842
+ console.log(left, top);
9843
+ var downX = eventDown.clientX;
9844
+ var downY = eventDown.clientY;
9845
+
9846
+ document.onmousemove = function (eventMove) {
9847
+ eventMove.stopPropagation();
9848
+ eventMove.preventDefault();
9849
+ var moveX = eventMove.clientX - downX;
9850
+ var moveY = eventMove.clientY - downY;
9851
+ containerEl.style.left = "".concat(left + moveX, "px");
9852
+ containerEl.style.top = "".concat(top + moveY, "px");
9853
+ };
9854
+ };
9855
+
9856
+ document.onmouseup = function (eventMove) {
9857
+ document.onmousemove = null;
9858
+ };
9859
+ }
9860
+ }, {
9815
9861
  key: "render",
9816
9862
  value: function render() {
9817
9863
  var _this$props4 = this.props,
@@ -9823,7 +9869,8 @@ var Modal = /*#__PURE__*/function (_React$PureComponent) {
9823
9869
  style = _this$props4.style,
9824
9870
  other = _objectWithoutProperties(_this$props4, _excluded$e);
9825
9871
 
9826
- return /*#__PURE__*/React.createElement(DialogModel, _objectSpread2({
9872
+ return /*#__PURE__*/React.createElement(Dialog, _objectSpread2({
9873
+ ref: this.containerRef,
9827
9874
  closeCb: closeCb,
9828
9875
  onClose: onClose,
9829
9876
  visible: visible,
package/dist/index.js CHANGED
@@ -9676,12 +9676,14 @@ 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,
9685
9687
  _props$className = props.className,
9686
9688
  className = _props$className === void 0 ? 'default-dialog' : _props$className,
9687
9689
  style = props.style;
@@ -9711,6 +9713,12 @@ function DialogModel(props) {
9711
9713
  isDesChild = _useState10[0],
9712
9714
  setIsDesChild = _useState10[1];
9713
9715
 
9716
+ var containerRef = React.useRef();
9717
+ React.useImperativeHandle(ref, function () {
9718
+ return {
9719
+ containerRef: containerRef.current
9720
+ };
9721
+ });
9714
9722
  var renderChildren = React.useMemo(function () {
9715
9723
  var _classNames;
9716
9724
 
@@ -9723,10 +9731,12 @@ function DialogModel(props) {
9723
9731
  left: 0
9724
9732
  }
9725
9733
  }, /*#__PURE__*/React__default['default'].createElement("div", {
9734
+ ref: containerRef,
9726
9735
  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
9736
  style: _objectSpread2({
9728
9737
  opacity: modelShowAync ? 1 : 0,
9729
- width: typeof width == 'number' ? width + 'px' : width
9738
+ width: typeof width == 'number' ? width + 'px' : width,
9739
+ left: "calc(50% - ".concat(typeof width == 'number' ? width / 2 : width / 2, "px)")
9730
9740
  }, style)
9731
9741
  }, /*#__PURE__*/React__default['default'].createElement("div", {
9732
9742
  className: 'model_wrap'
@@ -9736,7 +9746,7 @@ function DialogModel(props) {
9736
9746
  height: '100%',
9737
9747
  position: 'relative'
9738
9748
  }
9739
- }, isDesChild ? null : props.children))), /*#__PURE__*/React__default['default'].createElement("div", {
9749
+ }, isDesChild ? null : props.children))), !hiddenMask && /*#__PURE__*/React__default['default'].createElement("div", {
9740
9750
  className: 'mask',
9741
9751
  onClick: function onClick() {
9742
9752
  onClose && onClose();
@@ -9778,6 +9788,8 @@ function DialogModel(props) {
9778
9788
  return renderChildren;
9779
9789
  }
9780
9790
 
9791
+ var Dialog = /*#__PURE__*/React__default['default'].forwardRef(DialogModel);
9792
+
9781
9793
  var _excluded$e = ["visible", "width", "closeCb", "onClose", "className", "style"],
9782
9794
  _excluded2$3 = ["visible"];
9783
9795
 
@@ -9823,14 +9835,19 @@ var Modal = /*#__PURE__*/function (_React$PureComponent) {
9823
9835
  }, cancelText || '取消')));
9824
9836
  };
9825
9837
 
9838
+ _this.containerRef = /*#__PURE__*/React.createRef();
9839
+ _this.titleRef = /*#__PURE__*/React.createRef();
9840
+
9826
9841
  _this.renderTop = function () {
9827
9842
  var _this$props2 = _this.props,
9828
9843
  title = _this$props2.title,
9829
- onClose = _this$props2.onClose;
9844
+ onClose = _this$props2.onClose,
9845
+ isDrag = _this$props2.isDrag;
9830
9846
  return /*#__PURE__*/React__default['default'].createElement("div", {
9831
9847
  className: "model-header"
9832
9848
  }, /*#__PURE__*/React__default['default'].createElement("div", {
9833
- className: "model-title"
9849
+ ref: _this.titleRef,
9850
+ className: "model-title ".concat(isDrag ? 'move' : '')
9834
9851
  }, title), /*#__PURE__*/React__default['default'].createElement(icons.CloseCircleOutlined, {
9835
9852
  className: "model-closeIcon",
9836
9853
  onClick: function onClick() {
@@ -9850,6 +9867,35 @@ var Modal = /*#__PURE__*/function (_React$PureComponent) {
9850
9867
  }
9851
9868
 
9852
9869
  _createClass(Modal, [{
9870
+ key: "componentDidMount",
9871
+ value: function componentDidMount() {
9872
+ var isDrag = this.props.isDrag;
9873
+ if (!isDrag) return;
9874
+ var tltleEl = this.titleRef.current;
9875
+ var containerEl = this.containerRef.current.containerRef;
9876
+
9877
+ tltleEl.onmousedown = function (eventDown) {
9878
+ var left = containerEl.offsetLeft;
9879
+ var top = containerEl.offsetTop;
9880
+ console.log(left, top);
9881
+ var downX = eventDown.clientX;
9882
+ var downY = eventDown.clientY;
9883
+
9884
+ document.onmousemove = function (eventMove) {
9885
+ eventMove.stopPropagation();
9886
+ eventMove.preventDefault();
9887
+ var moveX = eventMove.clientX - downX;
9888
+ var moveY = eventMove.clientY - downY;
9889
+ containerEl.style.left = "".concat(left + moveX, "px");
9890
+ containerEl.style.top = "".concat(top + moveY, "px");
9891
+ };
9892
+ };
9893
+
9894
+ document.onmouseup = function (eventMove) {
9895
+ document.onmousemove = null;
9896
+ };
9897
+ }
9898
+ }, {
9853
9899
  key: "render",
9854
9900
  value: function render() {
9855
9901
  var _this$props4 = this.props,
@@ -9861,7 +9907,8 @@ var Modal = /*#__PURE__*/function (_React$PureComponent) {
9861
9907
  style = _this$props4.style,
9862
9908
  other = _objectWithoutProperties(_this$props4, _excluded$e);
9863
9909
 
9864
- return /*#__PURE__*/React__default['default'].createElement(DialogModel, _objectSpread2({
9910
+ return /*#__PURE__*/React__default['default'].createElement(Dialog, _objectSpread2({
9911
+ ref: this.containerRef,
9865
9912
  closeCb: closeCb,
9866
9913
  onClose: onClose,
9867
9914
  visible: visible,
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.15",
5
5
  "scripts": {
6
6
  "dev": "dumi dev",
7
7
  "docs:build": "dumi build",