angular-magic-breadcrumb
Version:
AngularMagicBreadcrumb is a library for self-generated breadcrumb in angular 7
216 lines • 21.2 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/custom-breadcrumb.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input } from '@angular/core';
import { NavigationEnd, Router } from "@angular/router";
import { AngularMagicBreadcrumbService } from "./angular-magic-breadcrumb.service";
import { filter } from "rxjs/operators";
import { Location } from '@angular/common';
export class CustomBreadcrumbComponent {
/**
* @param {?} router
* @param {?} breadcrumbService
* @param {?} location
*/
constructor(router, breadcrumbService, location) {
this.router = router;
this.breadcrumbService = breadcrumbService;
this.location = location;
// this variable will handle the current url split into a list structure
this.currentsplitUrl = [];
// this variable will handle the full breadcrumb itself, this variable will be used in the HTML template
this.breadcumValue = [];
// this variable is a flag that indicates if the Breadcrumb must be shown in a specific view
this.showBreadcrum = true;
}
/**
* @return {?}
*/
ngOnInit() {
this.setUrls();
this.getBreadcrum();
}
/**
* Checks if the part of the breadcrumb is active or not, and make the redirection to the specific url of the part
* @param {?} breadcrum -> part of the full breadcrumb
* @return {?}
*/
redirectToView(breadcrum) {
if (breadcrum.active) {
return;
}
this.router.navigate([breadcrum.url]);
}
/**
* Make the subscriptions to the two observables, and saves the value of them into a specific variable
* saves the breadcrumb and if should be shown or not
* @return {?}
*/
getBreadcrum() {
this.breadcrumbService.breadcrumbStructure_.subscribe((/**
* @param {?} value
* @return {?}
*/
value => {
/** @type {?} */
let newBreadcrum = [];
value.forEach((/**
* @param {?} item
* @return {?}
*/
item => {
if (item.show == true) {
newBreadcrum.push(item);
}
}));
this.breadcumValue = newBreadcrum;
}));
this.breadcrumbService.showBreadcrumbStructure_.subscribe((/**
* @param {?} value
* @return {?}
*/
value => {
this.showBreadcrum = value;
}));
}
/**
* @return {?}
*/
setUrls() {
this._mainRoot = this.mainRoot;
this.router.events.pipe(
// Just executed when an navigation event ends
filter((/**
* @param {?} event
* @return {?}
*/
event => event instanceof NavigationEnd))).subscribe((/**
* @return {?}
*/
() => {
// returns and save the breadcrumb into a new temporal variable
/** @type {?} */
const currentBreadCrumStructure = this.getBreadcrumbStructure();
// resets the structure of the breadcrumb
this.breadcrumbService.resetBreadcrumbStructure();
// this variable will hold the url to add to the breadcrumb structure
/** @type {?} */
let setsUrl = '';
/** @type {?} */
const pathnameUrl = this.location.path().split('#')[0].split('?')[0];
// this condition is when the breadcrumb is in a platform that has got a route that we don't want to show in the breadcrumb
if (pathnameUrl.includes('/' + this._mainRoot + '/')) {
setsUrl = '/' + this._mainRoot;
}
if (pathnameUrl != this.lastPathname) {
// the breadcrumb must be shown if the first item change
this.showBreadcrum = true;
}
// splits the url by the route on the condition above and splits it by the '/' separator
// Removes the /plataforma/ and params if the url have one of them
/** @type {?} */
let splitUrl = pathnameUrl.split('/' + this._mainRoot + '/').join('').split('/');
// this line assure us that the url split has no blanks or null or empty elements
splitUrl = splitUrl.filter(Boolean);
splitUrl.forEach((/**
* @param {?} item
* @param {?} index
* @return {?}
*/
(item, index) => {
setsUrl = setsUrl + '/' + item;
// a variable that holds the new part that will be added to the breadcrumb
/** @type {?} */
let newBreadcrum = {};
// if one part of the breadcrumb did'nt change, the last known value will be added (remains the same)
if (this.currentsplitUrl[index] === item) {
newBreadcrum = currentBreadCrumStructure[index];
}
else {
// else... a new structure is created
newBreadcrum = {
value: item,
url: setsUrl,
active: splitUrl.length - 1 === index,
show: true
};
}
// the new part of the breadcrumb is added to the structure that will be shown
this.setItemBreadcrumbStructure(newBreadcrum, index);
if (splitUrl.length - 1 === index) {
// in the last item of the route, the current route split is setted into the variable, to use it later when another navigation
// event happens
this.currentsplitUrl = splitUrl;
}
}));
this.lastPathname = pathnameUrl;
}));
}
/**
* @param {?} newBreadcrum
* @param {?} index
* @return {?}
*/
setItemBreadcrumbStructure(newBreadcrum, index) {
this.breadcrumbService.setItemBreadcrumbStructure(newBreadcrum, index);
}
/**
* @return {?}
*/
getBreadcrumbStructure() {
return this.breadcrumbService.getBreadcrumbStructure();
}
/**
* @param {?} value
* @return {?}
*/
changeVisibilityBreadcrumb(value) {
this.breadcrumbService.changeVisibilityBreadcrumb(value);
}
}
CustomBreadcrumbComponent.decorators = [
{ type: Component, args: [{
selector: 'lng-self-generated-breadcrumb',
template: "<div class=\"dynamic-breadcrumb\">\r\n <nav aria-label=\"breadcrumb\" class=\"navigation\" *ngIf=\"showBreadcrum\">\r\n <ol class=\"breadcrumb\">\r\n <li class=\"breadcrumb-item\" [class.active]=\"breadcrum.active\"\r\n (click)=\"redirectToView(breadcrum)\"\r\n style=\"text-transform: capitalize\"\r\n *ngFor=\"let breadcrum of breadcumValue\">{{breadcrum.value}}</li>\r\n </ol>\r\n </nav>\r\n</div>\r\n",
providers: [AngularMagicBreadcrumbService],
styles: [".dynamic-breadcrumb{background-color:#fff}.navigation{display:block}.breadcrumb{display:flex;flex-wrap:wrap;list-style:none;border-radius:.25rem;background-color:#fff;font-size:15px;padding:31px 30px 10px;color:#898989;font-weight:300;max-width:1216px;margin:0 auto}.breadcrumb .breadcrumb-item+.breadcrumb-item::before{display:inline-block;color:#6c757d;content:\"/\";padding-right:5px}.breadcrumb .breadcrumb-item{padding-left:5px}.breadcrumb .breadcrumb-item:not(.active){cursor:pointer}.breadcrumb .breadcrumb-item.active{color:#707070;font-weight:400}@media (min-width:768px){.breadcrumb{padding-left:30px;padding-bottom:22px}}@media (min-width:992px){.breadcrumb{padding-left:45px}}@media (min-width:1200px){.breadcrumb{font-size:17px;padding:40px 50px 10px}}"]
}] }
];
/** @nocollapse */
CustomBreadcrumbComponent.ctorParameters = () => [
{ type: Router },
{ type: AngularMagicBreadcrumbService },
{ type: Location }
];
CustomBreadcrumbComponent.propDecorators = {
mainRoot: [{ type: Input }]
};
if (false) {
/** @type {?} */
CustomBreadcrumbComponent.prototype.mainRoot;
/** @type {?} */
CustomBreadcrumbComponent.prototype._mainRoot;
/** @type {?} */
CustomBreadcrumbComponent.prototype.lastPathname;
/** @type {?} */
CustomBreadcrumbComponent.prototype.currentsplitUrl;
/** @type {?} */
CustomBreadcrumbComponent.prototype.breadcumValue;
/** @type {?} */
CustomBreadcrumbComponent.prototype.showBreadcrum;
/**
* @type {?}
* @private
*/
CustomBreadcrumbComponent.prototype.router;
/** @type {?} */
CustomBreadcrumbComponent.prototype.breadcrumbService;
/**
* @type {?}
* @private
*/
CustomBreadcrumbComponent.prototype.location;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-breadcrumb.component.js","sourceRoot":"ng://angular-magic-breadcrumb/","sources":["lib/custom-breadcrumb.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnInit} from '@angular/core';\r\nimport {NavigationEnd, Router} from \"@angular/router\";\r\nimport {AngularMagicBreadcrumbService} from \"./angular-magic-breadcrumb.service\";\r\nimport {filter} from \"rxjs/operators\";\r\nimport {Location} from '@angular/common';\r\n\r\n@Component({\r\n  selector: 'lng-self-generated-breadcrumb',\r\n  templateUrl: './custom-breadcrumb.component.html',\r\n  styleUrls: ['./custom-breadcrumb.component.scss'],\r\n  providers: [AngularMagicBreadcrumbService]\r\n})\r\nexport class CustomBreadcrumbComponent implements OnInit {\r\n  @Input() mainRoot: String;\r\n  _mainRoot: String;\r\n  lastPathname: string;\r\n  // this variable will handle the current url split into a list structure\r\n  currentsplitUrl = [];\r\n  // this variable will handle the full breadcrumb itself, this variable will be used in the HTML template\r\n  breadcumValue: {\r\n    url: string,\r\n    active: boolean,\r\n    value: string\r\n  }[] = [];\r\n  // this variable is a flag that indicates if the Breadcrumb must be shown in a specific view\r\n  showBreadcrum = true;\r\n\r\n  constructor(\r\n    private router: Router,\r\n    public breadcrumbService: AngularMagicBreadcrumbService,\r\n    private location: Location\r\n  ) { }\r\n\r\n  ngOnInit() {\r\n    this.setUrls();\r\n    this.getBreadcrum();\r\n  }\r\n\r\n  /**\r\n   * Checks if the part of the breadcrumb is active or not, and make the redirection to the specific url of the part\r\n   * @param breadcrum -> part of the full breadcrumb\r\n   */\r\n  redirectToView(breadcrum) {\r\n    if (breadcrum.active) {\r\n      return;\r\n    }\r\n    this.router.navigate([breadcrum.url]);\r\n  }\r\n\r\n  /**\r\n   * Make the subscriptions to the two observables, and saves the value of them into a specific variable\r\n   * saves the breadcrumb and if should be shown or not\r\n   */\r\n  getBreadcrum() {\r\n    this.breadcrumbService.breadcrumbStructure_.subscribe(value => {\r\n      let newBreadcrum = [];\r\n      value.forEach(item => {\r\n        if (item.show == true) {\r\n          newBreadcrum.push(item)\r\n        }\r\n      });\r\n      this.breadcumValue = newBreadcrum;\r\n    });\r\n\r\n    this.breadcrumbService.showBreadcrumbStructure_.subscribe(value => {\r\n      this.showBreadcrum = value;\r\n    });\r\n  }\r\n\r\n  setUrls() {\r\n    this._mainRoot = this.mainRoot;\r\n    this.router.events.pipe(\r\n      // Just executed when an navigation event ends\r\n      filter(event => event instanceof NavigationEnd)\r\n    ).subscribe(() => {\r\n      // returns and save the breadcrumb into a new temporal variable\r\n      const currentBreadCrumStructure = this.getBreadcrumbStructure();\r\n      // resets the structure of the breadcrumb\r\n      this.breadcrumbService.resetBreadcrumbStructure();\r\n      // this variable will hold the url to add to the breadcrumb structure\r\n      let setsUrl = '';\r\n      const pathnameUrl = this.location.path().split('#')[0].split('?')[0];\r\n      // this condition is when the breadcrumb is in a platform that has got a route that we don't want to show in the breadcrumb\r\n      if (pathnameUrl.includes('/'+ this._mainRoot +'/')) {\r\n        setsUrl = '/'+ this._mainRoot;\r\n      }\r\n      if (pathnameUrl != this.lastPathname) {\r\n        // the breadcrumb must be shown if the first item change\r\n        this.showBreadcrum = true;\r\n      }\r\n\r\n      // splits the url by the route on the condition above and splits it by the '/' separator\r\n      // Removes the /plataforma/ and params if the url have one of them\r\n      let splitUrl = pathnameUrl.split('/'+ this._mainRoot +'/').join('').split('/');\r\n      // this line assure us that the url split has no blanks or null or empty elements\r\n      splitUrl = splitUrl.filter(Boolean);\r\n      splitUrl.forEach((item, index) => {\r\n        setsUrl = setsUrl + '/' + item;\r\n        // a variable that holds the new part that will be added to the breadcrumb\r\n        let newBreadcrum = {};\r\n        // if one part of the breadcrumb did'nt change, the last known value will be added (remains the same)\r\n        if (this.currentsplitUrl[index] === item) {\r\n          newBreadcrum = currentBreadCrumStructure[index];\r\n        } else {\r\n          // else... a new structure is created\r\n          newBreadcrum = {\r\n            value: item,\r\n            url: setsUrl,\r\n            active: splitUrl.length - 1 === index,\r\n            show: true\r\n          };\r\n        }\r\n        // the new part of the breadcrumb is added to the structure that will be shown\r\n        this.setItemBreadcrumbStructure(newBreadcrum, index);\r\n\r\n        if (splitUrl.length - 1 === index) {\r\n          // in the last item of the route, the current route split is setted into the variable, to use it later when another navigation\r\n          // event happens\r\n          this.currentsplitUrl = splitUrl;\r\n        }\r\n\r\n      });\r\n      this.lastPathname = pathnameUrl;\r\n    });\r\n  }\r\n\r\n  setItemBreadcrumbStructure(newBreadcrum, index) {\r\n    this.breadcrumbService.setItemBreadcrumbStructure(newBreadcrum, index);\r\n  }\r\n\r\n  getBreadcrumbStructure() {\r\n    return this.breadcrumbService.getBreadcrumbStructure()\r\n  }\r\n\r\n  changeVisibilityBreadcrumb(value: boolean) {\r\n    this.breadcrumbService.changeVisibilityBreadcrumb(value)\r\n  }\r\n\r\n}\r\n"]}