@moudle/-product 0.0.4 → 0.0.5
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/module/api/delete-product.js +1 -1
- package/dist/module/api/delete-product.js.map +1 -1
- package/dist/module/api/detail-product.js +2 -2
- package/dist/module/api/detail-product.js.map +1 -1
- package/dist/module/api/update-product.js +1 -1
- package/dist/module/api/update-product.js.map +1 -1
- package/dist/module/page/DetailProductPage.d.ts +2 -0
- package/dist/module/page/DetailProductPage.d.ts.map +1 -0
- package/dist/module/page/DetailProductPage.js +54 -0
- package/dist/module/page/DetailProductPage.js.map +1 -0
- package/dist/module/page/EditProductPage.d.ts +2 -0
- package/dist/module/page/EditProductPage.d.ts.map +1 -0
- package/dist/module/page/EditProductPage.js +65 -0
- package/dist/module/page/EditProductPage.js.map +1 -0
- package/dist/module/page/MyProductsPage.d.ts.map +1 -1
- package/dist/module/page/MyProductsPage.js +1 -1
- package/dist/module/page/MyProductsPage.js.map +1 -1
- package/dist/module/ui.d.ts +30 -2
- package/dist/module/ui.d.ts.map +1 -1
- package/dist/module/ui.js +20 -3
- package/dist/module/ui.js.map +1 -1
- package/package.json +4 -3
|
@@ -9,7 +9,7 @@ const db_1 = require("../db");
|
|
|
9
9
|
const zod_1 = __importDefault(require("zod"));
|
|
10
10
|
async function delete_product(request, response) {
|
|
11
11
|
const DeleteProductRequest = zod_1.default.object({
|
|
12
|
-
id: zod_1.default.number()
|
|
12
|
+
id: zod_1.default.coerce.number()
|
|
13
13
|
});
|
|
14
14
|
let detail_product_request;
|
|
15
15
|
try {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"delete-product.js","sourceRoot":"","sources":["../../../module/api/delete-product.ts"],"names":[],"mappings":";;;;;AAKA,wCAyBC;AA7BD,8CAAmD;AACnD,8BAAgC;AAChC,8CAAoB;AAEb,KAAK,UAAU,cAAc,CAAC,OAAgB,EAAE,QAAkB;IACvE,MAAM,oBAAoB,GAAG,aAAC,CAAC,MAAM,CAAC;QACpC,EAAE,EAAE,aAAC,CAAC,MAAM,EAAE;
|
|
1
|
+
{"version":3,"file":"delete-product.js","sourceRoot":"","sources":["../../../module/api/delete-product.ts"],"names":[],"mappings":";;;;;AAKA,wCAyBC;AA7BD,8CAAmD;AACnD,8BAAgC;AAChC,8CAAoB;AAEb,KAAK,UAAU,cAAc,CAAC,OAAgB,EAAE,QAAkB;IACvE,MAAM,oBAAoB,GAAG,aAAC,CAAC,MAAM,CAAC;QACpC,EAAE,EAAE,aAAC,CAAC,MAAM,CAAC,MAAM,EAAE;KACtB,CAAC,CAAC;IACH,IAAI,sBAAsB,CAAC;IAC3B,IAAI,CAAC;QACH,sBAAsB,GAAG,oBAAoB,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IACtE,CAAC;IAAC,OAAM,KAAK,EAAC,CAAC;QACb,IAAG,KAAK,YAAY,aAAC,CAAC,QAAQ,EAAE,CAAC;YAC/B,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YACzC,OAAO;QACT,CAAC;IACH,CAAC;IACD,MAAM,IAAI,GAAG,MAAM,+BAAkB,CAAC,qBAAqB,CAAC,OAAO,CAAC,OAAO,CAAC,aAAa,IAAI,EAAE,CAAC,CAAC;IACjG,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAC1C,OAAO;IACT,CAAC;IACD,MAAM,OAAO,GAAG,MAAM,YAAO,CAAC,SAAS,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,EAAE,EAAE,EAAE,EAAE,sBAAuB,CAAC,EAAE,EAAE,CAAC,CAAC;IAC9F,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;QAC/C,OAAO;IACT,CAAC;IACD,MAAM,OAAO,CAAC,MAAM,EAAE,CAAC;IACvB,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACtB,CAAC"}
|
|
@@ -9,7 +9,7 @@ const db_1 = require("../db");
|
|
|
9
9
|
const zod_1 = __importDefault(require("zod"));
|
|
10
10
|
async function detail_product(request, response) {
|
|
11
11
|
const DetailProductRequest = zod_1.default.object({
|
|
12
|
-
id: zod_1.default.number()
|
|
12
|
+
id: zod_1.default.coerce.number()
|
|
13
13
|
});
|
|
14
14
|
let detail_product_request;
|
|
15
15
|
try {
|
|
@@ -26,7 +26,7 @@ async function detail_product(request, response) {
|
|
|
26
26
|
response.status(401).send('Unauthorized');
|
|
27
27
|
return;
|
|
28
28
|
}
|
|
29
|
-
const product = await db_1.Product.findOneBy({ id_user: user.id, id: detail_product_request.id });
|
|
29
|
+
const product = await db_1.Product.findOneBy({ id_user: user.id, id: +detail_product_request.id });
|
|
30
30
|
if (!product) {
|
|
31
31
|
response.status(400).send('Product not found');
|
|
32
32
|
return;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"detail-product.js","sourceRoot":"","sources":["../../../module/api/detail-product.ts"],"names":[],"mappings":";;;;;AAKA,wCAwBC;AA5BD,8CAAmD;AACnD,8BAAgC;AAChC,8CAAoB;AAEb,KAAK,UAAU,cAAc,CAAC,OAAgB,EAAE,QAAkB;IACvE,MAAM,oBAAoB,GAAG,aAAC,CAAC,MAAM,CAAC;QACpC,EAAE,EAAE,aAAC,CAAC,MAAM,EAAE;
|
|
1
|
+
{"version":3,"file":"detail-product.js","sourceRoot":"","sources":["../../../module/api/detail-product.ts"],"names":[],"mappings":";;;;;AAKA,wCAwBC;AA5BD,8CAAmD;AACnD,8BAAgC;AAChC,8CAAoB;AAEb,KAAK,UAAU,cAAc,CAAC,OAAgB,EAAE,QAAkB;IACvE,MAAM,oBAAoB,GAAG,aAAC,CAAC,MAAM,CAAC;QACpC,EAAE,EAAE,aAAC,CAAC,MAAM,CAAC,MAAM,EAAE;KACtB,CAAC,CAAC;IACH,IAAI,sBAAsB,CAAC;IAC3B,IAAI,CAAC;QACH,sBAAsB,GAAG,oBAAoB,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;IACtE,CAAC;IAAC,OAAM,KAAK,EAAC,CAAC;QACb,IAAG,KAAK,YAAY,aAAC,CAAC,QAAQ,EAAE,CAAC;YAC/B,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YACzC,OAAO;QACT,CAAC;IACH,CAAC;IACD,MAAM,IAAI,GAAG,MAAM,+BAAkB,CAAC,qBAAqB,CAAC,OAAO,CAAC,OAAO,CAAC,aAAa,IAAI,EAAE,CAAC,CAAC;IACjG,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAC1C,OAAO;IACT,CAAC;IACD,MAAM,OAAO,GAAG,MAAM,YAAO,CAAC,SAAS,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,sBAAuB,CAAC,EAAE,EAAE,CAAC,CAAC;IAC/F,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;QAC/C,OAAO;IACT,CAAC;IACD,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;AACzB,CAAC"}
|
|
@@ -9,7 +9,7 @@ const db_1 = require("../db");
|
|
|
9
9
|
const zod_1 = __importDefault(require("zod"));
|
|
10
10
|
async function update_product(request, response) {
|
|
11
11
|
const UpdateProductPathRequest = zod_1.default.object({
|
|
12
|
-
id: zod_1.default.number()
|
|
12
|
+
id: zod_1.default.coerce.number()
|
|
13
13
|
});
|
|
14
14
|
const UpdateProductBodyRequest = zod_1.default.object({
|
|
15
15
|
image_url: zod_1.default.string().nullable(),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"update-product.js","sourceRoot":"","sources":["../../../module/api/update-product.ts"],"names":[],"mappings":";;;;;AAKA,wCAqCC;AAzCD,8CAAmD;AACnD,8BAAgC;AAChC,8CAAoB;AAEb,KAAK,UAAU,cAAc,CAAC,OAAgB,EAAE,QAAkB;IACvE,MAAM,wBAAwB,GAAG,aAAC,CAAC,MAAM,CAAC;QACxC,EAAE,EAAE,aAAC,CAAC,MAAM,EAAE;
|
|
1
|
+
{"version":3,"file":"update-product.js","sourceRoot":"","sources":["../../../module/api/update-product.ts"],"names":[],"mappings":";;;;;AAKA,wCAqCC;AAzCD,8CAAmD;AACnD,8BAAgC;AAChC,8CAAoB;AAEb,KAAK,UAAU,cAAc,CAAC,OAAgB,EAAE,QAAkB;IACvE,MAAM,wBAAwB,GAAG,aAAC,CAAC,MAAM,CAAC;QACxC,EAAE,EAAE,aAAC,CAAC,MAAM,CAAC,MAAM,EAAE;KACtB,CAAC,CAAC;IACH,MAAM,wBAAwB,GAAG,aAAC,CAAC,MAAM,CAAC;QACxC,SAAS,EAAE,aAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;QAChC,IAAI,EAAE,aAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;QAC3B,KAAK,EAAE,aAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;QAC5B,WAAW,EAAE,aAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;KACnC,CAAC,CAAC;IACH,IAAI,2BAA2B,CAAC;IAChC,IAAI,2BAA2B,CAAC;IAChC,IAAI,CAAC;QACH,2BAA2B,GAAG,wBAAwB,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QAC7E,2BAA2B,GAAG,wBAAwB,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7E,CAAC;IAAC,OAAM,KAAK,EAAC,CAAC;QACb,IAAG,KAAK,YAAY,aAAC,CAAC,QAAQ,EAAE,CAAC;YAC/B,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YACzC,OAAO;QACT,CAAC;IACH,CAAC;IACD,MAAM,IAAI,GAAG,MAAM,+BAAkB,CAAC,qBAAqB,CAAC,OAAO,CAAC,OAAO,CAAC,aAAa,IAAI,EAAE,CAAC,CAAC;IACjG,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAC1C,OAAO;IACT,CAAC;IACD,MAAM,OAAO,GAAG,MAAM,YAAO,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,2BAA4B,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC;IACnG,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;QAC/C,OAAO;IACT,CAAC;IACD,OAAO,CAAC,SAAS,GAAG,2BAA4B,CAAC,SAAS,IAAI,OAAO,CAAC,SAAS,CAAC;IAChF,OAAO,CAAC,IAAI,GAAG,2BAA4B,CAAC,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IACjE,OAAO,CAAC,KAAK,GAAG,2BAA4B,CAAC,KAAK,IAAI,OAAO,CAAC,KAAK,CAAC;IACpE,OAAO,CAAC,WAAW,GAAG,2BAA4B,CAAC,WAAW,IAAI,OAAO,CAAC,WAAW,CAAC;IACtF,MAAM,OAAO,CAAC,IAAI,EAAE,CAAC;IACrB,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;AACzB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DetailProductPage.d.ts","sourceRoot":"","sources":["../../../module/page/DetailProductPage.tsx"],"names":[],"mappings":"AAKA,wBAAgB,iBAAiB,4CAoDhC"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.DetailProductPage = DetailProductPage;
|
|
7
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
8
|
+
const axios_1 = __importDefault(require("axios"));
|
|
9
|
+
const react_1 = require("react");
|
|
10
|
+
const config_ui_1 = require("../config-ui");
|
|
11
|
+
const react_router_1 = require("react-router");
|
|
12
|
+
function DetailProductPage() {
|
|
13
|
+
let data = (0, react_router_1.useLoaderData)();
|
|
14
|
+
const [loading, setLoading] = (0, react_1.useState)(false);
|
|
15
|
+
const [product, setProduct] = (0, react_1.useState)();
|
|
16
|
+
async function getData() {
|
|
17
|
+
try {
|
|
18
|
+
setLoading(true);
|
|
19
|
+
const res = await axios_1.default.get(`/api/product/${data.id}`, {
|
|
20
|
+
headers: {
|
|
21
|
+
Authorization: config_ui_1.CONFIG_UI_PRODUCT.getAuthHeader()
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
setProduct(res.data);
|
|
25
|
+
}
|
|
26
|
+
catch (err) {
|
|
27
|
+
alert(err?.response.data.toString());
|
|
28
|
+
}
|
|
29
|
+
finally {
|
|
30
|
+
setLoading(false);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
async function deleteData() {
|
|
34
|
+
if (!confirm(`Delete this product?`)) {
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
try {
|
|
38
|
+
const res = await axios_1.default.delete(`/api/product/${data.id}`, {
|
|
39
|
+
headers: {
|
|
40
|
+
Authorization: config_ui_1.CONFIG_UI_PRODUCT.getAuthHeader()
|
|
41
|
+
}
|
|
42
|
+
});
|
|
43
|
+
window.location.href = '/my-products';
|
|
44
|
+
}
|
|
45
|
+
catch (err) {
|
|
46
|
+
alert(err?.response.data.toString());
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
(0, react_1.useEffect)(() => {
|
|
50
|
+
getData();
|
|
51
|
+
}, []);
|
|
52
|
+
return ((0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)("div", { children: (0, jsx_runtime_1.jsx)("pre", { style: { fontSize: 10 }, children: JSON.stringify(product, null, 2) }) }), (0, jsx_runtime_1.jsx)("a", { href: `/my-product/${data.id}/edit`, children: "Edit" }), (0, jsx_runtime_1.jsx)("button", { onClick: deleteData, children: "Delete?" })] }));
|
|
53
|
+
}
|
|
54
|
+
//# sourceMappingURL=DetailProductPage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DetailProductPage.js","sourceRoot":"","sources":["../../../module/page/DetailProductPage.tsx"],"names":[],"mappings":";;;;;AAKA,8CAoDC;;AAzDD,kDAA0B;AAC1B,iCAA4C;AAC5C,4CAAiD;AACjD,+CAA6C;AAE7C,SAAgB,iBAAiB;IAC/B,IAAI,IAAI,GAAG,IAAA,4BAAa,GAAE,CAAC;IAC3B,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,IAAA,gBAAQ,EAAU,KAAK,CAAC,CAAC;IACvD,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,IAAA,gBAAQ,GAAO,CAAC;IAE9C,KAAK,UAAU,OAAO;QACpB,IAAI,CAAC;YACH,UAAU,CAAC,IAAI,CAAC,CAAC;YACjB,MAAM,GAAG,GAAG,MAAM,eAAK,CAAC,GAAG,CAAC,gBAAgB,IAAI,CAAC,EAAE,EAAE,EAAE;gBACrD,OAAO,EAAE;oBACP,aAAa,EAAE,6BAAiB,CAAC,aAAa,EAAE;iBACjD;aACF,CAAC,CAAC;YACH,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACvB,CAAC;QAAC,OAAO,GAAQ,EAAE,CAAC;YAClB,KAAK,CAAC,GAAG,EAAE,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QACvC,CAAC;gBAAS,CAAC;YACT,UAAU,CAAC,KAAK,CAAC,CAAC;QACpB,CAAC;IACH,CAAC;IAED,KAAK,UAAU,UAAU;QACvB,IAAI,CAAC,OAAO,CAAC,sBAAsB,CAAC,EAAE,CAAC;YACrC,OAAO;QACT,CAAC;QACD,IAAI,CAAC;YACH,MAAM,GAAG,GAAG,MAAM,eAAK,CAAC,MAAM,CAAC,gBAAgB,IAAI,CAAC,EAAE,EAAE,EAAE;gBACxD,OAAO,EAAE;oBACP,aAAa,EAAE,6BAAiB,CAAC,aAAa,EAAE;iBACjD;aACF,CAAC,CAAC;YACH,MAAM,CAAC,QAAQ,CAAC,IAAI,GAAG,cAAc,CAAC;QACxC,CAAC;QAAC,OAAO,GAAQ,EAAE,CAAC;YAClB,KAAK,CAAC,GAAG,EAAE,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QACvC,CAAC;IACH,CAAC;IAED,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,OAAO,EAAE,CAAC;IACZ,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,CACL,4CACE,0CACE,gCAAK,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,YAAG,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,GAAO,GAClE,EACN,8BAAG,IAAI,EAAE,eAAe,IAAI,CAAC,EAAE,OAAO,qBAAU,EAChD,mCAAQ,OAAO,EAAE,UAAU,wBAElB,IACL,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EditProductPage.d.ts","sourceRoot":"","sources":["../../../module/page/EditProductPage.tsx"],"names":[],"mappings":"AAKA,wBAAgB,eAAe,4CA0F9B"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.EditProductPage = EditProductPage;
|
|
7
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
8
|
+
const axios_1 = __importDefault(require("axios"));
|
|
9
|
+
const react_1 = require("react");
|
|
10
|
+
const config_ui_1 = require("../config-ui");
|
|
11
|
+
const react_router_1 = require("react-router");
|
|
12
|
+
function EditProductPage() {
|
|
13
|
+
let data = (0, react_router_1.useLoaderData)();
|
|
14
|
+
const [loading, setLoading] = (0, react_1.useState)(false);
|
|
15
|
+
const [updated_product, setUpdatedProduct] = (0, react_1.useState)({
|
|
16
|
+
image_url: '',
|
|
17
|
+
name: '',
|
|
18
|
+
price: 0
|
|
19
|
+
});
|
|
20
|
+
async function updateProduct() {
|
|
21
|
+
try {
|
|
22
|
+
setLoading(true);
|
|
23
|
+
const res = await axios_1.default.put(`/api/product/${data.id}`, updated_product, {
|
|
24
|
+
headers: {
|
|
25
|
+
Authorization: config_ui_1.CONFIG_UI_PRODUCT.getAuthHeader()
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
alert('Success');
|
|
29
|
+
window.location.href = '/my-products';
|
|
30
|
+
}
|
|
31
|
+
catch (err) {
|
|
32
|
+
alert(err?.response.data.toString());
|
|
33
|
+
}
|
|
34
|
+
finally {
|
|
35
|
+
setLoading(false);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
async function getData() {
|
|
39
|
+
try {
|
|
40
|
+
setLoading(true);
|
|
41
|
+
const res = await axios_1.default.get(`/api/product/${data.id}`, {
|
|
42
|
+
headers: {
|
|
43
|
+
Authorization: config_ui_1.CONFIG_UI_PRODUCT.getAuthHeader()
|
|
44
|
+
}
|
|
45
|
+
});
|
|
46
|
+
setUpdatedProduct({
|
|
47
|
+
image_url: res.data.image_url,
|
|
48
|
+
name: res.data.name,
|
|
49
|
+
price: +res.data.price,
|
|
50
|
+
description: res.data.description,
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
catch (err) {
|
|
54
|
+
alert(err?.response.data.toString());
|
|
55
|
+
}
|
|
56
|
+
finally {
|
|
57
|
+
setLoading(false);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
(0, react_1.useEffect)(() => {
|
|
61
|
+
getData();
|
|
62
|
+
}, []);
|
|
63
|
+
return ((0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)("div", { children: (0, jsx_runtime_1.jsx)("input", { value: updated_product.name, onChange: e => setUpdatedProduct({ ...updated_product, name: e.target.value }), placeholder: "Product Name" }) }), (0, jsx_runtime_1.jsx)("div", { children: (0, jsx_runtime_1.jsx)("input", { value: updated_product.image_url, onChange: e => setUpdatedProduct({ ...updated_product, image_url: e.target.value }), placeholder: "Image URL" }) }), (0, jsx_runtime_1.jsx)("div", { children: (0, jsx_runtime_1.jsx)("input", { value: updated_product.price, onChange: e => setUpdatedProduct({ ...updated_product, price: e.target.valueAsNumber }), placeholder: "Price", type: "number" }) }), (0, jsx_runtime_1.jsx)("div", { children: (0, jsx_runtime_1.jsx)("input", { value: updated_product.description, onChange: e => setUpdatedProduct({ ...updated_product, description: e.target.value }), placeholder: "Description (optional)" }) }), (0, jsx_runtime_1.jsx)("div", { children: (0, jsx_runtime_1.jsx)("button", { onClick: updateProduct, children: loading ? 'Loading' : 'Update' }) })] }));
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=EditProductPage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EditProductPage.js","sourceRoot":"","sources":["../../../module/page/EditProductPage.tsx"],"names":[],"mappings":";;;;;AAKA,0CA0FC;;AA/FD,kDAA0B;AAC1B,iCAA4C;AAC5C,4CAAiD;AACjD,+CAA6C;AAE7C,SAAgB,eAAe;IAC7B,IAAI,IAAI,GAAG,IAAA,4BAAa,GAAE,CAAC;IAC3B,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,IAAA,gBAAQ,EAAU,KAAK,CAAC,CAAC;IACvD,MAAM,CAAC,eAAe,EAAE,iBAAiB,CAAC,GAAG,IAAA,gBAAQ,EAKlD;QACD,SAAS,EAAE,EAAE;QACb,IAAI,EAAE,EAAE;QACR,KAAK,EAAE,CAAC;KACT,CAAC,CAAC;IAEH,KAAK,UAAU,aAAa;QAC1B,IAAI,CAAC;YACH,UAAU,CAAC,IAAI,CAAC,CAAC;YACjB,MAAM,GAAG,GAAG,MAAM,eAAK,CAAC,GAAG,CAAC,gBAAgB,IAAI,CAAC,EAAE,EAAE,EAAE,eAAe,EAAE;gBACtE,OAAO,EAAE;oBACP,aAAa,EAAE,6BAAiB,CAAC,aAAa,EAAE;iBACjD;aACF,CAAC,CAAC;YACH,KAAK,CAAC,SAAS,CAAC,CAAC;YACjB,MAAM,CAAC,QAAQ,CAAC,IAAI,GAAG,cAAc,CAAC;QACxC,CAAC;QAAC,OAAO,GAAQ,EAAE,CAAC;YAClB,KAAK,CAAC,GAAG,EAAE,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QACvC,CAAC;gBAAS,CAAC;YACT,UAAU,CAAC,KAAK,CAAC,CAAC;QACpB,CAAC;IACH,CAAC;IAED,KAAK,UAAU,OAAO;QACpB,IAAI,CAAC;YACH,UAAU,CAAC,IAAI,CAAC,CAAC;YACjB,MAAM,GAAG,GAAG,MAAM,eAAK,CAAC,GAAG,CAAC,gBAAgB,IAAI,CAAC,EAAE,EAAE,EAAE;gBACrD,OAAO,EAAE;oBACP,aAAa,EAAE,6BAAiB,CAAC,aAAa,EAAE;iBACjD;aACF,CAAC,CAAC;YACH,iBAAiB,CAAC;gBAChB,SAAS,EAAE,GAAG,CAAC,IAAI,CAAC,SAAS;gBAC7B,IAAI,EAAE,GAAG,CAAC,IAAI,CAAC,IAAI;gBACnB,KAAK,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK;gBACtB,WAAW,EAAE,GAAG,CAAC,IAAI,CAAC,WAAW;aAClC,CAAC,CAAC;QACL,CAAC;QAAC,OAAO,GAAQ,EAAE,CAAC;YAClB,KAAK,CAAC,GAAG,EAAE,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QACvC,CAAC;gBAAS,CAAC;YACT,UAAU,CAAC,KAAK,CAAC,CAAC;QACpB,CAAC;IACH,CAAC;IAED,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,OAAO,EAAE,CAAC;IACZ,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,CACL,4CACE,0CACE,kCACE,KAAK,EAAE,eAAe,CAAC,IAAI,EAC3B,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,iBAAiB,CAAC,EAAE,GAAG,eAAe,EAAE,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,EAC9E,WAAW,EAAC,cAAc,GAAG,GAC3B,EACN,0CACE,kCACE,KAAK,EAAE,eAAe,CAAC,SAAS,EAChC,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,iBAAiB,CAAC,EAAE,GAAG,eAAe,EAAE,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,EACnF,WAAW,EAAC,WAAW,GAAG,GACxB,EACN,0CACE,kCACE,KAAK,EAAE,eAAe,CAAC,KAAK,EAC5B,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,iBAAiB,CAAC,EAAE,GAAG,eAAe,EAAE,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC,EACvF,WAAW,EAAC,OAAO,EACnB,IAAI,EAAC,QAAQ,GAAG,GACd,EACN,0CACE,kCACE,KAAK,EAAE,eAAe,CAAC,WAAW,EAClC,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,iBAAiB,CAAC,EAAE,GAAG,eAAe,EAAE,WAAW,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,EACrF,WAAW,EAAC,wBAAwB,GAAG,GACrC,EACN,0CACE,mCAAQ,OAAO,EAAE,aAAa,YAC3B,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,GACxB,GACL,IACF,CACP,CAAC;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MyProductsPage.d.ts","sourceRoot":"","sources":["../../../module/page/MyProductsPage.tsx"],"names":[],"mappings":"AAIA,wBAAgB,cAAc,
|
|
1
|
+
{"version":3,"file":"MyProductsPage.d.ts","sourceRoot":"","sources":["../../../module/page/MyProductsPage.tsx"],"names":[],"mappings":"AAIA,wBAAgB,cAAc,4CA6C7B"}
|
|
@@ -31,6 +31,6 @@ function MyProductsPage() {
|
|
|
31
31
|
(0, react_1.useEffect)(() => {
|
|
32
32
|
getData();
|
|
33
33
|
}, []);
|
|
34
|
-
return ((0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)("div", { children: (0, jsx_runtime_1.jsx)("a", { href: '/create-product', children: "+ Create Product" }) }), (0, jsx_runtime_1.jsx)("pre", { style: { fontSize: 10 }, children: JSON.stringify(
|
|
34
|
+
return ((0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)("div", { children: (0, jsx_runtime_1.jsx)("a", { href: '/create-product', children: "+ Create Product" }) }), (0, jsx_runtime_1.jsx)("div", { children: products.map(p => ((0, jsx_runtime_1.jsxs)("div", { style: { padding: 12, border: 'solid 1px #CCC' }, children: [(0, jsx_runtime_1.jsx)("div", { children: (0, jsx_runtime_1.jsx)("pre", { style: { fontSize: 10 }, children: JSON.stringify(p, null, 2) }) }), (0, jsx_runtime_1.jsx)("a", { href: `/my-product/${p.id}`, children: "View Detail" })] }, p.id))) })] }));
|
|
35
35
|
}
|
|
36
36
|
//# sourceMappingURL=MyProductsPage.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MyProductsPage.js","sourceRoot":"","sources":["../../../module/page/MyProductsPage.tsx"],"names":[],"mappings":";;;;;AAIA,
|
|
1
|
+
{"version":3,"file":"MyProductsPage.js","sourceRoot":"","sources":["../../../module/page/MyProductsPage.tsx"],"names":[],"mappings":";;;;;AAIA,wCA6CC;;AAjDD,kDAA0B;AAC1B,iCAA4C;AAC5C,4CAAiD;AAEjD,SAAgB,cAAc;IAC5B,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,IAAA,gBAAQ,EAAU,KAAK,CAAC,CAAC;IACvD,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,IAAA,gBAAQ,EAAQ,EAAE,CAAC,CAAC;IAEpD,KAAK,UAAU,OAAO;QACpB,IAAI,CAAC;YACH,UAAU,CAAC,IAAI,CAAC,CAAC;YACjB,MAAM,GAAG,GAAG,MAAM,eAAK,CAAC,GAAG,CAAC,eAAe,EAAE;gBAC3C,OAAO,EAAE;oBACP,aAAa,EAAE,6BAAiB,CAAC,aAAa,EAAE;iBACjD;aACF,CAAC,CAAC;YACH,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACxB,CAAC;QAAC,OAAO,GAAQ,EAAE,CAAC;YAClB,KAAK,CAAC,GAAG,EAAE,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QACvC,CAAC;gBAAS,CAAC;YACT,UAAU,CAAC,KAAK,CAAC,CAAC;QACpB,CAAC;IACH,CAAC;IAED,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,OAAO,EAAE,CAAC;IACZ,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,OAAO,CACL,4CACE,0CACE,8BAAG,IAAI,EAAE,iBAAiB,iCAAsB,GAC5C,EACN,0CAEI,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAChB,iCACE,KAAK,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,MAAM,EAAE,gBAAgB,EAAE,aAEhD,0CACE,gCAAK,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,YAAG,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,GAAO,GAC5D,EACN,8BAAG,IAAI,EAAE,eAAe,CAAC,CAAC,EAAE,EAAE,4BAAiB,KAJ1C,CAAC,CAAC,EAAE,CAKL,CACP,CAAC,GAEA,IACF,CACP,CAAC;AACJ,CAAC"}
|
package/dist/module/ui.d.ts
CHANGED
|
@@ -1,5 +1,33 @@
|
|
|
1
|
+
import { CreateProductPage } from "./page/CreateProductPage";
|
|
2
|
+
import { DetailProductPage } from "./page/DetailProductPage";
|
|
3
|
+
import { EditProductPage } from "./page/EditProductPage";
|
|
4
|
+
import { MyProductsPage } from "./page/MyProductsPage";
|
|
1
5
|
export declare const LIST_PAGE_PRODUCT: {
|
|
2
|
-
'/my-products':
|
|
3
|
-
|
|
6
|
+
'/my-products': {
|
|
7
|
+
Component: typeof MyProductsPage;
|
|
8
|
+
};
|
|
9
|
+
'/create-product': {
|
|
10
|
+
Component: typeof CreateProductPage;
|
|
11
|
+
};
|
|
12
|
+
'/my-product/:id/edit': {
|
|
13
|
+
loader: (p: {
|
|
14
|
+
params: {
|
|
15
|
+
id: number;
|
|
16
|
+
};
|
|
17
|
+
}) => Promise<{
|
|
18
|
+
id: number;
|
|
19
|
+
}>;
|
|
20
|
+
Component: typeof EditProductPage;
|
|
21
|
+
};
|
|
22
|
+
'/my-product/:id': {
|
|
23
|
+
loader: (p: {
|
|
24
|
+
params: {
|
|
25
|
+
id: number;
|
|
26
|
+
};
|
|
27
|
+
}) => Promise<{
|
|
28
|
+
id: number;
|
|
29
|
+
}>;
|
|
30
|
+
Component: typeof DetailProductPage;
|
|
31
|
+
};
|
|
4
32
|
};
|
|
5
33
|
//# sourceMappingURL=ui.d.ts.map
|
package/dist/module/ui.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ui.d.ts","sourceRoot":"","sources":["../../module/ui.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"ui.d.ts","sourceRoot":"","sources":["../../module/ui.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAEvD,eAAO,MAAM,iBAAiB;;;;;;;;oBAQR;YAAE,MAAM,EAAE;gBAAE,EAAE,EAAE,MAAM,CAAA;aAAE,CAAA;SAAE;;;;;;oBAM1B;YAAE,MAAM,EAAE;gBAAE,EAAE,EAAE,MAAM,CAAA;aAAE,CAAA;SAAE;;;;;CAK/C,CAAA"}
|
package/dist/module/ui.js
CHANGED
|
@@ -1,11 +1,28 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.LIST_PAGE_PRODUCT = void 0;
|
|
4
|
-
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
4
|
const CreateProductPage_1 = require("./page/CreateProductPage");
|
|
5
|
+
const DetailProductPage_1 = require("./page/DetailProductPage");
|
|
6
|
+
const EditProductPage_1 = require("./page/EditProductPage");
|
|
6
7
|
const MyProductsPage_1 = require("./page/MyProductsPage");
|
|
7
8
|
exports.LIST_PAGE_PRODUCT = {
|
|
8
|
-
'/my-products':
|
|
9
|
-
|
|
9
|
+
'/my-products': {
|
|
10
|
+
Component: MyProductsPage_1.MyProductsPage
|
|
11
|
+
},
|
|
12
|
+
'/create-product': {
|
|
13
|
+
Component: CreateProductPage_1.CreateProductPage
|
|
14
|
+
},
|
|
15
|
+
'/my-product/:id/edit': {
|
|
16
|
+
loader: async (p) => {
|
|
17
|
+
return { id: p.params.id };
|
|
18
|
+
},
|
|
19
|
+
Component: EditProductPage_1.EditProductPage
|
|
20
|
+
},
|
|
21
|
+
'/my-product/:id': {
|
|
22
|
+
loader: async (p) => {
|
|
23
|
+
return { id: p.params.id };
|
|
24
|
+
},
|
|
25
|
+
Component: DetailProductPage_1.DetailProductPage
|
|
26
|
+
}
|
|
10
27
|
};
|
|
11
28
|
//# sourceMappingURL=ui.js.map
|
package/dist/module/ui.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ui.js","sourceRoot":"","sources":["../../module/ui.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"ui.js","sourceRoot":"","sources":["../../module/ui.tsx"],"names":[],"mappings":";;;AAAA,gEAA6D;AAC7D,gEAA6D;AAC7D,4DAAyD;AACzD,0DAAuD;AAE1C,QAAA,iBAAiB,GAAG;IAC/B,cAAc,EAAE;QACd,SAAS,EAAE,+BAAc;KAC1B;IACD,iBAAiB,EAAE;QACjB,SAAS,EAAE,qCAAiB;KAC7B;IACD,sBAAsB,EAAE;QACtB,MAAM,EAAE,KAAK,EAAE,CAA6B,EAAE,EAAE;YAC9C,OAAO,EAAE,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC;QAC7B,CAAC;QACD,SAAS,EAAE,iCAAe;KAC3B;IACD,iBAAiB,EAAE;QACjB,MAAM,EAAE,KAAK,EAAE,CAA6B,EAAE,EAAE;YAC9C,OAAO,EAAE,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC;QAC7B,CAAC;QACD,SAAS,EAAE,qCAAiB;KAC7B;CACF,CAAA"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@moudle/-product",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.5",
|
|
4
4
|
"description": "",
|
|
5
5
|
"main": "dist/lib.js",
|
|
6
6
|
"publishConfig": {
|
|
@@ -41,7 +41,7 @@
|
|
|
41
41
|
"typescript": "^6.0.3"
|
|
42
42
|
},
|
|
43
43
|
"dependencies": {
|
|
44
|
-
"@moudle/start": "^0.0.
|
|
44
|
+
"@moudle/start": "^0.0.4",
|
|
45
45
|
"@react-router/express": "^7.15.1",
|
|
46
46
|
"axios": "^1.16.1",
|
|
47
47
|
"bcrypt": "^6.0.0",
|
|
@@ -50,9 +50,10 @@
|
|
|
50
50
|
"jsonwebtoken": "^9.0.3",
|
|
51
51
|
"mysql2": "^3.22.3",
|
|
52
52
|
"react-dom": "^19.2.6",
|
|
53
|
+
"react-router": "^7.15.1",
|
|
53
54
|
"react-router-dom": "^7.15.1",
|
|
54
55
|
"reflect-metadata": "^0.2.2",
|
|
55
56
|
"typeorm": "^0.3.29",
|
|
56
57
|
"zod": "^4.4.3"
|
|
57
58
|
}
|
|
58
|
-
}
|
|
59
|
+
}
|