123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- import {
- e as e2
- } from "./chunk.YXKHB4AC.js";
- import {
- T,
- e,
- h,
- n,
- r,
- r2
- } from "./chunk.5PIDMFOE.js";
- import {
- __decorateClass
- } from "./chunk.IHGPZX35.js";
- var avatar_default = ":host {\n position: relative;\n box-sizing: border-box;\n}\n:host *, :host *:before, :host *:after {\n box-sizing: inherit;\n}\n\n[hidden] {\n display: none !important;\n}\n\n:host {\n display: inline-block;\n --size: 3rem;\n}\n\n.avatar {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n position: relative;\n width: var(--size);\n height: var(--size);\n background-color: var(--sl-color-gray-300);\n font-family: var(--sl-font-sans);\n font-size: calc(var(--size) * 0.5);\n font-weight: var(--sl-font-weight-normal);\n color: var(--sl-color-white);\n overflow: hidden;\n user-select: none;\n vertical-align: middle;\n}\n\n.avatar--circle {\n border-radius: var(--sl-border-radius-circle);\n}\n\n.avatar--rounded {\n border-radius: var(--sl-border-radius-medium);\n}\n\n.avatar--square {\n border-radius: 0;\n}\n\n.avatar__icon {\n display: flex;\n align-items: center;\n justify-content: center;\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n}\n\n.avatar__initials {\n line-height: 1;\n text-transform: uppercase;\n}\n\n.avatar__image {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n object-fit: cover;\n}";
- var SlAvatar = class extends h {
- constructor() {
- super(...arguments);
- this.hasError = false;
- this.shape = "circle";
- }
- render() {
- return T`
- <div
- part="base"
- class=${e2({
- avatar: true,
- "avatar--circle": this.shape === "circle",
- "avatar--rounded": this.shape === "rounded",
- "avatar--square": this.shape === "square"
- })}
- aria-label=${this.alt}
- >
- ${this.initials ? T` <div part="initials" class="avatar__initials">${this.initials}</div> ` : T`
- <div part="icon" class="avatar__icon">
- <slot name="icon">
- <sl-icon name="person-fill" library="system"></sl-icon>
- </slot>
- </div>
- `}
- ${this.image && !this.hasError ? T`
- <img part="image" class="avatar__image" src="${this.image}" @error="${() => this.hasError = true}" />
- ` : ""}
- </div>
- `;
- }
- };
- SlAvatar.styles = r(avatar_default);
- __decorateClass([
- r2()
- ], SlAvatar.prototype, "hasError", 2);
- __decorateClass([
- e()
- ], SlAvatar.prototype, "image", 2);
- __decorateClass([
- e()
- ], SlAvatar.prototype, "alt", 2);
- __decorateClass([
- e()
- ], SlAvatar.prototype, "initials", 2);
- __decorateClass([
- e({ reflect: true })
- ], SlAvatar.prototype, "shape", 2);
- SlAvatar = __decorateClass([
- n("sl-avatar")
- ], SlAvatar);
- var avatar_default2 = SlAvatar;
- export {
- avatar_default2 as avatar_default
- };
|