@nuralyui/tabs 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,32 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2023 Google Laabidi Aymen
4
+ * SPDX-License-Identifier: MIT
5
+ */
6
+ import { LitElement } from 'lit';
7
+ import '../tabs.component';
8
+ import '../../icon';
9
+ import '../../../helpers/ThemeHandler';
10
+ export declare class ElMeenuElement extends LitElement {
11
+ float: string;
12
+ editableTabs: {
13
+ label: string;
14
+ content: import("lit").TemplateResult<1>;
15
+ }[];
16
+ editableActiveTab: number;
17
+ orientation: string;
18
+ editableConfig: {
19
+ canDeleteTab: boolean;
20
+ canEditTabTitle: boolean;
21
+ canAddTab: boolean;
22
+ canMove: boolean;
23
+ };
24
+ swapElements(arr: any, index1: any, index2: any): any;
25
+ protected render(): import("lit").TemplateResult<1>;
26
+ }
27
+ declare global {
28
+ interface HTMLElementTagNameMap {
29
+ 'hy-tabs-demo': ElMeenuElement;
30
+ }
31
+ }
32
+ //# sourceMappingURL=tabs-demo.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tabs-demo.d.ts","sourceRoot":"","sources":["../../../../src/components/tabs/demo/tabs-demo.ts"],"names":[],"mappings":"AAEA;;;;GAIG;AAEH,OAAO,EAAC,UAAU,EAAO,MAAM,KAAK,CAAC;AAGrC,OAAO,mBAAmB,CAAC;AAE3B,OAAO,YAAY,CAAC;AACpB,OAAO,+BAA+B,CAAC;AAEvC,qBACa,cAAe,SAAQ,UAAU;IAE5C,KAAK,SAAU;IAGf,YAAY;;;QAaV;IAGF,iBAAiB,SAAK;IAGtB,WAAW,SAAgB;IAG3B,cAAc;;;;;MAKZ;IAEF,YAAY,CAAC,GAAG,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,GAAG;cAO5B,MAAM;CAiM1B;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAC7B,cAAc,EAAE,cAAc,CAAC;KAChC;CACF"}
@@ -0,0 +1,263 @@
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+ /* eslint-disable @typescript-eslint/no-explicit-any */
3
+ /**
4
+ * @license
5
+ * Copyright 2023 Google Laabidi Aymen
6
+ * SPDX-License-Identifier: MIT
7
+ */
8
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
9
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
10
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
11
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
12
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
13
+ };
14
+ import { LitElement, html } from 'lit';
15
+ import { customElement, state } from 'lit/decorators.js';
16
+ import '../tabs.component';
17
+ import '../../icon';
18
+ import '../../../helpers/ThemeHandler';
19
+ let ElMeenuElement = class ElMeenuElement extends LitElement {
20
+ constructor() {
21
+ super(...arguments);
22
+ this.float = 'left';
23
+ this.editableTabs = [
24
+ {
25
+ label: 'Tab 1',
26
+ content: html `Content for Tab 1`,
27
+ },
28
+ {
29
+ label: 'Tab 2',
30
+ content: html `Content for Tab 2`,
31
+ },
32
+ {
33
+ label: 'Tab 3',
34
+ content: html `Content for Tab 3`,
35
+ },
36
+ ];
37
+ this.editableActiveTab = 0;
38
+ this.orientation = 'horizontal';
39
+ this.editableConfig = {
40
+ canDeleteTab: false,
41
+ canEditTabTitle: false,
42
+ canAddTab: true,
43
+ canMove: true,
44
+ };
45
+ }
46
+ swapElements(arr, index1, index2) {
47
+ const temp = arr[index1];
48
+ arr[index1] = arr[index2];
49
+ arr[index2] = temp;
50
+ return arr;
51
+ }
52
+ render() {
53
+ var _a, _b;
54
+ return html `
55
+ <theme-handler>
56
+ <hy-tabs>
57
+ <div label="Tab 1">Content for Tab 1</div>
58
+ <div label="Tab 2">Content for Tab 2</div>
59
+ <div label="Tab 3">Content for Tab 3</div>
60
+ </hy-tabs>
61
+ <br />
62
+ <button
63
+ @click=${() => {
64
+ var _a;
65
+ this.editableConfig.canDeleteTab = !((_a = this.editableConfig) === null || _a === void 0 ? void 0 : _a.canDeleteTab);
66
+ this.requestUpdate();
67
+ this.editableConfig = Object.assign({}, this.editableConfig);
68
+ }}
69
+ >
70
+ ${((_a = this.editableConfig) === null || _a === void 0 ? void 0 : _a.canDeleteTab) ? 'Disable delete' : 'Enable delete'} mode
71
+ </button>
72
+ <button
73
+ @click=${() => {
74
+ var _a;
75
+ this.editableConfig.canEditTabTitle = !((_a = this.editableConfig) === null || _a === void 0 ? void 0 : _a.canEditTabTitle);
76
+ this.requestUpdate();
77
+ this.editableConfig = Object.assign({}, this.editableConfig);
78
+ }}
79
+ >
80
+ ${((_b = this.editableConfig) === null || _b === void 0 ? void 0 : _b.canEditTabTitle) ? 'Disable edition' : 'Enable edition'} mode
81
+ </button>
82
+ <button
83
+ @click=${() => {
84
+ this.orientation = this.orientation === 'vertical' ? 'horizontal' : 'vertical';
85
+ }}
86
+ >
87
+ ${this.orientation == 'vertical' ? 'vertical' : 'horizontal'} mode
88
+ </button>
89
+ <br />
90
+ <hy-tabs
91
+ .tabs=${this.editableTabs}
92
+ .orientation=${this.orientation}
93
+ @tabOrderChange=${(e) => {
94
+ this.editableTabs = this.swapElements(this.editableTabs, e.detail.sourceIndex, e.detail.targetIndex);
95
+ this.editableTabs = [...this.editableTabs];
96
+ }}
97
+ activeTab=${this.editableActiveTab}
98
+ .editable=${Object.assign({}, this.editableConfig)}
99
+ @addTab=${() => {
100
+ this.editableTabs.push({
101
+ label: 'Tab ' + (this.editableTabs.length + 1),
102
+ content: html `Content for Tab ${this.editableTabs.length + 1}`,
103
+ });
104
+ this.editableTabs = [...this.editableTabs];
105
+ this.editableActiveTab = this.editableTabs.length - 1;
106
+ }}
107
+ @removeTab=${(e) => {
108
+ this.editableTabs.splice(e.detail.index, 1);
109
+ this.editableTabs = [...this.editableTabs];
110
+ }}
111
+ @tabEdited=${(e) => {
112
+ const { tab } = e.detail;
113
+ this.editableTabs[tab.index] = Object.assign(Object.assign({}, this.editableTabs[tab.index]), { label: tab.label });
114
+ }}
115
+ >
116
+ ${this.editableTabs.map((tab) => {
117
+ return html `<div label=${tab.label}>${tab.content}</div>`;
118
+ })}
119
+ </hy-tabs>
120
+ <br />
121
+ <br />
122
+ <hy-tabs
123
+ activeTab=${this.editableActiveTab}
124
+ .editable=${{
125
+ //canEditTabTitle: true,
126
+ canAddTab: true,
127
+ canMove: true,
128
+ }}
129
+ @tabEdited=${(e) => {
130
+ console.log('tab', e.detail.tab);
131
+ }}
132
+ @addTab=${() => {
133
+ this.editableTabs.push({
134
+ label: 'Tab ' + (this.editableTabs.length + 1),
135
+ content: html `Content for Tab ${this.editableTabs.length + 1}`,
136
+ });
137
+ this.editableTabs = [...this.editableTabs];
138
+ this.editableActiveTab = this.editableTabs.length - 1;
139
+ }}
140
+ @removeTab=${(e) => {
141
+ this.editableTabs.splice(e.detail.index, 1);
142
+ }}
143
+ >
144
+ ${this.editableTabs.map((tab) => {
145
+ return html `<div label=${tab.label}>${tab.content}</div>`;
146
+ })}
147
+ </hy-tabs>
148
+ <br />
149
+ <br />
150
+ <br />
151
+ <hy-tabs
152
+ activeTab=${this.editableActiveTab}
153
+ .editable=${{
154
+ canAddTab: true,
155
+ }}
156
+ @tabEdited=${(e) => {
157
+ console.log('tab', e.detail.tab);
158
+ }}
159
+ @addTab=${() => {
160
+ this.editableTabs.push({
161
+ label: 'Tab ' + (this.editableTabs.length + 1),
162
+ content: html `Content for Tab ${this.editableTabs.length + 1}`,
163
+ });
164
+ this.editableTabs = [...this.editableTabs];
165
+ this.editableActiveTab = this.editableTabs.length - 1;
166
+ }}
167
+ @removeTab=${(e) => {
168
+ console.log(e);
169
+ this.editableTabs.splice(e.detail.index, 1);
170
+ this.editableTabs = [...this.editableTabs];
171
+ }}
172
+ >
173
+ ${this.editableTabs.map((tab) => {
174
+ return html `<div label=${tab.label}>${tab.content}</div>`;
175
+ })}
176
+ </hy-tabs>
177
+ <br />
178
+ <br />
179
+ <br />
180
+ <hy-tabs
181
+ activeTab=${this.editableActiveTab}
182
+ .editable=${{
183
+ canDeleteTab: true,
184
+ }}
185
+ @tabEdited=${(e) => {
186
+ console.log('tab', e.detail.tab);
187
+ }}
188
+ @addTab=${() => {
189
+ this.editableTabs.push({
190
+ label: 'Tab ' + (this.editableTabs.length + 1),
191
+ content: html `Content for Tab ${this.editableTabs.length + 1}`,
192
+ });
193
+ this.editableTabs = [...this.editableTabs];
194
+ this.editableActiveTab = this.editableTabs.length - 1;
195
+ }}
196
+ @removeTab=${(e) => {
197
+ this.editableTabs.splice(e.detail.index, 1);
198
+ }}
199
+ >
200
+ ${this.editableTabs.map((tab) => {
201
+ return html `<div label=${tab.label}>${tab.content}</div>`;
202
+ })}
203
+ </hy-tabs>
204
+ <br />
205
+ <br />
206
+ <hy-tabs>
207
+ <div label="Tab 1">Content for Tab 1</div>
208
+ <div label="Tab 2">Content for Tab 2</div>
209
+ <div label="Tab 3">Content for Tab 3</div>
210
+ </hy-tabs>
211
+ <br />
212
+ <br />
213
+ <br />
214
+ <hy-tabs orientation="vertical">
215
+ <div label="Tab 1">Content for Tab 1</div>
216
+ <div label="Tab 2">Content for Tab 2</div>
217
+ <div label="Tab 3">Content for Tab 3</div>
218
+ </hy-tabs>
219
+ <br />
220
+ <br />
221
+ <hy-tabs orientation="vertical" tabsAlign="right">
222
+ <div label="Tab 1">Content for Tab 1</div>
223
+ <div label="Tab 2">Content for Tab 2</div>
224
+ <div label="Tab 3">Content for Tab 3</div>
225
+ </hy-tabs>
226
+ <br />
227
+ <br />
228
+ <hy-tabs tabsAlign="center">
229
+ <div label="Tab 1">Content for Tab 1</div>
230
+ <div label="Tab 2">Content for Tab 2</div>
231
+ <div label="Tab 3">Content for Tab 3</div>
232
+ </hy-tabs>
233
+ <br />
234
+ <br />
235
+ <hy-tabs tabsAlign="right">
236
+ <div label="Tab 1">Content for Tab 1</div>
237
+ <div label="Tab 2">Content for Tab 2</div>
238
+ <div label="Tab 3">Content for Tab 3</div>
239
+ </hy-tabs>
240
+ </theme-handler>
241
+ `;
242
+ }
243
+ };
244
+ __decorate([
245
+ state()
246
+ ], ElMeenuElement.prototype, "float", void 0);
247
+ __decorate([
248
+ state()
249
+ ], ElMeenuElement.prototype, "editableTabs", void 0);
250
+ __decorate([
251
+ state()
252
+ ], ElMeenuElement.prototype, "editableActiveTab", void 0);
253
+ __decorate([
254
+ state()
255
+ ], ElMeenuElement.prototype, "orientation", void 0);
256
+ __decorate([
257
+ state()
258
+ ], ElMeenuElement.prototype, "editableConfig", void 0);
259
+ ElMeenuElement = __decorate([
260
+ customElement('hy-tabs-demo')
261
+ ], ElMeenuElement);
262
+ export { ElMeenuElement };
263
+ //# sourceMappingURL=tabs-demo.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tabs-demo.js","sourceRoot":"","sources":["../../../../src/components/tabs/demo/tabs-demo.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable @typescript-eslint/no-explicit-any */\n/**\n * @license\n * Copyright 2023 Google Laabidi Aymen\n * SPDX-License-Identifier: MIT\n */\n\nimport {LitElement, html} from 'lit';\nimport {customElement, state} from 'lit/decorators.js';\n\nimport '../tabs.component';\n\nimport '../../icon';\nimport '../../../helpers/ThemeHandler';\n\n@customElement('hy-tabs-demo')\nexport class ElMeenuElement extends LitElement {\n @state()\n float = 'left';\n\n @state()\n editableTabs = [\n {\n label: 'Tab 1',\n content: html`Content for Tab 1`,\n },\n {\n label: 'Tab 2',\n content: html`Content for Tab 2`,\n },\n {\n label: 'Tab 3',\n content: html`Content for Tab 3`,\n },\n ];\n\n @state()\n editableActiveTab = 0;\n\n @state()\n orientation = 'horizontal';\n\n @state()\n editableConfig = {\n canDeleteTab: false,\n canEditTabTitle: false,\n canAddTab: true,\n canMove: true,\n };\n\n swapElements(arr: any, index1: any, index2: any) {\n const temp = arr[index1];\n arr[index1] = arr[index2];\n arr[index2] = temp;\n return arr;\n }\n\n protected override render() {\n return html`\n <theme-handler>\n <hy-tabs>\n <div label=\"Tab 1\">Content for Tab 1</div>\n <div label=\"Tab 2\">Content for Tab 2</div>\n <div label=\"Tab 3\">Content for Tab 3</div>\n </hy-tabs>\n <br />\n <button\n @click=${() => {\n this.editableConfig.canDeleteTab = !this.editableConfig?.canDeleteTab;\n this.requestUpdate();\n this.editableConfig = {...this.editableConfig};\n }}\n >\n ${this.editableConfig?.canDeleteTab ? 'Disable delete' : 'Enable delete'} mode\n </button>\n <button\n @click=${() => {\n this.editableConfig.canEditTabTitle = !this.editableConfig?.canEditTabTitle;\n this.requestUpdate();\n this.editableConfig = {...this.editableConfig};\n }}\n >\n ${this.editableConfig?.canEditTabTitle ? 'Disable edition' : 'Enable edition'} mode\n </button>\n <button\n @click=${() => {\n this.orientation = this.orientation === 'vertical' ? 'horizontal' : 'vertical';\n }}\n >\n ${this.orientation == 'vertical' ? 'vertical' : 'horizontal'} mode\n </button>\n <br />\n <hy-tabs\n .tabs=${this.editableTabs}\n .orientation=${this.orientation}\n @tabOrderChange=${(e: any) => {\n this.editableTabs = this.swapElements(this.editableTabs, e.detail.sourceIndex, e.detail.targetIndex);\n this.editableTabs = [...this.editableTabs];\n }}\n activeTab=${this.editableActiveTab}\n .editable=${{\n ...this.editableConfig,\n }}\n @addTab=${() => {\n this.editableTabs.push({\n label: 'Tab ' + (this.editableTabs.length + 1),\n content: html`Content for Tab ${this.editableTabs.length + 1}`,\n });\n this.editableTabs = [...this.editableTabs];\n this.editableActiveTab = this.editableTabs.length - 1;\n }}\n @removeTab=${(e: any) => {\n this.editableTabs.splice(e.detail.index, 1);\n this.editableTabs = [...this.editableTabs];\n }}\n @tabEdited=${(e: any) => {\n const {tab} = e.detail;\n this.editableTabs[tab.index] = {\n ...this.editableTabs[tab.index],\n label: tab.label,\n };\n }}\n >\n ${this.editableTabs.map((tab: any) => {\n return html`<div label=${tab.label}>${tab.content}</div>`;\n })}\n </hy-tabs>\n <br />\n <br />\n <hy-tabs\n activeTab=${this.editableActiveTab}\n .editable=${{\n //canEditTabTitle: true,\n canAddTab: true,\n canMove: true,\n }}\n @tabEdited=${(e: CustomEvent) => {\n console.log('tab', e.detail.tab);\n }}\n @addTab=${() => {\n this.editableTabs.push({\n label: 'Tab ' + (this.editableTabs.length + 1),\n content: html`Content for Tab ${this.editableTabs.length + 1}`,\n });\n this.editableTabs = [...this.editableTabs];\n this.editableActiveTab = this.editableTabs.length - 1;\n }}\n @removeTab=${(e: any) => {\n this.editableTabs.splice(e.detail.index, 1);\n }}\n >\n ${this.editableTabs.map((tab: any) => {\n return html`<div label=${tab.label}>${tab.content}</div>`;\n })}\n </hy-tabs>\n <br />\n <br />\n <br />\n <hy-tabs\n activeTab=${this.editableActiveTab}\n .editable=${{\n canAddTab: true,\n }}\n @tabEdited=${(e: CustomEvent) => {\n console.log('tab', e.detail.tab);\n }}\n @addTab=${() => {\n this.editableTabs.push({\n label: 'Tab ' + (this.editableTabs.length + 1),\n content: html`Content for Tab ${this.editableTabs.length + 1}`,\n });\n this.editableTabs = [...this.editableTabs];\n this.editableActiveTab = this.editableTabs.length - 1;\n }}\n @removeTab=${(e: any) => {\n console.log(e);\n this.editableTabs.splice(e.detail.index, 1);\n this.editableTabs = [...this.editableTabs];\n }}\n >\n ${this.editableTabs.map((tab: any) => {\n return html`<div label=${tab.label}>${tab.content}</div>`;\n })}\n </hy-tabs>\n <br />\n <br />\n <br />\n <hy-tabs\n activeTab=${this.editableActiveTab}\n .editable=${{\n canDeleteTab: true,\n }}\n @tabEdited=${(e: CustomEvent) => {\n console.log('tab', e.detail.tab);\n }}\n @addTab=${() => {\n this.editableTabs.push({\n label: 'Tab ' + (this.editableTabs.length + 1),\n content: html`Content for Tab ${this.editableTabs.length + 1}`,\n });\n this.editableTabs = [...this.editableTabs];\n this.editableActiveTab = this.editableTabs.length - 1;\n }}\n @removeTab=${(e: any) => {\n this.editableTabs.splice(e.detail.index, 1);\n }}\n >\n ${this.editableTabs.map((tab: any) => {\n return html`<div label=${tab.label}>${tab.content}</div>`;\n })}\n </hy-tabs>\n <br />\n <br />\n <hy-tabs>\n <div label=\"Tab 1\">Content for Tab 1</div>\n <div label=\"Tab 2\">Content for Tab 2</div>\n <div label=\"Tab 3\">Content for Tab 3</div>\n </hy-tabs>\n <br />\n <br />\n <br />\n <hy-tabs orientation=\"vertical\">\n <div label=\"Tab 1\">Content for Tab 1</div>\n <div label=\"Tab 2\">Content for Tab 2</div>\n <div label=\"Tab 3\">Content for Tab 3</div>\n </hy-tabs>\n <br />\n <br />\n <hy-tabs orientation=\"vertical\" tabsAlign=\"right\">\n <div label=\"Tab 1\">Content for Tab 1</div>\n <div label=\"Tab 2\">Content for Tab 2</div>\n <div label=\"Tab 3\">Content for Tab 3</div>\n </hy-tabs>\n <br />\n <br />\n <hy-tabs tabsAlign=\"center\">\n <div label=\"Tab 1\">Content for Tab 1</div>\n <div label=\"Tab 2\">Content for Tab 2</div>\n <div label=\"Tab 3\">Content for Tab 3</div>\n </hy-tabs>\n <br />\n <br />\n <hy-tabs tabsAlign=\"right\">\n <div label=\"Tab 1\">Content for Tab 1</div>\n <div label=\"Tab 2\">Content for Tab 2</div>\n <div label=\"Tab 3\">Content for Tab 3</div>\n </hy-tabs>\n </theme-handler>\n `;\n }\n}\n\ndeclare global {\n interface HTMLElementTagNameMap {\n 'hy-tabs-demo': ElMeenuElement;\n }\n}\n"]}
package/index.d.ts ADDED
@@ -0,0 +1,2 @@
1
+ export * from './tabs.component.js';
2
+ //# sourceMappingURL=index.d.ts.map
package/index.d.ts.map ADDED
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/tabs/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAC"}
package/index.js ADDED
@@ -0,0 +1,2 @@
1
+ export * from './tabs.component.js';
2
+ //# sourceMappingURL=index.js.map
package/index.js.map ADDED
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/tabs/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAC","sourcesContent":["export * from './tabs.component.js';\n"]}
package/package.json ADDED
@@ -0,0 +1,15 @@
1
+ {
2
+ "name": "@nuralyui/tabs",
3
+ "version": "0.0.1",
4
+ "description": "",
5
+ "main": "index.js",
6
+ "type": "module",
7
+ "dependencies": {
8
+ "dayjs": "^1.11.7"
9
+ },
10
+ "scripts": {
11
+ "test": "echo \"Error: no test specified\" && exit 1"
12
+ },
13
+ "author": "Labidi Aymen",
14
+ "license": "ISC"
15
+ }
package/react.d.ts ADDED
@@ -0,0 +1,9 @@
1
+ import { TabsComponent } from './tabs.component.js';
2
+ export declare const HyTabsComponent: import("@lit-labs/react").ReactWebComponent<TabsComponent, {
3
+ removeTab: string;
4
+ tabEdited: string;
5
+ tabTilteClick: string;
6
+ tabOrderChange: string;
7
+ addTab: string;
8
+ }>;
9
+ //# sourceMappingURL=react.d.ts.map
package/react.d.ts.map ADDED
@@ -0,0 +1 @@
1
+ {"version":3,"file":"react.d.ts","sourceRoot":"","sources":["../../../src/components/tabs/react.ts"],"names":[],"mappings":"AAEA,OAAO,EAAC,aAAa,EAAC,MAAM,qBAAqB,CAAC;AAClD,eAAO,MAAM,eAAe;;;;;;EAW1B,CAAC"}
package/react.js ADDED
@@ -0,0 +1,16 @@
1
+ import { createComponent } from '@lit-labs/react';
2
+ import * as React from 'react';
3
+ import { TabsComponent } from './tabs.component.js';
4
+ export const HyTabsComponent = createComponent({
5
+ tagName: 'hy-tabs',
6
+ elementClass: TabsComponent,
7
+ react: React,
8
+ events: {
9
+ removeTab: 'removeTab',
10
+ tabEdited: 'tabEdited',
11
+ tabTilteClick: 'tabTilteClick',
12
+ tabOrderChange: 'tabOrderChange',
13
+ addTab: 'addTab',
14
+ },
15
+ });
16
+ //# sourceMappingURL=react.js.map
package/react.js.map ADDED
@@ -0,0 +1 @@
1
+ {"version":3,"file":"react.js","sourceRoot":"","sources":["../../../src/components/tabs/react.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,eAAe,EAAC,MAAM,iBAAiB,CAAC;AAChD,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAC,aAAa,EAAC,MAAM,qBAAqB,CAAC;AAClD,MAAM,CAAC,MAAM,eAAe,GAAG,eAAe,CAAC;IAC7C,OAAO,EAAE,SAAS;IAClB,YAAY,EAAE,aAAa;IAC3B,KAAK,EAAE,KAAK;IACZ,MAAM,EAAE;QACN,SAAS,EAAE,WAAW;QACtB,SAAS,EAAE,WAAW;QACtB,aAAa,EAAE,eAAe;QAC9B,cAAc,EAAE,gBAAgB;QAChC,MAAM,EAAE,QAAQ;KACjB;CACF,CAAC,CAAC","sourcesContent":["import {createComponent} from '@lit-labs/react';\nimport * as React from 'react';\nimport {TabsComponent} from './tabs.component.js';\nexport const HyTabsComponent = createComponent({\n tagName: 'hy-tabs',\n elementClass: TabsComponent,\n react: React,\n events: {\n removeTab: 'removeTab',\n tabEdited: 'tabEdited',\n tabTilteClick: 'tabTilteClick',\n tabOrderChange: 'tabOrderChange',\n addTab: 'addTab',\n },\n});\n"]}
@@ -0,0 +1,39 @@
1
+ import { LitElement, PropertyValueMap, nothing } from 'lit';
2
+ import { TabEditable, TabOrientation, TabsAlign } from './tabs.constant.js';
3
+ /**
4
+ * `hy-tabs` is a LitElement that provides a customizable tabs.
5
+ * @customElement 'hy-tabs'
6
+ *
7
+ * Attributes
8
+ * @attr activeTab
9
+ * @attr orientation
10
+ * @attr tabsAlign
11
+ * @attr editable
12
+ * Events
13
+ * @fires tabEdited - Indicates when tab edited
14
+ * @fires removeTab - Indicates when tab removed
15
+ * @fires addTab - Indicates when tab added
16
+ */
17
+ export declare class TabsComponent extends LitElement {
18
+ activeTab: number;
19
+ orientation: TabOrientation;
20
+ tabsAlign: TabsAlign;
21
+ editable: TabEditable;
22
+ tabs: any[];
23
+ static styles: import("lit").CSSResult;
24
+ constructor();
25
+ render(): import("lit").TemplateResult<1>;
26
+ connectedCallback(): void;
27
+ private observeChildrenChanges;
28
+ private handleDragStart;
29
+ private handleDragOver;
30
+ private handleDragEnter;
31
+ private handleDragLeave;
32
+ private handleDrop;
33
+ renderDeleteIcon(tab: any): typeof nothing | import("lit").TemplateResult<1>;
34
+ private renderTabs;
35
+ updated(changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>): void;
36
+ private renderActiveTab;
37
+ private setActiveTab;
38
+ }
39
+ //# sourceMappingURL=tabs.component.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tabs.component.d.ts","sourceRoot":"","sources":["../../../src/components/tabs/tabs.component.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,UAAU,EAAE,gBAAgB,EAAQ,OAAO,EAAC,MAAM,KAAK,CAAC;AAIhE,OAAO,EAAkB,WAAW,EAAY,cAAc,EAAE,SAAS,EAAC,MAAM,oBAAoB,CAAC;AAErG;;;;;;;;;;;;;GAaG;AACH,qBAAa,aAAc,SAAQ,UAAU;IAE3C,SAAS,EAAG,MAAM,CAAC;IAGnB,WAAW,EAAG,cAAc,CAAC;IAG7B,SAAS,EAAG,SAAS,CAAC;IAGtB,QAAQ,EAAG,WAAW,CAAC;IAGvB,IAAI,EAAG,GAAG,EAAE,CAAC;IAEb,OAAgB,MAAM,0BAAU;;IAQvB,MAAM;IAyBN,iBAAiB;IAM1B,OAAO,CAAC,sBAAsB;IAQ9B,OAAO,CAAC,eAAe;IAMvB,OAAO,CAAC,cAAc;IAKtB,OAAO,CAAC,eAAe;IAQvB,OAAO,CAAC,eAAe;IAUvB,OAAO,CAAC,UAAU;IAmBlB,gBAAgB,CAAC,GAAG,EAAE,GAAG;IAoBzB,OAAO,CAAC,UAAU;IAgET,OAAO,CAAC,iBAAiB,EAAE,gBAAgB,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,WAAW,EAAE,OAAO,CAAC;IAWrF,OAAO,CAAC,eAAe;IAQvB,OAAO,CAAC,YAAY;CASrB"}
@@ -0,0 +1,234 @@
1
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
6
+ };
7
+ /* eslint-disable @typescript-eslint/no-explicit-any */
8
+ import { LitElement, html, nothing } from 'lit';
9
+ import { property } from 'lit/decorators.js';
10
+ import { styles } from './tabs.style.js';
11
+ import { classMap } from 'lit/directives/class-map.js';
12
+ import { NOTHING_STRING, TabEvent, TabOrientation, TabsAlign } from './tabs.constant.js';
13
+ /**
14
+ * `hy-tabs` is a LitElement that provides a customizable tabs.
15
+ * @customElement 'hy-tabs'
16
+ *
17
+ * Attributes
18
+ * @attr activeTab
19
+ * @attr orientation
20
+ * @attr tabsAlign
21
+ * @attr editable
22
+ * Events
23
+ * @fires tabEdited - Indicates when tab edited
24
+ * @fires removeTab - Indicates when tab removed
25
+ * @fires addTab - Indicates when tab added
26
+ */
27
+ export class TabsComponent extends LitElement {
28
+ constructor() {
29
+ super();
30
+ this.activeTab = 0;
31
+ this.orientation = TabOrientation.Horizontal;
32
+ }
33
+ render() {
34
+ return html `
35
+ <div
36
+ class=${classMap({
37
+ 'tabs-container': true,
38
+ 'vertical-align': this.orientation === TabOrientation.Vertical,
39
+ 'horizontal-align': this.orientation === TabOrientation.Horizontal,
40
+ 'right-align': this.tabsAlign === TabsAlign.Right,
41
+ 'left-align': this.tabsAlign === TabsAlign.Left,
42
+ 'center-align': this.tabsAlign === TabsAlign.Center,
43
+ })}
44
+ >
45
+ <div
46
+ class="tab-labels"
47
+ style="flex-direction: ${this.orientation === TabOrientation.Vertical ? 'column' : 'row'}"
48
+ >
49
+ <div></div>
50
+
51
+ ${this.renderTabs()}
52
+ <div></div>
53
+ </div>
54
+ <div class="tab-content">${this.renderActiveTab()}</div>
55
+ </div>
56
+ `;
57
+ }
58
+ connectedCallback() {
59
+ super.connectedCallback();
60
+ this.observeChildrenChanges();
61
+ this.addEventListener('dragover', this.handleDragOver);
62
+ }
63
+ observeChildrenChanges() {
64
+ const mutationObserver = new MutationObserver(() => {
65
+ this.requestUpdate();
66
+ });
67
+ mutationObserver.observe(this, { childList: true });
68
+ }
69
+ handleDragStart(event) {
70
+ event.dataTransfer.setData('text/plain', event.currentTarget.dataset.index);
71
+ event.dataTransfer.effectAllowed = 'move';
72
+ event.target.closest('.tab-label').classList.add('dragging-start');
73
+ }
74
+ handleDragOver(event) {
75
+ event.preventDefault();
76
+ event.dataTransfer.dropEffect = 'move';
77
+ }
78
+ handleDragEnter(event) {
79
+ event.preventDefault();
80
+ if (event.currentTarget.contains(event.relatedTarget)) {
81
+ return;
82
+ }
83
+ event.currentTarget.classList.add('dragging');
84
+ }
85
+ handleDragLeave(event) {
86
+ event.preventDefault();
87
+ if (event.currentTarget.contains(event.relatedTarget)) {
88
+ return;
89
+ }
90
+ if (event.currentTarget.classList.contains('dragging')) {
91
+ event.currentTarget.classList.remove('dragging');
92
+ }
93
+ }
94
+ handleDrop(event) {
95
+ var _a, _b;
96
+ event.preventDefault();
97
+ const sourceIndex = event.dataTransfer.getData('text/plain');
98
+ const targetIndex = event.currentTarget.dataset.index;
99
+ if (sourceIndex !== targetIndex) {
100
+ const tabs = Array.from(this.children || []);
101
+ const sourceTab = tabs[sourceIndex];
102
+ const targetTab = tabs[targetIndex];
103
+ this.dispatchEvent(new CustomEvent(TabEvent.tabOrderChange, {
104
+ detail: { sourceTab, targetTab, sourceIndex: parseInt(sourceIndex), targetIndex: parseInt(targetIndex) },
105
+ }));
106
+ }
107
+ (_a = this.shadowRoot.querySelector('.dragging')) === null || _a === void 0 ? void 0 : _a.classList.remove('dragging');
108
+ event.target.classList.remove('dragging');
109
+ (_b = this.shadowRoot.querySelector('.dragging-start')) === null || _b === void 0 ? void 0 : _b.classList.remove('dragging-start');
110
+ }
111
+ renderDeleteIcon(tab) {
112
+ var _a;
113
+ // if the tab does not gave edibale propetry and canDeleteTab is true
114
+ // then render the delete icon
115
+ if (!tab.editable && ((_a = this.editable) === null || _a === void 0 ? void 0 : _a.canDeleteTab)) {
116
+ return html `<hy-icon
117
+ @click=${() => {
118
+ this.dispatchEvent(new CustomEvent(TabEvent.removeTab, {
119
+ detail: { index: tab.index },
120
+ }));
121
+ }}
122
+ name="window-close"
123
+ class="close-icon"
124
+ ></hy-icon>`;
125
+ }
126
+ return nothing;
127
+ }
128
+ renderTabs() {
129
+ var _a, _b, _c, _d, _e, _f;
130
+ const tabs = [];
131
+ const children = this.tabs || [];
132
+ for (let tabIndex = 0; tabIndex < children.length; tabIndex++) {
133
+ const tab = html `
134
+ <div
135
+ data-index=${tabIndex}
136
+ draggable=${(_a = this.editable) === null || _a === void 0 ? void 0 : _a.canMove}
137
+ @dragenter=${this.handleDragEnter}
138
+ @dragleave=${this.handleDragLeave}
139
+ @dragstart=${(e) => this.handleDragStart(e)}
140
+ @drop=${(event) => this.handleDrop(event)}
141
+ class=${tabIndex === this.activeTab ? 'tab-label active' : 'tab-label'}
142
+ @click=${(e) => this.setActiveTab(tabIndex, children[tabIndex], e)}
143
+ >
144
+ <span
145
+ contenteditable=${((_b = this.editable) === null || _b === void 0 ? void 0 : _b.canEditTabTitle) ? true : nothing}
146
+ @blur=${(event) => {
147
+ var _a;
148
+ this.dispatchEvent(new CustomEvent(TabEvent.tabEdited, {
149
+ detail: {
150
+ tab: {
151
+ label: (_a = event.target) === null || _a === void 0 ? void 0 : _a.textContent,
152
+ index: tabIndex,
153
+ },
154
+ },
155
+ }));
156
+ }}
157
+ >${children[tabIndex].label}</span
158
+ >
159
+ ${((_d = (_c = children[tabIndex].editable) === null || _c === void 0 ? void 0 : _c.canDeleteTab) !== null && _d !== void 0 ? _d : (_e = this.editable) === null || _e === void 0 ? void 0 : _e.canDeleteTab)
160
+ ? html `<hy-icon
161
+ @click=${() => {
162
+ this.dispatchEvent(new CustomEvent(TabEvent.removeTab, {
163
+ detail: { index: tabIndex },
164
+ }));
165
+ }}
166
+ name="window-close"
167
+ class="close-icon"
168
+ ></hy-icon>`
169
+ : NOTHING_STRING}
170
+ </div>
171
+ `;
172
+ tabs.push(tab);
173
+ }
174
+ if ((_f = this.editable) === null || _f === void 0 ? void 0 : _f.canAddTab) {
175
+ const tab = html `
176
+ <div
177
+ class="tab-label add-tab-label"
178
+ @click=${() => {
179
+ this.dispatchEvent(new CustomEvent(TabEvent.addTab));
180
+ }}
181
+ >
182
+ <hy-icon name="plus" class="add-tab-icon"></hy-icon>
183
+ </div>
184
+ `;
185
+ tabs.push(tab);
186
+ }
187
+ return tabs;
188
+ }
189
+ updated(changedProperties) {
190
+ super.updated(changedProperties);
191
+ if (!this.tabs[this.activeTab]) {
192
+ if (!this.tabs[this.activeTab - 1]) {
193
+ this.activeTab++;
194
+ }
195
+ else {
196
+ this.activeTab--;
197
+ }
198
+ }
199
+ }
200
+ renderActiveTab() {
201
+ const children = this.tabs ? [...this.tabs] : [];
202
+ if (children.length > 0 && this.activeTab >= 0 && this.activeTab < children.length) {
203
+ return html `${children[this.activeTab].content}`;
204
+ }
205
+ return html `${NOTHING_STRING}`;
206
+ }
207
+ setActiveTab(index, _element, event) {
208
+ event.preventDefault();
209
+ this.activeTab = index;
210
+ /*element?.dispatchEvent(
211
+ new CustomEvent(TabEvent.tabTilteClick, {
212
+ detail: event,
213
+ })
214
+ );*/
215
+ }
216
+ }
217
+ TabsComponent.styles = styles;
218
+ __decorate([
219
+ property({ type: Number })
220
+ ], TabsComponent.prototype, "activeTab", void 0);
221
+ __decorate([
222
+ property({ type: String })
223
+ ], TabsComponent.prototype, "orientation", void 0);
224
+ __decorate([
225
+ property({ type: String })
226
+ ], TabsComponent.prototype, "tabsAlign", void 0);
227
+ __decorate([
228
+ property({ type: Object })
229
+ ], TabsComponent.prototype, "editable", void 0);
230
+ __decorate([
231
+ property({ type: Array })
232
+ ], TabsComponent.prototype, "tabs", void 0);
233
+ customElements.define('hy-tabs', TabsComponent);
234
+ //# sourceMappingURL=tabs.component.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tabs.component.js","sourceRoot":"","sources":["../../../src/components/tabs/tabs.component.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {LitElement, PropertyValueMap, html, nothing} from 'lit';\nimport {property} from 'lit/decorators.js';\nimport {styles} from './tabs.style.js';\nimport {classMap} from 'lit/directives/class-map.js';\nimport { NOTHING_STRING, TabEditable, TabEvent, TabOrientation, TabsAlign} from './tabs.constant.js';\n\n/**\n * `hy-tabs` is a LitElement that provides a customizable tabs.\n * @customElement 'hy-tabs'\n *\n * Attributes\n * @attr activeTab\n * @attr orientation\n * @attr tabsAlign\n * @attr editable\n * Events\n * @fires tabEdited - Indicates when tab edited\n * @fires removeTab - Indicates when tab removed\n * @fires addTab - Indicates when tab added\n */\nexport class TabsComponent extends LitElement {\n @property({type: Number})\n activeTab!: number;\n\n @property({type: String})\n orientation!: TabOrientation;\n\n @property({type: String})\n tabsAlign!: TabsAlign;\n\n @property({type: Object})\n editable!: TabEditable;\n\n @property({type: Array})\n tabs!: any[];\n\n static override styles = styles;\n\n constructor() {\n super();\n this.activeTab = 0;\n this.orientation = TabOrientation.Horizontal;\n }\n\n override render() {\n return html`\n <div\n class=${classMap({\n 'tabs-container': true,\n 'vertical-align': this.orientation === TabOrientation.Vertical,\n 'horizontal-align': this.orientation === TabOrientation.Horizontal,\n 'right-align': this.tabsAlign === TabsAlign.Right,\n 'left-align': this.tabsAlign === TabsAlign.Left,\n 'center-align': this.tabsAlign === TabsAlign.Center,\n })}\n >\n <div\n class=\"tab-labels\"\n style=\"flex-direction: ${this.orientation === TabOrientation.Vertical ? 'column' : ('row' as any)}\"\n >\n <div></div>\n\n ${this.renderTabs()}\n <div></div>\n </div>\n <div class=\"tab-content\">${this.renderActiveTab()}</div>\n </div>\n `;\n }\n override connectedCallback() {\n super.connectedCallback();\n this.observeChildrenChanges();\n this.addEventListener('dragover', this.handleDragOver);\n }\n\n private observeChildrenChanges() {\n const mutationObserver = new MutationObserver(() => {\n this.requestUpdate();\n });\n\n mutationObserver.observe(this, {childList: true});\n }\n\n private handleDragStart(event: any) {\n event.dataTransfer.setData('text/plain', event.currentTarget.dataset.index);\n event.dataTransfer.effectAllowed = 'move';\n event.target.closest('.tab-label').classList.add('dragging-start');\n }\n\n private handleDragOver(event: any) {\n event.preventDefault();\n event.dataTransfer.dropEffect = 'move';\n }\n\n private handleDragEnter(event: any) {\n event.preventDefault();\n if (event.currentTarget.contains(event.relatedTarget)) {\n return;\n }\n event.currentTarget.classList.add('dragging');\n }\n\n private handleDragLeave(event: any) {\n event.preventDefault();\n if (event.currentTarget.contains(event.relatedTarget)) {\n return;\n }\n if (event.currentTarget.classList.contains('dragging')) {\n event.currentTarget.classList.remove('dragging');\n }\n }\n\n private handleDrop(event: any) {\n event.preventDefault();\n const sourceIndex = event.dataTransfer.getData('text/plain');\n const targetIndex = event.currentTarget.dataset.index;\n if (sourceIndex !== targetIndex) {\n const tabs = Array.from(this.children || []);\n const sourceTab = tabs[sourceIndex];\n const targetTab = tabs[targetIndex];\n this.dispatchEvent(\n new CustomEvent(TabEvent.tabOrderChange, {\n detail: {sourceTab, targetTab, sourceIndex: parseInt(sourceIndex), targetIndex: parseInt(targetIndex)},\n })\n );\n }\n this.shadowRoot!.querySelector('.dragging')?.classList.remove('dragging');\n event.target.classList.remove('dragging');\n this.shadowRoot!.querySelector('.dragging-start')?.classList.remove('dragging-start');\n }\n\n renderDeleteIcon(tab :any){\n // if the tab does not gave edibale propetry and canDeleteTab is true\n // then render the delete icon\n if(!tab.editable && this.editable?.canDeleteTab){\n return html`<hy-icon\n @click=${() => {\n this.dispatchEvent(\n new CustomEvent(TabEvent.removeTab, {\n detail: {index: tab.index},\n })\n );\n }}\n name=\"window-close\"\n class=\"close-icon\"\n ></hy-icon>`\n ;\n }\n return nothing;\n\n }\n private renderTabs() {\n const tabs = [];\n const children = this.tabs || [];\n for (let tabIndex = 0; tabIndex < children.length; tabIndex++) {\n const tab = html`\n <div\n data-index=${tabIndex}\n draggable=${this.editable?.canMove}\n @dragenter=${this.handleDragEnter}\n @dragleave=${this.handleDragLeave}\n @dragstart=${(e: any) => this.handleDragStart(e)}\n @drop=${(event: Event) => this.handleDrop(event)}\n class=${tabIndex === this.activeTab ? 'tab-label active' : 'tab-label'}\n @click=${(e: Event) => this.setActiveTab(tabIndex, children[tabIndex], e)}\n >\n <span\n contenteditable=${this.editable?.canEditTabTitle ? true : nothing}\n @blur=${(event: Event) => {\n this.dispatchEvent(\n new CustomEvent(TabEvent.tabEdited, {\n detail: {\n tab: {\n label: (event.target as HTMLElement)?.textContent,\n index: tabIndex,\n },\n },\n })\n );\n }}\n >${children[tabIndex].label}</span\n >\n ${children[tabIndex].editable?.canDeleteTab ?? this.editable?.canDeleteTab\n ? html`<hy-icon\n @click=${() => {\n this.dispatchEvent(\n new CustomEvent(TabEvent.removeTab, {\n detail: {index: tabIndex},\n })\n );\n }}\n name=\"window-close\"\n class=\"close-icon\"\n ></hy-icon>`\n : NOTHING_STRING}\n </div>\n `;\n tabs.push(tab);\n }\n if (this.editable?.canAddTab) {\n const tab = html`\n <div\n class=\"tab-label add-tab-label\"\n @click=${() => {\n this.dispatchEvent(new CustomEvent(TabEvent.addTab));\n }}\n >\n <hy-icon name=\"plus\" class=\"add-tab-icon\"></hy-icon>\n </div>\n `;\n tabs.push(tab);\n }\n return tabs;\n }\n\n override updated(changedProperties: PropertyValueMap<any> | Map<PropertyKey, unknown>) {\n super.updated(changedProperties);\n if (!this.tabs[this.activeTab]) {\n if (!this.tabs[this.activeTab - 1]) {\n this.activeTab++;\n } else {\n this.activeTab--;\n }\n }\n }\n\n private renderActiveTab() {\n const children = this.tabs ? [...this.tabs] : [];\n if (children.length > 0 && this.activeTab >= 0 && this.activeTab < children.length) {\n return html`${children[this.activeTab].content}`;\n }\n return html`${NOTHING_STRING}`;\n }\n\n private setActiveTab(index: number, _element: Element, event: Event) {\n event.preventDefault();\n this.activeTab = index;\n /*element?.dispatchEvent(\n new CustomEvent(TabEvent.tabTilteClick, {\n detail: event,\n })\n );*/\n }\n}\n\ncustomElements.define('hy-tabs', TabsComponent);\n"]}
@@ -0,0 +1,26 @@
1
+ export declare type TabEditable = {
2
+ canDeleteTab: boolean;
3
+ canEditTabTitle: boolean;
4
+ canAddTab: boolean;
5
+ canMove: boolean;
6
+ };
7
+ export declare enum TabOrientation {
8
+ Horizontal = "horizontal",
9
+ Vertical = "vertical"
10
+ }
11
+ export declare enum TabsAlign {
12
+ Right = "right",
13
+ Left = "left",
14
+ Center = "center"
15
+ }
16
+ export declare enum TabEvent {
17
+ removeTab = "removeTab",
18
+ tabEdited = "tabEdited",
19
+ tabTilteClick = "tabTilteClick",
20
+ tabOrderChange = "tabOrderChange",
21
+ addTab = "addTab"
22
+ }
23
+ export declare const NOTHING_STRING = "";
24
+ export declare const EMPTY_STRING = "";
25
+ export declare const LABEL_ATTRIBUTES = "label";
26
+ //# sourceMappingURL=tabs.constant.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tabs.constant.d.ts","sourceRoot":"","sources":["../../../src/components/tabs/tabs.constant.ts"],"names":[],"mappings":"AAAA,oBAAY,WAAW,GAAG;IACxB,YAAY,EAAE,OAAO,CAAC;IACtB,eAAe,EAAE,OAAO,CAAC;IACzB,SAAS,EAAE,OAAO,CAAC;IACnB,OAAO,EAAE,OAAO,CAAC;CAClB,CAAC;AAEF,oBAAY,cAAc;IACxB,UAAU,eAAe;IACzB,QAAQ,aAAa;CACtB;AACD,oBAAY,SAAS;IACnB,KAAK,UAAQ;IACb,IAAI,SAAQ;IACZ,MAAM,WAAU;CACjB;AAED,oBAAY,QAAQ;IAClB,SAAS,cAAc;IACvB,SAAS,cAAc;IACvB,aAAa,kBAAkB;IAC/B,cAAc,mBAAmB;IACjC,MAAM,WAAW;CAClB;AAED,eAAO,MAAM,cAAc,KAAK,CAAC;AACjC,eAAO,MAAM,YAAY,KAAK,CAAC;AAE/B,eAAO,MAAM,gBAAgB,UAAU,CAAC"}
@@ -0,0 +1,23 @@
1
+ export var TabOrientation;
2
+ (function (TabOrientation) {
3
+ TabOrientation["Horizontal"] = "horizontal";
4
+ TabOrientation["Vertical"] = "vertical";
5
+ })(TabOrientation || (TabOrientation = {}));
6
+ export var TabsAlign;
7
+ (function (TabsAlign) {
8
+ TabsAlign["Right"] = "right";
9
+ TabsAlign["Left"] = "left";
10
+ TabsAlign["Center"] = "center";
11
+ })(TabsAlign || (TabsAlign = {}));
12
+ export var TabEvent;
13
+ (function (TabEvent) {
14
+ TabEvent["removeTab"] = "removeTab";
15
+ TabEvent["tabEdited"] = "tabEdited";
16
+ TabEvent["tabTilteClick"] = "tabTilteClick";
17
+ TabEvent["tabOrderChange"] = "tabOrderChange";
18
+ TabEvent["addTab"] = "addTab";
19
+ })(TabEvent || (TabEvent = {}));
20
+ export const NOTHING_STRING = '';
21
+ export const EMPTY_STRING = '';
22
+ export const LABEL_ATTRIBUTES = 'label';
23
+ //# sourceMappingURL=tabs.constant.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tabs.constant.js","sourceRoot":"","sources":["../../../src/components/tabs/tabs.constant.ts"],"names":[],"mappings":"AAOA,MAAM,CAAN,IAAY,cAGX;AAHD,WAAY,cAAc;IACxB,2CAAyB,CAAA;IACzB,uCAAqB,CAAA;AACvB,CAAC,EAHW,cAAc,KAAd,cAAc,QAGzB;AACD,MAAM,CAAN,IAAY,SAIX;AAJD,WAAY,SAAS;IACnB,4BAAa,CAAA;IACb,0BAAY,CAAA;IACZ,8BAAgB,CAAA;AAClB,CAAC,EAJW,SAAS,KAAT,SAAS,QAIpB;AAED,MAAM,CAAN,IAAY,QAMX;AAND,WAAY,QAAQ;IAClB,mCAAuB,CAAA;IACvB,mCAAuB,CAAA;IACvB,2CAA+B,CAAA;IAC/B,6CAAiC,CAAA;IACjC,6BAAiB,CAAA;AACnB,CAAC,EANW,QAAQ,KAAR,QAAQ,QAMnB;AAED,MAAM,CAAC,MAAM,cAAc,GAAG,EAAE,CAAC;AACjC,MAAM,CAAC,MAAM,YAAY,GAAG,EAAE,CAAC;AAE/B,MAAM,CAAC,MAAM,gBAAgB,GAAG,OAAO,CAAC","sourcesContent":["export type TabEditable = {\n canDeleteTab: boolean;\n canEditTabTitle: boolean;\n canAddTab: boolean;\n canMove: boolean;\n};\n\nexport enum TabOrientation {\n Horizontal = 'horizontal',\n Vertical = 'vertical',\n}\nexport enum TabsAlign{\n Right='right',\n Left ='left',\n Center ='center'\n}\n\nexport enum TabEvent {\n removeTab = 'removeTab',\n tabEdited = 'tabEdited',\n tabTilteClick = 'tabTilteClick',\n tabOrderChange = 'tabOrderChange',\n addTab = 'addTab',\n}\n\nexport const NOTHING_STRING = '';\nexport const EMPTY_STRING = '';\n\nexport const LABEL_ATTRIBUTES = 'label';\n"]}
@@ -0,0 +1,2 @@
1
+ export declare const styles: import("lit").CSSResult;
2
+ //# sourceMappingURL=tabs.style.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tabs.style.d.ts","sourceRoot":"","sources":["../../../src/components/tabs/tabs.style.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,MAAM,yBA6LlB,CAAC"}
package/tabs.style.js ADDED
@@ -0,0 +1,192 @@
1
+ import { css } from 'lit';
2
+ export const styles = css `
3
+ :host{
4
+ display: block;
5
+ height: 100%;
6
+ }
7
+ .tabs-container{
8
+ background-color:var(--hybrid-tabs-container-background-color);
9
+ height: 100%;
10
+ }
11
+ .tab-labels,
12
+ .tabs-container {
13
+ display: flex;
14
+ }
15
+
16
+ .tabs-container {
17
+ box-shadow: var(--hybrid-tabs-container-box-shadow);
18
+ }
19
+
20
+ .dragging-start {
21
+ border: var(--hybrid-tabs-dragging-start-border);
22
+ }
23
+ .dragging-enter {
24
+ background-color: var(--hybrid-tabs-dragging-enter-background-color);
25
+ }
26
+ .vertical-align > .tab-content {
27
+ border: var(--hybrid-tabs-va-enter-border);
28
+ border-left: var(--hybrid-tabs-va-enter-border-left);
29
+ }
30
+ .vertical-align.right-align > .tab-content {
31
+ border: var(--hybrid-tabs-va-ra-border);
32
+ border-right: var(--hybrid-tabs-va-ra-border-right);
33
+ }
34
+
35
+ .tab-label {
36
+ cursor: var(--hybrid-tabs-label-cursor);
37
+ padding: var(--hybrid-tabs-label-padding);
38
+ border-bottom: var(--hybrid-tabs-label-border-bottom);
39
+ transition: var(--hybrid-tabs-label-transition);
40
+ user-select: var(--hybrid-tabs-label-user-select);
41
+ color:var(--hybrid-tabs-label-color);
42
+ }
43
+
44
+ .tab-label:hover {
45
+ color: var(--hybrid-tabs-label-hover-color);
46
+ }
47
+
48
+ .tab-label.active {
49
+ color: var(--hybrid-tabs-label-active-hover-color);
50
+ }
51
+
52
+ .tab-content {
53
+ padding: var(--hybrid-tabs-content-padding);
54
+ flex-grow: 1;
55
+ background-color: var(--hybrid-tabs-content-background-color);
56
+ border-top: var(--hybrid-tabs-content-border-top);
57
+ max-height:85vh;
58
+ overflow-y:auto;
59
+ overflow-x:hidden;
60
+ }
61
+ .right-align > .tab-labels {
62
+ flex-direction: var(--hybrid-tabs-right-align-labels-flex-direction);
63
+ align-self: var(--hybrid-tabs-right-align-labels-align-self);
64
+ }
65
+
66
+ .center-align > .tab-labels {
67
+ align-self: var(--hybrid-tabs-center-align-labels-align-self);
68
+ }
69
+ .vertical-align {
70
+ flex-direction: var(--hybrid-tabs-vertical-align-flex-direction);
71
+ }
72
+ .horizontal-align {
73
+ flex-direction: var(--hybrid-tabs-halign-flex-direction);
74
+ }
75
+
76
+ .vertical-align.right-align {
77
+ flex-direction: var(--hybrid-tabs-valign-right-align-flex-direction);
78
+ }
79
+
80
+ .tab-label:hover,
81
+ .tab-label.active {
82
+ border-bottom: var(--hybrid-tabs-label-active-border-bottom);
83
+ border-color: var(--hybrid-tabs-label-active-border-color);
84
+ }
85
+
86
+ .tab-label.active {
87
+ color: var(--hybrid-tabs-label-active-hover-color);
88
+ }
89
+
90
+ .vertical-align .tab-label {
91
+ border: var(--hybrid-tabs-vertical-align-label-border);
92
+ border-right: var(--hybrid-tabs-vertical-align-label-border-right);
93
+ }
94
+
95
+ .vertical-align.right-align .tab-label {
96
+ border: var(--hybrid-tabs-valign-ralign-label-border);
97
+ border-left: var(--hybrid-tabs-valign-ralign-label-border-left);
98
+ }
99
+
100
+ .vertical-align .tab-label:hover,
101
+ .vertical-align .tab-label.active {
102
+ border: var(--hybrid-tabs-vertical-align-label-border-active);
103
+ border-right: var(--hybrid-tabs-vertical-align-label-border-right-active);
104
+ border-color: var(--hybrid-tabs-vertical-align-label-border-color-active);
105
+ }
106
+ .vertical-align.right-align .tab-label:hover,
107
+ .vertical-align.right-align .tab-label.active {
108
+ border: var(--hybrid-tabs-valign-ralign-label-border-active);
109
+ border-left: var(--hybrid-tabs-valign-ralign-label-border-left-active);
110
+ border-color: var(--hybrid-tabs-valign-ralign-label-border-color-active);
111
+ }
112
+
113
+ .close-icon {
114
+ font-size: var(--hybrid-tabs-add-icon-font-size);
115
+ vertical-align: -webkit-baseline-middle;
116
+ margin-left: var(--hybrid-tabs-add-icon-margin-left);
117
+ }
118
+
119
+ .add-tab-label {
120
+ font-size: var(--hybrid-tabs-add-label-font-size);
121
+ text-align: var(--hybrid-tabs-add-label-text-align);
122
+ }
123
+ .dragging {
124
+ border: var(--hybrid-tabs-dragging-border) !important;
125
+ opacity: 0.8;
126
+ color: #464646 !important;
127
+ }
128
+ .tab-label.active {
129
+ color: var(--hybrid-tabs-label-active);
130
+ font-weight: bold;
131
+ }
132
+ .add-tab-icon{
133
+ --hybrid-icon-color:var(--hybrid-tabs-add-icon-color);
134
+ }
135
+ :host{
136
+ --hybrid-tabs-container-background-color:#ffffff;
137
+ --hybrid-tabs-container-box-shadow:none;
138
+ --hybrid-tabs-dragging-start-border:1px dashed black;
139
+ --hybrid-tabs-dragging-enter-background-color:#1661b1;
140
+ --hybrid-tabs-va-enter-border: none;
141
+ --hybrid-tabs-va-enter-border-left: 1px solid #ccc;
142
+ --hybrid-tabs-va-ra-border:none;
143
+ --hybrid-tabs-va-ra-border-right:1px solid #ccc;
144
+ --hybrid-tabs-label-cursor:pointer;
145
+ --hybrid-tabs-label-padding: 7px 7px 5px 7px;
146
+ --hybrid-tabs-label-border-bottom: 2px solid transparent;
147
+ --hybrid-tabs-label-transition: border-color 0.1s ease;
148
+ --hybrid-tabs-label-user-select: none;
149
+ --hybrid-tabs-label-hover-color: #1661b1;
150
+ --hybrid-tabs-label-active-hover-color:#006afe;
151
+ --hybrid-tabs-content-padding:10px;
152
+ --hybrid-tabs-content-background-color: #fff;
153
+ --hybrid-tabs-content-border-top: 1px solid #ccc;
154
+ --hybrid-tabs-right-align-labels-flex-direction:row-reverse;
155
+ --hybrid-tabs-right-align-labels-align-self: end;
156
+ --hybrid-tabs-center-align-labels-align-self:center;
157
+ --hybrid-tabs-vertical-align-flex-direction:row;
158
+ --hybrid-tabs-halign-flex-direction:column;
159
+ --hybrid-tabs-valign-right-align-flex-direction:row-reverse;
160
+ --hybrid-tabs-label-active-border-bottom:2px solid transparent;
161
+ --hybrid-tabs-label-active-border-color: rgb(0, 106, 254);
162
+ --hybrid-tabs-label-active-hover-color: #006afe;
163
+ --hybrid-tabs-vertical-align-label-border: #006afe;
164
+ --hybrid-tabs-vertical-align-label-border-right: 2px solid transparent;
165
+ --hybrid-tabs-valign-ralign-label-border: none;
166
+ --hybrid-tabs-valign-ralign-label-border-left: 2px solid transparent;
167
+ --hybrid-tabs-vertical-align-label-border-active: none;
168
+ --hybrid-tabs-vertical-align-label-border-right-active: 2px solid transparent;
169
+ --hybrid-tabs-vertical-align-label-border-color-active: rgb(0, 106, 254);
170
+ --hybrid-tabs-valign-ralign-label-border-active: none;
171
+ --hybrid-tabs-valign-ralign-label-border-left-active: 2px solid transparent;
172
+ --hybrid-tabs-valign-ralign-label-border-color-active: rgb(0, 106, 254);
173
+ --hybrid-tabs-add-icon-font-size: 13px;
174
+ --hybrid-tabs-add-icon-margin-left: 5px;
175
+ --hybrid-tabs-add-label-font-size: 13px;
176
+ --hybrid-tabs-add-label-text-align: center;
177
+ --hybrid-tabs-dragging-border: 1px dashed gray;
178
+ --hybrid-tabs-label-active: #000000;
179
+ --hybrid-tabs-label-color:gray;
180
+ --hybrid-tabs-add-icon-color: #000000;
181
+ }
182
+ @media (prefers-color-scheme: dark) {
183
+ :host{
184
+ --hybrid-tabs-container-background-color: #000000;
185
+ --hybrid-tabs-content-background-color: #2d2d2d;
186
+ --hybrid-tabs-label-hover-color: #aaa;
187
+ --hybrid-tabs-label-active:#ffffff;
188
+ --hybrid-tabs-add-icon-color: #ffffff;
189
+ }
190
+ }
191
+ `;
192
+ //# sourceMappingURL=tabs.style.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tabs.style.js","sourceRoot":"","sources":["../../../src/components/tabs/tabs.style.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,GAAG,EAAC,MAAM,KAAK,CAAC;AAExB,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA6LxB,CAAC","sourcesContent":["import {css} from 'lit';\n\nexport const styles = css`\n :host{\n display: block;\n height: 100%;\n }\n .tabs-container{\n background-color:var(--hybrid-tabs-container-background-color);\n height: 100%;\n }\n .tab-labels,\n .tabs-container {\n display: flex;\n }\n\n .tabs-container {\n box-shadow: var(--hybrid-tabs-container-box-shadow);\n }\n\n .dragging-start {\n border: var(--hybrid-tabs-dragging-start-border);\n }\n .dragging-enter {\n background-color: var(--hybrid-tabs-dragging-enter-background-color);\n }\n .vertical-align > .tab-content {\n border: var(--hybrid-tabs-va-enter-border);\n border-left: var(--hybrid-tabs-va-enter-border-left);\n }\n .vertical-align.right-align > .tab-content {\n border: var(--hybrid-tabs-va-ra-border);\n border-right: var(--hybrid-tabs-va-ra-border-right);\n }\n\n .tab-label {\n cursor: var(--hybrid-tabs-label-cursor);\n padding: var(--hybrid-tabs-label-padding);\n border-bottom: var(--hybrid-tabs-label-border-bottom);\n transition: var(--hybrid-tabs-label-transition);\n user-select: var(--hybrid-tabs-label-user-select);\n color:var(--hybrid-tabs-label-color);\n }\n\n .tab-label:hover {\n color: var(--hybrid-tabs-label-hover-color);\n }\n\n .tab-label.active {\n color: var(--hybrid-tabs-label-active-hover-color);\n }\n\n .tab-content {\n padding: var(--hybrid-tabs-content-padding);\n flex-grow: 1;\n background-color: var(--hybrid-tabs-content-background-color);\n border-top: var(--hybrid-tabs-content-border-top);\n max-height:85vh;\n overflow-y:auto;\n overflow-x:hidden;\n }\n .right-align > .tab-labels {\n flex-direction: var(--hybrid-tabs-right-align-labels-flex-direction);\n align-self: var(--hybrid-tabs-right-align-labels-align-self);\n }\n\n .center-align > .tab-labels {\n align-self: var(--hybrid-tabs-center-align-labels-align-self);\n }\n .vertical-align {\n flex-direction: var(--hybrid-tabs-vertical-align-flex-direction);\n }\n .horizontal-align {\n flex-direction: var(--hybrid-tabs-halign-flex-direction);\n }\n\n .vertical-align.right-align {\n flex-direction: var(--hybrid-tabs-valign-right-align-flex-direction);\n }\n\n .tab-label:hover,\n .tab-label.active {\n border-bottom: var(--hybrid-tabs-label-active-border-bottom);\n border-color: var(--hybrid-tabs-label-active-border-color);\n }\n\n .tab-label.active {\n color: var(--hybrid-tabs-label-active-hover-color);\n }\n\n .vertical-align .tab-label {\n border: var(--hybrid-tabs-vertical-align-label-border);\n border-right: var(--hybrid-tabs-vertical-align-label-border-right);\n }\n\n .vertical-align.right-align .tab-label {\n border: var(--hybrid-tabs-valign-ralign-label-border);\n border-left: var(--hybrid-tabs-valign-ralign-label-border-left);\n }\n\n .vertical-align .tab-label:hover,\n .vertical-align .tab-label.active {\n border: var(--hybrid-tabs-vertical-align-label-border-active);\n border-right: var(--hybrid-tabs-vertical-align-label-border-right-active);\n border-color: var(--hybrid-tabs-vertical-align-label-border-color-active);\n }\n .vertical-align.right-align .tab-label:hover,\n .vertical-align.right-align .tab-label.active {\n border: var(--hybrid-tabs-valign-ralign-label-border-active);\n border-left: var(--hybrid-tabs-valign-ralign-label-border-left-active);\n border-color: var(--hybrid-tabs-valign-ralign-label-border-color-active);\n }\n\n .close-icon {\n font-size: var(--hybrid-tabs-add-icon-font-size);\n vertical-align: -webkit-baseline-middle;\n margin-left: var(--hybrid-tabs-add-icon-margin-left);\n }\n\n .add-tab-label {\n font-size: var(--hybrid-tabs-add-label-font-size);\n text-align: var(--hybrid-tabs-add-label-text-align);\n }\n .dragging {\n border: var(--hybrid-tabs-dragging-border) !important;\n opacity: 0.8;\n color: #464646 !important;\n }\n .tab-label.active {\n color: var(--hybrid-tabs-label-active);\n font-weight: bold;\n } \n .add-tab-icon{\n --hybrid-icon-color:var(--hybrid-tabs-add-icon-color);\n }\n :host{\n --hybrid-tabs-container-background-color:#ffffff;\n --hybrid-tabs-container-box-shadow:none;\n --hybrid-tabs-dragging-start-border:1px dashed black;\n --hybrid-tabs-dragging-enter-background-color:#1661b1;\n --hybrid-tabs-va-enter-border: none;\n --hybrid-tabs-va-enter-border-left: 1px solid #ccc;\n --hybrid-tabs-va-ra-border:none;\n --hybrid-tabs-va-ra-border-right:1px solid #ccc;\n --hybrid-tabs-label-cursor:pointer;\n --hybrid-tabs-label-padding: 7px 7px 5px 7px;\n --hybrid-tabs-label-border-bottom: 2px solid transparent;\n --hybrid-tabs-label-transition: border-color 0.1s ease;\n --hybrid-tabs-label-user-select: none;\n --hybrid-tabs-label-hover-color: #1661b1;\n --hybrid-tabs-label-active-hover-color:#006afe;\n --hybrid-tabs-content-padding:10px;\n --hybrid-tabs-content-background-color: #fff;\n --hybrid-tabs-content-border-top: 1px solid #ccc;\n --hybrid-tabs-right-align-labels-flex-direction:row-reverse;\n --hybrid-tabs-right-align-labels-align-self: end;\n --hybrid-tabs-center-align-labels-align-self:center;\n --hybrid-tabs-vertical-align-flex-direction:row;\n --hybrid-tabs-halign-flex-direction:column;\n --hybrid-tabs-valign-right-align-flex-direction:row-reverse;\n --hybrid-tabs-label-active-border-bottom:2px solid transparent;\n --hybrid-tabs-label-active-border-color: rgb(0, 106, 254);\n --hybrid-tabs-label-active-hover-color: #006afe;\n --hybrid-tabs-vertical-align-label-border: #006afe;\n --hybrid-tabs-vertical-align-label-border-right: 2px solid transparent;\n --hybrid-tabs-valign-ralign-label-border: none;\n --hybrid-tabs-valign-ralign-label-border-left: 2px solid transparent;\n --hybrid-tabs-vertical-align-label-border-active: none;\n --hybrid-tabs-vertical-align-label-border-right-active: 2px solid transparent;\n --hybrid-tabs-vertical-align-label-border-color-active: rgb(0, 106, 254);\n --hybrid-tabs-valign-ralign-label-border-active: none;\n --hybrid-tabs-valign-ralign-label-border-left-active: 2px solid transparent;\n --hybrid-tabs-valign-ralign-label-border-color-active: rgb(0, 106, 254);\n --hybrid-tabs-add-icon-font-size: 13px;\n --hybrid-tabs-add-icon-margin-left: 5px;\n --hybrid-tabs-add-label-font-size: 13px;\n --hybrid-tabs-add-label-text-align: center;\n --hybrid-tabs-dragging-border: 1px dashed gray;\n --hybrid-tabs-label-active: #000000;\n --hybrid-tabs-label-color:gray;\n --hybrid-tabs-add-icon-color: #000000;\n }\n @media (prefers-color-scheme: dark) {\n :host{\n --hybrid-tabs-container-background-color: #000000;\n --hybrid-tabs-content-background-color: #2d2d2d;\n --hybrid-tabs-label-hover-color: #aaa;\n --hybrid-tabs-label-active:#ffffff; \n --hybrid-tabs-add-icon-color: #ffffff;\n }\n }\n`;\n"]}
@@ -0,0 +1,2 @@
1
+ export declare const addTabTemplate: (handlers: any) => import("lit").TemplateResult<1>;
2
+ //# sourceMappingURL=add-tab.template.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"add-tab.template.d.ts","sourceRoot":"","sources":["../../../../src/components/tabs/templates/add-tab.template.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,cAAc,aAAc,GAAG,oCAS3C,CAAC"}
@@ -0,0 +1,13 @@
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+ import { html } from 'lit';
3
+ export const addTabTemplate = (handlers) => {
4
+ return html ` <div
5
+ class="tab-label add-tab-label"
6
+ @click=${() => {
7
+ handlers.clickHandler();
8
+ }}
9
+ >
10
+ <hy-icon name="plus"></hy-icon>
11
+ </div>`;
12
+ };
13
+ //# sourceMappingURL=add-tab.template.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"add-tab.template.js","sourceRoot":"","sources":["../../../../src/components/tabs/templates/add-tab.template.ts"],"names":[],"mappings":"AAAA,uDAAuD;AACvD,OAAO,EAAC,IAAI,EAAC,MAAM,KAAK,CAAC;AAEzB,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,QAAa,EAAE,EAAE;IAC9C,OAAO,IAAI,CAAA;;aAEA,GAAG,EAAE;QACZ,QAAQ,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;;;SAGI,CAAC;AACV,CAAC,CAAC","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {html} from 'lit';\n\nexport const addTabTemplate = (handlers: any) => {\n return html` <div\n class=\"tab-label add-tab-label\"\n @click=${() => {\n handlers.clickHandler();\n }}\n >\n <hy-icon name=\"plus\"></hy-icon>\n </div>`;\n};\n"]}