|
1 | | -import { SUPPORTED_DOCUMENT_PATTERN, VERSION_TRIGGER_CHARACTERS } from '#constants' |
2 | | -import { defineExtension, useCommands, watchEffect } from 'reactive-vscode' |
3 | | -import { languages } from 'vscode' |
| 1 | +import { defineExtension, useCommands } from 'reactive-vscode' |
4 | 2 | import { openFileInNpmx } from './commands/open-file-in-npmx' |
5 | 3 | import { openInBrowser } from './commands/open-in-browser' |
6 | 4 | import { commands, displayName, version } from './generated-meta' |
7 | 5 | import { useCodeActions } from './providers/code-actions' |
8 | | -import { VersionCompletionItemProvider } from './providers/completion-item/version' |
| 6 | +import { useCompletionItem } from './providers/completion-item' |
9 | 7 | import { useDiagnostics } from './providers/diagnostics' |
10 | | -import { NpmxDocumentLinkProvider } from './providers/document-link/npmx' |
11 | | -import { NpmxHoverProvider } from './providers/hover/npmx' |
12 | | -import { config, logger } from './state' |
13 | | - |
14 | | -const documentFilter = { pattern: SUPPORTED_DOCUMENT_PATTERN } |
| 8 | +import { useDocumentLink } from './providers/document-link' |
| 9 | +import { useHover } from './providers/hover' |
| 10 | +import { logger } from './state' |
15 | 11 |
|
16 | 12 | export const { activate, deactivate } = defineExtension(() => { |
17 | 13 | logger.info(`${displayName} Activated, v${version}`) |
18 | 14 |
|
19 | | - watchEffect((onCleanup) => { |
20 | | - if (!config.hover.enabled) |
21 | | - return |
22 | | - |
23 | | - const disposable = languages.registerHoverProvider(documentFilter, new NpmxHoverProvider()) |
24 | | - |
25 | | - onCleanup(() => disposable.dispose()) |
26 | | - }) |
27 | | - |
28 | | - watchEffect((onCleanup) => { |
29 | | - if (config.completion.version === 'off') |
30 | | - return |
31 | | - |
32 | | - const disposable = languages.registerCompletionItemProvider( |
33 | | - documentFilter, |
34 | | - new VersionCompletionItemProvider(), |
35 | | - ...VERSION_TRIGGER_CHARACTERS, |
36 | | - ) |
37 | | - |
38 | | - onCleanup(() => disposable.dispose()) |
39 | | - }) |
40 | | - |
41 | | - watchEffect((onCleanup) => { |
42 | | - if (config.packageLinks === 'off') |
43 | | - return |
44 | | - |
45 | | - const disposable = languages.registerDocumentLinkProvider(documentFilter, new NpmxDocumentLinkProvider()) |
46 | | - |
47 | | - onCleanup(() => disposable.dispose()) |
48 | | - }) |
49 | | - |
50 | 15 | useDiagnostics() |
51 | | - |
52 | 16 | useCodeActions() |
| 17 | + useHover() |
| 18 | + useCompletionItem() |
| 19 | + useDocumentLink() |
53 | 20 |
|
54 | 21 | useCommands({ |
55 | 22 | [commands.openInBrowser]: openInBrowser, |
|
0 commit comments