Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/fintank/scaffoldv2

** No longer maintained ** Cross Platform web development with Angular 2, Ionic 2, Gulp. CI pipeline configurations included. MIT License. Created by Fintan Kearney.
https://github.com/fintank/scaffoldv2

angular gulp ionic minification protractor typescript

Last synced: 3 months ago
JSON representation

** No longer maintained ** Cross Platform web development with Angular 2, Ionic 2, Gulp. CI pipeline configurations included. MIT License. Created by Fintan Kearney.

Awesome Lists containing this project

README

        

# Scaffold JS 2.0

[![Build Status](https://travis-ci.org/FintanK/scaffoldV2.svg?branch=master)](https://travis-ci.org/FintanK/scaffoldV2)

** I am no longer maintaining this repo.**

NPM Module http://www.npmjs.com/package/generator-scaffold-web

The web changes a lot in a year!

**Note:** Angular 2 and Ionic 2 are in Beta right now. Things can and probably will be refactored later.

Scaffold V2 is completely re-written from the ground up to use Angular 2 as well as harnessing Ionic 2.
The project aims to follow best practices in frontend web development with a component based approach, comprehensive testing (Unit and Behavioural) and the optimization of frontend assets through the proven techniques of concatentation. minification and compression.

There will be automated processes to ensure that your project's data is as contextual as possible both in the domain of semantic markup and data as well as platform integration out of the box. The web isn't just in the browser anymore.

Template configurations are also included to allow you to easily set up things like docker containers, Travis CI buils, IDE configurations and code quality tools.

This project will be published as an NPM module and Yeoman generator to allow for modularity and reusability. The generator will contain options for customizing the architecture of your application.

# Ionic 2 http://ionicframework.com/docs/v2/

- Hybrid app development
- Updated design changes
- Simplicity using a component model
- Great choice of components
- No router required but still works with the router component from Angular,
- Lots of customizable components developed for cross platform compatibility,
- Completely modular styles.
- Native scrolling for hybrid apps,
- Material design
- Over 900 icons and much more!
- Ionic native plugins for access to the user's device and hardware. GPS, Bluetooth, Camera, NFC etc.
- Gulp, SASS (CSS Preprocessor), CommonJS and a new module loader out of the box. No longer using bower.
- Web animations API! https://w3c.github.io/web-animations/
- Ionic CLI

# Features

- Angular 2 https://angular.io ![](http://www.industrysalestax.com/images/green_checkmark_small.gif)
- Ionic 2 hybrid app development. Package your web app easily for Android and IOS. ![](http://www.industrysalestax.com/images/green_checkmark_small.gif)
- Gulp ![](http://www.industrysalestax.com/images/green_checkmark_small.gif)
- Livereload http://livereload.com ![](http://www.industrysalestax.com/images/green_checkmark_small.gif)
- Browserify http://browserify.org ![](http://www.industrysalestax.com/images/green_checkmark_small.gif)
- SASS http://sass-lang.com/ ![](http://www.industrysalestax.com/images/green_checkmark_small.gif)
- CSS and JS Concatenation and Minification ![](http://www.industrysalestax.com/images/green_checkmark_small.gif)
- Automatic CSS Vendor prefixing to support older browers ![](http://www.industrysalestax.com/images/green_checkmark_small.gif)
- CSS and JS Lints ![](http://www.industrysalestax.com/images/green_checkmark_small.gif)
- HTML minification for production builds if required. Squeeze every last Kb out of your app. ![](http://www.industrysalestax.com/images/green_checkmark_small.gif)
- Travis configurations to automate and test builds before deployment http://travis-ci.org ![](http://www.industrysalestax.com/images/green_checkmark_small.gif)
- Editorconfig for code styling http://editorconfig.org/ ![](http://www.industrysalestax.com/images/green_checkmark_small.gif)
- Auto generated cache manifest file (**Note** This has now been replaced by an offline service worker for providing an offline experience first. This is now better web practice as cache manifest files can be tricky to manage for different sites http://alistapart.com/article/application-cache-is-a-douchebag) ![](http://www.industrysalestax.com/images/green_checkmark_small.gif)
- Manifest.json file ![](http://www.industrysalestax.com/images/green_checkmark_small.gif)
- Further compression of assets using express in gzip format (To do)
- Development and production builds with a watcher to kick off builds when changes are made in development ![](http://www.industrysalestax.com/images/green_checkmark_small.gif)
- Native notification when builds are completed. ![](http://www.industrysalestax.com/images/green_checkmark_small.gif)
- Builds run against pagespeed for feedback on app performance ![](http://www.industrysalestax.com/images/green_checkmark_small.gif)
- Favicons, IOS splash / homescreen icons, Android icons and Windows 8 Tile Icons auto-generated.
- Protractor for Testing https://angular.github.io/protractor/#/ ![](http://www.industrysalestax.com/images/green_checkmark_small.gif)
- Karma and Jasmine Testing https://karma-runner.github.io/0.13/index.html http://jasmine.github.io ![](http://www.industrysalestax.com/images/green_checkmark_small.gif)
- Gulp task listing (just type 'gulp list') ![](http://www.industrysalestax.com/images/green_checkmark_small.gif)
- Sitemap generation ![](http://www.industrysalestax.com/images/green_checkmark_small.gif)

# What I'm excited about
- Angular 2! Improved and intuitive templating with better code completion in your IDE.
- Ionic 2! Build apps for Android and IOS with web technologies.
- Ionic Native! Only add the components you need.
- Phonegap build! Take the hassle out of packaging your app for the Google Play and/or the IOS app store.
- Builds using Travis! Automate builds and tests for every change ensuring code quality into the future.
- Web Components!
- Shadow DOM!
- HTML Imports!
- ES6!

# Directory structure

.
+-- app
+-- gulp-tasks
| +-- css-tasks.js
| +-- html-tasks.js
| +-- img-tasks.js
| +-- js-tasks.js
| +-- performance-tasks.js
+-- hooks
+-- platforms
+-- plugins
+-- resources
+-- tests
+-- www
+-- .csslintrc
+-- .editorconfig
+-- .gitattributes
+-- .gitignore
+-- .npmignore
+-- .travis.yml
+-- config.xml
+-- gulpfile.js
+-- index.html
+-- ionic.config.json
+-- karma.conf.js
+-- package.json
+-- protractor.config.js
+-- README.md

# Installation

> npm install -g gulp

> npm install -g ionic@beta

> npm install -g protractor

> npm install -g cordova

# Command Line

The majority of build related tasks are executed using the gulp cli tool.
For a full list of available commands enter..

> gulp list

The ionic cli tool is also of course available. For a full list of available commands..

> ionic -h

# Adding builds for IOS and Android

On IOS

> npm install -g ios-sim

> ionic platform add ios
> ionic platform add android

# Running the application

> ionic serve

# Protractor Tests

The webdriver-manager is a helper tool to easily get an instance of a Selenium Server running. Use it to download the necessary binaries with:

> webdriver-manager update

And start the selenium server with..

> webdriver-manager start

Ensure the Selenium server is running and the below command should execute the protractor specs.

> gulp test:protractor

# Karma Tests

Install Karma globally on your system

> npm install -g karma

You can then run your tests with

> gulp test:karma

# License

This source code has a MIT License.

# Further potential and reading Material

Build your first Web OS TV App
https://developer.lge.com/webOSTV/develop/web-app/getting-started/building-your-first-web-app-webos-tv/

Mozilla Packaged Apps
https://developer.mozilla.org/en-US/Marketplace/Options/Packaged_apps

Chrome Apps
https://developer.chrome.com/apps/about_apps

Authoring Yeoman Generators
http://yeoman.io/authoring/
http://code.tutsplus.com/tutorials/build-your-own-yeoman-generator--cms-20040

Ionic Lab
http://lab.ionic.io/

Ionic 2 Beginner utorial
http://www.gajotres.net/ionic-2-tutorial-lets-create-our-first-application/

Ionic Creator
http://ionic.io/products/creator

Protractor Documentation
https://angular.github.io/protractor/#/

Instanbul (Test Coverage)
https://github.com/gotwarlost/istanbul

Deployments from Cloud9 IDE (I use this for my personal projects)
https://docs.c9.io/docs/deploying-via-cli

Cloud9 Running an Ionic App
https://community.c9.io/t/running-a-ionic-2-application/3965

![](http://ionicframework.com/img/ionic-logo-blue.svg)
![](https://www.npmjs.com/static/images/npm-logo.svg)

## TO DO

- Offline first verification and tests
- Testing across as many platforms as possible.
- Demo functionality: NPM task to clear files.
- CLI generator integration.