From 4428963ca4e5c48708ba003a23dff50aafd2e31a Mon Sep 17 00:00:00 2001 From: Amirhossein Alibakhshi Date: Thu, 22 Aug 2024 13:28:56 +0330 Subject: [PATCH 1/2] fix: update rollup config --- package.json | 14 +++++++++--- rollup.config.mjs | 2 +- src/DaftarNaghashi.stories.tsx | 6 ++--- src/DaftarNaghashi.tsx | 42 +++++++++++++++++----------------- src/types.ts | 2 +- tsconfig.json | 3 ++- 6 files changed, 39 insertions(+), 30 deletions(-) diff --git a/package.json b/package.json index 6fbb5f9..42362d1 100644 --- a/package.json +++ b/package.json @@ -1,9 +1,17 @@ { "name": "daftar-naghashi", + "author": { + "name": "Amirhossein Alibakhshi", + "email": "amirhosseinalibakhshi@gmail.com" + }, + "keywords": ["paint", "react", "draw"], "version": "0.0.0", "type": "module", "scripts": { - "build": "rollup -c", + "build": "pnpm clean && pnpm build:types && pnpm build:rollup", + "clean": "rm -rf dist", + "build:types": "tsc --declaration true --emitDeclarationOnly true --outDir dist --noEmit false", + "build:rollup": "rollup -c", "lint": "eslint .", "format": "pnpm exec prettier . --write", "storybook": "storybook dev -p 6006", @@ -55,10 +63,10 @@ "plugin:storybook/recommended" ] }, - "main": "dist/cjs/index.js", - "module": "dist/esm/index.js", "files": [ "dist" ], + "main": "dist/cjs/index.js", + "module": "dist/esm/index.js", "types": "dist/index.d.ts" } diff --git a/rollup.config.mjs b/rollup.config.mjs index be4c7fd..9f0645d 100644 --- a/rollup.config.mjs +++ b/rollup.config.mjs @@ -25,7 +25,7 @@ export default [ ], }, { - input: "dist/esm/types/index.d.ts", + input: "dist/index.d.ts", output: [{ file: "dist/index.d.ts", format: "esm" }], plugins: [dts()], }, diff --git a/src/DaftarNaghashi.stories.tsx b/src/DaftarNaghashi.stories.tsx index 4e69bb9..ac675be 100644 --- a/src/DaftarNaghashi.stories.tsx +++ b/src/DaftarNaghashi.stories.tsx @@ -22,16 +22,16 @@ Simple.args = { onStopDrawing: () => console.log("onStopDrawing"), }; -export const readonly: Story = {}; +export const viewMode: Story = {}; -readonly.args = { +viewMode.args = { onDrawing: () => console.log("onDrawing"), onStartDrawing: (c) => { console.log("onStartDrawing"); console.log(c?.toDataURL()); console.log("-----"); }, - readonly: true, + viewMode: true, onStopDrawing: () => console.log("onStopDrawing"), value: '' }; diff --git a/src/DaftarNaghashi.tsx b/src/DaftarNaghashi.tsx index 3f9fe98..e887bea 100644 --- a/src/DaftarNaghashi.tsx +++ b/src/DaftarNaghashi.tsx @@ -7,7 +7,7 @@ import {useHotkeys} from "react-hotkeys-hook"; type Props = { height?: number; width?: number; - readonly: boolean; + viewMode?: boolean; onStartDrawing?: (c: HTMLCanvasElement | null) => void; onDrawing?: (c: HTMLCanvasElement | null) => void; onStopDrawing?: (c: HTMLCanvasElement | null) => void; @@ -23,13 +23,13 @@ const renderDefaultToolbar = ({ undo, clear, setMode, - readonly, + viewMode, }: ToolbarProps) => (
@@ -67,7 +67,7 @@ const DrawingComponent = ({ onStopDrawing, height = 500, width = 500, - readonly = false, + viewMode = false, renderToolbar = renderDefaultToolbar, value, }: Props) => { @@ -121,7 +121,7 @@ const DrawingComponent = ({ }, [color, thickness]); const startDrawing = (e: MouseEvent) => { - if (!ctxRef.current || readonly) return; + if (!ctxRef.current || viewMode) return; const { offsetX, offsetY } = e.nativeEvent; ctxRef.current.beginPath(); ctxRef.current.moveTo(offsetX, offsetY); @@ -130,7 +130,7 @@ const DrawingComponent = ({ }; const draw = (e: MouseEvent) => { - if (!isDrawing || !ctxRef.current || readonly) return; + if (!isDrawing || !ctxRef.current || viewMode) return; const { offsetX, offsetY } = e.nativeEvent; ctxRef.current.lineTo(offsetX, offsetY); @@ -139,7 +139,7 @@ const DrawingComponent = ({ }; const stopDrawing = () => { - if (readonly) return; + if (viewMode) return; if (isDrawing) { ctxRef.current?.closePath(); dispatch({ type: "STOP_DRAWING" }); @@ -149,7 +149,7 @@ const DrawingComponent = ({ }; const saveHistory = () => { - if (readonly) return; + if (viewMode) return; if (canvasRef.current) { dispatch({ type: "SAVE_HISTORY", @@ -160,7 +160,7 @@ const DrawingComponent = ({ const undo = () => { - if (readonly) return; + if (viewMode) return; dispatch({ type: "UNDO" }); if (ctxRef.current && canvasRef.current && history.length > 1) { const previousState = history[history.length - 2]; @@ -180,7 +180,7 @@ const DrawingComponent = ({ useHotkeys('u', undo) const clear = () => { - if (readonly) return; + if (viewMode) return; if (ctxRef.current && canvasRef.current) { ctxRef.current.clearRect( 0, @@ -194,7 +194,7 @@ const DrawingComponent = ({ useHotkeys('c', clear) const setMode = (m: Mode) => { - if (readonly) return; + if (viewMode) return; dispatch({ type: "SET_MODE", payload: m, @@ -205,7 +205,7 @@ const DrawingComponent = ({ useHotkeys('f', () => setMode('fill')) const handleCanvasClick = (e: MouseEvent) => { - if (readonly) return; + if (viewMode) return; if (mode === "fill" && canvasRef.current && ctxRef.current) { const { offsetX, offsetY } = e.nativeEvent; const imageData = ctxRef.current.getImageData( @@ -222,7 +222,7 @@ const DrawingComponent = ({ }; const setLineWidth = (value: number) => { - if (readonly) return; + if (viewMode) return; dispatch({ type: "SET_THICKNESS", payload: value, @@ -230,7 +230,7 @@ const DrawingComponent = ({ }; const setColor = (value: string) => { - if (readonly) return; + if (viewMode) return; dispatch({ type: "SET_COLOR", payload: value, @@ -239,9 +239,9 @@ const DrawingComponent = ({ return (
- {!readonly && + {!viewMode && renderToolbar({ - readonly, + viewMode, setLineWidth, thickness: thickness, setColor, diff --git a/src/types.ts b/src/types.ts index 4dddfc3..fc99164 100644 --- a/src/types.ts +++ b/src/types.ts @@ -3,7 +3,7 @@ export type RGBA = [number, number, number, number]; export type Mode = "pen" | "fill"; export type ToolbarProps = { - readonly: boolean; + viewMode: boolean; setLineWidth: (width: number) => void; thickness: number; setColor: (color: string) => void; diff --git a/tsconfig.json b/tsconfig.json index dcc44d3..d027e1f 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -21,5 +21,6 @@ "noFallthroughCasesInSwitch": true, "outDir": "dist" }, - "include": ["src"] + "include": ["src"], + "exclude": ["**/*.stories.tsx"] } From 8408ca1b6e8535172a28d67368c59ca17dccdb18 Mon Sep 17 00:00:00 2001 From: Amirhossein Alibakhshi Date: Thu, 22 Aug 2024 13:33:06 +0330 Subject: [PATCH 2/2] fix: update ignore files --- .eslintignore | 2 ++ .github/workflows/deploy.yml | 2 +- .prettierignore | 1 + package.json | 10 +++++++--- src/DaftarNaghashi.stories.tsx | 3 ++- src/DaftarNaghashi.tsx | 29 ++++++++++++++++++----------- 6 files changed, 31 insertions(+), 16 deletions(-) create mode 100644 .eslintignore diff --git a/.eslintignore b/.eslintignore new file mode 100644 index 0000000..61ad769 --- /dev/null +++ b/.eslintignore @@ -0,0 +1,2 @@ +pnpm-lock.yaml +dist \ No newline at end of file diff --git a/.github/workflows/deploy.yml b/.github/workflows/deploy.yml index d256f7d..d1ac95a 100644 --- a/.github/workflows/deploy.yml +++ b/.github/workflows/deploy.yml @@ -47,7 +47,7 @@ jobs: - name: Install Dependencies run: pnpm install - name: Build Storybook - run: pnpm build-storybook + run: pnpm build:storybook - name: Upload artifact uses: actions/upload-pages-artifact@v3 with: diff --git a/.prettierignore b/.prettierignore index 1b8ac88..673a867 100644 --- a/.prettierignore +++ b/.prettierignore @@ -1,3 +1,4 @@ # Ignore artifacts: build coverage +pnpm-lock.yaml diff --git a/package.json b/package.json index 42362d1..5db9739 100644 --- a/package.json +++ b/package.json @@ -4,7 +4,11 @@ "name": "Amirhossein Alibakhshi", "email": "amirhosseinalibakhshi@gmail.com" }, - "keywords": ["paint", "react", "draw"], + "keywords": [ + "paint", + "react", + "draw" + ], "version": "0.0.0", "type": "module", "scripts": { @@ -12,10 +16,10 @@ "clean": "rm -rf dist", "build:types": "tsc --declaration true --emitDeclarationOnly true --outDir dist --noEmit false", "build:rollup": "rollup -c", + "build:storybook": "storybook build", "lint": "eslint .", "format": "pnpm exec prettier . --write", - "storybook": "storybook dev -p 6006", - "build-storybook": "storybook build" + "storybook": "storybook dev -p 6006" }, "dependencies": { "react": "^18.3.1", diff --git a/src/DaftarNaghashi.stories.tsx b/src/DaftarNaghashi.stories.tsx index ac675be..c629e0e 100644 --- a/src/DaftarNaghashi.stories.tsx +++ b/src/DaftarNaghashi.stories.tsx @@ -33,7 +33,8 @@ viewMode.args = { }, viewMode: true, onStopDrawing: () => console.log("onStopDrawing"), - value: '' + value: + "", }; export const CustomToolbar: Story = {}; diff --git a/src/DaftarNaghashi.tsx b/src/DaftarNaghashi.tsx index e887bea..2f71732 100644 --- a/src/DaftarNaghashi.tsx +++ b/src/DaftarNaghashi.tsx @@ -1,8 +1,8 @@ import React, { MouseEvent, useEffect, useReducer, useRef } from "react"; -import {floodFill, getPixelColor, hexToRgba} from "./utils.ts"; +import { floodFill, getPixelColor, hexToRgba } from "./utils.ts"; import { Mode, ToolbarProps } from "./types.ts"; import drawingReducer from "./reducer.ts"; -import {useHotkeys} from "react-hotkeys-hook"; +import { useHotkeys } from "react-hotkeys-hook"; type Props = { height?: number; @@ -52,10 +52,18 @@ const renderDefaultToolbar = ({ - -
@@ -69,7 +77,7 @@ const DrawingComponent = ({ width = 500, viewMode = false, renderToolbar = renderDefaultToolbar, - value, + value, }: Props) => { const canvasRef = useRef(null); const ctxRef = useRef(null); @@ -158,7 +166,6 @@ const DrawingComponent = ({ } }; - const undo = () => { if (viewMode) return; dispatch({ type: "UNDO" }); @@ -177,7 +184,7 @@ const DrawingComponent = ({ }; } }; - useHotkeys('u', undo) + useHotkeys("u", undo); const clear = () => { if (viewMode) return; @@ -191,7 +198,7 @@ const DrawingComponent = ({ dispatch({ type: "CLEAR_CANVAS" }); } }; - useHotkeys('c', clear) + useHotkeys("c", clear); const setMode = (m: Mode) => { if (viewMode) return; @@ -200,9 +207,9 @@ const DrawingComponent = ({ payload: m, }); }; - useHotkeys('b', () => setMode('pen')) - useHotkeys('p', () => setMode('pen')) - useHotkeys('f', () => setMode('fill')) + useHotkeys("b", () => setMode("pen")); + useHotkeys("p", () => setMode("pen")); + useHotkeys("f", () => setMode("fill")); const handleCanvasClick = (e: MouseEvent) => { if (viewMode) return;