1
Fork 0
mirror of https://github.com/Steffo99/todocolors.git synced 2024-11-22 08:14:18 +00:00

Clean up some code

This commit is contained in:
Steffo 2023-08-04 02:56:04 +02:00
parent d49cdb1ae3
commit 4aff80efc8
Signed by: steffo
GPG key ID: 2A24051445686895
7 changed files with 206 additions and 87 deletions

View file

@ -28,22 +28,6 @@ export type TaskImportance =
"Low" | "Low" |
"Lowest"; "Lowest";
export const IMPORTANCE_TO_NUMBER = {
"Highest": 5,
"High": 4,
"Normal": 3,
"Low": 2,
"Lowest": 1,
}
export const IMPORTANCE_TO_STRING = {
"Highest": "Critico",
"High": "Importante",
"Normal": "Normale",
"Low": "Opzionale",
"Lowest": "Irrilevante"
}
export type TaskPriority = export type TaskPriority =
"Highest" | "Highest" |
"High" | "High" |
@ -51,22 +35,6 @@ export type TaskPriority =
"Low" | "Low" |
"Lowest"; "Lowest";
export const PRIORITY_TO_NUMBER = {
"Highest": 5,
"High": 4,
"Normal": 3,
"Low": 2,
"Lowest": 1,
}
export const PRIORITY_TO_STRING = {
"Highest": "Urgente",
"High": "Prioritario",
"Normal": "Normale",
"Low": "Rimandabile",
"Lowest": "In qualsiasi momento"
}
export type TaskStatus = export type TaskStatus =
"Unfinished" | "Unfinished" |
"InProgress" | "InProgress" |

View file

@ -0,0 +1,180 @@
import {TaskIconEl} from "@/app/board/[board]/TaskIconEl"
import {TaskIcon, TaskImportance, TaskPriority, TaskStatus, TaskWithId} from "@/app/board/[board]/Types"
import {TaskGroupTitleComponent, TaskGroupComparer, TaskGroup, TaskCategorizer} from "@/app/board/[board]/useBoardTaskArranger"
import {ReactNode} from "react"
/**
* **Function** categorizing a {@link TaskWithId} based on its {@link TaskIcon}.
* @param a The task to categorize.
*/
function categorizeTaskByIcon(a: TaskWithId): string {return a.icon}
/**
* **Function** categorizing a {@link TaskWithId} based on its {@link TaskImportance}.
* @param a The task to categorize.
*/
function categorizeTaskByImportance(a: TaskWithId): string {return a.importance}
/**
* **Function** categorizing a {@link TaskWithId} based on its {@link TaskPriority}.
* @param a The task to categorize.
*/
function categorizeTaskByPriority(a: TaskWithId): string {return a.priority}
/**
* **Function** categorizing a {@link TaskWithId} based on its {@link TaskStatus}.
* @param a The task to categorize.
*/
function categorizeTaskByStatus(a: TaskWithId): string {return a.status}
/**
* **Function** comparing {@link TaskGroup}s by their key.
* @param a The first task group to compare.
* @param b The second task group to compare.
*/
function compareGroupsByKey(a: TaskGroup, b: TaskGroup): number {return a.key.localeCompare(b.key)}
/**
* **Mapping** from {@link TaskImportance} to a {@link number}.
*/
const IMPORTANCE_TO_NUMBER = {
"Highest": 5,
"High": 4,
"Normal": 3,
"Low": 2,
"Lowest": 1,
}
/**
* **Mapping** from {@link TaskImportance} to a {@link string} to be displayed as the title of a column.
*/
const IMPORTANCE_TO_STRING = {
"Highest": "Critico",
"High": "Importante",
"Normal": "Normale",
"Low": "Opzionale",
"Lowest": "Irrilevante"
}
/**
* **Function** comparing {@link TaskGroup}s by their {@link TaskImportance}, with the greatest importance being placed at the start.
* @param a The first task group to compare.
* @param b The second task group to compare.
*/
function compareGroupsByDescendingImportance(a: TaskGroup, b: TaskGroup): number {
const aN = IMPORTANCE_TO_NUMBER[a.key as TaskImportance]
const bN = IMPORTANCE_TO_NUMBER[b.key as TaskImportance]
return bN - aN;
}
/**
* **Mapping** from {@link TaskPriority} to a {@link number}.
*/
const PRIORITY_TO_NUMBER = {
"Highest": 5,
"High": 4,
"Normal": 3,
"Low": 2,
"Lowest": 1,
}
/**
* **Mapping** from {@link TaskPriority} to a {@link string} to be displayed as the title of a column.
*/
const PRIORITY_TO_STRING = {
"Highest": "Urgente",
"High": "Prioritario",
"Normal": "Normale",
"Low": "Rimandabile",
"Lowest": "In qualsiasi momento"
}
/**
* **Function** comparing {@link TaskGroup}s by their {@link TaskPriority}, with the greatest priority being placed at the start.
* @param a The first task group to compare.
* @param b The second task group to compare.
*/
function compareGroupsByDescendingPriority(a: TaskGroup, b: TaskGroup): number {
const aN = PRIORITY_TO_NUMBER[a.key as TaskPriority]
const bN = PRIORITY_TO_NUMBER[b.key as TaskPriority]
return bN - aN;
}
/**
* **Mapping** from {@link TaskStatus} to a {@link number}.
*/
const STATUS_TO_NUMBER = {
"Unfinished": 1,
"InProgress": 2,
"Complete": 3,
}
/**
* **Mapping** from {@link TaskStatus} to a {@link string} to be displayed as the title of a column.
*/
const STATUS_TO_STRING = {
"Unfinished": "Da fare",
"InProgress": "In corso",
"Complete": "Completati",
}
/**
* **Function** comparing {@link TaskGroup}s by their {@link TaskStatus}, with the lowest progress being placed at the start.
* @param a The first task group to compare.
* @param b The second task group to compare.
*/
function compareGroupsByAscendingStatus(a: TaskGroup, b: TaskGroup): number {
const aN = STATUS_TO_NUMBER[a.key as TaskStatus]
const bN = STATUS_TO_NUMBER[b.key as TaskStatus]
return aN - bN;
}
/**
* **Component** interpreting the key of a {@link TaskGroup} as a {@link TaskIcon} and rendering it followed by its name.
* @param key The key to interpret.
* @constructor
* @todo Check accessibility status.
*/
function TaskGroupTitleFromIcon({key}: {key: string}): ReactNode {
let icon = key as TaskIcon;
return <>
<TaskIconEl icon={icon} status={"Complete"} size={"lg"}/>
&nbsp;
{key}
</>
}
/**
* **Component** interpreting the key of a {@link TaskGroup} as {@link TaskImportance} and rendering its name according to {@link IMPORTANCE_TO_STRING}.
* @param key The key to interpret.
* @constructor
*/
function TaskGroupTitleFromImportance({key}: {key: string}): ReactNode {
return IMPORTANCE_TO_STRING[key as TaskImportance];
}
/**
* **Component** interpreting the key of a {@link TaskGroup} as {@link TaskPriority} and rendering its name according to {@link PRIORITY_TO_STRING}.
* @param key The key to interpret.
* @constructor
*/
function TaskGroupTitleFromPriority({key}: {key: string}): ReactNode {
return PRIORITY_TO_STRING[key as TaskPriority];
}
/**
* **Component** interpreting the key of a {@link TaskGroup} as {@link TaskStatus} and rendering its name according to {@link STATUS_TO_STRING}.
* @param key The key to interpret.
* @constructor
*/
function TaskGroupTitleFromStatus({key}: {key: string}): ReactNode {
return STATUS_TO_STRING[key as TaskStatus];
}
export const TASK_GROUPERS: [TaskCategorizer, TaskGroupComparer, TaskGroupTitleComponent][] = [
[categorizeTaskByIcon, compareGroupsByKey, TaskGroupTitleFromIcon],
[categorizeTaskByStatus, compareGroupsByAscendingStatus, TaskGroupTitleFromStatus],
[categorizeTaskByImportance, compareGroupsByDescendingImportance, TaskGroupTitleFromImportance],
[categorizeTaskByPriority, compareGroupsByDescendingPriority, TaskGroupTitleFromPriority],
]

View file

@ -0,0 +1,14 @@
import {TaskWithId} from "@/app/board/[board]/Types"
import {TaskSortingFunction} from "@/app/board/[board]/useBoardTaskArranger"
/**
* **Function** comparing {@link Task}s by their text, following the order proposed by {@link string.localeCompare}.
* @param a The first task to compare.
* @param b The second task to compare.
*/
function compareTasksByText(a: TaskWithId, b: TaskWithId) {return a.text.localeCompare(b.text)}
export const TASK_SORTERS: TaskSortingFunction[] = [
compareTasksByText,
];

View file

@ -1,57 +1,14 @@
"use client"; "use client";
import {TaskIconEl} from "@/app/board/[board]/TaskIconEl" import {TASK_GROUPERS} from "@/app/board/[board]/doTaskGrouping"
import {BoardAction, IMPORTANCE_TO_NUMBER, IMPORTANCE_TO_STRING, PRIORITY_TO_NUMBER, PRIORITY_TO_STRING, TaskImportance, TaskPriority} from "@/app/board/[board]/Types" import {TASK_SORTERS} from "@/app/board/[board]/doTaskSorting"
import {TaskIcon, TaskWithId} from "@/app/board/[board]/Types" import {BoardAction} from "@/app/board/[board]/Types"
import {useBoardWebSocket} from "@/app/board/[board]/useBoardWebSocket" import {useBoardWebSocket} from "@/app/board/[board]/useBoardWebSocket"
import {GroupNamingFunction, GroupSortingFunction, TaskGroup, TaskGroupingFunction, TaskSortingFunction, useBoardTaskArranger} from "@/app/board/[board]/useBoardTaskArranger" import {TaskGroup, useBoardTaskArranger} from "@/app/board/[board]/useBoardTaskArranger"
import {useBoardTitleEditor} from "@/app/board/[board]/useBoardTitleEditor" import {useBoardTitleEditor} from "@/app/board/[board]/useBoardTitleEditor"
import {useCycleState} from "@/app/useCycleState" import {useCycleState} from "@/app/useCycleState"
import {Dispatch, SetStateAction} from "react" import {Dispatch, SetStateAction} from "react"
function groupTasksByIcon(a: TaskWithId) {return a.icon}
function groupTasksByImportance(a: TaskWithId) {return a.importance}
function groupTasksByPriority(a: TaskWithId) {return a.priority}
function sortGroupsByKey(a: TaskGroup, b: TaskGroup) {return a.key.localeCompare(b.key)}
function sortGroupsByImportance(a: TaskGroup, b: TaskGroup) {
const aN = IMPORTANCE_TO_NUMBER[a.key as TaskImportance]
const bN = IMPORTANCE_TO_NUMBER[b.key as TaskImportance]
return bN - aN;
}
function sortGroupsByPriority(a: TaskGroup, b: TaskGroup) {
const aN = PRIORITY_TO_NUMBER[a.key as TaskPriority]
const bN = PRIORITY_TO_NUMBER[b.key as TaskPriority]
return bN - aN;
}
function iconToTitle(a: string) {
let icon = a as TaskIcon;
return <>
<TaskIconEl icon={icon} status={"Complete"} size={"lg"}/>
&nbsp;
{a}
</>
}
function importanceToTitle(a: string) {
return IMPORTANCE_TO_STRING[a as TaskImportance];
}
function priorityToTitle(a: string) {
return PRIORITY_TO_STRING[a as TaskPriority];
}
const TASK_GROUPERS: [TaskGroupingFunction, GroupSortingFunction, GroupNamingFunction][] = [
[groupTasksByIcon, sortGroupsByKey, iconToTitle],
[groupTasksByImportance, sortGroupsByImportance, importanceToTitle],
[groupTasksByPriority, sortGroupsByPriority, priorityToTitle],
]
function sortTasksByText(a: TaskWithId, b: TaskWithId) {return a.text.localeCompare(b.text)}
const TASK_SORTERS: TaskSortingFunction[] = [
sortTasksByText,
];
export interface UseBoardReturns { export interface UseBoardReturns {
title: string, title: string,
taskGroups: TaskGroup[], taskGroups: TaskGroup[],

View file

@ -9,12 +9,12 @@ export type TaskGroup = {
tasks: TaskWithId[], tasks: TaskWithId[],
} }
export type TaskGroupingFunction = (a: TaskWithId) => string export type TaskCategorizer = (a: TaskWithId) => string
export type GroupSortingFunction = (a: TaskGroup, b: TaskGroup) => number; export type TaskGroupComparer = (a: TaskGroup, b: TaskGroup) => number;
export type GroupNamingFunction = (a: string) => ReactNode; export type TaskGroupTitleComponent = (a: {key: string}) => ReactNode;
export type TaskSortingFunction = (a: TaskWithId, b: TaskWithId) => number; export type TaskSortingFunction = (a: TaskWithId, b: TaskWithId) => number;
export function arrangeBoardTasks(tasksById: { [p: string]: Task }, taskGrouper: TaskGroupingFunction, groupSorter: GroupSortingFunction, groupNamer: GroupNamingFunction, taskSorter: TaskSortingFunction): TaskGroup[] { export function arrangeBoardTasks(tasksById: { [p: string]: Task }, taskGrouper: TaskCategorizer, groupSorter: TaskGroupComparer, groupNamer: TaskGroupTitleComponent, taskSorter: TaskSortingFunction): TaskGroup[] {
const groupsByKey: {[group: string]: TaskWithId[]} = {} const groupsByKey: {[group: string]: TaskWithId[]} = {}
for(const [id, task] of Object.entries(tasksById)) { for(const [id, task] of Object.entries(tasksById)) {
@ -33,7 +33,7 @@ export function arrangeBoardTasks(tasksById: { [p: string]: Task }, taskGrouper:
const groups: TaskGroup[] = [] const groups: TaskGroup[] = []
for(const [key, tasks] of Object.entries(groupsByKey)) { for(const [key, tasks] of Object.entries(groupsByKey)) {
const name = groupNamer(key); const name = groupNamer({key});
groups.push({key, name, tasks}) groups.push({key, name, tasks})
} }
@ -43,7 +43,7 @@ export function arrangeBoardTasks(tasksById: { [p: string]: Task }, taskGrouper:
} }
export function useBoardTaskArranger(tasksById: { [p: string]: Task }, taskGrouper: TaskGroupingFunction, groupSorter: GroupSortingFunction, groupNamer: GroupNamingFunction, taskSorter: TaskSortingFunction) { export function useBoardTaskArranger(tasksById: { [p: string]: Task }, taskGrouper: TaskCategorizer, groupSorter: TaskGroupComparer, groupNamer: TaskGroupTitleComponent, taskSorter: TaskSortingFunction) {
const taskGroups = useMemo(() => arrangeBoardTasks(tasksById, taskGrouper, groupSorter, groupNamer, taskSorter), [tasksById, taskGrouper, taskSorter, groupSorter]) const taskGroups = useMemo(() => arrangeBoardTasks(tasksById, taskGrouper, groupSorter, groupNamer, taskSorter), [tasksById, taskGrouper, taskSorter, groupSorter])
return {taskGroups}; return {taskGroups};

View file

@ -1,6 +1,6 @@
"use client"; "use client";
import {BoardAction} from "@/app/board/[board]/types" import {BoardAction} from "@/app/board/[board]/Types"
import {useCallback, useState} from "react" import {useCallback, useState} from "react"

View file

@ -1,6 +1,6 @@
'use client'; 'use client';
import {BoardAction} from "@/app/board/[board]/types" import {BoardAction} from "@/app/board/[board]/Types"
import {useBoardState} from "@/app/board/[board]/useBoardState" import {useBoardState} from "@/app/board/[board]/useBoardState"
import {useBoardWebSocketURL} from "@/app/board/[board]/useBoardWebSocketURL" import {useBoardWebSocketURL} from "@/app/board/[board]/useBoardWebSocketURL"
import {useCallback} from "react" import {useCallback} from "react"