npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@ralorotech/duino-ui

v0.0.18

Published

Sistema de diseño minimalista en React + TypeScript con estilos CSS (BEM), inspirado en la identidad visual de Arduino

Readme

Duino UI

Sistema de diseño minimalista en React + TypeScript con estilos CSS (BEM), inspirado en la identidad visual de Arduino.
Colores y tokens basados en la paleta teal/turquesa característica de Arduino.cc

🎨 Personalización Completa

Duino UI es 100% personalizable. Cambia colores, border radius, tipografía y más en tiempo real.

🚀 Inicio Rápido con Temas

import { ThemeProvider, Button, ThemeSwitcher } from '@ralorotech/duino-ui';

function App() {
  return (
    <ThemeProvider preset="blue">
      <ThemeSwitcher />  {/* Panel de personalización */}
      <Button variant="primary">Mi Botón Personalizado</Button>
    </ThemeProvider>
  );
}

📚 Guías de Personalización


🚀 Instalación

npm install @ralorotech/duino-ui
# o
yarn add @ralorotech/duino-ui
# o
pnpm add @ralorotech/duino-ui

✨ Uso Super Simple

Los estilos se incluyen automáticamente cuando importas cualquier componente. ¡No necesitas importar CSS por separado!

import { Button, Input, Modal } from "@ralorotech/duino-ui";
// ¡Los estilos ya están incluidos! 🎉

Uso rápido

import { Button, Input, Modal, Select } from "@ralorotech/duino-ui";

export default function App() {
  return (
    <div>
      <h2>Duino UI Components</h2>
      <Button>Primary</Button>
      <Button variant="secondary">Secondary</Button>
      <Button variant="ghost">Ghost</Button>
      <Button variant="danger" loading>Deleting…</Button>
      <Input placeholder="Ingresa texto..." />
      <Select 
        options={[
          { label: "Opción 1", value: "1" },
          { label: "Opción 2", value: "2" }
        ]}
        placeholder="Selecciona una opción"
      />
    </div>
  );
}

📖 Ejemplos de Uso

Ejemplo Básico

import { Button, Input, Modal } from "@ralorotech/duino-ui";

function App() {
  return (
    <div>
      <Button>Hola Mundo</Button>
      <Input placeholder="Escribe algo..." />
    </div>
  );
}

Ejemplo Completo

Ver el archivo examples/CompleteExample.tsx para un ejemplo completo que muestra todos los componentes disponibles.

🧑‍💻 Desarrollo local

Requisitos: Node 18+ y npm/pnpm/yarn.

  1. Instalar dependencias:
npm install
  1. Compilar en modo watch (genera dist/):
npm run dev
  1. Probar componentes con Storybook:
npm run storybook
  1. Ejecutar tests:
npm run test
  1. Verificar tipos:
npm run type-check

🎨 Tokens de diseño

Duino UI utiliza tokens CSS personalizados inspirados en Arduino:

/* Colores principales */
--duino-brand-500: #14b8a6;  /* Teal principal */
--duino-brand-700: #008184;  /* Teal oscuro para botones */
--duino-brand-800: #005c5f;  /* Teal muy oscuro para hover */

/* Espaciado */
--duino-gap-sm: .375rem;
--duino-gap: .5rem;
--duino-gap-lg: .75rem;

/* Bordes */
--duino-radius: 12px;

📚 Storybook

Explora todos los componentes de Duino UI:

  • Localmente:

    npm run storybook

    Abre: http://localhost:6006

  • Demo online: (próximamente)


🧩 Scripts disponibles

# Desarrollo
npm run dev          # Compilar en modo watch
npm run storybook    # Ejecutar Storybook

# Construcción
npm run build        # Compilar librería
npm run build:css    # Generar CSS combinado
npm run build:storybook  # Compilar Storybook

# Testing
npm run test         # Ejecutar tests con Vitest

✨ Características

  • Estilos Automáticos - ¡Solo importa el componente y listo! CSS incluido automáticamente
  • 🎨 100% Personalizable - Cambia colores, tipografía y espaciado en tiempo real
  • 🚀 Tree-shaking optimizado - Importa solo lo que necesitas
  • 📱 Responsive - Diseño adaptativo para todos los dispositivos
  • Accesible - Componentes con soporte completo de accesibilidad
  • 🎯 TypeScript - Tipado completo para mejor experiencia de desarrollo
  • 🎨 BEM CSS - Metodología de nomenclatura consistente y mantenible
  • 🔧 Temas - Sistema de temas predefinidos y personalizables
  • 📦 Múltiples formatos - ESM, CJS y UMD para máxima compatibilidad
  • Rápido - Optimizado para rendimiento y carga rápida
  • 🛠️ Desarrollador-friendly - Hot reload, source maps y debugging

🎯 Componentes incluidos

  • Button: Botones con variantes primary, secondary, ghost y danger
  • Input: Campos de entrada con estados de focus y error
  • Modal: Ventanas modales con overlay y animaciones
  • Select: Selectores desplegables con búsqueda
  • Table: Tablas con ordenamiento y paginación
  • Upload: Componente de carga de archivos con drag & drop
  • Collapse: Acordeones colapsables
  • Popover: Tooltips y popovers posicionables
  • Spin: Indicadores de carga
  • Message: Sistema de notificaciones
  • Image: Componente de imagen optimizado

Todos los componentes utilizan los tokens de Duino UI y siguen la metodología BEM para CSS.


🆕 Últimas Mejoras

v0.0.16 - Mejoras de Usabilidad

  • Estilos Automáticos - ¡Ya no necesitas importar CSS! Los estilos se incluyen automáticamente
  • Exports mejorados - Mejor experiencia de importación con múltiples puntos de entrada
  • Tree-shaking optimizado - Configuración mejorada para mejor eliminación de código muerto
  • TypeScript mejorado - Mejor resolución de tipos y configuración de build
  • Documentación actualizada - Ejemplos más completos y guías mejoradas
  • Scripts de desarrollo - Comandos adicionales para linting, type-checking y testing
  • Compatibilidad ampliada - Soporte para ESM, CJS y UMD
  • 🚀 Experiencia de desarrollo mejorada - Configuración simplificada sin importaciones de CSS

⚖️ Licencia

MIT