Cookies
This website uses cookies to improve the user experience, more information on the legal information path.
Notas
0
años
0
meses
0
días
0
horas
0
minus
0
segus
sáb16mar20:21
Esta es la imagen de fondo
2

Cómo documentar mis componentes react con JSDoc

lun, 16 ene 2023

Introdución

Es necesario tener una buena documentación sobre nuestros componentes, para que otros desarrolladores puedan entender como funciona y como usarlo. En este articulo vamos a ver como podemos documentar nuestros componentes de react con JSDoc y como publicar la documentación en nuestro sitio estático.

Con unos sencillos pasos, la librería jsdoc y el uso de las buenas prácticas de programación cuando trabajemos con react, podremos tener una documentación de nuestros componentes de forma automática. Existen diferentes plugins para upgradear nuestro jsdoc y dar soporte a react, pero como React no deja de ser javascript y los componentes funciones la lib por defecto es más que suficiente.

El reporte que vamos generar no deja de ser un archivo html, por lo que podrás desplegarlo en cualquier sitio estático.

Si utilizas typescript necesitarás instalar jsdoc-babel

1. Instalación


yarn add jsdoc-babel -D

2. Configuración

jsdoc.json

{
"tags": {
"allowUnknownTags": true,
"dictionaries": ["jsdoc", "closure"]
},
"source": {
"include": ["src/components/"],
"includePattern": ".+\\.tsx$",
"excludePattern": "(node_modules/|docs)"
},
"plugins": ["plugins/markdown", "node_modules/jsdoc-babel"],
"templates": {
"cleverLinks": false,
"monospaceLinks": false
},
"babel": {
"extensions": ["tsx"],
"ignore": ["**/*.(test|spec).ts"],
"babelrc": false,
"presets": [["@babel/preset-env", { "targets": { "node": true } }], "@babel/preset-typescript"],
"plugins": ["@babel/proposal-class-properties", "@babel/proposal-object-rest-spread"]
},
"opts": {
"encoding": "utf8",
"destination": "./public/docs/",
"recurse": true,
"verbose": true
}
}

3. Customiza tu reporte

custom-docs.js

import { readFile, writeFile } from 'fs';
import glob from 'glob';
glob('public/docs/**/*.?(html|css)', function (err, files) {
if (err) {
console.log('err', err);
return;
}
files.forEach((path) => {
readFile(path, 'utf8', (err, data) => {
...code
});
});
});

Ahí deberías buscar el código que necesitas para modificar tu reporte y sobreescribirlo.

4. Genera tu reporte


yarn jsdoc -c jsdoc.json

Para ver un ejemplo de salida puedes click arriba donde dice Docs o a través de este enlace