# ๐ŸฅFuwari [Astro](https://astro.build)๋กœ ๊ตฌ์ถ•๋œ ์ •์  ๋ธ”๋กœ๊ทธ ํ…œํ”Œ๋ฆฟ์ž…๋‹ˆ๋‹ค. [**๐Ÿ–ฅ๏ธ๋ฏธ๋ฆฌ๋ณด๊ธฐ (Vercel)**](https://fuwari.vercel.app) ![Preview Image](https://raw.githubusercontent.com/saicaca/resource/main/fuwari/home.png) ## โœจ ํŠน์ง• - [x] [Astro](https://astro.build) ๋ฐ [Tailwind CSS](https://tailwindcss.com)๋กœ ๊ตฌ์ถ•๋จ - [x] ๋ถ€๋“œ๋Ÿฌ์šด ์• ๋‹ˆ๋ฉ”์ด์…˜ ๋ฐ ํŽ˜์ด์ง€ ์ „ํ™˜ - [x] ๋ผ์ดํŠธ ๋ชจ๋“œ / ๋‹คํฌ ๋ชจ๋“œ - [x] ์‚ฌ์šฉ์ž ์ •์˜ ๊ฐ€๋Šฅํ•œ ํ…Œ๋งˆ ์ƒ‰์ƒ ๋ฐ ๋ฐฐ๋„ˆ - [x] ๋ฐ˜์‘ํ˜• ๋””์ž์ธ - [x] [Pagefind](https://pagefind.app/)๋ฅผ ์ด์šฉํ•œ ๊ฒ€์ƒ‰ ๊ธฐ๋Šฅ - [x] [Markdown ํ™•์žฅ ๊ธฐ๋Šฅ](https://github.com/saicaca/fuwari?tab=readme-ov-file#-markdown-extended-syntax) - [x] ๋ชฉ์ฐจ - [x] RSS ํ”ผ๋“œ ## ๐Ÿš€ ์‹œ์ž‘ํ•˜๊ธฐ 1. ๋ธ”๋กœ๊ทธ ์ €์žฅ์†Œ๋ฅผ ์ƒ์„ฑํ•˜์„ธ์š”: - ์ด ํ…œํ”Œ๋ฆฟ์—์„œ [์ƒˆ ์ €์žฅ์†Œ๋ฅผ ์ƒ์„ฑ](https://github.com/saicaca/fuwari/generate)ํ•˜๊ฑฐ๋‚˜ ์ด ์ €์žฅ์†Œ๋ฅผ ํฌํฌํ•˜์„ธ์š”. - ๋˜๋Š” ๋‹ค์Œ ๋ช…๋ น์–ด ์ค‘ ํ•˜๋‚˜๋ฅผ ์‹คํ–‰ํ•˜์„ธ์š”: ```sh npm create fuwari@latest yarn create fuwari pnpm create fuwari@latest bun create fuwari@latest deno run -A npm:create-fuwari@latest ``` 2. ๋กœ์ปฌ์—์„œ ๋ธ”๋กœ๊ทธ๋ฅผ ์ˆ˜์ •ํ•˜๋ ค๋ฉด, ์ €์žฅ์†Œ๋ฅผ ๋ณต์ œํ•˜๊ณ  `pnpm install`์„ ์‹คํ–‰ํ•˜์—ฌ ์ข…์†์„ฑ์„ ์„ค์น˜ํ•˜์„ธ์š”. - [pnpm](https://pnpm.io)์ด ์„ค์น˜๋˜์–ด ์žˆ์ง€ ์•Š๋‹ค๋ฉด `npm install -g pnpm`์„ ์‹คํ–‰ํ•˜์—ฌ ์„ค์น˜ํ•˜์„ธ์š”. 3. `src/config.ts`์„ค์ • ํŒŒ์ผ์„ ์ˆ˜์ •ํ•˜์—ฌ ๋ธ”๋กœ๊ทธ๋ฅผ ์ปค์Šคํ„ฐ๋งˆ์ด์ง•ํ•˜์„ธ์š”. 4. `pnpm new-post `์„ ์‹คํ–‰ํ•˜์—ฌ ์ƒˆ ๊ฒŒ์‹œ๋ฌผ์„ ๋งŒ๋“ค๊ณ  `src/content/posts/`์—์„œ ์ˆ˜์ •ํ•˜์„ธ์š”. 5. [๊ฐ€์ด๋“œ](https://docs.astro.build/en/guides/deploy/)์— ๋”ฐ๋ผ ๋ธ”๋กœ๊ทธ๋ฅผ Vercel, Netlify, Github Pages ๋“ฑ์— ๋ฐฐํฌํ•˜์„ธ์š”. ๋ฐฐํฌํ•˜๊ธฐ ์ „์— `astro.config.mjs`์—์„œ ์‚ฌ์ดํŠธ ๊ตฌ์„ฑ์„ ์ˆ˜์ •ํ•ด์•ผ ํ•ฉ๋‹ˆ๋‹ค. ## โš™๏ธ ๊ฒŒ์‹œ๋ฌผ์˜ ๋จธ๋ฆฌ๋ง ์„ค์ • ```yaml --- title: ๋‚ด ์ฒซ ๋ธ”๋กœ๊ทธ ๊ฒŒ์‹œ๋ฌผ published: 2023-09-09 description: ๋‚ด ์ƒˆ๋กœ์šด Astro ๋ธ”๋กœ๊ทธ์˜ ์ฒซ ๋ฒˆ์งธ ๊ฒŒ์‹œ๋ฌผ์ž…๋‹ˆ๋‹ค! image: ./cover.jpg tags: [Foo, Bar] category: Front-end draft: false lang: jp # ๊ฒŒ์‹œ๋ฌผ์˜ ์–ธ์–ด๊ฐ€ `config.ts`์˜ ์‚ฌ์ดํŠธ ์–ธ์–ด์™€ ๋‹ค๋ฅธ ๊ฒฝ์šฐ์—๋งŒ ์„ค์ •ํ•ฉ๋‹ˆ๋‹ค. --- ``` ## ๐Ÿงฉ ๋งˆํฌ๋‹ค์šด ํ™•์žฅ ๊ตฌ๋ฌธ Astro์˜ ๊ธฐ๋ณธ [GitHub Flavored Markdown](https://github.github.com/gfm/) ์ง€์› ์™ธ์—๋„ ๋ช‡ ๊ฐ€์ง€ ์ถ”๊ฐ€์ ์ธ ๋งˆํฌ๋‹ค์šด ๊ธฐ๋Šฅ์ด ํฌํ•จ๋˜์–ด ์žˆ์Šต๋‹ˆ๋‹ค. - Admonitions ([๋ฏธ๋ฆฌ๋ณด๊ธฐ ๋ฐ ์‚ฌ์šฉ๋ฒ•](https://fuwari.vercel.app/posts/markdown-extended/#admonitions)) - GitHub ์ €์žฅ์†Œ ์นด๋“œ ([๋ฏธ๋ฆฌ๋ณด๊ธฐ ๋ฐ ์‚ฌ์šฉ๋ฒ•](https://fuwari.vercel.app/posts/markdown-extended/#github-repository-cards)) - Expressive Code๋ฅผ ์‚ฌ์šฉํ•œ ํ–ฅ์ƒ๋œ ์ฝ”๋“œ ๋ธ”๋ก ([๋ฏธ๋ฆฌ๋ณด๊ธฐ](https://fuwari.vercel.app/posts/expressive-code/) / [๋ฌธ์„œ](https://expressive-code.com/)) ## โšก ๋ช…๋ น์–ด ๋ชจ๋“  ๋ช…๋ น์–ด๋Š” ํ”„๋กœ์ ํŠธ ์ตœ์ƒ๋‹จ, ํ„ฐ๋ฏธ๋„์—์„œ ์‹คํ–‰๋ฉ๋‹ˆ๋‹ค: | Command | Action | |:------------------------------------|:-------------------------------------------------| | `pnpm install` | ์ข…์†์„ฑ์„ ์„ค์น˜ํ•ฉ๋‹ˆ๋‹ค. | | `pnpm dev` | `localhost:4321`์—์„œ ๋กœ์ปฌ ๊ฐœ๋ฐœ ์„œ๋ฒ„๋ฅผ ์‹œ์ž‘ํ•ฉ๋‹ˆ๋‹ค. | | `pnpm build` | `./dist/`์— ํ”„๋กœ๋•์…˜ ์‚ฌ์ดํŠธ๋ฅผ ๊ตฌ์ถ•ํ•ฉ๋‹ˆ๋‹ค. | | `pnpm check` | ์ฝ”๋“œ์—์„œ ์˜ค๋ฅ˜๋ฅผ ํ™•์ธํ•ฉ๋‹ˆ๋‹ค. | | `pnpm format` | Biome์„ ์‚ฌ์šฉํ•˜์—ฌ ์ฝ”๋“œ๋ฅผ ํฌ๋ฉงํ•ฉ๋‹ˆ๋‹ค. | | `pnpm preview` | ๋ฐฐํฌํ•˜๊ธฐ ์ „์— ๋กœ์ปฌ์—์„œ ๋นŒ๋“œ ๋ฏธ๋ฆฌ๋ณด๊ธฐ | | `pnpm new-post ` | ์ƒˆ ๊ฒŒ์‹œ๋ฌผ ์ž‘์„ฑ | | `pnpm astro ...` | `astro add`, `astro check`์™€ ๊ฐ™์€ CLI ๋ช…๋ น์–ด ์‹คํ–‰ | | `pnpm astro --help` | Astro CLI๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ๋„์›€ ๋ฐ›๊ธฐ | ## โœ๏ธ ๊ธฐ์—ฌ ์ด ํ”„๋กœ์ ํŠธ์— ๊ธฐ์—ฌํ•˜๋Š” ๋ฐฉ๋ฒ•์— ๋Œ€ํ•œ ์ž์„ธํ•œ ๋‚ด์šฉ์€ [๊ธฐ์—ฌ ๊ฐ€์ด๋“œ](https://github.com/saicaca/fuwari/blob/main/CONTRIBUTING.md)๋ฅผ ํ™•์ธํ•˜์„ธ์š”. ## ๐Ÿ“„ ๋ผ์ด์„ ์Šค ์ด ํ”„๋กœ์ ํŠธ๋Š” MIT ๋ผ์ด์„ ์Šค์— ๋”ฐ๋ผ ๋ผ์ด์„ ์Šค๊ฐ€ ๋ถ€์—ฌ๋ฉ๋‹ˆ๋‹ค. [![FOSSA Status](https://app.fossa.com/api/projects/git%2Bgithub.com%2Fsaicaca%2Ffuwari.svg?type=large&issueType=license)](https://app.fossa.com/projects/git%2Bgithub.com%2Fsaicaca%2Ffuwari?ref=badge_large&issueType=license)