@yibozhang/pro-table 0.0.1

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 (63) hide show
  1. package/README.md +24 -0
  2. package/bundles/yibozhang-pro-table.umd.js +3110 -0
  3. package/bundles/yibozhang-pro-table.umd.js.map +1 -0
  4. package/bundles/yibozhang-pro-table.umd.min.js +2 -0
  5. package/bundles/yibozhang-pro-table.umd.min.js.map +1 -0
  6. package/esm2015/lib/components/colmuns-setting/colmuns-setting.component.js +158 -0
  7. package/esm2015/lib/components/dynamic-search-field/dynamic-search-field.component.js +101 -0
  8. package/esm2015/lib/constants.js +89 -0
  9. package/esm2015/lib/page-container/page-container.component.js +21 -0
  10. package/esm2015/lib/page-container/page-container.module.js +25 -0
  11. package/esm2015/lib/page-public/antd-form.js +734 -0
  12. package/esm2015/lib/plate-input/plate-input.component.js +155 -0
  13. package/esm2015/lib/plate-input/plate-input.module.js +26 -0
  14. package/esm2015/lib/plate-input/plate-prefix-load.service.js +41 -0
  15. package/esm2015/lib/pro-table.component.js +983 -0
  16. package/esm2015/lib/pro-table.module.js +73 -0
  17. package/esm2015/lib/table-search-bar/table-search-bar-module.js +27 -0
  18. package/esm2015/lib/table-search-bar/table-search-bar.component.js +51 -0
  19. package/esm2015/lib/tokens.js +4 -0
  20. package/esm2015/lib/type.js +2 -0
  21. package/esm2015/public-api.js +12 -0
  22. package/esm2015/yibozhang-pro-table.js +13 -0
  23. package/fesm2015/yibozhang-pro-table.js +2448 -0
  24. package/fesm2015/yibozhang-pro-table.js.map +1 -0
  25. package/lib/components/colmuns-setting/colmuns-setting.component.d.ts +35 -0
  26. package/lib/components/colmuns-setting/colmuns-setting.component.d.ts.map +1 -0
  27. package/lib/components/dynamic-search-field/dynamic-search-field.component.d.ts +22 -0
  28. package/lib/components/dynamic-search-field/dynamic-search-field.component.d.ts.map +1 -0
  29. package/lib/constants.d.ts +20 -0
  30. package/lib/constants.d.ts.map +1 -0
  31. package/lib/page-container/page-container.component.d.ts +9 -0
  32. package/lib/page-container/page-container.component.d.ts.map +1 -0
  33. package/lib/page-container/page-container.module.d.ts +3 -0
  34. package/lib/page-container/page-container.module.d.ts.map +1 -0
  35. package/lib/page-public/antd-form.d.ts +99 -0
  36. package/lib/page-public/antd-form.d.ts.map +1 -0
  37. package/lib/plate-input/plate-input.component.d.ts +31 -0
  38. package/lib/plate-input/plate-input.component.d.ts.map +1 -0
  39. package/lib/plate-input/plate-input.module.d.ts +3 -0
  40. package/lib/plate-input/plate-input.module.d.ts.map +1 -0
  41. package/lib/plate-input/plate-prefix-load.service.d.ts +13 -0
  42. package/lib/plate-input/plate-prefix-load.service.d.ts.map +1 -0
  43. package/lib/pro-table.component.d.ts +122 -0
  44. package/lib/pro-table.component.d.ts.map +1 -0
  45. package/lib/pro-table.module.d.ts +3 -0
  46. package/lib/pro-table.module.d.ts.map +1 -0
  47. package/lib/table-search-bar/table-search-bar-module.d.ts +3 -0
  48. package/lib/table-search-bar/table-search-bar-module.d.ts.map +1 -0
  49. package/lib/table-search-bar/table-search-bar.component.d.ts +15 -0
  50. package/lib/table-search-bar/table-search-bar.component.d.ts.map +1 -0
  51. package/lib/tokens.d.ts +36 -0
  52. package/lib/tokens.d.ts.map +1 -0
  53. package/lib/type.d.ts +226 -0
  54. package/lib/type.d.ts.map +1 -0
  55. package/package.json +40 -0
  56. package/public-api.d.ts +9 -0
  57. package/public-api.d.ts.map +1 -0
  58. package/src/lib/styles/custom-antd.less +114 -0
  59. package/src/lib/styles/margin.css +90 -0
  60. package/src/lib/styles/theme.less +42 -0
  61. package/yibozhang-pro-table.d.ts +13 -0
  62. package/yibozhang-pro-table.d.ts.map +1 -0
  63. package/yibozhang-pro-table.metadata.json +1 -0
@@ -0,0 +1,158 @@
1
+ import { Component, EventEmitter, Input, Output, ViewChild, } from "@angular/core";
2
+ import Sortable from "sortablejs";
3
+ import { PRO_TABLE_COLUMN_REMOTE } from "../../tokens";
4
+ import { Inject, Optional } from "@angular/core";
5
+ import { isObservable } from "rxjs";
6
+ export class ColmunsSettingComponent {
7
+ constructor(columnRemote) {
8
+ this.columnRemote = columnRemote;
9
+ this.columns = [];
10
+ this.selectedColumns = [];
11
+ this.afterConfirm = new EventEmitter();
12
+ this.modalVisible = false;
13
+ this.options = [];
14
+ this.sortableInstance = null;
15
+ }
16
+ ngOnInit() { }
17
+ ngAfterViewInit() {
18
+ this.initSortable();
19
+ }
20
+ ngOnDestroy() {
21
+ if (this.sortableInstance) {
22
+ this.sortableInstance.destroy();
23
+ }
24
+ }
25
+ initSortable() {
26
+ // 先销毁已存在的实例
27
+ if (this.sortableInstance) {
28
+ this.sortableInstance.destroy();
29
+ this.sortableInstance = null;
30
+ }
31
+ if (this.sortableContainer && this.sortableContainer.nativeElement) {
32
+ this.sortableInstance = new Sortable(this.sortableContainer.nativeElement, {
33
+ animation: 150,
34
+ ghostClass: "sortable-ghost",
35
+ chosenClass: "sortable-chosen",
36
+ dragClass: "sortable-drag",
37
+ handle: ".sort-list-item",
38
+ onEnd: (evt) => {
39
+ this.onSortEnd(evt);
40
+ },
41
+ });
42
+ }
43
+ }
44
+ onSortEnd(evt) {
45
+ const { oldIndex, newIndex } = evt;
46
+ if (oldIndex !== newIndex) {
47
+ // 创建新的数组来避免直接修改输入属性
48
+ const newSelectedColumns = [...this.selectedColumns];
49
+ const movedItem = newSelectedColumns.splice(oldIndex, 1)[0];
50
+ newSelectedColumns.splice(newIndex, 0, movedItem);
51
+ // 更新 selectedColumns
52
+ this.selectedColumns = newSelectedColumns;
53
+ }
54
+ }
55
+ trackByColumn(index, item) {
56
+ return item.prop || index.toString();
57
+ }
58
+ /**
59
+ * 同步 options 数组的 checked 状态与 selectedColumns
60
+ */
61
+ syncOptionsWithSelectedColumns() {
62
+ const selectedProps = this.selectedColumns.map((col) => col.prop);
63
+ this.options.forEach((option) => {
64
+ option.checked = selectedProps.includes(option.value);
65
+ });
66
+ }
67
+ handleModalVisible() {
68
+ this.options = this.columns
69
+ .filter((item) => !item.auxiliaryColumn)
70
+ .map((item) => {
71
+ return {
72
+ label: item.title,
73
+ value: item.prop,
74
+ checked: item.hideInTable ? false : true,
75
+ sortName: item.sortName || null,
76
+ };
77
+ });
78
+ // 同步 options 的 checked 状态与当前 selectedColumns
79
+ this.syncOptionsWithSelectedColumns();
80
+ this.modalVisible = true;
81
+ // 模态框打开后重新初始化排序
82
+ setTimeout(() => {
83
+ this.initSortable();
84
+ }, 100);
85
+ }
86
+ handleModalClose() {
87
+ this.modalVisible = false;
88
+ if (this.sortableInstance) {
89
+ this.sortableInstance.destroy();
90
+ this.sortableInstance = null;
91
+ }
92
+ }
93
+ handleSelectRemove(key) {
94
+ this.selectedColumns = this.selectedColumns.filter((item) => item.prop !== key);
95
+ // 使用同步方法确保所有状态一致
96
+ this.syncOptionsWithSelectedColumns();
97
+ }
98
+ handleCheckBoxChange(value, record) {
99
+ if (!value) {
100
+ this.handleSelectRemove(record.value);
101
+ }
102
+ else {
103
+ this.selectedColumns.push({
104
+ title: record.label,
105
+ prop: record.value,
106
+ sortName: record.sortName,
107
+ hideInTable: false,
108
+ });
109
+ // 添加项目后同步状态
110
+ this.syncOptionsWithSelectedColumns();
111
+ }
112
+ }
113
+ handleConfirm() {
114
+ var _a;
115
+ if (!((_a = this.columnRemote) === null || _a === void 0 ? void 0 : _a.setCol) || !this.tableName) {
116
+ this.modalVisible = false;
117
+ this.afterConfirm.emit();
118
+ return;
119
+ }
120
+ const payload = this.selectedColumns.map((column) => {
121
+ return {
122
+ field: column.prop,
123
+ isShow: column.hideInTable ? false : true,
124
+ header: column.title,
125
+ sortName: column.sortName || null,
126
+ };
127
+ });
128
+ const result = this.columnRemote.setCol(this.tableName, payload);
129
+ const done = (res) => {
130
+ this.modalVisible = false;
131
+ this.afterConfirm.emit();
132
+ };
133
+ if (result && isObservable(result)) {
134
+ result.subscribe(done, () => done(null));
135
+ }
136
+ else {
137
+ Promise.resolve(result).finally(() => done(null));
138
+ }
139
+ }
140
+ }
141
+ ColmunsSettingComponent.decorators = [
142
+ { type: Component, args: [{
143
+ selector: "app-colmuns-setting",
144
+ template: "<div class=\"action-pic-btn\" (click)=\"handleModalVisible()\" title=\"\u5217\u8BBE\u7F6E\">\r\n <i nz-icon nzType=\"setting\" nzTheme=\"outline\"></i>\r\n</div>\r\n\r\n<nz-modal\r\n [(nzVisible)]=\"modalVisible\"\r\n [nzWidth]=\"820\"\r\n [nzTitle]=\"modalTitle\"\r\n (nzOnCancel)=\"handleModalClose()\"\r\n [nzContent]=\"modalBody\"\r\n [nzBodyStyle]=\"{ padding: '12px' }\"\r\n (nzOnOk)=\"handleConfirm()\"\r\n [nzWrapClassName]=\"'draggable-modal'\"\r\n>\r\n <ng-template #modalTitle>\r\n <div\r\n class=\"modal-drag-handle\"\r\n cdkDrag\r\n [cdkDragRootElement]=\"'.draggable-modal .ant-modal'\"\r\n cdkDragHandle\r\n [cdkDragBoundary]=\"'.draggable-modal'\"\r\n >\r\n <span>\u8BBE\u7F6E\u663E\u793A\u5B57\u6BB5</span>\r\n </div>\r\n </ng-template>\r\n <ng-template #modalBody>\r\n <div class=\"modal-body\">\r\n <div class=\"check-box-list\">\r\n <div class=\"mb-12\">\u53EF\u9009\u5B57\u6BB5</div>\r\n <nz-checkbox-wrapper style=\"width: 100%\">\r\n <div nz-row [nzGutter]=\"[24, 24]\">\r\n <div nz-col nzSpan=\"6\" *ngFor=\"let item of options\">\r\n <label\r\n nz-checkbox\r\n nzValue=\"item.value\"\r\n [ngModel]=\"item.checked\"\r\n (ngModelChange)=\"handleCheckBoxChange($event, item)\"\r\n >{{ item.label }}</label\r\n >\r\n </div>\r\n </div>\r\n </nz-checkbox-wrapper>\r\n </div>\r\n <div class=\"sort-list\">\r\n <div nz-typography class=\"mb-4\">\u5F53\u524D\u5DF2\u7ECF\u9009\u5B9A\u7684\u5B57\u6BB5</div>\r\n <div\r\n nz-typography\r\n nzType=\"secondary\"\r\n class=\"mb-4\"\r\n [style.fontSize]=\"'12px'\"\r\n >\r\n \u63D0\u793A\uFF1A\u53EF\u62D6\u52A8\u6392\u5E8F\r\n </div>\r\n <div #sortableContainer class=\"sortable-container\">\r\n <div\r\n class=\"sort-list-item mb-12\"\r\n *ngFor=\"let item of selectedColumns; trackBy: trackByColumn\"\r\n >\r\n {{ item.title }}\r\n <a\r\n href=\"javascript:void(0)\"\r\n class=\"fieldd-remove\"\r\n title=\"\u5220\u9664\"\r\n (click)=\"handleSelectRemove(item.prop)\"\r\n >\u00D7</a\r\n >\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-template>\r\n</nz-modal>\r\n",
145
+ styles: [".action-pic-btn{align-items:center;cursor:pointer;display:inline-flex;height:32px;justify-content:center;width:32px}.modal-body{display:flex;height:600px;width:100%}.modal-body .check-box-list{height:100%;width:calc(100% - 200px)}.modal-body .sort-list{border-left:1px solid #e3e3e3;box-sizing:border-box;height:100%;overflow-y:auto;padding-left:12px;padding-right:12px;width:200px}.modal-body .sort-list .sortable-container{min-height:100px}.modal-body .sort-list .sort-list-item{-moz-user-select:none;-webkit-user-select:none;align-items:center;cursor:move;display:flex;justify-content:space-between;user-select:none}.modal-body .sort-list .sort-list-item a{font-size:18px}.modal-drag-handle{-moz-user-select:none;-webkit-user-select:none;cursor:move;user-select:none;width:100%}"]
146
+ },] }
147
+ ];
148
+ ColmunsSettingComponent.ctorParameters = () => [
149
+ { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [PRO_TABLE_COLUMN_REMOTE,] }] }
150
+ ];
151
+ ColmunsSettingComponent.propDecorators = {
152
+ columns: [{ type: Input }],
153
+ selectedColumns: [{ type: Input }],
154
+ tableName: [{ type: Input }],
155
+ afterConfirm: [{ type: Output }],
156
+ sortableContainer: [{ type: ViewChild, args: ["sortableContainer", { static: false },] }]
157
+ };
158
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"colmuns-setting.component.js","sourceRoot":"D:/projects/vps-front/Front/DasPMSWeb/projects/pro-table/src/","sources":["lib/components/colmuns-setting/colmuns-setting.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n} from \"@angular/core\";\r\nimport Sortable from \"sortablejs\";\r\nimport { ProTableColumn } from \"../../type\";\r\nimport { PRO_TABLE_COLUMN_REMOTE, ProTableRemoteColumnService } from \"../../tokens\";\r\nimport { Inject, Optional } from \"@angular/core\";\r\nimport { isObservable } from \"rxjs\";\r\n\r\n@Component({\r\n  selector: \"app-colmuns-setting\",\r\n  templateUrl: \"./colmuns-setting.component.html\",\r\n  styleUrls: [\"./colmuns-setting.component.less\"],\r\n})\r\nexport class ColmunsSettingComponent\r\n  implements OnInit, AfterViewInit, OnDestroy\r\n{\r\n  @Input() columns: ProTableColumn[] = [];\r\n\r\n  @Input() selectedColumns: ProTableColumn[] = [];\r\n\r\n  @Input() tableName: string;\r\n\r\n  @Output() afterConfirm = new EventEmitter<ProTableColumn[]>();\r\n\r\n  @ViewChild(\"sortableContainer\", { static: false })\r\n  sortableContainer!: ElementRef;\r\n\r\n  modalVisible: boolean = false;\r\n\r\n  options: Array<{ label: string; value: string; checked: boolean }> = [];\r\n\r\n  private sortableInstance: Sortable | null = null;\r\n\r\n  constructor(\r\n    @Optional()\r\n    @Inject(PRO_TABLE_COLUMN_REMOTE)\r\n    private columnRemote: ProTableRemoteColumnService | null\r\n  ) {}\r\n\r\n  ngOnInit(): void {}\r\n\r\n  ngAfterViewInit(): void {\r\n    this.initSortable();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.sortableInstance) {\r\n      this.sortableInstance.destroy();\r\n    }\r\n  }\r\n\r\n  initSortable(): void {\r\n    // 先销毁已存在的实例\r\n    if (this.sortableInstance) {\r\n      this.sortableInstance.destroy();\r\n      this.sortableInstance = null;\r\n    }\r\n\r\n    if (this.sortableContainer && this.sortableContainer.nativeElement) {\r\n      this.sortableInstance = new Sortable(\r\n        this.sortableContainer.nativeElement,\r\n        {\r\n          animation: 150,\r\n          ghostClass: \"sortable-ghost\",\r\n          chosenClass: \"sortable-chosen\",\r\n          dragClass: \"sortable-drag\",\r\n          handle: \".sort-list-item\", // 指定拖拽句柄\r\n          onEnd: (evt) => {\r\n            this.onSortEnd(evt);\r\n          },\r\n        }\r\n      );\r\n    }\r\n  }\r\n\r\n  onSortEnd(evt: any): void {\r\n    const { oldIndex, newIndex } = evt;\r\n    if (oldIndex !== newIndex) {\r\n      // 创建新的数组来避免直接修改输入属性\r\n      const newSelectedColumns = [...this.selectedColumns];\r\n      const movedItem = newSelectedColumns.splice(oldIndex, 1)[0];\r\n      newSelectedColumns.splice(newIndex, 0, movedItem);\r\n\r\n      // 更新 selectedColumns\r\n      this.selectedColumns = newSelectedColumns;\r\n    }\r\n  }\r\n\r\n  trackByColumn(index: number, item: ProTableColumn): string {\r\n    return item.prop || index.toString();\r\n  }\r\n\r\n  /**\r\n   * 同步 options 数组的 checked 状态与 selectedColumns\r\n   */\r\n  private syncOptionsWithSelectedColumns(): void {\r\n    const selectedProps = this.selectedColumns.map((col) => col.prop);\r\n    this.options.forEach((option) => {\r\n      option.checked = selectedProps.includes(option.value);\r\n    });\r\n  }\r\n\r\n  handleModalVisible() {\r\n    this.options = this.columns\r\n      .filter((item) => !item.auxiliaryColumn)\r\n      .map((item) => {\r\n        return {\r\n          label: item.title,\r\n          value: item.prop,\r\n          checked: item.hideInTable ? false : true,\r\n          sortName: item.sortName || null,\r\n        };\r\n      });\r\n\r\n    // 同步 options 的 checked 状态与当前 selectedColumns\r\n    this.syncOptionsWithSelectedColumns();\r\n\r\n    this.modalVisible = true;\r\n\r\n    // 模态框打开后重新初始化排序\r\n    setTimeout(() => {\r\n      this.initSortable();\r\n    }, 100);\r\n  }\r\n\r\n  handleModalClose() {\r\n    this.modalVisible = false;\r\n    if (this.sortableInstance) {\r\n      this.sortableInstance.destroy();\r\n      this.sortableInstance = null;\r\n    }\r\n  }\r\n\r\n  handleSelectRemove(key: string) {\r\n    this.selectedColumns = this.selectedColumns.filter(\r\n      (item) => item.prop !== key\r\n    );\r\n\r\n    // 使用同步方法确保所有状态一致\r\n    this.syncOptionsWithSelectedColumns();\r\n  }\r\n\r\n  handleCheckBoxChange(value, record) {\r\n    if (!value) {\r\n      this.handleSelectRemove(record.value);\r\n    } else {\r\n      this.selectedColumns.push({\r\n        title: record.label,\r\n        prop: record.value,\r\n        sortName: record.sortName,\r\n        hideInTable: false,\r\n      });\r\n      // 添加项目后同步状态\r\n      this.syncOptionsWithSelectedColumns();\r\n    }\r\n  }\r\n  handleConfirm() {\r\n    if (!this.columnRemote?.setCol || !this.tableName) {\r\n      this.modalVisible = false;\r\n      this.afterConfirm.emit();\r\n      return;\r\n    }\r\n    const payload = this.selectedColumns.map((column) => {\r\n      return {\r\n        field: column.prop,\r\n        isShow: column.hideInTable ? false : true,\r\n        header: column.title,\r\n        sortName: column.sortName || null,\r\n      };\r\n    });\r\n    const result = this.columnRemote.setCol(this.tableName, payload);\r\n    const done = (res) => {\r\n      this.modalVisible = false;\r\n      this.afterConfirm.emit();\r\n    };\r\n    if (result && isObservable(result)) {\r\n      result.subscribe(done, () => done(null));\r\n    } else {\r\n      Promise.resolve(result).finally(() => done(null));\r\n    }\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,101 @@
1
+ import { Component, ComponentFactoryResolver, EventEmitter, Input, Output, ViewChild, ViewContainerRef } from '@angular/core';
2
+ export class DynamicSearchFieldComponent {
3
+ constructor(cfr) {
4
+ this.cfr = cfr;
5
+ this.component = null;
6
+ this.props = null;
7
+ this.valueChange = new EventEmitter();
8
+ this.cmpRef = null;
9
+ this.isCva = false;
10
+ this.cvaOnChange = null;
11
+ }
12
+ ngOnInit() {
13
+ this.render();
14
+ }
15
+ ngOnChanges(changes) {
16
+ if (changes.component && !changes.component.firstChange) {
17
+ this.destroy();
18
+ this.render();
19
+ return;
20
+ }
21
+ if (this.cmpRef) {
22
+ if (changes.value && !changes.value.firstChange) {
23
+ if (this.isCva) {
24
+ if (typeof this.cmpRef.instance.writeValue === 'function') {
25
+ this.cmpRef.instance.writeValue(this.value);
26
+ }
27
+ }
28
+ else if ('value' in this.cmpRef.instance) {
29
+ this.cmpRef.instance.value = this.value;
30
+ }
31
+ }
32
+ if (changes.props && !changes.props.firstChange) {
33
+ this.applyProps();
34
+ }
35
+ }
36
+ }
37
+ render() {
38
+ if (!this.component)
39
+ return;
40
+ const factory = this.cfr.resolveComponentFactory(this.component);
41
+ this.vc.clear();
42
+ this.cmpRef = this.vc.createComponent(factory);
43
+ this.isCva = typeof this.cmpRef.instance.registerOnChange === 'function' && typeof this.cmpRef.instance.writeValue === 'function';
44
+ if (this.isCva) {
45
+ this.cmpRef.instance.writeValue(this.value);
46
+ this.cmpRef.instance.registerOnChange((v) => {
47
+ this.valueChange.emit(v);
48
+ });
49
+ }
50
+ else {
51
+ if ('value' in this.cmpRef.instance) {
52
+ this.cmpRef.instance.value = this.value;
53
+ }
54
+ if ('valueChange' in this.cmpRef.instance && this.cmpRef.instance.valueChange && typeof this.cmpRef.instance.valueChange.subscribe === 'function') {
55
+ this.cmpRef.instance.valueChange.subscribe((v) => {
56
+ this.valueChange.emit(v);
57
+ });
58
+ }
59
+ }
60
+ this.applyProps();
61
+ }
62
+ applyProps() {
63
+ const p = this.props || {};
64
+ const extra = p.componentProps || {};
65
+ Object.keys(extra).forEach((k) => {
66
+ try {
67
+ this.cmpRef.instance[k] = extra[k];
68
+ }
69
+ catch (_a) { }
70
+ });
71
+ }
72
+ destroy() {
73
+ if (this.cmpRef) {
74
+ try {
75
+ this.cmpRef.destroy();
76
+ }
77
+ catch (_a) { }
78
+ this.cmpRef = null;
79
+ }
80
+ }
81
+ ngOnDestroy() {
82
+ this.destroy();
83
+ }
84
+ }
85
+ DynamicSearchFieldComponent.decorators = [
86
+ { type: Component, args: [{
87
+ selector: 'app-dynamic-search-field',
88
+ template: `<ng-template #vc></ng-template>`
89
+ },] }
90
+ ];
91
+ DynamicSearchFieldComponent.ctorParameters = () => [
92
+ { type: ComponentFactoryResolver }
93
+ ];
94
+ DynamicSearchFieldComponent.propDecorators = {
95
+ component: [{ type: Input }],
96
+ value: [{ type: Input }],
97
+ props: [{ type: Input }],
98
+ valueChange: [{ type: Output }],
99
+ vc: [{ type: ViewChild, args: ['vc', { read: ViewContainerRef, static: true },] }]
100
+ };
101
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-search-field.component.js","sourceRoot":"D:/projects/vps-front/Front/DasPMSWeb/projects/pro-table/src/","sources":["lib/components/dynamic-search-field/dynamic-search-field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ComponentFactoryResolver, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges, Type, ViewChild, ViewContainerRef } from '@angular/core';\r\n\r\n@Component({\r\n  selector: 'app-dynamic-search-field',\r\n  template: `<ng-template #vc></ng-template>`\r\n})\r\nexport class DynamicSearchFieldComponent implements OnInit, OnChanges, OnDestroy {\r\n  @Input() component: Type<any> | null = null;\r\n  @Input() value: any;\r\n  @Input() props: { [key: string]: any } | null = null;\r\n  @Output() valueChange = new EventEmitter<any>();\r\n\r\n  @ViewChild('vc', { read: ViewContainerRef, static: true }) vc!: ViewContainerRef;\r\n\r\n  private cmpRef: any = null;\r\n  private isCva = false;\r\n  private cvaOnChange: ((val: any) => void) | null = null;\r\n\r\n  constructor(private cfr: ComponentFactoryResolver) {}\r\n\r\n  ngOnInit(): void {\r\n    this.render();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes.component && !changes.component.firstChange) {\r\n      this.destroy();\r\n      this.render();\r\n      return;\r\n    }\r\n    if (this.cmpRef) {\r\n      if (changes.value && !changes.value.firstChange) {\r\n        if (this.isCva) {\r\n          if (typeof this.cmpRef.instance.writeValue === 'function') {\r\n            this.cmpRef.instance.writeValue(this.value);\r\n          }\r\n        } else if ('value' in this.cmpRef.instance) {\r\n          this.cmpRef.instance.value = this.value;\r\n        }\r\n      }\r\n      if (changes.props && !changes.props.firstChange) {\r\n        this.applyProps();\r\n      }\r\n    }\r\n  }\r\n\r\n  private render() {\r\n    if (!this.component) return;\r\n    const factory = this.cfr.resolveComponentFactory(this.component);\r\n    this.vc.clear();\r\n    this.cmpRef = this.vc.createComponent(factory);\r\n\r\n    this.isCva = typeof this.cmpRef.instance.registerOnChange === 'function' && typeof this.cmpRef.instance.writeValue === 'function';\r\n\r\n    if (this.isCva) {\r\n      this.cmpRef.instance.writeValue(this.value);\r\n      this.cmpRef.instance.registerOnChange((v: any) => {\r\n        this.valueChange.emit(v);\r\n      });\r\n    } else {\r\n      if ('value' in this.cmpRef.instance) {\r\n        this.cmpRef.instance.value = this.value;\r\n      }\r\n      if ('valueChange' in this.cmpRef.instance && this.cmpRef.instance.valueChange && typeof this.cmpRef.instance.valueChange.subscribe === 'function') {\r\n        this.cmpRef.instance.valueChange.subscribe((v: any) => {\r\n          this.valueChange.emit(v);\r\n        });\r\n      }\r\n    }\r\n\r\n    this.applyProps();\r\n  }\r\n\r\n  private applyProps() {\r\n    const p = this.props || {};\r\n    const extra = p.componentProps || {};\r\n    Object.keys(extra).forEach((k) => {\r\n      try {\r\n        this.cmpRef.instance[k] = extra[k];\r\n      } catch {}\r\n    });\r\n  }\r\n\r\n  private destroy() {\r\n    if (this.cmpRef) {\r\n      try { this.cmpRef.destroy(); } catch {}\r\n      this.cmpRef = null;\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroy();\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,89 @@
1
+ const ɵ0 = () => [], ɵ1 = (value) => `${value}`, ɵ2 = (value) => value;
2
+ export const PRO_TABLE_DEFAULT_PROPS = {
3
+ input: {
4
+ name: "",
5
+ placeHolder: "",
6
+ disabled: false,
7
+ label: "",
8
+ value: "",
9
+ },
10
+ select: {
11
+ name: "",
12
+ options: [],
13
+ disabled: false,
14
+ label: "",
15
+ value: "",
16
+ allowClear: true,
17
+ placeHolder: "",
18
+ },
19
+ selectMultiple: {
20
+ name: "",
21
+ options: [],
22
+ disabled: false,
23
+ label: "",
24
+ value: [],
25
+ allowClear: true,
26
+ placeHolder: "请选择",
27
+ },
28
+ inputPlate: {
29
+ name: "",
30
+ label: "",
31
+ value: "",
32
+ },
33
+ checkbox: {
34
+ name: "",
35
+ options: [],
36
+ disabled: false,
37
+ label: "",
38
+ value: [],
39
+ noStyle: false,
40
+ },
41
+ date: {
42
+ name: "",
43
+ disabled: false,
44
+ label: "",
45
+ value: "",
46
+ allowClear: true,
47
+ placeHolder: "请选择",
48
+ showTime: false,
49
+ format: "yyyy-MM-dd",
50
+ mode: "date",
51
+ },
52
+ autoComplete: {
53
+ name: "",
54
+ disabled: false,
55
+ placeHolder: "请输入",
56
+ label: "",
57
+ value: "",
58
+ dataSource: ɵ0,
59
+ backFill: false,
60
+ defaultActiveFirstOption: false,
61
+ returnFullData: false,
62
+ },
63
+ inputNumber: {
64
+ name: "",
65
+ disabled: false,
66
+ label: "",
67
+ value: "",
68
+ placeHolder: "请输入",
69
+ min: 0,
70
+ max: 100,
71
+ precision: 0,
72
+ formatterPercent: ɵ1,
73
+ parserPercent: ɵ2,
74
+ },
75
+ custom: {
76
+ name: "",
77
+ value: null,
78
+ label: "",
79
+ },
80
+ };
81
+ export const PRO_TABLE_DEFAULT_COLUMN = {
82
+ width: "",
83
+ align: "left",
84
+ fixedLeft: false,
85
+ fixedRight: false,
86
+ auxiliaryColumn: false,
87
+ };
88
+ export { ɵ0, ɵ1, ɵ2 };
89
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnRzLmpzIiwic291cmNlUm9vdCI6IkQ6L3Byb2plY3RzL3Zwcy1mcm9udC9Gcm9udC9EYXNQTVNXZWIvcHJvamVjdHMvcHJvLXRhYmxlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9jb25zdGFudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IldBOEVnQixHQUFHLEVBQUUsQ0FBQyxFQUFFLE9BY0YsQ0FBQyxLQUFhLEVBQUUsRUFBRSxDQUFDLEdBQUcsS0FBSyxFQUFFLE9BQ2hDLENBQUMsS0FBYSxFQUFFLEVBQUUsQ0FBQyxLQUFLO0FBakYzQyxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FVaEM7SUFDRixLQUFLLEVBQUU7UUFDTCxJQUFJLEVBQUUsRUFBRTtRQUNSLFdBQVcsRUFBRSxFQUFFO1FBQ2YsUUFBUSxFQUFFLEtBQUs7UUFDZixLQUFLLEVBQUUsRUFBRTtRQUNULEtBQUssRUFBRSxFQUFFO0tBQ1Y7SUFDRCxNQUFNLEVBQUU7UUFDTixJQUFJLEVBQUUsRUFBRTtRQUNSLE9BQU8sRUFBRSxFQUFFO1FBQ1gsUUFBUSxFQUFFLEtBQUs7UUFDZixLQUFLLEVBQUUsRUFBRTtRQUNULEtBQUssRUFBRSxFQUFFO1FBQ1QsVUFBVSxFQUFFLElBQUk7UUFDaEIsV0FBVyxFQUFFLEVBQUU7S0FDaEI7SUFDRCxjQUFjLEVBQUU7UUFDZCxJQUFJLEVBQUUsRUFBRTtRQUNSLE9BQU8sRUFBRSxFQUFFO1FBQ1gsUUFBUSxFQUFFLEtBQUs7UUFDZixLQUFLLEVBQUUsRUFBRTtRQUNULEtBQUssRUFBRSxFQUFFO1FBQ1QsVUFBVSxFQUFFLElBQUk7UUFDaEIsV0FBVyxFQUFFLEtBQUs7S0FDbkI7SUFDRCxVQUFVLEVBQUU7UUFDVixJQUFJLEVBQUUsRUFBRTtRQUNSLEtBQUssRUFBRSxFQUFFO1FBQ1QsS0FBSyxFQUFFLEVBQUU7S0FDVjtJQUNELFFBQVEsRUFBRTtRQUNSLElBQUksRUFBRSxFQUFFO1FBQ1IsT0FBTyxFQUFFLEVBQUU7UUFDWCxRQUFRLEVBQUUsS0FBSztRQUNmLEtBQUssRUFBRSxFQUFFO1FBQ1QsS0FBSyxFQUFFLEVBQUU7UUFDVCxPQUFPLEVBQUUsS0FBSztLQUNmO0lBQ0QsSUFBSSxFQUFFO1FBQ0osSUFBSSxFQUFFLEVBQUU7UUFDUixRQUFRLEVBQUUsS0FBSztRQUNmLEtBQUssRUFBRSxFQUFFO1FBQ1QsS0FBSyxFQUFFLEVBQUU7UUFDVCxVQUFVLEVBQUUsSUFBSTtRQUNoQixXQUFXLEVBQUUsS0FBSztRQUNsQixRQUFRLEVBQUUsS0FBSztRQUNmLE1BQU0sRUFBRSxZQUFZO1FBQ3BCLElBQUksRUFBRSxNQUFNO0tBQ2I7SUFDRCxZQUFZLEVBQUU7UUFDWixJQUFJLEVBQUUsRUFBRTtRQUNSLFFBQVEsRUFBRSxLQUFLO1FBQ2YsV0FBVyxFQUFFLEtBQUs7UUFDbEIsS0FBSyxFQUFFLEVBQUU7UUFDVCxLQUFLLEVBQUUsRUFBRTtRQUNULFVBQVUsSUFBVTtRQUNwQixRQUFRLEVBQUUsS0FBSztRQUNmLHdCQUF3QixFQUFFLEtBQUs7UUFDL0IsY0FBYyxFQUFFLEtBQUs7S0FDdEI7SUFDRCxXQUFXLEVBQUU7UUFDWCxJQUFJLEVBQUUsRUFBRTtRQUNSLFFBQVEsRUFBRSxLQUFLO1FBQ2YsS0FBSyxFQUFFLEVBQUU7UUFDVCxLQUFLLEVBQUUsRUFBRTtRQUNULFdBQVcsRUFBRSxLQUFLO1FBQ2xCLEdBQUcsRUFBRSxDQUFDO1FBQ04sR0FBRyxFQUFFLEdBQUc7UUFDUixTQUFTLEVBQUUsQ0FBQztRQUNaLGdCQUFnQixJQUErQjtRQUMvQyxhQUFhLElBQTBCO0tBQ3hDO0lBQ0QsTUFBTSxFQUFFO1FBQ04sSUFBSSxFQUFFLEVBQUU7UUFDUixLQUFLLEVBQUUsSUFBSTtRQUNYLEtBQUssRUFBRSxFQUFFO0tBQ1Y7Q0FDRixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQUc7SUFDdEMsS0FBSyxFQUFFLEVBQUU7SUFDVCxLQUFLLEVBQUUsTUFBTTtJQUNiLFNBQVMsRUFBRSxLQUFLO0lBQ2hCLFVBQVUsRUFBRSxLQUFLO0lBQ2pCLGVBQWUsRUFBRSxLQUFLO0NBQ3ZCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIElucHV0RmllbGRQcm9wcyxcclxuICBJbnB1dFBsYXRlRmllbGRQcm9wcyxcclxuICBTZWxlY3RGaWVsZFByb3BzLFxyXG4gIFNlbGVjdE11bHRpcGxlRmllbGRQcm9wcyxcclxuICBEYXRlRmllbGRQcm9wcyxcclxuICBDaGVja2JveEZpZWxkUHJvcHMsXHJcbiAgQXV0b0NvbXBsZXRlRmllbGRQcm9wcyxcclxuICBDdXN0b21GaWVsZFByb3BzLFxyXG4gIElucHV0TnVtYmVyRmllbGRQcm9wcyxcclxufSBmcm9tIFwiLi90eXBlXCI7XHJcblxyXG5leHBvcnQgY29uc3QgUFJPX1RBQkxFX0RFRkFVTFRfUFJPUFM6IHtcclxuICBpbnB1dDogSW5wdXRGaWVsZFByb3BzO1xyXG4gIGlucHV0UGxhdGU6IElucHV0UGxhdGVGaWVsZFByb3BzO1xyXG4gIHNlbGVjdDogU2VsZWN0RmllbGRQcm9wcztcclxuICBzZWxlY3RNdWx0aXBsZTogU2VsZWN0TXVsdGlwbGVGaWVsZFByb3BzO1xyXG4gIGRhdGU6IERhdGVGaWVsZFByb3BzO1xyXG4gIGNoZWNrYm94OiBDaGVja2JveEZpZWxkUHJvcHM7XHJcbiAgYXV0b0NvbXBsZXRlOiBBdXRvQ29tcGxldGVGaWVsZFByb3BzO1xyXG4gIGN1c3RvbTogQ3VzdG9tRmllbGRQcm9wcztcclxuICBpbnB1dE51bWJlcjogSW5wdXROdW1iZXJGaWVsZFByb3BzO1xyXG59ID0ge1xyXG4gIGlucHV0OiB7XHJcbiAgICBuYW1lOiBcIlwiLFxyXG4gICAgcGxhY2VIb2xkZXI6IFwiXCIsXHJcbiAgICBkaXNhYmxlZDogZmFsc2UsXHJcbiAgICBsYWJlbDogXCJcIixcclxuICAgIHZhbHVlOiBcIlwiLFxyXG4gIH0sXHJcbiAgc2VsZWN0OiB7XHJcbiAgICBuYW1lOiBcIlwiLFxyXG4gICAgb3B0aW9uczogW10sXHJcbiAgICBkaXNhYmxlZDogZmFsc2UsXHJcbiAgICBsYWJlbDogXCJcIixcclxuICAgIHZhbHVlOiBcIlwiLFxyXG4gICAgYWxsb3dDbGVhcjogdHJ1ZSxcclxuICAgIHBsYWNlSG9sZGVyOiBcIlwiLFxyXG4gIH0sXHJcbiAgc2VsZWN0TXVsdGlwbGU6IHtcclxuICAgIG5hbWU6IFwiXCIsXHJcbiAgICBvcHRpb25zOiBbXSxcclxuICAgIGRpc2FibGVkOiBmYWxzZSxcclxuICAgIGxhYmVsOiBcIlwiLFxyXG4gICAgdmFsdWU6IFtdLFxyXG4gICAgYWxsb3dDbGVhcjogdHJ1ZSxcclxuICAgIHBsYWNlSG9sZGVyOiBcIuivt+mAieaLqVwiLFxyXG4gIH0sXHJcbiAgaW5wdXRQbGF0ZToge1xyXG4gICAgbmFtZTogXCJcIixcclxuICAgIGxhYmVsOiBcIlwiLFxyXG4gICAgdmFsdWU6IFwiXCIsXHJcbiAgfSxcclxuICBjaGVja2JveDoge1xyXG4gICAgbmFtZTogXCJcIixcclxuICAgIG9wdGlvbnM6IFtdLFxyXG4gICAgZGlzYWJsZWQ6IGZhbHNlLFxyXG4gICAgbGFiZWw6IFwiXCIsXHJcbiAgICB2YWx1ZTogW10sXHJcbiAgICBub1N0eWxlOiBmYWxzZSxcclxuICB9LFxyXG4gIGRhdGU6IHtcclxuICAgIG5hbWU6IFwiXCIsXHJcbiAgICBkaXNhYmxlZDogZmFsc2UsXHJcbiAgICBsYWJlbDogXCJcIixcclxuICAgIHZhbHVlOiBcIlwiLFxyXG4gICAgYWxsb3dDbGVhcjogdHJ1ZSxcclxuICAgIHBsYWNlSG9sZGVyOiBcIuivt+mAieaLqVwiLFxyXG4gICAgc2hvd1RpbWU6IGZhbHNlLFxyXG4gICAgZm9ybWF0OiBcInl5eXktTU0tZGRcIixcclxuICAgIG1vZGU6IFwiZGF0ZVwiLFxyXG4gIH0sXHJcbiAgYXV0b0NvbXBsZXRlOiB7XHJcbiAgICBuYW1lOiBcIlwiLFxyXG4gICAgZGlzYWJsZWQ6IGZhbHNlLFxyXG4gICAgcGxhY2VIb2xkZXI6IFwi6K+36L6T5YWlXCIsXHJcbiAgICBsYWJlbDogXCJcIixcclxuICAgIHZhbHVlOiBcIlwiLFxyXG4gICAgZGF0YVNvdXJjZTogKCkgPT4gW10sXHJcbiAgICBiYWNrRmlsbDogZmFsc2UsXHJcbiAgICBkZWZhdWx0QWN0aXZlRmlyc3RPcHRpb246IGZhbHNlLFxyXG4gICAgcmV0dXJuRnVsbERhdGE6IGZhbHNlLFxyXG4gIH0sXHJcbiAgaW5wdXROdW1iZXI6IHtcclxuICAgIG5hbWU6IFwiXCIsXHJcbiAgICBkaXNhYmxlZDogZmFsc2UsXHJcbiAgICBsYWJlbDogXCJcIixcclxuICAgIHZhbHVlOiBcIlwiLFxyXG4gICAgcGxhY2VIb2xkZXI6IFwi6K+36L6T5YWlXCIsXHJcbiAgICBtaW46IDAsXHJcbiAgICBtYXg6IDEwMCxcclxuICAgIHByZWNpc2lvbjogMCxcclxuICAgIGZvcm1hdHRlclBlcmNlbnQ6ICh2YWx1ZTogbnVtYmVyKSA9PiBgJHt2YWx1ZX1gLFxyXG4gICAgcGFyc2VyUGVyY2VudDogKHZhbHVlOiBzdHJpbmcpID0+IHZhbHVlLFxyXG4gIH0sXHJcbiAgY3VzdG9tOiB7XHJcbiAgICBuYW1lOiBcIlwiLFxyXG4gICAgdmFsdWU6IG51bGwsXHJcbiAgICBsYWJlbDogXCJcIixcclxuICB9LFxyXG59O1xyXG5cclxuZXhwb3J0IGNvbnN0IFBST19UQUJMRV9ERUZBVUxUX0NPTFVNTiA9IHtcclxuICB3aWR0aDogXCJcIixcclxuICBhbGlnbjogXCJsZWZ0XCIsXHJcbiAgZml4ZWRMZWZ0OiBmYWxzZSxcclxuICBmaXhlZFJpZ2h0OiBmYWxzZSxcclxuICBhdXhpbGlhcnlDb2x1bW46IGZhbHNlLFxyXG59O1xyXG4iXX0=
@@ -0,0 +1,21 @@
1
+ import { Component, ContentChild, Input } from "@angular/core";
2
+ export class PageContainerComponent {
3
+ constructor() {
4
+ this.title = "";
5
+ }
6
+ ngOnInit() { }
7
+ }
8
+ PageContainerComponent.decorators = [
9
+ { type: Component, args: [{
10
+ selector: "app-page-container",
11
+ template: "<nz-card\r\n [nzBorderless]=\"true\"\r\n [nzBodyStyle]=\"{ padding: '10px', width: '100%' }\"\r\n>\r\n <div class=\"page-container-title\" *ngIf=\"title\">{{ title }}</div>\r\n <div class=\"page-container-header\">\r\n <ng-container *ngTemplateOutlet=\"headerTpl\"></ng-container>\r\n </div>\r\n <div class=\"page-container-body\">\r\n <ng-container *ngTemplateOutlet=\"bodyTpl\"></ng-container>\r\n </div>\r\n</nz-card>\r\n",
12
+ styles: [".page-container-title{border-left:3px solid #096dd9;color:#1d1d1d;font-size:16px;margin-bottom:16px;padding-left:10px}.page-container-body,.page-container-header{box-sizing:border-box;padding:7px}"]
13
+ },] }
14
+ ];
15
+ PageContainerComponent.ctorParameters = () => [];
16
+ PageContainerComponent.propDecorators = {
17
+ title: [{ type: Input }],
18
+ headerTpl: [{ type: ContentChild, args: ["header",] }],
19
+ bodyTpl: [{ type: ContentChild, args: ["body",] }]
20
+ };
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS1jb250YWluZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IkQ6L3Byb2plY3RzL3Zwcy1mcm9udC9Gcm9udC9EYXNQTVNXZWIvcHJvamVjdHMvcHJvLXRhYmxlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9wYWdlLWNvbnRhaW5lci9wYWdlLWNvbnRhaW5lci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUF1QixNQUFNLGVBQWUsQ0FBQztBQU9wRixNQUFNLE9BQU8sc0JBQXNCO0lBS2pDO1FBSlMsVUFBSyxHQUFXLEVBQUUsQ0FBQztJQUliLENBQUM7SUFFaEIsUUFBUSxLQUFVLENBQUM7OztZQVpwQixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLG9CQUFvQjtnQkFDOUIsaWNBQThDOzthQUUvQzs7OztvQkFFRSxLQUFLO3dCQUNMLFlBQVksU0FBQyxRQUFRO3NCQUNyQixZQUFZLFNBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgQ29udGVudENoaWxkLCBJbnB1dCwgT25Jbml0LCBUZW1wbGF0ZVJlZiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogXCJhcHAtcGFnZS1jb250YWluZXJcIixcclxuICB0ZW1wbGF0ZVVybDogXCIuL3BhZ2UtY29udGFpbmVyLmNvbXBvbmVudC5odG1sXCIsXHJcbiAgc3R5bGVVcmxzOiBbXCIuL3BhZ2UtY29udGFpbmVyLmNvbXBvbmVudC5sZXNzXCJdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgUGFnZUNvbnRhaW5lckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgQElucHV0KCkgdGl0bGU6IHN0cmluZyA9IFwiXCI7XHJcbiAgQENvbnRlbnRDaGlsZChcImhlYWRlclwiKSBoZWFkZXJUcGwhOiBUZW1wbGF0ZVJlZjxhbnk+O1xyXG4gIEBDb250ZW50Q2hpbGQoXCJib2R5XCIpIGJvZHlUcGwhOiBUZW1wbGF0ZVJlZjxhbnk+O1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHt9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge31cclxufVxyXG4iXX0=
@@ -0,0 +1,25 @@
1
+ import { CommonModule } from "@angular/common";
2
+ import { HttpClientModule } from "@angular/common/http";
3
+ import { NgModule } from "@angular/core";
4
+ import { FormsModule, ReactiveFormsModule } from "@angular/forms";
5
+ import { RouterModule } from "@angular/router";
6
+ import { NzCardModule } from "ng-zorro-antd/card";
7
+ import { PageContainerComponent } from "./page-container.component";
8
+ export class PageContainerModule {
9
+ }
10
+ PageContainerModule.decorators = [
11
+ { type: NgModule, args: [{
12
+ imports: [
13
+ CommonModule,
14
+ FormsModule,
15
+ HttpClientModule,
16
+ RouterModule,
17
+ NzCardModule,
18
+ ReactiveFormsModule,
19
+ ],
20
+ declarations: [PageContainerComponent],
21
+ providers: [],
22
+ exports: [PageContainerComponent],
23
+ },] }
24
+ ];
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS1jb250YWluZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IkQ6L3Byb2plY3RzL3Zwcy1mcm9udC9Gcm9udC9EYXNQTVNXZWIvcHJvamVjdHMvcHJvLXRhYmxlL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9wYWdlLWNvbnRhaW5lci9wYWdlLWNvbnRhaW5lci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDbEQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFlcEUsTUFBTSxPQUFPLG1CQUFtQjs7O1lBYi9CLFFBQVEsU0FBQztnQkFDUixPQUFPLEVBQUU7b0JBQ1AsWUFBWTtvQkFDWixXQUFXO29CQUNYLGdCQUFnQjtvQkFDaEIsWUFBWTtvQkFDWixZQUFZO29CQUNaLG1CQUFtQjtpQkFDcEI7Z0JBQ0QsWUFBWSxFQUFFLENBQUMsc0JBQXNCLENBQUM7Z0JBQ3RDLFNBQVMsRUFBRSxFQUFFO2dCQUNiLE9BQU8sRUFBRSxDQUFDLHNCQUFzQixDQUFDO2FBQ2xDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xyXG5pbXBvcnQgeyBIdHRwQ2xpZW50TW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vbi9odHRwXCI7XHJcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcclxuaW1wb3J0IHsgUm91dGVyTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL3JvdXRlclwiO1xyXG5pbXBvcnQgeyBOekNhcmRNb2R1bGUgfSBmcm9tIFwibmctem9ycm8tYW50ZC9jYXJkXCI7XHJcbmltcG9ydCB7IFBhZ2VDb250YWluZXJDb21wb25lbnQgfSBmcm9tIFwiLi9wYWdlLWNvbnRhaW5lci5jb21wb25lbnRcIjtcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgRm9ybXNNb2R1bGUsXHJcbiAgICBIdHRwQ2xpZW50TW9kdWxlLFxyXG4gICAgUm91dGVyTW9kdWxlLFxyXG4gICAgTnpDYXJkTW9kdWxlLFxyXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcclxuICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW1BhZ2VDb250YWluZXJDb21wb25lbnRdLFxyXG4gIHByb3ZpZGVyczogW10sXHJcbiAgZXhwb3J0czogW1BhZ2VDb250YWluZXJDb21wb25lbnRdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgUGFnZUNvbnRhaW5lck1vZHVsZSB7fVxyXG4iXX0=