mirror of
https://github.com/lowdefy/lowdefy.git
synced 2025-01-06 13:15:24 +08:00
commit
4dbd286451
@ -24,28 +24,26 @@ _ref:
|
|||||||
type: MarkdownWithCode
|
type: MarkdownWithCode
|
||||||
properties:
|
properties:
|
||||||
content: |
|
content: |
|
||||||
##### TODO: This page needs to be updated.
|
|
||||||
|
|
||||||
The Lowdefy CLI is used to develop a Lowdefy app locally, and to build Lowdefy apps for deployment.
|
The Lowdefy CLI is used to develop a Lowdefy app locally, and to build Lowdefy apps for deployment.
|
||||||
|
|
||||||
We recommend running the CLI using `npx`, to always use the latest version:
|
We recommend running the CLI using `pnpx`, to always use the latest version:
|
||||||
|
|
||||||
```
|
```
|
||||||
npx lowdefy@latest <command>
|
pnpx lowdefy@4 <command>
|
||||||
```
|
```
|
||||||
|
|
||||||
or, to use a specific version:
|
or, to use a specific version:
|
||||||
|
|
||||||
```
|
```
|
||||||
npx lowdefy@version <command>
|
pnpx lowdefy@version <command>
|
||||||
```
|
```
|
||||||
|
|
||||||
Alternative, you can install the CLI globally or to a npm project (with a `package.json` file) via npm or yarn.
|
Alternative, you can install the CLI globally or to a Javascript project (with a `package.json` file) via pnpm.
|
||||||
|
|
||||||
To install the CLI globally run:
|
To install the CLI globally run:
|
||||||
|
|
||||||
```
|
```
|
||||||
npm install lowdefy -g
|
pnpm add -g lowdefy
|
||||||
```
|
```
|
||||||
|
|
||||||
The CLI can then be run using `lowdefy` as the executable name:
|
The CLI can then be run using `lowdefy` as the executable name:
|
||||||
@ -58,72 +56,80 @@ _ref:
|
|||||||
|
|
||||||
## build
|
## build
|
||||||
|
|
||||||
The `build` command runs a Lowdefy build. The options are:
|
The `build` command runs a Lowdefy build. This builds a production Lowdefy app in the server directory, which can then be started using the `lowdefy start` command. The options are:
|
||||||
|
|
||||||
- `--config-directory <config-directory>`: Change config directory. The default is the current working directory.
|
- `--config-directory <config-directory>`: Change the config directory. The default is the current working directory.
|
||||||
- `--blocks-server-url <blocks-server-url>`: The URL from where Lowdefy blocks will be served. See below for more information.
|
|
||||||
- `--disable-telemetry`: Disable telemetry.
|
- `--disable-telemetry`: Disable telemetry.
|
||||||
- `--output-directory <output-directory>`: Change the directory to which build artifacts are saved. The default is `<config-directory>/.lowdefy/build`.
|
- `--log-level <level>`: The minimum severity of logs to show in the CLI output. Options are `debug`, `info`, `warn` or `error`. The default is `info`.
|
||||||
|
- `--no-next-build`: Do not build the Next.js server, and only build the Lowdefy config. Used in some deployment scripts where the Next.js build is done as a separate step.
|
||||||
- `--ref-resolver <ref-resolver-function-path>`: Path to a JavaScript file containing a `_ref` resolver function to be used as the app default `_ref` resolver.
|
- `--ref-resolver <ref-resolver-function-path>`: Path to a JavaScript file containing a `_ref` resolver function to be used as the app default `_ref` resolver.
|
||||||
|
- `--server-directory <server-directory>`: Change the server directory, the directory in which the production server is placed. The default is `<config-directory>/.lowdefy/server`.
|
||||||
|
|
||||||
## build-netlify
|
|
||||||
The `build-netlify` command creates a production build for the [Netlify](https://www.netlify.com) web hosting service. It is designed to run as the Netlify build command.
|
|
||||||
|
|
||||||
We recommend setting the build command to `npx lowdefy@latest build-netlify`. The Netlify publish directory should be set to `.lowdefy/publish`, and the functions directory set to `.lowdefy/functions`.
|
|
||||||
|
|
||||||
- `--config-directory <config-directory>`: Change config directory. The default is the current working directory (The config directory should rather be configured in the Netlify build settings).
|
|
||||||
- `--blocks-server-url <blocks-server-url>`: The URL from where Lowdefy blocks will be served. See below for more information.
|
|
||||||
- `--disable-telemetry`: Disable telemetry.
|
|
||||||
- `--ref-resolver <ref-resolver-function-path>`: Path to a JavaScript file containing a `_ref` resolver function to be used as the app default `_ref` resolver.
|
|
||||||
|
|
||||||
## clean-cache
|
|
||||||
|
|
||||||
The Lowdefy CLI caches block metadata, and build and server scripts in the `.lowdefy/cache` directory. These cached files can be removed using the `clean-cache` command.
|
|
||||||
|
|
||||||
- `--config-directory <config-directory>`: Change config directory. The default is the current working directory.
|
|
||||||
- `--disable-telemetry`: Disable telemetry.
|
|
||||||
|
|
||||||
## dev
|
## dev
|
||||||
|
|
||||||
The `dev` command starts a Lowdefy development server, running locally. It can be accessed in a browser at [http://localhost:3000](http://localhost:3000). The CLI watches the file system, and rebuilds the app and reloads served pages every time a change is made to any of the files in the project directory.
|
The `dev` command starts a Lowdefy development server, running locally. It can be accessed in a browser at [http://localhost:3000](http://localhost:3000). The CLI watches the file system, and rebuilds the app and reloads served pages every time a change is made to any of the files in the project directory. The `dev` command should not be used to serve a production app, the `build` and `start` commands should be used instead.
|
||||||
|
|
||||||
- `--config-directory <config-directory>`: Change config directory. The default is the current working directory.
|
- `--config-directory <config-directory>`: Change the config directory. The default is the current working directory.
|
||||||
- `--blocks-server-url <blocks-server-url>`: The URL from where Lowdefy blocks will be served. See below for more information.
|
- `--dev-directory <dev-directory>`: Change the dev directory, the directory in which the development server is placed. The default is `<config-directory>/.lowdefy/dev`.
|
||||||
- `--disable-telemetry`: Disable telemetry.
|
- `--disable-telemetry`: Disable telemetry.
|
||||||
|
- `--log-level <level>`: The minimum severity of logs to show in the CLI output. Options are `debug`, `info`, `warn` or `error`. The default is `info`.
|
||||||
|
- `--no-open`: Do not open a new tab in the default browser.
|
||||||
- `--port <port>`: Change the port the server is hosted at. The default is `3000`.
|
- `--port <port>`: Change the port the server is hosted at. The default is `3000`.
|
||||||
- `--ref-resolver <ref-resolver-function-path>`: Path to a JavaScript file containing a `_ref` resolver function to be used as the app default `_ref` resolver.
|
- `--ref-resolver <ref-resolver-function-path>`: Path to a JavaScript file containing a `_ref` resolver function to be used as the app default `_ref` resolver.
|
||||||
- `--watch <paths...>`: A list of paths to files or directories that should be watched for changes.
|
- `--watch <paths...>`: A list of paths to files or directories that should be watched for changes. Globs are supported. Specify each path to watch separated by spaces.
|
||||||
- `--watch-ignore <patterns...>`: A list of paths to files or directories that should be ignored by the file watcher. Globs are supported.
|
- `--watch-ignore <patterns...>`: A list of paths to files or directories that should be ignored by the file watcher. Globs are supported. Specify each path to watch separated by spaces.
|
||||||
|
|
||||||
|
## init
|
||||||
|
|
||||||
|
The `init` command initializes a Lowdefy application. It creates the `lowdefy.yaml` and `.gitignore` in the working directory.
|
||||||
|
|
||||||
|
- `--disable-telemetry`: Disable telemetry.
|
||||||
|
- `--log-level <level>`: The minimum severity of logs to show in the CLI output. Options are `debug`, `info`, `warn` or `error`. The default is `info`.
|
||||||
|
|
||||||
|
## start
|
||||||
|
|
||||||
|
The `start` command starts a Lowdefy production server. To start a Lowdefy server, tha app should first be built using the `build` command.
|
||||||
|
|
||||||
|
- `--config-directory <config-directory>`: Change the config directory. The default is the current working directory.
|
||||||
|
- `--disable-telemetry`: Disable telemetry.
|
||||||
|
- `--log-level <level>`: The minimum severity of logs to show in the CLI output. Options are `debug`, `info`, `warn` or `error`. The default is `info`.
|
||||||
|
- `--port <port>`: Change the port the server is hosted at. The default is `3000`.
|
||||||
|
- `--server-directory <server-directory>`: Change the server directory, the directory in which the production server is placed. The default is `<config-directory>/.lowdefy/server`.
|
||||||
|
|
||||||
|
|
||||||
#### Examples
|
#### Examples
|
||||||
|
|
||||||
|
|
||||||
Run the dev server, watching a relative directory for file changes:
|
Run the dev server, watching a relative directory for file changes:
|
||||||
```txt
|
```txt
|
||||||
npx lowdefy@latest dev --watch ../other-project
|
pnpx lowdefy@4 dev --watch ../other-project
|
||||||
```
|
```
|
||||||
|
|
||||||
Run the dev server, ignoring the public directory:
|
Run the dev server, ignoring the public directory:
|
||||||
```txt
|
```txt
|
||||||
npx lowdefy@latest dev --watch-ignore public/**
|
pnpx lowdefy@4 dev --watch-ignore public/**
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Configuration
|
# Configuration
|
||||||
|
|
||||||
All the CLI options can either be set as command line options, or the `cli` config object in your `lowdefy.yaml` file. Options set as command line options take precedence over options set in the `lowdefy.yaml` file. The config in the `lowdefy.yaml` cannot be referenced using the `_ref` operator, but need to be set in the file itself.
|
All the CLI options can either be set as command line options, or the `cli` config object in your `lowdefy.yaml` file. Options set as command line options take precedence over options set in the `lowdefy.yaml` file. The config in the `lowdefy.yaml` cannot be referenced using the `_ref` operator, but need to be set in the file itself.
|
||||||
|
|
||||||
Options set in the `lowdefy.yaml` should be defined in camelCase. The options that can be set are:
|
Options set in the `lowdefy.yaml` should be defined in camelCase. The options that can be set are:
|
||||||
- `blocksServerUrl: string`: The URL from where Lowdefy blocks will be served. See below for more information.
|
- `devDirectory: string`: Change the dev directory, the directory in which the development server is placed. The default is `<config-directory>/.lowdefy/dev`.
|
||||||
- `disableTelemetry: boolean`: Disable telemetry.
|
- `disableTelemetry: boolean`: Disable telemetry.
|
||||||
- `outputDirectory: string`: Change the directory to which build artifacts are saved. The default is `<config-directory>/.lowdefy/build`.
|
- `logLevel: enum`: The minimum severity of logs to show in the CLI output. Options are `debug`, `info`, `warn` or `error`. The default is `info`.
|
||||||
- `refResolver: string`: Path to a JavaScript file containing a `_ref` resolver function to be used as the app default `_ref` resolver.
|
- `noOpen`: Do not open a new tab in the default browser.
|
||||||
- `port: number`: Change the port the server is hosted at. The default is `3000`.
|
- `port: number`: Change the port the server is hosted at. The default is `3000`.
|
||||||
|
- `refResolver: string`: Path to a JavaScript file containing a `_ref` resolver function to be used as the app default `_ref` resolver.
|
||||||
|
- `serverDirectory: string`: Change the server directory, the directory in which the production server is placed. The default is `<config-directory>/.lowdefy/server`.
|
||||||
- `watch: string[]`: A list of paths to files or directories that should be watched for changes.
|
- `watch: string[]`: A list of paths to files or directories that should be watched for changes.
|
||||||
- `watchIgnore: string[]`: A list of paths to files or directories that should be ignored by the file watcher. Globs are supported.
|
- `watchIgnore: string[]`: A list of paths to files or directories that should be ignored by the file watcher. Globs are supported.
|
||||||
|
|
||||||
The `--config-directory` option cannot be set from the `lowdefy.yaml` file.
|
The `--config-directory` option cannot be set from the `lowdefy.yaml` file.
|
||||||
|
|
||||||
|
|
||||||
# Telemetry
|
# Telemetry
|
||||||
|
|
||||||
The CLI collects usage and error information to help us fix bugs, prioritize features, and understand how Lowdefy is being used.
|
The CLI collects usage and error information to help us fix bugs, prioritize features, and understand how Lowdefy is being used.
|
||||||
@ -144,28 +150,9 @@ _ref:
|
|||||||
- The Lowdefy version of your app.
|
- The Lowdefy version of your app.
|
||||||
- A random local app id (stored locally in your project folder at `.lowdefy/cli.json`).
|
- A random local app id (stored locally in your project folder at `.lowdefy/cli.json`).
|
||||||
- The CLI command used.
|
- The CLI command used.
|
||||||
- If the CLI is being used in the Netlify CI environment (when using the `build-netlify` command).
|
|
||||||
- Your IP address.
|
- Your IP address.
|
||||||
- Error messages and stack traces for any errors.
|
- Error messages and stack traces for any errors.
|
||||||
|
|
||||||
# Blocks Server
|
|
||||||
|
|
||||||
The Lowdefy default blocks are not included in the Lowdefy build output, but are served from a CDN, and imported into the app using webpack module federation. All the default Lowdefy blocks are hosted at:
|
|
||||||
|
|
||||||
```yaml
|
|
||||||
https://blocks-cdn.lowdefy.com/v{LOWDEFY_VERSION}/
|
|
||||||
```
|
|
||||||
|
|
||||||
If you wish to host your own blocks instead, this url can be configured using the `--blocks-server-url` CLI option. This URL should serve the build artifacts of the Lowdefy default block packages (located in the `dist` directory). Each blocks package should be served under a path that corresponds to the package name. For example, `@lowdefy/blocks-basic` should be served under `{BLOCK_SERVER_URL}/blocks-basic/`. The required blocks packages and server paths are:
|
|
||||||
|
|
||||||
- `@lowdefy/blocks-basic` to be hosted at `{BLOCK_SERVER_URL}/blocks-basic/`.
|
|
||||||
- `@lowdefy/blocks-antd` to be hosted at `{BLOCK_SERVER_URL}/blocks-antd/`.
|
|
||||||
- `@lowdefy/blocks-color-selectors` to be hosted at `{BLOCK_SERVER_URL}/blocks-color-selectors/`.
|
|
||||||
- `@lowdefy/blocks-markdown` to be hosted at `{BLOCK_SERVER_URL}/blocks-markdown/`.
|
|
||||||
- `@lowdefy/blocks-echarts` to be hosted at `{BLOCK_SERVER_URL}/blocks-echarts/`.
|
|
||||||
|
|
||||||
If you wish to run the CLI dev server, the `@lowdefy/renderer` package build artifacts (located in the `dist` directory) should also be served from `{BLOCK_SERVER_URL}/renderer/`.
|
|
||||||
|
|
||||||
- _ref:
|
- _ref:
|
||||||
path: templates/navigation_buttons.yaml
|
path: templates/navigation_buttons.yaml
|
||||||
vars:
|
vars:
|
||||||
|
@ -37,7 +37,7 @@ _ref:
|
|||||||
path: templates/cli_command.yaml.njk
|
path: templates/cli_command.yaml.njk
|
||||||
vars:
|
vars:
|
||||||
id: quickstart
|
id: quickstart
|
||||||
command: 'pnpx lowdefy@latest init && npx lowdefy@latest dev'
|
command: 'pnpx lowdefy@4 init && pnpx lowdefy@4 dev'
|
||||||
|
|
||||||
- id: body_features
|
- id: body_features
|
||||||
type: Markdown
|
type: Markdown
|
||||||
|
@ -68,11 +68,6 @@
|
|||||||
pageId: overview
|
pageId: overview
|
||||||
properties:
|
properties:
|
||||||
title: Overview
|
title: Overview
|
||||||
- id: cli
|
|
||||||
type: MenuLink
|
|
||||||
pageId: cli
|
|
||||||
properties:
|
|
||||||
title: The CLI
|
|
||||||
- id: lowdefy-schema
|
- id: lowdefy-schema
|
||||||
type: MenuLink
|
type: MenuLink
|
||||||
pageId: lowdefy-schema
|
pageId: lowdefy-schema
|
||||||
@ -143,6 +138,11 @@
|
|||||||
pageId: custom-styling
|
pageId: custom-styling
|
||||||
properties:
|
properties:
|
||||||
title: Custom Styling
|
title: Custom Styling
|
||||||
|
- id: cli
|
||||||
|
type: MenuLink
|
||||||
|
pageId: cli
|
||||||
|
properties:
|
||||||
|
title: The CLI
|
||||||
- id: deployment
|
- id: deployment
|
||||||
type: MenuGroup
|
type: MenuGroup
|
||||||
properties:
|
properties:
|
||||||
|
@ -9,7 +9,6 @@
|
|||||||
- _ref: tutorial/tutorial-next-steps.yaml
|
- _ref: tutorial/tutorial-next-steps.yaml
|
||||||
|
|
||||||
- _ref: concepts/overview.yaml
|
- _ref: concepts/overview.yaml
|
||||||
- _ref: concepts/cli.yaml
|
|
||||||
- _ref: concepts/lowdefy-schema.yaml
|
- _ref: concepts/lowdefy-schema.yaml
|
||||||
- _ref: concepts/menus.yaml
|
- _ref: concepts/menus.yaml
|
||||||
- _ref: concepts/references-and-templates.yaml
|
- _ref: concepts/references-and-templates.yaml
|
||||||
@ -24,6 +23,7 @@
|
|||||||
- _ref: concepts/hosting-files.yaml
|
- _ref: concepts/hosting-files.yaml
|
||||||
- _ref: concepts/custom-code.yaml
|
- _ref: concepts/custom-code.yaml
|
||||||
- _ref: concepts/custom-styling.yaml
|
- _ref: concepts/custom-styling.yaml
|
||||||
|
- _ref: concepts/cli.yaml
|
||||||
|
|
||||||
- _ref: deployment/docker.yaml
|
- _ref: deployment/docker.yaml
|
||||||
- _ref: deployment/node-server.yaml
|
- _ref: deployment/node-server.yaml
|
||||||
|
@ -79,7 +79,7 @@ _ref:
|
|||||||
path: templates/cli_command.yaml.njk
|
path: templates/cli_command.yaml.njk
|
||||||
vars:
|
vars:
|
||||||
id: init
|
id: init
|
||||||
command: 'pnpx lowdefy@latest init'
|
command: 'pnpx lowdefy@4 init'
|
||||||
|
|
||||||
- id: body_init
|
- id: body_init
|
||||||
type: MarkdownWithCode
|
type: MarkdownWithCode
|
||||||
@ -101,7 +101,7 @@ _ref:
|
|||||||
path: templates/cli_command.yaml.njk
|
path: templates/cli_command.yaml.njk
|
||||||
vars:
|
vars:
|
||||||
id: dev
|
id: dev
|
||||||
command: 'pnpx lowdefy@latest dev'
|
command: 'pnpx lowdefy@4 dev'
|
||||||
|
|
||||||
- id: body_open_browser
|
- id: body_open_browser
|
||||||
type: MarkdownWithCode
|
type: MarkdownWithCode
|
||||||
@ -249,9 +249,9 @@ _ref:
|
|||||||
|
|
||||||
The Lowdefy CLI helps you develop a Lowdefy app.
|
The Lowdefy CLI helps you develop a Lowdefy app.
|
||||||
|
|
||||||
We used the `pnpx lowdefy@latest init` command to initialize a new project. This created all the essential files.
|
We used the `pnpx lowdefy@4 init` command to initialize a new project. This created all the essential files.
|
||||||
|
|
||||||
We also used the `pnpx lowdefy@latest dev` command to start a development server. The development server runs a Lowdefy app locally on your computer, which can be accessed at http://localhost:3000. The development server watches your configuration files, and if any of them changes it "builds" (compiles the configuration together for the server to serve) the configuration again and refreshes the browser to show the changes.
|
We also used the `pnpx lowdefy@4 dev` command to start a development server. The development server runs a Lowdefy app locally on your computer, which can be accessed at http://localhost:3000. The development server watches your configuration files, and if any of them changes it "builds" (compiles the configuration together for the server to serve) the configuration again and refreshes the browser to show the changes.
|
||||||
|
|
||||||
### Up next
|
### Up next
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user