group.vue 51 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352
  1. <template>
  2. <div>
  3. <div style="overflow: auto">
  4. <div class="g_d_btnBox">
  5. <!-- <div class="btn_left" v-if="type == 1 || type == 4">
  6. <div @click="setClassid('1')" :class="{ active: classid == '1' }" v-if="!classList.length">全部</div>
  7. <div @click="setClassid(item.id)" :class="{ active: classid == item.id }"
  8. v-for="(item, index) in classList" :key="index">{{ item.name }}</div>
  9. </div>
  10. <div class="btn_left" v-if="type == 2">
  11. <div @click="setClassid('1')" :class="{ active: classid == '1' }" v-if="!classList.length">全部</div>
  12. <div @click="setClassid(item.id)" :class="{ active: classid == item.id }"
  13. v-for="(item, index) in classList" :key="index">{{ item.name }}</div>
  14. </div> -->
  15. <div></div>
  16. <!-- || (courseDetail.course_teacher && courseDetail.course_teacher.indexOf(userid) != -1) -->
  17. <div class="btn_right"
  18. v-if="courseDetail.userid == userid">
  19. <div style="color: rgb(171 171 171); margin: 0 10px 0 0">
  20. 提示:开启【开放选座】,能够自由加入和退出小组。
  21. </div>
  22. <!-- 开放选座 -->
  23. <!-- <div type="primary" v-if="groupJson.islock == 1 && groupJson.group.length" class="returnBtn"
  24. style="background-color: #225bc7" @click="lockChair">
  25. 锁定位置
  26. </div>
  27. <div type="primary" v-else-if="groupJson.group.length" class="returnBtn"
  28. style="background-color: #225bc7" @click="lockChair">
  29. 解锁位置
  30. </div> -->
  31. <div class="group_switch">
  32. <span>开放选座</span>
  33. <el-switch v-model="islock" active-text="" class="switchCss" @change="lockChair"></el-switch>
  34. </div>
  35. <div class="group_switch">
  36. <span>开启分组</span>
  37. <el-switch v-model="isopen" class="switchCss" @change="openChair"></el-switch>
  38. </div>
  39. <div type="primary" @click="updateGroup" class="returnBtn" style="background-color: #225bc7">
  40. 分组设置
  41. </div>
  42. <div type="primary" @click="deleteCourseGroup" class="returnBtn" style="background-color: #225bc7">
  43. 删除分组
  44. </div>
  45. </div>
  46. <div class="btn_right"
  47. v-else>
  48. <div style="color: rgb(171 171 171); margin: 0 10px 0 0">
  49. 提示:开启【开放选座】,能够自由加入和退出小组。
  50. </div>
  51. <div class="group_switch">
  52. <span>开放选座</span>
  53. <el-switch v-model="islock" active-text="" class="switchCss" @change="lockChair" disabled></el-switch>
  54. </div>
  55. </div>
  56. </div>
  57. <div style="min-height: 250px;">
  58. <div class="g_d_box" v-if="groupJson.group.length && isopen">
  59. <div class="g_d_group" v-for="(g, gindex) in groupJson.group" :key="gindex">
  60. <div class="g_d_group_chair">
  61. <div v-if="groupJson.number > 1">
  62. <span :class="{
  63. isChair:
  64. groupStudent[g.id] &&
  65. groupStudent[g.id][0],
  66. updateChair:
  67. courseDetail.userid == userid &&
  68. groupStudent[g.id] &&
  69. groupStudent[g.id][0] &&
  70. groupJson.islock == 2,
  71. }"><span class="updateChairBtn"
  72. @click="updateGroupChair(groupStudent[g.id] && groupStudent[g.id][0])">修改</span></span><span>{{
  73. groupStudent[g.id] &&
  74. groupStudent[g.id][0]
  75. ? groupStudent[g.id] &&
  76. groupStudent[g.id][0].name
  77. : "空位置" }}</span>
  78. </div>
  79. <div v-if="groupJson.number > 4">
  80. <span :class="{
  81. isChair:
  82. groupStudent[g.id] &&
  83. groupStudent[g.id][4],
  84. updateChair:
  85. courseDetail.userid == userid &&
  86. groupStudent[g.id] &&
  87. groupStudent[g.id][4] &&
  88. groupJson.islock == 2,
  89. }"><span class="updateChairBtn"
  90. @click="updateGroupChair(groupStudent[g.id] && groupStudent[g.id][4])">修改</span></span><span>{{
  91. groupStudent[g.id] &&
  92. groupStudent[g.id][4]
  93. ? groupStudent[g.id] &&
  94. groupStudent[g.id][4].name
  95. : "空位置" }}</span>
  96. </div>
  97. <div v-if="groupJson.number > 8">
  98. <span :class="{
  99. isChair:
  100. groupStudent[g.id] &&
  101. groupStudent[g.id][8],
  102. updateChair:
  103. courseDetail.userid == userid &&
  104. groupStudent[g.id] &&
  105. groupStudent[g.id][8] &&
  106. groupJson.islock == 2,
  107. }"><span class="updateChairBtn"
  108. @click="updateGroupChair(groupStudent[g.id] && groupStudent[g.id][8])">修改</span></span><span>{{
  109. groupStudent[g.id] &&
  110. groupStudent[g.id][8]
  111. ? groupStudent[g.id] &&
  112. groupStudent[g.id][8].name
  113. : "空位置" }}</span>
  114. </div>
  115. </div>
  116. <div class="g_d_group_tableBox">
  117. <div class="g_d_group_chair2">
  118. <div v-if="groupJson.number > 2">
  119. <span :class="{
  120. isChair:
  121. groupStudent[g.id] &&
  122. groupStudent[g.id][2],
  123. updateChair:
  124. courseDetail.userid == userid &&
  125. groupStudent[g.id] &&
  126. groupStudent[g.id][2] &&
  127. groupJson.islock == 2,
  128. }"><span class="updateChairBtn"
  129. @click="updateGroupChair(groupStudent[g.id] && groupStudent[g.id][2])">修改</span></span><span>{{
  130. groupStudent[g.id] &&
  131. groupStudent[g.id][2]
  132. ? groupStudent[g.id] &&
  133. groupStudent[g.id][2].name
  134. : "空位置" }}</span>
  135. </div>
  136. <div v-if="groupJson.number > 6">
  137. <span :class="{
  138. isChair:
  139. groupStudent[g.id] &&
  140. groupStudent[g.id][6],
  141. updateChair:
  142. courseDetail.userid == userid &&
  143. groupStudent[g.id] &&
  144. groupStudent[g.id][6] &&
  145. groupJson.islock == 2,
  146. }"><span class="updateChairBtn"
  147. @click="updateGroupChair(groupStudent[g.id] && groupStudent[g.id][6])">修改</span></span><span>{{
  148. groupStudent[g.id] &&
  149. groupStudent[g.id][6]
  150. ? groupStudent[g.id] &&
  151. groupStudent[g.id][6].name
  152. : "空位置" }}</span>
  153. </div>
  154. </div>
  155. <div class="g_d_group_table">
  156. <div>
  157. {{ g.name }}
  158. </div>
  159. <div>
  160. <div v-if="courseDetail.userid == userid && groupJson.islock == 2"
  161. @click="deleteGroupChair(g.id, gindex)">
  162. 移除组员
  163. </div>
  164. <div @click="selectGroup(g.id)"
  165. v-else-if="groupStudentUid && groupStudentUid[g.id].indexOf(userid) == -1 && courseDetail.userid !== userid">
  166. 加入分组
  167. </div>
  168. <div @click="
  169. exitGroup(groupStudent[g.id] &&
  170. groupStudent[g.id][
  171. groupStudentUid[g.id].indexOf(userid)
  172. ].id)
  173. "
  174. v-else-if="groupStudentUid && groupStudentUid[g.id].indexOf(userid) != -1">
  175. 退出分组
  176. </div>
  177. <div style="margin-top:10px"
  178. v-if="(courseDetail.userid == userid ) && groupStudent[g.id].length < groupJson.number"
  179. @click="addGroupStudent(g.id)">
  180. 添加组员
  181. <!-- || (courseDetail.course_teacher && courseDetail.course_teacher.indexOf(userid) != -1) -->
  182. </div>
  183. </div>
  184. </div>
  185. <div class="g_d_group_chair2">
  186. <div v-if="groupJson.number > 3">
  187. <span :class="{
  188. isChair:
  189. groupStudent[g.id] &&
  190. groupStudent[g.id][3],
  191. updateChair:
  192. courseDetail.userid == userid &&
  193. groupStudent[g.id] &&
  194. groupStudent[g.id][3] &&
  195. groupJson.islock == 2,
  196. }"><span class="updateChairBtn"
  197. @click="updateGroupChair(groupStudent[g.id] && groupStudent[g.id][3])">修改</span></span><span>{{
  198. groupStudent[g.id] &&
  199. groupStudent[g.id][3]
  200. ? groupStudent[g.id] &&
  201. groupStudent[g.id][3].name
  202. : "空位置" }}</span>
  203. </div>
  204. <div v-if="groupJson.number > 7">
  205. <span :class="{
  206. isChair:
  207. groupStudent[g.id] &&
  208. groupStudent[g.id][7],
  209. updateChair:
  210. courseDetail.userid == userid &&
  211. groupStudent[g.id] &&
  212. groupStudent[g.id][7] &&
  213. groupJson.islock == 2,
  214. }"><span class="updateChairBtn"
  215. @click="updateGroupChair(groupStudent[g.id] && groupStudent[g.id][7])">修改</span></span><span>{{
  216. groupStudent[g.id] &&
  217. groupStudent[g.id][7]
  218. ? groupStudent[g.id] &&
  219. groupStudent[g.id][7].name
  220. : "空位置" }}</span>
  221. </div>
  222. </div>
  223. </div>
  224. <div class="g_d_group_chair">
  225. <div v-if="groupJson.number > 1">
  226. <span :class="{
  227. isChair:
  228. groupStudent[g.id] &&
  229. groupStudent[g.id][1],
  230. updateChair:
  231. courseDetail.userid == userid &&
  232. groupStudent[g.id] &&
  233. groupStudent[g.id][1] &&
  234. groupJson.islock == 2,
  235. }"><span class="updateChairBtn"
  236. @click="updateGroupChair(groupStudent[g.id] && groupStudent[g.id][1])">修改</span></span><span>{{
  237. groupStudent[g.id] &&
  238. groupStudent[g.id][1]
  239. ? groupStudent[g.id] &&
  240. groupStudent[g.id][1].name
  241. : "空位置" }}</span>
  242. </div>
  243. <div v-if="groupJson.number > 5">
  244. <span :class="{
  245. isChair:
  246. groupStudent[g.id] &&
  247. groupStudent[g.id][5],
  248. updateChair:
  249. courseDetail.userid == userid &&
  250. groupStudent[g.id] &&
  251. groupStudent[g.id][5] &&
  252. groupJson.islock == 2,
  253. }"><span class="updateChairBtn"
  254. @click="updateGroupChair(groupStudent[g.id] && groupStudent[g.id][5])">修改</span></span><span>{{
  255. groupStudent[g.id] &&
  256. groupStudent[g.id][5]
  257. ? groupStudent[g.id] &&
  258. groupStudent[g.id][5].name
  259. : "空位置" }}</span>
  260. </div>
  261. <div v-if="groupJson.number > 9">
  262. <span :class="{
  263. isChair:
  264. groupStudent[g.id] &&
  265. groupStudent[g.id][9],
  266. updateChair:
  267. courseDetail.userid == userid &&
  268. groupStudent[g.id] &&
  269. groupStudent[g.id][9] &&
  270. groupJson.islock == 2,
  271. }"><span class="updateChairBtn"
  272. @click="updateGroupChair(groupStudent[g.id] && groupStudent[g.id][9])">修改</span></span><span>{{
  273. groupStudent[g.id] &&
  274. groupStudent[g.id][9]
  275. ? groupStudent[g.id] &&
  276. groupStudent[g.id][9].name
  277. : "空位置" }}</span>
  278. </div>
  279. </div>
  280. </div>
  281. </div>
  282. <div v-else-if="!groupJson.group.length" style="text-align: center;">{{ courseDetail.userid == userid ?
  283. "暂无分组,请点击右上角设置分组" :
  284. "老师暂未添加分组" }}</div>
  285. <div v-else-if="!isopen" style="text-align: center;">{{ "已关闭分组" }}</div>
  286. </div>
  287. </div>
  288. <el-dialog title="分组设置" :visible.sync="dialogVisibleGroup2" :append-to-body="true" width="650px"
  289. :before-close="handleClose" class="dialog_diy">
  290. <div class="groupBox">
  291. <div v-if="groupJson2.group" class="groupContent">
  292. <div class="groupTitle">请设置小组数量及名称</div>
  293. <div v-for="(item, index) in groupJson2.group" :key="index" class="groupName">
  294. <span class="groupn">第{{ index + 1 }}组名称:</span>
  295. <el-input v-model="item.name" placeholder="请输入名称..." style="width: 250px"></el-input>
  296. <div class="groupBtn">
  297. <el-button type="primary" size="small" @click="addGroup(index)"
  298. v-if="(groupJson2.group.length - 1) == index">
  299. 添加</el-button>
  300. <el-button type="primary" size="small" @click="deleteGroup(index)"
  301. v-if="groupJson2.group && groupJson2.group.length > 1">删除</el-button>
  302. </div>
  303. </div>
  304. </div>
  305. <div class="groupContent">
  306. <div class="groupTitle">请设置每组人数</div>
  307. <el-input v-model="groupJson2.number" style="width:150px" placeholder="请输入2-10的数字"
  308. @change="numberPan"></el-input>
  309. </div>
  310. </div>
  311. <span slot="footer" class="dialog-footer">
  312. <el-button @click="dialogVisibleGroup2 = false">取 消</el-button>
  313. <el-button type="primary" @click="updateGroupJson(2)">确定</el-button>
  314. </span>
  315. </el-dialog>
  316. <el-dialog title="移除组员" :visible.sync="dialogVisibleDeleteGroup" :append-to-body="true" width="350px"
  317. :before-close="handleClose" class="dialog_diy">
  318. <div>
  319. <h2>
  320. {{ this.deleteGroupArray.name }}
  321. </h2>
  322. <div style="color: rgb(171 171 171); margin-top: 10px">
  323. 请选择要删除的组员
  324. </div>
  325. <el-checkbox-group v-model="checkDeleteGroup">
  326. <el-checkbox style="display: flex; margin-top: 20px" v-for="(item, index) in deleteGroupUser"
  327. :label="item.userid" :key="index">{{ item.name }}</el-checkbox>
  328. </el-checkbox-group>
  329. </div>
  330. <span slot="footer" class="dialog-footer">
  331. <el-button @click="dialogVisibleDeleteGroup = false">取 消</el-button>
  332. <el-button type="primary" @click="deleteChair">确定</el-button>
  333. </span>
  334. </el-dialog>
  335. <el-dialog title="修改分组" :visible.sync="dialogVisibleUpdateGroup" :append-to-body="true" width="350px"
  336. :before-close="handleClose" class="dialog_diy">
  337. <div>
  338. <h2>
  339. {{ this.updateGroupUser.name }}
  340. </h2>
  341. <div style="color: rgb(171 171 171); margin-top: 10px">
  342. 请选择要进入的分组
  343. </div>
  344. <el-radio-group v-model="checkChair">
  345. <el-radio style="display: block; margin-top: 20px" v-for="(item, index) in updateGroupArray"
  346. :label="item.id" :key="index">{{ item.name }}</el-radio>
  347. </el-radio-group>
  348. </div>
  349. <span slot="footer" class="dialog-footer">
  350. <el-button @click="dialogVisibleUpdateGroup = false">取 消</el-button>
  351. <el-button type="primary" @click="updateChair">确定</el-button>
  352. </span>
  353. </el-dialog>
  354. <el-dialog title="添加组员" :visible.sync="dialogVisibleMember" :append-to-body="true" width="540px" height="80%"
  355. :before-close="handleClose" class="addNewPP" v-loading="loading">
  356. <div class="people">
  357. <div class="people_top">
  358. <div class="people_top_right">
  359. <div class="people_search">
  360. <el-input placeholder="搜索学生的姓名" v-model="searchTN" @keyup.enter.native="getStudent"></el-input>
  361. <div class="search_img" @click="getStudent">
  362. <img src="../../../../assets/icon/search.png" alt />
  363. </div>
  364. </div>
  365. </div>
  366. <div class="people_nav">选择成员</div>
  367. </div>
  368. <!-- <div class="t_j_box" style="
  369. padding: 20px 0 0 25px;
  370. width: calc(100% - 55px);
  371. margin-left: 25px;
  372. ">
  373. <span>姓名</span>
  374. <span>账号</span>
  375. </div> -->
  376. <!-- <el-checkbox-group v-model="checkboxList3" class="people_name" v-if="classJuri.length">
  377. <el-checkbox v-for="item in classJuri" :key="item.userid" :label="item.userid">
  378. <div class="t_j_box">
  379. <el-tooltip placement="top" :content="item.name ? item.name : '暂无姓名'">
  380. <span>{{ item.name ? item.name : "暂无姓名" }}</span>
  381. </el-tooltip>
  382. <el-tooltip placement="top" :content="item.username">
  383. <span>{{ item.username }}</span>
  384. </el-tooltip>
  385. </div>
  386. </el-checkbox>
  387. </el-checkbox-group> -->
  388. <div class="i_box_login2" v-if="classJuri.length">
  389. <div :class="{ active: checkboxList3.indexOf(item.userid) != -1 }" v-for="item in classJuri"
  390. :key="item.userid" :label="item.userid" @click="addGroupUser(item.userid)">
  391. <el-tooltip placement="top" :content="item.name ? item.name : '暂无姓名'">
  392. <span>{{ item.name ? item.name : "暂无姓名" }}</span>
  393. </el-tooltip>
  394. </div>
  395. </div>
  396. <div style="text-align: center; margin-top: 10px" v-else>暂无数据</div>
  397. </div>
  398. <!-- <div style="margin-top: 10px;">
  399. <el-pagination background layout="prev, pager, next" :page-size="pageSize" :total="total"
  400. v-if="page && classJuri.length" style="padding-bottom: 20px"
  401. @current-change="handleCurrentChange"></el-pagination>
  402. </div> -->
  403. <span slot="footer" class="dialog-footer">
  404. <el-button @click="dialogVisibleMember = false">取 消</el-button>
  405. <el-button type="primary" @click="joinGroup2">确定</el-button>
  406. </span>
  407. </el-dialog>
  408. </div>
  409. </template>
  410. <script>
  411. export default {
  412. props: ['cid', 'classList', 'courseDetail', 'userid', "type", "classId", "oid", "people"],
  413. data() {
  414. return {
  415. groupJson2: {},
  416. classid: "1",
  417. groupid: "",
  418. gid: "",
  419. groupJson: {
  420. group: [],
  421. number: undefined,
  422. islock: 1,
  423. },
  424. islock: false,
  425. isopen: true,
  426. timer: null,
  427. groupStudent: {},
  428. groupStudentUid: {},
  429. allGroupStudentUid: [],
  430. dialogVisibleGroup2: false,
  431. checkDeleteGroup: [],
  432. deleteGroupUser: [],
  433. deleteGroupArray: [],
  434. dialogVisibleDeleteGroup: false,
  435. checkChair: "",
  436. updateGroupArray: [],
  437. updateGroupUser: {},
  438. dialogVisibleUpdateGroup: false,
  439. classJuri: [],
  440. checkboxList3: [],
  441. pageSize: 20,
  442. total: 0,
  443. page: 1,
  444. dialogVisibleMember: false,
  445. searchTN: "",
  446. loading: false,
  447. }
  448. },
  449. methods: {
  450. handleClose2(done) {
  451. this.$emit('update:dialogVisibleGroup', false)
  452. done();
  453. },
  454. handleClose(done) {
  455. done();
  456. },
  457. getStudent() {
  458. this.page = 1
  459. this.selectCStudent();
  460. },
  461. handleCurrentChange(val) {
  462. this.page = val;
  463. this.selectCStudent();
  464. },
  465. selectCStudent() {
  466. // let params = {
  467. // cid: this.classid,
  468. // oid: this.oid,
  469. // cn: this.searchTN,
  470. // };
  471. // this.ajax
  472. // .get(this.$store.state.api + "selectSnameByCidGroup", params)
  473. // .then((res) => {
  474. // if (res.data && res.data[0].length) {
  475. // this.classJuri = res.data[0].filter((el) => {
  476. // return this.allGroupStudentUid.indexOf(el.userid) == -1
  477. // });
  478. // }
  479. // })
  480. // .catch((err) => {
  481. // console.error(err);
  482. // });
  483. this.loading = true
  484. let _user = JSON.parse(JSON.stringify(this.people));
  485. if (_user.indexOf(this.userid) == -1) {
  486. _user.push(this.userid);
  487. }
  488. // if(_user.indexOf(this.courseDetail.userid) == -1){
  489. // _user.push(this.courseDetail.userid);
  490. // }
  491. if(_user.indexOf(this.courseDetail.userid) !== -1){
  492. _user.splice(_user.indexOf(this.courseDetail.userid), 1);
  493. }
  494. let params = {
  495. uid: _user.join(","),
  496. };
  497. this.ajax
  498. .get(this.$store.state.api + "getAllUserById", params)
  499. .then((res) => {
  500. this.loading = false
  501. if (res.data && res.data[0].length) {
  502. this.classJuri = res.data[0].filter((el) => {
  503. return this.allGroupStudentUid.indexOf(el.userid) == -1
  504. });
  505. }
  506. })
  507. .catch((err) => {
  508. this.loading = false
  509. console.error(err);
  510. });
  511. },
  512. setClassid(cid) {
  513. this.classid = cid
  514. this.groupid = ''
  515. this.groupJson = {
  516. group: [],
  517. number: undefined,
  518. islock: 1,
  519. }
  520. this.islock = false
  521. this.isopen = true
  522. this.getCourseGroup();
  523. },
  524. guid() {
  525. var _num,
  526. i,
  527. _guid = "";
  528. for (i = 0; i < 32; i++) {
  529. _guid += Math.floor(Math.random() * 16).toString(16); //随机0 - 16 的数字 转变为16进制的字符串
  530. _num = Math.floor((i - 7) / 4); //计算 (i-7)除4
  531. if (_num > -1 && _num < 4 && i == 7 + 4 * _num) {
  532. //会使guid中间加 "-" 形式为xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx
  533. _guid += "-";
  534. }
  535. }
  536. return _guid;
  537. },
  538. updateGroup() {
  539. this.groupJson2 = JSON.parse(JSON.stringify(this.groupJson));
  540. if (!this.groupJson2.group.length) {
  541. this.groupJson2.group.push({
  542. name: "第" + (this.groupJson2.group.length + 1) + "组",
  543. id: this.guid()
  544. });
  545. }
  546. this.dialogVisibleGroup2 = true;
  547. },
  548. deleteCourseGroup() {
  549. this.$confirm(
  550. // "您确定要删除该分组吗? 分组删除后将被清空并且无法恢复。",
  551. "是否确定删除已有分组?删除后分组数据将被清空!",
  552. "提示",
  553. {
  554. confirmButtonText: "确定",
  555. cancelButtonText: "取消",
  556. type: "warning",
  557. }
  558. )
  559. .then(() => {
  560. let params = [{
  561. gid: this.groupid,
  562. }];
  563. this.ajax
  564. .post(this.$store.state.api + "deleteCourseGroup", params)
  565. .then((res) => {
  566. this.groupJson = {
  567. group: [],
  568. number: undefined,
  569. islock: 1,
  570. }
  571. this.islock = false
  572. this.isopen = true
  573. this.$message.success("操作成功");
  574. this.getCourseGroup();
  575. this.$forceUpdate()
  576. })
  577. .catch((err) => {
  578. console.error(err);
  579. });
  580. })
  581. .catch(() => { });
  582. },
  583. addGroup() {
  584. this.groupJson2.group.push({
  585. name: "第" + (this.groupJson2.group.length + 1) + "组",
  586. id: this.guid()
  587. });
  588. },
  589. deleteGroup(i) {
  590. this.groupJson2.group.splice(i, 1);
  591. },
  592. lockChair() {
  593. this.groupJson2 = JSON.parse(JSON.stringify(this.groupJson));
  594. if (this.groupJson2.isopen == 2) {
  595. this.$message.error("请开启分组后才能开放选座")
  596. this.islock = false
  597. return
  598. } else {
  599. this.groupJson2.islock = this.groupJson2.islock == 1 ? 2 : 1;
  600. }
  601. this.updateGroupJson();
  602. },
  603. numberPan() {
  604. if (/[^\d]/.test(this.groupJson2.number) || this.groupJson2.number < 2 || this.groupJson2.number > 10) {
  605. this.$message.error('请输入2-10的数字')
  606. this.groupJson2.number = ''
  607. }
  608. },
  609. openChair() {
  610. this.groupJson2 = JSON.parse(JSON.stringify(this.groupJson));
  611. if (!this.groupJson2.isopen) {
  612. this.groupJson2.isopen = 2;
  613. } else {
  614. this.groupJson2.isopen = this.groupJson2.isopen == 1 ? 2 : 1;
  615. }
  616. if (this.groupJson2.isopen == 2) {
  617. this.groupJson2.islock = 2
  618. } else {
  619. this.groupJson2.islock = 1
  620. }
  621. this.updateGroupJson();
  622. },
  623. updateGroupJson(type) {
  624. for (var i = 0; i < this.groupJson2.group.length; i++) {
  625. if (!this.groupJson2.group[i].name) {
  626. this.$message.error("请将信息填写完整!");
  627. return;
  628. }
  629. }
  630. if (!this.groupJson2.number) {
  631. this.$message.error("请将信息填写完整!");
  632. return;
  633. }
  634. for (var i = 0; i < this.groupJson2.group.length; i++) {
  635. if (
  636. this.groupStudentUid[this.groupJson2.group[i].id] && this.groupStudentUid[this.groupJson2.group[i].id].length >
  637. this.groupJson2.number
  638. ) {
  639. this.$message.error("已经有小组比你设置的人数多,请重新设置");
  640. return;
  641. }
  642. }
  643. let params = [
  644. {
  645. cid: this.cid,
  646. group: JSON.stringify(this.groupJson2).replaceAll(/%/g, "%25"),
  647. classid: this.classid,
  648. },
  649. ];
  650. this.ajax
  651. .post(this.$store.state.api + "setCourseGroup", params)
  652. .then((res) => {
  653. if (this.groupJson2.isopen == 1) {
  654. if (type == 2) {
  655. this.$message.success("设置成功");
  656. } else {
  657. this.$message.success("开启分组成功");
  658. }
  659. } else if (this.groupJson2.isopen == 2) {
  660. this.$message.success("关闭分组成功");
  661. }
  662. // 开启分组成功/关闭分组成功
  663. this.dialogVisibleGroup2 = false;
  664. this.groupJson2 = {};
  665. this.getCourseGroup();
  666. this.$forceUpdate();
  667. })
  668. .catch((err) => {
  669. this.$message.error("网络不佳");
  670. console.error(err);
  671. });
  672. },
  673. getCourseGroup(gid) {
  674. let params = {
  675. cid: this.cid,
  676. classid: this.classid,
  677. };
  678. this.ajax
  679. .get(this.$store.state.api + "getCourseGroup", params)
  680. .then((res) => {
  681. if (res.data && res.data[0].length) {
  682. this.groupJson = JSON.parse(res.data[0][0].group);
  683. this.islock = this.groupJson.islock == 1 ? true : false;
  684. if (!this.groupJson.isopen) {
  685. this.isopen = true
  686. } else {
  687. this.isopen = this.groupJson.isopen == 1 ? true : false;
  688. }
  689. this.groupid = res.data[0][0].id;
  690. let groupPerson = res.data[1]
  691. let group = JSON.parse(res.data[0][0].group).group
  692. let groupStudent = {}
  693. let groupStudentUid = {}
  694. for (var i = 0; i < group.length; i++) {
  695. groupStudent[group[i].id] = []
  696. groupStudentUid[group[i].id] = []
  697. for (var j = 0; j < groupPerson.length; j++) {
  698. if (groupPerson[j].groupCid == group[i].id) {
  699. groupStudent[group[i].id].push(groupPerson[j])
  700. groupStudentUid[group[i].id].push(groupPerson[j].userid)
  701. }
  702. }
  703. }
  704. this.allGroupStudentUid = []
  705. for (var j = 0; j < groupPerson.length; j++) {
  706. this.allGroupStudentUid.push(groupPerson[j].userid)
  707. }
  708. this.groupStudent = groupStudent
  709. this.groupStudentUid = groupStudentUid
  710. this.$forceUpdate();
  711. if (gid) {
  712. this.joinGroup(gid)
  713. }
  714. }
  715. })
  716. .catch((err) => {
  717. this.$message.error("网络不佳");
  718. console.error(err);
  719. });
  720. },
  721. updateGroupChair(user) {
  722. this.updateGroupArray = this.groupJson.group.filter((el, index) => {
  723. el.label = index;
  724. return el.id != user.groupCid;
  725. });
  726. this.updateGroupUser = user;
  727. this.dialogVisibleUpdateGroup = true;
  728. },
  729. updateChair() {
  730. if (
  731. this.groupStudent[this.checkChair].length >
  732. this.groupJson.number ||
  733. this.groupStudent[this.checkChair].length ==
  734. this.groupJson.number
  735. ) {
  736. this.$message.error("位置已满,无法加入");
  737. return;
  738. }
  739. let params = [
  740. {
  741. gid: this.groupid,
  742. g: this.checkChair,
  743. uid: this.updateGroupUser.userid,
  744. },
  745. ];
  746. this.ajax
  747. .post(this.$store.state.api + "joinCourseGroup", params)
  748. .then((res) => {
  749. this.$message.success("修改成功");
  750. this.updateGroupUser = {};
  751. this.checkChair = "";
  752. this.updateGroupArray = {};
  753. this.dialogVisibleUpdateGroup = false;
  754. this.getCourseGroup();
  755. })
  756. .catch((err) => {
  757. this.$message.error("网络不佳");
  758. console.error(err);
  759. });
  760. },
  761. deleteGroupChair(gid, gindex) {
  762. this.checkDeleteGroup = [];
  763. this.deleteGroupUser = JSON.parse(
  764. JSON.stringify(this.groupStudent[gid])
  765. );
  766. this.deleteGroupArray = this.groupJson.group[gindex];
  767. this.gid = gid;
  768. this.dialogVisibleDeleteGroup = true;
  769. },
  770. async deleteChair() {
  771. for (let i = 0; i < this.checkDeleteGroup.length; i++) {
  772. const gid =
  773. this.groupStudent[this.gid][
  774. this.groupStudentUid[this.gid].indexOf(
  775. this.checkDeleteGroup[i]
  776. )
  777. ];
  778. let params = [
  779. {
  780. gid: gid.id,
  781. },
  782. ];
  783. var a = await this.deleteChairA(params);
  784. if (i == this.checkDeleteGroup.length - 1) {
  785. this.$message.success("退出成功");
  786. this.dialogVisibleDeleteGroup = false;
  787. this.deleteGroupUser = [];
  788. this.deleteGroupArray = {};
  789. this.gid = "";
  790. this.checkDeleteGroup = [];
  791. this.getCourseGroup();
  792. }
  793. }
  794. },
  795. deleteChairA(params) {
  796. return new Promise((resolve, reject) => {
  797. this.ajax
  798. .post(this.$store.state.api + "exitCourseGroup", params)
  799. .then((res) => {
  800. resolve(1);
  801. })
  802. .catch((err) => {
  803. this.$message.error("网络不佳");
  804. console.error(err);
  805. });
  806. });
  807. },
  808. selectGroup(gid) {
  809. this.getCourseGroup(gid)
  810. },
  811. joinGroup(gid) {
  812. if (this.groupJson.islock == 2) {
  813. this.$message.error("位置已被锁定,无法加入");
  814. return;
  815. }
  816. if (
  817. this.groupStudent[gid].length >
  818. this.groupJson.number ||
  819. this.groupStudent[gid].length == this.groupJson.number
  820. ) {
  821. this.$message.error("位置已满,无法加入");
  822. return;
  823. }
  824. let params = [
  825. {
  826. gid: this.groupid,
  827. g: gid,
  828. uid: this.userid,
  829. },
  830. ];
  831. this.ajax
  832. .post(this.$store.state.api + "joinCourseGroup", params)
  833. .then((res) => {
  834. this.$message.success("加入成功");
  835. this.$emit('getGroup')
  836. this.getCourseGroup();
  837. })
  838. .catch((err) => {
  839. this.$message.error("网络不佳");
  840. console.error(err);
  841. });
  842. },
  843. addGroupUser(uid) {
  844. if (this.checkboxList3.indexOf(uid) == -1) {
  845. this.checkboxList3.push(uid)
  846. } else {
  847. this.checkboxList3.splice(this.checkboxList3.indexOf(uid), 1)
  848. }
  849. },
  850. async joinGroup2() {
  851. if (
  852. this.groupStudent[this.gid].length + this.checkboxList3.length >
  853. this.groupJson.number
  854. ) {
  855. this.$message.error("位置已满,无法加入");
  856. return;
  857. }
  858. for (let i = 0; i < this.checkboxList3.length; i++) {
  859. let params = [
  860. {
  861. gid: this.groupid,
  862. g: this.gid,
  863. uid: this.checkboxList3[i],
  864. },
  865. ];
  866. const res = await this.ajax.post(this.$store.state.api + "joinCourseGroup", params)
  867. if (i == this.checkboxList3.length - 1) {
  868. this.$message.success("加入成功");
  869. this.dialogVisibleMember = false
  870. this.getCourseGroup();
  871. }
  872. }
  873. },
  874. exitGroup(id) {
  875. if (this.groupJson.islock == 2) {
  876. this.$message.error("位置已被锁定,无法退出");
  877. return;
  878. }
  879. let params = [
  880. {
  881. gid: id,
  882. },
  883. ];
  884. this.ajax
  885. .post(this.$store.state.api + "exitCourseGroup", params)
  886. .then((res) => {
  887. this.$message.success("退出成功");
  888. this.$emit('getGroup')
  889. this.getCourseGroup();
  890. })
  891. .catch((err) => {
  892. this.$message.error("网络不佳"); s
  893. console.error(err);
  894. });
  895. },
  896. addGroupStudent(groupid) {
  897. this.gid = groupid
  898. this.page = 1
  899. this.searchTN = ""
  900. this.checkboxList3 = []
  901. this.selectCStudent()
  902. this.getCourseGroup();
  903. this.dialogVisibleMember = true
  904. }
  905. },
  906. watch: {
  907. },
  908. beforeDestory() {
  909. clearInterval(this.timer)
  910. this.timer = null
  911. },
  912. mounted() {
  913. if (this.classList.length) {
  914. if (this.type == 2) {
  915. this.classList = this.classList.filter(el => {
  916. return this.classId.indexOf(el.id) != -1
  917. })
  918. this.classid = this.classList[0].id
  919. } else {
  920. this.classid = this.classList[0].id
  921. }
  922. } else {
  923. this.classid = '1'
  924. }
  925. this.setClassid(this.classid)
  926. this.getCourseGroup();
  927. // if (this.dialogVisibleGroup) {
  928. // this.getCourseGroup();
  929. this.timer = setInterval(() => {
  930. this.getCourseGroup();
  931. }, 5000)
  932. // } else {
  933. // clearInterval(this.timer)
  934. // this.timer = null
  935. // }
  936. }
  937. }
  938. </script>
  939. <style scoped>
  940. .dialog_diy>>>.el-dialog {
  941. margin-top: 10vh !important;
  942. }
  943. .dialog_diy>>>.el-dialog__header {
  944. background: #454545 !important;
  945. padding: 15px 20px;
  946. }
  947. .dialog_diy>>>.el-dialog__title {
  948. color: #fff;
  949. }
  950. .dialog_diy>>>.el-dialog__headerbtn {
  951. top: 19px;
  952. }
  953. .dialog_diy>>>.el-dialog__headerbtn .el-dialog__close {
  954. color: #fff;
  955. }
  956. .dialog_diy>>>.el-dialog__headerbtn .el-dialog__close:hover {
  957. color: #fff;
  958. }
  959. .dialog_diy>>>.el-dialog__body,
  960. .dialog_diy>>>.el-dialog__footer {
  961. background: #fafafa;
  962. }
  963. .group_workBox {}
  964. .group_workBox+.group_workBox {
  965. margin-top: 20px;
  966. }
  967. .group_box {
  968. padding-bottom: 20px;
  969. border-bottom: 2px solid #f0f0f0;
  970. }
  971. .group_title {
  972. display: flex;
  973. align-items: center;
  974. justify-content: space-between;
  975. }
  976. .group_name {
  977. background-image: url(../../../../assets/icon/groupN.png);
  978. width: 220px;
  979. background-size: 100% 100%;
  980. height: 67px;
  981. padding: 0 20px 0 43px;
  982. box-sizing: border-box;
  983. line-height: 63px;
  984. color: #fff;
  985. overflow: hidden;
  986. white-space: nowrap;
  987. text-overflow: ellipsis;
  988. }
  989. .group_work {
  990. width: 100%;
  991. padding: 0 10px;
  992. box-sizing: border-box;
  993. display: flex;
  994. flex-wrap: wrap;
  995. }
  996. .g_d_box {
  997. display: flex;
  998. flex-flow: wrap;
  999. justify-content: space-around;
  1000. }
  1001. .g_d_box .isChair {
  1002. background-image: url(../../../../assets/avatar.png) !important;
  1003. }
  1004. .g_d_group {
  1005. width: 500px;
  1006. margin-bottom: 80px;
  1007. }
  1008. .g_d_group_chair {
  1009. display: flex;
  1010. align-items: center;
  1011. justify-content: center;
  1012. }
  1013. .g_d_group_chair>div+div {
  1014. margin-left: 30px;
  1015. }
  1016. .g_d_group_chair>div,
  1017. .g_d_group_chair2>div {
  1018. display: flex;
  1019. flex-direction: column;
  1020. align-items: center;
  1021. }
  1022. .g_d_group_chair>div>span:nth-child(1),
  1023. .g_d_group_chair2>div>span:nth-child(1) {
  1024. background-image: url(../../../../assets/icon/chair.png);
  1025. width: 50px;
  1026. height: 50px;
  1027. display: block;
  1028. background-size: 100% 100%;
  1029. }
  1030. .g_d_group_tableBox {
  1031. display: flex;
  1032. align-items: center;
  1033. justify-content: center;
  1034. }
  1035. .g_d_group_chair2 {
  1036. display: flex;
  1037. flex-direction: column;
  1038. align-items: center;
  1039. justify-content: center;
  1040. }
  1041. .g_d_group_chair2>div+div {
  1042. margin-top: 10px;
  1043. }
  1044. .g_d_group_table {
  1045. background-image: url(../../../../assets/icon/groupBg.png);
  1046. width: 354px;
  1047. height: 196px;
  1048. background-size: 100% 100%;
  1049. display: flex;
  1050. align-items: center;
  1051. justify-content: center;
  1052. flex-direction: column;
  1053. color: #fff;
  1054. }
  1055. .g_d_group_table>div:nth-child(1) {
  1056. font-size: 24px;
  1057. margin-bottom: 5px;
  1058. }
  1059. .g_d_group_table>div:nth-child(2) div {
  1060. cursor: pointer;
  1061. background: #2e77bf;
  1062. padding: 4px 10px;
  1063. border-radius: 5px;
  1064. }
  1065. .groupBox {}
  1066. .groupContent+.groupContent {
  1067. margin-top: 30px;
  1068. }
  1069. .groupTitle {
  1070. font-size: 24px;
  1071. color: rgb(80, 80, 80);
  1072. margin-bottom: 20px;
  1073. }
  1074. .groupName {
  1075. display: flex;
  1076. align-items: center;
  1077. }
  1078. .groupn {
  1079. font-size: 15px;
  1080. margin-right: 10px;
  1081. }
  1082. .groupName+.groupName {
  1083. margin-top: 15px;
  1084. }
  1085. .groupBtn {
  1086. margin-left: 10px;
  1087. }
  1088. .groupContent>>>.el-input-number.is-without-controls .el-input__inner {
  1089. text-align: left;
  1090. }
  1091. .g_d_btnBox {
  1092. display: flex;
  1093. justify-content: space-between;
  1094. align-items: flex-end;
  1095. margin: 20px 0;
  1096. }
  1097. .btn_left {
  1098. display: flex;
  1099. margin-top: 20px;
  1100. padding: 0px 0 0 30px;
  1101. }
  1102. .btn_left>div {
  1103. cursor: pointer;
  1104. }
  1105. .btn_left>div+div {
  1106. margin-left: 10px;
  1107. }
  1108. .btn_left .active {
  1109. color: #3e88f4;
  1110. border-bottom: 2px solid #2f80f3;
  1111. padding: 0 0 5px;
  1112. }
  1113. .btn_right {
  1114. display: flex;
  1115. align-items: center;
  1116. }
  1117. .updateChair {
  1118. position: relative;
  1119. }
  1120. .updateChairBtn {
  1121. position: absolute;
  1122. width: 50px;
  1123. height: 50px;
  1124. overflow: hidden;
  1125. /* display: flex; */
  1126. align-items: center;
  1127. justify-content: center;
  1128. background: #00000087;
  1129. color: #fff;
  1130. border-radius: 50px;
  1131. display: none;
  1132. cursor: pointer;
  1133. }
  1134. .updateChair:hover .updateChairBtn {
  1135. display: flex;
  1136. }
  1137. .returnBtn {
  1138. background: #499eef;
  1139. width: 65px;
  1140. height: 30px;
  1141. color: #fff;
  1142. text-align: center;
  1143. line-height: 32px;
  1144. margin-right: 20px;
  1145. cursor: pointer;
  1146. border-radius: 5px;
  1147. font-size: 14px;
  1148. }
  1149. .addNewPP>>>.el-dialog__body {
  1150. padding: 5px 20px;
  1151. }
  1152. .people {
  1153. border: 1px solid rgb(229 229 229);
  1154. height: 495px;
  1155. border-radius: 5px;
  1156. width: 100%;
  1157. overflow: auto;
  1158. }
  1159. .people_top {
  1160. display: flex;
  1161. width: 100%;
  1162. /* justify-content: space-between; */
  1163. /* align-items: center; */
  1164. flex-direction: column;
  1165. padding: 10px 25px 0;
  1166. box-sizing: border-box;
  1167. }
  1168. .people_nav,
  1169. .people_top_right {
  1170. /* padding: 20px 0 0 20px; */
  1171. }
  1172. .people_top_right {
  1173. height: 40px;
  1174. margin-bottom: 10px;
  1175. }
  1176. .people_search {
  1177. display: flex;
  1178. position: relative;
  1179. }
  1180. .people_search>>>.el-input__inner {
  1181. /* height: 25px; */
  1182. width: 100%;
  1183. }
  1184. .search_img {
  1185. width: 20px;
  1186. height: 20px;
  1187. position: absolute;
  1188. right: 10px;
  1189. top: 50%;
  1190. transform: translateY(-50%);
  1191. }
  1192. .search_img>img {
  1193. width: 100%;
  1194. height: 100%;
  1195. }
  1196. .people_name {
  1197. display: flex;
  1198. justify-content: flex-start;
  1199. padding: 10px 0 0 25px;
  1200. flex-direction: column;
  1201. flex-wrap: nowrap;
  1202. height: calc(100% - 140px);
  1203. overflow-y: auto;
  1204. overflow-x: hidden;
  1205. flex-direction: column;
  1206. }
  1207. .people_name>>>.el-checkbox {
  1208. width: 100%;
  1209. display: flex;
  1210. align-items: center;
  1211. margin-bottom: 10px;
  1212. }
  1213. .people_name>>>.el-checkbox__label {
  1214. text-overflow: ellipsis;
  1215. overflow: hidden;
  1216. width: 100%;
  1217. }
  1218. .t_j_box {
  1219. display: flex;
  1220. }
  1221. .t_j_box span:nth-child(1) {
  1222. width: 50%;
  1223. overflow: hidden;
  1224. margin-right: 10px;
  1225. text-overflow: ellipsis;
  1226. white-space: nowrap;
  1227. }
  1228. .t_j_box span:nth-child(2) {
  1229. width: 50%;
  1230. overflow: hidden;
  1231. margin-right: 10px;
  1232. text-overflow: ellipsis;
  1233. white-space: nowrap;
  1234. }
  1235. .i_box_login2 {
  1236. height: calc(100% - 80px);
  1237. width: 100%;
  1238. display: flex;
  1239. flex-wrap: wrap;
  1240. overflow: auto;
  1241. padding-bottom: 10px;
  1242. box-sizing: border-box;
  1243. align-content: flex-start;
  1244. padding: 10px 25px 0;
  1245. }
  1246. .i_box_login2>div {
  1247. cursor: pointer;
  1248. width: 80px;
  1249. text-align: center;
  1250. height: 30px;
  1251. line-height: 30px;
  1252. padding: 0 5px;
  1253. overflow: hidden;
  1254. background: rgb(225, 237, 255);
  1255. margin: 10px calc((100% - (80px*5)) / 4) 0 0;
  1256. color: rgb(37 124 255);
  1257. border-radius: 5px;
  1258. box-sizing: border-box;
  1259. }
  1260. .i_box_login2>div:nth-child(5n) {
  1261. margin: 10px 0 0 0;
  1262. }
  1263. .i_box_login2>.active {
  1264. background: rgb(92, 157, 255);
  1265. color: #fff;
  1266. }
  1267. .i_box_login2>div>span {
  1268. width: 100%;
  1269. overflow: hidden;
  1270. white-space: nowrap;
  1271. text-overflow: ellipsis;
  1272. display: block;
  1273. }
  1274. .group_switch {
  1275. margin-right: 10px;
  1276. height: 30px;
  1277. display: flex;
  1278. align-items: center;
  1279. }
  1280. .group_switch>span {
  1281. margin-right: 5px;
  1282. }
  1283. </style>