-
-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathrenderer.ts
More file actions
44 lines (40 loc) · 1.36 KB
/
renderer.ts
File metadata and controls
44 lines (40 loc) · 1.36 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
export type * from "@vim-fall/core/renderer";
import type { Denops } from "@denops/std";
import type { Renderer, RenderParams } from "@vim-fall/core/renderer";
import { type DerivableArray, deriveArray } from "@vim-fall/custom/derivable";
import type { Detail, DetailUnit } from "./item.ts";
/**
* Defines a renderer for rendering items in a specific way.
*
* @param render - A function that renders items based on provided parameters.
* @returns A renderer object containing the `render` function.
*/
export function defineRenderer<T extends Detail = DetailUnit>(
render: (
denops: Denops,
params: RenderParams<T>,
options: { signal?: AbortSignal },
) => void | Promise<void>,
): Renderer<T> {
return { render };
}
/**
* Composes multiple renderers into a single renderer.
*
* Each renderer is applied sequentially in the order it is passed, allowing
* multiple render processes to be combined into one.
*
* @param renderers - The renderers to compose.
* @returns A single renderer that applies all given renderers in sequence.
*/
export function composeRenderers<T extends Detail>(
...renderers: DerivableArray<[Renderer<T>, ...Renderer<T>[]]>
): Renderer<T> {
return {
render: async (denops, params, options) => {
for (const renderer of deriveArray(renderers)) {
await renderer.render(denops, params, options);
}
},
};
}