From de8f5e071d8e0968ac9a71ee3eacb43220883f36 Mon Sep 17 00:00:00 2001 From: Neshura Date: Thu, 16 Mar 2023 22:19:56 +0100 Subject: [PATCH] Added "open" icon to cards, removed old code --- components/styles/cards/mobile.tsx | 226 ++--------------------------- 1 file changed, 11 insertions(+), 215 deletions(-) diff --git a/components/styles/cards/mobile.tsx b/components/styles/cards/mobile.tsx index a744d0a..f984bb2 100644 --- a/components/styles/cards/mobile.tsx +++ b/components/styles/cards/mobile.tsx @@ -2,7 +2,7 @@ import { Service } from '../../../interfaces/CardTypes'; import styled, { css, DefaultTheme } from 'styled-components'; import Link from 'next/link'; import Image from 'next/image'; -import { Dispatch, SetStateAction, useState } from 'react'; +import OpenInNewTabIcon from '../../../public/icons/open-new-window.svg' // needed for Online Status checks interface OnlinePropType { @@ -18,8 +18,8 @@ const Card = styled.div` width: 30rem; max-width: 90%; min-height: 10rem; - max-height: 15rem; - margin-bottom: 2rem; + max-height: 12.5rem; + margin: 1rem; // themeing border-top: 0.25rem solid; @@ -60,18 +60,13 @@ const CardTitleIcon = styled.div` `; const OpenInNewTab = styled.div` - filter: invert(); + color: ${({theme}) => theme.colors.primary }; position: relative; object-fit: contain; - margin: 0.3rem; + padding: 0.2rem; margin-left: 0.5rem; aspect-ratio: 1; - height: 1.2rem; -` - -const CardTitleIconMirror = styled.div` height: 1.5rem; - aspect-ratio: 1; ` const CardStatus = styled.p` @@ -84,31 +79,8 @@ const CardStatus = styled.p` border: 0; border-bottom: 0.125rem solid; - ${({ theme }) => { - let ret; - - if (theme.backgroundImage) { - ret = css` - background-image: ${() => { - return css` - linear-gradient(${theme.colors.background}, ${theme.colors.background}), - url(${theme.backgroundImage}) - ` - }}; - background-repeat: no-repeat; - background-attachment: fixed; - background-size: cover; - background-position: 60%; - `; - } - else { - ret = css` - background-color: ${({ theme }) => theme.colors.background}; - `; - } - - return ret; - }}; + background: transparent; + color: ${props => { let ret; switch (props.status) { @@ -155,7 +127,7 @@ const CardTitle = ({ content, href }: { content: Service, href: string }) => { if (href) { card = ( - + { content.icon ? ( @@ -165,11 +137,9 @@ const CardTitle = ({ content, href }: { content: Service, href: string }) => { } {content.name} { - content.icon ? ( - open + - ) : (<>) } {content.status} @@ -189,11 +159,6 @@ const CardTitle = ({ content, href }: { content: Service, href: string }) => { ) : (<>) } {content.name} - { - content.icon ? ( - - ) : (<>) - } {content.status} @@ -218,7 +183,7 @@ const CardDescriptionWrap = styled.div` ${CardDescriptionCommon} padding: 0 1rem; margin-bottom: 2rem; - overflow-y: scroll; + overflow: hidden; /* Hide scrollbars */ scrollbar-width: thin; width: 100%; @@ -247,7 +212,7 @@ const CardDescription = ({ content }: { content: Service }) => { {content.warn}

- {content.extName} + Official Site ); @@ -264,7 +229,6 @@ export const ServiceCardMobile = ({ content }: { content: Service }) => { // TEMP if (content.href) { - // TODO: adjust sizes card = ( @@ -282,172 +246,4 @@ export const ServiceCardMobile = ({ content }: { content: Service }) => { } return card; -} - -// TODO: remove unneeded exports - -//############# -// OLD ELEMENTS -//############# - -const CardStyle = css` - display: flex; - flex-direction: column; - align-items: center; - position: relative; - width: 332px; - height: 240px; -`; -const CardLink = styled(Link)` - ${CardStyle} -`; -const CardStyleWrap = styled.div` - ${CardStyle} -`; -// replaces .card & .contentcard -const PageCard = styled.div` - margin: 1rem; - padding: 23px 10px; - text-align: center; - color: ${({ theme }) => theme.colors.primary}; - background-color: ${({ theme }) => theme.colors.background}; - text-decoration: none; - border: 2px solid; - border-radius: 10px; - border-color: ${({ theme }) => theme.colors.primary}; - transition: all 0.1s linear; - width: 300px; - height: 200px; - display: flex; - flex-direction: column; - justify-content: space-between; - - h2 { - margin: 0 0 1rem 0; - font-size: 1.5rem; - } - - p { - margin: 0; - font-size: 1rem; - line-height: 1.5; - } - - ${CardStyleWrap}:focus,${CardStyleWrap}:active,${CardStyleWrap}:hover & { - color: ${({ theme }) => theme.colors.secondary}; - border-color: ${({ theme }) => theme.colors.secondary}; - background-color: ${({ theme }) => theme.invertButtons ? - theme.colors.backgroundAlt ? theme.colors.backgroundAlt : theme.colors.background : theme.colors.background}; - } - - ${CardLink}:focus,${CardLink}:active,${CardLink}:hover & { - color: ${({ theme }) => theme.colors.secondary}; - border-color: ${({ theme }) => theme.colors.secondary}; - background-color: ${({ theme }) => theme.invertButtons ? - theme.colors.backgroundAlt ? theme.colors.backgroundAlt : theme.colors.background : theme.colors.background}; - } -`; -// replaces the three status classes -const OnlineStatus = styled.p` - color: ${props => { - let ret; - switch (props.status) { - case "Online": - ret = ({ theme }: { theme: DefaultTheme }) => theme.colors.online; - break; - case "Loading": - ret = ({ theme }: { theme: DefaultTheme }) => theme.colors.loading; - break; - case "Offline": - ret = ({ theme }: { theme: DefaultTheme }) => theme.colors.offline; - break; - default: - ret = ({ theme }: { theme: DefaultTheme }) => theme.colors.offline; - } - return ret; - }}; - padding: 0.2rem; - border: 1px solid; - border-color: ${({ theme }) => theme.colors.primary}; - border-radius: 5px; - width: min-content; - position: absolute; - top: 100; right: 50; bottom: 0; left: 50; - offset-position: bottom 10px; - transition: color 0.15s ease, border-color 0.15s ease; - background-color: ${({ theme }) => theme.colors.background}; - background-image: ${({ theme }) => theme.backgroundImage ? - "linear-gradient(" - + theme.colors.background + "," + theme.colors.background + - "), url(" + theme.backgroundImage + ")" : ""}; - background-repeat: no-repeat; - background-attachment: fixed; - background-size: cover; - - ${CardStyleWrap}:focus,${CardStyleWrap}:active,${CardStyleWrap}:hover & { - border-color: ${({ theme }) => theme.colors.secondary}; - background-color: ${({ theme }) => theme.invertButtons ? - theme.colors.backgroundAlt ? theme.colors.backgroundAlt : theme.colors.background : theme.colors.background}; - } - - ${CardLink}:focus,${CardLink}:active,${CardLink}:hover & { - border-color: ${({ theme }) => theme.colors.secondary}; - background-color: ${({ theme }) => theme.invertButtons ? - theme.colors.backgroundAlt ? theme.colors.backgroundAlt : theme.colors.background : theme.colors.background}; - } -`; -// replaces .cardwarn -const CardContentWarning = styled.p` - color: ${({ theme }) => theme.colors.secondary}; - -`; -// replaces .contentTitle -const CardContentTitleWrap = styled.div` - position: relative; - display: flex; - flex-direction: row; - justify-content: center; - align-items: center; - margin-bottom: 1rem; - - h2 { - margin: 0; - white-space: nowrap; - } -`; -const CardContentTitle = ({ content }: { content: Service }) => { - return ( - -

{content.name}

-
- ) -} -// Card Content Component for Services Page -const MobileServiceCardOld = ({ content }: { content: Service }) => { - let ret; - if (content.href) { - ret = ( - - - -

{content.desc}

- {content.warn} -
- {content.status} -
- ) - } - else { - ret = ( - - - -

{content.desc}

- {content.warn} -
- {content.status} -
- ) - } - return ret; } \ No newline at end of file