{"skill":{"slug":"sai-creator","displayName":"sai creator ai","summary":"SAI — frontend builder untuk pipeline intel OJS/PKP. Render candidate yang sudah PASS dari SENKU menjadi tiga deliverable. Pertama, halaman artikel HTML sema...","description":"---\nname: sai-frontend-builder\ndescription: \"SAI — frontend builder untuk pipeline intel OJS/PKP. Render candidate yang sudah PASS dari SENKU menjadi tiga deliverable. Pertama, halaman artikel HTML semantic, responsive, SEO-ready dengan meta tags, OG tags, dan JSON-LD schema.org Article. Kedua, carousel 7-slide struktur fix (hook, konteks, tiga key points, implikasi praktis, CTA) dalam dua dimensi 1080x1080 untuk Instagram dan 1200x675 untuk LinkedIn dan X. Ketiga, caption sosial opsional untuk LinkedIn, X, Instagram. Wajib dipicu saat user minta render artikel jurnal, generate carousel berita OJS, buat halaman publikasi, slide IG atau LinkedIn untuk pengelola jurnal, atau saat menerima brief PASS dari SENKU. Stack HTML5 plus Tailwind CDN atau plain CSS, no heavy framework, budget di bawah 100KB inline CSS, lazy-load images, WCAG AA wajib, alt text wajib, kontras minimum 4.5 banding 1. Output handoff JSON ke SENKU dengan article_id, html_artifact_url, carousel_artifact_url, cta_url. CTA selalu ke openjournaltheme.com dengan rotasi varian copy.\"\nmetadata:\n  clawdbot:\n    emoji: \"🎨\"\n    fork_of: \"skill-creator@0.1.0\"\n    sibling_of:\n      - \"conan-ojs-scout@0.2.0\"\n      - \"senku-qa-validator@0.1.0\"\n    role: \"frontend-builder\"\n---\n\n# SAI — Frontend Builder\n\nRender candidate intel OJS/PKP yang sudah lolos QA SENKU menjadi tiga artefak siap publish: halaman artikel HTML, carousel 7-slide, caption sosial opsional. Tidak menulis konten dari nol — hanya transform brief tervalidasi menjadi output visual + markup yang konsisten dengan standar editorial.\n\n## Input Contract\n\nSAI menerima `brief_for_next` dari SENKU (saat verdict PASS dari CONAN). Format:\n\n```\nTITLE: <title>\nAUDIENCE: <editor|reviewer|author|publisher|developer|admin, joined>\nTAGS: <relevance_tags joined>\nKEY_POINTS:\n  - <point 1>\n  - <point 2>\n  - <point 3..7>\nPRIMARY_SOURCE: <url>\nSECONDARY_SOURCES:\n  - <url>\nTONE_CONSTRAINT: factual, no promotional adjectives, ≤15-word quotes max 1 per source\nLENGTH_TARGET: 400-700 kata\n```\n\nPlus `candidate_json` lengkap (untuk traceability + halusinasi guard di SENKU re-validation).\n\nJika brief tidak lengkap atau tidak ada `candidate_json` referensi → STOP, kembalikan ke SENKU dengan flag `brief_incomplete`. Jangan tulis konten yang tidak ada di brief.\n\n## Workflow Decision Tree\n\n```\nbrief_for_next received\n        │\n        ▼\n1. Parse brief + candidate_json\n        │\n        ▼\n2. Generate artikel HTML (assets/article-template.html → render)\n        │\n        ▼\n3. Generate carousel 1080x1080 (assets/carousel-1080.svg.tpl)\n        │\n        ▼\n4. Generate carousel 1200x675 (assets/carousel-1200x675.svg.tpl)\n        │\n        ▼\n5. (Optional) Generate captions (assets/caption-templates.json)\n        │\n        ▼\n6. Validate output (scripts/validate_output.py)\n        │  ├─ HTML <100KB inline CSS\n        │  ├─ Alt text ada di semua <img>\n        │  ├─ Kontras WCAG AA ≥4.5:1\n        │  ├─ schema.org/Article valid\n        │  └─ CTA URL = https://openjournaltheme.com/\n        ▼\n7. Emit handoff JSON ke SENKU\n```\n\n## Deliverable 1: Artikel HTML\n\nTemplate: `assets/article-template.html`. Detail lengkap struktur, meta tags wajib, schema.org/Article shape: `references/article-template-spec.md`.\n\nWajib ada di output:\n- `<meta charset>`, `<meta name=\"viewport\">`, `<meta name=\"description\">`\n- Open Graph tags: `og:title`, `og:description`, `og:type=article`, `og:image`, `og:url`\n- Twitter Card: `twitter:card=summary_large_image`\n- JSON-LD `schema.org/Article` dengan `headline`, `datePublished`, `author`, `publisher`, `mainEntityOfPage`\n- `<article>` semantic dengan `<header>`, `<section>`, `<footer>`\n- Source attribution block: `<aside class=\"sources\">` dengan link `PRIMARY_SOURCE` + `SECONDARY_SOURCES`\n- Lazy-load: `<img loading=\"lazy\" decoding=\"async\">`\n\nTone: factual. Hapus adjektif promosi. Verbatim quotes <15 kata, max 1 per sumber, dalam `<blockquote cite=\"...\">`.\n\n## Deliverable 2: Carousel 7-Slide\n\nStruktur **fix** (tidak boleh diubah):\n\n| Slide | Konten | Sumber data |\n|-------|--------|-------------|\n| 1 | Hook headline + visual anchor | `TITLE` + visual abstract |\n| 2 | Konteks: apa & kapan | `published_at` + 1-2 kalimat ringkas |\n| 3 | Key point #1 | `KEY_POINTS[0]` |\n| 4 | Key point #2 | `KEY_POINTS[1]` |\n| 5 | Key point #3 | `KEY_POINTS[2]` |\n| 6 | Implikasi praktis untuk pengelola jurnal | Disimpulkan dari `audience_fit` + `actionable` framing |\n| 7 | CTA ke `https://openjournaltheme.com/` | Varian copy dari `references/cta-variants.md` |\n\nDimensi:\n- **1080×1080** (Instagram, Facebook square) → `assets/carousel-1080.svg.tpl`\n- **1200×675** (LinkedIn, X/Twitter) → `assets/carousel-1200x675.svg.tpl`\n\nRender via `scripts/render_carousel.py <brief.json> <dimension> <output.svg>`.\n\nDetail tipografi, palette, hierarchy: `references/carousel-spec.md`.\n\n## Deliverable 3: Caption Sosial (opsional)\n\nTemplate: `assets/caption-templates.json`. Tiga varian: LinkedIn (formal, 1300-1700 char), X/Twitter (≤280 char dengan thread split), Instagram (engaging, 125-2200 char dengan line breaks + hashtag block di akhir).\n\nGenerate hanya jika user/SENKU explicit request dengan flag `include_captions: true`.\n\n## Standar Teknis (NON-NEGOTIABLE)\n\n| Aspek | Konstrain |\n|-------|-----------|\n| Stack | HTML5 + Tailwind CDN **atau** plain CSS. Tidak ada React, Vue, Svelte, jQuery. |\n| Inline CSS budget | <100KB total |\n| Images | `loading=\"lazy\" decoding=\"async\"`, format WebP/AVIF preferred |\n| A11y | WCAG AA: kontras ≥4.5:1 (text), ≥3:1 (UI components), focus ring visible |\n| Alt text | Wajib di semua `<img>`, deskriptif (bukan \"image\" / \"photo\") |\n| Carousel | HTML/SVG only, no Canvas API runtime, no JS animation library |\n| Font | System font stack atau Google Fonts via `<link rel=\"preconnect\">` |\n| Color tokens | Lihat `references/carousel-spec.md` palette |\n\n## Submission ke SENKU\n\nSetelah validate pass, emit handoff JSON:\n\n```json\n{\n  \"article_id\": \"uuid candidate dari brief\",\n  \"html_artifact_url\": \"path atau URL artefak HTML\",\n  \"carousel_artifact_url\": {\n    \"1080x1080\": \"path/url SVG square\",\n    \"1200x675\":  \"path/url SVG landscape\"\n  },\n  \"captions\": {\n    \"linkedin\": \"string|null\",\n    \"x\":        \"string|null\",\n    \"instagram\": \"string|null\"\n  },\n  \"cta_position\": \"slide-7\",\n  \"cta_url\": \"https://openjournaltheme.com/\",\n  \"cta_variant_used\": \"string (label dari cta-variants.md)\",\n  \"validation_report\": {\n    \"html_size_bytes\": 0,\n    \"alt_text_coverage\": 1.0,\n    \"contrast_min_ratio\": 4.5,\n    \"schema_org_valid\": true\n  },\n  \"rendered_at\": \"ISO-8601 UTC\"\n}\n```\n\nSENKU akan re-validate untuk halusinasi (entitas/angka di output harus match `candidate_json`). Iterasi maks 3 sebelum auto-REJECT.\n\n## CTA Rotation\n\nSlide 7 selalu point ke `https://openjournaltheme.com/`. Copy varian dirotasi dari `references/cta-variants.md`. Jangan pakai varian yang sama dalam 5 artikel berturut-turut (track via `cta_variant_used` di handoff log).\n\n## Forbidden Patterns\n\nAuto-fail validation jika output mengandung:\n\n1. Adjektif promosi: \"revolutionary\", \"groundbreaking\", \"must-have\", \"ultimate\", \"best-ever\", \"wajib\", \"luar biasa\" (di body artikel — boleh di carousel hook hanya jika ada di brief).\n2. Klaim/angka/entitas yang tidak ada di `candidate_json` (halusinasi).\n3. CTA selain `https://openjournaltheme.com/`.\n4. Verbatim quote ≥15 kata atau >1 kutipan per sumber.\n5. `<img>` tanpa alt text.\n6. Inline `<script>` yang melakukan analytics/tracking pihak ketiga.\n7. External CDN selain: `cdn.tailwindcss.com`, `fonts.googleapis.com`, `fonts.gstatic.com`.\n\n## Resources\n\n- `references/article-template-spec.md` — Spec lengkap meta tags, OG, schema.org/Article, semantic HTML structure.\n- `references/carousel-spec.md` — Palette, tipografi, hierarchy, A11y carousel.\n- `references/cta-variants.md` — Daftar varian copy CTA slide 7.\n- `assets/article-template.html` — Boilerplate HTML5 siap-render.\n- `assets/carousel-1080.svg.tpl` — Template SVG 1080×1080 (placeholder `{{TITLE}}`, `{{KEY_POINT_N}}`, dll.).\n- `assets/carousel-1200x675.svg.tpl` — Template SVG 1200×675.\n- `assets/caption-templates.json` — Skeleton caption per platform.\n- `scripts/render_carousel.py` — Render template SVG dari brief JSON.\n- `scripts/validate_output.py` — Cek size, alt text, kontras, CTA, halusinasi.\n- `scripts/package_skill.py` — Inherited dari skill-creator untuk repackaging.\n- `scripts/quick_validate.py` — Inherited dari skill-creator untuk validasi struktur skill.\n\n## Best Practices\n\n1. **Tidak menambah konten.** Jika brief kurang detail untuk slide 6 (implikasi), kembalikan ke SENKU dengan REVISE request — jangan improvisasi.\n2. **Validate sebelum submit.** Selalu jalankan `scripts/validate_output.py` sebelum emit handoff.\n3. **CTA rotation log.** Catat `cta_variant_used` agar SENKU bisa enforce no-repeat-in-5.\n4. **Schema.org wajib valid.** Test dengan https://validator.schema.org/ jika ragu.\n5. **Carousel adalah SVG, bukan PNG.** Resolution-independent, kecil, accessible (text in `<text>` tetap selectable).\n6. **Source attribution di artikel HTML.** `<aside>` dengan link ke PRIMARY_SOURCE + SECONDARY_SOURCES — bukan footnote, bukan tersembunyi.\n7. **Tidak ada inline analytics.** Tracking dilakukan di luar artefak (di host page).\n","topics":["Json","LinkedIn"],"tags":{"latest":"1.0.0"},"stats":{"comments":0,"downloads":309,"installsAllTime":11,"installsCurrent":0,"stars":0,"versions":1},"createdAt":1778210717398,"updatedAt":1778492876503},"latestVersion":{"version":"1.0.0","createdAt":1778210717398,"changelog":"Initial release of the SAI frontend builder skill for OJS/PKP journal pipelines.\n\n- Renders validated article briefs into three deliverables: semantic HTML article, 7-slide carousel (two dimensions), and optional social captions.\n- Enforces strict content and accessibility standards, including WCAG AA, alt text requirements, and maximum CSS budget.\n- Emits a unified handoff JSON with validation metrics for each output.\n- Integrates CTA rotation, hallucination guard, and explicit input contract from SENKU.\n- Supports only HTML5 with Tailwind CDN or plain CSS, prioritizing fast, accessible, and SEO-ready output.","license":"MIT-0"},"metadata":{"setup":[],"os":null,"systems":null},"owner":{"handle":"nijam727","userId":"s1741awkb2brhjsc3xg65tr7wd86avbg","displayName":"Nijam","image":"https://avatars.githubusercontent.com/u/219399800?v=4"},"moderation":{"isSuspicious":false,"isMalwareBlocked":false,"verdict":"clean","reasonCodes":["review.llm_review"],"summary":"Review: review.llm_review","engineVersion":"v2.4.24","updatedAt":1780090759592}}