Revert "Desktop: Fixes #5686: Fixed Tags Order (#6136)"

This reverts commit 07f128ae95.

Due to regression: https://github.com/laurent22/joplin/issues/6301
pull/6342/head
Laurent Cozic 2022-03-28 17:40:51 +01:00
parent a73d822998
commit 3725b14e04
5 changed files with 34 additions and 47 deletions

View File

@ -1,7 +1,6 @@
import { CommandRuntime, CommandDeclaration, CommandContext } from '@joplin/lib/services/CommandService'; import { CommandRuntime, CommandDeclaration, CommandContext } from '@joplin/lib/services/CommandService';
import { _ } from '@joplin/lib/locale'; import { _ } from '@joplin/lib/locale';
import Tag from '@joplin/lib/models/Tag'; import Tag from '@joplin/lib/models/Tag';
import { TagEntity } from '@joplin/lib/services/database/types';
export const declaration: CommandDeclaration = { export const declaration: CommandDeclaration = {
name: 'setTags', name: 'setTags',
@ -15,16 +14,23 @@ export const runtime = (comp: any): CommandRuntime => {
noteIds = noteIds || context.state.selectedNoteIds; noteIds = noteIds || context.state.selectedNoteIds;
const tags = await Tag.commonTagsByNoteIds(noteIds); const tags = await Tag.commonTagsByNoteIds(noteIds);
const sortedTags = Tag.sortTags(tags); const startTags = tags
const startTags = sortedTags .map((a: any) => {
.map((a: TagEntity) => {
return { value: a.id, label: a.title }; return { value: a.id, label: a.title };
})
.sort((a: any, b: any) => {
// sensitivity accent will treat accented characters as differemt
// but treats caps as equal
return a.label.localeCompare(b.label, undefined, { sensitivity: 'accent' });
}); });
const allTags = await Tag.allWithNotes(); const allTags = await Tag.allWithNotes();
const sortedAllTags = Tag.sortTags(allTags); const tagSuggestions = allTags.map((a: any) => {
const tagSuggestions = sortedAllTags return { value: a.id, label: a.title };
.map((a: TagEntity) => { })
return { value: a.id, label: a.title }; .sort((a: any, b: any) => {
// sensitivity accent will treat accented characters as differemt
// but treats caps as equal
return a.label.localeCompare(b.label, undefined, { sensitivity: 'accent' });
}); });
comp.setState({ comp.setState({

View File

@ -1,7 +1,6 @@
import * as React from 'react'; import * as React from 'react';
import { useMemo } from 'react'; import { useMemo } from 'react';
import { AppState } from '../app.reducer'; import { AppState } from '../app.reducer';
import Tag from '@joplin/lib/models/Tag';
const { connect } = require('react-redux'); const { connect } = require('react-redux');
const { themeStyle } = require('@joplin/lib/theme'); const { themeStyle } = require('@joplin/lib/theme');
@ -29,7 +28,11 @@ function TagList(props: Props) {
}, [props.style, props.themeId]); }, [props.style, props.themeId]);
const tags = useMemo(() => { const tags = useMemo(() => {
const output = Tag.sortTags(props.items.slice()); const output = props.items.slice();
output.sort((a: any, b: any) => {
return a.title < b.title ? -1 : +1;
});
return output; return output;
}, [props.items]); }, [props.items]);

View File

@ -1,7 +1,6 @@
const Folder = require('../../models/Folder').default; const Folder = require('../../models/Folder').default;
const Setting = require('../../models/Setting').default; const Setting = require('../../models/Setting').default;
const BaseModel = require('../../BaseModel').default; const BaseModel = require('../../BaseModel').default;
const Tag = require('../../models/Tag').default;
const shared = {}; const shared = {};
@ -51,7 +50,20 @@ shared.renderFolders = function(props, renderItem) {
}; };
shared.renderTags = function(props, renderItem) { shared.renderTags = function(props, renderItem) {
const tags = Tag.sortTags(props.tags.slice()); const tags = props.tags.slice();
tags.sort((a, b) => {
// It seems title can sometimes be undefined (perhaps when syncing
// and before tag has been decrypted?). It would be best to find
// the root cause but for now that will do.
//
// Fixes https://github.com/laurent22/joplin/issues/4051
if (!a || !a.title || !b || !b.title) return 0;
// Note: while newly created tags are normalized and lowercase
// imported tags might be any case, so we need to do case-insensitive
// sort.
return a.title.toLowerCase() < b.title.toLowerCase() ? -1 : +1;
});
const tagItems = []; const tagItems = [];
const order = []; const order = [];
for (let i = 0; i < tags.length; i++) { for (let i = 0; i < tags.length; i++) {

View File

@ -50,7 +50,7 @@ describe('models/Tag', function() {
it('should return tags with note counts', (async () => { it('should return tags with note counts', (async () => {
const folder1 = await Folder.save({ title: 'folder1' }); const folder1 = await Folder.save({ title: 'folder1' });
const note1 = await Note.save({ title: 'ma note', parent_id: folder1.id }); const note1 = await Note.save({ title: 'ma note', parent_id: folder1.id });
const note2 = await Note.save({ title: 'ma 2nd note',parent_id: folder1.id }); const note2 = await Note.save({ title: 'ma 2nd note', parent_id: folder1.id });
const todo1 = await Note.save({ title: 'todo 1', parent_id: folder1.id, is_todo: 1, todo_completed: 1590085027710 }); const todo1 = await Note.save({ title: 'todo 1', parent_id: folder1.id, is_todo: 1, todo_completed: 1590085027710 });
await Tag.setNoteTagsByTitles(note1.id, ['un']); await Tag.setNoteTagsByTitles(note1.id, ['un']);
await Tag.setNoteTagsByTitles(note2.id, ['un']); await Tag.setNoteTagsByTitles(note2.id, ['un']);
@ -156,24 +156,4 @@ describe('models/Tag', function() {
expect(commonTagIds.includes(tagc.id)).toBe(true); expect(commonTagIds.includes(tagc.id)).toBe(true);
})); }));
it('should sort tags', (async () => {
// test for tags with titles
const unsortedTags = [{ title: '@⏲15 min' },{ title: '#house' },{ title: '#coding' }, { title: '@⏲60 min' }, { title: '#wait' }, { title: '@⏲30 min' }];
const sortedTags = Tag.sortTags(unsortedTags);
expect(sortedTags).toEqual([{ title: '@⏲15 min' }, { title: '@⏲30 min' }, { title: '@⏲60 min' }, { title: '#coding' }, { title: '#house' }, { title: '#wait' }]);
// test for tags without titles
const unsortedTags2 = [{ id: '40' } , { id: '50' }, { id: '10' }, { id: '30' }, { id: '20' }];
const sortedTags2 = Tag.sortTags(unsortedTags2);
expect(sortedTags2).toEqual([{ id: '40' } , { id: '50' }, { id: '10' }, { id: '30' }, { id: '20' }]);
// test for tags with titles, without titles and empty tags
const unsortedTags3 = [{ id: '1' }, { id: '2', title: 'two' }, {}, { id: '3' }, { id: '4', title: 'four' }, { id: '5',title: 'five' }];
const sortedTags3 = Tag.sortTags(unsortedTags3);
expect(sortedTags3).toEqual([{ id: '1' }, { id: '2', title: 'two' }, {}, { id: '3' }, { id: '5', title: 'five' }, { id: '4', title: 'four' }]);
// test for empty list
const emptyListSort = Tag.sortTags([]);
expect(emptyListSort).toEqual([]);
}));
}); });

View File

@ -216,18 +216,4 @@ export default class Tag extends BaseItem {
return tag; return tag;
}); });
} }
static sortTags(tags: TagEntity[]) {
return tags.sort((a: TagEntity,b: TagEntity) => {
// It seems title can sometimes be undefined (perhaps when syncing and before tag has been decrypted?). It would be best to find the root cause but for now that will do.
// Fixes https://github.com/laurent22/joplin/issues/4051
if (!a || !a.title || !b || !b.title) return 0;
// Note: while newly created tags are normalized and lowercase
// imported tags might be any case, so we need to do case-insensitive
// sort.
return a.title.localeCompare(b.title, undefined, { sensitivity: 'accent' });
});
}
} }