fix(frontend): 优化账号筛选工具条布局并修复IP管理表头翻译
- 筛选组件保持固定宽度,不再自动拉伸填充 - 左右分布布局,中间自然留空 - 修复 IP 管理页面表头缺失的中文翻译
This commit is contained in:
@@ -1,8 +1,8 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="flex max-w-full flex-wrap justify-end gap-3">
|
<div class="flex flex-wrap items-center gap-3">
|
||||||
<button @click="$emit('refresh')" :disabled="loading" class="btn btn-secondary flex-shrink-0"><svg :class="['h-5 w-5', loading ? 'animate-spin' : '']" fill="none" viewBox="0 0 24 24" stroke="currentColor"><path stroke-linecap="round" stroke-linejoin="round" d="M16.023 9.348h4.992v-.001M2.985 19.644v-4.992m0 0h4.992m-4.993 0l3.181 3.183a8.25 8.25 0 0013.803-3.7M4.031 9.865a8.25 8.25 0 0113.803-3.7l3.181 3.182m0-4.991v4.99" /></svg></button>
|
<button @click="$emit('refresh')" :disabled="loading" class="btn btn-secondary"><svg :class="['h-5 w-5', loading ? 'animate-spin' : '']" fill="none" viewBox="0 0 24 24" stroke="currentColor"><path stroke-linecap="round" stroke-linejoin="round" d="M16.023 9.348h4.992v-.001M2.985 19.644v-4.992m0 0h4.992m-4.993 0l3.181 3.183a8.25 8.25 0 0013.803-3.7M4.031 9.865a8.25 8.25 0 0113.803-3.7l3.181 3.182m0-4.991v4.99" /></svg></button>
|
||||||
<button @click="$emit('sync')" class="btn btn-secondary flex-shrink-0">{{ t('admin.accounts.syncFromCrs') }}</button>
|
<button @click="$emit('sync')" class="btn btn-secondary">{{ t('admin.accounts.syncFromCrs') }}</button>
|
||||||
<button @click="$emit('create')" class="btn btn-primary flex-shrink-0">{{ t('admin.accounts.createAccount') }}</button>
|
<button @click="$emit('create')" class="btn btn-primary">{{ t('admin.accounts.createAccount') }}</button>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
|
|||||||
@@ -1,18 +1,15 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="flex flex-wrap items-start gap-3">
|
<div class="flex flex-wrap items-center gap-3">
|
||||||
<div class="min-w-0 flex-1">
|
<SearchInput
|
||||||
<SearchInput
|
:model-value="searchQuery"
|
||||||
:model-value="searchQuery"
|
:placeholder="t('admin.accounts.searchAccounts')"
|
||||||
:placeholder="t('admin.accounts.searchAccounts')"
|
class="w-64"
|
||||||
@update:model-value="$emit('update:searchQuery', $event)"
|
@update:model-value="$emit('update:searchQuery', $event)"
|
||||||
@search="$emit('change')"
|
@search="$emit('change')"
|
||||||
/>
|
/>
|
||||||
</div>
|
<Select v-model="filters.platform" class="w-40" :options="pOpts" @change="$emit('change')" />
|
||||||
<div class="flex flex-wrap items-center gap-3">
|
<Select v-model="filters.type" class="w-40" :options="tOpts" @change="$emit('change')" />
|
||||||
<Select v-model="filters.platform" class="w-40 flex-shrink-0" :options="pOpts" @change="$emit('change')" />
|
<Select v-model="filters.status" class="w-40" :options="sOpts" @change="$emit('change')" />
|
||||||
<Select v-model="filters.type" class="w-40 flex-shrink-0" :options="tOpts" @change="$emit('change')" />
|
|
||||||
<Select v-model="filters.status" class="w-40 flex-shrink-0" :options="sOpts" @change="$emit('change')" />
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
|
|||||||
@@ -1625,6 +1625,11 @@ export default {
|
|||||||
deleteConfirmMessage: "确定要删除代理 '{name}' 吗?",
|
deleteConfirmMessage: "确定要删除代理 '{name}' 吗?",
|
||||||
testProxy: '测试代理',
|
testProxy: '测试代理',
|
||||||
columns: {
|
columns: {
|
||||||
|
name: '名称',
|
||||||
|
protocol: '协议',
|
||||||
|
address: '地址',
|
||||||
|
status: '状态',
|
||||||
|
actions: '操作',
|
||||||
nameLabel: '名称',
|
nameLabel: '名称',
|
||||||
namePlaceholder: '请输入代理名称',
|
namePlaceholder: '请输入代理名称',
|
||||||
protocolLabel: '协议',
|
protocolLabel: '协议',
|
||||||
|
|||||||
@@ -3,22 +3,18 @@
|
|||||||
<TablePageLayout>
|
<TablePageLayout>
|
||||||
<template #filters>
|
<template #filters>
|
||||||
<div class="flex flex-wrap-reverse items-start justify-between gap-3">
|
<div class="flex flex-wrap-reverse items-start justify-between gap-3">
|
||||||
<div class="min-w-0 flex-1">
|
<AccountTableFilters
|
||||||
<AccountTableFilters
|
v-model:searchQuery="params.search"
|
||||||
v-model:searchQuery="params.search"
|
:filters="params"
|
||||||
:filters="params"
|
@change="reload"
|
||||||
@change="reload"
|
@update:searchQuery="debouncedReload"
|
||||||
@update:searchQuery="debouncedReload"
|
/>
|
||||||
/>
|
<AccountTableActions
|
||||||
</div>
|
:loading="loading"
|
||||||
<div class="flex-shrink-0">
|
@refresh="load"
|
||||||
<AccountTableActions
|
@sync="showSync = true"
|
||||||
:loading="loading"
|
@create="showCreate = true"
|
||||||
@refresh="load"
|
/>
|
||||||
@sync="showSync = true"
|
|
||||||
@create="showCreate = true"
|
|
||||||
/>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
<template #table>
|
<template #table>
|
||||||
|
|||||||
Reference in New Issue
Block a user