UNPKG

materialize-angular

Version:
205 lines 15.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'; var GlossaryComponent = /** @class */ (function () { function GlossaryComponent(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 {?} */ GlossaryComponent.prototype.ngAfterViewInit = /** * @return {?} */ function () { var _this = this; this.registerOptions(); setTimeout(this.update, 30); if (this.scrollSpy) { this.scrollSpy.onChangeEmitter.subscribe((/** * @param {?} referenceId * @return {?} */ function (referenceId) { _this.activeReferenceId = referenceId; _this.activeItemByReferenceId(referenceId); })); } }; /** * @return {?} */ GlossaryComponent.prototype.update = /** * @return {?} */ function () { this.activeReferenceId = this.getActiveReferenceId(); this.activeItemByReferenceId(this.activeReferenceId); this.scrollTo(this.activeReferenceId); }; /** * @param {?} referenceId * @return {?} */ GlossaryComponent.prototype.scrollTo = /** * @param {?} referenceId * @return {?} */ function (referenceId) { /** @type {?} */ var element = document.getElementById(referenceId); if (element) { /** @type {?} */ var elementOffsetTop = getOffseTop(element); /** @type {?} */ var scrollTop_1 = elementOffsetTop - this.topSpace; setTimeout((/** * @return {?} */ function () { return window.scrollTo(0, scrollTop_1); }), 150); } }; /** * @return {?} */ GlossaryComponent.prototype.getActiveReferenceId = /** * @return {?} */ function () { /** @type {?} */ var routerTree = this.router.parseUrl(this.router.url); if (routerTree && routerTree.fragment) { return routerTree.fragment; } return ''; }; /** * @return {?} */ GlossaryComponent.prototype.registerOptions = /** * @return {?} */ function () { var _this = this; this.items.forEach((/** * @param {?} item * @return {?} */ function (item) { item.onClickEmitter.subscribe(_this.onClickItem); })); }; /** * @param {?} referenceId * @return {?} */ GlossaryComponent.prototype.onClickItem = /** * @param {?} referenceId * @return {?} */ function (referenceId) { this.activeReferenceId = referenceId; this.activeItemByReferenceId(referenceId); this.scrollTo(referenceId); /** @type {?} */ var routerTree = this.router.parseUrl(this.router.url); var primary = routerTree.root.children.primary; /** @type {?} */ var urlWithoutParams = primary ? primary.segments.map((/** * @param {?} segment * @return {?} */ function (segment) { return segment.path; })) : routerTree.root.segments.map((/** * @param {?} segment * @return {?} */ function (segment) { return segment.path; })); this.router.navigate(urlWithoutParams, { fragment: referenceId }); }; /** * @param {?} referenceId * @return {?} */ GlossaryComponent.prototype.activeItemByReferenceId = /** * @param {?} referenceId * @return {?} */ function (referenceId) { this.items.forEach((/** * @param {?} item * @return {?} */ function (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 = function () { return [ { type: Router } ]; }; GlossaryComponent.propDecorators = { items: [{ type: ContentChildren, args: [GlossaryItemComponent,] }], className: [{ type: Input }], scrollSpy: [{ type: Input }], topSpace: [{ type: Input }] }; return GlossaryComponent; }()); export { GlossaryComponent }; 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"]}