0

Lazy load every instance of using ant icons. Closes #2583

This commit is contained in:
Gabe Kangas 2023-01-15 22:31:36 -08:00
parent 3986fcd032
commit 6fbd6cbbcf
No known key found for this signature in database
GPG Key ID: 4345B2060657F330
43 changed files with 537 additions and 91 deletions

View File

@ -1,10 +1,24 @@
import { FC } from 'react'; import { FC } from 'react';
import { Button, Dropdown, Menu } from 'antd'; import { Button, Dropdown, Menu } from 'antd';
import classNames from 'classnames'; import classNames from 'classnames';
import { EllipsisOutlined, HeartOutlined, BellOutlined } from '@ant-design/icons'; import dynamic from 'next/dynamic';
import styles from './ActionButtonMenu.module.scss'; import styles from './ActionButtonMenu.module.scss';
import { ExternalAction } from '../../../interfaces/external-action'; import { ExternalAction } from '../../../interfaces/external-action';
// Lazy loaded components
const EllipsisOutlined = dynamic(() => import('@ant-design/icons/EllipsisOutlined'), {
ssr: false,
});
const HeartOutlined = dynamic(() => import('@ant-design/icons/HeartOutlined'), {
ssr: false,
});
const BellOutlined = dynamic(() => import('@ant-design/icons/BellOutlined'), {
ssr: false,
});
const NOTIFY_KEY = 'notify'; const NOTIFY_KEY = 'notify';
const FOLLOW_KEY = 'follow'; const FOLLOW_KEY = 'follow';

View File

@ -1,9 +1,15 @@
import { Button, ButtonProps } from 'antd'; import { Button, ButtonProps } from 'antd';
import { HeartFilled } from '@ant-design/icons';
import { FC } from 'react'; import { FC } from 'react';
import dynamic from 'next/dynamic';
import styles from './ActionButton/ActionButton.module.scss'; import styles from './ActionButton/ActionButton.module.scss';
// Lazy loaded components
const HeartFilled = dynamic(() => import('@ant-design/icons/HeartFilled'), {
ssr: false,
});
export type FollowButtonProps = ButtonProps & { export type FollowButtonProps = ButtonProps & {
onClick?: () => void; onClick?: () => void;
props?: ButtonProps; props?: ButtonProps;

View File

@ -1,8 +1,14 @@
import { Button } from 'antd'; import { Button } from 'antd';
import { BellFilled } from '@ant-design/icons';
import { FC } from 'react'; import { FC } from 'react';
import dynamic from 'next/dynamic';
import styles from './ActionButton/ActionButton.module.scss'; import styles from './ActionButton/ActionButton.module.scss';
// Lazy loaded components
const BellFilled = dynamic(() => import('@ant-design/icons/BellFilled'), {
ssr: false,
});
export type NotifyButtonProps = { export type NotifyButtonProps = {
text?: string; text?: string;
onClick?: () => void; onClick?: () => void;

View File

@ -1,9 +1,23 @@
import { Modal, Button } from 'antd'; import { Modal, Button } from 'antd';
import { ExclamationCircleFilled, QuestionCircleFilled, StopTwoTone } from '@ant-design/icons';
import { FC } from 'react'; import { FC } from 'react';
import dynamic from 'next/dynamic';
import { USER_ENABLED_TOGGLE, fetchData } from '../../utils/apis'; import { USER_ENABLED_TOGGLE, fetchData } from '../../utils/apis';
import { User } from '../../types/chat'; import { User } from '../../types/chat';
// Lazy loaded components
const ExclamationCircleFilled = dynamic(() => import('@ant-design/icons/ExclamationCircleFilled'), {
ssr: false,
});
const QuestionCircleFilled = dynamic(() => import('@ant-design/icons/QuestionCircleFilled'), {
ssr: false,
});
const StopTwoTone = dynamic(() => import('@ant-design/icons/StopTwoTone'), {
ssr: false,
});
export type BanUserButtonProps = { export type BanUserButtonProps = {
user: User; user: User;
isEnabled: Boolean; // = this user's current status isEnabled: Boolean; // = this user's current status

View File

@ -2,10 +2,16 @@ import { Table, Button } from 'antd';
import format from 'date-fns/format'; import format from 'date-fns/format';
import { SortOrder } from 'antd/lib/table/interface'; import { SortOrder } from 'antd/lib/table/interface';
import React, { FC } from 'react'; import React, { FC } from 'react';
import { StopTwoTone } from '@ant-design/icons'; import dynamic from 'next/dynamic';
import { User } from '../../types/chat'; import { User } from '../../types/chat';
import { BANNED_IP_REMOVE, fetchData } from '../../utils/apis'; import { BANNED_IP_REMOVE, fetchData } from '../../utils/apis';
// Lazy loaded components
const StopTwoTone = dynamic(() => import('@ant-design/icons/StopTwoTone'), {
ssr: false,
});
function formatDisplayDate(date: string | Date) { function formatDisplayDate(date: string | Date) {
return format(new Date(date), 'MMM d H:mma'); return format(new Date(date), 'MMM d H:mma');
} }

View File

@ -1,14 +1,20 @@
import { Input, Table } from 'antd'; import { Input, Table } from 'antd';
import { FilterDropdownProps, SortOrder } from 'antd/lib/table/interface'; import { FilterDropdownProps, SortOrder } from 'antd/lib/table/interface';
import { ColumnsType } from 'antd/es/table'; import { ColumnsType } from 'antd/es/table';
import { SearchOutlined } from '@ant-design/icons';
import { formatDistanceToNow } from 'date-fns'; import { formatDistanceToNow } from 'date-fns';
import { FC } from 'react'; import { FC } from 'react';
import dynamic from 'next/dynamic';
import { Client } from '../../types/chat'; import { Client } from '../../types/chat';
import { UserPopover } from './UserPopover'; import { UserPopover } from './UserPopover';
import { BanUserButton } from './BanUserButton'; import { BanUserButton } from './BanUserButton';
import { formatUAstring } from '../../utils/format'; import { formatUAstring } from '../../utils/format';
// Lazy loaded components
const SearchOutlined = dynamic(() => import('@ant-design/icons/SearchOutlined'), {
ssr: false,
});
export type ClientTableProps = { export type ClientTableProps = {
data: Client[]; data: Client[];
}; };

View File

@ -3,7 +3,7 @@
import React, { FC, useContext, useState } from 'react'; import React, { FC, useContext, useState } from 'react';
import { Typography, Table, Modal, Button, Alert } from 'antd'; import { Typography, Table, Modal, Button, Alert } from 'antd';
import { ColumnsType } from 'antd/lib/table'; import { ColumnsType } from 'antd/lib/table';
import { DeleteOutlined } from '@ant-design/icons'; import dynamic from 'next/dynamic';
import { ServerStatusContext } from '../../utils/server-status-context'; import { ServerStatusContext } from '../../utils/server-status-context';
import { AlertMessageContext } from '../../utils/alert-message-context'; import { AlertMessageContext } from '../../utils/alert-message-context';
import { UpdateArgs, VideoVariant } from '../../types/config-section'; import { UpdateArgs, VideoVariant } from '../../types/config-section';
@ -28,6 +28,12 @@ import { FormStatusIndicator } from './FormStatusIndicator';
const { Title } = Typography; const { Title } = Typography;
// Lazy loaded components
const DeleteOutlined = dynamic(() => import('@ant-design/icons/DeleteOutlined'), {
ssr: false,
});
// eslint-disable-next-line import/prefer-default-export // eslint-disable-next-line import/prefer-default-export
export const CurrentVariantsTable: FC = () => { export const CurrentVariantsTable: FC = () => {
const [displayModal, setDisplayModal] = useState(false); const [displayModal, setDisplayModal] = useState(false);

View File

@ -1,6 +1,6 @@
import React, { useState, useContext, useEffect } from 'react'; import React, { useState, useContext, useEffect } from 'react';
import { Button, Collapse, Typography, Tooltip } from 'antd'; import { Button, Collapse, Typography, Tooltip } from 'antd';
import { CopyOutlined, RedoOutlined } from '@ant-design/icons'; import dynamic from 'next/dynamic';
import { TEXTFIELD_TYPE_NUMBER, TEXTFIELD_TYPE_PASSWORD, TEXTFIELD_TYPE_URL } from './TextField'; import { TEXTFIELD_TYPE_NUMBER, TEXTFIELD_TYPE_PASSWORD, TEXTFIELD_TYPE_URL } from './TextField';
import { TextFieldWithSubmit } from './TextFieldWithSubmit'; import { TextFieldWithSubmit } from './TextFieldWithSubmit';
import { ServerStatusContext } from '../../utils/server-status-context'; import { ServerStatusContext } from '../../utils/server-status-context';
@ -17,6 +17,14 @@ import { ResetYP } from './ResetYP';
// Lazy loaded components // Lazy loaded components
const CopyOutlined = dynamic(() => import('@ant-design/icons/CopyOutlined'), {
ssr: false,
});
const RedoOutlined = dynamic(() => import('@ant-design/icons/RedoOutlined'), {
ssr: false,
});
const { Panel } = Collapse; const { Panel } = Collapse;
// eslint-disable-next-line react/function-component-definition // eslint-disable-next-line react/function-component-definition

View File

@ -1,7 +1,7 @@
import { Button, Upload } from 'antd'; import { Button, Upload } from 'antd';
import { RcFile } from 'antd/lib/upload/interface'; import { RcFile } from 'antd/lib/upload/interface';
import { LoadingOutlined, UploadOutlined } from '@ant-design/icons';
import React, { useState, useContext, FC } from 'react'; import React, { useState, useContext, FC } from 'react';
import dynamic from 'next/dynamic';
import { FormStatusIndicator } from './FormStatusIndicator'; import { FormStatusIndicator } from './FormStatusIndicator';
import { ServerStatusContext } from '../../utils/server-status-context'; import { ServerStatusContext } from '../../utils/server-status-context';
import { import {
@ -25,6 +25,16 @@ import {
readableBytes, readableBytes,
} from '../../utils/images'; } from '../../utils/images';
// Lazy loaded components
const LoadingOutlined = dynamic(() => import('@ant-design/icons/LoadingOutlined'), {
ssr: false,
});
const UploadOutlined = dynamic(() => import('@ant-design/icons/UploadOutlined'), {
ssr: false,
});
// eslint-disable-next-line import/prefer-default-export // eslint-disable-next-line import/prefer-default-export
export const EditLogo: FC = () => { export const EditLogo: FC = () => {
const [logoUrl, setlogoUrl] = useState(null); const [logoUrl, setlogoUrl] = useState(null);

View File

@ -1,7 +1,13 @@
import { InfoCircleOutlined } from '@ant-design/icons';
import { Tooltip } from 'antd'; import { Tooltip } from 'antd';
import dynamic from 'next/dynamic';
import { FC } from 'react'; import { FC } from 'react';
// Lazy loaded components
const InfoCircleOutlined = dynamic(() => import('@ant-design/icons/InfoCircleOutlined'), {
ssr: false,
});
export type InfoTipProps = { export type InfoTipProps = {
tip: string | null; tip: string | null;
}; };

View File

@ -5,20 +5,9 @@ import Head from 'next/head';
import { differenceInSeconds } from 'date-fns'; import { differenceInSeconds } from 'date-fns';
import { useRouter } from 'next/router'; import { useRouter } from 'next/router';
import { Layout, Menu, Alert, Button, Space, Tooltip } from 'antd'; import { Layout, Menu, Alert, Button, Space, Tooltip } from 'antd';
import {
SettingOutlined,
HomeOutlined,
LineChartOutlined,
ToolOutlined,
PlayCircleFilled,
MinusSquareFilled,
QuestionCircleOutlined,
MessageOutlined,
ExperimentOutlined,
EditOutlined,
} from '@ant-design/icons';
import classNames from 'classnames'; import classNames from 'classnames';
import dynamic from 'next/dynamic';
import { upgradeVersionAvailable } from '../../utils/apis'; import { upgradeVersionAvailable } from '../../utils/apis';
import { parseSecondsToDurationString } from '../../utils/format'; import { parseSecondsToDurationString } from '../../utils/format';
@ -31,6 +20,48 @@ import { TEXTFIELD_PROPS_STREAM_TITLE } from '../../utils/config-constants';
import { ComposeFederatedPost } from './ComposeFederatedPost'; import { ComposeFederatedPost } from './ComposeFederatedPost';
import { UpdateArgs } from '../../types/config-section'; import { UpdateArgs } from '../../types/config-section';
// Lazy loaded components
const SettingOutlined = dynamic(() => import('@ant-design/icons/SettingOutlined'), {
ssr: false,
}); // Lazy loaded components
const HomeOutlined = dynamic(() => import('@ant-design/icons/HomeOutlined'), {
ssr: false,
});
const LineChartOutlined = dynamic(() => import('@ant-design/icons/LineChartOutlined'), {
ssr: false,
});
const ToolOutlined = dynamic(() => import('@ant-design/icons/ToolOutlined'), {
ssr: false,
});
const PlayCircleFilled = dynamic(() => import('@ant-design/icons/PlayCircleFilled'), {
ssr: false,
});
const MinusSquareFilled = dynamic(() => import('@ant-design/icons/MinusSquareFilled'), {
ssr: false,
});
const QuestionCircleOutlined = dynamic(() => import('@ant-design/icons/QuestionCircleOutlined'), {
ssr: false,
});
const MessageOutlined = dynamic(() => import('@ant-design/icons/MessageOutlined'), {
ssr: false,
});
const ExperimentOutlined = dynamic(() => import('@ant-design/icons/ExperimentOutlined'), {
ssr: false,
});
const EditOutlined = dynamic(() => import('@ant-design/icons/EditOutlined'), {
ssr: false,
});
export type MainLayoutProps = { export type MainLayoutProps = {
children: ReactNode; children: ReactNode;
}; };

View File

@ -1,16 +1,30 @@
// Custom component for AntDesign Button that makes an api call, then displays a confirmation icon upon // Custom component for AntDesign Button that makes an api call, then displays a confirmation icon upon
import React, { useState, useEffect, FC } from 'react'; import React, { useState, useEffect, FC } from 'react';
import { Button, Tooltip } from 'antd'; import { Button, Tooltip } from 'antd';
import {
EyeOutlined, import dynamic from 'next/dynamic';
EyeInvisibleOutlined,
CheckCircleFilled,
ExclamationCircleFilled,
} from '@ant-design/icons';
import { fetchData, UPDATE_CHAT_MESSGAE_VIZ } from '../../utils/apis'; import { fetchData, UPDATE_CHAT_MESSGAE_VIZ } from '../../utils/apis';
import { MessageType } from '../../types/chat'; import { MessageType } from '../../types/chat';
import { isEmptyObject } from '../../utils/format'; import { isEmptyObject } from '../../utils/format';
// Lazy loaded components
const EyeOutlined = dynamic(() => import('@ant-design/icons/EyeOutlined'), {
ssr: false,
});
const EyeInvisibleOutlined = dynamic(() => import('@ant-design/icons/EyeInvisibleOutlined'), {
ssr: false,
});
const CheckCircleFilled = dynamic(() => import('@ant-design/icons/CheckCircleFilled'), {
ssr: false,
});
const ExclamationCircleFilled = dynamic(() => import('@ant-design/icons/ExclamationCircleFilled'), {
ssr: false,
});
export type MessageToggleProps = { export type MessageToggleProps = {
isVisible: boolean; isVisible: boolean;
message: MessageType; message: MessageType;

View File

@ -1,14 +1,31 @@
import { Modal, Button } from 'antd'; import { Modal, Button } from 'antd';
import {
ExclamationCircleFilled,
QuestionCircleFilled,
StopTwoTone,
SafetyCertificateTwoTone,
} from '@ant-design/icons';
import { FC } from 'react'; import { FC } from 'react';
import dynamic from 'next/dynamic';
import { USER_SET_MODERATOR, fetchData } from '../../utils/apis'; import { USER_SET_MODERATOR, fetchData } from '../../utils/apis';
import { User } from '../../types/chat'; import { User } from '../../types/chat';
// Lazy loaded components
const ExclamationCircleFilled = dynamic(() => import('@ant-design/icons/ExclamationCircleFilled'), {
ssr: false,
});
const QuestionCircleFilled = dynamic(() => import('@ant-design/icons/QuestionCircleFilled'), {
ssr: false,
});
const StopTwoTone = dynamic(() => import('@ant-design/icons/StopTwoTone'), {
ssr: false,
});
const SafetyCertificateTwoTone = dynamic(
() => import('@ant-design/icons/SafetyCertificateTwoTone'),
{
ssr: false,
},
);
export type ModeratorUserButtonProps = { export type ModeratorUserButtonProps = {
user: User; user: User;
onClick?: () => void; onClick?: () => void;

View File

@ -1,7 +1,7 @@
import { BookTwoTone, MessageTwoTone, PlaySquareTwoTone, ProfileTwoTone } from '@ant-design/icons';
import { Card, Col, Row, Typography } from 'antd'; import { Card, Col, Row, Typography } from 'antd';
import Link from 'next/link'; import Link from 'next/link';
import { FC, useContext } from 'react'; import { FC, useContext } from 'react';
import dynamic from 'next/dynamic';
import { LogTable } from './LogTable'; import { LogTable } from './LogTable';
import { OwncastLogo } from '../common/OwncastLogo/OwncastLogo'; import { OwncastLogo } from '../common/OwncastLogo/OwncastLogo';
import { NewsFeed } from './NewsFeed'; import { NewsFeed } from './NewsFeed';
@ -13,6 +13,24 @@ const { Paragraph, Text } = Typography;
const { Title } = Typography; const { Title } = Typography;
const { Meta } = Card; const { Meta } = Card;
// Lazy loaded components
const BookTwoTone = dynamic(() => import('@ant-design/icons/BookTwoTone'), {
ssr: false,
});
const MessageTwoTone = dynamic(() => import('@ant-design/icons/MessageTwoTone'), {
ssr: false,
});
const PlaySquareTwoTone = dynamic(() => import('@ant-design/icons/PlaySquareTwoTone'), {
ssr: false,
});
const ProfileTwoTone = dynamic(() => import('@ant-design/icons/ProfileTwoTone'), {
ssr: false,
});
function generateStreamURL(serverURL, rtmpServerPort) { function generateStreamURL(serverURL, rtmpServerPort) {
return `rtmp://${serverURL.replace(/(^\w+:|^)\/\//, '')}:${rtmpServerPort}/live`; return `rtmp://${serverURL.replace(/(^\w+:|^)\/\//, '')}:${rtmpServerPort}/live`;
} }

View File

@ -1,9 +1,22 @@
import { CheckCircleOutlined, ExclamationCircleOutlined } from '@ant-design/icons';
import { Alert, Button, Col, Row, Statistic, Typography } from 'antd'; import { Alert, Button, Col, Row, Statistic, Typography } from 'antd';
import dynamic from 'next/dynamic';
import Link from 'next/link'; import Link from 'next/link';
import React, { FC, useContext } from 'react'; import React, { FC, useContext } from 'react';
import { ServerStatusContext } from '../../utils/server-status-context'; import { ServerStatusContext } from '../../utils/server-status-context';
// Lazy loaded components
const CheckCircleOutlined = dynamic(() => import('@ant-design/icons/CheckCircleOutlined'), {
ssr: false,
});
const ExclamationCircleOutlined = dynamic(
() => import('@ant-design/icons/ExclamationCircleOutlined'),
{
ssr: false,
},
);
export type StreamHealthOverviewProps = { export type StreamHealthOverviewProps = {
showTroubleshootButton?: Boolean; showTroubleshootButton?: Boolean;
}; };

View File

@ -1,8 +1,8 @@
// This content populates the video variant modal, which is spawned from the variants table. This relies on the `dataState` prop fed in by the table. // This content populates the video variant modal, which is spawned from the variants table. This relies on the `dataState` prop fed in by the table.
import React, { FC } from 'react'; import React, { FC } from 'react';
import { Popconfirm, Row, Col, Slider, Collapse, Typography, Alert, Button } from 'antd'; import { Popconfirm, Row, Col, Slider, Collapse, Typography, Alert, Button } from 'antd';
import { ExclamationCircleFilled } from '@ant-design/icons';
import classNames from 'classnames'; import classNames from 'classnames';
import dynamic from 'next/dynamic';
import { FieldUpdaterFunc, VideoVariant, UpdateArgs } from '../../types/config-section'; import { FieldUpdaterFunc, VideoVariant, UpdateArgs } from '../../types/config-section';
import { TextField } from './TextField'; import { TextField } from './TextField';
import { import {
@ -21,6 +21,12 @@ import { ToggleSwitch } from './ToggleSwitch';
const { Panel } = Collapse; const { Panel } = Collapse;
// Lazy loaded components
const ExclamationCircleFilled = dynamic(() => import('@ant-design/icons/ExclamationCircleFilled'), {
ssr: false,
});
export type VideoVariantFormProps = { export type VideoVariantFormProps = {
dataState: VideoVariant; dataState: VideoVariant;
onUpdateField: FieldUpdaterFunc; onUpdateField: FieldUpdaterFunc;

View File

@ -1,7 +1,7 @@
import React, { useState, useContext, useEffect } from 'react'; import React, { useState, useContext, useEffect } from 'react';
import { Typography, Table, Button, Modal, Input } from 'antd'; import { Typography, Table, Button, Modal, Input } from 'antd';
import { ColumnsType } from 'antd/lib/table'; import { ColumnsType } from 'antd/lib/table';
import { CaretDownOutlined, CaretUpOutlined, DeleteOutlined } from '@ant-design/icons'; import dynamic from 'next/dynamic';
import { SocialDropdown } from '../../SocialDropdown'; import { SocialDropdown } from '../../SocialDropdown';
import { fetchData, SOCIAL_PLATFORMS_LIST } from '../../../../utils/apis'; import { fetchData, SOCIAL_PLATFORMS_LIST } from '../../../../utils/apis';
import { ServerStatusContext } from '../../../../utils/server-status-context'; import { ServerStatusContext } from '../../../../utils/server-status-context';
@ -25,6 +25,20 @@ import { FormStatusIndicator } from '../../FormStatusIndicator';
const { Title } = Typography; const { Title } = Typography;
// Lazy loaded components
const CaretDownOutlined = dynamic(() => import('@ant-design/icons/CaretDownOutlined'), {
ssr: false,
});
const CaretUpOutlined = dynamic(() => import('@ant-design/icons/CaretUpOutlined'), {
ssr: false,
});
const DeleteOutlined = dynamic(() => import('@ant-design/icons/DeleteOutlined'), {
ssr: false,
});
// eslint-disable-next-line react/function-component-definition // eslint-disable-next-line react/function-component-definition
export default function EditSocialLinks() { export default function EditSocialLinks() {
const [availableIconsList, setAvailableIconsList] = useState([]); const [availableIconsList, setAvailableIconsList] = useState([]);

View File

@ -1,6 +1,6 @@
import React, { useContext, useState } from 'react'; import React, { useContext, useState } from 'react';
import { Table, Space, Button, Typography, Alert, Input, Form } from 'antd'; import { Table, Space, Button, Typography, Alert, Input, Form } from 'antd';
import { DeleteOutlined, EyeOutlined, PlusOutlined } from '@ant-design/icons'; import dynamic from 'next/dynamic';
import { ServerStatusContext } from '../../../../utils/server-status-context'; import { ServerStatusContext } from '../../../../utils/server-status-context';
import { fetchData, UPDATE_STREAM_KEYS } from '../../../../utils/apis'; import { fetchData, UPDATE_STREAM_KEYS } from '../../../../utils/apis';
@ -8,6 +8,20 @@ import { fetchData, UPDATE_STREAM_KEYS } from '../../../../utils/apis';
const { Paragraph } = Typography; const { Paragraph } = Typography;
const { Item } = Form; const { Item } = Form;
// Lazy loaded components
const DeleteOutlined = dynamic(() => import('@ant-design/icons/DeleteOutlined'), {
ssr: false,
});
const EyeOutlined = dynamic(() => import('@ant-design/icons/EyeOutlined'), {
ssr: false,
});
const PlusOutlined = dynamic(() => import('@ant-design/icons/PlusOutlined'), {
ssr: false,
});
const saveKeys = async (keys, setError) => { const saveKeys = async (keys, setError) => {
try { try {
await fetchData(UPDATE_STREAM_KEYS, { await fetchData(UPDATE_STREAM_KEYS, {

View File

@ -1,6 +1,6 @@
import { Virtuoso } from 'react-virtuoso'; import { Virtuoso } from 'react-virtuoso';
import { useState, useMemo, useRef, CSSProperties, FC, useEffect } from 'react'; import { useState, useMemo, useRef, CSSProperties, FC, useEffect } from 'react';
import { EditFilled } from '@ant-design/icons'; import dynamic from 'next/dynamic';
import { import {
ConnectedClientInfoEvent, ConnectedClientInfoEvent,
MessageType, MessageType,
@ -17,6 +17,11 @@ import { ChatJoinMessage } from '../ChatJoinMessage/ChatJoinMessage';
import { ScrollToBotBtn } from './ScrollToBotBtn'; import { ScrollToBotBtn } from './ScrollToBotBtn';
import { ChatActionMessage } from '../ChatActionMessage/ChatActionMessage'; import { ChatActionMessage } from '../ChatActionMessage/ChatActionMessage';
// Lazy loaded components
const EditFilled = dynamic(() => import('@ant-design/icons/EditFilled'), {
ssr: false,
});
export type ChatContainerProps = { export type ChatContainerProps = {
messages: ChatMessage[]; messages: ChatMessage[];
usernameToHighlight: string; usernameToHighlight: string;

View File

@ -1,9 +1,17 @@
import { VerticalAlignBottomOutlined } from '@ant-design/icons';
import { Button } from 'antd'; import { Button } from 'antd';
import dynamic from 'next/dynamic';
import { FC, MutableRefObject } from 'react'; import { FC, MutableRefObject } from 'react';
import { ChatMessage } from '../../../interfaces/chat-message.model'; import { ChatMessage } from '../../../interfaces/chat-message.model';
import styles from './ChatContainer.module.scss'; import styles from './ChatContainer.module.scss';
// Lazy loaded components
const VerticalAlignBottomOutlined = dynamic(
() => import('@ant-design/icons/VerticalAlignBottomOutlined'),
{
ssr: false,
},
);
type Props = { type Props = {
chatContainerRef: MutableRefObject<any>; chatContainerRef: MutableRefObject<any>;
messages: ChatMessage[]; messages: ChatMessage[];

View File

@ -1,8 +1,14 @@
import { FC } from 'react'; import { FC } from 'react';
import { TeamOutlined } from '@ant-design/icons'; import dynamic from 'next/dynamic';
import { ChatUserBadge } from '../ChatUserBadge/ChatUserBadge'; import { ChatUserBadge } from '../ChatUserBadge/ChatUserBadge';
import styles from './ChatJoinMessage.module.scss'; import styles from './ChatJoinMessage.module.scss';
// Lazy loaded components
const TeamOutlined = dynamic(() => import('@ant-design/icons/TeamOutlined'), {
ssr: false,
});
export type ChatJoinMessageProps = { export type ChatJoinMessageProps = {
isAuthorModerator: boolean; isAuthorModerator: boolean;
userColor: number; userColor: number;

View File

@ -1,11 +1,6 @@
import {
CloseCircleOutlined,
ExclamationCircleOutlined,
EyeInvisibleOutlined,
SmallDashOutlined,
} from '@ant-design/icons';
import { Dropdown, Menu, MenuProps, Space, message, Modal as AntModal } from 'antd'; import { Dropdown, Menu, MenuProps, Space, message, Modal as AntModal } from 'antd';
import { FC, useState } from 'react'; import { FC, useState } from 'react';
import dynamic from 'next/dynamic';
import { Modal } from '../../ui/Modal/Modal'; import { Modal } from '../../ui/Modal/Modal';
import { ChatModerationDetailsModal } from '../ChatModerationDetailsModal/ChatModerationDetailsModal'; import { ChatModerationDetailsModal } from '../ChatModerationDetailsModal/ChatModerationDetailsModal';
import styles from './ChatModerationActionMenu.module.scss'; import styles from './ChatModerationActionMenu.module.scss';
@ -13,6 +8,27 @@ import ChatModeration from '../../../services/moderation-service';
const { confirm } = AntModal; const { confirm } = AntModal;
// Lazy loaded components
const CloseCircleOutlined = dynamic(() => import('@ant-design/icons/CloseCircleOutlined'), {
ssr: false,
});
const ExclamationCircleOutlined = dynamic(
() => import('@ant-design/icons/ExclamationCircleOutlined'),
{
ssr: false,
},
);
const EyeInvisibleOutlined = dynamic(() => import('@ant-design/icons/EyeInvisibleOutlined'), {
ssr: false,
});
const SmallDashOutlined = dynamic(() => import('@ant-design/icons/SmallDashOutlined'), {
ssr: false,
});
export type ChatModerationActionMenuProps = { export type ChatModerationActionMenuProps = {
accessToken: string; accessToken: string;
messageID: string; messageID: string;

View File

@ -1,14 +1,20 @@
import { Button, Col, Collapse, Row, Spin, Table, Tag } from 'antd'; import { Button, Col, Collapse, Row, Spin, Table, Tag } from 'antd';
import { FC, useEffect, useState } from 'react'; import { FC, useEffect, useState } from 'react';
import format from 'date-fns/format'; import format from 'date-fns/format';
import { DeleteOutlined } from '@ant-design/icons';
import { ColumnsType } from 'antd/lib/table'; import { ColumnsType } from 'antd/lib/table';
import dynamic from 'next/dynamic';
import ChatModeration from '../../../services/moderation-service'; import ChatModeration from '../../../services/moderation-service';
import styles from './ChatModerationDetailsModal.module.scss'; import styles from './ChatModerationDetailsModal.module.scss';
import { formatUAstring } from '../../../utils/format'; import { formatUAstring } from '../../../utils/format';
const { Panel } = Collapse; const { Panel } = Collapse;
// Lazy loaded components
const DeleteOutlined = dynamic(() => import('@ant-design/icons/DeleteOutlined'), {
ssr: false,
});
export type ChatModerationDetailsModalProps = { export type ChatModerationDetailsModalProps = {
userId: string; userId: string;
accessToken: string; accessToken: string;

View File

@ -1,4 +1,3 @@
import { SendOutlined, SmileOutlined } from '@ant-design/icons';
import { Popover } from 'antd'; import { Popover } from 'antd';
import React, { FC, useMemo, useState } from 'react'; import React, { FC, useMemo, useState } from 'react';
import { useRecoilValue } from 'recoil'; import { useRecoilValue } from 'recoil';
@ -17,6 +16,14 @@ const EmojiPicker = dynamic(() => import('./EmojiPicker').then(mod => mod.EmojiP
ssr: false, ssr: false,
}); });
const SendOutlined = dynamic(() => import('@ant-design/icons/SendOutlined'), {
ssr: false,
});
const SmileOutlined = dynamic(() => import('@ant-design/icons/SmileOutlined'), {
ssr: false,
});
type CustomElement = { type: 'paragraph' | 'span'; children: CustomText[] } | ImageNode; type CustomElement = { type: 'paragraph' | 'span'; children: CustomText[] } | ImageNode;
type CustomText = { text: string }; type CustomText = { text: string };

View File

@ -1,7 +1,6 @@
/* eslint-disable react/no-danger */ /* eslint-disable react/no-danger */
import { FC, ReactNode, useEffect, useState } from 'react'; import { FC, ReactNode, useEffect, useState } from 'react';
import cn from 'classnames'; import cn from 'classnames';
import { LinkOutlined } from '@ant-design/icons';
import { Tooltip } from 'antd'; import { Tooltip } from 'antd';
import { useRecoilValue } from 'recoil'; import { useRecoilValue } from 'recoil';
import dynamic from 'next/dynamic'; import dynamic from 'next/dynamic';
@ -15,6 +14,10 @@ import { User } from '../../../interfaces/user.model';
// Lazy loaded components // Lazy loaded components
const LinkOutlined = dynamic(() => import('@ant-design/icons/LinkOutlined'), {
ssr: false,
});
const ChatModerationActionMenu = dynamic( const ChatModerationActionMenu = dynamic(
() => () =>
import('../ChatModerationActionMenu/ChatModerationActionMenu').then( import('../ChatModerationActionMenu/ChatModerationActionMenu').then(

View File

@ -1,11 +1,5 @@
import { Menu, Dropdown, Button } from 'antd'; import { Menu, Dropdown, Button } from 'antd';
import {
CaretDownOutlined,
EditOutlined,
LockOutlined,
MessageOutlined,
UserOutlined,
} from '@ant-design/icons';
import { useRecoilState, useRecoilValue } from 'recoil'; import { useRecoilState, useRecoilValue } from 'recoil';
import { FC, useState } from 'react'; import { FC, useState } from 'react';
import { useHotkeys } from 'react-hotkeys-hook'; import { useHotkeys } from 'react-hotkeys-hook';
@ -19,6 +13,27 @@ import styles from './UserDropdown.module.scss';
import { AppStateOptions } from '../../stores/application-state'; import { AppStateOptions } from '../../stores/application-state';
// Lazy loaded components // Lazy loaded components
const CaretDownOutlined = dynamic(() => import('@ant-design/icons/CaretDownOutlined'), {
ssr: false,
});
const EditOutlined = dynamic(() => import('@ant-design/icons/EditOutlined'), {
ssr: false,
});
const LockOutlined = dynamic(() => import('@ant-design/icons/LockOutlined'), {
ssr: false,
});
const MessageOutlined = dynamic(() => import('@ant-design/icons/MessageOutlined'), {
ssr: false,
});
const UserOutlined = dynamic(() => import('@ant-design/icons/UserOutlined'), {
ssr: false,
});
const Modal = dynamic(() => import('../../ui/Modal/Modal').then(mod => mod.Modal), { const Modal = dynamic(() => import('../../ui/Modal/Modal').then(mod => mod.Modal), {
ssr: false, ssr: false,
}); });

View File

@ -1,11 +1,17 @@
import { Alert, Button, Input, Space, Spin, Collapse } from 'antd'; import { Alert, Button, Input, Space, Spin, Collapse } from 'antd';
import React, { FC, useState } from 'react'; import React, { FC, useState } from 'react';
import { CheckCircleOutlined } from '@ant-design/icons'; import dynamic from 'next/dynamic';
import styles from './FediAuthModal.module.scss'; import styles from './FediAuthModal.module.scss';
import { validateAccount } from '../../../utils/validators'; import { validateAccount } from '../../../utils/validators';
const { Panel } = Collapse; const { Panel } = Collapse;
// Lazy loaded components
const CheckCircleOutlined = dynamic(() => import('@ant-design/icons/CheckCircleOutlined'), {
ssr: false,
});
export type FediAuthModalProps = { export type FediAuthModalProps = {
authenticated: boolean; authenticated: boolean;
displayName: string; displayName: string;

View File

@ -1,11 +1,17 @@
import { CheckCircleOutlined } from '@ant-design/icons';
import { Alert, Input, Space, Spin, Collapse, Typography, Button } from 'antd'; import { Alert, Input, Space, Spin, Collapse, Typography, Button } from 'antd';
import dynamic from 'next/dynamic';
import React, { FC, useState } from 'react'; import React, { FC, useState } from 'react';
import { isValidUrl } from '../../../utils/urls'; import { isValidUrl } from '../../../utils/urls';
const { Panel } = Collapse; const { Panel } = Collapse;
const { Link } = Typography; const { Link } = Typography;
// Lazy loaded components
const CheckCircleOutlined = dynamic(() => import('@ant-design/icons/CheckCircleOutlined'), {
ssr: false,
});
export type IndieAuthModalProps = { export type IndieAuthModalProps = {
authenticated: boolean; authenticated: boolean;
displayName: string; displayName: string;

View File

@ -1,8 +1,14 @@
import { Popover } from 'antd'; import { Popover } from 'antd';
import { CloseOutlined } from '@ant-design/icons';
import React, { useState, useEffect, FC } from 'react'; import React, { useState, useEffect, FC } from 'react';
import dynamic from 'next/dynamic';
import styles from './NotifyReminderPopup.module.scss'; import styles from './NotifyReminderPopup.module.scss';
// Lazy loaded components
const CloseOutlined = dynamic(() => import('@ant-design/icons/CloseOutlined'), {
ssr: false,
});
export type NotifyReminderPopupProps = { export type NotifyReminderPopupProps = {
open: boolean; open: boolean;
children: React.ReactNode; children: React.ReactNode;

View File

@ -1,10 +1,16 @@
/* eslint-disable jsx-a11y/click-events-have-key-events */ /* eslint-disable jsx-a11y/click-events-have-key-events */
import { Divider } from 'antd'; import { Divider } from 'antd';
import { ClockCircleOutlined } from '@ant-design/icons';
import { FC } from 'react'; import { FC } from 'react';
import formatDistanceToNow from 'date-fns/formatDistanceToNow'; import formatDistanceToNow from 'date-fns/formatDistanceToNow';
import dynamic from 'next/dynamic';
import styles from './OfflineBanner.module.scss'; import styles from './OfflineBanner.module.scss';
// Lazy loaded components
const ClockCircleOutlined = dynamic(() => import('@ant-design/icons/ClockCircleOutlined'), {
ssr: false,
});
export type OfflineBannerProps = { export type OfflineBannerProps = {
streamName: string; streamName: string;
customText?: string; customText?: string;

View File

@ -1,9 +1,15 @@
import formatDistanceToNow from 'date-fns/formatDistanceToNow'; import formatDistanceToNow from 'date-fns/formatDistanceToNow';
import intervalToDuration from 'date-fns/intervalToDuration'; import intervalToDuration from 'date-fns/intervalToDuration';
import { FC, useEffect, useState } from 'react'; import { FC, useEffect, useState } from 'react';
import { EyeFilled } from '@ant-design/icons'; import dynamic from 'next/dynamic';
import styles from './Statusbar.module.scss'; import styles from './Statusbar.module.scss';
// Lazy loaded components
const EyeFilled = dynamic(() => import('@ant-design/icons/EyeFilled'), {
ssr: false,
});
export type StatusbarProps = { export type StatusbarProps = {
online: Boolean; online: Boolean;
lastConnectTime?: Date; lastConnectTime?: Date;

View File

@ -12,10 +12,10 @@ import {
Col, Col,
Tooltip, Tooltip,
} from 'antd'; } from 'antd';
import { DeleteOutlined } from '@ant-design/icons';
import format from 'date-fns/format'; import format from 'date-fns/format';
import dynamic from 'next/dynamic';
import { import {
fetchData, fetchData,
ACCESS_TOKENS, ACCESS_TOKENS,
@ -25,6 +25,12 @@ import {
const { Title, Paragraph } = Typography; const { Title, Paragraph } = Typography;
// Lazy loaded components
const DeleteOutlined = dynamic(() => import('@ant-design/icons/DeleteOutlined'), {
ssr: false,
});
const availableScopes = { const availableScopes = {
CAN_SEND_SYSTEM_MESSAGES: { CAN_SEND_SYSTEM_MESSAGES: {
name: 'System messages', name: 'System messages',

View File

@ -1,6 +1,6 @@
import { DeleteOutlined, EditOutlined } from '@ant-design/icons';
import { Button, Checkbox, Form, Input, Modal, Space, Table, Typography } from 'antd'; import { Button, Checkbox, Form, Input, Modal, Space, Table, Typography } from 'antd';
import _ from 'lodash'; import _ from 'lodash';
import dynamic from 'next/dynamic';
import React, { useContext, useEffect, useState } from 'react'; import React, { useContext, useEffect, useState } from 'react';
import { FormStatusIndicator } from '../../components/admin/FormStatusIndicator'; import { FormStatusIndicator } from '../../components/admin/FormStatusIndicator';
import { ExternalAction } from '../../interfaces/external-action'; import { ExternalAction } from '../../interfaces/external-action';
@ -14,6 +14,17 @@ import { ServerStatusContext } from '../../utils/server-status-context';
import { isValidUrl, DEFAULT_TEXTFIELD_URL_PATTERN } from '../../utils/urls'; import { isValidUrl, DEFAULT_TEXTFIELD_URL_PATTERN } from '../../utils/urls';
const { Title, Paragraph } = Typography; const { Title, Paragraph } = Typography;
// Lazy loaded components
const DeleteOutlined = dynamic(() => import('@ant-design/icons/DeleteOutlined'), {
ssr: false,
});
const EditOutlined = dynamic(() => import('@ant-design/icons/EditOutlined'), {
ssr: false,
});
let resetTimer = null; let resetTimer = null;
interface Props { interface Props {

View File

@ -1,7 +1,7 @@
import { DeleteOutlined } from '@ant-design/icons';
import { Button, Space, Table, Typography, Upload } from 'antd'; import { Button, Space, Table, Typography, Upload } from 'antd';
import { RcFile } from 'antd/lib/upload'; import { RcFile } from 'antd/lib/upload';
import React, { useEffect, useState } from 'react'; import React, { useEffect, useState } from 'react';
import dynamic from 'next/dynamic';
import FormStatusIndicator from '../../../components/admin/FormStatusIndicator'; import FormStatusIndicator from '../../../components/admin/FormStatusIndicator';
import { DELETE_EMOJI, fetchData, UPLOAD_EMOJI } from '../../../utils/apis'; import { DELETE_EMOJI, fetchData, UPLOAD_EMOJI } from '../../../utils/apis';
@ -16,6 +16,12 @@ import {
import { RESET_TIMEOUT } from '../../../utils/config-constants'; import { RESET_TIMEOUT } from '../../../utils/config-constants';
import { URL_CUSTOM_EMOJIS } from '../../../utils/constants'; import { URL_CUSTOM_EMOJIS } from '../../../utils/constants';
// Lazy loaded components
const DeleteOutlined = dynamic(() => import('@ant-design/icons/DeleteOutlined'), {
ssr: false,
});
type CustomEmoji = { type CustomEmoji = {
name: string; name: string;
url: string; url: string;

View File

@ -1,10 +1,10 @@
import React, { useState, useEffect } from 'react'; import React, { useState, useEffect } from 'react';
import { Table, Typography, Button } from 'antd'; import { Table, Typography, Button } from 'antd';
import { CheckCircleFilled, ExclamationCircleFilled } from '@ant-design/icons';
import classNames from 'classnames'; import classNames from 'classnames';
import { ColumnsType } from 'antd/es/table'; import { ColumnsType } from 'antd/es/table';
import format from 'date-fns/format'; import format from 'date-fns/format';
import dynamic from 'next/dynamic';
import { MessageType } from '../../../types/chat'; import { MessageType } from '../../../types/chat';
import { import {
CHAT_HISTORY, CHAT_HISTORY,
@ -18,6 +18,16 @@ import { UserPopover } from '../../../components/admin/UserPopover';
const { Title } = Typography; const { Title } = Typography;
// Lazy loaded components
const CheckCircleFilled = dynamic(() => import('@ant-design/icons/CheckCircleFilled'), {
ssr: false,
});
const ExclamationCircleFilled = dynamic(() => import('@ant-design/icons/ExclamationCircleFilled'), {
ssr: false,
});
function createUserNameFilters(messages: MessageType[]) { function createUserNameFilters(messages: MessageType[]) {
const filtered = messages.reduce((acc, curItem) => { const filtered = messages.reduce((acc, curItem) => {
const curAuthor = curItem.user.id; const curAuthor = curItem.user.id;

View File

@ -2,7 +2,7 @@ import React, { useEffect, useState, useContext } from 'react';
import { Table, Avatar, Button, Tabs } from 'antd'; import { Table, Avatar, Button, Tabs } from 'antd';
import { ColumnsType, SortOrder } from 'antd/lib/table/interface'; import { ColumnsType, SortOrder } from 'antd/lib/table/interface';
import format from 'date-fns/format'; import format from 'date-fns/format';
import { UserAddOutlined, UserDeleteOutlined } from '@ant-design/icons'; import dynamic from 'next/dynamic';
import { ServerStatusContext } from '../../../utils/server-status-context'; import { ServerStatusContext } from '../../../utils/server-status-context';
import { import {
FOLLOWERS, FOLLOWERS,
@ -13,6 +13,15 @@ import {
} from '../../../utils/apis'; } from '../../../utils/apis';
import { isEmptyObject } from '../../../utils/format'; import { isEmptyObject } from '../../../utils/format';
// Lazy loaded components
const UserAddOutlined = dynamic(() => import('@ant-design/icons/UserAddOutlined'), {
ssr: false,
});
const UserDeleteOutlined = dynamic(() => import('@ant-design/icons/UserDeleteOutlined'), {
ssr: false,
});
export interface Follower { export interface Follower {
link: string; link: string;
username: string; username: string;

View File

@ -1,10 +1,24 @@
import { BulbOutlined, LaptopOutlined, SaveOutlined } from '@ant-design/icons';
import { Row, Col, Typography } from 'antd'; import { Row, Col, Typography } from 'antd';
import React, { useEffect, useState } from 'react'; import React, { useEffect, useState } from 'react';
import dynamic from 'next/dynamic';
import { fetchData, FETCH_INTERVAL, HARDWARE_STATS } from '../../utils/apis'; import { fetchData, FETCH_INTERVAL, HARDWARE_STATS } from '../../utils/apis';
import { Chart } from '../../components/admin/Chart'; import { Chart } from '../../components/admin/Chart';
import { StatisticItem } from '../../components/admin/StatisticItem'; import { StatisticItem } from '../../components/admin/StatisticItem';
// Lazy loaded components
const BulbOutlined = dynamic(() => import('@ant-design/icons/BulbOutlined'), {
ssr: false,
});
const LaptopOutlined = dynamic(() => import('@ant-design/icons/LaptopOutlined'), {
ssr: false,
});
const SaveOutlined = dynamic(() => import('@ant-design/icons/SaveOutlined'), {
ssr: false,
});
// TODO: FIX TS WARNING FROM THIS. // TODO: FIX TS WARNING FROM THIS.
// interface TimedValue { // interface TimedValue {
// time: Date; // time: Date;

View File

@ -1,19 +1,51 @@
import { Button, Card, Col, Divider, Result, Row } from 'antd'; import { Button, Card, Col, Divider, Result, Row } from 'antd';
import Meta from 'antd/lib/card/Meta'; import Meta from 'antd/lib/card/Meta';
import Title from 'antd/lib/typography/Title'; import Title from 'antd/lib/typography/Title';
import {
ApiTwoTone,
BugTwoTone,
CameraTwoTone,
DatabaseTwoTone,
EditTwoTone,
Html5TwoTone,
LinkOutlined,
QuestionCircleTwoTone,
SettingTwoTone,
SlidersTwoTone,
} from '@ant-design/icons';
import React from 'react'; import React from 'react';
import dynamic from 'next/dynamic';
// Lazy loaded components
const ApiTwoTone = dynamic(() => import('@ant-design/icons/ApiTwoTone'), {
ssr: false,
});
const BugTwoTone = dynamic(() => import('@ant-design/icons/BugTwoTone'), {
ssr: false,
});
const CameraTwoTone = dynamic(() => import('@ant-design/icons/CameraTwoTone'), {
ssr: false,
});
const DatabaseTwoTone = dynamic(() => import('@ant-design/icons/DatabaseTwoTone'), {
ssr: false,
});
const EditTwoTone = dynamic(() => import('@ant-design/icons/EditTwoTone'), {
ssr: false,
});
const Html5TwoTone = dynamic(() => import('@ant-design/icons/Html5TwoTone'), {
ssr: false,
});
const LinkOutlined = dynamic(() => import('@ant-design/icons/LinkOutlined'), {
ssr: false,
});
const QuestionCircleTwoTone = dynamic(() => import('@ant-design/icons/QuestionCircleTwoTone'), {
ssr: false,
});
const SettingTwoTone = dynamic(() => import('@ant-design/icons/SettingTwoTone'), {
ssr: false,
});
const SlidersTwoTone = dynamic(() => import('@ant-design/icons/SlidersTwoTone'), {
ssr: false,
});
export default function Help() { export default function Help() {
const questions = [ const questions = [

View File

@ -1,8 +1,8 @@
/* eslint-disable @next/next/no-css-tags */ /* eslint-disable @next/next/no-css-tags */
import React, { useState, useEffect, useContext } from 'react'; import React, { useState, useEffect, useContext } from 'react';
import { Skeleton, Card, Statistic, Row, Col } from 'antd'; import { Skeleton, Card, Statistic, Row, Col } from 'antd';
import { UserOutlined, ClockCircleOutlined } from '@ant-design/icons';
import { formatDistanceToNow, formatRelative } from 'date-fns'; import { formatDistanceToNow, formatRelative } from 'date-fns';
import dynamic from 'next/dynamic';
import { ServerStatusContext } from '../../utils/server-status-context'; import { ServerStatusContext } from '../../utils/server-status-context';
import { LogTable } from '../../components/admin/LogTable'; import { LogTable } from '../../components/admin/LogTable';
import { Offline } from '../../components/admin/Offline'; import { Offline } from '../../components/admin/Offline';
@ -12,6 +12,16 @@ import { LOGS_WARN, fetchData, FETCH_INTERVAL } from '../../utils/apis';
import { formatIPAddress, isEmptyObject } from '../../utils/format'; import { formatIPAddress, isEmptyObject } from '../../utils/format';
import { NewsFeed } from '../../components/admin/NewsFeed'; import { NewsFeed } from '../../components/admin/NewsFeed';
// Lazy loaded components
const UserOutlined = dynamic(() => import('@ant-design/icons/UserOutlined'), {
ssr: false,
});
const ClockCircleOutlined = dynamic(() => import('@ant-design/icons/ClockCircleOutlined'), {
ssr: false,
});
function streamDetailsFormatter(streamDetails) { function streamDetailsFormatter(streamDetails) {
return ( return (
<ul className="statistics-list"> <ul className="statistics-list">

View File

@ -2,11 +2,25 @@
// import { BulbOutlined, LaptopOutlined, SaveOutlined } from '@ant-design/icons'; // import { BulbOutlined, LaptopOutlined, SaveOutlined } from '@ant-design/icons';
import { Row, Col, Typography, Space, Statistic, Card, Alert, Spin } from 'antd'; import { Row, Col, Typography, Space, Statistic, Card, Alert, Spin } from 'antd';
import React, { ReactNode, useEffect, useState } from 'react'; import React, { ReactNode, useEffect, useState } from 'react';
import { ClockCircleOutlined, WarningOutlined, WifiOutlined } from '@ant-design/icons'; import dynamic from 'next/dynamic';
import { fetchData, FETCH_INTERVAL, API_STREAM_HEALTH_METRICS } from '../../utils/apis'; import { fetchData, FETCH_INTERVAL, API_STREAM_HEALTH_METRICS } from '../../utils/apis';
import { Chart } from '../../components/admin/Chart'; import { Chart } from '../../components/admin/Chart';
import { StreamHealthOverview } from '../../components/admin/StreamHealthOverview'; import { StreamHealthOverview } from '../../components/admin/StreamHealthOverview';
// Lazy loaded components
const ClockCircleOutlined = dynamic(() => import('@ant-design/icons/ClockCircleOutlined'), {
ssr: false,
});
const WarningOutlined = dynamic(() => import('@ant-design/icons/WarningOutlined'), {
ssr: false,
});
const WifiOutlined = dynamic(() => import('@ant-design/icons/WifiOutlined'), {
ssr: false,
});
interface TimedValue { interface TimedValue {
time: Date; time: Date;
value: Number; value: Number;

View File

@ -1,7 +1,7 @@
import React, { useState, useEffect, useContext } from 'react'; import React, { useState, useEffect, useContext } from 'react';
import { Row, Col, Typography, Menu, Dropdown, Spin, Alert } from 'antd'; import { Row, Col, Typography, Menu, Dropdown, Spin, Alert } from 'antd';
import { DownOutlined, UserOutlined } from '@ant-design/icons';
import { getUnixTime, sub } from 'date-fns'; import { getUnixTime, sub } from 'date-fns';
import dynamic from 'next/dynamic';
import { Chart } from '../../components/admin/Chart'; import { Chart } from '../../components/admin/Chart';
import { StatisticItem } from '../../components/admin/StatisticItem'; import { StatisticItem } from '../../components/admin/StatisticItem';
import { ViewerTable } from '../../components/admin/ViewerTable'; import { ViewerTable } from '../../components/admin/ViewerTable';
@ -10,6 +10,16 @@ import { ServerStatusContext } from '../../utils/server-status-context';
import { VIEWERS_OVER_TIME, ACTIVE_VIEWER_DETAILS, fetchData } from '../../utils/apis'; import { VIEWERS_OVER_TIME, ACTIVE_VIEWER_DETAILS, fetchData } from '../../utils/apis';
// Lazy loaded components
const DownOutlined = dynamic(() => import('@ant-design/icons/DownOutlined'), {
ssr: false,
});
const UserOutlined = dynamic(() => import('@ant-design/icons/UserOutlined'), {
ssr: false,
});
const FETCH_INTERVAL = 60 * 1000; // 1 min const FETCH_INTERVAL = 60 * 1000; // 1 min
export default function ViewersOverTime() { export default function ViewersOverTime() {

View File

@ -1,5 +1,4 @@
/* eslint-disable react/destructuring-assignment */ /* eslint-disable react/destructuring-assignment */
import { DeleteOutlined } from '@ant-design/icons';
import { import {
Button, Button,
Checkbox, Checkbox,
@ -13,12 +12,19 @@ import {
Typography, Typography,
Tooltip, Tooltip,
} from 'antd'; } from 'antd';
import dynamic from 'next/dynamic';
import React, { useEffect, useState } from 'react'; import React, { useEffect, useState } from 'react';
import { CREATE_WEBHOOK, DELETE_WEBHOOK, fetchData, WEBHOOKS } from '../../utils/apis'; import { CREATE_WEBHOOK, DELETE_WEBHOOK, fetchData, WEBHOOKS } from '../../utils/apis';
import { isValidUrl, DEFAULT_TEXTFIELD_URL_PATTERN } from '../../utils/urls'; import { isValidUrl, DEFAULT_TEXTFIELD_URL_PATTERN } from '../../utils/urls';
const { Title, Paragraph } = Typography; const { Title, Paragraph } = Typography;
// Lazy loaded components
const DeleteOutlined = dynamic(() => import('@ant-design/icons/DeleteOutlined'), {
ssr: false,
});
const availableEvents = { const availableEvents = {
CHAT: { name: 'Chat messages', description: 'When a user sends a chat message', color: 'purple' }, CHAT: { name: 'Chat messages', description: 'When a user sends a chat message', color: 'purple' },
USER_JOINED: { name: 'User joined', description: 'When a user joins the chat', color: 'green' }, USER_JOINED: { name: 'User joined', description: 'When a user joins the chat', color: 'green' },

View File

@ -1,9 +1,22 @@
import { import dynamic from 'next/dynamic';
CheckCircleFilled,
ExclamationCircleFilled, // Lazy loaded components
LoadingOutlined,
WarningOutlined, const CheckCircleFilled = dynamic(() => import('@ant-design/icons/CheckCircleFilled'), {
} from '@ant-design/icons'; ssr: false,
});
const ExclamationCircleFilled = dynamic(() => import('@ant-design/icons/ExclamationCircleFilled'), {
ssr: false,
});
const LoadingOutlined = dynamic(() => import('@ant-design/icons/LoadingOutlined'), {
ssr: false,
});
const WarningOutlined = dynamic(() => import('@ant-design/icons/WarningOutlined'), {
ssr: false,
});
export const STATUS_RESET_TIMEOUT = 3000; export const STATUS_RESET_TIMEOUT = 3000;