This repository has been archived on 2026-06-20. You can view files and clone it. You cannot open issues or pull requests or push a commit.
Files
carwash_order/style.css
T
wsh5485 e12968506a feat(预约系统): 添加日期详情弹窗功能并优化预约检查逻辑
- 在日历中添加点击日期显示详细预约信息的功能
- 实现按日期组织的预约数据查询和展示
- 添加CSS样式支持详情弹窗的显示效果
- 改进时间段检查逻辑,基于实际预约数据判断可用性
2025-11-19 01:36:45 +08:00

1091 lines
23 KiB
CSS

/* 饿了么风格的洗车预约系统样式 */
/* 变量定义 */
:root {
--el-primary-color: #409EFF;
--el-primary-hover: #66B1FF;
--el-primary-light: #A0CFFF;
--el-success-color: #67C23A;
--el-warning-color: #E6A23C;
--el-danger-color: #F56C6C;
--el-info-color: #909399;
--el-text-primary: #303133;
--el-text-regular: #606266;
--el-text-secondary: #909399;
--el-text-placeholder: #C0C4CC;
--el-border-color: #DCDFE6;
--el-border-light: #E4E7ED;
--el-border-lighter: #EBEEF5;
--el-border-extra-light: #F2F6FC;
--el-bg-color: #FFFFFF;
--el-bg-color-page: #F2F3F5;
--el-bg-color-light: #FCFCFC;
--el-shadow-base: 0 2px 4px rgba(0, 0, 0, 0.12), 0 0 6px rgba(0, 0, 0, 0.04);
--el-shadow-dark: 0 2px 4px rgba(0, 0, 0, 0.12), 0 0 6px rgba(0, 0, 0, 0.12);
--el-shadow-light: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
--el-border-radius-base: 4px;
--el-border-radius-small: 2px;
--el-border-radius-round: 20px;
--el-border-radius-circle: 100%;
--el-font-size-base: 14px;
--el-font-size-small: 13px;
--el-font-size-extra-small: 12px;
--el-font-size-large: 16px;
--el-font-size-extra-large: 18px;
--el-spacing-base: 16px;
--el-spacing-small: 8px;
--el-spacing-large: 24px;
--el-spacing-extra-large: 32px;
}
/* 全局样式 */
* {
box-sizing: border-box;
}
body {
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', 'Helvetica Neue', Helvetica, Arial, sans-serif;
line-height: 1.6;
margin: 0;
padding: 0;
background-color: var(--el-bg-color-page);
color: var(--el-text-primary);
font-size: var(--el-font-size-base);
}
.container {
max-width: 1200px;
margin: 0 auto;
padding: var(--el-spacing-large);
}
/* 头部样式 */
.header {
background: var(--el-bg-color);
box-shadow: var(--el-shadow-light);
padding: var(--el-spacing-large);
border-radius: var(--el-border-radius-base);
margin-bottom: var(--el-spacing-large);
display: flex;
justify-content: space-between;
align-items: center;
flex-wrap: wrap;
gap: var(--el-spacing-base);
}
.header h1 {
margin: 0;
font-size: var(--el-font-size-extra-large);
font-weight: 600;
color: var(--el-text-primary);
display: flex;
align-items: center;
gap: var(--el-spacing-small);
}
/* 导航样式 */
.nav {
display: flex;
gap: var(--el-spacing-small);
flex-wrap: wrap;
}
.nav-link {
display: inline-flex;
align-items: center;
padding: var(--el-spacing-small) var(--el-spacing-base);
text-decoration: none;
color: var(--el-text-regular);
border: 1px solid var(--el-border-color);
border-radius: var(--el-border-radius-base);
transition: all 0.3s ease;
font-size: var(--el-font-size-small);
background: var(--el-bg-color);
}
.nav-link:hover {
color: var(--el-primary-color);
border-color: var(--el-primary-color);
background: var(--el-primary-light);
background: rgba(64, 158, 255, 0.1);
}
.nav-link.active {
color: var(--el-primary-color);
border-color: var(--el-primary-color);
background: rgba(64, 158, 255, 0.1);
}
/* 卡片样式 */
.card {
background: var(--el-bg-color);
border-radius: var(--el-border-radius-base);
box-shadow: var(--el-shadow-light);
padding: var(--el-spacing-large);
margin-bottom: var(--el-spacing-large);
}
/* 表单样式 */
.form-group {
margin-bottom: var(--el-spacing-large);
}
.form-group label {
display: block;
margin-bottom: var(--el-spacing-small);
font-weight: 500;
color: var(--el-text-primary);
font-size: var(--el-font-size-base);
}
.form-group input,
.form-group select,
.form-group textarea {
width: 100%;
padding: 10px 12px;
border: 1px solid var(--el-border-color);
border-radius: var(--el-border-radius-base);
font-size: var(--el-font-size-base);
transition: border-color 0.3s ease;
background: var(--el-bg-color);
color: var(--el-text-primary);
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
outline: none;
border-color: var(--el-primary-color);
box-shadow: 0 0 0 2px rgba(64, 158, 255, 0.2);
}
.form-group input::placeholder,
.form-group textarea::placeholder {
color: var(--el-text-placeholder);
}
.form-row {
display: flex;
gap: var(--el-spacing-large);
flex-wrap: wrap;
}
.form-row .form-group {
flex: 1;
min-width: 200px;
}
/* 按钮样式 */
.btn {
display: inline-flex;
align-items: center;
justify-content: center;
padding: 10px 16px;
border: none;
border-radius: var(--el-border-radius-base);
font-size: var(--el-font-size-base);
font-weight: 500;
cursor: pointer;
transition: all 0.3s ease;
text-decoration: none;
white-space: nowrap;
gap: var(--el-spacing-small);
}
.btn:disabled {
opacity: 0.6;
cursor: not-allowed;
}
.btn-primary {
background-color: var(--el-primary-color);
color: white;
}
.btn-primary:hover:not(:disabled) {
background-color: var(--el-primary-hover);
transform: translateY(-1px);
box-shadow: var(--el-shadow-dark);
}
.btn-success {
background-color: var(--el-success-color);
color: white;
}
.btn-success:hover:not(:disabled) {
background-color: #85CE61;
transform: translateY(-1px);
box-shadow: var(--el-shadow-dark);
}
.btn-warning {
background-color: var(--el-warning-color);
color: white;
}
.btn-warning:hover:not(:disabled) {
background-color: #EEBE77;
transform: translateY(-1px);
box-shadow: var(--el-shadow-dark);
}
.btn-danger {
background-color: var(--el-danger-color);
color: white;
}
.btn-danger:hover:not(:disabled) {
background-color: #F78989;
transform: translateY(-1px);
box-shadow: var(--el-shadow-dark);
}
.btn-info {
background-color: var(--el-info-color);
color: white;
}
.btn-info:hover:not(:disabled) {
background-color: #B1B3B8;
transform: translateY(-1px);
box-shadow: var(--el-shadow-dark);
}
.btn-outline {
background: transparent;
color: var(--el-primary-color);
border: 1px solid var(--el-primary-color);
}
.btn-outline:hover:not(:disabled) {
background: var(--el-primary-color);
color: white;
}
.btn-sm {
padding: 6px 12px;
font-size: var(--el-font-size-small);
}
.btn-lg {
padding: 14px 20px;
font-size: var(--el-font-size-large);
}
/* 消息提示样式 */
.message {
padding: var(--el-spacing-base);
border-radius: var(--el-border-radius-base);
margin-bottom: var(--el-spacing-base);
font-size: var(--el-font-size-base);
display: flex;
align-items: center;
gap: var(--el-spacing-small);
}
.success-message {
background: rgba(103, 194, 58, 0.1);
color: var(--el-success-color);
border: 1px solid rgba(103, 194, 58, 0.2);
}
.error-message {
background: rgba(245, 108, 108, 0.1);
color: var(--el-danger-color);
border: 1px solid rgba(245, 108, 108, 0.2);
}
.warning-message {
background: rgba(230, 162, 60, 0.1);
color: var(--el-warning-color);
border: 1px solid rgba(230, 162, 60, 0.2);
}
.info-message {
background: rgba(144, 147, 153, 0.1);
color: var(--el-info-color);
border: 1px solid rgba(144, 147, 153, 0.2);
}
/* 状态标签 */
.status {
padding: 4px 8px;
border-radius: var(--el-border-radius-round);
font-size: var(--el-font-size-extra-small);
font-weight: 500;
text-transform: uppercase;
letter-spacing: 0.5px;
}
.status-pending {
background: rgba(230, 162, 60, 0.1);
color: var(--el-warning-color);
}
.status-confirmed {
background: rgba(64, 158, 255, 0.1);
color: var(--el-primary-color);
}
.status-completed {
background: rgba(103, 194, 58, 0.1);
color: var(--el-success-color);
}
.status-cancelled {
background: rgba(245, 108, 108, 0.1);
color: var(--el-danger-color);
}
/* 布局样式 */
.booking-container {
display: grid;
grid-template-columns: 1fr 1fr;
gap: var(--el-spacing-large);
margin-top: var(--el-spacing-large);
}
.section {
background: var(--el-bg-color);
border-radius: var(--el-border-radius-base);
box-shadow: var(--el-shadow-light);
padding: var(--el-spacing-large);
}
.section h2 {
margin: 0 0 var(--el-spacing-large) 0;
font-size: var(--el-font-size-large);
font-weight: 600;
color: var(--el-text-primary);
padding-bottom: var(--el-spacing-base);
border-bottom: 1px solid var(--el-border-lighter);
}
/* 日历样式 */
.calendar {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
gap: var(--el-spacing-base);
margin-bottom: var(--el-spacing-large);
}
.calendar-day {
background: var(--el-bg-color);
border: 1px solid var(--el-border-color);
border-radius: var(--el-border-radius-base);
padding: var(--el-spacing-base);
text-align: center;
cursor: pointer;
transition: all 0.3s ease;
position: relative;
}
.calendar-day:hover {
border-color: var(--el-primary-color);
box-shadow: var(--el-shadow-light);
}
.calendar-day.today {
border-color: var(--el-primary-color);
background: rgba(64, 158, 255, 0.1);
}
.calendar-day.selected {
background: var(--el-primary-color);
color: white;
border-color: var(--el-primary-color);
box-shadow: var(--el-shadow-dark);
}
.calendar-day.disabled {
background: var(--el-bg-color-page);
color: var(--el-text-placeholder);
cursor: not-allowed;
}
.day-number {
font-size: var(--el-font-size-large);
font-weight: 600;
margin-bottom: var(--el-spacing-small);
}
.day-week {
font-size: var(--el-font-size-small);
color: var(--el-text-secondary);
margin-bottom: var(--el-spacing-small);
}
.day-status {
font-size: var(--el-font-size-extra-small);
color: var(--el-text-secondary);
}
/* 时间段选择 */
.time-slots {
margin-top: var(--el-spacing-large);
}
.quick-duration {
display: flex;
align-items: center;
gap: var(--el-spacing-base);
margin-bottom: var(--el-spacing-large);
flex-wrap: wrap;
}
.quick-duration span {
font-weight: 500;
color: var(--el-text-primary);
white-space: nowrap;
}
.duration-btn {
padding: var(--el-spacing-small) var(--el-spacing-base);
border: 1px solid var(--el-border-color);
background: var(--el-bg-color);
color: var(--el-text-regular);
border-radius: var(--el-border-radius-base);
cursor: pointer;
transition: all 0.3s ease;
font-size: var(--el-font-size-small);
white-space: nowrap;
}
.duration-btn:hover {
border-color: var(--el-primary-color);
color: var(--el-primary-color);
}
.duration-btn.selected {
background: var(--el-primary-color);
color: white;
border-color: var(--el-primary-color);
}
.time-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(80px, 1fr));
gap: var(--el-spacing-base);
}
.time-slot {
padding: var(--el-spacing-base);
text-align: center;
border: 1px solid var(--el-border-color);
border-radius: var(--el-border-radius-base);
cursor: pointer;
transition: all 0.3s ease;
font-size: var(--el-font-size-small);
font-weight: 500;
background: var(--el-bg-color);
color: var(--el-text-primary);
}
.time-slot:hover {
border-color: var(--el-primary-color);
color: var(--el-primary-color);
}
.time-slot.selected {
background: var(--el-primary-color);
color: white;
border-color: var(--el-primary-color);
}
.time-slot.booked {
background: var(--el-bg-color-page);
color: var(--el-text-placeholder);
cursor: not-allowed;
text-decoration: line-through;
}
.time-slot.past {
background: var(--el-bg-color-page);
color: var(--el-text-placeholder);
cursor: not-allowed;
}
/* 套餐信息 */
.package-info {
background: var(--el-bg-color-page);
border: 1px solid var(--el-border-light);
border-radius: var(--el-border-radius-base);
padding: var(--el-spacing-large);
margin-top: var(--el-spacing-large);
}
.package-details h4 {
margin: 0 0 var(--el-spacing-small) 0;
color: var(--el-text-primary);
font-size: var(--el-font-size-base);
}
.package-details p {
margin: 0 0 var(--el-spacing-base) 0;
color: var(--el-text-regular);
font-size: var(--el-font-size-small);
line-height: 1.5;
}
.package-meta {
display: flex;
gap: var(--el-spacing-small);
margin-bottom: var(--el-spacing-base);
flex-wrap: wrap;
}
.package-meta span {
background: var(--el-primary-light);
background: rgba(64, 158, 255, 0.1);
color: var(--el-primary-color);
padding: 4px 8px;
border-radius: var(--el-border-radius-round);
font-size: var(--el-font-size-extra-small);
font-weight: 500;
}
/* 服务项目标签 */
.services-container {
display: flex;
flex-direction: column;
gap: var(--el-spacing-small);
}
.service-item {
display: flex;
gap: var(--el-spacing-small);
align-items: center;
}
.service-item input {
flex: 1;
}
.btn-add,
.btn-remove {
padding: var(--el-spacing-small);
border: 1px dashed var(--el-border-color);
background: var(--el-bg-color);
color: var(--el-primary-color);
border-radius: var(--el-border-radius-base);
cursor: pointer;
font-size: var(--el-font-size-small);
transition: all 0.3s ease;
}
.btn-add:hover,
.btn-remove:hover {
border-color: var(--el-primary-color);
background: var(--el-primary-light);
background: rgba(64, 158, 255, 0.1);
}
/* 模态框 */
.modal {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: rgba(0, 0, 0, 0.5);
z-index: 2000;
display: flex;
align-items: center;
justify-content: center;
padding: var(--el-spacing-large);
}
.modal-content {
background: var(--el-bg-color);
border-radius: var(--el-border-radius-base);
max-width: 500px;
width: 100%;
max-height: 80vh;
overflow-y: auto;
box-shadow: var(--el-shadow-dark);
}
.modal-header {
display: flex;
justify-content: space-between;
align-items: center;
padding: var(--el-spacing-large);
border-bottom: 1px solid var(--el-border-lighter);
}
.modal-header h3 {
margin: 0;
color: var(--el-text-primary);
font-size: var(--el-font-size-large);
}
.close {
font-size: var(--el-font-size-extra-large);
cursor: pointer;
color: var(--el-text-secondary);
transition: color 0.3s ease;
width: 24px;
height: 24px;
display: flex;
align-items: center;
justify-content: center;
}
.close:hover {
color: var(--el-text-primary);
}
.modal-body {
padding: var(--el-spacing-large);
}
.booking-detail-item {
background: var(--el-bg-color-light);
border: 1px solid var(--el-border-lighter);
border-radius: var(--el-border-radius-base);
padding: var(--el-spacing-base);
margin-bottom: var(--el-spacing-base);
}
.booking-time {
font-weight: 600;
color: var(--el-text-primary);
margin-bottom: var(--el-spacing-small);
font-size: var(--el-font-size-medium);
}
.booking-info {
color: var(--el-text-regular);
font-size: var(--el-font-size-base);
line-height: 1.5;
}
.status-已确认 {
color: var(--el-color-success);
}
.status-进行中 {
color: var(--el-color-warning);
}
.status-已完成 {
color: var(--el-color-info);
}
.status-已取消 {
color: var(--el-color-danger);
}
/* 表格样式 */
.table {
width: 100%;
border-collapse: collapse;
margin-top: var(--el-spacing-large);
}
.table th,
.table td {
padding: var(--el-spacing-base);
text-align: left;
border-bottom: 1px solid var(--el-border-lighter);
}
.table th {
background: var(--el-bg-color-page);
color: var(--el-text-primary);
font-weight: 600;
}
.table tr:hover {
background: var(--el-bg-color-light);
}
/* 空状态 */
.empty-message {
text-align: center;
padding: var(--el-spacing-extra-large);
color: var(--el-text-secondary);
font-size: var(--el-font-size-base);
}
/* 响应式设计 */
/* 平板设备 */
@media (max-width: 768px) {
:root {
--el-spacing-base: 12px;
--el-spacing-large: 16px;
--el-spacing-extra-large: 24px;
}
.container {
padding: var(--el-spacing-base);
}
.booking-container {
grid-template-columns: 1fr;
gap: var(--el-spacing-base);
}
.header {
flex-direction: column;
align-items: stretch;
text-align: center;
}
.nav {
justify-content: center;
}
.form-row {
flex-direction: column;
gap: var(--el-spacing-base);
}
.form-row .form-group {
flex: none;
}
.calendar {
grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
gap: var(--el-spacing-small);
}
.quick-duration {
justify-content: center;
flex-wrap: wrap;
}
.time-grid {
grid-template-columns: repeat(auto-fit, minmax(70px, 1fr));
gap: var(--el-spacing-small);
}
.package-meta {
justify-content: center;
}
}
/* 手机设备 */
@media (max-width: 480px) {
.container {
padding: var(--el-spacing-small);
}
.header {
padding: var(--el-spacing-base);
border-radius: 0;
margin-bottom: var(--el-spacing-base);
}
.header h1 {
font-size: var(--el-font-size-large);
}
.section {
padding: var(--el-spacing-base);
border-radius: 0;
box-shadow: none;
border-bottom: 1px solid var(--el-border-lighter);
}
.calendar {
grid-template-columns: repeat(2, 1fr);
}
.calendar-day {
padding: var(--el-spacing-small);
}
.day-number {
font-size: var(--el-font-size-base);
}
.nav {
flex-direction: column;
gap: var(--el-spacing-small);
}
.nav-link {
text-align: center;
justify-content: center;
}
.form-actions {
flex-direction: column;
gap: var(--el-spacing-small);
}
.btn {
width: 100%;
justify-content: center;
}
.package-meta {
flex-direction: column;
align-items: stretch;
}
.modal {
padding: var(--el-spacing-small);
}
.modal-content {
margin: 0;
max-height: calc(100vh - 20px);
}
}
/* 小屏幕手机 */
@media (max-width: 360px) {
.calendar {
grid-template-columns: 1fr;
}
.time-grid {
grid-template-columns: repeat(2, 1fr);
}
.quick-duration {
flex-direction: column;
align-items: stretch;
}
.form-group input,
.form-group select,
.form-group textarea {
font-size: 16px; /* 防止iOS缩放 */
}
}
/* 触摸设备优化 */
@media (hover: none) and (pointer: coarse) {
.btn {
min-height: 44px;
}
.form-group input,
.form-group select,
.form-group textarea {
min-height: 44px;
}
.nav-link {
min-height: 44px;
}
}
/* 加载状态 */
.loading {
opacity: 0.6;
pointer-events: none;
}
.loading::after {
content: '';
position: absolute;
top: 50%;
left: 50%;
width: 20px;
height: 20px;
margin: -10px 0 0 -10px;
border: 2px solid var(--el-border-color);
border-top: 2px solid var(--el-primary-color);
border-radius: 50%;
animation: spin 1s linear infinite;
}
@keyframes spin {
0% { transform: rotate(0deg); }
100% { transform: rotate(360deg); }
}
/* 动画效果 */
.fade-in {
animation: fadeIn 0.3s ease-in;
}
@keyframes fadeIn {
from { opacity: 0; transform: translateY(10px); }
to { opacity: 1; transform: translateY(0); }
}
.slide-in {
animation: slideIn 0.3s ease-out;
}
@keyframes slideIn {
from { transform: translateX(-100%); }
to { transform: translateX(0); }
}
/* 表单操作区域 */
.form-actions {
display: flex;
gap: var(--el-spacing-base);
margin-top: var(--el-spacing-large);
justify-content: flex-end;
flex-wrap: wrap;
}
.form-actions .btn {
flex: none;
}
/* 套餐卡片样式 */
.package-card {
border: 1px solid var(--el-border-lighter);
border-radius: var(--el-border-radius-base);
padding: var(--el-spacing-large);
margin-bottom: var(--el-spacing-base);
background: var(--el-bg-color);
transition: all 0.3s ease;
position: relative;
}
.package-card:hover {
box-shadow: var(--el-shadow-light);
border-color: var(--el-primary-light);
}
.package-card.inactive {
opacity: 0.7;
background: var(--el-bg-color-page);
}
.package-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: var(--el-spacing-base);
}
.package-header h3 {
margin: 0;
color: var(--el-text-primary);
font-size: var(--el-font-size-base);
}
.package-status {
display: flex;
align-items: center;
}
.status-badge {
padding: 4px 8px;
border-radius: var(--el-border-radius-round);
font-size: var(--el-font-size-extra-small);
font-weight: 500;
}
.status-badge.active {
background: rgba(103, 194, 58, 0.1);
color: var(--el-success-color);
}
.status-badge.inactive {
background: rgba(144, 147, 153, 0.1);
color: var(--el-info-color);
}
.package-description {
color: var(--el-text-regular);
margin-bottom: var(--el-spacing-base);
line-height: 1.5;
}
.package-details {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
gap: var(--el-spacing-base);
margin-bottom: var(--el-spacing-base);
}
.detail-item {
display: flex;
flex-direction: column;
gap: var(--el-spacing-small);
}
.detail-label {
font-size: var(--el-font-size-extra-small);
color: var(--el-text-secondary);
text-transform: uppercase;
letter-spacing: 0.5px;
}
.detail-value {
font-weight: 500;
color: var(--el-text-primary);
}
.package-services {
margin-bottom: var(--el-spacing-base);
}
.services-tags {
display: flex;
flex-wrap: wrap;
gap: var(--el-spacing-small);
margin-top: var(--el-spacing-small);
}
.service-tag {
background: var(--el-primary-light);
background: rgba(64, 158, 255, 0.1);
color: var(--el-primary-color);
padding: 4px 8px;
border-radius: var(--el-border-radius-small);
font-size: var(--el-font-size-extra-small);
font-weight: 500;
}
.package-actions {
display: flex;
gap: var(--el-spacing-small);
justify-content: flex-end;
flex-wrap: wrap;
}
.edit-form {
margin-top: var(--el-spacing-large);
padding-top: var(--el-spacing-large);
border-top: 1px solid var(--el-border-lighter);
}
/* 复选框样式 */
input[type="checkbox"] {
width: auto;
margin-right: var(--el-spacing-small);
}
/* 标签样式 */
label {
cursor: pointer;
}
/* 滚动条样式 */
::-webkit-scrollbar {
width: 6px;
}
::-webkit-scrollbar-track {
background: var(--el-bg-color-page);
}
::-webkit-scrollbar-thumb {
background: var(--el-border-color);
border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover {
background: var(--el-text-secondary);
}