Skip to content

YeisonGomez/ng-math-factory

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

52 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ng-math-factory

ng-math-factory es una librería que soluciona problemas matemáticos con AngularJS.

Instalación

$ bower install ng-math-factory --save

Esta acción ( --save ) es para agregarla como dependencia en el archivo bower.json.

La librería JavaScript debe agregarse en el index.html de tu proyecto:

<script src="../ng-math-factory/dist/ng-math-factory.min.js"></script>

Ahora debe inyectar la librería en su módulo app.js:

var app = angular.module('myapp', ['ng-math-factory']);

Uso

Paso 1. Obtener métodos

app.controller('appCtrl', function($scope, $math) {
	//Obtener métodos proporcionado por ng-math-factory
    $scope.methods = $math.getMethods();

	//Función para obtener el metodo seleccionado.
    $scope.selectMethod = function(module, sub){
    	module = "example";
    	sub = {name: "Sumar", in: "formula"};

		$scope.method_current = { name: module, sub: sub.name };
		if(sub.in == "formula"){
			//Obtener un String con la formula a resolver
		}else if(sub.in == "xy"){
			//Obtener un arreglo de JSON especificado en la descripción de in
		}
    }
});

$math.getMethods()

Retorna los métodos que proporciona ng-math-factory. Los datos se obtiene en formato JSON con esta estructura:

[{
    name: 'example',
    sub: [
        { name: 'Sumar', in : 'formula', readme: "bower_components/ng-math-factory/src/example/readme/sumar.html" },
        { name: 'Restar', in : 'formula', readme: "bower_components/ng-math-factory/src/example/readme/restar.html" },
        { name: 'Multiplicar', in : 'formula', readme: "bower_components/ng-math-factory/src/example/readme/multiplicar.html" }
    ]
}]
  • name - Nombre del modulo.
  • sub - Arreglo de JSON de los sub-modulos.
    • name - Nombre del sub-modulo.
    • in - Tipo de entrada que espera el sub-modulo (ejemplo).
    • readme - Ruta de un html que contiene una explicación del sub-modulo.

in

Es el tipo de entrada que se va utilizar:

1. formula: Se define que el método solicita un string con una formula a resolver ("3 + 4 - 6 * 5 / 2").
2. xy: Se define que el método espera un arreglo de JSON de esta forma:

[
	{x: 1, y: 2},
	{x: 3, y: 4},
	{x: 5, y: 6}
]

Paso 2. Renderizar métodos

<div ng-repeat="module in methods">
	<h3>{{module.name}}</h3>
	<button ng-repeat="sub in module" ng-click="selectMethod(module.name, sub)">{{sub.name}}</button>
</div>

Utilizamos la función para seleccionar el método a utilizar.

Paso 3. Resolver

app.controller('appCtrl', function($scope, $math) {

    $scope.solution = function(input) {
        $math.resolve($scope.method_current, input, "/bower_components", function(data, html) {
            $scope.resolveHTML = html.resolve;
            $scope.resolveGraphics = html.graphics;
            $scope.solveProblem = data;
        });
    }
});

$math.resolve(method_current, input, route, callback)

Parametros
Parametro Tipo Detalle
method_current JSON Es el método actualmente seleccionado.
input Object Son los datos que solicita el método actual un JSON o un String.
route String Es la ruta donde esta la librería ng-math-factory actualmente.
callback function Función donde se envia la respuesta.

$scope.method_current ejemplo:

{ name: "mi_nuevo_modulo", sub: "Sumar" }
Retorna
  • data - Es la solución de la formula solicitada en formato JSON.
  • html - Es un JSON con dos rutas de un archivo html con la respuesta ya renderizada, ejemplo:
{
	resolve: "lib/ng-math-factory/src/example_module/view_example_module.html",
	graphics: "lib/ng-math-factory/src/example_module/view_graphics.html"
}

Paso 4. Renderizar la respuesta

<div ng-include src="resolveHTML"></div>
<div ng-include src="resolveGraphics"></div>

Contribuir

Para contribuir y agregar nuevos módulos a ng-math-factory, debes tener conceptos basicos de Angular 1 y highcharts-ng. Siguiendo unos cuantos pasos la implementación de un nuevo módulo será muy sencillo y funcional.

Para hacer pruebas podras utilizar el demo, modificando la librería y la aplicación automáticamente tomara la actualización corriendola en local.

Paso 1. Adjuntar mi_nuevo_modulo

  • En el editor de código ubicarse en: /ng-math-factory/src/
  • Crear una carpeta con el nombre del nuevo módulo: /ng-math-factory/src/mi_nuevo_modulo/
  • Dentro del nuevo módulo crear 3 archivos, ejemplo:
    • mi_nuevo_modulo.js
    • view_mi_nuevo_modulo.html
    • view_graphics.html (Procurar no editar el nombre) //Opcional
    • readme //Recomendado

Paso 2. Hacer push

En el archivo /ng-math-factory/src/methods.js agregar el nuevo modulo con sus sub-modulos.

(function() {
'use strict';

    angular.module('math.methods', []).factory("$methods", function() {
    	var routeLib = "/ng-math-factory/src";

		return [
			{
		        name: "Ajuste de curvas",
		        sub: [
		            { name: "Mínimos cuadrados", in : "xy", readme: routeLib + '/adjust_curve/readme/minimo_cuadrado.html' }
		        ],
		       	html: { resolve: "/adjust_curve/view_adjust_curve.html", graphics: "/adjust_curve/view_graphics.html" },
		        factory: "adjustCurve"		        
		    },
			{
				name: "mi_nuevo_modulo",
				sub: [
					{name: 'Sumar', in: 'formula', readme: routeLib + '/mi_nuevo_modulo/readme/sumar.html'}
					{name: 'Restar', in: 'formula', readme: routeLib + '/mi_nuevo_modulo/readme/restar.html'}
				],
				html: { 
					resolve: "/mi_nuevo_modulo/view_mi_nuevo_modulo.html", 
					graphics: "/mi_nuevo_modulo/view_graphics.html" 
				},
				factory: "miNuevoModulo",
				libs: [ /*Opcional*/
		        	'/mi_nuevo_modulo/lib/libreria.js'
		        ]
			}
		]
	});
})();
  • name - Nombre del modulo.
  • factory - Nombre de la factoria que contiene el modulo (ver Paso 3).
  • html - Ruta del HTML de la solución personalizada (ver Paso 5).
  • sub - Arreglo de JSON de los sub-modulos.
    • name - Nombre del sub-modulo.
    • in - Tipo de entrada que espera el sub-modulo (ejemplo).
    • readme - Ruta de un html que contiene una explicación del sub-modulo.

Paso 3. Crear mi factoria

En /ng-math-factory/src/mi_nuevo_modulo/mi_nuevo_modulo.js agregar.

(function() {
    'use strict';
    angular.module('math.mi-nuevo-modulo', []).factory('miNuevoModulo', function() {
        return {
        	"Sumar": add, //Sumar tiene que coincidir con el nombre de los sub-modulos
        	"Restar": substract
        };

		function add(input) {
            return eval(input);
	   	}

		function substract(input){
			return eval(input);
		}
	});
})();

Nota: Para el uso de una dependencia más, deben agregar el script dentro de la carpeta lib, que previamente debe ser creada dentro del nuevo módulo.

Paso 4. Agregar mi_nuevo_modulo

En /ng-math-factory/src/math-factory.js agregar.

angular.module('ng-math-factory', 
[
    'math.methods', 
    'math.mi-nuevo-modulo'
])
.factory('$math', 
[
    '$methods', //No editar
    'adjustCurve', //No editar los otros modulos
    'miNuevoModulo',
    function($methods, adjustCurve, miNuevoModulo) {
    	//No editar
    }]);

Paso 5. Respuesta

La solución en pantalla para el usuario es editable por el contributor. Para personalizar la vista y mostrar la solución del nuevo módulo se debe agregar en /ng-math-factory/src/mi_nuevo_modulo/view_mi_nuevo_modulo.html

<h1>La solución del problema es:</h1>
<h2>{{solveProblem}}</h2>

Nota: solveProblem es la variable que contiene la respuesta del script proporcionado por el contributor (El nombre de la variable no es editable).

Paso 6. README

Los métodos ofrecidos en el nuevo modulo, deben tener una breve explicación del método y un ejemplo de la formula que se solicita al usuario. El archivo se solicita como un HTML agregado dentro de la carpeta /mi_nuevo_modulo/readme/, se recomienda tener un archivo readme por cada método del modulo.

<p>Este método se utiliza para sumar</p>
<h2>Ejemplo:</h2>
<p>4 + 5</p>

#Agregar gráfica con highcharts-ng#

Para agregar una grafica se debe llevar a cabo en la respuesta del script, ejemplo:

/ng-math-factory/src/mi_nuevo_modulo/mi_nuevo_modulo.js

function add(input) {
	var solution = {
		problem: metodo_libreria(input),
		miGrafica: []
	};

	//chartConfig son las configuraciones que solicita la librería highcharts-ng
	solution.miGrafica = chartConfig; 
    return solution;
}

/ng-math-factory/src/mi_nuevo_modulo/view_graphics.html

<highchart id="chart1" config="solveProblem.miGrafica"></highchart>

Nota: solveProblem no es editable.

Probar y depurar código con gulp

Para probar la libreria en el demo se debe modificar directamente la libreria desde la carpeta /www/lib/ng-math-factory/src y acceder desde la terminal, luego ejecutar:

$ gulp minify

El comando quedara escuchando los cambios que se hagan en los scripts de la librería.

Nota: Correr el demo con ionic serve, y refrescar la página cuando hay cambios en la librería.

About

Soluciones matemáticas con Angularjs

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •