nsc-react-component 1.1.0 → 1.1.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/chart/index.d.ts +21 -0
- package/lib/chart/index.js +185 -17
- package/lib/menu/index.d.ts +0 -1
- package/lib/menu/index.js +6 -7
- package/lib/utils.d.ts +1 -0
- package/lib/utils.js +14 -1
- package/package.json +2 -2
package/lib/chart/index.d.ts
CHANGED
|
@@ -4,16 +4,37 @@ import { StoreProps } from "@bj-nsc/msn";
|
|
|
4
4
|
interface ChartProps {
|
|
5
5
|
store?: StoreProps;
|
|
6
6
|
option: any;
|
|
7
|
+
data?: Array<Object> | Object;
|
|
7
8
|
width: number | string;
|
|
8
9
|
height: number | string;
|
|
10
|
+
autoFresh: boolean;
|
|
11
|
+
autoLoad: boolean;
|
|
12
|
+
OnClick?: (params: any) => void;
|
|
9
13
|
}
|
|
14
|
+
/**
|
|
15
|
+
数组:
|
|
16
|
+
data=[{name:'1月',value:20},{name:'2月',value:10},{name:'3月',value:25}]
|
|
17
|
+
对象
|
|
18
|
+
data={name:['1月','2月','3月'],value:[20,30,40]}
|
|
19
|
+
*/
|
|
10
20
|
declare class NscChart extends PureComponent<ChartProps> {
|
|
11
21
|
chartRef: React.RefObject<HTMLDivElement>;
|
|
12
22
|
myChart: ECharts | null;
|
|
23
|
+
store: any;
|
|
24
|
+
state: {
|
|
25
|
+
dataSource: any;
|
|
26
|
+
};
|
|
27
|
+
isFirst: boolean;
|
|
13
28
|
constructor(props: any);
|
|
14
29
|
componentDidMount(): void;
|
|
30
|
+
componentDidUpdate(prevProps: Readonly<ChartProps>, prevState: Readonly<{}>, snapshot?: any): void;
|
|
15
31
|
reSetChart(): void;
|
|
32
|
+
isString(v: any): boolean;
|
|
16
33
|
componentWillUnmount(): void;
|
|
34
|
+
isReplace(v: any): boolean;
|
|
35
|
+
replace(v: any): any;
|
|
36
|
+
dataConversion(data: any, datas: any, dataMap: any): any;
|
|
37
|
+
objectConversion(obj: any, datas: any, dataMap: any): any;
|
|
17
38
|
init(): void;
|
|
18
39
|
handleChartResize(): void;
|
|
19
40
|
render(): JSX.Element;
|
package/lib/chart/index.js
CHANGED
|
@@ -2,6 +2,18 @@ function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "functi
|
|
|
2
2
|
|
|
3
3
|
var _excluded = ["url", "listeners"];
|
|
4
4
|
|
|
5
|
+
function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
|
|
6
|
+
|
|
7
|
+
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
8
|
+
|
|
9
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
10
|
+
|
|
11
|
+
function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
|
|
12
|
+
|
|
13
|
+
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
|
|
14
|
+
|
|
15
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
|
16
|
+
|
|
5
17
|
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
6
18
|
|
|
7
19
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
@@ -34,9 +46,19 @@ function _defineProperty(obj, key, value) { if (key in obj) { Object.definePrope
|
|
|
34
46
|
|
|
35
47
|
import React, { PureComponent } from "react";
|
|
36
48
|
import * as echarts from "echarts";
|
|
49
|
+
import Store from "@bj-nsc/msn";
|
|
37
50
|
import { utils } from "@bj-nsc/msn/lib/utils";
|
|
38
51
|
import { px2vw } from "../utils";
|
|
52
|
+
import { isArray, isObject } from "@bj-nsc/functions";
|
|
39
53
|
|
|
54
|
+
//data示例
|
|
55
|
+
|
|
56
|
+
/**
|
|
57
|
+
数组:
|
|
58
|
+
data=[{name:'1月',value:20},{name:'2月',value:10},{name:'3月',value:25}]
|
|
59
|
+
对象
|
|
60
|
+
data={name:['1月','2月','3月'],value:[20,30,40]}
|
|
61
|
+
*/
|
|
40
62
|
var NscChart = /*#__PURE__*/function (_PureComponent) {
|
|
41
63
|
_inherits(NscChart, _PureComponent);
|
|
42
64
|
|
|
@@ -53,11 +75,21 @@ var NscChart = /*#__PURE__*/function (_PureComponent) {
|
|
|
53
75
|
|
|
54
76
|
_defineProperty(_assertThisInitialized(_this2), "myChart", null);
|
|
55
77
|
|
|
78
|
+
_defineProperty(_assertThisInitialized(_this2), "store", {});
|
|
79
|
+
|
|
80
|
+
_defineProperty(_assertThisInitialized(_this2), "state", {
|
|
81
|
+
dataSource: null
|
|
82
|
+
});
|
|
83
|
+
|
|
84
|
+
_defineProperty(_assertThisInitialized(_this2), "isFirst", true);
|
|
85
|
+
|
|
56
86
|
var data = props.data,
|
|
57
87
|
_props$store = props.store,
|
|
58
88
|
store = _props$store === void 0 ? {} : _props$store,
|
|
59
89
|
children = props.children,
|
|
60
|
-
options = props.option
|
|
90
|
+
options = props.option,
|
|
91
|
+
_props$autoFresh = props.autoFresh,
|
|
92
|
+
autoFresh = _props$autoFresh === void 0 ? true : _props$autoFresh;
|
|
61
93
|
|
|
62
94
|
var url = store.url,
|
|
63
95
|
_store$listeners = store.listeners,
|
|
@@ -81,6 +113,12 @@ var NscChart = /*#__PURE__*/function (_PureComponent) {
|
|
|
81
113
|
load: function load(data, modelData, store) {
|
|
82
114
|
_this.setState({
|
|
83
115
|
dataSource: modelData
|
|
116
|
+
}, function () {
|
|
117
|
+
if (_this.isFirst) {
|
|
118
|
+
_this.init();
|
|
119
|
+
|
|
120
|
+
_this.isFirst = false;
|
|
121
|
+
}
|
|
84
122
|
});
|
|
85
123
|
|
|
86
124
|
utils.callback(listenersPops.load, _this, [data, modelData, store]);
|
|
@@ -88,6 +126,10 @@ var NscChart = /*#__PURE__*/function (_PureComponent) {
|
|
|
88
126
|
dataChanged: function dataChanged(data, modelData, store) {
|
|
89
127
|
_this.setState({
|
|
90
128
|
dataSource: modelData
|
|
129
|
+
}, function () {
|
|
130
|
+
if (autoFresh) {
|
|
131
|
+
_this.init();
|
|
132
|
+
}
|
|
91
133
|
});
|
|
92
134
|
|
|
93
135
|
utils.callback(listenersPops.dataChanged, _this, [data, modelData, store]);
|
|
@@ -95,14 +137,14 @@ var NscChart = /*#__PURE__*/function (_PureComponent) {
|
|
|
95
137
|
}
|
|
96
138
|
}, stores);
|
|
97
139
|
|
|
98
|
-
if (url && data == null
|
|
140
|
+
if (url && data == null) {
|
|
99
141
|
storeProps = _objectSpread(_objectSpread({}, {
|
|
100
142
|
autoLoad: true,
|
|
101
|
-
url: url
|
|
102
|
-
|
|
143
|
+
url: url
|
|
103
144
|
}), storeProps);
|
|
104
|
-
}
|
|
145
|
+
}
|
|
105
146
|
|
|
147
|
+
_this2.store = new Store(storeProps);
|
|
106
148
|
}
|
|
107
149
|
|
|
108
150
|
return _this2;
|
|
@@ -111,31 +153,157 @@ var NscChart = /*#__PURE__*/function (_PureComponent) {
|
|
|
111
153
|
_createClass(NscChart, [{
|
|
112
154
|
key: "componentDidMount",
|
|
113
155
|
value: function componentDidMount() {
|
|
114
|
-
this.
|
|
115
|
-
} // componentDidUpdate(prevProps: any) {
|
|
116
|
-
// if (JSON.stringify(prevProps.data) !== JSON.stringify(this.props.data)) {
|
|
117
|
-
// this.init();
|
|
118
|
-
// }
|
|
119
|
-
// }
|
|
156
|
+
var data = this.props.data;
|
|
120
157
|
|
|
158
|
+
if (data) {
|
|
159
|
+
this.init();
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
}, {
|
|
163
|
+
key: "componentDidUpdate",
|
|
164
|
+
value: function componentDidUpdate(prevProps, prevState, snapshot) {
|
|
165
|
+
var autoFresh = this.props.autoFresh;
|
|
166
|
+
|
|
167
|
+
if (autoFresh) {
|
|
168
|
+
if (JSON.stringify(prevProps.data) !== JSON.stringify(this.props.data)) {
|
|
169
|
+
this.init();
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
}
|
|
121
173
|
}, {
|
|
122
174
|
key: "reSetChart",
|
|
123
175
|
value: function reSetChart() {
|
|
124
176
|
this.init();
|
|
125
177
|
}
|
|
178
|
+
}, {
|
|
179
|
+
key: "isString",
|
|
180
|
+
value: function isString(v) {
|
|
181
|
+
return typeof v === "string";
|
|
182
|
+
}
|
|
126
183
|
}, {
|
|
127
184
|
key: "componentWillUnmount",
|
|
128
185
|
value: function componentWillUnmount() {
|
|
129
186
|
window.removeEventListener("resize", this.handleChartResize.bind(this));
|
|
130
187
|
}
|
|
188
|
+
}, {
|
|
189
|
+
key: "isReplace",
|
|
190
|
+
value: function isReplace(v) {
|
|
191
|
+
return /^{.*}$/gi.test(v);
|
|
192
|
+
}
|
|
193
|
+
}, {
|
|
194
|
+
key: "replace",
|
|
195
|
+
value: function replace(v) {
|
|
196
|
+
return v.substring(1, v.length - 1);
|
|
197
|
+
}
|
|
198
|
+
}, {
|
|
199
|
+
key: "dataConversion",
|
|
200
|
+
value: function dataConversion(data, datas, dataMap) {
|
|
201
|
+
var _this3 = this;
|
|
202
|
+
|
|
203
|
+
var result;
|
|
204
|
+
|
|
205
|
+
if (data) {
|
|
206
|
+
if (this.isString(data) && this.isReplace(data)) {
|
|
207
|
+
result = dataMap[this.replace(data)];
|
|
208
|
+
} else if (isArray(data)) {
|
|
209
|
+
data.map(function (item) {
|
|
210
|
+
var v = item.value;
|
|
211
|
+
|
|
212
|
+
if (v && _this3.isReplace(v)) {
|
|
213
|
+
item.value = _this3.dataConversion(v, datas, dataMap);
|
|
214
|
+
}
|
|
215
|
+
});
|
|
216
|
+
result = data;
|
|
217
|
+
} else if (isObject(data)) {
|
|
218
|
+
result = [];
|
|
219
|
+
|
|
220
|
+
if (isArray(datas)) {
|
|
221
|
+
datas.map(function (item) {
|
|
222
|
+
var tempObj = {};
|
|
223
|
+
|
|
224
|
+
for (var key in item) {
|
|
225
|
+
var v = item[key];
|
|
226
|
+
|
|
227
|
+
if (_this3.isReplace(v)) {
|
|
228
|
+
tempObj[key] = item[_this3.replace(v)];
|
|
229
|
+
} else {
|
|
230
|
+
tempObj[key] = v;
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
result.push(tempObj);
|
|
235
|
+
});
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
|
|
240
|
+
return result;
|
|
241
|
+
}
|
|
242
|
+
}, {
|
|
243
|
+
key: "objectConversion",
|
|
244
|
+
value: function objectConversion(obj, datas, dataMap) {
|
|
245
|
+
var _this4 = this;
|
|
246
|
+
|
|
247
|
+
var tempObj;
|
|
248
|
+
|
|
249
|
+
if (obj) {
|
|
250
|
+
if (isArray(obj)) {
|
|
251
|
+
tempObj = _toConsumableArray(obj);
|
|
252
|
+
tempObj.map(function (item) {
|
|
253
|
+
if (item.data) {
|
|
254
|
+
item.data = _this4.dataConversion(item.data, datas, dataMap);
|
|
255
|
+
}
|
|
256
|
+
});
|
|
257
|
+
} else if (this.isString(obj)) {
|
|
258
|
+
tempObj = obj;
|
|
259
|
+
tempObj.data = this.dataConversion(tempObj, datas, dataMap);
|
|
260
|
+
} else if (isObject(obj)) {
|
|
261
|
+
tempObj = _objectSpread({}, obj);
|
|
262
|
+
tempObj.data = this.dataConversion(tempObj.data, datas, dataMap);
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
|
|
266
|
+
return tempObj;
|
|
267
|
+
}
|
|
131
268
|
}, {
|
|
132
269
|
key: "init",
|
|
133
270
|
value: function init() {
|
|
134
|
-
var
|
|
271
|
+
var _this$props = this.props,
|
|
272
|
+
option = _this$props.option,
|
|
273
|
+
data = _this$props.data,
|
|
274
|
+
OnClick = _this$props.OnClick;
|
|
275
|
+
var dataSource = this.state.dataSource;
|
|
276
|
+
var dataMap = {};
|
|
277
|
+
var newDatas = data || dataSource;
|
|
278
|
+
|
|
279
|
+
var newOption = _objectSpread({}, option);
|
|
280
|
+
|
|
281
|
+
if (isArray(newDatas)) {
|
|
282
|
+
newDatas.map(function (item) {
|
|
283
|
+
for (var key in item) {
|
|
284
|
+
if (dataMap[key] == null) {
|
|
285
|
+
dataMap[key] = [];
|
|
286
|
+
}
|
|
287
|
+
|
|
288
|
+
dataMap[key].push(item[key]);
|
|
289
|
+
}
|
|
290
|
+
});
|
|
291
|
+
} else if (isObject(newDatas)) {
|
|
292
|
+
dataMap = newDatas;
|
|
293
|
+
}
|
|
294
|
+
|
|
295
|
+
newOption.xAxis = this.objectConversion(newOption.xAxis, newDatas, dataMap);
|
|
296
|
+
newOption.yAxis = this.objectConversion(newOption.yAxis, newDatas, dataMap);
|
|
297
|
+
newOption.series = this.objectConversion(newOption.series, newDatas, dataMap);
|
|
135
298
|
var myChart = this.myChart = echarts.init(this.chartRef.current); //初始化echarts,通过ref属性获取dom
|
|
136
299
|
|
|
137
300
|
myChart.clear();
|
|
138
|
-
myChart.setOption(
|
|
301
|
+
myChart.setOption(newOption);
|
|
302
|
+
myChart.on("click", function (params) {
|
|
303
|
+
myChart.off("click"); // 这里很重要 ,防止重复点击事件!!!
|
|
304
|
+
|
|
305
|
+
OnClick && OnClick(params);
|
|
306
|
+
});
|
|
139
307
|
window.addEventListener("resize", this.handleChartResize.bind(this));
|
|
140
308
|
}
|
|
141
309
|
}, {
|
|
@@ -148,9 +316,9 @@ var NscChart = /*#__PURE__*/function (_PureComponent) {
|
|
|
148
316
|
}, {
|
|
149
317
|
key: "render",
|
|
150
318
|
value: function render() {
|
|
151
|
-
var _this$
|
|
152
|
-
width = _this$
|
|
153
|
-
height = _this$
|
|
319
|
+
var _this$props2 = this.props,
|
|
320
|
+
width = _this$props2.width,
|
|
321
|
+
height = _this$props2.height;
|
|
154
322
|
var boxStyle = {
|
|
155
323
|
width: typeof width == "number" ? px2vw(width) : width,
|
|
156
324
|
height: typeof height == "number" ? px2vw(height) : height
|
|
@@ -166,4 +334,4 @@ var NscChart = /*#__PURE__*/function (_PureComponent) {
|
|
|
166
334
|
}(PureComponent);
|
|
167
335
|
|
|
168
336
|
export default NscChart;
|
|
169
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/chart/index.tsx"],"names":["React","PureComponent","echarts","utils","px2vw","NscChart","props","createRef","data","store","children","options","option","url","listeners","listenersPops","stores","Error","_this","storeProps","model","component","onBeforeLoad","callback","load","modelData","setState","dataSource","dataChanged","autoLoad","init","window","removeEventListener","handleChartResize","bind","myChart","chartRef","current","clear","setOption","addEventListener","resize","width","height","boxStyle"],"mappings":"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","sourcesContent":["import React, { PureComponent } from \"react\";\r\nimport * as echarts from \"echarts\";\r\nimport { ECharts } from \"echarts/lib/echarts\";\r\nimport Store, { StoreProps } from \"@bj-nsc/msn\";\r\nimport { utils } from \"@bj-nsc/msn/lib/utils\";\r\nimport { px2vw } from \"../utils\";\r\n\r\ninterface ChartProps {\r\n  store?: StoreProps;\r\n  option: any;\r\n  width: number | string; //图表宽度\r\n  height: number | string; //图表长度\r\n}\r\n\r\nclass NscChart extends PureComponent<ChartProps> {\r\n  chartRef = React.createRef<HTMLDivElement>();\r\n  myChart: ECharts | null = null;\r\n\r\n  constructor(props) {\r\n    super(props);\r\n    const { data, store = {}, children, option: options } = props;\r\n    const { url, listeners: listenersPops = {}, ...stores } = store;\r\n\r\n    if (!children) {\r\n      if (!(data || url || options)) {\r\n        throw new Error(\"url、data、option不能都为空！\");\r\n      }\r\n      let _this = this;\r\n      let storeProps = {\r\n        model: \"model\",\r\n        component: this,\r\n        listeners: {\r\n          onBeforeLoad: function (store, options) {\r\n            utils.callback(listenersPops.onBeforeLoad, _this, [store, options]);\r\n          },\r\n          load: function (data, modelData, store) {\r\n            _this.setState({ dataSource: modelData });\r\n            utils.callback(listenersPops.load, _this, [data, modelData, store]);\r\n          },\r\n          dataChanged: function (data, modelData, store) {\r\n            _this.setState({ dataSource: modelData });\r\n            utils.callback(listenersPops.dataChanged, _this, [\r\n              data,\r\n              modelData,\r\n              store,\r\n            ]);\r\n          },\r\n        },\r\n        ...stores,\r\n      };\r\n      if (url && data == null && options == null) {\r\n        storeProps = {\r\n          ...{\r\n            autoLoad: true,\r\n            url: url, //读字典，url固定，viewname\r\n          },\r\n          ...storeProps,\r\n        };\r\n      }\r\n      //   this.store = new Store(storeProps);\r\n    }\r\n  }\r\n\r\n  componentDidMount() {\r\n    this.init();\r\n  }\r\n\r\n  //   componentDidUpdate(prevProps: any) {\r\n  //     if (JSON.stringify(prevProps.data) !== JSON.stringify(this.props.data)) {\r\n  //       this.init();\r\n  //     }\r\n  //   }\r\n\r\n  reSetChart() {\r\n    this.init();\r\n  }\r\n\r\n  componentWillUnmount() {\r\n    window.removeEventListener(\"resize\", this.handleChartResize.bind(this));\r\n  }\r\n\r\n  init() {\r\n    const { option } = this.props;\r\n    const myChart = (this.myChart = echarts.init(\r\n      this.chartRef.current as HTMLDivElement\r\n    )); //初始化echarts，通过ref属性获取dom\r\n    myChart.clear();\r\n    myChart.setOption(option);\r\n    window.addEventListener(\"resize\", this.handleChartResize.bind(this));\r\n  }\r\n\r\n  handleChartResize() {\r\n    if (this.myChart) {\r\n      this.myChart.resize();\r\n    }\r\n  }\r\n\r\n  render() {\r\n    const { width, height } = this.props;\r\n    const boxStyle = {\r\n      width: typeof width == \"number\" ? px2vw(width) : width,\r\n      height: typeof height == \"number\" ? px2vw(height) : height,\r\n    };\r\n    return <div style={boxStyle} ref={this.chartRef}></div>;\r\n  }\r\n}\r\n\r\nexport default NscChart;\r\n"]}
|
|
337
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/chart/index.tsx"],"names":["React","PureComponent","echarts","Store","utils","px2vw","isArray","isObject","NscChart","props","createRef","dataSource","data","store","children","options","option","autoFresh","url","listeners","listenersPops","stores","Error","_this","storeProps","model","component","onBeforeLoad","callback","load","modelData","setState","isFirst","init","dataChanged","autoLoad","prevProps","prevState","snapshot","JSON","stringify","v","window","removeEventListener","handleChartResize","bind","test","substring","length","datas","dataMap","result","isString","isReplace","replace","map","item","value","dataConversion","tempObj","key","push","obj","OnClick","state","newDatas","newOption","xAxis","objectConversion","yAxis","series","myChart","chartRef","current","clear","setOption","on","params","off","addEventListener","resize","width","height","boxStyle"],"mappings":"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","sourcesContent":["import React, { PureComponent } from \"react\";\r\nimport * as echarts from \"echarts\";\r\nimport { ECharts } from \"echarts/lib/echarts\";\r\nimport Store, { StoreProps } from \"@bj-nsc/msn\";\r\nimport { utils } from \"@bj-nsc/msn/lib/utils\";\r\nimport { px2vw } from \"../utils\";\r\nimport { isArray, isObject } from \"@bj-nsc/functions\";\r\ninterface ChartProps {\r\n  store?: StoreProps;\r\n  option: any;\r\n  data?: Array<Object> | Object;\r\n  width: number | string; //图表宽度\r\n  height: number | string; //图表长度\r\n  autoFresh: boolean; //数据改变，自动刷新图表,默认true\r\n  autoLoad: boolean;\r\n  OnClick?: (params: any) => void; //图表点击事件\r\n}\r\n\r\n//data示例\r\n/**\r\n 数组：\r\n data=[{name:'1月',value:20},{name:'2月',value:10},{name:'3月',value:25}]\r\n 对象\r\n data={name:['1月','2月','3月'],value:[20,30,40]}\r\n */\r\nclass NscChart extends PureComponent<ChartProps> {\r\n  chartRef = React.createRef<HTMLDivElement>();\r\n  myChart: ECharts | null = null;\r\n  store = {} as StoreProps;\r\n  state = {\r\n    dataSource: null,\r\n  };\r\n  isFirst = true;\r\n  constructor(props) {\r\n    super(props);\r\n    const {\r\n      data,\r\n      store = {},\r\n      children,\r\n      option: options,\r\n      autoFresh = true,\r\n    } = props;\r\n    const { url, listeners: listenersPops = {}, ...stores } = store;\r\n    if (!children) {\r\n      if (!(data || url || options)) {\r\n        throw new Error(\"url、data、option不能都为空！\");\r\n      }\r\n      let _this = this;\r\n      let storeProps = {\r\n        model: \"model\",\r\n        component: this,\r\n        listeners: {\r\n          onBeforeLoad: function (store, options) {\r\n            utils.callback(listenersPops.onBeforeLoad, _this, [store, options]);\r\n          },\r\n          load: function (data, modelData, store) {\r\n            _this.setState({ dataSource: modelData }, () => {\r\n              if (_this.isFirst) {\r\n                _this.init();\r\n                _this.isFirst = false;\r\n              }\r\n            });\r\n            utils.callback(listenersPops.load, _this, [data, modelData, store]);\r\n          },\r\n          dataChanged: function (data, modelData, store) {\r\n            _this.setState({ dataSource: modelData }, () => {\r\n              if (autoFresh) {\r\n                _this.init();\r\n              }\r\n            });\r\n            utils.callback(listenersPops.dataChanged, _this, [\r\n              data,\r\n              modelData,\r\n              store,\r\n            ]);\r\n          },\r\n        },\r\n        ...stores,\r\n      };\r\n      if (url && data == null) {\r\n        storeProps = {\r\n          ...{\r\n            autoLoad: true,\r\n            url: url,\r\n          },\r\n          ...storeProps,\r\n        };\r\n      }\r\n      this.store = new Store(storeProps);\r\n    }\r\n  }\r\n\r\n  componentDidMount() {\r\n    const { data } = this.props;\r\n    if (data) {\r\n      this.init();\r\n    }\r\n  }\r\n\r\n  componentDidUpdate(\r\n    prevProps: Readonly<ChartProps>,\r\n    prevState: Readonly<{}>,\r\n    snapshot?: any\r\n  ): void {\r\n    const { autoFresh } = this.props;\r\n    if (autoFresh) {\r\n      if (JSON.stringify(prevProps.data) !== JSON.stringify(this.props.data)) {\r\n        this.init();\r\n      }\r\n    }\r\n  }\r\n\r\n  reSetChart() {\r\n    this.init();\r\n  }\r\n  isString(v) {\r\n    return typeof v === \"string\";\r\n  }\r\n  componentWillUnmount() {\r\n    window.removeEventListener(\"resize\", this.handleChartResize.bind(this));\r\n  }\r\n\r\n  isReplace(v) {\r\n    return /^{.*}$/gi.test(v);\r\n  }\r\n  replace(v) {\r\n    return v.substring(1, v.length - 1);\r\n  }\r\n\r\n  dataConversion(data, datas, dataMap) {\r\n    let result;\r\n    if (data) {\r\n      if (this.isString(data) && this.isReplace(data)) {\r\n        result = dataMap[this.replace(data)];\r\n      } else if (isArray(data)) {\r\n        data.map((item) => {\r\n          let v = item.value;\r\n          if (v && this.isReplace(v)) {\r\n            item.value = this.dataConversion(v, datas, dataMap);\r\n          }\r\n        });\r\n        result = data;\r\n      } else if (isObject(data)) {\r\n        result = [];\r\n        if (isArray(datas)) {\r\n          datas.map((item) => {\r\n            var tempObj = {};\r\n            for (let key in item) {\r\n              let v = item[key];\r\n              if (this.isReplace(v)) {\r\n                tempObj[key] = item[this.replace(v)];\r\n              } else {\r\n                tempObj[key] = v;\r\n              }\r\n            }\r\n            result.push(tempObj);\r\n          });\r\n        }\r\n      }\r\n    }\r\n    return result;\r\n  }\r\n  objectConversion(obj, datas, dataMap) {\r\n    let tempObj: any;\r\n    if (obj) {\r\n      if (isArray(obj)) {\r\n        tempObj = [...obj];\r\n        tempObj.map((item) => {\r\n          if (item.data) {\r\n            item.data = this.dataConversion(item.data, datas, dataMap);\r\n          }\r\n        });\r\n      } else if (this.isString(obj)) {\r\n        tempObj = obj;\r\n        tempObj.data = this.dataConversion(tempObj, datas, dataMap);\r\n      } else if (isObject(obj)) {\r\n        tempObj = { ...obj };\r\n        tempObj.data = this.dataConversion(tempObj.data, datas, dataMap);\r\n      }\r\n    }\r\n    return tempObj;\r\n  }\r\n  init() {\r\n    const { option, data, OnClick } = this.props;\r\n    const { dataSource } = this.state;\r\n    let dataMap: any = {};\r\n    const newDatas = data || dataSource;\r\n    let newOption: any = { ...option };\r\n    if (isArray(newDatas)) {\r\n      newDatas.map((item) => {\r\n        for (let key in item) {\r\n          if (dataMap[key] == null) {\r\n            dataMap[key] = [];\r\n          }\r\n          dataMap[key].push(item[key]);\r\n        }\r\n      });\r\n    } else if (isObject(newDatas)) {\r\n      dataMap = newDatas;\r\n    }\r\n    newOption.xAxis = this.objectConversion(newOption.xAxis, newDatas, dataMap);\r\n    newOption.yAxis = this.objectConversion(newOption.yAxis, newDatas, dataMap);\r\n    newOption.series = this.objectConversion(\r\n      newOption.series,\r\n      newDatas,\r\n      dataMap\r\n    );\r\n    const myChart = (this.myChart = echarts.init(\r\n      this.chartRef.current as HTMLDivElement\r\n    )); //初始化echarts，通过ref属性获取dom\r\n    myChart.clear();\r\n    myChart.setOption(newOption);\r\n    myChart.on(\"click\", function (params) {\r\n      myChart.off(\"click\"); // 这里很重要 ，防止重复点击事件！！！\r\n      OnClick && OnClick(params);\r\n    });\r\n    window.addEventListener(\"resize\", this.handleChartResize.bind(this));\r\n  }\r\n\r\n  handleChartResize() {\r\n    if (this.myChart) {\r\n      this.myChart.resize();\r\n    }\r\n  }\r\n\r\n  render() {\r\n    const { width, height } = this.props;\r\n    const boxStyle = {\r\n      width: typeof width == \"number\" ? px2vw(width) : width,\r\n      height: typeof height == \"number\" ? px2vw(height) : height,\r\n    };\r\n    return <div style={boxStyle} ref={this.chartRef}></div>;\r\n  }\r\n}\r\n\r\nexport default NscChart;\r\n"]}
|
package/lib/menu/index.d.ts
CHANGED
|
@@ -6,7 +6,6 @@ interface IMenuProps extends MenuProps {
|
|
|
6
6
|
titleField?: string;
|
|
7
7
|
keyField?: string;
|
|
8
8
|
store?: StoreProps;
|
|
9
|
-
showIcon?: boolean;
|
|
10
9
|
}
|
|
11
10
|
export default class NSCMenu extends PureComponent<IMenuProps> {
|
|
12
11
|
static SubMenu: typeof import("antd/lib/menu/SubMenu").default;
|
package/lib/menu/index.js
CHANGED
|
@@ -45,6 +45,7 @@ function _defineProperty(obj, key, value) { if (key in obj) { Object.definePrope
|
|
|
45
45
|
import React, { PureComponent } from "react";
|
|
46
46
|
import Store from "@bj-nsc/msn";
|
|
47
47
|
import { utils } from "@bj-nsc/msn/lib/utils";
|
|
48
|
+
import { getIcon } from "../utils";
|
|
48
49
|
import omit from "omit.js";
|
|
49
50
|
var SubMenu = _Menu.SubMenu,
|
|
50
51
|
Item = _Menu.Item,
|
|
@@ -77,9 +78,7 @@ var NSCMenu = /*#__PURE__*/function (_PureComponent) {
|
|
|
77
78
|
_this2$props$titleFie = _this2$props.titleField,
|
|
78
79
|
titleField = _this2$props$titleFie === void 0 ? "title" : _this2$props$titleFie,
|
|
79
80
|
_this2$props$keyField = _this2$props.keyField,
|
|
80
|
-
keyField = _this2$props$keyField === void 0 ? "key" : _this2$props$keyField
|
|
81
|
-
_this2$props$showIcon = _this2$props.showIcon,
|
|
82
|
-
showIcon = _this2$props$showIcon === void 0 ? true : _this2$props$showIcon;
|
|
81
|
+
keyField = _this2$props$keyField === void 0 ? "key" : _this2$props$keyField;
|
|
83
82
|
return menusData.map(function (item) {
|
|
84
83
|
var style = item.style,
|
|
85
84
|
icon = item.icon,
|
|
@@ -104,7 +103,7 @@ var NSCMenu = /*#__PURE__*/function (_PureComponent) {
|
|
|
104
103
|
});
|
|
105
104
|
return /*#__PURE__*/React.createElement(SubMenu, {
|
|
106
105
|
key: item[keyField],
|
|
107
|
-
title:
|
|
106
|
+
title: icon ? /*#__PURE__*/React.createElement("span", null, getIcon(icon), spantitle) : spantitle
|
|
108
107
|
}, Object.keys(menuGroupData).map(function (key) {
|
|
109
108
|
return /*#__PURE__*/React.createElement(ItemGroup, {
|
|
110
109
|
key: key,
|
|
@@ -115,7 +114,7 @@ var NSCMenu = /*#__PURE__*/function (_PureComponent) {
|
|
|
115
114
|
return /*#__PURE__*/React.createElement(_Menu.Item, {
|
|
116
115
|
key: item[keyField],
|
|
117
116
|
disabled: disabled
|
|
118
|
-
},
|
|
117
|
+
}, icon ? /*#__PURE__*/React.createElement("span", null, getIcon(icon), spantitle) : spantitle);
|
|
119
118
|
}
|
|
120
119
|
});
|
|
121
120
|
});
|
|
@@ -199,7 +198,7 @@ var NSCMenu = /*#__PURE__*/function (_PureComponent) {
|
|
|
199
198
|
}, {
|
|
200
199
|
key: "render",
|
|
201
200
|
value: function render() {
|
|
202
|
-
var menuProps = omit(this.props, ["data", "store", "titleField", "keyField"
|
|
201
|
+
var menuProps = omit(this.props, ["data", "store", "titleField", "keyField"]);
|
|
203
202
|
return /*#__PURE__*/React.createElement(_Menu, menuProps, this.renderChildren());
|
|
204
203
|
}
|
|
205
204
|
}], [{
|
|
@@ -230,4 +229,4 @@ _defineProperty(NSCMenu, "Item", Item);
|
|
|
230
229
|
_defineProperty(NSCMenu, "ItemGroup", ItemGroup);
|
|
231
230
|
|
|
232
231
|
export { NSCMenu as default };
|
|
233
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/menu/index.tsx"],"names":["React","PureComponent","Store","utils","omit","SubMenu","Item","ItemGroup","NSCMenu","props","dataSource","menusData","Array","isArray","titleField","keyField","showIcon","map","item","style","icon","disabled","spantitle","menuGroupData","menuData","childData","gruoptitle","groupName","push","getIcon","Object","keys","key","renderMenuItem","children","state","data","store","url","listeners","listenersPops","viewname","stores","Error","_this","storeProps","model","component","onBeforeLoad","options","callback","load","modelData","setState","dataChanged","autoLoad","menuProps","renderChildren","nextProps","prevState","JSON","stringify"],"mappings":"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","sourcesContent":["/*\r\n * @Descripttion:\r\n * @version:\r\n * @Author: rxzhu\r\n * @Date: 2021-04-16 09:43:28\r\n * @LastEditors: rxzhu\r\n * @LastEditTime: 2021-04-23 15:53:40\r\n */\r\nimport React, { PureComponent } from \"react\";\r\n\r\nimport { Menu, MenuProps } from \"antd\";\r\nimport Store, { StoreProps } from \"@bj-nsc/msn\";\r\nimport { utils } from \"@bj-nsc/msn/lib/utils\";\r\nimport omit from \"omit.js\";\r\n\r\ninterface IMenuProps extends MenuProps {\r\n  data?: Array<object>;\r\n  titleField?: string;\r\n  keyField?: string;\r\n  store?: StoreProps;\r\n  showIcon?: boolean;\r\n}\r\nconst { SubMenu, Item, ItemGroup } = Menu;\r\n\r\nexport default class NSCMenu extends PureComponent<IMenuProps> {\r\n  static SubMenu = SubMenu;\r\n  static Item = Item;\r\n  static ItemGroup = ItemGroup;\r\n\r\n  state = {\r\n    dataSource: [],\r\n  };\r\n\r\n  store = {} as StoreProps;\r\n  static getDerivedStateFromProps(nextProps, prevState: any) {\r\n    const { dataSource } = prevState;\r\n    const { data } = nextProps;\r\n    if (data) {\r\n      if (JSON.stringify(dataSource) !== JSON.stringify(data)) {\r\n        return {\r\n          dataSource: data,\r\n        };\r\n      }\r\n    }\r\n    return null;\r\n  }\r\n  constructor(props) {\r\n    super(props);\r\n    const { data, store = {}, children } = props;\r\n    const { url, listeners: listenersPops = {}, viewname, ...stores } = store;\r\n    if (!children) {\r\n      if (!(data || url)) {\r\n        throw new Error(\"url、data不能都为空！\");\r\n      }\r\n      let _this = this;\r\n      let storeProps = {\r\n        model: \"model\",\r\n        component: this,\r\n        listeners: {\r\n          onBeforeLoad: function (store, options) {\r\n            utils.callback(listenersPops.onBeforeLoad, _this, [store, options]);\r\n          },\r\n          load: function (data, modelData, store) {\r\n            _this.setState({ dataSource: modelData });\r\n            utils.callback(listenersPops.load, _this, [data, modelData, store]);\r\n          },\r\n          dataChanged: function (data, modelData, store) {\r\n            _this.setState({ dataSource: modelData });\r\n            utils.callback(listenersPops.dataChanged, _this, [\r\n              data,\r\n              modelData,\r\n              store,\r\n            ]);\r\n          },\r\n        },\r\n        ...stores,\r\n      };\r\n      if (url && data == null) {\r\n        storeProps = {\r\n          ...{\r\n            autoLoad: true,\r\n            url: url, //读字典，url固定，viewname\r\n          },\r\n          ...storeProps,\r\n        };\r\n      }\r\n      this.store = new Store(storeProps);\r\n    }\r\n  }\r\n  componentDidMount() {\r\n    if (this.props.data) {\r\n      this.setState({\r\n        dataSource: this.props.data,\r\n      });\r\n    }\r\n  }\r\n  renderMenuItem = (menusData) => {\r\n    if (!menusData || !Array.isArray(menusData)) {\r\n      return [];\r\n    }\r\n    const {\r\n      titleField = \"title\",\r\n      keyField = \"key\",\r\n      showIcon = true,\r\n    } = this.props;\r\n    return menusData.map((item) => {\r\n      const { style, icon, disabled } = item;\r\n      const spantitle = <span style={style}>{item[titleField]}</span>;\r\n      if (item[\"childNodes\"] || item[\"children\"]) {\r\n        let menuGroupData = {},\r\n          menuData = [];\r\n        let childData = item[\"childNodes\"] || item[\"children\"];\r\n        childData.map((item) => {\r\n          let gruoptitle = item.groupName;\r\n          if (gruoptitle) {\r\n            if (!menuGroupData[gruoptitle]) menuGroupData[gruoptitle] = [];\r\n            menuGroupData[gruoptitle].push(item);\r\n          } else {\r\n            menuData.push(item);\r\n          }\r\n        });\r\n        return (\r\n          <SubMenu\r\n            key={item[keyField]}\r\n            title={\r\n              showIcon && icon ? (\r\n                <span>\r\n                  {utils.getIcon(icon)}\r\n                  {spantitle}\r\n                </span>\r\n              ) : (\r\n                spantitle\r\n              )\r\n            }\r\n          >\r\n            {Object.keys(menuGroupData).map((key) => {\r\n              return (\r\n                <ItemGroup key={key} title={key}>\r\n                  {this.renderMenuItem(menuGroupData[key])}\r\n                </ItemGroup>\r\n              );\r\n            })}\r\n            {this.renderMenuItem(menuData)}\r\n          </SubMenu>\r\n        );\r\n      } else {\r\n        return (\r\n          <Menu.Item key={item[keyField]} disabled={disabled}>\r\n            {showIcon && icon ? (\r\n              <span>\r\n                {utils.getIcon(icon)}\r\n                {spantitle}\r\n              </span>\r\n            ) : (\r\n              spantitle\r\n            )}\r\n          </Menu.Item>\r\n        );\r\n      }\r\n    });\r\n  };\r\n  renderChildren = () => {\r\n    const { children } = this.props;\r\n    const { dataSource } = this.state;\r\n    if (children) {\r\n      return <>{children}</>;\r\n    } else {\r\n      return this.renderMenuItem(dataSource);\r\n    }\r\n  };\r\n\r\n  render() {\r\n    const menuProps = omit(this.props, [\r\n      \"data\",\r\n      \"store\",\r\n      \"titleField\",\r\n      \"keyField\",\r\n      \"showIcon\",\r\n    ]);\r\n    return <Menu {...menuProps}>{this.renderChildren()}</Menu>;\r\n  }\r\n}\r\n"]}
|
|
232
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/menu/index.tsx"],"names":["React","PureComponent","Store","utils","getIcon","omit","SubMenu","Item","ItemGroup","NSCMenu","props","dataSource","menusData","Array","isArray","titleField","keyField","map","item","style","icon","disabled","spantitle","menuGroupData","menuData","childData","gruoptitle","groupName","push","Object","keys","key","renderMenuItem","children","state","data","store","url","listeners","listenersPops","viewname","stores","Error","_this","storeProps","model","component","onBeforeLoad","options","callback","load","modelData","setState","dataChanged","autoLoad","menuProps","renderChildren","nextProps","prevState","JSON","stringify"],"mappings":"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","sourcesContent":["/*\r\n * @Descripttion:\r\n * @version:\r\n * @Author: rxzhu\r\n * @Date: 2021-04-16 09:43:28\r\n * @LastEditors: rxzhu\r\n * @LastEditTime: 2021-04-23 15:53:40\r\n */\r\nimport React, { PureComponent } from \"react\";\r\n\r\nimport { Menu, MenuProps } from \"antd\";\r\nimport Store, { StoreProps } from \"@bj-nsc/msn\";\r\nimport { utils } from \"@bj-nsc/msn/lib/utils\";\r\nimport { getIcon } from \"../utils\";\r\nimport omit from \"omit.js\";\r\n\r\ninterface IMenuProps extends MenuProps {\r\n  data?: Array<object>;\r\n  titleField?: string;\r\n  keyField?: string;\r\n  store?: StoreProps;\r\n}\r\nconst { SubMenu, Item, ItemGroup } = Menu;\r\n\r\nexport default class NSCMenu extends PureComponent<IMenuProps> {\r\n  static SubMenu = SubMenu;\r\n  static Item = Item;\r\n  static ItemGroup = ItemGroup;\r\n\r\n  state = {\r\n    dataSource: [],\r\n  };\r\n\r\n  store = {} as StoreProps;\r\n  static getDerivedStateFromProps(nextProps, prevState: any) {\r\n    const { dataSource } = prevState;\r\n    const { data } = nextProps;\r\n    if (data) {\r\n      if (JSON.stringify(dataSource) !== JSON.stringify(data)) {\r\n        return {\r\n          dataSource: data,\r\n        };\r\n      }\r\n    }\r\n    return null;\r\n  }\r\n  constructor(props) {\r\n    super(props);\r\n    const { data, store = {}, children } = props;\r\n    const { url, listeners: listenersPops = {}, viewname, ...stores } = store;\r\n    if (!children) {\r\n      if (!(data || url)) {\r\n        throw new Error(\"url、data不能都为空！\");\r\n      }\r\n      let _this = this;\r\n      let storeProps = {\r\n        model: \"model\",\r\n        component: this,\r\n        listeners: {\r\n          onBeforeLoad: function (store, options) {\r\n            utils.callback(listenersPops.onBeforeLoad, _this, [store, options]);\r\n          },\r\n          load: function (data, modelData, store) {\r\n            _this.setState({ dataSource: modelData });\r\n            utils.callback(listenersPops.load, _this, [data, modelData, store]);\r\n          },\r\n          dataChanged: function (data, modelData, store) {\r\n            _this.setState({ dataSource: modelData });\r\n            utils.callback(listenersPops.dataChanged, _this, [\r\n              data,\r\n              modelData,\r\n              store,\r\n            ]);\r\n          },\r\n        },\r\n        ...stores,\r\n      };\r\n      if (url && data == null) {\r\n        storeProps = {\r\n          ...{\r\n            autoLoad: true,\r\n            url: url, //读字典，url固定，viewname\r\n          },\r\n          ...storeProps,\r\n        };\r\n      }\r\n      this.store = new Store(storeProps);\r\n    }\r\n  }\r\n  componentDidMount() {\r\n    if (this.props.data) {\r\n      this.setState({\r\n        dataSource: this.props.data,\r\n      });\r\n    }\r\n  }\r\n  renderMenuItem = (menusData) => {\r\n    if (!menusData || !Array.isArray(menusData)) {\r\n      return [];\r\n    }\r\n    const { titleField = \"title\", keyField = \"key\" } = this.props;\r\n    return menusData.map((item) => {\r\n      const { style, icon, disabled } = item;\r\n      const spantitle = <span style={style}>{item[titleField]}</span>;\r\n      if (item[\"childNodes\"] || item[\"children\"]) {\r\n        let menuGroupData = {},\r\n          menuData = [];\r\n        let childData = item[\"childNodes\"] || item[\"children\"];\r\n        childData.map((item) => {\r\n          let gruoptitle = item.groupName;\r\n          if (gruoptitle) {\r\n            if (!menuGroupData[gruoptitle]) menuGroupData[gruoptitle] = [];\r\n            menuGroupData[gruoptitle].push(item);\r\n          } else {\r\n            menuData.push(item);\r\n          }\r\n        });\r\n        return (\r\n          <SubMenu\r\n            key={item[keyField]}\r\n            title={\r\n              icon ? (\r\n                <span>\r\n                  {getIcon(icon)}\r\n                  {spantitle}\r\n                </span>\r\n              ) : (\r\n                spantitle\r\n              )\r\n            }\r\n          >\r\n            {Object.keys(menuGroupData).map((key) => {\r\n              return (\r\n                <ItemGroup key={key} title={key}>\r\n                  {this.renderMenuItem(menuGroupData[key])}\r\n                </ItemGroup>\r\n              );\r\n            })}\r\n            {this.renderMenuItem(menuData)}\r\n          </SubMenu>\r\n        );\r\n      } else {\r\n        return (\r\n          <Menu.Item key={item[keyField]} disabled={disabled}>\r\n            {icon ? (\r\n              <span>\r\n                {getIcon(icon)}\r\n                {spantitle}\r\n              </span>\r\n            ) : (\r\n              spantitle\r\n            )}\r\n          </Menu.Item>\r\n        );\r\n      }\r\n    });\r\n  };\r\n  renderChildren = () => {\r\n    const { children } = this.props;\r\n    const { dataSource } = this.state;\r\n    if (children) {\r\n      return <>{children}</>;\r\n    } else {\r\n      return this.renderMenuItem(dataSource);\r\n    }\r\n  };\r\n\r\n  render() {\r\n    const menuProps = omit(this.props, [\r\n      \"data\",\r\n      \"store\",\r\n      \"titleField\",\r\n      \"keyField\",\r\n    ]);\r\n    return <Menu {...menuProps}>{this.renderChildren()}</Menu>;\r\n  }\r\n}\r\n"]}
|
package/lib/utils.d.ts
CHANGED
|
@@ -5,6 +5,7 @@ export declare function checkModel(checktype: any, value: any): any;
|
|
|
5
5
|
export declare function getCacheKey(sotre: any): any;
|
|
6
6
|
export declare function checkChars(value: string): boolean;
|
|
7
7
|
export declare function px2vw(pxValue: number, baseValue?: number): string;
|
|
8
|
+
export declare function getIcon(icon: any): any;
|
|
8
9
|
declare const _default: {
|
|
9
10
|
encryptValue: typeof encryptValue;
|
|
10
11
|
checkModel: typeof checkModel;
|
package/lib/utils.js
CHANGED
|
@@ -9,6 +9,9 @@ function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "functi
|
|
|
9
9
|
* @LastEditTime: 2021-04-22 17:14:04
|
|
10
10
|
*/
|
|
11
11
|
import { sm2EncryptValue, sm4Encrypt, base64Encrypt, md5Encrypt, checkValue, sm2DecryptValue, sm4Decrypt, base64Decrypt } from "@bj-nsc/functions";
|
|
12
|
+
import { isEmpty } from "lodash";
|
|
13
|
+
import IconFont from "./common/IconFont";
|
|
14
|
+
import React from "react";
|
|
12
15
|
export function encryptValue(encrypt, value) {
|
|
13
16
|
var encryptValue = value;
|
|
14
17
|
|
|
@@ -76,6 +79,16 @@ export function checkChars(value) {
|
|
|
76
79
|
export function px2vw(pxValue, baseValue) {
|
|
77
80
|
var baseWidth = baseValue || 1920;
|
|
78
81
|
return (pxValue * 100 / baseWidth).toFixed(4) + "vw";
|
|
82
|
+
} //获取Icon
|
|
83
|
+
|
|
84
|
+
export function getIcon(icon) {
|
|
85
|
+
if (!isEmpty(icon) && typeof icon === "string") {
|
|
86
|
+
return /*#__PURE__*/React.createElement(IconFont, {
|
|
87
|
+
type: icon
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
return icon;
|
|
79
92
|
}
|
|
80
93
|
export default {
|
|
81
94
|
encryptValue: encryptValue,
|
|
@@ -85,4 +98,4 @@ export default {
|
|
|
85
98
|
checkChars: checkChars,
|
|
86
99
|
px2vw: px2vw
|
|
87
100
|
};
|
|
88
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
101
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/components/utils.tsx"],"names":["sm2EncryptValue","sm4Encrypt","base64Encrypt","md5Encrypt","checkValue","sm2DecryptValue","sm4Decrypt","base64Decrypt","isEmpty","IconFont","React","encryptValue","encrypt","value","type","key","decryptValue","decrypt","checkModel","checktype","getCacheKey","sotre","viewname","requestConfig","url","JSON","stringify","checkChars","reg","test","px2vw","pxValue","baseValue","baseWidth","toFixed","getIcon","icon"],"mappings":"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","sourcesContent":["/*\r\n * @Descripttion:\r\n * @version:\r\n * @Author: rxzhu\r\n * @Date: 2021-04-12 17:32:53\r\n * @LastEditors: rxzhu\r\n * @LastEditTime: 2021-04-22 17:14:04\r\n */\r\nimport {\r\n  sm2EncryptValue,\r\n  sm4Encrypt,\r\n  base64Encrypt,\r\n  md5Encrypt,\r\n  checkValue,\r\n  sm2DecryptValue,\r\n  sm4Decrypt,\r\n  base64Decrypt,\r\n} from \"@bj-nsc/functions\";\r\nimport { encrypt } from \"./Interface\";\r\nimport { isEmpty } from \"lodash\";\r\nimport IconFont from \"./common/IconFont\";\r\nimport React from \"react\";\r\n\r\nexport function encryptValue(encrypt: encrypt | boolean, value) {\r\n  let encryptValue = value;\r\n  if (encrypt && typeof encrypt === \"object\") {\r\n    const { type, key } = encrypt;\r\n    if (type == \"sm2\") {\r\n      encryptValue = key ? sm2EncryptValue(value, key) : sm2EncryptValue(value);\r\n    } else if (type == \"sm4\") {\r\n      encryptValue = sm4Encrypt(value);\r\n    } else if (type == \"base64\") {\r\n      encryptValue = base64Encrypt(value);\r\n    } else if (type == \"md5\") {\r\n      encryptValue = md5Encrypt(value);\r\n    }\r\n  } else if (encrypt && typeof encrypt === \"boolean\") {\r\n    encryptValue = sm2EncryptValue(value);\r\n  }\r\n  return encryptValue;\r\n}\r\nexport function decryptValue(decrypt: encrypt | boolean, value) {\r\n  let decryptValue = value;\r\n  if (decrypt && typeof decrypt === \"object\") {\r\n    const { type, key } = decrypt;\r\n    if (type == \"sm2\") {\r\n      decryptValue = key ? sm2DecryptValue(value, key) : sm2DecryptValue(value);\r\n    } else if (type == \"sm4\") {\r\n      decryptValue = sm4Decrypt(value);\r\n    } else if (type == \"base64\") {\r\n      decryptValue = base64Decrypt(value);\r\n    }\r\n  } else if (decrypt && typeof decrypt === \"boolean\") {\r\n    decryptValue = sm2DecryptValue(value);\r\n  }\r\n  return decryptValue;\r\n}\r\nexport function checkModel(checktype, value) {\r\n  return checkValue(value, checktype);\r\n}\r\n\r\nexport function getCacheKey(sotre) {\r\n  const { viewname, requestConfig, url } = sotre;\r\n  let key;\r\n  if (viewname) {\r\n    key = viewname;\r\n  } else {\r\n    key = requestConfig ? url + JSON.stringify(requestConfig) : url;\r\n  }\r\n  return key;\r\n}\r\n\r\nexport function checkChars(value: string) {\r\n  const reg = /^[0-9a-zA-Z\\u4E00-\\u9FA5\\uF900-\\uFA2D]*$/;\r\n  return reg.test(value);\r\n}\r\n\r\n// 转换px到vw\r\nexport function px2vw(pxValue: number, baseValue?: number): string {\r\n  const baseWidth = baseValue || 1920;\r\n  return ((pxValue * 100) / baseWidth).toFixed(4) + \"vw\";\r\n}\r\n\r\n//获取Icon\r\nexport function getIcon(icon) {\r\n  if (!isEmpty(icon) && typeof icon === \"string\") {\r\n    return <IconFont type={icon} />;\r\n  }\r\n  return icon;\r\n}\r\nexport default {\r\n  encryptValue,\r\n  checkModel,\r\n  decryptValue,\r\n  getCacheKey,\r\n  checkChars,\r\n  px2vw,\r\n};\r\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "nsc-react-component",
|
|
3
|
-
"version": "1.1.
|
|
3
|
+
"version": "1.1.4",
|
|
4
4
|
"description": "",
|
|
5
5
|
"main": "lib/index.js",
|
|
6
6
|
"scripts": {
|
|
@@ -61,7 +61,7 @@
|
|
|
61
61
|
"@babel/runtime": "^7.13.17",
|
|
62
62
|
"@babel/runtime-corejs3": "^7.13.17",
|
|
63
63
|
"@bj-nsc/functions": "^1.2.14",
|
|
64
|
-
"@bj-nsc/msn": "^1.0.
|
|
64
|
+
"@bj-nsc/msn": "^1.0.11",
|
|
65
65
|
"classnames": "^2.2.6",
|
|
66
66
|
"clone-deep": "^4.0.1",
|
|
67
67
|
"core-js": "3",
|