mirror of
https://github.com/zadam/trilium.git
synced 2025-12-04 22:44:25 +01:00
Compare commits
7 Commits
3c5f084031
...
aa1780c027
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
aa1780c027 | ||
|
|
67d2175ce9 | ||
|
|
8a3283f1ea | ||
|
|
2fb47fc186 | ||
|
|
4530c9a40c | ||
|
|
a1c0314334 | ||
|
|
3ecdcd9ea0 |
@ -1306,8 +1306,8 @@
|
|||||||
"zpetne_odkazy": {
|
"zpetne_odkazy": {
|
||||||
"relation": "relazione",
|
"relation": "relazione",
|
||||||
"backlink_one": "{{count}} Backlink",
|
"backlink_one": "{{count}} Backlink",
|
||||||
"backlink_many": "",
|
"backlink_many": "{{count}} Backlinks",
|
||||||
"backlink_other": "{{count}} Backlink"
|
"backlink_other": "{{count}} Backlinks"
|
||||||
},
|
},
|
||||||
"mobile_detail_menu": {
|
"mobile_detail_menu": {
|
||||||
"insert_child_note": "Inserisci nota secondaria",
|
"insert_child_note": "Inserisci nota secondaria",
|
||||||
@ -1801,8 +1801,8 @@
|
|||||||
"relation-map": "Mappa delle relazioni",
|
"relation-map": "Mappa delle relazioni",
|
||||||
"note-map": "Nota Mappa",
|
"note-map": "Nota Mappa",
|
||||||
"render-note": "Nota di rendering",
|
"render-note": "Nota di rendering",
|
||||||
"book": "Collezione",
|
"book": "Raccolta",
|
||||||
"mermaid-diagram": "Diagramma della sirena",
|
"mermaid-diagram": "Diagramma Mermaid",
|
||||||
"canvas": "Tela",
|
"canvas": "Tela",
|
||||||
"web-view": "Visualizzazione Web",
|
"web-view": "Visualizzazione Web",
|
||||||
"mind-map": "Mappa mentale",
|
"mind-map": "Mappa mentale",
|
||||||
@ -1967,7 +1967,8 @@
|
|||||||
"open_note_in_new_tab": "Apri la nota in una nuova scheda",
|
"open_note_in_new_tab": "Apri la nota in una nuova scheda",
|
||||||
"open_note_in_new_split": "Apri nota in una nuova divisione",
|
"open_note_in_new_split": "Apri nota in una nuova divisione",
|
||||||
"open_note_in_new_window": "Apri la nota in una nuova finestra",
|
"open_note_in_new_window": "Apri la nota in una nuova finestra",
|
||||||
"open_note_in_popup": "Modifica rapida"
|
"open_note_in_popup": "Modifica rapida",
|
||||||
|
"open_note_in_other_split": "Apri nota nell'altra divisione"
|
||||||
},
|
},
|
||||||
"help-button": {
|
"help-button": {
|
||||||
"title": "Apri la pagina di aiuto pertinente"
|
"title": "Apri la pagina di aiuto pertinente"
|
||||||
|
|||||||
@ -1158,7 +1158,8 @@
|
|||||||
"open_note_in_popup": "クイック編集",
|
"open_note_in_popup": "クイック編集",
|
||||||
"open_note_in_new_tab": "新しいタブでノートを開く",
|
"open_note_in_new_tab": "新しいタブでノートを開く",
|
||||||
"open_note_in_new_split": "新しく分割してノートを開く",
|
"open_note_in_new_split": "新しく分割してノートを開く",
|
||||||
"open_note_in_new_window": "新しいウィンドウでノートを開く"
|
"open_note_in_new_window": "新しいウィンドウでノートを開く",
|
||||||
|
"open_note_in_other_split": "他の分割画面でノートを開く"
|
||||||
},
|
},
|
||||||
"note_tooltip": {
|
"note_tooltip": {
|
||||||
"quick-edit": "クイック編集",
|
"quick-edit": "クイック編集",
|
||||||
|
|||||||
@ -1,11 +1,11 @@
|
|||||||
import { beforeEach, describe, expect, it, vi } from "vitest";
|
import {beforeEach, describe, expect, it, vi} from "vitest";
|
||||||
import { note, NoteBuilder } from "../test/becca_mocking.js";
|
import {note, NoteBuilder} from "../test/becca_mocking.js";
|
||||||
import becca from "../becca/becca.js";
|
import becca from "../becca/becca.js";
|
||||||
import BBranch from "../becca/entities/bbranch.js";
|
import BBranch from "../becca/entities/bbranch.js";
|
||||||
import BNote from "../becca/entities/bnote.js";
|
import BNote from "../becca/entities/bnote.js";
|
||||||
import tree from "./tree.js";
|
import tree from "./tree.js";
|
||||||
import cls from "./cls.js";
|
import cls from "./cls.js";
|
||||||
import { buildNote } from "../test/becca_easy_mocking.js";
|
import {buildNote} from "../test/becca_easy_mocking.js";
|
||||||
|
|
||||||
describe("Tree", () => {
|
describe("Tree", () => {
|
||||||
let rootNote!: NoteBuilder;
|
let rootNote!: NoteBuilder;
|
||||||
@ -48,6 +48,23 @@ describe("Tree", () => {
|
|||||||
};
|
};
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
it("sorts notes by title (base case)", () => {
|
||||||
|
|
||||||
|
const note = buildNote({
|
||||||
|
children: [
|
||||||
|
{title: "1"},
|
||||||
|
{title: "2"},
|
||||||
|
{title: "3"},
|
||||||
|
],
|
||||||
|
"#sorted": "",
|
||||||
|
});
|
||||||
|
cls.init(() => {
|
||||||
|
tree.sortNotesIfNeeded(note.noteId);
|
||||||
|
});
|
||||||
|
const orderedTitles = note.children.map((child) => child.title);
|
||||||
|
expect(orderedTitles).toStrictEqual(["1", "2", "3"]);
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
it("custom sort order is idempotent", () => {
|
it("custom sort order is idempotent", () => {
|
||||||
rootNote.label("sorted", "order");
|
rootNote.label("sorted", "order");
|
||||||
@ -56,13 +73,15 @@ describe("Tree", () => {
|
|||||||
for (let i = 0; i <= 5; i++) {
|
for (let i = 0; i <= 5; i++) {
|
||||||
rootNote.child(note(String(i)).label("order", String(i)));
|
rootNote.child(note(String(i)).label("order", String(i)));
|
||||||
}
|
}
|
||||||
|
rootNote.child(note("top").label("top"));
|
||||||
|
rootNote.child(note("bottom").label("bottom"));
|
||||||
|
|
||||||
// Add a few values which have no defined order.
|
// Add a few values which have no defined order.
|
||||||
for (let i = 6; i < 10; i++) {
|
for (let i = 6; i < 10; i++) {
|
||||||
rootNote.child(note(String(i)));
|
rootNote.child(note(String(i)));
|
||||||
}
|
}
|
||||||
|
|
||||||
const expectedOrder = [ "0", "1", "2", "3", "4", "5", "6", "7", "8", "9" ];
|
const expectedOrder = ["top", "0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "bottom"];
|
||||||
|
|
||||||
// Sort a few times to ensure that the resulting order is the same.
|
// Sort a few times to ensure that the resulting order is the same.
|
||||||
for (let i = 0; i < 5; i++) {
|
for (let i = 0; i < 5; i++) {
|
||||||
@ -78,12 +97,12 @@ describe("Tree", () => {
|
|||||||
it("pins to the top and bottom", () => {
|
it("pins to the top and bottom", () => {
|
||||||
const note = buildNote({
|
const note = buildNote({
|
||||||
children: [
|
children: [
|
||||||
{ title: "bottom", "#bottom": "" },
|
{title: "bottom", "#bottom": ""},
|
||||||
{ title: "5" },
|
{title: "5"},
|
||||||
{ title: "3" },
|
{title: "3"},
|
||||||
{ title: "2" },
|
{title: "2"},
|
||||||
{ title: "1" },
|
{title: "1"},
|
||||||
{ title: "top", "#top": "" }
|
{title: "top", "#top": ""}
|
||||||
],
|
],
|
||||||
"#sorted": ""
|
"#sorted": ""
|
||||||
});
|
});
|
||||||
@ -91,18 +110,18 @@ describe("Tree", () => {
|
|||||||
tree.sortNotesIfNeeded(note.noteId);
|
tree.sortNotesIfNeeded(note.noteId);
|
||||||
});
|
});
|
||||||
const orderedTitles = note.children.map((child) => child.title);
|
const orderedTitles = note.children.map((child) => child.title);
|
||||||
expect(orderedTitles).toStrictEqual([ "top", "1", "2", "3", "5", "bottom" ]);
|
expect(orderedTitles).toStrictEqual(["top", "1", "2", "3", "5", "bottom"]);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("pins to the top and bottom in reverse order", () => {
|
it("pins to the top and bottom in reverse order", () => {
|
||||||
const note = buildNote({
|
const note = buildNote({
|
||||||
children: [
|
children: [
|
||||||
{ title: "bottom", "#bottom": "" },
|
{title: "bottom", "#bottom": ""},
|
||||||
{ title: "1" },
|
{title: "1"},
|
||||||
{ title: "2" },
|
{title: "2"},
|
||||||
{ title: "3" },
|
{title: "3"},
|
||||||
{ title: "5" },
|
{title: "5"},
|
||||||
{ title: "top", "#top": "" }
|
{title: "top", "#top": ""}
|
||||||
],
|
],
|
||||||
"#sorted": "",
|
"#sorted": "",
|
||||||
"#sortDirection": "desc"
|
"#sortDirection": "desc"
|
||||||
@ -111,6 +130,50 @@ describe("Tree", () => {
|
|||||||
tree.sortNotesIfNeeded(note.noteId);
|
tree.sortNotesIfNeeded(note.noteId);
|
||||||
});
|
});
|
||||||
const orderedTitles = note.children.map((child) => child.title);
|
const orderedTitles = note.children.map((child) => child.title);
|
||||||
expect(orderedTitles).toStrictEqual([ "top", "5", "3", "2", "1", "bottom" ]);
|
expect(orderedTitles).toStrictEqual(["top", "5", "3", "2", "1", "bottom"]);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it("keeps folder notes on top when #sortFolderFirst is set, but not above #top", () => {
|
||||||
|
const note = buildNote({
|
||||||
|
children: [
|
||||||
|
{title: "bottom", "#bottom": ""},
|
||||||
|
{title: "1"},
|
||||||
|
{title: "2"},
|
||||||
|
{title: "p1", children: [{title: "1.1"}, {title: "1.2"}]},
|
||||||
|
{title: "p2", children: [{title: "2.1"}, {title: "2.2"}]},
|
||||||
|
{title: "3"},
|
||||||
|
{title: "5"},
|
||||||
|
{title: "top", "#top": ""}
|
||||||
|
],
|
||||||
|
"#sorted": "",
|
||||||
|
"#sortFoldersFirst": ""
|
||||||
|
});
|
||||||
|
cls.init(() => {
|
||||||
|
tree.sortNotesIfNeeded(note.noteId);
|
||||||
|
});
|
||||||
|
const orderedTitles = note.children.map((child) => child.title);
|
||||||
|
expect(orderedTitles).toStrictEqual(["top", "p1", "p2", "1", "2", "3", "5", "bottom"]);
|
||||||
|
});
|
||||||
|
|
||||||
|
it("sorts notes accordingly when #sortNatural is set", () => {
|
||||||
|
const note = buildNote({
|
||||||
|
children: [
|
||||||
|
{title: "bottom", "#bottom": ""},
|
||||||
|
{title: "1"},
|
||||||
|
{title: "2"},
|
||||||
|
{title: "10"},
|
||||||
|
{title: "20"},
|
||||||
|
{title: "3"},
|
||||||
|
{title: "top", "#top": ""}
|
||||||
|
],
|
||||||
|
"#sorted": "",
|
||||||
|
"#sortNatural": ""
|
||||||
|
});
|
||||||
|
cls.init(() => {
|
||||||
|
tree.sortNotesIfNeeded(note.noteId);
|
||||||
|
});
|
||||||
|
const orderedTitles = note.children.map((child) => child.title);
|
||||||
|
expect(orderedTitles).toStrictEqual(["top", "1", "2", "3", "10", "20", "bottom"]);
|
||||||
|
}
|
||||||
|
)
|
||||||
});
|
});
|
||||||
|
|||||||
@ -98,15 +98,6 @@ function sortNotes(parentNoteId: string, customSortBy: string = "title", reverse
|
|||||||
}
|
}
|
||||||
|
|
||||||
notes.sort((a, b) => {
|
notes.sort((a, b) => {
|
||||||
if (foldersFirst) {
|
|
||||||
const aHasChildren = a.hasChildren();
|
|
||||||
const bHasChildren = b.hasChildren();
|
|
||||||
|
|
||||||
if ((aHasChildren && !bHasChildren) || (!aHasChildren && bHasChildren)) {
|
|
||||||
// exactly one note of the two is a directory, so the sorting will be done based on this status
|
|
||||||
return aHasChildren ? -1 : 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function fetchValue(note: BNote, key: string) {
|
function fetchValue(note: BNote, key: string) {
|
||||||
let rawValue: string | null;
|
let rawValue: string | null;
|
||||||
@ -154,6 +145,16 @@ function sortNotes(parentNoteId: string, customSortBy: string = "title", reverse
|
|||||||
return compare(bottomBEl, bottomAEl) * (reverse ? -1 : 1);
|
return compare(bottomBEl, bottomAEl) * (reverse ? -1 : 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (foldersFirst) {
|
||||||
|
const aHasChildren = a.hasChildren();
|
||||||
|
const bHasChildren = b.hasChildren();
|
||||||
|
|
||||||
|
if ((aHasChildren && !bHasChildren) || (!aHasChildren && bHasChildren)) {
|
||||||
|
// exactly one note of the two is a directory, so the sorting will be done based on this status
|
||||||
|
return aHasChildren ? -1 : 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const customAEl = fetchValue(a, customSortBy) ?? fetchValue(a, "title") as string;
|
const customAEl = fetchValue(a, customSortBy) ?? fetchValue(a, "title") as string;
|
||||||
const customBEl = fetchValue(b, customSortBy) ?? fetchValue(b, "title") as string;
|
const customBEl = fetchValue(b, customSortBy) ?? fetchValue(b, "title") as string;
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user