@nuralyui/tabs 0.0.13 → 0.0.15

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,141 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2023 Nuraly, Laabidi Aymen
4
+ * SPDX-License-Identifier: MIT
5
+ */
6
+ /**
7
+ * Tab orientation options
8
+ */
9
+ export declare const enum TabOrientation {
10
+ Horizontal = "horizontal",
11
+ Vertical = "vertical"
12
+ }
13
+ /**
14
+ * Tab alignment options
15
+ */
16
+ export declare const enum TabsAlign {
17
+ Right = "right",
18
+ Left = "left",
19
+ Center = "center"
20
+ }
21
+ /**
22
+ * Tab size options
23
+ */
24
+ export declare const enum TabSize {
25
+ Small = "small",
26
+ Medium = "medium",
27
+ Large = "large"
28
+ }
29
+ /**
30
+ * Tab type/variant options
31
+ */
32
+ export declare const enum TabType {
33
+ Default = "default",
34
+ Card = "card",
35
+ Line = "line",
36
+ Bordered = "bordered"
37
+ }
38
+ /**
39
+ * Tab events enumeration
40
+ */
41
+ export declare const enum TabEvent {
42
+ TabClick = "nr-tab-click",
43
+ TabAdd = "nr-tab-add",
44
+ TabRemove = "nr-tab-remove",
45
+ TabEdit = "nr-tab-edit",
46
+ TabOrderChange = "nr-tab-order-change",
47
+ TabChange = "nr-tab-change"
48
+ }
49
+ /**
50
+ * Individual tab configuration interface
51
+ */
52
+ export interface TabItem {
53
+ /** Unique identifier for the tab */
54
+ id?: string | number;
55
+ /** Tab label/title */
56
+ label: string;
57
+ /** Tab content (HTML template or string) */
58
+ content?: any;
59
+ /** Whether the tab is disabled */
60
+ disabled?: boolean;
61
+ /** Whether the tab can be closed */
62
+ closable?: boolean;
63
+ /** Icon for the tab */
64
+ icon?: string;
65
+ /** Custom CSS classes for the tab */
66
+ className?: string;
67
+ /** Tab-specific editable options */
68
+ editable?: Partial<TabEditable>;
69
+ /** Custom data attributes */
70
+ data?: Record<string, any>;
71
+ }
72
+ /**
73
+ * Tab editable configuration interface
74
+ */
75
+ export interface TabEditable {
76
+ /** Whether tabs can be deleted/removed */
77
+ canDeleteTab: boolean;
78
+ /** Whether tab titles can be edited inline */
79
+ canEditTabTitle: boolean;
80
+ /** Whether new tabs can be added */
81
+ canAddTab: boolean;
82
+ /** Whether tabs can be reordered via drag & drop */
83
+ canMove: boolean;
84
+ }
85
+ /**
86
+ * Tab event detail interfaces
87
+ */
88
+ export interface TabClickEventDetail {
89
+ index: number;
90
+ tab: TabItem;
91
+ previousIndex?: number;
92
+ }
93
+ export interface TabAddEventDetail {
94
+ tab?: Partial<TabItem>;
95
+ index?: number;
96
+ }
97
+ export interface TabRemoveEventDetail {
98
+ index: number;
99
+ tab: TabItem;
100
+ }
101
+ export interface TabEditEventDetail {
102
+ index: number;
103
+ tab: TabItem;
104
+ oldLabel: string;
105
+ newLabel: string;
106
+ }
107
+ export interface TabOrderChangeEventDetail {
108
+ sourceIndex: number;
109
+ targetIndex: number;
110
+ sourceTab: TabItem;
111
+ targetTab: TabItem;
112
+ }
113
+ /**
114
+ * Tab configuration options
115
+ */
116
+ export interface TabsConfig {
117
+ /** Tab orientation */
118
+ orientation?: TabOrientation;
119
+ /** Tab alignment */
120
+ align?: TabsAlign;
121
+ /** Tab size */
122
+ size?: TabSize;
123
+ /** Tab type/variant */
124
+ type?: TabType;
125
+ /** Whether tabs are editable */
126
+ editable?: TabEditable;
127
+ /** Whether tabs are animated */
128
+ animated?: boolean;
129
+ /** Whether to hide tab content when tab is not active */
130
+ destroyInactiveTabPane?: boolean;
131
+ /** Custom tab bar extra content */
132
+ tabBarExtraContent?: any;
133
+ }
134
+ /**
135
+ * Constants
136
+ */
137
+ export declare const EMPTY_STRING = "";
138
+ export declare const NOTHING_STRING = "";
139
+ export declare const DEFAULT_ACTIVE_TAB = 0;
140
+ export declare const LABEL_ATTRIBUTES = "label";
141
+ //# sourceMappingURL=tabs.types.d.ts.map
package/tabs.types.js ADDED
@@ -0,0 +1,13 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2023 Nuraly, Laabidi Aymen
4
+ * SPDX-License-Identifier: MIT
5
+ */
6
+ /**
7
+ * Constants
8
+ */
9
+ export const EMPTY_STRING = '';
10
+ export const NOTHING_STRING = '';
11
+ export const DEFAULT_ACTIVE_TAB = 0;
12
+ export const LABEL_ATTRIBUTES = 'label';
13
+ //# sourceMappingURL=tabs.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tabs.types.js","sourceRoot":"","sources":["../../../src/components/tabs/tabs.types.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AA+IH;;GAEG;AACH,MAAM,CAAC,MAAM,YAAY,GAAG,EAAE,CAAC;AAC/B,MAAM,CAAC,MAAM,cAAc,GAAG,EAAE,CAAC;AACjC,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,CAAC;AACpC,MAAM,CAAC,MAAM,gBAAgB,GAAG,OAAO,CAAC","sourcesContent":["/**\n * @license\n * Copyright 2023 Nuraly, Laabidi Aymen\n * SPDX-License-Identifier: MIT\n */\n\n/**\n * Tab orientation options\n */\nexport const enum TabOrientation {\n Horizontal = 'horizontal',\n Vertical = 'vertical'\n}\n\n/**\n * Tab alignment options\n */\nexport const enum TabsAlign {\n Right = 'right',\n Left = 'left',\n Center = 'center'\n}\n\n/**\n * Tab size options\n */\nexport const enum TabSize {\n Small = 'small',\n Medium = 'medium',\n Large = 'large'\n}\n\n/**\n * Tab type/variant options\n */\nexport const enum TabType {\n Default = 'default',\n Card = 'card',\n Line = 'line',\n Bordered = 'bordered'\n}\n\n/**\n * Tab events enumeration\n */\nexport const enum TabEvent {\n TabClick = 'nr-tab-click',\n TabAdd = 'nr-tab-add',\n TabRemove = 'nr-tab-remove',\n TabEdit = 'nr-tab-edit',\n TabOrderChange = 'nr-tab-order-change',\n TabChange = 'nr-tab-change'\n}\n\n/**\n * Individual tab configuration interface\n */\nexport interface TabItem {\n /** Unique identifier for the tab */\n id?: string | number;\n /** Tab label/title */\n label: string;\n /** Tab content (HTML template or string) */\n content?: any;\n /** Whether the tab is disabled */\n disabled?: boolean;\n /** Whether the tab can be closed */\n closable?: boolean;\n /** Icon for the tab */\n icon?: string;\n /** Custom CSS classes for the tab */\n className?: string;\n /** Tab-specific editable options */\n editable?: Partial<TabEditable>;\n /** Custom data attributes */\n data?: Record<string, any>;\n}\n\n/**\n * Tab editable configuration interface\n */\nexport interface TabEditable {\n /** Whether tabs can be deleted/removed */\n canDeleteTab: boolean;\n /** Whether tab titles can be edited inline */\n canEditTabTitle: boolean;\n /** Whether new tabs can be added */\n canAddTab: boolean;\n /** Whether tabs can be reordered via drag & drop */\n canMove: boolean;\n}\n\n/**\n * Tab event detail interfaces\n */\nexport interface TabClickEventDetail {\n index: number;\n tab: TabItem;\n previousIndex?: number;\n}\n\nexport interface TabAddEventDetail {\n tab?: Partial<TabItem>;\n index?: number;\n}\n\nexport interface TabRemoveEventDetail {\n index: number;\n tab: TabItem;\n}\n\nexport interface TabEditEventDetail {\n index: number;\n tab: TabItem;\n oldLabel: string;\n newLabel: string;\n}\n\nexport interface TabOrderChangeEventDetail {\n sourceIndex: number;\n targetIndex: number;\n sourceTab: TabItem;\n targetTab: TabItem;\n}\n\n/**\n * Tab configuration options\n */\nexport interface TabsConfig {\n /** Tab orientation */\n orientation?: TabOrientation;\n /** Tab alignment */\n align?: TabsAlign;\n /** Tab size */\n size?: TabSize;\n /** Tab type/variant */\n type?: TabType;\n /** Whether tabs are editable */\n editable?: TabEditable;\n /** Whether tabs are animated */\n animated?: boolean;\n /** Whether to hide tab content when tab is not active */\n destroyInactiveTabPane?: boolean;\n /** Custom tab bar extra content */\n tabBarExtraContent?: any;\n}\n\n/**\n * Constants\n */\nexport const EMPTY_STRING = '';\nexport const NOTHING_STRING = '';\nexport const DEFAULT_ACTIVE_TAB = 0;\nexport const LABEL_ATTRIBUTES = 'label';"]}
@@ -1,32 +0,0 @@
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
@@ -1 +0,0 @@
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"}
package/demo/tabs-demo.js DELETED
@@ -1,263 +0,0 @@
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
@@ -1 +0,0 @@
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.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/tabs/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAC"}
package/react.d.ts.map DELETED
@@ -1 +0,0 @@
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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"tabs.component.d.ts","sourceRoot":"","sources":["../../../src/components/tabs/tabs.component.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,gBAAgB,EAAQ,OAAO,EAAE,MAAM,KAAK,CAAC;AAIlE,OAAO,EAAkB,WAAW,EAAY,cAAc,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AACtG;;;;;;;;;;;;;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"}
@@ -1 +0,0 @@
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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"tabs.style.d.ts","sourceRoot":"","sources":["../../../src/components/tabs/tabs.style.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,MAAM,yBAoMlB,CAAC"}
@@ -1,2 +0,0 @@
1
- export declare const addTabTemplate: (handlers: any) => import("lit").TemplateResult<1>;
2
- //# sourceMappingURL=add-tab.template.d.ts.map
@@ -1 +0,0 @@
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"}
@@ -1,13 +0,0 @@
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
@@ -1 +0,0 @@
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"]}