¶Ô±ÈÐÂÎļþ |
| | |
| | | <template> |
| | | <view class="content"> |
| | | <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> |
| | | </view> |
| | | <up-picker :show="show" :columns="factoryList" @confirm="changeFactory"></up-picker> |
| | | </view> |
| | | |
| | | <view class="hero-section"> |
| | | <view class="bg-img"> |
| | | <view class="hero-content"> |
| | | <text class="hero-title">产ååºå管çç³»ç»</text> |
| | | </view> |
| | | </view> |
| | | </view> |
| | | |
| | | <view class="notice-section"> |
| | | <view class="notice"> |
| | | <view class="notice-content"> |
| | | <view class="notice-left"> |
| | | <text class="notice-status">éç¥</text> |
| | | </view> |
| | | <view class="notice-separator"></view> |
| | | <view class="notice-right"> |
| | | <text class="notice-label">{{currentStatus}}</text> |
| | | <text class="notice-text">彿¥éå®è®¾å¤æ°:<text class="notice-number">{{number}}<text class="notice-unit">个</text></text></text> |
| | | </view> |
| | | </view> |
| | | </view> |
| | | </view> |
| | | |
| | | <!-- è¥éç®¡çæ¨¡å --> |
| | | <view class="common-module marketing-module"> |
| | | <view class="module-header"> |
| | | <view class="module-title-container"> |
| | | <text class="module-title">è¥é管ç</text> |
| | | </view> |
| | | </view> |
| | | <view class="module-content"> |
| | | <up-grid |
| | | :border="false" |
| | | col="4" |
| | | > |
| | | <up-grid-item |
| | | v-for="(item, index) in marketingItems" |
| | | :key="index" |
| | | @click="handleCommonItemClick(item)" |
| | | > |
| | | <view class="icon-container" :style="{ background: item.bgColor }"> |
| | | <up-icon |
| | | :name="item.icon" |
| | | :size="26" |
| | | color="#ffffff" |
| | | ></up-icon> |
| | | </view> |
| | | <text class="item-label">{{item.label}}</text> |
| | | </up-grid-item> |
| | | </up-grid> |
| | | </view> |
| | | </view> |
| | | |
| | | <!-- éè´ç®¡ç模å --> |
| | | <view class="common-module purchase-module"> |
| | | <view class="module-header"> |
| | | <view class="module-title-container"> |
| | | <text class="module-title">éè´ç®¡ç</text> |
| | | </view> |
| | | </view> |
| | | <view class="module-content"> |
| | | <up-grid |
| | | :border="false" |
| | | col="4" |
| | | > |
| | | <up-grid-item |
| | | v-for="(item, index) in purchaseItems" |
| | | :key="index" |
| | | @click="handleCommonItemClick(item)" |
| | | > |
| | | <view class="icon-container" :style="{ background: item.bgColor }"> |
| | | <up-icon |
| | | :name="item.icon" |
| | | :size="26" |
| | | color="#ffffff" |
| | | ></up-icon> |
| | | </view> |
| | | <text class="item-label">{{item.label}}</text> |
| | | </up-grid-item> |
| | | </up-grid> |
| | | </view> |
| | | </view> |
| | | |
| | | <!-- åååå
¬æ¨¡å --> |
| | | <view class="common-module collaboration-module"> |
| | | <view class="module-header"> |
| | | <view class="module-title-container"> |
| | | <text class="module-title">åååå
¬</text> |
| | | </view> |
| | | </view> |
| | | <view class="module-content"> |
| | | <up-grid |
| | | :border="false" |
| | | col="4" |
| | | > |
| | | <up-grid-item |
| | | v-for="(item, index) in collaborationItems" |
| | | :key="index" |
| | | @click="handleCommonItemClick(item)" |
| | | > |
| | | <view class="icon-container" :style="{ background: item.bgColor }"> |
| | | <up-icon |
| | | :name="item.icon" |
| | | :size="26" |
| | | color="#ffffff" |
| | | ></up-icon> |
| | | </view> |
| | | <text class="item-label">{{item.label}}</text> |
| | | </up-grid-item> |
| | | </up-grid> |
| | | </view> |
| | | </view> |
| | | |
| | | <!-- 设å¤ç®¡ç模å --> |
| | | <view class="common-module equipment-module"> |
| | | <view class="module-header"> |
| | | <view class="module-title-container"> |
| | | <text class="module-title">设å¤ç®¡ç</text> |
| | | </view> |
| | | </view> |
| | | <view class="module-content"> |
| | | <up-grid |
| | | :border="false" |
| | | col="4" |
| | | > |
| | | <up-grid-item |
| | | v-for="(item, index) in equipmentItems" |
| | | :key="index" |
| | | @click="handleCommonItemClick(item)" |
| | | > |
| | | <view class="icon-container" :style="{ background: item.bgColor }"> |
| | | <up-icon |
| | | :name="item.icon" |
| | | :size="26" |
| | | color="#ffffff" |
| | | ></up-icon> |
| | | </view> |
| | | <text class="item-label">{{item.label}}</text> |
| | | </up-grid-item> |
| | | </up-grid> |
| | | </view> |
| | | </view> |
| | | </view> |
| | | </template> |
| | | |
| | | <script setup> |
| | | import {ref, onMounted, nextTick, reactive} from 'vue'; |
| | | import {userLoginFacotryList} from "@/api/login"; |
| | | import modal from "@/plugins/modal"; |
| | | import useUserStore from "@/store/modules/user"; |
| | | |
| | | const userStore = useUserStore() |
| | | const factoryId = ref(''); |
| | | const show = ref(false); |
| | | const factoryList = ref([]); |
| | | const factoryListTem = ref([]); |
| | | const iconStyle = { |
| | | fontSize: '18px', |
| | | color: '#2979ff' |
| | | } |
| | | |
| | | // éç¥ç¶æåæ¢ |
| | | const statusList = ['éå®', 'éè´'] |
| | | let statusIndex = 0 |
| | | const currentStatus = ref(statusList[0]) |
| | | const number = ref(7643) |
| | | |
| | | // 宿¶å¨åæ¢éç¥ç¶æ |
| | | const startStatusTimer = () => { |
| | | setInterval(() => { |
| | | statusIndex = (statusIndex + 1) % statusList.length |
| | | currentStatus.value = statusList[statusIndex] |
| | | }, 3000) |
| | | } |
| | | |
| | | // è¥é管çåè½æ°æ® |
| | | const marketingItems = reactive([ |
| | | { |
| | | icon: 'account', |
| | | label: 'éå®å°è´¦', |
| | | bgColor: '#2979ff' |
| | | }, |
| | | { |
| | | icon: 'home', |
| | | label: 'å¼ç¥¨ç»è®°', |
| | | bgColor: '#1976d2' |
| | | }, |
| | | { |
| | | icon: 'file-text', |
| | | label: 'å¼ç¥¨å°è´¦', |
| | | bgColor: '#42a5f5' |
| | | }, |
| | | { |
| | | icon: 'shopping-cart', |
| | | label: '忬¾ç»è®°', |
| | | bgColor: '#64b5f6' |
| | | }, |
| | | { |
| | | icon: 'chat', |
| | | label: '忬¾æµæ°´', |
| | | bgColor: '#90caf9' |
| | | }, |
| | | { |
| | | icon: 'chat', |
| | | label: '客æ·å¾æ¥', |
| | | bgColor: '#90caf9' |
| | | } |
| | | ]); |
| | | |
| | | // éè´ç®¡çåè½æ°æ® |
| | | const purchaseItems = reactive([ |
| | | { |
| | | icon: 'order', |
| | | label: 'éè´å°è´¦', |
| | | bgColor: '#bbdefb' |
| | | }, |
| | | { |
| | | icon: 'truck', |
| | | label: 'æ¥ç¥¨ç»è®°', |
| | | bgColor: '#e3f2fd' |
| | | }, |
| | | { |
| | | icon: 'box', |
| | | label: 'æ¥ç¥¨å°è´¦', |
| | | bgColor: '#f3e5f5' |
| | | }, |
| | | { |
| | | icon: 'chart-line', |
| | | label: '仿¬¾ç»è®°', |
| | | bgColor: '#e8eaf6' |
| | | }, |
| | | { |
| | | icon: 'settings', |
| | | label: '仿¬¾æµæ°´', |
| | | bgColor: '#f1f8e9' |
| | | }, |
| | | { |
| | | icon: 'settings', |
| | | label: 'ä¾åºå徿¥', |
| | | bgColor: '#f1f8e9' |
| | | }, |
| | | ]); |
| | | |
| | | // åååå
¬åè½æ°æ® |
| | | const collaborationItems = reactive([ |
| | | { |
| | | icon: 'checkmark-circle', |
| | | label: 'åå审æ¹', |
| | | bgColor: '#4caf50' |
| | | }, |
| | | { |
| | | icon: 'map-pin', |
| | | label: 'å®¢æ·æè®¿', |
| | | bgColor: '#ff9800' |
| | | } |
| | | ]); |
| | | |
| | | // 设å¤ç®¡çåè½æ°æ® |
| | | const equipmentItems = reactive([ |
| | | { |
| | | icon: 'list', |
| | | label: '设å¤å°è´¦', |
| | | bgColor: '#9c27b0' |
| | | }, |
| | | { |
| | | icon: 'wrench', |
| | | label: 'è®¾å¤æ¥ä¿®', |
| | | bgColor: '#f44336' |
| | | }, |
| | | { |
| | | icon: 'shield-check', |
| | | label: '设å¤ä¿å
»', |
| | | bgColor: '#00bcd4' |
| | | } |
| | | ]); |
| | | |
| | | // å¤ç常ç¨åè½ç¹å» |
| | | const handleCommonItemClick = (item) => { |
| | | // æ ¹æ®ä¸åçåè½é¡¹è¿è¡è·³è½¬ |
| | | switch (item.label) { |
| | | case 'éå®å°è´¦': |
| | | uni.navigateTo({ |
| | | url: '/pages/sales/salesAccount/index' |
| | | }); |
| | | break; |
| | | case 'å¼ç¥¨ç»è®°': |
| | | uni.navigateTo({ |
| | | url: '/pages/sales/invoicingRegistration/index' |
| | | }); |
| | | break; |
| | | case 'å¼ç¥¨å°è´¦': |
| | | uni.navigateTo({ |
| | | url: '/pages/sales/invoiceLedger/index' |
| | | }); |
| | | break; |
| | | case '忬¾ç»è®°': |
| | | uni.navigateTo({ |
| | | url: '/pages/sales/receiptPayment/index' |
| | | }); |
| | | break; |
| | | case 'åå审æ¹': |
| | | uni.navigateTo({ |
| | | url: '/pages/cooperativeOffice/collaborativeApproval/index' |
| | | }); |
| | | break; |
| | | case 'å®¢æ·æè®¿': |
| | | uni.navigateTo({ |
| | | url: '/pages/cooperativeOffice/clientVisit/index' |
| | | }); |
| | | break; |
| | | default: |
| | | uni.showToast({ |
| | | title: `ç¹å»äº${item.label}`, |
| | | icon: 'none' |
| | | }); |
| | | } |
| | | }; |
| | | |
| | | // å建对åç»ä»¶çå¼ç¨ |
| | | const uToastRef = ref(null); |
| | | |
| | | function getUserLoginFacotryList() { |
| | | userLoginFacotryList({userName: userStore.nickName}).then(res => { |
| | | // æ£æ¥res.dataæ¯å¦ä¸ºæ°ç» |
| | | factoryList.value[0] = [] |
| | | if (res.data && Array.isArray(res.data)) { |
| | | factoryListTem.value = res.data |
| | | res.data.forEach(item => { |
| | | factoryList.value[0].push(item.deptName) |
| | | }) |
| | | factoryId.value = userStore.currentDeptId |
| | | } else { |
| | | // 妿res.data䏿¯æ°ç»ï¼è®¾ç½®ä¸ºç©ºæ°ç» |
| | | factoryList.value = [] |
| | | } |
| | | }).catch(error => { |
| | | modal.msgError('è·åå
¬å¸å表失败:', error) |
| | | factoryList.value = [] |
| | | }) |
| | | } |
| | | const changeFactory = async (arr) => { |
| | | show.value = false; |
| | | const factoryId = factoryListTem.value[arr.indexs[0]].deptId |
| | | const loginForm = { |
| | | username: userStore.name, |
| | | password: uni.getStorageSync('remembered_password'), |
| | | factoryId: factoryId, |
| | | } |
| | | modal.loading("å·æ°ä¸ï¼è¯·èå¿çå¾
...") |
| | | userStore.loginCheckFactory(loginForm).then(() => { |
| | | modal.closeLoading() |
| | | nextTick(() => { |
| | | loginSuccess() |
| | | }); |
| | | }).catch(() => { |
| | | modal.closeLoading() |
| | | }) |
| | | } |
| | | function loginSuccess(result) { |
| | | uni.reLaunch({ |
| | | url: '/pages/index' |
| | | }); |
| | | } |
| | | |
| | | // å®ä¹æ¹æ³ |
| | | const click = (name) => { |
| | | if (uToastRef.value) { |
| | | uToastRef.value.success(`ç¹å»äºç¬¬${name + 1}个`); // 注æï¼è¿éå 1æ¯å 为é常æä»¬æ¯ä»ç¬¬1个å¼å§è®¡æ°ç |
| | | } |
| | | }; |
| | | |
| | | onMounted(() => { |
| | | // è®¾ç½®ç¨æ·ä¿¡æ¯ |
| | | userStore.getInfo() |
| | | getUserLoginFacotryList() |
| | | // å¯å¨éç¥ç¶æå®æ¶å¨ |
| | | startStatusTimer() |
| | | }); |
| | | </script> |
| | | |
| | | <style scoped lang="scss"> |
| | | .content { |
| | | background: linear-gradient(135deg, #f8f9fa 0%, #e3f2fd 100%); |
| | | min-height: 100vh; |
| | | padding: 20px; |
| | | padding-top: env(safe-area-inset-top); |
| | | position: relative; |
| | | |
| | | &::before { |
| | | content: ''; |
| | | position: fixed; |
| | | top: 0; |
| | | left: 0; |
| | | right: 0; |
| | | bottom: 0; |
| | | 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(41, 121, 255, 0.03)"/></pattern></defs><rect width="100" height="100" fill="url(%23dots)"/></svg>'); |
| | | pointer-events: none; |
| | | z-index: -1; |
| | | } |
| | | |
| | | &::after { |
| | | content: ''; |
| | | position: fixed; |
| | | top: 0; |
| | | left: 0; |
| | | right: 0; |
| | | bottom: 0; |
| | | background: radial-gradient(circle at 20% 80%, rgba(41, 121, 255, 0.02) 0%, transparent 50%), |
| | | radial-gradient(circle at 80% 20%, rgba(156, 39, 176, 0.02) 0%, transparent 50%); |
| | | pointer-events: none; |
| | | z-index: -1; |
| | | } |
| | | } |
| | | |
| | | /* æ¬é¡µä¸åå®ä¹ .safe-area-topï¼å·²ç§»è³å
¨å±æ ·å¼ */ |
| | | |
| | | .header-section { |
| | | margin-bottom: 16px; |
| | | animation: fadeInDown 0.6s ease-out; |
| | | } |
| | | |
| | | .currentFactory { |
| | | margin-top: 8px; |
| | | margin-left: 4px; |
| | | font-weight: 500; |
| | | display: flex; |
| | | } |
| | | |
| | | .factoryName { |
| | | width: auto; |
| | | } |
| | | |
| | | :deep(.u-text) { |
| | | align-items: center; |
| | | } |
| | | |
| | | .hero-section { |
| | | margin-bottom: 16px; |
| | | animation: fadeInUp 0.6s ease-out 0.1s both; |
| | | } |
| | | |
| | | .bg-img { |
| | | width: 100%; |
| | | height: 120px; |
| | | background: linear-gradient(135deg, #2979ff 0%, #1565c0 100%); |
| | | border-radius: 12px; |
| | | position: relative; |
| | | overflow: hidden; |
| | | box-shadow: 0 4px 20px rgba(41, 121, 255, 0.15); |
| | | |
| | | &::before { |
| | | content: ''; |
| | | position: absolute; |
| | | top: -50%; |
| | | left: -50%; |
| | | width: 200%; |
| | | height: 200%; |
| | | background: conic-gradient(from 0deg, transparent, rgba(255,255,255,0.1), transparent, rgba(255,255,255,0.05), transparent); |
| | | animation: rotate 20s linear infinite; |
| | | } |
| | | |
| | | &::after { |
| | | content: ''; |
| | | position: absolute; |
| | | top: 0; |
| | | right: 0; |
| | | width: 120px; |
| | | height: 120px; |
| | | background: radial-gradient(circle, rgba(255,255,255,0.15) 0%, transparent 70%); |
| | | border-radius: 50%; |
| | | transform: translate(40px, -40px); |
| | | } |
| | | } |
| | | |
| | | .hero-content { |
| | | position: relative; |
| | | z-index: 1; |
| | | padding: 20px; |
| | | height: 100%; |
| | | display: flex; |
| | | align-items: center; |
| | | } |
| | | |
| | | .hero-title { |
| | | color: #ffffff; |
| | | font-size: 24px; |
| | | font-weight: 600; |
| | | } |
| | | |
| | | |
| | | |
| | | .notice-section { |
| | | margin-bottom: 16px; |
| | | 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); |
| | | position: relative; |
| | | overflow: hidden; |
| | | |
| | | &::before { |
| | | content: ''; |
| | | position: absolute; |
| | | top: -50%; |
| | | left: -50%; |
| | | width: 200%; |
| | | height: 200%; |
| | | background: linear-gradient(45deg, transparent, rgba(255,255,255,0.6), transparent); |
| | | animation: shine 4s infinite; |
| | | } |
| | | |
| | | &::after { |
| | | content: ''; |
| | | position: absolute; |
| | | top: 0; |
| | | right: 0; |
| | | width: 80px; |
| | | height: 80px; |
| | | background: radial-gradient(circle, rgba(255,255,255,0.2) 0%, transparent 70%); |
| | | border-radius: 50%; |
| | | transform: translate(30px, -30px); |
| | | } |
| | | } |
| | | |
| | | |
| | | |
| | | @keyframes shine { |
| | | 0% { |
| | | transform: translateX(-100%) translateY(-100%) rotate(45deg); |
| | | } |
| | | 100% { |
| | | transform: translateX(100%) translateY(100%) rotate(45deg); |
| | | } |
| | | } |
| | | |
| | | @keyframes fadeInDown { |
| | | from { |
| | | opacity: 0; |
| | | transform: translateY(-20px); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | transform: translateY(0); |
| | | } |
| | | } |
| | | |
| | | @keyframes fadeInUp { |
| | | from { |
| | | opacity: 0; |
| | | transform: translateY(20px); |
| | | } |
| | | to { |
| | | opacity: 1; |
| | | transform: translateY(0); |
| | | } |
| | | } |
| | | |
| | | @keyframes rotate { |
| | | from { |
| | | transform: rotate(0deg); |
| | | } |
| | | to { |
| | | transform: rotate(360deg); |
| | | } |
| | | } |
| | | |
| | | .notice-content { |
| | | display: flex; |
| | | align-items: center; |
| | | height: 100%; |
| | | position: relative; |
| | | z-index: 1; |
| | | } |
| | | |
| | | .notice-left { |
| | | margin-right: 16px; |
| | | } |
| | | |
| | | .notice-status { |
| | | font-weight: 600; |
| | | font-size: 16px; |
| | | color: #1976d2; |
| | | } |
| | | |
| | | .notice-separator { |
| | | width: 1px; |
| | | height: 24px; |
| | | background: #e0e0e0; |
| | | margin-right: 16px; |
| | | } |
| | | |
| | | .notice-right { |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: space-between; |
| | | flex: 1; |
| | | } |
| | | |
| | | .notice-label { |
| | | color: #333; |
| | | font-size: 14px; |
| | | font-weight: 500; |
| | | margin-right: 12px; |
| | | } |
| | | |
| | | .notice-text { |
| | | font-weight: 400; |
| | | font-size: 14px; |
| | | color: #666666; |
| | | } |
| | | |
| | | .notice-number { |
| | | font-weight: 600; |
| | | font-size: 16px; |
| | | color: #1976d2; |
| | | margin-left: 4px; |
| | | } |
| | | |
| | | .notice-unit { |
| | | color: #666666; |
| | | font-size: 14px; |
| | | margin-left: 2px; |
| | | } |
| | | |
| | | /* åè½æ¨¡åæ ·å¼ */ |
| | | .common-module { |
| | | margin-bottom: 24px; |
| | | 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: none; |
| | | position: relative; |
| | | overflow: hidden; |
| | | transition: all 0.3s ease; |
| | | |
| | | &::after { |
| | | content: ''; |
| | | position: absolute; |
| | | top: 0; |
| | | right: 0; |
| | | width: 60px; |
| | | height: 60px; |
| | | 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%); |
| | | } |
| | | } |
| | | } |
| | | |
| | | .marketing-module { |
| | | --module-color: #2979ff; |
| | | } |
| | | |
| | | .purchase-module { |
| | | --module-color: #1976d2; |
| | | } |
| | | |
| | | .collaboration-module { |
| | | --module-color: #4caf50; |
| | | } |
| | | |
| | | .equipment-module { |
| | | --module-color: #9c27b0; |
| | | } |
| | | |
| | | .module-header { |
| | | margin-bottom: 24px; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: space-between; |
| | | } |
| | | |
| | | .module-title-container { |
| | | display: flex; |
| | | align-items: center; |
| | | } |
| | | |
| | | .module-title { |
| | | color: #333333; |
| | | font-size: 18px; |
| | | 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-weight: 400; |
| | | margin-left: 8px; |
| | | } |
| | | |
| | | .module-content { |
| | | width: 100%; |
| | | display: grid; |
| | | gap: 16px; |
| | | } |
| | | |
| | | .icon-container { |
| | | width: 52px; |
| | | height: 52px; |
| | | border-radius: 12px; |
| | | 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; |
| | | position: relative; |
| | | overflow: hidden; |
| | | |
| | | &::before { |
| | | content: ''; |
| | | position: absolute; |
| | | top: 0; |
| | | left: 0; |
| | | right: 0; |
| | | bottom: 0; |
| | | background: linear-gradient(135deg, rgba(255,255,255,0.1) 0%, transparent 50%, rgba(255,255,255,0.05) 100%); |
| | | opacity: 0; |
| | | transition: opacity 0.3s ease; |
| | | } |
| | | |
| | | &::after { |
| | | content: ''; |
| | | position: absolute; |
| | | top: 0; |
| | | left: 0; |
| | | right: 0; |
| | | bottom: 0; |
| | | border-radius: 12px; |
| | | 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); |
| | | |
| | | &::before, |
| | | &::after { |
| | | opacity: 1; |
| | | } |
| | | } |
| | | } |
| | | |
| | | .item-label { |
| | | font-size: 13px; |
| | | color: #555555; |
| | | text-align: center; |
| | | display: block; |
| | | line-height: 1.4; |
| | | font-weight: 500; |
| | | margin-top: 4px; |
| | | margin-bottom: 10px; |
| | | } |
| | | |
| | | .grid-text { |
| | | font-size: 14px; |
| | | color: #909399; |
| | | padding: 10rpx 0 20rpx 0rpx; |
| | | /* #ifndef APP-PLUS */ |
| | | box-sizing: border-box; |
| | | /* #endif */ |
| | | } |
| | | |
| | | |
| | | </style> |