chore(admin-ui): tokenise sidebar hover and focus ring with primary tokens
This commit is contained in:
@@ -25,7 +25,7 @@ a:hover{text-decoration:underline;}
|
|||||||
.sidebar:not(.topnav) a:hover,
|
.sidebar:not(.topnav) a:hover,
|
||||||
.sidebar:not(.topnav) .sidebar-link:hover{
|
.sidebar:not(.topnav) .sidebar-link:hover{
|
||||||
text-decoration:none;
|
text-decoration:none;
|
||||||
background:rgba(22, 119, 255, .08);
|
background:var(--adm-primary-tint-08, rgba(22, 119, 255, .08));
|
||||||
color:var(--adm-text, #0f172a);
|
color:var(--adm-text, #0f172a);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -123,7 +123,7 @@ input:hover,select:hover,textarea:hover{
|
|||||||
input:focus,select:focus,textarea:focus{
|
input:focus,select:focus,textarea:focus{
|
||||||
outline:none;
|
outline:none;
|
||||||
border-color:var(--adm-color-primary, #1677ff);
|
border-color:var(--adm-color-primary, #1677ff);
|
||||||
box-shadow:0 0 0 3px rgba(22, 119, 255, .12);
|
box-shadow:0 0 0 3px var(--adm-primary-focus-ring, rgba(22, 119, 255, .12));
|
||||||
}
|
}
|
||||||
|
|
||||||
button{cursor:pointer;}
|
button{cursor:pointer;}
|
||||||
|
|||||||
@@ -50,6 +50,7 @@
|
|||||||
--adm-primary-tint-08: rgba(22, 119, 255, .08);
|
--adm-primary-tint-08: rgba(22, 119, 255, .08);
|
||||||
--adm-primary-border-35: rgba(22, 119, 255, .35);
|
--adm-primary-border-35: rgba(22, 119, 255, .35);
|
||||||
--adm-primary-border-45: rgba(22, 119, 255, .45);
|
--adm-primary-border-45: rgba(22, 119, 255, .45);
|
||||||
|
--adm-primary-focus-ring: rgba(22, 119, 255, .12);
|
||||||
|
|
||||||
/* 状态色(接近 Ant Design) */
|
/* 状态色(接近 Ant Design) */
|
||||||
--adm-success: #16a34a;
|
--adm-success: #16a34a;
|
||||||
|
|||||||
@@ -0,0 +1,36 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Tests\Feature;
|
||||||
|
|
||||||
|
use Illuminate\Foundation\Testing\RefreshDatabase;
|
||||||
|
use Tests\TestCase;
|
||||||
|
|
||||||
|
class AdminBaseCssSidebarHoverAndInputFocusShouldUsePrimaryTokensTest extends TestCase
|
||||||
|
{
|
||||||
|
use RefreshDatabase;
|
||||||
|
|
||||||
|
protected function loginAsPlatformAdmin(): void
|
||||||
|
{
|
||||||
|
$this->seed();
|
||||||
|
|
||||||
|
$this->post('/admin/login', [
|
||||||
|
'email' => 'platform.admin@demo.local',
|
||||||
|
'password' => 'Platform@123456',
|
||||||
|
])->assertRedirect('/admin');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function test_admin_base_css_sidebar_hover_and_input_focus_should_use_primary_tokens(): void
|
||||||
|
{
|
||||||
|
$this->loginAsPlatformAdmin();
|
||||||
|
|
||||||
|
$css = file_get_contents(public_path('css/admin-base.css'));
|
||||||
|
$this->assertIsString($css);
|
||||||
|
|
||||||
|
// 左侧菜单 hover 高亮必须走 primary tint token。
|
||||||
|
$this->assertStringContainsString('.sidebar:not(.topnav) a:hover', $css);
|
||||||
|
$this->assertStringContainsString('background:var(--adm-primary-tint-08', $css);
|
||||||
|
|
||||||
|
// input focus ring 必须走 focus-ring token。
|
||||||
|
$this->assertStringContainsString('box-shadow:0 0 0 3px var(--adm-primary-focus-ring', $css);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,31 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Tests\Feature;
|
||||||
|
|
||||||
|
use Illuminate\Foundation\Testing\RefreshDatabase;
|
||||||
|
use Tests\TestCase;
|
||||||
|
|
||||||
|
class AdminThemeCssShouldDefinePrimaryFocusRingTokenTest extends TestCase
|
||||||
|
{
|
||||||
|
use RefreshDatabase;
|
||||||
|
|
||||||
|
protected function loginAsPlatformAdmin(): void
|
||||||
|
{
|
||||||
|
$this->seed();
|
||||||
|
|
||||||
|
$this->post('/admin/login', [
|
||||||
|
'email' => 'platform.admin@demo.local',
|
||||||
|
'password' => 'Platform@123456',
|
||||||
|
])->assertRedirect('/admin');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function test_admin_theme_css_should_define_primary_focus_ring_token(): void
|
||||||
|
{
|
||||||
|
$this->loginAsPlatformAdmin();
|
||||||
|
|
||||||
|
$css = file_get_contents(public_path('css/admin-theme.css'));
|
||||||
|
$this->assertIsString($css);
|
||||||
|
|
||||||
|
$this->assertStringContainsString('--adm-primary-focus-ring', $css);
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user