@js-sugar/angular
Version:
JS-Sugar core package (Angular)
195 lines • 26.9 kB
JavaScript
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>"]}