From 7f1805172a0f7fa9c29f3f1c03adc08f2be1e0ec Mon Sep 17 00:00:00 2001 From: kunish Date: Sun, 3 Sep 2023 03:36:12 +0800 Subject: [PATCH] refactor: more refactoring --- src/App.tsx | 18 +++++------ src/components/ConnectionsModal.tsx | 37 +++++++++++++++-------- src/components/Header.tsx | 16 +++++----- src/constants.ts | 46 +++++++++++++++------------- src/pages/Connections.tsx | 47 ++++++++++++++++------------- 5 files changed, 92 insertions(+), 72 deletions(-) diff --git a/src/App.tsx b/src/App.tsx index b65513c1..467949bd 100644 --- a/src/App.tsx +++ b/src/App.tsx @@ -1,7 +1,7 @@ import { Navigate, Route, Routes, useNavigate } from '@solidjs/router' import { Show, createEffect, lazy, onMount } from 'solid-js' import { Header } from '~/components' -import { ROUTE } from '~/constants' +import { ROUTES } from '~/constants' import { curTheme, endpoint, @@ -46,14 +46,14 @@ export const App = () => {
- - - - - - - - } /> + + + + + + + + } /> diff --git a/src/components/ConnectionsModal.tsx b/src/components/ConnectionsModal.tsx index be8ed010..fbbf84f6 100644 --- a/src/components/ConnectionsModal.tsx +++ b/src/components/ConnectionsModal.tsx @@ -13,23 +13,29 @@ import { createSortable, useDragDropContext, } from '@thisbeyond/solid-dnd' -import { For, Show, createSignal } from 'solid-js' +import { Component, For, Show, createSignal } from 'solid-js' import { Button } from '~/components' -import { AccessorKey, initColumnOrder, initColumnVisibility } from '~/constants' +import { + CONNECTIONS_TABLE_ACCESSOR_KEY, + CONNECTIONS_TABLE_INITIAL_COLUMN_ORDER, + CONNECTIONS_TABLE_INITIAL_COLUMN_VISIBILITY, +} from '~/constants' -type ColumnVisibility = Partial> -type ColumnOrder = AccessorKey[] +type ColumnVisibility = Partial> +type ColumnOrder = CONNECTIONS_TABLE_ACCESSOR_KEY[] -export const ConnectionsModal = (props: { +export const ConnectionsTableOrderingModal = (props: { order: ColumnOrder visible: ColumnVisibility onOrderChange: (value: ColumnOrder) => void onVisibleChange: (value: ColumnVisibility) => void }) => { const [t] = useI18n() - const [activeKey, setActiveKey] = createSignal(null) + const [activeKey, setActiveKey] = + createSignal(null) + const onDragStart = ({ draggable }: { draggable: Draggable }) => - setActiveKey(draggable.id as AccessorKey) + setActiveKey(draggable.id as CONNECTIONS_TABLE_ACCESSOR_KEY) const onDragEnd = ({ draggable, droppable, @@ -39,8 +45,12 @@ export const ConnectionsModal = (props: { }) => { if (draggable && droppable) { const currentItems = props.order - const fromIndex = currentItems.indexOf(draggable.id as AccessorKey) - const toIndex = currentItems.indexOf(droppable.id as AccessorKey) + const fromIndex = currentItems.indexOf( + draggable.id as CONNECTIONS_TABLE_ACCESSOR_KEY, + ) + const toIndex = currentItems.indexOf( + droppable.id as CONNECTIONS_TABLE_ACCESSOR_KEY, + ) if (fromIndex !== toIndex) { const updatedItems = currentItems.slice() @@ -51,8 +61,9 @@ export const ConnectionsModal = (props: { } } - const FormRow = (p: { key: AccessorKey }) => { - const key = p.key + const FormRow: Component<{ + key: CONNECTIONS_TABLE_ACCESSOR_KEY + }> = ({ key }) => { const sortable = createSortable(key) const [state] = useDragDropContext()! @@ -109,8 +120,8 @@ export const ConnectionsModal = (props: {