UpstageAI/eduteam-ai-edu-day
JavaScript
Captured source
source ↗UpstageAI/eduteam-ai-edu-day
Language: JavaScript
Stars: 0
Forks: 0
Open issues: 0
Created: 2026-02-25T11:25:21Z
Pushed: 2026-05-04T11:03:59Z
Default branch: main
Fork: no
Archived: no
README:
Edu Team Day (GitHub Pages 운영 가이드)
이 저장소는 GitHub Pages 1개 사이트를 사용하고, 그 안에서 여러 폴더 경로로 슬라이드를 운영합니다.
- Pages 루트:
https://upstageai.github.io/eduteam-ai-edu-day/ - 폴더별 페이지 예시:
https://upstageai.github.io/eduteam-ai-edu-day/gas-tutorial/
---
README for Agents
Deterministic instructions for Coding Agents (Claude Code, Codex, Gemini, etc.) working in this repo. Human readers can skip to the Korean guide below.
Repo role
A static portal that exposes multiple HTML slide decks under https://upstageai.github.io/eduteam-ai-edu-day//. Each / is one deck.
Invariants
- Default branch is
main. Pages deploys frommain+/ (root)(legacybuild_type=branch). Always push tomain. - Each deck lives in its own root-level
/. Never rename an existing folder (its URL is shared). - Folder entry point is
/index.html— a redirect to the actual slide HTML (seegas-tutorial/index.html). - Use relative paths only. Never hardcode
/eduteam-ai-edu-day/...(must work both locally and on Pages). - Do not commit
.omc/,.omx/,node_modules/,.DS_Store. - Keep PDF/PPTX next to the source HTML so both originals and exports are discoverable.
- Avoid rapid back-to-back pushes to
main— the legacy Pages pipeline can deadlock if a deploy is cancelled mid-flight. Wait for the previous build to finish (gh api repos/UpstageAI/eduteam-ai-edu-day/pages/builds/latest) before pushing again.
Canonical layout
/ index.html # entry — redirects to slides/dist/presentation.html slides-/ dist/ presentation.html # built single-file HTML (required) presentation.pdf # PDF export (recommended)
Playbook: add a new deck
1. Prepare the slide HTML locally and verify it renders. 2. Create /slides-/dist/ at the repo root. 3. Copy presentation.html (and presentation.pdf if available). 4. Create /index.html from this template (replace `` only):
Presentation
/dist/presentation.html" />
window.location.replace('./slides-/dist/presentation.html');
Redirecting to /dist/presentation.html">presentation.html...5. Stage only the new folder: git add / (never git add . or -A). 6. Commit message style: Add slides or Update ... (short, imperative, English). 7. git push origin main, then wait 1–3 min for Pages to rebuild and verify the URL.
PDF generation (HTML → PDF)
Read the slide size from dist/presentation.html (--slide-w / --slide-h), patch @page { size: ... } in a temp copy, then render with headless Chrome:
# Example slide size: 960x540
SRC=./slides-/dist/presentation.html
DST=./slides-/dist/presentation.pdf
cp "$SRC" /tmp/print.html
sed -i '' 's/@page { size: landscape; margin: 0; }/@page { size: 960px 540px; margin: 0; }/' /tmp/print.html
"/Applications/Google Chrome.app/Contents/MacOS/Google Chrome" \
--headless --disable-gpu --no-pdf-header-footer \
--print-to-pdf="$DST" --print-to-pdf-no-header \
--virtual-time-budget=10000 "file:///tmp/print.html"Pre-push checklist
- [ ]
/index.htmlexists and redirects to a real file - [ ]
/slides-/dist/presentation.htmlexists - [ ]
git statusshows only intended files (no.omc/,.omx/) - [ ]
open /index.htmlworks locally - [ ] All internal links/images use relative paths
Auto-listing
The root index.html scans the main branch tree via the GitHub API and renders cards for every /index.html and .pptx. Just push — no manual list edit needed.
Common failure modes
| Symptom | Cause | Fix | |---------|-------|-----| | 404 after deploy | Pages still building | wait 1–3 min, retry | | Page loads but blank | wrong redirect path in index.html | check DevTools → Network for 404 | | CSS/images broken | absolute paths used | switch to relative (./) | | Missing from portal list | not pushed to main or /index.html missing | check and re-push | | Pages stuck at updating_pages and times out | a previous deploy was cancelled mid-flight, or build_type was changed | revert to build_type=legacy (gh api --method PUT repos/UpstageAI/eduteam-ai-edu-day/pages -f build_type=legacy -f 'source[branch]=main' -f 'source[path]=/'), remove any custom .github/workflows/pages.yml, and push a clean commit |
---
핵심 개념
- 한 저장소에서 Pages 설정은 보통 1개입니다. (브랜치/폴더 소스 1개)
- 대신
//형태로 여러 페이지를 함께 운영할 수 있습니다. - 즉, "사이트는 하나"지만 "경로는 여러 개"를 가질 수 있습니다.
---
새 폴더로 HTML 슬라이드 올리는 방법
아래 순서대로 진행하세요.
1) 폴더 생성
예: my-workshop/
2) 슬라이드 HTML 배치
예시 구조:
my-workshop/ index.html slides/ presentation.html
> 권장: my-workshop/index.html에서 실제 슬라이드 파일로 리다이렉트하면 URL이 깔끔해집니다.
3) (선택) index.html 리다이렉트 예시
location.replace('./slides/presentation.html');
Redirecting...4) 변경사항 커밋
git add my-workshop git commit -m "Add my-workshop slides"
5) main 브랜치로 푸시
git push origin main
6) Pages 설정 확인 (최초 1회)
GitHub 저장소에서:
- Settings → Pages
- Source: Deploy from a branch
- Branch: main
- Folder: / (root)
7) 접속 URL
- 폴더 진입점:
https://upstageai.github.io/eduteam-ai-edu-day/my-workshop/ - 직접 파일:
https://upstageai.github.io/eduteam-ai-edu-day/my-workshop/slides/presentation.html
---
현재 운영 중인 경로
gas-tutorial/—gas-tutorial/slides-gas-tutorial/dist/presentation.htmlomc-intro/—omc-intro/slides-omc-intro/dist/presentation.html
---
자주 발생하는 문제
1. 404 발생
- Pages 배포가 아직 안 끝났을 수 있습니다 (1~3분 대기)
- 브랜치/폴더 설정이
main+/ (root)인지 확인
2. 스타일/정적 파일 누락
- 상대경로(
./) 기준이 맞는지 확인 - 파일이 실제 커밋/푸시 되었는지 확인
3. 폴더 링크는 보이는데 내용이 안 열림
- 해당 폴더에
index.html이 있는지 확인
Excerpt shown — open the source for the full document.
Notability
notability 2.0/10Routine educational repo, no traction