/**
* DS Badge - Web Component
*
* Usage:
* Default
* Active
* Pending
*
* Attributes:
* - variant: default | secondary | outline | destructive | success | warning
* - dot: boolean (shows status dot)
*/
class DsBadge extends HTMLElement {
static get observedAttributes() {
return ['variant', 'dot'];
}
constructor() {
super();
this.attachShadow({ mode: 'open' });
}
connectedCallback() {
this.render();
}
disconnectedCallback() {
// Cleanup for consistency with other components
// This badge has no event listeners, but disconnectedCallback
// is present for future extensibility and pattern consistency
}
attributeChangedCallback() {
if (this.shadowRoot.innerHTML) {
this.render();
}
}
get variant() {
return this.getAttribute('variant') || 'default';
}
get dot() {
return this.hasAttribute('dot');
}
getVariantClass() {
const variants = {
default: 'ds-badge--default',
secondary: 'ds-badge--secondary',
outline: 'ds-badge--outline',
destructive: 'ds-badge--destructive',
success: 'ds-badge--success',
warning: 'ds-badge--warning'
};
return variants[this.variant] || variants.default;
}
render() {
const variantClass = this.getVariantClass();
this.shadowRoot.innerHTML = `
${this.dot ? '' : ''}
`;
}
}
customElements.define('ds-badge', DsBadge);
export default DsBadge;