bananas-commerce-admin 0.20.3 → 0.21.0
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/dist/esm/components/Card/CardFieldAutoComplete.js +2 -2
- package/dist/esm/components/Card/CardFieldAutoComplete.js.map +1 -1
- package/dist/esm/components/Card/CardFieldSelect.js +6 -3
- package/dist/esm/components/Card/CardFieldSelect.js.map +1 -1
- package/dist/esm/components/Card/index.js +17 -1
- package/dist/esm/components/Card/index.js.map +1 -1
- package/dist/esm/components/ContribInlines.js +3 -2
- package/dist/esm/components/ContribInlines.js.map +1 -1
- package/dist/esm/extensions/catalog/components/ArticleCard.js +9 -4
- package/dist/esm/extensions/catalog/components/ArticleCard.js.map +1 -1
- package/dist/esm/extensions/catalog/contrib/ProductArticles.js +48 -0
- package/dist/esm/extensions/catalog/contrib/ProductArticles.js.map +1 -0
- package/dist/esm/extensions/catalog/index.js +9 -0
- package/dist/esm/extensions/catalog/index.js.map +1 -1
- package/dist/esm/extensions/pim/components/ProductCard.js +123 -0
- package/dist/esm/extensions/pim/components/ProductCard.js.map +1 -0
- package/dist/esm/extensions/pim/components/ProductPropertiesCard.js +71 -0
- package/dist/esm/extensions/pim/components/ProductPropertiesCard.js.map +1 -0
- package/dist/esm/extensions/pim/components/ProductPropertyField.js +25 -0
- package/dist/esm/extensions/pim/components/ProductPropertyField.js.map +1 -0
- package/dist/esm/extensions/pim/components/ProductRow.js +11 -0
- package/dist/esm/extensions/pim/components/ProductRow.js.map +1 -0
- package/dist/esm/extensions/pim/contrib/ArticleProduct.js +32 -20
- package/dist/esm/extensions/pim/contrib/ArticleProduct.js.map +1 -1
- package/dist/esm/extensions/pim/index.js +30 -0
- package/dist/esm/extensions/pim/index.js.map +1 -1
- package/dist/esm/extensions/pim/pages/product/create.js +41 -0
- package/dist/esm/extensions/pim/pages/product/create.js.map +1 -0
- package/dist/esm/extensions/pim/pages/product/detail.js +46 -0
- package/dist/esm/extensions/pim/pages/product/detail.js.map +1 -0
- package/dist/esm/extensions/pim/pages/product/list.js +54 -0
- package/dist/esm/extensions/pim/pages/product/list.js.map +1 -0
- package/dist/esm/extensions/pim/types/product.js +2 -0
- package/dist/esm/extensions/pim/types/product.js.map +1 -0
- package/dist/types/components/Card/CardFieldAutoComplete.d.ts +3 -0
- package/dist/types/components/Card/CardFieldSelect.d.ts +1 -0
- package/dist/types/components/ContribInlines.d.ts +1 -0
- package/dist/types/extensions/catalog/components/ArticleCard.d.ts +12 -0
- package/dist/types/extensions/catalog/contrib/ProductArticles.d.ts +4 -0
- package/dist/types/extensions/catalog/types/contrib.d.ts +8 -0
- package/dist/types/extensions/pim/components/ProductCard.d.ts +23 -0
- package/dist/types/extensions/pim/components/ProductPropertiesCard.d.ts +8 -0
- package/dist/types/extensions/pim/components/ProductPropertyField.d.ts +8 -0
- package/dist/types/extensions/pim/components/ProductRow.d.ts +6 -0
- package/dist/types/extensions/pim/index.d.ts +6 -1
- package/dist/types/extensions/pim/pages/product/create.d.ts +3 -0
- package/dist/types/extensions/pim/pages/product/detail.d.ts +4 -0
- package/dist/types/extensions/pim/pages/product/list.d.ts +4 -0
- package/dist/types/extensions/pim/types/product.d.ts +35 -0
- package/dist/types/types/index.d.ts +1 -1
- package/package.json +1 -1
- package/src/components/Card/CardFieldAutoComplete.tsx +14 -1
- package/src/components/Card/CardFieldSelect.tsx +6 -2
- package/src/components/Card/index.tsx +21 -1
- package/src/components/ContribInlines.tsx +5 -2
- package/src/extensions/catalog/components/ArticleCard.tsx +22 -4
- package/src/extensions/catalog/contrib/ProductArticles.tsx +82 -0
- package/src/extensions/catalog/index.tsx +9 -0
- package/src/extensions/catalog/types/contrib.ts +9 -0
- package/src/extensions/pim/components/ProductCard.tsx +242 -0
- package/src/extensions/pim/components/ProductPropertiesCard.tsx +114 -0
- package/src/extensions/pim/components/ProductPropertyField.tsx +67 -0
- package/src/extensions/pim/components/ProductRow.tsx +23 -0
- package/src/extensions/pim/contrib/ArticleProduct.tsx +54 -30
- package/src/extensions/pim/index.tsx +52 -1
- package/src/extensions/pim/pages/product/create.tsx +63 -0
- package/src/extensions/pim/pages/product/detail.tsx +85 -0
- package/src/extensions/pim/pages/product/list.tsx +87 -0
- package/src/extensions/pim/types/product.ts +52 -0
- package/src/types/index.ts +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import React from "react";
|
|
1
|
+
import React, { useEffect, useState } from "react";
|
|
2
2
|
import { TableBody, TableHead, TableRow } from "@mui/material";
|
|
3
3
|
import Box from "@mui/material/Box";
|
|
4
4
|
import ImageList from "@mui/material/ImageList";
|
|
@@ -7,45 +7,57 @@ import ImageListItemBar from "@mui/material/ImageListItemBar";
|
|
|
7
7
|
import Modal from "@mui/material/Modal";
|
|
8
8
|
import Card from "../../../components/Card";
|
|
9
9
|
import CardContent from "../../../components/Card/CardContent";
|
|
10
|
+
import CardFieldSelect from "../../../components/Card/CardFieldSelect";
|
|
10
11
|
import CardFieldText from "../../../components/Card/CardFieldText";
|
|
11
12
|
import CardHeader from "../../../components/Card/CardHeader";
|
|
12
13
|
import CardRow from "../../../components/Card/CardRow";
|
|
13
14
|
import Table from "../../../components/Table";
|
|
14
15
|
import { TableCell } from "../../../components/Table/TableCell";
|
|
15
16
|
import TableHeading from "../../../components/Table/TableHeading";
|
|
17
|
+
import { useApi } from "../../../contexts/ApiContext";
|
|
16
18
|
import { useI18n } from "../../../contexts/I18nContext";
|
|
17
|
-
import {
|
|
19
|
+
import { ProductPropertyField } from "../components/ProductPropertyField";
|
|
18
20
|
const ArticleProductCard = ({ data, params }) => {
|
|
19
21
|
const { t } = useI18n();
|
|
20
|
-
const
|
|
22
|
+
const api = useApi();
|
|
23
|
+
const [selectedAsset, setSelectedAsset] = useState(null);
|
|
24
|
+
const [productItemTypes, setProductItemTypes] = useState([]);
|
|
21
25
|
const { code: articleCode } = params;
|
|
22
26
|
const { product, assets } = data;
|
|
23
27
|
const articleAssets = assets.filter((asset) => asset.article_code == articleCode || asset.article_code == "");
|
|
24
28
|
const imageAssets = articleAssets.filter((asset) => asset.asset_type == "image");
|
|
25
29
|
const otherAssets = articleAssets.filter((asset) => asset.asset_type !== "image");
|
|
26
|
-
const productProperties =
|
|
27
|
-
|
|
30
|
+
const productProperties = product.properties;
|
|
31
|
+
const productItemType = productItemTypes.find((itemType) => itemType.name == product.item_type);
|
|
32
|
+
const productPropertiesList = productItemType ? productItemType.product_properties : [];
|
|
33
|
+
const productPropertiesRows = productPropertiesList.reduce((rows, prop, index) => {
|
|
34
|
+
if (index % 2 === 0)
|
|
35
|
+
rows.push([prop]);
|
|
36
|
+
else
|
|
37
|
+
rows[rows.length - 1].push(prop);
|
|
38
|
+
return rows;
|
|
39
|
+
}, []);
|
|
40
|
+
useEffect(() => {
|
|
41
|
+
api.operations["pim.item_types:options"].call({}).then(async (response) => {
|
|
42
|
+
if (response.ok) {
|
|
43
|
+
setProductItemTypes(await response.json());
|
|
44
|
+
}
|
|
45
|
+
});
|
|
46
|
+
}, []);
|
|
47
|
+
return (React.createElement(Card, { columns: 2, isEditable: false },
|
|
28
48
|
React.createElement(CardHeader, { title: "Product" }),
|
|
29
49
|
React.createElement(CardContent, null,
|
|
30
50
|
React.createElement(CardRow, null,
|
|
31
|
-
React.createElement(CardFieldText, { formName: "name", label: t("Name"), required: true, value: product.name })
|
|
51
|
+
React.createElement(CardFieldText, { formName: "name", label: t("Name"), required: true, value: product.name }),
|
|
52
|
+
React.createElement(CardFieldSelect, { formName: "item_type", label: t("Type"), options: productItemTypes.map((itemType) => ({
|
|
53
|
+
id: itemType.name,
|
|
54
|
+
label: itemType.name,
|
|
55
|
+
})), required: true, size: 1, value: product.item_type ? { id: product.item_type, label: product.item_type } : undefined })),
|
|
32
56
|
React.createElement(CardRow, null,
|
|
33
57
|
React.createElement(CardFieldText, { formName: "description", label: t("Description"), required: true, value: product.description }))),
|
|
34
|
-
|
|
58
|
+
productPropertiesRows.length > 0 && (React.createElement(React.Fragment, null,
|
|
35
59
|
React.createElement(CardHeader, { title: t("Properties") }),
|
|
36
|
-
React.createElement(
|
|
37
|
-
React.createElement(TableBody, { sx: {
|
|
38
|
-
"& .MuiTableRow-root:first-of-type .MuiTableCell-root": (theme) => ({
|
|
39
|
-
borderTop: `1px solid ${theme.palette.divider}`,
|
|
40
|
-
}),
|
|
41
|
-
} }, productProperties
|
|
42
|
-
.sort((a, b) => (a[0] < b[0] ? -1 : 1))
|
|
43
|
-
.map((prop) => (React.createElement(TableRow, { key: prop[0] },
|
|
44
|
-
React.createElement(TableCell, null, capitalize(prop[0])),
|
|
45
|
-
React.createElement(TableCell, { typographyProps: {
|
|
46
|
-
variant: "caption",
|
|
47
|
-
color: "text.secondary",
|
|
48
|
-
} }, prop[1])))))))),
|
|
60
|
+
React.createElement(CardContent, null, productPropertiesRows.map((row, index) => (React.createElement(CardRow, { key: index }, row.map((prop) => (React.createElement(ProductPropertyField, { key: prop.name, property: prop, value: productProperties[prop.name] }))))))))),
|
|
49
61
|
articleAssets.length > 0 && React.createElement(CardHeader, { title: t("Assets") }),
|
|
50
62
|
imageAssets.length > 0 && (React.createElement(React.Fragment, null,
|
|
51
63
|
React.createElement(Modal, { "aria-describedby": "modal-modal-description", "aria-labelledby": "modal-modal-title", open: selectedAsset !== null, onClose: () => setSelectedAsset(null) },
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ArticleProduct.js","sourceRoot":"","sources":["../../../../../src/extensions/pim/contrib/ArticleProduct.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"ArticleProduct.js","sourceRoot":"","sources":["../../../../../src/extensions/pim/contrib/ArticleProduct.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,33 @@
|
|
|
1
1
|
import InventoryOutlinedIcon from "@mui/icons-material/InventoryOutlined";
|
|
2
|
+
import WorkspacesIcon from "../../assets/symbols/Workspaces";
|
|
3
|
+
export * from "./types/contrib";
|
|
4
|
+
export * from "./types/product";
|
|
5
|
+
const routes = {
|
|
6
|
+
product: {
|
|
7
|
+
create: { page: async () => (await import("./pages/product/create")).default, offline: true },
|
|
8
|
+
detail: { page: async () => (await import("./pages/product/detail")).default },
|
|
9
|
+
list: { page: async () => (await import("./pages/product/list")).default },
|
|
10
|
+
},
|
|
11
|
+
};
|
|
12
|
+
export const router = {
|
|
13
|
+
app: "pim",
|
|
14
|
+
pages: (route) => {
|
|
15
|
+
const { page, ...hit } = routes[route.view]?.[route.action] ?? {};
|
|
16
|
+
if (page != null) {
|
|
17
|
+
return {
|
|
18
|
+
page: page(),
|
|
19
|
+
...hit,
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
return undefined;
|
|
23
|
+
},
|
|
24
|
+
};
|
|
25
|
+
export const navigation = {
|
|
26
|
+
"pim.product:list": {
|
|
27
|
+
icon: WorkspacesIcon,
|
|
28
|
+
permission: "pim.view_product",
|
|
29
|
+
},
|
|
30
|
+
};
|
|
2
31
|
export const contrib = {
|
|
3
32
|
catalog: {
|
|
4
33
|
"catalog:article:detail:product": {
|
|
@@ -7,6 +36,7 @@ export const contrib = {
|
|
|
7
36
|
component: async () => (await import("./contrib/ArticleProduct")).default,
|
|
8
37
|
predicate: (article) => !!article.product_number,
|
|
9
38
|
variant: "inline",
|
|
39
|
+
permission: "pim.view_product",
|
|
10
40
|
},
|
|
11
41
|
},
|
|
12
42
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/extensions/pim/index.tsx"],"names":[],"mappings":"AAAA,OAAO,qBAAqB,MAAM,uCAAuC,CAAC;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/extensions/pim/index.tsx"],"names":[],"mappings":"AAAA,OAAO,qBAAqB,MAAM,uCAAuC,CAAC;AAI1E,OAAO,cAAc,MAAM,iCAAiC,CAAC;AAK7D,cAAc,iBAAiB,CAAC;AAChC,cAAc,iBAAiB,CAAC;AAEhC,MAAM,MAAM,GAYR;IACF,OAAO,EAAE;QACP,MAAM,EAAE,EAAE,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC,MAAM,MAAM,CAAC,wBAAwB,CAAC,CAAC,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE;QAC7F,MAAM,EAAE,EAAE,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC,MAAM,MAAM,CAAC,wBAAwB,CAAC,CAAC,CAAC,OAAO,EAAE;QAC9E,IAAI,EAAE,EAAE,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC,MAAM,MAAM,CAAC,sBAAsB,CAAC,CAAC,CAAC,OAAO,EAAE;KAC3E;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,MAAM,GAAoB;IACrC,GAAG,EAAE,KAAK;IACV,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;QACf,MAAM,EAAE,IAAI,EAAE,GAAG,GAAG,EAAE,GAAG,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;QAElE,IAAI,IAAI,IAAI,IAAI,EAAE,CAAC;YACjB,OAAO;gBACL,IAAI,EAAE,IAAI,EAAE;gBACZ,GAAG,GAAG;aACP,CAAC;QACJ,CAAC;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,UAAU,GAAwB;IAC7C,kBAAkB,EAAE;QAClB,IAAI,EAAE,cAAc;QACpB,UAAU,EAAE,kBAAkB;KAC/B;CACO,CAAC;AAEX,MAAM,CAAC,MAAM,OAAO,GAAwC;IAC1D,OAAO,EAAE;QACP,gCAAgC,EAAE;YAChC,KAAK,EAAE,SAAS;YAChB,IAAI,EAAE,qBAAqB;YAC3B,SAAS,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC,MAAM,MAAM,CAAC,0BAA0B,CAAC,CAAC,CAAC,OAAO;YACzE,SAAS,EAAE,CAAC,OAAsB,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,cAAc;YAC/D,OAAO,EAAE,QAAQ;YACjB,UAAU,EAAE,kBAAkB;SAC/B;KACF;CACO,CAAC"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import React, { useEffect, useState } from "react";
|
|
2
|
+
import CategoryOutlinedIcon from "@mui/icons-material/CategoryOutlined";
|
|
3
|
+
import { Header } from "../../../../components/Header";
|
|
4
|
+
import { Page } from "../../../../components/Page";
|
|
5
|
+
import { Tab } from "../../../../components/Tab";
|
|
6
|
+
import { TabPanel } from "../../../../components/TabPanel";
|
|
7
|
+
import { TabPanels } from "../../../../components/TabPanels";
|
|
8
|
+
import { Tabs } from "../../../../components/Tabs";
|
|
9
|
+
import { TitleBar } from "../../../../components/TitleBar";
|
|
10
|
+
import Content, { LeftColumn } from "../../../../containers/Content";
|
|
11
|
+
import { useApi } from "../../../../contexts/ApiContext";
|
|
12
|
+
import { useRouter } from "../../../../contexts/RouterContext";
|
|
13
|
+
import { ProductCard } from "../../components/ProductCard";
|
|
14
|
+
const ProductCreatePage = () => {
|
|
15
|
+
const { navigate } = useRouter();
|
|
16
|
+
const api = useApi();
|
|
17
|
+
const [productItemTypes, setProductItemTypes] = useState([]);
|
|
18
|
+
useEffect(() => {
|
|
19
|
+
api.operations["pim.item_types:options"].call({}).then(async (response) => {
|
|
20
|
+
if (response.ok) {
|
|
21
|
+
setProductItemTypes(await response.json());
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
}, []);
|
|
25
|
+
return (React.createElement(Page, null,
|
|
26
|
+
React.createElement(Header, { variant: "opaque" },
|
|
27
|
+
React.createElement(TitleBar, { title: "Create Product" }),
|
|
28
|
+
React.createElement(Tabs, null,
|
|
29
|
+
React.createElement(Tab, { key: "default", icon: React.createElement(CategoryOutlinedIcon, null), label: "Product", value: "default" }))),
|
|
30
|
+
React.createElement(TabPanels, null,
|
|
31
|
+
React.createElement(TabPanel, { key: "default", value: "default" },
|
|
32
|
+
React.createElement(Content, { layout: "fixedWidth" },
|
|
33
|
+
React.createElement(LeftColumn, null,
|
|
34
|
+
React.createElement(ProductCard, { create: true, itemTypes: productItemTypes, onCreated: (product) => {
|
|
35
|
+
navigate(`pim.product:detail`, {
|
|
36
|
+
params: { id: product.id },
|
|
37
|
+
});
|
|
38
|
+
} })))))));
|
|
39
|
+
};
|
|
40
|
+
export default ProductCreatePage;
|
|
41
|
+
//# sourceMappingURL=create.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create.js","sourceRoot":"","sources":["../../../../../../src/extensions/pim/pages/product/create.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAEnD,OAAO,oBAAoB,MAAM,sCAAsC,CAAC;AAExE,OAAO,EAAE,MAAM,EAAE,MAAM,+BAA+B,CAAC;AACvD,OAAO,EAAE,IAAI,EAAE,MAAM,6BAA6B,CAAC;AACnD,OAAO,EAAE,GAAG,EAAE,MAAM,4BAA4B,CAAC;AACjD,OAAO,EAAE,QAAQ,EAAE,MAAM,iCAAiC,CAAC;AAC3D,OAAO,EAAE,SAAS,EAAE,MAAM,kCAAkC,CAAC;AAC7D,OAAO,EAAE,IAAI,EAAE,MAAM,6BAA6B,CAAC;AACnD,OAAO,EAAE,QAAQ,EAAE,MAAM,iCAAiC,CAAC;AAC3D,OAAO,OAAO,EAAE,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AACrE,OAAO,EAAE,MAAM,EAAE,MAAM,iCAAiC,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,MAAM,oCAAoC,CAAC;AAE/D,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAG3D,MAAM,iBAAiB,GAAkB,GAAG,EAAE;IAC5C,MAAM,EAAE,QAAQ,EAAE,GAAG,SAAS,EAAE,CAAC;IACjC,MAAM,GAAG,GAAG,MAAM,EAAE,CAAC;IAErB,MAAM,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,GAAG,QAAQ,CAA0B,EAAE,CAAC,CAAC;IAEtF,SAAS,CAAC,GAAG,EAAE;QACb,GAAG,CAAC,UAAU,CAAC,wBAAwB,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,EAAE;YACxE,IAAI,QAAQ,CAAC,EAAE,EAAE,CAAC;gBAChB,mBAAmB,CAAC,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC;YAC7C,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,CACL,oBAAC,IAAI;QACH,oBAAC,MAAM,IAAC,OAAO,EAAC,QAAQ;YACtB,oBAAC,QAAQ,IAAC,KAAK,EAAC,gBAAgB,GAAG;YACnC,oBAAC,IAAI;gBACH,oBAAC,GAAG,IAAC,GAAG,EAAC,SAAS,EAAC,IAAI,EAAE,oBAAC,oBAAoB,OAAG,EAAE,KAAK,EAAC,SAAS,EAAC,KAAK,EAAC,SAAS,GAAG,CAChF,CACA;QAET,oBAAC,SAAS;YACR,oBAAC,QAAQ,IAAC,GAAG,EAAC,SAAS,EAAC,KAAK,EAAC,SAAS;gBACrC,oBAAC,OAAO,IAAC,MAAM,EAAC,YAAY;oBAC1B,oBAAC,UAAU;wBACT,oBAAC,WAAW,IACV,MAAM,QACN,SAAS,EAAE,gBAAgB,EAC3B,SAAS,EAAE,CAAC,OAAO,EAAE,EAAE;gCACrB,QAAQ,CAAC,oBAAoB,EAAE;oCAC7B,MAAM,EAAE,EAAE,EAAE,EAAE,OAAO,CAAC,EAAE,EAAE;iCAC3B,CAAC,CAAC;4BACL,CAAC,GACD,CACS,CACL,CACD,CACD,CACP,CACR,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import React, { useEffect, useState } from "react";
|
|
2
|
+
import CategoryOutlinedIcon from "@mui/icons-material/CategoryOutlined";
|
|
3
|
+
import Typography from "@mui/material/Typography";
|
|
4
|
+
import { ContribInlines } from "../../../../components/ContribInlines";
|
|
5
|
+
import { Header } from "../../../../components/Header";
|
|
6
|
+
import { Page } from "../../../../components/Page";
|
|
7
|
+
import { Tab } from "../../../../components/Tab";
|
|
8
|
+
import { TabPanel } from "../../../../components/TabPanel";
|
|
9
|
+
import { TabPanels } from "../../../../components/TabPanels";
|
|
10
|
+
import { Tabs } from "../../../../components/Tabs";
|
|
11
|
+
import { TitleBar } from "../../../../components/TitleBar";
|
|
12
|
+
import Content, { LeftColumn, RightColumn } from "../../../../containers/Content";
|
|
13
|
+
import { useApi } from "../../../../contexts/ApiContext";
|
|
14
|
+
import { ProductCard } from "../../components/ProductCard";
|
|
15
|
+
import { ProductPropertiesCard } from "../../components/ProductPropertiesCard";
|
|
16
|
+
const ProductDetailPage = ({ data }) => {
|
|
17
|
+
const [product, setProduct] = useState(data);
|
|
18
|
+
const [productItemTypes, setProductItemTypes] = useState([]);
|
|
19
|
+
const api = useApi();
|
|
20
|
+
useEffect(() => {
|
|
21
|
+
api.operations["pim.item_types:options"].call({}).then(async (response) => {
|
|
22
|
+
if (response.ok) {
|
|
23
|
+
setProductItemTypes(await response.json());
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
}, []);
|
|
27
|
+
const productItemType = productItemTypes.find((itemType) => itemType.name == product.item_type);
|
|
28
|
+
return (React.createElement(Page, null,
|
|
29
|
+
React.createElement(Header, { variant: "opaque" },
|
|
30
|
+
React.createElement(TitleBar, { title: React.createElement(React.Fragment, null,
|
|
31
|
+
data.name,
|
|
32
|
+
React.createElement(Typography, { sx: { pl: 1 }, variant: "button" }, data.number)) }),
|
|
33
|
+
React.createElement(Tabs, { data: product },
|
|
34
|
+
React.createElement(Tab, { key: "default", icon: React.createElement(CategoryOutlinedIcon, null), label: "Product", value: "default" }))),
|
|
35
|
+
React.createElement(TabPanels, { contribParams: { number: data.number } },
|
|
36
|
+
React.createElement(TabPanel, { key: "default", value: "default" },
|
|
37
|
+
React.createElement(Content, { layout: "fixedWidth" },
|
|
38
|
+
React.createElement(LeftColumn, null,
|
|
39
|
+
React.createElement(ProductCard, { itemTypes: productItemTypes, product: product, onUpdated: setProduct }),
|
|
40
|
+
productItemType && (React.createElement(ProductPropertiesCard, { itemType: productItemType, productProperties: product.properties, setProductProperties: (properties) => setProduct((previous) => ({ ...previous, properties })) })),
|
|
41
|
+
React.createElement(ContribInlines, { contribParams: { number: data.number }, data: data })),
|
|
42
|
+
React.createElement(RightColumn, null,
|
|
43
|
+
React.createElement(ContribInlines, { contribParams: { number: data.number }, data: data, variant: "sidebar" })))))));
|
|
44
|
+
};
|
|
45
|
+
export default ProductDetailPage;
|
|
46
|
+
//# sourceMappingURL=detail.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"detail.js","sourceRoot":"","sources":["../../../../../../src/extensions/pim/pages/product/detail.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAEnD,OAAO,oBAAoB,MAAM,sCAAsC,CAAC;AACxE,OAAO,UAAU,MAAM,0BAA0B,CAAC;AAElD,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAC;AACvE,OAAO,EAAE,MAAM,EAAE,MAAM,+BAA+B,CAAC;AACvD,OAAO,EAAE,IAAI,EAAE,MAAM,6BAA6B,CAAC;AACnD,OAAO,EAAE,GAAG,EAAE,MAAM,4BAA4B,CAAC;AACjD,OAAO,EAAE,QAAQ,EAAE,MAAM,iCAAiC,CAAC;AAC3D,OAAO,EAAE,SAAS,EAAE,MAAM,kCAAkC,CAAC;AAC7D,OAAO,EAAE,IAAI,EAAE,MAAM,6BAA6B,CAAC;AACnD,OAAO,EAAE,QAAQ,EAAE,MAAM,iCAAiC,CAAC;AAC3D,OAAO,OAAO,EAAE,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,gCAAgC,CAAC;AAClF,OAAO,EAAE,MAAM,EAAE,MAAM,iCAAiC,CAAC;AAEzD,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAC3D,OAAO,EAAE,qBAAqB,EAAE,MAAM,wCAAwC,CAAC;AAG/E,MAAM,iBAAiB,GAAiC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE;IACnE,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC;IAC7C,MAAM,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,GAAG,QAAQ,CAA0B,EAAE,CAAC,CAAC;IACtF,MAAM,GAAG,GAAG,MAAM,EAAE,CAAC;IAErB,SAAS,CAAC,GAAG,EAAE;QACb,GAAG,CAAC,UAAU,CAAC,wBAAwB,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,EAAE;YACxE,IAAI,QAAQ,CAAC,EAAE,EAAE,CAAC;gBAChB,mBAAmB,CAAC,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC;YAC7C,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,MAAM,eAAe,GAAG,gBAAgB,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,IAAI,IAAI,OAAO,CAAC,SAAS,CAAC,CAAC;IAEhG,OAAO,CACL,oBAAC,IAAI;QACH,oBAAC,MAAM,IAAC,OAAO,EAAC,QAAQ;YACtB,oBAAC,QAAQ,IACP,KAAK,EACH;oBACG,IAAI,CAAC,IAAI;oBACV,oBAAC,UAAU,IAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,OAAO,EAAC,QAAQ,IACxC,IAAI,CAAC,MAAM,CACD,CACZ,GAEL;YACF,oBAAC,IAAI,IAAC,IAAI,EAAE,OAAO;gBACjB,oBAAC,GAAG,IAAC,GAAG,EAAC,SAAS,EAAC,IAAI,EAAE,oBAAC,oBAAoB,OAAG,EAAE,KAAK,EAAC,SAAS,EAAC,KAAK,EAAC,SAAS,GAAG,CAChF,CACA;QAET,oBAAC,SAAS,IAAC,aAAa,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE;YAC/C,oBAAC,QAAQ,IAAC,GAAG,EAAC,SAAS,EAAC,KAAK,EAAC,SAAS;gBACrC,oBAAC,OAAO,IAAC,MAAM,EAAC,YAAY;oBAC1B,oBAAC,UAAU;wBACT,oBAAC,WAAW,IAAC,SAAS,EAAE,gBAAgB,EAAE,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,UAAU,GAAI;wBAEpF,eAAe,IAAI,CAClB,oBAAC,qBAAqB,IACpB,QAAQ,EAAE,eAAe,EACzB,iBAAiB,EAAE,OAAO,CAAC,UAAU,EACrC,oBAAoB,EAAE,CAAC,UAAU,EAAE,EAAE,CACnC,UAAU,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,QAAQ,EAAE,UAAU,EAAE,CAAC,CAAC,GAEzD,CACH;wBACD,oBAAC,cAAc,IAAC,aAAa,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,EAAE,IAAI,EAAE,IAAI,GAAI,CAC3D;oBACb,oBAAC,WAAW;wBACV,oBAAC,cAAc,IACb,aAAa,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,EACtC,IAAI,EAAE,IAAI,EACV,OAAO,EAAC,SAAS,GACjB,CACU,CACN,CACD,CACD,CACP,CACR,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { Button, TableBody } from "@mui/material";
|
|
3
|
+
import ActionBar from "../../../../components/ActionBar";
|
|
4
|
+
import { Header } from "../../../../components/Header";
|
|
5
|
+
import { Page } from "../../../../components/Page";
|
|
6
|
+
import SearchBar from "../../../../components/SearchBar";
|
|
7
|
+
import Table from "../../../../components/Table";
|
|
8
|
+
import TableHead from "../../../../components/Table/TableHead";
|
|
9
|
+
import TableHeading from "../../../../components/Table/TableHeading";
|
|
10
|
+
import TableCard from "../../../../components/TableCard";
|
|
11
|
+
import { TitleBar } from "../../../../components/TitleBar";
|
|
12
|
+
import Content, { ContentWrapperWithActionBar } from "../../../../containers/Content";
|
|
13
|
+
import { useI18n } from "../../../../contexts/I18nContext";
|
|
14
|
+
import { useRouter } from "../../../../contexts/RouterContext";
|
|
15
|
+
import { useUser } from "../../../../contexts/UserContext";
|
|
16
|
+
import { hasPermission } from "../../../../util/has_permission";
|
|
17
|
+
import { ProductRow } from "../../components/ProductRow";
|
|
18
|
+
const ProductListPage = ({ data }) => {
|
|
19
|
+
const { navigate } = useRouter();
|
|
20
|
+
const { user } = useUser();
|
|
21
|
+
const { t } = useI18n();
|
|
22
|
+
return (React.createElement(Page, null,
|
|
23
|
+
React.createElement(Header, null,
|
|
24
|
+
React.createElement(TitleBar, { title: t("Products") },
|
|
25
|
+
React.createElement(SearchBar, { defaultValue: new URLSearchParams(window.location.search).get("search") ?? "", placeholder: t("Search for product number or name"), onSubmit: (input) => {
|
|
26
|
+
if (input === "") {
|
|
27
|
+
navigate("pim.product:list", {
|
|
28
|
+
replace: true,
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
navigate("pim.product:list", {
|
|
33
|
+
query: {
|
|
34
|
+
search: input,
|
|
35
|
+
},
|
|
36
|
+
replace: true,
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
} }))),
|
|
40
|
+
React.createElement(ContentWrapperWithActionBar, null,
|
|
41
|
+
React.createElement(Content, { layout: "fullWidth" },
|
|
42
|
+
React.createElement(TableCard, null,
|
|
43
|
+
React.createElement(Table, { pagination: true, count: data?.count },
|
|
44
|
+
React.createElement(TableHead, null,
|
|
45
|
+
React.createElement(TableHeading, null, t("Name")),
|
|
46
|
+
React.createElement(TableHeading, null, t("Type")),
|
|
47
|
+
React.createElement(TableHeading, null, t("Product Number")),
|
|
48
|
+
React.createElement(TableHeading, { align: "right" }, t("Active"))),
|
|
49
|
+
React.createElement(TableBody, null, data?.results.map((product) => React.createElement(ProductRow, { key: product.id, product: product })))))),
|
|
50
|
+
hasPermission(user, "pim.add_product") && (React.createElement(ActionBar, null,
|
|
51
|
+
React.createElement(Button, { color: "primary", variant: "contained", onClick: () => navigate("pim.product:create") }, t("Create product")))))));
|
|
52
|
+
};
|
|
53
|
+
export default ProductListPage;
|
|
54
|
+
//# sourceMappingURL=list.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"list.js","sourceRoot":"","sources":["../../../../../../src/extensions/pim/pages/product/list.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"product.js","sourceRoot":"","sources":["../../../../../src/extensions/pim/types/product.ts"],"names":[],"mappings":""}
|
|
@@ -5,6 +5,9 @@ export interface CardFieldAutoCompleteProps extends CardFieldBaseProps, React.Pr
|
|
|
5
5
|
isEditable?: boolean;
|
|
6
6
|
type: "autocomplete";
|
|
7
7
|
value: FormOption[];
|
|
8
|
+
autoSelect?: boolean;
|
|
9
|
+
clearOnBlur?: boolean;
|
|
10
|
+
freeSolo?: boolean;
|
|
8
11
|
}
|
|
9
12
|
export declare const CardFieldAutoComplete: React.FC<Omit<CardFieldAutoCompleteProps, "type">>;
|
|
10
13
|
export default CardFieldAutoComplete;
|
|
@@ -7,6 +7,7 @@ export interface CardFieldSelectProps extends React.PropsWithChildren, Omit<Sele
|
|
|
7
7
|
emptyValue?: FormOption;
|
|
8
8
|
value: FormOption | undefined;
|
|
9
9
|
isEditable?: boolean;
|
|
10
|
+
onUpdated?: (val: string) => void;
|
|
10
11
|
}
|
|
11
12
|
export declare const CardFieldSelect: React.FC<Omit<CardFieldSelectProps, "type">>;
|
|
12
13
|
export default CardFieldSelect;
|
|
@@ -11,4 +11,16 @@ export type ArticleCardProps = {
|
|
|
11
11
|
onCreated?: never;
|
|
12
12
|
onUpdated: (article: ArticleDetail) => void;
|
|
13
13
|
};
|
|
14
|
+
export interface ArticleCardFormValues {
|
|
15
|
+
code: string;
|
|
16
|
+
item_type: string;
|
|
17
|
+
is_active: string;
|
|
18
|
+
name: string;
|
|
19
|
+
description: string;
|
|
20
|
+
product_number: string;
|
|
21
|
+
model_number: string;
|
|
22
|
+
tax_code: string;
|
|
23
|
+
gtin: string;
|
|
24
|
+
variant: string;
|
|
25
|
+
}
|
|
14
26
|
export declare const ArticleCard: React.FC<ArticleCardProps>;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { ProductCreated, ProductDetail, ProductItemTypeOption } from "../types/product";
|
|
3
|
+
export type ProductCardProps = {
|
|
4
|
+
create: true;
|
|
5
|
+
product?: ProductDetail;
|
|
6
|
+
onCreated: (product: ProductCreated) => void;
|
|
7
|
+
onUpdated?: never;
|
|
8
|
+
itemTypes: ProductItemTypeOption[];
|
|
9
|
+
} | {
|
|
10
|
+
create?: false;
|
|
11
|
+
product: ProductDetail;
|
|
12
|
+
onCreated?: never;
|
|
13
|
+
onUpdated: (product: ProductDetail) => void;
|
|
14
|
+
itemTypes: ProductItemTypeOption[];
|
|
15
|
+
};
|
|
16
|
+
export interface ProductCardFormValues {
|
|
17
|
+
number: string;
|
|
18
|
+
item_type: string;
|
|
19
|
+
is_active: string;
|
|
20
|
+
name: string;
|
|
21
|
+
description: string;
|
|
22
|
+
}
|
|
23
|
+
export declare const ProductCard: React.FC<ProductCardProps>;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { ProductItemTypeOption, ProductPropertiesData } from "../types/product";
|
|
3
|
+
export interface ProductPropertiesCardProps {
|
|
4
|
+
itemType: ProductItemTypeOption;
|
|
5
|
+
productProperties: ProductPropertiesData;
|
|
6
|
+
setProductProperties: (properties: ProductPropertiesData) => void;
|
|
7
|
+
}
|
|
8
|
+
export declare const ProductPropertiesCard: React.FC<ProductPropertiesCardProps>;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { ProductProperty, ProductPropertyValue } from "../types/product";
|
|
3
|
+
export interface ProductPropertyFieldProps {
|
|
4
|
+
property: ProductProperty;
|
|
5
|
+
value: ProductPropertyValue;
|
|
6
|
+
formName?: string;
|
|
7
|
+
}
|
|
8
|
+
export declare const ProductPropertyField: React.FC<ProductPropertyFieldProps>;
|
|
@@ -1,2 +1,7 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { RouterExtension } from "../../router/Router";
|
|
2
|
+
import { ContribComponentMap, NavigationOverrides } from "../../types";
|
|
3
|
+
export * from "./types/contrib";
|
|
4
|
+
export * from "./types/product";
|
|
5
|
+
export declare const router: RouterExtension;
|
|
6
|
+
export declare const navigation: NavigationOverrides;
|
|
2
7
|
export declare const contrib: Record<string, ContribComponentMap>;
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
export interface ProductList {
|
|
2
|
+
id: number;
|
|
3
|
+
number: string;
|
|
4
|
+
item_type: string;
|
|
5
|
+
name: string;
|
|
6
|
+
description: string;
|
|
7
|
+
is_active: boolean;
|
|
8
|
+
}
|
|
9
|
+
export type ProductPropertyValue = string | number | boolean | string[] | number[] | boolean[] | null | undefined;
|
|
10
|
+
export type ProductPropertiesData = Record<string, string | number | boolean | string[] | number[] | boolean[]>;
|
|
11
|
+
export interface ProductDetail {
|
|
12
|
+
id: number;
|
|
13
|
+
number: string;
|
|
14
|
+
item_type: string;
|
|
15
|
+
name: string;
|
|
16
|
+
description: string;
|
|
17
|
+
is_active: boolean;
|
|
18
|
+
properties: ProductPropertiesData;
|
|
19
|
+
}
|
|
20
|
+
export interface ProductCreated {
|
|
21
|
+
id: number;
|
|
22
|
+
}
|
|
23
|
+
export interface ProductProperty {
|
|
24
|
+
name: string;
|
|
25
|
+
title: string;
|
|
26
|
+
type: string;
|
|
27
|
+
min_length?: number;
|
|
28
|
+
min_value?: number;
|
|
29
|
+
max_value?: number;
|
|
30
|
+
array_type?: string;
|
|
31
|
+
}
|
|
32
|
+
export interface ProductItemTypeOption {
|
|
33
|
+
name: string;
|
|
34
|
+
product_properties: ProductProperty[];
|
|
35
|
+
}
|
|
@@ -66,7 +66,7 @@ export type ContribComponent<T = any> = React.ComponentType<PageProps<T> & OpenA
|
|
|
66
66
|
* The variant of the component, either a tab, inline or action menu item.
|
|
67
67
|
* Still requires a `Page` that loads the contrib.
|
|
68
68
|
*/
|
|
69
|
-
export type ContribVariant = "tab" | "inline" | "action";
|
|
69
|
+
export type ContribVariant = "tab" | "inline" | "action" | "sidebar";
|
|
70
70
|
export interface PageContribComponent<T = any> extends OpenAPI.Request {
|
|
71
71
|
/**
|
|
72
72
|
* The title shown in the NavRail.
|
package/package.json
CHANGED
|
@@ -16,6 +16,9 @@ export interface CardFieldAutoCompleteProps extends CardFieldBaseProps, React.Pr
|
|
|
16
16
|
isEditable?: boolean;
|
|
17
17
|
type: "autocomplete";
|
|
18
18
|
value: FormOption[];
|
|
19
|
+
autoSelect?: boolean;
|
|
20
|
+
clearOnBlur?: boolean;
|
|
21
|
+
freeSolo?: boolean;
|
|
19
22
|
}
|
|
20
23
|
|
|
21
24
|
export const CardFieldAutoComplete: React.FC<Omit<CardFieldAutoCompleteProps, "type">> = ({
|
|
@@ -29,6 +32,9 @@ export const CardFieldAutoComplete: React.FC<Omit<CardFieldAutoCompleteProps, "t
|
|
|
29
32
|
options,
|
|
30
33
|
size = "grow",
|
|
31
34
|
value: defaultValue,
|
|
35
|
+
autoSelect = false,
|
|
36
|
+
clearOnBlur = false,
|
|
37
|
+
freeSolo = false,
|
|
32
38
|
...props
|
|
33
39
|
}) => {
|
|
34
40
|
const { isCompact, isEditing } = useCardContext();
|
|
@@ -41,13 +47,20 @@ export const CardFieldAutoComplete: React.FC<Omit<CardFieldAutoCompleteProps, "t
|
|
|
41
47
|
{isEditing && isEditable ? (
|
|
42
48
|
<Stack alignItems="center" justifyContent="space-between">
|
|
43
49
|
<Autocomplete
|
|
50
|
+
autoSelect={autoSelect}
|
|
51
|
+
clearOnBlur={clearOnBlur}
|
|
52
|
+
freeSolo={freeSolo}
|
|
44
53
|
isOptionEqualToValue={(option: FormOption, value: FormOption) => option.id === value.id}
|
|
45
54
|
multiple={true}
|
|
46
55
|
options={options ?? []}
|
|
47
56
|
renderInput={(props) => <TextField {...props} label={label} />}
|
|
48
57
|
sx={{ width: "100%" }}
|
|
49
58
|
value={selectedOptions}
|
|
50
|
-
onChange={(_, value) =>
|
|
59
|
+
onChange={(_, value) =>
|
|
60
|
+
setSelectedOptions(
|
|
61
|
+
value.map((v) => (typeof v == "string" ? { id: v, label: v } : v)) as FormOption[],
|
|
62
|
+
)
|
|
63
|
+
}
|
|
51
64
|
{...props}
|
|
52
65
|
/>
|
|
53
66
|
|
|
@@ -21,6 +21,7 @@ export interface CardFieldSelectProps
|
|
|
21
21
|
emptyValue?: FormOption;
|
|
22
22
|
value: FormOption | undefined;
|
|
23
23
|
isEditable?: boolean;
|
|
24
|
+
onUpdated?: (val: string) => void;
|
|
24
25
|
}
|
|
25
26
|
|
|
26
27
|
export const CardFieldSelect: React.FC<Omit<CardFieldSelectProps, "type">> = ({
|
|
@@ -37,6 +38,7 @@ export const CardFieldSelect: React.FC<Omit<CardFieldSelectProps, "type">> = ({
|
|
|
37
38
|
required = false,
|
|
38
39
|
size = "grow",
|
|
39
40
|
value: defaultValue = undefined,
|
|
41
|
+
onUpdated,
|
|
40
42
|
...props
|
|
41
43
|
}) => {
|
|
42
44
|
const { isCompact, isEditing } = useCardContext();
|
|
@@ -44,9 +46,11 @@ export const CardFieldSelect: React.FC<Omit<CardFieldSelectProps, "type">> = ({
|
|
|
44
46
|
|
|
45
47
|
const handleChange = useCallback(
|
|
46
48
|
(event: SelectChangeEvent<unknown>) => {
|
|
47
|
-
|
|
49
|
+
const currentValue = event.target.value as string;
|
|
50
|
+
setValue(currentValue);
|
|
51
|
+
if (onUpdated) onUpdated(currentValue);
|
|
48
52
|
},
|
|
49
|
-
[setValue],
|
|
53
|
+
[setValue, onUpdated],
|
|
50
54
|
);
|
|
51
55
|
|
|
52
56
|
return (
|