ngx-histaff-alpha 4.6.5 → 4.6.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/app/libraries/core-compare-db-pipeline/core-compare-db-pipeline.component.mjs +110 -17
- package/fesm2022/ngx-histaff-alpha.mjs +104 -15
- package/fesm2022/ngx-histaff-alpha.mjs.map +1 -1
- package/lib/app/libraries/core-compare-db-pipeline/core-compare-db-pipeline.component.d.ts +12 -1
- package/package.json +1 -1
package/esm2022/lib/app/libraries/core-compare-db-pipeline/core-compare-db-pipeline.component.mjs
CHANGED
|
@@ -1,13 +1,17 @@
|
|
|
1
|
-
import { Component } from '@angular/core';
|
|
1
|
+
import { Component, ViewChild } from '@angular/core';
|
|
2
2
|
import { BaseComponent } from '../base-component/base/base.component';
|
|
3
3
|
import { CoreTableComponent } from '../core-table/core-table.component';
|
|
4
4
|
import { CorePageHeaderComponent } from '../core-page-header/core-page-header/core-page-header.component';
|
|
5
5
|
import { BehaviorSubject, distinctUntilChanged, switchMap, tap } from 'rxjs';
|
|
6
6
|
import { CorePaginationComponent } from '../core-pagination/core-pagination/core-pagination.component';
|
|
7
7
|
import { CoreButtonGroupVnsComponent } from '../core-button-group-vns/core-button-group-vns/core-button-group-vns.component';
|
|
8
|
+
import { TooltipDirective } from '../tooltip/tooltip.directive';
|
|
9
|
+
import { CoreCheckboxComponent } from '../core-checkbox/core-checkbox/core-checkbox.component';
|
|
10
|
+
import { FormsModule } from '@angular/forms';
|
|
8
11
|
import * as i0 from "@angular/core";
|
|
9
12
|
import * as i1 from "../../services/multi-language.service";
|
|
10
13
|
import * as i2 from "../../services/app.service";
|
|
14
|
+
import * as i3 from "@angular/forms";
|
|
11
15
|
export class CoreCompareDbPipelineComponent extends BaseComponent {
|
|
12
16
|
constructor(mls, appService) {
|
|
13
17
|
super(mls);
|
|
@@ -24,20 +28,20 @@ export class CoreCompareDbPipelineComponent extends BaseComponent {
|
|
|
24
28
|
width: 0
|
|
25
29
|
},
|
|
26
30
|
{
|
|
27
|
-
field: '
|
|
31
|
+
field: 'sourceAlias',
|
|
28
32
|
type: 'string',
|
|
29
|
-
caption: '
|
|
33
|
+
caption: 'Nguồn',
|
|
30
34
|
align: 'left',
|
|
31
35
|
sortDisabled: true,
|
|
32
|
-
width:
|
|
36
|
+
width: 60
|
|
33
37
|
},
|
|
34
38
|
{
|
|
35
|
-
field: '
|
|
39
|
+
field: 'targetAlias',
|
|
36
40
|
type: 'string',
|
|
37
|
-
caption: '
|
|
41
|
+
caption: 'Đích',
|
|
38
42
|
align: 'left',
|
|
39
43
|
sortDisabled: true,
|
|
40
|
-
width:
|
|
44
|
+
width: 60
|
|
41
45
|
},
|
|
42
46
|
{
|
|
43
47
|
field: 'tableName',
|
|
@@ -64,12 +68,12 @@ export class CoreCompareDbPipelineComponent extends BaseComponent {
|
|
|
64
68
|
width: 100
|
|
65
69
|
},
|
|
66
70
|
{
|
|
67
|
-
field: '
|
|
68
|
-
type: '
|
|
69
|
-
caption: '
|
|
70
|
-
align: '
|
|
71
|
+
field: 'sourceAllowsNull',
|
|
72
|
+
type: 'boolean',
|
|
73
|
+
caption: 'Source nullablity',
|
|
74
|
+
align: 'center',
|
|
71
75
|
sortDisabled: true,
|
|
72
|
-
width:
|
|
76
|
+
width: 70
|
|
73
77
|
},
|
|
74
78
|
{
|
|
75
79
|
field: 'sourceSize',
|
|
@@ -79,6 +83,22 @@ export class CoreCompareDbPipelineComponent extends BaseComponent {
|
|
|
79
83
|
sortDisabled: true,
|
|
80
84
|
width: 100
|
|
81
85
|
},
|
|
86
|
+
{
|
|
87
|
+
field: 'targetType',
|
|
88
|
+
type: 'string',
|
|
89
|
+
caption: 'Kiểu đích',
|
|
90
|
+
align: 'left',
|
|
91
|
+
sortDisabled: true,
|
|
92
|
+
width: 100
|
|
93
|
+
},
|
|
94
|
+
{
|
|
95
|
+
field: 'targetAllowsNull',
|
|
96
|
+
type: 'boolean',
|
|
97
|
+
caption: 'Target nullablity',
|
|
98
|
+
align: 'center',
|
|
99
|
+
sortDisabled: true,
|
|
100
|
+
width: 70
|
|
101
|
+
},
|
|
82
102
|
{
|
|
83
103
|
field: 'targetSize',
|
|
84
104
|
type: 'string',
|
|
@@ -107,9 +127,36 @@ export class CoreCompareDbPipelineComponent extends BaseComponent {
|
|
|
107
127
|
this.pageSize$ = new BehaviorSubject(50);
|
|
108
128
|
this.pageCount = 0;
|
|
109
129
|
this.suspendCurrentPageSubscription$ = new BehaviorSubject(false);
|
|
130
|
+
this.sqlCommand = '';
|
|
131
|
+
this.resolverSessionId = '';
|
|
132
|
+
this.conflictTotal = 0;
|
|
133
|
+
}
|
|
134
|
+
refreshList() {
|
|
135
|
+
this.loading = true;
|
|
136
|
+
this.subscriptions.push(this.appService.post('/api/SqlServerPipeline/CompareDbStructure', this.request$.value).subscribe(x => {
|
|
137
|
+
this.loading = false;
|
|
138
|
+
if (x.ok && x.status === 200 && x.body?.statusCode === 200) {
|
|
139
|
+
this.data = x.body.innerBody.data;
|
|
140
|
+
this.pageCount = Math.ceil(x.body.innerBody.count / this.pageSize$.value);
|
|
141
|
+
this.currentPage$.next(x.body.innerBody.pageNumber);
|
|
142
|
+
this.conflictTotal = x.body.innerBody.count || 0;
|
|
143
|
+
}
|
|
144
|
+
}));
|
|
110
145
|
}
|
|
111
146
|
ngAfterViewInit() {
|
|
112
147
|
setTimeout(() => {
|
|
148
|
+
const tryFilterDifference = this.columns.filter(x => x.field === 'difference');
|
|
149
|
+
if (!!tryFilterDifference.length) {
|
|
150
|
+
tryFilterDifference[0].templateRef = this.toolBlock;
|
|
151
|
+
}
|
|
152
|
+
const tryFilterSourceAllowsNull = this.columns.filter(x => x.field === 'sourceAllowsNull');
|
|
153
|
+
if (!!tryFilterSourceAllowsNull.length) {
|
|
154
|
+
tryFilterSourceAllowsNull[0].templateRef = this.sourceAllowsNull;
|
|
155
|
+
}
|
|
156
|
+
const tryFilterTargetAllowsNull = this.columns.filter(x => x.field === 'targetAllowsNull');
|
|
157
|
+
if (!!tryFilterTargetAllowsNull.length) {
|
|
158
|
+
tryFilterTargetAllowsNull[0].templateRef = this.targetAllowsNull;
|
|
159
|
+
}
|
|
113
160
|
this.tableHeight = window.innerHeight - 60 - 50 - 46 - 30;
|
|
114
161
|
this.subscriptions.push(this.request$.pipe(distinctUntilChanged((pre, cur) => JSON.stringify(pre) === JSON.stringify(cur)), tap(() => this.loading = true), switchMap(x => this.appService.post('/api/SqlServerPipeline/CompareDbStructure', x))).subscribe(x => {
|
|
115
162
|
this.loading = false;
|
|
@@ -117,6 +164,7 @@ export class CoreCompareDbPipelineComponent extends BaseComponent {
|
|
|
117
164
|
this.data = x.body.innerBody.data;
|
|
118
165
|
this.pageCount = Math.ceil(x.body.innerBody.count / this.pageSize$.value);
|
|
119
166
|
this.currentPage$.next(x.body.innerBody.pageNumber);
|
|
167
|
+
this.conflictTotal = x.body.innerBody.count || 0;
|
|
120
168
|
}
|
|
121
169
|
}));
|
|
122
170
|
this.subscriptions.push(this.currentPage$.subscribe(x => {
|
|
@@ -129,9 +177,42 @@ export class CoreCompareDbPipelineComponent extends BaseComponent {
|
|
|
129
177
|
});
|
|
130
178
|
}
|
|
131
179
|
onSearching(e) {
|
|
180
|
+
const filtered = e.filter(x => !!x.searchFor.length);
|
|
181
|
+
this.request$.next({
|
|
182
|
+
...this.request$.value,
|
|
183
|
+
filter: filtered
|
|
184
|
+
});
|
|
185
|
+
}
|
|
186
|
+
openRowResolver(event, context) {
|
|
187
|
+
event.stopPropagation();
|
|
188
|
+
this.loading = true;
|
|
189
|
+
this.subscriptions.push(this.appService.post('/api/SqlServerPipeline/GenerateConflictResolverCommand', context).subscribe(x => {
|
|
190
|
+
this.loading = false;
|
|
191
|
+
if (x.ok && x.status === 200 && x.body?.statusCode === 200) {
|
|
192
|
+
this.showRowResolverWindow = true;
|
|
193
|
+
this.resolverSessionId = x.body.innerBody.resolverSessionId;
|
|
194
|
+
this.sqlCommand = x.body.innerBody.sqlCommand.trim();
|
|
195
|
+
}
|
|
196
|
+
}));
|
|
197
|
+
}
|
|
198
|
+
closeRowResolver(event) {
|
|
199
|
+
this.showRowResolverWindow = false;
|
|
200
|
+
}
|
|
201
|
+
resolve(event) {
|
|
202
|
+
this.loading = true;
|
|
203
|
+
this.subscriptions.push(this.appService.post('/api/SqlServerPipeline/RunConflictResolverCommand', {
|
|
204
|
+
resolverSessionId: this.resolverSessionId,
|
|
205
|
+
sqlCommand: this.sqlCommand
|
|
206
|
+
}).subscribe(x => {
|
|
207
|
+
this.loading = false;
|
|
208
|
+
if (x.ok && x.status === 200 && x.body?.statusCode === 200) {
|
|
209
|
+
this.showRowResolverWindow = false;
|
|
210
|
+
this.refreshList();
|
|
211
|
+
}
|
|
212
|
+
}));
|
|
132
213
|
}
|
|
133
214
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.1", ngImport: i0, type: CoreCompareDbPipelineComponent, deps: [{ token: i1.MultiLanguageService }, { token: i2.AppService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
134
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
215
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.0.1", type: CoreCompareDbPipelineComponent, isStandalone: true, selector: "core-compare-db-pipeline", viewQueries: [{ propertyName: "toolBlock", first: true, predicate: ["toolBlock"], descendants: true }, { propertyName: "sourceAllowsNull", first: true, predicate: ["sourceAllowsNull"], descendants: true }, { propertyName: "targetAllowsNull", first: true, predicate: ["targetAllowsNull"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"core-compare-db-pipeline-container\">\r\n <core-page-header [title]=\"'SO S\u00C1NH C\u1EA4U TR\u00DAC C\u00C1C DB TRONG M\u00D4I TR\u01AF\u1EDCNG PH\u00C1T TRI\u1EC2N'\"\r\n [hideButtonGroup]=\"true\"></core-page-header>\r\n <core-table [showCheckbox]=\"true\" [columns]=\"columns\" [height]=\"tableHeight\" [data]=\"data\" [loading]=\"loading\"\r\n [autoColumnFitAvailableSpace]=\"false\" [frozen]=\"2\" [lazyLoading]=\"true\"\r\n (onSearching)=\"onSearching($event)\"></core-table>\r\n <div class=\"h15\"></div>\r\n <div class=\"w-100 d-flex d-flex-between\">\r\n <div class=\"conflict-total\" [class.error]=\"!!conflictTotal\">\r\n {{ !!conflictTotal ? conflictTotal + ' conflicts found!' : 'No conflict found' }} \r\n </div>\r\n <core-pagination [$height]=\"46\" [$currentPage]=\"currentPage$\" [$pageCount]=\"pageCount\" [$loading]=\"loading\"\r\n [$background]=\"'#848484'\" [$fixedPageSize]=\"20\"\r\n [$suspendCurrentPageSubscription]=\"suspendCurrentPageSubscription$\"></core-pagination>\r\n </div>\r\n\r\n @if (showRowResolverWindow) {\r\n <div class=\"modal-container\">\r\n <div class=\"modal-content-root\">\r\n <div class=\"row-resolver-window\">\r\n <core-page-header [title]=\"'RESOLVER WINDOW'\" [hideButtonGroup]=\"true\"></core-page-header>\r\n <i class=\"close-icon pointer feather-x fs24\" (click)=\"closeRowResolver($event)\"></i>\r\n <textarea class=\"form-control\" [rows]=\"'10'\" style=\"height: 400px; padding: 15px;\" disabled>\r\n {{ sqlCommand }}\r\n </textarea>\r\n <button class=\"btn btn-primary\" (click)=\"resolve($event)\" style=\"margin-top: 15px;\">Resolve</button>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n\r\n <ng-template #toolBlock let-context=\"context\">\r\n <div class=\"tools inter-font d-flex d-flex-start\">\r\n <div class=\"icon-wrapper\" [appTooltip]=\"'Resolve'\" [position]=\"'right'\" [showAnyway]=\"true\" (click)=\"openRowResolver($event, context)\">\r\n <i class=\"feather-play fs24\"></i>\r\n </div>\r\n <span>{{ context.difference }}</span>\r\n </div>\r\n </ng-template>\r\n <ng-template #sourceAllowsNull let-context=\"context\">\r\n <core-checkbox [ngModel]=\"context.sourceAllowsNull\" [disabled]=\"true\"></core-checkbox>\r\n </ng-template>\r\n <ng-template #targetAllowsNull let-context=\"context\">\r\n <core-checkbox [ngModel]=\"context.targetAllowsNull\" [disabled]=\"true\"></core-checkbox>\r\n </ng-template>\r\n</div>", styles: [".core-compare-db-pipeline-container .h15{height:15px}.core-compare-db-pipeline-container .tools{height:36px}.core-compare-db-pipeline-container .tools .icon-wrapper{color:#848484;opacity:.5;display:inline-flex;width:36px;height:36px;border-radius:50%}.core-compare-db-pipeline-container .tools .icon-wrapper:hover{opacity:1;color:#fff;background-color:#848484}.core-compare-db-pipeline-container .modal-content-root{padding-top:0}.core-compare-db-pipeline-container .close-icon{display:block;position:absolute;top:8px;right:8px;color:#848484}.core-compare-db-pipeline-container .close-icon:hover{color:inherit}.core-compare-db-pipeline-container .row-resolver-window{display:block;width:992px;max-width:100vw!important;height:500px}.core-compare-db-pipeline-container .conflict-total{height:50px;display:flex;align-items:center;justify-content:flex-start;color:#848484;font-size:24px;font-weight:700}.core-compare-db-pipeline-container .conflict-total.error{color:brown}\n"], dependencies: [{ kind: "component", type: CorePageHeaderComponent, selector: "core-page-header", inputs: ["instanceNumber", "shownItems", "title", "hideButtonGroup"], outputs: ["buttonClick"] }, { kind: "component", type: CoreTableComponent, selector: "core-table", inputs: ["id", "width", "height", "showCheckbox", "checkboxSize", "outerButtons", "showTools", "tools", "checkingResetFlag", "borderRadius", "headerColor", "headerBackgroundColor", "headerWrap", "headerFirstRowHeight", "headerSecondRowHeight", "wrap", "allowCellScrollY", "loading", "rowHeight", "frozen", "footer", "columns", "data", "selectedIds", "corePageListInstanceNumber", "disableHighlightOnClick", "freeMode", "searchSwitchDisabled", "disableSorting", "inlineToolItems", "columnSearchDefaultOpen", "lazyLoading", "primaryKey", "rowHoverBgColor", "noPaddingCell", "autoColumnFitAvailableSpace"], outputs: ["onSearching", "onToolClick", "onRowClick", "onRowDoubleClick", "onSelectedIdsChange", "onSelectedDataChange", "onColumnCaptionClick"] }, { kind: "component", type: CorePaginationComponent, selector: "core-pagination", inputs: ["$currentPage", "$height", "$pageCount", "$loading", "$suspendCurrentPageSubscription", "$showAdd", "$background", "$fixedPageSize"], outputs: ["$onClickAdd"] }, { kind: "directive", type: TooltipDirective, selector: "[appTooltip]", inputs: ["color", "backgroundColor", "appTooltip", "showAnyway", "position"] }, { kind: "component", type: CoreCheckboxComponent, selector: "core-checkbox", inputs: ["text", "tooltipPosition", "tooltip", "inputValue", "disabled"], outputs: ["onClick"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
|
|
135
216
|
}
|
|
136
217
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.1", ngImport: i0, type: CoreCompareDbPipelineComponent, decorators: [{
|
|
137
218
|
type: Component,
|
|
@@ -139,7 +220,19 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.1", ngImpor
|
|
|
139
220
|
CoreButtonGroupVnsComponent,
|
|
140
221
|
CorePageHeaderComponent,
|
|
141
222
|
CoreTableComponent,
|
|
142
|
-
CorePaginationComponent
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-compare-db-pipeline.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-compare-db-pipeline/core-compare-db-pipeline.component.ts","../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-compare-db-pipeline/core-compare-db-pipeline.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component } from '@angular/core';\r\nimport { AppService } from '../../services/app.service';\r\nimport { MultiLanguageService } from '../../services/multi-language.service';\r\nimport { BaseComponent } from '../base-component/base/base.component';\r\nimport { CoreTableComponent } from '../core-table/core-table.component';\r\nimport { ICoreTableColumnItem } from '../core-table/ICoreTableColumnItem';\r\nimport { CorePageHeaderComponent } from '../core-page-header/core-page-header/core-page-header.component';\r\nimport { BehaviorSubject, distinctUntilChanged, switchMap, tap } from 'rxjs';\r\nimport { CorePaginationComponent } from '../core-pagination/core-pagination/core-pagination.component';\r\nimport { CoreButtonGroupVnsComponent } from '../core-button-group-vns/core-button-group-vns/core-button-group-vns.component';\r\n\r\ninterface ICompareDbStructureFilterItem {\r\n  field: string;\r\n  searchFor: string;\r\n}\r\n\r\ninterface ICompareDbStructureRequest {\r\n  filter?: ICompareDbStructureFilterItem[];\r\n  pageNumber: number;\r\n  pageSize: number;\r\n}\r\n\r\n@Component({\r\n    selector: 'core-compare-db-pipeline',\r\n    imports: [\r\n        CoreButtonGroupVnsComponent,\r\n        CorePageHeaderComponent,\r\n        CoreTableComponent,\r\n        CorePaginationComponent\r\n    ],\r\n    templateUrl: './core-compare-db-pipeline.component.html',\r\n    styleUrl: './core-compare-db-pipeline.component.scss'\r\n})\r\nexport class CoreCompareDbPipelineComponent extends BaseComponent implements AfterViewInit {\r\n\r\n  data: any[] = [];\r\n\r\n  columns: ICoreTableColumnItem[] = [\r\n    {\r\n      field: 'id',\r\n      type: 'string',\r\n      caption: 'id',\r\n      align: 'left',\r\n      hidden: true,\r\n      width: 0\r\n    },\r\n    {\r\n      field: 'sourceDb',\r\n      type: 'string',\r\n      caption: 'DB nguồn',\r\n      align: 'left',\r\n      sortDisabled: true,\r\n      width: 160\r\n    },\r\n    {\r\n      field: 'targetDb',\r\n      type: 'string',\r\n      caption: 'DB đích',\r\n      align: 'left',\r\n      sortDisabled: true,\r\n      width: 160\r\n    },\r\n    {\r\n      field: 'tableName',\r\n      type: 'string',\r\n      caption: 'Bảng',\r\n      align: 'left',\r\n      sortDisabled: true,\r\n      width: 200\r\n    },\r\n    {\r\n      field: 'columnName',\r\n      type: 'string',\r\n      caption: 'Cột',\r\n      align: 'left',\r\n      sortDisabled: true,\r\n      width: 200\r\n    },\r\n    {\r\n      field: 'sourceType',\r\n      type: 'string',\r\n      caption: 'Kiểu nguồn',\r\n      align: 'left',\r\n      sortDisabled: true,\r\n      width: 100\r\n    },\r\n    {\r\n      field: 'targetType',\r\n      type: 'string',\r\n      caption: 'Kiểu đích',\r\n      align: 'left',\r\n      sortDisabled: true,\r\n      width: 100\r\n    },\r\n    {\r\n      field: 'sourceSize',\r\n      type: 'string',\r\n      caption: 'Cỡ nguồn',\r\n      align: 'right',\r\n      sortDisabled: true,\r\n      width: 100\r\n    },\r\n    {\r\n      field: 'targetSize',\r\n      type: 'string',\r\n      caption: 'Cỡ đích',\r\n      align: 'right',\r\n      sortDisabled: true,\r\n      width: 100\r\n    },\r\n    {\r\n      field: 'difference',\r\n      type: 'string',\r\n      caption: 'Khác biệt',\r\n      align: 'left',\r\n      sortDisabled: true,\r\n      width: 400\r\n    },\r\n  ]\r\n\r\n  tableHeight: number = 500;\r\n\r\n  loading: boolean = false;\r\n\r\n  defaultRequest: ICompareDbStructureRequest = {\r\n    pageNumber: 1,\r\n    pageSize: 50\r\n  }\r\n\r\n  request$ = new BehaviorSubject<ICompareDbStructureRequest>(this.defaultRequest);\r\n\r\n  currentPage$ = new BehaviorSubject<number>(1);\r\n  pageSize$ = new BehaviorSubject<number>(50);\r\n  pageCount: number = 0;\r\n\r\n  suspendCurrentPageSubscription$ = new BehaviorSubject<boolean>(false);\r\n\r\n  constructor(\r\n    public override mls: MultiLanguageService,\r\n    private appService: AppService\r\n  ) {\r\n    super(mls);\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n\r\n      this.tableHeight = window.innerHeight - 60 - 50 - 46 - 30;\r\n\r\n      this.subscriptions.push(\r\n        this.request$.pipe(\r\n          distinctUntilChanged((pre, cur) => JSON.stringify(pre) === JSON.stringify(cur)),\r\n          tap(() => this.loading = true),\r\n          switchMap(x => this.appService.post('/api/SqlServerPipeline/CompareDbStructure', x))\r\n        ).subscribe(x => {\r\n          this.loading = false;\r\n          if (x.ok && x.status === 200 && x.body?.statusCode === 200) {\r\n            this.data = x.body.innerBody.data\r\n            this.pageCount = Math.ceil(x.body.innerBody.count / this.pageSize$.value);\r\n            this.currentPage$.next(x.body.innerBody.pageNumber);\r\n          }\r\n        })\r\n      )\r\n\r\n      this.subscriptions.push(\r\n        this.currentPage$.subscribe(x => {\r\n          const newRequest: ICompareDbStructureRequest = {\r\n            ...this.request$.value,\r\n            pageNumber: x\r\n          }\r\n          this.request$.next(JSON.parse(JSON.stringify(newRequest)))\r\n        })\r\n      )\r\n\r\n    })\r\n  }\r\n\r\n  onSearching(e: any): void {\r\n\r\n  }\r\n\r\n}\r\n","<core-page-header [title]=\"'SO SÁNH CẤU TRÚC CÁC DB TRONG MÔI TRƯỜNG PHÁT TRIỂN'\"\r\n    [hideButtonGroup]=\"true\"></core-page-header>\r\n<core-table [showCheckbox]=\"true\" [columns]=\"columns\" [height]=\"tableHeight\" [data]=\"data\" [loading]=\"loading\"\r\n    [autoColumnFitAvailableSpace]=\"false\" [frozen]=\"2\" [lazyLoading]=\"true\"\r\n    (onSearching)=\"onSearching($event)\"></core-table>\r\n<div class=\"h15\"></div>\r\n<div class=\"w-100 d-flex d-flex-end\">\r\n    <core-pagination [$height]=\"46\" [$currentPage]=\"currentPage$\" [$pageCount]=\"pageCount\" [$loading]=\"loading\"\r\n        [$background]=\"'#848484'\" [$fixedPageSize]=\"20\" [$suspendCurrentPageSubscription]=\"suspendCurrentPageSubscription$\"></core-pagination>\r\n</div>\r\n\r\n<ng-template #tools let-context=\"context\">\r\n    \r\n</ng-template>"]}
|
|
223
|
+
CorePaginationComponent,
|
|
224
|
+
TooltipDirective,
|
|
225
|
+
CoreCheckboxComponent,
|
|
226
|
+
FormsModule
|
|
227
|
+
], template: "<div class=\"core-compare-db-pipeline-container\">\r\n <core-page-header [title]=\"'SO S\u00C1NH C\u1EA4U TR\u00DAC C\u00C1C DB TRONG M\u00D4I TR\u01AF\u1EDCNG PH\u00C1T TRI\u1EC2N'\"\r\n [hideButtonGroup]=\"true\"></core-page-header>\r\n <core-table [showCheckbox]=\"true\" [columns]=\"columns\" [height]=\"tableHeight\" [data]=\"data\" [loading]=\"loading\"\r\n [autoColumnFitAvailableSpace]=\"false\" [frozen]=\"2\" [lazyLoading]=\"true\"\r\n (onSearching)=\"onSearching($event)\"></core-table>\r\n <div class=\"h15\"></div>\r\n <div class=\"w-100 d-flex d-flex-between\">\r\n <div class=\"conflict-total\" [class.error]=\"!!conflictTotal\">\r\n {{ !!conflictTotal ? conflictTotal + ' conflicts found!' : 'No conflict found' }} \r\n </div>\r\n <core-pagination [$height]=\"46\" [$currentPage]=\"currentPage$\" [$pageCount]=\"pageCount\" [$loading]=\"loading\"\r\n [$background]=\"'#848484'\" [$fixedPageSize]=\"20\"\r\n [$suspendCurrentPageSubscription]=\"suspendCurrentPageSubscription$\"></core-pagination>\r\n </div>\r\n\r\n @if (showRowResolverWindow) {\r\n <div class=\"modal-container\">\r\n <div class=\"modal-content-root\">\r\n <div class=\"row-resolver-window\">\r\n <core-page-header [title]=\"'RESOLVER WINDOW'\" [hideButtonGroup]=\"true\"></core-page-header>\r\n <i class=\"close-icon pointer feather-x fs24\" (click)=\"closeRowResolver($event)\"></i>\r\n <textarea class=\"form-control\" [rows]=\"'10'\" style=\"height: 400px; padding: 15px;\" disabled>\r\n {{ sqlCommand }}\r\n </textarea>\r\n <button class=\"btn btn-primary\" (click)=\"resolve($event)\" style=\"margin-top: 15px;\">Resolve</button>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n\r\n <ng-template #toolBlock let-context=\"context\">\r\n <div class=\"tools inter-font d-flex d-flex-start\">\r\n <div class=\"icon-wrapper\" [appTooltip]=\"'Resolve'\" [position]=\"'right'\" [showAnyway]=\"true\" (click)=\"openRowResolver($event, context)\">\r\n <i class=\"feather-play fs24\"></i>\r\n </div>\r\n <span>{{ context.difference }}</span>\r\n </div>\r\n </ng-template>\r\n <ng-template #sourceAllowsNull let-context=\"context\">\r\n <core-checkbox [ngModel]=\"context.sourceAllowsNull\" [disabled]=\"true\"></core-checkbox>\r\n </ng-template>\r\n <ng-template #targetAllowsNull let-context=\"context\">\r\n <core-checkbox [ngModel]=\"context.targetAllowsNull\" [disabled]=\"true\"></core-checkbox>\r\n </ng-template>\r\n</div>", styles: [".core-compare-db-pipeline-container .h15{height:15px}.core-compare-db-pipeline-container .tools{height:36px}.core-compare-db-pipeline-container .tools .icon-wrapper{color:#848484;opacity:.5;display:inline-flex;width:36px;height:36px;border-radius:50%}.core-compare-db-pipeline-container .tools .icon-wrapper:hover{opacity:1;color:#fff;background-color:#848484}.core-compare-db-pipeline-container .modal-content-root{padding-top:0}.core-compare-db-pipeline-container .close-icon{display:block;position:absolute;top:8px;right:8px;color:#848484}.core-compare-db-pipeline-container .close-icon:hover{color:inherit}.core-compare-db-pipeline-container .row-resolver-window{display:block;width:992px;max-width:100vw!important;height:500px}.core-compare-db-pipeline-container .conflict-total{height:50px;display:flex;align-items:center;justify-content:flex-start;color:#848484;font-size:24px;font-weight:700}.core-compare-db-pipeline-container .conflict-total.error{color:brown}\n"] }]
|
|
228
|
+
}], ctorParameters: () => [{ type: i1.MultiLanguageService }, { type: i2.AppService }], propDecorators: { toolBlock: [{
|
|
229
|
+
type: ViewChild,
|
|
230
|
+
args: ['toolBlock']
|
|
231
|
+
}], sourceAllowsNull: [{
|
|
232
|
+
type: ViewChild,
|
|
233
|
+
args: ['sourceAllowsNull']
|
|
234
|
+
}], targetAllowsNull: [{
|
|
235
|
+
type: ViewChild,
|
|
236
|
+
args: ['targetAllowsNull']
|
|
237
|
+
}] } });
|
|
238
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-compare-db-pipeline.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-compare-db-pipeline/core-compare-db-pipeline.component.ts","../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-compare-db-pipeline/core-compare-db-pipeline.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, TemplateRef, ViewChild } from '@angular/core';\r\nimport { AppService } from '../../services/app.service';\r\nimport { MultiLanguageService } from '../../services/multi-language.service';\r\nimport { BaseComponent } from '../base-component/base/base.component';\r\nimport { CoreTableComponent } from '../core-table/core-table.component';\r\nimport { ICoreTableColumnItem } from '../core-table/ICoreTableColumnItem';\r\nimport { CorePageHeaderComponent } from '../core-page-header/core-page-header/core-page-header.component';\r\nimport { BehaviorSubject, distinctUntilChanged, switchMap, tap } from 'rxjs';\r\nimport { CorePaginationComponent } from '../core-pagination/core-pagination/core-pagination.component';\r\nimport { CoreButtonGroupVnsComponent } from '../core-button-group-vns/core-button-group-vns/core-button-group-vns.component';\r\nimport { TooltipDirective } from '../tooltip/tooltip.directive';\r\nimport { CoreCheckboxComponent } from '../core-checkbox/core-checkbox/core-checkbox.component';\r\nimport { FormsModule } from '@angular/forms';\r\n\r\ninterface ICompareDbStructureFilterItem {\r\n  field: string;\r\n  searchFor: string;\r\n}\r\n\r\ninterface ICompareDbStructureRequest {\r\n  filter?: ICompareDbStructureFilterItem[];\r\n  pageNumber: number;\r\n  pageSize: number;\r\n}\r\n\r\ninterface IDbStructureDifference\r\n{\r\n    id: string;\r\n    sourceAlias: string;\r\n    targetAlias: string;\r\n    tableName: string;\r\n    columnName: string;\r\n    conflictType: string;\r\n    sourceType?: string;\r\n    sourceSize?: number;\r\n    sourceAllowsNull?: boolean;\r\n    targetType?: string;\r\n    targetSize?: number;\r\n    targetAllowsNull?: boolean;\r\n    difference: string;\r\n    resolverSessionId?: string;\r\n}\r\n\r\n@Component({\r\n    selector: 'core-compare-db-pipeline',\r\n    imports: [\r\n        CoreButtonGroupVnsComponent,\r\n        CorePageHeaderComponent,\r\n        CoreTableComponent,\r\n        CorePaginationComponent,\r\n        TooltipDirective,\r\n        CoreCheckboxComponent,\r\n        FormsModule\r\n    ],\r\n    templateUrl: './core-compare-db-pipeline.component.html',\r\n    styleUrl: './core-compare-db-pipeline.component.scss'\r\n})\r\nexport class CoreCompareDbPipelineComponent extends BaseComponent implements AfterViewInit {\r\n\r\n  @ViewChild('toolBlock') toolBlock!: TemplateRef<any>;\r\n  @ViewChild('sourceAllowsNull') sourceAllowsNull!: TemplateRef<any>;\r\n  @ViewChild('targetAllowsNull') targetAllowsNull!: TemplateRef<any>;\r\n\r\n  data: any[] = [];\r\n\r\n  showRowResolverWindow!: boolean;\r\n\r\n  columns: ICoreTableColumnItem[] = [\r\n    {\r\n      field: 'id',\r\n      type: 'string',\r\n      caption: 'id',\r\n      align: 'left',\r\n      hidden: true,\r\n      width: 0\r\n    },\r\n    {\r\n      field: 'sourceAlias',\r\n      type: 'string',\r\n      caption: 'Nguồn',\r\n      align: 'left',\r\n      sortDisabled: true,\r\n      width: 60\r\n    },\r\n    {\r\n      field: 'targetAlias',\r\n      type: 'string',\r\n      caption: 'Đích',\r\n      align: 'left',\r\n      sortDisabled: true,\r\n      width: 60\r\n    },\r\n    {\r\n      field: 'tableName',\r\n      type: 'string',\r\n      caption: 'Bảng',\r\n      align: 'left',\r\n      sortDisabled: true,\r\n      width: 200\r\n    },\r\n    {\r\n      field: 'columnName',\r\n      type: 'string',\r\n      caption: 'Cột',\r\n      align: 'left',\r\n      sortDisabled: true,\r\n      width: 200\r\n    },\r\n    {\r\n      field: 'sourceType',\r\n      type: 'string',\r\n      caption: 'Kiểu nguồn',\r\n      align: 'left',\r\n      sortDisabled: true,\r\n      width: 100\r\n    },\r\n    {\r\n      field: 'sourceAllowsNull',\r\n      type: 'boolean',\r\n      caption: 'Source nullablity',\r\n      align: 'center',\r\n      sortDisabled: true,\r\n      width: 70\r\n    },\r\n    {\r\n      field: 'sourceSize',\r\n      type: 'string',\r\n      caption: 'Cỡ nguồn',\r\n      align: 'right',\r\n      sortDisabled: true,\r\n      width: 100\r\n    },\r\n    {\r\n      field: 'targetType',\r\n      type: 'string',\r\n      caption: 'Kiểu đích',\r\n      align: 'left',\r\n      sortDisabled: true,\r\n      width: 100\r\n    },\r\n    {\r\n      field: 'targetAllowsNull',\r\n      type: 'boolean',\r\n      caption: 'Target nullablity',\r\n      align: 'center',\r\n      sortDisabled: true,\r\n      width: 70\r\n    },\r\n    {\r\n      field: 'targetSize',\r\n      type: 'string',\r\n      caption: 'Cỡ đích',\r\n      align: 'right',\r\n      sortDisabled: true,\r\n      width: 100\r\n    },\r\n    {\r\n      field: 'difference',\r\n      type: 'string',\r\n      caption: 'Khác biệt',\r\n      align: 'left',\r\n      sortDisabled: true,\r\n      width: 400\r\n    },\r\n  ]\r\n\r\n  tableHeight: number = 500;\r\n\r\n  loading: boolean = false;\r\n\r\n  defaultRequest: ICompareDbStructureRequest = {\r\n    pageNumber: 1,\r\n    pageSize: 50\r\n  }\r\n\r\n  request$ = new BehaviorSubject<ICompareDbStructureRequest>(this.defaultRequest);\r\n\r\n  currentPage$ = new BehaviorSubject<number>(1);\r\n  pageSize$ = new BehaviorSubject<number>(50);\r\n  pageCount: number = 0;\r\n\r\n  suspendCurrentPageSubscription$ = new BehaviorSubject<boolean>(false);\r\n\r\n  sqlCommand: string = '';\r\n  resolverSessionId: string = '';\r\n\r\n  conflictTotal: number = 0;\r\n\r\n  constructor(\r\n    public override mls: MultiLanguageService,\r\n    private appService: AppService\r\n  ) {\r\n    super(mls);\r\n  }\r\n\r\n  refreshList(): void {\r\n    this.loading = true;\r\n    this.subscriptions.push(\r\n      this.appService.post('/api/SqlServerPipeline/CompareDbStructure', this.request$.value).subscribe(x => {\r\n        this.loading = false;\r\n        if (x.ok && x.status === 200 && x.body?.statusCode === 200) {\r\n          this.data = x.body.innerBody.data\r\n          this.pageCount = Math.ceil(x.body.innerBody.count / this.pageSize$.value);\r\n          this.currentPage$.next(x.body.innerBody.pageNumber);\r\n          this.conflictTotal = x.body.innerBody.count || 0;\r\n        }\r\n      })\r\n    )\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n\r\n      const tryFilterDifference  =this.columns.filter(x => x.field === 'difference');\r\n      if (!!tryFilterDifference.length) {\r\n        tryFilterDifference[0].templateRef = this.toolBlock;\r\n      }\r\n      const tryFilterSourceAllowsNull  =this.columns.filter(x => x.field === 'sourceAllowsNull');\r\n      if (!!tryFilterSourceAllowsNull.length) {\r\n        tryFilterSourceAllowsNull[0].templateRef = this.sourceAllowsNull;\r\n      }\r\n      const tryFilterTargetAllowsNull  =this.columns.filter(x => x.field === 'targetAllowsNull');\r\n      if (!!tryFilterTargetAllowsNull.length) {\r\n        tryFilterTargetAllowsNull[0].templateRef = this.targetAllowsNull;\r\n      }\r\n\r\n      this.tableHeight = window.innerHeight - 60 - 50 - 46 - 30;\r\n\r\n      this.subscriptions.push(\r\n        this.request$.pipe(\r\n          distinctUntilChanged((pre, cur) => JSON.stringify(pre) === JSON.stringify(cur)),\r\n          tap(() => this.loading = true),\r\n          switchMap(x => this.appService.post('/api/SqlServerPipeline/CompareDbStructure', x))\r\n        ).subscribe(x => {\r\n          this.loading = false;\r\n          if (x.ok && x.status === 200 && x.body?.statusCode === 200) {\r\n            this.data = x.body.innerBody.data\r\n            this.pageCount = Math.ceil(x.body.innerBody.count / this.pageSize$.value);\r\n            this.currentPage$.next(x.body.innerBody.pageNumber);\r\n            this.conflictTotal = x.body.innerBody.count || 0;\r\n          }\r\n        })\r\n      )\r\n\r\n      this.subscriptions.push(\r\n        this.currentPage$.subscribe(x => {\r\n          const newRequest: ICompareDbStructureRequest = {\r\n            ...this.request$.value,\r\n            pageNumber: x\r\n          }\r\n          this.request$.next(JSON.parse(JSON.stringify(newRequest)))\r\n        })\r\n      )\r\n\r\n    })\r\n  }\r\n\r\n  onSearching(e: any): void {\r\n    const filtered = e.filter(x => !!x.searchFor.length)\r\n    this.request$.next({\r\n      ...this.request$.value,\r\n      filter: filtered\r\n    })\r\n  }\r\n\r\n  openRowResolver(event: any, context: any) {\r\n    event.stopPropagation();\r\n    this.loading = true;\r\n    this.subscriptions.push(\r\n      this.appService.post('/api/SqlServerPipeline/GenerateConflictResolverCommand', context).subscribe(x => {\r\n        this.loading = false;\r\n        if (x.ok && x.status === 200 && x.body?.statusCode === 200) {\r\n          this.showRowResolverWindow = true;\r\n          this.resolverSessionId = x.body.innerBody.resolverSessionId\r\n          this.sqlCommand = (x.body.innerBody.sqlCommand as string).trim();\r\n        }\r\n      })\r\n    )\r\n  }\r\n\r\n  closeRowResolver(event: any) {\r\n    this.showRowResolverWindow = false;\r\n  }\r\n\r\n  resolve(event: any): void {\r\n    this.loading = true;\r\n    this.subscriptions.push(\r\n      this.appService.post('/api/SqlServerPipeline/RunConflictResolverCommand', {\r\n        resolverSessionId: this.resolverSessionId,\r\n        sqlCommand: this.sqlCommand\r\n      }).subscribe(x => {\r\n        this.loading = false;\r\n        if (x.ok && x.status === 200 && x.body?.statusCode === 200) {\r\n          this.showRowResolverWindow = false;\r\n          this.refreshList();\r\n        }\r\n      })\r\n    )\r\n  }\r\n\r\n}\r\n","<div class=\"core-compare-db-pipeline-container\">\r\n    <core-page-header [title]=\"'SO SÁNH CẤU TRÚC CÁC DB TRONG MÔI TRƯỜNG PHÁT TRIỂN'\"\r\n        [hideButtonGroup]=\"true\"></core-page-header>\r\n    <core-table [showCheckbox]=\"true\" [columns]=\"columns\" [height]=\"tableHeight\" [data]=\"data\" [loading]=\"loading\"\r\n        [autoColumnFitAvailableSpace]=\"false\" [frozen]=\"2\" [lazyLoading]=\"true\"\r\n        (onSearching)=\"onSearching($event)\"></core-table>\r\n    <div class=\"h15\"></div>\r\n    <div class=\"w-100 d-flex d-flex-between\">\r\n        <div class=\"conflict-total\" [class.error]=\"!!conflictTotal\">\r\n            {{ !!conflictTotal ? conflictTotal + ' conflicts found!' : 'No conflict found' }} \r\n        </div>\r\n        <core-pagination [$height]=\"46\" [$currentPage]=\"currentPage$\" [$pageCount]=\"pageCount\" [$loading]=\"loading\"\r\n            [$background]=\"'#848484'\" [$fixedPageSize]=\"20\"\r\n            [$suspendCurrentPageSubscription]=\"suspendCurrentPageSubscription$\"></core-pagination>\r\n    </div>\r\n\r\n    @if (showRowResolverWindow) {\r\n        <div class=\"modal-container\">\r\n            <div class=\"modal-content-root\">\r\n                <div class=\"row-resolver-window\">\r\n                    <core-page-header [title]=\"'RESOLVER WINDOW'\" [hideButtonGroup]=\"true\"></core-page-header>\r\n                    <i class=\"close-icon pointer feather-x fs24\" (click)=\"closeRowResolver($event)\"></i>\r\n                    <textarea class=\"form-control\" [rows]=\"'10'\" style=\"height: 400px; padding: 15px;\" disabled>\r\n                        {{ sqlCommand }}\r\n                    </textarea>\r\n                    <button class=\"btn btn-primary\" (click)=\"resolve($event)\" style=\"margin-top: 15px;\">Resolve</button>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    }\r\n\r\n    <ng-template #toolBlock let-context=\"context\">\r\n        <div class=\"tools inter-font d-flex d-flex-start\">\r\n            <div class=\"icon-wrapper\" [appTooltip]=\"'Resolve'\" [position]=\"'right'\" [showAnyway]=\"true\" (click)=\"openRowResolver($event, context)\">\r\n                <i class=\"feather-play fs24\"></i>\r\n            </div>\r\n            <span>{{ context.difference }}</span>\r\n        </div>\r\n    </ng-template>\r\n    <ng-template #sourceAllowsNull let-context=\"context\">\r\n        <core-checkbox [ngModel]=\"context.sourceAllowsNull\" [disabled]=\"true\"></core-checkbox>\r\n    </ng-template>\r\n    <ng-template #targetAllowsNull let-context=\"context\">\r\n        <core-checkbox [ngModel]=\"context.targetAllowsNull\" [disabled]=\"true\"></core-checkbox>\r\n    </ng-template>\r\n</div>"]}
|
|
@@ -25456,20 +25456,20 @@ class CoreCompareDbPipelineComponent extends BaseComponent {
|
|
|
25456
25456
|
width: 0
|
|
25457
25457
|
},
|
|
25458
25458
|
{
|
|
25459
|
-
field: '
|
|
25459
|
+
field: 'sourceAlias',
|
|
25460
25460
|
type: 'string',
|
|
25461
|
-
caption: '
|
|
25461
|
+
caption: 'Nguồn',
|
|
25462
25462
|
align: 'left',
|
|
25463
25463
|
sortDisabled: true,
|
|
25464
|
-
width:
|
|
25464
|
+
width: 60
|
|
25465
25465
|
},
|
|
25466
25466
|
{
|
|
25467
|
-
field: '
|
|
25467
|
+
field: 'targetAlias',
|
|
25468
25468
|
type: 'string',
|
|
25469
|
-
caption: '
|
|
25469
|
+
caption: 'Đích',
|
|
25470
25470
|
align: 'left',
|
|
25471
25471
|
sortDisabled: true,
|
|
25472
|
-
width:
|
|
25472
|
+
width: 60
|
|
25473
25473
|
},
|
|
25474
25474
|
{
|
|
25475
25475
|
field: 'tableName',
|
|
@@ -25496,12 +25496,12 @@ class CoreCompareDbPipelineComponent extends BaseComponent {
|
|
|
25496
25496
|
width: 100
|
|
25497
25497
|
},
|
|
25498
25498
|
{
|
|
25499
|
-
field: '
|
|
25500
|
-
type: '
|
|
25501
|
-
caption: '
|
|
25502
|
-
align: '
|
|
25499
|
+
field: 'sourceAllowsNull',
|
|
25500
|
+
type: 'boolean',
|
|
25501
|
+
caption: 'Source nullablity',
|
|
25502
|
+
align: 'center',
|
|
25503
25503
|
sortDisabled: true,
|
|
25504
|
-
width:
|
|
25504
|
+
width: 70
|
|
25505
25505
|
},
|
|
25506
25506
|
{
|
|
25507
25507
|
field: 'sourceSize',
|
|
@@ -25511,6 +25511,22 @@ class CoreCompareDbPipelineComponent extends BaseComponent {
|
|
|
25511
25511
|
sortDisabled: true,
|
|
25512
25512
|
width: 100
|
|
25513
25513
|
},
|
|
25514
|
+
{
|
|
25515
|
+
field: 'targetType',
|
|
25516
|
+
type: 'string',
|
|
25517
|
+
caption: 'Kiểu đích',
|
|
25518
|
+
align: 'left',
|
|
25519
|
+
sortDisabled: true,
|
|
25520
|
+
width: 100
|
|
25521
|
+
},
|
|
25522
|
+
{
|
|
25523
|
+
field: 'targetAllowsNull',
|
|
25524
|
+
type: 'boolean',
|
|
25525
|
+
caption: 'Target nullablity',
|
|
25526
|
+
align: 'center',
|
|
25527
|
+
sortDisabled: true,
|
|
25528
|
+
width: 70
|
|
25529
|
+
},
|
|
25514
25530
|
{
|
|
25515
25531
|
field: 'targetSize',
|
|
25516
25532
|
type: 'string',
|
|
@@ -25539,9 +25555,36 @@ class CoreCompareDbPipelineComponent extends BaseComponent {
|
|
|
25539
25555
|
this.pageSize$ = new BehaviorSubject(50);
|
|
25540
25556
|
this.pageCount = 0;
|
|
25541
25557
|
this.suspendCurrentPageSubscription$ = new BehaviorSubject(false);
|
|
25558
|
+
this.sqlCommand = '';
|
|
25559
|
+
this.resolverSessionId = '';
|
|
25560
|
+
this.conflictTotal = 0;
|
|
25561
|
+
}
|
|
25562
|
+
refreshList() {
|
|
25563
|
+
this.loading = true;
|
|
25564
|
+
this.subscriptions.push(this.appService.post('/api/SqlServerPipeline/CompareDbStructure', this.request$.value).subscribe(x => {
|
|
25565
|
+
this.loading = false;
|
|
25566
|
+
if (x.ok && x.status === 200 && x.body?.statusCode === 200) {
|
|
25567
|
+
this.data = x.body.innerBody.data;
|
|
25568
|
+
this.pageCount = Math.ceil(x.body.innerBody.count / this.pageSize$.value);
|
|
25569
|
+
this.currentPage$.next(x.body.innerBody.pageNumber);
|
|
25570
|
+
this.conflictTotal = x.body.innerBody.count || 0;
|
|
25571
|
+
}
|
|
25572
|
+
}));
|
|
25542
25573
|
}
|
|
25543
25574
|
ngAfterViewInit() {
|
|
25544
25575
|
setTimeout(() => {
|
|
25576
|
+
const tryFilterDifference = this.columns.filter(x => x.field === 'difference');
|
|
25577
|
+
if (!!tryFilterDifference.length) {
|
|
25578
|
+
tryFilterDifference[0].templateRef = this.toolBlock;
|
|
25579
|
+
}
|
|
25580
|
+
const tryFilterSourceAllowsNull = this.columns.filter(x => x.field === 'sourceAllowsNull');
|
|
25581
|
+
if (!!tryFilterSourceAllowsNull.length) {
|
|
25582
|
+
tryFilterSourceAllowsNull[0].templateRef = this.sourceAllowsNull;
|
|
25583
|
+
}
|
|
25584
|
+
const tryFilterTargetAllowsNull = this.columns.filter(x => x.field === 'targetAllowsNull');
|
|
25585
|
+
if (!!tryFilterTargetAllowsNull.length) {
|
|
25586
|
+
tryFilterTargetAllowsNull[0].templateRef = this.targetAllowsNull;
|
|
25587
|
+
}
|
|
25545
25588
|
this.tableHeight = window.innerHeight - 60 - 50 - 46 - 30;
|
|
25546
25589
|
this.subscriptions.push(this.request$.pipe(distinctUntilChanged((pre, cur) => JSON.stringify(pre) === JSON.stringify(cur)), tap$1(() => this.loading = true), switchMap(x => this.appService.post('/api/SqlServerPipeline/CompareDbStructure', x))).subscribe(x => {
|
|
25547
25590
|
this.loading = false;
|
|
@@ -25549,6 +25592,7 @@ class CoreCompareDbPipelineComponent extends BaseComponent {
|
|
|
25549
25592
|
this.data = x.body.innerBody.data;
|
|
25550
25593
|
this.pageCount = Math.ceil(x.body.innerBody.count / this.pageSize$.value);
|
|
25551
25594
|
this.currentPage$.next(x.body.innerBody.pageNumber);
|
|
25595
|
+
this.conflictTotal = x.body.innerBody.count || 0;
|
|
25552
25596
|
}
|
|
25553
25597
|
}));
|
|
25554
25598
|
this.subscriptions.push(this.currentPage$.subscribe(x => {
|
|
@@ -25561,9 +25605,42 @@ class CoreCompareDbPipelineComponent extends BaseComponent {
|
|
|
25561
25605
|
});
|
|
25562
25606
|
}
|
|
25563
25607
|
onSearching(e) {
|
|
25608
|
+
const filtered = e.filter(x => !!x.searchFor.length);
|
|
25609
|
+
this.request$.next({
|
|
25610
|
+
...this.request$.value,
|
|
25611
|
+
filter: filtered
|
|
25612
|
+
});
|
|
25613
|
+
}
|
|
25614
|
+
openRowResolver(event, context) {
|
|
25615
|
+
event.stopPropagation();
|
|
25616
|
+
this.loading = true;
|
|
25617
|
+
this.subscriptions.push(this.appService.post('/api/SqlServerPipeline/GenerateConflictResolverCommand', context).subscribe(x => {
|
|
25618
|
+
this.loading = false;
|
|
25619
|
+
if (x.ok && x.status === 200 && x.body?.statusCode === 200) {
|
|
25620
|
+
this.showRowResolverWindow = true;
|
|
25621
|
+
this.resolverSessionId = x.body.innerBody.resolverSessionId;
|
|
25622
|
+
this.sqlCommand = x.body.innerBody.sqlCommand.trim();
|
|
25623
|
+
}
|
|
25624
|
+
}));
|
|
25625
|
+
}
|
|
25626
|
+
closeRowResolver(event) {
|
|
25627
|
+
this.showRowResolverWindow = false;
|
|
25628
|
+
}
|
|
25629
|
+
resolve(event) {
|
|
25630
|
+
this.loading = true;
|
|
25631
|
+
this.subscriptions.push(this.appService.post('/api/SqlServerPipeline/RunConflictResolverCommand', {
|
|
25632
|
+
resolverSessionId: this.resolverSessionId,
|
|
25633
|
+
sqlCommand: this.sqlCommand
|
|
25634
|
+
}).subscribe(x => {
|
|
25635
|
+
this.loading = false;
|
|
25636
|
+
if (x.ok && x.status === 200 && x.body?.statusCode === 200) {
|
|
25637
|
+
this.showRowResolverWindow = false;
|
|
25638
|
+
this.refreshList();
|
|
25639
|
+
}
|
|
25640
|
+
}));
|
|
25564
25641
|
}
|
|
25565
25642
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.1", ngImport: i0, type: CoreCompareDbPipelineComponent, deps: [{ token: MultiLanguageService }, { token: AppService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
25566
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
25643
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.0.1", type: CoreCompareDbPipelineComponent, isStandalone: true, selector: "core-compare-db-pipeline", viewQueries: [{ propertyName: "toolBlock", first: true, predicate: ["toolBlock"], descendants: true }, { propertyName: "sourceAllowsNull", first: true, predicate: ["sourceAllowsNull"], descendants: true }, { propertyName: "targetAllowsNull", first: true, predicate: ["targetAllowsNull"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"core-compare-db-pipeline-container\">\r\n <core-page-header [title]=\"'SO S\u00C1NH C\u1EA4U TR\u00DAC C\u00C1C DB TRONG M\u00D4I TR\u01AF\u1EDCNG PH\u00C1T TRI\u1EC2N'\"\r\n [hideButtonGroup]=\"true\"></core-page-header>\r\n <core-table [showCheckbox]=\"true\" [columns]=\"columns\" [height]=\"tableHeight\" [data]=\"data\" [loading]=\"loading\"\r\n [autoColumnFitAvailableSpace]=\"false\" [frozen]=\"2\" [lazyLoading]=\"true\"\r\n (onSearching)=\"onSearching($event)\"></core-table>\r\n <div class=\"h15\"></div>\r\n <div class=\"w-100 d-flex d-flex-between\">\r\n <div class=\"conflict-total\" [class.error]=\"!!conflictTotal\">\r\n {{ !!conflictTotal ? conflictTotal + ' conflicts found!' : 'No conflict found' }} \r\n </div>\r\n <core-pagination [$height]=\"46\" [$currentPage]=\"currentPage$\" [$pageCount]=\"pageCount\" [$loading]=\"loading\"\r\n [$background]=\"'#848484'\" [$fixedPageSize]=\"20\"\r\n [$suspendCurrentPageSubscription]=\"suspendCurrentPageSubscription$\"></core-pagination>\r\n </div>\r\n\r\n @if (showRowResolverWindow) {\r\n <div class=\"modal-container\">\r\n <div class=\"modal-content-root\">\r\n <div class=\"row-resolver-window\">\r\n <core-page-header [title]=\"'RESOLVER WINDOW'\" [hideButtonGroup]=\"true\"></core-page-header>\r\n <i class=\"close-icon pointer feather-x fs24\" (click)=\"closeRowResolver($event)\"></i>\r\n <textarea class=\"form-control\" [rows]=\"'10'\" style=\"height: 400px; padding: 15px;\" disabled>\r\n {{ sqlCommand }}\r\n </textarea>\r\n <button class=\"btn btn-primary\" (click)=\"resolve($event)\" style=\"margin-top: 15px;\">Resolve</button>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n\r\n <ng-template #toolBlock let-context=\"context\">\r\n <div class=\"tools inter-font d-flex d-flex-start\">\r\n <div class=\"icon-wrapper\" [appTooltip]=\"'Resolve'\" [position]=\"'right'\" [showAnyway]=\"true\" (click)=\"openRowResolver($event, context)\">\r\n <i class=\"feather-play fs24\"></i>\r\n </div>\r\n <span>{{ context.difference }}</span>\r\n </div>\r\n </ng-template>\r\n <ng-template #sourceAllowsNull let-context=\"context\">\r\n <core-checkbox [ngModel]=\"context.sourceAllowsNull\" [disabled]=\"true\"></core-checkbox>\r\n </ng-template>\r\n <ng-template #targetAllowsNull let-context=\"context\">\r\n <core-checkbox [ngModel]=\"context.targetAllowsNull\" [disabled]=\"true\"></core-checkbox>\r\n </ng-template>\r\n</div>", styles: [".core-compare-db-pipeline-container .h15{height:15px}.core-compare-db-pipeline-container .tools{height:36px}.core-compare-db-pipeline-container .tools .icon-wrapper{color:#848484;opacity:.5;display:inline-flex;width:36px;height:36px;border-radius:50%}.core-compare-db-pipeline-container .tools .icon-wrapper:hover{opacity:1;color:#fff;background-color:#848484}.core-compare-db-pipeline-container .modal-content-root{padding-top:0}.core-compare-db-pipeline-container .close-icon{display:block;position:absolute;top:8px;right:8px;color:#848484}.core-compare-db-pipeline-container .close-icon:hover{color:inherit}.core-compare-db-pipeline-container .row-resolver-window{display:block;width:992px;max-width:100vw!important;height:500px}.core-compare-db-pipeline-container .conflict-total{height:50px;display:flex;align-items:center;justify-content:flex-start;color:#848484;font-size:24px;font-weight:700}.core-compare-db-pipeline-container .conflict-total.error{color:brown}\n"], dependencies: [{ kind: "component", type: CorePageHeaderComponent, selector: "core-page-header", inputs: ["instanceNumber", "shownItems", "title", "hideButtonGroup"], outputs: ["buttonClick"] }, { kind: "component", type: CoreTableComponent, selector: "core-table", inputs: ["id", "width", "height", "showCheckbox", "checkboxSize", "outerButtons", "showTools", "tools", "checkingResetFlag", "borderRadius", "headerColor", "headerBackgroundColor", "headerWrap", "headerFirstRowHeight", "headerSecondRowHeight", "wrap", "allowCellScrollY", "loading", "rowHeight", "frozen", "footer", "columns", "data", "selectedIds", "corePageListInstanceNumber", "disableHighlightOnClick", "freeMode", "searchSwitchDisabled", "disableSorting", "inlineToolItems", "columnSearchDefaultOpen", "lazyLoading", "primaryKey", "rowHoverBgColor", "noPaddingCell", "autoColumnFitAvailableSpace"], outputs: ["onSearching", "onToolClick", "onRowClick", "onRowDoubleClick", "onSelectedIdsChange", "onSelectedDataChange", "onColumnCaptionClick"] }, { kind: "component", type: CorePaginationComponent, selector: "core-pagination", inputs: ["$currentPage", "$height", "$pageCount", "$loading", "$suspendCurrentPageSubscription", "$showAdd", "$background", "$fixedPageSize"], outputs: ["$onClickAdd"] }, { kind: "directive", type: TooltipDirective, selector: "[appTooltip]", inputs: ["color", "backgroundColor", "appTooltip", "showAnyway", "position"] }, { kind: "component", type: CoreCheckboxComponent, selector: "core-checkbox", inputs: ["text", "tooltipPosition", "tooltip", "inputValue", "disabled"], outputs: ["onClick"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
|
|
25567
25644
|
}
|
|
25568
25645
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.1", ngImport: i0, type: CoreCompareDbPipelineComponent, decorators: [{
|
|
25569
25646
|
type: Component,
|
|
@@ -25571,9 +25648,21 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.1", ngImpor
|
|
|
25571
25648
|
CoreButtonGroupVnsComponent,
|
|
25572
25649
|
CorePageHeaderComponent,
|
|
25573
25650
|
CoreTableComponent,
|
|
25574
|
-
CorePaginationComponent
|
|
25575
|
-
|
|
25576
|
-
|
|
25651
|
+
CorePaginationComponent,
|
|
25652
|
+
TooltipDirective,
|
|
25653
|
+
CoreCheckboxComponent,
|
|
25654
|
+
FormsModule
|
|
25655
|
+
], template: "<div class=\"core-compare-db-pipeline-container\">\r\n <core-page-header [title]=\"'SO S\u00C1NH C\u1EA4U TR\u00DAC C\u00C1C DB TRONG M\u00D4I TR\u01AF\u1EDCNG PH\u00C1T TRI\u1EC2N'\"\r\n [hideButtonGroup]=\"true\"></core-page-header>\r\n <core-table [showCheckbox]=\"true\" [columns]=\"columns\" [height]=\"tableHeight\" [data]=\"data\" [loading]=\"loading\"\r\n [autoColumnFitAvailableSpace]=\"false\" [frozen]=\"2\" [lazyLoading]=\"true\"\r\n (onSearching)=\"onSearching($event)\"></core-table>\r\n <div class=\"h15\"></div>\r\n <div class=\"w-100 d-flex d-flex-between\">\r\n <div class=\"conflict-total\" [class.error]=\"!!conflictTotal\">\r\n {{ !!conflictTotal ? conflictTotal + ' conflicts found!' : 'No conflict found' }} \r\n </div>\r\n <core-pagination [$height]=\"46\" [$currentPage]=\"currentPage$\" [$pageCount]=\"pageCount\" [$loading]=\"loading\"\r\n [$background]=\"'#848484'\" [$fixedPageSize]=\"20\"\r\n [$suspendCurrentPageSubscription]=\"suspendCurrentPageSubscription$\"></core-pagination>\r\n </div>\r\n\r\n @if (showRowResolverWindow) {\r\n <div class=\"modal-container\">\r\n <div class=\"modal-content-root\">\r\n <div class=\"row-resolver-window\">\r\n <core-page-header [title]=\"'RESOLVER WINDOW'\" [hideButtonGroup]=\"true\"></core-page-header>\r\n <i class=\"close-icon pointer feather-x fs24\" (click)=\"closeRowResolver($event)\"></i>\r\n <textarea class=\"form-control\" [rows]=\"'10'\" style=\"height: 400px; padding: 15px;\" disabled>\r\n {{ sqlCommand }}\r\n </textarea>\r\n <button class=\"btn btn-primary\" (click)=\"resolve($event)\" style=\"margin-top: 15px;\">Resolve</button>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n\r\n <ng-template #toolBlock let-context=\"context\">\r\n <div class=\"tools inter-font d-flex d-flex-start\">\r\n <div class=\"icon-wrapper\" [appTooltip]=\"'Resolve'\" [position]=\"'right'\" [showAnyway]=\"true\" (click)=\"openRowResolver($event, context)\">\r\n <i class=\"feather-play fs24\"></i>\r\n </div>\r\n <span>{{ context.difference }}</span>\r\n </div>\r\n </ng-template>\r\n <ng-template #sourceAllowsNull let-context=\"context\">\r\n <core-checkbox [ngModel]=\"context.sourceAllowsNull\" [disabled]=\"true\"></core-checkbox>\r\n </ng-template>\r\n <ng-template #targetAllowsNull let-context=\"context\">\r\n <core-checkbox [ngModel]=\"context.targetAllowsNull\" [disabled]=\"true\"></core-checkbox>\r\n </ng-template>\r\n</div>", styles: [".core-compare-db-pipeline-container .h15{height:15px}.core-compare-db-pipeline-container .tools{height:36px}.core-compare-db-pipeline-container .tools .icon-wrapper{color:#848484;opacity:.5;display:inline-flex;width:36px;height:36px;border-radius:50%}.core-compare-db-pipeline-container .tools .icon-wrapper:hover{opacity:1;color:#fff;background-color:#848484}.core-compare-db-pipeline-container .modal-content-root{padding-top:0}.core-compare-db-pipeline-container .close-icon{display:block;position:absolute;top:8px;right:8px;color:#848484}.core-compare-db-pipeline-container .close-icon:hover{color:inherit}.core-compare-db-pipeline-container .row-resolver-window{display:block;width:992px;max-width:100vw!important;height:500px}.core-compare-db-pipeline-container .conflict-total{height:50px;display:flex;align-items:center;justify-content:flex-start;color:#848484;font-size:24px;font-weight:700}.core-compare-db-pipeline-container .conflict-total.error{color:brown}\n"] }]
|
|
25656
|
+
}], ctorParameters: () => [{ type: MultiLanguageService }, { type: AppService }], propDecorators: { toolBlock: [{
|
|
25657
|
+
type: ViewChild,
|
|
25658
|
+
args: ['toolBlock']
|
|
25659
|
+
}], sourceAllowsNull: [{
|
|
25660
|
+
type: ViewChild,
|
|
25661
|
+
args: ['sourceAllowsNull']
|
|
25662
|
+
}], targetAllowsNull: [{
|
|
25663
|
+
type: ViewChild,
|
|
25664
|
+
args: ['targetAllowsNull']
|
|
25665
|
+
}] } });
|
|
25577
25666
|
|
|
25578
25667
|
class CoreConfirmDialogComponent extends BaseComponent {
|
|
25579
25668
|
constructor(mls, dialogService, routingService) {
|