You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
116 lines
3.3 KiB
116 lines
3.3 KiB
/*
|
|
* Minio Browser (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.
|
|
*/
|
|
|
|
import './less/main.less'
|
|
|
|
import React from 'react'
|
|
import ReactDOM from 'react-dom'
|
|
import thunkMiddleware from 'redux-thunk'
|
|
import createStore from 'redux/lib/createStore'
|
|
import applyMiddleware from 'redux/lib/applyMiddleware'
|
|
|
|
import Route from 'react-router/lib/Route'
|
|
import Router from 'react-router/lib/Router'
|
|
import browserHistory from 'react-router/lib/browserHistory'
|
|
import IndexRoute from 'react-router/lib/IndexRoute'
|
|
|
|
import Provider from 'react-redux/lib/components/Provider'
|
|
import connect from 'react-redux/lib/components/connect'
|
|
|
|
import Moment from 'moment'
|
|
|
|
import { minioBrowserPrefix } from './js/constants.js'
|
|
import * as actions from './js/actions.js'
|
|
import reducer from './js/reducers.js'
|
|
|
|
import _Login from './js/components/Login.js'
|
|
import _Browse from './js/components/Browse.js'
|
|
import fontAwesome from 'font-awesome/css/font-awesome.css'
|
|
|
|
import Web from './js/web'
|
|
window.Web = Web
|
|
|
|
import storage from 'local-storage-fallback'
|
|
|
|
const store = applyMiddleware(thunkMiddleware)(createStore)(reducer)
|
|
const Browse = connect(state => state)(_Browse)
|
|
const Login = connect(state => state)(_Login)
|
|
|
|
let web = new Web(`${window.location.protocol}//${window.location.host}${minioBrowserPrefix}/webrpc`, store.dispatch)
|
|
|
|
window.web = web
|
|
|
|
store.dispatch(actions.setWeb(web))
|
|
|
|
function authNeeded(nextState, replace, cb) {
|
|
if (web.LoggedIn()) {
|
|
return cb()
|
|
}
|
|
if (location.pathname === minioBrowserPrefix || location.pathname === minioBrowserPrefix + '/') {
|
|
replace(`${minioBrowserPrefix}/login`)
|
|
}
|
|
return cb()
|
|
}
|
|
|
|
function authNotNeeded(nextState, replace) {
|
|
if (web.LoggedIn()) {
|
|
replace(`${minioBrowserPrefix}`)
|
|
}
|
|
}
|
|
|
|
const App = (props) => {
|
|
return <div>
|
|
{ props.children }
|
|
</div>
|
|
}
|
|
|
|
ReactDOM.render((
|
|
<Provider store={ store } web={ web }>
|
|
<Router history={ browserHistory }>
|
|
<Route path='/' component={ App }>
|
|
<Route path='minio' component={ App }>
|
|
<IndexRoute component={ Browse } onEnter={ authNeeded } />
|
|
<Route path='login' component={ Login } onEnter={ authNotNeeded } />
|
|
<Route path=':bucket' component={ Browse } onEnter={ authNeeded } />
|
|
<Route path=':bucket/*' component={ Browse } onEnter={ authNeeded } />
|
|
</Route>
|
|
</Route>
|
|
</Router>
|
|
</Provider>
|
|
), document.getElementById('root'))
|
|
|
|
//Page loader
|
|
let delay = [0, 400]
|
|
let i = 0
|
|
|
|
function handleLoader() {
|
|
if (i < 2) {
|
|
setTimeout(function() {
|
|
document.querySelector('.page-load').classList.add('pl-' + i)
|
|
i++
|
|
handleLoader()
|
|
}, delay[i])
|
|
}
|
|
}
|
|
handleLoader()
|
|
|
|
if (storage.getItem('newlyUpdated')) {
|
|
store.dispatch(actions.showAlert({
|
|
type: 'success',
|
|
message: "Updated to the latest UI Version."
|
|
}))
|
|
storage.removeItem('newlyUpdated')
|
|
}
|
|
|