install
source · Clone the upstream repo
git clone https://github.com/majiayu000/claude-skill-registry
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/design-mock" ~/.claude/skills/majiayu000-claude-skill-registry-design-mock && rm -rf "$T"
manifest:
skills/data/design-mock/SKILL.mdsource content
[デザイン] 1.(会話起点)SSOT + 静的HTML(叩き台)を生成
入力: $ARGUMENTS(任意)
- 画面キー(複数可。固定命名)(例:
,HomePage
,PricingPage
)LoginPage - 画面の用途/要件(任意。箇条書きでもOK)
複数ページ指定(固定)
のように ページキーを羅列するHomePage PricingPage LoginPage- 省略時は
として扱う(単一ページの叩き台)HomePage
ページキー(PageKey)のルール(固定)
(例:PascalCase
,HomePage
,PricingPage
)LoginPage- 後工程(
//design-html
)のページ選択キーになるため、URLやFigma名に依存せず安定させる/design-ui
いつ使う?(位置づけ)
- Figmaが無い/固まっていない状態で、まず叩き台を作って会話で詰めたいとき
- 「静的HTMLで目視」しながら調整し、その根拠を SSOT(tokens/components/context) に反映して後続へ合流したいとき
次に何をする?
- 1枚ペラをページ単位にしたい →
(任意)/design-split - 実装に進む →
→/design-ui
→/design-components/design-assemble
🎯 目的
- ユーザーとの会話(要件/トーン/主要導線)から、**ページ単位の静的HTML(複数可)**を生成する
- 実装(状態/データ取得/ルーティング)は入れず、見た目と情報設計に集中する
- 以降の共通ルート(
等)へ合流できるよう、SSOT(design JSON)も同時に用意する/design-ui - 生成したHTMLは、ユーザーが目で見ながら調整するためのプレビューとして扱う(調整点は会話で共有し、SSOT(JSON)側にも反映する)
共通前提(参照)
- 口調・出力規約は
に従う。CLAUDE.md - プロジェクト固有の事実は
(先頭のAI用事実ブロック)を参照する。doc/input/rdd.md - 判断軸は
を適用する(例:.claude/skills/*
/ui-designer
/usability-psychologist
/tailwind
)。creative-coder
見た目の基準(ビューポート)について
- まず
の「ターゲット表示環境(事実)」を参照し、そのビューポートを基準に叩き台(HTML/SSOT)を作るdoc/input/rdd.md - 未記入の場合は、以下を 推奨デフォルトとして仮置きし、出力やレビューの前提に明記する:
- desktop: 1440x900
- mobile: 390x844
- tablet: 834x1194
仕様
- 出力は 静的HTML(外部依存なしが基本)
に保存doc/input/design/html/- 単一ページ:
を生成(叩き台)doc/input/design/html/mock.html - 複数ページ:
をページ数分生成(既定)doc/input/design/html/{page}.html
- 単一ページ:
- 併せて、以下のSSOTを生成/更新する(Figmaルートと同じ合流点。複数ページ対応)
doc/input/design/design_context.jsondoc/input/design/design-tokens.jsondoc/input/design/components.json
(文言のSSOT。一字一句固定。言い換え禁止)doc/input/design/copy.json
(画像/動画等のアセットmanifest。取得できない場合はdoc/input/design/assets/assets.json
を記録して停止)status:"failed"
- 技術スタックは
をSSOTとして扱う(ここで勝手に変えない)doc/input/rdd.md
の variants 命名規約はdoc/input/design/components.json
を参照し、プロジェクト横断で揃えるdoc/input/design/ssot_schema.md- ここで停止(次工程は
。単一ページで/design-ui
の場合は必要に応じてmock.html
)/design-split
複数ページ時のSSOT規約(固定)
を PageKey単位で生成する(ページ同士を混ぜない)design_context.json.pages[]
のcopy.json
は ページキーで名前空間を切る(例:copyKey
)homePage.hero.title
のassets.json
は ページ横断で一意(衝突は停止)assetKey- tokens がページで矛盾する場合は 停止し、ユーザーに命名/設計の合意を依頼する(推測でマージしない)
反復(重要)
- ユーザーが
を手で編集して調整した場合は、差分(diff)または変更点の箇条書きを入力として受け取る(状況で使い分けOK)doc/input/design/html/*.html - その調整内容を根拠に、HTMLだけでなくSSOT(
/design-tokens.json
/components.json
)も同時に更新するdesign_context.json - 文言の調整が入った場合は、必ず
も同時に更新する(後続で一字一句の再現を担保するため)copy.json - SSOTが古いままだと、後続(
//design-ui
//design-components
)で不整合が出るため、HTML単独修正で終わらせない/design-assemble
ゲート
- 主要ブレイクポイントで破綻しない(簡易でOK)
- 情報設計(見出し/導線/主要CTA)が説明できる
- SSOT(tokens/components/context)が矛盾なく、
が実行できる状態になっている/design-ui
に未定義文言なし(参照されるcopy.json
の不足0件)copyKey- CSSで指定できる見た目(background/border/gradient/blur/blend/strokeAlign)が、SSOT(tokens/componentsのstyles参照)に落ちている(取りこぼし0)
- 画像アセットが必要な箇所(ロゴ/アイコン/イラスト/写真)が
に定義され、doc/input/design/assets/assets.json
配下に配置されている(取りこぼし0)baseDir
にassets.json
が1件でもある場合は、必ずユーザーに失敗理由と次アクション(手元提供/代替ファイル/Export設定)を明示して停止するstatus: "failed"