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 🙏

© 2024 – Pkg Stats / Ryan Hefner

ngx-sticky-navbar

v1.0.2

Published

ngx-sticky-navbar is an Angular 6+ component that wrapps your navigation and it has some cool features.

Downloads

49

Readme

ngx-sticky-navbar

ngx-sticky-navbar is an Angular 6+ component that wrapps your navigation and it has some cool features.

Navbar's Sensitivity

You can set sensitivity of scroll speed when to show/hide navbar. Example of sensitivity configuration:

settings: Settings = {
  sensitivity: {
    top: DefinedSensitivity.veryLow,
    bottom: DefinedSensitivity.veryHigh
  }
};

To setup sensitivitity You can use defined sensitivities (more details) or just pass a number. Greater number lowers sensitivity (0 = high sensitivity, 100 = low sensitivity).

Navbar's Offset Top

Everytime user scroll back to the top, the navbar becomes visible. You can configure the top offset when it should appear. There two ways:

  1. Setup offset top manually
settings: Settings = {
  scroll: {
    offset: {
      top: 300 // default is 300
    }
  }
};
  1. Setup offset top automatically. It will set top property automatically and dynamically to height of navbar element.
settings: Settings = {
  scroll: {
    offset: {
      autoTop: true // default is false
    }
  }
};
Navbar's Spacer

As ngx-sticky-navbar uses CSS position:fixed, so element wrapped by this component doesn't affect DOM height. You can compensate it by creating Spacer with height manually or automatically set at selected DOM element. To create Spacer You need three properties: height or autoHeight, Type, Element (more details).

  1. Manual height of Spacer:
ngAfterViewInit() {
    this.settings = {
      ...this.settings,
        height: 300,
        type: SpacerTypes.PADDING,
        element: this.spacerElement,
      }
    };
    this.navbarService.mergeSettingObject(this.settings);
  }
  1. Automatic height of Spacer:
ngAfterViewInit() {
    this.settings = {
      ...this.settings,
      spacer: {
        autoHeight: true,
        type: SpacerTypes.PADDING,
        element: this.spacerElement,
      }
    };
    this.navbarService.mergeSettingObject(this.settings);
  }
Navbar's Configuration
  1. Pass settings object via property binding (required usage) link
  2. Dynamically updating global variable settings object link

Note

Component requires Angular and Rxjs version >= 6.0.0.

Demo

Check the link

Usage

Install ngx-sticky-navbar
  • npm: $ npm install ngx-sticky-navbar
  • yarn: $ yarn add ngx-sticky-navbar
import NgxStickyNavbarModule
import { NgxStickyNavbarModule } from 'ngx-sticky-navbar';

@NgModule({
  declarations: [...],
  imports: [
    ...
    NgxStickyNavbarModule
  ],
  providers: []
})
Use ngx-sticky-navbar
import { 
  Settings, 
  DefinedSensitivity
} from 'ngx-sticky-navbar';

@Component(...)
export class SomeComponent {
  ...
  settings: Settings = {
    scroll: {
      element: '.scrollable'
    },
    sensitivity: {
      top: DefinedSensitivity.veryLow, // or 50
      bottom: DefinedSensitivity.veryHigh // or 10
    }
  };
Use Spacer (example extends example above)
import { 
  ...
  SpacerTypes,
  NgxStickyNavbarService 
} from 'ngx-sticky-navbar';

@Component(...)
export class SomeComponent {
  @ViewChild('spacerElement') spacerElement: ElementRef;
  ...
  constructor(private navbarService: NgxStickyNavbarService) {...}

  ngAfterViewInit() {
    this.settings = {
      ...this.settings,
      // Auto Height
      spacer: {
        autoHeight: true,
        type: SpacerTypes.PADDING,
        element: this.spacerElement,
      }
      // Manual Height
      spacer: {
        height: 300,
        type: SpacerTypes.PADDING,
        element: this.spacerElement,
      }
    };
    this.navbarService.mergeSettingObject(this.settings);
  }
}
HTML
<ngx-sticky-navbar [settings]="settings">
  <div class="nav"> ... </div>
</ngx-sticky-navbar>

<div class="scrollable">
  <div class="scrollable__big-element">
  </div>
</div>
Spacer HTML
...
<div class="scrollable">
  <div class="scrollable__big-element"
       #spacerElement> <!-- Place where You wanna add Spacer -->
  </div>
</div>

Enums / Models

Settings

interface Settings {
    spacer: {
        element: ElementRef; // default undefined
        autoHeight: boolean; // default false
        height: number; // default 0
        type: SpacerTypes;  // default undefined
    };
    sensitivity: {
        top: number | string; // 50 = DefinedSensitivity.veryLow
        bottom: number | string; // 10 = DefinedSensitivity.veryHigh
    };
    scroll: {
        element: string; // default <body></body>
        offset: {
            top: number; // default 300
            autoTop: boolean; // default false
        };
    };
}

Defined Sensitivity

enum DefinedSensitivity {
    Locked = 10000,
    veryLow = 50,
    Low = 40,
    Medium = 30,
    High = 20,
    veryHigh = 10
}

Navbar State

enum NavbarState {
    SHOW = 'show',
    HIDE = 'hide'
}

Spacer Types

enum SpacerTypes {
    MARGIN = 'margin-top',
    PADDING = 'padding-top'
}

Service

public initialSettings: Settings // default initial settings;
public settings: Settings // global settings used by all elements of component

//  NgxStickyNavbarService.settings = global settings
//  Method sets global settings but without triggering Subject<Settings>.
//  Used only to change global settings variable.
setGlobalSettings(settings: Settings): void

//  Method uses setGlobalSettings() and triggers Subject<Settings>
//  to update global settings state in every
//  component's element (service/directibe/component).
mergeSettingObject(settings: Settings): void

Dynamically Update Settings:

import { NgxStickyNavbarService } from 'ngx-sticky-navbar';

@Component(...)
export class SomeComponent {

  settings: Settings = { ... }

  constructor(private navbarService: NgxStickyNavbarService) { }

  someMethod(settings: Settings) {
    this.settings = {
      ...this.settings,
      sensitivity: { 
        top: settings.sensitivity.top,
        bottom: settings.sensitivity.bottom
        // or use ...settings.sensitivity
      }
    };
    this.navbarService.mergeSettingObject(this.settings);
  }
}

or reasign initialSettings

Contributing

  1. Fork repo.
  2. npm install / yarn.
  3. Make your changes.
  4. Add your tests.
  5. npm run test / yarn start test.
  6. npm run build / yarn start build.
  7. After all tests are passing.
  8. Commit, push, PR.

License

Released under the terms of MIT License.