123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345 |
- import { C as f } from './index.9169d438.js'
- import { S as p } from './index.2778830d.js'
- import { U as E } from './index.fdb44d83.js'
- import { r as n, p as F } from './index.9e4b607f.js'
- import {
- d as I,
- g as a,
- T as A,
- D as l,
- a as r,
- K as v,
- j as c,
- B as h
- } from './vendor.3506a68e.js'
- import { o as s, a as D } from './orderStatus.81f9c36b.js'
- import { C as b } from './index.9a4c80cd.js'
- import { C as Y } from './index.e311a214.js'
- import './index.f15b595a.js'
- /* empty css */ /* empty css */ /* empty css */ import './icon_teacher.cb128c00.js'
- import './icon_timer2.5fb1750d.js'
- import './icon-jiaozi.20e415ca.js'
- /* empty css */ const g = '_introduction_17dsu_1',
- B = '_tips_17dsu_12',
- j = '_btnMore_17dsu_35'
- var d = {
- 'live-detail': '_live-detail_17dsu_1',
- introduction: g,
- tips: B,
- btnMore: j
- },
- T =
- '',
- H = I({
- name: 'LiveDetail',
- data() {
- const e = this.$route.query
- return {
- joinRoom: e.joinRoom,
- recomUserId: e.recomUserId,
- groupId: e.groupId,
- courseId: e.classId,
- live: {}
- }
- },
- computed: {
- userInfo() {
- var i, m
- const e = this.live,
- u = e.planList || [],
- t = ((i = u[0]) == null ? void 0 : i.startTime) || new Date(),
- o = ((m = u[0]) == null ? void 0 : m.endTime) || new Date()
- return {
- headUrl: e.avatar,
- username: e.userName || `\u6E38\u5BA2${e.teacherId || ''}`,
- startTime:
- `${a(t).format('YYYY-MM-DD')} ${a(t).format('HH:mm')}~${a(o).format(
- 'HH:mm'
- )}` || '',
- buyNum: e.studentCount,
- lessonPrice: e.coursePrice,
- lessonNum: e.courseNum,
- lessonDesc: e.courseIntroduce,
- lessonCoverUrl: e.backgroundPic || e.backgroundPicTemplate,
- lessonName: e.courseGroupName,
- auditVersion: e.auditVersion || 0,
- isDegree: !!e.degreeFlag,
- isTeacher: !!e.teacherFlag
- }
- },
- courseInfo() {
- const e = []
- return (
- (this.live.planList || []).forEach(t => {
- const o = t.startTime || new Date(),
- i = t.endTime || new Date()
- e.push({
- courseTime: `${a(o).format('YYYY-MM-DD')} ${a(o).format(
- 'HH:mm'
- )}~${a(i).format('HH:mm')}`,
- coursePlan: t.plan,
- roomUid: t.roomUid,
- liveState: t.liveState,
- id: t.courseId
- })
- }),
- e || []
- )
- },
- salesEndDate() {
- const e = this.live
- return a(e.salesEndDate || new Date()).format('YYYY-MM-DD')
- },
- liveStatus() {
- const e = this.live.planList || [],
- u = { status: !1, liveStatus: 0, roomUid: '' }
- return (
- e.forEach(t => {
- t.courseId === Number(this.courseId) &&
- ((u.status = !0),
- (u.liveStatus = t.liveStatus),
- (u.roomUid = t.roomUid))
- }),
- u
- )
- }
- },
- async mounted() {
- await this._init()
- },
- methods: {
- async _init() {
- try {
- const e = await n.get(
- '/api-student/courseGroup/queryLiveCourseInfo',
- { params: { groupId: this.groupId } }
- )
- this.live = e.data || {}
- } catch {}
- },
- async onJoinRoom() {
- try {
- const t =
- (
- (
- await n.get('/api-student/courseGroup/queryLiveCourseInfo', {
- params: { groupId: this.groupId }
- })
- ).data || {}
- ).planList || []
- let o = {}
- t.forEach(i => {
- i.courseId === Number(this.courseId) && (o = i)
- }),
- console.log(o, this.live, 'tempObj'),
- o && o.liveState === 1
- ? F({
- api: 'joinLiveRoom',
- content: { roomId: o.roomUid, teacherId: this.live.teacherId }
- })
- : o && o.liveState === 2
- ? setTimeout(() => {
- A('\u8BFE\u7A0B\u5DF2\u7ED3\u675F')
- }, 100)
- : setTimeout(() => {
- A(
- '\u8BFE\u7A0B\u5C1A\u672A\u5F00\u59CB\uFF0C\u8BF7\u8010\u5FC3\u7B49\u5019'
- )
- }, 100)
- } catch {}
- },
- async onBuy() {
- try {
- const e = this.live
- if (
- ((s.orderObject.orderType = 'LIVE'),
- (s.orderObject.orderName = '\u76F4\u64AD\u8BFE\u8D2D\u4E70'),
- (s.orderObject.orderDesc = '\u76F4\u64AD\u8BFE\u8D2D\u4E70'),
- (s.orderObject.actualPrice = e.coursePrice),
- (s.orderObject.recomUserId = this.recomUserId),
- (s.orderObject.orderNo = ''),
- (s.orderObject.orderList = [
- {
- orderType: 'LIVE',
- goodsName: '\u76F4\u64AD\u8BFE\u8D2D\u4E70',
- courseGroupId: e.courseGroupId,
- courseGroupName: e.courseGroupName,
- coursePrice: e.coursePrice,
- teacherName: e.userName || `\u6E38\u5BA2${e.teacherId || ''}`,
- teacherId: e.teacherId,
- avatar: e.avatar,
- courseInfo: this.courseInfo,
- recomUserId: this.recomUserId
- }
- ]),
- e.coursePrice <= 0)
- ) {
- await D(() => {
- l.alert({
- message: '\u9886\u53D6\u6210\u529F',
- confirmButtonText: '\u786E\u5B9A',
- confirmButtonColor: '#01C1B5'
- }).then(() => {
- this._init()
- })
- })
- return
- }
- const t = (
- await n.post('/api-student/userOrder/getPendingOrder', {
- data: { goodType: 'LIVE', bizId: this.groupId }
- })
- ).data
- t
- ? l
- .confirm({
- title: '\u63D0\u793A',
- message:
- '\u60A8\u6709\u4E00\u4E2A\u672A\u652F\u4ED8\u7684\u8BA2\u5355\uFF0C\u662F\u5426\u7EE7\u7EED\u652F\u4ED8\uFF1F',
- confirmButtonColor: '#269a93',
- cancelButtonText: '\u53D6\u6D88\u8BA2\u5355',
- confirmButtonText: '\u7EE7\u7EED\u652F\u4ED8'
- })
- .then(async () => {
- ;(s.orderObject.orderNo = t.orderNo),
- (s.orderObject.actualPrice = t.actualPrice),
- (s.orderObject.discountPrice = t.discountPrice),
- this.routerTo()
- })
- .catch(() => {
- l.close(), this.cancelPayment(t.orderNo)
- })
- : this.routerTo()
- } catch {}
- },
- routerTo() {
- const e = this.live
- this.$router.push({
- path: '/orderDetail',
- query: { orderType: 'LIVE', courseGroupId: e.courseGroupId }
- })
- },
- async cancelPayment(e) {
- try {
- await n.post('/api-student/userOrder/orderCancel', {
- data: { orderNo: e }
- })
- } catch {}
- }
- },
- render() {
- return r('div', { class: [d['live-detail'], 'mb12'] }, [
- r(b, null, null),
- r(E, { userInfo: this.userInfo, showBuy: !1 }, null),
- r(
- p,
- { border: !0 },
- {
- default: () => [
- r('p', { class: d.introduction }, [this.userInfo.lessonDesc])
- ]
- }
- ),
- r(
- p,
- {
- title: '\u8BFE\u7A0B\u5217\u8868',
- icon: 'courseList',
- border: !0,
- contentStyle: { paddingTop: '0' }
- },
- {
- default: () => [
- this.courseInfo.length > 0 &&
- r(
- f,
- {
- courseInfo: this.courseInfo,
- courseId: Number(this.courseId) || 0
- },
- null
- )
- ]
- }
- ),
- r('div', { class: d.tips }, [
- r('h3', null, [
- r(v, { name: T, size: 15 }, null),
- c('\u6E29\u99A8\u63D0\u793A')
- ]),
- r('p', null, [
- c(
- '1\u3001\u8BE5\u76F4\u64AD\u8BFE\u7A0B\u9500\u552E\u622A\u6B62\u540E\uFF0C\u62A5\u540D\u4EBA\u6570\u82E5\u5C11\u4E8E'
- ),
- this.live.mixStudentNum || 0,
- c(
- '\u4EBA\u5C06\u53D6\u6D88\u5F00\u8BFE\uFF0C\u5DF2\u8D2D\u4E70\u5B66\u5458\u4ED8\u8D39\u91D1\u989D\u5C06\u81EA\u52A8\u8FD4\u8FD8\uFF0C\u8BF7\u60A8\u653E\u5FC3\u8D2D\u4E70\uFF1B'
- ),
- r('br', null, null),
- c(
- '2\u3001\u76F4\u64AD\u8BFE\u6559\u5B66\u8BA1\u5212\u4E2D\u7684\u4E0A\u8BFE\u65F6\u95F4\u4E3A\u8001\u5E08\u9884\u8BA1\u65F6\u95F4\uFF0C\u5B9E\u9645\u4E0A\u8BFE\u65F6\u95F4\u4EE5\u8001\u5E08\u5F00\u542F\u76F4\u64AD\u65F6\u95F4\u4E3A\u51C6\uFF1B'
- ),
- r('br', null, null),
- c(
- '3\u3001\u82E5\u60A8\u9519\u8FC7\u8001\u5E08\u76F4\u64AD\uFF0C\u53EF\u901A\u8FC7\u89C6\u9891\u56DE\u653E\u89C2\u770B\u5B8C\u6574\u8BFE\u7A0B\u3002'
- )
- ])
- ]),
- this.courseInfo.length > 0 &&
- this.live.existBuy !== 1 &&
- r(
- Y,
- { position: 'bottom', background: 'white' },
- {
- default: () => [
- r('div', { class: ['btnGroup', d.btnMore] }, [
- r(
- h,
- {
- block: !0,
- round: !0,
- type: 'primary',
- onClick: this.onBuy
- },
- {
- default: () => [
- this.live.coursePrice <= 0
- ? '\u514D\u8D39\u9886\u53D6'
- : '\u7ACB\u5373\u8D2D\u4E70'
- ]
- }
- )
- ])
- ]
- }
- ),
- this.joinRoom == '1' &&
- this.liveStatus.liveStatus !== 2 &&
- r(
- Y,
- { position: 'bottom', background: 'white' },
- {
- default: () => [
- r(
- 'div',
- { class: ['btnGroup'], style: { paddingTop: '12px' } },
- [
- r(
- h,
- {
- block: !0,
- round: !0,
- type: 'primary',
- onClick: this.onJoinRoom
- },
- { default: () => [c('\u8FDB\u5165\u76F4\u64AD\u95F4')] }
- )
- ]
- )
- ]
- }
- )
- ])
- }
- })
- export { H as default }
|