lbry-desktop/ui/js/component/link/view.jsx

57 lines
1.2 KiB
React
Raw Normal View History

2017-06-06 17:19:12 -04:00
import React from "react";
import { Icon } from "component/common.js";
2017-04-07 12:15:22 +07:00
2017-06-05 21:21:55 -07:00
const Link = props => {
2017-04-07 12:15:22 +07:00
const {
href,
title,
style,
label,
icon,
button,
disabled,
2017-05-05 12:10:37 +07:00
children,
2017-08-20 17:42:00 -04:00
navigate,
2017-09-17 14:26:55 -04:00
navigateParams,
2017-08-20 17:42:00 -04:00
doNavigate,
2017-06-06 17:19:12 -04:00
} = props;
2017-04-07 12:15:22 +07:00
2017-06-06 17:19:12 -04:00
const className =
(props.className || "") +
2017-08-15 17:42:48 -04:00
(!props.className && !button ? "button-text" : "") + // Non-button links get the same look as text buttons
(button ? " button-block button-" + button + " button-set-item" : "") +
(disabled ? " disabled" : "");
2017-04-07 12:15:22 +07:00
2017-08-25 23:21:26 -04:00
const onClick = !props.onClick && navigate
? () => {
2017-09-17 14:26:55 -04:00
doNavigate(navigate, navigateParams || {});
2017-08-25 23:21:26 -04:00
}
: props.onClick;
2017-08-20 17:42:00 -04:00
2017-04-07 12:15:22 +07:00
let content;
2017-05-05 12:10:37 +07:00
if (children) {
2017-06-06 17:19:12 -04:00
content = children;
2017-04-07 12:15:22 +07:00
} else {
content = (
2017-06-06 17:19:12 -04:00
<span {...("button" in props ? { className: "button__content" } : {})}>
{"icon" in props ? <Icon icon={icon} fixed={true} /> : null}
2017-04-07 12:15:22 +07:00
{label ? <span className="link-label">{label}</span> : null}
</span>
2017-06-06 17:19:12 -04:00
);
2017-04-07 12:15:22 +07:00
}
return (
2017-06-06 17:19:12 -04:00
<a
className={className}
href={href || "javascript:;"}
title={title}
2017-04-07 12:15:22 +07:00
onClick={onClick}
2017-06-06 17:19:12 -04:00
{...("style" in props ? { style: style } : {})}
>
2017-04-07 12:15:22 +07:00
{content}
</a>
);
2017-06-05 21:21:55 -07:00
};
2017-04-07 12:15:22 +07:00
2017-06-05 21:21:55 -07:00
export default Link;