@dev-tcloud/tcloud-ui 0.0.49 → 0.0.51

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 (32) hide show
  1. package/README.md +11 -0
  2. package/esm2020/lib/_directives/directives.module.mjs +10 -5
  3. package/esm2020/lib/_directives/hover-parent/hover-parent.directive.mjs +58 -0
  4. package/esm2020/lib/_modules/tcloud-ui-datepicker/tcloud-ui-datepicker.component.mjs +302 -0
  5. package/esm2020/lib/_modules/tcloud-ui-datepicker/tcloud-ui-datepicker.module.mjs +31 -0
  6. package/esm2020/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.component.mjs +209 -0
  7. package/esm2020/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.module.mjs +35 -0
  8. package/esm2020/lib/_modules/tcloud-ui-filters/tcloud-ui-filters.component.mjs +79 -29
  9. package/esm2020/lib/_modules/tcloud-ui-filters/tcloud-ui-filters.module.mjs +8 -4
  10. package/esm2020/lib/_pipes/datebr.mjs +102 -0
  11. package/esm2020/lib/_pipes/index.mjs +2 -1
  12. package/esm2020/lib/_pipes/tcloud-pipes.module.mjs +14 -8
  13. package/esm2020/lib/tcloud-ui.module.mjs +17 -3
  14. package/esm2020/public-api.mjs +8 -1
  15. package/fesm2015/dev-tcloud-tcloud-ui.mjs +1345 -553
  16. package/fesm2015/dev-tcloud-tcloud-ui.mjs.map +1 -1
  17. package/fesm2020/dev-tcloud-tcloud-ui.mjs +1337 -551
  18. package/fesm2020/dev-tcloud-tcloud-ui.mjs.map +1 -1
  19. package/lib/_directives/directives.module.d.ts +2 -1
  20. package/lib/_directives/hover-parent/hover-parent.directive.d.ts +15 -0
  21. package/lib/_modules/tcloud-ui-datepicker/tcloud-ui-datepicker.component.d.ts +46 -0
  22. package/lib/_modules/tcloud-ui-datepicker/tcloud-ui-datepicker.module.d.ts +9 -0
  23. package/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.component.d.ts +34 -0
  24. package/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.module.d.ts +10 -0
  25. package/lib/_modules/tcloud-ui-filters/tcloud-ui-filters.component.d.ts +2 -1
  26. package/lib/_modules/tcloud-ui-filters/tcloud-ui-filters.module.d.ts +2 -1
  27. package/lib/_pipes/datebr.d.ts +11 -0
  28. package/lib/_pipes/index.d.ts +1 -0
  29. package/lib/_pipes/tcloud-pipes.module.d.ts +3 -2
  30. package/lib/tcloud-ui.module.d.ts +5 -3
  31. package/package.json +1 -1
  32. package/public-api.d.ts +5 -0
package/README.md CHANGED
@@ -28,10 +28,13 @@ npm install @dev-tcloud/tcloud-ui --save
28
28
  - TCloudUiScrollBoxModule
29
29
  - TCloudUiFiltersModule
30
30
  - TCloudUiAccordionModule
31
+ - TCloudUiDatepickerComponent
32
+ - TCloudUiDatepickerTimeComponent
31
33
 
32
34
  ## tcloud-ui directives
33
35
  - TCloudUiTooltipDirective
34
36
  - TCloudUiAlignDirective
37
+ - TCloudUiHoverParentDirective
35
38
 
36
39
  ## tcloud-ui services
37
40
  - TCloudUiLoadingTransitionsService
@@ -63,6 +66,14 @@ angular.json
63
66
  ],
64
67
  ```
65
68
 
69
+
70
+ ## Add calendar library to use datepicker
71
+ ```javascript
72
+ "script": [
73
+ "node_modules/@dev-tcloud/tcloud-ui/datepicker/js/datepicker-full.min.js",
74
+ ],
75
+ ```
76
+
66
77
  # TcloudUi
67
78
 
68
79
  This project was generated with [Angular CLI](https://github.com/angular/angular-cli) version 14.1.1.
@@ -1,25 +1,30 @@
1
1
  import { NgModule } from '@angular/core';
2
2
  import { TCloudUiAlignDirective } from './align/align.directive';
3
+ import { TCloudUiHoverParentDirective } from './hover-parent/hover-parent.directive';
3
4
  import { TCloudUiTooltipDirective } from './tooltip/tooltip.directive';
4
5
  import * as i0 from "@angular/core";
5
6
  export class TCloudUiDirectiveModule {
6
7
  }
7
8
  TCloudUiDirectiveModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiDirectiveModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
8
9
  TCloudUiDirectiveModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiDirectiveModule, declarations: [TCloudUiTooltipDirective,
9
- TCloudUiAlignDirective], exports: [TCloudUiTooltipDirective,
10
- TCloudUiAlignDirective] });
10
+ TCloudUiAlignDirective,
11
+ TCloudUiHoverParentDirective], exports: [TCloudUiTooltipDirective,
12
+ TCloudUiAlignDirective,
13
+ TCloudUiHoverParentDirective] });
11
14
  TCloudUiDirectiveModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiDirectiveModule });
12
15
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiDirectiveModule, decorators: [{
13
16
  type: NgModule,
14
17
  args: [{
15
18
  declarations: [
16
19
  TCloudUiTooltipDirective,
17
- TCloudUiAlignDirective
20
+ TCloudUiAlignDirective,
21
+ TCloudUiHoverParentDirective
18
22
  ],
19
23
  exports: [
20
24
  TCloudUiTooltipDirective,
21
- TCloudUiAlignDirective
25
+ TCloudUiAlignDirective,
26
+ TCloudUiHoverParentDirective
22
27
  ],
23
28
  }]
24
29
  }] });
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlyZWN0aXZlcy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90Y2xvdWQtdWkvc3JjL2xpYi9fZGlyZWN0aXZlcy9kaXJlY3RpdmVzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ2pFLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDZCQUE2QixDQUFDOztBQVl2RSxNQUFNLE9BQU8sdUJBQXVCOztxSEFBdkIsdUJBQXVCO3NIQUF2Qix1QkFBdUIsaUJBUmhDLHdCQUF3QjtRQUN4QixzQkFBc0IsYUFHdEIsd0JBQXdCO1FBQ3hCLHNCQUFzQjtzSEFHYix1QkFBdUI7NEZBQXZCLHVCQUF1QjtrQkFWbkMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUU7d0JBQ1osd0JBQXdCO3dCQUN4QixzQkFBc0I7cUJBQ3ZCO29CQUNELE9BQU8sRUFBRTt3QkFDUCx3QkFBd0I7d0JBQ3hCLHNCQUFzQjtxQkFDdkI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBUQ2xvdWRVaUFsaWduRGlyZWN0aXZlIH0gZnJvbSAnLi9hbGlnbi9hbGlnbi5kaXJlY3RpdmUnO1xyXG5pbXBvcnQgeyBUQ2xvdWRVaVRvb2x0aXBEaXJlY3RpdmUgfSBmcm9tICcuL3Rvb2x0aXAvdG9vbHRpcC5kaXJlY3RpdmUnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtcclxuICAgIFRDbG91ZFVpVG9vbHRpcERpcmVjdGl2ZSxcclxuICAgIFRDbG91ZFVpQWxpZ25EaXJlY3RpdmVcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIFRDbG91ZFVpVG9vbHRpcERpcmVjdGl2ZSxcclxuICAgIFRDbG91ZFVpQWxpZ25EaXJlY3RpdmVcclxuICBdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgVENsb3VkVWlEaXJlY3RpdmVNb2R1bGUge30iXX0=
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlyZWN0aXZlcy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90Y2xvdWQtdWkvc3JjL2xpYi9fZGlyZWN0aXZlcy9kaXJlY3RpdmVzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ2pFLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQ3JGLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDZCQUE2QixDQUFDOztBQWN2RSxNQUFNLE9BQU8sdUJBQXVCOztxSEFBdkIsdUJBQXVCO3NIQUF2Qix1QkFBdUIsaUJBVmhDLHdCQUF3QjtRQUN4QixzQkFBc0I7UUFDdEIsNEJBQTRCLGFBRzVCLHdCQUF3QjtRQUN4QixzQkFBc0I7UUFDdEIsNEJBQTRCO3NIQUduQix1QkFBdUI7NEZBQXZCLHVCQUF1QjtrQkFabkMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUU7d0JBQ1osd0JBQXdCO3dCQUN4QixzQkFBc0I7d0JBQ3RCLDRCQUE0QjtxQkFDN0I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLHdCQUF3Qjt3QkFDeEIsc0JBQXNCO3dCQUN0Qiw0QkFBNEI7cUJBQzdCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgVENsb3VkVWlBbGlnbkRpcmVjdGl2ZSB9IGZyb20gJy4vYWxpZ24vYWxpZ24uZGlyZWN0aXZlJztcclxuaW1wb3J0IHsgVENsb3VkVWlIb3ZlclBhcmVudERpcmVjdGl2ZSB9IGZyb20gJy4vaG92ZXItcGFyZW50L2hvdmVyLXBhcmVudC5kaXJlY3RpdmUnO1xyXG5pbXBvcnQgeyBUQ2xvdWRVaVRvb2x0aXBEaXJlY3RpdmUgfSBmcm9tICcuL3Rvb2x0aXAvdG9vbHRpcC5kaXJlY3RpdmUnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtcclxuICAgIFRDbG91ZFVpVG9vbHRpcERpcmVjdGl2ZSxcclxuICAgIFRDbG91ZFVpQWxpZ25EaXJlY3RpdmUsXHJcbiAgICBUQ2xvdWRVaUhvdmVyUGFyZW50RGlyZWN0aXZlXHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBUQ2xvdWRVaVRvb2x0aXBEaXJlY3RpdmUsXHJcbiAgICBUQ2xvdWRVaUFsaWduRGlyZWN0aXZlLFxyXG4gICAgVENsb3VkVWlIb3ZlclBhcmVudERpcmVjdGl2ZVxyXG4gIF0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUQ2xvdWRVaURpcmVjdGl2ZU1vZHVsZSB7fSJdfQ==
@@ -0,0 +1,58 @@
1
+ import { Directive, Input, HostListener } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class TCloudUiHoverParentDirective {
4
+ constructor(renderer) {
5
+ this.renderer = renderer;
6
+ }
7
+ onMouseOver() {
8
+ if (this.getElement()) {
9
+ const el = this.getElement();
10
+ if (el) {
11
+ this.renderer.addClass(el, (this.CLASS) ? this.CLASS : 'tcloud-hover-parent');
12
+ }
13
+ }
14
+ }
15
+ onMouseOut() {
16
+ if (this.getElement()) {
17
+ const el = this.getElement();
18
+ if (el) {
19
+ this.renderer.removeClass(el, (this.CLASS) ? this.CLASS : 'tcloud-hover-parent');
20
+ }
21
+ }
22
+ }
23
+ set TCHoverParent(id) {
24
+ if (id) {
25
+ this.ID = id;
26
+ }
27
+ }
28
+ set TCHoverParentClass(clss) {
29
+ if (clss) {
30
+ this.CLASS = clss;
31
+ }
32
+ }
33
+ getElement() {
34
+ if (this.ID) {
35
+ return document.getElementById(this.ID) || undefined;
36
+ }
37
+ return undefined;
38
+ }
39
+ }
40
+ TCloudUiHoverParentDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiHoverParentDirective, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
41
+ TCloudUiHoverParentDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: TCloudUiHoverParentDirective, selector: "[TCHoverParent]", inputs: { TCHoverParent: "TCHoverParent", TCHoverParentClass: "TCHoverParentClass" }, host: { listeners: { "mouseover": "onMouseOver()", "mouseout": "onMouseOut()" } }, ngImport: i0 });
42
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiHoverParentDirective, decorators: [{
43
+ type: Directive,
44
+ args: [{
45
+ selector: '[TCHoverParent]'
46
+ }]
47
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }]; }, propDecorators: { onMouseOver: [{
48
+ type: HostListener,
49
+ args: ['mouseover']
50
+ }], onMouseOut: [{
51
+ type: HostListener,
52
+ args: ['mouseout']
53
+ }], TCHoverParent: [{
54
+ type: Input
55
+ }], TCHoverParentClass: [{
56
+ type: Input
57
+ }] } });
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaG92ZXItcGFyZW50LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RjbG91ZC11aS9zcmMvbGliL19kaXJlY3RpdmVzL2hvdmVyLXBhcmVudC9ob3Zlci1wYXJlbnQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFhLFlBQVksRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFLMUUsTUFBTSxPQUFPLDRCQUE0QjtJQUt2QyxZQUNVLFFBQW1CO1FBQW5CLGFBQVEsR0FBUixRQUFRLENBQVc7SUFDMUIsQ0FBQztJQUV1QixXQUFXO1FBQ3BDLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRSxFQUFFO1lBQ3JCLE1BQU0sRUFBRSxHQUFTLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztZQUNuQyxJQUFJLEVBQUUsRUFBRTtnQkFDTixJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLHFCQUFxQixDQUFDLENBQUM7YUFDL0U7U0FDRjtJQUNILENBQUM7SUFFeUIsVUFBVTtRQUNsQyxJQUFJLElBQUksQ0FBQyxVQUFVLEVBQUUsRUFBRTtZQUNyQixNQUFNLEVBQUUsR0FBUyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDbkMsSUFBSSxFQUFFLEVBQUU7Z0JBQ04sSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO2FBQ2xGO1NBRUY7SUFDSCxDQUFDO0lBRUQsSUFBYSxhQUFhLENBQUUsRUFBVTtRQUNwQyxJQUFJLEVBQUUsRUFBQztZQUFFLElBQUksQ0FBQyxFQUFFLEdBQUcsRUFBRSxDQUFDO1NBQUU7SUFDMUIsQ0FBQztJQUVELElBQWEsa0JBQWtCLENBQUUsSUFBUztRQUN4QyxJQUFJLElBQUksRUFBQztZQUNQLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO1NBQ25CO0lBQ0gsQ0FBQztJQUVELFVBQVU7UUFDUixJQUFJLElBQUksQ0FBQyxFQUFFLEVBQUU7WUFDVCxPQUFPLFFBQVEsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLFNBQVMsQ0FBQztTQUN4RDtRQUNELE9BQU8sU0FBUyxDQUFDO0lBQ25CLENBQUM7OzBIQTNDVSw0QkFBNEI7OEdBQTVCLDRCQUE0Qjs0RkFBNUIsNEJBQTRCO2tCQUh4QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxpQkFBaUI7aUJBQzVCO2dHQVU0QixXQUFXO3NCQUFyQyxZQUFZO3VCQUFDLFdBQVc7Z0JBU0MsVUFBVTtzQkFBbkMsWUFBWTt1QkFBQyxVQUFVO2dCQVVYLGFBQWE7c0JBQXpCLEtBQUs7Z0JBSU8sa0JBQWtCO3NCQUE5QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiXHJcbmltcG9ydCB7IERpcmVjdGl2ZSwgSW5wdXQsIFJlbmRlcmVyMiwgSG9zdExpc3RlbmVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5ARGlyZWN0aXZlKHtcclxuICBzZWxlY3RvcjogJ1tUQ0hvdmVyUGFyZW50XSdcclxufSlcclxuZXhwb3J0IGNsYXNzIFRDbG91ZFVpSG92ZXJQYXJlbnREaXJlY3RpdmUge1xyXG5cclxuICBwcml2YXRlIENMQVNTOiBzdHJpbmcgfCB1bmRlZmluZWQ7XHJcbiAgcHJpdmF0ZSBJRDogc3RyaW5nIHwgdW5kZWZpbmVkO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgcmVuZGVyZXI6IFJlbmRlcmVyMlxyXG4gICkge31cclxuXHJcbiAgQEhvc3RMaXN0ZW5lcignbW91c2VvdmVyJykgb25Nb3VzZU92ZXIoKSB7XHJcbiAgICBpZiggdGhpcy5nZXRFbGVtZW50KCkgKXtcclxuICAgICAgY29uc3QgZWwgPSA8YW55PiB0aGlzLmdldEVsZW1lbnQoKTtcclxuICAgICAgaWYoIGVsICl7XHJcbiAgICAgICAgdGhpcy5yZW5kZXJlci5hZGRDbGFzcyhlbCwgKHRoaXMuQ0xBU1MpID8gdGhpcy5DTEFTUyA6ICd0Y2xvdWQtaG92ZXItcGFyZW50Jyk7XHJcbiAgICAgIH1cclxuICAgIH0gXHJcbiAgfVxyXG5cclxuICBASG9zdExpc3RlbmVyKCdtb3VzZW91dCcpIG9uTW91c2VPdXQoKSB7XHJcbiAgICBpZiggdGhpcy5nZXRFbGVtZW50KCkgKXtcclxuICAgICAgY29uc3QgZWwgPSA8YW55PiB0aGlzLmdldEVsZW1lbnQoKTtcclxuICAgICAgaWYoIGVsICl7XHJcbiAgICAgICAgdGhpcy5yZW5kZXJlci5yZW1vdmVDbGFzcyhlbCwgKHRoaXMuQ0xBU1MpID8gdGhpcy5DTEFTUyA6ICd0Y2xvdWQtaG92ZXItcGFyZW50Jyk7XHJcbiAgICAgIH1cclxuICAgICBcclxuICAgIH0gICAgXHJcbiAgfVxyXG5cclxuICBASW5wdXQoKSBzZXQgVENIb3ZlclBhcmVudCAoaWQ6IHN0cmluZyl7XHJcbiAgICBpZiAoaWQpeyB0aGlzLklEID0gaWQ7IH1cclxuICB9XHJcblxyXG4gIEBJbnB1dCgpIHNldCBUQ0hvdmVyUGFyZW50Q2xhc3MgKGNsc3M6IGFueSl7XHJcbiAgICBpZiAoY2xzcyl7XHJcbiAgICAgIHRoaXMuQ0xBU1MgPSBjbHNzO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgZ2V0RWxlbWVudCgpOiBIVE1MRWxlbWVudCB8IHVuZGVmaW5lZHtcclxuICAgIGlmKCB0aGlzLklEICl7XHJcbiAgICAgICAgcmV0dXJuIGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKHRoaXMuSUQpIHx8IHVuZGVmaW5lZDtcclxuICAgIH1cclxuICAgIHJldHVybiB1bmRlZmluZWQ7XHJcbiAgfVxyXG5cclxufSJdfQ==
@@ -0,0 +1,302 @@
1
+ import { Component, ViewChild, Output, EventEmitter, forwardRef, Input, ViewEncapsulation } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../../_pipes";
5
+ import * as i2 from "@angular/common";
6
+ var translation = {
7
+ ptBR: {
8
+ days: ["Domingo", "Segunda", "Terça", "Quarta", "Quinta", "Sexta", "Sábado"],
9
+ daysShort: ["Dom", "Seg", "Ter", "Qua", "Qui", "Sex", "Sáb"],
10
+ daysMin: ["Do", "Se", "Te", "Qu", "Qu", "Se", "Sa"],
11
+ months: ["Janeiro", "Fevereiro", "Março", "Abril", "Maio", "Junho", "Julho", "Agosto", "Setembro", "Outubro", "Novembro", "Dezembro"],
12
+ monthsShort: ["Jan", "Fev", "Mar", "Abr", "Mai", "Jun", "Jul", "Ago", "Set", "Out", "Nov", "Dez"],
13
+ today: "Hoje",
14
+ clear: "Limpar",
15
+ titleFormat: "MM y",
16
+ format: "dd/mm/yyyy",
17
+ weekStart: 0
18
+ }
19
+ };
20
+ const CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR = {
21
+ provide: NG_VALUE_ACCESSOR,
22
+ useExisting: forwardRef(() => TCloudUiDatepickerComponent),
23
+ multi: true
24
+ };
25
+ const noop = () => {
26
+ };
27
+ export class TCloudUiDatepickerComponent {
28
+ constructor(_DateBRPipe, _changeDetectorRef) {
29
+ this._DateBRPipe = _DateBRPipe;
30
+ this._changeDetectorRef = _changeDetectorRef;
31
+ // multiple permite selecionar multiplas datas
32
+ this.multiple = false;
33
+ // maxNumberOfDates - Maximum number of dates users can select. No limit is applied if 0 is set.
34
+ // Depende de: multiple como true
35
+ this.maxNumberOfDates = 0;
36
+ // daysOfWeekDisabled - Dias da semana desabilidatos = 0 para sabado até 6 para domingo
37
+ this.daysOfWeekDisabled = [];
38
+ // minDate - Data minima para exibicao do calendario - ex: 01/01/2020
39
+ this.minDate = '';
40
+ // maxDate - Data maxima para exibicao do calendario - ex: 31/12/2020
41
+ this.maxDate = '';
42
+ // datesDisabled - Datas desabilitadas - Ex: ['12/10/2020','25/12/2020']
43
+ this.datesDisabled = [];
44
+ // modeInput - Exibe um input para quando clicar abrir o calendario
45
+ this.modeInput = false;
46
+ this.useBorder = true;
47
+ // onChange - Dispara a data selecionada
48
+ this.onChange = new EventEmitter();
49
+ this.ngModelChange = new EventEmitter();
50
+ this.code = 'tcloud-ui-datepicker';
51
+ this.ID = '';
52
+ //Placeholders for the callbacks which are later providesd
53
+ //by the Control Value Accessor
54
+ this.onTouchedCallback = noop;
55
+ this.onChangeCallback = noop;
56
+ }
57
+ set ngModel(v) {
58
+ //console.log('ngModel', v);
59
+ if (v && v !== this.innerValue) {
60
+ this.innerValue = v; //this.toSetMask(v);
61
+ }
62
+ }
63
+ ngOnInit() {
64
+ this.ID = this.generateID();
65
+ Datepicker.locales.ptBR = translation.ptBR;
66
+ this.start_datepicker();
67
+ }
68
+ generateID() {
69
+ return `tcloud-ui-datepicker-${Math.floor(Math.random() * Math.floor(Math.random() * Date.now()))}`;
70
+ }
71
+ toSetMask(v) {
72
+ return this._DateBRPipe.transform(v);
73
+ }
74
+ get_options() {
75
+ let options = {
76
+ nextArrow: `<i class="fas fa-caret-right"></i>`,
77
+ prevArrow: `<i class="fas fa-caret-left"></i>`,
78
+ format: 'dd/mm/yyyy',
79
+ daysOfWeekHighlighted: [0, 6],
80
+ language: 'ptBR'
81
+ };
82
+ if ((this.daysOfWeekDisabled).length > 0) {
83
+ options['daysOfWeekDisabled'] = this.daysOfWeekDisabled;
84
+ }
85
+ if ((this.datesDisabled).length > 0) {
86
+ options['datesDisabled'] = this.datesDisabled;
87
+ }
88
+ if (this.minDate !== '') {
89
+ options['minDate'] = this.minDate;
90
+ }
91
+ if (this.maxDate !== '') {
92
+ options['maxDate'] = this.maxDate;
93
+ }
94
+ if (this.multiple) {
95
+ options['maxNumberOfDates'] = this.maxNumberOfDates;
96
+ }
97
+ return options;
98
+ }
99
+ clearDate() {
100
+ if (this.datepicker) {
101
+ this.datepicker.setDate({ clear: true });
102
+ }
103
+ }
104
+ start_datepicker() {
105
+ setTimeout(() => {
106
+ const input_datepicker = this.input_datepicker?.nativeElement;
107
+ if (input_datepicker) {
108
+ input_datepicker.setAttribute('placeholder', 'DD/MM/YYYY');
109
+ if (!this.useBorder) {
110
+ input_datepicker.setAttribute('style', 'border:none; text-align: center; max-width: 105px; padding: 0;');
111
+ }
112
+ this.datepicker = new Datepicker(input_datepicker, this.get_options());
113
+ if (this.innerValue && this.innerValue !== '') {
114
+ this.toSetDefaultDate(this.innerValue);
115
+ }
116
+ input_datepicker.addEventListener('keyup', (event) => {
117
+ const v = (input_datepicker['value']) ? input_datepicker['value'] : '';
118
+ input_datepicker['value'] = this.toSetMask(v);
119
+ if ((input_datepicker['value']).length >= 10) {
120
+ const v = (input_datepicker['value']).substring(0, 10);
121
+ const part_date = (v).split('/');
122
+ if ((part_date).length === 3) {
123
+ let dia = part_date[0];
124
+ let mes = part_date[1];
125
+ let ano = part_date[2];
126
+ mes = (+(mes) < 10) ? `0${+mes}` : mes;
127
+ dia = (+(dia) < 10) ? `0${+dia}` : dia;
128
+ const dt = new Date(ano + '-' + mes + '-' + dia);
129
+ if (dt) {
130
+ input_datepicker?.changeDate;
131
+ document.getElementById(this.ID)?.blur();
132
+ this.onChange.emit(this.innerValue);
133
+ this.ngModelChange.emit(this.innerValue);
134
+ }
135
+ }
136
+ }
137
+ else {
138
+ this.innerValue = undefined;
139
+ this.onChange.emit(this.innerValue);
140
+ this.ngModelChange.emit(this.innerValue);
141
+ }
142
+ //console.log('input_datepicker', input_datepicker['value'] );
143
+ });
144
+ input_datepicker.addEventListener('changeDate', (event) => {
145
+ //console.log(event);
146
+ if (event?.detail?.date) {
147
+ this.toSelectedDate(event.detail);
148
+ }
149
+ else {
150
+ //console.log('event null');
151
+ this.innerValue = '';
152
+ this.ngModelChange.emit(this.innerValue);
153
+ }
154
+ });
155
+ }
156
+ });
157
+ }
158
+ toSetDate() {
159
+ // Ex de uso
160
+ const dates = ['18/11/2022'];
161
+ if (this.datepicker) {
162
+ this.datepicker.setDate(dates);
163
+ }
164
+ }
165
+ toSetDefaultDate(date) {
166
+ if (date === undefined || date === null || date === '') {
167
+ this.clearDate();
168
+ return;
169
+ }
170
+ let dates = [];
171
+ if (date && typeof date === 'string') {
172
+ if ((date).includes(',')) {
173
+ const dates = (date).split(',');
174
+ date = dates;
175
+ if (!this.multiple) {
176
+ this.innerValue = date = dates[0];
177
+ this.ngModelChange.emit(this.innerValue);
178
+ }
179
+ }
180
+ }
181
+ if (date && typeof date === 'string') {
182
+ (dates).push(date);
183
+ }
184
+ else {
185
+ dates = date;
186
+ }
187
+ if (this.datepicker) {
188
+ this.datepicker.setDate(dates);
189
+ }
190
+ }
191
+ toSelectedDate(detail) {
192
+ if (detail.datepicker.dates && (detail.datepicker.dates).length > 0) {
193
+ if (this.multiple) {
194
+ let dates = [];
195
+ for (let i = 0; i < (detail.datepicker.dates).length; i++) {
196
+ const timeStamp = detail.datepicker.dates[i];
197
+ (dates).push(this.format_date(timeStamp));
198
+ }
199
+ this.innerValue = dates;
200
+ this.onChange.emit(this.innerValue);
201
+ }
202
+ else {
203
+ const timeStamp = detail.datepicker.dates[0];
204
+ const date = this.format_date(timeStamp);
205
+ this.onChange.emit(date);
206
+ this.innerValue = date;
207
+ }
208
+ }
209
+ else {
210
+ this.clearDate();
211
+ this.innerValue = null;
212
+ this.onChange.emit(this.innerValue);
213
+ }
214
+ this.value = this.innerValue;
215
+ this.ngModelChange.emit(this.innerValue);
216
+ }
217
+ format_date(timeStamp) {
218
+ var date = new Date(timeStamp);
219
+ let dia = `${date.getDate()}`;
220
+ let mes = `${date.getMonth() + 1}`;
221
+ let ano = `${date.getFullYear()}`;
222
+ dia = (+(dia) < 10) ? `0${+dia}` : dia;
223
+ mes = (+(mes) < 10) ? `0${+mes}` : mes;
224
+ const dateFormat = `${dia}/${mes}/${ano}`;
225
+ return dateFormat;
226
+ }
227
+ toClickIn(id) {
228
+ const element = document.getElementById(id);
229
+ setTimeout(() => {
230
+ element?.datepicker?.show();
231
+ });
232
+ }
233
+ //get accessor
234
+ get value() {
235
+ return this.innerValue;
236
+ }
237
+ ;
238
+ //set accessor including call the onchange callback
239
+ set value(v) {
240
+ //console.log('value', v);
241
+ if (v !== this.innerValue) {
242
+ this.innerValue = v; // this.toSetMask(v);
243
+ this.onChangeCallback(v);
244
+ }
245
+ else {
246
+ // this.innerValue = '';
247
+ }
248
+ }
249
+ //Set touched on blur
250
+ onBlur() {
251
+ this.onTouchedCallback();
252
+ }
253
+ //From ControlValueAccessor interface
254
+ writeValue(value) {
255
+ if (value !== this.innerValue) {
256
+ this.innerValue = value;
257
+ this.toSetDefaultDate(value);
258
+ }
259
+ }
260
+ //From ControlValueAccessor interface
261
+ registerOnChange(fn) {
262
+ this.onChangeCallback = fn;
263
+ }
264
+ //From ControlValueAccessor interface
265
+ registerOnTouched(fn) {
266
+ this.onTouchedCallback = fn;
267
+ }
268
+ }
269
+ TCloudUiDatepickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiDatepickerComponent, deps: [{ token: i1.DateBRPipe }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
270
+ TCloudUiDatepickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: TCloudUiDatepickerComponent, selector: "tcloud-ui-datepicker", inputs: { multiple: "multiple", maxNumberOfDates: "maxNumberOfDates", daysOfWeekDisabled: "daysOfWeekDisabled", minDate: "minDate", maxDate: "maxDate", datesDisabled: "datesDisabled", modeInput: "modeInput", useBorder: "useBorder", ngModel: "ngModel", code: "code" }, outputs: { onChange: "onChange", ngModelChange: "ngModelChange" }, providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], viewQueries: [{ propertyName: "input_datepicker", first: true, predicate: ["input_datepicker"], descendants: true }], ngImport: i0, template: "<!-- Input mode -->\r\n<ng-container *ngIf=\"modeInput\">\r\n\r\n <div class=\"input-tc-datepicker\" [class.no-border]=\"!useBorder\">\r\n <table class=\"table-box-input\">\r\n <tr>\r\n <td>\r\n <div class=\"delimiter-time-icon\" (click)=\"toClickIn(ID)\" ><i class=\"fas fa-calendar-alt\"></i></div>\r\n </td>\r\n <td>\r\n <input #input_datepicker type=\"text\" name=\"{{ID}}\" id=\"{{ID}}\" class=\"form-control\" >\r\n </td>\r\n </tr>\r\n </table>\r\n </div>\r\n\r\n \r\n \r\n</ng-container>\r\n\r\n<!-- Inline mode -->\r\n<ng-container *ngIf=\"!modeInput\"> \r\n <div #input_datepicker id=\"{{ID}}\" pattern=\"/^\\d{2}\\/\\d{2}\\/\\d{4}$/\"></div>\r\n</ng-container>\r\n\r\n\r\n<!-- EX de uso \r\n <tc-datepicker \r\n [multiple]=\"false\"\r\n [daysOfWeekDisabled]=\"[0,6]\"\r\n [minDate]=\"'18/11/2021'\"\r\n [maxDate]=\"'18/12/2023'\"\r\n [datesDisabled]=\"['12/10/2022','25/12/2022']\"\r\n [modeInput]=\"false\"\r\n [(ngModel)]=\"dateValue\" >\r\n </tc-datepicker>\r\n \r\n // multiple = false\r\n // dateValue - string - pode ser: 12/12/2022 \r\n\r\n // multiple = true\r\n // dateValue - string - pode ser: 11/12/2022,12/12/2022 ... \r\n\r\n <pre>data: {{ dateValue }}</pre>\r\n-->\r\n", styles: [".input_datepicker{width:100%;max-width:290px}.input-tc-datepicker{border:1px solid #ccc;border-radius:3px}.input-tc-datepicker.no-border{border:none!important}.input-tc-datepicker .table-box-input{width:100%}.input-tc-datepicker .table-box-input td:first-child{width:20px}.input-tc-datepicker .table-box-input td:first-child .delimiter-time-icon{text-align:center;cursor:pointer}.input-tc-datepicker .table-box-input input{border:none}\n", ".datepicker{display:none}.datepicker.active{display:block}.datepicker-dropdown{left:0;padding-top:4px;position:absolute;top:0;z-index:20}.datepicker-dropdown.datepicker-orient-top{padding-bottom:4px;padding-top:0}.datepicker-picker{background-color:#fff;border-radius:4px;display:inline-block}.datepicker-dropdown .datepicker-picker{box-shadow:0 2px 3px #0a0a0a1a,0 0 0 1px #0a0a0a1a}.datepicker-picker span{-webkit-touch-callout:none;border:0;border-radius:4px;cursor:default;display:block;flex:1;text-align:center;-webkit-user-select:none;user-select:none}.datepicker-main{padding:2px}.datepicker-footer{background-color:#f5f5f5;box-shadow:inset 0 1px 1px #0a0a0a1a}.datepicker-controls,.datepicker-grid,.datepicker-view,.datepicker-view .days-of-week{display:flex}.datepicker-grid{flex-wrap:wrap}.datepicker-view .days .datepicker-cell,.datepicker-view .dow{flex-basis:14.2857142857%}.datepicker-view.datepicker-grid .datepicker-cell{flex-basis:25%}.datepicker-cell,.datepicker-view .week{height:2.25rem;line-height:2.25rem}.datepicker-title{background-color:#f5f5f5;box-shadow:inset 0 -1px 1px #0a0a0a1a;font-weight:700;padding:.375rem .75rem;text-align:center}.datepicker-header .datepicker-controls{padding:2px 2px 0}.datepicker-controls .button{align-items:center;background-color:#fff;border:1px solid #dbdbdb;border-radius:4px;box-shadow:none;color:#363636;cursor:pointer;display:inline-flex;font-size:1rem;height:2.25em;justify-content:center;line-height:1.5;margin:0;padding:calc(.375em - 1px) .75em;position:relative;text-align:center;vertical-align:top;white-space:nowrap}.datepicker-controls .button:active,.datepicker-controls .button:focus{outline:none}.datepicker-controls .button:hover{border-color:#b5b5b5;color:#363636}.datepicker-controls .button:focus{border-color:#3273dc;color:#363636}.datepicker-controls .button:focus:not(:active){box-shadow:0 0 0 .125em #3273dc40}.datepicker-controls .button:active{border-color:#4a4a4a;color:#363636}.datepicker-controls .button[disabled]{cursor:not-allowed}.datepicker-header .datepicker-controls .button{border-color:transparent;font-weight:700}.datepicker-header .datepicker-controls .button:hover{background-color:#f9f9f9}.datepicker-header .datepicker-controls .button:focus:not(:active){box-shadow:0 0 0 .125em #ffffff40}.datepicker-header .datepicker-controls .button:active{background-color:#f2f2f2}.datepicker-header .datepicker-controls .button[disabled]{box-shadow:none}.datepicker-footer .datepicker-controls .button{border-radius:2px;font-size:.75rem;margin:calc(.375rem - 1px) .375rem;width:100%}.datepicker-controls .view-switch{flex:auto}.datepicker-controls .next-btn,.datepicker-controls .prev-btn{padding-left:.375rem;padding-right:.375rem;width:2.25rem}.datepicker-controls .next-btn.disabled,.datepicker-controls .prev-btn.disabled{visibility:hidden}.datepicker-view .dow{font-size:.875rem;font-weight:700;height:1.5rem;line-height:1.5rem}.datepicker-view .week{color:#b5b5b5;font-size:.75rem;width:2.25rem}@media (max-width:22.5rem){.datepicker-view .week{width:1.96875rem}}.datepicker-grid{width:15.75rem}@media (max-width:22.5rem){.calendar-weeks+.days .datepicker-grid{width:13.78125rem}}.datepicker-cell:not(.disabled):hover{background-color:#f9f9f9;cursor:pointer}.datepicker-cell.focused:not(.selected){background-color:#e8e8e8}.datepicker-cell.selected,.datepicker-cell.selected:hover{background-color:#3273dc;color:#fff;font-weight:600}.datepicker-cell.disabled{color:#dbdbdb}.datepicker-cell.next:not(.disabled),.datepicker-cell.prev:not(.disabled){color:#7a7a7a}.datepicker-cell.next.selected,.datepicker-cell.prev.selected{color:#e6e6e6}.datepicker-cell.highlighted:not(.selected):not(.range):not(.today){background-color:#f5f5f5;border-radius:0}.datepicker-cell.highlighted:not(.selected):not(.range):not(.today):not(.disabled):hover{background-color:#eee}.datepicker-cell.highlighted:not(.selected):not(.range):not(.today).focused{background-color:#e8e8e8}.datepicker-cell.today:not(.selected){background-color:#00d1b2}.datepicker-cell.today:not(.selected):not(.disabled){color:#fff}.datepicker-cell.today.focused:not(.selected){background-color:#00c4a7}.datepicker-cell.range-end:not(.selected),.datepicker-cell.range-start:not(.selected){background-color:#b5b5b5;color:#fff}.datepicker-cell.range-end.focused:not(.selected),.datepicker-cell.range-start.focused:not(.selected){background-color:#afafaf}.datepicker-cell.range-start{border-radius:4px 0 0 4px}.datepicker-cell.range-end{border-radius:0 4px 4px 0}.datepicker-cell.range{background-color:#dbdbdb;border-radius:0}.datepicker-cell.range:not(.disabled):not(.focused):not(.today):hover{background-color:#d5d5d5}.datepicker-cell.range.disabled{color:#c2c2c2}.datepicker-cell.range.focused{background-color:#cfcfcf}.datepicker-view.datepicker-grid .datepicker-cell{height:4.5rem;line-height:4.5rem}.datepicker-input.in-edit{border-color:#2366d1}.datepicker-input.in-edit:active,.datepicker-input.in-edit:focus{box-shadow:0 0 .25em .25em #2366d133}\n", ".datepicker-picker{border:1px solid #ccc;padding:10px 15px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None });
271
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiDatepickerComponent, decorators: [{
272
+ type: Component,
273
+ args: [{ selector: 'tcloud-ui-datepicker', providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], encapsulation: ViewEncapsulation.None, template: "<!-- Input mode -->\r\n<ng-container *ngIf=\"modeInput\">\r\n\r\n <div class=\"input-tc-datepicker\" [class.no-border]=\"!useBorder\">\r\n <table class=\"table-box-input\">\r\n <tr>\r\n <td>\r\n <div class=\"delimiter-time-icon\" (click)=\"toClickIn(ID)\" ><i class=\"fas fa-calendar-alt\"></i></div>\r\n </td>\r\n <td>\r\n <input #input_datepicker type=\"text\" name=\"{{ID}}\" id=\"{{ID}}\" class=\"form-control\" >\r\n </td>\r\n </tr>\r\n </table>\r\n </div>\r\n\r\n \r\n \r\n</ng-container>\r\n\r\n<!-- Inline mode -->\r\n<ng-container *ngIf=\"!modeInput\"> \r\n <div #input_datepicker id=\"{{ID}}\" pattern=\"/^\\d{2}\\/\\d{2}\\/\\d{4}$/\"></div>\r\n</ng-container>\r\n\r\n\r\n<!-- EX de uso \r\n <tc-datepicker \r\n [multiple]=\"false\"\r\n [daysOfWeekDisabled]=\"[0,6]\"\r\n [minDate]=\"'18/11/2021'\"\r\n [maxDate]=\"'18/12/2023'\"\r\n [datesDisabled]=\"['12/10/2022','25/12/2022']\"\r\n [modeInput]=\"false\"\r\n [(ngModel)]=\"dateValue\" >\r\n </tc-datepicker>\r\n \r\n // multiple = false\r\n // dateValue - string - pode ser: 12/12/2022 \r\n\r\n // multiple = true\r\n // dateValue - string - pode ser: 11/12/2022,12/12/2022 ... \r\n\r\n <pre>data: {{ dateValue }}</pre>\r\n-->\r\n", styles: [".input_datepicker{width:100%;max-width:290px}.input-tc-datepicker{border:1px solid #ccc;border-radius:3px}.input-tc-datepicker.no-border{border:none!important}.input-tc-datepicker .table-box-input{width:100%}.input-tc-datepicker .table-box-input td:first-child{width:20px}.input-tc-datepicker .table-box-input td:first-child .delimiter-time-icon{text-align:center;cursor:pointer}.input-tc-datepicker .table-box-input input{border:none}\n", ".datepicker{display:none}.datepicker.active{display:block}.datepicker-dropdown{left:0;padding-top:4px;position:absolute;top:0;z-index:20}.datepicker-dropdown.datepicker-orient-top{padding-bottom:4px;padding-top:0}.datepicker-picker{background-color:#fff;border-radius:4px;display:inline-block}.datepicker-dropdown .datepicker-picker{box-shadow:0 2px 3px #0a0a0a1a,0 0 0 1px #0a0a0a1a}.datepicker-picker span{-webkit-touch-callout:none;border:0;border-radius:4px;cursor:default;display:block;flex:1;text-align:center;-webkit-user-select:none;user-select:none}.datepicker-main{padding:2px}.datepicker-footer{background-color:#f5f5f5;box-shadow:inset 0 1px 1px #0a0a0a1a}.datepicker-controls,.datepicker-grid,.datepicker-view,.datepicker-view .days-of-week{display:flex}.datepicker-grid{flex-wrap:wrap}.datepicker-view .days .datepicker-cell,.datepicker-view .dow{flex-basis:14.2857142857%}.datepicker-view.datepicker-grid .datepicker-cell{flex-basis:25%}.datepicker-cell,.datepicker-view .week{height:2.25rem;line-height:2.25rem}.datepicker-title{background-color:#f5f5f5;box-shadow:inset 0 -1px 1px #0a0a0a1a;font-weight:700;padding:.375rem .75rem;text-align:center}.datepicker-header .datepicker-controls{padding:2px 2px 0}.datepicker-controls .button{align-items:center;background-color:#fff;border:1px solid #dbdbdb;border-radius:4px;box-shadow:none;color:#363636;cursor:pointer;display:inline-flex;font-size:1rem;height:2.25em;justify-content:center;line-height:1.5;margin:0;padding:calc(.375em - 1px) .75em;position:relative;text-align:center;vertical-align:top;white-space:nowrap}.datepicker-controls .button:active,.datepicker-controls .button:focus{outline:none}.datepicker-controls .button:hover{border-color:#b5b5b5;color:#363636}.datepicker-controls .button:focus{border-color:#3273dc;color:#363636}.datepicker-controls .button:focus:not(:active){box-shadow:0 0 0 .125em #3273dc40}.datepicker-controls .button:active{border-color:#4a4a4a;color:#363636}.datepicker-controls .button[disabled]{cursor:not-allowed}.datepicker-header .datepicker-controls .button{border-color:transparent;font-weight:700}.datepicker-header .datepicker-controls .button:hover{background-color:#f9f9f9}.datepicker-header .datepicker-controls .button:focus:not(:active){box-shadow:0 0 0 .125em #ffffff40}.datepicker-header .datepicker-controls .button:active{background-color:#f2f2f2}.datepicker-header .datepicker-controls .button[disabled]{box-shadow:none}.datepicker-footer .datepicker-controls .button{border-radius:2px;font-size:.75rem;margin:calc(.375rem - 1px) .375rem;width:100%}.datepicker-controls .view-switch{flex:auto}.datepicker-controls .next-btn,.datepicker-controls .prev-btn{padding-left:.375rem;padding-right:.375rem;width:2.25rem}.datepicker-controls .next-btn.disabled,.datepicker-controls .prev-btn.disabled{visibility:hidden}.datepicker-view .dow{font-size:.875rem;font-weight:700;height:1.5rem;line-height:1.5rem}.datepicker-view .week{color:#b5b5b5;font-size:.75rem;width:2.25rem}@media (max-width:22.5rem){.datepicker-view .week{width:1.96875rem}}.datepicker-grid{width:15.75rem}@media (max-width:22.5rem){.calendar-weeks+.days .datepicker-grid{width:13.78125rem}}.datepicker-cell:not(.disabled):hover{background-color:#f9f9f9;cursor:pointer}.datepicker-cell.focused:not(.selected){background-color:#e8e8e8}.datepicker-cell.selected,.datepicker-cell.selected:hover{background-color:#3273dc;color:#fff;font-weight:600}.datepicker-cell.disabled{color:#dbdbdb}.datepicker-cell.next:not(.disabled),.datepicker-cell.prev:not(.disabled){color:#7a7a7a}.datepicker-cell.next.selected,.datepicker-cell.prev.selected{color:#e6e6e6}.datepicker-cell.highlighted:not(.selected):not(.range):not(.today){background-color:#f5f5f5;border-radius:0}.datepicker-cell.highlighted:not(.selected):not(.range):not(.today):not(.disabled):hover{background-color:#eee}.datepicker-cell.highlighted:not(.selected):not(.range):not(.today).focused{background-color:#e8e8e8}.datepicker-cell.today:not(.selected){background-color:#00d1b2}.datepicker-cell.today:not(.selected):not(.disabled){color:#fff}.datepicker-cell.today.focused:not(.selected){background-color:#00c4a7}.datepicker-cell.range-end:not(.selected),.datepicker-cell.range-start:not(.selected){background-color:#b5b5b5;color:#fff}.datepicker-cell.range-end.focused:not(.selected),.datepicker-cell.range-start.focused:not(.selected){background-color:#afafaf}.datepicker-cell.range-start{border-radius:4px 0 0 4px}.datepicker-cell.range-end{border-radius:0 4px 4px 0}.datepicker-cell.range{background-color:#dbdbdb;border-radius:0}.datepicker-cell.range:not(.disabled):not(.focused):not(.today):hover{background-color:#d5d5d5}.datepicker-cell.range.disabled{color:#c2c2c2}.datepicker-cell.range.focused{background-color:#cfcfcf}.datepicker-view.datepicker-grid .datepicker-cell{height:4.5rem;line-height:4.5rem}.datepicker-input.in-edit{border-color:#2366d1}.datepicker-input.in-edit:active,.datepicker-input.in-edit:focus{box-shadow:0 0 .25em .25em #2366d133}\n", ".datepicker-picker{border:1px solid #ccc;padding:10px 15px}\n"] }]
274
+ }], ctorParameters: function () { return [{ type: i1.DateBRPipe }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { multiple: [{
275
+ type: Input
276
+ }], maxNumberOfDates: [{
277
+ type: Input
278
+ }], daysOfWeekDisabled: [{
279
+ type: Input
280
+ }], minDate: [{
281
+ type: Input
282
+ }], maxDate: [{
283
+ type: Input
284
+ }], datesDisabled: [{
285
+ type: Input
286
+ }], modeInput: [{
287
+ type: Input
288
+ }], useBorder: [{
289
+ type: Input
290
+ }], onChange: [{
291
+ type: Output
292
+ }], ngModel: [{
293
+ type: Input
294
+ }], ngModelChange: [{
295
+ type: Output
296
+ }], input_datepicker: [{
297
+ type: ViewChild,
298
+ args: ['input_datepicker', { static: false }]
299
+ }], code: [{
300
+ type: Input
301
+ }] } });
302
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tcloud-ui-datepicker.component.js","sourceRoot":"","sources":["../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-datepicker/tcloud-ui-datepicker.component.ts","../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-datepicker/tcloud-ui-datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild, ElementRef, Output, EventEmitter, forwardRef, Input, ViewEncapsulation, ChangeDetectorRef } from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { DateBRPipe } from '../../_pipes';\r\n\r\n// https://mymth.github.io/vanillajs-datepicker/#/\r\ndeclare var Datepicker: any;\r\n\r\nvar translation = {\r\n  ptBR: {\r\n    days: [\"Domingo\", \"Segunda\", \"Terça\", \"Quarta\", \"Quinta\", \"Sexta\", \"Sábado\"],\r\n    daysShort: [\"Dom\", \"Seg\", \"Ter\", \"Qua\", \"Qui\", \"Sex\", \"Sáb\"],\r\n    daysMin: [\"Do\", \"Se\", \"Te\", \"Qu\", \"Qu\", \"Se\", \"Sa\"],\r\n    months: [\"Janeiro\", \"Fevereiro\", \"Março\", \"Abril\", \"Maio\", \"Junho\", \"Julho\", \"Agosto\", \"Setembro\", \"Outubro\", \"Novembro\", \"Dezembro\"],\r\n    monthsShort: [\"Jan\", \"Fev\", \"Mar\", \"Abr\", \"Mai\", \"Jun\", \"Jul\", \"Ago\", \"Set\", \"Out\", \"Nov\", \"Dez\"],\r\n    today: \"Hoje\",\r\n    clear: \"Limpar\",\r\n    titleFormat: \"MM y\",\r\n    format: \"dd/mm/yyyy\",\r\n    weekStart: 0\r\n  }\r\n};\r\n\r\nconst CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR: any = {\r\n  provide: NG_VALUE_ACCESSOR,\r\n  useExisting: forwardRef(() => TCloudUiDatepickerComponent),\r\n  multi: true\r\n};\r\n\r\nconst noop = () => {\r\n};\r\n\r\n@Component({\r\n  selector: 'tcloud-ui-datepicker',\r\n  templateUrl: './tcloud-ui-datepicker.component.html',\r\n  styleUrls: [\r\n    './tcloud-ui-datepicker.component.scss',\r\n    './datepicker/css/datepicker.min.css',\r\n    './datepicker/css/style.css',\r\n  ],\r\n  providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TCloudUiDatepickerComponent implements OnInit {\r\n\r\n  // multiple permite selecionar multiplas datas\r\n  @Input() multiple: boolean = false;\r\n\r\n  // maxNumberOfDates - Maximum number of dates users can select. No limit is applied if 0 is set.\r\n  // Depende de: multiple como true\r\n  @Input() maxNumberOfDates: number = 0;\r\n\r\n  // daysOfWeekDisabled - Dias da semana desabilidatos = 0 para sabado até 6 para domingo\r\n  @Input() daysOfWeekDisabled: number[] = [];\r\n\r\n  // minDate - Data minima para exibicao do calendario - ex: 01/01/2020\r\n  @Input() minDate: string = '';\r\n\r\n  // maxDate - Data maxima para exibicao do calendario - ex: 31/12/2020\r\n  @Input() maxDate: string = '';\r\n\r\n  // datesDisabled - Datas desabilitadas - Ex: ['12/10/2020','25/12/2020']\r\n  @Input() datesDisabled: string[] = [];\r\n\r\n  // modeInput - Exibe um input para quando clicar abrir o calendario\r\n  @Input() modeInput: boolean = false;\r\n\r\n  @Input() useBorder: boolean = true;\r\n\r\n  // onChange - Dispara a data selecionada\r\n  @Output() onChange = new EventEmitter<any|undefined>();\r\n\r\n  private _ngModel: any | undefined;\r\n  @Input() set ngModel(v: any){\r\n\r\n    //console.log('ngModel', v);\r\n\r\n    if( v && v !== this.innerValue ){\r\n      this.innerValue = v; //this.toSetMask(v); \r\n    } \r\n  }\r\n  @Output() ngModelChange = new EventEmitter<any|undefined>();\r\n\r\n  @ViewChild('input_datepicker', {static: false}) input_datepicker: ElementRef<HTMLElement> | undefined;\r\n  private datepicker: any | undefined;\r\n  @Input() code: string = 'tcloud-ui-datepicker';\r\n\r\n  constructor(\r\n    private _DateBRPipe: DateBRPipe,\r\n    private _changeDetectorRef: ChangeDetectorRef\r\n  ) { }\r\n\r\n  ID: string = '';\r\n\r\n  ngOnInit(): void {\r\n    this.ID = this.generateID();\r\n    Datepicker.locales.ptBR = translation.ptBR;    \r\n    this.start_datepicker();\r\n  }\r\n\r\n  generateID(): string{\r\n    return `tcloud-ui-datepicker-${Math.floor(Math.random() * Math.floor(Math.random() * Date.now()))}`;\r\n  }\r\n\r\n  toSetMask(v: string){\r\n    return this._DateBRPipe.transform(v);\r\n  }\r\n\r\n  get_options(){\r\n    let options = {\r\n      nextArrow: `<i class=\"fas fa-caret-right\"></i>`,\r\n      prevArrow: `<i class=\"fas fa-caret-left\"></i>`,\r\n      format: 'dd/mm/yyyy',      \r\n      daysOfWeekHighlighted: [0,6],\r\n      language: 'ptBR'\r\n    } as any;\r\n\r\n    if( (this.daysOfWeekDisabled).length > 0 ){\r\n      options['daysOfWeekDisabled'] = this.daysOfWeekDisabled;\r\n    }\r\n\r\n    if( (this.datesDisabled).length > 0 ){\r\n      options['datesDisabled'] = this.datesDisabled;\r\n    }\r\n\r\n    if( this.minDate !== '' ){\r\n      options['minDate'] = this.minDate;\r\n    }\r\n\r\n    if( this.maxDate !== '' ){\r\n      options['maxDate'] = this.maxDate;\r\n    }\r\n\r\n    if( this.multiple ){      \r\n      options['maxNumberOfDates'] = this.maxNumberOfDates;\r\n    }\r\n\r\n    return options;\r\n  }\r\n\r\n  clearDate(){\r\n    if( this.datepicker ){\r\n      this.datepicker.setDate({clear: true});\r\n    }\r\n  }\r\n\r\n  start_datepicker(){\r\n    setTimeout(() => {     \r\n      const input_datepicker = <any> this.input_datepicker?.nativeElement;\r\n      if( input_datepicker ){\r\n\r\n        input_datepicker.setAttribute('placeholder','DD/MM/YYYY');\r\n\r\n        if( !this.useBorder ){\r\n          input_datepicker.setAttribute('style','border:none; text-align: center; max-width: 105px; padding: 0;');\r\n        }\r\n        \r\n\r\n        this.datepicker = new Datepicker( input_datepicker, this.get_options() );\r\n\r\n        if( this.innerValue && this.innerValue !== '' ){\r\n          this.toSetDefaultDate(this.innerValue);\r\n        }\r\n\r\n        input_datepicker.addEventListener('keyup', (event: any) => {\r\n          const v = (input_datepicker['value']) ? input_datepicker['value'] : '';\r\n          input_datepicker['value'] = this.toSetMask(v);\r\n\r\n          if( (input_datepicker['value']).length >= 10 ){\r\n            const v = (input_datepicker['value']).substring(0, 10);\r\n            const part_date = (v).split('/');\r\n            if( (part_date).length === 3 ){\r\n\r\n              let dia = part_date[0];\r\n              let mes = part_date[1];\r\n              let ano = part_date[2];\r\n\r\n              mes = (+(mes) < 10 ) ? `0${+mes}` : mes;  \r\n              dia = (+(dia) < 10 ) ? `0${+dia}` : dia;\r\n\r\n              const dt = new Date(ano+'-'+mes+'-'+dia);\r\n              if( dt ){\r\n                input_datepicker?.changeDate;\r\n                document.getElementById(this.ID)?.blur();\r\n                this.onChange.emit(this.innerValue);\r\n                this.ngModelChange.emit(this.innerValue);\r\n              }\r\n            }\r\n          }else{\r\n            this.innerValue = undefined;\r\n            this.onChange.emit(this.innerValue);\r\n            this.ngModelChange.emit(this.innerValue);\r\n          }\r\n          //console.log('input_datepicker', input_datepicker['value'] );\r\n        })\r\n\r\n\r\n        input_datepicker.addEventListener('changeDate', (event: any) => {\r\n          //console.log(event);\r\n          if( event?.detail?.date ){\r\n            this.toSelectedDate( event.detail );\r\n          }else{\r\n            //console.log('event null');\r\n            this.innerValue = '';\r\n            this.ngModelChange.emit(this.innerValue);\r\n          }\r\n        })\r\n      }      \r\n    });\r\n  }\r\n\r\n  toSetDate(){\r\n    // Ex de uso\r\n    const dates = ['18/11/2022'];\r\n    if( this.datepicker ){\r\n      this.datepicker.setDate(dates);\r\n    }    \r\n  }\r\n\r\n  toSetDefaultDate(date: string | string[]){\r\n    \r\n    if( date === undefined || date === null || date === '' ){\r\n      this.clearDate();\r\n      return;\r\n    }\r\n\r\n    let dates = [] as string[];\r\n\r\n    if( date && typeof date === 'string' ){\r\n      if( (date).includes(',') ){\r\n        const dates = (date).split(',');\r\n        date = dates;\r\n        if( !this.multiple ){\r\n          this.innerValue = date = dates[0];\r\n          this.ngModelChange.emit(this.innerValue); \r\n        }\r\n      }\r\n    }\r\n    \r\n    if( date && typeof date === 'string' ){\r\n      (dates).push( date ); \r\n    }else{\r\n      dates = <Array<string>> date;\r\n    }\r\n    if( this.datepicker ){\r\n      this.datepicker.setDate(dates);      \r\n    } \r\n  }\r\n\r\n  toSelectedDate(detail: any){    \r\n    if( detail.datepicker.dates && (detail.datepicker.dates).length > 0 ){\r\n      if( this.multiple ){\r\n        let dates = [];\r\n        for( let i = 0; i < (detail.datepicker.dates).length; i++ ){\r\n          const timeStamp = <number> detail.datepicker.dates[i];\r\n          (dates).push( this.format_date( timeStamp ) );\r\n        }\r\n        this.innerValue = dates;\r\n        this.onChange.emit(this.innerValue);        \r\n      }else{\r\n        const timeStamp = <number> detail.datepicker.dates[0];\r\n        const date = this.format_date( timeStamp );\r\n        this.onChange.emit(date);\r\n        this.innerValue = date;\r\n      }      \r\n    }else{\r\n      this.clearDate();\r\n      this.innerValue = null;\r\n      this.onChange.emit(this.innerValue);\r\n    } \r\n    this.value = this.innerValue;\r\n    this.ngModelChange.emit(this.innerValue); \r\n  }\r\n\r\n  format_date(timeStamp: number){\r\n    var date = new Date(timeStamp);\r\n\r\n    let dia = `${date.getDate()}`;\r\n    let mes = `${date.getMonth()+1}`;\r\n    let ano = `${date.getFullYear()}`;\r\n\r\n    dia = (+(dia) < 10 ) ? `0${+dia}` : dia;\r\n    mes = (+(mes) < 10 ) ? `0${+mes}` : mes; \r\n\r\n    const dateFormat = `${dia}/${mes}/${ano}`;\r\n    return dateFormat;\r\n  }\r\n\r\n  toClickIn(id: string){\r\n    const element = document.getElementById(id) as any;\r\n    setTimeout(() => {      \r\n      element?.datepicker?.show();\r\n    });\r\n  }\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n  innerValue: any | undefined;\r\n  //Placeholders for the callbacks which are later providesd\r\n  //by the Control Value Accessor\r\n  private onTouchedCallback: () => void = noop;\r\n  private onChangeCallback: (_: any) => void = noop;\r\n\r\n  //get accessor\r\n  get value(): any {\r\n      return this.innerValue;\r\n  };\r\n\r\n  //set accessor including call the onchange callback\r\n  set value(v: any) {\r\n\r\n    //console.log('value', v);\r\n\r\n    if (v !== this.innerValue) {\r\n      this.innerValue = v; // this.toSetMask(v);      \r\n      this.onChangeCallback(v);\r\n    }else{\r\n     // this.innerValue = '';\r\n    }\r\n  }\r\n\r\n  //Set touched on blur\r\n  onBlur() {\r\n    this.onTouchedCallback();\r\n  }\r\n\r\n  //From ControlValueAccessor interface\r\n  writeValue(value: any) {\r\n    if (value !== this.innerValue) {\r\n      this.innerValue = value;\r\n      this.toSetDefaultDate(value);\r\n    }\r\n  }\r\n\r\n  //From ControlValueAccessor interface\r\n  registerOnChange(fn: any) {\r\n    this.onChangeCallback = fn;\r\n  }\r\n\r\n  //From ControlValueAccessor interface\r\n  registerOnTouched(fn: any) {\r\n    this.onTouchedCallback = fn;\r\n  }\r\n\r\n}\r\n","<!-- Input mode -->\r\n<ng-container *ngIf=\"modeInput\">\r\n\r\n  <div class=\"input-tc-datepicker\" [class.no-border]=\"!useBorder\">\r\n    <table class=\"table-box-input\">\r\n      <tr>\r\n        <td>\r\n          <div class=\"delimiter-time-icon\" (click)=\"toClickIn(ID)\" ><i class=\"fas fa-calendar-alt\"></i></div>\r\n        </td>\r\n        <td>\r\n          <input #input_datepicker type=\"text\" name=\"{{ID}}\" id=\"{{ID}}\" class=\"form-control\" >\r\n        </td>\r\n      </tr>\r\n    </table>\r\n  </div>\r\n\r\n  \r\n  \r\n</ng-container>\r\n\r\n<!-- Inline mode -->\r\n<ng-container *ngIf=\"!modeInput\">  \r\n  <div #input_datepicker id=\"{{ID}}\" pattern=\"/^\\d{2}\\/\\d{2}\\/\\d{4}$/\"></div>\r\n</ng-container>\r\n\r\n\r\n<!-- EX de uso \r\n  <tc-datepicker \r\n    [multiple]=\"false\"\r\n    [daysOfWeekDisabled]=\"[0,6]\"\r\n    [minDate]=\"'18/11/2021'\"\r\n    [maxDate]=\"'18/12/2023'\"\r\n    [datesDisabled]=\"['12/10/2022','25/12/2022']\"\r\n    [modeInput]=\"false\"\r\n    [(ngModel)]=\"dateValue\" >\r\n  </tc-datepicker>\r\n  \r\n  // multiple = false\r\n  // dateValue - string - pode ser: 12/12/2022 \r\n\r\n  // multiple = true\r\n  // dateValue - string - pode ser: 11/12/2022,12/12/2022 ... \r\n\r\n  <pre>data: {{ dateValue }}</pre>\r\n-->\r\n"]}
@@ -0,0 +1,31 @@
1
+ import { FormsModule, ReactiveFormsModule } from '@angular/forms';
2
+ import { NgModule } from '@angular/core';
3
+ import { CommonModule } from '@angular/common';
4
+ import { TCloudUiDatepickerComponent } from './tcloud-ui-datepicker.component';
5
+ import * as i0 from "@angular/core";
6
+ export class TCloudUiDatepickerModule {
7
+ }
8
+ TCloudUiDatepickerModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiDatepickerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
9
+ TCloudUiDatepickerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiDatepickerModule, declarations: [TCloudUiDatepickerComponent], imports: [CommonModule,
10
+ FormsModule,
11
+ ReactiveFormsModule], exports: [TCloudUiDatepickerComponent] });
12
+ TCloudUiDatepickerModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiDatepickerModule, imports: [CommonModule,
13
+ FormsModule,
14
+ ReactiveFormsModule] });
15
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiDatepickerModule, decorators: [{
16
+ type: NgModule,
17
+ args: [{
18
+ declarations: [
19
+ TCloudUiDatepickerComponent
20
+ ],
21
+ exports: [
22
+ TCloudUiDatepickerComponent
23
+ ],
24
+ imports: [
25
+ CommonModule,
26
+ FormsModule,
27
+ ReactiveFormsModule
28
+ ]
29
+ }]
30
+ }] });
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGNsb3VkLXVpLWRhdGVwaWNrZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGNsb3VkLXVpL3NyYy9saWIvX21vZHVsZXMvdGNsb3VkLXVpLWRhdGVwaWNrZXIvdGNsb3VkLXVpLWRhdGVwaWNrZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQzs7QUFpQi9FLE1BQU0sT0FBTyx3QkFBd0I7O3NIQUF4Qix3QkFBd0I7dUhBQXhCLHdCQUF3QixpQkFYakMsMkJBQTJCLGFBTTNCLFlBQVk7UUFDWixXQUFXO1FBQ1gsbUJBQW1CLGFBTG5CLDJCQUEyQjt1SEFRbEIsd0JBQXdCLFlBTGpDLFlBQVk7UUFDWixXQUFXO1FBQ1gsbUJBQW1COzRGQUdWLHdCQUF3QjtrQkFicEMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUU7d0JBQ1osMkJBQTJCO3FCQUM1QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsMkJBQTJCO3FCQUM1QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixXQUFXO3dCQUNYLG1CQUFtQjtxQkFDcEI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgVENsb3VkVWlEYXRlcGlja2VyQ29tcG9uZW50IH0gZnJvbSAnLi90Y2xvdWQtdWktZGF0ZXBpY2tlci5jb21wb25lbnQnO1xyXG5cclxuXHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgVENsb3VkVWlEYXRlcGlja2VyQ29tcG9uZW50XHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBUQ2xvdWRVaURhdGVwaWNrZXJDb21wb25lbnRcclxuICBdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZVxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIFRDbG91ZFVpRGF0ZXBpY2tlck1vZHVsZSB7IH1cclxuIl19