mirror of
https://github.com/captbaritone/webamp.git
synced 2026-01-24 02:36:00 +00:00
48 lines
1.4 KiB
JavaScript
48 lines
1.4 KiB
JavaScript
import React from "react";
|
|
import { connect } from "react-redux";
|
|
import WindowManager from "./WindowManager";
|
|
import MainWindow from "./MainWindow";
|
|
import PlaylistWindow from "./PlaylistWindow";
|
|
import EqualizerWindow from "./EqualizerWindow";
|
|
import Skin from "./Skin";
|
|
import { equalizerEnabled, playlistEnabled } from "../config";
|
|
|
|
const App = ({ winamp, loading, closed, equalizer, playlist }) => {
|
|
if (closed) {
|
|
return null;
|
|
}
|
|
if (loading) {
|
|
return (
|
|
<div id="loading">
|
|
Loading<span className="ellipsis-anim">
|
|
<span>.</span>
|
|
<span>.</span>
|
|
<span>.</span>
|
|
</span>
|
|
</div>
|
|
);
|
|
}
|
|
return (
|
|
<div id="loaded">
|
|
<Skin>
|
|
{/* This is not technically kosher, since <style> tags should be in
|
|
the <head>, but browsers don't really care... */}
|
|
</Skin>
|
|
<WindowManager>
|
|
<MainWindow fileInput={winamp.fileInput} mediaPlayer={winamp.media} />
|
|
{equalizerEnabled &&
|
|
equalizer && <EqualizerWindow fileInput={winamp.fileInput} />}
|
|
{playlistEnabled && playlist && <PlaylistWindow />}
|
|
</WindowManager>
|
|
</div>
|
|
);
|
|
};
|
|
|
|
const mapStateToProps = state => ({
|
|
loading: state.display.loading,
|
|
closed: state.display.closed,
|
|
equalizer: state.windows.equalizer,
|
|
playlist: state.windows.playlist
|
|
});
|
|
|
|
export default connect(mapStateToProps)(App);
|