kts-component-invoice-operate 3.2.164 → 3.2.166
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.dumi/theme/builtins/API.tsx +66 -66
- package/.editorconfig +16 -16
- package/.fatherrc.ts +4 -4
- package/.prettierignore +7 -7
- package/.prettierrc +11 -11
- package/.umirc.ts +8 -8
- package/README.md +9 -9
- package/dist/Invoice/InvoiceController/InvoiceControllerState/GoodsListState/EndowCode/index.d.ts +4 -4
- package/dist/TaxClassificationCodeModal/index.d.ts +4 -0
- package/dist/index.esm.js +798 -699
- package/dist/index.js +797 -698
- 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 +61 -61
- package/src/Invoice/Invoice-digtal/_test/disabled/index.tsx +40 -40
- package/src/Invoice/Invoice-digtal/_test/easiest/index.tsx +17 -17
- 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 +34 -34
- package/src/Invoice/InvoiceController/InvoiceControllerForm/index.ts +95 -95
- 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/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 +65 -65
- 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/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/saveEditGood.ts +24 -24
- package/src/Invoice/InvoiceController/fns/setEditGood.ts +16 -16
- package/src/Invoice/InvoiceController/fns/setGoods.ts +10 -10
- package/src/Invoice/InvoiceController/fns/updateInvoiceNo.ts +8 -8
- package/src/Invoice/InvoiceController/index.ts +87 -87
- 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 +183 -183
- 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 +8 -8
- 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 +592 -586
- 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/GoodsList/hook/useColumns/autoFillFn/index.ts +639 -639
- package/src/Invoice/ui/digtal/GoodsList/hook/useColumns/index.tsx +660 -660
- 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 +180 -180
- 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 +53 -53
- 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 +436 -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 +396 -396
- 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 -177
- package/src/TaxClassificationCodeModal/index.less +5 -0
- package/src/TaxClassificationCodeModal/index.md +6 -6
- package/src/TaxClassificationCodeModal/index.tsx +141 -74
- package/src/index.ts +12 -12
- package/tsconfig.json +31 -31
- package/typings.d.ts +3 -3
- package/yarn.e.lock +0 -14331
package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useAddDiscount/index.tsx
CHANGED
|
@@ -1,119 +1,119 @@
|
|
|
1
|
-
|
|
2
|
-
import React from 'react';
|
|
3
|
-
import { Typography } from 'kts-components-antd-x3';
|
|
4
|
-
import { message } from 'kts-xui';
|
|
5
|
-
import InvoiceController, { IGood, LineAttributeType } from '../../../../../../../../../InvoiceController';
|
|
6
|
-
import Invoice from '../../../../../../../../..';
|
|
7
|
-
|
|
8
|
-
const { Text } = Typography;
|
|
9
|
-
|
|
10
|
-
export default (goods: IGood) => {
|
|
11
|
-
|
|
12
|
-
const controller = Invoice.useInvoiceController();
|
|
13
|
-
|
|
14
|
-
const model = controller.useMemo(s => s.model, [])
|
|
15
|
-
|
|
16
|
-
/** 是否能添加折扣行 */
|
|
17
|
-
const isAddDiscount = controller.useMemo(s => s.goodsListState.isAddDiscount, [])
|
|
18
|
-
|
|
19
|
-
/** 点击了 添加折扣行 按钮 */
|
|
20
|
-
const onClick = React.useCallback(async e => {
|
|
21
|
-
try {
|
|
22
|
-
e.stopPropagation()
|
|
23
|
-
await controller.wait();
|
|
24
|
-
await controller.saveEditGood();
|
|
25
|
-
await checkDiscount(controller);
|
|
26
|
-
await checkFieldsError(controller, goods);
|
|
27
|
-
await checkDutyFree(controller, goods);
|
|
28
|
-
await checkZeroAmount(controller, goods);
|
|
29
|
-
await controller.run(async s => {
|
|
30
|
-
s.goodsListState.discountGoodIndex = [goods.$index];
|
|
31
|
-
})
|
|
32
|
-
} catch (error: any) {
|
|
33
|
-
console.error(error);
|
|
34
|
-
}
|
|
35
|
-
}, [controller, goods.$index]);
|
|
36
|
-
|
|
37
|
-
if (goods.lineAttribute !== LineAttributeType.正常) {
|
|
38
|
-
return undefined
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
if (!(model !== 'prefab')) {
|
|
42
|
-
return undefined;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
if (!(isAddDiscount !== false)) {
|
|
46
|
-
return undefined
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
if (goods.lineAttribute !== LineAttributeType.正常) {
|
|
50
|
-
return undefined
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
return {
|
|
54
|
-
key: 'addDiscount',
|
|
55
|
-
title: '折扣',
|
|
56
|
-
onClick,
|
|
57
|
-
}
|
|
58
|
-
};
|
|
59
|
-
|
|
60
|
-
/**
|
|
61
|
-
* 有折让行,不可以添加折扣
|
|
62
|
-
* @param controller 组件控制器
|
|
63
|
-
*/
|
|
64
|
-
async function checkDiscount(controller: InvoiceController) {
|
|
65
|
-
const { goodsList } = controller.state.goodsListState;
|
|
66
|
-
goodsList.forEach(e => {
|
|
67
|
-
if (e.lineAttribute === LineAttributeType.折让行) {
|
|
68
|
-
const content = '有折让行,不可以添加折扣';
|
|
69
|
-
message.error({ content, key: content });
|
|
70
|
-
throw new Error(content)
|
|
71
|
-
}
|
|
72
|
-
})
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
/**
|
|
76
|
-
* 零税率需要设置免税类型,请在赋码中设置!
|
|
77
|
-
* @param controller 组件控制器
|
|
78
|
-
* @param goods 当前行数据
|
|
79
|
-
*/
|
|
80
|
-
async function checkDutyFree(controller: InvoiceController, goods: IGood) {
|
|
81
|
-
goods = controller.state.goodsListState.goodsList.filter(e => e.$index === goods.$index)[0];
|
|
82
|
-
if (goods.taxRate === 0 && controller.state.goodsListState.endowCode.isTaxFreeTypeNeeded && !goods.taxFreeType) {
|
|
83
|
-
const content = '零税率需要设置免税类型,请在赋码中设置!'
|
|
84
|
-
message.error({ content, key: content });
|
|
85
|
-
throw new Error(content)
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
/**
|
|
90
|
-
* 金额为0不能添加折扣行
|
|
91
|
-
* @param controller 组件控制器
|
|
92
|
-
* @param goods 当前行数据
|
|
93
|
-
**/
|
|
94
|
-
async function checkZeroAmount(controller: InvoiceController, goods: IGood) {
|
|
95
|
-
goods = controller.state.goodsListState.goodsList.filter(e => e.$index === goods.$index)[0];
|
|
96
|
-
if (`${goods.lineAmountIncludeTax}` === '0') {
|
|
97
|
-
const content = '金额为0不能添加折扣行'
|
|
98
|
-
message.error({ content, key: content });
|
|
99
|
-
throw new Error(content)
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
/**
|
|
104
|
-
* 校验当前的表单
|
|
105
|
-
* @param controller 组件控制器
|
|
106
|
-
* @param goods 当前行数据
|
|
107
|
-
* */
|
|
108
|
-
async function checkFieldsError(controller: InvoiceController, goods: IGood) {
|
|
109
|
-
const s = controller.state;
|
|
110
|
-
if (s.goodsListState.form && s.goodsListState.editGood?.$index === goods?.$index) {
|
|
111
|
-
const err: any = s.goodsListState.form.getFieldsError();
|
|
112
|
-
for (let key in err) {
|
|
113
|
-
if (!err[key]) continue;
|
|
114
|
-
const content = err[key][0];
|
|
115
|
-
message.error({ content, key: content });
|
|
116
|
-
throw new Error(content)
|
|
117
|
-
}
|
|
118
|
-
}
|
|
1
|
+
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { Typography } from 'kts-components-antd-x3';
|
|
4
|
+
import { message } from 'kts-xui';
|
|
5
|
+
import InvoiceController, { IGood, LineAttributeType } from '../../../../../../../../../InvoiceController';
|
|
6
|
+
import Invoice from '../../../../../../../../..';
|
|
7
|
+
|
|
8
|
+
const { Text } = Typography;
|
|
9
|
+
|
|
10
|
+
export default (goods: IGood) => {
|
|
11
|
+
|
|
12
|
+
const controller = Invoice.useInvoiceController();
|
|
13
|
+
|
|
14
|
+
const model = controller.useMemo(s => s.model, [])
|
|
15
|
+
|
|
16
|
+
/** 是否能添加折扣行 */
|
|
17
|
+
const isAddDiscount = controller.useMemo(s => s.goodsListState.isAddDiscount, [])
|
|
18
|
+
|
|
19
|
+
/** 点击了 添加折扣行 按钮 */
|
|
20
|
+
const onClick = React.useCallback(async e => {
|
|
21
|
+
try {
|
|
22
|
+
e.stopPropagation()
|
|
23
|
+
await controller.wait();
|
|
24
|
+
await controller.saveEditGood();
|
|
25
|
+
await checkDiscount(controller);
|
|
26
|
+
await checkFieldsError(controller, goods);
|
|
27
|
+
await checkDutyFree(controller, goods);
|
|
28
|
+
await checkZeroAmount(controller, goods);
|
|
29
|
+
await controller.run(async s => {
|
|
30
|
+
s.goodsListState.discountGoodIndex = [goods.$index];
|
|
31
|
+
})
|
|
32
|
+
} catch (error: any) {
|
|
33
|
+
console.error(error);
|
|
34
|
+
}
|
|
35
|
+
}, [controller, goods.$index]);
|
|
36
|
+
|
|
37
|
+
if (goods.lineAttribute !== LineAttributeType.正常) {
|
|
38
|
+
return undefined
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
if (!(model !== 'prefab')) {
|
|
42
|
+
return undefined;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
if (!(isAddDiscount !== false)) {
|
|
46
|
+
return undefined
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
if (goods.lineAttribute !== LineAttributeType.正常) {
|
|
50
|
+
return undefined
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
return {
|
|
54
|
+
key: 'addDiscount',
|
|
55
|
+
title: '折扣',
|
|
56
|
+
onClick,
|
|
57
|
+
}
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
/**
|
|
61
|
+
* 有折让行,不可以添加折扣
|
|
62
|
+
* @param controller 组件控制器
|
|
63
|
+
*/
|
|
64
|
+
async function checkDiscount(controller: InvoiceController) {
|
|
65
|
+
const { goodsList } = controller.state.goodsListState;
|
|
66
|
+
goodsList.forEach(e => {
|
|
67
|
+
if (e.lineAttribute === LineAttributeType.折让行) {
|
|
68
|
+
const content = '有折让行,不可以添加折扣';
|
|
69
|
+
message.error({ content, key: content });
|
|
70
|
+
throw new Error(content)
|
|
71
|
+
}
|
|
72
|
+
})
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
/**
|
|
76
|
+
* 零税率需要设置免税类型,请在赋码中设置!
|
|
77
|
+
* @param controller 组件控制器
|
|
78
|
+
* @param goods 当前行数据
|
|
79
|
+
*/
|
|
80
|
+
async function checkDutyFree(controller: InvoiceController, goods: IGood) {
|
|
81
|
+
goods = controller.state.goodsListState.goodsList.filter(e => e.$index === goods.$index)[0];
|
|
82
|
+
if (goods.taxRate === 0 && controller.state.goodsListState.endowCode.isTaxFreeTypeNeeded && !goods.taxFreeType) {
|
|
83
|
+
const content = '零税率需要设置免税类型,请在赋码中设置!'
|
|
84
|
+
message.error({ content, key: content });
|
|
85
|
+
throw new Error(content)
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
/**
|
|
90
|
+
* 金额为0不能添加折扣行
|
|
91
|
+
* @param controller 组件控制器
|
|
92
|
+
* @param goods 当前行数据
|
|
93
|
+
**/
|
|
94
|
+
async function checkZeroAmount(controller: InvoiceController, goods: IGood) {
|
|
95
|
+
goods = controller.state.goodsListState.goodsList.filter(e => e.$index === goods.$index)[0];
|
|
96
|
+
if (`${goods.lineAmountIncludeTax}` === '0') {
|
|
97
|
+
const content = '金额为0不能添加折扣行'
|
|
98
|
+
message.error({ content, key: content });
|
|
99
|
+
throw new Error(content)
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
/**
|
|
104
|
+
* 校验当前的表单
|
|
105
|
+
* @param controller 组件控制器
|
|
106
|
+
* @param goods 当前行数据
|
|
107
|
+
* */
|
|
108
|
+
async function checkFieldsError(controller: InvoiceController, goods: IGood) {
|
|
109
|
+
const s = controller.state;
|
|
110
|
+
if (s.goodsListState.form && s.goodsListState.editGood?.$index === goods?.$index) {
|
|
111
|
+
const err: any = s.goodsListState.form.getFieldsError();
|
|
112
|
+
for (let key in err) {
|
|
113
|
+
if (!err[key]) continue;
|
|
114
|
+
const content = err[key][0];
|
|
115
|
+
message.error({ content, key: content });
|
|
116
|
+
throw new Error(content)
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
119
|
}
|
package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useDelItem/index.tsx
CHANGED
|
@@ -1,41 +1,41 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
// import { Menu, Typography } from 'kts-components-antd-x3';
|
|
3
|
-
import { IGood, LineAttributeType } from '../../../../../../../../../InvoiceController';
|
|
4
|
-
import Invoice from '../../../../../../../../..';
|
|
5
|
-
|
|
6
|
-
// const { Text } = Typography;
|
|
7
|
-
|
|
8
|
-
export default (goods: IGood) => {
|
|
9
|
-
|
|
10
|
-
const controller = Invoice.useInvoiceController();
|
|
11
|
-
|
|
12
|
-
const model = controller.useMemo(s => s.model, [])
|
|
13
|
-
|
|
14
|
-
const isRemRow = controller.useMemo(s => s.goodsListState.isRemRow, [])
|
|
15
|
-
|
|
16
|
-
const onClick = React.useCallback(() => {
|
|
17
|
-
controller.delGood(goods.$index);
|
|
18
|
-
}, [controller, goods.$index]);
|
|
19
|
-
|
|
20
|
-
if (goods.lineAttribute === LineAttributeType.被折扣行) {
|
|
21
|
-
return undefined;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
if(isRemRow === false) {
|
|
25
|
-
return undefined;
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
if (!(model !== 'prefab')) {
|
|
29
|
-
return undefined;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
return {
|
|
33
|
-
key:'delItem',
|
|
34
|
-
title:'删除',
|
|
35
|
-
onClick,
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
// return React.useMemo(() => {
|
|
39
|
-
// return <Menu.Item key="delItem" onClick={onClick}><Text strong type="danger">删除</Text></Menu.Item>
|
|
40
|
-
// }, [onClick])
|
|
41
|
-
};
|
|
1
|
+
import React from 'react';
|
|
2
|
+
// import { Menu, Typography } from 'kts-components-antd-x3';
|
|
3
|
+
import { IGood, LineAttributeType } from '../../../../../../../../../InvoiceController';
|
|
4
|
+
import Invoice from '../../../../../../../../..';
|
|
5
|
+
|
|
6
|
+
// const { Text } = Typography;
|
|
7
|
+
|
|
8
|
+
export default (goods: IGood) => {
|
|
9
|
+
|
|
10
|
+
const controller = Invoice.useInvoiceController();
|
|
11
|
+
|
|
12
|
+
const model = controller.useMemo(s => s.model, [])
|
|
13
|
+
|
|
14
|
+
const isRemRow = controller.useMemo(s => s.goodsListState.isRemRow, [])
|
|
15
|
+
|
|
16
|
+
const onClick = React.useCallback(() => {
|
|
17
|
+
controller.delGood(goods.$index);
|
|
18
|
+
}, [controller, goods.$index]);
|
|
19
|
+
|
|
20
|
+
if (goods.lineAttribute === LineAttributeType.被折扣行) {
|
|
21
|
+
return undefined;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
if(isRemRow === false) {
|
|
25
|
+
return undefined;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
if (!(model !== 'prefab')) {
|
|
29
|
+
return undefined;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
return {
|
|
33
|
+
key:'delItem',
|
|
34
|
+
title:'删除',
|
|
35
|
+
onClick,
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
// return React.useMemo(() => {
|
|
39
|
+
// return <Menu.Item key="delItem" onClick={onClick}><Text strong type="danger">删除</Text></Menu.Item>
|
|
40
|
+
// }, [onClick])
|
|
41
|
+
};
|
package/src/Invoice/ui/default/GoodsList/hook/useColumns/ui/RowMenu/hook/useEndowCode/index.tsx
CHANGED
|
@@ -1,25 +1,25 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
import Invoice from '../../../../../../../../..';
|
|
3
|
-
import { endowCode } from '../../../../autoFillFn';
|
|
4
|
-
import { IGood, LineAttributeType } from '../../../../../../../../../InvoiceController';
|
|
5
|
-
|
|
6
|
-
// const { Text } = Typography;
|
|
7
|
-
|
|
8
|
-
export default (goods: IGood) => {
|
|
9
|
-
|
|
10
|
-
const controller = Invoice.useInvoiceController();
|
|
11
|
-
|
|
12
|
-
const onClick = React.useCallback(async () => {
|
|
13
|
-
endowCode(controller, goods);
|
|
14
|
-
}, [controller, goods]);
|
|
15
|
-
|
|
16
|
-
if ([LineAttributeType.正常, LineAttributeType.被折扣行, LineAttributeType.折扣行].indexOf(goods.lineAttribute) >= 0) {
|
|
17
|
-
return {
|
|
18
|
-
key: 'endowCode',
|
|
19
|
-
title: '赋码',
|
|
20
|
-
onClick,
|
|
21
|
-
}
|
|
22
|
-
} else {
|
|
23
|
-
return undefined
|
|
24
|
-
}
|
|
25
|
-
};
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import Invoice from '../../../../../../../../..';
|
|
3
|
+
import { endowCode } from '../../../../autoFillFn';
|
|
4
|
+
import { IGood, LineAttributeType } from '../../../../../../../../../InvoiceController';
|
|
5
|
+
|
|
6
|
+
// const { Text } = Typography;
|
|
7
|
+
|
|
8
|
+
export default (goods: IGood) => {
|
|
9
|
+
|
|
10
|
+
const controller = Invoice.useInvoiceController();
|
|
11
|
+
|
|
12
|
+
const onClick = React.useCallback(async () => {
|
|
13
|
+
endowCode(controller, goods);
|
|
14
|
+
}, [controller, goods]);
|
|
15
|
+
|
|
16
|
+
if ([LineAttributeType.正常, LineAttributeType.被折扣行, LineAttributeType.折扣行].indexOf(goods.lineAttribute) >= 0) {
|
|
17
|
+
return {
|
|
18
|
+
key: 'endowCode',
|
|
19
|
+
title: '赋码',
|
|
20
|
+
onClick,
|
|
21
|
+
}
|
|
22
|
+
} else {
|
|
23
|
+
return undefined
|
|
24
|
+
}
|
|
25
|
+
};
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
.ktsAnt3x-btn.kts-invoice-operate-goods-list-columns-row-menu:focus,
|
|
2
|
-
.ktsAnt3x-btn.kts-invoice-operate-goods-list-columns-row-menu:hover,
|
|
3
|
-
.ktsAnt3x-btn.kts-invoice-operate-goods-list-columns-row-menu {
|
|
4
|
-
font-size: 16px;
|
|
5
|
-
color: #000;
|
|
6
|
-
text-align: center;
|
|
7
|
-
padding: 0;
|
|
8
|
-
}
|
|
9
|
-
.ktsAnt3x-btn.kts-invoice-operate-goods-list-columns-row-menu:hover,
|
|
10
|
-
.ktsAnt3x-btn.kts-invoice-operate-goods-list-columns-row-menu.ktsAnt3x-dropdown-open{
|
|
11
|
-
background: #ebebeb;
|
|
12
|
-
border-radius: 9999px;
|
|
13
|
-
}
|
|
1
|
+
.ktsAnt3x-btn.kts-invoice-operate-goods-list-columns-row-menu:focus,
|
|
2
|
+
.ktsAnt3x-btn.kts-invoice-operate-goods-list-columns-row-menu:hover,
|
|
3
|
+
.ktsAnt3x-btn.kts-invoice-operate-goods-list-columns-row-menu {
|
|
4
|
+
font-size: 16px;
|
|
5
|
+
color: #000;
|
|
6
|
+
text-align: center;
|
|
7
|
+
padding: 0;
|
|
8
|
+
}
|
|
9
|
+
.ktsAnt3x-btn.kts-invoice-operate-goods-list-columns-row-menu:hover,
|
|
10
|
+
.ktsAnt3x-btn.kts-invoice-operate-goods-list-columns-row-menu.ktsAnt3x-dropdown-open{
|
|
11
|
+
background: #ebebeb;
|
|
12
|
+
border-radius: 9999px;
|
|
13
|
+
}
|
|
@@ -1,99 +1,99 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
import { Button, Menu, Dropdown, Icon, Typography } from 'kts-components-antd-x3';
|
|
3
|
-
import Invoice from '../../../../../../..';
|
|
4
|
-
import { IGood } from '../../../../../../../InvoiceController';
|
|
5
|
-
import { ReactComponent as SpotSvg } from './spot.svg';
|
|
6
|
-
|
|
7
|
-
import useDelItem from './hook/useDelItem';
|
|
8
|
-
import useAddDiscount from './hook/useAddDiscount';
|
|
9
|
-
import useEndowCode from './hook/useEndowCode';
|
|
10
|
-
// import useAddComparison from './hook/useAddComparison';
|
|
11
|
-
|
|
12
|
-
import './index.less';
|
|
13
|
-
|
|
14
|
-
const { Text } = Typography;
|
|
15
|
-
|
|
16
|
-
export default (props: { goods: IGood }) => {
|
|
17
|
-
|
|
18
|
-
const controller = Invoice.useInvoiceController();
|
|
19
|
-
|
|
20
|
-
const model = controller.useMemo(s => s.model, [])
|
|
21
|
-
|
|
22
|
-
/** 是否能添加折扣行 */
|
|
23
|
-
const isAddDiscount = controller.useMemo(s => s.goodsListState.isAddDiscount, [])
|
|
24
|
-
|
|
25
|
-
const goodsMenuExpand = controller.useMemo(s => s.goodsListState.goodsMenuExpand, []);
|
|
26
|
-
|
|
27
|
-
const delItem = useDelItem(props.goods);
|
|
28
|
-
const addDiscount = useAddDiscount(props.goods);
|
|
29
|
-
const endowCode = useEndowCode(props.goods);
|
|
30
|
-
// const addComparison = useAddComparison(props.goods);
|
|
31
|
-
|
|
32
|
-
const itemList = React.useMemo(() => {
|
|
33
|
-
const arr: any[] = [];
|
|
34
|
-
|
|
35
|
-
endowCode && arr.push(endowCode); // 赋码
|
|
36
|
-
addDiscount && arr.push(addDiscount); // 添加折扣行
|
|
37
|
-
delItem && arr.push(delItem); // 删除
|
|
38
|
-
|
|
39
|
-
// addComparison && arr.push(addComparison); // 添加商品对照
|
|
40
|
-
|
|
41
|
-
if (!goodsMenuExpand || goodsMenuExpand.length === 0) return arr;
|
|
42
|
-
|
|
43
|
-
arr.unshift(<Menu.Divider key="divider-1" />);
|
|
44
|
-
|
|
45
|
-
for (let i = goodsMenuExpand.length - 1; i >= 0; i--) {
|
|
46
|
-
const fn = goodsMenuExpand[i];
|
|
47
|
-
arr.unshift(fn(props.goods.$index, controller));
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
return arr;
|
|
51
|
-
}, [controller, endowCode, addDiscount, delItem, goodsMenuExpand, props.goods, model, isAddDiscount])
|
|
52
|
-
|
|
53
|
-
const overlay = React.useMemo(() => {
|
|
54
|
-
if (itemList.length <= 2) {
|
|
55
|
-
return undefined
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
return (
|
|
59
|
-
<Menu>
|
|
60
|
-
{itemList.slice(2).map(e => {
|
|
61
|
-
return <Menu.Item key={e.key} onClick={e.onClick} ><Text strong>{e.title}</Text></Menu.Item>
|
|
62
|
-
})}
|
|
63
|
-
</Menu>
|
|
64
|
-
)
|
|
65
|
-
}, [itemList])
|
|
66
|
-
|
|
67
|
-
const buttonList = React.useMemo(() => {
|
|
68
|
-
return (
|
|
69
|
-
<div style={{ flex: 1, textAlign: 'left', display: 'flex', gap: 10 }} >
|
|
70
|
-
{
|
|
71
|
-
itemList.slice(0, 2).map(e => {
|
|
72
|
-
return (
|
|
73
|
-
<Button key={e.key} type='link' onClick={e.onClick} style={{ padding: 0 }} >
|
|
74
|
-
{e.title}
|
|
75
|
-
</Button>
|
|
76
|
-
)
|
|
77
|
-
})
|
|
78
|
-
}
|
|
79
|
-
</div>
|
|
80
|
-
)
|
|
81
|
-
}, [itemList])
|
|
82
|
-
|
|
83
|
-
if (props.goods.level && props.goods.level > 0) { return <></> }
|
|
84
|
-
if (itemList.length === 0) { return (<></>) }
|
|
85
|
-
|
|
86
|
-
return (
|
|
87
|
-
<span style={{ padding: '0 0 0 10px', display: 'flex' }}>
|
|
88
|
-
{buttonList}
|
|
89
|
-
{
|
|
90
|
-
overlay &&
|
|
91
|
-
<Dropdown overlay={overlay} trigger={['click']}>
|
|
92
|
-
<Button className="kts-invoice-operate-goods-list-columns-row-menu ant-btn-icon-only" type="link">
|
|
93
|
-
<Icon component={SpotSvg} />
|
|
94
|
-
</Button>
|
|
95
|
-
</Dropdown>
|
|
96
|
-
}
|
|
97
|
-
</span>
|
|
98
|
-
);
|
|
99
|
-
};
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Button, Menu, Dropdown, Icon, Typography } from 'kts-components-antd-x3';
|
|
3
|
+
import Invoice from '../../../../../../..';
|
|
4
|
+
import { IGood } from '../../../../../../../InvoiceController';
|
|
5
|
+
import { ReactComponent as SpotSvg } from './spot.svg';
|
|
6
|
+
|
|
7
|
+
import useDelItem from './hook/useDelItem';
|
|
8
|
+
import useAddDiscount from './hook/useAddDiscount';
|
|
9
|
+
import useEndowCode from './hook/useEndowCode';
|
|
10
|
+
// import useAddComparison from './hook/useAddComparison';
|
|
11
|
+
|
|
12
|
+
import './index.less';
|
|
13
|
+
|
|
14
|
+
const { Text } = Typography;
|
|
15
|
+
|
|
16
|
+
export default (props: { goods: IGood }) => {
|
|
17
|
+
|
|
18
|
+
const controller = Invoice.useInvoiceController();
|
|
19
|
+
|
|
20
|
+
const model = controller.useMemo(s => s.model, [])
|
|
21
|
+
|
|
22
|
+
/** 是否能添加折扣行 */
|
|
23
|
+
const isAddDiscount = controller.useMemo(s => s.goodsListState.isAddDiscount, [])
|
|
24
|
+
|
|
25
|
+
const goodsMenuExpand = controller.useMemo(s => s.goodsListState.goodsMenuExpand, []);
|
|
26
|
+
|
|
27
|
+
const delItem = useDelItem(props.goods);
|
|
28
|
+
const addDiscount = useAddDiscount(props.goods);
|
|
29
|
+
const endowCode = useEndowCode(props.goods);
|
|
30
|
+
// const addComparison = useAddComparison(props.goods);
|
|
31
|
+
|
|
32
|
+
const itemList = React.useMemo(() => {
|
|
33
|
+
const arr: any[] = [];
|
|
34
|
+
|
|
35
|
+
endowCode && arr.push(endowCode); // 赋码
|
|
36
|
+
addDiscount && arr.push(addDiscount); // 添加折扣行
|
|
37
|
+
delItem && arr.push(delItem); // 删除
|
|
38
|
+
|
|
39
|
+
// addComparison && arr.push(addComparison); // 添加商品对照
|
|
40
|
+
|
|
41
|
+
if (!goodsMenuExpand || goodsMenuExpand.length === 0) return arr;
|
|
42
|
+
|
|
43
|
+
arr.unshift(<Menu.Divider key="divider-1" />);
|
|
44
|
+
|
|
45
|
+
for (let i = goodsMenuExpand.length - 1; i >= 0; i--) {
|
|
46
|
+
const fn = goodsMenuExpand[i];
|
|
47
|
+
arr.unshift(fn(props.goods.$index, controller));
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
return arr;
|
|
51
|
+
}, [controller, endowCode, addDiscount, delItem, goodsMenuExpand, props.goods, model, isAddDiscount])
|
|
52
|
+
|
|
53
|
+
const overlay = React.useMemo(() => {
|
|
54
|
+
if (itemList.length <= 2) {
|
|
55
|
+
return undefined
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
return (
|
|
59
|
+
<Menu>
|
|
60
|
+
{itemList.slice(2).map(e => {
|
|
61
|
+
return <Menu.Item key={e.key} onClick={e.onClick} ><Text strong>{e.title}</Text></Menu.Item>
|
|
62
|
+
})}
|
|
63
|
+
</Menu>
|
|
64
|
+
)
|
|
65
|
+
}, [itemList])
|
|
66
|
+
|
|
67
|
+
const buttonList = React.useMemo(() => {
|
|
68
|
+
return (
|
|
69
|
+
<div style={{ flex: 1, textAlign: 'left', display: 'flex', gap: 10 }} >
|
|
70
|
+
{
|
|
71
|
+
itemList.slice(0, 2).map(e => {
|
|
72
|
+
return (
|
|
73
|
+
<Button key={e.key} type='link' onClick={e.onClick} style={{ padding: 0 }} >
|
|
74
|
+
{e.title}
|
|
75
|
+
</Button>
|
|
76
|
+
)
|
|
77
|
+
})
|
|
78
|
+
}
|
|
79
|
+
</div>
|
|
80
|
+
)
|
|
81
|
+
}, [itemList])
|
|
82
|
+
|
|
83
|
+
if (props.goods.level && props.goods.level > 0) { return <></> }
|
|
84
|
+
if (itemList.length === 0) { return (<></>) }
|
|
85
|
+
|
|
86
|
+
return (
|
|
87
|
+
<span style={{ padding: '0 0 0 10px', display: 'flex' }}>
|
|
88
|
+
{buttonList}
|
|
89
|
+
{
|
|
90
|
+
overlay &&
|
|
91
|
+
<Dropdown overlay={overlay} trigger={['click']}>
|
|
92
|
+
<Button className="kts-invoice-operate-goods-list-columns-row-menu ant-btn-icon-only" type="link">
|
|
93
|
+
<Icon component={SpotSvg} />
|
|
94
|
+
</Button>
|
|
95
|
+
</Dropdown>
|
|
96
|
+
}
|
|
97
|
+
</span>
|
|
98
|
+
);
|
|
99
|
+
};
|
|
@@ -1,14 +1,14 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
import { Button } from 'kts-components-antd-x3';
|
|
3
|
-
import Invoice from '../../../../../../';
|
|
4
|
-
import { IGood } from '../../../../../../InvoiceController';
|
|
5
|
-
|
|
6
|
-
export default (props: { goods: IGood }) => {
|
|
7
|
-
const controller = Invoice.useInvoiceController();
|
|
8
|
-
|
|
9
|
-
const onClick = React.useCallback(() => {
|
|
10
|
-
controller.saveEditGood();
|
|
11
|
-
}, [controller]);
|
|
12
|
-
|
|
13
|
-
return <Button type="link" icon="save" onClick={onClick} />;
|
|
14
|
-
};
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Button } from 'kts-components-antd-x3';
|
|
3
|
+
import Invoice from '../../../../../../';
|
|
4
|
+
import { IGood } from '../../../../../../InvoiceController';
|
|
5
|
+
|
|
6
|
+
export default (props: { goods: IGood }) => {
|
|
7
|
+
const controller = Invoice.useInvoiceController();
|
|
8
|
+
|
|
9
|
+
const onClick = React.useCallback(() => {
|
|
10
|
+
controller.saveEditGood();
|
|
11
|
+
}, [controller]);
|
|
12
|
+
|
|
13
|
+
return <Button type="link" icon="save" onClick={onClick} />;
|
|
14
|
+
};
|