kts-component-invoice-operate 3.2.192 → 3.2.194
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/ui/digtal/StakeFarmerholder/index.d.ts +3 -0
- package/dist/index.esm.js +829 -774
- package/dist/index.js +829 -774
- package/docs/index.md +5 -5
- 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/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 +29 -29
- 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 +81 -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 +190 -190
- package/src/Invoice/tools/calculate/index.ts +132 -132
- 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 +607 -607
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/autoFillFn/index.ts +647 -647
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/index.tsx +711 -711
- 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/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 +64 -64
- 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 +673 -673
- package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/index.tsx +673 -673
- 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 +67 -67
- 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 +50 -50
- 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 -436
- 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 +433 -433
- 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/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
package/src/Invoice/index.tsx
CHANGED
|
@@ -1,190 +1,190 @@
|
|
|
1
|
-
|
|
2
|
-
import './index.less';
|
|
3
|
-
import React from 'react';
|
|
4
|
-
import InvoiceController from './InvoiceController';
|
|
5
|
-
import useToGenerateId from './tools/useToGenerateId';
|
|
6
|
-
import idGenerator from './tools/idGenerator';
|
|
7
|
-
import * as calculator from './tools/calculate';
|
|
8
|
-
import * as utils from './tools/utils';
|
|
9
|
-
|
|
10
|
-
import InvoiceHeader from './ui/default/InvoiceHeader';
|
|
11
|
-
import GoodsList from './ui/default/GoodsList';
|
|
12
|
-
import Seller from './ui/default/Seller';
|
|
13
|
-
import Buyer from './ui/default/Buyer';
|
|
14
|
-
import Sign from './ui/default/Sign';
|
|
15
|
-
|
|
16
|
-
import InvoiceHeaderDigtal from './ui/digtal/InvoiceHeader';
|
|
17
|
-
import Stakeholder from './ui/digtal/Stakeholder';
|
|
18
|
-
import StakeFarmerholder from './ui/digtal/StakeFarmerholder';
|
|
19
|
-
import SignDigtal from './ui/digtal/Sign';
|
|
20
|
-
import GoodsListDigtal from './ui/digtal/GoodsList';
|
|
21
|
-
import RealEstateInfo from './ui/digtal/RealEstateInfo';
|
|
22
|
-
import Architecture from './ui/digtal/Architecture';
|
|
23
|
-
import FreightList from './ui/digtal/FreightList';
|
|
24
|
-
|
|
25
|
-
import ImportBuyerDrawer from './ui/default/ImportBuyerDrawer';
|
|
26
|
-
import ImportGoodsDrawer from './ui/default/ImportGoodsDrawer';
|
|
27
|
-
import EndowCodeDrawer from './ui/default/EndowCodeDrawer';
|
|
28
|
-
import AddComparisonDrawer from './ui/default/AddComparisonDrawer';
|
|
29
|
-
|
|
30
|
-
/** 发票组件的上下文 */
|
|
31
|
-
export const InvoiceContext = React.createContext<InvoiceController>(
|
|
32
|
-
undefined as any,
|
|
33
|
-
);
|
|
34
|
-
|
|
35
|
-
export interface IInvoiceProps {
|
|
36
|
-
/** 发票数据控制器 */
|
|
37
|
-
controller?: InvoiceController;
|
|
38
|
-
|
|
39
|
-
/** 发票头UI */
|
|
40
|
-
invoiceHeader?: React.ReactNode;
|
|
41
|
-
|
|
42
|
-
/** 货物列表UI */
|
|
43
|
-
goodsList?: React.ReactNode;
|
|
44
|
-
|
|
45
|
-
/** 购买方UI (invoiceType为default时生效) */
|
|
46
|
-
buyer?: React.ReactNode;
|
|
47
|
-
|
|
48
|
-
/** 销售方UI (invoiceType为default时生效)*/
|
|
49
|
-
seller?: React.ReactNode;
|
|
50
|
-
|
|
51
|
-
/** 干系人(购买方&销售方) (invoiceType为digtal时生效) */
|
|
52
|
-
stakeholder?: React.ReactNode;
|
|
53
|
-
|
|
54
|
-
/** 落款UI */
|
|
55
|
-
sign?: React.ReactNode;
|
|
56
|
-
|
|
57
|
-
/** 特殊信息 */
|
|
58
|
-
specialInfor?: React.ReactNode;
|
|
59
|
-
|
|
60
|
-
/** 底部扩展UI */
|
|
61
|
-
footExpand?: React.ReactNode;
|
|
62
|
-
|
|
63
|
-
/** 发票种类: default-默认,digtal-数电 */
|
|
64
|
-
invoiceType?: 'default' | 'digtal';
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
export default class Invoice extends React.PureComponent<IInvoiceProps> {
|
|
68
|
-
/** 控制器 */
|
|
69
|
-
static readonly InvoiceController = InvoiceController;
|
|
70
|
-
|
|
71
|
-
/** 发票头(默认) */
|
|
72
|
-
static readonly InvoiceHeader = InvoiceHeader;
|
|
73
|
-
|
|
74
|
-
/** 货物列表(默认) */
|
|
75
|
-
static readonly GoodsList = GoodsList;
|
|
76
|
-
|
|
77
|
-
/** 销售方(默认) */
|
|
78
|
-
static readonly Seller = Seller;
|
|
79
|
-
|
|
80
|
-
/** 落款(默认) */
|
|
81
|
-
static readonly Sign = Sign;
|
|
82
|
-
|
|
83
|
-
/** 购买方(默认) */
|
|
84
|
-
static readonly Buyer = Buyer;
|
|
85
|
-
|
|
86
|
-
/** 发票头(数电) */
|
|
87
|
-
static readonly InvoiceHeaderDigtal = InvoiceHeaderDigtal;
|
|
88
|
-
|
|
89
|
-
/** 干系人(数电) */
|
|
90
|
-
static readonly Stakeholder = Stakeholder;
|
|
91
|
-
|
|
92
|
-
/** 农产品干系人(数电) */
|
|
93
|
-
static readonly StakeFarmerholder = StakeFarmerholder;
|
|
94
|
-
|
|
95
|
-
/** 落款(数电) */
|
|
96
|
-
static readonly SignDigtal = SignDigtal;
|
|
97
|
-
|
|
98
|
-
/** 特殊信息-不动产经营租赁服务(数电) */
|
|
99
|
-
static readonly RealEstateInfo = RealEstateInfo;
|
|
100
|
-
|
|
101
|
-
/** 特殊信息-建筑服务(数电) */
|
|
102
|
-
static readonly Architecture = Architecture;
|
|
103
|
-
|
|
104
|
-
static readonly FreightList = FreightList;
|
|
105
|
-
|
|
106
|
-
/** 货物列表(数电) */
|
|
107
|
-
static readonly GoodsListDigtal = GoodsListDigtal;
|
|
108
|
-
|
|
109
|
-
/** 货物索引生成器 */
|
|
110
|
-
static idGenerator = idGenerator;
|
|
111
|
-
|
|
112
|
-
/** 金额计算方法 */
|
|
113
|
-
static calculator = calculator;
|
|
114
|
-
|
|
115
|
-
/** 工具方法 */
|
|
116
|
-
static utils = utils;
|
|
117
|
-
|
|
118
|
-
/** 获取控制器钩子 */
|
|
119
|
-
static useInvoiceController = () => { return React.useContext(InvoiceContext) };
|
|
120
|
-
|
|
121
|
-
render() {
|
|
122
|
-
if (this.props.invoiceType === 'digtal') {
|
|
123
|
-
return <Digtal {...this.props}></Digtal>;
|
|
124
|
-
} else {
|
|
125
|
-
return <Main {...this.props}></Main>;
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
/** 默认 */
|
|
131
|
-
const Main = (props: IInvoiceProps) => {
|
|
132
|
-
|
|
133
|
-
const controller = React.useMemo(() => props.controller || new InvoiceController(), [props.controller]);
|
|
134
|
-
|
|
135
|
-
const [key, setKey] = React.useState(0);
|
|
136
|
-
|
|
137
|
-
useToGenerateId(controller);
|
|
138
|
-
|
|
139
|
-
React.useEffect(() => { setKey(key + 1) }, [controller]);
|
|
140
|
-
|
|
141
|
-
return (
|
|
142
|
-
<InvoiceContext.Provider key={key} value={controller}>
|
|
143
|
-
|
|
144
|
-
<div className="kts-invoice-operate" ref={controller.pipeline<HTMLDivElement | null>(async (s, e) => { s.rootElement = e })} >
|
|
145
|
-
{props.invoiceHeader || <InvoiceHeader /> /** 发票头 */}
|
|
146
|
-
{props.buyer || <Buyer /> /** 购买方 */}
|
|
147
|
-
{props.goodsList || <GoodsList /> /** 货物列表 */}
|
|
148
|
-
{props.seller || <Seller /> /** 销售方 */}
|
|
149
|
-
{props.sign || <Sign /> /** 落款 */}
|
|
150
|
-
{props.footExpand}
|
|
151
|
-
</div>
|
|
152
|
-
|
|
153
|
-
<ImportBuyerDrawer />{/* 导入购买方的抽屉 */}
|
|
154
|
-
<ImportGoodsDrawer />{/* 导入货品的抽屉 */}
|
|
155
|
-
<EndowCodeDrawer />{/* 给货品赋码的抽屉 */}
|
|
156
|
-
<AddComparisonDrawer />{/* 添加商品对照的抽屉 */}
|
|
157
|
-
</InvoiceContext.Provider>
|
|
158
|
-
);
|
|
159
|
-
};
|
|
160
|
-
|
|
161
|
-
/** 数电 */
|
|
162
|
-
const Digtal = (props: IInvoiceProps) => {
|
|
163
|
-
|
|
164
|
-
const controller = React.useMemo(() => props.controller || new InvoiceController(), [props.controller]);
|
|
165
|
-
|
|
166
|
-
const [key, setKey] = React.useState(0);
|
|
167
|
-
|
|
168
|
-
useToGenerateId(controller);
|
|
169
|
-
|
|
170
|
-
React.useEffect(() => { setKey(key + 1) }, [controller]);
|
|
171
|
-
|
|
172
|
-
return (
|
|
173
|
-
<InvoiceContext.Provider key={key} value={controller}>
|
|
174
|
-
<div className="kts-invoice-operate-digtal" ref={controller.pipeline<HTMLDivElement | null>(async (s, e) => { s.rootElement = e })} >
|
|
175
|
-
{props.invoiceHeader || <InvoiceHeaderDigtal /> /** 发票头 */}
|
|
176
|
-
<div className='kts-invoice-operate-digtal-cont' >
|
|
177
|
-
{props.stakeholder || <Stakeholder /> /** 干系人 */}
|
|
178
|
-
{props.goodsList || <GoodsListDigtal /> /** 货物列表 */}
|
|
179
|
-
</div>
|
|
180
|
-
{props.specialInfor /** 特殊信息 */}
|
|
181
|
-
{props.sign || <SignDigtal /> /** 落款 */}
|
|
182
|
-
</div>
|
|
183
|
-
|
|
184
|
-
<ImportGoodsDrawer />{ /** 导入货品的抽屉 */}
|
|
185
|
-
<EndowCodeDrawer />{ /** 给货品赋码的抽屉 */}
|
|
186
|
-
</InvoiceContext.Provider>
|
|
187
|
-
)
|
|
188
|
-
}
|
|
189
|
-
|
|
190
|
-
|
|
1
|
+
|
|
2
|
+
import './index.less';
|
|
3
|
+
import React from 'react';
|
|
4
|
+
import InvoiceController from './InvoiceController';
|
|
5
|
+
import useToGenerateId from './tools/useToGenerateId';
|
|
6
|
+
import idGenerator from './tools/idGenerator';
|
|
7
|
+
import * as calculator from './tools/calculate';
|
|
8
|
+
import * as utils from './tools/utils';
|
|
9
|
+
|
|
10
|
+
import InvoiceHeader from './ui/default/InvoiceHeader';
|
|
11
|
+
import GoodsList from './ui/default/GoodsList';
|
|
12
|
+
import Seller from './ui/default/Seller';
|
|
13
|
+
import Buyer from './ui/default/Buyer';
|
|
14
|
+
import Sign from './ui/default/Sign';
|
|
15
|
+
|
|
16
|
+
import InvoiceHeaderDigtal from './ui/digtal/InvoiceHeader';
|
|
17
|
+
import Stakeholder from './ui/digtal/Stakeholder';
|
|
18
|
+
import StakeFarmerholder from './ui/digtal/StakeFarmerholder';
|
|
19
|
+
import SignDigtal from './ui/digtal/Sign';
|
|
20
|
+
import GoodsListDigtal from './ui/digtal/GoodsList';
|
|
21
|
+
import RealEstateInfo from './ui/digtal/RealEstateInfo';
|
|
22
|
+
import Architecture from './ui/digtal/Architecture';
|
|
23
|
+
import FreightList from './ui/digtal/FreightList';
|
|
24
|
+
|
|
25
|
+
import ImportBuyerDrawer from './ui/default/ImportBuyerDrawer';
|
|
26
|
+
import ImportGoodsDrawer from './ui/default/ImportGoodsDrawer';
|
|
27
|
+
import EndowCodeDrawer from './ui/default/EndowCodeDrawer';
|
|
28
|
+
import AddComparisonDrawer from './ui/default/AddComparisonDrawer';
|
|
29
|
+
|
|
30
|
+
/** 发票组件的上下文 */
|
|
31
|
+
export const InvoiceContext = React.createContext<InvoiceController>(
|
|
32
|
+
undefined as any,
|
|
33
|
+
);
|
|
34
|
+
|
|
35
|
+
export interface IInvoiceProps {
|
|
36
|
+
/** 发票数据控制器 */
|
|
37
|
+
controller?: InvoiceController;
|
|
38
|
+
|
|
39
|
+
/** 发票头UI */
|
|
40
|
+
invoiceHeader?: React.ReactNode;
|
|
41
|
+
|
|
42
|
+
/** 货物列表UI */
|
|
43
|
+
goodsList?: React.ReactNode;
|
|
44
|
+
|
|
45
|
+
/** 购买方UI (invoiceType为default时生效) */
|
|
46
|
+
buyer?: React.ReactNode;
|
|
47
|
+
|
|
48
|
+
/** 销售方UI (invoiceType为default时生效)*/
|
|
49
|
+
seller?: React.ReactNode;
|
|
50
|
+
|
|
51
|
+
/** 干系人(购买方&销售方) (invoiceType为digtal时生效) */
|
|
52
|
+
stakeholder?: React.ReactNode;
|
|
53
|
+
|
|
54
|
+
/** 落款UI */
|
|
55
|
+
sign?: React.ReactNode;
|
|
56
|
+
|
|
57
|
+
/** 特殊信息 */
|
|
58
|
+
specialInfor?: React.ReactNode;
|
|
59
|
+
|
|
60
|
+
/** 底部扩展UI */
|
|
61
|
+
footExpand?: React.ReactNode;
|
|
62
|
+
|
|
63
|
+
/** 发票种类: default-默认,digtal-数电 */
|
|
64
|
+
invoiceType?: 'default' | 'digtal';
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
export default class Invoice extends React.PureComponent<IInvoiceProps> {
|
|
68
|
+
/** 控制器 */
|
|
69
|
+
static readonly InvoiceController = InvoiceController;
|
|
70
|
+
|
|
71
|
+
/** 发票头(默认) */
|
|
72
|
+
static readonly InvoiceHeader = InvoiceHeader;
|
|
73
|
+
|
|
74
|
+
/** 货物列表(默认) */
|
|
75
|
+
static readonly GoodsList = GoodsList;
|
|
76
|
+
|
|
77
|
+
/** 销售方(默认) */
|
|
78
|
+
static readonly Seller = Seller;
|
|
79
|
+
|
|
80
|
+
/** 落款(默认) */
|
|
81
|
+
static readonly Sign = Sign;
|
|
82
|
+
|
|
83
|
+
/** 购买方(默认) */
|
|
84
|
+
static readonly Buyer = Buyer;
|
|
85
|
+
|
|
86
|
+
/** 发票头(数电) */
|
|
87
|
+
static readonly InvoiceHeaderDigtal = InvoiceHeaderDigtal;
|
|
88
|
+
|
|
89
|
+
/** 干系人(数电) */
|
|
90
|
+
static readonly Stakeholder = Stakeholder;
|
|
91
|
+
|
|
92
|
+
/** 农产品干系人(数电) */
|
|
93
|
+
static readonly StakeFarmerholder = StakeFarmerholder;
|
|
94
|
+
|
|
95
|
+
/** 落款(数电) */
|
|
96
|
+
static readonly SignDigtal = SignDigtal;
|
|
97
|
+
|
|
98
|
+
/** 特殊信息-不动产经营租赁服务(数电) */
|
|
99
|
+
static readonly RealEstateInfo = RealEstateInfo;
|
|
100
|
+
|
|
101
|
+
/** 特殊信息-建筑服务(数电) */
|
|
102
|
+
static readonly Architecture = Architecture;
|
|
103
|
+
|
|
104
|
+
static readonly FreightList = FreightList;
|
|
105
|
+
|
|
106
|
+
/** 货物列表(数电) */
|
|
107
|
+
static readonly GoodsListDigtal = GoodsListDigtal;
|
|
108
|
+
|
|
109
|
+
/** 货物索引生成器 */
|
|
110
|
+
static idGenerator = idGenerator;
|
|
111
|
+
|
|
112
|
+
/** 金额计算方法 */
|
|
113
|
+
static calculator = calculator;
|
|
114
|
+
|
|
115
|
+
/** 工具方法 */
|
|
116
|
+
static utils = utils;
|
|
117
|
+
|
|
118
|
+
/** 获取控制器钩子 */
|
|
119
|
+
static useInvoiceController = () => { return React.useContext(InvoiceContext) };
|
|
120
|
+
|
|
121
|
+
render() {
|
|
122
|
+
if (this.props.invoiceType === 'digtal') {
|
|
123
|
+
return <Digtal {...this.props}></Digtal>;
|
|
124
|
+
} else {
|
|
125
|
+
return <Main {...this.props}></Main>;
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
/** 默认 */
|
|
131
|
+
const Main = (props: IInvoiceProps) => {
|
|
132
|
+
|
|
133
|
+
const controller = React.useMemo(() => props.controller || new InvoiceController(), [props.controller]);
|
|
134
|
+
|
|
135
|
+
const [key, setKey] = React.useState(0);
|
|
136
|
+
|
|
137
|
+
useToGenerateId(controller);
|
|
138
|
+
|
|
139
|
+
React.useEffect(() => { setKey(key + 1) }, [controller]);
|
|
140
|
+
|
|
141
|
+
return (
|
|
142
|
+
<InvoiceContext.Provider key={key} value={controller}>
|
|
143
|
+
|
|
144
|
+
<div className="kts-invoice-operate" ref={controller.pipeline<HTMLDivElement | null>(async (s, e) => { s.rootElement = e })} >
|
|
145
|
+
{props.invoiceHeader || <InvoiceHeader /> /** 发票头 */}
|
|
146
|
+
{props.buyer || <Buyer /> /** 购买方 */}
|
|
147
|
+
{props.goodsList || <GoodsList /> /** 货物列表 */}
|
|
148
|
+
{props.seller || <Seller /> /** 销售方 */}
|
|
149
|
+
{props.sign || <Sign /> /** 落款 */}
|
|
150
|
+
{props.footExpand}
|
|
151
|
+
</div>
|
|
152
|
+
|
|
153
|
+
<ImportBuyerDrawer />{/* 导入购买方的抽屉 */}
|
|
154
|
+
<ImportGoodsDrawer />{/* 导入货品的抽屉 */}
|
|
155
|
+
<EndowCodeDrawer />{/* 给货品赋码的抽屉 */}
|
|
156
|
+
<AddComparisonDrawer />{/* 添加商品对照的抽屉 */}
|
|
157
|
+
</InvoiceContext.Provider>
|
|
158
|
+
);
|
|
159
|
+
};
|
|
160
|
+
|
|
161
|
+
/** 数电 */
|
|
162
|
+
const Digtal = (props: IInvoiceProps) => {
|
|
163
|
+
|
|
164
|
+
const controller = React.useMemo(() => props.controller || new InvoiceController(), [props.controller]);
|
|
165
|
+
|
|
166
|
+
const [key, setKey] = React.useState(0);
|
|
167
|
+
|
|
168
|
+
useToGenerateId(controller);
|
|
169
|
+
|
|
170
|
+
React.useEffect(() => { setKey(key + 1) }, [controller]);
|
|
171
|
+
|
|
172
|
+
return (
|
|
173
|
+
<InvoiceContext.Provider key={key} value={controller}>
|
|
174
|
+
<div className="kts-invoice-operate-digtal" ref={controller.pipeline<HTMLDivElement | null>(async (s, e) => { s.rootElement = e })} >
|
|
175
|
+
{props.invoiceHeader || <InvoiceHeaderDigtal /> /** 发票头 */}
|
|
176
|
+
<div className='kts-invoice-operate-digtal-cont' >
|
|
177
|
+
{props.stakeholder || <Stakeholder /> /** 干系人 */}
|
|
178
|
+
{props.goodsList || <GoodsListDigtal /> /** 货物列表 */}
|
|
179
|
+
</div>
|
|
180
|
+
{props.specialInfor /** 特殊信息 */}
|
|
181
|
+
{props.sign || <SignDigtal /> /** 落款 */}
|
|
182
|
+
</div>
|
|
183
|
+
|
|
184
|
+
<ImportGoodsDrawer />{ /** 导入货品的抽屉 */}
|
|
185
|
+
<EndowCodeDrawer />{ /** 给货品赋码的抽屉 */}
|
|
186
|
+
</InvoiceContext.Provider>
|
|
187
|
+
)
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
|
|
@@ -1,133 +1,133 @@
|
|
|
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
|
-
/**
|
|
96
|
-
* 数量 = 金额/单价
|
|
97
|
-
* @param amount 金额
|
|
98
|
-
* @param price 单价
|
|
99
|
-
* @returns 数量
|
|
100
|
-
*/
|
|
101
|
-
export function countQuantity(amount: string | number, price: string | number, calculatingDigits?: number): number | undefined | '' {
|
|
102
|
-
if (!amount && amount !== 0) return undefined;
|
|
103
|
-
if (!price && price !== 0) return undefined;
|
|
104
|
-
|
|
105
|
-
return format15(chain(bignumber(amount)).divide(bignumber(price))
|
|
106
|
-
.done()
|
|
107
|
-
.toNumber(), calculatingDigits)
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
/**
|
|
111
|
-
* 将数值转化为非科学计数法的字符串,忽略小数多余的0
|
|
112
|
-
* 无法转化的返回空字符串
|
|
113
|
-
* @param value 数值或字符串
|
|
114
|
-
* @param precision 精度
|
|
115
|
-
* @returns 字符串
|
|
116
|
-
*/
|
|
117
|
-
export function nonScientificNotation (value: number | string | undefined, precision?: number ): string {
|
|
118
|
-
try {
|
|
119
|
-
if (!value && value !== 0) {
|
|
120
|
-
return ''
|
|
121
|
-
} else {
|
|
122
|
-
// 先按照精度fixed
|
|
123
|
-
if (precision) {
|
|
124
|
-
value = format(bignumber(value), {notation: 'fixed', precision});
|
|
125
|
-
}
|
|
126
|
-
// 去掉小数位多余的0
|
|
127
|
-
return format(bignumber(value), {notation: 'fixed'})
|
|
128
|
-
}
|
|
129
|
-
} catch (e){
|
|
130
|
-
console.error(e);
|
|
131
|
-
return ''
|
|
132
|
-
}
|
|
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
|
+
/**
|
|
96
|
+
* 数量 = 金额/单价
|
|
97
|
+
* @param amount 金额
|
|
98
|
+
* @param price 单价
|
|
99
|
+
* @returns 数量
|
|
100
|
+
*/
|
|
101
|
+
export function countQuantity(amount: string | number, price: string | number, calculatingDigits?: number): number | undefined | '' {
|
|
102
|
+
if (!amount && amount !== 0) return undefined;
|
|
103
|
+
if (!price && price !== 0) return undefined;
|
|
104
|
+
|
|
105
|
+
return format15(chain(bignumber(amount)).divide(bignumber(price))
|
|
106
|
+
.done()
|
|
107
|
+
.toNumber(), calculatingDigits)
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
/**
|
|
111
|
+
* 将数值转化为非科学计数法的字符串,忽略小数多余的0
|
|
112
|
+
* 无法转化的返回空字符串
|
|
113
|
+
* @param value 数值或字符串
|
|
114
|
+
* @param precision 精度
|
|
115
|
+
* @returns 字符串
|
|
116
|
+
*/
|
|
117
|
+
export function nonScientificNotation (value: number | string | undefined, precision?: number ): string {
|
|
118
|
+
try {
|
|
119
|
+
if (!value && value !== 0) {
|
|
120
|
+
return ''
|
|
121
|
+
} else {
|
|
122
|
+
// 先按照精度fixed
|
|
123
|
+
if (precision) {
|
|
124
|
+
value = format(bignumber(value), {notation: 'fixed', precision});
|
|
125
|
+
}
|
|
126
|
+
// 去掉小数位多余的0
|
|
127
|
+
return format(bignumber(value), {notation: 'fixed'})
|
|
128
|
+
}
|
|
129
|
+
} catch (e){
|
|
130
|
+
console.error(e);
|
|
131
|
+
return ''
|
|
132
|
+
}
|
|
133
133
|
}
|