Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Lexical Editor Fixes #3229

Merged
merged 63 commits into from
Apr 22, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
63 commits
Select commit Hold shift + click to select a range
59e5ea9
feat: add color action to heading and paragraph toolbar
Mar 1, 2023
6f2ab41
wip: add color picker element to toolbar color action
Mar 1, 2023
ba156f5
wip: implement lexical configuration interface for font color action
Mar 1, 2023
bec6be2
refactor: prettier fix
Mar 1, 2023
dd86ba1
wip: brainstorming from the 1:1
Pavel910 Mar 2, 2023
1680458
wip: add font color acton context
Mar 2, 2023
f419315
wip: implmenting theme into lexical font color action node
Mar 7, 2023
4f29319
wip: get lexical conetnt text and lexical color node update
Mar 9, 2023
01d08a6
wip: updated node with factory class
Mar 10, 2023
c2d8ac2
wip: text theme color updates on change
Mar 13, 2023
efc6f24
wip: lexical html renderer support text theme change
Mar 13, 2023
93992a6
wip: update style and format from range selection to new font color node
Mar 13, 2023
7e7776f
wip: color picker dropdown supports selection of color without closin…
Mar 13, 2023
d0612ef
wip: add lexical editor config package with configuration plugin
Mar 13, 2023
8e9b51c
wip: package updates
Mar 14, 2023
a302c5f
wip: resolve circular deps
Pavel910 Mar 14, 2023
2af283c
refactor: remove dependency of the circular dependency on app-page-bu…
Mar 14, 2023
38ce5cd
refactor: rename to lexical editor action to match the component name
Mar 14, 2023
5b0004c
wip: inital implementation of the typography action
Mar 14, 2023
1ddeda3
wip: change typography text node with element node, support heading p…
Mar 15, 2023
296f333
wip: new css object to string converter
Mar 15, 2023
4485da0
refactor: use import instead of required for importing reactToCSS method
Mar 16, 2023
1654a7c
Merge branch 'next' into feat/lexical-editor-typography
Mar 16, 2023
58f9184
feat: changes in theme typography structure and typography selection …
Mar 17, 2023
4a9341d
wip: implement custom webiny list component that accept typography style
Mar 22, 2023
fe391f3
wip: typography styles listed by component
Mar 22, 2023
5b38485
wip: different styles for the list now can be applied from the menu
Mar 23, 2023
ed3063a
wip: list component finished
Mar 23, 2023
47a44c5
wip: implemented custom webiny quote component
Mar 23, 2023
094c4ce
wip: quote component and redo/undo actions
Mar 25, 2023
47dfaa9
wip: updated selection for actions with new toolbar state context
Mar 28, 2023
fde8eec
wip: inital heading component on drag and drop fixed
Mar 28, 2023
753fcd5
wip: create querable style classes in progress
Mar 29, 2023
d7c1773
wip: implemnted emotion into lexical editor
Mar 30, 2023
d0a6fa3
wip: remove debugger
Mar 30, 2023
f1a3ded
wip: merge, createTheme and migration to typograpy prop in theme
Mar 30, 2023
54dcba1
wip: eslint changes
Mar 30, 2023
dfd625f
feat: migrated all styles in the solution to the new theme typography…
Apr 3, 2023
1c6155a
fix: check if typograpy style is undefined in byId function in theme …
Apr 3, 2023
c27e47f
wip: merge from next, update styles expressions and theme in progress...
Apr 17, 2023
830169b
wip: updated DecoratedTheme with new implementation and updates style…
Apr 18, 2023
abcbe1b
refactor: typograophy style css prop renamed to styles and cssById re…
Apr 19, 2023
c802fb2
refactor: update typography dropdown in lexical and befor form render…
Apr 19, 2023
e8913d3
fix: readonly errors in typography object caused by as const
Apr 19, 2023
15989ff
refactor: comments and types from PR review #1
Apr 20, 2023
2eea805
refactor: element text heading comment, cwp theme object corrected
Apr 20, 2023
201ae29
refactor: renamed labale from decoratedTheme to Theme
Apr 20, 2023
84af5b9
refactor: theme is alias for decorated theme, theme imported in solut…
Apr 20, 2023
94e06b1
refactor: remove export from decorated theme interface
Apr 21, 2023
652d6b1
refactor: removed all coments from lexical toolbar actions
Apr 21, 2023
4dc39a9
Merge remote-tracking branch 'origin/next' into feat/theme-typography…
adrians5j Apr 21, 2023
b97329b
fix: ensure correct `styleId` and `name` is passed
adrians5j Apr 21, 2023
3b0fb67
fix: use `TypographyElementNode` instead of `ParagraphNode`
adrians5j Apr 21, 2023
646a2f8
Merge remote-tracking branch 'origin/next' into 535-lexical-fixes
adrians5j Apr 21, 2023
946b04d
fix: remove unused import
adrians5j Apr 21, 2023
7f7cd46
fix: use the correct external link icon
adrians5j Apr 21, 2023
9db588d
fix: make the whole link clickable and show cursor pointer on hover
adrians5j Apr 21, 2023
1e837e5
fix: set `list1` to `list`
adrians5j Apr 21, 2023
90fcfc3
fix: set `list 1` to `List 1`
adrians5j Apr 21, 2023
9d3fd7c
fix: remove `DecoratedTheme` and export `Theme` directly
adrians5j Apr 21, 2023
63eb72a
fix: access `typography["paragraphs"]` instead of `typography.paragra…
adrians5j Apr 21, 2023
ab10167
Merge remote-tracking branch 'origin/next' into 535-lexical-fixes
adrians5j Apr 21, 2023
36efed4
chore: run prettier
adrians5j Apr 21, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
wip: resolve circular deps
  • Loading branch information
Pavel910 committed Mar 14, 2023
commit a302c5fd54de23eddd055fe69faa0fb6fdf7586c
2 changes: 1 addition & 1 deletion packages/app-page-builder-elements/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
"@babel/runtime": "^7.19.0",
"@emotion/core": "^10.0.17",
"@emotion/styled": "^10.0.17",
"@webiny/lexical-editor": "0.0.0",
"@webiny/theme": "0.0.0"
},
"peerDependencies": {
Expand Down Expand Up @@ -54,7 +55,6 @@
"@types/react": "17.0.39",
"@types/resize-observer-browser": "^0.1.4",
"@webiny/cli": "0.0.0",
"@webiny/lexical-editor": "0.0.0",
"@webiny/project-utils": "0.0.0",
"babel-plugin-lodash": "^3.3.4",
"execa": "^5.0.0",
Expand Down
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
# @webiny/lexical-editor-config
[![](https://img.shields.io/npm/dw/@webiny/app-page-builder.svg)](https://www.npmjs.com/package/@webiny/lexical-editor)
[![](https://img.shields.io/npm/v/@webiny/app-page-builder.svg)](https://www.npmjs.com/package/@webiny/lexical-editor)
# @webiny/lexical-editor-actions
[![](https://img.shields.io/npm/dw/@webiny/lexical-editor-actions.svg)](https://www.npmjs.com/package/@webiny/lexical-editor)
[![](https://img.shields.io/npm/v/@webiny/lexical-editor-actions.svg)](https://www.npmjs.com/package/@webiny/lexical-editor)
[![code style: prettier](https://img.shields.io/badge/code_style-prettier-ff69b4.svg?style=flat-square)](https://github.com/prettier/prettier)
[![PRs Welcome](https://img.shields.io/badge/PRs-welcome-brightgreen.svg?style=flat-square)](http://makeapullrequest.com)


## About

This package provides a configuration plugins for lexical editor.
This package provides actions plugins for Lexical editor.


## Where is it used?
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
{
"name": "@webiny/lexical-editor-config",
"name": "@webiny/lexical-editor-actions",
"version": "0.0.0",
"dependencies": {
"@emotion/styled": "^10.0.27",
Expand Down
1 change: 0 additions & 1 deletion packages/lexical-editor/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,6 @@
"@lexical/rich-text": "0.8.1",
"@lexical/selection": "0.8.1",
"@lexical/utils": "0.8.1",
"@webiny/app-page-builder-elements": "0.0.0",
"@webiny/react-composition": "0.0.0",
"lexical": "0.8.1",
"react": "^17.0.2",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,6 @@ import { isValidLexicalData } from "~/utils/isValidLexicalData";
import { LexicalUpdateStatePlugin } from "~/plugins/LexicalUpdateStatePlugin";
import { BlurEventPlugin } from "~/plugins/BlurEventPlugin/BlurEventPlugin";
import { FontColorPlugin } from "~/plugins/FontColorPlugin/FontColorPlugin";
import { usePageElements } from "@webiny/app-page-builder-elements";
import { webinyEditorTheme } from "~/themes/webinyLexicalTheme";
import { WebinyNodes } from "~/nodes/webinyNodes";

Expand Down Expand Up @@ -52,7 +51,9 @@ const BaseRichTextEditor: React.FC<RichTextEditorProps> = ({
}: RichTextEditorProps) => {
const placeholderElem = <Placeholder>{placeholder || "Enter text..."}</Placeholder>;
const scrollRef = useRef(null);
const { theme } = usePageElements();
// const { theme } = usePageElements();
const theme = { styles: {}};

const [floatingAnchorElem, setFloatingAnchorElem] = useState<HTMLElement | undefined>(
undefined
);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,17 +8,17 @@ import { ContentEditable } from "@lexical/react/LexicalContentEditable";
import LexicalErrorBoundary from "@lexical/react/LexicalErrorBoundary";
import { LexicalUpdateStatePlugin } from "~/plugins/LexicalUpdateStatePlugin";
import { Klass, LexicalNode } from "lexical";
import { usePageElements } from "@webiny/app-page-builder-elements";
import { WebinyNodes } from "~/nodes/webinyNodes";
import { webinyLexicalTheme } from "~/themes/webinyLexicalTheme";
import { webinyEditorTheme } from "~/themes/webinyLexicalTheme";

interface LexicalHtmlRendererProps {
nodes?: Klass<LexicalNode>[];
value: LexicalValue | null;
}

export const LexicalHtmlRenderer: React.FC<LexicalHtmlRendererProps> = ({ nodes, value }) => {
const { theme } = usePageElements();
// const { theme } = usePageElements();
const theme = { styles: {}};
const initialConfig = {
editorState: isValidLexicalData(value) ? value : generateInitialLexicalValue(),
namespace: "webiny",
Expand All @@ -27,7 +27,7 @@ export const LexicalHtmlRenderer: React.FC<LexicalHtmlRendererProps> = ({ nodes,
},
editable: false,
nodes: [...WebinyNodes, ...(nodes || [])],
theme: { ...webinyLexicalTheme, styles: theme.styles }
theme: { ...webinyEditorTheme, styles: theme.styles }
};

return (
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ import { $getSelection, $isRangeSelection, LexicalCommand } from "lexical";
import { Compose, makeComposable } from "@webiny/react-composition";
import { FontColorActionContext } from "~/context/FontColorActionContext";
import { $isFontColorNode, ADD_FONT_COLOR_COMMAND, FontColorPayload } from "~/nodes/FontColorNode";
import { usePageElements } from "@webiny/app-page-builder-elements";
import { getSelectedNode } from "~/utils/getSelectedNode";

/*
Expand Down Expand Up @@ -33,7 +32,8 @@ export interface FontColorAction extends React.FC<unknown> {
export const FontColorAction: FontColorAction = () => {
const [editor] = useLexicalComposerContext();
const [fontColor, setFontColor] = useState<string>("#000");
const { theme } = usePageElements();
// const { theme } = usePageElements();
const theme = { styles: {}} as any;

const isThemeColorName = (color: string): boolean => {
return !!theme?.styles?.colors[color];
Expand Down
3 changes: 1 addition & 2 deletions packages/lexical-editor/src/themes/webinyLexicalTheme.ts
Original file line number Diff line number Diff line change
@@ -1,10 +1,9 @@
import type { EditorThemeClasses } from "lexical";

import "./webinyLexicalTheme.css";
import { ThemeStyles } from "@webiny/app-page-builder-elements/types";

export type WebinyTheme = {
styles?: ThemeStyles;
styles?: Record<string, any>;
};

export type WebinyEditorTheme = WebinyTheme & EditorThemeClasses;
Expand Down
1 change: 0 additions & 1 deletion packages/lexical-editor/tsconfig.build.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@
"extends": "../../tsconfig.build.json",
"include": ["src"],
"references": [
{ "path": "../app-page-builder-elements/tsconfig.build.json" },
{ "path": "../react-composition/tsconfig.build.json" }
],
"compilerOptions": {
Expand Down
4 changes: 1 addition & 3 deletions packages/lexical-editor/tsconfig.json
Original file line number Diff line number Diff line change
@@ -1,16 +1,14 @@
{
"extends": "../../tsconfig.json",
"include": ["src", "__tests__/**/*.ts"],
"references": [{ "path": "../app-page-builder-elements" }, { "path": "../react-composition" }],
"references": [{ "path": "../react-composition" }],
"compilerOptions": {
"rootDirs": ["./src", "./__tests__"],
"outDir": "./dist",
"declarationDir": "./dist",
"paths": {
"~/*": ["./src/*"],
"~tests/*": ["./__tests__/*"],
"@webiny/app-page-builder-elements/*": ["../app-page-builder-elements/src/*"],
"@webiny/app-page-builder-elements": ["../app-page-builder-elements/src"],
"@webiny/react-composition/*": ["../react-composition/src/*"],
"@webiny/react-composition": ["../react-composition/src"]
},
Expand Down
1 change: 0 additions & 1 deletion yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -15189,7 +15189,6 @@ __metadata:
"@lexical/rich-text": 0.8.1
"@lexical/selection": 0.8.1
"@lexical/utils": 0.8.1
"@webiny/app-page-builder-elements": 0.0.0
"@webiny/cli": ^5.33.1
"@webiny/project-utils": ^5.33.1
"@webiny/react-composition": 0.0.0
Expand Down