Skip to content

Latest commit

 

History

History
152 lines (116 loc) · 5.76 KB

README.md

File metadata and controls

152 lines (116 loc) · 5.76 KB

carefree-board

The carefree-board project, or cfb for short, is a lightweight, modular, and easy-to-use board library.

board can be thought of 'drawboard' / 'canvas' / '2D graphics world' / ..., depending on what you want to build with it (e.g., a drawing app, an infinite canvas, a 2D game, ...).

Getting Started

carefree-board needs deno 2.x to run. After you have installed deno, a web-native demo can be launched by:

deno task run:web

This will start the demo at http://localhost:1245, and you can play with the cfb. Currently this demo only supports:

  1. Display some contents on the screen, namely:
    1. Two squares.
    2. A 'Hello, World!' text.
  2. Respond to pointer events - you can drag the contents around!
  3. Undo / Redo the dragging actions by clicking the corresponding 'buttons'.

This demo can run on both desktop and mobile browsers, but there are some additional features that are only available on desktop browsers:

  1. Undo / Redo by pressing the Ctrl + z / Ctrl + Shift + z keys.
  2. Zoom in / out by rolling the mouse wheel while pressing the Ctrl / Meta key.
  3. Move the board globally by:
    1. pressing the Space key and dragging the mouse.
    2. rolling the mouse wheel to move up / down.
    3. rolling the mouse wheel while pressing the Shift key to move left / right.

You can also visit here, which is hosted by deno deploy, to play around with the demo.

Notice that I put single quotes to 'buttons' - this is because they are not real buttons, but just rectangle nodes that can respond to pointer events.

Project Status

carefree-board is still in its VERY EARLY stage, and mainly serves as a POC. The final goal is to define a set of abstract interfaces that can be extended to everything related to 2D graphics.

Project Hierachy

All submodules are structured under a deno workspace, and their functionalities are as follows:

  • cfb-core: implements the core components of cfb.
  • cfb-svg: implements svg exporters for cfb.
  • cfb-web: a web-native renderer for cfb that transpiles the data structures into dom elements.

Hybrid monorepo in deno

It REALLY took me couple of days to figure out how to manage a hybrid deno monorepo. Let me define it - a hybrid deno monorepo is a monorepo that:

  • All members are deno first modules.
  • Some members are browser specific modules, and need to have a runnable frontend demo.

The second part is where nightmare begins. I struggled quite a bit to figure out how to correctly do the linkings / bundlings / servings. Finally I made it to what I think simple and elegant, and I'd like to share some experience here:

Hint: after all these setups, everything is TIDY and BLAZINGLY FAST compared to the traditional webpack / rollup / tsconfig / package.json / ... mess, which makes me feel all the efforts are worth it!

  1. Export everything in main.ts (to distinguish from mod.ts that can be used in both node and browser environments) (exmaple).
  2. Write startup codes in public/index.ts, which may import the workspace members and setup the application (example).
  3. Use esbuild in a deno script to bundle index.ts (not main.ts!) into a single js file. It's common practice here to watch for changes (example).
  4. Write an index.html that includes the bundled js file. If the startup codes need to refer to some concrete dom elements, make sure to include the <script> tag after the elements are defined (example).
  5. Use Deno.serve to serve the index.html (example).
  6. Happy coding!

One implicit step is that we need to create an imports.json explicitly. This step is to make dnt / esbuild / deno publish happy, and I think it can (and maybe should) be skipped once the deno ecosystem becomes more mature.

Development

Some common deno tasks for development:

  • deno task check: will run bunch of checks asynchronously, including fmt, lint, test, dry publish, etc.
  • deno task bump: bump the patch version in each deno.json file no matter what.

Some common deno tasks for CI:

  • deno task build: build into npm packages with dnt.
  • deno task publish:npm: publish the npm packages.

There are several module-specific tasks as well:

  • deno task {cmd}:web: tasks specific to cfb-web, see cfb-web section below for more details.

A common .vscode/settings.json for this project is as follows:

{
  "deno.enable": true,
  "deno.lint": true,
  "typescript.preferences.preferTypeOnlyAutoImports": true,
  "[json]": {
    "editor.defaultFormatter": "denoland.vscode-deno"
  },
  "[markdown]": {
    "editor.defaultFormatter": "denoland.vscode-deno"
  },
  "[typescript]": {
    "editor.defaultFormatter": "denoland.vscode-deno"
  }
}

I did not use

{
  "...": "...",
  "editor.defaultFormatter": "denoland.vscode-deno"
}

directly because I found its priority is not high enough in my case.

cfb-web

A common setup for developing cfb-web is as follows:

  1. Open two terminals.
  2. In the first terminal, run deno task dev:web, this should be able to watch ALL changes in the workspace.
  3. In the second terminal, run deno task start:web, this should start a local server at http://localhost:1245 and you can test the changes in the browser. Notice that there are no hot-reload, so you need to refresh the page manually when changes are made.