@ -0,0 +1,77 @@ | |||||
<template> | |||||
<uv-navbar :leftIconColor="leftIconColor" :autoBack="autoBack" :title="title" :bgColor="bgColor" :leftIconSize="leftIconSize" :height="height" :titleStyle="titleStyle" @leftClick="leftClick"></uv-navbar> | |||||
</template> | |||||
<script> | |||||
export default { | |||||
data() { | |||||
return { | |||||
}; | |||||
}, | |||||
props: { | |||||
autoBack: { | |||||
type: Boolean, | |||||
default: false, | |||||
required: false | |||||
}, | |||||
title: { | |||||
type: String, | |||||
default: '', | |||||
required: false | |||||
}, | |||||
bgColor: { | |||||
type: String, | |||||
default: 'transparent', | |||||
required: false | |||||
}, | |||||
leftIconSize: { | |||||
type: String, | |||||
default: '20rpx', | |||||
required: false | |||||
}, | |||||
leftIconColor: { | |||||
type: String, | |||||
default: '', | |||||
required: false | |||||
}, | |||||
height: { | |||||
type: String, | |||||
default: '100rpx', | |||||
required: false | |||||
}, | |||||
titleStyle: { | |||||
type: Object, | |||||
default: {}, | |||||
required: false | |||||
}, | |||||
autoBack: { | |||||
type: Boolean, | |||||
default: false, | |||||
required: false | |||||
}, | |||||
}, | |||||
components: { | |||||
}, | |||||
computed: { | |||||
}, | |||||
watch: { | |||||
}, | |||||
created() { | |||||
}, | |||||
mounted() { | |||||
}, | |||||
methods: { | |||||
leftClick() {} | |||||
} | |||||
}; | |||||
</script> | |||||
<style scoped lang="scss"> | |||||
</style> |
@ -0,0 +1,33 @@ | |||||
export const globalMixin = { | |||||
data() { | |||||
return { | |||||
bgColor:'transparent', | |||||
fontColor:'#fff', | |||||
leftIconColor: '#fff' | |||||
}; | |||||
}, | |||||
computed: { | |||||
customStyle() { | |||||
return { | |||||
height: '88rpx', | |||||
color: '#FF4546', | |||||
} | |||||
} | |||||
}, | |||||
created() { | |||||
}, | |||||
onPageScroll(e) { | |||||
if(e.scrollTop > 50) { | |||||
this.bgColor ='#49070c' | |||||
this.fontColor ="#fff", | |||||
this.leftIconColor ="#fff" | |||||
}else{ | |||||
this.bgColor ='transparent' | |||||
this.fontColor ="#fff", | |||||
this.leftIconColor ="#fff" | |||||
} | |||||
}, | |||||
methods: { | |||||
} | |||||
}; | |||||
@ -0,0 +1,244 @@ | |||||
<template> | |||||
<view class="travelList"> | |||||
<view class="head-box"></view> | |||||
<uv-navbar autoBack title="活动列表" leftIconColor="#fff" :bgColor="bgColor" height="100rpx" :titleStyle="{color:'#fff'}"></uv-navbar> | |||||
<view class="content"> | |||||
<view class="drop"> | |||||
<uv-drop-down ref="dropDown" text-color="#fff" text-size="30rpx" sign="dropDown_1" text-active-color="#fff" | |||||
:extra-icon="{name:'arrow-down-fill',color:'#666',size:'26rpx'}" | |||||
:extra-active-icon="{name:'arrow-up-fill',color:'#fff',size:'26rpx'}" :defaultValue="defaultValue" | |||||
:custom-style="{padding: '0 30rpx'}" @click="selectMenu"> | |||||
<uv-drop-down-item name="order" type="2" :label="dropItem('order').label" :value="dropItem('order').value"> | |||||
</uv-drop-down-item> | |||||
<uv-drop-down-item name="place" type="2" :label="dropItem('type').label" :value="dropItem('type').value"> | |||||
</uv-drop-down-item> | |||||
<uv-drop-down-item name="type" type="2" :label="dropItem('type').label" :value="dropItem('type').value"> | |||||
</uv-drop-down-item> | |||||
</uv-drop-down> | |||||
<uv-drop-down-popup sign="dropDown_1" :click-overlay-on-close="true" :currentDropItem="currentDropItem" | |||||
@clickItem="clickItem" @popupChange="change"></uv-drop-down-popup> | |||||
</view> | |||||
<view class="info cardStyle_"> | |||||
<view class="left"> | |||||
<image src="https://img0.baidu.com/it/u=4274003247,920124130&fm=253&fmt=auto&app=138&f=JPEG?w=800&h=1031" | |||||
alt=""> | |||||
</view> | |||||
<view class="right"> | |||||
<view class="detailed"> | |||||
<view class="title">夏日去撒野旅游计划~</view> | |||||
<view class="date">2024.10.28 10:00</view> | |||||
<view class="address">成都市东丽湖露营地32号</view> | |||||
</view> | |||||
<view class="data"> | |||||
<text>¥233.00</text> | |||||
<text>11/40</text> | |||||
<text class="btn">已开票</text> | |||||
</view> | |||||
</view> | |||||
</view> | |||||
</view> | |||||
</view> | |||||
</template> | |||||
<script> | |||||
import Navbar from '@/pages/components/Navbar.vue' | |||||
// import { globalMixin } from '../pages/mixins/globalMixin'; | |||||
export default { | |||||
onPageScroll() { | |||||
// 滚动后及时更新位置 | |||||
this.$refs.dropDown.init(); | |||||
}, | |||||
// mixins: [globalMixin], | |||||
// components:{ | |||||
// Navbar | |||||
// }, | |||||
computed: { | |||||
dropItem(name) { | |||||
return (name) => { | |||||
const result = {}; | |||||
const find = this.result.find(item => item.name === name); | |||||
if (find) { | |||||
result.label = find.label; | |||||
result.value = find.value; | |||||
} else { | |||||
result.label = this[name].label; | |||||
result.value = this[name].value; | |||||
} | |||||
return result; | |||||
} | |||||
}, | |||||
// 获取当前下拉筛选项 | |||||
currentDropItem() { | |||||
return this[this.activeName]; | |||||
} | |||||
}, | |||||
data() { | |||||
return { | |||||
bgColor:'transparent', | |||||
// 表示value等于这些值,就属于默认值 | |||||
defaultValue: [0, 'all', '0'], | |||||
// 筛选结果 | |||||
result: [{ | |||||
name: 'order', | |||||
label: '全部', | |||||
value: 'new' | |||||
}], | |||||
// { name: 'order', label: '最新发布', value: 'new' } | |||||
activeName: 'order', | |||||
order: { | |||||
label: '全部', | |||||
value: 'all', | |||||
activeIndex: 0, | |||||
color: '#333', | |||||
activeColor: '#FF4546', | |||||
child: [{ | |||||
label: '综合排序', | |||||
value: 'all' | |||||
}, { | |||||
label: '最新发布', | |||||
value: 'new' | |||||
}, { | |||||
label: '低价优先', | |||||
value: 'money' | |||||
}] | |||||
}, | |||||
type: { | |||||
label: '时间', | |||||
value: 'all', | |||||
activeIndex: 0, | |||||
color: '#333', | |||||
activeColor: '#FF4546', | |||||
child: [{ | |||||
label: '全部', | |||||
value: 'all' | |||||
}, { | |||||
label: 'PDF', | |||||
value: 'pdf' | |||||
}, { | |||||
label: 'WROD', | |||||
value: 'word' | |||||
}, { | |||||
label: 'PPT', | |||||
value: 'ppt' | |||||
}] | |||||
} | |||||
} | |||||
}, | |||||
methods: { | |||||
change(e) { | |||||
console.log('弹窗打开状态:', e); | |||||
}, | |||||
/** | |||||
* 点击每个筛选项回调 | |||||
* @param {Object} e { name, active, type } = e | |||||
*/ | |||||
selectMenu(e) { | |||||
const { | |||||
name, | |||||
active, | |||||
type | |||||
} = e; | |||||
this.activeName = name; | |||||
// type 等于1 的需要特殊处理:type不等于1可以忽略 | |||||
if (type == 1) { | |||||
this.clickItem({ | |||||
name: 'vip_type', | |||||
label: 'VIP文档', | |||||
value: e.active ? 1 : 0 | |||||
}); | |||||
} else { | |||||
const find = this.result.find(item => item.name == this.activeName); | |||||
if (find) { | |||||
const findIndex = this[this.activeName].child.findIndex(item => item.label == find.label && item.value == | |||||
find.value); | |||||
this[this.activeName].activeIndex = findIndex; | |||||
} else { | |||||
this[this.activeName].activeIndex = 0; | |||||
} | |||||
} | |||||
}, | |||||
/** | |||||
* 点击菜单回调处理 | |||||
* @param {Object} item 选中项 { label,value } = e | |||||
*/ | |||||
clickItem(e) { | |||||
// 下面有重新赋值,所以用let | |||||
let { | |||||
label, | |||||
value | |||||
} = e; | |||||
const findIndex = this.result.findIndex(item => item.name == this.activeName); | |||||
if (this.defaultValue.indexOf(value) > -1 && this[this.activeName].label) { | |||||
label = this[this.activeName].label; | |||||
} | |||||
// 已经存在筛选项 | |||||
if (findIndex > -1) { | |||||
this.$set(this.result, findIndex, { | |||||
name: this.activeName, | |||||
label, | |||||
value | |||||
}) | |||||
} else { | |||||
this.result.push({ | |||||
name: this.activeName, | |||||
label, | |||||
value | |||||
}); | |||||
} | |||||
this.result = this.result.filter(item => this.defaultValue.indexOf(item.value) == -1); | |||||
uni.showModal({ | |||||
content: `筛选的值:${JSON.stringify(this.result)}` | |||||
}) | |||||
} | |||||
} | |||||
} | |||||
</script> | |||||
<style scoped lang="scss"> | |||||
.head-box { | |||||
background: url('@/static/image/nav-bg.png') no-repeat; | |||||
background-size: 100% 100%; | |||||
width: 100%; | |||||
height: 534rpx; | |||||
position: absolute; | |||||
} | |||||
.content { | |||||
padding-top: calc(var(--status-bar-height) + 110rpx); | |||||
} | |||||
/deep/.uv-sticky__content { | |||||
.uv-drop-down { | |||||
justify-content: normal; | |||||
border: 0; | |||||
background: transparent; | |||||
} | |||||
} | |||||
.travelList { | |||||
margin-bottom: 500rpx; | |||||
.content { | |||||
.info { | |||||
position: relative; | |||||
margin: 10rpx 32rpx 36rpx; | |||||
; | |||||
padding: 35rpx 0 35rpx 24rpx; | |||||
border-radius: 26rpx; | |||||
.right { | |||||
.data { | |||||
display: flex; | |||||
justify-content: space-between; | |||||
align-items: center; | |||||
.btn { | |||||
background: #381615; | |||||
color: $uni-color-primary; | |||||
padding: 10rpx 40rpx; | |||||
border-radius: 30rpx 0px 0px 30rpx; | |||||
} | |||||
} | |||||
} | |||||
} | |||||
} | |||||
} | |||||
</style> |
@ -0,0 +1,109 @@ | |||||
<template> | |||||
<view class="invoiceIssuance"> | |||||
<view class="head-box"></view> | |||||
<Navbar title="订单详情" :autoBack="true" :bgColor="bgColor" leftIconSize="18px" height="100rpx" :leftIconColor="leftIconColor" :titleStyle="{color:fontColor}" /> | |||||
<view class="content contentPosition_"> | |||||
<view class="info cardStyle_"> | |||||
<view class="left"> | |||||
<image src="https://img0.baidu.com/it/u=4274003247,920124130&fm=253&fmt=auto&app=138&f=JPEG?w=800&h=1031" alt=""> | |||||
</view> | |||||
<view class="right"> | |||||
<view class="detailed"> | |||||
<view class="title">夏日去撒野旅游计划~</view> | |||||
<view class="date">2024.10.28 10:00</view> | |||||
<view class="address">成都市东丽湖露营地32号</view> | |||||
</view> | |||||
<view class="data"> | |||||
<view>12/30</view> | |||||
<button class="mini-btn" size="mini">立即报名</button> | |||||
</view> | |||||
</view> | |||||
<i class="icon"></i> | |||||
</view> | |||||
<view class="info cardStyle_"> | |||||
<view class="left"> | |||||
<image src="https://img0.baidu.com/it/u=4274003247,920124130&fm=253&fmt=auto&app=138&f=JPEG?w=800&h=1031" alt=""> | |||||
</view> | |||||
<view class="right"> | |||||
<view class="detailed"> | |||||
<view class="title">夏日去撒野旅游计划~</view> | |||||
<view class="date">2024.10.28 10:00</view> | |||||
<view class="address">成都市东丽湖露营地32号</view> | |||||
</view> | |||||
<view class="data"> | |||||
<view>12/30</view> | |||||
<button class="mini-btn" size="mini">立即报名</button> | |||||
</view> | |||||
</view> | |||||
<i class="icon"></i> | |||||
</view> | |||||
</view> | |||||
</view> | |||||
</template> | |||||
<script> | |||||
import Navbar from '@/pages/components/Navbar.vue' | |||||
import { globalMixin } from '../pages/mixins/globalMixin'; | |||||
export default{ | |||||
mixins: [globalMixin], | |||||
components:{ | |||||
Navbar | |||||
}, | |||||
computed: { | |||||
customStyle1() { | |||||
return { | |||||
height: '30rpx', | |||||
color: '#FF4546', | |||||
} | |||||
} | |||||
}, | |||||
data() { | |||||
return { | |||||
} | |||||
}, | |||||
methods: { | |||||
} | |||||
} | |||||
</script> | |||||
<style scoped lang="scss"> | |||||
.invoiceIssuance { | |||||
margin-bottom: 500rpx; | |||||
.content { | |||||
.info { | |||||
position: relative; | |||||
margin: 10rpx 32rpx 36rpx;; | |||||
border-radius: 26rpx; | |||||
.icon { | |||||
position: absolute; | |||||
right: 0; | |||||
top: 0; | |||||
display: block; | |||||
width: 66rpx; | |||||
height: 56rpx; | |||||
background: red; | |||||
background: url('@/static/image/icon.png') no-repeat; | |||||
background-size: 100% 100%; | |||||
} | |||||
.right { | |||||
.data { | |||||
display: flex; | |||||
justify-content: space-between; | |||||
align-items: center; | |||||
.mini-btn { | |||||
margin: 0; | |||||
background: linear-gradient(to right, #FE5E5E, #E41522); | |||||
height: 45rpx; | |||||
line-height: 45rpx; | |||||
width: 181rpx; | |||||
color:#fff; | |||||
border-radius: 60rpx; | |||||
padding-bottom: 5rpx; | |||||
} | |||||
} | |||||
} | |||||
} | |||||
} | |||||
} | |||||
</style> |
@ -0,0 +1,236 @@ | |||||
<template> | |||||
<view class="travelList"> | |||||
<view class="head-box"></view> | |||||
<Navbar title="旅行列表" :autoBack="true" :bgColor="bgColor" leftIconSize="18px" height="100rpx" :leftIconColor="leftIconColor" :titleStyle="{color:fontColor}" /> | |||||
<view class="content contentPosition_"> | |||||
<view class="drop"> | |||||
<uv-drop-down | |||||
ref="dropDown" | |||||
text-color="#fff" | |||||
text-size="30rpx" | |||||
sign="dropDown_1" | |||||
text-active-color="#fff" | |||||
:extra-icon="{name:'arrow-down-fill',color:'#666',size:'26rpx'}" | |||||
:extra-active-icon="{name:'arrow-up-fill',color:'#fff',size:'26rpx'}" | |||||
:defaultValue="defaultValue" | |||||
:custom-style="{padding: '0 30rpx'}" | |||||
@click="selectMenu" | |||||
> | |||||
<uv-drop-down-item | |||||
name="order" | |||||
type="2" | |||||
:label="dropItem('order').label" | |||||
:value="dropItem('order').value"> | |||||
</uv-drop-down-item> | |||||
<uv-drop-down-item | |||||
name="type" | |||||
type="2" | |||||
:label="dropItem('type').label" | |||||
:value="dropItem('type').value"> | |||||
</uv-drop-down-item> | |||||
</uv-drop-down> | |||||
<uv-drop-down-popup | |||||
sign="dropDown_1" | |||||
:click-overlay-on-close="true" | |||||
:currentDropItem="currentDropItem" | |||||
@clickItem="clickItem" | |||||
@popupChange="change" | |||||
></uv-drop-down-popup> | |||||
</view> | |||||
<view class="info cardStyle_"> | |||||
<view class="left"> | |||||
<image src="https://img0.baidu.com/it/u=4274003247,920124130&fm=253&fmt=auto&app=138&f=JPEG?w=800&h=1031" alt=""> | |||||
</view> | |||||
<view class="right"> | |||||
<view class="detailed"> | |||||
<view class="title">夏日去撒野旅游计划~</view> | |||||
<view class="date">2024.10.28 10:00</view> | |||||
<view class="address">成都市东丽湖露营地32号</view> | |||||
</view> | |||||
<view class="data"> | |||||
<text>¥233.00</text> | |||||
<text>11/40</text> | |||||
<text class="btn">已开票</text> | |||||
</view> | |||||
</view> | |||||
</view> | |||||
</view> | |||||
</view> | |||||
</template> | |||||
<script> | |||||
import Navbar from '@/pages/components/Navbar.vue' | |||||
import { globalMixin } from '../pages/mixins/globalMixin'; | |||||
export default{ | |||||
onPageScroll() { | |||||
// 滚动后及时更新位置 | |||||
this.$refs.dropDown.init(); | |||||
}, | |||||
mixins: [globalMixin], | |||||
components:{ | |||||
Navbar | |||||
}, | |||||
computed: { | |||||
dropItem(name) { | |||||
return (name) => { | |||||
const result = {}; | |||||
const find = this.result.find(item => item.name === name); | |||||
if (find) { | |||||
result.label = find.label; | |||||
result.value = find.value; | |||||
} else { | |||||
result.label = this[name].label; | |||||
result.value = this[name].value; | |||||
} | |||||
return result; | |||||
} | |||||
}, | |||||
// 获取当前下拉筛选项 | |||||
currentDropItem() { | |||||
return this[this.activeName]; | |||||
} | |||||
}, | |||||
data() { | |||||
return { | |||||
// 表示value等于这些值,就属于默认值 | |||||
defaultValue: [0, 'all', '0'], | |||||
// 筛选结果 | |||||
result: [{ name: 'order', label: '全部', value: 'new' }], | |||||
// { name: 'order', label: '最新发布', value: 'new' } | |||||
activeName: 'order', | |||||
order: { | |||||
label: '全部', | |||||
value: 'all', | |||||
activeIndex: 0, | |||||
color: '#333', | |||||
activeColor: '#FF4546', | |||||
child: [{ | |||||
label: '综合排序', | |||||
value: 'all' | |||||
}, { | |||||
label: '最新发布', | |||||
value: 'new' | |||||
}, { | |||||
label: '低价优先', | |||||
value: 'money' | |||||
}] | |||||
}, | |||||
type: { | |||||
label: '时间', | |||||
value: 'all', | |||||
activeIndex: 0, | |||||
color: '#333', | |||||
activeColor: '#FF4546', | |||||
child: [{ | |||||
label: '全部', | |||||
value: 'all' | |||||
}, { | |||||
label: 'PDF', | |||||
value: 'pdf' | |||||
}, { | |||||
label: 'WROD', | |||||
value: 'word' | |||||
}, { | |||||
label: 'PPT', | |||||
value: 'ppt' | |||||
}] | |||||
} | |||||
} | |||||
}, | |||||
methods: { | |||||
change(e) { | |||||
console.log('弹窗打开状态:',e); | |||||
}, | |||||
/** | |||||
* 点击每个筛选项回调 | |||||
* @param {Object} e { name, active, type } = e | |||||
*/ | |||||
selectMenu(e) { | |||||
const { name, active, type } = e; | |||||
this.activeName = name; | |||||
// type 等于1 的需要特殊处理:type不等于1可以忽略 | |||||
if (type == 1) { | |||||
this.clickItem({ | |||||
name: 'vip_type', | |||||
label: 'VIP文档', | |||||
value: e.active ? 1 : 0 | |||||
}); | |||||
} else { | |||||
const find = this.result.find(item => item.name == this.activeName); | |||||
if (find) { | |||||
const findIndex = this[this.activeName].child.findIndex(item => item.label == find.label && item.value == find.value); | |||||
this[this.activeName].activeIndex = findIndex; | |||||
} else { | |||||
this[this.activeName].activeIndex = 0; | |||||
} | |||||
} | |||||
}, | |||||
/** | |||||
* 点击菜单回调处理 | |||||
* @param {Object} item 选中项 { label,value } = e | |||||
*/ | |||||
clickItem(e) { | |||||
// 下面有重新赋值,所以用let | |||||
let { label, value } = e; | |||||
const findIndex = this.result.findIndex(item => item.name == this.activeName); | |||||
if (this.defaultValue.indexOf(value) > -1 && this[this.activeName].label) { | |||||
label = this[this.activeName].label; | |||||
} | |||||
// 已经存在筛选项 | |||||
if (findIndex > -1) { | |||||
this.$set(this.result, findIndex, { | |||||
name: this.activeName, | |||||
label, | |||||
value | |||||
}) | |||||
} else { | |||||
this.result.push({ | |||||
name: this.activeName, | |||||
label, | |||||
value | |||||
}); | |||||
} | |||||
this.result = this.result.filter(item => this.defaultValue.indexOf(item.value) == -1); | |||||
uni.showModal({ | |||||
content: `筛选的值:${JSON.stringify(this.result)}` | |||||
}) | |||||
} | |||||
} | |||||
} | |||||
</script> | |||||
<style scoped lang="scss"> | |||||
/deep/.uv-sticky__content{ | |||||
.uv-drop-down { | |||||
justify-content: normal; | |||||
border: 0; | |||||
background: transparent; | |||||
} | |||||
} | |||||
.travelList { | |||||
margin-bottom: 500rpx; | |||||
.content { | |||||
.info { | |||||
position: relative; | |||||
margin: 10rpx 32rpx 36rpx;; | |||||
padding: 35rpx 0 35rpx 24rpx; | |||||
border-radius: 26rpx; | |||||
.right { | |||||
.data { | |||||
display: flex; | |||||
justify-content: space-between; | |||||
align-items: center; | |||||
.btn { | |||||
background: #381615; | |||||
color: $uni-color-primary; | |||||
padding: 10rpx 40rpx; | |||||
border-radius: 30rpx 0px 0px 30rpx; | |||||
} | |||||
} | |||||
} | |||||
} | |||||
} | |||||
} | |||||
</style> |
@ -0,0 +1,117 @@ | |||||
<template> | |||||
<view class="invoiceIssuance"> | |||||
<view class="head-box"></view> | |||||
<Navbar title="订单详情" :autoBack="true" :bgColor="bgColor" leftIconSize="18px" height="100rpx" :leftIconColor="leftIconColor" :titleStyle="{color:fontColor}" /> | |||||
<view class="content contentPosition_"> | |||||
<view class="info cardStyle_"> | |||||
<view class="left"> | |||||
<image src="https://img0.baidu.com/it/u=4274003247,920124130&fm=253&fmt=auto&app=138&f=JPEG?w=800&h=1031" alt=""> | |||||
</view> | |||||
<view class="right"> | |||||
<view class="detailed"> | |||||
<view class="title">夏日去撒野旅游计划~</view> | |||||
<view class="date">2024.10.28 10:00</view> | |||||
<view class="address">成都市东丽湖露营地32号</view> | |||||
</view> | |||||
<view class="price"><text>总计</text>¥800.00</view> | |||||
</view> | |||||
</view> | |||||
<view class="choice"> | |||||
<uv-radio-group | |||||
siz="300" | |||||
labelSize="25rpx" | |||||
iconSize="25rpx" | |||||
v-model="radioValue" | |||||
placement="column" | |||||
shape="square" | |||||
labelColor="#fff" | |||||
activeColor="#FF4546" | |||||
iconPlacement="right"> | |||||
<uv-radio name="个人" label="个人"></uv-radio> | |||||
<uv-radio name="企业" label="个人"></uv-radio> | |||||
</uv-radio-group> | |||||
</view> | |||||
<view class="iptInfo"> | |||||
<uv-form-item label="企业名称" labelWidth="180rpx" :customStyle="aa" borderBottom> | |||||
<uv-input placeholder="请输入内容" fontSize="29rpx" color="#fff" v-model="enterpriseName" border="none"></uv-input> | |||||
</uv-form-item> | |||||
<uv-form-item label="企业名称" labelWidth="180rpx" :customStyle="aa" borderBottom> | |||||
<uv-input placeholder="请输入内容" fontSize="29rpx" color="#fff" v-model="enterpriseName" border="none"></uv-input> | |||||
</uv-form-item> | |||||
<uv-form-item label="企业名称" labelWidth="180rpx" :customStyle="aa" borderBottom> | |||||
<uv-input placeholder="请输入内容" fontSize="29rpx" color="#fff" v-model="enterpriseName" border="none"></uv-input> | |||||
</uv-form-item> | |||||
</view> | |||||
<view style="padding: 65rpx 35rpx;"> | |||||
<uv-button @click="toInvoiceRecords" :custom-style="customStyle" type="primary" shape="circle" color="#381615" text="申请"></uv-button> | |||||
</view> | |||||
</view> | |||||
</view> | |||||
</template> | |||||
<script> | |||||
import Navbar from '@/pages/components/Navbar.vue' | |||||
import { globalMixin } from '../pages/mixins/globalMixin'; | |||||
export default{ | |||||
mixins: [globalMixin], | |||||
components:{ | |||||
Navbar | |||||
}, | |||||
data() { | |||||
return { | |||||
radioValue: '香蕉', | |||||
enterpriseName: '', | |||||
aa: { | |||||
color: '#f40' | |||||
} | |||||
} | |||||
}, | |||||
methods: { | |||||
toInvoiceRecords() { | |||||
uni.navigateTo({ | |||||
url: '/pages_order/invoiceRecords' | |||||
}) | |||||
} | |||||
} | |||||
} | |||||
</script> | |||||
<style scoped lang="scss"> | |||||
.invoiceIssuance { | |||||
margin-bottom: 500rpx; | |||||
.content { | |||||
.info { | |||||
margin: 10rpx 32rpx 0rpx;; | |||||
border-radius: 26rpx; | |||||
} | |||||
.choice { | |||||
/deep/.uv-radio-group { | |||||
margin: 32px 32rpx 40rpx; | |||||
.uv-radio { | |||||
color: #fff; | |||||
padding: 45rpx 35rpx; | |||||
background: $uni-color-card-background; | |||||
border-radius: 26rpx; | |||||
margin-bottom: 16rpx; | |||||
} | |||||
.uv-radio__icon-wrap { | |||||
width: 32rpx!important; | |||||
height: 32rpx!important; | |||||
} | |||||
} | |||||
} | |||||
.iptInfo { | |||||
background: $uni-color-card-background; | |||||
padding: 41rpx 46rpx 60rpx; | |||||
margin: 32px 32rpx 40rpx; | |||||
border-radius: 26rpx; | |||||
/deep/.uv-form-item__body__left__content__label { | |||||
color: #fff!important; | |||||
font-size: 32rpx; | |||||
} | |||||
} | |||||
} | |||||
} | |||||
</style> |
@ -0,0 +1,83 @@ | |||||
<template> | |||||
<view class='invoiceRecords'> | |||||
<view class="head-box"></view> | |||||
<Navbar title="开票记录" :autoBack="true" :bgColor="bgColor" leftIconSize="18px" height="100rpx" :leftIconColor="leftIconColor" :titleStyle="{color:fontColor}" /> | |||||
<view class="content contentPosition_"> | |||||
<view class="info cardStyle_"> | |||||
<view class="left"> | |||||
<image src="https://img0.baidu.com/it/u=4274003247,920124130&fm=253&fmt=auto&app=138&f=JPEG?w=800&h=1031" alt=""> | |||||
</view> | |||||
<view class="right"> | |||||
<view class="detailed"> | |||||
<view class="title">夏日去撒野旅游计划~</view> | |||||
<view class="date">2024.10.28 10:00</view> | |||||
<view class="address">成都市东丽湖露营地32号</view> | |||||
</view> | |||||
<view class="data"> | |||||
<text>标准票</text> | |||||
<text>×3</text> | |||||
<text class="btn">已开票</text> | |||||
</view> | |||||
</view> | |||||
</view> | |||||
</view> | |||||
</view> | |||||
</template> | |||||
<script> | |||||
import Navbar from '@/pages/components/Navbar.vue' | |||||
import { globalMixin } from '../pages/mixins/globalMixin'; | |||||
export default { | |||||
mixins: [globalMixin], | |||||
components:{ | |||||
Navbar | |||||
}, | |||||
data() { | |||||
return { | |||||
}; | |||||
}, | |||||
components: { | |||||
}, | |||||
computed: { | |||||
}, | |||||
watch: { | |||||
}, | |||||
created() { | |||||
}, | |||||
mounted() { | |||||
}, | |||||
methods: { | |||||
} | |||||
}; | |||||
</script> | |||||
<style scoped lang="scss"> | |||||
.invoiceRecords { | |||||
.info { | |||||
margin: 10rpx 32rpx 0rpx; | |||||
padding: 35rpx 0 35rpx 24rpx; | |||||
border-radius: 26rpx; | |||||
.right { | |||||
.data { | |||||
display: flex; | |||||
justify-content: space-between; | |||||
.btn { | |||||
background: #381615; | |||||
color: $uni-color-primary; | |||||
padding: 10rpx 40rpx; | |||||
border-radius: 30rpx 0px 0px 30rpx; | |||||
} | |||||
} | |||||
} | |||||
} | |||||
} | |||||
</style> |
@ -1,11 +1,103 @@ | |||||
<template> | <template> | ||||
<view> | |||||
第三代 | |||||
<view class="orderEvaluation"> | |||||
<Navbar title="活动评价" :autoBack="true" :bgColor="bgColor" leftIconSize="18px" height="100rpx" :leftIconColor="leftIconColor" :titleStyle="{color:fontColor}" /> | |||||
<view class="content"> | |||||
<view class="baseInfo cardBackground_"> | |||||
<view class="statusBox"> | |||||
<i></i> | |||||
<view class="status">主理人评价</view> | |||||
</view> | |||||
<view class="info grayBg"> | |||||
<view class="score"> | |||||
<image src="@/static/image/cart/selectIcon.png" mode=""></image> | |||||
<image src="@/static/image/cart/selectIcon.png" mode=""></image> | |||||
<image src="@/static/image/cart/selectIcon.png" mode=""></image> | |||||
<image src="@/static/image/cart/selectIcon.png" mode=""></image> | |||||
<image src="@/static/image/cart/uncheckedIcon.png" mode=""></image> | |||||
</view> | |||||
<uv-textarea height="376rpx" :textStyle="{color:fontColor}" border="none" v-model="value" :maxlength="-1" placeholder="请输入内容"></uv-textarea> | |||||
</view> | |||||
</view> | |||||
<view class="baseInfo" style="margin-top: 32rpx;"> | |||||
<view class="statusBox"> | |||||
<i></i> | |||||
<view class="status">活动评价</view> | |||||
</view> | |||||
<view class="info"> | |||||
<view class="score"> | |||||
<image src="@/static/image/cart/selectIcon.png" mode=""></image> | |||||
<image src="@/static/image/cart/selectIcon.png" mode=""></image> | |||||
<image src="@/static/image/cart/selectIcon.png" mode=""></image> | |||||
<image src="@/static/image/cart/selectIcon.png" mode=""></image> | |||||
<image src="@/static/image/cart/uncheckedIcon.png" mode=""></image> | |||||
</view> | |||||
<uv-textarea height="376rpx" :textStyle="{color:fontColor}" border="none" v-model="value1" :maxlength="-1" placeholder="请输入内容"></uv-textarea> | |||||
</view> | |||||
</view> | |||||
</view> | |||||
<view style="padding: 65rpx 35rpx;"> | |||||
<uv-button :custom-style="customStyle" type="primary" shape="circle" color="#381615" text="活动签到"></uv-button> | |||||
</view> | |||||
</view> | </view> | ||||
</template> | </template> | ||||
<script> | <script> | ||||
</script> | |||||
import Navbar from '@/pages/components/Navbar.vue' | |||||
import { globalMixin } from '../pages/mixins/globalMixin'; | |||||
<style> | |||||
export default{ | |||||
mixins: [globalMixin], | |||||
components:{ | |||||
Navbar | |||||
}, | |||||
data() { | |||||
return { | |||||
value: '', | |||||
value1: '' | |||||
} | |||||
}, | |||||
methods: { | |||||
} | |||||
} | |||||
</script> | |||||
<style scoped lang="scss"> | |||||
.orderEvaluation { | |||||
margin-top: 40rpx; | |||||
.content { | |||||
padding: 0 35rpx; | |||||
color: #fff; | |||||
padding-top: calc(var(--status-bar-height) + 100rpx); | |||||
.baseInfo{ | |||||
.statusBox { | |||||
display: flex; | |||||
align-items: center; | |||||
padding: 33rpx 47rpx 24rpx; | |||||
i { | |||||
background: url('@/static/image/cart/evaluateIcon.png') no-repeat; | |||||
background-size: 100% 100%; | |||||
display: block; | |||||
width: 33rpx; | |||||
height: 29rpx; | |||||
margin-right: 15rpx; | |||||
} | |||||
} | |||||
.info { | |||||
.score { | |||||
image { | |||||
width: 30rpx; | |||||
height: 30rpx; | |||||
margin-right: 30rpx; | |||||
margin-bottom: 34rpx; | |||||
} | |||||
} | |||||
/deep/.uv-textarea { | |||||
background: #493734; | |||||
} | |||||
.aa { | |||||
color: #fff!important; | |||||
} | |||||
} | |||||
} | |||||
} | |||||
} | |||||
</style> | </style> |