raise-common-lib 0.0.167 → 0.0.169

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 (34) hide show
  1. package/bundles/raise-common-lib.umd.js +271 -62
  2. package/bundles/raise-common-lib.umd.js.map +1 -1
  3. package/bundles/raise-common-lib.umd.min.js +1 -1
  4. package/bundles/raise-common-lib.umd.min.js.map +1 -1
  5. package/esm2015/lib/form/confirm-select/index.component.js +118 -0
  6. package/esm2015/lib/form/search-input/index.component.js +81 -0
  7. package/esm2015/lib/layout/grid-box/index.component.js +17 -29
  8. package/esm2015/lib/layout/multi-tab/index.component.js +6 -1
  9. package/esm2015/lib/layout/page-list/index.component.js +9 -28
  10. package/esm2015/lib/raise-common-lib.module.js +7 -1
  11. package/esm2015/public-api.js +2 -1
  12. package/esm2015/raise-common-lib.js +5 -4
  13. package/esm5/lib/form/confirm-select/index.component.js +143 -0
  14. package/esm5/lib/form/search-input/index.component.js +97 -0
  15. package/esm5/lib/layout/grid-box/index.component.js +18 -33
  16. package/esm5/lib/layout/multi-tab/index.component.js +6 -1
  17. package/esm5/lib/layout/page-list/index.component.js +10 -32
  18. package/esm5/lib/raise-common-lib.module.js +7 -1
  19. package/esm5/public-api.js +2 -1
  20. package/esm5/raise-common-lib.js +5 -4
  21. package/fesm2015/raise-common-lib.js +227 -53
  22. package/fesm2015/raise-common-lib.js.map +1 -1
  23. package/fesm5/raise-common-lib.js +268 -61
  24. package/fesm5/raise-common-lib.js.map +1 -1
  25. package/lib/form/confirm-select/index.component.d.ts +25 -0
  26. package/lib/form/search-input/index.component.d.ts +14 -0
  27. package/lib/layout/grid-box/index.component.d.ts +3 -5
  28. package/lib/layout/multi-tab/index.component.d.ts +1 -0
  29. package/lib/layout/page-list/index.component.d.ts +1 -4
  30. package/package.json +1 -1
  31. package/public-api.d.ts +1 -0
  32. package/raise-common-lib.d.ts +3 -2
  33. package/raise-common-lib.metadata.json +1 -1
  34. package/src/assets/img/toolbar-action-submitForApproval.svg +3 -3
@@ -0,0 +1,118 @@
1
+ /**
2
+ * @fileoverview added by tsickle
3
+ * Generated from: lib/form/confirm-select/index.component.ts
4
+ * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
5
+ */
6
+ import { Component, EventEmitter, Input, Output, ViewChild, } from "@angular/core";
7
+ import { MultiSelectComponent } from "@syncfusion/ej2-angular-dropdowns";
8
+ export class ConfirmSelectComponent {
9
+ constructor() {
10
+ this.dataSource = [];
11
+ this.disabled = false;
12
+ this.fields = { text: "Game", value: "Id" };
13
+ this.showSelectAll = true;
14
+ this.valueChange = new EventEmitter();
15
+ this.selectedItems = [];
16
+ this.isInteracted = false;
17
+ }
18
+ /**
19
+ * @return {?}
20
+ */
21
+ ngOnInit() {
22
+ this.getInfo();
23
+ this.resetSelectedItems();
24
+ }
25
+ /**
26
+ * @param {?} changes
27
+ * @return {?}
28
+ */
29
+ ngOnChanges(changes) {
30
+ if (changes.value && !changes.value.firstChange) {
31
+ this.resetSelectedItems();
32
+ }
33
+ }
34
+ /**
35
+ * @return {?}
36
+ */
37
+ getInfo() {
38
+ this.translation = JSON.parse(localStorage.getItem("translation"));
39
+ }
40
+ /**
41
+ * @return {?}
42
+ */
43
+ resetSelectedItems() {
44
+ this.selectedItems = JSON.parse(JSON.stringify(this.value || []));
45
+ }
46
+ /**
47
+ * @return {?}
48
+ */
49
+ onCancel() {
50
+ this.isInteracted = true;
51
+ this.resetSelectedItems();
52
+ this.comfirmSelect.hidePopup();
53
+ }
54
+ /**
55
+ * @return {?}
56
+ */
57
+ onApply() {
58
+ this.isInteracted = true;
59
+ /** @type {?} */
60
+ const val = this.comfirmSelect.value;
61
+ this.valueChange.emit(val);
62
+ this.comfirmSelect.hidePopup();
63
+ }
64
+ /**
65
+ * @param {?} e
66
+ * @return {?}
67
+ */
68
+ onClose(e) {
69
+ if (this.isInteracted) {
70
+ this.isInteracted = false;
71
+ }
72
+ else {
73
+ this.resetSelectedItems();
74
+ }
75
+ }
76
+ }
77
+ ConfirmSelectComponent.decorators = [
78
+ { type: Component, args: [{
79
+ selector: "rs-confirm-select",
80
+ template: "<div class=\"rs-confirm-select\">\r\n <ejs-multiselect\r\n #comfirmSelect\r\n [dataSource]=\"dataSource\"\r\n [showDropDownIcon]=\"true\"\r\n [placeholder]=\"placeholder\"\r\n [(ngModel)]=\"selectedItems\"\r\n [fields]=\"fields\"\r\n [showSelectAll]=\"showSelectAll\"\r\n mode=\"CheckBox\"\r\n [footerTemplate]=\"footerTemplate\"\r\n [showClearButton]=\"false\"\r\n (close)=\"onClose($event)\"\r\n >\r\n <ng-template #footerTemplate=\"\" let-data=\"data\">\r\n <div class=\"confirm-select-footer\">\r\n <button class=\"e-btn\" (click)=\"onCancel()\">Cancel</button>\r\n <button class=\"e-btn e-primary\" (click)=\"onApply()\">Apply</button>\r\n </div>\r\n </ng-template>\r\n </ejs-multiselect>\r\n</div>\r\n",
81
+ styles: [".confirm-select-footer{display:flex;align-items:center;justify-content:flex-end;padding:0 12px;gap:12px;height:40px;border-top:solid 1px var(--rs-border-color)}"]
82
+ }] }
83
+ ];
84
+ ConfirmSelectComponent.propDecorators = {
85
+ comfirmSelect: [{ type: ViewChild, args: ["comfirmSelect", { static: false },] }],
86
+ value: [{ type: Input }],
87
+ dataSource: [{ type: Input }],
88
+ disabled: [{ type: Input }],
89
+ fields: [{ type: Input }],
90
+ placeholder: [{ type: Input }],
91
+ showSelectAll: [{ type: Input }],
92
+ valueChange: [{ type: Output }]
93
+ };
94
+ if (false) {
95
+ /** @type {?} */
96
+ ConfirmSelectComponent.prototype.comfirmSelect;
97
+ /** @type {?} */
98
+ ConfirmSelectComponent.prototype.value;
99
+ /** @type {?} */
100
+ ConfirmSelectComponent.prototype.dataSource;
101
+ /** @type {?} */
102
+ ConfirmSelectComponent.prototype.disabled;
103
+ /** @type {?} */
104
+ ConfirmSelectComponent.prototype.fields;
105
+ /** @type {?} */
106
+ ConfirmSelectComponent.prototype.placeholder;
107
+ /** @type {?} */
108
+ ConfirmSelectComponent.prototype.showSelectAll;
109
+ /** @type {?} */
110
+ ConfirmSelectComponent.prototype.valueChange;
111
+ /** @type {?} */
112
+ ConfirmSelectComponent.prototype.translation;
113
+ /** @type {?} */
114
+ ConfirmSelectComponent.prototype.selectedItems;
115
+ /** @type {?} */
116
+ ConfirmSelectComponent.prototype.isInteracted;
117
+ }
118
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vcmFpc2UtY29tbW9uLWxpYi8iLCJzb3VyY2VzIjpbImxpYi9mb3JtL2NvbmZpcm0tc2VsZWN0L2luZGV4LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLE9BQU8sRUFDTCxTQUFTLEVBQ1QsWUFBWSxFQUNaLEtBQUssRUFFTCxNQUFNLEVBR04sU0FBUyxHQUNWLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBT3pFLE1BQU0sT0FBTyxzQkFBc0I7SUFMbkM7UUFTVyxlQUFVLEdBQUcsRUFBRSxDQUFDO1FBQ2hCLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFDakIsV0FBTSxHQUFHLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLENBQUM7UUFFdkMsa0JBQWEsR0FBRyxJQUFJLENBQUM7UUFFcEIsZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO1FBRzNDLGtCQUFhLEdBQUcsRUFBRSxDQUFDO1FBQ25CLGlCQUFZLEdBQUcsS0FBSyxDQUFDO0lBeUN2QixDQUFDOzs7O0lBdkNDLFFBQVE7UUFDTixJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDZixJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztJQUM1QixDQUFDOzs7OztJQUVELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLE9BQU8sQ0FBQyxLQUFLLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLFdBQVcsRUFBRTtZQUMvQyxJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztTQUMzQjtJQUNILENBQUM7Ozs7SUFFRCxPQUFPO1FBQ0wsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQztJQUNyRSxDQUFDOzs7O0lBRUQsa0JBQWtCO1FBQ2hCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxLQUFLLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQztJQUNwRSxDQUFDOzs7O0lBRUQsUUFBUTtRQUNOLElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxDQUFDO1FBQ3pCLElBQUksQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO1FBQzFCLElBQUksQ0FBQyxhQUFhLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDakMsQ0FBQzs7OztJQUVELE9BQU87UUFDTCxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQzs7Y0FDbkIsR0FBRyxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsS0FBSztRQUNwQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUMzQixJQUFJLENBQUMsYUFBYSxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQ2pDLENBQUM7Ozs7O0lBRUQsT0FBTyxDQUFDLENBQUM7UUFDUCxJQUFJLElBQUksQ0FBQyxZQUFZLEVBQUU7WUFDckIsSUFBSSxDQUFDLFlBQVksR0FBRyxLQUFLLENBQUM7U0FDM0I7YUFBTTtZQUNMLElBQUksQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO1NBQzNCO0lBQ0gsQ0FBQzs7O1lBM0RGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsbUJBQW1CO2dCQUM3QixpeEJBQXFDOzthQUV0Qzs7OzRCQUVFLFNBQVMsU0FBQyxlQUFlLEVBQUUsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFO29CQUU1QyxLQUFLO3lCQUNMLEtBQUs7dUJBQ0wsS0FBSztxQkFDTCxLQUFLOzBCQUNMLEtBQUs7NEJBQ0wsS0FBSzswQkFFTCxNQUFNOzs7O0lBVFAsK0NBQ29DOztJQUNwQyx1Q0FBZTs7SUFDZiw0Q0FBeUI7O0lBQ3pCLDBDQUEwQjs7SUFDMUIsd0NBQWdEOztJQUNoRCw2Q0FBcUI7O0lBQ3JCLCtDQUE4Qjs7SUFFOUIsNkNBQTJDOztJQUUzQyw2Q0FBWTs7SUFDWiwrQ0FBbUI7O0lBQ25CLDhDQUFxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ29tcG9uZW50LFxyXG4gIEV2ZW50RW1pdHRlcixcclxuICBJbnB1dCxcclxuICBPbkluaXQsXHJcbiAgT3V0cHV0LFxyXG4gIE9uQ2hhbmdlcyxcclxuICBTaW1wbGVDaGFuZ2VzLFxyXG4gIFZpZXdDaGlsZCxcclxufSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBNdWx0aVNlbGVjdENvbXBvbmVudCB9IGZyb20gXCJAc3luY2Z1c2lvbi9lajItYW5ndWxhci1kcm9wZG93bnNcIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiBcInJzLWNvbmZpcm0tc2VsZWN0XCIsXHJcbiAgdGVtcGxhdGVVcmw6IFwiLi9pbmRleC5jb21wb25lbnQuaHRtbFwiLFxyXG4gIHN0eWxlVXJsczogW1wiLi9pbmRleC5jb21wb25lbnQuc2Nzc1wiXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIENvbmZpcm1TZWxlY3RDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uQ2hhbmdlcyB7XHJcbiAgQFZpZXdDaGlsZChcImNvbWZpcm1TZWxlY3RcIiwgeyBzdGF0aWM6IGZhbHNlIH0pXHJcbiAgY29tZmlybVNlbGVjdDogTXVsdGlTZWxlY3RDb21wb25lbnQ7XHJcbiAgQElucHV0KCkgdmFsdWU7XHJcbiAgQElucHV0KCkgZGF0YVNvdXJjZSA9IFtdO1xyXG4gIEBJbnB1dCgpIGRpc2FibGVkID0gZmFsc2U7XHJcbiAgQElucHV0KCkgZmllbGRzID0geyB0ZXh0OiBcIkdhbWVcIiwgdmFsdWU6IFwiSWRcIiB9O1xyXG4gIEBJbnB1dCgpIHBsYWNlaG9sZGVyO1xyXG4gIEBJbnB1dCgpIHNob3dTZWxlY3RBbGwgPSB0cnVlO1xyXG5cclxuICBAT3V0cHV0KCkgdmFsdWVDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyKCk7XHJcblxyXG4gIHRyYW5zbGF0aW9uO1xyXG4gIHNlbGVjdGVkSXRlbXMgPSBbXTtcclxuICBpc0ludGVyYWN0ZWQgPSBmYWxzZTtcclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgICB0aGlzLmdldEluZm8oKTtcclxuICAgIHRoaXMucmVzZXRTZWxlY3RlZEl0ZW1zKCk7XHJcbiAgfVxyXG5cclxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKSB7XHJcbiAgICBpZiAoY2hhbmdlcy52YWx1ZSAmJiAhY2hhbmdlcy52YWx1ZS5maXJzdENoYW5nZSkge1xyXG4gICAgICB0aGlzLnJlc2V0U2VsZWN0ZWRJdGVtcygpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgZ2V0SW5mbygpIHtcclxuICAgIHRoaXMudHJhbnNsYXRpb24gPSBKU09OLnBhcnNlKGxvY2FsU3RvcmFnZS5nZXRJdGVtKFwidHJhbnNsYXRpb25cIikpO1xyXG4gIH1cclxuXHJcbiAgcmVzZXRTZWxlY3RlZEl0ZW1zKCkge1xyXG4gICAgdGhpcy5zZWxlY3RlZEl0ZW1zID0gSlNPTi5wYXJzZShKU09OLnN0cmluZ2lmeSh0aGlzLnZhbHVlIHx8IFtdKSk7XHJcbiAgfVxyXG5cclxuICBvbkNhbmNlbCgpIHtcclxuICAgIHRoaXMuaXNJbnRlcmFjdGVkID0gdHJ1ZTtcclxuICAgIHRoaXMucmVzZXRTZWxlY3RlZEl0ZW1zKCk7XHJcbiAgICB0aGlzLmNvbWZpcm1TZWxlY3QuaGlkZVBvcHVwKCk7XHJcbiAgfVxyXG5cclxuICBvbkFwcGx5KCkge1xyXG4gICAgdGhpcy5pc0ludGVyYWN0ZWQgPSB0cnVlO1xyXG4gICAgY29uc3QgdmFsID0gdGhpcy5jb21maXJtU2VsZWN0LnZhbHVlO1xyXG4gICAgdGhpcy52YWx1ZUNoYW5nZS5lbWl0KHZhbCk7XHJcbiAgICB0aGlzLmNvbWZpcm1TZWxlY3QuaGlkZVBvcHVwKCk7XHJcbiAgfVxyXG5cclxuICBvbkNsb3NlKGUpIHtcclxuICAgIGlmICh0aGlzLmlzSW50ZXJhY3RlZCkge1xyXG4gICAgICB0aGlzLmlzSW50ZXJhY3RlZCA9IGZhbHNlO1xyXG4gICAgfSBlbHNlIHtcclxuICAgICAgdGhpcy5yZXNldFNlbGVjdGVkSXRlbXMoKTtcclxuICAgIH1cclxuICB9XHJcbn1cclxuIl19
@@ -0,0 +1,81 @@
1
+ /**
2
+ * @fileoverview added by tsickle
3
+ * Generated from: lib/form/search-input/index.component.ts
4
+ * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
5
+ */
6
+ // 组件类
7
+ import { Component, EventEmitter, Input, Output } from "@angular/core";
8
+ import { debounce } from "lodash";
9
+ export class SearchInputComponent {
10
+ constructor() {
11
+ this.placeholder = "";
12
+ this.hanleSearch = new EventEmitter();
13
+ this.handleInput = new EventEmitter();
14
+ this.searchValue = "";
15
+ }
16
+ /**
17
+ * @return {?}
18
+ */
19
+ ngOnInit() {
20
+ this.getInfo();
21
+ this.debouncedInput = debounce((/**
22
+ * @return {?}
23
+ */
24
+ () => {
25
+ this.onSeach();
26
+ }), 300);
27
+ }
28
+ /**
29
+ * @return {?}
30
+ */
31
+ getInfo() {
32
+ this.translation = JSON.parse(localStorage.getItem("translation"));
33
+ this.placeholder = this.placeholder || this.translation.SEARCH;
34
+ }
35
+ /**
36
+ * @param {?} e
37
+ * @return {?}
38
+ */
39
+ onInput(e) {
40
+ this.handleInput.emit(e.value);
41
+ this.debouncedInput();
42
+ }
43
+ /**
44
+ * @return {?}
45
+ */
46
+ onSeach() {
47
+ this.hanleSearch.emit(this.searchValue);
48
+ }
49
+ }
50
+ SearchInputComponent.decorators = [
51
+ { type: Component, args: [{
52
+ selector: "rs-search-input",
53
+ template: "<div class=\"rs-search-input\">\r\n <ejs-textbox\r\n type=\"text\"\r\n class=\"e-input\"\r\n [(ngModel)]=\"searchValue\"\r\n (input)=\"onInput($event)\"\r\n [placeholder]=\"placeholder\"\r\n [showClearButton]=\"true\"\r\n autocomplete=\"off\"\r\n ></ejs-textbox>\r\n</div>\r\n",
54
+ styles: [".rs-search-input{width:240px}.rs-search-input ::ng-deep .e-input-group{border-radius:14px!important}.rs-search-input ::ng-deep .e-input-group.e-input-focus,.rs-search-input ::ng-deep .e-input-group:hover{box-shadow:0 0 3px 0 rgba(31,123,255,.4)!important;border-color:var(--rs-input-hover-border-color)!important}.rs-search-input ::ng-deep .e-input-group.e-input-focus input.e-input,.rs-search-input ::ng-deep .e-input-group:hover input.e-input{box-shadow:none!important}.rs-search-input ::ng-deep .e-input-group input.e-input{width:calc(100% - 50px);height:26px}.rs-search-input ::ng-deep .e-input-group input.e-input:hover{box-shadow:none!important}.rs-search-input ::ng-deep .e-input-group::before{content:\"\"!important;margin:6px 0 0 8px;display:block;width:16px;height:16px;background-image:url(/assets/img/search.svg);background-size:cover;background-position:center}"]
55
+ }] }
56
+ ];
57
+ /** @nocollapse */
58
+ SearchInputComponent.ctorParameters = () => [];
59
+ SearchInputComponent.propDecorators = {
60
+ placeholder: [{ type: Input }],
61
+ hanleSearch: [{ type: Output }],
62
+ handleInput: [{ type: Output }]
63
+ };
64
+ if (false) {
65
+ /** @type {?} */
66
+ SearchInputComponent.prototype.placeholder;
67
+ /** @type {?} */
68
+ SearchInputComponent.prototype.hanleSearch;
69
+ /** @type {?} */
70
+ SearchInputComponent.prototype.handleInput;
71
+ /**
72
+ * @type {?}
73
+ * @private
74
+ */
75
+ SearchInputComponent.prototype.debouncedInput;
76
+ /** @type {?} */
77
+ SearchInputComponent.prototype.searchValue;
78
+ /** @type {?} */
79
+ SearchInputComponent.prototype.translation;
80
+ }
81
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vcmFpc2UtY29tbW9uLWxpYi8iLCJzb3VyY2VzIjpbImxpYi9mb3JtL3NlYXJjaC1pbnB1dC9pbmRleC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQ0EsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMvRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBT2xDLE1BQU0sT0FBTyxvQkFBb0I7SUFDL0I7UUFFQSxnQkFBVyxHQUFHLEVBQUUsQ0FBQztRQUVqQixnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7UUFFakMsZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO1FBRWpDLGdCQUFXLEdBQUcsRUFBRSxDQUFDO0lBUkYsQ0FBQzs7OztJQVdoQixRQUFRO1FBQ04sSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2YsSUFBSSxDQUFDLGNBQWMsR0FBRyxRQUFROzs7UUFBQyxHQUFHLEVBQUU7WUFDbEMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2pCLENBQUMsR0FBRSxHQUFHLENBQUMsQ0FBQztJQUNWLENBQUM7Ozs7SUFFRCxPQUFPO1FBQ0wsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQztRQUNuRSxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxXQUFXLElBQUksSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUM7SUFDakUsQ0FBQzs7Ozs7SUFDRCxPQUFPLENBQUMsQ0FBQztRQUNQLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMvQixJQUFJLENBQUMsY0FBYyxFQUFFLENBQUM7SUFDeEIsQ0FBQzs7OztJQUVELE9BQU87UUFDTCxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDMUMsQ0FBQzs7O1lBbkNGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsaUJBQWlCO2dCQUMzQix1VEFBcUM7O2FBRXRDOzs7OzswQkFHRSxLQUFLOzBCQUVMLE1BQU07MEJBRU4sTUFBTTs7OztJQUpQLDJDQUNpQjs7SUFDakIsMkNBQ2lDOztJQUNqQywyQ0FDaUM7Ozs7O0lBQ2pDLDhDQUFpQzs7SUFDakMsMkNBQWlCOztJQUNqQiwyQ0FBWSIsInNvdXJjZXNDb250ZW50IjpbIi8vIOe7hOS7tuexu1xyXG5pbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uSW5pdCwgT3V0cHV0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgZGVib3VuY2UgfSBmcm9tIFwibG9kYXNoXCI7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogXCJycy1zZWFyY2gtaW5wdXRcIixcclxuICB0ZW1wbGF0ZVVybDogXCIuL2luZGV4LmNvbXBvbmVudC5odG1sXCIsXHJcbiAgc3R5bGVVcmxzOiBbXCIuL2luZGV4LmNvbXBvbmVudC5zY3NzXCJdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2VhcmNoSW5wdXRDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIGNvbnN0cnVjdG9yKCkge31cclxuICBASW5wdXQoKVxyXG4gIHBsYWNlaG9sZGVyID0gXCJcIjtcclxuICBAT3V0cHV0KClcclxuICBoYW5sZVNlYXJjaCA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuICBAT3V0cHV0KClcclxuICBoYW5kbGVJbnB1dCA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuICBwcml2YXRlIGRlYm91bmNlZElucHV0OiBGdW5jdGlvbjtcclxuICBzZWFyY2hWYWx1ZSA9IFwiXCI7XHJcbiAgdHJhbnNsYXRpb247XHJcblxyXG4gIG5nT25Jbml0KCkge1xyXG4gICAgdGhpcy5nZXRJbmZvKCk7XHJcbiAgICB0aGlzLmRlYm91bmNlZElucHV0ID0gZGVib3VuY2UoKCkgPT4ge1xyXG4gICAgICB0aGlzLm9uU2VhY2goKTtcclxuICAgIH0sIDMwMCk7XHJcbiAgfVxyXG5cclxuICBnZXRJbmZvKCkge1xyXG4gICAgdGhpcy50cmFuc2xhdGlvbiA9IEpTT04ucGFyc2UobG9jYWxTdG9yYWdlLmdldEl0ZW0oXCJ0cmFuc2xhdGlvblwiKSk7XHJcbiAgICB0aGlzLnBsYWNlaG9sZGVyID0gdGhpcy5wbGFjZWhvbGRlciB8fCB0aGlzLnRyYW5zbGF0aW9uLlNFQVJDSDtcclxuICB9XHJcbiAgb25JbnB1dChlKSB7XHJcbiAgICB0aGlzLmhhbmRsZUlucHV0LmVtaXQoZS52YWx1ZSk7XHJcbiAgICB0aGlzLmRlYm91bmNlZElucHV0KCk7XHJcbiAgfVxyXG5cclxuICBvblNlYWNoKCkge1xyXG4gICAgdGhpcy5oYW5sZVNlYXJjaC5lbWl0KHRoaXMuc2VhcmNoVmFsdWUpO1xyXG4gIH1cclxufVxyXG4iXX0=
@@ -4,15 +4,15 @@
4
4
  * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
5
5
  */
6
6
  // 组件类
7
- import { Component, ContentChild, Input, } from "@angular/core";
7
+ import { Component, ContentChild, EventEmitter, Input, Output, } from "@angular/core";
8
8
  import { CommonGridComponent } from "../../common-grid/index.component";
9
- import { debounce } from "lodash";
10
9
  import { GridComponent } from "@syncfusion/ej2-angular-grids";
11
10
  import { TreeGridComponent } from "@syncfusion/ej2-angular-treegrid";
12
11
  export class GridBoxComponent {
13
12
  constructor() {
14
13
  this.hideSearch = false;
15
14
  this.isInner = false;
15
+ this.onGridSearch = new EventEmitter();
16
16
  this.hasWholeToolbarSlot = false;
17
17
  }
18
18
  /**
@@ -20,12 +20,6 @@ export class GridBoxComponent {
20
20
  */
21
21
  ngOnInit() {
22
22
  this.getInfo();
23
- this.debouncedInput = debounce((/**
24
- * @return {?}
25
- */
26
- () => {
27
- this.onSeach();
28
- }), 300);
29
23
  }
30
24
  /**
31
25
  * @return {?}
@@ -41,31 +35,29 @@ export class GridBoxComponent {
41
35
  this.hasWholeToolbarSlot = !!this.wholeToolbarSlot;
42
36
  }
43
37
  /**
38
+ * @param {?} value
44
39
  * @return {?}
45
40
  */
46
- onSeach() {
41
+ onSeach(value) {
47
42
  if (this.gridContent) {
48
- this.gridContent.grid.search(this.searchValue);
43
+ this.gridContent.grid.search(value);
49
44
  }
50
45
  else if (this.orignGrid) {
51
- this.orignGrid.search(this.searchValue);
46
+ this.orignGrid.search(value);
52
47
  }
53
48
  else if (this.treeGrid) {
54
- this.treeGrid.search(this.searchValue);
49
+ this.treeGrid.search(value);
50
+ }
51
+ else {
52
+ this.onGridSearch.emit(value);
55
53
  }
56
- }
57
- /**
58
- * @return {?}
59
- */
60
- onInput() {
61
- this.debouncedInput();
62
54
  }
63
55
  }
64
56
  GridBoxComponent.decorators = [
65
57
  { type: Component, args: [{
66
58
  selector: "rs-grid-box",
67
- template: "<div class=\"rs-grid-box\" [ngClass]=\"{ 'is-not-inner': !isInner }\">\r\n <div class=\"rs-content-tab\">\r\n <ng-content select=\"[contentTabSlot]\"></ng-content>\r\n </div>\r\n <div class=\"rs-toolbar-wrap\">\r\n <div class=\"rs-whole-bar\" *ngIf=\"hasWholeToolbarSlot\">\r\n <ng-content select=\"[wholeToolbarSlot]\"></ng-content>\r\n </div>\r\n <div class=\"rs-left-col\" *ngIf=\"!hasWholeToolbarSlot\">\r\n <ng-content select=\"[leftToolbarBtnSlot]\"></ng-content>\r\n </div>\r\n <div class=\"rs-right-col\" *ngIf=\"!hasWholeToolbarSlot\">\r\n <ng-content select=\"[rightToolbarBtnSlot]\"></ng-content>\r\n <div class=\"rs-search-input\" *ngIf=\"!hideSearch\">\r\n <ejs-textbox\r\n type=\"text\"\r\n class=\"e-input\"\r\n [(ngModel)]=\"searchValue\"\r\n (input)=\"onInput()\"\r\n [placeholder]=\"translation.SEARCH_ALL_FIELD|| '.SEARCH_ALL_FIELD'\"\r\n [showClearButton]=\"true\"\r\n autocomplete=\"off\"\r\n ></ejs-textbox>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"rs-grid-wrap\">\r\n <ng-content select=\"[gridSlot]\"></ng-content>\r\n </div>\r\n</div>\r\n",
68
- styles: [":host{height:100%}.rs-grid-box{display:flex;flex-direction:column;height:100%}.rs-grid-box.is-not-inner{border-radius:15px;padding:12px 20px;background:#fff;border:1px solid var(--rs-border-color);box-shadow:0 0 4px 0 rgba(0,0,0,.1)}.rs-grid-box .rs-toolbar-wrap{display:flex;justify-content:space-between;align-items:center;padding-bottom:4px;border-bottom:1px solid #eaedf0}.rs-grid-box .rs-toolbar-wrap .rs-whole-bar{width:100%}.rs-grid-box .rs-toolbar-wrap .rs-left-col,.rs-grid-box .rs-toolbar-wrap .rs-right-col{display:flex;align-items:center}.rs-grid-box .rs-toolbar-wrap .rs-left-col ::ng-deep .e-btn,.rs-grid-box .rs-toolbar-wrap .rs-right-col ::ng-deep .e-btn{height:24px!important;min-width:auto!important}.rs-grid-box .rs-toolbar-wrap .rs-left-col{flex:1;width:0;gap:4px}.rs-grid-box .rs-toolbar-wrap .rs-right-col{gap:12px}.rs-grid-box .rs-grid-wrap{flex:1;height:0}.rs-grid-box .rs-search-input{width:240px}.rs-grid-box .rs-search-input ::ng-deep .e-input-group{border-radius:14px!important}.rs-grid-box .rs-search-input ::ng-deep .e-input-group.e-input-focus,.rs-grid-box .rs-search-input ::ng-deep .e-input-group:hover{box-shadow:0 0 3px 0 rgba(31,123,255,.4)!important;border-color:var(--rs-input-hover-border-color)!important}.rs-grid-box .rs-search-input ::ng-deep .e-input-group.e-input-focus input.e-input,.rs-grid-box .rs-search-input ::ng-deep .e-input-group:hover input.e-input{box-shadow:none!important}.rs-grid-box .rs-search-input ::ng-deep .e-input-group input.e-input{width:calc(100% - 50px);height:26px}.rs-grid-box .rs-search-input ::ng-deep .e-input-group input.e-input:hover{box-shadow:none!important}.rs-grid-box .rs-search-input ::ng-deep .e-input-group::before{content:\"\"!important;margin:6px 0 0 8px;display:block;width:16px;height:16px;background-image:url(/assets/img/search.svg);background-size:cover;background-position:center}"]
59
+ template: "<div class=\"rs-grid-box\" [ngClass]=\"{ 'is-not-inner': !isInner }\">\r\n <div class=\"rs-content-tab\">\r\n <ng-content select=\"[contentTabSlot]\"></ng-content>\r\n </div>\r\n <div class=\"rs-toolbar-wrap\">\r\n <div class=\"rs-whole-bar\" *ngIf=\"hasWholeToolbarSlot\">\r\n <ng-content select=\"[wholeToolbarSlot]\"></ng-content>\r\n </div>\r\n <div class=\"rs-left-col\" *ngIf=\"!hasWholeToolbarSlot\">\r\n <ng-content select=\"[leftToolbarBtnSlot]\"></ng-content>\r\n </div>\r\n <div class=\"rs-right-col\" *ngIf=\"!hasWholeToolbarSlot\">\r\n <ng-content select=\"[rightToolbarBtnSlot]\"></ng-content>\r\n <rs-search-input\r\n *ngIf=\"!hideSearch\"\r\n [placeholder]=\"translation.SEARCH_ALL_FIELD\"\r\n (hanleSearch)=\"onSeach($event)\"\r\n ></rs-search-input>\r\n </div>\r\n </div>\r\n <div class=\"rs-grid-wrap\">\r\n <ng-content select=\"[gridSlot]\"></ng-content>\r\n </div>\r\n</div>\r\n",
60
+ styles: [":host{height:100%}.rs-grid-box{display:flex;flex-direction:column;height:100%}.rs-grid-box.is-not-inner{border-radius:15px;padding:12px 20px;background:#fff;border:1px solid var(--rs-border-color);box-shadow:0 0 4px 0 rgba(0,0,0,.1)}.rs-grid-box .rs-toolbar-wrap{display:flex;justify-content:space-between;align-items:center;padding-bottom:4px;border-bottom:1px solid #eaedf0}.rs-grid-box .rs-toolbar-wrap .rs-whole-bar{width:100%}.rs-grid-box .rs-toolbar-wrap .rs-left-col,.rs-grid-box .rs-toolbar-wrap .rs-right-col{display:flex;align-items:center}.rs-grid-box .rs-toolbar-wrap .rs-left-col ::ng-deep .e-btn,.rs-grid-box .rs-toolbar-wrap .rs-right-col ::ng-deep .e-btn{height:24px!important;min-width:auto!important}.rs-grid-box .rs-toolbar-wrap .rs-left-col{flex:1;width:0;gap:4px}.rs-grid-box .rs-toolbar-wrap .rs-right-col{gap:12px}.rs-grid-box .rs-grid-wrap{flex:1;height:0}"]
69
61
  }] }
70
62
  ];
71
63
  GridBoxComponent.propDecorators = {
@@ -74,7 +66,8 @@ GridBoxComponent.propDecorators = {
74
66
  treeGrid: [{ type: ContentChild, args: [TreeGridComponent, { static: false },] }],
75
67
  wholeToolbarSlot: [{ type: ContentChild, args: ["wholeToolbarSlot", { static: false },] }],
76
68
  hideSearch: [{ type: Input }],
77
- isInner: [{ type: Input }]
69
+ isInner: [{ type: Input }],
70
+ onGridSearch: [{ type: Output }]
78
71
  };
79
72
  if (false) {
80
73
  /** @type {?} */
@@ -89,16 +82,11 @@ if (false) {
89
82
  GridBoxComponent.prototype.hideSearch;
90
83
  /** @type {?} */
91
84
  GridBoxComponent.prototype.isInner;
92
- /**
93
- * @type {?}
94
- * @private
95
- */
96
- GridBoxComponent.prototype.debouncedInput;
85
+ /** @type {?} */
86
+ GridBoxComponent.prototype.onGridSearch;
97
87
  /** @type {?} */
98
88
  GridBoxComponent.prototype.hasWholeToolbarSlot;
99
89
  /** @type {?} */
100
90
  GridBoxComponent.prototype.translation;
101
- /** @type {?} */
102
- GridBoxComponent.prototype.searchValue;
103
91
  }
104
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vcmFpc2UtY29tbW9uLWxpYi8iLCJzb3VyY2VzIjpbImxpYi9sYXlvdXQvZ3JpZC1ib3gvaW5kZXguY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUNBLE9BQU8sRUFFTCxTQUFTLEVBQ1QsWUFBWSxFQUNaLEtBQUssR0FFTixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUN4RSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBQ2xDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUM5RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQU9yRSxNQUFNLE9BQU8sZ0JBQWdCO0lBTDdCO1FBV1csZUFBVSxHQUFHLEtBQUssQ0FBQztRQUNuQixZQUFPLEdBQUcsS0FBSyxDQUFDO1FBR3pCLHdCQUFtQixHQUFZLEtBQUssQ0FBQztJQWdDdkMsQ0FBQzs7OztJQTdCQyxRQUFRO1FBQ04sSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2YsSUFBSSxDQUFDLGNBQWMsR0FBRyxRQUFROzs7UUFBQyxHQUFHLEVBQUU7WUFDbEMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2pCLENBQUMsR0FBRSxHQUFHLENBQUMsQ0FBQztJQUNWLENBQUM7Ozs7SUFFRCxPQUFPO1FBQ0wsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQztJQUNyRSxDQUFDOzs7O0lBQ0Qsa0JBQWtCO1FBQ2hCLDJCQUEyQjtRQUMzQixJQUFJLENBQUMsbUJBQW1CLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQztJQUNyRCxDQUFDOzs7O0lBR0QsT0FBTztRQUNMLElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUNwQixJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1NBQ2hEO2FBQU0sSUFBSSxJQUFJLENBQUMsU0FBUyxFQUFFO1lBQ3pCLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztTQUN6QzthQUFNLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUN4QixJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7U0FDeEM7SUFDSCxDQUFDOzs7O0lBRUQsT0FBTztRQUNMLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztJQUN4QixDQUFDOzs7WUE5Q0YsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxhQUFhO2dCQUN2Qixnc0NBQXFDOzthQUV0Qzs7OzBCQUVFLFlBQVksU0FBQyxtQkFBbUIsRUFBRSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUU7d0JBQ25ELFlBQVksU0FBQyxhQUFhLEVBQUUsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFO3VCQUM3QyxZQUFZLFNBQUMsaUJBQWlCLEVBQUUsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFOytCQUNqRCxZQUFZLFNBQUMsa0JBQWtCLEVBQUUsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFO3lCQUVsRCxLQUFLO3NCQUNMLEtBQUs7Ozs7SUFOTix1Q0FBa0U7O0lBQ2xFLHFDQUEwRDs7SUFDMUQsb0NBQTZEOztJQUM3RCw0Q0FBMkU7O0lBRTNFLHNDQUE0Qjs7SUFDNUIsbUNBQXlCOzs7OztJQUV6QiwwQ0FBaUM7O0lBQ2pDLCtDQUFxQzs7SUFDckMsdUNBQVk7O0lBaUJaLHVDQUFZIiwic291cmNlc0NvbnRlbnQiOlsiLy8g57uE5Lu257G7XHJcbmltcG9ydCB7XHJcbiAgQWZ0ZXJDb250ZW50SW5pdCxcclxuICBDb21wb25lbnQsXHJcbiAgQ29udGVudENoaWxkLFxyXG4gIElucHV0LFxyXG4gIE9uSW5pdCxcclxufSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBDb21tb25HcmlkQ29tcG9uZW50IH0gZnJvbSBcIi4uLy4uL2NvbW1vbi1ncmlkL2luZGV4LmNvbXBvbmVudFwiO1xyXG5pbXBvcnQgeyBkZWJvdW5jZSB9IGZyb20gXCJsb2Rhc2hcIjtcclxuaW1wb3J0IHsgR3JpZENvbXBvbmVudCB9IGZyb20gXCJAc3luY2Z1c2lvbi9lajItYW5ndWxhci1ncmlkc1wiO1xyXG5pbXBvcnQgeyBUcmVlR3JpZENvbXBvbmVudCB9IGZyb20gXCJAc3luY2Z1c2lvbi9lajItYW5ndWxhci10cmVlZ3JpZFwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IFwicnMtZ3JpZC1ib3hcIixcclxuICB0ZW1wbGF0ZVVybDogXCIuL2luZGV4LmNvbXBvbmVudC5odG1sXCIsXHJcbiAgc3R5bGVVcmxzOiBbXCIuL2luZGV4LmNvbXBvbmVudC5zY3NzXCJdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgR3JpZEJveENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgQWZ0ZXJDb250ZW50SW5pdCB7XHJcbiAgQENvbnRlbnRDaGlsZChDb21tb25HcmlkQ29tcG9uZW50LCB7IHN0YXRpYzogZmFsc2UgfSkgZ3JpZENvbnRlbnQ7XHJcbiAgQENvbnRlbnRDaGlsZChHcmlkQ29tcG9uZW50LCB7IHN0YXRpYzogZmFsc2UgfSkgb3JpZ25HcmlkO1xyXG4gIEBDb250ZW50Q2hpbGQoVHJlZUdyaWRDb21wb25lbnQsIHsgc3RhdGljOiBmYWxzZSB9KSB0cmVlR3JpZDtcclxuICBAQ29udGVudENoaWxkKFwid2hvbGVUb29sYmFyU2xvdFwiLCB7IHN0YXRpYzogZmFsc2UgfSkgd2hvbGVUb29sYmFyU2xvdDogYW55O1xyXG5cclxuICBASW5wdXQoKSBoaWRlU2VhcmNoID0gZmFsc2U7XHJcbiAgQElucHV0KCkgaXNJbm5lciA9IGZhbHNlO1xyXG5cclxuICBwcml2YXRlIGRlYm91bmNlZElucHV0OiBGdW5jdGlvbjtcclxuICBoYXNXaG9sZVRvb2xiYXJTbG90OiBib29sZWFuID0gZmFsc2U7XHJcbiAgdHJhbnNsYXRpb247XHJcblxyXG4gIG5nT25Jbml0KCkge1xyXG4gICAgdGhpcy5nZXRJbmZvKCk7XHJcbiAgICB0aGlzLmRlYm91bmNlZElucHV0ID0gZGVib3VuY2UoKCkgPT4ge1xyXG4gICAgICB0aGlzLm9uU2VhY2goKTtcclxuICAgIH0sIDMwMCk7XHJcbiAgfVxyXG5cclxuICBnZXRJbmZvKCkge1xyXG4gICAgdGhpcy50cmFuc2xhdGlvbiA9IEpTT04ucGFyc2UobG9jYWxTdG9yYWdlLmdldEl0ZW0oXCJ0cmFuc2xhdGlvblwiKSk7XHJcbiAgfVxyXG4gIG5nQWZ0ZXJDb250ZW50SW5pdCgpIHtcclxuICAgIC8vIOajgOa1i+aYr+WQpuS8oOWFpeS6hiB3aG9sZVRvb2xiYXJTbG90XHJcbiAgICB0aGlzLmhhc1dob2xlVG9vbGJhclNsb3QgPSAhIXRoaXMud2hvbGVUb29sYmFyU2xvdDtcclxuICB9XHJcblxyXG4gIHNlYXJjaFZhbHVlO1xyXG4gIG9uU2VhY2goKSB7XHJcbiAgICBpZiAodGhpcy5ncmlkQ29udGVudCkge1xyXG4gICAgICB0aGlzLmdyaWRDb250ZW50LmdyaWQuc2VhcmNoKHRoaXMuc2VhcmNoVmFsdWUpO1xyXG4gICAgfSBlbHNlIGlmICh0aGlzLm9yaWduR3JpZCkge1xyXG4gICAgICB0aGlzLm9yaWduR3JpZC5zZWFyY2godGhpcy5zZWFyY2hWYWx1ZSk7XHJcbiAgICB9IGVsc2UgaWYgKHRoaXMudHJlZUdyaWQpIHtcclxuICAgICAgdGhpcy50cmVlR3JpZC5zZWFyY2godGhpcy5zZWFyY2hWYWx1ZSk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBvbklucHV0KCkge1xyXG4gICAgdGhpcy5kZWJvdW5jZWRJbnB1dCgpO1xyXG4gIH1cclxufVxyXG4iXX0=
92
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vcmFpc2UtY29tbW9uLWxpYi8iLCJzb3VyY2VzIjpbImxpYi9sYXlvdXQvZ3JpZC1ib3gvaW5kZXguY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUNBLE9BQU8sRUFFTCxTQUFTLEVBQ1QsWUFBWSxFQUNaLFlBQVksRUFDWixLQUFLLEVBRUwsTUFBTSxHQUNQLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBRXhFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUM5RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQU9yRSxNQUFNLE9BQU8sZ0JBQWdCO0lBTDdCO1FBV1csZUFBVSxHQUFHLEtBQUssQ0FBQztRQUNuQixZQUFPLEdBQUcsS0FBSyxDQUFDO1FBQ2YsaUJBQVksR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO1FBRTVDLHdCQUFtQixHQUFZLEtBQUssQ0FBQztJQTBCdkMsQ0FBQzs7OztJQXZCQyxRQUFRO1FBQ04sSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ2pCLENBQUM7Ozs7SUFFRCxPQUFPO1FBQ0wsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQztJQUNyRSxDQUFDOzs7O0lBQ0Qsa0JBQWtCO1FBQ2hCLDJCQUEyQjtRQUMzQixJQUFJLENBQUMsbUJBQW1CLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQztJQUNyRCxDQUFDOzs7OztJQUVELE9BQU8sQ0FBQyxLQUFLO1FBQ1gsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFO1lBQ3BCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztTQUNyQzthQUFNLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRTtZQUN6QixJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztTQUM5QjthQUFNLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUN4QixJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztTQUM3QjthQUFNO1lBQ0wsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDL0I7SUFDSCxDQUFDOzs7WUF4Q0YsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxhQUFhO2dCQUN2QixtK0JBQXFDOzthQUV0Qzs7OzBCQUVFLFlBQVksU0FBQyxtQkFBbUIsRUFBRSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUU7d0JBQ25ELFlBQVksU0FBQyxhQUFhLEVBQUUsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFO3VCQUM3QyxZQUFZLFNBQUMsaUJBQWlCLEVBQUUsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFOytCQUNqRCxZQUFZLFNBQUMsa0JBQWtCLEVBQUUsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFO3lCQUVsRCxLQUFLO3NCQUNMLEtBQUs7MkJBQ0wsTUFBTTs7OztJQVBQLHVDQUFrRTs7SUFDbEUscUNBQTBEOztJQUMxRCxvQ0FBNkQ7O0lBQzdELDRDQUEyRTs7SUFFM0Usc0NBQTRCOztJQUM1QixtQ0FBeUI7O0lBQ3pCLHdDQUE0Qzs7SUFFNUMsK0NBQXFDOztJQUNyQyx1Q0FBWSIsInNvdXJjZXNDb250ZW50IjpbIi8vIOe7hOS7tuexu1xyXG5pbXBvcnQge1xyXG4gIEFmdGVyQ29udGVudEluaXQsXHJcbiAgQ29tcG9uZW50LFxyXG4gIENvbnRlbnRDaGlsZCxcclxuICBFdmVudEVtaXR0ZXIsXHJcbiAgSW5wdXQsXHJcbiAgT25Jbml0LFxyXG4gIE91dHB1dCxcclxufSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBDb21tb25HcmlkQ29tcG9uZW50IH0gZnJvbSBcIi4uLy4uL2NvbW1vbi1ncmlkL2luZGV4LmNvbXBvbmVudFwiO1xyXG5pbXBvcnQgeyBkZWJvdW5jZSB9IGZyb20gXCJsb2Rhc2hcIjtcclxuaW1wb3J0IHsgR3JpZENvbXBvbmVudCB9IGZyb20gXCJAc3luY2Z1c2lvbi9lajItYW5ndWxhci1ncmlkc1wiO1xyXG5pbXBvcnQgeyBUcmVlR3JpZENvbXBvbmVudCB9IGZyb20gXCJAc3luY2Z1c2lvbi9lajItYW5ndWxhci10cmVlZ3JpZFwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IFwicnMtZ3JpZC1ib3hcIixcclxuICB0ZW1wbGF0ZVVybDogXCIuL2luZGV4LmNvbXBvbmVudC5odG1sXCIsXHJcbiAgc3R5bGVVcmxzOiBbXCIuL2luZGV4LmNvbXBvbmVudC5zY3NzXCJdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgR3JpZEJveENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgQWZ0ZXJDb250ZW50SW5pdCB7XHJcbiAgQENvbnRlbnRDaGlsZChDb21tb25HcmlkQ29tcG9uZW50LCB7IHN0YXRpYzogZmFsc2UgfSkgZ3JpZENvbnRlbnQ7XHJcbiAgQENvbnRlbnRDaGlsZChHcmlkQ29tcG9uZW50LCB7IHN0YXRpYzogZmFsc2UgfSkgb3JpZ25HcmlkO1xyXG4gIEBDb250ZW50Q2hpbGQoVHJlZUdyaWRDb21wb25lbnQsIHsgc3RhdGljOiBmYWxzZSB9KSB0cmVlR3JpZDtcclxuICBAQ29udGVudENoaWxkKFwid2hvbGVUb29sYmFyU2xvdFwiLCB7IHN0YXRpYzogZmFsc2UgfSkgd2hvbGVUb29sYmFyU2xvdDogYW55O1xyXG5cclxuICBASW5wdXQoKSBoaWRlU2VhcmNoID0gZmFsc2U7XHJcbiAgQElucHV0KCkgaXNJbm5lciA9IGZhbHNlO1xyXG4gIEBPdXRwdXQoKSBvbkdyaWRTZWFyY2ggPSBuZXcgRXZlbnRFbWl0dGVyKCk7XHJcblxyXG4gIGhhc1dob2xlVG9vbGJhclNsb3Q6IGJvb2xlYW4gPSBmYWxzZTtcclxuICB0cmFuc2xhdGlvbjtcclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgICB0aGlzLmdldEluZm8oKTtcclxuICB9XHJcblxyXG4gIGdldEluZm8oKSB7XHJcbiAgICB0aGlzLnRyYW5zbGF0aW9uID0gSlNPTi5wYXJzZShsb2NhbFN0b3JhZ2UuZ2V0SXRlbShcInRyYW5zbGF0aW9uXCIpKTtcclxuICB9XHJcbiAgbmdBZnRlckNvbnRlbnRJbml0KCkge1xyXG4gICAgLy8g5qOA5rWL5piv5ZCm5Lyg5YWl5LqGIHdob2xlVG9vbGJhclNsb3RcclxuICAgIHRoaXMuaGFzV2hvbGVUb29sYmFyU2xvdCA9ICEhdGhpcy53aG9sZVRvb2xiYXJTbG90O1xyXG4gIH1cclxuXHJcbiAgb25TZWFjaCh2YWx1ZSkge1xyXG4gICAgaWYgKHRoaXMuZ3JpZENvbnRlbnQpIHtcclxuICAgICAgdGhpcy5ncmlkQ29udGVudC5ncmlkLnNlYXJjaCh2YWx1ZSk7XHJcbiAgICB9IGVsc2UgaWYgKHRoaXMub3JpZ25HcmlkKSB7XHJcbiAgICAgIHRoaXMub3JpZ25HcmlkLnNlYXJjaCh2YWx1ZSk7XHJcbiAgICB9IGVsc2UgaWYgKHRoaXMudHJlZUdyaWQpIHtcclxuICAgICAgdGhpcy50cmVlR3JpZC5zZWFyY2godmFsdWUpO1xyXG4gICAgfSBlbHNlIHtcclxuICAgICAgdGhpcy5vbkdyaWRTZWFyY2guZW1pdCh2YWx1ZSk7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
@@ -34,6 +34,7 @@ export class MultiTabComponent {
34
34
  this.flattenMenu = [];
35
35
  this.defaultTabUrl = "";
36
36
  this.onRefreshTab = new EventEmitter();
37
+ this.onCloseTab = new EventEmitter();
37
38
  this.subscriptions = [];
38
39
  this.TAB_WIDTH = 164;
39
40
  this.GAP_NORMAL = 54;
@@ -260,6 +261,7 @@ export class MultiTabComponent {
260
261
  }
261
262
  this.setEllipsisTitle();
262
263
  sessionStorage.setItem("TabCache", JSON.stringify(this.tabList));
264
+ this.onCloseTab.emit(tab);
263
265
  this.ref.markForCheck();
264
266
  }
265
267
  /**
@@ -458,6 +460,7 @@ MultiTabComponent.propDecorators = {
458
460
  flattenMenu: [{ type: Input }],
459
461
  defaultTabUrl: [{ type: Input }],
460
462
  onRefreshTab: [{ type: Output }],
463
+ onCloseTab: [{ type: Output }],
461
464
  onResize: [{ type: HostListener, args: ["window:resize", ["$event"],] }]
462
465
  };
463
466
  if (false) {
@@ -473,6 +476,8 @@ if (false) {
473
476
  MultiTabComponent.prototype.defaultTabUrl;
474
477
  /** @type {?} */
475
478
  MultiTabComponent.prototype.onRefreshTab;
479
+ /** @type {?} */
480
+ MultiTabComponent.prototype.onCloseTab;
476
481
  /**
477
482
  * @type {?}
478
483
  * @private
@@ -524,4 +529,4 @@ if (false) {
524
529
  */
525
530
  MultiTabComponent.prototype.routeReuseStrategy;
526
531
  }
527
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.component.js","sourceRoot":"ng://raise-common-lib/","sources":["lib/layout/multi-tab/index.component.ts"],"names":[],"mappings":"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","sourcesContent":["// 组件类\r\nimport {\r\n  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n} from \"@angular/core\";\r\nimport {\r\n  ActivatedRoute,\r\n  NavigationEnd,\r\n  Router,\r\n  RouterOutlet,\r\n} from \"@angular/router\";\r\nimport { filter } from \"rxjs/operators\";\r\nimport { Subscription } from \"rxjs\";\r\nimport { RouteReuseStrategy } from \"@angular/router\";\r\nimport { CommonFunctionService } from \"../../service/common-function.service\";\r\nimport { DrawerService } from \"../../service/drawer.service\";\r\nimport { KeepAliveService } from \"../../service/keep-alive.service\";\r\nimport { CdkDragDrop, moveItemInArray } from \"@angular/cdk/drag-drop\";\r\n@Component({\r\n  selector: \"rs-multi-tab\",\r\n  templateUrl: \"./index.component.html\",\r\n  styleUrls: [\"./index.component.scss\"],\r\n})\r\nexport class MultiTabComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  constructor(\r\n    public router: Router,\r\n    public cf: CommonFunctionService,\r\n    public activatedRoute: ActivatedRoute,\r\n    private ref: ChangeDetectorRef,\r\n    private drawer: DrawerService,\r\n    private routeReuseStrategy: RouteReuseStrategy\r\n  ) {\r\n    this.keepAlive = this.routeReuseStrategy as KeepAliveService;\r\n  }\r\n  keepAlive: KeepAliveService;\r\n  @Input() singleReuseUrls: string[] = []; //只能单个缓存的url\r\n  @Input() noGenerateTabUrls: string[] = []; //不生成tab的url\r\n  @Input() flattenMenu = [];\r\n  @Input() defaultTabUrl = \"\";\r\n\r\n  @Output() onRefreshTab = new EventEmitter();\r\n\r\n  private subscriptions: Subscription[] = [];\r\n  TAB_WIDTH = 164;\r\n  GAP_NORMAL = 54;\r\n  GAP_SMALL = 30;\r\n  textGap; // 文本与边框的总间距\r\n  foo: RouterOutlet;\r\n  comRef: any;\r\n  tabList = [];\r\n  selectedTab: number = 0;\r\n  maxTabs: number = 10;\r\n  screenWidth: number = window.innerWidth; // 初始化屏幕宽度\r\n  translation;\r\n\r\n  @HostListener(\"window:resize\", [\"$event\"])\r\n  onResize(event) {\r\n    this.screenWidth = window.innerWidth; // 更新屏幕宽度\r\n    // this.setEllipsisTitle(); 在最外面容器调用\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.translation = JSON.parse(localStorage.getItem(\"translation\"));\r\n\r\n    this.initTab();\r\n    // 解决刷新页面后，选中的 tab 丢失问题\r\n    const isExistIdx = this.tabList.findIndex(\r\n      (ele) =>\r\n        this.urlWithoutQuery(ele.url) === this.urlWithoutQuery(this.router.url)\r\n    );\r\n    if (isExistIdx !== -1) {\r\n      this.selectedTab = isExistIdx;\r\n    }\r\n\r\n    this.subscriptions.push(\r\n      this.router.events\r\n        .pipe(filter((event) => event instanceof NavigationEnd))\r\n        .subscribe(() => {\r\n          const navigation = this.router.getCurrentNavigation(); // 获取当前导航\r\n          if (navigation) {\r\n            const tooltipElements = document.querySelectorAll(\".e-popup-open\");\r\n            // 删除tooltips\r\n            tooltipElements.forEach((element) => {\r\n              const htmlElement = element as HTMLElement;\r\n              htmlElement.style.display = \"none\";\r\n            });\r\n            const state = navigation.extras.state; // 获取传递的 state\r\n            const skipLocationChange = navigation.extras.skipLocationChange; // 获取是否跳过 location change\r\n            const currentRoute = this.router.routerState.root.firstChild;\r\n            const navigationInfo = JSON.parse(\r\n              sessionStorage.getItem(\"navigationInfo\") || \"{}\"\r\n            );\r\n            let title =\r\n              (state && state[\"title\"]) ||\r\n              navigationInfo.title ||\r\n              navigationInfo.subTitle ||\r\n              navigationInfo.name;\r\n\r\n            let noReused = (state && state[\"noReused\"]) || false; // 当前tab不复用，新开一个tab,当有已经存在的tab时候也是新开\r\n            if (currentRoute && !skipLocationChange) {\r\n              if (\r\n                this.noGenerateTabUrls.includes(\r\n                  this.urlWithoutQuery(this.router.url)\r\n                )\r\n              ) {\r\n                return; // 排除不生成tab的url\r\n              }\r\n              this.setTab(\r\n                this.router.url,\r\n                currentRoute.snapshot.routeConfig.path,\r\n                title,\r\n                noReused\r\n              );\r\n            }\r\n          }\r\n        })\r\n    );\r\n  }\r\n  ngAfterViewInit() {\r\n    setTimeout(() => {\r\n      this.setEllipsisTitle();\r\n    }, 50);\r\n  }\r\n  ngOnDestroy() {\r\n    this.tabList = []; // 清空 tab 列表\r\n    this.selectedTab = 0; // 重置选中的 tab 索引\r\n    this.subscriptions.forEach((sub) => sub.unsubscribe());\r\n  }\r\n\r\n  setEllipsisTitle() {\r\n    this.textGap = this.GAP_NORMAL;\r\n    if (this.screenWidth <= 1100) {\r\n      this.textGap = this.GAP_SMALL;\r\n    }\r\n    let { allWidth, leftWidth, rightWidth } = this.calcTabWidth();\r\n    let width = Math.floor(\r\n      (allWidth - rightWidth) / (this.tabList && this.tabList.length)\r\n    );\r\n    this.tabList.forEach((ele, idx) => {\r\n      ele.displayTitle = this.cf.setMiddleEllipsis(\r\n        this.translation[ele.title] || ele.title,\r\n        width > this.TAB_WIDTH\r\n          ? this.TAB_WIDTH - this.textGap\r\n          : width - this.textGap,\r\n        12\r\n      );\r\n    });\r\n    this.ref.markForCheck();\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  calcTabWidth() {\r\n    const wrap = document.querySelector(\".rs-multi-tab\");\r\n    const ulElement = document.querySelector(\".rs-multi-tab > ul\");\r\n    const refreshTabDiv = document.querySelector(\".rs-multi-tab .refresh-tab\");\r\n    let allWidth;\r\n    let leftWidth;\r\n    let rightWidth;\r\n    if (wrap && ulElement) {\r\n      // 获取元素的位置信息\r\n      const wrapRect = wrap.getBoundingClientRect();\r\n      const ulRect = ulElement.getBoundingClientRect();\r\n      const refreshTabRect =\r\n        refreshTabDiv && refreshTabDiv.getBoundingClientRect();\r\n      allWidth = wrapRect.width;\r\n      leftWidth = ulRect.width;\r\n      rightWidth = (refreshTabRect && refreshTabRect.width) || 100;\r\n    }\r\n    return {\r\n      allWidth,\r\n      leftWidth,\r\n      rightWidth,\r\n    };\r\n  }\r\n  initTab() {\r\n    // console.log(\"this.flattenMenu\", this.flattenMenu);\r\n    let TabCache = JSON.parse(sessionStorage.getItem(\"TabCache\"));\r\n    this.tabList = TabCache || [];\r\n    if (this.tabList.length === 0) {\r\n      const pureUrl = this.urlWithoutQuery(this.router.url);\r\n      const target = this.flattenMenu.find((ele) => ele.url === pureUrl);\r\n      if (target) {\r\n        if (target.url !== this.defaultTabUrl) {\r\n          const defaultTab = this.flattenMenu.find(\r\n            (ele) => ele.url === this.defaultTabUrl\r\n          );\r\n          this.tabList.push({\r\n            url: defaultTab.url,\r\n            title: defaultTab.menuCode || defaultTab.label,\r\n            displayTitle: defaultTab.menuCode || defaultTab.label,\r\n          });\r\n        }\r\n        this.addTab(target.url, target.menuCode || target.label);\r\n      }\r\n    }\r\n  }\r\n\r\n  closeTab(idx, noChange?) {\r\n    const tab = this.tabList[idx];\r\n    this.tabList = this.tabList.filter((ele) => ele.url !== tab.url);\r\n    this.clearCache(tab.url);\r\n    if (!noChange && this.selectedTab === idx) {\r\n      const targetIdx = Math.max(0, idx - 1);\r\n      this.changeTab(this.tabList[targetIdx], targetIdx);\r\n    }\r\n    if (idx < this.selectedTab) {\r\n      this.selectedTab = this.selectedTab - 1; // 如果关闭的tab在当前选中的tab之前，选中tab索引减1\r\n    }\r\n    this.setEllipsisTitle();\r\n    sessionStorage.setItem(\"TabCache\", JSON.stringify(this.tabList));\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  changeTab(tab, idx) {\r\n    this.router.navigateByUrl(tab.url);\r\n    if (tab.navigationInfo) {\r\n      sessionStorage.setItem(\r\n        \"navigationInfo\",\r\n        JSON.stringify(tab.navigationInfo)\r\n      );\r\n    }\r\n    if (tab.fromInfo) {\r\n      sessionStorage.setItem(\"fromInfo\", JSON.stringify(tab.fromInfo));\r\n    }\r\n    if (tab.permissions) {\r\n      sessionStorage.setItem(\"permissions\", JSON.stringify(tab.permissions));\r\n    }\r\n    this.selectedTab = idx;\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  addTab(url, title) {\r\n    if (this.tabList.length >= this.maxTabs) {\r\n      const secondTab = this.tabList[1];\r\n      this.tabList = this.tabList.filter((ele) => ele.url !== secondTab.url);\r\n      this.clearCache(secondTab.url);\r\n    }\r\n    const localPermissions =\r\n      sessionStorage.getItem(\"permissions\") ||\r\n      localStorage.getItem(\"permissions\");\r\n    const navigationInfo = JSON.parse(sessionStorage.getItem(\"navigationInfo\"));\r\n    const fromInfo = JSON.parse(sessionStorage.getItem(\"fromInfo\"));\r\n    const permissions = JSON.parse(localPermissions);\r\n\r\n    this.tabList.push({\r\n      url: url,\r\n      title: title || \"default\",\r\n      displayTitle: title,\r\n      navigationInfo: navigationInfo,\r\n      permissions: permissions,\r\n      fromInfo: fromInfo,\r\n    });\r\n    this.selectedTab = this.tabList.length - 1;\r\n    this.setEllipsisTitle();\r\n    sessionStorage.setItem(\"TabCache\", JSON.stringify(this.tabList));\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  public setTab(url, pureUrl, title, noReused) {\r\n    const isExistIdx = this.tabList.findIndex(\r\n      (ele) => this.urlWithoutQuery(ele.url) === this.urlWithoutQuery(url)\r\n    );\r\n    if (isExistIdx === -1) {\r\n      const singleIdx = this.singleReuseUrls.findIndex(\r\n        (ele) => ele === pureUrl\r\n      );\r\n      if (singleIdx !== -1) {\r\n        this.tabList = this.tabList.filter(\r\n          (ele) => !ele.url.includes(this.singleReuseUrls[singleIdx])\r\n        );\r\n        this.keepAlive.clearCache(this.urlWithoutQuery(url));\r\n        this.drawer.deleteCache(url);\r\n      }\r\n      this.addTab(url, title);\r\n    } else {\r\n      const targetTabUrl = this.tabList[isExistIdx].url;\r\n      if (targetTabUrl !== url || noReused) {\r\n        // 当缓存一致时候，但是url不一致，重新按照新的url生成tab\r\n        this.closeTab(isExistIdx, true);\r\n        setTimeout(() => {\r\n          this.addTab(url, title);\r\n        }, 30);\r\n      } else {\r\n        this.changeTab(this.tabList[isExistIdx], isExistIdx);\r\n      }\r\n      this.ref.markForCheck();\r\n    }\r\n  }\r\n\r\n  onTabDrop(event: CdkDragDrop<string[]>) {\r\n    const { previousIndex, currentIndex } = event;\r\n    console.log(\"previousIndex\", previousIndex, \"currentIndex\", currentIndex);\r\n    if (previousIndex === 0 || currentIndex === 0) {\r\n      return;\r\n    }\r\n    moveItemInArray(this.tabList, event.previousIndex, event.currentIndex);\r\n    sessionStorage.setItem(\"TabCache\", JSON.stringify(this.tabList));\r\n  }\r\n\r\n  timer = null;\r\n  refreshTab() {\r\n    const loadingIcon = document.getElementById(\"loadingIcon\");\r\n    loadingIcon.classList.add(\"refresh-tab-loading\");\r\n    if (this.timer) {\r\n      clearInterval(this.timer);\r\n    }\r\n    // 模拟加载过程，1秒后移除动画\r\n    this.timer = setTimeout(() => {\r\n      loadingIcon.classList.remove(\"refresh-tab-loading\");\r\n      this.timer = null;\r\n    }, 1500);\r\n    // this.keepAlive.clearCache(this.tabList[this.selectedTab].url);\r\n    // this.drawer.deleteCache(this.tabList[this.selectedTab].url);\r\n    const currentUrl = this.router.url; // 获取当前 URL\r\n    this.onRefreshTab.emit(currentUrl);\r\n    // this.router.navigateByUrl(\"/\", { skipLocationChange: true }).then(() => {\r\n    //   this.router.navigateByUrl(currentUrl); // 重新导航到当前 URL\r\n    // });\r\n  }\r\n\r\n  clearCache(url) {\r\n    this.keepAlive.clearCache(this.urlWithoutQuery(url)); // 调用自定义策略的清除缓存方法\r\n    this.drawer.deleteCache(url);\r\n  }\r\n  cleanAllCache() {\r\n    sessionStorage.removeItem(\"TabCache\"); // 清除缓存\r\n    this.tabList = []; // 清空 tab 列表\r\n    this.selectedTab = 0; // 重置选中的 tab 索引\r\n    this.keepAlive.clearAllCache(); // 调用自定义策略的清除缓存方法\r\n  }\r\n  private urlWithoutQuery(url) {\r\n    return url.split(\"?\")[0];\r\n  }\r\n}\r\n"]}
532
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.component.js","sourceRoot":"ng://raise-common-lib/","sources":["lib/layout/multi-tab/index.component.ts"],"names":[],"mappings":"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","sourcesContent":["// 组件类\r\nimport {\r\n  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n} from \"@angular/core\";\r\nimport {\r\n  ActivatedRoute,\r\n  NavigationEnd,\r\n  Router,\r\n  RouterOutlet,\r\n} from \"@angular/router\";\r\nimport { filter } from \"rxjs/operators\";\r\nimport { Subscription } from \"rxjs\";\r\nimport { RouteReuseStrategy } from \"@angular/router\";\r\nimport { CommonFunctionService } from \"../../service/common-function.service\";\r\nimport { DrawerService } from \"../../service/drawer.service\";\r\nimport { KeepAliveService } from \"../../service/keep-alive.service\";\r\nimport { CdkDragDrop, moveItemInArray } from \"@angular/cdk/drag-drop\";\r\n@Component({\r\n  selector: \"rs-multi-tab\",\r\n  templateUrl: \"./index.component.html\",\r\n  styleUrls: [\"./index.component.scss\"],\r\n})\r\nexport class MultiTabComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  constructor(\r\n    public router: Router,\r\n    public cf: CommonFunctionService,\r\n    public activatedRoute: ActivatedRoute,\r\n    private ref: ChangeDetectorRef,\r\n    private drawer: DrawerService,\r\n    private routeReuseStrategy: RouteReuseStrategy\r\n  ) {\r\n    this.keepAlive = this.routeReuseStrategy as KeepAliveService;\r\n  }\r\n  keepAlive: KeepAliveService;\r\n  @Input() singleReuseUrls: string[] = []; //只能单个缓存的url\r\n  @Input() noGenerateTabUrls: string[] = []; //不生成tab的url\r\n  @Input() flattenMenu = [];\r\n  @Input() defaultTabUrl = \"\";\r\n\r\n  @Output() onRefreshTab = new EventEmitter();\r\n  @Output() onCloseTab = new EventEmitter();\r\n\r\n  private subscriptions: Subscription[] = [];\r\n  TAB_WIDTH = 164;\r\n  GAP_NORMAL = 54;\r\n  GAP_SMALL = 30;\r\n  textGap; // 文本与边框的总间距\r\n  foo: RouterOutlet;\r\n  comRef: any;\r\n  tabList = [];\r\n  selectedTab: number = 0;\r\n  maxTabs: number = 10;\r\n  screenWidth: number = window.innerWidth; // 初始化屏幕宽度\r\n  translation;\r\n\r\n  @HostListener(\"window:resize\", [\"$event\"])\r\n  onResize(event) {\r\n    this.screenWidth = window.innerWidth; // 更新屏幕宽度\r\n    // this.setEllipsisTitle(); 在最外面容器调用\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.translation = JSON.parse(localStorage.getItem(\"translation\"));\r\n\r\n    this.initTab();\r\n    // 解决刷新页面后，选中的 tab 丢失问题\r\n    const isExistIdx = this.tabList.findIndex(\r\n      (ele) =>\r\n        this.urlWithoutQuery(ele.url) === this.urlWithoutQuery(this.router.url)\r\n    );\r\n    if (isExistIdx !== -1) {\r\n      this.selectedTab = isExistIdx;\r\n    }\r\n\r\n    this.subscriptions.push(\r\n      this.router.events\r\n        .pipe(filter((event) => event instanceof NavigationEnd))\r\n        .subscribe(() => {\r\n          const navigation = this.router.getCurrentNavigation(); // 获取当前导航\r\n          if (navigation) {\r\n            const tooltipElements = document.querySelectorAll(\".e-popup-open\");\r\n            // 删除tooltips\r\n            tooltipElements.forEach((element) => {\r\n              const htmlElement = element as HTMLElement;\r\n              htmlElement.style.display = \"none\";\r\n            });\r\n            const state = navigation.extras.state; // 获取传递的 state\r\n            const skipLocationChange = navigation.extras.skipLocationChange; // 获取是否跳过 location change\r\n            const currentRoute = this.router.routerState.root.firstChild;\r\n            const navigationInfo = JSON.parse(\r\n              sessionStorage.getItem(\"navigationInfo\") || \"{}\"\r\n            );\r\n            let title =\r\n              (state && state[\"title\"]) ||\r\n              navigationInfo.title ||\r\n              navigationInfo.subTitle ||\r\n              navigationInfo.name;\r\n\r\n            let noReused = (state && state[\"noReused\"]) || false; // 当前tab不复用，新开一个tab,当有已经存在的tab时候也是新开\r\n            if (currentRoute && !skipLocationChange) {\r\n              if (\r\n                this.noGenerateTabUrls.includes(\r\n                  this.urlWithoutQuery(this.router.url)\r\n                )\r\n              ) {\r\n                return; // 排除不生成tab的url\r\n              }\r\n              this.setTab(\r\n                this.router.url,\r\n                currentRoute.snapshot.routeConfig.path,\r\n                title,\r\n                noReused\r\n              );\r\n            }\r\n          }\r\n        })\r\n    );\r\n  }\r\n  ngAfterViewInit() {\r\n    setTimeout(() => {\r\n      this.setEllipsisTitle();\r\n    }, 50);\r\n  }\r\n  ngOnDestroy() {\r\n    this.tabList = []; // 清空 tab 列表\r\n    this.selectedTab = 0; // 重置选中的 tab 索引\r\n    this.subscriptions.forEach((sub) => sub.unsubscribe());\r\n  }\r\n\r\n  setEllipsisTitle() {\r\n    this.textGap = this.GAP_NORMAL;\r\n    if (this.screenWidth <= 1100) {\r\n      this.textGap = this.GAP_SMALL;\r\n    }\r\n    let { allWidth, leftWidth, rightWidth } = this.calcTabWidth();\r\n    let width = Math.floor(\r\n      (allWidth - rightWidth) / (this.tabList && this.tabList.length)\r\n    );\r\n    this.tabList.forEach((ele, idx) => {\r\n      ele.displayTitle = this.cf.setMiddleEllipsis(\r\n        this.translation[ele.title] || ele.title,\r\n        width > this.TAB_WIDTH\r\n          ? this.TAB_WIDTH - this.textGap\r\n          : width - this.textGap,\r\n        12\r\n      );\r\n    });\r\n    this.ref.markForCheck();\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  calcTabWidth() {\r\n    const wrap = document.querySelector(\".rs-multi-tab\");\r\n    const ulElement = document.querySelector(\".rs-multi-tab > ul\");\r\n    const refreshTabDiv = document.querySelector(\".rs-multi-tab .refresh-tab\");\r\n    let allWidth;\r\n    let leftWidth;\r\n    let rightWidth;\r\n    if (wrap && ulElement) {\r\n      // 获取元素的位置信息\r\n      const wrapRect = wrap.getBoundingClientRect();\r\n      const ulRect = ulElement.getBoundingClientRect();\r\n      const refreshTabRect =\r\n        refreshTabDiv && refreshTabDiv.getBoundingClientRect();\r\n      allWidth = wrapRect.width;\r\n      leftWidth = ulRect.width;\r\n      rightWidth = (refreshTabRect && refreshTabRect.width) || 100;\r\n    }\r\n    return {\r\n      allWidth,\r\n      leftWidth,\r\n      rightWidth,\r\n    };\r\n  }\r\n  initTab() {\r\n    // console.log(\"this.flattenMenu\", this.flattenMenu);\r\n    let TabCache = JSON.parse(sessionStorage.getItem(\"TabCache\"));\r\n    this.tabList = TabCache || [];\r\n    if (this.tabList.length === 0) {\r\n      const pureUrl = this.urlWithoutQuery(this.router.url);\r\n      const target = this.flattenMenu.find((ele) => ele.url === pureUrl);\r\n      if (target) {\r\n        if (target.url !== this.defaultTabUrl) {\r\n          const defaultTab = this.flattenMenu.find(\r\n            (ele) => ele.url === this.defaultTabUrl\r\n          );\r\n          this.tabList.push({\r\n            url: defaultTab.url,\r\n            title: defaultTab.menuCode || defaultTab.label,\r\n            displayTitle: defaultTab.menuCode || defaultTab.label,\r\n          });\r\n        }\r\n        this.addTab(target.url, target.menuCode || target.label);\r\n      }\r\n    }\r\n  }\r\n\r\n  closeTab(idx, noChange?) {\r\n    const tab = this.tabList[idx];\r\n    this.tabList = this.tabList.filter((ele) => ele.url !== tab.url);\r\n    this.clearCache(tab.url);\r\n    if (!noChange && this.selectedTab === idx) {\r\n      const targetIdx = Math.max(0, idx - 1);\r\n      this.changeTab(this.tabList[targetIdx], targetIdx);\r\n    }\r\n    if (idx < this.selectedTab) {\r\n      this.selectedTab = this.selectedTab - 1; // 如果关闭的tab在当前选中的tab之前，选中tab索引减1\r\n    }\r\n    this.setEllipsisTitle();\r\n    sessionStorage.setItem(\"TabCache\", JSON.stringify(this.tabList));\r\n    this.onCloseTab.emit(tab);\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  changeTab(tab, idx) {\r\n    this.router.navigateByUrl(tab.url);\r\n    if (tab.navigationInfo) {\r\n      sessionStorage.setItem(\r\n        \"navigationInfo\",\r\n        JSON.stringify(tab.navigationInfo)\r\n      );\r\n    }\r\n    if (tab.fromInfo) {\r\n      sessionStorage.setItem(\"fromInfo\", JSON.stringify(tab.fromInfo));\r\n    }\r\n    if (tab.permissions) {\r\n      sessionStorage.setItem(\"permissions\", JSON.stringify(tab.permissions));\r\n    }\r\n    this.selectedTab = idx;\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  addTab(url, title) {\r\n    if (this.tabList.length >= this.maxTabs) {\r\n      const secondTab = this.tabList[1];\r\n      this.tabList = this.tabList.filter((ele) => ele.url !== secondTab.url);\r\n      this.clearCache(secondTab.url);\r\n    }\r\n    const localPermissions =\r\n      sessionStorage.getItem(\"permissions\") ||\r\n      localStorage.getItem(\"permissions\");\r\n    const navigationInfo = JSON.parse(sessionStorage.getItem(\"navigationInfo\"));\r\n    const fromInfo = JSON.parse(sessionStorage.getItem(\"fromInfo\"));\r\n    const permissions = JSON.parse(localPermissions);\r\n\r\n    this.tabList.push({\r\n      url: url,\r\n      title: title || \"default\",\r\n      displayTitle: title,\r\n      navigationInfo: navigationInfo,\r\n      permissions: permissions,\r\n      fromInfo: fromInfo,\r\n    });\r\n    this.selectedTab = this.tabList.length - 1;\r\n    this.setEllipsisTitle();\r\n    sessionStorage.setItem(\"TabCache\", JSON.stringify(this.tabList));\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  public setTab(url, pureUrl, title, noReused) {\r\n    const isExistIdx = this.tabList.findIndex(\r\n      (ele) => this.urlWithoutQuery(ele.url) === this.urlWithoutQuery(url)\r\n    );\r\n    if (isExistIdx === -1) {\r\n      const singleIdx = this.singleReuseUrls.findIndex(\r\n        (ele) => ele === pureUrl\r\n      );\r\n      if (singleIdx !== -1) {\r\n        this.tabList = this.tabList.filter(\r\n          (ele) => !ele.url.includes(this.singleReuseUrls[singleIdx])\r\n        );\r\n        this.keepAlive.clearCache(this.urlWithoutQuery(url));\r\n        this.drawer.deleteCache(url);\r\n      }\r\n      this.addTab(url, title);\r\n    } else {\r\n      const targetTabUrl = this.tabList[isExistIdx].url;\r\n      if (targetTabUrl !== url || noReused) {\r\n        // 当缓存一致时候，但是url不一致，重新按照新的url生成tab\r\n        this.closeTab(isExistIdx, true);\r\n        setTimeout(() => {\r\n          this.addTab(url, title);\r\n        }, 30);\r\n      } else {\r\n        this.changeTab(this.tabList[isExistIdx], isExistIdx);\r\n      }\r\n      this.ref.markForCheck();\r\n    }\r\n  }\r\n\r\n  onTabDrop(event: CdkDragDrop<string[]>) {\r\n    const { previousIndex, currentIndex } = event;\r\n    console.log(\"previousIndex\", previousIndex, \"currentIndex\", currentIndex);\r\n    if (previousIndex === 0 || currentIndex === 0) {\r\n      return;\r\n    }\r\n    moveItemInArray(this.tabList, event.previousIndex, event.currentIndex);\r\n    sessionStorage.setItem(\"TabCache\", JSON.stringify(this.tabList));\r\n  }\r\n\r\n  timer = null;\r\n  refreshTab() {\r\n    const loadingIcon = document.getElementById(\"loadingIcon\");\r\n    loadingIcon.classList.add(\"refresh-tab-loading\");\r\n    if (this.timer) {\r\n      clearInterval(this.timer);\r\n    }\r\n    // 模拟加载过程，1秒后移除动画\r\n    this.timer = setTimeout(() => {\r\n      loadingIcon.classList.remove(\"refresh-tab-loading\");\r\n      this.timer = null;\r\n    }, 1500);\r\n    // this.keepAlive.clearCache(this.tabList[this.selectedTab].url);\r\n    // this.drawer.deleteCache(this.tabList[this.selectedTab].url);\r\n    const currentUrl = this.router.url; // 获取当前 URL\r\n    this.onRefreshTab.emit(currentUrl);\r\n    // this.router.navigateByUrl(\"/\", { skipLocationChange: true }).then(() => {\r\n    //   this.router.navigateByUrl(currentUrl); // 重新导航到当前 URL\r\n    // });\r\n  }\r\n\r\n  clearCache(url) {\r\n    this.keepAlive.clearCache(this.urlWithoutQuery(url)); // 调用自定义策略的清除缓存方法\r\n    this.drawer.deleteCache(url);\r\n  }\r\n  cleanAllCache() {\r\n    sessionStorage.removeItem(\"TabCache\"); // 清除缓存\r\n    this.tabList = []; // 清空 tab 列表\r\n    this.selectedTab = 0; // 重置选中的 tab 索引\r\n    this.keepAlive.clearAllCache(); // 调用自定义策略的清除缓存方法\r\n  }\r\n  private urlWithoutQuery(url) {\r\n    return url.split(\"?\")[0];\r\n  }\r\n}\r\n"]}