task.vue 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. <template>
  2. <view class="container">
  3. <view class="item-list-wrap" v-if="total>0">
  4. <view class="item-list basics">
  5. <view class="basics-item" v-for="(item,idx) in items" :key="idx" @click="showDetail(item)">
  6. <view class="basics-title">{{item.checklistTitle}}</view>
  7. <view class="basics-body">
  8. <view class="lf">
  9. <text class="time">{{item.recordTime}}</text>
  10. <text class="user">{{item.accountName||'微信用户'}}</text>
  11. </view>
  12. <view class="status">{{checklistStatus(item.status)}}</view>
  13. </view>
  14. </view>
  15. </view>
  16. </view>
  17. <template v-else>
  18. <view class="isEmpty" >
  19. <p class="word">没有数据 ^_^ </p>
  20. </view>
  21. </template>
  22. </view>
  23. </template>
  24. <script>
  25. import { getchecklistByPage} from '@/api/aqpt/checklistPoint.js'
  26. export default {
  27. data() {
  28. return {
  29. conditions:{
  30. page:1,
  31. limit:15,
  32. },
  33. total:0,
  34. items:[]
  35. }
  36. },
  37. onLoad() {
  38. this.init()
  39. },
  40. methods: {
  41. checklistStatus(val){
  42. if(val===-1)return "巡检异常"
  43. const strs = ['未开始','未完成','完成']
  44. return strs[val]
  45. },
  46. init(){
  47. this.items=[]
  48. this.total=0
  49. this.conditions={
  50. limit:15,
  51. page:1
  52. }
  53. this.getData()
  54. this.clearDetail()
  55. },
  56. getData(){
  57. getchecklistByPage(this.conditions).then((res)=>{
  58. let items=JSON.parse(JSON.stringify(this.items))
  59. this.items=items.concat(res.data)
  60. this.total=res.total
  61. })
  62. },
  63. changePageNumber({type,current}){
  64. this.conditions.page=current
  65. this.getData()
  66. },
  67. clearDetail(){
  68. if(uni.getStorageSync('detail-info')){
  69. uni.removeStorageSync('detail-info')
  70. }
  71. },
  72. showDetail(item){
  73. let pageUrl="";
  74. if(item.checklistTypeId===2){
  75. pageUrl="/pages/app_views/checkList/index/index"
  76. }
  77. if(item.checklistTypeId===3){
  78. pageUrl="/pages/app_views/satisfaction_evaluation/satisfaction_evaluation"
  79. }
  80. if(item.checklistTypeId===1){
  81. pageUrl="/pages/app_views/hazard/index/index"
  82. }
  83. uni.navigateTo({
  84. url:`${pageUrl}?type=history&id=${item.checklistId}&recordId=${item.recordId}`
  85. })
  86. },
  87. isEmpty(val){
  88. if(val!=="undefined"&&val!==undefined&&val!==""&&val!==null){
  89. return false
  90. }
  91. return true
  92. }
  93. },
  94. onPullDownRefresh() {
  95. this.init()
  96. },
  97. onReachBottom() {
  98. if(this.total>=this.conditions.page*this.conditions.limit){
  99. this.conditions.page++
  100. this.getData()
  101. }
  102. }
  103. }
  104. </script>
  105. <style lang="scss" scoped>
  106. .container{
  107. padding-bottom: 100rpx;
  108. min-height: 100vh;
  109. box-sizing: border-box;
  110. background-color: #F5F6F8;
  111. }
  112. .isEmpty{
  113. width: 100%;
  114. height: 100vh;
  115. background-image: url(data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgNzkgODYiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiPjxkZWZzPjxsaW5lYXJHcmFkaWVudCBpZD0iYSIgeDE9IjM4Ljg1JSIgeTE9IjAlIiB4Mj0iNjEuMTUlIiB5Mj0iMTAwJSI+PHN0b3Agc3RvcC1jb2xvcj0iI0ZDRkNGRCIgb2Zmc2V0PSIwJSIvPjxzdG9wIHN0b3AtY29sb3I9IiNFRUVGRjMiIG9mZnNldD0iMTAwJSIvPjwvbGluZWFyR3JhZGllbnQ+PGxpbmVhckdyYWRpZW50IGlkPSJiIiB4MT0iMCUiIHkxPSI5LjUlIiB5Mj0iOTAuNSUiPjxzdG9wIHN0b3AtY29sb3I9IiNGQ0ZDRkQiIG9mZnNldD0iMCUiLz48c3RvcCBzdG9wLWNvbG9yPSIjRTlFQkVGIiBvZmZzZXQ9IjEwMCUiLz48L2xpbmVhckdyYWRpZW50PjxwYXRoIGlkPSJjIiBkPSJNMCAwaDE3djM2SDB6Ii8+PC9kZWZzPjxnIGZpbGw9Im5vbmUiIGZpbGwtcnVsZT0iZXZlbm9kZCI+PHBhdGggZD0iTTM5LjUgODZDNjEuMzE1IDg2IDc5IDgzLjkxIDc5IDgxLjMzM1M1Ny4zMTUgNzggMzUuNSA3OCAwIDc4Ljc1NiAwIDgxLjMzM0MwIDgzLjkxMSAxNy42ODUgODYgMzkuNSA4NnoiIGZpbGw9IiNGN0Y4RkMiLz48cGF0aCBmaWxsPSIjRTVFN0U5IiBkPSJNMTMgNDVoNDBMNDIgNThIMnpNNjUuNTUxIDI5Ljk4bC0xNi4zMTMtNy42MDctMi44NDEtNS43MzggMTYuMzEzIDcuNjA3eiIvPjxwYXRoIGZpbGw9IiNFREVFRjIiIGQ9Ik02NS41NTEgMjkuOThsLTM0LjQ0LTE2LjA1OS0xNS4yMTQgMzIuNjI3IDM0LjQ0IDE2LjA2eiIvPjxwYXRoIGZpbGw9InVybCgjYSkiIHRyYW5zZm9ybT0icm90YXRlKDI1IDI3LjQ0NiAtNDMuNDE2KSIgZD0iTTM4IDdoMTd2MzZIMzh6Ii8+PHBhdGggZmlsbD0iI0Y4RjlGQiIgZD0iTTE1LjcwNSA2LjczN2wxNS40MDcgNy4xODQgMTUuNjQ2LS40MjctMTUuNDA3LTcuMTg1eiIvPjxwYXRoIGZpbGw9InVybCgjYikiIGQ9Ik0xMyA0NWg0MHYzNkgxM3oiLz48ZyB0cmFuc2Zvcm09InRyYW5zbGF0ZSg1MyA0NSkiPjxtYXNrIGlkPSJkIiBmaWxsPSIjZmZmIj48dXNlIHhsaW5rOmhyZWY9IiNjIi8+PC9tYXNrPjx1c2UgZmlsbD0iI0UwRTNFOSIgdHJhbnNmb3JtPSJtYXRyaXgoLTEgMCAwIDEgMTcgMCkiIHhsaW5rOmhyZWY9IiNjIi8+PHBhdGggZmlsbD0iI0Q1RDdERSIgbWFzaz0idXJsKCNkKSIgdHJhbnNmb3JtPSJtYXRyaXgoLTEgMCAwIDEgMjQgMCkiIGQ9Ik03IDBoMTdsLTQgMTgtMjAtMnoiLz48L2c+PHBhdGggZmlsbD0iI0Y4RjlGQiIgZD0iTTcwIDQ1SDUzbDkgMTNoMTd6Ii8+PC9nPjwvc3ZnPg==);
  116. background-size: contain;
  117. background-repeat: no-repeat;
  118. position: relative;
  119. background-color: #fff;
  120. /* #ifndef MP-WEIXIN */
  121. height: calc( 100vh - 100px);
  122. /* #endif */
  123. .word{
  124. width: 100%;
  125. text-align: center;
  126. position: absolute;
  127. top: 80vh;
  128. left: 0;
  129. color: #999;
  130. font-size: 28rpx;
  131. letter-spacing: 2rpx;
  132. }
  133. }
  134. .item-list-wrap{
  135. padding: 0 20rpx;
  136. background-color: #F5F6F8;
  137. margin-top: 18rpx;
  138. .item-list{
  139. background-color: #fff;
  140. border-radius: 16rpx;
  141. overflow: hidden;
  142. &.basics{
  143. background-color: #F5F6F8;
  144. .basics-item{
  145. padding:30rpx 40rpx ;
  146. border-radius: 16rpx;
  147. margin-bottom: 20rpx;
  148. background-color: #fff;
  149. .basics-title{
  150. font-size: 32rpx;
  151. line-height: 48rpx;
  152. font-weight: 500;
  153. color: #212121;
  154. }
  155. .basics-body{
  156. display: flex;
  157. align-items: center;
  158. padding-top: 32rpx;
  159. .lf{
  160. flex: 1;
  161. .time{
  162. font-size: 24rpx;
  163. line-height: 48rpx;
  164. color: #999999;
  165. padding-left: 34rpx;
  166. background-position: center left;
  167. background-repeat: no-repeat;
  168. background-size: 24rpx 24rpx;
  169. background-image: url('/static/time.png');
  170. }
  171. .user{
  172. margin-left:24rpx ;
  173. font-size: 24rpx;
  174. line-height: 48rpx;
  175. color: #999999;
  176. padding-left: 34rpx;
  177. background-position: center left;
  178. background-repeat: no-repeat;
  179. background-size: 24rpx 24rpx;
  180. background-image: url('/static/user.png');
  181. }
  182. }
  183. .status{
  184. font-size: 28rpx;
  185. line-height: 48rpx;
  186. color: #4D73FF;
  187. }
  188. }
  189. }
  190. }
  191. }
  192. }
  193. </style>