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.
- package/components/ngt-action/ngt-action.component.d.ts +12 -9
- package/components/ngt-button/ngt-button.component.d.ts +11 -4
- package/components/ngt-checkbox/ngt-checkbox.component.d.ts +9 -7
- package/components/ngt-date/ngt-date.component.d.ts +10 -4
- package/components/ngt-dropzone/ngt-dropzone.component.d.ts +11 -3
- package/components/ngt-form/ngt-form.component.d.ts +11 -9
- package/components/ngt-input/ngt-input.component.d.ts +11 -4
- package/components/ngt-modal/ngt-modal-body/ngt-modal-body.component.d.ts +10 -3
- package/components/ngt-modal/ngt-modal.component.d.ts +9 -5
- package/components/ngt-multi-select/ngt-multi-select.component.d.ts +10 -4
- package/components/ngt-radio-button/ngt-radio-button.component.d.ts +10 -9
- package/components/ngt-section/ngt-section.component.d.ts +11 -7
- package/components/ngt-select/ngt-select.component.d.ts +13 -7
- package/esm2020/components/ngt-action/ngt-action.component.mjs +31 -39
- package/esm2020/components/ngt-button/ngt-button.component.mjs +37 -23
- package/esm2020/components/ngt-checkbox/ngt-checkbox.component.mjs +24 -36
- package/esm2020/components/ngt-datatable/ngt-datatable.component.mjs +3 -3
- package/esm2020/components/ngt-datatable/ngt-th/ngt-th.component.mjs +3 -3
- package/esm2020/components/ngt-date/ngt-date.component.mjs +41 -21
- package/esm2020/components/ngt-dropzone/ngt-dropzone.component.mjs +41 -15
- package/esm2020/components/ngt-form/ngt-form.component.mjs +24 -20
- package/esm2020/components/ngt-input/ngt-input.component.mjs +41 -16
- package/esm2020/components/ngt-modal/ngt-modal-body/ngt-modal-body.component.mjs +21 -6
- package/esm2020/components/ngt-modal/ngt-modal.component.mjs +21 -9
- package/esm2020/components/ngt-multi-select/ngt-multi-select.component.mjs +50 -30
- package/esm2020/components/ngt-pagination/ngt-pagination.component.mjs +3 -3
- package/esm2020/components/ngt-radio-button/ngt-radio-button.component.mjs +33 -47
- package/esm2020/components/ngt-section/ngt-section.component.mjs +29 -16
- package/esm2020/components/ngt-select/ngt-select.component.mjs +50 -47
- package/esm2020/public-api.mjs +3 -1
- package/esm2020/services/validation/ngt-ability-validation.service.mjs +3 -0
- package/fesm2015/ng-tailwind.mjs +612 -508
- package/fesm2015/ng-tailwind.mjs.map +1 -1
- package/fesm2020/ng-tailwind.mjs +601 -500
- package/fesm2020/ng-tailwind.mjs.map +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- 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 "
|
|
8
|
-
import * as i5 from "
|
|
9
|
-
import * as i6 from "
|
|
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,
|
|
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.
|
|
43
|
+
if (this.disabled()) {
|
|
49
44
|
event.stopPropagation();
|
|
50
45
|
}
|
|
51
46
|
}
|
|
52
|
-
|
|
53
|
-
this.
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
this.
|
|
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:
|
|
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"
|
|
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]=\"
|
|
83
|
-
}], ctorParameters: function () { return [{ type: i0.Injector }, { type:
|
|
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,
|
|
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 "
|
|
6
|
-
import * as i3 from "
|
|
7
|
-
import * as i4 from "
|
|
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.
|
|
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: {
|
|
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':
|
|
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.
|
|
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: {
|
|
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>"]}
|