From 5ffdd3f32dc500ae7a7b668f747f81de7fb7e050 Mon Sep 17 00:00:00 2001 From: Aakansha Doshi Date: Thu, 25 Mar 2021 21:38:15 +0530 Subject: [PATCH] docs: Readme tweaks :) (#3319) * docs: Readme tweaks :) * update * fix * Add info about collab --- src/packages/excalidraw/README.md | 68 ++++++++++++++++--------------- 1 file changed, 35 insertions(+), 33 deletions(-) diff --git a/src/packages/excalidraw/README.md b/src/packages/excalidraw/README.md index 59c04671..d1220aca 100644 --- a/src/packages/excalidraw/README.md +++ b/src/packages/excalidraw/README.md @@ -1,6 +1,6 @@ ### Excalidraw -Excalidraw exported as a component to directly embed in your projects +Excalidraw exported as a component to directly embed in your projects. ### Installation @@ -28,10 +28,13 @@ If you want to load assets from a different path you can set a variable `window. [Try here](https://codesandbox.io/s/excalidraw-ehlz3). -
-Usage +### Usage -1. If you are using a Web bundler (for instance, Webpack), you can import it as an ES6 module as shown below +#### Using Web Bundler + +If you are using a Web bundler (for instance, Webpack), you can import it as an ES6 module as shown below + +
View Example ```js import React, { useEffect, useState, useRef } from "react"; @@ -168,10 +171,29 @@ To view the full example visit :point_down: [![Edit excalidraw](https://codesandbox.io/static/img/play-codesandbox.svg)](https://codesandbox.io/s/excalidraw-ehlz3?fontsize=14&hidenavigation=1&theme=dark) -2. To use it in a browser directly: +Since Excalidraw doesn't support server side rendering yet so you will have to make sure the component is rendered once host is mounted. + +```js +import { useState, useEffect } from "react"; +export default function IndexPage() { + const [Comp, setComp] = useState(null); + useEffect(() => { + import("@excalidraw/excalidraw").then((comp) => setComp(comp.default)); + }); + return <>{Comp && }; +} +``` + +
+ +#### In Browser + +To use it in a browser directly: You will need to make sure `react`, `react-dom` is available as shown below. +
View Example + ```html @@ -183,7 +205,7 @@ You will need to make sure `react`, `react-dom` is available as shown below. @@ -348,23 +370,9 @@ To view the full example visit :point_down: [![Edit excalidraw-in-browser](https://codesandbox.io/static/img/play-codesandbox.svg)](https://codesandbox.io/s/excalidraw-in-browser-tlqom?fontsize=14&hidenavigation=1&theme=dark) -Since Excalidraw doesn't support server side rendering yet so you will have to make sure the component is rendered once host is mounted. - -```js -import { useState, useEffect } from "react"; -export default function IndexPage() { - const [Comp, setComp] = useState(null); - useEffect(() => { - import("@excalidraw/excalidraw").then((comp) => setComp(comp.default)); - }); - return <>{Comp && }; -} -``` -
-
-Props +### Props | Name | Type | Default | Description | | --- | --- | --- | --- | @@ -547,10 +555,11 @@ This prop controls Excalidraw's theme. When supplied, the value takes precedence This prop sets the name of the drawing which will be used when exporting the drawing. When supplied, the value takes precedence over `intialData.appState.name`, the `name` will be fully controlled by host app and the users won't be able to edit from within Excalidraw. -
+### Does it support collaboration ? -
-Extra API's +No Excalidraw package doesn't come with collaboration, since this would have different implementations on the consumer so we expose the API's which you can use to communicate with Excalidraw as mentioned above. If you are interested in understanding how Excalidraw does it you can check it [here](https://github.com/excalidraw/excalidraw/blob/master/src/excalidraw-app/index.tsx). + +### Extra API's #### `getSceneVersion` @@ -595,8 +604,7 @@ import { getElementsMap } from "@excalidraw/excalidraw"; This function returns an object where each element is mapped to its id. -
-Restore utilities +### Restore utilities #### `restoreAppState` @@ -646,10 +654,7 @@ import { restore } from "@excalidraw/excalidraw"; This function makes sure elements and state is set to appropriate values and set to default value if not present. It is combination of [restoreElements](#restoreElements) and [restoreAppState](#restoreAppState) -
- -
-Export utilities +### Export utilities #### `exportToCanvas` @@ -733,6 +738,3 @@ This function returns a svg with the exported elements. | viewBackgroundColor | string | #fff | The default background color | | shouldAddWatermark | boolean | false | Indicates whether watermark should be exported | | exportWithDarkMode | boolean | false | Indicates whether to export with dark mode | - -
-