aboutsummaryrefslogtreecommitdiff
path: root/frontend/src/app/_elements/carousel-vertical/carousel-vertical.component.ts
blob: d8849ea6d91138adb46b74cd7187aaa0cd0da07c (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
import { AfterViewInit, Component, ElementRef, Input, OnInit, ViewChild } from '@angular/core';

@Component({
  selector: 'app-carousel-vertical',
  templateUrl: './carousel-vertical.component.html',
  styleUrls: ['./carousel-vertical.component.css']
})
export class CarouselVerticalComponent implements OnInit, AfterViewInit {

  @ViewChild('wrapper') wrapper!: ElementRef;

  @Input() items!: any[];

  itemsToShow: any[] = [];

  @Input() type: string = "Object";

  scroll = 0;
  height = 9; //rem

  currentIndex = 0;

  @Input() shownElements: number = 5;

  constructor() {
  }

  ngOnInit(): void {
    this.itemsToShow = [...this.items.slice(0, this.shownElements)];
    console.log('0', this.itemsToShow);
  }

  ngAfterViewInit(): void {
    const container = this.wrapper.nativeElement

    container.addEventListener('scroll', (event: Event) => {
      this.scroll = (container.scrollTop / (container.scrollHeight - container.clientHeight));
      if (this.scroll == 1.0) {
        //console.log('removed', this.itemsToShow.splice(0, 1)[0].name);
        const itemToAdd = this.items[(this.currentIndex + this.shownElements) % (this.items.length - 1)];
        this.itemsToShow.push(itemToAdd);
        //console.log('added', itemToAdd.name);
        this.currentIndex = (this.currentIndex + 1);
        container.scrollTop = (container.scrollHeight - container.clientHeight) / 2;
      }
    });
  }

  clickItem(index: number) {
  }

  calcVisibility(i: number) {
    //return ((Math.sin((((i) / this.shownElements) - this.scroll) * Math.PI) + 1) / 2)
    const iPercent = (i + 1 - this.scroll) / this.shownElements;
    return iPercent;
  }

  calcStyle(i: number) {
    const a = this.calcVisibility(i)
    const v = (Math.sin(a * Math.PI) + 1) / 2;
    return `transform: translateY(${v * 100}%) scale(${v}) perspective(${v * 200}em) rotateX(${(1 - a) * 180 - 90}deg);
            opacity: ${v};
            height: ${this.height}rem;`;
  }
}