index.tsx 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. import { defineComponent, onMounted, ref } from 'vue';
  2. import styles from './index.module.less';
  3. import {
  4. NButton,
  5. NScrollbar,
  6. NSpace,
  7. NTabPane,
  8. NTabs,
  9. useMessage
  10. } from 'naive-ui';
  11. import { useCatchStore } from '/src/store/modules/catchData';
  12. import iconSelect from '../../images/icon-select.png';
  13. import { usePrepareStore } from '/src/store/modules/prepareLessons';
  14. import { PageEnum } from '/src/enums/pageEnum';
  15. export default defineComponent({
  16. name: 'subject-sync',
  17. props: {
  18. subjectId: {
  19. type: [String, Number],
  20. default: ''
  21. }
  22. },
  23. emits: ['close', 'confirm'],
  24. setup(props, { emit }) {
  25. const catchStore = useCatchStore();
  26. const prepareStore = usePrepareStore();
  27. const tabId = ref('' as any);
  28. const message = useMessage();
  29. const selectSubjectIds = ref([] as any);
  30. const subjectList = ref([] as any);
  31. const subjectImgs = {
  32. Panpipes: 'https://oss.dayaedu.com/ktqy/17103860536976fd4a751.png',
  33. // Ocarina: 'https://oss.dayaedu.com/ktqy/171038605369851874b22.png',
  34. Ocarina: 'https://oss.dayaedu.com/ktqy/17143623857205dba41a5.png',
  35. Whistling: 'https://oss.dayaedu.com/ktqy/1714362351692fcf8c0b8.png',
  36. Woodwind: 'https://oss.dayaedu.com/ktqy/17103860536966826c50d.png',
  37. 'Tenor Recorder':
  38. 'https://oss.dayaedu.com/ktqy/17103860536950592e357.png',
  39. Nai: 'https://oss.dayaedu.com/ktqy/1710386053697af4aa985.png',
  40. 'Baroque Recorder':
  41. 'https://oss.dayaedu.com/ktqy/1710386053698031e847a.png'
  42. } as any;
  43. /*
  44. https://oss.dayaedu.com/ktqy/17103860536950592e357.png
  45. https://oss.dayaedu.com/ktqy/17103860536966826c50d.png
  46. https://oss.dayaedu.com/ktqy/1710386053697af4aa985.png
  47. https://oss.dayaedu.com/ktqy/17103860536976fd4a751.png
  48. https://oss.dayaedu.com/ktqy/171038605369851874b22.png
  49. https://oss.dayaedu.com/ktqy/1710386053698031e847a.png
  50. */
  51. const onSubmit = () => {
  52. if (selectSubjectIds.value.length <= 0) {
  53. message.error('至少选择一个声部进行同步');
  54. return;
  55. }
  56. const subjectCode: any[] = [];
  57. // subjectList.value.forEach((subject: any) => {
  58. // if (selectSubjectIds.value.includes(subject.id)) {
  59. // subjectCode.push({
  60. // materialId: subject.id,
  61. // coverImg: subjectImgs[subject.code] || subjectImgs.Panpipes,
  62. // dataJson: null,
  63. // title: subject.name,
  64. // isCollect: false,
  65. // isSelected: false,
  66. // content: subject.code
  67. // });
  68. // }
  69. // });
  70. selectSubjectIds.value.forEach((id: any) => {
  71. const item = subjectList.value.find(
  72. (subject: any) => subject.id === id
  73. );
  74. console.log(item, 'item');
  75. if (item) {
  76. subjectCode.push({
  77. materialId: item.id,
  78. coverImg: subjectImgs[item.code] || subjectImgs.Panpipes,
  79. dataJson: null,
  80. title: item.name,
  81. isCollect: false,
  82. isSelected: false,
  83. content: item.code
  84. });
  85. }
  86. });
  87. emit('confirm', { subjectIds: selectSubjectIds.value, subjectCode });
  88. };
  89. const formatSubjectList = () => {
  90. const subjects = catchStore.getEnableSubjects;
  91. const temp: any = [];
  92. subjects.forEach((subject: any) => {
  93. if (tabId.value === '' && subject.instruments) {
  94. temp.push(...subject.instruments);
  95. } else if (
  96. tabId.value &&
  97. subject.instruments &&
  98. Number(tabId.value) === subject.id
  99. ) {
  100. temp.push(...subject.instruments);
  101. }
  102. });
  103. subjectList.value = temp;
  104. };
  105. onMounted(async () => {
  106. // 获取教材分类列表
  107. // await catchStore.getMusicInstrument();
  108. // subjectList.value = catchStore.getMusicInstruments;
  109. await catchStore.getSubjects();
  110. formatSubjectList();
  111. // const teachingSubjectList = prepareStore.getSubjectList; // 教材自带声部;
  112. // const tempSubjectList: any = [];
  113. // baseAllSubjectList.forEach((subject: any) => {
  114. // const index = teachingSubjectList.findIndex(
  115. // (t: any) => t.id == subject.id
  116. // );
  117. // if (index != -1) {
  118. // tempSubjectList.push(subject);
  119. // }
  120. // });
  121. // subjectList.value = tempSubjectList;
  122. if (props.subjectId) {
  123. selectSubjectIds.value = [Number(props.subjectId)];
  124. }
  125. });
  126. return () => (
  127. <div class={styles.subjectSync}>
  128. {/* <div class={styles.tips}>
  129. 请选择当前课件可使用的乐器
  130. <span>(勾选后则对应乐器下的课件内容将被当前课件内容全部替换)</span>
  131. </div> */}
  132. <NTabs
  133. defaultValue=""
  134. paneClass={styles.paneTitle}
  135. justifyContent="start"
  136. paneWrapperClass={styles.paneWrapperContainer}
  137. value={tabId.value}
  138. onUpdate:value={(val: any) => {
  139. tabId.value = val;
  140. formatSubjectList();
  141. }}>
  142. {[{ name: '全部声部', id: '' }, ...catchStore.getEnableSubjects].map(
  143. (item: any) => (
  144. <NTabPane
  145. name={`${item.id}`}
  146. tab={item.name}
  147. displayDirective="if"></NTabPane>
  148. )
  149. )}
  150. </NTabs>
  151. <NScrollbar style={{ maxHeight: '50vh', minHeight: '50vh' }}>
  152. <div class={styles.subjectList}>
  153. {subjectList.value.map((subject: any) => (
  154. <div
  155. class={[
  156. styles.subjectItem,
  157. selectSubjectIds.value.includes(subject.id)
  158. ? styles.subjectSelect
  159. : ''
  160. ]}
  161. onClick={() => {
  162. if (selectSubjectIds.value.includes(subject.id)) {
  163. const index = selectSubjectIds.value.indexOf(subject.id);
  164. selectSubjectIds.value.splice(index, 1);
  165. } else {
  166. selectSubjectIds.value.push(subject.id);
  167. }
  168. }}>
  169. <div class={styles.imgSection}>
  170. <img src={subject.img} />
  171. {selectSubjectIds.value.includes(subject.id) && (
  172. <img src={iconSelect} class={styles.iconSelect} />
  173. )}
  174. </div>
  175. <p class={styles.subjectName}>{subject.name}</p>
  176. </div>
  177. ))}
  178. </div>
  179. </NScrollbar>
  180. <NSpace class={styles.btnGroupModal} justify="center">
  181. <NButton round onClick={() => emit('close')}>
  182. 取消
  183. </NButton>
  184. <NButton round type="primary" onClick={onSubmit}>
  185. 确定
  186. </NButton>
  187. </NSpace>
  188. </div>
  189. );
  190. }
  191. });