123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144 |
- 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 };
|