versacompiler 2.6.0 → 2.6.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -3,15 +3,16 @@
3
3
  [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
4
4
  [![TypeScript](https://img.shields.io/badge/TypeScript-007ACC?style=flat&logo=typescript&logoColor=white)](https://www.typescriptlang.org/)
5
5
  [![Vue.js](https://img.shields.io/badge/Vue.js-35495E?style=flat&logo=vuedotjs&logoColor=4FC08D)](https://vuejs.org/)
6
+ [![Version](https://img.shields.io/badge/version-2.6.2-blue.svg)](https://github.com/kriollo/versaCompiler/releases/tag/v2.6.2)
6
7
 
7
- > **🎯 Compilador rápido y eficiente para Vue.js, TypeScript y JavaScript con Hot Module Replacement (HMR) integrado.**
8
+ > **🎯 Compilador rápido y eficiente para Vue.js, TypeScript y JavaScript con Hot Module Replacement (HMR) completo.**
8
9
 
9
10
  **VersaCompiler** es una herramienta de compilación diseñada para proyectos Vue 3 con soporte completo para TypeScript, JavaScript y todas las funcionalidades modernas que necesitas para desarrollo web.
10
11
 
11
12
  ## 🌟 Características Principales
12
13
 
13
14
  - ⚡ **Compilación ultra-rápida** - Workers paralelos y cache inteligente
14
- - 🔥 **HMR Automático (como Vite)** - Detección inteligente sin configuración manual, igual que Vite y esbuild
15
+ - 🔥 **HMR Completo (como Vite)** - Vue SFCs, librerías JS/TS y propagación en cascada sin recarga de página
15
16
  - 🧩 **Soporte completo para Vue 3** - SFC, Composition API, script setup
16
17
  - 📝 **TypeScript avanzado** - Language Service, decorators, validación de tipos
17
18
  - 🔍 **Sistema de linting dual** - ESLint + OxLint con auto-fix
@@ -125,25 +126,37 @@ versacompiler --typeCheck --file src/types.ts
125
126
 
126
127
  ### 🔧 Archivo de configuración
127
128
 
128
- Crea un archivo `versacompile.config.ts` en la raíz de tu proyecto:
129
+ Crea un archivo `versacompile.config.ts` en la raíz de tu proyecto usando `defineConfig` para autocompletado TypeScript:
129
130
 
130
131
  ```typescript
131
- // Archivo de configuración de VersaCompiler
132
- export default {
133
- tsconfig: './tsconfig.json',
134
- compilerOptions: {
135
- sourceRoot: './src',
132
+ import { defineConfig } from 'versacompiler/config';
133
+
134
+ export default defineConfig({
135
+ root: './src',
136
+ build: {
136
137
  outDir: './dist',
137
- pathsAlias: {
138
- '@/*': ['src/*'],
139
- 'P@/*': ['public/*'],
138
+ bundlers: [
139
+ {
140
+ name: 'appLoader',
141
+ fileInput: './public/module/appLoader.js',
142
+ fileOutput: './public/module/appLoader.prod.js',
143
+ },
144
+ ],
145
+ },
146
+ resolve: {
147
+ alias: {
148
+ '@': 'src',
149
+ 'P@': 'public',
140
150
  },
141
151
  },
142
- proxyConfig: {
152
+ server: {
143
153
  proxyUrl: '',
144
154
  assetsOmit: true,
155
+ watch: {
156
+ additional: ['./app/templates/**/*.twig'],
157
+ },
145
158
  },
146
- aditionalWatch: ['./app/templates/**/*.twig'],
159
+ tsconfig: './tsconfig.json',
147
160
  tailwindConfig: {
148
161
  bin: './node_modules/.bin/tailwindcss',
149
162
  input: './src/css/input.css',
@@ -165,62 +178,60 @@ export default {
165
178
  paths: ['src/'],
166
179
  },
167
180
  ],
168
- bundlers: [
169
- {
170
- name: 'appLoader',
171
- fileInput: './public/module/appLoader.js',
172
- fileOutput: './public/module/appLoader.prod.js',
173
- },
174
- ],
175
- };
181
+ typeCheckOptions: {
182
+ maxWorkers: 2,
183
+ },
184
+ });
176
185
  ```
177
186
 
178
187
  ### 📝 Opciones de configuración
179
188
 
180
- #### `compilerOptions`
189
+ #### `root` _(requerido)_
181
190
 
182
- - `sourceRoot`: Directorio de archivos fuente (por defecto: `'./src'`)
183
- - `outDir`: Directorio de salida (por defecto: `'./dist'`)
184
- - `pathsAlias`: Aliases para imports (ej: `'@/*': ['src/*']`)
191
+ - Directorio raíz de los archivos fuente (ej: `'./src'`)
185
192
 
186
- #### `proxyConfig`
193
+ #### `build` _(requerido)_
187
194
 
188
- - `proxyUrl`: URL del proxy para desarrollo
189
- - `assetsOmit`: Omitir assets en el proxy
195
+ - `outDir`: Directorio de salida de los archivos compilados (ej: `'./dist'`)
196
+ - `bundlers`: Array de entradas de bundling post-compilación (opcional, `false` para deshabilitar)
197
+ - `name`: Nombre del bundle
198
+ - `fileInput`: Archivo de entrada
199
+ - `fileOutput`: Archivo de salida
200
+
201
+ #### `resolve`
202
+
203
+ - `alias`: Mapa de alias de imports. La clave es el prefijo del alias y el valor es la ruta que reemplaza (ej: `{ '@': 'src', 'P@': 'public' }`)
204
+
205
+ #### `server`
206
+
207
+ - `proxyUrl`: URL del proxy para desarrollo (ej: `'http://localhost:8000'`)
208
+ - `assetsOmit`: Omitir assets estáticos del proxy (`true`/`false`)
209
+ - `watch.additional`: Globs adicionales a vigilar que disparan recarga completa (ej: plantillas Twig, HTML)
210
+
211
+ #### `tsconfig`
212
+
213
+ - Ruta al `tsconfig.json` del proyecto (ej: `'./tsconfig.json'`)
190
214
 
191
215
  #### `tailwindConfig`
192
216
 
193
217
  - `bin`: Ruta al binario de TailwindCSS
194
- - `input`: Archivo CSS de entrada
195
- - `output`: Archivo CSS de salida
218
+ - `input`: Archivo CSS de entrada con directivas Tailwind
219
+ - `output`: Archivo CSS de salida compilado
220
+ - Usar `false` para deshabilitar completamente
196
221
 
197
222
  #### `linter`
198
223
 
199
- Array de configuraciones de linters avanzadas:
224
+ Array de configuraciones de linters. Usar `false` para deshabilitar todos:
200
225
 
201
226
  - `name`: Nombre del linter (`'eslint'` o `'oxlint'`)
202
227
  - `bin`: Ruta al binario del linter
203
228
  - `configFile`: Archivo de configuración del linter
204
- - `fix`: Auto-fix de errores detectados
205
- - `paths`: Rutas específicas a analizar
206
- - `eslintConfig`: Configuración específica de ESLint
207
- - `cache`: Habilitar cache de ESLint
208
- - `maxWarnings`: Máximo número de warnings
209
- - `quiet`: Mostrar solo errores
210
- - `formats`: Formatos de salida (`'json'`, `'stylish'`, `'compact'`)
211
- - `oxlintConfig`: Configuración específica de OxLint
212
- - `rules`: Reglas personalizadas
213
- - `plugins`: Plugins de OxLint
214
- - `deny`: Reglas a denegar
215
- - `allow`: Reglas a permitir
216
-
217
- #### `bundlers`
218
-
219
- Array de configuraciones de bundling:
220
-
221
- - `name`: Nombre del bundle
222
- - `fileInput`: Archivo de entrada
223
- - `fileOutput`: Archivo de salida
229
+ - `fix`: Auto-fix de errores detectados (`true`/`false`)
230
+ - `paths`: Rutas específicas a analizar (ej: `['src/']`)
231
+
232
+ #### `typeCheckOptions`
233
+
234
+ - `maxWorkers`: Máximo número de worker threads para verificación de tipos (por defecto: depende del número de CPUs)
224
235
 
225
236
  ## 🎯 Ejemplos de Uso
226
237
 
@@ -514,12 +525,17 @@ cat tsconfig.json | grep -A 10 "paths"
514
525
 
515
526
  ```typescript
516
527
  // Verificar configuración en versacompile.config.ts
517
- export default {
518
- proxyConfig: {
528
+ import { defineConfig } from 'versacompiler/config';
529
+
530
+ export default defineConfig({
531
+ root: './src',
532
+ build: { outDir: './dist' },
533
+ resolve: { alias: { '@': 'src' } },
534
+ server: {
519
535
  proxyUrl: '', // Vacío si no usas proxy backend
520
536
  assetsOmit: true,
521
537
  },
522
- };
538
+ });
523
539
  ```
524
540
 
525
541
  ```bash
@@ -1653,6 +1653,11 @@ function extractLocalImports(code) {
1653
1653
  * Solo se llama cuando env.isPROD !== 'true' y la salida es un archivo .js.
1654
1654
  */
1655
1655
  function injectHmrShim(code) {
1656
+ // Los scripts CLI con shebang no se ejecutan en browser: omitir el shim HMR
1657
+ // para evitar que el shebang quede desplazado y cause SyntaxError en Node.js
1658
+ if (code.startsWith('#!')) {
1659
+ return code;
1660
+ }
1656
1661
  const localImports = extractLocalImports(code);
1657
1662
  // Detecta si es un Vue SFC (el compilador Vue inyecta 'data-versa-hmr-component')
1658
1663
  const isVueComponent = code.includes('data-versa-hmr-component');
@@ -0,0 +1 @@
1
+ export { defineConfig, type BundlerEntry, type LinterConfig, type VersaConfig, } from './servicios/versacompile.config.types';
package/dist/main.js CHANGED
@@ -1,15 +1,3 @@
1
- /* VersaCompiler HMR shim [dev] */
2
- if (typeof window !== 'undefined' && window.__versaHMR) {
3
- (() => {
4
- const _id = new URL(import.meta.url).pathname;
5
- import.meta.hot = {
6
- accept(cb) { window.__versaHMR.accept(_id, typeof cb === 'function' ? cb : () => {}); },
7
- invalidate() { window.__versaHMR._invalidate?.(_id); },
8
- dispose(cb) { window.__versaHMR._onDispose?.(_id, cb); },
9
- get data() { return window.__versaHMR._getHotData?.(_id) ?? {}; },
10
- };
11
- })();
12
- }
13
1
  #!/usr/bin/env node
14
2
  import * as path from 'node:path';
15
3
  import * as processModule from 'node:process';
@@ -0,0 +1,44 @@
1
+ export type LinterConfig = {
2
+ name: string;
3
+ bin: string;
4
+ configFile: string;
5
+ fix?: boolean;
6
+ paths?: string[];
7
+ };
8
+ export type BundlerEntry = {
9
+ name: string;
10
+ fileInput: string;
11
+ fileOutput: string;
12
+ };
13
+ export type VersaConfig = {
14
+ root: string;
15
+ build: {
16
+ outDir: string;
17
+ bundlers?: BundlerEntry[] | false;
18
+ };
19
+ resolve: {
20
+ alias: Record<string, string | string[]>;
21
+ };
22
+ server?: {
23
+ proxyUrl?: string;
24
+ assetsOmit?: boolean;
25
+ watch?: {
26
+ additional?: string[];
27
+ };
28
+ };
29
+ watch?: {
30
+ additional?: string[];
31
+ };
32
+ plugins?: unknown[];
33
+ tsconfig?: string;
34
+ tailwindConfig?: {
35
+ bin: string;
36
+ input: string;
37
+ output: string;
38
+ } | false;
39
+ linter?: LinterConfig[] | false;
40
+ typeCheckOptions?: {
41
+ maxWorkers?: number;
42
+ };
43
+ };
44
+ export declare const defineConfig: (config: VersaConfig) => VersaConfig;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "versacompiler",
3
- "version": "2.6.0",
3
+ "version": "2.6.2",
4
4
  "description": "Una herramienta para compilar y minificar archivos .vue, .js y .ts para proyectos de Vue 3 con soporte para TypeScript.",
5
5
  "keywords": [
6
6
  "compiler",