ng-tailwind 4.3.33 → 4.4.34

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 (38) hide show
  1. package/components/ngt-action/ngt-action.component.d.ts +12 -9
  2. package/components/ngt-button/ngt-button.component.d.ts +11 -4
  3. package/components/ngt-checkbox/ngt-checkbox.component.d.ts +9 -7
  4. package/components/ngt-date/ngt-date.component.d.ts +10 -4
  5. package/components/ngt-dropzone/ngt-dropzone.component.d.ts +11 -3
  6. package/components/ngt-form/ngt-form.component.d.ts +11 -9
  7. package/components/ngt-input/ngt-input.component.d.ts +11 -4
  8. package/components/ngt-modal/ngt-modal-body/ngt-modal-body.component.d.ts +10 -3
  9. package/components/ngt-modal/ngt-modal.component.d.ts +9 -5
  10. package/components/ngt-multi-select/ngt-multi-select.component.d.ts +10 -4
  11. package/components/ngt-radio-button/ngt-radio-button.component.d.ts +10 -9
  12. package/components/ngt-section/ngt-section.component.d.ts +11 -7
  13. package/components/ngt-select/ngt-select.component.d.ts +13 -7
  14. package/esm2020/components/ngt-action/ngt-action.component.mjs +31 -39
  15. package/esm2020/components/ngt-button/ngt-button.component.mjs +37 -23
  16. package/esm2020/components/ngt-checkbox/ngt-checkbox.component.mjs +24 -36
  17. package/esm2020/components/ngt-datatable/ngt-datatable.component.mjs +3 -3
  18. package/esm2020/components/ngt-datatable/ngt-th/ngt-th.component.mjs +3 -3
  19. package/esm2020/components/ngt-date/ngt-date.component.mjs +41 -21
  20. package/esm2020/components/ngt-dropzone/ngt-dropzone.component.mjs +41 -15
  21. package/esm2020/components/ngt-form/ngt-form.component.mjs +24 -20
  22. package/esm2020/components/ngt-input/ngt-input.component.mjs +41 -16
  23. package/esm2020/components/ngt-modal/ngt-modal-body/ngt-modal-body.component.mjs +21 -6
  24. package/esm2020/components/ngt-modal/ngt-modal.component.mjs +21 -9
  25. package/esm2020/components/ngt-multi-select/ngt-multi-select.component.mjs +50 -30
  26. package/esm2020/components/ngt-pagination/ngt-pagination.component.mjs +3 -3
  27. package/esm2020/components/ngt-radio-button/ngt-radio-button.component.mjs +33 -47
  28. package/esm2020/components/ngt-section/ngt-section.component.mjs +29 -16
  29. package/esm2020/components/ngt-select/ngt-select.component.mjs +50 -47
  30. package/esm2020/public-api.mjs +3 -1
  31. package/esm2020/services/validation/ngt-ability-validation.service.mjs +3 -0
  32. package/fesm2015/ng-tailwind.mjs +612 -508
  33. package/fesm2015/ng-tailwind.mjs.map +1 -1
  34. package/fesm2020/ng-tailwind.mjs +601 -500
  35. package/fesm2020/ng-tailwind.mjs.map +1 -1
  36. package/package.json +1 -1
  37. package/public-api.d.ts +1 -0
  38. package/services/validation/ngt-ability-validation.service.d.ts +5 -0
@@ -4,16 +4,19 @@ import * as i0 from "@angular/core";
4
4
  import * as i1 from "../../directives/ngt-stylizable/ngt-stylizable.directive";
5
5
  import * as i2 from "../ngt-form/ngt-form.component";
6
6
  import * as i3 from "../ngt-section/ngt-section.component";
7
- import * as i4 from "@angular/common";
8
- import * as i5 from "@angular/router";
9
- import * as i6 from "../ngt-svg/ngt-svg.component";
7
+ import * as i4 from "../ngt-modal/ngt-modal.component";
8
+ import * as i5 from "../ngt-modal/ngt-modal-body/ngt-modal-body.component";
9
+ import * as i6 from "@angular/common";
10
+ import * as i7 from "@angular/router";
11
+ import * as i8 from "../ngt-svg/ngt-svg.component";
10
12
  export class NgtActionComponent {
11
- constructor(injector, changeDetector, ngtStylizableDirective, ngtForm, ngtSection) {
13
+ constructor(injector, ngtStylizableDirective, ngtForm, ngtSection, ngtModal, ngtModalBody) {
12
14
  this.injector = injector;
13
- this.changeDetector = changeDetector;
14
15
  this.ngtStylizableDirective = ngtStylizableDirective;
15
16
  this.ngtForm = ngtForm;
16
17
  this.ngtSection = ngtSection;
18
+ this.ngtModal = ngtModal;
19
+ this.ngtModalBody = ngtModalBody;
17
20
  this.subscriptions = [];
18
21
  if (this.ngtStylizableDirective) {
19
22
  this.ngtStyle = this.ngtStylizableDirective.getNgtStylizableService();
@@ -33,54 +36,33 @@ export class NgtActionComponent {
33
36
  border: 'border-0',
34
37
  });
35
38
  }
36
- ngAfterViewInit() {
37
- this.bindSubscriptions();
38
- }
39
- ngOnChanges(changes) {
40
- if (changes.isDisabled && !changes.isDisabled.currentValue) {
41
- this.isDisabled = this.ngtForm?.isDisabled || this.ngtSection?.isDisabled;
42
- }
43
- }
44
39
  ngOnDestroy() {
45
40
  this.destroySubscriptions();
46
41
  }
47
42
  onClick(event) {
48
- if (this.isDisabled) {
43
+ if (this.disabled()) {
49
44
  event.stopPropagation();
50
45
  }
51
46
  }
52
- bindSubscriptions() {
53
- this.changeDetector.detectChanges();
54
- if (!this.isDisabled) {
55
- this.isDisabled = this.ngtForm?.isDisabled || this.ngtSection?.isDisabled;
56
- }
57
- if (this.ngtForm) {
58
- this.subscriptions.push(this.ngtForm.onIsDisabledChange.subscribe((isDisabled) => {
59
- if (!this.isDisabled) {
60
- this.isDisabled = isDisabled || this.ngtSection?.isDisabled;
61
- }
62
- }));
63
- }
64
- if (this.ngtSection) {
65
- this.subscriptions.push(this.ngtSection.onIsDisabledChange.subscribe((isDisabled) => {
66
- if (!this.isDisabled) {
67
- this.isDisabled = isDisabled || this.ngtForm?.isDisabled;
68
- }
69
- }));
70
- }
71
- this.changeDetector.detectChanges();
47
+ disabled() {
48
+ return !this.forceEnable && (this.isDisabled || this.isDisabledByParent());
49
+ }
50
+ isDisabledByParent() {
51
+ return this.ngtForm?.isDisabled
52
+ || this.ngtSection?.isDisabled
53
+ || this.ngtModal?.isDisabled;
72
54
  }
73
55
  destroySubscriptions() {
74
56
  this.subscriptions.forEach(subscription => subscription.unsubscribe());
75
57
  this.subscriptions = [];
76
58
  }
77
59
  }
78
- NgtActionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: NgtActionComponent, deps: [{ token: i0.Injector }, { token: i0.ChangeDetectorRef }, { token: i1.NgtStylizableDirective, optional: true, self: true }, { token: i2.NgtFormComponent, optional: true, skipSelf: true }, { token: i3.NgtSectionComponent, optional: true, skipSelf: true }], target: i0.ɵɵFactoryTarget.Component });
79
- NgtActionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: NgtActionComponent, selector: "ngt-action", inputs: { href: "href", icon: "icon", ngtStyle: "ngtStyle", isDisabled: "isDisabled" }, usesOnChanges: true, ngImport: i0, template: "<a *ngIf=\"href\"\n [class]=\"isDisabled ? 'block rounded-full cursor-not-allowed text-gray-600 bg-gray-400 hover:bg-gray-400 opacity-50' : 'cursor-pointer'\"\n [routerLink]=\"href\" (click)='onClick($event)'>\n <div\n class=\"flex justify-center rounded-full {{ ngtStyle.compile(['h', 'w', 'color.bg', 'color.text', 'px', 'py', 'shadow', 'text']) }}\">\n <ngt-svg [src]=\"icon\" class='self-center' *ngIf=\"icon\">\n </ngt-svg>\n <div class=\"self-center\">\n <ng-content></ng-content>\n </div>\n </div>\n</a>\n\n<a *ngIf=\"!href\"\n [class]=\"isDisabled ? 'block rounded-full cursor-not-allowed text-gray-600 bg-gray-400 hover:bg-gray-400 opacity-50' : 'cursor-pointer'\"\n (click)='onClick($event)'>\n <div\n class=\"flex justify-center rounded-full {{ ngtStyle.compile(['h', 'w', 'color.bg', 'color.text', 'px', 'py', 'shadow', 'text', 'border', 'color.border']) }}\">\n <ngt-svg [src]=\"icon\" class='self-center' *ngIf=\"icon\"></ngt-svg>\n <div class=\"self-center\">\n <ng-content></ng-content>\n </div>\n </div>\n</a>\n", dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i6.NgtSvgComponent, selector: "ngt-svg", inputs: ["src", "class"] }] });
60
+ NgtActionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: NgtActionComponent, deps: [{ token: i0.Injector }, { token: i1.NgtStylizableDirective, optional: true, self: true }, { token: i2.NgtFormComponent, optional: true, skipSelf: true }, { token: i3.NgtSectionComponent, optional: true, skipSelf: true }, { token: i4.NgtModalComponent, optional: true, skipSelf: true }, { token: i5.NgtModalBodyComponent, optional: true, skipSelf: true }], target: i0.ɵɵFactoryTarget.Component });
61
+ NgtActionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: NgtActionComponent, selector: "ngt-action", inputs: { href: "href", icon: "icon", ngtStyle: "ngtStyle", isDisabled: "isDisabled", forceEnable: "forceEnable" }, ngImport: i0, template: "<a *ngIf=\"href\"\n [class]=\"disabled() ? 'block rounded-full cursor-not-allowed text-gray-600 bg-gray-400 hover:bg-gray-400 opacity-50' : 'cursor-pointer'\"\n [routerLink]=\"href\" (click)='onClick($event)'>\n <div\n class=\"flex justify-center rounded-full {{ ngtStyle.compile(['h', 'w', 'color.bg', 'color.text', 'px', 'py', 'shadow', 'text']) }}\">\n <ngt-svg [src]=\"icon\" class='self-center' *ngIf=\"icon\">\n </ngt-svg>\n <div class=\"self-center\">\n <ng-content></ng-content>\n </div>\n </div>\n</a>\n\n<a *ngIf=\"!href\"\n [class]=\"disabled() ? 'block rounded-full cursor-not-allowed text-gray-600 bg-gray-400 hover:bg-gray-400 opacity-50' : 'cursor-pointer'\"\n (click)='onClick($event)'>\n <div\n class=\"flex justify-center rounded-full {{ ngtStyle.compile(['h', 'w', 'color.bg', 'color.text', 'px', 'py', 'shadow', 'text', 'border', 'color.border']) }}\">\n <ngt-svg [src]=\"icon\" class='self-center' *ngIf=\"icon\"></ngt-svg>\n <div class=\"self-center\">\n <ng-content></ng-content>\n </div>\n </div>\n</a>", dependencies: [{ kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i7.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i8.NgtSvgComponent, selector: "ngt-svg", inputs: ["src", "class"] }] });
80
62
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: NgtActionComponent, decorators: [{
81
63
  type: Component,
82
- args: [{ selector: 'ngt-action', template: "<a *ngIf=\"href\"\n [class]=\"isDisabled ? 'block rounded-full cursor-not-allowed text-gray-600 bg-gray-400 hover:bg-gray-400 opacity-50' : 'cursor-pointer'\"\n [routerLink]=\"href\" (click)='onClick($event)'>\n <div\n class=\"flex justify-center rounded-full {{ ngtStyle.compile(['h', 'w', 'color.bg', 'color.text', 'px', 'py', 'shadow', 'text']) }}\">\n <ngt-svg [src]=\"icon\" class='self-center' *ngIf=\"icon\">\n </ngt-svg>\n <div class=\"self-center\">\n <ng-content></ng-content>\n </div>\n </div>\n</a>\n\n<a *ngIf=\"!href\"\n [class]=\"isDisabled ? 'block rounded-full cursor-not-allowed text-gray-600 bg-gray-400 hover:bg-gray-400 opacity-50' : 'cursor-pointer'\"\n (click)='onClick($event)'>\n <div\n class=\"flex justify-center rounded-full {{ ngtStyle.compile(['h', 'w', 'color.bg', 'color.text', 'px', 'py', 'shadow', 'text', 'border', 'color.border']) }}\">\n <ngt-svg [src]=\"icon\" class='self-center' *ngIf=\"icon\"></ngt-svg>\n <div class=\"self-center\">\n <ng-content></ng-content>\n </div>\n </div>\n</a>\n" }]
83
- }], ctorParameters: function () { return [{ type: i0.Injector }, { type: i0.ChangeDetectorRef }, { type: i1.NgtStylizableDirective, decorators: [{
64
+ args: [{ selector: 'ngt-action', template: "<a *ngIf=\"href\"\n [class]=\"disabled() ? 'block rounded-full cursor-not-allowed text-gray-600 bg-gray-400 hover:bg-gray-400 opacity-50' : 'cursor-pointer'\"\n [routerLink]=\"href\" (click)='onClick($event)'>\n <div\n class=\"flex justify-center rounded-full {{ ngtStyle.compile(['h', 'w', 'color.bg', 'color.text', 'px', 'py', 'shadow', 'text']) }}\">\n <ngt-svg [src]=\"icon\" class='self-center' *ngIf=\"icon\">\n </ngt-svg>\n <div class=\"self-center\">\n <ng-content></ng-content>\n </div>\n </div>\n</a>\n\n<a *ngIf=\"!href\"\n [class]=\"disabled() ? 'block rounded-full cursor-not-allowed text-gray-600 bg-gray-400 hover:bg-gray-400 opacity-50' : 'cursor-pointer'\"\n (click)='onClick($event)'>\n <div\n class=\"flex justify-center rounded-full {{ ngtStyle.compile(['h', 'w', 'color.bg', 'color.text', 'px', 'py', 'shadow', 'text', 'border', 'color.border']) }}\">\n <ngt-svg [src]=\"icon\" class='self-center' *ngIf=\"icon\"></ngt-svg>\n <div class=\"self-center\">\n <ng-content></ng-content>\n </div>\n </div>\n</a>" }]
65
+ }], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.NgtStylizableDirective, decorators: [{
84
66
  type: Self
85
67
  }, {
86
68
  type: Optional
@@ -92,6 +74,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImpor
92
74
  type: Optional
93
75
  }, {
94
76
  type: SkipSelf
77
+ }] }, { type: i4.NgtModalComponent, decorators: [{
78
+ type: Optional
79
+ }, {
80
+ type: SkipSelf
81
+ }] }, { type: i5.NgtModalBodyComponent, decorators: [{
82
+ type: Optional
83
+ }, {
84
+ type: SkipSelf
95
85
  }] }]; }, propDecorators: { href: [{
96
86
  type: Input
97
87
  }], icon: [{
@@ -100,5 +90,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImpor
100
90
  type: Input
101
91
  }], isDisabled: [{
102
92
  type: Input
93
+ }], forceEnable: [{
94
+ type: Input
103
95
  }] } });
104
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngt-action.component.js","sourceRoot":"","sources":["../../../../../projects/ng-tailwind/src/components/ngt-action/ngt-action.component.ts","../../../../../projects/ng-tailwind/src/components/ngt-action/ngt-action.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';\nimport { NgtSectionComponent } from '../ngt-section/ngt-section.component';\n\n@Component({\n    selector: 'ngt-action',\n    templateUrl: './ngt-action.component.html'\n})\nexport class NgtActionComponent implements AfterViewInit, OnChanges, OnDestroy {\n    @Input() public href: string;\n    @Input() public icon: string;\n    @Input() public ngtStyle: NgtStylizableService;\n    @Input() public isDisabled: boolean;\n\n    private subscriptions: Array<Subscription> = [];\n\n    public constructor(\n        private injector: Injector,\n        private changeDetector: ChangeDetectorRef,\n        @Self() @Optional()\n        private ngtStylizableDirective: NgtStylizableDirective,\n        @Optional() @SkipSelf()\n        public ngtForm: NgtFormComponent,\n        @Optional() @SkipSelf()\n        public ngtSection: NgtSectionComponent\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, 'NgtAction', {\n            h: 'h-full',\n            w: 'w-full',\n            color: {\n                bg: 'bg-gray-500',\n                text: 'text-white',\n                border: '',\n            },\n            text: 'text-xl',\n            border: 'border-0',\n        });\n    }\n\n    public ngAfterViewInit(): void {\n        this.bindSubscriptions();\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\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 onClick(event: Event) {\n        if (this.isDisabled) {\n            event.stopPropagation();\n        }\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(): void {\n        this.subscriptions.forEach(subscription => subscription.unsubscribe());\n        this.subscriptions = [];\n    }\n}\n","<a *ngIf=\"href\"\n    [class]=\"isDisabled ? 'block rounded-full cursor-not-allowed text-gray-600 bg-gray-400 hover:bg-gray-400 opacity-50' : 'cursor-pointer'\"\n    [routerLink]=\"href\" (click)='onClick($event)'>\n    <div\n        class=\"flex justify-center rounded-full {{ ngtStyle.compile(['h', 'w', 'color.bg', 'color.text', 'px', 'py', 'shadow', 'text']) }}\">\n        <ngt-svg [src]=\"icon\" class='self-center' *ngIf=\"icon\">\n        </ngt-svg>\n        <div class=\"self-center\">\n            <ng-content></ng-content>\n        </div>\n    </div>\n</a>\n\n<a *ngIf=\"!href\"\n    [class]=\"isDisabled ? 'block rounded-full cursor-not-allowed text-gray-600 bg-gray-400 hover:bg-gray-400 opacity-50' : 'cursor-pointer'\"\n    (click)='onClick($event)'>\n    <div\n        class=\"flex justify-center rounded-full {{ ngtStyle.compile(['h', 'w', 'color.bg', 'color.text', 'px', 'py', 'shadow', 'text', 'border', 'color.border']) }}\">\n        <ngt-svg [src]=\"icon\" class='self-center' *ngIf=\"icon\"></ngt-svg>\n        <div class=\"self-center\">\n            <ng-content></ng-content>\n        </div>\n    </div>\n</a>\n"]}
96
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd0LWFjdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy10YWlsd2luZC9zcmMvY29tcG9uZW50cy9uZ3QtYWN0aW9uL25ndC1hY3Rpb24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctdGFpbHdpbmQvc3JjL2NvbXBvbmVudHMvbmd0LWFjdGlvbi9uZ3QtYWN0aW9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDSCxTQUFTLEVBRVQsS0FBSyxFQUVMLFFBQVEsRUFDUixJQUFJLEVBQ0osUUFBUSxHQUNYLE1BQU0sZUFBZSxDQUFDO0FBSXZCLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHNEQUFzRCxDQUFDOzs7Ozs7Ozs7O0FBVTVGLE1BQU0sT0FBTyxrQkFBa0I7SUFTM0IsWUFDWSxRQUFrQixFQUdsQixzQkFBOEMsRUFHL0MsT0FBeUIsRUFHekIsVUFBK0IsRUFHL0IsUUFBMkIsRUFHM0IsWUFBbUM7UUFmbEMsYUFBUSxHQUFSLFFBQVEsQ0FBVTtRQUdsQiwyQkFBc0IsR0FBdEIsc0JBQXNCLENBQXdCO1FBRy9DLFlBQU8sR0FBUCxPQUFPLENBQWtCO1FBR3pCLGVBQVUsR0FBVixVQUFVLENBQXFCO1FBRy9CLGFBQVEsR0FBUixRQUFRLENBQW1CO1FBRzNCLGlCQUFZLEdBQVosWUFBWSxDQUF1QjtRQWxCdEMsa0JBQWEsR0FBd0IsRUFBRSxDQUFDO1FBb0I1QyxJQUFJLElBQUksQ0FBQyxzQkFBc0IsRUFBRTtZQUM3QixJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyx1QkFBdUIsRUFBRSxDQUFDO1NBQ3pFO2FBQU07WUFDSCxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksb0JBQW9CLEVBQUUsQ0FBQztTQUM5QztRQUVELElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsV0FBVyxFQUFFO1lBQzNDLENBQUMsRUFBRSxRQUFRO1lBQ1gsQ0FBQyxFQUFFLFFBQVE7WUFDWCxLQUFLLEVBQUU7Z0JBQ0gsRUFBRSxFQUFFLGFBQWE7Z0JBQ2pCLElBQUksRUFBRSxZQUFZO2dCQUNsQixNQUFNLEVBQUUsRUFBRTthQUNiO1lBQ0QsSUFBSSxFQUFFLFNBQVM7WUFDZixNQUFNLEVBQUUsVUFBVTtTQUNyQixDQUFDLENBQUM7SUFDUCxDQUFDO0lBRU0sV0FBVztRQUNkLElBQUksQ0FBQyxvQkFBb0IsRUFBRSxDQUFDO0lBQ2hDLENBQUM7SUFFTSxPQUFPLENBQUMsS0FBWTtRQUN2QixJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsRUFBRTtZQUNqQixLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7U0FDM0I7SUFDTCxDQUFDO0lBRU0sUUFBUTtRQUNYLE9BQU8sQ0FBQyxJQUFJLENBQUMsV0FBVyxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsSUFBSSxJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQyxDQUFDO0lBQy9FLENBQUM7SUFFTyxrQkFBa0I7UUFDdEIsT0FBTyxJQUFJLENBQUMsT0FBTyxFQUFFLFVBQVU7ZUFDeEIsSUFBSSxDQUFDLFVBQVUsRUFBRSxVQUFVO2VBQzNCLElBQUksQ0FBQyxRQUFRLEVBQUUsVUFBVSxDQUFDO0lBQ3JDLENBQUM7SUFFTyxvQkFBb0I7UUFDeEIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsWUFBWSxDQUFDLEVBQUUsQ0FBQyxZQUFZLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztRQUN2RSxJQUFJLENBQUMsYUFBYSxHQUFHLEVBQUUsQ0FBQztJQUM1QixDQUFDOzsrR0FyRVEsa0JBQWtCO21HQUFsQixrQkFBa0Isc0tDdEIvQixpbkNBdUJJOzJGRERTLGtCQUFrQjtrQkFKOUIsU0FBUzsrQkFDSSxZQUFZOzswQkFlakIsSUFBSTs7MEJBQUksUUFBUTs7MEJBR2hCLFFBQVE7OzBCQUFJLFFBQVE7OzBCQUdwQixRQUFROzswQkFBSSxRQUFROzswQkFHcEIsUUFBUTs7MEJBQUksUUFBUTs7MEJBR3BCLFFBQVE7OzBCQUFJLFFBQVE7NENBdkJULElBQUk7c0JBQW5CLEtBQUs7Z0JBQ1UsSUFBSTtzQkFBbkIsS0FBSztnQkFDVSxRQUFRO3NCQUF2QixLQUFLO2dCQUNVLFVBQVU7c0JBQXpCLEtBQUs7Z0JBQ1UsV0FBVztzQkFBMUIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQ29tcG9uZW50LFxuICAgIEluamVjdG9yLFxuICAgIElucHV0LFxuICAgIE9uRGVzdHJveSxcbiAgICBPcHRpb25hbCxcbiAgICBTZWxmLFxuICAgIFNraXBTZWxmLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBOZ3RTdHlsaXphYmxlRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vZGlyZWN0aXZlcy9uZ3Qtc3R5bGl6YWJsZS9uZ3Qtc3R5bGl6YWJsZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgTmd0U3R5bGl6YWJsZVNlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9uZ3Qtc3R5bGl6YWJsZS9uZ3Qtc3R5bGl6YWJsZS5zZXJ2aWNlJztcbmltcG9ydCB7IE5ndEZvcm1Db21wb25lbnQgfSBmcm9tICcuLi9uZ3QtZm9ybS9uZ3QtZm9ybS5jb21wb25lbnQnO1xuaW1wb3J0IHsgTmd0U2VjdGlvbkNvbXBvbmVudCB9IGZyb20gJy4uL25ndC1zZWN0aW9uL25ndC1zZWN0aW9uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBOZ3RNb2RhbENvbXBvbmVudCB9IGZyb20gJy4uL25ndC1tb2RhbC9uZ3QtbW9kYWwuY29tcG9uZW50JztcbmltcG9ydCB7IE5ndE1vZGFsQm9keUNvbXBvbmVudCB9IGZyb20gJy4uL25ndC1tb2RhbC9uZ3QtbW9kYWwtYm9keS9uZ3QtbW9kYWwtYm9keS5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ25ndC1hY3Rpb24nLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9uZ3QtYWN0aW9uLmNvbXBvbmVudC5odG1sJ1xufSlcbmV4cG9ydCBjbGFzcyBOZ3RBY3Rpb25Db21wb25lbnQgaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xuICAgIEBJbnB1dCgpIHB1YmxpYyBocmVmOiBzdHJpbmc7XG4gICAgQElucHV0KCkgcHVibGljIGljb246IHN0cmluZztcbiAgICBASW5wdXQoKSBwdWJsaWMgbmd0U3R5bGU6IE5ndFN0eWxpemFibGVTZXJ2aWNlO1xuICAgIEBJbnB1dCgpIHB1YmxpYyBpc0Rpc2FibGVkOiBib29sZWFuO1xuICAgIEBJbnB1dCgpIHB1YmxpYyBmb3JjZUVuYWJsZTogYm9vbGVhbjtcblxuICAgIHByaXZhdGUgc3Vic2NyaXB0aW9uczogQXJyYXk8U3Vic2NyaXB0aW9uPiA9IFtdO1xuXG4gICAgcHVibGljIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIGluamVjdG9yOiBJbmplY3RvcixcblxuICAgICAgICBAU2VsZigpIEBPcHRpb25hbCgpXG4gICAgICAgIHByaXZhdGUgbmd0U3R5bGl6YWJsZURpcmVjdGl2ZTogTmd0U3R5bGl6YWJsZURpcmVjdGl2ZSxcblxuICAgICAgICBAT3B0aW9uYWwoKSBAU2tpcFNlbGYoKVxuICAgICAgICBwdWJsaWMgbmd0Rm9ybTogTmd0Rm9ybUNvbXBvbmVudCxcblxuICAgICAgICBAT3B0aW9uYWwoKSBAU2tpcFNlbGYoKVxuICAgICAgICBwdWJsaWMgbmd0U2VjdGlvbjogTmd0U2VjdGlvbkNvbXBvbmVudCxcblxuICAgICAgICBAT3B0aW9uYWwoKSBAU2tpcFNlbGYoKVxuICAgICAgICBwdWJsaWMgbmd0TW9kYWw6IE5ndE1vZGFsQ29tcG9uZW50LFxuXG4gICAgICAgIEBPcHRpb25hbCgpIEBTa2lwU2VsZigpXG4gICAgICAgIHB1YmxpYyBuZ3RNb2RhbEJvZHk6IE5ndE1vZGFsQm9keUNvbXBvbmVudFxuICAgICkge1xuICAgICAgICBpZiAodGhpcy5uZ3RTdHlsaXphYmxlRGlyZWN0aXZlKSB7XG4gICAgICAgICAgICB0aGlzLm5ndFN0eWxlID0gdGhpcy5uZ3RTdHlsaXphYmxlRGlyZWN0aXZlLmdldE5ndFN0eWxpemFibGVTZXJ2aWNlKCk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLm5ndFN0eWxlID0gbmV3IE5ndFN0eWxpemFibGVTZXJ2aWNlKCk7XG4gICAgICAgIH1cblxuICAgICAgICB0aGlzLm5ndFN0eWxlLmxvYWQodGhpcy5pbmplY3RvciwgJ05ndEFjdGlvbicsIHtcbiAgICAgICAgICAgIGg6ICdoLWZ1bGwnLFxuICAgICAgICAgICAgdzogJ3ctZnVsbCcsXG4gICAgICAgICAgICBjb2xvcjoge1xuICAgICAgICAgICAgICAgIGJnOiAnYmctZ3JheS01MDAnLFxuICAgICAgICAgICAgICAgIHRleHQ6ICd0ZXh0LXdoaXRlJyxcbiAgICAgICAgICAgICAgICBib3JkZXI6ICcnLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIHRleHQ6ICd0ZXh0LXhsJyxcbiAgICAgICAgICAgIGJvcmRlcjogJ2JvcmRlci0wJyxcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgcHVibGljIG5nT25EZXN0cm95KCkge1xuICAgICAgICB0aGlzLmRlc3Ryb3lTdWJzY3JpcHRpb25zKCk7XG4gICAgfVxuXG4gICAgcHVibGljIG9uQ2xpY2soZXZlbnQ6IEV2ZW50KSB7XG4gICAgICAgIGlmICh0aGlzLmRpc2FibGVkKCkpIHtcbiAgICAgICAgICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHVibGljIGRpc2FibGVkKCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gIXRoaXMuZm9yY2VFbmFibGUgJiYgKHRoaXMuaXNEaXNhYmxlZCB8fCB0aGlzLmlzRGlzYWJsZWRCeVBhcmVudCgpKTtcbiAgICB9XG5cbiAgICBwcml2YXRlIGlzRGlzYWJsZWRCeVBhcmVudCgpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIHRoaXMubmd0Rm9ybT8uaXNEaXNhYmxlZFxuICAgICAgICAgICAgfHwgdGhpcy5uZ3RTZWN0aW9uPy5pc0Rpc2FibGVkXG4gICAgICAgICAgICB8fCB0aGlzLm5ndE1vZGFsPy5pc0Rpc2FibGVkO1xuICAgIH1cblxuICAgIHByaXZhdGUgZGVzdHJveVN1YnNjcmlwdGlvbnMoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuc3Vic2NyaXB0aW9ucy5mb3JFYWNoKHN1YnNjcmlwdGlvbiA9PiBzdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKSk7XG4gICAgICAgIHRoaXMuc3Vic2NyaXB0aW9ucyA9IFtdO1xuICAgIH1cbn1cbiIsIjxhICpuZ0lmPVwiaHJlZlwiXG4gICAgW2NsYXNzXT1cImRpc2FibGVkKCkgPyAnYmxvY2sgcm91bmRlZC1mdWxsIGN1cnNvci1ub3QtYWxsb3dlZCB0ZXh0LWdyYXktNjAwIGJnLWdyYXktNDAwIGhvdmVyOmJnLWdyYXktNDAwIG9wYWNpdHktNTAnIDogJ2N1cnNvci1wb2ludGVyJ1wiXG4gICAgW3JvdXRlckxpbmtdPVwiaHJlZlwiIChjbGljayk9J29uQ2xpY2soJGV2ZW50KSc+XG4gICAgPGRpdlxuICAgICAgICBjbGFzcz1cImZsZXgganVzdGlmeS1jZW50ZXIgcm91bmRlZC1mdWxsIHt7IG5ndFN0eWxlLmNvbXBpbGUoWydoJywgJ3cnLCAnY29sb3IuYmcnLCAnY29sb3IudGV4dCcsICdweCcsICdweScsICdzaGFkb3cnLCAndGV4dCddKSB9fVwiPlxuICAgICAgICA8bmd0LXN2ZyBbc3JjXT1cImljb25cIiBjbGFzcz0nc2VsZi1jZW50ZXInICpuZ0lmPVwiaWNvblwiPlxuICAgICAgICA8L25ndC1zdmc+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJzZWxmLWNlbnRlclwiPlxuICAgICAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICAgICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbjwvYT5cblxuPGEgKm5nSWY9XCIhaHJlZlwiXG4gICAgW2NsYXNzXT1cImRpc2FibGVkKCkgPyAnYmxvY2sgcm91bmRlZC1mdWxsIGN1cnNvci1ub3QtYWxsb3dlZCB0ZXh0LWdyYXktNjAwIGJnLWdyYXktNDAwIGhvdmVyOmJnLWdyYXktNDAwIG9wYWNpdHktNTAnIDogJ2N1cnNvci1wb2ludGVyJ1wiXG4gICAgKGNsaWNrKT0nb25DbGljaygkZXZlbnQpJz5cbiAgICA8ZGl2XG4gICAgICAgIGNsYXNzPVwiZmxleCBqdXN0aWZ5LWNlbnRlciByb3VuZGVkLWZ1bGwge3sgbmd0U3R5bGUuY29tcGlsZShbJ2gnLCAndycsICdjb2xvci5iZycsICdjb2xvci50ZXh0JywgJ3B4JywgJ3B5JywgJ3NoYWRvdycsICd0ZXh0JywgJ2JvcmRlcicsICdjb2xvci5ib3JkZXInXSkgfX1cIj5cbiAgICAgICAgPG5ndC1zdmcgW3NyY109XCJpY29uXCIgY2xhc3M9J3NlbGYtY2VudGVyJyAqbmdJZj1cImljb25cIj48L25ndC1zdmc+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJzZWxmLWNlbnRlclwiPlxuICAgICAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICAgICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbjwvYT4iXX0=
@@ -2,20 +2,20 @@ 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";
5
- import * as i2 from "../../directives/ngt-stylizable/ngt-stylizable.directive";
6
- import * as i3 from "@angular/common";
7
- import * as i4 from "@angular/router";
5
+ import * as i2 from "../ngt-section/ngt-section.component";
6
+ import * as i3 from "../ngt-modal/ngt-modal.component";
7
+ import * as i4 from "../../directives/ngt-stylizable/ngt-stylizable.directive";
8
+ import * as i5 from "@angular/common";
9
+ import * as i6 from "@angular/router";
8
10
  export class NgtButtonComponent {
9
- constructor(changeDetector, injector, ngtForm, ngtStylizableDirective) {
11
+ constructor(changeDetector, injector, ngtForm, ngtSection, ngtModal, ngtStylizableDirective) {
10
12
  this.changeDetector = changeDetector;
11
13
  this.injector = injector;
12
14
  this.ngtForm = ngtForm;
15
+ this.ngtSection = ngtSection;
16
+ this.ngtModal = ngtModal;
13
17
  this.ngtStylizableDirective = ngtStylizableDirective;
14
- this.link = false;
15
18
  this.type = 'success';
16
- this.loading = false;
17
- this.isDisabled = false;
18
- this.noSubmit = false;
19
19
  this.subscriptions = [];
20
20
  if (this.ngtStylizableDirective) {
21
21
  this.ngtStyle = this.ngtStylizableDirective.getNgtStylizableService();
@@ -25,11 +25,12 @@ export class NgtButtonComponent {
25
25
  }
26
26
  this.ngtStyle.load(this.injector, 'NgtButton', {
27
27
  px: 'px-4',
28
- py: 'py-2'
28
+ py: 'py-2',
29
+ text: 'text-sm'
29
30
  });
30
31
  }
31
32
  onClick(event) {
32
- if (this.isDisabled || this.loading) {
33
+ if (this.disabled() || this.loading) {
33
34
  event.preventDefault();
34
35
  event.stopPropagation();
35
36
  }
@@ -73,52 +74,65 @@ export class NgtButtonComponent {
73
74
  }
74
75
  }
75
76
  }
77
+ disabled() {
78
+ return !this.forceEnable && (this.isDisabled || this.isDisabledByParent());
79
+ }
76
80
  ngOnDestroy() {
77
81
  this.destroySubscriptions();
78
82
  }
79
83
  bindSubscriptions() {
80
- this.changeDetector.detectChanges();
81
84
  if (this.ngtForm) {
82
85
  this.loading = this.ngtForm.isLoading();
83
- this.isDisabled = !this.isDisabled && this.ngtForm.isDisabled;
84
86
  this.changeDetector.detectChanges();
85
87
  this.subscriptions.push(this.ngtForm.onLoadingChange.subscribe((loading) => {
86
88
  this.loading = loading;
87
89
  }));
88
- this.subscriptions.push(this.ngtForm.onIsDisabledChange.subscribe((isDisabled) => {
89
- this.isDisabled = !this.isDisabled && isDisabled;
90
- }));
91
90
  }
92
91
  }
92
+ isDisabledByParent() {
93
+ return this.ngtForm?.isDisabled
94
+ || this.ngtSection?.isDisabled
95
+ || this.ngtModal?.isDisabled;
96
+ }
93
97
  destroySubscriptions() {
94
98
  this.subscriptions.forEach(subscription => subscription.unsubscribe());
95
99
  this.subscriptions = [];
96
100
  }
97
101
  }
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 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"] }] });
102
+ 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.NgtSectionComponent, optional: true, skipSelf: true }, { token: i3.NgtModalComponent, optional: true, skipSelf: true }, { token: i4.NgtStylizableDirective, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
103
+ NgtButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: NgtButtonComponent, selector: "ngt-button", inputs: { href: "href", type: "type", link: "link", loading: "loading", isDisabled: "isDisabled", forceEnable: "forceEnable", noSubmit: "noSubmit" }, usesOnChanges: true, ngImport: i0, template: "<ng-template #content>\n <ng-content></ng-content>\n</ng-template>\n\n<div class=\"relative h-full w-full\" (click)='onClick($event)'>\n <ng-container *ngIf='!link'>\n <button [ngClass]=\"{ 'disabled-button': disabled(), 'loading-button': loading }\" [disabled]=\"disabled()\"\n [type]=\"(loading || disabled() || 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', 'text']) }}\">\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': disabled(), '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', 'text']) }}\">\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\n <legend *ngIf=\"forceEnable\" class=\"absolute top-0 h-full w-full cursor-pointer hover:opacity-25 hover:bg-gray-100\"\n (click)='onClick($event)'>\n </legend>\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: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i6.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }] });
100
104
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: NgtButtonComponent, decorators: [{
101
105
  type: Component,
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 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"] }]
106
+ args: [{ selector: 'ngt-button', template: "<ng-template #content>\n <ng-content></ng-content>\n</ng-template>\n\n<div class=\"relative h-full w-full\" (click)='onClick($event)'>\n <ng-container *ngIf='!link'>\n <button [ngClass]=\"{ 'disabled-button': disabled(), 'loading-button': loading }\" [disabled]=\"disabled()\"\n [type]=\"(loading || disabled() || 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', 'text']) }}\">\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': disabled(), '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', 'text']) }}\">\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\n <legend *ngIf=\"forceEnable\" class=\"absolute top-0 h-full w-full cursor-pointer hover:opacity-25 hover:bg-gray-100\"\n (click)='onClick($event)'>\n </legend>\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
107
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.Injector }, { type: i1.NgtFormComponent, decorators: [{
104
108
  type: Optional
105
109
  }, {
106
110
  type: SkipSelf
107
- }] }, { type: i2.NgtStylizableDirective, decorators: [{
111
+ }] }, { type: i2.NgtSectionComponent, decorators: [{
112
+ type: Optional
113
+ }, {
114
+ type: SkipSelf
115
+ }] }, { type: i3.NgtModalComponent, decorators: [{
116
+ type: Optional
117
+ }, {
118
+ type: SkipSelf
119
+ }] }, { type: i4.NgtStylizableDirective, decorators: [{
108
120
  type: Self
109
121
  }, {
110
122
  type: Optional
111
- }] }]; }, propDecorators: { link: [{
112
- type: Input
113
- }], href: [{
123
+ }] }]; }, propDecorators: { href: [{
114
124
  type: Input
115
125
  }], type: [{
116
126
  type: Input
127
+ }], link: [{
128
+ type: Input
117
129
  }], loading: [{
118
130
  type: Input
119
131
  }], isDisabled: [{
120
132
  type: Input
133
+ }], forceEnable: [{
134
+ type: Input
121
135
  }], noSubmit: [{
122
136
  type: Input
123
137
  }] } });
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 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>"]}
138
+ //# 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';\nimport { NgtModalComponent } from '../ngt-modal/ngt-modal.component';\nimport { NgtSectionComponent } from '../ngt-section/ngt-section.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 href: string;\n    @Input() public type: string = 'success';\n    @Input() public link: boolean;\n    @Input() public loading: boolean;\n    @Input() public isDisabled: boolean;\n    @Input() public forceEnable: boolean;\n    @Input() public noSubmit: boolean;\n\n    public ngtStyle: NgtStylizableService;\n\n    private subscriptions: Array<Subscription> = [];\n\n    public constructor(\n        private changeDetector: ChangeDetectorRef,\n        private injector: Injector,\n\n        @Optional() @SkipSelf()\n        private ngtForm: NgtFormComponent,\n\n        @Optional() @SkipSelf()\n        private ngtSection: NgtSectionComponent,\n\n        @Optional() @SkipSelf()\n        private ngtModal: NgtModalComponent,\n\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            text: 'text-sm'\n        });\n    }\n\n    public onClick(event: Event): void {\n        if (this.disabled() || 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 disabled(): boolean {\n        return !this.forceEnable && (this.isDisabled || this.isDisabledByParent());\n    }\n\n    public ngOnDestroy(): void {\n        this.destroySubscriptions();\n    }\n\n    private bindSubscriptions(): void {\n        if (this.ngtForm) {\n            this.loading = this.ngtForm.isLoading();\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    }\n\n    private isDisabledByParent(): boolean {\n        return this.ngtForm?.isDisabled\n            || this.ngtSection?.isDisabled\n            || this.ngtModal?.isDisabled;\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=\"relative h-full w-full\" (click)='onClick($event)'>\n    <ng-container *ngIf='!link'>\n        <button [ngClass]=\"{ 'disabled-button': disabled(), 'loading-button': loading }\" [disabled]=\"disabled()\"\n            [type]=\"(loading || disabled() || 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', 'text']) }}\">\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': disabled(), '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', 'text']) }}\">\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\n    <legend *ngIf=\"forceEnable\" class=\"absolute top-0 h-full w-full cursor-pointer hover:opacity-25 hover:bg-gray-100\"\n        (click)='onClick($event)'>\n    </legend>\n</div>"]}