Home / Class/ DevToolbarHighlight Class — astro Architecture

DevToolbarHighlight Class — astro Architecture

Architecture documentation for the DevToolbarHighlight class in highlight.ts from the astro codebase.

Entity Profile

Dependency Diagram

graph TD
  72415224_142e_1e36_4c77_8fc883507bf2["DevToolbarHighlight"]
  542b8124_ad12_067d_82d7_526ad0a69372["highlight.ts"]
  72415224_142e_1e36_4c77_8fc883507bf2 -->|defined in| 542b8124_ad12_067d_82d7_526ad0a69372
  a297cf54_f189_0e1c_c1aa_070ad4bd7ea9["highlightStyle()"]
  72415224_142e_1e36_4c77_8fc883507bf2 -->|method| a297cf54_f189_0e1c_c1aa_070ad4bd7ea9
  c292751f_3a39_30fe_bd25_46768085704e["constructor()"]
  72415224_142e_1e36_4c77_8fc883507bf2 -->|method| c292751f_3a39_30fe_bd25_46768085704e
  700bfb4d_7404_0177_04f7_28819be7ca66["updateStyle()"]
  72415224_142e_1e36_4c77_8fc883507bf2 -->|method| 700bfb4d_7404_0177_04f7_28819be7ca66
  32d69e79_f8a9_a615_3a3d_155ff35a8f6d["attributeChangedCallback()"]
  72415224_142e_1e36_4c77_8fc883507bf2 -->|method| 32d69e79_f8a9_a615_3a3d_155ff35a8f6d
  e2666104_6dd2_32ae_a5dd_0cc91aef3385["connectedCallback()"]
  72415224_142e_1e36_4c77_8fc883507bf2 -->|method| e2666104_6dd2_32ae_a5dd_0cc91aef3385

Relationship Graph

Source Code

packages/astro/src/runtime/client/dev-toolbar/ui-library/highlight.ts lines 8–130

export class DevToolbarHighlight extends HTMLElement {
	icon?: Icon | undefined | null;
	_highlightStyle: HighlightStyle = 'purple';

	get highlightStyle() {
		return this._highlightStyle;
	}

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

	static observedAttributes = ['highlight-style'];

	shadowRoot: ShadowRoot;

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

		this.icon = this.hasAttribute('icon') ? (this.getAttribute('icon') as Icon) : undefined;

		this.shadowRoot.innerHTML = `
			<style>
				:host {
					--purple-background: linear-gradient(180deg, rgba(224, 204, 250, 0.33) 0%, rgba(224, 204, 250, 0.0825) 100%);
					--purple-border: 1px solid rgba(113, 24, 226, 1);

					--gray-background: linear-gradient(180deg, rgba(191, 193, 201, 0.33) 0%, rgba(191, 193, 201, 0.0825) 100%);
					--gray-border: 1px solid rgba(191, 193, 201, 1);

					--red-background: linear-gradient(180deg, rgba(249, 196, 215, 0.33) 0%, rgba(249, 196, 215, 0.0825) 100%);
					--red-border: 1px solid rgba(179, 62, 102, 1);

					--green-background: linear-gradient(180deg, rgba(213, 249, 196, 0.33) 0%, rgba(213, 249, 196, 0.0825) 100%);
					--green-border: 1px solid rgba(61, 125, 31, 1);

					--yellow-background: linear-gradient(180deg, rgba(255, 236, 179, 0.33) 0%, rgba(255, 236, 179, 0.0825) 100%);
					--yellow-border: 1px solid rgba(181, 138, 45, 1);

					--blue-background: linear-gradient(180deg, rgba(189, 195, 255, 0.33) 0%, rgba(189, 195, 255, 0.0825) 100%);
					--blue-border: 1px solid rgba(54, 69, 217, 1);

					border-radius: 4px;
					display: block;
					width: 100%;
					height: 100%;
					position: absolute;
					z-index: 2000000000;

					background: var(--background);
					border: var(--border);
				}

				.icon {
					width: 24px;
					height: 24px;
					color: white;
					background: linear-gradient(0deg, #B33E66, #B33E66), linear-gradient(0deg, #351722, #351722);
					border: 1px solid rgba(53, 23, 34, 1);
					border-radius: 9999px;
					display: flex;
					justify-content: center;
					align-items: center;
					position: absolute;
					top: -15px;
					right: -15px;
				}
			</style>
			<style id="selected-style"></style>
		`;
	}

	updateStyle() {

Domain

Frequently Asked Questions

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

Analyze Your Own Codebase

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

Try Supermodel Free