Quick Start
This is a single-part quick-start tutorial to build a simple todo application with the ABP Framework. Here's a screenshot from the final application:
You can find the source code of the completed application here.
We are currently preparing a video tutorial for Blazor UI. You can watch other tutorials for the three UI types from here.
Pre-Requirements
- An IDE (e.g. Visual Studio) that supports .NET 8.0+ development.
- Node v16.x
Creating a New Solution
In this tutorial, we will use the ABP CLI to create the sample application with the ABP Framework. You can run the following command in a command-line terminal to install the ABP CLI, if you haven't installed it yet:
Then create an empty folder, open a command-line terminal and execute the following command in the terminal:
This will create a new solution with three projects:
- A
blazor
application that contains the Blazor code, the client-side. - A
host
application, hosts and serves theblazor
application. - A
contracts
project, shared library between these two projects.
Once the solution is ready, open it in your favorite IDE.
Create the Database
You can run the following command in the directory of your TodoApp.Host
project to create the database and seed the initial data:
This command will create the database and seed the initial data for you. Then you can run the application.
Before Running the Application
Installing the Client-Side Packages
ABP CLI runs the abp install-libs
command behind the scenes to install the required NPM packages for your solution while creating the application.
However, sometimes this command might need to be manually run. For example, you need to run this command, if you have cloned the application, or the resources from node_modules folder didn't copy to wwwroot/libs folder, or if you have added a new client-side package dependency to your solution.
For such cases, run the abp install-libs
command on the root directory of your solution to install all required NPM packages:
We suggest you install Yarn to prevent possible package inconsistencies, if you haven't installed it yet.
Bundling and Minification
abp bundle
command offers bundling and minification support for client-side resources (JavaScript and CSS files) for Blazor projects. This command automatically run when you create a new solution with the ABP CLI.
However, sometimes you might need to run this command manually. To update script & style references without worrying about dependencies, ordering, etc. in a project, you can run this command in the directory of your blazor application:
For more details about managing style and script references in Blazor or MAUI Blazor apps, see Managing Global Scripts & Styles.
Run the Application
It is good to run the application before starting the development. Running the application is pretty straight-forward, you just need to run the TodoApp.Host
application with any IDE that supports .NET or by running the dotnet run
CLI command in the directory of your project.
Note: The
host
application hosts and serves theblazor
application. Therefore, you should run thehost
application only.
After the application runs, open the application in your default browser:
You can click on the Login button and use admin
as the username and 1q2w3E*
as the password to login to the application.
All right. We can start coding!
Defining the Entity
This application will have a single entity and we can start by creating it. So, create a new TodoItem
class under the Entities
folder of the TodoApp.Host
project:
BasicAggregateRoot
is the simplest base class to create root entities, and Guid
is the primary key (Id
) of the entity here.
Database Integration
Next step is to setup the Entity Framework Core configuration.
Mapping Configuration
Open the TodoAppDbContext
class (in the Data
folder) and add a new DbSet
property to this class:
Then navigate to the OnModelCreating
method in the same class and add the following mapping code for the TodoItem
entity:
We've mapped the TodoItem
entity to the TodoItems
table in the database. The next step is to create a migration and apply the changes to the database.
Code First Migrations
The startup solution is configured to use Entity Framework Core Code First Migrations. Since we've changed the database mapping configuration, we should create a new migration and apply changes to the database.
Open a command-line terminal in the directory of your TodoApp.Host
project and type the following command:
This will add a new migration class to the project. You should see the new migration in the Migrations
folder:
Then, you can apply changes to the database using the following command, in the same command-line terminal:
After the database integrations, now we can start to create application service methods and implement our use-cases.
Creating the Application Service
An application service is used to perform the use cases of the application. We need to perform the following use cases in this application:
- Get the list of the todo items
- Create a new todo item
- Delete an existing todo item
Before starting to implement these use cases, first we need to create a DTO class that will be used in the application service.
Creating the Data Transfer Object (DTO)
Application services typically get and return DTOs (Data Transfer Objects) instead of entities. So, create a new TodoItemDto
class under the Services/Dtos
folder of your TodoApp.Contracts
project:
This is a very simple DTO class that has the same properties as the TodoItem
entity. Now, we are ready to implement our use-cases.
The Application Service Interface
Create a ITodoAppService
interface under the Services
folder of the TodoApp.Contracts
project, as shown below:
The Application Service Implementation
Create a TodoAppService
class under the Services
folder of your TodoApp.Host
project, as shown below:
This class inherits from the TodoAppAppService
, which inherits from the ApplicationService
class of the ABP Framework and implements our use-cases. ABP provides default generic repositories for the entities. We can use them to perform the fundamental database operations. This class injects IRepository<TodoItem, Guid>
, which is the default repository for the TodoItem
entity. We will use it to implement our use cases.
Getting the Todo Items
Let's start by implementing the GetListAsync
method, which is used to get a list of todo items:
We are simply getting the TodoItem
list from the repository, mapping them to the TodoItemDto
objects and returning as the result.
Creating a New Todo Item
The next method is CreateAsync
and we can implement it as shown below:
The repository's InsertAsync
method inserts the given TodoItem
to the database and returns the same TodoItem
object. It also sets the Id
, so we can use it on the returning object. We are simply returning a TodoItemDto
by creating from the new TodoItem
entity.
Deleting a Todo Item
Finally, we can implement the DeleteAsync
as the following code block:
The application service is ready to be used from the UI layer. So, let's implement it.
User Interface
It is time to show the todo items on the UI! Before starting to write the code, it would be good to remember what we are trying to build. Here's a sample screenshot from the final UI:
Index.razor.cs
Open the Index.razor.cs
file in the Pages
folder in your Todo.Blazor
project and replace the content with the following code block:
This class uses the ITodoAppService
to get the list of todo items. It manipulates the TodoItems
list after create and delete operations. This way, we don't need to refresh the whole todo list from the server.
Index.razor
Open the Index.razor
file in the Pages
folder and replace the content with the following code block:
Index.razor.css
As the final touch, open the Index.razor.css
file in the Pages
folder and replace it with the following content:
This is a simple styling for the todo page. We believe that you can do much better :)
Now, you can run the TodoApp.Host
project again to see the result.
Conclusion
In this tutorial, we've built a very simple application to warm up with the ABP Framework.
Source Code
You can find the source code of the completed application here.
See Also
- Check the Web Application Development Tutorial to see a real-life web application development in a layered architecture using the Application Startup Template.