From 0e7b3d2053fbde9074ff770a0a31e05fe8fc0cc6 Mon Sep 17 00:00:00 2001
From: linwe <872216996@qq.com>
Date: Fri, 14 Jun 2024 19:44:57 +0800
Subject: [PATCH] E呼即办事件分享
---
api/task/ecall.js | 83 ++++
subPackage/ecall/index.vue | 271 +++++++++++++++
subPackage/ecall/detail.vue | 620 ++++++++++++++++++++++++++++++++++++
3 files changed, 974 insertions(+), 0 deletions(-)
diff --git a/api/task/ecall.js b/api/task/ecall.js
new file mode 100644
index 0000000..1e31f68
--- /dev/null
+++ b/api/task/ecall.js
@@ -0,0 +1,83 @@
+import http from '@/http/api.js'
+
+
+
+export const getPage = (params) => {
+ return http.request({
+ url: '/blade-eCallEventTwo/eCallEventTwo/page',
+ method: 'GET',
+ params: {
+ ...params
+ }
+ })
+}
+
+
+export const getDetail = (params) => {
+ return http.request({
+ url: '/blade-eCallEventTwo/eCallEventTwo/detail',
+ method: 'GET',
+ params: {
+ ...params
+ }
+ })
+}
+
+
+//添加
+export const save = (data) => {
+ return http.request({
+ url: '/blade-taskReportForRepairs/taskReportForRepairs/save',
+ method: 'POST',
+ data: data
+ })
+}
+
+export const checkReportForRepairsData = (data) => {
+ return http.request({
+ url: 'blade-taskReportForRepairs/taskReportForRepairs/checkReportForRepairs ',
+ method: 'POST',
+ data
+ })
+}
+
+//报事报修数据统计
+export const getRepairsStatistics = (params) => {
+ return http.request({
+ url: 'blade-taskReportForRepairs/taskReportForRepairs/getStatistics',
+ method: 'GET',
+ params: {
+ ...params
+ }
+ })
+}
+//报事报修数据统计 (数据驾驶舱)
+export const getReportStatistics = (params) => {
+ return http.request({
+ url: 'blade-taskReportForRepairs/taskReportForRepairs/getReportForStatistics',
+ method: 'GET',
+ params: {
+ ...params
+ }
+ })
+}
+
+//报事报修处理
+export const reportSave = (data) => {
+ return http.request({
+ url: 'blade-task/taskRepairStep/save',
+ method: 'POST',
+ data
+ })
+}
+
+//获取e呼即办详情
+export const getEcallEventDetail = (params) => {
+ return http.request({
+ url: 'blade-eCallEvent/eCallEvent/detail',
+ method: 'GET',
+ params: {
+ ...params
+ }
+ })
+}
\ No newline at end of file
diff --git a/subPackage/ecall/detail.vue b/subPackage/ecall/detail.vue
new file mode 100644
index 0000000..b82c517
--- /dev/null
+++ b/subPackage/ecall/detail.vue
@@ -0,0 +1,620 @@
+<template>
+ <view class="container">
+ <view class="">
+ <view>
+ <!-- 注意,如果需要兼容微信小程序,最好通过setRules方法设置rules规则 -->
+ <u--form labelPosition="left" :model="from" ref="uForm">
+ <u-form-item label="姓名" prop="applicantName" borderBottom ref="item1">
+ <u--input :disabled="true" inputAlign="center" v-model="from.applicantName"
+ border="none"></u--input>
+ </u-form-item>
+
+ <u-form-item labelWidth="80" label="手机" prop="applicantPhone" borderBottom ref="item1">
+ <u--input :disabled="true" inputAlign="center" v-model="from.applicantPhone"
+ border="none"></u--input>
+ </u-form-item>
+
+ <u-form-item labelWidth="80" label="事发地" prop="sceneAddr" borderBottom ref="item1">
+ <u--input :disabled="true" inputAlign="center" v-model="from.sceneAddr"
+ border="none"></u--input>
+ </u-form-item>
+
+
+ <u-form-item labelWidth="80" label="时间" prop="createTime" borderBottom ref="item1">
+ <u--input inputAlign="center" v-model="from.createTime" border="none"></u--input>
+ </u-form-item>
+
+ <u-form-item labelWidth="80" label="调度单位" prop="acptOrgName" borderBottom ref="item1">
+ <u--input :disabled="true" inputAlign="center" v-model="from.acptOrgName"
+ border="none"></u--input>
+ </u-form-item>
+
+ <u-form-item labelWidth="80" label="问题标题" prop="issueTitle" borderBottom ref="item1">
+ <u--input :disabled="true" inputAlign="center" v-model="from.issueTitle"
+ border="none"></u--input>
+ </u-form-item>
+
+ <u-form-item labelWidth="80" label="问题描述" prop="issueContent" borderBottom ref="item1">
+ <!-- <u--input v-model="from.issueContent" border="none"></u--input> -->
+ <u--textarea :disabled="true" v-model="from.issueContent" autoHeight
+ placeholder="请输入内容"></u--textarea>
+ </u-form-item>
+ </u--form>
+ </view>
+ </view>
+
+ <view class="footer flex a-i-c j-c-s-b" v-if="!types">
+ <!-- <button class="footer-btn" @click="submit(0)">处置</button> -->
+ <button class="footer-btn" @click="submit(2)">共享</button>
+ <!-- <button class="footer-btn" @click="submit(1)">转办</button> -->
+ </view>
+ <u-picker :defaultIndex="[defaultColums]" :closeOnClickOverlay="true" @close="isPickerShow = false"
+ :show="isPickerShow" ref="uPicker" :columns="columns" keyName="name" @cancel="isPickerShow = false"
+ @confirm="handleConfirm"></u-picker>
+
+ <u-picker :defaultIndex="peopleIndex" :closeOnClickOverlay="true" @close="isShowPeoplePicker = false"
+ :show="isShowPeoplePicker" ref="pPicker" :columns="peopleList" keyName="name"
+ @cancel="isShowPeoplePicker = false" @confirm="handlePeopleConfirm" @change="changePeople"></u-picker>
+
+ <u-popup :show="show" mode="bottom" @close="close" :round="10" :closeable="true">
+ <view class="popup-title">
+ 共享
+ </view>
+ <view style="margin-top: 20rpx 0rpx;" class="popup-content">
+ <u-checkbox-group v-model="radiovalue1" @change="groupChange" iconPlacement="right" placement="column">
+ <view v-for="(item, index) in radiolist1" style="padding:10rpx 0;">
+ <u-checkbox :customStyle="{marginBottom: '8px'}" :key="index" :label="item.name" :name="item.id"
+ @change="radioChange">
+ </u-checkbox>
+ </view>
+ </u-checkbox-group>
+ <view class="popup-btn flex a-i-c j-c-s-b">
+ <button class="popup-btn-item" @click="pushCircle">确认</button>
+ </view>
+ </view>
+ </u-popup>
+ </view>
+</template>
+
+<script>
+ import {
+ getDetail
+ } from '@/api/task/ecall.js'
+ import {
+ getPeopleType
+ } from '@/api/user.js'
+ import {
+ handlePublish
+ } from '@/api/circle/circle.js'
+ import {
+ minioBaseUrl
+ } from "@/common/setting.js"
+ import uploadMixin from "@/mixin/uploadMixin";
+ export default {
+ mixins: [uploadMixin],
+ components: {
+ // captionRow,
+ // lineItem
+ },
+ data() {
+ return {
+ basicData: [{
+ label: '事发地',
+ name: 'address',
+ value: '未完善'
+ },
+ {
+ label: '姓名',
+ name: 'realName',
+ value: '未完善'
+ },
+ {
+ label: '手机号码',
+ name: 'phone',
+ value: '未完善'
+ },
+ {
+ label: '事件类型',
+ name: 'type',
+ value: '未完善'
+ },
+ {
+ label: '事件描述',
+ name: 'remark',
+ value: '未完善'
+ },
+ {
+ label: '提交时间',
+ name: 'createTime',
+ value: '未完善'
+ }
+ ],
+ typeList: [{
+ name: "公共维修",
+ type: 1
+ },
+ {
+ name: "居家维修",
+ type: 2
+ },
+ {
+ name: "矛盾纠纷",
+ type: 3
+ },
+ {
+ name: "投诉举报",
+ type: 4
+ },
+ {
+ name: "企业商户上报",
+ type: 5
+ },
+ {
+ name: "统战上报",
+ type: 6
+ }
+ ],
+ form: {
+ confirmFlag: '',
+ confirmNotion: '',
+ imageList: [],
+ videoList: []
+ },
+ defaultPlaceholder: "",
+ defaultColums: 0,
+ imgUrls: [],
+ currentId: '',
+ defaultData: {
+ taskRepairStepList: []
+ },
+ isPickerShow: false,
+ columns: [
+ [{
+ name: "待处理",
+ status: 1
+ },
+ {
+ name: "处理中",
+ status: 2
+ },
+ {
+ name: "已处理",
+ status: 3
+ },
+ ]
+ ],
+ from: {},
+ peopleList: [
+ [{
+ name: "网格员",
+ type: 0
+ },
+ {
+ name: "物业人员",
+ type: 2
+ }
+ ],
+ []
+ ],
+ // 基本案列数据
+ radiolist1: [{
+ name: '邻里圈',
+ disabled: false,
+ id: 0
+ },
+ {
+ name: '协同圈',
+ disabled: false,
+ id: 1
+ }
+ ],
+ // u-radio-group的v-model绑定的值如果设置为某个radio的name,就会被默认选中
+ radiovalue1: [],
+ peopleIndex: [0, 0],
+ isShowPeoplePicker: false,
+ transferUserId: "",
+ content: "",
+ confirmFlag: "",
+ show: false,
+ types: ''
+
+ }
+ },
+ onLoad(option) {
+ // const { id } = option
+ // this.currentId = id
+
+ if (option.id) {
+ this.getEcallDetail(option.id)
+ }
+ if (option.types) {
+ this.types = option.types
+ }
+ },
+ onShow() {},
+ methods: {
+ getEcallDetail(id) {
+ getDetail({
+ id: id
+ }).then(res => {
+ this.from = res.data;
+ })
+ },
+ pushCircle() {
+ this.radiovalue1.forEach(item => {
+ let data = {
+ eventId: this.from.id,
+ evenType: 3,
+ circleType: item,
+ circleText: this.from.issueContent,
+ }
+ handlePublish(data).then(res => {
+ this.$showTips("操作成功", "success")
+ this.close()
+ })
+ })
+ },
+ close() {
+ this.show = false
+ },
+ groupChange(n) {
+ console.log('groupChange', n);
+ },
+ radioChange(n) {
+ console.log('radioChange', n);
+ },
+ getPeopleList(type) {
+ getPeopleType({
+ houseCode: this.defaultData.addressCode,
+ type
+ }).then(res => {
+ console.log(res);
+ this.$set(this.peopleList, 1, res.data);
+ })
+ },
+
+ showPicker() {
+ if (this.from == "list") {
+ this.isPickerShow = true;
+ }
+ },
+
+ setImgUrl(url) {
+ return `${minioBaseUrl}${url}`
+ },
+
+ async checkReportForRepairs() {
+ const {
+ confirmFlag,
+ confirmNotion
+ } = this.form
+
+ if (!confirmNotion) {
+ uni.showToast({
+ title: "请输入处理情况",
+ icon: "none"
+ })
+ return;
+ }
+
+ const res = await checkReportForRepairsData({
+ // id: this.currentId,
+ id: this.defaultData.id,
+ // confirmFlag: this.findObjValue(confirmFlag, this.columns[0], 'name').status,
+ confirmFlag: 3,
+ confirmNotion
+ })
+
+ if (res.code !== 200) {
+ uni.showToast({
+ title: "提交处理失败",
+ icon: "error"
+ })
+ return
+ }
+
+ uni.showToast({
+ title: "处理事件成功",
+ icon: "success",
+ duration: 1500,
+ complete() {
+ setTimeout(() => {
+ uni.navigateBack()
+ }, 1500)
+ }
+ })
+ },
+
+ setDefaultValue() {
+ console.log(this.defaultData);
+ this.basicData.forEach(item => {
+ item.value = this.defaultData[item.name] || '未完善'
+ if (item.name === 'type') {
+ item.value = this.findObjValue(item.value, this.typeList, 'type').name || '未完善'
+ }
+ })
+ this.imgUrls = this.$setImageUrl(this.defaultData.imageUrls);
+ //if(this.defaultData.imageUrls){
+ // let list = this.defaultData.imageUrls.split(",")
+ // let arr = []
+ // for(let i of list){
+ // arr.push(`${minioBaseUrl}${i}`);
+ // }
+ //}
+
+ let columns = this.columns[0]
+ this.defaultColums = columns.findIndex(item => item.status == this.defaultData.confirmFlag)
+ this.defaultPlaceholder = columns[this.defaultColums].name
+ },
+
+ submit(type) {
+ if (type == 1) {
+ this.isShowPeoplePicker = true;
+ } else if (type == 2) {
+ this.show = true
+ } else {
+ if (!this.form.confirmNotion) {
+ uni.showToast({
+ title: "请输入处理情况",
+ icon: "none"
+ })
+ return;
+ }
+
+ let data = {
+ confirmFlag: 3,
+ content: this.form.confirmNotion,
+ imageList: this.getFileName(this.form.imageList),
+ mobile: this.defaultData.mobile,
+ peopleType: 0,
+ repairId: this.defaultData.id,
+ videoList: this.getFileName(this.form.videoList)
+ }
+ this.submitRequest(data)
+ }
+ // this.checkReportForRepairs()
+ },
+
+ getFileName(urls) {
+ if (urls.length) {
+ let arr = [];
+ for (let i of urls) {
+ arr.push(i.name);
+ }
+ return arr.join(",");
+ } else {
+ return ""
+ }
+ },
+
+
+ submitRequest(data) {
+ reportSave(data).then(res => {
+ if (res.code == 200) {
+ uni.showToast({
+ title: "操作成功"
+ })
+ uni.navigateBack()
+ }
+ })
+ },
+
+ handleConfirm(e) {
+ this.form.confirmFlag = e.value[0].name
+ this.isPickerShow = false
+ },
+ findObjValue(value, obj, word) {
+ const res = obj.find(item => {
+ return item[word] == value
+ })
+ return res
+ },
+
+ previewImg(url) {
+ uni.previewImage({
+ urls: this.imgUrls,
+ current: url
+ })
+ },
+
+
+ changePeople(e) {
+ console.log(e);
+ const {
+ columnIndex,
+ value,
+ values, // values为当前变化列的数组内容
+ index,
+ // 微信小程序无法将picker实例传出来,只能通过ref操作
+ picker = this.$refs.pPicker
+ } = e
+ if (columnIndex === 0) {
+ // picker为选择器this实例,变化第二列对应的选项
+ // picker.setColumnValues(1, this.columnData[index])
+ this.getPeopleList(value[0].type)
+ }
+ },
+
+ handlePeopleConfirm(e) {
+ console.log(e)
+ let {
+ value,
+ indexs
+ } = e;
+ this.transferUserId = value[1].id
+ this.peopleIndex = indexs;
+ // this.content = `事件已移交至${value[0].distictName}${value[1].distictName}`
+ let data = {
+ addressCode: this.defaultData.addressCode,
+ confirmFlag: 1,
+ content: `事件已移交至${value[0].name}${value[1].name}`,
+ peopleType: 1,
+ repairId: this.defaultData.id,
+ transferUserId: value[1].id
+ }
+ console.log(data);
+ this.submitRequest(data)
+ },
+
+ }
+ }
+</script>
+
+<style lang="scss" scoped>
+ page {
+ background-color: #f6f6f6;
+ }
+
+ .container {
+ padding: 0 20rpx 150rpx;
+
+ .basic-box,
+ .pic-box,
+ .audit-box,
+ .bottom {
+ background-color: #fff;
+ padding: 20rpx;
+ }
+
+ .pic-box {
+
+ // margin-top: 20rpx;
+ .pic-data {
+ padding: 0 20rpx;
+ display: flex;
+ flex-wrap: wrap;
+ margin-top: 20rpx;
+ }
+ }
+
+ .audit-box {
+ // margin-top: 20rpx;
+
+ .audit-form {
+ padding: 0 20rpx;
+
+ .form {
+ font-size: 30rpx;
+
+ .form-item {
+ padding: 0 20rpx;
+
+ &:first-child {
+ border-bottom: 1rpx solid #f6f6ff;
+ }
+ }
+ }
+ }
+ }
+
+ .bottom {
+ position: fixed;
+ left: 0;
+ bottom: 0;
+ width: calc(100% - 40rpx);
+ border-top: 1rpx solid #f6f6f6;
+ }
+
+ .title-box {
+ display: flex;
+ align-items: center;
+ font-size: 30rpx;
+
+ .line {
+ width: 6rpx;
+ height: 30rpx;
+ margin-right: 10rpx;
+ background-color: #017BFC;
+ }
+
+ .text {
+ font-weight: 700;
+ }
+ }
+ }
+
+ /deep/ .u-form-item__body__left__content__label,
+ /deep/ .uni-input-placeholder {
+ font-size: 30rpx;
+ }
+
+ .footer {
+ width: 100%;
+ padding: 20rpx 30rpx;
+ box-sizing: border-box;
+ position: fixed;
+ bottom: 0;
+ left: 0;
+ background-color: #fff;
+ z-index: 10;
+ padding-bottom: calc(env(safe-area-inset-bottom) + 20rpx);
+ z-index: 999;
+ background-color: #fff;
+ box-shadow: 0rpx 0rpx 10rpx 1rpx rgba(0, 0, 0, 0.1);
+
+ .footer-btn {
+ width: 80%;
+ height: 78rpx;
+ border-radius: 8rpx;
+ font-size: 32rpx;
+ color: #fff;
+ border: none;
+ background: linear-gradient(163deg, #01BDFC 0%, #017BFC 100%);
+ }
+
+ .footer-btn:after {
+ border: none;
+ }
+
+ }
+
+
+ .upload {
+ margin: 0 30rpx;
+ padding: 30rpx;
+
+ .upload-item {
+ width: 140rpx;
+ height: 140rpx;
+ border: 1px solid #EEEEEE;
+ }
+ }
+
+ .step {
+ margin-top: 20rpx;
+ padding: 0 20rpx;
+ }
+
+ .step-list {
+ padding: 15rpx 0;
+ }
+
+ .popup-title {
+ padding: 20rpx 0;
+ text-align: center;
+
+ }
+
+ .popup-content {
+ padding: 20rpx;
+ }
+
+ .popup-btn {
+ padding: 20rpx;
+
+
+ .popup-btn-item {
+ width: 100%;
+ height: 78rpx;
+ line-height: 78rpx;
+ border-radius: 36rpx;
+ color: #fff;
+ background: linear-gradient(163deg, #01BDFC 0%, #017BFC 100%);
+ font-size: 28rpx;
+ }
+
+ .popup-btn-item:after {
+ border: none;
+ }
+ }
+</style>
\ No newline at end of file
diff --git a/subPackage/ecall/index.vue b/subPackage/ecall/index.vue
new file mode 100644
index 0000000..f40bc1f
--- /dev/null
+++ b/subPackage/ecall/index.vue
@@ -0,0 +1,271 @@
+<template>
+ <view>
+ <u-sticky>
+ <view class="hander">
+ <view class="tab">
+ <!-- <u-tabs :list="tabList" :scrollable="false" :current="tabIndex" @click="changeTab"
+ :inactiveStyle="{color:'#999999'}" :activeStyle="{color:'#017BFC'}">
+ </u-tabs> -->
+ <view class="search flex j-c-s-b a-i-c">
+ <view class="tab-filter flex j-c-c a-i-c" @click="showDateModal">
+ <text class="f-28">时间筛选</text>
+ <u-icon name="arrow-down"></u-icon>
+ </view>
+ <u-search placeholder="请输入需要查询信息的姓名" v-model="keyWord" :clearabled="true" :showAction="true"
+ :animation="true" @search="searchConfirm" @clear="clearConfirm"></u-search>
+ </view>
+ </view>
+ </view>
+ </u-sticky>
+ <view class="list">
+ <view class="list-item bgc-ff mb-20" v-for="item in reportList" :key="item.id" @click="pushPage(item)">
+ <!-- <view class="item-title flex a-i-c j-c-s-b mb-20">
+ <text class="f-32 fw">{{ findObjValue(item.type, typeList, 'type').name }}</text>
+ <u-tag class="u_tag" size="mini" plain plainFill
+ :text="findObjValue(item.confirmFlag, tabList, 'status').name"
+ :type="findObjValue(item.confirmFlag, tabList, 'status').type"></u-tag>
+ </view> -->
+ <view class="item-row flex a-i-c j-c-s-b">
+ <text class="f-28">姓名</text>
+ <text class="f-28 c-66">{{ item.applicantName }}</text>
+ </view>
+ <view class="item-row flex a-i-c j-c-s-b">
+ <text class="f-28">手机</text>
+ <text class="f-28 c-66">{{ item.applicantPhone }}</text>
+ </view>
+ <view class="item-row flex a-i-c j-c-s-b">
+ <text class="f-28">事发地</text>
+ <text class="address f-28 c-66">{{ item.sceneAddr || "" }}</text>
+ </view>
+ <view class="item-row flex a-i-c j-c-s-b f-28">
+ <text>时间</text>
+ <text class="c-66">{{item.createTime}}</text>
+ </view>
+ </view>
+ </view>
+ <u-loadmore :status="loadingStatus" loadmoreText="开始加载" loadingText="数据加载中" nomoreText="没有更多了" line />
+ <date-range-modal ref="dateRane" @comfirm="handleComfirmDate" @rest="handleRestDate" />
+ </view>
+</template>
+
+<script>
+ import {
+ getPage
+ } from '@/api/task/ecall.js'
+ import dateRangeModal from '@/components/dateRangeModal/modal.vue';
+ export default {
+ components: {
+ dateRangeModal
+ },
+ data() {
+ return {
+ reportList: [],
+ pagingParams: {
+ current: 1,
+ size: 10
+ },
+ tabList: [
+
+ {
+ name: "全部",
+ status: "",
+ },
+ {
+ name: "待处理",
+ status: 1,
+ type: 'warning'
+ },
+ {
+ name: "处理中",
+ status: 2,
+ type: 'success'
+ },
+ {
+ name: "已处理",
+ status: 3,
+ type: 'success'
+ },
+ ],
+ typeList: [{
+ name: "公共维修",
+ type: 1
+ },
+ {
+ name: "居家维修",
+ type: 2
+ },
+ {
+ name: "矛盾纠纷",
+ type: 3
+ },
+ {
+ name: "投诉举报",
+ type: 4
+ },
+ {
+ name: "企业商户上报",
+ type: 5
+ },
+ {
+ name: "统战上报",
+ type: 6
+ }
+ ],
+ tabIndex: 0,
+ tabStatus: "",
+ keyWord: '',
+ loadingStatus: 'nomore',
+ selectDate: [],
+ houseCode: ""
+ }
+ },
+
+ onLoad(option) {
+ if (option.from) {
+ this.tabIndex = 1;
+ this.tabStatus = 1;
+ }
+ if (option.code) {
+ this.houseCode = option.code;
+ }
+ },
+
+ onShow() {
+ this.currentRole = uni.getStorageSync("activeRole")
+ this.reportList = []
+ this.pagingParams.current = 1;
+ this.getPageList()
+ },
+ onReachBottom() {
+ this.pagingParams.current++
+ this.getPageList()
+ },
+ methods: {
+ async getPageList() {
+ this.loadingStatus = 'loadingmore'
+ const params = {
+ realName: this.keyWord,
+ confirmFlag: this.tabStatus
+ }
+ if (this.selectDate.length) {
+ params.startTime = this.selectDate[0]
+ params.endTime = this.selectDate[1]
+ }
+ if (this.houseCode) {
+ params.addressCode = this.houseCode;
+ }
+ const {
+ roleName
+ } = this.currentRole
+ const res = await getPage({
+ ...params,
+ roleName,
+ ...this.pagingParams
+ })
+ const {
+ code,
+ data: {
+ records
+ }
+ } = res
+ if (code !== 200) {
+ uni.showToast({
+ title: '数据请求失败',
+ icon: 'error'
+ })
+ return
+ }
+ this.reportList = [...this.reportList, ...records]
+ this.loadingStatus = 'nomore'
+ },
+ changeTab(e) {
+ this.tabStatus = e.status;
+ this.resetParams()
+ this.getPageList()
+ },
+ searchConfirm() {
+ this.resetParams()
+ this.getPageList()
+ },
+ clearConfirm() {
+ this.keyWord = ''
+ this.searchConfirm()
+ },
+ resetParams() {
+ this.reportList = []
+ this.pagingParams.current = 1
+ },
+ findObjValue(value, obj, word) {
+ const res = obj.find(item => {
+ return item[word] == value
+ })
+ return res
+ },
+ pushPage(item) {
+ // const data = JSON.stringify(item)
+ // uni.setStorageSync("ecallDetail", item)
+ this.$u.func.globalNavigator('/subPackage/ecall/detail?id=' + item.id)
+ },
+
+ showDateModal() {
+ this.$refs.dateRane.open();
+ },
+
+ handleRestDate() {
+ this.selectDate = [];
+ this.resetParams();
+ this.getPageList()
+ },
+ handleComfirmDate(val) {
+ this.selectDate = val;
+ this.resetParams();
+ this.getPageList()
+ }
+ }
+ }
+</script>
+
+<style lang="scss">
+ page {
+ background-color: #F5F5F5;
+ }
+
+ .hander {
+ background-color: #fff;
+
+ .tab {
+ width: 100%;
+ }
+
+ .tab-filter {
+ padding: 0 20rpx;
+ }
+
+ .search {
+ padding: 20rpx 30rpx;
+ }
+ }
+
+ .list {
+ margin: 20rpx 30rpx 0;
+ }
+
+ .list-item {
+ padding: 0 30rpx 20rpx;
+ border-radius: 8rpx;
+
+ .item-title {
+ padding: 30rpx 0;
+ border-bottom: 1px solid #F5F5F5;
+ }
+
+ .item-row {
+ padding: 10rpx 0;
+
+ .address {
+ width: 75%;
+ text-align: right;
+ }
+ }
+ }
+</style>
\ No newline at end of file
--
Gitblit v1.9.3