kts-component-invoice-operate 3.2.48 → 3.2.50

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 (200) 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/default/GoodsList/hook/useColumns/ui/ItemCodeInput/index.d.ts +0 -1
  9. package/dist/index.esm.js +5666 -7879
  10. package/dist/index.js +5666 -7879
  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 +84 -84
  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/AutoComplete/index.ts +17 -17
  32. package/src/Invoice/InvoiceController/InvoiceControllerState/BuyerState/index.tsx +88 -88
  33. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/Drag/index.ts +12 -12
  34. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/EndowCode/index.tsx +93 -93
  35. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/IColumnsReplenish/index.ts +10 -10
  36. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/IGood/index.ts +75 -75
  37. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/ImportGoods/index.ts +80 -80
  38. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/LineAttributeType/index.ts +5 -5
  39. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/ProductComparison/index.ts +9 -9
  40. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/index.ts +107 -107
  41. package/src/Invoice/InvoiceController/InvoiceControllerState/Stakeholder/index.ts +10 -10
  42. package/src/Invoice/InvoiceController/InvoiceControllerState/index.ts +60 -60
  43. package/src/Invoice/InvoiceController/fns/addGood.ts +11 -11
  44. package/src/Invoice/InvoiceController/fns/addGoodDiscount.ts +125 -125
  45. package/src/Invoice/InvoiceController/fns/addGoodDiscountV2.ts +84 -84
  46. package/src/Invoice/InvoiceController/fns/delGood.ts +41 -41
  47. package/src/Invoice/InvoiceController/fns/getGoodsSearch.ts +26 -26
  48. package/src/Invoice/InvoiceController/fns/importGoodsDrawer.ts +67 -67
  49. package/src/Invoice/InvoiceController/fns/mergeDetails.ts +163 -163
  50. package/src/Invoice/InvoiceController/fns/mergeDiscount.ts +28 -28
  51. package/src/Invoice/InvoiceController/fns/saveEditGood.ts +24 -24
  52. package/src/Invoice/InvoiceController/fns/setEditGood.ts +16 -16
  53. package/src/Invoice/InvoiceController/fns/setGoods.ts +10 -10
  54. package/src/Invoice/InvoiceController/fns/updateInvoiceNo.ts +8 -8
  55. package/src/Invoice/InvoiceController/index.ts +77 -77
  56. package/src/Invoice/_test/buyerNameSearch/index.tsx +41 -41
  57. package/src/Invoice/_test/deduction/index.tsx +935 -935
  58. package/src/Invoice/_test/draft/index.tsx +40 -40
  59. package/src/Invoice/_test/easiest/index.tsx +5 -5
  60. package/src/Invoice/_test/endowCode/index.tsx +1099 -1099
  61. package/src/Invoice/_test/goodsMenuExpand/index.tsx +32 -32
  62. package/src/Invoice/_test/importBuyer/index.tsx +74 -74
  63. package/src/Invoice/_test/importGoods/index.tsx +515 -515
  64. package/src/Invoice/_test/invoiceType/index.tsx +59 -59
  65. package/src/Invoice/_test/isInvoiceNo/index.tsx +12 -12
  66. package/src/Invoice/_test/replaceHead/index.tsx +22 -22
  67. package/src/Invoice/_test/retrieveData/index.tsx +22 -22
  68. package/src/Invoice/_test/seller/index.tsx +28 -28
  69. package/src/Invoice/_test/setDataSource/index.tsx +73 -73
  70. package/src/Invoice/_test/unit/index.tsx +19 -19
  71. package/src/Invoice/index.less +29 -29
  72. package/src/Invoice/index.md +53 -53
  73. package/src/Invoice/index.tsx +165 -165
  74. package/src/Invoice/tools/calculate/index.ts +112 -112
  75. package/src/Invoice/tools/coolingFn/index.ts +17 -17
  76. package/src/Invoice/tools/evaluate/index.ts +7 -7
  77. package/src/Invoice/tools/idGenerator/index.ts +2 -2
  78. package/src/Invoice/tools/itemName/index.ts +55 -55
  79. package/src/Invoice/tools/lazyFn/index.ts +19 -19
  80. package/src/Invoice/tools/mounting/index.ts +13 -13
  81. package/src/Invoice/tools/strringFn/index.ts +40 -40
  82. package/src/Invoice/tools/useToGenerateId/index.ts +8 -8
  83. package/src/Invoice/ui/default/AddComparisonDrawer/index.tsx +149 -149
  84. package/src/Invoice/ui/default/Buyer/index.less +219 -219
  85. package/src/Invoice/ui/default/Buyer/index.tsx +114 -114
  86. package/src/Invoice/ui/default/Buyer/ui/BuyerNameInput/index.tsx +166 -166
  87. package/src/Invoice/ui/default/Buyer/ui/ImportBuyerButton/index.tsx +21 -21
  88. package/src/Invoice/ui/default/EndowCodeDrawer/index.less +8 -8
  89. package/src/Invoice/ui/default/EndowCodeDrawer/index.tsx +431 -431
  90. package/src/Invoice/ui/default/GoodsList/hook/useColumns/autoFillFn/index.ts +533 -533
  91. package/src/Invoice/ui/default/GoodsList/hook/useColumns/index.tsx +664 -665
  92. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/Drag/index.less +20 -20
  93. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/Drag/index.tsx +202 -202
  94. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemCodeInput/index.less +18 -18
  95. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemCodeInput/index.tsx +58 -56
  96. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemNameInput/index.less +17 -17
  97. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemNameInput/index.tsx +128 -128
  98. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowEditButton/index.tsx +30 -30
  99. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/_useAddComparison/index.tsx +43 -43
  100. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useAddDiscount/index.tsx +76 -76
  101. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useDelItem/index.tsx +41 -41
  102. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useEndowCode/index.tsx +34 -34
  103. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/index.less +13 -13
  104. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/index.tsx +98 -98
  105. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowSaveButton/index.tsx +14 -14
  106. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/TitleText/index.tsx +20 -20
  107. package/src/Invoice/ui/default/GoodsList/hook/useDeduction/index.tsx +24 -24
  108. package/src/Invoice/ui/default/GoodsList/hook/useOnRow/index.tsx +39 -39
  109. package/src/Invoice/ui/default/GoodsList/hook/useRowSelection/index.tsx +111 -111
  110. package/src/Invoice/ui/default/GoodsList/hook/useWindowClick/index.tsx +23 -23
  111. package/src/Invoice/ui/default/GoodsList/index.less +177 -177
  112. package/src/Invoice/ui/default/GoodsList/index.tsx +191 -191
  113. package/src/Invoice/ui/default/GoodsList/ui/AddRowButton/index.tsx +65 -65
  114. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/index.less +21 -21
  115. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/index.tsx +244 -244
  116. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useCommodityComparisonButton/index.tsx +75 -75
  117. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useDelRowButton/index.tsx +69 -69
  118. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useEndowCodeButton/index.tsx +58 -58
  119. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useMergeDetails/index.tsx +37 -37
  120. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useMergeDiscount/index.tsx +36 -36
  121. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/index.tsx +37 -37
  122. package/src/Invoice/ui/default/GoodsList/ui/DescribeSwitch/index.tsx +36 -36
  123. package/src/Invoice/ui/default/GoodsList/ui/Search/index.less +10 -10
  124. package/src/Invoice/ui/default/GoodsList/ui/Search/index.tsx +52 -52
  125. package/src/Invoice/ui/default/GoodsList/ui/Statistics/index.less +18 -18
  126. package/src/Invoice/ui/default/GoodsList/ui/Statistics/index.tsx +109 -109
  127. package/src/Invoice/ui/default/GoodsList/ui/TableRow/index.less +13 -13
  128. package/src/Invoice/ui/default/GoodsList/ui/TableRow/index.tsx +46 -46
  129. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual/index.less +38 -38
  130. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual/index.tsx +108 -108
  131. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual.o/index.less +44 -44
  132. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual.o/index.tsx +96 -96
  133. package/src/Invoice/ui/default/GoodsList/ui/TaxIncludedSwitch/index.tsx +30 -30
  134. package/src/Invoice/ui/default/ImportBuyerDrawer/index.tsx +75 -75
  135. package/src/Invoice/ui/default/ImportGoodsDrawer/index.tsx +193 -193
  136. package/src/Invoice/ui/default/InvoiceHeader/index.less +68 -68
  137. package/src/Invoice/ui/default/InvoiceHeader/index.tsx +246 -246
  138. package/src/Invoice/ui/default/Seller/index.less +113 -113
  139. package/src/Invoice/ui/default/Seller/index.tsx +98 -98
  140. package/src/Invoice/ui/default/Sign/index.less +14 -14
  141. package/src/Invoice/ui/default/Sign/index.tsx +71 -71
  142. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/autoFillFn/index.ts +519 -519
  143. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/index.tsx +648 -648
  144. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/svg/plus.svg +11 -11
  145. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/Drag/index.less +20 -20
  146. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/Drag/index.tsx +186 -186
  147. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/ItemNameInput/index.less +9 -9
  148. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/ItemNameInput/index.tsx +50 -50
  149. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowEditButton/index.tsx +30 -30
  150. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/_useAddComparison/index.tsx +43 -43
  151. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/useAddDiscount/index.tsx +76 -76
  152. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/useDelItem/index.tsx +41 -41
  153. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/useEndowCode/index.tsx +34 -34
  154. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/index.less +13 -13
  155. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/index.tsx +98 -98
  156. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowSaveButton/index.tsx +14 -14
  157. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/TitleText/index.tsx +20 -20
  158. package/src/Invoice/ui/digtal/GoodsList/hook/useOnRow/index.tsx +39 -39
  159. package/src/Invoice/ui/digtal/GoodsList/hook/useRowSelection/index.tsx +121 -121
  160. package/src/Invoice/ui/digtal/GoodsList/hook/useWindowClick/index.tsx +23 -23
  161. package/src/Invoice/ui/digtal/GoodsList/index.less +56 -56
  162. package/src/Invoice/ui/digtal/GoodsList/index.tsx +180 -180
  163. package/src/Invoice/ui/digtal/GoodsList/ui/AddRowButton/index.tsx +65 -65
  164. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/index.tsx +341 -341
  165. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/svg/add.svg +11 -11
  166. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useCommodityComparisonButton/index.tsx +75 -75
  167. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useDelRowButton/index.tsx +50 -50
  168. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useEmptyRefill/index.tsx +35 -35
  169. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useEndowCodeButton/index.tsx +82 -82
  170. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useReselectInvoiceType/index.tsx +57 -57
  171. package/src/Invoice/ui/digtal/GoodsList/ui/DescribeSwitch/index.tsx +36 -36
  172. package/src/Invoice/ui/digtal/GoodsList/ui/Search/index.less +11 -11
  173. package/src/Invoice/ui/digtal/GoodsList/ui/Search/index.tsx +50 -50
  174. package/src/Invoice/ui/digtal/GoodsList/ui/Statistics/index.less +53 -53
  175. package/src/Invoice/ui/digtal/GoodsList/ui/Statistics/index.tsx +99 -99
  176. package/src/Invoice/ui/digtal/GoodsList/ui/Statistics/svg/fork.svg +11 -11
  177. package/src/Invoice/ui/digtal/GoodsList/ui/TableRow/index.less +13 -13
  178. package/src/Invoice/ui/digtal/GoodsList/ui/TableRow/index.tsx +40 -40
  179. package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual/index.less +38 -38
  180. package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual/index.tsx +108 -108
  181. package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual.o/index.less +44 -44
  182. package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual.o/index.tsx +96 -96
  183. package/src/Invoice/ui/digtal/GoodsList/ui/TaxIncludedSwitch/index.tsx +30 -30
  184. package/src/Invoice/ui/digtal/InvoiceHeader/index.less +57 -57
  185. package/src/Invoice/ui/digtal/InvoiceHeader/index.tsx +77 -77
  186. package/src/Invoice/ui/digtal/Sign/index.less +48 -48
  187. package/src/Invoice/ui/digtal/Sign/index.tsx +89 -89
  188. package/src/Invoice/ui/digtal/Stakeholder/index.less +75 -75
  189. package/src/Invoice/ui/digtal/Stakeholder/index.tsx +388 -388
  190. package/src/Invoice/ui/digtal/Stakeholder/svg/arrowDown.svg +2 -2
  191. package/src/Invoice/ui/digtal/Stakeholder/svg/arrowUp.svg +2 -2
  192. package/src/Invoice/ui/digtal/Stakeholder/svg/plus.svg +11 -11
  193. package/src/InvoiceTypeModal/_test/easiest/index.tsx +31 -31
  194. package/src/InvoiceTypeModal/index.less +7 -7
  195. package/src/InvoiceTypeModal/index.md +5 -5
  196. package/src/InvoiceTypeModal/index.tsx +153 -153
  197. package/src/index.ts +9 -9
  198. package/tsconfig.json +31 -31
  199. package/typings.d.ts +3 -3
  200. package/yarn.e.lock +14331 -14331
@@ -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,17 +1,17 @@
1
- import IGood from "../GoodsListState/IGood";
2
-
3
- /** 自动补全 */
4
- export default class AutoComplete {
5
-
6
- /** 商品名称自动补全 */
7
- onItemNameSearch?: (searchText: string) => Promise<IGood[]>;
8
-
9
- /** 购方名称自动补全 */
10
- onBuyerNameSearch?: (searchText: string) => Promise<any[]>;
11
-
12
- /** 统一社会信用代码/纳税人识别号 */
13
- onBuyerTaxIdSearch?: (searchText: string) => Promise<any[]>;
14
-
15
- /** 商品编码自动补全 */
16
- onItemCodeSearch?: (searchText: string, itemName: any) => Promise<any[]>;
17
- }
1
+ import IGood from "../GoodsListState/IGood";
2
+
3
+ /** 自动补全 */
4
+ export default class AutoComplete {
5
+
6
+ /** 商品名称自动补全 */
7
+ onItemNameSearch?: (searchText: string) => Promise<IGood[]>;
8
+
9
+ /** 购方名称自动补全 */
10
+ onBuyerNameSearch?: (searchText: string) => Promise<any[]>;
11
+
12
+ /** 统一社会信用代码/纳税人识别号 */
13
+ onBuyerTaxIdSearch?: (searchText: string) => Promise<any[]>;
14
+
15
+ /** 商品编码自动补全 */
16
+ onItemCodeSearch?: (searchText: string, itemName: any) => Promise<any[]>;
17
+ }
@@ -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,13 +1,13 @@
1
-
2
- /** 商品拖拽数据 */
3
- export default class Drag {
4
-
5
- /** 是否启用拖拽 */
6
- isStart: boolean = false;
7
-
8
- /** 当前拖动中的货品索引 */
9
- current?: string;
10
-
11
- /** 准备插入的货物索引 */
12
- container?: string;
1
+
2
+ /** 商品拖拽数据 */
3
+ export default class Drag {
4
+
5
+ /** 是否启用拖拽 */
6
+ isStart: boolean = false;
7
+
8
+ /** 当前拖动中的货品索引 */
9
+ current?: string;
10
+
11
+ /** 准备插入的货物索引 */
12
+ container?: string;
13
13
  }
@@ -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
+ }