materialize-angular
Version:
Material UI Angular library
205 lines • 15.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';
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"]}