index-a25e1c12.js 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. import {
  2. d as l,
  3. D as A,
  4. a as o,
  5. A as n,
  6. I as p,
  7. V as r,
  8. S as u
  9. } from './index-20bdb712.js';
  10. import { C as i } from './index-c814200a.js';
  11. const h = '_mProtocol_7s6ie_1',
  12. d = '_center_7s6ie_6',
  13. m = '_protocolText_7s6ie_11',
  14. E = '_boxStyle_7s6ie_15',
  15. C = '_protocolContent_7s6ie_40',
  16. e = {
  17. mProtocol: h,
  18. center: d,
  19. protocolText: m,
  20. boxStyle: E,
  21. protocolContent: C
  22. },
  23. T =
  24. '',
  25. w =
  26. '',
  27. R = {
  28. BUY_ORDER: '《音乐数字课堂服务协议》',
  29. REGISTER: '《音乐数字课堂注册协议》'
  30. },
  31. b = l({
  32. name: 'o-protocol',
  33. props: {
  34. showHeader: { type: Boolean, default: !1 },
  35. modelValue: { type: Boolean, default: !1 },
  36. prototcolType: { type: String, default: 'BUY_ORDER' },
  37. center: { type: Boolean, default: !1 }
  38. },
  39. data() {
  40. return {
  41. exists: !0,
  42. checked: this.modelValue,
  43. popupStatus: !1,
  44. protocolHTML: '',
  45. protocolPopup: null
  46. };
  47. },
  48. async mounted() {
  49. try {
  50. (this.checked = this.checked || this.exists),
  51. this.$emit('update:modelValue', this.checked || this.exists);
  52. } catch (t) {}
  53. (this.checked = this.modelValue),
  54. window.addEventListener('hashchange', this.onHash, !1);
  55. },
  56. unmounted() {
  57. window.removeEventListener('hashchange', this.onHash, !1);
  58. },
  59. watch: {
  60. checked(t) {
  61. this.$emit('update:modelValue', t);
  62. },
  63. modelValue() {
  64. this.checked = this.modelValue;
  65. }
  66. },
  67. methods: {
  68. async getContractDetail() {
  69. try {
  70. if (!this.protocolHTML)
  71. if (this.prototcolType === 'REGISTER') {
  72. const { data: t } = await A.get(
  73. '/edu-app/open/userContractRecord/queryLatestContractTemplate',
  74. { params: { contractType: 'REGISTER' } }
  75. );
  76. this.protocolHTML = t.contractTemplateContent;
  77. } else {
  78. const { data: t } = await A.get(
  79. '/edu-app/schoolContractTemplate/queryLatestContractTemplate',
  80. { params: { contractType: this.prototcolType } }
  81. );
  82. this.protocolHTML = t.contractTemplateContent;
  83. }
  84. this.onPopupClose();
  85. } catch (t) {}
  86. },
  87. onHash() {
  88. this.popupStatus = !1;
  89. },
  90. onPopupClose() {
  91. if (((this.popupStatus = !this.popupStatus), this.popupStatus)) {
  92. const t = this.$route;
  93. let s = 0;
  94. for (const S in t.query) s += 1;
  95. const a = window.location.href,
  96. c = s > 0 ? '&pto=' + +new Date() : '?pto=' + +new Date();
  97. history.pushState('', '', `${a}${c}`);
  98. } else window.history.go(-1);
  99. this.protocolPopup && (this.protocolPopup.scrollTop = 0);
  100. }
  101. },
  102. render() {
  103. return o('div', { class: [e.mProtocol, this.center ? e.center : ''] }, [
  104. o(
  105. i,
  106. {
  107. modelValue: this.checked,
  108. 'onUpdate:modelValue': t => (this.checked = t)
  109. },
  110. {
  111. default: () => [n('我已阅读并同意')],
  112. icon: t =>
  113. o(p, { class: e.boxStyle, name: t.checked ? T : w }, null)
  114. }
  115. ),
  116. o('span', { onClick: this.getContractDetail, class: e.protocolText }, [
  117. R[this.prototcolType]
  118. ]),
  119. o(
  120. r,
  121. {
  122. ref: this.protocolPopup,
  123. show: this.popupStatus,
  124. position: 'bottom',
  125. style: { height: '100%' }
  126. },
  127. {
  128. default: () => [
  129. this.showHeader && o(u, { title: '管乐团平台服务协议' }, null),
  130. this.popupStatus &&
  131. o('div', { id: 'mProtocol' }, [
  132. o(
  133. 'div',
  134. { class: e.protocolContent, innerHTML: this.protocolHTML },
  135. null
  136. )
  137. ])
  138. ]
  139. }
  140. )
  141. ]);
  142. }
  143. });
  144. export { b as O };