mirror of https://github.com/requarks/wiki
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
151 lines
6.4 KiB
151 lines
6.4 KiB
<div align="center">
|
|
|
|
<picture>
|
|
<source media="(prefers-color-scheme: dark)" srcset="https://static.requarks.io/logo/wikijs-full-darktheme.svg">
|
|
<img alt="Wiki.js" src="https://static.requarks.io/logo/wikijs-full.svg" width="600">
|
|
</picture>
|
|
|
|
[![License](https://img.shields.io/badge/license-AGPLv3-blue.svg?style=flat)](https://github.com/requarks/wiki/blob/master/LICENSE)
|
|
[![Standard - JavaScript Style Guide](https://img.shields.io/badge/code%20style-standard-green.svg?style=flat&logo=javascript&logoColor=white)](http://standardjs.com/)
|
|
[![GitHub Sponsors](https://img.shields.io/github/sponsors/ngpixel?logo=github&color=ea4aaa)](https://github.com/users/NGPixel/sponsorship)
|
|
[![Open Collective backers and sponsors](https://img.shields.io/opencollective/all/wikijs?label=backers&color=218bff&logo=opencollective&logoColor=white)](https://opencollective.com/wikijs)
|
|
[![Chat on Slack](https://img.shields.io/badge/slack-requarks-CC2B5E.svg?style=flat&logo=slack)](https://wiki.requarks.io/slack)
|
|
[![Twitter Follow](https://img.shields.io/badge/follow-%40requarks-blue.svg?style=flat&logo=twitter)](https://twitter.com/requarks)
|
|
[![Reddit](https://img.shields.io/badge/reddit-%2Fr%2Fwikijs-orange?logo=reddit&logoColor=white)](https://www.reddit.com/r/wikijs/)
|
|
[![Subscribe to Newsletter](https://img.shields.io/badge/newsletter-subscribe-yellow.svg?style=flat&logo=mailchimp)](https://blog.js.wiki/subscribe)
|
|
|
|
##### Next Generation Open Source Wiki
|
|
|
|
</div>
|
|
|
|
- **[Official Website](https://next.js.wiki/)**
|
|
- **[Documentation](https://next.js.wiki/docs/)**
|
|
|
|
:red_square: :warning: :warning: :red_square:
|
|
**THIS IS A VERY BUGGY, INCOMPLETE AND NON-SECURE DEVELOPMENT BRANCH!**
|
|
**USE AT YOUR OWN RISK! THERE'S NO UPGRADE PATH FROM THIS BUILD AND NO SUPPORT IS PROVIDED!**
|
|
:red_square: :warning: :warning: :red_square:
|
|
|
|
The current stable release (2.x) is available at https://js.wiki
|
|
|
|
---
|
|
|
|
- [Using VS Code Dev Environment](#using-vs-code-dev-environment) *(recommended)*
|
|
- [Requirements](#requirements-1)
|
|
- [Usage](#usage)
|
|
- [Server Development](#server-development)
|
|
- [Frontend Development (Quasar/Vue 3)](#frontend-development-quasarvue-3)
|
|
- [pgAdmin](#pgadmin)
|
|
- [Generic Setup](#generic-setup)
|
|
- [Requirements](#requirements)
|
|
- [Usage](#usage-1)
|
|
|
|
## Using VS Code Dev Environment
|
|
|
|
### Requirements
|
|
|
|
- [VS Code](https://code.visualstudio.com/)
|
|
- [Docker Desktop](https://www.docker.com/products/docker-desktop/)
|
|
- **Windows-only:** [WSL 2](https://learn.microsoft.com/en-us/windows/wsl/install) + [WSL Integration](https://docs.docker.com/desktop/wsl/) enabled in Docker Desktop
|
|
|
|
### Usage
|
|
|
|
1. Clone the project.
|
|
1. Open the project in VS Code.
|
|
1. Make sure you have **Dev Containers** extension installed. (On Windows, you need the **WSL** VS Code extension as well.)
|
|
1. Reopen the project in container (from the popup in the lower-right corner of the screen when opening the project, or via the Command Palette (Ctrl+Shift+P *or* F1) afterwards).
|
|
1. Once in container mode, make a copy of `config.sample.yml` and rename it to `config.yml`. There's no need to edit the file, the default values are ok.
|
|
1. From the Command Palette, run the task "Create terminals":
|
|
- Launch the Command Palette (Ctrl+Shift+P *or* F1)
|
|
- Type `Run Task` and press <kbd>Enter</kbd>
|
|
- Select the task "Create terminals" and press Enter
|
|
1. Two terminals will launch in split-screen mode at the bottom of the screen. **Server** on the left and **UX** on the right.
|
|
1. In the right-side terminal (UX), run the command:
|
|
```sh
|
|
pnpm build
|
|
```
|
|
1. In the left-side terminal (Server), run the command:
|
|
```sh
|
|
pnpm start
|
|
```
|
|
1. Open your browser to `http://localhost:3000`
|
|
1. Login using the default administrator user:
|
|
- Email: `admin@example.com`
|
|
- Password: `12345678`
|
|
|
|
> **DO NOT** report bugs. This build is **VERY** buggy and **VERY** incomplete. Absolutely **NO** support is provided either.
|
|
|
|
### Server Development
|
|
|
|
From the left-side terminal (Server), run the command:
|
|
|
|
```sh
|
|
pnpm dev
|
|
```
|
|
|
|
This will launch the server and automatically restart upon modification of any server files.
|
|
|
|
Only precompiled client assets are served in this mode. See the sections below on how to modify the frontend and run in SPA (Single Page Application) mode.
|
|
|
|
### Frontend Development
|
|
|
|
> Make sure you are running `npm run dev` in the left-side terminal (Server) first! Requests still need to be forwarded to the server, even in SPA mode!
|
|
|
|
If you wish to modify any frontend content (under `/ux`), you need to start the Quasar Dev Server in the right-side terminal (UX):
|
|
|
|
```sh
|
|
pnpm dev
|
|
```
|
|
|
|
You can then access the site at `http://localhost:3001`. Notice the port being `3001` rather than `3000`. The app runs in a SPA (single-page application) mode and automatically hot-reload any modified component. Any requests made to the `/graphql` endpoint are automatically forwarded to the server running on port `3000`, which is why both must be running at the same time.
|
|
|
|
Any change you make to the frontend will not be reflected on port 3000 until you run the command `yarn build` in the right-side terminal.
|
|
|
|
### pgAdmin
|
|
|
|
A web version of pgAdmin (a PostgreSQL administration tool) is available at `http://localhost:8000`. Use the login `dev@js.wiki` / `123123` to login.
|
|
|
|
The server **dev** should already be available under **Servers**. If that's not the case, add a new one with the following settings:
|
|
|
|
- Hostname: `db`
|
|
- Port: `5432`
|
|
- Username: `postgres`
|
|
- Password: `postgres`
|
|
- Database: `postgres`
|
|
|
|
## Generic Setup
|
|
|
|
### Requirements
|
|
|
|
- PostgreSQL **12** or later *(**16** or later recommended)*
|
|
- Node.js **20.x** or later
|
|
- [pnpm](https://pnpm.io/installation#using-corepack)
|
|
|
|
### Usage
|
|
|
|
1. Clone the project
|
|
1. Make a copy of `config.sample.yml` and rename it to `config.yml`
|
|
1. Edit `config.yml` and fill in the database details. **You need an empty PostgreSQL database.**
|
|
1. Run the following commands to install dependencies and generate the client assets:
|
|
```sh
|
|
cd server
|
|
pnpm install
|
|
cd ../ux
|
|
pnpm install
|
|
pnpm build
|
|
cd ../blocks
|
|
pnpm install
|
|
pnpm build
|
|
cd ..
|
|
```
|
|
1. Run this command to start the server:
|
|
```sh
|
|
node server
|
|
```
|
|
1. In your browser, navigate to `http://localhost:3000` *(or the IP/hostname of the server and the PORT you defined earlier.)*
|
|
1. Login using the default administrator user:
|
|
- Email: `admin@example.com`
|
|
- Password: `12345678`
|
|
|
|
> **DO NOT** report bugs. This build is **VERY** buggy and **VERY** incomplete. Absolutely **NO** support is provided either.
|