kts-component-invoice-operate 3.2.13 → 3.2.15

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.
Files changed (186) hide show
  1. package/.dumi/theme/builtins/API.tsx +66 -66
  2. package/.editorconfig +16 -16
  3. package/.fatherrc.ts +4 -4
  4. package/.prettierignore +7 -7
  5. package/.prettierrc +11 -11
  6. package/.umirc.ts +8 -8
  7. package/README.md +5 -5
  8. package/dist/Invoice/ui/digtal/Stakeholder/index.d.ts +2 -0
  9. package/dist/index.esm.js +4738 -6591
  10. package/dist/index.js +4738 -6591
  11. package/docs/index.md +5 -5
  12. package/docs-dist/static/arrowDown.a1cbf0d8.svg +2 -2
  13. package/docs-dist/static/arrowUp.4c482054.svg +2 -2
  14. package/docs-dist/static/fork.5431267d.svg +11 -11
  15. package/docs-dist/static/plus.44013ce3.svg +11 -11
  16. package/docs-dist/static/plus.4fd1af30.svg +11 -11
  17. package/index.html +12 -12
  18. package/package.json +60 -60
  19. package/src/Invoice/Invoice-digtal/_test/disabled/index.tsx +38 -38
  20. package/src/Invoice/Invoice-digtal/_test/easiest/index.tsx +16 -16
  21. package/src/Invoice/Invoice-digtal/_test/header/index.tsx +17 -17
  22. package/src/Invoice/Invoice-digtal/_test/importGoods/index.tsx +470 -470
  23. package/src/Invoice/Invoice-digtal/_test/importStakeholder/index.tsx +17 -17
  24. package/src/Invoice/Invoice-digtal/_test/lineCredit/index.tsx +20 -20
  25. package/src/Invoice/Invoice-digtal/_test/prefab/index.tsx +150 -150
  26. package/src/Invoice/Invoice-digtal/_test/readOnly/index.tsx +41 -41
  27. package/src/Invoice/Invoice-digtal/_test/stakeholder/index.tsx +12 -12
  28. package/src/Invoice/Invoice-digtal/_test/typeSelection/index.tsx +29 -29
  29. package/src/Invoice/Invoice-digtal/index.md +30 -30
  30. package/src/Invoice/InvoiceController/InvoiceControllerForm/index.ts +94 -94
  31. package/src/Invoice/InvoiceController/InvoiceControllerState/BuyerState/index.tsx +88 -88
  32. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/EndowCode/index.tsx +93 -93
  33. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/IColumnsReplenish/index.ts +10 -10
  34. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/IGood/index.ts +75 -75
  35. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/ImportGoods/index.ts +80 -80
  36. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/LineAttributeType/index.ts +5 -5
  37. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/ProductComparison/index.ts +9 -9
  38. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/index.ts +94 -94
  39. package/src/Invoice/InvoiceController/InvoiceControllerState/Stakeholder/index.ts +10 -10
  40. package/src/Invoice/InvoiceController/InvoiceControllerState/index.ts +56 -56
  41. package/src/Invoice/InvoiceController/fns/addGood.ts +11 -11
  42. package/src/Invoice/InvoiceController/fns/addGoodDiscount.ts +125 -125
  43. package/src/Invoice/InvoiceController/fns/addGoodDiscountV2.ts +84 -84
  44. package/src/Invoice/InvoiceController/fns/delGood.ts +41 -41
  45. package/src/Invoice/InvoiceController/fns/getGoodsSearch.ts +23 -23
  46. package/src/Invoice/InvoiceController/fns/saveEditGood.ts +24 -24
  47. package/src/Invoice/InvoiceController/fns/setEditGood.ts +16 -16
  48. package/src/Invoice/InvoiceController/fns/setGoods.ts +10 -10
  49. package/src/Invoice/InvoiceController/fns/updateInvoiceNo.ts +8 -8
  50. package/src/Invoice/InvoiceController/index.ts +65 -65
  51. package/src/Invoice/_test/buyerNameSearch/index.tsx +41 -41
  52. package/src/Invoice/_test/deduction/index.tsx +935 -935
  53. package/src/Invoice/_test/draft/index.tsx +40 -40
  54. package/src/Invoice/_test/easiest/index.tsx +5 -5
  55. package/src/Invoice/_test/endowCode/index.tsx +1095 -1095
  56. package/src/Invoice/_test/goodsMenuExpand/index.tsx +32 -32
  57. package/src/Invoice/_test/importBuyer/index.tsx +74 -74
  58. package/src/Invoice/_test/importGoods/index.tsx +515 -515
  59. package/src/Invoice/_test/invoiceType/index.tsx +59 -59
  60. package/src/Invoice/_test/isInvoiceNo/index.tsx +12 -12
  61. package/src/Invoice/_test/replaceHead/index.tsx +22 -22
  62. package/src/Invoice/_test/retrieveData/index.tsx +22 -22
  63. package/src/Invoice/_test/seller/index.tsx +28 -28
  64. package/src/Invoice/_test/setDataSource/index.tsx +22 -22
  65. package/src/Invoice/_test/unit/index.tsx +19 -19
  66. package/src/Invoice/index.less +29 -29
  67. package/src/Invoice/index.md +53 -53
  68. package/src/Invoice/index.tsx +165 -165
  69. package/src/Invoice/tools/calculate/index.ts +112 -112
  70. package/src/Invoice/tools/coolingFn/index.ts +17 -17
  71. package/src/Invoice/tools/evaluate/index.ts +7 -7
  72. package/src/Invoice/tools/idGenerator/index.ts +2 -2
  73. package/src/Invoice/tools/itemName/index.ts +55 -55
  74. package/src/Invoice/tools/lazyFn/index.ts +19 -19
  75. package/src/Invoice/tools/mounting/index.ts +13 -13
  76. package/src/Invoice/tools/strringFn/index.ts +40 -40
  77. package/src/Invoice/tools/useToGenerateId/index.ts +8 -8
  78. package/src/Invoice/ui/default/AddComparisonDrawer/index.tsx +149 -149
  79. package/src/Invoice/ui/default/Buyer/index.less +219 -219
  80. package/src/Invoice/ui/default/Buyer/index.tsx +114 -114
  81. package/src/Invoice/ui/default/Buyer/ui/BuyerNameInput/index.tsx +166 -166
  82. package/src/Invoice/ui/default/Buyer/ui/ImportBuyerButton/index.tsx +21 -21
  83. package/src/Invoice/ui/default/EndowCodeDrawer/index.less +8 -8
  84. package/src/Invoice/ui/default/EndowCodeDrawer/index.tsx +431 -431
  85. package/src/Invoice/ui/default/GoodsList/hook/useColumns/autoFillFn/index.ts +519 -519
  86. package/src/Invoice/ui/default/GoodsList/hook/useColumns/index.tsx +620 -620
  87. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemNameInput/index.less +9 -9
  88. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemNameInput/index.tsx +19 -19
  89. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowEditButton/index.tsx +30 -30
  90. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/_useAddComparison/index.tsx +43 -43
  91. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useAddDiscount/index.tsx +76 -76
  92. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useDelItem/index.tsx +41 -41
  93. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useEndowCode/index.tsx +34 -34
  94. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/index.less +13 -13
  95. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/index.tsx +98 -98
  96. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowSaveButton/index.tsx +14 -14
  97. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/TitleText/index.tsx +20 -20
  98. package/src/Invoice/ui/default/GoodsList/hook/useDeduction/index.tsx +24 -24
  99. package/src/Invoice/ui/default/GoodsList/hook/useOnRow/index.tsx +39 -39
  100. package/src/Invoice/ui/default/GoodsList/hook/useRowSelection/index.tsx +111 -111
  101. package/src/Invoice/ui/default/GoodsList/hook/useWindowClick/index.tsx +23 -23
  102. package/src/Invoice/ui/default/GoodsList/index.less +177 -177
  103. package/src/Invoice/ui/default/GoodsList/index.tsx +177 -177
  104. package/src/Invoice/ui/default/GoodsList/ui/AddRowButton/index.tsx +65 -65
  105. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/index.less +21 -21
  106. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/index.tsx +244 -244
  107. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useCommodityComparisonButton/index.tsx +75 -75
  108. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useDelRowButton/index.tsx +69 -69
  109. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useEndowCodeButton/index.tsx +58 -58
  110. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/index.tsx +37 -37
  111. package/src/Invoice/ui/default/GoodsList/ui/DescribeSwitch/index.tsx +36 -36
  112. package/src/Invoice/ui/default/GoodsList/ui/Search/index.less +10 -10
  113. package/src/Invoice/ui/default/GoodsList/ui/Search/index.tsx +50 -50
  114. package/src/Invoice/ui/default/GoodsList/ui/Statistics/index.less +18 -18
  115. package/src/Invoice/ui/default/GoodsList/ui/Statistics/index.tsx +109 -109
  116. package/src/Invoice/ui/default/GoodsList/ui/TableRow/index.tsx +27 -27
  117. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual/index.less +38 -38
  118. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual/index.tsx +108 -108
  119. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual.o/index.less +44 -44
  120. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual.o/index.tsx +96 -96
  121. package/src/Invoice/ui/default/GoodsList/ui/TaxIncludedSwitch/index.tsx +30 -30
  122. package/src/Invoice/ui/default/ImportBuyerDrawer/index.tsx +75 -75
  123. package/src/Invoice/ui/default/ImportGoodsDrawer/index.tsx +170 -170
  124. package/src/Invoice/ui/default/InvoiceHeader/index.less +68 -68
  125. package/src/Invoice/ui/default/InvoiceHeader/index.tsx +246 -246
  126. package/src/Invoice/ui/default/Seller/index.less +113 -113
  127. package/src/Invoice/ui/default/Seller/index.tsx +98 -98
  128. package/src/Invoice/ui/default/Sign/index.less +14 -14
  129. package/src/Invoice/ui/default/Sign/index.tsx +71 -71
  130. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/autoFillFn/index.ts +519 -519
  131. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/index.tsx +635 -635
  132. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/svg/plus.svg +11 -11
  133. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/ItemNameInput/index.less +9 -9
  134. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/ItemNameInput/index.tsx +24 -24
  135. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowEditButton/index.tsx +30 -30
  136. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/_useAddComparison/index.tsx +43 -43
  137. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/useAddDiscount/index.tsx +76 -76
  138. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/useDelItem/index.tsx +41 -41
  139. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/useEndowCode/index.tsx +34 -34
  140. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/index.less +13 -13
  141. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/index.tsx +98 -98
  142. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowSaveButton/index.tsx +14 -14
  143. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/TitleText/index.tsx +20 -20
  144. package/src/Invoice/ui/digtal/GoodsList/hook/useOnRow/index.tsx +39 -39
  145. package/src/Invoice/ui/digtal/GoodsList/hook/useRowSelection/index.tsx +121 -121
  146. package/src/Invoice/ui/digtal/GoodsList/hook/useWindowClick/index.tsx +23 -23
  147. package/src/Invoice/ui/digtal/GoodsList/index.less +56 -56
  148. package/src/Invoice/ui/digtal/GoodsList/index.tsx +180 -180
  149. package/src/Invoice/ui/digtal/GoodsList/ui/AddRowButton/index.tsx +65 -65
  150. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/index.tsx +341 -341
  151. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/svg/add.svg +11 -11
  152. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useCommodityComparisonButton/index.tsx +75 -75
  153. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useDelRowButton/index.tsx +50 -50
  154. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useEmptyRefill/index.tsx +35 -35
  155. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useEndowCodeButton/index.tsx +82 -82
  156. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useReselectInvoiceType/index.tsx +57 -57
  157. package/src/Invoice/ui/digtal/GoodsList/ui/DescribeSwitch/index.tsx +36 -36
  158. package/src/Invoice/ui/digtal/GoodsList/ui/Search/index.less +11 -11
  159. package/src/Invoice/ui/digtal/GoodsList/ui/Search/index.tsx +50 -50
  160. package/src/Invoice/ui/digtal/GoodsList/ui/Statistics/index.less +53 -53
  161. package/src/Invoice/ui/digtal/GoodsList/ui/Statistics/index.tsx +99 -99
  162. package/src/Invoice/ui/digtal/GoodsList/ui/Statistics/svg/fork.svg +11 -11
  163. package/src/Invoice/ui/digtal/GoodsList/ui/TableRow/index.tsx +27 -27
  164. package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual/index.less +38 -38
  165. package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual/index.tsx +108 -108
  166. package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual.o/index.less +44 -44
  167. package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual.o/index.tsx +96 -96
  168. package/src/Invoice/ui/digtal/GoodsList/ui/TaxIncludedSwitch/index.tsx +30 -30
  169. package/src/Invoice/ui/digtal/InvoiceHeader/index.less +57 -57
  170. package/src/Invoice/ui/digtal/InvoiceHeader/index.tsx +77 -77
  171. package/src/Invoice/ui/digtal/Sign/index.less +48 -48
  172. package/src/Invoice/ui/digtal/Sign/index.tsx +89 -89
  173. package/src/Invoice/ui/digtal/Stakeholder/index.less +56 -56
  174. package/src/Invoice/ui/digtal/Stakeholder/index.tsx +282 -269
  175. package/src/Invoice/ui/digtal/Stakeholder/svg/arrowDown.svg +2 -2
  176. package/src/Invoice/ui/digtal/Stakeholder/svg/arrowUp.svg +2 -2
  177. package/src/Invoice/ui/digtal/Stakeholder/svg/plus.svg +11 -11
  178. package/src/InvoiceTypeModal/_test/easiest/index.tsx +31 -31
  179. package/src/InvoiceTypeModal/index.less +7 -7
  180. package/src/InvoiceTypeModal/index.md +5 -5
  181. package/src/InvoiceTypeModal/index.tsx +153 -153
  182. package/src/index.ts +9 -9
  183. package/tsconfig.json +31 -31
  184. package/typings.d.ts +3 -3
  185. package/yarn.e.lock +14331 -14331
  186. package/yarn.o.lock +14800 -14800
@@ -1,94 +1,94 @@
1
- import React from 'react';
2
- import GreyReactBox from 'grey-react-box';
3
- import { chain, bignumber } from 'mathjs';
4
- import InvoiceControllerState from '../InvoiceControllerState';
5
- import { WrappedFormUtils } from 'kts-components-antd-x3/lib/form/Form';
6
-
7
- export default class InvoiceControllerForm extends GreyReactBox<InvoiceControllerState> {
8
- /** form 字典 */
9
- readonly formList = new Map<string, WrappedFormUtils>();
10
-
11
- /** 注册 form */
12
- useForm(key: string, value: WrappedFormUtils) {
13
- /** 注册 form 到组件 */
14
- React.useEffect(() => {
15
- this.formList.set(key, value);
16
- return () => {
17
- this.formList.delete(key);
18
- };
19
- }, [value, key]);
20
- }
21
-
22
- /** 校验所有表单 */
23
- async validateFields(): Promise<{ errors: Map<string, any>; values: Map<string, any> }> {
24
-
25
- await this.wait();
26
-
27
- const _errors = new Map<string, any>();
28
- const _values = new Map<string, any>();
29
-
30
- const arr = Array.from(this.formList);
31
- for (let i = 0; i < arr.length; i++) {
32
- const key = arr[i][0];
33
- const { errors, values } = await validateFields(arr[i][1]);
34
-
35
- errors && _errors.set(key, errors);
36
- _values && _values.set(key, values);
37
- }
38
-
39
- // 列表数据
40
- if (this.state.goodsListState.form) {
41
- try {
42
- await this.state.goodsListState.form?.validateFields()
43
- } catch (error:any) {
44
- _errors.set('goodsList', error.errors);
45
- }
46
- }
47
-
48
- _values.set('goodsList', this.state.goodsListState.goodsList.slice());
49
-
50
- // 金额(含税)
51
- _values.set('lineAmountIncludeTax', (() => {
52
- let sum = chain(bignumber(0));
53
- this.state.goodsListState.goodsList.forEach(e => {
54
- if (!e) return;
55
- sum = sum.add(bignumber(e.lineAmountIncludeTax || 0));
56
- });
57
- return sum.done().toNumber();
58
- })());
59
-
60
- // 金额(不含税)
61
- _values.set('lineAmountExcludeTax', (() => {
62
- let sum = chain(bignumber(0));
63
- this.state.goodsListState.goodsList.forEach(e => {
64
- if (!e) return;
65
- sum = sum.add(bignumber(e.lineAmountExcludeTax || 0));
66
- });
67
- return sum.done().toNumber();
68
- })());
69
-
70
- // 税额
71
- _values.set('taxAmount', (() => {
72
- let sum = chain(bignumber(0));
73
- this.state.goodsListState.goodsList.forEach((e) => {
74
- if (!e) return;
75
- sum = sum.add(bignumber(e.taxAmount || 0));
76
- });
77
- return sum.done().toNumber();
78
- })());
79
-
80
- // 含税标记
81
- _values.set('isTaxIncluded', this.state.goodsListState.isTaxIncluded)
82
-
83
- return { errors: _errors, values: _values };
84
- }
85
- }
86
-
87
- const validateFields = (form: WrappedFormUtils) => {
88
- return new Promise<any>((resolve: (v: any) => void) => {
89
- form.validateFields((errors, values) => {
90
- resolve({ errors, values });
91
- });
92
- });
93
- };
94
-
1
+ import React from 'react';
2
+ import GreyReactBox from 'grey-react-box';
3
+ import { chain, bignumber } from 'mathjs';
4
+ import InvoiceControllerState from '../InvoiceControllerState';
5
+ import { WrappedFormUtils } from 'kts-components-antd-x3/lib/form/Form';
6
+
7
+ export default class InvoiceControllerForm extends GreyReactBox<InvoiceControllerState> {
8
+ /** form 字典 */
9
+ readonly formList = new Map<string, WrappedFormUtils>();
10
+
11
+ /** 注册 form */
12
+ useForm(key: string, value: WrappedFormUtils) {
13
+ /** 注册 form 到组件 */
14
+ React.useEffect(() => {
15
+ this.formList.set(key, value);
16
+ return () => {
17
+ this.formList.delete(key);
18
+ };
19
+ }, [value, key]);
20
+ }
21
+
22
+ /** 校验所有表单 */
23
+ async validateFields(): Promise<{ errors: Map<string, any>; values: Map<string, any> }> {
24
+
25
+ await this.wait();
26
+
27
+ const _errors = new Map<string, any>();
28
+ const _values = new Map<string, any>();
29
+
30
+ const arr = Array.from(this.formList);
31
+ for (let i = 0; i < arr.length; i++) {
32
+ const key = arr[i][0];
33
+ const { errors, values } = await validateFields(arr[i][1]);
34
+
35
+ errors && _errors.set(key, errors);
36
+ _values && _values.set(key, values);
37
+ }
38
+
39
+ // 列表数据
40
+ if (this.state.goodsListState.form) {
41
+ try {
42
+ await this.state.goodsListState.form?.validateFields()
43
+ } catch (error:any) {
44
+ _errors.set('goodsList', error.errors);
45
+ }
46
+ }
47
+
48
+ _values.set('goodsList', this.state.goodsListState.goodsList.slice());
49
+
50
+ // 金额(含税)
51
+ _values.set('lineAmountIncludeTax', (() => {
52
+ let sum = chain(bignumber(0));
53
+ this.state.goodsListState.goodsList.forEach(e => {
54
+ if (!e) return;
55
+ sum = sum.add(bignumber(e.lineAmountIncludeTax || 0));
56
+ });
57
+ return sum.done().toNumber();
58
+ })());
59
+
60
+ // 金额(不含税)
61
+ _values.set('lineAmountExcludeTax', (() => {
62
+ let sum = chain(bignumber(0));
63
+ this.state.goodsListState.goodsList.forEach(e => {
64
+ if (!e) return;
65
+ sum = sum.add(bignumber(e.lineAmountExcludeTax || 0));
66
+ });
67
+ return sum.done().toNumber();
68
+ })());
69
+
70
+ // 税额
71
+ _values.set('taxAmount', (() => {
72
+ let sum = chain(bignumber(0));
73
+ this.state.goodsListState.goodsList.forEach((e) => {
74
+ if (!e) return;
75
+ sum = sum.add(bignumber(e.taxAmount || 0));
76
+ });
77
+ return sum.done().toNumber();
78
+ })());
79
+
80
+ // 含税标记
81
+ _values.set('isTaxIncluded', this.state.goodsListState.isTaxIncluded)
82
+
83
+ return { errors: _errors, values: _values };
84
+ }
85
+ }
86
+
87
+ const validateFields = (form: WrappedFormUtils) => {
88
+ return new Promise<any>((resolve: (v: any) => void) => {
89
+ form.validateFields((errors, values) => {
90
+ resolve({ errors, values });
91
+ });
92
+ });
93
+ };
94
+
@@ -1,88 +1,88 @@
1
-
2
- import React from 'react';
3
- import { ColumnProps } from 'kts-components-antd-x3/lib/Table/interface';
4
- import { PaginationConfig } from 'kts-components-antd-x3/lib/Table';
5
- import { GetFieldDecoratorOptions } from 'kts-components-antd-x3/lib/form/Form';
6
-
7
- export interface IGetBuyerListOption {
8
- /** 分页数据 */
9
- pagination: PaginationConfig;
10
- }
11
-
12
- export interface IFormItem {
13
- id: string;
14
- label: string;
15
- node: React.ReactNode;
16
- options: GetFieldDecoratorOptions;
17
- }
18
-
19
- export interface IBuyerInfo {
20
- /** 购买方名称 */
21
- buyerName?: string;
22
-
23
- /** 购买方纳税人识别号 */
24
- buyerNo?: string;
25
-
26
- /** 购买方地址及电话 */
27
- buyerAddress?: string;
28
-
29
- /** 购买方开户行及账号 */
30
- buyerBank?: string;
31
- }
32
-
33
- /** 自动填充 */
34
- export interface IAutoContainer {
35
-
36
- /** 购买方变化 */
37
- onBuyNameChange: (e?: string) => Promise<{ recent?: IBuyerInfo[], list?: IBuyerInfo[] }>;
38
- }
39
-
40
- export default class BuyerState {
41
-
42
- /** 表头 */
43
- columns: ColumnProps<any>[] = [
44
- {
45
- title: '公司名称',
46
- dataIndex: 'buyerName',
47
- key: 'buyerName',
48
- },
49
- {
50
- title: '纳税人识别号',
51
- dataIndex: 'buyerNo',
52
- key: 'buyerNo',
53
- },
54
- {
55
- title: '地址',
56
- dataIndex: 'address',
57
- key: 'address',
58
- },
59
- {
60
- title: '电话',
61
- dataIndex: 'phone',
62
- key: 'phone',
63
- },
64
- {
65
- title: '开户行及账号',
66
- dataIndex: 'buyerBank',
67
- key: 'buyerBank',
68
- },
69
- ];
70
-
71
- /** 行点击事件 */
72
- onRowClick = async (record: any) => record;
73
-
74
- /** 购方列表 */
75
- dataSource: any = [];
76
-
77
- /** 分页数据 */
78
- pagination: PaginationConfig = {};
79
-
80
- /** 是否显示导入 */
81
- isVisibleDrawer = false;
82
-
83
- /** 顶部扩展 */
84
- topExpand?: React.ReactNode;
85
-
86
- /** 自动填充 */
87
- autoContainer?: IAutoContainer;
88
- }
1
+
2
+ import React from 'react';
3
+ import { ColumnProps } from 'kts-components-antd-x3/lib/Table/interface';
4
+ import { PaginationConfig } from 'kts-components-antd-x3/lib/Table';
5
+ import { GetFieldDecoratorOptions } from 'kts-components-antd-x3/lib/form/Form';
6
+
7
+ export interface IGetBuyerListOption {
8
+ /** 分页数据 */
9
+ pagination: PaginationConfig;
10
+ }
11
+
12
+ export interface IFormItem {
13
+ id: string;
14
+ label: string;
15
+ node: React.ReactNode;
16
+ options: GetFieldDecoratorOptions;
17
+ }
18
+
19
+ export interface IBuyerInfo {
20
+ /** 购买方名称 */
21
+ buyerName?: string;
22
+
23
+ /** 购买方纳税人识别号 */
24
+ buyerNo?: string;
25
+
26
+ /** 购买方地址及电话 */
27
+ buyerAddress?: string;
28
+
29
+ /** 购买方开户行及账号 */
30
+ buyerBank?: string;
31
+ }
32
+
33
+ /** 自动填充 */
34
+ export interface IAutoContainer {
35
+
36
+ /** 购买方变化 */
37
+ onBuyNameChange: (e?: string) => Promise<{ recent?: IBuyerInfo[], list?: IBuyerInfo[] }>;
38
+ }
39
+
40
+ export default class BuyerState {
41
+
42
+ /** 表头 */
43
+ columns: ColumnProps<any>[] = [
44
+ {
45
+ title: '公司名称',
46
+ dataIndex: 'buyerName',
47
+ key: 'buyerName',
48
+ },
49
+ {
50
+ title: '纳税人识别号',
51
+ dataIndex: 'buyerNo',
52
+ key: 'buyerNo',
53
+ },
54
+ {
55
+ title: '地址',
56
+ dataIndex: 'address',
57
+ key: 'address',
58
+ },
59
+ {
60
+ title: '电话',
61
+ dataIndex: 'phone',
62
+ key: 'phone',
63
+ },
64
+ {
65
+ title: '开户行及账号',
66
+ dataIndex: 'buyerBank',
67
+ key: 'buyerBank',
68
+ },
69
+ ];
70
+
71
+ /** 行点击事件 */
72
+ onRowClick = async (record: any) => record;
73
+
74
+ /** 购方列表 */
75
+ dataSource: any = [];
76
+
77
+ /** 分页数据 */
78
+ pagination: PaginationConfig = {};
79
+
80
+ /** 是否显示导入 */
81
+ isVisibleDrawer = false;
82
+
83
+ /** 顶部扩展 */
84
+ topExpand?: React.ReactNode;
85
+
86
+ /** 自动填充 */
87
+ autoContainer?: IAutoContainer;
88
+ }
@@ -1,94 +1,94 @@
1
- import GoodsListState from '../../GoodsListState';
2
- import IGood from '../IGood';
3
- import LineAttributeType from '../LineAttributeType';
4
-
5
- export default class EndowCode {
6
-
7
- /** 准备赋码的货物索引列表 */
8
- endowcodeGoodIndex: string[] = [];
9
-
10
- /**
11
- * 获取 税收分类编码列表 (弃用)
12
- * @deprecated 请使用 getTaxCategoryCodeTree 替换
13
- * */
14
- getTaxCategoryCodeList: (value: string) => Promise<{ value: string, label: string }[]> = async () => [];
15
-
16
- /**
17
- * 获取 税收分类编码树
18
- * @param taxCategoryCode 税收分类编码
19
- * @param val val
20
- * @returns 税收分类编码树
21
- */
22
- getTaxCategoryCodeTree?: (taxCategoryCode?: string, val?: string) => Promise<{ id: string, pid: string }[]>;
23
-
24
- /** 税率 优惠政策 */
25
- getReadOnlyTaxRate?: (value?: GoodsListState) => boolean;
26
-
27
- /** 优惠政策 优惠政策 */
28
- getReadOnlyFavouredPolicy?: (value?: GoodsListState) => boolean;
29
-
30
- /**
31
- * 获取赋码时候的默认值
32
- * @param value 商品信息
33
- * @param length 商品数量
34
- * */
35
- getDefaultValue?: (value: IGood, length: number) => Promise<IGood>;
36
-
37
- /** 税率 是否可以编辑 校验函数 */
38
- readonly readOnlyTaxRateMap: { [key: string]: (value?: GoodsListState) => boolean } = {
39
- /** 草稿发票 */
40
- DRAFT: draft,
41
- };
42
-
43
- /** 优惠政策类型列表 */
44
- favouredPolicyNameList: string[] = [
45
- '100%先征后退',
46
- '即征即退30%',
47
- '即征即退50%',
48
- '即征即退70%',
49
- '按3%简易征收',
50
- '按5%简易征收',
51
- '按3%简易征收减按1.5%计征',
52
- '稀土产品',
53
- '简易征收',
54
- '50%先征后退',
55
- '不征税',
56
- '先征后退',
57
- '免税',
58
- '即征即退100%',
59
- '超税负3%即征即退',
60
- '超税负8%即征即退',
61
- '超税负12%即征即退',
62
- ];
63
-
64
- /** 免税类型 是否需要 */
65
- isTaxFreeTypeNeeded: boolean = true;
66
-
67
- /** 免税类型 列表 */
68
- taxFreeTypeList: any[] = [
69
- { label: '出口免税和其他免税优惠政策(免税)', value: 1 },
70
- { label: '不征增值税(不征税)', value: 2 },
71
- { label: '普通零税率(0%)', value: 3 },
72
- ];
73
-
74
- /**
75
- * 小规模纳税人 自动赋码缓存 、
76
- * */
77
- cache: { [key: string]: any } = {};
78
- }
79
-
80
- /** 草稿发票 税率 是否可以编辑 校验函数 */
81
- function draft(value?: GoodsListState) {
82
- if (!value) return true;
83
-
84
- // isDiscount
85
- const goods = value.endowCode.endowcodeGoodIndex.map(e => value.goodsMap.get(e)).filter(e => e?.lineAttribute !== LineAttributeType.折扣行);
86
- const isDiscount = goods.some(e => e?.lineAttribute === LineAttributeType.被折扣行);
87
-
88
- // 是否折扣
89
- if (isDiscount) {
90
- return goods.length === 1
91
- } else {
92
- return false;
93
- }
1
+ import GoodsListState from '../../GoodsListState';
2
+ import IGood from '../IGood';
3
+ import LineAttributeType from '../LineAttributeType';
4
+
5
+ export default class EndowCode {
6
+
7
+ /** 准备赋码的货物索引列表 */
8
+ endowcodeGoodIndex: string[] = [];
9
+
10
+ /**
11
+ * 获取 税收分类编码列表 (弃用)
12
+ * @deprecated 请使用 getTaxCategoryCodeTree 替换
13
+ * */
14
+ getTaxCategoryCodeList: (value: string) => Promise<{ value: string, label: string }[]> = async () => [];
15
+
16
+ /**
17
+ * 获取 税收分类编码树
18
+ * @param taxCategoryCode 税收分类编码
19
+ * @param val val
20
+ * @returns 税收分类编码树
21
+ */
22
+ getTaxCategoryCodeTree?: (taxCategoryCode?: string, val?: string) => Promise<{ id: string, pid: string }[]>;
23
+
24
+ /** 税率 优惠政策 */
25
+ getReadOnlyTaxRate?: (value?: GoodsListState) => boolean;
26
+
27
+ /** 优惠政策 优惠政策 */
28
+ getReadOnlyFavouredPolicy?: (value?: GoodsListState) => boolean;
29
+
30
+ /**
31
+ * 获取赋码时候的默认值
32
+ * @param value 商品信息
33
+ * @param length 商品数量
34
+ * */
35
+ getDefaultValue?: (value: IGood, length: number) => Promise<IGood>;
36
+
37
+ /** 税率 是否可以编辑 校验函数 */
38
+ readonly readOnlyTaxRateMap: { [key: string]: (value?: GoodsListState) => boolean } = {
39
+ /** 草稿发票 */
40
+ DRAFT: draft,
41
+ };
42
+
43
+ /** 优惠政策类型列表 */
44
+ favouredPolicyNameList: string[] = [
45
+ '100%先征后退',
46
+ '即征即退30%',
47
+ '即征即退50%',
48
+ '即征即退70%',
49
+ '按3%简易征收',
50
+ '按5%简易征收',
51
+ '按3%简易征收减按1.5%计征',
52
+ '稀土产品',
53
+ '简易征收',
54
+ '50%先征后退',
55
+ '不征税',
56
+ '先征后退',
57
+ '免税',
58
+ '即征即退100%',
59
+ '超税负3%即征即退',
60
+ '超税负8%即征即退',
61
+ '超税负12%即征即退',
62
+ ];
63
+
64
+ /** 免税类型 是否需要 */
65
+ isTaxFreeTypeNeeded: boolean = true;
66
+
67
+ /** 免税类型 列表 */
68
+ taxFreeTypeList: any[] = [
69
+ { label: '出口免税和其他免税优惠政策(免税)', value: 1 },
70
+ { label: '不征增值税(不征税)', value: 2 },
71
+ { label: '普通零税率(0%)', value: 3 },
72
+ ];
73
+
74
+ /**
75
+ * 小规模纳税人 自动赋码缓存 、
76
+ * */
77
+ cache: { [key: string]: any } = {};
78
+ }
79
+
80
+ /** 草稿发票 税率 是否可以编辑 校验函数 */
81
+ function draft(value?: GoodsListState) {
82
+ if (!value) return true;
83
+
84
+ // isDiscount
85
+ const goods = value.endowCode.endowcodeGoodIndex.map(e => value.goodsMap.get(e)).filter(e => e?.lineAttribute !== LineAttributeType.折扣行);
86
+ const isDiscount = goods.some(e => e?.lineAttribute === LineAttributeType.被折扣行);
87
+
88
+ // 是否折扣
89
+ if (isDiscount) {
90
+ return goods.length === 1
91
+ } else {
92
+ return false;
93
+ }
94
94
  }
@@ -1,10 +1,10 @@
1
-
2
- /** 商品表格补充配置 */
3
-
4
- import { ValidationRule } from "kts-components-antd-x3/lib/form";
5
-
6
- export default interface IColumnsReplenish {
7
-
8
- /** 补充的规则 */
9
- rules: ValidationRule[];
10
- }
1
+
2
+ /** 商品表格补充配置 */
3
+
4
+ import { ValidationRule } from "kts-components-antd-x3/lib/form";
5
+
6
+ export default interface IColumnsReplenish {
7
+
8
+ /** 补充的规则 */
9
+ rules: ValidationRule[];
10
+ }