Web Application Development Tutorial (with ABP Suite) - Part 5: Customizing the Generated Code

So far, you have created the all functionality for the bookstore application without needing to write any single line of code. In this part, let's write some code and check one of the great features of the ABP Suite, which is Customizable Code Support.

Customizable Code Support

ABP Suite allows you to customize the generated code blocks and preserve your custom code changes in the next CRUD Page Generation. It specifies hook points to allow adding custom code blocks. Then, the code written by you to these hook points will be respected and will not be overridden in the next CRUD Page Generation.

To enable custom code support, you should check the Customizable code option in the CRUD Page Generation page (it's selected by default), and you enabled it for both entities:

Custom Code Hookpoints

When you enable the custom code support, ABP Suite adds some hookpoints that you can write your own custom code without worrying about, are my codes being overridden with the next CRUD page generation.

On the C# side, ABP Suite adds abstract base classes for entities, application services, interfaces, domain services and so on... (and partial classes for interfaces)

You can write your custom code in those classes (with the *.Extended.cs extension) and next time when you need to re-generate the entity, your custom code will not be overridden (only the base abstract classes will be re-generated and your changes on Suite will be respected):

For example, you can create a new repository method like in the example above, and in the next CRUD page generation, you will ABP Suite won't override your custom code.

On the UI side, ABP Suite provides convenient comment placeholders within pages for MVC, Blazor, and Angular UIs. These comment sections serve as hook points where you can add your custom code.

For example, if you open the Books/Index.cshtml file in your IDE, you will see those placeholders like following:

<!-- Code omitted for brevity -->

@section styles
{
@*//<suite-custom-code-block-1>*@
@*//</suite-custom-code-block-1>*@
}

<!-- ... -->

You can write your custom codes between the placeholders and you can also extend these placeholders by customizing the ABP Suite templates.

For more information, please refer to Customizing the Generated Code documentation

Implementing Custom Code

Let's see the custom code support in action. We can demonstrate this feature with an easy example.

Assume that we want to show the author's name with his abbreviated name. For example, for the author John Ronald Reuel Tolkien, we want to show the name John Ronald Reuel Tolkien (a.k.a J.R.R.T). Achieving that is pretty straightforward.

We just need to open the src/Acme.BookStore.Application/Books/BooksAppService.Extended.cs file and override the base GetListAsync method, which is called on the books page:

using System;
using System.Linq;
using System.Collections.Generic;
using System.Threading.Tasks;
using Volo.Abp.Application.Dtos;
using Volo.Abp.Domain.Repositories;
using Volo.Abp.Caching;

namespace Acme.BookStore.Books
{
    public class BooksAppService : BooksAppServiceBase, IBooksAppService
    {
        //<suite-custom-code-autogenerated>
        public BooksAppService(IBookRepository bookRepository, BookManager bookManager, IDistributedCache<BookDownloadTokenCacheItem, string> downloadTokenCache, IRepository<Acme.BookStore.Authors.Author, Guid> authorRepository)
            : base(bookRepository, bookManager, downloadTokenCache, authorRepository)
        {
        }
        //</suite-custom-code-autogenerated>

        //Write your custom code...
        public override async Task<PagedResultDto<BookWithNavigationPropertiesDto>> GetListAsync(GetBooksInput input)
        {
            var result = await base.GetListAsync(input);

            foreach (var book in result.Items)
            {
                var akaName = book.Author.Name.Split(" ").Select(q => q[0]).JoinAsString(".");
                book.Author.Name += $" (a.k.a {akaName})";
            }
            
            return result;
        }
    }
}
  • Here, we have overridden the GetListAsync method and changed its result according to our need.
  • Notice, this class is derieved from the BooksAppServiceBase class and implements the IBooksAppService.
  • Thus, ABP Suite only modifies the BooksAppServiceBase class and implements the necessary services in each generation, but does not generate the files with the *.Extended postfixes and let you implement your own custom code.
  • You can create new methods, override an existing method and change its behaviour, add custom hookpoints to extend customization capabilities and more...

Now, we can open ABP Suite and try to regenerate the book entity and see if our custom code is gone or not:

After the regeneration has been completed, we can check the BooksAppService.Extended.cs file and we should see our custom code is there without any modification. ABP Suite didn't override our custom code, and finally, we can run the application to see the final result:

ABP Suite's custom code support is not limited to the backend side. You can also override the UI. You can refer to the Customizing the Generated Code document for further info.

Summary

In this tutorial, you created the bookstore application without needing to write a single line of code with ABP Suite. Then, in this last part, you have written custom code in the specified hookpoints and it did not override by ABP Suite.


Contributors


Last updated: December 17, 2024 Edit this page on GitHub

Was this page helpful?

Please make a selection.

To help us improve, please share your reason for the negative feedback in the field below.

Please enter a note.

Thank you for your valuable feedback!

Please note that although we cannot respond to feedback, our team will use your comments to improve the experience.

In this document
Community Talks

Layered vs Modular vs Microservices... Which one is best for you?

09 Jan, 17:00
Online
Register Now
Mastering ABP Framework Book
Mastering ABP Framework

This book will help you gain a complete understanding of the framework and modern web application development techniques.

Learn More