ngx-wrapper-tiny-slider

ngx-wrapper-tiny-slider JS library homepage ngx-wrapper-tiny-slider JS library on GitHub ngx-wrapper-tiny-slider JS library on npm Download ngx-wrapper-tiny-slider JS library

A simple Angular 19 wrapper for Tiny Slider

Version 19.0.0 License MIT
ngx-wrapper-tiny-slider JS library homepage
ngx-wrapper-tiny-slider JS library on GitHub
ngx-wrapper-tiny-slider JS library on npm
Download ngx-wrapper-tiny-slider JS library
Keywords
AngularAngular 19Angular 18Angular 17slidersimple slidertiny slidertiny slider wrapperangular ssr sliderwrapper angular tiny sliderangular tiny sliderangular carouselangular carousel tiny slidercarousel tiny slider

Angular Wrapper for Tiny Slider (with SSR !)

A simple angular wrapper for tiny slider. This project is a copy of this package because i need this wrapper up to date, and support SSR.

Getting Started

Install

npm i ngx-simple-countdown

Important ! To compile we need to add this line in your tsconfig.json, because there is a bug inside the tiny slider librairy

  "compilerOptions": {
    ...
    "skipLibCheck": true <----
  }

Import in your angular module (or feature module)

app.module.ts
import { NgxWrapperTinySliderModule } from 'ngx-wrapper-tiny-slider';

@NgModule({
  imports: [NgxWrapperTinySliderModule]
})
export class AppModule {}

Use the wrapper in your component

app.component.html
<ngx-wrapper-tiny-slider #tinySlider [config]="tinySliderConfig">
  <div class="item">
    <img src="https://picsum.photos/250/300" />
  </div>
  <div class="item">
    <img src="https://picsum.photos/200/300" />
  </div>
  <div class="item">
    <img src="https://picsum.photos/250/350" />
  </div>
</ngx-wrapper-tiny-slider>

<button (click)="goTo('prev')">prev</button>
<button (click)="goTo('next')">next</button>
app.component.ts
import { TinySliderInstance, TinySliderSettings } from 'tiny-slider';

export class AppComponent implements OnInit {
  // GET SLIDER INSTANCE HERE
  @ViewChild('tinySlider', { static: false }) tinySlider: TinySliderInstance;
  // ADD THE SLIDER CONFIG HERE (show tiny slider documentation for more)
  public tinySliderConfig: TinySliderSettings = {
    gutter: 20,
    items: 1,
    mouseDrag: true
  };

  constructor() {}

  ngOnInit() {}

  // USE THE INSTANCE OF THE SLIDER TO UPDATE SLIDER
  public goTo(foo: number | 'next' | 'prev' | 'first' | 'last'): void {
    this.tinySlider.goTo(foo);
  }
}

Use the wrapper with *ngFor

First add [initManually]="true" in the component properties

<ngx-wrapper-tiny-slider
  #tinySlider
  [config]="tinySliderConfig"
  [initManually]="true"
></ngx-wrapper-tiny-slider>

when this property is active, you have to initialize the slider yourself. So add this method in your ngAfterViewInit (or where do you need) :

  ngAfterViewInit(): void {
    this.tinySlider.initSlider();
  }