mirror of
https://github.com/nocobase/nocobase
synced 2024-11-15 11:36:42 +00:00
.github/workflows | ||
docker | ||
docs | ||
packages | ||
storage | ||
.editorconfig | ||
.env.example | ||
.eslintignore | ||
.eslintrc | ||
.gitignore | ||
.prettierignore | ||
.prettierrc | ||
.umirc.ts | ||
commitlint.config.js | ||
docker-compose.yml | ||
jest.cli.js | ||
jest.config.js | ||
jest.setup.ts | ||
lerna.json | ||
LICENSE | ||
package.json | ||
publish.js | ||
README.md | ||
README.zh-CN.md | ||
tsconfig.build.json | ||
tsconfig.jest.json | ||
tsconfig.json | ||
yarn.lock |
English | 中文
What is NocoBase
NocoBase is a scalability-first, open-source no-code development platform. No programming required, build your own collaboration platform, management system with NocoBase in minutes.
Homepage: https://www.nocobase.com/
Online Demo: https://demo.nocobase.com/new
Contact Us: hello@nocobase.com
Why choose NocoBase
- Open source and free
- Unrestricted commercial use under the Apache-2.0 license
- Full code ownership, private deployment, private and secure data
- Free to expand and develop for actual needs
- Good ecological support
- Strong no-code capability
- Data Model
- Create independent data models using dozens of field types such as text, date, number, attachment, option, icon, etc., and various association relationships such as one-to-one, one-to-many, many-to-many, etc.
- Block
- Display and manipulate data within a page using a free combination of block types such as tables, forms, kanban, calendars, details, etc.
- ACL
- Role-based control of user's system configuration rights, data action rights and menu access rights.
- Workflow
- Repetitive tasks are replaced by automation to increase efficiency. Manual approval is required for important matters.
- Menu
- You can group menus, support adding pages and links, and support unlimited submenus.
- Action
- Support filtering, exporting, adding, deleting, modifying, viewing and other operations to process data, which can be extended to more types.
- Data Model
- Built for extended development
- Microkernel architecture, flexible and easy to extend, with a robust plug-in system
- Node.js-based, with popular frameworks and technologies, including Koa, Sequelize, React, Formily, Ant Design, etc.
- Progressive development, easy for getting-started, friendly to newcomers
- No binding, no strong dependencies, can be used in any combination or extensions, can be used in existing projects
Architecture
Requirements
Node:
- Node.js 14+
Database:(choose one)
- PostgreSQL 10.x+
- MySQL 8.x+
- SQLite 3+
Installation
Create a project with Docker (👍Recommended)
⚡⚡ Please make sure you have installed Docker
1. Download NocoBase
Download with Git (or Download Zip,and extract it to the nocobase
directory)
git clone https://github.com/nocobase/nocobase.git nocobase
2. Select database (choose one)
Supports SQLite, MySQL, PostgreSQL
# SQLite
cd nocobase/docker/app-sqlite
# MySQL
cd nocobase/docker/app-mysql
# PostgreSQL
cd nocobase/docker/app-postgres
3. Install and start NocoBase
It may take dozens of seconds
# run in the background
$ docker-compose up -d
# view app logs
$ docker-compose logs app
app-sqlite-app-1 | nginx started
app-sqlite-app-1 | yarn run v1.22.15
app-sqlite-app-1 | $ cross-env DOTENV_CONFIG_PATH=.env node -r dotenv/config packages/app/server/lib/index.js install -s
app-sqlite-app-1 | Done in 2.72s.
app-sqlite-app-1 | yarn run v1.22.15
app-sqlite-app-1 | $ pm2-runtime start --node-args="-r dotenv/config" packages/app/server/lib/index.js -- start
app-sqlite-app-1 | 2022-04-28T15:45:38: PM2 log: Launching in no daemon mode
app-sqlite-app-1 | 2022-04-28T15:45:38: PM2 log: App [index:0] starting in -fork mode-
app-sqlite-app-1 | 2022-04-28T15:45:38: PM2 log: App [index:0] online
app-sqlite-app-1 | 🚀 NocoBase server running at: http://localhost:13000/
4. Log in to NocoBase
Open http://localhost:13000 in a web browser. The initial account and password are admin@nocobase.com
and admin123
.
Create a project with create-nocobase-app
# 1. create project
# SQLite
yarn create nocobase-app my-nocobase-app -d sqlite
# MySQL
yarn create nocobase-app my-nocobase-app -d mysql \
-e DB_HOST=mysql \
-e DB_PORT=3356 \
-e DB_DATABASE=nocobase \
-e DB_USER=nocobase \
-e DB_PASSWORD=nocobase
# PostgreSQL
yarn create nocobase-app my-nocobase-app -d postgres \
-e DB_HOST=postgres \
-e DB_PORT=5432 \
-e DB_DATABASE=postgres \
-e DB_USER=postgres \
-e DB_PASSWORD=postgres
# 2. switch to the project directory
cd my-nocobase-app
# 3. Install dependencies
yarn install
# 4. Install NocoBase
yarn nocobase install --lang=en-US
# 5. start project
yarn start
Open http://localhost:8000 in a web browser. The initial account and password are admin@nocobase.com
and admin123
.
Contributing
- Fork the source code to your own repository
- Modify source code
- Submit pull request
# Replace the following git address with your own repo
git clone https://github.com/nocobase/nocobase.git
cd nocobase
cp .env.example .env
yarn install
yarn nocobase install
yarn start
Building
# For all packages
yarn build
# For specific package
yarn build --scope @nocobase/database
Testing
# For all packages
yarn test
# For specific package
yarn test packages/<name>