UNPKG

@js-sugar/angular

Version:

JS-Sugar core package (Angular)

195 lines 26.9 kB
import { Input, Component, Output, EventEmitter, HostBinding } from '@angular/core'; import { PanelBackdropComponent } from './panel-backdrop.component'; import { trigger, state, style, transition } from '@angular/animations'; import { SIDENAV_ANIMATE } from './animation'; import * as i0 from "@angular/core"; import * as i1 from "./panels.component"; import * as i2 from "@angular/cdk/bidi"; export class PanelComponent { constructor(elementRef, _parent, _renderer, _viewRef, _dir) { this.elementRef = elementRef; this._parent = _parent; this._renderer = _renderer; this._viewRef = _viewRef; this._dir = _dir; this._backdrop = false; this._animationState = false; this.position = 'start'; this.placement = 'container'; this.stretch = 'both'; this.show = true; this.size = 200; this.over = true; this.zOrder = 1; this.backdropClick = new EventEmitter(); } set backdrop(value) { if (value === this._backdrop) { return; } if (value) { const compRef = this._viewRef.createComponent(PanelBackdropComponent); this._renderer.setStyle(compRef.instance.elementRef.nativeElement, 'z-index', this.zOrder * 2 - 1); this._backdropUnlistenFunc = this._renderer.listen(compRef.instance.elementRef.nativeElement, 'click', (e) => { this.backdropClick.emit(this); }); } else { this._viewRef.clear(); } this._backdrop = value; } get backdrop() { return this._backdrop; } ngOnChanges(changes) { const change = changes['position'] || changes['stretch'] || changes['size'] || changes['show'] || changes['over']; if (change && !change.isFirstChange()) { this._parent.refresh(); this._animationState = !this._animationState; } } get _zIndex() { return this.zOrder * 2; } get _position() { return this.placement === 'container' ? 'absolute' : 'fixed'; } get _animationTrigger() { const ltr = this._dir.value === 'ltr'; const contentPos = this._parent.contentPosition; const isStretchNoneOrStart = this.stretch === 'none' || this.stretch === 'start'; const isStretchNone = this.stretch === 'none'; const isStretchStart = this.stretch === 'start'; const isStretchEnd = this.stretch === 'end'; const isStretchNoneOrEnd = isStretchNone || isStretchEnd; const isStretchBoth = this.stretch === 'both'; let params; switch (this.position) { case 'start': params = { top: isStretchNoneOrEnd ? `${contentPos?.top}px` : '0', bottom: isStretchNoneOrStart ? `${contentPos?.bottom}px` : '0', left: ltr ? '0' : '', right: ltr ? '' : '0', hideTransform: `translateX(${ltr ? -100 : 100}%)`, }; break; case 'end': params = { top: isStretchNoneOrEnd ? `${contentPos?.top}px` : '0', bottom: isStretchNoneOrStart ? `${contentPos?.bottom}px` : '0', left: ltr ? '' : '0', right: ltr ? '0' : '', hideTransform: `translateX(${ltr ? 100 : -100}%)`, }; break; case 'top': params = { top: '0', bottom: '', left: isStretchBoth || (isStretchStart && ltr) || (isStretchEnd && !ltr) ? '0' : `${contentPos?.left}px`, right: isStretchBoth || (isStretchEnd && ltr) || (isStretchStart && !ltr) ? '0' : `${contentPos?.right}px`, hideTransform: 'translateY(-100%)', }; break; case 'bottom': params = { top: '', bottom: '0', left: isStretchBoth || (isStretchStart && ltr) || (isStretchEnd && !ltr) ? '0' : `${contentPos?.left}px`, right: isStretchBoth || (isStretchEnd && ltr) || (isStretchStart && !ltr) ? '0' : `${contentPos?.right}px`, hideTransform: 'translateY(100%)', }; break; default: throw Error('Invalid position'); } return { value: this._animationState, params: { ...params, transform: this.show ? 'translate(0,0)' : params.hideTransform, } }; } ngOnDestroy() { if (this._backdropUnlistenFunc) { this._backdropUnlistenFunc(); } } } PanelComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: PanelComponent, deps: [{ token: i0.ElementRef }, { token: i1.PanelsComponent }, { token: i0.Renderer2 }, { token: i0.ViewContainerRef }, { token: i2.Directionality }], target: i0.ɵɵFactoryTarget.Component }); PanelComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.1", type: PanelComponent, selector: "jss-panel", inputs: { position: "position", placement: "placement", stretch: "stretch", show: "show", size: "size", over: "over", zOrder: "zOrder", backdrop: "backdrop" }, outputs: { backdropClick: "backdropClick" }, host: { properties: { "style.z-index": "this._zIndex", "style.position": "this._position", "@t": "this._animationTrigger" } }, exportAs: ["jssPanel"], usesOnChanges: true, ngImport: i0, template: "<ng-content></ng-content>", styles: [":host{display:block;position:absolute}\n"], animations: [ trigger('t', [ state('0', style({ left: '{{left}}', right: '{{right}}', top: '{{top}}', bottom: '{{bottom}}', transform: '{{transform}}' }), { params: { left: '', right: '', top: '', bottom: '', transform: '' } }), state('1', style({ left: '{{left}}', right: '{{right}}', top: '{{top}}', bottom: '{{bottom}}', transform: '{{transform}}' }), { params: { left: '', right: '', top: '', bottom: '', transform: '' } }), transition('0 <=> 1', [ SIDENAV_ANIMATE, ]) ]), ] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: PanelComponent, decorators: [{ type: Component, args: [{ selector: 'jss-panel', exportAs: 'jssPanel', animations: [ trigger('t', [ state('0', style({ left: '{{left}}', right: '{{right}}', top: '{{top}}', bottom: '{{bottom}}', transform: '{{transform}}' }), { params: { left: '', right: '', top: '', bottom: '', transform: '' } }), state('1', style({ left: '{{left}}', right: '{{right}}', top: '{{top}}', bottom: '{{bottom}}', transform: '{{transform}}' }), { params: { left: '', right: '', top: '', bottom: '', transform: '' } }), transition('0 <=> 1', [ SIDENAV_ANIMATE, ]) ]), ], template: "<ng-content></ng-content>", styles: [":host{display:block;position:absolute}\n"] }] }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.PanelsComponent }, { type: i0.Renderer2 }, { type: i0.ViewContainerRef }, { type: i2.Directionality }]; }, propDecorators: { position: [{ type: Input }], placement: [{ type: Input }], stretch: [{ type: Input }], show: [{ type: Input }], size: [{ type: Input }], over: [{ type: Input }], zOrder: [{ type: Input }], backdrop: [{ type: Input }], backdropClick: [{ type: Output }], _zIndex: [{ type: HostBinding, args: ['style.z-index'] }], _position: [{ type: HostBinding, args: ['style.position'] }], _animationTrigger: [{ type: HostBinding, args: ['@t'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"panel.component.js","sourceRoot":"","sources":["../../../../../../projects/angular/src/lib/components/panels/panel.component.ts","../../../../../../projects/angular/src/lib/components/panels/panel.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Input, Component, Output, EventEmitter, Renderer2, ElementRef, ComponentFactoryResolver,\r\n    ViewContainerRef, OnDestroy, HostBinding, OnChanges, SimpleChanges\r\n} from '@angular/core';\r\nimport { PanelBackdropComponent } from './panel-backdrop.component';\r\nimport { PanelPlacement, PanelPosition, PanelStretch } from './types';\r\nimport { trigger, state, style, transition } from '@angular/animations';\r\nimport { Directionality } from '@angular/cdk/bidi';\r\nimport { SIDENAV_ANIMATE } from './animation';\r\nimport { PanelsComponent } from './panels.component';\r\n\r\n@Component({\r\n    selector: 'jss-panel',\r\n    exportAs: 'jssPanel',\r\n    styleUrls: ['./panel.component.scss'],\r\n    templateUrl: 'panel.component.html',\r\n    animations: [\r\n        trigger('t', [\r\n            state('0', style({\r\n                left: '{{left}}',\r\n                right: '{{right}}',\r\n                top: '{{top}}',\r\n                bottom: '{{bottom}}',\r\n                transform: '{{transform}}'\r\n            }), { params: { left: '', right: '', top: '', bottom: '', transform: '' } }),\r\n            state('1', style({\r\n                left: '{{left}}',\r\n                right: '{{right}}',\r\n                top: '{{top}}',\r\n                bottom: '{{bottom}}',\r\n                transform: '{{transform}}'\r\n            }), { params: { left: '', right: '', top: '', bottom: '', transform: '' } }),\r\n            transition('0 <=> 1', [\r\n                SIDENAV_ANIMATE,\r\n            ])\r\n        ]),\r\n    ]\r\n})\r\nexport class PanelComponent implements OnChanges, OnDestroy {\r\n    private _backdrop = false;\r\n    private _backdropUnlistenFunc?: () => void;\r\n    private _animationState = false;\r\n    @Input() position: PanelPosition = 'start';\r\n    @Input() placement: PanelPlacement = 'container';\r\n    @Input() stretch: PanelStretch = 'both';\r\n    @Input() show = true;\r\n    @Input() size = 200;\r\n    @Input() over = true;\r\n    @Input() zOrder = 1;\r\n    @Input() set backdrop(value: boolean) {\r\n        if (value === this._backdrop) { return; }\r\n        if (value) {\r\n            const compRef = this._viewRef.createComponent<PanelBackdropComponent>(PanelBackdropComponent);\r\n            this._renderer.setStyle(compRef.instance.elementRef.nativeElement, 'z-index', this.zOrder * 2 - 1);\r\n            this._backdropUnlistenFunc = this._renderer.listen(compRef.instance.elementRef.nativeElement, 'click', (e) => {\r\n                this.backdropClick.emit(this);\r\n            });\r\n        } else {\r\n            this._viewRef.clear();\r\n        }\r\n        this._backdrop = value;\r\n    }\r\n\r\n    get backdrop(): boolean {\r\n        return this._backdrop;\r\n    }\r\n    \r\n    @Output() backdropClick = new EventEmitter<PanelComponent>();\r\n\r\n    constructor(\r\n        public elementRef: ElementRef,\r\n        private _parent: PanelsComponent,\r\n        private _renderer: Renderer2,\r\n        private _viewRef: ViewContainerRef,\r\n        private _dir: Directionality,\r\n    ) {\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        const change = changes['position'] || changes['stretch'] || changes['size'] || changes['show'] || changes['over'];\r\n        if (change && !change.isFirstChange()) {\r\n            this._parent.refresh();\r\n            this._animationState = !this._animationState;\r\n        }\r\n    }\r\n\r\n    @HostBinding('style.z-index') private get _zIndex() {\r\n        return this.zOrder * 2;\r\n    }\r\n\r\n    @HostBinding('style.position') private get _position() {\r\n        return this.placement === 'container' ? 'absolute' : 'fixed';\r\n    }\r\n\r\n    @HostBinding('@t') private get _animationTrigger() {\r\n        const ltr = this._dir.value === 'ltr';\r\n        const contentPos = this._parent.contentPosition;\r\n        const isStretchNoneOrStart = this.stretch === 'none' || this.stretch === 'start';\r\n        const isStretchNone = this.stretch === 'none';\r\n        const isStretchStart = this.stretch === 'start';\r\n        const isStretchEnd = this.stretch === 'end';\r\n        const isStretchNoneOrEnd = isStretchNone || isStretchEnd;\r\n        const isStretchBoth = this.stretch === 'both';\r\n        let params: { top: string, bottom: string, left: string, right: string, hideTransform: string };\r\n\r\n        switch (this.position) {\r\n            case 'start':\r\n                params = {\r\n                    top: isStretchNoneOrEnd ? `${contentPos?.top}px` : '0',\r\n                    bottom: isStretchNoneOrStart ? `${contentPos?.bottom}px` : '0',\r\n                    left: ltr ? '0' : '',\r\n                    right: ltr ? '' : '0',\r\n                    hideTransform: `translateX(${ltr ? -100 : 100}%)`,\r\n                };\r\n                break;\r\n            case 'end':\r\n                params = {\r\n                    top: isStretchNoneOrEnd ? `${contentPos?.top}px` : '0',\r\n                    bottom: isStretchNoneOrStart ? `${contentPos?.bottom}px` : '0',\r\n                    left: ltr ? '' : '0',\r\n                    right: ltr ? '0' : '',\r\n                    hideTransform: `translateX(${ltr ? 100 : -100}%)`,\r\n                };\r\n                break;\r\n            case 'top':\r\n                params = {\r\n                    top: '0',\r\n                    bottom: '',\r\n                    left: isStretchBoth || (isStretchStart && ltr) || (isStretchEnd && !ltr) ? '0' : `${contentPos?.left}px`,\r\n                    right: isStretchBoth || (isStretchEnd && ltr) || (isStretchStart && !ltr) ? '0' : `${contentPos?.right}px`,\r\n                    hideTransform: 'translateY(-100%)',\r\n                };\r\n                break;\r\n            case 'bottom':\r\n                params = {\r\n                    top: '',\r\n                    bottom: '0',\r\n                    left: isStretchBoth || (isStretchStart && ltr) || (isStretchEnd && !ltr) ? '0' : `${contentPos?.left}px`,\r\n                    right: isStretchBoth || (isStretchEnd && ltr) || (isStretchStart && !ltr) ? '0' : `${contentPos?.right}px`,\r\n                    hideTransform: 'translateY(100%)',\r\n                };\r\n                break;\r\n            default:\r\n                throw Error('Invalid position');\r\n        }\r\n\r\n        return {\r\n            value: this._animationState,\r\n            params: {\r\n                ...params,\r\n                transform: this.show ? 'translate(0,0)' : params.hideTransform,\r\n            }\r\n        };\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        if (this._backdropUnlistenFunc) {\r\n            this._backdropUnlistenFunc();\r\n        }\r\n    }\r\n}\r\n","<ng-content></ng-content>"]}