minio/browser/app/js/objects/Path.js

67 lines
1.8 KiB
JavaScript
Raw Normal View History

/*
* Minio Cloud Storage (C) 2016 Minio, Inc.
*
* 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.
*/
2018-02-09 21:34:14 -05:00
import React from "react"
import { connect } from "react-redux"
import { getCurrentBucket } from "../buckets/selectors"
import * as actionsObjects from "./actions"
2018-02-09 21:34:14 -05:00
export const Path = ({ currentBucket, currentPrefix, selectPrefix }) => {
const onPrefixClick = (e, prefix) => {
e.preventDefault()
selectPrefix(prefix)
}
let dirPath = []
2018-02-09 21:34:14 -05:00
let path = ""
if (currentPrefix) {
path = currentPrefix.split("/").map((dir, i) => {
if (dir) {
dirPath.push(dir)
let dirPath_ = dirPath.join("/") + "/"
return (
<a key={i} href="" onClick={e => onPrefixClick(e, dirPath_)}>
{dir}
</a>
2018-02-09 21:34:14 -05:00
)
}
})
}
return (
<nav className="path hidden-xs">
<a onClick={e => onPrefixClick(e, "")} href="">
{currentBucket}
</a>
2018-02-09 21:34:14 -05:00
{path}
</nav>
)
}
2018-02-09 21:34:14 -05:00
const mapStateToProps = state => {
return {
2018-02-09 21:34:14 -05:00
currentBucket: getCurrentBucket(state),
currentPrefix: state.objects.currentPrefix
}
2018-02-09 21:34:14 -05:00
}
const mapDispatchToProps = dispatch => {
return {
selectPrefix: prefix => dispatch(actionsObjects.selectPrefix(prefix))
2018-02-09 21:34:14 -05:00
}
}
export default connect(mapStateToProps, mapDispatchToProps)(Path)