expoHead.vue 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. <script lang="ts">
  2. import Vue from 'vue'
  3. import { getMyExpoInfo } from '@/api/expo'
  4. export default Vue.extend({
  5. name: "expoPopover",
  6. data() {
  7. return {
  8. ossUrl: process.env.VUE_APP_OSS_DOMAIN
  9. }
  10. },
  11. props: {
  12. popover_data: Object,
  13. },
  14. mounted() {
  15. setTimeout(()=>{
  16. console.log(this.popover_data)
  17. },2000)
  18. },
  19. methods: {
  20. goto(url) {
  21. window.open(url, '_blank')
  22. },
  23. }
  24. })
  25. </script>
  26. <template>
  27. <div class="expo-info">
  28. <div class="cover loading">
  29. <img v-if="popover_data.images" :src="ossUrl+popover_data.images[0]">
  30. <div v-permission="'exhibitor.copyLink'" v-if="popover_data.form_template_id && popover_data.urla" @click="copyUrl()" class="button">复制表单地址</div>
  31. </div>
  32. <div class="info-body">
  33. <div class="avatar-name">
  34. <div class="avatar loading">
  35. <img v-if="popover_data.logo" :src="ossUrl+popover_data.logo">
  36. </div>
  37. <div class="name-cont">
  38. <div :class="['name',popover_data.expo_name!==undefined?'':'loading']">{{ popover_data.expo_name }}</div>
  39. <div :class="['sub-name',popover_data.organizer!==undefined?'':'loading']">{{ popover_data.organizer }}</div>
  40. <div class="contact">
  41. <div class="phone">
  42. <i class="icon el-icon-mobile-phone" />
  43. <div :class="['phone-num link',popover_data.contact_phone!==undefined?'':'loading']" @click="goto('tel:'+popover_data.contact_phone)">{{ popover_data.contact_phone }}</div>
  44. </div>
  45. <div class="email">
  46. <i class="icon el-icon-message" />
  47. <div :class="['email-addr link',popover_data.contact_email!==undefined?'':'loading']" @click="goto('mailto:'+popover_data.contact_email)">{{ popover_data.contact_email }}</div>
  48. </div>
  49. <div class="date">
  50. <i class="icon el-icon-date" />
  51. <div :class="['date-range',popover_data.start_date!==undefined?'':'loading']">{{ popover_data.start_date }} - {{ popover_data.end_date }}</div>
  52. </div>
  53. </div>
  54. </div>
  55. </div>
  56. <div :class="['desc',popover_data.content!==undefined?'':'loading']">
  57. {{ popover_data.content }}
  58. </div>
  59. <div v-if="popover_data.social_links" class="social_links">
  60. <div class="social-title">社交媒体</div>
  61. <div v-if="popover_data.social_links.facebook" class="social-item">
  62. <span>facebook:</span><span class="link" @click="goto(popover_data.social_links.facebook)">{{ popover_data.social_links.facebook }}</span>
  63. </div>
  64. <div v-if="popover_data.social_links.twitter" class="social-item">
  65. <span>twitter:</span><span class="link" @click="goto(popover_data.social_links.twitter)">{{ popover_data.social_links.twitter }}</span>
  66. </div>
  67. <div v-if="popover_data.social_links.linkedin" class="social-item">
  68. <span>linkedin:</span><span class="link" @click="goto(popover_data.social_links.linkedin)">{{ popover_data.social_links.linkedin }}</span>
  69. </div>
  70. </div>
  71. </div>
  72. </div>
  73. </template>
  74. <style scoped lang="scss">
  75. .expo-info{
  76. position: relative;
  77. width: 100%;
  78. .link{
  79. cursor: pointer;
  80. text-decoration: underline;
  81. }
  82. .info-body{
  83. margin: auto;
  84. max-width: 800px;
  85. padding: 16px;
  86. .social_links{
  87. margin-top: 12px;
  88. .social-title{
  89. font-weight: bold;
  90. }
  91. .social-item{
  92. }
  93. }
  94. .desc{
  95. margin-top: 12px;
  96. &.loading{
  97. height: 60px;
  98. width: 100%;
  99. }
  100. }
  101. .avatar-name{
  102. display: flex;
  103. grid-gap: 8px;
  104. .name-cont{
  105. flex: 1;
  106. .name{
  107. font-size: 20px;
  108. font-weight: bold;
  109. &.loading{
  110. height: 26px;
  111. width: 120px;
  112. }
  113. }
  114. .sub-name{
  115. color: gray;
  116. &.loading{
  117. margin-top: 8px;
  118. margin-bottom: 8px;
  119. height: 20px;
  120. width: 160px;
  121. }
  122. }
  123. .contact{
  124. flex-wrap: wrap;
  125. display: flex;
  126. grid-gap: 0 12px;
  127. .phone,.email,.date{
  128. display: flex;
  129. align-items: center;
  130. grid-gap: 4px;
  131. div{
  132. &.loading{
  133. height: 16px;
  134. width: 120px;
  135. }
  136. }
  137. }
  138. }
  139. }
  140. .avatar{
  141. width: 70px;
  142. height: 70px;
  143. border-radius: 50%;
  144. overflow: hidden;
  145. img{
  146. display: block;
  147. object-fit: cover;
  148. width: 100%;
  149. height: 100%;
  150. }
  151. }
  152. }
  153. }
  154. .cover{
  155. position: relative;
  156. width: 100%;
  157. height: 300px;
  158. .button{
  159. cursor: pointer;
  160. background: #00000044;
  161. padding: 4px 12px;
  162. border-radius: 24px;
  163. border: 2px solid white;
  164. color: white;
  165. position: absolute;
  166. right: 16px;
  167. top: 16px;
  168. }
  169. img{
  170. display: block;
  171. object-fit: cover;
  172. width: 100%;
  173. height: 100%;
  174. }
  175. }
  176. }
  177. </style>