Explorar el Código

新排版及对接

Ming hace 3 años
padre
commit
362db4865d

+ 1 - 1
common/common.scss

@@ -391,7 +391,7 @@ radio,checkbox {
 	}
 	
 	// 监察上报
-	textarea{
+	.appWrapper textarea{
 		border:1px solid #EDEDED;
 		padding:10px;
 		color: #999;

+ 3 - 0
pages/eleControl/controlReport/controlReport.vue

@@ -10,7 +10,10 @@
 						<view class="pro-title">
 							<view class="cut">{{item.supervision_title}}</view>
 						</view>
+						<view class="pro-date ">{{item.site_name}}</view>
 						<view class="pro-date ">{{item.create_time}}</view>
+						
+						
 					</view>
 					<view class="nav-right num">
 						<view class="text-grey">

+ 4 - 2
pages/eleControl/controlReport/controlReportAdd/controlReportAdd.vue

@@ -58,8 +58,10 @@
 				</view>
 			</view>
 			<br>
-			<view class="form-item">
-				<view style="color:#4074E7;border-bottom:1px solid #4074E7" @tap="goArchivePage()">现场档案</view>
+			<view style="height:20rpx;background:#EDEDED"></view>
+			<view class="form-item justify-between" style="border-bottom:1px solid #EDEDED;padding:20rpx 30rpx" @tap="goArchivePage()">
+				<view  >现场档案</view>
+				<view><text class="icon iconfont margin-left-xs ">&#xe629;</text></view>
 			</view>
 
 			<view class="btn-area submitBottomBtn padding-lr-sm">

+ 28 - 0
pages/eleControl/controlReport/controlReportDetail/controlReportDetail.vue

@@ -33,7 +33,29 @@
 
 				</view>
 			</view>
+			
+			<view class="form-item">
+				<view class="title">
+					<text class="necessary">*</text>
+					提交人:
+				</view>
+				<input type="text" v-model="controlReportDetail.creator" disabled>
+			</view>
+			
+			<view class="form-item">
+				<view class="title">
+					<text class="necessary">*</text>
+					提交时间:
+				</view>
+				<input type="text" v-model="controlReportDetail.create_time" disabled>
+			</view>
 		</form>
+		
+		<view style="height:20rpx;background:#EDEDED"></view>
+		<view class="form-item justify-between" style="border-bottom:1px solid #EDEDED;padding:20rpx 30rpx" @tap="goArchivePage()">
+			<view  >现场档案</view>
+			<view><text class="icon iconfont margin-left-xs ">&#xe629;</text></view>
+		</view>
 
 	</view>
 </template>
@@ -55,6 +77,12 @@
 		},
 		mounted() {},
 		methods: {
+			
+			goArchivePage(){
+				uni.navigateTo({
+					url: '/pages/siteArchive/siteArchive',
+				});
+			},
 
 			//数据请求
 			async getDataList(params = {}) {

+ 156 - 83
pages/processList/processList.vue

@@ -3,8 +3,8 @@
 
 		<view class="ding">
 			<scroll-view scroll-x class="bg-white nav text-center">
-				<view class="cu-item" :class="index==TabCur?'text-blue cur':''" v-for="(item,index) in tabNav" :key="index" @tap="tabSelect"
-				 :data-id="index">
+				<view class="cu-item" :class="index==TabCur?'text-blue cur':''" v-for="(item,index) in tabNav"
+					:key="index" @tap="tabSelect" :data-id="index">
 					<view v-if="TabCur==index&&!TabCur" class="cu-tag badge">
 						<block class="cu-tag badge">{{alarmUntreatedCount}} </block>
 					</view>
@@ -15,39 +15,40 @@
 
 		<block v-if="TabCur==0">
 			<view class="processList">
-					<view class="cu-list menu-avatar">
-						
-						<view class="cu-item" v-for="(item,index) in unporcessList" :key="index">
-							<view class="cu-avatar lg" style="background-image:url(../../static/process-icon.png);"></view>
-							<view class="content">
-								<view class="pro-title">
-									<view class="cut">{{item.measName}}</view>
-								</view>
-								<view class="pro-des  ">
-									<view class="text-cut">
-										{{item.digitalValue!=0?"动作":"复归"}}
-									</view>
-								</view>
-								<view class="pro-date ">{{item.soeTime}}</view>
+				<view class="cu-list menu-avatar">
+
+					<view class="cu-item" v-for="(item,index) in unporcessList" :key="index">
+						<view class="cu-avatar lg" style="background-image:url(../../static/process-icon.png);"></view>
+						<view class="content">
+							<view class="pro-title">
+								<view class="cut">{{item.measName}}</view>
 							</view>
-							<view class="action" style="z-index:99;width:170rpx;text-align:right">
-								<view class="unProcess"  @tap="goUnprocessDetail(item.id)">未处理<text class="icon iconfont margin-left-xs margin-right-xs">&#xe629;</text></view>
+							<view class="pro-des  ">
+								<view class="text-cut">
+									{{item.digitalValue!=0?"动作":"复归"}}
+								</view>
 							</view>
-						</view>
-						<view class=" text-center margin-top" v-if="alarmUntreatedCount === 0">暂无数据...</view>
+							<view class="pro-date ">{{item.soeTime}}</view>
+						</view>
+						<view class="action" style="z-index:99;width:170rpx;text-align:right">
+							<view class="unProcess" @tap="goUnprocessDetail(item.id)">未处理<text
+									class="icon iconfont margin-left-xs margin-right-xs">&#xe629;</text></view>
+						</view>
 					</view>
+					<view class=" text-center margin-top" v-if="alarmUntreatedCount === 0">暂无数据...</view>
+				</view>
+
+
+
+
 
-				
-				
-					
-				
 
 			</view>
 		</block>
 		<block v-if="TabCur==1">
 			<view class="processList">
 				<!-- 筛选 start -->
-				<view class=" padding-bottom-xs" style="border-bottom:1rpx solid  rgba(221,221,221,.3)">
+				<view  v-if="this.type==1 " class=" padding-bottom-xs" style="border-bottom:1rpx solid  rgba(221,221,221,.3)">
 					<view class="cu-bar search filter-section">
 						<view class="search-form border-gray round bg-white">
 							<select name="" id="" v-model="handleStatus">
@@ -62,8 +63,9 @@
 							<view>
 								<checkbox-group class="block " @change="allChoose">
 									<view class="cu-form-group">
-										<checkbox value="all"  class='round blue' :class="{'checked':allChecked}"  :checked="allChecked?true:false">
-										</checkbox> 
+										<checkbox value="all" class='round blue' :class="{'checked':allChecked}"
+											:checked="allChecked?true:false">
+										</checkbox>
 										<view class="title">批量处理</view>
 									</view>
 								</checkbox-group>
@@ -72,23 +74,23 @@
 					</view>
 				</view>
 				<!-- 筛选end -->
-				
-				
+
+
 				<checkbox-group @change="changeCheckbox">
-					<view class="cu-list menu-avatar ">
-						
+					<view class="cu-list menu-avatar " :class="this.handleStatus==2?'handle2scroll':''">
+
 						<view class="cu-item" v-for="(item,index) in porcessedList" :key="index">
-							
+
 							<view class="cu-form-group checkPos">
-								
-								<!-- <checkbox :value="String(item.owner_code)" :checked="checkedArr.includes(String(item.owner_code))"
-									:class="{'checked':checkedArr.includes(String(item.owner_code))}"></checkbox> -->
-									
-									<checkbox :value="String(item.id)"  class='round blue ' :class="{'checked':checkedArr.includes(String(item.id))}"  :checked="checkedArr.includes(String(item.id))">
-									</checkbox> 
+
+								<checkbox :value="String(item.id)" class='round blue '
+									:class="{'checked':checkedArr.includes(String(item.id))}"
+									:checked="checkedArr.includes(String(item.id))">
+								</checkbox>
 							</view>
-							
-							<view class="cu-avatar lg" :style="{'left':handleStatus==2 ? '60rpx':'0'}"  style="background-image:url(../../static/processed-icon.png);"></view>
+
+							<view class="cu-avatar lg" :style="{'left':handleStatus==2 ? '60rpx':'0'}"
+								style="background-image:url(../../static/processed-icon.png);"></view>
 							<view class="content" :style="{'left':handleStatus==2 ? '180rpx':'120rpx'}">
 								<view class="pro-title">
 									<view class="cut">{{item.measName}}</view>
@@ -101,33 +103,42 @@
 								<view class="pro-date ">{{item.soeTime}}</view>
 							</view>
 							<view class="action" style="z-index:99;width:180rpx;text-align:right">
-								<view class="processed" v-if="item.handling_status==1" @tap="goProcessedDetail(item.id)">
+								<view class="processed" v-if="item.handling_status==1"
+									@tap="goProcessedDetail(item)">
 									已处理
 									<text class="icon iconfont margin-left-xs  margin-right-xs">&#xe629;</text>
 								</view>
-								<view style="color:#FF8125" v-if="item.handling_status==2" @tap="goProcessedDetail(item.id)">待确认
-								<text class="icon iconfont margin-left-xs margin-right-xs">&#xe629;</text>
+								<view style="color:#FF8125" v-if="item.handling_status==2"
+									@tap="goProcessedDetail(item)">待确认
+									<text class="icon iconfont margin-left-xs margin-right-xs">&#xe629;</text>
 								</view>
-								<view style="color:#4274E7" v-if="item.handling_status==3" @tap="goProcessedDetail(item.id)">自动回复
-								<text class="icon iconfont margin-left-xs margin-right-xs">&#xe629;</text>
+								<view style="color:#4274E7" v-if="item.handling_status==3"
+									@tap="goProcessedDetail(item)">自动回复
+									<text class="icon iconfont margin-left-xs margin-right-xs">&#xe629;</text>
 								</view>
-								<view style="color:#999999" v-if="item.handling_status==4" @tap="goProcessedDetail(item.id)">过期失效
-								<text class="icon iconfont margin-left-xs margin-right-xs">&#xe629;</text>
+								<view style="color:#999999" v-if="item.handling_status==4"
+									@tap="goProcessedDetail(item)">过期失效
+									<text class="icon iconfont margin-left-xs margin-right-xs">&#xe629;</text>
 								</view>
-								
+
 							</view>
-						</view>
+						</view>
 						<view class="text-center margin-top" v-if="alarmUntreatedCount1 === 0">暂无数据...</view>
 					</view>
-					</checkbox-group>
 
-				
-					
-			
+					<view v-if="this.handleStatus==2" class="btn-area submitBottomBtn padding-lr-sm">
+						<button class="bg-blue round  margin-top" @click="$noMultipleClicks(quickConfirm)">快速确认 </button>
+					</view>
+
+				</checkbox-group>
+
+
+
+
 
 
 			</view>
-			
+
 		</block>
 
 	</view>
@@ -138,8 +149,9 @@
 	export default {
 		data() {
 			return {
-				allChecked:false,
-				
+				noClick:true,
+				allChecked: false,
+
 				checkbox: [{
 					value: 'A',
 					checked: true
@@ -150,9 +162,9 @@
 					value: 'C',
 					checked: false
 				}],
-				handleStatus:0,
-				checkedArr:[],
-				
+				handleStatus: 0,
+				checkedArr: [],
+
 				// unporcessList: json.unprocessList,
 				unporcessList: [],
 				porcessedList: [],
@@ -167,26 +179,26 @@
 				alarmUntreatedCount: '',
 				alarmUntreatedCount1: '',
 				processingStatus: '',
-				
-				
-		
+
+
+
 			};
 		},
-		watch:{
-			handleStatus(val){
+		watch: {
+			handleStatus(val) {
 				// this.porcessedList={};
 				this.getProcessData({
 					"companyCode": this.companyCode,
 					"type": this.type,
 					"processingStatus": val
-				},  this.TabCur);
-				
+				}, this.TabCur);
+
 			}
 		},
 		computed: {
-		
+
 		},
-		
+
 		onLoad: function(option) {
 
 			console.log(option.type);
@@ -213,6 +225,54 @@
 		},
 		methods: {
 			
+			quickConfirm(){
+				
+				// alert( this.formMess.start_time)
+				if (!this.checkedArr.length) {
+					uni.showToast({
+						title: "请至少选择一条需要确认的数据",
+						icon: "none"
+					});
+					return
+				}
+				
+				console.log(this.checkedArr)
+				
+				this.quickConfirmRes({
+					"id": this.checkedArr.toString(),
+					"companyCode": this.companyCode,
+					
+				})
+				
+				
+			},
+			
+			// 请求
+			async quickConfirmRes(ming = {}) {
+				const res = await this.$myRequest({
+					url: 'IntegratedAlarm/setBatchProcessing',
+					data: ming
+				})
+				if (!res.data.flag) {
+					uni.showToast({
+						title: "添加失败",
+						icon: "none"
+					});
+				} else {
+					uni.showToast({
+						title: "添加成功",
+					});
+				}
+				setTimeout(() => {
+					uni.navigateTo({
+						
+					
+						url: '/pages/processList/processList?companyCode=' + this.companyCode +
+							'&type=1'
+					});
+				}, 1000);
+			},
+
 			// 全选事件
 			allChoose(e) {
 				let chooseItem = e.detail.value;
@@ -231,8 +291,8 @@
 					this.checkedArr = [];
 				}
 			},
-			
-			changeCheckbox(e){
+
+			changeCheckbox(e) {
 				this.checkedArr = e.detail.value;
 				// 如果选择的数组中有值,并且长度等于列表的长度,就是全选
 				if (this.checkedArr.length > 0 && this.checkedArr.length == this.porcessedList.length) {
@@ -245,8 +305,8 @@
 			async getProcessData(ming = {}, whichTab) {
 				const res = await this.$myRequest({
 					url: 'IntegratedAlarm/getElectricAlarmUntreated',
-					data: ming,
-					showLoading:true
+					data: ming,
+					showLoading: true
 
 				})
 
@@ -254,25 +314,25 @@
 					this.unporcessList = res.data.data;
 					this.alarmUntreatedCount = parseInt(res.data.alarmUntreatedCount)
 				} else {
-				
+
 					this.porcessedList = res.data.data;
 					this.alarmUntreatedCount1 = parseInt(res.data.alarmUntreatedCount)
 
 				}
 
 
-				  console.log(this.porcessedList)
+				console.log(this.porcessedList)
 			},
 
 			tabSelect(e) {
 				console.log(e.currentTarget);
 				this.TabCur = e.currentTarget.dataset.id;
 				this.scrollLeft = (e.currentTarget.dataset.id - 1) * 60;
-
+				this.handleStatus=0
 				this.getProcessData({
 					"companyCode": this.companyCode,
 					"type": this.type,
-					"processingStatus": !e.currentTarget.dataset.id?e.currentTarget.dataset.id:'1,2,3,4'
+					"processingStatus": !e.currentTarget.dataset.id ? e.currentTarget.dataset.id : '1,2,3,4'
 				}, this.TabCur);
 
 
@@ -282,7 +342,8 @@
 			// 页面跳转
 			goUnprocessDetail(id) {
 				uni.navigateTo({
-					url: '/pages/unprocessDetail/unprocessDetail?companyCode=' + this.companyCode + '&processingStatus=0&id=' + id +
+					url: '/pages/unprocessDetail/unprocessDetail?companyCode=' + this.companyCode +
+						'&processingStatus=0&id=' + id +
 						'&type=1',
 					success: res => {},
 					fail: () => {},
@@ -291,17 +352,19 @@
 			},
 			goVideoUnprocessDetail(id) {
 				uni.navigateTo({
-					url: '/pages/unprocessDetail/unprocessDetail?companyCode=' + this.companyCode + '&processingStatus=0&id=' + id +
+					url: '/pages/unprocessDetail/unprocessDetail?companyCode=' + this.companyCode +
+						'&processingStatus=0&id=' + id +
 						'&type=2',
 					success: res => {},
 					fail: () => {},
 					complete: () => {}
 				});
 			},
-			goProcessedDetail(id) {
+			goProcessedDetail(item) {
 				uni.navigateTo({
-					url: '/pages/processedDetail/processedDetail?companyCode=' + this.companyCode + '&processingStatus=' + this.processingStatus +
-						'&id=' + id + '&type=1',
+					url: '/pages/processedDetail/processedDetail?companyCode=' + this.companyCode +
+						'&handling_status=' + item.handling_status +
+						'&id=' + item.id + '&type=1',
 					success: res => {},
 					fail: () => {},
 					complete: () => {}
@@ -310,14 +373,15 @@
 
 			goVideoProcessedDetail(id) {
 				uni.navigateTo({
-					url: '/pages/processedDetail/processedDetail?companyCode=' + this.companyCode + '&processingStatus=' + this.processingStatus +
+					url: '/pages/processedDetail/processedDetail?companyCode=' + this.companyCode +
+						'&processingStatus=' + this.processingStatus +
 						'&id=' + id + '&type=2',
 					success: res => {},
 					fail: () => {},
 					complete: () => {}
 				});
 			},
-			
+
 			InputFocus(e) {
 				this.InputBottom = e.detail.height
 			},
@@ -329,6 +393,12 @@
 </script>
 
 <style lang="scss">
+	.handle2scroll {
+		height: calc(100vh - 400rpx);
+		overflow: scroll;
+
+	}
+
 	//已处理未处理消息个数样式
 
 	.nav .cu-item.cur {
@@ -350,5 +420,8 @@
 		.lines-blue {
 			color: #4274E7
 		}
+
+
+
 	}
 </style>

+ 141 - 11
pages/processedDetail/processedDetail.vue

@@ -1,9 +1,30 @@
 <template>
 	<view class="dealDetail">
-		<view class="timeBox flex justify-between align-center padding-lr-sm">
-			<view class="time">{{type==1?detailMessage.time:detailMessage2.time}}</view>
+		
+		<view v-if="type==2" class="timeBox flex justify-between align-center padding-lr-sm">
+			<view class="time">{{detailMessage2.time}}</view>
 			<button class="cu-btn radius bg-green sm">已处理</button>
-		</view>
+		</view>
+		
+		<view v-else class="timeBox flex justify-between align-top padding-sm " style="height:auto;">
+			<view >
+				<view>发生时间:{{detailMessage.time}}</view>
+				<view>告警历时:{{detailMessage.duration}}</view>
+				<view>关联告警:{{detailMessage.handlerTime}}</view>
+				<view style="color:#4074E7">【{{detailMessage.route_name}}】设备低压-{{detailMessage.digitalValue=='1'?'动作':'复归'}}</view>
+				<!-- <view class="time">{{detailMessage.time}}</view> -->
+				<!-- <view>dfd</view> -->
+			</view>
+			
+			<button  v-if="handling_status==1" class="cu-btn radius bg-green sm margin-top-sm">已处理</button>
+			<button  v-if="handling_status==2" class="cu-btn radius bg-orange sm margin-top-sm">待确认</button>
+			<button  v-if="handling_status==3" class="cu-btn radius bg-blue sm margin-top-sm">自动恢复</button>
+			<button  v-if="handling_status==4" class="cu-btn radius bg-gray sm margin-top-sm">过期失效</button>
+			
+		
+		</view>
+		
+		
 		<view v-if="type==1">
 			<!-- 基本信息start -->
 			<view class="basic-info dealDetail">
@@ -18,7 +39,7 @@
 					</view>
 					<view class="info-one-info ">
 						<text>台区展示:</text>
-						<text>等待对接中.....</text>
+						<text>{{detailMessage.platform_area_name}}</text>
 					</view>
 					<view>
 						<text>线路名称:</text>
@@ -64,7 +85,7 @@
 			</view>
 			<!-- 基本信息end -->
 			<!-- 处理信息start -->
-			<view class="processStatus">
+			<view class="processStatus"  v-if="this.handling_status!=2">
 				<view class="info-tit margin-left-xs">
 					<text class="cuIcon-titles margin-right-xs"></text>
 					处理信息
@@ -88,6 +109,29 @@
 			
 			
 			</view>
+			<!-- 处理状态end -->
+			
+			<!-- 处理状态start -->
+			<view class="processStatus" v-if="this.handling_status==2">
+				<view class="info-tit margin-left-xs">
+					<text class="cuIcon-titles margin-right-xs"></text>
+					处理内容
+				</view>
+				<view class="padding-lr padding-bottom-lg">
+					<form action="">
+						<view class="cu-form-group">
+							<!-- <textarea maxlength="-1" :disabled="modalName!=null" @input="textareaAInput" placeholder="备注信息,最多可输入50个字..."></textarea>-->
+							<textarea class="JTxtArea lg" v-model="msg" placeholder="备注信息,最多可输入50个字..." :maxlength="50" :data-maxnum="reason.length+'/50'"
+							 auto-height></textarea>
+						</view>
+			
+						<view class="btn-area">
+							<!-- <button class="bg-orange round missReport margin-top">误 报 </button> -->
+							<button class="bg-blue round  missReport margin-top" @click="powerSubmit()">告警确认 </button>
+						</view>
+					</form>
+				</view>
+			</view>
 			<!-- 处理状态end -->
 		</view>
 		
@@ -165,28 +209,77 @@
 	export default {
 		data() {
 			return {
+				msg:'',
+				reason: '',
 				radio: 'A',
 				radio: 'B',
 				modalName: null,
 				type: '0',
-				detailMessage:{},
-				detailMessage2:{}
+				detailMessage:{},	
+				detailMessage2:{},
+				
+				handling_status:0
 			}
 		},
-		onLoad: function(option) {
+		onLoad: function(option) {
+			this.handling_status=option.handling_status;
 			this.type = option.type;
 			this.companyCode = option.companyCode;
-			this.processingStatus=option.processingStatus;
+			this.processingStatus=option.handling_status;
 			this.alarmId = option.id;
 			if(this.type==1){
-				this.getUnProcessDetail({"companyCode":option.companyCode,"processingStatus":option.processingStatus,"alarmId":option.id})
+				this.getUnProcessDetail({"companyCode":option.companyCode,"processingStatus":option.handling_status,"alarmId":option.id})
 			}else{
 				this.getVideoDetail({"companyCode":option.companyCode,"processingStatus":option.processingStatus,"alarmId":option.id})
 			}
 			
 			
 		},
-		methods: {
+		methods: {
+			
+			powerSubmit() {
+				if(!this.msg){
+					uni.showToast({
+						title: "请输入处理内容",
+						icon:"none"
+					});
+				}else{
+					this.powerSubmitRes({
+						"type": 1,
+						"deviceCode": this.detailMessage.deviceCode,
+						"companyCode": this.companyCode,
+						"id": this.detailMessage.id,
+						"handlerContent": this.msg
+					})
+				}
+				
+				
+			},
+			
+			async powerSubmitRes(params = {}) {
+				const res = await this.$myRequest({
+					url: 'IntegratedAlarm/setAlarmHandle',
+					data: params
+				})
+				
+			   if(res.data.flag){
+				  uni.showToast({
+				  	title: "提交成功",
+				  });
+			   }
+			   
+			   setTimeout(() => {
+			   	uni.navigateTo({
+			   		url: '/pages/processList/processList?companyCode=' + this.companyCode + '&type='+this.type+'',
+			   
+			   	});
+			   }, 1000);
+			 
+				
+			},
+			
+			
+			
 			async getUnProcessDetail(ming={}) {
 				const res= await this.$myRequest({
 					url:'IntegratedAlarm/getPowerAlarmDetails',
@@ -268,6 +361,10 @@
 			textareaAInput(e) {
 				this.textareaAValue = e.detail.value
 			},
+			// textarea
+			inputReason(e) {
+				this.reason = e.detail.value;
+			}
 
 		}
 	}
@@ -300,4 +397,37 @@
 		width: 160rpx;
 		display: inline-block
 	}
+	
+	/* // 处理内容 */
+	.cu-form-group {
+		background: #f5f5f5;
+	
+	}
+	
+	.processStatus {
+		textarea {
+			background: #F5F5F5;
+			color: #999999;
+		}
+	}
+	
+	// textarea
+	.JTxtArea {
+		position: relative;
+	
+		&.sm {
+			min-height: 60rpx;
+		}
+	
+		&.lg {
+			min-height: 100rpx;
+		}
+	
+		&:after {
+			content: attr(data-maxnum);
+			position: absolute;
+			right: 10rpx;
+			bottom: 0px;
+		}
+	}
 </style>

+ 147 - 17
pages/processedDetail1/processedDetail1.vue

@@ -1,12 +1,33 @@
 <template>
 	<view class="dealDetail">
-		<view class="timeBox flex justify-between align-center padding-lr-sm">
-			<view class="time">{{type==1?detailMessage.time:detailMessage2.time}}</view>
+		
+		<view v-if="type==2" class="timeBox flex justify-between align-center padding-lr-sm">
+			<view class="time">{{detailMessage2.time}}</view>
 			<button class="cu-btn radius bg-green sm">已处理</button>
-		</view>
+		</view>
+		
+		<view v-else class="timeBox flex justify-between align-top padding-sm " style="height:auto;">
+			<view >
+				<view>发生时间:{{detailMessage.time}}</view>
+				<view>告警历时:{{detailMessage.duration}}</view>
+				<view>关联告警:{{detailMessage.handlerTime}}</view>
+				<view style="color:#4074E7">【{{detailMessage.route_name}}】设备低压-{{detailMessage.digitalValue=='1'?'动作':'复归'}}</view>
+				<!-- <view class="time">{{detailMessage.time}}</view> -->
+				<!-- <view>dfd</view> -->
+			</view>
+			
+			<button  v-if="handling_status==1" class="cu-btn radius bg-green sm margin-top-sm">已处理</button>
+			<button  v-if="handling_status==2" class="cu-btn radius bg-orange sm margin-top-sm">待确认</button>
+			<button  v-if="handling_status==3" class="cu-btn radius bg-blue sm margin-top-sm">自动恢复</button>
+			<button  v-if="handling_status==4" class="cu-btn radius bg-gray sm margin-top-sm">过期失效</button>
+			
+		
+		</view>
+		
+		
 		<view v-if="type==1">
 			<!-- 基本信息start -->
-			<view class="basic-info">
+			<view class="basic-info dealDetail">
 				<view class="info-tit margin-left-xs">
 					<text class="cuIcon-titles margin-right-xs"></text>
 					基本信息
@@ -18,7 +39,7 @@
 					</view>
 					<view class="info-one-info ">
 						<text>台区展示:</text>
-						<text>等待对接中.....</text>
+						<text>{{detailMessage.platform_area_name}}</text>
 					</view>
 					<view>
 						<text>线路名称:</text>
@@ -30,7 +51,7 @@
 					</view>
 					<view>
 						<text>警告状态:</text>
-						<text>{{detailMessage.digitalValue=="1"?'动作':'复归'}}</text>
+						<text>{{detailMessage.digitalValue=='1'?'动作':'复归'}}</text>
 					</view>
 					<view>
 						<text>采集终端:</text>
@@ -64,7 +85,7 @@
 			</view>
 			<!-- 基本信息end -->
 			<!-- 处理信息start -->
-			<view class="processStatus">
+			<view class="processStatus"  v-if="this.handling_status!=2">
 				<view class="info-tit margin-left-xs">
 					<text class="cuIcon-titles margin-right-xs"></text>
 					处理信息
@@ -88,6 +109,29 @@
 			
 			
 			</view>
+			<!-- 处理状态end -->
+			
+			<!-- 处理状态start -->
+			<view class="processStatus" v-if="this.handling_status==2">
+				<view class="info-tit margin-left-xs">
+					<text class="cuIcon-titles margin-right-xs"></text>
+					处理内容
+				</view>
+				<view class="padding-lr padding-bottom-lg">
+					<form action="">
+						<view class="cu-form-group">
+							<!-- <textarea maxlength="-1" :disabled="modalName!=null" @input="textareaAInput" placeholder="备注信息,最多可输入50个字..."></textarea>-->
+							<textarea class="JTxtArea lg" v-model="msg" placeholder="备注信息,最多可输入50个字..." :maxlength="50" :data-maxnum="reason.length+'/50'"
+							 auto-height></textarea>
+						</view>
+			
+						<view class="btn-area">
+							<!-- <button class="bg-orange round missReport margin-top">误 报 </button> -->
+							<button class="bg-blue round  missReport margin-top" @click="powerSubmit()">告警确认 </button>
+						</view>
+					</form>
+				</view>
+			</view>
 			<!-- 处理状态end -->
 		</view>
 		
@@ -165,31 +209,80 @@
 	export default {
 		data() {
 			return {
+				msg:'',
+				reason: '',
 				radio: 'A',
 				radio: 'B',
 				modalName: null,
 				type: '0',
-				detailMessage:{},
-				detailMessage2:{}
+				detailMessage:{},	
+				detailMessage2:{},
+				
+				handling_status:0
 			}
-		},
-		mounted(){
-			document.querySelector('.uni-page-head-hd').style.display = 'none'
-		},
-		onLoad: function(option) {
+		},
+		mounted(){
+					document.querySelector('.uni-page-head-hd').style.display = 'none'
+				},
+		onLoad: function(option) {
+			this.handling_status=option.handling_status;
 			this.type = option.type;
 			this.companyCode = option.companyCode;
-			this.processingStatus=option.processingStatus;
+			this.processingStatus=option.handling_status;
 			this.alarmId = option.id;
 			if(this.type==1){
-				this.getUnProcessDetail({"companyCode":option.companyCode,"processingStatus":option.processingStatus,"alarmId":option.id})
+				this.getUnProcessDetail({"companyCode":option.companyCode,"processingStatus":option.handling_status,"alarmId":option.id})
 			}else{
 				this.getVideoDetail({"companyCode":option.companyCode,"processingStatus":option.processingStatus,"alarmId":option.id})
 			}
 			
 			
 		},
-		methods: {
+		methods: {
+			
+			powerSubmit() {
+				if(!this.msg){
+					uni.showToast({
+						title: "请输入处理内容",
+						icon:"none"
+					});
+				}else{
+					this.powerSubmitRes({
+						"type": 1,
+						"deviceCode": this.detailMessage.deviceCode,
+						"companyCode": this.companyCode,
+						"id": this.detailMessage.id,
+						"handlerContent": this.msg
+					})
+				}
+				
+				
+			},
+			
+			async powerSubmitRes(params = {}) {
+				const res = await this.$myRequest({
+					url: 'IntegratedAlarm/setAlarmHandle',
+					data: params
+				})
+				
+			   if(res.data.flag){
+				  uni.showToast({
+				  	title: "提交成功",
+				  });
+			   }
+			   
+			   setTimeout(() => {
+			   	uni.navigateTo({
+			   		url: '/pages/processList/processList?companyCode=' + this.companyCode + '&type='+this.type+'',
+			   
+			   	});
+			   }, 1000);
+			 
+				
+			},
+			
+			
+			
 			async getUnProcessDetail(ming={}) {
 				const res= await this.$myRequest({
 					url:'IntegratedAlarm/getPowerAlarmDetails',
@@ -271,6 +364,10 @@
 			textareaAInput(e) {
 				this.textareaAValue = e.detail.value
 			},
+			// textarea
+			inputReason(e) {
+				this.reason = e.detail.value;
+			}
 
 		}
 	}
@@ -303,4 +400,37 @@
 		width: 160rpx;
 		display: inline-block
 	}
+	
+	/* // 处理内容 */
+	.cu-form-group {
+		background: #f5f5f5;
+	
+	}
+	
+	.processStatus {
+		textarea {
+			background: #F5F5F5;
+			color: #999999;
+		}
+	}
+	
+	// textarea
+	.JTxtArea {
+		position: relative;
+	
+		&.sm {
+			min-height: 60rpx;
+		}
+	
+		&.lg {
+			min-height: 100rpx;
+		}
+	
+		&:after {
+			content: attr(data-maxnum);
+			position: absolute;
+			right: 10rpx;
+			bottom: 0px;
+		}
+	}
 </style>

+ 0 - 4
pages/unprocessDetail/unprocessDetail.vue

@@ -88,11 +88,7 @@
 							<!-- <button class="bg-orange round missReport margin-top">误 报 </button> -->
 							<button class="bg-blue round  missReport margin-top" @click="powerSubmit()">告警确认 </button>
 						</view>
-
 					</form>
-
-
-
 				</view>
 			</view>
 			<!-- 处理状态end -->