-
Notifications
You must be signed in to change notification settings - Fork 2
/
package.json
41 lines (41 loc) · 7.05 KB
/
package.json
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
{
"name": "lesshat-devstack",
"description": "Dev stack for maintaining LESS Hat mixins library",
"version": "1.0.0",
"homepage": "http://lesshat.com/",
"author": {
"name": "Petr Brzek",
"email": "[email protected]"
},
"contributors": [
{
"name": "Jan Kuca",
"url": "www.jankuca.com"
}
],
"repository": {
"type": "git",
"url": "https://github.com/csshat/lesshat-devstack/"
},
"bugs": {
"url": "https://github.com/csshat/lesshat-devstack/issues"
},
"licenses": [
{
"type": "MIT",
"url": "https://github.com/csshat/lesshat-devstack/blob/master/LICENSE"
}
],
"dependencies": {
"less": "1.4.x",
"uglify-js": "~2.3.6"
},
"readme": "# LESSHat Dev Stack documentation\n\n## Instalation\n1. Download lesshat repository\n2. `npm install`\n3. Code!\n\n## Grunt tasks\n1.\t`grunt` – for production. It will prompt you for new version, update package.json, bower.json, header inside lesshat.less and also create git tag. Then it builds mixins from mixins folders, test them and also it create prefixed version. Finally it builds documentation. **Don't use it for contribution.**\n2.\t`grunt contrib` – for contribution. It's the same like the one above, but doesn't prompt you for new version. **Use this for contribution**\n3.\t`grunt version` – changes version in package.json, bower.json and in lesshat.less and lesshat-prefixed.less files and it also creates git tag. **Don't use it for contribution.**\n4.\t`grunt generate` – mixin generator. It creates folder, mixin file, test file and also doc file. Please use it for creating new mixins.\n5.\t`grunt dev` – great for development. It just builds mixins and test them.\n6.\t`grunt build` – awesome for development. It just builds mixins.\n\n\n## About mixins\n* All mixin source files and tests are in *mixins* folder.\n* The mixin source file path pattern is `mixins/%name%/%name%.js` and the test file path pattern is `mixins/%name%/test.js`.\n* Mixin source files are CommonJS modules which have functions as their exports.\n* The exported function is the argument processing function of the mixin. This function is, by default, used for all browsers.\n* LESS Hat Dev Stack automatically handles converting between dash-case and camelCase. So `borderRadius` will be `border-radius` in CSS result.\n* Always use camelCase in mixin source files!\n* **The best way to learn how to create your own mixins is to learn from the existing ones.**\n\n\n## Mixins API\n* `<mixinName> = fn` **required!**\n\t* Function for handling mixin result. It's for all browsers by default. You must return some value.\n\t* If someone calls mixin without arguments and you don't want to polutte result CSS with empty CSS properties, you can return magic numbers `08121991` and LESS CSS then returns nothing.\n\t\n\t**Example:**\n\t\n\t\tvar alignSelf = function alignSelf(value) {\n \t\t\tvalue = value || 'auto';\n \t\t\treturn value;\n\t\t};\n\t\t\n* `<mixinName>[vendor] = fn`\n\t* It's the same as above!\n\t\n\t**Example:**\n\t\n\t\talignSelf.ms = function msalignSelf(value) {\n \t\t\tvalue = value || 'auto';\n\n \t\t\tif (value == 'flex-start') {\n \t\t\tvalue = 'start';\n \t\t\t} else if (value == 'flex-end') {\n \t\t\tvalue = 'end';\n \t\t\t}\n \t\t\treturn value;\n\t\t};\n\t\n* `<mixinName>.alias = String | [<alias>, ...]`\n\t* You can create aliases for your mixins. If you want to use stupid CSS properties names like `shadow` or `anime` you can!\n\t\n\t**Example:**\n\t\n\t\tborderRadius.alias = ['rounded', 'bor'];\n\t\t\n* `<mixinName>.vendors = [<browser>, …]` **required!**\n\t* In vendors array you specify for which browsers is this mixin supported.\n\t* W3C is handled by default. Don't specify that.\n\t\n\t**Example:**\n\t\n\t\tanimation.vendors = ['webkit', 'moz', 'opera'];\n\t\t\n* `<mixinName>.vendors.vendor = boolean`\n\t* If you support some sort of syntax, but you don't want it enable by default, you can turn it off with this.\n\t\n\t**Example:**\n\t\n\t\topacity.vendors.ms = false; // Don't want ms filter syntax by default\n\t\t\n* `<mixinName>.result = {} | String`\n\t* This is suitable for custom mixins, where you need to change result CSS somehow. It would be better to show it on example.\n\t\n\t**Example:**\n\t\n\t\t<mixinName>.result = {\n\t\t\t// This settings change CSS result property\n\t\t\tproperty: 'filter',\n\t\t\t\n\t\t\t// This setting wrap your result in some code\n\t\t\tvalue: 'rotate({{ result }})', \n\t\t\t\n\t\t\t// Sometimes you need to espace your code, because of LESS CSS great architecture. {{ escape_result }} add @{process} for your code\n\t\t\tvalue: '~\"saturate({{ escape_result }})\"',\n\t\t\t\n\t\t\t// If CSS result property would be prefixed or not (true is default)\n\t\t\tprefixed: false,\n\t\t\t\n\t\t\t// If you want to strip some charactes. Rarely used. \n\t\t\tstrip: ';',\n\t\t\t\n\t\t\t// Settings above is for all browsers, but you can also do ti just for specific browser\n\t\t\twebkit: {\n\t\t\t\tproperty: 'something',\n\t\t\t\t\n\t\t\t\t// same as above ...\n\t\t\t},\n\t\t}\n\t\t\n\t* In some extreme cases, where result is quite comlicated e.g. keyframes mixin, you need completely custom results. The result is completely up to you! It's not recommended, because it's not testable, but sometimes you have to be a bad guy.\n\t\n\t\t**Example:**\n\t\t\n\t\t\t// the result is completely up to you!\n\t\t\t<mixinName>.result = 'result.less'\n\t\t\t\n* `<mixinName>.appendCSS = {}`\n\t* Sometimes you want to add some addition CSS. \n\t\n\t**Example:**\n\t\n\t\tborderRadius.appendCSS = {\n\t\t\t// This is for all browsers\n \t\t\tall: 'background-clip: padding-box',\n \t\t\t\n \t\t\t// You can specified it for specific browser\n \t\t\twebkit: '-webkit-background-clip: padding-box',\n \t\t\tmoz: '-moz-background-clip: padding'\n\t\t};\n\t\t\n* `<mixinName>.prependCSS = {}`\n\t* Sometimes you want to add some CSS before mixin result. Properties as same as above.\n\t\n\t**Example:**\n\t\n\t\topacity.prependCSS = {\n \t\t\tms: 'zoom: 1',\n\t\t};\n\t\t\n\n## Full mixin example\n\n\t\t/**\n \t\t* animationName mixin\n \t\t*/\n\n\t\tvar animationName = function animationName(value) {\n \t\t\treturn value || 'none';\n\t\t};\n\n\t\t/**\n \t\t* For which browsers is this mixin specified\n \t\t*/\n\n\t\tanimationName.vendors = ['webkit', 'moz', 'opera'];\n\n\t\t/**\n \t\t* Export mixin\n \t\t*/\n\n\t\tmodule.exports = animationName;\n\n\n## LESS-only Mixins\nThere is definitely a lot of mixins that do not require any JavaScript-based processing of input arguments and a simple LESS file is all that's needed.\n\nYou can create mixins/%name%/%name%.less files instead of JavaScript files and their contents will be simply copied to the resulting LESS file.\n\n\t.size(@width, @height) {\n \twidth: @width;\n \theight: @height;\n\t}",
"readmeFilename": "readme.md",
"_id": "[email protected]",
"dist": {
"shasum": "08dae2b84a3ecd24d02bc6ac39f7e188095fac92"
},
"_resolved": "git://github.com/csshat/lesshat-devstack#9053f215c07fcd366edceeb9932cea6a46ab031d",
"_from": "lesshat-devstack@git://github.com/csshat/lesshat-devstack"
}