houzhongjian
2024-08-08 820397e43a0b64d35c6d31d2a55475061438593b
提交 | 用户 | 时间
820397 1 <template>
H 2   <div class="navigation-bar" :style="bgStyle">
3     <div class="h-full w-full flex items-center">
4       <div v-for="(cell, cellIndex) in cellList" :key="cellIndex" :style="getCellStyle(cell)">
5         <span v-if="cell.type === 'text'">{{ cell.text }}</span>
6         <img v-else-if="cell.type === 'image'" :src="cell.imgUrl" alt="" class="h-full w-full" />
7         <SearchBar v-else :property="getSearchProp" />
8       </div>
9     </div>
10     <img
11       v-if="property._local?.previewMp"
12       src="@/assets/imgs/diy/app-nav-bar-mp.png"
13       alt=""
14       class="h-30px w-86px"
15     />
16   </div>
17 </template>
18 <script setup lang="ts">
19 import { NavigationBarCellProperty, NavigationBarProperty } from './config'
20 import SearchBar from '@/components/DiyEditor/components/mobile/SearchBar/index.vue'
21 import { StyleValue } from 'vue'
22 import { SearchProperty } from '@/components/DiyEditor/components/mobile/SearchBar/config'
23
24 /** 页面顶部导航栏 */
25 defineOptions({ name: 'NavigationBar' })
26
27 const props = defineProps<{ property: NavigationBarProperty }>()
28
29 // 背景
30 const bgStyle = computed(() => {
31   const background =
32     props.property.bgType === 'img' && props.property.bgImg
33       ? `url(${props.property.bgImg}) no-repeat top center / 100% 100%`
34       : props.property.bgColor
35   return { background }
36 })
37 // 单元格列表
38 const cellList = computed(() =>
39   props.property._local?.previewMp ? props.property.mpCells : props.property.otherCells
40 )
41 // 单元格宽度
42 const cellWidth = computed(() => {
43   return props.property._local?.previewMp ? (375 - 80 - 86) / 6 : (375 - 90) / 8
44 })
45 // 获得单元格样式
46 const getCellStyle = (cell: NavigationBarCellProperty) => {
47   return {
48     width: cell.width * cellWidth.value + (cell.width - 1) * 10 + 'px',
49     left: cell.left * cellWidth.value + (cell.left + 1) * 10 + 'px',
50     position: 'absolute'
51   } as StyleValue
52 }
53 // 获得搜索框属性
54 const getSearchProp = (cell: NavigationBarCellProperty) => {
55   return {
56     height: 30,
57     showScan: false,
58     placeholder: cell.placeholder,
59     borderRadius: cell.borderRadius
60   } as SearchProperty
61 }
62 </script>
63 <style lang="scss" scoped>
64 .navigation-bar {
65   display: flex;
66   height: 50px;
67   background: #fff;
68   justify-content: space-between;
69   align-items: center;
70   padding: 0 6px;
71
72   /* 左边 */
73   .left {
74     margin-left: 8px;
75   }
76
77   .center {
78     font-size: 14px;
79     line-height: 35px;
80     color: #333;
81     text-align: center;
82     flex: 1;
83   }
84
85   /* 右边 */
86   .right {
87     margin-right: 8px;
88   }
89 }
90 </style>