forked from enyojs/onyx
-
Notifications
You must be signed in to change notification settings - Fork 0
/
CONTRIBUTING md
44 lines (27 loc) · 2.73 KB
/
CONTRIBUTING md
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
42
43
44
# Contributions
Contributions are welcome for Enyo and its associated libraries including onyx and layout.
Please see [Contributing to Enyo](http://enyojs.com/community/contribute/) for details
on our contribution policy and guidelines for use of the Enyo-DCO-1.0-Signed-off-by
line in your commits and pull requests.
If you're interested in introducing new kinds, you might also consider hosting your own repo
and contributing to the [Enyo community gallery](http://enyojs.com/gallery).
## Modifications to CSS
Onyx CSS is defined using parameterized LESS files. Whenever you make changes to LESS files in Onyx, you'll also need to re-generate and check-in the top-level .css file as well, to maintain backward-compatibility for environments that don't wish to use LESS.
You can re-generate the top-level onyx.css file as follows:
cd lib/onyx/css
../../../enyo/tools/lessc.sh ./package.js
NOTE: Since LESS generates relative URLs, it's important to run the `lessc.sh` script from the onyx css folder.
Also note you only need to generate the .css file when you're ready to check in your changes. During development, you can do all your testing modifying just LESS files if you include "less-xyz.min.js" in your app's debug.html file, which compiles the LESS client-side during loading:
<script src="enyo/tools/minifier/node_modules/less/dist/less-1.3.0e.min.js"></script>
Additionally, any new controls contributed should follow this basic pattern to ensure proper themability support:
* Place control's .js file(s) in `lib/onyx/source` and add to `lib/onyx/source/package.js`
* Place control's .less file(s) in `lib/onyx/css`
* @import .less file(s) into [`lib/onyx/css/onyx-rules.less`](https://github.com/enyojs/onyx/blob/master/css/onyx-rules.less)
* Use existing variables from [`lib/onyx/css/onyx-variables.less`](https://github.com/enyojs/onyx/blob/master/css/onyx-variables.less) in your control's LESS files when available, add any new variables your particular control needs along with their default definitions to onyx-variables.less.
Refer to the [UI Theming Guide](https://github.com/enyojs/enyo/wiki/UI-Theming) for more details.
## Samples
Every new control should be accompanied by at least one sample in the [Enyo 2 Sampler](http://enyojs.com/sampler). Read the [Sampler readme](https://github.com/enyojs/sampler) for details on how to go about adding new samples to the Sampler.
Guidelines for samples:
* Samples should live in a folder named `samples`, as a peer to the source
* Be sure to exercise useful API's and events of the control in the sample
* When one or more significantly different or interesting configurations of the control are available, include more than one instance in the sample to exhibit use of the different API's