diff --git a/.github/workflows/jsr-publish.yml b/.github/workflows/jsr-publish.yml new file mode 100644 index 0000000..48bbe9d --- /dev/null +++ b/.github/workflows/jsr-publish.yml @@ -0,0 +1,23 @@ +name: JSR Publish +on: + push: + branches: + - main + +jobs: + publish: + runs-on: ubuntu-latest + + permissions: + contents: read + id-token: write + + steps: + - uses: actions/checkout@v4 + - uses: oven-sh/setup-bun@v2 + - name: Install dependencies + run: bun install + - name: Build + run: bun run build + - name: Publish package + run: npx jsr publish diff --git a/README.md b/README.md index e1c7cc7..c54fccc 100644 --- a/README.md +++ b/README.md @@ -1,125 +1,6 @@ -# Kunkun Template UI Extension +# Kunkun OSS Insight Extension -This is a template for a template UI extension. (UI follows pre-defined template) +## Features -[./src/index.ts](./src/index.ts) is the default entrypoint for the extension. You can import any other files in this file, but the build process will bundle them into a single file. - -## Pros and Cons - -This type of extension is suitable for simple use cases, such as a list or form. All components are pre-defined, so there is not much room for customization. If you want more flexibility on the UI, consider using [Custom UI Extension](https://docs.kunkun.sh/extensions/custom-ui-ext/), which requires some frontend knowledge but gives you full control over the UI. - -Read documentation at https://docs.kunkun.sh/extensions/worker-template/ - -Make sure you understand what this type of extension is capable of. - -### Pros - -- Simple to develop, no need for any frontend knowledge. -- Small bundle size (~40KB) - - [Custom UI Extension](https://docs.kunkun.sh/extensions/custom-ui-ext/) are usually larger than 300KB. - -### Cons - -- Limited UI customization. Not suitable for complex use cases. - -Consider [Custom UI Extension](https://docs.kunkun.sh/extensions/custom-ui-ext/) if you need more complex UI. - -## Development - -```bash -pnpm install -``` - -Start extension in development mode. Every save will trigger a hot reload in Kunkun. - -```bash -pnpm dev -``` - -- During development, right click in Kunkun to open the developer tools. - - Error messages will be shown in the console. - - If you got any permission error while calling Kunknu's APIs, make sure you've declared the permission in `package.json`. Then go back to home page and enter the extension again to re-apply the permission. -- To develop and preview the extension in Kunkun, you need to run the `Add Dev Extension` command in Kunkun, and register this extension's path. - -Build the extension. Your extension source code can contain many files, but the build process will bundle them into a single file. - -```bash -pnpm build -# Due to Bun's bug, if you are on windows, and install dependencies with pnpm, you may get error during build. -# Try install dependencies with bun or npm instead. -``` - -## i18n - -[./src/i18n](./src/i18n/) contains optional internationalization support starter code. - -If you want to support i18n, you can use the `t` function to translate the strings in the extension. - -User's language setting is available via `app.language()`. - -```ts -import { app } from "@kksh/api/ui/worker" -import { setupI18n, t } from "./src/i18n" - -setupI18n("zh") -console.log(t("welcome")) - -setupI18n(await app.language()) -console.log(t("welcome")) -``` - -## Add More Commands - -If you want to add more template worker extension commands, simply modify the `entrypoints` array in [./build.ts](./build.ts). - -Then in `package.json`, register the new command. - -## Verify Build and Publish - -```bash -pnpm build # make sure the build npm script works -npx kksh@latest verify # Verify some basic settings -npx kksh@latest verify --publish # Verify some basic settings before publishing -``` - -It is recommended to build the extension with the same environment our CI uses. - -The docker image used by our CI is `huakunshen/kunkun-ext-builder:latest`. - -You can use the following command to build the extension with the same environment our CI uses. -This requires you to have docker installed, and the shell you are using has access to it via `docker` command. - -```bash -npx kksh@latest build # Build the extension with -``` - -`pnpm` is used to install dependencies and build the extension. - -The docker image environment also has `node`, `pnpm`, `npm`, `bun`, `deno` installed. -If your build failed, try debug with `huakunshen/kunkun-ext-builder:latest` image in interative mode and bind your extension volume to `/workspace`. - -After build successfully, you should find a tarball file ends with `.tgz` in the root of your extension. -The tarball is packaged with `npm pack` command. You can uncompress it to see if it contains all the necessary files. - -This tarball is the final product that will be published and installed in Kunkun. You can further verify your extension by installing this tarball directly in Kunkun. - -After verifying the tarball, it's ready to be published. - -Fork [KunkunExtensions](https://github.com/kunkunsh/KunkunExtensions) repo, add your extension to the `extensions` directory, and create a PR. - -Once CI passed and PR merged, you can use your extension in Kunkun. - -## Potential Error - -Our CI uses `pnpm` to install dependencies. If you are on Windows, you may get error during build. - -See issue https://github.com/kunkunsh/kunkun/issues/78 - -`bun` had problem building the extension when `pnpm` is used to install dependencies. - -### Options - -1. Install an older version of `bun` (1.1.27 should work) -2. Install dependencies with `bun` or `npm` instead of `pnpm` - -Our CI always builds the extension with on Linux and shouldn't have this problem. +- [x] Show default trending repositories +- [ ] Filter by programming language diff --git a/demo-images/trending-repos.png b/demo-images/trending-repos.png new file mode 100644 index 0000000..3a309a6 Binary files /dev/null and b/demo-images/trending-repos.png differ diff --git a/jsr.json b/jsr.json new file mode 100644 index 0000000..be6eb74 --- /dev/null +++ b/jsr.json @@ -0,0 +1,9 @@ +{ + "name": "@kunkun/ext-ossinsight", + "version": "0.0.1", + "license": "MIT", + "exports": "./mod.ts", + "publish": { + "include": ["dist", "demo-images", "README.md", "package.json"] + } +} diff --git a/mod.ts b/mod.ts new file mode 100644 index 0000000..e69de29 diff --git a/ossinsight-logo.svg b/ossinsight-logo.svg deleted file mode 100644 index 5339789..0000000 --- a/ossinsight-logo.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/package.json b/package.json index 782ff58..342c82d 100644 --- a/package.json +++ b/package.json @@ -20,7 +20,9 @@ ] } ], - "demoImages": [], + "demoImages": [ + "demo-images/trending-repos.png" + ], "icon": { "type": "svg", "value": "" diff --git a/src/index.ts b/src/index.ts index 7bb85e1..daa9a70 100644 --- a/src/index.ts +++ b/src/index.ts @@ -33,17 +33,21 @@ class TrendingRepos extends WorkerExtension { console.log(trendingRepos); return ui - .setSearchBarPlaceholder("Enter a search term, and press enter to search") + .setSearchBarPlaceholder( + "Enter a search term, and press enter to open the repo" + ) .then(() => { return ui.render( new List.List({ items: trendingRepos.data?.data.rows.map( (repo) => new List.Item({ + icon: new Icon({ + type: IconEnum.Iconify, + value: "mdi:github", + }), title: repo.repo_name ?? "N/A", - value: repo.repo_name - ? `https://github.com/${repo.repo_name}` - : "N/A", + value: repo.repo_name ?? "N/A", subTitle: `Language: ${ repo.primary_language ?? "N/A" }; Stars: ${repo.stars ?? "N/A"}`, @@ -70,8 +74,8 @@ class TrendingRepos extends WorkerExtension { } onListItemSelected(value: string): Promise { - if (value.startsWith("https://github.com/")) { - open.url(value); + if (value !== "N/A") { + open.url(`https://github.com/${value}`); } return Promise.resolve(); }