materialize-angular
Version:
Material UI Angular library
180 lines • 14.3 kB
JavaScript
/**
* @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"]}