@aquera/nile-elements 0.1.35-beta-1.0 → 0.1.35-beta-1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +7 -0
- package/demo/variables.css +13 -0
- package/demo/variables_v2.css +13 -0
- package/dist/index.cjs.js +1 -1
- package/dist/index.esm.js +1 -1
- package/dist/nile-filter-chip/index.cjs.js +2 -0
- package/dist/nile-filter-chip/index.cjs.js.map +1 -0
- package/dist/nile-filter-chip/index.esm.js +1 -0
- package/dist/nile-filter-chip/nile-filter-chip.cjs.js +2 -0
- package/dist/nile-filter-chip/nile-filter-chip.cjs.js.map +1 -0
- package/dist/nile-filter-chip/nile-filter-chip.css.cjs.js +2 -0
- package/dist/nile-filter-chip/nile-filter-chip.css.cjs.js.map +1 -0
- package/dist/nile-filter-chip/nile-filter-chip.css.esm.js +98 -0
- package/dist/nile-filter-chip/nile-filter-chip.esm.js +34 -0
- package/dist/nile-filter-chip/nile-filter-chip.test.cjs.js +2 -0
- package/dist/nile-filter-chip/nile-filter-chip.test.cjs.js.map +1 -0
- package/dist/nile-filter-chip/nile-filter-chip.test.esm.js +20 -0
- package/dist/nile-select/nile-select.cjs.js +1 -1
- package/dist/nile-select/nile-select.cjs.js.map +1 -1
- package/dist/nile-select/nile-select.esm.js +1 -1
- package/dist/src/index.d.ts +1 -0
- package/dist/src/index.js +1 -0
- package/dist/src/index.js.map +1 -1
- package/dist/src/nile-filter-chip/index.d.ts +1 -0
- package/dist/src/nile-filter-chip/index.js +2 -0
- package/dist/src/nile-filter-chip/index.js.map +1 -0
- package/dist/src/nile-filter-chip/nile-filter-chip.css.d.ts +12 -0
- package/dist/src/nile-filter-chip/nile-filter-chip.css.js +110 -0
- package/dist/src/nile-filter-chip/nile-filter-chip.css.js.map +1 -0
- package/dist/src/nile-filter-chip/nile-filter-chip.d.ts +35 -0
- package/dist/src/nile-filter-chip/nile-filter-chip.js +128 -0
- package/dist/src/nile-filter-chip/nile-filter-chip.js.map +1 -0
- package/dist/src/nile-filter-chip/nile-filter-chip.test.d.ts +1 -0
- package/dist/src/nile-filter-chip/nile-filter-chip.test.js +80 -0
- package/dist/src/nile-filter-chip/nile-filter-chip.test.js.map +1 -0
- package/dist/src/nile-select/nile-select.js +1 -1
- package/dist/src/nile-select/nile-select.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +2 -2
- package/src/index.ts +2 -1
- package/src/nile-filter-chip/index.ts +1 -0
- package/src/nile-filter-chip/nile-filter-chip.css.ts +115 -0
- package/src/nile-filter-chip/nile-filter-chip.test.ts +92 -0
- package/src/nile-filter-chip/nile-filter-chip.ts +125 -0
- package/src/nile-select/nile-select.ts +1 -1
- package/vscode-html-custom-data.json +47 -3
@@ -0,0 +1,110 @@
|
|
1
|
+
/**
|
2
|
+
* Copyright Aquera Inc 2023
|
3
|
+
*
|
4
|
+
* This source code is licensed under the BSD-3-Clause license found in the
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
6
|
+
*/
|
7
|
+
import { css } from 'lit';
|
8
|
+
/**
|
9
|
+
* FilterChip CSS
|
10
|
+
*/
|
11
|
+
export const styles = css `
|
12
|
+
|
13
|
+
|
14
|
+
.filter-chips {
|
15
|
+
display: flex;
|
16
|
+
align-items: center;
|
17
|
+
}
|
18
|
+
|
19
|
+
|
20
|
+
.chip {
|
21
|
+
display: inline-flex;
|
22
|
+
align-items: center;
|
23
|
+
padding: 4px 8px;
|
24
|
+
border: 1px solid var(--nile-filter-chip-chip-border-color-stroke);
|
25
|
+
border-radius: 4px;
|
26
|
+
font-size: 14px;
|
27
|
+
background-color: var(--nile-filter-chip-background-default);
|
28
|
+
color: var(--nile-filter-chip-text-default);
|
29
|
+
transition: background-color 0.2s ease-in-out, border-color 0.2s ease-in-out;
|
30
|
+
cursor: pointer;
|
31
|
+
gap: 6px;
|
32
|
+
margin-right: 6px;
|
33
|
+
}
|
34
|
+
|
35
|
+
.chip:hover {
|
36
|
+
background-color: var(--nile-filter-chip-hover-background);
|
37
|
+
}
|
38
|
+
|
39
|
+
.chip:active {
|
40
|
+
background-color: var(--nile-filter-chip-active-background);
|
41
|
+
border-color: var(--nile-filter-chip-active-border-color-stroke);
|
42
|
+
}
|
43
|
+
|
44
|
+
.icon {
|
45
|
+
color: var(--nile-filter-chip-icon-color-default);
|
46
|
+
display: flex;
|
47
|
+
align-items: center;
|
48
|
+
justify-content: center;
|
49
|
+
vertical-align: middle;
|
50
|
+
position: relative;
|
51
|
+
top: 12px;
|
52
|
+
}
|
53
|
+
|
54
|
+
.label {
|
55
|
+
font-weight: 500;
|
56
|
+
color: var(--nile-filter-chip-label-color-default);
|
57
|
+
}
|
58
|
+
|
59
|
+
nile-badge::part(base) {
|
60
|
+
width: auto;
|
61
|
+
height: 14px;
|
62
|
+
border-radius: 100px;
|
63
|
+
padding: 6px;
|
64
|
+
gap: 10px;
|
65
|
+
font-size: 8px;
|
66
|
+
display: inline-flex;
|
67
|
+
align-items: center;
|
68
|
+
justify-content: center;
|
69
|
+
line-height: 1;
|
70
|
+
}
|
71
|
+
|
72
|
+
.chip-container {
|
73
|
+
display: flex;
|
74
|
+
justify-content: space-between;
|
75
|
+
align-items: center;
|
76
|
+
width: 100%;
|
77
|
+
}
|
78
|
+
|
79
|
+
.clear-all-container {
|
80
|
+
margin-left: 18px;
|
81
|
+
white-space: nowrap;
|
82
|
+
cursor: pointer;
|
83
|
+
}
|
84
|
+
|
85
|
+
|
86
|
+
.value {
|
87
|
+
color: var(--nile-filter-chip-values-color-default);
|
88
|
+
overflow: hidden;
|
89
|
+
text-overflow: ellipsis;
|
90
|
+
white-space: nowrap;
|
91
|
+
max-width: 140px;
|
92
|
+
}
|
93
|
+
|
94
|
+
.close-icon {
|
95
|
+
color: var(--nile-filter-chip-close-icon-color-default);
|
96
|
+
cursor: pointer;
|
97
|
+
display: flex;
|
98
|
+
align-items: center;
|
99
|
+
padding: 2px;
|
100
|
+
border-radius: 50%;
|
101
|
+
transition: background-color 0.2s;
|
102
|
+
}
|
103
|
+
|
104
|
+
.close-icon:hover {
|
105
|
+
background-color: var(--nile-filter-chip-close-icon-hover-background);
|
106
|
+
color: var(--nile-filter-chip-close-icon-hover-color);
|
107
|
+
}
|
108
|
+
`;
|
109
|
+
export default [styles];
|
110
|
+
//# sourceMappingURL=nile-filter-chip.css.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"nile-filter-chip.css.js","sourceRoot":"","sources":["../../../src/nile-filter-chip/nile-filter-chip.css.ts"],"names":[],"mappings":"AAAA;;;;;EAKE;AAEF,OAAO,EAAC,GAAG,EAAC,MAAM,KAAK,CAAC;AAExB;;GAEG;AAEH,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAiGxB,CAAC;AAEF,eAAe,CAAC,MAAM,CAAC,CAAC","sourcesContent":["/**\n* Copyright Aquera Inc 2023\n*\n* This source code is licensed under the BSD-3-Clause license found in the\n* LICENSE file in the root directory of this source tree.\n*/\n\nimport {css} from 'lit';\n\n/**\n * FilterChip CSS\n */\n\nexport const styles = css`\n\n\n .filter-chips {\n display: flex;\n align-items: center;\n }\n\n\n .chip {\n display: inline-flex;\n align-items: center;\n padding: 4px 8px;\n border: 1px solid var(--nile-filter-chip-chip-border-color-stroke);\n border-radius: 4px;\n font-size: 14px;\n background-color: var(--nile-filter-chip-background-default);\n color: var(--nile-filter-chip-text-default);\n transition: background-color 0.2s ease-in-out, border-color 0.2s ease-in-out;\n cursor: pointer;\n gap: 6px;\n margin-right: 6px;\n }\n\n .chip:hover {\n background-color: var(--nile-filter-chip-hover-background);\n }\n\n .chip:active {\n background-color: var(--nile-filter-chip-active-background);\n border-color: var(--nile-filter-chip-active-border-color-stroke);\n }\n\n .icon {\n color: var(--nile-filter-chip-icon-color-default);\n display: flex;\n align-items: center;\n justify-content: center;\n vertical-align: middle;\n position: relative;\n top: 12px;\n }\n\n .label {\n font-weight: 500;\n color: var(--nile-filter-chip-label-color-default);\n }\n\n nile-badge::part(base) {\n width: auto;\n height: 14px;\n border-radius: 100px;\n padding: 6px;\n gap: 10px;\n font-size: 8px;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n line-height: 1;\n }\n\n .chip-container {\n display: flex;\n justify-content: space-between;\n align-items: center;\n width: 100%;\n }\n\n .clear-all-container {\n margin-left: 18px;\n white-space: nowrap;\n cursor: pointer;\n }\n\n\n .value {\n color: var(--nile-filter-chip-values-color-default);\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n max-width: 140px;\n }\n\n .close-icon {\n color: var(--nile-filter-chip-close-icon-color-default);\n cursor: pointer;\n display: flex;\n align-items: center;\n padding: 2px;\n border-radius: 50%;\n transition: background-color 0.2s;\n }\n\n .close-icon:hover {\n background-color: var(--nile-filter-chip-close-icon-hover-background);\n color: var(--nile-filter-chip-close-icon-hover-color);\n }\n`;\n\nexport default [styles];\n\n "]}
|
@@ -0,0 +1,35 @@
|
|
1
|
+
import { CSSResultArray, TemplateResult } from 'lit';
|
2
|
+
import NileElement from '../internal/nile-element';
|
3
|
+
/**
|
4
|
+
* Nile filter-chip component.
|
5
|
+
*
|
6
|
+
* @tag nile-filter-chip
|
7
|
+
*/
|
8
|
+
export declare class NileFilterChip extends NileElement {
|
9
|
+
label: string;
|
10
|
+
text: string;
|
11
|
+
extraCount: number;
|
12
|
+
editable: boolean;
|
13
|
+
closable: boolean;
|
14
|
+
icon: string;
|
15
|
+
removeIcon: string;
|
16
|
+
private static activeChips;
|
17
|
+
static get styles(): CSSResultArray;
|
18
|
+
connectedCallback(): void;
|
19
|
+
disconnectedCallback(): void;
|
20
|
+
private registerChip;
|
21
|
+
private unregisterChip;
|
22
|
+
private handleClose;
|
23
|
+
private handleClick;
|
24
|
+
private getLabelSlot;
|
25
|
+
private getValueSlot;
|
26
|
+
private getExtraCountSlot;
|
27
|
+
private getCloseIconSlot;
|
28
|
+
render(): TemplateResult;
|
29
|
+
}
|
30
|
+
export default NileFilterChip;
|
31
|
+
declare global {
|
32
|
+
interface HTMLElementTagNameMap {
|
33
|
+
'nile-filter-chip': NileFilterChip;
|
34
|
+
}
|
35
|
+
}
|
@@ -0,0 +1,128 @@
|
|
1
|
+
var NileFilterChip_1;
|
2
|
+
import { __decorate } from "tslib";
|
3
|
+
import { html } from 'lit';
|
4
|
+
import { customElement, property } from 'lit/decorators.js';
|
5
|
+
import NileElement from '../internal/nile-element';
|
6
|
+
import { styles } from './nile-filter-chip.css';
|
7
|
+
/**
|
8
|
+
* Nile filter-chip component.
|
9
|
+
*
|
10
|
+
* @tag nile-filter-chip
|
11
|
+
*/
|
12
|
+
let NileFilterChip = NileFilterChip_1 = class NileFilterChip extends NileElement {
|
13
|
+
constructor() {
|
14
|
+
super(...arguments);
|
15
|
+
this.label = '';
|
16
|
+
this.text = '';
|
17
|
+
this.extraCount = 0;
|
18
|
+
this.editable = false;
|
19
|
+
this.closable = false;
|
20
|
+
this.icon = '';
|
21
|
+
this.removeIcon = '';
|
22
|
+
}
|
23
|
+
static get styles() {
|
24
|
+
return [styles];
|
25
|
+
}
|
26
|
+
connectedCallback() {
|
27
|
+
super.connectedCallback();
|
28
|
+
this.registerChip();
|
29
|
+
}
|
30
|
+
disconnectedCallback() {
|
31
|
+
super.disconnectedCallback();
|
32
|
+
this.unregisterChip();
|
33
|
+
}
|
34
|
+
registerChip() {
|
35
|
+
NileFilterChip_1.activeChips.push(this);
|
36
|
+
}
|
37
|
+
unregisterChip() {
|
38
|
+
NileFilterChip_1.activeChips = NileFilterChip_1.activeChips.filter((chip) => chip !== this);
|
39
|
+
}
|
40
|
+
handleClose(event) {
|
41
|
+
event.stopPropagation();
|
42
|
+
this.dispatchEvent(new CustomEvent('nile-close', { detail: { text: this.text, extraCount: this.extraCount } }));
|
43
|
+
this.remove();
|
44
|
+
}
|
45
|
+
handleClick() {
|
46
|
+
this.dispatchEvent(new CustomEvent('nile-click', { detail: { text: this.text, extraCount: this.extraCount } }));
|
47
|
+
}
|
48
|
+
getLabelSlot() {
|
49
|
+
return html `
|
50
|
+
<slot name="label">
|
51
|
+
<span class="label">${this.label}:</span>
|
52
|
+
</slot>
|
53
|
+
`;
|
54
|
+
}
|
55
|
+
getValueSlot() {
|
56
|
+
return html `
|
57
|
+
<slot name="value">
|
58
|
+
<span class="value">${this.text}</span>
|
59
|
+
</slot>
|
60
|
+
`;
|
61
|
+
}
|
62
|
+
getExtraCountSlot() {
|
63
|
+
return html `
|
64
|
+
<slot name="suffix">
|
65
|
+
${this.extraCount
|
66
|
+
? html `
|
67
|
+
<nile-badge variant="primary" pilltype="pill-color">
|
68
|
+
+${this.extraCount}
|
69
|
+
</nile-badge>
|
70
|
+
`
|
71
|
+
: html ``}
|
72
|
+
</slot>
|
73
|
+
`;
|
74
|
+
}
|
75
|
+
getCloseIconSlot() {
|
76
|
+
return html `
|
77
|
+
${this.closable
|
78
|
+
? html `
|
79
|
+
<span class="close-icon" @click="${this.handleClose}">
|
80
|
+
<nile-icon name="${this.removeIcon || 'close'}" size="12"></nile-icon>
|
81
|
+
</span>
|
82
|
+
`
|
83
|
+
: html ``}
|
84
|
+
`;
|
85
|
+
}
|
86
|
+
render() {
|
87
|
+
return html `
|
88
|
+
<div class="chip" @click="${this.handleClick}">
|
89
|
+
<slot name="icon">
|
90
|
+
${this.icon ? html `<span class="icon">${this.icon}</span>` : html ``}
|
91
|
+
</slot>
|
92
|
+
${this.getLabelSlot()}
|
93
|
+
<slot name="content"></slot>
|
94
|
+
${this.getValueSlot()}
|
95
|
+
${this.getExtraCountSlot()}
|
96
|
+
${this.getCloseIconSlot()}
|
97
|
+
</div>
|
98
|
+
`;
|
99
|
+
}
|
100
|
+
};
|
101
|
+
NileFilterChip.activeChips = [];
|
102
|
+
__decorate([
|
103
|
+
property({ type: String })
|
104
|
+
], NileFilterChip.prototype, "label", void 0);
|
105
|
+
__decorate([
|
106
|
+
property({ type: String })
|
107
|
+
], NileFilterChip.prototype, "text", void 0);
|
108
|
+
__decorate([
|
109
|
+
property({ type: Number })
|
110
|
+
], NileFilterChip.prototype, "extraCount", void 0);
|
111
|
+
__decorate([
|
112
|
+
property({ type: Boolean })
|
113
|
+
], NileFilterChip.prototype, "editable", void 0);
|
114
|
+
__decorate([
|
115
|
+
property({ type: Boolean })
|
116
|
+
], NileFilterChip.prototype, "closable", void 0);
|
117
|
+
__decorate([
|
118
|
+
property({ type: String })
|
119
|
+
], NileFilterChip.prototype, "icon", void 0);
|
120
|
+
__decorate([
|
121
|
+
property({ type: String })
|
122
|
+
], NileFilterChip.prototype, "removeIcon", void 0);
|
123
|
+
NileFilterChip = NileFilterChip_1 = __decorate([
|
124
|
+
customElement('nile-filter-chip')
|
125
|
+
], NileFilterChip);
|
126
|
+
export { NileFilterChip };
|
127
|
+
export default NileFilterChip;
|
128
|
+
//# sourceMappingURL=nile-filter-chip.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"nile-filter-chip.js","sourceRoot":"","sources":["../../../src/nile-filter-chip/nile-filter-chip.ts"],"names":[],"mappings":"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","sourcesContent":["import { LitElement, html, css, CSSResultArray, TemplateResult } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport NileElement from '../internal/nile-element';\nimport { styles } from './nile-filter-chip.css';\n\n/**\n * Nile filter-chip component.\n *\n * @tag nile-filter-chip\n */\n@customElement('nile-filter-chip')\nexport class NileFilterChip extends NileElement {\n @property({ type: String }) label = '';\n @property({ type: String }) text = '';\n @property({ type: Number }) extraCount: number = 0;\n @property({ type: Boolean }) editable = false;\n @property({ type: Boolean }) closable = false;\n @property({ type: String }) icon = '';\n @property({ type: String }) removeIcon = '';\n\n private static activeChips: NileFilterChip[] = [];\n\n public static get styles(): CSSResultArray {\n return [styles];\n }\n\n connectedCallback() {\n super.connectedCallback();\n this.registerChip();\n }\n\n disconnectedCallback() {\n super.disconnectedCallback();\n this.unregisterChip();\n }\n\n private registerChip() {\n NileFilterChip.activeChips.push(this);\n }\n\n private unregisterChip() {\n NileFilterChip.activeChips = NileFilterChip.activeChips.filter(\n (chip) => chip !== this\n );\n }\n\n private handleClose(event: Event) {\n event.stopPropagation();\n this.dispatchEvent(\n new CustomEvent('nile-close', { detail: { text: this.text, extraCount: this.extraCount } })\n );\n this.remove();\n }\n\n private handleClick() {\n this.dispatchEvent(\n new CustomEvent('nile-click', { detail: { text: this.text, extraCount: this.extraCount } })\n );\n }\n\n private getLabelSlot(): TemplateResult {\n return html`\n <slot name=\"label\">\n <span class=\"label\">${this.label}:</span>\n </slot>\n `;\n }\n\n private getValueSlot(): TemplateResult {\n return html`\n <slot name=\"value\">\n <span class=\"value\">${this.text}</span>\n </slot>\n `;\n }\n\n private getExtraCountSlot(): TemplateResult {\n return html`\n <slot name=\"suffix\">\n ${this.extraCount\n ? html`\n <nile-badge variant=\"primary\" pilltype=\"pill-color\">\n +${this.extraCount}\n </nile-badge>\n `\n : html``}\n </slot>\n `;\n }\n\n private getCloseIconSlot(): TemplateResult {\n return html`\n ${this.closable\n ? html`\n <span class=\"close-icon\" @click=\"${this.handleClose}\">\n <nile-icon name=\"${this.removeIcon || 'close'}\" size=\"12\"></nile-icon>\n </span>\n `\n : html``}\n `;\n }\n\n public render(): TemplateResult {\n return html`\n <div class=\"chip\" @click=\"${this.handleClick}\">\n <slot name=\"icon\">\n ${this.icon ? html`<span class=\"icon\">${this.icon}</span>` : html``}\n </slot>\n ${this.getLabelSlot()}\n <slot name=\"content\"></slot>\n ${this.getValueSlot()}\n ${this.getExtraCountSlot()}\n ${this.getCloseIconSlot()}\n </div>\n `;\n }\n}\n\nexport default NileFilterChip;\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'nile-filter-chip': NileFilterChip;\n }\n}\n"]}
|
@@ -0,0 +1 @@
|
|
1
|
+
import './nile-filter-chip';
|
@@ -0,0 +1,80 @@
|
|
1
|
+
import { fixture, expect, html, oneEvent } from '@open-wc/testing';
|
2
|
+
import './nile-filter-chip';
|
3
|
+
import { NileFilterChip } from './nile-filter-chip';
|
4
|
+
describe('<nile-filter-chip>', () => {
|
5
|
+
afterEach(() => {
|
6
|
+
NileFilterChip.activeChips = [];
|
7
|
+
});
|
8
|
+
it('registers and unregisters itself in activeChips', async () => {
|
9
|
+
const el = await fixture(html `
|
10
|
+
<nile-filter-chip label="L" text="T"></nile-filter-chip>
|
11
|
+
`);
|
12
|
+
expect(NileFilterChip.activeChips).to.include(el);
|
13
|
+
el.remove();
|
14
|
+
await el.updateComplete;
|
15
|
+
expect(NileFilterChip.activeChips).to.not.include(el);
|
16
|
+
});
|
17
|
+
it('renders fallback label and text', async () => {
|
18
|
+
const el = await fixture(html `
|
19
|
+
<nile-filter-chip label="MyLabel" text="MyText"></nile-filter-chip>
|
20
|
+
`);
|
21
|
+
const label = el.shadowRoot.querySelector('.label');
|
22
|
+
const value = el.shadowRoot.querySelector('.value');
|
23
|
+
expect(label.textContent).to.equal('MyLabel:');
|
24
|
+
expect(value.textContent.trim()).to.equal('MyText');
|
25
|
+
});
|
26
|
+
it('renders slotted label and value over fallback', async () => {
|
27
|
+
const el = await fixture(html `
|
28
|
+
<nile-filter-chip>
|
29
|
+
<span slot="label">SLOT-LBL</span>
|
30
|
+
<span slot="value">SLOT-VAL</span>
|
31
|
+
</nile-filter-chip>
|
32
|
+
`);
|
33
|
+
const slottedLabel = el.querySelector('[slot="label"]');
|
34
|
+
const slottedValue = el.querySelector('[slot="value"]');
|
35
|
+
expect(slottedLabel.textContent).to.equal('SLOT-LBL');
|
36
|
+
expect(slottedValue.textContent).to.equal('SLOT-VAL');
|
37
|
+
});
|
38
|
+
it('renders an icon when the `icon` property is set', async () => {
|
39
|
+
const el = await fixture(html `
|
40
|
+
<nile-filter-chip icon="★" label="L" text="T"></nile-filter-chip>
|
41
|
+
`);
|
42
|
+
const iconSpan = el.shadowRoot.querySelector('.icon');
|
43
|
+
expect(iconSpan).to.exist;
|
44
|
+
expect(iconSpan.textContent).to.equal('★');
|
45
|
+
});
|
46
|
+
it('does not render a badge when extraCount is zero', async () => {
|
47
|
+
const el = await fixture(html `
|
48
|
+
<nile-filter-chip extraCount="0" label="L" text="T"></nile-filter-chip>
|
49
|
+
`);
|
50
|
+
expect(el.shadowRoot.querySelector('nile-badge')).to.be.null;
|
51
|
+
});
|
52
|
+
it('renders a +badge when extraCount > 0', async () => {
|
53
|
+
const el = await fixture(html `
|
54
|
+
<nile-filter-chip extraCount="5" label="L" text="T"></nile-filter-chip>
|
55
|
+
`);
|
56
|
+
const badge = el.shadowRoot.querySelector('nile-badge');
|
57
|
+
expect(badge).to.exist;
|
58
|
+
expect(badge.textContent).to.contain('+5');
|
59
|
+
});
|
60
|
+
it('dispatches `nile-click` on chip click', async () => {
|
61
|
+
const el = await fixture(html `
|
62
|
+
<nile-filter-chip label="L" text="T"></nile-filter-chip>
|
63
|
+
`);
|
64
|
+
const chip = el.shadowRoot.querySelector('.chip');
|
65
|
+
setTimeout(() => chip.click());
|
66
|
+
const ev = await oneEvent(el, 'nile-click');
|
67
|
+
expect(ev.detail).to.deep.equal({ text: 'T', extraCount: 0 });
|
68
|
+
});
|
69
|
+
it('dispatches `nile-close` on close icon click and removes itself', async () => {
|
70
|
+
const el = await fixture(html `
|
71
|
+
<nile-filter-chip closable extraCount="2" text="TT"></nile-filter-chip>
|
72
|
+
`);
|
73
|
+
const closeIcon = el.shadowRoot.querySelector('.close-icon');
|
74
|
+
setTimeout(() => closeIcon.click());
|
75
|
+
const ev = await oneEvent(el, 'nile-close');
|
76
|
+
expect(ev.detail).to.deep.equal({ text: 'TT', extraCount: 2 });
|
77
|
+
expect(document.body.contains(el)).to.be.false;
|
78
|
+
});
|
79
|
+
});
|
80
|
+
//# sourceMappingURL=nile-filter-chip.test.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"nile-filter-chip.test.js","sourceRoot":"","sources":["../../../src/nile-filter-chip/nile-filter-chip.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AACnE,OAAO,oBAAoB,CAAC;AAC5B,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAEpD,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IAClC,SAAS,CAAC,GAAG,EAAE;QACZ,cAAsB,CAAC,WAAW,GAAG,EAAE,CAAC;IAC3C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iDAAiD,EAAE,KAAK,IAAI,EAAE;QAC/D,MAAM,EAAE,GAAG,MAAM,OAAO,CAAiB,IAAI,CAAA;;KAE5C,CAAC,CAAC;QACH,MAAM,CAAE,cAAsB,CAAC,WAAW,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QAC3D,EAAE,CAAC,MAAM,EAAE,CAAC;QACZ,MAAM,EAAE,CAAC,cAAc,CAAC;QACxB,MAAM,CAAE,cAAsB,CAAC,WAAW,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;IACjE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iCAAiC,EAAE,KAAK,IAAI,EAAE;QAC/C,MAAM,EAAE,GAAG,MAAM,OAAO,CAAiB,IAAI,CAAA;;KAE5C,CAAC,CAAC;QACH,MAAM,KAAK,GAAG,EAAE,CAAC,UAAW,CAAC,aAAa,CAAC,QAAQ,CAAiB,CAAC;QACrE,MAAM,KAAK,GAAG,EAAE,CAAC,UAAW,CAAC,aAAa,CAAC,QAAQ,CAAiB,CAAC;QACrE,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QAC/C,MAAM,CAAC,KAAK,CAAC,WAAY,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;IACvD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+CAA+C,EAAE,KAAK,IAAI,EAAE;QAC7D,MAAM,EAAE,GAAG,MAAM,OAAO,CAAiB,IAAI,CAAA;;;;;KAK5C,CAAC,CAAC;QACH,MAAM,YAAY,GAAG,EAAE,CAAC,aAAa,CAAC,gBAAgB,CAAiB,CAAC;QACxE,MAAM,YAAY,GAAG,EAAE,CAAC,aAAa,CAAC,gBAAgB,CAAiB,CAAC;QACxE,MAAM,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QACtD,MAAM,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;IACxD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iDAAiD,EAAE,KAAK,IAAI,EAAE;QAC/D,MAAM,EAAE,GAAG,MAAM,OAAO,CAAiB,IAAI,CAAA;;KAE5C,CAAC,CAAC;QACH,MAAM,QAAQ,GAAG,EAAE,CAAC,UAAW,CAAC,aAAa,CAAC,OAAO,CAAiB,CAAC;QACvE,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC;QAC1B,MAAM,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iDAAiD,EAAE,KAAK,IAAI,EAAE;QAC/D,MAAM,EAAE,GAAG,MAAM,OAAO,CAAiB,IAAI,CAAA;;KAE5C,CAAC,CAAC;QACH,MAAM,CAAC,EAAE,CAAC,UAAW,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC;IAChE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sCAAsC,EAAE,KAAK,IAAI,EAAE;QACpD,MAAM,EAAE,GAAG,MAAM,OAAO,CAAiB,IAAI,CAAA;;KAE5C,CAAC,CAAC;QACH,MAAM,KAAK,GAAG,EAAE,CAAC,UAAW,CAAC,aAAa,CAAC,YAAY,CAAiB,CAAC;QACzE,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC;QACvB,MAAM,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAIH,EAAE,CAAC,uCAAuC,EAAE,KAAK,IAAI,EAAE;QACrD,MAAM,EAAE,GAAG,MAAM,OAAO,CAAiB,IAAI,CAAA;;KAE5C,CAAC,CAAC;QACH,MAAM,IAAI,GAAG,EAAE,CAAC,UAAW,CAAC,aAAa,CAAC,OAAO,CAAiB,CAAC;QACnE,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;QAC/B,MAAM,EAAE,GAAG,MAAM,QAAQ,CAAC,EAAE,EAAE,YAAY,CAAC,CAAC;QAC5C,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC;IAChE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gEAAgE,EAAE,KAAK,IAAI,EAAE;QAC9E,MAAM,EAAE,GAAG,MAAM,OAAO,CAAiB,IAAI,CAAA;;KAE5C,CAAC,CAAC;QACH,MAAM,SAAS,GAAG,EAAE,CAAC,UAAW,CAAC,aAAa,CAAC,aAAa,CAAiB,CAAC;QAC9E,UAAU,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC;QACpC,MAAM,EAAE,GAAG,MAAM,QAAQ,CAAC,EAAE,EAAE,YAAY,CAAC,CAAC;QAC5C,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC;QAC/D,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,KAAK,CAAC;IACjD,CAAC,CAAC,CAAC;AAGL,CAAC,CAAC,CAAC","sourcesContent":["import { fixture, expect, html, oneEvent } from '@open-wc/testing';\nimport './nile-filter-chip';\nimport { NileFilterChip } from './nile-filter-chip';\n\ndescribe('<nile-filter-chip>', () => {\n afterEach(() => {\n (NileFilterChip as any).activeChips = [];\n });\n\n it('registers and unregisters itself in activeChips', async () => {\n const el = await fixture<NileFilterChip>(html`\n <nile-filter-chip label=\"L\" text=\"T\"></nile-filter-chip>\n `);\n expect((NileFilterChip as any).activeChips).to.include(el);\n el.remove();\n await el.updateComplete;\n expect((NileFilterChip as any).activeChips).to.not.include(el);\n });\n\n it('renders fallback label and text', async () => {\n const el = await fixture<NileFilterChip>(html`\n <nile-filter-chip label=\"MyLabel\" text=\"MyText\"></nile-filter-chip>\n `);\n const label = el.shadowRoot!.querySelector('.label')! as HTMLElement;\n const value = el.shadowRoot!.querySelector('.value')! as HTMLElement;\n expect(label.textContent).to.equal('MyLabel:');\n expect(value.textContent!.trim()).to.equal('MyText');\n });\n\n it('renders slotted label and value over fallback', async () => {\n const el = await fixture<NileFilterChip>(html`\n <nile-filter-chip>\n <span slot=\"label\">SLOT-LBL</span>\n <span slot=\"value\">SLOT-VAL</span>\n </nile-filter-chip>\n `);\n const slottedLabel = el.querySelector('[slot=\"label\"]')! as HTMLElement;\n const slottedValue = el.querySelector('[slot=\"value\"]')! as HTMLElement;\n expect(slottedLabel.textContent).to.equal('SLOT-LBL');\n expect(slottedValue.textContent).to.equal('SLOT-VAL');\n });\n\n it('renders an icon when the `icon` property is set', async () => {\n const el = await fixture<NileFilterChip>(html`\n <nile-filter-chip icon=\"★\" label=\"L\" text=\"T\"></nile-filter-chip>\n `);\n const iconSpan = el.shadowRoot!.querySelector('.icon')! as HTMLElement;\n expect(iconSpan).to.exist;\n expect(iconSpan.textContent).to.equal('★');\n });\n\n it('does not render a badge when extraCount is zero', async () => {\n const el = await fixture<NileFilterChip>(html`\n <nile-filter-chip extraCount=\"0\" label=\"L\" text=\"T\"></nile-filter-chip>\n `);\n expect(el.shadowRoot!.querySelector('nile-badge')).to.be.null;\n });\n\n it('renders a +badge when extraCount > 0', async () => {\n const el = await fixture<NileFilterChip>(html`\n <nile-filter-chip extraCount=\"5\" label=\"L\" text=\"T\"></nile-filter-chip>\n `);\n const badge = el.shadowRoot!.querySelector('nile-badge')! as HTMLElement;\n expect(badge).to.exist;\n expect(badge.textContent).to.contain('+5');\n });\n\n\n\n it('dispatches `nile-click` on chip click', async () => {\n const el = await fixture<NileFilterChip>(html`\n <nile-filter-chip label=\"L\" text=\"T\"></nile-filter-chip>\n `);\n const chip = el.shadowRoot!.querySelector('.chip')! as HTMLElement;\n setTimeout(() => chip.click());\n const ev = await oneEvent(el, 'nile-click');\n expect(ev.detail).to.deep.equal({ text: 'T', extraCount: 0 });\n });\n\n it('dispatches `nile-close` on close icon click and removes itself', async () => {\n const el = await fixture<NileFilterChip>(html`\n <nile-filter-chip closable extraCount=\"2\" text=\"TT\"></nile-filter-chip>\n `);\n const closeIcon = el.shadowRoot!.querySelector('.close-icon')! as HTMLElement;\n setTimeout(() => closeIcon.click());\n const ev = await oneEvent(el, 'nile-close');\n expect(ev.detail).to.deep.equal({ text: 'TT', extraCount: 2 });\n expect(document.body.contains(el)).to.be.false;\n });\n\n \n});\n"]}
|
@@ -1169,7 +1169,7 @@ __decorate([
|
|
1169
1169
|
property({ type: Boolean, reflect: true })
|
1170
1170
|
], NileSelect.prototype, "multiple", void 0);
|
1171
1171
|
__decorate([
|
1172
|
-
property({ attribute:
|
1172
|
+
property({ attribute: true, reflect: true })
|
1173
1173
|
], NileSelect.prototype, "helpText", void 0);
|
1174
1174
|
__decorate([
|
1175
1175
|
property({ attribute: 'error-message', reflect: true })
|