Skip to content

A Yeoman generator for creating a modular and maintainable AngularJS project

License

Notifications You must be signed in to change notification settings

NechiK/generator-mma

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

73 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

This generator was deprecated. Please, use a new one angularjs-skeleton

Generator of AngularJS (1.x) project based on Hottowel generator.

For now it's on implementation stage so I am ready for your suggestions and remarks.

The key differences:

  • task for angular files generation (controllers, models, directives etc.)
  • REST API service
  • replaced LESS with SASS

Preconditions

  1. Install Node.js

  2. Install next NPM modules globally

    npm install -g bower gulp nodemon 
    
  3. Install Yeoman

    npm install -g yo
    

Quick Start

  1. Install generator-mma

    npm install -g generator-mma
    
  2. Create a new folder for project and step inside it

    mkdir myapp
    cd myapp
    
  3. Run the generator

    yo mma 
    
  4. Install dependencies

    npm install
    
  5. Start the project and begin coding

    gulp serve-dev
    

Project structure

/src
    /client
        /app
            /core <!-- main module and config files -->
            /routes <!-- route files -->
            /models <!-- factories -->
            /directives <!-- folder with directives -->
            
            <!-- folders with controllers and corresponding views -->
            /main
            /dashboard

REST API service

This service is based on $resource.

It stores the request promise during the time of its execution. It is done in order to block sending of same requests (requests with same url) with same parameters at the same time.

For example, resending form with identical data or using same APIs on different parts of your web app (e.g. you need to receive list of groups on the sidebar, however you have page for managing this groups which use the same API for receiving list of them. In this case this service makes request only once and other requests will receive promise at the end of the query execution )

To use APIService in controller, factory etc. you need to inject it.

angular
    .module('some_module')
    .controller('SomeController', SomeController)
    
SomeController.$inject = ['APIService'];

function SomeController(APIService) {}

###Methods

  • APIService.InitApiMethod(url, method)
Params Type Details
url string A parameterized URL template. Parameters should be prefixed by : as in /task/:task_id
method string Case insensitive HTTP method (e.g. GET, POST, PUT, DELETE)

####Returns

Type Details
object An APIService 'class' object with method run that takes only one parameter as object with request data (URL parameters shouldn't be prefixed by :) and returns promise when request will be finished
  • APIService.InitREST(url)
Params Type Details
url string A parameterized URL template. Parameters should be prefixed by : as in /task/:task_id

####Returns

Type Details
object An APIService 'class' object with set of methods (get, post, update, delete)

Gulp tasks

  • gulp generate

    Use gulp tasks listed below to generate your controllers, models, routes etc. easily.

    • gulp generate --controller controller_name - will add folder for controller (if it does not exist) and generate controller with name ControllerNameController
    • gulp generate --model model_name - will add file model_name.model.js to models folder and generate model with name ModelNameModel
    • gulp generate --model route_file_name - will add file route_file_name.route.js to routes folder
    • gulp generate --directive directive_name - will add file directive_name.directive.js to directives folder and generate directive with name directiveName
    • gulp generate --module module_name - - will add folder for module (if it does not exist) and generate module with module name module_name

    You can add --module [module_name] to all generators (except module generator) to attach a file to specified module. By default it will be attached to app.core

  • gulp vet

    Runs jshint and jscs on all javascript files.

  • gulp test

    Runs all unit tests (using Karma runner and next frameworks: mocha, chai and sinon).

  • gulp styles

    Compile scss files to CSS and copy to the build folder

  • gulp serve-dev

    Serves the development code and launches it in a browser. The goal of building for development is to do it as fast as possible, to keep development moving efficiently. This task serves all code from the source folders and compiles sass to css in a temp folder.

  • gulp build

    Copies all fonts, copies images and runs gulp html to build the production code to the build folder.

  • gulp serve-build

    Serve the optimized code from the build folder and launch it in a browser.

TODOs

  • writing more detailed documentation
  • replacing project commands (like npm install, gulp generate etc.) with make commands
  • add service for SOAP request architecture
  • unit tests implementation
  • generator tests implementation
  • issues fixing
  • move APIService to separate npm package

License

MIT

About

A Yeoman generator for creating a modular and maintainable AngularJS project

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published