From 52f0321248f5e72c198ed5bd7e422833ef12ac0e Mon Sep 17 00:00:00 2001 From: Ross Keenan Date: Fri, 10 Sep 2021 13:54:02 +0200 Subject: [PATCH] feat(List/Matrix View): :sparkles: Setting to list field names to check for alternate link text Basically, you can choose to use aliases to display notes, instead of file name --- main.js | 192 +++++++++++++++++++++++--------- src/BreadcrumbsSettingTab.ts | 18 +++ src/Components/Lists.svelte | 14 ++- src/Components/Matrix.svelte | 14 ++- src/Components/TrailGrid.svelte | 6 +- src/Components/TrailPath.svelte | 108 +++++++++--------- src/MatrixView.ts | 36 ++++-- src/interfaces.ts | 2 + src/main.ts | 1 + src/sharedFunctions.ts | 6 +- 10 files changed, 265 insertions(+), 132 deletions(-) diff --git a/main.js b/main.js index ea2daca5..d1c43ec9 100644 --- a/main.js +++ b/main.js @@ -6491,14 +6491,14 @@ function closeImpliedLinks(real, implied) { return closedG; } const isInVault = (app, note) => !!app.metadataCache.getFirstLinkpathDest(note, app.workspace.getActiveFile().path); -function hoverPreview$2(event, matrixView) { +function hoverPreview$2(event, matrixView, to) { const targetEl = event.target; matrixView.app.workspace.trigger("hover-link", { event, source: matrixView.getViewType(), hoverParent: matrixView, targetEl, - linktext: targetEl.innerText, + linktext: to, }); } async function openOrSwitch(app, dest, currFile, event) { @@ -24500,6 +24500,21 @@ class BreadcrumbsSettingTab extends obsidian.PluginSettingTab { settings.refreshIndexOnActiveLeafChange = value; await plugin.saveSettings(); })); + new obsidian.Setting(generalDetails) + .setName('Fields used for Alternative note names (Aliases)') + .setDesc('A comma-separated list of fields you use to specify note name aliases. These fields will be checked, in order, and be used to display an alternate note title in both the list/matrix view, and trail/grid view. This field will probably be `alias` or `aliases`, but it can be anything, like `title`, for example.') + .addText(text => { + let finalValue; + text + .setValue(settings.altLinkFields.join(', ')) + .onChange(str => { + finalValue = str; + }); + text.inputEl.onblur = async () => { + settings.altLinkFields = splitAndTrim(finalValue); + await plugin.saveSettings(); + }; + }); new obsidian.Setting(generalDetails) .setName("Use yaml or inline fields for hierarchy data") .setDesc("If enabled, Breadcrumbs will make it's hierarchy using yaml fields, and inline fields (if you have Dataview enabled). If this is disabled, it will only use Juggl links for it's metadata (See below).") @@ -25125,7 +25140,11 @@ function create_if_block_4$1(ctx) { function create_each_block_3$2(ctx) { let li; let div; - let t0_value = /*realItem*/ ctx[18].to.split("/").last() + ""; + + let t0_value = (/*realItem*/ ctx[18].alt + ? /*realItem*/ ctx[18].alt + : /*realItem*/ ctx[18].to.split("/").last()) + ""; + let t0; let div_class_value; let t1; @@ -25136,6 +25155,10 @@ function create_each_block_3$2(ctx) { return /*click_handler*/ ctx[5](/*realItem*/ ctx[18], ...args); } + function mouseover_handler(...args) { + return /*mouseover_handler*/ ctx[6](/*realItem*/ ctx[18], ...args); + } + return { c() { li = element("li"); @@ -25153,7 +25176,7 @@ function create_each_block_3$2(ctx) { if (!mounted) { dispose = [ listen(div, "click", click_handler), - listen(div, "mouseover", /*mouseover_handler*/ ctx[6]) + listen(div, "mouseover", mouseover_handler) ]; mounted = true; @@ -25161,7 +25184,10 @@ function create_each_block_3$2(ctx) { }, p(new_ctx, dirty) { ctx = new_ctx; - if (dirty & /*filteredSquaresArr*/ 1 && t0_value !== (t0_value = /*realItem*/ ctx[18].to.split("/").last() + "")) set_data(t0, t0_value); + + if (dirty & /*filteredSquaresArr*/ 1 && t0_value !== (t0_value = (/*realItem*/ ctx[18].alt + ? /*realItem*/ ctx[18].alt + : /*realItem*/ ctx[18].to.split("/").last()) + "")) set_data(t0, t0_value); if (dirty & /*filteredSquaresArr*/ 1 && div_class_value !== (div_class_value = /*realItem*/ ctx[18].cls)) { attr(div, "class", div_class_value); @@ -25175,7 +25201,7 @@ function create_each_block_3$2(ctx) { }; } -// (45:12) {#if square.impliedItems.length} +// (48:12) {#if square.impliedItems.length} function create_if_block_1$2(ctx) { let t; let ol; @@ -25258,7 +25284,7 @@ function create_if_block_1$2(ctx) { }; } -// (46:14) {#if settings.showRelationType} +// (49:14) {#if settings.showRelationType} function create_if_block_2$2(ctx) { let h5; @@ -25277,11 +25303,15 @@ function create_if_block_2$2(ctx) { }; } -// (54:16) {#each square.impliedItems as impliedItem} +// (57:16) {#each square.impliedItems as impliedItem} function create_each_block_2$3(ctx) { let li; let div; - let t_value = /*impliedItem*/ ctx[15].to.split("/").last() + ""; + + let t_value = (/*impliedItem*/ ctx[15].alt + ? /*impliedItem*/ ctx[15].alt + : /*impliedItem*/ ctx[15].to.split("/").last()) + ""; + let t; let div_class_value; let mounted; @@ -25291,6 +25321,10 @@ function create_each_block_2$3(ctx) { return /*click_handler_1*/ ctx[7](/*impliedItem*/ ctx[15], ...args); } + function mouseover_handler_1(...args) { + return /*mouseover_handler_1*/ ctx[8](/*impliedItem*/ ctx[15], ...args); + } + return { c() { li = element("li"); @@ -25307,7 +25341,7 @@ function create_each_block_2$3(ctx) { if (!mounted) { dispose = [ listen(div, "click", click_handler_1), - listen(div, "mouseover", /*mouseover_handler_1*/ ctx[8]) + listen(div, "mouseover", mouseover_handler_1) ]; mounted = true; @@ -25315,7 +25349,10 @@ function create_each_block_2$3(ctx) { }, p(new_ctx, dirty) { ctx = new_ctx; - if (dirty & /*filteredSquaresArr*/ 1 && t_value !== (t_value = /*impliedItem*/ ctx[15].to.split("/").last() + "")) set_data(t, t_value); + + if (dirty & /*filteredSquaresArr*/ 1 && t_value !== (t_value = (/*impliedItem*/ ctx[15].alt + ? /*impliedItem*/ ctx[15].alt + : /*impliedItem*/ ctx[15].to.split("/").last()) + "")) set_data(t, t_value); if (dirty & /*filteredSquaresArr*/ 1 && div_class_value !== (div_class_value = /*impliedItem*/ ctx[15].cls)) { attr(div, "class", div_class_value); @@ -25511,9 +25548,9 @@ function instance$5($$self, $$props, $$invalidate) { let { matrixView } = $$props; let { app } = $$props; const click_handler = async (realItem, e) => openOrSwitch(app, realItem.to, currFile, e); - const mouseover_handler = e => hoverPreview$2(e, matrixView); + const mouseover_handler = (realItem, e) => hoverPreview$2(e, matrixView, realItem.to); const click_handler_1 = async (impliedItem, e) => openOrSwitch(app, impliedItem.to, currFile, e); - const mouseover_handler_1 = e => hoverPreview$2(e, matrixView); + const mouseover_handler_1 = (impliedItem, e) => hoverPreview$2(e, matrixView, impliedItem.to); $$self.$$set = $$props => { if ("filteredSquaresArr" in $$props) $$invalidate(0, filteredSquaresArr = $$props.filteredSquaresArr); @@ -25753,7 +25790,11 @@ function create_if_block_4(ctx) { function create_each_block_3$1(ctx) { let li; let div; - let t0_value = /*realItem*/ ctx[18].to.split("/").last() + ""; + + let t0_value = (/*realItem*/ ctx[18].alt + ? /*realItem*/ ctx[18].alt + : /*realItem*/ ctx[18].to.split("/").last()) + ""; + let t0; let div_class_value; let t1; @@ -25764,6 +25805,10 @@ function create_each_block_3$1(ctx) { return /*click_handler*/ ctx[5](/*realItem*/ ctx[18], ...args); } + function mouseover_handler(...args) { + return /*mouseover_handler*/ ctx[6](/*realItem*/ ctx[18], ...args); + } + return { c() { li = element("li"); @@ -25781,7 +25826,7 @@ function create_each_block_3$1(ctx) { if (!mounted) { dispose = [ listen(div, "click", click_handler), - listen(div, "mouseover", /*mouseover_handler*/ ctx[6]) + listen(div, "mouseover", mouseover_handler) ]; mounted = true; @@ -25789,7 +25834,10 @@ function create_each_block_3$1(ctx) { }, p(new_ctx, dirty) { ctx = new_ctx; - if (dirty & /*filteredSquaresArr*/ 1 && t0_value !== (t0_value = /*realItem*/ ctx[18].to.split("/").last() + "")) set_data(t0, t0_value); + + if (dirty & /*filteredSquaresArr*/ 1 && t0_value !== (t0_value = (/*realItem*/ ctx[18].alt + ? /*realItem*/ ctx[18].alt + : /*realItem*/ ctx[18].to.split("/").last()) + "")) set_data(t0, t0_value); if (dirty & /*filteredSquaresArr*/ 1 && div_class_value !== (div_class_value = "" + (null_to_empty(/*realItem*/ ctx[18].cls) + " svelte-fq6v4k"))) { attr(div, "class", div_class_value); @@ -25803,7 +25851,7 @@ function create_each_block_3$1(ctx) { }; } -// (41:12) {#if square.impliedItems.length} +// (44:12) {#if square.impliedItems.length} function create_if_block_1$1(ctx) { let t; let ol; @@ -25886,7 +25934,7 @@ function create_if_block_1$1(ctx) { }; } -// (42:14) {#if settings.showRelationType} +// (45:14) {#if settings.showRelationType} function create_if_block_2$1(ctx) { let h5; @@ -25905,11 +25953,15 @@ function create_if_block_2$1(ctx) { }; } -// (46:16) {#each square.impliedItems as impliedItem} +// (49:16) {#each square.impliedItems as impliedItem} function create_each_block_2$2(ctx) { let li; let div; - let t_value = /*impliedItem*/ ctx[15].to.split("/").last() + ""; + + let t_value = (/*impliedItem*/ ctx[15].alt + ? /*impliedItem*/ ctx[15].alt + : /*impliedItem*/ ctx[15].to.split("/").last()) + ""; + let t; let div_class_value; let mounted; @@ -25919,6 +25971,10 @@ function create_each_block_2$2(ctx) { return /*click_handler_1*/ ctx[7](/*impliedItem*/ ctx[15], ...args); } + function mouseover_handler_1(...args) { + return /*mouseover_handler_1*/ ctx[8](/*impliedItem*/ ctx[15], ...args); + } + return { c() { li = element("li"); @@ -25935,7 +25991,7 @@ function create_each_block_2$2(ctx) { if (!mounted) { dispose = [ listen(div, "click", click_handler_1), - listen(div, "mouseover", /*mouseover_handler_1*/ ctx[8]) + listen(div, "mouseover", mouseover_handler_1) ]; mounted = true; @@ -25943,7 +25999,10 @@ function create_each_block_2$2(ctx) { }, p(new_ctx, dirty) { ctx = new_ctx; - if (dirty & /*filteredSquaresArr*/ 1 && t_value !== (t_value = /*impliedItem*/ ctx[15].to.split("/").last() + "")) set_data(t, t_value); + + if (dirty & /*filteredSquaresArr*/ 1 && t_value !== (t_value = (/*impliedItem*/ ctx[15].alt + ? /*impliedItem*/ ctx[15].alt + : /*impliedItem*/ ctx[15].to.split("/").last()) + "")) set_data(t, t_value); if (dirty & /*filteredSquaresArr*/ 1 && div_class_value !== (div_class_value = "" + (null_to_empty(/*impliedItem*/ ctx[15].cls) + " svelte-fq6v4k"))) { attr(div, "class", div_class_value); @@ -26124,9 +26183,9 @@ function instance$4($$self, $$props, $$invalidate) { let { matrixView } = $$props; let { app } = $$props; const click_handler = async (realItem, e) => openOrSwitch(app, realItem.to, currFile, e); - const mouseover_handler = event => hoverPreview$2(event, matrixView); + const mouseover_handler = (realItem, event) => hoverPreview$2(event, matrixView, realItem.to); const click_handler_1 = async (impliedItem, e) => openOrSwitch(app, impliedItem.to, currFile, e); - const mouseover_handler_1 = event => hoverPreview$2(event, matrixView); + const mouseover_handler_1 = (impliedItem, event) => hoverPreview$2(event, matrixView, impliedItem.to); $$self.$$set = $$props => { if ("filteredSquaresArr" in $$props) $$invalidate(0, filteredSquaresArr = $$props.filteredSquaresArr); @@ -26241,9 +26300,10 @@ class MatrixView extends obsidian.ItemView { } return unresolvedLinks[from][to] > 0; } - squareItems(g, currFile, realQ = true) { + squareItems(g, currFile, settings, realQ = true) { var _a, _b; let items; + const altFieldsQ = !!settings.altLinkFields.length; if (realQ) { items = ((_a = g.successors(currFile.basename)) !== null && _a !== void 0 ? _a : []); } @@ -26254,12 +26314,29 @@ class MatrixView extends obsidian.ItemView { // TODO I don't think I need to check the length here /// forEach won't run if it's empty anyway if (items.length) { - items.forEach((item) => { + items.forEach((to) => { + let alt = null; + if (altFieldsQ) { + const toFile = this.app.metadataCache.getFirstLinkpathDest(to, currFile.path); + if (toFile) { + const metadata = this.app.metadataCache.getFileCache(toFile); + settings.altLinkFields.forEach(altLinkField => { + var _a; + const altLink = (_a = metadata === null || metadata === void 0 ? void 0 : metadata.frontmatter) === null || _a === void 0 ? void 0 : _a[altLinkField]; + if (altLink) { + alt = altLink; + return; + } + console.log({ alt, altLink }); + }); + } + } internalLinkObjArr.push({ - to: item, + to, cls: "internal-link breadcrumbs-link" + - (this.unresolvedQ(item, currFile.path) ? " is-unresolved" : "") + + (this.unresolvedQ(to, currFile.path) ? " is-unresolved" : "") + (realQ ? "" : " breadcrumbs-implied"), + alt }); }); } @@ -26381,11 +26458,11 @@ class MatrixView extends obsidian.ItemView { data[i].down, ]; let [rUp, rSame, rDown, iUp, iDown] = [ - this.squareItems(currUpG, currFile), - this.squareItems(currSameG, currFile), - this.squareItems(currDownG, currFile), - this.squareItems(currDownG, currFile, false), - this.squareItems(currUpG, currFile, false), + this.squareItems(currUpG, currFile, settings), + this.squareItems(currSameG, currFile, settings), + this.squareItems(currDownG, currFile, settings), + this.squareItems(currDownG, currFile, settings, false), + this.squareItems(currUpG, currFile, settings, false), ]; // SECTION Implied Siblings /// Notes with the same parents @@ -26413,11 +26490,13 @@ class MatrixView extends obsidian.ItemView { (this.unresolvedQ(impliedSibling, currFile.path) ? " is-unresolved" : ""), + // TODO get alt for implied siblings + alt: null }); }); }); /// A real sibling implies the reverse sibling - iSameArr.push(...this.squareItems(currSameG, currFile, false)); + iSameArr.push(...this.squareItems(currSameG, currFile, settings, false)); // !SECTION iUp = this.removeDuplicateImplied(rUp, iUp); iSameArr = this.removeDuplicateImplied(rSame, iSameArr); @@ -36413,6 +36492,10 @@ function create_each_block_1$1(ctx) { return /*click_handler*/ ctx[11](/*step*/ ctx[24], ...args); } + function mouseover_handler(...args) { + return /*mouseover_handler*/ ctx[12](/*step*/ ctx[24], ...args); + } + return { c() { div1 = element("div"); @@ -36441,7 +36524,7 @@ function create_each_block_1$1(ctx) { if (!mounted) { dispose = [ listen(div1, "click", click_handler), - listen(div1, "mouseover", /*mouseover_handler*/ ctx[12]) + listen(div1, "mouseover", mouseover_handler) ]; mounted = true; @@ -36587,7 +36670,7 @@ function create_fragment$1(ctx) { }; } -function hoverPreview$1(event, view) { +function hoverPreview$1(event, view, to) { const targetEl = event.target; view.app.workspace.trigger("hover-link", { @@ -36595,7 +36678,7 @@ function hoverPreview$1(event, view) { source: view.getViewType(), hoverParent: view, targetEl, - linktext: targetEl.innerText + linktext: to }); } @@ -36673,7 +36756,7 @@ function instance$1($$self, $$props, $$invalidate) { const allRuns = transposedTrails.map(runs); const click_handler = (step, e) => openOrSwitch(app, step.value, currFile, e); - const mouseover_handler = e => hoverPreview$1(e, activeLeafView); + const mouseover_handler = (step, e) => hoverPreview$1(e, activeLeafView, step.value); $$self.$$set = $$props => { if ("sortedTrails" in $$props) $$invalidate(0, sortedTrails = $$props.sortedTrails); @@ -36710,8 +36793,8 @@ class TrailGrid extends SvelteComponent { function add_css() { var style = element("style"); - style.id = "svelte-154mvpu-style"; - style.textContent = "span.breadcrumbs-trail-path-container.svelte-154mvpu{display:flex;justify-content:space-between}"; + style.id = "svelte-1rndeic-style"; + style.textContent = "span.breadcrumbs-trail-path-container.svelte-1rndeic{display:flex;justify-content:space-between}"; append(document.head, style); } @@ -36728,7 +36811,7 @@ function get_each_context_1(ctx, list, i) { return child_ctx; } -// (30:16) {:else} +// (30:8) {:else} function create_else_block(ctx) { let each_1_anchor; let each_value_1 = /*trail*/ ctx[11]; @@ -36784,7 +36867,7 @@ function create_else_block(ctx) { }; } -// (28:16) {#if trail.length === 0} +// (28:8) {#if trail.length === 0} function create_if_block_1(ctx) { let span; let t_value = /*settings*/ ctx[2].noPathMessage + ""; @@ -36808,7 +36891,7 @@ function create_if_block_1(ctx) { }; } -// (38:24) {#if i < trail.length - 1} +// (40:12) {#if i < trail.length - 1} function create_if_block_2(ctx) { let span; let t_value = " " + /*settings*/ ctx[2].trailSeperator + " " + ""; @@ -36832,7 +36915,7 @@ function create_if_block_2(ctx) { }; } -// (31:20) {#each trail as crumb, i} +// (31:10) {#each trail as crumb, i} function create_each_block_1(ctx) { let span; let t0_value = /*crumb*/ ctx[14] + ""; @@ -36846,6 +36929,10 @@ function create_each_block_1(ctx) { return /*click_handler*/ ctx[8](/*crumb*/ ctx[14], ...args); } + function mouseover_handler(...args) { + return /*mouseover_handler*/ ctx[9](/*crumb*/ ctx[14], ...args); + } + let if_block = /*i*/ ctx[16] < /*trail*/ ctx[11].length - 1 && create_if_block_2(ctx); return { @@ -36867,7 +36954,7 @@ function create_each_block_1(ctx) { if (!mounted) { dispose = [ listen(span, "click", click_handler), - listen(span, "mouseover", /*mouseover_handler*/ ctx[9]) + listen(span, "mouseover", mouseover_handler) ]; mounted = true; @@ -36901,7 +36988,7 @@ function create_each_block_1(ctx) { }; } -// (26:8) {#each trailsToShow as trail} +// (26:4) {#each trailsToShow as trail} function create_each_block(ctx) { let div; let t; @@ -36945,7 +37032,7 @@ function create_each_block(ctx) { }; } -// (47:4) {#if sortedTrails.length > 1} +// (49:2) {#if sortedTrails.length > 1} function create_if_block(ctx) { let div; let button; @@ -37006,7 +37093,7 @@ function create_fragment(ctx) { t = space(); if (if_block) if_block.c(); attr(div, "class", "trails-div"); - attr(span, "class", "breadcrumbs-trail-path-container svelte-154mvpu"); + attr(span, "class", "breadcrumbs-trail-path-container svelte-1rndeic"); }, m(target, anchor) { insert(target, span, anchor); @@ -37066,7 +37153,7 @@ function create_fragment(ctx) { }; } -function hoverPreview(event, view) { +function hoverPreview(event, view, to) { const targetEl = event.target; view.app.workspace.trigger("hover-link", { @@ -37074,7 +37161,7 @@ function hoverPreview(event, view) { source: view.getViewType(), hoverParent: view, targetEl, - linktext: targetEl.innerText + linktext: to }); } @@ -37090,7 +37177,7 @@ function instance($$self, $$props, $$invalidate) { const activeLeafView = app.workspace.activeLeaf.view; let showAll = settings.showAll; const click_handler = async (crumb, e) => await openOrSwitch(app, crumb, currFile, e); - const mouseover_handler = e => hoverPreview(e, activeLeafView); + const mouseover_handler = (crumb, e) => hoverPreview(e, activeLeafView, crumb); const click_handler_1 = () => $$invalidate(4, showAll = !showAll); $$self.$$set = $$props => { @@ -37128,7 +37215,7 @@ function instance($$self, $$props, $$invalidate) { class TrailPath extends SvelteComponent { constructor(options) { super(); - if (!document.getElementById("svelte-154mvpu-style")) add_css(); + if (!document.getElementById("svelte-1rndeic-style")) add_css(); init$1(this, options, instance, create_fragment, safe_not_equal, { sortedTrails: 0, @@ -37146,6 +37233,7 @@ const DEFAULT_SETTINGS = { hierarchyNoteDownFieldName: "", hierarchyNoteUpFieldName: "", refreshIndexOnActiveLeafChange: false, + altLinkFields: [], useAllMetadata: true, parseJugglLinksWithoutJuggl: false, dvWaitTime: 5000, diff --git a/src/BreadcrumbsSettingTab.ts b/src/BreadcrumbsSettingTab.ts index a79057fb..393f3766 100644 --- a/src/BreadcrumbsSettingTab.ts +++ b/src/BreadcrumbsSettingTab.ts @@ -363,6 +363,24 @@ export class BreadcrumbsSettingTab extends PluginSettingTab { }) ); + new Setting(generalDetails) + .setName('Fields used for Alternative note names (Aliases)') + .setDesc('A comma-separated list of fields you use to specify note name aliases. These fields will be checked, in order, and be used to display an alternate note title in both the list/matrix view, and trail/grid view. This field will probably be `alias` or `aliases`, but it can be anything, like `title`, for example.') + .addText(text => { + let finalValue: string; + + text + .setValue(settings.altLinkFields.join(', ')) + .onChange(str => { + finalValue = str + }); + text.inputEl.onblur = async () => { + settings.altLinkFields = splitAndTrim(finalValue); + await plugin.saveSettings() + } + }) + + new Setting(generalDetails) .setName("Use yaml or inline fields for hierarchy data") .setDesc( diff --git a/src/Components/Lists.svelte b/src/Components/Lists.svelte index 9150992f..af1040fb 100644 --- a/src/Components/Lists.svelte +++ b/src/Components/Lists.svelte @@ -35,9 +35,12 @@ class={realItem.cls} on:click={async (e) => openOrSwitch(app, realItem.to, currFile, e)} - on:mouseover={(e) => hoverPreview(e, matrixView)} + on:mouseover={(e) => + hoverPreview(e, matrixView, realItem.to)} > - {realItem.to.split("/").last()} + {realItem.alt + ? realItem.alt + : realItem.to.split("/").last()} {/each} @@ -59,9 +62,12 @@ class={impliedItem.cls} on:click={async (e) => openOrSwitch(app, impliedItem.to, currFile, e)} - on:mouseover={(e) => hoverPreview(e, matrixView)} + on:mouseover={(e) => + hoverPreview(e, matrixView, impliedItem.to)} > - {impliedItem.to.split("/").last()} + {impliedItem.alt + ? impliedItem.alt + : impliedItem.to.split("/").last()} {/each} diff --git a/src/Components/Matrix.svelte b/src/Components/Matrix.svelte index bcba4566..bb8f61e1 100644 --- a/src/Components/Matrix.svelte +++ b/src/Components/Matrix.svelte @@ -31,9 +31,12 @@ class={realItem.cls} on:click={async (e) => openOrSwitch(app, realItem.to, currFile, e)} - on:mouseover={(event) => hoverPreview(event, matrixView)} + on:mouseover={(event) => + hoverPreview(event, matrixView, realItem.to)} > - {realItem.to.split("/").last()} + {realItem.alt + ? realItem.alt + : realItem.to.split("/").last()} {/each} @@ -51,9 +54,12 @@ class={impliedItem.cls} on:click={async (e) => openOrSwitch(app, impliedItem.to, currFile, e)} - on:mouseover={(event) => hoverPreview(event, matrixView)} + on:mouseover={(event) => + hoverPreview(event, matrixView, impliedItem.to)} > - {impliedItem.to.split("/").last()} + {impliedItem.alt + ? impliedItem.alt + : impliedItem.to.split("/").last()} {/each} diff --git a/src/Components/TrailGrid.svelte b/src/Components/TrailGrid.svelte index 84823c95..d8c568fb 100644 --- a/src/Components/TrailGrid.svelte +++ b/src/Components/TrailGrid.svelte @@ -26,7 +26,7 @@ : "internal-link breadcrumbs-link"; } - function hoverPreview(event: MouseEvent, view: View): void { + function hoverPreview(event: MouseEvent, view: View, to: string): void { const targetEl = event.target as HTMLElement; view.app.workspace.trigger("hover-link", { @@ -34,7 +34,7 @@ source: view.getViewType(), hoverParent: view, targetEl, - linktext: targetEl.innerText, + linktext: to, }); } @@ -123,7 +123,7 @@ ).toString(16)}` : ''}" on:click={(e) => openOrSwitch(app, step.value, currFile, e)} - on:mouseover={(e) => hoverPreview(e, activeLeafView)} + on:mouseover={(e) => hoverPreview(e, activeLeafView, step.value)} >
{step.value}
{#if step.value && settings.gridDots} diff --git a/src/Components/TrailPath.svelte b/src/Components/TrailPath.svelte index ef55b0ee..b3a650f7 100644 --- a/src/Components/TrailPath.svelte +++ b/src/Components/TrailPath.svelte @@ -1,73 +1,69 @@ -
- {#each trailsToShow as trail} -
- {#if trail.length === 0} - {settings.noPathMessage} - {:else} - {#each trail as crumb, i} - await openOrSwitch(app, crumb, currFile, e)} - on:mouseover={(e) => hoverPreview(e, activeLeafView)}> - {crumb} - - {#if i < trail.length - 1} - {' ' + settings.trailSeperator + ' '} - {/if} - {/each} - {/if} -
- {/each} -
+
+ {#each trailsToShow as trail} +
+ {#if trail.length === 0} + {settings.noPathMessage} + {:else} + {#each trail as crumb, i} + + await openOrSwitch(app, crumb, currFile, e)} + on:mouseover={(e) => hoverPreview(e, activeLeafView, crumb)} + > + {crumb} + + {#if i < trail.length - 1} + {" " + settings.trailSeperator + " "} + {/if} + {/each} + {/if} +
+ {/each} +
- {#if sortedTrails.length > 1} + {#if sortedTrails.length > 1}
- +
- {/if} + {/if}
- \ No newline at end of file + } + diff --git a/src/MatrixView.ts b/src/MatrixView.ts index 240ddeff..08e2ea96 100644 --- a/src/MatrixView.ts +++ b/src/MatrixView.ts @@ -122,8 +122,9 @@ export default class MatrixView extends ItemView { return unresolvedLinks[from][to] > 0; } - squareItems(g: Graph, currFile: TFile, realQ = true): internalLinkObj[] { + squareItems(g: Graph, currFile: TFile, settings: BreadcrumbsSettings, realQ = true): internalLinkObj[] { let items: string[]; + const altFieldsQ = !!settings.altLinkFields.length if (realQ) { items = (g.successors(currFile.basename) ?? []) as string[]; @@ -134,13 +135,26 @@ export default class MatrixView extends ItemView { // TODO I don't think I need to check the length here /// forEach won't run if it's empty anyway if (items.length) { - items.forEach((item: string) => { + items.forEach((to: string) => { + let alt = null; + if (altFieldsQ) { + const toFile = this.app.metadataCache.getFirstLinkpathDest(to, currFile.path) + if (toFile) { + const metadata = this.app.metadataCache.getFileCache(toFile) + settings.altLinkFields.forEach(altLinkField => { + const altLink = metadata?.frontmatter?.[altLinkField] + if (altLink) { alt = altLink; return } + console.log({ alt, altLink }) + }) + } + } internalLinkObjArr.push({ - to: item, + to, cls: "internal-link breadcrumbs-link" + - (this.unresolvedQ(item, currFile.path) ? " is-unresolved" : "") + + (this.unresolvedQ(to, currFile.path) ? " is-unresolved" : "") + (realQ ? "" : " breadcrumbs-implied"), + alt }); }); } @@ -298,11 +312,11 @@ export default class MatrixView extends ItemView { ]; let [rUp, rSame, rDown, iUp, iDown] = [ - this.squareItems(currUpG, currFile), - this.squareItems(currSameG, currFile), - this.squareItems(currDownG, currFile), - this.squareItems(currDownG, currFile, false), - this.squareItems(currUpG, currFile, false), + this.squareItems(currUpG, currFile, settings), + this.squareItems(currSameG, currFile, settings), + this.squareItems(currDownG, currFile, settings), + this.squareItems(currDownG, currFile, settings, false), + this.squareItems(currUpG, currFile, settings, false), ]; // SECTION Implied Siblings @@ -335,12 +349,14 @@ export default class MatrixView extends ItemView { (this.unresolvedQ(impliedSibling, currFile.path) ? " is-unresolved" : ""), + // TODO get alt for implied siblings + alt: null }); }); }); /// A real sibling implies the reverse sibling - iSameArr.push(...this.squareItems(currSameG, currFile, false)); + iSameArr.push(...this.squareItems(currSameG, currFile, settings, false)); // !SECTION diff --git a/src/interfaces.ts b/src/interfaces.ts index bba49480..57a760cf 100644 --- a/src/interfaces.ts +++ b/src/interfaces.ts @@ -8,6 +8,7 @@ export interface BreadcrumbsSettings { hierarchyNoteDownFieldName: string; hierarchyNoteUpFieldName: string; refreshIndexOnActiveLeafChange: boolean; + altLinkFields: string[]; useAllMetadata: boolean; parseJugglLinksWithoutJuggl: boolean; dvWaitTime: number; @@ -96,6 +97,7 @@ export interface fileFrontmatter { export interface internalLinkObj { to: string; cls: string; + alt: string | null; } export interface SquareProps { diff --git a/src/main.ts b/src/main.ts index bfb0b734..2585274e 100644 --- a/src/main.ts +++ b/src/main.ts @@ -50,6 +50,7 @@ const DEFAULT_SETTINGS: BreadcrumbsSettings = { hierarchyNoteDownFieldName: "", hierarchyNoteUpFieldName: "", refreshIndexOnActiveLeafChange: false, + altLinkFields: [], useAllMetadata: true, parseJugglLinksWithoutJuggl: false, dvWaitTime: 5000, diff --git a/src/sharedFunctions.ts b/src/sharedFunctions.ts index 0996d5e8..ea914efe 100644 --- a/src/sharedFunctions.ts +++ b/src/sharedFunctions.ts @@ -384,7 +384,7 @@ export const isInVault = (app: App, note: string): boolean => app.workspace.getActiveFile().path ); -export function hoverPreview(event: MouseEvent, matrixView: MatrixView): void { +export function hoverPreview(event: MouseEvent, matrixView: MatrixView, to: string): void { const targetEl = event.target as HTMLElement; matrixView.app.workspace.trigger("hover-link", { @@ -392,7 +392,7 @@ export function hoverPreview(event: MouseEvent, matrixView: MatrixView): void { source: matrixView.getViewType(), hoverParent: matrixView, targetEl, - linktext: targetEl.innerText, + linktext: to, }); } @@ -673,7 +673,7 @@ export const writeBCToFile = (app: App, plugin: BreadcrumbsPlugin, currGraphs: B succs.forEach(async succ => { const { fieldName } = fieldG.node(succ); if (!plugin.settings.limitWriteBCCheckboxStates[fieldName]) return - + const currHier = plugin.settings.userHierarchies.filter(hier => hier[dir].includes(fieldName))[0] let oppField: string = currHier[oppDir][0]; if (!oppField) oppField = `${fieldName}`