import React, {Component} from 'react'; import {Link} from "react-router-dom"; import axios from 'axios'; import { Input , Spin, Icon ,Button,Pagination,DatePicker} from 'antd'; import { handleDateString,getUrl,bytesToSize} from 'educoder'; import locale from 'antd/lib/date-picker/locale/zh_CN'; import MDEditors from '../MDEditors'; import PhoneModel from './PhoneModel'; import moment from 'moment'; import '../packageconcnet.css'; const { Search } = Input; const $ = window.$; let origin = getUrl(); // load if (!window.postUpMsg) { $.getScript( `${origin}/javascripts/attachments.js`, (data, textStatus, jqxhr) => { }); } function checkPhone(phone){ if(!(/^1[3456789]\d{9}$/.test(phone))){ // alert("手机号码有误,请重填"); return false; } } function range(start, end) { const result = []; for (let i = start; i < end; i++) { result.push(i); } return result; } function disabledDateTime() { return { disabledMinutes: () => range(1, 30).concat(range(31, 60)), }; } function disabledDate(current) { return current && current < moment().endOf('day').subtract(1, 'days'); } class PackageIndexNEIBannerConcent extends Component { constructor(props) { super(props) this.contentMdRef = React.createRef(); this.state = { modalCancel:false, getverificationcodes:true, seconds:60, springtype:false, category:undefined, title:undefined, content:undefined, attachment_ids:undefined, deadline_at:undefined, min_price:undefined, max_price:undefined, contact_name:undefined, contact_phone:undefined, code:undefined, publish:false, categories:[] } } componentDidMount() { window.document.title = '众包创新' if(this.props.match.params.id!=undefined){ let url=`/project_packages/${this.props.match.params.id}.json` axios.get((url)).then((response) => { console.log(response) let data=response.data this.setState({ category:data.category_id, title:data.title, content:data.content, deadline_at:moment(data.deadline_at), min_price:data.min_price, max_price:data.max_price, contact_name:data.contact_name==null||data.contact_name==undefined?this.props.current_user.real_name:data.contact_name, phones:data.contact_phone, attachments:data.attachments, }) }).catch((error) => { console.log(error); }) }else{ console.log(this.props.current_user&&this.props.current_user.real_name) } let Url = `/project_package_categories.json`; axios.get(Url).then((response) => { // console.log(response) if(response.data.status===-1){ }else{ this.setState({ categories:response.data.categories }) } }).catch((error) => { console.log(error) }) this.setState({ contact_name:this.props.current_user&&this.props.current_user.real_name }) // this.contentMdRef.current.setValue("测试赋值") } componentDidUpdate = (prevProps) => { if(prevProps.current_user!=this.props.current_user){ if(this.props.current_user!=undefined){ this.setState({ contact_name:this.props.current_user.real_name }) } } } //获取验证码; getverificationcode =()=>{ // if (this.state.logins&&this.state.logins.length === 0) { // // 判断没有输入手机号 // return // } if(this.state.getverificationcodes === undefined){ console.log("undefined"); return; } if (this.state.getverificationcodes === true) { this.setState({ getverificationcodes: undefined, }) let timer = setInterval(() => { this.setState((preState) => ({ seconds: preState.seconds - 1, }), () => { if (this.state.seconds == 0) { clearInterval(timer); this.setState({ getverificationcodes: false, seconds: 60, }) } }); }, 1000) //其他的网络请求也可以 this.SMSverification(); } else { this.setState({ getverificationcodes: undefined, }) let timer = setInterval(() => { this.setState((preState) => ({ seconds: preState.seconds - 1, }), () => { if (this.state.seconds == 0) { clearInterval(timer); this.setState({ getverificationcodes: false, seconds: 60, }) } }); }, 1000) //其他的网络请求也可以 this.SMSverification(); } } //短信验证 SMSverification = () => { let {contact_phone,code}=this.state; var url = `/accounts/get_verification_code.json`; axios.get((url), { params: { login: contact_phone, type: 5, } }).then((result) => { //验证有问题{"status":1,"message":"success"} // console.log(result); this.openNotification("验证码已发送,请注意查收!",2); }).catch((error) => { console.log(error); }) } onChangeTimePicker = (value, dateString) => { if(value===null){ this.setState({ deadline_at:"" }) }else{ if(moment(handleDateString(dateString))===undefined||moment(handleDateString(dateString))===null||moment(handleDateString(dateString))===""){ this.setState({ deadline_attypes:true }) }else{ this.setState({ deadline_attypes:false }) } if(moment(handleDateString(dateString)){ const content = this.contentMdRef.current.getValue().trim(); if(content===undefined||content===null||content===""){ this.setState({ contenttypes:true }) }else{ this.setState({ contenttypes:false }) } } setcheckout=(min_price,max_price)=>{ // if(min_price===undefined){ // this.setState({ // min_pricetype:true // }) // }else{ // this.setState({ // min_pricetype:false // }) // } // if(parseInt(min_price)===undefined||parseInt(min_price)===null||parseInt(min_price)===""){ // // this.setState({ // min_pricetype:true // }) // }else{ // this.setState({ // min_pricetype:false // }) // } // if(parseInt(max_price)===undefined||parseInt(max_price)===null||parseInt(max_price)===""){ // // this.setState({ // min_pricetype:true // }) // // }else{ // this.setState({ // min_pricetype:false // }) // } if(parseInt(min_price)<=0){ this.setState({ smallstype:true }) }else{ this.setState({ smallstype:false }) } if(parseInt(max_price){ const content = this.contentMdRef.current.getValue().trim(); // console.log(content) // console.log(this.state.deadline_at._i) this.setState({ publish:type }) let types=type; let {category,title,attachment_ids,deadline_at,min_price,max_price,contact_name,contact_phone,code,modalCancel}=this.state; if(category===undefined||category===null||category===""){ this.setState({ categorytypes:true }) this.scrollToAnchor("publishtimestart"); return } if(title===undefined||title===null||title===""){ this.setState({ titletypes:true }) this.scrollToAnchor("publishtimestart"); return } if(content===undefined||content===null||content===""){ this.setState({ contenttypes:true }) this.scrollToAnchor("publishtimestart"); return } if(deadline_at===undefined||deadline_at===null||deadline_at===""){ this.setState({ deadline_attypes:true }) this.scrollToAnchor("publishtime"); return } if(moment(deadline_at) { if(response.data.status===0){ if(type===true){ this.props.setPublicationfun(response.data.id) }else{ window.location.href="/crowdsourcing/"+response.data.id } this.setState({ springtype:false }) }else if(response.data.status===-1){ if(response.data.message==="无效的验证码"){ this.setState({ codeypesno:true, springtype:false }) } } this.setState({ springtype:false }) }).catch((error) => { console.log(error) this.setState({ springtype:false }) }) }else{ // edit const url = `/project_packages/${this.props.match.params.id}.json`; axios.put(url, { category_id: category, title: title, content: content, attachment_ids: attachment_ids, deadline_at:deadline_at._i, min_price:parseInt(min_price), max_price:parseInt(max_price), contact_name: contact_name===null||contact_name===undefined?this.props.current_user.real_name:contact_name, contact_phone: contact_phone===undefined?this.props.current_user&&this.props.current_user.phone:contact_phone, code:code, publish:types } ).then((response) => { if(response.data.status===0){ if(type===true){ this.props.setPublicationfun(response.data.id) }else{ window.location.href="/crowdsourcing/"+response.data.id } this.setState({ springtype:false }) }else if(response.data.status===-1){ if(response.data.message==="无效的验证码"){ this.setState({ codeypesno:true, springtype:false }) } } this.setState({ springtype:false }) }).catch((error) => { console.log(error) this.setState({ springtype:false }) }) } } modalCancel=()=>{ this.setState({ modalCancel:false, contact_phone:undefined, code:undefined, }) } editmodels=()=>{ this.setState({ modalCancel:true }) } setcategory=(value)=>{ if(value===undefined||value===null||value===""){ this.setState({ categorytypes:true }) }else{ this.setState({ categorytypes:false }) } this.setState({ category:value }) } settitlefun=(e)=>{ if(e.target.value===undefined||e.target.value===null||e.target.value===""){ this.setState({ titletypes:true }) }else{ this.setState({ titletypes:false }) } this.setState({ title:e.target.value }) } onChangemin_prices=(e)=>{ let{max_price}=this.state; this.setState({ min_price:e.target.value }) this.setcheckout(e.target.value,max_price) } onChangemax_prices=(e)=>{ let{min_price}=this.state; this.setState({ max_price:e.target.value }) this.setcheckout(min_price,e.target.value) } onChangeContact_name=(e)=>{ if(e.target.value===undefined||e.target.value===""||e.target.value===null){ this.setState({ contact_nametype:true }) }else{ this.setState({ contact_nametype:false }) } this.setState({ contact_name:e.target.value }) } onChangeContact_phone=(e)=>{ let {modalCancel}=this.state; // if(modalCancel===false){ // if(this.props.current_user.phone===undefined||this.props.current_user.phone===null||this.props.current_user.phone===""){ // this.setState({ // current_userphonetype:true // }) // }else{ // this.setState({ // current_userphonetype:false // }) // } // } if(this.props.current_user&&this.props.current_user.phone===null||modalCancel===true){ if(e.target.value===undefined||e.target.value===null||e.target.value===""){ this.setState({ contact_phonetype:true }) }else{ this.setState({ contact_phonetype:false }) } if(checkPhone(e.target.value)===false){ this.setState({ contact_phonetypes:true }) }else{ this.setState({ contact_phonetypes:false }) } } this.setState({ contact_phone:e.target.value }) } onChangeCode=(e)=>{ if(e.target.value===undefined||e.target.value===""||e.target.value===null){ this.setState({ codeypes:true }) }else{ this.setState({ codeypes:false }) } this.setState({ code:e.target.value }) } //跳转道描点的地方 scrollToAnchor = (anchorName) => { if (anchorName) { // 找到锚点 let anchorElement = document.getElementById(anchorName); // 如果对应id的锚点存在,就跳转到锚点 if(anchorElement) { anchorElement.scrollIntoView(); } } } render() { let {modalCancel,seconds,getverificationcodes,attachments, category,title}=this.state; let categorylist=[ {name:"前端开发",value:"front"}, {name:"后端开发",value:"backend"}, {name:"移动开发",value:"mobile"}, {name:"数据库",value:"database"}, {name:"云计算和大数据",value:"cloud_compute_and_big_data"}, {name:"人工智能",value:"ai"}, {name:"其他",value:"other"}, ] return (
{/**/}

{this.state.categories.map((item,key)=>{ return(
  • this.setcategory(item.id)}>{item.name}
  • ) })}

    {this.state.categorytypes===true?
    请选择类型
    :""}
    {this.state.titletypes===true?
    不能为空
    :""} this.setcheckoutcontent()}> {/* 请求status 422 */} {this.state.contenttypes===true?
    不能为空
    :""} {/*
    */} {/* window.$('#_file').click()}*/} {/*data-tip-down="请选择文件上传">*/} {/*/!**!/*/} {/*上传附件*/} {/**/} {/*(最多可添加 5 个图片/文件,每个大小不超过 10MB)*/} {/*
    */} {/*{attachments&&attachments.map((item,key)=>{*/} {/*return(*/} {/**/} {/*)})}*/} {/*
    */} {/**/} {/**/} {/**/} {/* {*/} {/*debugger;*/} {/*console.log(window.$('.file_selector')[0])*/} {/*window.addInputFiles(window.$('.file_selector')[0])*/} {/*}}*/} {/*style={{'display': 'none'}}*/} {/*type="file">*/} {/**/} {/**/} {/*
    */}

    竞标截止: {this.state.deadline_attypes===true?

    不能为空
    :""} {this.state.deadline_attypexy===true?
    不能早于当前时间
    :""}

    支付费用: this.onChangemin_prices(e)} suffix={ ¥ } /> this.onChangemax_prices(e)} suffix={ ¥ } />不填,则表示可议价 {this.state.min_pricetype===true?

    不能为空
    :""} {this.state.smallstype===true?
    不能小于零
    :""} {this.state.minmaxtype===true?
    最高费用不能小于最低费用
    :""}

    姓名: this.onChangeContact_name(e)} /> {this.state.contact_nametype===true?

    不能为空
    :""}

    {this.props.current_user&&this.props.current_user.phone!=null&&modalCancel===false?

    手机号: this.editmodels()}>

    :""} {/*{this.state.current_userphonetype===true?
    不能为空
    :""}*/} {this.props.current_user&&this.props.current_user.phone===null||modalCancel===true?

    {/*未注册才显示!*/} 手机号: this.onChangeContact_phone(e)} /> {this.state.contact_phonetype===true?

    不能为空
    :""} {this.state.contact_phonetypes===true?
    请输入正确的手机号
    :""} 重新发送 ({seconds}s): getverificationcodes === true ?获取验证码 :重新发送} onSearch={()=>this.getverificationcode()} onInput={(e)=>this.onChangeCode(e)} /> {this.state.codeypes===true?
    验证码不能为空
    :""} {this.state.codeypesno===true?
    验证码不正确
    :""}
    {/**/} this.modalCancel()}>X

    :""}

    this.setPublication(false)}>保存
    ) } } export default PackageIndexNEIBannerConcent; // attachments:[ // { // id: 206525, // title: "412420b57ed8c141963d4c548bde551f", // filesize: 18523, // description: null, // url: "/api/attachments/206525" // } // ]