nsc-react-component 2.7.11 → 2.8.0
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/upload/index.d.ts +1 -0
- package/lib/base/upload/index.js +134 -61
- package/lib/index.d.ts +1 -0
- package/lib/index.js +2 -1
- package/lib/page/BasePage/index.d.ts +1 -1
- package/lib/page/BasePage/index.js +25 -153
- package/lib/page/BasePage/index.module.less +3 -41
- package/lib/page/HeaderSearch/index.d.ts +19 -0
- package/lib/page/HeaderSearch/index.js +243 -0
- package/lib/page/HeaderSearch/index.less +44 -0
- package/package.json +1 -1
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
border-radius: 10px;
|
|
6
6
|
.page-title {
|
|
7
7
|
padding: 20px 20px 0px 20px;
|
|
8
|
-
font-size:
|
|
8
|
+
font-size: 24px;
|
|
9
9
|
font-family: PingFangSC-Semibold, PingFang SC;
|
|
10
10
|
font-weight: 600;
|
|
11
11
|
color: #333333;
|
|
@@ -31,50 +31,12 @@
|
|
|
31
31
|
box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 10%);
|
|
32
32
|
padding: 0 20px 0px 20px;
|
|
33
33
|
border-radius: 10px;
|
|
34
|
-
.header {
|
|
35
|
-
display: flex;
|
|
36
|
-
margin-top: 20px;
|
|
37
|
-
width: 100%;
|
|
38
|
-
.form {
|
|
39
|
-
width: 100%;
|
|
40
|
-
// :global {
|
|
41
|
-
// .ant-form-inline {
|
|
42
|
-
// max-width: 61vw !important;
|
|
43
|
-
// }
|
|
44
|
-
// }
|
|
45
|
-
}
|
|
46
|
-
:global {
|
|
47
|
-
// .ant-form-inline {
|
|
48
|
-
// max-width: 46vw;
|
|
49
|
-
// }
|
|
50
|
-
.ant-form-inline .ant-form-item {
|
|
51
|
-
margin-right: 0px;
|
|
52
|
-
margin-bottom: 10px;
|
|
53
|
-
// width: 200px;
|
|
54
|
-
}
|
|
55
|
-
.ant-select {
|
|
56
|
-
width: 100% !important;
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
.search-buttons {
|
|
61
|
-
display: flex;
|
|
62
|
-
margin-bottom: 10px;
|
|
63
|
-
// margin-top: 20px;
|
|
64
|
-
.margin {
|
|
65
|
-
margin-left: 20px;
|
|
66
|
-
}
|
|
67
|
-
button {
|
|
68
|
-
margin-right: 12px;
|
|
69
|
-
min-width: 80px;
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
34
|
.tool-buttons {
|
|
73
35
|
display: flex;
|
|
74
36
|
// margin-top: 20px;
|
|
75
37
|
flex-wrap: wrap;
|
|
76
38
|
width: calc(100% - 200px);
|
|
77
|
-
margin-bottom:
|
|
39
|
+
margin-bottom: 16px;
|
|
78
40
|
button {
|
|
79
41
|
margin-right: 12px;
|
|
80
42
|
min-width: 80px;
|
|
@@ -138,7 +100,7 @@
|
|
|
138
100
|
.editor:hover {
|
|
139
101
|
color: var(--ant-primary-5);
|
|
140
102
|
}
|
|
141
|
-
.editor_first{
|
|
103
|
+
.editor_first {
|
|
142
104
|
margin-left: 0;
|
|
143
105
|
}
|
|
144
106
|
.content-item {
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import React, { PureComponent } from "react";
|
|
2
|
+
interface SearchProps {
|
|
3
|
+
searchForms: Array<any>;
|
|
4
|
+
toolButtonPosition?: string;
|
|
5
|
+
onSearch?: any;
|
|
6
|
+
}
|
|
7
|
+
declare class HeaderSearch extends PureComponent<SearchProps, any> {
|
|
8
|
+
searchRef: React.RefObject<any>;
|
|
9
|
+
dateFormat: any;
|
|
10
|
+
state: {
|
|
11
|
+
expand: boolean;
|
|
12
|
+
};
|
|
13
|
+
setSearchParams(params: any, callBack: any): void;
|
|
14
|
+
getSearchValues(): any;
|
|
15
|
+
onSearch(): void;
|
|
16
|
+
resetSearch(): void;
|
|
17
|
+
render(): JSX.Element;
|
|
18
|
+
}
|
|
19
|
+
export default HeaderSearch;
|
|
@@ -0,0 +1,243 @@
|
|
|
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
|
+
|
|
3
|
+
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; }
|
|
4
|
+
|
|
5
|
+
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; }
|
|
6
|
+
|
|
7
|
+
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|
8
|
+
|
|
9
|
+
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); } }
|
|
10
|
+
|
|
11
|
+
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
|
|
12
|
+
|
|
13
|
+
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
|
|
14
|
+
|
|
15
|
+
function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
|
|
16
|
+
|
|
17
|
+
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
18
|
+
|
|
19
|
+
function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
|
|
20
|
+
|
|
21
|
+
function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
|
22
|
+
|
|
23
|
+
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
24
|
+
|
|
25
|
+
function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
|
26
|
+
|
|
27
|
+
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; }
|
|
28
|
+
|
|
29
|
+
import React, { PureComponent } from "react";
|
|
30
|
+
import Form from "../../base/form";
|
|
31
|
+
import Button from "../../base/button";
|
|
32
|
+
import cls from "classnames";
|
|
33
|
+
import styles from "./index.less";
|
|
34
|
+
import Col from "../../base/grid/Col";
|
|
35
|
+
import Row from "../../base/grid/Row";
|
|
36
|
+
import moment from "moment";
|
|
37
|
+
import { isEmptyObj } from "@bj-nsc/functions";
|
|
38
|
+
import { DownOutlined, UpOutlined, ReloadOutlined, SearchOutlined } from "@ant-design/icons";
|
|
39
|
+
import { getLess, getNode } from "../../utils";
|
|
40
|
+
|
|
41
|
+
var HeaderSearch = /*#__PURE__*/function (_PureComponent) {
|
|
42
|
+
_inherits(HeaderSearch, _PureComponent);
|
|
43
|
+
|
|
44
|
+
var _super = _createSuper(HeaderSearch);
|
|
45
|
+
|
|
46
|
+
function HeaderSearch() {
|
|
47
|
+
var _this;
|
|
48
|
+
|
|
49
|
+
_classCallCheck(this, HeaderSearch);
|
|
50
|
+
|
|
51
|
+
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
52
|
+
args[_key] = arguments[_key];
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
_this = _super.call.apply(_super, [this].concat(args));
|
|
56
|
+
|
|
57
|
+
_defineProperty(_assertThisInitialized(_this), "searchRef", /*#__PURE__*/React.createRef());
|
|
58
|
+
|
|
59
|
+
_defineProperty(_assertThisInitialized(_this), "dateFormat", {});
|
|
60
|
+
|
|
61
|
+
_defineProperty(_assertThisInitialized(_this), "state", {
|
|
62
|
+
expand: false
|
|
63
|
+
});
|
|
64
|
+
|
|
65
|
+
return _this;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
_createClass(HeaderSearch, [{
|
|
69
|
+
key: "setSearchParams",
|
|
70
|
+
value: function setSearchParams(params, callBack) {
|
|
71
|
+
var _this$searchRef$curre;
|
|
72
|
+
|
|
73
|
+
(_this$searchRef$curre = this.searchRef.current) === null || _this$searchRef$curre === void 0 ? void 0 : _this$searchRef$curre.setFieldsValue(params);
|
|
74
|
+
callBack && callBack(params);
|
|
75
|
+
}
|
|
76
|
+
}, {
|
|
77
|
+
key: "getSearchValues",
|
|
78
|
+
value: function getSearchValues() {
|
|
79
|
+
var _this$searchRef$curre2;
|
|
80
|
+
|
|
81
|
+
var fromValue = (_this$searchRef$curre2 = this.searchRef.current) === null || _this$searchRef$curre2 === void 0 ? void 0 : _this$searchRef$curre2.getFieldsValue();
|
|
82
|
+
return fromValue;
|
|
83
|
+
}
|
|
84
|
+
}, {
|
|
85
|
+
key: "onSearch",
|
|
86
|
+
value: function onSearch() {
|
|
87
|
+
var _this$searchRef$curre3;
|
|
88
|
+
|
|
89
|
+
var onSearch = this.props.onSearch;
|
|
90
|
+
var fromValue = (_this$searchRef$curre3 = this.searchRef.current) === null || _this$searchRef$curre3 === void 0 ? void 0 : _this$searchRef$curre3.getFieldsValue();
|
|
91
|
+
|
|
92
|
+
if (onSearch) {
|
|
93
|
+
onSearch(fromValue);
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
if (!isEmptyObj(this.dateFormat)) {
|
|
98
|
+
for (var key in this.dateFormat) {
|
|
99
|
+
var olddata = fromValue[key];
|
|
100
|
+
|
|
101
|
+
if (Array.isArray(olddata)) {
|
|
102
|
+
fromValue[key] = [moment(olddata[0]).format(this.dateFormat[key]), moment(olddata[1]).format(this.dateFormat[key])];
|
|
103
|
+
} else {
|
|
104
|
+
fromValue[key] = moment(olddata).format(this.dateFormat[key]);
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
}, {
|
|
110
|
+
key: "resetSearch",
|
|
111
|
+
value: function resetSearch() {
|
|
112
|
+
var _this$searchRef$curre4;
|
|
113
|
+
|
|
114
|
+
(_this$searchRef$curre4 = this.searchRef.current) === null || _this$searchRef$curre4 === void 0 ? void 0 : _this$searchRef$curre4.resetFields();
|
|
115
|
+
}
|
|
116
|
+
}, {
|
|
117
|
+
key: "render",
|
|
118
|
+
value: function render() {
|
|
119
|
+
var _this2 = this;
|
|
120
|
+
|
|
121
|
+
var _this$props = this.props,
|
|
122
|
+
_this$props$searchFor = _this$props.searchForms,
|
|
123
|
+
searchForms = _this$props$searchFor === void 0 ? [] : _this$props$searchFor,
|
|
124
|
+
toolButtonPosition = _this$props.toolButtonPosition,
|
|
125
|
+
onSearch = _this$props.onSearch;
|
|
126
|
+
var colSpan = 0;
|
|
127
|
+
var headerCount = toolButtonPosition == "right" ? 1 : 2;
|
|
128
|
+
var headerRout = searchForms.length % 4;
|
|
129
|
+
console.log("headerRout", headerRout);
|
|
130
|
+
|
|
131
|
+
if (headerRout == 0) {
|
|
132
|
+
colSpan = 18;
|
|
133
|
+
} else if (headerRout == 1) {
|
|
134
|
+
colSpan = 12;
|
|
135
|
+
} else if (headerRout == 2) {
|
|
136
|
+
colSpan = 6;
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
return /*#__PURE__*/React.createElement(Row, {
|
|
140
|
+
gutter: 24,
|
|
141
|
+
wrap: true
|
|
142
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
143
|
+
className: getLess(styles, "header")
|
|
144
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
145
|
+
className: cls(getLess(styles, "form"))
|
|
146
|
+
}, /*#__PURE__*/React.createElement(Form, {
|
|
147
|
+
ref: this.searchRef,
|
|
148
|
+
labelCol: {},
|
|
149
|
+
wrapperCol: {},
|
|
150
|
+
layout: "inline",
|
|
151
|
+
style: {
|
|
152
|
+
width: "100%"
|
|
153
|
+
}
|
|
154
|
+
}, searchForms.map(function (item, index) {
|
|
155
|
+
var _item$props;
|
|
156
|
+
|
|
157
|
+
var itemProps = item.props || {};
|
|
158
|
+
|
|
159
|
+
if (itemProps.valueFormat) {
|
|
160
|
+
_this2.dateFormat[item.name] = itemProps.valueFormat;
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
if (index > headerCount && !_this2.state.expand) {
|
|
164
|
+
return;
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
var allowChars = (item === null || item === void 0 ? void 0 : (_item$props = item.props) === null || _item$props === void 0 ? void 0 : _item$props.allowChars) || false;
|
|
168
|
+
|
|
169
|
+
var props = _objectSpread({}, itemProps);
|
|
170
|
+
|
|
171
|
+
if (!item.type || item.type == "Input") {
|
|
172
|
+
props.allowChars = true;
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
return /*#__PURE__*/React.createElement(Col, {
|
|
176
|
+
md: {
|
|
177
|
+
span: 12
|
|
178
|
+
},
|
|
179
|
+
sm: {
|
|
180
|
+
span: 24
|
|
181
|
+
},
|
|
182
|
+
lg: {
|
|
183
|
+
span: 6
|
|
184
|
+
},
|
|
185
|
+
key: index,
|
|
186
|
+
style: {
|
|
187
|
+
paddingRight: 0
|
|
188
|
+
}
|
|
189
|
+
}, /*#__PURE__*/React.createElement(Form.Item, {
|
|
190
|
+
label: item.label,
|
|
191
|
+
name: item.name,
|
|
192
|
+
allowChars: allowChars
|
|
193
|
+
}, getNode(item.type, _objectSpread({
|
|
194
|
+
placeholder: "\u8BF7\u8F93\u5165".concat(item.label)
|
|
195
|
+
}, props))));
|
|
196
|
+
}), /*#__PURE__*/React.createElement(Col, {
|
|
197
|
+
md: {
|
|
198
|
+
span: 12
|
|
199
|
+
},
|
|
200
|
+
sm: {
|
|
201
|
+
span: 24
|
|
202
|
+
},
|
|
203
|
+
lg: {
|
|
204
|
+
span: toolButtonPosition == "right" ? 12 : 6
|
|
205
|
+
},
|
|
206
|
+
style: {
|
|
207
|
+
paddingRight: 0
|
|
208
|
+
},
|
|
209
|
+
offset: (this.state.expand || searchForms.length < 4) && searchForms.length > 1 ? colSpan : 0
|
|
210
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
211
|
+
className: cls(getLess(styles, "search-buttons"), _defineProperty({}, getLess(styles, "search-buttons-flex"), searchForms.length > 1)),
|
|
212
|
+
style: {
|
|
213
|
+
marginTop: 0
|
|
214
|
+
}
|
|
215
|
+
}, /*#__PURE__*/React.createElement(Button, {
|
|
216
|
+
type: "primary",
|
|
217
|
+
onClick: this.onSearch.bind(this),
|
|
218
|
+
icon: /*#__PURE__*/React.createElement(SearchOutlined, null),
|
|
219
|
+
style: {
|
|
220
|
+
marginLeft: 0
|
|
221
|
+
}
|
|
222
|
+
}, "\u67E5\u8BE2"), searchForms.length > 1 && /*#__PURE__*/React.createElement(Button // type={"primary"}
|
|
223
|
+
, {
|
|
224
|
+
onClick: this.resetSearch.bind(this),
|
|
225
|
+
icon: /*#__PURE__*/React.createElement(ReloadOutlined, null)
|
|
226
|
+
}, "\u91CD\u7F6E"), searchForms.length > 3 && /*#__PURE__*/React.createElement("div", {
|
|
227
|
+
className: getLess(styles, "a_style"),
|
|
228
|
+
onClick: function onClick() {
|
|
229
|
+
var expand = _this2.state.expand;
|
|
230
|
+
|
|
231
|
+
_this2.setState({
|
|
232
|
+
expand: !expand
|
|
233
|
+
});
|
|
234
|
+
}
|
|
235
|
+
}, this.state.expand ? "收起" : "展开", this.state.expand ? /*#__PURE__*/React.createElement(UpOutlined, null) : /*#__PURE__*/React.createElement(DownOutlined, null))))))));
|
|
236
|
+
}
|
|
237
|
+
}]);
|
|
238
|
+
|
|
239
|
+
return HeaderSearch;
|
|
240
|
+
}(PureComponent);
|
|
241
|
+
|
|
242
|
+
export default HeaderSearch;
|
|
243
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/page/HeaderSearch/index.tsx"],"names":["React","PureComponent","Form","Button","cls","styles","Col","Row","moment","isEmptyObj","DownOutlined","UpOutlined","ReloadOutlined","SearchOutlined","getLess","getNode","HeaderSearch","createRef","expand","params","callBack","searchRef","current","setFieldsValue","fromValue","getFieldsValue","onSearch","props","dateFormat","key","olddata","Array","isArray","format","resetFields","searchForms","toolButtonPosition","colSpan","headerCount","headerRout","length","console","log","width","map","item","index","itemProps","valueFormat","name","state","allowChars","type","span","paddingRight","label","placeholder","marginTop","bind","marginLeft","resetSearch","setState"],"mappings":"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","sourcesContent":["import React, { PureComponent, ReactNode } from \"react\";\r\nimport Form from \"../../base/form\";\r\nimport Button from \"../../base/button\";\r\nimport cls from \"classnames\";\r\nimport styles from \"./index.less\";\r\nimport Col from \"../../base/grid/Col\";\r\nimport Row from \"../../base/grid/Row\";\r\nimport moment from \"moment\";\r\nimport { isEmptyObj } from \"@bj-nsc/functions\";\r\nimport {\r\n  DownOutlined,\r\n  UpOutlined,\r\n  ReloadOutlined,\r\n  SearchOutlined,\r\n} from \"@ant-design/icons\";\r\nimport { getLess, getNode } from \"../../utils\";\r\n\r\ninterface SearchProps {\r\n  searchForms: Array<any>; //是否显示操作列\r\n  toolButtonPosition?: string;\r\n  onSearch?: any;\r\n}\r\n\r\nclass HeaderSearch extends PureComponent<SearchProps, any> {\r\n  searchRef = React.createRef<any>();\r\n  dateFormat = {} as any;\r\n  state = { expand: false };\r\n  setSearchParams(params, callBack) {\r\n    this.searchRef.current?.setFieldsValue(params);\r\n    callBack && callBack(params);\r\n  }\r\n  getSearchValues() {\r\n    const fromValue = this.searchRef.current?.getFieldsValue();\r\n    return fromValue;\r\n  }\r\n  onSearch() {\r\n    const { onSearch } = this.props;\r\n    const fromValue = this.searchRef.current?.getFieldsValue();\r\n    if (onSearch) {\r\n      onSearch(fromValue);\r\n      return;\r\n    }\r\n    if (!isEmptyObj(this.dateFormat)) {\r\n      for (let key in this.dateFormat) {\r\n        let olddata = fromValue[key];\r\n        if (Array.isArray(olddata)) {\r\n          fromValue[key] = [\r\n            moment(olddata[0]).format(this.dateFormat[key]),\r\n            moment(olddata[1]).format(this.dateFormat[key]),\r\n          ];\r\n        } else {\r\n          fromValue[key] = moment(olddata).format(this.dateFormat[key]);\r\n        }\r\n      }\r\n    }\r\n  }\r\n  resetSearch() {\r\n    this.searchRef.current?.resetFields();\r\n  }\r\n  render() {\r\n    const { searchForms = [], toolButtonPosition, onSearch } = this.props;\r\n\r\n    let colSpan = 0;\r\n    const headerCount = toolButtonPosition == \"right\" ? 1 : 2;\r\n    const headerRout = searchForms.length % 4;\r\n    console.log(\"headerRout\", headerRout);\r\n    if (headerRout == 0) {\r\n      colSpan = 18;\r\n    } else if (headerRout == 1) {\r\n      colSpan = 12;\r\n    } else if (headerRout == 2) {\r\n      colSpan = 6;\r\n    }\r\n\r\n    return (\r\n      <Row gutter={24} wrap>\r\n        <div className={getLess(styles, \"header\")}>\r\n          <div className={cls(getLess(styles, \"form\"))}>\r\n            <Form\r\n              ref={this.searchRef}\r\n              labelCol={{}}\r\n              wrapperCol={{}}\r\n              layout=\"inline\"\r\n              style={{ width: \"100%\" }}\r\n            >\r\n              {searchForms.map((item: any, index: any) => {\r\n                const itemProps = item.props || {};\r\n                if (itemProps.valueFormat) {\r\n                  this.dateFormat[item.name] = itemProps.valueFormat;\r\n                }\r\n                if (index > headerCount && !this.state.expand) {\r\n                  return;\r\n                }\r\n                let allowChars = item?.props?.allowChars || false;\r\n                let props = { ...itemProps };\r\n                if (!item.type || item.type == \"Input\") {\r\n                  props.allowChars = true;\r\n                }\r\n                return (\r\n                  <Col\r\n                    md={{ span: 12 }}\r\n                    sm={{ span: 24 }}\r\n                    lg={{ span: 6 }}\r\n                    key={index}\r\n                    style={{ paddingRight: 0 }}\r\n                  >\r\n                    <Form.Item\r\n                      label={item.label}\r\n                      name={item.name}\r\n                      allowChars={allowChars}\r\n                    >\r\n                      {getNode(item.type, {\r\n                        placeholder: `请输入${item.label}`,\r\n                        ...props,\r\n                      })}\r\n                    </Form.Item>\r\n                  </Col>\r\n                );\r\n              })}\r\n              <Col\r\n                md={{ span: 12 }}\r\n                sm={{ span: 24 }}\r\n                lg={{ span: toolButtonPosition == \"right\" ? 12 : 6 }}\r\n                style={{ paddingRight: 0 }}\r\n                offset={\r\n                  (this.state.expand || searchForms.length < 4) &&\r\n                  searchForms.length > 1\r\n                    ? colSpan\r\n                    : 0\r\n                }\r\n              >\r\n                <div\r\n                  className={cls(getLess(styles, \"search-buttons\"), {\r\n                    [getLess(styles, \"search-buttons-flex\")]:\r\n                      searchForms.length > 1,\r\n                  })}\r\n                  style={{ marginTop: 0 }}\r\n                >\r\n                  <Button\r\n                    type={\"primary\"}\r\n                    onClick={this.onSearch.bind(this)}\r\n                    icon={<SearchOutlined />}\r\n                    style={{ marginLeft: 0 }}\r\n                  >\r\n                    查询\r\n                  </Button>\r\n                  {searchForms.length > 1 && (\r\n                    <Button\r\n                      // type={\"primary\"}\r\n                      onClick={this.resetSearch.bind(this)}\r\n                      icon={<ReloadOutlined />}\r\n                    >\r\n                      重置\r\n                    </Button>\r\n                  )}\r\n                  {searchForms.length > 3 && (\r\n                    <div\r\n                      className={getLess(styles, \"a_style\")}\r\n                      onClick={() => {\r\n                        const { expand } = this.state;\r\n                        this.setState({\r\n                          expand: !expand,\r\n                        });\r\n                      }}\r\n                    >\r\n                      {this.state.expand ? \"收起\" : \"展开\"}\r\n                      {this.state.expand ? <UpOutlined /> : <DownOutlined />}\r\n                    </div>\r\n                  )}\r\n                </div>\r\n              </Col>\r\n            </Form>\r\n          </div>\r\n        </div>\r\n      </Row>\r\n    );\r\n  }\r\n}\r\nexport default HeaderSearch;\r\n"]}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
.header {
|
|
2
|
+
display: flex;
|
|
3
|
+
margin-top: 20px;
|
|
4
|
+
width: 100%;
|
|
5
|
+
.form {
|
|
6
|
+
width: 100%;
|
|
7
|
+
// :global {
|
|
8
|
+
// .ant-form-inline {
|
|
9
|
+
// max-width: 61vw !important;
|
|
10
|
+
// }
|
|
11
|
+
// }
|
|
12
|
+
}
|
|
13
|
+
:global {
|
|
14
|
+
// .ant-form-inline {
|
|
15
|
+
// max-width: 46vw;
|
|
16
|
+
// }
|
|
17
|
+
.ant-form-inline .ant-form-item {
|
|
18
|
+
margin-right: 0px;
|
|
19
|
+
margin-bottom: 16px;
|
|
20
|
+
margin-right: 24px;
|
|
21
|
+
// width: 200px;
|
|
22
|
+
}
|
|
23
|
+
.ant-select {
|
|
24
|
+
width: 100% !important;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
.search-buttons {
|
|
29
|
+
display: flex;
|
|
30
|
+
margin-bottom: 16px;
|
|
31
|
+
// margin-top: 20px;
|
|
32
|
+
|
|
33
|
+
margin-right: 24px;
|
|
34
|
+
.margin {
|
|
35
|
+
margin-left: 20px;
|
|
36
|
+
}
|
|
37
|
+
button {
|
|
38
|
+
margin-right: 12px;
|
|
39
|
+
min-width: 80px;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
.search-buttons-flex {
|
|
43
|
+
justify-content: flex-end;
|
|
44
|
+
}
|