Giter VIP home page Giter VIP logo

circles's Introduction

English description | Описание на русском

Tars

Mac/Linux Build Status Windows Build status Gitter

TARS is a markup builder, which is based on Gulp.js. It facilitates and accelerates process of html-markup of any complexity. TARS will be suitable for teams and individual developer. It solves the most routine cases associated with a markup and it brings you more pleasure from work.

TARS is the framework for gulp, including a set of gulp-tasks and it allows the ability to easily expand (creating new tasks) and modification of existing tasks, provides comfortable architecture for storage tasks and watchers in the project.

There is TARS-CLI in order to not install all dependencies all the time, when you are installing TARS. So, TARS is not a npm-package by itself. This decision was decided so that everyone can customize the builder as comfortable as possible for themselves. CLI — just simple interface for builder, which includes all dependencies for TARS.

It is strongly recommended to use TARS-CLI for developing from with moment.

You can install TARS-CLI via NPM. More info in project's repository.

Basic features

Listed below are just a little part of the features. In fact builder has much more.

  • Jade or Handlebars as html-templater. You can also use a regular html. Read more in docs.
  • Using json (js-object actually, which can be described in json) to transfer data in templates (optional, but it is very cool thing that will let you to rid of copypast). Read more in docs.
  • You can use ES6 (and some experimental features from ES7) right now. More info.
  • SCSS (SASS), LESS or Stylus as a preprocessor for css. Also it includes a small set of mixins. Sourcemaps is included. You can use .scss and .sass extension then scss is selected as preprocessor. You can use .scss and .sass files together. Read more in docs. PostCSS with autoprefixer is supported by default and it is really easy to use additional plugins for PostCSS.
  • No external libraries and plugins (except html5shiv). Yes, this is a feature because you can choose library for using. Sourcemaps for JavaScript is included.
  • Chokidar module is used for watching files
  • Sharing of markup from your local computer to an external web, optional. And of course it has a livereload in browser (and not just locally) + GUI to control panel for devices, on which markup was shearing.
  • You can easily add new tasks and watchers. There are several examples of how to create and use a new task or watcher inside the TARS. Thereby, it is really easy to add any task from your builder to TARS or integrate TARS into your project.
  • Smart work with images. First of all with vector(svg). There will be no more hell with markup for screens with high pixel density. TARS supports two workflows of working with SVG: SVG-sprites and SVG-symbols.
  • Several modes of assembly (common, with minified files, with hash in the title of css- and js-files for deploy).
  • Creating archive with the ready build.

Documentation

It is important! All examples in documentation use the default settings.

Installation

Attention, TARS-CLI is the preferably way to work with TARS. It is more comfortable, fast to work with TARS-CLI. In case of using TARS with TARS-CLI all installation steps are not necessary!

You need to install Node.js with version equal to 4.x.x or higher. If you use Node.js version 5.x.x, please, be sure, that you use npm version 3.x.x and higher. Otherwise update npm by using command:

npm i -g npm

For Windows you have to do some more steps:

  • navigate to C:\Program Files (x86)\nodejs or C:\Program Files\nodejs via cmd.exe or any available terminal. The path depends on how Node.js was installed;
  • run command npm install npm@latest.

If you get a Permission denied or Error: EACCES error, you should run the previous command again in sudo.

Next you need to install gulp globally. (You may need rights of superuser or administrator).

npm install -g gulp

Download TARS and unzip it in the working directory. Then install dependencies. Command is run from a folder with TARS files (usually it is a tars-master).

npm install

If not all of the dependencies have been installed, the last operation must be repeated.

After installing of all dependencies you need to open tars-config (detailed description of the options are here) and set up the project for yourself. In that config file, you can select the templater, css-preprocessor, using the notifications, folder names for different static and etc. After setting up the project, execute the following command:

gulp init

Attention, TARS-CLI is the preferably way to work with TARS. Init command is available in TARS-CLI too.

This command will create the basic file structure, download tasks for selected templater and css-preprocessor. Everything is ready, make it work! :)

Basic commands

Attention, TARS-CLI is the preferably way to work with TARS. It is more comfortable, fast to work with TARS-CLI. All commands are available and described in TARS-CLI, so use only TARS-CLI for working with your project. TARS used Gulp to start tasks, when CLI was not created.

gulp init — initializes project with the specified settings in the tars-config. Creates a file structure.

gulp re-initThis command is depricated! reinitialize the project with specified settings in the tars-config. It is proposed to use this command if you initialize the project with incorrect options. Attention, files from pages and static folder will be deleted.

gulp or gulp build — make project assembly. There not minimized files are connected. Type of assembly depends on the transmitted keys with this command. Available keys:

  • --min – minimized files connected to html.
  • --release – minimized files connected to html whose names have hash. This mode is useful if you are directly trying to deploy ready markup to the server.

gulp dev — initialization of builder in development mode. Dev-version of the project is created without any minifications. Also it launches watchers for project files. Available keys:

  • --lr – initialization livereload (live page reloads with changes in project files), if it is included in the configuration of the project.
  • --tunnel – initialization project with sharing markup to an external web.

The link will be shown in the console. There also will be a link to control panel for devices on which markup was sharing.

gulp build-dev — generation of dev-version of the project without watchers.

Keys are available in any mode of assembly:

  • --ie8 – to include in the build styles for ie8.
  • --ie9 – to include in the build styles for ie9.
  • --ie – to include in the build styles for ie8 and ie9.

Documentation

It is important! All examples in documentation use the default settings.

Last changes

All recent changes are available at the link: changelog.

If you have a question you can write in gitter or mail [email protected]

Bugs and feature-request here: issues.

circles's People

Contributors

b-ff avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.