kts-component-invoice-operate 3.2.113 → 3.2.115

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 (205) 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 +9 -9
  8. package/dist/index.esm.js +6260 -8719
  9. package/dist/index.js +6260 -8719
  10. package/docs/index.md +5 -5
  11. package/docs-dist/static/arrowDown.a1cbf0d8.svg +2 -2
  12. package/docs-dist/static/arrowUp.4c482054.svg +2 -2
  13. package/docs-dist/static/fork.5431267d.svg +11 -11
  14. package/docs-dist/static/plus.44013ce3.svg +11 -11
  15. package/docs-dist/static/plus.4fd1af30.svg +11 -11
  16. package/index.html +12 -12
  17. package/package.json +61 -61
  18. package/src/Invoice/Invoice-digtal/_test/disabled/index.tsx +38 -38
  19. package/src/Invoice/Invoice-digtal/_test/easiest/index.tsx +16 -16
  20. package/src/Invoice/Invoice-digtal/_test/header/index.tsx +84 -84
  21. package/src/Invoice/Invoice-digtal/_test/importGoods/index.tsx +554 -554
  22. package/src/Invoice/Invoice-digtal/_test/importStakeholder/index.tsx +17 -17
  23. package/src/Invoice/Invoice-digtal/_test/lineCredit/index.tsx +20 -20
  24. package/src/Invoice/Invoice-digtal/_test/prefab/index.tsx +150 -150
  25. package/src/Invoice/Invoice-digtal/_test/readOnly/index.tsx +42 -42
  26. package/src/Invoice/Invoice-digtal/_test/stakeholder/index.tsx +12 -12
  27. package/src/Invoice/Invoice-digtal/_test/typeSelection/index.tsx +29 -29
  28. package/src/Invoice/Invoice-digtal/index.md +30 -30
  29. package/src/Invoice/InvoiceController/InvoiceControllerForm/index.ts +95 -95
  30. package/src/Invoice/InvoiceController/InvoiceControllerState/AutoComplete/index.ts +20 -20
  31. package/src/Invoice/InvoiceController/InvoiceControllerState/BuyerState/index.tsx +88 -88
  32. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/Drag/index.ts +15 -15
  33. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/EndowCode/index.tsx +104 -104
  34. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/IColumnsReplenish/index.ts +10 -10
  35. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/IGood/index.ts +78 -78
  36. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/ImportGoods/index.ts +80 -80
  37. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/LineAttributeType/index.ts +7 -7
  38. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/ProductComparison/index.ts +9 -9
  39. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/index.ts +113 -113
  40. package/src/Invoice/InvoiceController/InvoiceControllerState/Stakeholder/index.ts +13 -13
  41. package/src/Invoice/InvoiceController/InvoiceControllerState/index.ts +65 -65
  42. package/src/Invoice/InvoiceController/fns/addGood.ts +11 -11
  43. package/src/Invoice/InvoiceController/fns/addGoodDiscount.ts +126 -126
  44. package/src/Invoice/InvoiceController/fns/addGoodDiscountV2.ts +86 -86
  45. package/src/Invoice/InvoiceController/fns/delGood.ts +41 -41
  46. package/src/Invoice/InvoiceController/fns/getGoodsSearch.ts +26 -26
  47. package/src/Invoice/InvoiceController/fns/importGoodsDrawer.ts +79 -79
  48. package/src/Invoice/InvoiceController/fns/itemBlur.ts +40 -40
  49. package/src/Invoice/InvoiceController/fns/mergeDetails.ts +201 -201
  50. package/src/Invoice/InvoiceController/fns/mergeDiscount.ts +35 -35
  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 +81 -81
  56. package/src/Invoice/_test/buyerNameSearch/index.tsx +42 -42
  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 +1158 -1158
  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 +1197 -1197
  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 +167 -167
  74. package/src/Invoice/tools/calculate/index.ts +124 -124
  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 +543 -543
  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 +687 -687
  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 +205 -205
  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 +47 -47
  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 +88 -88
  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 +118 -118
  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 +25 -25
  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 +114 -114
  110. package/src/Invoice/ui/default/GoodsList/hook/useWindowClick/index.tsx +23 -23
  111. package/src/Invoice/ui/default/GoodsList/index.less +179 -179
  112. package/src/Invoice/ui/default/GoodsList/index.tsx +205 -205
  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 +65 -65
  119. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useMergeDetails/index.tsx +91 -91
  120. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useMergeDiscount/index.tsx +36 -36
  121. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useSalesDiscount/index.tsx +109 -109
  122. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useSalesGifts/index.tsx +88 -88
  123. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/index.tsx +37 -37
  124. package/src/Invoice/ui/default/GoodsList/ui/DescribeSwitch/index.tsx +36 -36
  125. package/src/Invoice/ui/default/GoodsList/ui/Search/index.less +10 -10
  126. package/src/Invoice/ui/default/GoodsList/ui/Search/index.tsx +52 -52
  127. package/src/Invoice/ui/default/GoodsList/ui/Statistics/index.less +18 -18
  128. package/src/Invoice/ui/default/GoodsList/ui/Statistics/index.tsx +113 -113
  129. package/src/Invoice/ui/default/GoodsList/ui/TableRow/index.less +28 -28
  130. package/src/Invoice/ui/default/GoodsList/ui/TableRow/index.tsx +57 -57
  131. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual/index.less +38 -38
  132. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual/index.tsx +108 -108
  133. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual.o/index.less +44 -44
  134. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual.o/index.tsx +96 -96
  135. package/src/Invoice/ui/default/GoodsList/ui/TaxIncludedSwitch/index.tsx +30 -30
  136. package/src/Invoice/ui/default/ImportBuyerDrawer/index.tsx +75 -75
  137. package/src/Invoice/ui/default/ImportGoodsDrawer/index.tsx +198 -201
  138. package/src/Invoice/ui/default/InvoiceHeader/index.less +68 -68
  139. package/src/Invoice/ui/default/InvoiceHeader/index.tsx +246 -246
  140. package/src/Invoice/ui/default/Seller/index.less +113 -113
  141. package/src/Invoice/ui/default/Seller/index.tsx +98 -98
  142. package/src/Invoice/ui/default/Sign/index.less +14 -14
  143. package/src/Invoice/ui/default/Sign/index.tsx +71 -71
  144. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/autoFillFn/index.ts +519 -519
  145. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/index.tsx +650 -650
  146. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/svg/plus.svg +11 -11
  147. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/Drag/index.less +20 -20
  148. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/Drag/index.tsx +205 -205
  149. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/ItemNameInput/index.less +9 -9
  150. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/ItemNameInput/index.tsx +77 -77
  151. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowEditButton/index.tsx +30 -30
  152. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/_useAddComparison/index.tsx +43 -43
  153. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/useAddDiscount/index.tsx +76 -76
  154. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/useDelItem/index.tsx +41 -41
  155. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/useEndowCode/index.tsx +34 -34
  156. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/index.less +13 -13
  157. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/index.tsx +98 -98
  158. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowSaveButton/index.tsx +14 -14
  159. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/TitleText/index.tsx +20 -20
  160. package/src/Invoice/ui/digtal/GoodsList/hook/useOnRow/index.tsx +39 -39
  161. package/src/Invoice/ui/digtal/GoodsList/hook/useRowSelection/index.tsx +121 -121
  162. package/src/Invoice/ui/digtal/GoodsList/hook/useWindowClick/index.tsx +23 -23
  163. package/src/Invoice/ui/digtal/GoodsList/index.less +56 -56
  164. package/src/Invoice/ui/digtal/GoodsList/index.tsx +180 -180
  165. package/src/Invoice/ui/digtal/GoodsList/ui/AddRowButton/index.tsx +65 -65
  166. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/index.tsx +339 -339
  167. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/svg/add.svg +11 -11
  168. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useCommodityComparisonButton/index.tsx +75 -75
  169. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useDelRowButton/index.tsx +50 -50
  170. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useEmptyRefill/index.tsx +35 -35
  171. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useEndowCodeButton/index.tsx +82 -82
  172. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useReselectInvoiceType/index.tsx +57 -57
  173. package/src/Invoice/ui/digtal/GoodsList/ui/DescribeSwitch/index.tsx +36 -36
  174. package/src/Invoice/ui/digtal/GoodsList/ui/Search/index.less +11 -11
  175. package/src/Invoice/ui/digtal/GoodsList/ui/Search/index.tsx +50 -50
  176. package/src/Invoice/ui/digtal/GoodsList/ui/Statistics/index.less +53 -53
  177. package/src/Invoice/ui/digtal/GoodsList/ui/Statistics/index.tsx +99 -99
  178. package/src/Invoice/ui/digtal/GoodsList/ui/Statistics/svg/fork.svg +11 -11
  179. package/src/Invoice/ui/digtal/GoodsList/ui/TableRow/index.less +28 -28
  180. package/src/Invoice/ui/digtal/GoodsList/ui/TableRow/index.tsx +53 -53
  181. package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual/index.less +38 -38
  182. package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual/index.tsx +108 -108
  183. package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual.o/index.less +44 -44
  184. package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual.o/index.tsx +96 -96
  185. package/src/Invoice/ui/digtal/GoodsList/ui/TaxIncludedSwitch/index.tsx +30 -30
  186. package/src/Invoice/ui/digtal/InvoiceHeader/index.less +57 -57
  187. package/src/Invoice/ui/digtal/InvoiceHeader/index.tsx +77 -77
  188. package/src/Invoice/ui/digtal/Sign/index.less +48 -48
  189. package/src/Invoice/ui/digtal/Sign/index.tsx +99 -99
  190. package/src/Invoice/ui/digtal/Stakeholder/index.less +90 -75
  191. package/src/Invoice/ui/digtal/Stakeholder/index.tsx +394 -394
  192. package/src/Invoice/ui/digtal/Stakeholder/svg/arrowDown.svg +2 -2
  193. package/src/Invoice/ui/digtal/Stakeholder/svg/arrowUp.svg +2 -2
  194. package/src/Invoice/ui/digtal/Stakeholder/svg/plus.svg +11 -11
  195. package/src/InvoiceTypeModal/_test/easiest/index.tsx +31 -31
  196. package/src/InvoiceTypeModal/index.less +7 -7
  197. package/src/InvoiceTypeModal/index.md +5 -5
  198. package/src/InvoiceTypeModal/index.tsx +153 -153
  199. package/src/TaxClassificationCodeModal/_test/easiest/index.tsx +177 -177
  200. package/src/TaxClassificationCodeModal/index.md +6 -6
  201. package/src/TaxClassificationCodeModal/index.tsx +74 -74
  202. package/src/index.ts +12 -12
  203. package/tsconfig.json +31 -31
  204. package/typings.d.ts +3 -3
  205. package/yarn.e.lock +14331 -14331
@@ -1,543 +1,543 @@
1
- import React from 'react';
2
- import Invoice from '../../..';
3
- import { Button, Drawer, Select, Modal, Input as InputAntd, Form, Tree, message } from 'kts-components-antd-x3';
4
- import { chain, bignumber } from 'mathjs';
5
- import { Input, NumberPicker } from '@formily/antd-components';
6
- import { format15 } from '../GoodsList/hook/useColumns/autoFillFn';
7
- import { LineAttributeType } from '../../../InvoiceController';
8
- import IGood from '../../../InvoiceController/InvoiceControllerState/GoodsListState/IGood';
9
- import { countTaxAmount } from '../../../tools/calculate';
10
- import { bytesLnegth, cutStr } from '../../../tools/strringFn';
11
- import {
12
- SchemaForm,
13
- FormButtonGroup,
14
- createAsyncFormActions,
15
- SchemaMarkupField as Field,
16
- FormEffectHooks,
17
- } from '@formily/antd';
18
- import './index.less';
19
- import { TaxClassificationModal } from "../../../..";
20
-
21
- const { TreeNode } = Tree;
22
- const { confirm } = Modal;
23
-
24
- export default () => {
25
- const controller = Invoice.useInvoiceController();
26
-
27
- const visible = controller.useMemo(s => s.goodsListState.endowCode.endowcodeGoodIndex.length > 0, []);
28
-
29
- const [defaultValue, setDefaultValue] = React.useState<IGood>();
30
-
31
- const onClose = React.useCallback(() => {
32
- controller.pipeline(async (s) => {
33
- s.goodsListState.endowCode.endowcodeGoodIndex = [];
34
- })();
35
- }, [controller]);
36
-
37
- // 计算赋码默认值
38
- React.useEffect(() => {
39
- if (visible) {
40
- controller.pipeline(async s => {
41
- const endowcodeGoodIndex = s.goodsListState.endowCode.endowcodeGoodIndex.filter(i => {
42
- const good = s.goodsListState.goodsMap.get(i);
43
- if (!good) return false;
44
-
45
- return good.lineAttribute !== LineAttributeType.折扣行;
46
- })
47
-
48
- const good = s.goodsListState.goodsMap.get(s.goodsListState.endowCode.endowcodeGoodIndex[0]);
49
- if (!good) return;
50
-
51
- const getDefaultValue = s.goodsListState.endowCode.getDefaultValue;
52
- if (getDefaultValue) {
53
- setDefaultValue(await getDefaultValue({ ...good }, endowcodeGoodIndex.length));
54
- } else {
55
- if (endowcodeGoodIndex.length === 1) {
56
- setDefaultValue(good);
57
- } else {
58
- setDefaultValue({ taxRate: good.taxRate } as any);
59
- }
60
- }
61
- })()
62
- } else {
63
- setDefaultValue(undefined);
64
- }
65
- }, [visible])
66
-
67
- return (
68
- <Drawer
69
- title="赋码"
70
- placement="right"
71
- destroyOnClose={true}
72
- closable={false}
73
- width={383}
74
- onClose={onClose}
75
- visible={visible}
76
- >
77
- {defaultValue && <DrawerBody defaultValue={defaultValue} />}
78
- </Drawer>
79
- );
80
- };
81
-
82
- const DrawerBody = (props: { defaultValue: IGood }) => {
83
-
84
- const controller = Invoice.useInvoiceController();
85
-
86
- const { defaultValue } = props;
87
-
88
- const actions = React.useMemo(() => createAsyncFormActions(), []);
89
-
90
- const taxClassificationProps = controller.useMemo(s => s.taxClassificationProps, []);
91
-
92
- /** 免税类型 是否需要 */
93
- const isTaxFreeTypeNeeded = controller.useMemo(s => s.goodsListState.endowCode.isTaxFreeTypeNeeded, []);
94
-
95
- /** 税率 是否禁用 */
96
- const readOnlyTaxRate = controller.useMemo(s => {
97
- if (s.goodsListState.endowCode.getReadOnlyTaxRate) {
98
- return s.goodsListState.endowCode.getReadOnlyTaxRate(s.goodsListState);
99
- } else {
100
- return false;
101
- }
102
- }, [])
103
-
104
- /** 优惠政策 是否禁用 */
105
- const readOnlyFavouredPolicy = controller.useMemo(s => {
106
- if (s.goodsListState.endowCode.getReadOnlyFavouredPolicy) {
107
- return s.goodsListState.endowCode.getReadOnlyFavouredPolicy(s.goodsListState);
108
- } else {
109
- return false;
110
- }
111
- }, [])
112
-
113
- /** 税率列表 */
114
- const taxRateList = controller.useMemo(s => s.goodsListState.taxRateList.map((e) => ({ label: `${e}%`, value: e })), []);
115
-
116
- /** 免税类型 列表 */
117
- const taxFreeTypeList = controller.useMemo(s => s.goodsListState.endowCode.taxFreeTypeList, []);
118
-
119
- /** 优惠政策类型列表 */
120
- const favouredPolicyNameList = controller.useMemo(s => s.goodsListState.endowCode.favouredPolicyNameList, []);
121
-
122
- /** 优惠政策类型列表 */
123
- // const getTaxCategoryCodeTree = controller.useMemo(s => s.goodsListState.endowCode.getTaxCategoryCodeTree, []);
124
-
125
- /** 税率 */
126
- const [taxRate, setTaxRate] = React.useState<number>(0);
127
-
128
- /** 税收分类编码 选择组件 */
129
- const ShowSearch = React.useCallback(props => {
130
-
131
- const [dataSource, setDataSource] = React.useState<any[]>([]);
132
-
133
- const onSearch = React.useCallback(async e => {
134
- const arr = await controller.state.goodsListState.endowCode.getTaxCategoryCodeList(e);
135
- setDataSource(arr);
136
- }, [])
137
-
138
- const onChange = React.useCallback((value: string) => {
139
- if (props.onChange) {
140
- props.onChange(value);
141
- }
142
-
143
- const info = dataSource.filter(i => i.value === value)[0];
144
- if (!info) return;
145
-
146
- !readOnlyTaxRate && actions.setFieldState('taxRate', async s => {
147
- if (info.taxRate || info.taxRate === 0) {
148
- s.value = info.taxRate
149
- }
150
- });
151
-
152
- actions.setFieldState('shorthand', async (s) => {
153
- if (info.shorthand) {
154
- s.value = info.shorthand
155
- }
156
- });
157
- }, [actions, dataSource, readOnlyTaxRate])
158
-
159
- return (
160
- <Select
161
- {...props}
162
- showSearch
163
- showArrow={false}
164
- notFoundContent={null}
165
- filterOption={false}
166
- onSearch={onSearch}
167
- onChange={onChange}
168
- >
169
- {dataSource.map(e => <Select.Option key={e.value} value={e.value}>{e.label}</Select.Option>)}
170
- </Select>
171
- )
172
- }, [controller, actions])
173
-
174
- /** 税收分类编码 选择组件2 */
175
- const ShowSearch2 = React.useCallback(props => {
176
-
177
- // 是否显示
178
- const [visible, setVisible] = React.useState(false);
179
-
180
- // 税收分类编码树
181
- const [list, setList] = React.useState<any[]>();
182
-
183
- // 搜索条件
184
- const [filter, setFilter] = React.useState<{
185
- /** 税收分类编码 */
186
- taxCategoryCode?: string,
187
-
188
- /** 货物和劳务名称/简称 */
189
- val?: string
190
- }>();
191
-
192
- /** 创建 树节点 */
193
- const createTreeNode = React.useCallback(() => {
194
- if (!list) return <></>;
195
-
196
- return ctn(list);
197
-
198
- function title(label: string) {
199
- if (!filter) return label;
200
- label = (filter.taxCategoryCode ? label.split(new RegExp(filter.taxCategoryCode, 'g')) : [label]).join(`<span style="color: #1890ff;">${filter.taxCategoryCode}</span>`);
201
- label = (filter.val ? label.split(new RegExp(filter.val, 'g')) : [label]).join(`<span style="color: #1890ff;">${filter.val}</span>`);
202
- return <span dangerouslySetInnerHTML={{ __html: label }} />
203
- }
204
-
205
- function ctn(l: any[], p = '0') {
206
- if (!l || !l.length) return [<></>];
207
- return l.filter(e => e.pid === p).map(e => {
208
- return (
209
- <TreeNode title={title(e.label)} key={e.id}>
210
- {ctn(l, e.id)}
211
- </TreeNode>
212
- )
213
- })
214
- }
215
- }, [list, filter])
216
-
217
- /** 点击了节点 */
218
- const onSelect = React.useCallback((e: string[]) => {
219
- const id = e[0];
220
-
221
- // 是否叶子节点
222
- if (list?.filter(e => e.pid === id).length !== 0) { return; }
223
-
224
- const info = list?.filter(e => e.id === id)[0];
225
-
226
- !readOnlyTaxRate && actions.setFieldState('taxRate', async s => {
227
- if (info.taxRate || info.taxRate === 0) {
228
- s.value = info.taxRate
229
- }
230
- });
231
-
232
- actions.setFieldState('taxClassificationCode', async s => {
233
- if (info.id) {
234
- s.value = info.id
235
- }
236
- });
237
-
238
- actions.setFieldState('shorthand', async (s) => {
239
- if (info.shorthand) {
240
- s.value = info.shorthand
241
- }
242
- });
243
-
244
- setVisible(false);
245
- }, [list, actions, readOnlyTaxRate])
246
-
247
- React.useEffect(() => {
248
- (async () => {
249
- const fn = controller.state.goodsListState.endowCode.getTaxCategoryCodeTree || (async () => []);
250
- const list = await fn(filter?.taxCategoryCode, filter?.val);
251
- setList(list || []);
252
- })()
253
- }, [filter])
254
-
255
- React.useEffect(() => {
256
- if (visible) {
257
- setList([])
258
- }
259
- }, [visible])
260
-
261
- return (
262
- <>
263
- <InputAntd readOnly value={props.value} addonAfter={<Button size="small" type="link" onClick={() => { setVisible(true) }} >点击选择</Button>} />
264
- <Drawer
265
- title="税收分类编码"
266
- visible={visible}
267
- width={500}
268
- onClose={() => { setVisible(false) }}
269
- >
270
- <Form key={`${visible}`} >
271
- <Form.Item label="产品或服务简称" >
272
- <InputAntd onChange={e => { setFilter({ ...filter, val: e.target.value }) }} />
273
- </Form.Item>
274
- <Form.Item label="税收分类编码">
275
- <InputAntd onChange={e => { setFilter({ ...filter, taxCategoryCode: e.target.value }) }} />
276
- </Form.Item>
277
- </Form>
278
- {
279
- (list && list.length > 0)
280
- ? <Tree
281
- defaultExpandAll
282
- selectedKeys={[]}
283
- onSelect={onSelect}
284
- >
285
- {createTreeNode()}
286
- </Tree>
287
- : <span style={{ color: '#00000073' }} >请输入“产品或服务简称”或“税收分类编码”查找数据。</span>
288
- }
289
- </Drawer>
290
- </>
291
- )
292
- }, [controller, actions])
293
-
294
- /** 税收分类编码 选择组件3 */
295
- const ShowSearch3 = React.useCallback(props => {
296
- const [open, setOpen] = React.useState(false);
297
-
298
- const [list, setList] = React.useState<any>([]);
299
-
300
- const onSearch = React.useCallback(async (value: any = null) => {
301
- if(value?.target?.value){
302
- const arr = await controller.state.goodsListState.endowCode.onSearchTaxClassificationCode(value?.target?.value);
303
- const list: any[] = arr.map((item: any)=> {
304
- return {
305
- ...item,
306
- title: `${item.productName} ${item.taxCategoryCode}`,
307
- key: item.taxCategoryCode,
308
- isLeaf: true
309
- }
310
- });
311
- setList(list);
312
- } else {
313
- await onLoad();
314
- }
315
- }, []);
316
-
317
- const onLoad = React.useCallback(async (value?: any) => {
318
- const arr = await controller.state.goodsListState.endowCode.onLoadTaxClassificationCode(value?.taxCategoryCode);
319
- const data: any[] = arr.map((item: any)=> {
320
- return {
321
- ...item,
322
- title: `${item.productName} ${item.taxCategoryCode}`,
323
- key: item.taxCategoryCode
324
- }
325
- });
326
-
327
- const treeData = optimizeTreeData(data);
328
-
329
- if(value?.key) {
330
- setList((origin: any)=> {
331
- updateTreeData(origin, value.key, treeData)
332
- });
333
- } else {
334
- setList(treeData);
335
- }
336
- return [];
337
- }, []);
338
-
339
- const onClick = React.useCallback(async () => {
340
- setOpen(true);
341
- await onLoad();
342
- }, []);
343
-
344
- const onSelect = React.useCallback((key: any, info: any) => {
345
- actions.setFieldState('taxClassificationCode', async s => {
346
- s.value = info.node.taxCategoryCode
347
- });
348
-
349
- actions.setFieldState('shorthand', async (s) => {
350
- s.value = info.node.shorthand
351
- });
352
- actions.setFieldState('taxRate', async s => {
353
- s.value = info.node.taxRate
354
- });
355
- setOpen(false);
356
- }, [controller, actions]);
357
-
358
- const optimizeTreeData = (data: any): any => {
359
- return data.map((item: any)=> {
360
- return {
361
- ...item,
362
- selectable: item?.hzx === 'N',
363
- isLeaf: item?.hzx === 'N'
364
- }
365
- });
366
- }
367
-
368
- const updateTreeData = (list: any, key: React.Key, children: any): any => {
369
- const data = list.map((node: any) => {
370
- if (node.key === key) {
371
- return {
372
- ...node,
373
- children
374
- };
375
- }
376
- if (node.children) {
377
- return {
378
- ...node,
379
- children: updateTreeData(node.children, key, children)
380
- };
381
- }
382
- return node;
383
- });
384
- setList(data);
385
- return data;
386
- }
387
-
388
- return (
389
- <>
390
- <InputAntd readOnly onClick={onClick} value={props.value} />
391
- <TaxClassificationModal
392
- list={list}
393
- open={open}
394
- onSelect={onSelect}
395
- onCancel={()=> {setOpen(false)}}
396
- onSearch={onSearch}
397
- onLoad={onLoad}
398
- />
399
- </>
400
- )
401
- }, [controller, actions])
402
-
403
- // 是否享受优惠政策
404
- const [favouredPolicyMark, setFavouredPolicyMark] = React.useState<number>(0);
405
-
406
- // 确定
407
- const onSubmit = React.useCallback(values => {
408
- controller.pipeline(async s => {
409
-
410
- const endowCodeGood = s.goodsListState.endowCode.endowcodeGoodIndex.map(e => s.goodsListState.goodsMap.get(e));
411
-
412
- // 赋码
413
- endowCodeGood.forEach(good => {
414
- if (!good) return;
415
-
416
- good.shorthand = values.shorthand;
417
- good.taxClassificationCode = values.taxClassificationCode;
418
- good.taxRate = values.taxRate;
419
- good.taxFreeType = values.taxFreeType;
420
- good.favouredPolicyMark = values.favouredPolicyMark;
421
- good.favouredPolicyName = values.favouredPolicyName;
422
-
423
- const taxRate = chain(bignumber(values.taxRate)).dotDivide(bignumber(100)).add(bignumber(1)).done();
424
-
425
- // 是否含税
426
- const lineAmountExcludeTax = chain(bignumber(good.lineAmountIncludeTax)).dotDivide(taxRate).done();
427
- const priceExcludeTax = good.priceIncludeTax ? chain(bignumber(good.priceIncludeTax)).dotDivide(taxRate).done() : undefined
428
-
429
- good.lineAmountExcludeTax = lineAmountExcludeTax.toNumber().toFixed(2);
430
- good.priceExcludeTax = (priceExcludeTax ? format15(priceExcludeTax.toNumber(), s.calculatingDigits) : undefined) || undefined;
431
-
432
- good.taxAmount = countTaxAmount(good.lineAmountIncludeTax || 0, s.goodsListState.deduction, values.taxRate);
433
- });
434
-
435
- s.goodsListState.goodsList = s.goodsListState.goodsList.slice();
436
- s.goodsListState.endowCode.endowcodeGoodIndex = [];
437
- })();
438
- }, [controller]);
439
-
440
- const effects = React.useCallback(() => {
441
- // 税率变化
442
- FormEffectHooks.onFieldValueChange$('taxRate').subscribe((e) => {
443
- setTaxRate(e.value);
444
- actions.setFieldState('taxFreeType', async (s) => {
445
- if (e.value !== 0)
446
- s.value = undefined;
447
- });
448
- });
449
-
450
- // 是否享受优惠政策
451
- FormEffectHooks.onFieldValueChange$('favouredPolicyMark').subscribe((e) => {
452
- setFavouredPolicyMark(e.value);
453
- actions.setFieldState('favouredPolicyName', async (s) => {
454
- if (e.value === 0)
455
- s.value = undefined;
456
- });
457
- });
458
- }, [actions]);
459
-
460
- // 更新 税收分类编码列表
461
- React.useEffect(() => {
462
- if (controller.getTaxCategoryCodeList) controller.getTaxCategoryCodeList();
463
- }, [controller]);
464
-
465
- return (
466
- <SchemaForm actions={actions} previewPlaceholder=" " components={{ ...components, showSearch: !!controller.state.goodsListState.endowCode.onLoadTaxClassificationCode ? ShowSearch3 : ShowSearch }} effects={effects}>
467
- <FormButtonGroup>
468
- <Field
469
- name="taxClassificationCode"
470
- type="showSearch"
471
- title="税收分类编码"
472
- // enum={taxCategoryCodeList}
473
- default={defaultValue?.taxClassificationCode}
474
- x-rules={[{ message: '请选择税收分类编码', required: true }]}
475
- />
476
- <Field
477
- name="shorthand"
478
- type="string"
479
- readOnly
480
- default={defaultValue?.shorthand}
481
- title="商品和服务分类简称"
482
- />
483
- <Field
484
- name="taxRate"
485
- type="string"
486
- title="税率"
487
- x-component-props={{ disabled: readOnlyTaxRate }}
488
- default={defaultValue?.taxRate ?? 0}
489
- enum={taxRateList}
490
- x-rules={[{ message: '请选择税率', required: true }]}
491
- />
492
- {taxRate === 0 && isTaxFreeTypeNeeded &&
493
- <Field
494
- name="taxFreeType"
495
- type="string"
496
- title="免税类型"
497
- x-component-props={{ disabled: readOnlyTaxRate }}
498
- default={defaultValue?.taxFreeType}
499
- enum={taxFreeTypeList}
500
- x-rules={[{ message: '请选择免税类型', required: true }]}
501
- />
502
- }
503
- <Field
504
- name="favouredPolicyMark"
505
- type="number"
506
- title="是否享受优惠政策"
507
- x-component-props={{ disabled: readOnlyFavouredPolicy }}
508
- enum={[
509
- { label: '是', value: 1 },
510
- { label: '否', value: 0 },
511
- ]}
512
- default={defaultValue?.favouredPolicyMark ?? 0}
513
- x-rules={[{ message: '请选择是否享受优惠政策', required: true }]}
514
- />
515
- {favouredPolicyMark === 1 &&
516
- <Field
517
- name="favouredPolicyName"
518
- type="string"
519
- title="优惠政策类型"
520
- x-component-props={{ disabled: readOnlyFavouredPolicy }}
521
- enum={favouredPolicyNameList}
522
- default={defaultValue?.favouredPolicyName}
523
- x-rules={[{ message: '请选择是否享受优惠政策', required: true }]}
524
- />
525
- }
526
- </FormButtonGroup>
527
-
528
- <span className="kts-invoice-operate-goods-endow-code-button-list">
529
- <Button onClick={() => { actions.submit(onSubmit) }} type="primary">
530
- 确定
531
- </Button>
532
- <Button onClick={() => { controller.pipeline(async s => (s.goodsListState.endowCode.endowcodeGoodIndex = []))() }}>
533
- 取消
534
- </Button>
535
- </span>
536
- </SchemaForm>
537
- );
538
- };
539
-
540
- const components = {
541
- string: Input,
542
- number: NumberPicker,
543
- };
1
+ import React from 'react';
2
+ import Invoice from '../../..';
3
+ import { Button, Drawer, Select, Modal, Input as InputAntd, Form, Tree, message } from 'kts-components-antd-x3';
4
+ import { chain, bignumber } from 'mathjs';
5
+ import { Input, NumberPicker } from '@formily/antd-components';
6
+ import { format15 } from '../GoodsList/hook/useColumns/autoFillFn';
7
+ import { LineAttributeType } from '../../../InvoiceController';
8
+ import IGood from '../../../InvoiceController/InvoiceControllerState/GoodsListState/IGood';
9
+ import { countTaxAmount } from '../../../tools/calculate';
10
+ import { bytesLnegth, cutStr } from '../../../tools/strringFn';
11
+ import {
12
+ SchemaForm,
13
+ FormButtonGroup,
14
+ createAsyncFormActions,
15
+ SchemaMarkupField as Field,
16
+ FormEffectHooks,
17
+ } from '@formily/antd';
18
+ import './index.less';
19
+ import { TaxClassificationModal } from "../../../..";
20
+
21
+ const { TreeNode } = Tree;
22
+ const { confirm } = Modal;
23
+
24
+ export default () => {
25
+ const controller = Invoice.useInvoiceController();
26
+
27
+ const visible = controller.useMemo(s => s.goodsListState.endowCode.endowcodeGoodIndex.length > 0, []);
28
+
29
+ const [defaultValue, setDefaultValue] = React.useState<IGood>();
30
+
31
+ const onClose = React.useCallback(() => {
32
+ controller.pipeline(async (s) => {
33
+ s.goodsListState.endowCode.endowcodeGoodIndex = [];
34
+ })();
35
+ }, [controller]);
36
+
37
+ // 计算赋码默认值
38
+ React.useEffect(() => {
39
+ if (visible) {
40
+ controller.pipeline(async s => {
41
+ const endowcodeGoodIndex = s.goodsListState.endowCode.endowcodeGoodIndex.filter(i => {
42
+ const good = s.goodsListState.goodsMap.get(i);
43
+ if (!good) return false;
44
+
45
+ return good.lineAttribute !== LineAttributeType.折扣行;
46
+ })
47
+
48
+ const good = s.goodsListState.goodsMap.get(s.goodsListState.endowCode.endowcodeGoodIndex[0]);
49
+ if (!good) return;
50
+
51
+ const getDefaultValue = s.goodsListState.endowCode.getDefaultValue;
52
+ if (getDefaultValue) {
53
+ setDefaultValue(await getDefaultValue({ ...good }, endowcodeGoodIndex.length));
54
+ } else {
55
+ if (endowcodeGoodIndex.length === 1) {
56
+ setDefaultValue(good);
57
+ } else {
58
+ setDefaultValue({ taxRate: good.taxRate } as any);
59
+ }
60
+ }
61
+ })()
62
+ } else {
63
+ setDefaultValue(undefined);
64
+ }
65
+ }, [visible])
66
+
67
+ return (
68
+ <Drawer
69
+ title="赋码"
70
+ placement="right"
71
+ destroyOnClose={true}
72
+ closable={false}
73
+ width={383}
74
+ onClose={onClose}
75
+ visible={visible}
76
+ >
77
+ {defaultValue && <DrawerBody defaultValue={defaultValue} />}
78
+ </Drawer>
79
+ );
80
+ };
81
+
82
+ const DrawerBody = (props: { defaultValue: IGood }) => {
83
+
84
+ const controller = Invoice.useInvoiceController();
85
+
86
+ const { defaultValue } = props;
87
+
88
+ const actions = React.useMemo(() => createAsyncFormActions(), []);
89
+
90
+ const taxClassificationProps = controller.useMemo(s => s.taxClassificationProps, []);
91
+
92
+ /** 免税类型 是否需要 */
93
+ const isTaxFreeTypeNeeded = controller.useMemo(s => s.goodsListState.endowCode.isTaxFreeTypeNeeded, []);
94
+
95
+ /** 税率 是否禁用 */
96
+ const readOnlyTaxRate = controller.useMemo(s => {
97
+ if (s.goodsListState.endowCode.getReadOnlyTaxRate) {
98
+ return s.goodsListState.endowCode.getReadOnlyTaxRate(s.goodsListState);
99
+ } else {
100
+ return false;
101
+ }
102
+ }, [])
103
+
104
+ /** 优惠政策 是否禁用 */
105
+ const readOnlyFavouredPolicy = controller.useMemo(s => {
106
+ if (s.goodsListState.endowCode.getReadOnlyFavouredPolicy) {
107
+ return s.goodsListState.endowCode.getReadOnlyFavouredPolicy(s.goodsListState);
108
+ } else {
109
+ return false;
110
+ }
111
+ }, [])
112
+
113
+ /** 税率列表 */
114
+ const taxRateList = controller.useMemo(s => s.goodsListState.taxRateList.map((e) => ({ label: `${e}%`, value: e })), []);
115
+
116
+ /** 免税类型 列表 */
117
+ const taxFreeTypeList = controller.useMemo(s => s.goodsListState.endowCode.taxFreeTypeList, []);
118
+
119
+ /** 优惠政策类型列表 */
120
+ const favouredPolicyNameList = controller.useMemo(s => s.goodsListState.endowCode.favouredPolicyNameList, []);
121
+
122
+ /** 优惠政策类型列表 */
123
+ // const getTaxCategoryCodeTree = controller.useMemo(s => s.goodsListState.endowCode.getTaxCategoryCodeTree, []);
124
+
125
+ /** 税率 */
126
+ const [taxRate, setTaxRate] = React.useState<number>(0);
127
+
128
+ /** 税收分类编码 选择组件 */
129
+ const ShowSearch = React.useCallback(props => {
130
+
131
+ const [dataSource, setDataSource] = React.useState<any[]>([]);
132
+
133
+ const onSearch = React.useCallback(async e => {
134
+ const arr = await controller.state.goodsListState.endowCode.getTaxCategoryCodeList(e);
135
+ setDataSource(arr);
136
+ }, [])
137
+
138
+ const onChange = React.useCallback((value: string) => {
139
+ if (props.onChange) {
140
+ props.onChange(value);
141
+ }
142
+
143
+ const info = dataSource.filter(i => i.value === value)[0];
144
+ if (!info) return;
145
+
146
+ !readOnlyTaxRate && actions.setFieldState('taxRate', async s => {
147
+ if (info.taxRate || info.taxRate === 0) {
148
+ s.value = info.taxRate
149
+ }
150
+ });
151
+
152
+ actions.setFieldState('shorthand', async (s) => {
153
+ if (info.shorthand) {
154
+ s.value = info.shorthand
155
+ }
156
+ });
157
+ }, [actions, dataSource, readOnlyTaxRate])
158
+
159
+ return (
160
+ <Select
161
+ {...props}
162
+ showSearch
163
+ showArrow={false}
164
+ notFoundContent={null}
165
+ filterOption={false}
166
+ onSearch={onSearch}
167
+ onChange={onChange}
168
+ >
169
+ {dataSource.map(e => <Select.Option key={e.value} value={e.value}>{e.label}</Select.Option>)}
170
+ </Select>
171
+ )
172
+ }, [controller, actions])
173
+
174
+ /** 税收分类编码 选择组件2 */
175
+ const ShowSearch2 = React.useCallback(props => {
176
+
177
+ // 是否显示
178
+ const [visible, setVisible] = React.useState(false);
179
+
180
+ // 税收分类编码树
181
+ const [list, setList] = React.useState<any[]>();
182
+
183
+ // 搜索条件
184
+ const [filter, setFilter] = React.useState<{
185
+ /** 税收分类编码 */
186
+ taxCategoryCode?: string,
187
+
188
+ /** 货物和劳务名称/简称 */
189
+ val?: string
190
+ }>();
191
+
192
+ /** 创建 树节点 */
193
+ const createTreeNode = React.useCallback(() => {
194
+ if (!list) return <></>;
195
+
196
+ return ctn(list);
197
+
198
+ function title(label: string) {
199
+ if (!filter) return label;
200
+ label = (filter.taxCategoryCode ? label.split(new RegExp(filter.taxCategoryCode, 'g')) : [label]).join(`<span style="color: #1890ff;">${filter.taxCategoryCode}</span>`);
201
+ label = (filter.val ? label.split(new RegExp(filter.val, 'g')) : [label]).join(`<span style="color: #1890ff;">${filter.val}</span>`);
202
+ return <span dangerouslySetInnerHTML={{ __html: label }} />
203
+ }
204
+
205
+ function ctn(l: any[], p = '0') {
206
+ if (!l || !l.length) return [<></>];
207
+ return l.filter(e => e.pid === p).map(e => {
208
+ return (
209
+ <TreeNode title={title(e.label)} key={e.id}>
210
+ {ctn(l, e.id)}
211
+ </TreeNode>
212
+ )
213
+ })
214
+ }
215
+ }, [list, filter])
216
+
217
+ /** 点击了节点 */
218
+ const onSelect = React.useCallback((e: string[]) => {
219
+ const id = e[0];
220
+
221
+ // 是否叶子节点
222
+ if (list?.filter(e => e.pid === id).length !== 0) { return; }
223
+
224
+ const info = list?.filter(e => e.id === id)[0];
225
+
226
+ !readOnlyTaxRate && actions.setFieldState('taxRate', async s => {
227
+ if (info.taxRate || info.taxRate === 0) {
228
+ s.value = info.taxRate
229
+ }
230
+ });
231
+
232
+ actions.setFieldState('taxClassificationCode', async s => {
233
+ if (info.id) {
234
+ s.value = info.id
235
+ }
236
+ });
237
+
238
+ actions.setFieldState('shorthand', async (s) => {
239
+ if (info.shorthand) {
240
+ s.value = info.shorthand
241
+ }
242
+ });
243
+
244
+ setVisible(false);
245
+ }, [list, actions, readOnlyTaxRate])
246
+
247
+ React.useEffect(() => {
248
+ (async () => {
249
+ const fn = controller.state.goodsListState.endowCode.getTaxCategoryCodeTree || (async () => []);
250
+ const list = await fn(filter?.taxCategoryCode, filter?.val);
251
+ setList(list || []);
252
+ })()
253
+ }, [filter])
254
+
255
+ React.useEffect(() => {
256
+ if (visible) {
257
+ setList([])
258
+ }
259
+ }, [visible])
260
+
261
+ return (
262
+ <>
263
+ <InputAntd readOnly value={props.value} addonAfter={<Button size="small" type="link" onClick={() => { setVisible(true) }} >点击选择</Button>} />
264
+ <Drawer
265
+ title="税收分类编码"
266
+ visible={visible}
267
+ width={500}
268
+ onClose={() => { setVisible(false) }}
269
+ >
270
+ <Form key={`${visible}`} >
271
+ <Form.Item label="产品或服务简称" >
272
+ <InputAntd onChange={e => { setFilter({ ...filter, val: e.target.value }) }} />
273
+ </Form.Item>
274
+ <Form.Item label="税收分类编码">
275
+ <InputAntd onChange={e => { setFilter({ ...filter, taxCategoryCode: e.target.value }) }} />
276
+ </Form.Item>
277
+ </Form>
278
+ {
279
+ (list && list.length > 0)
280
+ ? <Tree
281
+ defaultExpandAll
282
+ selectedKeys={[]}
283
+ onSelect={onSelect}
284
+ >
285
+ {createTreeNode()}
286
+ </Tree>
287
+ : <span style={{ color: '#00000073' }} >请输入“产品或服务简称”或“税收分类编码”查找数据。</span>
288
+ }
289
+ </Drawer>
290
+ </>
291
+ )
292
+ }, [controller, actions])
293
+
294
+ /** 税收分类编码 选择组件3 */
295
+ const ShowSearch3 = React.useCallback(props => {
296
+ const [open, setOpen] = React.useState(false);
297
+
298
+ const [list, setList] = React.useState<any>([]);
299
+
300
+ const onSearch = React.useCallback(async (value: any = null) => {
301
+ if(value?.target?.value){
302
+ const arr = await controller.state.goodsListState.endowCode.onSearchTaxClassificationCode(value?.target?.value);
303
+ const list: any[] = arr.map((item: any)=> {
304
+ return {
305
+ ...item,
306
+ title: `${item.productName} ${item.taxCategoryCode}`,
307
+ key: item.taxCategoryCode,
308
+ isLeaf: true
309
+ }
310
+ });
311
+ setList(list);
312
+ } else {
313
+ await onLoad();
314
+ }
315
+ }, []);
316
+
317
+ const onLoad = React.useCallback(async (value?: any) => {
318
+ const arr = await controller.state.goodsListState.endowCode.onLoadTaxClassificationCode(value?.taxCategoryCode);
319
+ const data: any[] = arr.map((item: any)=> {
320
+ return {
321
+ ...item,
322
+ title: `${item.productName} ${item.taxCategoryCode}`,
323
+ key: item.taxCategoryCode
324
+ }
325
+ });
326
+
327
+ const treeData = optimizeTreeData(data);
328
+
329
+ if(value?.key) {
330
+ setList((origin: any)=> {
331
+ updateTreeData(origin, value.key, treeData)
332
+ });
333
+ } else {
334
+ setList(treeData);
335
+ }
336
+ return [];
337
+ }, []);
338
+
339
+ const onClick = React.useCallback(async () => {
340
+ setOpen(true);
341
+ await onLoad();
342
+ }, []);
343
+
344
+ const onSelect = React.useCallback((key: any, info: any) => {
345
+ actions.setFieldState('taxClassificationCode', async s => {
346
+ s.value = info.node.taxCategoryCode
347
+ });
348
+
349
+ actions.setFieldState('shorthand', async (s) => {
350
+ s.value = info.node.shorthand
351
+ });
352
+ actions.setFieldState('taxRate', async s => {
353
+ s.value = info.node.taxRate
354
+ });
355
+ setOpen(false);
356
+ }, [controller, actions]);
357
+
358
+ const optimizeTreeData = (data: any): any => {
359
+ return data.map((item: any)=> {
360
+ return {
361
+ ...item,
362
+ selectable: item?.hzx === 'N',
363
+ isLeaf: item?.hzx === 'N'
364
+ }
365
+ });
366
+ }
367
+
368
+ const updateTreeData = (list: any, key: React.Key, children: any): any => {
369
+ const data = list.map((node: any) => {
370
+ if (node.key === key) {
371
+ return {
372
+ ...node,
373
+ children
374
+ };
375
+ }
376
+ if (node.children) {
377
+ return {
378
+ ...node,
379
+ children: updateTreeData(node.children, key, children)
380
+ };
381
+ }
382
+ return node;
383
+ });
384
+ setList(data);
385
+ return data;
386
+ }
387
+
388
+ return (
389
+ <>
390
+ <InputAntd readOnly onClick={onClick} value={props.value} />
391
+ <TaxClassificationModal
392
+ list={list}
393
+ open={open}
394
+ onSelect={onSelect}
395
+ onCancel={()=> {setOpen(false)}}
396
+ onSearch={onSearch}
397
+ onLoad={onLoad}
398
+ />
399
+ </>
400
+ )
401
+ }, [controller, actions])
402
+
403
+ // 是否享受优惠政策
404
+ const [favouredPolicyMark, setFavouredPolicyMark] = React.useState<number>(0);
405
+
406
+ // 确定
407
+ const onSubmit = React.useCallback(values => {
408
+ controller.pipeline(async s => {
409
+
410
+ const endowCodeGood = s.goodsListState.endowCode.endowcodeGoodIndex.map(e => s.goodsListState.goodsMap.get(e));
411
+
412
+ // 赋码
413
+ endowCodeGood.forEach(good => {
414
+ if (!good) return;
415
+
416
+ good.shorthand = values.shorthand;
417
+ good.taxClassificationCode = values.taxClassificationCode;
418
+ good.taxRate = values.taxRate;
419
+ good.taxFreeType = values.taxFreeType;
420
+ good.favouredPolicyMark = values.favouredPolicyMark;
421
+ good.favouredPolicyName = values.favouredPolicyName;
422
+
423
+ const taxRate = chain(bignumber(values.taxRate)).dotDivide(bignumber(100)).add(bignumber(1)).done();
424
+
425
+ // 是否含税
426
+ const lineAmountExcludeTax = chain(bignumber(good.lineAmountIncludeTax)).dotDivide(taxRate).done();
427
+ const priceExcludeTax = good.priceIncludeTax ? chain(bignumber(good.priceIncludeTax)).dotDivide(taxRate).done() : undefined
428
+
429
+ good.lineAmountExcludeTax = lineAmountExcludeTax.toNumber().toFixed(2);
430
+ good.priceExcludeTax = (priceExcludeTax ? format15(priceExcludeTax.toNumber(), s.calculatingDigits) : undefined) || undefined;
431
+
432
+ good.taxAmount = countTaxAmount(good.lineAmountIncludeTax || 0, s.goodsListState.deduction, values.taxRate);
433
+ });
434
+
435
+ s.goodsListState.goodsList = s.goodsListState.goodsList.slice();
436
+ s.goodsListState.endowCode.endowcodeGoodIndex = [];
437
+ })();
438
+ }, [controller]);
439
+
440
+ const effects = React.useCallback(() => {
441
+ // 税率变化
442
+ FormEffectHooks.onFieldValueChange$('taxRate').subscribe((e) => {
443
+ setTaxRate(e.value);
444
+ actions.setFieldState('taxFreeType', async (s) => {
445
+ if (e.value !== 0)
446
+ s.value = undefined;
447
+ });
448
+ });
449
+
450
+ // 是否享受优惠政策
451
+ FormEffectHooks.onFieldValueChange$('favouredPolicyMark').subscribe((e) => {
452
+ setFavouredPolicyMark(e.value);
453
+ actions.setFieldState('favouredPolicyName', async (s) => {
454
+ if (e.value === 0)
455
+ s.value = undefined;
456
+ });
457
+ });
458
+ }, [actions]);
459
+
460
+ // 更新 税收分类编码列表
461
+ React.useEffect(() => {
462
+ if (controller.getTaxCategoryCodeList) controller.getTaxCategoryCodeList();
463
+ }, [controller]);
464
+
465
+ return (
466
+ <SchemaForm actions={actions} previewPlaceholder=" " components={{ ...components, showSearch: !!controller.state.goodsListState.endowCode.onLoadTaxClassificationCode ? ShowSearch3 : ShowSearch }} effects={effects}>
467
+ <FormButtonGroup>
468
+ <Field
469
+ name="taxClassificationCode"
470
+ type="showSearch"
471
+ title="税收分类编码"
472
+ // enum={taxCategoryCodeList}
473
+ default={defaultValue?.taxClassificationCode}
474
+ x-rules={[{ message: '请选择税收分类编码', required: true }]}
475
+ />
476
+ <Field
477
+ name="shorthand"
478
+ type="string"
479
+ readOnly
480
+ default={defaultValue?.shorthand}
481
+ title="商品和服务分类简称"
482
+ />
483
+ <Field
484
+ name="taxRate"
485
+ type="string"
486
+ title="税率"
487
+ x-component-props={{ disabled: readOnlyTaxRate }}
488
+ default={defaultValue?.taxRate ?? 0}
489
+ enum={taxRateList}
490
+ x-rules={[{ message: '请选择税率', required: true }]}
491
+ />
492
+ {taxRate === 0 && isTaxFreeTypeNeeded &&
493
+ <Field
494
+ name="taxFreeType"
495
+ type="string"
496
+ title="免税类型"
497
+ x-component-props={{ disabled: readOnlyTaxRate }}
498
+ default={defaultValue?.taxFreeType}
499
+ enum={taxFreeTypeList}
500
+ x-rules={[{ message: '请选择免税类型', required: true }]}
501
+ />
502
+ }
503
+ <Field
504
+ name="favouredPolicyMark"
505
+ type="number"
506
+ title="是否享受优惠政策"
507
+ x-component-props={{ disabled: readOnlyFavouredPolicy }}
508
+ enum={[
509
+ { label: '是', value: 1 },
510
+ { label: '否', value: 0 },
511
+ ]}
512
+ default={defaultValue?.favouredPolicyMark ?? 0}
513
+ x-rules={[{ message: '请选择是否享受优惠政策', required: true }]}
514
+ />
515
+ {favouredPolicyMark === 1 &&
516
+ <Field
517
+ name="favouredPolicyName"
518
+ type="string"
519
+ title="优惠政策类型"
520
+ x-component-props={{ disabled: readOnlyFavouredPolicy }}
521
+ enum={favouredPolicyNameList}
522
+ default={defaultValue?.favouredPolicyName}
523
+ x-rules={[{ message: '请选择是否享受优惠政策', required: true }]}
524
+ />
525
+ }
526
+ </FormButtonGroup>
527
+
528
+ <span className="kts-invoice-operate-goods-endow-code-button-list">
529
+ <Button onClick={() => { actions.submit(onSubmit) }} type="primary">
530
+ 确定
531
+ </Button>
532
+ <Button onClick={() => { controller.pipeline(async s => (s.goodsListState.endowCode.endowcodeGoodIndex = []))() }}>
533
+ 取消
534
+ </Button>
535
+ </span>
536
+ </SchemaForm>
537
+ );
538
+ };
539
+
540
+ const components = {
541
+ string: Input,
542
+ number: NumberPicker,
543
+ };