detail.vue 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. <template>
  2. <div class="lookDetailBox">
  3. <div>
  4. <h2>{{ detailForm.title }}</h2>
  5. <div class="descBox">
  6. <p>
  7. <span>发布时间:{{ detailForm.createTime }}</span>
  8. <span style="margin: 0px 50px">阅读次数:{{ detailForm.readNum }}</span>
  9. </p>
  10. <div>
  11. <span class="title">附件:</span>
  12. <ul class="prviewFile">
  13. <li v-for="(item, index) in fileUrls" :key="index">
  14. <span>
  15. <a href="javascript:void(0);" @click="previewFile(item)">{{ item['name'] }}</a>
  16. </span>
  17. </li>
  18. </ul>
  19. </div>
  20. </div>
  21. <div v-html="detailForm.content"></div>
  22. <PreView :src="currentUrl" v-if="preVisiable" @close="closeHandler" />
  23. </div>
  24. </div>
  25. </template>
  26. <script setup lang="ts">
  27. import { useRoute } from 'vue-router'
  28. import request from '@/config/axios'
  29. import PreView from '@/components/PreView/index.vue'
  30. import { useFiles } from './mixins.ts'
  31. const detailForm = ref<{
  32. title: string
  33. createTime: any
  34. readNum: number
  35. content: string
  36. }>({
  37. title: '',
  38. createTime: '',
  39. readNum: 0,
  40. content: ''
  41. })
  42. const preVisiable = ref<boolean>(false)
  43. const currentUrl = ref<string>()
  44. function isImage(file) {
  45. return /^image\//i.test(file.type)
  46. }
  47. const previewFile = (item) => {
  48. if (isImage(item)) {
  49. preVisiable.value = true
  50. currentUrl.value = item['url']
  51. } else {
  52. window.open(item['url'])
  53. }
  54. }
  55. const closeHandler = () => {
  56. preVisiable.value = false
  57. }
  58. const { fileUrls, queryFiles } = useFiles(request)
  59. /***
  60. * 禁用右键菜单
  61. */
  62. document.addEventListener('contextmenu', function (e) {
  63. e.preventDefault()
  64. })
  65. async function queryDetailById(idStr: any): Promise<void> {
  66. const urlApi = `/adm/noticeAndLearn/query/detailById`
  67. const params = {
  68. id: idStr
  69. }
  70. const result = await request.get({ url: urlApi, params })
  71. if (result) {
  72. detailForm.value = result
  73. queryFiles(result.files)
  74. }
  75. }
  76. function addReadNum(idStr: any) {
  77. const urlApi = `/adm/noticeAndLearn/readNum/add`
  78. const params = {
  79. id: idStr
  80. }
  81. request.get({ url: urlApi, params })
  82. }
  83. function updateRead(idStr: any) {
  84. const urlApi = `/adm/noticeAndLearn/read/update`
  85. const params = {
  86. id: idStr
  87. }
  88. request.get({ url: urlApi, params })
  89. }
  90. const route = useRoute()
  91. const query = route.query
  92. if (query.id) {
  93. queryDetailById(query.id)
  94. addReadNum(query.id)
  95. updateRead(query.id)
  96. }
  97. </script>
  98. <style lang="scss" scoped>
  99. .lookDetailBox {
  100. margin-top: 20px;
  101. height: calc(100% - 20px);
  102. background-color: #fff;
  103. border-radius: 20px;
  104. padding: 40px 0px;
  105. position: relative;
  106. overflow-y: auto;
  107. > div {
  108. width: 60vw;
  109. margin: auto;
  110. > h2 {
  111. text-align: center;
  112. font-size: 36px;
  113. font-weight: bold;
  114. }
  115. > .descBox {
  116. border-bottom: solid 1px #d8d8d8;
  117. margin-bottom: 30px;
  118. > p {
  119. text-align: center;
  120. padding: 30px;
  121. color: #444452;
  122. > .copy_line {
  123. color: #409eff;
  124. cursor: pointer;
  125. }
  126. }
  127. > div {
  128. margin-bottom: 10px;
  129. display: flex;
  130. > .title {
  131. color: #999;
  132. margin-right: 10px;
  133. }
  134. > .prviewFile {
  135. display: flex;
  136. > li {
  137. margin-right: 20px;
  138. }
  139. }
  140. }
  141. }
  142. }
  143. }
  144. </style>
  145. ./mixins.js