From 79e57e86d53df6a67c76f36cd1b9925aeb96ef4f Mon Sep 17 00:00:00 2001 From: Engincan VESKE Date: Mon, 16 May 2022 15:17:20 +0300 Subject: [PATCH] Update the Application-Single-Layer.md --- .../Application-Single-Layer.md | 53 ++++++++++-------- .../single-layer-angular-folder-structure.png | Bin 0 -> 16705 bytes 2 files changed, 30 insertions(+), 23 deletions(-) create mode 100644 docs/en/images/single-layer-angular-folder-structure.png diff --git a/docs/en/Startup-Templates/Application-Single-Layer.md b/docs/en/Startup-Templates/Application-Single-Layer.md index 651988dcac..245ef435c1 100644 --- a/docs/en/Startup-Templates/Application-Single-Layer.md +++ b/docs/en/Startup-Templates/Application-Single-Layer.md @@ -2,23 +2,21 @@ ## Introduction -This template provides a single-layered application for quick start with ABP Framework. +This template provides a single-layered application for a quick start with ABP Framework. -This document explains the **solution structure** and project in details. If you want to start quickly, you can follow the guides below: - - +This document explains the **solution structure** and project in detail. ### What is the Difference Between the Application Startup Template? -ABP's [Application Startup Template](Application.md) provides a well-organized and layered solution to create maintainable business applications based on the [Domain Driven Design](../Domain-Driven-Design.md) (DDD) practises. However, some developers find this template little bit complex (or unneccessary) for simple and short-time applications. +ABP's [Application Startup Template](Application.md) provides a well-organized and layered solution to create maintainable business applications based on the [Domain Driven Design](../Domain-Driven-Design.md) (DDD) practices. However, some developers find this template a little bit complex (or unnecessary) for simple and short-time applications. -In that point, for such applications a single-layered application template is created. This template has the same functionality, features and modules on runtime with the [Application Startup Template](Application.md) and ABP modules are already installed but the development model is minimal and everything is in the single project (`.csproj`). +At this point, a single-layer application template has been created for such applications. This template has the same functionality, features and modules on runtime with the [Application Startup Template](Application.md) but the development model is minimal and everything is in a single project (`.csproj`). ## How to Start with? -You can use the [ABP CLI](../CLI.md) to create a new project using this startup template. Alternatively, you can directly create & download from the [Get Started](https://abp.io/get-started) page. How to download via CLI is explained in this section. +You can use the [ABP CLI](../CLI.md) to create a new project using this startup template. Alternatively, you can directly create & download this startup template from the [Get Started](https://abp.io/get-started) page. How to download via CLI is explained in this section. -First, install the ABP CLI if you haven't installed before: +Firstly, install the ABP CLI if you haven't installed it before: ```bash dotnet tool install -g Volo.Abp.Cli @@ -30,9 +28,9 @@ Then, use the `abp new` command in an empty folder to create a new solution: abp new Acme.BookStore -t app-nolayers ``` -* `Acme.BookStore` is the solution name, like *YourCompany.YourProduct*. You can use single level, two-levels or three-levels naming. -* This example specifies the template name (`-t` or `--template` option). - +* `Acme.BookStore` is the solution name, like *YourCompany.YourProduct*. You can use single-level, two-level or three-level naming. +* In this example, the `-t` option (or `--template` option) specifies the template name. + ### Specify the UI Framework This template provides multiple UI frameworks: @@ -42,15 +40,15 @@ This template provides multiple UI frameworks: * `angular`: Angular UI * `none`: Without UI -> Currently, this template doesn't have Blazor WASM UI, because it requries 3 projects at least (server-side, UI and shared library between these two projects). We'll consider to add Blazor WASM UI support based on your feedback. +> Currently, this template doesn't have Blazor WASM UI, because it requires 3 projects at least (server-side, UI and shared library between these two projects). -Use the `-u` or `--ui` option to specify the UI framework, while creating the solution: +Use the `-u` or `--ui` option to specify the UI framework while creating the solution: ```bash abp new Acme.BookStore -t app-nolayers -u angular ``` -* This example specifies the UI type (`-u` option) as `angular`, you can also specify the `mvc` or `blazor-server` for UI type. +* This example specifies the UI type (`-u` option) as `angular`, you can also specify `mvc` or `blazor-server` for UI type. ### Specify the Database Provider @@ -62,26 +60,27 @@ This template supports the following database providers: Use the `-d` (or `--database-provider`) option to specify the database provider while creating the solution: ```bash -abp new Acme.BookStore -d mongodb +abp new Acme.BookStore -t app-nolayers -d mongodb ``` ## Solution Structure -If you don't specify any additional option while creating an `app-nolayers` template, you will have a solution like shown below: +If you don't specify any additional options while creating an `app-nolayers` template, you will have a solution like shown below: ![](../images/bookstore-single-layer-solution-structure.png) -As you can see, it's a single layer template rather than a layered-architecture solution (like `Application Startup Template`). +As you can see, it's a single-layer template rather than a layered-architecture solution (like the `Application Startup Template`). ### Folder Structure -Since this template provides single layer solution, we've seperated concerns into folders instead of layers and you can see the pre-defined folders like shown below: +Since this template provides single-layer solution, we've separated concerns into folders instead of layers and you can see the pre-defined folders like shown below: ![](../images/single-layer-folder-structure.png) -* You can define your `entities`, `application services`, `DTOs` etc. in this single project (in the related folders). +* You can define your `entities`, `application services`, `DTOs`, etc. in this single project (in the related folders). +* For example, you can define your `application services` and `DTOs` under the **Services** folder. -## How to Run? +### How to Run? Before running the application, you need to create the database and seed the initial data. To do that, you can run the following command in the directory of your project: @@ -89,13 +88,21 @@ Before running the application, you need to create the database and seed the ini dotnet run --migrate-database ``` -* This command will create the database and seed the initial data for you. Then you can run the application with any IDE that supports .NET or by running the `dotnet run` CLI command in the directory of your project. Default username is `admin` and password is `1q2w3E*`. +* This command will create the database and seed the initial data for you. Then you can run the application with any IDE that supports .NET or by running the `dotnet run` CLI command in the directory of your project. The default username is `admin` and the password is `1q2w3E*`. + +> While creating a database & applying migrations seem only necessary for relational databases, this project comes even if you choose a NoSQL database provider (like MongoDB). In that case, it still seeds the initial data which is necessary for the application. > If you create an `app-nolayers` template with **Angular UI** you also need to run the angular project to see the UI. -### Angular UI +### Angular UI If you choose `Angular` as the UI framework, the solution is being separated into two folders: * `angular` folder contains the Angular UI application, the client-side code. -* `aspnet-core` folder contains the ASP.NET Core solution, the server-side code. \ No newline at end of file +* `aspnet-core` folder contains the ASP.NET Core solution (a single project), the server-side code. + +The server-side is similar to the solution described in the [Solution Structure](#solution-structure) section above. This project serves the API, so the `Angular` application can consume it. + +Angular application folder structure looks like below: + +![](../images/single-layer-angular-folder-structure.png) \ No newline at end of file diff --git a/docs/en/images/single-layer-angular-folder-structure.png b/docs/en/images/single-layer-angular-folder-structure.png new file mode 100644 index 0000000000000000000000000000000000000000..91fe09d61e2af7db8fd2a9e79247f349314c6041 GIT binary patch literal 16705 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