data:image/s3,"s3://crabby-images/8cb46/8cb46df524baf004b8733bb894c9307bf1a8b90b" alt=""
Build React reusable components with Aspect
Build React reusable components with Aspect êŽë š
data:image/s3,"s3://crabby-images/9b8f7/9b8f75d5910fb0812cbb6621e4b0e228a9d2b546" alt=""
Aspect is a new development tool that allows you to create React components virtually in your browser. It eliminates the stress of creating and setting up a React project for applications.
data:image/s3,"s3://crabby-images/8cb46/8cb46df524baf004b8733bb894c9307bf1a8b90b" alt="Colorful Aspect Symbols"
Aspect saves on development time by providing a dashboard with HTML drag-and-drop functionality that greatly simplifies the process of creating React components. Aspect also syncs your designs to your codebase and provides an option to export them as a zip file.
Lots of additional, cool features are promised in a future version (aspectdotapp
), like support for libraries such as MaterialUI and Tailwind CSS, as well as Sketch and AdobeXD.
In this tutorial, weâll demonstrate how to use Aspect to build a reusable component faster. Weâll build the simple product page shown below:
data:image/s3,"s3://crabby-images/9def5/9def551cf10ce42308a89fe2a1967cde5f0a8447" alt="Simple Product Page"
Getting started
To get started with Aspect, sign up here.
Then, install the Aspect CLI globally using the following command:
yarn add @metacode-inc/aspect -g
npm i @metacode-inc/aspect -g
Once youâre signed up, Aspect will create a new project with an empty view to get you started.
Project UI overview
Before we go any further, letâs take a quick look at the Aspect projectâs UI to become more familiar with how to navigate and use the tool.
data:image/s3,"s3://crabby-images/9ecc8/9ecc8f0f8bbaa1bb41a2bbc42ac582fe7913488a" alt="Aspect Project UI"
Hereâs a summary of the different sections of Aspectâs user interface:
- Project: View a list of your projectâs details, such as the product ID; you can also generate, view, and sync your codebase using your projectâs API key from here
- VIEWS: Create different views for your projects; double-click on a view to change its default name
- PROPERTIES: Define the custom properties of your project
- STATES: Create custom states and set conditions for the elements in your project
- ELEMENTS: Manage the elements in your project and define their hierarchy
- CSS: Define your projectâs styling; use the quick layout to organize your elements; the CSS section is visible when the ELEMENTS section is expanded
- + INSERT: Add a filter and add elements to your projects
Now that we have more familiarity with Aspectâs features, letâs work on building our product page.
Creating a view
We already have a view created by Aspect. To create a new view, click on the + symbol on the VIEWS tab. Then, double click on View2 and rename it âProductâ.
data:image/s3,"s3://crabby-images/467ee/467eef3d524b7721378b2c49227e84a48175c887" alt="Product Name"
Adding elements
Now, letâs add some elements to the view.
Creating the parent layout
Weâll start by adding a parent div
by clicking on + INSERT and selecting div from the dropdown. When you hover on the view, you should see a + symbol appear. This indicates that an element has been selected. Right click on the element and drag it to enlarge the element to the desired size.
data:image/s3,"s3://crabby-images/0cc91/0cc916e8983fd2c301ddb3b4ab17b6182522473b" alt="Large Layout"
Creating the navbar
Now that we have a parent layout, letâs add another div
for the navbar. Repeat the same steps you followed to add the parent div
. Then, go to the CSS tab and set the width to 100% and the min-height to 63.
data:image/s3,"s3://crabby-images/4fa83/4fa835cedd2263309772fe61705e7e654d64ca41" alt="CSS Tab"
The resulting layout should look like this:
data:image/s3,"s3://crabby-images/b34e9/b34e99de3bf91e422da97fb7b5f47804a8f35cb4" alt="Layout With Header"
Next, letâs use a ul
element to add some navbar lists to the project. Click on INSERT, select ul, and add it to the parent div
, div-0, by dropping it on it.
Now, add three li
list item elements in the ul
element. In the li
elements, add p
elements and âHomeâ, âAboutâ, and âProductsâ to the text property in the PROPERTIES tab.
Add the text to the p
elements, then click on the first layout in the CSS > QUICK LAYOUT tab to add styling. Select the first layout to display the contents inline.
data:image/s3,"s3://crabby-images/dd129/dd1293931e1191b1193d109fdaf0fda1856dd1c1" alt="Home About Products"
To remove the bullet symbols, change the list-style property in the ul
element to none. Add a black background by specifying background-color of #42a7f5 for the div-0.
Next, align the elements and change the font to white by adding a margin-right of 7px and a color of #fff to each li
element.
data:image/s3,"s3://crabby-images/a4155/a4155d4d1046eaa442731ec6381ccdd07b67ed1d" alt="Home About Products Blue Header"
Creating products
Now, letâs make a layout for the products. Weâll use a p
element for the product description. Then, weâll create a child layout for the products.
Insert a div
, and inside of that insert another div
and a p
inside div-1. Now, change the text property of p-2 to âProductsâ.
To style the child layout, click on div-1 and go to the CSS > QUICK LAYOUT tab. Select the second layout, and change the width property of div-2 to 100%. Your project should look like this:
data:image/s3,"s3://crabby-images/270c5/270c531f3a4952d1a611e2883a1974e0d8c339f8" alt="Products Line"
Next, insert another div
inside div-2 to hold the product details. Inside the div-3 insert two p
, one img
, and one button
. Change the text property of the p-3 element to âTechno m16â, and change the text property of the p-4 element to Price: $200. Next, add a p
to the button and set the text property to âAdd to cartâ.
Now, change the font-size properties of all the p
elements in div-3 to 12px and set the align properties to center.
Set the imageâs src property to https://tslnigeria.tv/wp-content/uploads/2021/05/mobile-phone.jpg
.
Next, click on div-3, and press Ctrl + D to duplicate the div and create div-4. Go ahead and change the text and the src properties of each element in div-4.
Now, click on div-2, go to CSS > QUICK LAYOUT, and select the first layout.
You should have output similar to this:
data:image/s3,"s3://crabby-images/318bb/318bb62267d7ed058d65701e684182742cae1e0c" alt="Products on Page"
Exporting components
Weâve finished creating our component UI using the Aspect UI builder, Now, letâs fetch the design and sync it with our codebase using the following command:
aspect fetch --project <projectId> \
--out <outputDirectory> \
--key <apiKey>
You can get the project ID and API key by clicking on the project name in the Project dropdown.
data:image/s3,"s3://crabby-images/6ff78/6ff789fc06b40c1f941d593e8e5fe9471166066b" alt="Project ID and API Key"
N.B.
the <apiKey>
is not generated by default, youâll need to click on the* Generate new API key button
After the design is successfully fetched and synced, you should see the following output:
data:image/s3,"s3://crabby-images/c3002/c30025ef3595bda7d6ec84ad38cf5090aba5a675" alt="Successfully Fetched Project"
Aspect will generate a component.tsx
and components.css
file. Now, you can import and use the view in your projects.
Conclusion
In this tutorial, we demonstrated how to use Aspect to reduce the development time associated with creating reusable React components.
Feel free to follow the steps outlined in this tutorial to add more features to the application.
data:image/s3,"s3://crabby-images/2e458/2e458bbc056facc22e4d495e120236062f517045" alt=""