kts-component-invoice-operate 3.2.53 → 3.2.55

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 (199) 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/index.esm.js +7905 -5681
  9. package/dist/index.js +7905 -5681
  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 +60 -60
  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 +470 -470
  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 +41 -41
  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 +94 -94
  30. package/src/Invoice/InvoiceController/InvoiceControllerState/AutoComplete/index.ts +17 -17
  31. package/src/Invoice/InvoiceController/InvoiceControllerState/BuyerState/index.tsx +88 -88
  32. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/Drag/index.ts +12 -12
  33. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/EndowCode/index.tsx +93 -93
  34. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/IColumnsReplenish/index.ts +10 -10
  35. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/IGood/index.ts +75 -75
  36. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/ImportGoods/index.ts +80 -80
  37. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/LineAttributeType/index.ts +5 -5
  38. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/ProductComparison/index.ts +9 -9
  39. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/index.ts +107 -107
  40. package/src/Invoice/InvoiceController/InvoiceControllerState/Stakeholder/index.ts +10 -10
  41. package/src/Invoice/InvoiceController/InvoiceControllerState/index.ts +60 -60
  42. package/src/Invoice/InvoiceController/fns/addGood.ts +11 -11
  43. package/src/Invoice/InvoiceController/fns/addGoodDiscount.ts +125 -125
  44. package/src/Invoice/InvoiceController/fns/addGoodDiscountV2.ts +84 -84
  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 -68
  48. package/src/Invoice/InvoiceController/fns/mergeDetails.ts +163 -163
  49. package/src/Invoice/InvoiceController/fns/mergeDiscount.ts +28 -28
  50. package/src/Invoice/InvoiceController/fns/saveEditGood.ts +24 -24
  51. package/src/Invoice/InvoiceController/fns/setEditGood.ts +16 -16
  52. package/src/Invoice/InvoiceController/fns/setGoods.ts +10 -10
  53. package/src/Invoice/InvoiceController/fns/updateInvoiceNo.ts +8 -8
  54. package/src/Invoice/InvoiceController/index.ts +77 -77
  55. package/src/Invoice/_test/buyerNameSearch/index.tsx +41 -41
  56. package/src/Invoice/_test/deduction/index.tsx +935 -935
  57. package/src/Invoice/_test/draft/index.tsx +40 -40
  58. package/src/Invoice/_test/easiest/index.tsx +5 -5
  59. package/src/Invoice/_test/endowCode/index.tsx +1099 -1099
  60. package/src/Invoice/_test/goodsMenuExpand/index.tsx +32 -32
  61. package/src/Invoice/_test/importBuyer/index.tsx +74 -74
  62. package/src/Invoice/_test/importGoods/index.tsx +515 -515
  63. package/src/Invoice/_test/invoiceType/index.tsx +59 -59
  64. package/src/Invoice/_test/isInvoiceNo/index.tsx +12 -12
  65. package/src/Invoice/_test/replaceHead/index.tsx +22 -22
  66. package/src/Invoice/_test/retrieveData/index.tsx +22 -22
  67. package/src/Invoice/_test/seller/index.tsx +28 -28
  68. package/src/Invoice/_test/setDataSource/index.tsx +73 -73
  69. package/src/Invoice/_test/unit/index.tsx +19 -19
  70. package/src/Invoice/index.less +29 -29
  71. package/src/Invoice/index.md +53 -53
  72. package/src/Invoice/index.tsx +165 -165
  73. package/src/Invoice/tools/calculate/index.ts +112 -112
  74. package/src/Invoice/tools/coolingFn/index.ts +17 -17
  75. package/src/Invoice/tools/evaluate/index.ts +7 -7
  76. package/src/Invoice/tools/idGenerator/index.ts +2 -2
  77. package/src/Invoice/tools/itemName/index.ts +55 -55
  78. package/src/Invoice/tools/lazyFn/index.ts +19 -19
  79. package/src/Invoice/tools/mounting/index.ts +13 -13
  80. package/src/Invoice/tools/strringFn/index.ts +40 -40
  81. package/src/Invoice/tools/useToGenerateId/index.ts +8 -8
  82. package/src/Invoice/ui/default/AddComparisonDrawer/index.tsx +149 -149
  83. package/src/Invoice/ui/default/Buyer/index.less +219 -219
  84. package/src/Invoice/ui/default/Buyer/index.tsx +114 -114
  85. package/src/Invoice/ui/default/Buyer/ui/BuyerNameInput/index.tsx +166 -166
  86. package/src/Invoice/ui/default/Buyer/ui/ImportBuyerButton/index.tsx +21 -21
  87. package/src/Invoice/ui/default/EndowCodeDrawer/index.less +8 -8
  88. package/src/Invoice/ui/default/EndowCodeDrawer/index.tsx +431 -431
  89. package/src/Invoice/ui/default/GoodsList/hook/useColumns/autoFillFn/index.ts +533 -533
  90. package/src/Invoice/ui/default/GoodsList/hook/useColumns/index.tsx +664 -664
  91. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/Drag/index.less +20 -20
  92. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/Drag/index.tsx +202 -202
  93. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemCodeInput/index.less +18 -18
  94. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemCodeInput/index.tsx +48 -48
  95. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemNameInput/index.less +17 -17
  96. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemNameInput/index.tsx +130 -130
  97. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowEditButton/index.tsx +30 -30
  98. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/_useAddComparison/index.tsx +43 -43
  99. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useAddDiscount/index.tsx +76 -76
  100. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useDelItem/index.tsx +41 -41
  101. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useEndowCode/index.tsx +34 -34
  102. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/index.less +13 -13
  103. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/index.tsx +98 -98
  104. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowSaveButton/index.tsx +14 -14
  105. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/TitleText/index.tsx +20 -20
  106. package/src/Invoice/ui/default/GoodsList/hook/useDeduction/index.tsx +24 -24
  107. package/src/Invoice/ui/default/GoodsList/hook/useOnRow/index.tsx +39 -39
  108. package/src/Invoice/ui/default/GoodsList/hook/useRowSelection/index.tsx +111 -111
  109. package/src/Invoice/ui/default/GoodsList/hook/useWindowClick/index.tsx +23 -23
  110. package/src/Invoice/ui/default/GoodsList/index.less +177 -177
  111. package/src/Invoice/ui/default/GoodsList/index.tsx +191 -191
  112. package/src/Invoice/ui/default/GoodsList/ui/AddRowButton/index.tsx +65 -65
  113. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/index.less +21 -21
  114. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/index.tsx +244 -244
  115. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useCommodityComparisonButton/index.tsx +75 -75
  116. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useDelRowButton/index.tsx +69 -69
  117. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useEndowCodeButton/index.tsx +58 -58
  118. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useMergeDetails/index.tsx +37 -37
  119. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useMergeDiscount/index.tsx +36 -36
  120. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/index.tsx +37 -37
  121. package/src/Invoice/ui/default/GoodsList/ui/DescribeSwitch/index.tsx +36 -36
  122. package/src/Invoice/ui/default/GoodsList/ui/Search/index.less +10 -10
  123. package/src/Invoice/ui/default/GoodsList/ui/Search/index.tsx +52 -52
  124. package/src/Invoice/ui/default/GoodsList/ui/Statistics/index.less +18 -18
  125. package/src/Invoice/ui/default/GoodsList/ui/Statistics/index.tsx +109 -109
  126. package/src/Invoice/ui/default/GoodsList/ui/TableRow/index.less +13 -13
  127. package/src/Invoice/ui/default/GoodsList/ui/TableRow/index.tsx +46 -46
  128. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual/index.less +38 -38
  129. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual/index.tsx +108 -108
  130. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual.o/index.less +44 -44
  131. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual.o/index.tsx +96 -96
  132. package/src/Invoice/ui/default/GoodsList/ui/TaxIncludedSwitch/index.tsx +30 -30
  133. package/src/Invoice/ui/default/ImportBuyerDrawer/index.tsx +75 -75
  134. package/src/Invoice/ui/default/ImportGoodsDrawer/index.tsx +193 -193
  135. package/src/Invoice/ui/default/InvoiceHeader/index.less +68 -68
  136. package/src/Invoice/ui/default/InvoiceHeader/index.tsx +246 -246
  137. package/src/Invoice/ui/default/Seller/index.less +113 -113
  138. package/src/Invoice/ui/default/Seller/index.tsx +98 -98
  139. package/src/Invoice/ui/default/Sign/index.less +14 -14
  140. package/src/Invoice/ui/default/Sign/index.tsx +71 -71
  141. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/autoFillFn/index.ts +519 -519
  142. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/index.tsx +648 -648
  143. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/svg/plus.svg +11 -11
  144. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/Drag/index.less +20 -20
  145. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/Drag/index.tsx +186 -186
  146. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/ItemNameInput/index.less +9 -9
  147. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/ItemNameInput/index.tsx +50 -50
  148. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowEditButton/index.tsx +30 -30
  149. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/_useAddComparison/index.tsx +43 -43
  150. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/useAddDiscount/index.tsx +76 -76
  151. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/useDelItem/index.tsx +41 -41
  152. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/useEndowCode/index.tsx +34 -34
  153. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/index.less +13 -13
  154. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/index.tsx +98 -98
  155. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowSaveButton/index.tsx +14 -14
  156. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/TitleText/index.tsx +20 -20
  157. package/src/Invoice/ui/digtal/GoodsList/hook/useOnRow/index.tsx +39 -39
  158. package/src/Invoice/ui/digtal/GoodsList/hook/useRowSelection/index.tsx +121 -121
  159. package/src/Invoice/ui/digtal/GoodsList/hook/useWindowClick/index.tsx +23 -23
  160. package/src/Invoice/ui/digtal/GoodsList/index.less +56 -56
  161. package/src/Invoice/ui/digtal/GoodsList/index.tsx +180 -180
  162. package/src/Invoice/ui/digtal/GoodsList/ui/AddRowButton/index.tsx +65 -65
  163. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/index.tsx +341 -341
  164. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/svg/add.svg +11 -11
  165. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useCommodityComparisonButton/index.tsx +75 -75
  166. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useDelRowButton/index.tsx +50 -50
  167. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useEmptyRefill/index.tsx +35 -35
  168. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useEndowCodeButton/index.tsx +82 -82
  169. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useReselectInvoiceType/index.tsx +57 -57
  170. package/src/Invoice/ui/digtal/GoodsList/ui/DescribeSwitch/index.tsx +36 -36
  171. package/src/Invoice/ui/digtal/GoodsList/ui/Search/index.less +11 -11
  172. package/src/Invoice/ui/digtal/GoodsList/ui/Search/index.tsx +50 -50
  173. package/src/Invoice/ui/digtal/GoodsList/ui/Statistics/index.less +53 -53
  174. package/src/Invoice/ui/digtal/GoodsList/ui/Statistics/index.tsx +99 -99
  175. package/src/Invoice/ui/digtal/GoodsList/ui/Statistics/svg/fork.svg +11 -11
  176. package/src/Invoice/ui/digtal/GoodsList/ui/TableRow/index.less +13 -13
  177. package/src/Invoice/ui/digtal/GoodsList/ui/TableRow/index.tsx +40 -40
  178. package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual/index.less +38 -38
  179. package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual/index.tsx +108 -108
  180. package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual.o/index.less +44 -44
  181. package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual.o/index.tsx +96 -96
  182. package/src/Invoice/ui/digtal/GoodsList/ui/TaxIncludedSwitch/index.tsx +30 -30
  183. package/src/Invoice/ui/digtal/InvoiceHeader/index.less +57 -57
  184. package/src/Invoice/ui/digtal/InvoiceHeader/index.tsx +77 -77
  185. package/src/Invoice/ui/digtal/Sign/index.less +48 -48
  186. package/src/Invoice/ui/digtal/Sign/index.tsx +89 -89
  187. package/src/Invoice/ui/digtal/Stakeholder/index.less +75 -75
  188. package/src/Invoice/ui/digtal/Stakeholder/index.tsx +388 -388
  189. package/src/Invoice/ui/digtal/Stakeholder/svg/arrowDown.svg +2 -2
  190. package/src/Invoice/ui/digtal/Stakeholder/svg/arrowUp.svg +2 -2
  191. package/src/Invoice/ui/digtal/Stakeholder/svg/plus.svg +11 -11
  192. package/src/InvoiceTypeModal/_test/easiest/index.tsx +31 -31
  193. package/src/InvoiceTypeModal/index.less +7 -7
  194. package/src/InvoiceTypeModal/index.md +5 -5
  195. package/src/InvoiceTypeModal/index.tsx +153 -153
  196. package/src/index.ts +9 -9
  197. package/tsconfig.json +31 -31
  198. package/typings.d.ts +3 -3
  199. package/yarn.e.lock +14331 -14331
@@ -1,43 +1,43 @@
1
- /** 添加商品对照 */
2
-
3
- import React from 'react';
4
- import { Menu, message, Typography } from 'kts-components-antd-x3';
5
- import { IGood, LineAttributeType } from '../../../../../../../../InvoiceController';
6
- import Invoice from '../../../../../../../../';
7
-
8
- const { Text } = Typography;
9
-
10
- export default (goods: IGood) => {
11
-
12
- const controller = Invoice.useInvoiceController();
13
-
14
- const productComparison = controller.useMemo(s => s.goodsListState.productComparison, []);
15
-
16
- const onClick = React.useCallback(async () => {
17
- await controller.saveEditGood();
18
- await controller.wait();
19
- await controller.run(async s => {
20
- if (s.goodsListState.form) {
21
- const err: any = s.goodsListState.form.getFieldsError();
22
- for (let key in err) {
23
- if (!err[key]) continue;
24
- message.error(err[key][0]);
25
- return;
26
- }
27
- }
28
- s.goodsListState.addComparisonIndex = goods.$index;
29
- })
30
- }, [controller, goods.$index]);
31
-
32
- if (!(goods.lineAttribute !== LineAttributeType.折扣行)) {
33
- return undefined;
34
- }
35
-
36
- return React.useMemo(() => {
37
- if (productComparison.onComply) {
38
- return <Menu.Item key="delItem" onClick={onClick}><Text strong>添加商品对照</Text></Menu.Item>
39
- } else {
40
- return <></>
41
- }
42
- }, [onClick, productComparison])
43
- };
1
+ /** 添加商品对照 */
2
+
3
+ import React from 'react';
4
+ import { Menu, message, Typography } from 'kts-components-antd-x3';
5
+ import { IGood, LineAttributeType } from '../../../../../../../../InvoiceController';
6
+ import Invoice from '../../../../../../../../';
7
+
8
+ const { Text } = Typography;
9
+
10
+ export default (goods: IGood) => {
11
+
12
+ const controller = Invoice.useInvoiceController();
13
+
14
+ const productComparison = controller.useMemo(s => s.goodsListState.productComparison, []);
15
+
16
+ const onClick = React.useCallback(async () => {
17
+ await controller.saveEditGood();
18
+ await controller.wait();
19
+ await controller.run(async s => {
20
+ if (s.goodsListState.form) {
21
+ const err: any = s.goodsListState.form.getFieldsError();
22
+ for (let key in err) {
23
+ if (!err[key]) continue;
24
+ message.error(err[key][0]);
25
+ return;
26
+ }
27
+ }
28
+ s.goodsListState.addComparisonIndex = goods.$index;
29
+ })
30
+ }, [controller, goods.$index]);
31
+
32
+ if (!(goods.lineAttribute !== LineAttributeType.折扣行)) {
33
+ return undefined;
34
+ }
35
+
36
+ return React.useMemo(() => {
37
+ if (productComparison.onComply) {
38
+ return <Menu.Item key="delItem" onClick={onClick}><Text strong>添加商品对照</Text></Menu.Item>
39
+ } else {
40
+ return <></>
41
+ }
42
+ }, [onClick, productComparison])
43
+ };
@@ -1,76 +1,76 @@
1
-
2
- import React from 'react';
3
- import { Menu, message, Typography } from 'kts-components-antd-x3';
4
- import { IGood, LineAttributeType } from '../../../../../../../../../InvoiceController';
5
- import Invoice from '../../../../../../../../..';
6
-
7
- const { Text } = Typography;
8
-
9
- export default (goods: IGood) => {
10
-
11
- const controller = Invoice.useInvoiceController();
12
-
13
- const model = controller.useMemo(s => s.model, [])
14
-
15
- /** 是否能添加折扣行 */
16
- const isAddDiscount = controller.useMemo(s => s.goodsListState.isAddDiscount, [])
17
-
18
- /** 点击了 添加折扣行 按钮 */
19
- const onClick = React.useCallback(async e => {
20
- e.stopPropagation()
21
- await controller.wait();
22
- await controller.saveEditGood();
23
- await controller.run(async s => {
24
- if (s.goodsListState.form && s.goodsListState.editGood?.$index === goods?.$index) {
25
- const err: any = s.goodsListState.form.getFieldsError();
26
- for (let key in err) {
27
- if (!err[key]) continue;
28
- message.error(err[key][0]);
29
- return;
30
- }
31
- }
32
- goods = s.goodsListState.goodsMap.get(goods.$index) as any;
33
- if (goods.taxRate === 0 && s.goodsListState.endowCode.isTaxFreeTypeNeeded && !goods.taxFreeType) {
34
- message.error({ content: '零税率需要设置免税类型,请在赋码中设置!', key: '零税率需要设置免税类型,请在赋码中设置!' });
35
- return;
36
- }
37
- if (`${goods.lineAmountIncludeTax}` === '0') {
38
- message.error({ content: '金额为0不能添加折扣行', key: '金额为0不能添加折扣行' });
39
- return;
40
- }
41
- s.goodsListState.discountGoodIndex = [goods.$index];
42
- })
43
- }, [controller, goods.$index]);
44
-
45
- if (goods.lineAttribute !== LineAttributeType.正常) {
46
- return undefined
47
- }
48
-
49
- if (!(model !== 'prefab')) {
50
- return undefined;
51
- }
52
-
53
- if (!(isAddDiscount !== false)) {
54
- return undefined
55
- }
56
-
57
- if (goods.lineAttribute !== LineAttributeType.正常) {
58
- return undefined
59
- }
60
-
61
- return {
62
- key:'addDiscount',
63
- title:'折扣',
64
- onClick,
65
- }
66
-
67
- // return React.useMemo(() => {
68
- // if (goods.lineAttribute !== LineAttributeType.正常) {
69
- // return undefined
70
- // }
71
-
72
- // return (
73
- // <Menu.Item key="addDiscount" onClick={onClick}><Text strong>折扣</Text></Menu.Item>
74
- // );
75
- // }, [onClick, goods.lineAttribute]);
76
- };
1
+
2
+ import React from 'react';
3
+ import { Menu, message, Typography } from 'kts-components-antd-x3';
4
+ import { IGood, LineAttributeType } from '../../../../../../../../../InvoiceController';
5
+ import Invoice from '../../../../../../../../..';
6
+
7
+ const { Text } = Typography;
8
+
9
+ export default (goods: IGood) => {
10
+
11
+ const controller = Invoice.useInvoiceController();
12
+
13
+ const model = controller.useMemo(s => s.model, [])
14
+
15
+ /** 是否能添加折扣行 */
16
+ const isAddDiscount = controller.useMemo(s => s.goodsListState.isAddDiscount, [])
17
+
18
+ /** 点击了 添加折扣行 按钮 */
19
+ const onClick = React.useCallback(async e => {
20
+ e.stopPropagation()
21
+ await controller.wait();
22
+ await controller.saveEditGood();
23
+ await controller.run(async s => {
24
+ if (s.goodsListState.form && s.goodsListState.editGood?.$index === goods?.$index) {
25
+ const err: any = s.goodsListState.form.getFieldsError();
26
+ for (let key in err) {
27
+ if (!err[key]) continue;
28
+ message.error(err[key][0]);
29
+ return;
30
+ }
31
+ }
32
+ goods = s.goodsListState.goodsMap.get(goods.$index) as any;
33
+ if (goods.taxRate === 0 && s.goodsListState.endowCode.isTaxFreeTypeNeeded && !goods.taxFreeType) {
34
+ message.error({ content: '零税率需要设置免税类型,请在赋码中设置!', key: '零税率需要设置免税类型,请在赋码中设置!' });
35
+ return;
36
+ }
37
+ if (`${goods.lineAmountIncludeTax}` === '0') {
38
+ message.error({ content: '金额为0不能添加折扣行', key: '金额为0不能添加折扣行' });
39
+ return;
40
+ }
41
+ s.goodsListState.discountGoodIndex = [goods.$index];
42
+ })
43
+ }, [controller, goods.$index]);
44
+
45
+ if (goods.lineAttribute !== LineAttributeType.正常) {
46
+ return undefined
47
+ }
48
+
49
+ if (!(model !== 'prefab')) {
50
+ return undefined;
51
+ }
52
+
53
+ if (!(isAddDiscount !== false)) {
54
+ return undefined
55
+ }
56
+
57
+ if (goods.lineAttribute !== LineAttributeType.正常) {
58
+ return undefined
59
+ }
60
+
61
+ return {
62
+ key:'addDiscount',
63
+ title:'折扣',
64
+ onClick,
65
+ }
66
+
67
+ // return React.useMemo(() => {
68
+ // if (goods.lineAttribute !== LineAttributeType.正常) {
69
+ // return undefined
70
+ // }
71
+
72
+ // return (
73
+ // <Menu.Item key="addDiscount" onClick={onClick}><Text strong>折扣</Text></Menu.Item>
74
+ // );
75
+ // }, [onClick, goods.lineAttribute]);
76
+ };
@@ -1,41 +1,41 @@
1
- import React from 'react';
2
- // import { Menu, Typography } from 'kts-components-antd-x3';
3
- import { IGood, LineAttributeType } from '../../../../../../../../../InvoiceController';
4
- import Invoice from '../../../../../../../../..';
5
-
6
- // const { Text } = Typography;
7
-
8
- export default (goods: IGood) => {
9
-
10
- const controller = Invoice.useInvoiceController();
11
-
12
- const model = controller.useMemo(s => s.model, [])
13
-
14
- const isRemRow = controller.useMemo(s => s.goodsListState.isRemRow, [])
15
-
16
- const onClick = React.useCallback(() => {
17
- controller.delGood(goods.$index);
18
- }, [controller, goods.$index]);
19
-
20
- if (goods.lineAttribute === LineAttributeType.被折扣行) {
21
- return undefined;
22
- }
23
-
24
- if(isRemRow === false) {
25
- return undefined;
26
- }
27
-
28
- if (!(model !== 'prefab')) {
29
- return undefined;
30
- }
31
-
32
- return {
33
- key:'delItem',
34
- title:'删除',
35
- onClick,
36
- }
37
-
38
- // return React.useMemo(() => {
39
- // return <Menu.Item key="delItem" onClick={onClick}><Text strong type="danger">删除</Text></Menu.Item>
40
- // }, [onClick])
41
- };
1
+ import React from 'react';
2
+ // import { Menu, Typography } from 'kts-components-antd-x3';
3
+ import { IGood, LineAttributeType } from '../../../../../../../../../InvoiceController';
4
+ import Invoice from '../../../../../../../../..';
5
+
6
+ // const { Text } = Typography;
7
+
8
+ export default (goods: IGood) => {
9
+
10
+ const controller = Invoice.useInvoiceController();
11
+
12
+ const model = controller.useMemo(s => s.model, [])
13
+
14
+ const isRemRow = controller.useMemo(s => s.goodsListState.isRemRow, [])
15
+
16
+ const onClick = React.useCallback(() => {
17
+ controller.delGood(goods.$index);
18
+ }, [controller, goods.$index]);
19
+
20
+ if (goods.lineAttribute === LineAttributeType.被折扣行) {
21
+ return undefined;
22
+ }
23
+
24
+ if(isRemRow === false) {
25
+ return undefined;
26
+ }
27
+
28
+ if (!(model !== 'prefab')) {
29
+ return undefined;
30
+ }
31
+
32
+ return {
33
+ key:'delItem',
34
+ title:'删除',
35
+ onClick,
36
+ }
37
+
38
+ // return React.useMemo(() => {
39
+ // return <Menu.Item key="delItem" onClick={onClick}><Text strong type="danger">删除</Text></Menu.Item>
40
+ // }, [onClick])
41
+ };
@@ -1,34 +1,34 @@
1
- import React from 'react';
2
- // import { Button } from 'kts-components-antd-x3';
3
- import Invoice from '../../../../../../../../..';
4
- import { IGood } from '../../../../../../../../../InvoiceController';
5
- import { endowCode } from '../../../../autoFillFn';
6
-
7
- // const { Text } = Typography;
8
-
9
- export default (goods: IGood) => {
10
-
11
- const controller = Invoice.useInvoiceController();
12
-
13
- const onClick = React.useCallback(async () => {
14
- endowCode(controller, goods);
15
- }, [controller, goods]);
16
-
17
- return {
18
- key: 'endowCode',
19
- title: '赋码',
20
- onClick,
21
- }
22
-
23
- // return React.useMemo(() => {
24
- // return (
25
- // <Menu.Item key="endowCode" onClick={onClick} ><Text strong>赋码</Text></Menu.Item>
26
- // );
27
- // }, [goods.lineAttribute, onClick])
28
-
29
- // return React.useMemo(() => {
30
- // return (
31
- // <Button key="endowCode" type="link" onClick={onClick} >赋码</Button>
32
- // );
33
- // }, [goods.lineAttribute, onClick])
34
- };
1
+ import React from 'react';
2
+ // import { Button } from 'kts-components-antd-x3';
3
+ import Invoice from '../../../../../../../../..';
4
+ import { IGood } from '../../../../../../../../../InvoiceController';
5
+ import { endowCode } from '../../../../autoFillFn';
6
+
7
+ // const { Text } = Typography;
8
+
9
+ export default (goods: IGood) => {
10
+
11
+ const controller = Invoice.useInvoiceController();
12
+
13
+ const onClick = React.useCallback(async () => {
14
+ endowCode(controller, goods);
15
+ }, [controller, goods]);
16
+
17
+ return {
18
+ key: 'endowCode',
19
+ title: '赋码',
20
+ onClick,
21
+ }
22
+
23
+ // return React.useMemo(() => {
24
+ // return (
25
+ // <Menu.Item key="endowCode" onClick={onClick} ><Text strong>赋码</Text></Menu.Item>
26
+ // );
27
+ // }, [goods.lineAttribute, onClick])
28
+
29
+ // return React.useMemo(() => {
30
+ // return (
31
+ // <Button key="endowCode" type="link" onClick={onClick} >赋码</Button>
32
+ // );
33
+ // }, [goods.lineAttribute, onClick])
34
+ };
@@ -1,13 +1,13 @@
1
- .ktsAnt3x-btn.kts-invoice-operate-goods-list-columns-row-menu:focus,
2
- .ktsAnt3x-btn.kts-invoice-operate-goods-list-columns-row-menu:hover,
3
- .ktsAnt3x-btn.kts-invoice-operate-goods-list-columns-row-menu {
4
- font-size: 16px;
5
- color: #000;
6
- text-align: center;
7
- padding: 0;
8
- }
9
- .ktsAnt3x-btn.kts-invoice-operate-goods-list-columns-row-menu:hover,
10
- .ktsAnt3x-btn.kts-invoice-operate-goods-list-columns-row-menu.ktsAnt3x-dropdown-open{
11
- background: #ebebeb;
12
- border-radius: 9999px;
13
- }
1
+ .ktsAnt3x-btn.kts-invoice-operate-goods-list-columns-row-menu:focus,
2
+ .ktsAnt3x-btn.kts-invoice-operate-goods-list-columns-row-menu:hover,
3
+ .ktsAnt3x-btn.kts-invoice-operate-goods-list-columns-row-menu {
4
+ font-size: 16px;
5
+ color: #000;
6
+ text-align: center;
7
+ padding: 0;
8
+ }
9
+ .ktsAnt3x-btn.kts-invoice-operate-goods-list-columns-row-menu:hover,
10
+ .ktsAnt3x-btn.kts-invoice-operate-goods-list-columns-row-menu.ktsAnt3x-dropdown-open{
11
+ background: #ebebeb;
12
+ border-radius: 9999px;
13
+ }
@@ -1,98 +1,98 @@
1
- import React from 'react';
2
- import { Button, Menu, Dropdown, Icon, Typography } from 'kts-components-antd-x3';
3
- import Invoice from '../../../../../../..';
4
- import { IGood } from '../../../../../../../InvoiceController';
5
- import { ReactComponent as SpotSvg } from './spot.svg';
6
-
7
- import useDelItem from './hook/useDelItem';
8
- import useAddDiscount from './hook/useAddDiscount';
9
- import useEndowCode from './hook/useEndowCode';
10
- // import useAddComparison from './hook/useAddComparison';
11
-
12
- import './index.less';
13
-
14
- const { Text } = Typography;
15
-
16
- export default (props: { goods: IGood }) => {
17
-
18
- const controller = Invoice.useInvoiceController();
19
-
20
- const model = controller.useMemo(s => s.model, [])
21
-
22
- /** 是否能添加折扣行 */
23
- const isAddDiscount = controller.useMemo(s => s.goodsListState.isAddDiscount, [])
24
-
25
- const goodsMenuExpand = controller.useMemo(s => s.goodsListState.goodsMenuExpand, []);
26
-
27
- const delItem = useDelItem(props.goods);
28
- const addDiscount = useAddDiscount(props.goods);
29
- const endowCode = useEndowCode(props.goods);
30
- // const addComparison = useAddComparison(props.goods);
31
-
32
- const itemList = React.useMemo(() => {
33
- const arr: any[] = [];
34
-
35
- endowCode && arr.push(endowCode); // 赋码
36
- addDiscount && arr.push(addDiscount); // 添加折扣行
37
- delItem && arr.push(delItem); // 删除
38
-
39
- // addComparison && arr.push(addComparison); // 添加商品对照
40
-
41
- if (!goodsMenuExpand || goodsMenuExpand.length === 0) return arr;
42
-
43
- arr.unshift(<Menu.Divider key="divider-1" />);
44
-
45
- for (let i = goodsMenuExpand.length - 1; i >= 0; i--) {
46
- const fn = goodsMenuExpand[i];
47
- arr.unshift(fn(props.goods.$index, controller));
48
- }
49
-
50
- return arr;
51
- }, [controller, endowCode, addDiscount, delItem, goodsMenuExpand, props.goods, model, isAddDiscount])
52
-
53
- const overlay = React.useMemo(() => {
54
- if (itemList.length <= 2) {
55
- return undefined
56
- }
57
-
58
- return (
59
- <Menu>
60
- {itemList.slice(2).map(e => {
61
- return <Menu.Item key={e.key} onClick={e.onClick} ><Text strong>{e.title}</Text></Menu.Item>
62
- })}
63
- </Menu>
64
- )
65
- }, [itemList])
66
-
67
- const buttonList = React.useMemo(() => {
68
- return (
69
- <div style={{ flex: 1, textAlign: 'left', display: 'flex', gap: 10 }} >
70
- {
71
- itemList.slice(0, 2).map(e => {
72
- return (
73
- <Button key={e.key} type='link' onClick={e.onClick} style={{ padding: 0 }} >
74
- {e.title}
75
- </Button>
76
- )
77
- })
78
- }
79
- </div>
80
- )
81
- }, [itemList])
82
-
83
- if (itemList.length === 0) { return (<></>) }
84
-
85
- return (
86
- <span style={{ padding: '0 0 0 10px', display: 'flex' }}>
87
- {buttonList}
88
- {
89
- overlay &&
90
- <Dropdown overlay={overlay} trigger={['click']}>
91
- <Button className="kts-invoice-operate-goods-list-columns-row-menu ant-btn-icon-only" type="link">
92
- <Icon component={SpotSvg} />
93
- </Button>
94
- </Dropdown>
95
- }
96
- </span>
97
- );
98
- };
1
+ import React from 'react';
2
+ import { Button, Menu, Dropdown, Icon, Typography } from 'kts-components-antd-x3';
3
+ import Invoice from '../../../../../../..';
4
+ import { IGood } from '../../../../../../../InvoiceController';
5
+ import { ReactComponent as SpotSvg } from './spot.svg';
6
+
7
+ import useDelItem from './hook/useDelItem';
8
+ import useAddDiscount from './hook/useAddDiscount';
9
+ import useEndowCode from './hook/useEndowCode';
10
+ // import useAddComparison from './hook/useAddComparison';
11
+
12
+ import './index.less';
13
+
14
+ const { Text } = Typography;
15
+
16
+ export default (props: { goods: IGood }) => {
17
+
18
+ const controller = Invoice.useInvoiceController();
19
+
20
+ const model = controller.useMemo(s => s.model, [])
21
+
22
+ /** 是否能添加折扣行 */
23
+ const isAddDiscount = controller.useMemo(s => s.goodsListState.isAddDiscount, [])
24
+
25
+ const goodsMenuExpand = controller.useMemo(s => s.goodsListState.goodsMenuExpand, []);
26
+
27
+ const delItem = useDelItem(props.goods);
28
+ const addDiscount = useAddDiscount(props.goods);
29
+ const endowCode = useEndowCode(props.goods);
30
+ // const addComparison = useAddComparison(props.goods);
31
+
32
+ const itemList = React.useMemo(() => {
33
+ const arr: any[] = [];
34
+
35
+ endowCode && arr.push(endowCode); // 赋码
36
+ addDiscount && arr.push(addDiscount); // 添加折扣行
37
+ delItem && arr.push(delItem); // 删除
38
+
39
+ // addComparison && arr.push(addComparison); // 添加商品对照
40
+
41
+ if (!goodsMenuExpand || goodsMenuExpand.length === 0) return arr;
42
+
43
+ arr.unshift(<Menu.Divider key="divider-1" />);
44
+
45
+ for (let i = goodsMenuExpand.length - 1; i >= 0; i--) {
46
+ const fn = goodsMenuExpand[i];
47
+ arr.unshift(fn(props.goods.$index, controller));
48
+ }
49
+
50
+ return arr;
51
+ }, [controller, endowCode, addDiscount, delItem, goodsMenuExpand, props.goods, model, isAddDiscount])
52
+
53
+ const overlay = React.useMemo(() => {
54
+ if (itemList.length <= 2) {
55
+ return undefined
56
+ }
57
+
58
+ return (
59
+ <Menu>
60
+ {itemList.slice(2).map(e => {
61
+ return <Menu.Item key={e.key} onClick={e.onClick} ><Text strong>{e.title}</Text></Menu.Item>
62
+ })}
63
+ </Menu>
64
+ )
65
+ }, [itemList])
66
+
67
+ const buttonList = React.useMemo(() => {
68
+ return (
69
+ <div style={{ flex: 1, textAlign: 'left', display: 'flex', gap: 10 }} >
70
+ {
71
+ itemList.slice(0, 2).map(e => {
72
+ return (
73
+ <Button key={e.key} type='link' onClick={e.onClick} style={{ padding: 0 }} >
74
+ {e.title}
75
+ </Button>
76
+ )
77
+ })
78
+ }
79
+ </div>
80
+ )
81
+ }, [itemList])
82
+
83
+ if (itemList.length === 0) { return (<></>) }
84
+
85
+ return (
86
+ <span style={{ padding: '0 0 0 10px', display: 'flex' }}>
87
+ {buttonList}
88
+ {
89
+ overlay &&
90
+ <Dropdown overlay={overlay} trigger={['click']}>
91
+ <Button className="kts-invoice-operate-goods-list-columns-row-menu ant-btn-icon-only" type="link">
92
+ <Icon component={SpotSvg} />
93
+ </Button>
94
+ </Dropdown>
95
+ }
96
+ </span>
97
+ );
98
+ };
@@ -1,14 +1,14 @@
1
- import React from 'react';
2
- import { Button } from 'kts-components-antd-x3';
3
- import Invoice from '../../../../../../';
4
- import { IGood } from '../../../../../../InvoiceController';
5
-
6
- export default (props: { goods: IGood }) => {
7
- const controller = Invoice.useInvoiceController();
8
-
9
- const onClick = React.useCallback(() => {
10
- controller.saveEditGood();
11
- }, [controller]);
12
-
13
- return <Button type="link" icon="save" onClick={onClick} />;
14
- };
1
+ import React from 'react';
2
+ import { Button } from 'kts-components-antd-x3';
3
+ import Invoice from '../../../../../../';
4
+ import { IGood } from '../../../../../../InvoiceController';
5
+
6
+ export default (props: { goods: IGood }) => {
7
+ const controller = Invoice.useInvoiceController();
8
+
9
+ const onClick = React.useCallback(() => {
10
+ controller.saveEditGood();
11
+ }, [controller]);
12
+
13
+ return <Button type="link" icon="save" onClick={onClick} />;
14
+ };