evaluation.vue 44 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710
  1. <template>
  2. <div
  3. class="pb_content"
  4. style="
  5. background: unset;
  6. overflow: auto;
  7. padding: 20px;
  8. margin: 0;
  9. box-sizing: border-box;
  10. "
  11. >
  12. <div>
  13. <div
  14. class="pb_content_body"
  15. style="
  16. background: #fff;
  17. padding: 0px 25px;
  18. box-sizing: border-box;
  19. border-radius: 5px;
  20. "
  21. >
  22. <div class="pb_head top">
  23. <span>目标管理设置</span>
  24. <div class="student_button">
  25. <el-button type="primary" class="bgColor" @click="addED"
  26. >添加目标</el-button
  27. >
  28. </div>
  29. </div>
  30. <div class="student_head">
  31. <div class="student_search">
  32. <el-input placeholder="请输入名称" v-model="sn"></el-input>
  33. <el-button type="primary" class="btn" @click="search"
  34. >查询</el-button
  35. >
  36. </div>
  37. </div>
  38. </div>
  39. <div class="pb_content_body" style="height: 100%">
  40. <el-table
  41. ref="table"
  42. :data="dataArray"
  43. border
  44. :fit="true"
  45. v-loading="isLoading"
  46. style="width: 100%"
  47. :header-cell-style="{ background: '#f1f1f1', fontSize: '17px' }"
  48. :row-class-name="tableRowClassName"
  49. >
  50. <el-table-column
  51. label="目标名称"
  52. min-width="15"
  53. align="center"
  54. prop="title"
  55. >
  56. </el-table-column>
  57. <el-table-column
  58. prop="username"
  59. label="负责人"
  60. min-width="15"
  61. align="center"
  62. >
  63. </el-table-column>
  64. <el-table-column
  65. prop="time"
  66. label="创建时间"
  67. min-width="15"
  68. align="center"
  69. >
  70. </el-table-column>
  71. <el-table-column label="操作" width="250px">
  72. <template slot-scope="scope">
  73. <div class="btnBox">
  74. <el-button
  75. class="de_button"
  76. type="primary"
  77. size="small"
  78. @click="checkE(scope.row)"
  79. >查看</el-button
  80. >
  81. <el-button
  82. class="de_button"
  83. type="primary"
  84. size="small"
  85. @click="copyEva(scope.row.id)"
  86. >复制</el-button
  87. >
  88. <el-button
  89. v-if="$route.query.userid == scope.row.userid"
  90. class="de_button"
  91. type="primary"
  92. size="small"
  93. @click="deleteE(scope.row.id)"
  94. >删除</el-button
  95. >
  96. </div>
  97. </template>
  98. </el-table-column>
  99. </el-table>
  100. <div class="student_page">
  101. <el-pagination
  102. v-if="dataArray.length"
  103. background
  104. layout="prev, pager, next"
  105. :page-size="10"
  106. :total="total"
  107. style="padding-bottom: 20px"
  108. @current-change="handleCurrentChange"
  109. ></el-pagination>
  110. </div>
  111. </div>
  112. </div>
  113. <el-dialog
  114. title="添加目标"
  115. :visible.sync="dialogVisible"
  116. :append-to-body="true"
  117. width="100%"
  118. :before-close="handleClose1"
  119. class="dialog_diy mubiao_diy fullStyle"
  120. >
  121. <div style="width: 100%; height: calc(100% - 80px)">
  122. <div class="e_add_top">
  123. <div class="e_add_title">
  124. <span>目标管理名称</span>
  125. <el-input
  126. v-model="eTitle"
  127. placeholder="请输入名称"
  128. @change="setMindData"
  129. ></el-input>
  130. </div>
  131. <div>
  132. <el-button v-show="false" type="primary" @click="addTemplate">新增模板</el-button>
  133. <el-button type="primary" @click="openTemplate">资源</el-button>
  134. <el-button @click="addEJson" type="primary" v-if="!update"
  135. >保存</el-button
  136. >
  137. <el-button @click="updateEJson" type="primary" v-else
  138. >保存</el-button
  139. >
  140. <el-button @click="clearAll()" type="primary">不保存</el-button>
  141. </div>
  142. </div>
  143. <div class="e_add_content">
  144. <div class="e_add_list">
  145. <div class="e_add_list_title">
  146. <span>一级目标</span>
  147. <!-- <img src="../../assets/add.png" @click="addE(1)" alt /> -->
  148. </div>
  149. <div class="e_add_list_body">
  150. <div
  151. class="e_add_list_child"
  152. v-for="(item, index) in eJson"
  153. :key="index"
  154. >
  155. <div
  156. v-if="evaObject.isFInput != '0-' + index"
  157. style="width: 100%"
  158. >
  159. <span
  160. :class="{ active: item.id == fid }"
  161. v-if="item.name.length < 8"
  162. @click="checkF(item.id)"
  163. >{{ item.name }}</span
  164. >
  165. <el-tooltip
  166. v-else
  167. class="item"
  168. effect="dark"
  169. :content="item.name"
  170. placement="top-start"
  171. popper-class="text_tooltip2"
  172. >
  173. <span
  174. :class="{ active: item.id == fid }"
  175. @click="checkF(item.id)"
  176. >{{ item.name }}</span
  177. >
  178. </el-tooltip>
  179. <img
  180. style="right: 40px"
  181. src="../../assets/autorUp.png"
  182. @click="
  183. (evaObject.isFInput = '0-' + index),
  184. (evaObject.fName1 = item.name)
  185. "
  186. alt
  187. />
  188. <!-- @click="updateF(item.id, item.name, 1)" -->
  189. </div>
  190. <div v-else>
  191. <textarea
  192. rows="2"
  193. v-autoHeight="30"
  194. v-model="evaObject.fName1"
  195. class="binfo_textarea"
  196. @change="noInput(item.id, evaObject.fName1, 1)"
  197. ></textarea>
  198. </div>
  199. <img
  200. style="width: 24px"
  201. src="../../assets/delete.png"
  202. @click="deleteF(item.id)"
  203. alt
  204. />
  205. </div>
  206. <div class="e_add_input">
  207. <textarea
  208. rows="2"
  209. v-autoHeight="30"
  210. v-model="evaObject.fName"
  211. class="binfo_textarea"
  212. placeholder="请添加内容.."
  213. @focus="setDetail(1)"
  214. ></textarea>
  215. <img
  216. src="../../assets/icon/new/addInput.png"
  217. @click="addInputName(1)"
  218. alt
  219. />
  220. </div>
  221. </div>
  222. <div class="e_add_list_detail" v-if="isFold">
  223. <textarea
  224. placeholder="添加目标描述"
  225. v-model="isFoldDetail"
  226. ></textarea>
  227. </div>
  228. <div class="e_add_list_detail" v-if="fid && !isFold">
  229. <textarea
  230. placeholder="添加目标描述"
  231. v-model="eJson[fid].detail"
  232. ></textarea>
  233. </div>
  234. <!-- <div class="e_add_list_btn">添加二级标题</div> -->
  235. </div>
  236. <div class="e_add_list">
  237. <div class="e_add_list_title">
  238. <span>二级目标</span>
  239. <!-- <img
  240. src="../../assets/add.png"
  241. @click="addE(2)"
  242. v-if="fid != ''"
  243. alt
  244. /> -->
  245. </div>
  246. <div class="e_add_list_body">
  247. <div
  248. class="e_add_list_child"
  249. v-for="(item, index) in fid && eJson[fid].child"
  250. :key="index"
  251. >
  252. <div
  253. v-if="evaObject.isSInput != '1-' + index"
  254. style="width: 100%"
  255. >
  256. <span
  257. :class="{ active: item.id == sid }"
  258. v-if="item.name.length < 8"
  259. @click="checkS(item.id)"
  260. >{{ item.name }}</span
  261. >
  262. <el-tooltip
  263. v-else
  264. class="item"
  265. effect="dark"
  266. :content="item.name"
  267. placement="top-start"
  268. popper-class="text_tooltip2"
  269. >
  270. <span
  271. :class="{ active: item.id == sid }"
  272. @click="checkS(item.id)"
  273. >{{ item.name }}</span
  274. >
  275. </el-tooltip>
  276. <img
  277. style="right: 40px"
  278. src="../../assets/autorUp.png"
  279. @click="
  280. (evaObject.isSInput = '1-' + index),
  281. (evaObject.sName1 = item.name)
  282. "
  283. alt
  284. />
  285. </div>
  286. <div v-else>
  287. <textarea
  288. rows="2"
  289. v-autoHeight="30"
  290. v-model="evaObject.sName1"
  291. class="binfo_textarea"
  292. @change="noInput(item.id, evaObject.sName1, 2)"
  293. ></textarea>
  294. </div>
  295. <img
  296. style="width: 24px"
  297. src="../../assets/delete.png"
  298. @click="deleteS(item.id)"
  299. alt
  300. />
  301. </div>
  302. <div class="e_add_input" v-if="fid != ''">
  303. <textarea
  304. rows="2"
  305. v-autoHeight="30"
  306. v-model="evaObject.sName"
  307. class="binfo_textarea"
  308. placeholder="请添加内容.."
  309. @focus="setDetail(2)"
  310. ></textarea>
  311. <img
  312. src="../../assets/icon/new/addInput.png"
  313. @click="addInputName(2)"
  314. alt
  315. />
  316. </div>
  317. </div>
  318. <div class="e_add_list_detail" v-if="isSold">
  319. <textarea
  320. placeholder="添加目标描述"
  321. v-model="isSoldDetail"
  322. ></textarea>
  323. </div>
  324. <div class="e_add_list_detail" v-if="sid && !isSold">
  325. <textarea
  326. placeholder="添加目标描述"
  327. v-model="eJson[fid].child[sid].detail"
  328. ></textarea>
  329. </div>
  330. <!-- <div class="e_add_list_btn">添加二级标题</div> -->
  331. </div>
  332. <div class="e_add_list">
  333. <div class="e_add_list_title">
  334. <span>三级目标</span>
  335. <!-- <img
  336. src="../../assets/add.png"
  337. @click="addE(3)"
  338. v-if="sid != ''"
  339. alt
  340. /> -->
  341. </div>
  342. <div class="e_add_list_body">
  343. <div
  344. class="e_add_list_child"
  345. v-for="(item, index) in fid &&
  346. sid &&
  347. eJson[fid].child[sid].child"
  348. :key="index"
  349. >
  350. <div
  351. v-if="evaObject.isTInput != '2-' + index"
  352. style="width: 100%"
  353. >
  354. <span
  355. :class="{ active: item.id == tid }"
  356. v-if="item.name.length < 8"
  357. @click="checkT(item.id)"
  358. >{{ item.name }}</span
  359. >
  360. <el-tooltip
  361. v-else
  362. class="item"
  363. effect="dark"
  364. :content="item.name"
  365. placement="top-start"
  366. popper-class="text_tooltip2"
  367. >
  368. <span
  369. :class="{ active: item.id == tid }"
  370. @click="checkT(item.id)"
  371. >{{ item.name }}</span
  372. >
  373. </el-tooltip>
  374. <img
  375. style="right: 40px"
  376. src="../../assets/autorUp.png"
  377. @click="
  378. (evaObject.isTInput = '2-' + index),
  379. (evaObject.tName1 = item.name)
  380. "
  381. alt
  382. />
  383. </div>
  384. <div v-else>
  385. <textarea
  386. rows="2"
  387. v-autoHeight="30"
  388. v-model="evaObject.tName1"
  389. class="binfo_textarea"
  390. @change="noInput(item.id, evaObject.tName1, 3)"
  391. ></textarea>
  392. </div>
  393. <img
  394. style="width: 24px"
  395. src="../../assets/delete.png"
  396. @click="deleteT(item.id)"
  397. alt
  398. />
  399. </div>
  400. <div class="e_add_input" v-if="sid != ''">
  401. <textarea
  402. rows="2"
  403. v-autoHeight="30"
  404. v-model="evaObject.tName"
  405. class="binfo_textarea"
  406. placeholder="请添加内容.."
  407. @focus="setDetail(3)"
  408. ></textarea>
  409. <img
  410. src="../../assets/icon/new/addInput.png"
  411. @click="addInputName(3)"
  412. alt
  413. />
  414. </div>
  415. </div>
  416. <div class="e_add_list_detail" v-if="isTold">
  417. <textarea
  418. placeholder="添加目标描述"
  419. v-model="isToldDetail"
  420. ></textarea>
  421. </div>
  422. <div class="e_add_list_detail" v-if="tid && !isTold">
  423. <textarea
  424. placeholder="添加目标描述"
  425. v-model="eJson[fid].child[sid].child[tid].detail"
  426. ></textarea>
  427. </div>
  428. <!-- <div class="e_add_list_btn">添加二级标题</div> -->
  429. </div>
  430. <div class="e_add_list_pbox">
  431. <div class="e_add_list_pbox_title">
  432. <span class="type_title">切换模式</span>
  433. <div class="type_content">
  434. <span :class="{ active: typeMode == 1 }" @click="typeMode = 1"
  435. >目标树</span
  436. >
  437. <span :class="{ active: typeMode == 2 }" @click="typeMode = 2"
  438. >目标罗盘</span
  439. >
  440. <span
  441. :class="{ active: typeMode == 3 }"
  442. @click="typeMode = 3"
  443. v-if="!update"
  444. >目标看板</span
  445. >
  446. </div>
  447. </div>
  448. <div class="e_add_list_pbox_content">
  449. <Mind
  450. :showBar="false"
  451. :mindData="data"
  452. v-show="typeMode == 1"
  453. ></Mind>
  454. <Sunburst
  455. :Josn="eJson"
  456. :num="eJSONNum"
  457. v-if="typeMode == 2"
  458. ></Sunburst>
  459. <SeeBoard
  460. :Josn="eJson"
  461. :num="eJSONNum"
  462. :ename="eTitle"
  463. v-if="typeMode == 3"
  464. ></SeeBoard>
  465. </div>
  466. </div>
  467. </div>
  468. </div>
  469. <span slot="footer" class="dialog-footer">
  470. <!-- <el-button @click="dialogVisible = false">关 闭</el-button>
  471. <el-button @click="addEJson" type="primary" v-if="!update"
  472. >确 定</el-button
  473. >
  474. <el-button @click="updateEJson" type="primary" v-else>修 改</el-button> -->
  475. <!-- <el-button @click="dialogVisible = false">关 闭</el-button> -->
  476. </span>
  477. </el-dialog>
  478. <el-dialog
  479. title="选择目标模板"
  480. :visible.sync="temDialogVisible"
  481. :append-to-body="true"
  482. width="600px"
  483. :before-close="handleClose"
  484. class="look_evaTem"
  485. >
  486. <div class="evaTemBox">
  487. <div
  488. v-for="(item, index) in templateArray"
  489. :key="index"
  490. class="evaTemItem"
  491. @click="chooseEva(item.id)"
  492. >
  493. <div class="evaItem">
  494. <div class="evaItemImg">
  495. <img src="../../assets/icon/new/evaTemItem.png" alt="" />
  496. </div>
  497. <div class="evaItemTitle">{{ item.title }}</div>
  498. </div>
  499. <div v-if="cEvaId == item.id" class="evaIsChoose">
  500. <img src="../../assets/icon/new/evaIsChoose.png" alt="" />
  501. </div>
  502. <div class="evaNoChoose" v-else></div>
  503. </div>
  504. </div>
  505. <span slot="footer" class="dialog-footer">
  506. <el-button @click="closeEvaTem">取 消</el-button>
  507. <el-button @click="addEvaByTem" type="primary">确 定</el-button>
  508. </span>
  509. </el-dialog>
  510. <el-dialog
  511. title="添加子级"
  512. :visible.sync="dialogVisible3"
  513. :append-to-body="true"
  514. width="400px"
  515. :before-close="handleClose"
  516. class="dialog_diy tips_diy"
  517. >
  518. <div>
  519. <div class="e_add_title2">
  520. <span>名称</span>
  521. <el-input v-model="eName" placeholder="请输入名称"></el-input>
  522. </div>
  523. </div>
  524. <span slot="footer" class="dialog-footer">
  525. <el-button @click="dialogVisible3 = false">关 闭</el-button>
  526. <el-button @click="addEName" type="primary">确 定</el-button>
  527. </span>
  528. </el-dialog>
  529. <el-dialog
  530. title="修改子级"
  531. :visible.sync="dialogVisible4"
  532. :append-to-body="true"
  533. width="400px"
  534. :before-close="handleClose"
  535. class="dialog_diy tips_diy"
  536. >
  537. <div>
  538. <div class="e_add_title2">
  539. <span>名称</span>
  540. <el-input v-model="eName1" placeholder="请输入名称"></el-input>
  541. </div>
  542. </div>
  543. <span slot="footer" class="dialog-footer">
  544. <el-button @click="dialogVisible4 = false">关 闭</el-button>
  545. <el-button @click="addEName1" type="primary">确 定</el-button>
  546. </span>
  547. </el-dialog>
  548. </div>
  549. </template>
  550. <script>
  551. import Mind from "../tools/jsmind";
  552. import Sunburst from "../tools/sunburst";
  553. import SeeBoard from "../tools/seeBoard";
  554. export default {
  555. components: {
  556. Mind,
  557. Sunburst,
  558. SeeBoard,
  559. },
  560. data() {
  561. return {
  562. data: {
  563. isLoading: false,
  564. meta: {
  565. name: "example",
  566. author: "dd@163.com",
  567. version: "0.2",
  568. },
  569. format: "node_array",
  570. data: [
  571. { id: "root", isroot: true, topic: "" },
  572. // { id: "easy", parentid: "root", topic: "Easy" },
  573. // { id: "easy1", parentid: "easy", topic: "Easy to show" },
  574. // { id: "easy2", parentid: "easy", topic: "Easy to edit" },
  575. // { id: "easy3", parentid: "easy", topic: "Easy to store" },
  576. // { id: "easy4", parentid: "easy", topic: "Easy to embed" },
  577. // { id: "open", parentid: "root", topic: "Open Source" },
  578. // { id: "open1", parentid: "open", topic: "on GitHub" },
  579. // { id: "open2", parentid: "open", topic: "BSD License" },
  580. // { id: "powerful", parentid: "root", topic: "Powerful" },
  581. // {
  582. // id: "powerful1",
  583. // parentid: "powerful",
  584. // topic: "Base on Javascript",
  585. // },
  586. // { id: "powerful2", parentid: "powerful", topic: "Base on HTML5" },
  587. // { id: "powerful3", parentid: "powerful", topic: "Depends on you" },
  588. ],
  589. },
  590. page: 1,
  591. total: 0,
  592. dialogVisible: false,
  593. dialogVisible2: false,
  594. dialogVisible3: false,
  595. dialogVisible4: false,
  596. temDialogVisible: false,
  597. userid: this.$route.query.userid,
  598. oid: this.$route.query.oid,
  599. eTitle: "",
  600. eTitle1: "",
  601. eName: "",
  602. eName1: "",
  603. mid: "",
  604. eJson: {},
  605. eJson1: {},
  606. fid: "", //一级
  607. sid: "", //二级
  608. tid: "", //二级
  609. type: 1,
  610. sn: "",
  611. dataArray: [],
  612. templateArray: [],
  613. update: false,
  614. eid: "",
  615. typeMode: 1,
  616. eJSONNum: 0,
  617. evaObject: {
  618. fName: "",
  619. fName1: "",
  620. isFInput: "",
  621. sName: "",
  622. sName1: "",
  623. isSInput: "",
  624. tName: "",
  625. tName1: "",
  626. isTInput: "",
  627. },
  628. isFold: false,
  629. isFoldDetail: "",
  630. isSold: false,
  631. isSoldDetail: "",
  632. isTold: false,
  633. isToldDetail: "",
  634. cEvaId: "",
  635. };
  636. },
  637. methods: {
  638. tableRowClassName({ row, rowIndex }) {
  639. if ((rowIndex + 1) % 2 === 0) {
  640. return "even_row";
  641. } else {
  642. return "";
  643. }
  644. },
  645. guid() {
  646. var _num,
  647. i,
  648. _guid = "";
  649. for (i = 0; i < 32; i++) {
  650. _guid += Math.floor(Math.random() * 16).toString(16); //随机0 - 16 的数字 转变为16进制的字符串
  651. _num = Math.floor((i - 7) / 4); //计算 (i-7)除4
  652. if (_num > -1 && _num < 4 && i == 7 + 4 * _num) {
  653. //会使guid中间加 "-" 形式为xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx
  654. _guid += "-";
  655. }
  656. }
  657. return _guid;
  658. },
  659. handleCurrentChange(val) {
  660. this.page = val;
  661. this.getData();
  662. },
  663. handleClose(done) {
  664. done();
  665. },
  666. handleClose1(done) {
  667. if (
  668. JSON.stringify(this.eJson) === JSON.stringify(this.eJson1) &&
  669. this.eTitle === this.eTitle1
  670. ) {
  671. done();
  672. } else {
  673. this.$confirm("是否保存该目标?", "提示", {
  674. confirmButtonText: "保存并关闭",
  675. cancelButtonText: "取消",
  676. type: "warning",
  677. })
  678. .then(() => {
  679. if (!this.update) {
  680. this.addEJson();
  681. } else {
  682. this.updateEJson();
  683. }
  684. done();
  685. })
  686. .catch(() => {});
  687. }
  688. },
  689. addE(type) {
  690. this.type = type;
  691. this.dialogVisible3 = true;
  692. },
  693. setDetail(t) {
  694. if (t == 1) {
  695. this.isFold = true;
  696. } else if (t == 2) {
  697. this.isSold = true;
  698. } else if (t == 3) {
  699. this.isTold = true;
  700. }
  701. },
  702. clearAll() {
  703. this.dialogVisible = false;
  704. this.isFold = false;
  705. this.isSold = false;
  706. this.isTold = false;
  707. this.isFoldDetail = "";
  708. this.isSoldDetail = "";
  709. this.isToldDetail = "";
  710. },
  711. addInputName(t) {
  712. let _id = this.guid();
  713. if (t == 1) {
  714. if (this.evaObject.fName == "") {
  715. this.$message.error("请输入目标");
  716. return;
  717. }
  718. this.eJson[_id] = {
  719. id: _id,
  720. name: this.evaObject.fName,
  721. detail: this.isFoldDetail ? this.isFoldDetail : "",
  722. child: {},
  723. };
  724. this.evaObject.fName = "";
  725. this.isFold = false;
  726. this.isFoldDetail = "";
  727. this.checkF(_id);
  728. } else if (t == 2) {
  729. if (this.evaObject.sName == "") {
  730. this.$message.error("请输入目标");
  731. return;
  732. }
  733. this.eJson[this.fid].child[_id] = {
  734. id: _id,
  735. name: this.evaObject.sName,
  736. detail: this.isSoldDetail ? this.isSoldDetail : "",
  737. child: {},
  738. };
  739. this.evaObject.sName = "";
  740. this.isSold = false;
  741. this.isSoldDetail = "";
  742. this.checkS(_id);
  743. } else if (t == 3) {
  744. this.eJson[this.fid].child[this.sid].child[_id] = {
  745. id: _id,
  746. name: this.evaObject.tName,
  747. detail: this.isToldDetail ? this.isToldDetail : "",
  748. child: [],
  749. };
  750. this.evaObject.tName = "";
  751. this.isTold = false;
  752. this.isToldDetail = "";
  753. this.checkT(_id);
  754. }
  755. this.eJSONNum++;
  756. this.setMindData();
  757. },
  758. noInput(id, n, t) {
  759. if (t == 1) {
  760. this.eJson[id].name = n;
  761. this.evaObject.isFInput = "";
  762. } else if (t == 2) {
  763. this.eJson[this.fid].child[id].name = n;
  764. this.evaObject.isSInput = "";
  765. } else if (t == 3) {
  766. this.eJson[this.fid].child[this.sid].child[id].name = n;
  767. this.evaObject.isTInput = "";
  768. }
  769. this.eJSONNum++;
  770. this.setMindData();
  771. },
  772. addEName() {
  773. if (this.eName == "") {
  774. this.$message.error("请输入目标");
  775. return;
  776. }
  777. let _id = this.guid();
  778. if (this.type == 1) {
  779. this.eJson[_id] = {
  780. id: _id,
  781. name: this.eName,
  782. detail: "",
  783. child: {},
  784. };
  785. this.dialogVisible3 = false;
  786. this.eName = "";
  787. } else if (this.type == 2) {
  788. this.eJson[this.fid].child[_id] = {
  789. id: _id,
  790. name: this.eName,
  791. detail: "",
  792. child: {},
  793. };
  794. this.dialogVisible3 = false;
  795. this.eName = "";
  796. } else if (this.type == 3) {
  797. this.eJson[this.fid].child[this.sid].child[_id] = {
  798. id: _id,
  799. name: this.eName,
  800. detail: "",
  801. child: [],
  802. };
  803. this.dialogVisible3 = false;
  804. this.eName = "";
  805. }
  806. this.eJSONNum++;
  807. this.setMindData();
  808. },
  809. addEName1() {
  810. if (this.eName1 == "") {
  811. this.$message.error("请输入目标");
  812. return;
  813. }
  814. if (this.type == 1) {
  815. this.eJson[this.mid].name = this.eName1;
  816. this.dialogVisible4 = false;
  817. this.eName1 = "";
  818. this.mid = "";
  819. } else if (this.type == 2) {
  820. this.eJson[this.fid].child[this.mid].name = this.eName1;
  821. this.dialogVisible4 = false;
  822. this.eName1 = "";
  823. this.mid = "";
  824. } else if (this.type == 3) {
  825. this.eJson[this.fid].child[this.sid].child[this.mid].name = this.eName1;
  826. this.dialogVisible4 = false;
  827. this.eName1 = "";
  828. this.mid = "";
  829. }
  830. this.eJSONNum++;
  831. this.setMindData();
  832. },
  833. checkF(id) {
  834. if (this.fid == id) {
  835. this.fid = "";
  836. } else {
  837. this.fid = id;
  838. }
  839. this.sid = "";
  840. this.tid = "";
  841. this.isFold = false;
  842. },
  843. checkS(id) {
  844. if (this.sid == id) {
  845. this.sid = "";
  846. } else {
  847. this.sid = id;
  848. }
  849. this.tid = "";
  850. this.isSold = false;
  851. },
  852. checkT(id) {
  853. if (this.tid == id) {
  854. this.tid = "";
  855. } else {
  856. this.tid = id;
  857. }
  858. this.isTold = false;
  859. },
  860. updateF(id, n, t) {
  861. this.eName1 = n;
  862. this.mid = id;
  863. this.type = t;
  864. this.dialogVisible4 = true;
  865. },
  866. deleteF(id) {
  867. // if (JSON.stringify(this.eJson[id].child) != "{}") {
  868. // this.$message.error(
  869. // "删除该目标将会同步删除该目标下所有内容,请先删除该目标底下子集!"
  870. // );
  871. // return;
  872. // }
  873. this.$confirm(
  874. "删除该目标将会同步删除该目标下所有内容,是否继续操作?",
  875. "提示",
  876. {
  877. confirmButtonText: "删除",
  878. cancelButtonText: "取消",
  879. type: "warning",
  880. }
  881. )
  882. .then(() => {
  883. if (this.fid == id) {
  884. this.fid = "";
  885. }
  886. var a = JSON.parse(JSON.stringify(this.eJson));
  887. delete a[id];
  888. this.eJson = a;
  889. this.eJSONNum++;
  890. this.$forceUpdate();
  891. this.setMindData();
  892. })
  893. .catch(() => {});
  894. },
  895. deleteS(id) {
  896. // if (JSON.stringify(this.eJson[this.fid].child[id].child) != "{}") {
  897. // this.$message.error(
  898. // "删除该目标将会同步删除该目标下所有内容,请先删除该目标底下子集!"
  899. // );
  900. // return;
  901. // }
  902. this.$confirm(
  903. "删除该目标将会同步删除该目标下所有内容,是否继续操作?",
  904. "提示",
  905. {
  906. confirmButtonText: "删除",
  907. cancelButtonText: "取消",
  908. type: "warning",
  909. }
  910. )
  911. .then(() => {
  912. if (this.sid == id) {
  913. this.sid = "";
  914. }
  915. var a = JSON.parse(JSON.stringify(this.eJson));
  916. delete a[this.fid].child[id];
  917. this.eJson = a;
  918. this.eJSONNum++;
  919. this.$forceUpdate();
  920. this.setMindData();
  921. })
  922. .catch(() => {});
  923. },
  924. deleteT(id) {
  925. this.$confirm("是否删除该子级?", "提示", {
  926. confirmButtonText: "删除",
  927. cancelButtonText: "取消",
  928. type: "warning",
  929. })
  930. .then(() => {
  931. if (this.tid == id) {
  932. this.tid = "";
  933. }
  934. var a = JSON.parse(JSON.stringify(this.eJson));
  935. delete a[this.fid].child[this.sid].child[id];
  936. this.eJson = a;
  937. this.eJSONNum++;
  938. this.$forceUpdate();
  939. this.setMindData();
  940. })
  941. .catch(() => {});
  942. },
  943. addEJson() {
  944. if (this.eTitle == "") {
  945. this.$message.error("请填写目标管理标题");
  946. return;
  947. }
  948. let params = [
  949. {
  950. uid: this.$route.query.userid,
  951. t: this.eTitle,
  952. c: JSON.stringify(this.eJson),
  953. },
  954. ];
  955. this.ajax
  956. .post(this.$store.state.api + "addEvaluation", params)
  957. .then((res) => {
  958. this.$message.success("保存成功");
  959. this.init();
  960. this.clearAll();
  961. this.getData();
  962. })
  963. .catch((err) => {
  964. this.$message.success("添加失败");
  965. console.error(err);
  966. });
  967. },
  968. addTemplate() {
  969. if (this.eTitle == "") {
  970. this.$message.error("请填写目标管理标题");
  971. return;
  972. }
  973. let params = {
  974. t: this.eTitle,
  975. c: JSON.stringify(this.eJson),
  976. uid: this.$route.query.userid,
  977. oid: this.oid,
  978. };
  979. this.ajax
  980. .get(this.$store.state.api + "addEvaTemplate", params)
  981. .then((res) => {
  982. this.$message.success("新增模板成功");
  983. this.init();
  984. this.clearAll();
  985. this.getData();
  986. })
  987. .catch((err) => {
  988. this.isLoading = false;
  989. console.error(err);
  990. });
  991. },
  992. updateEJson() {
  993. if (this.eTitle == "") {
  994. this.$message.error("请填写目标管理标题");
  995. return;
  996. }
  997. let params = [
  998. {
  999. c: JSON.stringify(this.eJson),
  1000. t: this.eTitle,
  1001. id: this.eid,
  1002. },
  1003. ];
  1004. this.ajax
  1005. .post(this.$store.state.api + "updateEvaluation", params)
  1006. .then((res) => {
  1007. this.$message.success("修改成功");
  1008. this.init();
  1009. this.clearAll();
  1010. this.getData();
  1011. })
  1012. .catch((err) => {
  1013. this.$message.success("修改失败");
  1014. console.error(err);
  1015. });
  1016. },
  1017. search() {
  1018. this.page = 1;
  1019. this.getData();
  1020. },
  1021. getData() {
  1022. this.isLoading = true;
  1023. let params = {
  1024. oid: this.oid,
  1025. n: this.sn,
  1026. page: this.page,
  1027. };
  1028. this.ajax
  1029. .get(this.$store.state.api + "getEvaluation", params)
  1030. .then((res) => {
  1031. this.isLoading = false;
  1032. this.total = res.data[0].length > 0 ? res.data[0][0].num : 0;
  1033. this.dataArray = res.data[0];
  1034. })
  1035. .catch((err) => {
  1036. this.isLoading = false;
  1037. console.error(err);
  1038. });
  1039. },
  1040. deleteEva(id) {
  1041. let params = [
  1042. {
  1043. id: id,
  1044. },
  1045. ];
  1046. this.ajax
  1047. .post(this.$store.state.api + "deleteEvaluation", params)
  1048. .then((res) => {
  1049. this.$message.success("删除成功");
  1050. if (this.page != 1 && this.tableData.length == 1) {
  1051. this.page--;
  1052. }
  1053. this.getData();
  1054. })
  1055. .catch((err) => {
  1056. this.$message.success("删除失败");
  1057. console.error(err);
  1058. });
  1059. },
  1060. deleteE(id) {
  1061. let params = {
  1062. eid: id,
  1063. };
  1064. this.ajax
  1065. .get(this.$store.state.api + "selectCourseEva", params)
  1066. .then((res) => {
  1067. if (res.data[0].length == 0) {
  1068. this.$confirm("是否删除此目标?", "提示", {
  1069. confirmButtonText: "确定",
  1070. cancelButtonText: "取消",
  1071. type: "warning",
  1072. })
  1073. .then(() => {
  1074. this.deleteEva(id);
  1075. })
  1076. .catch(() => {});
  1077. } else {
  1078. this.$confirm("此目标已被引用,是否继续删除操作?", "提示", {
  1079. confirmButtonText: "确定",
  1080. cancelButtonText: "取消",
  1081. type: "warning",
  1082. })
  1083. .then(() => {
  1084. this.deleteEva(id);
  1085. })
  1086. .catch(() => {});
  1087. }
  1088. })
  1089. .catch((err) => {
  1090. console.error(err);
  1091. });
  1092. },
  1093. init() {
  1094. this.eJson = {};
  1095. this.eJson1 = {};
  1096. this.fid = "";
  1097. this.sid = "";
  1098. this.tid = "";
  1099. this.eTitle = "";
  1100. this.eTitle1 = "";
  1101. },
  1102. addED() {
  1103. this.update = false;
  1104. this.init();
  1105. this.setMindData();
  1106. this.typeMode = 1;
  1107. this.clearAll();
  1108. this.dialogVisible = true;
  1109. },
  1110. openTemplate() {
  1111. this.templateArray = [];
  1112. this.selectEvaTem("1", () => {
  1113. this.selectEvaTem(this.oid, () => {
  1114. this.selectEvaTem(this.org);
  1115. });
  1116. });
  1117. this.temDialogVisible = true;
  1118. },
  1119. selectEvaTem(oid, callback) {
  1120. let params = {
  1121. oid: oid,
  1122. };
  1123. this.ajax
  1124. .get(this.$store.state.api + "selectEvaTemplate", params)
  1125. .then((res) => {
  1126. if (res.data[0].length) {
  1127. this.templateArray = [...res.data[0], ...this.templateArray];
  1128. }
  1129. this.templateArray.sort(
  1130. (a, b) =>
  1131. new Date(b.createTime).getTime() -
  1132. new Date(a.createTime).getTime()
  1133. );
  1134. this.$forceUpdate();
  1135. callback ? callback() : "";
  1136. })
  1137. .catch((err) => {});
  1138. },
  1139. checkE(res) {
  1140. this.init();
  1141. this.eJson = JSON.parse(res.content);
  1142. this.eJson1 = JSON.parse(res.content);
  1143. this.eTitle1 = res.title;
  1144. this.eTitle = res.title;
  1145. this.eid = res.id;
  1146. this.update = true;
  1147. this.typeMode = 1;
  1148. this.dialogVisible = true;
  1149. this.$forceUpdate();
  1150. setTimeout(() => {
  1151. this.setMindData();
  1152. }, 0);
  1153. },
  1154. checkE1(res) {
  1155. this.init();
  1156. this.eJson = JSON.parse(res.chapters);
  1157. this.eJson1 = JSON.parse(res.chapters);
  1158. this.eTitle1 = res.title;
  1159. this.eTitle = res.title;
  1160. if(this.update == false){
  1161. this.eid = res.courseId;
  1162. }
  1163. this.typeMode = 1;
  1164. this.$forceUpdate();
  1165. setTimeout(() => {
  1166. this.setMindData();
  1167. }, 0);
  1168. },
  1169. setMindData() {
  1170. this.data.data = [];
  1171. this.data.data.push({ id: "root", isroot: true, topic: this.eTitle });
  1172. let _eJson = Object.keys(this.eJson);
  1173. let _e = this.eJson;
  1174. for (let i = 0; i < _eJson.length; i++) {
  1175. let element = _e[_eJson[i]];
  1176. this.data.data.push({
  1177. id: element.id,
  1178. parentid: "root",
  1179. topic: element.name,
  1180. });
  1181. let _eJsonc = Object.keys(element.child);
  1182. let _e2 = element.child;
  1183. for (let j = 0; j < _eJsonc.length; j++) {
  1184. let _ec = _e2[_eJsonc[j]];
  1185. this.data.data.push({
  1186. id: _ec.id,
  1187. parentid: element.id,
  1188. topic: _ec.name,
  1189. });
  1190. let _eJsonz = Object.keys(_ec.child);
  1191. let _e3 = _ec.child;
  1192. for (let z = 0; z < _eJsonz.length; z++) {
  1193. let _ez = _e3[_eJsonz[z]];
  1194. this.data.data.push({
  1195. id: _ez.id,
  1196. parentid: _ec.id,
  1197. topic: _ez.name,
  1198. });
  1199. }
  1200. }
  1201. }
  1202. this.$forceUpdate();
  1203. },
  1204. chooseEva(id) {
  1205. this.cEvaId = "";
  1206. this.cEvaId = id;
  1207. },
  1208. closeEvaTem() {
  1209. this.temDialogVisible = false;
  1210. this.cEvaId = "";
  1211. },
  1212. addEvaByTem() {
  1213. this.temDialogVisible = false;
  1214. for (var i = 0; i < this.templateArray.length; i++) {
  1215. if (this.cEvaId == this.templateArray[i].id) {
  1216. this.checkE1(this.templateArray[i]);
  1217. }
  1218. }
  1219. },
  1220. copyEva(eid) {
  1221. let params = [
  1222. {
  1223. eid: eid,
  1224. uid: this.userid,
  1225. },
  1226. ];
  1227. this.ajax
  1228. .post(this.$store.state.api + "copyEva", params)
  1229. .then((res) => {
  1230. this.page = 1;
  1231. this.$message.success("复制成功");
  1232. this.getData();
  1233. })
  1234. .catch((err) => {
  1235. console.error(err);
  1236. });
  1237. },
  1238. },
  1239. created() {
  1240. this.getData();
  1241. },
  1242. };
  1243. </script>
  1244. <style scoped>
  1245. .dialog_diy >>> .el-dialog__header {
  1246. padding: 9px 20px 10px;
  1247. background: #32455b !important;
  1248. }
  1249. .dialog_diy >>> .el-dialog__title {
  1250. color: #fff;
  1251. font-size: 15px;
  1252. }
  1253. .dialog_diy >>> .el-dialog__headerbtn {
  1254. top: 14px;
  1255. }
  1256. .dialog_diy >>> .el-dialog__headerbtn .el-dialog__close {
  1257. color: #fff;
  1258. }
  1259. .dialog_diy >>> .el-dialog__headerbtn .el-dialog__close:hover {
  1260. color: #fff;
  1261. }
  1262. .dialog_diy >>> .el-dialog__body {
  1263. padding: 15px 20px 0;
  1264. }
  1265. .dialog_diy >>> .el-dialog__body,
  1266. .dialog_diy >>> .el-dialog__footer {
  1267. background: #e6eaf0;
  1268. }
  1269. .look_evaTem >>> .el-dialog {
  1270. border-radius: 5px;
  1271. }
  1272. .look_evaTem >>> .el-dialog__header {
  1273. background: #fff;
  1274. border-top-left-radius: 5px;
  1275. border-top-right-radius: 5px;
  1276. }
  1277. .look_evaTem >>> .el-dialog__headerbtn .el-dialog__close {
  1278. color: #000;
  1279. }
  1280. .look_evaTem >>> .el-dialog__headerbtn .el-dialog__close:hover {
  1281. color: #000;
  1282. }
  1283. .tips_diy >>> .el-dialog__body,
  1284. .tips_diy >>> .el-dialog__footer {
  1285. background: #fff;
  1286. }
  1287. .mubiao_diy >>> .el-dialog {
  1288. max-width: 1200px;
  1289. }
  1290. .pb_head > span:nth-child(2) {
  1291. font-size: 16px;
  1292. margin-left: 80px;
  1293. color: #ab582f;
  1294. }
  1295. .pb_head {
  1296. margin: 0 !important;
  1297. width: 100% !important;
  1298. }
  1299. .student_head {
  1300. margin-top: 10px;
  1301. padding-bottom: 15px;
  1302. display: flex;
  1303. justify-content: flex-end;
  1304. }
  1305. .student_search {
  1306. display: flex;
  1307. }
  1308. .student_search > div:nth-child(1) {
  1309. line-height: 35px;
  1310. font-size: 14px;
  1311. min-width: 60px;
  1312. }
  1313. .student_search >>> .el-input__inner {
  1314. width: 190px;
  1315. /* height: 35px; */
  1316. margin-right: 10px;
  1317. }
  1318. .student_search .btn {
  1319. background: rgb(34, 104, 189);
  1320. border: none;
  1321. }
  1322. .student_button {
  1323. display: flex;
  1324. overflow: hidden;
  1325. height: 40px;
  1326. }
  1327. .top {
  1328. display: flex;
  1329. justify-content: space-between;
  1330. }
  1331. .bgColor {
  1332. background: #466b99;
  1333. border: none;
  1334. }
  1335. .student_page {
  1336. margin-top: 10px;
  1337. }
  1338. .e_add_top {
  1339. display: flex;
  1340. justify-content: space-between;
  1341. padding: 20px 20px;
  1342. border-radius: 3px;
  1343. background: #fff;
  1344. }
  1345. .e_add_title2 {
  1346. display: flex;
  1347. align-items: center;
  1348. }
  1349. .e_add_title2 span {
  1350. width: 40px;
  1351. }
  1352. .e_add_title {
  1353. display: flex;
  1354. align-items: center;
  1355. }
  1356. .e_add_title span {
  1357. width: 135px;
  1358. }
  1359. .e_add_title .el_input {
  1360. width: 300px;
  1361. }
  1362. .e_add_title >>> .el-input__inner {
  1363. width: 400px;
  1364. }
  1365. .e_add_btn {
  1366. }
  1367. .e_add_content {
  1368. display: flex;
  1369. width: 100%;
  1370. height: 100%;
  1371. }
  1372. .e_add_list {
  1373. background: #fff;
  1374. height: 100%;
  1375. width: calc(50% / 3);
  1376. position: relative;
  1377. margin: 15px 10px 0 0;
  1378. flex-shrink: 0;
  1379. display: flex;
  1380. flex-direction: column;
  1381. }
  1382. .e_add_list_title {
  1383. font-size: 20px;
  1384. width: 100%;
  1385. box-sizing: border-box;
  1386. padding: 15px 40px;
  1387. text-align: center;
  1388. border-bottom: 1px solid #eaeaea;
  1389. position: relative;
  1390. display: flex;
  1391. align-items: center;
  1392. justify-content: center;
  1393. height: 57px;
  1394. background: #f6f6f6;
  1395. }
  1396. .e_add_list_title span {
  1397. overflow: hidden;
  1398. white-space: nowrap;
  1399. text-overflow: ellipsis;
  1400. }
  1401. .e_add_list_title img {
  1402. position: absolute;
  1403. right: 15px;
  1404. width: 25px;
  1405. cursor: pointer;
  1406. top: 50%;
  1407. transform: translateY(-50%);
  1408. }
  1409. .e_add_list_body {
  1410. height: calc(100% - 187px);
  1411. overflow: auto;
  1412. }
  1413. .e_add_input {
  1414. display: flex;
  1415. flex-direction: row;
  1416. flex-wrap: nowrap;
  1417. align-items: center;
  1418. justify-content: center;
  1419. padding: 10px;
  1420. }
  1421. .e_add_input > .el-input {
  1422. width: 300px;
  1423. }
  1424. .e_add_input > .el-button {
  1425. margin-left: 10px;
  1426. }
  1427. .e_add_input > img {
  1428. width: 35px;
  1429. height: 35px;
  1430. margin: 0 5px;
  1431. cursor: pointer;
  1432. }
  1433. .e_add_list_child {
  1434. width: 100%;
  1435. display: flex;
  1436. align-items: center;
  1437. justify-content: center;
  1438. position: relative;
  1439. box-sizing: border-box;
  1440. padding: 15px 62px 15px 30px;
  1441. text-align: center;
  1442. }
  1443. .e_add_list_child span {
  1444. cursor: pointer;
  1445. word-break: break-word;
  1446. min-width: 100%;
  1447. display: -webkit-box;
  1448. overflow: hidden;
  1449. white-space: normal !important;
  1450. text-overflow: ellipsis;
  1451. word-wrap: break-word;
  1452. -webkit-line-clamp: 3;
  1453. -webkit-box-orient: vertical;
  1454. }
  1455. .e_add_list_child img {
  1456. position: absolute;
  1457. right: 10px;
  1458. width: 21px;
  1459. cursor: pointer;
  1460. top: 50%;
  1461. transform: translateY(-50%);
  1462. }
  1463. .e_add_list_child + .e_add_list_child {
  1464. border-top: 1px solid #eaeaea;
  1465. }
  1466. .e_add_list_child .active {
  1467. color: #409eff;
  1468. font-weight: bold;
  1469. }
  1470. .e_add_list_btn {
  1471. position: absolute;
  1472. bottom: 0;
  1473. height: 50px;
  1474. background: rgb(120, 120, 254);
  1475. width: 100%;
  1476. color: #fff;
  1477. font-size: 16px;
  1478. text-align: center;
  1479. line-height: 50px;
  1480. cursor: pointer;
  1481. }
  1482. .e_add_list_detail {
  1483. position: absolute;
  1484. bottom: 0;
  1485. height: 130px;
  1486. background: rgb(120, 120, 254);
  1487. width: 100%;
  1488. color: #fff;
  1489. font-size: 16px;
  1490. display: flex;
  1491. align-items: center;
  1492. justify-content: center;
  1493. }
  1494. .e_add_list_detail textarea {
  1495. height: 90%;
  1496. width: 95%;
  1497. border: none;
  1498. resize: none;
  1499. outline: none;
  1500. padding: 5px;
  1501. box-sizing: border-box;
  1502. }
  1503. .e_add_list_pbox {
  1504. margin: 15px 0 0 0;
  1505. width: 50%;
  1506. min-width: 500px;
  1507. height: 100%;
  1508. min-height: 500px;
  1509. }
  1510. .e_add_list_pbox_title {
  1511. height: 50px;
  1512. background: #fff;
  1513. display: flex;
  1514. align-items: center;
  1515. width: 100%;
  1516. box-sizing: border-box;
  1517. padding: 0 20px;
  1518. }
  1519. .type_title {
  1520. font-size: 18px;
  1521. font-weight: 700;
  1522. }
  1523. .type_content {
  1524. font-size: 16px;
  1525. margin-left: 30px;
  1526. }
  1527. .type_content span + span {
  1528. margin-left: 20px;
  1529. }
  1530. .type_content span {
  1531. cursor: pointer;
  1532. padding-bottom: 5px;
  1533. box-sizing: border-box;
  1534. }
  1535. .type_content .active {
  1536. color: #409eff;
  1537. border-bottom: 2px solid #409eff;
  1538. }
  1539. .e_add_list_pbox_content {
  1540. height: calc(100% - 50px);
  1541. display: flex;
  1542. align-items: center;
  1543. width: 100%;
  1544. background: #fff;
  1545. }
  1546. .el-table >>> .even_row {
  1547. background-color: #f1f1f1 !important;
  1548. }
  1549. .fullStyle >>> .el-dialog__body {
  1550. height: calc(100% - 125px) !important;
  1551. box-sizing: border-box;
  1552. min-height: 500px;
  1553. }
  1554. .fullStyle >>> .el-dialog {
  1555. width: 100% !important;
  1556. max-width: 100% !important;
  1557. height: 100% !important;
  1558. margin: 0 !important;
  1559. }
  1560. .fullStyle {
  1561. width: 100% !important;
  1562. max-width: 100% !important;
  1563. height: 100% !important;
  1564. margin: 0 auto !important;
  1565. }
  1566. .binfo_textarea {
  1567. width: 100%;
  1568. margin: 0;
  1569. padding: 12px 14px;
  1570. display: block;
  1571. min-width: 0;
  1572. outline: none;
  1573. box-sizing: border-box;
  1574. background: none;
  1575. border: none;
  1576. border-radius: 4px;
  1577. background: #fff;
  1578. font-size: 16px;
  1579. resize: none;
  1580. font-family: "Microsoft YaHei";
  1581. min-height: 48px;
  1582. border: 1.5px solid #cad1dc;
  1583. }
  1584. .binfo_textarea:focus-visible {
  1585. border: 1.5px solid #3681fc !important;
  1586. }
  1587. .binfo_textarea::-webkit-scrollbar {
  1588. /*滚动条整体样式*/
  1589. width: 6px;
  1590. /*高宽分别对应横竖滚动条的尺寸*/
  1591. height: 6px;
  1592. }
  1593. /*定义滚动条轨道 内阴影+圆角*/
  1594. .binfo_textarea::-webkit-scrollbar {
  1595. border-radius: 10px;
  1596. background-color: #eee;
  1597. }
  1598. /*定义滑块 内阴影+圆角*/
  1599. .binfo_textarea::-webkit-scrollbar-thumb {
  1600. border-radius: 10px;
  1601. -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.3);
  1602. background-color: rgba(0, 0, 0, 0.1);
  1603. }
  1604. .text_tooltip2 {
  1605. max-width: 400px;
  1606. }
  1607. .evaTemBox {
  1608. display: flex;
  1609. flex-direction: row;
  1610. flex-wrap: wrap;
  1611. align-items: center;
  1612. width: 100%;
  1613. }
  1614. .evaTemItem {
  1615. width: 100px;
  1616. height: 100px;
  1617. background: #f0f4fa;
  1618. border-radius: 6px;
  1619. border: 1px solid #cad1dc;
  1620. cursor: pointer;
  1621. position: relative;
  1622. margin: 0 10px 10px 0;
  1623. }
  1624. .evaItem {
  1625. display: flex;
  1626. flex-direction: column;
  1627. flex-wrap: nowrap;
  1628. align-items: center;
  1629. width: 100%;
  1630. height: 100%;
  1631. justify-content: center;
  1632. }
  1633. .evaItemImg {
  1634. width: 30px;
  1635. height: 30px;
  1636. min-width: 30px;
  1637. min-height: 30px;
  1638. }
  1639. .evaItemImg > img {
  1640. width: 100%;
  1641. height: 100%;
  1642. }
  1643. .evaItemTitle {
  1644. margin-top: 10px;
  1645. max-width: 85px;
  1646. text-align: center;
  1647. white-space: nowrap;
  1648. overflow: hidden;
  1649. text-overflow: ellipsis;
  1650. word-break: break-word;
  1651. }
  1652. .evaNoChoose {
  1653. position: absolute;
  1654. top: 5px;
  1655. right: 5px;
  1656. width: 15px;
  1657. height: 15px;
  1658. background: #ffffff;
  1659. border: 1px solid #3681fc;
  1660. border-radius: 50%;
  1661. cursor: pointer;
  1662. }
  1663. .evaIsChoose {
  1664. position: absolute;
  1665. top: 5px;
  1666. right: 5px;
  1667. width: 15px;
  1668. height: 15px;
  1669. cursor: pointer;
  1670. }
  1671. .evaIsChoose > img {
  1672. width: 100%;
  1673. height: 100%;
  1674. }
  1675. </style>