Getting Started
The DAOhaus Toolbox is a modular, composable set of libraries that can be integrated into your own projects. It is a collection of tools that can be used to extend the DAOhaus functionality or to integrate DAOhaus functionality into an existing project.
DAOhaus v3 represents a move toward increased decentralization in our infrastructure and tooling. As we identified the core elements in each area of v3's functionality, we began building the libraries and tooling to support it. We then used these libraries and tools in creating our own DAOhaus v3 applications.
When we made the decision for DAOhaus v3 to be much more composable and modular, we also decided that we would open source the tooling that we create in making v3. Every library and utility contained in the DAOhaus Toolbox is used in our own DAOhaus v3 applications. We've made continual refinements and improvements along the way as we discover them in our own use cases.
There is a wide range of possibilities for communities and developers using our tooling. If you're looking to build a tool that extends DAOhaus functionality you can integrate our Utility Libraries. As a developer, you can choose if you want to use our component library and theming or if you'd like to build your own UI and styles and leverage our data libraries to query and interact with a user's DAOs.
We've also open sourced our Feature Libraries which are typically a combination of UI and data elements to create specific functionality such as in DAOhaus Connect.
Features
We're using a monorepo to manage our libraries and apps. Each library can be installed via npm
for use in an external app or tool that you're building.
Our libraries in the libs folder are structured to be consumed by our apps as well as used by external developers using our tooling.
Utility Libraries The Common and Contract libraries provide foundational utility that can be composed and integrated into applications.
Feature Libraries These compose together other libraries such as the DAO Data SDK and the Component Library to create "smart components" that can be integrated into applications.
Each of these libraries can be found in our DAOhaus v3 Monorepo in the /libs
folder and are included in the Toolbox documentation.
DAOhaus v3 Monorepo Overview
Our monorepo follows the recommended Nx structure with apps
and libs
folders. The apps
folder contains our core applications, subgraphs, and infrastructure jobs. If you want to see how we utilize the libraries in the DAOhaus Toolbox in our own v3 app development check out the packages in this folder.
The libs
folder contains the utilities, libraries, and infrastructure resources included in the DAOhaus Toolbox
Lib | Monorepo Location | npm Link |
---|---|---|
ABI Utilities | libs/abi-utilities | @daohaus/abi-utilities |
Contract Utilities | libs/contract-utilties | @daohaus/contract-utilities |
Common Utilities | libs/common-utilities | @daohaus/common-utilities |
DAO Data SDK | libs/dao-data-sdk | @daohaus/dao-data |
Component Library (UI) | libs/ui | @daohaus/ui |
DAOhaus Connect Feature | libs/daohaus-connect-feature | @daohaus/daohaus-connect-feature |
Form Builder Feature | libs/form-builderr | @daohaus/haus-form-builder |
Tx Builder Feature | libs/tx-builder-feature | @daohaus/tx-builder-feature |
Helm Chart Infrastructure Playbook | libs/infra-chart |
These libraries are also published to npm
. Each of the library docs contain links and installation instructions.
Using the Libraries
Our libraries are designed to be modular. Depending on the use case developers can integrate with the DAO data layer, use DAOhaus UI building blocks, or a combination of both.
Here are common pathways to get you started:
Data Only
Our data fetching utilities and functions are separate from our UI and theming libraries. This enables developers to create custom apps with UI separate from DAOhaus's styles and components. This approach can also be used to integrate DAOhaus's data packages into an existing application, such as one that reads a connected user's DAO proposals.
Example Use Case: Developers who want to build an external app with their own UI theming and component styles. This app would utilize our libraries related to data fetching, such as DAO Data SDK, Common Utilities, the upcoming DAO Context, and potentially the ABI Utilities and Contract Utilities.
This approach could be used to create an entire standalone app or integrate DAOhaus data feeds directly into an existing app without having any DAOhaus theming.
UI and Features
Our UI library is an implementation of our DAOhaus design system. It is a collection of opinionated components that are styled to match the DAOhaus theming present in our official apps. This library contains a range of components, including the overall theme (typeface, core design tokens, etc.) as well as specialized components for forms, modals, toasts, and layouts. The UI library is built on top of styled components
and also leverages Radix UI
for certain component primitives.
Example Use Case: Building an extension to DAOhaus that is intended to leverage the DAOhaus branding and component stylings. This could be something that extends DAOhaus such as a Boost or additional functionality. These types of apps may include the data packages as well depending on the intended functionality.
Our Form Builder library utilizes DAOhaus form components as part of the core building blocks. This is a powerful library for rapidly developing forms, but note that they utilize DAOhaus components out of the box.
Full Spectrum
What we've called our feature libraries were designed to be "smart components" that leverage both the UI and data libraries. The data and UI libraries are tightly coupled in these features, and these are designed for developers who want to make an "out of the box" DAOhaus app that leverages the full spectrum of composability that we offer.
An an example, the DAOhaus Connect library includes custom components for connecting a user and displaying basic profile information as well as utilities for handling the chain and other important elements related to wallets. These components leverage both our UI and data packages and are meant to be "batteries included" implementation for external apps.
Example Use Case: Developers who are building an app that extends DAOhaus functionality that integrates the DAOhaus theme.
As folks build on top of our tooling we'll have additional examples!