ng-tailwind 4.2.29 → 4.3.31

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 (24) hide show
  1. package/components/ngt-action/ngt-action.component.d.ts +15 -4
  2. package/components/ngt-button/ngt-button.component.d.ts +8 -5
  3. package/components/ngt-checkbox/ngt-checkbox.component.d.ts +10 -6
  4. package/components/ngt-form/ngt-form.component.d.ts +6 -3
  5. package/components/ngt-multi-select/ngt-multi-select.component.d.ts +3 -1
  6. package/components/ngt-radio-button/ngt-radio-button.component.d.ts +10 -5
  7. package/components/ngt-section/ngt-section.component.d.ts +6 -3
  8. package/components/ngt-select/ngt-select.component.d.ts +8 -5
  9. package/esm2020/components/ngt-action/ngt-action.component.mjs +59 -9
  10. package/esm2020/components/ngt-button/ngt-button.component.mjs +35 -26
  11. package/esm2020/components/ngt-checkbox/ngt-checkbox.component.mjs +46 -19
  12. package/esm2020/components/ngt-datatable/ngt-datatable.component.mjs +4 -2
  13. package/esm2020/components/ngt-form/ngt-form.component.mjs +14 -4
  14. package/esm2020/components/ngt-input/ngt-input.component.mjs +2 -1
  15. package/esm2020/components/ngt-multi-select/ngt-multi-select.component.mjs +9 -4
  16. package/esm2020/components/ngt-radio-button/ngt-radio-button.component.mjs +46 -18
  17. package/esm2020/components/ngt-section/ngt-section.component.mjs +13 -3
  18. package/esm2020/components/ngt-select/ngt-select.component.mjs +66 -36
  19. package/esm2020/components/ngt-shining/ngt-shining.component.mjs +2 -2
  20. package/fesm2015/ng-tailwind.mjs +793 -610
  21. package/fesm2015/ng-tailwind.mjs.map +1 -1
  22. package/fesm2020/ng-tailwind.mjs +784 -617
  23. package/fesm2020/ng-tailwind.mjs.map +1 -1
  24. package/package.json +1 -1
@@ -1,4 +1,4 @@
1
- import { Component, Input, Optional, Self, SkipSelf } from '@angular/core';
1
+ import { Component, Input, Optional, Self, SkipSelf, } from '@angular/core';
2
2
  import { NgtStylizableService } from '../../services/ngt-stylizable/ngt-stylizable.service';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "../ngt-form/ngt-form.component";
@@ -6,9 +6,10 @@ import * as i2 from "../../directives/ngt-stylizable/ngt-stylizable.directive";
6
6
  import * as i3 from "@angular/common";
7
7
  import * as i4 from "@angular/router";
8
8
  export class NgtButtonComponent {
9
- constructor(ngtFormComponent, injector, ngtStylizableDirective) {
10
- this.ngtFormComponent = ngtFormComponent;
9
+ constructor(changeDetector, injector, ngtForm, ngtStylizableDirective) {
10
+ this.changeDetector = changeDetector;
11
11
  this.injector = injector;
12
+ this.ngtForm = ngtForm;
12
13
  this.ngtStylizableDirective = ngtStylizableDirective;
13
14
  this.link = false;
14
15
  this.type = 'success';
@@ -22,11 +23,10 @@ export class NgtButtonComponent {
22
23
  else {
23
24
  this.ngtStyle = new NgtStylizableService();
24
25
  }
25
- if (this.ngtFormComponent) {
26
- this.subscriptions.push(this.ngtFormComponent.onLoadingChange.subscribe((loading) => {
27
- this.loading = loading;
28
- }));
29
- }
26
+ this.ngtStyle.load(this.injector, 'NgtButton', {
27
+ px: 'px-4',
28
+ py: 'py-2'
29
+ });
30
30
  }
31
31
  onClick(event) {
32
32
  if (this.isDisabled || this.loading) {
@@ -34,6 +34,9 @@ export class NgtButtonComponent {
34
34
  event.stopPropagation();
35
35
  }
36
36
  }
37
+ ngAfterViewInit() {
38
+ this.bindSubscriptions();
39
+ }
37
40
  ngOnChanges(changes) {
38
41
  if (changes.type) {
39
42
  if (changes.type.currentValue == 'success') {
@@ -41,9 +44,7 @@ export class NgtButtonComponent {
41
44
  color: {
42
45
  bg: 'bg-green-500',
43
46
  text: 'text-white text-sm',
44
- },
45
- px: 'px-4',
46
- py: 'py-2'
47
+ }
47
48
  });
48
49
  }
49
50
  else if (changes.type.currentValue == 'warning') {
@@ -51,9 +52,7 @@ export class NgtButtonComponent {
51
52
  color: {
52
53
  bg: 'bg-orange-500',
53
54
  text: 'text-white text-sm',
54
- },
55
- px: 'px-4',
56
- py: 'py-2'
55
+ }
57
56
  });
58
57
  }
59
58
  else if (changes.type.currentValue == 'danger') {
@@ -61,9 +60,7 @@ export class NgtButtonComponent {
61
60
  color: {
62
61
  bg: 'bg-red-500',
63
62
  text: 'text-white text-sm',
64
- },
65
- px: 'px-4',
66
- py: 'py-2'
63
+ }
67
64
  });
68
65
  }
69
66
  else {
@@ -71,9 +68,7 @@ export class NgtButtonComponent {
71
68
  color: {
72
69
  bg: 'bg-blue-500',
73
70
  text: 'text-white text-sm',
74
- },
75
- px: 'px-4',
76
- py: 'py-2'
71
+ }
77
72
  });
78
73
  }
79
74
  }
@@ -81,21 +76,35 @@ export class NgtButtonComponent {
81
76
  ngOnDestroy() {
82
77
  this.destroySubscriptions();
83
78
  }
79
+ bindSubscriptions() {
80
+ this.changeDetector.detectChanges();
81
+ if (this.ngtForm) {
82
+ this.loading = this.ngtForm.isLoading();
83
+ this.isDisabled = !this.isDisabled && this.ngtForm.isDisabled;
84
+ this.changeDetector.detectChanges();
85
+ this.subscriptions.push(this.ngtForm.onLoadingChange.subscribe((loading) => {
86
+ this.loading = loading;
87
+ }));
88
+ this.subscriptions.push(this.ngtForm.onIsDisabledChange.subscribe((isDisabled) => {
89
+ this.isDisabled = !this.isDisabled && isDisabled;
90
+ }));
91
+ }
92
+ }
84
93
  destroySubscriptions() {
85
94
  this.subscriptions.forEach(subscription => subscription.unsubscribe());
86
95
  this.subscriptions = [];
87
96
  }
88
97
  }
89
- NgtButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: NgtButtonComponent, deps: [{ token: i1.NgtFormComponent, optional: true, skipSelf: true }, { token: i0.Injector }, { token: i2.NgtStylizableDirective, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
90
- NgtButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: NgtButtonComponent, selector: "ngt-button", inputs: { link: "link", href: "href", type: "type", loading: "loading", isDisabled: "isDisabled", noSubmit: "noSubmit" }, usesOnChanges: true, ngImport: i0, template: "<ng-template #content>\n <ng-content></ng-content>\n</ng-template>\n\n<div class=\"h-full w-full\" (click)='onClick($event)'>\n <ng-container *ngIf='!link'>\n <button [ngClass]=\"{ 'disabled-button': isDisabled, 'loading-button': loading }\" [disabled]=\"isDisabled\"\n [type]=\"(loading || isDisabled || noSubmit) ? 'button' : 'submit'\"\n class=\"flex justify-center items-center h-full w-full focus:outline-none rounded cursor-pointer {{ ngtStyle.compile(['color.bg', 'color.text', 'color.border', 'px', 'py', 'border']) }}\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n\n <span *ngIf=\"loading\" class=\"ml-2\">\n <div class=\"div-loader h-5 w-5\"></div>\n </span>\n </button>\n </ng-container>\n\n <ng-container *ngIf='link'>\n <a [routerLink]='href ? href : null' [ngClass]=\"{ 'disabled-button': isDisabled, 'loading-button': loading }\"\n class=\"flex justify-center items-center h-full w-full focus:outline-none rounded cursor-pointer {{ ngtStyle.compile(['color.bg', 'color.text', 'color.border', 'px', 'py', 'border']) }}\">\n <span class=\"w-full\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </span>\n\n <span *ngIf=\"loading\" class=\"ml-1\">\n <div class=\"div-loader\"></div>\n </span>\n </a>\n </ng-container>\n</div>", styles: [".disabled-button{opacity:.5!important;cursor:not-allowed!important}.loading-button{opacity:.5!important;cursor:wait!important}.div-loader{border:3px solid #edf2f738;border-top-color:#edf2f7;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i4.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }] });
98
+ NgtButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: NgtButtonComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.Injector }, { token: i1.NgtFormComponent, optional: true, skipSelf: true }, { token: i2.NgtStylizableDirective, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
99
+ NgtButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: NgtButtonComponent, selector: "ngt-button", inputs: { link: "link", href: "href", type: "type", loading: "loading", isDisabled: "isDisabled", noSubmit: "noSubmit" }, usesOnChanges: true, ngImport: i0, template: "<ng-template #content>\n <ng-content></ng-content>\n</ng-template>\n\n<div class=\"h-full w-full\" (click)='onClick($event)'>\n <ng-container *ngIf='!link'>\n <button [ngClass]=\"{ 'disabled-button': isDisabled, 'loading-button': loading }\" [disabled]=\"isDisabled\"\n [type]=\"(loading || isDisabled || noSubmit) ? 'button' : 'submit'\"\n class=\"flex justify-center items-center w-full focus:outline-none rounded cursor-pointer {{ ngtStyle.compile(['color.bg', 'color.text', 'color.border', 'px', 'py', 'border']) }}\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n\n <span *ngIf=\"loading\" class=\"ml-2\">\n <div class=\"div-loader h-5 w-5\"></div>\n </span>\n </button>\n </ng-container>\n\n <ng-container *ngIf='link'>\n <a [routerLink]='href ? href : null' [ngClass]=\"{ 'disabled-button': isDisabled, 'loading-button': loading }\"\n class=\"flex justify-center items-center w-full focus:outline-none rounded cursor-pointer {{ ngtStyle.compile(['color.bg', 'color.text', 'color.border', 'px', 'py', 'border']) }}\">\n <span class=\"w-full\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </span>\n\n <span *ngIf=\"loading\" class=\"ml-1\">\n <div class=\"div-loader\"></div>\n </span>\n </a>\n </ng-container>\n</div>", styles: [".disabled-button{opacity:.5!important;cursor:not-allowed!important}.loading-button{opacity:.5!important;cursor:wait!important}.div-loader{border:3px solid #edf2f738;border-top-color:#edf2f7;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i4.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }] });
91
100
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: NgtButtonComponent, decorators: [{
92
101
  type: Component,
93
- args: [{ selector: 'ngt-button', template: "<ng-template #content>\n <ng-content></ng-content>\n</ng-template>\n\n<div class=\"h-full w-full\" (click)='onClick($event)'>\n <ng-container *ngIf='!link'>\n <button [ngClass]=\"{ 'disabled-button': isDisabled, 'loading-button': loading }\" [disabled]=\"isDisabled\"\n [type]=\"(loading || isDisabled || noSubmit) ? 'button' : 'submit'\"\n class=\"flex justify-center items-center h-full w-full focus:outline-none rounded cursor-pointer {{ ngtStyle.compile(['color.bg', 'color.text', 'color.border', 'px', 'py', 'border']) }}\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n\n <span *ngIf=\"loading\" class=\"ml-2\">\n <div class=\"div-loader h-5 w-5\"></div>\n </span>\n </button>\n </ng-container>\n\n <ng-container *ngIf='link'>\n <a [routerLink]='href ? href : null' [ngClass]=\"{ 'disabled-button': isDisabled, 'loading-button': loading }\"\n class=\"flex justify-center items-center h-full w-full focus:outline-none rounded cursor-pointer {{ ngtStyle.compile(['color.bg', 'color.text', 'color.border', 'px', 'py', 'border']) }}\">\n <span class=\"w-full\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </span>\n\n <span *ngIf=\"loading\" class=\"ml-1\">\n <div class=\"div-loader\"></div>\n </span>\n </a>\n </ng-container>\n</div>", styles: [".disabled-button{opacity:.5!important;cursor:not-allowed!important}.loading-button{opacity:.5!important;cursor:wait!important}.div-loader{border:3px solid #edf2f738;border-top-color:#edf2f7;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}\n"] }]
94
- }], ctorParameters: function () { return [{ type: i1.NgtFormComponent, decorators: [{
102
+ args: [{ selector: 'ngt-button', template: "<ng-template #content>\n <ng-content></ng-content>\n</ng-template>\n\n<div class=\"h-full w-full\" (click)='onClick($event)'>\n <ng-container *ngIf='!link'>\n <button [ngClass]=\"{ 'disabled-button': isDisabled, 'loading-button': loading }\" [disabled]=\"isDisabled\"\n [type]=\"(loading || isDisabled || noSubmit) ? 'button' : 'submit'\"\n class=\"flex justify-center items-center w-full focus:outline-none rounded cursor-pointer {{ ngtStyle.compile(['color.bg', 'color.text', 'color.border', 'px', 'py', 'border']) }}\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n\n <span *ngIf=\"loading\" class=\"ml-2\">\n <div class=\"div-loader h-5 w-5\"></div>\n </span>\n </button>\n </ng-container>\n\n <ng-container *ngIf='link'>\n <a [routerLink]='href ? href : null' [ngClass]=\"{ 'disabled-button': isDisabled, 'loading-button': loading }\"\n class=\"flex justify-center items-center w-full focus:outline-none rounded cursor-pointer {{ ngtStyle.compile(['color.bg', 'color.text', 'color.border', 'px', 'py', 'border']) }}\">\n <span class=\"w-full\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </span>\n\n <span *ngIf=\"loading\" class=\"ml-1\">\n <div class=\"div-loader\"></div>\n </span>\n </a>\n </ng-container>\n</div>", styles: [".disabled-button{opacity:.5!important;cursor:not-allowed!important}.loading-button{opacity:.5!important;cursor:wait!important}.div-loader{border:3px solid #edf2f738;border-top-color:#edf2f7;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}\n"] }]
103
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.Injector }, { type: i1.NgtFormComponent, decorators: [{
95
104
  type: Optional
96
105
  }, {
97
106
  type: SkipSelf
98
- }] }, { type: i0.Injector }, { type: i2.NgtStylizableDirective, decorators: [{
107
+ }] }, { type: i2.NgtStylizableDirective, decorators: [{
99
108
  type: Self
100
109
  }, {
101
110
  type: Optional
@@ -112,4 +121,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImpor
112
121
  }], noSubmit: [{
113
122
  type: Input
114
123
  }] } });
115
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngt-button.component.js","sourceRoot":"","sources":["../../../../../projects/ng-tailwind/src/components/ngt-button/ngt-button.component.ts","../../../../../projects/ng-tailwind/src/components/ngt-button/ngt-button.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAY,KAAK,EAAwB,QAAQ,EAAE,IAAI,EAAiB,QAAQ,EAAE,MAAM,eAAe,CAAC;AAI1H,OAAO,EAAE,oBAAoB,EAAE,MAAM,sDAAsD,CAAC;;;;;;AAQ5F,MAAM,OAAO,kBAAkB;IAY3B,YAEY,gBAAkC,EAClC,QAAkB,EACE,sBAA8C;QAFlE,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,aAAQ,GAAR,QAAQ,CAAU;QACE,2BAAsB,GAAtB,sBAAsB,CAAwB;QAf9D,SAAI,GAAY,KAAK,CAAC;QAEtB,SAAI,GAAW,SAAS,CAAC;QACzB,YAAO,GAAY,KAAK,CAAC;QACzB,eAAU,GAAY,KAAK,CAAC;QAC5B,aAAQ,GAAY,KAAK,CAAC;QAIlC,kBAAa,GAAwB,EAAE,CAAC;QAQ5C,IAAI,IAAI,CAAC,sBAAsB,EAAE;YAC7B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,sBAAsB,CAAC,uBAAuB,EAAE,CAAC;SACzE;aAAM;YACH,IAAI,CAAC,QAAQ,GAAG,IAAI,oBAAoB,EAAE,CAAC;SAC9C;QAED,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,IAAI,CAAC,aAAa,CAAC,IAAI,CACnB,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,OAAgB,EAAE,EAAE;gBACjE,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;YAC3B,CAAC,CAAC,CACL,CAAC;SACL;IACL,CAAC;IAEM,OAAO,CAAC,KAAY;QACvB,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,OAAO,EAAE;YACjC,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,KAAK,CAAC,eAAe,EAAE,CAAC;SAC3B;IACL,CAAC;IAEM,WAAW,CAAC,OAAsB;QACrC,IAAI,OAAO,CAAC,IAAI,EAAE;YACd,IAAI,OAAO,CAAC,IAAI,CAAC,YAAY,IAAI,SAAS,EAAE;gBACxC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,kBAAkB,EAAE;oBAClD,KAAK,EAAE;wBACH,EAAE,EAAE,cAAc;wBAClB,IAAI,EAAE,oBAAoB;qBAC7B;oBACD,EAAE,EAAE,MAAM;oBACV,EAAE,EAAE,MAAM;iBACb,CAAC,CAAC;aACN;iBAAM,IAAI,OAAO,CAAC,IAAI,CAAC,YAAY,IAAI,SAAS,EAAE;gBAC/C,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,kBAAkB,EAAE;oBAClD,KAAK,EAAE;wBACH,EAAE,EAAE,eAAe;wBACnB,IAAI,EAAE,oBAAoB;qBAC7B;oBACD,EAAE,EAAE,MAAM;oBACV,EAAE,EAAE,MAAM;iBACb,CAAC,CAAC;aACN;iBAAM,IAAI,OAAO,CAAC,IAAI,CAAC,YAAY,IAAI,QAAQ,EAAE;gBAC9C,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,iBAAiB,EAAE;oBACjD,KAAK,EAAE;wBACH,EAAE,EAAE,YAAY;wBAChB,IAAI,EAAE,oBAAoB;qBAC7B;oBACD,EAAE,EAAE,MAAM;oBACV,EAAE,EAAE,MAAM;iBACb,CAAC,CAAC;aACN;iBAAM;gBACH,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,eAAe,EAAE;oBAC/C,KAAK,EAAE;wBACH,EAAE,EAAE,aAAa;wBACjB,IAAI,EAAE,oBAAoB;qBAC7B;oBACD,EAAE,EAAE,MAAM;oBACV,EAAE,EAAE,MAAM;iBACb,CAAC,CAAC;aACN;SACJ;IACL,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAChC,CAAC;IAEO,oBAAoB;QACxB,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,YAAY,CAAC,EAAE,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC,CAAC;QACvE,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;IAC5B,CAAC;;+GAzFQ,kBAAkB;mGAAlB,kBAAkB,iMCZ/B,m8CA6BM;2FDjBO,kBAAkB;kBAL9B,SAAS;+BACI,YAAY;;0BAiBjB,QAAQ;;0BAAI,QAAQ;;0BAGpB,IAAI;;0BAAI,QAAQ;4CAfL,IAAI;sBAAnB,KAAK;gBACU,IAAI;sBAAnB,KAAK;gBACU,IAAI;sBAAnB,KAAK;gBACU,OAAO;sBAAtB,KAAK;gBACU,UAAU;sBAAzB,KAAK;gBACU,QAAQ;sBAAvB,KAAK","sourcesContent":["import { Component, Injector, Input, OnChanges, OnDestroy, Optional, Self, SimpleChanges, SkipSelf } from '@angular/core';\nimport { Subscription } from 'rxjs';\n\nimport { NgtStylizableDirective } from '../../directives/ngt-stylizable/ngt-stylizable.directive';\nimport { NgtStylizableService } from '../../services/ngt-stylizable/ngt-stylizable.service';\nimport { NgtFormComponent } from '../ngt-form/ngt-form.component';\n\n@Component({\n    selector: 'ngt-button',\n    templateUrl: './ngt-button.component.html',\n    styleUrls: ['./ngt-button.component.css'],\n})\nexport class NgtButtonComponent implements OnChanges, OnDestroy {\n    @Input() public link: boolean = false;\n    @Input() public href: string;\n    @Input() public type: string = 'success';\n    @Input() public loading: boolean = false;\n    @Input() public isDisabled: boolean = false;\n    @Input() public noSubmit: boolean = false;\n\n    public ngtStyle: NgtStylizableService;\n\n    private subscriptions: Array<Subscription> = [];\n\n    public constructor(\n        @Optional() @SkipSelf()\n        private ngtFormComponent: NgtFormComponent,\n        private injector: Injector,\n        @Self() @Optional() private ngtStylizableDirective: NgtStylizableDirective,\n    ) {\n        if (this.ngtStylizableDirective) {\n            this.ngtStyle = this.ngtStylizableDirective.getNgtStylizableService();\n        } else {\n            this.ngtStyle = new NgtStylizableService();\n        }\n\n        if (this.ngtFormComponent) {\n            this.subscriptions.push(\n                this.ngtFormComponent.onLoadingChange.subscribe((loading: boolean) => {\n                    this.loading = loading;\n                })\n            );\n        }\n    }\n\n    public onClick(event: Event) {\n        if (this.isDisabled || this.loading) {\n            event.preventDefault();\n            event.stopPropagation();\n        }\n    }\n\n    public ngOnChanges(changes: SimpleChanges) {\n        if (changes.type) {\n            if (changes.type.currentValue == 'success') {\n                this.ngtStyle.load(this.injector, 'NgtSuccessButton', {\n                    color: {\n                        bg: 'bg-green-500',\n                        text: 'text-white text-sm',\n                    },\n                    px: 'px-4',\n                    py: 'py-2'\n                });\n            } else if (changes.type.currentValue == 'warning') {\n                this.ngtStyle.load(this.injector, 'NgtWarningButton', {\n                    color: {\n                        bg: 'bg-orange-500',\n                        text: 'text-white text-sm',\n                    },\n                    px: 'px-4',\n                    py: 'py-2'\n                });\n            } else if (changes.type.currentValue == 'danger') {\n                this.ngtStyle.load(this.injector, 'NgtDangerButton', {\n                    color: {\n                        bg: 'bg-red-500',\n                        text: 'text-white text-sm',\n                    },\n                    px: 'px-4',\n                    py: 'py-2'\n                });\n            } else {\n                this.ngtStyle.load(this.injector, 'NgtInfoButton', {\n                    color: {\n                        bg: 'bg-blue-500',\n                        text: 'text-white text-sm',\n                    },\n                    px: 'px-4',\n                    py: 'py-2'\n                });\n            }\n        }\n    }\n\n    public ngOnDestroy() {\n        this.destroySubscriptions();\n    }\n\n    private destroySubscriptions() {\n        this.subscriptions.forEach(subscription => subscription.unsubscribe());\n        this.subscriptions = [];\n    }\n}\n","<ng-template #content>\n    <ng-content></ng-content>\n</ng-template>\n\n<div class=\"h-full w-full\" (click)='onClick($event)'>\n    <ng-container *ngIf='!link'>\n        <button [ngClass]=\"{ 'disabled-button': isDisabled, 'loading-button': loading }\" [disabled]=\"isDisabled\"\n            [type]=\"(loading || isDisabled || noSubmit) ? 'button' : 'submit'\"\n            class=\"flex justify-center items-center h-full w-full focus:outline-none rounded cursor-pointer {{ ngtStyle.compile(['color.bg', 'color.text', 'color.border', 'px', 'py', 'border']) }}\">\n            <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n\n            <span *ngIf=\"loading\" class=\"ml-2\">\n                <div class=\"div-loader h-5 w-5\"></div>\n            </span>\n        </button>\n    </ng-container>\n\n    <ng-container *ngIf='link'>\n        <a [routerLink]='href ? href : null' [ngClass]=\"{ 'disabled-button': isDisabled, 'loading-button': loading }\"\n            class=\"flex justify-center items-center h-full w-full focus:outline-none rounded cursor-pointer {{ ngtStyle.compile(['color.bg', 'color.text', 'color.border', 'px', 'py', 'border']) }}\">\n            <span class=\"w-full\">\n                <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n            </span>\n\n            <span *ngIf=\"loading\" class=\"ml-1\">\n                <div class=\"div-loader\"></div>\n            </span>\n        </a>\n    </ng-container>\n</div>"]}
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngt-button.component.js","sourceRoot":"","sources":["../../../../../projects/ng-tailwind/src/components/ngt-button/ngt-button.component.ts","../../../../../projects/ng-tailwind/src/components/ngt-button/ngt-button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    Injector,\n    Input,\n    OnChanges,\n    OnDestroy,\n    Optional,\n    Self,\n    SimpleChanges,\n    SkipSelf,\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\n\nimport { NgtStylizableDirective } from '../../directives/ngt-stylizable/ngt-stylizable.directive';\nimport { NgtStylizableService } from '../../services/ngt-stylizable/ngt-stylizable.service';\nimport { NgtFormComponent } from '../ngt-form/ngt-form.component';\n\n@Component({\n    selector: 'ngt-button',\n    templateUrl: './ngt-button.component.html',\n    styleUrls: ['./ngt-button.component.css'],\n})\nexport class NgtButtonComponent implements AfterViewInit, OnChanges, OnDestroy {\n    @Input() public link: boolean = false;\n    @Input() public href: string;\n    @Input() public type: string = 'success';\n    @Input() public loading: boolean = false;\n    @Input() public isDisabled: boolean = false;\n    @Input() public noSubmit: boolean = false;\n\n    public ngtStyle: NgtStylizableService;\n\n    private subscriptions: Array<Subscription> = [];\n\n    public constructor(\n        private changeDetector: ChangeDetectorRef,\n        private injector: Injector,\n        @Optional() @SkipSelf()\n        private ngtForm: NgtFormComponent,\n        @Self() @Optional()\n        private ngtStylizableDirective: NgtStylizableDirective,\n    ) {\n        if (this.ngtStylizableDirective) {\n            this.ngtStyle = this.ngtStylizableDirective.getNgtStylizableService();\n        } else {\n            this.ngtStyle = new NgtStylizableService();\n        }\n\n        this.ngtStyle.load(this.injector, 'NgtButton', {\n            px: 'px-4',\n            py: 'py-2'\n        });\n    }\n\n    public onClick(event: Event) {\n        if (this.isDisabled || this.loading) {\n            event.preventDefault();\n            event.stopPropagation();\n        }\n    }\n\n    public ngAfterViewInit(): void {\n        this.bindSubscriptions();\n    }\n\n    public ngOnChanges(changes: SimpleChanges) {\n        if (changes.type) {\n            if (changes.type.currentValue == 'success') {\n                this.ngtStyle.load(this.injector, 'NgtSuccessButton', {\n                    color: {\n                        bg: 'bg-green-500',\n                        text: 'text-white text-sm',\n                    }\n                });\n            } else if (changes.type.currentValue == 'warning') {\n                this.ngtStyle.load(this.injector, 'NgtWarningButton', {\n                    color: {\n                        bg: 'bg-orange-500',\n                        text: 'text-white text-sm',\n                    }\n                });\n            } else if (changes.type.currentValue == 'danger') {\n                this.ngtStyle.load(this.injector, 'NgtDangerButton', {\n                    color: {\n                        bg: 'bg-red-500',\n                        text: 'text-white text-sm',\n                    }\n                });\n            } else {\n                this.ngtStyle.load(this.injector, 'NgtInfoButton', {\n                    color: {\n                        bg: 'bg-blue-500',\n                        text: 'text-white text-sm',\n                    }\n                });\n            }\n        }\n    }\n\n    public ngOnDestroy() {\n        this.destroySubscriptions();\n    }\n\n    private bindSubscriptions(): void {\n        this.changeDetector.detectChanges();\n\n        if (this.ngtForm) {\n            this.loading = this.ngtForm.isLoading();\n            this.isDisabled = !this.isDisabled && this.ngtForm.isDisabled;\n\n            this.changeDetector.detectChanges();\n\n            this.subscriptions.push(\n                this.ngtForm.onLoadingChange.subscribe((loading: boolean) => {\n                    this.loading = loading;\n                })\n            );\n\n            this.subscriptions.push(\n                this.ngtForm.onIsDisabledChange.subscribe((isDisabled: boolean) => {\n                    this.isDisabled = !this.isDisabled && isDisabled;\n                })\n            );\n        }\n    }\n\n    private destroySubscriptions(): void {\n        this.subscriptions.forEach(subscription => subscription.unsubscribe());\n        this.subscriptions = [];\n    }\n}\n","<ng-template #content>\n    <ng-content></ng-content>\n</ng-template>\n\n<div class=\"h-full w-full\" (click)='onClick($event)'>\n    <ng-container *ngIf='!link'>\n        <button [ngClass]=\"{ 'disabled-button': isDisabled, 'loading-button': loading }\" [disabled]=\"isDisabled\"\n            [type]=\"(loading || isDisabled || noSubmit) ? 'button' : 'submit'\"\n            class=\"flex justify-center items-center w-full focus:outline-none rounded cursor-pointer {{ ngtStyle.compile(['color.bg', 'color.text', 'color.border', 'px', 'py', 'border']) }}\">\n            <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n\n            <span *ngIf=\"loading\" class=\"ml-2\">\n                <div class=\"div-loader h-5 w-5\"></div>\n            </span>\n        </button>\n    </ng-container>\n\n    <ng-container *ngIf='link'>\n        <a [routerLink]='href ? href : null' [ngClass]=\"{ 'disabled-button': isDisabled, 'loading-button': loading }\"\n            class=\"flex justify-center items-center w-full focus:outline-none rounded cursor-pointer {{ ngtStyle.compile(['color.bg', 'color.text', 'color.border', 'px', 'py', 'border']) }}\">\n            <span class=\"w-full\">\n                <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n            </span>\n\n            <span *ngIf=\"loading\" class=\"ml-1\">\n                <div class=\"div-loader\"></div>\n            </span>\n        </a>\n    </ng-container>\n</div>"]}
@@ -8,29 +8,27 @@ import * as i0 from "@angular/core";
8
8
  import * as i1 from "@angular/forms";
9
9
  import * as i2 from "../../directives/ngt-stylizable/ngt-stylizable.directive";
10
10
  import * as i3 from "../ngt-form/ngt-form.component";
11
- import * as i4 from "@angular/common";
12
- import * as i5 from "../ngt-shining/ngt-shining.component";
13
- import * as i6 from "../ngt-helper/ngt-helper.component";
11
+ import * as i4 from "../ngt-section/ngt-section.component";
12
+ import * as i5 from "@angular/common";
13
+ import * as i6 from "../ngt-shining/ngt-shining.component";
14
+ import * as i7 from "../ngt-helper/ngt-helper.component";
14
15
  export class NgtCheckboxComponent extends NgtBaseNgModel {
15
- constructor(injector, formContainer, renderer, ngtStylizableDirective, ngtFormComponent) {
16
+ constructor(changeDetector, injector, formContainer, renderer, ngtStylizableDirective, ngtForm, ngtSection) {
16
17
  super();
18
+ this.changeDetector = changeDetector;
17
19
  this.injector = injector;
18
20
  this.formContainer = formContainer;
19
21
  this.renderer = renderer;
20
22
  this.ngtStylizableDirective = ngtStylizableDirective;
21
- this.ngtFormComponent = ngtFormComponent;
23
+ this.ngtForm = ngtForm;
24
+ this.ngtSection = ngtSection;
22
25
  this.shining = false;
23
26
  this.isDisabled = false;
24
27
  this.isClickDisabled = false;
25
28
  this.mode = NgtCheckboxMode.DEFAULT;
26
29
  this.helpTextColor = 'text-green-500';
30
+ this.helperAutoXReverse = true;
27
31
  this.subscriptions = [];
28
- if (this.ngtFormComponent) {
29
- this.shining = this.ngtFormComponent.isShining();
30
- this.subscriptions.push(this.ngtFormComponent.onShiningChange.subscribe((shining) => {
31
- this.shining = shining;
32
- }));
33
- }
34
32
  if (this.ngtStylizableDirective) {
35
33
  this.ngtStyle = this.ngtStylizableDirective.getNgtStylizableService();
36
34
  }
@@ -53,6 +51,15 @@ export class NgtCheckboxComponent extends NgtBaseNgModel {
53
51
  this.renderer.listen(this.element.nativeElement, 'change', (value) => {
54
52
  this.onNativeChange(this.element.nativeElement.checked);
55
53
  });
54
+ this.bindSubscriptions();
55
+ }
56
+ ngOnChanges(changes) {
57
+ if (changes.mode) {
58
+ this.mode = getEnumFromString(changes.mode.currentValue, NgtCheckboxMode);
59
+ }
60
+ if (changes.isDisabled && !changes.isDisabled.currentValue) {
61
+ this.isDisabled = this.ngtForm?.isDisabled || this.ngtSection?.isDisabled;
62
+ }
56
63
  }
57
64
  ngOnDestroy() {
58
65
  this.destroySubscriptions();
@@ -82,20 +89,36 @@ export class NgtCheckboxComponent extends NgtBaseNgModel {
82
89
  isRadioMode() {
83
90
  return this.mode === NgtCheckboxMode.RADIO;
84
91
  }
85
- ngOnChanges(changes) {
86
- if (changes.mode) {
87
- this.mode = getEnumFromString(changes.mode.currentValue, NgtCheckboxMode);
92
+ bindSubscriptions() {
93
+ this.changeDetector.detectChanges();
94
+ if (!this.isDisabled) {
95
+ this.isDisabled = this.ngtForm?.isDisabled || this.ngtSection?.isDisabled;
88
96
  }
97
+ if (this.ngtForm) {
98
+ this.subscriptions.push(this.ngtForm.onIsDisabledChange.subscribe((isDisabled) => {
99
+ if (!this.isDisabled) {
100
+ this.isDisabled = isDisabled || this.ngtSection?.isDisabled;
101
+ }
102
+ }));
103
+ }
104
+ if (this.ngtSection) {
105
+ this.subscriptions.push(this.ngtSection.onIsDisabledChange.subscribe((isDisabled) => {
106
+ if (!this.isDisabled) {
107
+ this.isDisabled = isDisabled || this.ngtForm?.isDisabled;
108
+ }
109
+ }));
110
+ }
111
+ this.changeDetector.detectChanges();
89
112
  }
90
113
  destroySubscriptions() {
91
114
  this.subscriptions.forEach(subscription => subscription.unsubscribe());
92
115
  this.subscriptions = [];
93
116
  }
94
117
  }
95
- NgtCheckboxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: NgtCheckboxComponent, deps: [{ token: i0.Injector }, { token: i1.ControlContainer, host: true, optional: true }, { token: i0.Renderer2 }, { token: i2.NgtStylizableDirective, optional: true, self: true }, { token: i3.NgtFormComponent, optional: true, skipSelf: true }], target: i0.ɵɵFactoryTarget.Component });
118
+ NgtCheckboxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: NgtCheckboxComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.Injector }, { token: i1.ControlContainer, host: true, optional: true }, { token: i0.Renderer2 }, { token: i2.NgtStylizableDirective, optional: true, self: true }, { token: i3.NgtFormComponent, optional: true, skipSelf: true }, { token: i4.NgtSectionComponent, optional: true, skipSelf: true }], target: i0.ɵɵFactoryTarget.Component });
96
119
  NgtCheckboxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: NgtCheckboxComponent, selector: "ngt-checkbox", inputs: { label: "label", shining: "shining", isDisabled: "isDisabled", isClickDisabled: "isClickDisabled", name: "name", mode: "mode", helpTitle: "helpTitle", helpTextColor: "helpTextColor", helpText: "helpText", helperAutoXReverse: "helperAutoXReverse" }, providers: [
97
120
  NgtMakeProvider(NgtCheckboxComponent)
98
- ], viewQueries: [{ propertyName: "element", first: true, predicate: ["element"], descendants: true, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<label class=\"flex items-center {{ isDisabled ? 'cursor-not-allowed' : 'cursor-pointer' }}\"\n [class.flex-col]='isToggleMode()' style=\"max-width: max-content;\">\n <input type=\"checkbox\" [name]='name' class=\"hidden\" ([ngModel])='value' [disabled]=\"isDisabled || isClickDisabled\"\n #element>\n\n <span *ngIf=\"isToggleMode() && label\" class=\"flex\">\n <span class=\"{{ ngtStyle.compile(['text', 'fontCase']) }} mb-2\">{{ label }}</span>\n\n <ngt-helper *ngIf=\"helpText\" [helpTitle]=\"helpTitle\" [iconColor]=\"helpTextColor\"\n [autoXReverse]=\"helperAutoXReverse\" class=\"ml-1\">\n {{ helpText }}\n </ngt-helper>\n </span>\n\n <ng-container *ngIf=\"isDefaultMode()\">\n <div style=\"transition: background-color .2s ease-out\"\n class=\"{{ value ? ngtStyle.compile(['color.bg']) : 'bg-white' }} {{ ngtStyle.compile(['h', 'w']) }}\n shadow rounded border border-gray-400 {{ isDisabled ? 'opacity-50' : '' }} {{ !shining ? 'flex justify-center' : 'hidden' }}\">\n <svg class=\"fill-current self-center text-white pointer-events-none\" xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 20 20\">\n <path d=\"M0 11l2-2 5 5L18 3l2 2L7 18z\" />\n </svg>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"isRadioMode()\">\n <div style=\"transition: background-color .2s ease-out\"\n class=\"{{ value ? ngtStyle.compile(['color.border', 'color.text']) : 'border-gray-500' }} {{ isDisabled ? 'opacity-50' : '' }}\n shadow w-6 h-6 rounded-full border-2 border-gray-400 {{ !shining ? 'flex justify-center' : 'hidden' }}\">\n <svg *ngIf=\"value\" class=\"fill-current self-center h-3\" xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 29.107 29.107\">\n <path\n d=\"M14.554 0C6.561 0 0 6.562 0 14.552c0 7.996 6.561 14.555 14.554 14.555 7.996 0 14.553-6.559 14.553-14.555C29.106 6.562 22.55 0 14.554 0z\" />\n </svg>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"isToggleMode() || isSideToggleMode()\">\n <div class=\"shadow w-16 h-8 rounded-full border border-gray-400 {{ shining ? 'hidden' : 'flex' }}\"\n [class.justify-end]=\"value\" [class.opacity-50]=\"isDisabled\" style=\"padding: 1px;\">\n <div *ngIf=\"value\"\n class=\"flex text-xs text-white {{ ngtStyle.compile(['color.bg']) }} pointer-events-none rounded-full px-2 py-3\"\n @slideLeftToRight>\n <svg class=\"fill-current self-center\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\">\n <path d=\"M0 11l2-2 5 5L18 3l2 2L7 18z\" />\n </svg>\n </div>\n\n <div *ngIf=\"!value\" class=\"flex text-xl text-white bg-gray-300 pointer-events-none rounded-full px-1 py-3\"\n @slideRightToLeft>\n <svg class=\"fill-current self-center\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\">\n <path class=\"heroicon-ui\"\n d=\"M16.24 14.83a1 1 0 0 1-1.41 1.41L12 13.41l-2.83 2.83a1 1 0 0 1-1.41-1.41L10.59 12 7.76 9.17a1 1 0 0 1 1.41-1.41L12 10.59l2.83-2.83a1 1 0 0 1 1.41 1.41L13.41 12l2.83 2.83z\" />\n </svg>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf='label && !shining && !isToggleMode()'>\n <span class=\"{{ ngtStyle.compile(['text', 'fontCase']) }} ml-2\">{{ label }}</span>\n\n <ngt-helper *ngIf=\"helpText\" [helpTitle]=\"helpTitle\" [iconColor]=\"helpTextColor\"\n [autoXReverse]=\"helperAutoXReverse\" class=\"ml-1\">\n {{ helpText }}\n </ngt-helper>\n </ng-container>\n</label>\n\n<ng-container *ngIf='shining'>\n <div class=\"flex\">\n <ngt-shining class=\"w-16 h-12\"></ngt-shining>\n </div>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.NgtShiningComponent, selector: "ngt-shining", inputs: ["shiningWidth"] }, { kind: "component", type: i6.NgtHelperComponent, selector: "ngt-helper", inputs: ["helpTextColor", "helpText", "helpTitle", "icon", "iconSize", "iconColor", "iconTitle", "tooltipSize", "autoXReverse", "helperReverseYPosition"] }], viewProviders: [
121
+ ], viewQueries: [{ propertyName: "element", first: true, predicate: ["element"], descendants: true, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<label class=\"flex items-center {{ isDisabled ? 'cursor-not-allowed opacity-50' : 'cursor-pointer' }}\"\n [class.flex-col]='isToggleMode()' style=\"max-width: max-content;\">\n <input type=\"checkbox\" [name]='name' class=\"hidden\" ([ngModel])='value' [disabled]=\"isDisabled || isClickDisabled\"\n #element>\n\n <span *ngIf=\"isToggleMode() && label\" class=\"flex\">\n <span class=\"{{ ngtStyle.compile(['text', 'fontCase']) }} mb-2\">{{ label }}</span>\n\n <ngt-helper *ngIf=\"helpText\" [helpTitle]=\"helpTitle\" [iconColor]=\"helpTextColor\"\n [autoXReverse]=\"helperAutoXReverse\" class=\"ml-1\">\n {{ helpText }}\n </ngt-helper>\n </span>\n\n <ng-container *ngIf=\"isDefaultMode()\">\n <div style=\"transition: background-color .2s ease-out\" class=\"{{ value ? ngtStyle.compile(['color.bg']) : 'bg-white' }} {{ ngtStyle.compile(['h', 'w']) }}\n shadow rounded border border-gray-400 {{ !shining ? 'flex justify-center' : 'hidden' }}\">\n <svg class=\"fill-current self-center text-white pointer-events-none\" xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 20 20\">\n <path d=\"M0 11l2-2 5 5L18 3l2 2L7 18z\" />\n </svg>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"isRadioMode()\">\n <div style=\"transition: background-color .2s ease-out\"\n class=\"{{ value ? ngtStyle.compile(['color.border', 'color.text']) : 'border-gray-500' }}\n shadow w-6 h-6 rounded-full border-2 border-gray-400 {{ !shining ? 'flex justify-center' : 'hidden' }}\">\n <svg *ngIf=\"value\" class=\"fill-current self-center h-3\" xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 29.107 29.107\">\n <path\n d=\"M14.554 0C6.561 0 0 6.562 0 14.552c0 7.996 6.561 14.555 14.554 14.555 7.996 0 14.553-6.559 14.553-14.555C29.106 6.562 22.55 0 14.554 0z\" />\n </svg>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"isToggleMode() || isSideToggleMode()\">\n <div class=\"shadow w-16 h-8 rounded-full border border-gray-400 {{ shining ? 'hidden' : 'flex' }}\"\n [class.justify-end]=\"value\" style=\"padding: 1px;\">\n <div *ngIf=\"value\"\n class=\"flex text-xs text-white {{ ngtStyle.compile(['color.bg']) }} pointer-events-none rounded-full px-2 py-3\"\n @slideLeftToRight>\n <svg class=\"fill-current self-center\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\">\n <path d=\"M0 11l2-2 5 5L18 3l2 2L7 18z\" />\n </svg>\n </div>\n\n <div *ngIf=\"!value\" class=\"flex text-xl text-white bg-gray-300 pointer-events-none rounded-full px-1 py-3\"\n @slideRightToLeft>\n <svg class=\"fill-current self-center\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\">\n <path class=\"heroicon-ui\"\n d=\"M16.24 14.83a1 1 0 0 1-1.41 1.41L12 13.41l-2.83 2.83a1 1 0 0 1-1.41-1.41L10.59 12 7.76 9.17a1 1 0 0 1 1.41-1.41L12 10.59l2.83-2.83a1 1 0 0 1 1.41 1.41L13.41 12l2.83 2.83z\" />\n </svg>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf='label && !shining && !isToggleMode()'>\n <span class=\"{{ ngtStyle.compile(['text', 'fontCase']) }} ml-2\">{{ label }}</span>\n\n <ngt-helper *ngIf=\"helpText\" [helpTitle]=\"helpTitle\" [iconColor]=\"helpTextColor\"\n [autoXReverse]=\"helperAutoXReverse\" class=\"ml-1\">\n {{ helpText }}\n </ngt-helper>\n </ng-container>\n</label>\n\n<ng-container *ngIf='shining'>\n <div class=\"flex\">\n <ngt-shining class=\"w-16 h-12\"></ngt-shining>\n </div>\n</ng-container>", dependencies: [{ kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.NgtShiningComponent, selector: "ngt-shining", inputs: ["shiningWidth"] }, { kind: "component", type: i7.NgtHelperComponent, selector: "ngt-helper", inputs: ["helpTextColor", "helpText", "helpTitle", "icon", "iconSize", "iconColor", "iconTitle", "tooltipSize", "autoXReverse", "helperReverseYPosition"] }], viewProviders: [
99
122
  { provide: ControlContainer, useExisting: NgForm }
100
123
  ], animations: [
101
124
  trigger('slideLeftToRight', [
@@ -130,8 +153,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImpor
130
153
  animate(200)
131
154
  ])
132
155
  ])
133
- ], template: "<label class=\"flex items-center {{ isDisabled ? 'cursor-not-allowed' : 'cursor-pointer' }}\"\n [class.flex-col]='isToggleMode()' style=\"max-width: max-content;\">\n <input type=\"checkbox\" [name]='name' class=\"hidden\" ([ngModel])='value' [disabled]=\"isDisabled || isClickDisabled\"\n #element>\n\n <span *ngIf=\"isToggleMode() && label\" class=\"flex\">\n <span class=\"{{ ngtStyle.compile(['text', 'fontCase']) }} mb-2\">{{ label }}</span>\n\n <ngt-helper *ngIf=\"helpText\" [helpTitle]=\"helpTitle\" [iconColor]=\"helpTextColor\"\n [autoXReverse]=\"helperAutoXReverse\" class=\"ml-1\">\n {{ helpText }}\n </ngt-helper>\n </span>\n\n <ng-container *ngIf=\"isDefaultMode()\">\n <div style=\"transition: background-color .2s ease-out\"\n class=\"{{ value ? ngtStyle.compile(['color.bg']) : 'bg-white' }} {{ ngtStyle.compile(['h', 'w']) }}\n shadow rounded border border-gray-400 {{ isDisabled ? 'opacity-50' : '' }} {{ !shining ? 'flex justify-center' : 'hidden' }}\">\n <svg class=\"fill-current self-center text-white pointer-events-none\" xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 20 20\">\n <path d=\"M0 11l2-2 5 5L18 3l2 2L7 18z\" />\n </svg>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"isRadioMode()\">\n <div style=\"transition: background-color .2s ease-out\"\n class=\"{{ value ? ngtStyle.compile(['color.border', 'color.text']) : 'border-gray-500' }} {{ isDisabled ? 'opacity-50' : '' }}\n shadow w-6 h-6 rounded-full border-2 border-gray-400 {{ !shining ? 'flex justify-center' : 'hidden' }}\">\n <svg *ngIf=\"value\" class=\"fill-current self-center h-3\" xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 29.107 29.107\">\n <path\n d=\"M14.554 0C6.561 0 0 6.562 0 14.552c0 7.996 6.561 14.555 14.554 14.555 7.996 0 14.553-6.559 14.553-14.555C29.106 6.562 22.55 0 14.554 0z\" />\n </svg>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"isToggleMode() || isSideToggleMode()\">\n <div class=\"shadow w-16 h-8 rounded-full border border-gray-400 {{ shining ? 'hidden' : 'flex' }}\"\n [class.justify-end]=\"value\" [class.opacity-50]=\"isDisabled\" style=\"padding: 1px;\">\n <div *ngIf=\"value\"\n class=\"flex text-xs text-white {{ ngtStyle.compile(['color.bg']) }} pointer-events-none rounded-full px-2 py-3\"\n @slideLeftToRight>\n <svg class=\"fill-current self-center\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\">\n <path d=\"M0 11l2-2 5 5L18 3l2 2L7 18z\" />\n </svg>\n </div>\n\n <div *ngIf=\"!value\" class=\"flex text-xl text-white bg-gray-300 pointer-events-none rounded-full px-1 py-3\"\n @slideRightToLeft>\n <svg class=\"fill-current self-center\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\">\n <path class=\"heroicon-ui\"\n d=\"M16.24 14.83a1 1 0 0 1-1.41 1.41L12 13.41l-2.83 2.83a1 1 0 0 1-1.41-1.41L10.59 12 7.76 9.17a1 1 0 0 1 1.41-1.41L12 10.59l2.83-2.83a1 1 0 0 1 1.41 1.41L13.41 12l2.83 2.83z\" />\n </svg>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf='label && !shining && !isToggleMode()'>\n <span class=\"{{ ngtStyle.compile(['text', 'fontCase']) }} ml-2\">{{ label }}</span>\n\n <ngt-helper *ngIf=\"helpText\" [helpTitle]=\"helpTitle\" [iconColor]=\"helpTextColor\"\n [autoXReverse]=\"helperAutoXReverse\" class=\"ml-1\">\n {{ helpText }}\n </ngt-helper>\n </ng-container>\n</label>\n\n<ng-container *ngIf='shining'>\n <div class=\"flex\">\n <ngt-shining class=\"w-16 h-12\"></ngt-shining>\n </div>\n</ng-container>\n" }]
134
- }], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.ControlContainer, decorators: [{
156
+ ], template: "<label class=\"flex items-center {{ isDisabled ? 'cursor-not-allowed opacity-50' : 'cursor-pointer' }}\"\n [class.flex-col]='isToggleMode()' style=\"max-width: max-content;\">\n <input type=\"checkbox\" [name]='name' class=\"hidden\" ([ngModel])='value' [disabled]=\"isDisabled || isClickDisabled\"\n #element>\n\n <span *ngIf=\"isToggleMode() && label\" class=\"flex\">\n <span class=\"{{ ngtStyle.compile(['text', 'fontCase']) }} mb-2\">{{ label }}</span>\n\n <ngt-helper *ngIf=\"helpText\" [helpTitle]=\"helpTitle\" [iconColor]=\"helpTextColor\"\n [autoXReverse]=\"helperAutoXReverse\" class=\"ml-1\">\n {{ helpText }}\n </ngt-helper>\n </span>\n\n <ng-container *ngIf=\"isDefaultMode()\">\n <div style=\"transition: background-color .2s ease-out\" class=\"{{ value ? ngtStyle.compile(['color.bg']) : 'bg-white' }} {{ ngtStyle.compile(['h', 'w']) }}\n shadow rounded border border-gray-400 {{ !shining ? 'flex justify-center' : 'hidden' }}\">\n <svg class=\"fill-current self-center text-white pointer-events-none\" xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 20 20\">\n <path d=\"M0 11l2-2 5 5L18 3l2 2L7 18z\" />\n </svg>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"isRadioMode()\">\n <div style=\"transition: background-color .2s ease-out\"\n class=\"{{ value ? ngtStyle.compile(['color.border', 'color.text']) : 'border-gray-500' }}\n shadow w-6 h-6 rounded-full border-2 border-gray-400 {{ !shining ? 'flex justify-center' : 'hidden' }}\">\n <svg *ngIf=\"value\" class=\"fill-current self-center h-3\" xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 29.107 29.107\">\n <path\n d=\"M14.554 0C6.561 0 0 6.562 0 14.552c0 7.996 6.561 14.555 14.554 14.555 7.996 0 14.553-6.559 14.553-14.555C29.106 6.562 22.55 0 14.554 0z\" />\n </svg>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"isToggleMode() || isSideToggleMode()\">\n <div class=\"shadow w-16 h-8 rounded-full border border-gray-400 {{ shining ? 'hidden' : 'flex' }}\"\n [class.justify-end]=\"value\" style=\"padding: 1px;\">\n <div *ngIf=\"value\"\n class=\"flex text-xs text-white {{ ngtStyle.compile(['color.bg']) }} pointer-events-none rounded-full px-2 py-3\"\n @slideLeftToRight>\n <svg class=\"fill-current self-center\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\">\n <path d=\"M0 11l2-2 5 5L18 3l2 2L7 18z\" />\n </svg>\n </div>\n\n <div *ngIf=\"!value\" class=\"flex text-xl text-white bg-gray-300 pointer-events-none rounded-full px-1 py-3\"\n @slideRightToLeft>\n <svg class=\"fill-current self-center\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\">\n <path class=\"heroicon-ui\"\n d=\"M16.24 14.83a1 1 0 0 1-1.41 1.41L12 13.41l-2.83 2.83a1 1 0 0 1-1.41-1.41L10.59 12 7.76 9.17a1 1 0 0 1 1.41-1.41L12 10.59l2.83-2.83a1 1 0 0 1 1.41 1.41L13.41 12l2.83 2.83z\" />\n </svg>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf='label && !shining && !isToggleMode()'>\n <span class=\"{{ ngtStyle.compile(['text', 'fontCase']) }} ml-2\">{{ label }}</span>\n\n <ngt-helper *ngIf=\"helpText\" [helpTitle]=\"helpTitle\" [iconColor]=\"helpTextColor\"\n [autoXReverse]=\"helperAutoXReverse\" class=\"ml-1\">\n {{ helpText }}\n </ngt-helper>\n </ng-container>\n</label>\n\n<ng-container *ngIf='shining'>\n <div class=\"flex\">\n <ngt-shining class=\"w-16 h-12\"></ngt-shining>\n </div>\n</ng-container>" }]
157
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.Injector }, { type: i1.ControlContainer, decorators: [{
135
158
  type: Optional
136
159
  }, {
137
160
  type: Host
@@ -143,6 +166,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImpor
143
166
  type: Optional
144
167
  }, {
145
168
  type: SkipSelf
169
+ }] }, { type: i4.NgtSectionComponent, decorators: [{
170
+ type: Optional
171
+ }, {
172
+ type: SkipSelf
146
173
  }] }]; }, propDecorators: { element: [{
147
174
  type: ViewChild,
148
175
  args: ['element', { static: true }]
@@ -174,4 +201,4 @@ export var NgtCheckboxMode;
174
201
  NgtCheckboxMode["SIDE_TOGGLE"] = "SIDE_TOGGLE";
175
202
  NgtCheckboxMode["RADIO"] = "RADIO";
176
203
  })(NgtCheckboxMode || (NgtCheckboxMode = {}));
177
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngt-checkbox.component.js","sourceRoot":"","sources":["../../../../../projects/ng-tailwind/src/components/ngt-checkbox/ngt-checkbox.component.ts","../../../../../projects/ng-tailwind/src/components/ngt-checkbox/ngt-checkbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, state, style, transition, trigger } from '@angular/animations';\nimport {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    Host,\n    Injector,\n    Input,\n    OnDestroy,\n    Optional,\n    Renderer2,\n    Self,\n    SimpleChanges,\n    SkipSelf,\n    ViewChild,\n} from '@angular/core';\nimport { ControlContainer, NgForm } from '@angular/forms';\nimport { Subscription } from 'rxjs';\n\nimport { NgtBaseNgModel, NgtMakeProvider } from '../../base/ngt-base-ng-model';\nimport { NgtStylizableDirective } from '../../directives/ngt-stylizable/ngt-stylizable.directive';\nimport { getEnumFromString } from '../../helpers/enum/enum';\nimport { NgtStylizableService } from '../../services/ngt-stylizable/ngt-stylizable.service';\nimport { NgtFormComponent } from '../ngt-form/ngt-form.component';\n\n@Component({\n    selector: 'ngt-checkbox',\n    templateUrl: './ngt-checkbox.component.html',\n    providers: [\n        NgtMakeProvider(NgtCheckboxComponent)\n    ],\n    viewProviders: [\n        { provide: ControlContainer, useExisting: NgForm }\n    ],\n    animations: [\n        trigger('slideLeftToRight', [\n            state('void', style({ transform: 'translateX(-4px) rotate(45deg)', opacity: 0 })),\n            transition(':enter', [\n                animate(200)\n            ])\n        ]),\n\n        trigger('slideRightToLeft', [\n            state('void', style({ transform: 'translateX(4px) rotate(45deg)', opacity: 0 })),\n            transition(':enter', [\n                animate(200)\n            ])\n        ])\n    ]\n})\nexport class NgtCheckboxComponent extends NgtBaseNgModel implements AfterViewInit, OnDestroy {\n    @ViewChild('element', { static: true }) public element: ElementRef;\n\n    @Input() public label: string;\n    @Input() public shining: boolean = false;\n    @Input() public isDisabled: boolean = false;\n    @Input() public isClickDisabled: boolean = false;\n    @Input() public name: string;\n    @Input() public mode: NgtCheckboxMode = NgtCheckboxMode.DEFAULT;\n    @Input() public helpTitle: string;\n    @Input() public helpTextColor: string = 'text-green-500';\n    @Input() public helpText: string;\n    @Input() public helperAutoXReverse: boolean;\n\n    public ngtStyle: NgtStylizableService;\n\n    private subscriptions: Array<Subscription> = [];\n\n    public constructor(\n        private injector: Injector,\n        @Optional() @Host()\n        public formContainer: ControlContainer,\n        private renderer: Renderer2,\n        @Self() @Optional()\n        private ngtStylizableDirective: NgtStylizableDirective,\n        @Optional() @SkipSelf()\n        private ngtFormComponent: NgtFormComponent,\n    ) {\n        super();\n\n        if (this.ngtFormComponent) {\n            this.shining = this.ngtFormComponent.isShining();\n\n            this.subscriptions.push(\n                this.ngtFormComponent.onShiningChange.subscribe((shining: boolean) => {\n                    this.shining = shining;\n                })\n            );\n        }\n\n        if (this.ngtStylizableDirective) {\n            this.ngtStyle = this.ngtStylizableDirective.getNgtStylizableService();\n        } else {\n            this.ngtStyle = new NgtStylizableService();\n        }\n\n        this.ngtStyle.load(this.injector, 'NgtCheckbox', {\n            h: 'h-6',\n            w: 'w-6',\n            text: 'text-sm',\n            fontCase: '',\n            color: {\n                bg: 'bg-gray-500',\n                text: 'text-gray-500',\n                border: 'border-gray-500',\n            }\n        });\n    }\n\n    public ngAfterViewInit() {\n        this.renderer.listen(this.element.nativeElement, 'change', (value) => {\n            this.onNativeChange(this.element.nativeElement.checked);\n        });\n    }\n\n    public ngOnDestroy() {\n        this.destroySubscriptions();\n    }\n\n    public change(value) {\n        if (this.hasChangesBetweenModels()) {\n            this.element.nativeElement.checked = value;\n        }\n    }\n\n    public onNativeChange(value) {\n        if (this.hasChangesBetweenModels()) {\n            this.value = value;\n        }\n    }\n\n    public hasChangesBetweenModels() {\n        return this.element.nativeElement.checked !== this.value;\n    }\n\n    public isToggleMode() {\n        return this.mode === NgtCheckboxMode.TOGGLE;\n    }\n\n    public isSideToggleMode(): boolean {\n        return this.mode === NgtCheckboxMode.SIDE_TOGGLE;\n    }\n\n    public isDefaultMode() {\n        return this.mode === NgtCheckboxMode.DEFAULT;\n    }\n\n    public isRadioMode() {\n        return this.mode === NgtCheckboxMode.RADIO;\n    }\n\n    public ngOnChanges(changes: SimpleChanges) {\n        if (changes.mode) {\n            this.mode = getEnumFromString(changes.mode.currentValue, NgtCheckboxMode);\n        }\n    }\n\n    private destroySubscriptions() {\n        this.subscriptions.forEach(subscription => subscription.unsubscribe());\n        this.subscriptions = [];\n    }\n}\n\nexport enum NgtCheckboxMode {\n    DEFAULT = 'DEFAULT',\n    TOGGLE = 'TOGGLE',\n    SIDE_TOGGLE = 'SIDE_TOGGLE',\n    RADIO = 'RADIO'\n}\n","<label class=\"flex items-center {{ isDisabled ? 'cursor-not-allowed' : 'cursor-pointer' }}\"\n    [class.flex-col]='isToggleMode()' style=\"max-width: max-content;\">\n    <input type=\"checkbox\" [name]='name' class=\"hidden\" ([ngModel])='value' [disabled]=\"isDisabled || isClickDisabled\"\n        #element>\n\n    <span *ngIf=\"isToggleMode() && label\" class=\"flex\">\n        <span class=\"{{ ngtStyle.compile(['text', 'fontCase']) }} mb-2\">{{ label }}</span>\n\n        <ngt-helper *ngIf=\"helpText\" [helpTitle]=\"helpTitle\" [iconColor]=\"helpTextColor\"\n        [autoXReverse]=\"helperAutoXReverse\" class=\"ml-1\">\n            {{ helpText }}\n        </ngt-helper>\n    </span>\n\n    <ng-container *ngIf=\"isDefaultMode()\">\n        <div style=\"transition: background-color .2s ease-out\"\n            class=\"{{ value ? ngtStyle.compile(['color.bg']) : 'bg-white' }}  {{ ngtStyle.compile(['h', 'w']) }}\n                    shadow rounded border border-gray-400 {{ isDisabled ? 'opacity-50' : '' }} {{ !shining ? 'flex justify-center' : 'hidden' }}\">\n            <svg class=\"fill-current self-center text-white pointer-events-none\" xmlns=\"http://www.w3.org/2000/svg\"\n                viewBox=\"0 0 20 20\">\n                <path d=\"M0 11l2-2 5 5L18 3l2 2L7 18z\" />\n            </svg>\n        </div>\n    </ng-container>\n\n    <ng-container *ngIf=\"isRadioMode()\">\n        <div style=\"transition: background-color .2s ease-out\"\n            class=\"{{ value ? ngtStyle.compile(['color.border', 'color.text']) : 'border-gray-500' }} {{ isDisabled ? 'opacity-50' : '' }}\n                    shadow w-6 h-6 rounded-full border-2 border-gray-400 {{ !shining ? 'flex justify-center' : 'hidden' }}\">\n            <svg *ngIf=\"value\" class=\"fill-current self-center h-3\" xmlns=\"http://www.w3.org/2000/svg\"\n                viewBox=\"0 0 29.107 29.107\">\n                <path\n                    d=\"M14.554 0C6.561 0 0 6.562 0 14.552c0 7.996 6.561 14.555 14.554 14.555 7.996 0 14.553-6.559 14.553-14.555C29.106 6.562 22.55 0 14.554 0z\" />\n            </svg>\n        </div>\n    </ng-container>\n\n    <ng-container *ngIf=\"isToggleMode() || isSideToggleMode()\">\n        <div class=\"shadow w-16 h-8 rounded-full border border-gray-400 {{ shining ? 'hidden' : 'flex' }}\"\n            [class.justify-end]=\"value\" [class.opacity-50]=\"isDisabled\" style=\"padding: 1px;\">\n            <div *ngIf=\"value\"\n                class=\"flex text-xs text-white {{ ngtStyle.compile(['color.bg']) }} pointer-events-none rounded-full px-2 py-3\"\n                @slideLeftToRight>\n                <svg class=\"fill-current self-center\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\">\n                    <path d=\"M0 11l2-2 5 5L18 3l2 2L7 18z\" />\n                </svg>\n            </div>\n\n            <div *ngIf=\"!value\" class=\"flex text-xl text-white bg-gray-300 pointer-events-none rounded-full px-1 py-3\"\n                @slideRightToLeft>\n                <svg class=\"fill-current self-center\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\">\n                    <path class=\"heroicon-ui\"\n                        d=\"M16.24 14.83a1 1 0 0 1-1.41 1.41L12 13.41l-2.83 2.83a1 1 0 0 1-1.41-1.41L10.59 12 7.76 9.17a1 1 0 0 1 1.41-1.41L12 10.59l2.83-2.83a1 1 0 0 1 1.41 1.41L13.41 12l2.83 2.83z\" />\n                </svg>\n            </div>\n        </div>\n    </ng-container>\n\n    <ng-container *ngIf='label && !shining && !isToggleMode()'>\n        <span class=\"{{ ngtStyle.compile(['text', 'fontCase']) }} ml-2\">{{ label }}</span>\n\n        <ngt-helper *ngIf=\"helpText\" [helpTitle]=\"helpTitle\" [iconColor]=\"helpTextColor\"\n        [autoXReverse]=\"helperAutoXReverse\" class=\"ml-1\">\n            {{ helpText }}\n        </ngt-helper>\n    </ng-container>\n</label>\n\n<ng-container *ngIf='shining'>\n    <div class=\"flex\">\n        <ngt-shining class=\"w-16 h-12\"></ngt-shining>\n    </div>\n</ng-container>\n"]}
204
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngt-checkbox.component.js","sourceRoot":"","sources":["../../../../../projects/ng-tailwind/src/components/ngt-checkbox/ngt-checkbox.component.ts","../../../../../projects/ng-tailwind/src/components/ngt-checkbox/ngt-checkbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { animate, state, style, transition, trigger } from '@angular/animations';\nimport {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    Host,\n    Injector,\n    Input,\n    OnChanges,\n    OnDestroy,\n    Optional,\n    Renderer2,\n    Self,\n    SimpleChanges,\n    SkipSelf,\n    ViewChild,\n} from '@angular/core';\nimport { ControlContainer, NgForm } from '@angular/forms';\nimport { Subscription } from 'rxjs';\n\nimport { NgtBaseNgModel, NgtMakeProvider } from '../../base/ngt-base-ng-model';\nimport { NgtStylizableDirective } from '../../directives/ngt-stylizable/ngt-stylizable.directive';\nimport { getEnumFromString } from '../../helpers/enum/enum';\nimport { NgtStylizableService } from '../../services/ngt-stylizable/ngt-stylizable.service';\nimport { NgtFormComponent } from '../ngt-form/ngt-form.component';\nimport { NgtSectionComponent } from '../ngt-section/ngt-section.component';\n\n@Component({\n    selector: 'ngt-checkbox',\n    templateUrl: './ngt-checkbox.component.html',\n    providers: [\n        NgtMakeProvider(NgtCheckboxComponent)\n    ],\n    viewProviders: [\n        { provide: ControlContainer, useExisting: NgForm }\n    ],\n    animations: [\n        trigger('slideLeftToRight', [\n            state('void', style({ transform: 'translateX(-4px) rotate(45deg)', opacity: 0 })),\n            transition(':enter', [\n                animate(200)\n            ])\n        ]),\n\n        trigger('slideRightToLeft', [\n            state('void', style({ transform: 'translateX(4px) rotate(45deg)', opacity: 0 })),\n            transition(':enter', [\n                animate(200)\n            ])\n        ])\n    ]\n})\nexport class NgtCheckboxComponent extends NgtBaseNgModel implements AfterViewInit, OnChanges, OnDestroy {\n    @ViewChild('element', { static: true }) public element: ElementRef;\n\n    @Input() public label: string;\n    @Input() public shining: boolean = false;\n    @Input() public isDisabled: boolean = false;\n    @Input() public isClickDisabled: boolean = false;\n    @Input() public name: string;\n    @Input() public mode: NgtCheckboxMode = NgtCheckboxMode.DEFAULT;\n    @Input() public helpTitle: string;\n    @Input() public helpTextColor: string = 'text-green-500';\n    @Input() public helpText: string;\n    @Input() public helperAutoXReverse: boolean = true;\n\n    public ngtStyle: NgtStylizableService;\n\n    private subscriptions: Array<Subscription> = [];\n\n    public constructor(\n        private changeDetector: ChangeDetectorRef,\n        private injector: Injector,\n        @Optional() @Host()\n        public formContainer: ControlContainer,\n        private renderer: Renderer2,\n        @Self() @Optional()\n        private ngtStylizableDirective: NgtStylizableDirective,\n        @Optional() @SkipSelf()\n        private ngtForm: NgtFormComponent,\n        @Optional() @SkipSelf()\n        public ngtSection: NgtSectionComponent\n    ) {\n        super();\n\n        if (this.ngtStylizableDirective) {\n            this.ngtStyle = this.ngtStylizableDirective.getNgtStylizableService();\n        } else {\n            this.ngtStyle = new NgtStylizableService();\n        }\n\n        this.ngtStyle.load(this.injector, 'NgtCheckbox', {\n            h: 'h-6',\n            w: 'w-6',\n            text: 'text-sm',\n            fontCase: '',\n            color: {\n                bg: 'bg-gray-500',\n                text: 'text-gray-500',\n                border: 'border-gray-500',\n            }\n        });\n    }\n\n    public ngAfterViewInit(): void {\n        this.renderer.listen(this.element.nativeElement, 'change', (value) => {\n            this.onNativeChange(this.element.nativeElement.checked);\n        });\n\n        this.bindSubscriptions();\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (changes.mode) {\n            this.mode = getEnumFromString(changes.mode.currentValue, NgtCheckboxMode);\n        }\n\n        if (changes.isDisabled && !changes.isDisabled.currentValue) {\n            this.isDisabled = this.ngtForm?.isDisabled || this.ngtSection?.isDisabled;\n        }\n    }\n\n    public ngOnDestroy() {\n        this.destroySubscriptions();\n    }\n\n    public change(value) {\n        if (this.hasChangesBetweenModels()) {\n            this.element.nativeElement.checked = value;\n        }\n    }\n\n    public onNativeChange(value) {\n        if (this.hasChangesBetweenModels()) {\n            this.value = value;\n        }\n    }\n\n    public hasChangesBetweenModels() {\n        return this.element.nativeElement.checked !== this.value;\n    }\n\n    public isToggleMode() {\n        return this.mode === NgtCheckboxMode.TOGGLE;\n    }\n\n    public isSideToggleMode(): boolean {\n        return this.mode === NgtCheckboxMode.SIDE_TOGGLE;\n    }\n\n    public isDefaultMode() {\n        return this.mode === NgtCheckboxMode.DEFAULT;\n    }\n\n    public isRadioMode() {\n        return this.mode === NgtCheckboxMode.RADIO;\n    }\n\n    private bindSubscriptions(): void {\n        this.changeDetector.detectChanges();\n\n        if (!this.isDisabled) {\n            this.isDisabled = this.ngtForm?.isDisabled || this.ngtSection?.isDisabled;\n        }\n\n        if (this.ngtForm) {\n            this.subscriptions.push(\n                this.ngtForm.onIsDisabledChange.subscribe((isDisabled: boolean) => {\n                    if (!this.isDisabled) {\n                        this.isDisabled = isDisabled || this.ngtSection?.isDisabled;\n                    }\n                })\n            );\n        }\n\n        if (this.ngtSection) {\n            this.subscriptions.push(\n                this.ngtSection.onIsDisabledChange.subscribe((isDisabled: boolean) => {\n                    if (!this.isDisabled) {\n                        this.isDisabled = isDisabled || this.ngtForm?.isDisabled;\n                    }\n                })\n            );\n        }\n\n        this.changeDetector.detectChanges();\n    }\n\n    private destroySubscriptions() {\n        this.subscriptions.forEach(subscription => subscription.unsubscribe());\n        this.subscriptions = [];\n    }\n}\n\nexport enum NgtCheckboxMode {\n    DEFAULT = 'DEFAULT',\n    TOGGLE = 'TOGGLE',\n    SIDE_TOGGLE = 'SIDE_TOGGLE',\n    RADIO = 'RADIO'\n}\n","<label class=\"flex items-center {{ isDisabled ? 'cursor-not-allowed opacity-50' : 'cursor-pointer' }}\"\n    [class.flex-col]='isToggleMode()' style=\"max-width: max-content;\">\n    <input type=\"checkbox\" [name]='name' class=\"hidden\" ([ngModel])='value' [disabled]=\"isDisabled || isClickDisabled\"\n        #element>\n\n    <span *ngIf=\"isToggleMode() && label\" class=\"flex\">\n        <span class=\"{{ ngtStyle.compile(['text', 'fontCase']) }} mb-2\">{{ label }}</span>\n\n        <ngt-helper *ngIf=\"helpText\" [helpTitle]=\"helpTitle\" [iconColor]=\"helpTextColor\"\n            [autoXReverse]=\"helperAutoXReverse\" class=\"ml-1\">\n            {{ helpText }}\n        </ngt-helper>\n    </span>\n\n    <ng-container *ngIf=\"isDefaultMode()\">\n        <div style=\"transition: background-color .2s ease-out\" class=\"{{ value ? ngtStyle.compile(['color.bg']) : 'bg-white' }}  {{ ngtStyle.compile(['h', 'w']) }}\n                    shadow rounded border border-gray-400 {{ !shining ? 'flex justify-center' : 'hidden' }}\">\n            <svg class=\"fill-current self-center text-white pointer-events-none\" xmlns=\"http://www.w3.org/2000/svg\"\n                viewBox=\"0 0 20 20\">\n                <path d=\"M0 11l2-2 5 5L18 3l2 2L7 18z\" />\n            </svg>\n        </div>\n    </ng-container>\n\n    <ng-container *ngIf=\"isRadioMode()\">\n        <div style=\"transition: background-color .2s ease-out\"\n            class=\"{{ value ? ngtStyle.compile(['color.border', 'color.text']) : 'border-gray-500' }}\n                    shadow w-6 h-6 rounded-full border-2 border-gray-400 {{ !shining ? 'flex justify-center' : 'hidden' }}\">\n            <svg *ngIf=\"value\" class=\"fill-current self-center h-3\" xmlns=\"http://www.w3.org/2000/svg\"\n                viewBox=\"0 0 29.107 29.107\">\n                <path\n                    d=\"M14.554 0C6.561 0 0 6.562 0 14.552c0 7.996 6.561 14.555 14.554 14.555 7.996 0 14.553-6.559 14.553-14.555C29.106 6.562 22.55 0 14.554 0z\" />\n            </svg>\n        </div>\n    </ng-container>\n\n    <ng-container *ngIf=\"isToggleMode() || isSideToggleMode()\">\n        <div class=\"shadow w-16 h-8 rounded-full border border-gray-400 {{ shining ? 'hidden' : 'flex' }}\"\n            [class.justify-end]=\"value\" style=\"padding: 1px;\">\n            <div *ngIf=\"value\"\n                class=\"flex text-xs text-white {{ ngtStyle.compile(['color.bg']) }} pointer-events-none rounded-full px-2 py-3\"\n                @slideLeftToRight>\n                <svg class=\"fill-current self-center\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\">\n                    <path d=\"M0 11l2-2 5 5L18 3l2 2L7 18z\" />\n                </svg>\n            </div>\n\n            <div *ngIf=\"!value\" class=\"flex text-xl text-white bg-gray-300 pointer-events-none rounded-full px-1 py-3\"\n                @slideRightToLeft>\n                <svg class=\"fill-current self-center\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\">\n                    <path class=\"heroicon-ui\"\n                        d=\"M16.24 14.83a1 1 0 0 1-1.41 1.41L12 13.41l-2.83 2.83a1 1 0 0 1-1.41-1.41L10.59 12 7.76 9.17a1 1 0 0 1 1.41-1.41L12 10.59l2.83-2.83a1 1 0 0 1 1.41 1.41L13.41 12l2.83 2.83z\" />\n                </svg>\n            </div>\n        </div>\n    </ng-container>\n\n    <ng-container *ngIf='label && !shining && !isToggleMode()'>\n        <span class=\"{{ ngtStyle.compile(['text', 'fontCase']) }} ml-2\">{{ label }}</span>\n\n        <ngt-helper *ngIf=\"helpText\" [helpTitle]=\"helpTitle\" [iconColor]=\"helpTextColor\"\n            [autoXReverse]=\"helperAutoXReverse\" class=\"ml-1\">\n            {{ helpText }}\n        </ngt-helper>\n    </ng-container>\n</label>\n\n<ng-container *ngIf='shining'>\n    <div class=\"flex\">\n        <ngt-shining class=\"w-16 h-12\"></ngt-shining>\n    </div>\n</ng-container>"]}