From 5914cfb7099e281581db21656f3aa22e9993d710 Mon Sep 17 00:00:00 2001 From: Ross Keenan Date: Thu, 16 Dec 2021 09:55:07 +0200 Subject: [PATCH] fix(List/Matrix View): :bug: Sort by altField first, then regular note name (Fix #206) --- main.js | 29 +++++++++++++++++++---------- src/MatrixView.ts | 12 ++++++++---- 2 files changed, 27 insertions(+), 14 deletions(-) diff --git a/main.js b/main.js index 7995d89f..61c76c9b 100644 --- a/main.js +++ b/main.js @@ -24548,19 +24548,21 @@ class MatrixView extends require$$0.ItemView { return Promise.resolve(); } getAlt(node) { + var _a; const { altLinkFields } = this.plugin.settings; - let alt = null; if (altLinkFields.length) { const file = this.app.metadataCache.getFirstLinkpathDest(node, ""); if (file) { const metadata = this.app.metadataCache.getFileCache(file); - altLinkFields.forEach((altLinkField) => { - var _a; - alt = (_a = metadata === null || metadata === void 0 ? void 0 : metadata.frontmatter) === null || _a === void 0 ? void 0 : _a[altLinkField]; - }); + for (const altField of altLinkFields) { + const value = (_a = metadata === null || metadata === void 0 ? void 0 : metadata.frontmatter) === null || _a === void 0 ? void 0 : _a[altField]; + if (value) + return value; + } } } - return alt; + else + return null; } // ANCHOR Remove duplicate implied links removeDuplicateImplied(reals, implieds) { @@ -24629,7 +24631,16 @@ class MatrixView extends require$$0.ItemView { const { alphaSortAsc } = settings; const squares = [ru, rs, rd, rn, rp, iu, is, id, iN, ip]; if (settings.enableAlphaSort) { - squares.forEach((sq) => sq.sort((a, b) => a.to < b.to ? (alphaSortAsc ? -1 : 1) : alphaSortAsc ? 1 : -1)); + squares.forEach((sq) => sq.sort((a, b) => { + var _a, _b; + return ((_a = a.alt) !== null && _a !== void 0 ? _a : a.to) < ((_b = b.alt) !== null && _b !== void 0 ? _b : b.to) + ? alphaSortAsc + ? -1 + : 1 + : alphaSortAsc + ? 1 + : -1; + })); } squares.forEach((sq) => sq.sort((a, b) => a.order - b.order)); loglevel.info([ @@ -24691,9 +24702,7 @@ class MatrixView extends require$$0.ItemView { await this.draw(); }; }); - contentEl.createEl("button", { text: "↻", attr: { "aria-label": "Refresh Index" } }, (el) => { - el.onclick = async () => await this.plugin.refreshIndex(); - }); + contentEl.createEl("button", { text: "↻", attr: { "aria-label": "Refresh Index" } }, (el) => (el.onclick = async () => await this.plugin.refreshIndex())); contentEl.createEl("button", { text: settings.alphaSortAsc ? "↗" : "↘", attr: { "aria-label": "Alphabetical sorting order" }, diff --git a/src/MatrixView.ts b/src/MatrixView.ts index b7082ef0..0b1cf96a 100644 --- a/src/MatrixView.ts +++ b/src/MatrixView.ts @@ -208,7 +208,13 @@ export default class MatrixView extends ItemView { if (settings.enableAlphaSort) { squares.forEach((sq) => sq.sort((a, b) => - a.to < b.to ? (alphaSortAsc ? -1 : 1) : alphaSortAsc ? 1 : -1 + (a.alt ?? a.to) < (b.alt ?? b.to) + ? alphaSortAsc + ? -1 + : 1 + : alphaSortAsc + ? 1 + : -1 ) ); } @@ -287,9 +293,7 @@ export default class MatrixView extends ItemView { contentEl.createEl( "button", { text: "↻", attr: { "aria-label": "Refresh Index" } }, - (el) => { - el.onclick = async () => await this.plugin.refreshIndex(); - } + (el) => (el.onclick = async () => await this.plugin.refreshIndex()) ); contentEl.createEl(