Skip to content

Commit

Permalink
feat(job-speed-chart): basic framework
Browse files Browse the repository at this point in the history
  • Loading branch information
ElonH committed May 27, 2020
1 parent a2b9525 commit 5c0dd1f
Show file tree
Hide file tree
Showing 3 changed files with 148 additions and 8 deletions.
12 changes: 7 additions & 5 deletions src/app/pages/jobs/jobs.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -35,9 +35,9 @@ import { CombErr } from 'src/app/@dataflow/core';
<div class="container">
<div class="row">
<div class="col-6">
<nb-card>
<nb-card size="small">
<nb-card-header> Speed </nb-card-header>
<nb-card-body>
<nb-card-body class="speed-body">
<jobs-speed-chart [stats$]="stats$"> </jobs-speed-chart>
</nb-card-body>
</nb-card>
Expand Down Expand Up @@ -84,12 +84,14 @@ import { CombErr } from 'src/app/@dataflow/core';
div.row {
padding-top: 1rem;
}
nb-card {
height: 100%;
}
.active-group {
background-color: lightcoral;
}
.speed-body {
padding: 1rem 0 0 0;
min-height: 10rem;
overflow-y: hidden;
}
`,
],
})
Expand Down
2 changes: 2 additions & 0 deletions src/app/pages/jobs/jobs.module.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import { TableModule } from 'ngx-easy-table';
import { SpeedChartComponent } from './speed-chart/speed-chart.component';
import { SummaryComponent } from './summary/summary.component';
import { TransfersComponent } from './transferring/transferring.component';
import { ChartsModule } from 'ng2-charts';

@NgModule({
declarations: [JobsComponent, SpeedChartComponent, SummaryComponent, TransfersComponent],
Expand All @@ -26,6 +27,7 @@ import { TransfersComponent } from './transferring/transferring.component';
TableModule,
NbListModule,
NbIconModule,
ChartsModule,
],
})
export class JobsModule {}
142 changes: 139 additions & 3 deletions src/app/pages/jobs/speed-chart/speed-chart.component.ts
Original file line number Diff line number Diff line change
@@ -1,16 +1,152 @@
import { Component, OnInit, Input } from '@angular/core';
import { Component, OnInit, Input, ViewChild } from '@angular/core';
import { CoreStatsFlow } from 'src/app/@dataflow/rclone';
import { ChartDataSets, ChartOptions } from 'chart.js';
import { Color, BaseChartDirective } from 'ng2-charts';
import * as moment from 'moment';

@Component({
selector: 'jobs-speed-chart',
template: ` <canvas baseChart width="200" height="100"></canvas> `,
styles: [],
template: `
<div class="chart-container">
<canvas
baseChart
[datasets]="lineChartData"
[options]="lineChartOptions"
[colors]="lineChartColors"
chartType="line"
></canvas>
</div>
`,
styles: [
`
.chart-container {
position: relative;
width: 100%;
height: 287px;
}
canvas {
width: 100%;
height: 100%;
}
`,
],
})
export class SpeedChartComponent implements OnInit {
@Input()
stats$: CoreStatsFlow;

constructor() {}
public lineChartData: ChartDataSets[] = [
{
data: [
{ x: moment().add(11, 'second'), y: 380 },
{ x: moment().add(22, 'second'), y: 110 },
{ x: moment().add(33, 'second'), y: 400 },
{ x: moment().add(44, 'second'), y: 300 },
{ x: moment().add(55, 'second'), y: 800 },
{ x: moment().add(57, 'second'), y: 350 },
{ x: moment().add(1, 'minute'), y: 320 },
],
label: 'Speed',
},
{
data: [
{ x: moment().add(11, 'second'), y: 246 },
{ x: moment().add(22, 'second'), y: 104 },
{ x: moment().add(33, 'second'), y: 624 },
{ x: moment().add(44, 'second'), y: 428 },
{ x: moment().add(55, 'second'), y: 301 },
{ x: moment().add(57, 'second'), y: 134 },
{ x: moment().add(1, 'minute'), y: 642 },
],
label: 'Avg',
},
];
public lineChartOptions: ChartOptions = {
responsive: true,
maintainAspectRatio: false,
animation: {
duration: 0,
},
layout: {
padding: {
bottom: -20,
},
},
legend: {
display: false,
},
hover: {
intersect: false,
},
scales: {
// We use this empty structure as a placeholder for dynamic theming.
xAxes: [
{
type: 'time',
distribution: 'linear',
time: {
minUnit: 'second',
displayFormats: {
second: 'ss',
},
},
gridLines: {
display: false,
drawBorder: false,
},
ticks: {
display: false,
padding: 0,
},
scaleLabel: {
display: false,
},
},
],
yAxes: [
{
offset: true,
gridLines: {
color: 'rgb(0,0,0,0.3)',
drawBorder: false,
},
ticks: {
labelOffset: -10, // sit on gridline
padding: -40, // moving label into dataset
// min: 0,
beginAtZero: true,
},
scaleLabel: {
display: false,
},
},
],
unit: 'minute',
},
};
public lineChartColors: Color[] = [
{
// primary
backgroundColor: 'rgba(89,139,255,0.3)',
borderColor: 'rgb(89,139,255)',
pointBorderColor: 'rgba(0,0,0,0)',
pointBackgroundColor: 'rgba(0,0,0,0)',
pointHoverBackgroundColor: 'rgba(89,139,255,0.3)',
pointHoverBorderColor: 'rgb(89,139,255)',
},
{
// info
backgroundColor: 'rgba(0,149,255,0.3)',
borderColor: '#0095ff',
pointBorderColor: 'rgba(0,0,0,0)',
pointBackgroundColor: 'rgba(0,0,0,0)',
pointHoverBackgroundColor: 'rgba(0,149,255,0.3)',
pointHoverBorderColor: '#0095ff',
},
];

@ViewChild(BaseChartDirective, { static: true }) chart: BaseChartDirective;

ngOnInit() {}
}

0 comments on commit 5c0dd1f

Please sign in to comment.