GithubHelp home page GithubHelp logo

ng-module-parser's Introduction

ng-module-parser

This js module is used for extracting information about a js file that 
contains an AngularJS Module where the components/directives/services/etc. 
are declared

The result is an object with the follow keys:

  • Components
  • Services
  • Factories
  • Directives
  • Constants

And also will extract the module dependences.

Installation

Using NPM

npm install ng-module-parser

USE:

Example module.js:

// Módulos
import angular from 'angular';
import angularFilter from 'angular-filter';
import modal from '../modal/module';
import '../../services/acceso-cliente/module';
import dragDropRelation from '../drag-drop-relation/module';
import inputTypeMonto from '../../directives/input-type-monto/module';
import pubSub from '../../services/pub-sub/module.js';
import stepper from '../stepper/module';
import impresion from '../impresion/module.js';
import filtroBigNumber from '../../filters/big-number';
import inputMenorQue from '../../directives/input-menor-que';

import configuracionTipoUsuario from './configuracion-tipo-usuario';
import configuracionCuentas from './configuracion-cuentas';
import configuracionEmpresas from './configuracion-empresas';
import configuracionFacultades from './configuracion-facultades';
import configuracionFirmantes from './configuracion-firmantes';
import configuracionUsuariosDestino from './configuracion-usuarios-destino';
// Componentes
import usuariosFacultamientoComp from './component';
import aplicacionFacultamiento from './aplicacion-facultamiento/component';
import montosPorCuenta from './montos-por-cuenta/component';
import limitesOperables from './limites-operables/component';
import firmantesPersonas from './firmantes-personas/component';

// Servicios
import usuariosFacultamientoServ
  from '../../services/usuarios-facultamiento/module';
import perfilesPatron from '../../services/perfiles-patron/';
import facultades from '../../services/facultades';
import consultaFirmantes from '../../services/consulta-firmantes/';
import etiquetas from './../../services/etiquetas';

export default angular
  .module('usuariosFacultamiento', [
    'accesoCliente',
    angularFilter,
    impresion,
    stepper,
    modal,
    pubSub,
    dragDropRelation,
    inputTypeMonto,
    usuariosFacultamientoServ,
    configuracionTipoUsuario,
    configuracionCuentas,
    configuracionEmpresas,
    configuracionFacultades,
    configuracionFirmantes,
    configuracionUsuariosDestino,
    perfilesPatron,
    facultades,
    consultaFirmantes,
    etiquetas,
    filtroBigNumber,
    inputMenorQue,
  ])
  .component('usuariosFacultamiento', usuariosFacultamientoComp)
  .component('firmantesPersonas', firmantesPersonas)
  .component('montosPorCuenta', montosPorCuenta)
  .component('limitesOperables', limitesOperables)
  .component('aplicacionFacultamiento', aplicacionFacultamiento)
  .name;

Parsing:

const fs = require('fs');
const moduleParser = require('./index.js');
let program = fs.readFileSync('./example_module.js', 'utf8');

let infoModule = moduleParser.parse(program);
console.log(JSON.stringify(infoModule, null, 2));

Result infoModule:

{
  "name": "usuariosFacultamiento",
  "components": [
    "usuariosFacultamiento",
    "firmantesPersonas",
    "montosPorCuenta",
    "limitesOperables",
    "aplicacionFacultamiento"
  ],
  "dependencies": [
    "accesoCliente",
    "angularFilter",
    "impresion",
    "stepper",
    "modal",
    "pubSub",
    "dragDropRelation",
    "inputTypeMonto",
    "usuariosFacultamientoServ",
    "configuracionTipoUsuario",
    "configuracionCuentas",
    "configuracionEmpresas",
    "configuracionFacultades",
    "configuracionFirmantes",
    "configuracionUsuariosDestino",
    "perfilesPatron",
    "facultades",
    "consultaFirmantes",
    "etiquetas",
    "filtroBigNumber",
    "inputMenorQue"
  ],
  "directives": [],
  "services": [],
  "factories": [],
  "constants": []
}

ng-module-parser's People

Contributors

luisegr avatar

Watchers

James Cloos 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.