"pybis/src/git@sissource.ethz.ch:sispub/openbis.git" did not exist on "f51c0ea05eb4c622da66055673fe3fde9e5c09ce"
Newer
Older
/*
* Copyright ETH 2023 Zürich, Scientific IT Services
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
import React from 'react'
import Button from '@material-ui/core/Button'
import CreateNewFolderIcon from '@material-ui/icons/CreateNewFolderOutlined'
import DownloadIcon from '@material-ui/icons/GetApp'
import DeleteIcon from '@material-ui/icons/Delete'
import RenameIcon from '@material-ui/icons/Create'
import CopyIcon from '@material-ui/icons/FileCopy'
import MoveIcon from '@material-ui/icons/ArrowRightAlt'
import messages from '@src/js/common/messages.js'
import { withStyles } from '@material-ui/core/styles'
import logger from "@src/js/common/logger.js";
import autoBind from "auto-bind";
const color = 'secondary'
const styles = theme => ({
buttons: {
flex: '1 0 auto',
display: 'flex',
alignItems: 'center',
whiteSpace: 'nowrap',
'&>button': {
marginRight: theme.spacing(1)
},
'&>button:nth-last-child(1)': {
marginRight: 0
}
},
toggleButton: {}
})
class LeftToolbar extends React.Component {
constructor(props, context) {
super(props, context)
autoBind(this)
this.controller = this.props.controller
}
renderNoSelectionContextToolbar() {
const { classes, buttonSize } = this.props
return (
<div className={classes.buttons}>
<Button
classes={{ root: classes.button }}
color={color}
size={buttonSize}
variant='outlined'
startIcon={<CreateNewFolderIcon />}
onClick={this.controller.handleNewFolderClick}
>
{messages.get(messages.NEW_FOLDER)}
</Button>
</div>
)
}
renderSelectionContextToolbar() {
const { classes, buttonSize } = this.props
return (
<div className={classes.buttons}>
<Button
classes={{ root: classes.button }}
color={color}
size={buttonSize}
variant='outlined'
startIcon={<DownloadIcon />}
onClick={this.controller.handleNewFolderClick}
>
{messages.get(messages.DOWNLOAD)}
</Button>
<Button
classes={{ root: classes.button }}
color={color}
size={buttonSize}
startIcon={<DeleteIcon />}
onClick={this.controller.handleNewFolderClick}
>
{messages.get(messages.DELETE)}
</Button>
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
<Button
classes={{ root: classes.button }}
color={color}
size={buttonSize}
variant='text'
startIcon={<RenameIcon />}
onClick={this.controller.handleNewFolderClick}
>
{messages.get(messages.RENAME)}
</Button>
<Button
classes={{ root: classes.button }}
color={color}
size={buttonSize}
variant='text'
startIcon={<CopyIcon />}
onClick={this.controller.handleNewFolderClick}
>
{messages.get(messages.COPY)}
</Button>
<Button
classes={{ root: classes.button }}
color={color}
size={buttonSize}
variant='text'
startIcon={<MoveIcon />}
onClick={this.controller.handleNewFolderClick}
>
{messages.get(messages.MOVE)}
</Button>
</div>
)
}
render() {
logger.log(logger.DEBUG, 'LeftToolbar.render')
const { multiselectedFiles } = this.props
console.log("multiselectedFiles: " + multiselectedFiles)
console.log(multiselectedFiles.size)
console.log("multiselectedFiles.size: " + multiselectedFiles.size)
return multiselectedFiles && multiselectedFiles.size > 0
? this.renderSelectionContextToolbar()
: this.renderNoSelectionContextToolbar()
}
}
export default withStyles(styles)(LeftToolbar)