Skip to content
This repository has been archived by the owner on Jul 20, 2022. It is now read-only.

Latest commit

 

History

History
52 lines (41 loc) · 2.98 KB

README.md

File metadata and controls

52 lines (41 loc) · 2.98 KB

Ree.js

Make Sites Faster, without the need of building anything!

A framework boasting no-build-required features, that can be used to create websites faster, without the need of building anything. Brings support for URL Imports and Import Maps to Nodejs! Includes its own very dedicated package manager. Feel free to report any bugs at the issues section or introduce new ideas in discussions!

Check up the discussions over our Discord Server and let us know any suggestions if you have any!

Install with: Windows 10/11:

Invoke-RestMethod https://raw.githubusercontent.com/rovelstars/reejs/main/install.js | node

Linux/Mac:

curl -s https://raw.githubusercontent.com/rovelstars/reejs/main/install.js | node

Isn't this awesome? Its definitely better than npm install!

Note: We have reejs link command that can be used to link all the libraries that have been installed in the project with reejs install to the node_modules folder. This is useful if you want to use any dependency with nodejs' ESM syntax, since alternatives to them were:

  • Custom Module Loader (Its currently experimental by nodejs v18)
  • Import Maps (Deno has it, Nodejs doesn't; GG! sarcastically of course)
  • Module Alias npm package (Not really supported with ESM syntax, bye bye hacking require module loaders)

You can generate import maps with reejs map

Any library that's linked via above command will be installed into @reejs directory of node_modules, so you can import with @reejs/<library> syntax. Don't worry! Both @reejs & reejs scope/package has been locked to prevent any conflicts with other libraries! (Including hackers from introducing other packages with the same name!) Packages can be unscoped if their config file has scope: libraryName. This will link them to libraryName.

What's up with .rekt file?

These are module configs that are used to download the required files, and respectively generate and link to import maps and node modules respectively. If you know yaml, you know rekt. However it's a smaller and trimmed down version of the yaml spec, that not fully supports the spec, most of them being all those multiline values. Example of a rekt file:

url: https://cdn.jsdelivr.net/npm/[email protected]/twind.js
version: 0.16.17
type: module
more: ["https://cdn.jsdelivr.net/npm/[email protected]/shim/shim.js" | "https://cdn.jsdelivr.net/npm/[email protected]/observe/observe.js"]
more_as: [ "shim/shim.js" | "observe/observe.js"]
# double quotes are allowed in rekt files, as well as unquoted values. Double quotes are useful if you want strings that start or end with spaces, that otherwise would have been trimmed away by our parser.
more_alias: [ "shim/shim.js" | "observe"]
# more alias is for import mapping purposes, more_as is for node module linking.