diff --git a/.changeset/calm-shirts-battle.md b/.changeset/calm-shirts-battle.md new file mode 100644 index 000000000000..023e17f3b825 --- /dev/null +++ b/.changeset/calm-shirts-battle.md @@ -0,0 +1,5 @@ +--- +'astro': patch +--- + +Add ability to "Click to go editor" on auditted elements in the dev overlay diff --git a/packages/astro/package.json b/packages/astro/package.json index 47e1ae572b76..d1b87a79b8c3 100644 --- a/packages/astro/package.json +++ b/packages/astro/package.json @@ -121,7 +121,7 @@ "test:e2e:match": "playwright test -g" }, "dependencies": { - "@astrojs/compiler": "^2.1.0", + "@astrojs/compiler": "^2.3.0", "@astrojs/internal-helpers": "workspace:*", "@astrojs/markdown-remark": "workspace:*", "@astrojs/telemetry": "workspace:*", diff --git a/packages/astro/src/core/compile/compile.ts b/packages/astro/src/core/compile/compile.ts index 5e1cad1bed34..f270e123eba9 100644 --- a/packages/astro/src/core/compile/compile.ts +++ b/packages/astro/src/core/compile/compile.ts @@ -46,6 +46,7 @@ export async function compile({ scopedStyleStrategy: astroConfig.scopedStyleStrategy, resultScopedSlot: true, transitionsAnimationURL: 'astro/components/viewtransitions.css', + annotateSourceFile: !viteConfig.isProduction && astroConfig.experimental.devOverlay, preprocessStyle: createStylePreprocessor({ filename, viteConfig, diff --git a/packages/astro/src/runtime/client/dev-overlay/plugins/audit.ts b/packages/astro/src/runtime/client/dev-overlay/plugins/audit.ts index 6d5779facb7a..6961e1227329 100644 --- a/packages/astro/src/runtime/client/dev-overlay/plugins/audit.ts +++ b/packages/astro/src/runtime/client/dev-overlay/plugins/audit.ts @@ -1,4 +1,4 @@ -import type { DevOverlayPlugin } from '../../../../@types/astro.js'; +import type { DevOverlayMetadata, DevOverlayPlugin } from '../../../../@types/astro.js'; import type { DevOverlayHighlight } from '../ui-library/highlight.js'; import { getIconElement } from '../ui-library/icons.js'; import { attachTooltipToHighlight, createHighlight, positionHighlight } from './utils/highlight.js'; @@ -121,15 +121,16 @@ export default { const rect = originalElement.getBoundingClientRect(); const highlight = createHighlight(rect, 'warning'); - const tooltip = buildAuditTooltip(rule); + const tooltip = buildAuditTooltip(rule, originalElement); attachTooltipToHighlight(highlight, tooltip, originalElement); canvas.append(highlight); audits.push({ highlightElement: highlight, auditedElement: originalElement as HTMLElement }); } - function buildAuditTooltip(rule: AuditRule) { + function buildAuditTooltip(rule: AuditRule, element: Element) { const tooltip = document.createElement('astro-dev-overlay-tooltip'); + tooltip.sections = [ { icon: 'warning', @@ -138,15 +139,28 @@ export default { { content: rule.message, }, - // TODO: Add a link to the file - // Needs https://github.com/withastro/compiler/pull/375 - // { - // content: '/src/somewhere/component.astro', - // clickDescription: 'Click to go to file', - // clickAction() {}, - // }, ]; + const elementFile = element.getAttribute('data-astro-source-file'); + const elementPosition = element.getAttribute('data-astro-source-loc'); + + if (elementFile) { + const elementFileWithPosition = + elementFile + (elementPosition ? ':' + elementPosition : ''); + + tooltip.sections.push({ + content: elementFileWithPosition.slice( + (window as DevOverlayMetadata).__astro_dev_overlay__.root.length - 1 // We want to keep the final slash, so minus one. + ), + clickDescription: 'Click to go to file', + async clickAction() { + // NOTE: The path here has to be absolute and without any errors (no double slashes etc) + // or Vite will silently fail to open the file. Quite annoying. + await fetch('/__open-in-editor?file=' + encodeURIComponent(elementFileWithPosition)); + }, + }); + } + return tooltip; } diff --git a/packages/astro/test/fixtures/middleware space/src/middleware.js b/packages/astro/test/fixtures/middleware space/src/middleware.js index a889569c4344..779bc5c93930 100644 --- a/packages/astro/test/fixtures/middleware space/src/middleware.js +++ b/packages/astro/test/fixtures/middleware space/src/middleware.js @@ -1,4 +1,4 @@ -import { sequence, defineMiddleware } from 'astro:middleware'; +import { defineMiddleware, sequence } from 'astro:middleware'; const first = defineMiddleware(async (context, next) => { if (context.request.url.includes('/lorem')) { @@ -24,7 +24,7 @@ const first = defineMiddleware(async (context, next) => { const response = await next(); const newResponse = response.clone(); const /** @type {string} */ html = await newResponse.text(); - const newhtml = html.replace('