From 918b3e0bd97cf98899132ac0a1e480063579ff2f Mon Sep 17 00:00:00 2001 From: Ross Keenan Date: Thu, 18 Nov 2021 17:17:26 +0200 Subject: [PATCH] fix: :bug: More safety checks if no next/prev yet --- main.js | 110 +++++++++++++++++++---------------------- src/main.ts | 3 ++ src/sharedFunctions.ts | 54 ++++++++++---------- 3 files changed, 84 insertions(+), 83 deletions(-) diff --git a/main.js b/main.js index 6c62f048..7bf01e63 100644 --- a/main.js +++ b/main.js @@ -20401,30 +20401,36 @@ const getInNeighbours = (g, node) => g.hasNode(node) ? g.inNeighbors(node) : []; function getPrevNext(plugin, currNode) { const [rPrev, rNext, iPrev, iNext] = [[], [], [], []]; const { userHierarchies } = plugin.settings; - plugin.currGraphs.main.forEachEdge(currNode, (k, a, s, t) => { - const { fieldName } = a; - if (a.dir === "next" && s === currNode) { - rNext.push({ to: t, real: true, fieldName }); - } - if (a.dir === "prev" && t === currNode) { - iNext.push({ - to: s, - real: false, - fieldName: getOppFields(userHierarchies, fieldName)[0], - }); - } - if (a.dir === "prev" && s === currNode) { - rPrev.push({ to: t, real: true, fieldName }); - } - if (a.dir === "next" && t === currNode) { - iPrev.push({ - to: s, - real: false, - fieldName: getOppFields(userHierarchies, fieldName)[0], - }); - } - }); - return { rPrev, rNext, iPrev, iNext }; + try { + plugin.currGraphs.main.forEachEdge(currNode, (k, a, s, t) => { + const { fieldName } = a; + if (a.dir === "next" && s === currNode) { + rNext.push({ to: t, real: true, fieldName }); + } + if (a.dir === "prev" && t === currNode) { + iNext.push({ + to: s, + real: false, + fieldName: getOppFields(userHierarchies, fieldName)[0], + }); + } + if (a.dir === "prev" && s === currNode) { + rPrev.push({ to: t, real: true, fieldName }); + } + if (a.dir === "next" && t === currNode) { + iPrev.push({ + to: s, + real: false, + fieldName: getOppFields(userHierarchies, fieldName)[0], + }); + } + }); + return { rPrev, rNext, iPrev, iNext }; + } + catch (e) { + console.log(e); + return { rPrev, rNext, iPrev, iNext }; + } } function noop$1() { } @@ -22251,6 +22257,7 @@ class MatrixView extends obsidian.ItemView { } getHierSquares(userHierarchies, data, currFile, settings) { const { basename } = currFile; + const { iNext: iNextInfo, iPrev: iPrevInfo, rNext: rNextInfo, rPrev: rPrevInfo, } = getPrevNext(this.plugin, basename); return userHierarchies.map((hier, i) => { const { up, same, down } = data[i]; let [rUp, rSame, rDown, iUp, iDown] = [ @@ -22260,40 +22267,6 @@ class MatrixView extends obsidian.ItemView { this.squareItems(down, currFile, settings, false), this.squareItems(up, currFile, settings, false), ]; - const rNext = []; - const rPrev = []; - let iNext = []; - let iPrev = []; - this.plugin.currGraphs.main.forEachEdge(basename, (k, a, s, t) => { - if (a.dir === "next" && s === basename) { - rNext.push({ - to: t, - cls: linkClass(this.app, t, true), - alt: this.getAlt(t, settings), - }); - } - if (a.dir === "prev" && t === basename) { - iNext.push({ - to: s, - cls: linkClass(this.app, s, false), - alt: this.getAlt(s, settings), - }); - } - if (a.dir === "prev" && s === basename) { - rPrev.push({ - to: t, - cls: linkClass(this.app, t, true), - alt: this.getAlt(t, settings), - }); - } - if (a.dir === "next" && t === basename) { - iPrev.push({ - to: s, - cls: linkClass(this.app, s, false), - alt: this.getAlt(s, settings), - }); - } - }); // SECTION Implied Siblings /// Notes with the same parents let iSameArr = []; @@ -22333,6 +22306,24 @@ class MatrixView extends obsidian.ItemView { /// A real sibling implies the reverse sibling iSameArr.push(...this.squareItems(same, currFile, settings, false)); // !SECTION + let [iNext, iPrev, rNext, rPrev] = [ + iNextInfo, + iPrevInfo, + rNextInfo, + rPrevInfo, + ].map((info) => { + return info + .filter((item) => hier.next.includes(item.fieldName) || + hier.prev.includes(item.fieldName)) + .map((item) => { + const { to } = item; + return { + to, + cls: linkClass(this.app, to, item.real), + alt: this.getAlt(to, settings), + }; + }); + }); iUp = this.removeDuplicateImplied(rUp, iUp); iSameArr = this.removeDuplicateImplied(rSame, iSameArr); iDown = this.removeDuplicateImplied(rDown, iDown); @@ -35272,6 +35263,9 @@ class BCPlugin extends obsidian.Plugin { prev: {}, }; DIRECTIONS.forEach((dir) => { + if (!hier[dir]) { + hier[dir] = []; + } hier[dir].forEach((dirField) => { newGraphs[dir][dirField] = new graphology_umd_min(); }); diff --git a/src/main.ts b/src/main.ts index 0cafb65d..d9722a77 100644 --- a/src/main.ts +++ b/src/main.ts @@ -473,6 +473,9 @@ export default class BCPlugin extends Plugin { }; DIRECTIONS.forEach((dir: Directions) => { + if (!hier[dir]) { + hier[dir] = []; + } hier[dir].forEach((dirField) => { newGraphs[dir][dirField] = new Graph(); }); diff --git a/src/sharedFunctions.ts b/src/sharedFunctions.ts index bdf1eed5..c0903670 100644 --- a/src/sharedFunctions.ts +++ b/src/sharedFunctions.ts @@ -818,29 +818,33 @@ export const getInNeighbours = (g: Graph, node: string): string[] => export function getPrevNext(plugin: BCPlugin, currNode: string) { const [rPrev, rNext, iPrev, iNext]: PrevNext[][] = [[], [], [], []]; const { userHierarchies } = plugin.settings; - - plugin.currGraphs.main.forEachEdge(currNode, (k, a, s, t) => { - const { fieldName } = a; - if (a.dir === "next" && s === currNode) { - rNext.push({ to: t, real: true, fieldName }); - } - if (a.dir === "prev" && t === currNode) { - iNext.push({ - to: s, - real: false, - fieldName: getOppFields(userHierarchies, fieldName)[0], - }); - } - if (a.dir === "prev" && s === currNode) { - rPrev.push({ to: t, real: true, fieldName }); - } - if (a.dir === "next" && t === currNode) { - iPrev.push({ - to: s, - real: false, - fieldName: getOppFields(userHierarchies, fieldName)[0], - }); - } - }); - return { rPrev, rNext, iPrev, iNext }; + try { + plugin.currGraphs.main.forEachEdge(currNode, (k, a, s, t) => { + const { fieldName } = a; + if (a.dir === "next" && s === currNode) { + rNext.push({ to: t, real: true, fieldName }); + } + if (a.dir === "prev" && t === currNode) { + iNext.push({ + to: s, + real: false, + fieldName: getOppFields(userHierarchies, fieldName)[0], + }); + } + if (a.dir === "prev" && s === currNode) { + rPrev.push({ to: t, real: true, fieldName }); + } + if (a.dir === "next" && t === currNode) { + iPrev.push({ + to: s, + real: false, + fieldName: getOppFields(userHierarchies, fieldName)[0], + }); + } + }); + return { rPrev, rNext, iPrev, iNext }; + } catch (e) { + console.log(e); + return { rPrev, rNext, iPrev, iNext }; + } }