import React,{ Component } from "react";
import { Input,Checkbox,Menu,Pagination,Spin} from "antd";
import CourseLayoutcomponent from '../common/CourseLayoutComponent';
import UseBank from './UseBank'
import '../css/members.css'
import '../css/busyWork.css'
import CoursesListType from '../coursesPublic/CoursesListType'
import CommonWorkItem from './CommonWorkItem'
import PublishRightnow from './PublishRightnow'
import ConnectProject from './ConnectProject'
import { WordsBtn } from 'educoder'
import Modals from '../../modals/Modals'
import NoneData from "../coursesPublic/NoneData"
import Titlesearchsection from '../common/titleSearch/TitleSearchSection';
import { RouteHOC } from './common'
import axios from 'axios';
import _ from 'lodash'
const Search = Input.Search;
const map={1:"普通作业",2:"",3:"分组作业"}
const COMMON_WORK = 1
// const COMMON_WORK = 2
class commonWork extends Component{
constructor(props){
super(props);
this.state={
modalsType:"",
modalsTopval:"",
modalsBottomval:"",
modalCancel:"",
mainList:undefined,
order:"",
page:1,
search:"",
totalCount:0,
checkAll:false,
checkBoxValues:[],
isSpin:false
}
}
//输入搜索条件
inputStudent=(e)=>{
this.setState({
search:e.target.value,
page:1
})
}
//搜索查询
searchStudent=()=>{
let {page,search,order}=this.state;
this.getList(page,search,order);
}
openConnectionProject = (work) => {
this.refs['connectProject'].openConnectionProject(work)
}
// 新建
createCommonWork=(type)=>{
this.props.toNewPage(this.props.match.params)
}
cancelDelClasses=()=>{
this.setState({
modalsType:false,
modalsTopval:"",
modalsBottomval:"",
modalCancel:false
})
}
sureDelClasses(){
}
componentDidUpdate(prevProps, prevState) {
if (prevProps.match.path != this.props.match.path) {
this.componentDidMount()
}
}
componentDidMount(){
this.setState({
isSpin:true
})
let {page,search,order}=this.state;
this.getList(page,search,order);
}
useBankSuccess = (checkBoxValues, newWorkIdArray) => {
this.setState({
page:1,
checkBoxValues: newWorkIdArray
}, () => {
this.refs['publishModalRef'].open()
})
let {search, order}=this.state;
this.getList(1, search, order);
}
getList=(page,search,order)=>{
this.setState({
isSpin:true
})
let id=this.props.match.params.coursesId;
let workType = this.props.getModuleType()
let url="/courses/"+id+"/homework_commons.json?type="+workType+"&page="+page;
if(order!=""){
url+="&order="+order;
}
if(search!=""){
url+="&search="+search;
}
axios.get((url)).then((result)=>{
if(result.status==200){
this.setState({
mainList:result.data,
totalCount:result.data.task_count,
isSpin:false,
...result.data
})
}
}).catch((error)=>{
console.log(error);
})
}
//筛选条件
selectedStatus=(e)=>{
this.setState({
order:e.key==="all"?"":e.key,
page:1,
isSpin:true
})
let {search}=this.state;
this.getList(1,search,e.key==="all"?"":e.key);
}
onPageChange=(pageNumber)=>{
this.setState({
page:pageNumber
})
let {search,order}=this.state;
this.getList(pageNumber,search,order);
}
// 全选和反选
changeAll=(e)=>{
this.setState({
checkAll: e.target.checked
})
const valueId=this.state.mainList.homeworks.map(item=>{
return item.homework_id
})
if (e.target.checked) {
const concated = this.state.checkBoxValues.concat(valueId);
const sortedUniqed = _.uniq(concated)
this.setState({
checkBoxValues: sortedUniqed
})
} else {
this.setState({
checkBoxValues: _.difference(this.state.checkBoxValues, valueId)
})
}
}
onChangeSelect=(checkedValues)=>{
this.setState({
checkBoxValues: checkedValues,
checkAll: checkedValues.length == this.state.mainList.homeworks.length
})
}
onWorkDelete = () => {
const { checkBoxValues } = this.state;
const len = checkBoxValues.length;
if (len == 0) {
this.props.showNotification('请先选择要删除的作业')
return;
}
this.props.confirm({
// content: `确认要删除所选的${len}个作业吗?`,
content:
,
onOk: () => {
let coursesId=this.props.match.params.coursesId;
const url = `/courses/${coursesId}/homework_commons/multi_destroy.json`
axios.post(url, {
homework_ids: checkBoxValues,
all_check: 0,
// group_ids
}).then((response) => {
if (response.data.status == 0) {
this.props.showNotification('删除成功')
this.clearSelection()
let {search,order}=this.state;
this.getList(1,search,order);
this.props.updataleftNavfun()
}
console.log(response)
}).catch((error) => {
console.log(error)
})
}
})
}
clearSelection = () => {
this.setState({ checkBoxValues: [] })
}
//
onSetPublic = () => {
const { checkBoxValues } = this.state;
const len = checkBoxValues.length;
if (len == 0) {
this.props.showNotification('请先选择要公开的作业')
return;
}
this.props.confirm({
content:
设为公开后,非课堂成员也可以访问查看
是否确认设为公开?
,
onOk: () => {
let coursesId=this.props.match.params.coursesId;
const url = `/courses/${coursesId}/homework_commons/set_public.json`
axios.post(url, {
homework_ids: checkBoxValues,
all_check: 0
}).then((response) => {
if (response.data.status == 0) {
this.props.showNotification('设为公开操作成功')
let {search,order, page}=this.state;
this.getList(page,search,order);
}
console.log(response)
}).catch((error) => {
console.log(error)
})
}
})
}
doWhenSuccess = () => {
let {search,order, page}=this.state;
this.getList(page,search,order);
this.setState({
checkBoxValues:[]
})
}
onItemClick = (item) => {
const checkBoxValues = this.state.checkBoxValues.slice(0);
const index = checkBoxValues.indexOf(item.id);
if (index != -1) {
_.remove(checkBoxValues, (listItem)=> listItem === item.id)
} else {
checkBoxValues.push(item.id)
}
this.onChangeSelect(checkBoxValues)
}
addToBank = () => {
const { checkBoxValues } = this.state;
const len = checkBoxValues.length;
if (len == 0) {
this.props.showNotification('请先选择要加入题库的作业')
return;
}
const coursesId = this.props.match.params.coursesId
const url = `/courses/${coursesId}/homework_commons/add_to_homework_bank.json`
axios.post(url, {
homework_ids: checkBoxValues,
all_check: 0
}).then((response) => {
if (response.data.status == 0) {
this.props.showNotification('加入成功')
let {search,order}=this.state;
this.getList(1,search,order);
}
console.log(response)
}).catch((error) => {
console.log(error)
})
}
connectSuccess = () => {
let {page,search,order}=this.state;
this.getList(page,search,order);
}
cancelConnectionProject = (work) => {
let workId=this.props.match.params.workId;
let courseId=this.props.match.params.coursesId;
const url = `/homework_commons/${work.homework_id}/student_works/cancel_relate_project.json`
axios.get(url).then((response)=> {
if (response.data.status == 0) {
let {page,search,order}=this.state;
this.getList(page,search,order);
this.props.showNotification('取消关联成功')
}
}).catch((error)=>{
console.log(error)
})
}
render(){
let {
search,
page,
modalsType,
modalsTopval,
modalsBottomval,
mainList,
totalCount,
checkAll,
checkBoxValues,
task_count,
published_count,
unpublished_count,
main_category_name,
}=this.state;
const { coursedata } = this.props;
if (!coursedata) {
return ''
}
let workType = this.props.getModuleType()
const moduleChineseName = this.props.getModuleName(true)
const { course_public } = coursedata;
const isGroup = this.props.isGroup()
const isAdmin = this.props.isAdmin()
//
//
return(
{/*
{moduleChineseName}
*/}
{ isAdmin && this.createCommonWork(1)}>新建}
{ isAdmin &&
}
}
secondRowBotton={
}
secondRowLeft={
共 {mainList&&mainList.all_count} 个作业
已发布:{published_count}个
{/* {this.props.isAdmin()?:""} */}
未发布:{unpublished_count}个
}
searchPlaceholder={"请输入名称进行搜索"}
showSearchInput={true}
>
{
mainList && mainList.course_identity < 5 && mainList.homeworks.length>0 &&
已选 {checkBoxValues.length} 个
{/* 设为公开 */}
}
{
mainList && mainList.homeworks && mainList.homeworks.length==0 &&
}
{
!!totalCount && totalCount > 15 &&
}
)
}
}
export default RouteHOC() (commonWork);