/angularjs-styleguide-snippets

A set of snippets based on John Papa's AngularJS style guide.

Primary LanguageCoffeeScriptMIT LicenseMIT

angularjs-styleguide-snippets package

A set of AngularJS snippets based on John Papa's style guide.

Snippets

You can use the following snippets in JavaScript.

ngmodule
(function() {
    'use strict';

    angular
        .module('${1:module}', [
            '${2:dependencies}'
        ]);
})();
ngcontroller
(function() {
    'use strict';

    angular
        .module('${1:module}')
        .controller('${2:Controller}', ${2:Controller});

    ${2:Controller}.$inject = ['${3:dependencies}'];

    /* @ngInject */
    function ${2:Controller}(${3:dependencies}) {
        var vm = this;

        activate();

        function activate() {

        }
    }
})();
ngfactory
(function() {
    'use strict';

    angular
        .module('${1:module}')
        .factory('${2:factory}', ${2:factory});

    ${2:factory}.$inject = ['${3:dependencies}'];

    /* @ngInject */
    function ${2:factory}(${3:dependencies}) {
        var service = {
            ${4:function}: ${4:function}
        };

        return service;

        function ${4:function}() {

        }
    }
})();
ngcomponent
(function() {
          'use strict';

          angular
              .module('${1:module}')
              .component('${2:component}', ${2:component}());

          /* @ngInject */
          function ${2:component}() {
              var component = {
                  templateUrl: '${4:templateUrl}',
                  controller: ${5:Controller},
              };

              return component;
          }

          ${5:Controller}.$inject = ['${6:dependencies}'];

          /* @ngInject */
          function ${5:Controller}(${6:dependencies}) {

          }
      })();
ngdirective
(function() {
    'use strict';

    angular
        .module('${1:module}')
        .directive('${2:directive}', ${2:directive});

    /* @ngInject */
    function ${2:directive}() {
        var directive = {
            restrict: '${3:EA}',
            templateUrl: '${4:templateUrl}',
            scope: {
            },
            link: linkFunc,
            controller: ${5:Controller},
            controllerAs: 'vm',
            bindToController: true
        };

        return directive;

        function linkFunc(scope, el, attr, ctrl) {

        }
    }

    ${5:Controller}.$inject = ['${6:dependencies}'];

    /* @ngInject */
    function ${5:Controller}(${6:dependencies}) {
        var vm = this;

        activate();

        function activate() {

        }
    }
})();
ngservice
(function() {
    'use strict';

    angular
        .module('${1:module}')
        .service('${2:Service}', ${2:Service});

    ${2:Service}.$inject = ['${3:dependencies}'];

    /* @ngInject */
    function ${2:Service}(${3:dependencies}) {
        this.${4:function} = ${4:function};

        function ${4:function}() {

        }
    }
})();
ngfilter
(function() {
    'use strict';

    angular
        .module('${1:module}')
        .filter('${2:filter}', ${2:filter});

    function ${2:filter}() {
        return ${2:filter}Filter

        function ${2:filter}Filter(${3:params}) {
            return ${3:params};
        }
    }
})();
ngroute
(function() {
    'use strict';

    angular
        .module('${1:module}')
        .run(appRun);

    appRun.$inject = ['routerHelper'];
    /* @ngInject */
    function appRun(routerHelper) {
        routerHelper.configureStates(getStates());
    }

    function getStates() {
        return [
            {
                state: '${2:state}',
                config: {
                    url: '/',
                    templateUrl: 'app/${2:state}/${2:state}.html',
                    controller: '${2:State}Controller',
                    controllerAs: 'vm',
                    title: '${2:state}',
                    params: {
                        ${3:param}: ${4:value}
                    }
                }
            }
        ];
    }
})();
ngstate
{
    state: '${1:state}',
    config: {
        url: '/',
        templateUrl: 'app/${1:state}/${1:state}.html',
        controller: '${1:State}Controller',
        controllerAs: 'vm',
        title: '${1:state}',
        params: {
            ${2:param}: ${3:value}
        }
    }
}