Browse Source

Merge branch 'dev' into documentation/revise-all-angular-documentation

# Conflicts:
#	docs/en/tutorials/book-store/part-03.md
pull/24196/head
erdemcaygor 2 months ago
parent
commit
b566583315
  1. 4
      Directory.Packages.props
  2. 1
      abp_io/AbpIoLocalization/AbpIoLocalization/Admin/Localization/Resources/en.json
  3. 9
      abp_io/AbpIoLocalization/AbpIoLocalization/Www/Localization/Resources/en.json
  4. 89
      docs/en/Blog-Posts/2025-08-08 v10_0_Release_Stable/POST.md
  5. BIN
      docs/en/Blog-Posts/2025-08-08 v10_0_Release_Stable/cover-image.png
  6. BIN
      docs/en/Blog-Posts/2025-08-08 v10_0_Release_Stable/upgrade-abp-packages.png
  7. 156
      docs/en/Community-Articles/2025-11-15-Announcing-SSR-Support/article.md
  8. BIN
      docs/en/Community-Articles/2025-11-17-Angular-21-Signals/cover-image.png
  9. 322
      docs/en/Community-Articles/2025-11-17-Angular-21-Signals/post.md
  10. 25
      docs/en/Community-Articles/2025-11-19-ABP-BLACK-FRIDAY-BLOG/post.md
  11. 158
      docs/en/Community-Articles/2025-11-21-AntiGravity/Post.md
  12. BIN
      docs/en/Community-Articles/2025-11-21-AntiGravity/agent-settings.png
  13. BIN
      docs/en/Community-Articles/2025-11-21-AntiGravity/anti-gravity-ui.png
  14. BIN
      docs/en/Community-Articles/2025-11-21-AntiGravity/breakpoint.png
  15. BIN
      docs/en/Community-Articles/2025-11-21-AntiGravity/cover.png
  16. BIN
      docs/en/Community-Articles/2025-11-21-AntiGravity/csharp-debug-extension.png
  17. BIN
      docs/en/Community-Articles/2025-11-21-AntiGravity/debug.png
  18. BIN
      docs/en/Community-Articles/2025-11-21-AntiGravity/errors.png
  19. BIN
      docs/en/Community-Articles/2025-11-21-AntiGravity/extension-features.png
  20. BIN
      docs/en/Community-Articles/2025-11-21-AntiGravity/extension.png
  21. BIN
      docs/en/Community-Articles/2025-11-21-AntiGravity/find-website-port.png
  22. BIN
      docs/en/Community-Articles/2025-11-21-AntiGravity/image-20251123185724281.png
  23. BIN
      docs/en/Community-Articles/2025-11-21-AntiGravity/llms.png
  24. BIN
      docs/en/Community-Articles/2025-11-21-AntiGravity/mcp.png
  25. BIN
      docs/en/Community-Articles/2025-11-21-AntiGravity/pricing.png
  26. BIN
      docs/en/Community-Articles/2025-11-22-building-production-ready-llm-applications/coverimage.png
  27. 114
      docs/en/Community-Articles/2025-11-22-building-production-ready-llm-applications/images/chat-history-hybrid.svg
  28. 150
      docs/en/Community-Articles/2025-11-22-building-production-ready-llm-applications/images/mcp-architecture.svg
  29. 135
      docs/en/Community-Articles/2025-11-22-building-production-ready-llm-applications/images/multilingual-rag.svg
  30. 112
      docs/en/Community-Articles/2025-11-22-building-production-ready-llm-applications/images/pgvector-integration.svg
  31. 118
      docs/en/Community-Articles/2025-11-22-building-production-ready-llm-applications/images/rag-parent-child.svg
  32. 60
      docs/en/Community-Articles/2025-11-22-building-production-ready-llm-applications/images/reasoning-effort-diagram.svg
  33. 149
      docs/en/Community-Articles/2025-11-22-building-production-ready-llm-applications/images/svg-diagram-example.svg
  34. 414
      docs/en/Community-Articles/2025-11-22-building-production-ready-llm-applications/post.md
  35. 1
      docs/en/Community-Articles/2025-11-22-building-production-ready-llm-applications/summary.md
  36. 18
      docs/en/docs-nav.json
  37. 307
      docs/en/framework/infrastructure/artificial-intelligence.md
  38. 31
      docs/en/framework/infrastructure/artificial-intelligence/index.md
  39. 176
      docs/en/framework/infrastructure/artificial-intelligence/microsoft-extensions-ai.md
  40. 135
      docs/en/framework/infrastructure/artificial-intelligence/microsoft-semantic-kernel.md
  41. 2
      docs/en/framework/infrastructure/index.md
  42. 24
      docs/en/framework/ui/angular/modifying-the-menu.md
  43. BIN
      docs/en/images/abp-overall-diagram-1600.png
  44. BIN
      docs/en/images/db-options.png
  45. BIN
      docs/en/images/ui-options.png
  46. 10
      docs/en/modules/ai-management/index.md
  47. 6
      docs/en/modules/file-management.md
  48. 20
      docs/en/release-info/migration-guides/abp-10-0.md
  49. 4
      docs/en/release-info/release-notes.md
  50. 2
      docs/en/tutorials/book-store-with-abp-suite/index.md
  51. 60
      docs/en/tutorials/book-store/part-02.md
  52. 42
      docs/en/tutorials/book-store/part-03.md
  53. 16
      docs/en/tutorials/book-store/part-05.md
  54. 36
      docs/en/tutorials/book-store/part-09.md
  55. 10
      docs/en/tutorials/book-store/part-10.md
  56. 2
      docs/en/tutorials/microservice/index.md
  57. 4
      docs/en/tutorials/microservice/part-01.md
  58. 29
      docs/en/tutorials/microservice/part-05.md
  59. 12
      docs/en/tutorials/microservice/part-06.md
  60. 111
      docs/en/tutorials/todo/layered/index.md
  61. 113
      docs/en/tutorials/todo/single-layer/index.md
  62. 3
      framework/src/Volo.Abp.AspNetCore.Mvc/Volo/Abp/AspNetCore/Mvc/ApplicationPartSorter.cs
  63. 31
      framework/src/Volo.Abp.Authorization/Volo/Abp/Authorization/Permissions/PermissionChecker.cs
  64. 9
      framework/src/Volo.Abp.Core/Volo/Abp/AbpApplicationBase.cs
  65. 5
      framework/src/Volo.Abp.Core/Volo/Abp/Internal/Telemetry/Activity/Providers/TelemetrySolutionInfoEnricher.cs
  66. 18
      framework/src/Volo.Abp.Core/Volo/Abp/Internal/Telemetry/Activity/Storage/TelemetryActivityStorage.cs
  67. 1
      framework/src/Volo.Abp.Core/Volo/Abp/Internal/Telemetry/Constants/ActivityPropertyNames.cs
  68. 8
      framework/src/Volo.Abp.Core/Volo/Abp/Internal/Telemetry/Constants/DeviceManager.cs
  69. 10
      framework/src/Volo.Abp.Core/Volo/Abp/Internal/Telemetry/EnvironmentInspection/Detectors/AbpStudioDetector.cs
  70. 10
      framework/src/Volo.Abp.Core/Volo/Abp/Internal/Telemetry/EnvironmentInspection/Detectors/VisualStudioCodeDetector.cs
  71. 6
      framework/src/Volo.Abp.Core/Volo/Abp/Internal/Telemetry/Helpers/AbpPackageMetadataReader.cs
  72. 36
      framework/src/Volo.Abp.Core/Volo/Abp/Internal/Telemetry/TelemetryService.cs
  73. 2
      framework/src/Volo.Abp.EntityFrameworkCore.PostgreSql/Volo.Abp.EntityFrameworkCore.PostgreSql.csproj
  74. 7
      framework/src/Volo.Abp.ExceptionHandling/Volo/Abp/AspNetCore/ExceptionHandling/DefaultExceptionToErrorInfoConverter.cs
  75. 13
      framework/test/Volo.Abp.AspNetCore.Mvc.Tests/Volo/Abp/AspNetCore/Mvc/ApplicationPart/ApplicationPartSorter_Tests.cs
  76. 2
      framework/test/Volo.Abp.Authorization.Tests/Volo/Abp/Authorization/AbpAuthorizationTestModule.cs
  77. 27
      framework/test/Volo.Abp.Authorization.Tests/Volo/Abp/Authorization/PermissionChecker_Tests.cs
  78. 6
      framework/test/Volo.Abp.Authorization.Tests/Volo/Abp/Authorization/TestServices/AuthorizationTestPermissionDefinitionProvider.cs
  79. 38
      framework/test/Volo.Abp.Authorization.Tests/Volo/Abp/Authorization/TestServices/TestProhibitedPermissionValueProvider1.cs
  80. 38
      framework/test/Volo.Abp.Authorization.Tests/Volo/Abp/Authorization/TestServices/TestProhibitedPermissionValueProvider2.cs
  81. 9
      latest-versions.json
  82. 6
      modules/basic-theme/test/Volo.Abp.AspNetCore.Mvc.UI.Bootstrap.Demo/package.json
  83. 264
      modules/basic-theme/test/Volo.Abp.AspNetCore.Mvc.UI.Bootstrap.Demo/yarn.lock
  84. 4
      modules/basic-theme/test/Volo.Abp.AspNetCore.Mvc.UI.Theme.Basic.Demo/package.json
  85. 268
      modules/basic-theme/test/Volo.Abp.AspNetCore.Mvc.UI.Theme.Basic.Demo/yarn.lock
  86. 4
      modules/blogging/app/Volo.BloggingTestApp/package.json
  87. 306
      modules/blogging/app/Volo.BloggingTestApp/yarn.lock
  88. 2
      modules/client-simulation/demo/Volo.ClientSimulation.Demo/package.json
  89. 240
      modules/client-simulation/demo/Volo.ClientSimulation.Demo/yarn.lock
  90. 10
      modules/cms-kit/angular/package.json
  91. 4
      modules/cms-kit/angular/projects/cms-kit/package.json
  92. 2
      modules/cms-kit/host/Volo.CmsKit.IdentityServer/package.json
  93. 240
      modules/cms-kit/host/Volo.CmsKit.IdentityServer/yarn.lock
  94. 2
      modules/cms-kit/host/Volo.CmsKit.Web.Host/package.json
  95. 240
      modules/cms-kit/host/Volo.CmsKit.Web.Host/yarn.lock
  96. 4
      modules/cms-kit/host/Volo.CmsKit.Web.Unified/package.json
  97. 392
      modules/cms-kit/host/Volo.CmsKit.Web.Unified/yarn.lock
  98. 2
      modules/cms-kit/src/Volo.CmsKit.Domain.Shared/Volo/CmsKit/Localization/Resources/en.json
  99. 17
      modules/cms-kit/src/Volo.CmsKit.Domain/Volo/CmsKit/Menus/PageChangedHandler.cs
  100. 30
      modules/cms-kit/src/Volo.CmsKit.Public.Web/Pages/CmsKit/Shared/Components/Rating/Default.cshtml

4
Directory.Packages.props

@ -122,11 +122,11 @@
<PackageVersion Include="Microsoft.IdentityModel.Tokens" Version="8.14.0" />
<PackageVersion Include="Microsoft.IdentityModel.JsonWebTokens" Version="8.14.0" />
<PackageVersion Include="Minio" Version="6.0.5" />
<PackageVersion Include="MongoDB.Driver" Version="3.5.0" />
<PackageVersion Include="MongoDB.Driver" Version="3.5.2" />
<PackageVersion Include="NEST" Version="7.17.5" />
<PackageVersion Include="Newtonsoft.Json" Version="13.0.4" />
<PackageVersion Include="Nito.AsyncEx.Context" Version="5.1.2" />
<PackageVersion Include="Npgsql.EntityFrameworkCore.PostgreSQL" Version="10.0.0-rc.1" />
<PackageVersion Include="Npgsql.EntityFrameworkCore.PostgreSQL" Version="10.0.0" />
<PackageVersion Include="NSubstitute" Version="5.3.0" />
<PackageVersion Include="NuGet.Versioning" Version="6.14.0" />
<PackageVersion Include="NUglify" Version="1.21.17" />

1
abp_io/AbpIoLocalization/AbpIoLocalization/Admin/Localization/Resources/en.json

@ -672,6 +672,7 @@
"SupportQuestionCountPerDeveloperOnRenewLicense": "Support Question Count Per Developer for License Renewal",
"SupportQuestionCountPerDeveloperOnNewLicense": "Support Question Count Per Developer for New License",
"IncludedDeveloperCount": "Included Developer Count",
"AiTokenCountPerDeveloper": "AI Token Count Per Developer",
"CanBuyAdditionalDevelopers": "Can Buy Additional Developers",
"HasEmailSupport": "Has Email Support",
"IsSupportPrivateQuestion": "Can Open Private Support Question",

9
abp_io/AbpIoLocalization/AbpIoLocalization/Www/Localization/Resources/en.json

@ -1553,6 +1553,15 @@
"IntegrateToYourKubernetesCluster_Description1": "<span class=\"text-highlight-white\">Connect your local development environment to a local or remote Kubernetes cluster</span>, where that cluster already runs your microservice solution.",
"IntegrateToYourKubernetesCluster_Description2": "Access any service in Kubernetes with their service name as DNS, just like they are running in your local computer.",
"IntegrateToYourKubernetesCluster_Description3": "<span class=\"text-highlight-white\">Intercept any service</span> in that cluster, so all the <span class=\"text-highlight-white\">traffic to the intercepted service is automatically redirected to your service </span>that is running in your local machine. When your service needs to use any service in Kubernetes, the traffic is redirected back to the cluster, just like your local service is running inside the Kubernetes.",
"AskOurAiAssistant": "Ask Our AI Assistant",
"AskOurAiAssistant_Description1": "Build faster with an AI that actually understands your ABP project. The ABP AI Assistant answers your technical questions, explains your code, and helps you solve problems directly inside ABP Studio — with full awareness of your project’s structure. You can even send screenshots or code files to get precise, context-based guidance.",
"AskOurAiAssistant_Description2": "What It Helps You Do",
"AskOurAiAssistant_Description3": "Ask anything about your ABP project — domain layer, modules, configuration, entities, services, or UI.",
"AskOurAiAssistant_Description4": "Get smart, code-aware explanations tailored to your solution.",
"AskOurAiAssistant_Description5": "Generate snippets and scaffolding suggestions instantly.",
"AskOurAiAssistant_Description6": "Fix errors faster with context-aware debugging support.",
"AskOurAiAssistant_Description7": "Learn ABP best practices as you build.",
"AskOurAiAssistant_Description8": "Whether you're generating new features, debugging an issue, or exploring a module, the AI Assistant gives you actionable, project-specific answers — right when you need them.",
"GetInformed": "Get Informed",
"Studio_GetInformed_Description1": "Leave your contact information to <span class=\"text-highlight-white\">get informed</span> and <span class=\"text-highlight-white\">try it first</span> when ABP Studio has been launched.",
"Studio_GetInformed_Description2": "Planned preview release date: Q3 of 2023.",

89
docs/en/Blog-Posts/2025-08-08 v10_0_Release_Stable/POST.md

@ -0,0 +1,89 @@
# ABP.IO Platform 10.0 Final Has Been Released!
We are glad to announce that [ABP](https://abp.io/) 10.0 stable version has been released today.
## What's New With Version 10.0?
All the new features were explained in detail in the [10.0 RC Announcement Post](https://abp.io/community/announcements/announcing-abp-10-0-release-candidate-86lrnyox), so there is no need to review them again. You can check it out for more details.
## Getting Started with 10.0
### How to Upgrade an Existing Solution
You can upgrade your existing solutions with either ABP Studio or ABP CLI. In the following sections, both approaches are explained:
### Upgrading via ABP Studio
If you are already using the ABP Studio, you can upgrade it to the latest version. ABP Studio periodically checks for updates in the background, and when a new version of ABP Studio is available, you will be notified through a modal. Then, you can update it by confirming the opened modal. See [the documentation](https://abp.io/docs/latest/studio/installation#upgrading) for more info.
After upgrading the ABP Studio, then you can open your solution in the application, and simply click the **Upgrade ABP Packages** action button to instantly upgrade your solution:
![](upgrade-abp-packages.png)
### Upgrading via ABP CLI
Alternatively, you can upgrade your existing solution via ABP CLI. First, you need to install the ABP CLI or upgrade it to the latest version.
If you haven't installed it yet, you can run the following command:
```bash
dotnet tool install -g Volo.Abp.Studio.Cli
```
Or to update the existing CLI, you can run the following command:
```bash
dotnet tool update -g Volo.Abp.Studio.Cli
```
After installing/updating the ABP CLI, you can use the [`update` command](https://abp.io/docs/latest/CLI#update) to update all the ABP related NuGet and NPM packages in your solution as follows:
```bash
abp update
```
You can run this command in the root folder of your solution to update all ABP related packages.
## Migration Guides
There are a few breaking changes in this version that may affect your application. Please read the migration guide carefully, if you are upgrading from v9.x: [ABP Version 10.0 Migration Guide](https://abp.io/docs/10.0/release-info/migration-guides/abp-10-0)
## Community News
### New ABP Community Articles
As always, exciting articles have been contributed by the ABP community. I will highlight some of them here:
* [Alper Ebiçoğlu](https://abp.io/community/members/alper)
* [Optimize your .NET app for production Part 1](https://abp.io/community/articles/optimize-your-dotnet-app-for-production-for-any-.net-app-wa24j28e)
* [Optimize your .NET app for production Part 2](https://abp.io/community/articles/optimize-your-dotnet-app-for-production-for-any-.net-app-2-78xgncpi)
* [Return Code vs Exceptions: Which One is Better?](https://abp.io/community/articles/return-code-vs-exceptions-which-one-is-better-1rwcu9yi)
* [Sumeyye Kurtulus](https://abp.io/community/members/sumeyye.kurtulus)
* [Building Scalable Angular Apps with Reusable UI Components](https://abp.io/community/articles/building-scalable-angular-apps-with-reusable-ui-components-b9npiff3)
* [Angular Library Linking Made Easy: Paths, Workspaces and Symlinks](https://abp.io/community/articles/angular-library-linking-made-easy-paths-workspaces-and-5z2ate6e)
* [erdem çaygör](https://abp.io/community/members/erdem.caygor)
* [Building Dynamic Forms in Angular for Enterprise](https://abp.io/community/articles/building-dynamic-forms-in-angular-for-enterprise-6r3ewpxt)
* [From Server to Browser: Angular TransferState Explained](https://abp.io/community/articles/from-server-to-browser-angular-transferstate-explained-m99zf8oh)
* [Mansur Besleney](https://abp.io/community/members/mansur.besleney)
* [Top 10 Exception Handling Mistakes in .NET](https://abp.io/community/articles/top-10-exception-handling-mistakes-in-net-jhm8wzvg)
* [Berkan Şaşmaz](https://abp.io/community/members/berkansasmaz)
* [How to Dynamically Set the Connection String in EF Core](https://abp.io/community/articles/how-to-dynamically-set-the-connection-string-in-ef-core-30k87fpj)
* [Oğuzhan Ağır](https://abp.io/community/members/oguzhan.agir)
* [The ASP.NET Core Dependency Injection System](https://abp.io/community/articles/the-asp.net-core-dependency-injection-system-3vbsdhq8)
* [Selman Koç](https://abp.io/community/members/selmankoc)
* [5 Things Keep in Mind When Deploying Clustered Environment](https://abp.io/community/articles/5-things-keep-in-mind-when-deploying-clustered-environment-i9byusnv)
* [Muhammet Ali ÖZKAYA](https://abp.io/community/members/m.aliozkaya)
* [Repository Pattern in ASP.NET Core](https://abp.io/community/articles/repository-pattern-in-asp.net-core-2dudlg3j)
* [Armağan Ünlü](https://abp.io/community/members/armagan)
* [UI/UX Trends That Will Shape 2026](https://abp.io/community/articles/UI-UX-Trends-That-Will-Shape-2026-bx4c2kow)
* [Salih](https://abp.io/community/members/salih)
* [What is That Domain Service in DDD for .NET Developers?](https://abp.io/community/articles/what-is-that-domain-service-in-ddd-for-.net-developers-uqnpwjja)
* [Building an API Key Management System with ABP Framework](https://abp.io/community/articles/building-an-api-key-management-system-with-abp-framework-28gn4efw)
* [Fahri Gedik](https://abp.io/community/members/fahrigedik)
* [Signal-Based Forms in Angular](https://abp.io/community/articles/signal-based-forms-in-angular-21-9qentsqs)
Thanks to the ABP Community for all the content they have published. You can also [post your ABP related (text or video) content](https://abp.io/community/posts/create) to the ABP Community.
## About the Next Version
The next feature version will be 10.1. You can follow the [release planning here](https://github.com/abpframework/abp/milestones). Please [submit an issue](https://github.com/abpframework/abp/issues/new) if you have any problems with this version.

BIN
docs/en/Blog-Posts/2025-08-08 v10_0_Release_Stable/cover-image.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 127 KiB

BIN
docs/en/Blog-Posts/2025-08-08 v10_0_Release_Stable/upgrade-abp-packages.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 16 KiB

156
docs/en/Community-Articles/2025-11-15-Announcing-SSR-Support/article.md

@ -0,0 +1,156 @@
# Announcing Server-Side Rendering (SSR) Support for ABP Framework Angular Applications
We are pleased to announce that **Server-Side Rendering (SSR)** has become available for ABP Framework Angular applications! This highly requested feature brings major gains in performance, SEO, and user experience to your Angular applications based on ABP Framework.
## What is Server-Side Rendering (SSR)?
Server-Side Rendering refers to an approach which renders your Angular application on the server as opposed to the browser. The server creates the complete HTML for a page and sends it to the client, which can then show the page to the user. This poses many advantages over traditional client-side rendering.
## Why SSR Matters for ABP Angular Applications
### Improved Performance
- **Quicker visualization of the first contentful paint (FCP)**: Because prerendered HTML is sent over from the server, users will see content quicker.
- **Better perceived performance**: Even on slower devices, the page will be displaying something sooner.
- **Less JavaScript parsing time**: For example, the initial page load will not require parsing and executing a large bundle of JavaScript.
### Enhanced SEO
- **Improved indexing by search engines**: Search engine bots are able to crawl and index your content quicker.
- **Improved rankings in search**: The quicker the content loads and the easier it is to access, the better your SEO score.
- **Preview when sharing on social channels**: Rich previews with the appropriate meta tags are generated when sharing links on social platforms.
### Better User Experience
- **Support for low bandwidth**: Users with slower Internet connections will have a better experience
- **Progressive enhancement**: Users can start accessing the content before JavaScript has loaded
- **Better accessibility**: Screen readers and other assistive technologies can access the content immediately
## Getting Started with SSR
### Adding SSR to an Existing Project
You can easily add SSR support to your existing ABP Angular application using the Angular CLI with ABP schematics:
```bash
# Generate SSR configuration for your project
ng generate @abp/ng.schematics:ssr-add
# Alternatively, you can use the short form
ng g @abp/ng.schematics:ssr-add
```
If you have multiple projects in your workspace, you can specify which project to add SSR to:
```bash
ng g @abp/ng.schematics:ssr-add --project=my-project
```
If you want to skip the automatic installation of dependencies:
```bash
ng g @abp/ng.schematics:ssr-add --skip-install
```
## What Gets Configured
When you add SSR to your ABP Angular project, the schematic automatically:
1. **Installs necessary dependencies**: Adds `@angular/ssr` and related packages
2. **Creates Server Configuration**: Creates `server.ts` and related files
3. **Updates Project Structure**:
- Creates `main.server.ts` to bootstrap the server
- Adds `app.config.server.ts` for standalone apps (or `app.module.server.ts` for NgModule apps)
- Configures server routes in `app.routes.server.ts`
4. **Updates Build Configuration**: updates `angular.json` to include:
- a `serve-ssr` target for local SSR development
- a `prerender` target for static site generation
- Proper output paths for browser and server bundles
## Supported Configurations
The ABP SSR schematic supports both modern and legacy Angular build configurations:
### Application Builder (Suggested)
- The new `@angular-devkit/build-angular:application` builder
- Optimized for Angular 17+ apps
- Enhanced performance and smaller bundle sizes
### Server Builder (Legacy)
- The original `@angular-devkit/build-angular:server` builder
- Designed for legacy Angular applications
- Compatible with legacy applications
## Running Your SSR Application
After adding SSR to your project, you can run your application in SSR mode:
```bash
# Development mode with SSR
ng serve
# Or specifically target SSR development server
npm run serve:ssr
# Build for production
npm run build:ssr
# Preview production build
npm run serve:ssr:production
```
## Important Considerations
### Browser-Only APIs
Some browser APIs are not available on the server. Use platform checks to conditionally execute code:
```typescript
import { isPlatformBrowser } from '@angular/common';
import { PLATFORM_ID, inject } from '@angular/core';
export class MyComponent {
private platformId = inject(PLATFORM_ID);
ngOnInit() {
if (isPlatformBrowser(this.platformId)) {
// Code that uses browser-only APIs
console.log('Running in browser');
localStorage.setItem('key', 'value');
}
}
}
```
### Storage APIs
`localStorage` and `sessionStorage` are not accessible on the server. Consider using:
- Cookies for server-accessible data.
- The state transfer API for hydration.
- ABP's built-in storage abstractions.
### Third-Party Libraries
Please ensure that any third-party libraries you use are compatible with SSR. These libraries can require:
- Dynamic imports for browser-only code.
- Platform-specific service providers.
- Custom Angular Universal integration.
## ABP Framework Integration
The SSR implementation is natively integrated with all of the ABP Framework features:
- **Authentication & Authorization**: The OAuth/OpenID Connect flow functions seamlessly with ABP
- **Multi-tenancy**: Fully supports tenant resolution and switching
- **Localization**: Server-side rendering respects the locale
- **Permission Management**: Permission checks work on both server and client
- **Configuration**: The ABP configuration system is SSR-ready
## Performance Tips
1. **Utilize State Transfer**: Send data from server to client to eliminate redundant HTTP requests
2. **Optimize Images**: Proper image loading strategies, such as lazy loading and responsive images.
3. **Cache API Responses**: At the server, implement proper caching strategies.
4. **Monitor Bundle Size**: Keep your server bundle optimized
5. **Use Prerendering**: The prerender target should be used for static content.
## Conclusion
Server-side rendering can be a very effective feature in improving your ABP Angular application's performance, SEO, and user experience. Our new SSR schematic will make it easier than ever to add SSR to your project.
Try it today and let us know what you think!
---

BIN
docs/en/Community-Articles/2025-11-17-Angular-21-Signals/cover-image.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 752 KiB

322
docs/en/Community-Articles/2025-11-17-Angular-21-Signals/post.md

@ -0,0 +1,322 @@
# Signal-Based Forms in Angular 21: Why You’ll Never Miss Reactive Forms Again
Angular 21 introduces one of the most exciting developments in the modern edition of Angular: **Signal-Based Forms**. Built directly on the reactive foundation of Angular signals, this new experimental API provides a cleaner, more intuitive, strongly typed, and ergonomic approach for managing form state—without the heavy boilerplate of Reactive Forms.
> ⚠️ **Important:** Signal Forms are *experimental*.
> Their API can change. Avoid using them in critical production scenarios unless you understand the risks.
Despite this, Signal Forms clearly represent Angular’s future direction.
---
## Why Signal Forms?
Traditionally in Angular, building forms has involved several concerns:
- Tracking values
- Managing UI interaction states (touched, dirty)
- Handling validation
- Keeping UI and model in sync
Reactive Forms solved many challenges but introduced their own:
- Verbosity FormBuilder API
- Required subscriptions (valueChanges)
- Manual cleaning
- Difficult nested forms
- Weak type-safety
**Signal Forms solve these problems through:**
1." Automatic synchronization
2." Full type safety
3." Schema-based validation
4." Fine-grained reactivity
5." Drastically reduced boilerplate
6." Natural integration with Angular Signals
---
### 1. Form Models — The Core of Signal Forms
A **form model** is simply a writable signal holding the structure of your form data.
```ts
import { Component, signal } from '@angular/core';
import { form, Field } from '@angular/forms/signals';
@Component({
selector: 'app-login',
imports: [Field],
template: `
<input type="email" [field]="loginForm.email" />
<input type="password" [field]="loginForm.password" />
`,
})
export class LoginComponent {
loginModel = signal({
email: '',
password: '',
});
loginForm = form(this.loginModel);
}
```
Calling `form(model)` creates a **Field Tree** that maps directly to your model.
---
### 2. Achieving Full Type Safety
Although TypeScript can infer types from object literals, defining explicit interfaces provides maximum safety and better IDE support.
```ts
interface LoginData {
email: string;
password: string;
}
loginModel = signal<LoginData>({
email: '',
password: '',
});
loginForm = form(loginModel);
```
Now:
- `loginForm.email``FieldTree<string>`
- Accessing invalid fields like `loginForm.username` results in compile-time errors
This level of type safety surpasses Reactive Forms.
---
### 3. Reading Form Values
#### Read from the model (entire form):
```ts
onSubmit() {
const data = this.loginModel();
console.log(data.email, data.password);
}
```
#### Read from an individual field:
```html
<p>Current email: {{ loginForm.email().value() }}</p>
```
Each field exposes:
- `value()`
- `valid()`
- `errors()`
- `dirty()`
- `touched()`
All as signals.
---
### 4. Updating Form Models Programmatically
Signal Forms allow three update methods.
#### 1. Replace the entire model
```ts
this.userModel.set({
name: 'Alice',
email: 'alice@example.com',
});
```
#### 2. Patch specific fields
```ts
this.userModel.update(prev => ({
...prev,
email: newEmail,
}));
```
#### 3. Update a single field
```ts
this.userForm.email().value.set('');
```
This eliminates the need for:
- `patchValue()`
- `setValue()`
- `formGroup.get('field')`
---
### 5. Automatic Two-Way Binding With `[field]`
The `[field]` directive enables perfect two-way data binding:
```html
<input [field]="userForm.name" />
```
#### How it works:
- **User input → Field state → Model**
- **Model updates → Field state → Input UI**
No subscriptions.
No event handlers.
No boilerplate.
Reactive Forms could never achieve this cleanly.
---
### 6. Nested Models and Arrays
Models can contain nested object structures:
```ts
userModel = signal({
name: '',
address: {
street: '',
city: '',
},
});
```
Access fields easily:
```html
<input [field]="userForm.address.street" />
```
Arrays are also supported:
```ts
orderModel = signal({
items: [
{ product: '', quantity: 1, price: 0 }
]
});
```
Field state persists even when array items move, thanks to identity tracking.
---
### 7. Schema-Based Validation
Validation is clean and centralized:
```ts
import { required, email } from '@angular/forms/signals';
const model = signal({ email: '' });
const formRef = form(model, {
email: [required(), email()],
});
```
Field validation state is reactive:
```ts
formRef.email().valid()
formRef.email().errors()
formRef.email().touched()
```
Validation no longer scatters across components.
---
### 8. When Should You Use Signal Forms?
#### New Angular 21+ apps
Signal-first architecture is the new standard.
#### Teams wanting stronger type safety
Every field is exactly typed.
#### Devs tired of Reactive Form boilerplate
Signal Forms drastically simplify code.
#### Complex UI with computed reactive form state
Signals integrate perfectly.
#### ❌ Avoid if:
- You need long-term stability
- You rely on mature Reactive Forms features
- Your app must avoid experimental APIs
---
### 9. Reactive Forms vs Signal Forms
| Feature | Reactive Forms | Signal Forms |
|--------|----------------|--------------|
| Boilerplate | High | Very low |
| Type-safety | Weak | Strong |
| Two-way binding | Manual | Automatic |
| Validation | Scattered | Centralized schema |
| Nested forms | Verbose | Natural |
| Subscriptions | Required | None |
| Change detection | Zone-heavy | Fine-grained |
Signal Forms feel like the "modern Angular mode," while Reactive Forms increasingly feel legacy.
---
### 10. Full Example: Login Form
```ts
@Component({
selector: 'app-login',
imports: [Field],
template: `
<form (ngSubmit)="submit()">
<input type="email" [field]="form.email" />
<input type="password" [field]="form.password" />
<button>Login</button>
</form>
`,
})
export class LoginComponent {
model = signal({ email: '', password: '' });
form = form(this.model);
submit() {
console.log(this.model());
}
}
```
Minimal. Reactive. Completely type-safe.
---
## **Conclusion**
Signal Forms in Angular 21 represent a big step forward:
- Cleaner API
- Stronger type safety
- Automatic two-way binding
- Centralized validation
- Fine-grained reactivity
- Dramatically better developer experience
Although these are experimental, they clearly show the future of Angular's form ecosystem.
Once you get into using Signal Forms, you may never want to use Reactive Forms again.
---

25
docs/en/Community-Articles/2025-11-19-ABP-BLACK-FRIDAY-BLOG/post.md

@ -0,0 +1,25 @@
**ABP Black Friday Deals are Almost Here\!**
The season of huge savings is back\! We are happy to announce **ABP Black Friday Campaign**, packed with exclusive deals that you simply won't want to miss. Whether you are ready to start building with ABP or looking to expand your existing license, this is your chance to maximize your savings\!
**Campaign Dates: Mark Your Calendar**
Black Friday campaign is live for one week only\! Our deals run from: **November 24th \- December 1st.**
Don't miss this limited-time opportunity to **save up to $3,000** and take your software development to the next level.
**What's Included in the ABP Black Friday Campaign?**
Here’s why this campaign is the best time to buy or upgrade:
* Open to Everyone: This campaign is available for both new and existing customers.
* Stack Your Savings: You can combine this Black Friday offer with our multi-year discounts for the greatest possible value.
* Flexible Upgrades: Planning to upgrade to a higher package? Now is the perfect time to make that move at a lower cost.
* More Developer Seats? No Problem\! Additional developer seats are also eligible under this campaign, allowing you to grow your team effortlessly and affordably.
**Save Money Now\!**
This campaign is your best opportunity all year to unlock advanced features, scale your team, or upgrade your plan while **saving up to $3,000.** Secure your savings before the campaign ends on December 1st\!
[**Visit Pricing Page to Explore Offers\!**](https://abp.io/pricing)

158
docs/en/Community-Articles/2025-11-21-AntiGravity/Post.md

@ -0,0 +1,158 @@
# My First Look and Experience with Google AntiGravity
## Is Google AntiGravity Going to Replace Your Main Code Editor?
Today, I tried the new code-editor AntiGravity by Google. *"It's beyond a code-editor*" by Google 🙄
When I first launch it, I see the UI is almost same as Cursor. They're both based on Visual Studio Code.
That's why it was not hard to find what I'm looking for.
First of all, the main difference as I see from the Cursor is; when I type a prompt in the agent section **AntiGravity first creates a Task List** (like a road-map) and whenever it finishes a task, it checks the corresponding task. Actually Cursor has a similar functionality but AntiGravity took it one step further.
Second thing which was good to me; AntiGravity uses [Nano Banana 🍌](https://gemini.google/tr/overview/image-generation/). This is Google's AI image generation model... Why it's important because when you create an app, you don't need to search for graphics, deal with image licenses. **AntiGravity generates images automatically and no license is required!**
Third exciting feature for me; **AntiGravity is integrated with Google Chrome and can communicate with the running website**. When I first run my web project, it installed a browser extension which can see and interact with my website. It can see the results, click somewhere else on the page, scroll, fill up the forms, amazing 😵
Another feature I loved is that **you can enter a new prompt even while AntiGravity is still generating a response** 🧐. It instantly prioritizes the latest input and adjusts the ongoing process if needed. But in Cursor, if you add a prompt before the cursor finishes, it simply queues it and runs it later 😔.
And lastly, **AntiGravity is working very good with Gemini 3**.
Well, everything was not so perfect 😥 When I tried AntiGravity, couple of times it stucked AI generation and Agent stopped. I faced errors like this 👇
![Errors](errors.png)
## Debugging .NET Projects via AntiGravity
⚠ There's a crucial development issue with AntiGravity (and also for Cursor, Windsurf etc...) 🤕 you **cannot debug your .NET application with AntiGravity 🥺.** *This is Microsoft's policy!* Microsoft doesn't allow debugging for 3rd party IDEs and shows the below error... That's why I cannot say it's a downside of AntiGravity. You need to use Microsft's original VS Code, Visual Studio or Rider for debugging. But wait a while there's a workaround for this, I'll let you know in the next section.
![Debugging](debug.png)
### What does this error mean?
AntiGravity, Cursor, Windsurf etc... are using Visual Studio Code and the C# extension for VS Code includes the Microsoft .NET Core Debugger "*vsdbg*".
VS Code is open-source but "*vsdbg*" is not open-source! It's working only with Visual Studio Code, Visual Studio and Visual Studio for Mac. This is clearly stated at [Microsoft's this link](https://github.com/dotnet/vscode-csharp/blob/main/docs/debugger/Microsoft-.NET-Core-Debugger-licensing-and-Microsoft-Visual-Studio-Code.md).
### Ok! How to resolve debugging issue with AntiGravity? and Cursor and Windsurf...
There's a free C# debugger extension for Visual Studio Code based IDEs that supports AntiGravity, Cursor and Windsurf. The extension name is **C#**.
You can download this free C# debugger extension at 👉 [open-vsx.org/extension/muhammad-sammy/csharp/](https://open-vsx.org/extension/muhammad-sammy/csharp/).
For AntiGravity open Extension window (*Ctrl + Shift + X*) and search for `C#`, there you'll see this extension.
![C# Debugging Extension](csharp-debug-extension.png)
After installing, I restarted AntiGravity and now I can see the red circle which allows me to add breakpoint on C# code.
![Add C# Breakpoint](breakpoint.png)
### Another Extension For Debugging .NET Apps on VS Code
Recently I heard about DotRush extension from the folks. As they say DotRush works slightly faster and support Razor pages (.cshtml files).
Here's the link for DotRush https://github.com/JaneySprings/DotRush
### Finding Website Running Port
When you run the web project via C# debugger extension, normally it's not using the `launch.json` therefore the website port is not the one when you start from Visual Studio / Rider... So what's my website's port which I just run now? Normally for ASP.NET Core **the default port is 5000**. You can try navigating to http://localhost:5000/.
Alternatively you can write the below code in `Program.cs` which prints the full address of your website in the logs.
If you do the steps which I showed you, you can debug your C# application via AntiGravity and other VS Code derivatives.
![Find Website Port](find-website-port.png)
## How Much is AntiGravity? 💲
Currently there's only individual plan is available for personal accounts and that's free 👏! The contents of Team and Enterprise plans and prices are not announced yet. But **Gemini 3 is not free**! I used it with my company's Google Workspace account which we normally pay for Gemini.
![Pricing](pricing.png)
## More About AntiGravity
There have been many AI assisted IDEs like [Windsurf](https://windsurf.com/), [Cursor](https://cursor.com/), [Zed](https://zed.dev/), [Replit](https://replit.com/) and [Fleet](https://www.jetbrains.com/fleet/). But this time it's different, this is backed by Google.
As you see from the below image AntiGravity, uses a standard grid layout as others based on VS Code editor.
It's very similar to Cursor, Visual Studio, Rider.
![AntiGravity UI](anti-gravity-ui.png)
## Supported LLMs 🧠
Antigravity offers the below models which supports reasoning: Gemini 3 Pro, Claude Sonnet 4.5, GPT-OSS
![LLMs](llms.png)
Antigravity uses other models for supportive tasks in the background:
- **Nano banana**: This is used to generate images.
- **Gemini 2.5 Pro UI Checkpoint**: It's for the browser subagent to trigger browser action such as clicking, scrolling, or filling in input.
- **Gemini 2.5 Flash**: For checkpointing and context summarization, this is used.
- **Gemini 2.5 Flash Lite**: And when it's need to make a semantic search in your code-base, this is used.
## AntiGravity Can See Your Website
This makes a big difference from traditional IDEs. AntiGravity's browser agent is taking screenshots of your pages when it needs to check. This is achieved by a Chrome Extension as a tool to the agent, and you can also prompt the agent to take a screenshot of a page. It can iterate on website designs and implementations, it can perform UI Testing, it can monitor dashboards, it can automate routine tasks like rerunning CI.
This is the link for the extension 👉 [chromewebstore.google.com/detail/antigravity-browser-exten/eeijfnjmjelapkebgockoeaadonbchdd](https://chromewebstore.google.com/detail/antigravity-browser-exten/eeijfnjmjelapkebgockoeaadonbchdd). AntiGravity will install this extension automatically on the first run.
![Browser Extension](extension.png)
![Extension Features](extension-features.png)
## MCP Integration
### When Do We Need MCP in a Code Editor?
Simply if we want to connect to a 3rd party service to complete our task we need MCP. So AntiGravity can connect to your DB and write proper SQL queries or it can pull in recent build logs from Netlify or Heroku. Also you can ask AntiGravity to to connect GitHub for finding the best authentication pattern.
### AntiGravity Supports These MCP Servers
Airweave, AlloyDB for PostgreSQL, Atlassian, BigQuery, Cloud SQL for PostgreSQL, Cloud SQL for MySQL, Cloud SQL for SQL Server, Dart, Dataplex, Figma Dev Mode MCP, Firebase, GitHub, Harness, Heroku, Linear, Locofy, Looker, MCP Toolbox for Databases, MongoDB, Neon, Netlify, Notion, PayPal, Perplexity Ask, Pinecone, Prisma, Redis, Sequential Thinking, SonarQube, Spanner, Stripe and Supabase.
![MCP](mcp.png)
## Agent Settings ⚙️
The major settings of Agent are:
- **Agent Auto Fix Lints**: I enabled this setting because I want the Agent automatically fixes its own mistakes for invalid syntax, bad formatting, unused variables, unreachable code or following coding standards... It makes extra tool calls that's why little bit expensive 🥴.
- **Auto Execution**: Sometimes Agent tries to build application or writing test code and running it, in these cases it executes command. I choose "Turbo" 🤜 With this option, Agent always runs the terminal command and controls my browser.
- **Review Policy**: How much control you are giving to agent 🙎. I choose "Always Proceed" 👌 because I mostly trust AI 😀. The Agent will never ask for review.
![Agent Settings](agent-settings.png)
## Differences Between Cursor and AntiGravity
While Cursor was the champion of AI code editors, **Antigravity brings a different philosophy**.
### 1. "Agent-First 🤖" vs "You-First 🤠"
- **Cursor:** It acts like an assistant; it predicts your next move, auto-completes your thoughts, and helps you refactor while you type. You are still the driver; Cursor just drives the car at 200 km/h.
- **Antigravity:** Antigravity is built to let you manage coding tasks. It is "Agent-First." You don't just type code; you assign tasks to autonomous agents (e.g., "Fix the bug in the login flow and verify it in the browser"). It behaves more like a junior developer that you supervise.
### 2. The Interface
- **Cursor:** Looks and feels exactly like **VS Code**. If you know VS Code, you know Cursor.
- **Antigravity:** Introduces 2 major layouts:
- **Editor View:** Similar to a standard IDE
- **Manager View:** A dashboard where you see multiple "Agents" working in parallel. You can watch them plan, execute, and test tasks asynchronously.
### 3. Verification & Trust
- **Cursor:** You verify by reading the code diffs it suggests.
- **Antigravity:** Introduces **Artifacts**... Since the agents work autonomously, they generate proof-of-work documents, screenshots of the app running, browser logs and execution plans. So you can verify what they did without necessarily reading every line of code immediately.
### 4. Capabilities
- **Cursor:** Best-in-class **Autocomplete** ("Tab" feature) and **Composer** (multi-file editing). It excels at "Vibe Coding". It's getting into a flow state where the AI writes the boilerplate and you direct the logic.
- **Antigravity:** Is good at **Autonomous Execution**. It has a built-in browser and terminal that the *Agent* controls. The Agent can write code, run the server, open the browser, see the error, and fix it 😎
### 5. AI Models (Brains 🧠)
- **Cursor:** Model Agnostic. You can switch between **Claude 3.5 Sonnet** *-mostly the community uses this-*, GPT-4o, and others.
- **Antigravity:** Built deeply around **Gemini 3 Pro**. It leverages Gemini's massive context window (1M+ tokens) to understand huge mono repos without needing as much "RAG" as Cursor.
## Try It Yourself Now 🤝
If you are ready to experience the new AI code editor by Google, download and use 👇
[**Launch Google AntiGravity**](https://antigravity.google/)

BIN
docs/en/Community-Articles/2025-11-21-AntiGravity/agent-settings.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 70 KiB

BIN
docs/en/Community-Articles/2025-11-21-AntiGravity/anti-gravity-ui.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 183 KiB

BIN
docs/en/Community-Articles/2025-11-21-AntiGravity/breakpoint.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 62 KiB

BIN
docs/en/Community-Articles/2025-11-21-AntiGravity/cover.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 MiB

BIN
docs/en/Community-Articles/2025-11-21-AntiGravity/csharp-debug-extension.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 90 KiB

BIN
docs/en/Community-Articles/2025-11-21-AntiGravity/debug.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 13 KiB

BIN
docs/en/Community-Articles/2025-11-21-AntiGravity/errors.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 102 KiB

BIN
docs/en/Community-Articles/2025-11-21-AntiGravity/extension-features.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 293 KiB

BIN
docs/en/Community-Articles/2025-11-21-AntiGravity/extension.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 76 KiB

BIN
docs/en/Community-Articles/2025-11-21-AntiGravity/find-website-port.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 46 KiB

BIN
docs/en/Community-Articles/2025-11-21-AntiGravity/image-20251123185724281.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 13 KiB

BIN
docs/en/Community-Articles/2025-11-21-AntiGravity/llms.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 13 KiB

BIN
docs/en/Community-Articles/2025-11-21-AntiGravity/mcp.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 275 KiB

BIN
docs/en/Community-Articles/2025-11-21-AntiGravity/pricing.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 49 KiB

BIN
docs/en/Community-Articles/2025-11-22-building-production-ready-llm-applications/coverimage.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 154 KiB

114
docs/en/Community-Articles/2025-11-22-building-production-ready-llm-applications/images/chat-history-hybrid.svg

@ -0,0 +1,114 @@
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 800 450">
<!-- Background -->
<rect width="800" height="450" fill="#f8f9fa"/>
<!-- Title -->
<text x="400" y="30" font-family="Arial" font-size="18" font-weight="bold" text-anchor="middle" fill="#0066cc">
Hybrid Chat History: Truncation + RAG on History
</text>
<!-- Full conversation -->
<rect x="50" y="60" width="250" height="200" fill="#e3f2fd" stroke="#1976d2" stroke-width="2" rx="5"/>
<text x="175" y="85" font-family="Arial" font-size="13" font-weight="bold" text-anchor="middle" fill="#0d47a1">
Full Chat History
</text>
<text x="175" y="105" font-family="Arial" font-size="10" text-anchor="middle" fill="#0d47a1">
(100 messages, 20K tokens)
</text>
<!-- Messages visual -->
<rect x="60" y="120" width="230" height="15" fill="#90caf9" stroke="#1976d2" stroke-width="1" rx="2"/>
<text x="175" y="131" font-family="Arial" font-size="9" text-anchor="middle" fill="#0d47a1">Messages 1-10 (1 day ago)</text>
<rect x="60" y="140" width="230" height="15" fill="#90caf9" stroke="#1976d2" stroke-width="1" rx="2"/>
<text x="175" y="151" font-family="Arial" font-size="9" text-anchor="middle" fill="#0d47a1">Messages 11-20 (12 hours ago)</text>
<text x="175" y="175" font-family="Arial" font-size="11" text-anchor="middle" fill="#666">...</text>
<rect x="60" y="190" width="230" height="15" fill="#90caf9" stroke="#1976d2" stroke-width="1" rx="2"/>
<text x="175" y="201" font-family="Arial" font-size="9" text-anchor="middle" fill="#0d47a1">Messages 81-90</text>
<rect x="60" y="210" width="230" height="35" fill="#64b5f6" stroke="#1976d2" stroke-width="2" rx="2"/>
<text x="175" y="230" font-family="Arial" font-size="10" font-weight="bold" text-anchor="middle" fill="#0d47a1">Messages 91-100 (Last 10)</text>
<!-- Arrow split -->
<defs>
<marker id="arrow" markerWidth="10" markerHeight="10" refX="9" refY="3" orient="auto">
<polygon points="0 0, 10 3, 0 6" fill="#333"/>
</marker>
</defs>
<line x1="300" y1="150" x2="370" y2="100" stroke="#d32f2f" stroke-width="2" marker-end="url(#arrow)"/>
<line x1="300" y1="227" x2="370" y2="250" stroke="#388e3c" stroke-width="2" marker-end="url(#arrow)"/>
<text x="310" y="130" font-family="Arial" font-size="10" fill="#d32f2f">Old Messages</text>
<text x="310" y="270" font-family="Arial" font-size="10" fill="#388e3c">Recent Messages</text>
<!-- Vector DB (Long-term memory) -->
<rect x="370" y="60" width="180" height="100" fill="#ffebee" stroke="#d32f2f" stroke-width="2" rx="5"/>
<text x="460" y="85" font-family="Arial" font-size="12" font-weight="bold" text-anchor="middle" fill="#b71c1c">
Vector DB
</text>
<text x="460" y="105" font-family="Arial" font-size="10" text-anchor="middle" fill="#b71c1c">
(Long-term Memory)
</text>
<text x="460" y="125" font-family="Arial" font-size="9" text-anchor="middle" fill="#b71c1c">
Messages 1-90 with embeddings
</text>
<text x="460" y="140" font-family="Arial" font-size="9" text-anchor="middle" fill="#b71c1c">
Tool: SearchChatHistory()
</text>
<!-- Short-term memory (Prompt) -->
<rect x="370" y="200" width="180" height="100" fill="#c8e6c9" stroke="#388e3c" stroke-width="2" rx="5"/>
<text x="460" y="225" font-family="Arial" font-size="12" font-weight="bold" text-anchor="middle" fill="#1b5e20">
Prompt (Short-term)
</text>
<text x="460" y="245" font-family="Arial" font-size="10" text-anchor="middle" fill="#1b5e20">
Messages 91-100
</text>
<text x="460" y="265" font-family="Arial" font-size="9" text-anchor="middle" fill="#1b5e20">
Truncation (Last 10 messages)
</text>
<text x="460" y="280" font-family="Arial" font-size="9" text-anchor="middle" fill="#1b5e20">
Low tokens, fast
</text>
<!-- LLM -->
<line x1="550" y1="110" x2="600" y2="180" stroke="#666" stroke-width="2" stroke-dasharray="5,5" marker-end="url(#arrow)"/>
<line x1="550" y1="250" x2="600" y2="210" stroke="#666" stroke-width="2" marker-end="url(#arrow)"/>
<rect x="600" y="150" width="150" height="100" fill="#f3e5f5" stroke="#7b1fa2" stroke-width="2" rx="5"/>
<text x="675" y="185" font-family="Arial" font-size="14" font-weight="bold" text-anchor="middle" fill="#4a148c">
LLM
</text>
<text x="675" y="205" font-family="Arial" font-size="10" text-anchor="middle" fill="#4a148c">
Short-term context +
</text>
<text x="675" y="220" font-family="Arial" font-size="10" text-anchor="middle" fill="#4a148c">
Long-term memory via tool
</text>
<text x="675" y="235" font-family="Arial" font-size="10" text-anchor="middle" fill="#4a148c">
access when needed
</text>
<!-- Benefits -->
<rect x="50" y="330" width="700" height="100" fill="#fff9c4" stroke="#f57f17" stroke-width="2" rx="5"/>
<text x="400" y="360" font-family="Arial" font-size="14" font-weight="bold" text-anchor="middle" fill="#f57f17">
✅ Hybrid Approach Benefits
</text>
<g id="benefit1">
<circle cx="80" cy="385" r="5" fill="#fbc02d"/>
<text x="95" y="390" font-family="Arial" font-size="11" fill="#f57f17">
<tspan font-weight="bold">Low Cost:</tspan> Only last 10 messages in prompt per request (truncation)
</text>
</g>
<g id="benefit2">
<circle cx="80" cy="410" r="5" fill="#fbc02d"/>
<text x="95" y="415" font-family="Arial" font-size="11" fill="#f57f17">
<tspan font-weight="bold">High Fidelity:</tspan> LLM can access old messages via SearchChatHistory tool when needed
</text>
</g>
</svg>

After

Width:  |  Height:  |  Size: 5.4 KiB

150
docs/en/Community-Articles/2025-11-22-building-production-ready-llm-applications/images/mcp-architecture.svg

@ -0,0 +1,150 @@
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 900 500">
<!-- Background -->
<rect width="900" height="500" fill="#f8f9fa"/>
<!-- Title -->
<text x="450" y="30" font-family="Arial" font-size="20" font-weight="bold" text-anchor="middle" fill="#0066cc">
Model Context Protocol (MCP): Out-of-Process Tools
</text>
<!-- MCP Hosts -->
<text x="150" y="70" font-family="Arial" font-size="14" font-weight="bold" text-anchor="middle" fill="#333">
MCP Hosts (Clients)
</text>
<g id="semantic-kernel-host">
<rect x="50" y="80" width="200" height="70" fill="#0078d4" stroke="#005a9e" stroke-width="2" rx="5"/>
<text x="150" y="110" font-family="Arial" font-size="14" font-weight="bold" text-anchor="middle" fill="#fff">
Semantic Kernel
</text>
<text x="150" y="130" font-family="Arial" font-size="11" text-anchor="middle" fill="#fff">
(.NET Agent)
</text>
</g>
<g id="vscode-host">
<rect x="50" y="170" width="200" height="70" fill="#007acc" stroke="#005a8c" stroke-width="2" rx="5"/>
<text x="150" y="200" font-family="Arial" font-size="14" font-weight="bold" text-anchor="middle" fill="#fff">
VS Code Copilot
</text>
<text x="150" y="220" font-family="Arial" font-size="11" text-anchor="middle" fill="#fff">
(.vscode/mcp.json)
</text>
</g>
<g id="claude-host">
<rect x="50" y="260" width="200" height="70" fill="#d97706" stroke="#b45309" stroke-width="2" rx="5"/>
<text x="150" y="290" font-family="Arial" font-size="14" font-weight="bold" text-anchor="middle" fill="#fff">
Claude Desktop
</text>
<text x="150" y="310" font-family="Arial" font-size="11" text-anchor="middle" fill="#fff">
(Anthropic)
</text>
</g>
<!-- Arrows -->
<defs>
<marker id="arrow" markerWidth="10" markerHeight="10" refX="9" refY="3" orient="auto">
<polygon points="0 0, 10 3, 0 6" fill="#333"/>
</marker>
</defs>
<line x1="250" y1="115" x2="350" y2="200" stroke="#666" stroke-width="2" stroke-dasharray="5,5" marker-end="url(#arrow)"/>
<line x1="250" y1="205" x2="350" y2="200" stroke="#666" stroke-width="2" stroke-dasharray="5,5" marker-end="url(#arrow)"/>
<line x1="250" y1="295" x2="350" y2="200" stroke="#666" stroke-width="2" stroke-dasharray="5,5" marker-end="url(#arrow)"/>
<text x="290" y="160" font-family="Arial" font-size="10" text-anchor="middle" fill="#666">
stdio/http
</text>
<text x="290" y="175" font-family="Arial" font-size="10" text-anchor="middle" fill="#666">
JSON-RPC
</text>
<!-- MCP Protocol Layer -->
<rect x="350" y="160" width="200" height="80" fill="#00c853" stroke="#00a040" stroke-width="3" rx="5"/>
<text x="450" y="190" font-family="Arial" font-size="16" font-weight="bold" text-anchor="middle" fill="#fff">
MCP Protocol
</text>
<text x="450" y="210" font-family="Arial" font-size="11" text-anchor="middle" fill="#fff">
(Standardized Interface)
</text>
<text x="450" y="225" font-family="Arial" font-size="10" text-anchor="middle" fill="#fff">
ModelContextProtocol SDK
</text>
<!-- Arrows to servers -->
<line x1="550" y1="200" x2="620" y2="130" stroke="#333" stroke-width="2" marker-end="url(#arrow)"/>
<line x1="550" y1="200" x2="620" y2="205" stroke="#333" stroke-width="2" marker-end="url(#arrow)"/>
<line x1="550" y1="200" x2="620" y2="280" stroke="#333" stroke-width="2" marker-end="url(#arrow)"/>
<!-- MCP Servers -->
<text x="725" y="70" font-family="Arial" font-size="14" font-weight="bold" text-anchor="middle" fill="#333">
MCP Servers (Tools)
</text>
<g id="filesystem-server">
<rect x="620" y="90" width="210" height="80" fill="#9c27b0" stroke="#7b1fa2" stroke-width="2" rx="5"/>
<text x="725" y="120" font-family="Arial" font-size="13" font-weight="bold" text-anchor="middle" fill="#fff">
filesystem.mcp.exe
</text>
<text x="725" y="140" font-family="Arial" font-size="10" text-anchor="middle" fill="#fff">
ReadFile(), ListFiles()
</text>
<text x="725" y="155" font-family="Arial" font-size="10" text-anchor="middle" fill="#fff">
(.NET Console App)
</text>
</g>
<g id="database-server">
<rect x="620" y="180" width="210" height="80" fill="#1976d2" stroke="#0d47a1" stroke-width="2" rx="5"/>
<text x="725" y="210" font-family="Arial" font-size="13" font-weight="bold" text-anchor="middle" fill="#fff">
sqlserver.mcp.exe
</text>
<text x="725" y="230" font-family="Arial" font-size="10" text-anchor="middle" fill="#fff">
ExecuteQuery(), GetSchema()
</text>
<text x="725" y="245" font-family="Arial" font-size="10" text-anchor="middle" fill="#fff">
(.NET Console App)
</text>
</g>
<g id="github-server">
<rect x="620" y="270" width="210" height="80" fill="#333" stroke="#000" stroke-width="2" rx="5"/>
<text x="725" y="300" font-family="Arial" font-size="13" font-weight="bold" text-anchor="middle" fill="#fff">
github.mcp.js
</text>
<text x="725" y="320" font-family="Arial" font-size="10" text-anchor="middle" fill="#fff">
CreateIssue(), GetPR()
</text>
<text x="725" y="335" font-family="Arial" font-size="10" text-anchor="middle" fill="#fff">
(Node.js / TypeScript)
</text>
</g>
<!-- Benefits box -->
<rect x="50" y="370" width="800" height="120" fill="#e8f5e9" stroke="#388e3c" stroke-width="2" rx="5"/>
<text x="450" y="400" font-family="Arial" font-size="15" font-weight="bold" text-anchor="middle" fill="#1b5e20">
✅ MCP Benefits
</text>
<g id="benefit1">
<circle cx="80" cy="425" r="5" fill="#4caf50"/>
<text x="95" y="430" font-family="Arial" font-size="11" fill="#1b5e20">
<tspan font-weight="bold">Reusability:</tspan> Write once, use everywhere (SK, VS Code, Claude)
</text>
</g>
<g id="benefit2">
<circle cx="80" cy="450" r="5" fill="#4caf50"/>
<text x="95" y="455" font-family="Arial" font-size="11" fill="#1b5e20">
<tspan font-weight="bold">Independence:</tspan> MCP server runs separately, doesn't affect main app (out-of-process)
</text>
</g>
<g id="benefit3">
<circle cx="80" cy="475" r="5" fill="#4caf50"/>
<text x="95" y="480" font-family="Arial" font-size="11" fill="#1b5e20">
<tspan font-weight="bold">Language Agnostic:</tspan> Can be written in C#, Python, Node.js, everyone speaks same protocol
</text>
</g>
</svg>

After

Width:  |  Height:  |  Size: 6.3 KiB

135
docs/en/Community-Articles/2025-11-22-building-production-ready-llm-applications/images/multilingual-rag.svg

@ -0,0 +1,135 @@
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1000 400">
<!-- Background -->
<rect width="1000" height="400" fill="#f8f9fa"/>
<!-- Title -->
<text x="500" y="30" font-family="Arial" font-size="20" font-weight="bold" text-anchor="middle" fill="#0066cc">
Multilingual RAG: Query Translation Pattern
</text>
<!-- User Query (Turkish) -->
<rect x="50" y="80" width="180" height="80" fill="#fff3cd" stroke="#ffc107" stroke-width="2" rx="5"/>
<text x="140" y="110" font-family="Arial" font-size="14" font-weight="bold" text-anchor="middle" fill="#856404">
User Query
</text>
<text x="140" y="130" font-family="Arial" font-size="12" text-anchor="middle" fill="#856404">
🇹🇷 "Yazıcıyı ağa
</text>
<text x="140" y="145" font-family="Arial" font-size="12" text-anchor="middle" fill="#856404">
nasıl bağlarım?"
</text>
<!-- Arrow -->
<defs>
<marker id="arrow" markerWidth="10" markerHeight="10" refX="9" refY="3" orient="auto">
<polygon points="0 0, 10 3, 0 6" fill="#333"/>
</marker>
</defs>
<line x1="230" y1="120" x2="290" y2="120" stroke="#d32f2f" stroke-width="3" marker-end="url(#arrow)"/>
<text x="260" y="110" font-family="Arial" font-size="11" font-weight="bold" text-anchor="middle" fill="#d32f2f">
Tool 1
</text>
<!-- Translation Tool -->
<rect x="290" y="80" width="180" height="80" fill="#ffccbc" stroke="#d84315" stroke-width="2" rx="5"/>
<text x="380" y="105" font-family="Arial" font-size="13" font-weight="bold" text-anchor="middle" fill="#bf360c">
TranslationPlugin
</text>
<text x="380" y="125" font-family="Arial" font-size="11" text-anchor="middle" fill="#bf360c">
TranslateText()
</text>
<text x="380" y="145" font-family="Arial" font-size="10" text-anchor="middle" fill="#bf360c">
Target: English
</text>
<!-- Translated Query (English) -->
<line x1="470" y1="120" x2="530" y2="120" stroke="#388e3c" stroke-width="3" marker-end="url(#arrow)"/>
<text x="500" y="110" font-family="Arial" font-size="11" font-weight="bold" text-anchor="middle" fill="#1b5e20">
Tool 2
</text>
<rect x="530" y="80" width="180" height="80" fill="#c8e6c9" stroke="#388e3c" stroke-width="2" rx="5"/>
<text x="620" y="110" font-family="Arial" font-size="14" font-weight="bold" text-anchor="middle" fill="#1b5e20">
RAGPlugin
</text>
<text x="620" y="130" font-family="Arial" font-size="11" text-anchor="middle" fill="#1b5e20">
🇬🇧 "How do I connect
</text>
<text x="620" y="145" font-family="Arial" font-size="11" text-anchor="middle" fill="#1b5e20">
the printer to network?"
</text>
<!-- Vector DB -->
<line x1="710" y1="120" x2="770" y2="220" stroke="#1976d2" stroke-width="2" stroke-dasharray="5,5" marker-end="url(#arrow)"/>
<text x="740" y="170" font-family="Arial" font-size="10" text-anchor="middle" fill="#0d47a1">
Vector Search
</text>
<rect x="770" y="220" width="180" height="80" fill="#e3f2fd" stroke="#1976d2" stroke-width="2" rx="5"/>
<text x="860" y="245" font-family="Arial" font-size="13" font-weight="bold" text-anchor="middle" fill="#0d47a1">
Vector DB
</text>
<text x="860" y="265" font-family="Arial" font-size="10" text-anchor="middle" fill="#0d47a1">
(English Docs)
</text>
<text x="860" y="280" font-family="Arial" font-size="10" text-anchor="middle" fill="#0d47a1">
"Navigate to Settings
</text>
<text x="860" y="292" font-family="Arial" font-size="10" text-anchor="middle" fill="#0d47a1">
&gt; Network &gt; Wi-Fi..."
</text>
<!-- Retrieved Context -->
<line x1="770" y1="260" x2="710" y2="260" stroke="#1976d2" stroke-width="2" marker-end="url(#arrow)"/>
<rect x="530" y="220" width="180" height="80" fill="#bbdefb" stroke="#1976d2" stroke-width="2" rx="5"/>
<text x="620" y="245" font-family="Arial" font-size="12" font-weight="bold" text-anchor="middle" fill="#0d47a1">
Retrieved Context
</text>
<text x="620" y="265" font-family="Arial" font-size="10" text-anchor="middle" fill="#0d47a1">
🇬🇧 English text
</text>
<text x="620" y="280" font-family="Arial" font-size="10" text-anchor="middle" fill="#0d47a1">
(Manual excerpt)
</text>
<!-- Arrow to LLM -->
<line x1="530" y1="260" x2="470" y2="260" stroke="#9c27b0" stroke-width="3" marker-end="url(#arrow)"/>
<!-- LLM Final Generation -->
<rect x="290" y="220" width="180" height="80" fill="#f3e5f5" stroke="#7b1fa2" stroke-width="2" rx="5"/>
<text x="380" y="245" font-family="Arial" font-size="13" font-weight="bold" text-anchor="middle" fill="#4a148c">
LLM (GPT-5)
</text>
<text x="380" y="265" font-family="Arial" font-size="10" text-anchor="middle" fill="#4a148c">
Context: [English]
</text>
<text x="380" y="280" font-family="Arial" font-size="10" text-anchor="middle" fill="#4a148c">
Generates: [Turkish Response]
</text>
<!-- Arrow to user -->
<line x1="290" y1="260" x2="230" y2="260" stroke="#9c27b0" stroke-width="3" marker-end="url(#arrow)"/>
<!-- Final Answer -->
<rect x="50" y="220" width="180" height="80" fill="#e1bee7" stroke="#7b1fa2" stroke-width="2" rx="5"/>
<text x="140" y="245" font-family="Arial" font-size="13" font-weight="bold" text-anchor="middle" fill="#4a148c">
Response to User
</text>
<text x="140" y="265" font-family="Arial" font-size="11" text-anchor="middle" fill="#4a148c">
🇹🇷 "Ayarlar &gt;&gt;
</text>
<text x="140" y="280" font-family="Arial" font-size="11" text-anchor="middle" fill="#4a148c">
Wi-Fi bölümüne gidin..."
</text>
<!-- Benefit note -->
<rect x="50" y="320" width="900" height="60" fill="#fff9c4" stroke="#f57f17" stroke-width="2" rx="5"/>
<text x="500" y="345" font-family="Arial" font-size="13" font-weight="bold" text-anchor="middle" fill="#f57f17">
✅ Benefit: Single language (English) docs, multi-language query support
</text>
<text x="500" y="365" font-family="Arial" font-size="11" text-anchor="middle" fill="#f57f17">
Tool Chain: TranslationPlugin → RAGPlugin → LLM Final Generation (Original language)
</text>
</svg>

After

Width:  |  Height:  |  Size: 6.0 KiB

112
docs/en/Community-Articles/2025-11-22-building-production-ready-llm-applications/images/pgvector-integration.svg

@ -0,0 +1,112 @@
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 950 400">
<!-- Background -->
<rect width="950" height="400" fill="#f8f9fa"/>
<!-- Title -->
<text x="475" y="30" font-family="Arial" font-size="20" font-weight="bold" text-anchor="middle" fill="#0066cc">
PostgreSQL + pgvector: Integrated RAG with EF Core
</text>
<!-- .NET App -->
<rect x="50" y="80" width="200" height="80" fill="#0078d4" stroke="#005a9e" stroke-width="2" rx="5"/>
<text x="150" y="115" font-family="Arial" font-size="16" font-weight="bold" text-anchor="middle" fill="#fff">
.NET Application
</text>
<text x="150" y="135" font-family="Arial" font-size="12" text-anchor="middle" fill="#fff">
(EF Core DbContext)
</text>
<!-- Arrow -->
<defs>
<marker id="arrow" markerWidth="10" markerHeight="10" refX="9" refY="3" orient="auto">
<polygon points="0 0, 10 3, 0 6" fill="#333"/>
</marker>
</defs>
<line x1="250" y1="120" x2="330" y2="120" stroke="#333" stroke-width="2" marker-end="url(#arrow)"/>
<text x="290" y="110" font-family="Arial" font-size="11" text-anchor="middle" fill="#666">
LINQ Query
</text>
<!-- Pgvector.EntityFrameworkCore -->
<rect x="330" y="80" width="240" height="80" fill="#00c853" stroke="#00a040" stroke-width="3" rx="5"/>
<text x="450" y="110" font-family="Arial" font-size="15" font-weight="bold" text-anchor="middle" fill="#fff">
Pgvector.EntityFrameworkCore
</text>
<text x="450" y="130" font-family="Arial" font-size="11" text-anchor="middle" fill="#fff">
CosineDistance(), L2Distance()
</text>
<text x="450" y="145" font-family="Arial" font-size="11" text-anchor="middle" fill="#fff">
EF Core Extensions
</text>
<!-- Arrow -->
<line x1="570" y1="120" x2="650" y2="120" stroke="#333" stroke-width="2" marker-end="url(#arrow)"/>
<text x="610" y="110" font-family="Arial" font-size="11" text-anchor="middle" fill="#666">
SQL Query
</text>
<!-- PostgreSQL -->
<rect x="650" y="60" width="250" height="120" fill="#336791" stroke="#1a4a6d" stroke-width="2" rx="5"/>
<text x="775" y="95" font-family="Arial" font-size="16" font-weight="bold" text-anchor="middle" fill="#fff">
PostgreSQL + pgvector
</text>
<!-- Table visualization -->
<g id="table">
<rect x="670" y="110" width="210" height="60" fill="#4a7ba7" stroke="#fff" stroke-width="1" rx="3"/>
<!-- Header -->
<text x="685" y="127" font-family="Arial" font-size="10" font-weight="bold" fill="#fff">id</text>
<text x="725" y="127" font-family="Arial" font-size="10" font-weight="bold" fill="#fff">content</text>
<text x="800" y="127" font-family="Arial" font-size="10" font-weight="bold" fill="#fff">embedding</text>
<!-- Rows -->
<line x1="670" y1="130" x2="880" y2="130" stroke="#fff" stroke-width="1"/>
<text x="685" y="145" font-family="Arial" font-size="9" fill="#fff">1</text>
<text x="725" y="145" font-family="Arial" font-size="9" fill="#fff">Contoso...</text>
<text x="800" y="145" font-family="Arial" font-size="9" fill="#fff">[0.2, -0.1,...]</text>
<text x="685" y="160" font-family="Arial" font-size="9" fill="#fff">2</text>
<text x="725" y="160" font-family="Arial" font-size="9" fill="#fff">Revenue...</text>
<text x="800" y="160" font-family="Arial" font-size="9" fill="#fff">[0.5, 0.3,...]</text>
</g>
<!-- Benefits Box -->
<rect x="50" y="220" width="850" height="150" fill="#e8f5e9" stroke="#388e3c" stroke-width="2" rx="5"/>
<text x="475" y="250" font-family="Arial" font-size="16" font-weight="bold" text-anchor="middle" fill="#1b5e20">
✅ Benefits
</text>
<g id="benefit1">
<circle cx="80" cy="275" r="5" fill="#4caf50"/>
<text x="95" y="280" font-family="Arial" font-size="12" fill="#1b5e20">
<tspan font-weight="bold">Existing SQL Knowledge:</tspan> PostgreSQL is already a familiar database
</text>
</g>
<g id="benefit2">
<circle cx="80" cy="300" r="5" fill="#4caf50"/>
<text x="95" y="305" font-family="Arial" font-size="12" fill="#1b5e20">
<tspan font-weight="bold">EF Core Integration:</tspan> Vector queries with LINQ (.OrderBy(), .Where())
</text>
</g>
<g id="benefit3">
<circle cx="80" cy="325" r="5" fill="#4caf50"/>
<text x="95" y="330" font-family="Arial" font-size="12" fill="#1b5e20">
<tspan font-weight="bold">Metadata JOIN:</tspan> Vector + Relational data in same query (tenant_id, user_id...)
</text>
</g>
<g id="benefit4">
<circle cx="80" cy="350" r="5" fill="#4caf50"/>
<text x="95" y="355" font-family="Arial" font-size="12" fill="#1b5e20">
<tspan font-weight="bold">ACID Compliant:</tspan> Transaction support (rollback, commit)
</text>
</g>
<!-- Code Example Box -->
<rect x="50" y="390" width="850" height="10" fill="none" stroke="none"/>
</svg>

After

Width:  |  Height:  |  Size: 4.8 KiB

118
docs/en/Community-Articles/2025-11-22-building-production-ready-llm-applications/images/rag-parent-child.svg

@ -0,0 +1,118 @@
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1000 500">
<!-- Background -->
<rect width="1000" height="500" fill="#f8f9fa"/>
<!-- Title -->
<text x="500" y="30" font-family="Arial" font-size="20" font-weight="bold" text-anchor="middle" fill="#0066cc">
Parent-Child RAG Pattern: Search Small, Respond Large
</text>
<!-- Original Document -->
<rect x="50" y="60" width="180" height="200" fill="#e3f2fd" stroke="#1976d2" stroke-width="2" rx="5"/>
<text x="140" y="85" font-family="Arial" font-size="14" font-weight="bold" text-anchor="middle" fill="#0d47a1">Original Document</text>
<!-- Parent chunks -->
<rect x="60" y="100" width="160" height="50" fill="#90caf9" stroke="#1976d2" stroke-width="1" rx="3"/>
<text x="140" y="125" font-family="Arial" font-size="11" text-anchor="middle" fill="#0d47a1">Parent 1 (800 token)</text>
<rect x="60" y="160" width="160" height="50" fill="#90caf9" stroke="#1976d2" stroke-width="1" rx="3"/>
<text x="140" y="185" font-family="Arial" font-size="11" text-anchor="middle" fill="#0d47a1">Parent 2 (800 token)</text>
<rect x="60" y="220" width="160" height="30" fill="#90caf9" stroke="#1976d2" stroke-width="1" rx="3"/>
<text x="140" y="237" font-family="Arial" font-size="11" text-anchor="middle" fill="#0d47a1">Parent 3...</text>
<!-- Arrow to Child chunks -->
<defs>
<marker id="arrowBlue" markerWidth="10" markerHeight="10" refX="9" refY="3" orient="auto">
<polygon points="0 0, 10 3, 0 6" fill="#1976d2"/>
</marker>
<marker id="arrowGreen" markerWidth="10" markerHeight="10" refX="9" refY="3" orient="auto">
<polygon points="0 0, 10 3, 0 6" fill="#388e3c"/>
</marker>
<marker id="arrowRed" markerWidth="10" markerHeight="10" refX="9" refY="3" orient="auto">
<polygon points="0 0, 10 3, 0 6" fill="#d32f2f"/>
</marker>
</defs>
<line x1="230" y1="125" x2="300" y2="125" stroke="#1976d2" stroke-width="2" marker-end="url(#arrowBlue)"/>
<!-- Child Chunks (Vector DB) -->
<rect x="300" y="60" width="200" height="200" fill="#c8e6c9" stroke="#388e3c" stroke-width="2" rx="5"/>
<text x="400" y="85" font-family="Arial" font-size="14" font-weight="bold" text-anchor="middle" fill="#1b5e20">Child Chunks</text>
<text x="400" y="100" font-family="Arial" font-size="10" text-anchor="middle" fill="#1b5e20">(In Vector DB)</text>
<!-- Child chunk items -->
<g id="child1">
<rect x="310" y="110" width="180" height="25" fill="#a5d6a7" stroke="#66bb6a" stroke-width="1" rx="3"/>
<text x="400" y="126" font-family="Arial" font-size="10" text-anchor="middle" fill="#1b5e20">Child 1.1 (100 token) [ParentID=1]</text>
</g>
<g id="child2">
<rect x="310" y="140" width="180" height="25" fill="#a5d6a7" stroke="#66bb6a" stroke-width="1" rx="3"/>
<text x="400" y="156" font-family="Arial" font-size="10" text-anchor="middle" fill="#1b5e20">Child 1.2 (100 token) [ParentID=1]</text>
</g>
<g id="child3">
<rect x="310" y="170" width="180" height="25" fill="#a5d6a7" stroke="#66bb6a" stroke-width="1" rx="3"/>
<text x="400" y="186" font-family="Arial" font-size="10" text-anchor="middle" fill="#1b5e20">Child 1.3 (100 token) [ParentID=1]</text>
</g>
<g id="child4">
<rect x="310" y="200" width="180" height="25" fill="#a5d6a7" stroke="#66bb6a" stroke-width="1" rx="3"/>
<text x="400" y="216" font-family="Arial" font-size="10" text-anchor="middle" fill="#1b5e20">Child 2.1 (100 token) [ParentID=2]</text>
</g>
<g id="child5">
<rect x="310" y="230" width="180" height="20" fill="#a5d6a7" stroke="#66bb6a" stroke-width="1" rx="3"/>
<text x="400" y="243" font-family="Arial" font-size="10" text-anchor="middle" fill="#1b5e20">Child 2.2...</text>
</g>
<!-- User Query -->
<rect x="50" y="320" width="180" height="80" fill="#fff3cd" stroke="#ffc107" stroke-width="2" rx="5"/>
<text x="140" y="345" font-family="Arial" font-size="14" font-weight="bold" text-anchor="middle" fill="#856404">User Query</text>
<text x="140" y="365" font-family="Arial" font-size="11" text-anchor="middle" fill="#856404">"What was Contoso's</text>
<text x="140" y="380" font-family="Arial" font-size="11" text-anchor="middle" fill="#856404">2024 revenue?"</text>
<!-- Arrow to Vector Search -->
<line x1="230" y1="360" x2="300" y2="200" stroke="#388e3c" stroke-width="2" stroke-dasharray="5,5" marker-end="url(#arrowGreen)"/>
<text x="265" y="270" font-family="Arial" font-size="11" fill="#1b5e20">1. Vector Search</text>
<text x="265" y="285" font-family="Arial" font-size="11" fill="#1b5e20">(On Child chunks)</text>
<!-- Best Match -->
<rect x="520" y="150" width="180" height="60" fill="#ffccbc" stroke="#ff5722" stroke-width="2" rx="5"/>
<text x="610" y="175" font-family="Arial" font-size="12" font-weight="bold" text-anchor="middle" fill="#bf360c">Best Match</text>
<text x="610" y="195" font-family="Arial" font-size="10" text-anchor="middle" fill="#bf360c">Child 1.2 (Score: 0.95)</text>
<line x1="500" y1="152" x2="520" y2="180" stroke="#ff5722" stroke-width="2" marker-end="url(#arrowRed)"/>
<!-- Arrow to Parent Retrieval -->
<line x1="700" y1="180" x2="750" y2="180" stroke="#d32f2f" stroke-width="2" marker-end="url(#arrowRed)"/>
<text x="690" y="230" font-family="Arial" font-size="11" fill="#b71c1c">2. Fetch Parent via</text>
<text x="690" y="240" font-family="Arial" font-size="11" fill="#b71c1c">ParentID</text>
<!-- Retrieved Parent -->
<rect x="750" y="140" width="200" height="80" fill="#ffebee" stroke="#d32f2f" stroke-width="3" rx="5"/>
<text x="850" y="165" font-family="Arial" font-size="13" font-weight="bold" text-anchor="middle" fill="#b71c1c">Retrieved Parent Chunk</text>
<text x="850" y="185" font-family="Arial" font-size="10" text-anchor="middle" fill="#b71c1c">Parent 1 (800 tokens)</text>
<text x="850" y="200" font-family="Arial" font-size="10" text-anchor="middle" fill="#b71c1c">Full context + details</text>
<!-- Arrow to LLM -->
<line x1="850" y1="220" x2="850" y2="290" stroke="#0066cc" stroke-width="2" marker-end="url(#arrowBlue)"/>
<text x="880" y="255" font-family="Arial" font-size="11" fill="#0d47a1">3. Send to LLM</text>
<!-- LLM Response -->
<rect x="750" y="290" width="200" height="100" fill="#e3f2fd" stroke="#1976d2" stroke-width="3" rx="5"/>
<text x="850" y="320" font-family="Arial" font-size="14" font-weight="bold" text-anchor="middle" fill="#0d47a1">LLM Response</text>
<text x="850" y="340" font-family="Arial" font-size="10" text-anchor="middle" fill="#0d47a1">"Contoso's 2024</text>
<text x="850" y="355" font-family="Arial" font-size="10" text-anchor="middle" fill="#0d47a1">revenue was $2.5 billion</text>
<text x="850" y="370" font-family="Arial" font-size="10" text-anchor="middle" fill="#0d47a1">as reported."</text>
<!-- Benefit Box -->
<rect x="50" y="430" width="900" height="60" fill="#d1f2eb" stroke="#00695c" stroke-width="2" rx="5"/>
<text x="500" y="455" font-family="Arial" font-size="13" font-weight="bold" text-anchor="middle" fill="#004d40">
✅ Benefit: Precise search (Child) + Rich context (Parent) = Optimal quality
</text>
<text x="500" y="475" font-family="Arial" font-size="11" text-anchor="middle" fill="#004d40">
Alternative: Only large chunks → Lower precision | Only small chunks → Insufficient context
</text>
</svg>

After

Width:  |  Height:  |  Size: 7.2 KiB

60
docs/en/Community-Articles/2025-11-22-building-production-ready-llm-applications/images/reasoning-effort-diagram.svg

@ -0,0 +1,60 @@
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 800 300">
<!-- Background -->
<rect width="800" height="300" fill="#f8f9fa"/>
<!-- Title -->
<text x="400" y="30" font-family="Arial" font-size="20" font-weight="bold" text-anchor="middle" fill="#0066cc">
ReasoningEffortLevel: Cost vs Quality
</text>
<!-- Axis -->
<line x1="50" y1="250" x2="750" y2="250" stroke="#333" stroke-width="2"/>
<line x1="50" y1="250" x2="50" y2="50" stroke="#333" stroke-width="2"/>
<!-- Y-axis labels -->
<text x="40" y="60" font-family="Arial" font-size="12" text-anchor="end" fill="#666">High</text>
<text x="40" y="155" font-family="Arial" font-size="12" text-anchor="end" fill="#666">Medium</text>
<text x="40" y="250" font-family="Arial" font-size="12" text-anchor="end" fill="#666">Low</text>
<!-- Y-axis title -->
<text x="20" y="150" font-family="Arial" font-size="14" font-weight="bold" text-anchor="middle" fill="#333" transform="rotate(-90 20 150)">
Quality / Cost
</text>
<!-- Effort levels -->
<g id="minimal">
<rect x="100" y="200" width="120" height="50" fill="#90caf9" stroke="#1976d2" stroke-width="2" rx="5"/>
<text x="160" y="225" font-family="Arial" font-size="14" font-weight="bold" text-anchor="middle" fill="#0d47a1">Minimal</text>
<text x="160" y="242" font-family="Arial" font-size="10" text-anchor="middle" fill="#0d47a1">Fast + Cheap</text>
</g>
<g id="low">
<rect x="250" y="170" width="120" height="80" fill="#81c784" stroke="#388e3c" stroke-width="2" rx="5"/>
<text x="310" y="205" font-family="Arial" font-size="14" font-weight="bold" text-anchor="middle" fill="#1b5e20">Low</text>
<text x="310" y="222" font-family="Arial" font-size="10" text-anchor="middle" fill="#1b5e20">Simple Queries</text>
</g>
<g id="medium">
<rect x="400" y="120" width="120" height="130" fill="#ffb74d" stroke="#f57c00" stroke-width="2" rx="5"/>
<text x="460" y="175" font-family="Arial" font-size="14" font-weight="bold" text-anchor="middle" fill="#e65100">Medium</text>
<text x="460" y="192" font-family="Arial" font-size="10" text-anchor="middle" fill="#e65100">Standard</text>
</g>
<g id="high">
<rect x="550" y="60" width="120" height="190" fill="#e57373" stroke="#d32f2f" stroke-width="2" rx="5"/>
<text x="610" y="145" font-family="Arial" font-size="14" font-weight="bold" text-anchor="middle" fill="#b71c1c">High</text>
<text x="610" y="162" font-family="Arial" font-size="10" text-anchor="middle" fill="#b71c1c">Complex</text>
<text x="610" y="179" font-family="Arial" font-size="10" text-anchor="middle" fill="#b71c1c">Coding</text>
</g>
<!-- Cost arrow -->
<defs>
<marker id="arrowhead" markerWidth="10" markerHeight="10" refX="9" refY="3" orient="auto">
<polygon points="0 0, 10 3, 0 6" fill="#d32f2f"/>
</marker>
</defs>
<line x1="150" y1="270" x2="650" y2="270" stroke="#d32f2f" stroke-width="2" marker-end="url(#arrowhead)"/>
<text x="400" y="290" font-family="Arial" font-size="12" font-style="italic" text-anchor="middle" fill="#d32f2f">
Increasing Cost (Reasoning Tokens ↑)
</text>
</svg>

After

Width:  |  Height:  |  Size: 3.1 KiB

149
docs/en/Community-Articles/2025-11-22-building-production-ready-llm-applications/images/svg-diagram-example.svg

@ -0,0 +1,149 @@
<svg viewBox="0 0 800 400" xmlns="http://www.w3.org/2000/svg">
<!-- Background -->
<rect width="800" height="400" fill="#f0f4f8"/>
<!-- Title -->
<text x="400" y="30" font-family="Arial, sans-serif" font-size="20" font-weight="bold" fill="#1e3a8a" text-anchor="middle">
PostgreSQL + pgvector Architecture
</text>
<!-- .NET Application -->
<g id="dotnet-app">
<rect x="50" y="80" width="140" height="240" rx="10" fill="#3b82f6" stroke="#1e40af" stroke-width="2"/>
<text x="120" y="110" font-family="Arial, sans-serif" font-size="16" font-weight="bold" fill="white" text-anchor="middle">
.NET Application
</text>
<!-- API Layer -->
<rect x="65" y="130" width="110" height="50" rx="5" fill="#60a5fa" stroke="#2563eb" stroke-width="1.5"/>
<text x="120" y="160" font-family="Arial, sans-serif" font-size="13" fill="white" text-anchor="middle">
Web API /
</text>
<text x="120" y="175" font-family="Arial, sans-serif" font-size="13" fill="white" text-anchor="middle">
Controllers
</text>
<!-- Business Logic -->
<rect x="65" y="190" width="110" height="50" rx="5" fill="#60a5fa" stroke="#2563eb" stroke-width="1.5"/>
<text x="120" y="215" font-family="Arial, sans-serif" font-size="13" fill="white" text-anchor="middle">
Business Logic /
</text>
<text x="120" y="230" font-family="Arial, sans-serif" font-size="13" fill="white" text-anchor="middle">
Services
</text>
<!-- Data Layer -->
<rect x="65" y="250" width="110" height="50" rx="5" fill="#60a5fa" stroke="#2563eb" stroke-width="1.5"/>
<text x="120" y="275" font-family="Arial, sans-serif" font-size="13" fill="white" text-anchor="middle">
Data Access
</text>
<text x="120" y="290" font-family="Arial, sans-serif" font-size="13" fill="white" text-anchor="middle">
Layer
</text>
</g>
<!-- Arrow 1: .NET to EF Core -->
<defs>
<marker id="arrowblue" markerWidth="10" markerHeight="10" refX="9" refY="3" orient="auto" markerUnits="strokeWidth">
<path d="M0,0 L0,6 L9,3 z" fill="#1e40af" />
</marker>
</defs>
<line x1="190" y1="200" x2="260" y2="200" stroke="#1e40af" stroke-width="3" marker-end="url(#arrowblue)"/>
<text x="225" y="190" font-family="Arial, sans-serif" font-size="11" fill="#1e3a8a" text-anchor="middle">ORM</text>
<!-- EF Core -->
<g id="ef-core">
<rect x="260" y="150" width="140" height="100" rx="10" fill="#2563eb" stroke="#1e40af" stroke-width="2"/>
<text x="330" y="180" font-family="Arial, sans-serif" font-size="16" font-weight="bold" fill="white" text-anchor="middle">
Entity Framework
</text>
<text x="330" y="200" font-family="Arial, sans-serif" font-size="16" font-weight="bold" fill="white" text-anchor="middle">
Core
</text>
<text x="330" y="225" font-family="Arial, sans-serif" font-size="12" fill="#bfdbfe" text-anchor="middle">
DbContext
</text>
<text x="330" y="240" font-family="Arial, sans-serif" font-size="12" fill="#bfdbfe" text-anchor="middle">
LINQ Queries
</text>
</g>
<!-- Arrow 2: EF Core to PostgreSQL -->
<line x1="400" y1="200" x2="470" y2="200" stroke="#1e40af" stroke-width="3" marker-end="url(#arrowblue)"/>
<text x="435" y="190" font-family="Arial, sans-serif" font-size="11" fill="#1e3a8a" text-anchor="middle">Npgsql</text>
<!-- PostgreSQL -->
<g id="postgresql">
<rect x="470" y="80" width="140" height="240" rx="10" fill="#1e40af" stroke="#1e3a8a" stroke-width="2"/>
<text x="540" y="110" font-family="Arial, sans-serif" font-size="16" font-weight="bold" fill="white" text-anchor="middle">
PostgreSQL
</text>
<!-- Tables -->
<rect x="485" y="130" width="110" height="50" rx="5" fill="#3b82f6" stroke="#2563eb" stroke-width="1.5"/>
<text x="540" y="155" font-family="Arial, sans-serif" font-size="13" fill="white" text-anchor="middle">
Relational Tables
</text>
<text x="540" y="170" font-family="Arial, sans-serif" font-size="11" fill="#bfdbfe" text-anchor="middle">
(Standard Data)
</text>
<!-- pgvector Extension -->
<rect x="485" y="190" width="110" height="50" rx="5" fill="#60a5fa" stroke="#3b82f6" stroke-width="1.5"/>
<text x="540" y="215" font-family="Arial, sans-serif" font-size="13" font-weight="bold" fill="white" text-anchor="middle">
pgvector
</text>
<text x="540" y="230" font-family="Arial, sans-serif" font-size="11" fill="white" text-anchor="middle">
Vector Storage
</text>
<!-- Vector Search -->
<rect x="485" y="250" width="110" height="50" rx="5" fill="#93c5fd" stroke="#60a5fa" stroke-width="1.5"/>
<text x="540" y="270" font-family="Arial, sans-serif" font-size="12" fill="#1e3a8a" text-anchor="middle">
Vector Search
</text>
<text x="540" y="285" font-family="Arial, sans-serif" font-size="11" fill="#1e40af" text-anchor="middle">
Similarity Queries
</text>
<text x="540" y="297" font-family="Arial, sans-serif" font-size="10" fill="#1e40af" text-anchor="middle">
(&lt;=&gt;, &lt;-&gt;, &lt;#&gt;)
</text>
</g>
<!-- Arrow 3: Vector Operations -->
<path d="M 540 240 L 540 250" stroke="#1e40af" stroke-width="2" marker-end="url(#arrowblue)"/>
<!-- Vector Search Results -->
<g id="results">
<rect x="640" y="160" width="130" height="80" rx="8" fill="#dbeafe" stroke="#3b82f6" stroke-width="2" stroke-dasharray="5,5"/>
<text x="705" y="185" font-family="Arial, sans-serif" font-size="13" font-weight="bold" fill="#1e40af" text-anchor="middle">
Search Results
</text>
<text x="705" y="205" font-family="Arial, sans-serif" font-size="11" fill="#1e40af" text-anchor="middle">
• Embeddings
</text>
<text x="705" y="220" font-family="Arial, sans-serif" font-size="11" fill="#1e40af" text-anchor="middle">
• Similarity Score
</text>
<text x="705" y="235" font-family="Arial, sans-serif" font-size="11" fill="#1e40af" text-anchor="middle">
• Ranked Results
</text>
</g>
<!-- Arrow to Results -->
<line x1="610" y1="200" x2="640" y2="200" stroke="#3b82f6" stroke-width="2" marker-end="url(#arrowblue)" stroke-dasharray="5,5"/>
<!-- Legend -->
<g id="legend">
<text x="50" y="360" font-family="Arial, sans-serif" font-size="12" font-weight="bold" fill="#1e3a8a">
Data Flow:
</text>
<text x="50" y="380" font-family="Arial, sans-serif" font-size="11" fill="#334155">
1. .NET → EF Core → PostgreSQL (Data Operations)
</text>
<text x="420" y="380" font-family="Arial, sans-serif" font-size="11" fill="#334155">
2. Vector Similarity Search with pgvector
</text>
</g>
</svg>

After

Width:  |  Height:  |  Size: 6.6 KiB

414
docs/en/Community-Articles/2025-11-22-building-production-ready-llm-applications/post.md

@ -0,0 +1,414 @@
# Building Production-Ready LLM Applications with .NET: A Practical Guide
Large Language Models (LLMs) have evolved rapidly, and integrating them into production .NET applications requires staying current with the latest approaches. In this article, I'll share practical tips and patterns I've learned while building LLM-powered systems, covering everything from API changes in GPT-5 to implementing efficient RAG (Retrieval Augmented Generation) architectures.
Whether you're building a chatbot, a knowledge base assistant, or integrating AI into your enterprise applications, these production-tested insights will help you avoid common pitfalls and build more reliable systems.
## The Temperature Paradigm Shift: GPT-5 Changes Everything
If you've been working with GPT-4 or earlier models, you're familiar with the `temperature` and `top_p` parameters for controlling response randomness. **Here's the critical update**: GPT-5 no longer supports these parameters!
### The Old Way (GPT-4)
```csharp
var chatRequest = new ChatOptions
{
Temperature = 0.7, // ✅ Worked with GPT-4
TopP = 0.9 // ✅ Worked with GPT-4
};
```
### The New Way (GPT-5)
```csharp
var chatRequest = new ChatOptions
{
RawRepresentationFactory = (client => new ChatCompletionOptions()
{
#pragma warning disable OPENAI001
ReasoningEffortLevel = "minimal",
#pragma warning restore OPENAI001
})
};
```
**Why the change?** GPT-5 incorporates an internal reasoning and verification process. Instead of controlling randomness, you now specify how much computational effort the model should invest in reasoning through the problem.
![Reasoning Effort Levels](images/reasoning-effort-diagram.svg)
### Choosing the Right Reasoning Level
- **Low**: Quick responses for simple queries (e.g., "What's the capital of France?")
- **Medium**: Balanced approach for most use cases
- **High**: Complex reasoning tasks (e.g., code generation, multi-step problem solving)
> **Pro Tip**: Reasoning tokens are included in your API costs. Use "High" only when necessary to optimize your budget.
## System Prompts: The "Lost in the Middle" Problem
Here's a critical insight that can save you hours of debugging: **Important rules must be repeated at the END of your prompt!**
### ❌ What Doesn't Work
```
You are a helpful assistant.
RULE: Never share passwords or sensitive information.
[User Input]
```
### ✅ What Actually Works
```
You are a helpful assistant.
RULE: Never share passwords or sensitive information.
[User Input]
⚠️ REMINDER: Apply the rules above strictly, ESPECIALLY regarding passwords.
```
**Why?** LLMs suffer from the "Lost in the Middle" phenomenon—they pay more attention to the beginning and end of the context window. Critical instructions buried in the middle are often ignored.
## RAG Architecture: The Parent-Child Pattern
Retrieval Augmented Generation (RAG) is essential for grounding LLM responses in your own data. The most effective pattern I've found is the **Parent-Child approach**.
![RAG Parent-Child Architecture](images/rag-parent-child.svg)
### How It Works
1. **Split documents into hierarchies**:
- **Parent chunks**: Large sections (1000-2000 tokens) for context
- **Child chunks**: Small segments (200-500 tokens) for precise retrieval
2. **Store both in vector database** with references
3. **Query flow**:
- Search using child chunks (higher precision)
- Return parent chunks to LLM (richer context)
### The Overlap Strategy
Always use overlapping chunks to prevent information loss at boundaries!
```
Chunk 1: Token 0-500
Chunk 2: Token 400-900 ← 100 token overlap
Chunk 3: Token 800-1300 ← 100 token overlap
```
**Standard recommendation**: 10-20% overlap (for 500 tokens, use 50-100 token overlap)
### Implementation with Semantic Kernel
```csharp
using Microsoft.SemanticKernel.Text;
var chunks = TextChunker.SplitPlainTextParagraphs(
documentText,
maxTokensPerParagraph: 500,
overlapTokens: 50
);
foreach (var chunk in chunks)
{
var embedding = await embeddingService.GenerateEmbeddingAsync(chunk);
await vectorDb.StoreAsync(chunk, embedding);
}
```
## PostgreSQL + pgvector: The Pragmatic Choice
For .NET developers, choosing a vector database can be overwhelming. After evaluating multiple options, **PostgreSQL with pgvector** is the most practical choice for most scenarios.
![pgvector Integration](images/pgvector-integration.svg)
### Why pgvector?
**Use existing SQL knowledge** - No new query language to learn
**EF Core integration** - Works with your existing data access layer
**JOIN with metadata** - Combine vector search with traditional queries
**WHERE clause filtering** - Filter by tenant, user, date, etc.
**ACID compliance** - Transaction support for data consistency
**No separate infrastructure** - One database for everything
### Setting Up pgvector with EF Core
First, install the NuGet package:
```bash
dotnet add package Pgvector.EntityFrameworkCore
```
Define your entity:
```csharp
using Pgvector;
using Pgvector.EntityFrameworkCore;
public class DocumentChunk
{
public Guid Id { get; set; }
public string Content { get; set; }
public Vector Embedding { get; set; } // 👈 pgvector type
public Guid ParentChunkId { get; set; }
public DateTime CreatedAt { get; set; }
}
```
Configure in DbContext:
```csharp
protected override void OnModelCreating(ModelBuilder builder)
{
builder.HasPostgresExtension("vector");
builder.Entity<DocumentChunk>()
.Property(e => e.Embedding)
.HasColumnType("vector(1536)"); // 👈 OpenAI embedding dimension
builder.Entity<DocumentChunk>()
.HasIndex(e => e.Embedding)
.HasMethod("hnsw") // 👈 Fast approximate search
.HasOperators("vector_cosine_ops");
}
```
### Performing Vector Search
```csharp
using Pgvector.EntityFrameworkCore;
public async Task<List<DocumentChunk>> SearchAsync(string query)
{
// 1. Convert query to embedding
var queryVector = await _embeddingService.GetEmbeddingAsync(query);
// 2. Search
return await _context.DocumentChunks
.OrderBy(c => c.Embedding.L2Distance(queryVector)) // 👈 Lower is better
.Take(5)
.ToListAsync();
}
```
**Source**: [Pgvector.NET on GitHub](https://github.com/pgvector/pgvector-dotnet?tab=readme-ov-file#entity-framework-core)
## Smart Tool Usage: Make RAG a Tool, Not a Tax
A common mistake is calling RAG on every single user message. This wastes tokens and money. Instead, **make RAG a tool** and let the LLM decide when to use it.
### ❌ Expensive Approach
```csharp
// Always call RAG, even for "Hello"
var context = await PerformRAG(userMessage);
var response = await chatClient.CompleteAsync($"{context}\n\n{userMessage}");
```
### ✅ Smart Approach
```csharp
[KernelFunction]
[Description("Search the company knowledge base for information")]
public async Task<string> SearchKnowledgeBase(
[Description("The search query")] string query)
{
var results = await _vectorDb.SearchAsync(query);
return string.Join("\n---\n", results.Select(r => r.Content));
}
```
The LLM will call `SearchKnowledgeBase` only when needed:
- "Hello" → No tool call
- "What was our 2024 revenue?" → Calls tool
- "Tell me a joke" → No tool call
## Multilingual RAG: Query Translation Strategy
When your documents are in one language (e.g., English) but users query in another (e.g., Turkish), you need a translation strategy.
![Multilingual RAG Architecture](images/multilingual-rag.svg)
### Solution Options
**Option 1**: Use an LLM that automatically calls tools in English
- Many modern LLMs can do this if properly instructed
**Option 2**: Tool chain approach
```csharp
[KernelFunction]
[Description("Translate text to English")]
public async Task<string> TranslateToEnglish(string text)
{
// Translation logic
}
[KernelFunction]
[Description("Search knowledge base (English only)")]
public async Task<string> SearchKnowledgeBase(string englishQuery)
{
// Search logic
}
```
The LLM will:
1. Call `TranslateToEnglish("2024 geliri nedir?")`
2. Get "What was 2024 revenue?"
3. Call `SearchKnowledgeBase("What was 2024 revenue?")`
4. Return results and respond in Turkish
## Model Context Protocol (MCP): Beyond In-Process Tools
Microsoft and Anthropic recently released official C# SDKs for the Model Context Protocol (MCP). This is a game-changer for tool reusability.
![MCP Architecture](images/mcp-architecture.svg)
### MCP vs. Semantic Kernel Plugins
| Feature | SK Plugins | MCP Servers |
|---------|-----------|-------------|
| **Process** | In-process | Out-of-process (stdio/http) |
| **Reusability** | Application-specific | Cross-application |
| **Examples** | Used within your app | VS Code Copilot, Claude Desktop |
### Creating an MCP Server
```csharp
using Microsoft.Extensions.Hosting;
using ModelContextProtocol.Extensions.Hosting;
var builder = Host.CreateEmptyApplicationBuilder(settings: null);
builder.Services.AddMcpServer()
.WithStdioServerTransport()
.WithToolsFromAssembly();
await builder.Build().RunAsync();
```
Define your tools:
```csharp
[McpServerToolType]
public static class FileSystemTools
{
[McpServerTool, Description("Read a file from the file system")]
public static async Task<string> ReadFile(string path)
{
// ⚠️ SECURITY: Always validate paths!
if (!IsPathSafe(path))
throw new SecurityException("Invalid path");
return await File.ReadAllTextAsync(path);
}
private static bool IsPathSafe(string path)
{
// Implement path traversal prevention
var fullPath = Path.GetFullPath(path);
return fullPath.StartsWith(AllowedDirectory);
}
}
```
Your MCP server can now be used by VS Code Copilot, Claude Desktop, or any other MCP client!
## Chat History Management: Truncation + RAG Hybrid
For long conversations, storing all history in the context window becomes impractical. Here's the pattern that works:
![Chat History Hybrid Strategy](images/chat-history-hybrid.svg)
### ❌ Lossy Approach
```
First 50 messages → Summarize with LLM → Single summary message
```
**Problem**: Detail loss (fidelity loss)
### ✅ Hybrid Approach
1. **Recent messages** (last 5-10): Keep in prompt for immediate context
2. **Older messages**: Store in vector database as a tool
```csharp
[KernelFunction]
[Description("Search conversation history for past discussions")]
public async Task<string> SearchChatHistory(
[Description("What to search for")] string query)
{
var relevantMessages = await _vectorDb.SearchAsync(query);
return string.Join("\n", relevantMessages.Select(m =>
$"[{m.Timestamp}] {m.Role}: {m.Content}"));
}
```
The LLM retrieves only relevant past context when needed, avoiding summary-induced information loss.
## RAG vs. Fine-Tuning: Choose Wisely
A common misconception is using fine-tuning for knowledge injection. Here's when to use each:
| Purpose | RAG | Fine-Tuning |
|---------|-----|-------------|
| **Goal** | Memory (provide facts) | Behavior (teach style) |
| **Updates** | Dynamic (add docs anytime) | Static (requires retraining) |
| **Cost** | Low dev, higher inference | High dev, lower inference |
| **Hallucination** | Reduces | Doesn't reduce |
| **Use Case** | Company docs, FAQs | Brand voice, specific format |
**Common mistake**: "Let's fine-tune on our company documents" ❌
**Better approach**: Use RAG! ✅
Fine-tuning is for teaching the model *how* to respond, not *what* to know.
**Source**: [Oracle - RAG vs Fine-Tuning](https://www.oracle.com/artificial-intelligence/generative-ai/retrieval-augmented-generation-rag/rag-fine-tuning/)
## Bonus: Why SVG is Superior for LLM-Generated Images
When using LLMs to generate diagrams and visualizations, always request SVG format instead of PNG or JPG.
### Why SVG?
**Text-based** → LLMs produce better results
**Lower cost** → Fewer tokens than base64-encoded images
**Editable** → Easy to modify after generation
**Scalable** → Perfect quality at any size
**Version control friendly** → Works great in Git
### Example Prompt
```
Create an architecture diagram showing PostgreSQL with pgvector integration.
Format: SVG, 800x400 pixels. Show: .NET Application → EF Core → PostgreSQL → Vector Search.
Use arrows to connect stages. Color scheme: Blue tones.
```
![SVG Diagram Example](images/svg-diagram-example.svg)
All diagrams in this article were generated as SVG, resulting in excellent quality and lower token costs!
> **Pro Tip**: If you don't need photographs or complex renders, always choose SVG.
## Architecture Roadmap: Putting It All Together
Here's the recommended stack for building production LLM applications with .NET:
1. **Orchestration**: Microsoft.Extensions.AI + Semantic Kernel (when needed)
2. **Vector Database**: PostgreSQL + Pgvector.EntityFrameworkCore
3. **RAG Pattern**: Parent-Child chunks with 10-20% overlap
4. **Tools**: MCP servers for reusability
5. **Reasoning**: ReasoningEffortLevel instead of temperature
6. **Prompting**: Critical rules at the end
7. **Cost Optimization**: Make RAG a tool, not automatic
## Key Takeaways
Let me summarize the most important production tips:
1. **Temperature is gone** → Use `ReasoningEffortLevel` with GPT-5
2. **Rules at the end** → Combat "Lost in the Middle"
3. **RAG as a tool** → Reduce costs significantly
4. **Parent-Child pattern** → Search small, respond with large
5. **Always use overlap** → 10-20% is the standard
6. **pgvector for most cases** → Unless you have billions of vectors
7. **MCP for reusability** → One codebase, works everywhere
8. **SVG for diagrams** → Better results, lower cost
9. **Hybrid chat history** → Recent in prompt, old in vector DB
10. **RAG > Fine-tuning** → For knowledge, not behavior
Happy coding! 🚀

1
docs/en/Community-Articles/2025-11-22-building-production-ready-llm-applications/summary.md

@ -0,0 +1 @@
Learn how to build production-ready LLM applications with .NET. This comprehensive guide covers GPT-5 API changes, advanced RAG architectures with parent-child patterns, PostgreSQL pgvector integration, smart tool usage strategies, multilingual query handling, Model Context Protocol (MCP) for cross-application tool reusability, and chat history management techniques for enterprise applications.

18
docs/en/docs-nav.json

@ -552,6 +552,24 @@
"text": "Audit Logging",
"path": "framework/infrastructure/audit-logging.md"
},
{
"text": "Artificial Intelligence",
"items":[
{
"text": "Overview",
"path": "framework/infrastructure/artificial-intelligence/index.md",
"isIndex": true
},
{
"text": "Microsoft.Extensions.AI",
"path": "framework/infrastructure/artificial-intelligence/microsoft-extensions-ai.md"
},
{
"text": "Semantic Kernel",
"path": "framework/infrastructure/artificial-intelligence/microsoft-semantic-kernel.md"
}
]
},
{
"text": "Background Jobs",
"items": [

307
docs/en/framework/infrastructure/artificial-intelligence.md

@ -1,307 +0,0 @@
# Artificial Intelligence
ABP provides a simple way to integrate AI capabilities into your applications by unifying two popular .NET AI stacks under a common concept called a "workspace":
- Microsoft.Extensions.AI `IChatClient`
- Microsoft.SemanticKernel `Kernel`
A workspace is just a named scope. You configure providers per workspace and then resolve either default services (for the "Default" workspace) or workspace-scoped services.
## Installation
> This package is not included by default. Install it to enable AI features.
It is suggested to use the ABP CLI to install the package. Open a command line window in the folder of the project (.csproj file) and type the following command:
```bash
abp add-package Volo.Abp.AI
```
### Manual Installation
Add nuget package to your project:
```bash
dotnet add package Volo.Abp.AI
```
Then add the module dependency to your module class:
```csharp
using Volo.Abp.AI;
using Volo.Abp.Modularity;
[DependsOn(typeof(AbpAIModule))]
public class MyProjectModule : AbpModule
{
}
```
## Usage
### Chat Client
#### Default configuration (quick start)
Configure the default workspace to inject `IChatClient` directly.
```csharp
using Microsoft.Extensions.AI;
using Microsoft.SemanticKernel;
using Volo.Abp.AI;
using Volo.Abp.Modularity;
public class MyProjectModule : AbpModule
{
public override void ConfigureServices(ServiceConfigurationContext context)
{
context.Services.PreConfigure<AbpAIOptions>(options =>
{
options.Workspaces.ConfigureDefault(configuration =>
{
configuration.ConfigureChatClient(chatClientConfiguration =>
{
chatClientConfiguration.Builder = new ChatClientBuilder(
sp => new OllamaApiClient("http://localhost:11434", "mistral")
);
});
// Chat client only in this quick start
});
});
}
}
```
Once configured, inject the default chat client:
```csharp
using Microsoft.Extensions.AI;
public class MyService
{
private readonly IChatClient _chatClient; // default chat client
public MyService(IChatClient chatClient)
{
_chatClient = chatClient;
}
}
```
#### Workspace configuration
Workspaces allow multiple, isolated AI configurations. Define workspace types (optionally decorated with `WorkspaceNameAttribute`). If omitted, the type’s full name is used.
```csharp
using Volo.Abp.AI;
[WorkspaceName("GreetingAssistant")]
public class GreetingAssistant // ChatClient-only workspace
{
}
```
Configure a ChatClient workspace:
```csharp
public class MyProjectModule : AbpModule
{
public override void ConfigureServices(ServiceConfigurationContext context)
{
context.Services.PreConfigure<AbpAIOptions>(options =>
{
options.Workspaces.Configure<GreetingAssistant>(configuration =>
{
configuration.ConfigureChatClient(chatClientConfiguration =>
{
chatClientConfiguration.Builder = new ChatClientBuilder(
sp => new OllamaApiClient("http://localhost:11434", "mistral")
);
chatClientConfiguration.BuilderConfigurers.Add(builder =>
{
// Anything you want to do with the builder:
// builder.UseFunctionInvocation().UseLogging(); // For example
});
});
});
});
}
}
```
### Semantic Kernel
#### Default configuration
```csharp
public class MyProjectModule : AbpModule
{
public override void ConfigureServices(ServiceConfigurationContext context)
{
context.Services.PreConfigure<AbpAIOptions>(options =>
{
options.Workspaces.ConfigureDefault(configuration =>
{
configuration.ConfigureKernel(kernelConfiguration =>
{
kernelConfiguration.Builder = Kernel.CreateBuilder()
.AddAzureOpenAIChatClient("...", "...");
});
// Note: Chat client is not configured here
});
});
}
}
```
Once configured, inject the default kernel:
```csharp
using System.Threading.Tasks;
using Volo.Abp.AI;
public class MyService
{
private readonly IKernelAccessor _kernelAccessor;
public MyService(IKernelAccessor kernelAccessor)
{
_kernelAccessor = kernelAccessor;
}
public async Task DoSomethingAsync()
{
var kernel = _kernelAccessor.Kernel; // Kernel might be null if no workspace is configured.
var result = await kernel.InvokeAsync(/*... */);
}
}
```
#### Workspace configuration
```csharp
public class MyProjectModule : AbpModule
{
public override void ConfigureServices(ServiceConfigurationContext context)
{
context.Services.PreConfigure<AbpAIOptions>(options =>
{
options.Workspaces.Configure<ContentPlanner>(configuration =>
{
configuration.ConfigureKernel(kernelConfiguration =>
{
kernelConfiguration.Builder = Kernel.CreateBuilder()
.AddOpenAIChatCompletion("...", "...");
});
});
});
}
}
```
#### Workspace usage
```csharp
using Microsoft.Extensions.AI;
using Volo.Abp.AI;
using Microsoft.SemanticKernel;
public class PlanningService
{
private readonly IKernelAccessor<ContentPlanner> _kernelAccessor;
private readonly IChatClient<ContentPlanner> _chatClient; // available even if only Kernel is configured
public PlanningService(
IKernelAccessor<ContentPlanner> kernelAccessor,
IChatClient<ContentPlanner> chatClient)
{
_kernelAccessor = kernelAccessor;
_chatClient = chatClient;
}
public async Task<string> PlanAsync(string topic)
{
var kernel = _kernelAccessor.Kernel; // Microsoft.SemanticKernel.Kernel
// Use Semantic Kernel APIs if needed...
var response = await _chatClient.GetResponseAsync(
[new ChatMessage(ChatRole.User, $"Create a content plan for: {topic}")]
);
return response?.Message?.Text ?? string.Empty;
}
}
```
## Options
`AbpAIOptions` configuration pattern offers `ConfigureChatClient(...)` and `ConfigureKernel(...)` methods for configuration. These methods are defined in the `WorkspaceConfiguration` class. They are used to configure the `ChatClient` and `Kernel` respectively.
`Builder` is set once and is used to build the `ChatClient` or `Kernel` instance. `BuilderConfigurers` is a list of actions that are applied to the `Builder` instance for incremental changes. These actions are executed in the order they are added.
If a workspace configures only the Kernel, a chat client may still be exposed for that workspace through the Kernel’s service provider (when available).
## Advanced Usage and Customizations
### Addding Your Own DelegatingChatClient
If you want to build your own decorator, implement a `DelegatingChatClient` derivative and provide an extension method that adds it to the `ChatClientBuilder` using `builder.Use(...)`.
Example sketch:
```csharp
using Microsoft.Extensions.AI;
public class SystemMessageChatClient : DelegatingChatClient
{
public SystemMessageChatClient(IChatClient inner, string systemMessage) : base(inner)
{
SystemMessage = systemMessage;
}
public string SystemMessage { get; set; }
public override Task<ChatResponse> GetResponseAsync(IEnumerable<ChatMessage> messages, ChatOptions? options = null, CancellationToken cancellationToken = default)
{
// Mutate messages/options as needed, then call base
return base.GetResponseAsync(messages, options, cancellationToken);
}
}
public static class SystemMessageChatClientExtensions
{
public static ChatClientBuilder UseSystemMessage(this ChatClientBuilder builder, string systemMessage)
{
return builder.Use(client => new SystemMessageChatClient(client, systemMessage));
}
}
```
```cs
chatClientConfiguration.BuilderConfigurers.Add(builder =>
{
builder.UseSystemMessage("You are a helpful assistant that greets users in a friendly manner with their names.");
});
```
## Technical Anatomy
- `AbpAIModule`: Wires up configured workspaces, registers keyed services and default services for the `"Default"` workspace.
- `AbpAIOptions`: Holds `Workspaces` and provides helper methods for internal keyed service naming.
- `WorkspaceConfigurationDictionary` and `WorkspaceConfiguration`: Configure per-workspace Chat Client and Kernel.
- `ChatClientConfiguration` and `KernelConfiguration`: Hold builders and a list of ordered builder configurers.
- `WorkspaceNameAttribute`: Names a workspace; falls back to the type’s full name if not specified.
- `IChatClient<TWorkspace>`: Typed chat client for a workspace.
- `IKernelAccessor<TWorkspace>`: Provides access to the workspace’s `Kernel` instance if configured.
- `AbpAIWorkspaceOptions`: Exposes `ConfiguredWorkspaceNames` for diagnostics.
There are no database tables for this feature; it is a pure configuration and DI integration layer.
## See Also
- Microsoft.Extensions.AI (Chat Client)
- Microsoft Semantic Kernel

31
docs/en/framework/infrastructure/artificial-intelligence/index.md

@ -0,0 +1,31 @@
# Artificial Intelligence
ABP Framework provides integration for AI capabilities to your application by using Microsoft's popular AI libraries. The main purpose of this integration is to provide a consistent and easy way to use AI capabilities and manage different AI providers, models and configurations in a single application.
ABP introduces a concept called **AI Workspace**. A workspace allows you to configure isolated AI configurations for a named scope. You can then resolve AI services for a specific workspace when you need to use them.
> ABP Framework can work with any AI library or framework that supports .NET development. However, the AI integration features explained in the following documents provide a modular and standard way to work with AI, which allows ABP developers to create reusable modules and components with AI capabilities in a standard way.
## Installation
Use the [ABP CLI](../../../cli/index.md) to install the [Volo.Abp.AI](https://www.nuget.org/packages/Volo.Abp.AI) NuGet package into your project. Open a command line window in the root directory of your project (`.csproj` file) and type the following command:
```bash
abp add-package Volo.Abp.AI
```
*For different installation options, check [the package definition page](https://abp.io/package-detail/Volo.Abp.AI).*
## Usage
The `Volo.Abp.AI` package provides integration with the following libraries:
* [Microsoft.Extensions.AI](https://learn.microsoft.com/en-us/dotnet/ai/microsoft-extensions-ai)
* [Microsoft.SemanticKernel](https://learn.microsoft.com/en-us/semantic-kernel/overview/)
The Microsoft.Extensions.AI library is suggested for library developers to keep the library dependency minimum and simple (since it provides basic abstractions and fundamental AI provider integrations), while Semantic Kernel is suggested for applications that need rich and advanced AI integration features.
Check the following documentation to learn how to use these libraries with the ABP integration:
- [ABP Microsoft.Extensions.AI integration](./microsoft-extensions-ai.md)
- [ABP Microsoft.SemanticKernel integration](./microsoft-semantic-kernel.md)

176
docs/en/framework/infrastructure/artificial-intelligence/microsoft-extensions-ai.md

@ -0,0 +1,176 @@
# Microsoft.Extensions.AI
[Microsoft.Extensions.AI](https://learn.microsoft.com/en-us/dotnet/ai/microsoft-extensions-ai) is a library that provides a unified API for integrating AI services. It is a part of the Microsoft AI Extensions Library. It is used to integrate AI services into your application. This documentation is about the usage of this library with ABP Framework. Make sure you have read the [Artificial Intelligence](./index.md) documentation before reading this documentation.
## Usage
You can resolve `IChatClient` to access configured chat client from your service and use it directly.
```csharp
public class MyService
{
private readonly IChatClient _chatClient;
public MyService(IChatClient chatClient)
{
_chatClient = chatClient;
}
public async Task<string> GetResponseAsync(string prompt)
{
return await _chatClient.GetResponseAsync(prompt);
}
}
```
You can also resolve `IChatClientAccessor` to access the `IChatClient` optionally configured scenarios such as developing a module or a service that may use AI capabilities **optionally**.
```csharp
public class MyService
{
private readonly IChatClientAccessor _chatClientAccessor;
public MyService(IChatClientAccessor chatClientAccessor)
{
_chatClientAccessor = chatClientAccessor;
}
public async Task<string> GetResponseAsync(string prompt)
{
var chatClient = _chatClientAccessor.ChatClient;
if (chatClient is null)
{
return "No chat client configured";
}
return await chatClient.GetResponseAsync(prompt);
}
}
```
### Workspaces
Workspaces are a way to configure isolated AI configurations for a named scope. You can define a workspace by decorating a class with the `WorkspaceNameAttribute` attribute that carries the workspace name.
- Workspace names must be unique.
- Workspace names cannot contain spaces _(use underscores or camelCase)_.
- Workspace names are case-sensitive.
```csharp
using Volo.Abp.AI;
[WorkspaceName("CommentSummarization")]
public class CommentSummarization
{
}
```
> [!NOTE]
> If you don't specify the workspace name, the full name of the class will be used as the workspace name.
You can resolve generic versions of `IChatClient` and `IChatClientAccessor` services for a specific workspace as generic arguments. If Chat Client is not configured for a workspace, you will get `null` from the accessor services. You should check the accessor before using it. This applies only for specified workspaces. Another workspace may have a configured Chat Client.
`IChatClient<TWorkSpace>` or `IChatClientAccessor<TWorkSpace>` can be resolved to access a specific workspace's chat client. This is a typed chat client and can be configured separately from the default chat client.
Example of resolving a typed chat client:
```csharp
public class MyService
{
private readonly IChatClient<CommentSummarization> _chatClient;
public MyService(IChatClient<CommentSummarization> chatClient)
{
_chatClient = chatClient;
}
public async Task<string> GetResponseAsync(string prompt)
{
return await _chatClient.GetResponseAsync(prompt);
}
}
```
Example of resolving a typed chat client accessor:
```csharp
public class MyService
{
private readonly IChatClientAccessor<CommentSummarization> _chatClientAccessor;
}
public async Task<string> GetResponseAsync(string prompt)
{
var chatClient = _chatClientAccessor.ChatClient;
if (chatClient is null)
{
return "No chat client configured";
}
return await chatClient.GetResponseAsync(prompt);
}
}
```
## Configuration
`AbpAIWorkspaceOptions` configuration is used to configure AI workspaces and their configurations. You can configure the default workspace and also configure isolated workspaces by using the this options class.It has to be configured **before the services are configured** in the `PreConfigure` method of your module class. It is important since the services are registered after the configuration is applied.
- `AbpAIWorkspaceOptions` has a `Workspaces` property that is type of `WorkspaceConfigurationDictionary` which is a dictionary of workspace names and their configurations. It provides `Configure<T>` and `ConfigureDefault` methods to configure the default workspace and also configure isolated workspaces by using the workspace type.
- Configure method passes `WorkspaceConfiguration` object to the configure action. You can configure the `ChatClient` by using the `ConfigureChatClient` method.
- `ConfigureChatClient()` method passes `ChatClientConfiguration` parameter to the configure action. You can configure the `Builder` and `BuilderConfigurers` by using the `ConfigureBuilder` method.
- `Builder` is set once and is used to build the `ChatClient` instance.
- `BuilderConfigurers` is a list of actions that are applied to the `Builder` instance for incremental changes.These actions are executed in the order they are added.
To configure a chat client, you'll need a LLM provider package such as [Microsoft.Extensions.AI.OpenAI](https://www.nuget.org/packages/Microsoft.Extensions.AI.OpenAI) or [OllamaSharp](https://www.nuget.org/packages/OllamaSharp/) to configure a chat client.
_The following example requires [OllamaSharp](https://www.nuget.org/packages/OllamaSharp/) package to be installed._
Demonstration of the default workspace configuration:
```csharp
[DependsOn(typeof(AbpAIModule))]
public class MyProjectModule : AbpModule
{
public override void PreConfigureServices(ServiceConfigurationContext context)
{
PreConfigure<AbpAIWorkspaceOptions>(options =>
{
options.Workspaces.ConfigureDefault(configuration =>
{
configuration.ConfigureChatClient(chatClientConfiguration =>
{
chatClientConfiguration.Builder = new ChatClientBuilder(
sp => new OllamaApiClient("http://localhost:11434", "mistral")
);
});
});
});
}
}
```
Demonstration of the isolated workspace configuration:
```csharp
[DependsOn(typeof(AbpAIModule))]
public class MyProjectModule : AbpModule
{
public override void PreConfigureServices(ServiceConfigurationContext context)
{
PreConfigure<AbpAIWorkspaceOptions>(options =>
{
options.Workspaces.Configure<CommentSummarization>(configuration =>
{
configuration.ConfigureChatClient(chatClientConfiguration =>
{
chatClientConfiguration.Builder = new ChatClientBuilder(
sp => new OllamaApiClient("http://localhost:11434", "mistral")
);
});
});
});
}
}
```
## See Also
- [Usage of Semantic Kernel](./microsoft-semantic-kernel.md)
- [AI Samples for .NET](https://learn.microsoft.com/en-us/samples/dotnet/ai-samples/ai-samples/)

135
docs/en/framework/infrastructure/artificial-intelligence/microsoft-semantic-kernel.md

@ -0,0 +1,135 @@
# Microsoft.SemanticKernel
[Microsoft.SemanticKernel](https://learn.microsoft.com/en-us/semantic-kernel/overview/) is a library that provides a unified SDK for integrating AI services. This documentation is about the usage of this library with ABP Framework. Make sure you have read the [Artificial Intelligence](./index.md) documentation before reading this documentation.
## Usage
Semantic Kernel can be used by resolving `IKernelAccessor` service that carries the `Kernel` instance. Kernel might be `null` if no workspace is configured. You should check the kernel before using it.
```csharp
public class MyService
{
private readonly IKernelAccessor _kernelAccessor;
public MyService(IKernelAccessor kernelAccessor)
{
_kernelAccessor = kernelAccessor;
}
public async Task<string> GetResponseAsync(string prompt)
{
var kernel = _kernelAccessor.Kernel;
if (kernel is null)
{
return "No kernel configured";
}
return await kernel.InvokeAsync(prompt);
}
}
```
### Workspaces
Workspaces are a way to configure isolated AI configurations for a named scope. You can define a workspace by decorating a class with the `WorkspaceNameAttribute` attribute that carries the workspace name.
- Workspace names must be unique.
- Workspace names cannot contain spaces _(use underscores or camelCase)_.
- Workspace names are case-sensitive.
```csharp
using Volo.Abp.AI;
[WorkspaceName("CommentSummarization")]
public class CommentSummarization
{
}
```
> [!NOTE]
> If you don't specify the workspace name, the full name of the class will be used as the workspace name.
You can resolve generic versions of `IKernelAccessor` service for a specific workspace as generic arguments. If Kernel is not configured for a workspace, you will get `null` from the accessor service. You should check the accessor before using it. This applies only for specified workspaces. Another workspace may have a configured Kernel.
`IKernelAccessor<TWorkSpace>` can be resolved to access a specific workspace's kernel. This is a typed kernel accessor and each workspace can have its own kernel configuration.
Example of resolving a typed kernel accessor:
```csharp
public class MyService
{
private readonly IKernelAccessor<CommentSummarization> _kernelAccessor;
}
public async Task<string> GetResponseAsync(string prompt)
{
var kernel = _kernelAccessor.Kernel;
if (kernel is null)
{
return "No kernel configured";
}
return await kernel.InvokeAsync(prompt);
}
}
```
## Configuration
`AbpAIWorkspaceOptions` configuration is used to configure AI workspaces and their configurations. You can configure the default workspace and also configure isolated workspaces by using the this options class.It has to be configured **before the services are configured** in the `PreConfigure` method of your module class. It is important since the services are registered after the configuration is applied.
- `AbpAIWorkspaceOptions` has a `Workspaces` property that is type of `WorkspaceConfigurationDictionary` which is a dictionary of workspace names and their configurations. It provides `Configure<T>` and `ConfigureDefault` methods to configure the default workspace and also configure isolated workspaces by using the workspace type.
- Configure method passes `WorkspaceConfiguration` object to the configure action. You can configure the `Kernel` by using the `ConfigureKernel` method.
- `ConfigureKernel()` method passes `KernelConfiguration` parameter to the configure action. You can configure the `Builder` and `BuilderConfigurers` by using the `ConfigureBuilder` method.
- `Builder` is set once and is used to build the `Kernel` instance.
- `BuilderConfigurers` is a list of actions that are applied to the `Builder` instance for incremental changes.These actions are executed in the order they are added.
To configure a kernel, you'll need a kernel connector package such as [Microsoft.SemanticKernel.Connectors.OpenAI](Microsoft.SemanticKernel.Connectors.OpenAI) to configure a kernel to use a specific LLM provider.
_The following example requires [Microsoft.SemanticKernel.Connectors.AzureOpenAI](Microsoft.SemanticKernel.Connectors.AzureOpenAI) package to be installed._
Demonstration of the default workspace configuration:
```csharp
[DependsOn(typeof(AbpAIModule))]
public class MyProjectModule : AbpModule
{
public override void PreConfigureServices(ServiceConfigurationContext context)
{
PreConfigure<AbpAIOptions>(options =>
{
options.Workspaces.ConfigureDefault(configuration =>
{
configuration.ConfigureKernel(kernelConfiguration =>
{
kernelConfiguration.Builder = Kernel.CreateBuilder()
.AddAzureOpenAIChatClient("...", "...");
});
// Note: Chat client is not configured here
});
});
}
}
```
Demonstration of the isolated workspace configuration:
```csharp
[DependsOn(typeof(AbpAIModule))]
public class MyProjectModule : AbpModule
{
public override void PreConfigureServices(ServiceConfigurationContext context)
{
PreConfigure<AbpAIOptions>(options =>
{
options.Workspaces.Configure<CommentSummarization>(configuration =>
{
configuration.ConfigureKernel(kernelConfiguration =>
{
kernelConfiguration.Builder = Kernel.CreateBuilder()
.AddAzureOpenAIChatClient("...", "...");
});
});
});
}
}
```
## See Also
- [Usage of Microsoft.Extensions.AI](./microsoft-extensions-ai.md)
- [AI Samples for .NET](https://learn.microsoft.com/en-us/samples/dotnet/ai-samples/ai-samples/)

2
docs/en/framework/infrastructure/index.md

@ -10,7 +10,7 @@
ABP provides a complete infrastructure for creating real world software solutions with modern architectures based on the .NET platform. Each of the following documents explains an infrastructure feature:
* [Audit Logging](./audit-logging.md)
* [Artificial Intelligence](./artificial-intelligence.md)
* [Artificial Intelligence](./artificial-intelligence/index.md)
* [Background Jobs](./background-jobs/index.md)
* [Background Workers](./background-workers/index.md)
* [BLOB Storing](./blob-storing/index.md)

24
docs/en/framework/ui/angular/modifying-the-menu.md

@ -44,7 +44,29 @@ export const appConfig: ApplicationConfig = {
Notes
- This approach works across themes. If you are using LeptonX, the brand logo component reads these values automatically; you don't need any theme-specific code.
- You can still override visuals with CSS variables if desired. See the LeptonX section for CSS overrides.
- You can still override visuals with CSS variables if desired. See the alternative approach below.
### Alternative: Using CSS Variables (LeptonX Theme)
If you're using the LeptonX theme, you can also configure the logo using CSS variables in your `styles.scss` file. This approach is specific to LeptonX and provides direct control over the logo styling.
Add the following to your `src/styles.scss`:
```scss
:root {
--lpx-logo: url('/assets/images/logo/logo-light.png');
--lpx-logo-icon: url('/assets/images/logo/logo-light-thumbnail.png');
}
```
**When to use each approach:**
| Approach | Use Case | Theme Support |
|----------|----------|-------------|
| **provideLogo** (recommended) | Cross-theme compatibility, environment-based configuration | All themes |
| **CSS Variables** | LeptonX-specific styling, fine-grained CSS control | LeptonX only |
**Recommendation:** Use the `provideLogo` approach for most cases as it's theme-independent and follows ABP's standard configuration pattern. Use CSS variables only when you need LeptonX-specific styling control or have existing CSS-based theme customizations.
## How to Add a Navigation Element

BIN
docs/en/images/abp-overall-diagram-1600.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 407 KiB

After

Width:  |  Height:  |  Size: 559 KiB

BIN
docs/en/images/db-options.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 10 KiB

After

Width:  |  Height:  |  Size: 25 KiB

BIN
docs/en/images/ui-options.png

Binary file not shown.

Before

Width:  |  Height:  |  Size: 41 KiB

After

Width:  |  Height:  |  Size: 41 KiB

10
docs/en/modules/ai-management/index.md

@ -9,7 +9,7 @@
> You must have an ABP Team or a higher license to use this module.
This module implements AI (Artificial Intelligence) management capabilities on top of the [Artificial Intelligence Workspaces](../../framework/infrastructure/artificial-intelligence.md) feature of the ABP Framework and allows to manage workspaces dynamically from the application including UI components and API endpoints.
This module implements AI (Artificial Intelligence) management capabilities on top of the [Artificial Intelligence Workspaces](../../framework/infrastructure/artificial-intelligence/index.md) feature of the ABP Framework and allows to manage workspaces dynamically from the application including UI components and API endpoints.
## How to Install
@ -75,7 +75,7 @@ The AI Management module includes a built-in chat interface for testing workspac
* Test streaming responses
* Verify workspace configuration before using in production
> Access the chat interface at: `/AIManagement/Chat`
> Access the chat interface at: `/AIManagement/Workspaces/{WorkspaceName}`
## Workspace Configuration
@ -248,7 +248,7 @@ public class MyService
}
```
> See [Artificial Intelligence](../../framework/infrastructure/artificial-intelligence.md) documentation for more details about workspace configuration.
> See [Artificial Intelligence](../../framework/infrastructure/artificial-intelligence/index.md) documentation for more details about workspace configuration.
### Scenario 2: AI Management with Domain Layer Dependency (Local Execution)
@ -626,6 +626,6 @@ The cache is automatically invalidated when workspaces are created, updated, or
## See Also
- [Artificial Intelligence Infrastructure](../../framework/infrastructure/artificial-intelligence.md): Learn about the underlying AI workspace infrastructure
- [Artificial Intelligence Infrastructure](../../framework/infrastructure/artificial-intelligence/index.md): Learn about the underlying AI workspace infrastructure
- [Microsoft.Extensions.AI](https://learn.microsoft.com/en-us/dotnet/ai/): Microsoft's unified AI abstractions
- [Semantic Kernel](https://learn.microsoft.com/en-us/semantic-kernel/): Microsoft's Semantic Kernel integration
- [Semantic Kernel](https://learn.microsoft.com/en-us/semantic-kernel/): Microsoft's Semantic Kernel integration

6
docs/en/modules/file-management.md

@ -144,6 +144,12 @@ You can move files by clicking `Actions -> Move` on the table.
You can rename a file by clicking `Actions -> Rename` on the table.
###### File Sharing
To share a file, click `Actions -> Share` in the table. Once sharing is enabled, you can copy the shared link directly from the table.
> Anyone with the shared link will be able to access the file while sharing is enabled.
## Data Seed
This module doesn't seed any data.

20
docs/en/release-info/migration-guides/abp-10-0.md

@ -15,6 +15,24 @@ This document is a guide for upgrading ABP v9.x solutions to ABP v10.0. There ar
We've upgraded ABP to .NET 10.0, so you need to move your solutions to .NET 10.0 if you want to use ABP 10.0. You can check Microsoft’s [Migrate from ASP.NET Core 9.0 to 10.0](https://learn.microsoft.com/en-us/aspnet/core/migration/90-to-100) documentation to see how to update an existing ASP.NET Core 9.0 project to ASP.NET Core 10.0.
### MySQL Support for .NET 10.0
**If you are using MySQL as your database provider, please be aware of the following compatibility issues before upgrading to ABP 10.0!**
The MySQL Entity Framework Core providers currently have limited support for .NET 10.0:
* **Pomelo.EntityFrameworkCore.MySql**: Does not yet support .NET 10.0. The team is actively working on adding support.
* **MySql.EntityFrameworkCore**: Currently in Release Candidate (RC) status with known bugs that may affect production applications.
**Recommendation**: If you are using MySQL, we recommend waiting to upgrade to ABP 10.0 until the MySQL providers release stable versions with full .NET 10.0 support.
**Track Progress**:
* [Pomelo Provider - EF Core 10 Support](https://github.com/PomeloFoundation/Pomelo.EntityFrameworkCore.MySql/issues/2007)
* [MySql.EntityFrameworkCore NuGet Package](https://www.nuget.org/packages/MySql.EntityFrameworkCore/#versions-body-tab)
We will update to support the latest stable MySQL providers as soon as they become available.
### Add New EF Core Migrations
Some entities in certain modules have been modified. If you are using Entity Framework Core, please create a new EF Core migration in your project after upgrading to ABP 10.0.
@ -27,6 +45,8 @@ We removed the Razor Runtime Compilation support since it is obsolete and replac
If you want to keep using it, you can add [Microsoft.AspNetCore.Mvc.Razor.RuntimeCompilation](https://www.nuget.org/packages/Microsoft.AspNetCore.Mvc.Razor.RuntimeCompilation) package to your project and configure it manually.
> If the referenced project also contains Razor Pages that require this feature, add the package to that project as well.
```csharp
using Microsoft.AspNetCore.Mvc.Razor.RuntimeCompilation;
using Volo.Abp.DependencyInjection;

4
docs/en/release-info/release-notes.md

@ -14,9 +14,9 @@ Also see the following notes about ABP releases:
* [ABP Studio release notes](../studio/release-notes.md)
* [Change logs for ABP pro packages](https://abp.io/pro-releases)
## 10.0 (2025-10-01)
## 10.0 (2025-11-18)
This is currently a RC (release-candidate) and you can see the detailed **[blog post / announcement](https://abp.io/community/announcements/announcing-abp-10-0-release-candidate-86lrnyox)** for the v10.0 release.
See the detailed **[blog post / announcement](https://abp.io/community/announcements/abp.io-platform-10.0-final-has-been-released-spknn925)** for the v10.0 release.
* Upgraded to .NET 10.0
* Upgraded to `Blazorise` **v1.8.6**

2
docs/en/tutorials/book-store-with-abp-suite/index.md

@ -46,4 +46,4 @@ This tutorial is organized as the following parts:
### Download the Source Code
After logging in to the ABP website, you can download the source code from [here](https://abp.io/api/download/samples/suite-bookstore-mvc-ef).
After logging in to the ABP website, you can download the source code from [here](https://abp.io/api/download/samples/bookstore-mvc-ef).

60
docs/en/tutorials/book-store/part-02.md

@ -315,7 +315,7 @@ This is a fully working, server side paged, sorted and localized table of books.
## Install NPM packages
> Notice: This tutorial is based on the ABP v3.1.0+ If your project version is older, then please upgrade your solution. Check the [migration guide](../../framework/ui/angular/migration-guide-v3.md) if you are upgrading an existing project with v2.x.
> Notice: This tutorial is based on the ABP v9.3.0+ If your project version is older, then please upgrade your solution. Check the [migration guide](../../framework/ui/angular/migration-guide-v3.md) if you are upgrading an existing project with v2.x.
If you haven't done it before, open a new command line interface (terminal window) and go to your `angular` folder and then run the `yarn` command to install the NPM packages:
@ -330,69 +330,42 @@ It's time to create something visible and usable! There are some tools that we w
- [Ng Bootstrap](https://ng-bootstrap.github.io/#/home) will be used as the UI component library.
- [Ngx-Datatable](https://swimlane.gitbook.io/ngx-datatable/) will be used as the datatable library.
Run the following command line to create a new module, named `BookModule` in the root folder of the angular application:
Run the following command line to create a new component, named `BookComponent` in the root folder of the angular application:
```bash
yarn ng generate module book --module app --routing --route books
yarn ng generate component book
```
This command should produce the following output:
````bash
> yarn ng generate module book --module app --routing --route books
yarn run v1.19.1
$ ng generate module book --module app --routing --route books
CREATE src/app/book/book-routing.module.ts (336 bytes)
CREATE src/app/book/book.module.ts (335 bytes)
CREATE src/app/book/book.component.html (19 bytes)
CREATE src/app/book/book.component.spec.ts (614 bytes)
CREATE src/app/book/book.component.ts (268 bytes)
> yarn ng generate component book
yarn run v1.22.22
$ ng generate component book
CREATE src/app/book/book.component.spec.ts (537 bytes)
CREATE src/app/book/book.component.ts (189 bytes)
CREATE src/app/book/book.component.scss (0 bytes)
UPDATE src/app/app-routing.module.ts (1289 bytes)
CREATE src/app/book/book.component.html (20 bytes)
Done in 3.88s.
````
### BookModule
Open the `/src/app/book/book.module.ts` and replace the content as shown below:
````js
import { NgModule } from '@angular/core';
import { SharedModule } from '../shared/shared.module';
import { BookRoutingModule } from './book-routing.module';
import { BookComponent } from './book.component';
@NgModule({
declarations: [BookComponent],
imports: [
BookRoutingModule,
SharedModule
]
})
export class BookModule { }
````
* Added the `SharedModule`. `SharedModule` exports some common modules needed to create user interfaces.
* `SharedModule` already exports the `CommonModule`, so we've removed the `CommonModule`.
### Routing
The generated code places the new route definition to the `src/app/app-routing.module.ts` file as shown below:
The generated code places the new route definition to the `src/app/app.routes.ts` file as shown below:
````js
const routes: Routes = [
export const routes: Routes = [
// other route definitions...
{ path: 'books', loadChildren: () => import('./book/book.module').then(m => m.BookModule) },
{ path : 'books', loadComponent: () => import('./book/book.component').then(c => c.BookComponent) },
];
````
Now, open the `src/app/route.provider.ts` file and replace the `configureRoutes` function declaration as shown below:
```js
function configureRoutes(routes: RoutesService) {
return () => {
function configureRoutes() {
const routes = inject(RoutesService);
routes.add([
{
path: '/',
@ -416,7 +389,6 @@ function configureRoutes(routes: RoutesService) {
},
]);
};
}
```
`RoutesService` is a service provided by the ABP to configure the main menu and the routes.
@ -497,7 +469,7 @@ Open the `/src/app/book/book.component.html` and replace the content as shown be
</div>
<div class="card-body">
<ngx-datatable [rows]="book.items" [count]="book.totalCount" [list]="list" default>
<ngx-datatable-column [name]="'::Name' | abpLocalization" prop="name"></ngx-datatable-column>
<ngx-datatable-column [name]="'::Name' | abpLocalization" prop="name" />
<ngx-datatable-column [name]="'::Type' | abpLocalization" prop="type">
<ng-template let-row="row" ngx-datatable-cell-template>
{%{{{ '::Enum:BookType.' + row.type | abpLocalization }}}%}

42
docs/en/tutorials/book-store/part-03.md

@ -742,8 +742,8 @@ export class BookComponent implements OnInit {
* Imported `FormGroup`, `FormBuilder` and `Validators` from `@angular/forms`.
* Added a `form: FormGroup` property.
* Added a `bookTypes` property as a list of `BookType` enum members. That will be used in form options.
* Injected with the `FormBuilder` inject function.. [FormBuilder](https://angular.dev/api/forms/FormBuilder) provides convenient methods for generating form controls. It reduces the amount of boilerplate needed to build complex forms.
* Added a `buildForm` method to the end of the file and executed the `buildForm()` in the `createBook` method.
* Injected the `FormBuilder` with the inject function. [FormBuilder](https://angular.io/api/forms/FormBuilder) provides convenient methods for generating form controls. It reduces the amount of boilerplate that is needed to build complex forms.
* Added a `buildForm` method at the end of the file and executed the `buildForm()` in the `createBook` method.
* Added a `save` method.
Open `/src/app/book/book.component.html` and replace `<ng-template #abpBody> </ng-template>` with the following code part:
@ -765,7 +765,11 @@ Open `/src/app/book/book.component.html` and replace `<ng-template #abpBody> </n
<label for="book-type">Type</label><span> * </span>
<select class="form-control" id="book-type" formControlName="type">
<option [ngValue]="null">Select a book type</option>
<option [ngValue]="type.value" *ngFor="let type of bookTypes"> {%{{{ '::Enum:BookType.' + type.value | abpLocalization }}}%}</option>
@for (type of bookTypes; track type) {
<option [ngValue]="type.value">
{%{{{ '::Enum:BookType.' + type.value | abpLocalization }}}%}
</option>
}
</select>
</div>
@ -804,46 +808,24 @@ Also replace `<ng-template #abpFooter> </ng-template>` with the following code p
We've used [NgBootstrap datepicker](https://ng-bootstrap.github.io/#/components/datepicker/overview) in this component. So, we need to arrange the dependencies related to this component.
Open `/src/app/book/book.module.ts` and replace the content as below:
```js
import { NgModule } from '@angular/core';
import { SharedModule } from '../shared/shared.module';
import { BookRoutingModule } from './book-routing.module';
import { BookComponent } from './book.component';
import { NgbDatepickerModule } from '@ng-bootstrap/ng-bootstrap'; // add this line
@NgModule({
declarations: [BookComponent],
imports: [
BookRoutingModule,
SharedModule,
NgbDatepickerModule, // add this line
]
})
export class BookModule { }
```
* We imported `NgbDatepickerModule` to be able to use the date picker.
Open `/src/app/book/book.component.ts` and replace the content as below:
```js
import { ListService, PagedResultDto } from '@abp/ng.core';
import { Component, OnInit, inject } from '@angular/core';
import { BookService, BookDto, bookTypeOptions } from '@proxy/books';
import { FormGroup, FormBuilder, Validators } from '@angular/forms';
// added this line
import { NgbDateNativeAdapter, NgbDateAdapter } from '@ng-bootstrap/ng-bootstrap';
import { FormGroup, FormBuilder, Validators, ReactiveFormsModule } from '@angular/forms';
import { NgbDateNativeAdapter, NgbDateAdapter, NgbDatepickerModule } from '@ng-bootstrap/ng-bootstrap';
import { ThemeSharedModule } from '@abp/ng.theme.shared';
@Component({
selector: 'app-book',
templateUrl: './book.component.html',
styleUrls: ['./book.component.scss'],
imports: [ThemeSharedModule, ReactiveFormsModule, NgbDatepickerModule],
providers: [
ListService,
{ provide: NgbDateAdapter, useClass: NgbDateNativeAdapter } // add this line
{ provide: NgbDateAdapter, useClass: NgbDateNativeAdapter }
],
})
export class BookComponent implements OnInit {

16
docs/en/tutorials/book-store/part-05.md

@ -311,23 +311,19 @@ We've only added the `.RequirePermissions(BookStorePermissions.Books.Default)` e
First step of the UI is to prevent unauthorized users to see the "Books" menu item and enter to the book management page.
Open the `/src/app/book/book-routing.module.ts` and replace with the following content:
Open the `/src/app/app.routes.ts` and replace with the following content:
````js
import { NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import { authGuard, permissionGuard } from '@abp/ng.core';
import { BookComponent } from './book.component';
const routes: Routes = [
{ path: '', component: BookComponent, canActivate: [authGuard, permissionGuard] },
{
path: 'books',
loadComponent: () => import('./book/book.component').then(c => BookComponent),
canActivate: [authGuard, permissionGuard],
},
];
@NgModule({
imports: [RouterModule.forChild(routes)],
exports: [RouterModule],
})
export class BookRoutingModule {}
````
* Imported `authGuard` and `permissionGuard` from the `@abp/ng.core`.

36
docs/en/tutorials/book-store/part-09.md

@ -477,49 +477,43 @@ That's all! You can run the application and try to edit an author.
## The Author Management Page
Run the following command line to create a new module, named `AuthorModule` in the root folder of the angular application:
Run the following command line to create a new component, named `AuthorComponent` in the root folder of the angular application:
```bash
yarn ng generate module author --module app --routing --route authors
yarn ng generate component author
```
This command should produce the following output:
```bash
> yarn ng generate module author --module app --routing --route authors
> yarn ng generate component author
yarn run v1.19.1
$ ng generate module author --module app --routing --route authors
CREATE src/app/author/author-routing.module.ts (344 bytes)
CREATE src/app/author/author.module.ts (349 bytes)
$ yarn ng generate component author
CREATE src/app/author/author.component.html (21 bytes)
CREATE src/app/author/author.component.spec.ts (628 bytes)
CREATE src/app/author/author.component.ts (276 bytes)
CREATE src/app/author/author.component.scss (0 bytes)
UPDATE src/app/app-routing.module.ts (1396 bytes)
Done in 2.22s.
```
### AuthorModule
### Author Component
Open the `/src/app/author/author.module.ts` and replace the content as shown below:
Open the `/src/app/author/author.component.ts` and replace the content as shown below:
```js
import { NgModule } from '@angular/core';
import { SharedModule } from '../shared/shared.module';
import { AuthorRoutingModule } from './author-routing.module';
import { AuthorComponent } from './author.component';
import { Component } from '@angular/core';
import { NgbDatepickerModule } from '@ng-bootstrap/ng-bootstrap';
@NgModule({
declarations: [AuthorComponent],
imports: [SharedModule, AuthorRoutingModule, NgbDatepickerModule],
@Component({
selector: 'app-author',
templateUrl: './author.component.html',
styleUrls: ['./author.component.scss'],
imports: [NgbDatepickerModule],
})
export class AuthorModule {}
export class AuthorComponent {}
```
- Added the `SharedModule`. `SharedModule` exports some common modules needed to create user interfaces.
- `SharedModule` already exports the `CommonModule`, so we've removed the `CommonModule`.
- Added `NgbDatepickerModule` that will be used later on the author create and edit forms.
### Menu Definition
@ -753,13 +747,13 @@ Open the `/src/app/author/author.component.html` and replace the content as belo
</div>
</ng-template>
</ngx-datatable-column>
<ngx-datatable-column [name]="'::Name' | abpLocalization" prop="name"></ngx-datatable-column>
<ngx-datatable-column [name]="'::Name' | abpLocalization" prop="name" />
<ngx-datatable-column [name]="'::BirthDate' | abpLocalization">
<ng-template let-row="row" ngx-datatable-cell-template>
{%{{{ row.birthDate | date }}}%}
</ng-template>
</ngx-datatable-column>
<ngx-datatable-column [name]="'::ShortBio' | abpLocalization" prop="shortBio"></ngx-datatable-column>
<ngx-datatable-column [name]="'::ShortBio' | abpLocalization" prop="shortBio" />
</ngx-datatable>
</div>
</div>

10
docs/en/tutorials/book-store/part-10.md

@ -970,7 +970,7 @@ Book list page change is trivial. Open the `/src/app/book/book.component.html` a
[name]="'::Author' | abpLocalization"
prop="authorName"
[sortable]="false"
></ngx-datatable-column>
/>
````
When you run the application, you can see the *Author* column on the table:
@ -1098,9 +1098,11 @@ Open the `/src/app/book/book.component.html` and add the following form group ju
<label for="author-id">Author</label><span> * </span>
<select class="form-control" id="author-id" formControlName="authorId">
<option [ngValue]="null">Select author</option>
<option [ngValue]="author.id" *ngFor="let author of authors$ | async">
{%{{{ author.name }}}%}
</option>
@for (author of authors$ | async; track author) {
<option [ngValue]="author.id">
{%{{{ author.name }}}%}
</option>
}
</select>
</div>
````

2
docs/en/tutorials/microservice/index.md

@ -45,7 +45,7 @@ This tutorial is organized as the following parts:
## Download the Source Code
After logging in to the ABP website, you can download the source code from {{if UI == "MVC"}} [here](https://abp.io/api/download/samples/cloud-crm-mvc-ef) {{else if UI == "NG"}} [here](https://abp.io/api/download/samples/cloud-crm-ng-ef) {{else if UI == "Blazor"}} [here](https://abp.io/api/download/samples/cloud-crm-blazor-wasm-ef) {{else if UI == "BlazorServer"}} [here](https://abp.io/api/download/samples/cloud-crm-blazor-server-ef) {{else if UI == "BlazorWebApp"}} [here](https://abp.io/api/download/samples/cloud-crm-blazor-webapp-ef) {{end}}.
After logging in to the ABP website, you can download the source code from {{if UI == "MVC"}} [here](https://abp.io/api/download/samples/cloud-crm-mvc-ef) {{else if UI == "NG"}} [here](https://abp.io/api/download/samples/cloud-crm-angular-ef) {{else if UI == "Blazor"}} [here](https://abp.io/api/download/samples/cloud-crm-blazor-wasm-ef) {{else if UI == "BlazorServer"}} [here](https://abp.io/api/download/samples/cloud-crm-blazor-server-ef) {{else if UI == "BlazorWebApp"}} [here](https://abp.io/api/download/samples/cloud-crm-blazor-webapp-ef) {{end}}.
## See Also

4
docs/en/tutorials/microservice/part-01.md

@ -25,7 +25,7 @@
}
````
Follow the *[Get Started](../../get-started/microservice.md)* guide to create a new layered web application with the following configurations:
Follow the *[Get Started](../../get-started/microservice.md)* guide to create a new microservice solution with the following configurations:
* **Solution name**: `CloudCrm`
{{if DB == "EF"}}
@ -82,4 +82,4 @@ You can see the *[Microservice Solution Template](../../solution-templates/micro
## Summary
In this part, you've created the initial microservice solution, which already contains a few infrastructure services. We will create our first business service in the [next part](part-02.md).
In this part, you've created the initial microservice solution, which already contains a few infrastructure services. We will create our first business service in the [next part](part-02.md).

29
docs/en/tutorials/microservice/part-05.md

@ -628,7 +628,7 @@ export const APP_ROUTES: Routes = [
// ...
{
path: 'order-service',
children: ORDER_SERVICE_ROUTES,
loadChildren: () => import('ordering-service').then(c =>c.ORDER_SERVICE_ROUTES),
},
];
```
@ -636,12 +636,8 @@ export const APP_ROUTES: Routes = [
```typescript
// order-service.routes.ts
export const ORDER_SERVICE_ROUTES: Routes = [
{
path: '',
pathMatch: 'full',
component: RouterOutletComponent,
},
{ path: 'orders', children: ORDER_ROUTES },
{ path: 'orders', loadComponent: () => import('./order/order.component').then(c => c.OrderComponent) },
{ path: '**', redirectTo: 'orders' }
];
```
@ -657,17 +653,16 @@ import { OrderDto, OrderService } from './proxy/ordering-service/services';
@Component({
selector: 'lib-order',
templateUrl: './order.component.html',
styleUrl: './order.component.css'
styleUrl: './order.component.css',
imports: [CommonModule]
})
export class OrderComponent {
items: OrderDto[] = [];
private readonly proxy = inject(OrderService);
private readonly orderService = inject(OrderService);
constructor() {
this.proxy.getList().subscribe((res) => {
this.orderService.getList().subscribe((res) => {
this.items = res;
});
}
@ -686,11 +681,13 @@ export class OrderComponent {
<th>Product Id</th>
<th>Customer Name</th>
</tr>
<tr *ngFor="let item of items">
<td>{%{{{item.id}}}%}</td>
<td>{%{{{item.productId}}}%}</td>
<td>{%{{{item.customerName}}}%}</td>
</tr>
@for (item of items; track item.id) {
<tr>
<td>{%{{{item.id}}}%}</td>
<td>{%{{{item.productId}}}%}</td>
<td>{%{{{item.customerName}}}%}</td>
</tr>
}
</thead>
</table>
</div>

12
docs/en/tutorials/microservice/part-06.md

@ -314,11 +314,13 @@ Open the `order.component.html` file (the `order.component.html` file under the
<th>Product Name</th>
<th>Customer Name</th>
</tr>
<tr *ngFor="let item of items">
<td>{%{{{item.id}}}%}</td>
<td>{%{{{item.productName}}}%}</td>
<td>{%{{{item.customerName}}}%}</td>
</tr>
@for (item of items; track item.id) {
<tr>
<td>{%{{{item.id}}}%}</td>
<td>{%{{{item.productName}}}%}</td>
<td>{%{{{item.customerName}}}%}</td>
</tr>
}
</thead>
</table>
</div>

111
docs/en/tutorials/todo/layered/index.md

@ -139,7 +139,7 @@ Ensure the `TodoApp.HttpApi.Host` project is the startup project, then run the a
![todo-swagger-ui-initial](../images/todo-swagger-ui-initial.png)
You can explore and test your HTTP API with this UI. Now, we can set the `TodoApp.Blazor` as the startup project and run it to open the actual Blazor application UI:
You can explore and test your HTTP API with this UI. Now, we can set the {{if UI=="Blazor"}}`TodoApp.Blazor`{{else if UI=="MAUIBlazor"}}`TodoApp.MauiBlazor`{{end}} as the startup project and run it to open the actual Blazor application UI:
{{else if UI=="NG"}}
@ -577,7 +577,11 @@ If you open the [Swagger UI](https://swagger.io/tools/swagger-ui/) by entering t
### Index.razor.cs
Open the `Index.razor.cs` file in the `Pages` folder of the {{if UI=="Blazor" || UI=="BlazorWebApp"}} *TodoApp.Blazor.Client* {{else if UI=="BlazorServer"}} *TodoApp.Blazor* {{else if UI=="MAUIBlazor"}} *TodoApp.MauiBlazor* {{end}} project and replace the content with the following code block:
Open the `Index.razor.cs` file in the `Pages` folder of the {{if UI=="Blazor" || UI=="BlazorWebApp"}} `TodoApp.Blazor.Client` {{else if UI=="BlazorServer"}} `TodoApp.Blazor` {{else if UI=="MAUIBlazor"}} `TodoApp.MauiBlazor` {{end}} project and replace the content with the following code block:
{{if UI=="MAUIBlazor"}}
_(Create this file if it doesn't exist)_
{{end}}
```csharp
using Microsoft.AspNetCore.Components;
@ -756,45 +760,46 @@ We can then use `todoService` to use the server-side HTTP APIs, as we'll do in t
Open the `/angular/src/app/home/home.component.ts` file and replace its content with the following code block:
```js
```ts
import {Component, inject, OnInit} from '@angular/core';
import {FormsModule} from '@angular/forms';
import { ToasterService } from '@abp/ng.theme.shared';
import { Component, OnInit, inject } from '@angular/core';
import { TodoItemDto, TodoService } from '@proxy';
@Component({
selector: 'app-home',
standalone: false,
templateUrl: './home.component.html',
styleUrls: ['./home.component.scss']
selector: 'app-home',
templateUrl: './home.component.html',
styleUrls: ['./home.component.scss'],
imports: [FormsModule]
})
export class HomeComponent implements OnInit {
todoItems: TodoItemDto[];
newTodoText: string;
todoItems: TodoItemDto[];
newTodoText: string;
readonly todoService = inject(TodoService);
readonly toasterService = inject(ToasterService);
private readonly todoService = inject(TodoService);
private readonly toasterService = inject(ToasterService);
ngOnInit(): void {
this.todoService.getList().subscribe(response => {
this.todoItems = response;
});
}
ngOnInit(): void {
this.todoService.getList().subscribe(response => {
this.todoItems = response;
});
}
create(): void {
this.todoService.create(this.newTodoText).subscribe((result) => {
this.todoItems = this.todoItems.concat(result);
this.newTodoText = null;
});
}
create(): void{
this.todoService.create(this.newTodoText).subscribe((result) => {
this.todoItems = this.todoItems.concat(result);
this.newTodoText = null;
});
}
delete(id: string): void {
this.todoService.delete(id).subscribe(() => {
this.todoItems = this.todoItems.filter(item => item.id !== id);
this.toasterService.info('Deleted the todo item.');
});
}
delete(id: string): void {
this.todoService.delete(id).subscribe(() => {
this.todoItems = this.todoItems.filter(item => item.id !== id);
this.toasterService.info('Deleted the todo item.');
});
}
}
```
We've used `todoService` to get the list of todo items and assigned the returning value to the `todoItems` array. We've also added `create` and `delete` methods. These methods will be used on the view side.
@ -805,31 +810,35 @@ Open the `/angular/src/app/home/home.component.html` file and replace its conten
```html
<div class="container">
<div class="card">
<div class="card-header">
<div class="card-title">TODO LIST</div>
</div>
<div class="card-body">
<!-- FORM FOR NEW TODO ITEMS -->
<form class="row row-cols-lg-auto g-3 align-items-center" (ngSubmit)="create()">
<div class="col-12">
<div class="input-group">
<input name="NewTodoText" type="text" [(ngModel)]="newTodoText" class="form-control" placeholder="enter text..." />
</div>
<div class="card">
<div class="card-header">
<div class="card-title">TODO LIST</div>
</div>
<div class="col-12">
<button type="submit" class="btn btn-primary">Submit</button>
<div class="card-body">
<!-- FORM FOR NEW TODO ITEMS -->
<form class="row row-cols-lg-auto g-3 align-items-center" (ngSubmit)="create()">
<div class="col-12">
<div class="input-group">
<input name="NewTodoText" type="text" [(ngModel)]="newTodoText" class="form-control" placeholder="enter text..." />
</div>
</div>
<div class="col-12">
<button type="submit" class="btn btn-primary">Submit</button>
</div>
</form>
<!-- TODO ITEMS LIST -->
<ul id="TodoList">
@for (todoItem of todoItems; track todoItem.id) {
<li>
<i class="fa fa-trash-o" (click)="delete(todoItem.id)"></i> {%{{{ todoItem.text }}}%}
</li>
}
</ul>
</div>
</form>
<!-- TODO ITEMS LIST -->
<ul id="TodoList">
<li *ngFor="let todoItem of todoItems">
<i class="fa fa-trash-o" (click)="delete(todoItem.id)"></i> {%{{{ todoItem.text }}}%}
</li>
</ul>
</div>
</div>
</div>
```
### home.component.scss

113
docs/en/tutorials/todo/single-layer/index.md

@ -567,7 +567,7 @@ If you open [Swagger UI](https://swagger.io/tools/swagger-ui/) by entering the `
### Index.razor.cs
Open the `Index.razor.cs` file in the `Pages` folder{{if UI=="Blazor"}} in your `Todo.Blazor` project{{end}} and replace the content with the following code block:
Open the `Index.razor.cs` file in the {{if UI=="BlazorServer"}}`Components/Pages` {{else}} `Pages` {{end}} folder{{if UI=="Blazor"}} in your `Todo.Blazor` project{{end}} and replace the content with the following code block:
```csharp
{{if UI=="Blazor"}}
@ -580,7 +580,11 @@ using TodoApp.Services;
using TodoApp.Services.Dtos;
{{end}}
{{if UI=="Blazor"}}
namespace TodoApp.Pages;
{{else}}
namespace TodoApp.Components.Pages;
{{end}}
public partial class Index
{
@ -615,7 +619,7 @@ This class uses the {{if UI=="Blazor"}}`ITodoAppService`{{else}}`TodoAppService`
### Index.razor
Open the `Index.razor` file in the `Pages` folder and replace the content with the following code block:
Open the `Index.razor` file in the {{if UI=="BlazorServer"}}`Components/Pages`{{else}}`Pages`{{end}} folder and replace the content with the following code block:
```xml
@page "/"
@ -658,7 +662,7 @@ Open the `Index.razor` file in the `Pages` folder and replace the content with t
### Index.razor.css
As the final touch, open the `Index.razor.css` file in the `Pages` folder and add the following code block at the end of the file:
As the final touch, open the `Index.razor.css` file in the {{if UI=="BlazorServer"}}`Components/Pages`{{else}}`Pages`{{end}} folder and add the following code block at the end of the file:
````css
#TodoList{
@ -724,43 +728,43 @@ Then, we can use the `TodoService` to use the server-side HTTP APIs, as we'll do
Open the `/angular/src/app/home/home.component.ts` file and replace its content with the following code block:
```ts
import { ToasterService } from "@abp/ng.theme.shared";
import { Component, OnInit, inject } from '@angular/core';
import { TodoItemDto } from "@proxy/services/dtos";
import { TodoService } from "@proxy/services";
import {Component, inject, OnInit} from '@angular/core';
import {FormsModule} from '@angular/forms';
import { ToasterService } from '@abp/ng.theme.shared';
import { TodoItemDto, TodoService } from '@proxy';
@Component({
selector: 'app-home',
templateUrl: './home.component.html',
styleUrls: ['./home.component.scss'],
selector: 'app-home',
templateUrl: './home.component.html',
styleUrls: ['./home.component.scss'],
imports: [FormsModule]
})
export class HomeComponent implements OnInit {
todoItems: TodoItemDto[];
newTodoText: string;
todoItems: TodoItemDto[];
newTodoText: string;
readonly todoService = inject(TodoService);
readonly toasterService = inject(ToasterService);
private readonly todoService = inject(TodoService);
private readonly toasterService = inject(ToasterService);
ngOnInit(): void {
this.todoService.getList().subscribe(response => {
this.todoItems = response;
});
}
ngOnInit(): void {
this.todoService.getList().subscribe(response => {
this.todoItems = response;
});
}
create(): void {
this.todoService.create(this.newTodoText).subscribe((result) => {
this.todoItems = this.todoItems.concat(result);
this.newTodoText = null;
});
}
create(): void{
this.todoService.create(this.newTodoText).subscribe((result) => {
this.todoItems = this.todoItems.concat(result);
this.newTodoText = null;
});
}
delete(id: string): void {
this.todoService.delete(id).subscribe(() => {
this.todoItems = this.todoItems.filter(item => item.id !== id);
this.toasterService.info('Deleted the todo item.');
});
}
delete(id: string): void {
this.todoService.delete(id).subscribe(() => {
this.todoItems = this.todoItems.filter(item => item.id !== id);
this.toasterService.info('Deleted the todo item.');
});
}
}
```
@ -772,30 +776,33 @@ Open the `/angular/src/app/home/home.component.html` file and replace its conten
````html
<div class="container">
<div class="card">
<div class="card-header">
<div class="card-title">TODO LIST</div>
</div>
<div class="card-body">
<!-- FORM FOR NEW TODO ITEMS -->
<form class="row row-cols-lg-auto g-3 align-items-center" (ngSubmit)="create()">
<div class="col-12">
<div class="input-group">
<input name="NewTodoText" type="text" [(ngModel)]="newTodoText" class="form-control" placeholder="enter text..." />
</div>
<div class="card">
<div class="card-header">
<div class="card-title">TODO LIST</div>
</div>
<div class="col-12">
<button type="submit" class="btn btn-primary">Submit</button>
<div class="card-body">
<!-- FORM FOR NEW TODO ITEMS -->
<form class="row row-cols-lg-auto g-3 align-items-center" (ngSubmit)="create()">
<div class="col-12">
<div class="input-group">
<input name="NewTodoText" type="text" [(ngModel)]="newTodoText" class="form-control" placeholder="enter text..." />
</div>
</div>
<div class="col-12">
<button type="submit" class="btn btn-primary">Submit</button>
</div>
</form>
<!-- TODO ITEMS LIST -->
<ul id="TodoList">
@for (todoItem of todoItems; track todoItem.id) {
<li>
<i class="fa fa-trash-o" (click)="delete(todoItem.id)"></i> {%{{{ todoItem.text }}}%}
</li>
}
</ul>
</div>
</form>
<!-- TODO ITEMS LIST -->
<ul id="TodoList">
<li *ngFor="let todoItem of todoItems">
<i class="fa fa-trash-o" (click)="delete(todoItem.id)"></i> {%{{{ todoItem.text }}}%}
</li>
</ul>
</div>
</div>
</div>
````

3
framework/src/Volo.Abp.AspNetCore.Mvc/Volo/Abp/AspNetCore/Mvc/ApplicationPartSorter.cs

@ -15,7 +15,8 @@ public static class ApplicationPartSorter
{
var orderedModuleAssemblies = moduleContainer.Modules
.Select((moduleDescriptor, index) => new { moduleDescriptor.Assembly, index })
.ToDictionary(x => x.Assembly, x => x.index);
.GroupBy(x => x.Assembly)
.ToDictionary(g => g.Key, g => g.First().index);
var modulesAssemblies = moduleContainer.Modules.Select(x => x.Assembly).ToList();
var sortedTypes = partManager.ApplicationParts

31
framework/src/Volo.Abp.Authorization/Volo/Abp/Authorization/Permissions/PermissionChecker.cs

@ -48,7 +48,7 @@ public class PermissionChecker : IPermissionChecker, ITransientDependency
{
return false;
}
if (!permission.IsEnabled)
{
return false;
@ -92,12 +92,12 @@ public class PermissionChecker : IPermissionChecker, ITransientDependency
return isGranted;
}
public async Task<MultiplePermissionGrantResult> IsGrantedAsync(string[] names)
public virtual async Task<MultiplePermissionGrantResult> IsGrantedAsync(string[] names)
{
return await IsGrantedAsync(PrincipalAccessor.Principal, names);
}
public async Task<MultiplePermissionGrantResult> IsGrantedAsync(ClaimsPrincipal? claimsPrincipal, string[] names)
public virtual async Task<MultiplePermissionGrantResult> IsGrantedAsync(ClaimsPrincipal? claimsPrincipal, string[] names)
{
Check.NotNull(names, nameof(names));
@ -146,16 +146,27 @@ public class PermissionChecker : IPermissionChecker, ITransientDependency
claimsPrincipal);
var multipleResult = await provider.CheckAsync(context);
foreach (var grantResult in multipleResult.Result.Where(grantResult =>
result.Result.ContainsKey(grantResult.Key) &&
result.Result[grantResult.Key] == PermissionGrantResult.Undefined &&
grantResult.Value != PermissionGrantResult.Undefined))
foreach (var grantResult in multipleResult.Result.Where(x => result.Result.ContainsKey(x.Key)))
{
result.Result[grantResult.Key] = grantResult.Value;
permissionDefinitions.RemoveAll(x => x.Name == grantResult.Key);
switch (grantResult.Value)
{
case PermissionGrantResult.Granted:
{
if (result.Result[grantResult.Key] != PermissionGrantResult.Prohibited)
{
result.Result[grantResult.Key] = PermissionGrantResult.Granted;
}
break;
}
case PermissionGrantResult.Prohibited:
result.Result[grantResult.Key] = PermissionGrantResult.Prohibited;
permissionDefinitions.RemoveAll(x => x.Name == grantResult.Key);
break;
}
}
if (result.AllGranted || result.AllProhibited)
if (result.AllProhibited)
{
break;
}

9
framework/src/Volo.Abp.Core/Volo/Abp/AbpApplicationBase.cs

@ -2,6 +2,7 @@
using System.Collections.Generic;
using System.Linq;
using System.Reflection;
using System.Runtime.InteropServices;
using System.Threading.Tasks;
using JetBrains.Annotations;
using Microsoft.Extensions.Configuration;
@ -200,7 +201,13 @@ public abstract class AbpApplicationBase : IAbpApplication
using var scope = ServiceProvider.CreateScope();
var abpHostEnvironment = scope.ServiceProvider.GetRequiredService<IAbpHostEnvironment>();
var configuration = scope.ServiceProvider.GetRequiredService<IConfiguration>();
return abpHostEnvironment.IsDevelopment() && configuration.GetValue<bool?>("Abp:Telemetry:IsEnabled") != false;
if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows) || RuntimeInformation.IsOSPlatform(OSPlatform.OSX) || RuntimeInformation.IsOSPlatform(OSPlatform.Linux))
{
return abpHostEnvironment.IsDevelopment() && configuration.GetValue<bool?>("Abp:Telemetry:IsEnabled") != false;
}
return false;
}
//TODO: We can extract a new class for this

5
framework/src/Volo.Abp.Core/Volo/Abp/Internal/Telemetry/Activity/Providers/TelemetrySolutionInfoEnricher.cs

@ -114,7 +114,10 @@ internal sealed class TelemetrySolutionInfoEnricher : TelemetryActivityEventEnri
}
var moduleJsonFileContent = File.ReadAllText(modulePath);
using var moduleDoc = JsonDocument.Parse(moduleJsonFileContent);
using var moduleDoc = JsonDocument.Parse(moduleJsonFileContent, new JsonDocumentOptions
{
AllowTrailingCommas = true
});
if (!moduleDoc.RootElement.TryGetProperty("imports", out var imports))
{

18
framework/src/Volo.Abp.Core/Volo/Abp/Internal/Telemetry/Activity/Storage/TelemetryActivityStorage.cs

@ -25,6 +25,8 @@ public class TelemetryActivityStorage : ITelemetryActivityStorage, ISingletonDep
public TelemetryActivityStorage()
{
CreateDirectoryIfNotExist();
DeleteExistingOldInformation();
State = LoadState();
}
@ -166,6 +168,22 @@ public class TelemetryActivityStorage : ITelemetryActivityStorage, ISingletonDep
}
}
private static void DeleteExistingOldInformation()
{
try
{
var file = new FileInfo(TelemetryPaths.ActivityStorage);
if (file.Exists && file.CreationTime < new DateTime(2025, 12, 01))
{
file.Delete();
}
}
catch
{
// Ignored
}
}
private static TelemetryActivityStorageState LoadState()
{
try

1
framework/src/Volo.Abp.Core/Volo/Abp/Internal/Telemetry/Constants/ActivityPropertyNames.cs

@ -12,6 +12,7 @@ public static class ActivityPropertyNames
public const string IpAddress = "IpAddress";
public const string IsFirstSession = "IsFirstSession";
public const string DeviceId = "DeviceId";
public const string UserDeviceId = "UserDeviceId";
public const string DeviceLanguage = "DeviceLanguage";
public const string OperatingSystem = "OperatingSystem";
public const string CountryIsoCode = "CountryIsoCode";

8
framework/src/Volo.Abp.Core/Volo/Abp/Internal/Telemetry/Constants/DeviceManager.cs

@ -133,7 +133,7 @@ static internal class DeviceManager
{
try
{
return GetProcessorIdForWindows();
return GetBaseBoardSerialNumberForWindows();
}
catch
{
@ -142,10 +142,10 @@ static internal class DeviceManager
return GetWindowsMachineUniqueId();
}
private static string GetProcessorIdForWindows()
private static string GetBaseBoardSerialNumberForWindows()
{
using (var managementObjectSearcher =
new System.Management.ManagementObjectSearcher("SELECT ProcessorId FROM Win32_Processor"))
new System.Management.ManagementObjectSearcher("SELECT SerialNumber FROM Win32_BaseBoard"))
{
using (var searcherObj = managementObjectSearcher.Get())
{
@ -156,7 +156,7 @@ static internal class DeviceManager
var managementObjectEnumerator = searcherObj.GetEnumerator();
managementObjectEnumerator.MoveNext();
return managementObjectEnumerator.Current.GetPropertyValue("ProcessorId").ToString()!;
return managementObjectEnumerator.Current.GetPropertyValue("SerialNumber").ToString()!;
}
}
}

10
framework/src/Volo.Abp.Core/Volo/Abp/Internal/Telemetry/EnvironmentInspection/Detectors/AbpStudioDetector.cs

@ -40,7 +40,10 @@ internal sealed class AbpStudioDetector : SoftwareDetector
return null;
}
using var fs = new FileStream(ideStateJsonPath, FileMode.Open, FileAccess.Read, FileShare.ReadWrite);
using var doc = JsonDocument.Parse(fs);
using var doc = JsonDocument.Parse(fs, new JsonDocumentOptions
{
AllowTrailingCommas = true
});
return doc.RootElement.TryGetProperty("theme", out var themeElement) ? themeElement.GetString() : null;
}
@ -55,7 +58,10 @@ internal sealed class AbpStudioDetector : SoftwareDetector
}
using var fs = new FileStream(extensionsFilePath, FileMode.Open, FileAccess.Read, FileShare.ReadWrite);
using var doc = JsonDocument.Parse(fs);
using var doc = JsonDocument.Parse(fs, new JsonDocumentOptions
{
AllowTrailingCommas = true
});
if (doc.RootElement.TryGetProperty("Extensions", out var extensionsElement) &&
extensionsElement.ValueKind == JsonValueKind.Array)

10
framework/src/Volo.Abp.Core/Volo/Abp/Internal/Telemetry/EnvironmentInspection/Detectors/VisualStudioCodeDetector.cs

@ -77,7 +77,10 @@ internal sealed class VisualStudioCodeDetector : SoftwareDetector
{
try
{
using var jsonDoc = JsonDocument.Parse(File.ReadAllText(productJson));
using var jsonDoc = JsonDocument.Parse(File.ReadAllText(productJson), new JsonDocumentOptions
{
AllowTrailingCommas = true
});
var root = jsonDoc.RootElement;
if (root.TryGetProperty("version", out var versionProp))
{
@ -105,7 +108,10 @@ internal sealed class VisualStudioCodeDetector : SoftwareDetector
{
try
{
using var json = JsonDocument.Parse( File.ReadAllText(settingsPath));
using var json = JsonDocument.Parse( File.ReadAllText(settingsPath), new JsonDocumentOptions
{
AllowTrailingCommas = true
});
var root = json.RootElement;
if (root.TryGetProperty("theme", out var themeProp))
{

6
framework/src/Volo.Abp.Core/Volo/Abp/Internal/Telemetry/Helpers/AbpPackageMetadataReader.cs

@ -49,11 +49,13 @@ static internal class AbpProjectMetadataReader
private static AbpProjectMetaData ReadOrCreateMetadata(string packagePath)
{
var fileContent = File.ReadAllText(packagePath);
var metadata = new AbpProjectMetaData();
using var document = JsonDocument.Parse(fileContent);
using var document = JsonDocument.Parse(fileContent, new JsonDocumentOptions
{
AllowTrailingCommas = true
});
var root = document.RootElement;
if (TryGetProjectId(root,out var projectId))

36
framework/src/Volo.Abp.Core/Volo/Abp/Internal/Telemetry/TelemetryService.cs

@ -2,6 +2,7 @@
using System.Collections.Generic;
using System.Diagnostics;
using System.Threading.Tasks;
using Microsoft.Extensions.DependencyInjection;
using Volo.Abp.DependencyInjection;
using Volo.Abp.Internal.Telemetry.Activity.Contracts;
using Volo.Abp.Internal.Telemetry.Constants;
@ -11,17 +12,11 @@ namespace Volo.Abp.Internal.Telemetry;
public class TelemetryService : ITelemetryService, IScopedDependency
{
private readonly ITelemetryActivitySender _telemetryActivitySender;
private readonly ITelemetryActivityEventBuilder _telemetryActivityEventBuilder;
private readonly ITelemetryActivityStorage _telemetryActivityStorage;
private readonly IServiceScopeFactory _serviceScopeFactory;
public TelemetryService(ITelemetryActivitySender telemetryActivitySender,
ITelemetryActivityEventBuilder telemetryActivityEventBuilder,
ITelemetryActivityStorage telemetryActivityStorage)
public TelemetryService(IServiceScopeFactory serviceScopeFactory)
{
_telemetryActivitySender = telemetryActivitySender;
_telemetryActivityEventBuilder = telemetryActivityEventBuilder;
_telemetryActivityStorage = telemetryActivityStorage;
_serviceScopeFactory = serviceScopeFactory;
}
@ -74,24 +69,37 @@ public class TelemetryService : ITelemetryService, IScopedDependency
{
_ = Task.Run(async () =>
{
await BuildAndSendActivityAsync(context);
using var scope = _serviceScopeFactory.CreateScope();
var telemetryActivityEventBuilder = scope.ServiceProvider.GetRequiredService<ITelemetryActivityEventBuilder>();
var telemetryActivityStorage = scope.ServiceProvider.GetRequiredService<ITelemetryActivityStorage>();
var telemetryActivitySender = scope.ServiceProvider.GetRequiredService<ITelemetryActivitySender>();
await BuildAndSendActivityAsync(context,
telemetryActivityEventBuilder,
telemetryActivityStorage,
telemetryActivitySender);
});
return Task.CompletedTask;
}
private async Task BuildAndSendActivityAsync(ActivityContext context)
private static async Task BuildAndSendActivityAsync(
ActivityContext context,
ITelemetryActivityEventBuilder telemetryActivityEventBuilder,
ITelemetryActivityStorage telemetryActivityStorage,
ITelemetryActivitySender telemetryActivitySender)
{
try
{
var activityEvent = await _telemetryActivityEventBuilder.BuildAsync(context);
var activityEvent = await telemetryActivityEventBuilder.BuildAsync(context);
if (activityEvent is null)
{
return;
}
_telemetryActivityStorage.SaveActivity(activityEvent);
await _telemetryActivitySender.TrySendQueuedActivitiesAsync();
telemetryActivityStorage.SaveActivity(activityEvent);
await telemetryActivitySender.TrySendQueuedActivitiesAsync();
}
catch
{

2
framework/src/Volo.Abp.EntityFrameworkCore.PostgreSql/Volo.Abp.EntityFrameworkCore.PostgreSql.csproj

@ -22,8 +22,6 @@
<ItemGroup>
<PackageReference Include="Npgsql.EntityFrameworkCore.PostgreSQL" />
<PackageReference Include="Microsoft.EntityFrameworkCore" VersionOverride="10.0.0-rc.2.25502.107" />
<PackageReference Include="Microsoft.EntityFrameworkCore.Relational" VersionOverride="10.0.0-rc.2.25502.107" />
</ItemGroup>
</Project>

7
framework/src/Volo.Abp.ExceptionHandling/Volo/Abp/AspNetCore/ExceptionHandling/DefaultExceptionToErrorInfoConverter.cs

@ -21,17 +21,20 @@ namespace Volo.Abp.AspNetCore.ExceptionHandling;
public class DefaultExceptionToErrorInfoConverter : IExceptionToErrorInfoConverter, ITransientDependency
{
protected AbpExceptionHandlingOptions ExceptionHandlingOptions { get; }
protected AbpExceptionLocalizationOptions LocalizationOptions { get; }
protected IStringLocalizerFactory StringLocalizerFactory { get; }
protected IStringLocalizer<AbpExceptionHandlingResource> L { get; }
protected IServiceProvider ServiceProvider { get; }
public DefaultExceptionToErrorInfoConverter(
IOptions<AbpExceptionHandlingOptions> exceptionHandlingOptions,
IOptions<AbpExceptionLocalizationOptions> localizationOptions,
IStringLocalizerFactory stringLocalizerFactory,
IStringLocalizer<AbpExceptionHandlingResource> stringLocalizer,
IServiceProvider serviceProvider)
{
ExceptionHandlingOptions = exceptionHandlingOptions.Value;
ServiceProvider = serviceProvider;
StringLocalizerFactory = stringLocalizerFactory;
L = stringLocalizer;
@ -327,8 +330,8 @@ public class DefaultExceptionToErrorInfoConverter : IExceptionToErrorInfoConvert
{
return new AbpExceptionHandlingOptions
{
SendExceptionsDetailsToClients = false,
SendStackTraceToClients = true
SendExceptionsDetailsToClients = ExceptionHandlingOptions.SendExceptionsDetailsToClients,
SendStackTraceToClients = ExceptionHandlingOptions.SendStackTraceToClients
};
}
}

13
framework/test/Volo.Abp.AspNetCore.Mvc.Tests/Volo/Abp/AspNetCore/Mvc/ApplicationPart/ApplicationPartSorter_Tests.cs

@ -26,6 +26,13 @@ public class ApplicationPartSorter_Tests
partManager.ApplicationParts.Add(new AssemblyPart(assembly));
moduleDescriptors.Add(CreateModuleDescriptor(assembly));
}
var dumplicateAssembly = AssemblyBuilder.DefineDynamicAssembly(new AssemblyName($"ModuleB.dll"), AssemblyBuilderAccess.Run);
partManager.ApplicationParts.Add(new AssemblyPart(dumplicateAssembly));
partManager.ApplicationParts.Add(new AssemblyPart(dumplicateAssembly));
moduleDescriptors.Add(CreateModuleDescriptor(dumplicateAssembly));
moduleDescriptors.Add(CreateModuleDescriptor(dumplicateAssembly));
var randomApplicationParts = partManager.ApplicationParts.OrderBy(x => Guid.NewGuid()).ToList(); // Shuffle the parts
// Additional part
@ -44,7 +51,7 @@ public class ApplicationPartSorter_Tests
ApplicationPartSorter.Sort(partManager, moduleContainer);
// Act
partManager.ApplicationParts.Count.ShouldBe(13); // 10 modules + 3 additional parts
partManager.ApplicationParts.Count.ShouldBe(15); // 10 modules + 3 additional parts + 2 duplicate parts
var applicationParts = partManager.ApplicationParts.Reverse().ToList(); // Reverse the order to match the expected output
@ -60,7 +67,9 @@ public class ApplicationPartSorter_Tests
applicationParts[9].ShouldBeOfType<AssemblyPart>().Assembly.GetName().Name.ShouldStartWith("ModuleA7");
applicationParts[10].ShouldBeOfType<AssemblyPart>().Assembly.GetName().Name.ShouldStartWith("ModuleA8");
applicationParts[11].ShouldBeOfType<AssemblyPart>().Assembly.GetName().Name.ShouldStartWith("ModuleA9");
applicationParts[12].ShouldBeOfType<CompiledRazorAssemblyPart>().Assembly.ShouldBe(typeof(AbpVirtualFileSystemModule).Assembly);
applicationParts[12].ShouldBeOfType<AssemblyPart>().Assembly.GetName().Name.ShouldStartWith("ModuleB");
applicationParts[13].ShouldBeOfType<AssemblyPart>().Assembly.GetName().Name.ShouldStartWith("ModuleB");
applicationParts[14].ShouldBeOfType<CompiledRazorAssemblyPart>().Assembly.ShouldBe(typeof(AbpVirtualFileSystemModule).Assembly);
}
private static IModuleContainer CreateFakeModuleContainer(List<IAbpModuleDescriptor> moduleDescriptors)

2
framework/test/Volo.Abp.Authorization.Tests/Volo/Abp/Authorization/AbpAuthorizationTestModule.cs

@ -31,6 +31,8 @@ public class AbpAuthorizationTestModule : AbpModule
{
options.ValueProviders.Add<TestPermissionValueProvider1>();
options.ValueProviders.Add<TestPermissionValueProvider2>();
options.ValueProviders.Add<TestProhibitedPermissionValueProvider1>();
options.ValueProviders.Add<TestProhibitedPermissionValueProvider2>();
});
}
}

27
framework/test/Volo.Abp.Authorization.Tests/Volo/Abp/Authorization/PermissionChecker_Tests.cs

@ -8,7 +8,7 @@ namespace Volo.Abp.Authorization;
public class PermissionChecker_Tests: AuthorizationTestBase
{
private readonly IPermissionChecker _permissionChecker;
public PermissionChecker_Tests()
{
_permissionChecker = GetRequiredService<IPermissionChecker>();
@ -21,6 +21,13 @@ public class PermissionChecker_Tests: AuthorizationTestBase
(await _permissionChecker.IsGrantedAsync("UndefinedPermission")).ShouldBe(false);
}
[Fact]
public async Task IsGranted_ProhibitedAsync()
{
(await _permissionChecker.IsGrantedAsync("MyPermission8")).ShouldBe(false);
(await _permissionChecker.IsGrantedAsync("MyPermission9")).ShouldBe(false);
}
[Fact]
public async Task IsGranted_Multiple_Result_Async()
{
@ -35,7 +42,7 @@ public class PermissionChecker_Tests: AuthorizationTestBase
"MyPermission6",
"MyPermission7"
});
result.Result["MyPermission1"].ShouldBe(PermissionGrantResult.Undefined);
result.Result["MyPermission2"].ShouldBe(PermissionGrantResult.Prohibited);
result.Result["UndefinedPermission"].ShouldBe(PermissionGrantResult.Prohibited);
@ -44,6 +51,18 @@ public class PermissionChecker_Tests: AuthorizationTestBase
result.Result["MyPermission5"].ShouldBe(PermissionGrantResult.Granted);
result.Result["MyPermission6"].ShouldBe(PermissionGrantResult.Granted);
result.Result["MyPermission7"].ShouldBe(PermissionGrantResult.Granted);
}
}
[Fact]
public async Task IsGranted_Multiple_Result_ProhibitedAsync()
{
var result = await _permissionChecker.IsGrantedAsync(new []
{
"MyPermission8",
"MyPermission9"
});
result.Result["MyPermission8"].ShouldBe(PermissionGrantResult.Prohibited);
result.Result["MyPermission9"].ShouldBe(PermissionGrantResult.Prohibited);
}
}

6
framework/test/Volo.Abp.Authorization.Tests/Volo/Abp/Authorization/TestServices/AuthorizationTestPermissionDefinitionProvider.cs

@ -16,11 +16,11 @@ public class AuthorizationTestPermissionDefinitionProvider : PermissionDefinitio
var group = context.AddGroup("TestGroup");
group[PermissionDefinitionContext.KnownPropertyNames.CurrentProviderName].ShouldBe(typeof(AuthorizationTestPermissionDefinitionProvider).FullName);
var permission1 = group.AddPermission("MyAuthorizedService1");
permission1[PermissionDefinitionContext.KnownPropertyNames.CurrentProviderName].ShouldBe(typeof(AuthorizationTestPermissionDefinitionProvider).FullName);
group.AddPermission("MyPermission1").StateCheckers.Add(new TestRequireEditionPermissionSimpleStateChecker());
group.AddPermission("MyPermission2");
group.AddPermission("MyPermission3");
@ -28,6 +28,8 @@ public class AuthorizationTestPermissionDefinitionProvider : PermissionDefinitio
group.AddPermission("MyPermission5");
group.AddPermission("MyPermission6").WithProviders(nameof(TestPermissionValueProvider1));
group.AddPermission("MyPermission7").WithProviders(nameof(TestPermissionValueProvider2));
group.AddPermission("MyPermission8");
group.AddPermission("MyPermission9");
group.GetPermissionOrNull("MyAuthorizedService1").ShouldNotBeNull();

38
framework/test/Volo.Abp.Authorization.Tests/Volo/Abp/Authorization/TestServices/TestProhibitedPermissionValueProvider1.cs

@ -0,0 +1,38 @@
using System.Linq;
using System.Threading.Tasks;
using Volo.Abp.Authorization.Permissions;
namespace Volo.Abp.Authorization.TestServices;
public class TestProhibitedPermissionValueProvider1 : PermissionValueProvider
{
public TestProhibitedPermissionValueProvider1(IPermissionStore permissionStore) : base(permissionStore)
{
}
public override string Name => "TestProhibitedPermissionValueProvider1";
public override Task<PermissionGrantResult> CheckAsync(PermissionValueCheckContext context)
{
var result = PermissionGrantResult.Undefined;
if (context.Permission.Name == "MyPermission8" || context.Permission.Name == "MyPermission9")
{
result = PermissionGrantResult.Granted;
}
return Task.FromResult(result);
}
public override Task<MultiplePermissionGrantResult> CheckAsync(PermissionValuesCheckContext context)
{
var result = new MultiplePermissionGrantResult();
foreach (var name in context.Permissions.Select(x => x.Name))
{
result.Result.Add(name, name == "MyPermission8" || name == "MyPermission9"
? PermissionGrantResult.Granted
: PermissionGrantResult.Undefined);
}
return Task.FromResult(result);
}
}

38
framework/test/Volo.Abp.Authorization.Tests/Volo/Abp/Authorization/TestServices/TestProhibitedPermissionValueProvider2.cs

@ -0,0 +1,38 @@
using System.Linq;
using System.Threading.Tasks;
using Volo.Abp.Authorization.Permissions;
namespace Volo.Abp.Authorization.TestServices;
public class TestProhibitedPermissionValueProvider2 : PermissionValueProvider
{
public TestProhibitedPermissionValueProvider2(IPermissionStore permissionStore) : base(permissionStore)
{
}
public override string Name => "TestProhibitedPermissionValueProvider2";
public override Task<PermissionGrantResult> CheckAsync(PermissionValueCheckContext context)
{
var result = PermissionGrantResult.Undefined;
if (context.Permission.Name == "MyPermission8" || context.Permission.Name == "MyPermission9")
{
result = PermissionGrantResult.Prohibited;
}
return Task.FromResult(result);
}
public override Task<MultiplePermissionGrantResult> CheckAsync(PermissionValuesCheckContext context)
{
var result = new MultiplePermissionGrantResult();
foreach (var name in context.Permissions.Select(x => x.Name))
{
result.Result.Add(name, name == "MyPermission8" || name == "MyPermission9"
? PermissionGrantResult.Prohibited
: PermissionGrantResult.Undefined);
}
return Task.FromResult(result);
}
}

9
latest-versions.json

@ -1,4 +1,13 @@
[
{
"version": "10.0.0",
"releaseDate": "",
"type": "stable",
"message": "",
"leptonx": {
"version": "5.0.0"
}
},
{
"version": "9.3.6",
"releaseDate": "",

6
modules/basic-theme/test/Volo.Abp.AspNetCore.Mvc.UI.Bootstrap.Demo/package.json

@ -3,8 +3,8 @@
"name": "asp.net",
"private": true,
"dependencies": {
"@abp/aspnetcore.mvc.ui.theme.shared": "~10.0.0-rc.3",
"@abp/prismjs": "~10.0.0-rc.3",
"@abp/highlight.js": "~10.0.0-rc.3"
"@abp/aspnetcore.mvc.ui.theme.shared": "~10.0.0",
"@abp/prismjs": "~10.0.0",
"@abp/highlight.js": "~10.0.0"
}
}

264
modules/basic-theme/test/Volo.Abp.AspNetCore.Mvc.UI.Bootstrap.Demo/yarn.lock

@ -2,203 +2,203 @@
# yarn lockfile v1
"@abp/aspnetcore.mvc.ui.theme.shared@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.shared/-/aspnetcore.mvc.ui.theme.shared-10.0.0-rc.3.tgz#a68d95a189e79dccb7bc50460565e03777e3823c"
integrity sha512-QvMZy5gVSksLYiGE8VvDQ7n5GKWCyuJF9Y7Kx6/bw+weWKvEk6kiqw5glTMzUOnpkM4kH7bIb8PoJSAycDlvRg==
dependencies:
"@abp/aspnetcore.mvc.ui" "~10.0.0-rc.3"
"@abp/bootstrap" "~10.0.0-rc.3"
"@abp/bootstrap-datepicker" "~10.0.0-rc.3"
"@abp/bootstrap-daterangepicker" "~10.0.0-rc.3"
"@abp/datatables.net-bs5" "~10.0.0-rc.3"
"@abp/font-awesome" "~10.0.0-rc.3"
"@abp/jquery-form" "~10.0.0-rc.3"
"@abp/jquery-validation-unobtrusive" "~10.0.0-rc.3"
"@abp/lodash" "~10.0.0-rc.3"
"@abp/luxon" "~10.0.0-rc.3"
"@abp/malihu-custom-scrollbar-plugin" "~10.0.0-rc.3"
"@abp/moment" "~10.0.0-rc.3"
"@abp/select2" "~10.0.0-rc.3"
"@abp/sweetalert2" "~10.0.0-rc.3"
"@abp/timeago" "~10.0.0-rc.3"
"@abp/aspnetcore.mvc.ui@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui/-/aspnetcore.mvc.ui-10.0.0-rc.3.tgz#8d3cbec33ff9efe7789e5cafb86c39e2488304ca"
integrity sha512-HqbleKwVFVRK0Xxd0XkeyCfX4+JPouEMYvQCL+zo0RDOMfPViPua5ketfU9DDhCCyMfCwy7iW0GeX9NuqEjXwg==
"@abp/aspnetcore.mvc.ui.theme.shared@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.shared/-/aspnetcore.mvc.ui.theme.shared-10.0.0.tgz#ac4150739c6b2d24d27ddc86659e9d2bbdb82548"
integrity sha512-ghockOUBUG4ZoQCKB7H5Jd5ztgnxJsDoVaxpPc/amcF2Nm/7shSA0w2uK5p1Qo7icGoOriE2zM0hfpuKy7JDeQ==
dependencies:
"@abp/aspnetcore.mvc.ui" "~10.0.0"
"@abp/bootstrap" "~10.0.0"
"@abp/bootstrap-datepicker" "~10.0.0"
"@abp/bootstrap-daterangepicker" "~10.0.0"
"@abp/datatables.net-bs5" "~10.0.0"
"@abp/font-awesome" "~10.0.0"
"@abp/jquery-form" "~10.0.0"
"@abp/jquery-validation-unobtrusive" "~10.0.0"
"@abp/lodash" "~10.0.0"
"@abp/luxon" "~10.0.0"
"@abp/malihu-custom-scrollbar-plugin" "~10.0.0"
"@abp/moment" "~10.0.0"
"@abp/select2" "~10.0.0"
"@abp/sweetalert2" "~10.0.0"
"@abp/timeago" "~10.0.0"
"@abp/aspnetcore.mvc.ui@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui/-/aspnetcore.mvc.ui-10.0.0.tgz#3357ba70f5f6545a87755a4c368f373c8cee6f8d"
integrity sha512-S8wSmfRz66ozIm17a4cPJxBDoXRqhNAa+N6uV+gLhVRvTSFAGNvcCsUTCmW4VsEf1Wnaedxwg/cUFjMc6eD6nA==
dependencies:
ansi-colors "^4.1.3"
"@abp/bootstrap-datepicker@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-datepicker/-/bootstrap-datepicker-10.0.0-rc.3.tgz#6d7528d9275cede4bf91b929dd407c744e513014"
integrity sha512-zBLJ9hQXucXOM0GpRyJCMHxdi+C5gaGQtYzguFFGDw+jW5Ht7paoAU+HYS8Dy29zHJHMk+VdO5vJovVIXhfuPg==
"@abp/bootstrap-datepicker@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-datepicker/-/bootstrap-datepicker-10.0.0.tgz#76859087323bec5e8f9d05500b1858374e8d5f11"
integrity sha512-rZo7+l/VWXsRmIKtqq6hGIqlew/nB2axIsaIHnrzuOqoSyq/SqMjBoUoQsvLSfK/YaoloYGj1r/IDmtb+OxCOg==
dependencies:
bootstrap-datepicker "^1.10.1"
"@abp/bootstrap-daterangepicker@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-daterangepicker/-/bootstrap-daterangepicker-10.0.0-rc.3.tgz#85b09ce28da96e84a9ad448cee5b73d581056041"
integrity sha512-VyAZqPZyx/sjGcYYqDPStwUMeQ+nMwud1pEmDgpPWWsRoQBPOVB3PS8KGgW4Fb2oax9i2v6wF5qqLEQkD3CDmA==
"@abp/bootstrap-daterangepicker@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-daterangepicker/-/bootstrap-daterangepicker-10.0.0.tgz#be561035b4778b040470246f71cd5b228c80bbc2"
integrity sha512-njuKNfCg06d2J454/hD6A2lUZqg77c4qHxzPhaA5IFj5xGyV9qoZv98bz3Cf8KoHS/nrTHGRiAVYhfRxtx2Xrg==
dependencies:
bootstrap-daterangepicker "^3.1.0"
"@abp/bootstrap@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/bootstrap/-/bootstrap-10.0.0-rc.3.tgz#9daacf0ab7b3967dedad7f8792b9125c439f9022"
integrity sha512-Rl5DFxazgWZrioVjO6MLgnZW9YBsXN0DoWX3rprBp6qsLdBSNduIdM6J8DqB2y/UadoJwZRduykRZRVPgka3HQ==
"@abp/bootstrap@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/bootstrap/-/bootstrap-10.0.0.tgz#f78a0a0f1dbee8839d074e23559fd9bf906673fd"
integrity sha512-yXnSvZVl1T6y3vcZTCFBAm9C3kqWViM8cpYWGD/MNFnxz3CrrnCkE+SHFGwEaU2CozEBXIGgT3pDZ1rgQOIg9Q==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
bootstrap "^5.3.8"
"@abp/clipboard@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/clipboard/-/clipboard-10.0.0-rc.3.tgz#43f7989809da0df90eecbdda999351defa9f3eec"
integrity sha512-KXvgt91WX4GDOLZsT8OpTBwWdN93/adX+b5OuNxzgASdxKWXI+cj2ZU2PIyKQjPvU7A6tqsBqglVe4DKlGDCiQ==
"@abp/clipboard@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/clipboard/-/clipboard-10.0.0.tgz#ad3ebdcf5da314b4213518c2841fd8a15c3d4bf1"
integrity sha512-UT9NIqLvKL88ybA67SihA3CAzcNXYACTP/pDLM5IoqkRs0UNpUlN7+nK5pmC6j1TxY72piGoa+havcWikU/7Jw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
clipboard "^2.0.11"
"@abp/core@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/core/-/core-10.0.0-rc.3.tgz#7c74ed023ee91fa18d92dc33a64c11d279eb2414"
integrity sha512-z6QKxlAsiXcCwvn3BvNouLa7UsxQmQSlZ2yleTcJ7uEDSwUzbhzCiUQ5WwHTqoOACPQ71/wasSaxEyeRQBcE8w==
"@abp/core@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/core/-/core-10.0.0.tgz#a201dab2cec00d61154499fc0e4784632d6a4c29"
integrity sha512-9pg6a95iHtUMF9T0ZoNLO4xAJWoephBLPl2HqQ3TeagBuW3J1fu4FRM0bkvoUMaOUJ1O4emcfLUxkzqbaoEQWA==
dependencies:
"@abp/utils" "~10.0.0-rc.3"
"@abp/utils" "~10.0.0"
"@abp/datatables.net-bs5@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/datatables.net-bs5/-/datatables.net-bs5-10.0.0-rc.3.tgz#13a533e454c60702ab10eb41faa5643a7d6f6cce"
integrity sha512-a6O+iLX/LdLZTCbLfR7HJlr+z8KlIxih/PFBqaf5lLmTnyS0aJii+KMHjD7nRJy5/TWI+ALiT7gWRbjiHxOuFQ==
"@abp/datatables.net-bs5@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/datatables.net-bs5/-/datatables.net-bs5-10.0.0.tgz#bc5d59dffbbb22ec866b1702424433cc5fd3280e"
integrity sha512-2d/xlLHdf4oFE3EDyXpIQcdfsPjYvrUdv5RJTIajhMQ9vCftYwDtruDtVgnfNef7BR0KeeRJ3LAyxynh3siOuQ==
dependencies:
"@abp/datatables.net" "~10.0.0-rc.3"
"@abp/datatables.net" "~10.0.0"
datatables.net-bs5 "^2.3.4"
"@abp/datatables.net@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/datatables.net/-/datatables.net-10.0.0-rc.3.tgz#ae97a33f1695b6cab1658ff476a984c7ab9d51a6"
integrity sha512-1gHnOKNJxELYHY7eeO32aFm5+YA2YSEeOO6HrY4HZLRDr5rOHDAswH2OwFtn/qVPGR1fVbUr1TA9uqPOtxsJXA==
"@abp/datatables.net@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/datatables.net/-/datatables.net-10.0.0.tgz#9aa4dec837007eafa93667fcc36fe08f2ca25fcf"
integrity sha512-GoxswQyOyYvCxZDdbNPMlJ9CG0S2OpmK1CqLOVLFbYYHWSGT8X4T+AVg7Bys2AaBqqz3Smg1duIawfMu2yVEAA==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
datatables.net "^2.3.4"
"@abp/font-awesome@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/font-awesome/-/font-awesome-10.0.0-rc.3.tgz#a5b619452416af76203ef1bab18399abf8b8fa96"
integrity sha512-6FoA/2odS1kdV1EJ91YgIjMQiQdblUfqtDx72fDG7+qnqRyZ+Df/KWOqramEe9791zbXByZL4SjpqoisZgFNzQ==
"@abp/font-awesome@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/font-awesome/-/font-awesome-10.0.0.tgz#390669267f70a817f21f1cc0508a8ceb613fc631"
integrity sha512-R1pckhwQj+lHLV6rRD/sxEPqz58Od4xPKYR1IcfveZ74GV/PqVmjbNkC0U655l+CI6pwZzzyJMFVNRgl22/v6w==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
"@fortawesome/fontawesome-free" "^7.0.1"
"@abp/highlight.js@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/highlight.js/-/highlight.js-10.0.0-rc.3.tgz#b72dfecd68208e5c9125fc3f03390761c1b1b784"
integrity sha512-dNzuKfm66N7lFiDCkiDBoJNbLerbpK6XRNowVRuVIb/rgGTdMmzk7CatV0n04OJQgMqm/cq+cZSV0Lp0f7v1YA==
"@abp/highlight.js@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/highlight.js/-/highlight.js-10.0.0.tgz#8ca79a29c3fa6aef88ea20bf2fe74bdd58c3189e"
integrity sha512-BouG7VBk1VjkIIHpO3B8XggBBfs2EUD7cTD9akmDciErANjTD22hWkPRhONM4uqZX4tm9/7RL+TxBFRYXY6dFA==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
"@highlightjs/cdn-assets" "~11.11.1"
"@abp/jquery-form@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery-form/-/jquery-form-10.0.0-rc.3.tgz#24eefc512942dca37bdeb3fc1753cc3651e2872a"
integrity sha512-RRcGjt3blqH2R4uwrbrO+p1Kv6e7i1oJ9Wf6xrZK2upVfUvToUbif15HlC24FhNPX3BEUyL52s5HKcVBU5/1iw==
"@abp/jquery-form@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery-form/-/jquery-form-10.0.0.tgz#27182c80e17b4ffbc2551fa3e5d22f058c5b71ef"
integrity sha512-QVf+geob891AfdM2SGWbuUXo9/MhIquqmBgLJveKXRoNExqLyp2+jbd4YTRUW9RB7ZEzoKg+U+Om9ax/nnRV4A==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
jquery-form "^4.3.0"
"@abp/jquery-validation-unobtrusive@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation-unobtrusive/-/jquery-validation-unobtrusive-10.0.0-rc.3.tgz#20c8647e006954887eebe86e17ef39a336f47a30"
integrity sha512-6DVIIEVyqyeKMrZHNOTfW3/xuw7rkjqTMKXT6Z1wrDpt9Erseuz8CjbPpcS+RwpXn6va5ShrkJlwwyScFOKvkQ==
"@abp/jquery-validation-unobtrusive@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation-unobtrusive/-/jquery-validation-unobtrusive-10.0.0.tgz#89698d2ec25f21e697d5b23540885a2c74115db8"
integrity sha512-eqri3yDeyFutZcOJrP8aVf5vKoE47KP/mL8TXCRjyjVCZsHxOgjhSRY4n4rYo0JK2fePBOhwb5vpBhlezFKoNg==
dependencies:
"@abp/jquery-validation" "~10.0.0-rc.3"
"@abp/jquery-validation" "~10.0.0"
jquery-validation-unobtrusive "^4.0.0"
"@abp/jquery-validation@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation/-/jquery-validation-10.0.0-rc.3.tgz#2e562ad5ca7c5bef389a0b24293a3193fa9823ef"
integrity sha512-xLJVvCkUrNnVeQbdsKfBj7zh3cSaPJC3eWKm2NoVy9KimEhF4zeSJEkciFmS0cckSal+AO2xC8W8ot3FqpkCHQ==
"@abp/jquery-validation@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation/-/jquery-validation-10.0.0.tgz#83850af15bd3d65c399519da9461ff30fd615197"
integrity sha512-2Sigm4L+8IwzvLYIoNWpOE8u/HvHLqWlOfqClL1x0p3JQBhgAVNns5sm3P6xgjWVJpCzrUOh8lxFMUGUiRSS0w==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
jquery-validation "^1.21.0"
"@abp/jquery@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery/-/jquery-10.0.0-rc.3.tgz#3400f1b8c6966e2d71fceb5349f05b88aeb2bb88"
integrity sha512-liz3FITKdESLGomITjUqcOZYvV0rs61vYMxSbaCDoCKIQj4Ne9mN+HJ/KOpD6GOhqVsjmYOxDuSoecjiFLjVxA==
"@abp/jquery@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery/-/jquery-10.0.0.tgz#530b968eed2e94d13381679aabddfa4cb1aad8d5"
integrity sha512-KksQlTs3VojDBxjBcLPkI55V7aG9TpDqzpylVq+5Sj8ZozFH9C75XQZpkLVwiU57rGYyQpfKuKAAPiZlJnWK0Q==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
jquery "~3.7.1"
"@abp/lodash@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/lodash/-/lodash-10.0.0-rc.3.tgz#738baf7394d466112dc5a2380f2c549053621505"
integrity sha512-5PYQks4sJPdiz9zfZD1bfrCkmQ+ZMfWg2xyjbHoQzJdqu9rb2SRzkQ5MAWvqQPVTdLY6Bnutwxuq6mjkfcthcQ==
"@abp/lodash@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/lodash/-/lodash-10.0.0.tgz#08c271911d398329dbcb815c109bf3a29a940f1c"
integrity sha512-I8cqRK/2ln0/dFT9e+XzmjprBO2GnN5JCP8pb9q3wgOYb+Wf+BYg/3RQQhGAv+NhwCsxAezRMQfF+DU3xb3hAw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
lodash "^4.17.21"
"@abp/luxon@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/luxon/-/luxon-10.0.0-rc.3.tgz#bfb0c5fbf4a321e4531ec5b34dcdee47b486afe8"
integrity sha512-PCifbFy7t1h4L+FKJAo5Xr7v5hTvlelwuCsOVGfG8HVWmbOTKiQJywtxvSnARbsJ6SghUEzbqMzeX6nyHZ4Zuw==
"@abp/luxon@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/luxon/-/luxon-10.0.0.tgz#e0743dca2b50561176aec44cf90870e80863d6b9"
integrity sha512-CUPHIW/7osW2wDtjB6OuURq16/jAIPV9ssGINUxgJZYpVKsaHCfORQLQ+wn8h653Crf5CEiDVZMpuLaLVFEpXw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
luxon "^3.7.2"
"@abp/malihu-custom-scrollbar-plugin@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/malihu-custom-scrollbar-plugin/-/malihu-custom-scrollbar-plugin-10.0.0-rc.3.tgz#03bf7a8b2e71ec463794260e7fe5e6bfeb526f8e"
integrity sha512-aHOZnr4iPS6QqV07cXyWpQVl6zAaQXuct1yTeIUqcAqxsSt63K6Y27nBR8cU/m6BHhjaxSLn1kynOeccmx7lDA==
"@abp/malihu-custom-scrollbar-plugin@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/malihu-custom-scrollbar-plugin/-/malihu-custom-scrollbar-plugin-10.0.0.tgz#ff69e4dd180c7d6945b5db883b57b1131c51fae6"
integrity sha512-yGHsYExELbF/sKXS6zQ9SqEsl8w3yr6daWOkgW/aoITks6DeOte2jdjP2Ly6UpHQbAzbeAjZg0oCrSbtcz/tZw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
malihu-custom-scrollbar-plugin "^3.1.5"
"@abp/moment@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/moment/-/moment-10.0.0-rc.3.tgz#1d2c8081b9f7f2716b250d16b41021e74c093fb0"
integrity sha512-VKDVY3ml3bhPh2rUsUN1F7zH5Myi+jRYxQYC/OuOsa1P4x9+cKs1lsS68NYAq+JyMlwwuJcAx63nqkxArz+VEw==
"@abp/moment@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/moment/-/moment-10.0.0.tgz#8b84d1a15c43d0099125be2b5b071e11a7b402d4"
integrity sha512-AAu4BgciErLKYTIW6uT14q5WCl+oJeXz0J7a/kyZz2tHYbQz4FnYWMuFoDUFvkKKtGzyq7LuKTmGPxmJUXNpRg==
dependencies:
moment "^2.30.1"
"@abp/prismjs@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/prismjs/-/prismjs-10.0.0-rc.3.tgz#d7342b793fc7baf205726e8a088de88778fc24b1"
integrity sha512-cafgH3lrlT+jOuQKtBVeORbBkJKCG2DqnVF0blaD75ww32R5TJS+LH8gOufezdTfASG14ZlpzqNLl1Xu67Wh4Q==
"@abp/prismjs@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/prismjs/-/prismjs-10.0.0.tgz#6463b5d5fcbe2f9da687e04c49d38e8eb6e778b8"
integrity sha512-N2p18MAX9wYx62Ck5+V/RWLGyX+1BemiVuNX/cIOJMG0iDVJ57C6fEX1HzLc9Mchi+MXPHUR7lKwg92ui2OzfQ==
dependencies:
"@abp/clipboard" "~10.0.0-rc.3"
"@abp/core" "~10.0.0-rc.3"
"@abp/clipboard" "~10.0.0"
"@abp/core" "~10.0.0"
prismjs "^1.30.0"
"@abp/select2@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/select2/-/select2-10.0.0-rc.3.tgz#216403f1207a2556b0317fb973ed874c34c7fb73"
integrity sha512-6t/ZZl9xo0G86dX8zmEv82/64dOxCTgcQvjRGTb5Xwzh05nKHKpFFhJm6juVvpJcYqUj6Weks66SVjr6Wi2kQQ==
"@abp/select2@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/select2/-/select2-10.0.0.tgz#0a3a425c30e4139b8677c871bb7bfd2ab010b9f6"
integrity sha512-ZAFuLA8CIJr/UspKN/coRxnB+3xArc06a0YQ6HHVL5RWVRlRkcuZL/2aBFQ5HdrWZjSmImG1yXKxGyVLNmavpQ==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
select2 "^4.0.13"
"@abp/sweetalert2@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/sweetalert2/-/sweetalert2-10.0.0-rc.3.tgz#401dc08eb4607d3a575a5288296f6c703b18df8a"
integrity sha512-2nB9I+GxK7UeIjvdUJtAH9GqIL/HloQ+7WC/ZWUNLCBqI5Owx30La2wxj5e9MlDNcLvYs3A2EJP0Llo4Gdefsg==
"@abp/sweetalert2@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/sweetalert2/-/sweetalert2-10.0.0.tgz#ef9830d0d294aa685fe6ad8049056650a7d46381"
integrity sha512-wAAIacOdWyBiJMVuFVbiNpR3SnRsyhNHmNr4gmhge5KBDlO+JQlueaar0MrKkdUNaXuF9memdgERzi/cIJm1mw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
sweetalert2 "^11.23.0"
"@abp/timeago@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/timeago/-/timeago-10.0.0-rc.3.tgz#6fc8f16107171ae6f6afbbd3dc7e844651ffcf77"
integrity sha512-JYhSRbz06IObwA32GutyV+yo4p5PdAmGtlaApDLCpSFccHsel/A3jrN+ykovKy4chWYcbOhxhgjWw6ZaIZMvJg==
"@abp/timeago@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/timeago/-/timeago-10.0.0.tgz#af348b8ca21c466847c3dd47d4947f615ff82707"
integrity sha512-LbGIKpsDJyoDpN4ams9yTebA7fOPerdN4bQUWJB/7LV5wI0jtzkvbe+bEI00NLeMIDJ/nU+k+ecjhQjzkrY7qQ==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
timeago "^1.6.7"
"@abp/utils@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/utils/-/utils-10.0.0-rc.3.tgz#d6a07146ba627bcfa0cadd5c7c56601609b24d57"
integrity sha512-bA/WPuosvedfQr+5cJBwKXrhd6b8fDG7LWp4PuZFMdti8nSXgOheLeZ8PcRvut94ENIXS7jzSsqapLHRj5E6zQ==
"@abp/utils@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/utils/-/utils-10.0.0.tgz#372ea8b37809ec1951d3fd74ae02adff9215245b"
integrity sha512-VO725+ALRGmjFz9Yal+joivNZpBbPS9AWOx6N5E8meEYQnHo2oEDeoOziKkwLZ4EYIizno37zwsXiQLEO4iFRg==
dependencies:
just-compare "^2.3.0"

4
modules/basic-theme/test/Volo.Abp.AspNetCore.Mvc.UI.Theme.Basic.Demo/package.json

@ -3,8 +3,8 @@
"name": "asp.net",
"private": true,
"dependencies": {
"@abp/aspnetcore.mvc.ui.theme.basic": "~10.0.0-rc.3",
"@abp/prismjs": "~10.0.0-rc.3"
"@abp/aspnetcore.mvc.ui.theme.basic": "~10.0.0",
"@abp/prismjs": "~10.0.0"
},
"devDependencies": {}
}

268
modules/basic-theme/test/Volo.Abp.AspNetCore.Mvc.UI.Theme.Basic.Demo/yarn.lock

@ -2,202 +2,202 @@
# yarn lockfile v1
"@abp/aspnetcore.mvc.ui.theme.basic@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.basic/-/aspnetcore.mvc.ui.theme.basic-10.0.0-rc.3.tgz#d2784a3779500b0f22149a35eb81f0456b732239"
integrity sha512-6fYmDHPbaZGzDZgNz6/UzStP3DM4icxscY/IrqyJ0Mhzq00j/4nuG7zuc9hogUxqifwrBAa/oiiUtdkG1tr4uQ==
dependencies:
"@abp/aspnetcore.mvc.ui.theme.shared" "~10.0.0-rc.3"
"@abp/aspnetcore.mvc.ui.theme.shared@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.shared/-/aspnetcore.mvc.ui.theme.shared-10.0.0-rc.3.tgz#a68d95a189e79dccb7bc50460565e03777e3823c"
integrity sha512-QvMZy5gVSksLYiGE8VvDQ7n5GKWCyuJF9Y7Kx6/bw+weWKvEk6kiqw5glTMzUOnpkM4kH7bIb8PoJSAycDlvRg==
dependencies:
"@abp/aspnetcore.mvc.ui" "~10.0.0-rc.3"
"@abp/bootstrap" "~10.0.0-rc.3"
"@abp/bootstrap-datepicker" "~10.0.0-rc.3"
"@abp/bootstrap-daterangepicker" "~10.0.0-rc.3"
"@abp/datatables.net-bs5" "~10.0.0-rc.3"
"@abp/font-awesome" "~10.0.0-rc.3"
"@abp/jquery-form" "~10.0.0-rc.3"
"@abp/jquery-validation-unobtrusive" "~10.0.0-rc.3"
"@abp/lodash" "~10.0.0-rc.3"
"@abp/luxon" "~10.0.0-rc.3"
"@abp/malihu-custom-scrollbar-plugin" "~10.0.0-rc.3"
"@abp/moment" "~10.0.0-rc.3"
"@abp/select2" "~10.0.0-rc.3"
"@abp/sweetalert2" "~10.0.0-rc.3"
"@abp/timeago" "~10.0.0-rc.3"
"@abp/aspnetcore.mvc.ui@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui/-/aspnetcore.mvc.ui-10.0.0-rc.3.tgz#8d3cbec33ff9efe7789e5cafb86c39e2488304ca"
integrity sha512-HqbleKwVFVRK0Xxd0XkeyCfX4+JPouEMYvQCL+zo0RDOMfPViPua5ketfU9DDhCCyMfCwy7iW0GeX9NuqEjXwg==
"@abp/aspnetcore.mvc.ui.theme.basic@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.basic/-/aspnetcore.mvc.ui.theme.basic-10.0.0.tgz#ad918558653ed7c6d329d58a37e681a9f410e01f"
integrity sha512-gyAmQdwR/SWSNXF3Q8r1zyJu4h4DKnN+wSHfvfVB0A1+X/TFGUJXJ6FrJwoFh1QDAqeIdeXOTk4d+M3AZeCgIw==
dependencies:
"@abp/aspnetcore.mvc.ui.theme.shared" "~10.0.0"
"@abp/aspnetcore.mvc.ui.theme.shared@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.shared/-/aspnetcore.mvc.ui.theme.shared-10.0.0.tgz#ac4150739c6b2d24d27ddc86659e9d2bbdb82548"
integrity sha512-ghockOUBUG4ZoQCKB7H5Jd5ztgnxJsDoVaxpPc/amcF2Nm/7shSA0w2uK5p1Qo7icGoOriE2zM0hfpuKy7JDeQ==
dependencies:
"@abp/aspnetcore.mvc.ui" "~10.0.0"
"@abp/bootstrap" "~10.0.0"
"@abp/bootstrap-datepicker" "~10.0.0"
"@abp/bootstrap-daterangepicker" "~10.0.0"
"@abp/datatables.net-bs5" "~10.0.0"
"@abp/font-awesome" "~10.0.0"
"@abp/jquery-form" "~10.0.0"
"@abp/jquery-validation-unobtrusive" "~10.0.0"
"@abp/lodash" "~10.0.0"
"@abp/luxon" "~10.0.0"
"@abp/malihu-custom-scrollbar-plugin" "~10.0.0"
"@abp/moment" "~10.0.0"
"@abp/select2" "~10.0.0"
"@abp/sweetalert2" "~10.0.0"
"@abp/timeago" "~10.0.0"
"@abp/aspnetcore.mvc.ui@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui/-/aspnetcore.mvc.ui-10.0.0.tgz#3357ba70f5f6545a87755a4c368f373c8cee6f8d"
integrity sha512-S8wSmfRz66ozIm17a4cPJxBDoXRqhNAa+N6uV+gLhVRvTSFAGNvcCsUTCmW4VsEf1Wnaedxwg/cUFjMc6eD6nA==
dependencies:
ansi-colors "^4.1.3"
"@abp/bootstrap-datepicker@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-datepicker/-/bootstrap-datepicker-10.0.0-rc.3.tgz#6d7528d9275cede4bf91b929dd407c744e513014"
integrity sha512-zBLJ9hQXucXOM0GpRyJCMHxdi+C5gaGQtYzguFFGDw+jW5Ht7paoAU+HYS8Dy29zHJHMk+VdO5vJovVIXhfuPg==
"@abp/bootstrap-datepicker@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-datepicker/-/bootstrap-datepicker-10.0.0.tgz#76859087323bec5e8f9d05500b1858374e8d5f11"
integrity sha512-rZo7+l/VWXsRmIKtqq6hGIqlew/nB2axIsaIHnrzuOqoSyq/SqMjBoUoQsvLSfK/YaoloYGj1r/IDmtb+OxCOg==
dependencies:
bootstrap-datepicker "^1.10.1"
"@abp/bootstrap-daterangepicker@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-daterangepicker/-/bootstrap-daterangepicker-10.0.0-rc.3.tgz#85b09ce28da96e84a9ad448cee5b73d581056041"
integrity sha512-VyAZqPZyx/sjGcYYqDPStwUMeQ+nMwud1pEmDgpPWWsRoQBPOVB3PS8KGgW4Fb2oax9i2v6wF5qqLEQkD3CDmA==
"@abp/bootstrap-daterangepicker@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-daterangepicker/-/bootstrap-daterangepicker-10.0.0.tgz#be561035b4778b040470246f71cd5b228c80bbc2"
integrity sha512-njuKNfCg06d2J454/hD6A2lUZqg77c4qHxzPhaA5IFj5xGyV9qoZv98bz3Cf8KoHS/nrTHGRiAVYhfRxtx2Xrg==
dependencies:
bootstrap-daterangepicker "^3.1.0"
"@abp/bootstrap@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/bootstrap/-/bootstrap-10.0.0-rc.3.tgz#9daacf0ab7b3967dedad7f8792b9125c439f9022"
integrity sha512-Rl5DFxazgWZrioVjO6MLgnZW9YBsXN0DoWX3rprBp6qsLdBSNduIdM6J8DqB2y/UadoJwZRduykRZRVPgka3HQ==
"@abp/bootstrap@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/bootstrap/-/bootstrap-10.0.0.tgz#f78a0a0f1dbee8839d074e23559fd9bf906673fd"
integrity sha512-yXnSvZVl1T6y3vcZTCFBAm9C3kqWViM8cpYWGD/MNFnxz3CrrnCkE+SHFGwEaU2CozEBXIGgT3pDZ1rgQOIg9Q==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
bootstrap "^5.3.8"
"@abp/clipboard@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/clipboard/-/clipboard-10.0.0-rc.3.tgz#43f7989809da0df90eecbdda999351defa9f3eec"
integrity sha512-KXvgt91WX4GDOLZsT8OpTBwWdN93/adX+b5OuNxzgASdxKWXI+cj2ZU2PIyKQjPvU7A6tqsBqglVe4DKlGDCiQ==
"@abp/clipboard@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/clipboard/-/clipboard-10.0.0.tgz#ad3ebdcf5da314b4213518c2841fd8a15c3d4bf1"
integrity sha512-UT9NIqLvKL88ybA67SihA3CAzcNXYACTP/pDLM5IoqkRs0UNpUlN7+nK5pmC6j1TxY72piGoa+havcWikU/7Jw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
clipboard "^2.0.11"
"@abp/core@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/core/-/core-10.0.0-rc.3.tgz#7c74ed023ee91fa18d92dc33a64c11d279eb2414"
integrity sha512-z6QKxlAsiXcCwvn3BvNouLa7UsxQmQSlZ2yleTcJ7uEDSwUzbhzCiUQ5WwHTqoOACPQ71/wasSaxEyeRQBcE8w==
"@abp/core@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/core/-/core-10.0.0.tgz#a201dab2cec00d61154499fc0e4784632d6a4c29"
integrity sha512-9pg6a95iHtUMF9T0ZoNLO4xAJWoephBLPl2HqQ3TeagBuW3J1fu4FRM0bkvoUMaOUJ1O4emcfLUxkzqbaoEQWA==
dependencies:
"@abp/utils" "~10.0.0-rc.3"
"@abp/utils" "~10.0.0"
"@abp/datatables.net-bs5@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/datatables.net-bs5/-/datatables.net-bs5-10.0.0-rc.3.tgz#13a533e454c60702ab10eb41faa5643a7d6f6cce"
integrity sha512-a6O+iLX/LdLZTCbLfR7HJlr+z8KlIxih/PFBqaf5lLmTnyS0aJii+KMHjD7nRJy5/TWI+ALiT7gWRbjiHxOuFQ==
"@abp/datatables.net-bs5@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/datatables.net-bs5/-/datatables.net-bs5-10.0.0.tgz#bc5d59dffbbb22ec866b1702424433cc5fd3280e"
integrity sha512-2d/xlLHdf4oFE3EDyXpIQcdfsPjYvrUdv5RJTIajhMQ9vCftYwDtruDtVgnfNef7BR0KeeRJ3LAyxynh3siOuQ==
dependencies:
"@abp/datatables.net" "~10.0.0-rc.3"
"@abp/datatables.net" "~10.0.0"
datatables.net-bs5 "^2.3.4"
"@abp/datatables.net@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/datatables.net/-/datatables.net-10.0.0-rc.3.tgz#ae97a33f1695b6cab1658ff476a984c7ab9d51a6"
integrity sha512-1gHnOKNJxELYHY7eeO32aFm5+YA2YSEeOO6HrY4HZLRDr5rOHDAswH2OwFtn/qVPGR1fVbUr1TA9uqPOtxsJXA==
"@abp/datatables.net@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/datatables.net/-/datatables.net-10.0.0.tgz#9aa4dec837007eafa93667fcc36fe08f2ca25fcf"
integrity sha512-GoxswQyOyYvCxZDdbNPMlJ9CG0S2OpmK1CqLOVLFbYYHWSGT8X4T+AVg7Bys2AaBqqz3Smg1duIawfMu2yVEAA==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
datatables.net "^2.3.4"
"@abp/font-awesome@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/font-awesome/-/font-awesome-10.0.0-rc.3.tgz#a5b619452416af76203ef1bab18399abf8b8fa96"
integrity sha512-6FoA/2odS1kdV1EJ91YgIjMQiQdblUfqtDx72fDG7+qnqRyZ+Df/KWOqramEe9791zbXByZL4SjpqoisZgFNzQ==
"@abp/font-awesome@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/font-awesome/-/font-awesome-10.0.0.tgz#390669267f70a817f21f1cc0508a8ceb613fc631"
integrity sha512-R1pckhwQj+lHLV6rRD/sxEPqz58Od4xPKYR1IcfveZ74GV/PqVmjbNkC0U655l+CI6pwZzzyJMFVNRgl22/v6w==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
"@fortawesome/fontawesome-free" "^7.0.1"
"@abp/jquery-form@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery-form/-/jquery-form-10.0.0-rc.3.tgz#24eefc512942dca37bdeb3fc1753cc3651e2872a"
integrity sha512-RRcGjt3blqH2R4uwrbrO+p1Kv6e7i1oJ9Wf6xrZK2upVfUvToUbif15HlC24FhNPX3BEUyL52s5HKcVBU5/1iw==
"@abp/jquery-form@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery-form/-/jquery-form-10.0.0.tgz#27182c80e17b4ffbc2551fa3e5d22f058c5b71ef"
integrity sha512-QVf+geob891AfdM2SGWbuUXo9/MhIquqmBgLJveKXRoNExqLyp2+jbd4YTRUW9RB7ZEzoKg+U+Om9ax/nnRV4A==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
jquery-form "^4.3.0"
"@abp/jquery-validation-unobtrusive@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation-unobtrusive/-/jquery-validation-unobtrusive-10.0.0-rc.3.tgz#20c8647e006954887eebe86e17ef39a336f47a30"
integrity sha512-6DVIIEVyqyeKMrZHNOTfW3/xuw7rkjqTMKXT6Z1wrDpt9Erseuz8CjbPpcS+RwpXn6va5ShrkJlwwyScFOKvkQ==
"@abp/jquery-validation-unobtrusive@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation-unobtrusive/-/jquery-validation-unobtrusive-10.0.0.tgz#89698d2ec25f21e697d5b23540885a2c74115db8"
integrity sha512-eqri3yDeyFutZcOJrP8aVf5vKoE47KP/mL8TXCRjyjVCZsHxOgjhSRY4n4rYo0JK2fePBOhwb5vpBhlezFKoNg==
dependencies:
"@abp/jquery-validation" "~10.0.0-rc.3"
"@abp/jquery-validation" "~10.0.0"
jquery-validation-unobtrusive "^4.0.0"
"@abp/jquery-validation@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation/-/jquery-validation-10.0.0-rc.3.tgz#2e562ad5ca7c5bef389a0b24293a3193fa9823ef"
integrity sha512-xLJVvCkUrNnVeQbdsKfBj7zh3cSaPJC3eWKm2NoVy9KimEhF4zeSJEkciFmS0cckSal+AO2xC8W8ot3FqpkCHQ==
"@abp/jquery-validation@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation/-/jquery-validation-10.0.0.tgz#83850af15bd3d65c399519da9461ff30fd615197"
integrity sha512-2Sigm4L+8IwzvLYIoNWpOE8u/HvHLqWlOfqClL1x0p3JQBhgAVNns5sm3P6xgjWVJpCzrUOh8lxFMUGUiRSS0w==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
jquery-validation "^1.21.0"
"@abp/jquery@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery/-/jquery-10.0.0-rc.3.tgz#3400f1b8c6966e2d71fceb5349f05b88aeb2bb88"
integrity sha512-liz3FITKdESLGomITjUqcOZYvV0rs61vYMxSbaCDoCKIQj4Ne9mN+HJ/KOpD6GOhqVsjmYOxDuSoecjiFLjVxA==
"@abp/jquery@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery/-/jquery-10.0.0.tgz#530b968eed2e94d13381679aabddfa4cb1aad8d5"
integrity sha512-KksQlTs3VojDBxjBcLPkI55V7aG9TpDqzpylVq+5Sj8ZozFH9C75XQZpkLVwiU57rGYyQpfKuKAAPiZlJnWK0Q==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
jquery "~3.7.1"
"@abp/lodash@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/lodash/-/lodash-10.0.0-rc.3.tgz#738baf7394d466112dc5a2380f2c549053621505"
integrity sha512-5PYQks4sJPdiz9zfZD1bfrCkmQ+ZMfWg2xyjbHoQzJdqu9rb2SRzkQ5MAWvqQPVTdLY6Bnutwxuq6mjkfcthcQ==
"@abp/lodash@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/lodash/-/lodash-10.0.0.tgz#08c271911d398329dbcb815c109bf3a29a940f1c"
integrity sha512-I8cqRK/2ln0/dFT9e+XzmjprBO2GnN5JCP8pb9q3wgOYb+Wf+BYg/3RQQhGAv+NhwCsxAezRMQfF+DU3xb3hAw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
lodash "^4.17.21"
"@abp/luxon@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/luxon/-/luxon-10.0.0-rc.3.tgz#bfb0c5fbf4a321e4531ec5b34dcdee47b486afe8"
integrity sha512-PCifbFy7t1h4L+FKJAo5Xr7v5hTvlelwuCsOVGfG8HVWmbOTKiQJywtxvSnARbsJ6SghUEzbqMzeX6nyHZ4Zuw==
"@abp/luxon@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/luxon/-/luxon-10.0.0.tgz#e0743dca2b50561176aec44cf90870e80863d6b9"
integrity sha512-CUPHIW/7osW2wDtjB6OuURq16/jAIPV9ssGINUxgJZYpVKsaHCfORQLQ+wn8h653Crf5CEiDVZMpuLaLVFEpXw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
luxon "^3.7.2"
"@abp/malihu-custom-scrollbar-plugin@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/malihu-custom-scrollbar-plugin/-/malihu-custom-scrollbar-plugin-10.0.0-rc.3.tgz#03bf7a8b2e71ec463794260e7fe5e6bfeb526f8e"
integrity sha512-aHOZnr4iPS6QqV07cXyWpQVl6zAaQXuct1yTeIUqcAqxsSt63K6Y27nBR8cU/m6BHhjaxSLn1kynOeccmx7lDA==
"@abp/malihu-custom-scrollbar-plugin@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/malihu-custom-scrollbar-plugin/-/malihu-custom-scrollbar-plugin-10.0.0.tgz#ff69e4dd180c7d6945b5db883b57b1131c51fae6"
integrity sha512-yGHsYExELbF/sKXS6zQ9SqEsl8w3yr6daWOkgW/aoITks6DeOte2jdjP2Ly6UpHQbAzbeAjZg0oCrSbtcz/tZw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
malihu-custom-scrollbar-plugin "^3.1.5"
"@abp/moment@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/moment/-/moment-10.0.0-rc.3.tgz#1d2c8081b9f7f2716b250d16b41021e74c093fb0"
integrity sha512-VKDVY3ml3bhPh2rUsUN1F7zH5Myi+jRYxQYC/OuOsa1P4x9+cKs1lsS68NYAq+JyMlwwuJcAx63nqkxArz+VEw==
"@abp/moment@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/moment/-/moment-10.0.0.tgz#8b84d1a15c43d0099125be2b5b071e11a7b402d4"
integrity sha512-AAu4BgciErLKYTIW6uT14q5WCl+oJeXz0J7a/kyZz2tHYbQz4FnYWMuFoDUFvkKKtGzyq7LuKTmGPxmJUXNpRg==
dependencies:
moment "^2.30.1"
"@abp/prismjs@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/prismjs/-/prismjs-10.0.0-rc.3.tgz#d7342b793fc7baf205726e8a088de88778fc24b1"
integrity sha512-cafgH3lrlT+jOuQKtBVeORbBkJKCG2DqnVF0blaD75ww32R5TJS+LH8gOufezdTfASG14ZlpzqNLl1Xu67Wh4Q==
"@abp/prismjs@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/prismjs/-/prismjs-10.0.0.tgz#6463b5d5fcbe2f9da687e04c49d38e8eb6e778b8"
integrity sha512-N2p18MAX9wYx62Ck5+V/RWLGyX+1BemiVuNX/cIOJMG0iDVJ57C6fEX1HzLc9Mchi+MXPHUR7lKwg92ui2OzfQ==
dependencies:
"@abp/clipboard" "~10.0.0-rc.3"
"@abp/core" "~10.0.0-rc.3"
"@abp/clipboard" "~10.0.0"
"@abp/core" "~10.0.0"
prismjs "^1.30.0"
"@abp/select2@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/select2/-/select2-10.0.0-rc.3.tgz#216403f1207a2556b0317fb973ed874c34c7fb73"
integrity sha512-6t/ZZl9xo0G86dX8zmEv82/64dOxCTgcQvjRGTb5Xwzh05nKHKpFFhJm6juVvpJcYqUj6Weks66SVjr6Wi2kQQ==
"@abp/select2@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/select2/-/select2-10.0.0.tgz#0a3a425c30e4139b8677c871bb7bfd2ab010b9f6"
integrity sha512-ZAFuLA8CIJr/UspKN/coRxnB+3xArc06a0YQ6HHVL5RWVRlRkcuZL/2aBFQ5HdrWZjSmImG1yXKxGyVLNmavpQ==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
select2 "^4.0.13"
"@abp/sweetalert2@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/sweetalert2/-/sweetalert2-10.0.0-rc.3.tgz#401dc08eb4607d3a575a5288296f6c703b18df8a"
integrity sha512-2nB9I+GxK7UeIjvdUJtAH9GqIL/HloQ+7WC/ZWUNLCBqI5Owx30La2wxj5e9MlDNcLvYs3A2EJP0Llo4Gdefsg==
"@abp/sweetalert2@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/sweetalert2/-/sweetalert2-10.0.0.tgz#ef9830d0d294aa685fe6ad8049056650a7d46381"
integrity sha512-wAAIacOdWyBiJMVuFVbiNpR3SnRsyhNHmNr4gmhge5KBDlO+JQlueaar0MrKkdUNaXuF9memdgERzi/cIJm1mw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
sweetalert2 "^11.23.0"
"@abp/timeago@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/timeago/-/timeago-10.0.0-rc.3.tgz#6fc8f16107171ae6f6afbbd3dc7e844651ffcf77"
integrity sha512-JYhSRbz06IObwA32GutyV+yo4p5PdAmGtlaApDLCpSFccHsel/A3jrN+ykovKy4chWYcbOhxhgjWw6ZaIZMvJg==
"@abp/timeago@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/timeago/-/timeago-10.0.0.tgz#af348b8ca21c466847c3dd47d4947f615ff82707"
integrity sha512-LbGIKpsDJyoDpN4ams9yTebA7fOPerdN4bQUWJB/7LV5wI0jtzkvbe+bEI00NLeMIDJ/nU+k+ecjhQjzkrY7qQ==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
timeago "^1.6.7"
"@abp/utils@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/utils/-/utils-10.0.0-rc.3.tgz#d6a07146ba627bcfa0cadd5c7c56601609b24d57"
integrity sha512-bA/WPuosvedfQr+5cJBwKXrhd6b8fDG7LWp4PuZFMdti8nSXgOheLeZ8PcRvut94ENIXS7jzSsqapLHRj5E6zQ==
"@abp/utils@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/utils/-/utils-10.0.0.tgz#372ea8b37809ec1951d3fd74ae02adff9215245b"
integrity sha512-VO725+ALRGmjFz9Yal+joivNZpBbPS9AWOx6N5E8meEYQnHo2oEDeoOziKkwLZ4EYIizno37zwsXiQLEO4iFRg==
dependencies:
just-compare "^2.3.0"

4
modules/blogging/app/Volo.BloggingTestApp/package.json

@ -3,7 +3,7 @@
"name": "volo.blogtestapp",
"private": true,
"dependencies": {
"@abp/aspnetcore.mvc.ui.theme.basic": "~10.0.0-rc.3",
"@abp/blogging": "~10.0.0-rc.3"
"@abp/aspnetcore.mvc.ui.theme.basic": "~10.0.0",
"@abp/blogging": "~10.0.0"
}
}

306
modules/blogging/app/Volo.BloggingTestApp/yarn.lock

@ -2,228 +2,228 @@
# yarn lockfile v1
"@abp/aspnetcore.mvc.ui.theme.basic@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.basic/-/aspnetcore.mvc.ui.theme.basic-10.0.0-rc.3.tgz#d2784a3779500b0f22149a35eb81f0456b732239"
integrity sha512-6fYmDHPbaZGzDZgNz6/UzStP3DM4icxscY/IrqyJ0Mhzq00j/4nuG7zuc9hogUxqifwrBAa/oiiUtdkG1tr4uQ==
dependencies:
"@abp/aspnetcore.mvc.ui.theme.shared" "~10.0.0-rc.3"
"@abp/aspnetcore.mvc.ui.theme.shared@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.shared/-/aspnetcore.mvc.ui.theme.shared-10.0.0-rc.3.tgz#a68d95a189e79dccb7bc50460565e03777e3823c"
integrity sha512-QvMZy5gVSksLYiGE8VvDQ7n5GKWCyuJF9Y7Kx6/bw+weWKvEk6kiqw5glTMzUOnpkM4kH7bIb8PoJSAycDlvRg==
dependencies:
"@abp/aspnetcore.mvc.ui" "~10.0.0-rc.3"
"@abp/bootstrap" "~10.0.0-rc.3"
"@abp/bootstrap-datepicker" "~10.0.0-rc.3"
"@abp/bootstrap-daterangepicker" "~10.0.0-rc.3"
"@abp/datatables.net-bs5" "~10.0.0-rc.3"
"@abp/font-awesome" "~10.0.0-rc.3"
"@abp/jquery-form" "~10.0.0-rc.3"
"@abp/jquery-validation-unobtrusive" "~10.0.0-rc.3"
"@abp/lodash" "~10.0.0-rc.3"
"@abp/luxon" "~10.0.0-rc.3"
"@abp/malihu-custom-scrollbar-plugin" "~10.0.0-rc.3"
"@abp/moment" "~10.0.0-rc.3"
"@abp/select2" "~10.0.0-rc.3"
"@abp/sweetalert2" "~10.0.0-rc.3"
"@abp/timeago" "~10.0.0-rc.3"
"@abp/aspnetcore.mvc.ui@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui/-/aspnetcore.mvc.ui-10.0.0-rc.3.tgz#8d3cbec33ff9efe7789e5cafb86c39e2488304ca"
integrity sha512-HqbleKwVFVRK0Xxd0XkeyCfX4+JPouEMYvQCL+zo0RDOMfPViPua5ketfU9DDhCCyMfCwy7iW0GeX9NuqEjXwg==
"@abp/aspnetcore.mvc.ui.theme.basic@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.basic/-/aspnetcore.mvc.ui.theme.basic-10.0.0.tgz#ad918558653ed7c6d329d58a37e681a9f410e01f"
integrity sha512-gyAmQdwR/SWSNXF3Q8r1zyJu4h4DKnN+wSHfvfVB0A1+X/TFGUJXJ6FrJwoFh1QDAqeIdeXOTk4d+M3AZeCgIw==
dependencies:
"@abp/aspnetcore.mvc.ui.theme.shared" "~10.0.0"
"@abp/aspnetcore.mvc.ui.theme.shared@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.shared/-/aspnetcore.mvc.ui.theme.shared-10.0.0.tgz#ac4150739c6b2d24d27ddc86659e9d2bbdb82548"
integrity sha512-ghockOUBUG4ZoQCKB7H5Jd5ztgnxJsDoVaxpPc/amcF2Nm/7shSA0w2uK5p1Qo7icGoOriE2zM0hfpuKy7JDeQ==
dependencies:
"@abp/aspnetcore.mvc.ui" "~10.0.0"
"@abp/bootstrap" "~10.0.0"
"@abp/bootstrap-datepicker" "~10.0.0"
"@abp/bootstrap-daterangepicker" "~10.0.0"
"@abp/datatables.net-bs5" "~10.0.0"
"@abp/font-awesome" "~10.0.0"
"@abp/jquery-form" "~10.0.0"
"@abp/jquery-validation-unobtrusive" "~10.0.0"
"@abp/lodash" "~10.0.0"
"@abp/luxon" "~10.0.0"
"@abp/malihu-custom-scrollbar-plugin" "~10.0.0"
"@abp/moment" "~10.0.0"
"@abp/select2" "~10.0.0"
"@abp/sweetalert2" "~10.0.0"
"@abp/timeago" "~10.0.0"
"@abp/aspnetcore.mvc.ui@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui/-/aspnetcore.mvc.ui-10.0.0.tgz#3357ba70f5f6545a87755a4c368f373c8cee6f8d"
integrity sha512-S8wSmfRz66ozIm17a4cPJxBDoXRqhNAa+N6uV+gLhVRvTSFAGNvcCsUTCmW4VsEf1Wnaedxwg/cUFjMc6eD6nA==
dependencies:
ansi-colors "^4.1.3"
"@abp/blogging@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/blogging/-/blogging-10.0.0-rc.3.tgz#d1b400c90e9e116b998126f3ed534df1418df37f"
integrity sha512-V3WXTKCNmXhiDpLVrcWJzActiGhmlhIvz+v+P4SKfPCLgQQDCEyk4O+2w/OumWYRFNhkjy4La73yRSdsmzTUWw==
"@abp/blogging@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/blogging/-/blogging-10.0.0.tgz#7385bd1222750e9d729f882066aea27579822659"
integrity sha512-5MJmbD7V3ms2oGTMJ8S1OSDmB+++5G61SUBdxr3XAscB7V08F5V+RhlKZAnQQFCoJ/kQMOPf3UN/geJ2FHP6kw==
dependencies:
"@abp/aspnetcore.mvc.ui.theme.shared" "~10.0.0-rc.3"
"@abp/owl.carousel" "~10.0.0-rc.3"
"@abp/prismjs" "~10.0.0-rc.3"
"@abp/tui-editor" "~10.0.0-rc.3"
"@abp/aspnetcore.mvc.ui.theme.shared" "~10.0.0"
"@abp/owl.carousel" "~10.0.0"
"@abp/prismjs" "~10.0.0"
"@abp/tui-editor" "~10.0.0"
"@abp/bootstrap-datepicker@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-datepicker/-/bootstrap-datepicker-10.0.0-rc.3.tgz#6d7528d9275cede4bf91b929dd407c744e513014"
integrity sha512-zBLJ9hQXucXOM0GpRyJCMHxdi+C5gaGQtYzguFFGDw+jW5Ht7paoAU+HYS8Dy29zHJHMk+VdO5vJovVIXhfuPg==
"@abp/bootstrap-datepicker@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-datepicker/-/bootstrap-datepicker-10.0.0.tgz#76859087323bec5e8f9d05500b1858374e8d5f11"
integrity sha512-rZo7+l/VWXsRmIKtqq6hGIqlew/nB2axIsaIHnrzuOqoSyq/SqMjBoUoQsvLSfK/YaoloYGj1r/IDmtb+OxCOg==
dependencies:
bootstrap-datepicker "^1.10.1"
"@abp/bootstrap-daterangepicker@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-daterangepicker/-/bootstrap-daterangepicker-10.0.0-rc.3.tgz#85b09ce28da96e84a9ad448cee5b73d581056041"
integrity sha512-VyAZqPZyx/sjGcYYqDPStwUMeQ+nMwud1pEmDgpPWWsRoQBPOVB3PS8KGgW4Fb2oax9i2v6wF5qqLEQkD3CDmA==
"@abp/bootstrap-daterangepicker@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-daterangepicker/-/bootstrap-daterangepicker-10.0.0.tgz#be561035b4778b040470246f71cd5b228c80bbc2"
integrity sha512-njuKNfCg06d2J454/hD6A2lUZqg77c4qHxzPhaA5IFj5xGyV9qoZv98bz3Cf8KoHS/nrTHGRiAVYhfRxtx2Xrg==
dependencies:
bootstrap-daterangepicker "^3.1.0"
"@abp/bootstrap@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/bootstrap/-/bootstrap-10.0.0-rc.3.tgz#9daacf0ab7b3967dedad7f8792b9125c439f9022"
integrity sha512-Rl5DFxazgWZrioVjO6MLgnZW9YBsXN0DoWX3rprBp6qsLdBSNduIdM6J8DqB2y/UadoJwZRduykRZRVPgka3HQ==
"@abp/bootstrap@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/bootstrap/-/bootstrap-10.0.0.tgz#f78a0a0f1dbee8839d074e23559fd9bf906673fd"
integrity sha512-yXnSvZVl1T6y3vcZTCFBAm9C3kqWViM8cpYWGD/MNFnxz3CrrnCkE+SHFGwEaU2CozEBXIGgT3pDZ1rgQOIg9Q==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
bootstrap "^5.3.8"
"@abp/clipboard@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/clipboard/-/clipboard-10.0.0-rc.3.tgz#43f7989809da0df90eecbdda999351defa9f3eec"
integrity sha512-KXvgt91WX4GDOLZsT8OpTBwWdN93/adX+b5OuNxzgASdxKWXI+cj2ZU2PIyKQjPvU7A6tqsBqglVe4DKlGDCiQ==
"@abp/clipboard@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/clipboard/-/clipboard-10.0.0.tgz#ad3ebdcf5da314b4213518c2841fd8a15c3d4bf1"
integrity sha512-UT9NIqLvKL88ybA67SihA3CAzcNXYACTP/pDLM5IoqkRs0UNpUlN7+nK5pmC6j1TxY72piGoa+havcWikU/7Jw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
clipboard "^2.0.11"
"@abp/core@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/core/-/core-10.0.0-rc.3.tgz#7c74ed023ee91fa18d92dc33a64c11d279eb2414"
integrity sha512-z6QKxlAsiXcCwvn3BvNouLa7UsxQmQSlZ2yleTcJ7uEDSwUzbhzCiUQ5WwHTqoOACPQ71/wasSaxEyeRQBcE8w==
"@abp/core@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/core/-/core-10.0.0.tgz#a201dab2cec00d61154499fc0e4784632d6a4c29"
integrity sha512-9pg6a95iHtUMF9T0ZoNLO4xAJWoephBLPl2HqQ3TeagBuW3J1fu4FRM0bkvoUMaOUJ1O4emcfLUxkzqbaoEQWA==
dependencies:
"@abp/utils" "~10.0.0-rc.3"
"@abp/utils" "~10.0.0"
"@abp/datatables.net-bs5@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/datatables.net-bs5/-/datatables.net-bs5-10.0.0-rc.3.tgz#13a533e454c60702ab10eb41faa5643a7d6f6cce"
integrity sha512-a6O+iLX/LdLZTCbLfR7HJlr+z8KlIxih/PFBqaf5lLmTnyS0aJii+KMHjD7nRJy5/TWI+ALiT7gWRbjiHxOuFQ==
"@abp/datatables.net-bs5@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/datatables.net-bs5/-/datatables.net-bs5-10.0.0.tgz#bc5d59dffbbb22ec866b1702424433cc5fd3280e"
integrity sha512-2d/xlLHdf4oFE3EDyXpIQcdfsPjYvrUdv5RJTIajhMQ9vCftYwDtruDtVgnfNef7BR0KeeRJ3LAyxynh3siOuQ==
dependencies:
"@abp/datatables.net" "~10.0.0-rc.3"
"@abp/datatables.net" "~10.0.0"
datatables.net-bs5 "^2.3.4"
"@abp/datatables.net@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/datatables.net/-/datatables.net-10.0.0-rc.3.tgz#ae97a33f1695b6cab1658ff476a984c7ab9d51a6"
integrity sha512-1gHnOKNJxELYHY7eeO32aFm5+YA2YSEeOO6HrY4HZLRDr5rOHDAswH2OwFtn/qVPGR1fVbUr1TA9uqPOtxsJXA==
"@abp/datatables.net@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/datatables.net/-/datatables.net-10.0.0.tgz#9aa4dec837007eafa93667fcc36fe08f2ca25fcf"
integrity sha512-GoxswQyOyYvCxZDdbNPMlJ9CG0S2OpmK1CqLOVLFbYYHWSGT8X4T+AVg7Bys2AaBqqz3Smg1duIawfMu2yVEAA==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
datatables.net "^2.3.4"
"@abp/font-awesome@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/font-awesome/-/font-awesome-10.0.0-rc.3.tgz#a5b619452416af76203ef1bab18399abf8b8fa96"
integrity sha512-6FoA/2odS1kdV1EJ91YgIjMQiQdblUfqtDx72fDG7+qnqRyZ+Df/KWOqramEe9791zbXByZL4SjpqoisZgFNzQ==
"@abp/font-awesome@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/font-awesome/-/font-awesome-10.0.0.tgz#390669267f70a817f21f1cc0508a8ceb613fc631"
integrity sha512-R1pckhwQj+lHLV6rRD/sxEPqz58Od4xPKYR1IcfveZ74GV/PqVmjbNkC0U655l+CI6pwZzzyJMFVNRgl22/v6w==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
"@fortawesome/fontawesome-free" "^7.0.1"
"@abp/jquery-form@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery-form/-/jquery-form-10.0.0-rc.3.tgz#24eefc512942dca37bdeb3fc1753cc3651e2872a"
integrity sha512-RRcGjt3blqH2R4uwrbrO+p1Kv6e7i1oJ9Wf6xrZK2upVfUvToUbif15HlC24FhNPX3BEUyL52s5HKcVBU5/1iw==
"@abp/jquery-form@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery-form/-/jquery-form-10.0.0.tgz#27182c80e17b4ffbc2551fa3e5d22f058c5b71ef"
integrity sha512-QVf+geob891AfdM2SGWbuUXo9/MhIquqmBgLJveKXRoNExqLyp2+jbd4YTRUW9RB7ZEzoKg+U+Om9ax/nnRV4A==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
jquery-form "^4.3.0"
"@abp/jquery-validation-unobtrusive@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation-unobtrusive/-/jquery-validation-unobtrusive-10.0.0-rc.3.tgz#20c8647e006954887eebe86e17ef39a336f47a30"
integrity sha512-6DVIIEVyqyeKMrZHNOTfW3/xuw7rkjqTMKXT6Z1wrDpt9Erseuz8CjbPpcS+RwpXn6va5ShrkJlwwyScFOKvkQ==
"@abp/jquery-validation-unobtrusive@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation-unobtrusive/-/jquery-validation-unobtrusive-10.0.0.tgz#89698d2ec25f21e697d5b23540885a2c74115db8"
integrity sha512-eqri3yDeyFutZcOJrP8aVf5vKoE47KP/mL8TXCRjyjVCZsHxOgjhSRY4n4rYo0JK2fePBOhwb5vpBhlezFKoNg==
dependencies:
"@abp/jquery-validation" "~10.0.0-rc.3"
"@abp/jquery-validation" "~10.0.0"
jquery-validation-unobtrusive "^4.0.0"
"@abp/jquery-validation@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation/-/jquery-validation-10.0.0-rc.3.tgz#2e562ad5ca7c5bef389a0b24293a3193fa9823ef"
integrity sha512-xLJVvCkUrNnVeQbdsKfBj7zh3cSaPJC3eWKm2NoVy9KimEhF4zeSJEkciFmS0cckSal+AO2xC8W8ot3FqpkCHQ==
"@abp/jquery-validation@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation/-/jquery-validation-10.0.0.tgz#83850af15bd3d65c399519da9461ff30fd615197"
integrity sha512-2Sigm4L+8IwzvLYIoNWpOE8u/HvHLqWlOfqClL1x0p3JQBhgAVNns5sm3P6xgjWVJpCzrUOh8lxFMUGUiRSS0w==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
jquery-validation "^1.21.0"
"@abp/jquery@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery/-/jquery-10.0.0-rc.3.tgz#3400f1b8c6966e2d71fceb5349f05b88aeb2bb88"
integrity sha512-liz3FITKdESLGomITjUqcOZYvV0rs61vYMxSbaCDoCKIQj4Ne9mN+HJ/KOpD6GOhqVsjmYOxDuSoecjiFLjVxA==
"@abp/jquery@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery/-/jquery-10.0.0.tgz#530b968eed2e94d13381679aabddfa4cb1aad8d5"
integrity sha512-KksQlTs3VojDBxjBcLPkI55V7aG9TpDqzpylVq+5Sj8ZozFH9C75XQZpkLVwiU57rGYyQpfKuKAAPiZlJnWK0Q==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
jquery "~3.7.1"
"@abp/lodash@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/lodash/-/lodash-10.0.0-rc.3.tgz#738baf7394d466112dc5a2380f2c549053621505"
integrity sha512-5PYQks4sJPdiz9zfZD1bfrCkmQ+ZMfWg2xyjbHoQzJdqu9rb2SRzkQ5MAWvqQPVTdLY6Bnutwxuq6mjkfcthcQ==
"@abp/lodash@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/lodash/-/lodash-10.0.0.tgz#08c271911d398329dbcb815c109bf3a29a940f1c"
integrity sha512-I8cqRK/2ln0/dFT9e+XzmjprBO2GnN5JCP8pb9q3wgOYb+Wf+BYg/3RQQhGAv+NhwCsxAezRMQfF+DU3xb3hAw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
lodash "^4.17.21"
"@abp/luxon@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/luxon/-/luxon-10.0.0-rc.3.tgz#bfb0c5fbf4a321e4531ec5b34dcdee47b486afe8"
integrity sha512-PCifbFy7t1h4L+FKJAo5Xr7v5hTvlelwuCsOVGfG8HVWmbOTKiQJywtxvSnARbsJ6SghUEzbqMzeX6nyHZ4Zuw==
"@abp/luxon@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/luxon/-/luxon-10.0.0.tgz#e0743dca2b50561176aec44cf90870e80863d6b9"
integrity sha512-CUPHIW/7osW2wDtjB6OuURq16/jAIPV9ssGINUxgJZYpVKsaHCfORQLQ+wn8h653Crf5CEiDVZMpuLaLVFEpXw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
luxon "^3.7.2"
"@abp/malihu-custom-scrollbar-plugin@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/malihu-custom-scrollbar-plugin/-/malihu-custom-scrollbar-plugin-10.0.0-rc.3.tgz#03bf7a8b2e71ec463794260e7fe5e6bfeb526f8e"
integrity sha512-aHOZnr4iPS6QqV07cXyWpQVl6zAaQXuct1yTeIUqcAqxsSt63K6Y27nBR8cU/m6BHhjaxSLn1kynOeccmx7lDA==
"@abp/malihu-custom-scrollbar-plugin@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/malihu-custom-scrollbar-plugin/-/malihu-custom-scrollbar-plugin-10.0.0.tgz#ff69e4dd180c7d6945b5db883b57b1131c51fae6"
integrity sha512-yGHsYExELbF/sKXS6zQ9SqEsl8w3yr6daWOkgW/aoITks6DeOte2jdjP2Ly6UpHQbAzbeAjZg0oCrSbtcz/tZw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
malihu-custom-scrollbar-plugin "^3.1.5"
"@abp/moment@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/moment/-/moment-10.0.0-rc.3.tgz#1d2c8081b9f7f2716b250d16b41021e74c093fb0"
integrity sha512-VKDVY3ml3bhPh2rUsUN1F7zH5Myi+jRYxQYC/OuOsa1P4x9+cKs1lsS68NYAq+JyMlwwuJcAx63nqkxArz+VEw==
"@abp/moment@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/moment/-/moment-10.0.0.tgz#8b84d1a15c43d0099125be2b5b071e11a7b402d4"
integrity sha512-AAu4BgciErLKYTIW6uT14q5WCl+oJeXz0J7a/kyZz2tHYbQz4FnYWMuFoDUFvkKKtGzyq7LuKTmGPxmJUXNpRg==
dependencies:
moment "^2.30.1"
"@abp/owl.carousel@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/owl.carousel/-/owl.carousel-10.0.0-rc.3.tgz#4ba445bfd7a5fa291720f0307673fc35b521f52d"
integrity sha512-rY0fd51iM1rnqODzzNdPfJ/XGvVX8Rdk3gcAjHFiz1pPYl9xWMYs7dFtwFuld7RX9deZC3+na9jaRMAYViwtBQ==
"@abp/owl.carousel@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/owl.carousel/-/owl.carousel-10.0.0.tgz#d12fcf3a95b90053b1e81abfa135c11c3ce28c58"
integrity sha512-nJRgms6lZuqWjnplyJkKUYbGLUVsfOryptCMFqhRQUC8EKdK3ls3ebM4fmfI6QHFuBncfWDcYHYsQViDUgxJbg==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
owl.carousel "^2.3.4"
"@abp/prismjs@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/prismjs/-/prismjs-10.0.0-rc.3.tgz#d7342b793fc7baf205726e8a088de88778fc24b1"
integrity sha512-cafgH3lrlT+jOuQKtBVeORbBkJKCG2DqnVF0blaD75ww32R5TJS+LH8gOufezdTfASG14ZlpzqNLl1Xu67Wh4Q==
"@abp/prismjs@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/prismjs/-/prismjs-10.0.0.tgz#6463b5d5fcbe2f9da687e04c49d38e8eb6e778b8"
integrity sha512-N2p18MAX9wYx62Ck5+V/RWLGyX+1BemiVuNX/cIOJMG0iDVJ57C6fEX1HzLc9Mchi+MXPHUR7lKwg92ui2OzfQ==
dependencies:
"@abp/clipboard" "~10.0.0-rc.3"
"@abp/core" "~10.0.0-rc.3"
"@abp/clipboard" "~10.0.0"
"@abp/core" "~10.0.0"
prismjs "^1.30.0"
"@abp/select2@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/select2/-/select2-10.0.0-rc.3.tgz#216403f1207a2556b0317fb973ed874c34c7fb73"
integrity sha512-6t/ZZl9xo0G86dX8zmEv82/64dOxCTgcQvjRGTb5Xwzh05nKHKpFFhJm6juVvpJcYqUj6Weks66SVjr6Wi2kQQ==
"@abp/select2@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/select2/-/select2-10.0.0.tgz#0a3a425c30e4139b8677c871bb7bfd2ab010b9f6"
integrity sha512-ZAFuLA8CIJr/UspKN/coRxnB+3xArc06a0YQ6HHVL5RWVRlRkcuZL/2aBFQ5HdrWZjSmImG1yXKxGyVLNmavpQ==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
select2 "^4.0.13"
"@abp/sweetalert2@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/sweetalert2/-/sweetalert2-10.0.0-rc.3.tgz#401dc08eb4607d3a575a5288296f6c703b18df8a"
integrity sha512-2nB9I+GxK7UeIjvdUJtAH9GqIL/HloQ+7WC/ZWUNLCBqI5Owx30La2wxj5e9MlDNcLvYs3A2EJP0Llo4Gdefsg==
"@abp/sweetalert2@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/sweetalert2/-/sweetalert2-10.0.0.tgz#ef9830d0d294aa685fe6ad8049056650a7d46381"
integrity sha512-wAAIacOdWyBiJMVuFVbiNpR3SnRsyhNHmNr4gmhge5KBDlO+JQlueaar0MrKkdUNaXuF9memdgERzi/cIJm1mw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
sweetalert2 "^11.23.0"
"@abp/timeago@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/timeago/-/timeago-10.0.0-rc.3.tgz#6fc8f16107171ae6f6afbbd3dc7e844651ffcf77"
integrity sha512-JYhSRbz06IObwA32GutyV+yo4p5PdAmGtlaApDLCpSFccHsel/A3jrN+ykovKy4chWYcbOhxhgjWw6ZaIZMvJg==
"@abp/timeago@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/timeago/-/timeago-10.0.0.tgz#af348b8ca21c466847c3dd47d4947f615ff82707"
integrity sha512-LbGIKpsDJyoDpN4ams9yTebA7fOPerdN4bQUWJB/7LV5wI0jtzkvbe+bEI00NLeMIDJ/nU+k+ecjhQjzkrY7qQ==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
timeago "^1.6.7"
"@abp/tui-editor@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/tui-editor/-/tui-editor-10.0.0-rc.3.tgz#0a196dcfd7eb30223b808e1c192942e6135e1715"
integrity sha512-IaaI1/KNkwYVmEadIoYvuXbdkpwk7CwYA+3Sp64Ow2cbQB6IatW9h4BPHLmQqRmaP1xTLwTLVWenThEpo2CIAQ==
"@abp/tui-editor@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/tui-editor/-/tui-editor-10.0.0.tgz#6ccfe6a2337f4bc08cbb9342a43fb95fc49980f4"
integrity sha512-nDFmFbSzZ7IMM4LVIDGtvVWAbqYo+1OLOqeFL0iOXg21dUCBEs0WE8GQsaJsdOYa9AGyMLkzcHm37yqPqCN6mg==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/prismjs" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
"@abp/prismjs" "~10.0.0"
"@abp/utils@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/utils/-/utils-10.0.0-rc.3.tgz#d6a07146ba627bcfa0cadd5c7c56601609b24d57"
integrity sha512-bA/WPuosvedfQr+5cJBwKXrhd6b8fDG7LWp4PuZFMdti8nSXgOheLeZ8PcRvut94ENIXS7jzSsqapLHRj5E6zQ==
"@abp/utils@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/utils/-/utils-10.0.0.tgz#372ea8b37809ec1951d3fd74ae02adff9215245b"
integrity sha512-VO725+ALRGmjFz9Yal+joivNZpBbPS9AWOx6N5E8meEYQnHo2oEDeoOziKkwLZ4EYIizno37zwsXiQLEO4iFRg==
dependencies:
just-compare "^2.3.0"

2
modules/client-simulation/demo/Volo.ClientSimulation.Demo/package.json

@ -3,6 +3,6 @@
"name": "client-simulation-web",
"private": true,
"dependencies": {
"@abp/aspnetcore.mvc.ui.theme.basic": "~10.0.0-rc.3"
"@abp/aspnetcore.mvc.ui.theme.basic": "~10.0.0"
}
}

240
modules/client-simulation/demo/Volo.ClientSimulation.Demo/yarn.lock

@ -2,185 +2,185 @@
# yarn lockfile v1
"@abp/aspnetcore.mvc.ui.theme.basic@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.basic/-/aspnetcore.mvc.ui.theme.basic-10.0.0-rc.3.tgz#d2784a3779500b0f22149a35eb81f0456b732239"
integrity sha512-6fYmDHPbaZGzDZgNz6/UzStP3DM4icxscY/IrqyJ0Mhzq00j/4nuG7zuc9hogUxqifwrBAa/oiiUtdkG1tr4uQ==
"@abp/aspnetcore.mvc.ui.theme.basic@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.basic/-/aspnetcore.mvc.ui.theme.basic-10.0.0.tgz#ad918558653ed7c6d329d58a37e681a9f410e01f"
integrity sha512-gyAmQdwR/SWSNXF3Q8r1zyJu4h4DKnN+wSHfvfVB0A1+X/TFGUJXJ6FrJwoFh1QDAqeIdeXOTk4d+M3AZeCgIw==
dependencies:
"@abp/aspnetcore.mvc.ui.theme.shared" "~10.0.0-rc.3"
"@abp/aspnetcore.mvc.ui.theme.shared" "~10.0.0"
"@abp/aspnetcore.mvc.ui.theme.shared@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.shared/-/aspnetcore.mvc.ui.theme.shared-10.0.0-rc.3.tgz#a68d95a189e79dccb7bc50460565e03777e3823c"
integrity sha512-QvMZy5gVSksLYiGE8VvDQ7n5GKWCyuJF9Y7Kx6/bw+weWKvEk6kiqw5glTMzUOnpkM4kH7bIb8PoJSAycDlvRg==
"@abp/aspnetcore.mvc.ui.theme.shared@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.shared/-/aspnetcore.mvc.ui.theme.shared-10.0.0.tgz#ac4150739c6b2d24d27ddc86659e9d2bbdb82548"
integrity sha512-ghockOUBUG4ZoQCKB7H5Jd5ztgnxJsDoVaxpPc/amcF2Nm/7shSA0w2uK5p1Qo7icGoOriE2zM0hfpuKy7JDeQ==
dependencies:
"@abp/aspnetcore.mvc.ui" "~10.0.0-rc.3"
"@abp/bootstrap" "~10.0.0-rc.3"
"@abp/bootstrap-datepicker" "~10.0.0-rc.3"
"@abp/bootstrap-daterangepicker" "~10.0.0-rc.3"
"@abp/datatables.net-bs5" "~10.0.0-rc.3"
"@abp/font-awesome" "~10.0.0-rc.3"
"@abp/jquery-form" "~10.0.0-rc.3"
"@abp/jquery-validation-unobtrusive" "~10.0.0-rc.3"
"@abp/lodash" "~10.0.0-rc.3"
"@abp/luxon" "~10.0.0-rc.3"
"@abp/malihu-custom-scrollbar-plugin" "~10.0.0-rc.3"
"@abp/moment" "~10.0.0-rc.3"
"@abp/select2" "~10.0.0-rc.3"
"@abp/sweetalert2" "~10.0.0-rc.3"
"@abp/timeago" "~10.0.0-rc.3"
"@abp/aspnetcore.mvc.ui@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui/-/aspnetcore.mvc.ui-10.0.0-rc.3.tgz#8d3cbec33ff9efe7789e5cafb86c39e2488304ca"
integrity sha512-HqbleKwVFVRK0Xxd0XkeyCfX4+JPouEMYvQCL+zo0RDOMfPViPua5ketfU9DDhCCyMfCwy7iW0GeX9NuqEjXwg==
"@abp/aspnetcore.mvc.ui" "~10.0.0"
"@abp/bootstrap" "~10.0.0"
"@abp/bootstrap-datepicker" "~10.0.0"
"@abp/bootstrap-daterangepicker" "~10.0.0"
"@abp/datatables.net-bs5" "~10.0.0"
"@abp/font-awesome" "~10.0.0"
"@abp/jquery-form" "~10.0.0"
"@abp/jquery-validation-unobtrusive" "~10.0.0"
"@abp/lodash" "~10.0.0"
"@abp/luxon" "~10.0.0"
"@abp/malihu-custom-scrollbar-plugin" "~10.0.0"
"@abp/moment" "~10.0.0"
"@abp/select2" "~10.0.0"
"@abp/sweetalert2" "~10.0.0"
"@abp/timeago" "~10.0.0"
"@abp/aspnetcore.mvc.ui@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui/-/aspnetcore.mvc.ui-10.0.0.tgz#3357ba70f5f6545a87755a4c368f373c8cee6f8d"
integrity sha512-S8wSmfRz66ozIm17a4cPJxBDoXRqhNAa+N6uV+gLhVRvTSFAGNvcCsUTCmW4VsEf1Wnaedxwg/cUFjMc6eD6nA==
dependencies:
ansi-colors "^4.1.3"
"@abp/bootstrap-datepicker@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-datepicker/-/bootstrap-datepicker-10.0.0-rc.3.tgz#6d7528d9275cede4bf91b929dd407c744e513014"
integrity sha512-zBLJ9hQXucXOM0GpRyJCMHxdi+C5gaGQtYzguFFGDw+jW5Ht7paoAU+HYS8Dy29zHJHMk+VdO5vJovVIXhfuPg==
"@abp/bootstrap-datepicker@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-datepicker/-/bootstrap-datepicker-10.0.0.tgz#76859087323bec5e8f9d05500b1858374e8d5f11"
integrity sha512-rZo7+l/VWXsRmIKtqq6hGIqlew/nB2axIsaIHnrzuOqoSyq/SqMjBoUoQsvLSfK/YaoloYGj1r/IDmtb+OxCOg==
dependencies:
bootstrap-datepicker "^1.10.1"
"@abp/bootstrap-daterangepicker@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-daterangepicker/-/bootstrap-daterangepicker-10.0.0-rc.3.tgz#85b09ce28da96e84a9ad448cee5b73d581056041"
integrity sha512-VyAZqPZyx/sjGcYYqDPStwUMeQ+nMwud1pEmDgpPWWsRoQBPOVB3PS8KGgW4Fb2oax9i2v6wF5qqLEQkD3CDmA==
"@abp/bootstrap-daterangepicker@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-daterangepicker/-/bootstrap-daterangepicker-10.0.0.tgz#be561035b4778b040470246f71cd5b228c80bbc2"
integrity sha512-njuKNfCg06d2J454/hD6A2lUZqg77c4qHxzPhaA5IFj5xGyV9qoZv98bz3Cf8KoHS/nrTHGRiAVYhfRxtx2Xrg==
dependencies:
bootstrap-daterangepicker "^3.1.0"
"@abp/bootstrap@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/bootstrap/-/bootstrap-10.0.0-rc.3.tgz#9daacf0ab7b3967dedad7f8792b9125c439f9022"
integrity sha512-Rl5DFxazgWZrioVjO6MLgnZW9YBsXN0DoWX3rprBp6qsLdBSNduIdM6J8DqB2y/UadoJwZRduykRZRVPgka3HQ==
"@abp/bootstrap@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/bootstrap/-/bootstrap-10.0.0.tgz#f78a0a0f1dbee8839d074e23559fd9bf906673fd"
integrity sha512-yXnSvZVl1T6y3vcZTCFBAm9C3kqWViM8cpYWGD/MNFnxz3CrrnCkE+SHFGwEaU2CozEBXIGgT3pDZ1rgQOIg9Q==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
bootstrap "^5.3.8"
"@abp/core@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/core/-/core-10.0.0-rc.3.tgz#7c74ed023ee91fa18d92dc33a64c11d279eb2414"
integrity sha512-z6QKxlAsiXcCwvn3BvNouLa7UsxQmQSlZ2yleTcJ7uEDSwUzbhzCiUQ5WwHTqoOACPQ71/wasSaxEyeRQBcE8w==
"@abp/core@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/core/-/core-10.0.0.tgz#a201dab2cec00d61154499fc0e4784632d6a4c29"
integrity sha512-9pg6a95iHtUMF9T0ZoNLO4xAJWoephBLPl2HqQ3TeagBuW3J1fu4FRM0bkvoUMaOUJ1O4emcfLUxkzqbaoEQWA==
dependencies:
"@abp/utils" "~10.0.0-rc.3"
"@abp/utils" "~10.0.0"
"@abp/datatables.net-bs5@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/datatables.net-bs5/-/datatables.net-bs5-10.0.0-rc.3.tgz#13a533e454c60702ab10eb41faa5643a7d6f6cce"
integrity sha512-a6O+iLX/LdLZTCbLfR7HJlr+z8KlIxih/PFBqaf5lLmTnyS0aJii+KMHjD7nRJy5/TWI+ALiT7gWRbjiHxOuFQ==
"@abp/datatables.net-bs5@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/datatables.net-bs5/-/datatables.net-bs5-10.0.0.tgz#bc5d59dffbbb22ec866b1702424433cc5fd3280e"
integrity sha512-2d/xlLHdf4oFE3EDyXpIQcdfsPjYvrUdv5RJTIajhMQ9vCftYwDtruDtVgnfNef7BR0KeeRJ3LAyxynh3siOuQ==
dependencies:
"@abp/datatables.net" "~10.0.0-rc.3"
"@abp/datatables.net" "~10.0.0"
datatables.net-bs5 "^2.3.4"
"@abp/datatables.net@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/datatables.net/-/datatables.net-10.0.0-rc.3.tgz#ae97a33f1695b6cab1658ff476a984c7ab9d51a6"
integrity sha512-1gHnOKNJxELYHY7eeO32aFm5+YA2YSEeOO6HrY4HZLRDr5rOHDAswH2OwFtn/qVPGR1fVbUr1TA9uqPOtxsJXA==
"@abp/datatables.net@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/datatables.net/-/datatables.net-10.0.0.tgz#9aa4dec837007eafa93667fcc36fe08f2ca25fcf"
integrity sha512-GoxswQyOyYvCxZDdbNPMlJ9CG0S2OpmK1CqLOVLFbYYHWSGT8X4T+AVg7Bys2AaBqqz3Smg1duIawfMu2yVEAA==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
datatables.net "^2.3.4"
"@abp/font-awesome@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/font-awesome/-/font-awesome-10.0.0-rc.3.tgz#a5b619452416af76203ef1bab18399abf8b8fa96"
integrity sha512-6FoA/2odS1kdV1EJ91YgIjMQiQdblUfqtDx72fDG7+qnqRyZ+Df/KWOqramEe9791zbXByZL4SjpqoisZgFNzQ==
"@abp/font-awesome@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/font-awesome/-/font-awesome-10.0.0.tgz#390669267f70a817f21f1cc0508a8ceb613fc631"
integrity sha512-R1pckhwQj+lHLV6rRD/sxEPqz58Od4xPKYR1IcfveZ74GV/PqVmjbNkC0U655l+CI6pwZzzyJMFVNRgl22/v6w==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
"@fortawesome/fontawesome-free" "^7.0.1"
"@abp/jquery-form@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery-form/-/jquery-form-10.0.0-rc.3.tgz#24eefc512942dca37bdeb3fc1753cc3651e2872a"
integrity sha512-RRcGjt3blqH2R4uwrbrO+p1Kv6e7i1oJ9Wf6xrZK2upVfUvToUbif15HlC24FhNPX3BEUyL52s5HKcVBU5/1iw==
"@abp/jquery-form@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery-form/-/jquery-form-10.0.0.tgz#27182c80e17b4ffbc2551fa3e5d22f058c5b71ef"
integrity sha512-QVf+geob891AfdM2SGWbuUXo9/MhIquqmBgLJveKXRoNExqLyp2+jbd4YTRUW9RB7ZEzoKg+U+Om9ax/nnRV4A==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
jquery-form "^4.3.0"
"@abp/jquery-validation-unobtrusive@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation-unobtrusive/-/jquery-validation-unobtrusive-10.0.0-rc.3.tgz#20c8647e006954887eebe86e17ef39a336f47a30"
integrity sha512-6DVIIEVyqyeKMrZHNOTfW3/xuw7rkjqTMKXT6Z1wrDpt9Erseuz8CjbPpcS+RwpXn6va5ShrkJlwwyScFOKvkQ==
"@abp/jquery-validation-unobtrusive@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation-unobtrusive/-/jquery-validation-unobtrusive-10.0.0.tgz#89698d2ec25f21e697d5b23540885a2c74115db8"
integrity sha512-eqri3yDeyFutZcOJrP8aVf5vKoE47KP/mL8TXCRjyjVCZsHxOgjhSRY4n4rYo0JK2fePBOhwb5vpBhlezFKoNg==
dependencies:
"@abp/jquery-validation" "~10.0.0-rc.3"
"@abp/jquery-validation" "~10.0.0"
jquery-validation-unobtrusive "^4.0.0"
"@abp/jquery-validation@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation/-/jquery-validation-10.0.0-rc.3.tgz#2e562ad5ca7c5bef389a0b24293a3193fa9823ef"
integrity sha512-xLJVvCkUrNnVeQbdsKfBj7zh3cSaPJC3eWKm2NoVy9KimEhF4zeSJEkciFmS0cckSal+AO2xC8W8ot3FqpkCHQ==
"@abp/jquery-validation@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation/-/jquery-validation-10.0.0.tgz#83850af15bd3d65c399519da9461ff30fd615197"
integrity sha512-2Sigm4L+8IwzvLYIoNWpOE8u/HvHLqWlOfqClL1x0p3JQBhgAVNns5sm3P6xgjWVJpCzrUOh8lxFMUGUiRSS0w==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
jquery-validation "^1.21.0"
"@abp/jquery@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery/-/jquery-10.0.0-rc.3.tgz#3400f1b8c6966e2d71fceb5349f05b88aeb2bb88"
integrity sha512-liz3FITKdESLGomITjUqcOZYvV0rs61vYMxSbaCDoCKIQj4Ne9mN+HJ/KOpD6GOhqVsjmYOxDuSoecjiFLjVxA==
"@abp/jquery@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery/-/jquery-10.0.0.tgz#530b968eed2e94d13381679aabddfa4cb1aad8d5"
integrity sha512-KksQlTs3VojDBxjBcLPkI55V7aG9TpDqzpylVq+5Sj8ZozFH9C75XQZpkLVwiU57rGYyQpfKuKAAPiZlJnWK0Q==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
jquery "~3.7.1"
"@abp/lodash@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/lodash/-/lodash-10.0.0-rc.3.tgz#738baf7394d466112dc5a2380f2c549053621505"
integrity sha512-5PYQks4sJPdiz9zfZD1bfrCkmQ+ZMfWg2xyjbHoQzJdqu9rb2SRzkQ5MAWvqQPVTdLY6Bnutwxuq6mjkfcthcQ==
"@abp/lodash@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/lodash/-/lodash-10.0.0.tgz#08c271911d398329dbcb815c109bf3a29a940f1c"
integrity sha512-I8cqRK/2ln0/dFT9e+XzmjprBO2GnN5JCP8pb9q3wgOYb+Wf+BYg/3RQQhGAv+NhwCsxAezRMQfF+DU3xb3hAw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
lodash "^4.17.21"
"@abp/luxon@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/luxon/-/luxon-10.0.0-rc.3.tgz#bfb0c5fbf4a321e4531ec5b34dcdee47b486afe8"
integrity sha512-PCifbFy7t1h4L+FKJAo5Xr7v5hTvlelwuCsOVGfG8HVWmbOTKiQJywtxvSnARbsJ6SghUEzbqMzeX6nyHZ4Zuw==
"@abp/luxon@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/luxon/-/luxon-10.0.0.tgz#e0743dca2b50561176aec44cf90870e80863d6b9"
integrity sha512-CUPHIW/7osW2wDtjB6OuURq16/jAIPV9ssGINUxgJZYpVKsaHCfORQLQ+wn8h653Crf5CEiDVZMpuLaLVFEpXw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
luxon "^3.7.2"
"@abp/malihu-custom-scrollbar-plugin@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/malihu-custom-scrollbar-plugin/-/malihu-custom-scrollbar-plugin-10.0.0-rc.3.tgz#03bf7a8b2e71ec463794260e7fe5e6bfeb526f8e"
integrity sha512-aHOZnr4iPS6QqV07cXyWpQVl6zAaQXuct1yTeIUqcAqxsSt63K6Y27nBR8cU/m6BHhjaxSLn1kynOeccmx7lDA==
"@abp/malihu-custom-scrollbar-plugin@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/malihu-custom-scrollbar-plugin/-/malihu-custom-scrollbar-plugin-10.0.0.tgz#ff69e4dd180c7d6945b5db883b57b1131c51fae6"
integrity sha512-yGHsYExELbF/sKXS6zQ9SqEsl8w3yr6daWOkgW/aoITks6DeOte2jdjP2Ly6UpHQbAzbeAjZg0oCrSbtcz/tZw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
malihu-custom-scrollbar-plugin "^3.1.5"
"@abp/moment@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/moment/-/moment-10.0.0-rc.3.tgz#1d2c8081b9f7f2716b250d16b41021e74c093fb0"
integrity sha512-VKDVY3ml3bhPh2rUsUN1F7zH5Myi+jRYxQYC/OuOsa1P4x9+cKs1lsS68NYAq+JyMlwwuJcAx63nqkxArz+VEw==
"@abp/moment@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/moment/-/moment-10.0.0.tgz#8b84d1a15c43d0099125be2b5b071e11a7b402d4"
integrity sha512-AAu4BgciErLKYTIW6uT14q5WCl+oJeXz0J7a/kyZz2tHYbQz4FnYWMuFoDUFvkKKtGzyq7LuKTmGPxmJUXNpRg==
dependencies:
moment "^2.30.1"
"@abp/select2@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/select2/-/select2-10.0.0-rc.3.tgz#216403f1207a2556b0317fb973ed874c34c7fb73"
integrity sha512-6t/ZZl9xo0G86dX8zmEv82/64dOxCTgcQvjRGTb5Xwzh05nKHKpFFhJm6juVvpJcYqUj6Weks66SVjr6Wi2kQQ==
"@abp/select2@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/select2/-/select2-10.0.0.tgz#0a3a425c30e4139b8677c871bb7bfd2ab010b9f6"
integrity sha512-ZAFuLA8CIJr/UspKN/coRxnB+3xArc06a0YQ6HHVL5RWVRlRkcuZL/2aBFQ5HdrWZjSmImG1yXKxGyVLNmavpQ==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
select2 "^4.0.13"
"@abp/sweetalert2@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/sweetalert2/-/sweetalert2-10.0.0-rc.3.tgz#401dc08eb4607d3a575a5288296f6c703b18df8a"
integrity sha512-2nB9I+GxK7UeIjvdUJtAH9GqIL/HloQ+7WC/ZWUNLCBqI5Owx30La2wxj5e9MlDNcLvYs3A2EJP0Llo4Gdefsg==
"@abp/sweetalert2@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/sweetalert2/-/sweetalert2-10.0.0.tgz#ef9830d0d294aa685fe6ad8049056650a7d46381"
integrity sha512-wAAIacOdWyBiJMVuFVbiNpR3SnRsyhNHmNr4gmhge5KBDlO+JQlueaar0MrKkdUNaXuF9memdgERzi/cIJm1mw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
sweetalert2 "^11.23.0"
"@abp/timeago@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/timeago/-/timeago-10.0.0-rc.3.tgz#6fc8f16107171ae6f6afbbd3dc7e844651ffcf77"
integrity sha512-JYhSRbz06IObwA32GutyV+yo4p5PdAmGtlaApDLCpSFccHsel/A3jrN+ykovKy4chWYcbOhxhgjWw6ZaIZMvJg==
"@abp/timeago@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/timeago/-/timeago-10.0.0.tgz#af348b8ca21c466847c3dd47d4947f615ff82707"
integrity sha512-LbGIKpsDJyoDpN4ams9yTebA7fOPerdN4bQUWJB/7LV5wI0jtzkvbe+bEI00NLeMIDJ/nU+k+ecjhQjzkrY7qQ==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
timeago "^1.6.7"
"@abp/utils@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/utils/-/utils-10.0.0-rc.3.tgz#d6a07146ba627bcfa0cadd5c7c56601609b24d57"
integrity sha512-bA/WPuosvedfQr+5cJBwKXrhd6b8fDG7LWp4PuZFMdti8nSXgOheLeZ8PcRvut94ENIXS7jzSsqapLHRj5E6zQ==
"@abp/utils@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/utils/-/utils-10.0.0.tgz#372ea8b37809ec1951d3fd74ae02adff9215245b"
integrity sha512-VO725+ALRGmjFz9Yal+joivNZpBbPS9AWOx6N5E8meEYQnHo2oEDeoOziKkwLZ4EYIizno37zwsXiQLEO4iFRg==
dependencies:
just-compare "^2.3.0"

10
modules/cms-kit/angular/package.json

@ -15,11 +15,11 @@
},
"private": true,
"dependencies": {
"@abp/ng.account": "~10.0.0-rc.3",
"@abp/ng.identity": "~10.0.0-rc.3",
"@abp/ng.setting-management": "~10.0.0-rc.3",
"@abp/ng.tenant-management": "~10.0.0-rc.3",
"@abp/ng.theme.basic": "~10.0.0-rc.3",
"@abp/ng.account": "~10.0.0",
"@abp/ng.identity": "~10.0.0",
"@abp/ng.setting-management": "~10.0.0",
"@abp/ng.tenant-management": "~10.0.0",
"@abp/ng.theme.basic": "~10.0.0",
"@angular/animations": "~10.0.0",
"@angular/common": "~10.0.0",
"@angular/compiler": "~10.0.0",

4
modules/cms-kit/angular/projects/cms-kit/package.json

@ -4,8 +4,8 @@
"peerDependencies": {
"@angular/common": "^9.1.11",
"@angular/core": "^9.1.11",
"@abp/ng.core": ">=10.0.0-rc.3",
"@abp/ng.theme.shared": ">=10.0.0-rc.3"
"@abp/ng.core": ">=10.0.0",
"@abp/ng.theme.shared": ">=10.0.0"
},
"dependencies": {
"tslib": "^2.0.0"

2
modules/cms-kit/host/Volo.CmsKit.IdentityServer/package.json

@ -3,6 +3,6 @@
"name": "my-app-identityserver",
"private": true,
"dependencies": {
"@abp/aspnetcore.mvc.ui.theme.basic": "~10.0.0-rc.3"
"@abp/aspnetcore.mvc.ui.theme.basic": "~10.0.0"
}
}

240
modules/cms-kit/host/Volo.CmsKit.IdentityServer/yarn.lock

@ -2,185 +2,185 @@
# yarn lockfile v1
"@abp/aspnetcore.mvc.ui.theme.basic@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.basic/-/aspnetcore.mvc.ui.theme.basic-10.0.0-rc.3.tgz#d2784a3779500b0f22149a35eb81f0456b732239"
integrity sha512-6fYmDHPbaZGzDZgNz6/UzStP3DM4icxscY/IrqyJ0Mhzq00j/4nuG7zuc9hogUxqifwrBAa/oiiUtdkG1tr4uQ==
"@abp/aspnetcore.mvc.ui.theme.basic@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.basic/-/aspnetcore.mvc.ui.theme.basic-10.0.0.tgz#ad918558653ed7c6d329d58a37e681a9f410e01f"
integrity sha512-gyAmQdwR/SWSNXF3Q8r1zyJu4h4DKnN+wSHfvfVB0A1+X/TFGUJXJ6FrJwoFh1QDAqeIdeXOTk4d+M3AZeCgIw==
dependencies:
"@abp/aspnetcore.mvc.ui.theme.shared" "~10.0.0-rc.3"
"@abp/aspnetcore.mvc.ui.theme.shared" "~10.0.0"
"@abp/aspnetcore.mvc.ui.theme.shared@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.shared/-/aspnetcore.mvc.ui.theme.shared-10.0.0-rc.3.tgz#a68d95a189e79dccb7bc50460565e03777e3823c"
integrity sha512-QvMZy5gVSksLYiGE8VvDQ7n5GKWCyuJF9Y7Kx6/bw+weWKvEk6kiqw5glTMzUOnpkM4kH7bIb8PoJSAycDlvRg==
"@abp/aspnetcore.mvc.ui.theme.shared@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.shared/-/aspnetcore.mvc.ui.theme.shared-10.0.0.tgz#ac4150739c6b2d24d27ddc86659e9d2bbdb82548"
integrity sha512-ghockOUBUG4ZoQCKB7H5Jd5ztgnxJsDoVaxpPc/amcF2Nm/7shSA0w2uK5p1Qo7icGoOriE2zM0hfpuKy7JDeQ==
dependencies:
"@abp/aspnetcore.mvc.ui" "~10.0.0-rc.3"
"@abp/bootstrap" "~10.0.0-rc.3"
"@abp/bootstrap-datepicker" "~10.0.0-rc.3"
"@abp/bootstrap-daterangepicker" "~10.0.0-rc.3"
"@abp/datatables.net-bs5" "~10.0.0-rc.3"
"@abp/font-awesome" "~10.0.0-rc.3"
"@abp/jquery-form" "~10.0.0-rc.3"
"@abp/jquery-validation-unobtrusive" "~10.0.0-rc.3"
"@abp/lodash" "~10.0.0-rc.3"
"@abp/luxon" "~10.0.0-rc.3"
"@abp/malihu-custom-scrollbar-plugin" "~10.0.0-rc.3"
"@abp/moment" "~10.0.0-rc.3"
"@abp/select2" "~10.0.0-rc.3"
"@abp/sweetalert2" "~10.0.0-rc.3"
"@abp/timeago" "~10.0.0-rc.3"
"@abp/aspnetcore.mvc.ui@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui/-/aspnetcore.mvc.ui-10.0.0-rc.3.tgz#8d3cbec33ff9efe7789e5cafb86c39e2488304ca"
integrity sha512-HqbleKwVFVRK0Xxd0XkeyCfX4+JPouEMYvQCL+zo0RDOMfPViPua5ketfU9DDhCCyMfCwy7iW0GeX9NuqEjXwg==
"@abp/aspnetcore.mvc.ui" "~10.0.0"
"@abp/bootstrap" "~10.0.0"
"@abp/bootstrap-datepicker" "~10.0.0"
"@abp/bootstrap-daterangepicker" "~10.0.0"
"@abp/datatables.net-bs5" "~10.0.0"
"@abp/font-awesome" "~10.0.0"
"@abp/jquery-form" "~10.0.0"
"@abp/jquery-validation-unobtrusive" "~10.0.0"
"@abp/lodash" "~10.0.0"
"@abp/luxon" "~10.0.0"
"@abp/malihu-custom-scrollbar-plugin" "~10.0.0"
"@abp/moment" "~10.0.0"
"@abp/select2" "~10.0.0"
"@abp/sweetalert2" "~10.0.0"
"@abp/timeago" "~10.0.0"
"@abp/aspnetcore.mvc.ui@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui/-/aspnetcore.mvc.ui-10.0.0.tgz#3357ba70f5f6545a87755a4c368f373c8cee6f8d"
integrity sha512-S8wSmfRz66ozIm17a4cPJxBDoXRqhNAa+N6uV+gLhVRvTSFAGNvcCsUTCmW4VsEf1Wnaedxwg/cUFjMc6eD6nA==
dependencies:
ansi-colors "^4.1.3"
"@abp/bootstrap-datepicker@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-datepicker/-/bootstrap-datepicker-10.0.0-rc.3.tgz#6d7528d9275cede4bf91b929dd407c744e513014"
integrity sha512-zBLJ9hQXucXOM0GpRyJCMHxdi+C5gaGQtYzguFFGDw+jW5Ht7paoAU+HYS8Dy29zHJHMk+VdO5vJovVIXhfuPg==
"@abp/bootstrap-datepicker@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-datepicker/-/bootstrap-datepicker-10.0.0.tgz#76859087323bec5e8f9d05500b1858374e8d5f11"
integrity sha512-rZo7+l/VWXsRmIKtqq6hGIqlew/nB2axIsaIHnrzuOqoSyq/SqMjBoUoQsvLSfK/YaoloYGj1r/IDmtb+OxCOg==
dependencies:
bootstrap-datepicker "^1.10.1"
"@abp/bootstrap-daterangepicker@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-daterangepicker/-/bootstrap-daterangepicker-10.0.0-rc.3.tgz#85b09ce28da96e84a9ad448cee5b73d581056041"
integrity sha512-VyAZqPZyx/sjGcYYqDPStwUMeQ+nMwud1pEmDgpPWWsRoQBPOVB3PS8KGgW4Fb2oax9i2v6wF5qqLEQkD3CDmA==
"@abp/bootstrap-daterangepicker@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-daterangepicker/-/bootstrap-daterangepicker-10.0.0.tgz#be561035b4778b040470246f71cd5b228c80bbc2"
integrity sha512-njuKNfCg06d2J454/hD6A2lUZqg77c4qHxzPhaA5IFj5xGyV9qoZv98bz3Cf8KoHS/nrTHGRiAVYhfRxtx2Xrg==
dependencies:
bootstrap-daterangepicker "^3.1.0"
"@abp/bootstrap@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/bootstrap/-/bootstrap-10.0.0-rc.3.tgz#9daacf0ab7b3967dedad7f8792b9125c439f9022"
integrity sha512-Rl5DFxazgWZrioVjO6MLgnZW9YBsXN0DoWX3rprBp6qsLdBSNduIdM6J8DqB2y/UadoJwZRduykRZRVPgka3HQ==
"@abp/bootstrap@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/bootstrap/-/bootstrap-10.0.0.tgz#f78a0a0f1dbee8839d074e23559fd9bf906673fd"
integrity sha512-yXnSvZVl1T6y3vcZTCFBAm9C3kqWViM8cpYWGD/MNFnxz3CrrnCkE+SHFGwEaU2CozEBXIGgT3pDZ1rgQOIg9Q==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
bootstrap "^5.3.8"
"@abp/core@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/core/-/core-10.0.0-rc.3.tgz#7c74ed023ee91fa18d92dc33a64c11d279eb2414"
integrity sha512-z6QKxlAsiXcCwvn3BvNouLa7UsxQmQSlZ2yleTcJ7uEDSwUzbhzCiUQ5WwHTqoOACPQ71/wasSaxEyeRQBcE8w==
"@abp/core@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/core/-/core-10.0.0.tgz#a201dab2cec00d61154499fc0e4784632d6a4c29"
integrity sha512-9pg6a95iHtUMF9T0ZoNLO4xAJWoephBLPl2HqQ3TeagBuW3J1fu4FRM0bkvoUMaOUJ1O4emcfLUxkzqbaoEQWA==
dependencies:
"@abp/utils" "~10.0.0-rc.3"
"@abp/utils" "~10.0.0"
"@abp/datatables.net-bs5@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/datatables.net-bs5/-/datatables.net-bs5-10.0.0-rc.3.tgz#13a533e454c60702ab10eb41faa5643a7d6f6cce"
integrity sha512-a6O+iLX/LdLZTCbLfR7HJlr+z8KlIxih/PFBqaf5lLmTnyS0aJii+KMHjD7nRJy5/TWI+ALiT7gWRbjiHxOuFQ==
"@abp/datatables.net-bs5@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/datatables.net-bs5/-/datatables.net-bs5-10.0.0.tgz#bc5d59dffbbb22ec866b1702424433cc5fd3280e"
integrity sha512-2d/xlLHdf4oFE3EDyXpIQcdfsPjYvrUdv5RJTIajhMQ9vCftYwDtruDtVgnfNef7BR0KeeRJ3LAyxynh3siOuQ==
dependencies:
"@abp/datatables.net" "~10.0.0-rc.3"
"@abp/datatables.net" "~10.0.0"
datatables.net-bs5 "^2.3.4"
"@abp/datatables.net@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/datatables.net/-/datatables.net-10.0.0-rc.3.tgz#ae97a33f1695b6cab1658ff476a984c7ab9d51a6"
integrity sha512-1gHnOKNJxELYHY7eeO32aFm5+YA2YSEeOO6HrY4HZLRDr5rOHDAswH2OwFtn/qVPGR1fVbUr1TA9uqPOtxsJXA==
"@abp/datatables.net@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/datatables.net/-/datatables.net-10.0.0.tgz#9aa4dec837007eafa93667fcc36fe08f2ca25fcf"
integrity sha512-GoxswQyOyYvCxZDdbNPMlJ9CG0S2OpmK1CqLOVLFbYYHWSGT8X4T+AVg7Bys2AaBqqz3Smg1duIawfMu2yVEAA==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
datatables.net "^2.3.4"
"@abp/font-awesome@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/font-awesome/-/font-awesome-10.0.0-rc.3.tgz#a5b619452416af76203ef1bab18399abf8b8fa96"
integrity sha512-6FoA/2odS1kdV1EJ91YgIjMQiQdblUfqtDx72fDG7+qnqRyZ+Df/KWOqramEe9791zbXByZL4SjpqoisZgFNzQ==
"@abp/font-awesome@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/font-awesome/-/font-awesome-10.0.0.tgz#390669267f70a817f21f1cc0508a8ceb613fc631"
integrity sha512-R1pckhwQj+lHLV6rRD/sxEPqz58Od4xPKYR1IcfveZ74GV/PqVmjbNkC0U655l+CI6pwZzzyJMFVNRgl22/v6w==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
"@fortawesome/fontawesome-free" "^7.0.1"
"@abp/jquery-form@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery-form/-/jquery-form-10.0.0-rc.3.tgz#24eefc512942dca37bdeb3fc1753cc3651e2872a"
integrity sha512-RRcGjt3blqH2R4uwrbrO+p1Kv6e7i1oJ9Wf6xrZK2upVfUvToUbif15HlC24FhNPX3BEUyL52s5HKcVBU5/1iw==
"@abp/jquery-form@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery-form/-/jquery-form-10.0.0.tgz#27182c80e17b4ffbc2551fa3e5d22f058c5b71ef"
integrity sha512-QVf+geob891AfdM2SGWbuUXo9/MhIquqmBgLJveKXRoNExqLyp2+jbd4YTRUW9RB7ZEzoKg+U+Om9ax/nnRV4A==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
jquery-form "^4.3.0"
"@abp/jquery-validation-unobtrusive@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation-unobtrusive/-/jquery-validation-unobtrusive-10.0.0-rc.3.tgz#20c8647e006954887eebe86e17ef39a336f47a30"
integrity sha512-6DVIIEVyqyeKMrZHNOTfW3/xuw7rkjqTMKXT6Z1wrDpt9Erseuz8CjbPpcS+RwpXn6va5ShrkJlwwyScFOKvkQ==
"@abp/jquery-validation-unobtrusive@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation-unobtrusive/-/jquery-validation-unobtrusive-10.0.0.tgz#89698d2ec25f21e697d5b23540885a2c74115db8"
integrity sha512-eqri3yDeyFutZcOJrP8aVf5vKoE47KP/mL8TXCRjyjVCZsHxOgjhSRY4n4rYo0JK2fePBOhwb5vpBhlezFKoNg==
dependencies:
"@abp/jquery-validation" "~10.0.0-rc.3"
"@abp/jquery-validation" "~10.0.0"
jquery-validation-unobtrusive "^4.0.0"
"@abp/jquery-validation@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation/-/jquery-validation-10.0.0-rc.3.tgz#2e562ad5ca7c5bef389a0b24293a3193fa9823ef"
integrity sha512-xLJVvCkUrNnVeQbdsKfBj7zh3cSaPJC3eWKm2NoVy9KimEhF4zeSJEkciFmS0cckSal+AO2xC8W8ot3FqpkCHQ==
"@abp/jquery-validation@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation/-/jquery-validation-10.0.0.tgz#83850af15bd3d65c399519da9461ff30fd615197"
integrity sha512-2Sigm4L+8IwzvLYIoNWpOE8u/HvHLqWlOfqClL1x0p3JQBhgAVNns5sm3P6xgjWVJpCzrUOh8lxFMUGUiRSS0w==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
jquery-validation "^1.21.0"
"@abp/jquery@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery/-/jquery-10.0.0-rc.3.tgz#3400f1b8c6966e2d71fceb5349f05b88aeb2bb88"
integrity sha512-liz3FITKdESLGomITjUqcOZYvV0rs61vYMxSbaCDoCKIQj4Ne9mN+HJ/KOpD6GOhqVsjmYOxDuSoecjiFLjVxA==
"@abp/jquery@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery/-/jquery-10.0.0.tgz#530b968eed2e94d13381679aabddfa4cb1aad8d5"
integrity sha512-KksQlTs3VojDBxjBcLPkI55V7aG9TpDqzpylVq+5Sj8ZozFH9C75XQZpkLVwiU57rGYyQpfKuKAAPiZlJnWK0Q==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
jquery "~3.7.1"
"@abp/lodash@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/lodash/-/lodash-10.0.0-rc.3.tgz#738baf7394d466112dc5a2380f2c549053621505"
integrity sha512-5PYQks4sJPdiz9zfZD1bfrCkmQ+ZMfWg2xyjbHoQzJdqu9rb2SRzkQ5MAWvqQPVTdLY6Bnutwxuq6mjkfcthcQ==
"@abp/lodash@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/lodash/-/lodash-10.0.0.tgz#08c271911d398329dbcb815c109bf3a29a940f1c"
integrity sha512-I8cqRK/2ln0/dFT9e+XzmjprBO2GnN5JCP8pb9q3wgOYb+Wf+BYg/3RQQhGAv+NhwCsxAezRMQfF+DU3xb3hAw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
lodash "^4.17.21"
"@abp/luxon@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/luxon/-/luxon-10.0.0-rc.3.tgz#bfb0c5fbf4a321e4531ec5b34dcdee47b486afe8"
integrity sha512-PCifbFy7t1h4L+FKJAo5Xr7v5hTvlelwuCsOVGfG8HVWmbOTKiQJywtxvSnARbsJ6SghUEzbqMzeX6nyHZ4Zuw==
"@abp/luxon@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/luxon/-/luxon-10.0.0.tgz#e0743dca2b50561176aec44cf90870e80863d6b9"
integrity sha512-CUPHIW/7osW2wDtjB6OuURq16/jAIPV9ssGINUxgJZYpVKsaHCfORQLQ+wn8h653Crf5CEiDVZMpuLaLVFEpXw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
luxon "^3.7.2"
"@abp/malihu-custom-scrollbar-plugin@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/malihu-custom-scrollbar-plugin/-/malihu-custom-scrollbar-plugin-10.0.0-rc.3.tgz#03bf7a8b2e71ec463794260e7fe5e6bfeb526f8e"
integrity sha512-aHOZnr4iPS6QqV07cXyWpQVl6zAaQXuct1yTeIUqcAqxsSt63K6Y27nBR8cU/m6BHhjaxSLn1kynOeccmx7lDA==
"@abp/malihu-custom-scrollbar-plugin@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/malihu-custom-scrollbar-plugin/-/malihu-custom-scrollbar-plugin-10.0.0.tgz#ff69e4dd180c7d6945b5db883b57b1131c51fae6"
integrity sha512-yGHsYExELbF/sKXS6zQ9SqEsl8w3yr6daWOkgW/aoITks6DeOte2jdjP2Ly6UpHQbAzbeAjZg0oCrSbtcz/tZw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
malihu-custom-scrollbar-plugin "^3.1.5"
"@abp/moment@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/moment/-/moment-10.0.0-rc.3.tgz#1d2c8081b9f7f2716b250d16b41021e74c093fb0"
integrity sha512-VKDVY3ml3bhPh2rUsUN1F7zH5Myi+jRYxQYC/OuOsa1P4x9+cKs1lsS68NYAq+JyMlwwuJcAx63nqkxArz+VEw==
"@abp/moment@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/moment/-/moment-10.0.0.tgz#8b84d1a15c43d0099125be2b5b071e11a7b402d4"
integrity sha512-AAu4BgciErLKYTIW6uT14q5WCl+oJeXz0J7a/kyZz2tHYbQz4FnYWMuFoDUFvkKKtGzyq7LuKTmGPxmJUXNpRg==
dependencies:
moment "^2.30.1"
"@abp/select2@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/select2/-/select2-10.0.0-rc.3.tgz#216403f1207a2556b0317fb973ed874c34c7fb73"
integrity sha512-6t/ZZl9xo0G86dX8zmEv82/64dOxCTgcQvjRGTb5Xwzh05nKHKpFFhJm6juVvpJcYqUj6Weks66SVjr6Wi2kQQ==
"@abp/select2@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/select2/-/select2-10.0.0.tgz#0a3a425c30e4139b8677c871bb7bfd2ab010b9f6"
integrity sha512-ZAFuLA8CIJr/UspKN/coRxnB+3xArc06a0YQ6HHVL5RWVRlRkcuZL/2aBFQ5HdrWZjSmImG1yXKxGyVLNmavpQ==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
select2 "^4.0.13"
"@abp/sweetalert2@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/sweetalert2/-/sweetalert2-10.0.0-rc.3.tgz#401dc08eb4607d3a575a5288296f6c703b18df8a"
integrity sha512-2nB9I+GxK7UeIjvdUJtAH9GqIL/HloQ+7WC/ZWUNLCBqI5Owx30La2wxj5e9MlDNcLvYs3A2EJP0Llo4Gdefsg==
"@abp/sweetalert2@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/sweetalert2/-/sweetalert2-10.0.0.tgz#ef9830d0d294aa685fe6ad8049056650a7d46381"
integrity sha512-wAAIacOdWyBiJMVuFVbiNpR3SnRsyhNHmNr4gmhge5KBDlO+JQlueaar0MrKkdUNaXuF9memdgERzi/cIJm1mw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
sweetalert2 "^11.23.0"
"@abp/timeago@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/timeago/-/timeago-10.0.0-rc.3.tgz#6fc8f16107171ae6f6afbbd3dc7e844651ffcf77"
integrity sha512-JYhSRbz06IObwA32GutyV+yo4p5PdAmGtlaApDLCpSFccHsel/A3jrN+ykovKy4chWYcbOhxhgjWw6ZaIZMvJg==
"@abp/timeago@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/timeago/-/timeago-10.0.0.tgz#af348b8ca21c466847c3dd47d4947f615ff82707"
integrity sha512-LbGIKpsDJyoDpN4ams9yTebA7fOPerdN4bQUWJB/7LV5wI0jtzkvbe+bEI00NLeMIDJ/nU+k+ecjhQjzkrY7qQ==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
timeago "^1.6.7"
"@abp/utils@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/utils/-/utils-10.0.0-rc.3.tgz#d6a07146ba627bcfa0cadd5c7c56601609b24d57"
integrity sha512-bA/WPuosvedfQr+5cJBwKXrhd6b8fDG7LWp4PuZFMdti8nSXgOheLeZ8PcRvut94ENIXS7jzSsqapLHRj5E6zQ==
"@abp/utils@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/utils/-/utils-10.0.0.tgz#372ea8b37809ec1951d3fd74ae02adff9215245b"
integrity sha512-VO725+ALRGmjFz9Yal+joivNZpBbPS9AWOx6N5E8meEYQnHo2oEDeoOziKkwLZ4EYIizno37zwsXiQLEO4iFRg==
dependencies:
just-compare "^2.3.0"

2
modules/cms-kit/host/Volo.CmsKit.Web.Host/package.json

@ -3,6 +3,6 @@
"name": "my-app",
"private": true,
"dependencies": {
"@abp/aspnetcore.mvc.ui.theme.basic": "~10.0.0-rc.3"
"@abp/aspnetcore.mvc.ui.theme.basic": "~10.0.0"
}
}

240
modules/cms-kit/host/Volo.CmsKit.Web.Host/yarn.lock

@ -2,185 +2,185 @@
# yarn lockfile v1
"@abp/aspnetcore.mvc.ui.theme.basic@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.basic/-/aspnetcore.mvc.ui.theme.basic-10.0.0-rc.3.tgz#d2784a3779500b0f22149a35eb81f0456b732239"
integrity sha512-6fYmDHPbaZGzDZgNz6/UzStP3DM4icxscY/IrqyJ0Mhzq00j/4nuG7zuc9hogUxqifwrBAa/oiiUtdkG1tr4uQ==
"@abp/aspnetcore.mvc.ui.theme.basic@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.basic/-/aspnetcore.mvc.ui.theme.basic-10.0.0.tgz#ad918558653ed7c6d329d58a37e681a9f410e01f"
integrity sha512-gyAmQdwR/SWSNXF3Q8r1zyJu4h4DKnN+wSHfvfVB0A1+X/TFGUJXJ6FrJwoFh1QDAqeIdeXOTk4d+M3AZeCgIw==
dependencies:
"@abp/aspnetcore.mvc.ui.theme.shared" "~10.0.0-rc.3"
"@abp/aspnetcore.mvc.ui.theme.shared" "~10.0.0"
"@abp/aspnetcore.mvc.ui.theme.shared@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.shared/-/aspnetcore.mvc.ui.theme.shared-10.0.0-rc.3.tgz#a68d95a189e79dccb7bc50460565e03777e3823c"
integrity sha512-QvMZy5gVSksLYiGE8VvDQ7n5GKWCyuJF9Y7Kx6/bw+weWKvEk6kiqw5glTMzUOnpkM4kH7bIb8PoJSAycDlvRg==
"@abp/aspnetcore.mvc.ui.theme.shared@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.shared/-/aspnetcore.mvc.ui.theme.shared-10.0.0.tgz#ac4150739c6b2d24d27ddc86659e9d2bbdb82548"
integrity sha512-ghockOUBUG4ZoQCKB7H5Jd5ztgnxJsDoVaxpPc/amcF2Nm/7shSA0w2uK5p1Qo7icGoOriE2zM0hfpuKy7JDeQ==
dependencies:
"@abp/aspnetcore.mvc.ui" "~10.0.0-rc.3"
"@abp/bootstrap" "~10.0.0-rc.3"
"@abp/bootstrap-datepicker" "~10.0.0-rc.3"
"@abp/bootstrap-daterangepicker" "~10.0.0-rc.3"
"@abp/datatables.net-bs5" "~10.0.0-rc.3"
"@abp/font-awesome" "~10.0.0-rc.3"
"@abp/jquery-form" "~10.0.0-rc.3"
"@abp/jquery-validation-unobtrusive" "~10.0.0-rc.3"
"@abp/lodash" "~10.0.0-rc.3"
"@abp/luxon" "~10.0.0-rc.3"
"@abp/malihu-custom-scrollbar-plugin" "~10.0.0-rc.3"
"@abp/moment" "~10.0.0-rc.3"
"@abp/select2" "~10.0.0-rc.3"
"@abp/sweetalert2" "~10.0.0-rc.3"
"@abp/timeago" "~10.0.0-rc.3"
"@abp/aspnetcore.mvc.ui@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui/-/aspnetcore.mvc.ui-10.0.0-rc.3.tgz#8d3cbec33ff9efe7789e5cafb86c39e2488304ca"
integrity sha512-HqbleKwVFVRK0Xxd0XkeyCfX4+JPouEMYvQCL+zo0RDOMfPViPua5ketfU9DDhCCyMfCwy7iW0GeX9NuqEjXwg==
"@abp/aspnetcore.mvc.ui" "~10.0.0"
"@abp/bootstrap" "~10.0.0"
"@abp/bootstrap-datepicker" "~10.0.0"
"@abp/bootstrap-daterangepicker" "~10.0.0"
"@abp/datatables.net-bs5" "~10.0.0"
"@abp/font-awesome" "~10.0.0"
"@abp/jquery-form" "~10.0.0"
"@abp/jquery-validation-unobtrusive" "~10.0.0"
"@abp/lodash" "~10.0.0"
"@abp/luxon" "~10.0.0"
"@abp/malihu-custom-scrollbar-plugin" "~10.0.0"
"@abp/moment" "~10.0.0"
"@abp/select2" "~10.0.0"
"@abp/sweetalert2" "~10.0.0"
"@abp/timeago" "~10.0.0"
"@abp/aspnetcore.mvc.ui@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui/-/aspnetcore.mvc.ui-10.0.0.tgz#3357ba70f5f6545a87755a4c368f373c8cee6f8d"
integrity sha512-S8wSmfRz66ozIm17a4cPJxBDoXRqhNAa+N6uV+gLhVRvTSFAGNvcCsUTCmW4VsEf1Wnaedxwg/cUFjMc6eD6nA==
dependencies:
ansi-colors "^4.1.3"
"@abp/bootstrap-datepicker@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-datepicker/-/bootstrap-datepicker-10.0.0-rc.3.tgz#6d7528d9275cede4bf91b929dd407c744e513014"
integrity sha512-zBLJ9hQXucXOM0GpRyJCMHxdi+C5gaGQtYzguFFGDw+jW5Ht7paoAU+HYS8Dy29zHJHMk+VdO5vJovVIXhfuPg==
"@abp/bootstrap-datepicker@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-datepicker/-/bootstrap-datepicker-10.0.0.tgz#76859087323bec5e8f9d05500b1858374e8d5f11"
integrity sha512-rZo7+l/VWXsRmIKtqq6hGIqlew/nB2axIsaIHnrzuOqoSyq/SqMjBoUoQsvLSfK/YaoloYGj1r/IDmtb+OxCOg==
dependencies:
bootstrap-datepicker "^1.10.1"
"@abp/bootstrap-daterangepicker@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-daterangepicker/-/bootstrap-daterangepicker-10.0.0-rc.3.tgz#85b09ce28da96e84a9ad448cee5b73d581056041"
integrity sha512-VyAZqPZyx/sjGcYYqDPStwUMeQ+nMwud1pEmDgpPWWsRoQBPOVB3PS8KGgW4Fb2oax9i2v6wF5qqLEQkD3CDmA==
"@abp/bootstrap-daterangepicker@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-daterangepicker/-/bootstrap-daterangepicker-10.0.0.tgz#be561035b4778b040470246f71cd5b228c80bbc2"
integrity sha512-njuKNfCg06d2J454/hD6A2lUZqg77c4qHxzPhaA5IFj5xGyV9qoZv98bz3Cf8KoHS/nrTHGRiAVYhfRxtx2Xrg==
dependencies:
bootstrap-daterangepicker "^3.1.0"
"@abp/bootstrap@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/bootstrap/-/bootstrap-10.0.0-rc.3.tgz#9daacf0ab7b3967dedad7f8792b9125c439f9022"
integrity sha512-Rl5DFxazgWZrioVjO6MLgnZW9YBsXN0DoWX3rprBp6qsLdBSNduIdM6J8DqB2y/UadoJwZRduykRZRVPgka3HQ==
"@abp/bootstrap@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/bootstrap/-/bootstrap-10.0.0.tgz#f78a0a0f1dbee8839d074e23559fd9bf906673fd"
integrity sha512-yXnSvZVl1T6y3vcZTCFBAm9C3kqWViM8cpYWGD/MNFnxz3CrrnCkE+SHFGwEaU2CozEBXIGgT3pDZ1rgQOIg9Q==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
bootstrap "^5.3.8"
"@abp/core@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/core/-/core-10.0.0-rc.3.tgz#7c74ed023ee91fa18d92dc33a64c11d279eb2414"
integrity sha512-z6QKxlAsiXcCwvn3BvNouLa7UsxQmQSlZ2yleTcJ7uEDSwUzbhzCiUQ5WwHTqoOACPQ71/wasSaxEyeRQBcE8w==
"@abp/core@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/core/-/core-10.0.0.tgz#a201dab2cec00d61154499fc0e4784632d6a4c29"
integrity sha512-9pg6a95iHtUMF9T0ZoNLO4xAJWoephBLPl2HqQ3TeagBuW3J1fu4FRM0bkvoUMaOUJ1O4emcfLUxkzqbaoEQWA==
dependencies:
"@abp/utils" "~10.0.0-rc.3"
"@abp/utils" "~10.0.0"
"@abp/datatables.net-bs5@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/datatables.net-bs5/-/datatables.net-bs5-10.0.0-rc.3.tgz#13a533e454c60702ab10eb41faa5643a7d6f6cce"
integrity sha512-a6O+iLX/LdLZTCbLfR7HJlr+z8KlIxih/PFBqaf5lLmTnyS0aJii+KMHjD7nRJy5/TWI+ALiT7gWRbjiHxOuFQ==
"@abp/datatables.net-bs5@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/datatables.net-bs5/-/datatables.net-bs5-10.0.0.tgz#bc5d59dffbbb22ec866b1702424433cc5fd3280e"
integrity sha512-2d/xlLHdf4oFE3EDyXpIQcdfsPjYvrUdv5RJTIajhMQ9vCftYwDtruDtVgnfNef7BR0KeeRJ3LAyxynh3siOuQ==
dependencies:
"@abp/datatables.net" "~10.0.0-rc.3"
"@abp/datatables.net" "~10.0.0"
datatables.net-bs5 "^2.3.4"
"@abp/datatables.net@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/datatables.net/-/datatables.net-10.0.0-rc.3.tgz#ae97a33f1695b6cab1658ff476a984c7ab9d51a6"
integrity sha512-1gHnOKNJxELYHY7eeO32aFm5+YA2YSEeOO6HrY4HZLRDr5rOHDAswH2OwFtn/qVPGR1fVbUr1TA9uqPOtxsJXA==
"@abp/datatables.net@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/datatables.net/-/datatables.net-10.0.0.tgz#9aa4dec837007eafa93667fcc36fe08f2ca25fcf"
integrity sha512-GoxswQyOyYvCxZDdbNPMlJ9CG0S2OpmK1CqLOVLFbYYHWSGT8X4T+AVg7Bys2AaBqqz3Smg1duIawfMu2yVEAA==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
datatables.net "^2.3.4"
"@abp/font-awesome@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/font-awesome/-/font-awesome-10.0.0-rc.3.tgz#a5b619452416af76203ef1bab18399abf8b8fa96"
integrity sha512-6FoA/2odS1kdV1EJ91YgIjMQiQdblUfqtDx72fDG7+qnqRyZ+Df/KWOqramEe9791zbXByZL4SjpqoisZgFNzQ==
"@abp/font-awesome@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/font-awesome/-/font-awesome-10.0.0.tgz#390669267f70a817f21f1cc0508a8ceb613fc631"
integrity sha512-R1pckhwQj+lHLV6rRD/sxEPqz58Od4xPKYR1IcfveZ74GV/PqVmjbNkC0U655l+CI6pwZzzyJMFVNRgl22/v6w==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
"@fortawesome/fontawesome-free" "^7.0.1"
"@abp/jquery-form@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery-form/-/jquery-form-10.0.0-rc.3.tgz#24eefc512942dca37bdeb3fc1753cc3651e2872a"
integrity sha512-RRcGjt3blqH2R4uwrbrO+p1Kv6e7i1oJ9Wf6xrZK2upVfUvToUbif15HlC24FhNPX3BEUyL52s5HKcVBU5/1iw==
"@abp/jquery-form@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery-form/-/jquery-form-10.0.0.tgz#27182c80e17b4ffbc2551fa3e5d22f058c5b71ef"
integrity sha512-QVf+geob891AfdM2SGWbuUXo9/MhIquqmBgLJveKXRoNExqLyp2+jbd4YTRUW9RB7ZEzoKg+U+Om9ax/nnRV4A==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
jquery-form "^4.3.0"
"@abp/jquery-validation-unobtrusive@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation-unobtrusive/-/jquery-validation-unobtrusive-10.0.0-rc.3.tgz#20c8647e006954887eebe86e17ef39a336f47a30"
integrity sha512-6DVIIEVyqyeKMrZHNOTfW3/xuw7rkjqTMKXT6Z1wrDpt9Erseuz8CjbPpcS+RwpXn6va5ShrkJlwwyScFOKvkQ==
"@abp/jquery-validation-unobtrusive@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation-unobtrusive/-/jquery-validation-unobtrusive-10.0.0.tgz#89698d2ec25f21e697d5b23540885a2c74115db8"
integrity sha512-eqri3yDeyFutZcOJrP8aVf5vKoE47KP/mL8TXCRjyjVCZsHxOgjhSRY4n4rYo0JK2fePBOhwb5vpBhlezFKoNg==
dependencies:
"@abp/jquery-validation" "~10.0.0-rc.3"
"@abp/jquery-validation" "~10.0.0"
jquery-validation-unobtrusive "^4.0.0"
"@abp/jquery-validation@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation/-/jquery-validation-10.0.0-rc.3.tgz#2e562ad5ca7c5bef389a0b24293a3193fa9823ef"
integrity sha512-xLJVvCkUrNnVeQbdsKfBj7zh3cSaPJC3eWKm2NoVy9KimEhF4zeSJEkciFmS0cckSal+AO2xC8W8ot3FqpkCHQ==
"@abp/jquery-validation@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation/-/jquery-validation-10.0.0.tgz#83850af15bd3d65c399519da9461ff30fd615197"
integrity sha512-2Sigm4L+8IwzvLYIoNWpOE8u/HvHLqWlOfqClL1x0p3JQBhgAVNns5sm3P6xgjWVJpCzrUOh8lxFMUGUiRSS0w==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
jquery-validation "^1.21.0"
"@abp/jquery@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery/-/jquery-10.0.0-rc.3.tgz#3400f1b8c6966e2d71fceb5349f05b88aeb2bb88"
integrity sha512-liz3FITKdESLGomITjUqcOZYvV0rs61vYMxSbaCDoCKIQj4Ne9mN+HJ/KOpD6GOhqVsjmYOxDuSoecjiFLjVxA==
"@abp/jquery@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery/-/jquery-10.0.0.tgz#530b968eed2e94d13381679aabddfa4cb1aad8d5"
integrity sha512-KksQlTs3VojDBxjBcLPkI55V7aG9TpDqzpylVq+5Sj8ZozFH9C75XQZpkLVwiU57rGYyQpfKuKAAPiZlJnWK0Q==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
jquery "~3.7.1"
"@abp/lodash@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/lodash/-/lodash-10.0.0-rc.3.tgz#738baf7394d466112dc5a2380f2c549053621505"
integrity sha512-5PYQks4sJPdiz9zfZD1bfrCkmQ+ZMfWg2xyjbHoQzJdqu9rb2SRzkQ5MAWvqQPVTdLY6Bnutwxuq6mjkfcthcQ==
"@abp/lodash@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/lodash/-/lodash-10.0.0.tgz#08c271911d398329dbcb815c109bf3a29a940f1c"
integrity sha512-I8cqRK/2ln0/dFT9e+XzmjprBO2GnN5JCP8pb9q3wgOYb+Wf+BYg/3RQQhGAv+NhwCsxAezRMQfF+DU3xb3hAw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
lodash "^4.17.21"
"@abp/luxon@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/luxon/-/luxon-10.0.0-rc.3.tgz#bfb0c5fbf4a321e4531ec5b34dcdee47b486afe8"
integrity sha512-PCifbFy7t1h4L+FKJAo5Xr7v5hTvlelwuCsOVGfG8HVWmbOTKiQJywtxvSnARbsJ6SghUEzbqMzeX6nyHZ4Zuw==
"@abp/luxon@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/luxon/-/luxon-10.0.0.tgz#e0743dca2b50561176aec44cf90870e80863d6b9"
integrity sha512-CUPHIW/7osW2wDtjB6OuURq16/jAIPV9ssGINUxgJZYpVKsaHCfORQLQ+wn8h653Crf5CEiDVZMpuLaLVFEpXw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
luxon "^3.7.2"
"@abp/malihu-custom-scrollbar-plugin@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/malihu-custom-scrollbar-plugin/-/malihu-custom-scrollbar-plugin-10.0.0-rc.3.tgz#03bf7a8b2e71ec463794260e7fe5e6bfeb526f8e"
integrity sha512-aHOZnr4iPS6QqV07cXyWpQVl6zAaQXuct1yTeIUqcAqxsSt63K6Y27nBR8cU/m6BHhjaxSLn1kynOeccmx7lDA==
"@abp/malihu-custom-scrollbar-plugin@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/malihu-custom-scrollbar-plugin/-/malihu-custom-scrollbar-plugin-10.0.0.tgz#ff69e4dd180c7d6945b5db883b57b1131c51fae6"
integrity sha512-yGHsYExELbF/sKXS6zQ9SqEsl8w3yr6daWOkgW/aoITks6DeOte2jdjP2Ly6UpHQbAzbeAjZg0oCrSbtcz/tZw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
malihu-custom-scrollbar-plugin "^3.1.5"
"@abp/moment@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/moment/-/moment-10.0.0-rc.3.tgz#1d2c8081b9f7f2716b250d16b41021e74c093fb0"
integrity sha512-VKDVY3ml3bhPh2rUsUN1F7zH5Myi+jRYxQYC/OuOsa1P4x9+cKs1lsS68NYAq+JyMlwwuJcAx63nqkxArz+VEw==
"@abp/moment@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/moment/-/moment-10.0.0.tgz#8b84d1a15c43d0099125be2b5b071e11a7b402d4"
integrity sha512-AAu4BgciErLKYTIW6uT14q5WCl+oJeXz0J7a/kyZz2tHYbQz4FnYWMuFoDUFvkKKtGzyq7LuKTmGPxmJUXNpRg==
dependencies:
moment "^2.30.1"
"@abp/select2@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/select2/-/select2-10.0.0-rc.3.tgz#216403f1207a2556b0317fb973ed874c34c7fb73"
integrity sha512-6t/ZZl9xo0G86dX8zmEv82/64dOxCTgcQvjRGTb5Xwzh05nKHKpFFhJm6juVvpJcYqUj6Weks66SVjr6Wi2kQQ==
"@abp/select2@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/select2/-/select2-10.0.0.tgz#0a3a425c30e4139b8677c871bb7bfd2ab010b9f6"
integrity sha512-ZAFuLA8CIJr/UspKN/coRxnB+3xArc06a0YQ6HHVL5RWVRlRkcuZL/2aBFQ5HdrWZjSmImG1yXKxGyVLNmavpQ==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
select2 "^4.0.13"
"@abp/sweetalert2@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/sweetalert2/-/sweetalert2-10.0.0-rc.3.tgz#401dc08eb4607d3a575a5288296f6c703b18df8a"
integrity sha512-2nB9I+GxK7UeIjvdUJtAH9GqIL/HloQ+7WC/ZWUNLCBqI5Owx30La2wxj5e9MlDNcLvYs3A2EJP0Llo4Gdefsg==
"@abp/sweetalert2@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/sweetalert2/-/sweetalert2-10.0.0.tgz#ef9830d0d294aa685fe6ad8049056650a7d46381"
integrity sha512-wAAIacOdWyBiJMVuFVbiNpR3SnRsyhNHmNr4gmhge5KBDlO+JQlueaar0MrKkdUNaXuF9memdgERzi/cIJm1mw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
sweetalert2 "^11.23.0"
"@abp/timeago@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/timeago/-/timeago-10.0.0-rc.3.tgz#6fc8f16107171ae6f6afbbd3dc7e844651ffcf77"
integrity sha512-JYhSRbz06IObwA32GutyV+yo4p5PdAmGtlaApDLCpSFccHsel/A3jrN+ykovKy4chWYcbOhxhgjWw6ZaIZMvJg==
"@abp/timeago@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/timeago/-/timeago-10.0.0.tgz#af348b8ca21c466847c3dd47d4947f615ff82707"
integrity sha512-LbGIKpsDJyoDpN4ams9yTebA7fOPerdN4bQUWJB/7LV5wI0jtzkvbe+bEI00NLeMIDJ/nU+k+ecjhQjzkrY7qQ==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
timeago "^1.6.7"
"@abp/utils@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/utils/-/utils-10.0.0-rc.3.tgz#d6a07146ba627bcfa0cadd5c7c56601609b24d57"
integrity sha512-bA/WPuosvedfQr+5cJBwKXrhd6b8fDG7LWp4PuZFMdti8nSXgOheLeZ8PcRvut94ENIXS7jzSsqapLHRj5E6zQ==
"@abp/utils@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/utils/-/utils-10.0.0.tgz#372ea8b37809ec1951d3fd74ae02adff9215245b"
integrity sha512-VO725+ALRGmjFz9Yal+joivNZpBbPS9AWOx6N5E8meEYQnHo2oEDeoOziKkwLZ4EYIizno37zwsXiQLEO4iFRg==
dependencies:
just-compare "^2.3.0"

4
modules/cms-kit/host/Volo.CmsKit.Web.Unified/package.json

@ -3,8 +3,8 @@
"name": "my-app",
"private": true,
"dependencies": {
"@abp/aspnetcore.mvc.ui.theme.basic": "~10.0.0-rc.3",
"@abp/cms-kit": "10.0.0-rc.3"
"@abp/aspnetcore.mvc.ui.theme.basic": "~10.0.0",
"@abp/cms-kit": "10.0.0"
},
"resolutions": {
"codemirror": "^5.65.1"

392
modules/cms-kit/host/Volo.CmsKit.Web.Unified/yarn.lock

@ -2,293 +2,293 @@
# yarn lockfile v1
"@abp/aspnetcore.mvc.ui.theme.basic@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.basic/-/aspnetcore.mvc.ui.theme.basic-10.0.0-rc.3.tgz#d2784a3779500b0f22149a35eb81f0456b732239"
integrity sha512-6fYmDHPbaZGzDZgNz6/UzStP3DM4icxscY/IrqyJ0Mhzq00j/4nuG7zuc9hogUxqifwrBAa/oiiUtdkG1tr4uQ==
dependencies:
"@abp/aspnetcore.mvc.ui.theme.shared" "~10.0.0-rc.3"
"@abp/aspnetcore.mvc.ui.theme.shared@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.shared/-/aspnetcore.mvc.ui.theme.shared-10.0.0-rc.3.tgz#a68d95a189e79dccb7bc50460565e03777e3823c"
integrity sha512-QvMZy5gVSksLYiGE8VvDQ7n5GKWCyuJF9Y7Kx6/bw+weWKvEk6kiqw5glTMzUOnpkM4kH7bIb8PoJSAycDlvRg==
dependencies:
"@abp/aspnetcore.mvc.ui" "~10.0.0-rc.3"
"@abp/bootstrap" "~10.0.0-rc.3"
"@abp/bootstrap-datepicker" "~10.0.0-rc.3"
"@abp/bootstrap-daterangepicker" "~10.0.0-rc.3"
"@abp/datatables.net-bs5" "~10.0.0-rc.3"
"@abp/font-awesome" "~10.0.0-rc.3"
"@abp/jquery-form" "~10.0.0-rc.3"
"@abp/jquery-validation-unobtrusive" "~10.0.0-rc.3"
"@abp/lodash" "~10.0.0-rc.3"
"@abp/luxon" "~10.0.0-rc.3"
"@abp/malihu-custom-scrollbar-plugin" "~10.0.0-rc.3"
"@abp/moment" "~10.0.0-rc.3"
"@abp/select2" "~10.0.0-rc.3"
"@abp/sweetalert2" "~10.0.0-rc.3"
"@abp/timeago" "~10.0.0-rc.3"
"@abp/aspnetcore.mvc.ui@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui/-/aspnetcore.mvc.ui-10.0.0-rc.3.tgz#8d3cbec33ff9efe7789e5cafb86c39e2488304ca"
integrity sha512-HqbleKwVFVRK0Xxd0XkeyCfX4+JPouEMYvQCL+zo0RDOMfPViPua5ketfU9DDhCCyMfCwy7iW0GeX9NuqEjXwg==
"@abp/aspnetcore.mvc.ui.theme.basic@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.basic/-/aspnetcore.mvc.ui.theme.basic-10.0.0.tgz#ad918558653ed7c6d329d58a37e681a9f410e01f"
integrity sha512-gyAmQdwR/SWSNXF3Q8r1zyJu4h4DKnN+wSHfvfVB0A1+X/TFGUJXJ6FrJwoFh1QDAqeIdeXOTk4d+M3AZeCgIw==
dependencies:
"@abp/aspnetcore.mvc.ui.theme.shared" "~10.0.0"
"@abp/aspnetcore.mvc.ui.theme.shared@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui.theme.shared/-/aspnetcore.mvc.ui.theme.shared-10.0.0.tgz#ac4150739c6b2d24d27ddc86659e9d2bbdb82548"
integrity sha512-ghockOUBUG4ZoQCKB7H5Jd5ztgnxJsDoVaxpPc/amcF2Nm/7shSA0w2uK5p1Qo7icGoOriE2zM0hfpuKy7JDeQ==
dependencies:
"@abp/aspnetcore.mvc.ui" "~10.0.0"
"@abp/bootstrap" "~10.0.0"
"@abp/bootstrap-datepicker" "~10.0.0"
"@abp/bootstrap-daterangepicker" "~10.0.0"
"@abp/datatables.net-bs5" "~10.0.0"
"@abp/font-awesome" "~10.0.0"
"@abp/jquery-form" "~10.0.0"
"@abp/jquery-validation-unobtrusive" "~10.0.0"
"@abp/lodash" "~10.0.0"
"@abp/luxon" "~10.0.0"
"@abp/malihu-custom-scrollbar-plugin" "~10.0.0"
"@abp/moment" "~10.0.0"
"@abp/select2" "~10.0.0"
"@abp/sweetalert2" "~10.0.0"
"@abp/timeago" "~10.0.0"
"@abp/aspnetcore.mvc.ui@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/aspnetcore.mvc.ui/-/aspnetcore.mvc.ui-10.0.0.tgz#3357ba70f5f6545a87755a4c368f373c8cee6f8d"
integrity sha512-S8wSmfRz66ozIm17a4cPJxBDoXRqhNAa+N6uV+gLhVRvTSFAGNvcCsUTCmW4VsEf1Wnaedxwg/cUFjMc6eD6nA==
dependencies:
ansi-colors "^4.1.3"
"@abp/bootstrap-datepicker@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-datepicker/-/bootstrap-datepicker-10.0.0-rc.3.tgz#6d7528d9275cede4bf91b929dd407c744e513014"
integrity sha512-zBLJ9hQXucXOM0GpRyJCMHxdi+C5gaGQtYzguFFGDw+jW5Ht7paoAU+HYS8Dy29zHJHMk+VdO5vJovVIXhfuPg==
"@abp/bootstrap-datepicker@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-datepicker/-/bootstrap-datepicker-10.0.0.tgz#76859087323bec5e8f9d05500b1858374e8d5f11"
integrity sha512-rZo7+l/VWXsRmIKtqq6hGIqlew/nB2axIsaIHnrzuOqoSyq/SqMjBoUoQsvLSfK/YaoloYGj1r/IDmtb+OxCOg==
dependencies:
bootstrap-datepicker "^1.10.1"
"@abp/bootstrap-daterangepicker@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-daterangepicker/-/bootstrap-daterangepicker-10.0.0-rc.3.tgz#85b09ce28da96e84a9ad448cee5b73d581056041"
integrity sha512-VyAZqPZyx/sjGcYYqDPStwUMeQ+nMwud1pEmDgpPWWsRoQBPOVB3PS8KGgW4Fb2oax9i2v6wF5qqLEQkD3CDmA==
"@abp/bootstrap-daterangepicker@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/bootstrap-daterangepicker/-/bootstrap-daterangepicker-10.0.0.tgz#be561035b4778b040470246f71cd5b228c80bbc2"
integrity sha512-njuKNfCg06d2J454/hD6A2lUZqg77c4qHxzPhaA5IFj5xGyV9qoZv98bz3Cf8KoHS/nrTHGRiAVYhfRxtx2Xrg==
dependencies:
bootstrap-daterangepicker "^3.1.0"
"@abp/bootstrap@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/bootstrap/-/bootstrap-10.0.0-rc.3.tgz#9daacf0ab7b3967dedad7f8792b9125c439f9022"
integrity sha512-Rl5DFxazgWZrioVjO6MLgnZW9YBsXN0DoWX3rprBp6qsLdBSNduIdM6J8DqB2y/UadoJwZRduykRZRVPgka3HQ==
"@abp/bootstrap@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/bootstrap/-/bootstrap-10.0.0.tgz#f78a0a0f1dbee8839d074e23559fd9bf906673fd"
integrity sha512-yXnSvZVl1T6y3vcZTCFBAm9C3kqWViM8cpYWGD/MNFnxz3CrrnCkE+SHFGwEaU2CozEBXIGgT3pDZ1rgQOIg9Q==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
bootstrap "^5.3.8"
"@abp/clipboard@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/clipboard/-/clipboard-10.0.0-rc.3.tgz#43f7989809da0df90eecbdda999351defa9f3eec"
integrity sha512-KXvgt91WX4GDOLZsT8OpTBwWdN93/adX+b5OuNxzgASdxKWXI+cj2ZU2PIyKQjPvU7A6tqsBqglVe4DKlGDCiQ==
"@abp/clipboard@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/clipboard/-/clipboard-10.0.0.tgz#ad3ebdcf5da314b4213518c2841fd8a15c3d4bf1"
integrity sha512-UT9NIqLvKL88ybA67SihA3CAzcNXYACTP/pDLM5IoqkRs0UNpUlN7+nK5pmC6j1TxY72piGoa+havcWikU/7Jw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
clipboard "^2.0.11"
"@abp/cms-kit.admin@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/cms-kit.admin/-/cms-kit.admin-10.0.0-rc.3.tgz#260e7c6409c7004f9aee28b927b7d96c7dbcd545"
integrity sha512-5CAsTDzyJYuG1Ww+ucAOGm58nCRtavovkqMh18VuIEwrIuxFtliz5TS587kMl3XGug1MtsodFSZYHqqhzIvPVA==
"@abp/cms-kit.admin@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/cms-kit.admin/-/cms-kit.admin-10.0.0.tgz#8c100453f3b56f32c29f9d0cb8a88acd9248c0f6"
integrity sha512-mg6+b8yF+i/oxfP+tyHeNBlPj33F+iDdUshVSCrESjkEuPOGlxU+n3Xwks0XB9RyAHRpWpvNNTt6JmnKM03Mfw==
dependencies:
"@abp/codemirror" "~10.0.0-rc.3"
"@abp/jstree" "~10.0.0-rc.3"
"@abp/markdown-it" "~10.0.0-rc.3"
"@abp/slugify" "~10.0.0-rc.3"
"@abp/tui-editor" "~10.0.0-rc.3"
"@abp/uppy" "~10.0.0-rc.3"
"@abp/codemirror" "~10.0.0"
"@abp/jstree" "~10.0.0"
"@abp/markdown-it" "~10.0.0"
"@abp/slugify" "~10.0.0"
"@abp/tui-editor" "~10.0.0"
"@abp/uppy" "~10.0.0"
"@abp/cms-kit.public@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/cms-kit.public/-/cms-kit.public-10.0.0-rc.3.tgz#6c80384e979d7f00590ff42b599d0a9fce2909bb"
integrity sha512-u8aTT8p8kdhlqbEYVwXyW4CyHGpKbe5IFO9XpKFckVs7OzabbrZtFWzkVx8/kxStlLnM4DgvUo56+3ipNISMGQ==
"@abp/cms-kit.public@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/cms-kit.public/-/cms-kit.public-10.0.0.tgz#36175d172eb2fc2d1169ab98764d8ab999662c43"
integrity sha512-4U/0A+qGgMdptSsh+SdAue6wwtYsUORGclvIw5GA4JQgCRboThsh2MfB4DAkl2xZqdHsrcljShkqR0DyYMM2LA==
dependencies:
"@abp/highlight.js" "~10.0.0-rc.3"
"@abp/star-rating-svg" "~10.0.0-rc.3"
"@abp/highlight.js" "~10.0.0"
"@abp/star-rating-svg" "~10.0.0"
"@abp/cms-kit@10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/cms-kit/-/cms-kit-10.0.0-rc.3.tgz#2cb1bb682008db7ffb295cf4c529138f0c3681a1"
integrity sha512-y1ifTW2wGevW+zo42QndzcCihPf/q58512mVsmfXxJsXelFg/3f7Q3Kxndd4C4t1SLD3eygL0b69ny975v8K0g==
"@abp/cms-kit@10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/cms-kit/-/cms-kit-10.0.0.tgz#1540c00ac0ab953e9a1a765ac98bd0f6257cb3c0"
integrity sha512-KrCajyE7nVUeOhRw00s6g3bX2Fzw9uUpl0GpVO+Tsatr8Nf7qft50/i+VZ45ApRg/fnVwPhfQDKltdBfpcPrJQ==
dependencies:
"@abp/cms-kit.admin" "~10.0.0-rc.3"
"@abp/cms-kit.public" "~10.0.0-rc.3"
"@abp/cms-kit.admin" "~10.0.0"
"@abp/cms-kit.public" "~10.0.0"
"@abp/codemirror@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/codemirror/-/codemirror-10.0.0-rc.3.tgz#e5dc9fe9da5971aaad534571a4917f9008755ac4"
integrity sha512-CL0cjUTGC8R9+AV85C0v6lE4n2b1yc81pCVwgYCZB5mVDw0zLFtf0F3bnvT48UdjJ3TcHYrtiIs77oJXKAdvRA==
"@abp/codemirror@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/codemirror/-/codemirror-10.0.0.tgz#c27524db0b83a099ef2957083e2eac527ef01dac"
integrity sha512-Kb8ClFayuLz86I3bT6dwEhbkJa+NGFLa/JlrAM/9UtlehWgAkVM9D5Ze9defAF+0T5cntijhunwEWdQv5iwf0w==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
codemirror "^5.65.1"
"@abp/core@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/core/-/core-10.0.0-rc.3.tgz#7c74ed023ee91fa18d92dc33a64c11d279eb2414"
integrity sha512-z6QKxlAsiXcCwvn3BvNouLa7UsxQmQSlZ2yleTcJ7uEDSwUzbhzCiUQ5WwHTqoOACPQ71/wasSaxEyeRQBcE8w==
"@abp/core@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/core/-/core-10.0.0.tgz#a201dab2cec00d61154499fc0e4784632d6a4c29"
integrity sha512-9pg6a95iHtUMF9T0ZoNLO4xAJWoephBLPl2HqQ3TeagBuW3J1fu4FRM0bkvoUMaOUJ1O4emcfLUxkzqbaoEQWA==
dependencies:
"@abp/utils" "~10.0.0-rc.3"
"@abp/utils" "~10.0.0"
"@abp/datatables.net-bs5@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/datatables.net-bs5/-/datatables.net-bs5-10.0.0-rc.3.tgz#13a533e454c60702ab10eb41faa5643a7d6f6cce"
integrity sha512-a6O+iLX/LdLZTCbLfR7HJlr+z8KlIxih/PFBqaf5lLmTnyS0aJii+KMHjD7nRJy5/TWI+ALiT7gWRbjiHxOuFQ==
"@abp/datatables.net-bs5@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/datatables.net-bs5/-/datatables.net-bs5-10.0.0.tgz#bc5d59dffbbb22ec866b1702424433cc5fd3280e"
integrity sha512-2d/xlLHdf4oFE3EDyXpIQcdfsPjYvrUdv5RJTIajhMQ9vCftYwDtruDtVgnfNef7BR0KeeRJ3LAyxynh3siOuQ==
dependencies:
"@abp/datatables.net" "~10.0.0-rc.3"
"@abp/datatables.net" "~10.0.0"
datatables.net-bs5 "^2.3.4"
"@abp/datatables.net@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/datatables.net/-/datatables.net-10.0.0-rc.3.tgz#ae97a33f1695b6cab1658ff476a984c7ab9d51a6"
integrity sha512-1gHnOKNJxELYHY7eeO32aFm5+YA2YSEeOO6HrY4HZLRDr5rOHDAswH2OwFtn/qVPGR1fVbUr1TA9uqPOtxsJXA==
"@abp/datatables.net@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/datatables.net/-/datatables.net-10.0.0.tgz#9aa4dec837007eafa93667fcc36fe08f2ca25fcf"
integrity sha512-GoxswQyOyYvCxZDdbNPMlJ9CG0S2OpmK1CqLOVLFbYYHWSGT8X4T+AVg7Bys2AaBqqz3Smg1duIawfMu2yVEAA==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
datatables.net "^2.3.4"
"@abp/font-awesome@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/font-awesome/-/font-awesome-10.0.0-rc.3.tgz#a5b619452416af76203ef1bab18399abf8b8fa96"
integrity sha512-6FoA/2odS1kdV1EJ91YgIjMQiQdblUfqtDx72fDG7+qnqRyZ+Df/KWOqramEe9791zbXByZL4SjpqoisZgFNzQ==
"@abp/font-awesome@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/font-awesome/-/font-awesome-10.0.0.tgz#390669267f70a817f21f1cc0508a8ceb613fc631"
integrity sha512-R1pckhwQj+lHLV6rRD/sxEPqz58Od4xPKYR1IcfveZ74GV/PqVmjbNkC0U655l+CI6pwZzzyJMFVNRgl22/v6w==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
"@fortawesome/fontawesome-free" "^7.0.1"
"@abp/highlight.js@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/highlight.js/-/highlight.js-10.0.0-rc.3.tgz#b72dfecd68208e5c9125fc3f03390761c1b1b784"
integrity sha512-dNzuKfm66N7lFiDCkiDBoJNbLerbpK6XRNowVRuVIb/rgGTdMmzk7CatV0n04OJQgMqm/cq+cZSV0Lp0f7v1YA==
"@abp/highlight.js@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/highlight.js/-/highlight.js-10.0.0.tgz#8ca79a29c3fa6aef88ea20bf2fe74bdd58c3189e"
integrity sha512-BouG7VBk1VjkIIHpO3B8XggBBfs2EUD7cTD9akmDciErANjTD22hWkPRhONM4uqZX4tm9/7RL+TxBFRYXY6dFA==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
"@highlightjs/cdn-assets" "~11.11.1"
"@abp/jquery-form@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery-form/-/jquery-form-10.0.0-rc.3.tgz#24eefc512942dca37bdeb3fc1753cc3651e2872a"
integrity sha512-RRcGjt3blqH2R4uwrbrO+p1Kv6e7i1oJ9Wf6xrZK2upVfUvToUbif15HlC24FhNPX3BEUyL52s5HKcVBU5/1iw==
"@abp/jquery-form@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery-form/-/jquery-form-10.0.0.tgz#27182c80e17b4ffbc2551fa3e5d22f058c5b71ef"
integrity sha512-QVf+geob891AfdM2SGWbuUXo9/MhIquqmBgLJveKXRoNExqLyp2+jbd4YTRUW9RB7ZEzoKg+U+Om9ax/nnRV4A==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
jquery-form "^4.3.0"
"@abp/jquery-validation-unobtrusive@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation-unobtrusive/-/jquery-validation-unobtrusive-10.0.0-rc.3.tgz#20c8647e006954887eebe86e17ef39a336f47a30"
integrity sha512-6DVIIEVyqyeKMrZHNOTfW3/xuw7rkjqTMKXT6Z1wrDpt9Erseuz8CjbPpcS+RwpXn6va5ShrkJlwwyScFOKvkQ==
"@abp/jquery-validation-unobtrusive@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation-unobtrusive/-/jquery-validation-unobtrusive-10.0.0.tgz#89698d2ec25f21e697d5b23540885a2c74115db8"
integrity sha512-eqri3yDeyFutZcOJrP8aVf5vKoE47KP/mL8TXCRjyjVCZsHxOgjhSRY4n4rYo0JK2fePBOhwb5vpBhlezFKoNg==
dependencies:
"@abp/jquery-validation" "~10.0.0-rc.3"
"@abp/jquery-validation" "~10.0.0"
jquery-validation-unobtrusive "^4.0.0"
"@abp/jquery-validation@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation/-/jquery-validation-10.0.0-rc.3.tgz#2e562ad5ca7c5bef389a0b24293a3193fa9823ef"
integrity sha512-xLJVvCkUrNnVeQbdsKfBj7zh3cSaPJC3eWKm2NoVy9KimEhF4zeSJEkciFmS0cckSal+AO2xC8W8ot3FqpkCHQ==
"@abp/jquery-validation@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery-validation/-/jquery-validation-10.0.0.tgz#83850af15bd3d65c399519da9461ff30fd615197"
integrity sha512-2Sigm4L+8IwzvLYIoNWpOE8u/HvHLqWlOfqClL1x0p3JQBhgAVNns5sm3P6xgjWVJpCzrUOh8lxFMUGUiRSS0w==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
jquery-validation "^1.21.0"
"@abp/jquery@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jquery/-/jquery-10.0.0-rc.3.tgz#3400f1b8c6966e2d71fceb5349f05b88aeb2bb88"
integrity sha512-liz3FITKdESLGomITjUqcOZYvV0rs61vYMxSbaCDoCKIQj4Ne9mN+HJ/KOpD6GOhqVsjmYOxDuSoecjiFLjVxA==
"@abp/jquery@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jquery/-/jquery-10.0.0.tgz#530b968eed2e94d13381679aabddfa4cb1aad8d5"
integrity sha512-KksQlTs3VojDBxjBcLPkI55V7aG9TpDqzpylVq+5Sj8ZozFH9C75XQZpkLVwiU57rGYyQpfKuKAAPiZlJnWK0Q==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
jquery "~3.7.1"
"@abp/jstree@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/jstree/-/jstree-10.0.0-rc.3.tgz#2fa742149d42ac9d9758eb6a5c2ee309003caf39"
integrity sha512-QvMimaaMTokfEuhEd0OeJVAoTTYJyhb+7frPd52a1HraPF2d7aiht4bdHcOyeJxVYi2KiRmAgzIHHIX9AeIy8g==
"@abp/jstree@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/jstree/-/jstree-10.0.0.tgz#1a6588b6575e22f1643135cf220c0bd960204195"
integrity sha512-NxHxIDctz92MjdS8pVY/qANv1H09UpWz+BUDdqtYuGw7QMGJQn+ZXiQck/G7fz2O/z1hQquHl0/5svR4ACg/fw==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
jstree "^3.3.17"
"@abp/lodash@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/lodash/-/lodash-10.0.0-rc.3.tgz#738baf7394d466112dc5a2380f2c549053621505"
integrity sha512-5PYQks4sJPdiz9zfZD1bfrCkmQ+ZMfWg2xyjbHoQzJdqu9rb2SRzkQ5MAWvqQPVTdLY6Bnutwxuq6mjkfcthcQ==
"@abp/lodash@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/lodash/-/lodash-10.0.0.tgz#08c271911d398329dbcb815c109bf3a29a940f1c"
integrity sha512-I8cqRK/2ln0/dFT9e+XzmjprBO2GnN5JCP8pb9q3wgOYb+Wf+BYg/3RQQhGAv+NhwCsxAezRMQfF+DU3xb3hAw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
lodash "^4.17.21"
"@abp/luxon@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/luxon/-/luxon-10.0.0-rc.3.tgz#bfb0c5fbf4a321e4531ec5b34dcdee47b486afe8"
integrity sha512-PCifbFy7t1h4L+FKJAo5Xr7v5hTvlelwuCsOVGfG8HVWmbOTKiQJywtxvSnARbsJ6SghUEzbqMzeX6nyHZ4Zuw==
"@abp/luxon@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/luxon/-/luxon-10.0.0.tgz#e0743dca2b50561176aec44cf90870e80863d6b9"
integrity sha512-CUPHIW/7osW2wDtjB6OuURq16/jAIPV9ssGINUxgJZYpVKsaHCfORQLQ+wn8h653Crf5CEiDVZMpuLaLVFEpXw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
luxon "^3.7.2"
"@abp/malihu-custom-scrollbar-plugin@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/malihu-custom-scrollbar-plugin/-/malihu-custom-scrollbar-plugin-10.0.0-rc.3.tgz#03bf7a8b2e71ec463794260e7fe5e6bfeb526f8e"
integrity sha512-aHOZnr4iPS6QqV07cXyWpQVl6zAaQXuct1yTeIUqcAqxsSt63K6Y27nBR8cU/m6BHhjaxSLn1kynOeccmx7lDA==
"@abp/malihu-custom-scrollbar-plugin@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/malihu-custom-scrollbar-plugin/-/malihu-custom-scrollbar-plugin-10.0.0.tgz#ff69e4dd180c7d6945b5db883b57b1131c51fae6"
integrity sha512-yGHsYExELbF/sKXS6zQ9SqEsl8w3yr6daWOkgW/aoITks6DeOte2jdjP2Ly6UpHQbAzbeAjZg0oCrSbtcz/tZw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
malihu-custom-scrollbar-plugin "^3.1.5"
"@abp/markdown-it@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/markdown-it/-/markdown-it-10.0.0-rc.3.tgz#01f29a09fa8f87a928088ddab4ed73e5e06fa7f2"
integrity sha512-eVenb0mKVxZlvfDVoebt8fJrhvHzqM3y7Fc32FwQcd/0ExP09OT5/VlPbv6p88s59nvdznxtXCETQFjwZ9DkqQ==
"@abp/markdown-it@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/markdown-it/-/markdown-it-10.0.0.tgz#7df1b5f662f85cf56a5e5499d44e42c4ed4f0c7c"
integrity sha512-RVYgEQntj2DJrjVn026fPslrEO6oRjBK2saejrvfSqzGniPzBZWPQPc7lA9VU1cCPPEZJdYzpi6eWxC6DZSLMQ==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
markdown-it "^14.1.0"
"@abp/moment@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/moment/-/moment-10.0.0-rc.3.tgz#1d2c8081b9f7f2716b250d16b41021e74c093fb0"
integrity sha512-VKDVY3ml3bhPh2rUsUN1F7zH5Myi+jRYxQYC/OuOsa1P4x9+cKs1lsS68NYAq+JyMlwwuJcAx63nqkxArz+VEw==
"@abp/moment@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/moment/-/moment-10.0.0.tgz#8b84d1a15c43d0099125be2b5b071e11a7b402d4"
integrity sha512-AAu4BgciErLKYTIW6uT14q5WCl+oJeXz0J7a/kyZz2tHYbQz4FnYWMuFoDUFvkKKtGzyq7LuKTmGPxmJUXNpRg==
dependencies:
moment "^2.30.1"
"@abp/prismjs@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/prismjs/-/prismjs-10.0.0-rc.3.tgz#d7342b793fc7baf205726e8a088de88778fc24b1"
integrity sha512-cafgH3lrlT+jOuQKtBVeORbBkJKCG2DqnVF0blaD75ww32R5TJS+LH8gOufezdTfASG14ZlpzqNLl1Xu67Wh4Q==
"@abp/prismjs@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/prismjs/-/prismjs-10.0.0.tgz#6463b5d5fcbe2f9da687e04c49d38e8eb6e778b8"
integrity sha512-N2p18MAX9wYx62Ck5+V/RWLGyX+1BemiVuNX/cIOJMG0iDVJ57C6fEX1HzLc9Mchi+MXPHUR7lKwg92ui2OzfQ==
dependencies:
"@abp/clipboard" "~10.0.0-rc.3"
"@abp/core" "~10.0.0-rc.3"
"@abp/clipboard" "~10.0.0"
"@abp/core" "~10.0.0"
prismjs "^1.30.0"
"@abp/select2@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/select2/-/select2-10.0.0-rc.3.tgz#216403f1207a2556b0317fb973ed874c34c7fb73"
integrity sha512-6t/ZZl9xo0G86dX8zmEv82/64dOxCTgcQvjRGTb5Xwzh05nKHKpFFhJm6juVvpJcYqUj6Weks66SVjr6Wi2kQQ==
"@abp/select2@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/select2/-/select2-10.0.0.tgz#0a3a425c30e4139b8677c871bb7bfd2ab010b9f6"
integrity sha512-ZAFuLA8CIJr/UspKN/coRxnB+3xArc06a0YQ6HHVL5RWVRlRkcuZL/2aBFQ5HdrWZjSmImG1yXKxGyVLNmavpQ==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
select2 "^4.0.13"
"@abp/slugify@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/slugify/-/slugify-10.0.0-rc.3.tgz#423502a7dacd960ee65f4ad3e7079ef56bb50b07"
integrity sha512-PAPutBCzD7TMijGXuiREpNBa4JLfW7Y7f2GDxJhKMqJ4WZ5yjMl+QWpAmrndeLyKi2w+HxnHocKTqnW/F8X5nA==
"@abp/slugify@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/slugify/-/slugify-10.0.0.tgz#2b5cd3a4e2062920f3e362ba1b5761d719326ef9"
integrity sha512-3y/HhsRsDIdjL25NSMM4UqF8C1+wZQQHaXgguCysXeajMcLG6zzkr1F+rHqW55gylDRtlc7+dvAZTxJ9C2tF1g==
dependencies:
slugify "^1.6.6"
"@abp/star-rating-svg@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/star-rating-svg/-/star-rating-svg-10.0.0-rc.3.tgz#672b4138c86c8502b0100c35b7dc471762e1454c"
integrity sha512-/DKDPhhfZBK+madBkYPWD2WxN2gPpxwFVXBaDR/esx9dZ8NuXZPkQ05RasEpwizz5RdK+yl9xF7JoH6ieYcqsw==
"@abp/star-rating-svg@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/star-rating-svg/-/star-rating-svg-10.0.0.tgz#eee8be42be93d473bb7d93665178ca1d886ba4bd"
integrity sha512-UD0I/vHFn/nYVB5QpEjgGikKpN3e4Go9wuIIKgD3n1Ftj3wKHMX1HBTZw93OePzcatNVEcDqGaHGWehbqqNvaA==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
star-rating-svg "^3.5.0"
"@abp/sweetalert2@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/sweetalert2/-/sweetalert2-10.0.0-rc.3.tgz#401dc08eb4607d3a575a5288296f6c703b18df8a"
integrity sha512-2nB9I+GxK7UeIjvdUJtAH9GqIL/HloQ+7WC/ZWUNLCBqI5Owx30La2wxj5e9MlDNcLvYs3A2EJP0Llo4Gdefsg==
"@abp/sweetalert2@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/sweetalert2/-/sweetalert2-10.0.0.tgz#ef9830d0d294aa685fe6ad8049056650a7d46381"
integrity sha512-wAAIacOdWyBiJMVuFVbiNpR3SnRsyhNHmNr4gmhge5KBDlO+JQlueaar0MrKkdUNaXuF9memdgERzi/cIJm1mw==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
sweetalert2 "^11.23.0"
"@abp/timeago@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/timeago/-/timeago-10.0.0-rc.3.tgz#6fc8f16107171ae6f6afbbd3dc7e844651ffcf77"
integrity sha512-JYhSRbz06IObwA32GutyV+yo4p5PdAmGtlaApDLCpSFccHsel/A3jrN+ykovKy4chWYcbOhxhgjWw6ZaIZMvJg==
"@abp/timeago@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/timeago/-/timeago-10.0.0.tgz#af348b8ca21c466847c3dd47d4947f615ff82707"
integrity sha512-LbGIKpsDJyoDpN4ams9yTebA7fOPerdN4bQUWJB/7LV5wI0jtzkvbe+bEI00NLeMIDJ/nU+k+ecjhQjzkrY7qQ==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
timeago "^1.6.7"
"@abp/tui-editor@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/tui-editor/-/tui-editor-10.0.0-rc.3.tgz#0a196dcfd7eb30223b808e1c192942e6135e1715"
integrity sha512-IaaI1/KNkwYVmEadIoYvuXbdkpwk7CwYA+3Sp64Ow2cbQB6IatW9h4BPHLmQqRmaP1xTLwTLVWenThEpo2CIAQ==
"@abp/tui-editor@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/tui-editor/-/tui-editor-10.0.0.tgz#6ccfe6a2337f4bc08cbb9342a43fb95fc49980f4"
integrity sha512-nDFmFbSzZ7IMM4LVIDGtvVWAbqYo+1OLOqeFL0iOXg21dUCBEs0WE8GQsaJsdOYa9AGyMLkzcHm37yqPqCN6mg==
dependencies:
"@abp/jquery" "~10.0.0-rc.3"
"@abp/prismjs" "~10.0.0-rc.3"
"@abp/jquery" "~10.0.0"
"@abp/prismjs" "~10.0.0"
"@abp/uppy@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/uppy/-/uppy-10.0.0-rc.3.tgz#ef15186cfb9f06a4eba6ed50b01815d1f8de7eae"
integrity sha512-MAlRdHXn9rWQeCnOKAMKk7DOqPnUj+ffnSByaFsnzmxoawl5ZMmUfhFq5eOT+QbYW02GWVWx1K9cG7wNq+6k+Q==
"@abp/uppy@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/uppy/-/uppy-10.0.0.tgz#0694b8a39ed32c161c0731b115b64e037dc39c1b"
integrity sha512-INKk6bsi01DYnUBCJ2hc+a4Th/QnBTtB7hJbWe+tCLkGXPZMD+2EB3ZW6kjD5ELgOwaIq1hQrEuj2N6MEQS31w==
dependencies:
"@abp/core" "~10.0.0-rc.3"
"@abp/core" "~10.0.0"
uppy "^5.1.2"
"@abp/utils@~10.0.0-rc.3":
version "10.0.0-rc.3"
resolved "https://registry.yarnpkg.com/@abp/utils/-/utils-10.0.0-rc.3.tgz#d6a07146ba627bcfa0cadd5c7c56601609b24d57"
integrity sha512-bA/WPuosvedfQr+5cJBwKXrhd6b8fDG7LWp4PuZFMdti8nSXgOheLeZ8PcRvut94ENIXS7jzSsqapLHRj5E6zQ==
"@abp/utils@~10.0.0":
version "10.0.0"
resolved "https://registry.yarnpkg.com/@abp/utils/-/utils-10.0.0.tgz#372ea8b37809ec1951d3fd74ae02adff9215245b"
integrity sha512-VO725+ALRGmjFz9Yal+joivNZpBbPS9AWOx6N5E8meEYQnHo2oEDeoOziKkwLZ4EYIizno37zwsXiQLEO4iFRg==
dependencies:
just-compare "^2.3.0"

2
modules/cms-kit/src/Volo.CmsKit.Domain.Shared/Volo/CmsKit/Localization/Resources/en.json

@ -3,6 +3,7 @@
"texts": {
"AddSubMenuItem": "Add Sub Menu Item",
"AreYouSure": "Are You Sure?",
"AverageRating": "Average Rating",
"BlogDeletionConfirmationMessage": "The blog '{0}' will be deleted. Are you sure?",
"BlogFeatureNotAvailable": "This feature is not available now. Enable with 'GlobalFeatureManager' to use it.",
"BlogId": "Blog",
@ -168,6 +169,7 @@
"Text": "Text",
"ThankYou": "Thank you",
"Title": "Title",
"TotalRatings": "Total Ratings",
"Undo": "Undo",
"Update": "Update",
"UpdatePreferenceSuccessMessage": "Your preferences have been saved.",

17
modules/cms-kit/src/Volo.CmsKit.Domain/Volo/CmsKit/Menus/PageChangedHandler.cs

@ -4,6 +4,10 @@ using System.Threading.Tasks;
using Volo.Abp.DependencyInjection;
using Volo.Abp.Domain.Entities.Events;
using Volo.Abp.EventBus;
using Volo.Abp.Features;
using Volo.Abp.GlobalFeatures;
using Volo.CmsKit.Features;
using Volo.CmsKit.GlobalFeatures;
using Volo.CmsKit.Pages;
namespace Volo.CmsKit.Menus;
@ -12,19 +16,32 @@ public class PageChangedHandler :
ILocalEventHandler<EntityUpdatedEventData<Page>>,
ITransientDependency
{
protected IFeatureChecker FeatureChecker { get; set; }
protected IMenuItemRepository MenuRepository { get; }
protected MenuItemManager MenuManager { get; }
public PageChangedHandler(
IFeatureChecker featureChecker,
IMenuItemRepository menuRepository,
MenuItemManager menuManager)
{
FeatureChecker = featureChecker;
MenuRepository = menuRepository;
MenuManager = menuManager;
}
public async Task HandleEventAsync(EntityUpdatedEventData<Page> eventData)
{
if(!GlobalFeatureManager.Instance.IsEnabled<MenuFeature>())
{
return;
}
if(!await FeatureChecker.IsEnabledAsync(CmsKitFeatures.MenuEnable))
{
return;
}
// TODO: Write a repository query.
var allMenuItems = await MenuRepository.GetListAsync();

30
modules/cms-kit/src/Volo.CmsKit.Public.Web/Pages/CmsKit/Shared/Components/Rating/Default.cshtml

@ -5,32 +5,37 @@
@model Volo.CmsKit.Public.Web.Pages.CmsKit.Shared.Components.Rating.RatingViewModel
@inject IHtmlLocalizer<CmsKitResource> L
@{
var modalId = "ratingDetail_" + Model.EntityType + "_" + Model.EntityId;
modalId = modalId.Replace(".", "-").Replace(":", "-").Replace("/", "-").Replace(" ", "-");
var modalLabelId = modalId + "_label";
}
<div class="row row">
<div class="col">
<div class="cms-rating-area" data-entity-type="@Model.EntityType" data-entity-id="@Model.EntityId" id="cms-rating_{@Model.EntityType}_{@Model.EntityId}">
@if (CurrentUser.IsAuthenticated)
{
@if (!Model.IsReadOnly && Model.CurrentRating != null)
@if (Model.Ratings != null)
{
<a href="#" class="rating-undo-link text-decoration-none">
<small class="text-muted"><i class="fa fa-undo"></i> @L["Undo"]</small>
</a>
}
if (Model.Ratings != null)
{
<a href="#" class="text-muted ms-1 text-decoration-none" data-bs-toggle="modal" data-bs-target="#ratingDetail">
<a href="#" class="text-muted ms-1 text-decoration-none" data-bs-toggle="modal" data-bs-target="#@modalId">
<i class="far fa-question-circle"></i>
</a>
<div class="modal fade" id="ratingDetail" tabindex="-1" role="dialog" aria-labelledby="ratingDetail" aria-hidden="true">
<div class="modal fade" id="@modalId" tabindex="-1" role="dialog" aria-labelledby="@modalLabelId" aria-hidden="true">
<div class="modal-dialog modal-dialog-centered" role="document">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalLabel">Rating Detail</h5>
<h5 class="modal-title" id="@modalLabelId">Rating Detail</h5>
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
</div>
<div class="modal-body">
<div class="text-center mb-3">
<h4>@L["AverageRating"]: @Model.AverageRating.ToString("F1")</h4>
<small class="text-muted">(@Model.TotalRating @L["TotalRatings"])</small>
</div>
<hr />
<div class="row text-center">
@foreach (var rating in Model.Ratings)
{
@ -49,13 +54,14 @@
</div>
}
<small class="live-rating text-center d-inline-block" style="width: 24px">@(Model.CurrentRating != null ? Model.CurrentRating + " " : 0 + "")</small>
<small class="live-rating text-center d-inline-block" style="width: 32px">@Model.AverageRating.ToString("F1")</small>
<span class="my-rating text-dark p-1" data-rating="@(Model.CurrentRating ?? 0)" data-authenticated="@(Model.CurrentRating != null)" data-readonly="@Model.IsReadOnly">
<span class="my-rating text-dark p-1" data-rating="@(Model.CurrentRating ?? 0)" data-readonly="@Model.IsReadOnly">
</span>
}
else
{
<small class="live-rating text-center d-inline-block" style="width: 32px">@Model.AverageRating.ToString("F1")</small>
<span class="my-rating text-dark p-1" data-authenticated="True" data-bs-toggle="popover" data-bs-placement="right" data-html="true" data-content="<div class='text-center'><div class='d-grid gap-2'><a href='@Model.LoginUrl' class='btn btn-primary'>@L["LoginToRate"]</a></div></div>"></span>
<span class="rating-login"></span>
}

Some files were not shown because too many files changed in this diff

Loading…
Cancel
Save