UNPKG

joywok-material-components

Version:

<h1 align="center"> Joywok Material Components </h1>

556 lines (552 loc) 25.9 kB
/** * * @api {} BaseShare * @apiName BaseShare * @apiGroup 组件使用 * * @apiParam {String } url 远程请求的url * @apiParam {String } placeholder Input默认Placeholder * @apiParam {Array } shareobj 当前选中的数据 * @apiParam {Function } onChange 数据变化的回调事件(传回Array) * * @apiSuccessExample {json} 使用案例: * import BaseShare from 'joywok-material-components/lib/share/BaseShare'; * <BaseShare url={'/api/suggestion/searchobjs?s='} placeholder={'搜点什么吧'} shareobj={[]} onChange={(data)=>this.changeAllVisiScope(data)}/> * * */ import React from 'react'; import { withStyles } from '@material-ui/core/styles'; import InputBase from "@material-ui/core/InputBase/InputBase"; import Popper from '@material-ui/core/Popper'; import Fade from '@material-ui/core/Fade'; import Paper from '@material-ui/core/Paper'; import ClickAwayListener from '@material-ui/core/ClickAwayListener'; import Chip from '@material-ui/core/Chip'; import TagFacesIcon from '@material-ui/icons/TagFaces'; import request from './../utils/request'; require('./style/index.css'); import { generateMixed } from './../utils/pubfun'; import { COMPONENT_DICT } from '../constants'; const shareobj_type = { jw_n_calendar: COMPONENT_DICT('label.business.shareobj.calendar'), jw_n_dept: COMPONENT_DICT('label.business.shareobj.dept'), jw_n_group: COMPONENT_DICT('label.business.shareobj.group'), jw_n_post: COMPONENT_DICT('label.business.shareobj.jwpost'), jw_n_role: COMPONENT_DICT('label.business.shareobj.jwrole'), jw_n_user: COMPONENT_DICT('label.business.shareobj.user'), jw_n_user_category: COMPONENT_DICT('label.business.shareobj.jwuser.category'), jw_n_region: COMPONENT_DICT('label.business.shareobj.jwregion'), jw_n_area: COMPONENT_DICT('label.business.shareobj.jwarea'), jw_n_usergroup: COMPONENT_DICT('label.business.shareobj.usergroup') } const curLang = (window.language || window.cur_lang) || 'zh'; const styles = theme => ({ root: { width: '100%', }, inputRoot: { color: 'inherit', marginLeft:"5px" }, inputInput: { transition: theme.transitions.create('width'), color: "#333", fontSize:14, lineHeight:1 }, list:{ maxHeight:'300px', overflowY:'auto' } }); class CustomSelect extends React.Component { constructor(props) { super(props); this.state = { open:false, loading:false, list:[], check:props.shareobj || [], anchorEl:null, value:'' } this.fetchTime = null } inputChange(e){ let self = this; let value = e.target.value; // let target = this.refs.container; let target = this.container; self.setState({ value:value }) clearTimeout(this.fetchTime); if(value.length!=0 && self.props.url && self.props.url !== ''){ this.fetchTime = setTimeout(function(){ self.setState({ loading:true, anchorEl:target }) self.setState({ open:true }) let url = self.props.url + value request(url,{ method:'GET', }).then(function(resp){ if(resp['data']['success'] && resp['data']['success'] == 0){ }else{ let nowData = []; _.each( (resp.data.JMObjs&&resp.data.JMObjs.list) || resp.data.JMObjs || resp.data.JMUsergroups||resp.data.JMTrioInsts, function (i) { // if (Underscore.findWhere(self.props.shareobj, { id: i['id'] })) { // } else { nowData.push(i) // } }) // nowData = nowData.reverse(); let allData = []; // let key = nowData[0]['type'] let key = 'jw_n_user'; _.each(nowData, function (i) { if (i['type'] != key && i['type']!="jw_trio_inst") { key = i['type'] allData.push({ type: 'sep', name: shareobj_type[i['type']] }) allData.push(i) } else { allData.push(i) } }) console.log("allData::::",allData) self.setState({ list:allData, loading:false }) } }) },800) $(document).off('click').one('click',function(){ self.setState({ open:false, }) }) }else{ self.setState({ open:false, list:[], loading:false }) } } onKeyDown(e){ let code = e.keyCode; if(code == '38' || code == '40'){ let item = $('.custom-search-popper .search-item'); let nowActive = $('.custom-search-popper .search-item.active').eq(0); if(nowActive.length!=0){ let nowIndex = parseInt(nowActive.attr('data-index')); item.removeClass('active'); if(code == '38'){ nowIndex = nowIndex - 1; if(nowIndex==-1){ $('.custom-search-popper .search-item').eq(item.length-1).addClass('active'); }else{ $('.custom-search-popper .search-item').eq(nowIndex).addClass('active'); } }else{ nowIndex = nowIndex+ 1; if(nowIndex==item.length){ $('.custom-search-popper .search-item').eq(0).addClass('active'); }else{ $('.custom-search-popper .search-item').eq(nowIndex).addClass('active'); } } }else{ item.removeClass('active'); if(code == '38'){ $('.custom-search-popper .search-item').eq(item.length-1).addClass('active'); }else{ $('.custom-search-popper .search-item').eq(0).addClass('active'); } } e.preventDefault() //上下 } if(code == '13'){ //确定 let index = $('.custom-search-popper .search-item.active').attr('data-index'); // console.log(index,'asdasdasd'); if(typeof(index) != 'undefined'){ let data = this.state.list[index]; this.choseItem(e,data); } e.preventDefault(); } } onMouseOver(index){ let item = $('.custom-search-popper .search-item'); item.removeClass('active'); item.eq(index).addClass('active'); } onMouseOut(index){ } handleDelete(e,data){ let self = this; if(typeof(this.props.onDelete)!='undefined'){ this.props.onDelete(e,data) }else{ if(typeof(this.props.sigle)!='undefined'){ this.setState({ check:{}, }) self.props.onChange && self.props.onChange({}) setTimeout(function(){ self.inputFocus(); },100) }else{ let newList = []; // console.log(this.state.check,data,'dsadasdasdasd'); _.each(this.state.check,function(i){ // if(i['id'] != data['id']){ // newList.push(i) // } if(i['id']){ if(i['id'] != data['id']){ newList.push(i) } }else{ if(i['key']){ if(i['key'] != data['key']){ newList.push(i) } }else{ if(i['value']){ if(i['value'] != data['value']){ newList.push(i) } } } } }); this.setState({ check:newList, }) this.inputFocus(); self.props.onChange && self.props.onChange(newList) } } } inputFocus(){ // $(this.refs.container).find('input').focus(); $(this.container).find('input').focus(); } customHandleDelete(e,data){ // console.log(e,data,'这个是什么啊'); } handleClickAway(){ this.setState({ open:false }) } choseItem(e,data){ let self = this; let check = this.state.check; if(data.type == 'sep'){ setTimeout(function(){ self.setState({ open:true }) },0) }else{ if(typeof(this.props.sigle)!='undefined'){ check = data; this.setState({ check:check, open:false, value:'' }) }else{ if(_.findWhere(check,{id:data['id'] || data['key'] || data['value']})){ this.setState({ value:'' }) }else{ check.push(data); this.setState({ open:false, check:check, value:'' }) } this.inputFocus(); } self.props.onChange && self.props.onChange(check) } } _combineOne(socialobj) { if (socialobj.type == 'jw_n_user') { return (<div className={"jw-shareobj-item-w " + socialobj.type} data-action-val={socialobj["name"]} data-action-id={socialobj["id"]}> <div className="jw-shareobj-item-pic"> <img src={socialobj.dtype&&socialobj.dtype==1 ? jwimgsrc + '/images/jw-img/share/group.png' : (socialobj['avatar'] ? socialobj['avatar']['avatar_l'] : jwimgsrc + '/images/jw-img/share/user.jpg')} /> </div> <div className="jw-shareobj-item-c"> <div className="jw-shareobj-item-c-name ellipsis">{socialobj.name}</div> { socialobj['depts'] && socialobj['depts'].length != 0 ? <div className="jw-shareobj-item-c-tip">{(socialobj['depts'][0]['title'])+(socialobj['depts'][0]['title']!='' ? ',' : '')+(socialobj['depts'][0]['name'])}</div> : '' } </div> </div>) } else if (socialobj.type == 'jw_n_group' || socialobj.type == 'jw_n_dept' || socialobj.type == '1'||socialobj.type=='app') { return (<div className={"jw-shareobj-item-w " + socialobj.type} data-action-val={socialobj["name"]} data-action-id={socialobj["id"]}> <div className={"jw-shareobj-item-pic " + (socialobj.type=='app' ? 'jw-shareobj-item-pic-app' : '')}> <img src={socialobj.dtype&&socialobj.dtype==1 ? jwimgsrc + '/images/jw-img/share/group.png' : socialobj['logo']} /> </div> <div className="jw-shareobj-item-c"> <div className="jw-shareobj-item-c-name ellipsis">{socialobj.name}</div> <div className="jw-shareobj-item-c-tip">{COMPONENT_DICT('label.business.shareobj.dept.member').replace('{num}',socialobj.members_num)}</div> </div> </div>) } else if (socialobj.type == 'jw_n_role') { return (<div className={"jw-shareobj-item-w " + socialobj.type} data-action-val={socialobj["name"]} data-action-id={socialobj["id"]}> <div className="jw-shareobj-item-pic"> <img src={socialobj.dtype&&socialobj.dtype==1 ? jwimgsrc + '/images/jw-img/share/group.png' : jwimgsrc + '/images/jw-img/share/roles.png'} /> </div> <div className={socialobj.dtype&&socialobj.dtype==2 ? "jw-shareobj-item-c jw-shareobj-item-c-margin" :"jw-shareobj-item-c"}> <div className="jw-shareobj-item-c-name ellipsis">{socialobj.name}</div> <div className="jw-shareobj-item-c-tip"></div> </div> </div>) } else if (socialobj.type == 'jw_n_topic') { } else if (socialobj.type == 'jw_n_folder') { } else if (socialobj.type == 'jw_n_file') { } else if (socialobj.type == 'jw_n_calendar') { } else if (socialobj.type == 'jw_n_task') { } else if (socialobj.type == 'jw_n_project') { } else if (socialobj.type == 'jw_n_domain') { } else if (socialobj.type == 'jw_n_post') { return (<div className={"jw-shareobj-item-w " + socialobj.type} data-action-val={socialobj["name"]} data-action-id={socialobj["id"]}> <div className={"jw-shareobj-item-pic"}> <img src={socialobj.dtype&&socialobj.dtype==1 ? jwimgsrc + '/images/jw-img/share/group.png' : jwimgsrc + '/images/jw-img/share/position.png'} /> </div> <div className={"jw-shareobj-item-c"}> <div className="jw-shareobj-item-c-name ellipsis">{socialobj.parent_path&&socialobj.parent_path!="" ? socialobj.parent_path+"-"+socialobj.name : socialobj.name}</div> <div className="jw-shareobj-item-c-tip"></div> </div> </div>) // } else if (socialobj.type == 'jw_user_category') { } else if (socialobj.type == 'jw_n_user_category') { return (<div className={"jw-shareobj-item-w " + socialobj.type} data-action-val={socialobj["name"]} data-action-id={socialobj["id"]}> <div className={socialobj.dtype&&socialobj.dtype==2 ? 'hide' : "jw-shareobj-item-pic"}> <img src={socialobj.dtype&&socialobj.dtype==1 ? jwimgsrc + '/images/jw-img/share/group.png' : ""} /> </div> <div className={socialobj.dtype&&socialobj.dtype==2 ? "jw-shareobj-item-c jw-shareobj-item-c-margin" : "jw-shareobj-item-c"}> <div className="jw-shareobj-item-c-name ellipsis">{socialobj.parent_path&&socialobj.parent_path!="" ? socialobj.parent_path+"-"+socialobj.name : socialobj.name}</div> <div className="jw-shareobj-item-c-tip"></div> </div> </div>) } else if (socialobj.type == 'jw_n_region') { return (<div className={"jw-shareobj-item-w " + socialobj.type} data-action-val={socialobj["name"]} data-action-id={socialobj["id"]}> <div className={socialobj.dtype&&socialobj.dtype==2 ? 'hide' : "jw-shareobj-item-pic"}> <img src={socialobj.dtype&&socialobj.dtype==1 ? jwimgsrc + '/images/jw-img/share/group.png' : jwimgsrc + '/images/jw-img/share/region.png'} /> </div> <div className={socialobj.dtype&&socialobj.dtype==2 ? "jw-shareobj-item-c jw-shareobj-item-c-margin" :"jw-shareobj-item-c"}> <div className="jw-shareobj-item-c-name ellipsis">{socialobj.parent_path&&socialobj.parent_path!="" ? socialobj.parent_path+"-"+socialobj.name : socialobj.name}</div> <div className="jw-shareobj-item-c-tip"></div> </div> </div>) } else if(socialobj.type == 'jw_n_brand'||socialobj.type == 'jw_n_office'||socialobj.type == 'jw_n_personnel_category'||socialobj.type == 'jw_n_function_level'||socialobj.type == 'jw_n_personnel_group'||socialobj.type == 'jw_n_assign_category'||socialobj.type == 'jw_n_store_category'||socialobj.type == 'jw_n_teamtype'||socialobj.type == 'jw_n_region_category'){ return (<div className={"jw-shareobj-item-w " + socialobj.type} data-action-val={socialobj["name"]} data-action-id={socialobj["id"]}> <div className={socialobj.dtype&&socialobj.dtype==2 ? 'hide' : "jw-shareobj-item-pic"}> <img src={socialobj.dtype&&socialobj.dtype==1 ? jwimgsrc + '/images/jw-img/share/group.png' : jwimgsrc + '/images/jw-img/share/position.png'} /> </div> <div className={socialobj.dtype&&socialobj.dtype==2 ? "jw-shareobj-item-c jw-shareobj-item-c-margin" : "jw-shareobj-item-c"}> <div className="jw-shareobj-item-c-name ellipsis">{socialobj.parent_path&&socialobj.parent_path!="" ? socialobj.parent_path+"-"+socialobj.name : socialobj.name}</div> <div className="jw-shareobj-item-c-tip"></div> </div> </div>) }else if (socialobj.type == 'jw_n_area') { return (<div className={"jw-shareobj-item-w " + socialobj.type} data-action-val={socialobj["name"]} data-action-id={socialobj["id"]}> <div className={socialobj.dtype&&socialobj.dtype==2 ? 'hide' : "jw-shareobj-item-pic"}> <img src={socialobj.dtype&&socialobj.dtype==1 ? jwimgsrc + '/images/jw-img/share/group.png' :jwimgsrc + '/images/jw-img/share/area.png'} /> </div> <div className={socialobj.dtype&&socialobj.dtype==2 ? "jw-shareobj-item-c jw-shareobj-item-c-margin" :"jw-shareobj-item-c "}> <div className="jw-shareobj-item-c-name ellipsis">{socialobj.name}</div> <div className="jw-shareobj-item-c-tip"></div> </div> </div>) } else if (socialobj.type == 'jw_n_usergroup'||socialobj.type == 'jw_trio_inst') { return (<div className={"jw-shareobj-item-w " + socialobj.type} data-action-val={socialobj["name"]} data-action-id={socialobj["id"]}> <div className="jw-shareobj-item-c margin-left"> <div className="jw-shareobj-item-c-name ellipsis">{socialobj.name}</div> <div className="jw-shareobj-item-c-tip"></div> </div> </div>) } else { return <div className="jw-shareobj-item-w disabled"> {socialobj.name} </div> } } onBlur(e){ } _initElement(){ let self = this; const { classes } = this.props; const { anchorEl } = this.state; if(typeof(this.props.sigle)!='undefined'){ let chipData = { className:"custom-shareselect-check-i", key:(this.state.check.id || this.state.check.key || this.state.check.value ), onDelete:(e)=>self.handleDelete(e,this.state.check), label:(curLang == 'en' ? (this.state.check['en_name'] || this.state.check['name']) : this.state.check['name']) || this.state.check['label'], title:(curLang == 'en' ? (this.state.check['en_name'] || this.state.check['name']) : this.state.check['name']) || this.state.check['label'], } if(this.props.disabled || this.props.autoShowDis){ delete chipData['onDelete'] } return <div className="custom-shareselect-c" // ref="container" ref={ref=>this.container=ref} onClick={(e)=>this.inputFocus(e)}> { this.state.value.length!=0 || this.state.check.id || this.state.check.key || this.state.check.value ?'':<div className="custom-shareselect-placeholder">{this.props.placeholder}</div> } <div className="custom-shareselect-list"> { this.state.check && (this.state.check.id || this.state.check.key || this.state.check.value )?<Chip {...chipData} />:'' } { this.state.check && (this.state.check.id || this.state.check.key || this.state.check.value )?'':<InputBase classes={{ root: classes.inputRoot, input: classes.inputInput, }} className="custom-shareselect-search-input" value={this.state.value} onChange={(e)=>self.inputChange(e)} onKeyDown={(e)=>self.onKeyDown(e)} disabled={self.props.disabled?true:false} // ref="input" /> } </div> { this.props.autoShowDis?<div className="custom-shareselect-auto-remove" onClick={(e)=>self.handleDelete(e,this.state.check)}><svg focusable="false" viewBox="0 0 24 24" aria-hidden="true" role="presentation"><path d="M12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2zm5 13.59L15.59 17 12 13.41 8.41 17 7 15.59 10.59 12 7 8.41 8.41 7 12 10.59 15.59 7 17 8.41 13.41 12 17 15.59z"></path></svg></div>:"" } </div> }else{ return <div className="custom-shareselect-c" // ref="container" ref={ref=>this.container=ref} onClick={(e)=>this.inputFocus(e)}> { this.state.value.length!=0 || (this.state.check.length>0)?'':<div className="custom-shareselect-placeholder">{this.props.placeholder}</div> } <div className="custom-shareselect-list"> { this.state.check && this.state.check.length!=0?_.map(this.state.check,function(i){ let chipData = { className:"custom-shareselect-check-i", key:(i['id'] || i['key'] || i['value']), onDelete:(e)=>self.handleDelete(e,i), label:(curLang == 'en' ? (i['en_name'] || i['name']) : i['name']) || i['label'], title:(curLang == 'en' ? (i['en_name'] || i['name']) : i['name']) || i['label'] } if(self.props.disabled){ delete chipData['onDelete'] } return <Chip {...chipData} /> }):'' } { this.state.max && this.state.check.length!=0 && this.state.max <=this.state.check.length?'':<InputBase classes={{ root: classes.inputRoot, input: classes.inputInput, }} className="custom-shareselect-search-input" value={this.state.value} onChange={(e)=>self.inputChange(e)} onKeyDown={(e)=>self.onKeyDown(e)} disabled={self.props.disabled?true:false} // ref="input" /> } </div> </div> } } render(){ let self = this; const { classes } = this.props; const { anchorEl } = this.state; let icon = <TagFacesIcon/> // return <div ref={input => (this.yourView = input)}>ss</div> return(<div className={"custom-shareselect base-share "+(this.props.className || "")} // ref="main" ref={ref=>this.main=ref} > {self._initElement()} <div className="custom-shareselect-showlist"> <Popper id="custom-search-popper" open={this.state.open} placement={'bottom-start'} anchorEl={anchorEl} modifiers={{ preventOverflow: { enabled: true, boundariesElement: 'viewport', }, }} className={'custom-search-popper custom-search-selectlist'} style={{ // width:$(this.refs.container).width()+'px', width:$(this.container).width()+'px', marginTop:'10px', marginBottom:"10px", zIndex:'3001' }} transition > {({ TransitionProps }) => ( <Fade {...TransitionProps} timeout={350}> { self.state.loading?<Paper><div className={'custom-search-loading'}>加载中…</div></Paper>: <Paper className={classes.list}> <ClickAwayListener onClickAway={(e)=>self.handleClickAway(e)}> { self.state.list.length!=0?_.map(self.state.list,function(i,index){ return <div className={"search-item " + (i.name==undefined ? 'hide' : '')} data-index={index} data-id={i['id'] || i['key']} onMouseOver={(e)=>self.onMouseOver(index)} onMouseOut={(e)=>self.onMouseOut(index)} onClick={(e)=>self.choseItem(e,i)}> <div className={"search-item-info"}> <div className={'search-item-info-l'}> { self._combineOne(i) } </div> </div> </div> }):<div className={'custom-search-none'}>{i18n('label.form.nullData')}</div> } </ClickAwayListener> </Paper> } </Fade> )} </Popper> </div> </div>) } componentWillReceiveProps(nextProps, nextState){ // console.log(nextProps,'zzzzzz'); this.setState({ check:nextProps.shareobj || [] }) } } export default withStyles(styles)(CustomSelect);