index-1089f88b.js 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506
  1. import {
  2. D as g,
  3. d as S,
  4. a as e,
  5. C as m,
  6. A as i,
  7. E as l,
  8. U as V,
  9. x as B,
  10. y as k,
  11. a4 as v,
  12. V as C
  13. } from './index-20bdb712.js';
  14. import { F as R } from './index-61a6f012.js';
  15. import { C as f } from './index-6930c802.js';
  16. import { F as p } from './index-7f161d6e.js';
  17. import { C as T } from './index-c814200a.js';
  18. import { A as q } from './index-064e7df8.js';
  19. import './index-a4ff0f6f.js';
  20. import './Checker-65584c7b.js';
  21. import './index-e6baae88.js';
  22. const M = '_container_1c3ne_1',
  23. L = '_titleIcon_1c3ne_11',
  24. J = '_schoolName_1c3ne_17',
  25. w = '_teacherIcon_1c3ne_25',
  26. N = '_toggleBtn_1c3ne_36',
  27. D = '_contentWrap_1c3ne_56',
  28. Y = '_content_1c3ne_56',
  29. Z = '_group_1c3ne_66',
  30. X = '_inputCode_1c3ne_86',
  31. P = '_sendBtn_1c3ne_96',
  32. j = '_tips_1c3ne_108',
  33. K = '_xieyiWrap_1c3ne_117',
  34. z = '_xieyi_1c3ne_117',
  35. O = '_submit_1c3ne_129',
  36. G = '_successWrap_1c3ne_139',
  37. H = '_p1_1c3ne_146',
  38. _ = '_p2_1c3ne_151',
  39. $ = '_btnWrap_1c3ne_156',
  40. ee = '_btnTitle_1c3ne_167',
  41. ne = '_btnDes_1c3ne_176',
  42. oe = '_btn_1c3ne_156',
  43. c = {
  44. container: M,
  45. titleIcon: L,
  46. schoolName: J,
  47. teacherIcon: w,
  48. toggleBtn: N,
  49. contentWrap: D,
  50. content: Y,
  51. group: Z,
  52. inputCode: X,
  53. sendBtn: P,
  54. tips: j,
  55. xieyiWrap: K,
  56. xieyi: z,
  57. submit: O,
  58. successWrap: G,
  59. p1: H,
  60. p2: _,
  61. btnWrap: $,
  62. btnTitle: ee,
  63. btnDes: ne,
  64. btn: oe
  65. },
  66. te =
  67. '',
  68. ce =
  69. '',
  70. b = '' + new URL('logo-cf48ca66.png', import.meta.url).href,
  71. ae = '' + new URL('icon_man-aebea9e4.png', import.meta.url).href,
  72. se = '' + new URL('icon_woman-64d74842.png', import.meta.url).href,
  73. le =
  74. '',
  75. ue =
  76. '',
  77. re = () => g.get('/edu-app/open/sysArea/queryAllProvince'),
  78. ie = a => g.post('/edu-app/open/teacher/add', { data: a }),
  79. Ae = a => g.post('/edu-app/open/sendSms', { data: a, requestType: 'form' }),
  80. de = '_container_ohbq7_1',
  81. pe = '_titleIcon_ohbq7_11',
  82. me = '_teacherIcon_ohbq7_17',
  83. ge = '_contentWrap_ohbq7_28',
  84. he = '_content_ohbq7_28',
  85. Fe = '_group_ohbq7_38',
  86. Ue = '_title_ohbq7_11',
  87. Ee = '_url_ohbq7_52',
  88. Be = '_submit_ohbq7_58',
  89. s = {
  90. container: de,
  91. titleIcon: pe,
  92. teacherIcon: me,
  93. contentWrap: ge,
  94. content: he,
  95. group: Fe,
  96. title: Ue,
  97. url: Ee,
  98. submit: Be
  99. },
  100. Ce = '' + new URL('icon_success-cf05a393.png', import.meta.url).href,
  101. Se = '' + new URL('icon_pcTeacher-a04e7e89.png', import.meta.url).href,
  102. Re =
  103. '',
  104. fe = S({
  105. name: 'SchoolRegister',
  106. setup() {
  107. const a = `${location.origin}/classroom`,
  108. t = () => {
  109. const o = document.createElement('input');
  110. (o.value = a),
  111. document.body.appendChild(o),
  112. o.select(),
  113. o.setSelectionRange(0, o.value.length),
  114. document.execCommand('Copy'),
  115. document.body.removeChild(o),
  116. l('复制成功');
  117. };
  118. return () =>
  119. e('div', { class: s.container }, [
  120. e('img', { class: s.titleIcon, src: b }, null),
  121. e(
  122. 'img',
  123. {
  124. class: s.titleIcon,
  125. style: { margin: '36Px auto', height: '68Px' },
  126. src: Ce
  127. },
  128. null
  129. ),
  130. e('div', { class: s.teacherIcon }, [e('img', { src: Se }, null)]),
  131. e('div', { class: s.contentWrap }, [
  132. e('div', { class: s.content }, [
  133. e(R, null, {
  134. default: () => [
  135. e(
  136. f,
  137. { class: s.group, border: !1 },
  138. {
  139. default: () => [
  140. e('div', { class: s.title }, [
  141. e('img', { src: Re }, null)
  142. ]),
  143. e('div', { class: s.url }, [a]),
  144. e('div', { class: s.submit }, [
  145. e(
  146. m,
  147. { block: !0, onClick: t },
  148. { default: () => [i('复制链接')] }
  149. )
  150. ])
  151. ]
  152. }
  153. )
  154. ]
  155. })
  156. ])
  157. ])
  158. ]);
  159. }
  160. }),
  161. Te = S({
  162. name: 'SchoolRegister',
  163. setup() {
  164. const a = V(),
  165. t = B({
  166. regionCode: '',
  167. cityCode: '',
  168. provinceCode: '',
  169. code: '',
  170. tenantId: a.query.tenantId || '',
  171. phone: null,
  172. schoolId: a.query.schoolId || '',
  173. nickname: null,
  174. gender: 1
  175. }),
  176. o = B({
  177. schoolName: a.query.schoolName || '',
  178. cityName: '',
  179. showArea: !1,
  180. checked: !0,
  181. success: !1,
  182. areaList: {},
  183. sendMsg: '获取验证码'
  184. }),
  185. x = n => {
  186. const u = {},
  187. h = {},
  188. F = {};
  189. return (
  190. n.forEach(r => {
  191. u[r.code] = r.name;
  192. }),
  193. n.forEach(r => {
  194. var A;
  195. (A = r.areas) == null ||
  196. A.forEach(d => {
  197. h[d.code] = d.name;
  198. });
  199. }),
  200. n.forEach(r => {
  201. var A;
  202. (A = r.areas) == null ||
  203. A.forEach(d => {
  204. var U;
  205. (U = d.areas) == null ||
  206. U.forEach(E => {
  207. F[E.code] = E.name;
  208. });
  209. });
  210. }),
  211. { province_list: u, city_list: h, county_list: F }
  212. );
  213. },
  214. y = () => {
  215. re().then(n => {
  216. (n == null ? void 0 : n.code) === 200 && (o.areaList = x(n.data));
  217. });
  218. };
  219. k(() => {
  220. y();
  221. });
  222. const Q = async () => {
  223. if (!t.phone) {
  224. l('请输入手机号码');
  225. return;
  226. }
  227. if (!/^1[3456789]\d{9}$/.test(t.phone)) {
  228. l('手机号码格式不正确');
  229. return;
  230. }
  231. if (!o.sendMsg.includes('s'))
  232. try {
  233. await Ae({
  234. clientId: 'cooleshow-student',
  235. type: 'REGISTER',
  236. mobile: t.phone
  237. }),
  238. W(),
  239. l({ message: '验证码发送成功', duration: 2e3 });
  240. } catch (n) {
  241. o.sendMsg = '重新发送';
  242. }
  243. },
  244. W = () => {
  245. o.sendMsg = '30s';
  246. let n = 30,
  247. u = setInterval(() => {
  248. n--,
  249. (o.sendMsg = `${n}s`),
  250. n <= 0 && ((o.sendMsg = '重新发送'), clearInterval(u));
  251. }, 1e3);
  252. },
  253. I = async () => {
  254. if (!o.checked) {
  255. l('请勾选注册协议');
  256. return;
  257. }
  258. if (!t.nickname) {
  259. l('请输入老师姓名');
  260. return;
  261. }
  262. if (!t.phone) {
  263. l('请输入手机号码');
  264. return;
  265. }
  266. if (!/^1[3456789]\d{9}$/.test(t.phone)) {
  267. l('手机号码格式不正确');
  268. return;
  269. }
  270. if (!t.code) {
  271. l('请输入验证码');
  272. return;
  273. }
  274. if (!t.provinceCode) {
  275. l('请选择城市');
  276. return;
  277. }
  278. const n = await ie({ ...t });
  279. (n == null ? void 0 : n.code) === 200 && (o.success = !0);
  280. };
  281. return () =>
  282. e('div', { class: c.container }, [
  283. e('img', { class: c.titleIcon, src: b }, null),
  284. e(
  285. 'img',
  286. {
  287. class: c.titleIcon,
  288. style: { margin: '16Px auto', height: '32Px' },
  289. src: te
  290. },
  291. null
  292. ),
  293. e('div', { class: c.schoolName }, [
  294. e(
  295. 'img',
  296. {
  297. style: {
  298. width: '16px',
  299. height: '16px',
  300. marginRight: '8px',
  301. verticalAlign: 'middle'
  302. },
  303. src: ce
  304. },
  305. null
  306. ),
  307. o.schoolName
  308. ]),
  309. e('div', { class: c.teacherIcon }, [
  310. e('img', { src: t.gender === 1 ? ae : se }, null),
  311. e(
  312. 'div',
  313. {
  314. class: c.toggleBtn,
  315. onClick: () => (t.gender = t.gender === 1 ? 0 : 1)
  316. },
  317. [
  318. e('span', null, [t.gender === 1 ? '男老师' : '女老师']),
  319. e('img', { src: le }, null)
  320. ]
  321. )
  322. ]),
  323. e('div', { class: c.contentWrap }, [
  324. e('div', { class: c.content }, [
  325. e(
  326. R,
  327. { onSubmit: () => I() },
  328. {
  329. default: () => [
  330. e(
  331. f,
  332. { class: c.group, border: !1 },
  333. {
  334. default: () => [
  335. e(
  336. p,
  337. {
  338. border: !1,
  339. labelWidth: '0',
  340. placeholder: '请输入老师姓名',
  341. maxlength: 20,
  342. modelValue: t.nickname,
  343. 'onUpdate:modelValue': n => (t.nickname = n)
  344. },
  345. null
  346. ),
  347. e(
  348. p,
  349. {
  350. border: !1,
  351. labelWidth: '0',
  352. maxlength: 11,
  353. placeholder: '请输入手机号码',
  354. modelValue: t.phone,
  355. 'onUpdate:modelValue': n => (t.phone = n)
  356. },
  357. null
  358. ),
  359. e('div', { class: c.tips }, [
  360. i('该手机号码即为酷乐秀音乐数字课堂老师端登录账号')
  361. ]),
  362. e(
  363. p,
  364. {
  365. class: c.inputCode,
  366. border: !1,
  367. labelWidth: 0,
  368. placeholder: '请输入验证码',
  369. modelValue: t.code,
  370. 'onUpdate:modelValue': n => (t.code = n),
  371. maxlength: 6
  372. },
  373. {
  374. button: () =>
  375. e(
  376. m,
  377. {
  378. disabled: o.sendMsg.includes('s'),
  379. class: c.sendBtn,
  380. onClick: () => Q()
  381. },
  382. { default: () => [o.sendMsg] }
  383. )
  384. }
  385. ),
  386. e(
  387. p,
  388. {
  389. border: !1,
  390. labelWidth: 0,
  391. placeholder: '请选择城市',
  392. readonly: !0,
  393. modelValue: o.cityName,
  394. 'onUpdate:modelValue': n => (o.cityName = n),
  395. onClick: () => (o.showArea = !0)
  396. },
  397. {
  398. button: () =>
  399. e(
  400. 'img',
  401. {
  402. style: {
  403. display: 'block',
  404. width: '8px',
  405. height: '6px',
  406. marginRight: '10px'
  407. },
  408. src: ue
  409. },
  410. null
  411. )
  412. }
  413. ),
  414. e('div', { class: c.xieyiWrap }, [
  415. e(
  416. T,
  417. {
  418. modelValue: o.checked,
  419. 'onUpdate:modelValue': n => (o.checked = n)
  420. },
  421. {
  422. default: () => [
  423. e('div', { class: c.xieyi }, [
  424. e('span', null, [i('我已阅读并同意')]),
  425. e(
  426. 'span',
  427. {
  428. style: { color: '#1677FF' },
  429. onClick: n => {
  430. n.stopPropagation(),
  431. v({
  432. api: 'openWebView',
  433. content: {
  434. url: `${location.origin}${location.pathname}#/preview-protocol`,
  435. orientation: 1,
  436. isHideTitle: !1
  437. }
  438. });
  439. }
  440. },
  441. [i('《酷乐秀音乐数字课堂学生端》')]
  442. ),
  443. e('span', null, [i('注册协议')])
  444. ])
  445. ]
  446. }
  447. )
  448. ]),
  449. e('div', { class: c.submit }, [
  450. e(
  451. m,
  452. { block: !0, 'native-type': 'submit' },
  453. { default: () => [i('注册')] }
  454. )
  455. ])
  456. ]
  457. }
  458. )
  459. ]
  460. }
  461. ),
  462. e(
  463. C,
  464. {
  465. show: o.showArea,
  466. 'onUpdate:show': n => (o.showArea = n),
  467. position: 'bottom'
  468. },
  469. {
  470. default: () => [
  471. e(
  472. q,
  473. {
  474. areaList: o.areaList,
  475. onCancel: () => (o.showArea = !1),
  476. onConfirm: ({ selectedOptions: n }) => {
  477. (t.provinceCode = n[0].value),
  478. (t.cityCode = n[1].value),
  479. (t.regionCode = n[2].value),
  480. (o.cityName = n.map(u => u.text).join('-')),
  481. (o.showArea = !1);
  482. }
  483. },
  484. null
  485. )
  486. ]
  487. }
  488. ),
  489. e(
  490. C,
  491. {
  492. style: { margin: 0 },
  493. class: 'popup-custom van-scale',
  494. transition: 'van-scale',
  495. closeOnClickOverlay: !1,
  496. show: o.success,
  497. 'onUpdate:show': n => (o.success = n)
  498. },
  499. { default: () => [e(fe, null, null)] }
  500. )
  501. ])
  502. ])
  503. ]);
  504. }
  505. });
  506. export { Te as default };