UNPKG

jsim-lazy-expandable

Version:

Light weight and easy to use expansion panel with lazy loaded content.

142 lines 23.5 kB
import { Component, ContentChild, EventEmitter, Input, Output, ViewChild } from '@angular/core'; import { LazyContentDirective } from './lazy-content.directive'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; export class LazyExpandableComponent { constructor() { /** Is the panel open? */ this.isOpen = false; /** Event emitted when isOpen changes */ this.openChanged = new EventEmitter(); /** Hide the arrow icon */ this.hideIcon = false; /** Height of the header when collapsed (in pixels) */ this.headerHeight = 48; /** Height of the header when expanded (in pixels) */ this.headerHeightExpanded = 64; /** Speed of the expand and collapse animation (in pixel by milisecond) */ this.animationSpeed = 0.5; /** Event emitted when animation ends */ this.animationEnd = new EventEmitter(); /** Is expanding and collapsing disabled? */ this.disabled = false; this.headerHeightStyle = this.headerHeight + 'px'; this.contentHeight = this.headerHeight + 'px'; this.currentContentHeight = 0; this.desiredContentHeight = 0; this.timeLastFrame = Date.now(); this.animationDuration = 0; this.currentAnimationTime = 0; this.lerp = (x, y, a) => x * (1 - a) + y * a; } ngOnInit() { } ngAfterContentInit() { setTimeout(() => { this.setContentHeight(false); if (this.isOpen && this.directive) { this.directive.showContent(); } }, 0); } toggleOpen() { if (this.disabled) { return; } this.isOpen = !this.isOpen; if (this.isOpen && this.directive) { this.directive.showContent(); } this.openChanged.emit(this.isOpen); this.setContentHeight(); } setContentHeight(animate = true) { if (animate) { if (this.isOpen) { this.headerHeightStyle = this.headerHeightExpanded + 'px'; this.desiredContentHeight = this.content.nativeElement.clientHeight; this.currentContentHeight = 0; } else { this.headerHeightStyle = this.headerHeight + 'px'; this.desiredContentHeight = 0; this.currentContentHeight = this.content.nativeElement.clientHeight; } this.animationDuration = Math.abs(this.desiredContentHeight - this.currentContentHeight) / this.animationSpeed; this.startAnimation(); } else { if (this.isOpen) { this.headerHeightStyle = this.headerHeightExpanded + 'px'; this.contentHeight = 'unset'; } else { this.headerHeightStyle = this.headerHeight + 'px'; this.contentHeight = this.headerHeight + 'px'; } } } startAnimation() { this.timeLastFrame = Date.now(); this.currentAnimationTime = 0; if (this.animationFrameRef) { cancelAnimationFrame(this.animationFrameRef); } this.animationFrameRef = requestAnimationFrame(this.animateHeader.bind(this)); } animateHeader() { const time = Date.now(); const deltatime = time - this.timeLastFrame; this.timeLastFrame = time; this.currentAnimationTime += deltatime; const amount = this.currentAnimationTime / this.animationDuration; this.currentContentHeight = this.lerp(this.currentContentHeight, this.desiredContentHeight, amount); if (this.isOpen) { this.currentContentHeight = Math.min(this.currentContentHeight, this.desiredContentHeight); this.contentHeight = this.headerHeightExpanded + this.currentContentHeight + 'px'; } else { this.currentContentHeight = Math.max(this.currentContentHeight, this.desiredContentHeight); this.contentHeight = this.headerHeight + this.currentContentHeight + 'px'; } if (this.currentContentHeight == this.desiredContentHeight) { this.animationEnded(); return; } this.animationFrameRef = requestAnimationFrame(this.animateHeader.bind(this)); } animationEnded() { this.animationEnd.emit(this.isOpen); if (this.isOpen) { this.contentHeight = 'unset'; } } } LazyExpandableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: LazyExpandableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); LazyExpandableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.7", type: LazyExpandableComponent, selector: "jsim-lazy-expandable", inputs: { isOpen: "isOpen", hideIcon: "hideIcon", headerHeight: "headerHeight", headerHeightExpanded: "headerHeightExpanded", animationSpeed: "animationSpeed", disabled: "disabled" }, outputs: { openChanged: "openChanged", animationEnd: "animationEnd" }, queries: [{ propertyName: "directive", first: true, predicate: LazyContentDirective, descendants: true }], viewQueries: [{ propertyName: "content", first: true, predicate: ["lazyContent"], descendants: true }], ngImport: i0, template: "<div class=\"lazy-exp-container\" [class.is-open]=\"isOpen\" [style.height]=\"contentHeight\" [class.disabled]=\"disabled\">\n <div class=\"lazy-exp-header\" (click)=\"toggleOpen()\" [style.height]=\"headerHeightStyle\">\n <div class=\"lazy-exp-header-title\">\n <ng-content select=\"[exp-header-title]\"></ng-content>\n </div>\n <div class=\"lazy-exp-header-subtitle\">\n <ng-content select=\"[exp-header-subtitle]\"></ng-content>\n </div>\n <div *ngIf=\"!hideIcon\" class=\"lazy-exp-header-icon\"></div>\n </div>\n <div #lazyContent class=\"lazy-exp-content\">\n <div class=\"lazy-exp-content-container\">\n <ng-content select=\"[exp-content]\"></ng-content>\n </div>\n </div>\n</div>\n", styles: [".lazy-exp-container{--background-color: white;--background-color-hover: rgba(0,0,0,.04);--icon-color: rgb(119, 119, 119);border-radius:4px;box-shadow:0 3px 1px -2px #0003,0 2px 2px #00000024,0 1px 5px #0000001f;background-color:var(--background-color);overflow:hidden}.lazy-exp-header{display:flex;align-items:center;cursor:pointer;transition:height 225ms cubic-bezier(.4,0,.2,1)}.lazy-exp-container:not(.is-open):not(.disabled) .lazy-exp-header:hover{background-color:var(--background-color-hover)}.lazy-exp-container.disabled .lazy-exp-header{cursor:not-allowed}.lazy-exp-header-title{margin-left:1rem;width:50%}.lazy-exp-header-subtitle{width:50%;color:#2e2e2e}.lazy-exp-header-icon{justify-self:flex-end;margin-right:1rem;transform:rotate(0);transition:transform .2s ease-out}.is-open .lazy-exp-header-icon{transform:rotate(180deg)}.lazy-exp-header-icon:after{border-color:var(--icon-color);border-style:solid;border-width:0 2px 2px 0;content:\"\";display:inline-block;padding:3px;transform:rotate(45deg);vertical-align:middle}.lazy-exp-content{box-sizing:border-box;padding:1rem}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: LazyExpandableComponent, decorators: [{ type: Component, args: [{ selector: 'jsim-lazy-expandable', template: "<div class=\"lazy-exp-container\" [class.is-open]=\"isOpen\" [style.height]=\"contentHeight\" [class.disabled]=\"disabled\">\n <div class=\"lazy-exp-header\" (click)=\"toggleOpen()\" [style.height]=\"headerHeightStyle\">\n <div class=\"lazy-exp-header-title\">\n <ng-content select=\"[exp-header-title]\"></ng-content>\n </div>\n <div class=\"lazy-exp-header-subtitle\">\n <ng-content select=\"[exp-header-subtitle]\"></ng-content>\n </div>\n <div *ngIf=\"!hideIcon\" class=\"lazy-exp-header-icon\"></div>\n </div>\n <div #lazyContent class=\"lazy-exp-content\">\n <div class=\"lazy-exp-content-container\">\n <ng-content select=\"[exp-content]\"></ng-content>\n </div>\n </div>\n</div>\n", styles: [".lazy-exp-container{--background-color: white;--background-color-hover: rgba(0,0,0,.04);--icon-color: rgb(119, 119, 119);border-radius:4px;box-shadow:0 3px 1px -2px #0003,0 2px 2px #00000024,0 1px 5px #0000001f;background-color:var(--background-color);overflow:hidden}.lazy-exp-header{display:flex;align-items:center;cursor:pointer;transition:height 225ms cubic-bezier(.4,0,.2,1)}.lazy-exp-container:not(.is-open):not(.disabled) .lazy-exp-header:hover{background-color:var(--background-color-hover)}.lazy-exp-container.disabled .lazy-exp-header{cursor:not-allowed}.lazy-exp-header-title{margin-left:1rem;width:50%}.lazy-exp-header-subtitle{width:50%;color:#2e2e2e}.lazy-exp-header-icon{justify-self:flex-end;margin-right:1rem;transform:rotate(0);transition:transform .2s ease-out}.is-open .lazy-exp-header-icon{transform:rotate(180deg)}.lazy-exp-header-icon:after{border-color:var(--icon-color);border-style:solid;border-width:0 2px 2px 0;content:\"\";display:inline-block;padding:3px;transform:rotate(45deg);vertical-align:middle}.lazy-exp-content{box-sizing:border-box;padding:1rem}\n"] }] }], ctorParameters: function () { return []; }, propDecorators: { isOpen: [{ type: Input }], openChanged: [{ type: Output }], hideIcon: [{ type: Input }], headerHeight: [{ type: Input }], headerHeightExpanded: [{ type: Input }], animationSpeed: [{ type: Input }], animationEnd: [{ type: Output }], disabled: [{ type: Input }], content: [{ type: ViewChild, args: ['lazyContent'] }], directive: [{ type: ContentChild, args: [LazyContentDirective] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lazy-expandable.component.js","sourceRoot":"","sources":["../../../../projects/jsim-lazy-expandable/src/lib/lazy-expandable.component.ts","../../../../projects/jsim-lazy-expandable/src/lib/lazy-expandable.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterContentInit, Component, ContentChild, ElementRef, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';\nimport { LazyContentDirective } from './lazy-content.directive';\n\n@Component({\n  selector: 'jsim-lazy-expandable',\n  templateUrl: './lazy-expandable.component.html',\n  styleUrls: ['./lazy-expandable.component.css']\n})\nexport class LazyExpandableComponent implements OnInit, AfterContentInit {\n\n  /** Is the panel open? */\n  @Input() isOpen: boolean = false;\n\n  /** Event emitted when isOpen changes */\n  @Output() openChanged = new EventEmitter<boolean>();\n\n  /** Hide the arrow icon */\n  @Input() hideIcon: boolean = false;\n\n  /** Height of the header when collapsed (in pixels) */\n  @Input() headerHeight: number = 48;\n\n  /** Height of the header when expanded (in pixels) */\n  @Input() headerHeightExpanded: number = 64;\n\n  /** Speed of the expand and collapse animation (in pixel by milisecond) */\n  @Input() animationSpeed: number = 0.5;\n\n  /** Event emitted when animation ends */\n  @Output() animationEnd = new EventEmitter<boolean>();\n\n  /** Is expanding and collapsing disabled? */\n  @Input() disabled: boolean = false;\n\n  @ViewChild('lazyContent') content: ElementRef | undefined;\n\n  @ContentChild(LazyContentDirective) directive: LazyContentDirective | undefined;\n\n  headerHeightStyle: string = this.headerHeight + 'px';\n  contentHeight: string =  this.headerHeight + 'px';\n\n  private currentContentHeight: number = 0;\n  private desiredContentHeight: number = 0;\n  private timeLastFrame: number = Date.now();\n  private animationDuration: number = 0;\n  private currentAnimationTime: number = 0;\n\n  private animationFrameRef: number | undefined;\n\n  constructor() {}\n\n  ngOnInit(): void {}\n\n  ngAfterContentInit(): void {\n    setTimeout(() => {\n      this.setContentHeight(false);\n      if(this.isOpen && this.directive){\n        this.directive.showContent();\n      }\n    }, 0);\n  }\n\n  toggleOpen(){\n    if(this.disabled){\n      return;\n    }\n\n    this.isOpen = !this.isOpen;\n\n    if(this.isOpen && this.directive){\n      this.directive.showContent();\n    }\n\n    this.openChanged.emit(this.isOpen);\n    this.setContentHeight();\n  }\n\n  private setContentHeight(animate: boolean = true){\n    if(animate){\n      if(this.isOpen){\n        this.headerHeightStyle = this.headerHeightExpanded + 'px';\n        this.desiredContentHeight = this.content!.nativeElement.clientHeight;\n        this.currentContentHeight = 0;\n      } else {\n        this.headerHeightStyle = this.headerHeight + 'px';\n        this.desiredContentHeight = 0;\n        this.currentContentHeight = this.content!.nativeElement.clientHeight;\n      }\n      this.animationDuration = Math.abs(this.desiredContentHeight - this.currentContentHeight) / this.animationSpeed;\n      this.startAnimation();\n    } else {\n      if(this.isOpen){\n        this.headerHeightStyle = this.headerHeightExpanded + 'px';\n        this.contentHeight = 'unset';\n      } else {\n        this.headerHeightStyle = this.headerHeight + 'px';\n        this.contentHeight = this.headerHeight + 'px';\n      }\n    }\n  }\n\n  private startAnimation(){\n    this.timeLastFrame = Date.now();\n    this.currentAnimationTime = 0;\n    if(this.animationFrameRef){\n      cancelAnimationFrame(this.animationFrameRef);\n    }\n    this.animationFrameRef = requestAnimationFrame(this.animateHeader.bind(this));\n  }\n\n  private animateHeader() {\n    const time = Date.now();\n    const deltatime = time - this.timeLastFrame;\n    this.timeLastFrame = time;\n    this.currentAnimationTime += deltatime;\n\n    const amount = this.currentAnimationTime / this.animationDuration;\n\n    this.currentContentHeight = this.lerp(this.currentContentHeight, this.desiredContentHeight, amount);\n\n    if(this.isOpen){\n      this.currentContentHeight = Math.min(this.currentContentHeight, this.desiredContentHeight);\n      this.contentHeight = this.headerHeightExpanded + this.currentContentHeight + 'px';\n    } else {\n      this.currentContentHeight = Math.max(this.currentContentHeight, this.desiredContentHeight);\n      this.contentHeight = this.headerHeight + this.currentContentHeight + 'px';\n    }\n\n    if(this.currentContentHeight == this.desiredContentHeight){\n      this.animationEnded();\n      return;\n    }\n\n    this.animationFrameRef = requestAnimationFrame(this.animateHeader.bind(this));\n  }\n\n  private lerp = (x: number, y: number, a: number) => x * (1 - a) + y * a;\n\n  private animationEnded(){\n    this.animationEnd.emit(this.isOpen);\n    if(this.isOpen){\n      this.contentHeight = 'unset';\n    }\n  }\n}\n","<div class=\"lazy-exp-container\" [class.is-open]=\"isOpen\" [style.height]=\"contentHeight\" [class.disabled]=\"disabled\">\n    <div class=\"lazy-exp-header\" (click)=\"toggleOpen()\" [style.height]=\"headerHeightStyle\">\n        <div class=\"lazy-exp-header-title\">\n            <ng-content select=\"[exp-header-title]\"></ng-content>\n        </div>\n        <div class=\"lazy-exp-header-subtitle\">\n            <ng-content select=\"[exp-header-subtitle]\"></ng-content>\n        </div>\n        <div *ngIf=\"!hideIcon\" class=\"lazy-exp-header-icon\"></div>\n    </div>\n    <div #lazyContent class=\"lazy-exp-content\">\n        <div class=\"lazy-exp-content-container\">\n            <ng-content select=\"[exp-content]\"></ng-content>\n        </div>\n    </div>\n</div>\n"]}