Home / Class/ DevToolbarBadge Class — astro Architecture

DevToolbarBadge Class — astro Architecture

Architecture documentation for the DevToolbarBadge class in badge.ts from the astro codebase.

Entity Profile

Dependency Diagram

graph TD
  bc3405ae_fd18_8ad9_3e21_98219f1338ab["DevToolbarBadge"]
  ccf99a0e_00b7_53c3_725a_7ede4ad7cb4c["badge.ts"]
  bc3405ae_fd18_8ad9_3e21_98219f1338ab -->|defined in| ccf99a0e_00b7_53c3_725a_7ede4ad7cb4c
  2f2ad715_49e8_63a1_2da9_4f6bf82a59ef["size()"]
  bc3405ae_fd18_8ad9_3e21_98219f1338ab -->|method| 2f2ad715_49e8_63a1_2da9_4f6bf82a59ef
  721779b3_bbd4_66f6_a690_516e63a08cf8["badgeStyle()"]
  bc3405ae_fd18_8ad9_3e21_98219f1338ab -->|method| 721779b3_bbd4_66f6_a690_516e63a08cf8
  0e123ba1_4088_b675_4c6b_fe51a26d57f5["constructor()"]
  bc3405ae_fd18_8ad9_3e21_98219f1338ab -->|method| 0e123ba1_4088_b675_4c6b_fe51a26d57f5
  7065b5eb_d557_a5be_81bd_32fbbdcbe809["connectedCallback()"]
  bc3405ae_fd18_8ad9_3e21_98219f1338ab -->|method| 7065b5eb_d557_a5be_81bd_32fbbdcbe809
  66ad2bff_f56d_df08_3959_c9aff533b865["attributeChangedCallback()"]
  bc3405ae_fd18_8ad9_3e21_98219f1338ab -->|method| 66ad2bff_f56d_df08_3959_c9aff533b865
  ce5889ba_3e4c_5cfe_9b6d_d4afe134fd47["updateStyle()"]
  bc3405ae_fd18_8ad9_3e21_98219f1338ab -->|method| ce5889ba_3e4c_5cfe_9b6d_d4afe134fd47

Relationship Graph

Source Code

packages/astro/src/runtime/client/dev-toolbar/ui-library/badge.ts lines 9–120

export class DevToolbarBadge extends HTMLElement {
	_size: BadgeSize = 'small';
	_badgeStyle: BadgeStyle = 'purple';

	get size() {
		return this._size;
	}

	set size(value) {
		if (!sizes.includes(value)) {
			settings.logger.error(
				`Invalid size: ${value}, expected one of ${sizes.join(', ')}, got ${value}.`,
			);
			return;
		}
		this._size = value;
		this.updateStyle();
	}

	get badgeStyle() {
		return this._badgeStyle;
	}

	set badgeStyle(value) {
		if (!styles.includes(value)) {
			settings.logger.error(
				`Invalid style: ${value}, expected one of ${styles.join(', ')}, got ${value}.`,
			);
			return;
		}
		this._badgeStyle = value;
		this.updateStyle();
	}

	shadowRoot: ShadowRoot;

	static observedAttributes = ['badge-style', 'size'];

	constructor() {
		super();
		this.shadowRoot = this.attachShadow({ mode: 'open' });

		this.shadowRoot.innerHTML = `
			<style>
				.badge {
					box-sizing: border-box;
					border-radius: 4px;
					border: 1px solid transparent;
					padding: 8px;
					font-size: 12px;
					color: var(--text-color);
					height: var(--size);
					border: 1px solid var(--border-color);
					display: flex;
					align-items: center;
					justify-content: center;
					font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;

					--purple-text: rgba(224, 204, 250, 1);
					--purple-border: rgba(113, 24, 226, 1);

					--gray-text: rgba(191, 193, 201, 1);
					--gray-border:rgba(191, 193, 201, 1);

					--red-text: rgba(249, 196, 215, 1);
					--red-border: rgba(179, 62, 102, 1);

					--green-text: rgba(213, 249, 196, 1);
					--green-border: rgba(61, 125, 31, 1);

					--yellow-text: rgba(249, 233, 196, 1);
					--yellow-border: rgba(181, 138, 45, 1);

					--blue-text: rgba(189, 195, 255, 1);
					--blue-border: rgba(54, 69, 217, 1);

					--large: 24px;
					--small: 20px;
				}
			</style>
			<style id="selected-style"></style>

Domain

Frequently Asked Questions

What is the DevToolbarBadge class?
DevToolbarBadge is a class in the astro codebase, defined in packages/astro/src/runtime/client/dev-toolbar/ui-library/badge.ts.
Where is DevToolbarBadge defined?
DevToolbarBadge is defined in packages/astro/src/runtime/client/dev-toolbar/ui-library/badge.ts at line 9.

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free