2020-02-08 19:43:14 +01:00
|
|
|
import React from 'react'
|
2020-07-03 18:53:35 +02:00
|
|
|
import ReactGA from 'react-ga'
|
2020-11-08 19:15:46 +01:00
|
|
|
import 'react-jinke-music-player/assets/index.css'
|
2020-11-08 06:06:48 +01:00
|
|
|
import { Provider, useDispatch } from 'react-redux'
|
2020-03-31 20:04:10 +02:00
|
|
|
import { createHashHistory } from 'history'
|
2020-11-08 06:06:48 +01:00
|
|
|
import { Admin as RAAdmin, Resource } from 'react-admin'
|
2020-01-20 15:54:29 +01:00
|
|
|
import dataProvider from './dataProvider'
|
|
|
|
import authProvider from './authProvider'
|
2020-06-19 16:51:39 +02:00
|
|
|
import { Layout, Login, Logout } from './layout'
|
2020-03-01 02:01:09 +01:00
|
|
|
import transcoding from './transcoding'
|
2020-03-12 14:38:07 +01:00
|
|
|
import player from './player'
|
2020-01-20 02:40:18 +01:00
|
|
|
import user from './user'
|
2020-01-22 16:19:13 +01:00
|
|
|
import song from './song'
|
2020-01-22 18:32:31 +01:00
|
|
|
import album from './album'
|
2020-01-22 19:02:19 +01:00
|
|
|
import artist from './artist'
|
2020-05-06 00:28:55 +02:00
|
|
|
import playlist from './playlist'
|
2020-11-08 19:15:46 +01:00
|
|
|
import { Player } from './audioplayer'
|
2020-03-31 15:35:44 +02:00
|
|
|
import customRoutes from './routes'
|
2020-11-08 19:15:46 +01:00
|
|
|
import {
|
|
|
|
themeReducer,
|
|
|
|
addToPlaylistDialogReducer,
|
|
|
|
playQueueReducer,
|
|
|
|
albumViewReducer,
|
2020-11-08 06:06:48 +01:00
|
|
|
activityReducer,
|
2020-11-20 05:06:09 +01:00
|
|
|
settingsReducer,
|
2020-11-08 19:15:46 +01:00
|
|
|
} from './reducers'
|
2020-03-31 20:04:10 +02:00
|
|
|
import createAdminStore from './store/createAdminStore'
|
2020-05-02 23:44:24 +02:00
|
|
|
import { i18nProvider } from './i18n'
|
2020-07-03 18:53:35 +02:00
|
|
|
import config from './config'
|
2020-11-21 02:22:22 +01:00
|
|
|
import { setDispatch, startEventStream } from './eventStream'
|
2021-02-04 00:29:33 +01:00
|
|
|
import { HotKeys } from 'react-hotkeys'
|
|
|
|
import { keyMap } from './hotkeys'
|
2020-11-14 00:40:33 +01:00
|
|
|
|
2020-03-31 20:04:10 +02:00
|
|
|
const history = createHashHistory()
|
|
|
|
|
2020-07-03 18:53:35 +02:00
|
|
|
if (config.gaTrackingId) {
|
|
|
|
ReactGA.initialize(config.gaTrackingId)
|
|
|
|
history.listen((location) => {
|
|
|
|
ReactGA.pageview(location.pathname)
|
|
|
|
})
|
|
|
|
ReactGA.pageview(window.location.pathname)
|
|
|
|
}
|
|
|
|
|
2020-04-08 19:20:02 +02:00
|
|
|
const App = () => (
|
|
|
|
<Provider
|
|
|
|
store={createAdminStore({
|
|
|
|
authProvider,
|
|
|
|
dataProvider,
|
|
|
|
history,
|
|
|
|
customReducers: {
|
|
|
|
queue: playQueueReducer,
|
|
|
|
albumView: albumViewReducer,
|
2020-04-26 20:50:44 +02:00
|
|
|
theme: themeReducer,
|
2020-05-25 20:50:46 +02:00
|
|
|
addToPlaylistDialog: addToPlaylistDialogReducer,
|
2020-11-08 06:06:48 +01:00
|
|
|
activity: activityReducer,
|
2020-11-20 05:06:09 +01:00
|
|
|
settings: settingsReducer,
|
2020-04-26 20:50:44 +02:00
|
|
|
},
|
2020-04-08 19:20:02 +02:00
|
|
|
})}
|
|
|
|
>
|
2020-11-08 06:06:48 +01:00
|
|
|
<Admin />
|
|
|
|
</Provider>
|
|
|
|
)
|
|
|
|
|
|
|
|
const Admin = (props) => {
|
|
|
|
const dispatch = useDispatch()
|
2020-11-25 21:29:46 +01:00
|
|
|
if (config.devActivityPanel) {
|
2020-11-21 02:22:22 +01:00
|
|
|
setDispatch(dispatch)
|
|
|
|
authProvider
|
|
|
|
.checkAuth()
|
|
|
|
.then(() => startEventStream())
|
|
|
|
.catch(() => {}) // ignore if not logged in
|
2020-11-09 21:31:05 +01:00
|
|
|
}
|
2020-11-08 06:06:48 +01:00
|
|
|
|
|
|
|
return (
|
|
|
|
<RAAdmin
|
2021-02-01 00:50:27 +01:00
|
|
|
disableTelemetry
|
2020-04-08 19:20:02 +02:00
|
|
|
dataProvider={dataProvider}
|
|
|
|
authProvider={authProvider}
|
|
|
|
i18nProvider={i18nProvider}
|
|
|
|
customRoutes={customRoutes}
|
|
|
|
history={history}
|
|
|
|
layout={Layout}
|
|
|
|
loginPage={Login}
|
2020-06-19 16:51:39 +02:00
|
|
|
logoutButton={Logout}
|
2020-11-08 06:06:48 +01:00
|
|
|
{...props}
|
2020-02-08 19:43:14 +01:00
|
|
|
>
|
2020-04-08 19:20:02 +02:00
|
|
|
{(permissions) => [
|
2020-07-28 14:49:28 +02:00
|
|
|
<Resource name="album" {...album} options={{ subMenu: 'albumList' }} />,
|
2020-05-05 21:44:05 +02:00
|
|
|
<Resource name="artist" {...artist} options={{ subMenu: 'library' }} />,
|
2020-04-08 19:20:02 +02:00
|
|
|
<Resource name="song" {...song} options={{ subMenu: 'library' }} />,
|
2020-06-12 04:11:59 +02:00
|
|
|
<Resource
|
|
|
|
name="playlist"
|
|
|
|
{...playlist}
|
|
|
|
options={{ subMenu: 'library' }}
|
|
|
|
/>,
|
2021-04-29 04:35:25 +02:00
|
|
|
<Resource name="user" {...user} options={{ subMenu: 'settings' }} />,
|
2020-04-08 19:20:02 +02:00
|
|
|
<Resource
|
|
|
|
name="player"
|
|
|
|
{...player}
|
|
|
|
options={{ subMenu: 'settings' }}
|
|
|
|
/>,
|
|
|
|
permissions === 'admin' ? (
|
2020-03-31 20:04:10 +02:00
|
|
|
<Resource
|
2020-04-08 19:20:02 +02:00
|
|
|
name="transcoding"
|
|
|
|
{...transcoding}
|
2020-03-01 02:01:09 +01:00
|
|
|
options={{ subMenu: 'settings' }}
|
2020-04-08 19:20:02 +02:00
|
|
|
/>
|
|
|
|
) : (
|
|
|
|
<Resource name="transcoding" />
|
|
|
|
),
|
2020-05-02 00:29:50 +02:00
|
|
|
<Resource name="albumSong" />,
|
|
|
|
<Resource name="translation" />,
|
2020-05-12 03:27:00 +02:00
|
|
|
<Resource name="playlistTrack" />,
|
2020-11-24 03:28:09 +01:00
|
|
|
<Resource name="keepalive" />,
|
2020-05-25 20:50:46 +02:00
|
|
|
|
2020-04-26 20:50:44 +02:00
|
|
|
<Player />,
|
2020-04-08 19:20:02 +02:00
|
|
|
]}
|
2020-11-08 06:06:48 +01:00
|
|
|
</RAAdmin>
|
|
|
|
)
|
|
|
|
}
|
2020-02-08 06:11:15 +01:00
|
|
|
|
2021-02-04 00:29:33 +01:00
|
|
|
const AppWithHotkeys = () => (
|
|
|
|
<HotKeys keyMap={keyMap}>
|
|
|
|
<App />
|
|
|
|
</HotKeys>
|
|
|
|
)
|
|
|
|
|
|
|
|
export default AppWithHotkeys
|