raceOverview.vue 38 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328
  1. <template>
  2. <!-- 项目概况 -->
  3. <div class="pb_content">
  4. <div class="race_content_body">
  5. <div class="raceBox">
  6. <div class="stepBg">
  7. <!-- <div class="steps">
  8. <div>
  9. <img src="../../../../assets/icon/race/progress.png" alt="" />
  10. </div>
  11. <div class="stepRightNav">
  12. <div>项目简介</div>
  13. <div>说明</div>
  14. </div>
  15. </div> -->
  16. <div class="steps">
  17. <div>
  18. <img src="../../../../assets/icon/race/progress.png" alt="" />
  19. </div>
  20. <div class="stepRightNav" @click="jump('first')">
  21. <div>驱动问题</div>
  22. <div>说明</div>
  23. </div>
  24. </div>
  25. <div class="steps">
  26. <div>
  27. <img src="../../../../assets/icon/race/progress.png" alt="" />
  28. </div>
  29. <div class="stepRightNav" @click="jump('second')">
  30. <div>学习目标</div>
  31. <div>说明</div>
  32. </div>
  33. </div>
  34. <div class="steps">
  35. <div>
  36. <img src="../../../../assets/icon/race/progress.png" alt="" />
  37. </div>
  38. <div class="stepRightNav" @click="jump('third')">
  39. <div>评价设计</div>
  40. <div>说明</div>
  41. </div>
  42. </div>
  43. <!-- <div class="steps">
  44. <div>
  45. <img src="../../../../assets/icon/race/progress.png" alt="" />
  46. </div>
  47. <div class="stepRightNav">
  48. <div>平台案例实施(选填)</div>
  49. <div>协同人员</div>
  50. </div>
  51. </div>
  52. <div class="steps">
  53. <div>
  54. <img src="../../../../assets/icon/race/progress.png" alt="" />
  55. </div>
  56. <div class="stepRightNav">
  57. <div>案例评审</div>
  58. <div>评审状态、反馈</div>
  59. </div>
  60. </div> -->
  61. </div>
  62. <div class="right">
  63. <div class="whiteBg">
  64. <div class="firstTop">
  65. <div class="right_title" id="first">驱动问题</div>
  66. <!-- <div class="rightNav">
  67. 可包括阶段性问题和学科问题:阶段性问题是指在核心问题解决的不同阶段,通过提出驱动性问题,明确阶段子任务。学科问题是指从不同学科的角度以及分解和提出要研究解决的主要问题。
  68. </div> -->
  69. </div>
  70. <div class="basic_box1">
  71. <div class="editorCss">
  72. <editor-bar
  73. v-model="raceOver.driQuestion.brief"
  74. @change="upRaceOver"
  75. :placeholder="'可包括阶段性问题和学科问题:阶段性问题是指在核心问题解决的不同阶段,通过提出驱动性问题,明确阶段子任务。学科问题是指从不同学科的角度以及分解和提出要研究解决的主要问题。'"
  76. ></editor-bar>
  77. </div>
  78. <div>
  79. <div class="basic_box">
  80. <div class="lineBox">
  81. <div class="lineTitle">附件内容</div>
  82. <div class="strLine"></div>
  83. </div>
  84. <div>
  85. <div
  86. class="add_chapters_box"
  87. v-if="
  88. raceOver.driQuestion.data &&
  89. raceOver.driQuestion.data.length == 0
  90. "
  91. ></div>
  92. <div
  93. v-else
  94. class="add_chapters_box"
  95. style="display: flex; flex-direction: column"
  96. >
  97. <div
  98. class="chapter_upload"
  99. v-for="(item, index) in raceOver.driQuestion.data"
  100. :key="item.id"
  101. >
  102. <div class="chapter_upload_t"></div>
  103. <div class="chapter_upload_o">
  104. <div class="chapter_upload_l">
  105. <div
  106. v-if="item.type == 2"
  107. class="chapter_upload_l_i1"
  108. ></div>
  109. <div
  110. v-if="item.type == 1 || item.type == 3"
  111. class="chapter_upload_l_i5"
  112. ></div>
  113. </div>
  114. <div class="chapter_upload_ic">
  115. <div class="chapter_upload_ic_l"></div>
  116. <div
  117. class="chapter_upload_ic_r"
  118. @click.stop="deleteChapterData($event, index, 0)"
  119. >
  120. <div></div>
  121. </div>
  122. </div>
  123. <div class="chapter_upload_n">
  124. <input
  125. class="first"
  126. v-if="item.type == 1 || item.type == 3"
  127. :placeholder="item.name"
  128. />
  129. <input
  130. class="first"
  131. v-if="item.type == 2"
  132. :placeholder="item.name"
  133. />
  134. <div class="chapter_upload_ud">
  135. <div class="chapter_upload_up"></div>
  136. <div class="chapter_upload_down"></div>
  137. </div>
  138. </div>
  139. </div>
  140. </div>
  141. </div>
  142. </div>
  143. <div class="add_info_box">
  144. <button class="info_btn" @click="addImg($event)">
  145. 上传附件
  146. <input
  147. type="file"
  148. accept="application/pdf, application/.ppt, .ppt, .pptx, .xlsx, .xls, application/msword, application/vnd.openxmlformats-officedocument.wordprocessingml.document,video/mp4, video/quicktime, video/x-msvideo,image/*"
  149. style="display: none"
  150. @change="beforeUpload($event, null, 0)"
  151. />
  152. </button>
  153. </div>
  154. <div v-if="raceOver.driQuestion.data.proVisible" class="mask">
  155. <div class="progressBox">
  156. <div class="lbox">
  157. <img
  158. src="../../../../assets/loading.gif"
  159. />上传中,请稍后
  160. </div>
  161. <el-progress
  162. :text-inside="true"
  163. :stroke-width="20"
  164. :percentage="
  165. raceOver.driQuestion.data.progress
  166. ? raceOver.driQuestion.data.progress
  167. : 0
  168. "
  169. style="width: 80%"
  170. ></el-progress>
  171. </div>
  172. </div>
  173. </div>
  174. </div>
  175. </div>
  176. </div>
  177. <div class="whiteBg">
  178. <div class="firstTop">
  179. <div class="right_title" id="second">学习目标</div>
  180. <!-- <div class="rightNav">
  181. 学习目标提倡用核心素养来分类概括再描述,具体表述时应行为化、具体化、操作化,可以用“通过什么,达到什么,培养什么”的句式来进行表述
  182. </div> -->
  183. </div>
  184. <div class="basic_box1">
  185. <div class="editorCss">
  186. <editor-bar
  187. v-model="raceOver.tarDesign.brief"
  188. @change="upRaceOver"
  189. :placeholder="'学习目标提倡用核心素养来分类概括再描述,具体表述时应行为化、具体化、操作化,可以用“通过什么,达到什么,培养什么”的句式来进行表述'"
  190. ></editor-bar>
  191. </div>
  192. <div>
  193. <div class="basic_box">
  194. <div class="lineBox">
  195. <div class="lineTitle">附件内容</div>
  196. <div class="strLine"></div>
  197. </div>
  198. <div>
  199. <div
  200. class="add_chapters_box"
  201. v-if="
  202. raceOver.tarDesign.data &&
  203. raceOver.tarDesign.data.length == 0
  204. "
  205. ></div>
  206. <div
  207. v-else
  208. class="add_chapters_box"
  209. style="display: flex; flex-direction: column"
  210. >
  211. <div
  212. class="chapter_upload"
  213. v-for="(item1, index1) in raceOver.tarDesign.data"
  214. :key="item1.id"
  215. >
  216. <div class="chapter_upload_t"></div>
  217. <div class="chapter_upload_o">
  218. <div class="chapter_upload_l">
  219. <div
  220. v-if="item1.type == 2"
  221. class="chapter_upload_l_i1"
  222. ></div>
  223. <div
  224. v-if="item1.type == 1 || item1.type == 3"
  225. class="chapter_upload_l_i5"
  226. ></div>
  227. </div>
  228. <div class="chapter_upload_ic">
  229. <div class="chapter_upload_ic_l"></div>
  230. <div
  231. class="chapter_upload_ic_r"
  232. @click.stop="deleteChapterData($event, index1, 1)"
  233. >
  234. <div></div>
  235. </div>
  236. </div>
  237. <div class="chapter_upload_n">
  238. <input
  239. class="first"
  240. v-if="item1.type == 1 || item1.type == 3"
  241. :placeholder="item1.name"
  242. />
  243. <input
  244. class="first"
  245. v-if="item1.type == 2"
  246. :placeholder="item1.name"
  247. />
  248. <div class="chapter_upload_ud">
  249. <div class="chapter_upload_up"></div>
  250. <div class="chapter_upload_down"></div>
  251. </div>
  252. </div>
  253. </div>
  254. </div>
  255. </div>
  256. </div>
  257. <div class="add_info_box">
  258. <button class="info_btn" @click="addImg($event)">
  259. 上传附件
  260. <input
  261. type="file"
  262. accept="application/pdf, application/.ppt, .ppt, .pptx, .xlsx, .xls, application/msword, application/vnd.openxmlformats-officedocument.wordprocessingml.document,video/mp4, video/quicktime, video/x-msvideo,image/*"
  263. style="display: none"
  264. @change="beforeUpload($event, null, 1)"
  265. />
  266. </button>
  267. </div>
  268. <div v-if="raceOver.tarDesign.data.proVisible" class="mask">
  269. <div class="progressBox">
  270. <div class="lbox">
  271. <img
  272. src="../../../../assets/loading.gif"
  273. />上传中,请稍后
  274. </div>
  275. <el-progress
  276. :text-inside="true"
  277. :stroke-width="20"
  278. :percentage="
  279. raceOver.tarDesign.data.progress
  280. ? raceOver.tarDesign.data.progress
  281. : 0
  282. "
  283. style="width: 80%"
  284. ></el-progress>
  285. </div>
  286. </div>
  287. </div>
  288. </div>
  289. </div>
  290. </div>
  291. <div class="whiteBg">
  292. <div class="firstTop">
  293. <div class="right_title" id="third">评价设计</div>
  294. <!-- <div class="rightNav">
  295. 项目学习评价方式需要体现过程性评价与总结性评价相结合,积极使用表现性评价。本次征集案例中,需要将学生的作品和报告作为附件呈现作品评价。
  296. </div> -->
  297. </div>
  298. <div class="basic_box1">
  299. <div class="editorCss">
  300. <editor-bar
  301. v-model="raceOver.actiDesign.brief"
  302. @change="upRaceOver"
  303. :placeholder="'项目学习评价方式需要体现过程性评价与总结性评价相结合,积极使用表现性评价。本次征集案例中,需要将学生的作品和报告作为附件呈现作品评价。'"
  304. ></editor-bar>
  305. </div>
  306. <div>
  307. <div class="basic_box">
  308. <div class="lineBox">
  309. <div class="lineTitle">附件内容</div>
  310. <div class="strLine"></div>
  311. </div>
  312. <div>
  313. <div
  314. class="add_chapters_box"
  315. v-if="
  316. raceOver.actiDesign.data &&
  317. raceOver.actiDesign.data.length == 0
  318. "
  319. ></div>
  320. <div
  321. v-else
  322. class="add_chapters_box"
  323. style="display: flex; flex-direction: column"
  324. >
  325. <div
  326. class="chapter_upload"
  327. v-for="(item2, index2) in raceOver.actiDesign.data"
  328. :key="item2.id"
  329. >
  330. <div class="chapter_upload_t"></div>
  331. <div class="chapter_upload_o">
  332. <div class="chapter_upload_l">
  333. <div
  334. v-if="item2.type == 2"
  335. class="chapter_upload_l_i1"
  336. ></div>
  337. <div
  338. v-if="item2.type == 1 || item2.type == 3"
  339. class="chapter_upload_l_i5"
  340. ></div>
  341. </div>
  342. <div class="chapter_upload_ic">
  343. <div class="chapter_upload_ic_l"></div>
  344. <div
  345. class="chapter_upload_ic_r"
  346. @click.stop="deleteChapterData($event, index2, 2)"
  347. >
  348. <div></div>
  349. </div>
  350. </div>
  351. <div class="chapter_upload_n">
  352. <input
  353. class="first"
  354. v-if="item2.type == 1 || item2.type == 3"
  355. :placeholder="item2.name"
  356. />
  357. <input
  358. class="first"
  359. v-if="item2.type == 2"
  360. :placeholder="item2.name"
  361. />
  362. <div class="chapter_upload_ud">
  363. <div class="chapter_upload_up"></div>
  364. <div class="chapter_upload_down"></div>
  365. </div>
  366. </div>
  367. </div>
  368. </div>
  369. </div>
  370. </div>
  371. <div class="add_info_box">
  372. <button class="info_btn" @click="addImg($event)">
  373. 上传附件
  374. <input
  375. type="file"
  376. accept="application/pdf, application/.ppt, .ppt, .pptx, .xlsx, .xls, application/msword, application/vnd.openxmlformats-officedocument.wordprocessingml.document,video/mp4, video/quicktime, video/x-msvideo,image/*"
  377. style="display: none"
  378. @change="beforeUpload($event, null, 2)"
  379. />
  380. </button>
  381. </div>
  382. <div v-if="raceOver.actiDesign.data.proVisible" class="mask">
  383. <div class="progressBox">
  384. <div class="lbox">
  385. <img
  386. src="../../../../assets/loading.gif"
  387. />上传中,请稍后
  388. </div>
  389. <el-progress
  390. :text-inside="true"
  391. :stroke-width="20"
  392. :percentage="
  393. raceOver.actiDesign.data.progress
  394. ? raceOver.actiDesign.data.progress
  395. : 0
  396. "
  397. style="width: 80%"
  398. ></el-progress>
  399. </div>
  400. </div>
  401. </div>
  402. </div>
  403. </div>
  404. </div>
  405. </div>
  406. </div>
  407. </div>
  408. <el-dialog
  409. title="添加富文本"
  410. :visible.sync="dialogVisible"
  411. :append-to-body="true"
  412. width="500px"
  413. :before-close="handleClose"
  414. class="dialog_diy"
  415. >
  416. <el-form>
  417. <el-form-item label="文本标题">
  418. <el-input
  419. v-model="AttText.title"
  420. auto-complete="off"
  421. @input="change1"
  422. placeholder="请输入文本标题..."
  423. ></el-input>
  424. </el-form-item>
  425. <div>富文本内容</div>
  426. <editor-bar v-model="AttText.text" @change="change"></editor-bar>
  427. </el-form>
  428. <span slot="footer" class="dialog-footer">
  429. <el-button @click="clearAttText">取 消</el-button>
  430. <el-button type="primary" @click="isAddOrUpdateAttText">确定</el-button>
  431. </span>
  432. </el-dialog>
  433. <el-dialog
  434. title="添加链接"
  435. :visible.sync="dialogVisible1"
  436. :append-to-body="true"
  437. width="500px"
  438. :before-close="handleClose"
  439. class="dialog_diy lineCss"
  440. >
  441. <el-form>
  442. <el-form-item label="链接" :label-width="formLabelWidth">
  443. <span>
  444. <el-input
  445. placeholder="请输入链接"
  446. clearable
  447. v-model="line"
  448. class="add_input"
  449. ></el-input>
  450. </span>
  451. </el-form-item>
  452. </el-form>
  453. <span slot="footer" class="dialog-footer">
  454. <el-button @click="clearLine">取 消</el-button>
  455. <el-button type="primary" @click="isAddOrUpdateLine">确定</el-button>
  456. </span>
  457. </el-dialog>
  458. </div>
  459. </template>
  460. <script>
  461. import EditorBar from "../../../tools/wangEnduit";
  462. export default {
  463. components: { EditorBar },
  464. props: ["raceOverView"],
  465. data() {
  466. return {
  467. chapterData: [],
  468. formLabelWidth: "100px",
  469. noneBtnImg: false,
  470. raceOver: {
  471. driQuestion: { brief: "", data: [] },
  472. tarDesign: { brief: "", data: [] },
  473. actiDesign: { brief: "", data: [] },
  474. },
  475. AttText: {},
  476. task: 0,
  477. AttTextType: 0,
  478. AttTextIndex: 0,
  479. dialogVisible: false,
  480. dialogVisible1: false,
  481. line: "",
  482. lineCount: 0,
  483. };
  484. },
  485. methods: {
  486. handleClose(done) {
  487. done();
  488. },
  489. change(val) {
  490. console.log(val);
  491. },
  492. jump(t) {
  493. var a = document.getElementById(t);
  494. var b = document.getElementsByClassName("right")[0];
  495. b.scrollTop = a.offsetTop - 30;
  496. },
  497. change1(val) {
  498. console.log(val);
  499. this.$forceUpdate();
  500. },
  501. addImg(e) {
  502. var el = e.currentTarget;
  503. el.getElementsByTagName("input")[0].click();
  504. },
  505. imgChange(file, fileList, type, jT) {
  506. if (jT == 0) {
  507. var _tmp = this.raceOver.driQuestion.data;
  508. } else if (jT == 1) {
  509. var _tmp = this.raceOver.tarDesign.data;
  510. } else {
  511. var _tmp = this.raceOver.actiDesign.data;
  512. }
  513. this.noneBtnImg = _tmp.length >= 1;
  514. },
  515. deleteChapterData(e, i, t) {
  516. e.stopPropagation();
  517. if (t == 0) {
  518. this.raceOver.driQuestion.data.splice(i, 1);
  519. } else if (t == 1) {
  520. this.raceOver.tarDesign.data.splice(i, 1);
  521. } else {
  522. this.raceOver.actiDesign.data.splice(i, 1);
  523. }
  524. },
  525. beforeUpload(event, type, jsonType) {
  526. var file = event.target.files[0];
  527. var credentials = {
  528. accessKeyId: "AKIATLPEDU37QV5CHLMH",
  529. secretAccessKey: "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",
  530. }; //秘钥形式的登录上传
  531. window.AWS.config.update(credentials);
  532. window.AWS.config.region = "cn-northwest-1"; //设置区域
  533. var type1 = type;
  534. var bucket = new window.AWS.S3({ params: { Bucket: "ccrb" } }); //选择桶
  535. var _this = this;
  536. var b = [
  537. "DOC",
  538. "DOCX",
  539. "DOCM",
  540. "DOTM",
  541. "DOTX",
  542. "PPTX",
  543. "PPSX",
  544. "PPT",
  545. "PPS",
  546. "PPTM",
  547. "POTM",
  548. "PPAM",
  549. "POTX",
  550. "PPSM",
  551. ];
  552. var c = ["PDF", "DOT", "DOC", "DOCX", "PPT", "PPTX", "XLSX", "XLS"];
  553. var d = [
  554. "BMP",
  555. "PJP",
  556. "APNG",
  557. "PNG",
  558. "JPG",
  559. "GIF",
  560. "SVG",
  561. "JPEG",
  562. "JPG",
  563. "ICO",
  564. "PGPEG",
  565. "AVIF",
  566. ];
  567. if (
  568. b.indexOf(
  569. file.name
  570. .split(".")
  571. [file.name.split(".").length - 1].toLocaleUpperCase()
  572. ) != -1
  573. ) {
  574. if (file.size / 1024 / 1024 > 10) {
  575. this.$message.error("上传文件大于10M,请重新选择文件!");
  576. return;
  577. }
  578. } else if (
  579. c.indexOf(
  580. file.name
  581. .split(".")
  582. [file.name.split(".").length - 1].toLocaleUpperCase()
  583. ) != -1
  584. ) {
  585. if (file.size / 1024 / 1024 > 5) {
  586. this.$message.error("添加的上传文件大于5M,请重新选择文件!");
  587. return;
  588. }
  589. }
  590. if (
  591. c.indexOf(
  592. file.name
  593. .split(".")
  594. [file.name.split(".").length - 1].toLocaleUpperCase()
  595. ) != -1
  596. ) {
  597. type1 = 1;
  598. } else if (
  599. d.indexOf(
  600. file.name
  601. .split(".")
  602. [file.name.split(".").length - 1].toLocaleUpperCase()
  603. ) != -1
  604. ) {
  605. type1 = 3;
  606. } else {
  607. type1 = 2;
  608. }
  609. if (jsonType == 0) {
  610. _this.raceOver.driQuestion.data.progress = 0;
  611. _this.raceOver.driQuestion.data.proVisible = true;
  612. } else if (jsonType == 1) {
  613. _this.raceOver.tarDesign.data.progress = 0;
  614. _this.raceOver.tarDesign.data.proVisible = true;
  615. } else {
  616. _this.raceOver.actiDesign.data.progress = 0;
  617. _this.raceOver.actiDesign.data.proVisible = true;
  618. }
  619. _this.$forceUpdate();
  620. if (file) {
  621. var params = {
  622. Key:
  623. file.name.split(".")[0] +
  624. new Date().getTime() +
  625. "." +
  626. file.name.split(".")[file.name.split(".").length - 1],
  627. ContentType: file.type,
  628. Body: file,
  629. "Access-Control-Allow-Credentials": "*",
  630. ACL: "public-read",
  631. }; //key可以设置为桶的相抵路径,Body为文件, ACL最好要设置
  632. var options = {
  633. partSize: 2048 * 1024 * 1024,
  634. queueSize: 2,
  635. leavePartsOnError: true,
  636. };
  637. bucket
  638. .upload(params, options)
  639. .on("httpUploadProgress", function (evt) {
  640. //这里可以写进度条
  641. // console.log("Uploaded : " + parseInt((evt.loaded * 80) / evt.total) + '%');
  642. if (jsonType == 0) {
  643. _this.raceOver.driQuestion.data.progress = parseInt(
  644. (evt.loaded * 80) / evt.total
  645. );
  646. } else if (jsonType == 1) {
  647. _this.raceOver.tarDesign.data.progress = parseInt(
  648. (evt.loaded * 80) / evt.total
  649. );
  650. } else {
  651. _this.raceOver.actiDesign.data.progress = parseInt(
  652. (evt.loaded * 80) / evt.total
  653. );
  654. }
  655. })
  656. .send(function (err, data) {
  657. if (jsonType == 0) {
  658. _this.raceOver.driQuestion.data.progress = 100;
  659. } else if (jsonType == 1) {
  660. _this.raceOver.tarDesign.data.progress = 100;
  661. } else {
  662. _this.raceOver.actiDesign.data.progress = 100;
  663. }
  664. setTimeout(() => {
  665. if (jsonType == 0) {
  666. _this.raceOver.driQuestion.data.proVisible = false;
  667. } else if (jsonType == 1) {
  668. _this.raceOver.tarDesign.data.proVisible = false;
  669. } else {
  670. _this.raceOver.actiDesign.data.proVisible = false;
  671. }
  672. _this.$forceUpdate();
  673. }, 1000);
  674. if (err) {
  675. _this.$message.error("上传失败");
  676. } else {
  677. if (jsonType == 0) {
  678. _this.raceOver.driQuestion.data.push({
  679. name: file.name,
  680. url: data.Location,
  681. type: type1,
  682. });
  683. _this.imgChange(null, null, type1, jsonType);
  684. } else if (jsonType == 1) {
  685. _this.raceOver.tarDesign.data.push({
  686. name: file.name,
  687. url: data.Location,
  688. type: type1,
  689. });
  690. _this.imgChange(null, null, type1, jsonType);
  691. } else {
  692. _this.raceOver.actiDesign.data.push({
  693. name: file.name,
  694. url: data.Location,
  695. type: type1,
  696. });
  697. _this.imgChange(null, null, type1, jsonType);
  698. }
  699. console.log(data.Location);
  700. }
  701. });
  702. }
  703. },
  704. upRaceOver() {
  705. this.$emit("upRaceOver", this.raceOver);
  706. },
  707. addAttText(i) {
  708. this.AttText = {
  709. title: "",
  710. text: "",
  711. };
  712. this.task = i;
  713. this.AttTextType = 0;
  714. this.$forceUpdate();
  715. this.dialogVisible = true;
  716. },
  717. clearAttText() {
  718. this.AttText = {
  719. title: "",
  720. text: "",
  721. };
  722. this.dialogVisible = false;
  723. },
  724. isAddOrUpdateAttText() {
  725. if (this.AttTextType == 0) {
  726. this.addAttTextMessage();
  727. } else {
  728. this.updateAttText();
  729. }
  730. },
  731. addAttTextMessage() {
  732. if (this.task == 0) {
  733. this.raceOver.driQuestion.data.push({
  734. name: this.AttText.title,
  735. url: this.AttText.text,
  736. type: 3,
  737. });
  738. this.imgChange(null, null, 3, this.task);
  739. } else if (this.task == 1) {
  740. this.raceOver.tarDesign.data.push({
  741. name: this.AttText.title,
  742. url: this.AttText.text,
  743. type: 3,
  744. });
  745. this.imgChange(null, null, 3, this.task);
  746. } else {
  747. this.raceOver.actiDesign.data.push({
  748. name: this.AttText.title,
  749. url: this.AttText.text,
  750. type: 3,
  751. });
  752. this.imgChange(null, null, 3, this.task);
  753. }
  754. this.dialogVisible = false;
  755. this.upRaceOver();
  756. },
  757. updateAttText() {
  758. if (this.task == 0) {
  759. this.raceOver.driQuestion.data[this.AttTextIndex].name =
  760. this.AttText.title;
  761. this.raceOver.driQuestion.data[this.AttTextIndex].url =
  762. this.AttText.text;
  763. } else if (this.task == 1) {
  764. this.raceOver.tarDesign.data[this.AttTextIndex].name =
  765. this.AttText.title;
  766. this.raceOver.tarDesign.data[this.AttTextIndex].url = this.AttText.text;
  767. } else {
  768. this.raceOver.actiDesign.data[this.AttTextIndex].name =
  769. this.AttText.title;
  770. this.raceOver.actiDesign.data[this.AttTextIndex].url =
  771. this.AttText.text;
  772. }
  773. this.dialogVisible = false;
  774. this.upRaceOver();
  775. },
  776. selectAttText(t, i) {
  777. if (t == 0) {
  778. this.AttText.title = this.raceOver.driQuestion.data[i].name;
  779. this.AttText.text = this.raceOver.driQuestion.data[i].url;
  780. } else if (t == 1) {
  781. this.AttText.title = this.raceOver.tarDesign.data[i].name;
  782. this.AttText.text = this.raceOver.tarDesign.data[i].url;
  783. } else {
  784. this.AttText.title = this.raceOver.actiDesign.data[i].name;
  785. this.AttText.text = this.raceOver.actiDesign.data[i].url;
  786. }
  787. this.task = t;
  788. this.AttTextIndex = i;
  789. this.AttTextType = 1;
  790. this.dialogVisible = true;
  791. },
  792. openLine(i) {
  793. this.line = "";
  794. this.task = i;
  795. this.lineCount = i;
  796. this.lineType = 0;
  797. this.$forceUpdate();
  798. this.dialogVisible1 = true;
  799. },
  800. clearLine() {
  801. this.line = "";
  802. this.dialogVisible1 = false;
  803. },
  804. isAddOrUpdateLine() {
  805. if (this.lineType == 0) {
  806. this.addLine();
  807. } else {
  808. this.updateLine();
  809. }
  810. },
  811. addLine() {
  812. if (this.task == 0) {
  813. this.raceOver.driQuestion.data.push({
  814. name: "链接",
  815. url: this.line,
  816. type: 4,
  817. });
  818. this.imgChange(null, null, 4, this.task);
  819. } else if (this.task == 1) {
  820. this.raceOver.tarDesign.data.push({
  821. name: "链接",
  822. url: this.line,
  823. type: 4,
  824. });
  825. this.imgChange(null, null, 4, this.task);
  826. } else {
  827. this.raceOver.actiDesign.data.push({
  828. name: "链接",
  829. url: this.line,
  830. type: 4,
  831. });
  832. this.imgChange(null, null, 4, this.task);
  833. }
  834. this.dialogVisible1 = false;
  835. this.upRaceOver();
  836. },
  837. updateLine() {
  838. if (this.task == 0) {
  839. this.raceOver.driQuestion.data[this.lineCount].url = this.line;
  840. } else if (this.task == 1) {
  841. this.raceOver.tarDesign.data[this.lineCount].url = this.line;
  842. } else {
  843. this.raceOver.actiDesign.data[this.lineCount].url = this.line;
  844. }
  845. this.dialogVisible1 = false;
  846. this.upRaceOver();
  847. },
  848. selectLine(t, i) {
  849. if (t == 0) {
  850. this.line = this.raceOver.driQuestion.data[i].url;
  851. } else if (t == 1) {
  852. this.line = this.raceOver.tarDesign.data[i].url;
  853. } else {
  854. this.line = this.raceOver.actiDesign.data[i].url;
  855. }
  856. this.task = t;
  857. this.lineCount = i;
  858. this.lineType = 1;
  859. this.dialogVisible1 = true;
  860. },
  861. },
  862. created() {
  863. this.raceOver.driQuestion = this.raceOverView.driQuestion;
  864. this.raceOver.tarDesign = this.raceOverView.tarDesign;
  865. this.raceOver.actiDesign = this.raceOverView.actiDesign;
  866. },
  867. };
  868. </script>
  869. <style scoped>
  870. @media screen and (max-width: 1280px) {
  871. }
  872. .dialog_diy >>> .el-dialog__header {
  873. background: #3c3c3c !important;
  874. padding: 15px 20px;
  875. }
  876. .dialog_diy >>> .el-dialog__title {
  877. color: #fff;
  878. }
  879. .pb_content {
  880. width: 100%;
  881. height: 100%;
  882. }
  883. .race_content_body {
  884. width: 100%;
  885. position: relative;
  886. margin: 0;
  887. height: 100%;
  888. }
  889. .raceBox {
  890. width: 100%;
  891. height: 100%;
  892. display: flex;
  893. flex-direction: row;
  894. flex-wrap: nowrap;
  895. align-items: flex-start;
  896. }
  897. .stepBg {
  898. padding: 80px 0 0 0;
  899. margin: 0 25px 0 0;
  900. width: 20%;
  901. display: flex;
  902. justify-content: flex-start;
  903. align-items: center;
  904. flex-wrap: nowrap;
  905. background: #fff;
  906. /* min-height: 800px; */
  907. height: calc(100% - 80px);
  908. border-radius: 15px;
  909. overflow: auto;
  910. min-width: 260px;
  911. flex-direction: column;
  912. font-size: 14px;
  913. }
  914. .steps {
  915. display: flex;
  916. flex-direction: row;
  917. flex-wrap: nowrap;
  918. position: relative;
  919. width: 210px;
  920. height: 130px;
  921. }
  922. .steps > div:nth-child(1) > img {
  923. z-index: 9;
  924. position: relative;
  925. }
  926. .stepLeft,
  927. .isSteps {
  928. width: 30px;
  929. height: 30px;
  930. border-radius: 50%;
  931. text-align: center;
  932. line-height: 30px;
  933. border: 2px solid #eee;
  934. color: #c0c0c0;
  935. }
  936. .isSteps {
  937. background: #1990ff;
  938. color: #fff;
  939. border: none;
  940. }
  941. .stepRightNav {
  942. display: flex;
  943. flex-direction: column;
  944. flex-wrap: nowrap;
  945. justify-content: space-between;
  946. align-items: flex-start;
  947. margin-left: 10px;
  948. height: 50px;
  949. cursor: pointer;
  950. }
  951. .stepRightNav:hover{
  952. color: #999;
  953. }
  954. .line,
  955. .isLine {
  956. position: absolute;
  957. width: 5px;
  958. height: 50px;
  959. border-left: 1px solid #dadada;
  960. top: 38px;
  961. left: 15px;
  962. }
  963. .isLine {
  964. border-left: 1px solid #1d92ff !important;
  965. }
  966. .right {
  967. width: calc(100% - 20%);
  968. background: rgb(255, 255, 255);
  969. border-radius: 10px;
  970. overflow: auto;
  971. height: 100%;
  972. border-radius: 15px;
  973. /* max-height: 800px; */
  974. }
  975. .allBox {
  976. padding: 25px;
  977. }
  978. .allBox > div:nth-child(1) {
  979. color: #0f40f5;
  980. font-size: 18px;
  981. font-weight: bold;
  982. }
  983. .raceTop > div:nth-child(2) {
  984. width: 80%;
  985. margin-top: 10px;
  986. }
  987. .titleTop {
  988. display: flex;
  989. flex-direction: row;
  990. flex-wrap: nowrap;
  991. align-items: center;
  992. width: 100%;
  993. }
  994. .titleTop > div:nth-child(2) {
  995. width: 82%;
  996. margin-left: 20px;
  997. }
  998. .editorCss {
  999. width: 90% !important;
  1000. }
  1001. .basic_box {
  1002. position: relative;
  1003. margin: 0;
  1004. min-height: 0;
  1005. width: 90%;
  1006. }
  1007. .basic_box1 {
  1008. margin: 10px auto;
  1009. position: relative;
  1010. padding: 0 20px 0 20px;
  1011. }
  1012. .add_info_box {
  1013. margin: 20px 0;
  1014. }
  1015. .add_info_box button {
  1016. margin: 0 10px 10px 0;
  1017. }
  1018. .add_chapters_box {
  1019. text-align: left;
  1020. background-color: rgb(232 234 237);
  1021. width: 100%;
  1022. padding: 0px 15px;
  1023. border-radius: 15px;
  1024. font-size: 16px;
  1025. box-sizing: border-box;
  1026. position: relative;
  1027. padding: 0 10px 5px 10px;
  1028. height: 140px;
  1029. overflow-y: auto;
  1030. overflow-x: hidden;
  1031. }
  1032. .chapter_upload {
  1033. height: 50px;
  1034. margin-top: 12px;
  1035. position: relative;
  1036. display: flex;
  1037. align-items: center;
  1038. width: 100%;
  1039. min-height: 50px;
  1040. }
  1041. .chapter_upload_t {
  1042. background-color: #fff;
  1043. position: absolute;
  1044. height: 100%;
  1045. top: 0px;
  1046. left: 0px;
  1047. border-radius: 40px;
  1048. box-sizing: border-box;
  1049. box-shadow: 0 0 3px 3px #dfdfdf;
  1050. width: 100%;
  1051. }
  1052. .chapter_upload_o {
  1053. width: 100%;
  1054. height: 100%;
  1055. position: relative;
  1056. z-index: 1;
  1057. display: flex;
  1058. align-items: center;
  1059. }
  1060. .chapter_upload_ic {
  1061. height: 30px;
  1062. float: right;
  1063. cursor: pointer;
  1064. position: absolute;
  1065. width: 45px;
  1066. right: 0;
  1067. top: 0;
  1068. }
  1069. .chapter_upload_ic_l {
  1070. width: 50px;
  1071. height: 50px;
  1072. float: left;
  1073. }
  1074. .chapter_upload_ic_l div {
  1075. width: 30px;
  1076. height: 35px;
  1077. background: url("../../../../assets/icon/icon.png");
  1078. }
  1079. .chapter_upload_ic_r {
  1080. width: 50px;
  1081. height: 50px;
  1082. float: left;
  1083. margin-left: 0px;
  1084. display: flex;
  1085. align-items: center;
  1086. position: absolute;
  1087. }
  1088. .chapter_upload_ic_r div {
  1089. width: 25px;
  1090. height: 25px;
  1091. background-image: url("../../../../assets/delete.png");
  1092. background-size: 100% 100%;
  1093. }
  1094. .chapter_upload_n {
  1095. display: flex;
  1096. text-indent: 10px;
  1097. text-decoration: none;
  1098. text-overflow: ellipsis;
  1099. white-space: nowrap;
  1100. overflow: hidden;
  1101. width: 55%;
  1102. margin-left: 10px;
  1103. cursor: pointer;
  1104. margin-top: 2px;
  1105. }
  1106. .chapter_upload_l_i1 {
  1107. background-image: url("../../../../assets/icon/video.png");
  1108. width: 28px;
  1109. height: 28px;
  1110. background-size: 100% 100%;
  1111. }
  1112. .chapter_upload_l_i5 {
  1113. background-image: url("../../../../assets/icon/word.png");
  1114. width: 24px;
  1115. height: 24px;
  1116. background-size: 100% 100%;
  1117. margin-left: 1px;
  1118. }
  1119. .chapter_upload_l_i8 {
  1120. background-image: url("../../../../assets/icon/line.png");
  1121. width: 24px;
  1122. height: 24px;
  1123. background-size: 100% 100%;
  1124. margin-left: 1px;
  1125. }
  1126. .chapter_upload_ud {
  1127. display: flex;
  1128. flex-direction: column;
  1129. margin-left: 5px;
  1130. justify-content: center;
  1131. z-index: 99;
  1132. }
  1133. .chapter_upload_up {
  1134. background-image: url("../../../../assets/icon/up.png");
  1135. width: 17px;
  1136. height: 15px;
  1137. background-size: 100% 100%;
  1138. cursor: pointer;
  1139. }
  1140. .chapter_upload_down {
  1141. background-image: url("../../../../assets/icon/down.png");
  1142. width: 17px;
  1143. height: 15px;
  1144. margin: 2px auto 0 auto;
  1145. background-size: 100% 100%;
  1146. cursor: pointer;
  1147. }
  1148. .chapter_upload_l {
  1149. padding: 1px 0 0 10px;
  1150. }
  1151. .first {
  1152. border: none;
  1153. outline: none;
  1154. width: 80%;
  1155. min-width: 215px;
  1156. z-index: 99;
  1157. font-size: 14px;
  1158. white-space: nowrap;
  1159. overflow: hidden;
  1160. text-overflow: ellipsis;
  1161. }
  1162. .info_btn {
  1163. color: #fff;
  1164. background-color: #0f7eff;
  1165. padding: 8px 24px;
  1166. font-size: 0.9375rem;
  1167. box-shadow: 0px 1px 3px 0px rgb(0 0 0 / 20%), 0px 2px 2px 0px rgb(0 0 0 / 14%),
  1168. 0px 3px 1px -2px rgb(0 0 0 / 12%);
  1169. min-width: 64px;
  1170. font-weight: 500;
  1171. border-radius: 4px;
  1172. box-sizing: border-box;
  1173. border: none;
  1174. cursor: pointer;
  1175. }
  1176. .info_btn:hover {
  1177. background-color: #4f7cd5 !important;
  1178. }
  1179. .right_title {
  1180. height: 30px;
  1181. font-size: 1.5em;
  1182. font-weight: bold;
  1183. color: #0f7eff;
  1184. width: 10%;
  1185. min-width: 100px;
  1186. }
  1187. .whiteBg {
  1188. background: #fff;
  1189. border-radius: 10px;
  1190. }
  1191. .lineBox {
  1192. display: flex;
  1193. margin: 0 0 20px 0;
  1194. flex-direction: row;
  1195. justify-content: flex-start;
  1196. align-items: center;
  1197. }
  1198. .lineTitle {
  1199. margin-top: 15px;
  1200. width: 110px;
  1201. }
  1202. .strLine {
  1203. width: 85%;
  1204. margin: 0 auto;
  1205. border-top: 1px solid #e5e5e5;
  1206. margin-top: 20px;
  1207. }
  1208. .stepBg .steps:nth-child(1) ::after,
  1209. .stepBg .steps:nth-child(2) ::after{
  1210. content: "";
  1211. height: 100%;
  1212. background: #eee;
  1213. width: 4px;
  1214. position: absolute;
  1215. left: 15px;
  1216. top: calc(50% + (35px / 2));
  1217. transform: translateY(-50%);
  1218. z-index: 1;
  1219. }
  1220. .mask {
  1221. background-color: rgb(0 0 0 / 30%);
  1222. /* position: fixed; */
  1223. position: absolute;
  1224. top: 0;
  1225. left: 0;
  1226. width: 100%;
  1227. height: 100%;
  1228. z-index: 20000;
  1229. display: flex;
  1230. align-items: center;
  1231. justify-content: center;
  1232. }
  1233. .progressBox {
  1234. width: 300px;
  1235. height: 150px;
  1236. background: #fff;
  1237. border-radius: 10px;
  1238. box-shadow: 0 0 6px 1px #bfbfbf;
  1239. display: flex;
  1240. align-items: center;
  1241. justify-content: center;
  1242. flex-direction: column;
  1243. }
  1244. .progressBox .lbox {
  1245. height: 100px;
  1246. font-size: 16px;
  1247. display: flex;
  1248. align-items: center;
  1249. }
  1250. .progressBox .lbox img {
  1251. width: 40px;
  1252. margin-right: 20px;
  1253. }
  1254. .progressBox >>> .el-progress-bar__outer {
  1255. background-color: #d1dfff !important;
  1256. }
  1257. .progressBox .lbox {
  1258. height: 100px;
  1259. font-size: 19px;
  1260. display: flex;
  1261. align-items: center;
  1262. }
  1263. .progressBox .lbox img {
  1264. width: 40px;
  1265. margin-right: 20px;
  1266. }
  1267. .firstTop {
  1268. display: flex;
  1269. flex-direction: row;
  1270. flex-wrap: nowrap;
  1271. align-items: center;
  1272. width: 90%;
  1273. padding: 20px 0 20px 20px;
  1274. }
  1275. .rightNav {
  1276. width: 87%;
  1277. color: #a19f9f;
  1278. }
  1279. </style>