feat: leave view transition pseudo selectors untouched (#11375)

* feat: leave view transition pseudo selectors untouched

view transition pseude selectors are global-like, i.e. they shouldn't be scoped or treated as unused.
In the process of adding support for this, is_root and is_host were consolidated into is_global_like because their usage locations didn't need any differentiation between them (same for the new view transition treatment)

closes #9127

* regenerate types
pull/11381/head
Simon H 9 months ago committed by GitHub
parent de315d84eb
commit cd2506535f
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

@ -0,0 +1,5 @@
---
"svelte": patch
---
feat: leave view transition pseudo selectors untouched

@ -182,8 +182,7 @@ function read_selector(parser, inside_pseudo_class = false) {
end: -1, end: -1,
metadata: { metadata: {
is_global: false, is_global: false,
is_host: false, is_global_like: false,
is_root: false,
scoped: false scoped: false
} }
}; };

@ -42,7 +42,7 @@ const analysis_visitors = {
node.metadata.rule = context.state.rule; node.metadata.rule = context.state.rule;
node.metadata.used = node.children.every( node.metadata.used = node.children.every(
({ metadata }) => metadata.is_global || metadata.is_host || metadata.is_root ({ metadata }) => metadata.is_global || metadata.is_global_like
); );
}, },
RelativeSelector(node, context) { RelativeSelector(node, context) {
@ -57,10 +57,19 @@ const analysis_visitors = {
if (node.selectors.length === 1) { if (node.selectors.length === 1) {
const first = node.selectors[0]; const first = node.selectors[0];
node.metadata.is_host = first.type === 'PseudoClassSelector' && first.name === 'host'; node.metadata.is_global_like ||=
} (first.type === 'PseudoClassSelector' && first.name === 'host') ||
(first.type === 'PseudoElementSelector' &&
node.metadata.is_root = !!node.selectors.find( [
'view-transition',
'view-transition-group',
'view-transition-old',
'view-transition-new',
'view-transition-image-pair'
].includes(first.name));
}
node.metadata.is_global_like ||= !!node.selectors.find(
(child) => child.type === 'PseudoClassSelector' && child.name === 'root' (child) => child.type === 'PseudoClassSelector' && child.name === 'root'
); );
@ -87,7 +96,7 @@ const analysis_visitors = {
node.metadata.has_local_selectors = node.prelude.children.some((selector) => { node.metadata.has_local_selectors = node.prelude.children.some((selector) => {
return selector.children.some( return selector.children.some(
({ metadata }) => !metadata.is_global && !metadata.is_host && !metadata.is_root ({ metadata }) => !metadata.is_global && !metadata.is_global_like
); );
}); });
} }

@ -42,8 +42,7 @@ const nesting_selector = {
], ],
metadata: { metadata: {
is_global: false, is_global: false,
is_host: false, is_global_like: false,
is_root: false,
scoped: false scoped: false
} }
}; };
@ -109,7 +108,7 @@ const visitors = {
*/ */
function truncate(node) { function truncate(node) {
const i = node.children.findLastIndex(({ metadata }) => { const i = node.children.findLastIndex(({ metadata }) => {
return !metadata.is_global && !metadata.is_host && !metadata.is_root; return !metadata.is_global && !metadata.is_global_like;
}); });
return node.children.slice(0, i + 1); return node.children.slice(0, i + 1);
@ -229,14 +228,14 @@ function mark(relative_selector, element) {
/** /**
* Returns `true` if the relative selector is global, meaning * Returns `true` if the relative selector is global, meaning
* it's a `:global(...)` or `:host` or `:root` selector, or * it's a `:global(...)` or unscopeable selector, or
* is an `:is(...)` or `:where(...)` selector that contains * is an `:is(...)` or `:where(...)` selector that contains
* a global selector * a global selector
* @param {import('#compiler').Css.RelativeSelector} selector * @param {import('#compiler').Css.RelativeSelector} selector
* @param {import('#compiler').Css.Rule} rule * @param {import('#compiler').Css.Rule} rule
*/ */
function is_global(selector, rule) { function is_global(selector, rule) {
if (selector.metadata.is_global || selector.metadata.is_host || selector.metadata.is_root) { if (selector.metadata.is_global || selector.metadata.is_global_like) {
return true; return true;
} }

@ -56,9 +56,10 @@ export namespace Css {
combinator: null | Combinator; combinator: null | Combinator;
selectors: SimpleSelector[]; selectors: SimpleSelector[];
metadata: { metadata: {
/** :global(..) */
is_global: boolean; is_global: boolean;
is_host: boolean; /** :root, :host, ::view-transition */
is_root: boolean; is_global_like: boolean;
scoped: boolean; scoped: boolean;
}; };
} }

@ -0,0 +1,16 @@
::view-transition {
animation-duration: 0.5s;
}
::view-transition-group(foo) {
animation-duration: 0.5s;
}
::view-transition-old {
animation-duration: 0.5s;
}
::view-transition-new {
animation-duration: 0.5s;
}
::view-transition-image-pair {
animation-duration: 0.5s;
}

@ -0,0 +1,17 @@
<style>
::view-transition {
animation-duration: 0.5s;
}
::view-transition-group(foo) {
animation-duration: 0.5s;
}
::view-transition-old {
animation-duration: 0.5s;
}
::view-transition-new {
animation-duration: 0.5s;
}
::view-transition-image-pair {
animation-duration: 0.5s;
}
</style>

@ -1202,9 +1202,10 @@ declare module 'svelte/compiler' {
combinator: null | Combinator; combinator: null | Combinator;
selectors: SimpleSelector[]; selectors: SimpleSelector[];
metadata: { metadata: {
/** :global(..) */
is_global: boolean; is_global: boolean;
is_host: boolean; /** :root, :host, ::view-transition */
is_root: boolean; is_global_like: boolean;
scoped: boolean; scoped: boolean;
}; };
} }

Loading…
Cancel
Save