Skip to content
Snippets Groups Projects

CubicWebJS

This repository contains several packages to help developers build JavaScript clients for a CubicWeb application using the API cube.

If you want to communicate with the rqlcontroller cube , use cwclientlibjs instead.

Each JavaScript package contains its own readme with information on how to use it and are all built with TypeScript in mind.

Provided packages

This repository contains 5 packages in the /packages folder.

  • client

This is the base library for any JavaScript client interfacing with CubicWeb. It provides an easy way to communicate with all endpoints from the API cube as well as classes to handle the data schema. It is published on npm under the name @cubicweb/client.

  • data-provider

Originally made for react-admin, it provides a set of helpers to get, update and create entities. It generates RQL requests and sends them using the client. It is published on npm under the name @cubicweb/data-provider.

  • react-form-utils

A set of utilities to simplify building forms in React for CubicWeb. It is published on npm under the name @cubicweb/react-form-utils.

  • yup

A form validator built with yup and compatible with the CubicWeb schema. Used in react-form-utils. It is published on npm under the name @cubicweb/yup.

  • demo.

An old demo for the client which has not been updated in a while. Needs either updating or to be removed.

Contribute

Development is done using yarn workspaces. The main repo contains global commands to generate the documentation and lint/test the whole codebase. Please check each package for a list of specific commands.

Releases

Releases are automatically published when a tag on the default branch is detected.

The tag format is: <package-name>@<version-code>

eg: adding the tag data-provider@0.1.0 will publish the package @cubicweb/data-provider version 0.1.0 on npm.

Documentation

Documentation is generated using typedoc and is available online. Please refer to typedoc's documentation to learn how to write docstrings.

New documentation is automatically published when new commits on default are detected.

Get Help

Contact us on Matrix and check the roadmap on the CubicWeb Repository.