-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathextension.ts
More file actions
61 lines (56 loc) · 2.17 KB
/
extension.ts
File metadata and controls
61 lines (56 loc) · 2.17 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
import * as vscode from 'vscode'
import { extractUrl } from './utils'
import { Commands } from './vscode/commands'
import { DataStore } from './vscode/db'
import { UploadonDropProvider } from './vscode/dropProvider'
export async function activate(context: vscode.ExtensionContext) {
const selector: vscode.DocumentSelector = {
language: '*',
scheme: 'file',
}
const disposable = [
vscode.commands.registerCommand(
'piclist.uploadFromClipboard',
async () => await Commands.commandManager.uploadImageFromClipboard(),
),
vscode.commands.registerCommand(
'piclist.uploadFromExplorer',
async () => await Commands.commandManager.uploadImageFromExplorer(),
),
vscode.commands.registerCommand('piclist.openImageDB', async () => await Commands.commandManager.openImageDB()),
vscode.commands.registerCommand(
'piclist.uploadFromInputBox',
async () => await Commands.commandManager.uploadImageFromInputBox(),
),
vscode.commands.registerCommand('piclist.deleteImage', async () => {
const editor = vscode.window.activeTextEditor
if (editor) {
const document = editor.document
const selection = editor.selection
const text = document.getText(selection)
const extractedURL = extractUrl(text)
if (extractedURL) {
const res = DataStore.searchUploadedFileDB(extractedURL)
const result = await Commands.commandManager.DeleteImage(res)
if (result) {
editor.edit(editBuilder => {
editBuilder.delete(selection)
})
} else {
vscode.window.showErrorMessage('Delete failed.')
}
}
}
}),
vscode.commands.registerCommand('piclist.uploadSelectedImg', async () => {
await Commands.commandManager.uploadSelectedImg()
}),
vscode.commands.registerCommand('piclist.uploadAllImgInFile', async () => {
await Commands.commandManager.uploadAllImgInFile()
}),
]
context.subscriptions.push(...disposable)
context.subscriptions.push(vscode.languages.registerDocumentDropEditProvider(selector, new UploadonDropProvider()))
return context
}
export function deactivate() {}