UNPKG

@blox/material

Version:

Material Components for Angular

195 lines 25.6 kB
import { Directive, ElementRef, HostBinding, Input, Renderer2 } from '@angular/core'; import { MDCLinearProgressFoundation } from '@material/linear-progress'; import { asBoolean } from '../../utils/value.utils'; const CLASS_INDETERMINATE = 'mdc-linear-progress--indeterminate'; const CLASS_REVERSED = 'mdc-linear-progress--reversed'; /** * Directive for creating a Material Design linear progress indicator. * The current implementation will add and manage all DOM child elements that * are required for the wrapped <code>mdc-linear-progress</code> component. * Future implementations will also support supplying (customized) * DOM children. */ export class MdcLinearProgressDirective { constructor(_rndr, _root) { this._rndr = _rndr; this._root = _root; /** @internal */ this._cls = true; /** @internal */ this._role = 'progressbar'; /** @internal */ this._min = 0; /** @internal */ this._max = 1; /** @internal */ this._indeterminate = false; /** @internal */ this._reverse = false; this._progress = 0; this._buffer = 1; this._closed = false; this._elmBuffer = null; this._elmPrimaryBar = null; /** * Label indicationg how the progress bar should be announced to the user. * Determines the ària-label` attribute value. */ this.label = null; this.mdcAdapter = { addClass: (className) => { if (className !== CLASS_INDETERMINATE && className != CLASS_REVERSED) this._rndr.addClass(this._root.nativeElement, className); }, getPrimaryBar: () => this._elmPrimaryBar, getBuffer: () => this._elmBuffer, hasClass: (className) => { if (className === CLASS_INDETERMINATE) return this._indeterminate; if (className === CLASS_REVERSED) return this._reverse; return this._root.nativeElement.classList.contains(className); }, removeClass: (className) => { if (className !== CLASS_INDETERMINATE && className != CLASS_REVERSED) this._rndr.removeClass(this._root.nativeElement, className); }, setStyle: (el, styleProperty, value) => { this._rndr.setStyle(el, styleProperty, value); }, forceLayout: () => this._root.nativeElement.offsetWidth, removeAttribute: (name) => this._rndr.removeAttribute(this._root.nativeElement, name), setAttribute: (name, value) => this._rndr.setAttribute(this._root.nativeElement, name, value) }; this.foundation = null; } ngAfterContentInit() { this.initElements(); this.foundation = new MDCLinearProgressFoundation(this.mdcAdapter); this.foundation.init(); this.foundation.setProgress(this._progress); this.foundation.setBuffer(this._buffer); if (this._closed) this.foundation.close(); } ngOnDestroy() { var _a; (_a = this.foundation) === null || _a === void 0 ? void 0 : _a.destroy(); this._elmPrimaryBar = null; this._elmBuffer = null; } initElements() { this.addElement(this._root.nativeElement, 'div', ['mdc-linear-progress__buffering-dots']); this._elmBuffer = this.addElement(this._root.nativeElement, 'div', ['mdc-linear-progress__buffer']); this._elmPrimaryBar = this.addElement(this._root.nativeElement, 'div', ['mdc-linear-progress__bar', 'mdc-linear-progress__primary-bar']); this.addElement(this._elmPrimaryBar, 'span', ['mdc-linear-progress__bar-inner']); const secondaryBar = this.addElement(this._root.nativeElement, 'div', ['mdc-linear-progress__bar', 'mdc-linear-progress__secondary-bar']); this.addElement(secondaryBar, 'span', ['mdc-linear-progress__bar-inner']); } addElement(parent, element, classNames) { let child = this._rndr.createElement(element); classNames.forEach(name => { this._rndr.addClass(child, name); }); this._rndr.appendChild(parent, child); return child; } /** * Puts the progress indicator in 'indeterminate' state, signaling * that the exact progress on a measured task is not known. */ get indeterminate() { return this._indeterminate; } set indeterminate(value) { let newValue = asBoolean(value); if (newValue !== this._indeterminate) { this._indeterminate = newValue; if (this.foundation) { this.foundation.setDeterminate(!this._indeterminate); if (!this._indeterminate) { this.foundation.setProgress(this._progress); this.foundation.setBuffer(this._buffer); } } } } /** * Reverses the direction of the linear progress indicator. */ get reversed() { return this._reverse; } set reversed(value) { var _a; this._reverse = asBoolean(value); (_a = this.foundation) === null || _a === void 0 ? void 0 : _a.setReverse(this._reverse); } /** * Set the progress, the value should be between [0, 1]. */ get progressValue() { return this._progress; } set progressValue(value) { var _a; this._progress = +value; (_a = this.foundation) === null || _a === void 0 ? void 0 : _a.setProgress(this._progress); } /** * Set the buffer progress, the value should be between [0, 1]. */ get bufferValue() { return this._buffer; } set bufferValue(value) { var _a; this._buffer = +value; (_a = this.foundation) === null || _a === void 0 ? void 0 : _a.setBuffer(this._buffer); } /** * When set to true this closes (animates away) the progress bar, * when set to false this opens (animates into view) the progress bar. */ get closed() { return this._closed; } set closed(value) { var _a, _b; let newValue = asBoolean(value); if (newValue !== this._closed) { this._closed = newValue; if (newValue) (_a = this.foundation) === null || _a === void 0 ? void 0 : _a.close(); else (_b = this.foundation) === null || _b === void 0 ? void 0 : _b.open(); } } } MdcLinearProgressDirective.decorators = [ { type: Directive, args: [{ selector: '[mdcLinearProgress]' },] } ]; MdcLinearProgressDirective.ctorParameters = () => [ { type: Renderer2 }, { type: ElementRef } ]; MdcLinearProgressDirective.propDecorators = { _cls: [{ type: HostBinding, args: ['class.mdc-linear-progress',] }], _role: [{ type: HostBinding, args: ['attr.role',] }], _min: [{ type: HostBinding, args: ['attr.aria-valuemin',] }], _max: [{ type: HostBinding, args: ['attr.aria-valuemax',] }], _indeterminate: [{ type: HostBinding, args: ['class.' + CLASS_INDETERMINATE,] }], _reverse: [{ type: HostBinding, args: ['class.' + CLASS_REVERSED,] }], label: [{ type: HostBinding, args: ['attr.aria-label',] }, { type: Input }], indeterminate: [{ type: Input }, { type: HostBinding, args: ['class.' + CLASS_INDETERMINATE,] }], reversed: [{ type: Input }, { type: HostBinding, args: ['class.' + CLASS_REVERSED,] }], progressValue: [{ type: Input }], bufferValue: [{ type: Input }], closed: [{ type: Input }] }; export const LINEAR_PROGRESS_DIRECTIVES = [ MdcLinearProgressDirective ]; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mdc.linear-progress.directive.js","sourceRoot":"","sources":["../../../../src/components/linear-progress/mdc.linear-progress.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterContentInit, Directive, ElementRef, HostBinding, Input, OnDestroy, Renderer2 } from '@angular/core';\r\nimport { MDCLinearProgressFoundation, MDCLinearProgressAdapter } from '@material/linear-progress';\r\nimport { asBoolean } from '../../utils/value.utils';\r\n\r\nconst CLASS_INDETERMINATE = 'mdc-linear-progress--indeterminate';\r\nconst CLASS_REVERSED = 'mdc-linear-progress--reversed';\r\n\r\n/**\r\n * Directive for creating a Material Design linear progress indicator.\r\n * The current implementation will add and manage all DOM child elements that\r\n * are required for the wrapped <code>mdc-linear-progress</code> component.\r\n * Future implementations will also support supplying (customized)\r\n * DOM children.\r\n */\r\n@Directive({\r\n    selector: '[mdcLinearProgress]'\r\n})\r\nexport class MdcLinearProgressDirective implements AfterContentInit, OnDestroy {\r\n    /** @internal */\r\n    @HostBinding('class.mdc-linear-progress') readonly _cls = true;\r\n    /** @internal */\r\n    @HostBinding('attr.role') _role: string = 'progressbar';\r\n    /** @internal */\r\n    @HostBinding('attr.aria-valuemin') _min = 0;\r\n    /** @internal */\r\n    @HostBinding('attr.aria-valuemax') _max = 1;\r\n    /** @internal */\r\n    @HostBinding('class.' + CLASS_INDETERMINATE) _indeterminate = false;\r\n    /** @internal */\r\n    @HostBinding('class.' + CLASS_REVERSED) _reverse = false;\r\n    private _progress = 0;\r\n    private _buffer = 1;\r\n    private _closed = false;\r\n    private _elmBuffer: HTMLElement | null = null;\r\n    private _elmPrimaryBar: HTMLElement | null = null;\r\n    /**\r\n     * Label indicationg how the progress bar should be announced to the user.\r\n     * Determines the ària-label` attribute value.\r\n     */\r\n    @HostBinding('attr.aria-label') @Input() label: string | null = null;\r\n\r\n    private mdcAdapter: MDCLinearProgressAdapter = {\r\n        addClass: (className: string) => {\r\n            if (className !== CLASS_INDETERMINATE && className != CLASS_REVERSED)\r\n                this._rndr.addClass(this._root.nativeElement, className);\r\n        },\r\n        getPrimaryBar: () => this._elmPrimaryBar,\r\n        getBuffer: () => this._elmBuffer,\r\n        hasClass: (className: string) => {\r\n            if (className === CLASS_INDETERMINATE)\r\n                return this._indeterminate;\r\n            if (className === CLASS_REVERSED)\r\n                return this._reverse;\r\n            return this._root.nativeElement.classList.contains(className);\r\n        },\r\n        removeClass: (className: string) => {\r\n            if (className !== CLASS_INDETERMINATE && className != CLASS_REVERSED)\r\n                this._rndr.removeClass(this._root.nativeElement, className);\r\n        },\r\n        setStyle: (el, styleProperty, value) => {\r\n            this._rndr.setStyle(el, styleProperty, value);\r\n        },\r\n        forceLayout: () => this._root.nativeElement.offsetWidth,\r\n        removeAttribute: (name) => this._rndr.removeAttribute(this._root.nativeElement, name),\r\n        setAttribute: (name, value) => this._rndr.setAttribute(this._root.nativeElement, name, value)\r\n    };\r\n    private foundation: MDCLinearProgressFoundation | null = null;\r\n\r\n    constructor(private _rndr: Renderer2, private _root: ElementRef) {\r\n    }\r\n\r\n    ngAfterContentInit() {\r\n        this.initElements();\r\n        this.foundation = new MDCLinearProgressFoundation(this.mdcAdapter);\r\n        this.foundation.init();\r\n        this.foundation.setProgress(this._progress);\r\n        this.foundation.setBuffer(this._buffer);\r\n        if (this._closed)\r\n            this.foundation.close();\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        this.foundation?.destroy();\r\n        this._elmPrimaryBar = null;\r\n        this._elmBuffer = null;\r\n    }\r\n\r\n    private initElements() {\r\n        this.addElement(this._root.nativeElement, 'div', ['mdc-linear-progress__buffering-dots']);\r\n        this._elmBuffer = this.addElement(this._root.nativeElement, 'div', ['mdc-linear-progress__buffer']);\r\n        this._elmPrimaryBar = this.addElement(this._root.nativeElement, 'div', ['mdc-linear-progress__bar', 'mdc-linear-progress__primary-bar']);\r\n        this.addElement(this._elmPrimaryBar!, 'span', ['mdc-linear-progress__bar-inner']);\r\n        const secondaryBar = this.addElement(this._root.nativeElement, 'div', ['mdc-linear-progress__bar', 'mdc-linear-progress__secondary-bar']);\r\n        this.addElement(secondaryBar, 'span', ['mdc-linear-progress__bar-inner']);\r\n    }\r\n\r\n    private addElement(parent: HTMLElement, element: string, classNames: string[]) {\r\n        let child = this._rndr.createElement(element);\r\n        classNames.forEach(name => {\r\n            this._rndr.addClass(child, name);\r\n        });\r\n        this._rndr.appendChild(parent, child);\r\n        return child;\r\n    }\r\n\r\n    /**\r\n     * Puts the progress indicator in 'indeterminate' state, signaling\r\n     * that the exact progress on a measured task is not known.\r\n     */\r\n    @Input()\r\n    @HostBinding('class.' + CLASS_INDETERMINATE)\r\n    get indeterminate() {\r\n        return this._indeterminate;\r\n    }\r\n    \r\n    set indeterminate(value: boolean) {\r\n        let newValue = asBoolean(value);\r\n        if (newValue !== this._indeterminate) {\r\n            this._indeterminate = newValue;\r\n            if (this.foundation) {\r\n                this.foundation.setDeterminate(!this._indeterminate);\r\n                if (!this._indeterminate) {\r\n                    this.foundation.setProgress(this._progress);\r\n                    this.foundation.setBuffer(this._buffer);\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    static ngAcceptInputType_indeterminate: boolean | '';\r\n\r\n    /**\r\n     * Reverses the direction of the linear progress indicator.\r\n     */\r\n    @Input() @HostBinding('class.' + CLASS_REVERSED)\r\n    get reversed() {\r\n        return this._reverse;\r\n    }\r\n\r\n    set reversed(value: boolean) {\r\n        this._reverse = asBoolean(value);\r\n        this.foundation?.setReverse(this._reverse);\r\n    }\r\n\r\n    static ngAcceptInputType_reversed: boolean | '';\r\n\r\n    /**\r\n     * Set the progress, the value should be between [0, 1].\r\n     */\r\n    @Input()\r\n    get progressValue() {\r\n        return this._progress;\r\n    }\r\n\r\n    set progressValue(value: number) {\r\n        this._progress = +value;\r\n        this.foundation?.setProgress(this._progress);\r\n    }\r\n\r\n    static ngAcceptInputType_progressValue: number | string;\r\n\r\n    /**\r\n     * Set the buffer progress, the value should be between [0, 1].\r\n     */\r\n    @Input()\r\n    get bufferValue() {\r\n        return this._buffer;\r\n    }\r\n\r\n    set bufferValue(value: number) {\r\n        this._buffer = +value;\r\n        this.foundation?.setBuffer(this._buffer);\r\n    }\r\n\r\n    static ngAcceptInputType_bufferValue: number | string;\r\n\r\n    /**\r\n     * When set to true this closes (animates away) the progress bar,\r\n     * when set to false this opens (animates into view) the progress bar.\r\n     */\r\n    @Input()\r\n    get closed() {\r\n        return this._closed;\r\n    }\r\n\r\n    set closed(value: boolean) {\r\n        let newValue = asBoolean(value);\r\n        if (newValue !== this._closed) {\r\n            this._closed = newValue;\r\n            if (newValue)\r\n                this.foundation?.close();\r\n            else\r\n                this.foundation?.open();\r\n        }\r\n    }\r\n\r\n    static ngAcceptInputType_closed: boolean | '';\r\n}\r\n\r\nexport const LINEAR_PROGRESS_DIRECTIVES = [\r\n    MdcLinearProgressDirective\r\n];\r\n"]}