nsc-react-component 2.4.2 → 2.4.4
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.
- package/lib/base/drawer/index.d.ts +10 -1
- package/lib/base/drawer/index.js +6 -16
- package/lib/base/drawer/index.less +42 -0
- package/lib/base/form/Form.d.ts +1 -0
- package/lib/base/form/Form.js +50 -124
- package/lib/base/image/index.d.ts +7 -0
- package/lib/base/image/index.js +91 -7
- package/lib/base/image/index.less +29 -0
- package/lib/base/modal/index.d.ts +11 -1
- package/lib/base/modal/index.js +129 -15
- package/lib/base/modal/index.less +42 -0
- package/lib/page/BasePage/index.js +6 -3
- package/lib/page/BasePage/index.module.less +3 -0
- package/package.json +1 -1
package/lib/base/image/index.js
CHANGED
|
@@ -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
|
|
|
@@ -38,6 +38,10 @@ function _defineProperty(obj, key, value) { if (key in obj) { Object.definePrope
|
|
|
38
38
|
|
|
39
39
|
import * as React from "react";
|
|
40
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";
|
|
41
45
|
var download = file.download,
|
|
42
46
|
previewDocument = file.previewDocument;
|
|
43
47
|
|
|
@@ -57,8 +61,13 @@ var NscImage = /*#__PURE__*/function (_React$PureComponent) {
|
|
|
57
61
|
|
|
58
62
|
_this = _super.call.apply(_super, [this].concat(args));
|
|
59
63
|
|
|
64
|
+
_defineProperty(_assertThisInitialized(_this), "defaultImg", "data:image/png;base64,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");
|
|
65
|
+
|
|
60
66
|
_defineProperty(_assertThisInitialized(_this), "state", {
|
|
61
|
-
imgData:
|
|
67
|
+
imgData: _this.defaultImg,
|
|
68
|
+
visible: false,
|
|
69
|
+
mask: false,
|
|
70
|
+
loading: true
|
|
62
71
|
});
|
|
63
72
|
|
|
64
73
|
return _this;
|
|
@@ -85,7 +94,8 @@ var NscImage = /*#__PURE__*/function (_React$PureComponent) {
|
|
|
85
94
|
img = _context.sent;
|
|
86
95
|
this.blobToBase64(img).then(function (res) {
|
|
87
96
|
_this2.setState({
|
|
88
|
-
imgData: res
|
|
97
|
+
imgData: res,
|
|
98
|
+
loading: false
|
|
89
99
|
});
|
|
90
100
|
});
|
|
91
101
|
|
|
@@ -120,6 +130,19 @@ var NscImage = /*#__PURE__*/function (_React$PureComponent) {
|
|
|
120
130
|
};
|
|
121
131
|
});
|
|
122
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
|
+
}
|
|
123
146
|
}, {
|
|
124
147
|
key: "componentDidMount",
|
|
125
148
|
value: function componentDidMount() {
|
|
@@ -127,22 +150,83 @@ var NscImage = /*#__PURE__*/function (_React$PureComponent) {
|
|
|
127
150
|
|
|
128
151
|
if (fileId) {
|
|
129
152
|
this.getImgData();
|
|
153
|
+
} else {
|
|
154
|
+
this.setState({
|
|
155
|
+
loading: false
|
|
156
|
+
});
|
|
130
157
|
}
|
|
131
158
|
}
|
|
132
159
|
}, {
|
|
133
160
|
key: "render",
|
|
134
161
|
value: function render() {
|
|
162
|
+
var _this3 = this;
|
|
163
|
+
|
|
135
164
|
var _this$props = this.props,
|
|
136
165
|
fileId = _this$props.fileId,
|
|
137
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,
|
|
138
171
|
params = _objectWithoutProperties(_this$props, _excluded);
|
|
139
172
|
|
|
140
|
-
return /*#__PURE__*/React.createElement(
|
|
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({
|
|
141
216
|
src: this.props.src || this.state.imgData,
|
|
217
|
+
style: {
|
|
218
|
+
display: "none"
|
|
219
|
+
},
|
|
142
220
|
preview: {
|
|
143
|
-
|
|
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
|
+
}
|
|
144
228
|
}
|
|
145
|
-
}, params));
|
|
229
|
+
}, params)));
|
|
146
230
|
}
|
|
147
231
|
}]);
|
|
148
232
|
|
|
@@ -150,4 +234,4 @@ var NscImage = /*#__PURE__*/function (_React$PureComponent) {
|
|
|
150
234
|
}(React.PureComponent);
|
|
151
235
|
|
|
152
236
|
export { NscImage as default };
|
|
153
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL2Jhc2UvaW1hZ2UvaW5kZXgudHN4Il0sIm5hbWVzIjpbIlJlYWN0IiwiZmlsZSIsImRvd25sb2FkIiwicHJldmlld0RvY3VtZW50IiwiTnNjSW1hZ2UiLCJpbWdEYXRhIiwiZmlsZUlkIiwicHJvcHMiLCJyZXNwb25zZVR5cGUiLCJpbWciLCJibG9iVG9CYXNlNjQiLCJ0aGVuIiwicmVzIiwic2V0U3RhdGUiLCJibG9iIiwiUHJvbWlzZSIsInJlc29sdmUiLCJyZWplY3QiLCJmaWxlUmVhZGVyIiwiRmlsZVJlYWRlciIsIm9ubG9hZCIsImUiLCJ0YXJnZXQiLCJyZXN1bHQiLCJyZWFkQXNEYXRhVVJMIiwib25lcnJvciIsIkVycm9yIiwiZ2V0SW1nRGF0YSIsInNyYyIsInBhcmFtcyIsInN0YXRlIiwiUHVyZUNvbXBvbmVudCJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSxPQUFPLEtBQUtBLEtBQVosTUFBdUIsT0FBdkI7QUFFQSxPQUFPQyxJQUFQLE1BQWlCLFVBQWpCO0FBQ0EsSUFBUUMsUUFBUixHQUFzQ0QsSUFBdEMsQ0FBUUMsUUFBUjtBQUFBLElBQWtCQyxlQUFsQixHQUFzQ0YsSUFBdEMsQ0FBa0JFLGVBQWxCOztJQU1xQkMsUTs7Ozs7Ozs7Ozs7Ozs7Ozs0REFDWDtBQUNOQyxNQUFBQSxPQUFPLEVBQUU7QUFESCxLOzs7Ozs7OztnRkFHUjtBQUFBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFDVUMsZ0JBQUFBLE1BRFYsR0FDcUIsS0FBS0MsS0FEMUIsQ0FDVUQsTUFEVjtBQUFBO0FBQUEsdUJBRW9CSCxlQUFlLENBQUNHLE1BQUQsRUFBUztBQUFFRSxrQkFBQUEsWUFBWSxFQUFFO0FBQWhCLGlCQUFULENBRm5DOztBQUFBO0FBRVFDLGdCQUFBQSxHQUZSO0FBR0UscUJBQUtDLFlBQUwsQ0FBa0JELEdBQWxCLEVBQXVCRSxJQUF2QixDQUE0QixVQUFDQyxHQUFELEVBQVM7QUFDbkMsa0JBQUEsTUFBSSxDQUFDQyxRQUFMLENBQWM7QUFDWlIsb0JBQUFBLE9BQU8sRUFBRU87QUFERyxtQkFBZDtBQUdELGlCQUpEOztBQUhGO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLE87Ozs7Ozs7Ozs7V0FTQSxzQkFBYUUsSUFBYixFQUFtQjtBQUNqQixhQUFPLElBQUlDLE9BQUosQ0FBWSxVQUFDQyxPQUFELEVBQVVDLE1BQVYsRUFBcUI7QUFDdEMsWUFBTUMsVUFBVSxHQUFHLElBQUlDLFVBQUosRUFBbkI7O0FBQ0FELFFBQUFBLFVBQVUsQ0FBQ0UsTUFBWCxHQUFvQixVQUFDQyxDQUFELEVBQU87QUFDekJMLFVBQUFBLE9BQU8sQ0FBQ0ssQ0FBQyxDQUFDQyxNQUFGLENBQVNDLE1BQVYsQ0FBUDtBQUNELFNBRkQ7O0FBR0FMLFFBQUFBLFVBQVUsQ0FBQ00sYUFBWCxDQUF5QlYsSUFBekI7O0FBQ0FJLFFBQUFBLFVBQVUsQ0FBQ08sT0FBWCxHQUFxQixZQUFNO0FBQ3pCUixVQUFBQSxNQUFNLENBQUMsSUFBSVMsS0FBSixDQUFVLG9CQUFWLENBQUQsQ0FBTjtBQUNELFNBRkQ7QUFHRCxPQVRNLENBQVA7QUFVRDs7O1dBRUQsNkJBQW9CO0FBQ2xCLFVBQVFwQixNQUFSLEdBQW1CLEtBQUtDLEtBQXhCLENBQVFELE1BQVI7O0FBQ0EsVUFBSUEsTUFBSixFQUFZO0FBQ1YsYUFBS3FCLFVBQUw7QUFDRDtBQUNGOzs7V0FDRCxrQkFBMEI7QUFDeEIsd0JBQW1DLEtBQUtwQixLQUF4QztBQUFBLFVBQVFELE1BQVIsZUFBUUEsTUFBUjtBQUFBLFVBQWdCc0IsR0FBaEIsZUFBZ0JBLEdBQWhCO0FBQUEsVUFBd0JDLE1BQXhCOztBQUNBLDBCQUNFO0FBQ0UsUUFBQSxHQUFHLEVBQUUsS0FBS3RCLEtBQUwsQ0FBV3FCLEdBQVgsSUFBa0IsS0FBS0UsS0FBTCxDQUFXekIsT0FEcEM7QUFFRSxRQUFBLE9BQU8sRUFBRTtBQUNQdUIsVUFBQUEsR0FBRyxFQUFFLEtBQUtyQixLQUFMLENBQVdxQixHQUFYLElBQWtCLEtBQUtFLEtBQUwsQ0FBV3pCO0FBRDNCO0FBRlgsU0FLTXdCLE1BTE4sRUFERjtBQVNEOzs7O0VBM0NtQzdCLEtBQUssQ0FBQytCLGE7O1NBQXZCM0IsUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gXCJyZWFjdFwiO1xyXG5pbXBvcnQgeyBJbWFnZSwgSW1hZ2VQcm9wcyB9IGZyb20gXCJhbnRkXCI7XHJcbmltcG9ydCBmaWxlIGZyb20gXCJuc2MtZmlsZVwiO1xyXG5jb25zdCB7IGRvd25sb2FkLCBwcmV2aWV3RG9jdW1lbnQgfSA9IGZpbGU7XHJcbmludGVyZmFjZSBJSW1hZ2VQcm9wcyBleHRlbmRzIEltYWdlUHJvcHMge1xyXG4gIGZpbGVJZD86IHN0cmluZztcclxuICBzcmM/OiBzdHJpbmc7XHJcbn1cclxuXHJcbmV4cG9ydCBkZWZhdWx0IGNsYXNzIE5zY0ltYWdlIGV4dGVuZHMgUmVhY3QuUHVyZUNvbXBvbmVudDxJSW1hZ2VQcm9wcywgYW55PiB7XHJcbiAgc3RhdGUgPSB7XHJcbiAgICBpbWdEYXRhOiBcIlwiLFxyXG4gIH07XHJcbiAgYXN5bmMgZ2V0SW1nRGF0YSgpIHtcclxuICAgIGNvbnN0IHsgZmlsZUlkIH0gPSB0aGlzLnByb3BzO1xyXG4gICAgY29uc3QgaW1nID0gYXdhaXQgcHJldmlld0RvY3VtZW50KGZpbGVJZCwgeyByZXNwb25zZVR5cGU6IFwiYmxvYlwiIH0pO1xyXG4gICAgdGhpcy5ibG9iVG9CYXNlNjQoaW1nKS50aGVuKChyZXMpID0+IHtcclxuICAgICAgdGhpcy5zZXRTdGF0ZSh7XHJcbiAgICAgICAgaW1nRGF0YTogcmVzLFxyXG4gICAgICB9KTtcclxuICAgIH0pO1xyXG4gIH1cclxuICBibG9iVG9CYXNlNjQoYmxvYikge1xyXG4gICAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcclxuICAgICAgY29uc3QgZmlsZVJlYWRlciA9IG5ldyBGaWxlUmVhZGVyKCk7XHJcbiAgICAgIGZpbGVSZWFkZXIub25sb2FkID0gKGUpID0+IHtcclxuICAgICAgICByZXNvbHZlKGUudGFyZ2V0LnJlc3VsdCk7XHJcbiAgICAgIH07XHJcbiAgICAgIGZpbGVSZWFkZXIucmVhZEFzRGF0YVVSTChibG9iKTtcclxuICAgICAgZmlsZVJlYWRlci5vbmVycm9yID0gKCkgPT4ge1xyXG4gICAgICAgIHJlamVjdChuZXcgRXJyb3IoXCJibG9iVG9CYXNlNjQgZXJyb3JcIikpO1xyXG4gICAgICB9O1xyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICBjb21wb25lbnREaWRNb3VudCgpIHtcclxuICAgIGNvbnN0IHsgZmlsZUlkIH0gPSB0aGlzLnByb3BzO1xyXG4gICAgaWYgKGZpbGVJZCkge1xyXG4gICAgICB0aGlzLmdldEltZ0RhdGEoKTtcclxuICAgIH1cclxuICB9XHJcbiAgcmVuZGVyKCk6IFJlYWN0LlJlYWN0Tm9kZSB7XHJcbiAgICBjb25zdCB7IGZpbGVJZCwgc3JjLCAuLi5wYXJhbXMgfSA9IHRoaXMucHJvcHM7XHJcbiAgICByZXR1cm4gKFxyXG4gICAgICA8SW1hZ2VcclxuICAgICAgICBzcmM9e3RoaXMucHJvcHMuc3JjIHx8IHRoaXMuc3RhdGUuaW1nRGF0YX1cclxuICAgICAgICBwcmV2aWV3PXt7XHJcbiAgICAgICAgICBzcmM6IHRoaXMucHJvcHMuc3JjIHx8IHRoaXMuc3RhdGUuaW1nRGF0YSxcclxuICAgICAgICB9fVxyXG4gICAgICAgIHsuLi5wYXJhbXN9XHJcbiAgICAgIC8+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,15 @@
|
|
|
1
|
-
import { PureComponent } from "react";
|
|
1
|
+
import { PureComponent, ReactNode } 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;
|
|
11
|
+
cancelIcon?: ReactNode;
|
|
12
|
+
okIcon?: ReactNode;
|
|
5
13
|
}
|
|
6
14
|
export default class NscModal extends PureComponent<NscModalPorps> {
|
|
7
15
|
static confirm: import("antd/lib/modal/confirm").ModalFunc;
|
|
@@ -12,6 +20,7 @@ export default class NscModal extends PureComponent<NscModalPorps> {
|
|
|
12
20
|
returnValue: any;
|
|
13
21
|
state: {
|
|
14
22
|
visible: boolean;
|
|
23
|
+
expand: boolean;
|
|
15
24
|
};
|
|
16
25
|
option: any;
|
|
17
26
|
/**
|
|
@@ -31,6 +40,7 @@ export default class NscModal extends PureComponent<NscModalPorps> {
|
|
|
31
40
|
* @param {String} key
|
|
32
41
|
*/
|
|
33
42
|
getParams(key: any): any;
|
|
43
|
+
formValid(flag?: boolean): void;
|
|
34
44
|
render(): JSX.Element;
|
|
35
45
|
}
|
|
36
46
|
export {};
|
package/lib/base/modal/index.js
CHANGED
|
@@ -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
|
-
|
|
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
|
|
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
|
|
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
|
-
|
|
137
|
-
|
|
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$
|
|
158
|
-
_this$
|
|
159
|
-
type = _this$
|
|
160
|
-
|
|
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: this.props.okIcon ? this.props.okIcon : /*#__PURE__*/React.createElement(PlusCircleOutlined, null)
|
|
268
|
+
}, okButtonProps), this.props.okText ? this.props.okText : "保存"), /*#__PURE__*/React.createElement(Button, {
|
|
269
|
+
onClick: this.close.bind(this),
|
|
270
|
+
className: getLess(styles, "button-margin"),
|
|
271
|
+
icon: this.props.cancelIcon ? this.props.cancelIcon : /*#__PURE__*/React.createElement(CloseCircleOutlined, null)
|
|
272
|
+
}, this.props.cancelText ? this.props.cancelText : "取消"));
|
|
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","okIcon","cancelIcon","style","maxWidth","className","width","info","success","error","warning"],"mappings":"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","sourcesContent":["import React, { PureComponent, ReactNode } 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  cancelIcon?: ReactNode;\r\n  okIcon?: ReactNode;\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={this.props.okIcon ? this.props.okIcon : <PlusCircleOutlined />}\r\n          {...okButtonProps}\r\n        >\r\n          {this.props.okText ? this.props.okText : \"保存\"}\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={\r\n            this.props.cancelIcon ? (\r\n              this.props.cancelIcon\r\n            ) : (\r\n              <CloseCircleOutlined />\r\n            )\r\n          }\r\n        >\r\n          {this.props.cancelText ? this.props.cancelText : \"取消\"}\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
|
+
|