@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.
- package/demo/tabs-demo.d.ts +32 -0
- package/demo/tabs-demo.d.ts.map +1 -0
- package/demo/tabs-demo.js +263 -0
- package/demo/tabs-demo.js.map +1 -0
- package/index.d.ts +2 -0
- package/index.d.ts.map +1 -0
- package/index.js +2 -0
- package/index.js.map +1 -0
- package/package.json +15 -0
- package/react.d.ts +9 -0
- package/react.d.ts.map +1 -0
- package/react.js +16 -0
- package/react.js.map +1 -0
- package/tabs.component.d.ts +39 -0
- package/tabs.component.d.ts.map +1 -0
- package/tabs.component.js +234 -0
- package/tabs.component.js.map +1 -0
- package/tabs.constant.d.ts +26 -0
- package/tabs.constant.d.ts.map +1 -0
- package/tabs.constant.js +23 -0
- package/tabs.constant.js.map +1 -0
- package/tabs.style.d.ts +2 -0
- package/tabs.style.d.ts.map +1 -0
- package/tabs.style.js +192 -0
- package/tabs.style.js.map +1 -0
- package/templates/add-tab.template.d.ts +2 -0
- package/templates/add-tab.template.d.ts.map +1 -0
- package/templates/add-tab.template.js +13 -0
- package/templates/add-tab.template.js.map +1 -0
|
@@ -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
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
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"}
|
package/tabs.constant.js
ADDED
|
@@ -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"]}
|
package/tabs.style.d.ts
ADDED
|
@@ -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 @@
|
|
|
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"]}
|