kts-component-invoice-operate 3.2.213 → 3.2.215
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.
- package/.dumi/theme/builtins/API.tsx +66 -66
- package/.editorconfig +16 -16
- package/.fatherrc.ts +4 -4
- package/.prettierignore +7 -7
- package/.prettierrc +11 -11
- package/.umirc.ts +8 -8
- package/README.md +9 -9
- package/dist/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/ImportGoods/index.d.ts +2 -0
- package/dist/index.esm.js +6 -6
- package/dist/index.js +6 -6
- package/docs/index.md +5 -5
- package/docs-dist/404.html +33 -33
- package/docs-dist/index.html +33 -33
- package/docs-dist/static/arrowDown.a1cbf0d8.svg +2 -2
- package/docs-dist/static/arrowUp.4c482054.svg +2 -2
- package/docs-dist/static/fork.5431267d.svg +11 -11
- package/docs-dist/static/plus.44013ce3.svg +11 -11
- package/docs-dist/static/plus.4fd1af30.svg +11 -11
- package/docs-dist/umi.css +18 -18
- package/index.html +12 -12
- package/package.json +62 -62
- package/src/Invoice/Invoice-digtal/_test/architecture/index.tsx +21 -21
- package/src/Invoice/Invoice-digtal/_test/disabled/index.tsx +40 -40
- package/src/Invoice/Invoice-digtal/_test/easiest/index.tsx +176 -174
- package/src/Invoice/Invoice-digtal/_test/freight/index.tsx +14574 -14574
- package/src/Invoice/Invoice-digtal/_test/header/index.tsx +84 -84
- package/src/Invoice/Invoice-digtal/_test/importGoods/index.tsx +868 -868
- package/src/Invoice/Invoice-digtal/_test/importStakeholder/index.tsx +18 -18
- package/src/Invoice/Invoice-digtal/_test/lineCredit/index.tsx +19 -19
- package/src/Invoice/Invoice-digtal/_test/prefab/index.tsx +150 -150
- package/src/Invoice/Invoice-digtal/_test/readOnly/index.tsx +55 -55
- package/src/Invoice/Invoice-digtal/_test/realEstateInfo/index.tsx +21 -21
- package/src/Invoice/Invoice-digtal/_test/stakeholder/index.tsx +12 -12
- package/src/Invoice/Invoice-digtal/_test/typeSelection/index.tsx +29 -29
- package/src/Invoice/Invoice-digtal/index.md +41 -41
- package/src/Invoice/InvoiceController/InvoiceControllerForm/index.ts +105 -105
- package/src/Invoice/InvoiceController/InvoiceControllerState/AutoComplete/index.ts +26 -26
- package/src/Invoice/InvoiceController/InvoiceControllerState/BuyerState/index.tsx +88 -88
- package/src/Invoice/InvoiceController/InvoiceControllerState/FreightListState/IColumnsReplenish/index.ts +10 -10
- package/src/Invoice/InvoiceController/InvoiceControllerState/FreightListState/IGood/index.ts +33 -33
- package/src/Invoice/InvoiceController/InvoiceControllerState/FreightListState/ImportGoods/index.ts +81 -81
- package/src/Invoice/InvoiceController/InvoiceControllerState/FreightListState/index.ts +39 -39
- package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/Drag/index.ts +15 -15
- package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/EndowCode/index.tsx +104 -104
- package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/IColumnsReplenish/index.ts +10 -10
- package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/IGood/index.ts +87 -87
- package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/ImportGoods/index.ts +84 -81
- package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/LineAttributeType/index.ts +7 -7
- package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/ProductComparison/index.ts +9 -9
- package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/index.ts +131 -131
- package/src/Invoice/InvoiceController/InvoiceControllerState/Stakeholder/index.ts +13 -13
- package/src/Invoice/InvoiceController/InvoiceControllerState/index.ts +71 -71
- package/src/Invoice/InvoiceController/fns/addFreight.ts +11 -11
- package/src/Invoice/InvoiceController/fns/addGood.ts +11 -11
- package/src/Invoice/InvoiceController/fns/addGoodDiscount.ts +126 -126
- package/src/Invoice/InvoiceController/fns/addGoodDiscountV2.ts +86 -86
- package/src/Invoice/InvoiceController/fns/delFreight.ts +38 -38
- package/src/Invoice/InvoiceController/fns/delGood.ts +41 -41
- package/src/Invoice/InvoiceController/fns/getGoodsSearch.ts +26 -26
- package/src/Invoice/InvoiceController/fns/importGoodsDrawer.ts +79 -79
- package/src/Invoice/InvoiceController/fns/itemBlur.ts +40 -40
- package/src/Invoice/InvoiceController/fns/mergeDetails.ts +201 -201
- package/src/Invoice/InvoiceController/fns/mergeDiscount.ts +35 -35
- package/src/Invoice/InvoiceController/fns/saveEditFreight.ts +24 -24
- package/src/Invoice/InvoiceController/fns/saveEditGood.ts +24 -24
- package/src/Invoice/InvoiceController/fns/setEditFreight.ts +16 -16
- package/src/Invoice/InvoiceController/fns/setEditGood.ts +16 -16
- package/src/Invoice/InvoiceController/fns/setFreight.ts +10 -10
- package/src/Invoice/InvoiceController/fns/setGoods.ts +10 -10
- package/src/Invoice/InvoiceController/fns/updateInvoiceNo.ts +8 -8
- package/src/Invoice/InvoiceController/index.ts +106 -106
- package/src/Invoice/_test/buyerNameSearch/index.tsx +42 -42
- package/src/Invoice/_test/children/index.tsx +214 -214
- package/src/Invoice/_test/deduction/index.tsx +935 -935
- package/src/Invoice/_test/draft/index.tsx +40 -40
- package/src/Invoice/_test/easiest/index.tsx +5 -5
- package/src/Invoice/_test/endowCode/index.tsx +1158 -1158
- package/src/Invoice/_test/goodsMenuExpand/index.tsx +32 -32
- package/src/Invoice/_test/importBuyer/index.tsx +74 -74
- package/src/Invoice/_test/importGoods/index.tsx +1197 -1197
- package/src/Invoice/_test/invoiceType/index.tsx +59 -59
- package/src/Invoice/_test/isInvoiceNo/index.tsx +12 -12
- package/src/Invoice/_test/replaceHead/index.tsx +22 -22
- package/src/Invoice/_test/retrieveData/index.tsx +22 -22
- package/src/Invoice/_test/seller/index.tsx +28 -28
- package/src/Invoice/_test/setDataSource/index.tsx +73 -73
- package/src/Invoice/_test/unit/index.tsx +19 -19
- package/src/Invoice/index.less +31 -31
- package/src/Invoice/index.md +56 -56
- package/src/Invoice/index.tsx +197 -197
- package/src/Invoice/tools/calculate/index.ts +144 -144
- package/src/Invoice/tools/coolingFn/index.ts +17 -17
- package/src/Invoice/tools/evaluate/index.ts +7 -7
- package/src/Invoice/tools/idGenerator/index.ts +2 -2
- package/src/Invoice/tools/itemName/index.ts +55 -55
- package/src/Invoice/tools/lazyFn/index.ts +19 -19
- package/src/Invoice/tools/mounting/index.ts +13 -13
- package/src/Invoice/tools/strringFn/index.ts +40 -40
- package/src/Invoice/tools/useToGenerateId/index.ts +10 -10
- package/src/Invoice/tools/utils/index.ts +1 -1
- package/src/Invoice/tools/utils/money/index.ts +20 -20
- package/src/Invoice/ui/default/AddComparisonDrawer/index.tsx +149 -149
- package/src/Invoice/ui/default/Buyer/index.less +219 -219
- package/src/Invoice/ui/default/Buyer/index.tsx +114 -114
- package/src/Invoice/ui/default/Buyer/ui/BuyerNameInput/index.tsx +166 -166
- package/src/Invoice/ui/default/Buyer/ui/ImportBuyerButton/index.tsx +21 -21
- package/src/Invoice/ui/default/EndowCodeDrawer/index.less +8 -8
- package/src/Invoice/ui/default/EndowCodeDrawer/index.tsx +612 -612
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/autoFillFn/index.ts +647 -647
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/index.tsx +712 -712
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/Drag/index.less +20 -20
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/Drag/index.tsx +205 -205
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/Expand/index.tsx +57 -57
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemCodeInput/index.less +18 -18
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemCodeInput/index.tsx +49 -49
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemNameInput/index.less +17 -17
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/ItemNameInput/index.tsx +91 -91
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowEditButton/index.tsx +30 -30
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/_useAddComparison/index.tsx +43 -43
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useAddDiscount/index.tsx +118 -118
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useDelItem/dist/index.js +32 -32
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useDelItem/index.tsx +41 -41
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useEndowCode/index.tsx +25 -25
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/index.less +13 -13
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/index.tsx +99 -99
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowSaveButton/index.tsx +14 -14
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/TitleText/index.tsx +20 -20
- package/src/Invoice/ui/default/GoodsList/hook/useDeduction/index.tsx +24 -24
- package/src/Invoice/ui/default/GoodsList/hook/useOnRow/index.tsx +52 -52
- package/src/Invoice/ui/default/GoodsList/hook/useRowSelection/index.tsx +120 -120
- package/src/Invoice/ui/default/GoodsList/hook/useWindowClick/index.tsx +23 -23
- package/src/Invoice/ui/default/GoodsList/index.less +185 -185
- package/src/Invoice/ui/default/GoodsList/index.tsx +205 -205
- package/src/Invoice/ui/default/GoodsList/ui/AddRowButton/index.tsx +65 -65
- package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/index.less +21 -21
- package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/index.tsx +244 -244
- package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useCommodityComparisonButton/index.tsx +75 -75
- package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useDelRowButton/index.tsx +69 -69
- package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useEndowCodeButton/index.tsx +65 -65
- package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useMergeDetails/index.tsx +91 -91
- package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useMergeDiscount/index.tsx +36 -36
- package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useSalesDiscount/index.tsx +109 -109
- package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/hooks/useSalesGifts/index.tsx +94 -94
- package/src/Invoice/ui/default/GoodsList/ui/BulkMenu/index.tsx +37 -37
- package/src/Invoice/ui/default/GoodsList/ui/DescribeSwitch/index.tsx +36 -36
- package/src/Invoice/ui/default/GoodsList/ui/Search/index.less +10 -10
- package/src/Invoice/ui/default/GoodsList/ui/Search/index.tsx +52 -52
- package/src/Invoice/ui/default/GoodsList/ui/Statistics/index.less +18 -18
- package/src/Invoice/ui/default/GoodsList/ui/Statistics/index.tsx +114 -114
- package/src/Invoice/ui/default/GoodsList/ui/TableRow/index.less +40 -40
- package/src/Invoice/ui/default/GoodsList/ui/TableRow/index.tsx +71 -71
- package/src/Invoice/ui/default/GoodsList/ui/TableVirtual/index.less +38 -38
- package/src/Invoice/ui/default/GoodsList/ui/TableVirtual/index.tsx +130 -130
- package/src/Invoice/ui/default/GoodsList/ui/TableVirtual.o/index.less +44 -44
- package/src/Invoice/ui/default/GoodsList/ui/TableVirtual.o/index.tsx +96 -96
- package/src/Invoice/ui/default/GoodsList/ui/TaxIncludedSwitch/index.tsx +31 -31
- package/src/Invoice/ui/default/ImportBuyerDrawer/index.tsx +75 -75
- package/src/Invoice/ui/default/ImportGoodsDrawer/index.tsx +198 -198
- package/src/Invoice/ui/default/InvoiceHeader/index.less +68 -68
- package/src/Invoice/ui/default/InvoiceHeader/index.tsx +246 -246
- package/src/Invoice/ui/default/Seller/index.less +113 -113
- package/src/Invoice/ui/default/Seller/index.tsx +98 -98
- package/src/Invoice/ui/default/Sign/index.less +14 -14
- package/src/Invoice/ui/default/Sign/index.tsx +71 -71
- package/src/Invoice/ui/digtal/Architecture/index.less +18 -18
- package/src/Invoice/ui/digtal/Architecture/index.tsx +177 -177
- package/src/Invoice/ui/digtal/FreightList/hook/useColumns/dist/index.js +616 -616
- package/src/Invoice/ui/digtal/FreightList/hook/useColumns/index.tsx +246 -246
- package/src/Invoice/ui/digtal/FreightList/hook/useColumns/ui/TitleText/index.tsx +20 -20
- package/src/Invoice/ui/digtal/FreightList/hook/useOnRow/index.tsx +37 -37
- package/src/Invoice/ui/digtal/FreightList/hook/useRowSelection/index.tsx +119 -119
- package/src/Invoice/ui/digtal/FreightList/hook/useWindowClick/index.tsx +23 -23
- package/src/Invoice/ui/digtal/FreightList/index.less +72 -72
- package/src/Invoice/ui/digtal/FreightList/index.tsx +129 -129
- package/src/Invoice/ui/digtal/FreightList/ui/AddRowButton/index.tsx +74 -74
- package/src/Invoice/ui/digtal/FreightList/ui/BulkMenu/hooks/useDelRowButton/index.tsx +50 -50
- package/src/Invoice/ui/digtal/FreightList/ui/BulkMenu/hooks/useEmptyRefill/index.tsx +36 -36
- package/src/Invoice/ui/digtal/FreightList/ui/TableRow/index.less +28 -28
- package/src/Invoice/ui/digtal/FreightList/ui/TableRow/index.tsx +20 -20
- package/src/Invoice/ui/digtal/FreightList/ui/TableVirtual/index.less +38 -38
- package/src/Invoice/ui/digtal/FreightList/ui/TableVirtual/index.tsx +108 -108
- package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/autoFillFn/index.ts +683 -683
- package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/dist/index.js +616 -616
- package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/index.tsx +703 -704
- package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/svg/plus.svg +11 -11
- package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/Drag/index.less +20 -20
- package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/Drag/index.tsx +205 -205
- package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/ItemNameInput/index.less +9 -9
- package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/ItemNameInput/index.tsx +87 -87
- package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowEditButton/index.tsx +30 -30
- package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/_useAddComparison/index.tsx +43 -43
- package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/useAddDiscount/index.tsx +76 -76
- package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/useDelItem/index.tsx +41 -41
- package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/hook/useEndowCode/index.tsx +34 -34
- package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/index.less +13 -13
- package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowMenu/index.tsx +98 -98
- package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/RowSaveButton/index.tsx +14 -14
- package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/ui/TitleText/index.tsx +20 -20
- package/src/Invoice/ui/digtal/GoodsList/hook/useOnRow/index.tsx +51 -51
- package/src/Invoice/ui/digtal/GoodsList/hook/useRowSelection/index.tsx +121 -121
- package/src/Invoice/ui/digtal/GoodsList/hook/useWindowClick/index.tsx +23 -23
- package/src/Invoice/ui/digtal/GoodsList/index.less +56 -56
- package/src/Invoice/ui/digtal/GoodsList/index.tsx +179 -179
- package/src/Invoice/ui/digtal/GoodsList/ui/AddRowButton/index.tsx +77 -77
- package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/index.tsx +340 -340
- package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useAddDiscountRowButton/svg/add.svg +11 -11
- package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useCommodityComparisonButton/index.tsx +75 -75
- package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useDelRowButton/index.tsx +50 -50
- package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useEmptyRefill/index.tsx +37 -37
- package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useEndowCodeButton/index.tsx +82 -82
- package/src/Invoice/ui/digtal/GoodsList/ui/BulkMenu/hooks/useReselectInvoiceType/index.tsx +57 -57
- package/src/Invoice/ui/digtal/GoodsList/ui/DescribeSwitch/index.tsx +36 -36
- package/src/Invoice/ui/digtal/GoodsList/ui/Search/index.less +11 -11
- package/src/Invoice/ui/digtal/GoodsList/ui/Search/index.tsx +60 -60
- package/src/Invoice/ui/digtal/GoodsList/ui/Statistics/index.less +53 -53
- package/src/Invoice/ui/digtal/GoodsList/ui/Statistics/index.tsx +98 -98
- package/src/Invoice/ui/digtal/GoodsList/ui/Statistics/svg/fork.svg +11 -11
- package/src/Invoice/ui/digtal/GoodsList/ui/TableRow/index.less +28 -28
- package/src/Invoice/ui/digtal/GoodsList/ui/TableRow/index.tsx +52 -52
- package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual/index.less +38 -38
- package/src/Invoice/ui/digtal/GoodsList/ui/TableVirtual/index.tsx +108 -108
- package/src/Invoice/ui/digtal/GoodsList/ui/TaxIncludedSwitch/index.tsx +31 -31
- package/src/Invoice/ui/digtal/InvoiceHeader/index.less +57 -57
- package/src/Invoice/ui/digtal/InvoiceHeader/index.tsx +77 -77
- package/src/Invoice/ui/digtal/RealEstateInfo/index.less +14 -14
- package/src/Invoice/ui/digtal/RealEstateInfo/index.tsx +192 -192
- package/src/Invoice/ui/digtal/Sign/index.less +48 -48
- package/src/Invoice/ui/digtal/Sign/index.tsx +99 -99
- package/src/Invoice/ui/digtal/StakeFarmerholder/index.less +99 -99
- package/src/Invoice/ui/digtal/StakeFarmerholder/index.tsx +477 -477
- package/src/Invoice/ui/digtal/StakeFarmerholder/svg/arrowDown.svg +2 -2
- package/src/Invoice/ui/digtal/StakeFarmerholder/svg/arrowUp.svg +2 -2
- package/src/Invoice/ui/digtal/StakeFarmerholder/svg/plus.svg +11 -11
- package/src/Invoice/ui/digtal/Stakeholder/index.less +99 -99
- package/src/Invoice/ui/digtal/Stakeholder/index.tsx +435 -435
- package/src/Invoice/ui/digtal/Stakeholder/svg/arrowDown.svg +2 -2
- package/src/Invoice/ui/digtal/Stakeholder/svg/arrowUp.svg +2 -2
- package/src/Invoice/ui/digtal/Stakeholder/svg/plus.svg +11 -11
- package/src/InvoiceTypeModal/_test/easiest/index.tsx +31 -31
- package/src/InvoiceTypeModal/dist/index.js +92 -92
- package/src/InvoiceTypeModal/index.less +7 -7
- package/src/InvoiceTypeModal/index.md +5 -5
- package/src/InvoiceTypeModal/index.tsx +161 -161
- package/src/TaxClassificationCodeModal/_test/easiest/index.tsx +184 -184
- package/src/TaxClassificationCodeModal/index.less +17 -17
- package/src/TaxClassificationCodeModal/index.md +6 -6
- package/src/TaxClassificationCodeModal/index.tsx +152 -152
- package/src/index.ts +13 -13
- package/tsconfig.json +31 -31
- package/typings.d.ts +3 -3
|
@@ -1,145 +1,145 @@
|
|
|
1
|
-
|
|
2
|
-
import { chain, bignumber, format } from 'mathjs';
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
/** 格式化 保留2位小数 */
|
|
6
|
-
export const format2 = (value: number | string) => {
|
|
7
|
-
if (value === Infinity) return '';
|
|
8
|
-
if (`${value}` === 'NaN') return '';
|
|
9
|
-
if (typeof value === 'string') value = parseFloat(value);
|
|
10
|
-
return parseFloat(value.toFixed(2));
|
|
11
|
-
};
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
/** 格式化 保留15位数字 */
|
|
15
|
-
export const format15 = (value: number | string, defaultFractionDigits: number = 8) => {
|
|
16
|
-
if (value === Infinity) return '';
|
|
17
|
-
if (`${value}` === 'NaN') return '';
|
|
18
|
-
if (typeof value === 'string') value = parseFloat(value);
|
|
19
|
-
|
|
20
|
-
const fractionDigits = 15 - `${value || 0}`.indexOf('.');
|
|
21
|
-
return nonScientificNotation(value, fractionDigits > defaultFractionDigits ? defaultFractionDigits : fractionDigits) as number | undefined | '';
|
|
22
|
-
};
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
/**
|
|
26
|
-
* 金额(含税) = 数量 * 单价(含税)
|
|
27
|
-
* @param quantity 数量
|
|
28
|
-
* @param priceIncludeTax 单价(含税)
|
|
29
|
-
* @returns 金额(含税)
|
|
30
|
-
*/
|
|
31
|
-
export function countAmountIncludeTax(quantity?: number | string, priceIncludeTax?: number | string, calculatingDigits?: number): number | undefined {
|
|
32
|
-
if (!quantity && quantity !== 0) return undefined;
|
|
33
|
-
if (!priceIncludeTax && priceIncludeTax !== 0) return undefined;
|
|
34
|
-
|
|
35
|
-
quantity = format15(quantity, calculatingDigits);
|
|
36
|
-
priceIncludeTax = format15(priceIncludeTax, calculatingDigits);
|
|
37
|
-
|
|
38
|
-
return parseFloat(chain(bignumber(priceIncludeTax)).multiply(bignumber(quantity)).done().toNumber().toFixed(2));
|
|
39
|
-
// return parseFloat(evaluate(`${priceIncludeTax} * ${quantity}`).toFixed(2));
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
/**
|
|
43
|
-
* 不含税金额 = 含税金额-税额
|
|
44
|
-
* @param amountIncludeTax 含税金额
|
|
45
|
-
* @param taxAmount 税额
|
|
46
|
-
* @returns 不含税金额
|
|
47
|
-
*/
|
|
48
|
-
export function countAmountExcludeTax(amountIncludeTax: string | number, taxAmount: number): number | undefined {
|
|
49
|
-
if (!amountIncludeTax && amountIncludeTax !== 0) return undefined;
|
|
50
|
-
if (!taxAmount && taxAmount !== 0) return undefined;
|
|
51
|
-
|
|
52
|
-
return chain(bignumber(amountIncludeTax)).subtract(bignumber(taxAmount)).done().toNumber();
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
/**
|
|
56
|
-
* 税额 = (含税金额-扣除额)/(1+税率)*税率
|
|
57
|
-
* @param amountIncludeTax 含税金额
|
|
58
|
-
* @param deduction 扣除额
|
|
59
|
-
* @param taxRate 税率
|
|
60
|
-
* @returns 税额
|
|
61
|
-
*/
|
|
62
|
-
export function countTaxAmount(amountIncludeTax: string | number, deduction: number, taxRate: number): number | undefined {
|
|
63
|
-
|
|
64
|
-
if (!amountIncludeTax && amountIncludeTax !== 0) return undefined;
|
|
65
|
-
if (!deduction && deduction !== 0) return undefined;
|
|
66
|
-
if (!taxRate && taxRate !== 0) return undefined;
|
|
67
|
-
|
|
68
|
-
const taxRateBu = chain(bignumber(taxRate)).divide(bignumber(100)).done();
|
|
69
|
-
|
|
70
|
-
return parseFloat(chain(bignumber(amountIncludeTax))
|
|
71
|
-
.subtract(bignumber(deduction))
|
|
72
|
-
.divide(chain(bignumber(1)).add(taxRateBu).done())
|
|
73
|
-
.multiply(taxRateBu)
|
|
74
|
-
.done()
|
|
75
|
-
.toNumber()
|
|
76
|
-
.toFixed(2))
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
/**
|
|
80
|
-
* 单价 = 金额/数量
|
|
81
|
-
* @param amount 金额
|
|
82
|
-
* @param quantity 数量
|
|
83
|
-
* @returns 单价
|
|
84
|
-
*/
|
|
85
|
-
export function countPrice(amount: string | number, quantity: string | number, calculatingDigits?: number): number | undefined | '' {
|
|
86
|
-
if (!amount && amount !== 0) return undefined;
|
|
87
|
-
if (!quantity && quantity !== 0) return undefined;
|
|
88
|
-
|
|
89
|
-
return format15(chain(bignumber(amount)).divide(bignumber(quantity))
|
|
90
|
-
.done()
|
|
91
|
-
.toNumber(), calculatingDigits)
|
|
92
|
-
}
|
|
93
|
-
// /**
|
|
94
|
-
// * 单价 = 金额/数量 不做小数限制
|
|
95
|
-
// * @param amount 金额
|
|
96
|
-
// * @param quantity 数量
|
|
97
|
-
// * @returns 单价
|
|
98
|
-
// */
|
|
99
|
-
// export function countPriceNoLimit(amount: string | number, quantity: string | number, calculatingDigits?: number): number | undefined | '' {
|
|
100
|
-
// if (!amount && amount !== 0) return undefined;
|
|
101
|
-
// if (!quantity && quantity !== 0) return undefined;
|
|
102
|
-
// return chain(bignumber(amount)).divide(bignumber(quantity))
|
|
103
|
-
// .done()
|
|
104
|
-
// .toString().substr(0,25)
|
|
105
|
-
// }
|
|
106
|
-
|
|
107
|
-
/**
|
|
108
|
-
* 数量 = 金额/单价
|
|
109
|
-
* @param amount 金额
|
|
110
|
-
* @param price 单价
|
|
111
|
-
* @returns 数量
|
|
112
|
-
*/
|
|
113
|
-
export function countQuantity(amount: string | number, price: string | number, calculatingDigits?: number): number | undefined | '' {
|
|
114
|
-
if (!amount && amount !== 0) return undefined;
|
|
115
|
-
if (!price && price !== 0) return undefined;
|
|
116
|
-
|
|
117
|
-
return format15(chain(bignumber(amount)).divide(bignumber(price))
|
|
118
|
-
.done()
|
|
119
|
-
.toNumber(), calculatingDigits)
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
/**
|
|
123
|
-
* 将数值转化为非科学计数法的字符串,忽略小数多余的0
|
|
124
|
-
* 无法转化的返回空字符串
|
|
125
|
-
* @param value 数值或字符串
|
|
126
|
-
* @param precision 精度
|
|
127
|
-
* @returns 字符串
|
|
128
|
-
*/
|
|
129
|
-
export function nonScientificNotation (value: number | string | undefined, precision?: number ): string {
|
|
130
|
-
try {
|
|
131
|
-
if (!value && value !== 0) {
|
|
132
|
-
return ''
|
|
133
|
-
} else {
|
|
134
|
-
// 先按照精度fixed
|
|
135
|
-
if (precision) {
|
|
136
|
-
value = format(bignumber(value), {notation: 'fixed', precision});
|
|
137
|
-
}
|
|
138
|
-
// 去掉小数位多余的0
|
|
139
|
-
return format(bignumber(value), {notation: 'fixed'})
|
|
140
|
-
}
|
|
141
|
-
} catch (e){
|
|
142
|
-
console.error(e);
|
|
143
|
-
return ''
|
|
144
|
-
}
|
|
1
|
+
|
|
2
|
+
import { chain, bignumber, format } from 'mathjs';
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
/** 格式化 保留2位小数 */
|
|
6
|
+
export const format2 = (value: number | string) => {
|
|
7
|
+
if (value === Infinity) return '';
|
|
8
|
+
if (`${value}` === 'NaN') return '';
|
|
9
|
+
if (typeof value === 'string') value = parseFloat(value);
|
|
10
|
+
return parseFloat(value.toFixed(2));
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
/** 格式化 保留15位数字 */
|
|
15
|
+
export const format15 = (value: number | string, defaultFractionDigits: number = 8) => {
|
|
16
|
+
if (value === Infinity) return '';
|
|
17
|
+
if (`${value}` === 'NaN') return '';
|
|
18
|
+
if (typeof value === 'string') value = parseFloat(value);
|
|
19
|
+
|
|
20
|
+
const fractionDigits = 15 - `${value || 0}`.indexOf('.');
|
|
21
|
+
return nonScientificNotation(value, fractionDigits > defaultFractionDigits ? defaultFractionDigits : fractionDigits) as number | undefined | '';
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* 金额(含税) = 数量 * 单价(含税)
|
|
27
|
+
* @param quantity 数量
|
|
28
|
+
* @param priceIncludeTax 单价(含税)
|
|
29
|
+
* @returns 金额(含税)
|
|
30
|
+
*/
|
|
31
|
+
export function countAmountIncludeTax(quantity?: number | string, priceIncludeTax?: number | string, calculatingDigits?: number): number | undefined {
|
|
32
|
+
if (!quantity && quantity !== 0) return undefined;
|
|
33
|
+
if (!priceIncludeTax && priceIncludeTax !== 0) return undefined;
|
|
34
|
+
|
|
35
|
+
quantity = format15(quantity, calculatingDigits);
|
|
36
|
+
priceIncludeTax = format15(priceIncludeTax, calculatingDigits);
|
|
37
|
+
|
|
38
|
+
return parseFloat(chain(bignumber(priceIncludeTax)).multiply(bignumber(quantity)).done().toNumber().toFixed(2));
|
|
39
|
+
// return parseFloat(evaluate(`${priceIncludeTax} * ${quantity}`).toFixed(2));
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* 不含税金额 = 含税金额-税额
|
|
44
|
+
* @param amountIncludeTax 含税金额
|
|
45
|
+
* @param taxAmount 税额
|
|
46
|
+
* @returns 不含税金额
|
|
47
|
+
*/
|
|
48
|
+
export function countAmountExcludeTax(amountIncludeTax: string | number, taxAmount: number): number | undefined {
|
|
49
|
+
if (!amountIncludeTax && amountIncludeTax !== 0) return undefined;
|
|
50
|
+
if (!taxAmount && taxAmount !== 0) return undefined;
|
|
51
|
+
|
|
52
|
+
return chain(bignumber(amountIncludeTax)).subtract(bignumber(taxAmount)).done().toNumber();
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* 税额 = (含税金额-扣除额)/(1+税率)*税率
|
|
57
|
+
* @param amountIncludeTax 含税金额
|
|
58
|
+
* @param deduction 扣除额
|
|
59
|
+
* @param taxRate 税率
|
|
60
|
+
* @returns 税额
|
|
61
|
+
*/
|
|
62
|
+
export function countTaxAmount(amountIncludeTax: string | number, deduction: number, taxRate: number): number | undefined {
|
|
63
|
+
|
|
64
|
+
if (!amountIncludeTax && amountIncludeTax !== 0) return undefined;
|
|
65
|
+
if (!deduction && deduction !== 0) return undefined;
|
|
66
|
+
if (!taxRate && taxRate !== 0) return undefined;
|
|
67
|
+
|
|
68
|
+
const taxRateBu = chain(bignumber(taxRate)).divide(bignumber(100)).done();
|
|
69
|
+
|
|
70
|
+
return parseFloat(chain(bignumber(amountIncludeTax))
|
|
71
|
+
.subtract(bignumber(deduction))
|
|
72
|
+
.divide(chain(bignumber(1)).add(taxRateBu).done())
|
|
73
|
+
.multiply(taxRateBu)
|
|
74
|
+
.done()
|
|
75
|
+
.toNumber()
|
|
76
|
+
.toFixed(2))
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
/**
|
|
80
|
+
* 单价 = 金额/数量
|
|
81
|
+
* @param amount 金额
|
|
82
|
+
* @param quantity 数量
|
|
83
|
+
* @returns 单价
|
|
84
|
+
*/
|
|
85
|
+
export function countPrice(amount: string | number, quantity: string | number, calculatingDigits?: number): number | undefined | '' {
|
|
86
|
+
if (!amount && amount !== 0) return undefined;
|
|
87
|
+
if (!quantity && quantity !== 0) return undefined;
|
|
88
|
+
|
|
89
|
+
return format15(chain(bignumber(amount)).divide(bignumber(quantity))
|
|
90
|
+
.done()
|
|
91
|
+
.toNumber(), calculatingDigits)
|
|
92
|
+
}
|
|
93
|
+
// /**
|
|
94
|
+
// * 单价 = 金额/数量 不做小数限制
|
|
95
|
+
// * @param amount 金额
|
|
96
|
+
// * @param quantity 数量
|
|
97
|
+
// * @returns 单价
|
|
98
|
+
// */
|
|
99
|
+
// export function countPriceNoLimit(amount: string | number, quantity: string | number, calculatingDigits?: number): number | undefined | '' {
|
|
100
|
+
// if (!amount && amount !== 0) return undefined;
|
|
101
|
+
// if (!quantity && quantity !== 0) return undefined;
|
|
102
|
+
// return chain(bignumber(amount)).divide(bignumber(quantity))
|
|
103
|
+
// .done()
|
|
104
|
+
// .toString().substr(0,25)
|
|
105
|
+
// }
|
|
106
|
+
|
|
107
|
+
/**
|
|
108
|
+
* 数量 = 金额/单价
|
|
109
|
+
* @param amount 金额
|
|
110
|
+
* @param price 单价
|
|
111
|
+
* @returns 数量
|
|
112
|
+
*/
|
|
113
|
+
export function countQuantity(amount: string | number, price: string | number, calculatingDigits?: number): number | undefined | '' {
|
|
114
|
+
if (!amount && amount !== 0) return undefined;
|
|
115
|
+
if (!price && price !== 0) return undefined;
|
|
116
|
+
|
|
117
|
+
return format15(chain(bignumber(amount)).divide(bignumber(price))
|
|
118
|
+
.done()
|
|
119
|
+
.toNumber(), calculatingDigits)
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
/**
|
|
123
|
+
* 将数值转化为非科学计数法的字符串,忽略小数多余的0
|
|
124
|
+
* 无法转化的返回空字符串
|
|
125
|
+
* @param value 数值或字符串
|
|
126
|
+
* @param precision 精度
|
|
127
|
+
* @returns 字符串
|
|
128
|
+
*/
|
|
129
|
+
export function nonScientificNotation (value: number | string | undefined, precision?: number ): string {
|
|
130
|
+
try {
|
|
131
|
+
if (!value && value !== 0) {
|
|
132
|
+
return ''
|
|
133
|
+
} else {
|
|
134
|
+
// 先按照精度fixed
|
|
135
|
+
if (precision) {
|
|
136
|
+
value = format(bignumber(value), {notation: 'fixed', precision});
|
|
137
|
+
}
|
|
138
|
+
// 去掉小数位多余的0
|
|
139
|
+
return format(bignumber(value), {notation: 'fixed'})
|
|
140
|
+
}
|
|
141
|
+
} catch (e){
|
|
142
|
+
console.error(e);
|
|
143
|
+
return ''
|
|
144
|
+
}
|
|
145
145
|
}
|
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
const keys: { [key: string]: any } = {}
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* 有冷却时间的函数
|
|
7
|
-
* @param key 方法key
|
|
8
|
-
* @param delayed 冷却时间
|
|
9
|
-
* @param fn 方法
|
|
10
|
-
*/
|
|
11
|
-
export default (key: string = 'default', delayed: number = 200, fn: Function) => {
|
|
12
|
-
if (keys[key]) {
|
|
13
|
-
return;
|
|
14
|
-
} else {
|
|
15
|
-
fn();
|
|
16
|
-
keys[key] = setTimeout(() => { delete keys[key] }, delayed);
|
|
17
|
-
}
|
|
1
|
+
|
|
2
|
+
|
|
3
|
+
const keys: { [key: string]: any } = {}
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* 有冷却时间的函数
|
|
7
|
+
* @param key 方法key
|
|
8
|
+
* @param delayed 冷却时间
|
|
9
|
+
* @param fn 方法
|
|
10
|
+
*/
|
|
11
|
+
export default (key: string = 'default', delayed: number = 200, fn: Function) => {
|
|
12
|
+
if (keys[key]) {
|
|
13
|
+
return;
|
|
14
|
+
} else {
|
|
15
|
+
fn();
|
|
16
|
+
keys[key] = setTimeout(() => { delete keys[key] }, delayed);
|
|
17
|
+
}
|
|
18
18
|
}
|
|
@@ -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,11 +1,11 @@
|
|
|
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
|
-
const freightList = controller.useMemo(s => s.freightListState.goodsList, []);
|
|
10
|
-
React.useEffect(() => { freightList.forEach((e, i) => { e.sortNumber = i + 1 }) }, [freightList])
|
|
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
|
+
const freightList = controller.useMemo(s => s.freightListState.goodsList, []);
|
|
10
|
+
React.useEffect(() => { freightList.forEach((e, i) => { e.sortNumber = i + 1 }) }, [freightList])
|
|
11
11
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export * as Money from './money';
|
|
1
|
+
export * as Money from './money';
|