Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
@luigi-project/client-support-angular
Advanced tools
This library provides several features to run your Angular application inside the Luigi micro frontend framework. If you want to know more about Luigi, please have a look at the [Luigi homepage](https://luigi-project.io/).
This library provides several features to run your Angular application inside the Luigi micro frontend framework.
If you want to know more about Luigi, please have a look at the Luigi homepage.
package.json
:npm install @luigi-project/client-support-angular -s
LuigiAngularSupportModule
:imports: [
........
,LuigiAngularSupportModule
],
These are the main features provided by the library:
You can inject this service inside your Angular items in order to:
LuigiContextService is an abstract class. Its implementation is in the LuigiContextServiceImpl class.
If you need to change or extend the implementation, you can easily create a new class extending LuigiContextServiceImpl:
In this class, we added the possibility to "reuse" a component and not initialize it every time you load it (it could be useful to keep component state.)
export class YourContextService extends LuigiContextServiceImpl {
....
}
Inside your module, redefine the provider:
providers: [
{
provide: LuigiContextService,
useClass: YourContextService
}
]
This service cannot be used directly, but it will provide useful features on how to synchronize your angular application with Luigi navigation.
It can happen that in your microfrontend, user can navigate through different components/pages.
With this feature we provide an easy way of synchronizing angular route with Luigi navigation; in angular route configuration, you can now add in data these attributes:
{path: 'luigi-client-support-preload',component: Sample1Component,data: { fromVirtualTreeRoot: true }}
{path: 'luigi-client-support-preload',component: Sample2Component,data: { luigiRoute: '/home/sample2' }}
with data: { fromVirtualTreeRoot: true }
, once we load Sample1Component, we will call Luigi Client:
luigiClient.linkManager().fromVirtualTreeRoot().withoutSync().navigate({route url});
with data: { luigiRoute: '/home/sample2' }
, uses luigiClient API in this way:
luigiClient.linkManager().withoutSync().navigate(data.luigiRoute);
More information about linkManager can be found here.
To use LuigiAutoRoutingService, this library defines a new RouteReuseStrategy named LuigiRouteStrategy.
If you need to define your own RouteReuseStrategy, you can extend LuigiRouteStrategy by overriding it in this way:
export class YourRouteStrategy extends LuigiRouteStrategy {
retrieve(route: ActivatedRouteSnapshot): DetachedRouteHandle {
super.retrieve(route);
// Your code
}
}
and define the provider:
{
provide: RouteReuseStrategy,
useClass: YourRouteStrategy
}
We also provide an example of how to extend LuigiRouteStrategy in class LuigiReuseRouteStrategy.
In this class, we added the possibility to "reuse" a component and not initialize it every time you load it (it could be useful to keep component state.)
LuigiReuseRouteStrategy can be configured in the following way:
{path: 'luigi-client-support-preload',component: Sample1Component,data: { reuse: true }}
If you want to use LuigiReuseRouteStrategy (it is not enabled by default), you need to configure in your application:
{
provide: RouteReuseStrategy,
useClass: LuigiReuseRouteStrategy
}
FAQs
This library provides several features which make it easier to run your Angular application inside the Luigi micro frontend framework. If you want to know more about Luigi, please have a look at the [Luigi homepage](https://luigi-project.io/).
The npm package @luigi-project/client-support-angular receives a total of 1,995 weekly downloads. As such, @luigi-project/client-support-angular popularity was classified as popular.
We found that @luigi-project/client-support-angular demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.