obsidian-dev-utils 1.7.7 → 2.0.0
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/CHANGELOG.md +10 -0
- package/dist/lib/@types/compare-versions.d.ts +37 -0
- package/dist/lib/JSON.cjs +2 -5
- package/dist/lib/Npm.cjs +1 -1
- package/dist/lib/Npm.d.ts +1 -0
- package/dist/lib/Root.cjs +4 -13
- package/dist/lib/Root.d.ts +0 -9
- package/dist/lib/_dependencies.cjs +49643 -0
- package/dist/lib/_dependencies.d.ts +6 -0
- package/dist/lib/bin/ESLint/@types/@stylistic__eslint-plugin.d.ts +16 -0
- package/dist/lib/bin/ESLint/@types/@typescript-eslint__eslint-plugin.d.ts +27 -0
- package/dist/lib/bin/ESLint/@types/@typescript-eslint__parser.d.ts +16 -0
- package/dist/lib/bin/ESLint/@types/eslint-plugin-deprecation.d.ts +17 -0
- package/dist/lib/bin/ESLint/@types/eslint-plugin-import.d.ts +15 -0
- package/dist/lib/bin/ESLint/@types/eslint-plugin-modules-newlines.d.ts +15 -0
- package/dist/lib/bin/ESLint/@types/globals.d.ts +22 -0
- package/dist/lib/bin/ESLint/ESLint.cjs +5 -6
- package/dist/lib/bin/ESLint/eslint.config.cjs +4 -2
- package/dist/lib/bin/ObsidianDevUtilsRepoPaths.cjs +2 -1
- package/dist/lib/bin/ObsidianDevUtilsRepoPaths.d.ts +2 -0
- package/dist/lib/bin/cli.cjs +2 -2
- package/dist/lib/bin/esbuild/Dependency.cjs +125 -0
- package/dist/lib/bin/esbuild/Dependency.d.ts +18 -0
- package/dist/lib/bin/esbuild/ObsidianPluginBuilder.cjs +1 -1
- package/dist/lib/bin/esbuild/index.cjs +4 -1
- package/dist/lib/bin/esbuild/index.d.ts +1 -0
- package/dist/lib/bin/esbuild/renameToCjsPlugin.cjs +15 -3
- package/dist/lib/bin/esbuild/renameToCjsPlugin.d.ts +2 -1
- package/dist/lib/bin/spellcheck.cjs +3 -4
- package/dist/lib/bin/version.cjs +13 -1
- package/dist/lib/obsidian/@types/Dataview/api/data-array.d.ts +134 -0
- package/dist/lib/obsidian/@types/Dataview/api/extensions.d.ts +15 -0
- package/dist/lib/obsidian/@types/Dataview/api/inline-api.d.ts +165 -0
- package/dist/lib/obsidian/@types/Dataview/api/plugin-api.d.ts +192 -0
- package/dist/lib/obsidian/@types/Dataview/api/result.d.ts +38 -0
- package/dist/lib/obsidian/@types/Dataview/data-import/common.d.ts +3 -0
- package/dist/lib/obsidian/@types/Dataview/data-import/csv.d.ts +3 -0
- package/dist/lib/obsidian/@types/Dataview/data-import/inline-field.d.ts +42 -0
- package/dist/lib/obsidian/@types/Dataview/data-import/markdown-file.d.ts +36 -0
- package/dist/lib/obsidian/@types/Dataview/data-import/persister.d.ts +32 -0
- package/dist/lib/obsidian/@types/Dataview/data-import/web-worker/import-entry.d.ts +1 -0
- package/dist/lib/obsidian/@types/Dataview/data-import/web-worker/import-impl.d.ts +3 -0
- package/dist/lib/obsidian/@types/Dataview/data-import/web-worker/import-manager.d.ts +32 -0
- package/dist/lib/obsidian/@types/Dataview/data-index/index.d.ts +179 -0
- package/dist/lib/obsidian/@types/Dataview/data-index/resolver.d.ts +20 -0
- package/dist/lib/obsidian/@types/Dataview/data-index/source.d.ts +71 -0
- package/dist/lib/obsidian/@types/Dataview/data-model/markdown.d.ts +109 -0
- package/dist/lib/obsidian/@types/Dataview/data-model/serialized/markdown.d.ts +103 -0
- package/dist/lib/obsidian/@types/Dataview/data-model/transferable.d.ts +7 -0
- package/dist/lib/obsidian/@types/Dataview/data-model/value.d.ts +148 -0
- package/dist/lib/obsidian/@types/Dataview/expression/binaryop.d.ts +29 -0
- package/dist/lib/obsidian/@types/Dataview/expression/context.d.ts +43 -0
- package/dist/lib/obsidian/@types/Dataview/expression/field.d.ts +82 -0
- package/dist/lib/obsidian/@types/Dataview/expression/functions.d.ts +137 -0
- package/dist/lib/obsidian/@types/Dataview/expression/parse.d.ts +143 -0
- package/dist/lib/obsidian/@types/Dataview/index.d.ts +21 -0
- package/dist/lib/obsidian/@types/Dataview/main.d.ts +44 -0
- package/dist/lib/obsidian/@types/Dataview/query/engine.d.ts +87 -0
- package/dist/lib/obsidian/@types/Dataview/query/parse.d.ts +31 -0
- package/dist/lib/obsidian/@types/Dataview/query/query.d.ts +95 -0
- package/dist/lib/obsidian/@types/Dataview/settings.d.ts +60 -0
- package/dist/lib/obsidian/@types/Dataview/typings/obsidian-ex.d.ts +28 -0
- package/dist/lib/obsidian/@types/Dataview/typings/workers.d.ts +4 -0
- package/dist/lib/obsidian/@types/Dataview/ui/export/markdown.d.ts +9 -0
- package/dist/lib/obsidian/@types/Dataview/ui/lp-render.d.ts +24 -0
- package/dist/lib/obsidian/@types/Dataview/ui/markdown.d.ts +73 -0
- package/dist/lib/obsidian/@types/Dataview/ui/refreshable-view.d.ts +15 -0
- package/dist/lib/obsidian/@types/Dataview/ui/render.d.ts +12 -0
- package/dist/lib/obsidian/@types/Dataview/ui/views/calendar-view.d.ts +17 -0
- package/dist/lib/obsidian/@types/Dataview/ui/views/inline-field-live-preview.d.ts +29 -0
- package/dist/lib/obsidian/@types/Dataview/ui/views/inline-view.d.ts +19 -0
- package/dist/lib/obsidian/@types/Dataview/ui/views/js-view.d.ts +23 -0
- package/dist/lib/obsidian/@types/Dataview/ui/views/list-view.d.ts +25 -0
- package/dist/lib/obsidian/@types/Dataview/ui/views/table-view.d.ts +28 -0
- package/dist/lib/obsidian/@types/Dataview/ui/views/task-view.d.ts +39 -0
- package/dist/lib/obsidian/@types/Dataview/util/hash.d.ts +1 -0
- package/dist/lib/obsidian/@types/Dataview/util/locale.d.ts +2 -0
- package/dist/lib/obsidian/@types/Dataview/util/media.d.ts +6 -0
- package/dist/lib/obsidian/@types/Dataview/util/normalize.d.ts +41 -0
- package/dist/lib/obsidian/Dataview.cjs +1 -1
- package/dist/lib/obsidian/Dataview.d.ts +2 -2
- package/package.json +156 -14
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { Decoration, DecorationSet, EditorView, ViewPlugin, ViewUpdate } from "@codemirror/view";
|
|
2
|
+
import type { EditorSelection, Range } from "@codemirror/state";
|
|
3
|
+
import type { DataviewSettings } from "../settings.d.ts";
|
|
4
|
+
import type { FullIndex } from "../data-index/index.d.ts";
|
|
5
|
+
import type { App, Component, TFile } from "obsidian";
|
|
6
|
+
import type { DataviewApi } from "../api/plugin-api.d.ts";
|
|
7
|
+
import type { SyntaxNode } from "@lezer/common";
|
|
8
|
+
export declare function selectionAndRangeOverlap(selection: EditorSelection, rangeFrom: number, rangeTo: number): boolean;
|
|
9
|
+
export declare function inlinePlugin(app: App, index: FullIndex, settings: DataviewSettings, api: DataviewApi): ViewPlugin<{
|
|
10
|
+
decorations: DecorationSet;
|
|
11
|
+
component: Component;
|
|
12
|
+
update(update: ViewUpdate): void;
|
|
13
|
+
updateTree(view: EditorView): void;
|
|
14
|
+
removeDeco(node: SyntaxNode): void;
|
|
15
|
+
addDeco(node: SyntaxNode, view: EditorView): void;
|
|
16
|
+
renderNode(view: EditorView, node: SyntaxNode): {
|
|
17
|
+
render: boolean;
|
|
18
|
+
isQuery: boolean;
|
|
19
|
+
};
|
|
20
|
+
isInlineQuery(view: EditorView, start: number, end: number): boolean;
|
|
21
|
+
inlineRender(view: EditorView): DecorationSet | undefined;
|
|
22
|
+
renderWidget(node: SyntaxNode, view: EditorView, currentFile: TFile): Range<Decoration> | undefined;
|
|
23
|
+
destroy(): void;
|
|
24
|
+
}>;
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
/** Provides core preact / rendering utilities for all view types. */
|
|
2
|
+
import type { App, MarkdownRenderChild } from "obsidian";
|
|
3
|
+
import type { h, ComponentChildren } from "preact";
|
|
4
|
+
import type { Component } from "obsidian";
|
|
5
|
+
import type { DataviewSettings } from "../settings.d.ts";
|
|
6
|
+
import type { FullIndex } from "../data-index/index.d.ts";
|
|
7
|
+
import type { Literal } from "../data-model/value.d.ts";
|
|
8
|
+
import React from "preact/compat";
|
|
9
|
+
export type MarkdownProps = {
|
|
10
|
+
contents: string;
|
|
11
|
+
sourcePath: string;
|
|
12
|
+
};
|
|
13
|
+
export type MarkdownContext = {
|
|
14
|
+
component: Component;
|
|
15
|
+
};
|
|
16
|
+
/** Context need to create dataviews. */
|
|
17
|
+
export type DataviewInit = {
|
|
18
|
+
app: App;
|
|
19
|
+
index: FullIndex;
|
|
20
|
+
settings: DataviewSettings;
|
|
21
|
+
container: HTMLElement;
|
|
22
|
+
};
|
|
23
|
+
/** Shared context for dataview views and objects. */
|
|
24
|
+
export type DataviewContexts = DataviewInit & {
|
|
25
|
+
component: Component;
|
|
26
|
+
};
|
|
27
|
+
export declare const DataviewContext: React.Context<DataviewContexts>;
|
|
28
|
+
/** Hacky preact component which wraps Obsidian's markdown renderer into a neat component. */
|
|
29
|
+
export declare function RawMarkdown({ content, sourcePath, inline, style, cls, onClick, }: {
|
|
30
|
+
content: string;
|
|
31
|
+
sourcePath: string;
|
|
32
|
+
inline?: boolean;
|
|
33
|
+
style?: string;
|
|
34
|
+
cls?: string;
|
|
35
|
+
onClick?: (e: preact.JSX.TargetedMouseEvent<HTMLElement>) => void;
|
|
36
|
+
}): h.JSX.Element;
|
|
37
|
+
/** Hacky preact component which wraps Obsidian's markdown renderer into a neat component. */
|
|
38
|
+
export declare const Markdown: typeof RawMarkdown;
|
|
39
|
+
/** Embeds an HTML element in the react DOM. */
|
|
40
|
+
export declare function RawEmbedHtml({ element }: {
|
|
41
|
+
element: HTMLElement;
|
|
42
|
+
}): h.JSX.Element;
|
|
43
|
+
/** Embeds an HTML element in the react DOM. */
|
|
44
|
+
export declare const EmbedHtml: typeof RawEmbedHtml;
|
|
45
|
+
/** Intelligently render an arbitrary literal value. */
|
|
46
|
+
export declare function RawLit({ value, sourcePath, inline, depth, }: {
|
|
47
|
+
value: Literal | undefined;
|
|
48
|
+
sourcePath: string;
|
|
49
|
+
inline?: boolean;
|
|
50
|
+
depth?: number;
|
|
51
|
+
}): h.JSX.Element;
|
|
52
|
+
/** Intelligently render an arbitrary literal value. */
|
|
53
|
+
export declare const Lit: typeof RawLit;
|
|
54
|
+
/** Render a simple nice looking error box in a code style. */
|
|
55
|
+
export declare function ErrorPre(props: {
|
|
56
|
+
children: ComponentChildren;
|
|
57
|
+
}, {}: {}): h.JSX.Element;
|
|
58
|
+
/** Render a pretty centered error message in a box. */
|
|
59
|
+
export declare function ErrorMessage({ message }: {
|
|
60
|
+
message: string;
|
|
61
|
+
}): h.JSX.Element;
|
|
62
|
+
/**
|
|
63
|
+
* Complex convenience hook which calls `compute` every time the index updates, updating the current state.
|
|
64
|
+
*/
|
|
65
|
+
export declare function useIndexBackedState<T>(container: HTMLElement, app: App, settings: DataviewSettings, index: FullIndex, initial: T, compute: () => Promise<T>): T;
|
|
66
|
+
/** A trivial wrapper which allows a react component to live for the duration of a `MarkdownRenderChild`. */
|
|
67
|
+
export declare class ReactRenderer extends MarkdownRenderChild {
|
|
68
|
+
init: DataviewInit;
|
|
69
|
+
element: h.JSX.Element;
|
|
70
|
+
constructor(init: DataviewInit, element: h.JSX.Element);
|
|
71
|
+
onload(): void;
|
|
72
|
+
onunload(): void;
|
|
73
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { FullIndex } from "../data-index/index.d.ts";
|
|
2
|
+
import type { App, MarkdownRenderChild } from "obsidian";
|
|
3
|
+
import type { DataviewSettings } from "../settings.d.ts";
|
|
4
|
+
/** Generic code for embedded Dataviews. */
|
|
5
|
+
export declare abstract class DataviewRefreshableRenderer extends MarkdownRenderChild {
|
|
6
|
+
container: HTMLElement;
|
|
7
|
+
index: FullIndex;
|
|
8
|
+
app: App;
|
|
9
|
+
settings: DataviewSettings;
|
|
10
|
+
private lastReload;
|
|
11
|
+
constructor(container: HTMLElement, index: FullIndex, app: App, settings: DataviewSettings);
|
|
12
|
+
abstract render(): Promise<void>;
|
|
13
|
+
onload(): void;
|
|
14
|
+
maybeRefresh: () => void;
|
|
15
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { App, Component } from "obsidian";
|
|
2
|
+
import type { QuerySettings } from "../settings.d.ts";
|
|
3
|
+
import type { Literal } from "../data-model/value.d.ts";
|
|
4
|
+
/** Render simple fields compactly, removing wrapping content like paragraph and span. */
|
|
5
|
+
export declare function renderCompactMarkdown(app: App, markdown: string, container: HTMLElement, sourcePath: string, component: Component, isInlineFieldLivePreview?: boolean): Promise<void>;
|
|
6
|
+
/** Render a pre block with an error in it; returns the element to allow for dynamic updating. */
|
|
7
|
+
export declare function renderErrorPre(container: HTMLElement, error: string): HTMLElement;
|
|
8
|
+
/** Render a static codeblock. */
|
|
9
|
+
export declare function renderCodeBlock(container: HTMLElement, source: string, language?: string): HTMLElement;
|
|
10
|
+
export type ValueRenderContext = "root" | "list";
|
|
11
|
+
/** Prettily render a value into a container with the given settings. */
|
|
12
|
+
export declare function renderValue(app: App, field: Literal, container: HTMLElement, originFile: string, component: Component, settings: QuerySettings, expandList?: boolean, context?: ValueRenderContext, depth?: number, isInlineFieldLivePreview?: boolean): Promise<void>;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { FullIndex } from "../../data-index/index.d.ts";
|
|
2
|
+
import type { App } from "obsidian";
|
|
3
|
+
import type { Query } from "../../query/query.d.ts";
|
|
4
|
+
import type { DataviewSettings } from "../../settings.d.ts";
|
|
5
|
+
import type { DataviewRefreshableRenderer } from "../../ui/refreshable-view.d.ts";
|
|
6
|
+
export declare class DataviewCalendarRenderer extends DataviewRefreshableRenderer {
|
|
7
|
+
query: Query;
|
|
8
|
+
container: HTMLElement;
|
|
9
|
+
index: FullIndex;
|
|
10
|
+
origin: string;
|
|
11
|
+
settings: DataviewSettings;
|
|
12
|
+
app: App;
|
|
13
|
+
private calendar;
|
|
14
|
+
constructor(query: Query, container: HTMLElement, index: FullIndex, origin: string, settings: DataviewSettings, app: App);
|
|
15
|
+
render(): Promise<void>;
|
|
16
|
+
onClose(): Promise<void>;
|
|
17
|
+
}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import type { App, Component, TFile } from "obsidian";
|
|
2
|
+
import type { RangeSet, RangeValue, StateField } from "@codemirror/state";
|
|
3
|
+
import type { DecorationSet, EditorView, ViewPlugin, ViewUpdate } from "@codemirror/view";
|
|
4
|
+
import type { InlineField } from "../../data-import/inline-field.d.ts";
|
|
5
|
+
import type { DataviewSettings } from "../../settings.d.ts";
|
|
6
|
+
declare class InlineFieldValue extends RangeValue {
|
|
7
|
+
field: InlineField;
|
|
8
|
+
constructor(field: InlineField);
|
|
9
|
+
eq(other: InlineFieldValue): boolean;
|
|
10
|
+
}
|
|
11
|
+
/** A state field that stores the inline fields and their positions as a range set. */
|
|
12
|
+
export declare const inlineFieldsField: StateField<RangeSet<InlineFieldValue>>;
|
|
13
|
+
/** Create a view plugin that renders inline fields in live preview just as in the reading view. */
|
|
14
|
+
export declare const replaceInlineFieldsInLivePreview: (app: App, settings: DataviewSettings) => ViewPlugin<{
|
|
15
|
+
decorations: DecorationSet;
|
|
16
|
+
component: Component;
|
|
17
|
+
destroy(): void;
|
|
18
|
+
buildDecorations(view: EditorView): DecorationSet;
|
|
19
|
+
update(update: ViewUpdate): void;
|
|
20
|
+
updateDecorations(view: EditorView): void;
|
|
21
|
+
removeDeco(start: number, end: number): void;
|
|
22
|
+
addDeco(start: number, end: number, field: InlineField, file: TFile, view: EditorView): void;
|
|
23
|
+
}>;
|
|
24
|
+
/**
|
|
25
|
+
* A state effect that represents the workspace's layout change.
|
|
26
|
+
* Mainly intended to detect when the user switches between live preview and source mode.
|
|
27
|
+
*/
|
|
28
|
+
export declare const workspaceLayoutChangeEffect: import("@codemirror/state").StateEffectType<null>;
|
|
29
|
+
export {};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { FullIndex } from "../../data-index/index.d.ts";
|
|
2
|
+
import type { Field } from "../../expression/field.d.ts";
|
|
3
|
+
import type { App } from "obsidian";
|
|
4
|
+
import type { DataviewSettings } from "../../settings.d.ts";
|
|
5
|
+
import type { DataviewRefreshableRenderer } from "../../ui/refreshable-view.d.ts";
|
|
6
|
+
/** Refreshable renderer which renders inline instead of in a div. */
|
|
7
|
+
export declare class DataviewInlineRenderer extends DataviewRefreshableRenderer {
|
|
8
|
+
field: Field;
|
|
9
|
+
fieldText: string;
|
|
10
|
+
container: HTMLElement;
|
|
11
|
+
target: HTMLElement;
|
|
12
|
+
index: FullIndex;
|
|
13
|
+
origin: string;
|
|
14
|
+
settings: DataviewSettings;
|
|
15
|
+
app: App;
|
|
16
|
+
errorbox?: HTMLElement;
|
|
17
|
+
constructor(field: Field, fieldText: string, container: HTMLElement, target: HTMLElement, index: FullIndex, origin: string, settings: DataviewSettings, app: App);
|
|
18
|
+
render(): Promise<void>;
|
|
19
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import type { DataviewRefreshableRenderer } from "../../ui/refreshable-view.d.ts";
|
|
2
|
+
import type { DataviewApi } from "../../api/plugin-api.d.ts";
|
|
3
|
+
export declare class DataviewJSRenderer extends DataviewRefreshableRenderer {
|
|
4
|
+
api: DataviewApi;
|
|
5
|
+
script: string;
|
|
6
|
+
container: HTMLElement;
|
|
7
|
+
origin: string;
|
|
8
|
+
static PREAMBLE: string;
|
|
9
|
+
constructor(api: DataviewApi, script: string, container: HTMLElement, origin: string);
|
|
10
|
+
render(): Promise<void>;
|
|
11
|
+
}
|
|
12
|
+
/** Inline JS renderer accessible using '=$' by default. */
|
|
13
|
+
export declare class DataviewInlineJSRenderer extends DataviewRefreshableRenderer {
|
|
14
|
+
api: DataviewApi;
|
|
15
|
+
script: string;
|
|
16
|
+
container: HTMLElement;
|
|
17
|
+
target: HTMLElement;
|
|
18
|
+
origin: string;
|
|
19
|
+
static PREAMBLE: string;
|
|
20
|
+
errorbox?: HTMLElement;
|
|
21
|
+
constructor(api: DataviewApi, script: string, container: HTMLElement, target: HTMLElement, origin: string);
|
|
22
|
+
render(): Promise<void>;
|
|
23
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type { MarkdownRenderChild } from "obsidian";
|
|
2
|
+
import type { Query } from "../../query/query.d.ts";
|
|
3
|
+
import type { DataviewInit } from "../../ui/markdown.d.ts";
|
|
4
|
+
import type { h } from "preact";
|
|
5
|
+
import type { Literal } from "../../data-model/value.d.ts";
|
|
6
|
+
export declare function ListGrouping({ items, sourcePath }: {
|
|
7
|
+
items: Literal[];
|
|
8
|
+
sourcePath: string;
|
|
9
|
+
}): h.JSX.Element;
|
|
10
|
+
export type ListViewState = {
|
|
11
|
+
state: "loading";
|
|
12
|
+
} | {
|
|
13
|
+
state: "error";
|
|
14
|
+
error: string;
|
|
15
|
+
} | {
|
|
16
|
+
state: "ready";
|
|
17
|
+
items: Literal[];
|
|
18
|
+
};
|
|
19
|
+
/** Pure view over list elements. */
|
|
20
|
+
export declare function ListView({ query, sourcePath }: {
|
|
21
|
+
query: Query;
|
|
22
|
+
sourcePath: string;
|
|
23
|
+
}): h.JSX.Element;
|
|
24
|
+
export declare function createListView(init: DataviewInit, query: Query, sourcePath: string): MarkdownRenderChild;
|
|
25
|
+
export declare function createFixedListView(init: DataviewInit, elements: Literal[], sourcePath: string): MarkdownRenderChild;
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import type { Literal } from "../../data-model/value.d.ts";
|
|
2
|
+
import type { Query } from "../../query/query.d.ts";
|
|
3
|
+
import type { DataviewInit } from "../../ui/markdown.d.ts";
|
|
4
|
+
import type { h } from "preact";
|
|
5
|
+
import type { MarkdownRenderChild } from "obsidian";
|
|
6
|
+
/** Simple table over headings and corresponding values. */
|
|
7
|
+
export declare function TableGrouping({ headings, values, sourcePath, }: {
|
|
8
|
+
headings: string[];
|
|
9
|
+
values: Literal[][];
|
|
10
|
+
sourcePath: string;
|
|
11
|
+
}): h.JSX.Element;
|
|
12
|
+
export type TableViewState = {
|
|
13
|
+
state: "loading";
|
|
14
|
+
} | {
|
|
15
|
+
state: "error";
|
|
16
|
+
error: string;
|
|
17
|
+
} | {
|
|
18
|
+
state: "ready";
|
|
19
|
+
headings: string[];
|
|
20
|
+
values: Literal[][];
|
|
21
|
+
};
|
|
22
|
+
/** Pure view over list elements. */
|
|
23
|
+
export declare function TableView({ query, sourcePath }: {
|
|
24
|
+
query: Query;
|
|
25
|
+
sourcePath: string;
|
|
26
|
+
}): h.JSX.Element;
|
|
27
|
+
export declare function createTableView(init: DataviewInit, query: Query, sourcePath: string): MarkdownRenderChild;
|
|
28
|
+
export declare function createFixedTableView(init: DataviewInit, headings: string[], values: Literal[][], sourcePath: string): MarkdownRenderChild;
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import type { SListItem, STask } from "../../data-model/serialized/markdown.d.ts";
|
|
2
|
+
import type { Grouping } from "../../data-model/value.d.ts";
|
|
3
|
+
import type { MarkdownRenderChild, Vault } from "obsidian";
|
|
4
|
+
import type { h } from "preact";
|
|
5
|
+
import type { Query } from "../../query/query.d.ts";
|
|
6
|
+
import type { DataviewInit } from "../../ui/markdown.d.ts";
|
|
7
|
+
export type TaskViewState = {
|
|
8
|
+
state: "loading";
|
|
9
|
+
} | {
|
|
10
|
+
state: "error";
|
|
11
|
+
error: string;
|
|
12
|
+
} | {
|
|
13
|
+
state: "ready";
|
|
14
|
+
items: Grouping<SListItem>;
|
|
15
|
+
};
|
|
16
|
+
/**
|
|
17
|
+
* Pure view over (potentially grouped) tasks and list items which allows for checking/unchecking tasks and manipulating
|
|
18
|
+
* the task view.
|
|
19
|
+
*/
|
|
20
|
+
export declare function TaskView({ query, sourcePath }: {
|
|
21
|
+
query: Query;
|
|
22
|
+
sourcePath: string;
|
|
23
|
+
}): h.JSX.Element;
|
|
24
|
+
export declare function createTaskView(init: DataviewInit, query: Query, sourcePath: string): MarkdownRenderChild;
|
|
25
|
+
export declare function createFixedTaskView(init: DataviewInit, items: Grouping<SListItem>, sourcePath: string): MarkdownRenderChild;
|
|
26
|
+
/**
|
|
27
|
+
* Removes tasks from a list if they are already present by being a child of another task. Fixes child pointers.
|
|
28
|
+
* Retains original order of input list.
|
|
29
|
+
*/
|
|
30
|
+
export declare function nestItems(raw: SListItem[]): [SListItem[], Set<string>];
|
|
31
|
+
/**
|
|
32
|
+
* Recursively removes tasks from each subgroup if they are already present by being a child of another task.
|
|
33
|
+
* Fixes child pointers. Retains original order of input list.
|
|
34
|
+
*/
|
|
35
|
+
export declare function nestGroups(raw: Grouping<SListItem>): Grouping<SListItem>;
|
|
36
|
+
/** Set the task completion key on check. */
|
|
37
|
+
export declare function setTaskCompletion(originalText: string, useEmojiShorthand: boolean, completionKey: string, completionDateFormat: string, complete: boolean): string;
|
|
38
|
+
/** Rewrite a task with the given completion status and new text. */
|
|
39
|
+
export declare function rewriteTask(vault: Vault, task: STask, desiredStatus: string, desiredText?: string): Promise<void>;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function cyrb53(str: string, seed?: number): number;
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { Link } from "../data-model/value.d.ts";
|
|
2
|
+
export declare const IMAGE_EXTENSIONS: Readonly<Set<string>>;
|
|
3
|
+
/** Determines if the given link points to an embedded image. */
|
|
4
|
+
export declare function isImageEmbed(link: Link): boolean;
|
|
5
|
+
/** Extract text of the form 'WxH' or 'W' from the display of a link. */
|
|
6
|
+
export declare function extractImageDimensions(link: Link): [number, number] | [number] | undefined;
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import type { DateTime, Duration } from "luxon";
|
|
2
|
+
import type { Result } from "../api/result.d.ts";
|
|
3
|
+
import type { QuerySettings } from "../settings.d.ts";
|
|
4
|
+
/** Normalize a duration to all of the proper units. */
|
|
5
|
+
export declare function normalizeDuration(dur: Duration): Duration;
|
|
6
|
+
/** Strip the time components of a date time object. */
|
|
7
|
+
export declare function stripTime(dt: DateTime): DateTime;
|
|
8
|
+
/** Try to extract a YYYYMMDD date from a string. */
|
|
9
|
+
export declare function extractDate(str: string): DateTime | undefined;
|
|
10
|
+
/** Get the folder containing the given path (i.e., like computing 'path/..'). */
|
|
11
|
+
export declare function getParentFolder(path: string): string;
|
|
12
|
+
/** Get the file name for the file referenced in the given path, by stripping the parent folders. */
|
|
13
|
+
export declare function getFileName(path: string): string;
|
|
14
|
+
/** Get the "title" for a file, by stripping other parts of the path as well as the extension. */
|
|
15
|
+
export declare function getFileTitle(path: string): string;
|
|
16
|
+
/** Get the extension of a file from the file path. */
|
|
17
|
+
export declare function getExtension(path: string): string;
|
|
18
|
+
/** Parse all subtags out of the given tag. I.e., #hello/i/am would yield [#hello/i/am, #hello/i, #hello]. */
|
|
19
|
+
export declare function extractSubtags(tag: string): string[];
|
|
20
|
+
/** Try calling the given function; on failure, return the error message. */
|
|
21
|
+
export declare function tryOrPropogate<T>(func: () => Result<T, string>): Result<T, string>;
|
|
22
|
+
/** Try asynchronously calling the given function; on failure, return the error message. */
|
|
23
|
+
export declare function asyncTryOrPropogate<T>(func: () => Promise<Result<T, string>>): Promise<Result<T, string>>;
|
|
24
|
+
/**
|
|
25
|
+
* Escape regex characters in a string.
|
|
26
|
+
* See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions.
|
|
27
|
+
*/
|
|
28
|
+
export declare function escapeRegex(str: string): string;
|
|
29
|
+
/** Convert an arbitrary variable name into something JS/query friendly. */
|
|
30
|
+
export declare function canonicalizeVarName(name: string): string;
|
|
31
|
+
/**
|
|
32
|
+
* Normalizes the text in a header to be something that is actually linkable to. This mimics
|
|
33
|
+
* how Obsidian does it's normalization, collapsing repeated spaces and stripping out control characters.
|
|
34
|
+
*/
|
|
35
|
+
export declare function normalizeHeaderForLink(header: string): string;
|
|
36
|
+
/** Render a DateTime in a minimal format to save space. */
|
|
37
|
+
export declare function renderMinimalDate(time: DateTime, settings: QuerySettings, locale: string): string;
|
|
38
|
+
/** Render a duration in a minimal format to save space. */
|
|
39
|
+
export declare function renderMinimalDuration(dur: Duration): string;
|
|
40
|
+
/** Determine if two sets are equal in contents. */
|
|
41
|
+
export declare function setsEqual<T>(first: Set<T>, second: Set<T>): boolean;
|
|
@@ -221,4 +221,4 @@ function renderIframe({
|
|
|
221
221
|
renderPaginatedList,
|
|
222
222
|
renderPaginatedTable
|
|
223
223
|
});
|
|
224
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/obsidian/Dataview.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis[\"import.meta.url\"] ?? (()=>require(\"node:url\").pathToFileURL(__filename))();\nvar __process = globalThis[\"process\"] ?? {\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\nimport type { DataviewInlineApi as DataviewInlineApiOriginal } from \"obsidian-dataview/inline-api\";\nimport type {\n  DataArray,\n  DataviewApi,\n  DateTime,\n  Link,\n  SMarkdownPage\n} from \"obsidian-dataview\";\n\nimport {\n  convertAsyncToSync,\n  type MaybePromise\n} from \"../Async.ts\";\nimport { relativePathToResourceUrl } from \"../obsidian/ResourceUrl.ts\";\nimport { errorToString } from \"../Error.ts\";\n\ndeclare global {\n  // eslint-disable-next-line no-var\n  var DataviewAPI: DataviewApi | undefined;\n}\n\nexport type {\n  DateTime,\n  Link\n};\n\nexport interface DataviewInlineApi<CustomPage = SMarkdownPage> extends DataviewInlineApiOriginal {\n  current: () => Page<CustomPage>;\n  array<T>(arr: T[]): DataArray<T>;\n  pages(query?: string): DataArray<Page<CustomPage>>;\n  paragraph(text: unknown, options?: DomElementInfo & { container?: HTMLElement }): HTMLParagraphElement;\n}\n\nexport async function reloadCurrentFileCache(dv: DataviewInlineApi): Promise<void> {\n  await DataviewAPI?.index.reload(dv.app.vault.getFileByPath(dv.current().file.path)!);\n}\n\nexport type Page<T = SMarkdownPage> = SMarkdownPage & T;\n\ntype PageFile = Page[\"file\"];\nexport type PageFiles = DataArray<PageFile> | PageFile[];\n\nconst paginationCss = `\n.pagination .page-link.disabled {\n  pointer-events: none;\n  color: gray;\n}\n\n.pagination .page-link {\n  margin: 0 5px;\n  cursor: pointer;\n  text-decoration: none;\n  color: blue;\n}\n\n.pagination .page-link:hover:not(.disabled) {\n  text-decoration: underline;\n}\n.pagination .page-link.current {\n  font-weight: bold;\n  text-decoration: underline;\n}\n\n.pagination select,\n.pagination input {\n  margin: 0 5px;\n}\n`;\n\ntype ArrayOrDataArray<T> = T[] | DataArray<T>;\n\nexport async function renderPaginatedList<T>({\n  dv,\n  rows,\n  itemsPerPageOptions = [10, 20, 50, 100]\n}: {\n  dv: DataviewInlineApi,\n  rows: ArrayOrDataArray<T>,\n  itemsPerPageOptions?: number[]\n}): Promise<void> {\n  await renderPaginated({\n    dv,\n    rows,\n    itemsPerPageOptions,\n    renderer: async (rows: ArrayOrDataArray<T>): Promise<void> => {\n      await dv.list(rows);\n    }\n  });\n}\n\nexport async function renderPaginatedTable<T extends unknown[]>({\n  dv,\n  headers,\n  rows,\n  itemsPerPageOptions = [10, 20, 50, 100]\n}: {\n  dv: DataviewInlineApi,\n  headers: string[],\n  rows: ArrayOrDataArray<T>,\n  itemsPerPageOptions?: number[]\n}): Promise<void> {\n  await renderPaginated({\n    dv,\n    rows,\n    itemsPerPageOptions,\n    renderer: async (rows: ArrayOrDataArray<T>): Promise<void> => {\n      await dv.table(headers, rows);\n    }\n  });\n}\n\nasync function renderPaginated<T>({\n  dv,\n  rows,\n  itemsPerPageOptions = [10, 20, 50, 100],\n  renderer\n}: {\n  dv: DataviewInlineApi,\n  rows: ArrayOrDataArray<T>,\n  itemsPerPageOptions: number[],\n  renderer: (rows: ArrayOrDataArray<T>) => MaybePromise<void>\n}): Promise<void> {\n  if (rows.length === 0) {\n    dv.paragraph(\"No items found\");\n    return;\n  }\n  const container = dv.container;\n  let itemsPerPage = itemsPerPageOptions[0]!;\n  let totalPages = Math.ceil(rows.length / itemsPerPage);\n  await renderPage(1);\n\n  function createPaginationControls(pageNumber: number): void {\n    const paginationDiv = container.createEl(\"div\", { cls: \"pagination\" });\n    const paginationRow1Div = paginationDiv.createDiv();\n\n    createPageLink(\"First\", 1, pageNumber === 1);\n    createPageLink(\"Prev\", pageNumber - 1, pageNumber === 1);\n\n    if (pageNumber > 3) {\n      paginationRow1Div.createEl(\"span\", { text: \"...\" });\n    }\n\n    for (let i = Math.max(1, pageNumber - 2); i <= Math.min(totalPages, pageNumber + 2); i++) {\n      const pageLink = createPageLink(i.toString(), i, i === pageNumber);\n      if (i === pageNumber) {\n        pageLink.addClass(\"current\");\n      }\n    }\n\n    if (pageNumber < totalPages - 2) {\n      paginationRow1Div.createEl(\"span\", { text: \"...\" });\n    }\n\n    createPageLink(\"Next\", pageNumber + 1, pageNumber === totalPages);\n    createPageLink(\"Last\", totalPages, pageNumber === totalPages);\n\n    const paginationRow2Div = paginationDiv.createDiv();\n\n    paginationRow2Div.createEl(\"span\", { text: \" Items per page: \" });\n\n    const itemsPerPageSelect = paginationRow2Div.createEl(\"select\");\n    itemsPerPageOptions.forEach((option: number): void => {\n      itemsPerPageSelect.createEl(\"option\", { text: option.toString(), value: option.toString() });\n    });\n    itemsPerPageSelect.value = itemsPerPage.toString();\n    itemsPerPageSelect.addEventListener(\"change\", convertAsyncToSync(async (): Promise<void> => {\n      itemsPerPage = parseInt(itemsPerPageSelect.value);\n      totalPages = Math.ceil(rows.length / itemsPerPage);\n      await renderPage(1);\n    }));\n\n    paginationRow2Div.createEl(\"span\", { text: \"  Jump to page: \" });\n\n    const jumpToPageInput = paginationRow2Div.createEl(\"input\", { type: \"number\", attr: { min: 1, max: totalPages } });\n    jumpToPageInput.addEventListener(\"keydown\", convertAsyncToSync(async (event: KeyboardEvent): Promise<void> => {\n      if (event.key === \"Enter\") {\n        const page = parseInt(jumpToPageInput.value);\n        if (page >= 1 && page <= totalPages) {\n          await renderPage(page);\n        }\n      }\n    }));\n\n    paginationRow2Div.createEl(\"span\", { text: `  Page ${pageNumber} of ${totalPages}, Total items: ${rows.length}` });\n\n    function createPageLink(text: string, pageNumber: number, disabled = false): HTMLAnchorElement {\n      const link = paginationRow1Div.createEl(\"a\", { cls: \"page-link\", text: text, href: `#${pageNumber}` });\n      if (disabled) {\n        link.addClass(\"disabled\");\n        link.onclick = (event: MouseEvent): void => event.preventDefault();\n      } else {\n        link.addEventListener(\"click\", convertAsyncToSync(async (event: MouseEvent): Promise<void> => {\n          event.preventDefault();\n          await renderPage(pageNumber);\n        }));\n      }\n      return link;\n    }\n  }\n\n  async function renderPage(pageNumber: number): Promise<void> {\n    container.empty();\n    container.createEl(\"style\", { text: paginationCss });\n\n    const startIndex = (pageNumber - 1) * itemsPerPage;\n    const endIndex = startIndex + itemsPerPage;\n    const rowsForCurrentPage = rows.slice(startIndex, endIndex);\n\n    const oldContainer = dv.container;\n\n    dv.container = container;\n    try {\n      await renderer(rowsForCurrentPage);\n    } catch (e) {\n      dv.paragraph(\"\u274C\" + errorToString(e));\n    } finally {\n      dv.container = oldContainer;\n    }\n\n    createPaginationControls(pageNumber);\n  }\n}\n\nexport async function getRenderedContainer(dv: DataviewInlineApi, renderer: () => MaybePromise<void>): Promise<HTMLParagraphElement> {\n  const tempContainer = dv.paragraph(\"\");\n  dv.container = tempContainer;\n  dv.container.empty();\n\n  try {\n    await renderer();\n  } catch (e) {\n    dv.paragraph(\"\u274C\" + errorToString(e));\n  } finally {\n    dv.container = tempContainer.parentElement!;\n    tempContainer.remove();\n  }\n\n  return tempContainer;\n}\n\nexport function renderIframe({\n  dv,\n  relativePath,\n  width = \"100%\",\n  height = \"600px\"\n}: {\n  dv: DataviewInlineApi,\n  relativePath: string,\n  width: string,\n  height: string\n}): void {\n  dv.el(\"iframe\", \"\", {\n    attr: {\n      src: relativePathToResourceUrl(dv.app, relativePath, dv.current().file.path),\n      width,\n      height\n    }\n  });\n}\n"],
  "mappings": "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",
  "names": ["rows", "pageNumber"]
}

|
|
224
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/obsidian/Dataview.ts"],
  "sourcesContent": ["var __import_meta_url = globalThis[\"import.meta.url\"] ?? (()=>require(\"node:url\").pathToFileURL(__filename))();\nvar __process = globalThis[\"process\"] ?? {\n  \"cwd\": ()=>\"/\",\n  \"env\": {},\n  \"platform\": \"android\"\n};\nimport type { DataviewInlineApi as DataviewInlineApiOriginal } from \"./@types/Dataview/api/inline-api.d.ts\";\nimport type {\n  DataArray,\n  DataviewApi,\n  DateTime,\n  Link,\n  SMarkdownPage\n} from \"./@types/Dataview/index.d.ts\";\n\nimport {\n  convertAsyncToSync,\n  type MaybePromise\n} from \"../Async.ts\";\nimport { relativePathToResourceUrl } from \"../obsidian/ResourceUrl.ts\";\nimport { errorToString } from \"../Error.ts\";\n\ndeclare global {\n  // eslint-disable-next-line no-var\n  var DataviewAPI: DataviewApi | undefined;\n}\n\nexport type {\n  DateTime,\n  Link\n};\n\nexport interface DataviewInlineApi<CustomPage = SMarkdownPage> extends DataviewInlineApiOriginal {\n  current: () => Page<CustomPage>;\n  array<T>(arr: T[]): DataArray<T>;\n  pages(query?: string): DataArray<Page<CustomPage>>;\n  paragraph(text: unknown, options?: DomElementInfo & { container?: HTMLElement }): HTMLParagraphElement;\n}\n\nexport async function reloadCurrentFileCache(dv: DataviewInlineApi): Promise<void> {\n  await DataviewAPI?.index.reload(dv.app.vault.getFileByPath(dv.current().file.path)!);\n}\n\nexport type Page<T = SMarkdownPage> = SMarkdownPage & T;\n\ntype PageFile = Page[\"file\"];\nexport type PageFiles = DataArray<PageFile> | PageFile[];\n\nconst paginationCss = `\n.pagination .page-link.disabled {\n  pointer-events: none;\n  color: gray;\n}\n\n.pagination .page-link {\n  margin: 0 5px;\n  cursor: pointer;\n  text-decoration: none;\n  color: blue;\n}\n\n.pagination .page-link:hover:not(.disabled) {\n  text-decoration: underline;\n}\n.pagination .page-link.current {\n  font-weight: bold;\n  text-decoration: underline;\n}\n\n.pagination select,\n.pagination input {\n  margin: 0 5px;\n}\n`;\n\ntype ArrayOrDataArray<T> = T[] | DataArray<T>;\n\nexport async function renderPaginatedList<T>({\n  dv,\n  rows,\n  itemsPerPageOptions = [10, 20, 50, 100]\n}: {\n  dv: DataviewInlineApi,\n  rows: ArrayOrDataArray<T>,\n  itemsPerPageOptions?: number[]\n}): Promise<void> {\n  await renderPaginated({\n    dv,\n    rows,\n    itemsPerPageOptions,\n    renderer: async (rows: ArrayOrDataArray<T>): Promise<void> => {\n      await dv.list(rows);\n    }\n  });\n}\n\nexport async function renderPaginatedTable<T extends unknown[]>({\n  dv,\n  headers,\n  rows,\n  itemsPerPageOptions = [10, 20, 50, 100]\n}: {\n  dv: DataviewInlineApi,\n  headers: string[],\n  rows: ArrayOrDataArray<T>,\n  itemsPerPageOptions?: number[]\n}): Promise<void> {\n  await renderPaginated({\n    dv,\n    rows,\n    itemsPerPageOptions,\n    renderer: async (rows: ArrayOrDataArray<T>): Promise<void> => {\n      await dv.table(headers, rows);\n    }\n  });\n}\n\nasync function renderPaginated<T>({\n  dv,\n  rows,\n  itemsPerPageOptions = [10, 20, 50, 100],\n  renderer\n}: {\n  dv: DataviewInlineApi,\n  rows: ArrayOrDataArray<T>,\n  itemsPerPageOptions: number[],\n  renderer: (rows: ArrayOrDataArray<T>) => MaybePromise<void>\n}): Promise<void> {\n  if (rows.length === 0) {\n    dv.paragraph(\"No items found\");\n    return;\n  }\n  const container = dv.container;\n  let itemsPerPage = itemsPerPageOptions[0]!;\n  let totalPages = Math.ceil(rows.length / itemsPerPage);\n  await renderPage(1);\n\n  function createPaginationControls(pageNumber: number): void {\n    const paginationDiv = container.createEl(\"div\", { cls: \"pagination\" });\n    const paginationRow1Div = paginationDiv.createDiv();\n\n    createPageLink(\"First\", 1, pageNumber === 1);\n    createPageLink(\"Prev\", pageNumber - 1, pageNumber === 1);\n\n    if (pageNumber > 3) {\n      paginationRow1Div.createEl(\"span\", { text: \"...\" });\n    }\n\n    for (let i = Math.max(1, pageNumber - 2); i <= Math.min(totalPages, pageNumber + 2); i++) {\n      const pageLink = createPageLink(i.toString(), i, i === pageNumber);\n      if (i === pageNumber) {\n        pageLink.addClass(\"current\");\n      }\n    }\n\n    if (pageNumber < totalPages - 2) {\n      paginationRow1Div.createEl(\"span\", { text: \"...\" });\n    }\n\n    createPageLink(\"Next\", pageNumber + 1, pageNumber === totalPages);\n    createPageLink(\"Last\", totalPages, pageNumber === totalPages);\n\n    const paginationRow2Div = paginationDiv.createDiv();\n\n    paginationRow2Div.createEl(\"span\", { text: \" Items per page: \" });\n\n    const itemsPerPageSelect = paginationRow2Div.createEl(\"select\");\n    itemsPerPageOptions.forEach((option: number): void => {\n      itemsPerPageSelect.createEl(\"option\", { text: option.toString(), value: option.toString() });\n    });\n    itemsPerPageSelect.value = itemsPerPage.toString();\n    itemsPerPageSelect.addEventListener(\"change\", convertAsyncToSync(async (): Promise<void> => {\n      itemsPerPage = parseInt(itemsPerPageSelect.value);\n      totalPages = Math.ceil(rows.length / itemsPerPage);\n      await renderPage(1);\n    }));\n\n    paginationRow2Div.createEl(\"span\", { text: \"  Jump to page: \" });\n\n    const jumpToPageInput = paginationRow2Div.createEl(\"input\", { type: \"number\", attr: { min: 1, max: totalPages } });\n    jumpToPageInput.addEventListener(\"keydown\", convertAsyncToSync(async (event: KeyboardEvent): Promise<void> => {\n      if (event.key === \"Enter\") {\n        const page = parseInt(jumpToPageInput.value);\n        if (page >= 1 && page <= totalPages) {\n          await renderPage(page);\n        }\n      }\n    }));\n\n    paginationRow2Div.createEl(\"span\", { text: `  Page ${pageNumber} of ${totalPages}, Total items: ${rows.length}` });\n\n    function createPageLink(text: string, pageNumber: number, disabled = false): HTMLAnchorElement {\n      const link = paginationRow1Div.createEl(\"a\", { cls: \"page-link\", text: text, href: `#${pageNumber}` });\n      if (disabled) {\n        link.addClass(\"disabled\");\n        link.onclick = (event: MouseEvent): void => event.preventDefault();\n      } else {\n        link.addEventListener(\"click\", convertAsyncToSync(async (event: MouseEvent): Promise<void> => {\n          event.preventDefault();\n          await renderPage(pageNumber);\n        }));\n      }\n      return link;\n    }\n  }\n\n  async function renderPage(pageNumber: number): Promise<void> {\n    container.empty();\n    container.createEl(\"style\", { text: paginationCss });\n\n    const startIndex = (pageNumber - 1) * itemsPerPage;\n    const endIndex = startIndex + itemsPerPage;\n    const rowsForCurrentPage = rows.slice(startIndex, endIndex);\n\n    const oldContainer = dv.container;\n\n    dv.container = container;\n    try {\n      await renderer(rowsForCurrentPage);\n    } catch (e) {\n      dv.paragraph(\"\u274C\" + errorToString(e));\n    } finally {\n      dv.container = oldContainer;\n    }\n\n    createPaginationControls(pageNumber);\n  }\n}\n\nexport async function getRenderedContainer(dv: DataviewInlineApi, renderer: () => MaybePromise<void>): Promise<HTMLParagraphElement> {\n  const tempContainer = dv.paragraph(\"\");\n  dv.container = tempContainer;\n  dv.container.empty();\n\n  try {\n    await renderer();\n  } catch (e) {\n    dv.paragraph(\"\u274C\" + errorToString(e));\n  } finally {\n    dv.container = tempContainer.parentElement!;\n    tempContainer.remove();\n  }\n\n  return tempContainer;\n}\n\nexport function renderIframe({\n  dv,\n  relativePath,\n  width = \"100%\",\n  height = \"600px\"\n}: {\n  dv: DataviewInlineApi,\n  relativePath: string,\n  width: string,\n  height: string\n}): void {\n  dv.el(\"iframe\", \"\", {\n    attr: {\n      src: relativePathToResourceUrl(dv.app, relativePath, dv.current().file.path),\n      width,\n      height\n    }\n  });\n}\n"],
  "mappings": "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",
  "names": ["rows", "pageNumber"]
}

|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import type { DataviewInlineApi as DataviewInlineApiOriginal } from "
|
|
2
|
-
import type { DataArray, DataviewApi, DateTime, Link, SMarkdownPage } from "
|
|
1
|
+
import type { DataviewInlineApi as DataviewInlineApiOriginal } from "./@types/Dataview/api/inline-api.d.ts";
|
|
2
|
+
import type { DataArray, DataviewApi, DateTime, Link, SMarkdownPage } from "./@types/Dataview/index.d.ts";
|
|
3
3
|
import { type MaybePromise } from "../Async.ts";
|
|
4
4
|
declare global {
|
|
5
5
|
var DataviewAPI: DataviewApi | undefined;
|