Skip to content

uiuniversal/ngu-carousel

Repository files navigation

ngu-carousel

npm downloads

npm version

All Contributors

Angular Universal carousel

Note: This carousel doesn't include any CSS. go and customize CSS for buttons, items except ngucarousel and ngucarousel-inner

Demo

Demo available in Stackblitz Here

Demo available Here

Installation

ngu-carousel supports touch actions and requires hammerjs to be installed before the ngu-carousel is installed.

Angular Versionngu-carousel Version
Angular >= 20npm i --save @ngu/carousel@20
Angular >= 19npm i --save @ngu/carousel@19
Angular >= 18npm i --save @ngu/carousel@18
Angular >= 17npm i --save @ngu/[email protected]

Usage

  1. Include Carousel needed parts in your module or component (all carousel components and directives are standalone):
import{NguCarousel,NguCarouselDefDirective,NguCarouselNextDirective,NguCarouselPrevDirective,NguItemComponent}from'@ngu/carousel'; @NgModule({imports: [NguCarousel,NguTileComponent,NguCarousel,NguCarouselDefDirective,NguCarouselNextDirective,NguCarouselPrevDirective,NguItemComponent]})exportclassAppModule{}OR; @Component({imports: [NguCarousel,NguTileComponent,NguCarousel,NguCarouselDefDirective,NguCarouselNextDirective,NguCarouselPrevDirective,NguItemComponent],standalone: true})exportclassAppComponent{}
  1. Then use in your component:
import{Component,OnInit}from'@angular/core';import{NguCarouselConfig}from'@ngu/carousel'; @Component({selector: 'sample',template: ` <ngu-carousel #myCarousel [inputs]="carouselTile" [dataSource]="carouselTileItems"> <ngu-tile *nguCarouselDef="let item; let i = index"> <ngu-carousel #myCarousel [inputs]="carouselTile" (carouselLoad)="carouselTileLoad(i)" [dataSource]="carouselTiles[i]"> <ngu-tile *nguCarouselDef="let item; let j = index"> <div class="tile" [style.background]="'url(' + item + ')'" style="min-height: 200px"> <h1>{{j}}</h1> </div> </ngu-tile> <button NguCarouselPrev class="leftRs" [style.opacity]="myCarousel.isFirst() ? 0.5:1">&lt;</button> <button NguCarouselNext class="rightRs" [style.opacity]="myCarousel.isLast() ? 0.5:1">&gt;</button> <ul class="myPoint" NguCarouselPoint> <li *ngFor="let j of myCarousel.pointNumbers(); let j = index" [class.active]="j==myCarousel.activePoint()" (click)="myCarousel.moveTo(j)" [style.background]="'url(' + carouselTileItems[j] + ')'"></li> </ul> </ngu-carousel> </ngu-tile> <button NguCarouselPrev class="leftRs" [style.opacity]="myCarousel.isFirst() ? 0.5:1">&lt;</button> <button NguCarouselNext class="rightRs" [style.opacity]="myCarousel.isLast() ? 0.5:1">&gt;</button> <ul class="myPoint" NguCarouselPoint> <li *ngFor="let i of myCarousel.pointNumbers(); let i = index" [class.active]="i==myCarousel.activePoint()" (click)="myCarousel.moveTo(i)" [style.background]="'url(' + carouselTileItems[i] + ')'"></li> </ul></ngu-carousel> `,})exportclassSampleComponentimplementsOnInit{imgags=['assets/bg.jpg','assets/car.png','assets/canberra.jpg','assets/holi.jpg'];publiccarouselTileItems: Array<any>=[0,1,2,3,4,5];publiccarouselTiles={0: [],1: [],2: [],3: [],4: [],5: []};publiccarouselTile: NguCarouselConfig={grid: {xs: 1,sm: 1,md: 3,lg: 3,all: 0},slide: 3,speed: 250,point: {visible: true},load: 2,velocity: 0,touch: true,easing: 'cubic-bezier(0, 0, 0.2, 1)'};constructor(){}ngOnInit(){this.carouselTileItems.forEach(el=>{this.carouselTileLoad(el);});}publiccarouselTileLoad(j){// console.log(this.carouselTiles[j]);constlen=this.carouselTiles[j].length;if(len<=30){for(leti=len;i<len+15;i++){this.carouselTiles[j].push(this.imgags[Math.floor(Math.random()*this.imgags.length)]);}}}}

Input Interface

export classNguCarouselStore{type: string; deviceType: DeviceType; token: string; items: number; load: number; deviceWidth: number; carouselWidth: number; itemWidth: number; visibleItems: ItemsControl; slideItems: number; itemWidthPer: number; itemLength: number; currentSlide: number; easing: string; speed: number; transform: Transfrom; loop: boolean; dexVal: number; touchTransform: number; touch: Touch; isEnd: boolean; isFirst: boolean; isLast: boolean; RTL: boolean; vertical: Vertical;}exporttypeDeviceType='xs'|'sm'|'md'|'lg'|'xl'|'all'; export classItemsControl{start: number; end: number;} export classVertical{enabled: boolean; height: number;}exportclassTouch{active?: boolean;swipe: string;velocity: number;} export classNguCarouselConfig{grid: Transfrom;gridBreakpoints?: Breakpoints;slide?: number;speed?: number;interval?: CarouselInterval;animation?: Animate;point?: Point;type?: string;load?: number;custom?: Custom;loop?: boolean;touch?: boolean;easing?: string;RTL?: boolean;button?: NguButton;vertical?: Vertical;velocity?: number;} export classGrid{xs: number; sm: number; md: number; lg: number; xl: number; all: number;}exportinterfacePoint{ visible: boolean;hideOnSingleSlide?: boolean;}exporttypeCustom='banner';exporttypeAnimate='lazy';
CommandTypeRequiredDescription
gridObjectYesxs - mobile, sm - tablet, md - desktop, lg - large desktops, xl - extra large desktops, all - fixed width (When you use all make others 0 and vice versa)
gridBreakpointsObjectoptionalDetermines the browser width in pixels that the grid displays the intended number of tiles.

default: {sm: 768, md: 992, lg: 1200, xl: 1200}
slidenumberoptionalIt is used to slide the number items on click
speedmillisecondsoptionalIt is used for time taken to slide the number items
intervalmillisecondsoptionalIt is used to make the carousel auto slide with given value. interval defines the interval between slides
loadnumberoptionalIt is used to load the items similar to pagination. The carousel will trigger the carouselLoad function to load another set of items. It will help you to improve the performance of the app.(carouselLoad)="myfunc($event)"
point.visiblebooleanoptionalIt is used to indicate no. of slides and also shows the current active slide.
point.hideOnSingleSlidebooleanoptionalIt is used to hide the point indicator when slide is less than one.
touchbooleanoptionalIt is used to active touch support to the carousel.
easingstringoptionalIt is used to define the easing style of the carousel. Only define the ease name without any timing like ease,ease-in
loopbooleanoptionalIt is used to loop the ngu-item ngu-tile. It must be true for interval
animationstringoptionalIt is used to animate the sliding items. currently it only supports lazy. more coming soon and also with custom CSS animation option
customstringoptionalIt is you to define the purpose of the carousel. Currently, it only supports banner.
RTLbooleanoptionalThis option enables the rtl direction and acts as rtl. By default it is set to ltr
vertical.enabledbooleanoptionalThis option enable the vertical direction
vertical.heightnumberoptionalThis option is used to set the height of the carousel

Custom CSS for Point

<ulclass="ngucarouselPoint"><li*ngFor="let i of pointNumbers; let i = index" [class.active]="i==pointers"></li></ul>

This is HTML I'm using in the carousel. Add your own CSS according to this elements in pointStyles. check below guide for more details.

<ngu-carousel[inputs]="carouselBanner" (onMove)="onmoveFn($event)" (carouselLoad)="loadItemsFn()"></ngu-carousel>
  • inputs is an Input and It accepts NguCarouselConfig.
  • onMove is an Output which triggered on every slide before start and it will emit $event as NguCarouselStore object.
  • carouselLoad is an Output which triggered when slide reaches the end on items based on inputs load.

Getstarted guide

Banner with Custom point style

import{Component}from'@angular/core';import{NguCarousel,NguCarouselStore}from'@ngu/carousel'; @Component({selector: 'app-carousel',template: ` <ngu-carousel [inputs]="carouselBanner" (onMove)="onmoveFn($event)" [trackBy]="trackCarousel"> <ngu-item NguCarouselItem class="bannerStyle"> <h1>1</h1> </ngu-item> <ngu-item NguCarouselItem class="bannerStyle"> <h1>2</h1> </ngu-item> <ngu-item NguCarouselItem class="bannerStyle"> <h1>3</h1> </ngu-item> <button NguCarouselPrev class="leftRs">&lt;</button> <button NguCarouselNext class="rightRs">&gt;</button> </ngu-carousel> `,styles: [` .bannerStyle h1{ background-color: #ccc; min-height: 300px; text-align: center; line-height: 300px; } .leftRs{ position: absolute; margin: auto; top: 0; bottom: 0; width: 50px; height: 50px; box-shadow: 1px 2px 10px -1px rgba(0, 0, 0, 0.3); border-radius: 999px; left: 0; } .rightRs{ position: absolute; margin: auto; top: 0; bottom: 0; width: 50px; height: 50px; box-shadow: 1px 2px 10px -1px rgba(0, 0, 0, 0.3); border-radius: 999px; right: 0; } `]})exportclassSampleimplementsOnInit{ngOnInit(){this.carouselBanner={grid: {xs: 1,sm: 1,md: 1,lg: 1,xl: 1,all: 0},slide: 1,speed: 400,interval: {timing: 3000,initialDelay: 1000},point: {visible: true},load: 2,loop: true,touch: true};}/* It will be triggered on every slide*/onmoveFn(data: NguCarouselStore){console.log(data);}trackCarousel(_,item){returnitem;}}

Banner with Vertical carousel

import{Component}from'@angular/core';import{NguCarousel,NguCarouselConfig}from'@ngu/carousel'; @Component({selector: 'app-carousel',template: ` <ngu-carousel [inputs]="carouselBanner" (onMove)="onmoveFn($event)"> <ngu-item NguCarouselItem class="bannerStyle"> <h1>1</h1> </ngu-item> <ngu-item NguCarouselItem class="bannerStyle"> <h1>2</h1> </ngu-item> <ngu-item NguCarouselItem class="bannerStyle"> <h1>3</h1> </ngu-item> <button NguCarouselPrev class='leftRs'>&lt;</button> <button NguCarouselNext class='rightRs'>&gt;</button> </ngu-carousel> `,styles: [` .bannerStyle h1{ background-color: #ccc; min-height: 300px; text-align: center; line-height: 300px; } .leftRs{ position: absolute; margin: auto; top: 0; bottom: 0; width: 50px; height: 50px; box-shadow: 1px 2px 10px -1px rgba(0, 0, 0, .3); border-radius: 999px; left: 0; } .rightRs{ position: absolute; margin: auto; top: 0; bottom: 0; width: 50px; height: 50px; box-shadow: 1px 2px 10px -1px rgba(0, 0, 0, .3); border-radius: 999px; right: 0; } .ngucarouselPoint{ list-style-type: none; text-align: center; padding: 12px; margin: 0; white-space: nowrap; overflow: auto; position: absolute; width: 100%; bottom: 20px; left: 0; box-sizing: border-box; } .ngucarouselPoint li{ display: inline-block; border-radius: 999px; background: rgba(255, 255, 255, 0.55); padding: 5px; margin: 0 3px; transition: .4s ease all; } .ngucarouselPoint li.active{ background: white; width: 10px; } `]})exportclassSampleimplementsOnInit{ngOnInit(){this.carouselBanner={grid: {xs: 1,sm: 1,md: 1,lg: 1,xl:1,all: 0},slide: 1,speed: 400,interval: 4000,point: {visible: true},load: 2,loop: true,touch: true,// touch is not currently in active for vertical carousel, will enable it in future buildvertical{enabled: true,height: 400}};}/* It will be triggered on every slide*/onmoveFn(data: NguCarousel){console.log(data);}}

Tile with Carousel Control

import{Component}from'@angular/core';import{NguCarousel,NguCarouselConfig}from'@ngu/carousel'; @Component({selector: 'app-carousel',template: ` <ngu-carousel #carousel [inputs]="carouselTile" (carouselLoad)="carouselTileLoad($event)"> <ngu-tile NguCarouselItem *ngFor="let Tile of carouselTileItems"> <h1>{{Tile + 1}}</h1> </ngu-tile> <button NguCarouselPrev class='leftRs'>&lt;</button> <button NguCarouselNext class='rightRs'>&gt;</button> </ngu-carousel> <button (click)="resetFn()">Reset</button> `,styles: [` h1{ min-height: 200px; background-color: #ccc; text-align: center; line-height: 200px; } .leftRs{ position: absolute; margin: auto; top: 0; bottom: 0; width: 50px; height: 50px; box-shadow: 1px 2px 10px -1px rgba(0, 0, 0, .3); border-radius: 999px; left: 0; } .rightRs{ position: absolute; margin: auto; top: 0; bottom: 0; width: 50px; height: 50px; box-shadow: 1px 2px 10px -1px rgba(0, 0, 0, .3); border-radius: 999px; right: 0; } `]})exportclassSampleimplementsOnInit{privatecarouselToken: string;publiccarouselTileItems: Array<any>;publiccarouselTile: NguCarouselConfig; @ViewChild('carousel')carousel: NguCarousel;constructor(){}ngOnInit(){this.carouselTileItems=[0,1,2,3,4,5,6,7,8,9,10,11,12,13];this.carouselTile={grid: {xs: 2,sm: 3,md: 3,lg: 5,xl:5,all: 0},slide: 2,speed: 400,animation: 'lazy',point: {visible: true},load: 2,touch: true,easing: 'ease'}}initDataFn(key: NguCarouselStore){this.carouselToken=key.token;}resetFn(){this.carousel.reset(this.carouselToken);}moveToSlide(){this.carousel.moveToSlide(this.carouselToken,2,false);}publiccarouselTileLoad(evt: any){constlen=this.carouselTileItems.lengthif(len<=30){for(leti=len;i<len+10;i++){this.carouselTileItems.push(i);}}}// carouselLoad will trigger this function when your load value reaches// it helps to load the data by parts to increase the performance of the app// must use feature to all carousel}

Tile with custom point style

import{Component}from'@angular/core';import{NguCarousel}from'@ngu/carousel'; @Component({selector: 'app-carousel',template: ` <ngu-carousel [inputs]="carouselTile" (carouselLoad)="carouselTileLoad($event)"> <ngu-tile NguCarouselItem *ngFor="let Tile of carouselTileItems"> <h1>{{Tile + 1}}</h1> </ngu-tile> <button NguCarouselPrev class='leftRs'>&lt;</button> <button NguCarouselNext class='rightRs'>&gt;</button> </ngu-carousel> `,styles: [` h1{ min-height: 200px; background-color: #ccc; text-align: center; line-height: 200px; } .leftRs{ position: absolute; margin: auto; top: 0; bottom: 0; width: 50px; height: 50px; box-shadow: 1px 2px 10px -1px rgba(0, 0, 0, .3); border-radius: 999px; left: 0; } .rightRs{ position: absolute; margin: auto; top: 0; bottom: 0; width: 50px; height: 50px; box-shadow: 1px 2px 10px -1px rgba(0, 0, 0, .3); border-radius: 999px; right: 0; } `]})exportclassSampleimplementsOnInit{publiccarouselTileItems: Array<any>;publiccarouselTile: NguCarousel;ngOnInit(){this.carouselTileItems=[0,1,2,3,4,5,6,7,8,9,10,11,12,13];this.carouselTile={grid: {xs: 2,sm: 3,md: 3,lg: 5,xl:5,all: 0},slide: 2,speed: 400,animation: 'lazy',point: {visible: true,pointStyles: ` .ngucarouselPoint{ list-style-type: none; text-align: center; padding: 12px; margin: 0; white-space: nowrap; overflow: auto; box-sizing: border-box; } .ngucarouselPoint li{ display: inline-block; border-radius: 50%; border: 2px solid rgba(0, 0, 0, 0.55); padding: 4px; margin: 0 3px; transition-timing-function: cubic-bezier(.17, .67, .83, .67); transition: .4s; } .ngucarouselPoint li.active{ background: #6b6b6b; transform: scale(1.2); } `},load: 2,touch: true,easing: 'ease'}}publiccarouselTileLoad(evt: any){constlen=this.carouselTileItems.lengthif(len<=30){for(leti=len;i<len+10;i++){this.carouselTileItems.push(i);}}}// carouselLoad will trigger this function when your load value reaches// it helps to load the data by parts to increase the performance of the app// must use feature to all carousel}

License

MIT license.

Contributors ✨

Thanks goes to these wonderful people (emoji key):

Code Veins
Code Veins

💻
Marcin Czachurski
Marcin Czachurski

💻
Alexander Buiko
Alexander Buiko

💻
Frido Koch
Frido Koch

💻
Giorgio Modoni
Giorgio Modoni

💻
faran312
faran312

💻
Euan Goddard
Euan Goddard

💻
Santosh Yadav
Santosh Yadav

💻
Tiago Magalhães
Tiago Magalhães

📖
Sam Vloeberghs
Sam Vloeberghs

📖
rat-matheson
rat-matheson

💻
Brandon Largeau
Brandon Largeau

💻
Artur Androsovych
Artur Androsovych

💻
chivesrs
chivesrs

💻
Luca Peruzzo
Luca Peruzzo

💻
Mateusz Stefańczyk
Mateusz Stefańczyk

💻
Matthieu Riegler
Matthieu Riegler

👀
Sasidharan SD
Sasidharan SD

📖
Jonatan Plata
Jonatan Plata

💻
Felipe Yukio Fupunaga
Felipe Yukio Fupunaga

💻

This project follows the all-contributors specification. Contributions of any kind welcome!