﻿import { Component, ViewChild } from '@angular/core';

import { jqxKnobComponent } from 'jqwidgets-scripts/jqwidgets-ts/angular_jqxknob';

@Component({
    selector: 'app-root',
    templateUrl: './app.component.html'
})

export class AppComponent {
    @ViewChild('myKnob') myKnob: jqxKnobComponent;

    style: any =
    {
        stroke: '#dfe3e9',
        strokeWidth: 3,
        fill: {
            color: '#fefefe', gradientType: 'linear',
            gradientStops: [[0, 1], [50, 0.9], [100, 1]]
        }
    };

    marks: any =
    {
        colorRemaining: '#333',
        colorProgress: '#333',
        type: 'line',
        offset: '71%',
        thickness: 1,
        size: '6%',
        majorSize: '9%',
        majorInterval: 10,
        minorInterval: 2
    };

    labels: any =
    {
        offset: '88%',
        step: 10
    };

    progressBar: any =
    {
        style: { fill: { color: '#00a644', gradientType: 'linear', gradientStops: [[0, 1], [50, 0.9], [100, 1]] }, stroke: '#00a644' },
        background: { fill: { color: '#ff8b1e', gradientType: 'linear', gradientStops: [[0, 1], [50, 0.9], [100, 1]] }, stroke: '#ff8b1e' },
        size: '9%',
        offset: '60%'
    };

    pointer: any =
    {
        type: 'circle',
        style: { fill: '#ef6100', stroke: '#ef6100' },
        size: '5%',
        offset: '38%',
        thickness: 20
    };

    spinner: any =
    {
        style: { fill: { color: '#00a4e1', gradientType: 'linear', gradientStops: [[0, 1], [50, 0.9], [100, 1]] }, stroke: '#00a4e1' },
        innerRadius: '45%', // specifies the inner Radius of the dial
        outerRadius: '60%', // specifies the outer Radius of the dial
        marks: {
            colorRemaining: '#fff',
            colorProgress: '#fff',
            type: 'line',
            offset: '46%',
            thickness: 2,
            size: '14%',
            majorSize: '14%',
            majorInterval: 10,
            minorInterval: 10
        }
    };

    dial: any =
    {
        style: { fill: { color: '#dfe3e9', gradientType: 'linearHorizontal', gradientStops: [[0, 0.9], [50, 1], [100, 1]] }, stroke: '#dfe3e9' },
        innerRadius: '0%', // specifies the inner Radius of the dial
        outerRadius: '45%'
    };


    lastValue: number;
    newValue: number = 0;
    min: number = 0;
    max: number = 100;

    myKnobOnChange(event: any): void {
        this.lastValue = this.newValue;
        this.newValue = event.args.value;
        if (this.newValue >= this.min && this.newValue <= this.min + 10 && this.lastValue <= this.max && this.lastValue >= this.max - 10) {
            this.min = this.max;
            this.max += 100;
            this.myKnob.setOptions({ value: this.max, max: this.max, min: this.min });
        } else if (this.newValue >= this.max - 10 && this.newValue <= this.max && this.lastValue >= this.min && this.lastValue <= this.min + 10) {
            this.max = this.min;
            this.min -= 100;
            this.myKnob.setOptions({ value: this.min, min: this.min, max: this.max });
        }
    }
}