@softheon/armature 8.15.0 → 8.15.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -3,9 +3,10 @@
3
3
  * Generated from: lib/navigation/components/navigation/navigation.component.ts
4
4
  * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
5
5
  */
6
- import { Component, ChangeDetectorRef, Input } from '@angular/core';
7
6
  import { MediaMatcher } from '@angular/cdk/layout';
7
+ import { ChangeDetectorRef, Component, Input, ViewChild } from '@angular/core';
8
8
  import { TranslateService } from '@ngx-translate/core';
9
+ import { MatSidenav } from '@angular/material';
9
10
  /**
10
11
  * The Navigation Component
11
12
  */
@@ -95,6 +96,7 @@ export class ArmatureNavigationComponent {
95
96
  openMobileSubNav(nav) {
96
97
  this.isMobileSubNavOpen = true;
97
98
  this.currentMobileNav = nav;
99
+ this.sidenav.open();
98
100
  }
99
101
  /**
100
102
  * Mobile SubNav - closes the SubNav
@@ -102,6 +104,7 @@ export class ArmatureNavigationComponent {
102
104
  */
103
105
  closeMobileSubNav() {
104
106
  this.isMobileSubNavOpen = false;
107
+ this.sidenav.close();
105
108
  }
106
109
  /**
107
110
  * Sets the theme color
@@ -127,12 +130,18 @@ ArmatureNavigationComponent.ctorParameters = () => [
127
130
  { type: TranslateService }
128
131
  ];
129
132
  ArmatureNavigationComponent.propDecorators = {
133
+ sidenav: [{ type: ViewChild, args: ['snav', { static: false },] }],
130
134
  navigationData: [{ type: Input }],
131
135
  settings: [{ type: Input }],
132
136
  advancedSettings: [{ type: Input }],
133
137
  themeSettings: [{ type: Input }]
134
138
  };
135
139
  if (false) {
140
+ /**
141
+ * The side mobile nav
142
+ * @type {?}
143
+ */
144
+ ArmatureNavigationComponent.prototype.sidenav;
136
145
  /**
137
146
  * Component Input - the navigation data
138
147
  * @type {?}
@@ -230,4 +239,4 @@ if (false) {
230
239
  */
231
240
  ArmatureNavigationComponent.prototype.translate;
232
241
  }
233
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation.component.js","sourceRoot":"ng://@softheon/armature/","sources":["lib/navigation/components/navigation/navigation.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, OnDestroy, ChangeDetectorRef, ViewEncapsulation, Input } from '@angular/core';\r\nimport { MediaMatcher } from '@angular/cdk/layout';\r\nimport { TranslateService } from '@ngx-translate/core';\r\n\r\nimport { NavNode, NavigationSettings, NavigationAdvancedSettings, NavigationThemeSettings } from '../../models/nav-models-api';\r\n\r\n/**\r\n * The Navigation Component\r\n */\r\n@Component({\r\n  selector: 'sof-ar-navigation',\r\n  templateUrl: './navigation.component.html',\r\n  styleUrls: ['./navigation.component.scss']\r\n})\r\nexport class ArmatureNavigationComponent implements OnInit, OnDestroy {\r\n\r\n  /** Component Input - the navigation data */\r\n  @Input() public navigationData: NavNode[];\r\n\r\n  /** Component Input - the navigation settings */\r\n  @Input() public settings: NavigationSettings = {};\r\n\r\n  /** Component Input - the navigation settings */\r\n  @Input() public advancedSettings: NavigationAdvancedSettings = {};\r\n\r\n  /** Component Input - the navigation settings */\r\n  @Input() public themeSettings: NavigationThemeSettings = {};\r\n\r\n  /** Mobile SubNav - whether or not the mobile SubNav is open */\r\n  public isMobileSubNavOpen: boolean = false;\r\n\r\n  /** Mobile SubNav -the data to be passed to the mobile SubNav */\r\n  public currentMobileNav: NavNode;\r\n\r\n  /** Settings - the font awesome menu icon */\r\n  public fontAwesomeMenuIcon: string;\r\n\r\n  /** Settings - the top gap on desktop screens for the MD component */\r\n  public topGapDesktop: number;\r\n\r\n  /** Settings - the top gap on mobile screens for the MD component */\r\n  public topGapMobile: number;\r\n\r\n  /** Settings - the margin on desktop screens for the MD component */\r\n  public marginTopDesktop: number;\r\n\r\n  /** Settings - the margin on mobile screens for the MD component */\r\n  public marginTopMobile: number;\r\n\r\n  /** Settings - the main menu text that appears in the mobile SubNav */\r\n  public mainMenuText: string;\r\n\r\n  /** Settings - the header height */\r\n  public headerHeight: number;\r\n\r\n  /** Settings - the menu button screen reader text */\r\n  public menuButtonSRText: string;\r\n\r\n  /** the mobile query */\r\n  public mobileQuery: MediaQueryList;\r\n\r\n  /** the mobile query listener */\r\n  private readonly _mobileQueryListener: () => void;\r\n\r\n  /**\r\n   * the constructor\r\n   * @param changeDetectorRef the change detector reference\r\n   * @param media the media matcher\r\n   * @param translate the translate service\r\n   */\r\n  constructor(\r\n    private changeDetectorRef: ChangeDetectorRef,\r\n    private media: MediaMatcher,\r\n    private translate: TranslateService) {\r\n    this.mobileQuery = media.matchMedia('(max-width: 959px)');\r\n    this._mobileQueryListener = () => {\r\n      changeDetectorRef.detectChanges();\r\n    };\r\n    // below if statement is for edge support since addEventListener doesn't exist for MediaQueryLists\r\n    if (this.mobileQuery.addEventListener) {\r\n      this.mobileQuery.addEventListener('change', this._mobileQueryListener);\r\n    }\r\n    else {\r\n      this.mobileQuery.addListener(this._mobileQueryListener);\r\n    }\r\n  }\r\n\r\n  /** On Init - configure the settings */\r\n  public ngOnInit(): void {\r\n    // basic settings\r\n    this.settings.fontAwesomeMenuIcon ? this.fontAwesomeMenuIcon = this.settings.fontAwesomeMenuIcon : this.fontAwesomeMenuIcon = 'fas fa-bars';\r\n    this.settings.mainMenuText ? this.mainMenuText = this.settings.mainMenuText : this.mainMenuText = 'Main Menu';\r\n    this.settings.headerHeight ? this.headerHeight = this.settings.headerHeight : this.headerHeight = 60;\r\n    this.settings.menuButtonSRText ? this.menuButtonSRText = this.settings.menuButtonSRText : this.menuButtonSRText = 'Menu Button';\r\n\r\n    // advanced settings\r\n    this.advancedSettings.topGapDesktop ? this.topGapDesktop = this.advancedSettings.topGapDesktop : this.topGapDesktop = 0;\r\n    this.advancedSettings.topGapMobile ? this.topGapMobile = this.advancedSettings.topGapMobile : this.topGapMobile = this.headerHeight;\r\n    this.advancedSettings.marginTopDesktop ? this.marginTopDesktop = this.advancedSettings.marginTopDesktop : this.marginTopDesktop = 0;\r\n    this.advancedSettings.marginTopMobile ? this.marginTopMobile = this.advancedSettings.marginTopMobile : this.marginTopMobile = 0;\r\n\r\n    // theme settings\r\n    this.themeSettings.contentBgColor ? this.setThemeColor('content-bg-color', this.themeSettings.contentBgColor) : undefined;\r\n    this.themeSettings.fontColor ? this.setThemeColor('font-color', this.themeSettings.fontColor) : undefined;\r\n    this.themeSettings.bgGradientColor1 ? this.setThemeColor('bg-gradient-color-1', this.themeSettings.bgGradientColor1) : undefined;\r\n    this.themeSettings.bgGradientColor2 ? this.setThemeColor('bg-gradient-color-2', this.themeSettings.bgGradientColor2) : undefined;\r\n    this.themeSettings.borderRightColor ? this.setThemeColor('border-right-color', this.themeSettings.borderRightColor) : undefined;\r\n    this.themeSettings.listBorderColor ? this.setThemeColor('list-border-color', this.themeSettings.listBorderColor) : undefined;\r\n    this.themeSettings.highlightGradient1 ? this.setThemeColor('highlight-gradient-1', this.themeSettings.highlightGradient1) : undefined;\r\n    this.themeSettings.highlightGradient2 ? this.setThemeColor('highlight-gradient-2', this.themeSettings.highlightGradient2) : undefined;\r\n    this.themeSettings.subHighlightBorderColor ?\r\n      this.setThemeColor('sub-highlight-border-color', this.themeSettings.subHighlightBorderColor) : undefined;\r\n    this.themeSettings.subHighlightBgColor ?\r\n      this.setThemeColor('sub-highlight-bg-color', this.themeSettings.subHighlightBgColor) : undefined;\r\n  }\r\n\r\n  /** On Destroy */\r\n  public ngOnDestroy(): void {\r\n    this.mobileQuery.removeEventListener('change', this._mobileQueryListener);\r\n  }\r\n\r\n  /**\r\n   * Mobile SubNav - open the SubNav\r\n   * @param nav the nav data to be passed to the SubNav\r\n   */\r\n  public openMobileSubNav(nav: NavNode): void {\r\n    this.isMobileSubNavOpen = true;\r\n    this.currentMobileNav = nav;\r\n  }\r\n\r\n  /**\r\n   * Mobile SubNav - closes the SubNav\r\n   */\r\n  public closeMobileSubNav(): void {\r\n    this.isMobileSubNavOpen = false;\r\n  }\r\n\r\n  /**\r\n   * Sets the theme color\r\n   * @param variable the css variable name\r\n   * @param color the color\r\n   */\r\n  public setThemeColor(variable: string, color: string): void {\r\n    document.documentElement.style.setProperty(`--sof-nav-${variable}`, color);\r\n  }\r\n}\r\n"]}
242
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation.component.js","sourceRoot":"ng://@softheon/armature/","sources":["lib/navigation/components/navigation/navigation.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { MediaMatcher } from '@angular/cdk/layout';\r\nimport { ChangeDetectorRef, Component, Input, OnDestroy, OnInit, ViewChild } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\n\r\nimport { MatSidenav } from '@angular/material';\r\nimport { NavigationAdvancedSettings, NavigationSettings, NavigationThemeSettings, NavNode } from '../../models/nav-models-api';\r\n\r\n/**\r\n * The Navigation Component\r\n */\r\n@Component({\r\n  selector: 'sof-ar-navigation',\r\n  templateUrl: './navigation.component.html',\r\n  styleUrls: ['./navigation.component.scss']\r\n})\r\nexport class ArmatureNavigationComponent implements OnInit, OnDestroy {\r\n  /** The side mobile nav */\r\n  @ViewChild('snav', { static: false }) public sidenav: MatSidenav;\r\n\r\n  /** Component Input - the navigation data */\r\n  @Input() public navigationData: NavNode[];\r\n\r\n  /** Component Input - the navigation settings */\r\n  @Input() public settings: NavigationSettings = {};\r\n\r\n  /** Component Input - the navigation settings */\r\n  @Input() public advancedSettings: NavigationAdvancedSettings = {};\r\n\r\n  /** Component Input - the navigation settings */\r\n  @Input() public themeSettings: NavigationThemeSettings = {};\r\n\r\n  /** Mobile SubNav - whether or not the mobile SubNav is open */\r\n  public isMobileSubNavOpen: boolean = false;\r\n\r\n  /** Mobile SubNav -the data to be passed to the mobile SubNav */\r\n  public currentMobileNav: NavNode;\r\n\r\n  /** Settings - the font awesome menu icon */\r\n  public fontAwesomeMenuIcon: string;\r\n\r\n  /** Settings - the top gap on desktop screens for the MD component */\r\n  public topGapDesktop: number;\r\n\r\n  /** Settings - the top gap on mobile screens for the MD component */\r\n  public topGapMobile: number;\r\n\r\n  /** Settings - the margin on desktop screens for the MD component */\r\n  public marginTopDesktop: number;\r\n\r\n  /** Settings - the margin on mobile screens for the MD component */\r\n  public marginTopMobile: number;\r\n\r\n  /** Settings - the main menu text that appears in the mobile SubNav */\r\n  public mainMenuText: string;\r\n\r\n  /** Settings - the header height */\r\n  public headerHeight: number;\r\n\r\n  /** Settings - the menu button screen reader text */\r\n  public menuButtonSRText: string;\r\n\r\n  /** the mobile query */\r\n  public mobileQuery: MediaQueryList;\r\n\r\n  /** the mobile query listener */\r\n  private readonly _mobileQueryListener: () => void;\r\n\r\n  /**\r\n   * the constructor\r\n   * @param changeDetectorRef the change detector reference\r\n   * @param media the media matcher\r\n   * @param translate the translate service\r\n   */\r\n  constructor(\r\n    private changeDetectorRef: ChangeDetectorRef,\r\n    private media: MediaMatcher,\r\n    private translate: TranslateService) {\r\n    this.mobileQuery = media.matchMedia('(max-width: 959px)');\r\n    this._mobileQueryListener = () => {\r\n      changeDetectorRef.detectChanges();\r\n    };\r\n    // below if statement is for edge support since addEventListener doesn't exist for MediaQueryLists\r\n    if (this.mobileQuery.addEventListener) {\r\n      this.mobileQuery.addEventListener('change', this._mobileQueryListener);\r\n    }\r\n    else {\r\n      this.mobileQuery.addListener(this._mobileQueryListener);\r\n    }\r\n  }\r\n\r\n  /** On Init - configure the settings */\r\n  public ngOnInit(): void {\r\n    // basic settings\r\n    this.settings.fontAwesomeMenuIcon ? this.fontAwesomeMenuIcon = this.settings.fontAwesomeMenuIcon : this.fontAwesomeMenuIcon = 'fas fa-bars';\r\n    this.settings.mainMenuText ? this.mainMenuText = this.settings.mainMenuText : this.mainMenuText = 'Main Menu';\r\n    this.settings.headerHeight ? this.headerHeight = this.settings.headerHeight : this.headerHeight = 60;\r\n    this.settings.menuButtonSRText ? this.menuButtonSRText = this.settings.menuButtonSRText : this.menuButtonSRText = 'Menu Button';\r\n\r\n    // advanced settings\r\n    this.advancedSettings.topGapDesktop ? this.topGapDesktop = this.advancedSettings.topGapDesktop : this.topGapDesktop = 0;\r\n    this.advancedSettings.topGapMobile ? this.topGapMobile = this.advancedSettings.topGapMobile : this.topGapMobile = this.headerHeight;\r\n    this.advancedSettings.marginTopDesktop ? this.marginTopDesktop = this.advancedSettings.marginTopDesktop : this.marginTopDesktop = 0;\r\n    this.advancedSettings.marginTopMobile ? this.marginTopMobile = this.advancedSettings.marginTopMobile : this.marginTopMobile = 0;\r\n\r\n    // theme settings\r\n    this.themeSettings.contentBgColor ? this.setThemeColor('content-bg-color', this.themeSettings.contentBgColor) : undefined;\r\n    this.themeSettings.fontColor ? this.setThemeColor('font-color', this.themeSettings.fontColor) : undefined;\r\n    this.themeSettings.bgGradientColor1 ? this.setThemeColor('bg-gradient-color-1', this.themeSettings.bgGradientColor1) : undefined;\r\n    this.themeSettings.bgGradientColor2 ? this.setThemeColor('bg-gradient-color-2', this.themeSettings.bgGradientColor2) : undefined;\r\n    this.themeSettings.borderRightColor ? this.setThemeColor('border-right-color', this.themeSettings.borderRightColor) : undefined;\r\n    this.themeSettings.listBorderColor ? this.setThemeColor('list-border-color', this.themeSettings.listBorderColor) : undefined;\r\n    this.themeSettings.highlightGradient1 ? this.setThemeColor('highlight-gradient-1', this.themeSettings.highlightGradient1) : undefined;\r\n    this.themeSettings.highlightGradient2 ? this.setThemeColor('highlight-gradient-2', this.themeSettings.highlightGradient2) : undefined;\r\n    this.themeSettings.subHighlightBorderColor ?\r\n      this.setThemeColor('sub-highlight-border-color', this.themeSettings.subHighlightBorderColor) : undefined;\r\n    this.themeSettings.subHighlightBgColor ?\r\n      this.setThemeColor('sub-highlight-bg-color', this.themeSettings.subHighlightBgColor) : undefined;\r\n  }\r\n\r\n  /** On Destroy */\r\n  public ngOnDestroy(): void {\r\n    this.mobileQuery.removeEventListener('change', this._mobileQueryListener);\r\n  }\r\n\r\n  /**\r\n   * Mobile SubNav - open the SubNav\r\n   * @param nav the nav data to be passed to the SubNav\r\n   */\r\n  public openMobileSubNav(nav: NavNode): void {\r\n    this.isMobileSubNavOpen = true;\r\n    this.currentMobileNav = nav;\r\n    this.sidenav.open();\r\n  }\r\n\r\n  /**\r\n   * Mobile SubNav - closes the SubNav\r\n   */\r\n  public closeMobileSubNav(): void {\r\n    this.isMobileSubNavOpen = false;\r\n    this.sidenav.close();\r\n  }\r\n\r\n  /**\r\n   * Sets the theme color\r\n   * @param variable the css variable name\r\n   * @param color the color\r\n   */\r\n  public setThemeColor(variable: string, color: string): void {\r\n    document.documentElement.style.setProperty(`--sof-nav-${variable}`, color);\r\n  }\r\n}\r\n"]}
@@ -3,9 +3,10 @@
3
3
  * Generated from: lib/navigation/components/navigation/navigation.component.ts
4
4
  * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
5
5
  */
6
- import { Component, ChangeDetectorRef, Input } from '@angular/core';
7
6
  import { MediaMatcher } from '@angular/cdk/layout';
7
+ import { ChangeDetectorRef, Component, Input, ViewChild } from '@angular/core';
8
8
  import { TranslateService } from '@ngx-translate/core';
9
+ import { MatSidenav } from '@angular/material';
9
10
  /**
10
11
  * The Navigation Component
11
12
  */
@@ -114,6 +115,7 @@ var ArmatureNavigationComponent = /** @class */ (function () {
114
115
  function (nav) {
115
116
  this.isMobileSubNavOpen = true;
116
117
  this.currentMobileNav = nav;
118
+ this.sidenav.open();
117
119
  };
118
120
  /**
119
121
  * Mobile SubNav - closes the SubNav
@@ -128,6 +130,7 @@ var ArmatureNavigationComponent = /** @class */ (function () {
128
130
  */
129
131
  function () {
130
132
  this.isMobileSubNavOpen = false;
133
+ this.sidenav.close();
131
134
  };
132
135
  /**
133
136
  * Sets the theme color
@@ -163,6 +166,7 @@ var ArmatureNavigationComponent = /** @class */ (function () {
163
166
  { type: TranslateService }
164
167
  ]; };
165
168
  ArmatureNavigationComponent.propDecorators = {
169
+ sidenav: [{ type: ViewChild, args: ['snav', { static: false },] }],
166
170
  navigationData: [{ type: Input }],
167
171
  settings: [{ type: Input }],
168
172
  advancedSettings: [{ type: Input }],
@@ -172,6 +176,11 @@ var ArmatureNavigationComponent = /** @class */ (function () {
172
176
  }());
173
177
  export { ArmatureNavigationComponent };
174
178
  if (false) {
179
+ /**
180
+ * The side mobile nav
181
+ * @type {?}
182
+ */
183
+ ArmatureNavigationComponent.prototype.sidenav;
175
184
  /**
176
185
  * Component Input - the navigation data
177
186
  * @type {?}
@@ -269,4 +278,4 @@ if (false) {
269
278
  */
270
279
  ArmatureNavigationComponent.prototype.translate;
271
280
  }
272
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation.component.js","sourceRoot":"ng://@softheon/armature/","sources":["lib/navigation/components/navigation/navigation.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, OnDestroy, ChangeDetectorRef, ViewEncapsulation, Input } from '@angular/core';\r\nimport { MediaMatcher } from '@angular/cdk/layout';\r\nimport { TranslateService } from '@ngx-translate/core';\r\n\r\nimport { NavNode, NavigationSettings, NavigationAdvancedSettings, NavigationThemeSettings } from '../../models/nav-models-api';\r\n\r\n/**\r\n * The Navigation Component\r\n */\r\n@Component({\r\n  selector: 'sof-ar-navigation',\r\n  templateUrl: './navigation.component.html',\r\n  styleUrls: ['./navigation.component.scss']\r\n})\r\nexport class ArmatureNavigationComponent implements OnInit, OnDestroy {\r\n\r\n  /** Component Input - the navigation data */\r\n  @Input() public navigationData: NavNode[];\r\n\r\n  /** Component Input - the navigation settings */\r\n  @Input() public settings: NavigationSettings = {};\r\n\r\n  /** Component Input - the navigation settings */\r\n  @Input() public advancedSettings: NavigationAdvancedSettings = {};\r\n\r\n  /** Component Input - the navigation settings */\r\n  @Input() public themeSettings: NavigationThemeSettings = {};\r\n\r\n  /** Mobile SubNav - whether or not the mobile SubNav is open */\r\n  public isMobileSubNavOpen: boolean = false;\r\n\r\n  /** Mobile SubNav -the data to be passed to the mobile SubNav */\r\n  public currentMobileNav: NavNode;\r\n\r\n  /** Settings - the font awesome menu icon */\r\n  public fontAwesomeMenuIcon: string;\r\n\r\n  /** Settings - the top gap on desktop screens for the MD component */\r\n  public topGapDesktop: number;\r\n\r\n  /** Settings - the top gap on mobile screens for the MD component */\r\n  public topGapMobile: number;\r\n\r\n  /** Settings - the margin on desktop screens for the MD component */\r\n  public marginTopDesktop: number;\r\n\r\n  /** Settings - the margin on mobile screens for the MD component */\r\n  public marginTopMobile: number;\r\n\r\n  /** Settings - the main menu text that appears in the mobile SubNav */\r\n  public mainMenuText: string;\r\n\r\n  /** Settings - the header height */\r\n  public headerHeight: number;\r\n\r\n  /** Settings - the menu button screen reader text */\r\n  public menuButtonSRText: string;\r\n\r\n  /** the mobile query */\r\n  public mobileQuery: MediaQueryList;\r\n\r\n  /** the mobile query listener */\r\n  private readonly _mobileQueryListener: () => void;\r\n\r\n  /**\r\n   * the constructor\r\n   * @param changeDetectorRef the change detector reference\r\n   * @param media the media matcher\r\n   * @param translate the translate service\r\n   */\r\n  constructor(\r\n    private changeDetectorRef: ChangeDetectorRef,\r\n    private media: MediaMatcher,\r\n    private translate: TranslateService) {\r\n    this.mobileQuery = media.matchMedia('(max-width: 959px)');\r\n    this._mobileQueryListener = () => {\r\n      changeDetectorRef.detectChanges();\r\n    };\r\n    // below if statement is for edge support since addEventListener doesn't exist for MediaQueryLists\r\n    if (this.mobileQuery.addEventListener) {\r\n      this.mobileQuery.addEventListener('change', this._mobileQueryListener);\r\n    }\r\n    else {\r\n      this.mobileQuery.addListener(this._mobileQueryListener);\r\n    }\r\n  }\r\n\r\n  /** On Init - configure the settings */\r\n  public ngOnInit(): void {\r\n    // basic settings\r\n    this.settings.fontAwesomeMenuIcon ? this.fontAwesomeMenuIcon = this.settings.fontAwesomeMenuIcon : this.fontAwesomeMenuIcon = 'fas fa-bars';\r\n    this.settings.mainMenuText ? this.mainMenuText = this.settings.mainMenuText : this.mainMenuText = 'Main Menu';\r\n    this.settings.headerHeight ? this.headerHeight = this.settings.headerHeight : this.headerHeight = 60;\r\n    this.settings.menuButtonSRText ? this.menuButtonSRText = this.settings.menuButtonSRText : this.menuButtonSRText = 'Menu Button';\r\n\r\n    // advanced settings\r\n    this.advancedSettings.topGapDesktop ? this.topGapDesktop = this.advancedSettings.topGapDesktop : this.topGapDesktop = 0;\r\n    this.advancedSettings.topGapMobile ? this.topGapMobile = this.advancedSettings.topGapMobile : this.topGapMobile = this.headerHeight;\r\n    this.advancedSettings.marginTopDesktop ? this.marginTopDesktop = this.advancedSettings.marginTopDesktop : this.marginTopDesktop = 0;\r\n    this.advancedSettings.marginTopMobile ? this.marginTopMobile = this.advancedSettings.marginTopMobile : this.marginTopMobile = 0;\r\n\r\n    // theme settings\r\n    this.themeSettings.contentBgColor ? this.setThemeColor('content-bg-color', this.themeSettings.contentBgColor) : undefined;\r\n    this.themeSettings.fontColor ? this.setThemeColor('font-color', this.themeSettings.fontColor) : undefined;\r\n    this.themeSettings.bgGradientColor1 ? this.setThemeColor('bg-gradient-color-1', this.themeSettings.bgGradientColor1) : undefined;\r\n    this.themeSettings.bgGradientColor2 ? this.setThemeColor('bg-gradient-color-2', this.themeSettings.bgGradientColor2) : undefined;\r\n    this.themeSettings.borderRightColor ? this.setThemeColor('border-right-color', this.themeSettings.borderRightColor) : undefined;\r\n    this.themeSettings.listBorderColor ? this.setThemeColor('list-border-color', this.themeSettings.listBorderColor) : undefined;\r\n    this.themeSettings.highlightGradient1 ? this.setThemeColor('highlight-gradient-1', this.themeSettings.highlightGradient1) : undefined;\r\n    this.themeSettings.highlightGradient2 ? this.setThemeColor('highlight-gradient-2', this.themeSettings.highlightGradient2) : undefined;\r\n    this.themeSettings.subHighlightBorderColor ?\r\n      this.setThemeColor('sub-highlight-border-color', this.themeSettings.subHighlightBorderColor) : undefined;\r\n    this.themeSettings.subHighlightBgColor ?\r\n      this.setThemeColor('sub-highlight-bg-color', this.themeSettings.subHighlightBgColor) : undefined;\r\n  }\r\n\r\n  /** On Destroy */\r\n  public ngOnDestroy(): void {\r\n    this.mobileQuery.removeEventListener('change', this._mobileQueryListener);\r\n  }\r\n\r\n  /**\r\n   * Mobile SubNav - open the SubNav\r\n   * @param nav the nav data to be passed to the SubNav\r\n   */\r\n  public openMobileSubNav(nav: NavNode): void {\r\n    this.isMobileSubNavOpen = true;\r\n    this.currentMobileNav = nav;\r\n  }\r\n\r\n  /**\r\n   * Mobile SubNav - closes the SubNav\r\n   */\r\n  public closeMobileSubNav(): void {\r\n    this.isMobileSubNavOpen = false;\r\n  }\r\n\r\n  /**\r\n   * Sets the theme color\r\n   * @param variable the css variable name\r\n   * @param color the color\r\n   */\r\n  public setThemeColor(variable: string, color: string): void {\r\n    document.documentElement.style.setProperty(`--sof-nav-${variable}`, color);\r\n  }\r\n}\r\n"]}
281
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation.component.js","sourceRoot":"ng://@softheon/armature/","sources":["lib/navigation/components/navigation/navigation.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { MediaMatcher } from '@angular/cdk/layout';\r\nimport { ChangeDetectorRef, Component, Input, OnDestroy, OnInit, ViewChild } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\n\r\nimport { MatSidenav } from '@angular/material';\r\nimport { NavigationAdvancedSettings, NavigationSettings, NavigationThemeSettings, NavNode } from '../../models/nav-models-api';\r\n\r\n/**\r\n * The Navigation Component\r\n */\r\n@Component({\r\n  selector: 'sof-ar-navigation',\r\n  templateUrl: './navigation.component.html',\r\n  styleUrls: ['./navigation.component.scss']\r\n})\r\nexport class ArmatureNavigationComponent implements OnInit, OnDestroy {\r\n  /** The side mobile nav */\r\n  @ViewChild('snav', { static: false }) public sidenav: MatSidenav;\r\n\r\n  /** Component Input - the navigation data */\r\n  @Input() public navigationData: NavNode[];\r\n\r\n  /** Component Input - the navigation settings */\r\n  @Input() public settings: NavigationSettings = {};\r\n\r\n  /** Component Input - the navigation settings */\r\n  @Input() public advancedSettings: NavigationAdvancedSettings = {};\r\n\r\n  /** Component Input - the navigation settings */\r\n  @Input() public themeSettings: NavigationThemeSettings = {};\r\n\r\n  /** Mobile SubNav - whether or not the mobile SubNav is open */\r\n  public isMobileSubNavOpen: boolean = false;\r\n\r\n  /** Mobile SubNav -the data to be passed to the mobile SubNav */\r\n  public currentMobileNav: NavNode;\r\n\r\n  /** Settings - the font awesome menu icon */\r\n  public fontAwesomeMenuIcon: string;\r\n\r\n  /** Settings - the top gap on desktop screens for the MD component */\r\n  public topGapDesktop: number;\r\n\r\n  /** Settings - the top gap on mobile screens for the MD component */\r\n  public topGapMobile: number;\r\n\r\n  /** Settings - the margin on desktop screens for the MD component */\r\n  public marginTopDesktop: number;\r\n\r\n  /** Settings - the margin on mobile screens for the MD component */\r\n  public marginTopMobile: number;\r\n\r\n  /** Settings - the main menu text that appears in the mobile SubNav */\r\n  public mainMenuText: string;\r\n\r\n  /** Settings - the header height */\r\n  public headerHeight: number;\r\n\r\n  /** Settings - the menu button screen reader text */\r\n  public menuButtonSRText: string;\r\n\r\n  /** the mobile query */\r\n  public mobileQuery: MediaQueryList;\r\n\r\n  /** the mobile query listener */\r\n  private readonly _mobileQueryListener: () => void;\r\n\r\n  /**\r\n   * the constructor\r\n   * @param changeDetectorRef the change detector reference\r\n   * @param media the media matcher\r\n   * @param translate the translate service\r\n   */\r\n  constructor(\r\n    private changeDetectorRef: ChangeDetectorRef,\r\n    private media: MediaMatcher,\r\n    private translate: TranslateService) {\r\n    this.mobileQuery = media.matchMedia('(max-width: 959px)');\r\n    this._mobileQueryListener = () => {\r\n      changeDetectorRef.detectChanges();\r\n    };\r\n    // below if statement is for edge support since addEventListener doesn't exist for MediaQueryLists\r\n    if (this.mobileQuery.addEventListener) {\r\n      this.mobileQuery.addEventListener('change', this._mobileQueryListener);\r\n    }\r\n    else {\r\n      this.mobileQuery.addListener(this._mobileQueryListener);\r\n    }\r\n  }\r\n\r\n  /** On Init - configure the settings */\r\n  public ngOnInit(): void {\r\n    // basic settings\r\n    this.settings.fontAwesomeMenuIcon ? this.fontAwesomeMenuIcon = this.settings.fontAwesomeMenuIcon : this.fontAwesomeMenuIcon = 'fas fa-bars';\r\n    this.settings.mainMenuText ? this.mainMenuText = this.settings.mainMenuText : this.mainMenuText = 'Main Menu';\r\n    this.settings.headerHeight ? this.headerHeight = this.settings.headerHeight : this.headerHeight = 60;\r\n    this.settings.menuButtonSRText ? this.menuButtonSRText = this.settings.menuButtonSRText : this.menuButtonSRText = 'Menu Button';\r\n\r\n    // advanced settings\r\n    this.advancedSettings.topGapDesktop ? this.topGapDesktop = this.advancedSettings.topGapDesktop : this.topGapDesktop = 0;\r\n    this.advancedSettings.topGapMobile ? this.topGapMobile = this.advancedSettings.topGapMobile : this.topGapMobile = this.headerHeight;\r\n    this.advancedSettings.marginTopDesktop ? this.marginTopDesktop = this.advancedSettings.marginTopDesktop : this.marginTopDesktop = 0;\r\n    this.advancedSettings.marginTopMobile ? this.marginTopMobile = this.advancedSettings.marginTopMobile : this.marginTopMobile = 0;\r\n\r\n    // theme settings\r\n    this.themeSettings.contentBgColor ? this.setThemeColor('content-bg-color', this.themeSettings.contentBgColor) : undefined;\r\n    this.themeSettings.fontColor ? this.setThemeColor('font-color', this.themeSettings.fontColor) : undefined;\r\n    this.themeSettings.bgGradientColor1 ? this.setThemeColor('bg-gradient-color-1', this.themeSettings.bgGradientColor1) : undefined;\r\n    this.themeSettings.bgGradientColor2 ? this.setThemeColor('bg-gradient-color-2', this.themeSettings.bgGradientColor2) : undefined;\r\n    this.themeSettings.borderRightColor ? this.setThemeColor('border-right-color', this.themeSettings.borderRightColor) : undefined;\r\n    this.themeSettings.listBorderColor ? this.setThemeColor('list-border-color', this.themeSettings.listBorderColor) : undefined;\r\n    this.themeSettings.highlightGradient1 ? this.setThemeColor('highlight-gradient-1', this.themeSettings.highlightGradient1) : undefined;\r\n    this.themeSettings.highlightGradient2 ? this.setThemeColor('highlight-gradient-2', this.themeSettings.highlightGradient2) : undefined;\r\n    this.themeSettings.subHighlightBorderColor ?\r\n      this.setThemeColor('sub-highlight-border-color', this.themeSettings.subHighlightBorderColor) : undefined;\r\n    this.themeSettings.subHighlightBgColor ?\r\n      this.setThemeColor('sub-highlight-bg-color', this.themeSettings.subHighlightBgColor) : undefined;\r\n  }\r\n\r\n  /** On Destroy */\r\n  public ngOnDestroy(): void {\r\n    this.mobileQuery.removeEventListener('change', this._mobileQueryListener);\r\n  }\r\n\r\n  /**\r\n   * Mobile SubNav - open the SubNav\r\n   * @param nav the nav data to be passed to the SubNav\r\n   */\r\n  public openMobileSubNav(nav: NavNode): void {\r\n    this.isMobileSubNavOpen = true;\r\n    this.currentMobileNav = nav;\r\n    this.sidenav.open();\r\n  }\r\n\r\n  /**\r\n   * Mobile SubNav - closes the SubNav\r\n   */\r\n  public closeMobileSubNav(): void {\r\n    this.isMobileSubNavOpen = false;\r\n    this.sidenav.close();\r\n  }\r\n\r\n  /**\r\n   * Sets the theme color\r\n   * @param variable the css variable name\r\n   * @param color the color\r\n   */\r\n  public setThemeColor(variable: string, color: string): void {\r\n    document.documentElement.style.setProperty(`--sof-nav-${variable}`, color);\r\n  }\r\n}\r\n"]}
@@ -1,4 +1,4 @@
1
- import { InjectionToken, Injectable, Optional, Inject, ɵɵdefineInjectable, ɵɵinject, Component, Input, NgModule, Directive, ElementRef, HostListener, EventEmitter, Output, ChangeDetectorRef, Injector, ViewChild, TemplateRef, ViewContainerRef, INJECTOR, ErrorHandler } from '@angular/core';
1
+ import { InjectionToken, Injectable, Optional, Inject, ɵɵdefineInjectable, ɵɵinject, Component, Input, NgModule, Directive, ElementRef, HostListener, EventEmitter, Output, ChangeDetectorRef, ViewChild, Injector, TemplateRef, ViewContainerRef, INJECTOR, ErrorHandler } from '@angular/core';
2
2
  import { HttpHeaders, HttpClient, HttpClientModule } from '@angular/common/http';
3
3
  import { OAuthService, OAuthModule } from 'angular-oauth2-oidc';
4
4
  import { of, BehaviorSubject, Observable, ReplaySubject, Subscription } from 'rxjs';
@@ -3911,6 +3911,7 @@ class ArmatureNavigationComponent {
3911
3911
  openMobileSubNav(nav) {
3912
3912
  this.isMobileSubNavOpen = true;
3913
3913
  this.currentMobileNav = nav;
3914
+ this.sidenav.open();
3914
3915
  }
3915
3916
  /**
3916
3917
  * Mobile SubNav - closes the SubNav
@@ -3918,6 +3919,7 @@ class ArmatureNavigationComponent {
3918
3919
  */
3919
3920
  closeMobileSubNav() {
3920
3921
  this.isMobileSubNavOpen = false;
3922
+ this.sidenav.close();
3921
3923
  }
3922
3924
  /**
3923
3925
  * Sets the theme color
@@ -3943,12 +3945,18 @@ ArmatureNavigationComponent.ctorParameters = () => [
3943
3945
  { type: TranslateService }
3944
3946
  ];
3945
3947
  ArmatureNavigationComponent.propDecorators = {
3948
+ sidenav: [{ type: ViewChild, args: ['snav', { static: false },] }],
3946
3949
  navigationData: [{ type: Input }],
3947
3950
  settings: [{ type: Input }],
3948
3951
  advancedSettings: [{ type: Input }],
3949
3952
  themeSettings: [{ type: Input }]
3950
3953
  };
3951
3954
  if (false) {
3955
+ /**
3956
+ * The side mobile nav
3957
+ * @type {?}
3958
+ */
3959
+ ArmatureNavigationComponent.prototype.sidenav;
3952
3960
  /**
3953
3961
  * Component Input - the navigation data
3954
3962
  * @type {?}