UNPKG

ngsl-carousel

Version:

This project was generated with [Angular CLI](https://github.com/angular/angular-cli) version 6.2.4.

238 lines (237 loc) 22.2 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import { Component, ContentChildren, Directive, ElementRef, Input, QueryList, ViewChild, ViewChildren } from '@angular/core'; import { NgslCarouselItemDirective } from './ngsl-carousel-item.directive'; import { NgslCarouselDotDirective } from './ngsl-carousel-dot.directive'; import { animate, AnimationBuilder, style } from '@angular/animations'; // tslint:disable-next-line:directive-class-suffix export class CarouselItemElement { } CarouselItemElement.decorators = [ { type: Directive, args: [{ // tslint:disable-next-line:directive-selector selector: '.ngsl-carousel-item-directive' },] } ]; // tslint:disable-next-line:directive-class-suffix export class CarouselDotElement { } CarouselDotElement.decorators = [ { type: Directive, args: [{ // tslint:disable-next-line:directive-selector selector: '.ngsl-carousel-dot-directive' },] } ]; export class NgslCarouselComponent { /** * @param {?} builder */ constructor(builder) { this.builder = builder; /* carousel end dot */ /* Input props start*/ this.timing = 450; this.rewindTiming = 900; this.arrows = true; this.dots = true; this.infinity = true; this.dynamicTiming = false; this.autoplay = true; this.perView = 1; this.action = null; this.currentSlide = 0; this.prevSlide = null; this.nextSlide = null; this.trackWidth = {}; } /** * @param {?} offset * @return {?} */ buildAnimation(offset) { /** @type {?} */ const duration = this.action === 'REWIND' ? this.rewindTiming : this.timing; return this.builder.build([ animate(`${duration}ms cubic-bezier(0.165, 0.840, 0.440, 1.000)`, style({ transform: `translateX(${offset}%)` })) ]); } /** * @param {?} action * @return {?} */ changeSlide(action) { this.setSlidesIndex(); /** @type {?} */ const itemW = (100 / this.items.length) / this.perView; /** @type {?} */ const offset = (itemW * this.currentSlide) * this.perView; /** @type {?} */ const myAnimation = this.buildAnimation(-offset); this.player = myAnimation.create(this.carousel.nativeElement); this.player.play(); // console.log(`changeSlide action: ${action}, is current slide: `, this.currentSlide + 1); } /** * @param {?} index * @return {?} */ goToSlide(index) { if (this.dynamicTiming) { // В разработке, тестовая опция this.timing = this.timing + (55 * (index - this.currentSlide)); } this.currentSlide = index; this.changeSlide('go to slide'); } /** * @return {?} */ next() { /** @type {?} */ const countSlides = this.items.length; if (this.currentSlide + 1 === countSlides && this.infinity) { this.currentSlide = 0; this.action = 'REWIND'; this.changeSlide('rewind to first slide'); return; } if (this.currentSlide + 1 === countSlides && !this.infinity) { return; } this.currentSlide++; this.action = 'NEXT_SLIDE'; this.changeSlide('next slide'); } /** * @return {?} */ prev() { /** @type {?} */ const countSlides = this.items.length; if (this.currentSlide === 0 && this.infinity) { this.currentSlide = countSlides - 1; this.action = 'REWIND'; this.changeSlide('rewind to last slide'); return; } if (this.currentSlide === 0 && !this.infinity) { return; } this.currentSlide--; this.action = 'PREV_SLIDE'; this.changeSlide('prev slide'); } /** * @return {?} */ setSlidesIndex() { this.prevSlide = this.currentSlide === 0 ? this.items.length - 1 : this.currentSlide - 1; this.nextSlide = this.currentSlide === this.items.length - 1 ? 0 : this.currentSlide + 1; } /** * @return {?} */ removeDotsInDomElements() { /** @type {?} */ const position = this.perView > 1 ? this.dotsList.length - this.perView : null; this.dotsList.toArray().forEach((dot, i) => { if (i > position) { dot.isVisible = false; } }); } /** * @return {?} */ setInitValues() { this.setSlidesIndex(); if (this.perView > 1) { this.removeDotsInDomElements(); } this.trackWidth = { width: `${(100 * this.items.length) / this.perView}%` }; } /** * @return {?} */ ngAfterContentInit() { this.setInitValues(); } } NgslCarouselComponent.decorators = [ { type: Component, args: [{ // tslint:disable-next-line:component-selector selector: 'ngsl-carousel', exportAs: 'ngsl-carousel', template: "<div class=\"ngsl-carousel\">\n <div *ngIf=\"dots\" class=\"dots\" #dotsTrack>\n <div *ngFor=\"let item of dotsList; let i = index\"\n class=\"ngsl-carousel-dot-directive dot\"\n (click)=\"goToSlide(i)\"\n [class.is-current-item]=\"currentSlide === i\">\n <ng-container *ngIf=\"item.isVisible\" [ngTemplateOutlet]=\"item.tpl\"></ng-container>\n </div>\n </div>\n <div class=\"slide\">\n <div class=\"content\">\n <div *ngIf=\"arrows\" class=\"slide-arrows\">\n <input type=\"button\" (click)=\"prev()\" class=\"prev\" [class.is-disabled]=\"currentSlide === 0\" />\n <input type=\"button\" (click)=\"next()\" class=\"next\" [class.is-disabled]=\"currentSlide === items.length - 1\" />\n </div>\n <div class=\"slide-track\" #track [ngStyle]=\"trackWidth\">\n <div *ngFor=\"let item of items\" class=\"ngsl-carousel-item-directive\">\n <ng-container [ngTemplateOutlet]=\"item.tpl\"></ng-container>\n </div>\n </div>\n </div>\n </div>\n</div>\n", styles: [".ngsl-carousel{overflow:hidden;position:relative}.ngsl-carousel .dots{position:absolute;top:30px;right:40px;font-size:0;z-index:10}.ngsl-carousel .dots .dot{display:inline-block;vertical-align:middle;width:10px;height:10px;border-radius:100%;background-color:#768692;box-sizing:border-box;cursor:pointer}.ngsl-carousel .dots .dot+.dot{margin-left:10px}.ngsl-carousel .dots .dot.is-current-item{width:22px;height:22px;position:relative;border:1px solid #fff;background-color:transparent}.ngsl-carousel .dots .dot.is-current-item:after{content:\"\";position:absolute;left:50%;top:50%;-webkit-transform:translate3d(-50%,-50%,0);transform:translate3d(-50%,-50%,0);width:10px;height:10px;border-radius:100%;background-color:#fff}.slide-track{display:flex;flex-direction:row;flex-wrap:nowrap;height:100%}.ngsl-carousel-item-directive{width:100%;height:100%}.slide-arrows input[type=button]{z-index:10;position:absolute;left:0;top:50%;-webkit-transform:translateY(-50%);transform:translateY(-50%);width:40px;height:40px;background-color:#768692;opacity:.7;border:0;cursor:pointer;background-repeat:no-repeat;background-position:center}.slide-arrows input[type=button]:hover{opacity:.9}.slide-arrows input[type=button].is-disabled{background-color:#c4bcb7}.slide-arrows input[type=button].is-disabled:hover{opacity:.7}.slide-arrows input[type=button]:focus{outline:0}.slide-arrows input[type=button].prev{-webkit-transform:translateY(-50%) rotate(-180deg);transform:translateY(-50%) rotate(-180deg)}.slide-arrows input[type=button].next{left:auto;right:0}"] }] } ]; /** @nocollapse */ NgslCarouselComponent.ctorParameters = () => [ { type: AnimationBuilder } ]; NgslCarouselComponent.propDecorators = { items: [{ type: ContentChildren, args: [NgslCarouselItemDirective,] }], itemsElements: [{ type: ViewChildren, args: [CarouselItemElement, { read: ElementRef },] }], carousel: [{ type: ViewChild, args: ['track',] }], dotsList: [{ type: ContentChildren, args: [NgslCarouselDotDirective,] }], dotElements: [{ type: ViewChildren, args: [CarouselDotElement, { read: ElementRef },] }], dotTrack: [{ type: ViewChild, args: ['dotTrack',] }], timing: [{ type: Input }], rewindTiming: [{ type: Input }], arrows: [{ type: Input }], dots: [{ type: Input }], infinity: [{ type: Input }], dynamicTiming: [{ type: Input }], autoplay: [{ type: Input }], perView: [{ type: Input }] }; if (false) { /** @type {?} */ NgslCarouselComponent.prototype.items; /** @type {?} */ NgslCarouselComponent.prototype.itemsElements; /** @type {?} */ NgslCarouselComponent.prototype.carousel; /** @type {?} */ NgslCarouselComponent.prototype.dotsList; /** @type {?} */ NgslCarouselComponent.prototype.dotElements; /** @type {?} */ NgslCarouselComponent.prototype.dotTrack; /** @type {?} */ NgslCarouselComponent.prototype.timing; /** @type {?} */ NgslCarouselComponent.prototype.rewindTiming; /** @type {?} */ NgslCarouselComponent.prototype.arrows; /** @type {?} */ NgslCarouselComponent.prototype.dots; /** @type {?} */ NgslCarouselComponent.prototype.infinity; /** @type {?} */ NgslCarouselComponent.prototype.dynamicTiming; /** @type {?} */ NgslCarouselComponent.prototype.autoplay; /** @type {?} */ NgslCarouselComponent.prototype.perView; /** @type {?} */ NgslCarouselComponent.prototype.player; /** @type {?} */ NgslCarouselComponent.prototype.action; /** @type {?} */ NgslCarouselComponent.prototype.currentSlide; /** @type {?} */ NgslCarouselComponent.prototype.prevSlide; /** @type {?} */ NgslCarouselComponent.prototype.nextSlide; /** @type {?} */ NgslCarouselComponent.prototype.trackWidth; /** @type {?} */ NgslCarouselComponent.prototype.builder; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngsl-carousel.component.js","sourceRoot":"ng://ngsl-carousel/","sources":["src/app/ngsl-carousel/ngsl-carousel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  Component,\n  ContentChildren,\n  Directive,\n  ElementRef,\n  Input,\n  QueryList,\n  ViewChild,\n  ViewChildren\n} from '@angular/core';\n\nimport { NgslCarouselItemDirective } from './ngsl-carousel-item.directive';\nimport { NgslCarouselDotDirective } from './ngsl-carousel-dot.directive';\nimport {\n  animate,\n  AnimationBuilder,\n  AnimationFactory,\n  AnimationPlayer,\n  style\n} from '@angular/animations';\n\n@Directive({\n  // tslint:disable-next-line:directive-selector\n  selector: '.ngsl-carousel-item-directive'\n})\n// tslint:disable-next-line:directive-class-suffix\nexport class CarouselItemElement {}\n@Directive({\n  // tslint:disable-next-line:directive-selector\n  selector: '.ngsl-carousel-dot-directive'\n})\n// tslint:disable-next-line:directive-class-suffix\nexport class CarouselDotElement {}\n\n@Component({\n  // tslint:disable-next-line:component-selector\n  selector: 'ngsl-carousel',\n  exportAs: 'ngsl-carousel',\n  templateUrl: './ngsl-carousel.component.html',\n  styleUrls: ['./ngsl-carousel.component.scss']\n})\nexport class NgslCarouselComponent implements AfterContentInit {\n  /* carousel start item */\n  @ContentChildren(NgslCarouselItemDirective) items: QueryList<NgslCarouselItemDirective>;\n  @ViewChildren(CarouselItemElement, { read: ElementRef }) private itemsElements: QueryList<ElementRef>;\n  @ViewChild('track') private carousel: ElementRef;\n  /* carousel end item */\n\n  /* carousel start dot */\n  @ContentChildren(NgslCarouselDotDirective) dotsList: QueryList<NgslCarouselDotDirective>;\n  @ViewChildren(CarouselDotElement, { read: ElementRef }) private dotElements: QueryList<ElementRef>;\n  @ViewChild('dotTrack') private dotTrack: ElementRef;\n  /* carousel end dot */\n\n  /* Input props start*/\n  @Input() timing = 450;\n  @Input() rewindTiming = 900;\n  @Input() arrows = true;\n  @Input() dots = true;\n  @Input() infinity = true;\n  @Input() dynamicTiming = false;\n  @Input() autoplay = true;\n  @Input() perView = 1;\n  /* Input props end*/\n  private player: AnimationPlayer;\n  private action = null;\n  currentSlide = 0;\n  prevSlide = null;\n  nextSlide = null;\n  trackWidth = {};\n\n  private buildAnimation(offset) {\n    const duration = this.action === 'REWIND' ? this.rewindTiming : this.timing;\n    return this.builder.build([\n      animate(`${duration}ms cubic-bezier(0.165, 0.840, 0.440, 1.000)`, style({ transform: `translateX(${offset}%)` }))\n    ]);\n  }\n\n  private changeSlide(action) {\n    this.setSlidesIndex();\n    const itemW = (100 / this.items.length) / this.perView;\n    const offset = (itemW * this.currentSlide) * this.perView;\n    const myAnimation: AnimationFactory = this.buildAnimation(-offset);\n    this.player = myAnimation.create(this.carousel.nativeElement);\n    this.player.play();\n    // console.log(`changeSlide action: ${action}, is current slide: `, this.currentSlide + 1);\n  }\n\n  goToSlide(index) {\n    if (this.dynamicTiming) {\n      // В разработке, тестовая опция\n      this.timing = this.timing + (55 * (index - this.currentSlide));\n    }\n    this.currentSlide = index;\n    this.changeSlide('go to slide');\n  }\n\n  next() {\n    const countSlides = this.items.length;\n    if (this.currentSlide + 1 === countSlides && this.infinity) {\n      this.currentSlide = 0;\n      this.action = 'REWIND';\n      this.changeSlide('rewind to first slide');\n      return;\n    }\n    if (this.currentSlide + 1 === countSlides && !this.infinity) {\n      return;\n    }\n\n    this.currentSlide++;\n    this.action = 'NEXT_SLIDE';\n    this.changeSlide('next slide');\n  }\n\n  prev() {\n    const countSlides = this.items.length;\n    if (this.currentSlide === 0 && this.infinity) {\n      this.currentSlide = countSlides - 1;\n      this.action = 'REWIND';\n      this.changeSlide('rewind to last slide');\n      return;\n    }\n    if (this.currentSlide === 0 && !this.infinity) {\n      return;\n    }\n\n    this.currentSlide--;\n    this.action = 'PREV_SLIDE';\n    this.changeSlide('prev slide');\n  }\n\n  private setSlidesIndex() {\n    this.prevSlide = this.currentSlide === 0 ? this.items.length - 1 : this.currentSlide - 1;\n    this.nextSlide = this.currentSlide === this.items.length - 1 ? 0 : this.currentSlide + 1;\n  }\n\n  private removeDotsInDomElements() {\n    const position = this.perView > 1 ? this.dotsList.length - this.perView : null;\n    this.dotsList.toArray().forEach((dot, i) => {\n      if (i > position) { dot.isVisible = false; }\n    });\n  }\n\n  private setInitValues() {\n    this.setSlidesIndex();\n    if (this.perView > 1) {\n      this.removeDotsInDomElements();\n    }\n    this.trackWidth = {\n      width: `${(100 * this.items.length) / this.perView}%`\n    };\n  }\n\n  constructor(private builder: AnimationBuilder) {}\n\n  ngAfterContentInit() {\n    this.setInitValues();\n  }\n}\n"]}