nsc-react-component 2.4.1 → 2.4.3

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.
@@ -2,7 +2,7 @@ function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "functi
2
2
 
3
3
  import "antd/es/image/style/css";
4
4
  import _Image from "antd/es/image";
5
- var _excluded = ["fileId", "src"];
5
+ var _excluded = ["fileId", "src", "clickPreview", "showDownloadIcon"];
6
6
 
7
7
  function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
8
8
 
@@ -10,6 +10,10 @@ function _objectWithoutProperties(source, excluded) { if (source == null) return
10
10
 
11
11
  function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
12
12
 
13
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
14
+
15
+ function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
16
+
13
17
  function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
14
18
 
15
19
  function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
@@ -30,7 +34,16 @@ function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Re
30
34
 
31
35
  function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
32
36
 
37
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
38
+
33
39
  import * as React from "react";
40
+ import file from "nsc-file";
41
+ import styles from "./index.less";
42
+ import { getLess } from "../../utils";
43
+ import { EyeOutlined, DownloadOutlined } from "@ant-design/icons";
44
+ import Spin from "../spin";
45
+ var download = file.download,
46
+ previewDocument = file.previewDocument;
34
47
 
35
48
  var NscImage = /*#__PURE__*/function (_React$PureComponent) {
36
49
  _inherits(NscImage, _React$PureComponent);
@@ -38,31 +51,182 @@ var NscImage = /*#__PURE__*/function (_React$PureComponent) {
38
51
  var _super = _createSuper(NscImage);
39
52
 
40
53
  function NscImage() {
54
+ var _this;
55
+
41
56
  _classCallCheck(this, NscImage);
42
57
 
43
- return _super.apply(this, arguments);
58
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
59
+ args[_key] = arguments[_key];
60
+ }
61
+
62
+ _this = _super.call.apply(_super, [this].concat(args));
63
+
64
+ _defineProperty(_assertThisInitialized(_this), "defaultImg", "data:image/png;base64,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");
65
+
66
+ _defineProperty(_assertThisInitialized(_this), "state", {
67
+ imgData: _this.defaultImg,
68
+ visible: false,
69
+ mask: false,
70
+ loading: true
71
+ });
72
+
73
+ return _this;
44
74
  }
45
75
 
46
76
  _createClass(NscImage, [{
77
+ key: "getImgData",
78
+ value: function () {
79
+ var _getImgData = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {
80
+ var _this2 = this;
81
+
82
+ var fileId, img;
83
+ return regeneratorRuntime.wrap(function _callee$(_context) {
84
+ while (1) {
85
+ switch (_context.prev = _context.next) {
86
+ case 0:
87
+ fileId = this.props.fileId;
88
+ _context.next = 3;
89
+ return previewDocument(fileId, {
90
+ responseType: "blob"
91
+ });
92
+
93
+ case 3:
94
+ img = _context.sent;
95
+ this.blobToBase64(img).then(function (res) {
96
+ _this2.setState({
97
+ imgData: res,
98
+ loading: false
99
+ });
100
+ });
101
+
102
+ case 5:
103
+ case "end":
104
+ return _context.stop();
105
+ }
106
+ }
107
+ }, _callee, this);
108
+ }));
109
+
110
+ function getImgData() {
111
+ return _getImgData.apply(this, arguments);
112
+ }
113
+
114
+ return getImgData;
115
+ }()
116
+ }, {
117
+ key: "blobToBase64",
118
+ value: function blobToBase64(blob) {
119
+ return new Promise(function (resolve, reject) {
120
+ var fileReader = new FileReader();
121
+
122
+ fileReader.onload = function (e) {
123
+ resolve(e.target.result);
124
+ };
125
+
126
+ fileReader.readAsDataURL(blob);
127
+
128
+ fileReader.onerror = function () {
129
+ reject(new Error("blobToBase64 error"));
130
+ };
131
+ });
132
+ }
133
+ }, {
134
+ key: "componentDidUpdate",
135
+ value: function componentDidUpdate(prevProps) {
136
+ if (prevProps.fileId !== this.props.fileId) {
137
+ if (this.props.fileId) {
138
+ this.setState({
139
+ loading: true,
140
+ imgData: this.defaultImg
141
+ });
142
+ this.getImgData();
143
+ }
144
+ }
145
+ }
146
+ }, {
147
+ key: "componentDidMount",
148
+ value: function componentDidMount() {
149
+ var fileId = this.props.fileId;
150
+
151
+ if (fileId) {
152
+ this.getImgData();
153
+ } else {
154
+ this.setState({
155
+ loading: false
156
+ });
157
+ }
158
+ }
159
+ }, {
47
160
  key: "render",
48
161
  value: function render() {
162
+ var _this3 = this;
163
+
49
164
  var _this$props = this.props,
50
165
  fileId = _this$props.fileId,
51
166
  src = _this$props.src,
167
+ _this$props$clickPrev = _this$props.clickPreview,
168
+ clickPreview = _this$props$clickPrev === void 0 ? true : _this$props$clickPrev,
169
+ _this$props$showDownl = _this$props.showDownloadIcon,
170
+ showDownloadIcon = _this$props$showDownl === void 0 ? false : _this$props$showDownl,
52
171
  params = _objectWithoutProperties(_this$props, _excluded);
53
172
 
54
- var filesrc = "";
55
-
56
- if (fileId) {
57
- filesrc = "/jquick-resource/oss/endpoint/preview-files?attachId=".concat(fileId);
58
- }
59
-
60
- return /*#__PURE__*/React.createElement(_Image, _extends({
61
- src: filesrc,
173
+ return /*#__PURE__*/React.createElement("div", {
174
+ className: getLess(styles, "nsc-image-total"),
175
+ onMouseEnter: function onMouseEnter() {
176
+ console.log("onMouseEnteronMouseEnter");
177
+
178
+ _this3.setState({
179
+ mask: true
180
+ });
181
+ },
182
+ onMouseLeave: function onMouseLeave() {
183
+ _this3.setState({
184
+ mask: false
185
+ });
186
+ },
187
+ onClick: function onClick() {
188
+ clickPreview && _this3.setState({
189
+ visible: true
190
+ });
191
+ }
192
+ }, /*#__PURE__*/React.createElement(Spin, {
193
+ spinning: this.state.loading // style={{ width: "100%", height: "100%" }}
194
+
195
+ }, /*#__PURE__*/React.createElement("img", {
196
+ src: this.props.src || this.state.imgData,
197
+ style: {
198
+ width: "100%",
199
+ height: "100%"
200
+ }
201
+ })), /*#__PURE__*/React.createElement("div", {
202
+ className: getLess(styles, "nsc-image-mask")
203
+ }, showDownloadIcon && /*#__PURE__*/React.createElement("div", {
204
+ className: getLess(styles, "nsc-image-icon"),
205
+ onClick: function onClick() {
206
+ if (fileId) download(fileId);
207
+ }
208
+ }, /*#__PURE__*/React.createElement(DownloadOutlined, null)), /*#__PURE__*/React.createElement("div", {
209
+ onClick: function onClick() {
210
+ _this3.setState({
211
+ visible: true
212
+ });
213
+ },
214
+ className: getLess(styles, "nsc-image-icon")
215
+ }, /*#__PURE__*/React.createElement(EyeOutlined, null))), /*#__PURE__*/React.createElement(_Image, _extends({
216
+ src: this.props.src || this.state.imgData,
217
+ style: {
218
+ display: "none"
219
+ },
62
220
  preview: {
63
- src: filesrc
221
+ visible: this.state.visible,
222
+ src: this.props.src || this.state.imgData,
223
+ onVisibleChange: function onVisibleChange(value) {
224
+ _this3.setState({
225
+ visible: value
226
+ });
227
+ }
64
228
  }
65
- }, params));
229
+ }, params)));
66
230
  }
67
231
  }]);
68
232
 
@@ -70,4 +234,4 @@ var NscImage = /*#__PURE__*/function (_React$PureComponent) {
70
234
  }(React.PureComponent);
71
235
 
72
236
  export { NscImage as default };
73
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL2Jhc2UvaW1hZ2UvaW5kZXgudHN4Il0sIm5hbWVzIjpbIlJlYWN0IiwiTnNjSW1hZ2UiLCJwcm9wcyIsImZpbGVJZCIsInNyYyIsInBhcmFtcyIsImZpbGVzcmMiLCJQdXJlQ29tcG9uZW50Il0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLE9BQU8sS0FBS0EsS0FBWixNQUF1QixPQUF2Qjs7SUFPcUJDLFE7Ozs7Ozs7Ozs7Ozs7V0FDbkIsa0JBQTBCO0FBQ3hCLHdCQUFtQyxLQUFLQyxLQUF4QztBQUFBLFVBQVFDLE1BQVIsZUFBUUEsTUFBUjtBQUFBLFVBQWdCQyxHQUFoQixlQUFnQkEsR0FBaEI7QUFBQSxVQUF3QkMsTUFBeEI7O0FBQ0EsVUFBSUMsT0FBTyxHQUFHLEVBQWQ7O0FBQ0EsVUFBSUgsTUFBSixFQUFZO0FBQ1ZHLFFBQUFBLE9BQU8sa0VBQTJESCxNQUEzRCxDQUFQO0FBQ0Q7O0FBQ0QsMEJBQ0U7QUFDRSxRQUFBLEdBQUcsRUFBRUcsT0FEUDtBQUVFLFFBQUEsT0FBTyxFQUFFO0FBQ1BGLFVBQUFBLEdBQUcsRUFBRUU7QUFERTtBQUZYLFNBS01ELE1BTE4sRUFERjtBQVNEOzs7O0VBaEJtQ0wsS0FBSyxDQUFDTyxhOztTQUF2Qk4sUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gXCJyZWFjdFwiO1xyXG5pbXBvcnQgeyBJbWFnZSwgSW1hZ2VQcm9wcyB9IGZyb20gXCJhbnRkXCI7XHJcblxyXG5pbnRlcmZhY2UgSUltYWdlUHJvcHMgZXh0ZW5kcyBJbWFnZVByb3BzIHtcclxuICBmaWxlSWQ/OiBzdHJpbmc7XHJcbn1cclxuXHJcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIE5zY0ltYWdlIGV4dGVuZHMgUmVhY3QuUHVyZUNvbXBvbmVudDxJSW1hZ2VQcm9wcywgYW55PiB7XHJcbiAgcmVuZGVyKCk6IFJlYWN0LlJlYWN0Tm9kZSB7XHJcbiAgICBjb25zdCB7IGZpbGVJZCwgc3JjLCAuLi5wYXJhbXMgfSA9IHRoaXMucHJvcHM7XHJcbiAgICBsZXQgZmlsZXNyYyA9IFwiXCI7XHJcbiAgICBpZiAoZmlsZUlkKSB7XHJcbiAgICAgIGZpbGVzcmMgPSBgL2pxdWljay1yZXNvdXJjZS9vc3MvZW5kcG9pbnQvcHJldmlldy1maWxlcz9hdHRhY2hJZD0ke2ZpbGVJZH1gO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChcclxuICAgICAgPEltYWdlXHJcbiAgICAgICAgc3JjPXtmaWxlc3JjfVxyXG4gICAgICAgIHByZXZpZXc9e3tcclxuICAgICAgICAgIHNyYzogZmlsZXNyYyxcclxuICAgICAgICB9fVxyXG4gICAgICAgIHsuLi5wYXJhbXN9XHJcbiAgICAgIC8+XHJcbiAgICApO1xyXG4gIH1cclxufVxyXG4iXX0=
237
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/base/image/index.tsx"],"names":["React","file","styles","getLess","EyeOutlined","DownloadOutlined","Spin","download","previewDocument","NscImage","imgData","defaultImg","visible","mask","loading","fileId","props","responseType","img","blobToBase64","then","res","setState","blob","Promise","resolve","reject","fileReader","FileReader","onload","e","target","result","readAsDataURL","onerror","Error","prevProps","getImgData","src","clickPreview","showDownloadIcon","params","console","log","state","width","height","display","onVisibleChange","value","PureComponent"],"mappings":"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","sourcesContent":["import * as React from \"react\";\r\nimport { Image, ImageProps } from \"antd\";\r\nimport file from \"nsc-file\";\r\nimport styles from \"./index.less\";\r\nimport { getLess } from \"../../utils\";\r\nimport {\r\n  EyeOutlined,\r\n  DownloadOutlined,\r\n  UploadOutlined,\r\n  DeleteOutlined,\r\n} from \"@ant-design/icons\";\r\nimport cls from \"classnames\";\r\nimport Spin from \"../spin\";\r\n\r\nconst { download, previewDocument } = file;\r\ninterface IImageProps extends ImageProps {\r\n  fileId?: string;\r\n  src?: string;\r\n  clickPreview?: boolean;\r\n  // showDeleteIcon?: boolean;\r\n  // showUploadIcon?: boolean;\r\n  showDownloadIcon?: boolean;\r\n}\r\n\r\nexport default class NscImage extends React.PureComponent<IImageProps, any> {\r\n  defaultImg =\r\n    \"data:image/png;base64,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\";\r\n  state = {\r\n    imgData: this.defaultImg,\r\n    visible: false,\r\n    mask: false,\r\n    loading: true,\r\n  };\r\n  async getImgData() {\r\n    const { fileId } = this.props;\r\n    const img = await previewDocument(fileId, { responseType: \"blob\" });\r\n    this.blobToBase64(img).then((res) => {\r\n      this.setState({\r\n        imgData: res,\r\n        loading: false,\r\n      });\r\n    });\r\n  }\r\n  blobToBase64(blob) {\r\n    return new Promise((resolve, reject) => {\r\n      const fileReader = new FileReader();\r\n      fileReader.onload = (e) => {\r\n        resolve(e.target.result);\r\n      };\r\n      fileReader.readAsDataURL(blob);\r\n      fileReader.onerror = () => {\r\n        reject(new Error(\"blobToBase64 error\"));\r\n      };\r\n    });\r\n  }\r\n  componentDidUpdate(prevProps) {\r\n    if (prevProps.fileId !== this.props.fileId) {\r\n      if (this.props.fileId) {\r\n        this.setState({\r\n          loading: true,\r\n          imgData: this.defaultImg,\r\n        });\r\n        this.getImgData();\r\n      }\r\n    }\r\n  }\r\n  componentDidMount() {\r\n    const { fileId } = this.props;\r\n    if (fileId) {\r\n      this.getImgData();\r\n    } else {\r\n      this.setState({\r\n        loading: false,\r\n      });\r\n    }\r\n  }\r\n  render(): React.ReactNode {\r\n    const {\r\n      fileId,\r\n      src,\r\n      clickPreview = true,\r\n      showDownloadIcon = false,\r\n      ...params\r\n    } = this.props;\r\n    return (\r\n      <div\r\n        className={getLess(styles, \"nsc-image-total\")}\r\n        onMouseEnter={() => {\r\n          console.log(\"onMouseEnteronMouseEnter\");\r\n          this.setState({\r\n            mask: true,\r\n          });\r\n        }}\r\n        onMouseLeave={() => {\r\n          this.setState({\r\n            mask: false,\r\n          });\r\n        }}\r\n        onClick={() => {\r\n          clickPreview &&\r\n            this.setState({\r\n              visible: true,\r\n            });\r\n        }}\r\n      >\r\n        <Spin\r\n          spinning={this.state.loading}\r\n          // style={{ width: \"100%\", height: \"100%\" }}\r\n        >\r\n          <img\r\n            src={this.props.src || this.state.imgData}\r\n            style={{ width: \"100%\", height: \"100%\" }}\r\n          />\r\n        </Spin>\r\n        {/* {this.state.mask && ( */}\r\n        <div className={getLess(styles, \"nsc-image-mask\")}>\r\n          {/* <div className={getLess(styles, \"nsc-image-icon\")}>\r\n            <UploadOutlined />\r\n          </div> */}\r\n          {showDownloadIcon && (\r\n            <div\r\n              className={getLess(styles, \"nsc-image-icon\")}\r\n              onClick={() => {\r\n                if (fileId) download(fileId);\r\n              }}\r\n            >\r\n              <DownloadOutlined />\r\n            </div>\r\n          )}\r\n          <div\r\n            onClick={() => {\r\n              this.setState({\r\n                visible: true,\r\n              });\r\n            }}\r\n            className={getLess(styles, \"nsc-image-icon\")}\r\n          >\r\n            <EyeOutlined />\r\n          </div>\r\n          {/* <div className={getLess(styles, \"nsc-image-icon\")}>\r\n            <DeleteOutlined />\r\n          </div> */}\r\n        </div>\r\n        {/* )} */}\r\n        <Image\r\n          src={this.props.src || this.state.imgData}\r\n          style={{ display: \"none\" }}\r\n          preview={{\r\n            visible: this.state.visible,\r\n            src: this.props.src || this.state.imgData,\r\n            onVisibleChange: (value) => {\r\n              this.setState({\r\n                visible: value,\r\n              });\r\n            },\r\n          }}\r\n          {...params}\r\n        />\r\n      </div>\r\n    );\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,29 @@
1
+ .nsc-image-total {
2
+ height: 100%;
3
+ width: 100%;
4
+ position: relative;
5
+ cursor: pointer;
6
+ :global {
7
+ .ant-spin-container {
8
+ width: 100%;
9
+ height: 100%;
10
+ }
11
+ }
12
+ }
13
+ .nsc-image-mask {
14
+ height: 100%;
15
+ width: 100%;
16
+ position: absolute;
17
+ inset: 0;
18
+ display: flex;
19
+ align-items: center;
20
+ justify-content: center;
21
+ color: #fff;
22
+ background: rgba(0, 0, 0, 0.5);
23
+ transition: opacity 0.3s;
24
+ }
25
+ .nsc-image-icon {
26
+ font-size: 14px;
27
+ width: 20px;
28
+ text-align: center;
29
+ }
@@ -1,7 +1,13 @@
1
1
  import { PureComponent } from "react";
2
2
  import { ModalProps, DrawerProps } from "antd";
3
+ interface formExpand {
4
+ change?: boolean;
5
+ valid?: boolean;
6
+ expand?: boolean;
7
+ }
3
8
  interface NscModalPorps extends ModalProps, DrawerProps {
4
9
  type?: "modal" | "drawer";
10
+ formExpand?: formExpand;
5
11
  }
6
12
  export default class NscModal extends PureComponent<NscModalPorps> {
7
13
  static confirm: import("antd/lib/modal/confirm").ModalFunc;
@@ -12,6 +18,7 @@ export default class NscModal extends PureComponent<NscModalPorps> {
12
18
  returnValue: any;
13
19
  state: {
14
20
  visible: boolean;
21
+ expand: boolean;
15
22
  };
16
23
  option: any;
17
24
  /**
@@ -31,6 +38,7 @@ export default class NscModal extends PureComponent<NscModalPorps> {
31
38
  * @param {String} key
32
39
  */
33
40
  getParams(key: any): any;
41
+ formValid(flag?: boolean): void;
34
42
  render(): JSX.Element;
35
43
  }
36
44
  export {};
@@ -1,10 +1,10 @@
1
1
  function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
2
2
 
3
- import "antd/es/modal/style/css";
4
- import _Modal from "antd/es/modal";
5
3
  import "antd/es/drawer/style/css";
6
4
  import _Drawer from "antd/es/drawer";
7
- var _excluded = ["type"];
5
+ import "antd/es/modal/style/css";
6
+ import _Modal from "antd/es/modal";
7
+ var _excluded = ["type", "closable", "title", "okButtonProps", "formExpand"];
8
8
 
9
9
  function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
10
10
 
@@ -40,7 +40,11 @@ function _defineProperty(obj, key, value) { if (key in obj) { Object.definePrope
40
40
 
41
41
  import React, { PureComponent } from "react";
42
42
  import { utils } from "@bj-nsc/msn/lib/utils";
43
- import config from '../../config';
43
+ import config from "../../config";
44
+ import { PlusCircleOutlined, CloseCircleOutlined, CloseOutlined, ExpandOutlined, CompressOutlined } from "@ant-design/icons";
45
+ import Button from "../button";
46
+ import { getLess } from "../../utils";
47
+ import styles from "./index.less";
44
48
 
45
49
  var NscModal = /*#__PURE__*/function (_PureComponent) {
46
50
  _inherits(NscModal, _PureComponent);
@@ -61,7 +65,8 @@ var NscModal = /*#__PURE__*/function (_PureComponent) {
61
65
  _defineProperty(_assertThisInitialized(_this2), "returnValue", null);
62
66
 
63
67
  _defineProperty(_assertThisInitialized(_this2), "state", {
64
- visible: false
68
+ visible: false,
69
+ expand: false
65
70
  });
66
71
 
67
72
  _defineProperty(_assertThisInitialized(_this2), "option", {
@@ -102,7 +107,9 @@ var NscModal = /*#__PURE__*/function (_PureComponent) {
102
107
  }, {
103
108
  key: "hide",
104
109
  value: function hide() {
105
- this.setState({
110
+ var _this = this;
111
+
112
+ _this.setState({
106
113
  visible: false
107
114
  });
108
115
  } //设置需要返回的值
@@ -131,11 +138,47 @@ var NscModal = /*#__PURE__*/function (_PureComponent) {
131
138
  callback = _this$option.callback,
132
139
  scope = _this$option.scope,
133
140
  callbackBeforeClose = _this$option.callbackBeforeClose;
141
+ var _this$props = this.props,
142
+ _this$props$formExpan = _this$props.formExpand,
143
+ formExpand = _this$props$formExpan === void 0 ? {} : _this$props$formExpan,
144
+ onCancel = _this$props.onCancel,
145
+ onClose = _this$props.onClose;
134
146
  if (result) this.setReturnValue(result);
135
147
  var r = utils.callback(callbackBeforeClose, scope, [this.returnValue]);
136
- if (r !== false) this.setState({
137
- visible: false
138
- });
148
+
149
+ if (r !== false) {
150
+ var _formExpand$expand = formExpand.expand,
151
+ expand = _formExpand$expand === void 0 ? false : _formExpand$expand;
152
+
153
+ if (expand && formExpand.change && formExpand.change) {
154
+ _Modal.confirm({
155
+ title: "当前记录已修改尚未保存,确定要放弃修改吗?",
156
+ cancelText: "取消",
157
+ okText: "确定",
158
+ centered: true,
159
+ onOk: function onOk() {
160
+ if (onCancel || onClose) {
161
+ onCancel && onCancel(result);
162
+ onClose && onClose(result);
163
+ } else {
164
+ _this.setState({
165
+ visible: false
166
+ });
167
+ }
168
+ }
169
+ });
170
+ } else {
171
+ if (onCancel || onClose) {
172
+ onCancel && onCancel(result);
173
+ onClose && onClose(result);
174
+ } else {
175
+ _this.setState({
176
+ visible: false
177
+ });
178
+ }
179
+ }
180
+ }
181
+
139
182
  utils.callback(callback, scope, [_this.returnValue]);
140
183
  }
141
184
  /**
@@ -149,15 +192,30 @@ var NscModal = /*#__PURE__*/function (_PureComponent) {
149
192
  if (key) return this.option.params[key];
150
193
  return this.option.params;
151
194
  }
195
+ }, {
196
+ key: "formValid",
197
+ value: function formValid() {
198
+ var flag = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
199
+
200
+ var _this = this;
201
+
202
+ if (flag) {}
203
+ }
152
204
  }, {
153
205
  key: "render",
154
206
  value: function render() {
155
207
  var _this3 = this;
156
208
 
157
- var _this$props = this.props,
158
- _this$props$type = _this$props.type,
159
- type = _this$props$type === void 0 ? "modal" : _this$props$type,
160
- params = _objectWithoutProperties(_this$props, _excluded);
209
+ var _this$props2 = this.props,
210
+ _this$props2$type = _this$props2.type,
211
+ type = _this$props2$type === void 0 ? "modal" : _this$props2$type,
212
+ closable = _this$props2.closable,
213
+ orgtitle = _this$props2.title,
214
+ _this$props2$okButton = _this$props2.okButtonProps,
215
+ okButtonProps = _this$props2$okButton === void 0 ? {} : _this$props2$okButton,
216
+ _this$props2$formExpa = _this$props2.formExpand,
217
+ formExpand = _this$props2$formExpa === void 0 ? {} : _this$props2$formExpa,
218
+ params = _objectWithoutProperties(_this$props2, _excluded);
161
219
 
162
220
  var props = _objectSpread({}, params);
163
221
 
@@ -172,6 +230,60 @@ var NscModal = /*#__PURE__*/function (_PureComponent) {
172
230
  });
173
231
  }
174
232
 
233
+ var title = /*#__PURE__*/React.createElement("div", {
234
+ className: getLess(styles, "title")
235
+ }, /*#__PURE__*/React.createElement("div", {
236
+ className: getLess(styles, "icons")
237
+ }, !this.state.expand && /*#__PURE__*/React.createElement("div", {
238
+ onClick: function onClick() {
239
+ _this3.setState({
240
+ expand: true
241
+ });
242
+ },
243
+ className: getLess(styles, "icon")
244
+ }, /*#__PURE__*/React.createElement(ExpandOutlined, null)), this.state.expand && /*#__PURE__*/React.createElement("div", {
245
+ onClick: function onClick() {
246
+ _this3.setState({
247
+ expand: false
248
+ });
249
+ },
250
+ className: getLess(styles, "icon")
251
+ }, /*#__PURE__*/React.createElement(CompressOutlined, null)), closable !== false && /*#__PURE__*/React.createElement("div", {
252
+ onClick: this.close.bind(this),
253
+ className: getLess(styles, "icon"),
254
+ style: {
255
+ marginRight: 0
256
+ }
257
+ }, /*#__PURE__*/React.createElement(CloseOutlined, null))), /*#__PURE__*/React.createElement("div", {
258
+ className: getLess(styles, "title-content")
259
+ }, orgtitle));
260
+ var footer = /*#__PURE__*/React.createElement("div", {
261
+ className: getLess(styles, "footer")
262
+ }, /*#__PURE__*/React.createElement(Button, _extends({
263
+ type: "primary",
264
+ onClick: function onClick() {
265
+ props.onOk && props.onOk();
266
+ },
267
+ icon: /*#__PURE__*/React.createElement(PlusCircleOutlined, null)
268
+ }, okButtonProps), "\u4FDD\u5B58"), /*#__PURE__*/React.createElement(Button, {
269
+ onClick: this.close.bind(this),
270
+ className: getLess(styles, "button-margin"),
271
+ icon: /*#__PURE__*/React.createElement(CloseCircleOutlined, null)
272
+ }, "\u53D6\u6D88"));
273
+
274
+ if (formExpand.expand) {
275
+ props = _objectSpread(_objectSpread({}, props), {}, {
276
+ footer: footer,
277
+ title: title,
278
+ closable: false,
279
+ style: {
280
+ maxWidth: "100vw"
281
+ },
282
+ className: this.state.expand ? getLess(styles, "allsreen") : "",
283
+ width: this.state.expand ? "100vw" : props.width
284
+ });
285
+ }
286
+
175
287
  if (type == "drawer") {
176
288
  return /*#__PURE__*/React.createElement(_Drawer, _extends({
177
289
  visible: this.state.visible,
@@ -189,7 +301,9 @@ var NscModal = /*#__PURE__*/function (_PureComponent) {
189
301
  _this3.close();
190
302
  },
191
303
  okText: "确定",
192
- cancelText: "取消"
304
+ cancelText: "取消",
305
+ centered: true // title={formExpand ? title : this.props.title}
306
+
193
307
  }, props));
194
308
  }
195
309
  }
@@ -209,4 +323,4 @@ _defineProperty(NscModal, "error", _Modal.error);
209
323
  _defineProperty(NscModal, "warning", _Modal.warning);
210
324
 
211
325
  export { NscModal as default };
212
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/base/modal/index.tsx"],"names":["React","PureComponent","utils","config","NscModal","visible","scope","params","beforeRender","callbackBeforeClose","callback","option","setState","returnValue","result","_this","setReturnValue","r","key","props","type","mountElementId","getContainer","document","getElementById","state","close","confirm","info","success","error","warning"],"mappings":"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","sourcesContent":["import React, { PureComponent } from \"react\";\r\nimport { Modal, ModalProps, Drawer, DrawerProps } from \"antd\";\r\nimport { utils } from \"@bj-nsc/msn/lib/utils\";\r\nimport config from '../../config'\r\n\r\ninterface NscModalPorps extends ModalProps, DrawerProps {\r\n  type?: \"modal\" | \"drawer\";\r\n}\r\n\r\nexport default class NscModal extends PureComponent<NscModalPorps> {\r\n  static confirm = Modal.confirm;\r\n  static info = Modal.info;\r\n  static success = Modal.success;\r\n  static error = Modal.error;\r\n  static warning = Modal.warning;\r\n\r\n  //返回值\r\n  returnValue = null;\r\n\r\n  state = {\r\n    visible: false,\r\n  };\r\n  option: any = {\r\n    //回调作用域\r\n    scope: this,\r\n    //open传递过来的页面参数\r\n    params: {},\r\n    //显示之前回调\r\n    beforeRender: null,\r\n    //关闭之前回调，如果return false，且窗口不关闭\r\n    callbackBeforeClose: null,\r\n    //关闭后回调，异步操作\r\n    callback: null,\r\n  };\r\n  /**\r\n   * 渲染完成\r\n   * @param {*} option  整改传递对象\r\n   */\r\n\r\n  //显示\r\n  show(option: any = {}) {\r\n    const { scope } = this.option;\r\n    const { beforeRender } = option;\r\n    this.option = { ...this.option, ...option };\r\n    utils.callback(beforeRender, scope);\r\n    this.setState({ visible: true });\r\n  }\r\n\r\n  //隐藏\r\n  hide() {\r\n    this.setState({ visible: false });\r\n  }\r\n\r\n  //设置需要返回的值\r\n  setReturnValue(returnValue) {\r\n    this.returnValue = returnValue;\r\n  }\r\n\r\n  //获取需要返回的值\r\n  getReturnValue() {\r\n    return this.returnValue;\r\n  }\r\n\r\n  /**\r\n   * 关闭带回调\r\n   */\r\n  close(result?: any) {\r\n    var _this = this;\r\n    const { callback, scope, callbackBeforeClose } = this.option;\r\n    if (result) this.setReturnValue(result);\r\n    const r = utils.callback(callbackBeforeClose, scope, [this.returnValue]);\r\n    if (r !== false) this.setState({ visible: false });\r\n    utils.callback(callback, scope, [_this.returnValue]);\r\n  }\r\n\r\n  /**\r\n   * 获取参数，如果key不传递，且获取全部\r\n   * @param {String} key\r\n   */\r\n  getParams(key) {\r\n    if (key) return this.option.params[key];\r\n    return this.option.params;\r\n  }\r\n  render() {\r\n    const { type = \"modal\", ...params } = this.props;\r\n    let props :any = { ...params };\r\n    let { mountElementId } = config();\r\n    if (mountElementId) {\r\n      props = {\r\n        ...props,\r\n        getContainer: () => document.getElementById(mountElementId),\r\n      };\r\n    }\r\n    if (type == \"drawer\") {\r\n      return (\r\n        <Drawer\r\n          visible={this.state.visible}\r\n          onClose={() => {\r\n            this.close();\r\n          }}\r\n          {...props}\r\n        />\r\n      );\r\n    } else {\r\n      return (\r\n        <Modal\r\n          visible={this.state.visible}\r\n          onCancel={() => {\r\n            this.close();\r\n          }}\r\n          onOk={() => {\r\n            this.close();\r\n          }}\r\n          okText={\"确定\"}\r\n          cancelText={\"取消\"}\r\n          {...props}\r\n        />\r\n      );\r\n    }\r\n  }\r\n}\r\n"]}
326
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/base/modal/index.tsx"],"names":["React","PureComponent","utils","config","PlusCircleOutlined","CloseCircleOutlined","CloseOutlined","ExpandOutlined","CompressOutlined","Button","getLess","styles","NscModal","visible","expand","scope","params","beforeRender","callbackBeforeClose","callback","option","setState","_this","returnValue","result","props","formExpand","onCancel","onClose","setReturnValue","r","change","confirm","title","cancelText","okText","centered","onOk","key","flag","type","closable","orgtitle","okButtonProps","mountElementId","getContainer","document","getElementById","state","close","bind","marginRight","footer","style","maxWidth","className","width","info","success","error","warning"],"mappings":"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","sourcesContent":["import React, { PureComponent } from \"react\";\r\nimport { Modal, ModalProps, Drawer, DrawerProps } from \"antd\";\r\nimport { utils } from \"@bj-nsc/msn/lib/utils\";\r\nimport config from \"../../config\";\r\nimport {\r\n  PlusCircleOutlined,\r\n  CloseCircleOutlined,\r\n  CloseOutlined,\r\n  ExpandOutlined,\r\n  CompressOutlined,\r\n} from \"@ant-design/icons\";\r\nimport Button from \"../button\";\r\nimport { getLess } from \"../../utils\";\r\nimport styles from \"./index.less\";\r\n\r\ninterface formExpand {\r\n  change?: boolean;\r\n  valid?: boolean;\r\n  expand?: boolean;\r\n}\r\ninterface NscModalPorps extends ModalProps, DrawerProps {\r\n  type?: \"modal\" | \"drawer\";\r\n  formExpand?: formExpand;\r\n}\r\n\r\nexport default class NscModal extends PureComponent<NscModalPorps> {\r\n  static confirm = Modal.confirm;\r\n  static info = Modal.info;\r\n  static success = Modal.success;\r\n  static error = Modal.error;\r\n  static warning = Modal.warning;\r\n\r\n  //返回值\r\n  returnValue = null;\r\n\r\n  state = {\r\n    visible: false,\r\n    expand: false,\r\n  };\r\n  option: any = {\r\n    //回调作用域\r\n    scope: this,\r\n    //open传递过来的页面参数\r\n    params: {},\r\n    //显示之前回调\r\n    beforeRender: null,\r\n    //关闭之前回调，如果return false，且窗口不关闭\r\n    callbackBeforeClose: null,\r\n    //关闭后回调，异步操作\r\n    callback: null,\r\n  };\r\n  /**\r\n   * 渲染完成\r\n   * @param {*} option  整改传递对象\r\n   */\r\n\r\n  //显示\r\n  show(option: any = {}) {\r\n    const { scope } = this.option;\r\n    const { beforeRender } = option;\r\n    this.option = { ...this.option, ...option };\r\n    utils.callback(beforeRender, scope);\r\n    this.setState({ visible: true });\r\n  }\r\n\r\n  //隐藏\r\n  hide() {\r\n    let _this = this;\r\n    _this.setState({ visible: false });\r\n  }\r\n\r\n  //设置需要返回的值\r\n  setReturnValue(returnValue) {\r\n    this.returnValue = returnValue;\r\n  }\r\n\r\n  //获取需要返回的值\r\n  getReturnValue() {\r\n    return this.returnValue;\r\n  }\r\n\r\n  /**\r\n   * 关闭带回调\r\n   */\r\n  close(result?: any) {\r\n    var _this = this;\r\n    const { callback, scope, callbackBeforeClose } = this.option;\r\n    const { formExpand = {}, onCancel, onClose } = this.props;\r\n    if (result) this.setReturnValue(result);\r\n    const r = utils.callback(callbackBeforeClose, scope, [this.returnValue]);\r\n    if (r !== false) {\r\n      const { expand = false } = formExpand;\r\n      if (expand && formExpand.change && formExpand.change) {\r\n        Modal.confirm({\r\n          title: \"当前记录已修改尚未保存，确定要放弃修改吗？\",\r\n          cancelText: \"取消\",\r\n          okText: \"确定\",\r\n          centered: true,\r\n          onOk() {\r\n            if (onCancel || onClose) {\r\n              onCancel && onCancel(result);\r\n              onClose && onClose(result);\r\n            } else {\r\n              _this.setState({ visible: false });\r\n            }\r\n          },\r\n        });\r\n      } else {\r\n        if (onCancel || onClose) {\r\n          onCancel && onCancel(result);\r\n          onClose && onClose(result);\r\n        } else {\r\n          _this.setState({ visible: false });\r\n        }\r\n      }\r\n    }\r\n    utils.callback(callback, scope, [_this.returnValue]);\r\n  }\r\n\r\n  /**\r\n   * 获取参数，如果key不传递，且获取全部\r\n   * @param {String} key\r\n   */\r\n  getParams(key) {\r\n    if (key) return this.option.params[key];\r\n    return this.option.params;\r\n  }\r\n  formValid(flag = false) {\r\n    const _this = this;\r\n    if (flag) {\r\n    }\r\n  }\r\n  render() {\r\n    const {\r\n      type = \"modal\",\r\n      closable,\r\n      title: orgtitle,\r\n      okButtonProps = {},\r\n      formExpand = {},\r\n      ...params\r\n    } = this.props;\r\n    let props: any = { ...params };\r\n    let { mountElementId } = config();\r\n\r\n    if (mountElementId) {\r\n      props = {\r\n        ...props,\r\n        getContainer: () => document.getElementById(mountElementId),\r\n      };\r\n    }\r\n\r\n    const title = (\r\n      <div className={getLess(styles, \"title\")}>\r\n        <div className={getLess(styles, \"icons\")}>\r\n          {!this.state.expand && (\r\n            <div\r\n              onClick={() => {\r\n                this.setState({ expand: true });\r\n              }}\r\n              className={getLess(styles, \"icon\")}\r\n            >\r\n              <ExpandOutlined />\r\n            </div>\r\n          )}\r\n          {this.state.expand && (\r\n            <div\r\n              onClick={() => {\r\n                this.setState({ expand: false });\r\n              }}\r\n              className={getLess(styles, \"icon\")}\r\n            >\r\n              <CompressOutlined />\r\n            </div>\r\n          )}\r\n          {closable !== false && (\r\n            <div\r\n              onClick={this.close.bind(this)}\r\n              className={getLess(styles, \"icon\")}\r\n              style={{ marginRight: 0 }}\r\n            >\r\n              <CloseOutlined />\r\n            </div>\r\n          )}\r\n        </div>\r\n        <div className={getLess(styles, \"title-content\")}>{orgtitle}</div>\r\n      </div>\r\n    );\r\n    const footer = (\r\n      <div className={getLess(styles, \"footer\")}>\r\n        <Button\r\n          type=\"primary\"\r\n          onClick={() => {\r\n            props.onOk && props.onOk();\r\n          }}\r\n          icon={<PlusCircleOutlined />}\r\n          {...okButtonProps}\r\n        >\r\n          保存\r\n        </Button>\r\n\r\n        <Button\r\n          onClick={this.close.bind(this)}\r\n          className={getLess(styles, \"button-margin\")}\r\n          icon={<CloseCircleOutlined />}\r\n        >\r\n          取消\r\n        </Button>\r\n      </div>\r\n    );\r\n    if (formExpand.expand) {\r\n      props = {\r\n        ...props,\r\n        footer,\r\n        title,\r\n        closable: false,\r\n        style: { maxWidth: \"100vw\" },\r\n        className: this.state.expand ? getLess(styles, \"allsreen\") : \"\",\r\n        width: this.state.expand ? \"100vw\" : props.width,\r\n      };\r\n    }\r\n    if (type == \"drawer\") {\r\n      return (\r\n        <Drawer\r\n          visible={this.state.visible}\r\n          onClose={() => {\r\n            this.close();\r\n          }}\r\n          {...props}\r\n        />\r\n      );\r\n    } else {\r\n      return (\r\n        <Modal\r\n          visible={this.state.visible}\r\n          onCancel={() => {\r\n            this.close();\r\n          }}\r\n          onOk={() => {\r\n            this.close();\r\n          }}\r\n          okText={\"确定\"}\r\n          cancelText={\"取消\"}\r\n          centered={true}\r\n          // title={formExpand ? title : this.props.title}\r\n          {...props}\r\n        />\r\n      );\r\n    }\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,42 @@
1
+ .footer {
2
+ display: flex;
3
+ flex-direction: row-reverse;
4
+ .button-margin {
5
+ margin-right: 15px;
6
+ }
7
+ :global {
8
+ .ant-btn {
9
+ border-radius: 4px;
10
+ min-width: 80px;
11
+ min-height: 35px;
12
+ }
13
+ }
14
+ }
15
+ .title {
16
+ display: flex;
17
+ flex-direction: row-reverse;
18
+ .icons {
19
+ display: flex;
20
+ margin-left: 15px;
21
+ .icon {
22
+ cursor: pointer;
23
+ margin-right: 10px;
24
+ }
25
+ }
26
+ .title-content {
27
+ flex: 1;
28
+ display: flex;
29
+ }
30
+ }
31
+
32
+ .allsreen {
33
+ :global {
34
+ .ant-modal-content {
35
+ height: 100vh;
36
+ }
37
+ .ant-modal-body {
38
+ height: calc(100vh - 150px);
39
+ }
40
+ }
41
+ }
42
+
@@ -0,0 +1,5 @@
1
+ import * as React from "react";
2
+ import { TransferProps } from "antd";
3
+ export default class NscTransfer extends React.PureComponent<TransferProps<any>, any> {
4
+ render(): React.ReactNode;
5
+ }