@theseam/ui-common 0.4.1 → 0.4.2
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.
- package/esm2020/datatable/datatable-action-menu/datatable-action-menu.component.mjs +1 -1
- package/esm2020/datatable/datatable-column-preferences-button/datatable-column-preferences-button.component.mjs +1 -1
- package/esm2020/datatable/datatable-export-button/datatable-export-button.component.mjs +1 -1
- package/esm2020/datatable-dynamic/datatable-dynamic-action-menu/datatable-dynamic-action-menu.component.mjs +1 -1
- package/esm2020/framework/schema-form-controls/schema-form-submit-split/schema-form-submit-split.component.mjs +1 -1
- package/esm2020/framework/top-bar/top-bar.component.mjs +1 -1
- package/esm2020/google-maps/google-maps/google-maps.component.mjs +32 -8
- package/esm2020/google-maps/google-maps-feature-helpers.mjs +13 -1
- package/esm2020/google-maps/google-maps.module.mjs +4 -2
- package/esm2020/google-maps/google-maps.service.mjs +96 -25
- package/esm2020/menu/menu-item.component.mjs +43 -15
- package/esm2020/menu/menu-toggle.directive.mjs +202 -43
- package/esm2020/menu/menu.component.mjs +37 -14
- package/esm2020/utils/geo-json/close-polygons.mjs +38 -0
- package/esm2020/utils/public-api.mjs +2 -1
- package/esm2020/widget/widget/widget.component.mjs +54 -33
- package/fesm2015/theseam-ui-common-datatable-dynamic.mjs +1 -1
- package/fesm2015/theseam-ui-common-datatable-dynamic.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-datatable.mjs +3 -3
- package/fesm2015/theseam-ui-common-datatable.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-framework.mjs +2 -2
- package/fesm2015/theseam-ui-common-framework.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-google-maps.mjs +138 -28
- package/fesm2015/theseam-ui-common-google-maps.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-menu.mjs +442 -228
- package/fesm2015/theseam-ui-common-menu.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-utils.mjs +39 -1
- package/fesm2015/theseam-ui-common-utils.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-widget.mjs +53 -32
- package/fesm2015/theseam-ui-common-widget.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-datatable-dynamic.mjs +1 -1
- package/fesm2020/theseam-ui-common-datatable-dynamic.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-datatable.mjs +3 -3
- package/fesm2020/theseam-ui-common-datatable.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-framework.mjs +2 -2
- package/fesm2020/theseam-ui-common-framework.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-google-maps.mjs +141 -32
- package/fesm2020/theseam-ui-common-google-maps.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-menu.mjs +432 -225
- package/fesm2020/theseam-ui-common-menu.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-utils.mjs +39 -1
- package/fesm2020/theseam-ui-common-utils.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-widget.mjs +53 -32
- package/fesm2020/theseam-ui-common-widget.mjs.map +1 -1
- package/google-maps/google-maps/google-maps.component.d.ts +8 -1
- package/google-maps/google-maps-feature-helpers.d.ts +3 -0
- package/google-maps/google-maps.module.d.ts +1 -1
- package/google-maps/google-maps.service.d.ts +7 -0
- package/menu/menu-item.component.d.ts +20 -9
- package/menu/menu-toggle.directive.d.ts +34 -11
- package/menu/menu.component.d.ts +16 -2
- package/package.json +1 -1
- package/utils/geo-json/close-polygons.d.ts +9 -0
- package/utils/public-api.d.ts +1 -0
- package/widget/widget/widget.component.d.ts +10 -11
- package/widget/widget/widget.component.scss +12 -1
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { DOCUMENT } from '@angular/common';
|
|
2
2
|
import { ChangeDetectionStrategy, Component, HostListener, Inject, Input, Optional } from '@angular/core';
|
|
3
3
|
import { Subject } from 'rxjs';
|
|
4
|
+
import { faCaretRight } from '@fortawesome/free-solid-svg-icons';
|
|
4
5
|
import { mixinDisabled } from '@theseam/ui-common/core';
|
|
5
6
|
import { THESEAM_MENU_PANEL } from './menu-panel-token';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
@@ -11,25 +12,25 @@ class TheSeamMenuItemBase {
|
|
|
11
12
|
}
|
|
12
13
|
const _seamMenuItemMixinBase = mixinDisabled(TheSeamMenuItemBase);
|
|
13
14
|
export class MenuItemComponent extends _seamMenuItemMixinBase {
|
|
14
|
-
constructor(_elementRef,
|
|
15
|
+
constructor(_elementRef, _document, _focusMonitor, _changeDetectorRef, _parentMenu) {
|
|
15
16
|
super();
|
|
16
17
|
this._elementRef = _elementRef;
|
|
17
|
-
this.
|
|
18
|
+
this._document = _document;
|
|
18
19
|
this._focusMonitor = _focusMonitor;
|
|
20
|
+
this._changeDetectorRef = _changeDetectorRef;
|
|
19
21
|
this._parentMenu = _parentMenu;
|
|
20
22
|
/** ARIA role for the menu item. */
|
|
21
23
|
this.role = 'menuitem';
|
|
24
|
+
this.sublevelIcon = faCaretRight;
|
|
22
25
|
this.badgeTheme = 'danger';
|
|
23
26
|
/** Stream that emits when the menu item is hovered. */
|
|
24
27
|
this._hovered = new Subject();
|
|
28
|
+
/** Stream that emits when the menu item is focused. */
|
|
29
|
+
this._focused = new Subject();
|
|
25
30
|
/** Whether the menu item is highlighted. */
|
|
26
31
|
this._highlighted = false;
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
// to show the focus style for menu items only when the focus was not caused by a
|
|
30
|
-
// mouse or touch interaction.
|
|
31
|
-
_focusMonitor.monitor(this._elementRef, false);
|
|
32
|
-
}
|
|
32
|
+
/** Whether the menu item acts as a trigger for a sub-menu. */
|
|
33
|
+
this._triggersSubmenu = false;
|
|
33
34
|
// console.log(this._parentMenu)
|
|
34
35
|
if (_parentMenu && _parentMenu.addItem) {
|
|
35
36
|
_parentMenu.addItem(this);
|
|
@@ -43,6 +44,15 @@ export class MenuItemComponent extends _seamMenuItemMixinBase {
|
|
|
43
44
|
this._parentMenu.removeItem(this);
|
|
44
45
|
}
|
|
45
46
|
this._hovered.complete();
|
|
47
|
+
this._focused.complete();
|
|
48
|
+
}
|
|
49
|
+
ngAfterViewInit() {
|
|
50
|
+
if (this._focusMonitor) {
|
|
51
|
+
// Start monitoring the element, so it gets the appropriate focused classes. We want
|
|
52
|
+
// to show the focus style for menu items only when the focus was not caused by a
|
|
53
|
+
// mouse or touch interaction.
|
|
54
|
+
this._focusMonitor.monitor(this._elementRef, false);
|
|
55
|
+
}
|
|
46
56
|
}
|
|
47
57
|
/** Focuses the menu item. */
|
|
48
58
|
focus(origin = 'program') {
|
|
@@ -52,6 +62,7 @@ export class MenuItemComponent extends _seamMenuItemMixinBase {
|
|
|
52
62
|
else {
|
|
53
63
|
this._getHostElement().focus();
|
|
54
64
|
}
|
|
65
|
+
this._focused.next(this);
|
|
55
66
|
}
|
|
56
67
|
/** Used to set the `tabindex`. */
|
|
57
68
|
_getTabIndex() {
|
|
@@ -75,7 +86,7 @@ export class MenuItemComponent extends _seamMenuItemMixinBase {
|
|
|
75
86
|
/** Gets the label to be used when determining whether the option should be focused. */
|
|
76
87
|
getLabel() {
|
|
77
88
|
const element = this._elementRef.nativeElement;
|
|
78
|
-
const textNodeType = this.
|
|
89
|
+
const textNodeType = this._document ? this._document.TEXT_NODE : 3;
|
|
79
90
|
let output = '';
|
|
80
91
|
if (element.childNodes) {
|
|
81
92
|
const length = element.childNodes.length;
|
|
@@ -90,22 +101,35 @@ export class MenuItemComponent extends _seamMenuItemMixinBase {
|
|
|
90
101
|
}
|
|
91
102
|
return output.trim();
|
|
92
103
|
}
|
|
104
|
+
_setHighlighted(isHighlighted) {
|
|
105
|
+
this._highlighted = isHighlighted;
|
|
106
|
+
this._changeDetectorRef?.markForCheck();
|
|
107
|
+
}
|
|
108
|
+
_setTriggersSubmenu(triggersSubmenu) {
|
|
109
|
+
this._triggersSubmenu = triggersSubmenu;
|
|
110
|
+
this._changeDetectorRef?.markForCheck();
|
|
111
|
+
}
|
|
112
|
+
_hasFocus() {
|
|
113
|
+
return this._document && this._document.activeElement === this._getHostElement();
|
|
114
|
+
}
|
|
93
115
|
}
|
|
94
|
-
MenuItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: MenuItemComponent, deps: [{ token: i0.ElementRef }, { token: DOCUMENT }, { token: i1.FocusMonitor }, { token: THESEAM_MENU_PANEL, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
95
|
-
MenuItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: MenuItemComponent, selector: "[seamMenuItem]", inputs: { disabled: "disabled", role: "role", icon: "icon", iconClass: "iconClass", badgeText: "badgeText", badgeTheme: "badgeTheme" }, host: { listeners: { "click": "_checkDisabled($event)", "mouseenter": "_handleMouseEnter()" }, properties: { "attr.role": "role", "attr.tabindex": "_getTabIndex()", "attr.aria-disabled": "disabled.toString()", "attr.disabled": "disabled || null" }, classAttribute: "dropdown-item" }, exportAs: ["seamMenuItem"], usesInheritance: true, ngImport: i0, template: "<div class=\"d-flex flex-row\">\n <seam-icon *ngIf=\"icon\"\n style=\"width: 30px; height: 20px; flex: 0 0 auto;\"\n class=\"pr-2\"\n [icon]=\"icon\"\n [iconClass]=\"iconClass\"\n iconType=\"image-fill\">\n </seam-icon>\n
|
|
116
|
+
MenuItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: MenuItemComponent, deps: [{ token: i0.ElementRef }, { token: DOCUMENT }, { token: i1.FocusMonitor }, { token: i0.ChangeDetectorRef }, { token: THESEAM_MENU_PANEL, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
117
|
+
MenuItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: MenuItemComponent, selector: "[seamMenuItem]", inputs: { disabled: "disabled", role: "role", icon: "icon", iconClass: "iconClass", sublevelIcon: "sublevelIcon", subLevelIconClass: "subLevelIconClass", badgeText: "badgeText", badgeTheme: "badgeTheme" }, host: { listeners: { "click": "_checkDisabled($event)", "mouseenter": "_handleMouseEnter()" }, properties: { "attr.role": "role", "class.seam-menu-item-highlighted": "_highlighted", "class.seam-menu-item-submenu-trigger": "_triggersSubmenu", "attr.tabindex": "_getTabIndex()", "attr.aria-disabled": "disabled.toString()", "attr.disabled": "disabled || null" }, classAttribute: "seam-menu-item dropdown-item" }, exportAs: ["seamMenuItem"], usesInheritance: true, ngImport: i0, template: "<div class=\"d-flex flex-row\">\n <seam-icon *ngIf=\"icon\"\n style=\"width: 30px; height: 20px; flex: 0 0 auto;\"\n class=\"pr-2\"\n [icon]=\"icon\"\n [iconClass]=\"iconClass\"\n iconType=\"image-fill\">\n </seam-icon>\n <div class=\"flex-fill\">\n <div class=\"text-truncate\">\n <ng-content></ng-content>\n </div>\n\n <div *ngIf=\"badgeText\">\n <span class=\"badge badge-pill{{ badgeTheme ? ' badge-' + badgeTheme : '' }} position-relative\"\n style=\"top: -8px\"\n >{{ badgeText }}</span>\n </div>\n </div>\n <seam-icon *ngIf=\"_triggersSubmenu\"\n style=\"width: 30px; height: 20px; flex: 0 0 auto;\"\n class=\"pl-2\"\n [icon]=\"sublevelIcon\"\n [iconClass]=\"subLevelIconClass\"\n iconType=\"image-fill\">\n </seam-icon>\n</div>\n", styles: [":host.cdk-mouse-focused:not(:hover){background:transparent}:host[aria-expanded]{color:#16181b;text-decoration:none;background-color:#e9ecef}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.IconComponent, selector: "seam-icon", inputs: ["grayscaleOnDisable", "disabled", "iconClass", "icon", "size", "showDefaultOnError", "defaultIcon", "iconType"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
96
118
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: MenuItemComponent, decorators: [{
|
|
97
119
|
type: Component,
|
|
98
120
|
args: [{ selector: '[seamMenuItem]', exportAs: 'seamMenuItem', inputs: ['disabled'], host: {
|
|
99
121
|
'[attr.role]': 'role',
|
|
100
|
-
'class': 'dropdown-item',
|
|
122
|
+
'class': 'seam-menu-item dropdown-item',
|
|
123
|
+
'[class.seam-menu-item-highlighted]': '_highlighted',
|
|
124
|
+
'[class.seam-menu-item-submenu-trigger]': '_triggersSubmenu',
|
|
101
125
|
'[attr.tabindex]': '_getTabIndex()',
|
|
102
126
|
'[attr.aria-disabled]': 'disabled.toString()',
|
|
103
127
|
'[attr.disabled]': 'disabled || null',
|
|
104
|
-
}, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"d-flex flex-row\">\n <seam-icon *ngIf=\"icon\"\n style=\"width: 30px; height: 20px; flex: 0 0 auto;\"\n class=\"pr-2\"\n [icon]=\"icon\"\n [iconClass]=\"iconClass\"\n iconType=\"image-fill\">\n </seam-icon>\n
|
|
128
|
+
}, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"d-flex flex-row\">\n <seam-icon *ngIf=\"icon\"\n style=\"width: 30px; height: 20px; flex: 0 0 auto;\"\n class=\"pr-2\"\n [icon]=\"icon\"\n [iconClass]=\"iconClass\"\n iconType=\"image-fill\">\n </seam-icon>\n <div class=\"flex-fill\">\n <div class=\"text-truncate\">\n <ng-content></ng-content>\n </div>\n\n <div *ngIf=\"badgeText\">\n <span class=\"badge badge-pill{{ badgeTheme ? ' badge-' + badgeTheme : '' }} position-relative\"\n style=\"top: -8px\"\n >{{ badgeText }}</span>\n </div>\n </div>\n <seam-icon *ngIf=\"_triggersSubmenu\"\n style=\"width: 30px; height: 20px; flex: 0 0 auto;\"\n class=\"pl-2\"\n [icon]=\"sublevelIcon\"\n [iconClass]=\"subLevelIconClass\"\n iconType=\"image-fill\">\n </seam-icon>\n</div>\n", styles: [":host.cdk-mouse-focused:not(:hover){background:transparent}:host[aria-expanded]{color:#16181b;text-decoration:none;background-color:#e9ecef}\n"] }]
|
|
105
129
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: undefined, decorators: [{
|
|
106
130
|
type: Inject,
|
|
107
131
|
args: [DOCUMENT]
|
|
108
|
-
}] }, { type: i1.FocusMonitor }, { type: undefined, decorators: [{
|
|
132
|
+
}] }, { type: i1.FocusMonitor }, { type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
|
|
109
133
|
type: Inject,
|
|
110
134
|
args: [THESEAM_MENU_PANEL]
|
|
111
135
|
}, {
|
|
@@ -116,6 +140,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
116
140
|
type: Input
|
|
117
141
|
}], iconClass: [{
|
|
118
142
|
type: Input
|
|
143
|
+
}], sublevelIcon: [{
|
|
144
|
+
type: Input
|
|
145
|
+
}], subLevelIconClass: [{
|
|
146
|
+
type: Input
|
|
119
147
|
}], badgeText: [{
|
|
120
148
|
type: Input
|
|
121
149
|
}], badgeTheme: [{
|
|
@@ -127,4 +155,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
127
155
|
type: HostListener,
|
|
128
156
|
args: ['mouseenter']
|
|
129
157
|
}] } });
|
|
130
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu-item.component.js","sourceRoot":"","sources":["../../../../projects/ui-common/menu/menu-item.component.ts","../../../../projects/ui-common/menu/menu-item.component.html"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAA;AAC1C,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAc,YAAY,EAAE,MAAM,EAAE,KAAK,EAAa,QAAQ,EAAE,MAAM,eAAe,CAAA;AAChI,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAA;AAE9B,OAAO,EAAkB,aAAa,EAAE,MAAM,yBAAyB,CAAA;AAIvE,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAA;;;;;AAEvD,MAAM,mBAAmB;CAAG;AAE5B,MAAM,sBAAsB,GACxB,aAAa,CAAC,mBAAmB,CAAC,CAAA;AAkBtC,MAAM,OAAO,iBAAkB,SAAQ,sBAAsB;IAiB3D,YACU,WAAoC,EACnB,QAAa,EAC9B,aAA2B,EACa,WAAkD;QAElG,KAAK,EAAE,CAAA;QALC,gBAAW,GAAX,WAAW,CAAyB;QACnB,aAAQ,GAAR,QAAQ,CAAK;QAC9B,kBAAa,GAAb,aAAa,CAAc;QACa,gBAAW,GAAX,WAAW,CAAuC;QAnBpG,mCAAmC;QAC1B,SAAI,GAAyE,UAAU,CAAA;QAMvF,eAAU,GAA8B,QAAQ,CAAA;QAEzD,uDAAuD;QAC9C,aAAQ,GAA+B,IAAI,OAAO,EAAqB,CAAA;QAEhF,4CAA4C;QAC5C,iBAAY,GAAG,KAAK,CAAA;QAUlB,IAAI,aAAa,EAAE;YACjB,mFAAmF;YACnF,iFAAiF;YACjF,8BAA8B;YAC9B,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,EAAE,KAAK,CAAC,CAAA;SAC/C;QAED,gCAAgC;QAChC,IAAI,WAAW,IAAI,WAAW,CAAC,OAAO,EAAE;YACtC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;SAC1B;IACH,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;SACpD;QAED,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE;YACnD,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,CAAA;SAClC;QAED,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAA;IAC1B,CAAC;IAED,6BAA6B;IAC7B,KAAK,CAAC,SAAsB,SAAS;QACnC,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,EAAE,EAAE,MAAM,CAAC,CAAA;SAC5D;aAAM;YACL,IAAI,CAAC,eAAe,EAAE,CAAC,KAAK,EAAE,CAAA;SAC/B;IACH,CAAC;IAED,kCAAkC;IAClC,YAAY;QACV,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAA;IACnC,CAAC;IAED,oCAAoC;IACpC,eAAe;QACb,OAAO,IAAI,CAAC,WAAW,CAAC,aAAa,CAAA;IACvC,CAAC;IAED,8DAA8D;IAE9D,cAAc,CAAC,KAAY;QACzB,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,KAAK,CAAC,cAAc,EAAE,CAAA;YACtB,KAAK,CAAC,eAAe,EAAE,CAAA;SACxB;IACH,CAAC;IAED,iCAAiC;IAEjC,iBAAiB;QACf,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IAC1B,CAAC;IAED,uFAAuF;IACvF,QAAQ;QACN,MAAM,OAAO,GAAgB,IAAI,CAAC,WAAW,CAAC,aAAa,CAAA;QAC3D,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAA;QAChE,IAAI,MAAM,GAAG,EAAE,CAAA;QAEf,IAAI,OAAO,CAAC,UAAU,EAAE;YACtB,MAAM,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC,MAAM,CAAA;YAExC,kEAAkE;YAClE,mEAAmE;YACnE,8CAA8C;YAC9C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC/B,IAAI,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,QAAQ,KAAK,YAAY,EAAE;oBACnD,MAAM,IAAI,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,WAAW,CAAA;iBAC5C;aACF;SACF;QAED,OAAO,MAAM,CAAC,IAAI,EAAE,CAAA;IACtB,CAAC;;8GAxGU,iBAAiB,4CAmBlB,QAAQ,yCAER,kBAAkB;kGArBjB,iBAAiB,6gBChC9B,8lBAqBA;2FDWa,iBAAiB;kBAhB7B,SAAS;+BAEE,gBAAgB,YAGhB,cAAc,UAChB,CAAE,UAAU,CAAE,QAChB;wBACJ,aAAa,EAAE,MAAM;wBACrB,OAAO,EAAE,eAAe;wBACxB,iBAAiB,EAAE,gBAAgB;wBACnC,sBAAsB,EAAE,qBAAqB;wBAC7C,iBAAiB,EAAE,kBAAkB;qBACtC,mBACgB,uBAAuB,CAAC,MAAM;;0BAqB5C,MAAM;2BAAC,QAAQ;;0BAEf,MAAM;2BAAC,kBAAkB;;0BAAG,QAAQ;4CAlB9B,IAAI;sBAAZ,KAAK;gBAEG,IAAI;sBAAZ,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBA8DN,cAAc;sBADb,YAAY;uBAAC,OAAO,EAAE,CAAC,QAAQ,CAAC;gBAUjC,iBAAiB;sBADhB,YAAY;uBAAC,YAAY","sourcesContent":["import { FocusableOption, FocusMonitor, FocusOrigin } from '@angular/cdk/a11y'\nimport { DOCUMENT } from '@angular/common'\nimport { ChangeDetectionStrategy, Component, ElementRef, HostListener, Inject, Input, OnDestroy, Optional } from '@angular/core'\nimport { Subject } from 'rxjs'\n\nimport { CanDisableCtor, mixinDisabled } from '@theseam/ui-common/core'\nimport { SeamIcon } from '@theseam/ui-common/icon'\n\nimport type { ITheSeamMenuPanel } from './menu-panel'\nimport { THESEAM_MENU_PANEL } from './menu-panel-token'\n\nclass TheSeamMenuItemBase {}\n\nconst _seamMenuItemMixinBase: CanDisableCtor & typeof TheSeamMenuItemBase =\n    mixinDisabled(TheSeamMenuItemBase)\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: '[seamMenuItem]',\n  templateUrl: './menu-item.component.html',\n  styleUrls: ['./menu-item.component.scss'],\n  exportAs: 'seamMenuItem',\n  inputs: [ 'disabled' ],\n  host: {\n    '[attr.role]': 'role',\n    'class': 'dropdown-item',\n    '[attr.tabindex]': '_getTabIndex()',\n    '[attr.aria-disabled]': 'disabled.toString()',\n    '[attr.disabled]': 'disabled || null',\n  },\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MenuItemComponent extends _seamMenuItemMixinBase implements OnDestroy, FocusableOption {\n\n  /** ARIA role for the menu item. */\n  @Input() role: 'menuitem' | 'menuitemradio' | 'menuitemcheckbox' | undefined | null = 'menuitem'\n\n  @Input() icon: SeamIcon | string | undefined | null\n  @Input() iconClass: string | undefined | null\n\n  @Input() badgeText: string | undefined | null\n  @Input() badgeTheme: string | undefined | null = 'danger'\n\n  /** Stream that emits when the menu item is hovered. */\n  readonly _hovered: Subject<MenuItemComponent> = new Subject<MenuItemComponent>()\n\n  /** Whether the menu item is highlighted. */\n  _highlighted = false\n\n  constructor(\n    private _elementRef: ElementRef<HTMLElement>,\n    @Inject(DOCUMENT) public document: any,\n    private _focusMonitor: FocusMonitor,\n    @Inject(THESEAM_MENU_PANEL) @Optional() private _parentMenu?: ITheSeamMenuPanel<MenuItemComponent>\n  ) {\n    super()\n\n    if (_focusMonitor) {\n      // Start monitoring the element so it gets the appropriate focused classes. We want\n      // to show the focus style for menu items only when the focus was not caused by a\n      // mouse or touch interaction.\n      _focusMonitor.monitor(this._elementRef, false)\n    }\n\n    // console.log(this._parentMenu)\n    if (_parentMenu && _parentMenu.addItem) {\n      _parentMenu.addItem(this)\n    }\n  }\n\n  ngOnDestroy() {\n    if (this._focusMonitor) {\n      this._focusMonitor.stopMonitoring(this._elementRef)\n    }\n\n    if (this._parentMenu && this._parentMenu.removeItem) {\n      this._parentMenu.removeItem(this)\n    }\n\n    this._hovered.complete()\n  }\n\n  /** Focuses the menu item. */\n  focus(origin: FocusOrigin = 'program'): void {\n    if (this._focusMonitor) {\n      this._focusMonitor.focusVia(this._getHostElement(), origin)\n    } else {\n      this._getHostElement().focus()\n    }\n  }\n\n  /** Used to set the `tabindex`. */\n  _getTabIndex(): string {\n    return this.disabled ? '-1' : '0'\n  }\n\n  /** Returns the host DOM element. */\n  _getHostElement(): HTMLElement {\n    return this._elementRef.nativeElement\n  }\n\n  /** Prevents the default element actions if it is disabled. */\n  @HostListener('click', ['$event'])\n  _checkDisabled(event: Event): void {\n    if (this.disabled) {\n      event.preventDefault()\n      event.stopPropagation()\n    }\n  }\n\n  /** Emits to the hover stream. */\n  @HostListener('mouseenter')\n  _handleMouseEnter() {\n    this._hovered.next(this)\n  }\n\n  /** Gets the label to be used when determining whether the option should be focused. */\n  getLabel(): string {\n    const element: HTMLElement = this._elementRef.nativeElement\n    const textNodeType = this.document ? this.document.TEXT_NODE : 3\n    let output = ''\n\n    if (element.childNodes) {\n      const length = element.childNodes.length\n\n      // Go through all the top-level text nodes and extract their text.\n      // We skip anything that's not a text node to prevent the text from\n      // being thrown off by something like an icon.\n      for (let i = 0; i < length; i++) {\n        if (element.childNodes[i].nodeType === textNodeType) {\n          output += element.childNodes[i].textContent\n        }\n      }\n    }\n\n    return output.trim()\n  }\n\n}\n","<div class=\"d-flex flex-row\">\n  <seam-icon *ngIf=\"icon\"\n    style=\"width: 30px; height: 20px; flex: 0 0 auto;\"\n    class=\"pr-2\"\n    [icon]=\"icon\"\n    [iconClass]=\"iconClass\"\n    iconType=\"image-fill\">\n  </seam-icon>\n  <!-- <span class=\"text-nowrap\">\n    <ng-content></ng-content>\n  </span> -->\n  <div class=\"text-truncate\">\n    <ng-content></ng-content>\n  </div>\n\n  <div *ngIf=\"badgeText\">\n    <span class=\"badge badge-pill{{ badgeTheme ? ' badge-' + badgeTheme : '' }} position-relative\"\n      style=\"top: -8px\"\n      >{{ badgeText }}</span>\n  </div>\n</div>\n"]}
|
|
158
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu-item.component.js","sourceRoot":"","sources":["../../../../projects/ui-common/menu/menu-item.component.ts","../../../../projects/ui-common/menu/menu-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FocusableOption, FocusMonitor, FocusOrigin } from '@angular/cdk/a11y'\nimport { DOCUMENT } from '@angular/common'\nimport { AfterViewInit, ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, HostListener, Inject, Input, OnDestroy, Optional } from '@angular/core'\nimport { Subject } from 'rxjs'\n\nimport { faCaretRight } from '@fortawesome/free-solid-svg-icons'\nimport { CanDisableCtor, mixinDisabled } from '@theseam/ui-common/core'\nimport { SeamIcon } from '@theseam/ui-common/icon'\n\nimport type { ITheSeamMenuPanel } from './menu-panel'\nimport { THESEAM_MENU_PANEL } from './menu-panel-token'\n\nclass TheSeamMenuItemBase {}\n\nconst _seamMenuItemMixinBase: CanDisableCtor & typeof TheSeamMenuItemBase =\n    mixinDisabled(TheSeamMenuItemBase)\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: '[seamMenuItem]',\n  templateUrl: './menu-item.component.html',\n  styleUrls: ['./menu-item.component.scss'],\n  exportAs: 'seamMenuItem',\n  inputs: [ 'disabled' ],\n  host: {\n    '[attr.role]': 'role',\n    'class': 'seam-menu-item dropdown-item',\n    '[class.seam-menu-item-highlighted]': '_highlighted',\n    '[class.seam-menu-item-submenu-trigger]': '_triggersSubmenu',\n    '[attr.tabindex]': '_getTabIndex()',\n    '[attr.aria-disabled]': 'disabled.toString()',\n    '[attr.disabled]': 'disabled || null',\n  },\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MenuItemComponent extends _seamMenuItemMixinBase implements OnDestroy, AfterViewInit, FocusableOption {\n\n  /** ARIA role for the menu item. */\n  @Input() role: 'menuitem' | 'menuitemradio' | 'menuitemcheckbox' | undefined | null = 'menuitem'\n\n  @Input() icon: SeamIcon | string | undefined | null\n  @Input() iconClass: string | undefined | null\n\n  @Input() sublevelIcon: SeamIcon | string | undefined | null = faCaretRight\n  @Input() subLevelIconClass: string | undefined | null\n\n  @Input() badgeText: string | undefined | null\n  @Input() badgeTheme: string | undefined | null = 'danger'\n\n  /** Stream that emits when the menu item is hovered. */\n  readonly _hovered = new Subject<MenuItemComponent>()\n\n  /** Stream that emits when the menu item is focused. */\n  readonly _focused = new Subject<MenuItemComponent>()\n\n  /** Whether the menu item is highlighted. */\n  _highlighted = false\n\n  /** Whether the menu item acts as a trigger for a sub-menu. */\n  _triggersSubmenu = false\n\n  constructor(\n    private readonly _elementRef: ElementRef<HTMLElement>,\n    @Inject(DOCUMENT) public readonly _document: any,\n    private readonly _focusMonitor: FocusMonitor,\n    private readonly _changeDetectorRef: ChangeDetectorRef,\n    @Inject(THESEAM_MENU_PANEL) @Optional() private readonly _parentMenu?: ITheSeamMenuPanel<MenuItemComponent>\n  ) {\n    super()\n\n    // console.log(this._parentMenu)\n    if (_parentMenu && _parentMenu.addItem) {\n      _parentMenu.addItem(this)\n    }\n  }\n\n  ngOnDestroy() {\n    if (this._focusMonitor) {\n      this._focusMonitor.stopMonitoring(this._elementRef)\n    }\n\n    if (this._parentMenu && this._parentMenu.removeItem) {\n      this._parentMenu.removeItem(this)\n    }\n\n    this._hovered.complete()\n    this._focused.complete()\n  }\n\n  ngAfterViewInit() {\n    if (this._focusMonitor) {\n      // Start monitoring the element, so it gets the appropriate focused classes. We want\n      // to show the focus style for menu items only when the focus was not caused by a\n      // mouse or touch interaction.\n      this._focusMonitor.monitor(this._elementRef, false)\n    }\n  }\n\n  /** Focuses the menu item. */\n  focus(origin: FocusOrigin = 'program'): void {\n    if (this._focusMonitor) {\n      this._focusMonitor.focusVia(this._getHostElement(), origin)\n    } else {\n      this._getHostElement().focus()\n    }\n    this._focused.next(this)\n  }\n\n  /** Used to set the `tabindex`. */\n  _getTabIndex(): string {\n    return this.disabled ? '-1' : '0'\n  }\n\n  /** Returns the host DOM element. */\n  _getHostElement(): HTMLElement {\n    return this._elementRef.nativeElement\n  }\n\n  /** Prevents the default element actions if it is disabled. */\n  @HostListener('click', ['$event'])\n  _checkDisabled(event: Event): void {\n    if (this.disabled) {\n      event.preventDefault()\n      event.stopPropagation()\n    }\n  }\n\n  /** Emits to the hover stream. */\n  @HostListener('mouseenter')\n  _handleMouseEnter() {\n    this._hovered.next(this)\n  }\n\n  /** Gets the label to be used when determining whether the option should be focused. */\n  getLabel(): string {\n    const element: HTMLElement = this._elementRef.nativeElement\n    const textNodeType = this._document ? this._document.TEXT_NODE : 3\n    let output = ''\n\n    if (element.childNodes) {\n      const length = element.childNodes.length\n\n      // Go through all the top-level text nodes and extract their text.\n      // We skip anything that's not a text node to prevent the text from\n      // being thrown off by something like an icon.\n      for (let i = 0; i < length; i++) {\n        if (element.childNodes[i].nodeType === textNodeType) {\n          output += element.childNodes[i].textContent\n        }\n      }\n    }\n\n    return output.trim()\n  }\n\n  _setHighlighted(isHighlighted: boolean) {\n    this._highlighted = isHighlighted\n    this._changeDetectorRef?.markForCheck()\n  }\n\n  _setTriggersSubmenu(triggersSubmenu: boolean) {\n    this._triggersSubmenu = triggersSubmenu\n    this._changeDetectorRef?.markForCheck()\n  }\n\n  _hasFocus(): boolean {\n    return this._document && this._document.activeElement === this._getHostElement()\n  }\n}\n","<div class=\"d-flex flex-row\">\n  <seam-icon *ngIf=\"icon\"\n    style=\"width: 30px; height: 20px; flex: 0 0 auto;\"\n    class=\"pr-2\"\n    [icon]=\"icon\"\n    [iconClass]=\"iconClass\"\n    iconType=\"image-fill\">\n  </seam-icon>\n  <div class=\"flex-fill\">\n    <div class=\"text-truncate\">\n      <ng-content></ng-content>\n    </div>\n\n    <div *ngIf=\"badgeText\">\n      <span class=\"badge badge-pill{{ badgeTheme ? ' badge-' + badgeTheme : '' }} position-relative\"\n        style=\"top: -8px\"\n        >{{ badgeText }}</span>\n    </div>\n  </div>\n  <seam-icon *ngIf=\"_triggersSubmenu\"\n    style=\"width: 30px; height: 20px; flex: 0 0 auto;\"\n    class=\"pl-2\"\n    [icon]=\"sublevelIcon\"\n    [iconClass]=\"subLevelIconClass\"\n    iconType=\"image-fill\">\n  </seam-icon>\n</div>\n"]}
|