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,130 +1,130 @@
1
-
2
- import { Input } from 'kts-components-antd-x3';
3
- import React, { ChangeEvent } from 'react';
4
- import { AutoComplete } from 'kts-xui';
5
- // import { countAmountIncludeTax } from '../../../../../../../tools/calculate'
6
- import { IGood, Invoice } from '../../../../../../../..';
7
- import './index.less';
8
- // import { dutyFree, format15, updateUnitPriceExcludingTax, updateUnitPriceTax } from '../../autoFillFn';
9
- // import evaluate from '../../../../../../../tools/evaluate';
10
-
11
- export default function ItemNameInput(props: { onChange?: (e: ChangeEvent<HTMLInputElement>) => void, value?: string, shorthand?: string }) {
12
-
13
- const controller = Invoice.useInvoiceController();
14
-
15
- const autoComplete = controller.useMemo(s => s.autoComplete, [])
16
-
17
- const editGood = controller.useMemo((e) => e.goodsListState.editGood, []);
18
-
19
- const [options, setOptions] = React.useState<IGood[]>([])
20
-
21
- const onChange = React.useCallback((e: ChangeEvent<HTMLInputElement>) => {
22
- const event = { ...e };
23
- props.onChange && props.onChange(event);
24
- }, [])
25
-
26
- const onSearch = React.useCallback(async (searchText: string) => {
27
- try {
28
- if (autoComplete.onItemNameSearch) {
29
- setOptions(await autoComplete.onItemNameSearch(searchText))
30
- }
31
- } catch (error) {
32
- setOptions([])
33
- throw error;
34
- }
35
- }, [autoComplete.onItemNameSearch])
36
-
37
- const onChangeAutoComplete = React.useCallback(async itemName => {
38
- // const good = options.filter(e=>e.itemName === itemName)[0];
39
- // good && controller.state.goodsListState.form?.setFieldsValue(removeNullUndefined(good));
40
-
41
- const record = options.filter(e => e.itemName === itemName)[0] as any;
42
- if (!record) return;
43
-
44
- await controller.setEditGood({ itemName: record.itemName });
45
-
46
- controller.importGoodsDrawer(record);
47
- // controller.run(async s => {
48
- // Object.keys(record).filter(e => !record[e] && record[e] !== 0).forEach(e => { delete record[e] });
49
-
50
- // // 没用 被编辑的货物 和 form 就退出
51
- // if (!s.goodsListState.editGood || !s.goodsListState.form) return;
52
-
53
- // // 导入时清空之前输入的值,使用导入的单价和税率(参考税局系统)
54
- // record.quantity = undefined;
55
- // record.lineAmountExcludeTax = undefined;
56
- // record.lineAmountIncludeTax = undefined;
57
-
58
- // // 中间数据
59
- // const between = { ...record };
60
- // between.itemName = record.itemName;
61
- // between.itemNameOther = record.itemName;
62
-
63
- // // 设置编辑货物
64
- // const editGood: IGood = s.goodsListState.editGood = { ...s.goodsListState.editGood, ...between };
65
-
66
- // if (editGood.taxRate) {
67
- // editGood.taxRate = dutyFree(controller, editGood.taxRate, s.goodsListState.form, editGood)
68
- // }
69
-
70
- // if (`${editGood.priceIncludeTax}` === '0') {
71
- // editGood.priceIncludeTax = undefined;
72
- // editGood.priceExcludeTax = undefined;
73
- // } else {
74
- // editGood.priceExcludeTax = getPriceExcludeTax(editGood, record, s.calculatingDigits) as number;
75
- // }
76
-
77
- // if (editGood.quantity && editGood.priceIncludeTax) {
78
- // editGood.lineAmountIncludeTax = countAmountIncludeTax(editGood.quantity, editGood.priceIncludeTax, s.calculatingDigits);
79
- // }
80
-
81
- // // 导入FORM里
82
- // if (s.goodsListState.isMyShow) {
83
- // s.goodsListState.form.setFieldsValue({
84
- // ...editGood,
85
- // itemName: editGood.itemNameSelf,
86
- // itemModelName: editGood.itemModelNameSelf,
87
- // });
88
- // } else {
89
- // s.goodsListState.form.setFieldsValue({
90
- // ...editGood,
91
- // });
92
- // }
93
-
94
- // s.goodsListState.importGoods.isVisibleDrawer = false;
95
- // s.goodsListState.isTaxIncluded
96
- // ? await updateUnitPriceExcludingTax(controller, s.goodsListState.form, record)
97
- // : await updateUnitPriceTax(controller, s.goodsListState.form, record)
98
- // })
99
- }, [options, controller])
100
-
101
- return (
102
- <div className='kts-invoice-operate-goods-list-itemName-input'>
103
- {props.shorthand && <span style={{ alignSelf: 'center', fontSize: 12 }} >*{props.shorthand}*</span>}
104
- <AutoComplete onSearch={onSearch} defaultValue={props.value} value={editGood?.itemName} options={options.map(e => ({ value: e.itemName }))} onSelect={onChangeAutoComplete} >
105
- <Input style={{ height: '100%', border: 'none' }} value={props.value} onChange={onChange} />
106
- </AutoComplete>
107
- </div>
108
- )
109
- }
110
-
111
-
112
- // function removeNullUndefined(obj: Record<string, any>): Record<string, any> {
113
- // const filteredObj: Record<string, any> = {};
114
-
115
- // for (const key in obj) {
116
- // if (obj[key] !== null && obj[key] !== undefined) {
117
- // filteredObj[key] = obj[key];
118
- // }
119
- // }
120
-
121
- // return filteredObj;
122
- // }
123
-
124
- /** 货物单价,不含税 */
125
- // const getPriceExcludeTax = (s: IGood, record: any, calculatingDigits?: number) => {
126
- // if ((!s.taxRate && s.taxRate !== 0) || (!record.priceIncludeTax && record.priceIncludeTax !== 0)) return;
127
-
128
- // // 单价(含税)/(1+税率) = 单价(不含税)
129
- // return format15(evaluate(`${record.priceIncludeTax} / (1+${s.taxRate}/100)`), calculatingDigits);
130
- // };
1
+
2
+ import { Input } from 'kts-components-antd-x3';
3
+ import React, { ChangeEvent } from 'react';
4
+ import { AutoComplete } from 'kts-xui';
5
+ // import { countAmountIncludeTax } from '../../../../../../../tools/calculate'
6
+ import { IGood, Invoice } from '../../../../../../../..';
7
+ import './index.less';
8
+ // import { dutyFree, format15, updateUnitPriceExcludingTax, updateUnitPriceTax } from '../../autoFillFn';
9
+ // import evaluate from '../../../../../../../tools/evaluate';
10
+
11
+ export default function ItemNameInput(props: { onChange?: (e: ChangeEvent<HTMLInputElement>) => void, value?: string, shorthand?: string }) {
12
+
13
+ const controller = Invoice.useInvoiceController();
14
+
15
+ const autoComplete = controller.useMemo(s => s.autoComplete, [])
16
+
17
+ const editGood = controller.useMemo((e) => e.goodsListState.editGood, []);
18
+
19
+ const [options, setOptions] = React.useState<IGood[]>([])
20
+
21
+ const onChange = React.useCallback((e: ChangeEvent<HTMLInputElement>) => {
22
+ const event = { ...e };
23
+ props.onChange && props.onChange(event);
24
+ }, [])
25
+
26
+ const onSearch = React.useCallback(async (searchText: string) => {
27
+ try {
28
+ if (autoComplete.onItemNameSearch) {
29
+ setOptions(await autoComplete.onItemNameSearch(searchText))
30
+ }
31
+ } catch (error) {
32
+ setOptions([])
33
+ throw error;
34
+ }
35
+ }, [autoComplete.onItemNameSearch])
36
+
37
+ const onChangeAutoComplete = React.useCallback(async itemName => {
38
+ // const good = options.filter(e=>e.itemName === itemName)[0];
39
+ // good && controller.state.goodsListState.form?.setFieldsValue(removeNullUndefined(good));
40
+
41
+ const record = options.filter(e => e.itemName === itemName)[0] as any;
42
+ if (!record) return;
43
+
44
+ await controller.setEditGood({ itemName: record.itemName });
45
+
46
+ controller.importGoodsDrawer(record);
47
+ // controller.run(async s => {
48
+ // Object.keys(record).filter(e => !record[e] && record[e] !== 0).forEach(e => { delete record[e] });
49
+
50
+ // // 没用 被编辑的货物 和 form 就退出
51
+ // if (!s.goodsListState.editGood || !s.goodsListState.form) return;
52
+
53
+ // // 导入时清空之前输入的值,使用导入的单价和税率(参考税局系统)
54
+ // record.quantity = undefined;
55
+ // record.lineAmountExcludeTax = undefined;
56
+ // record.lineAmountIncludeTax = undefined;
57
+
58
+ // // 中间数据
59
+ // const between = { ...record };
60
+ // between.itemName = record.itemName;
61
+ // between.itemNameOther = record.itemName;
62
+
63
+ // // 设置编辑货物
64
+ // const editGood: IGood = s.goodsListState.editGood = { ...s.goodsListState.editGood, ...between };
65
+
66
+ // if (editGood.taxRate) {
67
+ // editGood.taxRate = dutyFree(controller, editGood.taxRate, s.goodsListState.form, editGood)
68
+ // }
69
+
70
+ // if (`${editGood.priceIncludeTax}` === '0') {
71
+ // editGood.priceIncludeTax = undefined;
72
+ // editGood.priceExcludeTax = undefined;
73
+ // } else {
74
+ // editGood.priceExcludeTax = getPriceExcludeTax(editGood, record, s.calculatingDigits) as number;
75
+ // }
76
+
77
+ // if (editGood.quantity && editGood.priceIncludeTax) {
78
+ // editGood.lineAmountIncludeTax = countAmountIncludeTax(editGood.quantity, editGood.priceIncludeTax, s.calculatingDigits);
79
+ // }
80
+
81
+ // // 导入FORM里
82
+ // if (s.goodsListState.isMyShow) {
83
+ // s.goodsListState.form.setFieldsValue({
84
+ // ...editGood,
85
+ // itemName: editGood.itemNameSelf,
86
+ // itemModelName: editGood.itemModelNameSelf,
87
+ // });
88
+ // } else {
89
+ // s.goodsListState.form.setFieldsValue({
90
+ // ...editGood,
91
+ // });
92
+ // }
93
+
94
+ // s.goodsListState.importGoods.isVisibleDrawer = false;
95
+ // s.goodsListState.isTaxIncluded
96
+ // ? await updateUnitPriceExcludingTax(controller, s.goodsListState.form, record)
97
+ // : await updateUnitPriceTax(controller, s.goodsListState.form, record)
98
+ // })
99
+ }, [options, controller])
100
+
101
+ return (
102
+ <div className='kts-invoice-operate-goods-list-itemName-input'>
103
+ {props.shorthand && <span style={{ alignSelf: 'center', fontSize: 12 }} >*{props.shorthand}*</span>}
104
+ <AutoComplete onSearch={onSearch} defaultValue={props.value} value={editGood?.itemName} options={options.map(e => ({ value: e.itemName }))} onSelect={onChangeAutoComplete} >
105
+ <Input style={{ height: '100%', border: 'none' }} value={props.value} onChange={onChange} />
106
+ </AutoComplete>
107
+ </div>
108
+ )
109
+ }
110
+
111
+
112
+ // function removeNullUndefined(obj: Record<string, any>): Record<string, any> {
113
+ // const filteredObj: Record<string, any> = {};
114
+
115
+ // for (const key in obj) {
116
+ // if (obj[key] !== null && obj[key] !== undefined) {
117
+ // filteredObj[key] = obj[key];
118
+ // }
119
+ // }
120
+
121
+ // return filteredObj;
122
+ // }
123
+
124
+ /** 货物单价,不含税 */
125
+ // const getPriceExcludeTax = (s: IGood, record: any, calculatingDigits?: number) => {
126
+ // if ((!s.taxRate && s.taxRate !== 0) || (!record.priceIncludeTax && record.priceIncludeTax !== 0)) return;
127
+
128
+ // // 单价(含税)/(1+税率) = 单价(不含税)
129
+ // return format15(evaluate(`${record.priceIncludeTax} / (1+${s.taxRate}/100)`), calculatingDigits);
130
+ // };
@@ -1,30 +1,30 @@
1
- import React from 'react';
2
- import { Button, message } from 'kts-components-antd-x3';
3
- import Invoice from '../../../../../../';
4
- import { IGood } from '../../../../../../InvoiceController';
5
- import LineAttributeType from '../../../../../../InvoiceController/InvoiceControllerState/GoodsListState/LineAttributeType';
6
-
7
- export default (props: { goods: IGood }) => {
8
- const { goods } = props;
9
-
10
- const controller = Invoice.useInvoiceController();
11
-
12
- const editGood = controller.useMemo((s) => s.goodsListState.editGood, []);
13
-
14
- const onClick = React.useCallback(() => {
15
- if (editGood) {
16
- message.error({
17
- content: '你正在编辑一个货物',
18
- key: '你正在编辑一个货物',
19
- });
20
- return;
21
- }
22
- controller.setEditGood(goods);
23
- }, [controller, goods, editGood]);
24
-
25
- if (goods.lineAttribute !== LineAttributeType.正常) {
26
- return <></>;
27
- } else {
28
- return <Button type="link" icon="edit" onClick={onClick} />;
29
- }
30
- };
1
+ import React from 'react';
2
+ import { Button, message } from 'kts-components-antd-x3';
3
+ import Invoice from '../../../../../../';
4
+ import { IGood } from '../../../../../../InvoiceController';
5
+ import LineAttributeType from '../../../../../../InvoiceController/InvoiceControllerState/GoodsListState/LineAttributeType';
6
+
7
+ export default (props: { goods: IGood }) => {
8
+ const { goods } = props;
9
+
10
+ const controller = Invoice.useInvoiceController();
11
+
12
+ const editGood = controller.useMemo((s) => s.goodsListState.editGood, []);
13
+
14
+ const onClick = React.useCallback(() => {
15
+ if (editGood) {
16
+ message.error({
17
+ content: '你正在编辑一个货物',
18
+ key: '你正在编辑一个货物',
19
+ });
20
+ return;
21
+ }
22
+ controller.setEditGood(goods);
23
+ }, [controller, goods, editGood]);
24
+
25
+ if (goods.lineAttribute !== LineAttributeType.正常) {
26
+ return <></>;
27
+ } else {
28
+ return <Button type="link" icon="edit" onClick={onClick} />;
29
+ }
30
+ };
@@ -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
+ };