joywok-material-components
Version:
<h1 align="center"> Joywok Material Components </h1>
1,002 lines (993 loc) • 100 kB
JavaScript
import React, { Component } from 'react';
import ReactDOM from 'react-dom';
import { createStore } from 'redux'
import { Provider } from 'react-redux'
import request from './../utils/request';
import { COMPONENT_DICT, GetNewDate } from '../constants';
// import { Input, Modal, Select, Steps, Spin, Checkbox, Button, message, Popover } from 'antd';
import Input from '@material-ui/core/Input';
import Modal from 'joywok-material-components/lib/modal/modal'
import Checkbox from 'joywok-material-components/lib/checkbox/index'
import Button from 'joywok-material-components/lib/button/index'
import Popover from 'joywok-material-components/lib/popper/custom'
import Dialog from '@material-ui/core/Dialog';
import AloneTip from 'joywok-material-components/lib/tips/aloneTip';
import RadioButtonCheckedIcon from '@material-ui/icons/RadioButtonChecked';
import RadioButtonUncheckedIcon from '@material-ui/icons/RadioButtonUnchecked';
import ToolTips from '../tips/toolTips';
const curLang = (window.language || window.cur_lang) || 'zh';
window.shareAloneTip = null;
require('./style/shareobj.css');
const jssdkData = [
{ code: 10, default_flag: 0, desc: 'xxx', id: 'base', name: 'Basic / Device SDK', parent_code: 0 },
{ code: 1001, default_flag: 1, desc: 'JS环境初始化JS环境初始化JS环境初始化JS环境初始化JS环境初始化JS环境初始化JS环境初始化JS环境初始化JS环境初始化JS环境初始化JS环境初始化JS环境初始化JS环境初始化JS环境初始化JS环境初始化', id: 'config', name: '1001 SDK 初始化', parent_code: 10 },
{ code: 1002, default_flag: 0, desc: '', id: 'getDeviceID', name: '1002 获取设备ID', parent_code: 10 },
{ code: 1003, default_flag: 0, desc: '', id: 'getDevice', name: '1003 获取设备信息', parent_code: 10 },
{ code: 11, default_flag: 0, desc: '', id: 'ui_sdk', name: 'UI SDK', parent_code: 0 },
{ code: 1004, default_flag: 0, desc: '', id: 'getInfo', name: '1004 获取个人信息', parent_code: 11 },
{ code: 1005, default_flag: 0, desc: '', id: 'getCode', name: '1005 获取免登码', parent_code: 11 },
{ code: 12, default_flag: 0, desc: '', id: 'image_sdk', name: 'Image_SDK', parent_code: 0 },
{ code: 1006, default_flag: 0, desc: '', id: 'preImg', name: '1006 预览图片', parent_code: 12 }
]
class ShareObjContainer extends Component {
constructor(props) {
super(props);
let selectD = _.filter(props.data.select, i => !i.selected_flag || (i.selected_flag && i.selected_flag == 1 && i.default_flag != 1));
this.state = Underscore.extend({
sk: '',
nav: [],
nowNav: [],
showSelect: false,
pageno: 0,
enterSub: 0,
page: {
pageno: 0,
pagesize: 10
},
sidbarList: [],
select: [],
defaultSelJssdk: [],
defaultSelAPI: [],
data: []
}, props.data, { select: selectD },
{
selectAllStatus: false,//全选的初始的状态,用于选用户,当前页面没用户信息
}
)
this.backupData = JSON.parse(JSON.stringify(this.state.select));
this.searchTime = null;
this.fetchIng = false;
this.nowData = {};
}
_init_nav(nowNav, i) {
let self = this;
// (i,'asdasda');
if (i['id'] == 'domain') {
return (<div className={"share-object-cat-material-i " + (i['customClass'] || '') + ' ' + (nowNav && nowNav["id"] == i["id"] ? 'actives' : '')}>
<img src={i['icon'] || jwimgsrc + '/images/jw-img/share/objselect_comp.png'} />
<span className="ellipsis">{i['name']}</span>
{
i['help'] ? <i className="icon-share-help"></i> : ''
}
</div>)
}else if (i['id'] == 'jw_n_folder') {
return (<div className={"share-object-cat-material-i " + (i['customClass'] || '') + ' ' + (nowNav && nowNav["id"] == i["id"] ? 'actives' : '')} onClick={()=>self.getFolderNav()}>
<img src={i['icon'] || jwimgsrc + '/images/jw-img/share/jw-n-files.png'} />
<span className="ellipsis">{i['name']}</span>
{
i['help'] ? <i className="icon-share-help"></i> : ''
}
</div>)
} else if (i['id'] == 'dept') {
return (<div className={"share-object-cat-material-i " + (i['customClass'] || '') + ' ' + (nowNav && nowNav["id"] == i["id"] ? 'actives' : '')} onClick={(e) => self.fetchData(e, i)}>
<b className="">
<i className="icon-share-zoom"></i>
</b>
<span className="ellipsis">{i['name']}</span>
{
i['help'] ? <Popover placement="right" content={i['help']} trigger="hover">
<i className="icon-share-help"></i>
</Popover> : ''
}
<i className="icon-share-angle-right"></i>
</div>)
} else if (i['id'] == 'mydept') {
let parentNav = this.state.nowNav[0];
return (
<div className="share-object-cat-material-i specail-cat share-object-mydept">
<div className="share-object-cat-main " onClick={(e) => self.fetchData(e, i)}>
<b className="">
<i className="icon-share-zoom"></i>
</b>
<span className="ellipsis1">{i['name']}</span>
{
i['help'] ? <i className="icon-share-help"></i> : ''
}
<i className="icon-share-angle-right"></i>
</div>
{
i['list'] ? <div className="icon-share-object-child">{Underscore.map(i['list'], function (item) {
let checked = _.find(self.state.select, { id: item['id'] }) ? true : false;
return (<div className={"share-object-cat-material-i specail-checkbox-w " + (nowNav && nowNav["id"] == item["id"] ? 'active' : '')} onClick={(e) => self.fetchGroup(item, 'list', i)}>
{parentNav && parentNav['flag'] == 'onlyuser' ? ""
: <Checkbox icon={<RadioButtonUncheckedIcon/>} checkedIcon={<RadioButtonCheckedIcon/>} checked={checked} onChange={(e) => self.select(e, item)}></Checkbox>
}
{/* */}
<img src={item["logo"] || jwimgsrc + '/images/jw-img/share/position.png'} />
<span className="share-object-cat-i-name">{item['name']}</span>
</div>)
})}</div> : ''
}
</div>)
} else if (i['id'] == 'post' || i['id'] == 'personnel_category' ) {
return (
<div className={"share-object-cat-material-i " + (i['customClass'] || '') + ' ' + (nowNav && nowNav["id"] == i["id"] ? 'actives' : '')} onClick={(e) => self.fetchData(e, i)}>
<img src={i['icon'] || jwimgsrc + '/images/jw-img/share/position.png'} />
<span className="ellipsis1">{i['name']}</span>
{
i['help'] ? <i className="icon-share-help"></i> : ''
}
<i className="icon-share-angle-right"></i>
</div>
)
} else if (i['id'] == 'role'||i['id'] == 'apps') {
return (
<div className={"share-object-cat-material-i " + (i['customClass'] || '') + ' ' + (nowNav && nowNav["id"] == i["id"] ? 'actives' : '')} onClick={(e) => self.fetchData(e, i)}>
{i['id'] == 'apps' ? '' : <img src={i['icon'] || jwimgsrc + '/images/jw-img/share/roles.png'} />}
<span className="ellipsis">{i['name']}</span>
{
i['help'] ? <i className="icon-share-help"></i> : ''
}
<i className="icon-share-angle-right"></i>
</div>
)
} else if (i['id'] == 'extuser') {
return (
<div className={"share-object-cat-material-i " + (i['customClass'] || '') + ' ' + (nowNav && nowNav["id"] == i["id"] ? 'actives' : '')} onClick={(e) => self.fetchData(e, i)}>
<img src={i['icon'] || jwimgsrc + '/images/jw-img/share/position.png'} />
<span className="ellipsis">{i['name']}</span>
{
i['help'] ? <i className="icon-share-help"></i> : ''
}
<i className="icon-share-angle-right"></i>
</div>
)
} else if (i['id'] == 'category') {
return (
<div className={"share-object-cat-material-i " + (i['customClass'] || '') + ' ' + (nowNav && nowNav["id"] == i["id"] ? 'actives' : '')} onClick={(e) => self.fetchData(e, i)}>
<img src={i['icon'] || ''} />
<span className="ellipsis">{i['name']}</span>
{
i['help'] ? <i className="icon-share-help"></i> : ''
}
<i className="icon-share-angle-right"></i>
</div>
)
} else if (i['id'] == 'region'|| i['id'] == 'instance') {
return (
<div className={"share-object-cat-material-i " + (i['customClass'] || '') + ' ' + (nowNav && nowNav["id"] == i["id"] ? 'actives' : '')} onClick={i['id'] == 'region' ? (e) => self.fetchData(e, i) : function(){}}>
{i['id'] == 'region' ? <img src={i['icon'] || jwimgsrc + '/images/jw-img/share/region.png'} />: ''}
<span className="ellipsis">{i['name']}</span>
{
i['help'] ? <i className="icon-share-help"></i> : ''
}
<i className="icon-share-angle-right"></i>
</div>
)
} else if (i['id'] == 'area') {
return (
<div className={"share-object-cat-material-i " + (i['customClass'] || '') + ' ' + (nowNav && nowNav["id"] == i["id"] ? 'actives' : '')} onClick={(e) => self.fetchData(e, i)}>
<img src={i['icon'] || jwimgsrc + '/images/jw-img/share/area.png'} />
<span className="ellipsis">{i['name']}</span>
{
i['help'] ? <i className="icon-share-help"></i> : ''
}
<i className="icon-share-angle-right"></i>
</div>
)
} else if (i['type'] == 'group' || i['type'] == 'jssdk'|| i['type'] == 'groupApi' || i['type'] == 'selFolder') {
return <div className={"share-object-cat-material-i " + (i['customClass'] || '') + ' ' + (nowNav && nowNav["id"] == i["id"] ? ' actives ' : '')} onClick={(e) => self.fetchData(e, i)}>
<span className="ellipsis">{i['name']}</span>
{
i['help'] ? <i className="icon-share-help"></i> : ''
}
<i className="icon-share-angle-right"></i>
</div>
} else if(i['id']=='usergroup'||i['id']=='function_level'||i['type']=='jw_n_subscribe'){
return (
<div className={"share-object-cat-material-i " + (i['customClass'] || '') + ' ' + (nowNav && (nowNav["id"]!=undefined&&nowNav["id"] == i["id"]||(nowNav["src_id"]!=undefined&&nowNav["src_id"] == i["src_id"])) ? 'actives' : '')} onClick={(e) => self.fetchData(e, i)}>
{
i['type']=='jw_n_subscribe' ? '' : <img src={i['icon'] || jwimgsrc + '/images/jw-img/share/'+i['id']+'.png'} />
}
<span className="ellipsis">{i['name']}</span>
{
i['help'] ? <i className="icon-share-help"></i> : ''
}
<i className="icon-share-angle-right"></i>
</div>
)
} else if(i['id']=='dictParent' ){
return (
<div className={"share-object-cat-material-i " + (i['customClass'] || '') + ' ' + (nowNav && nowNav["id"] == i["id"] ? 'actives' : '')} onClick={(e) => self.fetchData(e, i)}>
<span className="ellipsis">{i['name']}</span>
{
i['help'] ? <i className="icon-share-help"></i> : ''
}
<i className="icon-share-angle-right"></i>
</div>
)
}else if(i['id'] == 'business_dict'){
return (
<div className={"share-object-cat-material-i " + (i['customClass'] || '') + ' ' + (nowNav && nowNav["id"] == i["id"] ? 'actives' : '')} onClick={(e) => self.fetchData(e, i)}>
<span className="ellipsis">{i['name']}</span>
{
i['help'] ? <i className="icon-share-help"></i> : ''
}
<i className="icon-share-angle-right"></i>
</div>
)
}else if(i['id']=='customusergroup'){
return (
<div className={"share-object-cat-material-i " + (i['customClass'] || '') + ' ' + (nowNav && nowNav["id"] == i["id"] ? 'actives' : '')} onClick={(e) => self.fetchData(e, i)}>
<img src={i['icon'] || jwimgsrc + '/images/jw-img/share/'+i['id']+'.png'} />
<span className="ellipsis">{i['name']}</span>
{
i['help'] ? <i className="icon-share-help"></i> : ''
}
<i className="icon-share-angle-right"></i>
</div>
)
}else if(i['id']=='subscribeteam'){
return (
<div className={"share-object-cat-material-i " + (i['customClass'] || '') + ' ' + 'actives'} onClick={(e) => self.fetchData(e, i)}>
<span className="ellipsis">{i['name']}</span>
{
i['help'] ? <i className="icon-share-help"></i> : ''
}
<i className="icon-share-angle-right"></i>
</div>
)
}else if(i['id']=='select_task'){
return (
<div className={"share-object-cat-material-i " + (i['customClass'] || '') + ' ' + 'actives'}>
<span className="ellipsis">{i['name']}</span>
{
i['help'] ? <i className="icon-share-help"></i> : ''
}
<i className="icon-share-angle-right"></i>
</div>
)
}else if(i['id']=='specificUser'){
return (
<div className={"share-object-cat-material-i " + (i['customClass'] || '') + ' ' + (nowNav && nowNav["id"] == i["id"] ? 'actives' : '')} onClick={(e) => self.fetchData(e, i)}>
<img src={i['icon'] || jwimgsrc + '/images/jw-img/share/specific-user.png'} />
<span className="ellipsis">{i['name']}</span>
{
i['help'] ? <i className="icon-share-help"></i> : ''
}
<i className="icon-share-angle-right"></i>
</div>
)
}else if(i['id'] == 'office'){
return (
<div className={"share-object-cat-material-i " + (i['customClass'] || '') + ' ' + (nowNav && nowNav["id"] == i["id"] ? 'actives' : '')} onClick={(e) => self.fetchData(e, i)}>
<span className="ellipsis">{i['name']}</span>
{
i['help'] ? <i className="icon-share-help"></i> : ''
}
<i className="icon-share-angle-right"></i>
</div>
)
}
}
_init_normal() {
let self = this;
let data = this.state;
let nowNav = data['nowNav'][data['nowNav'].length - 1];
return (<div className={"sahre-object-l-i " + (this.state.sk && this.state.sk.length != 0 ? 'hide' : '')}>
{
_.map(data['nav'], function (i) {
return self._init_nav(nowNav, i);
})
}
</div>)
}
changeNav(data, index) {
let self = this;
let navLenght = this.state.nowNav;
if (navLenght[0].id == 'area') {
navLenght = _.filter(navLenght, (item, i) => i <= index);
} else {
navLenght.splice(index + 1);
// navLenght.splice(index + 1, 1);
}
this.setState({
nowNav: navLenght,
hideSub: false
})
if (navLenght[0].id == 'area') {
this.fetchGroupRegion(navLenght[navLenght.length - 1], navLenght);
} else if(navLenght[0].id == 'dictParent'){
this.fetchDictParent(navLenght[navLenght.length - 1], navLenght);
} else if(data.id=='instance'){
this.getInstanceData(navLenght[navLenght.length - 1],navLenght);
} else if(data.id=='jw_n_folder'){
this.getFolderNav();
// 用户组
}else if(navLenght[0].id == 'usergroup'){
this.fetchIng = true;
window.shareAloneTip = AloneTip({type: 'warning',duration: 200000,hasclose: false,autoHideDuration: 200000,message: COMPONENT_DICT('label.business.shareobj.loading')})
let url = '/api/usergroup/classes'
request(url, {
method: 'GET'
})
.then(function (resp) {
self.fetchIng = false;
let fetchList = resp["data"]["JMUsergroupclasses"];
window.shareAloneTip.close();
self.setState({
data: fetchList,
// page: resp["data"]["JMObjs"]["page"],
nowNav: [data]
})
})
// 自定义用户组
}else if(navLenght[0].id == 'customusergroup'){
this.fetchIng = true;
window.shareAloneTip = AloneTip({type: 'warning',duration: 200000,hasclose: false,autoHideDuration: 200000,message: COMPONENT_DICT('label.business.shareobj.loading')})
let url = '/api/customusergroup/classes?oid='+navLenght[0].oid+'&otype='+navLenght[0].otype
request(url, {
method: 'GET'
})
.then(function (resp) {
self.fetchIng = false;
let fetchList = resp["data"]["JMUsergroupclasses"];
window.shareAloneTip.close();
self.setState({
data: fetchList,
// page: resp["data"]["JMObjs"]["page"],
nowNav: [data]
})
})
} else if(navLenght[navLenght.length-1].type == 'jw_subscribe_team'||navLenght[navLenght.length-1].id=='subscribeteam'){
let dept_id = navLenght[navLenght.length-1].id === 'subscribeteam' ? '' : navLenght[navLenght.length-1].id
this.fetchIng = true;
window.shareAloneTip = AloneTip({type: 'warning',duration: 200000,hasclose: false,autoHideDuration: 200000,message: COMPONENT_DICT('label.business.shareobj.loading')})
let url = '/api/subscription/subgetdeptinfo'
request(url, {
method: 'GET',
body: {
dept_id: dept_id
}
})
.then(function (resp) {
let resD = resp.data.JMSubscription;
_.each(resD, i => i.type = 'jw_subscribe_team');
_.each(resD, i => i.flag = 'onlydept');
self.fetchIng = false;
let fetchList = resD;
window.shareAloneTip.close();
self.setState({
data: fetchList,
// page: resp["data"]["JMObjs"]["page"],
// nowNav: [data]
})
})
} else if (navLenght[0].id == 'select_task') {
if(navLenght[navLenght.length - 1].id == 'select_task'){
self.getTaskData(navLenght[navLenght.length - 1]);
}else {
self.fetchTaskData(navLenght[navLenght.length - 1],true);
}
}else {
this.fetchGroup(navLenght[navLenght.length - 1], true);
}
}
_init_folderSearch(){
if(this.state.nav && this.state.nav.length && this.state.nav.length>0 && this.state.nav[0] && this.state.nav[0].id=='jw_n_folder' ){
return <div className="share-object-search">
<i className="icon-search-s"></i>
<Input className="has-border" placeholder={COMPONENT_DICT('label.business.shareobj.search')} onChange={(e) => this.searchData(e)} />
</div>
}
}
_init_title() {
let self = this;
let navLenght = this.state.nowNav;
let html = [];
let isJssdk = this.props.data.nav[0].id;
let isUsergroup = this.props.data.nav[0].id;
let isArticles = this.props.data.nav[0].id;
let isAPI = this.props.data.nav[0].id;
let isSpecificUser = this.props.data.nav[0].id;
_.each(this.state.nowNav, function (i, index) {
html.push(<span id={i.id} className={'ellipsis ' + (index != navLenght.length - 1 ? 'active' : '')} onClick={(e) => (index != navLenght.length - 1 ? self.changeNav(i, index) : function () { })}>{(i.type == "boardgroup" || i.type == "board" || i.type == "list") ? self.getLabelValue(i['name'],true) : i["name"]}</span>)
if (index != self.state.nowNav.length - 1) {
html.push(<span className="active share-object-path-sep">{'>'}</span>)
}
})
setTimeout(function () {
let left = $('.share-object-path-c').width() - $('.share-object-path').width();
if (left > 0) {
left = '-' + left
} else {
left = 0;
}
$('.share-object-path-c').stop().animate({ marginLeft: left + 'px' })
}, 100)
return <div className="share-object-path"><div className={"share-object-path-c " + (isJssdk == 'selJssdk' || isUsergroup == 'usergroup' || isArticles=='subscribe_articles' || isAPI == 'groupApi' ? 'path-jssdk' : '')}>{html}</div></div>
}
_init_item(data,isSearch) {
let self = this;
let nowNav = this.state['nowNav'][0];
let curData = data.type=='jw_n_subscribe_article' ? _.find(self.state.select, { oid: data['oid'] }) : _.find(self.state.select, { id: data['id'] });
// 整合一下外面传递的参数
if(curData!=undefined){ data = _.extend(data,curData) }
let checked = curData ? true : false;
let checkboxProps = {};
if(data['disabled']) checkboxProps.disabled=true;
if (data['type'] == 'jw_n_dept') {
return <div className={"share-object-i specail " + (data['disabled'] ? 'share-object-i-disabled' : '')}>
{
nowNav &&( nowNav["id"] == 'dept'||nowNav["id"] == 'dictParent'&&nowNav["type"] == 'dept') && nowNav['flag'] && nowNav['flag'] != 'onlyuser' ? <Checkbox icon={<RadioButtonUncheckedIcon/>} checkedIcon={<RadioButtonCheckedIcon/>} disabled={data['disabled']} checked={checked} onChange={(e) => self.select(e, data)}></Checkbox> : ''
}
<div className="share-objec-i-c" onClick={(e) => this.fetchGroup(data,'','',isSearch)}>
<img src={data['logo']} />
<span className="ellipsis">
<ToolTips title={curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name']} placement="top">
<div className="toolTips-label">{ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] }</div>
</ToolTips>
</span>
<i className="icon-share-angle-right icon-share-angle-right-dept"></i>
</div>
</div>
} else if (data['type'] == 'jw_n_group') {
return <div className={"share-object-i specail " + (data['disabled'] ? 'share-object-i-disabled' : '')}>
{
nowNav && nowNav["id"] == 'dept' && nowNav['flag'] && nowNav['flag'] != 'onlyuser' ? <Checkbox icon={<RadioButtonUncheckedIcon/>} checkedIcon={<RadioButtonCheckedIcon/>} disabled={data['disabled']} checked={checked} onChange={(e) => self.select(e, data)}></Checkbox> : ''
}
<div className="share-objec-i-c" onClick={(e) => this.fetchGroup(data,'','',isSearch)}>
<img src={data['logo']} />
<span className="ellipsis">
<ToolTips title={ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] } placement="top">
<div className="toolTips-label">{ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] }</div>
</ToolTips>
</span>
</div>
</div>
} else if (data['type'] == 'jw_n_user') {
let checked = _.find(self.state.select, { id: data['id'] }) ? true : false;
if(!data['disabled']) checkboxProps.onChange= (e) => self.select(e, data);
return <div className={"share-object-i " + (data['disabled'] ? 'share-object-i-disabled' : '')}>
<Checkbox icon={<RadioButtonUncheckedIcon/>} checkedIcon={<RadioButtonCheckedIcon/>} checked={checked} {...checkboxProps}></Checkbox>
<div className="share-objec-i-c">
<img src={data["avatar"] ? data["avatar"]['avatar_l'] : jwimgsrc + '/images/jw-img/share/user.jpg'} />
{
isSearch ?
<span className="ellipsis">
<ToolTips title={ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] } placement="top">
<div className="share-objec-user-info">
<div className="toolTips-label">{ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] }</div>
<p className="share-objec-user-dept">{(data['depts']&&data['depts'].length>0&&data['depts'][0]['title']) + (data['depts']&&data['depts'].length>0&&data['depts'][0]['title']=="" ? '' : ',') + (data['depts']&&data['depts'].length>0&&data['depts'][0]['name'])}</p>
</div>
</ToolTips>
</span> :
<span className="ellipsis">
<ToolTips title={ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] } placement="top">
<div className="toolTips-label">{ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] }</div>
</ToolTips>
</span>
}
</div>
</div>
} else if (data['file_type'] == 'jw_n_folder') {
let checked = _.find(self.state.select, { id: data['id'] }) ? true : false;
return <div className={"share-object-i" + (data['disabled'] ? 'share-object-i-disabled' : '')}>
<Checkbox icon={<RadioButtonUncheckedIcon/>} checkedIcon={<RadioButtonCheckedIcon/>} disabled={data['disabled']} checked={checked} onChange={(e) => self.select(e, data)}></Checkbox>
<div className="share-objec-i-c app-cur-def" onChange={(e) => self.select(!checked, data)}>
<img src={data["avatar"] ? data["avatar"]['avatar_l'] : jwimgsrc + '/images/jw-img/share/jw-n-folder.png'} />
<span className="ellipsis">
<ToolTips title={ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] } placement="top">
<div className="toolTips-label">{ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] }</div>
</ToolTips>
</span>
</div>
</div>
} else if (data['type'] == 'topFolder') {
let checked = _.find(self.state.select, { id: data['id'] }) ? true : false;
return <div className={"share-object-i" + (data['disabled'] ? 'share-object-i-disabled' : '')}>
<div className="share-objec-i-c" onClick={(e) => self.fetchData(e, data, false)}>
<span className="ellipsis">
<ToolTips title={ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] } placement="top">
<div className="toolTips-label">{ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] }</div>
</ToolTips>
</span>
</div>
</div>
} else if (data['type'] == 'jw_n_project') {
return <div className="share-object-i specail" onClick={(e) => this.fetchByOther(e, data)}>
<div className="share-objec-i-c">
<img src={data['logo']} />
<span className="ellipsis">
<ToolTips title={ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] } placement="top">
<div className="toolTips-label">{ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] }</div>
</ToolTips>
</span>
</div>
</div>
} else if (data['type'] == 'jw_n_task') {
return <div className="share-object-i specail" onClick={(e) => this.fetchByOther(e, data)}>
<div className="share-objec-i-c">
<img src={data['logo']} />
<span className="ellipsis">
<ToolTips title={ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] } placement="top">
<div className="toolTips-label">{ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] }</div>
</ToolTips>
</span>
</div>
</div>
} else if (data['obj_type'] == 'jw_n_area') {
return <div className={"share-object-i specail " + (data['disabled'] ? 'share-object-i-disabled ' : '') + (this.state.hideSub ? "" : "flex-two")} >
<div className="share-object-i-w">
<Checkbox icon={<RadioButtonUncheckedIcon/>} checkedIcon={<RadioButtonCheckedIcon/>} disabled={data['disabled']} checked={checked} onChange={(e) => self.select(e, data)}></Checkbox>
<div className="share-objec-i-c" onClick={(e) => self.specailSelect(!checked, data)}>
<span className="ellipsis">
<ToolTips title={ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] } placement="top">
<div className="toolTips-label">{ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] }</div>
</ToolTips>
</span>
</div>
</div>
{self.state.hideSub ? '' : <div className="next-icon " onClick={() => self.fetchGroupRegion(data,'',isSearch)}>
<i className="icon-share-angle-right"></i>
</div>}
</div>
} else if (data.type == 'jssdk' || data.type == 'groupApi' ) {
return <div className={"share-object-i share-jssdk " + (data['default_flag'] == 1 ? " not-allowed" : "")}>
{data['default_flag'] == 1 && data['selected_flag'] == 1 ? <img src={jwimgsrc + '/images/jw-img/share/checkout-dis.png'} width="20" alt="" />
: <Checkbox icon={<RadioButtonUncheckedIcon/>} checkedIcon={<RadioButtonCheckedIcon/>} disabled={data['default_flag'] == 1 || data['disabled']} defaultChecked={false} checked={checked} onChange={(e) => self.select(e, data)}></Checkbox>}
<div className="share-objec-i-c" onClick={(e) => self.specailSelect(!checked, data)}>
{/* <span className="ellipsis">{data['name']}</span> */}
<span className="ellipsis js-name">
<ToolTips title={ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] } placement="top">
<div className="toolTips-label">{ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] }</div>
</ToolTips>
</span>
<div className="js-des">{data.desc}</div>
</div>
</div>
} else if(data.type=='jw_n_dict'){
let checked = _.find(self.state.select, { id: data['id'] }) ? true : false;
return <div className={"share-object-i " + (data['disabled'] ? 'share-object-i-disabled ' : '') + (data['type']=='app' ? 'share-objec-apps' : '')}>
<Checkbox icon={<RadioButtonUncheckedIcon/>} checkedIcon={<RadioButtonCheckedIcon/>} disabled={data['disabled']} checked={checked} onChange={(e) => self.select(e, data)}></Checkbox>
<div className="share-objec-i-c" onClick={(e) => self.specailSelect(!checked, data)}>
<span className="ellipsis">
<ToolTips title={ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] } placement="top">
<div className="toolTips-label">{ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] }</div>
</ToolTips>
</span>
</div>
</div>
} else if(data.dict_flag==1 ||data.type == 'jw_n_teamtype' || data.type == 'jw_n_store_category' ||data.type == 'jw_n_personnel_category' ||data.type == 'jw_n_post'||data.type == 'jw_n_jobtype' ||data.type == 'jw_n_function_level' || data.type == 'jw_n_office' ||data.type == 'jw_n_brand' ||data.type == 'jw_n_region'|| data.type == 'jw_n_user_category' || data.type == 'jw_n_region_category' || data.type == 'jw_n_personnel_group' || data.type == 'jw_n_assign_category'|| data.type=='jw_trio_inst'||data.type=='corporation'){
return <div className={"share-object-i specail share-dict " + (data.type=='jw_trio_inst' ? 'share-dict_trio_inst ' :"") + (data['disabled'] ? 'share-object-i-disabled' : '') + (nowNav&&nowNav.isSelectGroup!=undefined&&nowNav.isSelectGroup ? '' : 'share-dict-not-select-group')}>
{ nowNav&&nowNav.isSelectGroup!=undefined&&nowNav.isSelectGroup||data.dtype=="2" ?
<Checkbox icon={<RadioButtonUncheckedIcon/>} checkedIcon={<RadioButtonCheckedIcon/>} disabled={data['disabled']}
checked={checked} onChange={(e) => self.select(e, data)}></Checkbox> : ''
}
{data.dtype=="1"? <img className="dict-group-icon" src={jwimgsrc + '/images/jw-img/share/group.png'} width="20" alt="" /> : ''}
<div className={data.dtype=="1" ? "share-objec-group-w" : "share-objec-entry-w" } onClick={data.type=='jw_n_origanization' ? ()=>function(){} : () => self.fetchDictParent(data,'',isSearch)}>
<div className="share-objec-i-c " >
<span className="ellipsis">
<ToolTips title={nowNav.id=="dictParent"&&data['parent_path']!=''&&isSearch&&data['parent_path'] ? (data['parent_path']+ '-' + data['name']) : data['name']} placement="top">
<div className="toolTips-label">{nowNav.id=="dictParent"&&data['parent_path']!=''&&isSearch&&data['parent_path'] ? (data['parent_path']+ '-' + data['name']) : data['name']}</div>
</ToolTips>
</span>
</div>
{
data.type=='jw_n_origanization' ? '' : <i className="icon-share-angle-right"></i>
}
</div>
</div>
} else if(data.type == 'jw_n_usergroup_class'||data.type == 'jw_n_subscribe'){
return <div className={"share-object-i specail " + (data['disabled'] ? 'share-object-i-disabled ' : '')}>
{/*<Checkbox icon={<RadioButtonUncheckedIcon/>} checkedIcon={<RadioButtonCheckedIcon/>} disabled={data['disabled']} checked={checked} onChange={(e) => self.select(e, data)}></Checkbox>*/}
<div className="share-objec-i-c share-objec-i-c-usergroup" onClick={data.type == 'jw_n_usergroup_class' ? (e) => self.fetchUsergroup(data, '', isSearch) : (e) => self.fetchArticles(data, '', isSearch)}>
<span className="ellipsis">
<ToolTips title={ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] } placement="top">
<div className="toolTips-label">{ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] }</div>
</ToolTips>
</span>
<i className="icon-share-angle-right icon-share-angle-right-usergroup"></i>
</div>
</div>
} else if(data.type == 'jw_n_usergroup'||data.type == 'jw_n_subscribe_article'){
return <div className={"share-object-i specail " + (data['disabled'] ? 'share-object-i-disabled ' : '')}>
<Checkbox icon={<RadioButtonUncheckedIcon/>} checkedIcon={<RadioButtonCheckedIcon/>} disabled={data['disabled']}
checked={checked} onChange={(e) => self.select(e, data)}></Checkbox>
<div className="share-objec-i-c" >
<span className={"ellipsis " + (data.type == 'jw_n_usergroup' ? 'ellipsis-usergroup' : '')}>
<ToolTips title={ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] } placement="top">
<div className="toolTips-label">{ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] }</div>
</ToolTips>
{
data.type == 'jw_n_subscribe_article' ?
<div className="share-objec-i-c-time">
{GetNewDate(data.created_at)}
</div> : ''
}
</span>
</div>
</div>
} else if(data.type == 'jw_subscribe_team'){
return <div className={"share-object-i specail share-object-subscribe_team"}>
<Checkbox icon={<RadioButtonUncheckedIcon/>} checkedIcon={<RadioButtonCheckedIcon/>} disabled={data['disabled']} checked={checked} onChange={(e) => self.select(e, data)}></Checkbox>
<div className="share-objec-i-c" onClick={(e) => self.fetchData(e,data)}>
<span className="ellipsis">
<ToolTips title={ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] } placement="top">
<div className="toolTips-label">{ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] }</div>
</ToolTips>
</span>
<i className="icon-share-angle-right"></i>
</div>
</div>
} else if(data.type == "boardgroup" || data.type == "board" || data.type == "list" || data.type == "task"){
return <div className={"share-object-i specail share-object-subscribe_team"}>
<Checkbox icon={<i className="icon-task-share-checkbox-disabled"></i>} checkedIcon={<i className="icon-task-share-checkbox-active"></i>} disabled={data['disabled']} checked={checked} onChange={(e) => self.select(e, data)}></Checkbox>
<div className="share-objec-i-c share-object-select-task" onClick={(data.type=='task' || checked) ? ()=>function(){} : (e) => self.fetchTaskData(data)}>
<span className="ellipsis">
<ToolTips title={self.getLabelValue(data['name'],true)} placement="top">
<div className="toolTips-label">{self.getLabelValue(data['name'],true)}</div>
</ToolTips>
</span>
{
(data.type == "task" || checked) ? <i className="icon-share-angle-right-bak"></i>: <i className="icon-share-angle-right"></i>
}
</div>
</div>
} else {
return <div className={"share-object-i specail " + (data['disabled'] ? 'share-object-i-disabled ' : '') + (data['type']=='app' ? 'share-objec-apps' : '')}>
<Checkbox icon={<RadioButtonUncheckedIcon/>} checkedIcon={<RadioButtonCheckedIcon/>} disabled={data['disabled']} checked={checked} onChange={(e) => self.select(e, data)}></Checkbox>
<div className="share-objec-i-c" onClick={(e) => self.specailSelect(!checked, data)}>
{
data['type']=='app' ? <img className="share-objec-apps-logo" src={data['logo']} /> : ''
}
<span className="ellipsis">
<ToolTips title={ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] } placement="top">
<div className="toolTips-label">{ curLang && curLang == 'en' && data['en_name'] ? data['en_name'] : data['name'] }</div>
</ToolTips>
</span>
</div>
</div>
}
}
specailSelect(checked, data) {
let datas = this.state;
let selectList = this.state.select;
let curData = this.props.data.title=='添加 JS SDK' ? this.state.defaultSelJssdk : this.state.defaultSelAPI;
if (data['disabled'] || data['default_flag'] == 1) {
return
}
//代码有点复杂,稍后整理下;
if (datas['maxSelect']) {
//优化
if (datas['maxSelect'] == '1') {
if (checked) {
selectList = [data];
} else {
selectList = [];
}
} else {
if (selectList.length + curData.length >= datas['maxSelect']) {
if (checked) {
selectList.shift();
selectList.push(data);
} else {
let nowSelectList = [];
_.each(selectList, function (i) {
if (i['id'] != data['id']) {
nowSelectList.push(i)
}
})
selectList = nowSelectList;
}
} else {
if (checked) {
selectList.push(data);
} else {
let nowSelectList = [];
_.each(selectList, function (i) {
if (i['id'] != data['id']) {
nowSelectList.push(i)
}
})
selectList = nowSelectList;
}
}
}
} else {
if (checked) {
selectList.push(data);
} else {
let nowSelectList = [];
_.each(selectList, function (i) {
if (i['id'] != data['id']) {
nowSelectList.push(i)
}
})
selectList = nowSelectList;
}
}
this.setState({
select: selectList
})
}
select(e, data) {
let datas = this.state;
let checked = e.target.checked;
if (!checked) {
if (this.state.cantRemoveData && this.state.cantRemoveData.length != 0) {
if (data.type!='jw_n_subscribe_article'&&_.findWhere(this.state.cantRemoveData, { id: data['id'] })) {
return
}
if (data.type=='jw_n_subscribe_article'&&_.findWhere(this.state.cantRemoveData, { oid: data['oid'] })) {
return
}
}
}
let selectList = this.state.select;
let curData = this.props.data.title=='添加 JS SDK' ? this.state.defaultSelJssdk : this.state.defaultSelAPI;
//代码有点复杂,稍后整理下;
if (datas['maxSelect']) {
//优化
if (datas['maxSelect'] == '1') {
if (checked) {
selectList = [data];
} else {
selectList = [];
}
} else {
if (selectList.length + curData.length >= datas['maxSelect']) {
if (checked) {
selectList.shift();
selectList.push(data);
} else {
let nowSelectList = [];
_.each(selectList, function (i) {
if ((i['id']!=undefined&&i['id'] != data['id'])||(i['0id']!=undefined&&i['oid'] != data['oid'])) {
nowSelectList.push(i)
}
})
selectList = nowSelectList;
}
} else {
if (checked) {
selectList.push(data);
} else {
let nowSelectList = [];
_.each(selectList, function (i) {
if ((i['id']!=undefined&&i['id'] != data['id'])||(i['0id']!=undefined&&i['oid'] != data['oid'])) {
nowSelectList.push(i)
}
})
selectList = nowSelectList;
}
}
}
} else {
if (checked) {
selectList.push(data);
} else {
let nowSelectList = [];
_.each(selectList, function (i) {
if ((i['id']!=undefined&&i['id'] != data['id'])||(i['0id']!=undefined&&i['oid'] != data['oid'])) {
nowSelectList.push(i)
}
})
selectList = nowSelectList;
}
}
this.setState({
select: selectList
})
}
selectAll(e) {
let self = this;
let checked = e.target.checked;
let selectList = this.state.select;
let filterList;
if (this.props.isJssdk) {
filterList = _.filter(this.state.data, i => i.default_flag === 0);
} else {
filterList = this.state.data;
}
let nowData = this.state.nowNav[0];
let newfilterList = [];
if (nowData['id'] == 'dept' || nowData['id'] == 'mydept' || (nowData['type']&&nowData['type'].indexOf('dept')!=-1)) {
if (nowData['flag']) {
if (nowData.flag == 'onlyuser') {
filterList = _.filter(filterList, function (i) {
return (i['type'] == 'jw_n_user')
})
} else if (nowData.flag == 'onydept') {
filterList = _.filter(filterList, function (i) {
return (i['type'] == 'jw_n_dept' || i['type'] == 'jw_n_group')
})
}
} else {
filterList = _.filter(filterList, function (i) {
return (i['type'] == 'jw_n_user')
})
}
}
// 过滤掉新增的里面 状态为 disabled 的数据
filterList = _.filter(filterList, function (i) {
return typeof (i['disabled']) == 'undefined' || !i['disabled']
})
if (checked) {
selectList = selectList.concat(filterList)
} else {
let nowList = [];
_.each(selectList, function (i) {
if (_.find(filterList, { id: i['id'] })||(_.find(filterList, { oid: i['oid'] }))) {
} else {
nowList.push(i)
}
})
selectList = nowList;
}
selectList = Underscore.uniq(selectList, function (i) { return i['id']||i['oid'] })
this.setState({
select: selectList,
selectAllStatus: !this.state.selectAllStatus
})
}
unSelectAll(e) {
let list = [];
if (this.state.cantRemoveData && this.state.cantRemoveData.length != 0) {
list = this.state.cantRemoveData
}
if(Array.isArray(this.state.select)&&this.state.select.length>0){
_.each(this.state.select,(item)=>{
if(item.disabled&&(item.disabled==true || item.disabled=='disabled')){
list.push(item);
}
})
}
this.setState({
select: list
})
}
inputSearch(e) {
let self = this;
const text = e.target.value.trim();
let curId = self.props.data.nav && self.props.data.nav[0].id;
clearTimeout(this.searchTime);
this.searchTime = setTimeout(function () {
self.setState({
sk: text
})
if (text.length != 0) {
$('.share-object-cat-material-i').removeClass('active');
if(curId!="subscribe_articles"){
let url = '/api/suggestion/search?s=' + encodeURIComponent(text) + '&pageno=0&pagesize=50';
if (self.props.searchUrl) {
url = self.props.searchUrl;
url = url.replace(/{s}/, encodeURIComponent(text));
let lastParam = '';
if(url.substring(url.length-3,url.length)=='?s=' || url.substring(url.length-3,url.length)=='&s='){
url = url+encodeURIComponent(text);
}
url = url+'&pageno=0&pagesize=50';
}
request(url, {
method: 'GET'
})
.then(function (resp) {
let showId = self.props.data.nav && self.props.data.nav[0].id;
let resData;
if (showId == 'usergroup') {
resData = resp.data.JMUsergroups;
} else if (showId == 'selJssdk') {
let resD = resp.data.JMJssdks;
_.each(resD, i => i.type = 'jssdk');
resData = resD;
} else if(showId == 'groupApi'){
let resD = resp.data.JMAppsapis;
_.each(resD, i => i.type = 'groupApi');
resData = resD;
} else if(showId=='apps'||showId=='dictParent'){
resData = resp['data']['JMObjs']['list'];
} else if(showId=='instance'){
resData = resp['data']['JMTrioInsts'];
} else if(showId == 'business_dict'){
resData = resp['data']['JMAttrs'];
} else if(showId=='subscribeteam'){
resData = resp['data']['JMSubscription'];
} else {
resData = resp['data']['JMObjs'];
if(Array.isArray(resData)==false){
resData = resData['list'] || [];
}
}
self.setState({
sidbarList: resData
})
})
}else{
let params = {
src_id: '',
pageno: 0,
pagesize:50,
match_str: text,
file_types: self.props.data.file_types
}
request('/api/subscription/getarticlebysrcid', {
method: 'POST',
data: JSON.stringify(params)
})
.then(function (resp) {
self.setState({
sidbarList: resp.data.JMSubscription
})
})
}
} else {
self.setState({
sidbarList: []
})
}
}, 200)
}
searchData(e){
let self = this;
// _.throttle(()=>{
// _.debounce(()=>{
// console.log('111');
// self.fetchData(e, {id: 'searchFolder', name: '搜索'}, false);
// }, 500);
if(this.searchTimer!=undefined){
clearTimeout(this.searchTimer);
}
const text = e.target.value.trim();
this.searchTimer = setTimeout(function(){
if(text===''){
self.getFolderNav();
}else{
self.fetchData(e, {id: 'searchfile', name: COMPONENT_DICT('label.business.shareobj.search'), searchKey: text}, false);
}
}, 500);
}
fetchCustomData(e,data,page){
let self = this;
let datas = this.state['page'];
if (this.fetchIng) {
return
}
e.stopPropagation()
if (page) {
if (datas['num'] > (Number(datas['pageno']) + 1) * datas['pagesize']) {
this.fetchIng = true;
window.shareAloneTip = AloneTip({type: 'warning',duration: 200000,hasclose: false,autoHideDuration: 200000,message: COMPONENT_DICT('label.business.shareobj.loading')})
let url = '/api/suggestion/objs?type=' + data['id'] + '&pageno=' + (Number(datas['pageno']) + 1) + '&pagesize=' + datas['pagesize'] + (data['flag'] ? '&flag=' + data['flag'] : '');
if(typeof(data['op'])!=undefined){
url+='&op='+data['op']
}
request(url, {
method: 'GET'
})
.then(function (resp) {
self.fetchIng = false;
let fetchList = [].concat(self.state.data, resp["data"]["JMObjs"]["list"])
window.shareAloneTip.close();
self.setState({
data: fetchList,
page: resp["data"]["JMObjs"]["page"],
nowNav: [data]
})
})
} else {
}
} else {
this.fetchIng = true;
window.shareAloneTip = AloneTip({type: 'warning',duration: 200000,hasclose: false,autoHideDuration: 200000,message: COMPONENT_DICT('label.business.shareobj.loading')})
let url = this.props.data.url