adjust styles

This commit is contained in:
pompurin404 2024-08-27 09:36:49 +08:00
parent 5815076ee3
commit 1882a38aa2
No known key found for this signature in database
9 changed files with 192 additions and 169 deletions

View File

@ -101,6 +101,7 @@ async function checkProfile(): Promise<void> {
} }
export async function autoGrantCorePermition(corePath: string): Promise<void> { export async function autoGrantCorePermition(corePath: string): Promise<void> {
if (process.platform === 'win32') return
const { encryptedPassword } = await getAppConfig() const { encryptedPassword } = await getAppConfig()
const execPromise = promisify(exec) const execPromise = promisify(exec)
if (encryptedPassword && isEncryptionAvailable()) { if (encryptedPassword && isEncryptionAvailable()) {

View File

@ -15,8 +15,8 @@ const BasePage = forwardRef<HTMLDivElement, Props>((props, ref) => {
return ( return (
<div ref={contentRef} className="w-full h-full overflow-y-auto custom-scrollbar"> <div ref={contentRef} className="w-full h-full overflow-y-auto custom-scrollbar">
<div className="sticky top-0 z-40 h-[48px] w-full backdrop-blur bg-background/40"> <div className="sticky top-0 z-40 h-[49px] w-full backdrop-blur bg-background/40">
<div className="p-2 flex justify-between"> <div className="p-2 flex justify-between h-[48px]">
<div className="title h-full text-lg leading-[32px]">{props.title}</div> <div className="title h-full text-lg leading-[32px]">{props.title}</div>
<div className="header h-full">{props.header}</div> <div className="header h-full">{props.header}</div>
</div> </div>

View File

@ -7,10 +7,11 @@ const colorMap = {
info: 'primary', info: 'primary',
debug: 'default' debug: 'default'
} }
const LogItem: React.FC<IMihomoLogInfo> = (props) => { const LogItem: React.FC<IMihomoLogInfo & { index: number }> = (props) => {
const { type, payload, time } = props const { type, payload, time, index } = props
return ( return (
<Card className="m-2"> <div className={`px-2 pb-2 ${index === 0 ? 'pt-2' : ''}`}>
<Card>
<CardHeader className="pb-0 pt-1"> <CardHeader className="pb-0 pt-1">
<div className={`mr-2 text-lg font-bold text-${colorMap[type]}`}> <div className={`mr-2 text-lg font-bold text-${colorMap[type]}`}>
{props.type.toUpperCase()} {props.type.toUpperCase()}
@ -19,6 +20,7 @@ const LogItem: React.FC<IMihomoLogInfo> = (props) => {
</CardHeader> </CardHeader>
<CardBody className="pt-0 text-sm">{payload}</CardBody> <CardBody className="pt-0 text-sm">{payload}</CardBody>
</Card> </Card>
</div>
) )
} }

View File

@ -1,10 +1,11 @@
import { Card, CardBody } from '@nextui-org/react' import { Card, CardBody } from '@nextui-org/react'
import React from 'react' import React from 'react'
const RuleItem: React.FC<IMihomoRulesDetail> = (props) => { const RuleItem: React.FC<IMihomoRulesDetail & { index: number }> = (props) => {
const { type, payload, proxy } = props const { type, payload, proxy, index } = props
return ( return (
<Card className="mb-2 mx-2"> <div className={`w-full px-2 pb-2 ${index === 0 ? 'pt-2' : ''}`}>
<Card>
<CardBody className="w-full"> <CardBody className="w-full">
<div className="text-ellipsis whitespace-nowrap overflow-hidden">{payload}</div> <div className="text-ellipsis whitespace-nowrap overflow-hidden">{payload}</div>
<div className="flex justify-start text-default-500"> <div className="flex justify-start text-default-500">
@ -13,6 +14,7 @@ const RuleItem: React.FC<IMihomoRulesDetail> = (props) => {
</div> </div>
</CardBody> </CardBody>
</Card> </Card>
</div>
) )
} }

View File

@ -6,7 +6,7 @@ import {
stopMihomoConnections stopMihomoConnections
} from '@renderer/utils/ipc' } from '@renderer/utils/ipc'
import { Key, useEffect, useMemo, useState } from 'react' import { Key, useEffect, useMemo, useState } from 'react'
import { Button, Input } from '@nextui-org/react' import { Button, Divider, Input } from '@nextui-org/react'
import { IoCloseCircle } from 'react-icons/io5' import { IoCloseCircle } from 'react-icons/io5'
import { calcTraffic } from '@renderer/utils/calc' import { calcTraffic } from '@renderer/utils/calc'
import { Table, TableHeader, TableColumn, TableBody, TableRow, TableCell } from '@nextui-org/react' import { Table, TableHeader, TableColumn, TableBody, TableRow, TableCell } from '@nextui-org/react'
@ -83,7 +83,8 @@ const Connections: React.FC = () => {
connection={selectedConnection} connection={selectedConnection}
/> />
)} )}
<div className="overflow-x-auto sticky top-[49px] z-40 backdrop-blur bg-background/40 flex p-2"> <div className="overflow-x-auto sticky top-[49px] z-40">
<div className="flex p-2">
<Input <Input
variant="bordered" variant="bordered"
size="sm" size="sm"
@ -92,6 +93,8 @@ const Connections: React.FC = () => {
onValueChange={setFilter} onValueChange={setFilter}
/> />
</div> </div>
<Divider />
</div>
<Table <Table
onRowAction={(id: Key) => { onRowAction={(id: Key) => {
setSelectedConnection(connections.find((c) => c.id === (id as string))) setSelectedConnection(connections.find((c) => c.id === (id as string)))

View File

@ -2,7 +2,7 @@ import BasePage from '@renderer/components/base/base-page'
import { startMihomoLogs, stopMihomoLogs } from '@renderer/utils/ipc' import { startMihomoLogs, stopMihomoLogs } from '@renderer/utils/ipc'
import LogItem from '@renderer/components/logs/log-item' import LogItem from '@renderer/components/logs/log-item'
import { useEffect, useMemo, useRef, useState } from 'react' import { useEffect, useMemo, useRef, useState } from 'react'
import { Button, Input } from '@nextui-org/react' import { Button, Divider, Input } from '@nextui-org/react'
import { Virtuoso, VirtuosoHandle } from 'react-virtuoso' import { Virtuoso, VirtuosoHandle } from 'react-virtuoso'
const Logs: React.FC = () => { const Logs: React.FC = () => {
@ -45,8 +45,8 @@ const Logs: React.FC = () => {
return ( return (
<BasePage title="实时日志"> <BasePage title="实时日志">
<div className="sticky top-[49px] z-40 backdrop-blur bg-background/40 flex p-2"> <div className="sticky top-[49px] z-40">
<div className="w-full flex"> <div className="w-full flex p-2">
<Input <Input
variant="bordered" variant="bordered"
size="sm" size="sm"
@ -66,17 +66,19 @@ const Logs: React.FC = () => {
</Button> </Button>
</div> </div>
<Divider />
</div> </div>
<Virtuoso <Virtuoso
autoFocus autoFocus
ref={virtuosoRef} ref={virtuosoRef}
style={{ height: 'calc(100vh - 100px)' }} style={{ height: 'calc(100vh - 100px)' }}
data={filteredLogs}
totalCount={filteredLogs.length} totalCount={filteredLogs.length}
itemContent={(index) => { itemContent={(i, log) => {
const log = filteredLogs[index]
return ( return (
<LogItem <LogItem
key={log.payload + index} index={i}
key={log.payload + i}
time={log.time} time={log.time}
type={log.type} type={log.type}
payload={log.payload} payload={log.payload}

View File

@ -1,4 +1,4 @@
import { Button, Input } from '@nextui-org/react' import { Button, Divider, Input } from '@nextui-org/react'
import BasePage from '@renderer/components/base/base-page' import BasePage from '@renderer/components/base/base-page'
import { getFilePath, readTextFile } from '@renderer/utils/ipc' import { getFilePath, readTextFile } from '@renderer/utils/ipc'
import { useEffect, useRef, useState } from 'react' import { useEffect, useRef, useState } from 'react'
@ -133,7 +133,8 @@ const Override: React.FC = () => {
</> </>
} }
> >
<div className="sticky top-[48px] z-40 backdrop-blur bg-background/40 flex p-2"> <div className="sticky top-[49px] z-40 backdrop-blur bg-background/40">
<div className="flex p-2">
<Input <Input
variant="bordered" variant="bordered"
size="sm" size="sm"
@ -186,9 +187,11 @@ const Override: React.FC = () => {
</Button> </Button>
</div> </div>
<Divider />
</div>
<DndContext sensors={sensors} collisionDetection={closestCenter} onDragEnd={onDragEnd}> <DndContext sensors={sensors} collisionDetection={closestCenter} onDragEnd={onDragEnd}>
<div <div
className={`${fileOver ? 'blur-sm' : ''} grid sm:grid-cols-2 md:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4 gap-2 mx-2`} className={`${fileOver ? 'blur-sm' : ''} grid sm:grid-cols-2 md:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4 gap-2 m-2`}
> >
<SortableContext <SortableContext
items={sortedItems.map((item) => { items={sortedItems.map((item) => {

View File

@ -1,4 +1,4 @@
import { Button, Checkbox, Input } from '@nextui-org/react' import { Button, Checkbox, Divider, Input } from '@nextui-org/react'
import BasePage from '@renderer/components/base/base-page' import BasePage from '@renderer/components/base/base-page'
import ProfileItem from '@renderer/components/profiles/profile-item' import ProfileItem from '@renderer/components/profiles/profile-item'
import { useProfileConfig } from '@renderer/hooks/use-profile-config' import { useProfileConfig } from '@renderer/hooks/use-profile-config'
@ -122,7 +122,8 @@ const Profiles: React.FC = () => {
</Button> </Button>
} }
> >
<div className="sticky top-[48px] z-40 backdrop-blur bg-background/40 flex p-2"> <div className="sticky top-[49px] z-40 backdrop-blur bg-background/40">
<div className="flex p-2">
<Input <Input
variant="bordered" variant="bordered"
size="sm" size="sm"
@ -183,9 +184,11 @@ const Profiles: React.FC = () => {
</Button> </Button>
</div> </div>
<Divider />
</div>
<DndContext sensors={sensors} collisionDetection={closestCenter} onDragEnd={onDragEnd}> <DndContext sensors={sensors} collisionDetection={closestCenter} onDragEnd={onDragEnd}>
<div <div
className={`${fileOver ? 'blur-sm' : ''} grid sm:grid-cols-2 md:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4 gap-2 mx-2`} className={`${fileOver ? 'blur-sm' : ''} grid sm:grid-cols-2 md:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4 gap-2 m-2`}
> >
<SortableContext <SortableContext
items={sortedItems.map((item) => { items={sortedItems.map((item) => {

View File

@ -2,14 +2,12 @@ import BasePage from '@renderer/components/base/base-page'
import RuleItem from '@renderer/components/rules/rule-item' import RuleItem from '@renderer/components/rules/rule-item'
import { Virtuoso } from 'react-virtuoso' import { Virtuoso } from 'react-virtuoso'
import { useMemo, useState } from 'react' import { useMemo, useState } from 'react'
import { Input } from '@nextui-org/react' import { Divider, Input } from '@nextui-org/react'
import useSWR from 'swr' import useSWR from 'swr'
import { mihomoRules } from '@renderer/utils/ipc' import { mihomoRules } from '@renderer/utils/ipc'
const Rules: React.FC = () => { const Rules: React.FC = () => {
const { data: rules } = useSWR<IMihomoRulesInfo>('mihomoRules', mihomoRules, { const { data: rules } = useSWR<IMihomoRulesInfo>('mihomoRules', mihomoRules)
refreshInterval: 5000
})
const [filter, setFilter] = useState('') const [filter, setFilter] = useState('')
const filteredRules = useMemo(() => { const filteredRules = useMemo(() => {
@ -24,7 +22,8 @@ const Rules: React.FC = () => {
return ( return (
<BasePage title="分流规则"> <BasePage title="分流规则">
<div className="sticky top-[49px] z-40 backdrop-blur bg-background/40 flex p-2"> <div className="sticky top-[50px] z-40">
<div className="flex p-2">
<Input <Input
variant="bordered" variant="bordered"
size="sm" size="sm"
@ -33,11 +32,19 @@ const Rules: React.FC = () => {
onValueChange={setFilter} onValueChange={setFilter}
/> />
</div> </div>
<Divider />
</div>
<Virtuoso <Virtuoso
style={{ height: 'calc(100vh - 100px)' }} style={{ height: 'calc(100vh - 100px)', marginTop: '1px' }}
data={filteredRules} data={filteredRules}
itemContent={(_, rule) => ( itemContent={(i, rule) => (
<RuleItem type={rule.type} payload={rule.payload} proxy={rule.proxy} size={rule.size} /> <RuleItem
index={i}
type={rule.type}
payload={rule.payload}
proxy={rule.proxy}
size={rule.size}
/>
)} )}
/> />
</BasePage> </BasePage>