@colijnit/corecomponents_v12 259.1.13 → 259.1.15
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/bundles/colijnit-corecomponents_v12.umd.js +15 -2
- package/bundles/colijnit-corecomponents_v12.umd.js.map +1 -1
- package/colijnit-corecomponents_v12.metadata.json +1 -1
- package/esm2015/lib/components/double-calendar/double-calendar.component.js +13 -1
- package/esm2015/lib/components/simple-grid/simple-grid-cell.component.js +31 -31
- package/esm2015/lib/components/simple-grid/simple-grid.component.js +173 -172
- package/fesm2015/colijnit-corecomponents_v12.js +214 -201
- package/fesm2015/colijnit-corecomponents_v12.js.map +1 -1
- package/lib/components/card/style/_layout.scss +25 -2
- package/lib/components/double-calendar/double-calendar.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -26,6 +26,7 @@ export class DoubleCalendarComponent extends BaseInputDatePickerDirective {
|
|
|
26
26
|
}
|
|
27
27
|
}
|
|
28
28
|
this.outputRangeIfValid();
|
|
29
|
+
this._closeIfRangeComplete();
|
|
29
30
|
}
|
|
30
31
|
handleSecondDateSelected(date) {
|
|
31
32
|
this.selectedSecondDate = date;
|
|
@@ -41,6 +42,7 @@ export class DoubleCalendarComponent extends BaseInputDatePickerDirective {
|
|
|
41
42
|
this.outputRangeIfValid();
|
|
42
43
|
this.secondDateSelected.next();
|
|
43
44
|
}
|
|
45
|
+
this._closeIfRangeComplete();
|
|
44
46
|
}
|
|
45
47
|
outputRangeIfValid() {
|
|
46
48
|
if (this.selectedDates[0] instanceof Date && this.selectedDates[1] instanceof Date) {
|
|
@@ -57,6 +59,16 @@ export class DoubleCalendarComponent extends BaseInputDatePickerDirective {
|
|
|
57
59
|
// Emit updated state to parent
|
|
58
60
|
this.datesSelected.emit(this.selectedDates);
|
|
59
61
|
}
|
|
62
|
+
_closeIfRangeComplete() {
|
|
63
|
+
if (this.selectedFirstDate instanceof Date && this.selectedSecondDate instanceof Date) {
|
|
64
|
+
// emit the selected range (keeps current behavior)
|
|
65
|
+
this.outputRangeIfValid();
|
|
66
|
+
// optional: keep your “second date chosen” signal
|
|
67
|
+
this.secondDateSelected.next();
|
|
68
|
+
// close the overlay/popup
|
|
69
|
+
this.clickedOutside.emit();
|
|
70
|
+
}
|
|
71
|
+
}
|
|
60
72
|
}
|
|
61
73
|
DoubleCalendarComponent.decorators = [
|
|
62
74
|
{ type: Component, args: [{
|
|
@@ -97,4 +109,4 @@ DoubleCalendarComponent.propDecorators = {
|
|
|
97
109
|
clickedOutside: [{ type: Output }],
|
|
98
110
|
showClass: [{ type: HostBinding, args: ["class.co-double-calendar",] }]
|
|
99
111
|
};
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"double-calendar.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/double-calendar/double-calendar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  ViewEncapsulation\r\n} from \"@angular/core\";\r\nimport {BaseInputDatePickerDirective} from \"../base-input-date-picker/base-input-date-picker.directive\";\r\n\r\n@Component({\r\n  selector: \"co-double-calendar\",\r\n  template: `\r\n    <div class=\"dual-calendar-wrapper\" [overlay]=\"parentForOverlay\" (clickOutside)=\"clickedOutside.next()\">\r\n      <calendar-template\r\n        [selectedDate]=\"selectedFirstDate\"\r\n        [secondSelectedDate]=\"selectedSecondDate\"\r\n        [secondHoveringDate]=\"secondHoveringDate\"\r\n        [highlightDaysBetweenDates]=\"true\"\r\n        (dateSelected)=\"handleFirstDateSelected($event)\"\r\n        [showButtons]=\"false\"\r\n        (clearDates)=\"clearAllDates()\"\r\n        [doubleCalendar]=\"true\"\r\n      ></calendar-template>\r\n      <calendar-template\r\n        [selectedDate]=\"selectedSecondDate\"\r\n        [secondSelectedDate]=\"selectedFirstDate\"\r\n        [highlightDaysBetweenDates]=\"true\"\r\n        (hoveringDate)=\"handleSecondHoveringDate($event)\"\r\n        (dateSelected)=\"handleSecondDateSelected($event)\"\r\n        (clickedOutside)=\"clickedOutside.next()\"\r\n        [showButtons]=\"true\"\r\n        [doubleCalendar]=\"true\"\r\n        (clearDates)=\"clearAllDates()\"\r\n      ></calendar-template>\r\n    </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class DoubleCalendarComponent extends BaseInputDatePickerDirective implements OnInit {\r\n\r\n  @Input()\r\n  public selectedDates: Date[] = [null, null]; // Initialize with valid array elements\r\n\r\n  @Input()\r\n  public parentForOverlay: ElementRef;\r\n\r\n  @Output()\r\n  public datesSelected: EventEmitter<Date[]> = new EventEmitter<Date[]>();\r\n\r\n  @Output()\r\n  public secondDateSelected: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output()\r\n  public clickedOutside: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  public selectedFirstDate: Date;\r\n  public selectedSecondDate: Date;\r\n  public secondHoveringDate: Date;\r\n\r\n  @HostBinding(\"class.co-double-calendar\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    // Ensure `selectedDates` always has two elements\r\n    this.selectedDates = this.selectedDates || [null, null];\r\n    this.selectedFirstDate = this.selectedDates[0];\r\n    this.selectedSecondDate = this.selectedDates[1];\r\n  }\r\n\r\n  public handleFirstDateSelected(date: Date): void {\r\n    this.selectedFirstDate = date;\r\n    this.selectedDates[0] = date;\r\n\r\n    if (this.selectedSecondDate && this.selectedFirstDate) {\r\n      if (this.selectedFirstDate.getTime() > this.selectedSecondDate.getTime()) {\r\n        this.selectedSecondDate = null;\r\n      }\r\n    }\r\n\r\n    this.outputRangeIfValid();\r\n    this._closeIfRangeComplete();\r\n  }\r\n\r\n\r\n  public handleSecondDateSelected(date: Date): void {\r\n    this.selectedSecondDate = date;\r\n    this.selectedDates[1] = date;\r\n\r\n    if (this.selectedFirstDate && this.selectedSecondDate) {\r\n      if (this.selectedSecondDate.getTime() < this.selectedFirstDate.getTime()) {\r\n        this.selectedFirstDate = null;\r\n        this.selectedSecondDate = null;\r\n        this.secondHoveringDate = null;\r\n      }\r\n    }\r\n\r\n    if (this.selectedSecondDate && this.selectedFirstDate) {\r\n      this.outputRangeIfValid();\r\n      this.secondDateSelected.next();\r\n    }\r\n    this._closeIfRangeComplete();\r\n  }\r\n\r\n\r\n  public outputRangeIfValid(): void {\r\n    if (this.selectedDates[0] instanceof Date && this.selectedDates[1] instanceof Date) {\r\n      this.datesSelected.next(this.selectedDates);\r\n    }\r\n  }\r\n\r\n  public handleSecondHoveringDate(day: Date): void {\r\n    this.secondHoveringDate = day;\r\n  }\r\n  public clearAllDates(): void {\r\n    this.selectedFirstDate = null;\r\n    this.selectedSecondDate = null;\r\n    this.selectedDates = [null, null];\r\n\r\n    // Emit updated state to parent\r\n    this.datesSelected.emit(this.selectedDates);\r\n  }\r\n  private _closeIfRangeComplete(): void {\r\n    if (this.selectedFirstDate instanceof Date && this.selectedSecondDate instanceof Date) {\r\n      // emit the selected range (keeps current behavior)\r\n      this.outputRangeIfValid();\r\n      // optional: keep your “second date chosen” signal\r\n      this.secondDateSelected.next();\r\n      // close the overlay/popup\r\n      this.clickedOutside.emit();\r\n    }\r\n  }\r\n\r\n}\r\n\r\n"]}
|
|
@@ -120,36 +120,36 @@ export class SimpleGridCellComponent {
|
|
|
120
120
|
SimpleGridCellComponent.decorators = [
|
|
121
121
|
{ type: Component, args: [{
|
|
122
122
|
selector: "co-simple-grid-cell",
|
|
123
|
-
template: `
|
|
124
|
-
<div class="simple-grid-column-cell-value" [ngClass]="column.textAlign ? column.textAlign : defaultTextAlign">
|
|
125
|
-
<ng-container *ngIf="editMode; else noInlineEdit">
|
|
126
|
-
<div class="simple-grid-column-cell-field">
|
|
127
|
-
<ng-container #editTemplate *ngIf="column.editTemplate; else noEditTemplate"
|
|
128
|
-
[ngTemplateOutlet]="column.editTemplate"
|
|
129
|
-
[ngTemplateOutletContext]="{value: row[column.field], row: row}"></ng-container>
|
|
130
|
-
<ng-template #noEditTemplate>
|
|
131
|
-
<ng-container *ngIf="column.template; else noTemplate">
|
|
132
|
-
<ng-container [ngTemplateOutlet]="column.template"
|
|
133
|
-
[ngTemplateOutletContext]="{value: row[column.field], row: row}"></ng-container>
|
|
134
|
-
</ng-container>
|
|
135
|
-
<ng-template #noTemplate>
|
|
136
|
-
<co-input-text [(model)]="row[column.field]" [required]="column.required"></co-input-text>
|
|
137
|
-
</ng-template>
|
|
138
|
-
</ng-template>
|
|
139
|
-
</div>
|
|
140
|
-
</ng-container>
|
|
141
|
-
<ng-template #noInlineEdit>
|
|
142
|
-
<div class="simple-grid-column-cell-field">
|
|
143
|
-
<ng-container *ngIf="column.template; else noTemplate">
|
|
144
|
-
<ng-container [ngTemplateOutlet]="column.template"
|
|
145
|
-
[ngTemplateOutletContext]="{value: row[column.field], row: row}"></ng-container>
|
|
146
|
-
</ng-container>
|
|
147
|
-
<ng-template #noTemplate>
|
|
148
|
-
<span [textContent]="column.getFieldValue(row[column.field])"></span>
|
|
149
|
-
</ng-template>
|
|
150
|
-
</div>
|
|
151
|
-
</ng-template>
|
|
152
|
-
</div>
|
|
123
|
+
template: `
|
|
124
|
+
<div class="simple-grid-column-cell-value" [ngClass]="column.textAlign ? column.textAlign : defaultTextAlign">
|
|
125
|
+
<ng-container *ngIf="editMode; else noInlineEdit">
|
|
126
|
+
<div class="simple-grid-column-cell-field">
|
|
127
|
+
<ng-container #editTemplate *ngIf="column.editTemplate; else noEditTemplate"
|
|
128
|
+
[ngTemplateOutlet]="column.editTemplate"
|
|
129
|
+
[ngTemplateOutletContext]="{value: row[column.field], row: row}"></ng-container>
|
|
130
|
+
<ng-template #noEditTemplate>
|
|
131
|
+
<ng-container *ngIf="column.template; else noTemplate">
|
|
132
|
+
<ng-container [ngTemplateOutlet]="column.template"
|
|
133
|
+
[ngTemplateOutletContext]="{value: row[column.field], row: row}"></ng-container>
|
|
134
|
+
</ng-container>
|
|
135
|
+
<ng-template #noTemplate>
|
|
136
|
+
<co-input-text [(model)]="row[column.field]" [required]="column.required"></co-input-text>
|
|
137
|
+
</ng-template>
|
|
138
|
+
</ng-template>
|
|
139
|
+
</div>
|
|
140
|
+
</ng-container>
|
|
141
|
+
<ng-template #noInlineEdit>
|
|
142
|
+
<div class="simple-grid-column-cell-field">
|
|
143
|
+
<ng-container *ngIf="column.template; else noTemplate">
|
|
144
|
+
<ng-container [ngTemplateOutlet]="column.template"
|
|
145
|
+
[ngTemplateOutletContext]="{value: row[column.field], row: row}"></ng-container>
|
|
146
|
+
</ng-container>
|
|
147
|
+
<ng-template #noTemplate>
|
|
148
|
+
<span [textContent]="column.getFieldValue(row[column.field])" [title]="row[column.field]"></span>
|
|
149
|
+
</ng-template>
|
|
150
|
+
</div>
|
|
151
|
+
</ng-template>
|
|
152
|
+
</div>
|
|
153
153
|
`,
|
|
154
154
|
encapsulation: ViewEncapsulation.None
|
|
155
155
|
},] }
|
|
@@ -169,4 +169,4 @@ SimpleGridCellComponent.propDecorators = {
|
|
|
169
169
|
showClass: [{ type: HostBinding, args: ["class.co-simple-grid-cell",] }],
|
|
170
170
|
handleClick: [{ type: HostListener, args: ['click', ['$event'],] }]
|
|
171
171
|
};
|
|
172
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"simple-grid-cell.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/simple-grid/simple-grid-cell.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,WAAW,EACX,YAAY,EACZ,KAAK,EACL,MAAM,EAEN,SAAS,EACT,iBAAiB,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,WAAW,EAA6B,MAAM,gCAAgC,CAAC;AACxF,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAqClE,MAAM,OAAO,uBAAuB;IAsElC,YAAoB,eAAkC;QAAlC,oBAAe,GAAf,eAAe,CAAmB;QA9DtC,qBAAgB,GAAgB,WAAW,CAAC,IAAI,CAAC;QA6BzD,cAAS,GAAY,KAAK,CAAC;QAa5B,cAAS,GAA6B,IAAI,YAAY,EAAc,CAAC;QAcpE,mBAAc,GAAY,KAAK,CAAC;QAChC,aAAQ,GAAY,KAAK,CAAC;IAMlC,CAAC;IAtED,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IACD,IACI,QAAQ,CAAC,KAAc;QACzB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IAGD,IAA2D,mBAAmB,CAAC,QAAQ;QACrF,IAAI,QAAQ,EAAE;YACZ,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC;YAC9B,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAC3B;IACH,CAAC;IAED,IAAiC,qBAAqB,CAAC,QAAQ;QAC7D,IAAI,QAAQ,EAAE;YACZ,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;YAC1B,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAC3B;IACH,CAAC;IAED,IAA6B,iBAAiB,CAAC,QAAQ;QACrD,IAAI,QAAQ,EAAE;YACZ,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC;YAC/B,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAC3B;IACH,CAAC;IAUD,IACW,aAAa,CAAC,KAAc;QACrC,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAC5B,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAED,IAAW,aAAa;QACtB,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IAMM,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAGM,WAAW,CAAC,KAAiB;QAClC,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE;YACxC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;SACvB;IACH,CAAC;IAWO,kBAAkB;QACxB,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,aAAa,EAAE;YACxC,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;YACnC,IAAI,OAAO,EAAE;gBACX,MAAM,UAAU,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;gBAC1D,OAAO,CAAC,KAAK,EAAE,CAAC;gBAChB,OAAO,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;gBAClC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;aACtB;SACF;aAAM;YACL,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;gBACnC,IAAI,OAAO,EAAE;oBACX,MAAM,SAAS,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;oBACxD,OAAO,CAAC,IAAI,EAAE,CAAC;oBACf,OAAO,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;iBAClC;gBACD,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;aACvB;SACF;QACD,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEO,kBAAkB,CAAC,MAAW;QACpC,IAAI,MAAM,EAAE;YACV,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC,CAAC;YACpE,MAAM,eAAe,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,oBAAoB,CAAC,UAAU,CAAC,CAAC,CAAC;YAC5E,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;YAC7C,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE;gBACzB,OAAO,UAAU,CAAC,CAAC,CAAC,CAAC;aACtB;SACF;IACH,CAAC;IAEO,eAAe,CAAC,OAAY,EAAE,SAAiB;QACrD,IAAI,KAAK,CAAC;QACV,IAAI,aAAa,IAAI,QAAQ,EAAE;YAC7B,KAAK,GAAG,QAAQ,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YACtC,KAAK,CAAC,SAAS,CAAC,SAAS,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;SACxC;aAAM,IAAI,OAAO,IAAI,MAAM,EAAE;YAC5B,KAAK,GAAG,IAAI,KAAK,CAAC,SAAS,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC,CAAC;SACnE;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAEO,WAAW;QACjB,IAAI,KAAuB,CAAC;QAC5B,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC;SAC5B;aAAM,IAAI,IAAI,CAAC,SAAS,EAAE;YACzB,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC;SACxB;aAAM;YACL,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC;SAC7B;QACD,IAAI,KAAK,EAAE;YACT,IAAI,KAAK,IAAI,KAAK,CAAC,UAAU,EAAE;gBAC7B,MAAM,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC;gBAC3F,IAAI,YAAY,EAAE;oBAChB,OAAO,YAAY,CAAC;iBACrB;aACF;SACF;IACH,CAAC;IAEO,cAAc;QACpB,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;IACvC,CAAC;;;YA9KF,SAAS,SAAC;gBACT,QAAQ,EAAE,qBAAqB;gBAC/B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8BT;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;YAhDC,iBAAiB;;;uBAqDhB,KAAK;kCAML,SAAS,SAAC,cAAc,EAAE,EAAC,IAAI,EAAE,kBAAkB,EAAC;oCAOpD,SAAS,SAAC,gBAAgB;gCAO1B,SAAS,SAAC,YAAY;qBAOtB,KAAK;kBAGL,KAAK;4BAKL,KAAK;wBAUL,MAAM;wBAGN,WAAW,SAAC,2BAA2B;0BAKvC,YAAY,SAAC,OAAO,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  HostBinding,\r\n  HostListener,\r\n  Input, OnChanges,\r\n  Output, SimpleChanges,\r\n  TemplateRef,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport { ColumnAlign, SimpleGridColumnDirective } from \"./simple-grid-column.directive\";\r\nimport { BaseInputComponent } from \"../base/base-input.component\";\r\n\r\n@Component({\r\n  selector: \"co-simple-grid-cell\",\r\n  template: `\r\n      <div class=\"simple-grid-column-cell-value\" [ngClass]=\"column.textAlign ? column.textAlign : defaultTextAlign\">\r\n          <ng-container *ngIf=\"editMode; else noInlineEdit\">\r\n              <div class=\"simple-grid-column-cell-field\">\r\n                <ng-container #editTemplate *ngIf=\"column.editTemplate; else noEditTemplate\"\r\n                              [ngTemplateOutlet]=\"column.editTemplate\"\r\n                              [ngTemplateOutletContext]=\"{value: row[column.field], row: row}\"></ng-container>\r\n                <ng-template #noEditTemplate>\r\n                    <ng-container *ngIf=\"column.template; else noTemplate\">\r\n                        <ng-container [ngTemplateOutlet]=\"column.template\"\r\n                                      [ngTemplateOutletContext]=\"{value: row[column.field], row: row}\"></ng-container>\r\n                    </ng-container>\r\n                    <ng-template #noTemplate>\r\n                        <co-input-text [(model)]=\"row[column.field]\" [required]=\"column.required\"></co-input-text>\r\n                    </ng-template>\r\n                </ng-template>\r\n              </div>\r\n          </ng-container>\r\n          <ng-template #noInlineEdit>\r\n              <div class=\"simple-grid-column-cell-field\">\r\n                <ng-container *ngIf=\"column.template; else noTemplate\">\r\n                    <ng-container [ngTemplateOutlet]=\"column.template\"\r\n                                  [ngTemplateOutletContext]=\"{value: row[column.field], row: row}\"></ng-container>\r\n                </ng-container>\r\n                <ng-template #noTemplate>\r\n                    <span [textContent]=\"column.getFieldValue(row[column.field])\"></span>\r\n                </ng-template>\r\n              </div>\r\n          </ng-template>\r\n      </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class SimpleGridCellComponent {\r\n  get editMode(): boolean {\r\n    return this._editMode;\r\n  }\r\n  @Input()\r\n  set editMode(value: boolean) {\r\n    this._editMode = value;\r\n  }\r\n  public readonly defaultTextAlign: ColumnAlign = ColumnAlign.Left;\r\n\r\n  @ViewChild(\"editTemplate\", {read: BaseInputComponent}) set editTemplateContent(template) {\r\n    if (template) {\r\n      this._editTemplate = template;\r\n      this._setFocusComponent();\r\n    }\r\n  }\r\n\r\n  @ViewChild(\"noEditTemplate\") set noEditTemplateContent(template) {\r\n    if (template) {\r\n      this._template = template;\r\n      this._setFocusComponent();\r\n    }\r\n  }\r\n\r\n  @ViewChild(\"noTemplate\") set noTemplateContent(template) {\r\n    if (template) {\r\n      this._inputTemplate = template;\r\n      this._setFocusComponent();\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public column: SimpleGridColumnDirective;\r\n\r\n  @Input()\r\n  public row: {};\r\n\r\n  private _editMode: boolean = false;\r\n\r\n  @Input()\r\n  public set fieldEditMode(value: boolean) {\r\n    this._fieldEditMode = value;\r\n    this._setFocusComponent();\r\n  }\r\n\r\n  public get fieldEditMode(): boolean {\r\n    return this._fieldEditMode;\r\n  }\r\n\r\n  @Output()\r\n  public cellClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @HostBinding(\"class.co-simple-grid-cell\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  @HostListener('click', ['$event'])\r\n  public handleClick(event: MouseEvent): void {\r\n    if (this.column && !this.column.readonly) {\r\n      this.cellClick.next();\r\n    }\r\n  }\r\n\r\n  private _fieldEditMode: boolean = false;\r\n  private _focused: boolean = false;\r\n  private _editTemplate: TemplateRef<any>;\r\n  private _template: TemplateRef<any>;\r\n  private _inputTemplate: TemplateRef<any>;\r\n\r\n  constructor(private _changeDetector: ChangeDetectorRef) {\r\n  }\r\n\r\n  private _setFocusComponent(): void {\r\n    if (this._editMode && this.fieldEditMode) {\r\n      const element = this._getElement();\r\n      if (element) {\r\n        const focusEvent = this._createNewEvent(element, 'focus');\r\n        element.focus();\r\n        element.dispatchEvent(focusEvent);\r\n        this._focused = true;\r\n      }\r\n    } else {\r\n      if (this._focused) {\r\n        const element = this._getElement();\r\n        if (element) {\r\n          const blurEvent = this._createNewEvent(element, 'blur');\r\n          element.blur();\r\n          element.dispatchEvent(blurEvent);\r\n        }\r\n        this._focused = false;\r\n      }\r\n    }\r\n    this._detectChanges();\r\n  }\r\n\r\n  private _getFirstFormInput(parent: any): any {\r\n    if (parent) {\r\n      const collection = Array.from(parent.getElementsByTagName('input'));\r\n      const otherCollection = Array.from(parent.getElementsByTagName('textarea'));\r\n      otherCollection.map(o => collection.push(o));\r\n      if (collection.length > 0) {\r\n        return collection[0];\r\n      }\r\n    }\r\n  }\r\n\r\n  private _createNewEvent(element: any, eventType: string): Event {\r\n    let event;\r\n    if (\"createEvent\" in document) {\r\n      event = document.createEvent(\"Event\");\r\n      event.initEvent(eventType, true, true);\r\n    } else if (\"Event\" in window) {\r\n      event = new Event(eventType, { bubbles: true, cancelable: true });\r\n    }\r\n    return event;\r\n  }\r\n\r\n  private _getElement(): HTMLElement {\r\n    let templ: TemplateRef<any>;\r\n    if (this._editTemplate) {\r\n      templ = this._editTemplate;\r\n    } else if (this._template) {\r\n      templ = this._template;\r\n    } else {\r\n      templ = this._inputTemplate;\r\n    }\r\n    if (templ) {\r\n      if (templ && templ.elementRef) {\r\n        const inputElement = this._getFirstFormInput(templ.elementRef.nativeElement.parentElement);\r\n        if (inputElement) {\r\n          return inputElement;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private _detectChanges(): void {\r\n    this._changeDetector.detectChanges();\r\n  }\r\n}\r\n"]}
|
|
172
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"simple-grid-cell.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/simple-grid/simple-grid-cell.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  HostBinding,\n  HostListener,\n  Input, OnChanges,\n  Output, SimpleChanges,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { ColumnAlign, SimpleGridColumnDirective } from \"./simple-grid-column.directive\";\nimport { BaseInputComponent } from \"../base/base-input.component\";\n\n@Component({\n  selector: \"co-simple-grid-cell\",\n  template: `\n      <div class=\"simple-grid-column-cell-value\" [ngClass]=\"column.textAlign ? column.textAlign : defaultTextAlign\">\n          <ng-container *ngIf=\"editMode; else noInlineEdit\">\n              <div class=\"simple-grid-column-cell-field\">\n                <ng-container #editTemplate *ngIf=\"column.editTemplate; else noEditTemplate\"\n                              [ngTemplateOutlet]=\"column.editTemplate\"\n                              [ngTemplateOutletContext]=\"{value: row[column.field], row: row}\"></ng-container>\n                <ng-template #noEditTemplate>\n                    <ng-container *ngIf=\"column.template; else noTemplate\">\n                        <ng-container [ngTemplateOutlet]=\"column.template\"\n                                      [ngTemplateOutletContext]=\"{value: row[column.field], row: row}\"></ng-container>\n                    </ng-container>\n                    <ng-template #noTemplate>\n                        <co-input-text [(model)]=\"row[column.field]\" [required]=\"column.required\"></co-input-text>\n                    </ng-template>\n                </ng-template>\n              </div>\n          </ng-container>\n          <ng-template #noInlineEdit>\n              <div class=\"simple-grid-column-cell-field\">\n                <ng-container *ngIf=\"column.template; else noTemplate\">\n                    <ng-container [ngTemplateOutlet]=\"column.template\"\n                                  [ngTemplateOutletContext]=\"{value: row[column.field], row: row}\"></ng-container>\n                </ng-container>\n                <ng-template #noTemplate>\n                    <span [textContent]=\"column.getFieldValue(row[column.field])\"  [title]=\"row[column.field]\"></span>\n                </ng-template>\n              </div>\n          </ng-template>\n      </div>\n  `,\n  encapsulation: ViewEncapsulation.None\n})\nexport class SimpleGridCellComponent {\n  get editMode(): boolean {\n    return this._editMode;\n  }\n  @Input()\n  set editMode(value: boolean) {\n    this._editMode = value;\n  }\n  public readonly defaultTextAlign: ColumnAlign = ColumnAlign.Left;\n\n  @ViewChild(\"editTemplate\", {read: BaseInputComponent}) set editTemplateContent(template) {\n    if (template) {\n      this._editTemplate = template;\n      this._setFocusComponent();\n    }\n  }\n\n  @ViewChild(\"noEditTemplate\") set noEditTemplateContent(template) {\n    if (template) {\n      this._template = template;\n      this._setFocusComponent();\n    }\n  }\n\n  @ViewChild(\"noTemplate\") set noTemplateContent(template) {\n    if (template) {\n      this._inputTemplate = template;\n      this._setFocusComponent();\n    }\n  }\n\n  @Input()\n  public column: SimpleGridColumnDirective;\n\n  @Input()\n  public row: {};\n\n  private _editMode: boolean = false;\n\n  @Input()\n  public set fieldEditMode(value: boolean) {\n    this._fieldEditMode = value;\n    this._setFocusComponent();\n  }\n\n  public get fieldEditMode(): boolean {\n    return this._fieldEditMode;\n  }\n\n  @Output()\n  public cellClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n\n  @HostBinding(\"class.co-simple-grid-cell\")\n  public showClass(): boolean {\n    return true;\n  }\n\n  @HostListener('click', ['$event'])\n  public handleClick(event: MouseEvent): void {\n    if (this.column && !this.column.readonly) {\n      this.cellClick.next();\n    }\n  }\n\n  private _fieldEditMode: boolean = false;\n  private _focused: boolean = false;\n  private _editTemplate: TemplateRef<any>;\n  private _template: TemplateRef<any>;\n  private _inputTemplate: TemplateRef<any>;\n\n  constructor(private _changeDetector: ChangeDetectorRef) {\n  }\n\n  private _setFocusComponent(): void {\n    if (this._editMode && this.fieldEditMode) {\n      const element = this._getElement();\n      if (element) {\n        const focusEvent = this._createNewEvent(element, 'focus');\n        element.focus();\n        element.dispatchEvent(focusEvent);\n        this._focused = true;\n      }\n    } else {\n      if (this._focused) {\n        const element = this._getElement();\n        if (element) {\n          const blurEvent = this._createNewEvent(element, 'blur');\n          element.blur();\n          element.dispatchEvent(blurEvent);\n        }\n        this._focused = false;\n      }\n    }\n    this._detectChanges();\n  }\n\n  private _getFirstFormInput(parent: any): any {\n    if (parent) {\n      const collection = Array.from(parent.getElementsByTagName('input'));\n      const otherCollection = Array.from(parent.getElementsByTagName('textarea'));\n      otherCollection.map(o => collection.push(o));\n      if (collection.length > 0) {\n        return collection[0];\n      }\n    }\n  }\n\n  private _createNewEvent(element: any, eventType: string): Event {\n    let event;\n    if (\"createEvent\" in document) {\n      event = document.createEvent(\"Event\");\n      event.initEvent(eventType, true, true);\n    } else if (\"Event\" in window) {\n      event = new Event(eventType, { bubbles: true, cancelable: true });\n    }\n    return event;\n  }\n\n  private _getElement(): HTMLElement {\n    let templ: TemplateRef<any>;\n    if (this._editTemplate) {\n      templ = this._editTemplate;\n    } else if (this._template) {\n      templ = this._template;\n    } else {\n      templ = this._inputTemplate;\n    }\n    if (templ) {\n      if (templ && templ.elementRef) {\n        const inputElement = this._getFirstFormInput(templ.elementRef.nativeElement.parentElement);\n        if (inputElement) {\n          return inputElement;\n        }\n      }\n    }\n  }\n\n  private _detectChanges(): void {\n    this._changeDetector.detectChanges();\n  }\n}\n"]}
|