kts-component-invoice-operate 3.2.145 → 3.2.147

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 (211) 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 +715 -605
  9. package/dist/index.js +715 -605
  10. package/docs/index.md +5 -5
  11. package/docs-dist/static/I001.a774b052.svg +1 -0
  12. package/docs-dist/static/{arrowDown.a1cbf0d8.svg → arrowDown.22c7885c.svg} +2 -2
  13. package/docs-dist/static/{arrowUp.4c482054.svg → arrowUp.d707a3e4.svg} +2 -2
  14. package/docs-dist/static/{fork.5431267d.svg → fork.43eb4ffa.svg} +11 -11
  15. package/docs-dist/static/{plus.4fd1af30.svg → plus.0e60e9ea.svg} +11 -11
  16. package/docs-dist/static/{plus.44013ce3.svg → plus.384f41d9.svg} +11 -11
  17. package/docs-dist/umi.css +2 -3
  18. package/docs-dist/umi.js +1 -1
  19. package/index.html +12 -12
  20. package/package.json +61 -61
  21. package/src/Invoice/Invoice-digtal/_test/disabled/index.tsx +40 -39
  22. package/src/Invoice/Invoice-digtal/_test/easiest/index.tsx +16 -16
  23. package/src/Invoice/Invoice-digtal/_test/header/index.tsx +84 -84
  24. package/src/Invoice/Invoice-digtal/_test/importGoods/index.tsx +868 -868
  25. package/src/Invoice/Invoice-digtal/_test/importStakeholder/index.tsx +18 -18
  26. package/src/Invoice/Invoice-digtal/_test/lineCredit/index.tsx +19 -19
  27. package/src/Invoice/Invoice-digtal/_test/prefab/index.tsx +150 -150
  28. package/src/Invoice/Invoice-digtal/_test/readOnly/index.tsx +55 -42
  29. package/src/Invoice/Invoice-digtal/_test/realEstateInfo/index.tsx +11 -11
  30. package/src/Invoice/Invoice-digtal/_test/stakeholder/index.tsx +12 -12
  31. package/src/Invoice/Invoice-digtal/_test/typeSelection/index.tsx +29 -29
  32. package/src/Invoice/Invoice-digtal/index.md +34 -34
  33. package/src/Invoice/InvoiceController/InvoiceControllerForm/index.ts +95 -95
  34. package/src/Invoice/InvoiceController/InvoiceControllerState/AutoComplete/index.ts +20 -20
  35. package/src/Invoice/InvoiceController/InvoiceControllerState/BuyerState/index.tsx +88 -88
  36. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/Drag/index.ts +15 -15
  37. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/EndowCode/index.tsx +104 -104
  38. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/IColumnsReplenish/index.ts +10 -10
  39. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/IGood/index.ts +78 -78
  40. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/ImportGoods/index.ts +81 -81
  41. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/LineAttributeType/index.ts +7 -7
  42. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/ProductComparison/index.ts +9 -9
  43. package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/index.ts +117 -117
  44. package/src/Invoice/InvoiceController/InvoiceControllerState/Stakeholder/index.ts +13 -13
  45. package/src/Invoice/InvoiceController/InvoiceControllerState/index.ts +65 -65
  46. package/src/Invoice/InvoiceController/fns/addGood.ts +11 -11
  47. package/src/Invoice/InvoiceController/fns/addGoodDiscount.ts +126 -126
  48. package/src/Invoice/InvoiceController/fns/addGoodDiscountV2.ts +86 -86
  49. package/src/Invoice/InvoiceController/fns/delGood.ts +41 -41
  50. package/src/Invoice/InvoiceController/fns/getGoodsSearch.ts +26 -26
  51. package/src/Invoice/InvoiceController/fns/importGoodsDrawer.ts +79 -79
  52. package/src/Invoice/InvoiceController/fns/itemBlur.ts +40 -40
  53. package/src/Invoice/InvoiceController/fns/mergeDetails.ts +201 -201
  54. package/src/Invoice/InvoiceController/fns/mergeDiscount.ts +35 -35
  55. package/src/Invoice/InvoiceController/fns/saveEditGood.ts +24 -24
  56. package/src/Invoice/InvoiceController/fns/setEditGood.ts +16 -16
  57. package/src/Invoice/InvoiceController/fns/setGoods.ts +10 -10
  58. package/src/Invoice/InvoiceController/fns/updateInvoiceNo.ts +8 -8
  59. package/src/Invoice/InvoiceController/index.ts +81 -81
  60. package/src/Invoice/_test/buyerNameSearch/index.tsx +42 -42
  61. package/src/Invoice/_test/deduction/index.tsx +935 -935
  62. package/src/Invoice/_test/draft/index.tsx +40 -40
  63. package/src/Invoice/_test/easiest/index.tsx +5 -5
  64. package/src/Invoice/_test/endowCode/index.tsx +1158 -1158
  65. package/src/Invoice/_test/goodsMenuExpand/index.tsx +32 -32
  66. package/src/Invoice/_test/importBuyer/index.tsx +74 -74
  67. package/src/Invoice/_test/importGoods/index.tsx +1197 -1197
  68. package/src/Invoice/_test/invoiceType/index.tsx +59 -59
  69. package/src/Invoice/_test/isInvoiceNo/index.tsx +12 -12
  70. package/src/Invoice/_test/replaceHead/index.tsx +22 -22
  71. package/src/Invoice/_test/retrieveData/index.tsx +22 -22
  72. package/src/Invoice/_test/seller/index.tsx +28 -28
  73. package/src/Invoice/_test/setDataSource/index.tsx +73 -73
  74. package/src/Invoice/_test/unit/index.tsx +19 -19
  75. package/src/Invoice/index.less +29 -29
  76. package/src/Invoice/index.md +53 -53
  77. package/src/Invoice/index.tsx +179 -179
  78. package/src/Invoice/tools/calculate/index.ts +132 -132
  79. package/src/Invoice/tools/coolingFn/index.ts +17 -17
  80. package/src/Invoice/tools/evaluate/index.ts +7 -7
  81. package/src/Invoice/tools/idGenerator/index.ts +2 -2
  82. package/src/Invoice/tools/itemName/index.ts +55 -55
  83. package/src/Invoice/tools/lazyFn/index.ts +19 -19
  84. package/src/Invoice/tools/mounting/index.ts +13 -13
  85. package/src/Invoice/tools/strringFn/index.ts +40 -40
  86. package/src/Invoice/tools/useToGenerateId/index.ts +8 -8
  87. package/src/Invoice/tools/utils/index.ts +1 -1
  88. package/src/Invoice/tools/utils/money/index.ts +20 -20
  89. package/src/Invoice/ui/default/AddComparisonDrawer/index.tsx +149 -149
  90. package/src/Invoice/ui/default/Buyer/index.less +219 -219
  91. package/src/Invoice/ui/default/Buyer/index.tsx +114 -114
  92. package/src/Invoice/ui/default/Buyer/ui/BuyerNameInput/index.tsx +166 -166
  93. package/src/Invoice/ui/default/Buyer/ui/ImportBuyerButton/index.tsx +21 -21
  94. package/src/Invoice/ui/default/EndowCodeDrawer/index.less +8 -8
  95. package/src/Invoice/ui/default/EndowCodeDrawer/index.tsx +550 -550
  96. package/src/Invoice/ui/default/GoodsList/hook/useColumns/autoFillFn/index.ts +632 -632
  97. package/src/Invoice/ui/default/GoodsList/hook/useColumns/index.tsx +691 -691
  98. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/Drag/index.less +20 -20
  99. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/Drag/index.tsx +205 -205
  100. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemCodeInput/index.less +18 -18
  101. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemCodeInput/index.tsx +47 -47
  102. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemNameInput/index.less +17 -17
  103. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemNameInput/index.tsx +88 -88
  104. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowEditButton/index.tsx +30 -30
  105. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/_useAddComparison/index.tsx +43 -43
  106. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useAddDiscount/index.tsx +118 -118
  107. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useDelItem/index.tsx +41 -41
  108. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useEndowCode/index.tsx +25 -25
  109. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/index.less +13 -13
  110. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/index.tsx +98 -98
  111. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowSaveButton/index.tsx +14 -14
  112. package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/TitleText/index.tsx +20 -20
  113. package/src/Invoice/ui/default/GoodsList/hook/useDeduction/index.tsx +24 -24
  114. package/src/Invoice/ui/default/GoodsList/hook/useOnRow/index.tsx +39 -39
  115. package/src/Invoice/ui/default/GoodsList/hook/useRowSelection/index.tsx +114 -114
  116. package/src/Invoice/ui/default/GoodsList/hook/useWindowClick/index.tsx +23 -23
  117. package/src/Invoice/ui/default/GoodsList/index.less +179 -179
  118. package/src/Invoice/ui/default/GoodsList/index.tsx +205 -205
  119. package/src/Invoice/ui/default/GoodsList/ui/AddRowButton/index.tsx +65 -65
  120. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/index.less +21 -21
  121. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/index.tsx +244 -244
  122. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useCommodityComparisonButton/index.tsx +75 -75
  123. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useDelRowButton/index.tsx +69 -69
  124. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useEndowCodeButton/index.tsx +65 -65
  125. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useMergeDetails/index.tsx +91 -91
  126. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useMergeDiscount/index.tsx +36 -36
  127. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useSalesDiscount/index.tsx +109 -109
  128. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useSalesGifts/index.tsx +94 -94
  129. package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/index.tsx +37 -37
  130. package/src/Invoice/ui/default/GoodsList/ui/DescribeSwitch/index.tsx +36 -36
  131. package/src/Invoice/ui/default/GoodsList/ui/Search/index.less +10 -10
  132. package/src/Invoice/ui/default/GoodsList/ui/Search/index.tsx +52 -52
  133. package/src/Invoice/ui/default/GoodsList/ui/Statistics/index.less +18 -18
  134. package/src/Invoice/ui/default/GoodsList/ui/Statistics/index.tsx +114 -114
  135. package/src/Invoice/ui/default/GoodsList/ui/TableRow/index.less +28 -28
  136. package/src/Invoice/ui/default/GoodsList/ui/TableRow/index.tsx +57 -57
  137. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual/index.less +38 -38
  138. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual/index.tsx +108 -108
  139. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual.o/index.less +44 -44
  140. package/src/Invoice/ui/default/GoodsList/ui/TableVirtual.o/index.tsx +96 -96
  141. package/src/Invoice/ui/default/GoodsList/ui/TaxIncludedSwitch/index.tsx +31 -31
  142. package/src/Invoice/ui/default/ImportBuyerDrawer/index.tsx +75 -75
  143. package/src/Invoice/ui/default/ImportGoodsDrawer/index.tsx +198 -198
  144. package/src/Invoice/ui/default/InvoiceHeader/index.less +68 -68
  145. package/src/Invoice/ui/default/InvoiceHeader/index.tsx +246 -246
  146. package/src/Invoice/ui/default/Seller/index.less +113 -113
  147. package/src/Invoice/ui/default/Seller/index.tsx +98 -98
  148. package/src/Invoice/ui/default/Sign/index.less +14 -14
  149. package/src/Invoice/ui/default/Sign/index.tsx +71 -71
  150. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/autoFillFn/index.ts +624 -624
  151. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/index.tsx +654 -654
  152. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/svg/plus.svg +11 -11
  153. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/Drag/index.less +20 -20
  154. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/Drag/index.tsx +205 -205
  155. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/ItemNameInput/index.less +9 -9
  156. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/ItemNameInput/index.tsx +84 -84
  157. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowEditButton/index.tsx +30 -30
  158. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/_useAddComparison/index.tsx +43 -43
  159. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/useAddDiscount/index.tsx +76 -76
  160. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/useDelItem/index.tsx +41 -41
  161. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/useEndowCode/index.tsx +34 -34
  162. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/index.less +13 -13
  163. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/index.tsx +98 -98
  164. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowSaveButton/index.tsx +14 -14
  165. package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/TitleText/index.tsx +20 -20
  166. package/src/Invoice/ui/digtal/GoodsList/hook/useOnRow/index.tsx +39 -39
  167. package/src/Invoice/ui/digtal/GoodsList/hook/useRowSelection/index.tsx +121 -121
  168. package/src/Invoice/ui/digtal/GoodsList/hook/useWindowClick/index.tsx +23 -23
  169. package/src/Invoice/ui/digtal/GoodsList/index.less +56 -56
  170. package/src/Invoice/ui/digtal/GoodsList/index.tsx +180 -180
  171. package/src/Invoice/ui/digtal/GoodsList/ui/AddRowButton/index.tsx +67 -65
  172. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/index.tsx +340 -340
  173. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/svg/add.svg +11 -11
  174. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useCommodityComparisonButton/index.tsx +75 -75
  175. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useDelRowButton/index.tsx +50 -50
  176. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useEmptyRefill/index.tsx +37 -37
  177. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useEndowCodeButton/index.tsx +82 -82
  178. package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useReselectInvoiceType/index.tsx +57 -57
  179. package/src/Invoice/ui/digtal/GoodsList/ui/DescribeSwitch/index.tsx +36 -36
  180. package/src/Invoice/ui/digtal/GoodsList/ui/Search/index.less +11 -11
  181. package/src/Invoice/ui/digtal/GoodsList/ui/Search/index.tsx +50 -50
  182. package/src/Invoice/ui/digtal/GoodsList/ui/Statistics/index.less +53 -53
  183. package/src/Invoice/ui/digtal/GoodsList/ui/Statistics/index.tsx +98 -98
  184. package/src/Invoice/ui/digtal/GoodsList/ui/Statistics/svg/fork.svg +11 -11
  185. package/src/Invoice/ui/digtal/GoodsList/ui/TableRow/index.less +28 -28
  186. package/src/Invoice/ui/digtal/GoodsList/ui/TableRow/index.tsx +53 -53
  187. package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual/index.less +38 -38
  188. package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual/index.tsx +108 -108
  189. package/src/Invoice/ui/digtal/GoodsList/ui/TaxIncludedSwitch/index.tsx +31 -31
  190. package/src/Invoice/ui/digtal/InvoiceHeader/index.less +57 -57
  191. package/src/Invoice/ui/digtal/InvoiceHeader/index.tsx +77 -77
  192. package/src/Invoice/ui/digtal/RealEstateInfo/index.less +14 -14
  193. package/src/Invoice/ui/digtal/RealEstateInfo/index.tsx +210 -137
  194. package/src/Invoice/ui/digtal/Sign/index.less +48 -48
  195. package/src/Invoice/ui/digtal/Sign/index.tsx +99 -99
  196. package/src/Invoice/ui/digtal/Stakeholder/index.less +99 -99
  197. package/src/Invoice/ui/digtal/Stakeholder/index.tsx +393 -393
  198. package/src/Invoice/ui/digtal/Stakeholder/svg/arrowDown.svg +2 -2
  199. package/src/Invoice/ui/digtal/Stakeholder/svg/arrowUp.svg +2 -2
  200. package/src/Invoice/ui/digtal/Stakeholder/svg/plus.svg +11 -11
  201. package/src/InvoiceTypeModal/_test/easiest/index.tsx +31 -31
  202. package/src/InvoiceTypeModal/index.less +7 -7
  203. package/src/InvoiceTypeModal/index.md +5 -5
  204. package/src/InvoiceTypeModal/index.tsx +153 -153
  205. package/src/TaxClassificationCodeModal/_test/easiest/index.tsx +177 -177
  206. package/src/TaxClassificationCodeModal/index.md +6 -6
  207. package/src/TaxClassificationCodeModal/index.tsx +74 -74
  208. package/src/index.ts +12 -12
  209. package/tsconfig.json +31 -31
  210. package/typings.d.ts +3 -3
  211. package/yarn.e.lock +14331 -14331
@@ -1,7 +1,7 @@
1
- import { create, all } from 'mathjs';
2
-
3
- const math = create(all, { number: 'BigNumber', precision: 20 }) as any;
4
-
5
- export default (expr: any, fractionDigits = 20) => {
6
- return parseFloat(math.evaluate(expr).toFixed(fractionDigits));
7
- };
1
+ import { create, all } from 'mathjs';
2
+
3
+ const math = create(all, { number: 'BigNumber', precision: 20 }) as any;
4
+
5
+ export default (expr: any, fractionDigits = 20) => {
6
+ return parseFloat(math.evaluate(expr).toFixed(fractionDigits));
7
+ };
@@ -1,3 +1,3 @@
1
-
2
- import { v4 as uuidv4 } from 'uuid';
1
+
2
+ import { v4 as uuidv4 } from 'uuid';
3
3
  export default () => uuidv4();
@@ -1,56 +1,56 @@
1
-
2
- export interface ISN {
3
-
4
- /** 简称 */
5
- shorthand?: string;
6
-
7
- /** 全称 */
8
- full: string
9
- }
10
-
11
- /** 拆分全称加简称 */
12
- export const getSN = (value?: string): ISN | undefined => {
13
- if (!value) return undefined;
14
- const arr = value.match(/\*[^*]+\*/);
15
- if (arr && arr[0]) {
16
- return { shorthand: arr[0].split('*')[1], full: value.replace(arr[0], '') };
17
- } else {
18
- return { shorthand: undefined, full: value };
19
- }
20
- };
21
-
22
- /** 组合全称加简称 */
23
- export const getItemName = (value: ISN) => {
24
- if (value.shorthand) {
25
- return `*${value.shorthand}*${value.full}`;
26
- } else {
27
- return value.full;
28
- }
29
- }
30
-
31
- /** 设置全称 */
32
- export const setFull = (name?:string, full?:string) => {
33
- const sn = getSN(name);
34
- if(!sn) return full;
35
- sn.full = full || '';
36
- return getItemName(sn);
37
- }
38
-
39
- /** 设置简称 */
40
- export const setShorthand = (name?:string, shorthand?:string) => {
41
- if(!name) return undefined
42
-
43
- const sn = getSN(name);
44
- if(!sn) return undefined;
45
- sn.shorthand = shorthand || '';
46
- return getItemName(sn);
47
- }
48
-
49
- /** 组合全称加简称 */
50
- export const getItemNameWithShorthand = (value: ISN) => {
51
- if (value.shorthand) {
52
- return `*${value.shorthand}*${value.full}`;
53
- } else {
54
- return value.full;
55
- }
1
+
2
+ export interface ISN {
3
+
4
+ /** 简称 */
5
+ shorthand?: string;
6
+
7
+ /** 全称 */
8
+ full: string
9
+ }
10
+
11
+ /** 拆分全称加简称 */
12
+ export const getSN = (value?: string): ISN | undefined => {
13
+ if (!value) return undefined;
14
+ const arr = value.match(/\*[^*]+\*/);
15
+ if (arr && arr[0]) {
16
+ return { shorthand: arr[0].split('*')[1], full: value.replace(arr[0], '') };
17
+ } else {
18
+ return { shorthand: undefined, full: value };
19
+ }
20
+ };
21
+
22
+ /** 组合全称加简称 */
23
+ export const getItemName = (value: ISN) => {
24
+ if (value.shorthand) {
25
+ return `*${value.shorthand}*${value.full}`;
26
+ } else {
27
+ return value.full;
28
+ }
29
+ }
30
+
31
+ /** 设置全称 */
32
+ export const setFull = (name?:string, full?:string) => {
33
+ const sn = getSN(name);
34
+ if(!sn) return full;
35
+ sn.full = full || '';
36
+ return getItemName(sn);
37
+ }
38
+
39
+ /** 设置简称 */
40
+ export const setShorthand = (name?:string, shorthand?:string) => {
41
+ if(!name) return undefined
42
+
43
+ const sn = getSN(name);
44
+ if(!sn) return undefined;
45
+ sn.shorthand = shorthand || '';
46
+ return getItemName(sn);
47
+ }
48
+
49
+ /** 组合全称加简称 */
50
+ export const getItemNameWithShorthand = (value: ISN) => {
51
+ if (value.shorthand) {
52
+ return `*${value.shorthand}*${value.full}`;
53
+ } else {
54
+ return value.full;
55
+ }
56
56
  }
@@ -1,20 +1,20 @@
1
- /** 延迟函数 */
2
- export default (fn: Function, delayed: number = 200) => {
3
- // let timer: any = 0;
4
- // return (...par: any[]) => {
5
- // if (timer === 0) {
6
- // timer = setTimeout(() => {
7
- // fn.apply(null, par);
8
- // timer = 0;
9
- // }, delayed);
10
- // }
11
- // }
12
- let timer: any;
13
- return (...par: any[]) => {
14
- if (timer) return;
15
- timer = setTimeout(() => {
16
- timer = undefined;
17
- fn.apply(null, par);
18
- }, delayed);
19
- }
1
+ /** 延迟函数 */
2
+ export default (fn: Function, delayed: number = 200) => {
3
+ // let timer: any = 0;
4
+ // return (...par: any[]) => {
5
+ // if (timer === 0) {
6
+ // timer = setTimeout(() => {
7
+ // fn.apply(null, par);
8
+ // timer = 0;
9
+ // }, delayed);
10
+ // }
11
+ // }
12
+ let timer: any;
13
+ return (...par: any[]) => {
14
+ if (timer) return;
15
+ timer = setTimeout(() => {
16
+ timer = undefined;
17
+ fn.apply(null, par);
18
+ }, delayed);
19
+ }
20
20
  }
@@ -1,14 +1,14 @@
1
-
2
- import * as ReactDOM from 'react-dom';
3
-
4
- /** 挂在组件到跟上 */
5
- export default function mounting(node: JSX.Element, containerId?: string) {
6
- ReactDOM.render(node, getContainer(containerId));
7
- }
8
-
9
- function getContainer(containerId: string = 'kts-component-invoice-operate-invoicing-authorization') {
10
- const div: HTMLElement = document.querySelector(`#${containerId}`) || document.createElement("div");
11
- div.id = containerId;
12
- document.body.appendChild(div);
13
- return div;
1
+
2
+ import * as ReactDOM from 'react-dom';
3
+
4
+ /** 挂在组件到跟上 */
5
+ export default function mounting(node: JSX.Element, containerId?: string) {
6
+ ReactDOM.render(node, getContainer(containerId));
7
+ }
8
+
9
+ function getContainer(containerId: string = 'kts-component-invoice-operate-invoicing-authorization') {
10
+ const div: HTMLElement = document.querySelector(`#${containerId}`) || document.createElement("div");
11
+ div.id = containerId;
12
+ document.body.appendChild(div);
13
+ return div;
14
14
  }
@@ -1,41 +1,41 @@
1
- /**
2
- * 判断一个字符串得字节长度
3
- * @param str
4
- * @returns
5
- */
6
- export function bytesLnegth(str: string) {
7
- var count = str.length;
8
- for (var i = 0; i < str.length; i++) {
9
- if (str.charCodeAt(i) > 255) {
10
- count++;
11
- }
12
- }
13
- return count;
14
- }
15
-
16
- /*
17
- * param str 要截取的字符串
18
- * param L 要截取的字节长度,注意是字节不是字符,一个汉字两个字节
19
- * return 截取后的字符串
20
- */
21
- export function cutStr(str: string, L: number) {
22
- var result = '',
23
- strlen = str.length, // 字符串长度
24
- chrlen = str.replace(/[^\x00-\xff]/g, '**').length; // 字节长度
25
-
26
- if (chrlen <= L) { return str; }
27
-
28
- for (var i = 0, j = 0; i < strlen; i++) {
29
- var chr = str.charAt(i);
30
- if (/[\x00-\xff]/.test(chr)) {
31
- j++; // ascii码为0-255,一个字符就是一个字节的长度
32
- } else {
33
- j += 2; // ascii码为0-255以外,一个字符就是两个字节的长度
34
- }
35
- if (j <= L) { // 当加上当前字符以后,如果总字节长度小于等于L,则将当前字符真实的+在result后
36
- result += chr;
37
- } else { // 反之则说明result已经是不拆分字符的情况下最接近L的值了,直接返回
38
- return result;
39
- }
40
- }
1
+ /**
2
+ * 判断一个字符串得字节长度
3
+ * @param str
4
+ * @returns
5
+ */
6
+ export function bytesLnegth(str: string) {
7
+ var count = str.length;
8
+ for (var i = 0; i < str.length; i++) {
9
+ if (str.charCodeAt(i) > 255) {
10
+ count++;
11
+ }
12
+ }
13
+ return count;
14
+ }
15
+
16
+ /*
17
+ * param str 要截取的字符串
18
+ * param L 要截取的字节长度,注意是字节不是字符,一个汉字两个字节
19
+ * return 截取后的字符串
20
+ */
21
+ export function cutStr(str: string, L: number) {
22
+ var result = '',
23
+ strlen = str.length, // 字符串长度
24
+ chrlen = str.replace(/[^\x00-\xff]/g, '**').length; // 字节长度
25
+
26
+ if (chrlen <= L) { return str; }
27
+
28
+ for (var i = 0, j = 0; i < strlen; i++) {
29
+ var chr = str.charAt(i);
30
+ if (/[\x00-\xff]/.test(chr)) {
31
+ j++; // ascii码为0-255,一个字符就是一个字节的长度
32
+ } else {
33
+ j += 2; // ascii码为0-255以外,一个字符就是两个字节的长度
34
+ }
35
+ if (j <= L) { // 当加上当前字符以后,如果总字节长度小于等于L,则将当前字符真实的+在result后
36
+ result += chr;
37
+ } else { // 反之则说明result已经是不拆分字符的情况下最接近L的值了,直接返回
38
+ return result;
39
+ }
40
+ }
41
41
  }
@@ -1,9 +1,9 @@
1
-
2
- import React from 'react'
3
- import InvoiceController from '../../InvoiceController'
4
-
5
- /** 更新 商品序号 */
6
- export default function useToGenerateId(controller: InvoiceController) {
7
- const goodsList = controller.useMemo(s => s.goodsListState.goodsList, []);
8
- React.useEffect(() => { goodsList.forEach((e, i) => { e.serialNo = i + 1 }) }, [goodsList])
1
+
2
+ import React from 'react'
3
+ import InvoiceController from '../../InvoiceController'
4
+
5
+ /** 更新 商品序号 */
6
+ export default function useToGenerateId(controller: InvoiceController) {
7
+ const goodsList = controller.useMemo(s => s.goodsListState.goodsList, []);
8
+ React.useEffect(() => { goodsList.forEach((e, i) => { e.serialNo = i + 1 }) }, [goodsList])
9
9
  }
@@ -1 +1 @@
1
- export * as Money from './money';
1
+ export * as Money from './money';
@@ -1,20 +1,20 @@
1
- const Nzh = require("nzh");
2
-
3
- const nzhcn = new Nzh({
4
- ch: '零壹贰叁肆伍陆柒捌玖'
5
- ,ch_u: '个拾佰仟万亿'
6
- ,ch_f: '负'
7
- ,ch_d: '点'
8
- ,m_t: '人民币'
9
- ,m_z: '整'
10
- ,m_u: '圆角分'
11
- })
12
-
13
- /** 数字转中文 */
14
- export const toStringChinese = (value: any) => {
15
- try {
16
- return nzhcn.toMoney(value, { outSymbol: false })
17
- } catch(e) {
18
- return ''
19
- }
20
- };
1
+ const Nzh = require("nzh");
2
+
3
+ const nzhcn = new Nzh({
4
+ ch: '零壹贰叁肆伍陆柒捌玖'
5
+ ,ch_u: '个拾佰仟万亿'
6
+ ,ch_f: '负'
7
+ ,ch_d: '点'
8
+ ,m_t: '人民币'
9
+ ,m_z: '整'
10
+ ,m_u: '圆角分'
11
+ })
12
+
13
+ /** 数字转中文 */
14
+ export const toStringChinese = (value: any) => {
15
+ try {
16
+ return nzhcn.toMoney(value, { outSymbol: false })
17
+ } catch(e) {
18
+ return ''
19
+ }
20
+ };
@@ -1,150 +1,150 @@
1
-
2
- import React from "react";
3
- import { Row, Col, Input, Button, message } from "kts-components-antd-x3";
4
- import { Form, Drawer } from "kts-xui";
5
- import { Invoice, IGood } from "../../../..";
6
- import { getSN } from "../../../tools/itemName";
7
- import { LineAttributeType } from "../../../InvoiceController";
8
-
9
- export default function AddComparisonDrawer() {
10
-
11
- const [form] = Form.useForm();
12
-
13
- /** 控制器 */
14
- const controller = Invoice.useInvoiceController();
15
-
16
- /** 正在 添加商品对照 的货物索引 */
17
- const addComparisonIndex = controller.useMemo(s => s.goodsListState?.addComparisonIndex, []);
18
-
19
- /** 货物字典 */
20
- const goodsMap = controller.useMemo(s => s.goodsListState.goodsMap, []);
21
-
22
- /** 正在 对照 的货物 */
23
- const good = React.useMemo(() => addComparisonIndex ? goodsMap.get(addComparisonIndex) : undefined, [addComparisonIndex]);
24
-
25
- /** 关闭对照 */
26
- const onClose = React.useCallback(controller.pipeline<any>(async s => { s.goodsListState.addComparisonIndex = undefined }), [controller]);
27
-
28
- /** 提交数据 */
29
- const onSubmit = React.useCallback(() => {
30
- controller.run(async s => {
31
- if (!good) return
32
-
33
- try {
34
- const values = await form.validateFields()
35
- const shorthand = s.goodsListState.isMyShow ? getSN(good.itemNameSelf)?.shorthand : getSN(good.itemName)?.shorthand;
36
- const setGood = (good: IGood) => {
37
- good.itemCode = values.itemCode;
38
- good.itemCodeSelf = values.itemCodeSelf;
39
- good.itemName = shorthand ? `*${shorthand}*${values.itemName}` : values.itemName;
40
- good.itemNameSelf = shorthand ? `*${shorthand}*${values.itemNameSelf}` : values.itemNameSelf;
41
-
42
- if (good.lineAttribute !== LineAttributeType.折扣行) {
43
- good.itemModelName = values.itemModelName;
44
- good.itemModelNameSelf = values.itemModelNameSelf;
45
- }
46
- }
47
-
48
- setGood(good);
49
-
50
- if (good.lineAttribute !== LineAttributeType.正常) {
51
- const c = good.lineAttribute === LineAttributeType.折扣行 ? -1 : good.lineAttribute === LineAttributeType.被折扣行 ? 1 : 0
52
- const g = s.goodsListState.goodsList[s.goodsListState.goodsList.indexOf(good) + c]
53
- setGood(g);
54
- }
55
-
56
- s.goodsListState.addComparisonIndex = undefined;
57
- s.goodsListState.goodsList = [...s.goodsListState.goodsList];
58
-
59
- message.success('商品映射成功');
60
- } catch (error) {
61
-
62
- }
63
- })
64
- }, [form, good])
65
-
66
- React.useEffect(() => {
67
- form.resetFields();
68
- if (good) {
69
- form.setFieldsValue({
70
- ...good,
71
- itemName: getSN(good.itemName)?.full,
72
- itemNameSelf: getSN(good.itemNameSelf)?.full,
73
- })
74
- }
75
- }, [good])
76
-
77
- return (
78
- <Drawer
79
- width={500}
80
- onClose={onClose}
81
- placement="right"
82
- title="商品映射"
83
- visible={!!good}
84
- footer={
85
- <div style={{ display: 'flex', justifyContent: 'flex-end', gap: 10 }} >
86
- <Button type="primary" onClick={onSubmit} >提交</Button>
87
- <Button onClick={onClose} >取消</Button>
88
- </div>
89
- }
90
- >
91
- {
92
- !!good &&
93
- <Form layout="vertical" style={{ flex: 1 }} form={form} >
94
- <Row gutter={[8, 8]} >
95
- {/* <Col span={12}>
96
- <Form.Item
97
- name="itemCodeSelf"
98
- label="我方商品编码"
99
- >
100
- <Input />
101
- </Form.Item>
102
- </Col>
103
- <Col span={12} >
104
- <Form.Item
105
- name="itemCode"
106
- label="对方商品编码"
107
- >
108
- <Input />
109
- </Form.Item>
110
- </Col> */}
111
- <Col span={12} >
112
- <Form.Item
113
- name="itemNameSelf"
114
- label="我方商品名称"
115
- >
116
- <Input />
117
- </Form.Item>
118
- </Col>
119
- <Col span={12} >
120
- <Form.Item
121
- name="itemName"
122
- label="对方商品名称"
123
- >
124
- <Input />
125
- </Form.Item>
126
- </Col>
127
- <Col span={12} >
128
- <Form.Item name='itemModelNameSelf' label="我方规格型号">
129
- <Input />
130
- </Form.Item>
131
- </Col>
132
- <Col span={12} >
133
- <Form.Item name="itemModelName" label="对方规格型号">
134
- <Input />
135
- </Form.Item>
136
- </Col>
137
- </Row>
138
- </Form>
139
- }
140
- </Drawer>
141
- )
142
- }
143
-
144
- // function validateFields(form: WrappedFormUtils<any>) {
145
- // return new Promise<{ err: any, values: any }>(resolve => {
146
- // form.validateFields((err, values) => {
147
- // resolve({ err, values })
148
- // })
149
- // })
1
+
2
+ import React from "react";
3
+ import { Row, Col, Input, Button, message } from "kts-components-antd-x3";
4
+ import { Form, Drawer } from "kts-xui";
5
+ import { Invoice, IGood } from "../../../..";
6
+ import { getSN } from "../../../tools/itemName";
7
+ import { LineAttributeType } from "../../../InvoiceController";
8
+
9
+ export default function AddComparisonDrawer() {
10
+
11
+ const [form] = Form.useForm();
12
+
13
+ /** 控制器 */
14
+ const controller = Invoice.useInvoiceController();
15
+
16
+ /** 正在 添加商品对照 的货物索引 */
17
+ const addComparisonIndex = controller.useMemo(s => s.goodsListState?.addComparisonIndex, []);
18
+
19
+ /** 货物字典 */
20
+ const goodsMap = controller.useMemo(s => s.goodsListState.goodsMap, []);
21
+
22
+ /** 正在 对照 的货物 */
23
+ const good = React.useMemo(() => addComparisonIndex ? goodsMap.get(addComparisonIndex) : undefined, [addComparisonIndex]);
24
+
25
+ /** 关闭对照 */
26
+ const onClose = React.useCallback(controller.pipeline<any>(async s => { s.goodsListState.addComparisonIndex = undefined }), [controller]);
27
+
28
+ /** 提交数据 */
29
+ const onSubmit = React.useCallback(() => {
30
+ controller.run(async s => {
31
+ if (!good) return
32
+
33
+ try {
34
+ const values = await form.validateFields()
35
+ const shorthand = s.goodsListState.isMyShow ? getSN(good.itemNameSelf)?.shorthand : getSN(good.itemName)?.shorthand;
36
+ const setGood = (good: IGood) => {
37
+ good.itemCode = values.itemCode;
38
+ good.itemCodeSelf = values.itemCodeSelf;
39
+ good.itemName = shorthand ? `*${shorthand}*${values.itemName}` : values.itemName;
40
+ good.itemNameSelf = shorthand ? `*${shorthand}*${values.itemNameSelf}` : values.itemNameSelf;
41
+
42
+ if (good.lineAttribute !== LineAttributeType.折扣行) {
43
+ good.itemModelName = values.itemModelName;
44
+ good.itemModelNameSelf = values.itemModelNameSelf;
45
+ }
46
+ }
47
+
48
+ setGood(good);
49
+
50
+ if (good.lineAttribute !== LineAttributeType.正常) {
51
+ const c = good.lineAttribute === LineAttributeType.折扣行 ? -1 : good.lineAttribute === LineAttributeType.被折扣行 ? 1 : 0
52
+ const g = s.goodsListState.goodsList[s.goodsListState.goodsList.indexOf(good) + c]
53
+ setGood(g);
54
+ }
55
+
56
+ s.goodsListState.addComparisonIndex = undefined;
57
+ s.goodsListState.goodsList = [...s.goodsListState.goodsList];
58
+
59
+ message.success('商品映射成功');
60
+ } catch (error) {
61
+
62
+ }
63
+ })
64
+ }, [form, good])
65
+
66
+ React.useEffect(() => {
67
+ form.resetFields();
68
+ if (good) {
69
+ form.setFieldsValue({
70
+ ...good,
71
+ itemName: getSN(good.itemName)?.full,
72
+ itemNameSelf: getSN(good.itemNameSelf)?.full,
73
+ })
74
+ }
75
+ }, [good])
76
+
77
+ return (
78
+ <Drawer
79
+ width={500}
80
+ onClose={onClose}
81
+ placement="right"
82
+ title="商品映射"
83
+ visible={!!good}
84
+ footer={
85
+ <div style={{ display: 'flex', justifyContent: 'flex-end', gap: 10 }} >
86
+ <Button type="primary" onClick={onSubmit} >提交</Button>
87
+ <Button onClick={onClose} >取消</Button>
88
+ </div>
89
+ }
90
+ >
91
+ {
92
+ !!good &&
93
+ <Form layout="vertical" style={{ flex: 1 }} form={form} >
94
+ <Row gutter={[8, 8]} >
95
+ {/* <Col span={12}>
96
+ <Form.Item
97
+ name="itemCodeSelf"
98
+ label="我方商品编码"
99
+ >
100
+ <Input />
101
+ </Form.Item>
102
+ </Col>
103
+ <Col span={12} >
104
+ <Form.Item
105
+ name="itemCode"
106
+ label="对方商品编码"
107
+ >
108
+ <Input />
109
+ </Form.Item>
110
+ </Col> */}
111
+ <Col span={12} >
112
+ <Form.Item
113
+ name="itemNameSelf"
114
+ label="我方商品名称"
115
+ >
116
+ <Input />
117
+ </Form.Item>
118
+ </Col>
119
+ <Col span={12} >
120
+ <Form.Item
121
+ name="itemName"
122
+ label="对方商品名称"
123
+ >
124
+ <Input />
125
+ </Form.Item>
126
+ </Col>
127
+ <Col span={12} >
128
+ <Form.Item name='itemModelNameSelf' label="我方规格型号">
129
+ <Input />
130
+ </Form.Item>
131
+ </Col>
132
+ <Col span={12} >
133
+ <Form.Item name="itemModelName" label="对方规格型号">
134
+ <Input />
135
+ </Form.Item>
136
+ </Col>
137
+ </Row>
138
+ </Form>
139
+ }
140
+ </Drawer>
141
+ )
142
+ }
143
+
144
+ // function validateFields(form: WrappedFormUtils<any>) {
145
+ // return new Promise<{ err: any, values: any }>(resolve => {
146
+ // form.validateFields((err, values) => {
147
+ // resolve({ err, values })
148
+ // })
149
+ // })
150
150
  // }