AI销管
選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。
 
 
 
 

124 行
2.7 KiB

  1. <template>
  2. <view class="pages">
  3. <block v-for="(data, index) in list">
  4. <view class="page-box" v-if="data.list.length > 0" :key="index">
  5. <view class="title">
  6. <text class="a1">
  7. {{ data.houseName || '' }}
  8. </text>
  9. <text :style="{color: item.showStatus == 0 ? 'blue' : 'black'}" @click="updateShowStatus(data)">已了解</text>
  10. </view>
  11. <u-checkbox-group @change="checkboxGroupChange" shape="circle">
  12. <block v-for="item in data.list" :key="item.id">
  13. <u-checkbox :disabled="item.showStatus == 0" @change="checkboxChange" v-model="item.checked">
  14. <view :style="{ textDecoration: item.showStatus == 0 ? 'line-through' : 'none'}">
  15. {{ item.createTime }}
  16. </view>
  17. <rich-text :style="{ textDecoration: item.showStatus == 0 ? 'line-through' : 'none'}" :nodes="item.message"></rich-text>
  18. </u-checkbox>
  19. </block>
  20. </u-checkbox-group>
  21. </view>
  22. </block>
  23. </view>
  24. </template>
  25. <script>
  26. export default {
  27. data() {
  28. return {
  29. list: [], //
  30. }
  31. },
  32. onLoad() {
  33. this.getWarningList()
  34. },
  35. methods: {
  36. //
  37. updateShowStatus(data) {
  38. let arr = data.list.filter(item => item.checked).map(items => {return items.id})
  39. console.log(arr)
  40. if (arr.length == 0) {
  41. uni.showToast({
  42. title: '请选择已了解的消息~',
  43. icon: "none",
  44. duration: 2000,
  45. })
  46. return
  47. }
  48. this.$u.get('/customer/updateShowStatus', {
  49. ids: arr.join(',')
  50. }).then(res => {
  51. uni.showToast({
  52. title: '提交成功',
  53. icon: "none",
  54. duration: 2000,
  55. })
  56. setTimeout(() => {
  57. this.getWarningList()
  58. }, 1000)
  59. })
  60. },
  61. // 项目预警列表
  62. getWarningList() {
  63. this.$u.get('/customer/warningList').then(res => {
  64. if (res) {
  65. this.list = res.records.map(item => {
  66. item.list.forEach(items => {
  67. items.checked = items.showStatus == 0 ? true : false
  68. })
  69. return item
  70. })
  71. this.$forceUpdate()
  72. }
  73. })
  74. },
  75. // 选中某个复选框时,由checkbox时触发
  76. checkboxChange(e) {
  77. console.log(e);
  78. },
  79. // 选中任一checkbox时,由checkbox-group触发
  80. checkboxGroupChange(e) {
  81. console.log(e);
  82. }
  83. }
  84. }
  85. </script>
  86. <style lang="scss" scoped>
  87. .pages {
  88. padding: 20rpx 0;
  89. width: 100vw;
  90. min-height: 100vh;
  91. background: #f2f2f2;
  92. display: flex;
  93. flex-direction: column;
  94. .page-box {
  95. margin: 0 auto 20rpx;
  96. padding: 20rpx;
  97. width: 686rpx;
  98. background: #fff;
  99. border-radius: 16rpx;
  100. box-shadow: 0rpx 0rpx 7rpx #82848A;
  101. .title {
  102. display: flex;
  103. justify-content: space-between;
  104. .a1 {
  105. font-size: 32rpx;
  106. font-weight: 600;
  107. }
  108. }
  109. }
  110. }
  111. </style>