@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.
Files changed (94) hide show
  1. package/esm2022/index.mjs +5 -12
  2. package/esm2022/lib/components/index.mjs +12 -0
  3. package/esm2022/lib/components/product-action/product-action.component.mjs +25 -0
  4. package/esm2022/lib/components/product-info/product-info.component.mjs +17 -0
  5. package/esm2022/lib/components/product-item/product-item.component.mjs +17 -0
  6. package/esm2022/lib/components/product-manage-option-add/product-manage-option-add.component.mjs +68 -0
  7. package/esm2022/lib/components/product-manage-option-item/product-manage-option-item.component.mjs +49 -0
  8. package/esm2022/lib/components/product-manage-variant/product-manage-variant.component.mjs +115 -0
  9. package/esm2022/lib/components/product-mange-option-action/product-manage-option-action.component.mjs +22 -0
  10. package/esm2022/lib/components/product-mange-section-item/product-mange-section-item.component.mjs +89 -0
  11. package/esm2022/lib/components/product-media/product-media.component.mjs +34 -0
  12. package/esm2022/lib/components/product-option/product-option.component.mjs +23 -0
  13. package/esm2022/lib/components/product-owner-renderer/product-owner-renderer.component.mjs +20 -0
  14. package/esm2022/lib/components/product-pricing/product-pricing.component.mjs +31 -0
  15. package/esm2022/lib/components/product-section/product-section.component.mjs +26 -0
  16. package/esm2022/lib/interfaces/category.mjs +2 -0
  17. package/esm2022/lib/interfaces/index.mjs +2 -0
  18. package/esm2022/lib/interfaces/product.mjs +32 -0
  19. package/esm2022/lib/pages/product/product-category/product-category.component.mjs +70 -8
  20. package/esm2022/lib/pages/product/product-details/product-details.component.mjs +193 -0
  21. package/esm2022/lib/pages/product/product-details/selected.pipe.mjs +18 -0
  22. package/esm2022/lib/pages/product/product-index/product-index.component.mjs +39 -8
  23. package/esm2022/lib/pages/product/product-layout/product-layout.component.mjs +46 -8
  24. package/esm2022/lib/pages/product/product.routes.mjs +3 -3
  25. package/esm2022/lib/pages/product-manage/product-manage-content/product-manage-content.component.mjs +5 -5
  26. package/esm2022/lib/pages/product-manage/product-manage-create/product-manage-create.component.mjs +61 -0
  27. package/esm2022/lib/pages/product-manage/product-manage-index/product-manage-index.component.mjs +155 -0
  28. package/esm2022/lib/pages/product-manage/product-manage-info/product-manage-info.component.mjs +98 -8
  29. package/esm2022/lib/pages/product-manage/product-manage-inventory/product-manage-inventory.component.mjs +14 -0
  30. package/esm2022/lib/pages/product-manage/product-manage-item/product-manage-item.component.mjs +27 -0
  31. package/esm2022/lib/pages/product-manage/product-manage-item-header/product-manage-item-header.component.mjs +12 -0
  32. package/esm2022/lib/pages/product-manage/product-manage-layout/product-manage-layout.component.mjs +51 -8
  33. package/esm2022/lib/pages/product-manage/product-manage-media/product-manage-media.component.mjs +133 -8
  34. package/esm2022/lib/pages/product-manage/product-manage-options/product-manage-options.component.mjs +102 -0
  35. package/esm2022/lib/pages/product-manage/product-manage-pricing/product-manage-pricing.component.mjs +5 -5
  36. package/esm2022/lib/pages/product-manage/product-manage-schedule/product-manage-schedule.component.mjs +14 -0
  37. package/esm2022/lib/pages/product-manage/product-manage-sections/product-manage-sections.component.mjs +170 -0
  38. package/esm2022/lib/pages/product-manage/product-manage-variants/product-manage-variants.component.mjs +133 -0
  39. package/esm2022/lib/pages/product-manage/product-manage.routes.mjs +34 -4
  40. package/esm2022/lib/services/index.mjs +4 -0
  41. package/esm2022/lib/services/product-category.service.mjs +38 -0
  42. package/esm2022/provider.mjs +13 -0
  43. package/fesm2022/rolatech-angular-product-product-index.component-C_cbg95R.mjs +70 -0
  44. package/fesm2022/rolatech-angular-product-product-index.component-C_cbg95R.mjs.map +1 -0
  45. package/fesm2022/rolatech-angular-product.mjs +1697 -76
  46. package/fesm2022/rolatech-angular-product.mjs.map +1 -1
  47. package/index.d.ts +4 -11
  48. package/lib/components/index.d.ts +11 -0
  49. package/lib/components/product-action/product-action.component.d.ts +11 -0
  50. package/lib/components/product-info/product-info.component.d.ts +7 -0
  51. package/lib/components/product-item/product-item.component.d.ts +7 -0
  52. package/lib/components/product-manage-option-add/product-manage-option-add.component.d.ts +20 -0
  53. package/lib/components/product-manage-option-item/product-manage-option-item.component.d.ts +14 -0
  54. package/lib/components/product-manage-variant/product-manage-variant.component.d.ts +18 -0
  55. package/lib/components/product-mange-option-action/product-manage-option-action.component.d.ts +10 -0
  56. package/lib/components/product-mange-section-item/product-mange-section-item.component.d.ts +33 -0
  57. package/lib/components/product-media/product-media.component.d.ts +12 -0
  58. package/lib/components/product-option/product-option.component.d.ts +14 -0
  59. package/lib/components/product-owner-renderer/product-owner-renderer.component.d.ts +8 -0
  60. package/lib/components/product-pricing/product-pricing.component.d.ts +12 -0
  61. package/lib/components/product-section/product-section.component.d.ts +16 -0
  62. package/lib/interfaces/category.d.ts +16 -0
  63. package/lib/interfaces/index.d.ts +2 -0
  64. package/lib/interfaces/product.d.ts +91 -0
  65. package/lib/pages/product/product-category/product-category.component.d.ts +19 -2
  66. package/lib/pages/product/product-details/product-details.component.d.ts +39 -0
  67. package/lib/pages/product/product-details/selected.pipe.d.ts +8 -0
  68. package/lib/pages/product/product-index/product-index.component.d.ts +12 -2
  69. package/lib/pages/product/product-layout/product-layout.component.d.ts +15 -2
  70. package/lib/pages/product-manage/product-manage-content/product-manage-content.component.d.ts +1 -1
  71. package/lib/pages/product-manage/product-manage-create/product-manage-create.component.d.ts +11 -0
  72. package/lib/pages/product-manage/product-manage-index/product-manage-index.component.d.ts +38 -0
  73. package/lib/pages/product-manage/product-manage-info/product-manage-info.component.d.ts +26 -2
  74. package/lib/pages/product-manage/product-manage-inventory/product-manage-inventory.component.d.ts +5 -0
  75. package/lib/pages/product-manage/product-manage-item/product-manage-item.component.d.ts +12 -0
  76. package/lib/pages/product-manage/product-manage-item-header/product-manage-item-header.component.d.ts +5 -0
  77. package/lib/pages/product-manage/product-manage-layout/product-manage-layout.component.d.ts +22 -2
  78. package/lib/pages/product-manage/product-manage-media/product-manage-media.component.d.ts +26 -2
  79. package/lib/pages/product-manage/product-manage-options/product-manage-options.component.d.ts +17 -0
  80. package/lib/pages/product-manage/product-manage-pricing/product-manage-pricing.component.d.ts +1 -1
  81. package/lib/pages/product-manage/product-manage-schedule/product-manage-schedule.component.d.ts +5 -0
  82. package/lib/pages/product-manage/product-manage-sections/product-manage-sections.component.d.ts +29 -0
  83. package/lib/pages/product-manage/product-manage-variants/product-manage-variants.component.d.ts +27 -0
  84. package/lib/services/index.d.ts +3 -0
  85. package/lib/services/product-category.service.d.ts +12 -0
  86. package/package.json +1 -1
  87. package/provider.d.ts +2 -0
  88. package/themes/_default.scss +1 -1
  89. package/esm2022/lib/angular-product/angular-product.component.mjs +0 -12
  90. package/esm2022/lib/pages/product/product-detail/product-detail.component.mjs +0 -12
  91. package/esm2022/lib/pages/product-manage/product-manage-details/product-manage-details.component.mjs +0 -12
  92. package/lib/angular-product/angular-product.component.d.ts +0 -5
  93. package/lib/pages/product/product-detail/product-detail.component.d.ts +0 -5
  94. package/lib/pages/product-manage/product-manage-details/product-manage-details.component.d.ts +0 -5
@@ -1,12 +1,137 @@
1
- import { Component } from '@angular/core';
2
- import { CommonModule } from '@angular/common';
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
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: ProductManageMediaComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
6
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.0", type: ProductManageMediaComponent, isStandalone: true, selector: "lib-product-manage-media", ngImport: i0, template: "<p>product-manage-media works!</p>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
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.0", ngImport: i0, type: ProductManageMediaComponent, decorators: [{
133
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: ProductManageMediaComponent, decorators: [{
9
134
  type: Component,
10
- args: [{ selector: 'lib-product-manage-media', standalone: true, imports: [CommonModule], template: "<p>product-manage-media works!</p>\n" }]
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"]}
@@ -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"]}
@@ -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.0", ngImport: i0, type: ProductManagePricingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
6
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.0", type: ProductManagePricingComponent, isStandalone: true, selector: "lib-product-manage-pricing", ngImport: i0, template: "<p>product-manage-pricing works!</p>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
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.0", ngImport: i0, type: ProductManagePricingComponent, decorators: [{
8
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: ProductManagePricingComponent, decorators: [{
9
9
  type: Component,
10
- args: [{ selector: 'lib-product-manage-pricing', standalone: true, imports: [CommonModule], template: "<p>product-manage-pricing works!</p>\n" }]
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1tYW5hZ2UtcHJpY2luZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItcHJvZHVjdC9zcmMvbGliL3BhZ2VzL3Byb2R1Y3QtbWFuYWdlL3Byb2R1Y3QtbWFuYWdlLXByaWNpbmcvcHJvZHVjdC1tYW5hZ2UtcHJpY2luZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItcHJvZHVjdC9zcmMvbGliL3BhZ2VzL3Byb2R1Y3QtbWFuYWdlL3Byb2R1Y3QtbWFuYWdlLXByaWNpbmcvcHJvZHVjdC1tYW5hZ2UtcHJpY2luZy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7QUFTL0MsTUFBTSxPQUFPLDZCQUE2Qjs4R0FBN0IsNkJBQTZCO2tHQUE3Qiw2QkFBNkIsc0ZDVjFDLHdDQUNBLHlEREtZLFlBQVk7OzJGQUlYLDZCQUE2QjtrQkFQekMsU0FBUzsrQkFDRSw0QkFBNEIsY0FDMUIsSUFBSSxXQUNQLENBQUMsWUFBWSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdsaWItcHJvZHVjdC1tYW5hZ2UtcHJpY2luZycsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICB0ZW1wbGF0ZVVybDogJy4vcHJvZHVjdC1tYW5hZ2UtcHJpY2luZy5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsOiAnLi9wcm9kdWN0LW1hbmFnZS1wcmljaW5nLmNvbXBvbmVudC5zY3NzJyxcbn0pXG5leHBvcnQgY2xhc3MgUHJvZHVjdE1hbmFnZVByaWNpbmdDb21wb25lbnQge31cbiIsIjxwPnByb2R1Y3QtbWFuYWdlLXByaWNpbmcgd29ya3MhPC9wPlxuIl19
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"]}