@rolatech/angular-product 17.0.0 → 17.1.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/esm2022/index.mjs +5 -12
- package/esm2022/lib/components/index.mjs +12 -0
- package/esm2022/lib/components/product-action/product-action.component.mjs +25 -0
- package/esm2022/lib/components/product-info/product-info.component.mjs +17 -0
- package/esm2022/lib/components/product-item/product-item.component.mjs +17 -0
- package/esm2022/lib/components/product-manage-option-add/product-manage-option-add.component.mjs +68 -0
- package/esm2022/lib/components/product-manage-option-item/product-manage-option-item.component.mjs +49 -0
- package/esm2022/lib/components/product-manage-variant/product-manage-variant.component.mjs +115 -0
- package/esm2022/lib/components/product-mange-option-action/product-manage-option-action.component.mjs +22 -0
- package/esm2022/lib/components/product-mange-section-item/product-mange-section-item.component.mjs +89 -0
- package/esm2022/lib/components/product-media/product-media.component.mjs +34 -0
- package/esm2022/lib/components/product-option/product-option.component.mjs +23 -0
- package/esm2022/lib/components/product-owner-renderer/product-owner-renderer.component.mjs +20 -0
- package/esm2022/lib/components/product-pricing/product-pricing.component.mjs +31 -0
- package/esm2022/lib/components/product-section/product-section.component.mjs +26 -0
- package/esm2022/lib/interfaces/category.mjs +2 -0
- package/esm2022/lib/interfaces/index.mjs +2 -0
- package/esm2022/lib/interfaces/product.mjs +32 -0
- package/esm2022/lib/pages/product/product-category/product-category.component.mjs +70 -8
- package/esm2022/lib/pages/product/product-details/product-details.component.mjs +193 -0
- package/esm2022/lib/pages/product/product-details/selected.pipe.mjs +18 -0
- package/esm2022/lib/pages/product/product-index/product-index.component.mjs +39 -8
- package/esm2022/lib/pages/product/product-layout/product-layout.component.mjs +46 -8
- package/esm2022/lib/pages/product/product.routes.mjs +3 -3
- package/esm2022/lib/pages/product-manage/product-manage-content/product-manage-content.component.mjs +5 -5
- package/esm2022/lib/pages/product-manage/product-manage-create/product-manage-create.component.mjs +61 -0
- package/esm2022/lib/pages/product-manage/product-manage-index/product-manage-index.component.mjs +155 -0
- package/esm2022/lib/pages/product-manage/product-manage-info/product-manage-info.component.mjs +98 -8
- package/esm2022/lib/pages/product-manage/product-manage-inventory/product-manage-inventory.component.mjs +14 -0
- package/esm2022/lib/pages/product-manage/product-manage-item/product-manage-item.component.mjs +27 -0
- package/esm2022/lib/pages/product-manage/product-manage-item-header/product-manage-item-header.component.mjs +12 -0
- package/esm2022/lib/pages/product-manage/product-manage-layout/product-manage-layout.component.mjs +51 -8
- package/esm2022/lib/pages/product-manage/product-manage-media/product-manage-media.component.mjs +133 -8
- package/esm2022/lib/pages/product-manage/product-manage-options/product-manage-options.component.mjs +102 -0
- package/esm2022/lib/pages/product-manage/product-manage-pricing/product-manage-pricing.component.mjs +5 -5
- package/esm2022/lib/pages/product-manage/product-manage-schedule/product-manage-schedule.component.mjs +14 -0
- package/esm2022/lib/pages/product-manage/product-manage-sections/product-manage-sections.component.mjs +170 -0
- package/esm2022/lib/pages/product-manage/product-manage-variants/product-manage-variants.component.mjs +133 -0
- package/esm2022/lib/pages/product-manage/product-manage.routes.mjs +34 -4
- package/esm2022/lib/services/index.mjs +4 -0
- package/esm2022/lib/services/product-category.service.mjs +38 -0
- package/esm2022/provider.mjs +13 -0
- package/fesm2022/rolatech-angular-product-product-index.component-C_cbg95R.mjs +70 -0
- package/fesm2022/rolatech-angular-product-product-index.component-C_cbg95R.mjs.map +1 -0
- package/fesm2022/rolatech-angular-product.mjs +1697 -76
- package/fesm2022/rolatech-angular-product.mjs.map +1 -1
- package/index.d.ts +4 -11
- package/lib/components/index.d.ts +11 -0
- package/lib/components/product-action/product-action.component.d.ts +11 -0
- package/lib/components/product-info/product-info.component.d.ts +7 -0
- package/lib/components/product-item/product-item.component.d.ts +7 -0
- package/lib/components/product-manage-option-add/product-manage-option-add.component.d.ts +20 -0
- package/lib/components/product-manage-option-item/product-manage-option-item.component.d.ts +14 -0
- package/lib/components/product-manage-variant/product-manage-variant.component.d.ts +18 -0
- package/lib/components/product-mange-option-action/product-manage-option-action.component.d.ts +10 -0
- package/lib/components/product-mange-section-item/product-mange-section-item.component.d.ts +33 -0
- package/lib/components/product-media/product-media.component.d.ts +12 -0
- package/lib/components/product-option/product-option.component.d.ts +14 -0
- package/lib/components/product-owner-renderer/product-owner-renderer.component.d.ts +8 -0
- package/lib/components/product-pricing/product-pricing.component.d.ts +12 -0
- package/lib/components/product-section/product-section.component.d.ts +16 -0
- package/lib/interfaces/category.d.ts +16 -0
- package/lib/interfaces/index.d.ts +2 -0
- package/lib/interfaces/product.d.ts +91 -0
- package/lib/pages/product/product-category/product-category.component.d.ts +19 -2
- package/lib/pages/product/product-details/product-details.component.d.ts +39 -0
- package/lib/pages/product/product-details/selected.pipe.d.ts +8 -0
- package/lib/pages/product/product-index/product-index.component.d.ts +12 -2
- package/lib/pages/product/product-layout/product-layout.component.d.ts +15 -2
- package/lib/pages/product-manage/product-manage-content/product-manage-content.component.d.ts +1 -1
- package/lib/pages/product-manage/product-manage-create/product-manage-create.component.d.ts +11 -0
- package/lib/pages/product-manage/product-manage-index/product-manage-index.component.d.ts +38 -0
- package/lib/pages/product-manage/product-manage-info/product-manage-info.component.d.ts +26 -2
- package/lib/pages/product-manage/product-manage-inventory/product-manage-inventory.component.d.ts +5 -0
- package/lib/pages/product-manage/product-manage-item/product-manage-item.component.d.ts +12 -0
- package/lib/pages/product-manage/product-manage-item-header/product-manage-item-header.component.d.ts +5 -0
- package/lib/pages/product-manage/product-manage-layout/product-manage-layout.component.d.ts +22 -2
- package/lib/pages/product-manage/product-manage-media/product-manage-media.component.d.ts +26 -2
- package/lib/pages/product-manage/product-manage-options/product-manage-options.component.d.ts +17 -0
- package/lib/pages/product-manage/product-manage-pricing/product-manage-pricing.component.d.ts +1 -1
- package/lib/pages/product-manage/product-manage-schedule/product-manage-schedule.component.d.ts +5 -0
- package/lib/pages/product-manage/product-manage-sections/product-manage-sections.component.d.ts +29 -0
- package/lib/pages/product-manage/product-manage-variants/product-manage-variants.component.d.ts +27 -0
- package/lib/services/index.d.ts +3 -0
- package/lib/services/product-category.service.d.ts +12 -0
- package/package.json +1 -1
- package/provider.d.ts +2 -0
- package/themes/_default.scss +1 -1
- package/esm2022/lib/angular-product/angular-product.component.mjs +0 -12
- package/esm2022/lib/pages/product/product-detail/product-detail.component.mjs +0 -12
- package/esm2022/lib/pages/product-manage/product-manage-details/product-manage-details.component.mjs +0 -12
- package/lib/angular-product/angular-product.component.d.ts +0 -5
- package/lib/pages/product/product-detail/product-detail.component.d.ts +0 -5
- package/lib/pages/product-manage/product-manage-details/product-manage-details.component.d.ts +0 -5
package/esm2022/lib/pages/product-manage/product-manage-media/product-manage-media.component.mjs
CHANGED
|
@@ -1,12 +1,137 @@
|
|
|
1
|
-
import { Component } from '@angular/core';
|
|
2
|
-
import {
|
|
1
|
+
import { Component, inject } from '@angular/core';
|
|
2
|
+
import { MatDialog } from '@angular/material/dialog';
|
|
3
|
+
import { MatSnackBar } from '@angular/material/snack-bar';
|
|
4
|
+
import { ActivatedRoute } from '@angular/router';
|
|
5
|
+
import { ConfirmationDialogComponent, ImagePreviewDialogComponent, MediaListComponent, MediaListItemComponent, ToolbarComponent, } from '@rolatech/angular-components';
|
|
6
|
+
import { findLastIndex } from 'lodash';
|
|
7
|
+
import { ProductService } from '@rolatech/angular-services';
|
|
8
|
+
import { ProductManageContentComponent } from '../product-manage-content/product-manage-content.component';
|
|
9
|
+
import { ProductStatus } from '../../../interfaces';
|
|
3
10
|
import * as i0 from "@angular/core";
|
|
11
|
+
const SIZE = 10 * 1024 * 1024; // file slice size 10MB
|
|
4
12
|
export class ProductManageMediaComponent {
|
|
5
|
-
|
|
6
|
-
|
|
13
|
+
// productType: any = ProductType;
|
|
14
|
+
constructor() {
|
|
15
|
+
this.route = inject(ActivatedRoute);
|
|
16
|
+
this.productService = inject(ProductService);
|
|
17
|
+
this.dialog = inject(MatDialog);
|
|
18
|
+
this.snackBar = inject(MatSnackBar);
|
|
19
|
+
this.isUploading = false;
|
|
20
|
+
this.isLoading = false;
|
|
21
|
+
this.media = [];
|
|
22
|
+
this.status = ProductStatus;
|
|
23
|
+
this.id = this.route.parent?.snapshot.paramMap.get('id');
|
|
24
|
+
}
|
|
25
|
+
ngOnInit() {
|
|
26
|
+
this.find();
|
|
27
|
+
}
|
|
28
|
+
find() {
|
|
29
|
+
this.productService.get(this.id).subscribe({
|
|
30
|
+
next: (res) => {
|
|
31
|
+
this.media = res.data.media || [];
|
|
32
|
+
},
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
onImageClick(i) {
|
|
36
|
+
const dialogRef = this.dialog.open(ImagePreviewDialogComponent, {
|
|
37
|
+
maxWidth: '80vw',
|
|
38
|
+
maxHeight: '80vh',
|
|
39
|
+
height: '80%',
|
|
40
|
+
width: '80%',
|
|
41
|
+
panelClass: 'full-screen-modal',
|
|
42
|
+
data: {
|
|
43
|
+
media: this.media,
|
|
44
|
+
selected: i,
|
|
45
|
+
},
|
|
46
|
+
});
|
|
47
|
+
dialogRef.afterClosed().subscribe((result) => { });
|
|
48
|
+
}
|
|
49
|
+
createFileChunk(file, size = SIZE) {
|
|
50
|
+
const fileChunkList = [];
|
|
51
|
+
let cur = 0;
|
|
52
|
+
while (cur < file.size) {
|
|
53
|
+
fileChunkList.push({ file: file.slice(cur, cur + size) });
|
|
54
|
+
cur += size;
|
|
55
|
+
}
|
|
56
|
+
return fileChunkList;
|
|
57
|
+
}
|
|
58
|
+
onUploadMedia2(event) {
|
|
59
|
+
const file = event.target.files[0];
|
|
60
|
+
const reader = new FileReader();
|
|
61
|
+
reader.onload = (e) => { };
|
|
62
|
+
const fileChunkList = this.createFileChunk(file);
|
|
63
|
+
fileChunkList.forEach((item) => { });
|
|
64
|
+
}
|
|
65
|
+
onUploadMedia(event) {
|
|
66
|
+
const file = event.target.files[0];
|
|
67
|
+
// 5MB * 1024 * 1024 = 5242880
|
|
68
|
+
// if (file?.size > 5242880) {
|
|
69
|
+
// this.snackBar.open('尺寸过大, 请修改后上传');
|
|
70
|
+
// this.isUploading = false;
|
|
71
|
+
// return;
|
|
72
|
+
// }
|
|
73
|
+
if (file) {
|
|
74
|
+
const reader = new FileReader();
|
|
75
|
+
const formData = new FormData();
|
|
76
|
+
formData.append('file', file);
|
|
77
|
+
reader.readAsDataURL(file);
|
|
78
|
+
reader.onload = () => {
|
|
79
|
+
const img = new Image();
|
|
80
|
+
img.onload = () => {
|
|
81
|
+
this.media.push({
|
|
82
|
+
url: img.src,
|
|
83
|
+
alt: 'upload image',
|
|
84
|
+
width: img.width,
|
|
85
|
+
height: img.height,
|
|
86
|
+
});
|
|
87
|
+
this.isUploading = true;
|
|
88
|
+
};
|
|
89
|
+
img.src = reader.result; // This is the data URL
|
|
90
|
+
};
|
|
91
|
+
this.productService.uploadMedia(this.id, formData).subscribe({
|
|
92
|
+
next: (res) => {
|
|
93
|
+
this.isUploading = false;
|
|
94
|
+
const index = findLastIndex(this.media);
|
|
95
|
+
// Replace item at index using native splice
|
|
96
|
+
this.media.splice(index, 1, res.data);
|
|
97
|
+
},
|
|
98
|
+
error: (e) => {
|
|
99
|
+
this.isUploading = false;
|
|
100
|
+
this.snackBar.open('上传失败: ' + e.message);
|
|
101
|
+
},
|
|
102
|
+
});
|
|
103
|
+
reader.onerror = (error) => {
|
|
104
|
+
this.isUploading = false;
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
onMediaDelete(item) {
|
|
109
|
+
const dialogRef = this.dialog.open(ConfirmationDialogComponent, {
|
|
110
|
+
width: '400px',
|
|
111
|
+
data: {
|
|
112
|
+
title: '删除图片',
|
|
113
|
+
message: '确定删除这张商品图片吗?',
|
|
114
|
+
},
|
|
115
|
+
});
|
|
116
|
+
dialogRef.afterClosed().subscribe((result) => {
|
|
117
|
+
if (result) {
|
|
118
|
+
this.productService.deleteMedia(this.id, item.id).subscribe({
|
|
119
|
+
next: (res) => {
|
|
120
|
+
this.media = this.media.filter((m) => m.id !== item.id);
|
|
121
|
+
this.snackBar.open('删除成功');
|
|
122
|
+
},
|
|
123
|
+
error: (e) => {
|
|
124
|
+
this.snackBar.open(e.message);
|
|
125
|
+
},
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: ProductManageMediaComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
131
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.4", type: ProductManageMediaComponent, isStandalone: true, selector: "rolatech-product-manage-media", ngImport: i0, template: "<rolatech-product-manage-content>\n <rolatech-toolbar title=\"\u56FE\u7247\u4FE1\u606F\" class=\"hidden md:block\" divider></rolatech-toolbar>\n <div>\n <p>*\u56FE\u7247\u6587\u4EF6\u5927\u5C0F\u9650\u5236\u57285MB\u4EE5\u4E0B*</p>\n <rolatech-media-list (upload)=\"onUploadMedia($event)\" [isUploading]=\"isUploading\">\n @for (item of media; track item; let i = $index) {\n <rolatech-media-list-item\n [media]=\"item\"\n (mediaItemClick)=\"onImageClick(i)\"\n (deleteMedia)=\"onMediaDelete(item)\"\n ></rolatech-media-list-item>\n }\n </rolatech-media-list>\n </div>\n</rolatech-product-manage-content>\n", styles: [""], dependencies: [{ kind: "component", type: MediaListComponent, selector: "rolatech-media-list", inputs: ["isUploading", "media", "showAdd"], outputs: ["mediaItemClick", "upload"] }, { kind: "component", type: MediaListItemComponent, selector: "rolatech-media-list-item", inputs: ["media", "uploadProgress"], outputs: ["mediaItemClick", "deleteMedia"] }, { kind: "component", type: ToolbarComponent, selector: "rolatech-toolbar", inputs: ["title", "subtitle", "back", "link", "large", "divider"] }, { kind: "component", type: ProductManageContentComponent, selector: "rolatech-product-manage-content" }] }); }
|
|
7
132
|
}
|
|
8
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.
|
|
133
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: ProductManageMediaComponent, decorators: [{
|
|
9
134
|
type: Component,
|
|
10
|
-
args: [{ selector: '
|
|
11
|
-
}] });
|
|
12
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1tYW5hZ2UtbWVkaWEuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLXByb2R1Y3Qvc3JjL2xpYi9wYWdlcy9wcm9kdWN0LW1hbmFnZS9wcm9kdWN0LW1hbmFnZS1tZWRpYS9wcm9kdWN0LW1hbmFnZS1tZWRpYS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItcHJvZHVjdC9zcmMvbGliL3BhZ2VzL3Byb2R1Y3QtbWFuYWdlL3Byb2R1Y3QtbWFuYWdlLW1lZGlhL3Byb2R1Y3QtbWFuYWdlLW1lZGlhLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQVMvQyxNQUFNLE9BQU8sMkJBQTJCOzhHQUEzQiwyQkFBMkI7a0dBQTNCLDJCQUEyQixvRkNWeEMsc0NBQ0EseURES1ksWUFBWTs7MkZBSVgsMkJBQTJCO2tCQVB2QyxTQUFTOytCQUNFLDBCQUEwQixjQUN4QixJQUFJLFdBQ1AsQ0FBQyxZQUFZLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2xpYi1wcm9kdWN0LW1hbmFnZS1tZWRpYScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICB0ZW1wbGF0ZVVybDogJy4vcHJvZHVjdC1tYW5hZ2UtbWVkaWEuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vcHJvZHVjdC1tYW5hZ2UtbWVkaWEuY29tcG9uZW50LnNjc3MnLFxufSlcbmV4cG9ydCBjbGFzcyBQcm9kdWN0TWFuYWdlTWVkaWFDb21wb25lbnQge31cbiIsIjxwPnByb2R1Y3QtbWFuYWdlLW1lZGlhIHdvcmtzITwvcD5cbiJdfQ==
|
|
135
|
+
args: [{ selector: 'rolatech-product-manage-media', standalone: true, imports: [MediaListComponent, MediaListItemComponent, ToolbarComponent, ProductManageContentComponent], template: "<rolatech-product-manage-content>\n <rolatech-toolbar title=\"\u56FE\u7247\u4FE1\u606F\" class=\"hidden md:block\" divider></rolatech-toolbar>\n <div>\n <p>*\u56FE\u7247\u6587\u4EF6\u5927\u5C0F\u9650\u5236\u57285MB\u4EE5\u4E0B*</p>\n <rolatech-media-list (upload)=\"onUploadMedia($event)\" [isUploading]=\"isUploading\">\n @for (item of media; track item; let i = $index) {\n <rolatech-media-list-item\n [media]=\"item\"\n (mediaItemClick)=\"onImageClick(i)\"\n (deleteMedia)=\"onMediaDelete(item)\"\n ></rolatech-media-list-item>\n }\n </rolatech-media-list>\n </div>\n</rolatech-product-manage-content>\n" }]
|
|
136
|
+
}], ctorParameters: () => [] });
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-manage-media.component.js","sourceRoot":"","sources":["../../../../../../../../libs/angular-product/src/lib/pages/product-manage/product-manage-media/product-manage-media.component.ts","../../../../../../../../libs/angular-product/src/lib/pages/product-manage/product-manage-media/product-manage-media.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, OnInit } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport { MatSnackBar } from '@angular/material/snack-bar';\nimport { ActivatedRoute } from '@angular/router';\nimport { Media } from '@rolatech/angular-common';\nimport {\n  ConfirmationDialogComponent,\n  ImagePreviewDialogComponent,\n  MediaListComponent,\n  MediaListItemComponent,\n  ToolbarComponent,\n} from '@rolatech/angular-components';\nimport { findLastIndex } from 'lodash';\nimport { ProductService } from '@rolatech/angular-services';\nimport { ProductManageContentComponent } from '../product-manage-content/product-manage-content.component';\nimport { ProductStatus } from '../../../interfaces';\n\nconst SIZE = 10 * 1024 * 1024; // file slice size 10MB\n\n@Component({\n  selector: 'rolatech-product-manage-media',\n  standalone: true,\n  imports: [MediaListComponent, MediaListItemComponent, ToolbarComponent, ProductManageContentComponent],\n  templateUrl: './product-manage-media.component.html',\n  styleUrl: './product-manage-media.component.scss',\n})\nexport class ProductManageMediaComponent implements OnInit {\n  route = inject(ActivatedRoute);\n  productService = inject(ProductService);\n  dialog = inject(MatDialog);\n  snackBar = inject(MatSnackBar);\n  id: string;\n  isUploading = false;\n  isLoading = false;\n  media: Media[] = [];\n  status = ProductStatus;\n  // productType: any = ProductType;\n  constructor() {\n    this.id = this.route.parent?.snapshot.paramMap.get('id') as string;\n  }\n  ngOnInit(): void {\n    this.find();\n  }\n  find() {\n    this.productService.get(this.id).subscribe({\n      next: (res: any) => {\n        this.media = res.data.media || [];\n      },\n    });\n  }\n  onImageClick(i: any) {\n    const dialogRef = this.dialog.open(ImagePreviewDialogComponent, {\n      maxWidth: '80vw',\n      maxHeight: '80vh',\n      height: '80%',\n      width: '80%',\n      panelClass: 'full-screen-modal',\n      data: {\n        media: this.media,\n        selected: i,\n      },\n    });\n    dialogRef.afterClosed().subscribe((result) => {});\n  }\n  private createFileChunk(file: any, size = SIZE) {\n    const fileChunkList: any = [];\n    let cur = 0;\n    while (cur < file.size) {\n      fileChunkList.push({ file: file.slice(cur, cur + size) });\n      cur += size;\n    }\n    return fileChunkList;\n  }\n\n  onUploadMedia2(event: any) {\n    const file = event.target.files[0];\n    const reader = new FileReader();\n    reader.onload = (e) => {};\n\n    const fileChunkList = this.createFileChunk(file);\n    fileChunkList.forEach((item) => {});\n  }\n  onUploadMedia(event: any) {\n    const file = event.target.files[0];\n    // 5MB * 1024 * 1024 = 5242880\n    // if (file?.size > 5242880) {\n    //   this.snackBar.open('尺寸过大, 请修改后上传');\n    //   this.isUploading = false;\n    //   return;\n    // }\n\n    if (file) {\n      const reader = new FileReader();\n      const formData = new FormData();\n      formData.append('file', file);\n\n      reader.readAsDataURL(file);\n      reader.onload = () => {\n        const img: any = new Image();\n        img.onload = () => {\n          this.media.push({\n            url: img.src,\n            alt: 'upload image',\n            width: img.width,\n            height: img.height,\n          });\n\n          this.isUploading = true;\n        };\n        img.src = reader.result; // This is the data URL\n      };\n      this.productService.uploadMedia(this.id, formData).subscribe({\n        next: (res: any) => {\n          this.isUploading = false;\n          const index = findLastIndex(this.media);\n          // Replace item at index using native splice\n          this.media.splice(index, 1, res.data);\n        },\n        error: (e: any) => {\n          this.isUploading = false;\n          this.snackBar.open('上传失败: ' + e.message);\n        },\n      });\n      reader.onerror = (error) => {\n        this.isUploading = false;\n      };\n    }\n  }\n  onMediaDelete(item: any) {\n    const dialogRef = this.dialog.open(ConfirmationDialogComponent, {\n      width: '400px',\n      data: {\n        title: '删除图片',\n        message: '确定删除这张商品图片吗?',\n      },\n    });\n    dialogRef.afterClosed().subscribe((result) => {\n      if (result) {\n        this.productService.deleteMedia(this.id, item.id).subscribe({\n          next: (res) => {\n            this.media = this.media.filter((m) => m.id !== item.id);\n            this.snackBar.open('删除成功');\n          },\n          error: (e) => {\n            this.snackBar.open(e.message);\n          },\n        });\n      }\n    });\n  }\n}\n","<rolatech-product-manage-content>\n  <rolatech-toolbar title=\"图片信息\" class=\"hidden md:block\" divider></rolatech-toolbar>\n  <div>\n    <p>*图片文件大小限制在5MB以下*</p>\n    <rolatech-media-list (upload)=\"onUploadMedia($event)\" [isUploading]=\"isUploading\">\n      @for (item of media; track item; let i = $index) {\n        <rolatech-media-list-item\n          [media]=\"item\"\n          (mediaItemClick)=\"onImageClick(i)\"\n          (deleteMedia)=\"onMediaDelete(item)\"\n        ></rolatech-media-list-item>\n      }\n    </rolatech-media-list>\n  </div>\n</rolatech-product-manage-content>\n"]}
|
package/esm2022/lib/pages/product-manage/product-manage-options/product-manage-options.component.mjs
ADDED
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
import { Component, inject } from '@angular/core';
|
|
2
|
+
import { ProductManageContentComponent } from '../product-manage-content/product-manage-content.component';
|
|
3
|
+
import { AccordionComponent, AngularComponentsModule, BaseComponent, ConfirmationDialogComponent, PanelComponent, ToolbarComponent, } from '@rolatech/angular-components';
|
|
4
|
+
import { ProductService } from '@rolatech/angular-services';
|
|
5
|
+
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
6
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
7
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
8
|
+
import { AngularCommonModule } from '@rolatech/angular-common';
|
|
9
|
+
import { ProductManageOptionAddComponent, ProductManageOptionItemComponent } from '../../../components';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "@angular/material/button";
|
|
12
|
+
import * as i2 from "@angular/material/icon";
|
|
13
|
+
export class ProductManageOptionsComponent extends BaseComponent {
|
|
14
|
+
constructor() {
|
|
15
|
+
super(...arguments);
|
|
16
|
+
this.productService = inject(ProductService);
|
|
17
|
+
this.options = [];
|
|
18
|
+
this.add = false;
|
|
19
|
+
}
|
|
20
|
+
ngOnInit() {
|
|
21
|
+
this.id = this.route.parent?.snapshot.paramMap.get('id');
|
|
22
|
+
this.find();
|
|
23
|
+
}
|
|
24
|
+
find() {
|
|
25
|
+
this.productService.findOptions(this.id).subscribe({
|
|
26
|
+
next: (res) => {
|
|
27
|
+
this.options = res.data || [];
|
|
28
|
+
},
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
saveOption(option) {
|
|
32
|
+
this.productService.addOption(this.id, option).subscribe({
|
|
33
|
+
next: (res) => {
|
|
34
|
+
this.options.push(res.data);
|
|
35
|
+
this.add = false;
|
|
36
|
+
},
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
onUpdateOption(option) {
|
|
40
|
+
const options = {
|
|
41
|
+
title: '编辑选项',
|
|
42
|
+
cancelText: '取消',
|
|
43
|
+
confirmText: '确认',
|
|
44
|
+
data: {
|
|
45
|
+
option: option,
|
|
46
|
+
action: false,
|
|
47
|
+
},
|
|
48
|
+
component: ProductManageOptionAddComponent,
|
|
49
|
+
};
|
|
50
|
+
this.dialogService.open(options);
|
|
51
|
+
this.dialogService.confirmed().subscribe({
|
|
52
|
+
next: (res) => {
|
|
53
|
+
if (res) {
|
|
54
|
+
this.productService.updateOption(option.id, res).subscribe({
|
|
55
|
+
next: (res) => {
|
|
56
|
+
option.values = res.data.values;
|
|
57
|
+
},
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
},
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
onDeleteOption(option) {
|
|
64
|
+
const dialogRef = this.dialog.open(ConfirmationDialogComponent, {
|
|
65
|
+
width: '400px',
|
|
66
|
+
data: {
|
|
67
|
+
title: '删除选项',
|
|
68
|
+
message: `确定删除 ${option.name} 吗?`,
|
|
69
|
+
},
|
|
70
|
+
});
|
|
71
|
+
dialogRef.afterClosed().subscribe((result) => {
|
|
72
|
+
if (result) {
|
|
73
|
+
this.productService.deleteOption(option.id).subscribe({
|
|
74
|
+
next: (res) => {
|
|
75
|
+
const index = this.options.findIndex((item) => item.id === option.id);
|
|
76
|
+
this.options.splice(index, 1);
|
|
77
|
+
this.snackBarService.open('删除成功');
|
|
78
|
+
},
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: ProductManageOptionsComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
84
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.4", type: ProductManageOptionsComponent, isStandalone: true, selector: "rolatech-product-manage-options", usesInheritance: true, ngImport: i0, template: "<rolatech-product-manage-content>\n <rolatech-toolbar title=\"\u9009\u9879\" class=\"hidden md:block\" divider> </rolatech-toolbar>\n <div>\n @for (item of options; track $index) {\n <rolatech-product-manage-option-item\n [option]=\"item\"\n (delete)=\"onDeleteOption($event)\"\n (edit)=\"onUpdateOption($event)\"\n ></rolatech-product-manage-option-item>\n }\n <div class=\"mt-3\">\n @if (add) {\n <rolatech-product-manage-option-add\n (save)=\"saveOption($event)\"\n (cancel)=\"add = false\"\n ></rolatech-product-manage-option-add>\n } @else {\n <button mat-stroked-button (click)=\"add = true\">\n <mat-icon>add</mat-icon>\n <span>\u589E\u52A0</span>\n </button>\n }\n </div>\n </div>\n</rolatech-product-manage-content>\n", styles: [""], dependencies: [{ kind: "component", type: ProductManageContentComponent, selector: "rolatech-product-manage-content" }, { kind: "component", type: ToolbarComponent, selector: "rolatech-toolbar", inputs: ["title", "subtitle", "back", "link", "large", "divider"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i1.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: AngularCommonModule }, { kind: "ngmodule", type: AngularComponentsModule }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: ProductManageOptionItemComponent, selector: "rolatech-product-manage-option-item", inputs: ["option"], outputs: ["delete", "save", "edit"] }, { kind: "component", type: ProductManageOptionAddComponent, selector: "rolatech-product-manage-option-add", outputs: ["cancel", "save", "output"] }] }); }
|
|
85
|
+
}
|
|
86
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: ProductManageOptionsComponent, decorators: [{
|
|
87
|
+
type: Component,
|
|
88
|
+
args: [{ selector: 'rolatech-product-manage-options', standalone: true, imports: [
|
|
89
|
+
ProductManageContentComponent,
|
|
90
|
+
ToolbarComponent,
|
|
91
|
+
MatButtonModule,
|
|
92
|
+
MatFormFieldModule,
|
|
93
|
+
AngularCommonModule,
|
|
94
|
+
AngularComponentsModule,
|
|
95
|
+
MatIconModule,
|
|
96
|
+
AccordionComponent,
|
|
97
|
+
PanelComponent,
|
|
98
|
+
ProductManageOptionItemComponent,
|
|
99
|
+
ProductManageOptionAddComponent,
|
|
100
|
+
], template: "<rolatech-product-manage-content>\n <rolatech-toolbar title=\"\u9009\u9879\" class=\"hidden md:block\" divider> </rolatech-toolbar>\n <div>\n @for (item of options; track $index) {\n <rolatech-product-manage-option-item\n [option]=\"item\"\n (delete)=\"onDeleteOption($event)\"\n (edit)=\"onUpdateOption($event)\"\n ></rolatech-product-manage-option-item>\n }\n <div class=\"mt-3\">\n @if (add) {\n <rolatech-product-manage-option-add\n (save)=\"saveOption($event)\"\n (cancel)=\"add = false\"\n ></rolatech-product-manage-option-add>\n } @else {\n <button mat-stroked-button (click)=\"add = true\">\n <mat-icon>add</mat-icon>\n <span>\u589E\u52A0</span>\n </button>\n }\n </div>\n </div>\n</rolatech-product-manage-content>\n" }]
|
|
101
|
+
}] });
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-manage-options.component.js","sourceRoot":"","sources":["../../../../../../../../libs/angular-product/src/lib/pages/product-manage/product-manage-options/product-manage-options.component.ts","../../../../../../../../libs/angular-product/src/lib/pages/product-manage/product-manage-options/product-manage-options.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, OnInit, signal } from '@angular/core';\nimport { ProductManageContentComponent } from '../product-manage-content/product-manage-content.component';\nimport {\n  AccordionComponent,\n  AngularComponentsModule,\n  BaseComponent,\n  ConfirmationDialogComponent,\n  PanelComponent,\n  ToolbarComponent,\n} from '@rolatech/angular-components';\nimport { ProductService } from '@rolatech/angular-services';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatButtonModule } from '@angular/material/button';\nimport { ProductOption } from '../../../interfaces';\nimport { AngularCommonModule } from '@rolatech/angular-common';\nimport { ProductManageOptionAddComponent, ProductManageOptionItemComponent } from '../../../components';\n\n@Component({\n  selector: 'rolatech-product-manage-options',\n  standalone: true,\n  imports: [\n    ProductManageContentComponent,\n    ToolbarComponent,\n    MatButtonModule,\n    MatFormFieldModule,\n    AngularCommonModule,\n    AngularComponentsModule,\n    MatIconModule,\n    AccordionComponent,\n    PanelComponent,\n    ProductManageOptionItemComponent,\n    ProductManageOptionAddComponent,\n  ],\n  templateUrl: './product-manage-options.component.html',\n  styleUrl: './product-manage-options.component.scss',\n})\nexport class ProductManageOptionsComponent extends BaseComponent implements OnInit {\n  productService = inject(ProductService);\n  options: ProductOption[] = [];\n\n  add = false;\n  ngOnInit(): void {\n    this.id = this.route.parent?.snapshot.paramMap.get('id') as string;\n    this.find();\n  }\n  find() {\n    this.productService.findOptions(this.id).subscribe({\n      next: (res) => {\n        this.options = res.data || [];\n      },\n    });\n  }\n  saveOption(option: ProductOption) {\n    this.productService.addOption(this.id, option).subscribe({\n      next: (res) => {\n        this.options.push(res.data);\n        this.add = false;\n      },\n    });\n  }\n  onUpdateOption(option: ProductOption) {\n    const options = {\n      title: '编辑选项',\n      cancelText: '取消',\n      confirmText: '确认',\n      data: {\n        option: option,\n        action: false,\n      },\n      component: ProductManageOptionAddComponent,\n    };\n    this.dialogService.open(options);\n    this.dialogService.confirmed().subscribe({\n      next: (res) => {\n        if (res) {\n          this.productService.updateOption(option.id, res).subscribe({\n            next: (res) => {\n              option.values = res.data.values;\n            },\n          });\n        }\n      },\n    });\n  }\n  onDeleteOption(option: ProductOption) {\n    const dialogRef = this.dialog.open(ConfirmationDialogComponent, {\n      width: '400px',\n      data: {\n        title: '删除选项',\n        message: `确定删除 ${option.name} 吗?`,\n      },\n    });\n\n    dialogRef.afterClosed().subscribe((result) => {\n      if (result) {\n        this.productService.deleteOption(option.id).subscribe({\n          next: (res) => {\n            const index = this.options.findIndex((item) => item.id === option.id);\n            this.options.splice(index, 1);\n            this.snackBarService.open('删除成功');\n          },\n        });\n      }\n    });\n  }\n}\n","<rolatech-product-manage-content>\n  <rolatech-toolbar title=\"选项\" class=\"hidden md:block\" divider> </rolatech-toolbar>\n  <div>\n    @for (item of options; track $index) {\n      <rolatech-product-manage-option-item\n        [option]=\"item\"\n        (delete)=\"onDeleteOption($event)\"\n        (edit)=\"onUpdateOption($event)\"\n      ></rolatech-product-manage-option-item>\n    }\n    <div class=\"mt-3\">\n      @if (add) {\n        <rolatech-product-manage-option-add\n          (save)=\"saveOption($event)\"\n          (cancel)=\"add = false\"\n        ></rolatech-product-manage-option-add>\n      } @else {\n        <button mat-stroked-button (click)=\"add = true\">\n          <mat-icon>add</mat-icon>\n          <span>增加</span>\n        </button>\n      }\n    </div>\n  </div>\n</rolatech-product-manage-content>\n"]}
|
package/esm2022/lib/pages/product-manage/product-manage-pricing/product-manage-pricing.component.mjs
CHANGED
|
@@ -2,11 +2,11 @@ import { Component } from '@angular/core';
|
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export class ProductManagePricingComponent {
|
|
5
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.
|
|
6
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.
|
|
5
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: ProductManagePricingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
6
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.4", type: ProductManagePricingComponent, isStandalone: true, selector: "rolatech-product-manage-pricing", ngImport: i0, template: "<p>product-manage-pricing works!</p>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
|
|
7
7
|
}
|
|
8
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.
|
|
8
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: ProductManagePricingComponent, decorators: [{
|
|
9
9
|
type: Component,
|
|
10
|
-
args: [{ selector: '
|
|
10
|
+
args: [{ selector: 'rolatech-product-manage-pricing', standalone: true, imports: [CommonModule], template: "<p>product-manage-pricing works!</p>\n" }]
|
|
11
11
|
}] });
|
|
12
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1tYW5hZ2UtcHJpY2luZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItcHJvZHVjdC9zcmMvbGliL3BhZ2VzL3Byb2R1Y3QtbWFuYWdlL3Byb2R1Y3QtbWFuYWdlLXByaWNpbmcvcHJvZHVjdC1tYW5hZ2UtcHJpY2luZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItcHJvZHVjdC9zcmMvbGliL3BhZ2VzL3Byb2R1Y3QtbWFuYWdlL3Byb2R1Y3QtbWFuYWdlLXByaWNpbmcvcHJvZHVjdC1tYW5hZ2UtcHJpY2luZy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7QUFTL0MsTUFBTSxPQUFPLDZCQUE2Qjs4R0FBN0IsNkJBQTZCO2tHQUE3Qiw2QkFBNkIsMkZDVjFDLHdDQUNBLHlEREtZLFlBQVk7OzJGQUlYLDZCQUE2QjtrQkFQekMsU0FBUzsrQkFDRSxpQ0FBaUMsY0FDL0IsSUFBSSxXQUNQLENBQUMsWUFBWSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdyb2xhdGVjaC1wcm9kdWN0LW1hbmFnZS1wcmljaW5nJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIHRlbXBsYXRlVXJsOiAnLi9wcm9kdWN0LW1hbmFnZS1wcmljaW5nLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmw6ICcuL3Byb2R1Y3QtbWFuYWdlLXByaWNpbmcuY29tcG9uZW50LnNjc3MnLFxufSlcbmV4cG9ydCBjbGFzcyBQcm9kdWN0TWFuYWdlUHJpY2luZ0NvbXBvbmVudCB7fVxuIiwiPHA+cHJvZHVjdC1tYW5hZ2UtcHJpY2luZyB3b3JrcyE8L3A+XG4iXX0=
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import { AngularCommonModule } from '@rolatech/angular-common';
|
|
3
|
+
import { AngularComponentsModule, ToolbarComponent } from '@rolatech/angular-components';
|
|
4
|
+
import { ProductManageContentComponent } from '../product-manage-content/product-manage-content.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class ProductManageScheduleComponent {
|
|
7
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: ProductManageScheduleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
8
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.4", type: ProductManageScheduleComponent, isStandalone: true, selector: "rolatech-product-manage-schedule", ngImport: i0, template: "<rolatech-product-manage-content>\n <rolatech-toolbar title=\"\u53D1\u5E03\u8BBE\u7F6E\" class=\"hidden md:block\" divider> </rolatech-toolbar>\n <div></div>\n</rolatech-product-manage-content>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: AngularCommonModule }, { kind: "ngmodule", type: AngularComponentsModule }, { kind: "component", type: ToolbarComponent, selector: "rolatech-toolbar", inputs: ["title", "subtitle", "back", "link", "large", "divider"] }, { kind: "component", type: ProductManageContentComponent, selector: "rolatech-product-manage-content" }] }); }
|
|
9
|
+
}
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: ProductManageScheduleComponent, decorators: [{
|
|
11
|
+
type: Component,
|
|
12
|
+
args: [{ selector: 'rolatech-product-manage-schedule', standalone: true, imports: [AngularCommonModule, AngularComponentsModule, ToolbarComponent, ProductManageContentComponent], template: "<rolatech-product-manage-content>\n <rolatech-toolbar title=\"\u53D1\u5E03\u8BBE\u7F6E\" class=\"hidden md:block\" divider> </rolatech-toolbar>\n <div></div>\n</rolatech-product-manage-content>\n" }]
|
|
13
|
+
}] });
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1tYW5hZ2Utc2NoZWR1bGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLXByb2R1Y3Qvc3JjL2xpYi9wYWdlcy9wcm9kdWN0LW1hbmFnZS9wcm9kdWN0LW1hbmFnZS1zY2hlZHVsZS9wcm9kdWN0LW1hbmFnZS1zY2hlZHVsZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItcHJvZHVjdC9zcmMvbGliL3BhZ2VzL3Byb2R1Y3QtbWFuYWdlL3Byb2R1Y3QtbWFuYWdlLXNjaGVkdWxlL3Byb2R1Y3QtbWFuYWdlLXNjaGVkdWxlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDL0QsT0FBTyxFQUFFLHVCQUF1QixFQUFFLGdCQUFnQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDekYsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sNERBQTRELENBQUM7O0FBUzNHLE1BQU0sT0FBTyw4QkFBOEI7OEdBQTlCLDhCQUE4QjtrR0FBOUIsOEJBQThCLDRGQ1ozQyx1TUFJQSx5RERJWSxtQkFBbUIsOEJBQUUsdUJBQXVCLCtCQUFFLGdCQUFnQixnSUFBRSw2QkFBNkI7OzJGQUk1Riw4QkFBOEI7a0JBUDFDLFNBQVM7K0JBQ0Usa0NBQWtDLGNBQ2hDLElBQUksV0FDUCxDQUFDLG1CQUFtQixFQUFFLHVCQUF1QixFQUFFLGdCQUFnQixFQUFFLDZCQUE2QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBbmd1bGFyQ29tbW9uTW9kdWxlIH0gZnJvbSAnQHJvbGF0ZWNoL2FuZ3VsYXItY29tbW9uJztcbmltcG9ydCB7IEFuZ3VsYXJDb21wb25lbnRzTW9kdWxlLCBUb29sYmFyQ29tcG9uZW50IH0gZnJvbSAnQHJvbGF0ZWNoL2FuZ3VsYXItY29tcG9uZW50cyc7XG5pbXBvcnQgeyBQcm9kdWN0TWFuYWdlQ29udGVudENvbXBvbmVudCB9IGZyb20gJy4uL3Byb2R1Y3QtbWFuYWdlLWNvbnRlbnQvcHJvZHVjdC1tYW5hZ2UtY29udGVudC5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdyb2xhdGVjaC1wcm9kdWN0LW1hbmFnZS1zY2hlZHVsZScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtBbmd1bGFyQ29tbW9uTW9kdWxlLCBBbmd1bGFyQ29tcG9uZW50c01vZHVsZSwgVG9vbGJhckNvbXBvbmVudCwgUHJvZHVjdE1hbmFnZUNvbnRlbnRDb21wb25lbnRdLFxuICB0ZW1wbGF0ZVVybDogJy4vcHJvZHVjdC1tYW5hZ2Utc2NoZWR1bGUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vcHJvZHVjdC1tYW5hZ2Utc2NoZWR1bGUuY29tcG9uZW50LnNjc3MnLFxufSlcbmV4cG9ydCBjbGFzcyBQcm9kdWN0TWFuYWdlU2NoZWR1bGVDb21wb25lbnQge31cbiIsIjxyb2xhdGVjaC1wcm9kdWN0LW1hbmFnZS1jb250ZW50PlxuICA8cm9sYXRlY2gtdG9vbGJhciB0aXRsZT1cIuWPkeW4g+iuvue9rlwiIGNsYXNzPVwiaGlkZGVuIG1kOmJsb2NrXCIgZGl2aWRlcj4gPC9yb2xhdGVjaC10b29sYmFyPlxuICA8ZGl2PjwvZGl2PlxuPC9yb2xhdGVjaC1wcm9kdWN0LW1hbmFnZS1jb250ZW50PlxuIl19
|
|
@@ -0,0 +1,170 @@
|
|
|
1
|
+
import { Component, inject } from '@angular/core';
|
|
2
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
3
|
+
import { MatDialog } from '@angular/material/dialog';
|
|
4
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
5
|
+
import { MatSnackBar } from '@angular/material/snack-bar';
|
|
6
|
+
import { ActivatedRoute } from '@angular/router';
|
|
7
|
+
import { ToolbarComponent, ConfirmationDialogComponent } from '@rolatech/angular-components';
|
|
8
|
+
import { remove } from 'lodash';
|
|
9
|
+
import { ProductStatus, ProductType } from '../../../interfaces';
|
|
10
|
+
import { ProductService } from '@rolatech/angular-services';
|
|
11
|
+
import { ProductManageContentComponent } from '../product-manage-content/product-manage-content.component';
|
|
12
|
+
import { ProductManageSectionItemComponent } from '../../../components';
|
|
13
|
+
import * as i0 from "@angular/core";
|
|
14
|
+
import * as i1 from "@angular/material/button";
|
|
15
|
+
import * as i2 from "@angular/material/icon";
|
|
16
|
+
export class ProductManageSectionsComponent {
|
|
17
|
+
constructor() {
|
|
18
|
+
this.route = inject(ActivatedRoute);
|
|
19
|
+
this.productService = inject(ProductService);
|
|
20
|
+
this.dialog = inject(MatDialog);
|
|
21
|
+
this.snackBar = inject(MatSnackBar);
|
|
22
|
+
this.isLoading = false;
|
|
23
|
+
this.isUploading = false;
|
|
24
|
+
this.sections = [];
|
|
25
|
+
this.status = ProductStatus;
|
|
26
|
+
this.productType = ProductType;
|
|
27
|
+
this.id = this.route.parent?.snapshot.paramMap.get('id');
|
|
28
|
+
}
|
|
29
|
+
ngOnInit() {
|
|
30
|
+
this.find();
|
|
31
|
+
}
|
|
32
|
+
find() {
|
|
33
|
+
this.productService.findSections(this.id).subscribe({
|
|
34
|
+
next: (res) => {
|
|
35
|
+
if (res.data) {
|
|
36
|
+
this.sections = res.data;
|
|
37
|
+
}
|
|
38
|
+
},
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
addSection() {
|
|
42
|
+
if (!this.sections) {
|
|
43
|
+
this.sections = [];
|
|
44
|
+
}
|
|
45
|
+
this.productService
|
|
46
|
+
.addSection(this.id, {
|
|
47
|
+
title: '',
|
|
48
|
+
description: '',
|
|
49
|
+
content: '',
|
|
50
|
+
media: [],
|
|
51
|
+
})
|
|
52
|
+
.subscribe({
|
|
53
|
+
next: (res) => {
|
|
54
|
+
const section = res.data;
|
|
55
|
+
this.sections.push({
|
|
56
|
+
id: section.id,
|
|
57
|
+
title: '',
|
|
58
|
+
description: '',
|
|
59
|
+
media: [],
|
|
60
|
+
});
|
|
61
|
+
},
|
|
62
|
+
error: (e) => {
|
|
63
|
+
this.snackBar.open(e.message);
|
|
64
|
+
},
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
onUploadSectionMedia(event) {
|
|
68
|
+
const section = event.section;
|
|
69
|
+
const sectionId = section.id;
|
|
70
|
+
const file = event.data.target.files[0];
|
|
71
|
+
if (file) {
|
|
72
|
+
const reader = new FileReader();
|
|
73
|
+
reader.readAsDataURL(file);
|
|
74
|
+
reader.onload = () => {
|
|
75
|
+
if (!section.media) {
|
|
76
|
+
section.media = [];
|
|
77
|
+
}
|
|
78
|
+
section.media.push({
|
|
79
|
+
url: reader.result,
|
|
80
|
+
alt: 'upload image',
|
|
81
|
+
});
|
|
82
|
+
section.isUploading = true;
|
|
83
|
+
const formData = new FormData();
|
|
84
|
+
formData.append('file', file);
|
|
85
|
+
this.productService.uploadSectionMedia(sectionId, formData).subscribe({
|
|
86
|
+
next: (res) => {
|
|
87
|
+
this.isUploading = false;
|
|
88
|
+
section.isUploading = false;
|
|
89
|
+
delete res.data.productSection;
|
|
90
|
+
section.media[section.media.length - 1].id = res.data.id;
|
|
91
|
+
},
|
|
92
|
+
error: (e) => {
|
|
93
|
+
this.isUploading = false;
|
|
94
|
+
this.snackBar.open('上传失败: ' + e.message);
|
|
95
|
+
},
|
|
96
|
+
});
|
|
97
|
+
};
|
|
98
|
+
reader.onerror = (error) => {
|
|
99
|
+
this.isUploading = false;
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
onDeleteSectionMedia(event) {
|
|
104
|
+
const dialogRef = this.dialog.open(ConfirmationDialogComponent, {
|
|
105
|
+
width: '400px',
|
|
106
|
+
data: {
|
|
107
|
+
title: '删除图片',
|
|
108
|
+
message: `确定删除吗?`,
|
|
109
|
+
},
|
|
110
|
+
});
|
|
111
|
+
dialogRef.afterClosed().subscribe((result) => {
|
|
112
|
+
if (result) {
|
|
113
|
+
const section = event.section;
|
|
114
|
+
const mediaId = event.media.id;
|
|
115
|
+
remove(section.media, {
|
|
116
|
+
id: mediaId,
|
|
117
|
+
});
|
|
118
|
+
this.productService.deleteSectionMedia(section.id, mediaId).subscribe({
|
|
119
|
+
next: (res) => {
|
|
120
|
+
// remove(section.media, {
|
|
121
|
+
// id: mediaId,
|
|
122
|
+
// });
|
|
123
|
+
},
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
onSectionSave(section) {
|
|
129
|
+
delete section.isUploading;
|
|
130
|
+
this.productService.updateSection(section.id, section).subscribe({
|
|
131
|
+
next: (res) => {
|
|
132
|
+
this.snackBar.open('保存成功');
|
|
133
|
+
},
|
|
134
|
+
error: (e) => {
|
|
135
|
+
this.snackBar.open(e.message);
|
|
136
|
+
},
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
onSectionDelete(section) {
|
|
140
|
+
const dialogRef = this.dialog.open(ConfirmationDialogComponent, {
|
|
141
|
+
width: '400px',
|
|
142
|
+
data: {
|
|
143
|
+
title: '删除详情',
|
|
144
|
+
message: '确定删除此详情吗?',
|
|
145
|
+
},
|
|
146
|
+
});
|
|
147
|
+
dialogRef.afterClosed().subscribe((result) => {
|
|
148
|
+
if (result) {
|
|
149
|
+
this.productService.deleteSection(section.id).subscribe({
|
|
150
|
+
next: (res) => {
|
|
151
|
+
this.snackBar.open(res.data);
|
|
152
|
+
remove(this.sections, {
|
|
153
|
+
id: section.id,
|
|
154
|
+
});
|
|
155
|
+
},
|
|
156
|
+
error: (e) => {
|
|
157
|
+
this.snackBar.open(e.message);
|
|
158
|
+
},
|
|
159
|
+
});
|
|
160
|
+
}
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: ProductManageSectionsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
164
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.4", type: ProductManageSectionsComponent, isStandalone: true, selector: "rolatech-product-manage-sections", ngImport: i0, template: "<rolatech-product-manage-content>\n <rolatech-toolbar title=\"\u8BE6\u60C5\" class=\"hidden md:block\" divider> </rolatech-toolbar>\n <div>\n <div>\n @for (section of sections; track section) {\n <rolatech-product-manage-section-item\n [section]=\"section\"\n (upload)=\"onUploadSectionMedia($event)\"\n (deleteMedia)=\"onDeleteSectionMedia($event)\"\n (save)=\"onSectionSave($event)\"\n (delete)=\"onSectionDelete($event)\"\n [actions]=\"true\"\n ></rolatech-product-manage-section-item>\n }\n </div>\n <button mat-stroked-button (click)=\"addSection()\" class=\"mt-3\">\n <mat-icon>add</mat-icon>\n <span>\u6DFB\u52A0\u8BE6\u60C5</span>\n </button>\n </div>\n</rolatech-product-manage-content>\n", styles: [""], dependencies: [{ kind: "component", type: ProductManageSectionItemComponent, selector: "rolatech-product-manage-section-item", inputs: ["isUploading", "section", "actions", "selectMedia"], outputs: ["upload", "delete", "save", "deleteMedia"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i1.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: ToolbarComponent, selector: "rolatech-toolbar", inputs: ["title", "subtitle", "back", "link", "large", "divider"] }, { kind: "component", type: ProductManageContentComponent, selector: "rolatech-product-manage-content" }] }); }
|
|
165
|
+
}
|
|
166
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: ProductManageSectionsComponent, decorators: [{
|
|
167
|
+
type: Component,
|
|
168
|
+
args: [{ selector: 'rolatech-product-manage-sections', standalone: true, imports: [ProductManageSectionItemComponent, MatButtonModule, MatIconModule, ToolbarComponent, ProductManageContentComponent], template: "<rolatech-product-manage-content>\n <rolatech-toolbar title=\"\u8BE6\u60C5\" class=\"hidden md:block\" divider> </rolatech-toolbar>\n <div>\n <div>\n @for (section of sections; track section) {\n <rolatech-product-manage-section-item\n [section]=\"section\"\n (upload)=\"onUploadSectionMedia($event)\"\n (deleteMedia)=\"onDeleteSectionMedia($event)\"\n (save)=\"onSectionSave($event)\"\n (delete)=\"onSectionDelete($event)\"\n [actions]=\"true\"\n ></rolatech-product-manage-section-item>\n }\n </div>\n <button mat-stroked-button (click)=\"addSection()\" class=\"mt-3\">\n <mat-icon>add</mat-icon>\n <span>\u6DFB\u52A0\u8BE6\u60C5</span>\n </button>\n </div>\n</rolatech-product-manage-content>\n" }]
|
|
169
|
+
}], ctorParameters: () => [] });
|
|
170
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"product-manage-sections.component.js","sourceRoot":"","sources":["../../../../../../../../libs/angular-product/src/lib/pages/product-manage/product-manage-sections/product-manage-sections.component.ts","../../../../../../../../libs/angular-product/src/lib/pages/product-manage/product-manage-sections/product-manage-sections.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, OnInit } from '@angular/core';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatDialog } from '@angular/material/dialog';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatSnackBar } from '@angular/material/snack-bar';\nimport { ActivatedRoute } from '@angular/router';\nimport { ToolbarComponent, ConfirmationDialogComponent } from '@rolatech/angular-components';\nimport { findIndex, remove } from 'lodash';\nimport { ProductSection, ProductStatus, ProductType } from '../../../interfaces';\nimport { ProductService } from '@rolatech/angular-services';\nimport { ProductManageContentComponent } from '../product-manage-content/product-manage-content.component';\nimport { ProductManageSectionItemComponent } from '../../../components';\n\n@Component({\n  selector: 'rolatech-product-manage-sections',\n  standalone: true,\n  imports: [ProductManageSectionItemComponent, MatButtonModule, MatIconModule, ToolbarComponent, ProductManageContentComponent],\n  templateUrl: './product-manage-sections.component.html',\n  styleUrl: './product-manage-sections.component.scss',\n})\nexport class ProductManageSectionsComponent implements OnInit {\n  route = inject(ActivatedRoute);\n  productService = inject(ProductService);\n  dialog = inject(MatDialog);\n  snackBar = inject(MatSnackBar);\n\n  id: string;\n  isLoading = false;\n  isUploading = false;\n  sections: ProductSection[] = [];\n  status = ProductStatus;\n  productType: any = ProductType;\n  constructor() {\n    this.id = this.route.parent?.snapshot.paramMap.get('id') as string;\n  }\n  ngOnInit(): void {\n    this.find();\n  }\n  find() {\n    this.productService.findSections(this.id).subscribe({\n      next: (res) => {\n        if (res.data) {\n          this.sections = res.data;\n        }\n      },\n    });\n  }\n  addSection() {\n    if (!this.sections) {\n      this.sections = [];\n    }\n    this.productService\n      .addSection(this.id, {\n        title: '',\n        description: '',\n        content: '',\n        media: [],\n      })\n      .subscribe({\n        next: (res: any) => {\n          const section = res.data;\n          this.sections.push({\n            id: section.id,\n            title: '',\n            description: '',\n            media: [],\n          });\n        },\n        error: (e) => {\n          this.snackBar.open(e.message);\n        },\n      });\n  }\n  onUploadSectionMedia(event: any) {\n    const section = event.section;\n    const sectionId = section.id;\n    const file = event.data.target.files[0];\n    if (file) {\n      const reader = new FileReader();\n      reader.readAsDataURL(file);\n      reader.onload = () => {\n        if (!section.media) {\n          section.media = [];\n        }\n        (section.media as any).push({\n          url: reader.result,\n          alt: 'upload image',\n        });\n        section.isUploading = true;\n        const formData = new FormData();\n        formData.append('file', file);\n        this.productService.uploadSectionMedia(sectionId, formData).subscribe({\n          next: (res: any) => {\n            this.isUploading = false;\n            section.isUploading = false;\n            delete res.data.productSection;\n            section.media[section.media.length - 1].id = res.data.id;\n          },\n          error: (e) => {\n            this.isUploading = false;\n            this.snackBar.open('上传失败: ' + e.message);\n          },\n        });\n      };\n      reader.onerror = (error) => {\n        this.isUploading = false;\n      };\n    }\n  }\n  onDeleteSectionMedia(event: any) {\n    const dialogRef = this.dialog.open(ConfirmationDialogComponent, {\n      width: '400px',\n      data: {\n        title: '删除图片',\n        message: `确定删除吗?`,\n      },\n    });\n\n    dialogRef.afterClosed().subscribe((result) => {\n      if (result) {\n        const section = event.section;\n        const mediaId = event.media.id;\n        remove(section.media, {\n          id: mediaId,\n        });\n        this.productService.deleteSectionMedia(section.id, mediaId).subscribe({\n          next: (res: any) => {\n            // remove(section.media, {\n            //   id: mediaId,\n            // });\n          },\n        });\n      }\n    });\n  }\n  onSectionSave(section: ProductSection) {\n    delete section.isUploading;\n    this.productService.updateSection(section.id, section).subscribe({\n      next: (res: any) => {\n        this.snackBar.open('保存成功');\n      },\n      error: (e) => {\n        this.snackBar.open(e.message);\n      },\n    });\n  }\n  onSectionDelete(section: ProductSection) {\n    const dialogRef = this.dialog.open(ConfirmationDialogComponent, {\n      width: '400px',\n      data: {\n        title: '删除详情',\n        message: '确定删除此详情吗?',\n      },\n    });\n    dialogRef.afterClosed().subscribe((result) => {\n      if (result) {\n        this.productService.deleteSection(section.id).subscribe({\n          next: (res: any) => {\n            this.snackBar.open(res.data);\n            remove(this.sections, {\n              id: section.id,\n            });\n          },\n          error: (e) => {\n            this.snackBar.open(e.message);\n          },\n        });\n      }\n    });\n  }\n}\n","<rolatech-product-manage-content>\n  <rolatech-toolbar title=\"详情\" class=\"hidden md:block\" divider> </rolatech-toolbar>\n  <div>\n    <div>\n      @for (section of sections; track section) {\n        <rolatech-product-manage-section-item\n          [section]=\"section\"\n          (upload)=\"onUploadSectionMedia($event)\"\n          (deleteMedia)=\"onDeleteSectionMedia($event)\"\n          (save)=\"onSectionSave($event)\"\n          (delete)=\"onSectionDelete($event)\"\n          [actions]=\"true\"\n        ></rolatech-product-manage-section-item>\n      }\n    </div>\n    <button mat-stroked-button (click)=\"addSection()\" class=\"mt-3\">\n      <mat-icon>add</mat-icon>\n      <span>添加详情</span>\n    </button>\n  </div>\n</rolatech-product-manage-content>\n"]}
|