Skip to content
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
12 changes: 6 additions & 6 deletions demo/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@
],
"main": "./dist/extension.cjs",
"engines": {
"vscode": "^1.101.0"
"vscode": "^1.102.0"
},
"activationEvents": [
"onStartupFinished"
Expand Down Expand Up @@ -64,12 +64,12 @@
},
"devDependencies": {
"@reactive-vscode/mock": "workspace:*",
"@types/node": "18.x",
"@types/vscode": "^1.101.0",
"@types/node": "^22.10.7",
"@types/vscode": "^1.102.0",
"reactive-vscode": "workspace:*",
"tsdown": "^0.11.13",
"typescript": "^5.8.3",
"vite": "^5.4.19",
"vitest": "^2.1.9"
"typescript": "^5.9.2",
"vite": "^7.1.3",
"vitest": "^3.2.4"
}
}
3 changes: 2 additions & 1 deletion docs/guide/config.md
Original file line number Diff line number Diff line change
Expand Up @@ -113,8 +113,9 @@ Visit the [official documentation](https://code.visualstudio.com/api/references/
You can also use the [`vscode-ext-gen`](https://github.com/antfu/vscode-ext-gen) to generate the configuration settings. For example:

```ts
import type { NestedScopedConfigs } from './generated-meta'
import { defineConfigObject, defineConfigs, reactive, ref } from 'reactive-vscode'
import { type NestedScopedConfigs, scopedConfigs } from './generated-meta'
import { scopedConfigs } from './generated-meta'

const config = defineConfigObject<NestedScopedConfigs>(
scopedConfigs.scope,
Expand Down
1 change: 1 addition & 0 deletions docs/guide/event.md
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ export = defineExtension(() => {
<!-- eslint-disable import/first -->
```ts
import type { Event } from 'vscode'

declare function someVscodeApi(options: { onSomeEvent: Event<string> }): void
// ---cut---
import { defineExtension, useEventEmitter } from 'reactive-vscode'
Expand Down
1 change: 1 addition & 0 deletions docs/guide/extension.md
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ Or you can avoid the `export =` statement in this way:

```ts
import { defineExtension } from 'reactive-vscode'

const { activate, deactivate } = defineExtension(() => {
// Your extension code here
})
Expand Down
8 changes: 4 additions & 4 deletions docs/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -13,19 +13,19 @@
"@reactive-vscode/metadata": "workspace:*",
"@reactive-vscode/vueuse": "workspace:*",
"@shikijs/vitepress-twoslash": "^1.29.2",
"@types/vscode": "^1.101.0",
"@types/vscode": "^1.102.0",
"@unocss/preset-attributify": "^0.63.6",
"@unocss/preset-icons": "^0.63.6",
"@unocss/preset-uno": "^0.63.6",
"@unocss/transformer-directives": "^0.63.6",
"@unocss/transformer-variant-group": "^0.63.6",
"@vueuse/core": "^12.8.2",
"@vueuse/core": "^13.8.0",
"fuse.js": "^7.1.0",
"reactive-vscode": "workspace:*",
"unocss": "^0.63.6",
"unplugin-vue-components": "^0.27.5",
"vitepress": "^1.6.3",
"vitepress": "^1.6.4",
"vitepress-plugin-group-icons": "^1.6.0",
"vue": "^3.5.17"
"vue": "^3.5.20"
}
}
6 changes: 3 additions & 3 deletions package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"type": "module",
"version": "0.3.1",
"version": "0.3.2",
"packageManager": "[email protected]",
"scripts": {
"dev": "nr demo:dev",
Expand All @@ -21,14 +21,14 @@
"typecheck": "nr -r --parallel typecheck"
},
"devDependencies": {
"@antfu/eslint-config": "^3.16.0",
"@antfu/eslint-config": "^5.2.1",
"@antfu/ni": "^0.23.2",
"bumpp": "^9.11.1",
"eslint": "^9.29.0",
"lint-staged": "^15.5.2",
"pnpm": "^9.15.9",
"simple-git-hooks": "^2.13.0",
"typescript": "^5.8.3",
"typescript": "^5.9.2",
"zx": "^8.5.5"
},
"simple-git-hooks": {
Expand Down
12 changes: 6 additions & 6 deletions packages/core/package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"name": "reactive-vscode",
"type": "module",
"version": "0.3.1",
"version": "0.3.2",
"description": "Develop VSCode extension with Vue Reactivity API",
"author": "_Kerman <[email protected]>",
"license": "MIT",
Expand Down Expand Up @@ -39,16 +39,16 @@
"prepublishOnly": "pnpm typecheck && pnpm build"
},
"peerDependencies": {
"@types/vscode": "^1.101.0"
"@types/vscode": "^1.102.0"
},
"dependencies": {
"@reactive-vscode/reactivity": "workspace:*"
},
"devDependencies": {
"@types/node": "^20.19.1",
"@types/vscode": "^1.101.0",
"typescript": "^5.8.3",
"vite": "^5.4.19",
"@types/node": "^22.10.7",
"@types/vscode": "^1.102.0",
"typescript": "^5.9.2",
"vite": "^7.1.3",
"vite-plugin-dts": "^4.5.4"
},
"publishConfig": {
Expand Down
3 changes: 2 additions & 1 deletion packages/core/src/composables/useChatParticipant.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import type { MaybeRef, MaybeRefOrGetter } from '@reactive-vscode/reactivity'
import type { ChatFollowupProvider, ChatRequestHandler, IconPath } from 'vscode'
import { type MaybeRef, type MaybeRefOrGetter, unref, watchEffect } from '@reactive-vscode/reactivity'
import { unref, watchEffect } from '@reactive-vscode/reactivity'
import { chat } from 'vscode'
import { createKeyedComposable } from '../utils'
import { useDisposable } from './useDisposable'
Expand Down
3 changes: 2 additions & 1 deletion packages/core/src/composables/useOutputChannel.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { type LogOutputChannel, type OutputChannel, window } from 'vscode'
import type { LogOutputChannel, OutputChannel } from 'vscode'
import { window } from 'vscode'
import { useDisposable } from './useDisposable'

/**
Expand Down
3 changes: 2 additions & 1 deletion packages/core/src/composables/useReactiveOptions.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { type MaybeRefOrGetter, toValue, watchEffect } from '@reactive-vscode/reactivity'
import type { MaybeRefOrGetter } from '@reactive-vscode/reactivity'
import { toValue, watchEffect } from '@reactive-vscode/reactivity'

export function useReactiveOptions<T extends object>(
target: T,
Expand Down
22 changes: 11 additions & 11 deletions packages/core/src/composables/useTreeView.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,17 +14,17 @@ export interface TreeViewNode {
readonly treeItem: TreeItem | Thenable<TreeItem>
}

export type UseTreeViewOptions<T> =
& Omit<TreeViewOptions<T>, 'treeDataProvider'>
& Pick<TreeDataProvider<T>, 'resolveTreeItem'>
& {
title?: MaybeRefOrGetter<string | undefined>
badge?: MaybeRefOrGetter<ViewBadge | undefined>
/**
* Additional watch source to trigger a change event. Useful when `treeItem` is a promise.
*/
watchSource?: AnyWatchSource
}
export type UseTreeViewOptions<T>
= & Omit<TreeViewOptions<T>, 'treeDataProvider'>
& Pick<TreeDataProvider<T>, 'resolveTreeItem'>
& {
title?: MaybeRefOrGetter<string | undefined>
badge?: MaybeRefOrGetter<ViewBadge | undefined>
/**
* Additional watch source to trigger a change event. Useful when `treeItem` is a promise.
*/
watchSource?: AnyWatchSource
}

/**
* Register a tree view. See `vscode::window.createTreeView`.
Expand Down
16 changes: 8 additions & 8 deletions packages/core/src/utils/defineConfigs.ts
Original file line number Diff line number Diff line change
Expand Up @@ -28,15 +28,15 @@ type ConfigTypeRaw<T> = ConfigTypeSingle<T> | ConfigTypeSingle<T>[]

export type ConfigTypeOptions = Record<string, ConfigTypeRaw<any>>

type ParseConfigType<C extends ConfigTypeRaw<any>> =
C extends (infer C1)[] ? (C1 extends ConfigTypeSingle<any> ? ParseConfigType<C1> : never)
type ParseConfigType<C extends ConfigTypeRaw<any>>
= C extends (infer C1)[] ? (C1 extends ConfigTypeSingle<any> ? ParseConfigType<C1> : never)
: C extends ConfigType<infer T> ? T : (
C extends typeof String ? string :
C extends typeof Number ? number :
C extends typeof Boolean ? boolean :
C extends typeof Array ? any[] :
C extends typeof Object ? Record<string | number, any> :
C extends null ? null : never
C extends typeof String ? string
: C extends typeof Number ? number
: C extends typeof Boolean ? boolean
: C extends typeof Array ? any[]
: C extends typeof Object ? Record<string | number, any>
: C extends null ? null : never
)

export type ParseConfigTypeOptions<C extends ConfigTypeOptions> = {
Expand Down
6 changes: 3 additions & 3 deletions packages/creator/package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"name": "create-reactive-vscode",
"type": "module",
"version": "0.3.1",
"version": "0.3.2",
"description": "Reactive-vscode project creator",
"author": "_Kerman <[email protected]>",
"license": "MIT",
Expand Down Expand Up @@ -30,11 +30,11 @@
"prepublishOnly": "npm run build"
},
"devDependencies": {
"@types/node": "^20.19.1",
"@types/node": "^22.10.7",
"@types/prompts": "^2.4.9",
"chalk": "^5.4.1",
"prompts": "^2.4.2",
"tsdown": "^0.11.13",
"typescript": "^5.8.3"
"typescript": "^5.9.2"
}
}
6 changes: 3 additions & 3 deletions packages/metadata/package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"name": "@reactive-vscode/metadata",
"type": "module",
"version": "0.3.1",
"version": "0.3.2",
"description": "Metadata for reactive-vscode",
"author": "_Kerman <[email protected]>",
"license": "MIT",
Expand Down Expand Up @@ -40,11 +40,11 @@
},
"devDependencies": {
"@antfu/ni": "^0.23.2",
"@types/node": "18.x",
"@types/node": "^22.10.7",
"fast-glob": "^3.3.3",
"nodemon": "^3.1.10",
"simple-git": "^3.28.0",
"tsx": "^4.20.3",
"typescript": "^5.8.3"
"typescript": "^5.9.2"
}
}
8 changes: 4 additions & 4 deletions packages/mock/package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"name": "@reactive-vscode/mock",
"type": "module",
"version": "0.3.1",
"version": "0.3.2",
"description": "Mock VSCode API for testing",
"author": "_Kerman <[email protected]>",
"license": "MIT",
Expand Down Expand Up @@ -34,11 +34,11 @@
"prepublishOnly": "pnpm typecheck"
},
"dependencies": {
"vitest": "^2.1.9",
"vitest": "^3.2.4",
"vscode-uri": "^3.1.0"
},
"devDependencies": {
"@types/vscode": "^1.101.0",
"typescript": "^5.8.3"
"@types/vscode": "^1.102.0",
"typescript": "^5.9.2"
}
}
10 changes: 5 additions & 5 deletions packages/reactivity/package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"name": "@reactive-vscode/reactivity",
"type": "module",
"version": "0.3.1",
"version": "0.3.2",
"description": "Full Vue Reactivity API without DOM",
"author": "_Kerman <[email protected]>",
"license": "MIT",
Expand Down Expand Up @@ -34,10 +34,10 @@
"prepublishOnly": "pnpm typecheck && pnpm build"
},
"devDependencies": {
"@vue/reactivity": "^3.5.17",
"@vue/shared": "^3.5.17",
"typescript": "^5.8.3",
"vite": "^5.4.19",
"@vue/reactivity": "^3.5.20",
"@vue/shared": "^3.5.20",
"typescript": "^5.9.2",
"vite": "^7.1.3",
"vite-plugin-dts": "^4.5.4"
},
"publishConfig": {
Expand Down
8 changes: 4 additions & 4 deletions packages/vueuse/package.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"name": "@reactive-vscode/vueuse",
"type": "module",
"version": "0.3.1",
"version": "0.3.2",
"description": "Useful VueUse utilities for VSCode extension development",
"author": "_Kerman <[email protected]>",
"license": "MIT",
Expand Down Expand Up @@ -40,10 +40,10 @@
"@reactive-vscode/reactivity": "workspace:*"
},
"devDependencies": {
"@types/node": "^20.19.1",
"@types/node": "^22.10.7",
"@vueuse/core": "^12.8.2",
"typescript": "^5.8.3",
"vite": "^5.4.19",
"typescript": "^5.9.2",
"vite": "^7.1.3",
"vite-plugin-dts": "^4.5.4"
},
"publishConfig": {
Expand Down
Loading