@bit-sun/business-component 4.2.0-alpha.23 → 4.2.0-alpha.24

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/dist/index.esm.js CHANGED
@@ -39208,12 +39208,24 @@ var RuleObjectComponent = /*#__PURE__*/function (_Component) {
39208
39208
  padding: '10px',
39209
39209
  borderRadius: '4px'
39210
39210
  }
39211
- }, /*#__PURE__*/React$1.createElement("span", {
39211
+ }, /*#__PURE__*/React$1.createElement(Select, {
39212
+ disabled: disabled,
39212
39213
  style: {
39213
- marginRight: 8,
39214
- flexShrink: 0
39215
- }
39216
- }, "\u8BF7\u6C42\u53C2\u6570\u540D\u79F0:"), /*#__PURE__*/React$1.createElement(Input, {
39214
+ width: 150,
39215
+ marginRight: 10
39216
+ },
39217
+ placeholder: "\u8BF7\u9009\u62E9",
39218
+ value: String(itemDetail.reqConditionData.reqParamType || '10'),
39219
+ onChange: function onChange(val) {
39220
+ return _this.handleReqDataChange(itemDetail, 'reqParamType', val);
39221
+ }
39222
+ }, /*#__PURE__*/React$1.createElement(Select.Option, {
39223
+ value: "10"
39224
+ }, "\u8BF7\u6C42\u53C2\u6570\u540D\u79F0"), /*#__PURE__*/React$1.createElement(Select.Option, {
39225
+ value: "20"
39226
+ }, "\u8BF7\u6C42\u5934\u53C2\u6570\u540D\u79F0"), /*#__PURE__*/React$1.createElement(Select.Option, {
39227
+ value: "40"
39228
+ }, "\u6E90\u8BF7\u6C42\u5730\u5740")), String(itemDetail.reqConditionData.reqParamType || '10') !== '40' && /*#__PURE__*/React$1.createElement(Input, {
39217
39229
  disabled: disabled,
39218
39230
  style: {
39219
39231
  width: 150,
@@ -39769,6 +39781,8 @@ var RuleObjectComponent = /*#__PURE__*/function (_Component) {
39769
39781
  if (valueNames) {
39770
39782
  itemDetail.reqConditionData.paramNames = valueNames;
39771
39783
  }
39784
+ } else if (field === 'reqParamType') {
39785
+ itemDetail.reqConditionData.reqParamType = value;
39772
39786
  }
39773
39787
  _this.setState({
39774
39788
  ruleClassData: ruleClassData
package/dist/index.js CHANGED
@@ -39231,12 +39231,24 @@ var RuleObjectComponent = /*#__PURE__*/function (_Component) {
39231
39231
  padding: '10px',
39232
39232
  borderRadius: '4px'
39233
39233
  }
39234
- }, /*#__PURE__*/React__default['default'].createElement("span", {
39234
+ }, /*#__PURE__*/React__default['default'].createElement(antd.Select, {
39235
+ disabled: disabled,
39235
39236
  style: {
39236
- marginRight: 8,
39237
- flexShrink: 0
39238
- }
39239
- }, "\u8BF7\u6C42\u53C2\u6570\u540D\u79F0:"), /*#__PURE__*/React__default['default'].createElement(antd.Input, {
39237
+ width: 150,
39238
+ marginRight: 10
39239
+ },
39240
+ placeholder: "\u8BF7\u9009\u62E9",
39241
+ value: String(itemDetail.reqConditionData.reqParamType || '10'),
39242
+ onChange: function onChange(val) {
39243
+ return _this.handleReqDataChange(itemDetail, 'reqParamType', val);
39244
+ }
39245
+ }, /*#__PURE__*/React__default['default'].createElement(antd.Select.Option, {
39246
+ value: "10"
39247
+ }, "\u8BF7\u6C42\u53C2\u6570\u540D\u79F0"), /*#__PURE__*/React__default['default'].createElement(antd.Select.Option, {
39248
+ value: "20"
39249
+ }, "\u8BF7\u6C42\u5934\u53C2\u6570\u540D\u79F0"), /*#__PURE__*/React__default['default'].createElement(antd.Select.Option, {
39250
+ value: "40"
39251
+ }, "\u6E90\u8BF7\u6C42\u5730\u5740")), String(itemDetail.reqConditionData.reqParamType || '10') !== '40' && /*#__PURE__*/React__default['default'].createElement(antd.Input, {
39240
39252
  disabled: disabled,
39241
39253
  style: {
39242
39254
  width: 150,
@@ -39792,6 +39804,8 @@ var RuleObjectComponent = /*#__PURE__*/function (_Component) {
39792
39804
  if (valueNames) {
39793
39805
  itemDetail.reqConditionData.paramNames = valueNames;
39794
39806
  }
39807
+ } else if (field === 'reqParamType') {
39808
+ itemDetail.reqConditionData.reqParamType = value;
39795
39809
  }
39796
39810
  _this.setState({
39797
39811
  ruleClassData: ruleClassData
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@bit-sun/business-component",
3
- "version": "4.2.0-alpha.23",
3
+ "version": "4.2.0-alpha.24",
4
4
  "scripts": {
5
5
  "start": "dumi dev",
6
6
  "docs:build": "dumi build",
@@ -0,0 +1,187 @@
1
+ # RuleObjectComponent 规则组件
2
+
3
+ ## 简介
4
+ `RuleObjectComponent` 是一个功能强大的规则构建器组件,支持可视化的条件组合(并且/或者逻辑嵌套)、动态参数插入、执行动作配置以及返回值配置。它广泛应用于需要灵活定义业务规则的场景。
5
+
6
+ ## 组件路径
7
+ `src/components/Solution/RuleComponent/index.js`
8
+
9
+ ## Props 属性说明
10
+
11
+ | 属性名 | 类型 | 必填 | 说明 |
12
+ |Ref | --- | --- | --- |
13
+ | regularDataList | `Array` | 是 | 规则左侧“对象”选择树的数据源。 |
14
+ | operationList | `Array` | 是 | 规则中间“操作符”下拉列表的数据源。 |
15
+ | ruleClassData | `Array` | 是 | 规则组件的核心数据模型,用于回显和存储规则配置。 |
16
+ | callBack | `Function` | 是 | 数据变更时的回调函数,返回最新的 `ruleClassData`。 |
17
+ | systemVariableList | `Array` | 否 | “插入参数”功能的数据源,允许用户选择系统变量而非固定值。 |
18
+ | initialThresholdQuery | `Object` | 否 | 用于获取规则值域(右侧输入框/选择框)的初始查询参数。 |
19
+ | ruleGroupInfo | `Object` | 否 | 规则组信息,用于规则组实例场景。 |
20
+ | ruleTypeData | `Array` | 否 | “动作”配置的数据源。 |
21
+ | ruleReturnConfig | `Array` | 否 | “返回值”配置的数据源。 |
22
+ | disabled | `Boolean` | 否 | 是否禁用(只读模式)。 |
23
+ | canDelete | `Boolean` | 否 | 是否显示删除规则按钮。 |
24
+ | onlyOneRule | `Boolean` | 否 | 是否限制为单条规则(不显示新增规则按钮)。 |
25
+ | onlyCondition | `Boolean` | 否 | 是否仅展示条件部分(隐藏动作和返回值)。 |
26
+ | onlyAction | `Boolean` | 否 | 是否仅展示动作部分。 |
27
+ | needShowInsertSQL | `Boolean` | 否 | 是否显示“插入SQL”功能按钮。 |
28
+ | headerButtonComponentFun | `Function` | 否 | 自定义头部按钮渲染函数。 |
29
+
30
+ ## 数据结构示例
31
+
32
+ ### ruleClassData 结构
33
+ ```json
34
+ [
35
+ {
36
+ "ruleName": "规则1",
37
+ "subExpression": [
38
+ {
39
+ "operationType": "logic", // logic 或 relation
40
+ "operationCode": "and", // logic时为 and/or
41
+ "subExpression": [ ... ] // 嵌套子条件
42
+ },
43
+ {
44
+ "operationType": "relation",
45
+ "elementId": "...", // 左侧对象ID
46
+ "operationCode": "...", // 操作符
47
+ "params": ["..."], // 右侧值
48
+ // 新增参数条件控制
49
+ "isReqCondition": true,
50
+ "reqConditionData": {
51
+ "reqParamName": "param1",
52
+ "dataTypeCode": "21",
53
+ "operationCode": "eq",
54
+ "params": ["value"]
55
+ }
56
+ }
57
+ ],
58
+ "extraInfo": {
59
+ "execute": [], // 动作
60
+ "response": [] // 返回值
61
+ }
62
+ }
63
+ ]
64
+ ```
65
+
66
+ ## 功能特性
67
+ 1. **多层级逻辑嵌套**:支持无限层级的“并且/或者”逻辑组合。
68
+ 2. **动态表单渲染**:根据选择的对象属性类型(`dataTypeCode`),自动渲染对应的输入组件(文本框、日期选择、业务选择器等)。
69
+ 3. **参数插入**:支持将系统变量作为条件值。
70
+ 4. **参数条件控制**:支持为特定条件配置请求参数名称、类型及校验规则。
71
+ 5. **动作与返回值**:支持配置规则命中后的执行动作及返回值。
72
+
73
+ ## 代码演示
74
+
75
+ ```tsx
76
+ import React, { useState } from 'react';
77
+ import { RuleComponent } from '../../../index';
78
+
79
+ export default () => {
80
+ const [ruleClassData, setRuleClassData] = useState([]);
81
+ const [disabled, setDisabled] = useState(false);
82
+
83
+ // 模拟规则对象数据源
84
+ const regularDataList = [
85
+ {
86
+ id: 'user_info',
87
+ name: '用户信息',
88
+ code: 'user',
89
+ valueType: 'object',
90
+ propertyList: [
91
+ { id: 'age', name: '年龄', code: 'age', valueType: '22', inputType: 11, choiceType: 10, },
92
+ { id: 'name', name: '姓名', code: 'name', valueType: '21', inputType: 11, choiceType: 10, },
93
+ ]
94
+ },
95
+ {
96
+ id: 'order_info',
97
+ name: '订单信息',
98
+ code: 'order',
99
+ valueType: 'object',
100
+ propertyList: [
101
+ { id: 'amount', name: '金额', code: 'amount', valueType: '22', inputType: 11, choiceType: 10, },
102
+ ]
103
+ }
104
+ ];
105
+
106
+ // 模拟操作符数据源
107
+ const operationList = [
108
+ {
109
+ code: '21', // 字符串
110
+ operationList: [
111
+ { code: 'eq', name: '等于' },
112
+ { code: 'cn', name: '包含' },
113
+ ]
114
+ },
115
+ {
116
+ code: '22', // 数值
117
+ operationList: [
118
+ { code: 'eq', name: '等于' },
119
+ { code: 'gt', name: '大于' },
120
+ { code: 'lt', name: '小于' },
121
+ ]
122
+ }
123
+ ];
124
+
125
+ // 模拟系统变量
126
+ const systemVariableList = [
127
+ { code: 'sys_uid', name: '当前用户ID' },
128
+ { code: 'sys_time', name: '当前时间' },
129
+ ];
130
+
131
+ const handleSave = () => {
132
+ console.log('保存规则数据:', JSON.stringify(ruleClassData, null, 2));
133
+ alert('规则数据已输出到控制台,请查看!');
134
+ };
135
+
136
+ return (
137
+ <div style={{ background: '#f0f2f5', padding: 20, width: '1200px' }}>
138
+ <div style={{ marginBottom: 16, textAlign: 'right' }}>
139
+ <button
140
+ onClick={() => setDisabled(!disabled)}
141
+ style={{
142
+ backgroundColor: '#faad14',
143
+ color: '#fff',
144
+ border: 'none',
145
+ padding: '6px 15px',
146
+ borderRadius: '2px',
147
+ cursor: 'pointer',
148
+ marginRight: '10px'
149
+ }}
150
+ >
151
+ {disabled ? '启用编辑' : '禁用编辑'}
152
+ </button>
153
+ <button
154
+ onClick={handleSave}
155
+ style={{
156
+ backgroundColor: '#1890ff',
157
+ color: '#fff',
158
+ border: 'none',
159
+ padding: '6px 15px',
160
+ borderRadius: '2px',
161
+ cursor: 'pointer'
162
+ }}
163
+ >
164
+ 保存规则
165
+ </button>
166
+ </div>
167
+ <RuleComponent
168
+ regularDataList={regularDataList}
169
+ operationList={operationList}
170
+ ruleClassData={ruleClassData}
171
+ needShowInsertSQL={true}
172
+ needShowReqCondition={true}
173
+ systemVariableList={systemVariableList}
174
+ disabled={disabled}
175
+ callBack={(newData) => {
176
+ console.log('Rule Changed:', newData);
177
+ setRuleClassData([...newData]);
178
+ }}
179
+ />
180
+ <div style={{ marginTop: 20 }}>
181
+ <h4>当前规则数据:</h4>
182
+ <pre>{JSON.stringify(ruleClassData, null, 2)}</pre>
183
+ </div>
184
+ </div>
185
+ );
186
+ };
187
+ ```
@@ -0,0 +1,63 @@
1
+ # RuleField 规则字段组件
2
+
3
+ ## 简介
4
+ `RuleField` 是 `RuleObjectComponent` 内部使用的核心子组件,主要负责根据规则配置的**数据类型**和**操作符**,动态渲染出合适的输入控件(如输入框、下拉框、日期选择器、业务选择器等)。
5
+
6
+ ## 组件路径
7
+ `src/components/Solution/RuleComponent/ruleFiled.js`
8
+
9
+ ## Props 属性说明
10
+
11
+ | 属性名 | 类型 | 说明 |
12
+ | --- | --- | --- |
13
+ | selectOperation | `String` | 当前选中的操作符编码(如 `eq`, `in`, `be` 等)。 |
14
+ | dataTypeCode | `String` | 数据类型编码(21:字符串, 22:数值, 41:日期, 32:日期时间等)。 |
15
+ | dataChoiceBusinessType | `String`/`Number` | 业务数据选择类型(如 110:物理仓, 120:逻辑仓, 250:客户 等),用于决定渲染哪种业务选择器。 |
16
+ | dataInputBusinessType | `Number` | 输入交互类型(11:单选, 12:多选)。 |
17
+ | values | `Array` | 当前输入的值数组。 |
18
+ | valueNames | `Array` | 当前输入值的名称数组(用于回显)。 |
19
+ | callback | `Function` | 值发生变化时的回调,签名:`(newValues, newValueNames) => void`。 |
20
+ | disabled | `Boolean` | 是否禁用。 |
21
+ | customerWidth | `String` | 自定义控件宽度。 |
22
+ | queryIdentify | `String` | 字典或枚举的标识符,用于获取下拉选项数据。 |
23
+ | queryIdentifyType | `String` | 标识符类型(`dictCodeIdentify`, `dynamicDictCodeIdentify` 等)。 |
24
+ | initialThresholdQuery | `Object` | 初始查询参数。 |
25
+ | propertyCode | `String` | 属性编码。 |
26
+ | others | `Object` | 其他扩展配置,如 `customSelectorConfig`。 |
27
+
28
+ ## 支持的控件类型
29
+
30
+ 组件根据 `dataTypeCode` 和 `dataChoiceBusinessType` 自动匹配以下控件:
31
+
32
+ 1. **基础控件**:
33
+ * Input (文本/数值)
34
+ * DatePicker / RangePicker (日期/时间)
35
+ * Select (枚举/字典下拉)
36
+
37
+ 2. **区间控件**:
38
+ * 当操作符为区间类型(如 `be`, `bed`)时,自动渲染两个输入控件及中间的 `~` 符号。
39
+
40
+ 3. **业务选择器**:
41
+ * 物理仓 (`physicalWarehouse`)
42
+ * 逻辑仓 (`realWarehouse`)
43
+ * 虚拟仓 (`virtualWarehouse`)
44
+ * 渠道仓 (`channelWarehouse`)
45
+ * 商品SPU/SKU
46
+ * 省市区级联 (`BsCascader`)
47
+ * 行政/采购/销售/库存/结算组织 (`BusinessTreeSearchSelect`)
48
+ * 供应商/客户/店铺/员工 (`BusinessSearchSelect`)
49
+ * 品牌/类目
50
+ * 自定义选择器 (`CustomSelector`)
51
+
52
+ ## 使用示例
53
+
54
+ ```javascript
55
+ <RuleField
56
+ selectOperation="eq"
57
+ dataTypeCode="21"
58
+ values={['some value']}
59
+ valueNames={['some value']}
60
+ callback={(vals, names) => console.log(vals, names)}
61
+ disabled={false}
62
+ />
63
+ ```
@@ -1143,21 +1143,36 @@ class RuleObjectComponent extends Component {
1143
1143
  borderRadius: '4px',
1144
1144
  }}
1145
1145
  >
1146
- <span style={{ marginRight: 8, flexShrink: 0 }}>
1147
- 请求参数名称:
1148
- </span>
1149
- <Input
1146
+ <Select
1150
1147
  disabled={disabled}
1151
1148
  style={{ width: 150, marginRight: 10 }}
1152
- value={itemDetail.reqConditionData.reqParamName}
1153
- onChange={(e) =>
1154
- this.handleReqDataChange(
1155
- itemDetail,
1156
- 'reqParamName',
1157
- e.target.value,
1158
- )
1149
+ placeholder="请选择"
1150
+ value={String(
1151
+ itemDetail.reqConditionData.reqParamType || '10',
1152
+ )}
1153
+ onChange={(val) =>
1154
+ this.handleReqDataChange(itemDetail, 'reqParamType', val)
1159
1155
  }
1160
- />
1156
+ >
1157
+ <Select.Option value="10">请求参数名称</Select.Option>
1158
+ <Select.Option value="20">请求头参数名称</Select.Option>
1159
+ <Select.Option value="40">源请求地址</Select.Option>
1160
+ </Select>
1161
+ {String(itemDetail.reqConditionData.reqParamType || '10') !==
1162
+ '40' && (
1163
+ <Input
1164
+ disabled={disabled}
1165
+ style={{ width: 150, marginRight: 10 }}
1166
+ value={itemDetail.reqConditionData.reqParamName}
1167
+ onChange={(e) =>
1168
+ this.handleReqDataChange(
1169
+ itemDetail,
1170
+ 'reqParamName',
1171
+ e.target.value,
1172
+ )
1173
+ }
1174
+ />
1175
+ )}
1161
1176
 
1162
1177
  <span style={{ marginRight: 8, flexShrink: 0 }}>类型:</span>
1163
1178
  <Select
@@ -1843,6 +1858,8 @@ class RuleObjectComponent extends Component {
1843
1858
  if (valueNames) {
1844
1859
  itemDetail.reqConditionData.paramNames = valueNames;
1845
1860
  }
1861
+ } else if (field === 'reqParamType') {
1862
+ itemDetail.reqConditionData.reqParamType = value;
1846
1863
  }
1847
1864
 
1848
1865
  this.setState(
@@ -0,0 +1,97 @@
1
+ # RuleSetter 规则设置器组件
2
+
3
+ ## 简介
4
+ `RuleSetter` 是一个封装了完整规则编辑逻辑的高级业务组件。它内部集成了 `RuleObjectComponent`,并内置了规则模板详情查询、规则对象树加载、操作符获取、规则实例数据回显以及规则保存等全套数据交互逻辑。
5
+
6
+ 开发者只需提供规则模板 ID (`id`) 和业务标识 (`extStrField01`),即可快速在页面中引入一个功能完备的规则编辑器。
7
+
8
+ ## 组件路径
9
+ `src/components/Solution/RuleSetter/index.tsx`
10
+
11
+ ## Props 属性说明
12
+
13
+ | 属性名 | 类型 | 必填 | 说明 |
14
+ |Ref | --- | --- | --- |
15
+ | id / sceneId | `String` | 是 | 规则模板 ID,用于加载规则元数据(对象树、操作符等)。 |
16
+ | extStrField01 | `String` | 否 | 业务关键字段(如业务单据ID、租户ID等),用于区分同一模板下的不同业务实例。 |
17
+ | name | `String` | 否 | 规则实例名称。 |
18
+ | type | `String` | 否 | 组件模式。`instance` 表示规则实例模式(加载并保存具体的业务规则);为空则通常用于模板设计模式。 |
19
+ | saveUrl | `String` | 否 | 自定义保存接口地址。默认为 `/basic/ruleDetail/addAndUpdate`。 |
20
+ | customerValidator | `Function` | 否 | 自定义校验函数。`(ruleResultList, ruleTypeData) => boolean`。 |
21
+ | parseCustomParams | `Function` | 否 | 自定义保存参数处理函数。`(params) => newParams`。 |
22
+ | RuleObjectComponentProps | `Object` | 否 | 透传给底层 `RuleObjectComponent` 的属性对象。可用于开启特定功能(如插入SQL)。 |
23
+
24
+ ## 开启“插入 SQL”功能
25
+
26
+ 通过 `RuleObjectComponentProps` 属性,可以将 `needShowInsertSQL` 参数传递给底层的规则组件,从而开启“插入 SQL”功能。
27
+
28
+ 开启后,在每条规则条件的右侧会新增一个“插入 SQL”按钮,允许用户直接输入 SQL 片段作为条件值。
29
+
30
+ ```javascript
31
+ <RuleSetter
32
+ id="template_123"
33
+ type="instance"
34
+ RuleObjectComponentProps={{
35
+ needShowInsertSQL: true
36
+ }}
37
+ />
38
+ ```
39
+
40
+ ## 代码演示
41
+
42
+ ```tsx
43
+ import React, { useRef } from 'react';
44
+ import { Button, message } from 'antd';
45
+ import { RuleSetter } from '../../../index';
46
+
47
+ export default () => {
48
+ const ruleSetterRef = useRef();
49
+
50
+ const handleSave = () => {
51
+ if (ruleSetterRef.current) {
52
+ // 调用组件内部的保存方法
53
+ ruleSetterRef.current.handleSave()
54
+ .then(() => {
55
+ message.success('规则保存成功');
56
+ })
57
+ .catch((err) => {
58
+ console.error('保存失败', err);
59
+ });
60
+ }
61
+ };
62
+
63
+ return (
64
+ <div style={{ background: '#f5f5f5', padding: 20 }}>
65
+ <div style={{ marginBottom: 16, textAlign: 'right' }}>
66
+ <Button type="primary" onClick={handleSave}>
67
+ 保存规则
68
+ </Button>
69
+ </div>
70
+
71
+ <RuleSetter
72
+ ref={ruleSetterRef}
73
+ id="100000132" // 示例模板ID,请替换为实际存在的ID
74
+ type="instance"
75
+ extStrField01="business_order_001" // 示例业务ID
76
+ name="订单审核规则"
77
+ // 开启插入SQL功能
78
+ RuleObjectComponentProps={{
79
+ needShowInsertSQL: true,
80
+ needShowReqCondition: true,
81
+ // 也可以传递其他 RuleObjectComponent 支持的属性
82
+ onlyCondition: false
83
+ }}
84
+ saveUrl="/api/custom/save/rule" // 可选:自定义保存接口
85
+ />
86
+ </div>
87
+ );
88
+ };
89
+ ```
90
+
91
+ ## 注意事项
92
+
93
+ 1. **数据依赖**:该组件强依赖后端接口(如 `/basic/ruleTemplate/`等),请确保后端服务正常且接口地址匹配。
94
+ 2. **Ref 引用**:组件暴露了 `handleSave` 方法,父组件需要通过 `ref` 来触发保存操作。
95
+ 3. **模式区别**:
96
+ * `type="instance"`:会根据 `id` 和 `extStrField01` 加载已保存的规则实例数据。
97
+ * `type` 为空:主要用于设计规则模板本身,加载的是模板定义数据。