elzar
v0.1.8-beta.5
Published
resmio glamourous style guide in sass mode
Downloads
27
Readme
elzar
resmio glamourous style guide
We are publishing this styleguide as a bower package so we can require it in any
app. The styleguide is already registered as a Bower package called elzar, so
to install it on a project you need to run bower install elzar --save
(if you
don't have bower installed run npm install bower -g
to install it, if you
don't have npm install Node)
When we have changes that we want to push to the places where elzar is used we
need to do some work. This is how it goes.
##How to work with elzar## This is just a workflow I just came up with, so feel free to point any error/improvement.
Clone elzar by doing
git clone [email protected]:resmio/elzar.git
Run
cd elzar
to enter the elzar folder repoCreate a branch with your feature name (
git checkout -b your-feature-name
)Run
gulp watch
to start the compiling process, it will automatically open a browser pointing to index.html, every time you change the code gulp will update the files and refresh the browser. If this doesn't happen check the terminal for error messages. You need chrome canary installed since it is the browser that gulp will open by default.Create your awesome feature, once finished run
git add -A
to tell git that you want all the changes included in your commit, then rungit commit
to save all your changes in a commit, it will open a text editor enter here a message describing what your changes are for (ie: Styled the headers to use Comic Sans and adding a blink effect to the links), save the text file and your changes are commited.Push your branch to github
git push origin your-branch-name
.Go to the elzar repo on github and do a pull request. This means that you want your changes integrated into the master elzar branch. Here is an explanation on how to create a pull request.
Celebrate!
##How to update the npm module## Best to do this when the branch is tested and the feature is merged into master, but we can do it from any branch. Here's how to do it:
Stage and commit all your changes.
Go to the elzar directory in the terminal and run
npm version <type>
replacing with the kind of update you are doing (we use semantic versioning) this is: patch, minor or major. This will update package.json to reflect the new version.Run
npm publish
to update the changes in the npm repo.You will need to update the elzar version in the repo where you use it. You can do this by running
npm update -S elzar
the -S causes the version to be also updated in package.json.
##The ten commandments of sane style sheets## These are extracted from the great book Enduring CSS For more info on stylesheets check this other readme
Have a single source of truth for all key selectors.
Overrides, media queries and all the rules modifying an element are in the same declaration.Do not nest selectors (except media queries or (not many) overrides).
Each key selector gets its own class and rule block, do not nest child elements. Do NOT do things like this:
.MarketGrid > .PhoneOnlyContainer > .ClickToCallHeader > .ClickToCal\ lHeaderMessage > .MessageHolder > span {
font-weight: bold;
padding-right: 5px; }
Do not use ID selectors.
Please don't, they introduce specifity and specifity is evil.Do not write vendor prefixes in the source stylesheets
We will add them later using a post-processor.Use variables for colors, sizing, z-index and breakpoints
It helps us maintain consistency, to find the colors please use htmlcsscolor to avoid things like$red-darker-than-darkest
.
For breakpoints we use the $breakpoint-a $breakpoint-b scheme, a being the smallest one.Write rules mobile first, avoid max-width
It's easier and allows us to get into a mobile-first mentality, the only time we are allowed to use max-width is when we want to isolate some style to a middle range viewport.Use mixins (or variables) for font-stacks
Put it in the body declaration and only override if necessary, if you don't need complicated logic, use a variable instead.Comment all magic numbers and browser hacks
If a situation arises where a pixel based value needs entering into the authoring style sheets that isn’t already defined in the variables this should serve as a red flag to you. About browser hacks it is clear now what that clever hack does, but it won't probably be in three months so put a comment there.Do not inline images (still not sure about this one)
We will use a post-processor to inline them later. But this is still a work in progress, so just use regular background-images for now.Simple is a lot better than complicated
Try and write CSS code that is as simple as possible for others to reason about in future. Writing loops, mixins and functions should be minimised or used very seldom.