diff --git a/.babelrc b/.babelrc
deleted file mode 100644
index 8ce15820..00000000
--- a/.babelrc
+++ /dev/null
@@ -1,4 +0,0 @@
-{
- "presets": [["next/babel"], ["@emotion/babel-preset-css-prop"]],
- "plugins": []
-}
diff --git a/babel.config.js b/babel.config.js
new file mode 100644
index 00000000..6eb07b00
--- /dev/null
+++ b/babel.config.js
@@ -0,0 +1,14 @@
+module.exports = {
+ plugins: ['@emotion/babel-plugin'],
+ presets: [
+ [
+ 'next/babel',
+ {
+ 'preset-react': {
+ runtime: 'automatic',
+ importSource: '@emotion/react',
+ },
+ },
+ ],
+ ],
+};
diff --git a/components/Button.tsx b/components/Button.tsx
index 4f6bbaf0..badc22a4 100644
--- a/components/Button.tsx
+++ b/components/Button.tsx
@@ -20,7 +20,7 @@
*/
import React, { ReactNode, ReactNodeArray } from 'react';
-import { css } from '@emotion/core';
+import { css } from '@emotion/react';
import styled from '@emotion/styled';
import defaultTheme from './theme';
diff --git a/components/ErrorNotification.tsx b/components/ErrorNotification.tsx
index 87984310..f8e8267c 100644
--- a/components/ErrorNotification.tsx
+++ b/components/ErrorNotification.tsx
@@ -19,12 +19,11 @@
*
*/
-import { css } from '@emotion/core';
+import { css, useTheme } from '@emotion/react';
import styled from '@emotion/styled';
import React from 'react';
import IconButton from './IconButton';
-import defaultTheme from './theme';
import { Error as ErrorIcon } from './theme/icons';
import DismissIcon from './theme/icons/dismiss';
@@ -61,8 +60,8 @@ const getContainerStyles = (size: ErrorSize) =>
`,
}[size]);
-const ErrorContentContainer = styled('div')`
- ${({ theme, size }: { theme: typeof defaultTheme; size: ErrorSize }) => css`
+const ErrorContentContainer = styled('div')<{ size: ErrorSize }>`
+ ${({ theme, size }) => css`
border: 1px solid ${theme.colors.error_2};
border-radius: 5px;
${theme.shadow.default};
@@ -111,82 +110,86 @@ const ErrorTitle = styled('h1')`
const ErrorNotification = ({
children,
+ className,
title,
size,
- styles = '',
onDismiss,
dismissible = false,
+ ...props
}: {
children: React.ReactNode;
+ className?: string;
title?: string;
size: ErrorSize;
styles?: string;
onDismiss?: Function;
dismissible?: boolean;
-}) => (
-
-
- {title ? (
-
-
- {' '}
- {title}
- {dismissible && (
-
- )}
-
- {children}
-
- ) : (
-
-
-
-
+}) => {
+ const theme = useTheme();
+
+ return (
+
+
+ {title ? (
+
+
+ {' '}
+ {title}
+ {dismissible && }
+
+ {children}
+
+ ) : (
- {children}
+
+
+
+
+ {children}
+
+ {dismissible && (
+
(onDismiss ? onDismiss() : () => null)}
+ Icon={DismissIcon}
+ height={12}
+ width={12}
+ fill={theme.colors.error_dark}
+ />
+ )}
- {dismissible && (
- (onDismiss ? onDismiss() : () => null)}
- Icon={DismissIcon}
- height={12}
- width={12}
- fill={defaultTheme.colors.error_dark}
- />
- )}
-
- )}
-
-
-);
+ )}
+
+
+ );
+};
export default ErrorNotification;
diff --git a/components/Footer.tsx b/components/Footer.tsx
index 6f91f1cc..f6afae4e 100644
--- a/components/Footer.tsx
+++ b/components/Footer.tsx
@@ -20,7 +20,7 @@
*/
import React from 'react';
-import { css } from '@emotion/core';
+import { css } from '@emotion/react';
import defaultTheme from './theme';
import { OvertureLogoWithText } from './theme/icons';
import StyledLink from './Link';
diff --git a/components/Head.tsx b/components/Head.tsx
index d6f22e5e..79dc9962 100644
--- a/components/Head.tsx
+++ b/components/Head.tsx
@@ -21,22 +21,8 @@
import React from 'react';
import NextHead from 'next/head';
-import { getConfig } from '../global/config';
-const Head = () => {
- const { NEXT_PUBLIC_BASE_PATH } = getConfig();
- return (
-
-
-
-
- );
-};
-
-export const PageHead = ({ subtitle }: { subtitle?: string }) => {
+const PageHead = ({ subtitle }: { subtitle?: string }) => {
return (
Overture DMS{subtitle ? ` - ${subtitle}` : ''}
@@ -44,4 +30,4 @@ export const PageHead = ({ subtitle }: { subtitle?: string }) => {
);
};
-export default Head;
+export default PageHead;
diff --git a/components/IconButton.tsx b/components/IconButton.tsx
index e99d8b42..035e4f4e 100644
--- a/components/IconButton.tsx
+++ b/components/IconButton.tsx
@@ -19,7 +19,7 @@
*
*/
-import { css } from '@emotion/core';
+import { css } from '@emotion/react';
import { IconProps } from './theme/icons/types';
const IconButton = ({
diff --git a/components/Link.tsx b/components/Link.tsx
index da26bf9b..1eaf7a89 100644
--- a/components/Link.tsx
+++ b/components/Link.tsx
@@ -20,7 +20,7 @@
*/
import styled from '@emotion/styled';
-import { css } from '@emotion/core';
+import { css } from '@emotion/react';
import Link from 'next/link';
import defaultTheme from './theme';
diff --git a/components/Loader.tsx b/components/Loader.tsx
index 0989c4b3..cc26c478 100644
--- a/components/Loader.tsx
+++ b/components/Loader.tsx
@@ -19,7 +19,7 @@
*
*/
-import { css } from '@emotion/core';
+import { css } from '@emotion/react';
// TODO: this is a placeholder Loader
const Loader = () => {
diff --git a/components/NavBar.tsx b/components/NavBar.tsx
index 4ac426c3..580f714b 100644
--- a/components/NavBar.tsx
+++ b/components/NavBar.tsx
@@ -20,7 +20,7 @@
*/
import React from 'react';
-import { css } from '@emotion/core';
+import { css, useTheme } from '@emotion/react';
import { useRouter } from 'next/router';
import UserDropdown from './UserDropdown';
@@ -28,7 +28,6 @@ import defaultTheme from './theme';
import { OvertureLogo } from './theme/icons';
import useAuthContext from '../global/hooks/useAuthContext';
import { StyledLinkAsButton, InternalLink as Link } from './Link';
-import { useTheme } from 'emotion-theming';
import { EXPLORER_PATH, LOGIN_PATH, USER_PATH } from '../global/utils/constants';
import { getConfig } from '../global/config';
diff --git a/components/PageLayout.tsx b/components/PageLayout.tsx
index a5ab6743..afb000c9 100644
--- a/components/PageLayout.tsx
+++ b/components/PageLayout.tsx
@@ -20,11 +20,11 @@
*/
import React, { ReactNode } from 'react';
-import { css } from '@emotion/core';
+import { css } from '@emotion/react';
import NavBar from './NavBar';
import Footer from './Footer';
-import { PageHead } from './Head';
+import PageHead from './Head';
import ErrorNotification from './ErrorNotification';
const PageLayout = ({ children, subtitle }: { children: ReactNode; subtitle?: string }) => {
@@ -62,7 +62,7 @@ export const ErrorPageLayout = ({
-
+
{children}
diff --git a/components/UserDropdown.tsx b/components/UserDropdown.tsx
index a8d1a322..29aae36e 100644
--- a/components/UserDropdown.tsx
+++ b/components/UserDropdown.tsx
@@ -20,9 +20,8 @@
*/
import React, { useEffect, useState, useRef } from 'react';
-import { css } from '@emotion/core';
+import { css, useTheme } from '@emotion/react';
import styled from '@emotion/styled';
-import { useTheme } from 'emotion-theming';
import defaultTheme from './theme';
import { Avatar, ChevronDown } from './theme/icons';
diff --git a/components/pages/explorer/Facets.tsx b/components/pages/explorer/Facets.tsx
index 17476b51..ad02b99c 100644
--- a/components/pages/explorer/Facets.tsx
+++ b/components/pages/explorer/Facets.tsx
@@ -19,18 +19,18 @@
*
*/
-import { css } from '@emotion/core';
import dynamic from 'next/dynamic';
+import { css, useTheme } from '@emotion/react';
import { PageContentProps } from '.';
-import defaultTheme from '../../theme';
+import { DMSThemeInterface } from '../../theme';
const Aggregations = dynamic(
import('@arranger/components/dist/Arranger').then((comp) => comp.Aggregations),
{ ssr: false },
) as any;
-const getFacetStyles = (theme: typeof defaultTheme) => css`
+const getFacetStyles = (theme: DMSThemeInterface) => css`
padding-bottom: 2rem;
.input-range-wrapper div {
${theme.typography.label2}
@@ -246,10 +246,11 @@ const getFacetStyles = (theme: typeof defaultTheme) => css`
`;
const Facets = (props: PageContentProps) => {
+ const theme: DMSThemeInterface = useTheme();
return (
- getFacetStyles(theme)}>
+
css`
+ css={css`
${theme.typography.subheading}
padding: 6px 0 2px 8px;
margin: 0;
@@ -258,6 +259,7 @@ const Facets = (props: PageContentProps) => {
>
Filters
+
);
diff --git a/components/pages/explorer/PageContent.tsx b/components/pages/explorer/PageContent.tsx
index 669940c8..51f2dbca 100644
--- a/components/pages/explorer/PageContent.tsx
+++ b/components/pages/explorer/PageContent.tsx
@@ -19,7 +19,7 @@
*
*/
-import { css } from '@emotion/core';
+import { css } from '@emotion/react';
import RepoTable from './RepoTable';
import Facets from './Facets';
import QueryBar from './QueryBar';
diff --git a/components/pages/explorer/QueryBar.tsx b/components/pages/explorer/QueryBar.tsx
index f3aefdec..0d948a85 100644
--- a/components/pages/explorer/QueryBar.tsx
+++ b/components/pages/explorer/QueryBar.tsx
@@ -19,11 +19,11 @@
*
*/
-import { css } from '@emotion/core';
import dynamic from 'next/dynamic';
+import { css, useTheme } from '@emotion/react';
import { Row } from 'react-grid-system';
-import defaultTheme from '../../theme';
+import { DMSThemeInterface } from '../../theme';
import { PageContentProps } from '.';
const CurrentSQON = dynamic(
@@ -31,7 +31,7 @@ const CurrentSQON = dynamic(
{ ssr: false },
) as any;
-const getCss = (theme: typeof defaultTheme) => css`
+const getCss = (theme: DMSThemeInterface) => css`
${theme.shadow.default};
& .sqon-view {
background-color: transparent;
@@ -40,7 +40,7 @@ const getCss = (theme: typeof defaultTheme) => css`
align-items: center;
padding: 12px 0 12px 12px;
margin: 0;
- font-family: Lato, sans-serif;
+ font-family: 'Lato', sans-serif;
color: ${theme.colors.accent_dark};
& .sqon-group {
flex-wrap: wrap;
@@ -147,10 +147,11 @@ const getCss = (theme: typeof defaultTheme) => css`
`;
const QueryBar = (props: PageContentProps) => {
+ const theme = useTheme();
return (
css`
+ css={css`
min-height: 48px;
margin: 10px 0;
background-color: ${theme.colors.white};
diff --git a/components/pages/explorer/RepoTable.tsx b/components/pages/explorer/RepoTable.tsx
index 778a5047..f1a22e49 100644
--- a/components/pages/explorer/RepoTable.tsx
+++ b/components/pages/explorer/RepoTable.tsx
@@ -19,14 +19,13 @@
*
*/
-import { css } from '@emotion/core';
import dynamic from 'next/dynamic';
+import { css, useTheme } from '@emotion/react';
import urlJoin from 'url-join';
-import { useTheme } from 'emotion-theming';
import { PageContentProps } from './index';
import StyledLink from '../../Link';
-import defaultTheme from '../../theme';
+import { DMSThemeInterface } from '../../theme';
import { getConfig } from '../../../global/config';
const Table = dynamic(
@@ -34,7 +33,7 @@ const Table = dynamic(
{ ssr: false },
) as any;
-const getTableStyle = (theme: typeof defaultTheme) => css`
+const getTableStyle = (theme: DMSThemeInterface) => css`
border-radius: 5px;
background-color: ${theme.colors.white};
padding: 8px;
@@ -230,12 +229,12 @@ const getTableStyle = (theme: typeof defaultTheme) => css`
`;
const RepoTable = (props: PageContentProps) => {
- const theme: typeof defaultTheme = useTheme();
const {
NEXT_PUBLIC_ARRANGER_API,
NEXT_PUBLIC_ARRANGER_PROJECT_ID,
NEXT_PUBLIC_ARRANGER_MANIFEST_COLUMNS,
} = getConfig();
+ const theme = useTheme();
const manifestColumns = NEXT_PUBLIC_ARRANGER_MANIFEST_COLUMNS.split(',')
.filter((field) => field.trim()) // break it into arrays, and ensure there's no empty field names
.map((fieldName) => fieldName.replace(/['"]+/g, '').trim());
@@ -282,6 +281,7 @@ const RepoTable = (props: PageContentProps) => {
columnDropdownText={'Columns'}
exporter={customExporters}
downloadUrl={urlJoin(NEXT_PUBLIC_ARRANGER_API, NEXT_PUBLIC_ARRANGER_PROJECT_ID, 'download')}
+ enableSelectedTableRowsExporterFilter
/>
);
diff --git a/components/pages/explorer/getConfigError.tsx b/components/pages/explorer/getConfigError.tsx
index f231aa93..d13474ec 100644
--- a/components/pages/explorer/getConfigError.tsx
+++ b/components/pages/explorer/getConfigError.tsx
@@ -20,7 +20,7 @@
*/
import { ReactNode } from 'react';
-import { css } from '@emotion/core';
+import { css } from '@emotion/react';
import { Checkmark, Warning } from '../../theme/icons';
import theme from '../../theme';
diff --git a/components/pages/explorer/index.tsx b/components/pages/explorer/index.tsx
index 7c428ad8..a846ef2d 100644
--- a/components/pages/explorer/index.tsx
+++ b/components/pages/explorer/index.tsx
@@ -21,6 +21,7 @@
import dynamic from 'next/dynamic';
import urlJoin from 'url-join';
+import { css, useTheme } from '@emotion/react';
import PageContent from './PageContent';
import PageLayout from '../../PageLayout';
@@ -32,7 +33,6 @@ import { useEffect, useState } from 'react';
import ErrorNotification from '../../ErrorNotification';
import getConfigError from './getConfigError';
import Loader from '../../Loader';
-import { css } from '@emotion/core';
import sleep from '../../utils/sleep';
const Arranger = dynamic(
@@ -89,6 +89,7 @@ const RepositoryPage = () => {
NEXT_PUBLIC_ARRANGER_GRAPHQL_FIELD,
NEXT_PUBLIC_ARRANGER_INDEX,
} = getConfig();
+ const theme = useTheme();
const [availableProjects, setAvailableProjects] = useState([]);
const [loadingProjects, setLoadingProjects] = useState(true);
@@ -149,7 +150,7 @@ const RepositoryPage = () => {
css`
+ ${({ theme }) => css`
${theme.typography.label};
background: ${theme.colors.grey_6};
border-radius: 2px;
@@ -143,7 +142,7 @@ const ApiTokenInfo = () => {
const [isCopyingToken, setIsCopyingToken] = React.useState(false);
const [copySuccess, setCopySuccess] = React.useState(false);
const [requestError, setRequestError] = React.useState(null);
- const theme: typeof defaultTheme = useTheme();
+ const theme = useTheme();
// still need to display any errors for the generate request, as permissions may have changed in between
// the time a user signed in and when they attempted to generate a token
@@ -303,26 +302,22 @@ const ApiTokenInfo = () => {
return (
- css`
- ${theme.typography.regular};
- font-size: 24px;
- line-height: 40px;
- color: ${theme.colors.accent_dark};
- `
- }
+ css={css`
+ ${theme.typography.regular};
+ font-size: 24px;
+ line-height: 40px;
+ color: ${theme.colors.accent_dark};
+ `}
>
API Token
- css`
- ${theme.typography.subheading};
- font-weight: normal;
- color: ${theme.colors.accent_dark};
- margin-bottom: 1rem;
- `
- }
+ css={css`
+ ${theme.typography.subheading};
+ font-weight: normal;
+ color: ${theme.colors.accent_dark};
+ margin-bottom: 1rem;
+ `}
>
- Your API token is used to download controlled access data.
-
@@ -353,7 +348,7 @@ const ApiTokenInfo = () => {
>
css`
+ css={css`
background-color: ${theme.colors.error_1};
color: ${theme.colors.accent_dark};
`}
@@ -391,16 +386,14 @@ const ApiTokenInfo = () => {