| | |
| | | <view class="bg-img"> |
| | | <view class="hero-content"> |
| | | <text class="hero-title">产品库存管理系统</text> |
| | | <text class="hero-subtitle">高效、便捷的业务管理入口</text> |
| | | </view> |
| | | <view class="hero-wave"></view> |
| | | </view> |
| | | </view> |
| | | |
| | |
| | | const factoryList = ref([]); |
| | | const factoryListTem = ref([]); |
| | | const iconStyle = { |
| | | fontSize: '18px', |
| | | fontSize: '1.125rem', |
| | | color: '#2979ff' |
| | | } |
| | | |
| | |
| | | .content { |
| | | background: linear-gradient(135deg, #f8f9fa 0%, #e3f2fd 100%); |
| | | min-height: 100vh; |
| | | padding: 20px; |
| | | padding: 1.25rem; |
| | | padding-top: env(safe-area-inset-top); |
| | | position: relative; |
| | | |
| | |
| | | /* 本页不再定义 .safe-area-top,已移至全局样式 */ |
| | | |
| | | .header-section { |
| | | margin-bottom: 16px; |
| | | margin-bottom: 1rem; |
| | | animation: fadeInDown 0.6s ease-out; |
| | | } |
| | | |
| | | .currentFactory { |
| | | margin-top: 8px; |
| | | margin-left: 4px; |
| | | margin-top: 0.5rem; |
| | | margin-left: 0.25rem; |
| | | font-weight: 500; |
| | | display: flex; |
| | | } |
| | |
| | | } |
| | | |
| | | .hero-section { |
| | | margin-bottom: 16px; |
| | | margin-bottom: 1rem; |
| | | animation: fadeInUp 0.6s ease-out 0.1s both; |
| | | } |
| | | |
| | | .bg-img { |
| | | width: 100%; |
| | | height: 120px; |
| | | height: 8.75rem; |
| | | background: linear-gradient(135deg, #2979ff 0%, #1565c0 100%); |
| | | border-radius: 12px; |
| | | border-radius: 0.75rem; |
| | | position: relative; |
| | | overflow: hidden; |
| | | box-shadow: 0 4px 20px rgba(41, 121, 255, 0.15); |
| | | box-shadow: 0 0.25rem 1.25rem rgba(41, 121, 255, 0.15); |
| | | |
| | | &::before { |
| | | content: ''; |
| | |
| | | position: absolute; |
| | | top: 0; |
| | | right: 0; |
| | | width: 120px; |
| | | height: 120px; |
| | | width: 7.5rem; |
| | | height: 7.5rem; |
| | | background: radial-gradient(circle, rgba(255,255,255,0.15) 0%, transparent 70%); |
| | | border-radius: 50%; |
| | | transform: translate(40px, -40px); |
| | | transform: translate(2.5rem, -2.5rem); |
| | | } |
| | | } |
| | | |
| | | .hero-content { |
| | | position: relative; |
| | | z-index: 1; |
| | | padding: 20px; |
| | | padding: 1.25rem; |
| | | height: 100%; |
| | | display: flex; |
| | | align-items: center; |
| | | flex-direction: column; |
| | | align-items: flex-start; |
| | | justify-content: center; |
| | | } |
| | | |
| | | .hero-title { |
| | | color: #ffffff; |
| | | font-size: 24px; |
| | | font-weight: 600; |
| | | font-size: 1.625rem; |
| | | font-weight: 700; |
| | | letter-spacing: 0.03125rem; |
| | | } |
| | | .hero-subtitle { font-size: 0.8125rem; margin-top: 0.375rem; } |
| | | .hero-wave { height: 2.75rem; } |
| | | |
| | | .hero-subtitle { |
| | | color: rgba(255, 255, 255, 0.9); |
| | | font-size: 0.8125rem; |
| | | margin-top: 0.375rem; |
| | | font-weight: 400; |
| | | } |
| | | |
| | | .hero-wave { |
| | | position: absolute; |
| | | left: 0; |
| | | right: 0; |
| | | bottom: 0; |
| | | height: 2.75rem; |
| | | background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 320' preserveAspectRatio='none'><path fill='%23ffffff' fill-opacity='0.2' d='M0,224L48,218.7C96,213,192,203,288,197.3C384,192,480,192,576,176C672,160,768,128,864,122.7C960,117,1056,139,1152,144C1248,149,1344,139,1392,133.3L1440,128L1440,320L1392,320C1344,320,1248,320,1152,320C1056,320,960,320,864,320C768,320,672,320,576,320C480,320,384,320,288,320C192,320,96,320,48,320L0,320Z'></path></svg>") no-repeat bottom center/cover; |
| | | pointer-events: none; |
| | | } |
| | | |
| | | |
| | | |
| | | .notice-section { |
| | | margin-bottom: 16px; |
| | | margin-bottom: 1rem; |
| | | animation: fadeInUp 0.6s ease-out 0.2s both; |
| | | } |
| | | |
| | | .notice { |
| | | width: 100%; |
| | | background: linear-gradient(135deg, #EAF2FF 0%, #BBDEFB 100%); |
| | | border: 1px solid #e3f2fd; |
| | | border-radius: 12px; |
| | | padding: 16px; |
| | | box-shadow: 0 4px 20px rgba(41, 121, 255, 0.08); |
| | | border: 0.0625rem solid #e3f2fd; |
| | | border-radius: 0.75rem; |
| | | padding: 1rem; |
| | | box-shadow: 0 0.25rem 1.25rem rgba(41, 121, 255, 0.08); |
| | | position: relative; |
| | | overflow: hidden; |
| | | |
| | |
| | | position: absolute; |
| | | top: 0; |
| | | right: 0; |
| | | width: 80px; |
| | | height: 80px; |
| | | width: 5rem; |
| | | height: 5rem; |
| | | background: radial-gradient(circle, rgba(255,255,255,0.2) 0%, transparent 70%); |
| | | border-radius: 50%; |
| | | transform: translate(30px, -30px); |
| | | transform: translate(1.875rem, -1.875rem); |
| | | } |
| | | |
| | | &:hover { |
| | | transform: translateY(-0.125rem); |
| | | box-shadow: 0 0.5rem 1.875rem rgba(0, 0, 0, 0.1); |
| | | } |
| | | } |
| | | |
| | |
| | | @keyframes fadeInDown { |
| | | from { |
| | | opacity: 0; |
| | | transform: translateY(-20px); |
| | | transform: translateY(-1.25rem); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | |
| | | @keyframes fadeInUp { |
| | | from { |
| | | opacity: 0; |
| | | transform: translateY(20px); |
| | | transform: translateY(1.25rem); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | |
| | | } |
| | | } |
| | | |
| | | @keyframes rotate { |
| | | from { |
| | | transform: rotate(0deg); |
| | | } |
| | | to { |
| | | transform: rotate(360deg); |
| | | } |
| | | @keyframes fadeInScale { |
| | | 0% { opacity: 0; transform: translateY(0.5rem) scale(0.96); } |
| | | 100% { opacity: 1; transform: translateY(0) scale(1); } |
| | | } |
| | | |
| | | .notice-content { |
| | |
| | | } |
| | | |
| | | .notice-left { |
| | | margin-right: 16px; |
| | | margin-right: 1rem; |
| | | } |
| | | |
| | | .notice-status { |
| | | font-weight: 600; |
| | | font-size: 16px; |
| | | font-size: 1rem; |
| | | color: #1976d2; |
| | | } |
| | | |
| | | .notice-separator { |
| | | width: 1px; |
| | | height: 24px; |
| | | width: 0.0625rem; |
| | | height: 1.5rem; |
| | | background: #e0e0e0; |
| | | margin-right: 16px; |
| | | margin-right: 1rem; |
| | | } |
| | | |
| | | .notice-right { |
| | |
| | | |
| | | .notice-label { |
| | | color: #333; |
| | | font-size: 14px; |
| | | font-size: 0.875rem; |
| | | font-weight: 500; |
| | | margin-right: 12px; |
| | | margin-right: 0.75rem; |
| | | } |
| | | |
| | | .notice-text { |
| | | font-weight: 400; |
| | | font-size: 14px; |
| | | font-size: 0.875rem; |
| | | color: #666666; |
| | | } |
| | | |
| | | .notice-number { |
| | | font-weight: 600; |
| | | font-size: 16px; |
| | | font-size: 1rem; |
| | | color: #1976d2; |
| | | margin-left: 4px; |
| | | margin-left: 0.25rem; |
| | | } |
| | | |
| | | .notice-unit { |
| | | color: #666666; |
| | | font-size: 14px; |
| | | margin-left: 2px; |
| | | font-size: 0.875rem; |
| | | margin-left: 0.125rem; |
| | | } |
| | | |
| | | /* 功能模块样式 */ |
| | | .common-module { |
| | | margin-bottom: 24px; |
| | | margin-bottom: 1.5rem; |
| | | background: linear-gradient(135deg, #ffffff 0%, #fafbfc 100%); |
| | | border-radius: 16px; |
| | | padding: 16px; |
| | | box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06); |
| | | border-radius: 1rem; |
| | | padding: 1rem; |
| | | box-shadow: 0 0.25rem 1.25rem rgba(0, 0, 0, 0.06); |
| | | border: none; |
| | | position: relative; |
| | | overflow: hidden; |
| | |
| | | position: absolute; |
| | | top: 0; |
| | | right: 0; |
| | | width: 60px; |
| | | height: 60px; |
| | | width: 3.75rem; |
| | | height: 3.75rem; |
| | | background: radial-gradient(circle, rgba(0,0,0,0.02) 0%, transparent 70%); |
| | | border-radius: 50%; |
| | | transform: translate(30px, -30px); |
| | | } |
| | | |
| | | &:hover { |
| | | transform: translateY(-2px); |
| | | box-shadow: 0 8px 30px rgba(0, 0, 0, 0.1); |
| | | |
| | | &::after { |
| | | background: radial-gradient(circle, rgba(0,0,0,0.04) 0%, transparent 70%); |
| | | } |
| | | transform: translate(1.875rem, -1.875rem); |
| | | } |
| | | } |
| | | |
| | |
| | | } |
| | | |
| | | .module-header { |
| | | margin-bottom: 24px; |
| | | margin-bottom: 1.5rem; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: space-between; |
| | |
| | | |
| | | .module-title { |
| | | color: #333333; |
| | | font-size: 18px; |
| | | font-size: 1.125rem; |
| | | font-weight: 600; |
| | | position: relative; |
| | | |
| | | &::after { |
| | | content: ''; |
| | | position: absolute; |
| | | bottom: -4px; |
| | | left: 0; |
| | | width: 100%; |
| | | height: 2px; |
| | | background: linear-gradient(90deg, var(--module-color), rgba(255,255,255,0.9)); |
| | | border-radius: 1px; |
| | | transition: all 0.3s ease; |
| | | box-shadow: 0 0 8px rgba(0,0,0,0.1); |
| | | } |
| | | |
| | | &:hover::after { |
| | | width: 30px; |
| | | box-shadow: 0 0 12px rgba(0,0,0,0.15); |
| | | } |
| | | } |
| | | |
| | | .module-subtitle { |
| | | color: #666666; |
| | | font-size: 12px; |
| | | font-size: 0.75rem; |
| | | font-weight: 400; |
| | | margin-left: 8px; |
| | | margin-left: 0.5rem; |
| | | } |
| | | |
| | | .module-content { |
| | | width: 100%; |
| | | display: grid; |
| | | gap: 16px; |
| | | gap: 1rem; |
| | | } |
| | | |
| | | .icon-container { |
| | | width: 52px; |
| | | height: 52px; |
| | | border-radius: 12px; |
| | | width: 3.25rem; |
| | | height: 3.25rem; |
| | | border-radius: 0.75rem; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: center; |
| | | margin-bottom: 6px; |
| | | box-shadow: 0 3px 12px rgba(0, 0, 0, 0.12); |
| | | transition: all 0.3s ease; |
| | | margin-bottom: 0.375rem; |
| | | box-shadow: 0 0.1875rem 0.75rem rgba(0, 0, 0, 0.12); |
| | | transition: all 0.2s ease; |
| | | position: relative; |
| | | overflow: hidden; |
| | | animation: fadeInScale 0.5s ease both; |
| | | |
| | | &::before { |
| | | content: ''; |
| | |
| | | left: 0; |
| | | right: 0; |
| | | bottom: 0; |
| | | border-radius: 12px; |
| | | border-radius: 0.75rem; |
| | | background: linear-gradient(45deg, transparent, rgba(255,255,255,0.2), transparent); |
| | | opacity: 0; |
| | | transition: opacity 0.3s ease; |
| | | } |
| | | |
| | | &:hover { |
| | | transform: translateY(-3px) scale(1.02); |
| | | box-shadow: 0 8px 25px rgba(0, 0, 0, 0.18); |
| | | transform: translateY(-0.1875rem) scale(1.02); |
| | | box-shadow: 0 0.5rem 1.5625rem rgba(0, 0, 0, 0.18); |
| | | |
| | | &::before, |
| | | &::after { |
| | | opacity: 1; |
| | | } |
| | | } |
| | | |
| | | &:active { |
| | | transform: scale(0.97); |
| | | box-shadow: 0 0.125rem 0.5rem rgba(0, 0, 0, 0.18); |
| | | } |
| | | } |
| | | |
| | | .item-label { |
| | | font-size: 13px; |
| | | font-size: 0.8125rem; |
| | | color: #555555; |
| | | text-align: center; |
| | | display: block; |
| | | line-height: 1.4; |
| | | font-weight: 500; |
| | | margin-top: 4px; |
| | | margin-bottom: 10px; |
| | | margin-top: 0.25rem; |
| | | margin-bottom: 0.625rem; |
| | | } |
| | | |
| | | .grid-text { |
| | | font-size: 14px; |
| | | font-size: 0.875rem; |
| | | color: #909399; |
| | | padding: 10rpx 0 20rpx 0rpx; |
| | | padding: 0.625rem 0 1.25rem 0; |
| | | /* #ifndef APP-PLUS */ |
| | | box-sizing: border-box; |
| | | /* #endif */ |
| | | } |
| | | |
| | | /* 暗色模式适配 */ |
| | | @media (prefers-color-scheme: dark) { |
| | | .content { |
| | | background: linear-gradient(135deg, #121317 0%, #161a20 100%); |
| | | } |
| | | .content::before { |
| | | background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="dots" width="20" height="20" patternUnits="userSpaceOnUse"><circle cx="10" cy="10" r="1" fill="rgba(255, 255, 255, 0.05)"/></pattern></defs><rect width="100" height="100" fill="url(%23dots)"/></svg>'); |
| | | } |
| | | .common-module { |
| | | background: linear-gradient(135deg, #1e1f24 0%, #23252b 100%); |
| | | box-shadow: 0 0.375rem 1.5rem rgba(0,0,0,0.35); |
| | | } |
| | | .module-title { |
| | | color: #e9edf3; |
| | | } |
| | | .module-subtitle, .item-label, .notice-text, .notice-unit, .notice-label { |
| | | color: #c7cbd3; |
| | | } |
| | | .notice { |
| | | background: linear-gradient(135deg, #1b2330 0%, #1a2432 100%); |
| | | border-color: rgba(255,255,255,0.06); |
| | | box-shadow: 0 0.375rem 1.25rem rgba(0,0,0,0.4); |
| | | } |
| | | .notice-status, .notice-number { |
| | | color: #8ab4ff; |
| | | } |
| | | .bg-img { |
| | | background: linear-gradient(135deg, #1f4fb9 0%, #0e3a8a 100%); |
| | | } |
| | | } |
| | | |
| | | @keyframes rotate { |
| | | from { transform: rotate(0deg); } |
| | | to { transform: rotate(360deg); } |
| | | } |
| | | |
| | | @keyframes fadeInDown { |
| | | from { opacity: 0; transform: translateY(-1.25rem); } |
| | | to { opacity: 1; transform: translateY(0); } |
| | | } |
| | | |
| | | @keyframes fadeInUp { |
| | | from { opacity: 0; transform: translateY(1.25rem); } |
| | | to { opacity: 1; transform: translateY(0); } |
| | | } |
| | | |
| | | @keyframes fadeInScale { |
| | | 0% { opacity: 0; transform: translateY(0.5rem) scale(0.96); } |
| | | 100% { opacity: 1; transform: translateY(0) scale(1); } |
| | | } |
| | | |
| | | .notice-left { margin-right: 1rem; } |
| | | .notice-status { font-size: 1rem; } |
| | | .notice-separator { width: 0.0625rem; height: 1.5rem; margin-right: 1rem; } |
| | | .notice-label { font-size: 0.875rem; margin-right: 0.75rem; } |
| | | .notice-text { font-size: 0.875rem; } |
| | | .notice-number { font-size: 1rem; margin-left: 0.25rem; } |
| | | .notice-unit { font-size: 0.875rem; margin-left: 0.125rem; } |
| | | |
| | | .common-module { |
| | | margin-bottom: 1.5rem; |
| | | background: linear-gradient(135deg, #ffffff 0%, #fafbfc 100%); |
| | | border-radius: 1rem; |
| | | padding: 1rem; |
| | | box-shadow: 0 0.25rem 1.25rem rgba(0, 0, 0, 0.06); |
| | | border: none; |
| | | position: relative; |
| | | overflow: hidden; |
| | | transition: all 0.3s ease; |
| | | |
| | | &::after { |
| | | content: ''; |
| | | position: absolute; |
| | | top: 0; |
| | | right: 0; |
| | | width: 3.75rem; |
| | | height: 3.75rem; |
| | | background: radial-gradient(circle, rgba(0,0,0,0.02) 0%, transparent 70%); |
| | | border-radius: 50%; |
| | | transform: translate(1.875rem, -1.875rem); |
| | | } |
| | | } |
| | | |
| | | .marketing-module { |
| | | --module-color: #2979ff; |
| | | } |
| | | |
| | | .purchase-module { |
| | | --module-color: #1976d2; |
| | | } |
| | | |
| | | .collaboration-module { |
| | | --module-color: #4caf50; |
| | | } |
| | | |
| | | .equipment-module { |
| | | --module-color: #9c27b0; |
| | | } |
| | | |
| | | .module-header { |
| | | margin-bottom: 1.5rem; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: space-between; |
| | | } |
| | | |
| | | .module-title-container { |
| | | display: flex; |
| | | align-items: center; |
| | | } |
| | | |
| | | .module-title { |
| | | color: #333333; |
| | | font-size: 1.125rem; |
| | | font-weight: 600; |
| | | position: relative; |
| | | } |
| | | |
| | | .module-subtitle { |
| | | color: #666666; |
| | | font-size: 0.75rem; |
| | | font-weight: 400; |
| | | margin-left: 0.5rem; |
| | | } |
| | | |
| | | .module-content { |
| | | width: 100%; |
| | | display: grid; |
| | | gap: 1rem; |
| | | } |
| | | |
| | | .icon-container { |
| | | width: 3.25rem; |
| | | height: 3.25rem; |
| | | border-radius: 0.75rem; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: center; |
| | | margin-bottom: 0.375rem; |
| | | box-shadow: 0 0.1875rem 0.75rem rgba(0, 0, 0, 0.12); |
| | | transition: all 0.2s ease; |
| | | position: relative; |
| | | overflow: hidden; |
| | | animation: fadeInScale 0.5s ease both; |
| | | |
| | | &:hover { |
| | | transform: translateY(-0.1875rem) scale(1.02); |
| | | box-shadow: 0 0.5rem 1.5625rem rgba(0, 0, 0, 0.18); |
| | | } |
| | | |
| | | &:active { |
| | | transform: scale(0.97); |
| | | box-shadow: 0 0.125rem 0.5rem rgba(0, 0, 0, 0.18); |
| | | } |
| | | } |
| | | |
| | | .item-label { font-size: 0.8125rem; margin-top: 0.25rem; margin-bottom: 0.625rem; } |
| | | .grid-text { font-size: 0.875rem; } |
| | | |
| | | @media (prefers-color-scheme: dark) { |
| | | .common-module { box-shadow: 0 0.375rem 1.5rem rgba(0,0,0,0.35); } |
| | | .notice { box-shadow: 0 0.375rem 1.25rem rgba(0,0,0,0.4); } |
| | | } |
| | | </style> |