Improve type checking for formal syntax #9351
                  
                    
                      lzt1008
                    
                  
                
                  started this conversation in
                Show and tell
              
            Replies: 1 comment
-
| If this checking is too strict for us, I think we can also by checking the keywords(using regex), such as url | gradient                           => background-image
rgb | hsl | # (only startWith) | color   => background-color
left | right | top | bottom | position   => background-position
auto | cover | contain | size            => background-sizeso we can also infer the type of css variable (only contains the keyword): bg[var(--some-color)]    => background-color
bg[var(--some-position)] => background-position
bg[var(--some-size)]     => background-sizeand offer users a config like // tailwind.config.js
module.exports = {
  content: [],
  theme: {
    extend: {},
  },
  plugins: [],
  strict: true,
}to switch between keyword mode and formal syntax mode. | 
Beta Was this translation helpful? Give feedback.
                  
                    0 replies
                  
                
            
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment
  
        
    
Uh oh!
There was an error while loading. Please reload this page.
Uh oh!
There was an error while loading. Please reload this page.
-
There are type validators in
dataType.jsreferencing CSS Types, but splitting the basic data types(<length> and <percentage> ) is not a good solution for further maintenance and development. We can just keep them as minimal validators for the css data type.In my opinion,
familyNameandpositionis something like value definition syntax. And we should take them out as validators for formal syntax for better type checking, anddataType.jsis only for basic css data types.So I've created a pull request that created
validateFormalSyntax.jsandsizetype (or formal syntax) for better background checks based on MDN web docs. (#9349)tailwindcss/src/util/validateFormalSyntax.js
Line 22 in b37a44a
and I think it's also a better solution for #7997, which can also fix #9352
Also, as MDN web doc says, the
calc() min() max() clamp()function can all be used anywhere a <length>, <frequency>, <angle>, <time>, <percentage>, <number>, or <integer> is allowed. So we can basically just check the value is wrapped by css functions innumber,length, andpercentagetailwindcss/src/util/dataTypes.js
Line 9 in b37a44a
Beta Was this translation helpful? Give feedback.
All reactions