@js-sugar/angular
Version:
JS-Sugar core package (Angular)
99 lines • 14.6 kB
JavaScript
import { isPlatformBrowser } from '@angular/common';
import { Component, ContentChildren, EventEmitter, Inject, Output, PLATFORM_ID } from '@angular/core';
import { PanelComponent } from './panel.component';
import { state, style, transition, trigger } from '@angular/animations';
import { SIDENAV_ANIMATE } from './animation';
import * as i0 from "@angular/core";
import * as i1 from "@angular/cdk/bidi";
export class PanelsComponent {
constructor(_dir, _platformId) {
this._dir = _dir;
this.layoutChange = new EventEmitter();
this._animationState = false;
this._contentPosition = { top: 0, bottom: 0, left: 0, right: 0 };
this._isBrowser = isPlatformBrowser(_platformId);
this._isRtl = this._dir.value === 'rtl';
}
get contentPosition() {
return this._contentPosition;
}
ngAfterContentInit() {
this.refresh();
}
refresh() {
this.computeContentPosition();
this._animationState = !this._animationState;
}
computeContentPosition() {
if (this._isBrowser) {
const fixedPanels = this._panels.filter(p => p.show && !p.over);
const max = (items) => items.length === 0 ? 0 : Math.max(...items);
const getPositionSizes = (position) => fixedPanels
.filter(p => p.position === position)
.map(p => position === 'start' || position === 'end' ? p.elementRef.nativeElement.clientWidth : p.elementRef.nativeElement.clientHeight);
const positions = ['start', 'end', 'top', 'bottom'];
var paddings = positions.map(pos => max(getPositionSizes(pos)));
this._contentPosition = {
left: this._isRtl ? paddings[1] : paddings[0],
right: this._isRtl ? paddings[0] : paddings[1],
top: paddings[2],
bottom: paddings[3],
};
}
else {
this._contentPosition = { top: 0, right: 0, bottom: 0, left: 0 };
}
}
get _animationTrigger() {
const { bottom, left, top, right } = this._contentPosition;
return {
value: this._animationState,
params: {
padding: `${top}px ${right}px ${bottom}px ${left}px`,
}
};
}
}
PanelsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: PanelsComponent, deps: [{ token: i1.Directionality }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Component });
PanelsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.1", type: PanelsComponent, selector: "jss-panels", outputs: { layoutChange: "layoutChange" }, queries: [{ propertyName: "_panels", predicate: PanelComponent }], exportAs: ["jssPanels"], ngImport: i0, template: "<ng-content select=\"jss-panel\"></ng-content>\r\n<div class=\"jss-panels-content\" [@t]=\"_animationTrigger\">\r\n <ng-content></ng-content>\r\n</div>", styles: [":host{display:block;position:relative;overflow:hidden}\n"], animations: [
trigger('t', [
state('0', style({
padding: '{{padding}}',
height: '100%'
}), { params: { padding: '' } }),
state('1', style({
padding: '{{padding}}',
height: '100%'
}), { params: { padding: '' } }),
transition('0 <=> 1', [
SIDENAV_ANIMATE,
])
]),
] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.1", ngImport: i0, type: PanelsComponent, decorators: [{
type: Component,
args: [{ selector: 'jss-panels', exportAs: 'jssPanels', animations: [
trigger('t', [
state('0', style({
padding: '{{padding}}',
height: '100%'
}), { params: { padding: '' } }),
state('1', style({
padding: '{{padding}}',
height: '100%'
}), { params: { padding: '' } }),
transition('0 <=> 1', [
SIDENAV_ANIMATE,
])
]),
], template: "<ng-content select=\"jss-panel\"></ng-content>\r\n<div class=\"jss-panels-content\" [@t]=\"_animationTrigger\">\r\n <ng-content></ng-content>\r\n</div>", styles: [":host{display:block;position:relative;overflow:hidden}\n"] }]
}], ctorParameters: function () { return [{ type: i1.Directionality }, { type: undefined, decorators: [{
type: Inject,
args: [PLATFORM_ID]
}] }]; }, propDecorators: { layoutChange: [{
type: Output
}], _panels: [{
type: ContentChildren,
args: [PanelComponent]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"panels.component.js","sourceRoot":"","sources":["../../../../../../projects/angular/src/lib/components/panels/panels.component.ts","../../../../../../projects/angular/src/lib/components/panels/panels.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Directionality } from '@angular/cdk/bidi';\r\nimport { isPlatformBrowser } from '@angular/common';\r\nimport {\r\n  AfterContentInit, Component, ContentChildren, EventEmitter, Inject, Input, Output, PLATFORM_ID, QueryList\r\n} from '@angular/core';\r\nimport { PanelPosition, PanelsContentPosition } from './types';\r\nimport { PanelComponent } from './panel.component';\r\nimport { state, style, transition, trigger } from '@angular/animations';\r\nimport { SIDENAV_ANIMATE } from './animation';\r\n\r\n@Component({\r\n  selector: 'jss-panels',\r\n  exportAs: 'jssPanels',\r\n  templateUrl: './panels.component.html',\r\n  styleUrls: ['./panels.component.scss'],\r\n  animations: [\r\n    trigger('t', [\r\n      state('0', style({\r\n        padding: '{{padding}}',\r\n        height: '100%'\r\n      }), { params: { padding: '' } }),\r\n      state('1', style({\r\n        padding: '{{padding}}',\r\n        height: '100%'\r\n      }), { params: { padding: '' } }),\r\n      transition('0 <=> 1', [\r\n        SIDENAV_ANIMATE,\r\n      ])\r\n    ]),\r\n  ]\r\n})\r\nexport class PanelsComponent implements AfterContentInit {\r\n  @Output() layoutChange = new EventEmitter<PanelsContentPosition>();\r\n  @ContentChildren(PanelComponent) private _panels!: QueryList<PanelComponent>;\r\n  private _isBrowser: boolean;\r\n  private _isRtl: boolean;\r\n  private _animationState = false;\r\n  private _contentPosition: PanelsContentPosition = { top: 0, bottom: 0, left: 0, right: 0 };\r\n  public get contentPosition(): PanelsContentPosition {\r\n    return this._contentPosition;\r\n  }\r\n\r\n  constructor(\r\n    private _dir: Directionality,\r\n    @Inject(PLATFORM_ID) _platformId: any) {\r\n\r\n    this._isBrowser = isPlatformBrowser(_platformId);\r\n    this._isRtl = this._dir.value === 'rtl';\r\n  }\r\n\r\n  ngAfterContentInit(): void {\r\n    this.refresh();\r\n  }\r\n\r\n  public refresh() {\r\n    this.computeContentPosition();\r\n    this._animationState = !this._animationState;\r\n  }\r\n\r\n  private computeContentPosition() {\r\n    if (this._isBrowser) {\r\n      const fixedPanels = this._panels.filter(p => p.show && !p.over);\r\n      const max = (items: number[]) => items.length === 0 ? 0 : Math.max(...items);\r\n      const getPositionSizes = (position: PanelPosition): number[] => fixedPanels\r\n          .filter(p => p.position === position)\r\n          .map(p => position === 'start' || position === 'end' ? p.elementRef.nativeElement.clientWidth : p.elementRef.nativeElement.clientHeight);\r\n\r\n      const positions: PanelPosition[] = ['start', 'end', 'top', 'bottom'];\r\n      var paddings = positions.map(pos => max(getPositionSizes(pos)));\r\n      this._contentPosition = {\r\n        left: this._isRtl ? paddings[1] : paddings[0],\r\n        right: this._isRtl ? paddings[0] : paddings[1],\r\n        top: paddings[2],\r\n        bottom: paddings[3],\r\n      };\r\n    } else {\r\n      this._contentPosition = { top: 0, right: 0, bottom: 0, left: 0 };\r\n    }\r\n  }\r\n\r\n  get _animationTrigger() {\r\n    const { bottom, left, top, right } = this._contentPosition;\r\n    return {\r\n      value: this._animationState,\r\n      params: {\r\n        padding: `${top}px ${right}px ${bottom}px ${left}px`,\r\n      }\r\n    };\r\n  }\r\n}\r\n","<ng-content select=\"jss-panel\"></ng-content>\r\n<div class=\"jss-panels-content\" [@t]=\"_animationTrigger\">\r\n        <ng-content></ng-content>\r\n</div>"]}