illustrator-mcp-server 1.3.2 → 1.5.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/README.de.md +539 -0
- package/README.es.md +539 -0
- package/README.fr.md +539 -0
- package/README.ja.md +120 -10
- package/README.ko.md +539 -0
- package/README.md +119 -10
- package/README.pt-BR.md +539 -0
- package/README.zh-CN.md +539 -0
- package/dist/bundle.cjs +621 -328
- package/dist/executor/file-transport.d.ts.map +1 -1
- package/dist/executor/file-transport.js +11 -1
- package/dist/executor/file-transport.js.map +1 -1
- package/dist/jsx/helpers/common.jsx +63 -6
- package/dist/tools/export/export-pdf.d.ts.map +1 -1
- package/dist/tools/export/export-pdf.js +2 -1
- package/dist/tools/export/export-pdf.js.map +1 -1
- package/dist/tools/export/export.d.ts.map +1 -1
- package/dist/tools/export/export.js +54 -3
- package/dist/tools/export/export.js.map +1 -1
- package/dist/tools/modify/align-objects.d.ts.map +1 -1
- package/dist/tools/modify/align-objects.js +4 -5
- package/dist/tools/modify/align-objects.js.map +1 -1
- package/dist/tools/modify/apply-color-profile.d.ts.map +1 -1
- package/dist/tools/modify/apply-color-profile.js +2 -1
- package/dist/tools/modify/apply-color-profile.js.map +1 -1
- package/dist/tools/modify/apply-graphic-style.d.ts.map +1 -1
- package/dist/tools/modify/apply-graphic-style.js +3 -2
- package/dist/tools/modify/apply-graphic-style.js.map +1 -1
- package/dist/tools/modify/apply-text-style.d.ts.map +1 -1
- package/dist/tools/modify/apply-text-style.js +3 -2
- package/dist/tools/modify/apply-text-style.js.map +1 -1
- package/dist/tools/modify/close-document.d.ts.map +1 -1
- package/dist/tools/modify/close-document.js +2 -1
- package/dist/tools/modify/close-document.js.map +1 -1
- package/dist/tools/modify/convert-to-outlines.d.ts.map +1 -1
- package/dist/tools/modify/convert-to-outlines.js +2 -1
- package/dist/tools/modify/convert-to-outlines.js.map +1 -1
- package/dist/tools/modify/create-crop-marks.d.ts.map +1 -1
- package/dist/tools/modify/create-crop-marks.js +34 -3
- package/dist/tools/modify/create-crop-marks.js.map +1 -1
- package/dist/tools/modify/create-document.d.ts.map +1 -1
- package/dist/tools/modify/create-document.js +2 -1
- package/dist/tools/modify/create-document.js.map +1 -1
- package/dist/tools/modify/create-ellipse.js +1 -1
- package/dist/tools/modify/create-gradient.d.ts.map +1 -1
- package/dist/tools/modify/create-gradient.js +2 -1
- package/dist/tools/modify/create-gradient.js.map +1 -1
- package/dist/tools/modify/create-line.js +1 -1
- package/dist/tools/modify/create-path-text.d.ts.map +1 -1
- package/dist/tools/modify/create-path-text.js +2 -1
- package/dist/tools/modify/create-path-text.js.map +1 -1
- package/dist/tools/modify/create-path.js +1 -1
- package/dist/tools/modify/create-rectangle.js +1 -1
- package/dist/tools/modify/create-text-frame.d.ts.map +1 -1
- package/dist/tools/modify/create-text-frame.js +4 -6
- package/dist/tools/modify/create-text-frame.js.map +1 -1
- package/dist/tools/modify/duplicate-objects.d.ts.map +1 -1
- package/dist/tools/modify/duplicate-objects.js +17 -3
- package/dist/tools/modify/duplicate-objects.js.map +1 -1
- package/dist/tools/modify/group-objects.d.ts.map +1 -1
- package/dist/tools/modify/group-objects.js +2 -1
- package/dist/tools/modify/group-objects.js.map +1 -1
- package/dist/tools/modify/import-svg-as-editable.d.ts +3 -0
- package/dist/tools/modify/import-svg-as-editable.d.ts.map +1 -0
- package/dist/tools/modify/import-svg-as-editable.js +247 -0
- package/dist/tools/modify/import-svg-as-editable.js.map +1 -0
- package/dist/tools/modify/manage-artboards.d.ts.map +1 -1
- package/dist/tools/modify/manage-artboards.js +9 -2
- package/dist/tools/modify/manage-artboards.js.map +1 -1
- package/dist/tools/modify/manage-datasets.d.ts.map +1 -1
- package/dist/tools/modify/manage-datasets.js +2 -1
- package/dist/tools/modify/manage-datasets.js.map +1 -1
- package/dist/tools/modify/manage-layers.d.ts.map +1 -1
- package/dist/tools/modify/manage-layers.js +2 -1
- package/dist/tools/modify/manage-layers.js.map +1 -1
- package/dist/tools/modify/manage-linked-images.d.ts.map +1 -1
- package/dist/tools/modify/manage-linked-images.js +2 -1
- package/dist/tools/modify/manage-linked-images.js.map +1 -1
- package/dist/tools/modify/manage-swatches.d.ts.map +1 -1
- package/dist/tools/modify/manage-swatches.js +2 -1
- package/dist/tools/modify/manage-swatches.js.map +1 -1
- package/dist/tools/modify/modify-object.d.ts.map +1 -1
- package/dist/tools/modify/modify-object.js +22 -17
- package/dist/tools/modify/modify-object.js.map +1 -1
- package/dist/tools/modify/move-to-layer.d.ts.map +1 -1
- package/dist/tools/modify/move-to-layer.js +2 -1
- package/dist/tools/modify/move-to-layer.js.map +1 -1
- package/dist/tools/modify/open-document.d.ts.map +1 -1
- package/dist/tools/modify/open-document.js +2 -1
- package/dist/tools/modify/open-document.js.map +1 -1
- package/dist/tools/modify/place-color-chips.d.ts.map +1 -1
- package/dist/tools/modify/place-color-chips.js +4 -5
- package/dist/tools/modify/place-color-chips.js.map +1 -1
- package/dist/tools/modify/place-image.d.ts.map +1 -1
- package/dist/tools/modify/place-image.js +22 -8
- package/dist/tools/modify/place-image.js.map +1 -1
- package/dist/tools/modify/place-style-guide.d.ts.map +1 -1
- package/dist/tools/modify/place-style-guide.js +4 -5
- package/dist/tools/modify/place-style-guide.js.map +1 -1
- package/dist/tools/modify/place-symbol.d.ts.map +1 -1
- package/dist/tools/modify/place-symbol.js +2 -1
- package/dist/tools/modify/place-symbol.js.map +1 -1
- package/dist/tools/modify/replace-color.d.ts.map +1 -1
- package/dist/tools/modify/replace-color.js +2 -1
- package/dist/tools/modify/replace-color.js.map +1 -1
- package/dist/tools/modify/resize-for-variation.d.ts.map +1 -1
- package/dist/tools/modify/resize-for-variation.js +4 -5
- package/dist/tools/modify/resize-for-variation.js.map +1 -1
- package/dist/tools/modify/save-document.d.ts.map +1 -1
- package/dist/tools/modify/save-document.js +2 -1
- package/dist/tools/modify/save-document.js.map +1 -1
- package/dist/tools/modify/select-objects.d.ts.map +1 -1
- package/dist/tools/modify/select-objects.js +2 -1
- package/dist/tools/modify/select-objects.js.map +1 -1
- package/dist/tools/modify/set-z-order.d.ts.map +1 -1
- package/dist/tools/modify/set-z-order.js +2 -1
- package/dist/tools/modify/set-z-order.js.map +1 -1
- package/dist/tools/modify/undo.d.ts.map +1 -1
- package/dist/tools/modify/undo.js +2 -1
- package/dist/tools/modify/undo.js.map +1 -1
- package/dist/tools/modify/ungroup-objects.d.ts.map +1 -1
- package/dist/tools/modify/ungroup-objects.js +2 -1
- package/dist/tools/modify/ungroup-objects.js.map +1 -1
- package/dist/tools/read/check-contrast.d.ts.map +1 -1
- package/dist/tools/read/check-contrast.js +14 -27
- package/dist/tools/read/check-contrast.js.map +1 -1
- package/dist/tools/read/convert-coordinate.d.ts.map +1 -1
- package/dist/tools/read/convert-coordinate.js +2 -1
- package/dist/tools/read/convert-coordinate.js.map +1 -1
- package/dist/tools/read/extract-design-tokens.d.ts.map +1 -1
- package/dist/tools/read/extract-design-tokens.js +2 -1
- package/dist/tools/read/extract-design-tokens.js.map +1 -1
- package/dist/tools/read/find-objects.d.ts.map +1 -1
- package/dist/tools/read/find-objects.js +3 -7
- package/dist/tools/read/find-objects.js.map +1 -1
- package/dist/tools/read/get-artboards.js +1 -1
- package/dist/tools/read/get-colors.d.ts.map +1 -1
- package/dist/tools/read/get-colors.js +2 -1
- package/dist/tools/read/get-colors.js.map +1 -1
- package/dist/tools/read/get-document-info.d.ts.map +1 -1
- package/dist/tools/read/get-document-info.js +2 -3
- package/dist/tools/read/get-document-info.js.map +1 -1
- package/dist/tools/read/get-document-structure.d.ts.map +1 -1
- package/dist/tools/read/get-document-structure.js +3 -7
- package/dist/tools/read/get-document-structure.js.map +1 -1
- package/dist/tools/read/get-effects.d.ts.map +1 -1
- package/dist/tools/read/get-effects.js +3 -7
- package/dist/tools/read/get-effects.js.map +1 -1
- package/dist/tools/read/get-groups.d.ts.map +1 -1
- package/dist/tools/read/get-groups.js +3 -7
- package/dist/tools/read/get-groups.js.map +1 -1
- package/dist/tools/read/get-guidelines.d.ts.map +1 -1
- package/dist/tools/read/get-guidelines.js +3 -7
- package/dist/tools/read/get-guidelines.js.map +1 -1
- package/dist/tools/read/get-images.d.ts.map +1 -1
- package/dist/tools/read/get-images.js +40 -13
- package/dist/tools/read/get-images.js.map +1 -1
- package/dist/tools/read/get-layers.js +1 -1
- package/dist/tools/read/get-overprint-info.d.ts.map +1 -1
- package/dist/tools/read/get-overprint-info.js +2 -3
- package/dist/tools/read/get-overprint-info.js.map +1 -1
- package/dist/tools/read/get-path-items.d.ts.map +1 -1
- package/dist/tools/read/get-path-items.js +11 -9
- package/dist/tools/read/get-path-items.js.map +1 -1
- package/dist/tools/read/get-separation-info.d.ts.map +1 -1
- package/dist/tools/read/get-separation-info.js +2 -3
- package/dist/tools/read/get-separation-info.js.map +1 -1
- package/dist/tools/read/get-symbols.d.ts.map +1 -1
- package/dist/tools/read/get-symbols.js +3 -7
- package/dist/tools/read/get-symbols.js.map +1 -1
- package/dist/tools/read/get-text-frame-detail.d.ts.map +1 -1
- package/dist/tools/read/get-text-frame-detail.js +2 -1
- package/dist/tools/read/get-text-frame-detail.js.map +1 -1
- package/dist/tools/read/list-fonts.d.ts.map +1 -1
- package/dist/tools/read/list-fonts.js +2 -1
- package/dist/tools/read/list-fonts.js.map +1 -1
- package/dist/tools/read/list-text-frames.d.ts.map +1 -1
- package/dist/tools/read/list-text-frames.js +3 -5
- package/dist/tools/read/list-text-frames.js.map +1 -1
- package/dist/tools/registry.d.ts.map +1 -1
- package/dist/tools/registry.js +2 -0
- package/dist/tools/registry.js.map +1 -1
- package/dist/tools/session.d.ts.map +1 -1
- package/dist/tools/session.js +5 -1
- package/dist/tools/session.js.map +1 -1
- package/dist/tools/utility/check-text-consistency.d.ts.map +1 -1
- package/dist/tools/utility/check-text-consistency.js +14 -20
- package/dist/tools/utility/check-text-consistency.js.map +1 -1
- package/dist/tools/utility/preflight-check.d.ts.map +1 -1
- package/dist/tools/utility/preflight-check.js +48 -20
- package/dist/tools/utility/preflight-check.js.map +1 -1
- package/dist/tools/utility/set-workflow.js +1 -1
- package/dist/tools/utility/set-workflow.js.map +1 -1
- package/package.json +1 -1
package/README.fr.md
ADDED
|
@@ -0,0 +1,539 @@
|
|
|
1
|
+
[🇺🇸 English](README.md) | [🇯🇵 日本語](README.ja.md) | [🇨🇳 简体中文](README.zh-CN.md) | [🇰🇷 한국어](README.ko.md) | [🇪🇸 Español](README.es.md) | [🇩🇪 Deutsch](README.de.md) | **🇫🇷 Français** | [🇵🇹 Português (BR)](README.pt-BR.md)
|
|
2
|
+
|
|
3
|
+
# Illustrator MCP Server
|
|
4
|
+
|
|
5
|
+
[](https://www.npmjs.com/package/illustrator-mcp-server)
|
|
6
|
+
[](LICENSE)
|
|
7
|
+
[]()
|
|
8
|
+
[](https://www.adobe.com/products/illustrator.html)
|
|
9
|
+
[](https://modelcontextprotocol.io/)
|
|
10
|
+
[](https://ko-fi.com/cyocun)
|
|
11
|
+
|
|
12
|
+
Un serveur [MCP (Model Context Protocol)](https://modelcontextprotocol.io/) pour lire, manipuler et exporter les données de conception Adobe Illustrator — avec 63 outils intégrés.
|
|
13
|
+
|
|
14
|
+
Pilotez Illustrator directement depuis des assistants IA comme Claude — extrayez les informations de conception pour l'implémentation web, vérifiez les données prêtes à l'impression et exportez vos assets.
|
|
15
|
+
|
|
16
|
+
[](https://glama.ai/mcp/servers/ie3jp/illustrator-mcp-server)
|
|
17
|
+
|
|
18
|
+
---
|
|
19
|
+
|
|
20
|
+
## 🎨 Galerie
|
|
21
|
+
|
|
22
|
+
Toutes les créations ci-dessous ont été entièrement réalisées par Claude via une conversation en langage naturel — aucune manipulation manuelle d'Illustrator.
|
|
23
|
+
|
|
24
|
+
<table>
|
|
25
|
+
<tr>
|
|
26
|
+
<td align="center"><img src="docs/images/example-event-poster.png" width="300" alt="Affiche d'événement — SYNC TOKYO 2026" /><br><b>Affiche d'événement</b></td>
|
|
27
|
+
<td align="center"><img src="docs/images/example-logo-concepts.png" width="300" alt="Concepts de logo — Slow Drip Coffee Co." /><br><b>Concepts de logo</b></td>
|
|
28
|
+
</tr>
|
|
29
|
+
<tr>
|
|
30
|
+
<td align="center"><img src="docs/images/example-business-card.png" width="300" alt="Carte de visite — KUMO Studio" /><br><b>Carte de visite</b></td>
|
|
31
|
+
<td align="center"><img src="docs/images/example-twilight-geometry.png" width="300" alt="Twilight Geometry — paysage géométrique abstrait" /><br><b>Twilight Geometry</b></td>
|
|
32
|
+
</tr>
|
|
33
|
+
</table>
|
|
34
|
+
|
|
35
|
+
> Voir les [décompositions détaillées](#exemple--mire-de-test-smpte) ci-dessous pour les prompts, l'utilisation des outils et la structure des plans de travail.
|
|
36
|
+
|
|
37
|
+
---
|
|
38
|
+
|
|
39
|
+
> [!TIP]
|
|
40
|
+
> Développer et maintenir cet outil demande du temps et des ressources.
|
|
41
|
+
> Si cela aide votre workflow, votre soutien compte beaucoup — [☕ offrez-moi un café !](https://ko-fi.com/cyocun)
|
|
42
|
+
|
|
43
|
+
---
|
|
44
|
+
|
|
45
|
+
## 🚀 Démarrage rapide
|
|
46
|
+
|
|
47
|
+
### 🛠️ Claude Code
|
|
48
|
+
|
|
49
|
+
Nécessite [Node.js 20+](https://nodejs.org/).
|
|
50
|
+
|
|
51
|
+
```bash
|
|
52
|
+
claude mcp add illustrator-mcp -- npx illustrator-mcp-server
|
|
53
|
+
```
|
|
54
|
+
|
|
55
|
+
### 🖥️ Claude Desktop
|
|
56
|
+
|
|
57
|
+
1. Téléchargez **`illustrator-mcp-server.mcpb`** depuis [GitHub Releases](https://github.com/ie3jp/illustrator-mcp-server/releases/latest)
|
|
58
|
+
2. Ouvrez Claude Desktop → **Settings** → **Extensions**
|
|
59
|
+
3. Glissez-déposez le fichier `.mcpb` dans le panneau Extensions
|
|
60
|
+
4. Cliquez sur le bouton **Install**
|
|
61
|
+
|
|
62
|
+
<details>
|
|
63
|
+
<summary><strong>Alternative : configuration manuelle (toujours à jour via npx)</strong></summary>
|
|
64
|
+
|
|
65
|
+
> [!NOTE]
|
|
66
|
+
> L'extension `.mcpb` ne se met pas à jour automatiquement. Pour mettre à jour, téléchargez la nouvelle version et réinstallez-la. Si vous préférez les mises à jour automatiques, utilisez plutôt la méthode npx ci-dessous.
|
|
67
|
+
|
|
68
|
+
Nécessite [Node.js 20+](https://nodejs.org/). Ouvrez le fichier de configuration et ajoutez les paramètres de connexion.
|
|
69
|
+
|
|
70
|
+
#### 1. Ouvrir le fichier de configuration
|
|
71
|
+
|
|
72
|
+
Depuis la barre de menu de Claude Desktop :
|
|
73
|
+
|
|
74
|
+
**Claude** → **Settings...** → **Developer** (dans la barre latérale gauche) → Cliquez sur le bouton **Edit Config**
|
|
75
|
+
|
|
76
|
+
#### 2. Ajouter les paramètres
|
|
77
|
+
|
|
78
|
+
```json
|
|
79
|
+
{
|
|
80
|
+
"mcpServers": {
|
|
81
|
+
"illustrator": {
|
|
82
|
+
"command": "npx",
|
|
83
|
+
"args": ["illustrator-mcp-server"]
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
> [!NOTE]
|
|
90
|
+
> Si vous avez installé Node.js via un gestionnaire de versions (nvm, mise, fnm, etc.), Claude Desktop peut ne pas trouver `npx`. Dans ce cas, utilisez le chemin complet :
|
|
91
|
+
> ```json
|
|
92
|
+
> "command": "/full/path/to/npx"
|
|
93
|
+
> ```
|
|
94
|
+
> Exécutez `which npx` dans votre terminal pour trouver le chemin.
|
|
95
|
+
|
|
96
|
+
#### 3. Enregistrer et redémarrer
|
|
97
|
+
|
|
98
|
+
1. Enregistrez le fichier et fermez l'éditeur de texte
|
|
99
|
+
2. **Quittez complètement** Claude Desktop (⌘Q / Ctrl+Q) puis rouvrez-le
|
|
100
|
+
|
|
101
|
+
</details>
|
|
102
|
+
|
|
103
|
+
> [!CAUTION]
|
|
104
|
+
> L'IA peut faire des erreurs. Ne vous fiez pas trop au résultat — **un humain doit toujours effectuer la vérification finale des données à remettre**. L'utilisateur est responsable des résultats.
|
|
105
|
+
|
|
106
|
+
> [!NOTE]
|
|
107
|
+
> **macOS :** au premier lancement, autorisez l'accès à l'automatisation dans Réglages Système > Confidentialité et sécurité > Automatisation.
|
|
108
|
+
|
|
109
|
+
> [!NOTE]
|
|
110
|
+
> Les outils de modification et d'exportation mettent Illustrator au premier plan pendant leur exécution.
|
|
111
|
+
|
|
112
|
+
### Plusieurs versions d'Illustrator
|
|
113
|
+
|
|
114
|
+
Si plusieurs versions d'Illustrator sont installées, vous pouvez indiquer à Claude quelle version utiliser pendant la conversation. Dites simplement quelque chose comme « Utilise Illustrator 2024 » et l'outil `set_illustrator_version` ciblera cette version.
|
|
115
|
+
|
|
116
|
+
> [!NOTE]
|
|
117
|
+
> Si Illustrator est déjà en cours d'exécution, le serveur se connecte à l'instance en cours, indépendamment du paramètre de version. La version n'est utilisée que pour lancer la bonne version lorsqu'Illustrator n'est pas encore démarré.
|
|
118
|
+
|
|
119
|
+
---
|
|
120
|
+
|
|
121
|
+
## 🎬 Ce que vous pouvez faire
|
|
122
|
+
|
|
123
|
+
```
|
|
124
|
+
Toi : Montre-moi toutes les informations textuelles de ce document
|
|
125
|
+
Claude: → list_text_frames → get_text_frame_detail
|
|
126
|
+
Il y a 12 blocs de texte dans le document.
|
|
127
|
+
Le titre « My Design » utilise Noto Sans JP Bold 48px, couleur #333333 ...
|
|
128
|
+
```
|
|
129
|
+
|
|
130
|
+
```
|
|
131
|
+
Toi : Lance un contrôle préflight prépresse
|
|
132
|
+
Claude: → preflight_check
|
|
133
|
+
⚠ 2 avertissements :
|
|
134
|
+
- Image basse résolution : image_01.jpg (150dpi) — 300dpi ou plus recommandé
|
|
135
|
+
- Polices non vectorisées : 3 blocs de texte
|
|
136
|
+
```
|
|
137
|
+
|
|
138
|
+
```
|
|
139
|
+
Toi : Vérifie la cohérence du texte
|
|
140
|
+
Claude: → check_text_consistency
|
|
141
|
+
📝 Rapport de cohérence :
|
|
142
|
+
⚠ « Contact Us » vs « Contact us » — différence de casse
|
|
143
|
+
❌ « Lorem ipsum » (2 emplacements) — texte de remplissage restant
|
|
144
|
+
```
|
|
145
|
+
|
|
146
|
+
```
|
|
147
|
+
Toi : Crée des déclinaisons de bannière à partir de ce flyer A4
|
|
148
|
+
Claude: → get_document_info → resize_for_variation
|
|
149
|
+
3 déclinaisons de taille créées :
|
|
150
|
+
- 728×90 / 300×250 / 160×600
|
|
151
|
+
```
|
|
152
|
+
|
|
153
|
+
---
|
|
154
|
+
|
|
155
|
+
## 📖 Recettes
|
|
156
|
+
|
|
157
|
+
<details>
|
|
158
|
+
<summary><b>Extraire les couleurs et les polices pour le CSS</b></summary>
|
|
159
|
+
|
|
160
|
+
```
|
|
161
|
+
Toi : Résume les couleurs et la typographie de ce design
|
|
162
|
+
|
|
163
|
+
Claude: → get_colors → list_text_frames → get_text_frame_detail
|
|
164
|
+
|
|
165
|
+
■ Palette de couleurs
|
|
166
|
+
- Principale : #1A73E8 (CMYK : 85,50,0,0)
|
|
167
|
+
- Secondaire : #34A853
|
|
168
|
+
- Texte : #202124
|
|
169
|
+
- Fond : #FFFFFF
|
|
170
|
+
|
|
171
|
+
■ Typographie
|
|
172
|
+
- Titres : Noto Sans JP Bold / 32px
|
|
173
|
+
- Corps : Noto Sans JP Regular / 16px / line-height : 1.75
|
|
174
|
+
- Légendes : Noto Sans JP Medium / 12px
|
|
175
|
+
```
|
|
176
|
+
|
|
177
|
+
</details>
|
|
178
|
+
|
|
179
|
+
<details>
|
|
180
|
+
<summary><b>Exporter les plans de travail en SVG / PNG</b></summary>
|
|
181
|
+
|
|
182
|
+
```
|
|
183
|
+
Toi : Exporte tous les plans de travail en SVG avec le texte vectorisé
|
|
184
|
+
|
|
185
|
+
Claude: → get_artboards → convert_to_outlines → export (répété)
|
|
186
|
+
|
|
187
|
+
4 plans de travail exportés :
|
|
188
|
+
- /output/header.svg
|
|
189
|
+
- /output/hero.svg
|
|
190
|
+
- /output/feature.svg
|
|
191
|
+
- /output/footer.svg
|
|
192
|
+
```
|
|
193
|
+
|
|
194
|
+
</details>
|
|
195
|
+
|
|
196
|
+
<details>
|
|
197
|
+
<summary><b>Vérifier la conformité PDF/X-1a avant remise</b></summary>
|
|
198
|
+
|
|
199
|
+
```
|
|
200
|
+
Toi : Vérifie si ce document est conforme PDF/X-1a
|
|
201
|
+
|
|
202
|
+
Claude: → preflight_check (target_pdf_profile: "x1a")
|
|
203
|
+
|
|
204
|
+
❌ Erreurs de conformité PDF/X-1a :
|
|
205
|
+
- Transparence sur 3 objets (X-1a interdit la transparence)
|
|
206
|
+
- Couleurs RGB trouvées à 2 endroits (X-1a exige CMYK / ton direct uniquement)
|
|
207
|
+
|
|
208
|
+
⚠ Avertissements :
|
|
209
|
+
- 5 polices non vectorisées (incorporation recommandée)
|
|
210
|
+
- Image « photo_02.jpg » à 150dpi (300dpi recommandé)
|
|
211
|
+
```
|
|
212
|
+
|
|
213
|
+
</details>
|
|
214
|
+
|
|
215
|
+
<details>
|
|
216
|
+
<summary><b>Vérifier la qualité des images pour l'impression</b></summary>
|
|
217
|
+
|
|
218
|
+
```
|
|
219
|
+
Toi : Vérifie la qualité des images importées pour l'impression
|
|
220
|
+
|
|
221
|
+
Claude: → get_images (include_print_info: true)
|
|
222
|
+
|
|
223
|
+
■ Rapport de qualité des images :
|
|
224
|
+
✅ hero.psd — CMYK, 350dpi, échelle 98%
|
|
225
|
+
⚠ icon_set.png — RGB (incompatible avec le document CMYK), 300dpi, échelle 100%
|
|
226
|
+
❌ photo_bg.jpg — CMYK, 72dpi, échelle 400% (sur-agrandie)
|
|
227
|
+
→ À remplacer par une image de 300dpi+ à la taille réelle
|
|
228
|
+
```
|
|
229
|
+
|
|
230
|
+
</details>
|
|
231
|
+
|
|
232
|
+
<details>
|
|
233
|
+
<summary><b>Vérifier les ratios de contraste de couleur WCAG</b></summary>
|
|
234
|
+
|
|
235
|
+
```
|
|
236
|
+
Toi : Vérifie les ratios de contraste du texte
|
|
237
|
+
|
|
238
|
+
Claude: → check_contrast (auto_detect: true)
|
|
239
|
+
|
|
240
|
+
■ Rapport de contraste WCAG :
|
|
241
|
+
❌ « Caption » sur « gris clair » — 2.8:1 (AA échec)
|
|
242
|
+
⚠ « Subheading » sur « blanc » — 4.2:1 (AA Large OK, AA Normal échec)
|
|
243
|
+
✅ « Body text » sur « blanc » — 12.1:1 (AAA réussi)
|
|
244
|
+
```
|
|
245
|
+
|
|
246
|
+
</details>
|
|
247
|
+
|
|
248
|
+
---
|
|
249
|
+
|
|
250
|
+
## Modèles de workflow
|
|
251
|
+
|
|
252
|
+
Des modèles de workflow prédéfinis sont disponibles dans le sélecteur de prompts de Claude Desktop.
|
|
253
|
+
|
|
254
|
+
| Modèle | Description |
|
|
255
|
+
|----------|-------------|
|
|
256
|
+
| `quick-layout` | Collez du contenu textuel et Claude le dispose sur le plan de travail sous forme de titres, corps et légendes |
|
|
257
|
+
| `print-preflight-workflow` | Contrôle prépresse complet en 7 étapes (document → preflight → surimpression → séparations → images → couleurs → texte) |
|
|
258
|
+
|
|
259
|
+
---
|
|
260
|
+
|
|
261
|
+
## Référence des outils
|
|
262
|
+
|
|
263
|
+
### Outils de lecture (21)
|
|
264
|
+
|
|
265
|
+
<details>
|
|
266
|
+
<summary>Cliquez pour déployer</summary>
|
|
267
|
+
|
|
268
|
+
| Outil | Description |
|
|
269
|
+
|---|---|
|
|
270
|
+
| `get_document_info` | Métadonnées du document (dimensions, mode colorimétrique, profil, etc.) |
|
|
271
|
+
| `get_artboards` | Informations sur les plans de travail (position, taille, orientation) |
|
|
272
|
+
| `get_layers` | Structure des calques sous forme d'arbre |
|
|
273
|
+
| `get_document_structure` | Arbre complet : calques → groupes → objets en un seul appel |
|
|
274
|
+
| `list_text_frames` | Liste des blocs de texte (police, taille, nom de style) |
|
|
275
|
+
| `get_text_frame_detail` | Tous les attributs d'un bloc de texte précis (crénage, réglages de paragraphe, etc.) |
|
|
276
|
+
| `get_colors` | Informations sur les couleurs utilisées (nuanciers, dégradés, tons directs). `include_diagnostics` pour l'analyse d'impression |
|
|
277
|
+
| `get_path_items` | Données de tracés / formes (fond, contour, points d'ancrage) |
|
|
278
|
+
| `get_groups` | Groupes, masques d'écrêtage et structure des tracés transparents |
|
|
279
|
+
| `get_effects` | Informations sur les effets et l'aspect (opacité, mode de fusion) |
|
|
280
|
+
| `get_images` | Informations sur les images incorporées / liées (résolution, détection de liens rompus). `include_print_info` pour l'incompatibilité d'espace colorimétrique et le facteur d'échelle |
|
|
281
|
+
| `get_symbols` | Définitions et instances de symboles |
|
|
282
|
+
| `get_guidelines` | Informations sur les repères |
|
|
283
|
+
| `get_overprint_info` | Réglages de surimpression + détection K100 / noir riche et classification d'intention |
|
|
284
|
+
| `get_separation_info` | Informations de séparation des couleurs (plaques de quadrichromie CMYK + plaques de tons directs avec décomptes d'utilisation) |
|
|
285
|
+
| `get_selection` | Détails des objets actuellement sélectionnés |
|
|
286
|
+
| `find_objects` | Recherche par critères (nom, type, couleur, police, etc.) |
|
|
287
|
+
| `check_contrast` | Contrôle du ratio de contraste WCAG (manuel ou détection automatique des paires superposées) |
|
|
288
|
+
| `extract_design_tokens` | Extraction des design tokens au format CSS custom properties, JSON ou Tailwind config |
|
|
289
|
+
| `list_fonts` | Liste des polices disponibles dans Illustrator (aucun document requis) |
|
|
290
|
+
| `convert_coordinate` | Convertit les points entre les systèmes de coordonnées plan de travail et document |
|
|
291
|
+
|
|
292
|
+
</details>
|
|
293
|
+
|
|
294
|
+
### Outils de modification (38)
|
|
295
|
+
|
|
296
|
+
<details>
|
|
297
|
+
<summary>Cliquez pour déployer</summary>
|
|
298
|
+
|
|
299
|
+
| Outil | Description |
|
|
300
|
+
|---|---|
|
|
301
|
+
| `create_rectangle` | Crée un rectangle (coins arrondis pris en charge) |
|
|
302
|
+
| `create_ellipse` | Crée une ellipse |
|
|
303
|
+
| `create_line` | Crée une ligne |
|
|
304
|
+
| `create_text_frame` | Crée un bloc de texte (texte captif ou curviligne) |
|
|
305
|
+
| `create_path` | Crée un tracé personnalisé (avec poignées de Bézier) |
|
|
306
|
+
| `place_image` | Place un fichier image en lien ou incorporé |
|
|
307
|
+
| `modify_object` | Modifie les propriétés d'un objet existant |
|
|
308
|
+
| `convert_to_outlines` | Vectorise le texte |
|
|
309
|
+
| `assign_color_profile` | Attribue (marque) un profil colorimétrique (ne convertit pas les valeurs de couleur) |
|
|
310
|
+
| `create_document` | Crée un nouveau document (taille, mode colorimétrique) |
|
|
311
|
+
| `close_document` | Ferme le document actif |
|
|
312
|
+
| `resize_for_variation` | Crée des déclinaisons de taille à partir d'un plan de travail source (mise à l'échelle proportionnelle) |
|
|
313
|
+
| `align_objects` | Aligne et répartit plusieurs objets |
|
|
314
|
+
| `replace_color` | Recherche et remplace les couleurs dans le document (avec tolérance) |
|
|
315
|
+
| `manage_layers` | Ajoute, renomme, affiche/masque, verrouille/déverrouille, réorganise ou supprime des calques |
|
|
316
|
+
| `place_color_chips` | Extrait les couleurs uniques et place des pastilles de nuances hors du plan de travail |
|
|
317
|
+
| `save_document` | Enregistre ou enregistre sous le document actif |
|
|
318
|
+
| `open_document` | Ouvre un document depuis un chemin de fichier |
|
|
319
|
+
| `group_objects` | Groupe des objets (masques d'écrêtage pris en charge) |
|
|
320
|
+
| `ungroup_objects` | Dissocie un groupe, libérant ses enfants |
|
|
321
|
+
| `duplicate_objects` | Duplique des objets avec un décalage optionnel |
|
|
322
|
+
| `set_z_order` | Modifie l'ordre d'empilement (premier/arrière-plan) |
|
|
323
|
+
| `move_to_layer` | Déplace des objets vers un autre calque |
|
|
324
|
+
| `manage_artboards` | Ajoute, supprime, redimensionne, renomme, réorganise les plans de travail |
|
|
325
|
+
| `manage_swatches` | Ajoute, met à jour ou supprime des nuances |
|
|
326
|
+
| `manage_linked_images` | Relie ou incorpore les images importées |
|
|
327
|
+
| `manage_datasets` | Liste/applique/crée des jeux de données, importe/exporte des variables |
|
|
328
|
+
| `apply_graphic_style` | Applique un style graphique à des objets |
|
|
329
|
+
| `list_graphic_styles` | Liste tous les styles graphiques du document |
|
|
330
|
+
| `apply_text_style` | Applique un style de caractère ou de paragraphe au texte |
|
|
331
|
+
| `list_text_styles` | Liste tous les styles de caractère et de paragraphe |
|
|
332
|
+
| `create_gradient` | Crée des dégradés et les applique aux objets |
|
|
333
|
+
| `create_path_text` | Crée du texte le long d'un tracé |
|
|
334
|
+
| `place_symbol` | Place ou remplace des instances de symboles |
|
|
335
|
+
| `select_objects` | Sélectionne des objets par UUID (sélection multiple prise en charge) |
|
|
336
|
+
| `create_crop_marks` | Crée des traits de coupe (repères de rognage) avec détection automatique du style selon la locale (double filet japonais / filet simple occidental) |
|
|
337
|
+
| `place_style_guide` | Place un guide de style visuel hors du plan de travail (couleurs, polices, espacements, marges, interstices des repères) |
|
|
338
|
+
| `undo` | Opérations d'annulation/rétablissement (multi-étapes) |
|
|
339
|
+
|
|
340
|
+
</details>
|
|
341
|
+
|
|
342
|
+
### Outils d'exportation (2)
|
|
343
|
+
|
|
344
|
+
<details>
|
|
345
|
+
<summary>Cliquez pour déployer</summary>
|
|
346
|
+
|
|
347
|
+
| Outil | Description |
|
|
348
|
+
|---|---|
|
|
349
|
+
| `export` | Exportation SVG / PNG / JPG (par plan de travail, sélection ou UUID) |
|
|
350
|
+
| `export_pdf` | Exportation PDF prête à l'impression (traits de coupe, fond perdu, sous-échantillonnage sélectif, intention de sortie) |
|
|
351
|
+
|
|
352
|
+
</details>
|
|
353
|
+
|
|
354
|
+
### Utilitaires (3)
|
|
355
|
+
|
|
356
|
+
<details>
|
|
357
|
+
<summary>Cliquez pour déployer</summary>
|
|
358
|
+
|
|
359
|
+
| Outil | Description |
|
|
360
|
+
|---|---|
|
|
361
|
+
| `preflight_check` | Contrôle prépresse (mélange RGB, liens rompus, basse résolution, surimpression de blanc, interaction transparence+surimpression, conformité PDF/X, etc.) |
|
|
362
|
+
| `check_text_consistency` | Vérification de cohérence du texte (détection de texte de remplissage, variations de notation, liste complète du texte pour analyse par le LLM) |
|
|
363
|
+
| `set_workflow` | Définit le mode workflow (web/print) pour outrepasser le système de coordonnées détecté automatiquement |
|
|
364
|
+
|
|
365
|
+
</details>
|
|
366
|
+
|
|
367
|
+
---
|
|
368
|
+
|
|
369
|
+
## Système de coordonnées
|
|
370
|
+
|
|
371
|
+
Le serveur détecte automatiquement le système de coordonnées à partir du document :
|
|
372
|
+
|
|
373
|
+
| Type de document | Système de coordonnées | Origine | Axe Y |
|
|
374
|
+
|---|---|---|---|
|
|
375
|
+
| CMYK / Impression | `document` | Bas-gauche | Vers le haut |
|
|
376
|
+
| RGB / Web | `artboard-web` | Haut-gauche du plan de travail | Vers le bas |
|
|
377
|
+
|
|
378
|
+
- Les **documents CMYK** utilisent le système de coordonnées natif d'Illustrator, conforme aux attentes des designers print
|
|
379
|
+
- Les **documents RGB** utilisent un système de coordonnées de type web, plus facile à manipuler pour une IA
|
|
380
|
+
- Utilisez `set_workflow` pour outrepasser le système de coordonnées détecté automatiquement si nécessaire
|
|
381
|
+
- Toutes les réponses des outils incluent un champ `coordinateSystem` indiquant quel système est actif
|
|
382
|
+
|
|
383
|
+
---
|
|
384
|
+
|
|
385
|
+
## Exemple : mire de test SMPTE
|
|
386
|
+
|
|
387
|
+
Une mire de barres colorées SMPTE 1920×1080, créée entièrement via des instructions en langage naturel à Claude.
|
|
388
|
+
|
|
389
|
+
**Prompt :**
|
|
390
|
+
|
|
391
|
+
> Fais une mire de test vidéo 1920x1080
|
|
392
|
+
|
|
393
|
+
**Résultat :**
|
|
394
|
+
|
|
395
|
+
<img src="docs/images/example-smpte-test-pattern.png" width="720" alt="Mire de test de barres colorées SMPTE générée par Claude via illustrator-mcp-server" />
|
|
396
|
+
|
|
397
|
+
**Structure du plan de travail** (via `get_document_structure`) :
|
|
398
|
+
|
|
399
|
+
<details>
|
|
400
|
+
<summary>Cliquez pour déployer</summary>
|
|
401
|
+
|
|
402
|
+
```
|
|
403
|
+
Labels
|
|
404
|
+
├── title-safe-label (text) — "TITLE SAFE (10%)"
|
|
405
|
+
├── action-safe-label (text) — "ACTION SAFE (5%)"
|
|
406
|
+
├── credit-label (text) — "Generated by illustrator-mcp-server"
|
|
407
|
+
├── test-label (text) — "SMPTE COLOR BARS — TEST PATTERN"
|
|
408
|
+
├── format-label (text) — "Full HD — 16:9"
|
|
409
|
+
└── resolution-label (text) — "1920 x 1080"
|
|
410
|
+
|
|
411
|
+
Center Cross
|
|
412
|
+
├── title-safe (path) — 1536×864 stroke rectangle
|
|
413
|
+
├── action-safe (path) — 1728×972 stroke rectangle
|
|
414
|
+
├── cross-circle (path) — 150×150 center circle
|
|
415
|
+
├── cross-v (path) — vertical crosshair
|
|
416
|
+
└── cross-h (path) — horizontal crosshair
|
|
417
|
+
|
|
418
|
+
Color Bars
|
|
419
|
+
├── pluge-black … pluge-navy (path ×9) — PLUGE / grayscale bottom strip
|
|
420
|
+
├── rev-white … rev-blue (path ×7) — reverse color middle strip
|
|
421
|
+
└── bar-white … bar-blue (path ×7) — 75% SMPTE color bars
|
|
422
|
+
```
|
|
423
|
+
|
|
424
|
+
</details>
|
|
425
|
+
|
|
426
|
+
> Outils utilisés : `create_document`, `manage_layers`, `create_rectangle` ×23, `create_line` ×2, `create_ellipse`, `create_text_frame` ×6, `modify_object` ×4, `save_document`, `export`
|
|
427
|
+
|
|
428
|
+
---
|
|
429
|
+
|
|
430
|
+
## Exemple : Twilight Geometry
|
|
431
|
+
|
|
432
|
+
Une œuvre abstraite de paysage géométrique — créée entièrement par Claude, sans autre direction artistique humaine que « fais l'œuvre que tu veux ».
|
|
433
|
+
|
|
434
|
+
**Prompt :**
|
|
435
|
+
|
|
436
|
+
> Fais une œuvre d'art de ta propre imagination dans Illustrator. Prends ton temps. Crée ce que tu veux.
|
|
437
|
+
|
|
438
|
+
**Démarche de Claude :**
|
|
439
|
+
|
|
440
|
+
> Je vais créer « Twilight Geometry » — un paysage abstrait avec des éléments célestes géométriques. Un ciel crépusculaire en dégradé profond, des silhouettes de montagnes en couches, un croissant de lune avec des anneaux décoratifs, et des étoiles parsemées sur le canevas.
|
|
441
|
+
|
|
442
|
+
> Des étoiles en forme de losange de différentes couleurs — blancs chauds, bleus froids, violets lavande — chacune subtilement différente pour suggérer différents types d'étoiles. Des lignes de constellation les reliant. Des triangles filaires et un hexagone flottant dans le ciel pour une atmosphère mystique.
|
|
443
|
+
|
|
444
|
+
> Une surface d'eau au bas avec la lumière de la lune reflétée en lignes ondulantes scintillantes, s'estompant à mesure qu'elles descendent.
|
|
445
|
+
|
|
446
|
+
**Réflexion de Claude :**
|
|
447
|
+
|
|
448
|
+
> Le résultat est meilleur que prévu. Je pense que le monde hybride de la géométrie et de la nature est bien ressorti.
|
|
449
|
+
|
|
450
|
+
**Résultat :**
|
|
451
|
+
|
|
452
|
+
<img src="docs/images/example-twilight-geometry.png" width="720" alt="Twilight Geometry — art de paysage géométrique abstrait généré par Claude via illustrator-mcp-server" />
|
|
453
|
+
|
|
454
|
+
> Outils utilisés : `create_document`, `manage_layers` ×4, `create_rectangle` ×2, `create_gradient` ×2, `create_path` ×11, `create_ellipse` ×14, `create_line` ×4, `create_text_frame` ×2, `modify_object`, `set_z_order`, `export`
|
|
455
|
+
|
|
456
|
+
---
|
|
457
|
+
|
|
458
|
+
## Limitations connues
|
|
459
|
+
|
|
460
|
+
| Limitation | Détails |
|
|
461
|
+
|---|---|
|
|
462
|
+
| Prise en charge Windows | Windows utilise l'automatisation COM via PowerShell (pas encore testé sur matériel réel) |
|
|
463
|
+
| Effets dynamiques | Les paramètres d'ombre portée et d'autres effets peuvent être détectés mais pas lus |
|
|
464
|
+
| Profils colorimétriques | Attribution de profil colorimétrique uniquement — la conversion complète n'est pas disponible |
|
|
465
|
+
| Réglages de fond perdu | Les réglages de fond perdu ne peuvent pas être lus (limitation de l'API Illustrator) |
|
|
466
|
+
| Exportation WebP | Non pris en charge — utilisez PNG ou SVG à la place |
|
|
467
|
+
| Traits de coupe japonais | L'exportation PDF utilise automatiquement l'approche par commande TrimMark : génère les repères comme tracés du document, exporte, puis les supprime via undo |
|
|
468
|
+
| Incorporation de polices | Le mode d'incorporation (complet/sous-ensemble) ne peut pas être contrôlé directement — utilisez des préréglages PDF |
|
|
469
|
+
| Déclinaisons de taille | Mise à l'échelle proportionnelle uniquement — le texte peut nécessiter un ajustement manuel ensuite |
|
|
470
|
+
|
|
471
|
+
---
|
|
472
|
+
|
|
473
|
+
<br>
|
|
474
|
+
|
|
475
|
+
# Pour les développeurs
|
|
476
|
+
|
|
477
|
+
## Architecture
|
|
478
|
+
|
|
479
|
+
```mermaid
|
|
480
|
+
flowchart LR
|
|
481
|
+
Claude <-->|MCP Protocol| Server["MCP Server\n(TypeScript/Node.js)"]
|
|
482
|
+
|
|
483
|
+
Server -.->|generate| Runner["run-{uuid}.scpt / .ps1"]
|
|
484
|
+
Server -.->|generate| JSX["script-{uuid}.jsx\n(BOM UTF-8)"]
|
|
485
|
+
Server -.->|write| PF["params-{uuid}.json"]
|
|
486
|
+
|
|
487
|
+
Runner -->|execFile| osascript
|
|
488
|
+
Runner -->|execFile| PS["powershell.exe"]
|
|
489
|
+
|
|
490
|
+
osascript -->|do javascript| AI["Adobe Illustrator\n(ExtendScript/JSX)"]
|
|
491
|
+
PS -->|DoJavaScript| AI
|
|
492
|
+
|
|
493
|
+
JSX -.->|execute| AI
|
|
494
|
+
PF -.->|read| AI
|
|
495
|
+
AI -.->|write| RF["result-{uuid}.json"]
|
|
496
|
+
RF -.->|read| Server
|
|
497
|
+
```
|
|
498
|
+
|
|
499
|
+
---
|
|
500
|
+
|
|
501
|
+
## Compilation depuis les sources
|
|
502
|
+
|
|
503
|
+
```bash
|
|
504
|
+
git clone https://github.com/ie3jp/illustrator-mcp-server.git
|
|
505
|
+
cd illustrator-mcp-server
|
|
506
|
+
npm install
|
|
507
|
+
npm run build
|
|
508
|
+
claude mcp add illustrator-mcp -- node /path/to/illustrator-mcp-server/dist/index.js
|
|
509
|
+
```
|
|
510
|
+
|
|
511
|
+
### Vérification
|
|
512
|
+
|
|
513
|
+
```bash
|
|
514
|
+
npx @modelcontextprotocol/inspector npx illustrator-mcp-server
|
|
515
|
+
```
|
|
516
|
+
|
|
517
|
+
### Tests
|
|
518
|
+
|
|
519
|
+
```bash
|
|
520
|
+
# Tests unitaires
|
|
521
|
+
npm test
|
|
522
|
+
|
|
523
|
+
# Test E2E de fumée (nécessite qu'Illustrator soit lancé)
|
|
524
|
+
npx tsx test/e2e/smoke-test.ts
|
|
525
|
+
```
|
|
526
|
+
|
|
527
|
+
Le test E2E crée de nouveaux documents (RGB + CMYK), place des objets de test, exécute 182 cas de test sur 10 phases couvrant tous les outils enregistrés et la détection automatique du système de coordonnées, puis nettoie automatiquement.
|
|
528
|
+
|
|
529
|
+
---
|
|
530
|
+
|
|
531
|
+
## Avertissement
|
|
532
|
+
|
|
533
|
+
Cet outil automatise de nombreuses opérations Illustrator, mais l'IA peut faire des erreurs. Les données extraites, les résultats de preflight et les modifications de document doivent toujours être relus par une personne. **Ne vous reposez pas sur cet outil comme seule vérification qualité.** Utilisez-le comme un assistant aux côtés de votre propre vérification manuelle, en particulier pour les remises à l'imprimeur et les livrables clients. Les auteurs ne sauraient être tenus responsables des dommages ou pertes résultant de l'utilisation de ce logiciel ou de ses sorties.
|
|
534
|
+
|
|
535
|
+
---
|
|
536
|
+
|
|
537
|
+
## Licence
|
|
538
|
+
|
|
539
|
+
[MIT](LICENSE)
|