@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.
- package/README.md +11 -0
- package/esm2020/lib/_directives/directives.module.mjs +10 -5
- package/esm2020/lib/_directives/hover-parent/hover-parent.directive.mjs +58 -0
- package/esm2020/lib/_modules/tcloud-ui-datepicker/tcloud-ui-datepicker.component.mjs +302 -0
- package/esm2020/lib/_modules/tcloud-ui-datepicker/tcloud-ui-datepicker.module.mjs +31 -0
- package/esm2020/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.component.mjs +209 -0
- package/esm2020/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.module.mjs +35 -0
- package/esm2020/lib/_modules/tcloud-ui-filters/tcloud-ui-filters.component.mjs +79 -29
- package/esm2020/lib/_modules/tcloud-ui-filters/tcloud-ui-filters.module.mjs +8 -4
- package/esm2020/lib/_pipes/datebr.mjs +102 -0
- package/esm2020/lib/_pipes/index.mjs +2 -1
- package/esm2020/lib/_pipes/tcloud-pipes.module.mjs +14 -8
- package/esm2020/lib/tcloud-ui.module.mjs +17 -3
- package/esm2020/public-api.mjs +8 -1
- package/fesm2015/dev-tcloud-tcloud-ui.mjs +1345 -553
- package/fesm2015/dev-tcloud-tcloud-ui.mjs.map +1 -1
- package/fesm2020/dev-tcloud-tcloud-ui.mjs +1337 -551
- package/fesm2020/dev-tcloud-tcloud-ui.mjs.map +1 -1
- package/lib/_directives/directives.module.d.ts +2 -1
- package/lib/_directives/hover-parent/hover-parent.directive.d.ts +15 -0
- package/lib/_modules/tcloud-ui-datepicker/tcloud-ui-datepicker.component.d.ts +46 -0
- package/lib/_modules/tcloud-ui-datepicker/tcloud-ui-datepicker.module.d.ts +9 -0
- package/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.component.d.ts +34 -0
- package/lib/_modules/tcloud-ui-datepicker-time/tcloud-ui-datepicker-time.module.d.ts +10 -0
- package/lib/_modules/tcloud-ui-filters/tcloud-ui-filters.component.d.ts +2 -1
- package/lib/_modules/tcloud-ui-filters/tcloud-ui-filters.module.d.ts +2 -1
- package/lib/_pipes/datebr.d.ts +11 -0
- package/lib/_pipes/index.d.ts +1 -0
- package/lib/_pipes/tcloud-pipes.module.d.ts +3 -2
- package/lib/tcloud-ui.module.d.ts +5 -3
- package/package.json +1 -1
- 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
|
|
10
|
-
|
|
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,
|
|
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
|