@gloww/gloww 0.9.0-beta.5 → 0.9.0-beta.52
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/esm2020/lib/Components/auto-complete/auto-complete.component.mjs +151 -0
- package/esm2020/lib/Components/code-editor/code-editor.component.mjs +8 -4
- package/esm2020/lib/Components/datetime/datetime.component.mjs +84 -0
- package/esm2020/lib/Components/display-objects/display-objects.component.mjs +172 -50
- package/esm2020/lib/Components/download-progress/download-progress.component.mjs +4 -6
- package/esm2020/lib/Components/dummy/dummy.component.mjs +14 -0
- package/esm2020/lib/Components/menu-list-item/menu-list-item.component.mjs +38 -30
- package/esm2020/lib/Components/select/select.component.mjs +123 -0
- package/esm2020/lib/Components/upload-file/upload-file.component.mjs +10 -3
- package/esm2020/lib/Guards/has-unsaved-data.guard.mjs +29 -0
- package/esm2020/lib/Guards/ihas-unsaved-data.mjs +2 -0
- package/esm2020/lib/Models/nav-item.mjs +1 -1
- package/esm2020/lib/Services/folder.service.mjs +5 -1
- package/esm2020/lib/Services/gloww.service.mjs +53 -14
- package/esm2020/lib/gloww.module.mjs +58 -9
- package/esm2020/public-api.mjs +8 -1
- package/fesm2015/gloww-gloww.mjs +729 -126
- package/fesm2015/gloww-gloww.mjs.map +1 -1
- package/fesm2020/gloww-gloww.mjs +710 -123
- package/fesm2020/gloww-gloww.mjs.map +1 -1
- package/lib/Components/auto-complete/auto-complete.component.d.ts +39 -0
- package/lib/Components/code-editor/code-editor.component.d.ts +2 -1
- package/lib/Components/datetime/datetime.component.d.ts +22 -0
- package/lib/Components/display-objects/display-objects.component.d.ts +18 -9
- package/lib/Components/dummy/dummy.component.d.ts +8 -0
- package/lib/Components/menu-list-item/menu-list-item.component.d.ts +11 -3
- package/lib/Components/select/select.component.d.ts +33 -0
- package/lib/Guards/has-unsaved-data.guard.d.ts +8 -0
- package/lib/Guards/ihas-unsaved-data.d.ts +3 -0
- package/lib/Models/nav-item.d.ts +2 -1
- package/lib/Services/folder.service.d.ts +1 -0
- package/lib/Services/gloww.service.d.ts +14 -3
- package/lib/gloww.module.d.ts +32 -18
- package/package.json +5 -2
- package/public-api.d.ts +7 -0
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
import { catchError, debounceTime, distinctUntilChanged, filter, map, switchMap, tap } from 'rxjs/operators';
|
|
2
|
+
import { Component, Input, Inject, forwardRef } from '@angular/core';
|
|
3
|
+
import { FormControl, 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/material/form-field";
|
|
9
|
+
import * as i3 from "@angular/material/autocomplete";
|
|
10
|
+
import * as i4 from "@angular/material/core";
|
|
11
|
+
import * as i5 from "@angular/material/input";
|
|
12
|
+
import * as i6 from "@angular/common";
|
|
13
|
+
export class AutoCompleteComponent {
|
|
14
|
+
constructor(glowwService, formBuilder, ref) {
|
|
15
|
+
this.formBuilder = formBuilder;
|
|
16
|
+
this.ref = ref;
|
|
17
|
+
this._value = null;
|
|
18
|
+
this.objectName = null;
|
|
19
|
+
this.searchField = null;
|
|
20
|
+
this.returnField = null;
|
|
21
|
+
this.displayField = null;
|
|
22
|
+
this.displayExpr = null;
|
|
23
|
+
this.displayFct = null;
|
|
24
|
+
this.placeHolder = null;
|
|
25
|
+
this.data = null;
|
|
26
|
+
this.onChange = () => { };
|
|
27
|
+
this.onTouched = () => { };
|
|
28
|
+
this.items = [];
|
|
29
|
+
this.parser = new TranslateDefaultParser();
|
|
30
|
+
this.options = []; //Observable<unknown>;
|
|
31
|
+
this.propagateChange = (_) => { };
|
|
32
|
+
this.glowwService = glowwService;
|
|
33
|
+
this.resultCtrl = new FormControl();
|
|
34
|
+
this.form = this.formBuilder.group({
|
|
35
|
+
__result: this.resultCtrl
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
ngAfterViewInit() {
|
|
39
|
+
}
|
|
40
|
+
ngOnInit() {
|
|
41
|
+
//debugger;
|
|
42
|
+
this.searchRequest = this.glowwService[`search${this.objectName}`];
|
|
43
|
+
this.resultCtrl.valueChanges.pipe(filter(res => res != null && res.length > 2), distinctUntilChanged(), debounceTime(250), tap(() => { this.error = ""; this.options = []; }), switchMap(searchStr => {
|
|
44
|
+
let searchObj = {};
|
|
45
|
+
if (this.data) {
|
|
46
|
+
Object.keys(this.data).forEach(k => {
|
|
47
|
+
searchObj[k] = this.data[k];
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
searchObj[this.searchField] = searchStr;
|
|
51
|
+
return this.searchRequest.call(this.glowwService, searchObj).pipe(map(res => res), catchError(err => {
|
|
52
|
+
this.error = err.message;
|
|
53
|
+
this.ref.markForCheck();
|
|
54
|
+
return of([]);
|
|
55
|
+
}));
|
|
56
|
+
})).subscribe({
|
|
57
|
+
next: (data) => {
|
|
58
|
+
this.options = data;
|
|
59
|
+
this.ref.markForCheck();
|
|
60
|
+
},
|
|
61
|
+
error: (error) => { this.error = error; }
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
writeValue(val) {
|
|
65
|
+
val && this.form.setValue({ __result: val }, { emitEvent: false });
|
|
66
|
+
}
|
|
67
|
+
registerOnChange(fn) {
|
|
68
|
+
this.onChange = fn;
|
|
69
|
+
this.form.valueChanges.subscribe(data => {
|
|
70
|
+
if (this.returnField) {
|
|
71
|
+
this.onChange(this.form.value.__result[this.returnField]);
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
this.onChange(this.form.value.__result);
|
|
75
|
+
}
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
registerOnTouched(fn) {
|
|
79
|
+
this.onTouched = fn;
|
|
80
|
+
}
|
|
81
|
+
setDisabledState(isDisabled) {
|
|
82
|
+
const status = isDisabled ? 'disable' : 'enable';
|
|
83
|
+
//TODO
|
|
84
|
+
}
|
|
85
|
+
displayObj(item) {
|
|
86
|
+
if (!item)
|
|
87
|
+
return null;
|
|
88
|
+
console.log("displayOf");
|
|
89
|
+
if (this.displayField) {
|
|
90
|
+
return item[this.displayField];
|
|
91
|
+
}
|
|
92
|
+
else if (this.displayExpr) {
|
|
93
|
+
return this.parser.interpolate(this.displayExpr.replace(/\\\{/g, "{").replace(/\\\}/g, "}"), item);
|
|
94
|
+
//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;
|
|
95
|
+
}
|
|
96
|
+
else if (this.displayFct) {
|
|
97
|
+
return this.displayFct(item);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
AutoCompleteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: AutoCompleteComponent, deps: [{ token: 'glowwService' }, { token: i1.FormBuilder }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
102
|
+
AutoCompleteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", 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: [
|
|
103
|
+
{
|
|
104
|
+
provide: NG_VALUE_ACCESSOR,
|
|
105
|
+
multi: true,
|
|
106
|
+
useExisting: forwardRef(() => AutoCompleteComponent)
|
|
107
|
+
}
|
|
108
|
+
], ngImport: i0, template: "<div [formGroup]=\"form\" style=\"width:100%\">\n <div style=\"color:red\">{{error}}</div>\n <mat-form-field style=\"width:100%\">\n <input type=\"text\" matInput formControlName=\"__result\" [matAutocomplete]=\"auto\" [placeholder]=\"placeHolder\">\n </mat-form-field>\n <mat-autocomplete #auto=\"matAutocomplete\" [displayWith]=\"displayObj.bind(this)\">\n <mat-option *ngFor=\"let option of options\" [value]=\"option\">\n {{displayObj(option)}}\n </mat-option>\n </mat-autocomplete>\n</div>", styles: [""], components: [{ type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i3.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { type: i4.MatOption, selector: "mat-option", exportAs: ["matOption"] }], directives: [{ type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i5.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"] }, { 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]" }, { type: i3.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
109
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: AutoCompleteComponent, decorators: [{
|
|
110
|
+
type: Component,
|
|
111
|
+
args: [{ selector: 'gloww-auto-complete', providers: [
|
|
112
|
+
{
|
|
113
|
+
provide: NG_VALUE_ACCESSOR,
|
|
114
|
+
multi: true,
|
|
115
|
+
useExisting: forwardRef(() => AutoCompleteComponent)
|
|
116
|
+
}
|
|
117
|
+
], template: "<div [formGroup]=\"form\" style=\"width:100%\">\n <div style=\"color:red\">{{error}}</div>\n <mat-form-field style=\"width:100%\">\n <input type=\"text\" matInput formControlName=\"__result\" [matAutocomplete]=\"auto\" [placeholder]=\"placeHolder\">\n </mat-form-field>\n <mat-autocomplete #auto=\"matAutocomplete\" [displayWith]=\"displayObj.bind(this)\">\n <mat-option *ngFor=\"let option of options\" [value]=\"option\">\n {{displayObj(option)}}\n </mat-option>\n </mat-autocomplete>\n</div>", styles: [""] }]
|
|
118
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
119
|
+
type: Inject,
|
|
120
|
+
args: ['glowwService']
|
|
121
|
+
}] }, { type: i1.FormBuilder }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { _value: [{
|
|
122
|
+
type: Input,
|
|
123
|
+
args: ['value']
|
|
124
|
+
}], objectName: [{
|
|
125
|
+
type: Input,
|
|
126
|
+
args: ['objectName']
|
|
127
|
+
}], searchField: [{
|
|
128
|
+
type: Input,
|
|
129
|
+
args: ['searchField']
|
|
130
|
+
}], returnField: [{
|
|
131
|
+
type: Input,
|
|
132
|
+
args: ['returnField']
|
|
133
|
+
}], displayField: [{
|
|
134
|
+
type: Input,
|
|
135
|
+
args: ['displayField']
|
|
136
|
+
}], displayExpr: [{
|
|
137
|
+
type: Input,
|
|
138
|
+
args: ['displayExpr']
|
|
139
|
+
}], displayFct: [{
|
|
140
|
+
type: Input,
|
|
141
|
+
args: ['displayFct']
|
|
142
|
+
}], placeHolder: [{
|
|
143
|
+
type: Input,
|
|
144
|
+
args: ['placeHolder']
|
|
145
|
+
}], data: [{
|
|
146
|
+
type: Input,
|
|
147
|
+
args: ['data']
|
|
148
|
+
}], searchRequest: [{
|
|
149
|
+
type: Input
|
|
150
|
+
}] } });
|
|
151
|
+
//# 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 } from '@angular/core';\r\nimport { ControlValueAccessor, FormBuilder, FormControl, FormGroup, 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.css'],\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: FormGroup;\r\n  glowwService: any;\r\n  resultCtrl: FormControl;\r\n  public parser = new TranslateDefaultParser();\r\n\r\n  constructor(@Inject('glowwService') glowwService: any, private formBuilder: FormBuilder, private ref: ChangeDetectorRef) {\r\n    this.glowwService = glowwService;\r\n    this.resultCtrl = new FormControl();\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\tif (!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%\">\n    <div style=\"color:red\">{{error}}</div>\n    <mat-form-field style=\"width:100%\">\n        <input type=\"text\" matInput formControlName=\"__result\" [matAutocomplete]=\"auto\" [placeholder]=\"placeHolder\">\n    </mat-form-field>\n    <mat-autocomplete #auto=\"matAutocomplete\" [displayWith]=\"displayObj.bind(this)\">\n        <mat-option *ngFor=\"let option of options\" [value]=\"option\">\n            {{displayObj(option)}}\n        </mat-option>\n    </mat-autocomplete>\n</div>"]}
|
|
@@ -6,6 +6,7 @@ import * as i2 from "@angular/forms";
|
|
|
6
6
|
export class CodeEditorComponent {
|
|
7
7
|
constructor() {
|
|
8
8
|
this._value = null;
|
|
9
|
+
this.mode = "text/typescript";
|
|
9
10
|
this.onChange = () => { };
|
|
10
11
|
this.onTouched = () => { };
|
|
11
12
|
}
|
|
@@ -36,13 +37,13 @@ export class CodeEditorComponent {
|
|
|
36
37
|
}
|
|
37
38
|
}
|
|
38
39
|
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: [
|
|
40
|
+
CodeEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: CodeEditorComponent, selector: "gloww-code-editor", inputs: { _value: ["value", "_value"], mode: "mode" }, providers: [
|
|
40
41
|
{
|
|
41
42
|
provide: NG_VALUE_ACCESSOR,
|
|
42
43
|
multi: true,
|
|
43
44
|
useExisting: CodeEditorComponent
|
|
44
45
|
}
|
|
45
|
-
], ngImport: i0, template: "<ngx-codemirror [(ngModel)]=\"value\" [options]=\"{lineNumbers: true,theme: 'eclipse', indentWithTabs:true,indentUnit: 4,matchBrackets: true, mode:
|
|
46
|
+
], ngImport: i0, template: "<ngx-codemirror [(ngModel)]=\"value\" [options]=\"{lineNumbers: true,theme: 'eclipse', indentWithTabs:true,indentUnit: 4,matchBrackets: true, mode: mode, fixedGutter:false}\">\r\n</ngx-codemirror>", 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
47
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: CodeEditorComponent, decorators: [{
|
|
47
48
|
type: Component,
|
|
48
49
|
args: [{ selector: 'gloww-code-editor', providers: [
|
|
@@ -51,9 +52,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
|
|
|
51
52
|
multi: true,
|
|
52
53
|
useExisting: CodeEditorComponent
|
|
53
54
|
}
|
|
54
|
-
], template: "<ngx-codemirror [(ngModel)]=\"value\" [options]=\"{lineNumbers: true,theme: 'eclipse', indentWithTabs:true,indentUnit: 4,matchBrackets: true, mode:
|
|
55
|
+
], template: "<ngx-codemirror [(ngModel)]=\"value\" [options]=\"{lineNumbers: true,theme: 'eclipse', indentWithTabs:true,indentUnit: 4,matchBrackets: true, mode: mode, fixedGutter:false}\">\r\n</ngx-codemirror>", styles: [".cm-tab{background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAAAMCAYAAAAkuj5RAAAAAXNSR0IArs4c6QAAAGFJREFUSMft1LsRQFAQheHPowAKoACx3IgEKtaEHujDjORSgWTH/ZOdnZOcM/sgk/kFFWY0qV8foQwS4MKBCS3qR6ixBJvElOobYAtivseIE120FaowJPN75GMu8j/LfMwNjh4HUpwg4LUAAAAASUVORK5CYII=);background-position:right;background-repeat:no-repeat}\n"] }]
|
|
55
56
|
}], ctorParameters: function () { return []; }, propDecorators: { _value: [{
|
|
56
57
|
type: Input,
|
|
57
58
|
args: ['value']
|
|
59
|
+
}], mode: [{
|
|
60
|
+
type: Input,
|
|
61
|
+
args: ['mode']
|
|
58
62
|
}] } });
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29kZS1lZGl0b3IuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZ2xvd3cvc3JjL2xpYi9Db21wb25lbnRzL2NvZGUtZWRpdG9yL2NvZGUtZWRpdG9yLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2dsb3d3L3NyYy9saWIvQ29tcG9uZW50cy9jb2RlLWVkaXRvci9jb2RlLWVkaXRvci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUN6RCxPQUFPLEVBQXdCLGlCQUFpQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7Ozs7QUFjekUsTUFBTSxPQUFPLG1CQUFtQjtJQU05QjtRQUxnQixXQUFNLEdBQVEsSUFBSSxDQUFDO1FBQ3BCLFNBQUksR0FBUSxpQkFBaUIsQ0FBQztRQUM3QyxhQUFRLEdBQVEsR0FBRyxFQUFFLEdBQUcsQ0FBQyxDQUFDO1FBQzFCLGNBQVMsR0FBUSxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFFWCxDQUFDO0lBR2pCLElBQUksS0FBSztRQUNQLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQztJQUNyQixDQUFDO0lBRUQsSUFBSSxLQUFLLENBQUMsR0FBRztRQUNYLElBQUksQ0FBQyxNQUFNLEdBQUcsR0FBRyxDQUFDO1FBQ2xCLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDbkIsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQ25CLENBQUM7SUFDRCxVQUFVLENBQUMsR0FBUTtRQUNqQixJQUFJLE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxRQUFRLEVBQUU7WUFDN0IsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1NBQ2xDO2FBQU07WUFDTCxJQUFJLENBQUMsS0FBSyxHQUFHLEdBQUcsQ0FBQztTQUNsQjtJQUNILENBQUM7SUFDRCxnQkFBZ0IsQ0FBQyxFQUFPO1FBQ3RCLElBQUksQ0FBQyxRQUFRLEdBQUcsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFDRCxpQkFBaUIsQ0FBQyxFQUFPO1FBQ3ZCLElBQUksQ0FBQyxTQUFTLEdBQUcsRUFBRSxDQUFDO0lBQ3RCLENBQUM7SUFDRCxnQkFBZ0IsQ0FBRSxVQUFtQjtRQUNuQyw2Q0FBNkM7SUFDL0MsQ0FBQzs7Z0hBakNVLG1CQUFtQjtvR0FBbkIsbUJBQW1CLG1HQVJuQjtRQUNUO1lBQ0UsT0FBTyxFQUFFLGlCQUFpQjtZQUMxQixLQUFLLEVBQUUsSUFBSTtZQUNYLFdBQVcsRUFBRSxtQkFBbUI7U0FDakM7S0FDRiwwQkNiSCxzTUFDaUI7MkZEY0osbUJBQW1CO2tCQVovQixTQUFTOytCQUNFLG1CQUFtQixhQUdsQjt3QkFDVDs0QkFDRSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixLQUFLLEVBQUUsSUFBSTs0QkFDWCxXQUFXLHFCQUFxQjt5QkFDakM7cUJBQ0Y7MEVBR2UsTUFBTTtzQkFBckIsS0FBSzt1QkFBQyxPQUFPO2dCQUNDLElBQUk7c0JBQWxCLEtBQUs7dUJBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb250cm9sVmFsdWVBY2Nlc3NvciwgTkdfVkFMVUVfQUNDRVNTT1IgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2dsb3d3LWNvZGUtZWRpdG9yJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vY29kZS1lZGl0b3IuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2NvZGUtZWRpdG9yLmNvbXBvbmVudC5jc3MnXSxcclxuICBwcm92aWRlcnM6IFtcclxuICAgIHtcclxuICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXHJcbiAgICAgIG11bHRpOiB0cnVlLFxyXG4gICAgICB1c2VFeGlzdGluZzogQ29kZUVkaXRvckNvbXBvbmVudFxyXG4gICAgfVxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIENvZGVFZGl0b3JDb21wb25lbnQgaW1wbGVtZW50cyBDb250cm9sVmFsdWVBY2Nlc3NvciB7XHJcbiAgQElucHV0KCd2YWx1ZScpIF92YWx1ZTogYW55ID0gbnVsbDtcclxuICBASW5wdXQoJ21vZGUnKSBtb2RlOiBhbnkgPSBcInRleHQvdHlwZXNjcmlwdFwiO1xyXG4gIG9uQ2hhbmdlOiBhbnkgPSAoKSA9PiB7IH07XHJcbiAgb25Ub3VjaGVkOiBhbnkgPSAoKSA9PiB7IH07XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkgeyB9XHJcblxyXG5cclxuICBnZXQgdmFsdWUoKSB7XHJcbiAgICByZXR1cm4gdGhpcy5fdmFsdWU7XHJcbiAgfVxyXG5cclxuICBzZXQgdmFsdWUodmFsKSB7XHJcbiAgICB0aGlzLl92YWx1ZSA9IHZhbDtcclxuICAgIHRoaXMub25DaGFuZ2UodmFsKTtcclxuICAgIHRoaXMub25Ub3VjaGVkKCk7XHJcbiAgfVxyXG4gIHdyaXRlVmFsdWUob2JqOiBhbnkpOiB2b2lkIHtcclxuICAgIGlmICh0eXBlb2YgKG9iaikgPT09ICdvYmplY3QnKSB7XHJcbiAgICAgIHRoaXMudmFsdWUgPSBKU09OLnN0cmluZ2lmeShvYmopO1xyXG4gICAgfSBlbHNlIHtcclxuICAgICAgdGhpcy52YWx1ZSA9IG9iajtcclxuICAgIH1cclxuICB9XHJcbiAgcmVnaXN0ZXJPbkNoYW5nZShmbjogYW55KTogdm9pZCB7XHJcbiAgICB0aGlzLm9uQ2hhbmdlID0gZm47XHJcbiAgfVxyXG4gIHJlZ2lzdGVyT25Ub3VjaGVkKGZuOiBhbnkpOiB2b2lkIHtcclxuICAgIHRoaXMub25Ub3VjaGVkID0gZm47XHJcbiAgfVxyXG4gIHNldERpc2FibGVkU3RhdGU/KGlzRGlzYWJsZWQ6IGJvb2xlYW4pOiB2b2lkIHtcclxuICAgIC8vdGhyb3cgbmV3IEVycm9yKCdNZXRob2Qgbm90IGltcGxlbWVudGVkLicpO1xyXG4gIH1cclxuXHJcbn1cclxuIiwiPG5neC1jb2RlbWlycm9yIFsobmdNb2RlbCldPVwidmFsdWVcIiBbb3B0aW9uc109XCJ7bGluZU51bWJlcnM6IHRydWUsdGhlbWU6ICdlY2xpcHNlJywgaW5kZW50V2l0aFRhYnM6dHJ1ZSxpbmRlbnRVbml0OiA0LG1hdGNoQnJhY2tldHM6IHRydWUsIG1vZGU6IG1vZGUsIGZpeGVkR3V0dGVyOmZhbHNlfVwiPlxyXG48L25neC1jb2RlbWlycm9yPiJdfQ==
|
|
@@ -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/material/form-field";
|
|
6
|
+
import * as i2 from "@angular/material/datepicker";
|
|
7
|
+
import * as i3 from "@angular-material-components/datetime-picker";
|
|
8
|
+
import * as i4 from "@angular/common";
|
|
9
|
+
import * as i5 from "@angular/material/input";
|
|
10
|
+
import * as i6 from "@angular/forms";
|
|
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: "13.2.3", ngImport: i0, type: DatetimeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
49
|
+
DatetimeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", 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%\">\n <mat-form-field *ngIf=\"mode==='date'\">\n <mat-label>{{display}}</mat-label>\n <input matInput [matDatepicker]=\"picker\" [placeholder]=\"placeHolder\" [(ngModel)]=\"value\">\n <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n <mat-datepicker #picker></mat-datepicker>\n </mat-form-field>\n\n <mat-form-field *ngIf=\"mode==='datetime'\">\n <mat-label>{{display}}</mat-label>\n <input matInput [ngxMatDatetimePicker]=\"pickerDT\" [placeholder]=\"placeHolder\" [(ngModel)]=\"value\">\n <mat-datepicker-toggle matSuffix [for]=\"$any(pickerDT)\"></mat-datepicker-toggle>\n <ngx-mat-datetime-picker #pickerDT [showSpinners]=\"showSpinners\" [showSeconds]=\"showSeconds\" [touchUi]=\"true\" [disableMinute]=\"disableMinute\">\n </ngx-mat-datetime-picker>\n </mat-form-field>\n</div>\n", styles: [""], components: [{ type: i1.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i2.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { type: i2.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { type: i3.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"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.MatLabel, selector: "mat-label" }, { type: i5.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"] }, { type: i2.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i1.MatSuffix, selector: "[matSuffix]" }, { type: i3.NgxMatDatetimeInput, selector: "input[ngxMatDatetimePicker]", inputs: ["ngxMatDatetimePicker", "ngxMatDatetimePickerFilter", "value", "min", "max", "disabled"], outputs: ["dateChange", "dateInput"], exportAs: ["ngxMatDatetimePickerInput"] }] });
|
|
56
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", 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%\">\n <mat-form-field *ngIf=\"mode==='date'\">\n <mat-label>{{display}}</mat-label>\n <input matInput [matDatepicker]=\"picker\" [placeholder]=\"placeHolder\" [(ngModel)]=\"value\">\n <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n <mat-datepicker #picker></mat-datepicker>\n </mat-form-field>\n\n <mat-form-field *ngIf=\"mode==='datetime'\">\n <mat-label>{{display}}</mat-label>\n <input matInput [ngxMatDatetimePicker]=\"pickerDT\" [placeholder]=\"placeHolder\" [(ngModel)]=\"value\">\n <mat-datepicker-toggle matSuffix [for]=\"$any(pickerDT)\"></mat-datepicker-toggle>\n <ngx-mat-datetime-picker #pickerDT [showSpinners]=\"showSpinners\" [showSeconds]=\"showSeconds\" [touchUi]=\"true\" [disableMinute]=\"disableMinute\">\n </ngx-mat-datetime-picker>\n </mat-form-field>\n</div>\n", styles: [""] }]
|
|
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXRpbWUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZ2xvd3cvc3JjL2xpYi9Db21wb25lbnRzL2RhdGV0aW1lL2RhdGV0aW1lLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2dsb3d3L3NyYy9saWIvQ29tcG9uZW50cy9kYXRldGltZS9kYXRldGltZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUN6RCxPQUFPLEVBQXdCLGlCQUFpQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDekUsT0FBTyxLQUFLLE1BQU0sTUFBTSxRQUFRLENBQUM7Ozs7Ozs7O0FBY2pDLE1BQU0sT0FBTyxpQkFBaUI7SUFZNUI7UUFYZ0IsV0FBTSxHQUFRLElBQUksQ0FBQztRQUNqQixZQUFPLEdBQVEsSUFBSSxDQUFDO1FBQ2hCLGdCQUFXLEdBQVEsSUFBSSxDQUFDO1FBQy9CLFNBQUksR0FBVyxNQUFNLENBQUM7UUFDNUIsaUJBQVksR0FBWSxJQUFJLENBQUM7UUFDN0IsZ0JBQVcsR0FBWSxLQUFLLENBQUM7UUFDN0Isa0JBQWEsR0FBWSxLQUFLLENBQUM7UUFFeEMsYUFBUSxHQUFRLEdBQUcsRUFBRSxHQUFHLENBQUMsQ0FBQztRQUMxQixjQUFTLEdBQVEsR0FBRyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBRVgsQ0FBQztJQUdqQixJQUFJLEtBQUs7UUFDUCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUM7SUFDckIsQ0FBQztJQUVELElBQUksS0FBSyxDQUFDLEdBQUc7UUFDWCxJQUFJLENBQUMsTUFBTSxHQUFHLEdBQUcsQ0FBQztRQUNsQixJQUFJLEVBQUUsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDO1FBQ3JCLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxRQUFRLEVBQUU7WUFDckMsRUFBRSxHQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFtQixDQUFDLFdBQVcsRUFBRSxDQUFDO1NBQzNEO1FBQ0QsSUFBSSxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUNsQixJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDbkIsQ0FBQztJQUNELFVBQVUsQ0FBQyxHQUFRO1FBQ2pCLElBQUksQ0FBQyxLQUFLLEdBQUcsR0FBRyxDQUFDO0lBQ25CLENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxFQUFPO1FBQ3RCLElBQUksQ0FBQyxRQUFRLEdBQUcsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFDRCxpQkFBaUIsQ0FBQyxFQUFPO1FBQ3ZCLElBQUksQ0FBQyxTQUFTLEdBQUcsRUFBRSxDQUFDO0lBQ3RCLENBQUM7SUFDRCxnQkFBZ0IsQ0FBRSxVQUFtQjtRQUNuQyw2Q0FBNkM7SUFDL0MsQ0FBQzs7OEdBeENVLGlCQUFpQjtrR0FBakIsaUJBQWlCLDBPQVJqQjtRQUNUO1lBQ0UsT0FBTyxFQUFFLGlCQUFpQjtZQUMxQixLQUFLLEVBQUUsSUFBSTtZQUNYLFdBQVcsRUFBRSxpQkFBaUI7U0FDL0I7S0FDRiwwQkNkSCxnNUJBZ0JBOzJGREFhLGlCQUFpQjtrQkFaN0IsU0FBUzsrQkFDRSxnQkFBZ0IsYUFHZjt3QkFDVDs0QkFDRSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixLQUFLLEVBQUUsSUFBSTs0QkFDWCxXQUFXLG1CQUFtQjt5QkFDL0I7cUJBQ0Y7MEVBR2UsTUFBTTtzQkFBckIsS0FBSzt1QkFBQyxPQUFPO2dCQUNJLE9BQU87c0JBQXhCLEtBQUs7dUJBQUMsU0FBUztnQkFDTSxXQUFXO3NCQUFoQyxLQUFLO3VCQUFDLGFBQWE7Z0JBQ0wsSUFBSTtzQkFBbEIsS0FBSzt1QkFBQyxNQUFNO2dCQUNKLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb250cm9sVmFsdWVBY2Nlc3NvciwgTkdfVkFMVUVfQUNDRVNTT1IgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgKiBhcyBtb21lbnQgZnJvbSAnbW9tZW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZ2xvd3ctZGF0ZXRpbWUnLFxuICB0ZW1wbGF0ZVVybDogJy4vZGF0ZXRpbWUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9kYXRldGltZS5jb21wb25lbnQuY3NzJ10sXG4gIHByb3ZpZGVyczogW1xuICAgIHtcbiAgICAgIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxuICAgICAgbXVsdGk6IHRydWUsXG4gICAgICB1c2VFeGlzdGluZzogRGF0ZXRpbWVDb21wb25lbnRcbiAgICB9XG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgRGF0ZXRpbWVDb21wb25lbnQgaW1wbGVtZW50cyBDb250cm9sVmFsdWVBY2Nlc3NvciB7XG4gIEBJbnB1dCgndmFsdWUnKSBfdmFsdWU6IGFueSA9IG51bGw7XG4gIEBJbnB1dCgnZGlzcGxheScpIGRpc3BsYXk6IGFueSA9IG51bGw7XG4gIEBJbnB1dCgncGxhY2VIb2xkZXInKSBwbGFjZUhvbGRlcjogYW55ID0gbnVsbDtcbiAgQElucHV0KCdtb2RlJykgbW9kZTogc3RyaW5nID0gJ2RhdGUnO1xuICBASW5wdXQoKSBzaG93U3Bpbm5lcnM6IGJvb2xlYW4gPSB0cnVlO1xuICBASW5wdXQoKSBzaG93U2Vjb25kczogYm9vbGVhbiA9IGZhbHNlO1xuICBASW5wdXQoKSBkaXNhYmxlTWludXRlOiBib29sZWFuID0gZmFsc2U7XG5cbiAgb25DaGFuZ2U6IGFueSA9ICgpID0+IHsgfTtcbiAgb25Ub3VjaGVkOiBhbnkgPSAoKSA9PiB7IH07XG5cbiAgY29uc3RydWN0b3IoKSB7IH1cblxuXG4gIGdldCB2YWx1ZSgpIHtcbiAgICByZXR1cm4gdGhpcy5fdmFsdWU7XG4gIH1cblxuICBzZXQgdmFsdWUodmFsKSB7XG4gICAgdGhpcy5fdmFsdWUgPSB2YWw7XG4gICAgbGV0IGR0ID0gdGhpcy5fdmFsdWU7XG4gICAgaWYgKHR5cGVvZiAodGhpcy5fdmFsdWUpID09PSAnc3RyaW5nJykge1xuICAgICAgZHQgPSAobW9tZW50KHRoaXMuX3ZhbHVlKSBhcyBtb21lbnQuTW9tZW50KS50b0lTT1N0cmluZygpO1xuICAgIH1cbiAgICB0aGlzLm9uQ2hhbmdlKGR0KTtcbiAgICB0aGlzLm9uVG91Y2hlZCgpO1xuICB9XG4gIHdyaXRlVmFsdWUob2JqOiBhbnkpOiB2b2lkIHtcbiAgICB0aGlzLnZhbHVlID0gb2JqO1xuICB9XG5cbiAgcmVnaXN0ZXJPbkNoYW5nZShmbjogYW55KTogdm9pZCB7XG4gICAgdGhpcy5vbkNoYW5nZSA9IGZuO1xuICB9XG4gIHJlZ2lzdGVyT25Ub3VjaGVkKGZuOiBhbnkpOiB2b2lkIHtcbiAgICB0aGlzLm9uVG91Y2hlZCA9IGZuO1xuICB9XG4gIHNldERpc2FibGVkU3RhdGU/KGlzRGlzYWJsZWQ6IGJvb2xlYW4pOiB2b2lkIHtcbiAgICAvL3Rocm93IG5ldyBFcnJvcignTWV0aG9kIG5vdCBpbXBsZW1lbnRlZC4nKTtcbiAgfVxufVxuIiwiPGRpdiBzdHlsZT1cIndpZHRoOjEwMCVcIj5cbiAgICA8bWF0LWZvcm0tZmllbGQgKm5nSWY9XCJtb2RlPT09J2RhdGUnXCI+XG4gICAgICAgIDxtYXQtbGFiZWw+e3tkaXNwbGF5fX08L21hdC1sYWJlbD5cbiAgICAgICAgPGlucHV0IG1hdElucHV0IFttYXREYXRlcGlja2VyXT1cInBpY2tlclwiIFtwbGFjZWhvbGRlcl09XCJwbGFjZUhvbGRlclwiIFsobmdNb2RlbCldPVwidmFsdWVcIj5cbiAgICAgICAgPG1hdC1kYXRlcGlja2VyLXRvZ2dsZSBtYXRTdWZmaXggW2Zvcl09XCJwaWNrZXJcIj48L21hdC1kYXRlcGlja2VyLXRvZ2dsZT5cbiAgICAgICAgPG1hdC1kYXRlcGlja2VyICNwaWNrZXI+PC9tYXQtZGF0ZXBpY2tlcj5cbiAgICA8L21hdC1mb3JtLWZpZWxkPlxuXG4gICAgPG1hdC1mb3JtLWZpZWxkICpuZ0lmPVwibW9kZT09PSdkYXRldGltZSdcIj5cbiAgICAgICAgPG1hdC1sYWJlbD57e2Rpc3BsYXl9fTwvbWF0LWxhYmVsPlxuICAgICAgICA8aW5wdXQgbWF0SW5wdXQgW25neE1hdERhdGV0aW1lUGlja2VyXT1cInBpY2tlckRUXCIgW3BsYWNlaG9sZGVyXT1cInBsYWNlSG9sZGVyXCIgWyhuZ01vZGVsKV09XCJ2YWx1ZVwiPlxuICAgICAgICA8bWF0LWRhdGVwaWNrZXItdG9nZ2xlIG1hdFN1ZmZpeCBbZm9yXT1cIiRhbnkocGlja2VyRFQpXCI+PC9tYXQtZGF0ZXBpY2tlci10b2dnbGU+XG4gICAgICAgIDxuZ3gtbWF0LWRhdGV0aW1lLXBpY2tlciAjcGlja2VyRFQgW3Nob3dTcGlubmVyc109XCJzaG93U3Bpbm5lcnNcIiBbc2hvd1NlY29uZHNdPVwic2hvd1NlY29uZHNcIiBbdG91Y2hVaV09XCJ0cnVlXCIgW2Rpc2FibGVNaW51dGVdPVwiZGlzYWJsZU1pbnV0ZVwiPlxuICAgICAgICA8L25neC1tYXQtZGF0ZXRpbWUtcGlja2VyPlxuICAgIDwvbWF0LWZvcm0tZmllbGQ+XG48L2Rpdj5cbiJdfQ==
|