Sorting column names

This commit is contained in:
Jarosław Sadziński 2024-10-02 13:16:10 +02:00
parent 8e2831ae6a
commit 83c6785754
3 changed files with 22 additions and 3 deletions

View File

@ -230,6 +230,23 @@ export function formatterForRec(
return func(args); return func(args);
} }
export function labelsOrder(a: ColumnRec, b: ColumnRec): number {
const left = a.label.peek().toLowerCase();
const right = b.label.peek().toLowerCase();
// Order is as follows:
// - First columns with normal labels starting with a letter.
// - Second all columns starting with '_' (treated as private)
// - Third all columns starting with '#' (treated as private)
// - Rest.
if (left[0] === '_' && right[0] !== '_') { return 1; }
if (left[0] !== '_' && right[0] === '_') { return -1; }
if (left[0] === '#' && right[0] !== '#') { return 1; }
if (left[0] !== '#' && right[0] === '#') { return -1; }
return left.localeCompare(right);
}
/** /**
* A chat message. Either send by the user or by the AI. * A chat message. Either send by the user or by the AI.
*/ */

View File

@ -7,6 +7,7 @@ import {makeT} from 'app/client/lib/localization';
import {localStorageBoolObs} from 'app/client/lib/localStorageObs'; import {localStorageBoolObs} from 'app/client/lib/localStorageObs';
import {ColumnToMapImpl} from 'app/client/models/ColumnToMap'; import {ColumnToMapImpl} from 'app/client/models/ColumnToMap';
import {ColumnRec, ViewSectionRec} from 'app/client/models/DocModel'; import {ColumnRec, ViewSectionRec} from 'app/client/models/DocModel';
import {labelsOrder} from 'app/client/models/entities/ColumnRec';
import { import {
cssDeveloperLink, cssDeveloperLink,
cssWidgetMetadata, cssWidgetMetadata,
@ -75,13 +76,12 @@ class ColumnPicker extends Disposable {
void use(refreshTrigger); void use(refreshTrigger);
const columnsAsOptions: IOption<number|null>[] = use(canBeMapped) const columnsAsOptions: IOption<number|null>[] = use(canBeMapped)
.sort(labelsOrder)
.map((col) => ({ .map((col) => ({
value: col.getRowId(), value: col.getRowId(),
label: col.label.peek() || '', label: col.label.peek() || '',
icon: 'FieldColumn', icon: 'FieldColumn',
})); }));
// Order it by label.
columnsAsOptions.sort((a, b) => a.label.localeCompare(b.label));
// For optional mappings, add 'Blank' option but only if the value is set. // For optional mappings, add 'Blank' option but only if the value is set.
// This option will allow to clear the selection. // This option will allow to clear the selection.
@ -205,6 +205,7 @@ class ColumnListPicker extends Disposable {
const wrongTypeCount = notMapped.get().length - typedColumns.get().length; const wrongTypeCount = notMapped.get().length - typedColumns.get().length;
return [ return [
...typedColumns.get() ...typedColumns.get()
.sort(labelsOrder)
.map((col) => menuItem( .map((col) => menuItem(
() => this._addColumn(col), () => this._addColumn(col),
col.label.peek(), col.label.peek(),

View File

@ -32,6 +32,7 @@ import {
import Popper from 'popper.js'; import Popper from 'popper.js';
import {IOpenController, popupOpen, setPopupToCreateDom} from 'popweasel'; import {IOpenController, popupOpen, setPopupToCreateDom} from 'popweasel';
import without = require('lodash/without'); import without = require('lodash/without');
import {labelsOrder} from 'app/client/models/entities/ColumnRec';
const t = makeT('PageWidgetPicker'); const t = makeT('PageWidgetPicker');
@ -407,7 +408,7 @@ export class PageWidgetSelect extends Disposable {
(use) => use(this._columns) (use) => use(this._columns)
.filter((col) => !col.isHiddenCol() && col.parentId() === use(this._value.table)), .filter((col) => !col.isHiddenCol() && col.parentId() === use(this._value.table)),
(cols) => cols ? (cols) => cols ?
dom.forEach(cols, (col) => dom.forEach([...cols].sort(labelsOrder), (col) =>
cssEntry(cssIcon('FieldColumn'), cssFieldLabel(dom.text(col.label)), cssEntry(cssIcon('FieldColumn'), cssFieldLabel(dom.text(col.label)),
dom.on('click', () => this._toggleColumnId(col.id())), dom.on('click', () => this._toggleColumnId(col.id())),
cssEntry.cls('-selected', (use) => use(this._value.columns).includes(col.id())), cssEntry.cls('-selected', (use) => use(this._value.columns).includes(col.id())),