UNPKG

angular2-ladda

Version:
98 lines 12.3 kB
import { isPlatformBrowser } from '@angular/common'; import { Directive, Input, Optional, Inject, PLATFORM_ID } from '@angular/core'; import { create as createLadda } from 'ladda'; import { LaddaConfig } from './ladda-config'; import * as i0 from "@angular/core"; import * as i1 from "./ladda-config"; export class LaddaDirective { constructor(el, config, platformId) { this.platformId = platformId; this.ladda = undefined; this.disabled = false; this.el = el.nativeElement; if (!config) { return; } if (config.style && !this.el.getAttribute('data-style')) { this.el.setAttribute('data-style', config.style); } if (config.spinnerSize && !this.el.getAttribute('data-spinner-size')) { this.el.setAttribute('data-spinner-size', config.spinnerSize.toString()); } if (config.spinnerColor && !this.el.getAttribute('data-spinner-color')) { this.el.setAttribute('data-spinner-color', config.spinnerColor); } if (config.spinnerLines && !this.el.getAttribute('data-spinner-lines')) { this.el.setAttribute('data-spinner-lines', config.spinnerLines.toString()); } } ngOnChanges(changes) { if (!this.ladda) { return; // needed since ngOnChanges is called before ngOnInit } if (changes.loading) { this.updateLadda(changes.loading.previousValue); } if (changes.disabled) { this.updateDisabled(); } } ngOnInit() { if (!isPlatformBrowser(this.platformId)) { return; } this.ladda = createLadda(this.el); // if the initial loading value isn't false, a timeout of 0 ms // is necessary for the calculated spinner size to be correct. setTimeout(() => { this.updateLadda(false); }, 0); } ngOnDestroy() { if (this.ladda) { this.ladda.remove(); } } updateLadda(previousValue) { if (!this.ladda) { return; } let loading = typeof this.loading === 'number' || !!this.loading; let wasLoading = typeof previousValue === 'number' || !!previousValue; if (!loading) { if (wasLoading) { this.ladda.stop(); } return this.updateDisabled(); } if (!wasLoading) { this.ladda.start(); } if (typeof this.loading === 'number') { this.ladda.setProgress(this.loading); } } updateDisabled() { this.el.disabled = this.disabled; } } LaddaDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: LaddaDirective, deps: [{ token: i0.ElementRef }, { token: LaddaConfig, optional: true }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Directive }); LaddaDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.0.4", type: LaddaDirective, selector: "[ladda]", inputs: { loading: ["ladda", "loading"], disabled: "disabled" }, usesOnChanges: true, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: LaddaDirective, decorators: [{ type: Directive, args: [{ selector: '[ladda]', }] }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.LaddaConfigArgs, decorators: [{ type: Inject, args: [LaddaConfig] }, { type: Optional }] }, { type: Object, decorators: [{ type: Inject, args: [PLATFORM_ID] }] }]; }, propDecorators: { loading: [{ type: Input, args: ['ladda'] }], disabled: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ladda.directive.js","sourceRoot":"","sources":["../../../../projects/ladda/src/lib/ladda.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {isPlatformBrowser} from '@angular/common';\r\nimport {Directive, ElementRef, Input, OnInit, OnDestroy, OnChanges, SimpleChanges, Optional, Inject, PLATFORM_ID} from '@angular/core';\r\nimport {create as createLadda, LaddaButton} from 'ladda';\r\nimport {LaddaConfig, LaddaConfigArgs} from './ladda-config';\r\n\r\nexport type LaddaValue = boolean | number | undefined | null;\r\n\r\n@Directive({\r\n    selector: '[ladda]',\r\n})\r\nexport class LaddaDirective implements OnInit, OnDestroy, OnChanges {\r\n    private el: HTMLButtonElement;\r\n    private ladda: LaddaButton | undefined = undefined;\r\n\r\n    @Input('ladda') loading: LaddaValue;\r\n    @Input() disabled = false;\r\n\r\n    constructor(\r\n        el: ElementRef,\r\n        @Inject(LaddaConfig) @Optional() config: LaddaConfigArgs,\r\n        @Inject(PLATFORM_ID) private platformId: Object,\r\n    ) {\r\n        this.el = el.nativeElement;\r\n\r\n        if (!config) {\r\n            return;\r\n        }\r\n\r\n        if (config.style && !this.el.getAttribute('data-style')) {\r\n            this.el.setAttribute('data-style', config.style);\r\n        }\r\n\r\n        if (config.spinnerSize && !this.el.getAttribute('data-spinner-size')) {\r\n            this.el.setAttribute('data-spinner-size', config.spinnerSize.toString());\r\n        }\r\n\r\n        if (config.spinnerColor && !this.el.getAttribute('data-spinner-color')) {\r\n            this.el.setAttribute('data-spinner-color', config.spinnerColor);\r\n        }\r\n\r\n        if (config.spinnerLines && !this.el.getAttribute('data-spinner-lines')) {\r\n            this.el.setAttribute('data-spinner-lines', config.spinnerLines.toString());\r\n        }\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        if (!this.ladda) {\r\n            return; // needed since ngOnChanges is called before ngOnInit\r\n        }\r\n\r\n        if (changes.loading) {\r\n            this.updateLadda(changes.loading.previousValue);\r\n        }\r\n\r\n        if (changes.disabled) {\r\n            this.updateDisabled();\r\n        }\r\n    }\r\n\r\n    ngOnInit() {\r\n        if (!isPlatformBrowser(this.platformId)) {\r\n            return;\r\n        }\r\n\r\n        this.ladda = createLadda(this.el);\r\n\r\n        // if the initial loading value isn't false, a timeout of 0 ms\r\n        // is necessary for the calculated spinner size to be correct.\r\n        setTimeout(() => {this.updateLadda(false);}, 0);\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        if (this.ladda) {\r\n            this.ladda.remove();\r\n        }\r\n    }\r\n\r\n    private updateLadda(previousValue: LaddaValue): void {\r\n        if (!this.ladda) {\r\n            return;\r\n        }\r\n\r\n        let loading: boolean = typeof this.loading === 'number' || !!this.loading;\r\n        let wasLoading: boolean = typeof previousValue === 'number' || !!previousValue;\r\n\r\n        if (!loading) {\r\n            if (wasLoading) {\r\n                this.ladda.stop();\r\n            }\r\n\r\n            return this.updateDisabled();\r\n        }\r\n\r\n        if (!wasLoading) {\r\n            this.ladda.start();\r\n        }\r\n\r\n        if (typeof this.loading === 'number') {\r\n            this.ladda.setProgress(this.loading);\r\n        }\r\n    }\r\n\r\n    private updateDisabled(): void {\r\n        this.el.disabled = this.disabled;\r\n    }\r\n}\r\n"]}