UNPKG

@mobilelivenpm/fds-angular-qa

Version:

This library was generated with [Nx](https://nx.dev).

235 lines 28.2 kB
import { Component, ChangeDetectionStrategy, ViewEncapsulation, Input, EventEmitter, Output, ContentChildren, Inject, forwardRef, ChangeDetectorRef, ElementRef } from '@angular/core'; import { trigger, state, style, transition, animate } from '@angular/animations'; import { Template, Header } from '../shared/template.directive'; let idx = 0; export class AccordionTabComponent { constructor(accordion, changeDetector) { this.changeDetector = changeDetector; this.cache = true; this.selectedChange = new EventEmitter(); this.transitionOptions = '400ms cubic-bezier(0.86, 0, 0.07, 1)'; this.id = `fds-accordiontab-${idx++}`; this.accordion = accordion; } get selected() { return this._selected; } set selected(val) { this._selected = val; if (!this.loaded) { if (this._selected && this.cache) { this.loaded = true; } this.changeDetector.markForCheck(); } } ngAfterContentInit() { this.templates.forEach(item => { switch (item.getType()) { case 'content': this.contentTemplate = item.template; break; case 'header': this.headerTemplate = item.template; break; default: this.contentTemplate = item.template; break; } }); } toggle(event) { if (this.disabled) { return false; } let index = this.findTabIndex(); if (this.selected) { this.selected = false; this.accordion.onClose.emit({ originalEvent: event, index: index }); } else { if (!this.accordion.multiple) { for (var i = 0; i < this.accordion.tabs.length; i++) { this.accordion.tabs[i].selected = false; this.accordion.tabs[i].selectedChange.emit(false); this.accordion.tabs[i].changeDetector.markForCheck(); } } this.selected = true; this.loaded = true; this.accordion.onOpen.emit({ originalEvent: event, index: index }); } this.selectedChange.emit(this.selected); this.accordion.updateActiveIndex(); this.changeDetector.markForCheck(); event.preventDefault(); } findTabIndex() { let index = -1; for (var i = 0; i < this.accordion.tabs.length; i++) { if (this.accordion.tabs[i] == this) { index = i; break; } } return index; } get hasHeaderFacet() { return this.headerFacet && this.headerFacet.length > 0; } onKeydown(event) { if (event.which === 32 || event.which === 13) { this.toggle(event); event.preventDefault(); } } ngOnDestroy() { this.accordion.tabs.splice(this.findTabIndex(), 1); } } AccordionTabComponent.decorators = [ { type: Component, args: [{ selector: 'fds-accordionTab', template: "<div\n class=\"fds-accordion-item fds-accordion-tab\"\n [ngClass]=\"{ 'fds-accordion-tab-active': selected }\"\n>\n <div\n class=\"fds-accordion-header\"\n [ngClass]=\"{\n 'fds-highlight': selected,\n 'fds-accordion-disabled': disabled\n }\"\n >\n <a\n role=\"tab\"\n [class]=\"accordionTabClass\"\n class=\"fds-btnaccordion fds-accordion-header-link mb--3\"\n (click)=\"toggle($event)\"\n (keydown)=\"onKeydown($event)\"\n [attr.tabindex]=\"disabled ? null : 0\"\n [attr.id]=\"id\"\n [attr.aria-controls]=\"id + '-content'\"\n [attr.aria-expanded]=\"selected\"\n >\n <span class=\"fds-accordion-header-text\" *ngIf=\"!hasHeaderFacet\">\n {{ header }}\n </span>\n <i\n class=\"fds-accordion-toggle-icon\"\n [ngClass]=\"selected ? accordion.collapseIcon : accordion.expandIcon\"\n ></i>\n <ng-container *ngTemplateOutlet=\"headerTemplate\"></ng-container>\n <ng-content select=\"fds-header\" *ngIf=\"hasHeaderFacet\"></ng-content>\n </a>\n </div>\n <div\n [attr.id]=\"id + '-content'\"\n class=\"fds-accordion-content fds-toggleable-content\"\n [@tabContent]=\"\n selected\n ? {\n value: 'visible',\n params: { transitionParams: transitionOptions }\n }\n : {\n value: 'hidden',\n params: { transitionParams: transitionOptions }\n }\n \"\n role=\"region\"\n [attr.aria-hidden]=\"!selected\"\n [attr.aria-labelledby]=\"id\"\n >\n <div class=\"fds-accordion-content-holder overflow--hidden\">\n <ng-content></ng-content>\n <ng-container *ngIf=\"contentTemplate && (cache ? loaded : selected)\">\n <ng-container *ngTemplateOutlet=\"contentTemplate\"></ng-container>\n </ng-container>\n </div>\n </div>\n</div>", animations: [ trigger('tabContent', [ state('hidden', style({ height: '0', overflow: 'hidden' })), state('visible', style({ height: '*' })), transition('visible <=> hidden', [ style({ overflow: 'hidden' }), animate('{{transitionParams}}') ]), transition('void => *', animate(0)) ]) ], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, styles: [".p-accordion-header-link{cursor:pointer;display:flex;align-items:center;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;position:relative;text-decoration:none}.p-accordion-header-link:focus{z-index:1}.p-accordion-header-link .p-accordion-header-text{line-height:1}"] },] } ]; AccordionTabComponent.ctorParameters = () => [ { type: undefined, decorators: [{ type: Inject, args: [forwardRef(() => Accordion),] }] }, { type: ChangeDetectorRef } ]; AccordionTabComponent.propDecorators = { header: [{ type: Input }], accordionTabClass: [{ type: Input }], disabled: [{ type: Input }], cache: [{ type: Input }], selectedChange: [{ type: Output }], transitionOptions: [{ type: Input }], headerFacet: [{ type: ContentChildren, args: [Header,] }], templates: [{ type: ContentChildren, args: [Template,] }], selected: [{ type: Input }] }; export class Accordion { constructor(el, changeDetector) { this.el = el; this.changeDetector = changeDetector; this.onClose = new EventEmitter(); this.onOpen = new EventEmitter(); this.expandIcon = 'icon-arrowdown'; this.collapseIcon = 'icon-arrowdown'; this.activeIndexChange = new EventEmitter(); this.tabs = []; } ngAfterContentInit() { this.initTabs(); this.tabListSubscription = this.tabList.changes.subscribe(_ => { this.initTabs(); }); } initTabs() { this.tabs = this.tabList.toArray(); this.updateSelectionState(); this.changeDetector.markForCheck(); } getBlockableElement() { return this.el.nativeElement.children[0]; } get activeIndex() { return this._activeIndex; } set activeIndex(val) { this._activeIndex = val; if (this.preventActiveIndexPropagation) { this.preventActiveIndexPropagation = false; return; } this.updateSelectionState(); } updateSelectionState() { if (this.tabs && this.tabs.length && this._activeIndex != null) { for (let i = 0; i < this.tabs.length; i++) { let selected = this.multiple ? this._activeIndex.includes(i) : i === this._activeIndex; let changed = selected !== this.tabs[i].selected; if (changed) { this.tabs[i].selected = selected; this.tabs[i].selectedChange.emit(selected); this.tabs[i].changeDetector.markForCheck(); } } } } updateActiveIndex() { let index = this.multiple ? [] : null; this.tabs.forEach((tab, i) => { if (tab.selected) { if (this.multiple) { index.push(i); } else { index = i; return; } } }); this.preventActiveIndexPropagation = true; this.activeIndexChange.emit(index); } ngOnDestroy() { if (this.tabListSubscription) { this.tabListSubscription.unsubscribe(); } } } Accordion.decorators = [ { type: Component, args: [{ selector: 'fds-accordion', template: ` <div [ngClass]="'fds-accordion fds-component'" [ngStyle]="style" [class]="fdsAccordionClass" role="tablist" > <ng-content></ng-content> </div> `, changeDetection: ChangeDetectionStrategy.OnPush },] } ]; Accordion.ctorParameters = () => [ { type: ElementRef }, { type: ChangeDetectorRef } ]; Accordion.propDecorators = { multiple: [{ type: Input }], onClose: [{ type: Output }], onOpen: [{ type: Output }], style: [{ type: Input }], fdsAccordionClass: [{ type: Input }], expandIcon: [{ type: Input }], collapseIcon: [{ type: Input }], activeIndexChange: [{ type: Output }], tabList: [{ type: ContentChildren, args: [AccordionTabComponent,] }], activeIndex: [{ type: Input }] }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"accordion.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/src/lib/accordion/accordion.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ChangeDetectionStrategy,\n  ViewEncapsulation,\n  AfterContentInit,\n  OnDestroy,\n  Input,\n  EventEmitter,\n  Output,\n  ContentChildren,\n  QueryList,\n  TemplateRef,\n  Inject,\n  forwardRef,\n  ChangeDetectorRef,\n  ElementRef\n} from '@angular/core';\nimport {\n  trigger,\n  state,\n  style,\n  transition,\n  animate\n} from '@angular/animations';\nimport { Template, Header } from '../shared/template.directive';\nimport { Subscription } from 'rxjs';\nimport { BlockableUI } from './accordion.config';\n\nlet idx: number = 0;\n\n@Component({\n  selector: 'fds-accordionTab',\n  templateUrl: './accordion.component.html',\n  styleUrls: ['./accordion.component.scss'],\n  animations: [\n    trigger('tabContent', [\n      state(\n        'hidden',\n        style({\n          height: '0',\n          overflow: 'hidden'\n        })\n      ),\n      state(\n        'visible',\n        style({\n          height: '*'\n        })\n      ),\n      transition('visible <=> hidden', [\n        style({ overflow: 'hidden' }),\n        animate('{{transitionParams}}')\n      ]),\n      transition('void => *', animate(0))\n    ])\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\n\nexport class AccordionTabComponent implements AfterContentInit, OnDestroy {\n  @Input() header: string;\n\n  @Input() accordionTabClass: string;\n\n  @Input() disabled: boolean;\n\n  @Input() cache: boolean = true;\n\n  @Output() selectedChange: EventEmitter<any> = new EventEmitter();\n\n  @Input() transitionOptions: string = '400ms cubic-bezier(0.86, 0, 0.07, 1)';\n\n  @ContentChildren(Header) headerFacet: QueryList<Header>;\n\n  @ContentChildren(Template) templates: QueryList<any>;\n\n  private _selected: boolean;\n\n  @Input() get selected(): any {\n    return this._selected;\n  }\n\n  set selected(val: any) {\n    this._selected = val;\n\n    if (!this.loaded) {\n      if (this._selected && this.cache) {\n        this.loaded = true;\n      }\n\n      this.changeDetector.markForCheck();\n    }\n  }\n\n  contentTemplate: TemplateRef<any>;\n\n  headerTemplate: TemplateRef<any>;\n\n  id: string = `fds-accordiontab-${idx++}`;\n\n  loaded: boolean;\n\n  accordion: Accordion;\n\n  constructor(\n    @Inject(forwardRef(() => Accordion)) accordion: any,\n    public changeDetector: ChangeDetectorRef\n  ) {\n    this.accordion = accordion as Accordion;\n  }\n\n  ngAfterContentInit() {\n    this.templates.forEach(item => {\n      switch (item.getType()) {\n        case 'content':\n          this.contentTemplate = item.template;\n          break;\n\n        case 'header':\n          this.headerTemplate = item.template;\n          break;\n\n        default:\n          this.contentTemplate = item.template;\n          break;\n      }\n    });\n  }\n\n  toggle(event: any): any {\n    if (this.disabled) {\n      return false;\n    }\n\n    let index = this.findTabIndex();\n\n    if (this.selected) {\n      this.selected = false;\n      this.accordion.onClose.emit({ originalEvent: event, index: index });\n    } else {\n      if (!this.accordion.multiple) {\n        for (var i = 0; i < this.accordion.tabs.length; i++) {\n          this.accordion.tabs[i].selected = false;\n          this.accordion.tabs[i].selectedChange.emit(false);\n          this.accordion.tabs[i].changeDetector.markForCheck();\n        }\n      }\n\n      this.selected = true;\n      this.loaded = true;\n      this.accordion.onOpen.emit({ originalEvent: event, index: index });\n    }\n\n    this.selectedChange.emit(this.selected);\n    this.accordion.updateActiveIndex();\n    this.changeDetector.markForCheck();\n\n    event.preventDefault();\n  }\n\n  findTabIndex() {\n    let index = -1;\n    for (var i = 0; i < this.accordion.tabs.length; i++) {\n      if (this.accordion.tabs[i] == this) {\n        index = i;\n        break;\n      }\n    }\n    return index;\n  }\n\n  get hasHeaderFacet(): boolean {\n    return this.headerFacet && this.headerFacet.length > 0;\n  }\n\n  onKeydown(event: KeyboardEvent) {\n    if (event.which === 32 || event.which === 13) {\n      this.toggle(event);\n      event.preventDefault();\n    }\n  }\n\n  ngOnDestroy() {\n    this.accordion.tabs.splice(this.findTabIndex(), 1);\n  }\n}\n\n@Component({\n  selector: 'fds-accordion',\n  template: `\n    <div\n      [ngClass]=\"'fds-accordion fds-component'\"\n      [ngStyle]=\"style\"\n      [class]=\"fdsAccordionClass\"\n      role=\"tablist\"\n    >\n      <ng-content></ng-content>\n    </div>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class Accordion implements BlockableUI, AfterContentInit, OnDestroy {\n  @Input() multiple: boolean;\n\n  @Output() onClose: EventEmitter<any> = new EventEmitter();\n\n  @Output() onOpen: EventEmitter<any> = new EventEmitter();\n\n  @Input() style: any;\n\n  @Input() fdsAccordionClass: string;\n\n  @Input() expandIcon: string = 'icon-arrowdown';\n\n  @Input() collapseIcon: string = 'icon-arrowdown';\n\n  @Output() activeIndexChange: EventEmitter<any> = new EventEmitter();\n\n  @ContentChildren(AccordionTabComponent)\n  tabList: QueryList<AccordionTabComponent>;\n\n  tabListSubscription: Subscription;\n\n  private _activeIndex: any;\n\n  preventActiveIndexPropagation: boolean;\n\n  public tabs: AccordionTabComponent[] = [];\n\n  constructor(\n    public el: ElementRef,\n    public changeDetector: ChangeDetectorRef\n  ) {}\n\n  ngAfterContentInit() {\n    this.initTabs();\n\n    this.tabListSubscription = this.tabList.changes.subscribe(_ => {\n      this.initTabs();\n    });\n  }\n\n  initTabs(): any {\n    this.tabs = this.tabList.toArray();\n    this.updateSelectionState();\n    this.changeDetector.markForCheck();\n  }\n\n  getBlockableElement(): HTMLElement {\n    return this.el.nativeElement.children[0];\n  }\n\n  @Input() get activeIndex(): any {\n    return this._activeIndex;\n  }\n\n  set activeIndex(val: any) {\n    this._activeIndex = val;\n    if (this.preventActiveIndexPropagation) {\n      this.preventActiveIndexPropagation = false;\n      return;\n    }\n\n    this.updateSelectionState();\n  }\n\n  updateSelectionState() {\n    if (this.tabs && this.tabs.length && this._activeIndex != null) {\n      for (let i = 0; i < this.tabs.length; i++) {\n        let selected = this.multiple\n          ? this._activeIndex.includes(i)\n          : i === this._activeIndex;\n        let changed = selected !== this.tabs[i].selected;\n\n        if (changed) {\n          this.tabs[i].selected = selected;\n          this.tabs[i].selectedChange.emit(selected);\n          this.tabs[i].changeDetector.markForCheck();\n        }\n      }\n    }\n  }\n\n  updateActiveIndex() {\n    let index: any = this.multiple ? [] : null;\n    this.tabs.forEach((tab, i) => {\n      if (tab.selected) {\n        if (this.multiple) {\n          index.push(i);\n        } else {\n          index = i;\n          return;\n        }\n      }\n    });\n\n    this.preventActiveIndexPropagation = true;\n    this.activeIndexChange.emit(index);\n  }\n\n  ngOnDestroy() {\n    if (this.tabListSubscription) {\n      this.tabListSubscription.unsubscribe();\n    }\n  }\n}\n\n"]}