import { d as l, D as A, a as o, A as n, I as p, V as r, S as u } from './index-20bdb712.js'; import { C as i } from './index-c814200a.js'; const h = '_mProtocol_7s6ie_1', d = '_center_7s6ie_6', m = '_protocolText_7s6ie_11', E = '_boxStyle_7s6ie_15', C = '_protocolContent_7s6ie_40', e = { mProtocol: h, center: d, protocolText: m, boxStyle: E, protocolContent: C }, T = '', w = '', R = { BUY_ORDER: '《音乐数字课堂服务协议》', REGISTER: '《音乐数字课堂注册协议》' }, b = l({ name: 'o-protocol', props: { showHeader: { type: Boolean, default: !1 }, modelValue: { type: Boolean, default: !1 }, prototcolType: { type: String, default: 'BUY_ORDER' }, center: { type: Boolean, default: !1 } }, data() { return { exists: !0, checked: this.modelValue, popupStatus: !1, protocolHTML: '', protocolPopup: null }; }, async mounted() { try { (this.checked = this.checked || this.exists), this.$emit('update:modelValue', this.checked || this.exists); } catch (t) {} (this.checked = this.modelValue), window.addEventListener('hashchange', this.onHash, !1); }, unmounted() { window.removeEventListener('hashchange', this.onHash, !1); }, watch: { checked(t) { this.$emit('update:modelValue', t); }, modelValue() { this.checked = this.modelValue; } }, methods: { async getContractDetail() { try { if (!this.protocolHTML) if (this.prototcolType === 'REGISTER') { const { data: t } = await A.get( '/edu-app/open/userContractRecord/queryLatestContractTemplate', { params: { contractType: 'REGISTER' } } ); this.protocolHTML = t.contractTemplateContent; } else { const { data: t } = await A.get( '/edu-app/schoolContractTemplate/queryLatestContractTemplate', { params: { contractType: this.prototcolType } } ); this.protocolHTML = t.contractTemplateContent; } this.onPopupClose(); } catch (t) {} }, onHash() { this.popupStatus = !1; }, onPopupClose() { if (((this.popupStatus = !this.popupStatus), this.popupStatus)) { const t = this.$route; let s = 0; for (const S in t.query) s += 1; const a = window.location.href, c = s > 0 ? '&pto=' + +new Date() : '?pto=' + +new Date(); history.pushState('', '', `${a}${c}`); } else window.history.go(-1); this.protocolPopup && (this.protocolPopup.scrollTop = 0); } }, render() { return o('div', { class: [e.mProtocol, this.center ? e.center : ''] }, [ o( i, { modelValue: this.checked, 'onUpdate:modelValue': t => (this.checked = t) }, { default: () => [n('我已阅读并同意')], icon: t => o(p, { class: e.boxStyle, name: t.checked ? T : w }, null) } ), o('span', { onClick: this.getContractDetail, class: e.protocolText }, [ R[this.prototcolType] ]), o( r, { ref: this.protocolPopup, show: this.popupStatus, position: 'bottom', style: { height: '100%' } }, { default: () => [ this.showHeader && o(u, { title: '管乐团平台服务协议' }, null), this.popupStatus && o('div', { id: 'mProtocol' }, [ o( 'div', { class: e.protocolContent, innerHTML: this.protocolHTML }, null ) ]) ] } ) ]); } }); export { b as O };