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();
}