mirror of
https://github.com/toeverything/AFFiNE.git
synced 2024-12-18 18:01:35 +03:00
Merge branch 'develop'
This commit is contained in:
commit
09dcca1b8d
@ -22,7 +22,7 @@ See https://github.com/all-?/all-contributors/issues/361#issuecomment-637166066
|
||||
|
||||
<!-- ALL-CONTRIBUTORS-BADGE:END -->
|
||||
|
||||
[![affine.pro](https://img.shields.io/static/v1?label=affine.pro&logo=&color=orange&message=→)](https://affine.pro)
|
||||
[![affine.pro](https://img.shields.io/static/v1?label=live%20demo&logo=&color=orange&message=→)](https://affine.pro)
|
||||
[![stars](https://img.shields.io/github/stars/toeverything/AFFiNE.svg?style=flat&logo=github&colorB=red&label=stars)](https://github.com/toeverything/AFFiNE)
|
||||
[![All Contributors][all-contributors-badge]](#contributors)
|
||||
[![Node](https://img.shields.io/badge/node->=16.0-success)](https://www.typescriptlang.org/)
|
||||
|
@ -1,9 +1,15 @@
|
||||
import { type FC, useRef } from 'react';
|
||||
import { type ComponentType, useRef } from 'react';
|
||||
import * as uiIcons from '@toeverything/components/icons';
|
||||
import { message, styled } from '@toeverything/components/ui';
|
||||
import { copy } from './copy';
|
||||
|
||||
const IconBooth = ({ name, Icon }: { name: string; Icon: FC<any> }) => {
|
||||
const IconBooth = ({
|
||||
name,
|
||||
Icon,
|
||||
}: {
|
||||
name: string;
|
||||
Icon: ComponentType<any>;
|
||||
}) => {
|
||||
const on_click = () => {
|
||||
copy(`<${name} />`);
|
||||
message.success('Copied ~');
|
||||
@ -36,7 +42,13 @@ export const Icons = () => {
|
||||
<hr />
|
||||
<IconsContainer>
|
||||
{_icons.map(([key, icon]) => {
|
||||
return <IconBooth key={key} name={key} Icon={icon as FC} />;
|
||||
return (
|
||||
<IconBooth
|
||||
key={key}
|
||||
name={key}
|
||||
Icon={icon as ComponentType<any>}
|
||||
/>
|
||||
);
|
||||
})}
|
||||
</IconsContainer>
|
||||
</Container>
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import type { TldrawApp } from '@toeverything/components/board-state';
|
||||
import type { TDShape } from '@toeverything/components/board-types';
|
||||
import { Popover, Tooltip, IconButton } from '@toeverything/components/ui';
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import { Fragment } from 'react';
|
||||
import { Vec } from '@tldraw/vec';
|
||||
import { TldrawApp, TLDR } from '@toeverything/components/board-state';
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import type { TldrawApp } from '@toeverything/components/board-state';
|
||||
import type { TDShape } from '@toeverything/components/board-types';
|
||||
import { IconButton, Tooltip } from '@toeverything/components/ui';
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import type { TldrawApp } from '@toeverything/components/board-state';
|
||||
import type { TDShape } from '@toeverything/components/board-types';
|
||||
import {
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import type { TldrawApp } from '@toeverything/components/board-state';
|
||||
import type { TDShape } from '@toeverything/components/board-types';
|
||||
import { FontSizeStyle } from '@toeverything/components/board-types';
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import type { TldrawApp } from '@toeverything/components/board-state';
|
||||
import type { TDShape } from '@toeverything/components/board-types';
|
||||
import {
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import type { TldrawApp } from '@toeverything/components/board-state';
|
||||
import type { TDShape } from '@toeverything/components/board-types';
|
||||
import { IconButton, Tooltip } from '@toeverything/components/ui';
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import type { TldrawApp } from '@toeverything/components/board-state';
|
||||
import type { TDShape } from '@toeverything/components/board-types';
|
||||
import { IconButton, Tooltip } from '@toeverything/components/ui';
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import { DashStyle, StrokeWidth } from '@toeverything/components/board-types';
|
||||
import {
|
||||
LineNoneIcon,
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import type { TldrawApp } from '@toeverything/components/board-state';
|
||||
import { DashStyle, StrokeWidth } from '@toeverything/components/board-types';
|
||||
import type { TDShape } from '@toeverything/components/board-types';
|
||||
|
@ -1,4 +1,4 @@
|
||||
import type { FC, ReactNode } from 'react';
|
||||
import type { ReactNode } from 'react';
|
||||
|
||||
export const ContextMenu = ({ children }: { children: ReactNode }) => {
|
||||
return <div>{children}</div>;
|
||||
|
@ -1,4 +1,4 @@
|
||||
import type { FC, PropsWithChildren } from 'react';
|
||||
import type { PropsWithChildren } from 'react';
|
||||
import { useMemo } from 'react';
|
||||
import { styled, Tooltip } from '@toeverything/components/ui';
|
||||
import { ShapeColorNoneIcon } from '@toeverything/components/icons';
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { FC, useState, useEffect } from 'react';
|
||||
import { useState, useEffect } from 'react';
|
||||
import {
|
||||
ConnectorIcon,
|
||||
ConectorLineIcon,
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { FC, useState, useEffect } from 'react';
|
||||
import { useState, useEffect } from 'react';
|
||||
import {
|
||||
ShapeIcon,
|
||||
RectangleIcon,
|
||||
|
@ -1,4 +1,3 @@
|
||||
import { FC } from 'react';
|
||||
import style9 from 'style9';
|
||||
import {
|
||||
// MuiIconButton as IconButton,
|
||||
@ -14,6 +13,10 @@ import {
|
||||
SelectIcon,
|
||||
TextIcon,
|
||||
EraserIcon,
|
||||
SelectIconProps,
|
||||
EraserIconProps,
|
||||
HandToolIconProps,
|
||||
TextIconProps,
|
||||
} from '@toeverything/components/icons';
|
||||
|
||||
import {
|
||||
@ -26,6 +29,7 @@ import { TldrawApp } from '@toeverything/components/board-state';
|
||||
import { ShapeTools } from './ShapeTools';
|
||||
import { PenTools } from './pen-tools';
|
||||
import { LineTools } from './LineTools';
|
||||
import { ComponentType, Component } from 'react';
|
||||
|
||||
const activeToolSelector = (s: TDSnapshot) => s.appState.activeTool;
|
||||
const toolLockedSelector = (s: TDSnapshot) => s.appState.isToolLocked;
|
||||
@ -34,8 +38,10 @@ const tools: Array<{
|
||||
type: string;
|
||||
label?: string;
|
||||
tooltip?: string;
|
||||
icon?: FC;
|
||||
component?: FC<{ app: TldrawApp }>;
|
||||
icon?: ComponentType<
|
||||
SelectIconProps | EraserIconProps | HandToolIconProps | TextIconProps
|
||||
>;
|
||||
component?: ComponentType<{ app: TldrawApp }>;
|
||||
}> = [
|
||||
{
|
||||
type: 'select',
|
||||
|
@ -1,4 +1,4 @@
|
||||
import type { FC, ReactNode } from 'react';
|
||||
import type { ReactNode } from 'react';
|
||||
import { Tooltip, styled, IconButton } from '@toeverything/components/ui';
|
||||
|
||||
interface PenProps {
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { FC, ReactElement, type CSSProperties } from 'react';
|
||||
import { ReactElement, type CSSProperties } from 'react';
|
||||
import style9 from 'style9';
|
||||
import {
|
||||
MuiDivider as Divider,
|
||||
|
@ -1,4 +1,3 @@
|
||||
import { FC } from 'react';
|
||||
import {
|
||||
MuiIconButton as IconButton,
|
||||
MuiButton as Button,
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import { Utils } from '@tldraw/core';
|
||||
import Vec from '@tldraw/vec';
|
||||
import { TLDR } from '@toeverything/components/board-state';
|
||||
|
@ -1,4 +1,4 @@
|
||||
import type { FC, CSSProperties } from 'react';
|
||||
import type { CSSProperties } from 'react';
|
||||
import type { TLBounds } from '@tldraw/core';
|
||||
import { styled } from '@toeverything/components/ui';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import type { FC, CSSProperties, PointerEventHandler } from 'react';
|
||||
import type { CSSProperties, PointerEventHandler } from 'react';
|
||||
import { useState, useRef } from 'react';
|
||||
import type { TLBounds } from '@tldraw/core';
|
||||
import Vec from '@tldraw/vec';
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { FC, useState } from 'react';
|
||||
import { useState } from 'react';
|
||||
import { useNavigate } from 'react-router';
|
||||
import clsx from 'clsx';
|
||||
import style9 from 'style9';
|
||||
@ -21,7 +21,7 @@ export const commonListContainer = 'commonListContainer';
|
||||
type Content = {
|
||||
id: string;
|
||||
content: string;
|
||||
icon: FC<SvgIconProps>;
|
||||
icon: (prop: SvgIconProps) => JSX.Element;
|
||||
};
|
||||
|
||||
export type CommonListItem = {
|
||||
|
@ -5,7 +5,7 @@ import {
|
||||
Protocol,
|
||||
} from '@toeverything/datasource/db-service';
|
||||
import { type CreateView } from '@toeverything/framework/virgo';
|
||||
import { useEffect, useRef, useState, type FC } from 'react';
|
||||
import { useEffect, useRef, useState } from 'react';
|
||||
|
||||
import {
|
||||
TextManage,
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { FC, useState, useRef, useEffect } from 'react';
|
||||
import { useState, useRef, useEffect } from 'react';
|
||||
import { StyleWithAtRules } from 'style9';
|
||||
|
||||
import { CreateView } from '@toeverything/framework/virgo';
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { FC, useState } from 'react';
|
||||
import { useState } from 'react';
|
||||
import { CreateView } from '@toeverything/framework/virgo';
|
||||
import { styled } from '@toeverything/components/ui';
|
||||
import { useOnSelect } from '@toeverything/components/editor-core';
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { FC, useState } from 'react';
|
||||
import { useState } from 'react';
|
||||
import { CreateView } from '@toeverything/framework/virgo';
|
||||
import {
|
||||
BlockPendantProvider,
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { FC, useState } from 'react';
|
||||
import { useState } from 'react';
|
||||
import { CreateView } from '@toeverything/framework/virgo';
|
||||
import {
|
||||
useOnSelect,
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { FC, useState, useEffect, useRef } from 'react';
|
||||
import { useState, useEffect, useRef } from 'react';
|
||||
import { CreateView } from '@toeverything/framework/virgo';
|
||||
import { Upload } from '../../components/upload/upload';
|
||||
import { services, FileColumnValue } from '@toeverything/datasource/db-service';
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { FC, useEffect, useLayoutEffect, useRef } from 'react';
|
||||
import { useEffect, useLayoutEffect, useRef } from 'react';
|
||||
import { ChildrenView } from '@toeverything/framework/virgo';
|
||||
import { styled } from '@toeverything/components/ui';
|
||||
import { sleep } from '@toeverything/utils';
|
||||
|
@ -1,8 +1,9 @@
|
||||
import { FC } from 'react';
|
||||
import { RenderBlock } from '@toeverything/components/editor-core';
|
||||
import { ChildrenView, CreateView } from '@toeverything/framework/virgo';
|
||||
|
||||
export const GridItemRender = function (creator: FC<ChildrenView>) {
|
||||
export const GridItemRender = function (
|
||||
creator: (prop: ChildrenView) => JSX.Element
|
||||
) {
|
||||
const GridItem = function (props: CreateView) {
|
||||
const { block } = props;
|
||||
const children = (
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import { useState } from 'react';
|
||||
import { styled } from '@toeverything/components/ui';
|
||||
import { BlockEditor } from '@toeverything/framework/virgo';
|
||||
|
@ -1,6 +1,6 @@
|
||||
import { RenderBlock } from '@toeverything/components/editor-core';
|
||||
import { CreateView } from '@toeverything/framework/virgo';
|
||||
import React, { FC, useEffect, useRef, useState } from 'react';
|
||||
import React, { useEffect, useRef, useState } from 'react';
|
||||
import { GridHandle } from './GirdHandle';
|
||||
import { styled } from '@toeverything/components/ui';
|
||||
import ReactDOM from 'react-dom';
|
||||
|
@ -1,8 +1,7 @@
|
||||
import { FC } from 'react';
|
||||
import { CreateView } from '@toeverything/framework/virgo';
|
||||
import { BlockContainer } from '../../components/BlockContainer';
|
||||
|
||||
export function GridRender(creator: FC<CreateView>) {
|
||||
export function GridRender(creator: (prop: CreateView) => JSX.Element) {
|
||||
return function GridWithItem(props: CreateView) {
|
||||
const { editor, block } = props;
|
||||
return (
|
||||
|
@ -8,7 +8,7 @@ import {
|
||||
} from '@toeverything/components/editor-core';
|
||||
import { styled } from '@toeverything/components/ui';
|
||||
import type { CreateView } from '@toeverything/framework/virgo';
|
||||
import type { ComponentType, FC } from 'react';
|
||||
import type { ComponentType } from 'react';
|
||||
import { useState } from 'react';
|
||||
import { GroupMenuWrapper } from './group-menu';
|
||||
import { SceneKanban } from './scene-kanban';
|
||||
|
@ -1,6 +1,5 @@
|
||||
import { RenderBlockChildren } from '@toeverything/components/editor-core';
|
||||
import type { CreateView } from '@toeverything/framework/virgo';
|
||||
import { FC } from 'react';
|
||||
|
||||
export const ScenePage = ({ block }: CreateView) => {
|
||||
return <RenderBlockChildren block={block} />;
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import { useState, useMemo, useEffect } from 'react';
|
||||
import type { DefaultColumnsValue } from '@toeverything/datasource/db-service';
|
||||
import type { CreateView } from '@toeverything/framework/virgo';
|
||||
|
@ -1,9 +1,9 @@
|
||||
import { styled } from '@toeverything/components/ui';
|
||||
import type { FC } from 'react';
|
||||
|
||||
import type { SvgIconProps } from '@toeverything/components/ui';
|
||||
|
||||
interface Props {
|
||||
Icon: FC<SvgIconProps>;
|
||||
Icon: (prop: SvgIconProps) => JSX.Element;
|
||||
text?: string;
|
||||
onClick: () => void;
|
||||
}
|
||||
|
@ -1,4 +1,3 @@
|
||||
import { FC } from 'react';
|
||||
import { CreateView } from '@toeverything/framework/virgo';
|
||||
|
||||
export const GroupDividerView = ({ block, editor }: CreateView) => {
|
||||
|
@ -6,7 +6,7 @@ import {
|
||||
import { styled } from '@toeverything/components/ui';
|
||||
import { services } from '@toeverything/datasource/db-service';
|
||||
import { CreateView } from '@toeverything/framework/virgo';
|
||||
import { FC, useEffect, useRef, useState } from 'react';
|
||||
import { useEffect, useRef, useState } from 'react';
|
||||
import { Image as SourceView } from '../../components/ImageView';
|
||||
import { Upload } from '../../components/upload/upload';
|
||||
import { SCENE_CONFIG } from '../group/config';
|
||||
|
@ -5,7 +5,7 @@ import {
|
||||
Protocol,
|
||||
} from '@toeverything/datasource/db-service';
|
||||
import { type CreateView } from '@toeverything/framework/virgo';
|
||||
import { useEffect, useRef, useState, type FC } from 'react';
|
||||
import { useEffect, useRef, useState } from 'react';
|
||||
import {
|
||||
TextManage,
|
||||
type ExtendedTextUtils,
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { FC, useRef, useEffect, useMemo, useState } from 'react';
|
||||
import { useRef, useEffect, useMemo, useState } from 'react';
|
||||
import { useParams } from 'react-router';
|
||||
|
||||
import { BackLink, TextProps } from '@toeverything/components/common';
|
||||
|
@ -13,9 +13,9 @@ import {
|
||||
} from '@toeverything/framework/virgo';
|
||||
|
||||
import { PageView } from './PageView';
|
||||
import { ComponentType, FC } from 'react';
|
||||
|
||||
export const PageChildrenView: FC<ChildrenView> = props => props.children;
|
||||
export const PageChildrenView: (prop: ChildrenView) => JSX.Element = props =>
|
||||
props.children;
|
||||
|
||||
export class PageBlock extends BaseView {
|
||||
type = Protocol.Block.Type.page;
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { FC, useEffect, useMemo, useState } from 'react';
|
||||
import { useEffect, useMemo, useState } from 'react';
|
||||
|
||||
import { InlineRefLink } from '@toeverything/components/common';
|
||||
import { CreateView } from '@toeverything/framework/virgo';
|
||||
|
@ -10,13 +10,13 @@ import {
|
||||
getTextProperties,
|
||||
SelectBlock,
|
||||
} from '@toeverything/framework/virgo';
|
||||
import { FC } from 'react';
|
||||
|
||||
import { TextView } from './TextView';
|
||||
|
||||
export class QuoteBlock extends BaseView {
|
||||
type = Protocol.Block.Type.quote;
|
||||
|
||||
View: FC<CreateView> = TextView;
|
||||
View: (prop: CreateView) => JSX.Element = TextView;
|
||||
|
||||
// override ChildrenView = IndentWrapper;
|
||||
|
||||
@ -83,7 +83,7 @@ export class QuoteBlock extends BaseView {
|
||||
export class CalloutBlock extends BaseView {
|
||||
type = Protocol.Block.Type.callout;
|
||||
|
||||
View: FC<CreateView> = TextView;
|
||||
View: (prop: CreateView) => JSX.Element = TextView;
|
||||
|
||||
// override ChildrenView = IndentWrapper;
|
||||
|
||||
|
@ -11,13 +11,13 @@ import {
|
||||
Protocol,
|
||||
} from '@toeverything/datasource/db-service';
|
||||
import { TextView } from './TextView';
|
||||
import { FC } from 'react';
|
||||
|
||||
import { getRandomString } from '@toeverything/components/common';
|
||||
|
||||
export class TextBlock extends BaseView {
|
||||
type = Protocol.Block.Type.text;
|
||||
|
||||
View: FC<CreateView> = TextView;
|
||||
View: (prop: CreateView) => JSX.Element = TextView;
|
||||
|
||||
override async onCreate(block: AsyncBlock): Promise<AsyncBlock> {
|
||||
if (!block.getProperty('text')) {
|
||||
@ -134,7 +134,7 @@ export class TextBlock extends BaseView {
|
||||
export class Heading1Block extends BaseView {
|
||||
type = Protocol.Block.Type.heading1;
|
||||
|
||||
View: FC<CreateView> = TextView;
|
||||
View: (prop: CreateView) => JSX.Element = TextView;
|
||||
|
||||
override async onCreate(block: AsyncBlock): Promise<AsyncBlock> {
|
||||
if (!block.getProperty('text')) {
|
||||
@ -199,7 +199,7 @@ export class Heading1Block extends BaseView {
|
||||
export class Heading2Block extends BaseView {
|
||||
type = Protocol.Block.Type.heading2;
|
||||
|
||||
View: FC<CreateView> = TextView;
|
||||
View: (prop: CreateView) => JSX.Element = TextView;
|
||||
|
||||
override async onCreate(block: AsyncBlock): Promise<AsyncBlock> {
|
||||
if (!block.getProperty('text')) {
|
||||
@ -264,7 +264,7 @@ export class Heading2Block extends BaseView {
|
||||
export class Heading3Block extends BaseView {
|
||||
type = Protocol.Block.Type.heading3;
|
||||
|
||||
View: FC<CreateView> = TextView;
|
||||
View: (prop: CreateView) => JSX.Element = TextView;
|
||||
|
||||
override async onCreate(block: AsyncBlock): Promise<AsyncBlock> {
|
||||
if (!block.getProperty('text')) {
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { FC, useState } from 'react';
|
||||
import { useState } from 'react';
|
||||
|
||||
import { CustomText, TextProps } from '@toeverything/components/common';
|
||||
import {
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { FC, useEffect, useState } from 'react';
|
||||
import { useEffect, useState } from 'react';
|
||||
import { CreateView } from '@toeverything/framework/virgo';
|
||||
import {
|
||||
is_heading_child_type,
|
||||
|
@ -1,5 +1,5 @@
|
||||
import { styled } from '@toeverything/components/ui';
|
||||
import { FC, useMemo } from 'react';
|
||||
import { useMemo } from 'react';
|
||||
|
||||
interface CheckBoxProps {
|
||||
size?: number;
|
||||
|
@ -5,7 +5,7 @@ import {
|
||||
Protocol,
|
||||
} from '@toeverything/datasource/db-service';
|
||||
import { AsyncBlock, type CreateView } from '@toeverything/framework/virgo';
|
||||
import { useRef, type FC } from 'react';
|
||||
import { useRef } from 'react';
|
||||
import {
|
||||
TextManage,
|
||||
type ExtendedTextUtils,
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { FC, useState } from 'react';
|
||||
import { useState } from 'react';
|
||||
import { CreateView } from '@toeverything/framework/virgo';
|
||||
import { Upload } from '../../components/upload/upload';
|
||||
import { SourceView } from '../../components/source-view';
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import { styled } from '@toeverything/components/ui';
|
||||
import { AsyncBlock, BlockEditor } from '@toeverything/framework/virgo';
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
import { AsyncBlock } from '@toeverything/framework/virgo';
|
||||
import { FC } from 'react';
|
||||
|
||||
import { ResizableBox } from 'react-resizable';
|
||||
import { styled } from '@toeverything/components/ui';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { FC, PropsWithChildren } from 'react';
|
||||
import { PropsWithChildren } from 'react';
|
||||
import { ChildrenView } from '@toeverything/framework/virgo';
|
||||
import { styled } from '@toeverything/components/ui';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { FC, useMemo } from 'react';
|
||||
import { useMemo } from 'react';
|
||||
import { createEditor } from 'slate';
|
||||
import { Slate, Editable as SlateEditable, withReact } from 'slate-react';
|
||||
import { ErrorBoundary } from '@toeverything/utils';
|
||||
|
@ -4,14 +4,7 @@ import {
|
||||
useLazyIframe,
|
||||
} from '@toeverything/components/editor-core';
|
||||
import { styled } from '@toeverything/components/ui';
|
||||
import {
|
||||
FC,
|
||||
ReactElement,
|
||||
ReactNode,
|
||||
useEffect,
|
||||
useRef,
|
||||
useState,
|
||||
} from 'react';
|
||||
import { ReactElement, ReactNode, useEffect, useRef, useState } from 'react';
|
||||
import { SCENE_CONFIG } from '../../blocks/group/config';
|
||||
import { BlockPreview } from './BlockView';
|
||||
import { formatUrl } from './format-url';
|
||||
|
@ -6,7 +6,7 @@ import {
|
||||
useLayoutEffect,
|
||||
useCallback,
|
||||
} from 'react';
|
||||
import type { FC } from 'react';
|
||||
|
||||
import { VariableSizeGrid, areEqual } from 'react-window';
|
||||
import type {
|
||||
GridChildComponentProps,
|
||||
@ -34,7 +34,7 @@ export interface CustomCellProps<T = unknown> {
|
||||
value: T;
|
||||
valueKey: string;
|
||||
}
|
||||
export type CustomCell<T = unknown> = FC<CustomCellProps<T>>;
|
||||
export type CustomCell<T = unknown> = (prop: CustomCellProps<T>) => JSX.Element;
|
||||
|
||||
interface TableData {
|
||||
columns: readonly TableColumn[];
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import { Checkbox } from '@toeverything/components/ui';
|
||||
import type { BooleanColumnValue } from '@toeverything/datasource/db-service';
|
||||
import type { CellProps } from '../types';
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import { ColumnType } from '@toeverything/datasource/db-service';
|
||||
import type { CustomCellProps as TableCustomCellProps } from '../basic-table';
|
||||
import { DEFAULT_RENDER_CELL } from '../basic-table';
|
||||
@ -16,7 +15,7 @@ const DefaultCell = ({ onChange, ...props }: CellProps) => {
|
||||
/**
|
||||
* @deprecated
|
||||
*/
|
||||
const cellMap: Record<ColumnType, FC<CellProps<any>>> = {
|
||||
const cellMap: Record<ColumnType, (prop: CellProps<any>) => JSX.Element> = {
|
||||
[ColumnType.content]: DefaultCell,
|
||||
[ColumnType.number]: DefaultCell,
|
||||
[ColumnType.enum]: SelectCell,
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import { useMemo } from 'react';
|
||||
import { OldSelect } from '@toeverything/components/ui';
|
||||
import type { EnumColumnValue } from '@toeverything/datasource/db-service';
|
||||
|
@ -1,4 +1,4 @@
|
||||
import type { FC, ReactNode } from 'react';
|
||||
import type { ReactNode } from 'react';
|
||||
import { BasicTable } from './basic-table';
|
||||
import type { BasicTableProps } from './basic-table';
|
||||
|
||||
|
@ -1,5 +1,4 @@
|
||||
import {
|
||||
FC,
|
||||
useRef,
|
||||
ChangeEvent,
|
||||
ReactElement,
|
||||
|
@ -1,4 +1,4 @@
|
||||
import type { FC, PropsWithChildren } from 'react';
|
||||
import type { PropsWithChildren } from 'react';
|
||||
import { styled } from '@toeverything/components/ui';
|
||||
import type { AsyncBlock } from '../editor';
|
||||
import { PendantPopover } from './pendant-popover';
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { FC, useRef } from 'react';
|
||||
import { useRef } from 'react';
|
||||
import { AsyncBlock } from '../../editor';
|
||||
import { PendantHistoryPanel } from '../pendant-history-panel';
|
||||
import {
|
||||
|
@ -4,7 +4,6 @@ import {
|
||||
SelectOption,
|
||||
SelectOptionId,
|
||||
} from '../recast-block';
|
||||
import { FunctionComponent } from 'react';
|
||||
import { TextFontIcon } from '@toeverything/components/icons';
|
||||
|
||||
export { PropertyType as PendantTypes } from '../recast-block';
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import type { AsyncBlock } from '../editor';
|
||||
import { RenderBlock } from './RenderBlock';
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { useCallback, type FC, type MouseEvent } from 'react';
|
||||
import { useCallback, type MouseEvent } from 'react';
|
||||
import {
|
||||
styled,
|
||||
Tooltip,
|
||||
@ -83,7 +83,7 @@ export const AddCommentActions = ({
|
||||
};
|
||||
|
||||
type IconButtonWithTooltipProps = {
|
||||
icon: FC<SvgIconProps>;
|
||||
icon: (prop: SvgIconProps) => JSX.Element;
|
||||
tooltip?: string;
|
||||
};
|
||||
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import {
|
||||
HeadingOneIcon,
|
||||
HeadingTwoIcon,
|
||||
@ -40,7 +39,7 @@ type ClickItemHandler = (
|
||||
export type CommandMenuDataType = {
|
||||
type: BlockFlavorKeys;
|
||||
text: string;
|
||||
icon: FC<SvgIconProps>;
|
||||
icon: (prop: SvgIconProps) => JSX.Element;
|
||||
};
|
||||
|
||||
export const commonCommandMenuHandler: ClickItemHandler = async (
|
||||
|
@ -135,7 +135,9 @@ export const MenuDropdownItem = ({
|
||||
);
|
||||
};
|
||||
|
||||
const withStylesForIcon = (FontIconComponent: React.FC<SvgIconProps>) =>
|
||||
const withStylesForIcon = (
|
||||
FontIconComponent: (prop: SvgIconProps) => JSX.Element
|
||||
) =>
|
||||
styled(FontIconComponent, {
|
||||
shouldForwardProp: (prop: string) =>
|
||||
!['fontColor', 'fontBgColor'].includes(prop),
|
||||
|
@ -1,4 +1,3 @@
|
||||
import React, { type FC } from 'react';
|
||||
import type { SvgIconProps } from '@toeverything/components/ui';
|
||||
import type { Virgo, SelectionInfo } from '@toeverything/framework/virgo';
|
||||
import { inlineMenuNames, INLINE_MENU_UI_TYPES } from './config';
|
||||
@ -23,7 +22,7 @@ export type ClickItemHandler = ({
|
||||
|
||||
export type IconItemType = {
|
||||
type: typeof INLINE_MENU_UI_TYPES['icon'];
|
||||
icon: FC<SvgIconProps>;
|
||||
icon: (prop: SvgIconProps) => JSX.Element;
|
||||
nameKey: InlineMenuNamesType;
|
||||
name: typeof inlineMenuNames[InlineMenuNamesType];
|
||||
onClick?: ClickItemHandler;
|
||||
@ -32,7 +31,7 @@ export type IconItemType = {
|
||||
|
||||
export type DropdownItemType = {
|
||||
type: typeof INLINE_MENU_UI_TYPES['dropdown'];
|
||||
icon: FC<SvgIconProps>;
|
||||
icon: (prop: SvgIconProps) => JSX.Element;
|
||||
nameKey: InlineMenuNamesType;
|
||||
name: typeof inlineMenuNames[InlineMenuNamesType];
|
||||
children: IconItemType[];
|
||||
|
@ -1,7 +1,6 @@
|
||||
import {
|
||||
useState,
|
||||
useEffect,
|
||||
FC,
|
||||
type MouseEvent,
|
||||
type DragEvent,
|
||||
type ReactNode,
|
||||
|
@ -1,4 +1,4 @@
|
||||
export const timestamp = 1660239514133;
|
||||
export const timestamp = 1660270988401;
|
||||
export * from './image/image';
|
||||
export * from './format-clear/format-clear';
|
||||
export * from './backward-undo/backward-undo';
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import type { DocMode } from './type';
|
||||
import { styled } from '@toeverything/components/ui';
|
||||
import { StatusIcon } from './StatusIcon';
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import { styled } from '@toeverything/components/ui';
|
||||
import { LastModified } from './LastModified';
|
||||
import { Logout } from './Logout';
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import format from 'date-fns/format';
|
||||
import { Typography, styled } from '@toeverything/components/ui';
|
||||
import { useUserAndSpaces } from '@toeverything/datasource/state';
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import { MoveToIcon } from '@toeverything/components/icons';
|
||||
import {
|
||||
ListItem,
|
||||
|
@ -1,5 +1,4 @@
|
||||
import type {
|
||||
FC,
|
||||
MouseEventHandler,
|
||||
CSSProperties,
|
||||
PropsWithChildren,
|
||||
|
@ -41,7 +41,7 @@ type ListButtonProps = {
|
||||
content?: string;
|
||||
children?: () => JSX.Element;
|
||||
hover?: boolean;
|
||||
icon?: React.FC<SvgIconProps>;
|
||||
icon?: (prop: SvgIconProps) => JSX.Element;
|
||||
};
|
||||
|
||||
export const ListButton = (props: ListButtonProps) => {
|
||||
|
@ -1,4 +1,4 @@
|
||||
import type { FC, ReactNode, CSSProperties } from 'react';
|
||||
import type { ReactNode, CSSProperties } from 'react';
|
||||
import { styled } from '../styled';
|
||||
import { MuiDivider } from '../mui';
|
||||
import type { MuiDividerProps } from '../mui';
|
||||
|
@ -1,4 +1,4 @@
|
||||
import type { FC, PropsWithChildren, CSSProperties } from 'react';
|
||||
import type { PropsWithChildren, CSSProperties } from 'react';
|
||||
import { Clickable } from '../clickable';
|
||||
import { styled } from '../styled';
|
||||
|
||||
|
@ -1,6 +1,6 @@
|
||||
import { useCallback } from 'react';
|
||||
import { styled } from '../styled';
|
||||
import type { FC, CSSProperties, ChangeEvent } from 'react';
|
||||
import type { CSSProperties, ChangeEvent } from 'react';
|
||||
|
||||
/**
|
||||
* WARNING: This component is about to be deprecated, use Select replace
|
||||
|
@ -1,4 +1,3 @@
|
||||
import type { FC } from 'react';
|
||||
import { SliderUnstyled, sliderUnstyledClasses } from '@mui/base';
|
||||
import type { SliderUnstyledProps } from '@mui/base';
|
||||
import { alpha } from '@mui/system';
|
||||
|
@ -1,5 +1,4 @@
|
||||
import type {
|
||||
FC,
|
||||
ChangeEventHandler,
|
||||
PropsWithChildren,
|
||||
CSSProperties,
|
||||
|
@ -1,4 +1,4 @@
|
||||
import type { FC, PropsWithChildren, ReactNode } from 'react';
|
||||
import type { PropsWithChildren, ReactNode } from 'react';
|
||||
// eslint-disable-next-line no-restricted-imports
|
||||
import {
|
||||
createTheme,
|
||||
@ -30,8 +30,8 @@ export const ThemeProvider = ({ children }: { children?: ReactNode }) => {
|
||||
export const useTheme = () => muiUseTheme();
|
||||
|
||||
export const withTheme = <T,>(
|
||||
Component: FC<T & { theme: MuiTheme }>
|
||||
): FC<T> => {
|
||||
Component: (prop: T & { theme: MuiTheme }) => JSX.Element
|
||||
): ((prop: T) => JSX.Element) => {
|
||||
return props => {
|
||||
const theme = useTheme();
|
||||
return <Component {...props} theme={theme} />;
|
||||
|
@ -11,8 +11,8 @@
|
||||
{
|
||||
"id": "wusZ8Qht8rsmFD1s",
|
||||
"name": "No Started",
|
||||
"color": "#05683D",
|
||||
"background": "#C5FBE0",
|
||||
"color": "#AF1212",
|
||||
"background": "#FFCECE",
|
||||
"iconName": "status"
|
||||
},
|
||||
{
|
||||
@ -25,8 +25,8 @@
|
||||
{
|
||||
"id": "u0ZgY0sRCnqMkxzn",
|
||||
"name": "Complete",
|
||||
"color": "#AF1212",
|
||||
"background": "#FFCECE",
|
||||
"color": "#05683D",
|
||||
"background": "#C5FBE0",
|
||||
"iconName": "status"
|
||||
}
|
||||
]
|
||||
|
@ -24,10 +24,7 @@ interface ErrorBoundaryPropsWithComponent {
|
||||
|
||||
declare function FallbackRender(
|
||||
props: FallbackProps
|
||||
): React.ReactElement<
|
||||
unknown,
|
||||
string | React.FunctionComponent | typeof React.Component
|
||||
> | null;
|
||||
): React.ReactElement<unknown, string | typeof React.Component> | null;
|
||||
|
||||
interface ErrorBoundaryPropsWithRender {
|
||||
onResetKeysChange?: (
|
||||
@ -52,7 +49,7 @@ interface ErrorBoundaryPropsWithFallback {
|
||||
resetKeys?: Array<unknown>;
|
||||
fallback: React.ReactElement<
|
||||
unknown,
|
||||
string | React.FunctionComponent | typeof React.Component
|
||||
string | typeof React.Component
|
||||
> | null;
|
||||
FallbackComponent?: never;
|
||||
fallbackRender?: never;
|
||||
|
@ -84,9 +84,8 @@ async function getJSXContent(name, svgCode) {
|
||||
}
|
||||
let matcher = svgrContent.match(/<svg ([^\>]+)>([\s\S]*?)<\/svg>/);
|
||||
return `
|
||||
import { FC } from 'react';
|
||||
import { SvgIcon, SvgIconProps } from '@mui/material';
|
||||
export const ${name}Icon: FC<SvgIconProps> = (props) => (
|
||||
export const ${name}Icon = (props: SvgIconProps) => (
|
||||
<SvgIcon ${matcher[1]}>
|
||||
${matcher[2]}
|
||||
</SvgIcon>
|
||||
|
Loading…
Reference in New Issue
Block a user