I am creating a set of LESS mixins with Visual Studio/Web Essentials.
Is it possible to write XML-type documentation for LESS mixins? Or perhaps have an enum to limit the parameters that are input?
For instance, with this mixin:
.background-clip(@value)
{
    -webkit-background-clip: @value;
       -moz-background-clip: @value;
            background-clip: @value;
}
It would be nice to have some documentation that describes the three possible values, just like when you are creating a normal CSS selector for background-clip -
Overview In this tutorial, we'll learn what Java enums are, what problems they solve, and how some of their design patterns can be used in practice. Java 5 first introduced the enum keyword. It denotes a special type of class that always extends the java.lang.Enum class.
With Less, we can define so-called "mixins", which have some similarities to functions in programming languages. In Less, they’re used to group CSS instructions in handy, reusable classes. Mixins allow you to embed all the properties of a class into another class by simply including the class name as one of its properties.
Remember to add empty parentheses when you define mixins, which don’t take parameters. This way the initial definition isn’t included in the rendered CSS, only in the code where the mixin is being used.
Like CSS custom properties, mixin and variable definitions do not have to be placed before a line where they are referenced. So the following Less code is identical to the previous example: Both block-style and inline comments may be used: Importing works pretty much as expected.
This would be handled through a parametric mixin call, like this:
.background-clip(@value) when (@value = border-box),
                              (@value = padding-box),
                              (@value = content-box),
                              (@value = inherit)
{
    -webkit-background-clip: @value;
       -moz-background-clip: @value;
            background-clip: @value;
}
This only allows the four values given to be passed in order for it to activate. So this:
.test1 {
  .background-clip(border-box);
}
.test2 {
  .background-clip(something);
}
Would yield this output (ignoring the second call because it is not valid):
.test1 {
  -webkit-background-clip: border-box;
  -moz-background-clip: border-box;
  background-clip: border-box;
}
If feedback to the user was wanted, then a second parametric mixin could offer that through a comment.
OPTION 1 is pure comment
.background-clip(@value) when not (@value = border-box) and
                              not (@value = padding-box) and
                              not (@value = content-box) and
                              not (@value = inherit)
{
  /* WARNING - INVALID INPUT
     CSS output for backbround-clip property given in
     LESS .background-clip() call has been suppressed
     due to invalid input.
     VALID INPUT is one of:
       border-box
       padding-box
       content-box
       inherit
  */
}
Then the above test case would have this additional output:
.test2 {
  /* WARNING - INVALID INPUT
     CSS output for backbround-clip property given in
     LESS .background-clip() call has been suppressed
     due to invalid input.
     VALID INPUT is one of:
       border-box
       padding-box
       content-box
       inherit
  */
}
OPTION 2 includes a bogus property value to show what the improper @value input was:
.background-clip(@value) when not (@value = border-box) and
                              not (@value = padding-box) and
                              not (@value = content-box) and
                              not (@value = inherit)
{
  /* WARNING - INVALID INPUT */
  invalid-background-clip-input-equals: @value;
  /* CSS output for backbround-clip property given in
     LESS .background-clip() call has been suppressed
     due to invalid input.
     VALID INPUT is one of:
       border-box
       padding-box
       content-box
       inherit
  */
}
Which outputs this additional test case CSS:
.test2 {
  /* WARNING - INVALID INPUT */
  invalid-background-clip-input-equals: something;
  /* CSS output for backbround-clip property given in
         LESS .background-clip() call has been suppressed
         due to invalid input.
         VALID INPUT is one of:
           border-box
           padding-box
           content-box
           inherit
      */
}
Browsers would ignore the unrecognized "property" of invalid-background-clip-input-equals, but it would alert one viewing the compiled css what invalid the value passed was.
OPTION 3 includes a bogus (i.e. undefined) mixin to potentially force a compilation error (different compilers might handle undefined mixins differently):
.background-clip(@value) when not (@value = border-box) and
                              not (@value = padding-box) and
                              not (@value = content-box) and
                              not (@value = inherit)
{
   .background-clip-undefined();
}
Which outputs in this compiler this information:
SyntaxError: .background-clip-undefined is undefined on line 24, column 3:
23 .test2 {
24   .background-clip(something);
25 }
This may be a way to "force" the less programmer to input a valid value by throwing an error. Note how in this case the actual undefined mixin giving the error is the .background-clip-undefined(), yet this compiler is actually providing the "calling" information .background-clip(something) which is really what the error is.
One could combine options 2 and 3 so that if an error is not thrown by a compiler, at least the comment feedback is visible.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With