| | |
| | | { |
| | | "path": "pages/mine", |
| | | "style": { |
| | | "navigationBarTitleText": "我的" |
| | | "navigationBarTitleText": "我的", |
| | | "navigationStyle": "custom" |
| | | } |
| | | }, |
| | | { |
| | |
| | | <view class="header-section"> |
| | | <view class="currentFactory"> |
| | | <up-text type="primary" :text="userStore.currentFactoryName" @click="show = true" size="18" |
| | | class="factoryName" suffixIcon="arrow-right" :iconStyle="iconStyle"></up-text> |
| | | class="factoryName" suffixIcon="arrow-right" :iconStyle="iconStyle"></up-text> |
| | | </view> |
| | | <up-picker :show="show" :columns="factoryList" @confirm="changeFactory" @cancel="show = false"></up-picker> |
| | | </view> |
| | |
| | | <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> |
| | |
| | | <template> |
| | | <view class="mine-container" :style="{ height: `${windowHeight}px` }"> |
| | | <!--顶部个人信息栏--> |
| | | <view class="header-section"> |
| | | <view class="flex padding justify-between"> |
| | | <view class="flex align-center"> |
| | | <view v-if="!avatar" class="cu-avatar xl round bg-white"> |
| | | <view class="iconfont icon-people text-gray icon"></view> |
| | | </view> |
| | | <image v-if="avatar" @click="handleToAvatar" :src="avatar" class="cu-avatar xl round" mode="widthFix"> |
| | | </image> |
| | | <view v-if="!name" @click="handleToLogin" class="login-tip"> |
| | | 点击登录 |
| | | </view> |
| | | <view v-if="name" @click="handleToInfo" class="user-info"> |
| | | <view class="u_title"> |
| | | 用户名:{{ name }} |
| | | </view> |
| | | <view class="mine-page"> |
| | | <!-- 顶部个人信息卡 --> |
| | | <view class="profile-card"> |
| | | <view class="left"> |
| | | <view v-if="!avatar" class="avatar-placeholder"> |
| | | <view class="iconfont icon-people"></view> |
| | | </view> |
| | | <image |
| | | v-else |
| | | class="avatar" |
| | | :src="avatar" |
| | | mode="aspectFill" |
| | | @click="handleToAvatar" |
| | | /> |
| | | <view class="info"> |
| | | <view class="name-line"> |
| | | <text class="name" @click="name ? handleToInfo() : handleToLogin()"> |
| | | {{ name || '点击登录' }} |
| | | </text> |
| | | <text v-if="roleName" class="role-tag">{{ roleName }}</text> |
| | | </view> |
| | | </view> |
| | | <view @click="handleToInfo" class="flex align-center"> |
| | | <text>个人信息</text> |
| | | <view class="iconfont icon-right"></view> |
| | | </view> |
| | | </view> |
| | | <view class="right" @click="handleToInfo"> |
| | | <text class="link">个人信息</text> |
| | | <view class="iconfont icon-right"></view> |
| | | </view> |
| | | </view> |
| | | |
| | | <view class="content-section"> |
| | | <view class="mine-actions grid col-4 text-center"> |
| | | <view class="action-item" @click="handleJiaoLiuQun"> |
| | | <view class="iconfont icon-friendfill text-pink icon"></view> |
| | | <text class="text">交流群</text> |
| | | </view> |
| | | <view class="action-item" @click="handleBuilding"> |
| | | <view class="iconfont icon-service text-blue icon"></view> |
| | | <text class="text">在线客服</text> |
| | | </view> |
| | | <view class="action-item" @click="handleBuilding"> |
| | | <view class="iconfont icon-community text-mauve icon"></view> |
| | | <text class="text">反馈社区</text> |
| | | </view> |
| | | <view class="action-item" @click="handleBuilding"> |
| | | <view class="iconfont icon-dianzan text-green icon"></view> |
| | | <text class="text">点赞我们</text> |
| | | </view> |
| | | <!-- 三个管理菜单 --> |
| | | <view class="menu-card"> |
| | | <view class="menu-item" @click="handleUnitManage"> |
| | | <uni-icons type="home" size="22" color="#3C96F3" /> |
| | | <text class="label">单位管理</text> |
| | | <uni-icons class="arrow" type="right" size="18" color="#c0c4cc" /> |
| | | </view> |
| | | |
| | | <view class="menu-list"> |
| | | <view class="list-cell list-cell-arrow" @click="handleToEditInfo"> |
| | | <view class="menu-item-box"> |
| | | <view class="iconfont icon-user menu-icon"></view> |
| | | <view>编辑资料</view> |
| | | </view> |
| | | </view> |
| | | <view class="list-cell list-cell-arrow" @click="handleHelp"> |
| | | <view class="menu-item-box"> |
| | | <view class="iconfont icon-help menu-icon"></view> |
| | | <view>常见问题</view> |
| | | </view> |
| | | </view> |
| | | <view class="list-cell list-cell-arrow" @click="handleAbout"> |
| | | <view class="menu-item-box"> |
| | | <view class="iconfont icon-aixin menu-icon"></view> |
| | | <view>关于我们</view> |
| | | </view> |
| | | </view> |
| | | <view class="list-cell list-cell-arrow" @click="handleToSetting"> |
| | | <view class="menu-item-box"> |
| | | <view class="iconfont icon-setting menu-icon"></view> |
| | | <view>应用设置</view> |
| | | </view> |
| | | </view> |
| | | <view class="menu-item" @click="handleUserManage"> |
| | | <uni-icons type="person" size="22" color="#3C96F3" /> |
| | | <text class="label">用户管理</text> |
| | | <uni-icons class="arrow" type="right" size="18" color="#c0c4cc" /> |
| | | </view> |
| | | |
| | | <view class="menu-item" @click="handleContractManage"> |
| | | <uni-icons type="compose" size="22" color="#3C96F3" /> |
| | | <text class="label">合同管理</text> |
| | | <uni-icons class="arrow" type="right" size="18" color="#c0c4cc" /> |
| | | </view> |
| | | </view> |
| | | |
| | | <!-- 底部两个信息卡片 --> |
| | | <!-- <view class="info-cards"> |
| | | <view class="info-card"> |
| | | <view class="card-left"> |
| | | <view class="title">帮助文档</view> |
| | | <view class="desc">了解平台功能模块</view> |
| | | <button class="card-btn" @click="handleHelp">点击查看</button> |
| | | </view> |
| | | <view class="card-illu note"></view> |
| | | </view> |
| | | |
| | | <view class="info-card"> |
| | | <view class="card-left"> |
| | | <view class="title">问题反馈</view> |
| | | <view class="desc">解决平台使用问题</view> |
| | | <button class="card-btn warn" @click="handleFeedback">点击咨询</button> |
| | | </view> |
| | | <view class="card-illu faq"></view> |
| | | </view> |
| | | </view> --> |
| | | </view> |
| | | <!-- <view> |
| | | <uni-popup ref="popup" type="dialog"> |
| | | <uni-popup-dialog type="info" cancelText="关闭" confirmText="退出" |
| | | title="通知" content="确定注销并退出系统吗" |
| | | @confirm="dialogConfirm" |
| | | @close="dialogClose"> |
| | | </uni-popup-dialog> |
| | | </uni-popup> |
| | | </view> --> |
| | | </template> |
| | | |
| | | <script setup> |
| | | import { ref } from "vue"; |
| | | import { ref, onMounted } from "vue"; |
| | | import config from '@/config.js' |
| | | import { getUserProfile } from "@/api/system/user"; |
| | | import useUserStore from '@/store/modules/user' |
| | | const userStore = useUserStore() |
| | | const name = userStore.name; |
| | | const roleName = userStore.roleName; |
| | | const version = config.appInfo.version; |
| | | |
| | | const avatar = ref(userStore.avatar); |
| | | const windowHeight = ref(uni.getSystemInfoSync().windowHeight - 50); |
| | | // rem 基准:1rem = 16px(如有不同请调整 REM_BASE 或样式数值) |
| | | const REM_BASE = 16; |
| | | const windowHeightRem = ref((uni.getSystemInfoSync().windowHeight - 50) / REM_BASE); |
| | | const popup = ref(null); |
| | | |
| | | uni.$on('refresh', () => { |
| | |
| | | function handleToInfo() { |
| | | uni.navigateTo({ |
| | | url: '/pages_mine/pages/info/index' |
| | | }); |
| | | }; |
| | | function handleToEditInfo() { |
| | | uni.navigateTo({ |
| | | url: '/pages_mine/pages/info/edit' |
| | | }); |
| | | }; |
| | | function handleToSetting() { |
| | | uni.navigateTo({ |
| | | url: '/pages_mine/pages/setting/index' |
| | | }); |
| | | }; |
| | | function handleToLogin() { |
| | |
| | | }); |
| | | }) |
| | | }; |
| | | function dialogClose() { |
| | | //console.log('点击关闭') |
| | | }; |
| | | function handleHelp() { |
| | | uni.navigateTo({ |
| | | url: '/pages_mine/pages/help/index' |
| | | }); |
| | | }; |
| | | function handleAbout() { |
| | | uni.navigateTo({ |
| | | url: '/pages_mine/pages/about/index' |
| | | }); |
| | | }; |
| | | function handleJiaoLiuQun() { |
| | | uni.showToast({ |
| | | title: 'QQ群:133713780', |
| | | mask: false, |
| | | icon: "none", |
| | | duration: 1000 |
| | | }); |
| | | }; |
| | | function handleBuilding() { |
| | | uni.showToast({ |
| | | title: '模块建设中~', |
| | | mask: false, |
| | | icon: "none", |
| | | duration: 1000 |
| | | }); |
| | | } |
| | | |
| | | // 现有跳转方法保留:handleToInfo / handleToLogin / handleToAvatar / handleHelp 等 |
| | | function handleUnitManage() { |
| | | // TODO: 替换为真实路由 |
| | | uni.showToast({ title: '模块建设中~', icon: 'none' }); |
| | | } |
| | | function handleUserManage() { |
| | | // TODO: 替换为真实路由 |
| | | uni.showToast({ title: '模块建设中~', icon: 'none' }); |
| | | } |
| | | function handleContractManage() { |
| | | // TODO: 替换为真实路由 |
| | | uni.showToast({ title: '模块建设中~', icon: 'none' }); |
| | | } |
| | | onMounted(() => { |
| | | // 设置用户信息 |
| | | }); |
| | | </script> |
| | | |
| | | <style lang="scss"> |
| | | page { |
| | | background-color: #f5f6f7; |
| | | <style lang="scss" scoped> |
| | | /* 页面容器 */ |
| | | .mine-page { |
| | | min-height: 100vh; |
| | | padding: 1.25rem; |
| | | padding-top: env(safe-area-inset-top); |
| | | position: relative; |
| | | background: linear-gradient( 225deg, #E7F1FF 0%, rgba(255,255,255,0) 74%, rgba(255,255,255,0) 100%); |
| | | } |
| | | |
| | | .mine-container { |
| | | width: 100%; |
| | | height: 100%; |
| | | /* 顶部个人信息卡 */ |
| | | .profile-card { |
| | | display: flex; |
| | | justify-content: space-between; |
| | | align-items: center; |
| | | color: #333; |
| | | margin: 1.25rem 0; |
| | | |
| | | .left { |
| | | display: flex; |
| | | align-items: center; |
| | | gap: 0.75rem; |
| | | |
| | | .header-section { |
| | | padding: 15px 15px 45px 15px; |
| | | background-color: #3c96f3; |
| | | color: white; |
| | | |
| | | .login-tip { |
| | | font-size: 18px; |
| | | margin-left: 10px; |
| | | .avatar { |
| | | width: 3.5rem; |
| | | height: 3.5rem; |
| | | border-radius: 50%; |
| | | border: 0.125rem solid #fff; |
| | | background: #fff; |
| | | object-fit: cover; |
| | | } |
| | | .avatar-placeholder { |
| | | width: 3.5rem; |
| | | height: 3.5rem; |
| | | border-radius: 50%; |
| | | background: #fff; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: center; |
| | | border: 0.125rem solid #fff; |
| | | |
| | | .cu-avatar { |
| | | border: 2px solid #eaeaea; |
| | | |
| | | .icon { |
| | | font-size: 40px; |
| | | .iconfont { |
| | | font-size: 2rem; |
| | | color: #c0c4cc; |
| | | } |
| | | } |
| | | |
| | | .user-info { |
| | | margin-left: 15px; |
| | | .info { |
| | | display: flex; |
| | | flex-direction: column; |
| | | |
| | | .u_title { |
| | | font-size: 18px; |
| | | line-height: 30px; |
| | | .name-line { |
| | | display: flex; |
| | | align-items: flex-end; |
| | | gap: 0.5rem; |
| | | |
| | | .name { |
| | | font-size: 1.125rem; |
| | | font-weight: 600; |
| | | color: #2c2c2c; |
| | | } |
| | | .role-tag { |
| | | font-size: 0.75rem; |
| | | color: #fff; |
| | | background: #ffa940; |
| | | padding: 0.125rem 0.5rem; |
| | | border-radius: 0.75rem; |
| | | } |
| | | } |
| | | |
| | | .phone { |
| | | margin-top: 0.25rem; |
| | | font-size: 0.8125rem; |
| | | color: #3c96f3; |
| | | } |
| | | } |
| | | } |
| | | |
| | | .content-section { |
| | | .right { |
| | | display: flex; |
| | | align-items: center; |
| | | gap: 0.375rem; |
| | | color: #666; |
| | | |
| | | .link { |
| | | font-size: 0.875rem; |
| | | } |
| | | .iconfont { |
| | | font-size: 0.875rem; |
| | | color: #c0c4cc; |
| | | } |
| | | } |
| | | } |
| | | |
| | | /* 菜单卡片 */ |
| | | .menu-card { |
| | | margin-top: 0.75rem; |
| | | background: #fff; |
| | | border-radius: 0.75rem; |
| | | overflow: hidden; |
| | | |
| | | .menu-item { |
| | | display: flex; |
| | | align-items: center; |
| | | height: 3.5rem; |
| | | padding: 1.25rem; |
| | | position: relative; |
| | | top: -50px; |
| | | |
| | | .mine-actions { |
| | | margin: 15px 15px; |
| | | padding: 20px 0px; |
| | | border-radius: 8px; |
| | | background-color: white; |
| | | .label { |
| | | flex: 1; |
| | | margin-left: 0.625rem; |
| | | color: #303133; |
| | | font-size: 0.9375rem; |
| | | } |
| | | .arrow { |
| | | opacity: 0.6; |
| | | } |
| | | } |
| | | |
| | | .action-item { |
| | | .icon { |
| | | font-size: 28px; |
| | | .menu-item + .menu-item { |
| | | border-top: 0.0625rem solid #f2f3f5; |
| | | } |
| | | } |
| | | |
| | | /* 底部信息卡片 */ |
| | | .info-cards { |
| | | display: grid; |
| | | grid-template-columns: 1fr 1fr; |
| | | gap: 0.75rem; |
| | | margin-top: 0.75rem; |
| | | |
| | | .info-card { |
| | | position: relative; |
| | | background: #fff; |
| | | border-radius: 0.75rem; |
| | | padding: 0.875rem 0.75rem; |
| | | min-height: 7rem; |
| | | overflow: hidden; |
| | | |
| | | .card-left { |
| | | display: flex; |
| | | flex-direction: column; |
| | | gap: 0.375rem; |
| | | |
| | | .title { |
| | | font-size: 1rem; |
| | | font-weight: 600; |
| | | color: #2c2c2c; |
| | | } |
| | | .desc { |
| | | font-size: 0.75rem; |
| | | color: #8a8a8a; |
| | | } |
| | | .card-btn { |
| | | margin-top: 0.5rem; |
| | | width: 6rem; |
| | | height: 1.875rem; |
| | | line-height: 1.875rem; |
| | | border: none; |
| | | border-radius: 62.4375rem; |
| | | font-size: 0.8125rem; |
| | | color: #fff; |
| | | background: #3c96f3; |
| | | |
| | | &.warn { |
| | | background: #ffb03a; |
| | | } |
| | | } |
| | | } |
| | | |
| | | .text { |
| | | display: block; |
| | | font-size: 13px; |
| | | margin: 8px 0px; |
| | | } |
| | | /* 右侧装饰(可替换为图片) */ |
| | | .card-illu { |
| | | position: absolute; |
| | | right: -0.375rem; |
| | | bottom: 0; |
| | | width: 4.875rem; |
| | | height: 4.875rem; |
| | | opacity: 0.9; |
| | | |
| | | &.note { |
| | | background: radial-gradient(closest-side, #e8f2ff, transparent), |
| | | linear-gradient(135deg, #d8eaff, #f5faff); |
| | | border-radius: 0.75rem 0 0 0; |
| | | } |
| | | &.faq { |
| | | background: radial-gradient(closest-side, #ffe9d0, transparent), |
| | | linear-gradient(135deg, #ffe0b2, #fff3e0); |
| | | border-radius: 0.75rem 0 0 0; |
| | | } |
| | | } |
| | | } |
| | |
| | | <template> |
| | | <view class="container"> |
| | | <uni-list> |
| | | <uni-list-item showExtraIcon="true" :extraIcon="{ type: 'person-filled' }" title="昵称" :rightText="user.nickName" /> |
| | | <uni-list-item showExtraIcon="true" :extraIcon="{ type: 'phone-filled' }" title="手机号码" |
| | | :rightText="user.phonenumber" /> |
| | | <uni-list-item showExtraIcon="true" :extraIcon="{ type: 'email-filled' }" title="邮箱" :rightText="user.email" /> |
| | | <uni-list-item showExtraIcon="true" :extraIcon="{ type: 'auth-filled' }" title="岗位" :rightText="postGroup" /> |
| | | <uni-list-item showExtraIcon="true" :extraIcon="{ type: 'staff-filled' }" title="角色" :rightText="roleGroup" /> |
| | | <uni-list-item showExtraIcon="true" :extraIcon="{ type: 'calendar-filled' }" title="创建日期" |
| | | :rightText="user.createTime" /> |
| | | </uni-list> |
| | | <view class="card"> |
| | | <van-cell-group inset> |
| | | <van-cell icon="user" title="昵称" :value="user.nickName" /> |
| | | <van-cell icon="phone" title="手机号码" :value="user.phonenumber" /> |
| | | <van-cell icon="invitation" title="邮箱" :value="user.email" /> |
| | | <van-cell icon="medal" title="岗位" :value="postGroup" /> |
| | | <van-cell icon="friends" title="角色" :value="roleGroup" /> |
| | | <van-cell icon="notes" title="创建日期" :value="user.createTime" /> |
| | | </van-cell-group> |
| | | </view> |
| | | |
| | | <u-button @click="register()">绑定微信</u-button> |
| | | <!-- <u-button @click="register()">绑定微信</u-button> --> |
| | | </view> |
| | | </template> |
| | | |
| | |
| | | </script> |
| | | |
| | | <style lang="scss"> |
| | | /* 背景更柔和,卡片更突出 */ |
| | | page { |
| | | background-color: #ffffff; |
| | | background-color: #f5f7fb; |
| | | } |
| | | |
| | | .container { |
| | | min-height: 100vh; |
| | | padding: 0.75rem; /* 24rpx -> 0.75rem */ |
| | | box-sizing: border-box; |
| | | } |
| | | |
| | | /* 列表卡片容器 */ |
| | | .card { |
| | | background-color: #ffffff; |
| | | border-radius: 0.625rem; /* 20rpx -> 0.625rem */ |
| | | box-shadow: 0 0.375rem 1rem rgba(0, 0, 0, 0.06); /* 0 12rpx 32rpx -> 0 0.375rem 1rem */ |
| | | overflow: hidden; |
| | | } |
| | | |
| | | /* 适配 Vant Cell */ |
| | | :deep(.van-cell) { |
| | | min-height: 2.875rem; /* 92rpx -> 2.875rem */ |
| | | } |
| | | |
| | | :deep(.van-cell__title) { |
| | | font-weight: 500; |
| | | color: #1f2937; /* 深灰 */ |
| | | } |
| | | |
| | | :deep(.van-cell__value) { |
| | | color: #6b7280; /* 次要灰 */ |
| | | } |
| | | |
| | | /* 移除不再使用的 .cell-icon 样式 */ |
| | | </style> |