claude-code-achievements 1.0.0 → 1.1.0
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/.claude-plugin/plugin.json +1 -0
- package/README.es.md +315 -0
- package/README.ja.md +315 -0
- package/README.ko.md +315 -0
- package/README.md +225 -111
- package/README.zh.md +315 -0
- package/assets/icon.png +0 -0
- package/bin/install.js +64 -14
- package/commands/achievements.md +40 -44
- package/data/achievements.json +96 -30
- package/data/i18n/en.json +77 -10
- package/data/i18n/es.json +161 -0
- package/data/i18n/ja.json +161 -0
- package/data/i18n/ko.json +77 -10
- package/data/i18n/zh.json +161 -0
- package/hooks/track-achievement.sh +96 -11
- package/package.json +3 -2
- package/scripts/show-achievements.sh +119 -64
- package/scripts/show-notification.sh +36 -56
package/README.es.md
ADDED
|
@@ -0,0 +1,315 @@
|
|
|
1
|
+
<div align="center">
|
|
2
|
+
|
|
3
|
+
<img src="assets/icon.png" alt="Claude Code Achievements" width="120" height="120">
|
|
4
|
+
|
|
5
|
+
# Claude Code Achievements
|
|
6
|
+
|
|
7
|
+
**Sistema de logros estilo Steam para Claude Code**
|
|
8
|
+
|
|
9
|
+
[](https://www.npmjs.com/package/claude-code-achievements)
|
|
10
|
+
[](LICENSE)
|
|
11
|
+
[](package.json)
|
|
12
|
+
|
|
13
|
+
¡Gamifica tu experiencia de programación y desbloquea logros mientras dominas las funciones de Claude Code!
|
|
14
|
+
|
|
15
|
+
[Instalación](#instalación) · [Uso](#uso) · [Logros](#logros) · [Cómo Funciona](#arquitectura)
|
|
16
|
+
|
|
17
|
+
**[English](README.md)** · **[中文](README.zh.md)** · **[한국어](README.ko.md)** · **[日本語](README.ja.md)**
|
|
18
|
+
|
|
19
|
+
</div>
|
|
20
|
+
|
|
21
|
+
---
|
|
22
|
+
|
|
23
|
+
## Características
|
|
24
|
+
|
|
25
|
+
- **26 Logros** en 4 categorías
|
|
26
|
+
- **Notificaciones en tiempo real** vía alertas del sistema o terminal
|
|
27
|
+
- **Soporte multiidioma** (EN / 中文 / ES / 한국어 / 日本語)
|
|
28
|
+
- **Multiplataforma** (macOS / Linux / Windows)
|
|
29
|
+
- **Instalación global** - funciona en todos tus proyectos
|
|
30
|
+
|
|
31
|
+
## Instalación
|
|
32
|
+
|
|
33
|
+
```bash
|
|
34
|
+
npx claude-code-achievements
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
El instalador interactivo:
|
|
38
|
+
1. Detectará automáticamente tu SO y capacidad de notificaciones
|
|
39
|
+
2. Preguntará tu preferencia de idioma
|
|
40
|
+
3. Configurará el estilo de notificación (sistema/terminal/ambos)
|
|
41
|
+
4. Instalará globalmente en `~/.claude/plugins/local/`
|
|
42
|
+
|
|
43
|
+
> **Nota:** Este plugin se instala **globalmente** y funciona automáticamente en todos tus proyectos.
|
|
44
|
+
|
|
45
|
+
### Instalación Manual
|
|
46
|
+
|
|
47
|
+
```bash
|
|
48
|
+
git clone https://github.com/subinium/claude-code-achievements.git
|
|
49
|
+
cd claude-code-achievements
|
|
50
|
+
node bin/install.js
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
## Uso
|
|
54
|
+
|
|
55
|
+
| Comando | Descripción |
|
|
56
|
+
|---------|-------------|
|
|
57
|
+
| `/achievements` | Ver logros desbloqueados (predeterminado) |
|
|
58
|
+
| `/achievements locked` | Ver logros bloqueados con pistas |
|
|
59
|
+
| `/achievements all` | Ver todos los logros por categoría |
|
|
60
|
+
| `/achievements-settings` | Cambiar idioma o configuración de notificaciones |
|
|
61
|
+
|
|
62
|
+
### Filtros de Categoría
|
|
63
|
+
|
|
64
|
+
```bash
|
|
65
|
+
/achievements basics # Primeros Pasos
|
|
66
|
+
/achievements workflow # Flujo de Trabajo
|
|
67
|
+
/achievements tools # Herramientas Avanzadas
|
|
68
|
+
/achievements mastery # Maestría
|
|
69
|
+
```
|
|
70
|
+
|
|
71
|
+
## Logros
|
|
72
|
+
|
|
73
|
+
<details>
|
|
74
|
+
<summary><b>Primeros Pasos</b> (4 logros)</summary>
|
|
75
|
+
|
|
76
|
+
| Logro | Cómo Desbloquear |
|
|
77
|
+
|-------|------------------|
|
|
78
|
+
| ✏️ **Primer Toque** | Editar cualquier archivo |
|
|
79
|
+
| 📝 **Creador** | Crear un nuevo archivo |
|
|
80
|
+
| 🔍 **Detective de Código** | Usar Glob o Grep para buscar en el código |
|
|
81
|
+
| 📋 **Curador de Proyecto** | Crear `CLAUDE.md` para contexto del proyecto |
|
|
82
|
+
|
|
83
|
+
</details>
|
|
84
|
+
|
|
85
|
+
<details>
|
|
86
|
+
<summary><b>Flujo de Trabajo</b> (8 logros)</summary>
|
|
87
|
+
|
|
88
|
+
| Logro | Cómo Desbloquear |
|
|
89
|
+
|-------|------------------|
|
|
90
|
+
| 📋 **Planificador de Tareas** | Usar TodoWrite para seguimiento de tareas |
|
|
91
|
+
| 🎯 **Pensador Estratégico** | Usar modo Plan (`Shift+Tab` dos veces) |
|
|
92
|
+
| 🗣️ **Comunicador** | Claude usa `AskUserQuestion` para clarificar requisitos |
|
|
93
|
+
| 🌍 **Curador Global** | Configurar `~/.claude/CLAUDE.md` |
|
|
94
|
+
| 📦 **Controlador de Versiones** | Hacer commit con Claude |
|
|
95
|
+
| 🚀 **¡A Producción!** | Hacer push al repositorio remoto |
|
|
96
|
+
| 🧪 **Guardián de Calidad** | Ejecutar tests con Claude |
|
|
97
|
+
| 🚦 **Pionero CI/CD** | Crear workflow de GitHub Actions |
|
|
98
|
+
|
|
99
|
+
</details>
|
|
100
|
+
|
|
101
|
+
<details>
|
|
102
|
+
<summary><b>Herramientas Avanzadas</b> (9 logros)</summary>
|
|
103
|
+
|
|
104
|
+
| Logro | Cómo Desbloquear |
|
|
105
|
+
|-------|------------------|
|
|
106
|
+
| 🎨 **Inspector Visual** | Analizar imagen o captura de pantalla |
|
|
107
|
+
| 📡 **Cazador de Docs** | Obtener y analizar una página web |
|
|
108
|
+
| 🤖 **Maestro de Delegación** | Usar herramienta `Task` para sub-agentes |
|
|
109
|
+
| 🔌 **Pionero MCP** | Usar cualquier herramienta MCP |
|
|
110
|
+
| 🌐 **Explorador Web** | Usar herramienta `WebSearch` |
|
|
111
|
+
| ⚡ **Maestro de Habilidades** | Usar comandos slash skills |
|
|
112
|
+
| ⚙️ **Personalizador** | Modificar configuración de Claude Code |
|
|
113
|
+
| 📜 **Creador de Skills** | Crear skill personalizado en `.claude/skills/` |
|
|
114
|
+
| ⌨️ **Artesano de Comandos** | Crear comando slash personalizado |
|
|
115
|
+
|
|
116
|
+
</details>
|
|
117
|
+
|
|
118
|
+
<details>
|
|
119
|
+
<summary><b>Maestría</b> (5 logros)</summary>
|
|
120
|
+
|
|
121
|
+
| Logro | Cómo Desbloquear |
|
|
122
|
+
|-------|------------------|
|
|
123
|
+
| 🪝 **Arquitecto de Automatización** | Configurar hooks de Claude Code |
|
|
124
|
+
| 🔗 **Conector MCP** | Configurar `.mcp.json` para integraciones |
|
|
125
|
+
| 🤖 **Arquitecto de Agentes** | Crear agente personalizado en `.claude/agents/` |
|
|
126
|
+
| 🛡️ **Guardia de Seguridad** | Configurar permisos de seguridad |
|
|
127
|
+
| 🔄 **Maestro del Bucle** | Iniciar bucle de codificación autónomo |
|
|
128
|
+
|
|
129
|
+
</details>
|
|
130
|
+
|
|
131
|
+
---
|
|
132
|
+
|
|
133
|
+
## Arquitectura
|
|
134
|
+
|
|
135
|
+
Este plugin usa el **sistema de hooks de Claude Code** para rastrear tus acciones en tiempo real.
|
|
136
|
+
|
|
137
|
+
```
|
|
138
|
+
┌─────────────────────────────────────────────────────────────┐
|
|
139
|
+
│ SESIÓN DE CLAUDE CODE │
|
|
140
|
+
├─────────────────────────────────────────────────────────────┤
|
|
141
|
+
│ │
|
|
142
|
+
│ Tú: "Edita el archivo de configuración" │
|
|
143
|
+
│ │ │
|
|
144
|
+
│ ▼ │
|
|
145
|
+
│ ┌─────────────────────────────────────┐ │
|
|
146
|
+
│ │ Claude usa la herramienta Edit │ │
|
|
147
|
+
│ └─────────────────────────────────────┘ │
|
|
148
|
+
│ │ │
|
|
149
|
+
│ ▼ │
|
|
150
|
+
│ ┌─────────────────────────────────────┐ │
|
|
151
|
+
│ │ Se activa el Hook PostToolUse │◄── hooks.json │
|
|
152
|
+
│ │ → track-achievement.sh │ │
|
|
153
|
+
│ └─────────────────────────────────────┘ │
|
|
154
|
+
│ │ │
|
|
155
|
+
│ ┌──────────┴──────────┐ │
|
|
156
|
+
│ ▼ ▼ │
|
|
157
|
+
│ ┌───────────┐ ┌───────────┐ │
|
|
158
|
+
│ │ ¡Coincide!│ │ No coincide│ │
|
|
159
|
+
│ │ │ │ │ │
|
|
160
|
+
│ │ Desbloquear│ │ Continuar │ │
|
|
161
|
+
│ │ Notificar │ └───────────┘ │
|
|
162
|
+
│ │ Guardar │ │
|
|
163
|
+
│ └───────────┘ │
|
|
164
|
+
│ │
|
|
165
|
+
└─────────────────────────────────────────────────────────────┘
|
|
166
|
+
```
|
|
167
|
+
|
|
168
|
+
### Estructura del Plugin
|
|
169
|
+
|
|
170
|
+
```
|
|
171
|
+
~/.claude/plugins/local/claude-code-achievements/
|
|
172
|
+
├── .claude-plugin/
|
|
173
|
+
│ └── plugin.json # Metadatos del plugin
|
|
174
|
+
├── hooks/
|
|
175
|
+
│ ├── hooks.json # Definiciones de hooks (PostToolUse, Stop)
|
|
176
|
+
│ ├── track-achievement.sh # Lógica principal de seguimiento
|
|
177
|
+
│ └── track-stop.sh # Manejador de fin de sesión
|
|
178
|
+
├── commands/
|
|
179
|
+
│ ├── achievements.md # Comando /achievements
|
|
180
|
+
│ └── achievements-settings.md
|
|
181
|
+
├── scripts/
|
|
182
|
+
│ ├── show-achievements.sh # UI de visualización
|
|
183
|
+
│ └── show-notification.sh # Manejador de notificaciones
|
|
184
|
+
└── data/
|
|
185
|
+
├── achievements.json # Definiciones de logros
|
|
186
|
+
└── i18n/
|
|
187
|
+
├── en.json # English
|
|
188
|
+
├── zh.json # 中文
|
|
189
|
+
├── es.json # Español
|
|
190
|
+
├── ko.json # 한국어
|
|
191
|
+
└── ja.json # 日本語
|
|
192
|
+
```
|
|
193
|
+
|
|
194
|
+
### Cómo Funcionan los Hooks
|
|
195
|
+
|
|
196
|
+
El plugin registra dos hooks en Claude Code:
|
|
197
|
+
|
|
198
|
+
| Hook | Activador | Propósito |
|
|
199
|
+
|------|-----------|-----------|
|
|
200
|
+
| `PostToolUse` | Después de ejecutar herramienta | Verificar condiciones de logro |
|
|
201
|
+
| `Stop` | Al finalizar sesión | Guardar estadísticas de sesión |
|
|
202
|
+
|
|
203
|
+
### Cómo Funcionan los Comandos
|
|
204
|
+
|
|
205
|
+
Los comandos slash (`/achievements`) se implementan como **archivos Markdown** en `~/.claude/commands/`.
|
|
206
|
+
|
|
207
|
+
---
|
|
208
|
+
|
|
209
|
+
## Notificaciones
|
|
210
|
+
|
|
211
|
+
Las notificaciones del sistema se detectan automáticamente durante la instalación:
|
|
212
|
+
|
|
213
|
+
| SO | Método | Sonido |
|
|
214
|
+
|----|--------|--------|
|
|
215
|
+
| macOS | `osascript` | Glass |
|
|
216
|
+
| Linux | `notify-send` | Predeterminado del sistema |
|
|
217
|
+
| Windows | PowerShell | Predeterminado del sistema |
|
|
218
|
+
| Alternativa | Terminal | Ninguno |
|
|
219
|
+
|
|
220
|
+
### Instalar notify-send en Linux
|
|
221
|
+
|
|
222
|
+
```bash
|
|
223
|
+
# Ubuntu/Debian
|
|
224
|
+
sudo apt install libnotify-bin
|
|
225
|
+
|
|
226
|
+
# Fedora
|
|
227
|
+
sudo dnf install libnotify
|
|
228
|
+
|
|
229
|
+
# Arch
|
|
230
|
+
sudo pacman -S libnotify
|
|
231
|
+
```
|
|
232
|
+
|
|
233
|
+
---
|
|
234
|
+
|
|
235
|
+
## Configuración
|
|
236
|
+
|
|
237
|
+
La configuración se guarda en `~/.claude/achievements/state.json`:
|
|
238
|
+
|
|
239
|
+
```json
|
|
240
|
+
{
|
|
241
|
+
"settings": {
|
|
242
|
+
"language": "es",
|
|
243
|
+
"notifications": true,
|
|
244
|
+
"notification_style": "system"
|
|
245
|
+
},
|
|
246
|
+
"achievements": {},
|
|
247
|
+
"counters": {}
|
|
248
|
+
}
|
|
249
|
+
```
|
|
250
|
+
|
|
251
|
+
| Configuración | Valores | Descripción |
|
|
252
|
+
|---------------|---------|-------------|
|
|
253
|
+
| `language` | `"en"`, `"zh"`, `"es"`, `"ko"`, `"ja"` | Idioma de la interfaz |
|
|
254
|
+
| `notifications` | `true`, `false` | Activar/desactivar alertas |
|
|
255
|
+
| `notification_style` | `"system"`, `"terminal"`, `"both"` | Método de alerta |
|
|
256
|
+
|
|
257
|
+
---
|
|
258
|
+
|
|
259
|
+
## Solución de Problemas
|
|
260
|
+
|
|
261
|
+
<details>
|
|
262
|
+
<summary><b>¿Los logros no se desbloquean?</b></summary>
|
|
263
|
+
|
|
264
|
+
```bash
|
|
265
|
+
# Verificar que el plugin está instalado
|
|
266
|
+
ls ~/.claude/plugins/local/claude-code-achievements/
|
|
267
|
+
|
|
268
|
+
# Verificar que existe el archivo de estado
|
|
269
|
+
cat ~/.claude/achievements/state.json
|
|
270
|
+
|
|
271
|
+
# Reiniciar Claude Code después de la instalación para cargar los hooks
|
|
272
|
+
```
|
|
273
|
+
|
|
274
|
+
</details>
|
|
275
|
+
|
|
276
|
+
<details>
|
|
277
|
+
<summary><b>Reiniciar todo el progreso</b></summary>
|
|
278
|
+
|
|
279
|
+
```bash
|
|
280
|
+
rm ~/.claude/achievements/state.json
|
|
281
|
+
```
|
|
282
|
+
|
|
283
|
+
</details>
|
|
284
|
+
|
|
285
|
+
<details>
|
|
286
|
+
<summary><b>Reinstalar el plugin</b></summary>
|
|
287
|
+
|
|
288
|
+
```bash
|
|
289
|
+
npx claude-code-achievements@latest
|
|
290
|
+
```
|
|
291
|
+
|
|
292
|
+
</details>
|
|
293
|
+
|
|
294
|
+
---
|
|
295
|
+
|
|
296
|
+
## Contribuir
|
|
297
|
+
|
|
298
|
+
¡Las contribuciones son bienvenidas! Ideas:
|
|
299
|
+
|
|
300
|
+
- Nuevos logros
|
|
301
|
+
- Nuevas traducciones de idiomas
|
|
302
|
+
- Mejoras de UI
|
|
303
|
+
- Corrección de errores
|
|
304
|
+
|
|
305
|
+
## Licencia
|
|
306
|
+
|
|
307
|
+
MIT © [subinium](https://github.com/subinium)
|
|
308
|
+
|
|
309
|
+
---
|
|
310
|
+
|
|
311
|
+
<div align="center">
|
|
312
|
+
|
|
313
|
+
**¡Feliz programación!**
|
|
314
|
+
|
|
315
|
+
</div>
|
package/README.ja.md
ADDED
|
@@ -0,0 +1,315 @@
|
|
|
1
|
+
<div align="center">
|
|
2
|
+
|
|
3
|
+
<img src="assets/icon.png" alt="Claude Code Achievements" width="120" height="120">
|
|
4
|
+
|
|
5
|
+
# Claude Code Achievements
|
|
6
|
+
|
|
7
|
+
**Steam スタイルの Claude Code アチーブメントシステム**
|
|
8
|
+
|
|
9
|
+
[](https://www.npmjs.com/package/claude-code-achievements)
|
|
10
|
+
[](LICENSE)
|
|
11
|
+
[](package.json)
|
|
12
|
+
|
|
13
|
+
コーディングの旅をゲーム化し、Claude Code の機能をマスターしながらアチーブメントを解除しよう!
|
|
14
|
+
|
|
15
|
+
[インストール](#インストール) · [使い方](#使い方) · [アチーブメント](#アチーブメント) · [仕組み](#アーキテクチャ)
|
|
16
|
+
|
|
17
|
+
**[English](README.md)** · **[中文](README.zh.md)** · **[Español](README.es.md)** · **[한국어](README.ko.md)**
|
|
18
|
+
|
|
19
|
+
</div>
|
|
20
|
+
|
|
21
|
+
---
|
|
22
|
+
|
|
23
|
+
## 機能
|
|
24
|
+
|
|
25
|
+
- **26 のアチーブメント**、4 つのカテゴリに分類
|
|
26
|
+
- **リアルタイム通知**、システムアラートまたはターミナル経由
|
|
27
|
+
- **多言語サポート**(EN / 中文 / ES / 한국어 / 日本語)
|
|
28
|
+
- **クロスプラットフォーム**(macOS / Linux / Windows)
|
|
29
|
+
- **グローバルインストール** - すべてのプロジェクトで自動的に動作
|
|
30
|
+
|
|
31
|
+
## インストール
|
|
32
|
+
|
|
33
|
+
```bash
|
|
34
|
+
npx claude-code-achievements
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
インタラクティブインストーラーが:
|
|
38
|
+
1. OS と通知機能を自動検出
|
|
39
|
+
2. 言語設定を確認
|
|
40
|
+
3. 通知スタイルを設定(システム/ターミナル/両方)
|
|
41
|
+
4. `~/.claude/plugins/local/` にグローバルインストール
|
|
42
|
+
|
|
43
|
+
> **注意:** このプラグインは**グローバルインストール**され、すべてのプロジェクトで自動的に動作します。
|
|
44
|
+
|
|
45
|
+
### 手動インストール
|
|
46
|
+
|
|
47
|
+
```bash
|
|
48
|
+
git clone https://github.com/subinium/claude-code-achievements.git
|
|
49
|
+
cd claude-code-achievements
|
|
50
|
+
node bin/install.js
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
## 使い方
|
|
54
|
+
|
|
55
|
+
| コマンド | 説明 |
|
|
56
|
+
|----------|------|
|
|
57
|
+
| `/achievements` | 解除済みアチーブメントを表示(デフォルト) |
|
|
58
|
+
| `/achievements locked` | 未解除アチーブメントとヒントを表示 |
|
|
59
|
+
| `/achievements all` | カテゴリ別に全アチーブメントを表示 |
|
|
60
|
+
| `/achievements-settings` | 言語や通知設定を変更 |
|
|
61
|
+
|
|
62
|
+
### カテゴリフィルター
|
|
63
|
+
|
|
64
|
+
```bash
|
|
65
|
+
/achievements basics # はじめに
|
|
66
|
+
/achievements workflow # ワークフロー
|
|
67
|
+
/achievements tools # パワーツール
|
|
68
|
+
/achievements mastery # マスタリー
|
|
69
|
+
```
|
|
70
|
+
|
|
71
|
+
## アチーブメント
|
|
72
|
+
|
|
73
|
+
<details>
|
|
74
|
+
<summary><b>はじめに</b>(4 アチーブメント)</summary>
|
|
75
|
+
|
|
76
|
+
| アチーブメント | 解除方法 |
|
|
77
|
+
|----------------|----------|
|
|
78
|
+
| ✏️ **ファーストタッチ** | 任意のファイルを編集 |
|
|
79
|
+
| 📝 **クリエイター** | 新しいファイルを作成 |
|
|
80
|
+
| 🔍 **コードディテクティブ** | Glob または Grep でコードベースを検索 |
|
|
81
|
+
| 📋 **プロジェクトキュレーター** | `CLAUDE.md` を作成してプロジェクトコンテキストを設定 |
|
|
82
|
+
|
|
83
|
+
</details>
|
|
84
|
+
|
|
85
|
+
<details>
|
|
86
|
+
<summary><b>ワークフロー</b>(8 アチーブメント)</summary>
|
|
87
|
+
|
|
88
|
+
| アチーブメント | 解除方法 |
|
|
89
|
+
|----------------|----------|
|
|
90
|
+
| 📋 **タスクプランナー** | TodoWrite でタスク管理 |
|
|
91
|
+
| 🎯 **戦略的思考者** | Plan モードを使用(`Shift+Tab` を 2 回) |
|
|
92
|
+
| 🗣️ **コミュニケーター** | Claude が `AskUserQuestion` で要件を確認 |
|
|
93
|
+
| 🌍 **グローバルキュレーター** | `~/.claude/CLAUDE.md` を設定 |
|
|
94
|
+
| 📦 **バージョン管理者** | Claude と一緒にコミット |
|
|
95
|
+
| 🚀 **シップイット!** | リモートリポジトリにプッシュ |
|
|
96
|
+
| 🧪 **品質ガーディアン** | Claude と一緒にテストを実行 |
|
|
97
|
+
| 🚦 **CI/CD パイオニア** | GitHub Actions ワークフローを作成 |
|
|
98
|
+
|
|
99
|
+
</details>
|
|
100
|
+
|
|
101
|
+
<details>
|
|
102
|
+
<summary><b>パワーツール</b>(9 アチーブメント)</summary>
|
|
103
|
+
|
|
104
|
+
| アチーブメント | 解除方法 |
|
|
105
|
+
|----------------|----------|
|
|
106
|
+
| 🎨 **ビジュアルインスペクター** | 画像やスクリーンショットを分析 |
|
|
107
|
+
| 📡 **ドキュメントハンター** | Web ページを取得して分析 |
|
|
108
|
+
| 🤖 **デリゲーションマスター** | `Task` ツールでサブエージェントを使用 |
|
|
109
|
+
| 🔌 **MCP パイオニア** | 任意の MCP ツールを使用 |
|
|
110
|
+
| 🌐 **ウェブエクスプローラー** | `WebSearch` ツールを使用 |
|
|
111
|
+
| ⚡ **スキルマスター** | スラッシュコマンドスキルを使用 |
|
|
112
|
+
| ⚙️ **カスタマイザー** | Claude Code の設定を変更 |
|
|
113
|
+
| 📜 **スキルクリエイター** | `.claude/skills/` にカスタムスキルを作成 |
|
|
114
|
+
| ⌨️ **コマンドクラフター** | カスタムスラッシュコマンドを作成 |
|
|
115
|
+
|
|
116
|
+
</details>
|
|
117
|
+
|
|
118
|
+
<details>
|
|
119
|
+
<summary><b>マスタリー</b>(5 アチーブメント)</summary>
|
|
120
|
+
|
|
121
|
+
| アチーブメント | 解除方法 |
|
|
122
|
+
|----------------|----------|
|
|
123
|
+
| 🪝 **オートメーションアーキテクト** | Claude Code フックを設定 |
|
|
124
|
+
| 🔗 **MCP コネクター** | `.mcp.json` で統合を設定 |
|
|
125
|
+
| 🤖 **エージェントアーキテクト** | `.claude/agents/` にカスタムエージェントを作成 |
|
|
126
|
+
| 🛡️ **セキュリティガード** | セキュリティ権限を設定 |
|
|
127
|
+
| 🔄 **ループマスター** | 自律コーディングループを開始 |
|
|
128
|
+
|
|
129
|
+
</details>
|
|
130
|
+
|
|
131
|
+
---
|
|
132
|
+
|
|
133
|
+
## アーキテクチャ
|
|
134
|
+
|
|
135
|
+
このプラグインは **Claude Code のフックシステム** を使用してアクションをリアルタイムで追跡します。
|
|
136
|
+
|
|
137
|
+
```
|
|
138
|
+
┌─────────────────────────────────────────────────────────────┐
|
|
139
|
+
│ CLAUDE CODE セッション │
|
|
140
|
+
├─────────────────────────────────────────────────────────────┤
|
|
141
|
+
│ │
|
|
142
|
+
│ あなた: 「設定ファイルを編集して」 │
|
|
143
|
+
│ │ │
|
|
144
|
+
│ ▼ │
|
|
145
|
+
│ ┌─────────────────────────────────────┐ │
|
|
146
|
+
│ │ Claude が Edit ツールを使用 │ │
|
|
147
|
+
│ └─────────────────────────────────────┘ │
|
|
148
|
+
│ │ │
|
|
149
|
+
│ ▼ │
|
|
150
|
+
│ ┌─────────────────────────────────────┐ │
|
|
151
|
+
│ │ PostToolUse フックがトリガー │◄── hooks.json │
|
|
152
|
+
│ │ → track-achievement.sh │ │
|
|
153
|
+
│ └─────────────────────────────────────┘ │
|
|
154
|
+
│ │ │
|
|
155
|
+
│ ┌──────────┴──────────┐ │
|
|
156
|
+
│ ▼ ▼ │
|
|
157
|
+
│ ┌───────────┐ ┌───────────┐ │
|
|
158
|
+
│ │ マッチ! │ │ マッチなし │ │
|
|
159
|
+
│ │ │ │ │ │
|
|
160
|
+
│ │ 解除 │ │ 継続 │ │
|
|
161
|
+
│ │ 通知 │ └───────────┘ │
|
|
162
|
+
│ │ 保存 │ │
|
|
163
|
+
│ └───────────┘ │
|
|
164
|
+
│ │
|
|
165
|
+
└─────────────────────────────────────────────────────────────┘
|
|
166
|
+
```
|
|
167
|
+
|
|
168
|
+
### プラグイン構造
|
|
169
|
+
|
|
170
|
+
```
|
|
171
|
+
~/.claude/plugins/local/claude-code-achievements/
|
|
172
|
+
├── .claude-plugin/
|
|
173
|
+
│ └── plugin.json # プラグインメタデータ
|
|
174
|
+
├── hooks/
|
|
175
|
+
│ ├── hooks.json # フック定義 (PostToolUse, Stop)
|
|
176
|
+
│ ├── track-achievement.sh # メイン追跡ロジック
|
|
177
|
+
│ └── track-stop.sh # セッション終了ハンドラー
|
|
178
|
+
├── commands/
|
|
179
|
+
│ ├── achievements.md # /achievements コマンド
|
|
180
|
+
│ └── achievements-settings.md
|
|
181
|
+
├── scripts/
|
|
182
|
+
│ ├── show-achievements.sh # 表示 UI
|
|
183
|
+
│ └── show-notification.sh # 通知ハンドラー
|
|
184
|
+
└── data/
|
|
185
|
+
├── achievements.json # アチーブメント定義
|
|
186
|
+
└── i18n/
|
|
187
|
+
├── en.json # English
|
|
188
|
+
├── zh.json # 中文
|
|
189
|
+
├── es.json # Español
|
|
190
|
+
├── ko.json # 한국어
|
|
191
|
+
└── ja.json # 日本語
|
|
192
|
+
```
|
|
193
|
+
|
|
194
|
+
### フックの仕組み
|
|
195
|
+
|
|
196
|
+
プラグインは Claude Code に 2 つのフックを登録します:
|
|
197
|
+
|
|
198
|
+
| フック | トリガー | 目的 |
|
|
199
|
+
|--------|----------|------|
|
|
200
|
+
| `PostToolUse` | ツール実行後 | アチーブメント条件の確認 |
|
|
201
|
+
| `Stop` | セッション終了時 | セッション統計の保存 |
|
|
202
|
+
|
|
203
|
+
### コマンドの仕組み
|
|
204
|
+
|
|
205
|
+
スラッシュコマンド(`/achievements`)は `~/.claude/commands/` にある**マークダウンファイル**として実装されています。
|
|
206
|
+
|
|
207
|
+
---
|
|
208
|
+
|
|
209
|
+
## 通知
|
|
210
|
+
|
|
211
|
+
インストール時にシステム通知が自動検出されます:
|
|
212
|
+
|
|
213
|
+
| OS | 方法 | サウンド |
|
|
214
|
+
|----|------|----------|
|
|
215
|
+
| macOS | `osascript` | Glass |
|
|
216
|
+
| Linux | `notify-send` | システムデフォルト |
|
|
217
|
+
| Windows | PowerShell | システムデフォルト |
|
|
218
|
+
| フォールバック | ターミナル | なし |
|
|
219
|
+
|
|
220
|
+
### Linux で notify-send をインストール
|
|
221
|
+
|
|
222
|
+
```bash
|
|
223
|
+
# Ubuntu/Debian
|
|
224
|
+
sudo apt install libnotify-bin
|
|
225
|
+
|
|
226
|
+
# Fedora
|
|
227
|
+
sudo dnf install libnotify
|
|
228
|
+
|
|
229
|
+
# Arch
|
|
230
|
+
sudo pacman -S libnotify
|
|
231
|
+
```
|
|
232
|
+
|
|
233
|
+
---
|
|
234
|
+
|
|
235
|
+
## 設定
|
|
236
|
+
|
|
237
|
+
設定は `~/.claude/achievements/state.json` に保存されます:
|
|
238
|
+
|
|
239
|
+
```json
|
|
240
|
+
{
|
|
241
|
+
"settings": {
|
|
242
|
+
"language": "ja",
|
|
243
|
+
"notifications": true,
|
|
244
|
+
"notification_style": "system"
|
|
245
|
+
},
|
|
246
|
+
"achievements": {},
|
|
247
|
+
"counters": {}
|
|
248
|
+
}
|
|
249
|
+
```
|
|
250
|
+
|
|
251
|
+
| 設定 | 値 | 説明 |
|
|
252
|
+
|------|-----|------|
|
|
253
|
+
| `language` | `"en"`, `"zh"`, `"es"`, `"ko"`, `"ja"` | UI 言語 |
|
|
254
|
+
| `notifications` | `true`, `false` | アラートの有効/無効 |
|
|
255
|
+
| `notification_style` | `"system"`, `"terminal"`, `"both"` | アラート方法 |
|
|
256
|
+
|
|
257
|
+
---
|
|
258
|
+
|
|
259
|
+
## トラブルシューティング
|
|
260
|
+
|
|
261
|
+
<details>
|
|
262
|
+
<summary><b>アチーブメントが解除されない?</b></summary>
|
|
263
|
+
|
|
264
|
+
```bash
|
|
265
|
+
# プラグインがインストールされているか確認
|
|
266
|
+
ls ~/.claude/plugins/local/claude-code-achievements/
|
|
267
|
+
|
|
268
|
+
# 状態ファイルが存在するか確認
|
|
269
|
+
cat ~/.claude/achievements/state.json
|
|
270
|
+
|
|
271
|
+
# インストール後に Claude Code を再起動してフックをロード
|
|
272
|
+
```
|
|
273
|
+
|
|
274
|
+
</details>
|
|
275
|
+
|
|
276
|
+
<details>
|
|
277
|
+
<summary><b>進捗をリセット</b></summary>
|
|
278
|
+
|
|
279
|
+
```bash
|
|
280
|
+
rm ~/.claude/achievements/state.json
|
|
281
|
+
```
|
|
282
|
+
|
|
283
|
+
</details>
|
|
284
|
+
|
|
285
|
+
<details>
|
|
286
|
+
<summary><b>プラグインを再インストール</b></summary>
|
|
287
|
+
|
|
288
|
+
```bash
|
|
289
|
+
npx claude-code-achievements@latest
|
|
290
|
+
```
|
|
291
|
+
|
|
292
|
+
</details>
|
|
293
|
+
|
|
294
|
+
---
|
|
295
|
+
|
|
296
|
+
## 貢献
|
|
297
|
+
|
|
298
|
+
貢献を歓迎します!アイデア:
|
|
299
|
+
|
|
300
|
+
- 新しいアチーブメント
|
|
301
|
+
- 新しい言語翻訳
|
|
302
|
+
- UI の改善
|
|
303
|
+
- バグ修正
|
|
304
|
+
|
|
305
|
+
## ライセンス
|
|
306
|
+
|
|
307
|
+
MIT © [subinium](https://github.com/subinium)
|
|
308
|
+
|
|
309
|
+
---
|
|
310
|
+
|
|
311
|
+
<div align="center">
|
|
312
|
+
|
|
313
|
+
**Happy coding!**
|
|
314
|
+
|
|
315
|
+
</div>
|