Mostrando entradas con la etiqueta Sencha Cmd. Mostrar todas las entradas
Mostrando entradas con la etiqueta Sencha Cmd. Mostrar todas las entradas

jueves, 9 de noviembre de 2017

Despliegue Rápido de Aplicaciones WEB

Llevo ya dos años desarrollando pequeñas aplicaciones con Extjs desde  la versión 4.2 hasta la más reciente 6.0.1 en sus versiones OpenSource, he integrado este framework con PHP, ASP MVC y Java Servlet.

En el mercado nos encontramos con infinidad de aplicaciones que nos ayudan a optimizar el desarrollo de aplicaciones web gratis y de pago, pero muy pocas desarrolladas con Extjs como capa de presentación.

Es por eso que me di en la tarea de desarrollar una herramienta que nos ayude a optimizar los tiempos de desarrollo de aplicaciones web con Extjs.

EAS es un sistema creado para optimizar el desarrollo y despliegue de aplicaciones Web basadas en las siguientes tecnologías: Extjs, Php, Java, JAsperReports y PostgreSql

TECNOLOGIA
DESCRIPCION
ExtJs 6.0.1
Ext JS es una biblioteca de JavaScript para el desarrollo de aplicaciones web interactivas usando tecnologías como AJAX, DHTML y DOM.
Ext JS soporta todos los navegadores web más importantes, incluyendo:
PHP
Es un lenguaje para programar scripts del lado del servidor, que se incrustan dentro del código HTML. Este lenguaje es gratuito y multiplataforma.
Un lenguaje del lado del servidor es aquel que se ejecuta en el servidor web, justo antes de que se envíe la página a través de Internet al cliente
JAsperReports
JasperReports es una biblioteca de creación de informes que tiene la habilidad de entregar contenido enriquecido al monitor, a la impresora o a ficheros PDF, HTML, XLS, CSV y XML.
Está escrito completamente en Java y puede ser usado en gran variedad de aplicaciones de Java, incluyendo J2EE o aplicaciones web, para generar contenido dinámico.
Su propósito principal es ayudar a crear documentos de tipo páginas, preparados para imprimir en una forma simple y flexible.
Java
Java es un lenguaje de programación de propósito general, concurrente, orientado a objetos que fue diseñado específicamente para tener tan pocas dependencias de implementación como fuera posible. Su intención es permitir que los desarrolladores de aplicaciones escriban el programa una vez y lo ejecuten en cualquier dispositivo (conocido en inglés como WORA, o "write once, run anywhere"), lo que quiere decir que el código que es ejecutado en una plataforma no tiene que ser recompilado para correr en otra
PostgreSql

El objetivo principal de “EAS”, es brindar a los usuarios las herramientas necesarias para que puedan desarrollar sus propios ERP’s, la herramienta cuenta con las funcionalidades básicas que debería tener todo ERP, las cuales son:
  •          Control de Usuarios
  •          Registro de aplicaciones(módulos)
  •          Registro de funciones(formularios)
  •          Configuración dinámica de menús
  •          Configuración dinámica de Perfiles de Usuarios
  •          Configuración dinámica de Solicitudes (Informes, invocación de procesos almacenados o invocación de método de contenidos en una clase Java/Php).
  •          Configuración dinámica de Grupos de Solicitudes(Encapsulación de informes)


A cada nueva aplicación en “EAS” le corresponde un esquema de Base de Datos, este esquema se crea de forma automática al registrar una nueva aplicación, así como se crean la estructura de carpetas en el servidor, la siguiente imagen muestra la esta estructura:


EAS también nos proporciona herramientas para crear objetos en la base de datos, así como la generación dinámica de ABM’s.

El motor de solicitudes de EAS permite generar varios reportes a la vez, el usuario solo debe seleccionar la solicitud que dese ejecutar y enviarla al servidor,  el motor se encarga de ejecutar la solicitud he informar al usuario del estado de la misma, así de esta forma no tenemos que esperar a que termine el proceso para poder hacer otras actividades dentro del sistema.

La siguiente imagen explica la estructura interna de EAS en el servidor:


A continuación les dejo los manuales oficiales de la aplicación:

Manual del Módulo Administrador: Version PDF

Manual del Módulo Desarrollador: Version PDF

usuario: admin
clave: admin

Videos

A continuación te dejo los enlaces a los videos tutoriales que he preparado con respecto a la herramienta.

Configurar una Aplicación(nuevo modulo)..?
Crear Objeto de Base de datos con EAS…….?
Crear modelos y controladores………………….?
Crear ABM y Registrar función (usando el módulo DEV)…………………..?
Crear ABM y Registrar función (de forma manual)…………………..?

Crear una solicitud tipo “PROC”…………………?
Crear una solicitud tipo “IReport”…………………?
Crear una solicitud tipo “JAVA”….…………………?
Crear un grupo de Solicitudes……….………………?
Crear un menú……………………….…………………….?
Crear un Perfil………………………………………………?
Crear una empresa……………………………………….?
Crear un usuario…………………………………………..?
Crear juego de valor tipo “TABLA”………………..?
Crear juego de valor tipo “INDEPENDIENTE”..?
Ejecutar una solicitud……………………………………?


martes, 7 de abril de 2015

Paquetes con Sencha Cmd

Los paquetes en Sencha, son la mejor forma de compartir código JavaScript entre varias aplicaciones con diferentes tecnologías(Extjs y Sencha Touch).En este articulo veremos como aprovechar esta funcionalidad junto a nuestras aplicaciones Ext JS.


Preparando el escenario

La mejor forma de trabajar con Sencha Cmd y la generación de aplicaciones es atraves de los espacios de trabajo "Workspace", un espacio de trabajo no es mas que un directorio determinado dentro de nuestra PC, donde podemos encontrar elementos comunes tales como: aplicaciones,paquetes y el frameworks de ExtJs, esta no es la única forma de trabajar con Sencha Cmd, pero de lejos es la mejor para poder tener todo centralizado en un solo lugar.

Para este artículo, vamos a crear un espacio de trabajo de prueba en una carpeta vacía:

D:\extjs> sencha generate workspace .
Sencha Cmd v5.0.1.231
...


Ahora vamos a crear dos aplicaciones en nuestro nuevo espacio de trabajo,para ello nos dirigimos, en la consola de comando ejecutamos :

D:\extjs> sencha -sdk D:\Instaladores\ext-4.2.2-gpl\ext-4.2.2.1144 generate app ExtApp1 extApps/app1
Sencha Cmd v5.0.1.231
...

D:\extjs> sencha -sdk ext generate app ExtApp2 extApps/app2
Sencha Cmd v5.0.1.231
...

Podemos observar en el primer comando se puso la dirección absoluta del SDK de ExtJs, el cual no esta en nuestro "Workspace", esta instrucción crea nuestra aplicación y hace una copia local del SDK en nuestro worksape, es por esto que en el segundo comando se apunta a este para crear la segunda aplicación.

Ahora, tenemos un área de trabajo, un subconjunto de Ext JS y dos aplicaciones vacías en una estructura de carpetas que se ve así:

extjs/
    ext/             (Una copia con los archivos necesarios de Ext JS)
        packages/    (Paquetes proporcionados por Ext JS)
    extApps/
        app1/
        app2/
    packages/        (Carpeta para paquetes que no son del framework)

Vamos a Generar un paquete

Los paquetes pueden ser generados de forma similar a las aplicaciones, así:

D:\extjs> sencha generate package common
Sencha Cmd v5.0.1.231
...

La diferencia clave es que el nuevo paquete se coloca en la carpeta de "packages":

extjs/
    ...
    packages/
        common/
            resources/
            sass/
            src/
            package.json
            ...

ahora crearemos un archivo que sobrescriba la clase "Ext.form.field.Text", la dirección del archivo sera la siguiente:

el contenido de este archivo sera el siguiente :


Ahora vamos a utilizar el paquete en el proyecto app1, para ello en el archivo "app.json" en la seccion requires ponemos lo siguiente:


con esto nos estamos asegurando que nuestra aplicación cargara el contenido de este maquete, el sobrescribe la clase "Ext.form.field.Text".

Ahora actualizamos nuestra aplicación :

luego la ejecutamos:


y el resultado sera el siguiente:


como ahora si quisiéramos utilizar este mismo componente en la aplicación "app2", bastaría con modificar su respectivo archivo "app.json" incluyendo el paquete "common" y listo.

esta es una de las principales funcionalidades de trabajar con espacios de trabajo y paquetes.

eso es todo amigos espero que el articulo se de utilidad.











File sharing system in PHP free code (Veno File Manager v4.2.7)

  File sharing system in PHP free code (Veno File Manager v4.2.7) Download: veno-file-manager-v427 File sharing system in PHP free code ===...