0.2.1 • Published 2 years ago

ngx-hide-on-scroll v0.2.1

Weekly downloads
-
License
MIT
Repository
github
Last release
2 years ago

NgxHideOnScroll

NPM NPM downloads

Hide an element on scroll down or up in Angular.

This library allows you to hide an html element (e.g. navbar) on scroll down and show it again on scroll up.

View the demo

Installation

npm install ngx-hide-on-scroll --save

Usage

Step 01: Import the NgxHideOnScrollModule to your module.

import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';

import { AppComponent } from './app.component';

// Import NgxHideOnScrollModule
import { NgxHideOnScrollModule } from 'ngx-hide-on-scroll';

@NgModule({
  declarations: [AppComponent],
  imports: [
    BrowserModule,
    NgxHideOnScrollModule // Import NgxHideOnScrollModule
  ],
  providers: [],
  bootstrap: [AppComponent]
})
export class AppModule { }

Step 02: Add the ngxHideOnScroll directive to your element.

app.component.html

<!-- Example 01 -->
<nav ngxHideOnScroll [classNameWhenHidden]="'nav--hidden'">
  <h2>Navbar</h2>
</nav>

<!-- Example 02 -->
<div class="fixed-footer" ngxHideOnScroll [propertyUsedToHide]="'transform'" [valueWhenHidden]="'translateY(100%)'"
  [valueWhenShown]="'translateY(0%)'">
  <h2>Fixed footer, with transition on hide/show.</h2>
</div>

app.component.scss

// Example 01
nav {
  position: fixed;
  top: 0;
  width: 100%;
  color: white;
  background-color: #2980b9;
  padding: 0 2rem;
}

nav.nav--hidden {
  transform: translateY(-100%);
}
// End - Example 01

// Example 02
.fixed-footer {
  position: fixed;
  bottom: 0;
  width: 100%;
  color: white;
  background-color: #2c3e50;
  padding: 0 2rem;

  transition: transform 0.3s ease-in-out; // Transition on hide/show.
}

Documentation

Inputs

@Input()TypeRequiredDefaultDescription
hideOnScroll'Down' | 'Up'optional'Down''Down': The element will be hidden on scroll down and it will be shown again on scroll up. 'Up': The element will be hidden on scroll up and it will be shown again on scroll down.
classNameWhenHiddenstringoptionalnoneCSS class name added to the element to hide it. When this property is set, propertyUsedToHide, valueWhenHidden, and valueWhenShown have not effect.
propertyUsedToHide'transform' | 'top' | 'bottom' | 'height'optional'transform'The CSS property used to hide/show the element.
valueWhenHiddenstringoptional'translateY(-100%)'The value of the propertyUsedToHide when the element is hidden.
valueWhenShownstringoptional'translateY(0)'The value of the propertyUsedToHide when the element is shown.
scrollingElementSelectorstringoptionalnoneThe selector of the element you want to listen the scroll event, in case it is not the browser default scrolling element (document.scrollingElement or document.documentElement). For example '.mat-sidenav-content' if you are using Angular Material Sidenav.

Outputs

@Output()TypeDescription
eventElementHiddenEventEmitter<void>Emitted when the element is hidden.
eventElementShownEventEmitter<void>Emitted when the element is shown.

License

MIT

0.2.1

2 years ago

0.2.0

3 years ago

0.1.0

3 years ago