astro/examples/hackernews
Brian McManus 7da05febea
Enhanced Astro codespace support (#6288)
* Enhanced Astro codespace support

Enhances the base devcontainer and Dockerfile to provide a smoother
development experience out of the box for contributors.

Adds a devcontainer per example so that we can add buttons on astro.new
that will launch users straight into the appropriate example app.

* Cleanup devcontainers and pin base image

* Update .devcontainer/example-welcome-message.txt

Co-authored-by: Samruddhi Khandale <skhandale@microsoft.com>

---------

Co-authored-by: Samruddhi Khandale <skhandale@microsoft.com>
2023-02-23 09:34:37 -06:00
..
.vscode Adds a Hackernews example site (#5213) 2022-11-01 16:20:04 +00:00
public Adds a Hackernews example site (#5213) 2022-11-01 16:20:04 +00:00
src [ci] format 2022-11-08 18:39:22 +00:00
.gitignore Add .astro/ to .gitignore in example projects (#5841) 2023-01-12 11:26:13 -05:00
astro.config.mjs Adds a Hackernews example site (#5213) 2022-11-01 16:20:04 +00:00
package.json [ci] release (#6279) 2023-02-17 13:44:15 -05:00
README.md Enhanced Astro codespace support (#6288) 2023-02-23 09:34:37 -06:00
sandbox.config.json Adds a Hackernews example site (#5213) 2022-11-01 16:20:04 +00:00
tsconfig.json Adds a Hackernews example site (#5213) 2022-11-01 16:20:04 +00:00

Astro Starter Kit: Hackernews

npm create astro@latest -- --template hackernews

Open in StackBlitz Open with CodeSandbox Open in GitHub Codespaces

🧑‍🚀 Seasoned astronaut? Delete this file. Have fun!

🚀 Project Structure

Inside of your Astro project, you'll see the following folders and files:

/
├── public/
│   └── favicon.svg
├── src/
│   ├── components/
│   ├── layouts/
│   │   └── Layout.astro
│   └── pages/
        └── stories/
            └── [id].astro
        └── users/
            └── [id].astro
│       └── [...stories].astro
└── package.json

Astro looks for .astro or .md files in the src/pages/ directory. Each page is exposed as a route based on its file name. Because the list of stories and users is always changing, dynamic routes like [id].astro are used to build pages when a specific page is requested.

There's nothing special about src/components/, but that's where we like to put any Astro/React/Vue/Svelte/Preact components.

Any static assets, like images, can be placed in the public/ directory.

Server-side rendering (SSR)

This project uses the @astrojs/node adapter to deploy the SSR site to Node targets. Check out Astro's deployment docs for details on other adapters and hosting environments.

🧞 Commands

All commands are run from the root of the project, from a terminal:

Command Action
npm install Installs dependencies
npm run dev Starts local dev server at localhost:3000
npm run build Build your production site to ./dist/
npm run preview Preview your build locally, before deploying
npm run astro ... Run CLI commands like astro add, astro check
npm run astro --help Get help using the Astro CLI

👀 Want to learn more?

Feel free to check our documentation or jump into our Discord server.