Using Umi UI
Umi UI is a visual extension of Umi to interact with the project. You can run commands to install dependencies, verify and test code, build the project, and add components through a graphical user interface.
Before using Umi UI, we need to add the @umijs/preset-ui
package. You can do that by running the following command:
$ yarn add @umijs/preset-ui -D
Now, when you start the project, you should see the following console log:
data:image/s3,"s3://crabby-images/4c9df/4c9dfdc77d58f14b938d2631a9e5ca5022e354f0" alt="Figure 1.7 – Umi UI starting log"
Figure 1.7 – Umi UI starting log
Navigate to http://localhost:8000
, and you will notice that the UmiJS logo appears in a bubble in the bottom-right corner. Clicking on this bubble will open Umi UI (you can also access Umi UI at http://localhost:3000
).
data:image/s3,"s3://crabby-images/34f5a/34f5a2c912b5f9e7364429bc4f375b3b6365e399" alt="Figure 1.8 – Umi UI bubble in the bottom-right corner"
Figure 1.8 – Umi UI bubble in the bottom-right corner
Let's see what we can do using Umi UI, beginning with tasks:
- BUILD: This option will create the application bundle in the
dist
folder. You can also click on ENVS to select compilation options, such as CSS compression. - LINT: This option will execute linters in your project. You need to configure the
lint
script to use this option. - TEST: This option will test the project. You need to write tests first.
- INSTALL: This option will install all project dependencies.
The following screenshot shows the Umi UI Task tab:
data:image/s3,"s3://crabby-images/f42d8/f42d8b093487cdafabef7ec486fe20943dd818fd" alt="Figure 1.9 – Umi UI Task tab"
Figure 1.9 – Umi UI Task tab
Next, let's add Ant Design components to our project.
Adding Ant Design components
Ant Design is a design system created by Ant Financial's user experience design team to meet the high demands of enterprise application development and fast changes in these applications. They also created a React UI library of components for building interfaces.
In the Assets tab, we can add Ant Design components to our pages as blocks:
data:image/s3,"s3://crabby-images/8e6ce/8e6ceaa25127c0ef6d808a452a7a114aeaecf89a" alt="Figure 1.10 – Umi UI Preview Demo button"
Figure 1.10 – Umi UI Preview Demo button
Tip
The Umi UI Assets tab is almost entirely in Chinese at the moment. Still, you can always refer to the Ant Design documentation by clicking on Preview Demo and changing the website language to English.
Let's add a login form to experiment with this feature:
- Navigate to
http://localhost:8000
and open the Umi UI Assets tab. - Click on Add in the form-login box component.
data:image/s3,"s3://crabby-images/8d111/8d111c66fd6be8fec7828eca5536b977dcff7e0f" alt="Figure 1.11 – form-login box component Add button"
Figure 1.11 – form-login box component Add button
- Select the second area by clicking on + Add to here.
data:image/s3,"s3://crabby-images/e0a83/e0a83fb18f63a8fe263d2f03854995830aeb8758" alt="Figure 1.12 – Selecting where to add the component"
Figure 1.12 – Selecting where to add the component
- Now, in the Variable Name field, type
LoginForm
, make sure the package manager client selected is yarn, and click on OK.
data:image/s3,"s3://crabby-images/0caa5/0caa5b83efc33c6b002a3dc2ef8754d5f3d8a062" alt="Figure 1.13 – Add Block options"
Figure 1.13 – Add Block options
Wait until the block is added and we are done. Umi UI will reload the page, and the component is already there!
If you want, you can add some styles to the login page, as follows:
- Add this code to the Login page's
index.less
file:.container { display: flex; flex-direction: column; align-items: center; }
- Add the
container
CSS class to the login component:import React from 'react'; import styles from './index.less'; import LoginForm from './LoginForm'; export default function Page() { return ( <div className={styles.container}> <h1 className={styles.title}> Welcome! Access your account.</h1> <LoginForm /> </div> ); }
The result should look like this:
data:image/s3,"s3://crabby-images/c81cf/c81cfbdf5d5a625adbe9bbc7762888d9eae078e1" alt="Figure 1.14 – Login page with login form block"
Figure 1.14 – Login page with login form block
And that's it! Now you know how to use Umi UI to interact with your project. If you like this option, I recommend experimenting with it by adding more components and styling them to get you used to it.