index.tsx 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  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. 'Alto Ocarina': 'https://oss.dayaedu.com/ktqy/17143623857205dba41a5.png',
  36. Whistling: 'https://oss.dayaedu.com/ktqy/1714362351692fcf8c0b8.png',
  37. 'Soprano Ocarina':
  38. 'https://oss.dayaedu.com/ktqy/1714362351692fcf8c0b8.png',
  39. Woodwind: 'https://oss.dayaedu.com/ktqy/17103860536966826c50d.png',
  40. Hulusi: 'https://oss.dayaedu.com/ktqy/17103860536966826c50d.png',
  41. 'Tenor Recorder':
  42. 'https://oss.dayaedu.com/ktqy/17103860536950592e357.png',
  43. 'German Recorder':
  44. 'https://oss.dayaedu.com/ktqy/17103860536950592e357.png',
  45. Nai: 'https://oss.dayaedu.com/ktqy/1710386053697af4aa985.png',
  46. Melodica: 'https://oss.dayaedu.com/ktqy/1710386053697af4aa985.png',
  47. 'Baroque Recorder':
  48. 'https://oss.dayaedu.com/ktqy/1710386053698031e847a.png'
  49. } as any;
  50. const onSubmit = () => {
  51. if (selectSubjectIds.value.length <= 0) {
  52. message.error('至少选择一个声部进行同步');
  53. return;
  54. }
  55. const subjectCode: any[] = [];
  56. selectSubjectIds.value.forEach((id: any) => {
  57. const item = subjectList.value.find(
  58. (subject: any) => subject.id === id
  59. );
  60. console.log(item, 'item', item.code);
  61. if (item) {
  62. const tempCode = item.code ? item.code.split(',')[0] : '';
  63. subjectCode.push({
  64. materialId: item.id,
  65. instrumentIds: item.id,
  66. coverImg: subjectImgs[tempCode] || subjectImgs.Panpipes,
  67. dataJson: null,
  68. title: item.name,
  69. isCollect: false,
  70. isSelected: false,
  71. content: item.code
  72. });
  73. }
  74. });
  75. emit('confirm', { subjectIds: selectSubjectIds.value, subjectCode });
  76. };
  77. const formatSubjectList = () => {
  78. const subjects = catchStore.getEnableSubjects;
  79. const temp: any = [];
  80. subjects.forEach((subject: any) => {
  81. if (tabId.value === '' && subject.instruments) {
  82. temp.push(...subject.instruments);
  83. } else if (
  84. tabId.value &&
  85. subject.instruments &&
  86. Number(tabId.value) === subject.id
  87. ) {
  88. temp.push(...subject.instruments);
  89. }
  90. });
  91. subjectList.value = temp;
  92. };
  93. onMounted(async () => {
  94. // 获取教材分类列表
  95. await catchStore.getSubjects();
  96. formatSubjectList();
  97. if (props.subjectId) {
  98. selectSubjectIds.value = [Number(props.subjectId)];
  99. }
  100. });
  101. return () => (
  102. <div class={styles.subjectSync}>
  103. {/* <div class={styles.tips}>
  104. 请选择当前课件可使用的乐器
  105. <span>(勾选后则对应乐器下的课件内容将被当前课件内容全部替换)</span>
  106. </div> */}
  107. <NTabs
  108. defaultValue=""
  109. paneClass={styles.paneTitle}
  110. justifyContent="start"
  111. paneWrapperClass={styles.paneWrapperContainer}
  112. value={tabId.value}
  113. onUpdate:value={(val: any) => {
  114. tabId.value = val;
  115. formatSubjectList();
  116. }}>
  117. {[{ name: '全部声部', id: '' }, ...catchStore.getEnableSubjects].map(
  118. (item: any) => (
  119. <NTabPane
  120. name={`${item.id}`}
  121. tab={item.name}
  122. displayDirective="if"></NTabPane>
  123. )
  124. )}
  125. </NTabs>
  126. <NScrollbar style={{ maxHeight: '50vh', minHeight: '50vh' }}>
  127. <div class={styles.subjectList}>
  128. {subjectList.value.map((subject: any) => (
  129. <div
  130. class={[
  131. styles.subjectItem,
  132. selectSubjectIds.value.includes(subject.id)
  133. ? styles.subjectSelect
  134. : ''
  135. ]}
  136. onClick={() => {
  137. if (selectSubjectIds.value.includes(subject.id)) {
  138. const index = selectSubjectIds.value.indexOf(subject.id);
  139. selectSubjectIds.value.splice(index, 1);
  140. } else {
  141. selectSubjectIds.value.push(subject.id);
  142. }
  143. }}>
  144. <div class={styles.imgSection}>
  145. <img src={subject.img} />
  146. {selectSubjectIds.value.includes(subject.id) && (
  147. <img src={iconSelect} class={styles.iconSelect} />
  148. )}
  149. </div>
  150. <p class={styles.subjectName}>{subject.name}</p>
  151. </div>
  152. ))}
  153. </div>
  154. </NScrollbar>
  155. <NSpace class={styles.btnGroupModal} justify="center">
  156. <NButton round onClick={() => emit('close')}>
  157. 取消
  158. </NButton>
  159. <NButton round type="primary" onClick={onSubmit}>
  160. 确定
  161. </NButton>
  162. </NSpace>
  163. </div>
  164. );
  165. }
  166. });