index.tsx 32 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941
  1. import { defineComponent, onMounted, onUnmounted, reactive, ref, nextTick, computed, watch } from 'vue';
  2. import styles from './index.module.less';
  3. import {
  4. Button,
  5. CellGroup,
  6. Field,
  7. Picker,
  8. Popup,
  9. closeToast,
  10. showToast,
  11. Loading,
  12. Form,
  13. CountDown,
  14. Cell,
  15. Area,
  16. } from 'vant';
  17. import { useRoute, useRouter } from 'vue-router';
  18. // import threeMan from './images/update/three-man.png'
  19. import OWxTip from '@/components/m-wx-tip';
  20. import { checkPhone } from '@/helpers/utils';
  21. import qs from 'query-string';
  22. import request from '@/helpers/request';
  23. import MImgCode from '@/components/m-img-code';
  24. import MSearch from '@/components/m-search';
  25. import submitBtn from './images/submit_icon.png'
  26. import signupBtn from './images/signup_icon.png'
  27. import signSusIcon from './images/sign_icon.png'
  28. import subSusIcon from './images/subsus_icon.png'
  29. import doneIcon from './images/done_icon.png'
  30. import { api_sysAreaQueryAllProvince, api_queryTennatArea } from '@/views/school-register/api';
  31. import useAuthCode from '@/hooks/useAuthCode';
  32. export default defineComponent({
  33. name: 'fill-questionnaire',
  34. setup() {
  35. const router = useRouter();
  36. const route = useRoute();
  37. const authCode = useAuthCode();
  38. const classList: any = [];
  39. for (let i = 1; i <= 40; i++) {
  40. classList.push({ text: i + '班', value: i });
  41. }
  42. const gradeList = route.query.meetingType === 'primarySchoolNo' || route.query.meetingType === 'primarySchoolYes' ? [
  43. {
  44. text: '一年级',
  45. value: 1
  46. },
  47. {
  48. text: '二年级',
  49. value: 2
  50. },
  51. {
  52. text: '三年级',
  53. value: 3
  54. },
  55. {
  56. text: '四年级',
  57. value: 4
  58. },
  59. {
  60. text: '五年级',
  61. value: 5
  62. },
  63. {
  64. text: '六年级',
  65. value: 6
  66. },
  67. ] : [
  68. {
  69. text: '六年级',
  70. value: 6
  71. },
  72. {
  73. text: '七年级',
  74. value: 7
  75. },
  76. {
  77. text: '八年级',
  78. value: 8
  79. },
  80. {
  81. text: '九年级',
  82. value: 9
  83. },
  84. ]
  85. const GRADE_ENUM = {
  86. '1': '一年级',
  87. '2': '二年级',
  88. '3': '三年级',
  89. '4': '四年级',
  90. '5': '五年级',
  91. '6': '六年级',
  92. '7': '七年级',
  93. '8': '八年级',
  94. '9': '九年级'
  95. } as any;
  96. const getGradeList = (gradeYear?: string, instrumentCode?: string) => {
  97. let tempList: any = [];
  98. const five = [
  99. { text: '一年级', value: 1, instrumentCode },
  100. { text: '二年级', value: 2, instrumentCode },
  101. { text: '三年级', value: 3, instrumentCode },
  102. { text: '四年级', value: 4, instrumentCode },
  103. { text: '五年级', value: 5, instrumentCode }
  104. ];
  105. const one = [{ text: '六年级', value: 6, instrumentCode }];
  106. const three = [
  107. { text: '七年级', value: 7, instrumentCode },
  108. { text: '八年级', value: 8, instrumentCode },
  109. { text: '九年级', value: 9, instrumentCode }
  110. ];
  111. if (gradeYear === 'FIVE_YEAR_SYSTEM') {
  112. tempList.push(...[...five]);
  113. } else if (gradeYear === 'SIX_YEAR_SYSTEM') {
  114. tempList.push(...[...five, ...one]);
  115. } else if (gradeYear === 'THREE_YEAR_SYSTEM') {
  116. tempList.push(...[...three]);
  117. } else if (gradeYear === 'FORE_YEAR_SYSTEM') {
  118. tempList.push(...[...one, ...three]);
  119. } else {
  120. tempList.push(...[...five, ...one, ...three]);
  121. }
  122. return tempList;
  123. };
  124. const countDownRef = ref();
  125. const forms = reactive({
  126. isPageHide: false,
  127. currentClassText: '',
  128. supportList: [
  129. {
  130. title: '支持学校开展',
  131. val: true
  132. },
  133. {
  134. title: '不支持开展',
  135. val: false
  136. }
  137. ],
  138. willingList: [
  139. {
  140. title: '愿意参加并意向报名',
  141. val: true
  142. },
  143. {
  144. title: '不愿意参加',
  145. val: false
  146. }
  147. ],
  148. username: '',
  149. openId: null as any,
  150. participationFlag: null as any, // 是否愿意参加
  151. supportFlag: null as any, // 是否支持
  152. currentGrade: null as any,
  153. currentClass: null as any,
  154. provinceCode: '',
  155. cityCode: '',
  156. districtCode: '',
  157. phone: '',
  158. prePhone: '',
  159. smsCode: '',
  160. selectArea: '', // 所选地区
  161. selectSchool: '', // 所选学校
  162. selectClass: '',
  163. countDownStatus: true,
  164. countDownTime: 1000 * 120, // 倒计时时间
  165. imgCodeStatus: false,
  166. successPopShow: false, // 提交结果弹窗
  167. schoolStatus: false,
  168. schoolPopupShow: false,
  169. schoolLoading: false,
  170. schoolPopupIndex: [] as any,
  171. schoolAreaList: [] as any,
  172. schoolAreaId: null, // 学校区域编号
  173. schoolInstrumentSetType: null as any,
  174. gradeList: [] as any,
  175. classList: [] as any,
  176. schoolName: '',
  177. gradeNumText: '',
  178. areaName: '',
  179. gradeStatus: false, // 年级状态
  180. classStatus: false, // 班级状态
  181. gradePopupShow: false,
  182. gradePopupIndex: [] as any, // 年级下拉索引
  183. classPopupShow: false,
  184. classPopupIndex: [] as any, // 班级下拉索引
  185. areaList: [] as any,
  186. showPicker: false,
  187. gradeAndClass: [gradeList, classList],
  188. gradeAndClassIndex: [] as any,
  189. gradeOptions: gradeList,
  190. classOptions: classList,
  191. gradeOptionIndex: [] as any,
  192. classOptionIndex: [] as any,
  193. submitLoading: false,
  194. id: null as any,
  195. code: null as any,
  196. areaPopupIndex: null as any,
  197. customSearchText: '' as any,
  198. tenantId: null as any, // 机构id
  199. customQuestionE: null as any, // 自定义的题目标题
  200. })
  201. onMounted(async () => {
  202. // 根据机构id获取省市区id
  203. forms.tenantId = route.query.tenantId
  204. if (sessionStorage.getItem('customQuestionE')) {
  205. forms.customQuestionE = sessionStorage.getItem('customQuestionE')
  206. }
  207. const { data } = await api_queryTennatArea(forms.tenantId)
  208. if (data && data.length) {
  209. forms.provinceCode = data[0].provinceCode
  210. forms.cityCode = data[0].cityCode
  211. forms.districtCode = data[0].regionCode
  212. /**
  213. * 2025.02.28,修改为不需要选区域,直接选学校,之前的逻辑如果areaName存在,则不需要选区域,后续可能会放开,又需要选区域,所以先随便给areaName赋值
  214. */
  215. forms.areaName = '学校名称'
  216. //getSchoolAreaList()
  217. }
  218. console.log(333,forms.provinceCode)
  219. queryDetail();
  220. // getAreaList();
  221. });
  222. // 如果没有openId,跳转到第一个页面
  223. forms.openId = authCode.onWeChatCatchOpenId("GET");
  224. if (!forms.openId) {
  225. router.push({
  226. path: '/intention-questionnaire',
  227. query: {
  228. type: route.query.meetingType
  229. }
  230. });
  231. }
  232. const onPageShow = () => {
  233. console.log(forms.isPageHide, 'showInfo');
  234. if (forms.isPageHide) {
  235. window.location.reload();
  236. }
  237. };
  238. // 处理监听页面返回不刷新的问题
  239. window.addEventListener('pageshow', onPageShow);
  240. const onPageHide = () => {
  241. console.log(forms.isPageHide, 'showInfo');
  242. forms.isPageHide = true;
  243. };
  244. window.addEventListener('pagehide', onPageHide);
  245. const queryDetail = async () => {
  246. try {
  247. // 判断是否获取微信code码
  248. if (!forms.openId) return;
  249. const { data } = await request.get(
  250. '/edu-app/open/schoolMeetingQuestion/detail?openId=' + forms.openId
  251. );
  252. if (!data) return;
  253. // forms.provinceCode = data.provinceCode
  254. // forms.cityCode = data.cityCode
  255. // forms.districtCode = data.districtCode
  256. // console.log(12222,data,forms.provinceCode)
  257. // 回显省市区
  258. forms.areaPopupIndex = data.districtCode || data.cityCode || data.provinceCode
  259. forms.areaPopupIndex = forms.areaPopupIndex ? String(forms.areaPopupIndex) : null
  260. const primarySchool = ['一年级','二年级','三年级','四年级','五年级','六年级',], juniorSchool = ['六年级','七年级','八年级','九年级'];
  261. if (primarySchool.includes(data.currentGrade) && (route.query.meetingType === 'primarySchoolNo' || route.query.meetingType === 'primarySchoolYes')) {
  262. forms.currentClass = data.currentClass
  263. forms.currentGrade = data.currentGrade
  264. }
  265. if (juniorSchool.includes(data.currentGrade) && (route.query.meetingType === 'juniorSchoolNo' || route.query.meetingType === 'juniorSchool')) {
  266. forms.currentClass = data.currentClass
  267. forms.currentGrade = data.currentGrade
  268. }
  269. forms.phone = data.phone
  270. forms.prePhone = data.phone
  271. forms.username = data.username
  272. forms.schoolAreaId = data.schoolAreaId
  273. forms.schoolPopupIndex = data.schoolAreaId ? [data.schoolAreaId] : []
  274. forms.schoolName = data.schoolName
  275. forms.supportFlag = data.supportFlag
  276. forms.participationFlag = data.participationFlag
  277. forms.areaName = data.provinceName + ' ' + data.cityName + ' ' + (data.districtName || '')
  278. const gradeIdx = gradeList.find(item => item.text === data.currentGrade)?.value || 1
  279. // @ts-ignore
  280. const classIdx = classList.find(item => item.text === data.currentClass)?.value || 1
  281. // forms.gradeAndClassIndex = [gradeIdx, classIdx]
  282. forms.gradeOptionIndex = [gradeIdx]
  283. forms.classOptionIndex = [classIdx]
  284. getSchoolAreaList()
  285. } catch {
  286. //
  287. }
  288. }
  289. /** 手机号变更时清空验证码信息,用户信息 */
  290. const phoneChangeEmptyInfo = () => {
  291. };
  292. const onCodeSend = () => {
  293. forms.countDownStatus = false;
  294. nextTick(() => {
  295. countDownRef.value.start();
  296. });
  297. };
  298. const onSendCode = () => {
  299. // 发送验证码
  300. if (!checkPhone(forms.phone)) {
  301. return showToast('请输入正确的手机号码');
  302. }
  303. forms.imgCodeStatus = true;
  304. };
  305. const validatePhone = computed(() => {
  306. return checkPhone(forms.phone) ? true : false;
  307. });
  308. const onFinished = () => {
  309. forms.countDownStatus = true;
  310. countDownRef.value.reset();
  311. };
  312. const checkForm = (status = true) => {
  313. const regex = /^[\u4e00-\u9fa5]{2,14}$/;
  314. if (!forms.schoolAreaId) {
  315. showToast('请选择学校');
  316. return false;
  317. }
  318. if (!forms.username) {
  319. showToast('请输入姓名');
  320. return false;
  321. }
  322. if (!regex.test(forms.username)) {
  323. showToast('请输入正确的中文姓名');
  324. return false;
  325. }
  326. if (!forms.currentGrade) {
  327. showToast('请选择年级');
  328. return false;
  329. }
  330. if (!forms.currentClass) {
  331. showToast('请选择班级');
  332. return false;
  333. }
  334. if (forms.supportFlag === null) {
  335. showToast('请勾选是否支持学校数字化转型');
  336. return false;
  337. }
  338. if (forms.participationFlag === null) {
  339. showToast('请勾选是否愿意学生参加数字化转型');
  340. return false;
  341. }
  342. if (forms.participationFlag) {
  343. if (!checkPhone(forms.phone)) {
  344. status && showToast('请输入正确的手机号码');
  345. return false;
  346. } else if (!forms.smsCode) {
  347. status && showToast('请输入验证码');
  348. return false;
  349. }
  350. }
  351. return true;
  352. };
  353. const submitFill = async () => {
  354. if (checkForm()) {
  355. try {
  356. forms.submitLoading = true;
  357. const { currentClass, districtCode, currentGrade, participationFlag,cityCode, openId,provinceCode,smsCode,phone,schoolAreaId,supportFlag,username,id, tenantId} = forms
  358. let params: any = {
  359. currentClass, districtCode, currentGrade, participationFlag,cityCode, openId,provinceCode,schoolAreaId,supportFlag,username, tenantId
  360. }
  361. if (id) {
  362. params.id = id
  363. }
  364. if (participationFlag) {
  365. params.phone = phone
  366. params.smsCode = smsCode
  367. }
  368. const res = await request.post('/edu-app/open/schoolMeetingQuestion/save', {
  369. data: params
  370. });
  371. if (res.code === 200) {
  372. forms.successPopShow = true;
  373. forms.prePhone = forms.phone
  374. }
  375. forms.submitLoading = false;
  376. forms.countDownStatus = true;
  377. } catch {
  378. //
  379. forms.submitLoading = false;
  380. forms.countDownStatus = true;
  381. }
  382. }
  383. }
  384. const formateArea = (area: any[]) => {
  385. const province_list: { [_: string]: string } = {};
  386. const city_list: { [_: string]: string } = {};
  387. const county_list: { [_: string]: string } = {};
  388. area.forEach((item: any) => {
  389. province_list[item.code] = item.name;
  390. });
  391. area.forEach((item: any) => {
  392. item.areas?.forEach((city: any) => {
  393. city_list[city.code] = city.name;
  394. });
  395. });
  396. area.forEach((item: any) => {
  397. item.areas?.forEach((city: any) => {
  398. city.areas?.forEach((county: any) => {
  399. county_list[county.code] = county.name;
  400. });
  401. });
  402. });
  403. return {
  404. province_list,
  405. city_list,
  406. county_list
  407. };
  408. };
  409. const getAreaList = () => {
  410. api_sysAreaQueryAllProvince().then(res => {
  411. if (res?.code === 200) {
  412. forms.areaList = formateArea(res.data);
  413. }
  414. });
  415. };
  416. const openAreaPop = () => {
  417. console.log(11111)
  418. // forms.schoolStatus = true
  419. // 如果没有选省市区,默认打开省市区弹窗
  420. if (!forms.areaName) {
  421. forms.showPicker = true
  422. } else {
  423. forms.schoolStatus = true
  424. getSchoolAreaList()
  425. }
  426. }
  427. // 高亮显示匹配的文字
  428. const highlightText = (text: string) => {
  429. if (!forms.customSearchText) return text;
  430. const regex = new RegExp(`(${forms.customSearchText})`, 'gi'); // 创建正则匹配用户输入
  431. const customText = text.replace(regex, '<span class="highLight">$1</span>'); // 将匹配部分包裹在 <span> 中
  432. // console.log(customText,999)
  433. return customText
  434. }
  435. const getSchoolAreaList = async (name?: string) => {
  436. forms.schoolLoading = true;
  437. try {
  438. const { data } = await request.post('/edu-app/open/schoolArea/list', {
  439. data: {
  440. name,
  441. testFlag: true,
  442. provinceCode: forms.provinceCode,
  443. cityCode: forms.cityCode,
  444. regionCode: forms.districtCode
  445. }
  446. });
  447. forms.customSearchText = name || ''
  448. forms.schoolAreaList = data;
  449. } catch {
  450. //
  451. }
  452. forms.schoolLoading = false;
  453. };
  454. const switchParticipationFlag = (val: boolean) => {
  455. forms.participationFlag = val
  456. if (!forms.participationFlag) {
  457. forms.phone = ''
  458. forms.smsCode = ''
  459. forms.countDownStatus = true
  460. }
  461. if (forms.participationFlag) {
  462. forms.phone = forms.prePhone
  463. }
  464. }
  465. // 获取地区学校详情
  466. const getSchoolAreaDetail = async () => {
  467. try {
  468. const { data } = await request.get(
  469. '/edu-app/open/schoolArea/detail/' + forms.schoolAreaId
  470. );
  471. console.log(data, 'data');
  472. if (data.school) {
  473. const schoolInfo = data.school || {};
  474. const schoolInstrumentList = schoolInfo.schoolInstrumentList || [];
  475. forms.schoolInstrumentSetType = schoolInfo.instrumentSetType;
  476. if (schoolInfo.instrumentSetType === 'SCHOOL') {
  477. const instrumentCode = schoolInstrumentList[0]?.instrumentCode;
  478. forms.gradeList = getGradeList(
  479. schoolInfo.gradeYear,
  480. instrumentCode
  481. );
  482. forms.classList = classList;
  483. } else if (schoolInfo.instrumentSetType === 'GRADE') {
  484. forms.gradeList = [];
  485. schoolInstrumentList.forEach((item: any) => {
  486. forms.gradeList.push({
  487. text: GRADE_ENUM[item.gradeNum],
  488. value: item.gradeNum,
  489. instrumentId: item.instrumentId,
  490. instrumentCode: item.instrumentCode
  491. });
  492. });
  493. forms.gradeList.sort((a: any, b: any) => a.value - b.value);
  494. forms.classList = classList;
  495. } else if (schoolInfo.instrumentSetType === 'CLASS') {
  496. // 班级
  497. const tempGradeList: any[] = [];
  498. schoolInstrumentList.forEach((item: any) => {
  499. if (!tempGradeList.includes(item.gradeNum)) {
  500. tempGradeList.push(item.gradeNum);
  501. }
  502. });
  503. const lastGradeList: any[] = [];
  504. tempGradeList.forEach((temp: any) => {
  505. const list = {
  506. text: GRADE_ENUM[temp],
  507. value: temp,
  508. instrumentId: '',
  509. instrumentCode: '',
  510. instrumentName: '',
  511. classList: [] as any
  512. };
  513. schoolInstrumentList.forEach((item: any) => {
  514. if (temp === item.gradeNum) {
  515. list.instrumentId = item.instrumentId;
  516. list.instrumentCode = item.instrumentCode;
  517. list.instrumentName = item.instrumentName;
  518. list.classList.push({
  519. text: item.classNum + '班',
  520. value: item.classNum,
  521. instrumentCode: item.instrumentCode
  522. });
  523. }
  524. });
  525. // 排序班级
  526. list.classList.sort((a: any, b: any) => a.value - b.value);
  527. lastGradeList.push(list);
  528. });
  529. lastGradeList.sort((a: any, b: any) => a.value - b.value);
  530. forms.gradeList = lastGradeList;
  531. forms.classList = [];
  532. } else {
  533. forms.gradeList = getGradeList(schoolInfo.gradeYear);
  534. forms.classList = classList;
  535. }
  536. } else {
  537. forms.schoolInstrumentSetType = '';
  538. forms.gradeList = getGradeList();
  539. forms.classList = classList;
  540. }
  541. } catch {
  542. //
  543. }
  544. };
  545. // 监听状态
  546. watch(
  547. () => forms.showPicker,
  548. () => {
  549. if (forms.showPicker) {
  550. forms.areaPopupIndex = forms.districtCode || forms.cityCode || forms.provinceCode
  551. forms.areaPopupIndex = forms.areaPopupIndex ? String(forms.areaPopupIndex) : null
  552. }
  553. }
  554. )
  555. watch(
  556. () => forms.schoolStatus,
  557. () => {
  558. if (forms.schoolStatus) {
  559. forms.schoolPopupIndex = forms.schoolAreaId ? [forms.schoolAreaId] : [];
  560. }
  561. }
  562. )
  563. onUnmounted(() => {
  564. window.removeEventListener('pageshow', onPageShow);
  565. window.removeEventListener('pagehide', onPageHide);
  566. });
  567. return () => (
  568. <div class={styles['intention-page']}>
  569. <div class={styles.formBox}>
  570. <div class={styles.formItem}>
  571. <p>1. 学校</p>
  572. {
  573. forms.schoolName ?
  574. <div class={[styles.valDone, (forms.schoolStatus||forms.showPicker) && styles.openVal]} onClick={() => {
  575. forms.schoolStatus = true
  576. getSchoolAreaList()
  577. }}>
  578. {forms.schoolName && <span class={styles.vdSchool}>{forms.schoolName}</span>}
  579. {/* <span class={styles.vdArea}>{forms.areaName}</span> */}
  580. <i></i>
  581. </div> :
  582. <div class={[styles.valDot, styles.grayText, (forms.schoolStatus||forms.showPicker) && styles.openVal]} onClick={openAreaPop}>请选择学校<i></i></div>
  583. }
  584. <div></div>
  585. </div>
  586. <div class={styles.formItem}>
  587. <p>2. 学生姓名</p>
  588. <Field
  589. class={styles.valDot}
  590. clearable={false}
  591. inputAlign="left"
  592. placeholder="请输入学生姓名"
  593. autocomplete="off"
  594. maxlength={14}
  595. v-model={forms.username}>
  596. </Field>
  597. </div>
  598. <div class={styles.formItem}>
  599. <p>3. 年级</p>
  600. <div class={[styles.valDot, !forms.currentGrade && styles.grayText, forms.gradeStatus && styles.openVal]}
  601. onClick={()=> {
  602. const gradeIdx = gradeList.find(item => item.text === forms.currentGrade)?.value || 1
  603. forms.gradeOptionIndex = [gradeIdx]
  604. forms.gradeStatus = true
  605. }}>{forms.currentGrade ? forms.currentGrade : '请选择年级'}<i></i></div>
  606. </div>
  607. <div class={styles.formItem}>
  608. <p>4. 班级</p>
  609. <div class={[styles.valDot, !forms.currentClass && styles.grayText, forms.classStatus && styles.openVal]}
  610. onClick={()=> {
  611. const classIdx = classList.find((item: any) => item.text === forms.currentClass)?.value || 1
  612. forms.classOptionIndex = [classIdx]
  613. forms.classStatus = true
  614. }}>{forms.currentClass ? forms.currentClass : '请选择班级'}<i></i></div>
  615. </div>
  616. <div class={styles.formItem}>
  617. <p>5. 在您了解以上数字化转型事项后,您是否支持学校开展音乐(器乐)课堂数字化转型</p>
  618. <div class={styles.selectItem}>
  619. {
  620. forms.supportList.map(item =>
  621. <div onClick={() => (forms.supportFlag = item.val)}>
  622. <i class={forms.supportFlag === item.val && styles.selectedIcon}></i>
  623. <span>{item.title}</span>
  624. </div>
  625. )
  626. }
  627. </div>
  628. </div>
  629. <div class={styles.formItem}>
  630. {
  631. forms.customQuestionE ?
  632. <>
  633. <div v-html={forms.customQuestionE}></div>
  634. </> :
  635. <>
  636. {
  637. route.query.meetingType === 'primarySchoolNo' || route.query.meetingType === 'juniorSchoolNo' ?
  638. <p>6. 您是否愿意学生参加数字化转型<span>(注:以学生及家长自愿参加为原则。如愿意参加,家长需自行为学生准备好乐器和“器乐数字Ai”应用软件两项学习工具,市面上均有提供,大约300多元一年。学校不涉及任何收费行为。如不参加,学生按原有方式进行音乐课学习。)</span></p> :
  639. <p>6. 您是否愿意学生参加数字化转型<span>(注:以学生及家长自愿参加为原则。如愿意参加,家长需自行为学生准备好“器乐数字Ai”应用软件,市面上均有提供,大约300多元一年,学校不涉及任何收费行为。如不参加,学生按原有方式进行器乐课程学习。)</span></p>
  640. }
  641. </>
  642. }
  643. <div class={styles.selectItem}>
  644. {
  645. forms.willingList.map(item =>
  646. <div onClick={() => switchParticipationFlag(item.val)}>
  647. <i class={forms.participationFlag === item.val && styles.selectedIcon}></i>
  648. <span>{item.title}</span>
  649. </div>
  650. )
  651. }
  652. </div>
  653. </div>
  654. {
  655. forms.participationFlag &&
  656. <div class={styles.formItem}>
  657. <p>联系方式</p>
  658. <Field
  659. class={styles.valDot}
  660. clearable={false}
  661. placeholder="请输入手机号码"
  662. type="digit"
  663. autocomplete="off"
  664. inputAlign="left"
  665. v-model={forms.phone}
  666. maxlength={11}
  667. onUpdate:modelValue={(val: any) => {
  668. phoneChangeEmptyInfo();
  669. }}>
  670. </Field>
  671. <Field
  672. class={[styles.valDot, styles.codeItem]}
  673. center
  674. clearable={false}
  675. inputAlign="left"
  676. placeholder="请输入验证码"
  677. autocomplete="off"
  678. type="number"
  679. v-model={forms.smsCode}
  680. maxlength={6}>
  681. {{
  682. button: () =>
  683. forms.countDownStatus ? (
  684. <span
  685. class={[
  686. styles.codeText,
  687. !validatePhone.value ? styles.codeTextDisabled : ''
  688. ]}
  689. onClick={onSendCode}>
  690. 获取验证码
  691. </span>
  692. ) : (
  693. <CountDown
  694. ref={(el: any) => (countDownRef.value = el)}
  695. auto-start={false}
  696. class={styles.countDown}
  697. time={forms.countDownTime}
  698. onFinish={onFinished}
  699. format="ss秒后重试"
  700. />
  701. )
  702. }}
  703. </Field>
  704. </div>
  705. }
  706. {
  707. forms.participationFlag !== null &&
  708. <img class={styles.bottomBtn} src={forms.participationFlag ? signupBtn : submitBtn}
  709. onClick={() => {
  710. if (forms.submitLoading) return;
  711. submitFill()
  712. }}
  713. />
  714. }
  715. </div>
  716. {/* 是否在微信中打开 */}
  717. <OWxTip />
  718. {forms.imgCodeStatus ? (
  719. <MImgCode
  720. v-model:value={forms.imgCodeStatus}
  721. phone={forms.phone}
  722. type="MEETING_QUESTION"
  723. onClose={() => {
  724. forms.imgCodeStatus = false;
  725. }}
  726. onSendCode={onCodeSend}
  727. />
  728. ) : null}
  729. {
  730. forms.successPopShow &&
  731. <div class={styles.successPop}>
  732. <div class={styles.successBox}>
  733. <img class={styles.sTitle} src={forms.participationFlag ? signSusIcon : subSusIcon} />
  734. <p>{forms.participationFlag ? '感谢您的参与' : '感谢您的宝贵意见'}</p>
  735. <img class={styles.sDone} src={doneIcon} onClick={() => {
  736. forms.successPopShow = false
  737. }} />
  738. </div>
  739. </div>
  740. }
  741. <Popup
  742. zIndex={2010}
  743. v-model:show={forms.showPicker}
  744. position="bottom"
  745. round
  746. class={'popupBottomSearch'}>
  747. <Area
  748. optionHeight={46}
  749. areaList={forms.areaList}
  750. v-model={forms.areaPopupIndex}
  751. onCancel={() => {
  752. forms.showPicker = false
  753. // if (!forms.areaName) {
  754. // forms.schoolStatus = false
  755. // }
  756. }}
  757. onConfirm={({ selectedOptions }) => {
  758. forms.provinceCode = selectedOptions[0].value;
  759. forms.cityCode = selectedOptions[1].value;
  760. forms.districtCode = selectedOptions[2]?.value || null;
  761. forms.areaPopupIndex = forms.districtCode || forms.cityCode || forms.provinceCode
  762. forms.areaPopupIndex = forms.areaPopupIndex ? String(forms.areaPopupIndex) : null
  763. forms.areaName = selectedOptions
  764. .map((item: any) => item?.text)
  765. .join(' ');
  766. forms.showPicker = false;
  767. // if (!forms.areaName) {
  768. // forms.schoolStatus = false
  769. // }
  770. forms.schoolAreaId = null;
  771. forms.schoolName = '';
  772. forms.gradeNumText = '';
  773. forms.currentGrade = null;
  774. forms.currentClass = null;
  775. forms.currentClassText = '';
  776. // console.log('地址1')
  777. getSchoolAreaList();
  778. forms.schoolStatus = true
  779. }}
  780. />
  781. </Popup>
  782. {/* 互通学校 */}
  783. <Popup
  784. zIndex={2001}
  785. v-model:show={forms.schoolStatus}
  786. position="bottom"
  787. round
  788. safeAreaInsetBottom
  789. lazyRender={false}
  790. class={'popupBottomSearch'}
  791. onOpen={() => {
  792. forms.schoolPopupShow = true;
  793. }}
  794. onClosed={() => {
  795. forms.schoolPopupShow = false;
  796. }}>
  797. {forms.schoolPopupShow && (
  798. <div>
  799. <Picker
  800. class="cityPopBox"
  801. showToolbar
  802. v-model={forms.schoolPopupIndex}
  803. columns={forms.schoolAreaList}
  804. loading={forms.schoolLoading}
  805. columnsFieldNames={{
  806. text: 'name',
  807. value: 'id'
  808. }}
  809. onCancel={() => (forms.schoolStatus = false)}
  810. onConfirm={(val: any) => {
  811. const selectedOption = val.selectedOptions[0];
  812. forms.schoolAreaId = selectedOption.id || null;
  813. forms.schoolPopupIndex = forms.schoolAreaId ? [forms.schoolAreaId] : [];
  814. forms.schoolName = selectedOption.name;
  815. forms.schoolStatus = false;
  816. forms.currentGrade = null;
  817. forms.currentClass = null;
  818. // console.log('学校id',forms.schoolAreaId,selectedOption)
  819. // getSchoolAreaDetail();
  820. }}>
  821. {{
  822. 'columns-top': (
  823. <div class={styles.columnsTop}>
  824. {/* <Cell border={false} clickable={false} title={forms.areaName || '请选择省市区'} isLink onClick={() => {
  825. forms.showPicker = true;
  826. }} /> */}
  827. <MSearch
  828. placeholder="请输入学校名称"
  829. onSearch={(val: any) => {
  830. getSchoolAreaList(val);
  831. }}
  832. onSearchUpdate={(val: any) => {
  833. getSchoolAreaList(val);
  834. }}
  835. />
  836. </div>
  837. ),
  838. option: (item: any, index: number) => (
  839. <div class={styles.columnsContent} v-html={highlightText(item.name)} key={index}></div>
  840. ),
  841. }}
  842. </Picker>
  843. </div>
  844. )}
  845. </Popup>
  846. {/* 年级 */}
  847. <Popup
  848. v-model:show={forms.gradeStatus}
  849. position="bottom"
  850. round
  851. safeAreaInsetBottom
  852. lazyRender={false}
  853. class={'popupBottomSearch'}
  854. onOpen={() => {
  855. forms.gradePopupShow = true;
  856. }}
  857. onClosed={() => {
  858. forms.gradePopupShow = false;
  859. }}>
  860. {forms.gradePopupShow && (
  861. <Picker
  862. showToolbar
  863. v-model={forms.gradeOptionIndex}
  864. columns={forms.gradeOptions}
  865. onCancel={() => (forms.gradeStatus = false)}
  866. onConfirm={(val: any) => {
  867. console.log('选择1111',val)
  868. // forms.gradeAndClassIndex = [val.selectedOptions[0].value, val.selectedOptions[1].value]
  869. // forms.currentGrade = val.selectedOptions[0].text;
  870. // forms.currentClass = val.selectedOptions[1].text;
  871. forms.currentGrade = val.selectedOptions[0].text
  872. forms.gradeOptionIndex = [val.selectedOptions[0].value]
  873. forms.gradeStatus = false;
  874. }}
  875. />
  876. )}
  877. </Popup>
  878. {/* 班级 */}
  879. <Popup
  880. v-model:show={forms.classStatus}
  881. position="bottom"
  882. round
  883. safeAreaInsetBottom
  884. lazyRender={false}
  885. class={'popupBottomSearch'}
  886. onOpen={() => {
  887. forms.gradePopupShow = true;
  888. }}
  889. onClosed={() => {
  890. forms.gradePopupShow = false;
  891. }}>
  892. {forms.gradePopupShow && (
  893. <Picker
  894. showToolbar
  895. v-model={forms.classOptionIndex}
  896. columns={forms.classOptions}
  897. onCancel={() => (forms.classStatus = false)}
  898. onConfirm={(val: any) => {
  899. console.log('选择1111',val)
  900. forms.currentClass = val.selectedOptions[0].text
  901. forms.classOptionIndex = [val.selectedOptions[0].value]
  902. forms.classStatus = false;
  903. }}
  904. />
  905. )}
  906. </Popup>
  907. </div>
  908. );
  909. }
  910. });