@acorex/components 18.14.1-next.5 → 18.15.1
Sign up to get free protection for your applications and to get access to all the features.
- package/comment/lib/comment-container/comment-container.component.d.ts +1 -0
- package/common/lib/components/value-component.class.d.ts +1 -0
- package/common/lib/directives/auto-focus.directive.d.ts +1 -0
- package/common/lib/directives/ripple.directive.d.ts +1 -0
- package/data-table/lib/columns/data-table-column-resizable.directive.d.ts +1 -0
- package/data-table/lib/data-table/data-table.component.d.ts +61 -60
- package/data-table/lib/infinite-scroll-data-table/infinite-scroll-data-table.component.d.ts +7 -6
- package/drawer/lib/drawer/drawer-item/drawer.component.d.ts +2 -0
- package/esm2022/audio-wave/lib/audio-wave.component.mjs +79 -14
- package/esm2022/avatar/lib/avatar.component.mjs +2 -2
- package/esm2022/button/lib/button.component.mjs +2 -2
- package/esm2022/calendar/lib/calendar-range.component.mjs +2 -2
- package/esm2022/calendar/lib/calendar.component.mjs +3 -3
- package/esm2022/comment/lib/comment-container/comment-container.component.mjs +7 -3
- package/esm2022/common/lib/components/value-component.class.mjs +4 -2
- package/esm2022/common/lib/directives/auto-focus.directive.mjs +5 -3
- package/esm2022/common/lib/directives/inverted-color.directive.mjs +1 -1
- package/esm2022/common/lib/directives/ripple.directive.mjs +5 -3
- package/esm2022/conversation/lib/conversation-message/conversation-message.component.mjs +2 -2
- package/esm2022/conversation/lib/conversation-messages/conversation-message-voice/conversation-message-voice.component.mjs +2 -2
- package/esm2022/cron-job/index.mjs +1 -1
- package/esm2022/cron-job/lib/cron-job-container/cron-job-container.component.mjs +3 -3
- package/esm2022/cron-job/lib/day/day.component.mjs +3 -3
- package/esm2022/cron-job/lib/hours/hours.component.mjs +3 -3
- package/esm2022/cron-job/lib/minutes/minutes.component.mjs +3 -3
- package/esm2022/cron-job/lib/month/month.component.mjs +3 -3
- package/esm2022/cron-job/lib/seconds/seconds.component.mjs +3 -3
- package/esm2022/cron-job/lib/year/year.component.mjs +3 -3
- package/esm2022/data-table/lib/columns/data-table-column-resizable.directive.mjs +9 -7
- package/esm2022/data-table/lib/data-table/data-table.component.mjs +71 -67
- package/esm2022/data-table/lib/infinite-scroll-data-table/infinite-scroll-data-table.component.mjs +16 -11
- package/esm2022/drawer/lib/drawer/drawer-item/drawer.component.mjs +5 -2
- package/esm2022/list/lib/list.component.mjs +17 -5
- package/esm2022/loading/lib/loading-spinner.component.mjs +2 -2
- package/esm2022/loading-dialog/lib/loading-dialog.component.mjs +2 -2
- package/esm2022/menu/lib/context-menu.component.mjs +28 -21
- package/esm2022/password-box/lib/password-box.component.mjs +13 -5
- package/esm2022/password-box/lib/password-box.module.mjs +19 -3
- package/esm2022/password-box/lib/password-strength-validation/password-strength-validation.component.mjs +36 -14
- package/esm2022/popover/lib/popover.component.mjs +5 -3
- package/esm2022/popup/lib/popup.component.mjs +2 -2
- package/esm2022/uploader/lib/uploader-zone.directive.mjs +7 -5
- package/fesm2022/acorex-components-audio-wave.mjs +78 -13
- package/fesm2022/acorex-components-audio-wave.mjs.map +1 -1
- package/fesm2022/acorex-components-avatar.mjs +2 -2
- package/fesm2022/acorex-components-avatar.mjs.map +1 -1
- package/fesm2022/acorex-components-button.mjs +2 -2
- package/fesm2022/acorex-components-calendar.mjs +4 -4
- package/fesm2022/acorex-components-calendar.mjs.map +1 -1
- package/fesm2022/acorex-components-comment.mjs +7 -4
- package/fesm2022/acorex-components-comment.mjs.map +1 -1
- package/fesm2022/acorex-components-common.mjs +6 -3
- package/fesm2022/acorex-components-common.mjs.map +1 -1
- package/fesm2022/acorex-components-conversation.mjs +2 -2
- package/fesm2022/acorex-components-conversation.mjs.map +1 -1
- package/fesm2022/acorex-components-cron-job.mjs +14 -14
- package/fesm2022/acorex-components-cron-job.mjs.map +1 -1
- package/fesm2022/acorex-components-data-table.mjs +89 -81
- package/fesm2022/acorex-components-data-table.mjs.map +1 -1
- package/fesm2022/acorex-components-drawer.mjs +4 -2
- package/fesm2022/acorex-components-drawer.mjs.map +1 -1
- package/fesm2022/acorex-components-list.mjs +16 -4
- package/fesm2022/acorex-components-list.mjs.map +1 -1
- package/fesm2022/acorex-components-loading-dialog.mjs +2 -2
- package/fesm2022/acorex-components-loading.mjs +2 -2
- package/fesm2022/acorex-components-loading.mjs.map +1 -1
- package/fesm2022/acorex-components-menu.mjs +24 -18
- package/fesm2022/acorex-components-menu.mjs.map +1 -1
- package/fesm2022/acorex-components-password-box.mjs +65 -19
- package/fesm2022/acorex-components-password-box.mjs.map +1 -1
- package/fesm2022/acorex-components-popover.mjs +4 -3
- package/fesm2022/acorex-components-popover.mjs.map +1 -1
- package/fesm2022/acorex-components-popup.mjs +2 -2
- package/fesm2022/acorex-components-uploader.mjs +7 -6
- package/fesm2022/acorex-components-uploader.mjs.map +1 -1
- package/menu/lib/context-menu.component.d.ts +2 -1
- package/package.json +1 -1
- package/password-box/lib/password-box.component.d.ts +9 -1
- package/password-box/lib/password-box.module.d.ts +3 -1
- package/password-box/lib/password-strength-validation/password-strength-validation.component.d.ts +23 -1
- package/popover/lib/popover.component.d.ts +1 -0
- package/uploader/lib/uploader-zone.directive.d.ts +1 -0
@@ -1,10 +1,11 @@
|
|
1
1
|
import { NXComponent, NXEvent } from '@acorex/components/common';
|
2
|
-
import {
|
3
|
-
import { AXRootMenu } from './menu.types';
|
4
|
-
import { AXMenuService } from './menu.service';
|
2
|
+
import { isBrowser } from '@acorex/core/platform';
|
5
3
|
import { AXHtmlUtil } from '@acorex/core/utils';
|
4
|
+
import { DOCUMENT } from '@angular/common';
|
5
|
+
import { afterNextRender, ChangeDetectionStrategy, Component, HostBinding, HostListener, inject, input, output, Renderer2, signal, ViewEncapsulation, } from '@angular/core';
|
6
6
|
import { cloneDeep } from 'lodash-es';
|
7
|
-
import {
|
7
|
+
import { AXMenuService } from './menu.service';
|
8
|
+
import { AXRootMenu, } from './menu.types';
|
8
9
|
import * as i0 from "@angular/core";
|
9
10
|
import * as i1 from "@angular/common";
|
10
11
|
import * as i2 from "@acorex/components/decorators";
|
@@ -28,13 +29,14 @@ export class AXContextMenuComponent extends NXComponent {
|
|
28
29
|
this.orientation = input('vertical');
|
29
30
|
this.openOn = input('hover');
|
30
31
|
this.closeOn = input('click');
|
31
|
-
this.orginalItems = input([], { alias:
|
32
|
+
this.orginalItems = input([], { alias: 'items' });
|
32
33
|
this.target = input();
|
33
34
|
this.onItemClick = output();
|
34
35
|
this.onOpening = output();
|
35
36
|
// Injected Services
|
36
37
|
this.service = inject(AXMenuService);
|
37
38
|
this.renderer = inject(Renderer2);
|
39
|
+
this.document = inject(DOCUMENT);
|
38
40
|
this.items = signal([]);
|
39
41
|
//
|
40
42
|
afterNextRender(() => {
|
@@ -72,11 +74,11 @@ export class AXContextMenuComponent extends NXComponent {
|
|
72
74
|
// Private Methods (Internal Logic)
|
73
75
|
/** @ignore */
|
74
76
|
getTargetElements() {
|
75
|
-
const elements = typeof this.target() == 'string'
|
76
|
-
Array.from(document.querySelectorAll(this.target()))
|
77
|
-
Array.isArray(this.target())
|
78
|
-
this.target()
|
79
|
-
[this.target()];
|
77
|
+
const elements = typeof this.target() == 'string'
|
78
|
+
? Array.from(this.document.querySelectorAll(this.target()))
|
79
|
+
: Array.isArray(this.target())
|
80
|
+
? this.target()
|
81
|
+
: [this.target()];
|
80
82
|
return elements;
|
81
83
|
}
|
82
84
|
/** @ignore */
|
@@ -96,9 +98,9 @@ export class AXContextMenuComponent extends NXComponent {
|
|
96
98
|
e.preventDefault();
|
97
99
|
e.stopPropagation();
|
98
100
|
//
|
99
|
-
const elementsUnderMouse = document.elementsFromPoint(e.x, e.y);
|
101
|
+
const elementsUnderMouse = this.document.elementsFromPoint(e.x, e.y);
|
100
102
|
const targetElements = this.getTargetElements();
|
101
|
-
const targetElement = elementsUnderMouse.find(target => targetElements.includes(target));
|
103
|
+
const targetElement = elementsUnderMouse.find((target) => targetElements.includes(target));
|
102
104
|
//
|
103
105
|
const event = {
|
104
106
|
sender: this,
|
@@ -172,9 +174,9 @@ export class AXContextMenuComponent extends NXComponent {
|
|
172
174
|
const l3 = this.renderer.listen(this.backdropElement, 'contextmenu', (e) => {
|
173
175
|
this.close();
|
174
176
|
// Get all elements under the mouse pointer
|
175
|
-
const elementsUnderMouse = document.elementsFromPoint(e.x, e.y);
|
177
|
+
const elementsUnderMouse = this.document.elementsFromPoint(e.x, e.y);
|
176
178
|
const targetElements = this.getTargetElements();
|
177
|
-
if (targetElements.some(target => elementsUnderMouse.includes(target))) {
|
179
|
+
if (targetElements.some((target) => elementsUnderMouse.includes(target))) {
|
178
180
|
e.preventDefault();
|
179
181
|
setTimeout(() => {
|
180
182
|
//this.internalShowAt({ x: e.x, y: e.y });
|
@@ -183,7 +185,7 @@ export class AXContextMenuComponent extends NXComponent {
|
|
183
185
|
}
|
184
186
|
l3();
|
185
187
|
});
|
186
|
-
document.body.appendChild(this.backdropElement);
|
188
|
+
this.document.body.appendChild(this.backdropElement);
|
187
189
|
}
|
188
190
|
/** @ignore */
|
189
191
|
removeBackdrop() {
|
@@ -202,15 +204,20 @@ export class AXContextMenuComponent extends NXComponent {
|
|
202
204
|
}
|
203
205
|
/** @ignore */
|
204
206
|
get __hostClass() {
|
205
|
-
return [
|
207
|
+
return [
|
208
|
+
'ax-menu-container',
|
209
|
+
`ax-orientation-${this.orientation()}`,
|
210
|
+
'ax-action-list',
|
211
|
+
'ax-action-list-vertical',
|
212
|
+
];
|
206
213
|
}
|
207
214
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXContextMenuComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
208
215
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: AXContextMenuComponent, selector: "ax-context-menu", inputs: { orientation: { classPropertyName: "orientation", publicName: "orientation", isSignal: true, isRequired: false, transformFunction: null }, openOn: { classPropertyName: "openOn", publicName: "openOn", isSignal: true, isRequired: false, transformFunction: null }, closeOn: { classPropertyName: "closeOn", publicName: "closeOn", isSignal: true, isRequired: false, transformFunction: null }, orginalItems: { classPropertyName: "orginalItems", publicName: "items", isSignal: true, isRequired: false, transformFunction: null }, target: { classPropertyName: "target", publicName: "target", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onItemClick: "onItemClick", onOpening: "onOpening" }, host: { listeners: { "window:scroll": "onWindowEvent($event)", "window:resize": "onWindowEvent($event)" }, properties: { "class": "this.__hostClass" } }, providers: [
|
209
216
|
AXMenuService,
|
210
217
|
{
|
211
218
|
provide: AXRootMenu,
|
212
|
-
useExisting: AXContextMenuComponent
|
213
|
-
}
|
219
|
+
useExisting: AXContextMenuComponent,
|
220
|
+
},
|
214
221
|
], usesInheritance: true, ngImport: i0, template: "<ng-content select=\"ax-menu-item,ax-divider,ax-title,ng-container\"></ng-content>\n\n<ng-container\n *ngFor=\"let node of items()\"\n [ngTemplateOutlet]=\"Recursion\"\n [ngTemplateOutletContext]=\"{ $implicit: node }\"\n>\n</ng-container>\n<ng-template #Recursion let-item>\n @if (item.group?.title) {\n <ax-title>{{ item.group?.title }}</ax-title>\n }\n <ax-menu-item [name]=\"item.name\" [data]=\"item.data\" [disabled]=\"item.disabled\" [color]=\"item.color\">\n <ax-prefix>\n @if (item.icon) {\n <ax-icon [icon]=\"item.icon\"> </ax-icon>\n }\n </ax-prefix>\n @if (item.text) {\n <ax-text>{{ item.text }}</ax-text>\n }\n @if (item.suffix) {\n <ax-suffix>\n <ax-text>{{ item.suffix.text }}</ax-text>\n </ax-suffix>\n }\n <ng-container\n *ngFor=\"let child of item.items\"\n [ngTemplateOutlet]=\"Recursion\"\n [ngTemplateOutletContext]=\"{ $implicit: child }\"\n ></ng-container>\n </ax-menu-item>\n @if (item.break) {\n <ax-divider></ax-divider>\n }\n</ng-template>\n", styles: ["ax-context-menu,ax-menu{width:100%;color:inherit;display:flex;width:max-content}ax-context-menu .ax-action-item,ax-menu .ax-action-item{padding-inline-end:0!important}ax-context-menu.ax-menu-container,ax-context-menu .ax-menu-items,ax-menu.ax-menu-container,ax-menu .ax-menu-items{padding-block:.5rem;display:flex;opacity:0;visibility:hidden;transition:opacity .3s;width:max-content;min-width:12rem;height:max-content;position:fixed;flex-direction:column;border-radius:0;border-width:1px;border-color:rgba(var(--ax-color-border-default));background-color:rgba(var(--ax-color-surface));--ax-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--ax-shadow-colored: 0 4px 6px -1px var(--ax-shadow-color), 0 2px 4px -2px var(--ax-shadow-color);box-shadow:var(--ax-ring-offset-shadow, 0 0 rgba(0, 0, 0, 0)),var(--ax-ring-shadow, 0 0 rgba(0, 0, 0, 0)),var(--ax-shadow);border-radius:var(--ax-rounded-border-default);z-index:9999;color:rgba(var(--ax-color-text-default))}ax-context-menu.ax-menu-container.ax-state-open,ax-context-menu .ax-menu-items.ax-state-open,ax-menu.ax-menu-container.ax-state-open,ax-menu .ax-menu-items.ax-state-open{opacity:1;visibility:visible}ax-context-menu.ax-menu-container .ax-action-item:hover,ax-context-menu .ax-menu-items .ax-action-item:hover,ax-menu.ax-menu-container .ax-action-item:hover,ax-menu .ax-menu-items .ax-action-item:hover{background-color:rgba(var(--ax-color-on-surface),var(--tw-bg-opacity))}ax-context-menu.ax-action-list-horizontal{padding-inline:1rem}ax-menu.ax-action-list-horizontal{min-width:12rem;gap:.875rem}ax-menu.ax-action-list-horizontal>ax-title{display:none}ax-menu.ax-action-list-horizontal>ax-menu-item{font-weight:500}ax-menu.ax-action-list-horizontal>ax-menu-item>.ax-action-item-prefix{padding-inline-start:0!important}ax-menu.ax-action-list-horizontal>ax-menu-item>.ax-action-item-suffix:not(ax-menu.ax-action-list-horizontal>ax-menu-item>.ax-action-item-suffix:empty){padding-inline-end:0!important;margin-inline-start:0!important}ax-menu.ax-action-list-horizontal>ax-menu-item:hover{background-color:transparent!important}ax-menu.ax-action-list-horizontal>ax-menu-item:hover>.ax-action-item-prefix{opacity:.5}ax-menu.ax-action-list-horizontal>ax-menu-item:hover>.ax-action-item-suffix{opacity:.5}ax-menu.ax-action-list-vertical{width:max-content;min-width:12rem}ax-menu.ax-action-list-vertical>ax-menu-item{font-weight:500}ax-menu.ax-action-list-vertical>ax-menu-item:hover{background-color:transparent!important}ax-menu.ax-action-list-vertical>ax-menu-item:hover>.ax-action-item-prefix{opacity:.5}ax-menu.ax-action-list-vertical>ax-menu-item:hover>.ax-action-item-suffix{opacity:.5}ax-menu>ax-menu-item{padding-block:.5rem}ax-menu>ax-menu-item:hover:not(ax-menu>ax-menu-item:hover.ax-state-disabled){border-radius:var(--ax-rounded-border-default)}ax-menu>ax-menu-item:hover:not(ax-menu>ax-menu-item:hover.ax-state-disabled)>ax-icon,ax-menu>ax-menu-item:hover:not(ax-menu>ax-menu-item:hover.ax-state-disabled)>ax-text{opacity:.5}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i2.AXDecoratorGenericComponent, selector: "ax-footer, ax-header, ax-content, ax-divider, ax-form-hint, ax-prefix, ax-suffix, ax-text, ax-title, ax-sub-title, ax-placeholder, ax-overlay" }, { kind: "component", type: i3.AXMenuItemComponent, selector: "ax-menu-item", inputs: ["name", "data", "disabled", "color"], outputs: ["onClick"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
215
222
|
}
|
216
223
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXContextMenuComponent, decorators: [{
|
@@ -219,8 +226,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
219
226
|
AXMenuService,
|
220
227
|
{
|
221
228
|
provide: AXRootMenu,
|
222
|
-
useExisting: AXContextMenuComponent
|
223
|
-
}
|
229
|
+
useExisting: AXContextMenuComponent,
|
230
|
+
},
|
224
231
|
], template: "<ng-content select=\"ax-menu-item,ax-divider,ax-title,ng-container\"></ng-content>\n\n<ng-container\n *ngFor=\"let node of items()\"\n [ngTemplateOutlet]=\"Recursion\"\n [ngTemplateOutletContext]=\"{ $implicit: node }\"\n>\n</ng-container>\n<ng-template #Recursion let-item>\n @if (item.group?.title) {\n <ax-title>{{ item.group?.title }}</ax-title>\n }\n <ax-menu-item [name]=\"item.name\" [data]=\"item.data\" [disabled]=\"item.disabled\" [color]=\"item.color\">\n <ax-prefix>\n @if (item.icon) {\n <ax-icon [icon]=\"item.icon\"> </ax-icon>\n }\n </ax-prefix>\n @if (item.text) {\n <ax-text>{{ item.text }}</ax-text>\n }\n @if (item.suffix) {\n <ax-suffix>\n <ax-text>{{ item.suffix.text }}</ax-text>\n </ax-suffix>\n }\n <ng-container\n *ngFor=\"let child of item.items\"\n [ngTemplateOutlet]=\"Recursion\"\n [ngTemplateOutletContext]=\"{ $implicit: child }\"\n ></ng-container>\n </ax-menu-item>\n @if (item.break) {\n <ax-divider></ax-divider>\n }\n</ng-template>\n", styles: ["ax-context-menu,ax-menu{width:100%;color:inherit;display:flex;width:max-content}ax-context-menu .ax-action-item,ax-menu .ax-action-item{padding-inline-end:0!important}ax-context-menu.ax-menu-container,ax-context-menu .ax-menu-items,ax-menu.ax-menu-container,ax-menu .ax-menu-items{padding-block:.5rem;display:flex;opacity:0;visibility:hidden;transition:opacity .3s;width:max-content;min-width:12rem;height:max-content;position:fixed;flex-direction:column;border-radius:0;border-width:1px;border-color:rgba(var(--ax-color-border-default));background-color:rgba(var(--ax-color-surface));--ax-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--ax-shadow-colored: 0 4px 6px -1px var(--ax-shadow-color), 0 2px 4px -2px var(--ax-shadow-color);box-shadow:var(--ax-ring-offset-shadow, 0 0 rgba(0, 0, 0, 0)),var(--ax-ring-shadow, 0 0 rgba(0, 0, 0, 0)),var(--ax-shadow);border-radius:var(--ax-rounded-border-default);z-index:9999;color:rgba(var(--ax-color-text-default))}ax-context-menu.ax-menu-container.ax-state-open,ax-context-menu .ax-menu-items.ax-state-open,ax-menu.ax-menu-container.ax-state-open,ax-menu .ax-menu-items.ax-state-open{opacity:1;visibility:visible}ax-context-menu.ax-menu-container .ax-action-item:hover,ax-context-menu .ax-menu-items .ax-action-item:hover,ax-menu.ax-menu-container .ax-action-item:hover,ax-menu .ax-menu-items .ax-action-item:hover{background-color:rgba(var(--ax-color-on-surface),var(--tw-bg-opacity))}ax-context-menu.ax-action-list-horizontal{padding-inline:1rem}ax-menu.ax-action-list-horizontal{min-width:12rem;gap:.875rem}ax-menu.ax-action-list-horizontal>ax-title{display:none}ax-menu.ax-action-list-horizontal>ax-menu-item{font-weight:500}ax-menu.ax-action-list-horizontal>ax-menu-item>.ax-action-item-prefix{padding-inline-start:0!important}ax-menu.ax-action-list-horizontal>ax-menu-item>.ax-action-item-suffix:not(ax-menu.ax-action-list-horizontal>ax-menu-item>.ax-action-item-suffix:empty){padding-inline-end:0!important;margin-inline-start:0!important}ax-menu.ax-action-list-horizontal>ax-menu-item:hover{background-color:transparent!important}ax-menu.ax-action-list-horizontal>ax-menu-item:hover>.ax-action-item-prefix{opacity:.5}ax-menu.ax-action-list-horizontal>ax-menu-item:hover>.ax-action-item-suffix{opacity:.5}ax-menu.ax-action-list-vertical{width:max-content;min-width:12rem}ax-menu.ax-action-list-vertical>ax-menu-item{font-weight:500}ax-menu.ax-action-list-vertical>ax-menu-item:hover{background-color:transparent!important}ax-menu.ax-action-list-vertical>ax-menu-item:hover>.ax-action-item-prefix{opacity:.5}ax-menu.ax-action-list-vertical>ax-menu-item:hover>.ax-action-item-suffix{opacity:.5}ax-menu>ax-menu-item{padding-block:.5rem}ax-menu>ax-menu-item:hover:not(ax-menu>ax-menu-item:hover.ax-state-disabled){border-radius:var(--ax-rounded-border-default)}ax-menu>ax-menu-item:hover:not(ax-menu>ax-menu-item:hover.ax-state-disabled)>ax-icon,ax-menu>ax-menu-item:hover:not(ax-menu>ax-menu-item:hover.ax-state-disabled)>ax-text{opacity:.5}\n"] }]
|
225
232
|
}], ctorParameters: () => [], propDecorators: { onWindowEvent: [{
|
226
233
|
type: HostListener,
|
@@ -232,4 +239,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
232
239
|
type: HostBinding,
|
233
240
|
args: ['class']
|
234
241
|
}] } });
|
235
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-menu.component.js","sourceRoot":"","sources":["../../../../../../libs/components/menu/src/lib/context-menu.component.ts","../../../../../../libs/components/menu/src/lib/menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXOrientation, NXComponent, NXEvent } from '@acorex/components/common';\nimport {\n    afterNextRender,\n    ChangeDetectionStrategy,\n    Component,\n    HostBinding,\n    HostListener,\n    inject,\n    input,\n    output,\n    Renderer2,\n    signal,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { AXMenuCloseTrigger, AXMenuItem, AXMenuItemClickBaseEvent, AXMenuOpenTrigger, AXRootMenu } from './menu.types';\nimport { AXMenuService } from './menu.service';\nimport { AXHtmlUtil, AXPoint } from '@acorex/core/utils';\nimport { cloneDeep } from 'lodash-es';\nimport { isBrowser } from '@acorex/core/platform';\n\n\nexport class AXContextMenuOpeningEvent extends NXEvent<AXContextMenuComponent> {\n    items: AXMenuItem[];\n    canceled = false;\n    targetElement: HTMLElement\n\n}\nexport type AXContextMenuItemsClickEvent = AXMenuItemClickBaseEvent<AXContextMenuComponent>\n\n/**\n * Represents a menu component that displays context menu.\n * @category Components\n */\n@Component({\n    selector: 'ax-context-menu',\n    templateUrl: './menu.component.html',\n    styleUrls: ['./menu.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    providers: [\n        AXMenuService,\n        {\n            provide: AXRootMenu,\n            useExisting: AXContextMenuComponent\n        }\n    ]\n})\nexport class AXContextMenuComponent extends NXComponent {\n\n    // Inputs and Outputs\n\n    orientation = input<AXOrientation>('vertical');\n    openOn = input<AXMenuOpenTrigger>('hover');\n    closeOn = input<AXMenuCloseTrigger>('click');\n    orginalItems = input<AXMenuItem[]>([], { alias: \"items\" });\n    target = input<HTMLElement | HTMLElement[] | string>();\n\n    onItemClick = output<AXContextMenuItemsClickEvent>();\n    onOpening = output<AXContextMenuOpeningEvent>();\n\n    // Injected Services\n\n    private service = inject(AXMenuService);\n    private renderer = inject(Renderer2)\n\n    // Constructor (Dependency Injection)\n\n    /** @ignore */\n    constructor() {\n        super();\n        //\n        afterNextRender(() => {\n            this.bindContextEvent();\n        });\n\n        this.service.closeAllContextMenu$.subscribe(() => {\n            this.service.closeAll$.next();\n            this.close();\n        });\n\n        this.service.openContextMenu$.subscribe((e) => {\n            if (e.sender as any == this) {\n                this.internalShowAt(e.point);\n            }\n        });\n    }\n\n\n\n    // Lifecycle Hooks\n\n    ngOnDestroy() {\n        if (isBrowser()) {\n            this.removeContextEvent();\n        }\n    }\n\n    public refresh(){\n        this.bindContextEvent()\n    }\n\n    // Public Methods\n\n    public showAt(point: AXPoint) {\n        const sender = this as any as AXRootMenu;\n        this.service.closeAllContextMenu$.next({ sender });\n        this.service.openContextMenu$.next({ sender, point });\n    }\n\n    public close() {\n        this.nativeElement.classList.remove('ax-state-open');\n        this.removeBackdrop();\n    }\n\n    // Private Properties\n\n    private backdropElement!: HTMLElement;\n\n    protected items = signal<AXMenuItem[]>([]);\n\n    // Private Methods (Internal Logic)\n\n    /** @ignore */\n    private getTargetElements(): HTMLElement[] {\n        const elements: HTMLElement[] = typeof this.target() == 'string' ?\n            Array.from(document.querySelectorAll<HTMLElement>(this.target() as string)) :\n            Array.isArray(this.target()) ?\n                this.target() as HTMLElement[] :\n                [this.target() as HTMLElement]\n\n        return elements;\n    }\n\n    /** @ignore */\n    private bindContextEvent() {\n        this.getTargetElements().forEach((e) => {\n            e.addEventListener('contextmenu', this.handleContextMenu.bind(this));\n        })\n    }\n\n    /** @ignore */\n    private removeContextEvent() {\n        this.getTargetElements().forEach((e) => {\n            e.removeEventListener('contextmenu', this.handleContextMenu.bind(this));\n        })\n    }\n\n    /** @ignore */\n    private handleContextMenu(e: MouseEvent) {\n        e.preventDefault();\n        e.stopPropagation();\n        //\n        const elementsUnderMouse = document.elementsFromPoint(e.x, e.y) as HTMLElement[];\n        const targetElements = this.getTargetElements();\n        const targetElement = elementsUnderMouse.find(target => targetElements.includes(target))\n        //\n        const event = {\n            sender: this,\n            canceled: false,\n            targetElement: targetElement,\n            items: cloneDeep(this.orginalItems()),\n        } as AXContextMenuOpeningEvent;\n        this.onOpening.emit(event);\n        this.items.set(event.items);\n        //\n        if (!event.canceled) {\n            this.showAt({ x: e.clientX, y: e.clientY });\n        }\n    }\n\n    /** @ignore */\n    private internalShowAt(point: AXPoint) {\n        const elementRef = this.nativeElement;\n        elementRef.classList.add('ax-state-open');\n        const itemRect = elementRef.getBoundingClientRect();\n        const windowWidth = window.innerWidth;\n        const windowHeight = window.innerHeight;\n\n        // Detect RTL (Right-To-Left) mode\n        const isRtl = AXHtmlUtil.isRtl(elementRef);\n\n        let left: number;\n        if (isRtl) {\n            left = point.x - itemRect.width;\n            if (left < 0) {\n                left = point.x;\n            }\n        } else {\n            left = point.x;\n            if (left + itemRect.width > windowWidth) {\n                left = point.x - itemRect.width;\n            }\n        }\n\n        const bottom = point.y + itemRect.height;\n        let top: number;\n\n        if (bottom > windowHeight) {\n            top = point.y - itemRect.height;\n            if (top < 0) {\n                top = 0;\n            }\n        } else {\n            top = point.y;\n        }\n\n        this.renderer.setStyle(elementRef, 'left', `${left}px`);\n        this.renderer.setStyle(elementRef, 'top', `${top}px`);\n        this.renderer.setStyle(elementRef, 'position', 'fixed');\n\n        this.createBackdrop();\n    }\n\n    /** @ignore */\n    private createBackdrop() {\n        this.backdropElement = this.renderer.createElement('div');\n        this.renderer.setStyle(this.backdropElement, 'position', 'fixed');\n        this.renderer.setStyle(this.backdropElement, 'top', '0');\n        this.renderer.setStyle(this.backdropElement, 'left', '0');\n        this.renderer.setStyle(this.backdropElement, 'width', '100%');\n        this.renderer.setStyle(this.backdropElement, 'height', '100%');\n        this.renderer.setStyle(this.backdropElement, 'z-index', '999'); // Ensure it's below the context menu\n        this.renderer.setStyle(this.backdropElement, 'background', 'transparent');\n\n        const l1 = this.renderer.listen(this.backdropElement, 'click', () => {\n            this.close();\n            l1();\n        });\n\n        const l2 = this.renderer.listen(this.backdropElement, 'wheel', () => {\n            this.close();\n            l2();\n        });\n\n        const l3 = this.renderer.listen(this.backdropElement, 'contextmenu', (e: MouseEvent) => {\n            this.close();\n            // Get all elements under the mouse pointer\n            const elementsUnderMouse = document.elementsFromPoint(e.x, e.y) as HTMLElement[];\n            const targetElements = this.getTargetElements();\n            if (targetElements.some(target => elementsUnderMouse.includes(target))) {\n                e.preventDefault();\n                setTimeout(() => {\n                    //this.internalShowAt({ x: e.x, y: e.y });\n                    this.handleContextMenu(e);\n                });\n            }\n            l3();\n        });\n\n        document.body.appendChild(this.backdropElement);\n    }\n\n    /** @ignore */\n    private removeBackdrop() {\n        if (this.backdropElement) {\n            if (this.backdropElement.parentNode) {\n                this.backdropElement.parentNode.removeChild(this.backdropElement);\n            }\n            this.backdropElement = null;\n        }\n    }\n\n    // Host Listeners (UI Interaction Handling)\n\n    /** @ignore */\n    @HostListener('window:scroll', ['$event'])\n    @HostListener('window:resize', ['$event'])\n    private onWindowEvent() {\n        const sender = this as any as AXRootMenu;\n        this.service.closeAllContextMenu$.next({ sender: sender }); // Close all menus on scroll or resize\n    }\n\n    /** @ignore */\n    @HostBinding('class')\n    get __hostClass(): any {\n        return ['ax-menu-container', `ax-orientation-${this.orientation()}`, 'ax-action-list', 'ax-action-list-vertical'];\n    }\n}\n","<ng-content select=\"ax-menu-item,ax-divider,ax-title,ng-container\"></ng-content>\n\n<ng-container\n  *ngFor=\"let node of items()\"\n  [ngTemplateOutlet]=\"Recursion\"\n  [ngTemplateOutletContext]=\"{ $implicit: node }\"\n>\n</ng-container>\n<ng-template #Recursion let-item>\n  @if (item.group?.title) {\n    <ax-title>{{ item.group?.title }}</ax-title>\n  }\n  <ax-menu-item [name]=\"item.name\" [data]=\"item.data\" [disabled]=\"item.disabled\" [color]=\"item.color\">\n    <ax-prefix>\n      @if (item.icon) {\n        <ax-icon [icon]=\"item.icon\"> </ax-icon>\n      }\n    </ax-prefix>\n    @if (item.text) {\n      <ax-text>{{ item.text }}</ax-text>\n    }\n    @if (item.suffix) {\n      <ax-suffix>\n        <ax-text>{{ item.suffix.text }}</ax-text>\n      </ax-suffix>\n    }\n    <ng-container\n      *ngFor=\"let child of item.items\"\n      [ngTemplateOutlet]=\"Recursion\"\n      [ngTemplateOutletContext]=\"{ $implicit: child }\"\n    ></ng-container>\n  </ax-menu-item>\n  @if (item.break) {\n    <ax-divider></ax-divider>\n  }\n</ng-template>\n"]}
|
242
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-menu.component.js","sourceRoot":"","sources":["../../../../../../libs/components/menu/src/lib/context-menu.component.ts","../../../../../../libs/components/menu/src/lib/menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXOrientation, NXComponent, NXEvent } from '@acorex/components/common';\nimport { isBrowser } from '@acorex/core/platform';\nimport { AXHtmlUtil, AXPoint } from '@acorex/core/utils';\nimport { DOCUMENT } from '@angular/common';\nimport {\n  afterNextRender,\n  ChangeDetectionStrategy,\n  Component,\n  HostBinding,\n  HostListener,\n  inject,\n  input,\n  output,\n  Renderer2,\n  signal,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { cloneDeep } from 'lodash-es';\nimport { AXMenuService } from './menu.service';\nimport {\n  AXMenuCloseTrigger,\n  AXMenuItem,\n  AXMenuItemClickBaseEvent,\n  AXMenuOpenTrigger,\n  AXRootMenu,\n} from './menu.types';\n\nexport class AXContextMenuOpeningEvent extends NXEvent<AXContextMenuComponent> {\n  items: AXMenuItem[];\n  canceled = false;\n  targetElement: HTMLElement;\n}\nexport type AXContextMenuItemsClickEvent = AXMenuItemClickBaseEvent<AXContextMenuComponent>;\n\n/**\n * Represents a menu component that displays context menu.\n * @category Components\n */\n@Component({\n  selector: 'ax-context-menu',\n  templateUrl: './menu.component.html',\n  styleUrls: ['./menu.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    AXMenuService,\n    {\n      provide: AXRootMenu,\n      useExisting: AXContextMenuComponent,\n    },\n  ],\n})\nexport class AXContextMenuComponent extends NXComponent {\n  // Inputs and Outputs\n\n  orientation = input<AXOrientation>('vertical');\n  openOn = input<AXMenuOpenTrigger>('hover');\n  closeOn = input<AXMenuCloseTrigger>('click');\n  orginalItems = input<AXMenuItem[]>([], { alias: 'items' });\n  target = input<HTMLElement | HTMLElement[] | string>();\n\n  onItemClick = output<AXContextMenuItemsClickEvent>();\n  onOpening = output<AXContextMenuOpeningEvent>();\n\n  // Injected Services\n\n  private service = inject(AXMenuService);\n  private renderer = inject(Renderer2);\n  private document = inject(DOCUMENT);\n\n  // Constructor (Dependency Injection)\n\n  /** @ignore */\n  constructor() {\n    super();\n    //\n    afterNextRender(() => {\n      this.bindContextEvent();\n    });\n\n    this.service.closeAllContextMenu$.subscribe(() => {\n      this.service.closeAll$.next();\n      this.close();\n    });\n\n    this.service.openContextMenu$.subscribe((e) => {\n      if ((e.sender as any) == this) {\n        this.internalShowAt(e.point);\n      }\n    });\n  }\n\n  // Lifecycle Hooks\n\n  ngOnDestroy() {\n    if (isBrowser()) {\n      this.removeContextEvent();\n    }\n  }\n\n  public refresh() {\n    this.bindContextEvent();\n  }\n\n  // Public Methods\n\n  public showAt(point: AXPoint) {\n    const sender = this as any as AXRootMenu;\n    this.service.closeAllContextMenu$.next({ sender });\n    this.service.openContextMenu$.next({ sender, point });\n  }\n\n  public close() {\n    this.nativeElement.classList.remove('ax-state-open');\n    this.removeBackdrop();\n  }\n\n  // Private Properties\n\n  private backdropElement!: HTMLElement;\n\n  protected items = signal<AXMenuItem[]>([]);\n\n  // Private Methods (Internal Logic)\n\n  /** @ignore */\n  private getTargetElements(): HTMLElement[] {\n    const elements: HTMLElement[] =\n      typeof this.target() == 'string'\n        ? Array.from(this.document.querySelectorAll<HTMLElement>(this.target() as string))\n        : Array.isArray(this.target())\n          ? (this.target() as HTMLElement[])\n          : [this.target() as HTMLElement];\n\n    return elements;\n  }\n\n  /** @ignore */\n  private bindContextEvent() {\n    this.getTargetElements().forEach((e) => {\n      e.addEventListener('contextmenu', this.handleContextMenu.bind(this));\n    });\n  }\n\n  /** @ignore */\n  private removeContextEvent() {\n    this.getTargetElements().forEach((e) => {\n      e.removeEventListener('contextmenu', this.handleContextMenu.bind(this));\n    });\n  }\n\n  /** @ignore */\n  private handleContextMenu(e: MouseEvent) {\n    e.preventDefault();\n    e.stopPropagation();\n    //\n    const elementsUnderMouse = this.document.elementsFromPoint(e.x, e.y) as HTMLElement[];\n    const targetElements = this.getTargetElements();\n    const targetElement = elementsUnderMouse.find((target) => targetElements.includes(target));\n    //\n    const event = {\n      sender: this,\n      canceled: false,\n      targetElement: targetElement,\n      items: cloneDeep(this.orginalItems()),\n    } as AXContextMenuOpeningEvent;\n    this.onOpening.emit(event);\n    this.items.set(event.items);\n    //\n    if (!event.canceled) {\n      this.showAt({ x: e.clientX, y: e.clientY });\n    }\n  }\n\n  /** @ignore */\n  private internalShowAt(point: AXPoint) {\n    const elementRef = this.nativeElement;\n    elementRef.classList.add('ax-state-open');\n    const itemRect = elementRef.getBoundingClientRect();\n    const windowWidth = window.innerWidth;\n    const windowHeight = window.innerHeight;\n\n    // Detect RTL (Right-To-Left) mode\n    const isRtl = AXHtmlUtil.isRtl(elementRef);\n\n    let left: number;\n    if (isRtl) {\n      left = point.x - itemRect.width;\n      if (left < 0) {\n        left = point.x;\n      }\n    } else {\n      left = point.x;\n      if (left + itemRect.width > windowWidth) {\n        left = point.x - itemRect.width;\n      }\n    }\n\n    const bottom = point.y + itemRect.height;\n    let top: number;\n\n    if (bottom > windowHeight) {\n      top = point.y - itemRect.height;\n      if (top < 0) {\n        top = 0;\n      }\n    } else {\n      top = point.y;\n    }\n\n    this.renderer.setStyle(elementRef, 'left', `${left}px`);\n    this.renderer.setStyle(elementRef, 'top', `${top}px`);\n    this.renderer.setStyle(elementRef, 'position', 'fixed');\n\n    this.createBackdrop();\n  }\n\n  /** @ignore */\n  private createBackdrop() {\n    this.backdropElement = this.renderer.createElement('div');\n    this.renderer.setStyle(this.backdropElement, 'position', 'fixed');\n    this.renderer.setStyle(this.backdropElement, 'top', '0');\n    this.renderer.setStyle(this.backdropElement, 'left', '0');\n    this.renderer.setStyle(this.backdropElement, 'width', '100%');\n    this.renderer.setStyle(this.backdropElement, 'height', '100%');\n    this.renderer.setStyle(this.backdropElement, 'z-index', '999'); // Ensure it's below the context menu\n    this.renderer.setStyle(this.backdropElement, 'background', 'transparent');\n\n    const l1 = this.renderer.listen(this.backdropElement, 'click', () => {\n      this.close();\n      l1();\n    });\n\n    const l2 = this.renderer.listen(this.backdropElement, 'wheel', () => {\n      this.close();\n      l2();\n    });\n\n    const l3 = this.renderer.listen(this.backdropElement, 'contextmenu', (e: MouseEvent) => {\n      this.close();\n      // Get all elements under the mouse pointer\n      const elementsUnderMouse = this.document.elementsFromPoint(e.x, e.y) as HTMLElement[];\n      const targetElements = this.getTargetElements();\n      if (targetElements.some((target) => elementsUnderMouse.includes(target))) {\n        e.preventDefault();\n        setTimeout(() => {\n          //this.internalShowAt({ x: e.x, y: e.y });\n          this.handleContextMenu(e);\n        });\n      }\n      l3();\n    });\n\n    this.document.body.appendChild(this.backdropElement);\n  }\n\n  /** @ignore */\n  private removeBackdrop() {\n    if (this.backdropElement) {\n      if (this.backdropElement.parentNode) {\n        this.backdropElement.parentNode.removeChild(this.backdropElement);\n      }\n      this.backdropElement = null;\n    }\n  }\n\n  // Host Listeners (UI Interaction Handling)\n\n  /** @ignore */\n  @HostListener('window:scroll', ['$event'])\n  @HostListener('window:resize', ['$event'])\n  private onWindowEvent() {\n    const sender = this as any as AXRootMenu;\n    this.service.closeAllContextMenu$.next({ sender: sender }); // Close all menus on scroll or resize\n  }\n\n  /** @ignore */\n  @HostBinding('class')\n  get __hostClass(): any {\n    return [\n      'ax-menu-container',\n      `ax-orientation-${this.orientation()}`,\n      'ax-action-list',\n      'ax-action-list-vertical',\n    ];\n  }\n}\n","<ng-content select=\"ax-menu-item,ax-divider,ax-title,ng-container\"></ng-content>\n\n<ng-container\n  *ngFor=\"let node of items()\"\n  [ngTemplateOutlet]=\"Recursion\"\n  [ngTemplateOutletContext]=\"{ $implicit: node }\"\n>\n</ng-container>\n<ng-template #Recursion let-item>\n  @if (item.group?.title) {\n    <ax-title>{{ item.group?.title }}</ax-title>\n  }\n  <ax-menu-item [name]=\"item.name\" [data]=\"item.data\" [disabled]=\"item.disabled\" [color]=\"item.color\">\n    <ax-prefix>\n      @if (item.icon) {\n        <ax-icon [icon]=\"item.icon\"> </ax-icon>\n      }\n    </ax-prefix>\n    @if (item.text) {\n      <ax-text>{{ item.text }}</ax-text>\n    }\n    @if (item.suffix) {\n      <ax-suffix>\n        <ax-text>{{ item.suffix.text }}</ax-text>\n      </ax-suffix>\n    }\n    <ng-container\n      *ngFor=\"let child of item.items\"\n      [ngTemplateOutlet]=\"Recursion\"\n      [ngTemplateOutletContext]=\"{ $implicit: child }\"\n    ></ng-container>\n  </ax-menu-item>\n  @if (item.break) {\n    <ax-divider></ax-divider>\n  }\n</ng-template>\n"]}
|
@@ -1,5 +1,5 @@
|
|
1
1
|
import { AXClearableComponent, AXComponent, AXFocusableComponent, AXValuableComponent, MXInputBaseValueComponent, MXLookComponent, } from '@acorex/components/common';
|
2
|
-
import { ChangeDetectionStrategy, Component, ElementRef, Input, ViewChild, ViewEncapsulation, forwardRef, } from '@angular/core';
|
2
|
+
import { ChangeDetectionStrategy, Component, ElementRef, Input, ViewChild, ViewEncapsulation, forwardRef, input, } from '@angular/core';
|
3
3
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
4
4
|
import { classes } from 'polytype';
|
5
5
|
import * as i0 from "@angular/core";
|
@@ -24,6 +24,14 @@ export class AXPasswordBoxComponent extends classes((MXInputBaseValueComponent),
|
|
24
24
|
* A flag for showing or hiding password button.
|
25
25
|
*/
|
26
26
|
this.showToggleButton = true;
|
27
|
+
/**
|
28
|
+
* Hint status.
|
29
|
+
*/
|
30
|
+
this.showHint = input(false);
|
31
|
+
/**
|
32
|
+
* Progress status.
|
33
|
+
*/
|
34
|
+
this.showProgress = input(false);
|
27
35
|
}
|
28
36
|
/** @ignore */
|
29
37
|
_handleModelChange(value) {
|
@@ -43,7 +51,7 @@ export class AXPasswordBoxComponent extends classes((MXInputBaseValueComponent),
|
|
43
51
|
}
|
44
52
|
}
|
45
53
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPasswordBoxComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
46
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: AXPasswordBoxComponent, selector: "ax-password-box", inputs: { readonly: "readonly", disabled: "disabled", tabIndex: "tabIndex", placeholder: "placeholder", value: "value", state: "state", name: "name", id: "id", look: "look", autoComplete: "autoComplete", showToggleButton: "showToggleButton", classNames:
|
54
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: AXPasswordBoxComponent, selector: "ax-password-box", inputs: { readonly: { classPropertyName: "readonly", publicName: "readonly", isSignal: false, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: false, isRequired: false, transformFunction: null }, tabIndex: { classPropertyName: "tabIndex", publicName: "tabIndex", isSignal: false, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: false, isRequired: false, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: false, isRequired: false, transformFunction: null }, state: { classPropertyName: "state", publicName: "state", isSignal: false, isRequired: false, transformFunction: null }, name: { classPropertyName: "name", publicName: "name", isSignal: false, isRequired: false, transformFunction: null }, id: { classPropertyName: "id", publicName: "id", isSignal: false, isRequired: false, transformFunction: null }, look: { classPropertyName: "look", publicName: "look", isSignal: false, isRequired: false, transformFunction: null }, autoComplete: { classPropertyName: "autoComplete", publicName: "autoComplete", isSignal: false, isRequired: false, transformFunction: null }, showToggleButton: { classPropertyName: "showToggleButton", publicName: "showToggleButton", isSignal: false, isRequired: false, transformFunction: null }, classNames: { classPropertyName: "classNames", publicName: "class", isSignal: false, isRequired: false, transformFunction: null }, showHint: { classPropertyName: "showHint", publicName: "showHint", isSignal: true, isRequired: false, transformFunction: null }, showProgress: { classPropertyName: "showProgress", publicName: "showProgress", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { valueChange: "valueChange", stateChange: "stateChange", onValueChanged: "onValueChanged", onBlur: "onBlur", onFocus: "onFocus", readonlyChange: "readonlyChange", disabledChange: "disabledChange", onKeyDown: "onKeyDown", onKeyUp: "onKeyUp", onKeyPress: "onKeyPress" }, providers: [
|
47
55
|
{ provide: AXComponent, useExisting: AXPasswordBoxComponent },
|
48
56
|
{ provide: AXFocusableComponent, useExisting: AXPasswordBoxComponent },
|
49
57
|
{ provide: AXClearableComponent, useExisting: AXPasswordBoxComponent },
|
@@ -53,7 +61,7 @@ export class AXPasswordBoxComponent extends classes((MXInputBaseValueComponent),
|
|
53
61
|
useExisting: forwardRef(() => AXPasswordBoxComponent),
|
54
62
|
multi: true,
|
55
63
|
},
|
56
|
-
], viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"ax-editor-container ax-look-{{ look }} {{ classNames }}\" [class.ax-state-disabled]=\"disabled\">\n <ng-content select=\"ax-prefix\"> </ng-content>\n <input\n #input\n class=\"ax-input\"\n [name]=\"name\"\n [type]=\"_type\"\n [id]=\"id\"\n [attr.placeholder]=\"placeholder\"\n [class.ax-state-disabled]=\"disabled\"\n [class.ax-state-readonly]=\"readonly\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [tabindex]=\"tabIndex\"\n [ngModel]=\"value\"\n [attr.autocomplete]=\"autoComplete\"\n (ngModelChange)=\"_handleModelChange($event)\"\n (keydown)=\"emitOnKeydownEvent($event)\"\n (keyup)=\"emitOnKeyupEvent($event)\"\n (keypress)=\"emitOnKeypressEvent($event)\"\n (focus)=\"emitOnFocusEvent($event)\"\n (blur)=\"emitOnBlurEvent($event)\"\n />\n @if (value && !disabled && !readonly) {\n <ng-content select=\"ax-clear-button\"></ng-content>\n }\n @if (showToggleButton) {\n <button type=\"button\" class=\"ax-general-button ax-button-icon\" (click)=\"toggleType()\" [tabIndex]=\"-1\">\n <span class=\"ax-icon {{ _icon }}\"></span>\n </button>\n }\n <ng-content select=\"ax-suffix\"> </ng-content>\n <ng-content select=\"ax-validation-rule\"> </ng-content>\n</div>\n<div class=\"ax-error-container\"></div>\n\n<div class=\"ax-strength-validation-container\">\n <ng-content select=\"ax-password-strength-validation\"></ng-content>\n</div>\n", styles: [".ax-strength-validation-container{margin-top:.
|
64
|
+
], viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"ax-editor-container ax-look-{{ look }} {{ classNames }}\" [class.ax-state-disabled]=\"disabled\">\n <ng-content select=\"ax-prefix\"> </ng-content>\n <input\n #input\n class=\"ax-input\"\n [name]=\"name\"\n [type]=\"_type\"\n [id]=\"id\"\n [attr.placeholder]=\"placeholder\"\n [class.ax-state-disabled]=\"disabled\"\n [class.ax-state-readonly]=\"readonly\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [tabindex]=\"tabIndex\"\n [ngModel]=\"value\"\n [attr.autocomplete]=\"autoComplete\"\n (ngModelChange)=\"_handleModelChange($event)\"\n (keydown)=\"emitOnKeydownEvent($event)\"\n (keyup)=\"emitOnKeyupEvent($event)\"\n (keypress)=\"emitOnKeypressEvent($event)\"\n (focus)=\"emitOnFocusEvent($event)\"\n (blur)=\"emitOnBlurEvent($event)\"\n />\n @if (value && !disabled && !readonly) {\n <ng-content select=\"ax-clear-button\"></ng-content>\n }\n @if (showToggleButton) {\n <button type=\"button\" class=\"ax-general-button ax-button-icon\" (click)=\"toggleType()\" [tabIndex]=\"-1\">\n <span class=\"ax-icon {{ _icon }}\"></span>\n </button>\n }\n <ng-content select=\"ax-suffix\"> </ng-content>\n <ng-content select=\"ax-validation-rule\"> </ng-content>\n</div>\n<div class=\"ax-error-container\"></div>\n\n<div class=\"ax-strength-validation-container\">\n <ng-content select=\"ax-password-strength-validation\" [showHint]=\"showStrength()\"></ng-content>\n</div>\n", styles: [".ax-strength-validation-container{margin-top:.25rem}\n"], dependencies: [{ kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
57
65
|
}
|
58
66
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPasswordBoxComponent, decorators: [{
|
59
67
|
type: Component,
|
@@ -78,7 +86,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
78
86
|
useExisting: forwardRef(() => AXPasswordBoxComponent),
|
79
87
|
multi: true,
|
80
88
|
},
|
81
|
-
], template: "<div class=\"ax-editor-container ax-look-{{ look }} {{ classNames }}\" [class.ax-state-disabled]=\"disabled\">\n <ng-content select=\"ax-prefix\"> </ng-content>\n <input\n #input\n class=\"ax-input\"\n [name]=\"name\"\n [type]=\"_type\"\n [id]=\"id\"\n [attr.placeholder]=\"placeholder\"\n [class.ax-state-disabled]=\"disabled\"\n [class.ax-state-readonly]=\"readonly\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [tabindex]=\"tabIndex\"\n [ngModel]=\"value\"\n [attr.autocomplete]=\"autoComplete\"\n (ngModelChange)=\"_handleModelChange($event)\"\n (keydown)=\"emitOnKeydownEvent($event)\"\n (keyup)=\"emitOnKeyupEvent($event)\"\n (keypress)=\"emitOnKeypressEvent($event)\"\n (focus)=\"emitOnFocusEvent($event)\"\n (blur)=\"emitOnBlurEvent($event)\"\n />\n @if (value && !disabled && !readonly) {\n <ng-content select=\"ax-clear-button\"></ng-content>\n }\n @if (showToggleButton) {\n <button type=\"button\" class=\"ax-general-button ax-button-icon\" (click)=\"toggleType()\" [tabIndex]=\"-1\">\n <span class=\"ax-icon {{ _icon }}\"></span>\n </button>\n }\n <ng-content select=\"ax-suffix\"> </ng-content>\n <ng-content select=\"ax-validation-rule\"> </ng-content>\n</div>\n<div class=\"ax-error-container\"></div>\n\n<div class=\"ax-strength-validation-container\">\n <ng-content select=\"ax-password-strength-validation\"></ng-content>\n</div>\n", styles: [".ax-strength-validation-container{margin-top:.
|
89
|
+
], template: "<div class=\"ax-editor-container ax-look-{{ look }} {{ classNames }}\" [class.ax-state-disabled]=\"disabled\">\n <ng-content select=\"ax-prefix\"> </ng-content>\n <input\n #input\n class=\"ax-input\"\n [name]=\"name\"\n [type]=\"_type\"\n [id]=\"id\"\n [attr.placeholder]=\"placeholder\"\n [class.ax-state-disabled]=\"disabled\"\n [class.ax-state-readonly]=\"readonly\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [tabindex]=\"tabIndex\"\n [ngModel]=\"value\"\n [attr.autocomplete]=\"autoComplete\"\n (ngModelChange)=\"_handleModelChange($event)\"\n (keydown)=\"emitOnKeydownEvent($event)\"\n (keyup)=\"emitOnKeyupEvent($event)\"\n (keypress)=\"emitOnKeypressEvent($event)\"\n (focus)=\"emitOnFocusEvent($event)\"\n (blur)=\"emitOnBlurEvent($event)\"\n />\n @if (value && !disabled && !readonly) {\n <ng-content select=\"ax-clear-button\"></ng-content>\n }\n @if (showToggleButton) {\n <button type=\"button\" class=\"ax-general-button ax-button-icon\" (click)=\"toggleType()\" [tabIndex]=\"-1\">\n <span class=\"ax-icon {{ _icon }}\"></span>\n </button>\n }\n <ng-content select=\"ax-suffix\"> </ng-content>\n <ng-content select=\"ax-validation-rule\"> </ng-content>\n</div>\n<div class=\"ax-error-container\"></div>\n\n<div class=\"ax-strength-validation-container\">\n <ng-content select=\"ax-password-strength-validation\" [showHint]=\"showStrength()\"></ng-content>\n</div>\n", styles: [".ax-strength-validation-container{margin-top:.25rem}\n"] }]
|
82
90
|
}], propDecorators: { input: [{
|
83
91
|
type: ViewChild,
|
84
92
|
args: ['input']
|
@@ -90,4 +98,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
90
98
|
type: Input,
|
91
99
|
args: ['class']
|
92
100
|
}] } });
|
93
|
-
//# sourceMappingURL=data:application/json;base64,
|
101
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"password-box.component.js","sourceRoot":"","sources":["../../../../../../libs/components/password-box/src/lib/password-box.component.ts","../../../../../../libs/components/password-box/src/lib/password-box.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AXClearableComponent,\n  AXComponent,\n  AXFocusableComponent,\n  AXValuableComponent,\n  MXInputBaseValueComponent,\n  MXLookComponent,\n} from '@acorex/components/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  ViewChild,\n  ViewEncapsulation,\n  forwardRef,\n  input,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { classes } from 'polytype';\n\n/**\n * The Textbox is a component which detects user interaction and triggers a corresponding event\n *\n * @category Components\n */\n@Component({\n  selector: 'ax-password-box',\n  templateUrl: 'password-box.component.html',\n  inputs: ['readonly', 'disabled', 'tabIndex', 'placeholder', 'value', 'state', 'name', 'id', 'look'],\n  styles: `\n    .ax-strength-validation-container {\n      margin-top: 0.25rem;\n    }\n  `,\n  outputs: [\n    'valueChange',\n    'stateChange',\n    'onValueChanged',\n    'onBlur',\n    'onFocus',\n    'readonlyChange',\n    'disabledChange',\n    'onKeyDown',\n    'onKeyUp',\n    'onKeyPress',\n  ],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n\n  providers: [\n    { provide: AXComponent, useExisting: AXPasswordBoxComponent },\n    { provide: AXFocusableComponent, useExisting: AXPasswordBoxComponent },\n    { provide: AXClearableComponent, useExisting: AXPasswordBoxComponent },\n    { provide: AXValuableComponent, useExisting: AXPasswordBoxComponent },\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => AXPasswordBoxComponent),\n      multi: true,\n    },\n  ],\n})\nexport class AXPasswordBoxComponent extends classes(MXInputBaseValueComponent<string>, MXLookComponent) {\n  /** @ignore */\n  @ViewChild('input') input: ElementRef<HTMLInputElement>;\n\n  /** @ignore */\n  protected _type: 'password' | 'text' = 'password';\n\n  /** @ignore */\n  protected _icon: 'ax-icon-visibility' | 'ax-icon-visibility-off' = 'ax-icon-visibility';\n\n  /**\n   * Sets the autocomplete behavior for the input field.\n   */\n  @Input()\n  autoComplete: 'current-password' | 'new-password' | 'one-time-code' | 'off' = 'one-time-code';\n\n  /**\n   *  A flag for showing or hiding password button.\n   */\n  @Input()\n  showToggleButton = true;\n\n  /**\n   * Defines custom CSS classes to apply to the component.\n   */\n  @Input('class')\n  classNames: string;\n\n  /**\n   * Hint status.\n   */\n  showHint = input(false);\n\n  /**\n   * Progress status.\n   */\n  showProgress = input(false);\n\n  /** @ignore */\n  _handleModelChange(value: string) {\n    this.commitValue(value, true);\n  }\n\n  /**\n   * Toggles the input type between 'password' and 'text' to show or hide the password.\n   */\n  toggleType() {\n    if (this._type === 'password') {\n      this._type = 'text';\n      this._icon = 'ax-icon-visibility-off';\n    } else {\n      this._type = 'password';\n      this._icon = 'ax-icon-visibility';\n    }\n  }\n\n  // @HostBinding('class')\n  // get __hostClass(): string[] {\n  //   return ['ax-editor-container', `ax-look-${this.look}`, `${this.disabled ? 'ax-state-disabled' : ''}`];\n  // }\n}\n","<div class=\"ax-editor-container ax-look-{{ look }} {{ classNames }}\" [class.ax-state-disabled]=\"disabled\">\n  <ng-content select=\"ax-prefix\"> </ng-content>\n  <input\n    #input\n    class=\"ax-input\"\n    [name]=\"name\"\n    [type]=\"_type\"\n    [id]=\"id\"\n    [attr.placeholder]=\"placeholder\"\n    [class.ax-state-disabled]=\"disabled\"\n    [class.ax-state-readonly]=\"readonly\"\n    [disabled]=\"disabled\"\n    [readonly]=\"readonly\"\n    [tabindex]=\"tabIndex\"\n    [ngModel]=\"value\"\n    [attr.autocomplete]=\"autoComplete\"\n    (ngModelChange)=\"_handleModelChange($event)\"\n    (keydown)=\"emitOnKeydownEvent($event)\"\n    (keyup)=\"emitOnKeyupEvent($event)\"\n    (keypress)=\"emitOnKeypressEvent($event)\"\n    (focus)=\"emitOnFocusEvent($event)\"\n    (blur)=\"emitOnBlurEvent($event)\"\n  />\n  @if (value && !disabled && !readonly) {\n    <ng-content select=\"ax-clear-button\"></ng-content>\n  }\n  @if (showToggleButton) {\n    <button type=\"button\" class=\"ax-general-button ax-button-icon\" (click)=\"toggleType()\" [tabIndex]=\"-1\">\n      <span class=\"ax-icon {{ _icon }}\"></span>\n    </button>\n  }\n  <ng-content select=\"ax-suffix\"> </ng-content>\n  <ng-content select=\"ax-validation-rule\"> </ng-content>\n</div>\n<div class=\"ax-error-container\"></div>\n\n<div class=\"ax-strength-validation-container\">\n  <ng-content select=\"ax-password-strength-validation\" [showHint]=\"showStrength()\"></ng-content>\n</div>\n"]}
|
@@ -1,6 +1,8 @@
|
|
1
|
+
import { AXBadgeModule } from '@acorex/components/badge';
|
1
2
|
import { AXButtonModule } from '@acorex/components/button';
|
2
3
|
import { AXDecoratorModule } from '@acorex/components/decorators';
|
3
4
|
import { AXProgressBarModule } from '@acorex/components/progress-bar';
|
5
|
+
import { AXTranslationModule } from '@acorex/core/translation';
|
4
6
|
import { CommonModule } from '@angular/common';
|
5
7
|
import { NgModule } from '@angular/core';
|
6
8
|
import { FormsModule } from '@angular/forms';
|
@@ -8,10 +10,24 @@ import { AXPasswordBoxComponent } from './password-box.component';
|
|
8
10
|
import { AXPasswordStrengthValidationComponent } from './password-strength-validation/password-strength-validation.component';
|
9
11
|
import * as i0 from "@angular/core";
|
10
12
|
const COMPONENT = [AXPasswordBoxComponent, AXPasswordStrengthValidationComponent];
|
11
|
-
const MODULES = [
|
13
|
+
const MODULES = [
|
14
|
+
CommonModule,
|
15
|
+
FormsModule,
|
16
|
+
AXButtonModule,
|
17
|
+
AXDecoratorModule,
|
18
|
+
AXProgressBarModule,
|
19
|
+
AXBadgeModule,
|
20
|
+
AXTranslationModule,
|
21
|
+
];
|
12
22
|
export class AXPasswordBoxModule {
|
13
23
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPasswordBoxModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
14
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.0", ngImport: i0, type: AXPasswordBoxModule, declarations: [AXPasswordBoxComponent, AXPasswordStrengthValidationComponent], imports: [CommonModule,
|
24
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.0", ngImport: i0, type: AXPasswordBoxModule, declarations: [AXPasswordBoxComponent, AXPasswordStrengthValidationComponent], imports: [CommonModule,
|
25
|
+
FormsModule,
|
26
|
+
AXButtonModule,
|
27
|
+
AXDecoratorModule,
|
28
|
+
AXProgressBarModule,
|
29
|
+
AXBadgeModule,
|
30
|
+
AXTranslationModule], exports: [AXPasswordBoxComponent, AXPasswordStrengthValidationComponent] }); }
|
15
31
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPasswordBoxModule, imports: [MODULES] }); }
|
16
32
|
}
|
17
33
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPasswordBoxModule, decorators: [{
|
@@ -23,4 +39,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
23
39
|
providers: [],
|
24
40
|
}]
|
25
41
|
}] });
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFzc3dvcmQtYm94Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9wYXNzd29yZC1ib3gvc3JjL2xpYi9wYXNzd29yZC1ib3gubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDbEUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDdEUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDL0QsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxxQ0FBcUMsRUFBRSxNQUFNLHVFQUF1RSxDQUFDOztBQUU5SCxNQUFNLFNBQVMsR0FBRyxDQUFDLHNCQUFzQixFQUFFLHFDQUFxQyxDQUFDLENBQUM7QUFDbEYsTUFBTSxPQUFPLEdBQUc7SUFDZCxZQUFZO0lBQ1osV0FBVztJQUNYLGNBQWM7SUFDZCxpQkFBaUI7SUFDakIsbUJBQW1CO0lBQ25CLGFBQWE7SUFDYixtQkFBbUI7Q0FDcEIsQ0FBQztBQVFGLE1BQU0sT0FBTyxtQkFBbUI7OEdBQW5CLG1CQUFtQjsrR0FBbkIsbUJBQW1CLGlCQWpCYixzQkFBc0IsRUFBRSxxQ0FBcUMsYUFFOUUsWUFBWTtZQUNaLFdBQVc7WUFDWCxjQUFjO1lBQ2QsaUJBQWlCO1lBQ2pCLG1CQUFtQjtZQUNuQixhQUFhO1lBQ2IsbUJBQW1CLGFBUkYsc0JBQXNCLEVBQUUscUNBQXFDOytHQWlCbkUsbUJBQW1CLFlBSmpCLE9BQU87OzJGQUlULG1CQUFtQjtrQkFOL0IsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQztvQkFDNUIsT0FBTyxFQUFFLENBQUMsR0FBRyxPQUFPLENBQUM7b0JBQ3JCLE9BQU8sRUFBRSxDQUFDLEdBQUcsU0FBUyxDQUFDO29CQUN2QixTQUFTLEVBQUUsRUFBRTtpQkFDZCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFYQmFkZ2VNb2R1bGUgfSBmcm9tICdAYWNvcmV4L2NvbXBvbmVudHMvYmFkZ2UnO1xuaW1wb3J0IHsgQVhCdXR0b25Nb2R1bGUgfSBmcm9tICdAYWNvcmV4L2NvbXBvbmVudHMvYnV0dG9uJztcbmltcG9ydCB7IEFYRGVjb3JhdG9yTW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2RlY29yYXRvcnMnO1xuaW1wb3J0IHsgQVhQcm9ncmVzc0Jhck1vZHVsZSB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9wcm9ncmVzcy1iYXInO1xuaW1wb3J0IHsgQVhUcmFuc2xhdGlvbk1vZHVsZSB9IGZyb20gJ0BhY29yZXgvY29yZS90cmFuc2xhdGlvbic7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgQVhQYXNzd29yZEJveENvbXBvbmVudCB9IGZyb20gJy4vcGFzc3dvcmQtYm94LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBBWFBhc3N3b3JkU3RyZW5ndGhWYWxpZGF0aW9uQ29tcG9uZW50IH0gZnJvbSAnLi9wYXNzd29yZC1zdHJlbmd0aC12YWxpZGF0aW9uL3Bhc3N3b3JkLXN0cmVuZ3RoLXZhbGlkYXRpb24uY29tcG9uZW50JztcblxuY29uc3QgQ09NUE9ORU5UID0gW0FYUGFzc3dvcmRCb3hDb21wb25lbnQsIEFYUGFzc3dvcmRTdHJlbmd0aFZhbGlkYXRpb25Db21wb25lbnRdO1xuY29uc3QgTU9EVUxFUyA9IFtcbiAgQ29tbW9uTW9kdWxlLFxuICBGb3Jtc01vZHVsZSxcbiAgQVhCdXR0b25Nb2R1bGUsXG4gIEFYRGVjb3JhdG9yTW9kdWxlLFxuICBBWFByb2dyZXNzQmFyTW9kdWxlLFxuICBBWEJhZGdlTW9kdWxlLFxuICBBWFRyYW5zbGF0aW9uTW9kdWxlLFxuXTtcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbLi4uQ09NUE9ORU5UXSxcbiAgaW1wb3J0czogWy4uLk1PRFVMRVNdLFxuICBleHBvcnRzOiBbLi4uQ09NUE9ORU5UXSxcbiAgcHJvdmlkZXJzOiBbXSxcbn0pXG5leHBvcnQgY2xhc3MgQVhQYXNzd29yZEJveE1vZHVsZSB7fVxuIl19
|
@@ -2,40 +2,62 @@ import { afterNextRender, ChangeDetectionStrategy, Component, inject, signal, Vi
|
|
2
2
|
import { AXPasswordBoxComponent } from '../password-box.component';
|
3
3
|
import * as i0 from "@angular/core";
|
4
4
|
import * as i1 from "@acorex/components/progress-bar";
|
5
|
+
import * as i2 from "@acorex/components/badge";
|
6
|
+
import * as i3 from "@angular/common";
|
7
|
+
import * as i4 from "@acorex/core/translation";
|
5
8
|
export class AXPasswordStrengthValidationComponent {
|
6
9
|
constructor() {
|
7
10
|
this.passwordStrength = signal(0);
|
8
|
-
this.
|
11
|
+
this.updatedPassword = signal('');
|
12
|
+
this.strengthLabel = signal('fragile');
|
9
13
|
this.strengthLabelColor = signal('danger');
|
10
14
|
this.parent = inject(AXPasswordBoxComponent);
|
15
|
+
this.isLenghtgraterThan8 = signal({ regex: /.{8,}/, state: false });
|
16
|
+
this.isUseUpperCase = signal({ regex: /[A-Z]/, state: false });
|
17
|
+
this.isUseLowerCase = signal({ regex: /[a-z]/, state: false });
|
18
|
+
this.isUseNumber = signal({ regex: /\d/, state: false });
|
19
|
+
this.isUseSpecialCharacter = signal({
|
20
|
+
regex: /[!@#$%^&*(),.?":{}|<>]/,
|
21
|
+
state: false,
|
22
|
+
});
|
11
23
|
this.#onComponentInit = afterNextRender(() => {
|
12
24
|
this.parent.onValueChanged.subscribe((v) => {
|
13
25
|
if (v.value) {
|
14
|
-
this.
|
26
|
+
this.updatedPassword.set(v.value);
|
15
27
|
}
|
16
28
|
else {
|
17
|
-
this.
|
29
|
+
this.updatedPassword.set('');
|
18
30
|
}
|
31
|
+
this.checkPasswordStrength();
|
19
32
|
});
|
20
33
|
});
|
21
34
|
}
|
22
35
|
#onComponentInit;
|
23
|
-
|
36
|
+
checkRegexHandler(inter) {
|
37
|
+
if (inter().regex.test(this.updatedPassword())) {
|
38
|
+
inter.update((prev) => ({ ...prev, state: true }));
|
39
|
+
return true;
|
40
|
+
}
|
41
|
+
inter.update((prev) => ({ ...prev, state: false }));
|
42
|
+
return false;
|
43
|
+
}
|
44
|
+
checkPasswordStrength() {
|
24
45
|
let strength = 0;
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
46
|
+
this.checkRegexHandler(this.isLenghtgraterThan8) && strength++;
|
47
|
+
this.checkRegexHandler(this.isUseUpperCase) && strength++;
|
48
|
+
this.checkRegexHandler(this.isUseLowerCase) && strength++;
|
49
|
+
this.checkRegexHandler(this.isUseNumber) && strength++;
|
50
|
+
this.checkRegexHandler(this.isUseSpecialCharacter) && strength++;
|
51
|
+
const strengthLabels = ['fragile', 'fragile', 'weak', 'good', 'strong', 'unbreakable'];
|
52
|
+
this.strengthLabel.set(strengthLabels[strength]);
|
31
53
|
this.strengthLabelColor.set(strength <= 2 ? 'danger' : strength <= 3 ? 'warning' : 'success');
|
32
|
-
this.passwordStrength.set((strength * 100) /
|
54
|
+
this.passwordStrength.set((strength * 100) / 5);
|
33
55
|
}
|
34
56
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPasswordStrengthValidationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
35
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
57
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: AXPasswordStrengthValidationComponent, selector: "ax-password-strength-validation", ngImport: i0, template: "@if (parent.showProgress()) {\n <small\n class=\"ax-state-password\"\n [class.ax-text-red]=\"strengthLabelColor() === 'danger'\"\n [class.ax-text-orange]=\"strengthLabelColor() === 'warning'\"\n [class.ax-text-green]=\"strengthLabelColor() === 'success'\"\n >\n {{ strengthLabel() | translate | async }}\n </small>\n\n <ax-progress-bar\n [color]=\"strengthLabelColor()\"\n [progress]=\"passwordStrength()\"\n [height]=\"4\"\n ></ax-progress-bar>\n}\n@if (parent.showHint()) {\n <div class=\"ax-hint-container\">\n <small class=\"ax-hint-state\">\n <ax-badge [color]=\"isLenghtgraterThan8().state ? 'success' : 'danger'\"></ax-badge>\n <span [class.ax-line]=\"isLenghtgraterThan8().state\">\n {{ 'at-least-8-characters' | translate | async }}\n </span>\n </small>\n <small class=\"ax-hint-state\" [class.ax-line]=\"isUseUpperCase().state\">\n <ax-badge [color]=\"isUseUpperCase().state ? 'success' : 'danger'\"></ax-badge>\n <span>\n {{ 'english-upper-case-letter' | translate | async }}\n </span>\n </small>\n <small class=\"ax-hint-state\" [class.ax-line]=\"isUseLowerCase().state\">\n <ax-badge [color]=\"isUseLowerCase().state ? 'success' : 'danger'\"></ax-badge>\n <span>\n {{ 'english-lower-case-letter' | translate | async }}\n </span>\n </small>\n <small class=\"ax-hint-state\" [class.ax-line]=\"isUseNumber().state\">\n <ax-badge [color]=\"isUseNumber().state ? 'success' : 'danger'\"></ax-badge\n ><span> {{ 'digits' | translate | async }} </span>\n </small>\n <small class=\"ax-hint-state\" [class.ax-line]=\"isUseSpecialCharacter().state\">\n <ax-badge [color]=\"isUseSpecialCharacter().state ? 'success' : 'danger'\"></ax-badge>\n <span>\n {{ 'special-character' | translate | async }}\n </span>\n </small>\n </div>\n}\n", styles: [".ax-state-password.ax-text-red{color:rgb(var(--ax-color-danger-500))}.ax-state-password.ax-text-orange{color:rgb(var(--ax-color-warning-500))}.ax-state-password.ax-text-green{color:rgb(var(--ax-color-success-500))}.ax-hint-container{display:flex;flex-direction:column;gap:.5rem;padding-top:.5rem}.ax-hint-container .ax-line{text-decoration:line-through}\n"], dependencies: [{ kind: "component", type: i1.AXProgressBarComponent, selector: "ax-progress-bar", inputs: ["color", "mode", "progress", "height"], outputs: ["ValueChange", "sizeChange"] }, { kind: "component", type: i2.AXBadgeComponent, selector: "ax-badge", inputs: ["color", "look", "text"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.AXTranslatorPipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
36
58
|
}
|
37
59
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXPasswordStrengthValidationComponent, decorators: [{
|
38
60
|
type: Component,
|
39
|
-
args: [{ selector: 'ax-password-strength-validation', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<ax-progress-bar\n
|
61
|
+
args: [{ selector: 'ax-password-strength-validation', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "@if (parent.showProgress()) {\n <small\n class=\"ax-state-password\"\n [class.ax-text-red]=\"strengthLabelColor() === 'danger'\"\n [class.ax-text-orange]=\"strengthLabelColor() === 'warning'\"\n [class.ax-text-green]=\"strengthLabelColor() === 'success'\"\n >\n {{ strengthLabel() | translate | async }}\n </small>\n\n <ax-progress-bar\n [color]=\"strengthLabelColor()\"\n [progress]=\"passwordStrength()\"\n [height]=\"4\"\n ></ax-progress-bar>\n}\n@if (parent.showHint()) {\n <div class=\"ax-hint-container\">\n <small class=\"ax-hint-state\">\n <ax-badge [color]=\"isLenghtgraterThan8().state ? 'success' : 'danger'\"></ax-badge>\n <span [class.ax-line]=\"isLenghtgraterThan8().state\">\n {{ 'at-least-8-characters' | translate | async }}\n </span>\n </small>\n <small class=\"ax-hint-state\" [class.ax-line]=\"isUseUpperCase().state\">\n <ax-badge [color]=\"isUseUpperCase().state ? 'success' : 'danger'\"></ax-badge>\n <span>\n {{ 'english-upper-case-letter' | translate | async }}\n </span>\n </small>\n <small class=\"ax-hint-state\" [class.ax-line]=\"isUseLowerCase().state\">\n <ax-badge [color]=\"isUseLowerCase().state ? 'success' : 'danger'\"></ax-badge>\n <span>\n {{ 'english-lower-case-letter' | translate | async }}\n </span>\n </small>\n <small class=\"ax-hint-state\" [class.ax-line]=\"isUseNumber().state\">\n <ax-badge [color]=\"isUseNumber().state ? 'success' : 'danger'\"></ax-badge\n ><span> {{ 'digits' | translate | async }} </span>\n </small>\n <small class=\"ax-hint-state\" [class.ax-line]=\"isUseSpecialCharacter().state\">\n <ax-badge [color]=\"isUseSpecialCharacter().state ? 'success' : 'danger'\"></ax-badge>\n <span>\n {{ 'special-character' | translate | async }}\n </span>\n </small>\n </div>\n}\n", styles: [".ax-state-password.ax-text-red{color:rgb(var(--ax-color-danger-500))}.ax-state-password.ax-text-orange{color:rgb(var(--ax-color-warning-500))}.ax-state-password.ax-text-green{color:rgb(var(--ax-color-success-500))}.ax-hint-container{display:flex;flex-direction:column;gap:.5rem;padding-top:.5rem}.ax-hint-container .ax-line{text-decoration:line-through}\n"] }]
|
40
62
|
}] });
|
41
|
-
//# sourceMappingURL=data:application/json;base64,
|
63
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"password-strength-validation.component.js","sourceRoot":"","sources":["../../../../../../../libs/components/password-box/src/lib/password-strength-validation/password-strength-validation.component.ts","../../../../../../../libs/components/password-box/src/lib/password-strength-validation/password-strength-validation.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  afterNextRender,\n  ChangeDetectionStrategy,\n  Component,\n  inject,\n  signal,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { AXPasswordBoxComponent } from '../password-box.component';\n\n@Component({\n  selector: 'ax-password-strength-validation',\n  templateUrl: './password-strength-validation.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  styleUrl: './password-strength-validation.component.scss',\n})\nexport class AXPasswordStrengthValidationComponent {\n  protected passwordStrength = signal(0);\n  protected updatedPassword = signal('');\n  protected strengthLabel = signal('fragile');\n  protected strengthLabelColor = signal('danger');\n  protected parent = inject(AXPasswordBoxComponent);\n\n  protected isLenghtgraterThan8 = signal({ regex: /.{8,}/, state: false });\n  protected isUseUpperCase = signal({ regex: /[A-Z]/, state: false });\n  protected isUseLowerCase = signal({ regex: /[a-z]/, state: false });\n  protected isUseNumber = signal({ regex: /\\d/, state: false });\n  protected isUseSpecialCharacter = signal({\n    regex: /[!@#$%^&*(),.?\":{}|<>]/,\n    state: false,\n  });\n\n  #onComponentInit = afterNextRender(() => {\n    this.parent.onValueChanged.subscribe((v) => {\n      if (v.value) {\n        this.updatedPassword.set(v.value);\n      } else {\n        this.updatedPassword.set('');\n      }\n      this.checkPasswordStrength();\n    });\n  });\n\n  private checkRegexHandler(inter) {\n    if (inter().regex.test(this.updatedPassword())) {\n      inter.update((prev) => ({ ...prev, state: true }));\n      return true;\n    }\n    inter.update((prev) => ({ ...prev, state: false }));\n    return false;\n  }\n\n  protected checkPasswordStrength() {\n    let strength = 0;\n\n    this.checkRegexHandler(this.isLenghtgraterThan8) && strength++;\n    this.checkRegexHandler(this.isUseUpperCase) && strength++;\n    this.checkRegexHandler(this.isUseLowerCase) && strength++;\n    this.checkRegexHandler(this.isUseNumber) && strength++;\n    this.checkRegexHandler(this.isUseSpecialCharacter) && strength++;\n\n    const strengthLabels = ['fragile', 'fragile', 'weak', 'good', 'strong', 'unbreakable'];\n    this.strengthLabel.set(strengthLabels[strength]);\n    this.strengthLabelColor.set(strength <= 2 ? 'danger' : strength <= 3 ? 'warning' : 'success');\n    this.passwordStrength.set((strength * 100) / 5);\n  }\n}\n","@if (parent.showProgress()) {\n  <small\n    class=\"ax-state-password\"\n    [class.ax-text-red]=\"strengthLabelColor() === 'danger'\"\n    [class.ax-text-orange]=\"strengthLabelColor() === 'warning'\"\n    [class.ax-text-green]=\"strengthLabelColor() === 'success'\"\n  >\n    {{ strengthLabel() | translate | async }}\n  </small>\n\n  <ax-progress-bar\n    [color]=\"strengthLabelColor()\"\n    [progress]=\"passwordStrength()\"\n    [height]=\"4\"\n  ></ax-progress-bar>\n}\n@if (parent.showHint()) {\n  <div class=\"ax-hint-container\">\n    <small class=\"ax-hint-state\">\n      <ax-badge [color]=\"isLenghtgraterThan8().state ? 'success' : 'danger'\"></ax-badge>\n      <span [class.ax-line]=\"isLenghtgraterThan8().state\">\n        {{ 'at-least-8-characters' | translate | async }}\n      </span>\n    </small>\n    <small class=\"ax-hint-state\" [class.ax-line]=\"isUseUpperCase().state\">\n      <ax-badge [color]=\"isUseUpperCase().state ? 'success' : 'danger'\"></ax-badge>\n      <span>\n        {{ 'english-upper-case-letter' | translate | async }}\n      </span>\n    </small>\n    <small class=\"ax-hint-state\" [class.ax-line]=\"isUseLowerCase().state\">\n      <ax-badge [color]=\"isUseLowerCase().state ? 'success' : 'danger'\"></ax-badge>\n      <span>\n        {{ 'english-lower-case-letter' | translate | async }}\n      </span>\n    </small>\n    <small class=\"ax-hint-state\" [class.ax-line]=\"isUseNumber().state\">\n      <ax-badge [color]=\"isUseNumber().state ? 'success' : 'danger'\"></ax-badge\n      ><span> {{ 'digits' | translate | async }} </span>\n    </small>\n    <small class=\"ax-hint-state\" [class.ax-line]=\"isUseSpecialCharacter().state\">\n      <ax-badge [color]=\"isUseSpecialCharacter().state ? 'success' : 'danger'\"></ax-badge>\n      <span>\n        {{ 'special-character' | translate | async }}\n      </span>\n    </small>\n  </div>\n}\n"]}
|