kts-component-invoice-operate 3.2.192 → 3.2.193

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 (243) 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 +768 -765
  9. package/dist/index.js +768 -765
  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 +62 -62
  18. package/src/Invoice/Invoice-digtal/_test/architecture/index.tsx +21 -21
  19. package/src/Invoice/Invoice-digtal/_test/disabled/index.tsx +40 -40
  20. package/src/Invoice/Invoice-digtal/_test/easiest/index.tsx +29 -29
  21. package/src/Invoice/Invoice-digtal/_test/freight/index.tsx +14574 -14574
  22. package/src/Invoice/Invoice-digtal/_test/header/index.tsx +84 -84
  23. package/src/Invoice/Invoice-digtal/_test/importGoods/index.tsx +868 -868
  24. package/src/Invoice/Invoice-digtal/_test/importStakeholder/index.tsx +18 -18
  25. package/src/Invoice/Invoice-digtal/_test/lineCredit/index.tsx +19 -19
  26. package/src/Invoice/Invoice-digtal/_test/prefab/index.tsx +150 -150
  27. package/src/Invoice/Invoice-digtal/_test/readOnly/index.tsx +55 -55
  28. package/src/Invoice/Invoice-digtal/_test/realEstateInfo/index.tsx +21 -21
  29. package/src/Invoice/Invoice-digtal/_test/stakeholder/index.tsx +12 -12
  30. package/src/Invoice/Invoice-digtal/_test/typeSelection/index.tsx +29 -29
  31. package/src/Invoice/Invoice-digtal/index.md +41 -41
  32. package/src/Invoice/InvoiceController/InvoiceControllerForm/index.ts +105 -105
  33. package/src/Invoice/InvoiceController/InvoiceControllerState/AutoComplete/index.ts +26 -26
  34. package/src/Invoice/InvoiceController/InvoiceControllerState/BuyerState/index.tsx +88 -88
  35. package/src/Invoice/InvoiceController/InvoiceControllerState/FreightListState/IColumnsReplenish/index.ts +10 -10
  36. package/src/Invoice/InvoiceController/InvoiceControllerState/FreightListState/IGood/index.ts +33 -33
  37. package/src/Invoice/InvoiceController/InvoiceControllerState/FreightListState/ImportGoods/index.ts +81 -81
  38. package/src/Invoice/InvoiceController/InvoiceControllerState/FreightListState/index.ts +39 -39
  39. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/Drag/index.ts +15 -15
  40. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/EndowCode/index.tsx +104 -104
  41. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/IColumnsReplenish/index.ts +10 -10
  42. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/IGood/index.ts +87 -87
  43. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/ImportGoods/index.ts +81 -81
  44. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/LineAttributeType/index.ts +7 -7
  45. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/ProductComparison/index.ts +9 -9
  46. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/index.ts +131 -131
  47. package/src/Invoice/InvoiceController/InvoiceControllerState/Stakeholder/index.ts +13 -13
  48. package/src/Invoice/InvoiceController/InvoiceControllerState/index.ts +71 -71
  49. package/src/Invoice/InvoiceController/fns/addFreight.ts +11 -11
  50. package/src/Invoice/InvoiceController/fns/addGood.ts +11 -11
  51. package/src/Invoice/InvoiceController/fns/addGoodDiscount.ts +126 -126
  52. package/src/Invoice/InvoiceController/fns/addGoodDiscountV2.ts +86 -86
  53. package/src/Invoice/InvoiceController/fns/delFreight.ts +38 -38
  54. package/src/Invoice/InvoiceController/fns/delGood.ts +41 -41
  55. package/src/Invoice/InvoiceController/fns/getGoodsSearch.ts +26 -26
  56. package/src/Invoice/InvoiceController/fns/importGoodsDrawer.ts +79 -79
  57. package/src/Invoice/InvoiceController/fns/itemBlur.ts +40 -40
  58. package/src/Invoice/InvoiceController/fns/mergeDetails.ts +201 -201
  59. package/src/Invoice/InvoiceController/fns/mergeDiscount.ts +35 -35
  60. package/src/Invoice/InvoiceController/fns/saveEditFreight.ts +24 -24
  61. package/src/Invoice/InvoiceController/fns/saveEditGood.ts +24 -24
  62. package/src/Invoice/InvoiceController/fns/setEditFreight.ts +16 -16
  63. package/src/Invoice/InvoiceController/fns/setEditGood.ts +16 -16
  64. package/src/Invoice/InvoiceController/fns/setFreight.ts +10 -10
  65. package/src/Invoice/InvoiceController/fns/setGoods.ts +10 -10
  66. package/src/Invoice/InvoiceController/fns/updateInvoiceNo.ts +8 -8
  67. package/src/Invoice/InvoiceController/index.ts +106 -106
  68. package/src/Invoice/_test/buyerNameSearch/index.tsx +42 -42
  69. package/src/Invoice/_test/children/index.tsx +214 -214
  70. package/src/Invoice/_test/deduction/index.tsx +935 -935
  71. package/src/Invoice/_test/draft/index.tsx +40 -40
  72. package/src/Invoice/_test/easiest/index.tsx +5 -5
  73. package/src/Invoice/_test/endowCode/index.tsx +1158 -1158
  74. package/src/Invoice/_test/goodsMenuExpand/index.tsx +32 -32
  75. package/src/Invoice/_test/importBuyer/index.tsx +74 -74
  76. package/src/Invoice/_test/importGoods/index.tsx +1197 -1197
  77. package/src/Invoice/_test/invoiceType/index.tsx +59 -59
  78. package/src/Invoice/_test/isInvoiceNo/index.tsx +12 -12
  79. package/src/Invoice/_test/replaceHead/index.tsx +22 -22
  80. package/src/Invoice/_test/retrieveData/index.tsx +22 -22
  81. package/src/Invoice/_test/seller/index.tsx +28 -28
  82. package/src/Invoice/_test/setDataSource/index.tsx +73 -73
  83. package/src/Invoice/_test/unit/index.tsx +19 -19
  84. package/src/Invoice/index.less +31 -31
  85. package/src/Invoice/index.md +56 -56
  86. package/src/Invoice/index.tsx +190 -190
  87. package/src/Invoice/tools/calculate/index.ts +132 -132
  88. package/src/Invoice/tools/coolingFn/index.ts +17 -17
  89. package/src/Invoice/tools/evaluate/index.ts +7 -7
  90. package/src/Invoice/tools/idGenerator/index.ts +2 -2
  91. package/src/Invoice/tools/itemName/index.ts +55 -55
  92. package/src/Invoice/tools/lazyFn/index.ts +19 -19
  93. package/src/Invoice/tools/mounting/index.ts +13 -13
  94. package/src/Invoice/tools/strringFn/index.ts +40 -40
  95. package/src/Invoice/tools/useToGenerateId/index.ts +10 -10
  96. package/src/Invoice/tools/utils/index.ts +1 -1
  97. package/src/Invoice/tools/utils/money/index.ts +20 -20
  98. package/src/Invoice/ui/default/AddComparisonDrawer/index.tsx +149 -149
  99. package/src/Invoice/ui/default/Buyer/index.less +219 -219
  100. package/src/Invoice/ui/default/Buyer/index.tsx +114 -114
  101. package/src/Invoice/ui/default/Buyer/ui/BuyerNameInput/index.tsx +166 -166
  102. package/src/Invoice/ui/default/Buyer/ui/ImportBuyerButton/index.tsx +21 -21
  103. package/src/Invoice/ui/default/EndowCodeDrawer/index.less +8 -8
  104. package/src/Invoice/ui/default/EndowCodeDrawer/index.tsx +607 -607
  105. package/src/Invoice/ui/default/GoodsList/hook/useColumns/autoFillFn/index.ts +647 -647
  106. package/src/Invoice/ui/default/GoodsList/hook/useColumns/index.tsx +711 -711
  107. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/Drag/index.less +20 -20
  108. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/Drag/index.tsx +205 -205
  109. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/Expand/index.tsx +57 -57
  110. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemCodeInput/index.less +18 -18
  111. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemCodeInput/index.tsx +49 -49
  112. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemNameInput/index.less +17 -17
  113. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemNameInput/index.tsx +91 -91
  114. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowEditButton/index.tsx +30 -30
  115. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/_useAddComparison/index.tsx +43 -43
  116. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useAddDiscount/index.tsx +118 -118
  117. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useDelItem/index.tsx +41 -41
  118. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useEndowCode/index.tsx +25 -25
  119. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/index.less +13 -13
  120. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/index.tsx +99 -99
  121. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowSaveButton/index.tsx +14 -14
  122. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/TitleText/index.tsx +20 -20
  123. package/src/Invoice/ui/default/GoodsList/hook/useDeduction/index.tsx +24 -24
  124. package/src/Invoice/ui/default/GoodsList/hook/useOnRow/index.tsx +52 -52
  125. package/src/Invoice/ui/default/GoodsList/hook/useRowSelection/index.tsx +120 -120
  126. package/src/Invoice/ui/default/GoodsList/hook/useWindowClick/index.tsx +23 -23
  127. package/src/Invoice/ui/default/GoodsList/index.less +185 -185
  128. package/src/Invoice/ui/default/GoodsList/index.tsx +205 -205
  129. package/src/Invoice/ui/default/GoodsList/ui/AddRowButton/index.tsx +65 -65
  130. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/index.less +21 -21
  131. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/index.tsx +244 -244
  132. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useCommodityComparisonButton/index.tsx +75 -75
  133. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useDelRowButton/index.tsx +69 -69
  134. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useEndowCodeButton/index.tsx +65 -65
  135. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useMergeDetails/index.tsx +91 -91
  136. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useMergeDiscount/index.tsx +36 -36
  137. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useSalesDiscount/index.tsx +109 -109
  138. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useSalesGifts/index.tsx +94 -94
  139. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/index.tsx +37 -37
  140. package/src/Invoice/ui/default/GoodsList/ui/DescribeSwitch/index.tsx +36 -36
  141. package/src/Invoice/ui/default/GoodsList/ui/Search/index.less +10 -10
  142. package/src/Invoice/ui/default/GoodsList/ui/Search/index.tsx +52 -52
  143. package/src/Invoice/ui/default/GoodsList/ui/Statistics/index.less +18 -18
  144. package/src/Invoice/ui/default/GoodsList/ui/Statistics/index.tsx +114 -114
  145. package/src/Invoice/ui/default/GoodsList/ui/TableRow/index.less +40 -40
  146. package/src/Invoice/ui/default/GoodsList/ui/TableRow/index.tsx +71 -71
  147. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual/index.less +38 -38
  148. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual/index.tsx +130 -130
  149. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual.o/index.less +44 -44
  150. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual.o/index.tsx +96 -96
  151. package/src/Invoice/ui/default/GoodsList/ui/TaxIncludedSwitch/index.tsx +31 -31
  152. package/src/Invoice/ui/default/ImportBuyerDrawer/index.tsx +75 -75
  153. package/src/Invoice/ui/default/ImportGoodsDrawer/index.tsx +198 -198
  154. package/src/Invoice/ui/default/InvoiceHeader/index.less +68 -68
  155. package/src/Invoice/ui/default/InvoiceHeader/index.tsx +246 -246
  156. package/src/Invoice/ui/default/Seller/index.less +113 -113
  157. package/src/Invoice/ui/default/Seller/index.tsx +98 -98
  158. package/src/Invoice/ui/default/Sign/index.less +14 -14
  159. package/src/Invoice/ui/default/Sign/index.tsx +71 -71
  160. package/src/Invoice/ui/digtal/Architecture/index.less +18 -18
  161. package/src/Invoice/ui/digtal/Architecture/index.tsx +177 -177
  162. package/src/Invoice/ui/digtal/FreightList/hook/useColumns/dist/index.js +616 -616
  163. package/src/Invoice/ui/digtal/FreightList/hook/useColumns/index.tsx +246 -246
  164. package/src/Invoice/ui/digtal/FreightList/hook/useColumns/ui/TitleText/index.tsx +20 -20
  165. package/src/Invoice/ui/digtal/FreightList/hook/useOnRow/index.tsx +37 -37
  166. package/src/Invoice/ui/digtal/FreightList/hook/useRowSelection/index.tsx +119 -119
  167. package/src/Invoice/ui/digtal/FreightList/hook/useWindowClick/index.tsx +23 -23
  168. package/src/Invoice/ui/digtal/FreightList/index.less +72 -72
  169. package/src/Invoice/ui/digtal/FreightList/index.tsx +129 -129
  170. package/src/Invoice/ui/digtal/FreightList/ui/AddRowButton/index.tsx +64 -64
  171. package/src/Invoice/ui/digtal/FreightList/ui/BulkMenu/hooks/useDelRowButton/index.tsx +50 -50
  172. package/src/Invoice/ui/digtal/FreightList/ui/BulkMenu/hooks/useEmptyRefill/index.tsx +36 -36
  173. package/src/Invoice/ui/digtal/FreightList/ui/TableRow/index.less +28 -28
  174. package/src/Invoice/ui/digtal/FreightList/ui/TableRow/index.tsx +20 -20
  175. package/src/Invoice/ui/digtal/FreightList/ui/TableVirtual/index.less +38 -38
  176. package/src/Invoice/ui/digtal/FreightList/ui/TableVirtual/index.tsx +108 -108
  177. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/autoFillFn/index.ts +673 -673
  178. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/index.tsx +673 -673
  179. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/svg/plus.svg +11 -11
  180. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/Drag/index.less +20 -20
  181. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/Drag/index.tsx +205 -205
  182. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/ItemNameInput/index.less +9 -9
  183. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/ItemNameInput/index.tsx +87 -87
  184. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowEditButton/index.tsx +30 -30
  185. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/_useAddComparison/index.tsx +43 -43
  186. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/useAddDiscount/index.tsx +76 -76
  187. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/useDelItem/index.tsx +41 -41
  188. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/useEndowCode/index.tsx +34 -34
  189. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/index.less +13 -13
  190. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/index.tsx +98 -98
  191. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowSaveButton/index.tsx +14 -14
  192. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/TitleText/index.tsx +20 -20
  193. package/src/Invoice/ui/digtal/GoodsList/hook/useOnRow/index.tsx +51 -51
  194. package/src/Invoice/ui/digtal/GoodsList/hook/useRowSelection/index.tsx +121 -121
  195. package/src/Invoice/ui/digtal/GoodsList/hook/useWindowClick/index.tsx +23 -23
  196. package/src/Invoice/ui/digtal/GoodsList/index.less +56 -56
  197. package/src/Invoice/ui/digtal/GoodsList/index.tsx +179 -179
  198. package/src/Invoice/ui/digtal/GoodsList/ui/AddRowButton/index.tsx +67 -67
  199. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/index.tsx +340 -340
  200. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/svg/add.svg +11 -11
  201. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useCommodityComparisonButton/index.tsx +75 -75
  202. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useDelRowButton/index.tsx +50 -50
  203. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useEmptyRefill/index.tsx +37 -37
  204. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useEndowCodeButton/index.tsx +82 -82
  205. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useReselectInvoiceType/index.tsx +57 -57
  206. package/src/Invoice/ui/digtal/GoodsList/ui/DescribeSwitch/index.tsx +36 -36
  207. package/src/Invoice/ui/digtal/GoodsList/ui/Search/index.less +11 -11
  208. package/src/Invoice/ui/digtal/GoodsList/ui/Search/index.tsx +50 -50
  209. package/src/Invoice/ui/digtal/GoodsList/ui/Statistics/index.less +53 -53
  210. package/src/Invoice/ui/digtal/GoodsList/ui/Statistics/index.tsx +98 -98
  211. package/src/Invoice/ui/digtal/GoodsList/ui/Statistics/svg/fork.svg +11 -11
  212. package/src/Invoice/ui/digtal/GoodsList/ui/TableRow/index.less +28 -28
  213. package/src/Invoice/ui/digtal/GoodsList/ui/TableRow/index.tsx +52 -52
  214. package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual/index.less +38 -38
  215. package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual/index.tsx +108 -108
  216. package/src/Invoice/ui/digtal/GoodsList/ui/TaxIncludedSwitch/index.tsx +31 -31
  217. package/src/Invoice/ui/digtal/InvoiceHeader/index.less +57 -57
  218. package/src/Invoice/ui/digtal/InvoiceHeader/index.tsx +77 -77
  219. package/src/Invoice/ui/digtal/RealEstateInfo/index.less +14 -14
  220. package/src/Invoice/ui/digtal/RealEstateInfo/index.tsx +192 -192
  221. package/src/Invoice/ui/digtal/Sign/index.less +48 -48
  222. package/src/Invoice/ui/digtal/Sign/index.tsx +99 -99
  223. package/src/Invoice/ui/digtal/StakeFarmerholder/index.less +99 -99
  224. package/src/Invoice/ui/digtal/StakeFarmerholder/index.tsx +436 -436
  225. package/src/Invoice/ui/digtal/StakeFarmerholder/svg/arrowDown.svg +2 -2
  226. package/src/Invoice/ui/digtal/StakeFarmerholder/svg/arrowUp.svg +2 -2
  227. package/src/Invoice/ui/digtal/StakeFarmerholder/svg/plus.svg +11 -11
  228. package/src/Invoice/ui/digtal/Stakeholder/index.less +99 -99
  229. package/src/Invoice/ui/digtal/Stakeholder/index.tsx +433 -433
  230. package/src/Invoice/ui/digtal/Stakeholder/svg/arrowDown.svg +2 -2
  231. package/src/Invoice/ui/digtal/Stakeholder/svg/arrowUp.svg +2 -2
  232. package/src/Invoice/ui/digtal/Stakeholder/svg/plus.svg +11 -11
  233. package/src/InvoiceTypeModal/_test/easiest/index.tsx +31 -31
  234. package/src/InvoiceTypeModal/index.less +7 -7
  235. package/src/InvoiceTypeModal/index.md +5 -5
  236. package/src/InvoiceTypeModal/index.tsx +161 -161
  237. package/src/TaxClassificationCodeModal/_test/easiest/index.tsx +184 -184
  238. package/src/TaxClassificationCodeModal/index.less +17 -17
  239. package/src/TaxClassificationCodeModal/index.md +6 -6
  240. package/src/TaxClassificationCodeModal/index.tsx +152 -152
  241. package/src/index.ts +13 -13
  242. package/tsconfig.json +31 -31
  243. package/typings.d.ts +3 -3
@@ -1,119 +1,119 @@
1
-
2
- import React from 'react';
3
- import { Typography } from 'kts-components-antd-x3';
4
- import { message } from 'kts-xui';
5
- import InvoiceController, { 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 model = controller.useMemo(s => s.model, [])
15
-
16
- /** 是否能添加折扣行 */
17
- const isAddDiscount = controller.useMemo(s => s.goodsListState.isAddDiscount, [])
18
-
19
- /** 点击了 添加折扣行 按钮 */
20
- const onClick = React.useCallback(async e => {
21
- try {
22
- e.stopPropagation()
23
- await controller.wait();
24
- await controller.saveEditGood();
25
- await checkDiscount(controller);
26
- await checkFieldsError(controller, goods);
27
- await checkDutyFree(controller, goods);
28
- await checkZeroAmount(controller, goods);
29
- await controller.run(async s => {
30
- s.goodsListState.discountGoodIndex = [goods.$index];
31
- })
32
- } catch (error: any) {
33
- console.error(error);
34
- }
35
- }, [controller, goods.$index]);
36
-
37
- if (goods.lineAttribute !== LineAttributeType.正常) {
38
- return undefined
39
- }
40
-
41
- if (!(model !== 'prefab')) {
42
- return undefined;
43
- }
44
-
45
- if (!(isAddDiscount !== false)) {
46
- return undefined
47
- }
48
-
49
- if (goods.lineAttribute !== LineAttributeType.正常) {
50
- return undefined
51
- }
52
-
53
- return {
54
- key: 'addDiscount',
55
- title: '折扣',
56
- onClick,
57
- }
58
- };
59
-
60
- /**
61
- * 有折让行,不可以添加折扣
62
- * @param controller 组件控制器
63
- */
64
- async function checkDiscount(controller: InvoiceController) {
65
- const { goodsList } = controller.state.goodsListState;
66
- goodsList.forEach(e => {
67
- if (e.lineAttribute === LineAttributeType.折让行) {
68
- const content = '有折让行,不可以添加折扣';
69
- message.error({ content, key: content });
70
- throw new Error(content)
71
- }
72
- })
73
- }
74
-
75
- /**
76
- * 零税率需要设置免税类型,请在赋码中设置!
77
- * @param controller 组件控制器
78
- * @param goods 当前行数据
79
- */
80
- async function checkDutyFree(controller: InvoiceController, goods: IGood) {
81
- goods = controller.state.goodsListState.goodsList.filter(e => e.$index === goods.$index)[0];
82
- if (goods.taxRate === 0 && controller.state.goodsListState.endowCode.isTaxFreeTypeNeeded && !goods.taxFreeType) {
83
- const content = '零税率需要设置免税类型,请在赋码中设置!'
84
- message.error({ content, key: content });
85
- throw new Error(content)
86
- }
87
- }
88
-
89
- /**
90
- * 金额为0不能添加折扣行
91
- * @param controller 组件控制器
92
- * @param goods 当前行数据
93
- **/
94
- async function checkZeroAmount(controller: InvoiceController, goods: IGood) {
95
- goods = controller.state.goodsListState.goodsList.filter(e => e.$index === goods.$index)[0];
96
- if (`${goods.lineAmountIncludeTax}` === '0') {
97
- const content = '金额为0不能添加折扣行'
98
- message.error({ content, key: content });
99
- throw new Error(content)
100
- }
101
- }
102
-
103
- /**
104
- * 校验当前的表单
105
- * @param controller 组件控制器
106
- * @param goods 当前行数据
107
- * */
108
- async function checkFieldsError(controller: InvoiceController, goods: IGood) {
109
- const s = controller.state;
110
- if (s.goodsListState.form && s.goodsListState.editGood?.$index === goods?.$index) {
111
- const err: any = s.goodsListState.form.getFieldsError();
112
- for (let key in err) {
113
- if (!err[key]) continue;
114
- const content = err[key][0];
115
- message.error({ content, key: content });
116
- throw new Error(content)
117
- }
118
- }
1
+
2
+ import React from 'react';
3
+ import { Typography } from 'kts-components-antd-x3';
4
+ import { message } from 'kts-xui';
5
+ import InvoiceController, { 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 model = controller.useMemo(s => s.model, [])
15
+
16
+ /** 是否能添加折扣行 */
17
+ const isAddDiscount = controller.useMemo(s => s.goodsListState.isAddDiscount, [])
18
+
19
+ /** 点击了 添加折扣行 按钮 */
20
+ const onClick = React.useCallback(async e => {
21
+ try {
22
+ e.stopPropagation()
23
+ await controller.wait();
24
+ await controller.saveEditGood();
25
+ await checkDiscount(controller);
26
+ await checkFieldsError(controller, goods);
27
+ await checkDutyFree(controller, goods);
28
+ await checkZeroAmount(controller, goods);
29
+ await controller.run(async s => {
30
+ s.goodsListState.discountGoodIndex = [goods.$index];
31
+ })
32
+ } catch (error: any) {
33
+ console.error(error);
34
+ }
35
+ }, [controller, goods.$index]);
36
+
37
+ if (goods.lineAttribute !== LineAttributeType.正常) {
38
+ return undefined
39
+ }
40
+
41
+ if (!(model !== 'prefab')) {
42
+ return undefined;
43
+ }
44
+
45
+ if (!(isAddDiscount !== false)) {
46
+ return undefined
47
+ }
48
+
49
+ if (goods.lineAttribute !== LineAttributeType.正常) {
50
+ return undefined
51
+ }
52
+
53
+ return {
54
+ key: 'addDiscount',
55
+ title: '折扣',
56
+ onClick,
57
+ }
58
+ };
59
+
60
+ /**
61
+ * 有折让行,不可以添加折扣
62
+ * @param controller 组件控制器
63
+ */
64
+ async function checkDiscount(controller: InvoiceController) {
65
+ const { goodsList } = controller.state.goodsListState;
66
+ goodsList.forEach(e => {
67
+ if (e.lineAttribute === LineAttributeType.折让行) {
68
+ const content = '有折让行,不可以添加折扣';
69
+ message.error({ content, key: content });
70
+ throw new Error(content)
71
+ }
72
+ })
73
+ }
74
+
75
+ /**
76
+ * 零税率需要设置免税类型,请在赋码中设置!
77
+ * @param controller 组件控制器
78
+ * @param goods 当前行数据
79
+ */
80
+ async function checkDutyFree(controller: InvoiceController, goods: IGood) {
81
+ goods = controller.state.goodsListState.goodsList.filter(e => e.$index === goods.$index)[0];
82
+ if (goods.taxRate === 0 && controller.state.goodsListState.endowCode.isTaxFreeTypeNeeded && !goods.taxFreeType) {
83
+ const content = '零税率需要设置免税类型,请在赋码中设置!'
84
+ message.error({ content, key: content });
85
+ throw new Error(content)
86
+ }
87
+ }
88
+
89
+ /**
90
+ * 金额为0不能添加折扣行
91
+ * @param controller 组件控制器
92
+ * @param goods 当前行数据
93
+ **/
94
+ async function checkZeroAmount(controller: InvoiceController, goods: IGood) {
95
+ goods = controller.state.goodsListState.goodsList.filter(e => e.$index === goods.$index)[0];
96
+ if (`${goods.lineAmountIncludeTax}` === '0') {
97
+ const content = '金额为0不能添加折扣行'
98
+ message.error({ content, key: content });
99
+ throw new Error(content)
100
+ }
101
+ }
102
+
103
+ /**
104
+ * 校验当前的表单
105
+ * @param controller 组件控制器
106
+ * @param goods 当前行数据
107
+ * */
108
+ async function checkFieldsError(controller: InvoiceController, goods: IGood) {
109
+ const s = controller.state;
110
+ if (s.goodsListState.form && s.goodsListState.editGood?.$index === goods?.$index) {
111
+ const err: any = s.goodsListState.form.getFieldsError();
112
+ for (let key in err) {
113
+ if (!err[key]) continue;
114
+ const content = err[key][0];
115
+ message.error({ content, key: content });
116
+ throw new Error(content)
117
+ }
118
+ }
119
119
  }
@@ -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,25 +1,25 @@
1
- import React from 'react';
2
- import Invoice from '../../../../../../../../..';
3
- import { endowCode } from '../../../../autoFillFn';
4
- import { IGood, LineAttributeType } from '../../../../../../../../../InvoiceController';
5
-
6
- // const { Text } = Typography;
7
-
8
- export default (goods: IGood) => {
9
-
10
- const controller = Invoice.useInvoiceController();
11
-
12
- const onClick = React.useCallback(async () => {
13
- endowCode(controller, goods);
14
- }, [controller, goods]);
15
-
16
- if ([LineAttributeType.正常, LineAttributeType.被折扣行, LineAttributeType.折扣行].indexOf(goods.lineAttribute) >= 0) {
17
- return {
18
- key: 'endowCode',
19
- title: '赋码',
20
- onClick,
21
- }
22
- } else {
23
- return undefined
24
- }
25
- };
1
+ import React from 'react';
2
+ import Invoice from '../../../../../../../../..';
3
+ import { endowCode } from '../../../../autoFillFn';
4
+ import { IGood, LineAttributeType } from '../../../../../../../../../InvoiceController';
5
+
6
+ // const { Text } = Typography;
7
+
8
+ export default (goods: IGood) => {
9
+
10
+ const controller = Invoice.useInvoiceController();
11
+
12
+ const onClick = React.useCallback(async () => {
13
+ endowCode(controller, goods);
14
+ }, [controller, goods]);
15
+
16
+ if ([LineAttributeType.正常, LineAttributeType.被折扣行, LineAttributeType.折扣行].indexOf(goods.lineAttribute) >= 0) {
17
+ return {
18
+ key: 'endowCode',
19
+ title: '赋码',
20
+ onClick,
21
+ }
22
+ } else {
23
+ return undefined
24
+ }
25
+ };
@@ -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,99 +1,99 @@
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 (props.goods.level && props.goods.level > 0) { return <></> }
84
- if (itemList.length === 0) { return (<></>) }
85
-
86
- return (
87
- <span style={{ padding: '0 0 0 10px', display: 'flex' }}>
88
- {buttonList}
89
- {
90
- overlay &&
91
- <Dropdown overlay={overlay} trigger={['click']}>
92
- <Button className="kts-invoice-operate-goods-list-columns-row-menu ant-btn-icon-only" type="link">
93
- <Icon component={SpotSvg} />
94
- </Button>
95
- </Dropdown>
96
- }
97
- </span>
98
- );
99
- };
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 (props.goods.level && props.goods.level > 0) { return <></> }
84
+ if (itemList.length === 0) { return (<></>) }
85
+
86
+ return (
87
+ <span style={{ padding: '0 0 0 10px', display: 'flex' }}>
88
+ {buttonList}
89
+ {
90
+ overlay &&
91
+ <Dropdown overlay={overlay} trigger={['click']}>
92
+ <Button className="kts-invoice-operate-goods-list-columns-row-menu ant-btn-icon-only" type="link">
93
+ <Icon component={SpotSvg} />
94
+ </Button>
95
+ </Dropdown>
96
+ }
97
+ </span>
98
+ );
99
+ };
@@ -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
+ };