import { DeesElement, property, html, customElement, type TemplateResult, css, cssManager, unsafeCSS } from '@design.estate/dees-element'; import * as domtools from '@design.estate/dees-domtools'; import { fonts, shadows } from '../styles/shared.styles.js'; import { demoFunc } from './upl-statuspage-header.demo.js'; declare global { interface HTMLElementTagNameMap { 'upl-statuspage-header': UplStatuspageHeader; } } @customElement('upl-statuspage-header') export class UplStatuspageHeader extends DeesElement { // STATIC public static demo = demoFunc; // INSTANCE @property({ type: String }) public pageTitle: string = "Statuspage Title"; @property({ type: Boolean }) public showReportButton: boolean = true; @property({ type: Boolean }) public showSubscribeButton: boolean = true; @property({ type: String }) public brandColor: string = ''; @property({ type: String }) public logoUrl: string = ''; @property({ type: Boolean }) public customStyles: boolean = false; @property({ type: Boolean }) public loading: boolean = false; constructor() { super(); } public static styles = [ domtools.elementBasic.staticStyles, css` :host { display: block; background: transparent; font-family: ${unsafeCSS(fonts.base)}; color: ${cssManager.bdTheme('#0a0a0a', '#fafafa')}; } .mainbox { margin: auto; max-width: 1200px; padding: 0 24px; } .mainbox .actions { display: flex; justify-content: flex-end; gap: 8px; padding: 24px 0; } .mainbox .actions .actionButton { background: ${cssManager.bdTheme('rgba(255, 255, 255, 0.8)', 'rgba(0, 0, 0, 0.6)')}; backdrop-filter: blur(10px); font-size: 14px; font-weight: 500; border: 1px solid ${cssManager.bdTheme('rgba(0, 0, 0, 0.08)', 'rgba(255, 255, 255, 0.08)')}; padding: 8px 16px; border-radius: 6px; cursor: pointer; user-select: none; transition: all 0.2s ease; display: inline-flex; align-items: center; justify-content: center; min-height: 36px; color: ${cssManager.bdTheme('#0a0a0a', '#fafafa')}; box-shadow: ${unsafeCSS(shadows.sm)}; } .mainbox .actions .actionButton:hover { background: ${cssManager.bdTheme('rgba(255, 255, 255, 0.95)', 'rgba(0, 0, 0, 0.8)')}; border-color: ${cssManager.bdTheme('rgba(0, 0, 0, 0.12)', 'rgba(255, 255, 255, 0.12)')}; transform: translateY(-1px); box-shadow: ${unsafeCSS(shadows.md)}; } .mainbox .actions .actionButton:active { transform: translateY(0); } .header-content { padding: 64px 0 48px 0; text-align: center; } h1 { margin: 0; font-size: 48px; font-weight: 700; letter-spacing: -0.02em; line-height: 1.1; color: ${cssManager.bdTheme('#0a0a0a', '#fafafa')}; } .subtitle { margin: 16px 0 0 0; font-size: 16px; font-weight: 400; color: ${cssManager.bdTheme('#6b7280', '#a1a1aa')}; letter-spacing: 0.02em; text-transform: uppercase; } .logo { display: block; margin: 0 auto 32px; max-width: 180px; height: auto; filter: ${cssManager.bdTheme('none', 'brightness(0) invert(1)')}; } .loading-skeleton { height: 200px; background: ${cssManager.bdTheme( 'linear-gradient(90deg, #f3f4f6 25%, #e5e7eb 50%, #f3f4f6 75%)', 'linear-gradient(90deg, #1f1f1f 25%, #262626 50%, #1f1f1f 75%)' )}; background-size: 200% 100%; animation: loading 1.5s infinite; border-radius: 6px; margin: 24px 0; } @keyframes loading { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } } /* Primary button variant */ .actionButton.primary { background: ${cssManager.bdTheme('#0a0a0a', '#fafafa')}; color: ${cssManager.bdTheme('#ffffff', '#0a0a0a')}; border-color: transparent; backdrop-filter: none; } .actionButton.primary:hover { background: ${cssManager.bdTheme('#262626', '#e5e7eb')}; transform: translateY(-1px); box-shadow: ${unsafeCSS(shadows.md)}; } ` ] public render(): TemplateResult { if (this.loading) { return html`