ecabs-components 0.0.59 → 0.0.61

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (172) hide show
  1. package/assets/images/nothing-here.svg +22 -0
  2. package/esm2020/lib/base/directives/digits-only.directive.mjs +2 -2
  3. package/esm2020/lib/ecabs-checkbox-toggle/ecabs-checkbox-toggle.component.mjs +9 -5
  4. package/esm2020/lib/ecabs-expansion-panel/ecabs-expansion-panel.component.mjs +1 -1
  5. package/esm2020/lib/ecabs-increment/ecabs-increment.component.mjs +2 -2
  6. package/esm2020/lib/ecabs-picker-header/ecabs-picker-header.component.mjs +2 -2
  7. package/fesm2015/ecabs-components.mjs +14 -10
  8. package/fesm2015/ecabs-components.mjs.map +1 -1
  9. package/fesm2020/ecabs-components.mjs +14 -10
  10. package/fesm2020/ecabs-components.mjs.map +1 -1
  11. package/lib/base/consts/date-mask.consts.ts +70 -0
  12. package/lib/base/directives/date-mask.directive.module.ts +15 -0
  13. package/lib/base/directives/date-mask.directive.ts +58 -0
  14. package/lib/base/directives/digits-only.directive.module.ts +15 -0
  15. package/lib/base/directives/digits-only.directive.ts +129 -0
  16. package/lib/base/directives/number-border.directive.module.ts +14 -0
  17. package/lib/base/directives/number-border.directive.ts +57 -0
  18. package/lib/base/element-base.ts +72 -0
  19. package/lib/base/element-wrapper/element-wrapper.component.html +30 -0
  20. package/lib/base/element-wrapper/element-wrapper.component.ts +33 -0
  21. package/lib/base/element-wrapper/element-wrapper.module.ts +30 -0
  22. package/lib/base/hint/hint.component.html +1 -0
  23. package/lib/base/hint/hint.component.scss +0 -0
  24. package/lib/base/hint/hint.component.ts +12 -0
  25. package/lib/base/hint/hint.module.ts +13 -0
  26. package/lib/base/validation/validation.component.html +8 -0
  27. package/lib/base/validation/validation.component.scss +0 -0
  28. package/lib/base/validation/validation.component.ts +84 -0
  29. package/lib/base/validation/validation.module.ts +12 -0
  30. package/lib/ecabs-active-status-filter/ecabs-active-status-filter.component.html +14 -0
  31. package/lib/ecabs-active-status-filter/ecabs-active-status-filter.component.scss +16 -0
  32. package/lib/ecabs-active-status-filter/ecabs-active-status-filter.component.ts +23 -0
  33. package/lib/ecabs-active-status-filter/ecabs-active-status-filter.module.ts +13 -0
  34. package/lib/ecabs-breadcrumb/ecabs-breadcrumb.component.html +11 -0
  35. package/lib/ecabs-breadcrumb/ecabs-breadcrumb.component.scss +0 -0
  36. package/lib/ecabs-breadcrumb/ecabs-breadcrumb.component.spec.ts +24 -0
  37. package/lib/ecabs-breadcrumb/ecabs-breadcrumb.component.ts +12 -0
  38. package/lib/ecabs-breadcrumb/ecabs-breadcrumb.module.ts +12 -0
  39. package/lib/ecabs-buttons/ecabs-buttons.component.html +18 -0
  40. package/lib/ecabs-buttons/ecabs-buttons.component.ts +54 -0
  41. package/lib/ecabs-buttons/ecabs-buttons.module.ts +13 -0
  42. package/lib/ecabs-checkbox-toggle/ecabs-checkbox-toggle.component.d.ts +5 -3
  43. package/lib/ecabs-checkbox-toggle/ecabs-checkbox-toggle.component.html +27 -0
  44. package/lib/ecabs-checkbox-toggle/ecabs-checkbox-toggle.component.scss +15 -0
  45. package/lib/ecabs-checkbox-toggle/ecabs-checkbox-toggle.component.ts +86 -0
  46. package/lib/ecabs-checkbox-toggle/ecabs-checkbox-toggle.module.ts +21 -0
  47. package/lib/ecabs-date-picker/components/ecabs-date-picker-header/ecabs-date-picker-header.component.html +4 -0
  48. package/lib/ecabs-date-picker/components/ecabs-date-picker-header/ecabs-date-picker-header.component.scss +0 -0
  49. package/lib/ecabs-date-picker/components/ecabs-date-picker-header/ecabs-date-picker-header.component.spec.ts +23 -0
  50. package/lib/ecabs-date-picker/components/ecabs-date-picker-header/ecabs-date-picker-header.component.ts +11 -0
  51. package/lib/ecabs-date-picker/ecabs-date-picker.component.html +31 -0
  52. package/lib/ecabs-date-picker/ecabs-date-picker.component.scss +10 -0
  53. package/lib/ecabs-date-picker/ecabs-date-picker.component.spec.ts +24 -0
  54. package/lib/ecabs-date-picker/ecabs-date-picker.component.ts +72 -0
  55. package/lib/ecabs-date-picker/ecabs-date-picker.module.ts +28 -0
  56. package/lib/ecabs-date-range-picker/components/ecabs-date-range-picker-header/ecabs-date-range-picker-header.component.html +4 -0
  57. package/lib/ecabs-date-range-picker/components/ecabs-date-range-picker-header/ecabs-date-range-picker-header.component.scss +1 -0
  58. package/lib/ecabs-date-range-picker/components/ecabs-date-range-picker-header/ecabs-date-range-picker-header.component.spec.ts +23 -0
  59. package/lib/ecabs-date-range-picker/components/ecabs-date-range-picker-header/ecabs-date-range-picker-header.component.ts +11 -0
  60. package/lib/ecabs-date-range-picker/ecabs-date-range-picker.component.html +31 -0
  61. package/lib/ecabs-date-range-picker/ecabs-date-range-picker.component.scss +23 -0
  62. package/lib/ecabs-date-range-picker/ecabs-date-range-picker.component.spec.ts +23 -0
  63. package/lib/ecabs-date-range-picker/ecabs-date-range-picker.component.ts +113 -0
  64. package/lib/ecabs-date-range-picker/ecabs-date-range-picker.module.ts +48 -0
  65. package/lib/ecabs-date-time-picker/components/ecabs-date-time-picker-header/ecabs-date-time-picker-header.component.html +4 -0
  66. package/lib/ecabs-date-time-picker/components/ecabs-date-time-picker-header/ecabs-date-time-picker-header.component.scss +14 -0
  67. package/lib/ecabs-date-time-picker/components/ecabs-date-time-picker-header/ecabs-date-time-picker-header.component.ts +11 -0
  68. package/lib/ecabs-date-time-picker/ecabs-date-time-picker.component.html +87 -0
  69. package/lib/ecabs-date-time-picker/ecabs-date-time-picker.component.scss +68 -0
  70. package/lib/ecabs-date-time-picker/ecabs-date-time-picker.component.spec.ts +23 -0
  71. package/lib/ecabs-date-time-picker/ecabs-date-time-picker.component.ts +185 -0
  72. package/lib/ecabs-date-time-picker/ecabs-date-time-picker.module.ts +36 -0
  73. package/lib/ecabs-date-time-range-picker/components/ecabs-date-time-range-picker-header/ecabs-date-time-range-picker-header.component.html +4 -0
  74. package/lib/ecabs-date-time-range-picker/components/ecabs-date-time-range-picker-header/ecabs-date-time-range-picker-header.component.scss +11 -0
  75. package/lib/ecabs-date-time-range-picker/components/ecabs-date-time-range-picker-header/ecabs-date-time-range-picker-header.component.spec.ts +23 -0
  76. package/lib/ecabs-date-time-range-picker/components/ecabs-date-time-range-picker-header/ecabs-date-time-range-picker-header.component.ts +10 -0
  77. package/lib/ecabs-date-time-range-picker/ecabs-date-time-range-picker.component.html +107 -0
  78. package/lib/ecabs-date-time-range-picker/ecabs-date-time-range-picker.component.scss +51 -0
  79. package/lib/ecabs-date-time-range-picker/ecabs-date-time-range-picker.component.spec.ts +24 -0
  80. package/lib/ecabs-date-time-range-picker/ecabs-date-time-range-picker.component.ts +206 -0
  81. package/lib/ecabs-date-time-range-picker/ecabs-date-time-range-picker.module.ts +37 -0
  82. package/lib/ecabs-date-time-range-picker/time-range.directive.ts +38 -0
  83. package/lib/ecabs-dialog-confirm/ecabs-dialog-confirm.component.html +32 -0
  84. package/lib/ecabs-dialog-confirm/ecabs-dialog-confirm.component.scss +24 -0
  85. package/lib/ecabs-dialog-confirm/ecabs-dialog-confirm.component.ts +57 -0
  86. package/lib/ecabs-dialog-confirm/ecabs-dialog-confirm.module.ts +12 -0
  87. package/lib/ecabs-dialog-message/ecabs-dialog-message.component.html +27 -0
  88. package/lib/ecabs-dialog-message/ecabs-dialog-message.component.scss +25 -0
  89. package/lib/ecabs-dialog-message/ecabs-dialog-message.component.spec.ts +38 -0
  90. package/lib/ecabs-dialog-message/ecabs-dialog-message.component.ts +49 -0
  91. package/lib/ecabs-dialog-message/ecabs-dialog-message.module.ts +12 -0
  92. package/lib/ecabs-empty-placeholder/ecabs-empty-placeholder.component.html +9 -0
  93. package/lib/ecabs-empty-placeholder/ecabs-empty-placeholder.component.scss +0 -0
  94. package/lib/ecabs-empty-placeholder/ecabs-empty-placeholder.component.spec.ts +34 -0
  95. package/lib/ecabs-empty-placeholder/ecabs-empty-placeholder.component.ts +22 -0
  96. package/lib/ecabs-empty-placeholder/ecabs-empty-placeholder.module.ts +11 -0
  97. package/lib/ecabs-expansion-panel/ecabs-expansion-panel.component.html +33 -0
  98. package/lib/ecabs-expansion-panel/ecabs-expansion-panel.component.scss +79 -0
  99. package/lib/ecabs-expansion-panel/ecabs-expansion-panel.component.spec.ts +26 -0
  100. package/lib/ecabs-expansion-panel/ecabs-expansion-panel.component.ts +77 -0
  101. package/lib/ecabs-expansion-panel/ecabs-expansion-panel.module.ts +16 -0
  102. package/lib/ecabs-increment/ecabs-increment.component.html +18 -0
  103. package/lib/ecabs-increment/ecabs-increment.component.scss +33 -0
  104. package/lib/ecabs-increment/ecabs-increment.component.ts +74 -0
  105. package/lib/ecabs-increment/ecabs-increment.module.ts +16 -0
  106. package/lib/ecabs-input/ecabs-input.component.html +27 -0
  107. package/lib/ecabs-input/ecabs-input.component.ts +86 -0
  108. package/lib/ecabs-input/ecabs-input.module.ts +14 -0
  109. package/lib/ecabs-language-selector/ecabs-language-selector.component.html +17 -0
  110. package/lib/ecabs-language-selector/ecabs-language-selector.component.scss +24 -0
  111. package/lib/ecabs-language-selector/ecabs-language-selector.component.ts +56 -0
  112. package/lib/ecabs-language-selector/ecabs-language-selector.module.ts +21 -0
  113. package/lib/ecabs-loading/ecabs-loading.component.html +7 -0
  114. package/lib/ecabs-loading/ecabs-loading.component.spec.ts +24 -0
  115. package/lib/ecabs-loading/ecabs-loading.component.ts +11 -0
  116. package/lib/ecabs-loading/ecabs-loading.module.ts +11 -0
  117. package/lib/ecabs-loading/spinner/spinner.component.html +5 -0
  118. package/lib/ecabs-loading/spinner/spinner.component.scss +61 -0
  119. package/lib/ecabs-loading/spinner/spinner.component.spec.ts +24 -0
  120. package/lib/ecabs-loading/spinner/spinner.component.ts +11 -0
  121. package/lib/ecabs-note/ecabs-note.component.html +10 -0
  122. package/lib/ecabs-note/ecabs-note.component.scss +29 -0
  123. package/lib/ecabs-note/ecabs-note.component.ts +27 -0
  124. package/lib/ecabs-note/ecabs-note.module.ts +11 -0
  125. package/lib/ecabs-phone/ecabs-phone.component.html +17 -0
  126. package/lib/ecabs-phone/ecabs-phone.component.ts +108 -0
  127. package/lib/ecabs-phone/ecabs-phone.module.ts +15 -0
  128. package/lib/ecabs-picker-header/ecabs-picker-header.component.html +12 -0
  129. package/lib/ecabs-picker-header/ecabs-picker-header.component.scss +12 -0
  130. package/lib/ecabs-picker-header/ecabs-picker-header.component.ts +61 -0
  131. package/lib/ecabs-picker-header/ecabs-picker-header.module.ts +15 -0
  132. package/lib/ecabs-radio-button-list/ecabs-radio-button-list.component.html +13 -0
  133. package/lib/ecabs-radio-button-list/ecabs-radio-button-list.component.scss +16 -0
  134. package/lib/ecabs-radio-button-list/ecabs-radio-button-list.component.ts +60 -0
  135. package/lib/ecabs-radio-button-list/ecabs-radio-button-list.module.ts +20 -0
  136. package/lib/ecabs-select/ecabs-select.component.html +38 -0
  137. package/lib/ecabs-select/ecabs-select.component.ts +346 -0
  138. package/lib/ecabs-select/ecabs-select.module.ts +37 -0
  139. package/lib/ecabs-table/ecabs-table-filter-wrapper/ecabs-table-filter-wrapper.component.html +7 -0
  140. package/lib/ecabs-table/ecabs-table-filter-wrapper/ecabs-table-filter-wrapper.component.scss +11 -0
  141. package/lib/ecabs-table/ecabs-table-filter-wrapper/ecabs-table-filter-wrapper.component.spec.ts +34 -0
  142. package/lib/ecabs-table/ecabs-table-filter-wrapper/ecabs-table-filter-wrapper.component.ts +14 -0
  143. package/lib/ecabs-table/ecabs-table-filter-wrapper/ecabs-table-filter-wrapper.module.ts +14 -0
  144. package/lib/ecabs-table/ecabs-table.component.html +26 -0
  145. package/lib/ecabs-table/ecabs-table.component.scss +6 -0
  146. package/lib/ecabs-table/ecabs-table.component.spec.ts +24 -0
  147. package/lib/ecabs-table/ecabs-table.component.ts +42 -0
  148. package/lib/ecabs-table/ecabs-table.module.ts +19 -0
  149. package/lib/ecabs-textarea/ecabs-textarea.component.html +13 -0
  150. package/lib/ecabs-textarea/ecabs-textarea.component.ts +61 -0
  151. package/lib/ecabs-textarea/ecabs-textarea.module.ts +12 -0
  152. package/lib/ecabs-timepicker/componets/ecabs-time-list-panel/ecabs-time-list-panel.component.html +16 -0
  153. package/lib/ecabs-timepicker/componets/ecabs-time-list-panel/ecabs-time-list-panel.component.ts +126 -0
  154. package/lib/ecabs-timepicker/config.model.ts +5 -0
  155. package/lib/ecabs-timepicker/ecabs-timepicker.component.html +36 -0
  156. package/lib/ecabs-timepicker/ecabs-timepicker.component.scss +5 -0
  157. package/lib/ecabs-timepicker/ecabs-timepicker.component.ts +330 -0
  158. package/lib/ecabs-timepicker/ecabs-timepicker.module.ts +12 -0
  159. package/lib/ecabs-timepicker/ecabs-timepicker.service.ts +28 -0
  160. package/lib/ecabs-validation/ecabs-validation.component.html +9 -0
  161. package/lib/ecabs-validation/ecabs-validation.component.scss +23 -0
  162. package/lib/ecabs-validation/ecabs-validation.component.ts +14 -0
  163. package/lib/ecabs-validation/ecabs-validation.module.ts +12 -0
  164. package/lib/models/bread-crumb.ts +5 -0
  165. package/lib/models/language.models.ts +0 -0
  166. package/lib/models/timepicker.models.ts +7 -0
  167. package/lib/models/validation.models.ts +4 -0
  168. package/lib/services/ecabs-components.service.ts +33 -0
  169. package/package.json +1 -1
  170. package/public-api.ts +58 -0
  171. package/styles/material/overrides/_form.scss +5 -0
  172. package/test.ts +27 -0
@@ -0,0 +1,14 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { EcabsTableFilterWrapperComponent } from './ecabs-table-filter-wrapper.component';
4
+ import { EcabsExpansionPanelModule } from '../../ecabs-expansion-panel/ecabs-expansion-panel.module';
5
+
6
+ @NgModule( {
7
+ declarations: [ EcabsTableFilterWrapperComponent ],
8
+ imports: [
9
+ CommonModule,
10
+ EcabsExpansionPanelModule
11
+ ],
12
+ exports: [ EcabsTableFilterWrapperComponent ],
13
+ } )
14
+ export class EcabsTableFilterWrapperModule { }
@@ -0,0 +1,26 @@
1
+ <section class="table-ui table-ui--wrapper" [ngClass]="{ 'table-ui__bordered': bordered, loading: loading }">
2
+ <mat-progress-bar *ngIf="loading" mode="indeterminate" class="table-ui__progress"></mat-progress-bar>
3
+
4
+
5
+ <div *ngIf="header" class="table-ui__header">
6
+ <ng-container *ngTemplateOutlet="header"></ng-container>
7
+ </div>
8
+
9
+ <ng-container *ngIf="!(isEmptyMessage && isEmpty); else noDataTemplate">
10
+ <ng-content></ng-content>
11
+
12
+ <div *ngIf="paginator" class="table-ui__paginator">
13
+ <ng-container *ngTemplateOutlet="paginator"></ng-container>
14
+ </div>
15
+ </ng-container>
16
+
17
+ <!--#For Empty state -->
18
+ <ng-template #noDataTemplate>
19
+ <ecabs-empty-placeholder
20
+ *ngIf="!loading"
21
+ [redirectPath]="redirectPath"
22
+ [isEmptyMessage]="isEmptyMessage"
23
+ [srcImage]="srcImageEmpty"
24
+ ></ecabs-empty-placeholder>
25
+ </ng-template>
26
+ </section>
@@ -0,0 +1,6 @@
1
+ :host {
2
+ mat-progress-bar {
3
+ position: absolute;
4
+ width: auto;
5
+ }
6
+ }
@@ -0,0 +1,24 @@
1
+ import { ComponentFixture, TestBed } from '@angular/core/testing';
2
+
3
+ import { TableComponent } from './ecabs-table.component';
4
+
5
+ describe( 'TableComponent', () => {
6
+ let component: TableComponent;
7
+ let fixture: ComponentFixture<TableComponent>;
8
+
9
+ beforeEach( async () => {
10
+ await TestBed.configureTestingModule( {
11
+ declarations: [ TableComponent ],
12
+ } ).compileComponents();
13
+ } );
14
+
15
+ beforeEach( () => {
16
+ fixture = TestBed.createComponent( TableComponent );
17
+ component = fixture.componentInstance;
18
+ fixture.detectChanges();
19
+ } );
20
+
21
+ it( 'should create', () => {
22
+ expect( component ).toBeTruthy();
23
+ } );
24
+ } );
@@ -0,0 +1,42 @@
1
+ import { AfterContentChecked, Component, ContentChild, Input, TemplateRef } from '@angular/core';
2
+ import { MatTable } from '@angular/material/table';
3
+ import { PlaceholderRedirectPath } from '../ecabs-empty-placeholder/ecabs-empty-placeholder.component';
4
+
5
+ @Component( {
6
+ selector: 'ecabs-table',
7
+ templateUrl: './ecabs-table.component.html',
8
+ styleUrls: [ './ecabs-table.component.scss' ],
9
+ } )
10
+ export class TableComponent implements AfterContentChecked {
11
+ @ContentChild( MatTable )
12
+ table: MatTable<any>;
13
+
14
+ @Input()
15
+ header: TemplateRef<any>;
16
+
17
+ @Input()
18
+ paginator: TemplateRef<any>;
19
+
20
+ @Input()
21
+ bordered = false;
22
+
23
+ @Input()
24
+ loading = false;
25
+
26
+ @Input()
27
+ isEmpty: boolean;
28
+ @Input()
29
+ isEmptyMessage: string;
30
+
31
+ @Input()
32
+ redirectPath: PlaceholderRedirectPath;
33
+
34
+ @Input()
35
+ srcImageEmpty: string;
36
+
37
+ ngAfterContentChecked(): void {
38
+ if ( this.table ) {
39
+ this.isEmpty = !this.table[ '_data' ]?.length;
40
+ }
41
+ }
42
+ }
@@ -0,0 +1,19 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { TableComponent } from './ecabs-table.component';
4
+ import { MatTableModule } from '@angular/material/table';
5
+ import { MatProgressBarModule } from '@angular/material/progress-bar';
6
+ import { RouterModule } from '@angular/router';
7
+ import { EcabsEmptyPlaceholderModule } from '../ecabs-empty-placeholder/ecabs-empty-placeholder.module';
8
+
9
+ @NgModule( {
10
+ declarations: [ TableComponent ],
11
+ imports: [
12
+ CommonModule,
13
+ MatProgressBarModule,
14
+ RouterModule,
15
+ EcabsEmptyPlaceholderModule
16
+ ],
17
+ exports: [ TableComponent, MatTableModule, EcabsEmptyPlaceholderModule ],
18
+ } )
19
+ export class EcabsTableModule { }
@@ -0,0 +1,13 @@
1
+ <app-element-wrapper [data]="getData()">
2
+ <textarea
3
+ class="form-field__textarea"
4
+ [id]="name"
5
+ [(ngModel)]="value"
6
+ [placeholder]="placeholder"
7
+ (blur)="onTouch()"
8
+ [disabled]="disabled"
9
+ [maxlength]="maxLength"
10
+ [rows]="rows"
11
+ >
12
+ </textarea>
13
+ </app-element-wrapper>
@@ -0,0 +1,61 @@
1
+ import { AfterViewInit, Component, Injector, Input } from '@angular/core';
2
+ import { ControlValueAccessor, UntypedFormControl, NgControl, NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import ElementBaseComponent from '../base/element-base';
4
+
5
+ @Component({
6
+ selector: 'ecabs-textarea',
7
+ templateUrl: './ecabs-textarea.component.html',
8
+ providers: [
9
+ {
10
+ provide: NG_VALUE_ACCESSOR,
11
+ useExisting: EcabsTextareaComponent,
12
+ multi: true,
13
+ },
14
+ ],
15
+ })
16
+ export class EcabsTextareaComponent extends ElementBaseComponent implements ControlValueAccessor, AfterViewInit {
17
+ @Input()
18
+ rows!: number;
19
+
20
+ val!: string;
21
+
22
+ get value(): string {
23
+ return this.val;
24
+ }
25
+
26
+ set value(val) {
27
+ if (val !== undefined && this.val !== val) {
28
+ this.val = val;
29
+ this.onChange(val);
30
+ this.onTouch(val);
31
+ }
32
+ }
33
+
34
+ constructor(private injector: Injector) {
35
+ super();
36
+ }
37
+
38
+ ngAfterViewInit(): void {
39
+ const ngControl: NgControl = this.injector.get(NgControl, null) as NgControl;
40
+ if (ngControl) {
41
+ this.control = ngControl.control as UntypedFormControl;
42
+ }
43
+ }
44
+
45
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
46
+ onChange: any = (): void => {};
47
+ // eslint-disable-next-line @typescript-eslint/no-empty-function
48
+ onTouch: any = (): void => {};
49
+
50
+ writeValue(value: any): void {
51
+ this.value = value;
52
+ }
53
+
54
+ registerOnChange(fn: any): void {
55
+ this.onChange = fn;
56
+ }
57
+
58
+ registerOnTouched(fn: any): void {
59
+ this.onTouch = fn;
60
+ }
61
+ }
@@ -0,0 +1,12 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { EcabsTextareaComponent } from './ecabs-textarea.component';
4
+ import { ElementWrapperModule } from '../base/element-wrapper/element-wrapper.module';
5
+ import { FormsModule } from '@angular/forms';
6
+
7
+ @NgModule({
8
+ declarations: [EcabsTextareaComponent],
9
+ imports: [CommonModule, ElementWrapperModule, FormsModule],
10
+ exports: [EcabsTextareaComponent],
11
+ })
12
+ export class EcabsTextAreaModule {}
@@ -0,0 +1,16 @@
1
+ <div class="list">
2
+ <div class="inner-scroll">
3
+ <div class="inner">
4
+ <ul>
5
+ <li
6
+ *ngFor="let i of timeList; let counter = index"
7
+ (click)="setTime(i.value)"
8
+ (mouseenter)="hoveredItemIndex = counter"
9
+ [ngClass]="{ active: typedValue === i.value, hovered: counter === hoveredItemIndex }"
10
+ >
11
+ {{ i.title }}
12
+ </li>
13
+ </ul>
14
+ </div>
15
+ </div>
16
+ </div>
@@ -0,0 +1,126 @@
1
+ import { Component, OnInit, Input, Output, EventEmitter, HostListener, ElementRef, OnChanges } from '@angular/core';
2
+ import { ListPlacement, ListPosition } from '../../../models/timepicker.models';
3
+ import { FormTimePickerService } from '../../ecabs-timepicker.service';
4
+ @Component( {
5
+ selector: 'ecabs-time-list-panel',
6
+ templateUrl: './ecabs-time-list-panel.component.html',
7
+ } )
8
+ export class EcabsTimeListPanelComponent implements OnInit, OnChanges {
9
+ @Input() typedValue: any;
10
+ @Input() listPlacement: ListPlacement = 'auto';
11
+ @Input() listPosition: ListPosition = {};
12
+
13
+ @Input() appendTo!: string;
14
+ @Input() min!: string;
15
+ @Input() max!: string;
16
+ @Input() showDayStart = true;
17
+ @Input() showDayEnd = false;
18
+ @Input() position: ListPosition = {};
19
+
20
+ @Output() onscroll = new EventEmitter<{ start: number; end: number }>();
21
+ @Output() closeMe = new EventEmitter<any>();
22
+
23
+ hoveredItemIndex = 0;
24
+ timeList: { value: any; title: string }[] = [];
25
+
26
+ private listItemHeight!: any;
27
+
28
+ constructor( private elementRef: ElementRef, private timepickerService: FormTimePickerService ) { }
29
+
30
+ @HostListener( 'document:keydown', [ '$event' ] )
31
+ handleKeydown( $event: KeyboardEvent ): void {
32
+ if ( $event.key === 'ArrowUp' ) {
33
+ // eslint-disable-next-line @typescript-eslint/no-unused-expressions
34
+ this.hoveredItemIndex ? this.hoveredItemIndex-- : null;
35
+ this.scrollTo( this.hoveredItemIndex );
36
+ }
37
+ if ( $event.key === 'ArrowDown' ) {
38
+ // eslint-disable-next-line @typescript-eslint/no-unused-expressions
39
+ this.hoveredItemIndex + 1 < this.timeList.length ? this.hoveredItemIndex++ : null;
40
+ this.scrollTo( this.hoveredItemIndex );
41
+ }
42
+ if ( $event.key === 'Enter' ) {
43
+ this.setTime( this.timeList[ this.hoveredItemIndex ].value );
44
+ }
45
+ }
46
+
47
+ ngOnInit(): void {
48
+ this.calcListItems();
49
+ if ( this.appendTo ) {
50
+ this.appendListTo();
51
+ }
52
+
53
+ setTimeout( () => {
54
+ this.listItemHeight = this.elementRef.nativeElement.querySelector( 'li' ).getBoundingClientRect().height;
55
+ this.selectTypedValue( this.typedValue );
56
+ } );
57
+ }
58
+
59
+ appendListTo(): void {
60
+ const parent = document.querySelector( this.appendTo );
61
+ if ( !parent ) {
62
+ throw new Error( `appendTo selector ${ this.appendTo } did not found any parent element` );
63
+ }
64
+ parent.appendChild( this.elementRef.nativeElement );
65
+ }
66
+
67
+ calcListItems(): void {
68
+ if ( this.showDayStart ) {
69
+ this.timeList.push( {
70
+ value: '00:00',
71
+ title: this.timepickerService.getConfig().dayStart,
72
+ } );
73
+ }
74
+ for ( let index = 0; index < 24; index++ ) {
75
+ for ( const minute of [ '00', '30' ] ) {
76
+ if ( index === 0 && minute === '00' ) {
77
+ continue;
78
+ }
79
+ this.timeList.push( {
80
+ value: ( index > 9 ? index + '' : '0' + index ) + ':' + minute,
81
+ title: ( index > 9 ? index + '' : '0' + index ) + ':' + minute,
82
+ } );
83
+ }
84
+ }
85
+ if ( this.showDayEnd ) {
86
+ this.timeList.push( {
87
+ value: '23:59',
88
+ title: this.timepickerService.getConfig().dayEnd,
89
+ } );
90
+ }
91
+ }
92
+
93
+ ngOnChanges(): void {
94
+ this.selectTypedValue( this.typedValue );
95
+ if ( this.elementRef.nativeElement ) {
96
+ this.elementRef.nativeElement.style.top = this.listPosition.top + 'px';
97
+ this.elementRef.nativeElement.style.left = this.listPosition.left + 'px';
98
+ this.elementRef.nativeElement.style.width = this.listPosition.width + 'px';
99
+ if ( this.appendTo ) {
100
+ this.elementRef.nativeElement.style.position = 'fixed';
101
+ }
102
+ }
103
+ }
104
+
105
+ selectTypedValue( value: any ): void {
106
+ if ( value ) {
107
+ const hour = parseInt( value.split( ':' )[ 0 ], 10 );
108
+ if ( hour || hour === 0 ) {
109
+ this.hoveredItemIndex = hour * 2;
110
+ this.scrollTo( this.hoveredItemIndex );
111
+ }
112
+ }
113
+ }
114
+
115
+ scrollTo( index: number ): void {
116
+ this.elementRef.nativeElement.querySelector( '.inner-scroll' ).scrollTop = index * this.listItemHeight;
117
+ }
118
+
119
+ close(): void {
120
+ this.closeMe.emit( null );
121
+ }
122
+
123
+ setTime( value: any ): void {
124
+ this.closeMe.emit( value );
125
+ }
126
+ }
@@ -0,0 +1,5 @@
1
+ export interface FormTimePickerConfig {
2
+ dayStart: string;
3
+ dayEnd: string;
4
+ iconClass: string;
5
+ }
@@ -0,0 +1,36 @@
1
+ <div class="timeInputWrapper" [ngClass]="{ disabled: disabled }">
2
+ <app-element-wrapper
3
+ [data]="getData()"
4
+ [showCloseIcon]="showCloseIcon"
5
+ [focusedFlag]="focusedFlag"
6
+ (clear)="clearInput()"
7
+ >
8
+ <div class="timeInputFieldWrapper">
9
+ <input
10
+ type="text"
11
+ class="form-field__input"
12
+ [value]="data"
13
+ [disabled]="disabled"
14
+ (focus)="show()"
15
+ (click)="show()"
16
+ (keydown)="inputKeyDown($event)"
17
+ [placeholder]="placeholder"
18
+ />
19
+ <div class="form-field__input--suffix" *ngIf="type !== 'number'">
20
+ <ng-content select="mat-icon"></ng-content>
21
+ </div>
22
+ <ecabs-time-list-panel
23
+ [typedValue]="data"
24
+ *ngIf="focusedFlag"
25
+ [showDayStart]="showDayStart"
26
+ [showDayEnd]="showDayEnd"
27
+ [min]="min"
28
+ [max]="max"
29
+ class="form-time-list"
30
+ [appendTo]="appendTo"
31
+ [listPosition]="listPosition"
32
+ (closeMe)="close($event)"
33
+ ></ecabs-time-list-panel>
34
+ </div>
35
+ </app-element-wrapper>
36
+ </div>
@@ -0,0 +1,5 @@
1
+ :host::ng-deep {
2
+ .timeInputWrapper app-element-wrapper .form-field {
3
+ margin-bottom: 0;
4
+ }
5
+ }