JSReports/WMD/es/notes.w.md

177 lines
7.4 KiB
Markdown
Raw Permalink Normal View History

[[post_data {
"author" : "KyMAN",
"since" : 20220422,
"version" : 20220422
}]]
# Notas
Notas para no olvidarme del proyecto.
El proyecto se basa en una librería ECMA/JS la cual se llama JSReports como nombre de clase. Hay que
crear un objecto JSReports para poder trabajar con ella. En el caso de PDF depende de las librerías:
- [https://cdn.k3y.pw/js/html2canvas.min.js]
- [https://cdn.k3y.pw/js/jspdf.umd.min.js]
- [https://cdn.k3y.pw/js/purify.min.js]
Para poder empezar a trabajar con esta librería hay que esperar asíncronamente a que termine de
cargar mediante un Callback "on_ready"
```js
(js_reports = new JSReports(/* PARAMETROS DE ENTRADA */)).on_ready(() => console.log("Ya terminó de cargar xD"));
```
> [[! note NOTA]]: La librería requiere de un sitio donde poner componentes de forma temporal a modo
de caché. No le vale un DocumentFragment. Si no se le establece se pondrá por defecto BODY.
# PDF y DOC
El trabajo con esta librería cara los PDF y DOC es exactamente igual. Hay que llamar a un método
llamado "create" el cual permite crear este tipo de documentos. La librería se centra en que crees
un HTML4 y CSS2, aunque pueden ser adjuntadas cosas de HTML5 y XHTML, así como algunos parámetros
CSS3 y customizados cara cualquier a de las dos plataformas. La idea es construir plantillas para
cabeceras, pies y cuerpos en HTML y una única hoja de estilos general en CSS, lo que cubriría el 99%
del informe, luego hay ciertos parámetros que son necesarios establecer mediante valores.
Con esta información tenemos como parámetros de entrada un único valor que vendrá siendo un
diccionario el cual tiene los siguientes elementos:
> [[! note NOTA]]: Todas las medidas se toma en mm (Milímetros).
- **header**: Cabecera HTML.
- **body**: Cuerpo HTML.
- **footer**: Pié HTML.
- **css**: Estilos CSS.
- **type**: Extensión que determina si es "doc" o "pdf".
- **margin**: Margen general para cualquier lado.
- **margin_top**: Margen superior.
- **margin_right**: Margen derecho.
- **margin_bottom**: Margen inferior.
- **margin_left**: Margen izquierdo.
- **variables**: Variables para cubrir dentro de los HTML.
- **header_height**: Alto de la cabecera.
- **footer_height**: Alto del pié.
- **margin_header**: Margen de la cabecera.
- **margin_footer**: Margen del pié.
- **dpi**: DPI para marcar tamaños digitales en PX.
- **page_format**: Formato de página (A4, A3, A5, C5, Letter (L), etc.); o tamaño (alto y ancho).
El formato PDF requiere de embedar las fuentes con las que se vaya a trabajar en formato TTF, que es
el formato por defecto cara los OS. Dicho formato requiere de un archivo por estilo (Regular o
normal, Light, Bold, Italic, etc). Para embedar fuentes es necesario cubrir la variable "fonts" en
el diccionario de parámetros de entrada del objeto y se compone de un Array bidimensional donde el
primer nivel es conjunto de fuentes y el segundo se compone de:
0. Nombre de la fuente.
0. Link del estilo.
0. Nombre del estilo.
En ambos casos, las imágenes se embedarán mediante URI Base64, pasando a formar parte del documento.
Las imágenes, por defecto, suelen estar protegidas por CORS. Para saltarse dicha restricción es
importante hacer uso de un Proxy. Para establecer el Proxy hemos de establecer el parámetro global
"proxy" que vendrá siendo una URL contra el Proxy donde la variable String "{url}" determinará donde
colocar la URL de la imagen.
```js
js_reports = new JSReports({
proxy : "https://proxycors.local/api/DHkwPBhzp78Gz8g3BmG4VFnDgnt5kU9J6XQPjWMGDKwjr6s3f9nV7545B/{url}"
})
```
> [[! note NOTA]]: Si el Proxy no retorna las cabeceras del CORS, éste no servirá de nada. Se puede
hacer uso del proyecto [https://proxycors.k3y.pw/ ProxyCORS], proyecto en el que está basado el
ejemplo también desarrollado por KyMAN. El Git del proyecto es [https://git.k3y.pw/KyMAN/ProxyCORS].
> [[! important IMPORTANTE]]: El link del ProxyCORS posiblemente no funcione por el hecho de que con
dicho Hash podrían usar mi servidor como salto anónimo para saltarse el CORS entre otros fines por
lo que el Hash quede deshabilitado.
También se le pueden agregar componentes especiales al documento como tablas o listas programas
directamente como objetos o Arrays a partir de un objeto que determina su tipo y el contenido del
mismo. A continuación se titularán los tipos de objetos especiales que hay actualmente.
## Tablas (Grids)
Los documentos DOC y PDF permiten la generación de tablas dinámicas a partir de la idea de un Grid,
es decir, un objeto que determina la cabecera y los datos y automáticamente, el programa embedará
una tabla con dichos datos. La estructura del objeto es la siguiente:
- **type**: Tipo (puede ser "table" o "grid").
- **header** : Array de textos, cada uno será la cabecera de esa columna concreta.
- **body**: Cuerpo de la tabla o datos. Array bidimensional con los valores por cada tupla y columna.
Un ejemplo de una tabla puede ser el siguiente:
```js
const table = {
type : "table",
header : ["Cabecera 1", "Cabecera 2", "Cabecera 3", "...", "Cabecera N"],
body : [
["Valor 1", "Valor 2", "Valor 3", "...", "Valor N"],
["Valor 1", "Valor 2", "Valor 3", "...", "Valor N"],
["Valor 1", "Valor 2", "Valor 3", "...", "Valor N"],
["Valor 1", "Valor 2", "Valor 3", "...", "Valor N"],
["Valor 1", "Valor 2", "Valor 3", "...", "Valor N"],
["Valor 1", "Valor 2", "Valor 3", "...", "Valor N"],
["Valor 1", "Valor 2", "Valor 3", "...", "Valor N"],
["Valor 1", "Valor 2", "Valor 3", "...", "Valor N"]
]
};
```
## Listas
Los documentos DOC y PDF permiten la generación de listas dinámicas a partir de un Array el cual
puede anidar otros Array para hacer Listas de múltiples niveles. Admiten tantos listas ordenadas
como desordenadas, y su estructura es la siguiente:
- **type**: Tipo (Siempre será "list"),
- **mode**: El modo en que se mostrarán los datos. Éste puede ser:
- *ol* o *ordered*: Para mostrar los datos con un valor que representa su posición autoincremental.
- *ul* o *unordered*: Para mostrar los datos con puntos, guiones o como se establezca por CSS.
- **start**: Para los elementos ordenados autoincrementalmente, valor numérico de inicio.
- **items**: Array de elementos ordenados. Puede contener objetos que anidan otras listas.
Un ejemplo de una tabla puede ser el siguiente:
```js
const list = {
type : "list",
mode : "ordered",
start : 12,
items : [
"cosa 1",
"cosa 2",
"cosa 3",
"...",
["jojo", {
mode : "unordered",
items : [
"pasa A",
["pasa B", {
items : [
"otro xD"
]
}],
"pasa C"
]
}],
"juas",
"jiji"
]
};
```
[[html_data {
"title" : "JSReports - Notas",
"url" : "https://jsreports.k3y.pw/es/notes.html",
"author" : "KyMAN",
"since" : 20220422,
"version" : 20220422,
"key_words" : "jsreports,js,report,ecma,pdf,doc,csv,kyman,wmd,wmarkdown,documentación,notas",
"description" : "Notas del proyecto JSReports.",
"project" : "JSReports",
"logo" : "https://jsreports.k3y.pw/images/JSReports.png",
"language" : "es"
}]]