@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.
- package/README.md +24 -0
- package/bundles/yibozhang-pro-table.umd.js +3110 -0
- package/bundles/yibozhang-pro-table.umd.js.map +1 -0
- package/bundles/yibozhang-pro-table.umd.min.js +2 -0
- package/bundles/yibozhang-pro-table.umd.min.js.map +1 -0
- package/esm2015/lib/components/colmuns-setting/colmuns-setting.component.js +158 -0
- package/esm2015/lib/components/dynamic-search-field/dynamic-search-field.component.js +101 -0
- package/esm2015/lib/constants.js +89 -0
- package/esm2015/lib/page-container/page-container.component.js +21 -0
- package/esm2015/lib/page-container/page-container.module.js +25 -0
- package/esm2015/lib/page-public/antd-form.js +734 -0
- package/esm2015/lib/plate-input/plate-input.component.js +155 -0
- package/esm2015/lib/plate-input/plate-input.module.js +26 -0
- package/esm2015/lib/plate-input/plate-prefix-load.service.js +41 -0
- package/esm2015/lib/pro-table.component.js +983 -0
- package/esm2015/lib/pro-table.module.js +73 -0
- package/esm2015/lib/table-search-bar/table-search-bar-module.js +27 -0
- package/esm2015/lib/table-search-bar/table-search-bar.component.js +51 -0
- package/esm2015/lib/tokens.js +4 -0
- package/esm2015/lib/type.js +2 -0
- package/esm2015/public-api.js +12 -0
- package/esm2015/yibozhang-pro-table.js +13 -0
- package/fesm2015/yibozhang-pro-table.js +2448 -0
- package/fesm2015/yibozhang-pro-table.js.map +1 -0
- package/lib/components/colmuns-setting/colmuns-setting.component.d.ts +35 -0
- package/lib/components/colmuns-setting/colmuns-setting.component.d.ts.map +1 -0
- package/lib/components/dynamic-search-field/dynamic-search-field.component.d.ts +22 -0
- package/lib/components/dynamic-search-field/dynamic-search-field.component.d.ts.map +1 -0
- package/lib/constants.d.ts +20 -0
- package/lib/constants.d.ts.map +1 -0
- package/lib/page-container/page-container.component.d.ts +9 -0
- package/lib/page-container/page-container.component.d.ts.map +1 -0
- package/lib/page-container/page-container.module.d.ts +3 -0
- package/lib/page-container/page-container.module.d.ts.map +1 -0
- package/lib/page-public/antd-form.d.ts +99 -0
- package/lib/page-public/antd-form.d.ts.map +1 -0
- package/lib/plate-input/plate-input.component.d.ts +31 -0
- package/lib/plate-input/plate-input.component.d.ts.map +1 -0
- package/lib/plate-input/plate-input.module.d.ts +3 -0
- package/lib/plate-input/plate-input.module.d.ts.map +1 -0
- package/lib/plate-input/plate-prefix-load.service.d.ts +13 -0
- package/lib/plate-input/plate-prefix-load.service.d.ts.map +1 -0
- package/lib/pro-table.component.d.ts +122 -0
- package/lib/pro-table.component.d.ts.map +1 -0
- package/lib/pro-table.module.d.ts +3 -0
- package/lib/pro-table.module.d.ts.map +1 -0
- package/lib/table-search-bar/table-search-bar-module.d.ts +3 -0
- package/lib/table-search-bar/table-search-bar-module.d.ts.map +1 -0
- package/lib/table-search-bar/table-search-bar.component.d.ts +15 -0
- package/lib/table-search-bar/table-search-bar.component.d.ts.map +1 -0
- package/lib/tokens.d.ts +36 -0
- package/lib/tokens.d.ts.map +1 -0
- package/lib/type.d.ts +226 -0
- package/lib/type.d.ts.map +1 -0
- package/package.json +40 -0
- package/public-api.d.ts +9 -0
- package/public-api.d.ts.map +1 -0
- package/src/lib/styles/custom-antd.less +114 -0
- package/src/lib/styles/margin.css +90 -0
- package/src/lib/styles/theme.less +42 -0
- package/yibozhang-pro-table.d.ts +13 -0
- package/yibozhang-pro-table.d.ts.map +1 -0
- 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=
|