Skip to content

Commit

Permalink
refactor: [M3-8827] - Migrate CircleProgress to ui package (#11214)
Browse files Browse the repository at this point in the history
  • Loading branch information
jaalah-akamai authored Nov 14, 2024
1 parent 1d0051e commit afbd8d9
Show file tree
Hide file tree
Showing 130 changed files with 263 additions and 289 deletions.
5 changes: 5 additions & 0 deletions packages/manager/.changeset/pr-11214-removed-1730844124766.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"@linode/manager": Removed
---

Migrate CircleProgress to ui package ([#11214](https://github.com/linode/manager/pull/11214))
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import { CircleProgress } from '@linode/ui';
import { Box, InputAdornment } from '@linode/ui';
import CloseIcon from '@mui/icons-material/Close';
import KeyboardArrowDownIcon from '@mui/icons-material/KeyboardArrowDown';
Expand All @@ -6,7 +7,6 @@ import React from 'react';

import { TextField } from 'src/components/TextField';

import { CircleProgress } from '../CircleProgress';
import {
CustomPopper,
SelectedIcon,
Expand Down
1 change: 0 additions & 1 deletion packages/manager/src/components/CircleProgress/index.ts

This file was deleted.

Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
import { CircleProgress } from '@linode/ui';
import { IconButton, InputAdornment } from '@linode/ui';
import Clear from '@mui/icons-material/Clear';
import Search from '@mui/icons-material/Search';
import { styled } from '@mui/material/styles';
import * as React from 'react';
import { debounce } from 'throttle-debounce';

import { CircleProgress } from 'src/components/CircleProgress';
import { TextField } from 'src/components/TextField';

import type { TextFieldProps } from 'src/components/TextField';
Expand Down
Original file line number Diff line number Diff line change
@@ -1,8 +1,6 @@
import { Notice } from '@linode/ui';
import { CircleProgress, Notice } from '@linode/ui';
import * as React from 'react';

import { CircleProgress } from 'src/components/CircleProgress';

export interface DrawerContentProps {
children: React.ReactNode;
error: boolean;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,8 +1,7 @@
import { CircleProgress } from '@linode/ui';
import { styled } from '@mui/material/styles';
import * as React from 'react';

import { CircleProgress } from 'src/components/CircleProgress';

export const LoadingIndicator = () => {
return <StyledCircleProgress data-testid="input-loading" size="sm" />;
};
Expand Down
4 changes: 1 addition & 3 deletions packages/manager/src/components/LinkButton.tsx
Original file line number Diff line number Diff line change
@@ -1,9 +1,7 @@
import { Box } from '@linode/ui';
import { Box, CircleProgress } from '@linode/ui';
import * as React from 'react';
import { makeStyles } from 'tss-react/mui';

import { CircleProgress } from 'src/components/CircleProgress';

import { StyledLinkButton } from './Button/StyledLinkButton';

import type { Theme } from '@mui/material/styles';
Expand Down
35 changes: 17 additions & 18 deletions packages/manager/src/components/PromiseLoader/PromiseLoader.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
import { CircleProgress } from '@linode/ui';
import * as React from 'react';

import { CircleProgress } from 'src/components/CircleProgress';

interface State {
[name: string]: any;
loading: boolean;
Expand All @@ -22,6 +21,21 @@ export interface PromiseLoaderResponse<T> {
export default function preload<P>(requests: RequestMap<P>) {
return function (Component: React.ComponentType<P>) {
return class LoadedComponent extends React.Component<P, State> {
static displayName = `PromiseLoader(${
Component.displayName || Component.name
})`;
handleDone = () => {
if (!this.mounted) {
return;
}

this.setState((prevState) => ({ ...prevState, loading: false }));
};

mounted: boolean = false;

state = { loading: true };

componentDidMount() {
this.mounted = true;
const promises = Object.entries(requests).map(([name, request]) =>
Expand Down Expand Up @@ -50,6 +64,7 @@ export default function preload<P>(requests: RequestMap<P>) {

Promise.all(promises).then(this.handleDone).catch(this.handleDone);
}

componentWillUnmount() {
this.mounted = false;
}
Expand All @@ -62,22 +77,6 @@ export default function preload<P>(requests: RequestMap<P>) {

return <Component {...this.props} {...responses} />;
}

static displayName = `PromiseLoader(${
Component.displayName || Component.name
})`;

handleDone = () => {
if (!this.mounted) {
return;
}

this.setState((prevState) => ({ ...prevState, loading: false }));
};

mounted: boolean = false;

state = { loading: true };
};
};
}
3 changes: 1 addition & 2 deletions packages/manager/src/components/SplashScreen.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
import { Box } from '@linode/ui';
import { Box, CircleProgress } from '@linode/ui';
import * as React from 'react';

import { CircleProgress } from 'src/components/CircleProgress';
import { srSpeak } from 'src/utilities/accessibility';

export const SplashScreen = () => {
Expand Down
3 changes: 1 addition & 2 deletions packages/manager/src/components/SuspenseLoader.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
import { CircleProgress } from '@linode/ui';
import * as React from 'react';

import { CircleProgress } from 'src/components/CircleProgress';

interface Props {
/**
* Ammount of time before the CircleProgress shows
Expand Down
11 changes: 5 additions & 6 deletions packages/manager/src/components/TableSortCell/TableSortCell.tsx
Original file line number Diff line number Diff line change
@@ -1,15 +1,14 @@
import {
TableCellProps as _TableCellProps,
default as TableCell,
} from '@mui/material/TableCell';
import { CircleProgress } from '@linode/ui';
import { default as TableCell } from '@mui/material/TableCell';
import TableSortLabel from '@mui/material/TableSortLabel';
import { Theme } from '@mui/material/styles';
import * as React from 'react';
import { makeStyles } from 'tss-react/mui';

import SortUp from 'src/assets/icons/sort-up.svg';
import Sort from 'src/assets/icons/unsorted.svg';
import { CircleProgress } from 'src/components/CircleProgress';

import type { Theme } from '@mui/material/styles';
import type { TableCellProps as _TableCellProps } from '@mui/material/TableCell';

const useStyles = makeStyles()((theme: Theme) => ({
initialIcon: {
Expand Down
3 changes: 1 addition & 2 deletions packages/manager/src/components/TagCell/TagCell.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { IconButton, omittedProps } from '@linode/ui';
import { CircleProgress, IconButton, omittedProps } from '@linode/ui';
import MoreHoriz from '@mui/icons-material/MoreHoriz';
import { styled } from '@mui/material/styles';
import Grid from '@mui/material/Unstable_Grid2';
Expand All @@ -8,7 +8,6 @@ import { Tag } from 'src/components/Tag/Tag';
import { useWindowDimensions } from 'src/hooks/useWindowDimensions';

import { StyledPlusIcon, StyledTagButton } from '../Button/StyledTagButton';
import { CircleProgress } from '../CircleProgress';
import { AddTag } from './AddTag';
import { TagDrawer } from './TagDrawer';

Expand Down
9 changes: 7 additions & 2 deletions packages/manager/src/components/TextField.tsx
Original file line number Diff line number Diff line change
@@ -1,11 +1,16 @@
import { Box, FormHelperText, InputAdornment, InputLabel } from '@linode/ui';
import {
Box,
CircleProgress,
FormHelperText,
InputAdornment,
InputLabel,
} from '@linode/ui';
import KeyboardArrowDown from '@mui/icons-material/KeyboardArrowDown';
import { useTheme } from '@mui/material/styles';
import { default as _TextField } from '@mui/material/TextField';
import { clamp } from 'ramda';
import * as React from 'react';

import { CircleProgress } from 'src/components/CircleProgress';
import { TooltipIcon } from 'src/components/TooltipIcon';
import { convertToKebabCase } from 'src/utilities/convertToKebobCase';

Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
import { Box } from '@linode/ui';
import { Box, CircleProgress } from '@linode/ui';
import * as React from 'react';

import { CircleProgress } from 'src/components/CircleProgress';
import { Typography } from 'src/components/Typography';
import { useAccountNetworkTransfer } from 'src/queries/account/transfer';
import { useRegionsQuery } from 'src/queries/regions/regions';
Expand Down
2 changes: 1 addition & 1 deletion packages/manager/src/features/Account/GlobalSettings.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import { CircleProgress } from '@linode/ui';
import { useSnackbar } from 'notistack';
import * as React from 'react';

import { CircleProgress } from 'src/components/CircleProgress';
import { ErrorState } from 'src/components/ErrorState/ErrorState';
import {
useAccountSettings,
Expand Down
Original file line number Diff line number Diff line change
@@ -1,10 +1,9 @@
import { Box, Notice, Stack } from '@linode/ui';
import { Box, CircleProgress, Notice, Stack } from '@linode/ui';
import { enqueueSnackbar } from 'notistack';
import * as React from 'react';

import { Accordion } from 'src/components/Accordion';
import { Button } from 'src/components/Button/Button';
import { CircleProgress } from 'src/components/CircleProgress';
import { Link } from 'src/components/Link';
import { TypeToConfirmDialog } from 'src/components/TypeToConfirmDialog/TypeToConfirmDialog';
import { Typography } from 'src/components/Typography';
Expand Down
Original file line number Diff line number Diff line change
@@ -1,11 +1,10 @@
import { Box, Notice, Stack } from '@linode/ui';
import { Box, CircleProgress, Notice, Stack } from '@linode/ui';
import React, { useState } from 'react';
import { Waypoint } from 'react-waypoint';

import ErrorStateCloud from 'src/assets/icons/error-state-cloud.svg';
import { Button } from 'src/components/Button/Button';
import { StyledLinkButton } from 'src/components/Button/StyledLinkButton';
import { CircleProgress } from 'src/components/CircleProgress';
import { Typography } from 'src/components/Typography';
import { useChildAccountsInfiniteQuery } from 'src/queries/account/account';

Expand Down
3 changes: 1 addition & 2 deletions packages/manager/src/features/Betas/BetaDetailsList.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
import { Divider, Paper, Stack } from '@linode/ui';
import { CircleProgress, Divider, Paper, Stack } from '@linode/ui';
import * as React from 'react';

import { CircleProgress } from 'src/components/CircleProgress';
import { ErrorState } from 'src/components/ErrorState/ErrorState';
import { Typography } from 'src/components/Typography';

Expand Down
3 changes: 1 addition & 2 deletions packages/manager/src/features/Betas/BetaSignup.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { Paper, Stack } from '@linode/ui';
import { CircleProgress, Paper, Stack } from '@linode/ui';
import {
createLazyRoute,
useNavigate,
Expand All @@ -9,7 +9,6 @@ import * as React from 'react';

import { ActionsPanel } from 'src/components/ActionsPanel/ActionsPanel';
import { Checkbox } from 'src/components/Checkbox';
import { CircleProgress } from 'src/components/CircleProgress';
import { HighlightedMarkdown } from 'src/components/HighlightedMarkdown/HighlightedMarkdown';
import { LandingHeader } from 'src/components/LandingHeader/LandingHeader';
import { NotFound } from 'src/components/NotFound';
Expand Down
2 changes: 1 addition & 1 deletion packages/manager/src/features/Billing/BillingDetail.tsx
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
import { CircleProgress } from '@linode/ui';
import Paper from '@mui/material/Paper';
import { styled } from '@mui/material/styles';
import Grid from '@mui/material/Unstable_Grid2';
import { PayPalScriptProvider } from '@paypal/react-paypal-js';
import * as React from 'react';

import { Button } from 'src/components/Button/Button';
import { CircleProgress } from 'src/components/CircleProgress';
import { DocumentTitleSegment } from 'src/components/DocumentTitle';
import { ErrorState } from 'src/components/ErrorState/ErrorState';
import { PAYPAL_CLIENT_ID } from 'src/constants';
Expand Down
Original file line number Diff line number Diff line change
@@ -1,11 +1,10 @@
import { Tooltip } from '@linode/ui';
import { CircleProgress, Tooltip } from '@linode/ui';
import Grid from '@mui/material/Unstable_Grid2';
import { useQueryClient } from '@tanstack/react-query';
import * as React from 'react';
import { makeStyles } from 'tss-react/mui';

import GooglePayIcon from 'src/assets/icons/payment/gPayButton.svg';
import { CircleProgress } from 'src/components/CircleProgress';
import { getPaymentLimits } from 'src/features/Billing/billingUtils';
import {
gPay,
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { makePayment } from '@linode/api-v4/lib/account/payments';
import { Tooltip } from '@linode/ui';
import { CircleProgress, Tooltip } from '@linode/ui';
import Grid from '@mui/material/Unstable_Grid2';
import {
BraintreePayPalButtons,
Expand All @@ -10,7 +10,6 @@ import { useQueryClient } from '@tanstack/react-query';
import * as React from 'react';
import { makeStyles } from 'tss-react/mui';

import { CircleProgress } from 'src/components/CircleProgress';
import { reportException } from 'src/exceptionReporting';
import { getPaymentLimits } from 'src/features/Billing/billingUtils';
import { useAccount } from 'src/queries/account/account';
Expand Down
Original file line number Diff line number Diff line change
@@ -1,18 +1,19 @@
import { CircleProgress } from '@linode/ui';
import Grid from '@mui/material/Unstable_Grid2';
import * as React from 'react';
import { useQueryClient } from '@tanstack/react-query';
import * as React from 'react';
import { makeStyles } from 'tss-react/mui';

import GooglePayIcon from 'src/assets/icons/payment/googlePay.svg';
import { CircleProgress } from 'src/components/CircleProgress';
import { PaymentMessage } from 'src/features/Billing/BillingPanels/PaymentInfoPanel/AddPaymentMethodDrawer/AddPaymentMethodDrawer';
import {
gPay,
initGooglePaymentInstance,
} from 'src/features/Billing/GooglePayProvider';
import { useScript } from 'src/hooks/useScript';
import { useClientToken } from 'src/queries/account/payment';

import type { PaymentMessage } from 'src/features/Billing/BillingPanels/PaymentInfoPanel/AddPaymentMethodDrawer/AddPaymentMethodDrawer';

const useStyles = makeStyles()(() => ({
button: {
'&:hover': {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,26 +1,30 @@
import { addPaymentMethod } from '@linode/api-v4/lib/account/payments';
import { APIError } from '@linode/api-v4/lib/types';
import { CircleProgress } from '@linode/ui';
import Grid from '@mui/material/Unstable_Grid2';
import {
BraintreePayPalButtons,
CreateBillingAgreementActions,
FUNDING,
OnApproveBraintreeActions,
OnApproveBraintreeData,
usePayPalScriptReducer,
} from '@paypal/react-paypal-js';
import { QueryClient, useQueryClient } from '@tanstack/react-query';
import { useQueryClient } from '@tanstack/react-query';
import { useSnackbar } from 'notistack';
import React, { useEffect } from 'react';
import { makeStyles } from 'tss-react/mui';

import { CircleProgress } from 'src/components/CircleProgress';
import { reportException } from 'src/exceptionReporting';
import { PaymentMessage } from 'src/features/Billing/BillingPanels/PaymentInfoPanel/AddPaymentMethodDrawer/AddPaymentMethodDrawer';
import { useClientToken } from 'src/queries/account/payment';
import { accountQueries } from 'src/queries/account/queries';
import { getAPIErrorOrDefault } from 'src/utilities/errorUtils';

import type { APIError } from '@linode/api-v4/lib/types';
import type {
CreateBillingAgreementActions,
OnApproveBraintreeActions,
OnApproveBraintreeData,
} from '@paypal/react-paypal-js';
import type { QueryClient } from '@tanstack/react-query';
import type { PaymentMessage } from 'src/features/Billing/BillingPanels/PaymentInfoPanel/AddPaymentMethodDrawer/AddPaymentMethodDrawer';

const useStyles = makeStyles()(() => ({
disabled: {
// Allows us to disable the pointer on the PayPal button because the SDK does not
Expand Down
Original file line number Diff line number Diff line change
@@ -1,13 +1,14 @@
import { PaymentMethod } from '@linode/api-v4/lib/account/types';
import { APIError } from '@linode/api-v4/lib/types';
import { CircleProgress } from '@linode/ui';
import Grid from '@mui/material/Unstable_Grid2';
import * as React from 'react';

import { CircleProgress } from 'src/components/CircleProgress';
import { PaymentMethodRow } from 'src/components/PaymentMethodRow/PaymentMethodRow';
import { Typography } from 'src/components/Typography';
import { getAPIErrorOrDefault } from 'src/utilities/errorUtils';

import type { PaymentMethod } from '@linode/api-v4/lib/account/types';
import type { APIError } from '@linode/api-v4/lib/types';

interface Props {
error: APIError[] | null | undefined;
isChildUser?: boolean | undefined;
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import { CircleProgress } from '@linode/ui';
import { Grid } from '@mui/material';
import React from 'react';

import { CircleProgress } from 'src/components/CircleProgress';
import { ErrorState } from 'src/components/ErrorState/ErrorState';
import { useCloudPulseDashboardByIdQuery } from 'src/queries/cloudpulse/dashboards';
import { useResourcesQuery } from 'src/queries/cloudpulse/resources';
Expand Down
Loading

0 comments on commit afbd8d9

Please sign in to comment.