npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

ngx-feature-control

v0.0.6

Published

**ngx-feature-control** — a module for Angular that simplifies managing feature toggles. It allows you to enable/disable features and manage dependencies between them.

Readme

ngx-feature-control

ngx-feature-control — a module for Angular that simplifies managing feature toggles. It allows you to enable/disable features and manage dependencies between them.

Features

  • Simple management of feature states (enabled/disabled).
  • Support for dependencies between features.
  • Easy integration with Angular components and routes.
  • Provides a flexible directive to conditionally render components based on feature states.

Installation

To install ngx-feature-control, run:

npm install ngx-feature-control --save

Setup

Add FeatureToggleModule to your app's module:

import { NgModule, APP_INITIALIZER } from '@angular/core';
import { FeatureToggleModule, FeatureToggleService } from 'ngx-feature-control';

export function initializeFeatures(featureToggleService: FeatureToggleService) {
  return () => {
    const features = [
      { name: 'featureA', isEnabled: true },
      { name: 'featureB', isEnabled: false },
      { name: 'featureC', isEnabled: true, dependencies: ['featureA'] }
    ];
    featureToggleService.init(features);  // Initialize features during app startup
  };
}

@NgModule({
  imports: [
    FeatureToggleModule,
    // other modules
  ],
  providers: [
    {
      provide: APP_INITIALIZER,
      useFactory: initializeFeatures,
      deps: [FeatureToggleService],
      multi: true,
    },
  ],
  bootstrap: [AppComponent]
})
export class AppModule {}

Usage

Using in Components

You can use the *appFeatureIf directive to conditionally render elements based on feature states:

import { Component } from '@angular/core';

@Component({
  selector: 'app-example',
  template: `
    <div *appFeatureIf="['featureA', '!featureB']">
      This section is visible if 'featureA' is enabled and 'featureB' is disabled.
    </div>
  `
})
export class ExampleComponent {
  public featureToggleData = {
    featureA: true,
    featureB: false,
  };
}

Using Feature Toggles in Lazy Loaded Routes

You can use feature toggles to conditionally load components based on feature states in lazy-loaded routes:

import { Routes } from '@angular/router';
import { FeatureToggleComponentLoader } from 'ngx-feature-control';

export const routes: Routes = [
    {
        path: 'business',
        component: FeatureToggleComponentLoader,
        data: {
            features: [
                {
                    featureFlag: 'business',
                    component: () => import('./modules/business/business.component').then(m => m.BusinessComponent),
                },
                {
                    featureFlag: 'contacts',
                    component: () => import('./modules/contacts/contacts.component').then(m => m.ContactsComponent),
                }
            ],
            default: () => import('./modules/business/business.component').then(m => m.BusinessComponent),
        }
    },
];

In this example, the FeatureToggleComponentLoader is used to dynamically load the appropriate component based on the feature flag provided in the data. If a feature flag is enabled, the corresponding component is loaded lazily. If no feature flag matches, a default component is loaded.

Using Feature Toggles in Lazy Loaded Modules

You can also use feature toggles to conditionally load entire modules based on feature states in lazy-loaded routes:

import { Routes } from '@angular/router';
import { FeatureToggleModuleLoader } from 'ngx-feature-control';

export const routes: Routes = [
    {
        path: 'business',
        component: FeatureToggleModuleLoader,
        data: {
            features: [
                {
                    featureFlag: 'users',
                    module: () => import('./modules/users/user.module').then(m => m.UserModule),
                },
                {
                    featureFlag: 'contacts',
                    module: () => import('./modules/contacts/contact.module').then(m => m.ContactsModule),
                },
            ],
        }
    },
];

In this example, the FeatureToggleModuleLoader is used to load entire modules conditionally based on the feature flag. If the feature flag is enabled, the corresponding module is loaded lazily. This allows you to manage and conditionally load larger parts of your application dynamically.

Development

Run locally

You can run the project locally by using:

npm start

Running tests

To run the tests, use:

npm test

Contributions

Any contribution is welcome. Please check out CONTRIBUTING.md for instructions.