aboutsummaryrefslogtreecommitdiffstats
path: root/packages/website/ts/pages/instant/action_link.tsx
diff options
context:
space:
mode:
authorFrancesco Agosti <francesco.agosti93@gmail.com>2018-12-06 07:44:54 +0800
committerGitHub <noreply@github.com>2018-12-06 07:44:54 +0800
commit21122f0137c39835e5cf15e1a5c2bdbd20030611 (patch)
treeb0b38b40bac88612a5dad019e37087e4a27ff054 /packages/website/ts/pages/instant/action_link.tsx
parente6acc0416a0de54d53c8f50e522ee2a952c58965 (diff)
parentc282c2fcc40b6efbac7c91c3d17b204756359a26 (diff)
downloaddexon-0x-contracts-21122f0137c39835e5cf15e1a5c2bdbd20030611.tar
dexon-0x-contracts-21122f0137c39835e5cf15e1a5c2bdbd20030611.tar.gz
dexon-0x-contracts-21122f0137c39835e5cf15e1a5c2bdbd20030611.tar.bz2
dexon-0x-contracts-21122f0137c39835e5cf15e1a5c2bdbd20030611.tar.lz
dexon-0x-contracts-21122f0137c39835e5cf15e1a5c2bdbd20030611.tar.xz
dexon-0x-contracts-21122f0137c39835e5cf15e1a5c2bdbd20030611.tar.zst
dexon-0x-contracts-21122f0137c39835e5cf15e1a5c2bdbd20030611.zip
Merge pull request #1369 from 0xProject/feature/website/instant-configurator
[website][instant] Instant configurator
Diffstat (limited to 'packages/website/ts/pages/instant/action_link.tsx')
-rw-r--r--packages/website/ts/pages/instant/action_link.tsx46
1 files changed, 46 insertions, 0 deletions
diff --git a/packages/website/ts/pages/instant/action_link.tsx b/packages/website/ts/pages/instant/action_link.tsx
new file mode 100644
index 000000000..c196f03ef
--- /dev/null
+++ b/packages/website/ts/pages/instant/action_link.tsx
@@ -0,0 +1,46 @@
+import * as _ from 'lodash';
+import * as React from 'react';
+
+import { Container } from 'ts/components/ui/container';
+import { Text } from 'ts/components/ui/text';
+import { colors } from 'ts/style/colors';
+import { utils } from 'ts/utils/utils';
+
+export interface ActionLinkProps {
+ displayText: string;
+ linkSrc?: string;
+ onClick?: () => void;
+ fontSize?: number;
+ color?: string;
+ className?: string;
+}
+
+export class ActionLink extends React.Component<ActionLinkProps> {
+ public static defaultProps = {
+ fontSize: 16,
+ color: colors.white,
+ };
+ public render(): React.ReactNode {
+ const { displayText, fontSize, color, className } = this.props;
+ return (
+ <Container className={`flex items-center ${className}`} onClick={this._handleClick} cursor="pointer">
+ <Container>
+ <Text fontSize="16px" fontColor={color}>
+ {displayText}
+ </Text>
+ </Container>
+ <Container paddingTop="1px" paddingLeft="6px">
+ <i className="zmdi zmdi-chevron-right bold" style={{ fontSize, color }} />
+ </Container>
+ </Container>
+ );
+ }
+
+ private readonly _handleClick = (event: React.MouseEvent<HTMLElement>) => {
+ if (!_.isUndefined(this.props.onClick)) {
+ this.props.onClick();
+ } else if (!_.isUndefined(this.props.linkSrc)) {
+ utils.openUrl(this.props.linkSrc);
+ }
+ };
+}