mirror of
https://github.com/captbaritone/webamp.git
synced 2026-01-23 10:15:31 +00:00
57 lines
1.5 KiB
JavaScript
57 lines
1.5 KiB
JavaScript
import React from "react";
|
|
import { connect } from "react-redux";
|
|
import ClickedDiv from "../ClickedDiv";
|
|
import {
|
|
close,
|
|
setSkinFromUrl,
|
|
openMediaFileDialog,
|
|
openSkinFileDialog,
|
|
openDropboxFileDialog
|
|
} from "../../actionCreators";
|
|
import { ContextMenu, Hr, Node, Parent, LinkNode } from "../ContextMenu";
|
|
|
|
const MainContextMenu = props => (
|
|
<ContextMenu
|
|
id="option-context"
|
|
bottom
|
|
handle={<ClickedDiv id="option" title="Winamp Menu" />}
|
|
>
|
|
<LinkNode
|
|
href="https://github.com/captbaritone/winamp2-js"
|
|
target="_blank"
|
|
label="Winamp2-js"
|
|
/>
|
|
<Hr />
|
|
<Parent label="Play">
|
|
<Node onClick={props.openMediaFileDialog} label="File..." />
|
|
<Node onClick={props.openDropboxFileDialog} label="Dropbox..." />
|
|
</Parent>
|
|
<Parent label="Skins">
|
|
<Node onClick={props.openSkinFileDialog} label="Load Skin..." />
|
|
{!!props.avaliableSkins.length && <Hr />}
|
|
{props.avaliableSkins.map(skin => (
|
|
<Node
|
|
key={skin.url}
|
|
onClick={() => props.setSkin(skin.url)}
|
|
label={skin.name}
|
|
/>
|
|
))}
|
|
</Parent>
|
|
<Hr />
|
|
<Node onClick={props.close} label="Exit" />
|
|
</ContextMenu>
|
|
);
|
|
|
|
const mapStateToProps = state => ({
|
|
avaliableSkins: state.settings.avaliableSkins
|
|
});
|
|
|
|
const mapDispatchToProps = {
|
|
close,
|
|
openSkinFileDialog,
|
|
openMediaFileDialog,
|
|
openDropboxFileDialog,
|
|
setSkin: setSkinFromUrl
|
|
};
|
|
|
|
export default connect(mapStateToProps, mapDispatchToProps)(MainContextMenu);
|