@icarusmx/creta 1.5.13 → 1.5.14

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/bin/creta.js CHANGED
@@ -681,6 +681,7 @@ function showHelp() {
681
681
  console.log("📖 Documentación de comandos:")
682
682
  console.log(" creta ls - Documentación en español del comando ls")
683
683
  console.log(" creta grep - Documentación en español del comando grep")
684
+ console.log(" creta lz - Localiza recursos (alias de curl)")
684
685
  console.log(" creta cd - Documentación en español del comando cd")
685
686
  console.log(" creta curl - Documentación en español del comando curl")
686
687
  console.log(" creta git status - Documentación en español de git status")
@@ -1904,7 +1905,7 @@ async function startVimSetupTutorial() {
1904
1905
  // Helper function to detect command help requests
1905
1906
  function isCommandHelpRequest(args) {
1906
1907
  // List of supported commands for help
1907
- const basicCommands = ['ls', 'cd', 'mkdir', 'touch', 'wc', 'curl', 'grep']
1908
+ const basicCommands = ['ls', 'cd', 'mkdir', 'touch', 'wc', 'curl', 'grep', 'lz']
1908
1909
  const gitCommands = ['git status', 'git add', 'git commit', 'git push', 'git log']
1909
1910
 
1910
1911
  const commandString = args.join(' ')
@@ -23,6 +23,10 @@ export const grep = {
23
23
  flag: '-c',
24
24
  description: 'Cuenta líneas que coinciden'
25
25
  },
26
+ {
27
+ flag: '-q',
28
+ description: 'Modo silencioso (no imprime nada, solo devuelve código de salida)'
29
+ },
26
30
  {
27
31
  flag: '-l',
28
32
  description: 'Solo muestra nombres de archivos con coincidencias'
@@ -6,6 +6,7 @@ export { touch } from './touch.js'
6
6
  export { wc } from './wc.js'
7
7
  export { curl } from './curl.js'
8
8
  export { grep } from './grep.js'
9
+ export { lz } from './lz.js'
9
10
 
10
11
  // Git commands
11
12
  export { gitStatus } from './git-status.js'
@@ -27,6 +28,7 @@ export const commandMap = {
27
28
  'wc': 'wc',
28
29
  'curl': 'curl',
29
30
  'grep': 'grep',
31
+ 'lz': 'lz',
30
32
 
31
33
  // Git
32
34
  'git status': 'gitStatus',
@@ -0,0 +1,57 @@
1
+ export const lz = {
2
+ command: 'lz',
3
+ description: 'Localiza un recurso en la web (alias didáctico de curl)',
4
+ usage: 'lz [url]',
5
+ commonOptions: [
6
+ {
7
+ flag: '-O',
8
+ description: 'Guarda el archivo con su nombre original'
9
+ },
10
+ {
11
+ flag: '-o archivo',
12
+ description: 'Guarda el contenido en el archivo especificado'
13
+ },
14
+ {
15
+ flag: '-L',
16
+ description: 'Sigue redirecciones automáticamente'
17
+ },
18
+ {
19
+ flag: '-I',
20
+ description: 'Solo muestra los headers (encabezados)'
21
+ },
22
+ {
23
+ flag: '-s',
24
+ description: 'Modo silencioso (no muestra progreso)'
25
+ }
26
+ ],
27
+ examples: [
28
+ {
29
+ command: 'lz icarus.mx/README.md',
30
+ description: 'Localiza y muestra el contenido del README'
31
+ },
32
+ {
33
+ command: 'lz -O icarus.mx/logo.png',
34
+ description: 'Descarga logo.png con su nombre original'
35
+ },
36
+ {
37
+ command: 'lz -o mi-archivo.json api.ejemplo.com/data',
38
+ description: 'Guarda la respuesta en mi-archivo.json'
39
+ },
40
+ {
41
+ command: 'lz -I icarus.mx',
42
+ description: 'Muestra solo los headers del sitio'
43
+ },
44
+ {
45
+ command: 'lz -sL api.ejemplo.com | grep "version"',
46
+ description: 'Busca "version" en la respuesta (silencioso + sigue redirects)'
47
+ }
48
+ ],
49
+ relatedLesson: 'Curl y pipes',
50
+ tips: [
51
+ '🧠 lz = "localiza recurso" - Alias en español para curl',
52
+ 'curl significa "Client URL" - Cliente para Localizar Recursos Universales',
53
+ 'Lo "universal" viene del protocolo HTTP (HyperText Transfer Protocol)',
54
+ 'En la terminal real usa curl, pero lz te ayuda a pensar en español',
55
+ 'Pro tip: lz es perfecto para probar APIs rápidamente'
56
+ ]
57
+ }
@@ -0,0 +1,134 @@
1
+ # Shell Aliases: Personaliza tu Terminal
2
+
3
+ ## Objetivo
4
+
5
+ Aprende a crear alias de shell para hacer comandos más intuitivos y personalizados. Crearemos el alias `lz` (localiza recurso) para `curl`.
6
+
7
+ ## ¿Qué es un Alias?
8
+
9
+ Un alias es un atajo personalizado para un comando. Por ejemplo:
10
+ - En vez de escribir `curl https://icarus.mx`
11
+ - Escribes `lz https://icarus.mx`
12
+
13
+ ## Por qué `lz` para curl
14
+
15
+ **curl** = Client URL (Cliente de URL)
16
+ - **Cliente**: localiza recursos para ti
17
+ - **Universal**: usa HTTP (HyperText Transfer Protocol)
18
+ - **lz**: "localiza recurso" - alias en español
19
+
20
+ ## Paso 1: Identificar tu Shell
21
+
22
+ En macOS Catalina+ se usa `zsh` por defecto:
23
+
24
+ ```bash
25
+ echo $SHELL
26
+ ```
27
+
28
+ Si ves `/bin/zsh` → usas zsh (archivo: `~/.zshrc`)
29
+ Si ves `/bin/bash` → usas bash (archivo: `~/.bashrc`)
30
+
31
+ ## Paso 2: Abrir el Archivo de Configuración
32
+
33
+ Para zsh (más común en Mac):
34
+
35
+ ```bash
36
+ nvim ~/.zshrc
37
+ ```
38
+
39
+ O si prefieres VS Code:
40
+
41
+ ```bash
42
+ code ~/.zshrc
43
+ ```
44
+
45
+ ## Paso 3: Agregar el Alias
46
+
47
+ Al final del archivo, agrega:
48
+
49
+ ```bash
50
+ # Alias personalizados
51
+ alias lz='curl'
52
+ ```
53
+
54
+ Guarda el archivo:
55
+ - En nvim: presiona `ESC`, luego escribe `:wq` y `ENTER`
56
+ - En VS Code: `Cmd + S`
57
+
58
+ ## Paso 4: Recargar la Configuración
59
+
60
+ Tienes dos opciones:
61
+
62
+ **Opción 1: Recargar el archivo**
63
+ ```bash
64
+ source ~/.zshrc
65
+ ```
66
+
67
+ **Opción 2: Cerrar y abrir una nueva terminal**
68
+
69
+ ## Paso 5: Probar el Alias
70
+
71
+ ```bash
72
+ lz icarus.mx
73
+ ```
74
+
75
+ Deberías ver el HTML del sitio de Icarus.
76
+
77
+ ## Alias Útiles para Agregar
78
+
79
+ Mientras estás editando `~/.zshrc`, considera agregar:
80
+
81
+ ```bash
82
+ # Alias para comandos comunes
83
+ alias ls='ls -G' # ls con colores en Mac
84
+ alias ll='ls -lah' # ls largo con todo
85
+ alias ..='cd ..' # sube un nivel
86
+ alias ...='cd ../..' # sube dos niveles
87
+ alias gs='git status' # git status rápido
88
+ alias ga='git add' # git add rápido
89
+ alias gc='git commit -m' # git commit con mensaje
90
+ alias gp='git push' # git push rápido
91
+ alias lz='curl' # localiza recurso (nuestro nuevo alias)
92
+
93
+ # Alias para navegación rápida
94
+ alias proyectos='cd ~/proyectos'
95
+ alias icarus='cd ~/icarus'
96
+ ```
97
+
98
+ ## Verificar que Funciona
99
+
100
+ ```bash
101
+ # Probar lz
102
+ lz -I icarus.mx
103
+
104
+ # Debería mostrar los headers del sitio
105
+ ```
106
+
107
+ ## Troubleshooting
108
+
109
+ **Problema: "command not found: lz"**
110
+ - Solución: Verifica que ejecutaste `source ~/.zshrc`
111
+
112
+ **Problema: "No such file or directory: ~/.zshrc"**
113
+ - Solución: Crea el archivo primero: `touch ~/.zshrc`
114
+
115
+ **Problema: Sigo usando bash en vez de zsh**
116
+ - Solución: Edita `~/.bashrc` en vez de `~/.zshrc`
117
+
118
+ ## Siguiente Nivel
119
+
120
+ Una vez que domines los alias básicos, aprende sobre:
121
+ - **Funciones de shell**: alias con argumentos complejos
122
+ - **Dotfiles**: versionar tu configuración con Git
123
+ - **Oh My Zsh**: framework para mejorar tu terminal
124
+
125
+ ## Recursos
126
+
127
+ - `man zsh` - Manual de zsh
128
+ - `man bash` - Manual de bash
129
+ - `alias` - Ver todos tus alias actuales
130
+ - `unalias lz` - Eliminar un alias temporal
131
+
132
+ ---
133
+
134
+ **Pro tip**: Los alias se cargan cada vez que abres una terminal nueva. Si quieres un alias temporal (solo para la sesión actual), simplemente escribe `alias lz='curl'` directo en la terminal sin agregarlo al archivo.
@@ -34,6 +34,12 @@ Each phase builds on knowledge from previous phases.
34
34
  **Time:** 15 minutes
35
35
  **Level:** 🟢 Beginner
36
36
 
37
+ ### 13. [Shell Aliases: Personaliza tu Terminal](./13-shell-aliases.md)
38
+ **What:** Crear alias personalizados (lz para curl)
39
+ **Why:** Comandos más intuitivos en español - piensa "localiza recurso"
40
+ **Time:** 10 minutes
41
+ **Level:** 🟢 Beginner
42
+
37
43
  ### 4. [Array & Object Manipulation](./04-array-object-manipulation.md)
38
44
  **What:** JavaScript warmups - map, filter, reduce, destructuring
39
45
  **Why:** Foundation for real app data transformations
@@ -144,6 +150,7 @@ Prefer to browse by subject?
144
150
  - [Developing Muscle Memory for Neovim](./01-developing-muscle-for-nvim.md)
145
151
  - [iTerm2 Pane Navigation](./02-iterm2-pane-navigation.md)
146
152
  - [Git Stash Workflow](./03-git-stash-workflow.md)
153
+ - [Shell Aliases](./13-shell-aliases.md)
147
154
  - [curl + Pipes](./06-curl-and-pipes.md)
148
155
 
149
156
  ### JavaScript & Development
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@icarusmx/creta",
3
- "version": "1.5.13",
3
+ "version": "1.5.14",
4
4
  "description": "Salgamos de este laberinto.",
5
5
  "type": "module",
6
6
  "bin": {