kts-component-invoice-operate 3.2.244 → 3.2.246
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/BRANCH.md +5 -0
- package/README.md +12 -12
- package/branch/3.2.x +1 -0
- package/dist/Invoice/ui/default/GoodsList/hook/useColumns/autoFillFn/index.d.ts +2 -0
- package/dist/Invoice/ui/digtal/StakeFarmerholder/index.d.ts +2 -0
- package/dist/index.esm.js +126 -7
- package/dist/index.js +126 -7
- 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 +214 -214
- package/src/Invoice/Invoice-digtal/_test/freight/index.tsx +14580 -14580
- 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/pay/index.tsx +14636 -14636
- 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 +83 -83
- 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 +44 -44
- package/src/Invoice/InvoiceController/InvoiceControllerForm/index.ts +116 -116
- 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 +91 -90
- package/src/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/ImportGoods/index.ts +84 -84
- 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 +134 -134
- package/src/Invoice/InvoiceController/InvoiceControllerState/PayListState/IColumnsReplenish/index.ts +10 -10
- package/src/Invoice/InvoiceController/InvoiceControllerState/PayListState/IGood/index.ts +35 -35
- package/src/Invoice/InvoiceController/InvoiceControllerState/PayListState/ImportGoods/index.ts +81 -81
- package/src/Invoice/InvoiceController/InvoiceControllerState/PayListState/index.ts +39 -39
- package/src/Invoice/InvoiceController/InvoiceControllerState/Stakeholder/index.ts +13 -13
- package/src/Invoice/InvoiceController/InvoiceControllerState/index.ts +76 -76
- 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/addPay.ts +11 -11
- package/src/Invoice/InvoiceController/fns/delFreight.ts +38 -38
- package/src/Invoice/InvoiceController/fns/delGood.ts +41 -41
- package/src/Invoice/InvoiceController/fns/delPay.ts +38 -38
- 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/saveEditPay.ts +23 -23
- package/src/Invoice/InvoiceController/fns/setEditFreight.ts +16 -16
- package/src/Invoice/InvoiceController/fns/setEditGood.ts +16 -16
- package/src/Invoice/InvoiceController/fns/setEditPay.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/setPay.ts +10 -10
- package/src/Invoice/InvoiceController/fns/updateInvoiceNo.ts +8 -8
- package/src/Invoice/InvoiceController/index.ts +127 -127
- 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 +956 -957
- 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 +200 -200
- 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 +12 -12
- 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 +681 -647
- package/src/Invoice/ui/default/GoodsList/hook/useColumns/index.tsx +769 -719
- 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 +207 -207
- package/src/Invoice/ui/default/GoodsList/ui/AddRowButton/index.tsx +72 -72
- 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 +201 -201
- 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 +723 -724
- 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 +181 -181
- package/src/Invoice/ui/digtal/GoodsList/ui/AddRowButton/index.tsx +87 -87
- 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 +113 -113
- package/src/Invoice/ui/digtal/GoodsList/ui/TaxIncludedSwitch/index.tsx +34 -34
- 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/PayList/hook/useColumns/dist/index.js +616 -616
- package/src/Invoice/ui/digtal/PayList/hook/useColumns/index.tsx +168 -168
- package/src/Invoice/ui/digtal/PayList/hook/useColumns/ui/TitleText/index.tsx +20 -20
- package/src/Invoice/ui/digtal/PayList/hook/useOnRow/index.tsx +37 -37
- package/src/Invoice/ui/digtal/PayList/hook/useRowSelection/index.tsx +119 -119
- package/src/Invoice/ui/digtal/PayList/hook/useWindowClick/index.tsx +19 -19
- package/src/Invoice/ui/digtal/PayList/index.less +72 -72
- package/src/Invoice/ui/digtal/PayList/index.tsx +132 -132
- package/src/Invoice/ui/digtal/PayList/ui/AddRowButton/index.tsx +74 -74
- package/src/Invoice/ui/digtal/PayList/ui/BulkMenu/hooks/useDelRowButton/index.tsx +50 -50
- package/src/Invoice/ui/digtal/PayList/ui/BulkMenu/hooks/useEmptyRefill/index.tsx +36 -36
- package/src/Invoice/ui/digtal/PayList/ui/TableRow/index.less +28 -28
- package/src/Invoice/ui/digtal/PayList/ui/TableRow/index.tsx +20 -20
- package/src/Invoice/ui/digtal/PayList/ui/TableVirtual/index.less +38 -38
- package/src/Invoice/ui/digtal/PayList/ui/TableVirtual/index.tsx +108 -108
- package/src/Invoice/ui/digtal/RealEstateInfo/index.less +21 -21
- package/src/Invoice/ui/digtal/RealEstateInfo/index.tsx +451 -451
- 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 +1102 -1096
- 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 +453 -453
- 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,1096 +1,1102 @@
|
|
|
1
|
-
|
|
2
|
-
import React, { useCallback } from 'react';
|
|
3
|
-
import Icon from '@ant-design/icons';
|
|
4
|
-
import { decorator } from "grey-react-box";
|
|
5
|
-
import { Form } from "kts-components-antd-x3";
|
|
6
|
-
import { AutoComplete, Button, Checkbox, Col, Input, InputProps, Select, Row, Tooltip } from 'kts-xui'
|
|
7
|
-
import { CheckboxChangeEvent } from 'kts-components-antd-x4/lib/checkbox';
|
|
8
|
-
import { FormComponentProps } from "kts-components-antd-x3/lib/form";
|
|
9
|
-
import { WrappedFormUtils } from 'kts-components-antd-x3/lib/form/Form';
|
|
10
|
-
import { ReactComponent as ArrowUpSvg } from './svg/arrowUp.svg';
|
|
11
|
-
import { ReactComponent as ArrowDownSvg } from './svg/arrowDown.svg';
|
|
12
|
-
import { ReactComponent as PlusSvg } from './svg/plus.svg'
|
|
13
|
-
import InvoiceController from "../../../InvoiceController";
|
|
14
|
-
import Invoice from "../../..";
|
|
15
|
-
import './index.less';
|
|
16
|
-
import classNames from 'classnames';
|
|
17
|
-
|
|
18
|
-
const RULES = {
|
|
19
|
-
companyName: (label: string) => [
|
|
20
|
-
{ required: true, message: `${label}必填` },
|
|
21
|
-
{ max: 100, message: `${label}内容超长` }
|
|
22
|
-
],
|
|
23
|
-
taxId: (label: string) => [
|
|
24
|
-
{ max: 20, message: `${label}内容超长` },
|
|
25
|
-
{ pattern: /^([a-zA-Z0-9])*$/g, message: `${label}仅能数字、英文` }
|
|
26
|
-
],
|
|
27
|
-
buyerTelPhone: (label: string) => [
|
|
28
|
-
{ required: true, message: `${label}必填` },
|
|
29
|
-
{ max: 100, message: `${label}内容超长` },
|
|
30
|
-
{ pattern: /^[0-9\s\-\+]+$/g, message: `${label}仅能数字、空格、-、+` }
|
|
31
|
-
],
|
|
32
|
-
sellerTelPhone: (label: string) => [
|
|
33
|
-
|
|
34
|
-
{ max: 100, message: `${label}内容超长` },
|
|
35
|
-
{ pattern: /^[0-9\s\-\+]+$/g, message: `${label}仅能数字、空格、-、+` }
|
|
36
|
-
],
|
|
37
|
-
bankName: (label: string) => [
|
|
38
|
-
{ max: 100, message: `${label}内容超长` }
|
|
39
|
-
],
|
|
40
|
-
bankAccount: (label: string) => [
|
|
41
|
-
{ max: 100, message: `${label}内容超长` },
|
|
42
|
-
{ pattern: /^([0-9a-zA-Z-\s])*$/g, message: `${label}仅能数字、字母、-、空格` }
|
|
43
|
-
],
|
|
44
|
-
certificateNumber: (label: string) => [
|
|
45
|
-
{ required: true, message: `${label}必填` },
|
|
46
|
-
{ max: 30, message: `${label}内容超长` },
|
|
47
|
-
{ pattern: /^([a-zA-Z0-9])*$/g, message: `${label}仅能数字、英文` }
|
|
48
|
-
],
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
const formatCompanyName = (e: any) => {
|
|
52
|
-
const value = e?.target?.value;
|
|
53
|
-
if (value) {
|
|
54
|
-
return value.replace('(', '(').replace(')', ')').replace(' ', '');
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
export interface IStakeholder {
|
|
59
|
-
|
|
60
|
-
/** 是否显示导入按钮 */
|
|
61
|
-
isShowImportButton?: boolean;
|
|
62
|
-
|
|
63
|
-
/** 点击了 */
|
|
64
|
-
onClickImportButton?: (e: InvoiceController) => void
|
|
65
|
-
|
|
66
|
-
/** 查看当前可用授信额度 */
|
|
67
|
-
lineCredit?: React.ReactNode;
|
|
68
|
-
|
|
69
|
-
/** 票种类型 */
|
|
70
|
-
isVatNormal?: boolean;
|
|
71
|
-
|
|
72
|
-
/** 是否可以选择自然人 */
|
|
73
|
-
isNaturalPerson?: boolean;
|
|
74
|
-
|
|
75
|
-
/**
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
const
|
|
102
|
-
|
|
103
|
-
const
|
|
104
|
-
const [
|
|
105
|
-
|
|
106
|
-
const
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
(
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
setNationStatue('');
|
|
165
|
-
setNation('');
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
setNationStatue('');
|
|
175
|
-
setNation('');
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
setNationStatue('');
|
|
189
|
-
setNation('');
|
|
190
|
-
}
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
setNationStatue('');
|
|
198
|
-
setNation('');
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
setNationStatue('');
|
|
242
|
-
setNation('');
|
|
243
|
-
}
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
setNationStatue('');
|
|
252
|
-
setNation('');
|
|
253
|
-
}
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
setNationStatue('');
|
|
268
|
-
setNation('');
|
|
269
|
-
}
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
setNationStatue('');
|
|
277
|
-
setNation('');
|
|
278
|
-
}
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
}
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
//
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
setStatus('');
|
|
324
|
-
setInfo('')
|
|
325
|
-
}
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
if (
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
if (
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
(
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
486
|
-
|
|
487
|
-
|
|
488
|
-
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
|
|
514
|
-
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
|
|
520
|
-
|
|
521
|
-
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
|
|
534
|
-
|
|
535
|
-
|
|
536
|
-
|
|
537
|
-
|
|
538
|
-
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
|
|
549
|
-
|
|
550
|
-
|
|
551
|
-
|
|
552
|
-
|
|
553
|
-
|
|
554
|
-
|
|
555
|
-
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
|
|
568
|
-
|
|
569
|
-
|
|
570
|
-
|
|
571
|
-
|
|
572
|
-
|
|
573
|
-
|
|
574
|
-
|
|
575
|
-
|
|
576
|
-
|
|
577
|
-
|
|
578
|
-
|
|
579
|
-
|
|
580
|
-
|
|
581
|
-
|
|
582
|
-
|
|
583
|
-
|
|
584
|
-
|
|
585
|
-
|
|
586
|
-
|
|
587
|
-
|
|
588
|
-
|
|
589
|
-
|
|
590
|
-
|
|
591
|
-
|
|
592
|
-
|
|
593
|
-
|
|
594
|
-
|
|
595
|
-
|
|
596
|
-
|
|
597
|
-
|
|
598
|
-
|
|
599
|
-
|
|
600
|
-
|
|
601
|
-
|
|
602
|
-
|
|
603
|
-
|
|
604
|
-
|
|
605
|
-
|
|
606
|
-
|
|
607
|
-
|
|
608
|
-
|
|
609
|
-
|
|
610
|
-
|
|
611
|
-
|
|
612
|
-
|
|
613
|
-
|
|
614
|
-
|
|
615
|
-
|
|
616
|
-
|
|
617
|
-
|
|
618
|
-
|
|
619
|
-
|
|
620
|
-
|
|
621
|
-
|
|
622
|
-
|
|
623
|
-
|
|
624
|
-
|
|
625
|
-
|
|
626
|
-
|
|
627
|
-
|
|
628
|
-
|
|
629
|
-
|
|
630
|
-
|
|
631
|
-
|
|
632
|
-
|
|
633
|
-
|
|
634
|
-
|
|
635
|
-
|
|
636
|
-
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
|
|
640
|
-
|
|
641
|
-
|
|
642
|
-
|
|
643
|
-
|
|
644
|
-
|
|
645
|
-
|
|
646
|
-
{
|
|
647
|
-
|
|
648
|
-
|
|
649
|
-
|
|
650
|
-
|
|
651
|
-
|
|
652
|
-
|
|
653
|
-
|
|
654
|
-
|
|
655
|
-
|
|
656
|
-
|
|
657
|
-
|
|
658
|
-
|
|
659
|
-
</
|
|
660
|
-
|
|
661
|
-
|
|
662
|
-
|
|
663
|
-
|
|
664
|
-
|
|
665
|
-
|
|
666
|
-
|
|
667
|
-
|
|
668
|
-
|
|
669
|
-
|
|
670
|
-
}
|
|
671
|
-
|
|
672
|
-
|
|
673
|
-
|
|
674
|
-
|
|
675
|
-
|
|
676
|
-
|
|
677
|
-
|
|
678
|
-
|
|
679
|
-
|
|
680
|
-
|
|
681
|
-
|
|
682
|
-
|
|
683
|
-
|
|
684
|
-
|
|
685
|
-
|
|
686
|
-
|
|
687
|
-
|
|
688
|
-
|
|
689
|
-
|
|
690
|
-
|
|
691
|
-
|
|
692
|
-
|
|
693
|
-
|
|
694
|
-
|
|
695
|
-
|
|
696
|
-
|
|
697
|
-
|
|
698
|
-
React.
|
|
699
|
-
|
|
700
|
-
|
|
701
|
-
|
|
702
|
-
|
|
703
|
-
|
|
704
|
-
|
|
705
|
-
|
|
706
|
-
|
|
707
|
-
|
|
708
|
-
|
|
709
|
-
|
|
710
|
-
|
|
711
|
-
}
|
|
712
|
-
|
|
713
|
-
|
|
714
|
-
|
|
715
|
-
|
|
716
|
-
|
|
717
|
-
|
|
718
|
-
|
|
719
|
-
|
|
720
|
-
|
|
721
|
-
const
|
|
722
|
-
|
|
723
|
-
const
|
|
724
|
-
|
|
725
|
-
const
|
|
726
|
-
|
|
727
|
-
|
|
728
|
-
|
|
729
|
-
|
|
730
|
-
|
|
731
|
-
|
|
732
|
-
|
|
733
|
-
|
|
734
|
-
|
|
735
|
-
|
|
736
|
-
|
|
737
|
-
|
|
738
|
-
|
|
739
|
-
|
|
740
|
-
|
|
741
|
-
|
|
742
|
-
|
|
743
|
-
|
|
744
|
-
|
|
745
|
-
|
|
746
|
-
|
|
747
|
-
|
|
748
|
-
|
|
749
|
-
|
|
750
|
-
|
|
751
|
-
|
|
752
|
-
|
|
753
|
-
|
|
754
|
-
|
|
755
|
-
|
|
756
|
-
|
|
757
|
-
|
|
758
|
-
|
|
759
|
-
|
|
760
|
-
|
|
761
|
-
|
|
762
|
-
|
|
763
|
-
|
|
764
|
-
|
|
765
|
-
|
|
766
|
-
|
|
767
|
-
|
|
768
|
-
|
|
769
|
-
|
|
770
|
-
|
|
771
|
-
|
|
772
|
-
|
|
773
|
-
|
|
774
|
-
}
|
|
775
|
-
|
|
776
|
-
|
|
777
|
-
|
|
778
|
-
|
|
779
|
-
|
|
780
|
-
|
|
781
|
-
|
|
782
|
-
|
|
783
|
-
|
|
784
|
-
|
|
785
|
-
|
|
786
|
-
|
|
787
|
-
|
|
788
|
-
|
|
789
|
-
|
|
790
|
-
|
|
791
|
-
|
|
792
|
-
|
|
793
|
-
|
|
794
|
-
|
|
795
|
-
|
|
796
|
-
|
|
797
|
-
|
|
798
|
-
{ label: "
|
|
799
|
-
|
|
800
|
-
{ label: "
|
|
801
|
-
|
|
802
|
-
{ label: "
|
|
803
|
-
|
|
804
|
-
|
|
805
|
-
|
|
806
|
-
|
|
807
|
-
|
|
808
|
-
|
|
809
|
-
|
|
810
|
-
|
|
811
|
-
|
|
812
|
-
|
|
813
|
-
|
|
814
|
-
return
|
|
815
|
-
|
|
816
|
-
|
|
817
|
-
|
|
818
|
-
|
|
819
|
-
|
|
820
|
-
|
|
821
|
-
|
|
822
|
-
|
|
823
|
-
|
|
824
|
-
|
|
825
|
-
|
|
826
|
-
|
|
827
|
-
|
|
828
|
-
|
|
829
|
-
{ value: "
|
|
830
|
-
{ value: "
|
|
831
|
-
{ value: "
|
|
832
|
-
{ value: "
|
|
833
|
-
|
|
834
|
-
{ value: "
|
|
835
|
-
{ value: "
|
|
836
|
-
{ value: "
|
|
837
|
-
{ value: "
|
|
838
|
-
{ value: "
|
|
839
|
-
{ value: "
|
|
840
|
-
{ value: "
|
|
841
|
-
{ value: "
|
|
842
|
-
{ value: "
|
|
843
|
-
{ value: "
|
|
844
|
-
{ value: "
|
|
845
|
-
{ value: "
|
|
846
|
-
{ value: "
|
|
847
|
-
{ value: "
|
|
848
|
-
{ value: "
|
|
849
|
-
{ value: "
|
|
850
|
-
{ value: "
|
|
851
|
-
{ value: "
|
|
852
|
-
{ value: "
|
|
853
|
-
{ value: "
|
|
854
|
-
{ value: "
|
|
855
|
-
{ value: "
|
|
856
|
-
{ value: "
|
|
857
|
-
{ value: "
|
|
858
|
-
{ value: "
|
|
859
|
-
{ value: "
|
|
860
|
-
{ value: "
|
|
861
|
-
{ value: "
|
|
862
|
-
{ value: "
|
|
863
|
-
{ value: "
|
|
864
|
-
{ value: "
|
|
865
|
-
{ value: "
|
|
866
|
-
{ value: "
|
|
867
|
-
{ value: "
|
|
868
|
-
{ value: "
|
|
869
|
-
{ value: "
|
|
870
|
-
{ value: "
|
|
871
|
-
|
|
872
|
-
{ value: "
|
|
873
|
-
{ value: "
|
|
874
|
-
{ value: "
|
|
875
|
-
{ value: "
|
|
876
|
-
{ value: "
|
|
877
|
-
|
|
878
|
-
{ value: "
|
|
879
|
-
{ value: "
|
|
880
|
-
{ value: "
|
|
881
|
-
{ value: "
|
|
882
|
-
{ value: "
|
|
883
|
-
{ value: "
|
|
884
|
-
{ value: "
|
|
885
|
-
{ value: "
|
|
886
|
-
{ value: "
|
|
887
|
-
{ value: "
|
|
888
|
-
{ value: "
|
|
889
|
-
{ value: "
|
|
890
|
-
{ value: "
|
|
891
|
-
{ value: "
|
|
892
|
-
{ value: "
|
|
893
|
-
{ value: "
|
|
894
|
-
{ value: "
|
|
895
|
-
{ value: "
|
|
896
|
-
{ value: "
|
|
897
|
-
{ value: "
|
|
898
|
-
{ value: "
|
|
899
|
-
{ value: "
|
|
900
|
-
{ value: "
|
|
901
|
-
{ value: "
|
|
902
|
-
{ value: "
|
|
903
|
-
{ value: "
|
|
904
|
-
{ value: "
|
|
905
|
-
{ value: "
|
|
906
|
-
{ value: "
|
|
907
|
-
{ value: "
|
|
908
|
-
{ value: "
|
|
909
|
-
{ value: "
|
|
910
|
-
{ value: "
|
|
911
|
-
{ value: "
|
|
912
|
-
{ value: "
|
|
913
|
-
{ value: "
|
|
914
|
-
{ value: "
|
|
915
|
-
{ value: "
|
|
916
|
-
{ value: "
|
|
917
|
-
{ value: "
|
|
918
|
-
{ value: "
|
|
919
|
-
{ value: "
|
|
920
|
-
{ value: "
|
|
921
|
-
{ value: "
|
|
922
|
-
{ value: "
|
|
923
|
-
{ value: "
|
|
924
|
-
{ value: "
|
|
925
|
-
|
|
926
|
-
{ value: "
|
|
927
|
-
{ value: "
|
|
928
|
-
{ value: "
|
|
929
|
-
{ value: "
|
|
930
|
-
{ value: "
|
|
931
|
-
|
|
932
|
-
{ value: "
|
|
933
|
-
{ value: "
|
|
934
|
-
{ value: "
|
|
935
|
-
{ value: "
|
|
936
|
-
{ value: "
|
|
937
|
-
{ value: "
|
|
938
|
-
{ value: "
|
|
939
|
-
{ value: "
|
|
940
|
-
{ value: "
|
|
941
|
-
{ value: "
|
|
942
|
-
{ value: "
|
|
943
|
-
{ value: "
|
|
944
|
-
{ value: "
|
|
945
|
-
{ value: "
|
|
946
|
-
{ value: "
|
|
947
|
-
{ value: "
|
|
948
|
-
{ value: "
|
|
949
|
-
{ value: "
|
|
950
|
-
{ value: "
|
|
951
|
-
{ value: "
|
|
952
|
-
{ value: "
|
|
953
|
-
{ value: "
|
|
954
|
-
|
|
955
|
-
{ value: "
|
|
956
|
-
{ value: "
|
|
957
|
-
{ value: "
|
|
958
|
-
{ value: "
|
|
959
|
-
{ value: "
|
|
960
|
-
|
|
961
|
-
{ value: "
|
|
962
|
-
{ value: "
|
|
963
|
-
{ value: "
|
|
964
|
-
{ value: "
|
|
965
|
-
{ value: "
|
|
966
|
-
{ value: "
|
|
967
|
-
{ value: "
|
|
968
|
-
{ value: "
|
|
969
|
-
{ value: "
|
|
970
|
-
{ value: "
|
|
971
|
-
{ value: "
|
|
972
|
-
{ value: "
|
|
973
|
-
{ value: "
|
|
974
|
-
{ value: "
|
|
975
|
-
{ value: "
|
|
976
|
-
{ value: "
|
|
977
|
-
{ value: "
|
|
978
|
-
{ value: "
|
|
979
|
-
{ value: "
|
|
980
|
-
{ value: "
|
|
981
|
-
{ value: "
|
|
982
|
-
{ value: "
|
|
983
|
-
{ value: "
|
|
984
|
-
{ value: "
|
|
985
|
-
{ value: "
|
|
986
|
-
{ value: "
|
|
987
|
-
{ value: "
|
|
988
|
-
{ value: "
|
|
989
|
-
{ value: "
|
|
990
|
-
{ value: "
|
|
991
|
-
{ value: "
|
|
992
|
-
{ value: "
|
|
993
|
-
{ value: "
|
|
994
|
-
{ value: "
|
|
995
|
-
{ value: "
|
|
996
|
-
{ value: "
|
|
997
|
-
{ value: "
|
|
998
|
-
{ value: "
|
|
999
|
-
{ value: "
|
|
1000
|
-
{ value: "
|
|
1001
|
-
{ value: "
|
|
1002
|
-
{ value: "
|
|
1003
|
-
{ value: "
|
|
1004
|
-
{ value: "
|
|
1005
|
-
{ value: "
|
|
1006
|
-
{ value: "
|
|
1007
|
-
{ value: "
|
|
1008
|
-
{ value: "
|
|
1009
|
-
{ value: "
|
|
1010
|
-
{ value: "
|
|
1011
|
-
{ value: "
|
|
1012
|
-
{ value: "
|
|
1013
|
-
{ value: "
|
|
1014
|
-
{ value: "
|
|
1015
|
-
{ value: "
|
|
1016
|
-
{ value: "
|
|
1017
|
-
{ value: "
|
|
1018
|
-
{ value: "
|
|
1019
|
-
{ value: "
|
|
1020
|
-
{ value: "
|
|
1021
|
-
{ value: "
|
|
1022
|
-
{ value: "
|
|
1023
|
-
{ value: "
|
|
1024
|
-
{ value: "
|
|
1025
|
-
{ value: "
|
|
1026
|
-
{ value: "
|
|
1027
|
-
{ value: "
|
|
1028
|
-
{ value: "
|
|
1029
|
-
{ value: "
|
|
1030
|
-
{ value: "
|
|
1031
|
-
{ value: "
|
|
1032
|
-
{ value: "
|
|
1033
|
-
{ value: "
|
|
1034
|
-
{ value: "
|
|
1035
|
-
{ value: "
|
|
1036
|
-
{ value: "
|
|
1037
|
-
{ value: "
|
|
1038
|
-
{ value: "
|
|
1039
|
-
{ value: "
|
|
1040
|
-
{ value: "
|
|
1041
|
-
{ value: "
|
|
1042
|
-
{ value: "
|
|
1043
|
-
{ value: "
|
|
1044
|
-
{ value: "
|
|
1045
|
-
{ value: "
|
|
1046
|
-
{ value: "
|
|
1047
|
-
{ value: "
|
|
1048
|
-
{ value: "
|
|
1049
|
-
{ value: "
|
|
1050
|
-
{ value: "
|
|
1051
|
-
{ value: "
|
|
1052
|
-
{ value: "
|
|
1053
|
-
{ value: "
|
|
1054
|
-
{ value: "
|
|
1055
|
-
{ value: "
|
|
1056
|
-
{ value: "
|
|
1057
|
-
{ value: "
|
|
1058
|
-
{ value: "
|
|
1059
|
-
{ value: "
|
|
1060
|
-
{ value: "
|
|
1061
|
-
{ value: "
|
|
1062
|
-
{ value: "
|
|
1063
|
-
{ value: "
|
|
1064
|
-
{ value: "
|
|
1065
|
-
{ value: "
|
|
1066
|
-
{ value: "
|
|
1067
|
-
{ value: "
|
|
1068
|
-
{ value: "
|
|
1069
|
-
{ value: "
|
|
1070
|
-
{ value: "
|
|
1071
|
-
{ value: "
|
|
1072
|
-
{ value: "
|
|
1073
|
-
|
|
1074
|
-
|
|
1075
|
-
|
|
1076
|
-
|
|
1077
|
-
|
|
1078
|
-
|
|
1079
|
-
|
|
1080
|
-
|
|
1081
|
-
|
|
1082
|
-
|
|
1083
|
-
return
|
|
1084
|
-
|
|
1085
|
-
|
|
1086
|
-
|
|
1087
|
-
|
|
1088
|
-
|
|
1089
|
-
|
|
1090
|
-
|
|
1091
|
-
|
|
1092
|
-
|
|
1093
|
-
|
|
1094
|
-
|
|
1095
|
-
|
|
1096
|
-
|
|
1
|
+
|
|
2
|
+
import React, { useCallback } from 'react';
|
|
3
|
+
import Icon from '@ant-design/icons';
|
|
4
|
+
import { decorator } from "grey-react-box";
|
|
5
|
+
import { Form } from "kts-components-antd-x3";
|
|
6
|
+
import { AutoComplete, Button, Checkbox, Col, Input, InputProps, Select, Row, Tooltip } from 'kts-xui'
|
|
7
|
+
import { CheckboxChangeEvent } from 'kts-components-antd-x4/lib/checkbox';
|
|
8
|
+
import { FormComponentProps } from "kts-components-antd-x3/lib/form";
|
|
9
|
+
import { WrappedFormUtils } from 'kts-components-antd-x3/lib/form/Form';
|
|
10
|
+
import { ReactComponent as ArrowUpSvg } from './svg/arrowUp.svg';
|
|
11
|
+
import { ReactComponent as ArrowDownSvg } from './svg/arrowDown.svg';
|
|
12
|
+
import { ReactComponent as PlusSvg } from './svg/plus.svg'
|
|
13
|
+
import InvoiceController from "../../../InvoiceController";
|
|
14
|
+
import Invoice from "../../..";
|
|
15
|
+
import './index.less';
|
|
16
|
+
import classNames from 'classnames';
|
|
17
|
+
|
|
18
|
+
const RULES = {
|
|
19
|
+
companyName: (label: string) => [
|
|
20
|
+
{ required: true, message: `${label}必填` },
|
|
21
|
+
{ max: 100, message: `${label}内容超长` }
|
|
22
|
+
],
|
|
23
|
+
taxId: (label: string) => [
|
|
24
|
+
{ max: 20, message: `${label}内容超长` },
|
|
25
|
+
{ pattern: /^([a-zA-Z0-9])*$/g, message: `${label}仅能数字、英文` }
|
|
26
|
+
],
|
|
27
|
+
buyerTelPhone: (label: string) => [
|
|
28
|
+
{ required: true, message: `${label}必填` },
|
|
29
|
+
{ max: 100, message: `${label}内容超长` },
|
|
30
|
+
{ pattern: /^[0-9\s\-\+]+$/g, message: `${label}仅能数字、空格、-、+` }
|
|
31
|
+
],
|
|
32
|
+
sellerTelPhone: (label: string) => [
|
|
33
|
+
|
|
34
|
+
{ max: 100, message: `${label}内容超长` },
|
|
35
|
+
{ pattern: /^[0-9\s\-\+]+$/g, message: `${label}仅能数字、空格、-、+` }
|
|
36
|
+
],
|
|
37
|
+
bankName: (label: string) => [
|
|
38
|
+
{ max: 100, message: `${label}内容超长` }
|
|
39
|
+
],
|
|
40
|
+
bankAccount: (label: string) => [
|
|
41
|
+
{ max: 100, message: `${label}内容超长` },
|
|
42
|
+
{ pattern: /^([0-9a-zA-Z-\s])*$/g, message: `${label}仅能数字、字母、-、空格` }
|
|
43
|
+
],
|
|
44
|
+
certificateNumber: (label: string) => [
|
|
45
|
+
{ required: true, message: `${label}必填` },
|
|
46
|
+
{ max: 30, message: `${label}内容超长` },
|
|
47
|
+
{ pattern: /^([a-zA-Z0-9])*$/g, message: `${label}仅能数字、英文` }
|
|
48
|
+
],
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
const formatCompanyName = (e: any) => {
|
|
52
|
+
const value = e?.target?.value;
|
|
53
|
+
if (value) {
|
|
54
|
+
return value.replace('(', '(').replace(')', ')').replace(' ', '');
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
export interface IStakeholder {
|
|
59
|
+
|
|
60
|
+
/** 是否显示导入按钮 */
|
|
61
|
+
isShowImportButton?: boolean;
|
|
62
|
+
|
|
63
|
+
/** 点击了 */
|
|
64
|
+
onClickImportButton?: (e: InvoiceController) => void
|
|
65
|
+
|
|
66
|
+
/** 查看当前可用授信额度 */
|
|
67
|
+
lineCredit?: React.ReactNode;
|
|
68
|
+
|
|
69
|
+
/** 票种类型 */
|
|
70
|
+
isVatNormal?: boolean;
|
|
71
|
+
|
|
72
|
+
/** 是否可以选择自然人 */
|
|
73
|
+
isNaturalPerson?: boolean;
|
|
74
|
+
|
|
75
|
+
/** 是否显示自然人销售方补充信息 */
|
|
76
|
+
isShowNaturalPersonInfo?: boolean;
|
|
77
|
+
|
|
78
|
+
/** 是否展开 */
|
|
79
|
+
isExpand?: boolean;
|
|
80
|
+
|
|
81
|
+
leqi?: boolean;
|
|
82
|
+
|
|
83
|
+
riskData?: any;
|
|
84
|
+
|
|
85
|
+
invoiceMarkCallback?: (value: any) => void;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
/** 农产品干系人 */
|
|
89
|
+
export default decorator<IStakeholder, IStakeholder & FormComponentProps>(Form.create())(props => {
|
|
90
|
+
|
|
91
|
+
const { form, isShowImportButton, onClickImportButton, isVatNormal = false, isShowNaturalPersonInfo = true } = props;
|
|
92
|
+
|
|
93
|
+
const [isExpand, setExpand] = React.useState(typeof props.isExpand === 'boolean' ? props.isExpand : true);
|
|
94
|
+
|
|
95
|
+
const { getFieldDecorator } = form;
|
|
96
|
+
|
|
97
|
+
const controller = Invoice.useInvoiceController();
|
|
98
|
+
|
|
99
|
+
const model = controller.useMemo(s => s.model, []);
|
|
100
|
+
|
|
101
|
+
const disableds = controller.useMemo(s => s.stakeholder.disableds || [], []);
|
|
102
|
+
|
|
103
|
+
const rulesMap = controller.useMemo(s => s.stakeholder.rulesMap || {}, []);
|
|
104
|
+
const [validateStatus, setStatus] = React.useState<any>('');
|
|
105
|
+
const [errorInfo, setInfo] = React.useState('');
|
|
106
|
+
const [nation, setNationStatue] = React.useState<any>('');
|
|
107
|
+
const [nationInfo, setNation] = React.useState('');
|
|
108
|
+
/** 乐企 */
|
|
109
|
+
const leqispanW = React.useMemo(() => {
|
|
110
|
+
if (props.leqi) {
|
|
111
|
+
return 0;
|
|
112
|
+
} else {
|
|
113
|
+
return 2;
|
|
114
|
+
}
|
|
115
|
+
}, [props.leqi, props.riskData]);
|
|
116
|
+
/** 直连 */
|
|
117
|
+
const riskspanW = React.useMemo(() => {
|
|
118
|
+
if (props.riskData?.code === 'success') {
|
|
119
|
+
return 0;
|
|
120
|
+
} else {
|
|
121
|
+
return 2;
|
|
122
|
+
}
|
|
123
|
+
}, [props.leqi, props.riskData]);
|
|
124
|
+
|
|
125
|
+
const readOnly = React.useMemo(() => {
|
|
126
|
+
if (model === 'readOnly') return true;
|
|
127
|
+
if (model === 'prefab') return true;
|
|
128
|
+
return false;
|
|
129
|
+
}, [model]);
|
|
130
|
+
|
|
131
|
+
const onExpand = React.useCallback(() => { setExpand(e => !e) }, []);
|
|
132
|
+
|
|
133
|
+
const isReadOnly = React.useCallback(field => readOnly || disableds.indexOf(field) >= 0, [disableds, readOnly]);
|
|
134
|
+
|
|
135
|
+
const getRules = React.useCallback((field, defaultRules) => {
|
|
136
|
+
if (isReadOnly(field)) return [];
|
|
137
|
+
return rulesMap[field] || defaultRules;
|
|
138
|
+
}, [rulesMap, isReadOnly, isReadOnly]);
|
|
139
|
+
|
|
140
|
+
controller.useForm('stakeholder', form);
|
|
141
|
+
|
|
142
|
+
// props.isExpand 变化的时候更新
|
|
143
|
+
React.useEffect(() => {
|
|
144
|
+
setExpand(typeof props.isExpand === 'boolean' ? props.isExpand : true);
|
|
145
|
+
}, [props.isExpand])
|
|
146
|
+
const onChangeType = useCallback(
|
|
147
|
+
(value: string) => {
|
|
148
|
+
const supplierTaxId = form?.getFieldValue("supplierTaxId");
|
|
149
|
+
const certificateNumber = form?.getFieldValue("certificateNumber");
|
|
150
|
+
const nationality = form?.getFieldValue("nationality");
|
|
151
|
+
if (value === "201") {
|
|
152
|
+
// 当“自然人证件类型”选择“201:居民身份证”时,校验是否为“156:中国’
|
|
153
|
+
form?.setFieldsValue({ nationality: "156" });
|
|
154
|
+
setNationStatue('');
|
|
155
|
+
setNation('');
|
|
156
|
+
if (supplierTaxId !== certificateNumber) {
|
|
157
|
+
setStatus('error');
|
|
158
|
+
setInfo('证件号码应与销方税号保持一致')
|
|
159
|
+
}
|
|
160
|
+
} else if (value === "210") {
|
|
161
|
+
if (value.startsWith("M")) {
|
|
162
|
+
//如果“证件号码”以M开头,"国籍(或地区头,)”必须为“446:中国澳门”;校验证件号码必须以H或M开头
|
|
163
|
+
if (nationality !== '446') {
|
|
164
|
+
setNationStatue('error');
|
|
165
|
+
setNation('请选择正确的国籍');
|
|
166
|
+
} else {
|
|
167
|
+
setNationStatue('');
|
|
168
|
+
setNation('');
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
} else if (value.startsWith("H")) {
|
|
172
|
+
//如果“证件号码”以H开国籍(或地区)”必须为“344:中国香港”;
|
|
173
|
+
if (nationality !== '344') {
|
|
174
|
+
setNationStatue('error');
|
|
175
|
+
setNation('请选择正确的国籍');
|
|
176
|
+
} else {
|
|
177
|
+
setNationStatue('');
|
|
178
|
+
setNation('');
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
} else {
|
|
182
|
+
setStatus('error');
|
|
183
|
+
setInfo('请输入正确的证件号码')
|
|
184
|
+
}
|
|
185
|
+
} else if (value === "237") {
|
|
186
|
+
if (value.startsWith("810000")) {
|
|
187
|
+
if (nationality !== '344') {
|
|
188
|
+
setNationStatue('error');
|
|
189
|
+
setNation('请选择正确的国籍');
|
|
190
|
+
} else {
|
|
191
|
+
setNationStatue('');
|
|
192
|
+
setNation('');
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
} else if (value.startsWith("820000")) {
|
|
196
|
+
if (nationality !== '446') {
|
|
197
|
+
setNationStatue('error');
|
|
198
|
+
setNation('请选择正确的国籍');
|
|
199
|
+
} else {
|
|
200
|
+
setNationStatue('');
|
|
201
|
+
setNation('');
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
|
|
205
|
+
} else {
|
|
206
|
+
setStatus('error');
|
|
207
|
+
setInfo('请输入正确的证件号码')
|
|
208
|
+
return Promise.reject("请输入正确的证件号码");
|
|
209
|
+
}
|
|
210
|
+
} else if (value === "227") {
|
|
211
|
+
|
|
212
|
+
// 当“自然人证件类型”选择“227:中华人民共和国护照”时,校验是否为“156:中国
|
|
213
|
+
form?.setFieldsValue({ nationality: "156" });
|
|
214
|
+
|
|
215
|
+
} else if (value === "213" || value === "238") {
|
|
216
|
+
// 当“自然人证件类型”选择“213:台湾居民来往大陆通行证”时,校验是否为”158:中国台湾”
|
|
217
|
+
// 当“自然人证件类型”选择“238:中华人民共和国台湾居民居住证”时,校验是否为“ 158:中国台湾”
|
|
218
|
+
form?.setFieldsValue({ nationality: "158" });
|
|
219
|
+
}
|
|
220
|
+
},
|
|
221
|
+
[form]
|
|
222
|
+
);
|
|
223
|
+
/** 校验证件号码*/
|
|
224
|
+
const validateIDCode = useCallback(
|
|
225
|
+
(_: any, value: string) => {
|
|
226
|
+
if (!value) {
|
|
227
|
+
setStatus('error');
|
|
228
|
+
setInfo('请输入正确的证件号码')
|
|
229
|
+
return Promise.resolve();
|
|
230
|
+
}
|
|
231
|
+
|
|
232
|
+
const idtype = form?.getFieldValue("certificateType");
|
|
233
|
+
const nationality = form?.getFieldValue("nationality");
|
|
234
|
+
if (idtype === "210") {
|
|
235
|
+
// 当“自然人证件类型”选择“210:港澳居民来往内地通行证”时,
|
|
236
|
+
|
|
237
|
+
|
|
238
|
+
if (value.startsWith("M")) {
|
|
239
|
+
//如果“证件号码”以M开头,"国籍(或地区头,)”必须为“446:中国澳门”;校验证件号码必须以H或M开头
|
|
240
|
+
if (nationality !== '446') {
|
|
241
|
+
setNationStatue('error');
|
|
242
|
+
setNation('请选择正确的国籍');
|
|
243
|
+
} else {
|
|
244
|
+
setNationStatue('');
|
|
245
|
+
setNation('');
|
|
246
|
+
}
|
|
247
|
+
|
|
248
|
+
} else if (value.startsWith("H")) {
|
|
249
|
+
//如果“证件号码”以H开国籍(或地区)”必须为“344:中国香港”;
|
|
250
|
+
if (nationality !== '344') {
|
|
251
|
+
setNationStatue('error');
|
|
252
|
+
setNation('请选择正确的国籍');
|
|
253
|
+
} else {
|
|
254
|
+
setNationStatue('');
|
|
255
|
+
setNation('');
|
|
256
|
+
}
|
|
257
|
+
|
|
258
|
+
} else {
|
|
259
|
+
setStatus('error');
|
|
260
|
+
setInfo('请输入正确的证件号码')
|
|
261
|
+
return Promise.reject("请输入正确的证件号码");
|
|
262
|
+
}
|
|
263
|
+
} else if (idtype === "237") {
|
|
264
|
+
//当“自然人证件类型”选择“237:中华人民共和国港澳居民居住证”时,校验证件号码必须以810000或820000开头,如果“证件号码”以810000开头,必须为“344:中国香国籍(或地区))港”;如果“证件号码”以820000开头,国籍(或地区)必须为“446:中国澳门”
|
|
265
|
+
if (value.startsWith("810000")) {
|
|
266
|
+
if (nationality !== '344') {
|
|
267
|
+
setNationStatue('error');
|
|
268
|
+
setNation('请选择正确的国籍');
|
|
269
|
+
} else {
|
|
270
|
+
setNationStatue('');
|
|
271
|
+
setNation('');
|
|
272
|
+
}
|
|
273
|
+
|
|
274
|
+
} else if (value.startsWith("820000")) {
|
|
275
|
+
if (nationality !== '446') {
|
|
276
|
+
setNationStatue('error');
|
|
277
|
+
setNation('请选择正确的国籍');
|
|
278
|
+
} else {
|
|
279
|
+
setNationStatue('');
|
|
280
|
+
setNation('');
|
|
281
|
+
}
|
|
282
|
+
|
|
283
|
+
|
|
284
|
+
} else {
|
|
285
|
+
setStatus('error');
|
|
286
|
+
setInfo('请输入正确的证件号码')
|
|
287
|
+
return Promise.reject("请输入正确的证件号码");
|
|
288
|
+
}
|
|
289
|
+
}
|
|
290
|
+
// 当“销售方自然人证件类型”填写“201:居民身份证”,“销售方纳税人识别号”必须与“销售方自然人证件号码”完全一致
|
|
291
|
+
if (idtype === "201") {
|
|
292
|
+
const supplierTaxId = form?.getFieldValue("supplierTaxId");
|
|
293
|
+
if (value !== supplierTaxId) {
|
|
294
|
+
setStatus('error');
|
|
295
|
+
setInfo('证件号码应与销方税号保持一致')
|
|
296
|
+
return Promise.reject("证件号码应与销方税号保持一致");
|
|
297
|
+
} else if (value === supplierTaxId) {
|
|
298
|
+
setStatus('');
|
|
299
|
+
setInfo('')
|
|
300
|
+
}
|
|
301
|
+
}
|
|
302
|
+
setStatus('');
|
|
303
|
+
setInfo('')
|
|
304
|
+
return Promise.resolve();
|
|
305
|
+
},
|
|
306
|
+
[form]
|
|
307
|
+
);
|
|
308
|
+
const validateIDCode2 = useCallback(
|
|
309
|
+
(e: any) => {
|
|
310
|
+
const value = e.target.value;
|
|
311
|
+
// if (!value) {
|
|
312
|
+
// setStatus('');
|
|
313
|
+
// setInfo('')
|
|
314
|
+
// }
|
|
315
|
+
|
|
316
|
+
const idtype = form?.getFieldValue("certificateType");
|
|
317
|
+
|
|
318
|
+
// // 当“销售方自然人证件类型”填写“201:居民身份证”,“销售方纳税人识别号”必须与“销售方自然人证件号码”完全一致
|
|
319
|
+
if (idtype === "201") {
|
|
320
|
+
const certificateNumber = form?.getFieldValue("certificateNumber");
|
|
321
|
+
console.log(value, certificateNumber)
|
|
322
|
+
if (value !== certificateNumber) {
|
|
323
|
+
setStatus('error');
|
|
324
|
+
setInfo('证件号码应与销方税号保持一致')
|
|
325
|
+
} else {
|
|
326
|
+
setStatus('');
|
|
327
|
+
setInfo('')
|
|
328
|
+
}
|
|
329
|
+
}
|
|
330
|
+
},
|
|
331
|
+
[form]
|
|
332
|
+
);
|
|
333
|
+
const validateNationality = useCallback(
|
|
334
|
+
(_: any, value: string) => {
|
|
335
|
+
if (!value) {
|
|
336
|
+
setNationStatue('error');
|
|
337
|
+
setNation('请选择正确的国籍');
|
|
338
|
+
return Promise.resolve();
|
|
339
|
+
}
|
|
340
|
+
const idtype = form?.getFieldValue("certificateType");
|
|
341
|
+
const idcode = form?.getFieldValue("certificateNumber");
|
|
342
|
+
console.log(value, idtype, idcode)
|
|
343
|
+
if (idtype === "201" || idtype === "227") {
|
|
344
|
+
// 当“自然人证件类型”选择“201:居民身份证”时,校验是否为“156:中国’
|
|
345
|
+
// 当“自然人证件类型”选择“227:中华人民共和国护照”时,校验是否为“156:中国
|
|
346
|
+
if (value !== "156") {
|
|
347
|
+
setNationStatue('error');
|
|
348
|
+
setNation('请选择正确的国籍');
|
|
349
|
+
return Promise.reject("请选择正确的国籍");
|
|
350
|
+
}
|
|
351
|
+
} else if (idtype === "213" || idtype === "238") {
|
|
352
|
+
// 当“自然人证件类型”选择“213:台湾居民来往大陆通行证”时,校验是否为”158:中国台湾”
|
|
353
|
+
// 当“自然人证件类型”选择“238:中华人民共和国台湾居民居住证”时,校验是否为“ 158:中国台湾”
|
|
354
|
+
if (value !== "158") {
|
|
355
|
+
setNationStatue('error');
|
|
356
|
+
setNation('请选择正确的国籍');
|
|
357
|
+
return Promise.reject("请选择正确的国籍");
|
|
358
|
+
}
|
|
359
|
+
} else if (idtype === "210") {
|
|
360
|
+
//当“自然人证件类型”选择“210:港澳居民来往内地通行证”时,如果“证件号码”以H开国籍(或地区)”必须为“344:中国香港”;如果“证件号码”以M开头,"国籍(或地区头,)”必须为“446:中国澳门”;
|
|
361
|
+
let r = false;
|
|
362
|
+
if (idcode) {
|
|
363
|
+
if (idcode.startsWith("M") && value === "446") {
|
|
364
|
+
r = true;
|
|
365
|
+
} else if (idcode.startsWith("H") && value === "344") {
|
|
366
|
+
r = true;
|
|
367
|
+
}
|
|
368
|
+
} else if (value === "344" || value === "446") {
|
|
369
|
+
r = true;
|
|
370
|
+
}
|
|
371
|
+
if (!r) {
|
|
372
|
+
setNationStatue('error');
|
|
373
|
+
setNation('请选择正确的国籍');
|
|
374
|
+
return Promise.reject("请选择正确的国籍");
|
|
375
|
+
}
|
|
376
|
+
} else if (idtype === "237") {
|
|
377
|
+
//当“自然人证件类型”选择“237:中华人民共和国港澳居民居住证”时,校验证件号码必须以810000或820000开头,如果“证件号码”以810000开头,必须为“344:中国香国籍(或地区))港”;如果“证件号码”以820000开头,国籍(或地区)必须为“446:中国澳门”
|
|
378
|
+
let r = false;
|
|
379
|
+
if (idcode) {
|
|
380
|
+
if (idcode.startsWith("820000") && value === "446") {
|
|
381
|
+
r = true;
|
|
382
|
+
} else if (idcode.startsWith("810000") && value === "344") {
|
|
383
|
+
r = true;
|
|
384
|
+
}
|
|
385
|
+
} else if (value === "344" || value === "446") {
|
|
386
|
+
r = true;
|
|
387
|
+
}
|
|
388
|
+
if (!r) {
|
|
389
|
+
setNationStatue('error');
|
|
390
|
+
setNation('请选择正确的国籍');
|
|
391
|
+
return Promise.reject("请选择正确的国籍");
|
|
392
|
+
}
|
|
393
|
+
}
|
|
394
|
+
setNationStatue('');
|
|
395
|
+
setNation('');
|
|
396
|
+
return Promise.resolve();
|
|
397
|
+
},
|
|
398
|
+
[form]
|
|
399
|
+
);
|
|
400
|
+
return (
|
|
401
|
+
<>
|
|
402
|
+
<div className={classNames("kts-invoice-operate-invoice-digtal-stakeholder", { readOnly: readOnly })} >
|
|
403
|
+
<div>
|
|
404
|
+
{'销售方信息'.split('').map(e => <span>{e}</span>)}
|
|
405
|
+
{
|
|
406
|
+
!readOnly &&
|
|
407
|
+
<Icon
|
|
408
|
+
className="digtal-stakeholder-expand-button"
|
|
409
|
+
component={isExpand ? ArrowUpSvg : ArrowDownSvg}
|
|
410
|
+
onClick={onExpand}
|
|
411
|
+
/>
|
|
412
|
+
}
|
|
413
|
+
</div>
|
|
414
|
+
<div>
|
|
415
|
+
<div style={{ marginTop: 20 }} className='natural-person-flag' >
|
|
416
|
+
{
|
|
417
|
+
props.isNaturalPerson === true &&
|
|
418
|
+
<Form.Item colon={false}>
|
|
419
|
+
{getFieldDecorator('naturalPersonFlag', {
|
|
420
|
+
})(
|
|
421
|
+
<NaturalPersonFlag readOnly={isReadOnly('naturalPersonFlag')} />
|
|
422
|
+
)}
|
|
423
|
+
</Form.Item>
|
|
424
|
+
}
|
|
425
|
+
</div>
|
|
426
|
+
<Form className="digtal-stakeholder-form" >
|
|
427
|
+
<Row gutter={[16, 0]}>
|
|
428
|
+
<Col span={24} >
|
|
429
|
+
<Form.Item label='名称' colon={false}>
|
|
430
|
+
{getFieldDecorator('supplierName', {
|
|
431
|
+
rules: getRules('supplierName', RULES.companyName('销售方名称')),
|
|
432
|
+
// getValueFromEvent: formatCompanyName
|
|
433
|
+
})
|
|
434
|
+
// (<MyInput readOnly={isReadOnly('supplierName')} placeholder="请输入名称" autoComplete="off" />)
|
|
435
|
+
(
|
|
436
|
+
<BuyerNameInput
|
|
437
|
+
myform={form}
|
|
438
|
+
fieldName='supplierName'
|
|
439
|
+
readOnly={isReadOnly('supplierName')}
|
|
440
|
+
placeholder="请输入名称"
|
|
441
|
+
autoComplete="off"
|
|
442
|
+
suffix={
|
|
443
|
+
isShowImportButton === true &&
|
|
444
|
+
<Button
|
|
445
|
+
type='link'
|
|
446
|
+
style={{ padding: 0, width: 20, height: '100%' }}
|
|
447
|
+
icon={<Icon component={PlusSvg} />}
|
|
448
|
+
onClick={() => { onClickImportButton && onClickImportButton(controller) }}
|
|
449
|
+
/>
|
|
450
|
+
}
|
|
451
|
+
/>
|
|
452
|
+
)
|
|
453
|
+
}
|
|
454
|
+
</Form.Item>
|
|
455
|
+
</Col>
|
|
456
|
+
|
|
457
|
+
<Col span={24} >
|
|
458
|
+
<Form.Item label='统一社会信用代码/纳税人识别号' colon={false}>
|
|
459
|
+
{getFieldDecorator('supplierTaxId', {
|
|
460
|
+
rules: getRules('supplierTaxId', [{ required: true, message: '销售方纳税人识别号必填' }, ...RULES.taxId('销售方纳税人识别号')])
|
|
461
|
+
})
|
|
462
|
+
// (<MyInput readOnly={isReadOnly('supplierTaxId')} placeholder="请输入统一社会信用代码/纳税人识别号" autoComplete="off" />)
|
|
463
|
+
(<BuyerNameInput
|
|
464
|
+
onChange={validateIDCode2}
|
|
465
|
+
myform={form}
|
|
466
|
+
fieldName='supplierTaxId'
|
|
467
|
+
readOnly={isReadOnly('supplierTaxId')}
|
|
468
|
+
placeholder="请输入统一社会信用代码/纳税人识别号"
|
|
469
|
+
autoComplete="off"
|
|
470
|
+
/>)
|
|
471
|
+
}
|
|
472
|
+
</Form.Item>
|
|
473
|
+
</Col>
|
|
474
|
+
|
|
475
|
+
<Col span={10 + leqispanW} style={{ display: isExpand ? undefined : 'none' }} >
|
|
476
|
+
<Form.Item label='销售方地址' colon={false}>
|
|
477
|
+
{getFieldDecorator('sellerAddress', {
|
|
478
|
+
rules: getRules('sellerAddress', [{ max: 300, message: '销售方地址内容超长' }])
|
|
479
|
+
})(<MyInput readOnly={isReadOnly('sellerAddress')} placeholder="请输入销售方地址" autoComplete="off" />)}
|
|
480
|
+
</Form.Item>
|
|
481
|
+
</Col>
|
|
482
|
+
|
|
483
|
+
<Col span={10 + leqispanW} style={{ display: isExpand ? undefined : 'none' }} >
|
|
484
|
+
<Form.Item label='电话' colon={false} className='telephone' >
|
|
485
|
+
{getFieldDecorator('sellerPhone', {
|
|
486
|
+
rules: getRules('sellerPhone', RULES.sellerTelPhone('销售方电话'))
|
|
487
|
+
})(<MyInput readOnly={isReadOnly('sellerPhone')} placeholder="请输入电话" autoComplete="off" />)}
|
|
488
|
+
</Form.Item>
|
|
489
|
+
</Col>
|
|
490
|
+
|
|
491
|
+
<Col span={10 + leqispanW} style={{ display: isExpand ? undefined : 'none' }} >
|
|
492
|
+
<Form.Item label='销售方开户银行' colon={false}>
|
|
493
|
+
{getFieldDecorator('sellerBank', {
|
|
494
|
+
rules: getRules('sellerBank', RULES.bankName('销售方开户银行'))
|
|
495
|
+
})(<MyInput readOnly={isReadOnly('sellerBank')} placeholder="请输入销售方开户银行" autoComplete="off" />)}
|
|
496
|
+
</Form.Item>
|
|
497
|
+
</Col>
|
|
498
|
+
{(props.leqi) &&
|
|
499
|
+
<Col span={4} style={{ display: isExpand ? undefined : 'none' }}>
|
|
500
|
+
<Form.Item colon={false}>
|
|
501
|
+
{getFieldDecorator('sellerAddressPhoneFlag', {
|
|
502
|
+
valuePropName: 'checked',
|
|
503
|
+
})(<Checkbox onChange={props?.invoiceMarkCallback} disabled={isReadOnly('sellerAddressPhoneFlag')} style={{ whiteSpace: 'nowrap' }}>是否展示</Checkbox>)}
|
|
504
|
+
</Form.Item>
|
|
505
|
+
</Col>
|
|
506
|
+
}
|
|
507
|
+
<Col span={10 + leqispanW} style={{ display: isExpand ? undefined : 'none' }} >
|
|
508
|
+
<Form.Item label='银行账号' colon={false}>
|
|
509
|
+
{getFieldDecorator('sellerAccount', {
|
|
510
|
+
rules: getRules('sellerAccount', RULES.bankAccount('销售方银行账号'))
|
|
511
|
+
})(<MyInput readOnly={isReadOnly('sellerAccount')} placeholder="请输入银行账号" autoComplete="off" />)}
|
|
512
|
+
</Form.Item>
|
|
513
|
+
</Col>
|
|
514
|
+
{(props.leqi || props.riskData?.code === 'success') &&
|
|
515
|
+
<Col span={4} style={{ display: isExpand ? undefined : 'none' }}>
|
|
516
|
+
<Form.Item colon={false}>
|
|
517
|
+
{getFieldDecorator('sellerBankAccountFlag', {
|
|
518
|
+
valuePropName: 'checked',
|
|
519
|
+
})(<Checkbox onChange={props?.invoiceMarkCallback} disabled={isReadOnly('sellerBankAccountFlag')} style={{ whiteSpace: 'nowrap' }}>是否展示</Checkbox>)}
|
|
520
|
+
</Form.Item>
|
|
521
|
+
</Col>
|
|
522
|
+
}
|
|
523
|
+
</Row>
|
|
524
|
+
</Form>
|
|
525
|
+
</div>
|
|
526
|
+
<div>
|
|
527
|
+
{'购买方信息'.split('').map(e => <span>{e}</span>)}
|
|
528
|
+
{
|
|
529
|
+
!readOnly &&
|
|
530
|
+
<Icon
|
|
531
|
+
className="digtal-stakeholder-expand-button"
|
|
532
|
+
component={isExpand ? ArrowUpSvg : ArrowDownSvg}
|
|
533
|
+
onClick={onExpand}
|
|
534
|
+
/>
|
|
535
|
+
}
|
|
536
|
+
</div>
|
|
537
|
+
<div>
|
|
538
|
+
{
|
|
539
|
+
!readOnly && props.lineCredit &&
|
|
540
|
+
<div style={{ marginTop: 20 }} >
|
|
541
|
+
<Tooltip trigger="click" title={props.lineCredit} >
|
|
542
|
+
<Button type="link" style={{ padding: `0px 8px` }} >查看当前可用授信额度</Button>
|
|
543
|
+
</Tooltip>
|
|
544
|
+
</div>
|
|
545
|
+
}
|
|
546
|
+
|
|
547
|
+
<Form className="digtal-stakeholder-form" >
|
|
548
|
+
<Row gutter={[16, 0]}>
|
|
549
|
+
<Col span={24} >
|
|
550
|
+
<Form.Item label='名称' colon={false}>
|
|
551
|
+
{getFieldDecorator('buyerName', {
|
|
552
|
+
rules: getRules('buyerName', RULES.companyName('购买方名称')),
|
|
553
|
+
})(
|
|
554
|
+
<BuyerNameInput
|
|
555
|
+
myform={form}
|
|
556
|
+
fieldName='buyerName'
|
|
557
|
+
readOnly={isReadOnly('buyerName')}
|
|
558
|
+
placeholder="请输入名称"
|
|
559
|
+
autoComplete="off"
|
|
560
|
+
suffix={
|
|
561
|
+
isShowImportButton === true &&
|
|
562
|
+
<Button
|
|
563
|
+
type='link'
|
|
564
|
+
style={{ padding: 0, width: 20, height: '100%' }}
|
|
565
|
+
icon={<Icon component={PlusSvg} />}
|
|
566
|
+
onClick={() => { onClickImportButton && onClickImportButton(controller) }}
|
|
567
|
+
/>
|
|
568
|
+
}
|
|
569
|
+
/>
|
|
570
|
+
)}
|
|
571
|
+
</Form.Item>
|
|
572
|
+
</Col>
|
|
573
|
+
|
|
574
|
+
<Col span={24} >
|
|
575
|
+
<Form.Item label='统一社会信用代码/纳税人识别号' colon={false}>
|
|
576
|
+
{getFieldDecorator('buyerTaxId', {
|
|
577
|
+
rules: getRules('buyerTaxId', [{ required: !isVatNormal, message: '购买方纳税人识别号必填' }, ...RULES.taxId('购买方纳税人识别号')])
|
|
578
|
+
})(
|
|
579
|
+
<BuyerNameInput
|
|
580
|
+
myform={form}
|
|
581
|
+
fieldName='buyerTaxId'
|
|
582
|
+
readOnly={isReadOnly('buyerTaxId')}
|
|
583
|
+
placeholder="请输入统一社会信用代码/纳税人识别号"
|
|
584
|
+
autoComplete="off"
|
|
585
|
+
/>
|
|
586
|
+
)}
|
|
587
|
+
</Form.Item>
|
|
588
|
+
</Col>
|
|
589
|
+
|
|
590
|
+
<Col span={10 + leqispanW} style={{ display: isExpand ? undefined : 'none' }} >
|
|
591
|
+
<Form.Item label='购买方地址' colon={false}>
|
|
592
|
+
{getFieldDecorator('buyerAddress', {
|
|
593
|
+
rules: getRules('buyerAddress', [{ max: 100, message: '购买方地址内容超长' }])
|
|
594
|
+
})(<MyInput readOnly={isReadOnly('buyerAddress')} placeholder="请输入购买方地址" autoComplete="off" />)}
|
|
595
|
+
</Form.Item>
|
|
596
|
+
</Col>
|
|
597
|
+
|
|
598
|
+
<Col span={10 + leqispanW} style={{ display: isExpand ? undefined : 'none' }} >
|
|
599
|
+
<Form.Item label='电话' colon={false} className='telephone'>
|
|
600
|
+
{getFieldDecorator('buyerPhone', {
|
|
601
|
+
rules: getRules('buyerPhone', RULES.buyerTelPhone('购买方电话'))
|
|
602
|
+
})(<MyInput readOnly={isReadOnly('buyerPhone')} placeholder="请输入电话" autoComplete="off" />)}
|
|
603
|
+
</Form.Item>
|
|
604
|
+
</Col>
|
|
605
|
+
<Col span={10 + leqispanW} style={{ display: isExpand ? undefined : 'none' }} >
|
|
606
|
+
<Form.Item label='购买方开户银行' colon={false}>
|
|
607
|
+
{getFieldDecorator('buyerBank', {
|
|
608
|
+
rules: getRules('buyerBank', RULES.bankName('购买方开户银行'))
|
|
609
|
+
})(<MyInput readOnly={isReadOnly('buyerBank')} placeholder="请输入购买方开户银行" autoComplete="off" />)}
|
|
610
|
+
</Form.Item>
|
|
611
|
+
</Col>
|
|
612
|
+
<Col span={10 + leqispanW} style={{ display: isExpand ? undefined : 'none' }} >
|
|
613
|
+
<Form.Item label='购买方开户银行' colon={false}>
|
|
614
|
+
{getFieldDecorator('buyerBank', {
|
|
615
|
+
rules: getRules('buyerBank', RULES.bankName('购买方开户银行'))
|
|
616
|
+
})(<MyInput readOnly={isReadOnly('buyerBank')} placeholder="请输入购买方开户银行" autoComplete="off" />)}
|
|
617
|
+
</Form.Item>
|
|
618
|
+
</Col>
|
|
619
|
+
|
|
620
|
+
<Col span={10 + leqispanW} style={{ display: isExpand ? undefined : 'none' }} >
|
|
621
|
+
<Form.Item label='银行账号' colon={false}>
|
|
622
|
+
{getFieldDecorator('buyerAccount', {
|
|
623
|
+
rules: getRules('buyerAccount', RULES.bankAccount('购买方银行账号'))
|
|
624
|
+
})(<MyInput readOnly={isReadOnly('buyerAccount')} placeholder="请输入银行账号" autoComplete="off" />)}
|
|
625
|
+
</Form.Item>
|
|
626
|
+
</Col>
|
|
627
|
+
{(props.leqi || props.riskData?.code === 'success') &&
|
|
628
|
+
<Col span={4} style={{ display: isExpand ? undefined : 'none' }}>
|
|
629
|
+
<Form.Item colon={false}>
|
|
630
|
+
{getFieldDecorator('buyerBankAccountFlag', {
|
|
631
|
+
valuePropName: 'checked',
|
|
632
|
+
})(<Checkbox onChange={props?.invoiceMarkCallback} disabled={isReadOnly('buyerBankAccountFlag')} style={{ whiteSpace: 'nowrap' }}>是否展示</Checkbox>)}
|
|
633
|
+
</Form.Item>
|
|
634
|
+
</Col>
|
|
635
|
+
}
|
|
636
|
+
</Row>
|
|
637
|
+
</Form>
|
|
638
|
+
</div>
|
|
639
|
+
|
|
640
|
+
</div>
|
|
641
|
+
|
|
642
|
+
{
|
|
643
|
+
isShowNaturalPersonInfo &&
|
|
644
|
+
<div className='kts-invoice-operate-invoice-digtal-payinfo'>
|
|
645
|
+
<Form className="digtal-stakeholder-form" style={{ width: '100%' }}>
|
|
646
|
+
<Row gutter={[16, 0]}>
|
|
647
|
+
<Col span={5} >
|
|
648
|
+
<Form.Item label='自然人销售方补充信息' colon={false} >
|
|
649
|
+
|
|
650
|
+
</Form.Item>
|
|
651
|
+
</Col>
|
|
652
|
+
{/* <label>自然人销售方补充信息</label> */}
|
|
653
|
+
<Col span={6} >
|
|
654
|
+
<Form.Item label='证件类型' colon={false} >
|
|
655
|
+
{getFieldDecorator('certificateType', {
|
|
656
|
+
rules: [{ required: true, message: '数据必填' }]
|
|
657
|
+
})(<CardSelect onChange={onChangeType} readOnly={isReadOnly('certificateType')} placeholder="数据必填" autoComplete="off" />)}
|
|
658
|
+
</Form.Item>
|
|
659
|
+
</Col>
|
|
660
|
+
<Col span={7} >
|
|
661
|
+
<Form.Item label='证件号码' colon={false} validateStatus={validateStatus} help={errorInfo}>
|
|
662
|
+
{getFieldDecorator('certificateNumber', {
|
|
663
|
+
rules: [{ required: true, message: '数据必填' }, { max: 30, message: `内容超长` }, { validator: validateIDCode },]
|
|
664
|
+
})(<MyInput readOnly={isReadOnly('certificateNumber')} placeholder="数据必填" autoComplete="off" />)}
|
|
665
|
+
</Form.Item>
|
|
666
|
+
</Col>
|
|
667
|
+
<Col span={6} >
|
|
668
|
+
<Form.Item label='国籍(或地区)' colon={false} validateStatus={nation} help={nationInfo}>
|
|
669
|
+
{getFieldDecorator('nationality', {
|
|
670
|
+
rules: [{ required: true, message: '数据必填' }, { validator: validateNationality }]
|
|
671
|
+
})(<NationalSelect showSearch={true}
|
|
672
|
+
optionFilterProp="children"
|
|
673
|
+
filterOption={(input: any, option: any) => {
|
|
674
|
+
if (option) {
|
|
675
|
+
return option.label?.indexOf(input) >= 0;
|
|
676
|
+
}
|
|
677
|
+
return false;
|
|
678
|
+
}} readOnly={isReadOnly('nationality')} placeholder="数据必填" autoComplete="off" />)}
|
|
679
|
+
</Form.Item>
|
|
680
|
+
</Col>
|
|
681
|
+
</Row>
|
|
682
|
+
</Form>
|
|
683
|
+
</div>
|
|
684
|
+
}
|
|
685
|
+
</>
|
|
686
|
+
)
|
|
687
|
+
})
|
|
688
|
+
|
|
689
|
+
function NaturalPersonFlag(props: {
|
|
690
|
+
// NATURAL("自然人"), COMPANY("非自然人");
|
|
691
|
+
value?: 'COMPANY' | 'NATURAL',
|
|
692
|
+
onChange?: (e: 'COMPANY' | 'NATURAL') => void
|
|
693
|
+
readOnly?: boolean;
|
|
694
|
+
}) {
|
|
695
|
+
|
|
696
|
+
const [value, setValue] = React.useState(props.value || 'COMPANY');
|
|
697
|
+
|
|
698
|
+
const onChange = React.useCallback((e: CheckboxChangeEvent) => {
|
|
699
|
+
if (props.readOnly) return;
|
|
700
|
+
setValue(e.target.checked ? 'NATURAL' : 'COMPANY');
|
|
701
|
+
props.onChange && props.onChange(e.target.checked ? 'NATURAL' : 'COMPANY');
|
|
702
|
+
}, [props.onChange, props.readOnly])
|
|
703
|
+
|
|
704
|
+
React.useEffect(() => {
|
|
705
|
+
setValue(props.value || 'COMPANY')
|
|
706
|
+
}, [props.value])
|
|
707
|
+
|
|
708
|
+
return (
|
|
709
|
+
<Checkbox
|
|
710
|
+
disabled={props.readOnly}
|
|
711
|
+
checked={value === 'NATURAL'}
|
|
712
|
+
onChange={onChange}
|
|
713
|
+
>
|
|
714
|
+
是否开票给自然人
|
|
715
|
+
</Checkbox>
|
|
716
|
+
)
|
|
717
|
+
}
|
|
718
|
+
|
|
719
|
+
function BuyerNameInput(props: InputProps & { fieldName: string; myform: WrappedFormUtils<any> }) {
|
|
720
|
+
|
|
721
|
+
const { fieldName, myform: form } = props;
|
|
722
|
+
|
|
723
|
+
const controller = Invoice.useInvoiceController();
|
|
724
|
+
|
|
725
|
+
const rootElement = controller.useMemo(s => s.rootElement, []);
|
|
726
|
+
|
|
727
|
+
const autoComplete = controller.useMemo(s => s.autoComplete, [])
|
|
728
|
+
|
|
729
|
+
const [options, setOptions] = React.useState<any[]>([])
|
|
730
|
+
|
|
731
|
+
const onChangeAutoComplete = React.useCallback(value => {
|
|
732
|
+
const record = options.filter(e => e[fieldName] === value)[0] as any;
|
|
733
|
+
if (!record || !form) return;
|
|
734
|
+
|
|
735
|
+
form.setFieldsValue(record);
|
|
736
|
+
setOptions([])
|
|
737
|
+
}, [options, fieldName, form])
|
|
738
|
+
|
|
739
|
+
const onSearch = React.useCallback(async (searchText: string) => {
|
|
740
|
+
await Discontinue.start();
|
|
741
|
+
try {
|
|
742
|
+
if (fieldName === 'buyerName') {
|
|
743
|
+
if (autoComplete.onBuyerNameSearch) {
|
|
744
|
+
setOptions(await autoComplete.onBuyerNameSearch(searchText));
|
|
745
|
+
}
|
|
746
|
+
} else if (fieldName === 'buyerTaxId') {
|
|
747
|
+
if (autoComplete.onBuyerTaxIdSearch) {
|
|
748
|
+
setOptions(await autoComplete.onBuyerTaxIdSearch(searchText));
|
|
749
|
+
}
|
|
750
|
+
} else if (fieldName === 'supplierName') {
|
|
751
|
+
if (autoComplete.onSupplierNameSearch) {
|
|
752
|
+
setOptions(await autoComplete.onSupplierNameSearch(searchText));
|
|
753
|
+
}
|
|
754
|
+
} else if (fieldName === 'supplierTaxId') {
|
|
755
|
+
if (autoComplete.onSupplierTaxIdSearch) {
|
|
756
|
+
setOptions(await autoComplete.onSupplierTaxIdSearch(searchText));
|
|
757
|
+
}
|
|
758
|
+
}
|
|
759
|
+
|
|
760
|
+
} catch (error) {
|
|
761
|
+
setOptions([]);
|
|
762
|
+
throw error;
|
|
763
|
+
}
|
|
764
|
+
}, [autoComplete.onBuyerNameSearch, fieldName])
|
|
765
|
+
|
|
766
|
+
if (props.readOnly) return <span className='digtal-stakeholder-form-text'>{props.value}</span>;
|
|
767
|
+
|
|
768
|
+
return (
|
|
769
|
+
<AutoComplete
|
|
770
|
+
onSearch={onSearch}
|
|
771
|
+
options={options.map(e => ({ value: e[fieldName] }))}
|
|
772
|
+
onChange={onChangeAutoComplete}
|
|
773
|
+
value={props.value}
|
|
774
|
+
getPopupContainer={() => rootElement || document.body}
|
|
775
|
+
style={{ width: '100%' }}
|
|
776
|
+
>
|
|
777
|
+
<Input {...props} style={{ width: '100%', ...props.style }} />
|
|
778
|
+
</AutoComplete>
|
|
779
|
+
)
|
|
780
|
+
}
|
|
781
|
+
|
|
782
|
+
class MyInput extends React.Component<InputProps> {
|
|
783
|
+
render() {
|
|
784
|
+
const props = this.props;
|
|
785
|
+
if (props.readOnly) {
|
|
786
|
+
return <span className='digtal-stakeholder-form-text'>{props.value}</span>
|
|
787
|
+
} else {
|
|
788
|
+
return <Input {...props} />
|
|
789
|
+
}
|
|
790
|
+
}
|
|
791
|
+
}
|
|
792
|
+
class CardSelect extends React.Component<any> {
|
|
793
|
+
|
|
794
|
+
render() {
|
|
795
|
+
const props = this.props;
|
|
796
|
+
const option = [
|
|
797
|
+
|
|
798
|
+
{ label: "居民身份证", value: "201" },
|
|
799
|
+
{ label: "外国护照", value: "208" },
|
|
800
|
+
{ label: "港澳居民来往内地通行证", value: "210" },
|
|
801
|
+
|
|
802
|
+
{ label: "台湾居民来往大陆通行证", value: "213" },
|
|
803
|
+
|
|
804
|
+
{ label: "中国护照", value: "227" },
|
|
805
|
+
|
|
806
|
+
{ label: "外国人永久居留身份证", value: "233" },
|
|
807
|
+
|
|
808
|
+
{ label: "中华人民共和国港澳居民居住证", value: "237" },
|
|
809
|
+
{ label: "中华人民共和国台湾居民居住证", value: "238" },
|
|
810
|
+
|
|
811
|
+
];
|
|
812
|
+
function getLable(value?: string) {
|
|
813
|
+
|
|
814
|
+
return option.find(e => e.value === value)?.label || '';
|
|
815
|
+
|
|
816
|
+
}
|
|
817
|
+
if (props.readOnly) {
|
|
818
|
+
return <span className='digtal-stakeholder-form-text'>{getLable(props.value)}</span>
|
|
819
|
+
} else {
|
|
820
|
+
return <Select style={{ width: 200 }} options={option} {...props} />
|
|
821
|
+
}
|
|
822
|
+
}
|
|
823
|
+
}
|
|
824
|
+
class NationalSelect extends React.Component<any> {
|
|
825
|
+
|
|
826
|
+
render() {
|
|
827
|
+
const props = this.props;
|
|
828
|
+
const option = [
|
|
829
|
+
{ value: "156", label: "中国" },
|
|
830
|
+
{ value: "344", label: "中国香港" },
|
|
831
|
+
{ value: "158", label: "中国台湾" },
|
|
832
|
+
{ value: "446", label: "中国澳门" },
|
|
833
|
+
|
|
834
|
+
{ value: "004", label: "阿富汗" },
|
|
835
|
+
{ value: "008", label: "阿尔巴尼亚" },
|
|
836
|
+
{ value: "010", label: "南极洲" },
|
|
837
|
+
{ value: "012", label: "阿尔及利亚" },
|
|
838
|
+
{ value: "016", label: "美属萨摩亚" },
|
|
839
|
+
{ value: "020", label: "安道尔" },
|
|
840
|
+
{ value: "024", label: "安哥拉" },
|
|
841
|
+
{ value: "028", label: "安提瓜和巴布达" },
|
|
842
|
+
{ value: "031", label: "阿塞拜疆" },
|
|
843
|
+
{ value: "032", label: "阿根廷" },
|
|
844
|
+
{ value: "036", label: "澳大利亚" },
|
|
845
|
+
{ value: "040", label: "奥地利" },
|
|
846
|
+
{ value: "044", label: "巴哈马" },
|
|
847
|
+
{ value: "048", label: "巴林" },
|
|
848
|
+
{ value: "050", label: "孟加拉国" },
|
|
849
|
+
{ value: "051", label: "亚美尼亚" },
|
|
850
|
+
{ value: "052", label: "巴巴多斯" },
|
|
851
|
+
{ value: "056", label: "比利时" },
|
|
852
|
+
{ value: "060", label: "百慕大" },
|
|
853
|
+
{ value: "064", label: "不丹" },
|
|
854
|
+
{ value: "068", label: "玻利维亚" },
|
|
855
|
+
{ value: "070", label: "波黑" },
|
|
856
|
+
{ value: "072", label: "博茨瓦纳" },
|
|
857
|
+
{ value: "074", label: "布维岛" },
|
|
858
|
+
{ value: "076", label: "巴西" },
|
|
859
|
+
{ value: "084", label: "伯利兹" },
|
|
860
|
+
{ value: "086", label: "英属印度洋领地" },
|
|
861
|
+
{ value: "090", label: "所罗门群岛" },
|
|
862
|
+
{ value: "092", label: "英属维尔京群岛" },
|
|
863
|
+
{ value: "096", label: "文莱" },
|
|
864
|
+
{ value: "100", label: "保加利亚" },
|
|
865
|
+
{ value: "104", label: "缅甸" },
|
|
866
|
+
{ value: "108", label: "布隆迪" },
|
|
867
|
+
{ value: "112", label: "白俄罗斯" },
|
|
868
|
+
{ value: "116", label: "柬埔寨" },
|
|
869
|
+
{ value: "120", label: "喀麦隆" },
|
|
870
|
+
{ value: "124", label: "加拿大" },
|
|
871
|
+
{ value: "132", label: "佛得角" },
|
|
872
|
+
{ value: "136", label: "开曼群岛" },
|
|
873
|
+
{ value: "140", label: "中非" },
|
|
874
|
+
{ value: "144", label: "斯里兰卡" },
|
|
875
|
+
{ value: "148", label: "乍得" },
|
|
876
|
+
{ value: "152", label: "智利" },
|
|
877
|
+
|
|
878
|
+
{ value: "162", label: "圣诞岛" },
|
|
879
|
+
{ value: "166", label: "科科斯(基林)群岛" },
|
|
880
|
+
{ value: "170", label: "哥伦比亚" },
|
|
881
|
+
{ value: "174", label: "科摩罗" },
|
|
882
|
+
{ value: "175", label: "马约特" },
|
|
883
|
+
{ value: "178", label: "刚果(布)" },
|
|
884
|
+
{ value: "180", label: "刚果(金)" },
|
|
885
|
+
{ value: "184", label: "库克群岛" },
|
|
886
|
+
{ value: "188", label: "哥斯达黎加" },
|
|
887
|
+
{ value: "191", label: "克罗地亚" },
|
|
888
|
+
{ value: "192", label: "古巴" },
|
|
889
|
+
{ value: "196", label: "塞浦路斯" },
|
|
890
|
+
{ value: "203", label: "捷克" },
|
|
891
|
+
{ value: "204", label: "贝宁" },
|
|
892
|
+
{ value: "208", label: "丹麦" },
|
|
893
|
+
{ value: "212", label: "多米尼克" },
|
|
894
|
+
{ value: "214", label: "多米尼加" },
|
|
895
|
+
{ value: "218", label: "厄瓜多尔" },
|
|
896
|
+
{ value: "222", label: "萨尔瓦多" },
|
|
897
|
+
{ value: "226", label: "赤道几内亚" },
|
|
898
|
+
{ value: "231", label: "埃塞俄比亚" },
|
|
899
|
+
{ value: "232", label: "厄立特里亚" },
|
|
900
|
+
{ value: "233", label: "爱沙尼亚" },
|
|
901
|
+
{ value: "234", label: "法罗群岛" },
|
|
902
|
+
{ value: "238", label: "福克兰群岛" },
|
|
903
|
+
{ value: "239", label: "南乔治亚岛和南桑德韦奇岛" },
|
|
904
|
+
{ value: "242", label: "斐济" },
|
|
905
|
+
{ value: "246", label: "芬兰" },
|
|
906
|
+
{ value: "250", label: "法国" },
|
|
907
|
+
{ value: "254", label: "法属圭亚那" },
|
|
908
|
+
{ value: "258", label: "法属波利尼西亚" },
|
|
909
|
+
{ value: "260", label: "法属南部领地" },
|
|
910
|
+
{ value: "262", label: "吉布提" },
|
|
911
|
+
{ value: "266", label: "加蓬" },
|
|
912
|
+
{ value: "268", label: "格鲁吉亚" },
|
|
913
|
+
{ value: "270", label: "冈比亚" },
|
|
914
|
+
{ value: "275", label: "巴勒斯坦" },
|
|
915
|
+
{ value: "276", label: "德国" },
|
|
916
|
+
{ value: "288", label: "加纳" },
|
|
917
|
+
{ value: "292", label: "直布罗陀" },
|
|
918
|
+
{ value: "296", label: "基里巴斯" },
|
|
919
|
+
{ value: "300", label: "希腊" },
|
|
920
|
+
{ value: "304", label: "格陵兰" },
|
|
921
|
+
{ value: "308", label: "格林纳达" },
|
|
922
|
+
{ value: "312", label: "瓜德罗普" },
|
|
923
|
+
{ value: "316", label: "关岛" },
|
|
924
|
+
{ value: "320", label: "危地马拉" },
|
|
925
|
+
{ value: "324", label: "几内亚" },
|
|
926
|
+
{ value: "328", label: "圭亚那" },
|
|
927
|
+
{ value: "332", label: "海地" },
|
|
928
|
+
{ value: "334", label: "赫德岛和麦克唐纳岛" },
|
|
929
|
+
{ value: "336", label: "梵蒂冈" },
|
|
930
|
+
{ value: "340", label: "洪都拉斯" },
|
|
931
|
+
|
|
932
|
+
{ value: "348", label: "匈牙利" },
|
|
933
|
+
{ value: "352", label: "冰岛" },
|
|
934
|
+
{ value: "356", label: "印度" },
|
|
935
|
+
{ value: "360", label: "印度尼西亚" },
|
|
936
|
+
{ value: "364", label: "伊朗" },
|
|
937
|
+
{ value: "368", label: "伊拉克" },
|
|
938
|
+
{ value: "372", label: "爱尔兰" },
|
|
939
|
+
{ value: "376", label: "以色列" },
|
|
940
|
+
{ value: "380", label: "意大利" },
|
|
941
|
+
{ value: "384", label: "科特迪瓦" },
|
|
942
|
+
{ value: "388", label: "牙买加" },
|
|
943
|
+
{ value: "392", label: "日本" },
|
|
944
|
+
{ value: "398", label: "哈萨克斯坦" },
|
|
945
|
+
{ value: "400", label: "约旦" },
|
|
946
|
+
{ value: "404", label: "肯尼亚" },
|
|
947
|
+
{ value: "408", label: "朝鲜" },
|
|
948
|
+
{ value: "410", label: "韩国" },
|
|
949
|
+
{ value: "414", label: "科威特" },
|
|
950
|
+
{ value: "417", label: "吉尔吉斯斯坦" },
|
|
951
|
+
{ value: "418", label: "老挝" },
|
|
952
|
+
{ value: "422", label: "黎巴嫩" },
|
|
953
|
+
{ value: "426", label: "莱索托" },
|
|
954
|
+
{ value: "428", label: "拉脱维亚" },
|
|
955
|
+
{ value: "430", label: "利比里亚" },
|
|
956
|
+
{ value: "434", label: "利比亚" },
|
|
957
|
+
{ value: "438", label: "列支敦士登" },
|
|
958
|
+
{ value: "440", label: "立陶宛" },
|
|
959
|
+
{ value: "442", label: "卢森堡" },
|
|
960
|
+
|
|
961
|
+
{ value: "450", label: "马达加斯加" },
|
|
962
|
+
{ value: "454", label: "马拉维" },
|
|
963
|
+
{ value: "458", label: "马来西亚" },
|
|
964
|
+
{ value: "462", label: "马尔代夫" },
|
|
965
|
+
{ value: "466", label: "马里" },
|
|
966
|
+
{ value: "470", label: "马耳他" },
|
|
967
|
+
{ value: "474", label: "马提尼克" },
|
|
968
|
+
{ value: "478", label: "毛里塔尼亚" },
|
|
969
|
+
{ value: "480", label: "毛里求斯" },
|
|
970
|
+
{ value: "484", label: "墨西哥" },
|
|
971
|
+
{ value: "492", label: "摩纳哥" },
|
|
972
|
+
{ value: "496", label: "蒙古" },
|
|
973
|
+
{ value: "498", label: "摩尔多瓦" },
|
|
974
|
+
{ value: "499", label: "黑山" },
|
|
975
|
+
{ value: "500", label: "蒙特塞拉特" },
|
|
976
|
+
{ value: "504", label: "摩洛哥" },
|
|
977
|
+
{ value: "508", label: "莫桑比克" },
|
|
978
|
+
{ value: "512", label: "阿曼" },
|
|
979
|
+
{ value: "516", label: "纳米比亚" },
|
|
980
|
+
{ value: "520", label: "瑙鲁" },
|
|
981
|
+
{ value: "524", label: "尼泊尔" },
|
|
982
|
+
{ value: "528", label: "荷兰" },
|
|
983
|
+
{ value: "530", label: "荷属安的列斯" },
|
|
984
|
+
{ value: "533", label: "阿鲁巴" },
|
|
985
|
+
{ value: "540", label: "新喀里多尼亚" },
|
|
986
|
+
{ value: "548", label: "瓦努阿图" },
|
|
987
|
+
{ value: "554", label: "新西兰" },
|
|
988
|
+
{ value: "558", label: "尼加拉瓜" },
|
|
989
|
+
{ value: "562", label: "尼日尔" },
|
|
990
|
+
{ value: "566", label: "尼日利亚" },
|
|
991
|
+
{ value: "570", label: "纽埃" },
|
|
992
|
+
{ value: "574", label: "诺福克岛" },
|
|
993
|
+
{ value: "578", label: "挪威" },
|
|
994
|
+
{ value: "580", label: "北马里亚纳" },
|
|
995
|
+
{ value: "581", label: "美国本土外小岛屿" },
|
|
996
|
+
{ value: "583", label: "密克罗尼西亚联邦" },
|
|
997
|
+
{ value: "584", label: "马绍尔群岛" },
|
|
998
|
+
{ value: "585", label: "帕劳" },
|
|
999
|
+
{ value: "586", label: "巴基斯坦" },
|
|
1000
|
+
{ value: "591", label: "巴拿马" },
|
|
1001
|
+
{ value: "598", label: "巴布亚新几内亚" },
|
|
1002
|
+
{ value: "600", label: "巴拉圭" },
|
|
1003
|
+
{ value: "604", label: "秘鲁" },
|
|
1004
|
+
{ value: "608", label: "菲律宾" },
|
|
1005
|
+
{ value: "612", label: "皮特凯恩" },
|
|
1006
|
+
{ value: "616", label: "波兰" },
|
|
1007
|
+
{ value: "620", label: "葡萄牙" },
|
|
1008
|
+
{ value: "624", label: "几内亚比绍" },
|
|
1009
|
+
{ value: "626", label: "东帝汶" },
|
|
1010
|
+
{ value: "630", label: "波多黎各" },
|
|
1011
|
+
{ value: "634", label: "卡塔尔" },
|
|
1012
|
+
{ value: "638", label: "留尼汪" },
|
|
1013
|
+
{ value: "642", label: "罗马尼亚" },
|
|
1014
|
+
{ value: "643", label: "俄罗斯联邦" },
|
|
1015
|
+
{ value: "646", label: "卢旺达" },
|
|
1016
|
+
{ value: "654", label: "圣赫勒拿" },
|
|
1017
|
+
{ value: "659", label: "圣基茨和尼维斯" },
|
|
1018
|
+
{ value: "660", label: "安圭拉" },
|
|
1019
|
+
{ value: "662", label: "圣卢西亚" },
|
|
1020
|
+
{ value: "666", label: "圣皮埃尔和密克隆" },
|
|
1021
|
+
{ value: "670", label: "圣文森特和格林纳丁斯" },
|
|
1022
|
+
{ value: "674", label: "圣马力诺" },
|
|
1023
|
+
{ value: "678", label: "圣多美和普林西比" },
|
|
1024
|
+
{ value: "682", label: "沙特阿拉伯" },
|
|
1025
|
+
{ value: "686", label: "塞内加尔" },
|
|
1026
|
+
{ value: "688", label: "塞尔维亚" },
|
|
1027
|
+
{ value: "690", label: "塞舌尔" },
|
|
1028
|
+
{ value: "694", label: "塞拉利昂" },
|
|
1029
|
+
{ value: "702", label: "新加坡" },
|
|
1030
|
+
{ value: "703", label: "斯洛伐克" },
|
|
1031
|
+
{ value: "704", label: "越南" },
|
|
1032
|
+
{ value: "705", label: "斯洛文尼亚" },
|
|
1033
|
+
{ value: "706", label: "索马里" },
|
|
1034
|
+
{ value: "710", label: "南非" },
|
|
1035
|
+
{ value: "716", label: "津巴布韦" },
|
|
1036
|
+
{ value: "724", label: "西班牙" },
|
|
1037
|
+
{ value: "728", label: "南苏丹" },
|
|
1038
|
+
{ value: "732", label: "西撒哈拉" },
|
|
1039
|
+
{ value: "736", label: "苏丹" },
|
|
1040
|
+
{ value: "740", label: "苏里南" },
|
|
1041
|
+
{ value: "744", label: "斯瓦尔巴岛和扬马延岛" },
|
|
1042
|
+
{ value: "748", label: "斯威士兰" },
|
|
1043
|
+
{ value: "752", label: "瑞典" },
|
|
1044
|
+
{ value: "756", label: "瑞士" },
|
|
1045
|
+
{ value: "760", label: "叙利亚" },
|
|
1046
|
+
{ value: "762", label: "塔吉克斯坦" },
|
|
1047
|
+
{ value: "764", label: "泰国" },
|
|
1048
|
+
{ value: "768", label: "多哥" },
|
|
1049
|
+
{ value: "772", label: "托克劳" },
|
|
1050
|
+
{ value: "776", label: "汤加" },
|
|
1051
|
+
{ value: "780", label: "特立尼达和多巴哥" },
|
|
1052
|
+
{ value: "784", label: "阿联酋" },
|
|
1053
|
+
{ value: "788", label: "突尼斯" },
|
|
1054
|
+
{ value: "792", label: "土耳其" },
|
|
1055
|
+
{ value: "795", label: "土库曼斯坦" },
|
|
1056
|
+
{ value: "796", label: "特克斯和凯科斯群岛" },
|
|
1057
|
+
{ value: "798", label: "图瓦卢" },
|
|
1058
|
+
{ value: "800", label: "乌干达" },
|
|
1059
|
+
{ value: "804", label: "乌克兰" },
|
|
1060
|
+
{ value: "807", label: "前南马其顿" },
|
|
1061
|
+
{ value: "818", label: "埃及" },
|
|
1062
|
+
{ value: "826", label: "英国" },
|
|
1063
|
+
{ value: "831", label: "根西岛" },
|
|
1064
|
+
{ value: "832", label: "泽西岛" },
|
|
1065
|
+
{ value: "833", label: "马恩岛" },
|
|
1066
|
+
{ value: "834", label: "坦桑尼亚" },
|
|
1067
|
+
{ value: "840", label: "美国" },
|
|
1068
|
+
{ value: "850", label: "美属维尔京群岛" },
|
|
1069
|
+
{ value: "854", label: "布基纳法索" },
|
|
1070
|
+
{ value: "858", label: "乌拉圭" },
|
|
1071
|
+
{ value: "860", label: "乌兹别克斯坦" },
|
|
1072
|
+
{ value: "862", label: "委内瑞拉" },
|
|
1073
|
+
{ value: "876", label: "瓦利斯和富图纳" },
|
|
1074
|
+
{ value: "882", label: "萨摩亚" },
|
|
1075
|
+
{ value: "887", label: "也门" },
|
|
1076
|
+
{ value: "891", label: "南斯拉夫" },
|
|
1077
|
+
{ value: "894", label: "赞比亚" },
|
|
1078
|
+
{ value: "A00", label: "科索沃" }
|
|
1079
|
+
];
|
|
1080
|
+
|
|
1081
|
+
function getLable(value?: string) {
|
|
1082
|
+
|
|
1083
|
+
return option.find(e => e.value === value)?.label || '';
|
|
1084
|
+
|
|
1085
|
+
}
|
|
1086
|
+
if (props.readOnly) {
|
|
1087
|
+
return <span className='digtal-stakeholder-form-text'>{getLable(props.value)}</span>
|
|
1088
|
+
} else {
|
|
1089
|
+
return <Select style={{ width: 100 }} options={option} {...props} />
|
|
1090
|
+
}
|
|
1091
|
+
}
|
|
1092
|
+
}
|
|
1093
|
+
class Discontinue {
|
|
1094
|
+
|
|
1095
|
+
private static timer: any;
|
|
1096
|
+
|
|
1097
|
+
static start = (interval = 200) => new Promise<void>(resolve => {
|
|
1098
|
+
clearTimeout(Discontinue.timer);
|
|
1099
|
+
Discontinue.timer = setTimeout(resolve, interval);
|
|
1100
|
+
})
|
|
1101
|
+
}
|
|
1102
|
+
|