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
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
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:
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.