@gloww/gloww 0.9.0-beta.9 → 14.0.0-beta.1

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 (98) hide show
  1. package/esm2020/lib/Components/auto-complete/auto-complete.component.mjs +152 -0
  2. package/esm2020/lib/Components/code-editor/code-editor.component.mjs +109 -13
  3. package/esm2020/lib/Components/confirmation/confirmation.component.mjs +6 -6
  4. package/esm2020/lib/Components/datetime/datetime.component.mjs +84 -0
  5. package/esm2020/lib/Components/display-objects/display-objects.component.mjs +182 -62
  6. package/esm2020/lib/Components/download-progress/download-progress.component.mjs +8 -10
  7. package/esm2020/lib/Components/dummy/dummy.component.mjs +14 -0
  8. package/esm2020/lib/Components/folders/file-edit/file-edit.component.mjs +31 -12
  9. package/esm2020/lib/Components/folders/folders/folders.component.mjs +6 -6
  10. package/esm2020/lib/Components/header/header.component.mjs +4 -4
  11. package/esm2020/lib/Components/html-editor/html-editor.component.mjs +8 -8
  12. package/esm2020/lib/Components/menu-list-item/menu-list-item.component.mjs +43 -37
  13. package/esm2020/lib/Components/prompt/prompt.component.mjs +8 -8
  14. package/esm2020/lib/Components/result-table/result-table.component.mjs +4 -4
  15. package/esm2020/lib/Components/search-form/search-form.component.mjs +4 -4
  16. package/esm2020/lib/Components/secure-a/secure-a.component.mjs +5 -5
  17. package/esm2020/lib/Components/secure-img/secure-img.component.mjs +4 -4
  18. package/esm2020/lib/Components/select/select.component.mjs +132 -0
  19. package/esm2020/lib/Components/upload-doc/upload-doc.component.mjs +8 -8
  20. package/esm2020/lib/Components/upload-file/upload-file.component.mjs +20 -12
  21. package/esm2020/lib/Directives/file-sink.directive.mjs +3 -3
  22. package/esm2020/lib/Guards/has-unsaved-data.guard.mjs +29 -0
  23. package/esm2020/lib/Guards/ihas-unsaved-data.mjs +2 -0
  24. package/esm2020/lib/Helpers/gloww-validators.mjs +116 -0
  25. package/esm2020/lib/Models/nav-item.mjs +1 -1
  26. package/esm2020/lib/Pipes/html-format.pipe.mjs +3 -3
  27. package/esm2020/lib/Pipes/safe-html.pipe.mjs +3 -3
  28. package/esm2020/lib/Pipes/secure.pipe.mjs +3 -3
  29. package/esm2020/lib/Services/dialog.service.mjs +3 -3
  30. package/esm2020/lib/Services/folder-service-config.mjs +3 -3
  31. package/esm2020/lib/Services/folder.service.mjs +8 -4
  32. package/esm2020/lib/Services/gloww.service.mjs +26 -9
  33. package/esm2020/lib/Services/nav.service.mjs +3 -3
  34. package/esm2020/lib/Services/snippets.service.mjs +25 -0
  35. package/esm2020/lib/Services/version-check.service.mjs +3 -3
  36. package/esm2020/lib/Services/voice-recognition.service.mjs +3 -3
  37. package/esm2020/lib/gloww-security/Components/change-password-dlg/change-password-dlg.component.mjs +8 -8
  38. package/esm2020/lib/gloww-security/Components/login/login.component.mjs +11 -11
  39. package/esm2020/lib/gloww-security/Components/social-network/social-network.component.mjs +5 -5
  40. package/esm2020/lib/gloww-security/Components/social-network-dlg/social-network-dlg.component.mjs +7 -7
  41. package/esm2020/lib/gloww-security/Components/user-menu/user-menu.component.mjs +3 -3
  42. package/esm2020/lib/gloww-security/Helpers/administrator.guard.mjs +3 -3
  43. package/esm2020/lib/gloww-security/Helpers/auth.guard.mjs +3 -3
  44. package/esm2020/lib/gloww-security/Helpers/error.interceptor.mjs +3 -3
  45. package/esm2020/lib/gloww-security/Helpers/jwt.interceptor.mjs +3 -3
  46. package/esm2020/lib/gloww-security/Helpers/staging.interceptor.mjs +3 -3
  47. package/esm2020/lib/gloww-security/Services/authentication-service-config.mjs +3 -3
  48. package/esm2020/lib/gloww-security/Services/authentication.service.mjs +3 -3
  49. package/esm2020/lib/gloww-security/Services/gloww-security.service.mjs +3 -3
  50. package/esm2020/lib/gloww-security/gloww-security.module.mjs +19 -21
  51. package/esm2020/lib/gloww.module.mjs +90 -31
  52. package/esm2020/public-api.mjs +9 -1
  53. package/fesm2015/gloww-gloww.mjs +1139 -307
  54. package/fesm2015/gloww-gloww.mjs.map +1 -1
  55. package/fesm2020/gloww-gloww.mjs +1117 -305
  56. package/fesm2020/gloww-gloww.mjs.map +1 -1
  57. package/gloww.theme.scss +164 -0
  58. package/{gloww-gloww.d.ts → index.d.ts} +0 -0
  59. package/lib/Components/auto-complete/auto-complete.component.d.ts +39 -0
  60. package/lib/Components/code-editor/code-editor.component.d.ts +32 -3
  61. package/lib/Components/confirmation/confirmation.component.d.ts +1 -1
  62. package/lib/Components/datetime/datetime.component.d.ts +22 -0
  63. package/lib/Components/display-objects/display-objects.component.d.ts +20 -12
  64. package/lib/Components/download-progress/download-progress.component.d.ts +1 -1
  65. package/lib/Components/dummy/dummy.component.d.ts +8 -0
  66. package/lib/Components/folders/file-edit/file-edit.component.d.ts +11 -4
  67. package/lib/Components/folders/folders/folders.component.d.ts +1 -1
  68. package/lib/Components/header/header.component.d.ts +1 -1
  69. package/lib/Components/html-editor/html-editor.component.d.ts +1 -1
  70. package/lib/Components/menu-list-item/menu-list-item.component.d.ts +12 -4
  71. package/lib/Components/prompt/prompt.component.d.ts +4 -4
  72. package/lib/Components/result-table/result-table.component.d.ts +1 -1
  73. package/lib/Components/search-form/search-form.component.d.ts +1 -1
  74. package/lib/Components/secure-a/secure-a.component.d.ts +1 -1
  75. package/lib/Components/secure-img/secure-img.component.d.ts +1 -1
  76. package/lib/Components/select/select.component.d.ts +35 -0
  77. package/lib/Components/upload-doc/upload-doc.component.d.ts +3 -3
  78. package/lib/Components/upload-file/upload-file.component.d.ts +3 -3
  79. package/lib/Directives/file-sink.directive.d.ts +1 -1
  80. package/lib/Guards/has-unsaved-data.guard.d.ts +8 -0
  81. package/lib/Guards/ihas-unsaved-data.d.ts +3 -0
  82. package/lib/Helpers/gloww-validators.d.ts +39 -0
  83. package/lib/Models/nav-item.d.ts +2 -1
  84. package/lib/Pipes/html-format.pipe.d.ts +1 -1
  85. package/lib/Pipes/safe-html.pipe.d.ts +1 -1
  86. package/lib/Pipes/secure.pipe.d.ts +1 -1
  87. package/lib/Services/folder.service.d.ts +1 -0
  88. package/lib/Services/gloww.service.d.ts +5 -0
  89. package/lib/Services/snippets.service.d.ts +16 -0
  90. package/lib/gloww-security/Components/change-password-dlg/change-password-dlg.component.d.ts +4 -4
  91. package/lib/gloww-security/Components/login/login.component.d.ts +8 -8
  92. package/lib/gloww-security/Components/social-network/social-network.component.d.ts +1 -1
  93. package/lib/gloww-security/Components/social-network-dlg/social-network-dlg.component.d.ts +1 -1
  94. package/lib/gloww-security/Components/user-menu/user-menu.component.d.ts +1 -1
  95. package/lib/gloww.module.d.ts +35 -18
  96. package/package.json +13 -9
  97. package/public-api.d.ts +8 -0
  98. package/gloww-assets/.gitkeep +0 -0
@@ -0,0 +1,152 @@
1
+ import { catchError, debounceTime, distinctUntilChanged, filter, map, switchMap, tap } from 'rxjs/operators';
2
+ import { Component, Input, Inject, forwardRef, ViewEncapsulation } from '@angular/core';
3
+ import { UntypedFormControl, NG_VALUE_ACCESSOR } from '@angular/forms';
4
+ import { of } from 'rxjs';
5
+ import { TranslateDefaultParser } from '@ngx-translate/core';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/forms";
8
+ import * as i2 from "@angular/common";
9
+ import * as i3 from "@angular/material/form-field";
10
+ import * as i4 from "@angular/material/input";
11
+ import * as i5 from "@angular/material/core";
12
+ import * as i6 from "@angular/material/autocomplete";
13
+ import * as i7 from "../../Pipes/safe-html.pipe";
14
+ export class AutoCompleteComponent {
15
+ constructor(glowwService, formBuilder, ref) {
16
+ this.formBuilder = formBuilder;
17
+ this.ref = ref;
18
+ this._value = null;
19
+ this.objectName = null;
20
+ this.searchField = null;
21
+ this.returnField = null;
22
+ this.displayField = null;
23
+ this.displayExpr = null;
24
+ this.displayFct = null;
25
+ this.placeHolder = null;
26
+ this.data = null;
27
+ this.onChange = () => { };
28
+ this.onTouched = () => { };
29
+ this.items = [];
30
+ this.parser = new TranslateDefaultParser();
31
+ this.options = []; //Observable<unknown>;
32
+ this.propagateChange = (_) => { };
33
+ this.glowwService = glowwService;
34
+ this.resultCtrl = new UntypedFormControl();
35
+ this.form = this.formBuilder.group({
36
+ __result: this.resultCtrl
37
+ });
38
+ }
39
+ ngAfterViewInit() {
40
+ }
41
+ ngOnInit() {
42
+ //debugger;
43
+ this.searchRequest = this.glowwService[`search${this.objectName}`];
44
+ this.resultCtrl.valueChanges.pipe(filter(res => res != null && res.length > 2), distinctUntilChanged(), debounceTime(250), tap(() => { this.error = ""; this.options = []; }), switchMap(searchStr => {
45
+ let searchObj = {};
46
+ if (this.data) {
47
+ Object.keys(this.data).forEach(k => {
48
+ searchObj[k] = this.data[k];
49
+ });
50
+ }
51
+ searchObj[this.searchField] = searchStr;
52
+ return this.searchRequest.call(this.glowwService, searchObj).pipe(map(res => res), catchError(err => {
53
+ this.error = err.message;
54
+ this.ref.markForCheck();
55
+ return of([]);
56
+ }));
57
+ })).subscribe({
58
+ next: (data) => {
59
+ this.options = data;
60
+ this.ref.markForCheck();
61
+ },
62
+ error: (error) => { this.error = error; }
63
+ });
64
+ }
65
+ writeValue(val) {
66
+ val && this.form.setValue({ __result: val }, { emitEvent: false });
67
+ }
68
+ registerOnChange(fn) {
69
+ this.onChange = fn;
70
+ this.form.valueChanges.subscribe(data => {
71
+ if (this.returnField) {
72
+ this.onChange(this.form.value.__result[this.returnField]);
73
+ }
74
+ else {
75
+ this.onChange(this.form.value.__result);
76
+ }
77
+ });
78
+ }
79
+ registerOnTouched(fn) {
80
+ this.onTouched = fn;
81
+ }
82
+ setDisabledState(isDisabled) {
83
+ const status = isDisabled ? 'disable' : 'enable';
84
+ //TODO
85
+ }
86
+ displayObj(item) {
87
+ if (!item)
88
+ return null;
89
+ console.log("displayOf");
90
+ if (this.displayField) {
91
+ return item[this.displayField];
92
+ }
93
+ else if (this.displayExpr) {
94
+ return this.parser.interpolate(this.displayExpr.replace(/\\\{/g, "{").replace(/\\\}/g, "}"), item);
95
+ //return '?1' + this.parser.interpolate("{{Name}}", { Name: "test" }) + '?2' + this.parser.interpolate("{{Name}}", item)+'?3'+this.parser.interpolate(this.displayExpr.replace(/\\\{/g,"{").replace(/\\\}/g,"}"), item) +'?4'+ item;
96
+ }
97
+ else if (this.displayFct) {
98
+ return this.displayFct(item);
99
+ }
100
+ }
101
+ }
102
+ AutoCompleteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: AutoCompleteComponent, deps: [{ token: 'glowwService' }, { token: i1.UntypedFormBuilder }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
103
+ AutoCompleteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.2", type: AutoCompleteComponent, selector: "gloww-auto-complete", inputs: { _value: ["value", "_value"], objectName: "objectName", searchField: "searchField", returnField: "returnField", displayField: "displayField", displayExpr: "displayExpr", displayFct: "displayFct", placeHolder: "placeHolder", data: "data", searchRequest: "searchRequest" }, providers: [
104
+ {
105
+ provide: NG_VALUE_ACCESSOR,
106
+ multi: true,
107
+ useExisting: forwardRef(() => AutoCompleteComponent)
108
+ }
109
+ ], ngImport: i0, template: "<div [formGroup]=\"form\" style=\"width:100%\" class=\"mainDiv\">\r\n <div style=\"color:red\">{{error}}</div>\r\n <mat-form-field style=\"width:100%\" class=\"autocff\">\r\n <input type=\"text\" matInput formControlName=\"__result\" [matAutocomplete]=\"auto\" [placeholder]=\"placeHolder\">\r\n </mat-form-field>\r\n <mat-autocomplete #auto=\"matAutocomplete\" [displayWith]=\"displayObj.bind(this)\">\r\n <mat-option *ngFor=\"let option of options\" [value]=\"option\" [innerHTML]=\"displayObj(option) | safeHtml\">\r\n </mat-option>\r\n </mat-autocomplete>\r\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i5.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "component", type: i6.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { kind: "directive", type: i6.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { kind: "pipe", type: i7.SafeHtmlPipe, name: "safeHtml" }], encapsulation: i0.ViewEncapsulation.None });
110
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: AutoCompleteComponent, decorators: [{
111
+ type: Component,
112
+ args: [{ selector: 'gloww-auto-complete', encapsulation: ViewEncapsulation.None, providers: [
113
+ {
114
+ provide: NG_VALUE_ACCESSOR,
115
+ multi: true,
116
+ useExisting: forwardRef(() => AutoCompleteComponent)
117
+ }
118
+ ], template: "<div [formGroup]=\"form\" style=\"width:100%\" class=\"mainDiv\">\r\n <div style=\"color:red\">{{error}}</div>\r\n <mat-form-field style=\"width:100%\" class=\"autocff\">\r\n <input type=\"text\" matInput formControlName=\"__result\" [matAutocomplete]=\"auto\" [placeholder]=\"placeHolder\">\r\n </mat-form-field>\r\n <mat-autocomplete #auto=\"matAutocomplete\" [displayWith]=\"displayObj.bind(this)\">\r\n <mat-option *ngFor=\"let option of options\" [value]=\"option\" [innerHTML]=\"displayObj(option) | safeHtml\">\r\n </mat-option>\r\n </mat-autocomplete>\r\n</div>" }]
119
+ }], ctorParameters: function () { return [{ type: undefined, decorators: [{
120
+ type: Inject,
121
+ args: ['glowwService']
122
+ }] }, { type: i1.UntypedFormBuilder }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { _value: [{
123
+ type: Input,
124
+ args: ['value']
125
+ }], objectName: [{
126
+ type: Input,
127
+ args: ['objectName']
128
+ }], searchField: [{
129
+ type: Input,
130
+ args: ['searchField']
131
+ }], returnField: [{
132
+ type: Input,
133
+ args: ['returnField']
134
+ }], displayField: [{
135
+ type: Input,
136
+ args: ['displayField']
137
+ }], displayExpr: [{
138
+ type: Input,
139
+ args: ['displayExpr']
140
+ }], displayFct: [{
141
+ type: Input,
142
+ args: ['displayFct']
143
+ }], placeHolder: [{
144
+ type: Input,
145
+ args: ['placeHolder']
146
+ }], data: [{
147
+ type: Input,
148
+ args: ['data']
149
+ }], searchRequest: [{
150
+ type: Input
151
+ }] } });
152
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auto-complete.component.js","sourceRoot":"","sources":["../../../../../../projects/gloww/src/lib/Components/auto-complete/auto-complete.component.ts","../../../../../../projects/gloww/src/lib/Components/auto-complete/auto-complete.component.html"],"names":[],"mappings":"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","sourcesContent":["import { catchError, debounceTime, distinctUntilChanged, filter, map, switchMap, tap } from 'rxjs/operators';\r\nimport { Component, OnInit, Input, AfterViewInit, Inject, ChangeDetectorRef, forwardRef, ViewEncapsulation } from '@angular/core';\r\nimport { ControlValueAccessor, UntypedFormBuilder, UntypedFormControl, UntypedFormGroup, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { Observable, of } from 'rxjs';\r\nimport { TranslateDefaultParser } from '@ngx-translate/core';\r\n\r\n@Component({\r\n  selector: 'gloww-auto-complete',\r\n  templateUrl: './auto-complete.component.html',\r\n  styleUrls: ['./auto-complete.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: forwardRef(() => AutoCompleteComponent)\r\n    }\r\n  ]\r\n})\r\nexport class AutoCompleteComponent implements ControlValueAccessor, OnInit, AfterViewInit {\r\n  @Input('value') _value: any = null;\r\n  @Input('objectName') objectName: any = null;\r\n  @Input('searchField') searchField: any = null;\r\n  @Input('returnField') returnField: any = null;\r\n  @Input('displayField') displayField: any = null;\r\n  @Input('displayExpr') displayExpr: any = null;\r\n  @Input('displayFct') displayFct: any = null;\r\n  @Input('placeHolder') placeHolder: any = null;\r\n  @Input('data') data: any = null;\r\n  onChange: any = () => { };\r\n  onTouched: any = () => { };\r\n  public items: any[] = [];\r\n  public error: string;\r\n\r\n  @Input() searchRequest: (obj?: any) => Observable<[]>;\r\n\r\n  public form: UntypedFormGroup;\r\n  glowwService: any;\r\n  resultCtrl: UntypedFormControl;\r\n  public parser = new TranslateDefaultParser();\r\n\r\n  constructor(@Inject('glowwService') glowwService: any, private formBuilder: UntypedFormBuilder, private ref: ChangeDetectorRef) {\r\n    this.glowwService = glowwService;\r\n    this.resultCtrl = new UntypedFormControl();\r\n    this.form = this.formBuilder.group({\r\n      __result: this.resultCtrl\r\n    });\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n\r\n  }\r\n\r\n  public options: any[] = [];//Observable<unknown>;\r\n  ngOnInit(): void {\r\n    //debugger;\r\n    this.searchRequest = this.glowwService[`search${this.objectName}`];\r\n    this.resultCtrl.valueChanges.pipe(\r\n      filter(res => res != null && res.length > 2),\r\n      distinctUntilChanged(),\r\n      debounceTime(250),\r\n      tap(() => { this.error = \"\"; this.options = []; }),\r\n      switchMap(searchStr => {\r\n        let searchObj = {};\r\n        if (this.data) {\r\n          Object.keys(this.data).forEach(k => {\r\n            searchObj[k] = this.data[k];\r\n          });\r\n        }\r\n        searchObj[this.searchField] = searchStr;\r\n        return this.searchRequest.call(this.glowwService, searchObj).pipe(\r\n          map(res => res),\r\n          catchError(err => {\r\n            this.error = err.message;\r\n            this.ref.markForCheck();\r\n            return of([])\r\n          })\r\n        )\r\n      })\r\n    ).subscribe(\r\n      {\r\n        next: (data: any[]) => {\r\n          this.options = data;\r\n          this.ref.markForCheck();\r\n        },\r\n        error: (error) => { this.error = error }\r\n      }\r\n    );\r\n  }\r\n\r\n\r\n  writeValue(val: any): void {\r\n    val && this.form.setValue({ __result: val }, { emitEvent: false });\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n    this.form.valueChanges.subscribe(data => {\r\n      if (this.returnField) {\r\n        this.onChange(this.form.value.__result[this.returnField]);\r\n      } else {\r\n        this.onChange(this.form.value.__result);\r\n      }\r\n    });\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  propagateChange = (_: any) => { };\r\n\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    const status = isDisabled ? 'disable' : 'enable';\r\n    //TODO\r\n  }\r\n\r\n  displayObj(item) {\r\n    if (!item) return null;\r\n    console.log(\"displayOf\");\r\n    if (this.displayField) {\r\n      return item[this.displayField];\r\n    } else if (this.displayExpr) {\r\n      return this.parser.interpolate(this.displayExpr.replace(/\\\\\\{/g, \"{\").replace(/\\\\\\}/g, \"}\"), item);\r\n      //return '?1' + this.parser.interpolate(\"{{Name}}\", { Name: \"test\" }) + '?2' + this.parser.interpolate(\"{{Name}}\", item)+'?3'+this.parser.interpolate(this.displayExpr.replace(/\\\\\\{/g,\"{\").replace(/\\\\\\}/g,\"}\"), item) +'?4'+ item;\r\n    } else if (this.displayFct) {\r\n      return this.displayFct(item);\r\n    }\r\n  }\r\n}\r\n\r\n","<div [formGroup]=\"form\" style=\"width:100%\" class=\"mainDiv\">\r\n    <div style=\"color:red\">{{error}}</div>\r\n    <mat-form-field style=\"width:100%\" class=\"autocff\">\r\n        <input type=\"text\" matInput formControlName=\"__result\" [matAutocomplete]=\"auto\" [placeholder]=\"placeHolder\">\r\n    </mat-form-field>\r\n    <mat-autocomplete #auto=\"matAutocomplete\" [displayWith]=\"displayObj.bind(this)\">\r\n        <mat-option *ngFor=\"let option of options\" [value]=\"option\" [innerHTML]=\"displayObj(option) | safeHtml\">\r\n        </mat-option>\r\n    </mat-autocomplete>\r\n</div>"]}
@@ -1,13 +1,51 @@
1
- import { Component, Input } from '@angular/core';
1
+ import { Component, Input, ViewChild, ViewEncapsulation } from '@angular/core';
2
2
  import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { CodemirrorComponent } from '@ctrl/ngx-codemirror';
4
+ import prettier from 'node_modules/prettier/esm/standalone.mjs';
5
+ import parserTypescript from 'node_modules/prettier/esm/parser-typescript.mjs';
6
+ import parserBabel from 'node_modules/prettier/esm/parser-babel.mjs';
3
7
  import * as i0 from "@angular/core";
4
- import * as i1 from "@ctrl/ngx-codemirror";
5
- import * as i2 from "@angular/forms";
8
+ import * as i1 from "./../../Services/snippets.service";
9
+ import * as i2 from "../../Services/gloww.service";
10
+ import * as i3 from "@angular/common";
11
+ import * as i4 from "@angular/forms";
12
+ import * as i5 from "@angular/material/form-field";
13
+ import * as i6 from "@angular/material/button";
14
+ import * as i7 from "@angular/material/select";
15
+ import * as i8 from "@angular/material/core";
16
+ import * as i9 from "@ctrl/ngx-codemirror";
17
+ import * as i10 from "@angular/flex-layout/flex";
6
18
  export class CodeEditorComponent {
7
- constructor() {
19
+ constructor(snippetsService, glowwService) {
20
+ this.snippetsService = snippetsService;
21
+ this.glowwService = glowwService;
8
22
  this._value = null;
23
+ this.display = null;
24
+ this.mode = "text/typescript";
25
+ this.formatterOptions = { useTabs: true, printWidth: 160 };
9
26
  this.onChange = () => { };
10
27
  this.onTouched = () => { };
28
+ this.resizable = true;
29
+ this.doc = null;
30
+ this.extraKeys = {
31
+ "Alt-K": function (cm) { alert('Alt-K'); cm.blockComment(cm.doc.getCursor('from'), cm.doc.getCursor('to')); /*cm.toggleComment();*/ },
32
+ "Shift-Alt-K": "toggleComment",
33
+ "Alt-N": this.autoFormatSelection.bind(this)
34
+ };
35
+ }
36
+ ngAfterViewInit() {
37
+ console.log(this.codeMirrorComponent);
38
+ console.log(this.codeMirrorComponent.codeMirror);
39
+ this.doc = this.codeMirrorComponent.codeMirror?.getDoc();
40
+ console.log(this.doc);
41
+ if (this.snippetsPath) {
42
+ this.snippetsService.getSnippets(this.snippetsPath.replace("/assets/", this.glowwService.baseHref + "/assets/")).subscribe((snippets) => {
43
+ if (!this.snippets) {
44
+ this.snippets = [];
45
+ }
46
+ snippets.forEach((snippet) => this.snippets.push(snippet));
47
+ });
48
+ }
11
49
  }
12
50
  get value() {
13
51
  return this._value;
@@ -18,7 +56,7 @@ export class CodeEditorComponent {
18
56
  this.onTouched();
19
57
  }
20
58
  writeValue(obj) {
21
- if (typeof (obj) === 'object') {
59
+ if (typeof (obj) === 'object' && obj != null) {
22
60
  this.value = JSON.stringify(obj);
23
61
  }
24
62
  else {
@@ -34,26 +72,84 @@ export class CodeEditorComponent {
34
72
  setDisabledState(isDisabled) {
35
73
  //throw new Error('Method not implemented.');
36
74
  }
75
+ insert() {
76
+ this.doc = this.codeMirrorComponent.codeMirror?.getDoc();
77
+ var cursor = this.doc.getCursor();
78
+ if (this.currentSnippet.code) {
79
+ this.doc.replaceRange(this.currentSnippet.code, cursor);
80
+ }
81
+ if (this.currentSnippet.externfile) {
82
+ this.snippetsService.getSnippetCode(this.currentSnippet.externfile).subscribe((code) => this.doc.replaceRange(code, cursor));
83
+ }
84
+ }
85
+ getSelectedRange(doc) {
86
+ return { from: doc.getCursor('from'), to: doc.getCursor('to') };
87
+ }
88
+ getFormatter() {
89
+ if (this.formatter)
90
+ return this.formatter;
91
+ if (this.mode.match(/typescript/)) {
92
+ return "typescript";
93
+ }
94
+ return null;
95
+ }
96
+ autoFormatSelection(cm) {
97
+ try {
98
+ const formatter = this.getFormatter();
99
+ if (!formatter) {
100
+ alert("no formatter defined for this code");
101
+ return;
102
+ }
103
+ let options = { ...this.formatterOptions };
104
+ options.parser = formatter;
105
+ options.plugins = [parserTypescript, parserBabel];
106
+ cm.doc.setValue(prettier.format(cm.doc.getValue(), options));
107
+ }
108
+ catch (ex) {
109
+ alert(`Unable to format this code, check Syntax`);
110
+ }
111
+ }
37
112
  }
38
- CodeEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: CodeEditorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
39
- CodeEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: CodeEditorComponent, selector: "gloww-code-editor", inputs: { _value: ["value", "_value"] }, providers: [
113
+ CodeEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: CodeEditorComponent, deps: [{ token: i1.SnippetsService }, { token: i2.GlowwService }], target: i0.ɵɵFactoryTarget.Component });
114
+ CodeEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.2", type: CodeEditorComponent, selector: "gloww-code-editor", inputs: { _value: ["value", "_value"], display: "display", mode: "mode", formatter: "formatter", formatterOptions: "formatterOptions", snippets: "snippets", snippetsPath: "snippetsPath" }, providers: [
40
115
  {
41
116
  provide: NG_VALUE_ACCESSOR,
42
117
  multi: true,
43
118
  useExisting: CodeEditorComponent
44
119
  }
45
- ], ngImport: i0, template: "<ngx-codemirror [(ngModel)]=\"value\" [options]=\"{lineNumbers: true,theme: 'eclipse', indentWithTabs:true,indentUnit: 4,matchBrackets: true, mode: 'text/typescript', fixedGutter:false}\">\r\n</ngx-codemirror>\r\n", styles: [".cm-tab{background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAAAMCAYAAAAkuj5RAAAAAXNSR0IArs4c6QAAAGFJREFUSMft1LsRQFAQheHPowAKoACx3IgEKtaEHujDjORSgWTH/ZOdnZOcM/sgk/kFFWY0qV8foQwS4MKBCS3qR6ixBJvElOobYAtivseIE120FaowJPN75GMu8j/LfMwNjh4HUpwg4LUAAAAASUVORK5CYII=);background-position:right;background-repeat:no-repeat}\n"], components: [{ type: i1.CodemirrorComponent, selector: "ngx-codemirror", inputs: ["className", "name", "autoFocus", "options", "preserveScrollPosition"], outputs: ["cursorActivity", "focusChange", "scroll", "drop"] }], directives: [{ type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
46
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: CodeEditorComponent, decorators: [{
120
+ ], viewQueries: [{ propertyName: "codeMirrorComponent", first: true, predicate: CodemirrorComponent, descendants: true }], ngImport: i0, template: "<div fxLayout=\"column\" fxFill fxLayoutAlign=\"strech\" class=\"mainDiv\">\r\n <mat-label>{{display}}</mat-label>\r\n <div *ngIf=\"snippets?.length\" fxLayout=\"row\">\r\n <mat-select [(ngModel)]=\"currentSnippet\" fxFlex>\r\n <mat-option *ngFor=\"let snippet of snippets\" [value]=\"snippet\">{{snippet.name}}</mat-option>\r\n </mat-select>\r\n <button mat-stroked-button color=\"primary\" type=\"button\" (click)=\"insert()\">Insert</button>\r\n </div>\r\n\r\n <ngx-codemirror [(ngModel)]=\"value\" [options]=\"{lineNumbers: true,theme: 'eclipse', indentWithTabs:true,indentUnit: 4,matchBrackets: true, mode: mode, fixedGutter:false, extraKeys: extraKeys}\" style=\"width:100%\">\r\n </ngx-codemirror>\r\n</div>", styles: [".CodeMirror{resize:both;padding:0;margin:0}.sameSize{padding:0;margin:0;border:1px solid}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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"] }, { kind: "directive", type: i5.MatLabel, selector: "mat-label" }, { kind: "component", type: i6.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i7.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i8.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "component", type: i9.CodemirrorComponent, selector: "ngx-codemirror", inputs: ["className", "name", "autoFocus", "options", "preserveScrollPosition"], outputs: ["cursorActivity", "focusChange", "scroll", "drop"] }, { kind: "directive", type: i10.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i10.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "directive", type: i10.FlexFillDirective, selector: "[fxFill], [fxFlexFill]" }, { kind: "directive", type: i10.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }], encapsulation: i0.ViewEncapsulation.None });
121
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: CodeEditorComponent, decorators: [{
47
122
  type: Component,
48
- args: [{ selector: 'gloww-code-editor', providers: [
123
+ args: [{ selector: 'gloww-code-editor', encapsulation: ViewEncapsulation.None, providers: [
49
124
  {
50
125
  provide: NG_VALUE_ACCESSOR,
51
126
  multi: true,
52
127
  useExisting: CodeEditorComponent
53
128
  }
54
- ], template: "<ngx-codemirror [(ngModel)]=\"value\" [options]=\"{lineNumbers: true,theme: 'eclipse', indentWithTabs:true,indentUnit: 4,matchBrackets: true, mode: 'text/typescript', fixedGutter:false}\">\r\n</ngx-codemirror>\r\n", styles: [".cm-tab{background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAAAMCAYAAAAkuj5RAAAAAXNSR0IArs4c6QAAAGFJREFUSMft1LsRQFAQheHPowAKoACx3IgEKtaEHujDjORSgWTH/ZOdnZOcM/sgk/kFFWY0qV8foQwS4MKBCS3qR6ixBJvElOobYAtivseIE120FaowJPN75GMu8j/LfMwNjh4HUpwg4LUAAAAASUVORK5CYII=);background-position:right;background-repeat:no-repeat}\n"] }]
55
- }], ctorParameters: function () { return []; }, propDecorators: { _value: [{
129
+ ], template: "<div fxLayout=\"column\" fxFill fxLayoutAlign=\"strech\" class=\"mainDiv\">\r\n <mat-label>{{display}}</mat-label>\r\n <div *ngIf=\"snippets?.length\" fxLayout=\"row\">\r\n <mat-select [(ngModel)]=\"currentSnippet\" fxFlex>\r\n <mat-option *ngFor=\"let snippet of snippets\" [value]=\"snippet\">{{snippet.name}}</mat-option>\r\n </mat-select>\r\n <button mat-stroked-button color=\"primary\" type=\"button\" (click)=\"insert()\">Insert</button>\r\n </div>\r\n\r\n <ngx-codemirror [(ngModel)]=\"value\" [options]=\"{lineNumbers: true,theme: 'eclipse', indentWithTabs:true,indentUnit: 4,matchBrackets: true, mode: mode, fixedGutter:false, extraKeys: extraKeys}\" style=\"width:100%\">\r\n </ngx-codemirror>\r\n</div>", styles: [".CodeMirror{resize:both;padding:0;margin:0}.sameSize{padding:0;margin:0;border:1px solid}\n"] }]
130
+ }], ctorParameters: function () { return [{ type: i1.SnippetsService }, { type: i2.GlowwService }]; }, propDecorators: { _value: [{
56
131
  type: Input,
57
132
  args: ['value']
133
+ }], display: [{
134
+ type: Input,
135
+ args: ['display']
136
+ }], mode: [{
137
+ type: Input,
138
+ args: ['mode']
139
+ }], formatter: [{
140
+ type: Input,
141
+ args: ['formatter']
142
+ }], formatterOptions: [{
143
+ type: Input,
144
+ args: ['formatterOptions']
145
+ }], snippets: [{
146
+ type: Input,
147
+ args: ['snippets']
148
+ }], snippetsPath: [{
149
+ type: Input,
150
+ args: ['snippetsPath']
151
+ }], codeMirrorComponent: [{
152
+ type: ViewChild,
153
+ args: [CodemirrorComponent]
58
154
  }] } });
59
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29kZS1lZGl0b3IuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZ2xvd3cvc3JjL2xpYi9Db21wb25lbnRzL2NvZGUtZWRpdG9yL2NvZGUtZWRpdG9yLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2dsb3d3L3NyYy9saWIvQ29tcG9uZW50cy9jb2RlLWVkaXRvci9jb2RlLWVkaXRvci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUN6RCxPQUFPLEVBQXdCLGlCQUFpQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7Ozs7QUFjekUsTUFBTSxPQUFPLG1CQUFtQjtJQUs5QjtRQUpnQixXQUFNLEdBQVEsSUFBSSxDQUFDO1FBQ25DLGFBQVEsR0FBUSxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFDMUIsY0FBUyxHQUFRLEdBQUcsRUFBRSxHQUFHLENBQUMsQ0FBQztJQUVYLENBQUM7SUFHakIsSUFBSSxLQUFLO1FBQ1AsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDO0lBQ3JCLENBQUM7SUFFRCxJQUFJLEtBQUssQ0FBQyxHQUFHO1FBQ1gsSUFBSSxDQUFDLE1BQU0sR0FBRyxHQUFHLENBQUM7UUFDbEIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUNuQixJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDbkIsQ0FBQztJQUNELFVBQVUsQ0FBQyxHQUFRO1FBQ2pCLElBQUksT0FBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLFFBQVEsRUFBRTtZQUM3QixJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLENBQUM7U0FDbEM7YUFBTTtZQUNMLElBQUksQ0FBQyxLQUFLLEdBQUcsR0FBRyxDQUFDO1NBQ2xCO0lBQ0gsQ0FBQztJQUNELGdCQUFnQixDQUFDLEVBQU87UUFDdEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUNELGlCQUFpQixDQUFDLEVBQU87UUFDdkIsSUFBSSxDQUFDLFNBQVMsR0FBRyxFQUFFLENBQUM7SUFDdEIsQ0FBQztJQUNELGdCQUFnQixDQUFFLFVBQW1CO1FBQ25DLDZDQUE2QztJQUMvQyxDQUFDOztnSEFoQ1UsbUJBQW1CO29HQUFuQixtQkFBbUIscUZBUm5CO1FBQ1Q7WUFDRSxPQUFPLEVBQUUsaUJBQWlCO1lBQzFCLEtBQUssRUFBRSxJQUFJO1lBQ1gsV0FBVyxFQUFFLG1CQUFtQjtTQUNqQztLQUNGLDBCQ2JILHVOQUVBOzJGRGFhLG1CQUFtQjtrQkFaL0IsU0FBUzsrQkFDRSxtQkFBbUIsYUFHbEI7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLGlCQUFpQjs0QkFDMUIsS0FBSyxFQUFFLElBQUk7NEJBQ1gsV0FBVyxxQkFBcUI7eUJBQ2pDO3FCQUNGOzBFQUdlLE1BQU07c0JBQXJCLEtBQUs7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb250cm9sVmFsdWVBY2Nlc3NvciwgTkdfVkFMVUVfQUNDRVNTT1IgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2dsb3d3LWNvZGUtZWRpdG9yJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vY29kZS1lZGl0b3IuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2NvZGUtZWRpdG9yLmNvbXBvbmVudC5jc3MnXSxcclxuICBwcm92aWRlcnM6IFtcclxuICAgIHtcclxuICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXHJcbiAgICAgIG11bHRpOiB0cnVlLFxyXG4gICAgICB1c2VFeGlzdGluZzogQ29kZUVkaXRvckNvbXBvbmVudFxyXG4gICAgfVxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIENvZGVFZGl0b3JDb21wb25lbnQgaW1wbGVtZW50cyBDb250cm9sVmFsdWVBY2Nlc3NvciB7XHJcbiAgQElucHV0KCd2YWx1ZScpIF92YWx1ZTogYW55ID0gbnVsbDtcclxuICBvbkNoYW5nZTogYW55ID0gKCkgPT4geyB9O1xyXG4gIG9uVG91Y2hlZDogYW55ID0gKCkgPT4geyB9O1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHsgfVxyXG5cclxuXHJcbiAgZ2V0IHZhbHVlKCkge1xyXG4gICAgcmV0dXJuIHRoaXMuX3ZhbHVlO1xyXG4gIH1cclxuXHJcbiAgc2V0IHZhbHVlKHZhbCkge1xyXG4gICAgdGhpcy5fdmFsdWUgPSB2YWw7XHJcbiAgICB0aGlzLm9uQ2hhbmdlKHZhbCk7XHJcbiAgICB0aGlzLm9uVG91Y2hlZCgpO1xyXG4gIH1cclxuICB3cml0ZVZhbHVlKG9iajogYW55KTogdm9pZCB7XHJcbiAgICBpZiAodHlwZW9mIChvYmopID09PSAnb2JqZWN0Jykge1xyXG4gICAgICB0aGlzLnZhbHVlID0gSlNPTi5zdHJpbmdpZnkob2JqKTtcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIHRoaXMudmFsdWUgPSBvYmo7XHJcbiAgICB9XHJcbiAgfVxyXG4gIHJlZ2lzdGVyT25DaGFuZ2UoZm46IGFueSk6IHZvaWQge1xyXG4gICAgdGhpcy5vbkNoYW5nZSA9IGZuO1xyXG4gIH1cclxuICByZWdpc3Rlck9uVG91Y2hlZChmbjogYW55KTogdm9pZCB7XHJcbiAgICB0aGlzLm9uVG91Y2hlZCA9IGZuO1xyXG4gIH1cclxuICBzZXREaXNhYmxlZFN0YXRlPyhpc0Rpc2FibGVkOiBib29sZWFuKTogdm9pZCB7XHJcbiAgICAvL3Rocm93IG5ldyBFcnJvcignTWV0aG9kIG5vdCBpbXBsZW1lbnRlZC4nKTtcclxuICB9XHJcblxyXG59XHJcbiIsIjxuZ3gtY29kZW1pcnJvciBbKG5nTW9kZWwpXT1cInZhbHVlXCIgW29wdGlvbnNdPVwie2xpbmVOdW1iZXJzOiB0cnVlLHRoZW1lOiAnZWNsaXBzZScsIGluZGVudFdpdGhUYWJzOnRydWUsaW5kZW50VW5pdDogNCxtYXRjaEJyYWNrZXRzOiB0cnVlLCBtb2RlOiAndGV4dC90eXBlc2NyaXB0JywgZml4ZWRHdXR0ZXI6ZmFsc2V9XCI+XHJcbjwvbmd4LWNvZGVtaXJyb3I+XHJcbiJdfQ==
155
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"code-editor.component.js","sourceRoot":"","sources":["../../../../../../projects/gloww/src/lib/Components/code-editor/code-editor.component.ts","../../../../../../projects/gloww/src/lib/Components/code-editor/code-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Snippet, SnippetsService } from './../../Services/snippets.service';\r\nimport { Component, Input, OnInit, ViewChild, AfterViewInit, ViewEncapsulation } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { CodemirrorComponent } from '@ctrl/ngx-codemirror';\r\nimport { ResizedEvent } from 'angular-resize-event';\r\nimport { GlowwService } from '../../Services/gloww.service';\r\nimport prettier from 'node_modules/prettier/esm/standalone.mjs';\r\nimport parserTypescript from 'node_modules/prettier/esm/parser-typescript.mjs'\r\nimport parserBabel from 'node_modules/prettier/esm/parser-babel.mjs'\r\n\r\n@Component({\r\n  selector: 'gloww-code-editor',\r\n  templateUrl: './code-editor.component.html',\r\n  styleUrls: ['./code-editor.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: CodeEditorComponent\r\n    }\r\n  ]\r\n})\r\nexport class CodeEditorComponent implements ControlValueAccessor, AfterViewInit {\r\n  @Input('value') _value: any = null;\r\n  @Input('display') display: string = null;\r\n  @Input('mode') mode: any = \"text/typescript\";\r\n  @Input('formatter') formatter?: string;\r\n  @Input('formatterOptions') formatterOptions?: any = { useTabs: true, printWidth: 160 };\r\n  @Input('snippets') snippets?: Snippet[];\r\n  @Input('snippetsPath') snippetsPath?: string;\r\n  @ViewChild(CodemirrorComponent) codeMirrorComponent: CodemirrorComponent;\r\n\r\n  onChange: any = () => { };\r\n  onTouched: any = () => { };\r\n  resizable = true;\r\n\r\n  currentSnippet?: Snippet;\r\n  doc: any = null;\r\n  extraKeys = {\r\n    \"Alt-K\": function(cm) { alert('Alt-K'); cm.blockComment(cm.doc.getCursor('from'), cm.doc.getCursor('to'));/*cm.toggleComment();*/ },\r\n    \"Shift-Alt-K\": \"toggleComment\",\r\n    \"Alt-N\": this.autoFormatSelection.bind(this)\r\n  };\r\n\r\n  constructor(private snippetsService: SnippetsService, private glowwService: GlowwService) {\r\n\r\n  }\r\n  ngAfterViewInit(): void {\r\n    console.log(this.codeMirrorComponent);\r\n    console.log(this.codeMirrorComponent.codeMirror);\r\n    this.doc = this.codeMirrorComponent.codeMirror?.getDoc();\r\n    console.log(this.doc);\r\n    if (this.snippetsPath) {\r\n      this.snippetsService.getSnippets(this.snippetsPath.replace(\"/assets/\", this.glowwService.baseHref + \"/assets/\")).subscribe((snippets) => {\r\n        if (!this.snippets) {\r\n          this.snippets = [];\r\n        }\r\n        snippets.forEach((snippet) => this.snippets.push(snippet));\r\n      });\r\n    }\r\n  }\r\n\r\n\r\n  get value() {\r\n    return this._value;\r\n  }\r\n\r\n  set value(val) {\r\n    this._value = val;\r\n    this.onChange(val);\r\n    this.onTouched();\r\n  }\r\n  writeValue(obj: any): void {\r\n    if (typeof (obj) === 'object' && obj != null) {\r\n      this.value = JSON.stringify(obj);\r\n    } else {\r\n      this.value = obj;\r\n    }\r\n  }\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    //throw new Error('Method not implemented.');\r\n  }\r\n  insert() {\r\n    this.doc = this.codeMirrorComponent.codeMirror?.getDoc();\r\n    var cursor = this.doc.getCursor();\r\n    if (this.currentSnippet.code) {\r\n      this.doc.replaceRange(this.currentSnippet.code, cursor);\r\n    }\r\n    if (this.currentSnippet.externfile) {\r\n      this.snippetsService.getSnippetCode(this.currentSnippet.externfile).subscribe((code) => this.doc.replaceRange(code, cursor));\r\n    }\r\n  }\r\n\r\n  getSelectedRange(doc) {\r\n    return { from: doc.getCursor('from'), to: doc.getCursor('to') };\r\n  }\r\n\r\n  getFormatter(): string {\r\n    if (this.formatter) return this.formatter;\r\n    if (this.mode.match(/typescript/)) { return \"typescript\"; }\r\n    return null;\r\n  }\r\n\r\n\r\n  autoFormatSelection(cm) {\r\n    try {\r\n      const formatter = this.getFormatter();\r\n      if (!formatter) {\r\n        alert(\"no formatter defined for this code\");\r\n        return;\r\n      }\r\n      let options: any = { ...this.formatterOptions };\r\n      options.parser = formatter;\r\n      options.plugins = [parserTypescript, parserBabel]\r\n\r\n      cm.doc.setValue(prettier.format(cm.doc.getValue(), options));\r\n    } catch (ex) {\r\n      alert(`Unable to format this code, check Syntax`);\r\n    }\r\n  }\r\n}\r\n","<div fxLayout=\"column\" fxFill fxLayoutAlign=\"strech\" class=\"mainDiv\">\r\n    <mat-label>{{display}}</mat-label>\r\n    <div *ngIf=\"snippets?.length\" fxLayout=\"row\">\r\n        <mat-select [(ngModel)]=\"currentSnippet\" fxFlex>\r\n            <mat-option *ngFor=\"let snippet of snippets\" [value]=\"snippet\">{{snippet.name}}</mat-option>\r\n        </mat-select>\r\n        <button mat-stroked-button color=\"primary\" type=\"button\" (click)=\"insert()\">Insert</button>\r\n    </div>\r\n\r\n    <ngx-codemirror [(ngModel)]=\"value\" [options]=\"{lineNumbers: true,theme: 'eclipse', indentWithTabs:true,indentUnit: 4,matchBrackets: true, mode: mode, fixedGutter:false, extraKeys: extraKeys}\" style=\"width:100%\">\r\n    </ngx-codemirror>\r\n</div>"]}
@@ -2,8 +2,8 @@ import { Component, Inject } from '@angular/core';
2
2
  import { MAT_DIALOG_DATA } from '@angular/material/dialog';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "@angular/material/dialog";
5
- import * as i2 from "@angular/material/button";
6
- import * as i3 from "@angular/common";
5
+ import * as i2 from "@angular/common";
6
+ import * as i3 from "@angular/material/button";
7
7
  import * as i4 from "../../Pipes/safe-html.pipe";
8
8
  export class ConfirmationComponent {
9
9
  constructor(dialogRef, data) {
@@ -23,11 +23,11 @@ export class ConfirmationComponent {
23
23
  this.dialogRef.close(false);
24
24
  }
25
25
  }
26
- ConfirmationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ConfirmationComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
27
- ConfirmationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: ConfirmationComponent, selector: "glw-confirmation", ngImport: i0, template: "<h1 mat-dialog-title>\r\n {{title}}\r\n</h1>\r\n\r\n<div mat-dialog-content>\r\n <p [innerHTML]=\"message | safeHtml\"></p>\r\n</div>\r\n\r\n<mat-dialog-actions *ngIf=\"mode==='confirmation'\">\r\n <button mat-button (click)=\"onDismiss()\">No</button>\r\n <button mat-raised-button color=\"primary\" (click)=\"onConfirm()\">Yes</button>\r\n</mat-dialog-actions>\r\n<mat-dialog-actions *ngIf=\"mode==='alert'\">\r\n <button mat-raised-button color=\"primary\" (click)=\"onConfirm()\">OK</button>\r\n</mat-dialog-actions>\r\n", styles: [""], components: [{ type: i2.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], directives: [{ type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }], pipes: { "safeHtml": i4.SafeHtmlPipe } });
28
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ConfirmationComponent, decorators: [{
26
+ ConfirmationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: ConfirmationComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
27
+ ConfirmationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.2", type: ConfirmationComponent, selector: "glw-confirmation", ngImport: i0, template: "<h1 mat-dialog-title>\r\n {{title}}\r\n</h1>\r\n\r\n<div mat-dialog-content>\r\n <p [innerHTML]=\"message | safeHtml\"></p>\r\n</div>\r\n\r\n<mat-dialog-actions *ngIf=\"mode==='confirmation'\">\r\n <button mat-button (click)=\"onDismiss()\">No</button>\r\n <button mat-raised-button color=\"primary\" (click)=\"onConfirm()\">Yes</button>\r\n</mat-dialog-actions>\r\n<mat-dialog-actions *ngIf=\"mode==='alert'\">\r\n <button mat-raised-button color=\"primary\" (click)=\"onConfirm()\">OK</button>\r\n</mat-dialog-actions>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "component", type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "pipe", type: i4.SafeHtmlPipe, name: "safeHtml" }] });
28
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: ConfirmationComponent, decorators: [{
29
29
  type: Component,
30
- args: [{ selector: 'glw-confirmation', template: "<h1 mat-dialog-title>\r\n {{title}}\r\n</h1>\r\n\r\n<div mat-dialog-content>\r\n <p [innerHTML]=\"message | safeHtml\"></p>\r\n</div>\r\n\r\n<mat-dialog-actions *ngIf=\"mode==='confirmation'\">\r\n <button mat-button (click)=\"onDismiss()\">No</button>\r\n <button mat-raised-button color=\"primary\" (click)=\"onConfirm()\">Yes</button>\r\n</mat-dialog-actions>\r\n<mat-dialog-actions *ngIf=\"mode==='alert'\">\r\n <button mat-raised-button color=\"primary\" (click)=\"onConfirm()\">OK</button>\r\n</mat-dialog-actions>\r\n", styles: [""] }]
30
+ args: [{ selector: 'glw-confirmation', template: "<h1 mat-dialog-title>\r\n {{title}}\r\n</h1>\r\n\r\n<div mat-dialog-content>\r\n <p [innerHTML]=\"message | safeHtml\"></p>\r\n</div>\r\n\r\n<mat-dialog-actions *ngIf=\"mode==='confirmation'\">\r\n <button mat-button (click)=\"onDismiss()\">No</button>\r\n <button mat-raised-button color=\"primary\" (click)=\"onConfirm()\">Yes</button>\r\n</mat-dialog-actions>\r\n<mat-dialog-actions *ngIf=\"mode==='alert'\">\r\n <button mat-raised-button color=\"primary\" (click)=\"onConfirm()\">OK</button>\r\n</mat-dialog-actions>\r\n" }]
31
31
  }], ctorParameters: function () { return [{ type: i1.MatDialogRef }, { type: ConfirmationModel, decorators: [{
32
32
  type: Inject,
33
33
  args: [MAT_DIALOG_DATA]
@@ -0,0 +1,84 @@
1
+ import { Component, Input } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import * as moment from 'moment';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/common";
6
+ import * as i2 from "@angular/forms";
7
+ import * as i3 from "@angular/material/form-field";
8
+ import * as i4 from "@angular/material/input";
9
+ import * as i5 from "@angular/material/datepicker";
10
+ import * as i6 from "@angular-material-components/datetime-picker";
11
+ export class DatetimeComponent {
12
+ constructor() {
13
+ this._value = null;
14
+ this.display = null;
15
+ this.placeHolder = null;
16
+ this.mode = 'date';
17
+ this.showSpinners = true;
18
+ this.showSeconds = false;
19
+ this.disableMinute = false;
20
+ this.onChange = () => { };
21
+ this.onTouched = () => { };
22
+ }
23
+ get value() {
24
+ return this._value;
25
+ }
26
+ set value(val) {
27
+ this._value = val;
28
+ let dt = this._value;
29
+ if (typeof (this._value) === 'string') {
30
+ dt = moment(this._value).toISOString();
31
+ }
32
+ this.onChange(dt);
33
+ this.onTouched();
34
+ }
35
+ writeValue(obj) {
36
+ this.value = obj;
37
+ }
38
+ registerOnChange(fn) {
39
+ this.onChange = fn;
40
+ }
41
+ registerOnTouched(fn) {
42
+ this.onTouched = fn;
43
+ }
44
+ setDisabledState(isDisabled) {
45
+ //throw new Error('Method not implemented.');
46
+ }
47
+ }
48
+ DatetimeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DatetimeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
49
+ DatetimeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.2", type: DatetimeComponent, selector: "gloww-datetime", inputs: { _value: ["value", "_value"], display: "display", placeHolder: "placeHolder", mode: "mode", showSpinners: "showSpinners", showSeconds: "showSeconds", disableMinute: "disableMinute" }, providers: [
50
+ {
51
+ provide: NG_VALUE_ACCESSOR,
52
+ multi: true,
53
+ useExisting: DatetimeComponent
54
+ }
55
+ ], ngImport: i0, template: "<div style=\"width:100%\">\r\n <mat-form-field *ngIf=\"mode==='date'\">\r\n <mat-label>{{display}}</mat-label>\r\n <input matInput [matDatepicker]=\"picker\" [placeholder]=\"placeHolder\" [(ngModel)]=\"value\">\r\n <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\r\n <mat-datepicker #picker></mat-datepicker>\r\n </mat-form-field>\r\n\r\n <mat-form-field *ngIf=\"mode==='datetime'\">\r\n <mat-label>{{display}}</mat-label>\r\n <input matInput [ngxMatDatetimePicker]=\"pickerDT\" [placeholder]=\"placeHolder\" [(ngModel)]=\"value\">\r\n <mat-datepicker-toggle matSuffix [for]=\"$any(pickerDT)\"></mat-datepicker-toggle>\r\n <ngx-mat-datetime-picker #pickerDT [showSpinners]=\"showSpinners\" [showSeconds]=\"showSeconds\" [touchUi]=\"true\" [disableMinute]=\"disableMinute\">\r\n </ngx-mat-datetime-picker>\r\n </mat-form-field>\r\n</div>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix]" }, { kind: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i5.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i5.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i5.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "component", type: i6.NgxMatDatetimePicker, selector: "ngx-mat-datetime-picker", inputs: ["calendarHeaderComponent", "startAt", "startView", "defaultColor", "color", "touchUi", "hideTime", "disabled", "panelClass", "dateClass", "opened", "showSpinners", "showSeconds", "stepHour", "stepMinute", "stepSecond", "enableMeridian", "disableMinute", "defaultTime"], outputs: ["yearSelected", "monthSelected", "opened", "closed"], exportAs: ["ngxMatDatetimePicker"] }, { kind: "directive", type: i6.NgxMatDatetimeInput, selector: "input[ngxMatDatetimePicker]", inputs: ["ngxMatDatetimePicker", "ngxMatDatetimePickerFilter", "value", "min", "max", "disabled"], outputs: ["dateChange", "dateInput"], exportAs: ["ngxMatDatetimePickerInput"] }] });
56
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: DatetimeComponent, decorators: [{
57
+ type: Component,
58
+ args: [{ selector: 'gloww-datetime', providers: [
59
+ {
60
+ provide: NG_VALUE_ACCESSOR,
61
+ multi: true,
62
+ useExisting: DatetimeComponent
63
+ }
64
+ ], template: "<div style=\"width:100%\">\r\n <mat-form-field *ngIf=\"mode==='date'\">\r\n <mat-label>{{display}}</mat-label>\r\n <input matInput [matDatepicker]=\"picker\" [placeholder]=\"placeHolder\" [(ngModel)]=\"value\">\r\n <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\r\n <mat-datepicker #picker></mat-datepicker>\r\n </mat-form-field>\r\n\r\n <mat-form-field *ngIf=\"mode==='datetime'\">\r\n <mat-label>{{display}}</mat-label>\r\n <input matInput [ngxMatDatetimePicker]=\"pickerDT\" [placeholder]=\"placeHolder\" [(ngModel)]=\"value\">\r\n <mat-datepicker-toggle matSuffix [for]=\"$any(pickerDT)\"></mat-datepicker-toggle>\r\n <ngx-mat-datetime-picker #pickerDT [showSpinners]=\"showSpinners\" [showSeconds]=\"showSeconds\" [touchUi]=\"true\" [disableMinute]=\"disableMinute\">\r\n </ngx-mat-datetime-picker>\r\n </mat-form-field>\r\n</div>\r\n" }]
65
+ }], ctorParameters: function () { return []; }, propDecorators: { _value: [{
66
+ type: Input,
67
+ args: ['value']
68
+ }], display: [{
69
+ type: Input,
70
+ args: ['display']
71
+ }], placeHolder: [{
72
+ type: Input,
73
+ args: ['placeHolder']
74
+ }], mode: [{
75
+ type: Input,
76
+ args: ['mode']
77
+ }], showSpinners: [{
78
+ type: Input
79
+ }], showSeconds: [{
80
+ type: Input
81
+ }], disableMinute: [{
82
+ type: Input
83
+ }] } });
84
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXRpbWUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZ2xvd3cvc3JjL2xpYi9Db21wb25lbnRzL2RhdGV0aW1lL2RhdGV0aW1lLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2dsb3d3L3NyYy9saWIvQ29tcG9uZW50cy9kYXRldGltZS9kYXRldGltZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUN6RCxPQUFPLEVBQXdCLGlCQUFpQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDekUsT0FBTyxLQUFLLE1BQU0sTUFBTSxRQUFRLENBQUM7Ozs7Ozs7O0FBY2pDLE1BQU0sT0FBTyxpQkFBaUI7SUFZNUI7UUFYZ0IsV0FBTSxHQUFRLElBQUksQ0FBQztRQUNqQixZQUFPLEdBQVEsSUFBSSxDQUFDO1FBQ2hCLGdCQUFXLEdBQVEsSUFBSSxDQUFDO1FBQy9CLFNBQUksR0FBVyxNQUFNLENBQUM7UUFDNUIsaUJBQVksR0FBWSxJQUFJLENBQUM7UUFDN0IsZ0JBQVcsR0FBWSxLQUFLLENBQUM7UUFDN0Isa0JBQWEsR0FBWSxLQUFLLENBQUM7UUFFeEMsYUFBUSxHQUFRLEdBQUcsRUFBRSxHQUFHLENBQUMsQ0FBQztRQUMxQixjQUFTLEdBQVEsR0FBRyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBRVgsQ0FBQztJQUdqQixJQUFJLEtBQUs7UUFDUCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUM7SUFDckIsQ0FBQztJQUVELElBQUksS0FBSyxDQUFDLEdBQUc7UUFDWCxJQUFJLENBQUMsTUFBTSxHQUFHLEdBQUcsQ0FBQztRQUNsQixJQUFJLEVBQUUsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDO1FBQ3JCLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxRQUFRLEVBQUU7WUFDckMsRUFBRSxHQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFtQixDQUFDLFdBQVcsRUFBRSxDQUFDO1NBQzNEO1FBQ0QsSUFBSSxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUNsQixJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDbkIsQ0FBQztJQUNELFVBQVUsQ0FBQyxHQUFRO1FBQ2pCLElBQUksQ0FBQyxLQUFLLEdBQUcsR0FBRyxDQUFDO0lBQ25CLENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxFQUFPO1FBQ3RCLElBQUksQ0FBQyxRQUFRLEdBQUcsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFDRCxpQkFBaUIsQ0FBQyxFQUFPO1FBQ3ZCLElBQUksQ0FBQyxTQUFTLEdBQUcsRUFBRSxDQUFDO0lBQ3RCLENBQUM7SUFDRCxnQkFBZ0IsQ0FBRSxVQUFtQjtRQUNuQyw2Q0FBNkM7SUFDL0MsQ0FBQzs7OEdBeENVLGlCQUFpQjtrR0FBakIsaUJBQWlCLDBPQVJqQjtRQUNUO1lBQ0UsT0FBTyxFQUFFLGlCQUFpQjtZQUMxQixLQUFLLEVBQUUsSUFBSTtZQUNYLFdBQVcsRUFBRSxpQkFBaUI7U0FDL0I7S0FDRiwwQkNkSCxnN0JBZ0JBOzJGREFhLGlCQUFpQjtrQkFaN0IsU0FBUzsrQkFDRSxnQkFBZ0IsYUFHZjt3QkFDVDs0QkFDRSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixLQUFLLEVBQUUsSUFBSTs0QkFDWCxXQUFXLG1CQUFtQjt5QkFDL0I7cUJBQ0Y7MEVBR2UsTUFBTTtzQkFBckIsS0FBSzt1QkFBQyxPQUFPO2dCQUNJLE9BQU87c0JBQXhCLEtBQUs7dUJBQUMsU0FBUztnQkFDTSxXQUFXO3NCQUFoQyxLQUFLO3VCQUFDLGFBQWE7Z0JBQ0wsSUFBSTtzQkFBbEIsS0FBSzt1QkFBQyxNQUFNO2dCQUNKLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0ICogYXMgbW9tZW50IGZyb20gJ21vbWVudCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2dsb3d3LWRhdGV0aW1lJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vZGF0ZXRpbWUuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2RhdGV0aW1lLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgcHJvdmlkZXJzOiBbXHJcbiAgICB7XHJcbiAgICAgIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxyXG4gICAgICBtdWx0aTogdHJ1ZSxcclxuICAgICAgdXNlRXhpc3Rpbmc6IERhdGV0aW1lQ29tcG9uZW50XHJcbiAgICB9XHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgRGF0ZXRpbWVDb21wb25lbnQgaW1wbGVtZW50cyBDb250cm9sVmFsdWVBY2Nlc3NvciB7XHJcbiAgQElucHV0KCd2YWx1ZScpIF92YWx1ZTogYW55ID0gbnVsbDtcclxuICBASW5wdXQoJ2Rpc3BsYXknKSBkaXNwbGF5OiBhbnkgPSBudWxsO1xyXG4gIEBJbnB1dCgncGxhY2VIb2xkZXInKSBwbGFjZUhvbGRlcjogYW55ID0gbnVsbDtcclxuICBASW5wdXQoJ21vZGUnKSBtb2RlOiBzdHJpbmcgPSAnZGF0ZSc7XHJcbiAgQElucHV0KCkgc2hvd1NwaW5uZXJzOiBib29sZWFuID0gdHJ1ZTtcclxuICBASW5wdXQoKSBzaG93U2Vjb25kczogYm9vbGVhbiA9IGZhbHNlO1xyXG4gIEBJbnB1dCgpIGRpc2FibGVNaW51dGU6IGJvb2xlYW4gPSBmYWxzZTtcclxuXHJcbiAgb25DaGFuZ2U6IGFueSA9ICgpID0+IHsgfTtcclxuICBvblRvdWNoZWQ6IGFueSA9ICgpID0+IHsgfTtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcblxyXG4gIGdldCB2YWx1ZSgpIHtcclxuICAgIHJldHVybiB0aGlzLl92YWx1ZTtcclxuICB9XHJcblxyXG4gIHNldCB2YWx1ZSh2YWwpIHtcclxuICAgIHRoaXMuX3ZhbHVlID0gdmFsO1xyXG4gICAgbGV0IGR0ID0gdGhpcy5fdmFsdWU7XHJcbiAgICBpZiAodHlwZW9mICh0aGlzLl92YWx1ZSkgPT09ICdzdHJpbmcnKSB7XHJcbiAgICAgIGR0ID0gKG1vbWVudCh0aGlzLl92YWx1ZSkgYXMgbW9tZW50Lk1vbWVudCkudG9JU09TdHJpbmcoKTtcclxuICAgIH1cclxuICAgIHRoaXMub25DaGFuZ2UoZHQpO1xyXG4gICAgdGhpcy5vblRvdWNoZWQoKTtcclxuICB9XHJcbiAgd3JpdGVWYWx1ZShvYmo6IGFueSk6IHZvaWQge1xyXG4gICAgdGhpcy52YWx1ZSA9IG9iajtcclxuICB9XHJcblxyXG4gIHJlZ2lzdGVyT25DaGFuZ2UoZm46IGFueSk6IHZvaWQge1xyXG4gICAgdGhpcy5vbkNoYW5nZSA9IGZuO1xyXG4gIH1cclxuICByZWdpc3Rlck9uVG91Y2hlZChmbjogYW55KTogdm9pZCB7XHJcbiAgICB0aGlzLm9uVG91Y2hlZCA9IGZuO1xyXG4gIH1cclxuICBzZXREaXNhYmxlZFN0YXRlPyhpc0Rpc2FibGVkOiBib29sZWFuKTogdm9pZCB7XHJcbiAgICAvL3Rocm93IG5ldyBFcnJvcignTWV0aG9kIG5vdCBpbXBsZW1lbnRlZC4nKTtcclxuICB9XHJcbn1cclxuIiwiPGRpdiBzdHlsZT1cIndpZHRoOjEwMCVcIj5cclxuICAgIDxtYXQtZm9ybS1maWVsZCAqbmdJZj1cIm1vZGU9PT0nZGF0ZSdcIj5cclxuICAgICAgICA8bWF0LWxhYmVsPnt7ZGlzcGxheX19PC9tYXQtbGFiZWw+XHJcbiAgICAgICAgPGlucHV0IG1hdElucHV0IFttYXREYXRlcGlja2VyXT1cInBpY2tlclwiIFtwbGFjZWhvbGRlcl09XCJwbGFjZUhvbGRlclwiIFsobmdNb2RlbCldPVwidmFsdWVcIj5cclxuICAgICAgICA8bWF0LWRhdGVwaWNrZXItdG9nZ2xlIG1hdFN1ZmZpeCBbZm9yXT1cInBpY2tlclwiPjwvbWF0LWRhdGVwaWNrZXItdG9nZ2xlPlxyXG4gICAgICAgIDxtYXQtZGF0ZXBpY2tlciAjcGlja2VyPjwvbWF0LWRhdGVwaWNrZXI+XHJcbiAgICA8L21hdC1mb3JtLWZpZWxkPlxyXG5cclxuICAgIDxtYXQtZm9ybS1maWVsZCAqbmdJZj1cIm1vZGU9PT0nZGF0ZXRpbWUnXCI+XHJcbiAgICAgICAgPG1hdC1sYWJlbD57e2Rpc3BsYXl9fTwvbWF0LWxhYmVsPlxyXG4gICAgICAgIDxpbnB1dCBtYXRJbnB1dCBbbmd4TWF0RGF0ZXRpbWVQaWNrZXJdPVwicGlja2VyRFRcIiBbcGxhY2Vob2xkZXJdPVwicGxhY2VIb2xkZXJcIiBbKG5nTW9kZWwpXT1cInZhbHVlXCI+XHJcbiAgICAgICAgPG1hdC1kYXRlcGlja2VyLXRvZ2dsZSBtYXRTdWZmaXggW2Zvcl09XCIkYW55KHBpY2tlckRUKVwiPjwvbWF0LWRhdGVwaWNrZXItdG9nZ2xlPlxyXG4gICAgICAgIDxuZ3gtbWF0LWRhdGV0aW1lLXBpY2tlciAjcGlja2VyRFQgW3Nob3dTcGlubmVyc109XCJzaG93U3Bpbm5lcnNcIiBbc2hvd1NlY29uZHNdPVwic2hvd1NlY29uZHNcIiBbdG91Y2hVaV09XCJ0cnVlXCIgW2Rpc2FibGVNaW51dGVdPVwiZGlzYWJsZU1pbnV0ZVwiPlxyXG4gICAgICAgIDwvbmd4LW1hdC1kYXRldGltZS1waWNrZXI+XHJcbiAgICA8L21hdC1mb3JtLWZpZWxkPlxyXG48L2Rpdj5cclxuIl19