Activities of "wazbek"

Hi

I have checked the docs, samples and also the support site but have not found anything documented about the Abp signalR integration on the Angular side.

What do I need to do to get this to work? My code is below.

Thanks,

Warick

  • ABP Framework version: v3.0.4
  • UI type: Angular
  • Tiered (MVC) or Identity Server Seperated (Angular): Identity Server Separated
  • Exception message and stack trace: Access to XMLHttpRequest at 'https://localhost:44336/signalr-hubs/idm/negotiate?negotiateVersion=1' from origin 'http://localhost:4200' has been blocked by CORS policy: No 'Access-Control-Allow- Origin' header is present on the requested resource.
  • Steps to reproduce the issue:
import { Injectable } from '@angular/core';
import * as signalR from '@microsoft/signalr';
import { environment } from '@nexweb/core';
import { IdmManagement } from '../models/idm.models';

@Injectable({
  providedIn: 'root'
})
export class IdmHubService {
  private hubConnection: signalR.HubConnection;
  private idmHubUrl = '/signalr-hubs/idm';
  public hubConnectionEstablished = false;

  constructor() {
    this.buildConnection();
    this.startConnection();
  }

  private buildConnection() {
    this.hubConnection = new signalR.HubConnectionBuilder()
      .withUrl(environment.apis.default.url + this.idmHubUrl)
      .build();
  }

  private startConnection() {
    this.hubConnection
      .start()
      .then(() => {
        this.hubConnectionEstablished = true;
      })
      .catch(err => {
        console.error('Error while starting connection: ' + err);
      });
  }

Hi Mehmet

Thanks for taking a look. Your recommendation pointed me in the right direction and I managed to find what was causing the issue.

I started by importing everything into my app module again like this:

imports: [
    BrowserModule,
    BrowserAnimationsModule,
    AppRoutingModule,
    ThemeSharedModule.forRoot({
      httpErrorConfig: {
        errorScreen: {
          component: HttpErrorComponent,
          forWhichErrors: [401, 403, 404, 500],
          hideCloseIcon: true,
        },
      },
    }),
    CoreModule.forRoot({
      environment,
    }),
    AccountConfigModule.forRoot({ redirectUrl: '/' }),
    IdentityConfigModule,
    LanguageManagementConfigModule,
    SaasConfigModule,
    AuditLoggingConfigModule,
    IdentityServerConfigModule,
    TextTemplateManagementConfigModule,
    SettingManagementConfigModule,
    NgxsModule.forRoot([]),
    SharedModule,

    ...(environment.production ? [] : LOGGERS),

Which got my application working witout any errors. I then started moving them one by one to my shell module file that i sent you and I then realised the NgxsModule.forRoot([]) import. I was importing the NgxsModule like this in my core module:

export const ngxsConfig: NgxsModuleOptions = {
  //developmentMode: !environment.production,
  selectorOptions: {
    suppressErrors: false,
    injectContainerState: false
  }
};

@NgModule({
  imports: [
    CommonModule,
    NgxsModule.forRoot([], ngxsConfig),
    NgxsFormPluginModule.forRoot(),
    NgxsReduxDevtoolsPluginModule.forRoot({ disabled: environment.production }),
    ...(environment.production ? [] : LOGGERS)
  ]
})
export class CoreModule {

The NgxsModuleOptions that I had set will only be used in NGXS v4. I removed the ngxsConfig from my NgxsModule import and everything works as expected now. https://www.ngxs.io/advanced/options. This was working before ABP version 2.8.

Sorry for waisting your time.

Thanks again.

Hi Mehmet

Yes we did, we used ABP Suite 2.8 to do the update.

We are using an nx workspace(https://nx.dev/angular/getting-started/why-nx) so our app.module.ts file does not have all the modules imported like a normal angular app. I have follow the order of module imports in our nx workspace by looking at a newly created angular application using abp version 2.8.

I will email the files to info@abp.io.

Hi

  • ABP Framework version: v2.8.0

  • UI type: Angular

  • Tiered (MVC) or Identity Server Seperated (Angular):
    Identity Server Not Separated (Angular)

  • Exception message and stack trace:

    core.js:6210 ERROR TypeError: Cannot read property 'objectExtensions' of undefined
      at ɵ1 (volo-abp.commercial.ng.ui.js:3358)
      at wrappedSelectorFn (ngxs-store.js:2865)
      at memoized (ngxs-store-internals.js:59)
      at selectFromRoot (ngxs-store.js:2901)
      at ngxs-store.js:2896
      at Array.map (<anonymous>)
      at MapSubscriber.selectFromRoot [as project] (ngxs-store.js:2892)
      at MapSubscriber._next (map.js:29)
      at MapSubscriber.next (Subscriber.js:49)
      at StateStream._subscribe (BehaviorSubject.js:14)
    

    also warnings in the browser

    Could not find localization source: TextTemplateManagement   abp-ng.core.js:1014
    
    The localization source separator (::) not found.  abp-ng.core.js:1014
    

    All the abp screens are displaying like this too:

  • Steps to reproduce the issue: We are getting some errors after updating to version 2.8. We updated our aspnetcore to 2.8 using ABP suite 2.8. We also update our ABP/Volo packages in our angular application to 2.8.0. We then ran the application and we receive the above errors on application startup.

Hi

We are getting some errors after updating to version 2.8. We are using the Angular frontend.

This error happens when the app loads up:

core.js:6210 ERROR TypeError: Cannot read property 'objectExtensions' of undefined
    at ɵ1 (volo-abp.commercial.ng.ui.js:3358)
    at wrappedSelectorFn (ngxs-store.js:2865)
    at memoized (ngxs-store-internals.js:59)
    at selectFromRoot (ngxs-store.js:2901)
    at ngxs-store.js:2896
    at Array.map (<anonymous>)
    at MapSubscriber.selectFromRoot [as project] (ngxs-store.js:2892)
    at MapSubscriber._next (map.js:29)
    at MapSubscriber.next (Subscriber.js:49)
    at StateStream._subscribe (BehaviorSubject.js:14)

There are also these warnings in the browser console:

Could not find localization source: TextTemplateManagement   abp-ng.core.js:1014

The localization source separator (::) not found.  abp-ng.core.js:1014

All the abp screens are displaying like this too:

Thank you.

Hi Mehmet

Thanks. I am already protecting my routes with the AuthGuard.

Any idea when this fix will be released?

HI

I try to browse to a page on our website, say /setting-management but I am not logged in yet. I get redirected to the /account/login screen as expected. I then login but I am not redirected back to the /setting-management page which I first navigated to.

I had a look at the AuthGuard and found this line of code router.navigate(['/account/login'], { state: { redirectUrl: state.url } });

How can I get this to work as expected?

Thank you Mehmet.

I completely forgot about the !important.

I am able to override what I need to now.

Hi alper

Completely forgot about the !important.

I am able to override now.

Thank you.

Showing 21 to 30 of 52 entries
Made with ❤️ on ABP v9.2.0-preview. Updated on January 14, 2025, 14:54