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.
@@ -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: 'sourceDb',
31
+ field: 'sourceAlias',
28
32
  type: 'string',
29
- caption: 'DB nguồn',
33
+ caption: 'Nguồn',
30
34
  align: 'left',
31
35
  sortDisabled: true,
32
- width: 160
36
+ width: 60
33
37
  },
34
38
  {
35
- field: 'targetDb',
39
+ field: 'targetAlias',
36
40
  type: 'string',
37
- caption: 'DB đích',
41
+ caption: 'Đích',
38
42
  align: 'left',
39
43
  sortDisabled: true,
40
- width: 160
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: 'targetType',
68
- type: 'string',
69
- caption: 'Kiểu đích',
70
- align: 'left',
71
+ field: 'sourceAllowsNull',
72
+ type: 'boolean',
73
+ caption: 'Source nullablity',
74
+ align: 'center',
71
75
  sortDisabled: true,
72
- width: 100
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: "14.0.0", version: "19.0.1", type: CoreCompareDbPipelineComponent, isStandalone: true, selector: "core-compare-db-pipeline", usesInheritance: true, ngImport: i0, template: "<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-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>", styles: [".core-compare-db-pipeline-container{position:fixed;display:block;z-index:9999999999;left:0;top:60px;width:100vw;height:calc(100vh - 60px)}.core-compare-db-pipeline-container .h15{height:15px}\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"] }] }); }
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
- ], template: "<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-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>", styles: [".core-compare-db-pipeline-container{position:fixed;display:block;z-index:9999999999;left:0;top:60px;width:100vw;height:calc(100vh - 60px)}.core-compare-db-pipeline-container .h15{height:15px}\n"] }]
144
- }], ctorParameters: () => [{ type: i1.MultiLanguageService }, { type: i2.AppService }] });
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":"AAAA,OAAO,EAAiB,SAAS,EAAE,MAAM,eAAe,CAAC;AAGzD,OAAO,EAAE,aAAa,EAAE,MAAM,uCAAuC,CAAC;AACtE,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AAExE,OAAO,EAAE,uBAAuB,EAAE,MAAM,iEAAiE,CAAC;AAC1G,OAAO,EAAE,eAAe,EAAE,oBAAoB,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAC7E,OAAO,EAAE,uBAAuB,EAAE,MAAM,8DAA8D,CAAC;AACvG,OAAO,EAAE,2BAA2B,EAAE,MAAM,gFAAgF,CAAC;;;;AAwB7H,MAAM,OAAO,8BAA+B,SAAQ,aAAa;IAwG/D,YACkB,GAAyB,EACjC,UAAsB;QAE9B,KAAK,CAAC,GAAG,CAAC,CAAC;QAHK,QAAG,GAAH,GAAG,CAAsB;QACjC,eAAU,GAAV,UAAU,CAAY;QAxGhC,SAAI,GAAU,EAAE,CAAC;QAEjB,YAAO,GAA2B;YAChC;gBACE,KAAK,EAAE,IAAI;gBACX,IAAI,EAAE,QAAQ;gBACd,OAAO,EAAE,IAAI;gBACb,KAAK,EAAE,MAAM;gBACb,MAAM,EAAE,IAAI;gBACZ,KAAK,EAAE,CAAC;aACT;YACD;gBACE,KAAK,EAAE,UAAU;gBACjB,IAAI,EAAE,QAAQ;gBACd,OAAO,EAAE,UAAU;gBACnB,KAAK,EAAE,MAAM;gBACb,YAAY,EAAE,IAAI;gBAClB,KAAK,EAAE,GAAG;aACX;YACD;gBACE,KAAK,EAAE,UAAU;gBACjB,IAAI,EAAE,QAAQ;gBACd,OAAO,EAAE,SAAS;gBAClB,KAAK,EAAE,MAAM;gBACb,YAAY,EAAE,IAAI;gBAClB,KAAK,EAAE,GAAG;aACX;YACD;gBACE,KAAK,EAAE,WAAW;gBAClB,IAAI,EAAE,QAAQ;gBACd,OAAO,EAAE,MAAM;gBACf,KAAK,EAAE,MAAM;gBACb,YAAY,EAAE,IAAI;gBAClB,KAAK,EAAE,GAAG;aACX;YACD;gBACE,KAAK,EAAE,YAAY;gBACnB,IAAI,EAAE,QAAQ;gBACd,OAAO,EAAE,KAAK;gBACd,KAAK,EAAE,MAAM;gBACb,YAAY,EAAE,IAAI;gBAClB,KAAK,EAAE,GAAG;aACX;YACD;gBACE,KAAK,EAAE,YAAY;gBACnB,IAAI,EAAE,QAAQ;gBACd,OAAO,EAAE,YAAY;gBACrB,KAAK,EAAE,MAAM;gBACb,YAAY,EAAE,IAAI;gBAClB,KAAK,EAAE,GAAG;aACX;YACD;gBACE,KAAK,EAAE,YAAY;gBACnB,IAAI,EAAE,QAAQ;gBACd,OAAO,EAAE,WAAW;gBACpB,KAAK,EAAE,MAAM;gBACb,YAAY,EAAE,IAAI;gBAClB,KAAK,EAAE,GAAG;aACX;YACD;gBACE,KAAK,EAAE,YAAY;gBACnB,IAAI,EAAE,QAAQ;gBACd,OAAO,EAAE,UAAU;gBACnB,KAAK,EAAE,OAAO;gBACd,YAAY,EAAE,IAAI;gBAClB,KAAK,EAAE,GAAG;aACX;YACD;gBACE,KAAK,EAAE,YAAY;gBACnB,IAAI,EAAE,QAAQ;gBACd,OAAO,EAAE,SAAS;gBAClB,KAAK,EAAE,OAAO;gBACd,YAAY,EAAE,IAAI;gBAClB,KAAK,EAAE,GAAG;aACX;YACD;gBACE,KAAK,EAAE,YAAY;gBACnB,IAAI,EAAE,QAAQ;gBACd,OAAO,EAAE,WAAW;gBACpB,KAAK,EAAE,MAAM;gBACb,YAAY,EAAE,IAAI;gBAClB,KAAK,EAAE,GAAG;aACX;SACF,CAAA;QAED,gBAAW,GAAW,GAAG,CAAC;QAE1B,YAAO,GAAY,KAAK,CAAC;QAEzB,mBAAc,GAA+B;YAC3C,UAAU,EAAE,CAAC;YACb,QAAQ,EAAE,EAAE;SACb,CAAA;QAED,aAAQ,GAAG,IAAI,eAAe,CAA6B,IAAI,CAAC,cAAc,CAAC,CAAC;QAEhF,iBAAY,GAAG,IAAI,eAAe,CAAS,CAAC,CAAC,CAAC;QAC9C,cAAS,GAAG,IAAI,eAAe,CAAS,EAAE,CAAC,CAAC;QAC5C,cAAS,GAAW,CAAC,CAAC;QAEtB,oCAA+B,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;IAOtE,CAAC;IAED,eAAe;QACb,UAAU,CAAC,GAAG,EAAE;YAEd,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,WAAW,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;YAE1D,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAChB,oBAAoB,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,EAC/E,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,EAC9B,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,2CAA2C,EAAE,CAAC,CAAC,CAAC,CACrF,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;gBACd,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;gBACrB,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,IAAI,EAAE,UAAU,KAAK,GAAG,EAAE,CAAC;oBAC3D,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAA;oBACjC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;oBAC1E,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;gBACtD,CAAC;YACH,CAAC,CAAC,CACH,CAAA;YAED,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;gBAC9B,MAAM,UAAU,GAA+B;oBAC7C,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK;oBACtB,UAAU,EAAE,CAAC;iBACd,CAAA;gBACD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,CAAA;YAC5D,CAAC,CAAC,CACH,CAAA;QAEH,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,WAAW,CAAC,CAAM;IAElB,CAAC;8GAlJU,8BAA8B;kGAA9B,8BAA8B,2GCjC3C,u3BAac,2PDaN,uBAAuB,6JACvB,kBAAkB,qyBAClB,uBAAuB;;2FAKlB,8BAA8B;kBAX1C,SAAS;+BACI,0BAA0B,WAC3B;wBACL,2BAA2B;wBAC3B,uBAAuB;wBACvB,kBAAkB;wBAClB,uBAAuB;qBAC1B","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: 'sourceDb',
25459
+ field: 'sourceAlias',
25460
25460
  type: 'string',
25461
- caption: 'DB nguồn',
25461
+ caption: 'Nguồn',
25462
25462
  align: 'left',
25463
25463
  sortDisabled: true,
25464
- width: 160
25464
+ width: 60
25465
25465
  },
25466
25466
  {
25467
- field: 'targetDb',
25467
+ field: 'targetAlias',
25468
25468
  type: 'string',
25469
- caption: 'DB đích',
25469
+ caption: 'Đích',
25470
25470
  align: 'left',
25471
25471
  sortDisabled: true,
25472
- width: 160
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: 'targetType',
25500
- type: 'string',
25501
- caption: 'Kiểu đích',
25502
- align: 'left',
25499
+ field: 'sourceAllowsNull',
25500
+ type: 'boolean',
25501
+ caption: 'Source nullablity',
25502
+ align: 'center',
25503
25503
  sortDisabled: true,
25504
- width: 100
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: "14.0.0", version: "19.0.1", type: CoreCompareDbPipelineComponent, isStandalone: true, selector: "core-compare-db-pipeline", usesInheritance: true, ngImport: i0, template: "<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-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>", styles: [".core-compare-db-pipeline-container{position:fixed;display:block;z-index:9999999999;left:0;top:60px;width:100vw;height:calc(100vh - 60px)}.core-compare-db-pipeline-container .h15{height:15px}\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"] }] }); }
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
- ], template: "<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-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>", styles: [".core-compare-db-pipeline-container{position:fixed;display:block;z-index:9999999999;left:0;top:60px;width:100vw;height:calc(100vh - 60px)}.core-compare-db-pipeline-container .h15{height:15px}\n"] }]
25576
- }], ctorParameters: () => [{ type: MultiLanguageService }, { type: AppService }] });
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) {