UNPKG

materialize-angular

Version:
180 lines 14.3 kB
/** * @fileoverview added by tsickle * Generated from: app/completed-components/glossary/glossary.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @license * Copyright Workylab. All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://raw.githubusercontent.com/workylab/materialize-angular/master/LICENSE */ import { Component, ContentChildren, Input, QueryList } from '@angular/core'; import { config } from '../../config'; import { getOffseTop } from '../../utils/get-offset-top.util'; import { GlossaryItemComponent } from './glossary-item/glossary-item.component'; import { Router } from '@angular/router'; export class GlossaryComponent { /** * @param {?} router */ constructor(router) { this.router = router; this.className = GlossaryComponent.defaultProps.className; this.scrollSpy = GlossaryComponent.defaultProps.scrollSpy; this.topSpace = GlossaryComponent.defaultProps.topSpace; this.prefix = config.components.prefix; this.activeReferenceId = ''; this.onClickItem = this.onClickItem.bind(this); this.registerOptions = this.registerOptions.bind(this); this.update = this.update.bind(this); } /** * @return {?} */ ngAfterViewInit() { this.registerOptions(); setTimeout(this.update, 30); if (this.scrollSpy) { this.scrollSpy.onChangeEmitter.subscribe((/** * @param {?} referenceId * @return {?} */ (referenceId) => { this.activeReferenceId = referenceId; this.activeItemByReferenceId(referenceId); })); } } /** * @return {?} */ update() { this.activeReferenceId = this.getActiveReferenceId(); this.activeItemByReferenceId(this.activeReferenceId); this.scrollTo(this.activeReferenceId); } /** * @param {?} referenceId * @return {?} */ scrollTo(referenceId) { /** @type {?} */ const element = document.getElementById(referenceId); if (element) { /** @type {?} */ const elementOffsetTop = getOffseTop(element); /** @type {?} */ const scrollTop = elementOffsetTop - this.topSpace; setTimeout((/** * @return {?} */ () => window.scrollTo(0, scrollTop)), 150); } } /** * @return {?} */ getActiveReferenceId() { /** @type {?} */ const routerTree = this.router.parseUrl(this.router.url); if (routerTree && routerTree.fragment) { return routerTree.fragment; } return ''; } /** * @return {?} */ registerOptions() { this.items.forEach((/** * @param {?} item * @return {?} */ item => { item.onClickEmitter.subscribe(this.onClickItem); })); } /** * @param {?} referenceId * @return {?} */ onClickItem(referenceId) { this.activeReferenceId = referenceId; this.activeItemByReferenceId(referenceId); this.scrollTo(referenceId); /** @type {?} */ const routerTree = this.router.parseUrl(this.router.url); const { primary } = routerTree.root.children; /** @type {?} */ const urlWithoutParams = primary ? primary.segments.map((/** * @param {?} segment * @return {?} */ segment => segment.path)) : routerTree.root.segments.map((/** * @param {?} segment * @return {?} */ segment => segment.path)); this.router.navigate(urlWithoutParams, { fragment: referenceId }); } /** * @param {?} referenceId * @return {?} */ activeItemByReferenceId(referenceId) { this.items.forEach((/** * @param {?} item * @return {?} */ item => { item.isActive = item.referenceId === referenceId; })); } } GlossaryComponent.defaultProps = { className: '', scrollSpy: null, topSpace: 0 }; GlossaryComponent.decorators = [ { type: Component, args: [{ selector: `${config.components.prefix}-glossary`, template: "<ul [ngClass]=\"className\">\n <ng-content></ng-content>\n</ul>\n" }] } ]; /** @nocollapse */ GlossaryComponent.ctorParameters = () => [ { type: Router } ]; GlossaryComponent.propDecorators = { items: [{ type: ContentChildren, args: [GlossaryItemComponent,] }], className: [{ type: Input }], scrollSpy: [{ type: Input }], topSpace: [{ type: Input }] }; if (false) { /** @type {?} */ GlossaryComponent.defaultProps; /** @type {?} */ GlossaryComponent.prototype.items; /** @type {?} */ GlossaryComponent.prototype.className; /** @type {?} */ GlossaryComponent.prototype.scrollSpy; /** @type {?} */ GlossaryComponent.prototype.topSpace; /** @type {?} */ GlossaryComponent.prototype.prefix; /** @type {?} */ GlossaryComponent.prototype.activeReferenceId; /** * @type {?} * @private */ GlossaryComponent.prototype.router; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"glossary.component.js","sourceRoot":"ng://materialize-angular/","sources":["app/completed-components/glossary/glossary.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Workylab. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://raw.githubusercontent.com/workylab/materialize-angular/master/LICENSE\n */\n\nimport { AfterViewInit, Component, ContentChildren, Input, QueryList } from '@angular/core';\nimport { config } from '../../config';\nimport { getOffseTop } from '../../utils/get-offset-top.util';\nimport { GlossaryItemComponent } from './glossary-item/glossary-item.component';\nimport { GlossaryModel } from './glossary.model';\nimport { Router } from '@angular/router';\n\n@Component({\n  selector: `${ config.components.prefix }-glossary`,\n  templateUrl: './glossary.component.html'\n})\nexport class GlossaryComponent implements AfterViewInit, GlossaryModel {\n  static readonly defaultProps: GlossaryModel = {\n    className: '',\n    scrollSpy: null,\n    topSpace: 0\n  };\n\n  @ContentChildren(GlossaryItemComponent) items: QueryList<GlossaryItemComponent>;\n\n  @Input() className = GlossaryComponent.defaultProps.className;\n  @Input() scrollSpy = GlossaryComponent.defaultProps.scrollSpy;\n  @Input() topSpace = GlossaryComponent.defaultProps.topSpace;\n\n  public prefix = config.components.prefix;\n\n  public activeReferenceId = '';\n\n  constructor(private router: Router) {\n    this.onClickItem = this.onClickItem.bind(this);\n    this.registerOptions = this.registerOptions.bind(this);\n    this.update = this.update.bind(this);\n  }\n\n  ngAfterViewInit() {\n    this.registerOptions();\n\n    setTimeout(this.update, 30);\n\n    if (this.scrollSpy) {\n      this.scrollSpy.onChangeEmitter.subscribe((referenceId: string) => {\n        this.activeReferenceId = referenceId;\n\n        this.activeItemByReferenceId(referenceId);\n      });\n    }\n  }\n\n  update() {\n    this.activeReferenceId = this.getActiveReferenceId();\n\n    this.activeItemByReferenceId(this.activeReferenceId);\n\n    this.scrollTo(this.activeReferenceId);\n  }\n\n  scrollTo(referenceId: string) {\n    const element = document.getElementById(referenceId);\n\n    if (element) {\n      const elementOffsetTop = getOffseTop(element);\n      const scrollTop = elementOffsetTop - this.topSpace;\n\n      setTimeout(() => window.scrollTo(0, scrollTop), 150);\n    }\n  }\n\n  getActiveReferenceId(): string {\n    const routerTree = this.router.parseUrl(this.router.url);\n\n    if (routerTree && routerTree.fragment) {\n      return routerTree.fragment;\n    }\n\n    return '';\n  }\n\n  registerOptions() {\n    this.items.forEach(item => {\n      item.onClickEmitter.subscribe(this.onClickItem);\n    });\n  }\n\n  onClickItem(referenceId: string) {\n    this.activeReferenceId = referenceId;\n\n    this.activeItemByReferenceId(referenceId);\n    this.scrollTo(referenceId);\n\n    const routerTree = this.router.parseUrl(this.router.url);\n    const { primary } = routerTree.root.children;\n\n    const urlWithoutParams = primary\n      ? primary.segments.map(segment => segment.path)\n      : routerTree.root.segments.map(segment => segment.path);\n\n    this.router.navigate(urlWithoutParams, { fragment: referenceId });\n  }\n\n  activeItemByReferenceId(referenceId: string) {\n    this.items.forEach(item => {\n      item.isActive = item.referenceId === referenceId;\n    });\n  }\n}\n"]}