Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
@laboratoria/rubric
Advanced tools
[![Build Status](https://travis-ci.com/Laboratoria/rubric.svg?token=4uyuoxi9qhvAfjzUTB6y&branch=master)](https://travis-ci.com/Laboratoria/rubric) [![Coverage Status](https://coveralls.io/repos/github/Laboratoria/rubric/badge.svg?branch=master)](https://c
Este repositorio contienen una librería (biblioteca) de JavaScript que representa la rúbrica que usamos en el Bootcamp de Laboratoria. La rúbrica se mantiene como un par de hojas de cálculo en Google Sheets (español, portugués).
Los mantenedores de los documentos de la rúbrica en Google Sheets son:
Si solo necesitas la versión más reciente de la rúbrica, puedes instalar el
módulo @laboratoria/rubric
desde el repo de GitHub con los siguientes comandos:
# con npm
npm install --save @laboratoria/rubric
name
El nombre de la librería: rubric
.
version
La versión de la librería: 3.0.0
.
categories
Objeto (diccionario) con las diferentes categorías en las que se organizan las habilidades o skills.
skills
Objeto (diccionario) con las diferentes habilidades/skills.
intl
Objeto (diccionario) con las traducciones de los nombres de las categorías, y nombres, descripciones y niveles de cada habilidad
buildTree(nodes = categories, parent = undefined)
Retorna un Array
con las categorías raíz. Por defecto, si omitimos el
argumento nodes
, las categorías raíz serían las hojas del spreadsheet, y si
omitimos el argumento parent
estaríamos diciendo que queremos construir el
árbol desde la raíz. El arreglo retornado contiene las categorías raíz, cada una
con sus subcategorías y habilidades correspondientes.
const rubric = require('@laboratoria/rubric');
// Build entire tree from the root
console.log(rubric.buildTree());
// Build partial tree (sub-tree) for a given branch
console.log(rubric.buildTree(undefined, 'frontEnd'));
Cada categoría/subcategoría (Category
) tiene las siguientes propiedades:
id
: String
: El identificador de la categoría.order
: Number
: El orden de la categoría dentro de su categoría madre.children
: Array
[Category]
: Un arreglo con subcategorías que sean
hijas de la categoría.skills
Array
[Skill]
: Un arreglo de objetos de tipo Skill
detallados
más abajo.Cada habilidad (Skill
) tiene las siguientes propiedades:
id
: String
: El identificador de la habilidad.core
: Boolean
: Un booleano (true
o false
) que indica si la habilidad
en cuestión es considerada central al programa de formación.order
: Number
: El orden de la habilidad dentro de su categoría madre.category
: String
: La categoría a la que pertenece la habilidad.Ejemplo de un objeto Category
conteniendo un objeto Skill
:
// Objeto `Category`
{
id: 'cs',
parent: 'frontEnd',
order: 0,
children: [],
skills: [
// Objeto `Skill`
{
id: 'logic',
core: true,
order: 0,
category: 'cs'
}
]
}
buildTreeWithLocale(locale, nodes, parent)
Igual que buildTree
, pero agrega todos los textos (títulos, descripcciones,
niveles, ...) en el idioma (locale
) seleccionado.
Cada categoría (Category
) tiene las mismas propiedades que las categorías que
retorna buildTree()
, pero además incluye la propiedad title
en el idioma
seleccionado:
id
: String
: El identificador de la categoría.order
: Number
: El orden de la categoría dentro de su categoría madre.children
: Array
[Category]
: Un arreglo con subcategorías que sean
hijas de la categoría.skills
Array
[Skill]
: Un arreglo de objetos de tipo Skill
detallados
más abajo.title
: String
: El título de la categoría en el idioma seleccionado.Cada habilidad (Skill
) tiene las mismas propiedades que las habilidades que
retorna buildTree()
, pero además incluye las propiedadestitle
,
description
y levels
:
id
: String
: El identificador de la habilidad.core
: Boolean
: Un booleano (true
o false
) que indica si la habilidad
en cuestión es considerada central al programa de formación.order
: Number
: El orden de la habilidad dentro de su categoría madre.category
: String
: La categoría a la que pertenece la habilidad.title
: String
: El título de la habilidad en el idioma seleccionado.description
: String
: Descripcción de la habilidad en el idioma
seleccionado.levels
: Array
[String]
: Un arreglo de strings con las descripcciones
de cada nivel en el idioma seleccionado.Ejemplo de un objeto Category
(con traducción) conteniendo un objeto Skill
(con traducción):
// Objeto `Category` con traducción
{
id: 'cs',
parent: 'frontEnd',
order: 0,
title: 'Computer Science (CS)',
children: [],
skills:[
// Objeto `Skill` con traducción
{
id: 'logic',
core: true,
order: 0,
category: 'cs',
title: 'Lógica / Algoritmia',
description: 'Capacidad de expresión lógica, ...',
levels: [
'Código no sigue ninguna convención o patrón común...',
'Demuestra uso de convenciones de JavaScript idiomático...',
'Es consciente de la diferencia entre estilos...',
'Demuestra soltura pasando de un estilo/paradigma a otro...',
'Demuestra soltura y profundidad con diferentes convenciones...',
],
},
],
};
applyLocale(tree, locale)
Dado un árbol creado con buildTree
, aplica los textos (títulos,
descripcciones, niveles, ...) en el idioma (locale
) seleccionado.
npm test
npx jest --watch
npm run fetch-data
npm run process-data
npm run fetch-and-process
FAQs
:warning: WARNING: This module has been DEPRECATED and is no longer supported.
The npm package @laboratoria/rubric receives a total of 2 weekly downloads. As such, @laboratoria/rubric popularity was classified as not popular.
We found that @laboratoria/rubric demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 5 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.