From 945b948f4f61176cce66248e911a93e848c66c05 Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" <41898282+github-actions[bot]@users.noreply.github.com> Date: Fri, 20 Dec 2024 12:22:12 +0000 Subject: [PATCH] Sync from 5f4c543609dea291c5f5c1e3ee0252ee5a66a1e1 --- .gitignore | 24 ++++++++++++++++++++++++ README.md | 35 +++++++++++++++++++++++++++++++++++ index.ts | 6 ++++++ package.json | 23 +++++++++++++++++++++++ src/MyComponent.astro | 8 ++++++++ tsconfig.json | 8 ++++++++ 6 files changed, 104 insertions(+) create mode 100644 .gitignore create mode 100644 README.md create mode 100644 index.ts create mode 100644 package.json create mode 100644 src/MyComponent.astro create mode 100644 tsconfig.json diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000000..16d54bb13c --- /dev/null +++ b/.gitignore @@ -0,0 +1,24 @@ +# build output +dist/ +# generated types +.astro/ + +# dependencies +node_modules/ + +# logs +npm-debug.log* +yarn-debug.log* +yarn-error.log* +pnpm-debug.log* + + +# environment variables +.env +.env.production + +# macOS-specific files +.DS_Store + +# jetbrains setting folder +.idea/ diff --git a/README.md b/README.md new file mode 100644 index 0000000000..f519585299 --- /dev/null +++ b/README.md @@ -0,0 +1,35 @@ +# Astro Starter Kit: Component Package + +This is a template for an Astro component library. Use this template for writing components to use in multiple projects or publish to NPM. + +```sh +npm create astro@latest -- --template component +``` + +[![Open in StackBlitz](https://developer.stackblitz.com/img/open_in_stackblitz.svg)](https://stackblitz.com/github/withastro/astro/tree/latest/examples/non-html-pages) +[![Open with CodeSandbox](https://assets.codesandbox.io/github/button-edit-lime.svg)](https://codesandbox.io/p/sandbox/github/withastro/astro/tree/latest/examples/non-html-pages) +[![Open in GitHub Codespaces](https://github.com/codespaces/badge.svg)](https://codespaces.new/withastro/astro?devcontainer_path=.devcontainer/component/devcontainer.json) + +## 🚀 Project Structure + +Inside of your Astro project, you'll see the following folders and files: + +```text +/ +├── index.ts +├── src +│ └── MyComponent.astro +├── tsconfig.json +├── package.json +``` + +The `index.ts` file is the "entry point" for your package. Export your components in `index.ts` to make them importable from your package. + +## 🧞 Commands + +All commands are run from the root of the project, from a terminal: + +| Command | Action | +| :------------ | :------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| `npm link` | Registers this package locally. Run `npm link my-component-library` in an Astro project to install your components | +| `npm publish` | [Publishes](https://docs.npmjs.com/creating-and-publishing-unscoped-public-packages#publishing-unscoped-public-packages) this package to NPM. Requires you to be [logged in](https://docs.npmjs.com/cli/v8/commands/npm-adduser) | diff --git a/index.ts b/index.ts new file mode 100644 index 0000000000..0e2e94fb2f --- /dev/null +++ b/index.ts @@ -0,0 +1,6 @@ +// Do not write code directly here, instead use the `src` folder! +// Then, use this file to export everything you want your user to access. + +import MyComponent from './src/MyComponent.astro'; + +export default MyComponent; diff --git a/package.json b/package.json new file mode 100644 index 0000000000..df92791097 --- /dev/null +++ b/package.json @@ -0,0 +1,23 @@ +{ + "name": "@example/component", + "private": true, + "version": "0.0.1", + "type": "module", + "exports": { + ".": "./index.ts" + }, + "files": [ + "src", + "index.ts" + ], + "keywords": [ + "astro-component" + ], + "scripts": {}, + "devDependencies": { + "astro": "^5.1.1" + }, + "peerDependencies": { + "astro": "^4.0.0 || ^5.0.0" + } +} diff --git a/src/MyComponent.astro b/src/MyComponent.astro new file mode 100644 index 0000000000..2a3ebcea54 --- /dev/null +++ b/src/MyComponent.astro @@ -0,0 +1,8 @@ +--- +// Write your component code in this file! +interface Props { + prefix?: string; +} +--- + +
{Astro.props.prefix} My special component
diff --git a/tsconfig.json b/tsconfig.json new file mode 100644 index 0000000000..f85ec795bf --- /dev/null +++ b/tsconfig.json @@ -0,0 +1,8 @@ +{ + "extends": "astro/tsconfigs/strict", + "include": [".astro/types.d.ts", "**/*"], + "exclude": ["dist"], + "compilerOptions": { + "jsx": "preserve" + } +}