Intent to Ship: CSS Custom Functions (@function)

Visto 1.226 veces
Saltar al primer mensaje no leído

Anders Hartvoll Ruud

no leída,
25 feb 2025, 7:26:2525 feb
a blink-dev

Contact emails

and...@chromium.org, se...@chromium.org


Explainer

https://css.oddbird.net/sasslike/mixins-functions

Note: the explainer includes a description of mixins as well. This intent covers custom functions (@function) only.


Specification

https://drafts.csswg.org/css-mixins-1


Note: despite its shortname (css-mixins), the spec currently describes custom functions only.


Summary

Custom Functions are similar to custom properties, but instead of returning a single fixed value, it returns a value based on other custom properties, parameters, and conditionals.


Example: Custom light-dark function:


@function --light-dark(--light, --dark) {

   result: var(--light);

   @media (prefers-color-scheme: dark) {

     result: var(--dark);

   }

}


div {

  background-image: --light-dark(black-logo.png, white-logo.png);

}


Blink component

Blink>CSS


TAG review

https://github.com/w3ctag/design-reviews/issues/1031


TAG review status

Pending


Risks



Interoperability and Compatibility

None



Gecko: No signal (https://github.com/mozilla/standards-positions/issues/1148)


WebKit: No signal (https://github.com/WebKit/standards-positions/issues/437)


Web developers: Positive


(Dug up what I could find per goo.gle/developer-signals):



Other signals:


WebView application risks

None



Debuggability

The Devtools team is working on “basic support” for @function: https://docs.google.com/document/d/17UCa0XDXAG9EBx18w1fXAA9SL3V9Lr4vTptaXYyE1CA/

Unfortunately that doc requires @google.com to access, but “basic support” primarily means that callsites can be clicked, you’ll be taken to the relevant function, and you’ll be able to edit the contents of the function.


Will this feature be supported on all six Blink platforms (Windows, Mac, Linux, ChromeOS, Android, and Android WebView)?

Yes


Is this feature fully tested by web-platform-tests?

Yes


https://wpt.fyi/results/css/css-mixins



In both cases, I’ll make sure we get these things edited so we can remove the .tentative suffixes before shipping.


I do not plan to fix crbug.com/333965945 before shipping, which means that a failure on "Indexed property getter" is to be expected. I will not ship with any other test failures; unexpected red boxes on wpt.fyi may be considered temporary, usually due to Canary not having picked up the latest changes yet.


Flag name on about://flags

CSSFunctions


Finch feature name

CSSFunctions


Requires code in //chrome?

False


Tracking bug

https://issues.chromium.org/issues/325504770


Estimated milestones

Shipping on desktop

136

Shipping on Android

136

Shipping on WebView

136



Anticipated spec changes


At this point, I anticipate only one real spec change: disallowing argument values that begin with two dashes (‘--’). This is to make #11749 (named arguments) possible in the future without compat concerns.


All other issues are not interesting in terms of compat risk.


Full list (only the top one being interesting):



Link to entry on the Chrome Platform Status

https://chromestatus.com/feature/5179721933651968?gate=5074532782309376


Links to previous Intent discussions

Intent to Prototype: https://groups.google.com/a/chromium.org/g/blink-dev/c/b-BTxKD-Ldc/m/1pyobjq7AQAJ


Alan Stearns

no leída,
25 feb 2025, 16:09:4525 feb
a blink-dev,and...@chromium.org
This is a feature that is greatly desired by developers, and as such runs increased risk that whatever gets shipped first gets heavily used and then cannot be improved due to web compat. I think it’s premature to ship without signals from other engines and without a TAG review. We should have more time with this feature behind a flag.

Another signal for implementing behind a feature flag for now: https://blog.kizu.dev/intent-to-experiment-for-longer/

Anders Hartvoll Ruud

no leída,
25 feb 2025, 16:17:2325 feb
a Alan Stearns,Tab Atkins,blink-dev

Panos Astithas

no leída,
25 feb 2025, 17:36:0525 feb
a Anders Hartvoll Ruud,Jeffrey Yasskin,Alan Stearns,Tab Atkins,blink-dev
@Jeffrey Yasskin can fix the outdated labels in the TAG review to ensure it gets in the review queue.

--
You received this message because you are subscribed to the Google Groups "blink-dev" group.
To unsubscribe from this group and stop receiving emails from it, send an email to blink-dev+...@chromium.org.
To view this discussion visit https://groups.google.com/a/chromium.org/d/msgid/blink-dev/CAKFBnUofT%2BKD_b7r28JUJRdUgCs9HJaFhStgZsg8QyTUfJgR3Q%40mail.gmail.com.

Anders Hartvoll Ruud

no leída,
26 feb 2025, 16:11:2326 feb
a Alan Stearns,kiz...@gmail.com,blink-dev,Tab Atkins
Note that this was targeting the M136 release, so we would have had another month to tweak this feature, and even a couple of weeks after that to land finishing touches (or to disable the feature, worst case).

As for signals, concerns could have been raised at any time between December 18th and now. TAG could easily have reviewed earlier, taking the one relevant pending change into account, but chose to delay (despite time constraints being communicated). (Unfortunate that I didn't pay attention to the GitHub labels, though - thanks for fixing that pastithas@ & jyasskin@).

That said, I do agree with the core concern here, so we'll retarget this for the M139 release (branching June 23rd). This intent can be considered "on hold" for now, and I'll be back in June with an update. Meanwhile, the Blink implementation (behind a flag) is ready for experimentation.

Anders Hartvoll Ruud

no leída,
6 may 2025, 7:42:076 may
a blink-dev
See updates inline:

On Wed, Feb 26, 2025 at 10:10 PM Anders Hartvoll Ruud <and...@chromium.org> wrote:
Note that this was targeting the M136 release, so we would have had another month to tweak this feature, and even a couple of weeks after that to land finishing touches (or to disable the feature, worst case).

As for signals, concerns could have been raised at any time between December 18th and now. TAG could easily have reviewed earlier, taking the one relevant pending change into account, but chose to delay (despite time constraints being communicated). (Unfortunate that I didn't pay attention to the GitHub labels, though - thanks for fixing that pastithas@ & jyasskin@).

That said, I do agree with the core concern here, so we'll retarget this for the M139 release (branching June 23rd). This intent can be considered "on hold" for now, and I'll be back in June with an update. Meanwhile, the Blink implementation (behind a flag) is ready for experimentation.


On Tue, Feb 25, 2025 at 10:06 PM Alan Stearns <famu...@gmail.com> wrote:
This is a feature that is greatly desired by developers, and as such runs increased risk that whatever gets shipped first gets heavily used and then cannot be improved due to web compat. I think it’s premature to ship without signals from other engines and without a TAG review. We should have more time with this feature behind a flag.

Another signal for implementing behind a feature flag for now: https://blog.kizu.dev/intent-to-experiment-for-longer/

On Tuesday, February 25, 2025 at 4:26:25 AM UTC-8 and...@chromium.org wrote:

Contact emails

and...@chromium.org, se...@chromium.org


Explainer

https://css.oddbird.net/sasslike/mixins-functions

Note: the explainer includes a description of mixins as well. This intent covers custom functions (@function) only.


Specification

https://drafts.csswg.org/css-mixins-1


The CSSWG resolved to publish a FPWD of this specification.
 

Note: despite its shortname (css-mixins), the spec currently describes custom functions only.


Summary

Custom Functions are similar to custom properties, but instead of returning a single fixed value, it returns a value based on other custom properties, parameters, and conditionals.


Example: Custom light-dark function:


@function --light-dark(--light, --dark) {

   result: var(--light);

   @media (prefers-color-scheme: dark) {

     result: var(--dark);

   }

}


div {

  background-image: --light-dark(black-logo.png, white-logo.png);

}


Blink component

Blink>CSS


TAG review

https://github.com/w3ctag/design-reviews/issues/1031


TAG review status

Pending


TAG closed the design review with Resolution:satisfied. (No issues.)
 

Risks



Interoperability and Compatibility

None



Gecko: No signal (https://github.com/mozilla/standards-positions/issues/1148)


WebKit: No signal (https://github.com/WebKit/standards-positions/issues/437)


Web developers: Positive


(Dug up what I could find per goo.gle/developer-signals):



Other signals:


WebView application risks

None



Debuggability

The Devtools team is working on “basic support” for @function: https://docs.google.com/document/d/17UCa0XDXAG9EBx18w1fXAA9SL3V9Lr4vTptaXYyE1CA/

Unfortunately that doc requires @google.com to access, but “basic support” primarily means that callsites can be clicked, you’ll be taken to the relevant function, and you’ll be able to edit the contents of the function.


Will this feature be supported on all six Blink platforms (Windows, Mac, Linux, ChromeOS, Android, and Android WebView)?

Yes


Is this feature fully tested by web-platform-tests?

Yes


https://wpt.fyi/results/css/css-mixins


  • at-function-cssom.tentative.html is marked tentative because the spec is currently missing a few obvious parts from the API.

    • The subtest "Indexed property getter" is failing due to a Bindings bug. This is an existing issue (likely low impact) that's unrelated to Custom Functions. crbug.com/333965945


This is now specified, and the test is no longer tentative. 
 

This is now also specified, and the test is about to lose the "tentative" status. 


In both cases, I’ll make sure we get these things edited so we can remove the .tentative suffixes before shipping.


I do not plan to fix crbug.com/333965945 before shipping, which means that a failure on "Indexed property getter" is to be expected. I will not ship with any other test failures; unexpected red boxes on wpt.fyi may be considered temporary, usually due to Canary not having picked up the latest changes yet.


Flag name on about://flags

CSSFunctions


Finch feature name

CSSFunctions


Requires code in //chrome?

False


Tracking bug

https://issues.chromium.org/issues/325504770


Estimated milestones

Shipping on desktop

136

Shipping on Android

136

Shipping on WebView

136



Anticipated spec changes


At this point, I anticipate only one real spec change: disallowing argument values that begin with two dashes (‘--’). This is to make #11749 (named arguments) possible in the future without compat concerns.


All other issues are not interesting in terms of compat risk.


Full list (only the top one being interesting):



This has now been reserved in Blink's implementation. This means that arguments starting with "--foo:" (a dashed name, followed by a colon) are invalid for now. The behavior is tested by dashed-function-named-arg.tentative.html.

Mike Taylor

no leída,
6 may 2025, 14:37:036 may
a Anders Hartvoll Ruud,blink-dev

Thanks for the updates.

LGTM1

--
You received this message because you are subscribed to the Google Groups "blink-dev" group.
To unsubscribe from this group and stop receiving emails from it, send an email to blink-dev+...@chromium.org.

Daniel Bratell

no leída,
7 may 2025, 10:51:417 may
a Mike Taylor,Anders Hartvoll Ruud,blink-dev

Yoav Weiss (@Shopify)

no leída,
9 may 2025, 0:33:159 may
a blink-dev,Daniel Bratell,Mike Taylor,Anders Hartvoll Ruud
LGTM3

To unsubscribe from this group and stop receiving emails from it, send an email to blink-dev+unsubscribe@chromium.org.
--
You received this message because you are subscribed to the Google Groups "blink-dev" group.
To unsubscribe from this group and stop receiving emails from it, send an email to blink-dev+unsubscribe@chromium.org.
Responder a todos
Responder al autor
Reenviar
0 mensajes nuevos