Merge branch 'dev_aliyun' of https://bdgit.educoder.net/Hjqreturn/educoder into dev_aliyun

courseware
caicai8 5 years ago
commit 97c08b84c0

@ -238,7 +238,9 @@ module CoursesHelper
# 获取课堂的资源数 # 获取课堂的资源数
def get_attachment_count(course, category_id) def get_attachment_count(course, category_id)
category_id.to_i == 0 ? course.attachments.size : course.attachments.where(course_second_category_id: category_id).size identity = current_user.course_identity(course)
attachments = category_id.to_i == 0 ? course.attachments : course.attachments.where(course_second_category_id: category_id)
identity > Course::ASSISTANT_PROFESSOR ? attachments.published.size : attachments.size
end end
# 获取课堂的视频数 # 获取课堂的视频数

@ -26,7 +26,7 @@ module AliyunVod::Service::VideoManage
result result
end end
# 读取视频编码格式 # 读取视频编码格式与视频格式
def get_meta_code_info(video_id) def get_meta_code_info(video_id)
params = { params = {
Action: 'GetMezzanineInfo', Action: 'GetMezzanineInfo',
@ -36,11 +36,14 @@ module AliyunVod::Service::VideoManage
result = request(:post, params) result = request(:post, params)
Rails.logger.info("#######:#{result['Mezzanine']['VideoStreamList'][0]['CodecName']}") Rails.logger.info("#######:#{result['Mezzanine']['VideoStreamList'][0]['CodecName']}")
result['Mezzanine']['VideoStreamList'][0]['CodecName'] codecnamne = result['Mezzanine']['VideoStreamList'].first['CodecName']
file_url = result['Mezzanine']['FileURL']
format = file_url&.split(".")&.last
{codecnamne: codecnamne, format: format}
rescue => e rescue => e
Rails.logger.info "读取视频编码信息失败: #{video_id}, #{e.message}" Rails.logger.info "读取视频编码信息失败: #{video_id}, #{e.message}"
"" {codecnamne: "", format: ""}
end end
# 删除视频信息 # 删除视频信息

@ -24,6 +24,7 @@ class Attachment < ApplicationRecord
scope :simple_columns, -> { select(:id, :filename, :filesize, :created_on, :cloud_url, :author_id, :content_type, :container_type, :container_id) } scope :simple_columns, -> { select(:id, :filename, :filesize, :created_on, :cloud_url, :author_id, :content_type, :container_type, :container_id) }
scope :search_by_container, -> (ids) {where(container_id: ids)} scope :search_by_container, -> (ids) {where(container_id: ids)}
scope :unified_setting, -> {where("unified_setting = ? ", 1)} scope :unified_setting, -> {where("unified_setting = ? ", 1)}
scope :published, -> {where(is_publish: 1)}
validates_length_of :description, maximum: 100, message: "不能超过100个字符" validates_length_of :description, maximum: 100, message: "不能超过100个字符"

@ -29,12 +29,13 @@ class Videos::BatchPublishService < ApplicationService
video.status = "published" video.status = "published"
end end
# 标清转码为h264 # 非MP4 H264编码的都转码
code_info = AliyunVod::Service.get_meta_code_info(video.uuid) code_info = AliyunVod::Service.get_meta_code_info(video.uuid)
if code_info.present? && code_info.start_with?('h264', 'h265') Rails.logger.info("code_info: #{code_info[:format]}, #{code_info[:codecnamne]}")
if code_info[:format] == "mp4" && code_info[:codecnamne].present? && code_info[:codecnamne].start_with?('h264')
video.transcoded = true video.transcoded = true
result = AliyunVod::Service.get_play_info(video.uuid) rescue nil result = AliyunVod::Service.get_play_info(video.uuid) rescue nil
play_url = result['PlayInfoList']['PlayInfo'][0]['PlayURL'] if result.present? play_url = result['PlayInfoList']['PlayInfo'].first['PlayURL'] if result.present?
video.play_url = play_url video.play_url = play_url
else else
AliyunVod::Service.submit_transcode_job(video.uuid, Video::NORMAL_TRANSCODE_GROUP_ID) AliyunVod::Service.submit_transcode_job(video.uuid, Video::NORMAL_TRANSCODE_GROUP_ID)

@ -3,7 +3,7 @@ namespace :video_transcode do
desc "视频转码成h264" desc "视频转码成h264"
task :submit => :environment do task :submit => :environment do
Video.find_each do |v| Video.find_each do |v|
if v.uuid && !v.transcoded && !v.file_url.include?('.mp4') && !AliyunVod::Service.get_meta_code_info(v.uuid).start_with?("h264", "h265") if v.uuid && !v.transcoded && !v.file_url.include?('.mp4') && !AliyunVod::Service.get_meta_code_info(v.uuid)[:codecnamne].start_with?("h264", "h265")
p "--- Start submit video trans code #{v.uuid}" p "--- Start submit video trans code #{v.uuid}"
AliyunVod::Service.submit_transcode_job(v.uuid, 'a0277c5c0c7458458e171b0cee6ebf5e') AliyunVod::Service.submit_transcode_job(v.uuid, 'a0277c5c0c7458458e171b0cee6ebf5e')
else else

@ -64,6 +64,7 @@ class Fileslists extends Component{
}); });
} }
componentDidMount=()=>{ componentDidMount=()=>{
this.getcourse_groupslists() this.getcourse_groupslists()
this.setState({ this.setState({
isSpin:true, isSpin:true,
@ -85,43 +86,45 @@ class Fileslists extends Component{
this.seactall(parseInt(this.props.match.params.Id),"desc") this.seactall(parseInt(this.props.match.params.Id),"desc")
} }
this.updadatalist(); this.updadatalist();
on('updateNavSuccess', this.updateNavSuccess) on('files', this.updateNavSuccess)
on('updateNavSuccess',this.updadatalist) on('files',this.updadatalist)
} }
updateNavSuccess=()=>{ updateNavSuccess=()=>{
let{sort}=this.state; let{sort}=this.state;
this.setState({ this.setState({
isSpin:true isSpin:true
}) })
if(this.props.match.params.main_id){ if(this.props.match.params.main_id){
this.seactall(undefined,sort); this.seactall(undefined,sort);
}else if(this.props.match.params.Id){ }else if(this.props.match.params.Id){
this.seactall(parseInt(this.props.match.params.Id),sort) this.seactall(parseInt(this.props.match.params.Id),sort)
} }
} }
componentDidUpdate = (prevProps) => { componentDidUpdate = (prevProps) => {
if(prevProps.coursesidtype!=this.props.coursesidtype||prevProps.match.params.main_id!=this.props.match.params.main_id||prevProps.match.params.Id!=this.props.match.params.Id){ if(prevProps.coursesidtype!=this.props.coursesidtype||prevProps.match.params.Id!=this.props.match.params.Id&&this.props.coursesidtype!="node") {
if(this.props.coursesidtype==="node") {
if(this.props.match.params.main_id){
this.getcourse_groupslists() this.getcourse_groupslists()
this.setState({ this.setState({
isSpin:true, isSpin: true,
checkBoxValues:[], checkBoxValues: [],
checkAllValue:false, checkAllValue: false,
}) })
if(this.props.match.params.main_id!=undefined){ if (this.props.match.params.main_id != undefined) {
this.setState({ this.setState({
child:false, child: false,
sort:"desc" sort: "desc"
}) })
this.seactall(undefined,"desc"); this.seactall(undefined, "desc");
} }
} }else{
if(this.props.match.params.Id){
this.getcourse_groupslists() this.getcourse_groupslists()
this.setState({ this.setState({
isSpin:true, isSpin:true,
@ -136,8 +139,12 @@ class Fileslists extends Component{
this.seactall(parseInt(this.props.match.params.Id),"desc") this.seactall(parseInt(this.props.match.params.Id),"desc")
} }
} }
} }
} }
updadatalist=(id)=>{ updadatalist=(id)=>{
@ -174,6 +181,7 @@ class Fileslists extends Component{
} }
updatafiled=()=>{ updatafiled=()=>{
let{sort}=this.state; let{sort}=this.state;
if(this.props.match.params.main_id){ if(this.props.match.params.main_id){
this.seactall(undefined,sort); this.seactall(undefined,sort);
@ -640,7 +648,7 @@ class Fileslists extends Component{
} }
Settingtypess=(id,title,link)=>{ Settingtypess=(id,title,link)=>{
debugger
this.setState({ this.setState({
Addanexternallink:true, Addanexternallink:true,
Exterchainname:"资源设置", Exterchainname:"资源设置",
@ -951,10 +959,12 @@ class Fileslists extends Component{
} }
secondRowLeft={ secondRowLeft={
<div style={{"display":"inline-block", "marginTop": "22px"}}> this.props.isAdmin()?<div style={{"display":"inline-block", "marginTop": "22px"}}>
<span> {total_count} 个资源</span> <span> {total_count} 个资源</span>
<span style={{"marginLeft":"16px"}}>已发布{publish_count}</span> <span style={{"marginLeft":"16px"}}>已发布{publish_count}</span>
<span style={{"marginLeft":"16px"}}>未发布{unpublish_count}</span> <span style={{"marginLeft":"16px"}}>未发布{unpublish_count}</span>
</div>:<div style={{"display":"inline-block", "marginTop": "22px"}}>
<span> {publish_count} 个资源</span>
</div> </div>
} }
onPressEnter={this.onPressEnter} onPressEnter={this.onPressEnter}

@ -775,7 +775,7 @@ class CommonWorkList extends Component{
const hasData = this.state.homework_status && this.state.homework_status.indexOf("未发布") == -1 // student_works && !!student_works.length && page == 1 && const hasData = this.state.homework_status && this.state.homework_status.indexOf("未发布") == -1 // student_works && !!student_works.length && page == 1 &&
console.log(StudentData) //console.log(StudentData)
// console.log(student_works) // console.log(student_works)
return( return(
<React.Fragment> <React.Fragment>

@ -706,7 +706,7 @@ class CoursesBanner extends Component {
{this.props.isStudent()?this.props.current_user&&this.props.current_user.course_is_end===true?"":<a className="fr user_default_btn user_blue_btn mr20 font-18" {this.props.isStudent()?this.props.current_user&&this.props.current_user.course_is_end===true?"":<a className="fr user_default_btn user_blue_btn mr20 font-18"
onClick={() => this.exitclass()} onClick={() => this.exitclass()}
> 退出课堂 </a>:""} > 永久退出课堂 </a>:""}
</div> </div>

@ -536,7 +536,7 @@ class Coursesleftnav extends Component{
successFunc && successFunc(1); successFunc && successFunc(1);
} }
saveNavmodapost=(url,value,positiontype,coursesId)=>{ saveNavmodapost=(url,value,positiontype,coursesId,type)=>{
axios.post(url, axios.post(url,
{name:value}).then((result)=>{ {name:value}).then((result)=>{
@ -548,16 +548,29 @@ class Coursesleftnav extends Component{
description:result.data.message description:result.data.message
}); });
if(positiontype==="shixun_homeworks"){ if(positiontype==="shixun_homeworks"||positiontype==="shixun_homework"){
this.updasaveNavmoda() if(type===true){
trigger('updateNavSuccess') this.updasaveNavmoda()
this.props.history.push(`/classrooms/${coursesId}/shixun_homework/${result.data.category_id}`); trigger('shixun')
}else{
this.updasaveNavmoda()
this.props.history.push(`/classrooms/${coursesId}/shixun_homework/${result.data.category_id}`);
}
} }
if(positiontype==="files"){
this.updasaveNavmoda() if(positiontype==="files"||positiontype==="file"){
trigger('updateNavSuccess')
this.props.history.push(`/classrooms/${coursesId}/file/${result.data.category_id}`); if(type===true){
} this.updasaveNavmoda()
trigger('files')
}else{
this.updasaveNavmoda()
this.props.history.push(`/classrooms/${coursesId}/file/${result.data.category_id}`);
}
}
if(positiontype==="boards"){ if(positiontype==="boards"){
this.updasaveNavmoda() this.updasaveNavmoda()
@ -565,7 +578,7 @@ class Coursesleftnav extends Component{
this.props.history.push(`/classrooms/${coursesId}/boards/${result.data.category_id}`); this.props.history.push(`/classrooms/${coursesId}/boards/${result.data.category_id}`);
} }
if(positiontype!="course_groups"&&positiontype!="shixun_homeworks"){ if(positiontype!="course_groups"&&positiontype!="shixun_homeworks"&&positiontype!="shixun_homework"){
this.updasaveNavmoda() this.updasaveNavmoda()
} }
@ -640,12 +653,12 @@ class Coursesleftnav extends Component{
}else if(Navmodaltypename===3){ }else if(Navmodaltypename===3){
let url="/course_modules/"+id+"/rename_module.json" let url="/course_modules/"+id+"/rename_module.json"
this.saveNavmodapost(url,NavmodalValue) this.saveNavmodapost(url,NavmodalValue,this.state.positiontype,null,true)
}else if(Navmodaltypename===4){ }else if(Navmodaltypename===4){
let url="/course_second_categories/"+id+"/rename_category.json"; let url="/course_second_categories/"+id+"/rename_category.json";
this.saveNavmodapost(url,NavmodalValue) this.saveNavmodapost(url,NavmodalValue,this.state.positiontype,null,true)
}else if(Navmodaltypename===5){ }else if(Navmodaltypename===5){

@ -58,6 +58,7 @@ class ShixunHomework extends Component{
} }
} }
updateNavSuccess=()=>{ updateNavSuccess=()=>{
debugger
this.setState({ this.setState({
isSpin:true isSpin:true
}) })
@ -111,7 +112,7 @@ class ShixunHomework extends Component{
this.updadatalist() this.updadatalist()
} }
} }
on('updateNavSuccess', this.updateNavSuccess) on('shixun', this.updateNavSuccess)
} }
seactall=(id)=>{ seactall=(id)=>{
this.setState({ this.setState({
@ -146,7 +147,7 @@ class ShixunHomework extends Component{
componentDidUpdate = (prevProps) => { componentDidUpdate = (prevProps) => {
if(prevProps.coursesidtype!=this.props.coursesidtype||prevProps.match.params.main_id!=this.props.match.params.main_id||prevProps.match.params.category_id!=this.props.match.params.category_id) { if(prevProps.coursesidtype!=this.props.coursesidtype||prevProps.match.params.category_id!=this.props.match.params.category_id&&this.props.coursesidtype!="node") {
if(this.props.match.params.main_id){ if(this.props.match.params.main_id){
if(this.props.match.params.main_id!=undefined){ if(this.props.match.params.main_id!=undefined){

@ -83,7 +83,7 @@ export default ({ middleshixundata, pagination, typepvisible, pages, totalcount,
</div> </div>
<div className="both"></div> <div className="both"></div>
<div className={"ml425"} <div className={"educontent edu-txt-center mt10"}
style={{ display: pagination ? "block" : "none" }}> style={{ display: pagination ? "block" : "none" }}>
<Pagination defaultCurrent={1} current={pages} total={totalcount || 1299} type="mini" pageSize={16} onChange={onPageChange} /> <Pagination defaultCurrent={1} current={pages} total={totalcount || 1299} type="mini" pageSize={16} onChange={onPageChange} />
</div> </div>

Loading…
Cancel
Save