SmartBeehive/pages/Apiary/addrizhi.vue
2024-11-13 18:01:04 +08:00

725 lines
15 KiB
Vue
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<template>
<view class="page">
<u-navbar :title="title" :border-bottom="false" :background="bgc" title-color='#000' title-size='36'
:title-bold='true' height='45' id="navbar">
</u-navbar>
<view class="top" @click="showmiyuan = true">
<view class="top_left">
{{apiaryName}}
</view>
<view class="top_right">
其他蜂箱 <view class="iconfont icon-xiangyou1" style="font-size: 40rpx;">
</view>
</view>
</view>
<view class="set_log_box">
<view class="tit">
选择操作类型
</view>
<view class="set_type_box">
<view class="type_li" v-for="(item,index) in tabs" :key="index" @click="btntab(index,item.type)"
:class='indexs==index?"act1":""'>
{{item.title}}
</view>
</view>
<view class="tit" style="margin-top: 48rpx;">
上传操作图片
</view>
<view class="icon">
<view class="imgbox" v-if="imglist != ''" v-for="(item,index) in imglist " :key="index">
<view class="xx" @click="imgdel(index)">×</view>
<image :src="item" mode="aspectFill"></image>
</view>
<view class="imgbox" @click="btn">
<image src="https://api.ccttiot.com/smartmeter/img/static/ulkCEWjWYqwijg7yhdY9" mode=""></image>
</view>
</view>
<view class="tit" style="margin-top: 48rpx;">
操作说明描述
</view>
<view class="input-container">
<view class="placeholder" v-if="!textValue">在此输入文字描述选填</view>
<textarea class="custom-textarea" v-model="textValue" @focus="hidePlaceholder" style="border: none;"
@input="updateWordCount" @blur="showPlaceholder"></textarea>
<text class="word-count">{{ currentCount }}/140</text>
</view>
<view class="xy">
<u-checkbox-group>
<u-checkbox v-model="checked" shape="circle" active-color="#FFCC25"
@change="checkboxChange">该蜂场的所有蜂箱进行此日志</u-checkbox>
</u-checkbox-group>
<view class="txt">
</view>
</view>
<view class="btn" v-if="title == '添加操作日志'" @click="btnadd">
确认添加
</view>
<view class="btn" v-else @click="btnedit">
确认修改
</view>
</view>
<u-select v-model="showmiyuan" :list="fclist" title='选择蜂箱' @confirm="confirmmy"></u-select>
</view>
</template>
<script>
export default {
data() {
return {
bgc: {
backgroundColor: " #F4FAF8",
},
showmiyuan: false,
title: "添加操作日志",
currentIndex: 0,
wuflag: false,
tabs: [{
title: '换脾',
type: 1
},
{
title: '饲喂',
type: 2
},
{
title: '取蜜',
type: 3
},
{
title: '加脾',
type: 4
},
{
title: '除螨',
type: 5
},
{
title: '换王',
type: 6
},
{
title: '换位置',
type: 7
},
],
textValue: '',
currentCount: 0,
showxy: false,
apiaryId: '',
beehiveId: '',
fclist: [],
apiaryName: '',
type: null,
indexs: -1,
imglist: [],
token: '',
checked: false,
id: '',
arrimg: []
}
},
onLoad(option) {
if (option.id) {
this.id = option.id
this.title = '编辑操作日志'
this.getxq()
}
this.getQiniuToken()
this.getfc()
},
onShow() {
// this.imglist = []
},
methods: {
// 编辑
getxq() {
this.$u.get(`/farm/beehive/log/${this.id}`).then(res => {
if (res.code == 200) {
this.type = res.data.type
this.apiaryId = res.data.beehiveId
this.indexs = res.data.type - 1
this.apiaryName = res.data.beehiveName
this.textValue = res.data.content
this.checked = res.data.apiaryLog
if (res.data.picture.length > 0) {
this.imglist = res.data.picture.split(',')
} else {
this.imglist = []
}
}
})
},
// 删除数组其中图片
imgdel(indexToRemove) {
this.imglist = this.imglist.filter((item, index) => index !== indexToRemove)
},
// 点击确定修改
btnedit() {
if (this.imglist) {
let validUrls = this.imglist.filter(item => typeof item === 'string')
this.arrimg = validUrls.join(',')
}
let data = {
id: this.id,
beehiveId: this.apiaryId,
type: this.type,
content: this.textValue,
picture: this.arrimg,
apiaryLog: this.checked
}
this.$u.put(`/farm/beehive/log`, data).then(res => {
if (res.code == 200) {
uni.showToast({
title: '编辑成功',
icon: 'success',
duration: 1000
})
setTimeout(() => {
uni.navigateBack()
}, 1500)
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
})
}
})
},
// 是否选中所有蜂箱都添加此日志
checkboxChange(e) {
this.checked = e
},
// 点击确定添加日志
btnadd() {
if (this.apiaryId == '') {
uni.showToast({
title: '请选择蜂箱',
icon: 'none',
duration: 1000
})
} else {
if (this.imglist) {
let validUrls = this.imglist.filter(item => typeof item == 'string')
this.imglist = validUrls.join(',')
}else{
this.imglist = this.imglist[0]
}
let data = {
beehiveId: this.apiaryId,
type: this.type,
content: this.textValue,
picture: this.imglist,
apiaryLog: this.checked
}
this.$u.post(`/farm/beehive/log`, data).then(res => {
if (res.code == 200) {
this.imglist = []
uni.showToast({
title: '添加成功',
icon: 'success',
duration: 1000
})
setTimeout(() => {
uni.navigateBack()
}, 1500)
} else {
uni.showToast({
title: res.msg,
icon: 'none',
duration: 2000
})
}
})
}
},
// 选择蜂场
confirmmy(e) {
this.apiaryId = e[0].value
this.apiaryName = e[0].label
},
// 请求蜂箱
getfc() {
this.$u.get(`/farm/beehive/listAll`).then(res => {
if (res.code == 200) {
this.fclist = res.data.map(item => ({
value: item.beehiveId,
label: item.name
}))
}
})
},
// 选择类型
btntab(index, type) {
this.type = type
this.indexs = index
},
hidePlaceholder() {
this.placeholderVisible = false;
},
showPlaceholder() {
if (!this.textValue) {
this.placeholderVisible = true;
}
},
updateWordCount() {
this.currentCount = this.textValue.trim().replace(/\s+/g, '').length
},
getQiniuToken() {
this.$u.get("/common/qiniu/uploadInfo").then((res) => {
if (res.code == 200) {
this.token = res.token
}
})
},
btn() {
let _this = this
let math = 'static/' + _this.$u.guid(20)
uni.chooseImage({
count: 9,
type: 'all',
success(res) {
const tempFilePaths = res.tempFiles
wx.uploadFile({
url: 'https://up-z2.qiniup.com',
name: 'file',
filePath: tempFilePaths[0].path,
formData: {
token: _this.token, //后端返回的token
key: 'smartmeter/img/' + math
},
success: function(res) {
let str = JSON.parse(res.data)
_this.userImgs = 'https://api.ccttiot.com/' + str.key
_this.imglist.push(_this.userImgs)
console.log(_this.imglist);
}
});
}
})
},
changeTag(idx, type) {
this.type = type
this.currentIndex = idx
this.getfxrz()
},
ClickImage(PhotoAddress) {
uni.previewImage({
urls: [PhotoAddress], //需要预览的图片http链接列表多张的时候url直接写在后面就行了
current: '', // 当前显示图片的http链接默认是第一个
success: function(res) {},
fail: function(res) {},
complete: function(res) {},
})
},
}
}
</script>
<style lang="scss">
page {
background-color: #F4FAF8;
}
.addtj {
width: 300rpx;
height: 90rpx;
background-color: #FFCC25;
color: #fff;
text-align: center;
line-height: 90rpx;
position: fixed;
left: 50%;
bottom: 150rpx;
border-radius: 10rpx;
font-size: 36rpx;
}
.page {
// position: relative;
width: 750rpx;
padding-bottom: 300rpx;
box-sizing: border-box;
.no_cont {
margin: 152rpx auto 0;
width: 432rpx;
.img {
image {
width: 432rpx;
height: 432rpx;
}
}
.txt {
margin-top: 50rpx;
width: 100%;
text-align: center;
font-weight: 500;
font-size: 32rpx;
color: #808080;
}
}
.set_log_box {
padding: 50rpx 56rpx;
.btn {
display: flex;
align-items: center;
justify-content: center;
position: fixed;
left: 58rpx;
bottom: 68rpx;
width: 638rpx;
height: 88rpx;
background: #FFCC25;
border-radius: 20rpx 20rpx 20rpx 20rpx;
font-weight: 500;
font-size: 32rpx;
color: #FFFFFF;
}
.xy {
margin-top: 46rpx;
width: 100%;
display: flex;
flex-wrap: nowrap;
align-items: center;
justify-content: center;
.yuans {
margin-top: 2rpx;
display: flex;
align-items: center;
justify-content: center;
width: 34rpx;
height: 34rpx;
border-radius: 50%;
border: #808080 solid 2rpx;
image {
width: 100%;
height: 100%;
border-radius: 50%;
}
}
.txt {
margin-left: 10rpx;
font-weight: 400;
font-size: 28rpx;
color: #808080;
span {
color: #3D3D3D;
}
}
}
.input-container {
position: relative;
width: 612rpx;
height: 172rpx;
background: #FFFFFF;
box-shadow: 0rpx 16rpx 40rpx 0rpx rgba(42, 130, 228, 0.1);
border-radius: 20rpx;
margin-top: 40rpx;
overflow: hidden;
padding-right: 38rpx;
box-sizing: border-box;
border: 2rpx solid #C7C7C7;
}
.placeholder {
position: absolute;
top: 18rpx;
left: 38rpx;
color: #999;
/* placeholder颜色 */
pointer-events: none;
/* 确保点击事件可以穿透到textarea上 */
}
.custom-textarea {
width: 100%;
height: 100%;
/* 设置一个合适高度 */
padding-top: 18rpx;
/* 为placeholder留出空间 */
padding-left: 38rpx;
box-sizing: border-box;
border: 1px solid #ccc;
}
.word-count {
position: absolute;
right: 10px;
bottom: 10px;
font-size: 12px;
color: #999;
}
.icon {
display: flex;
flex-wrap: wrap;
align-items: center;
margin-top: 40rpx;
.imgbox {
width: 33%;
padding-right: 10rpx;
box-sizing: border-box;
position: relative;
.xx {
width: 40rpx;
height: 40rpx;
border-radius: 50%;
background-color: red;
text-align: center;
line-height: 40rpx;
color: #fff;
font-size: 32rpx;
position: absolute;
top: -8rpx;
right: 0;
}
image {
height: 212rpx;
border-radius: 20rpx;
}
}
}
.tit {
font-weight: 600;
font-size: 36rpx;
color: #3D3D3D;
}
.set_type_box {
display: flex;
flex-wrap: wrap;
// margin-top: 26rpx;
.type_li {
margin-top: 26rpx;
margin-right: 18rpx;
padding: 12rpx 50rpx;
background: #FFF5D6;
border-radius: 12rpx 12rpx 12rpx 12rpx;
border: 2rpx solid #FFC107;
font-weight: 500;
font-size: 32rpx;
color: #3D3D3D;
}
.act1 {
background: #FFC107;
border-radius: 12rpx 12rpx 12rpx 12rpx;
border: 2rpx solid #FFC107;
color: #FFFFFF;
}
}
}
.top {
display: flex;
align-items: center;
justify-content: space-between;
padding: 0 22rpx;
margin: 0 auto;
width: 658rpx;
height: 106rpx;
background: #FFFFFF;
box-shadow: 0rpx 0rpx 8rpx 0rpx rgba(0, 0, 0, 0.15);
border-radius: 20rpx 20rpx 20rpx 20rpx;
.top_left {
font-weight: 600;
font-size: 36rpx;
color: #3D3D3D;
}
.top_right {
display: flex;
align-items: center;
flex-wrap: nowrap;
font-weight: 500;
font-size: 36rpx;
color: #808080;
}
}
.cont_box {
margin-top: 26rpx;
display: flex;
flex-wrap: nowrap;
.left {
margin-left: 48rpx;
width: 216rpx;
.left_cont_box {
width: 216rpx;
height: 100rpx;
background: #fff;
.left_cont {
display: flex;
align-items: center;
justify-content: center;
width: 216rpx;
height: 100rpx;
font-weight: 600;
font-size: 36rpx;
color: #3D3D3D;
background-color: #F4FAF8;
// border-radius: 0rpx 40rpx 40rpx 0rpx;
// border: 1rpx solid #fff;
}
.act1 {
background: #fff;
border-radius: 40rpx 0 0 40rpx;
// box-shadow: 0rpx 0rpx 8rpx 0rpx rgba(0, 0, 0, 0.15);
}
.act2 {
border-radius: 0rpx 0rpx 40rpx 0rpx;
}
.act3 {
border-radius: 0rpx 40rpx 0rpx 0rpx;
}
}
.act4 {
background-color: #F4FAF8;
border-radius: 40rpx 0 0 40rpx;
}
}
.right {
padding: 16rpx;
margin-left: -10rpx;
width: 100%;
height: 100vh;
background: #fff;
.right_cont {
padding: 20rpx 26rpx;
border: 2rpx solid #D8D8D8;
border-radius: 20rpx;
margin-top: 20rpx;
.log_work {
margin-top: 16rpx;
display: flex;
flex-wrap: nowrap;
align-items: center;
.work_cont {
display: flex;
flex-wrap: nowrap;
align-items: center;
image {
width: 29rpx;
height: 29rpx;
}
.cont_xtx {
margin-left: 6rpx;
font-weight: 400;
font-size: 28rpx;
color: #3D3D3D;
}
}
}
.log_info {
margin-top: 16rpx;
display: flex;
flex-wrap: nowrap;
align-items: center;
justify-content: space-between;
.txt {
font-weight: 400;
font-size: 28rpx;
color: #3D3D3D;
}
}
.imgcont {
display: flex;
flex-wrap: wrap;
margin-top: 16rpx;
.img_box {
margin-top: 16rpx;
margin-right: 14rpx;
height: 124rpx;
width: 124rpx;
image {
background: #D8D8D8;
border-radius: 12rpx 12rpx 12rpx 12rpx;
height: 124rpx;
width: 124rpx;
}
}
}
// border-radius: 20rpx 20rpx 20rpx 20rpx;
.cont {
margin-top: 16rpx;
font-weight: 400;
font-size: 28rpx;
color: #3D3D3D;
}
.right_cont_top {
display: flex;
flex-wrap: nowrap;
align-items: center;
justify-content: space-between;
.cont_left {
font-weight: 400;
font-size: 28rpx;
color: #808080;
}
.cont_right {
font-weight: 500;
font-size: 28rpx;
color: #FFC107;
}
}
}
// border-radius: 40rpx 0 0 40rpx;
// box-shadow: 0rpx 0rpx 8rpx 0rpx rgba(0, 0, 0, 0.15);
}
}
}
</style>