Template of a markup projects build system
[TOC]
- git
- nodejs
- yarn
git clone https://github.com/latushko-igor/template_build_markup.git
yarn
gulp
tools
- yarn - package manager
- gulp - build system
- pug - html-preprocessor & template engine
- sass - css-preprocessor
- smartgrid - flexbox grid system
features
- json file with pages data (
./src/_particles/_data.json
) - css-styles reset (
./src/_particles/_reset.scss
) - beml for pug
- sticky footer on flexbox (
./src/main.scss
) - responsive youtube video (
./src/main.scss
) - yandex map integrated (
./src/main.js
,./src/page.pug
) - mixin (
./src/_particles
)- pug (
_mixins.pug
)- index page - pages links hub (for multipage markup projects)
- inline images - svg, png
- sprites - svg, png / png retina
- scss (
_mixins.scss
)- easing linear gradients
- sprites
- pug (
- necessary libraries & plugins (
./gulp/settings.js
,./src/page.pug
- path to*.min
files) - deploying in github pages
settings
./package.json
- github (
name
,description
,repository
)
- github (
./gulp/settings.js
deploy.js
(projectName
,projectType
)- libraries & plugins paths
- smartgrid settings
./src/particles/_data.json
index.pug
(language
,projectName
,index
)_layout.pug
(language
,lorem
)
pages ./src
/index.pug
- index layout/page.pug
- page layout/main.scss
- main styles file/main.js
- custom scripts
media ./src/media
/appearance/svg/*.svg
- svg sprite source/appearance/*.png
- png sprite source/appearance/retina/*.png
- png retina sprite source/appearance/bg/*
- background images/content/*
- content pictures/favicons/*
- favicons/fonts/*/*
- fonts
particles ./src/_particles
_head.pug
- head section_fonts.scss
- fonts_header.pug
- header_footer.pug
- footer
templates ./src/_templates
/_layout.pug
- page/_iframe.pug
- iframe/_form.pug
- form (?)
styles ./src/_particles
/_reset.sass
- resets/_base.sass
- presets/_sprite.sass
- sprites (создается gulp`ом)/[email protected]
- retina sprites (создается gulp`ом)
mixins ./src/_particles
/_mixins.pug
/_mixins.sass
variables ./src/_particles
/_vars.pug
/_vars.sass
project dependencies
- install
sudo npm install --save <...>
svg4everybody
- external SVG spritemaps support (all browsers SVG support)jquery
- javascript libraryjquery-form
- formsjquery-nice-select
- customizable dropdownsjquery.maskedinput
- masked inputjquery-validation
- form validationfancybox
- popup- slider / carousel
slick-carousel
owl.carousel
bxslider
- responsive slider
bootstrap
- grid
inline png/svg image
<!-- pug -->
+img('{fileName}', {width}, {height}, '{className}')
beml
<!-- pug -->
nav(block='navigation')
ul
li(elem='item', mod='active')
a(href='#', title='Page') Page
svg sprite
<!-- pug -->
+icon('{filename}', 'mod')
png sprite
<!-- pug -->
+sprite('{filename}', 'mod')
// scss
.sprite-{filename} {
@include sprite(${filename}) // for simple sprite
@include retina-sprite(${filename}-group) // for simple & retina sprite
}
easing linear gradients
// scss
.container {
@include scrimGradient($startColor, $direction); // rgba(0,0,0,1), 'to bottom'
}
yandex map
<!-- pug -->
div(id='map')
responcive youtube video
<!-- pug -->
div(block='embed-container')
iframe(src='https://www.youtube.com/embed/HVrLvSeSNME', frameborder='0', allowfullscreen)
smart-grid
Default: disabled
(in styles.scss
)
<!-- pug -->
.wrapper
.row
.col
.col
// scss
.wrapper {
@include wrapper();
.row {
@include row-flex();
@include md(justify-content, space-between);
.col {
@include col();
@include size(n);
}
}
}
deploy
gulp deploy
- закачивает страницу на gh-pages
- linux:
Error: ENOSPC: System limit for number of file watchers reached, watch
# Debian
echo fs.inotify.max_user_watches=524288 | sudo tee -a /etc/sysctl.conf && sudo sysctl -p