equinox-web-components
Version:
Equinox design for the web using StencilJS
38 lines (34 loc) • 1.9 kB
JavaScript
import { r as registerInstance, c as createEvent, h, H as Host } from './index-ab05bccf.js';
import { d as deserializeJSON } from './utils-8fac59ff.js';
const eTabsCss = ":host{display:block}.tabs{display:-ms-flexbox;display:flex;gap:12px}.tabs .tab{cursor:pointer;color:var(--primary);background:var(--gray-50);padding:12px;border-radius:100px}.tabs .tab.active{color:#fff;background:var(--primary)}.tabs .tab.disabled{color:var(--gray-500);background:transparent}.tabs .tab.text{padding:12px 0;color:var(--gray-500);background:transparent}.tabs .tab.text.active{color:var(--primary);font-weight:bold}.tabs .tab.text.disabled{color:var(--gray-300)}.tabs .tab.underline{padding:6px;color:var(--primary)}";
const ETabs = class {
constructor(hostRef) {
registerInstance(this, hostRef);
this.tabSelected = createEvent(this, "tabSelected", 7);
this.tabs = "[{\"key\":\"Stencil\",\"title\":\"www.stenciljs.com\"},{\"key\":\"Google\",\"title\":\"www.google.com\"}]";
this.deserializedTabs = [];
this.selectedTab = {
title: null,
key: null
};
}
componentWillLoad() {
this.deserializedTabs = deserializeJSON(this.tabs);
}
parseTabsProp(newValue) {
if (newValue)
this.deserializedTabs = deserializeJSON(this.tabs);
}
tabSelectedHandler(tab) {
this.selectedTab = Object.assign({}, tab);
this.tabSelected.emit(tab);
}
render() {
return (h(Host, null, h("div", { class: "tabs" }, this.deserializedTabs.map(tab => (h("div", { class: `tab ${this.selectedTab.key === tab.key && 'active'}`, onClick: () => !tab.disabled && this.tabSelectedHandler(tab) }, tab.title))))));
}
static get watchers() { return {
"tabs": ["parseTabsProp"]
}; }
};
ETabs.style = eTabsCss;
export { ETabs as e_tabs };