@tailng-ui/primitives 0.1.0 → 0.12.0
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/README.md +97 -11
- package/package.json +9 -3
- package/src/index.d.ts +5 -0
- package/src/index.d.ts.map +1 -1
- package/src/index.js +5 -0
- package/src/index.js.map +1 -1
- package/src/lib/feedback/empty/tng-empty.d.ts.map +1 -1
- package/src/lib/feedback/empty/tng-empty.js +5 -0
- package/src/lib/feedback/empty/tng-empty.js.map +1 -1
- package/src/lib/feedback/progress-bar/tng-progress-bar.d.ts.map +1 -1
- package/src/lib/feedback/progress-bar/tng-progress-bar.js +4 -1
- package/src/lib/feedback/progress-bar/tng-progress-bar.js.map +1 -1
- package/src/lib/feedback/progress-spinner/tng-progress-spinner.d.ts.map +1 -1
- package/src/lib/feedback/progress-spinner/tng-progress-spinner.js +3 -1
- package/src/lib/feedback/progress-spinner/tng-progress-spinner.js.map +1 -1
- package/src/lib/feedback/skeleton/tng-skeleton.d.ts +1 -0
- package/src/lib/feedback/skeleton/tng-skeleton.d.ts.map +1 -1
- package/src/lib/feedback/skeleton/tng-skeleton.js +5 -0
- package/src/lib/feedback/skeleton/tng-skeleton.js.map +1 -1
- package/src/lib/feedback/toast/tng-toast.d.ts.map +1 -1
- package/src/lib/feedback/toast/tng-toast.js +2 -0
- package/src/lib/feedback/toast/tng-toast.js.map +1 -1
- package/src/lib/form/checkbox/tng-checkbox.d.ts.map +1 -1
- package/src/lib/form/checkbox/tng-checkbox.js +1 -0
- package/src/lib/form/checkbox/tng-checkbox.js.map +1 -1
- package/src/lib/form/chips/tng-chips.d.ts +53 -1
- package/src/lib/form/chips/tng-chips.d.ts.map +1 -1
- package/src/lib/form/chips/tng-chips.js +284 -1
- package/src/lib/form/chips/tng-chips.js.map +1 -1
- package/src/lib/form/combobox/tng-combobox.d.ts.map +1 -1
- package/src/lib/form/combobox/tng-combobox.js +1 -0
- package/src/lib/form/combobox/tng-combobox.js.map +1 -1
- package/src/lib/form/input-otp/tng-input-otp.d.ts +22 -0
- package/src/lib/form/input-otp/tng-input-otp.d.ts.map +1 -1
- package/src/lib/form/input-otp/tng-input-otp.js +106 -1
- package/src/lib/form/input-otp/tng-input-otp.js.map +1 -1
- package/src/lib/form/label/tng-label.d.ts +2 -0
- package/src/lib/form/label/tng-label.d.ts.map +1 -1
- package/src/lib/form/label/tng-label.js +10 -0
- package/src/lib/form/label/tng-label.js.map +1 -1
- package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.trigger.d.ts +1 -0
- package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.trigger.d.ts.map +1 -1
- package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.trigger.js +26 -0
- package/src/lib/form/multi-autocomplete/tng-multi-autocomplete.trigger.js.map +1 -1
- package/src/lib/form/multiselect/tng-multiselect.d.ts.map +1 -1
- package/src/lib/form/multiselect/tng-multiselect.js +1 -0
- package/src/lib/form/multiselect/tng-multiselect.js.map +1 -1
- package/src/lib/form/radio/tng-radio.d.ts +26 -0
- package/src/lib/form/radio/tng-radio.d.ts.map +1 -1
- package/src/lib/form/radio/tng-radio.js +130 -1
- package/src/lib/form/radio/tng-radio.js.map +1 -1
- package/src/lib/form/slider/tng-slider.d.ts.map +1 -1
- package/src/lib/form/slider/tng-slider.js +1 -0
- package/src/lib/form/slider/tng-slider.js.map +1 -1
- package/src/lib/form/switch/tng-switch.d.ts.map +1 -1
- package/src/lib/form/switch/tng-switch.js +1 -0
- package/src/lib/form/switch/tng-switch.js.map +1 -1
- package/src/lib/form/textarea/tng-textarea.d.ts +6 -14
- package/src/lib/form/textarea/tng-textarea.d.ts.map +1 -1
- package/src/lib/form/textarea/tng-textarea.js +42 -85
- package/src/lib/form/textarea/tng-textarea.js.map +1 -1
- package/src/lib/form/toggle/tng-toggle.d.ts.map +1 -1
- package/src/lib/form/toggle/tng-toggle.js +1 -0
- package/src/lib/form/toggle/tng-toggle.js.map +1 -1
- package/src/lib/form/toggle-group/tng-toggle-group.d.ts.map +1 -1
- package/src/lib/form/toggle-group/tng-toggle-group.js +1 -0
- package/src/lib/form/toggle-group/tng-toggle-group.js.map +1 -1
- package/src/lib/layout/accordion/tng-accordion.d.ts +9 -0
- package/src/lib/layout/accordion/tng-accordion.d.ts.map +1 -1
- package/src/lib/layout/accordion/tng-accordion.js +113 -0
- package/src/lib/layout/accordion/tng-accordion.js.map +1 -1
- package/src/lib/layout/bottom-sheet/tng-bottom-sheet.d.ts.map +1 -1
- package/src/lib/layout/bottom-sheet/tng-bottom-sheet.js +1 -0
- package/src/lib/layout/bottom-sheet/tng-bottom-sheet.js.map +1 -1
- package/src/lib/layout/card/tng-card.d.ts.map +1 -1
- package/src/lib/layout/card/tng-card.js +10 -0
- package/src/lib/layout/card/tng-card.js.map +1 -1
- package/src/lib/layout/collapsible/tng-collapsible.d.ts.map +1 -1
- package/src/lib/layout/collapsible/tng-collapsible.js +3 -0
- package/src/lib/layout/collapsible/tng-collapsible.js.map +1 -1
- package/src/lib/layout/grid/tng-grid.d.ts.map +1 -1
- package/src/lib/layout/grid/tng-grid.js +1 -0
- package/src/lib/layout/grid/tng-grid.js.map +1 -1
- package/src/lib/layout/separator/tng-separator.d.ts.map +1 -1
- package/src/lib/layout/separator/tng-separator.js +1 -0
- package/src/lib/layout/separator/tng-separator.js.map +1 -1
- package/src/lib/layout/stepper/tng-stepper.d.ts.map +1 -1
- package/src/lib/layout/stepper/tng-stepper.js +1 -0
- package/src/lib/layout/stepper/tng-stepper.js.map +1 -1
- package/src/lib/layout/tree/__tests__/tng-tree.test-harness.d.ts +20 -0
- package/src/lib/layout/tree/__tests__/tng-tree.test-harness.d.ts.map +1 -0
- package/src/lib/layout/tree/__tests__/tng-tree.test-harness.js +106 -0
- package/src/lib/layout/tree/__tests__/tng-tree.test-harness.js.map +1 -0
- package/src/lib/layout/tree/index.d.ts +5 -0
- package/src/lib/layout/tree/index.d.ts.map +1 -0
- package/src/lib/layout/tree/index.js +5 -0
- package/src/lib/layout/tree/index.js.map +1 -0
- package/src/lib/layout/tree/tng-tree-group.d.ts +10 -0
- package/src/lib/layout/tree/tng-tree-group.d.ts.map +1 -0
- package/src/lib/layout/tree/tng-tree-group.js +29 -0
- package/src/lib/layout/tree/tng-tree-group.js.map +1 -0
- package/src/lib/layout/tree/tng-tree-indicator.d.ts +8 -0
- package/src/lib/layout/tree/tng-tree-indicator.d.ts.map +1 -0
- package/src/lib/layout/tree/tng-tree-indicator.js +36 -0
- package/src/lib/layout/tree/tng-tree-indicator.js.map +1 -0
- package/src/lib/layout/tree/tng-tree-item.d.ts +36 -0
- package/src/lib/layout/tree/tng-tree-item.d.ts.map +1 -0
- package/src/lib/layout/tree/tng-tree-item.js +139 -0
- package/src/lib/layout/tree/tng-tree-item.js.map +1 -0
- package/src/lib/layout/tree/tng-tree.d.ts +64 -1
- package/src/lib/layout/tree/tng-tree.d.ts.map +1 -1
- package/src/lib/layout/tree/tng-tree.js +536 -1
- package/src/lib/layout/tree/tng-tree.js.map +1 -1
- package/src/lib/layout/tree/tng-tree.transforms.d.ts +10 -0
- package/src/lib/layout/tree/tng-tree.transforms.d.ts.map +1 -0
- package/src/lib/layout/tree/tng-tree.transforms.js +46 -0
- package/src/lib/layout/tree/tng-tree.transforms.js.map +1 -0
- package/src/lib/navigation/breadcrumb/tng-breadcrumb.d.ts.map +1 -1
- package/src/lib/navigation/breadcrumb/tng-breadcrumb.js +5 -0
- package/src/lib/navigation/breadcrumb/tng-breadcrumb.js.map +1 -1
- package/src/lib/navigation/dropdown-menu/tng-dropdown-menu.d.ts.map +1 -1
- package/src/lib/navigation/dropdown-menu/tng-dropdown-menu.js +1 -0
- package/src/lib/navigation/dropdown-menu/tng-dropdown-menu.js.map +1 -1
- package/src/lib/navigation/navigation-menu/tng-navigation-menu.d.ts.map +1 -1
- package/src/lib/navigation/navigation-menu/tng-navigation-menu.js +1 -0
- package/src/lib/navigation/navigation-menu/tng-navigation-menu.js.map +1 -1
- package/src/lib/navigation/toolbar/tng-toolbar.d.ts.map +1 -1
- package/src/lib/navigation/toolbar/tng-toolbar.js +1 -0
- package/src/lib/navigation/toolbar/tng-toolbar.js.map +1 -1
- package/src/lib/overlay/dialog/tng-dialog.d.ts +158 -0
- package/src/lib/overlay/dialog/tng-dialog.d.ts.map +1 -0
- package/src/lib/overlay/dialog/tng-dialog.js +854 -0
- package/src/lib/overlay/dialog/tng-dialog.js.map +1 -0
- package/src/lib/overlay/popover/tng-popover.d.ts +121 -0
- package/src/lib/overlay/popover/tng-popover.d.ts.map +1 -0
- package/src/lib/overlay/popover/tng-popover.js +614 -0
- package/src/lib/overlay/popover/tng-popover.js.map +1 -0
- package/src/lib/overlay/tng-overlay-runtime.d.ts +11 -0
- package/src/lib/overlay/tng-overlay-runtime.d.ts.map +1 -0
- package/src/lib/overlay/tng-overlay-runtime.js +6 -0
- package/src/lib/overlay/tng-overlay-runtime.js.map +1 -0
- package/src/lib/overlay/tooltip/tng-tooltip.d.ts +92 -3
- package/src/lib/overlay/tooltip/tng-tooltip.d.ts.map +1 -1
- package/src/lib/overlay/tooltip/tng-tooltip.js +477 -3
- package/src/lib/overlay/tooltip/tng-tooltip.js.map +1 -1
- package/src/lib/utility/avatar/tng-avatar.d.ts.map +1 -1
- package/src/lib/utility/avatar/tng-avatar.js +3 -0
- package/src/lib/utility/avatar/tng-avatar.js.map +1 -1
- package/src/lib/utility/badge/tng-badge.d.ts +6 -0
- package/src/lib/utility/badge/tng-badge.d.ts.map +1 -1
- package/src/lib/utility/badge/tng-badge.js +66 -0
- package/src/lib/utility/badge/tng-badge.js.map +1 -1
- package/src/lib/utility/code-block/tng-code-block.d.ts.map +1 -1
- package/src/lib/utility/code-block/tng-code-block.js +5 -0
- package/src/lib/utility/code-block/tng-code-block.js.map +1 -1
- package/src/lib/utility/copy/tng-copy.d.ts +21 -10
- package/src/lib/utility/copy/tng-copy.d.ts.map +1 -1
- package/src/lib/utility/copy/tng-copy.js +118 -88
- package/src/lib/utility/copy/tng-copy.js.map +1 -1
- package/src/lib/utility/press/tng-press.d.ts.map +1 -1
- package/src/lib/utility/press/tng-press.js +1 -0
- package/src/lib/utility/press/tng-press.js.map +1 -1
- package/src/lib/utility/tag/tng-tag.d.ts +37 -0
- package/src/lib/utility/tag/tng-tag.d.ts.map +1 -1
- package/src/lib/utility/tag/tng-tag.js +198 -1
- package/src/lib/utility/tag/tng-tag.js.map +1 -1
|
@@ -1,8 +1,61 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
|
-
import { Directive, HostBinding } from '@angular/core';
|
|
2
|
+
import { Directive, ElementRef, HostBinding, HostListener, booleanAttribute, inject, input, output, } from '@angular/core';
|
|
3
|
+
function normalizeString(value) {
|
|
4
|
+
if (value === undefined || value === null) {
|
|
5
|
+
return null;
|
|
6
|
+
}
|
|
7
|
+
const normalized = value.trim();
|
|
8
|
+
return normalized.length > 0 ? normalized : null;
|
|
9
|
+
}
|
|
3
10
|
let TngTag = class TngTag {
|
|
11
|
+
disabled = input(false, {
|
|
12
|
+
alias: 'tngTagDisabled',
|
|
13
|
+
transform: booleanAttribute,
|
|
14
|
+
});
|
|
15
|
+
removable = input(false, {
|
|
16
|
+
alias: 'tngTagRemovable',
|
|
17
|
+
transform: booleanAttribute,
|
|
18
|
+
});
|
|
19
|
+
label = input(null, {
|
|
20
|
+
alias: 'tngTagLabel',
|
|
21
|
+
});
|
|
22
|
+
tngTagRemoved = output();
|
|
23
|
+
isDisabled() {
|
|
24
|
+
return this.disabled();
|
|
25
|
+
}
|
|
26
|
+
isRemovable() {
|
|
27
|
+
return this.removable() && !this.isDisabled();
|
|
28
|
+
}
|
|
29
|
+
resolvedLabel() {
|
|
30
|
+
return normalizeString(this.label()) ?? 'tag';
|
|
31
|
+
}
|
|
32
|
+
requestRemove() {
|
|
33
|
+
if (!this.isRemovable()) {
|
|
34
|
+
return false;
|
|
35
|
+
}
|
|
36
|
+
this.tngTagRemoved.emit();
|
|
37
|
+
return true;
|
|
38
|
+
}
|
|
39
|
+
get ariaDisabledAttr() {
|
|
40
|
+
return this.isDisabled() ? 'true' : null;
|
|
41
|
+
}
|
|
42
|
+
get dataDisabledAttr() {
|
|
43
|
+
return this.isDisabled() ? '' : null;
|
|
44
|
+
}
|
|
45
|
+
get dataRemovableAttr() {
|
|
46
|
+
return this.removable() ? '' : null;
|
|
47
|
+
}
|
|
4
48
|
dataSlot = 'tag';
|
|
5
49
|
};
|
|
50
|
+
__decorate([
|
|
51
|
+
HostBinding('attr.aria-disabled')
|
|
52
|
+
], TngTag.prototype, "ariaDisabledAttr", null);
|
|
53
|
+
__decorate([
|
|
54
|
+
HostBinding('attr.data-disabled')
|
|
55
|
+
], TngTag.prototype, "dataDisabledAttr", null);
|
|
56
|
+
__decorate([
|
|
57
|
+
HostBinding('attr.data-removable')
|
|
58
|
+
], TngTag.prototype, "dataRemovableAttr", null);
|
|
6
59
|
__decorate([
|
|
7
60
|
HostBinding('attr.data-slot')
|
|
8
61
|
], TngTag.prototype, "dataSlot", void 0);
|
|
@@ -10,7 +63,151 @@ TngTag = __decorate([
|
|
|
10
63
|
Directive({
|
|
11
64
|
selector: '[tngTag]',
|
|
12
65
|
exportAs: 'tngTag',
|
|
66
|
+
standalone: true,
|
|
13
67
|
})
|
|
14
68
|
], TngTag);
|
|
15
69
|
export { TngTag };
|
|
70
|
+
let TngTagIcon = class TngTagIcon {
|
|
71
|
+
dataSlot = 'tag-icon';
|
|
72
|
+
};
|
|
73
|
+
__decorate([
|
|
74
|
+
HostBinding('attr.data-slot')
|
|
75
|
+
], TngTagIcon.prototype, "dataSlot", void 0);
|
|
76
|
+
TngTagIcon = __decorate([
|
|
77
|
+
Directive({
|
|
78
|
+
selector: '[tngTagIcon]',
|
|
79
|
+
exportAs: 'tngTagIcon',
|
|
80
|
+
standalone: true,
|
|
81
|
+
})
|
|
82
|
+
], TngTagIcon);
|
|
83
|
+
export { TngTagIcon };
|
|
84
|
+
let TngTagClose = class TngTagClose {
|
|
85
|
+
elementRef = inject(ElementRef);
|
|
86
|
+
tag = inject(TngTag, { optional: true });
|
|
87
|
+
focused = false;
|
|
88
|
+
suppressNextClick = false;
|
|
89
|
+
ariaLabel = input(null, {
|
|
90
|
+
alias: 'tngTagCloseAriaLabel',
|
|
91
|
+
});
|
|
92
|
+
onClick(event) {
|
|
93
|
+
if (this.suppressNextClick) {
|
|
94
|
+
this.suppressNextClick = false;
|
|
95
|
+
event.preventDefault();
|
|
96
|
+
event.stopPropagation();
|
|
97
|
+
return;
|
|
98
|
+
}
|
|
99
|
+
if (!this.requestRemove()) {
|
|
100
|
+
event.preventDefault();
|
|
101
|
+
event.stopPropagation();
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
onFocusIn() {
|
|
105
|
+
this.focused = true;
|
|
106
|
+
}
|
|
107
|
+
onFocusOut() {
|
|
108
|
+
this.focused = false;
|
|
109
|
+
}
|
|
110
|
+
onKeydown(event) {
|
|
111
|
+
if (event.key !== 'Enter' && event.key !== ' ') {
|
|
112
|
+
return;
|
|
113
|
+
}
|
|
114
|
+
event.preventDefault();
|
|
115
|
+
event.stopPropagation();
|
|
116
|
+
this.suppressNextClick = true;
|
|
117
|
+
setTimeout(() => {
|
|
118
|
+
this.suppressNextClick = false;
|
|
119
|
+
});
|
|
120
|
+
this.requestRemove();
|
|
121
|
+
}
|
|
122
|
+
requestRemove() {
|
|
123
|
+
return this.tag?.requestRemove() === true;
|
|
124
|
+
}
|
|
125
|
+
isButtonElement() {
|
|
126
|
+
return this.elementRef.nativeElement.tagName === 'BUTTON';
|
|
127
|
+
}
|
|
128
|
+
isDisabled() {
|
|
129
|
+
return this.tag?.isRemovable() !== true;
|
|
130
|
+
}
|
|
131
|
+
get ariaLabelAttr() {
|
|
132
|
+
const explicit = normalizeString(this.ariaLabel());
|
|
133
|
+
if (explicit !== null) {
|
|
134
|
+
return explicit;
|
|
135
|
+
}
|
|
136
|
+
const hostDefined = normalizeString(this.elementRef.nativeElement.getAttribute('aria-label'));
|
|
137
|
+
if (hostDefined !== null) {
|
|
138
|
+
return hostDefined;
|
|
139
|
+
}
|
|
140
|
+
const label = this.tag?.resolvedLabel() ?? 'tag';
|
|
141
|
+
return `Remove ${label}`;
|
|
142
|
+
}
|
|
143
|
+
get dataDisabledAttr() {
|
|
144
|
+
return this.isDisabled() ? '' : null;
|
|
145
|
+
}
|
|
146
|
+
get dataFocusedAttr() {
|
|
147
|
+
return this.focused ? '' : null;
|
|
148
|
+
}
|
|
149
|
+
dataSlot = 'tag-close';
|
|
150
|
+
get disabledAttr() {
|
|
151
|
+
if (!this.isButtonElement()) {
|
|
152
|
+
return null;
|
|
153
|
+
}
|
|
154
|
+
return this.isDisabled() ? '' : null;
|
|
155
|
+
}
|
|
156
|
+
get roleAttr() {
|
|
157
|
+
return this.isButtonElement() ? null : 'button';
|
|
158
|
+
}
|
|
159
|
+
get tabIndexAttr() {
|
|
160
|
+
if (this.isButtonElement()) {
|
|
161
|
+
return null;
|
|
162
|
+
}
|
|
163
|
+
return this.isDisabled() ? '-1' : '0';
|
|
164
|
+
}
|
|
165
|
+
get typeAttr() {
|
|
166
|
+
return this.isButtonElement() ? 'button' : null;
|
|
167
|
+
}
|
|
168
|
+
};
|
|
169
|
+
__decorate([
|
|
170
|
+
HostListener('click', ['$event'])
|
|
171
|
+
], TngTagClose.prototype, "onClick", null);
|
|
172
|
+
__decorate([
|
|
173
|
+
HostListener('focusin')
|
|
174
|
+
], TngTagClose.prototype, "onFocusIn", null);
|
|
175
|
+
__decorate([
|
|
176
|
+
HostListener('focusout')
|
|
177
|
+
], TngTagClose.prototype, "onFocusOut", null);
|
|
178
|
+
__decorate([
|
|
179
|
+
HostListener('keydown', ['$event'])
|
|
180
|
+
], TngTagClose.prototype, "onKeydown", null);
|
|
181
|
+
__decorate([
|
|
182
|
+
HostBinding('attr.aria-label')
|
|
183
|
+
], TngTagClose.prototype, "ariaLabelAttr", null);
|
|
184
|
+
__decorate([
|
|
185
|
+
HostBinding('attr.data-disabled')
|
|
186
|
+
], TngTagClose.prototype, "dataDisabledAttr", null);
|
|
187
|
+
__decorate([
|
|
188
|
+
HostBinding('attr.data-focused')
|
|
189
|
+
], TngTagClose.prototype, "dataFocusedAttr", null);
|
|
190
|
+
__decorate([
|
|
191
|
+
HostBinding('attr.data-slot')
|
|
192
|
+
], TngTagClose.prototype, "dataSlot", void 0);
|
|
193
|
+
__decorate([
|
|
194
|
+
HostBinding('attr.disabled')
|
|
195
|
+
], TngTagClose.prototype, "disabledAttr", null);
|
|
196
|
+
__decorate([
|
|
197
|
+
HostBinding('attr.role')
|
|
198
|
+
], TngTagClose.prototype, "roleAttr", null);
|
|
199
|
+
__decorate([
|
|
200
|
+
HostBinding('attr.tabindex')
|
|
201
|
+
], TngTagClose.prototype, "tabIndexAttr", null);
|
|
202
|
+
__decorate([
|
|
203
|
+
HostBinding('attr.type')
|
|
204
|
+
], TngTagClose.prototype, "typeAttr", null);
|
|
205
|
+
TngTagClose = __decorate([
|
|
206
|
+
Directive({
|
|
207
|
+
selector: '[tngTagClose]',
|
|
208
|
+
exportAs: 'tngTagClose',
|
|
209
|
+
standalone: true,
|
|
210
|
+
})
|
|
211
|
+
], TngTagClose);
|
|
212
|
+
export { TngTagClose };
|
|
16
213
|
//# sourceMappingURL=tng-tag.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tng-tag.js","sourceRoot":"","sources":["../../../../../../../../libs/tailng-ui/primitives/src/lib/utility/tag/tng-tag.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAMhD,IAAM,MAAM,GAAZ,MAAM,MAAM;IAEE,QAAQ,GAAG,KAAc,CAAC;CAC9C,CAAA;AADoB;IADlB,WAAW,CAAC,gBAAgB,CAAC;wCACe;AAFlC,MAAM;IAJlB,SAAS,CAAC;QACT,QAAQ,EAAE,UAAU;QACpB,QAAQ,EAAE,QAAQ;KACnB,CAAC;GACW,MAAM,CAGlB","sourcesContent":["import { Directive, HostBinding } from '@angular/core';\n\n@Directive({\n selector: '[tngTag]',\n exportAs: 'tngTag',\n})\nexport class TngTag {\n @HostBinding('attr.data-slot')\n protected readonly dataSlot = 'tag' as const;\n}\n"]}
|
|
1
|
+
{"version":3,"file":"tng-tag.js","sourceRoot":"","sources":["../../../../../../../../libs/tailng-ui/primitives/src/lib/utility/tag/tng-tag.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n Directive,\n ElementRef,\n HostBinding,\n HostListener,\n booleanAttribute,\n inject,\n input,\n output,\n} from '@angular/core';\nimport type { TngKeyboardEvent, TngMouseEvent } from '@tailng-ui/cdk';\n\nfunction normalizeString(value: string | null | undefined): string | null {\n if (value === undefined || value === null) {\n return null;\n }\n\n const normalized = value.trim();\n return normalized.length > 0 ? normalized : null;\n}\n\n@Directive({\n selector: '[tngTag]',\n exportAs: 'tngTag',\n standalone: true,\n})\nexport class TngTag {\n public readonly disabled = input<boolean, boolean | string>(false, {\n alias: 'tngTagDisabled',\n transform: booleanAttribute,\n });\n\n public readonly removable = input<boolean, boolean | string>(false, {\n alias: 'tngTagRemovable',\n transform: booleanAttribute,\n });\n\n public readonly label = input<string | null>(null, {\n alias: 'tngTagLabel',\n });\n\n public readonly tngTagRemoved = output<void>();\n\n public isDisabled(): boolean {\n return this.disabled();\n }\n\n public isRemovable(): boolean {\n return this.removable() && !this.isDisabled();\n }\n\n public resolvedLabel(): string {\n return normalizeString(this.label()) ?? 'tag';\n }\n\n public requestRemove(): boolean {\n if (!this.isRemovable()) {\n return false;\n }\n\n this.tngTagRemoved.emit();\n return true;\n }\n\n @HostBinding('attr.aria-disabled')\n protected get ariaDisabledAttr(): 'true' | null {\n return this.isDisabled() ? 'true' : null;\n }\n\n @HostBinding('attr.data-disabled')\n protected get dataDisabledAttr(): '' | null {\n return this.isDisabled() ? '' : null;\n }\n\n @HostBinding('attr.data-removable')\n protected get dataRemovableAttr(): '' | null {\n return this.removable() ? '' : null;\n }\n\n @HostBinding('attr.data-slot')\n protected readonly dataSlot = 'tag' as const;\n}\n\n@Directive({\n selector: '[tngTagIcon]',\n exportAs: 'tngTagIcon',\n standalone: true,\n})\nexport class TngTagIcon {\n @HostBinding('attr.data-slot')\n protected readonly dataSlot = 'tag-icon' as const;\n}\n\n@Directive({\n selector: '[tngTagClose]',\n exportAs: 'tngTagClose',\n standalone: true,\n})\nexport class TngTagClose {\n private readonly elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n private readonly tag = inject(TngTag, { optional: true });\n\n private focused = false;\n private suppressNextClick = false;\n\n public readonly ariaLabel = input<string | null>(null, {\n alias: 'tngTagCloseAriaLabel',\n });\n\n @HostListener('click', ['$event'])\n protected onClick(event: TngMouseEvent): void {\n if (this.suppressNextClick) {\n this.suppressNextClick = false;\n event.preventDefault();\n event.stopPropagation();\n return;\n }\n\n if (!this.requestRemove()) {\n event.preventDefault();\n event.stopPropagation();\n }\n }\n\n @HostListener('focusin')\n protected onFocusIn(): void {\n this.focused = true;\n }\n\n @HostListener('focusout')\n protected onFocusOut(): void {\n this.focused = false;\n }\n\n @HostListener('keydown', ['$event'])\n protected onKeydown(event: TngKeyboardEvent): void {\n if (event.key !== 'Enter' && event.key !== ' ') {\n return;\n }\n\n event.preventDefault();\n event.stopPropagation();\n\n this.suppressNextClick = true;\n setTimeout(() => {\n this.suppressNextClick = false;\n });\n\n this.requestRemove();\n }\n\n private requestRemove(): boolean {\n return this.tag?.requestRemove() === true;\n }\n\n private isButtonElement(): boolean {\n return this.elementRef.nativeElement.tagName === 'BUTTON';\n }\n\n private isDisabled(): boolean {\n return this.tag?.isRemovable() !== true;\n }\n\n @HostBinding('attr.aria-label')\n protected get ariaLabelAttr(): string {\n const explicit = normalizeString(this.ariaLabel());\n if (explicit !== null) {\n return explicit;\n }\n\n const hostDefined = normalizeString(this.elementRef.nativeElement.getAttribute('aria-label'));\n if (hostDefined !== null) {\n return hostDefined;\n }\n\n const label = this.tag?.resolvedLabel() ?? 'tag';\n return `Remove ${label}`;\n }\n\n @HostBinding('attr.data-disabled')\n protected get dataDisabledAttr(): '' | null {\n return this.isDisabled() ? '' : null;\n }\n\n @HostBinding('attr.data-focused')\n protected get dataFocusedAttr(): '' | null {\n return this.focused ? '' : null;\n }\n\n @HostBinding('attr.data-slot')\n protected readonly dataSlot = 'tag-close' as const;\n\n @HostBinding('attr.disabled')\n protected get disabledAttr(): '' | null {\n if (!this.isButtonElement()) {\n return null;\n }\n\n return this.isDisabled() ? '' : null;\n }\n\n @HostBinding('attr.role')\n protected get roleAttr(): 'button' | null {\n return this.isButtonElement() ? null : 'button';\n }\n\n @HostBinding('attr.tabindex')\n protected get tabIndexAttr(): '0' | '-1' | null {\n if (this.isButtonElement()) {\n return null;\n }\n\n return this.isDisabled() ? '-1' : '0';\n }\n\n @HostBinding('attr.type')\n protected get typeAttr(): 'button' | null {\n return this.isButtonElement() ? 'button' : null;\n }\n}\n"]}
|