Merge branch 'dev_aliyun' of http://bdgit.educoder.net/Hjqreturn/educoder into dev_aliyun
commit
48334ee537
@ -0,0 +1,5 @@
|
||||
class AddCommitMethodToExerciseUser < ActiveRecord::Migration[5.2]
|
||||
def change
|
||||
add_column :exercise_users, :commit_method, :integer, :default => 0
|
||||
end
|
||||
end
|
@ -0,0 +1,72 @@
|
||||
import React, { useState, useEffect } from 'react'
|
||||
import { trigger, WordsBtn } from 'educoder'
|
||||
import { Input, Checkbox, Popconfirm } from "antd";
|
||||
import axios from 'axios'
|
||||
|
||||
/**
|
||||
角色数组, CREATOR: 创建者, PROFESSOR: 教师, ASSISTANT_PROFESSOR: 助教, STUDENT: 学生
|
||||
*/
|
||||
function ChangeRolePop({ member_roles = [], record, courseId, onChangeRoleSuccess, showNotification }) {
|
||||
const [checkBoxRoles, setCheckBoxRoles] = useState(member_roles)
|
||||
useEffect(() => {
|
||||
setCheckBoxRoles(member_roles)
|
||||
}, [member_roles])
|
||||
function onCheckBoxChange(val) {
|
||||
console.log(val)
|
||||
|
||||
const isTeacher = checkBoxRoles.indexOf('PROFESSOR')
|
||||
const isAssitant = checkBoxRoles.indexOf('ASSISTANT_PROFESSOR')
|
||||
const isTeacherNew = val.indexOf('PROFESSOR')
|
||||
const isAssitantNew = val.indexOf('ASSISTANT_PROFESSOR')
|
||||
if (isTeacherNew > -1 && isTeacher == -1 && isAssitantNew > -1) {
|
||||
val.splice(isAssitantNew, 1)
|
||||
}
|
||||
if (isAssitantNew > -1 && isAssitant == -1 && isTeacherNew > -1) {
|
||||
val.splice(isTeacherNew, 1)
|
||||
}
|
||||
|
||||
setCheckBoxRoles(val)
|
||||
}
|
||||
function onCancel() {
|
||||
setCheckBoxRoles(member_roles)
|
||||
}
|
||||
const onConfirm = async () => {
|
||||
if (checkBoxRoles && checkBoxRoles.length == 0) {
|
||||
showNotification('请至少选择一个角色')
|
||||
return;
|
||||
}
|
||||
const url = `/courses/${courseId}/change_member_role.json`
|
||||
const response = await axios.post(url, {
|
||||
roles: checkBoxRoles,
|
||||
user_id: record.user_id
|
||||
})
|
||||
if (response.data.status == 0) {
|
||||
onChangeRoleSuccess()
|
||||
}
|
||||
console.log(response)
|
||||
}
|
||||
const isAdmin = checkBoxRoles.indexOf('CREATOR') != -1
|
||||
const isTeacher = checkBoxRoles.indexOf('PROFESSOR') != -1
|
||||
const isAssitant = checkBoxRoles.indexOf('ASSISTANT_PROFESSOR') != -1
|
||||
const isStudent = checkBoxRoles.indexOf('STUDENT') != -1
|
||||
return (
|
||||
<Popconfirm
|
||||
overlayClassName="changeRolePop"
|
||||
placement="bottom"
|
||||
icon={null}
|
||||
onConfirm={onConfirm}
|
||||
onCancel={onCancel}
|
||||
title={
|
||||
<Checkbox.Group style={{ width: '100%' }} onChange={onCheckBoxChange} value={checkBoxRoles}>
|
||||
{isAdmin && <Checkbox disabled={isAdmin} value="CREATOR">管理员</Checkbox>}
|
||||
{!isAdmin && <Checkbox value="PROFESSOR">教师</Checkbox>}
|
||||
<Checkbox disabled={isAdmin} value="ASSISTANT_PROFESSOR">助教</Checkbox>
|
||||
<Checkbox value="STUDENT">学生</Checkbox>
|
||||
</Checkbox.Group>
|
||||
}
|
||||
>
|
||||
<WordsBtn style={'blue'}>修改角色</WordsBtn>
|
||||
</Popconfirm>
|
||||
)
|
||||
}
|
||||
export default ChangeRolePop
|
@ -0,0 +1,3 @@
|
||||
.stu_table .ant-table-thead > tr > th, .stu_table .ant-table-tbody > tr > td {
|
||||
padding: 14px 6px;
|
||||
}
|
Loading…
Reference in new issue