@wox-launcher/wox-plugin 0.0.107 → 0.0.111

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/types/index.d.ts CHANGED
@@ -1,119 +1,532 @@
1
1
  import { MetadataCommand, PluginSettingDefinitionItem } from "./setting.js"
2
2
  import { AI } from "./ai.js"
3
3
 
4
+ /**
5
+ * A dictionary type for string key-value pairs.
6
+ *
7
+ * Used throughout the plugin API for passing arbitrary string data,
8
+ * such as context data, settings, and metadata.
9
+ *
10
+ * @example
11
+ * ```typescript
12
+ * const data: MapString = {
13
+ * "userId": "12345",
14
+ * "category": "documents",
15
+ * "tag": "favorite"
16
+ * }
17
+ * ```
18
+ */
4
19
  export type MapString = { [key: string]: string }
5
20
 
21
+ /**
22
+ * Operating system platform identifier.
23
+ *
24
+ * Used for platform-specific functionality and conditional behavior.
25
+ *
26
+ * - `windows`: Windows operating system
27
+ * - `darwin`: macOS operating system
28
+ * - `linux`: Linux operating system
29
+ *
30
+ * @example
31
+ * ```typescript
32
+ * if (platform === "darwin") {
33
+ * // macOS-specific code
34
+ * }
35
+ * ```
36
+ */
6
37
  export type Platform = "windows" | "darwin" | "linux"
7
38
 
39
+ /**
40
+ * Main plugin interface that all Wox plugins must implement.
41
+ *
42
+ * A plugin is a class or object that provides search functionality to Wox.
43
+ * It must implement the `init` and `query` methods.
44
+ *
45
+ * @example
46
+ * ```typescript
47
+ * class MyPlugin implements Plugin {
48
+ * private api: PublicAPI
49
+ *
50
+ * async init(ctx: Context, initParams: PluginInitParams): Promise<void> {
51
+ * this.api = initParams.API
52
+ * await this.api.Log(ctx, "Info", "Plugin initialized")
53
+ * }
54
+ *
55
+ * async query(ctx: Context, query: Query): Promise<Result[]> {
56
+ * return [{
57
+ * Title: "Hello World",
58
+ * SubTitle: "My first result",
59
+ * Icon: { ImageType: "emoji", ImageData: "👋" },
60
+ * Score: 100
61
+ * }]
62
+ * }
63
+ * }
64
+ * ```
65
+ */
8
66
  export interface Plugin {
67
+ /**
68
+ * Initialize the plugin with the provided context and parameters.
69
+ *
70
+ * Called once when the plugin is first loaded. Use this to:
71
+ * - Store the API for later use
72
+ * - Load initial data
73
+ * - Register callbacks
74
+ * - Set up any required resources
75
+ *
76
+ * @param ctx - Request context with trace ID for logging
77
+ * @param initParams - Initialization parameters including API and plugin directory
78
+ *
79
+ * @example
80
+ * ```typescript
81
+ * async init(ctx: Context, initParams: PluginInitParams): Promise<void> {
82
+ * this.api = initParams.API
83
+ * this.pluginDir = initParams.PluginDirectory
84
+ *
85
+ * // Load settings
86
+ * const apiKey = await this.api.GetSetting(ctx, "apiKey")
87
+ *
88
+ * // Register callbacks
89
+ * await this.api.OnSettingChanged(ctx, (ctx, key, value) => {
90
+ * console.log(`Setting changed: ${key} = ${value}`)
91
+ * })
92
+ * }
93
+ * ```
94
+ */
9
95
  init: (ctx: Context, initParams: PluginInitParams) => Promise<void>
96
+
97
+ /**
98
+ * Query handler that returns results based on user input.
99
+ *
100
+ * Called whenever the user types a query that triggers this plugin.
101
+ * The plugin should return a list of matching results sorted by relevance.
102
+ *
103
+ * @param ctx - Request context with trace ID for logging
104
+ * @param query - The query object containing search text, type, environment
105
+ * @returns Array of results to display to the user
106
+ *
107
+ * @example
108
+ * ```typescript
109
+ * async query(ctx: Context, query: Query): Promise<Result[]> {
110
+ * if (query.Type === "selection") {
111
+ * return this.handleSelection(query.Selection)
112
+ * }
113
+ *
114
+ * const searchTerm = query.Search.toLowerCase()
115
+ * return this.items
116
+ * .filter(item => item.name.toLowerCase().includes(searchTerm))
117
+ * .map(item => ({
118
+ * Title: item.name,
119
+ * SubTitle: item.description,
120
+ * Icon: this.getIcon(item),
121
+ * Score: this.calculateScore(item, searchTerm),
122
+ * Actions: [
123
+ * {
124
+ * Name: "Open",
125
+ * Icon: { ImageType: "emoji", ImageData: "🔗" },
126
+ * Action: async (ctx, actionCtx) => {
127
+ * await this.openItem(item)
128
+ * }
129
+ * }
130
+ * ]
131
+ * }))
132
+ * }
133
+ * ```
134
+ */
10
135
  query: (ctx: Context, query: Query) => Promise<Result[]>
11
136
  }
12
137
 
138
+ /**
139
+ * User-selected or drag-dropped data.
140
+ *
141
+ * When a plugin has the `MetadataFeatureQuerySelection` feature enabled,
142
+ * it can receive selection queries in addition to input queries.
143
+ *
144
+ * @example
145
+ * ```typescript
146
+ * async query(ctx: Context, query: Query): Promise<Result[]> {
147
+ * if (query.Type === "selection") {
148
+ * const selection = query.Selection
149
+ * if (selection.Type === "text") {
150
+ * console.log("Selected text:", selection.Text)
151
+ * } else if (selection.Type === "file") {
152
+ * console.log("Selected files:", selection.FilePaths)
153
+ * }
154
+ * }
155
+ * return []
156
+ * }
157
+ * ```
158
+ */
13
159
  export interface Selection {
160
+ /**
161
+ * The type of selection data.
162
+ *
163
+ * - `text`: User has selected text content
164
+ * - `file`: User has selected or drag-dropped files
165
+ */
14
166
  Type: "text" | "file"
15
- // Only available when Type is text
167
+ /**
168
+ * The selected text content.
169
+ *
170
+ * Only available when Type is "text".
171
+ */
16
172
  Text: string
17
- // Only available when Type is file
173
+ /**
174
+ * Array of selected file paths.
175
+ *
176
+ * Only available when Type is "file".
177
+ * Contains full paths to all selected/dropped files.
178
+ */
18
179
  FilePaths: string[]
19
180
  }
20
181
 
182
+ /**
183
+ * Environment context for a query.
184
+ *
185
+ * Provides information about the user's current environment when the
186
+ * query was made, such as the active window, browser URL, etc.
187
+ *
188
+ * This allows plugins to provide context-aware results.
189
+ *
190
+ * @example
191
+ * ```typescript
192
+ * // Show different results based on active window
193
+ * async query(ctx: Context, query: Query): Promise<Result[]> {
194
+ * if (query.Env.ActiveWindowTitle.includes("Visual Studio")) {
195
+ * return this.getVSCodeActions()
196
+ * }
197
+ * return []
198
+ * }
199
+ * ```
200
+ */
21
201
  export interface QueryEnv {
22
202
  /**
23
- * Active window title when user query
203
+ * Title of the active window when the query was made.
204
+ *
205
+ * Useful for context-aware results based on what application
206
+ * the user is currently using.
24
207
  */
25
208
  ActiveWindowTitle: string
26
209
 
27
210
  /**
28
- * Active window pid when user query, 0 if not available
211
+ * Process ID of the active window.
212
+ *
213
+ * Zero if the information is not available.
29
214
  */
30
215
  ActiveWindowPid: number
31
216
 
32
217
  /**
33
- * Active window icon when user query, may be empty
218
+ * Icon of the active window.
219
+ *
220
+ * May be empty if no icon is available.
34
221
  */
35
222
  ActiveWindowIcon: WoxImage
36
223
 
37
- // active browser url when user query
38
- // Only available when active window is browser and https://github.com/Wox-launcher/Wox.Chrome.Extension is installed
224
+ /**
225
+ * URL of the active browser tab.
226
+ *
227
+ * Only available when:
228
+ * - The active window is a supported browser
229
+ * - The Wox browser extension is installed
230
+ *
231
+ * @see https://github.com/Wox-launcher/Wox.Chrome.Extension
232
+ */
39
233
  ActiveBrowserUrl: string
40
234
  }
41
235
 
236
+ /**
237
+ * Query object containing user input and context.
238
+ *
239
+ * Passed to the plugin's `query()` method, contains all information
240
+ * about the user's search query including the search text, type,
241
+ * trigger keyword, and environment context.
242
+ *
243
+ * @example
244
+ * ```typescript
245
+ * async query(ctx: Context, query: Query): Promise<Result[]> {
246
+ * // Handle input query
247
+ * if (query.Type === "input") {
248
+ * console.log("Search:", query.Search)
249
+ * console.log("Trigger:", query.TriggerKeyword)
250
+ * }
251
+ *
252
+ * // Handle selection query
253
+ * if (query.Type === "selection") {
254
+ * console.log("Selection:", query.Selection)
255
+ * }
256
+ *
257
+ * // Check environment
258
+ * if (query.Env.ActiveBrowserUrl) {
259
+ * console.log("Browser:", query.Env.ActiveBrowserUrl)
260
+ * }
261
+ * }
262
+ * ```
263
+ */
42
264
  export interface Query {
43
265
  /**
44
- * Query id passed from UI to correlate async updates.
266
+ * Unique query identifier.
267
+ *
268
+ * Used to correlate async updates with the original query.
269
+ * Pass this ID when calling UpdateResult or PushResults.
45
270
  */
46
271
  Id: string
272
+
47
273
  /**
48
- * By default, Wox will only pass input query to plugin.
49
- * plugin author need to enable MetadataFeatureQuerySelection feature to handle selection query
274
+ * Query type.
275
+ *
276
+ * - `input`: User typed a query
277
+ * - `selection`: User selected text or drag-dropped files
278
+ *
279
+ * Note: Selection queries require the `MetadataFeatureQuerySelection` feature.
50
280
  */
51
281
  Type: "input" | "selection"
282
+
52
283
  /**
53
- * Raw query, this includes trigger keyword if it has
54
- * We didn't recommend use this property directly. You should always use Search property.
284
+ * Raw query string including trigger keyword.
55
285
  *
56
- * NOTE: Only available when query type is input
286
+ * Not recommended for direct use. Use `Search` instead for the
287
+ * actual search term without the trigger keyword.
288
+ *
289
+ * Only available when Type is "input".
57
290
  */
58
291
  RawQuery: string
292
+
59
293
  /**
60
- * Trigger keyword of a query. It can be empty if user is using global trigger keyword.
294
+ * Trigger keyword that activated this plugin.
295
+ *
296
+ * Empty if using global trigger keyword.
61
297
  *
62
- * NOTE: Only available when query type is input
298
+ * Only available when Type is "input".
299
+ *
300
+ * @example
301
+ * If user types "git status", TriggerKeyword is "git" and Search is "status"
63
302
  */
64
303
  TriggerKeyword?: string
304
+
65
305
  /**
66
- * Command part of a query.
306
+ * Command part of the query (between trigger and search).
307
+ *
308
+ * Only available when Type is "input".
67
309
  *
68
- * NOTE: Only available when query type is input
310
+ * @example
311
+ * If user types "myplugin cmd search", Command is "cmd" and Search is "search"
69
312
  */
70
313
  Command?: string
314
+
71
315
  /**
72
- * Search part of a query.
316
+ * The actual search term.
317
+ *
318
+ * This is the text the user wants to search for, without
319
+ * trigger keyword or command. Use this for your search logic.
73
320
  *
74
- * NOTE: Only available when query type is input
321
+ * Only available when Type is "input".
75
322
  */
76
323
  Search: string
77
324
 
78
325
  /**
79
- * User selected or drag-drop data, can be text or file or image etc
326
+ * User selected or drag-dropped data.
80
327
  *
81
- * NOTE: Only available when query type is selection
328
+ * Only available when Type is "selection".
82
329
  */
83
330
  Selection: Selection
84
331
 
85
332
  /**
86
- * Additional query environment data
87
- * expose more context env data to plugin, E.g. plugin A only show result when active window title is "Chrome"
333
+ * Environment context when the query was made.
334
+ *
335
+ * Includes information about the active window, browser URL, etc.
336
+ * Use this to provide context-aware results.
88
337
  */
89
338
  Env: QueryEnv
90
339
 
91
340
  /**
92
- * Whether current query is global query
341
+ * Check if this is a global query (no trigger keyword).
342
+ *
343
+ * @returns true if triggered globally, false if triggered by keyword
93
344
  */
94
345
  IsGlobalQuery(): boolean
95
346
  }
96
347
 
348
+ /**
349
+ * A search result displayed to the user.
350
+ *
351
+ * Results are displayed in the Wox UI and can include icons, previews,
352
+ * actions, and tail elements for additional information.
353
+ *
354
+ * @example
355
+ * ```typescript
356
+ * const result: Result = {
357
+ * Id: "result-1",
358
+ * Title: "Open Calculator",
359
+ * SubTitle: "Launch the system calculator app",
360
+ * Icon: { ImageType: "emoji", ImageData: "🔢" },
361
+ * Score: 100,
362
+ * Preview: {
363
+ * PreviewType: "markdown",
364
+ * PreviewData: "# Calculator\n\nA simple calculator app",
365
+ * PreviewProperties: {}
366
+ * },
367
+ * Tails: [
368
+ * { Type: "text", Text: "⌘⏎ Quick Action" }
369
+ * ],
370
+ * Actions: [
371
+ * {
372
+ * Name: "Open",
373
+ * Icon: { ImageType: "emoji", ImageData: "🚀" },
374
+ * Action: async (ctx, actionCtx) => {
375
+ * // Open calculator
376
+ * }
377
+ * }
378
+ * ]
379
+ * }
380
+ * ```
381
+ */
97
382
  export interface Result {
383
+ /**
384
+ * Unique identifier for this result.
385
+ *
386
+ * Optional. If not provided, Wox will generate a random ID.
387
+ * Use this ID with UpdateResult to update the result later.
388
+ */
98
389
  Id?: string
390
+
391
+ /**
392
+ * Main title displayed to the user.
393
+ *
394
+ * This is the primary text shown in the result list.
395
+ * Should be concise but descriptive.
396
+ */
99
397
  Title: string
398
+
399
+ /**
400
+ * Secondary text shown below the title.
401
+ *
402
+ * Use for additional context like description, path, or metadata.
403
+ */
100
404
  SubTitle?: string
405
+
406
+ /**
407
+ * Icon displayed next to the result.
408
+ *
409
+ * Can be emoji, image path, base64, etc.
410
+ */
101
411
  Icon: WoxImage
412
+
413
+ /**
414
+ * Preview panel content.
415
+ *
416
+ * When selected, this content is shown in the preview panel.
417
+ * Supports markdown, text, images, URLs, and files.
418
+ */
102
419
  Preview?: WoxPreview
420
+
421
+ /**
422
+ * Relevance score for sorting.
423
+ *
424
+ * Higher values appear first in the result list.
425
+ * Default is 0.
426
+ */
103
427
  Score?: number
428
+
429
+ /**
430
+ * Group name for organizing results.
431
+ *
432
+ * Results with the same group name are displayed together
433
+ * with a group header.
434
+ */
104
435
  Group?: string
436
+
437
+ /**
438
+ * Score for group sorting.
439
+ *
440
+ * Determines the order of groups in the result list.
441
+ */
105
442
  GroupScore?: number
443
+
444
+ /**
445
+ * Additional visual elements displayed after the result.
446
+ *
447
+ * Tails are small UI elements like text labels or icons
448
+ * shown to the right of the result.
449
+ *
450
+ * @example
451
+ * ```typescript
452
+ * Tails: [
453
+ * { Type: "text", Text: "⭐ Favorite" },
454
+ * { Type: "image", Image: { ImageType: "emoji", ImageData: "🔥" } }
455
+ * ]
456
+ * ```
457
+ */
106
458
  Tails?: ResultTail[]
459
+
460
+ /**
461
+ * User actions available for this result.
462
+ *
463
+ * Actions are shown when the result is selected and can be
464
+ * triggered via keyboard shortcuts or clicking.
465
+ */
107
466
  Actions?: ResultAction[]
108
467
  }
109
468
 
469
+ /**
470
+ * A visual element displayed after a result.
471
+ *
472
+ * Tails are small UI elements that provide additional information
473
+ * or quick actions. They appear to the right of the result in
474
+ * the list view.
475
+ *
476
+ * @example
477
+ * ```typescript
478
+ * // Text tail for status
479
+ * { Type: "text", Text: "✓ Verified", Id: "status-tail" }
480
+ *
481
+ * // Image tail for icon
482
+ * { Type: "image", Image: { ImageType: "emoji", ImageData: "🔥" } }
483
+ * ```
484
+ */
110
485
  export interface ResultTail {
486
+ /**
487
+ * The type of tail content.
488
+ *
489
+ * - `text`: Display text content
490
+ * - `image`: Display an icon or image
491
+ */
111
492
  Type: "text" | "image"
493
+
494
+ /**
495
+ * Text content for text tails.
496
+ *
497
+ * Only used when Type is "text".
498
+ */
112
499
  Text?: string
500
+
501
+ /**
502
+ * Image content for image tails.
503
+ *
504
+ * Only used when Type is "image".
505
+ */
113
506
  Image?: WoxImage
114
- /** Tail id, should be unique. It's optional, if you don't set it, Wox will assign a random id for you */
507
+
508
+ /**
509
+ * Unique identifier for this tail.
510
+ *
511
+ * Optional. If not provided, Wox generates a random ID.
512
+ * Use this to identify specific tails for updates.
513
+ */
115
514
  Id?: string
116
- /** Additional data associate with this tail, can be retrieved later */
515
+
516
+ /**
517
+ * Additional data associated with this tail.
518
+ *
519
+ * Store arbitrary key-value pairs for identification and metadata.
520
+ *
521
+ * Note: This data is NOT passed to action callbacks.
522
+ * Use ResultAction.ContextData for data that needs to be available
523
+ * in action handlers.
524
+ *
525
+ * Tail context data is primarily used for:
526
+ * - Identifying specific tails (e.g., custom IDs, tags)
527
+ * - Storing tail metadata for UI updates
528
+ * - System-level tail identification (e.g., "system:favorite")
529
+ */
117
530
  ContextData?: MapString
118
531
  }
119
532
 
@@ -145,6 +558,8 @@ export interface UpdatableResult {
145
558
  Title?: string
146
559
  /** Optional - update the subtitle */
147
560
  SubTitle?: string
561
+ /** Optional - update the icon */
562
+ Icon?: WoxImage
148
563
  /** Optional - update the tails */
149
564
  Tails?: ResultTail[]
150
565
  /** Optional - update the preview */
@@ -153,112 +568,424 @@ export interface UpdatableResult {
153
568
  Actions?: ResultAction[]
154
569
  }
155
570
 
571
+ /**
572
+ * Type of result action.
573
+ *
574
+ * - `execute`: Immediately execute the action's callback function
575
+ * - `form`: Display a form to the user before executing
576
+ */
156
577
  export type ResultActionType = "execute" | "form"
157
578
 
579
+ /**
580
+ * A user action that can be performed on a result.
581
+ *
582
+ * Actions are displayed when a result is selected and can be triggered
583
+ * via keyboard shortcuts or by clicking. There are two types:
584
+ * execute actions (run immediately) and form actions (show form first).
585
+ *
586
+ * @example
587
+ * ```typescript
588
+ * const action: ExecuteResultAction = {
589
+ * Name: "Copy to Clipboard",
590
+ * Icon: { ImageType: "emoji", ImageData: "📋" },
591
+ * IsDefault: true,
592
+ * Hotkey: "Ctrl+C",
593
+ * Action: async (ctx, actionCtx) => {
594
+ * await api.Copy(ctx, { type: "text", text: "Hello" })
595
+ * }
596
+ * }
597
+ * ```
598
+ */
158
599
  export type ResultAction = ExecuteResultAction | FormResultAction
159
600
 
601
+ /**
602
+ * An action that executes immediately when triggered.
603
+ *
604
+ * Execute actions run their callback function as soon as the user
605
+ * activates them (via keyboard shortcut or click).
606
+ *
607
+ * @example
608
+ * ```typescript
609
+ * const action: ExecuteResultAction = {
610
+ * Id: "action-copy",
611
+ * Name: "Copy",
612
+ * Icon: { ImageType: "emoji", ImageData: "📋" },
613
+ * IsDefault: true,
614
+ * PreventHideAfterAction: false,
615
+ * Hotkey: "Ctrl+C",
616
+ * ContextData: { "copyType": "text" },
617
+ * Action: async (ctx, actionCtx) => {
618
+ * console.log("ResultId:", actionCtx.ResultId)
619
+ * await this.copyItem(ctx, actionCtx)
620
+ * }
621
+ * }
622
+ * ```
623
+ */
160
624
  export interface ExecuteResultAction {
161
625
  /**
162
- * Result id, should be unique. It's optional, if you don't set it, Wox will assign a random id for you
626
+ * Unique identifier for this action.
627
+ *
628
+ * Optional. If not provided, Wox generates a random ID.
629
+ * Use this to identify the action for updates or logging.
163
630
  */
164
631
  Id?: string
632
+
633
+ /**
634
+ * Action type discriminator.
635
+ *
636
+ * Set to "execute" for immediate execution actions.
637
+ */
165
638
  Type?: "execute"
639
+
640
+ /**
641
+ * Display name for the action.
642
+ *
643
+ * This is shown to the user in the UI.
644
+ */
166
645
  Name: string
646
+
647
+ /**
648
+ * Icon displayed next to the action name.
649
+ */
167
650
  Icon?: WoxImage
651
+
168
652
  /**
169
- * If true, Wox will use this action as default action. There can be only one default action in results
170
- * This can be omitted, if you don't set it, Wox will use the first action as default action
653
+ * Whether this is the default action.
654
+ *
655
+ * If true, this action is triggered when the user presses Enter.
656
+ * Only one action per result can be the default.
657
+ * If not set, the first action becomes the default.
171
658
  */
172
659
  IsDefault?: boolean
660
+
173
661
  /**
174
- * If true, Wox will not hide after user select this result
662
+ * Whether to keep Wox visible after executing this action.
663
+ *
664
+ * If true, Wox remains open after the action completes.
665
+ * Useful for actions that update the result rather than navigate away.
175
666
  */
176
667
  PreventHideAfterAction?: boolean
668
+
669
+ /**
670
+ * The callback function to execute when the action is triggered.
671
+ *
672
+ * @param ctx - Request context
673
+ * @param actionContext - Action context with result ID and context data
674
+ */
177
675
  Action: (ctx: Context, actionContext: ActionContext) => Promise<void>
676
+
178
677
  /**
179
- * Hotkey to trigger this action. E.g. "ctrl+Shift+Space", "Ctrl+1", "Command+K"
180
- * Case insensitive, space insensitive
678
+ * Keyboard shortcut to trigger this action.
181
679
  *
182
- * If IsDefault is true, Hotkey will be set to enter key by default
680
+ * Examples: "Ctrl+Shift+Space", "Ctrl+1", "Command+K"
681
+ * Case and space insensitive.
682
+ *
683
+ * If IsDefault is true, the hotkey defaults to Enter.
183
684
  */
184
685
  Hotkey?: string
686
+
185
687
  /**
186
- * Additional data associate with this action, can be retrieved later
688
+ * Additional data associated with this action.
689
+ *
690
+ * This data is passed to ActionContext.ContextData when
691
+ * the action is executed. Use it to identify which action
692
+ * was triggered or pass custom parameters.
187
693
  */
188
694
  ContextData?: MapString
189
695
  }
190
696
 
697
+ /**
698
+ * An action that shows a form before executing.
699
+ *
700
+ * Form actions display a form to the user, collect input,
701
+ * and then execute the OnSubmit callback with the form values.
702
+ *
703
+ * @example
704
+ * ```typescript
705
+ * const action: FormResultAction = {
706
+ * Name: "Create New Item",
707
+ * Icon: { ImageType: "emoji", ImageData: "➕" },
708
+ * Form: [
709
+ * createTextboxSetting({
710
+ * key: "name",
711
+ * label: "Name",
712
+ * defaultValue: ""
713
+ * }),
714
+ * createCheckboxSetting({
715
+ * key: "enabled",
716
+ * label: "Enable",
717
+ * defaultValue: "true"
718
+ * })
719
+ * ],
720
+ * OnSubmit: async (ctx, formCtx) => {
721
+ * console.log("Name:", formCtx.Values["name"])
722
+ * console.log("Enabled:", formCtx.Values["enabled"])
723
+ * await this.createItem(ctx, formCtx.Values)
724
+ * }
725
+ * }
726
+ * ```
727
+ */
191
728
  export interface FormResultAction {
192
729
  /**
193
- * Result id, should be unique. It's optional, if you don't set it, Wox will assign a random id for you
730
+ * Unique identifier for this action.
731
+ *
732
+ * Optional. If not provided, Wox generates a random ID.
194
733
  */
195
734
  Id?: string
735
+
736
+ /**
737
+ * Action type discriminator.
738
+ *
739
+ * Must be "form" for form-based actions.
740
+ */
196
741
  Type: "form"
742
+
743
+ /**
744
+ * Display name for the action.
745
+ */
197
746
  Name: string
747
+
748
+ /**
749
+ * Icon displayed next to the action name.
750
+ */
198
751
  Icon?: WoxImage
752
+
199
753
  /**
200
- * If true, Wox will use this action as default action. There can be only one default action in results
201
- * This can be omitted, if you don't set it, Wox will use the first action as default action
754
+ * Whether this is the default action.
755
+ *
756
+ * If true, this action is triggered when the user presses Enter.
757
+ * Only one action per result can be the default.
202
758
  */
203
759
  IsDefault?: boolean
760
+
204
761
  /**
205
- * If true, Wox will not hide after user select this result
762
+ * Whether to keep Wox visible after executing this action.
206
763
  */
207
764
  PreventHideAfterAction?: boolean
765
+
766
+ /**
767
+ * Form definition to display.
768
+ *
769
+ * Array of setting items that define the form fields.
770
+ */
208
771
  Form: PluginSettingDefinitionItem[]
772
+
773
+ /**
774
+ * Callback executed when the form is submitted.
775
+ *
776
+ * @param ctx - Request context
777
+ * @param actionContext - Form action context with submitted values
778
+ */
209
779
  OnSubmit: (ctx: Context, actionContext: FormActionContext) => Promise<void>
780
+
210
781
  /**
211
- * Hotkey to trigger this action. E.g. "ctrl+Shift+Space", "Ctrl+1", "Command+K"
212
- * Case insensitive, space insensitive
782
+ * Keyboard shortcut to trigger this action.
213
783
  *
214
- * If IsDefault is true, Hotkey will be set to enter key by default
784
+ * Examples: "Ctrl+Shift+Space", "Ctrl+1", "Command+K"
215
785
  */
216
786
  Hotkey?: string
787
+
217
788
  /**
218
- * Additional data associate with this action, can be retrieved later
789
+ * Additional data associated with this action.
219
790
  */
220
791
  ContextData?: MapString
221
792
  }
222
793
 
794
+ /**
795
+ * Context passed to action callback functions.
796
+ *
797
+ * When a user triggers an action, Wox creates an ActionContext
798
+ * containing information about which result and action were triggered,
799
+ * along with any custom context data.
800
+ *
801
+ * @example
802
+ * ```typescript
803
+ * Action: async (ctx: Context, actionContext: ActionContext) => {
804
+ * console.log("Result ID:", actionContext.ResultId)
805
+ * console.log("Action ID:", actionContext.ResultActionId)
806
+ * console.log("Custom data:", actionContext.ContextData)
807
+ *
808
+ * // Update the result
809
+ * await api.UpdateResult(ctx, {
810
+ * Id: actionContext.ResultId,
811
+ * Title: "Updated!"
812
+ * })
813
+ * }
814
+ * ```
815
+ */
223
816
  export interface ActionContext {
224
817
  /**
225
- * The ID of the result that triggered this action
226
- * This is automatically set by Wox when the action is invoked
227
- * Useful for calling UpdateResult API to update the result's UI
818
+ * The ID of the result that triggered this action.
819
+ *
820
+ * Automatically set by Wox when the action is invoked.
821
+ * Use this with UpdateResult to modify the result's UI.
228
822
  */
229
823
  ResultId: string
230
824
  /**
231
- * The ID of the action that was triggered
232
- * This is automatically set by Wox when the action is invoked
233
- * Useful for calling UpdateResult API to update this action's UI
825
+ * The ID of the action that was triggered.
826
+ *
827
+ * Automatically set by Wox when the action is invoked.
828
+ * Useful for identifying which action was executed.
234
829
  */
235
830
  ResultActionId: string
236
831
  /**
237
- * Additional data associated with this action
832
+ * Additional data associated with this action.
833
+ *
834
+ * Contains the ContextData from the ResultAction that was triggered.
835
+ * Use this to pass custom parameters to your action handler.
238
836
  */
239
837
  ContextData: MapString
240
838
  }
241
839
 
840
+ /**
841
+ * Extended action context for form submissions.
842
+ *
843
+ * In addition to the standard ActionContext fields, this includes
844
+ * the form values submitted by the user.
845
+ *
846
+ * @example
847
+ * ```typescript
848
+ * OnSubmit: async (ctx: Context, formContext: FormActionContext) => {
849
+ * const name = formContext.Values["name"]
850
+ * const email = formContext.Values["email"]
851
+ * console.log("User submitted:", name, email)
852
+ * }
853
+ * ```
854
+ */
242
855
  export interface FormActionContext extends ActionContext {
856
+ /**
857
+ * Form field values submitted by the user.
858
+ *
859
+ * Keys are the setting keys, values are the user-submitted strings.
860
+ */
243
861
  Values: Record<string, string>
244
862
  }
245
863
 
864
+ /**
865
+ * Most Recently Used (MRU) item data.
866
+ *
867
+ * Wox keeps track of recently selected items and can restore them
868
+ * via the OnMRURestore callback.
869
+ *
870
+ * @example
871
+ * ```typescript
872
+ * await api.OnMRURestore(ctx, async (ctx, mruData) => {
873
+ * // Find the item in our data
874
+ * const item = this.findById(mruData.ContextData["id"])
875
+ * if (!item) {
876
+ * return null // Item no longer exists
877
+ * }
878
+ *
879
+ * // Return a result for the MRU item
880
+ * return {
881
+ * Title: item.name,
882
+ * SubTitle: item.description,
883
+ * Icon: mruData.Icon
884
+ * }
885
+ * })
886
+ * ```
887
+ */
246
888
  export interface MRUData {
889
+ /**
890
+ * Plugin ID that owns this MRU item.
891
+ */
247
892
  PluginID: string
893
+ /**
894
+ * Title of the MRU item.
895
+ */
248
896
  Title: string
897
+ /**
898
+ * Subtitle of the MRU item.
899
+ */
249
900
  SubTitle: string
901
+ /**
902
+ * Icon of the MRU item.
903
+ */
250
904
  Icon: WoxImage
905
+ /**
906
+ * Custom data associated with this MRU item.
907
+ *
908
+ * Use this to store identifiers or metadata needed to
909
+ * reconstruct the item when restoring from MRU.
910
+ */
251
911
  ContextData: MapString
252
912
  }
253
913
 
914
+ /**
915
+ * Parameters passed to the plugin's init method.
916
+ *
917
+ * Contains the API instance and plugin directory path.
918
+ *
919
+ * @example
920
+ * ```typescript
921
+ * async init(ctx: Context, initParams: PluginInitParams): Promise<void> {
922
+ * this.api = initParams.API
923
+ * this.pluginDir = initParams.PluginDirectory
924
+ *
925
+ * // Load data from plugin directory
926
+ * const dataPath = `${this.pluginDir}/data.json`
927
+ * this.data = JSON.parse(await fs.readFile(dataPath, 'utf-8'))
928
+ * }
929
+ * ```
930
+ */
254
931
  export interface PluginInitParams {
932
+ /**
933
+ * The public API for interacting with Wox.
934
+ *
935
+ * Store this for later use in your plugin methods.
936
+ */
255
937
  API: PublicAPI
938
+ /**
939
+ * Absolute path to the plugin directory.
940
+ *
941
+ * Use this to load plugin-specific data files, configs, etc.
942
+ */
256
943
  PluginDirectory: string
257
944
  }
258
945
 
946
+ /**
947
+ * Parameters for changing the current Wox query.
948
+ *
949
+ * Used with the ChangeQuery API to programmatically change
950
+ * what the user is searching for.
951
+ *
952
+ * @example
953
+ * ```typescript
954
+ * // Change to input query
955
+ * await api.ChangeQuery(ctx, {
956
+ * QueryType: "input",
957
+ * QueryText: "github wox"
958
+ * })
959
+ *
960
+ * // Change to selection query
961
+ * await api.ChangeQuery(ctx, {
962
+ * QueryType: "selection",
963
+ * QuerySelection: {
964
+ * Type: "text",
965
+ * Text: "selected text"
966
+ * }
967
+ * })
968
+ * ```
969
+ */
259
970
  export interface ChangeQueryParam {
971
+ /**
972
+ * The type of query to change to.
973
+ *
974
+ * - `input`: Change to a text input query
975
+ * - `selection`: Change to a selection-based query
976
+ */
260
977
  QueryType: "input" | "selection"
978
+ /**
979
+ * New query text (for input queries).
980
+ *
981
+ * Only used when QueryType is "input".
982
+ */
261
983
  QueryText?: string
984
+ /**
985
+ * New selection data (for selection queries).
986
+ *
987
+ * Only used when QueryType is "selection".
988
+ */
262
989
  QuerySelection?: Selection
263
990
  }
264
991
 
@@ -271,11 +998,51 @@ export interface RefreshQueryParam {
271
998
  PreserveSelectedIndex: boolean
272
999
  }
273
1000
 
1001
+ /**
1002
+ * Type of data to copy to clipboard.
1003
+ *
1004
+ * - `text`: Copy plain text
1005
+ * - `image`: Copy image data
1006
+ */
274
1007
  export type CopyType = "text" | "image"
275
1008
 
1009
+ /**
1010
+ * Parameters for copying data to clipboard.
1011
+ *
1012
+ * Used with the Copy API to copy text or images.
1013
+ *
1014
+ * @example
1015
+ * ```typescript
1016
+ * // Copy text
1017
+ * await api.Copy(ctx, {
1018
+ * type: "text",
1019
+ * text: "Hello, World!"
1020
+ * })
1021
+ *
1022
+ * // Copy image
1023
+ * await api.Copy(ctx, {
1024
+ * type: "image",
1025
+ * text: "",
1026
+ * woxImage: { ImageType: "base64", ImageData: "data:image/png;base64,..." }
1027
+ * })
1028
+ * ```
1029
+ */
276
1030
  export interface CopyParams {
1031
+ /**
1032
+ * Type of content to copy.
1033
+ */
277
1034
  type: CopyType
1035
+ /**
1036
+ * Text content to copy.
1037
+ *
1038
+ * Used when type is "text".
1039
+ */
278
1040
  text: string
1041
+ /**
1042
+ * Image data to copy.
1043
+ *
1044
+ * Used when type is "image".
1045
+ */
279
1046
  woxImage?: WoxImage
280
1047
  }
281
1048
 
@@ -485,30 +1252,251 @@ export interface PublicAPI {
485
1252
  Copy: (ctx: Context, params: CopyParams) => Promise<void>
486
1253
  }
487
1254
 
1255
+ /**
1256
+ * Type of image data.
1257
+ *
1258
+ * - `absolute`: Absolute file path to an image
1259
+ * - `relative`: Path relative to the plugin directory
1260
+ * - `base64`: Base64 encoded image with data URI prefix (e.g., "data:image/png;base64,...")
1261
+ * - `svg`: SVG string content
1262
+ * - `url`: HTTP/HTTPS URL to an image
1263
+ * - `emoji`: Emoji character
1264
+ * - `lottie`: Lottie animation JSON URL or data
1265
+ *
1266
+ * @example
1267
+ * ```typescript
1268
+ * // Absolute path
1269
+ * { ImageType: "absolute", ImageData: "/usr/share/icons/app.png" }
1270
+ *
1271
+ * // Relative path (from plugin directory)
1272
+ * { ImageType: "relative", ImageData: "./icons/icon.png" }
1273
+ *
1274
+ * // Base64 with data URI prefix
1275
+ * { ImageType: "base64", ImageData: "..." }
1276
+ *
1277
+ * // Emoji
1278
+ * { ImageType: "emoji", ImageData: "🔍" }
1279
+ *
1280
+ * // URL
1281
+ * { ImageType: "url", ImageData: "https://example.com/icon.png" }
1282
+ * ```
1283
+ */
488
1284
  export type WoxImageType = "absolute" | "relative" | "base64" | "svg" | "url" | "emoji" | "lottie"
489
1285
 
1286
+ /**
1287
+ * Image representation in Wox.
1288
+ *
1289
+ * Used throughout the plugin API for icons, previews, and UI elements.
1290
+ * The ImageData format depends on the ImageType.
1291
+ *
1292
+ * @example
1293
+ * ```typescript
1294
+ * const emojiIcon: WoxImage = {
1295
+ * ImageType: "emoji",
1296
+ * ImageData: "🔍"
1297
+ * }
1298
+ *
1299
+ * const base64Icon: WoxImage = {
1300
+ * ImageType: "base64",
1301
+ * ImageData: "..."
1302
+ * }
1303
+ *
1304
+ * const relativeIcon: WoxImage = {
1305
+ * ImageType: "relative",
1306
+ * ImageData: "./icons/my-icon.png"
1307
+ * }
1308
+ * ```
1309
+ */
490
1310
  export interface WoxImage {
1311
+ /**
1312
+ * The type of image data.
1313
+ *
1314
+ * Determines how ImageData should be interpreted.
1315
+ */
491
1316
  ImageType: WoxImageType
1317
+ /**
1318
+ * The image data.
1319
+ *
1320
+ * Format depends on ImageType:
1321
+ * - `absolute`: Absolute file path
1322
+ * - `relative`: Path relative to plugin directory
1323
+ * - `base64`: Data URI with base64 content (e.g., "data:image/png;base64,...")
1324
+ * - `svg`: SVG string content
1325
+ * - `url`: HTTP/HTTPS URL
1326
+ * - `emoji`: Single emoji character
1327
+ * - `lottie`: Lottie JSON URL or data
1328
+ */
492
1329
  ImageData: string
493
1330
  }
494
1331
 
1332
+ /**
1333
+ * Type of preview content.
1334
+ *
1335
+ * - `markdown`: Rendered markdown content
1336
+ * - `text`: Plain text content
1337
+ * - `image`: Image preview
1338
+ * - `url`: Website URL preview
1339
+ * - `file`: File preview
1340
+ */
495
1341
  export type WoxPreviewType = "markdown" | "text" | "image" | "url" | "file"
496
1342
 
1343
+ /**
1344
+ * Preview panel content for a result.
1345
+ *
1346
+ * When a result is selected, the preview panel displays additional
1347
+ * information using the specified preview type.
1348
+ *
1349
+ * @example
1350
+ * ```typescript
1351
+ * // Markdown preview
1352
+ * {
1353
+ * PreviewType: "markdown",
1354
+ * PreviewData: "# Title\n\nDescription with **formatting**",
1355
+ * PreviewProperties: {}
1356
+ * }
1357
+ *
1358
+ * // Image preview
1359
+ * {
1360
+ * PreviewType: "image",
1361
+ * PreviewData: "https://example.com/image.png",
1362
+ * PreviewProperties: { "height": "300" }
1363
+ * }
1364
+ *
1365
+ * // URL preview
1366
+ * {
1367
+ * PreviewType: "url",
1368
+ * PreviewData: "https://github.com/Wox-launcher/Wox",
1369
+ * PreviewProperties: {}
1370
+ * }
1371
+ * ```
1372
+ */
497
1373
  export interface WoxPreview {
1374
+ /**
1375
+ * The type of preview content.
1376
+ *
1377
+ * Determines how PreviewData is rendered.
1378
+ */
498
1379
  PreviewType: WoxPreviewType
1380
+ /**
1381
+ * The preview content data.
1382
+ *
1383
+ * Format depends on PreviewType:
1384
+ * - `markdown`: Markdown string to render
1385
+ * - `text`: Plain text string
1386
+ * - `image`: Image URL, path, or base64 data
1387
+ * - `url`: Website URL to preview
1388
+ * - `file`: File path to preview
1389
+ */
499
1390
  PreviewData: string
1391
+ /**
1392
+ * Additional properties for the preview.
1393
+ *
1394
+ * Type-specific options like height, width, scroll position, etc.
1395
+ *
1396
+ * @example
1397
+ * ```typescript
1398
+ * { "height": "400", "width": "600" }
1399
+ * { "scrollPosition": "top" }
1400
+ * ```
1401
+ */
500
1402
  PreviewProperties: Record<string, string>
501
1403
  }
502
1404
 
1405
+ /**
1406
+ * Request context for tracking and passing data.
1407
+ *
1408
+ * Context is passed to all plugin API calls and contains a trace ID
1409
+ * for logging and debugging. Plugins can also store custom values
1410
+ * in the context for passing between function calls.
1411
+ *
1412
+ * @example
1413
+ * ```typescript
1414
+ * // Create a new context
1415
+ * const ctx = NewContext()
1416
+ * const traceId = ctx.Get("traceId") // Auto-generated UUID
1417
+ *
1418
+ * // Store custom data
1419
+ * ctx.Set("userId", "12345")
1420
+ * ctx.Set("requestId", "req-abc")
1421
+ *
1422
+ * // Check if key exists
1423
+ * if (ctx.Exists("userId")) {
1424
+ * console.log("User ID:", ctx.Get("userId"))
1425
+ * }
1426
+ *
1427
+ * // Create with initial value
1428
+ * const ctxWithValue = NewContextWithValue("userId", "12345")
1429
+ * ```
1430
+ */
503
1431
  export declare interface Context {
1432
+ /**
1433
+ * Key-value storage for context data.
1434
+ *
1435
+ * Contains auto-generated trace ID and any custom values.
1436
+ */
504
1437
  Values: { [key: string]: string }
1438
+ /**
1439
+ * Get a value from the context.
1440
+ *
1441
+ * @param key - The key to retrieve
1442
+ * @returns The value, or undefined if not found
1443
+ */
505
1444
  Get: (key: string) => string | undefined
1445
+ /**
1446
+ * Set a value in the context.
1447
+ *
1448
+ * @param key - The key to set
1449
+ * @param value - The value to store
1450
+ */
506
1451
  Set: (key: string, value: string) => void
1452
+ /**
1453
+ * Check if a key exists in the context.
1454
+ *
1455
+ * @param key - The key to check
1456
+ * @returns true if the key exists, false otherwise
1457
+ */
507
1458
  Exists: (key: string) => boolean
508
1459
  }
509
1460
 
1461
+ /**
1462
+ * Create a new context with auto-generated trace ID.
1463
+ *
1464
+ * @returns A new Context instance with a UUID in the "traceId" key
1465
+ *
1466
+ * @example
1467
+ * ```typescript
1468
+ * const ctx = NewContext()
1469
+ * console.log(ctx.Get("traceId")) // e.g., "550e8400-e29b-41d4-a716-446655440000"
1470
+ * ```
1471
+ */
510
1472
  export function NewContext(): Context
511
1473
 
1474
+ /**
1475
+ * Create a new context with an initial key-value pair.
1476
+ *
1477
+ * @param key - The key to set
1478
+ * @param value - The value to store
1479
+ * @returns A new Context instance with the trace ID and custom value
1480
+ *
1481
+ * @example
1482
+ * ```typescript
1483
+ * const ctx = NewContextWithValue("userId", "12345")
1484
+ * console.log(ctx.Get("userId")) // "12345"
1485
+ * console.log(ctx.Get("traceId")) // auto-generated UUID
1486
+ * ```
1487
+ */
512
1488
  export function NewContextWithValue(key: string, value: string): Context
513
1489
 
1490
+ /**
1491
+ * Create a base64 WoxImage from image data.
1492
+ *
1493
+ * @param imageData - Base64 image data with data URI prefix (e.g., "data:image/png;base64,...")
1494
+ * @returns A WoxImage with type "base64"
1495
+ *
1496
+ * @example
1497
+ * ```typescript
1498
+ * const pngData = "..."
1499
+ * const icon = NewBase64WoxImage(pngData)
1500
+ * ```
1501
+ */
514
1502
  export function NewBase64WoxImage(imageData: string): WoxImage