-
Notifications
You must be signed in to change notification settings - Fork 3.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add autoprefixer? like "Myth".. #1917
Comments
This is something that has been discussed here numerous times, but I think the consensus has been (should be still) that this is not something that belongs in less.js (for all of the reasons described in the other issues - run a search and you'll find a few). However, I do think this is a great example of the kind of thing plugins ought to do, so I'll leave this open until others have a chance to weigh in on it. |
Came here to look up and ask for the same thing. It'd be amazing to see the preprocessors like Less and Sass address this. |
If it were written as a plugin, would it affect sourcemap accuracy? |
Hmm, and why you need it to be integrated into Less? You can use it with Less w/o any special integration. |
From my perspective, it'd be awesome to see Less and Sass address this to help move projects and the web in general forward. Having to create extensive libraries of mixins just sucks. Folks want a mixin for everything, but I don't think that should be the case. Mixins make the most sense when creating code shortcuts (e.g., clearfix, image replacement, etc). Moreover, I'd argue the vision of a CSS preprocessor should be to eliminate itself. Improving the core CSS language should the ultimate goal, and having this as part of Less and Sass opens the door to so many more people for writing more bulletproof code, now and forever. |
Hmm, I'm not sure I understand how (and why) preprocessors should "address this" specifically. We just do put the AP tool after the PP tool in the building chain, that's it. |
Right, that fixes it for us, and those using Grunt. Not everyone uses Grunt or another build tool. When I say Less and Sass should address this, I mean that auto-prefixing CSS3 properties should happen automatically (and be configurable) within the core Less and Sass projects. An external tool shouldn't be necessary. |
@seven-phases-max autoprefixer supports source maps with less' output css, not less' raw source input. There's also the argument for autoprefixer in "development mode", without the need for a task runner. |
Amen. I could not have articulated my view any better than this line. Sums it up well.
This is the kind of feedback that I was looking for when I left the issue open. @mdo / @stevenvachon would it make a material difference if this functionality was supplied by a plugin that for all intents and purposes "felt" like it was native, and not like an external tool (meaning that it wouldn't rely on a third party build chain, Less.js would do all the work)? |
@jonschlinkert sure, but would it work with Less.js' dev mode and would it produce accurate source maps relative to the Less code and not its CSS output? |
@stevenvachon by "Less.js' dev mode" do you mean client side usage? See #1835. |
@stevenvachon well, that brings up a good point - I guess (like most things) it will depend on expectations. So maybe the first thing to do is for us to outline these things and get consensus on what the autoprefixer would be expected to do. Then @lukeapage / @seven-phases-max can decide whether or not a plugin would work, or if it needs to be implemented natively. |
@jonschlinkert my expectations would be pretty simple:
Not sure if anyone has anything to add to that. As to whether it should be a plugin or a native feature, I'd push for native as it maintains Less.js' ease of use and brings everything closer to achieving @mdo's summary of what a pre-processor should be. |
@jonschlinkert that link you posted, does it have a reference of properties/rules that get prefixed? And, does it—should it—have a source for updates (like autoprefixer does with caniuse.com)? |
Well, my point is: of course there's nothing wrong with implementing autoprefixing as a plugin (when we have the plugin subsystem ready). But this is just a tiny bonus to what we already have. And we are able to put the AP after the PP in whatever build environment (not just Grunt). Sure, there's always people out there that would prefer "just give me one monster tool that can do everything" way... Well, I don't think I need to enumerate all the cons of the "everything-in-one" approach, especially when it comes to a community-driven open-source development. That's pretty old story. So my personal vision: preprocessors are for generating styles, postprocessors are for prefixing (and similar things), just let each tool do its work at its bests.
According to https://github.com/ai/autoprefixer#source-map, an output sourcemap of the autoprefixer still should point to the original line in the less file. I dunno about client-side usage though, never tried - probably you're right and it does not work as supposed there. Either way: |
I just wanted to link to that as a resource for the discussion. Since @lukeapage developed the plugin (and to my knowledge it's not "officially" released), we should probably get feedback from Luke on it |
Yeah, I think anyone who wants life to be a little easier. Who in there right mind would want to use multiple tools to get one job accomplished? |
Someone who knows that the benefits of the modular approach are infinite :) (it's a rhetorical question of course, you know that better than me... btw. out of curiosity, how many node-modules you have installed currently?)
|
@seven-phases-max we already have that "problem" with clean-css. |
@stevenvachon Yep, and there're some thoughts of getting rid of it too... |
@seven-phases-max replaced with custom code, I imagine? If so, what about writing a custom autoprefixer for Less.js ? |
@seven-phases-max after reading more into your link, their primary concern is that clean-css is not related to Less.js' use of it, so it's more dangerous. Less.js using autoprefixer would be directly related. However, rework is a big engine that doesn't work on client-side, at least currently. |
Regarding the core or plugin question: Yeah, I mean if it fucks up everything to make it part of the core, let's not do that. But if the intent is to help as many folks as possible, this should ship as part of the core. |
Hi all, I completely agree with this being necessary and in fact I already made a I want to adjust it to work differently, taking a configuration rather than It has not occurred to me that it is a hassle to have it in a different Part of the reason I thought of using a plugin is because I thought it Another quicker option is to make a plugin that uses auto prefixer or like People complain if lessc brings in too many dependencies that people don't Its also been pointed out that tying yourself to another repo like we do |
Just actually reading all the comments, I think, lets do this.
Because its not a different implementation between the 2. Also just to be clear, I want to remove cleancss from the node api for |
👍 |
@lukeapage will your solution work on the client side? If not, we might as well use autoprefixer, no? |
Yes it would work both places and yes you can also already use postProcess |
Agreed with creating as a plugin. Autoprefixing is not a simple task (and most over-prefix), so let's keep the core light. As a core community-supported plugin is fine, but then it's opt-in. |
Incidentally, it would be brilliant if an auto-prefixer didn't just add -webkit- and -ms- and -moz- to everything under the sun, but actually used up-to-date data from caniuse.com, and only appended based on:
Also, interestingly, in the case of keyframes, an autoprefixer would need to duplicate entire rulesets, not just individual properties. But all that can be part of the auto-prefixer plugin wiki/issue/repo, wherever it lives. |
Wouldn't it be even better to use depend on autoprefixer, and let that lib do all the heavy lifting? I'm good with @lukeapage's decision on this since he's much more familiar with the challenges and requirements. But it does seem like we would be recreating a lot of work that has already been done by a library (and some smart folks) dedicated to the task of autoprefixing. So before we finalized anything I just wanted to throw this out there mainly because I think we might get bitten by the nuances and edge cases that we're not thinking about. |
fwiw, @matthew-dean I agree that the things you're mentioning would be pretty awesome. as a rule of thumb though I like to lean towards using established solutions over recreating the wheel (unless the other wheels are broken) |
Oh, that link was mentioned but it wasn't mentioned that it was using that methodology. I'm not saying anything different, then. Seems smart to just wrap a less plugin around that lib. |
👍 |
Having looked at autoprefixer it seems silly to reinvent the wheel when ap I will add it to our 2.0 deliverable, which shouldn't be too far away, |
Along with this, why not just include Myth as a possible post-processor option? Excessive? |
@stevenvachon If I understand it correctly the agreement is to provide whatever post-preprocessing via plugins and not as a dedicated core-options. (I.e. to add |
Ah, yeah, I prefer that approach. And, haha, I don't use task runners as much anymore; maybe others are doing the same? |
You will then. |
What I mean is that I don't use Grunt/Gulp much anymore. Lately, I've just been using npm-scripts and a build.js with each lib's programmatic API. |
Yes, I've got it above. I mean it does not matter how the thing is named: |
A plugin architecture may not even be necessary if we have a callback that supports a |
A callback also may be not necessary since These ("external tool wrapper") plugins are still necessary only because they'll keep asking for a monolith tool no matter what. |
(maybe you knew but) less.render returns a promise on v2 if no callback is |
Yes, my bad, I guess just overgeneralized things a bit to not confuse even more :) (In other words, the real purpose of the callback and/or promise there is that it can make async things more simple and/or make error handling more easy... If that would not be necessary it could just really return a string and never care of anything that happens after that (if it could be "just" Less compiler :).) |
No problem, I was actually replying to Steve! |
😄 I hadn't checked much of the source before saying that. Most everything seems to have been thought of, which is awesome. |
less-plugin-autoprefix is now on npm and works with the (just release) beta v2 of lessc. I've started mentioning autoprefixer in the docs and I hope more people take advantage of how easy it is to use now, even without a build process. |
https://github.com/ai/autoprefixer
It's what Myth uses.
Would be cool. Wouldn't need to use mixins for as many things.
The text was updated successfully, but these errors were encountered: