From e249a465bb90556aae8a395b9bbe81f1bd7edae2 Mon Sep 17 00:00:00 2001
From: Antonette Caldwell <134739862+nebula-aac@users.noreply.github.com>
Date: Fri, 26 Apr 2024 14:17:07 +0000
Subject: [PATCH] feat: move custom button to styled
Signed-off-by: Antonette Caldwell <134739862+nebula-aac@users.noreply.github.com>
---
src/base/Button/Button.tsx | 16 ---
src/custom/Modal/index.tsx | 2 +-
src/styled/button/index.tsx | 193 ++++++++++++++++++++++++++++++++++++
src/styled/index.ts | 1 +
4 files changed, 195 insertions(+), 17 deletions(-)
create mode 100644 src/styled/button/index.tsx
create mode 100644 src/styled/index.ts
diff --git a/src/base/Button/Button.tsx b/src/base/Button/Button.tsx
index 534ae2de0..bc5a6fce7 100644
--- a/src/base/Button/Button.tsx
+++ b/src/base/Button/Button.tsx
@@ -14,20 +14,4 @@ export function Button({ label, children, ...props }: ButtonProps): JSX.Element
);
}
-export const ContainedButton = (props: ButtonProps): JSX.Element => (
-
-);
-export const OutlinedButton = (props: ButtonProps): JSX.Element => (
-
-);
-export const TextButton = (props: ButtonProps): JSX.Element => (
-
-);
-
export default Button;
diff --git a/src/custom/Modal/index.tsx b/src/custom/Modal/index.tsx
index feff30922..f563339d6 100644
--- a/src/custom/Modal/index.tsx
+++ b/src/custom/Modal/index.tsx
@@ -1,9 +1,9 @@
import { DialogProps, styled } from '@mui/material';
import React, { useRef, useState } from 'react';
import { Dialog, IconButton, Paper, Typography } from '../../base';
-import { ContainedButton, OutlinedButton, TextButton } from '../../base/Button/Button';
import { iconLarge } from '../../constants/iconsSizes';
import { CloseIcon, InfoCircleIcon } from '../../icons';
+import { ContainedButton, OutlinedButton, TextButton } from '../../styled';
import { CustomTooltip } from '../CustomTooltip';
interface ModalProps extends DialogProps {
diff --git a/src/styled/button/index.tsx b/src/styled/button/index.tsx
new file mode 100644
index 000000000..c28ef6c63
--- /dev/null
+++ b/src/styled/button/index.tsx
@@ -0,0 +1,193 @@
+import { styled } from '@mui/material/styles';
+import React from 'react';
+import Button, { ButtonProps } from '../../base/Button/Button';
+import { darkTeal } from '../../theme/colors';
+
+export function ContainedButton(props: ButtonProps): React.JSX.Element {
+ return ;
+}
+
+export function OutlinedButton(props: ButtonProps): React.JSX.Element {
+ return ;
+}
+
+export function TextButton(props: ButtonProps): React.JSX.Element {
+ return ;
+}
+
+export function SecondaryContainedButton(props: ButtonProps): React.JSX.Element {
+ return ;
+}
+
+export function LargeContainedButton(props: ButtonProps): React.JSX.Element {
+ return ;
+}
+
+/**
+ * Renders the default style for the Button
+ */
+export const DefaultButton = styled(Button)(() => ({}));
+
+/**
+ * Renders the style for `variant="contained"`
+ */
+export const ContainedDefaultButton = styled(ContainedButton)(() => ({}));
+
+/**
+ * Renders the style for `variant="outlined"`
+ */
+export const OutlinedDefaultButton = styled(OutlinedButton)(() => ({}));
+
+/**
+ * Renders the style for `variant="text"`
+ */
+export const TextDefaultButton = styled(TextButton)(() => ({}));
+
+/**
+ * Renders the style for `variant="contained" color="secondary"`
+ */
+export const SecondaryContainedDefaultButton = styled(SecondaryContainedButton)(() => ({}));
+
+/**
+ * Exports the `StyledButton` which inherits the `DefaultButton`
+ */
+export const StyledButton = DefaultButton;
+
+export const GetStartedButton = styled(ContainedDefaultButton)(() => ({}));
+
+export const LoginButton = styled(SecondaryContainedButton)(() => ({}));
+
+export const AddButton = styled(ContainedDefaultButton)(({ theme }) => ({
+ margin: theme.spacing(1)
+}));
+
+export const EditButton = styled(ContainedDefaultButton)(() => ({
+ '@media (max-width: 768px)': {
+ minWidth: '50px'
+ }
+}));
+
+export const SpanTextButton = styled('span')(() => ({
+ marginLeft: '0.5rem',
+ display: 'block',
+ '@media (max-width: 853px)': {
+ display: 'none'
+ }
+}));
+
+export const DeleteButton = styled(DefaultButton)(() => ({}));
+
+export const DenyButton = styled(DefaultButton)(() => ({}));
+
+export const ApproveButton = styled(ContainedDefaultButton)(() => ({
+ marginRight: '.5rem'
+}));
+
+export const CancelButton = styled(DefaultButton)(() => ({
+ marginRight: '1rem',
+ color: '#000',
+ backgroundColor: '#fff'
+}));
+
+export const SaveButton = styled(ContainedDefaultButton)(() => ({
+ marginRight: '1rem'
+}));
+
+export const ConnectButton = styled(ContainedDefaultButton)(() => ({
+ marginTop: '1rem'
+}));
+
+export const FilterButton = styled(ContainedDefaultButton)(() => ({
+ height: '3.5rem'
+}));
+
+export const ActionButton = styled(ContainedDefaultButton)(() => ({}));
+
+export const TableCtrlButton = styled(SecondaryContainedDefaultButton)(() => ({
+ '&:first-child': {
+ marginRight: '1rem'
+ }
+}));
+
+export const RangeButton = styled(DefaultButton)(() => ({
+ border: '1px solid rgba(0, 0, 0, 0.23)',
+ backgroundColor: 'white'
+}));
+
+export const ErrorCloseButton = styled(DefaultButton)(() => ({}));
+
+export const TryAgainButton = styled(OutlinedButton)(() => ({}));
+
+export const TransferButton = styled(DefaultButton)(() => ({
+ margin: '5px 0',
+ padding: '7px 0',
+ borderRadius: '10px',
+ boxShadow: 'none',
+ borderColor: darkTeal.main,
+ '&:hover': {
+ borderColor: darkTeal.main
+ }
+}));
+
+export const CardStatsBox = styled(ContainedDefaultButton)(() => ({
+ display: 'flex',
+ alignItems: 'center',
+ flexDirection: 'column',
+ padding: '5px',
+ minWidth: '175px',
+ borderRadius: '5px',
+ marginBottom: '10px'
+}));
+
+export const IconButton = styled(DefaultButton)({
+ minWidth: 'fit-content',
+ '&.MuiButtonBase-root:hover': {
+ bgcolor: 'transparent'
+ }
+});
+
+export const PopupButton = styled(DefaultButton)(({ theme }) => ({
+ width: '100%',
+ borderRadius: '4px',
+ background: theme.palette.common.white,
+ color: theme.palette.text.secondary,
+ boxShadow: '0px 4px 4px 0px rgba(0, 0, 0, 0.25)',
+ display: 'flex',
+ flexDirection: 'column',
+ marginBottom: '10px'
+}));
+
+export const ConnectionsButton = styled(ContainedDefaultButton)(() => ({
+ marginTop: '1rem',
+ marginRight: '1rem',
+ padding: '1.5rem, 1.5rem',
+ width: 'object-fit'
+}));
+
+/** Review later
+export const TOSButton = styled("a")(({ theme }) => ({
+ display: "flex",
+ padding: "0.5rem 2rem",
+ color: theme.palette.common.white,
+ backgroundColor: theme.palette.keppelGreen,
+ borderRadius: "5px",
+ transition: "all .3s",
+ boxShadow: "0 1px 20px rgba(0, 0, 0, 0.2)",
+ "&:hover": {
+ backgroundColor: theme.palette.caribbeanGreen,
+ },
+}));
+
+export const PrivacyButton = styled("a")(({ theme }) => ({
+ display: "flex",
+ padding: "0.5rem 2rem",
+ color: theme.palette.common.white,
+ backgroundColor: theme.palette.keppelGreen,
+ borderRadius: "5px",
+ transition: "all .3s",
+ boxShadow: "0 1px 20px rgba(0, 0, 0, 0.2)",
+ "&:hover": {
+ backgroundColor: theme.palette.caribbeanGreen,
+ },
+}));
+*/
diff --git a/src/styled/index.ts b/src/styled/index.ts
new file mode 100644
index 000000000..eaf5eea7f
--- /dev/null
+++ b/src/styled/index.ts
@@ -0,0 +1 @@
+export * from './button';