activityDetail.vue 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788
  1. <template>
  2. <view class="container activity-detail">
  3. <view class="" v-if="haveAuth == 1">
  4. <block v-if="detailData.YidongActivityUrl">
  5. <web-view :src="detailData.YidongActivityUrl"></web-view>
  6. </block>
  7. <block v-else>
  8. <!-- 头部滚动显示 -->
  9. <view class="notice" v-if="detailData.IsLimitPeople == 1">
  10. <van-notice-bar color="#FFFFFF" background="#FE9000" text="该活动参与名额有限,报名客户请按时参加,若不能按时参加请及时取消报名,爽约会影响您的后续报名资格" />
  11. </view>
  12. <!-- 内容部分 -->
  13. <view class="content">
  14. <view v-if="detailData.ActivityName" class="dialog-title" :class="1 == 1 ? 'brackets-title' : ''">{{ detailData.ActivityName }}</view>
  15. <view class="audio-card" v-if="detailData.AudioLink">
  16. <view class="card-title text_oneLine">
  17. {{ detailData.VoiceList.Name }}
  18. </view>
  19. <slider activeColor="#3385FF" :max="detailData.VoiceList.PlaySeconds" :value="curTime" @change="handleAudioSliderChange($event)" block-size="16" class="slider" />
  20. <view class="card-time">
  21. <text class="time">{{ curTime | formatVoiceTime }}</text>
  22. <text class="time">{{ detailData.VoiceList.PlaySeconds | formatVoiceTime }}</text>
  23. </view>
  24. <view class="is-paly-card">
  25. <image
  26. @click.stop="audioPlayBack"
  27. class=""
  28. :src="
  29. curVoiceId === detailData.ActivityId && !curAudioPaused
  30. ? 'https://hzchart.oss-cn-shanghai.aliyuncs.com/cygx/czbk/suspend_icon.png'
  31. : 'https://hzchart.oss-cn-shanghai.aliyuncs.com/cygx/czbk/play_icon.png'
  32. "
  33. ></image>
  34. </view>
  35. </view>
  36. <view class="city-box">
  37. <text v-if="detailData.ActivityTypeName">活动类型:</text>
  38. <view class="city">
  39. <text style="color: #333">({{ detailData.ChartPermissionName }}){{ detailData.ActivityTypeName }}</text>
  40. <image v-if="detailData.City" style="margin-left: 15rpx" src="https://hzchart.oss-cn-shanghai.aliyuncs.com/cygx/czbk/location.png" mode=""></image>
  41. <text v-if="detailData.City">{{ detailData.City }}</text>
  42. </view>
  43. <view class="choose-limit" @click="strictSelection" v-if="detailData.IsShowSustainable">
  44. <image src="https://hzchart.oss-cn-shanghai.aliyuncs.com/cygx/czbk/purchaser.png" mode=""></image>
  45. <image class="limit-img" src="https://hzchart.oss-cn-shanghai.aliyuncs.com/cygx/czbk/limit_icon.png" mode=""></image>
  46. </view>
  47. </view>
  48. <view v-if="detailData.Listndustrial.length" class="network dustrial-ui">
  49. <view class="network-left">产业标签:</view>
  50. <view class="network-right">
  51. <view :class="['dustrial-li', item.IsJump && 'dustrial-item']" @click="goDustrialHandler(item)" v-for="item in detailData.Listndustrial" :key="item.IndustrialManagementId">{{
  52. item.IndustryName
  53. }}</view>
  54. </view>
  55. </view>
  56. <view v-if="detailData.ActivityTimeText" class="network">
  57. <view class="network-left">活动时间:</view>
  58. <view class="network-right">{{ detailData.ActivityTimeText }}</view>
  59. </view>
  60. <view v-if="detailData.DistinguishedGuest" class="network">
  61. <view class="network-left">嘉&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;宾:</view>
  62. <view class="network-right">{{ detailData.DistinguishedGuest }}</view>
  63. </view>
  64. <view v-if="detailData.Host" class="network">
  65. <view class="network-left">主&nbsp;&nbsp;持&nbsp;人:</view>
  66. <view class="network-right">{{ detailData.Host }}</view>
  67. </view>
  68. <view v-if="detailData.Speaker" class="network">
  69. <view class="network-left">主&nbsp;&nbsp;讲&nbsp;人:</view>
  70. <view class="network-right">{{ detailData.Speaker }}</view>
  71. </view>
  72. <view v-if="detailData.Expert" class="network">
  73. <view class="network-left">专家背景:</view>
  74. <view class="network-right">
  75. <rich-text :nodes="detailData.Expert"></rich-text>
  76. </view>
  77. </view>
  78. <view v-if="detailData.MainlandTell" class="network">
  79. <view class="network-left">大陆拨入:</view>
  80. <view class="network-right" style="color: #2c83ff" @click="phonebtn(detailData.MainlandTell)">{{ detailData.MainlandTell }}</view>
  81. </view>
  82. <view v-if="detailData.HongKongTell" class="network">
  83. <view class="network-left">香港拨入:</view>
  84. <view class="network-right" style="color: #2c83ff" @click="phonebtn(detailData.HongKongTell)">{{ detailData.HongKongTell }}</view>
  85. </view>
  86. <view v-if="detailData.TaiwanTell" class="network">
  87. <view class="network-left">台湾拨入:</view>
  88. <view class="network-right" style="color: #2c83ff" @click="phonebtn(detailData.TaiwanTell)">{{ detailData.TaiwanTell }}</view>
  89. </view>
  90. <view v-if="detailData.AmericaTell" class="network">
  91. <view class="network-left">美国拨入:</view>
  92. <view class="network-right" style="color: #2c83ff" @click="phonebtn(detailData.AmericaTell)">{{ detailData.AmericaTell }}</view>
  93. </view>
  94. <view v-if="detailData.ParticipationCode" class="network">
  95. <view class="network-left">拨入密码:</view>
  96. <view class="network-right">{{
  97. detailData.ActivityTypeName == "公司调研电话会" && detailData.IsLimitPeople == 1 && detailData.IsSignup == 0 ? "请报名获取" : detailData.ParticipationCode
  98. }}</view>
  99. </view>
  100. <view class="network" v-if="detailData.OnlineParticipation">
  101. <view class="network-left">网络参会:</view>
  102. <view class="network-right network-link" style="color: #2c83ff">
  103. <view class="">
  104. <text class="default text_oneLine" @click="networkBtn">{{ detailData.OnlineParticipation }}</text>
  105. <text class="default copy-link" @click="copyLink">复制链接</text>
  106. </view>
  107. </view>
  108. </view>
  109. <view class="network" v-if="detailData.LinkParticipants">
  110. <view class="network-left">链接参会:</view>
  111. <view class="network-right network-zoom" style="color: #2c83ff">
  112. <view>
  113. <text class="default text_zoom">{{ detailData.LinkParticipants }}</text>
  114. <view> 点击<text class="default copy-link copy-zoom" @click="copyLink">复制链接</text>在手机浏览器打开,并输入会议密码 </view>
  115. </view>
  116. </view>
  117. </view>
  118. <view v-if="detailData.AppAttendance" class="network">
  119. <view class="network-left">App参会: </view>
  120. <view class="network-right">
  121. <rich-text :nodes="detailData.AppAttendance"></rich-text>
  122. </view>
  123. </view>
  124. <view v-if="detailData.ConferencePassword" class="network">
  125. <view class="network-left">拨入密码:</view>
  126. <view class="network-right">{{
  127. detailData.ActivityTypeName == "公司调研电话会" && detailData.IsLimitPeople == 1 && detailData.IsSignup == 0 ? "请报名获取" : detailData.ConferencePassword
  128. }}</view>
  129. </view>
  130. <view v-if="detailData.Address" class="network">
  131. <view class="network-left">活动地址:</view>
  132. <view class="network-right" v-if="detailData.IsSignup == 0 && detailData.ActivityTypeName == '公司线下调研' && detailData.IsLimitPeople == 1">请报名获取 </view>
  133. <view class="network-right" v-else>{{ detailData.Address }}</view>
  134. </view>
  135. <view v-if="detailData.Highlights" class="network">
  136. <view class="network-left">活动亮点: </view>
  137. <view class="network-right">
  138. <rich-text :nodes="detailData.Highlights"></rich-text>
  139. </view>
  140. </view>
  141. <view class="network" v-if="detailData.ArticleList.length">
  142. <view class="network-left">相关报告:</view>
  143. <view class="network-right" style="color: #2c83ff">
  144. <view style="margin-left: -20rpx" class="text_oneLine" @click="goDetail(item.ArticleId)" v-for="item in detailData.ArticleList" :key="item.ArticleId"> {{ item.ReportLink }}</view>
  145. </view>
  146. </view>
  147. <view v-if="detailData.Theme" class="network">
  148. <view class="network-left">主&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;题: </view>
  149. <view class="network-right">
  150. <rich-text :nodes="detailData.Theme"></rich-text>
  151. </view>
  152. </view>
  153. <view v-if="detailData.Remarks" class="network">
  154. <view class="network-left">备&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;注: </view>
  155. <view class="network-right">
  156. <rich-text :nodes="detailData.Remarks"></rich-text>
  157. </view>
  158. </view>
  159. </view>
  160. <view class="" style="height: 50rpx"></view>
  161. <!-- 操作按钮部分 -->
  162. <view class="content-bottom">
  163. <block v-if="detailData.ActiveState == 1">
  164. <view class="make-outbound" @click="signupCancel(1)" v-if="detailData.IsShowOutboundCall">{{ detailData.IsSignup == 1 ? "取消外呼" : "预约外呼" }} </view>
  165. <view @click="meetingReminderCancel" class="make-conference" v-if="detailData.IsShowMeetingReminder">
  166. {{ detailData.IsCancelMeetingReminder == 1 ? "取消会议提醒" : "会议提醒" }}
  167. <text>(会前15分钟推送微信消息提醒)</text>
  168. </view>
  169. <view v-if="detailData.IsShowAppointment" @click="summaryIsHandel" class="make-generation make-conference">{{ detailData.IsAppointment == 1 ? "取消纪要" : "预约纪要" }}</view>
  170. <view v-if="detailData.IsShowHelpSsk" class="make-generation make-conference" @click="askingGo"> 帮我带问 </view>
  171. <view class="make-outbound" @click="wanttosignup" v-if="detailData.IsSignup == 0 && detailData.IsShowSignup">
  172. {{ detailData.LimitPeopleNum > 0 ? `我要报名(${detailData.SignupNum}/${detailData.LimitPeopleNum})` : "我要报名" }}
  173. </view>
  174. <view v-if="detailData.IsSignup != 0 && detailData.IsShowSignup" class="make-outbound" @click="signupCancel(2)">
  175. {{ detailData.LimitPeopleNum > 0 ? `取消报名(${detailData.SignupNum}/${detailData.LimitPeopleNum})` : "取消报名" }}
  176. </view>
  177. </block>
  178. <view class="content-bottom" v-if="detailData.ActiveState == 2 && detailData.ActivityTypeId == 1">
  179. <view class="make-conference" @click="askingGo('提问')">
  180. 实时提问
  181. <text>会议过程中,分析师可替您提问专家</text>
  182. </view>
  183. </view>
  184. </view>
  185. </block>
  186. <!-- 参会方式的弹出层 -->
  187. <view class="select-box">
  188. <u-popup v-model="selectShow" mode="bottom">
  189. <view style="color: #333333; font-size: 28rpxrpx">请选择参会方式</view>
  190. <view style="color: #2c83ff" @click="signupAdd(1)">预约外呼</view>
  191. <view style="color: #2c83ff" @click="signupAdd(2)">自主拨入</view>
  192. <view style="color: #a9afb8" @click="selectShow = false">取消</view>
  193. </u-popup>
  194. </view>
  195. <!-- 各种弹框部分 -->
  196. <modalDialog
  197. :isShow="isShow"
  198. :signupType="signupType"
  199. :goFollow="goFollow"
  200. :signupStatus="signupStatus"
  201. :isCancelShow="isCancelShow"
  202. :idTypeCancel="idTypeCancel"
  203. @cancelShowBtn="cancelEnsure"
  204. :editIsShow="editIsShow"
  205. :countryCode="countryCode"
  206. :mobileEdit="mobileEdit"
  207. :goOnNextStep="goOnNextStep"
  208. :mailboxBinding="mailboxBinding"
  209. />
  210. <!-- 区号的弹出层 -->
  211. <areaCode :isAreaCode="isAreaCode" :areaCode="areaCode" />
  212. </view>
  213. <!-- 权限部分 -->
  214. <view v-else>
  215. <jurisdiction :idAct="id" :haveAuth="haveAuth" :industryMsg="industryMsg" :msgType="msgType" :sellerMobile="sellerMobile" :sellerName="sellerName"></jurisdiction>
  216. </view>
  217. <freeCharge class="free-charge" :isShowFreeBtn="isShowFree" />
  218. <audioModule :showAudioPop="false" />
  219. </view>
  220. </template>
  221. <script>
  222. import { activity, User } from "@/config/api.js";
  223. import modalDialog from "@/components/modalDialog.vue";
  224. import areaCode from "@/activityPages/components/areaCode.vue";
  225. import jurisdiction from "./jurisdiction/components.vue";
  226. import freeCharge from "@/components/freeCharge";
  227. import audioModule from "@/components/audioModule/index";
  228. let app = getApp({ allowDefault: true });
  229. export default {
  230. filters: {
  231. formatVoiceTime(e) {
  232. let m = parseInt(e / 60);
  233. let s = parseInt(e % 60);
  234. return `${m > 9 ? m : "0" + m}:${s > 9 ? s : "0" + s}`;
  235. },
  236. },
  237. data() {
  238. return {
  239. id: "",
  240. detailData: {},
  241. isShowJurisdiction: false,
  242. isGain: true,
  243. signupType: "", //关注类型
  244. goFollow: false, //是否关注公众号
  245. signupStatus: "Success", //4个不同的类型提示文案
  246. isShow: false, //弹框
  247. isCancelShow: false,
  248. idTypeCancel: {
  249. id: "",
  250. type: 1,
  251. cutId: "",
  252. state: "",
  253. },
  254. selectShow: false,
  255. isAreaCode: false,
  256. areaCode: {
  257. id: "",
  258. type: "",
  259. },
  260. isNeedAddCountryCode: false,
  261. haveAuth: "",
  262. industryMsg: "",
  263. sellerMobile: "",
  264. sellerName: "", //销售名称
  265. msgType: "",
  266. editIsShow: false, //外呼莫泰框
  267. countryCode: "", //外呼区号
  268. mobileEdit: "", //外呼手机号
  269. goOnNextStep: "", //设置外呼号后弹出哪个
  270. mailboxBinding: false, //是否绑定邮箱
  271. play: false,
  272. };
  273. },
  274. computed: {
  275. curVoiceId() {
  276. //当前正在播放的音频id
  277. return this.$store.state.audioBg.activityId;
  278. },
  279. curAudioPaused() {
  280. //当前音频是否暂停状态
  281. return this.$store.state.audioBg.paused;
  282. },
  283. curTime() {
  284. //当前音频的播放时间
  285. return this.$store.state.audioBg.curTime;
  286. },
  287. },
  288. components: {
  289. modalDialog,
  290. jurisdiction,
  291. areaCode,
  292. freeCharge,
  293. audioModule,
  294. },
  295. watch: {
  296. haveAuth: {
  297. handler() {
  298. if (this.haveAuth == 1) {
  299. this.$store.dispatch("statistics", { PageType: "ActivitParticulars", DetailId: this.id });
  300. }
  301. },
  302. immediate: true,
  303. },
  304. },
  305. methods: {
  306. //获取是否需要填写区号接口
  307. countryCcode() {
  308. User.countryCcode().then((res) => {
  309. if (res.Ret == 200) {
  310. this.isNeedAddCountryCode = res.Data.IsNeedAddCountryCode;
  311. }
  312. });
  313. },
  314. getActivityDetail() {
  315. activity
  316. .getActivityDetail({
  317. ActivityId: this.id,
  318. })
  319. .then((res) => {
  320. if (res.Ret == 200) {
  321. this.haveAuth = res.Data.HasPermission;
  322. this.industryMsg = res.Data.PopupMsg;
  323. this.sellerMobile = res.Data.SellerMobile;
  324. this.sellerName = res.Data.SellerName;
  325. this.msgType = res.Data.MsgType;
  326. if (res.Data.HasPermission == 1) {
  327. this.detailData = res.Data.Detail;
  328. let pages = getCurrentPages();
  329. let prevPage = pages[pages.length - 2];
  330. let path = prevPage ? prevPage.$page.fullPath : "";
  331. if (path == "/pages/activity/activity" || path == "/activityPages/activitySearch/activitySearch") {
  332. const index = prevPage.$vm.collectList.findIndex((item) => item.ActivityId == this.id);
  333. prevPage.$vm.collectList[index].IsSignup = this.detailData.IsSignup;
  334. prevPage.$vm.collectList[index].SignupNum = this.detailData.SignupNum;
  335. prevPage.$vm.collectList[index].IsCancelMeetingReminder = this.detailData.IsCancelMeetingReminder;
  336. }
  337. }
  338. }
  339. });
  340. },
  341. //拨打电话
  342. phonebtn(phone) {
  343. uni.makePhoneCall({
  344. phoneNumber: phone,
  345. });
  346. },
  347. // 跳转新的小程序
  348. networkBtn() {
  349. if (this.detailData.OnlineParticipation.includes("http")) {
  350. uni.navigateTo({
  351. url: "/activityPages/networkAttend/networkAttend?url=" + this.detailData.OnlineParticipation,
  352. });
  353. } else {
  354. uni.navigateToMiniProgram({
  355. appId: "wxade30ff0c4ee757d",
  356. path: this.detailData.OnlineParticipation,
  357. });
  358. }
  359. },
  360. cancelEnsure() {
  361. this.getActivityDetail();
  362. },
  363. goDetail(id) {
  364. uni.navigateTo({
  365. url: "/pageMy/reportDetail/reportDetail?id=" + id,
  366. });
  367. },
  368. askingGo(type = "") {
  369. uni.navigateTo({
  370. url: "/activityPages/generationAsk/generationAsk?id=" + this.id + "&type=" + type,
  371. });
  372. },
  373. meetingReminderAdd() {
  374. activity
  375. .meetingReminderAdd({
  376. ActivityId: Number(this.id),
  377. })
  378. .then((res) => {
  379. if (res.Ret == 200) {
  380. uni.showModal({
  381. confirmText: "知道了",
  382. confirmColor: "#3385FF",
  383. content: res.Msg,
  384. showCancel: false,
  385. success: (res) => {
  386. if (res.confirm) {
  387. this.getActivityDetail();
  388. }
  389. },
  390. });
  391. }
  392. });
  393. },
  394. //取消会议提醒接口
  395. meetingReminderCancel() {
  396. if (this.detailData.IsCancelMeetingReminder == 1) {
  397. activity
  398. .meetingReminderCancel({
  399. ActivityId: Number(this.id),
  400. })
  401. .then((res) => {
  402. if (res.Ret == 200) {
  403. uni.showModal({
  404. confirmText: "知道了",
  405. confirmColor: "#3385FF",
  406. content: res.Msg,
  407. showCancel: false,
  408. success: (res) => {
  409. if (res.confirm) {
  410. this.getActivityDetail();
  411. }
  412. },
  413. });
  414. }
  415. });
  416. } else {
  417. this.meetingReminderAdd();
  418. }
  419. },
  420. wanttosignup() {
  421. if (this.detailData.IsLimitPeople == 1 && this.detailData.ActivityTypeName == "公司调研电话会") {
  422. this.selectShow = true;
  423. } else {
  424. this.signupAdd(3);
  425. }
  426. },
  427. //点击了严选
  428. strictSelection() {
  429. activity.descriptionOfResearch().then((res) => {
  430. if (res.Ret == 200) {
  431. uni.showModal({
  432. content: res.Data.Item.ConfigValue,
  433. confirmText: "知道了",
  434. showCancel: false,
  435. confirmColor: "#3385FF",
  436. success: function (res) {},
  437. });
  438. }
  439. });
  440. },
  441. copyLink() {
  442. uni.setClipboardData({
  443. data: this.detailData.LinkParticipants || this.detailData.OnlineParticipation,
  444. success: function () {
  445. uni.showToast({
  446. title: "复制成功,可在浏览器打开",
  447. icon: "none",
  448. duration: 2000,
  449. });
  450. },
  451. });
  452. },
  453. //跳转产业标签
  454. goDustrialHandler(item) {
  455. if (!item.IsJump) return;
  456. if (item.IsResearch) {
  457. //严选
  458. this.$store.dispatch("checkHandle", "/reportPages/researchTheme/researchTheme?id=" + item.IndustrialManagementId);
  459. } else {
  460. //非严选
  461. this.$store.dispatch("checkHandle", "/reportPages/IndustryReport/IndustryReport?id=" + item.IndustrialManagementId);
  462. }
  463. },
  464. //音频点击暂停播放
  465. audioPlayBack() {
  466. if (this.$store.state.audioBg.activityId == this.detailData.ActivityId) {
  467. if (this.globalBgAudioManager.paused) {
  468. this.globalBgAudioManager.play();
  469. } else {
  470. this.globalBgAudioManager.pause();
  471. }
  472. } else {
  473. this.$store.commit("audioBg/addAudio", { list: this.detailData.VoiceList, activityId: this.detailData.ActivityId, activityTitle: this.detailData.ActivityName });
  474. }
  475. },
  476. //拖动进度条
  477. handleAudioSliderChange(e) {
  478. const value = e.detail.value;
  479. this.globalBgAudioManager.seek(value);
  480. },
  481. },
  482. async onLoad(option) {
  483. this.id = option.id || "";
  484. await this.$store.dispatch("checkHandle");
  485. // this.listenAudio()
  486. if (!this.$store.state.isAuth && !this.$store.state.isBind) {
  487. //已授权已绑定
  488. this.countryCcode(); //判断是否加区号
  489. this.getActivityDetail();
  490. }
  491. },
  492. /**
  493. * 用户点击分享
  494. */
  495. onShareAppMessage: function (res) {
  496. return {
  497. title: this.isHorzMobile ? "好友向您推荐此内容,上传名片享查研观向免费月卡!" : "活动详情",
  498. path: "/activityPages/activityDetail/activityDetail?id=" + this.id,
  499. success: (res) => {},
  500. fail: (err) => {},
  501. };
  502. },
  503. };
  504. </script>
  505. <style lang="scss">
  506. .activity-detail {
  507. padding-bottom: 100rpx;
  508. .notice {
  509. height: 60rpx;
  510. width: 100%;
  511. }
  512. .choose-limit {
  513. position: relative;
  514. display: flex;
  515. align-items: center;
  516. image {
  517. width: 130rpx;
  518. height: 38rpx;
  519. }
  520. .limit-img {
  521. position: absolute;
  522. top: -13rpx;
  523. right: -30rpx;
  524. width: 46rpx;
  525. height: 26rpx;
  526. }
  527. }
  528. .content {
  529. padding: 34rpx 34rpx 0rpx;
  530. margin-bottom: -20rpx;
  531. color: #333333;
  532. font-size: 28rpx;
  533. view {
  534. padding-left: 20rpx;
  535. }
  536. text {
  537. line-height: 80rpx;
  538. padding-left: 20rpx;
  539. }
  540. .phone {
  541. padding: 0;
  542. display: inline-block;
  543. color: #2c83ff;
  544. }
  545. .dialog-title {
  546. width: 682rpx;
  547. padding: 20rpx;
  548. background: #f2f2f2;
  549. opacity: 0.8;
  550. font-size: 30rpx;
  551. font-weight: bold;
  552. margin-bottom: 15rpx;
  553. color: #000;
  554. }
  555. .brackets-title {
  556. padding-left: 20rpx;
  557. }
  558. .city-box {
  559. display: flex;
  560. align-items: center;
  561. text {
  562. padding: 0;
  563. }
  564. .city {
  565. display: flex;
  566. color: #2088ff;
  567. align-items: center;
  568. image {
  569. width: 27rpx;
  570. height: 32rpx;
  571. margin-right: 12rpx;
  572. }
  573. }
  574. }
  575. }
  576. .network {
  577. margin-bottom: 30rpx;
  578. padding: 0 !important;
  579. display: flex;
  580. .network-left {
  581. width: 160rpx;
  582. text-align-last: justify;
  583. text-align: justify;
  584. flex-shrink: 0;
  585. }
  586. .network-right {
  587. width: 480rpx;
  588. }
  589. .network-zoom {
  590. .text_zoom {
  591. width: 100%;
  592. word-break: break-all;
  593. color: #333333;
  594. }
  595. view {
  596. padding: 0 !important;
  597. margin: 0 !important;
  598. }
  599. .copy-zoom {
  600. display: inline-block;
  601. padding: 5rpx 17rpx !important;
  602. border-radius: 34rpx;
  603. background-color: #ebf4ff;
  604. font-size: 24rpx;
  605. color: #2c83ff;
  606. margin: 0 10rpx;
  607. margin-top: 30rpx;
  608. }
  609. }
  610. .network-link {
  611. width: 520rpx !important;
  612. view {
  613. padding: 0 !important;
  614. margin: 0 !important;
  615. width: 100%;
  616. display: flex;
  617. justify-content: space-between;
  618. :first-child {
  619. width: 350rpx;
  620. }
  621. .copy-link {
  622. padding: 5rpx 17rpx !important;
  623. border-radius: 34rpx;
  624. background-color: #ebf4ff;
  625. font-size: 24rpx;
  626. color: #2c83ff;
  627. }
  628. }
  629. }
  630. }
  631. .default {
  632. // padding: 0 !important;
  633. // margin: 0;
  634. padding-left: 0 !important;
  635. line-height: 40rpx !important;
  636. }
  637. .content-bottom {
  638. margin: 50rpx 0 30rpx;
  639. .make-outbound {
  640. margin: 0 auto;
  641. width: 368rpx;
  642. height: 80rpx;
  643. background: linear-gradient(268deg, #2ddbff 0%, #1599ff 49%, #005eff 100%);
  644. opacity: 1;
  645. border-radius: 4rpx;
  646. color: #ffffff;
  647. font-size: 34rpx;
  648. line-height: 80rpx;
  649. text-align: center;
  650. }
  651. .make-generation {
  652. padding-top: 0rpx !important;
  653. line-height: 76rpx;
  654. }
  655. .make-conference {
  656. margin: 30rpx auto;
  657. width: 368rpx;
  658. height: 80rpx;
  659. border: 2px solid #2c83ff;
  660. opacity: 1;
  661. border-radius: 4rpx;
  662. padding-top: 5rpx;
  663. text-align: center;
  664. color: #2c83ff;
  665. font-size: 30rpx;
  666. text {
  667. font-size: 16rpx;
  668. }
  669. }
  670. }
  671. .bottom-env {
  672. position: fixed;
  673. bottom: 0;
  674. padding-bottom: constant(safe-area-inset-bottom);
  675. padding-bottom: env(safe-area-inset-bottom);
  676. left: 0;
  677. width: 100%;
  678. background-color: #ffffff;
  679. }
  680. .apply-box {
  681. width: 100%;
  682. height: 100rpx;
  683. display: flex;
  684. font-size: 32rpx;
  685. color: #333333;
  686. line-height: 100rpx;
  687. .cancel-apply {
  688. display: flex;
  689. padding-left: 50rpx;
  690. flex: 1;
  691. border: 2rpx solid #005eff;
  692. background-color: #fff;
  693. text {
  694. color: #005eff;
  695. }
  696. }
  697. .ok-apply {
  698. flex: 1;
  699. background: linear-gradient(268deg, #2ddbff 0%, #1599ff 49%, #005eff 100%);
  700. text-align: center;
  701. color: #ffffff;
  702. }
  703. }
  704. .select-box {
  705. width: 100%;
  706. view {
  707. height: 95prx;
  708. line-height: 95rpx;
  709. text-align: center;
  710. font-size: 32rpx;
  711. border-bottom: 1rpx solid #ebebeb;
  712. }
  713. }
  714. .dustrial-ui {
  715. margin-bottom: 10rpx !important;
  716. }
  717. .dustrial-li {
  718. display: inline-block;
  719. padding: 0 13rpx;
  720. margin: 0 20rpx 20rpx 0;
  721. }
  722. .dustrial-item {
  723. background: #edf4ff;
  724. border: 1px solid #3385ff;
  725. border-radius: 4rpx;
  726. color: #3385ff;
  727. }
  728. .audio-card {
  729. width: 100%;
  730. height: 282rpx;
  731. background: #f5f9ff;
  732. border-radius: 16rpx;
  733. margin: 0 auto;
  734. padding: 30rpx !important;
  735. .slider {
  736. width: 100%;
  737. margin: 0;
  738. }
  739. .card-title {
  740. color: #3385ff;
  741. font-size: 26rpx;
  742. padding: 0 66rpx;
  743. text-align: center;
  744. margin-bottom: 35rpx;
  745. }
  746. .card-time {
  747. display: flex;
  748. justify-content: space-between;
  749. color: #999999;
  750. font-size: 20rpx;
  751. padding-left: 0;
  752. .time {
  753. padding: 0;
  754. line-height: 26rpx;
  755. }
  756. }
  757. .is-paly-card {
  758. width: 100%;
  759. text-align: center;
  760. padding-left: 0;
  761. image {
  762. margin-top: 5rpx;
  763. width: 100rpx;
  764. height: 100rpx;
  765. }
  766. }
  767. }
  768. }
  769. </style>