Skip to content

Sistema de administración de notas con diferentes interfaces

License

Notifications You must be signed in to change notification settings

rtro-dev/Sistema-Notas

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Sistema-Notas

Sistema de administración de notas con diferentes interfaces

Contenidos

  1. Servidor Docker
  2. Javascript en el servidor
  3. Html
  4. Javascript en el cliente
    4.1 Mapper
    4.2 Modules

1. Servidor Docker

Inicialmente tendremos un Dockerfile en el directorio del servidor como se muestra a continuación:

FROM debian:bullseye
RUN apt update
RUN apt install nodejs -y 
RUN apt install npm -y
RUN mkdir -p /home/node/app/
WORKDIR /home/node/app
RUN mkdir interfaces
COPY ./interfaces ./interfaces
COPY package.json ./
COPY interfaces ./
COPY index.js ./
RUN npm install
EXPOSE 3000
CMD [ "node", "index.js" ]

También contamos con un package.json:

{
    "name": "uiserver",
    "version": "1.0.0",
    "description": "Servidor UI para sistema de notas.",
    "main": "index.js",
    "type": "module",
    "scripts": {
        "test": "echo \"Error: no test specified\" && exit 1",
        "build": "docker build -t notes/uiserver .",
        "container" : "docker run --name uiserver -p 3000:3000 -d notes/uiserver"
    },
    "author": "",
    "license": "ISC",
    "dependencies": {
        "cors": "^2.8.5",
        "express": "^4.21.1"
    }
}

De esta forma, podemos construir una imagen y correr un contenedor con el servidor con estos dos comandos:

npm run build

npm run container

Por otro lado, en la parte de cliente, tenemos otro package.json con el que crear un contenedor con un servidor apache para ir viendo los cambios y haciendo pruebas en local:

{
    "name": "uiclient",
    "version": "1.0.0",
    "description": "UI client ",
    "main": "index.html",
    "scripts": {
        "test": "echo \"Error: no test specified\" && exit 1",
        "server" : "docker run -dit --name my-apache-app -p 8080:80 -v //c/Users/NombreUsuario/.../uiclient:/usr/local/apache2/htdocs/ httpd:2.4" //Esta dirección tendría que modificarse
    },
    "author": "",
    "license": "ISC"
}

Ejecución:

npm run server

2. Javascript en el servidor

index.js del servidor:

import express from 'express';
import cors from 'cors';
import { model1 } from './interfaces/model_1.js';

const appUI = new express();
appUI.use(cors());

appUI.get('/', (req, res) => {
    res.send(model1);
})

appUI.listen(3000, ()=>{
    console.log("UI Server running.")
});

Dentro hay otro directorio interfaces, done estará el archivo model_1.js con la estructura de datos a utilizar en formato json:

export const model1 = {
    panels: [
        {
            type: "title",
            panelName: "app",
            panelDescription: "Aplicación de Notas",
            panelWidth: "100%",
            panelHeight: "100%",
            cssData: "app_style",       // El nombre del estilo CSS, si tiene alguno específico
        }
    ],
    components: [
        {
            type: "title",
            father: "app",
            content: "Notas",
            position: "0,0"
        }
    ]
};

En esta estructura siempre es recomendable separar los elementos para evitar tener que hacer redundancias en el código, que cada uno tenga su tipo y que los hijos especifiquen su padre.

3. Html

En la parte de cliente está el siguiente index.html:

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <link rel="stylesheet" href="css/styles.css">
        <title>Notas</title>
    </head>
    <body>
        <div id="main_container">
            hola
        </div>
        <script type="module" src="js/index.js"></script>
    </body>
</html>

4. Javascript en el cliente

La parte de cliente tiene el siguiente index.js:

import { HttpFetch } from "./modules/HttpFetch.js";
import { UIBuilder } from "./modules/UIBuilder.js";
function hola(a){
    console.log('Datos listos' + a)
}

const httpFetch = new HttpFetch('http://localhost:3000');
httpFetch.obtenerUI('', (datos) => {
    UIBuilder.build(datos);
});

4.1 Mapper

El cliente tiene un mapeador, para que si el código html sufre modificaciones se pueda adaptar.

export const PanelMapper = (panel) => {
    const div = document.createElement("div");
    for (const key in panel) {
        switch(key) {
            case 'panelName': 
                div.setAttribute("id",panel[key]);
                break;
        }
    }
    return div;
};

4.2 Modules

El cliente cuenta con tres módulos, dos para formas de conexión distinta y uno para construir los elementos html.

Http.js (conexión)

export class Http {
    constructor (base_url) {
        this.base_url = base_url;
        this.last_error = null;
    }

    obtenerUI(route){}
}

HttpFetch.js (conexión)

import { Http } from "./Http.js";

export class HttpFetch extends Http {
    obtenerUI(route, callBackOnSuccess){
        fetch(`${this.base_url}/${route}`).then(
            (response) => {
                response.json().then(
                    (data) => {
                        callBackOnSuccess(data);
                    }
                , (error) =>{
                    this.last_error = error;
                })
            }
        , (error) =>{
            this.last_error = error;
        }
    )}
}

UIBuilder.js (constructor)

import { PanelMapper } from "../mapper/PanelMapper.js";

export class UIBuilder {
    static build(data) {
        console.log(data.panels);
        const contenedor = document.getElementById("main_container");
        data.panels.forEach(element => {
            const div = PanelMapper(element);
            contenedor.appendChild(div);
        });
    }
}

About

Sistema de administración de notas con diferentes interfaces

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •