2018-06-23 04:30:50 +08:00
|
|
|
// Copyright 2018 Google Inc.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
2018-06-22 05:04:19 +08:00
|
|
|
// Binary sparklinedemo displays a couple of SparkLine widgets.
|
|
|
|
// Exist when 'q' is pressed.
|
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"math/rand"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/mum4k/termdash"
|
2019-02-24 14:13:26 +08:00
|
|
|
"github.com/mum4k/termdash/cell"
|
2018-06-22 05:04:19 +08:00
|
|
|
"github.com/mum4k/termdash/container"
|
2019-02-24 14:51:50 +08:00
|
|
|
"github.com/mum4k/termdash/linestyle"
|
2019-02-24 14:04:57 +08:00
|
|
|
"github.com/mum4k/termdash/terminal/termbox"
|
2019-02-24 14:27:17 +08:00
|
|
|
"github.com/mum4k/termdash/terminal/terminalapi"
|
2018-06-22 05:04:19 +08:00
|
|
|
"github.com/mum4k/termdash/widgets/sparkline"
|
|
|
|
)
|
|
|
|
|
|
|
|
// playSparkLine continuously adds values to the SparkLine, once every delay.
|
|
|
|
// Exits when the context expires.
|
|
|
|
func playSparkLine(ctx context.Context, sl *sparkline.SparkLine, delay time.Duration) {
|
|
|
|
const max = 100
|
|
|
|
|
|
|
|
ticker := time.NewTicker(delay)
|
|
|
|
defer ticker.Stop()
|
|
|
|
for {
|
|
|
|
select {
|
|
|
|
case <-ticker.C:
|
|
|
|
v := int(rand.Int31n(max + 1))
|
2018-06-23 04:33:05 +08:00
|
|
|
if err := sl.Add([]int{v}); err != nil {
|
2018-06-22 05:04:19 +08:00
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
case <-ctx.Done():
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-03-04 07:13:17 +08:00
|
|
|
// fillSparkLine continuously fills the SparkLine up to its capacity with
|
|
|
|
// random values.
|
|
|
|
func fillSparkLine(ctx context.Context, sl *sparkline.SparkLine, delay time.Duration) {
|
|
|
|
const max = 100
|
|
|
|
|
|
|
|
ticker := time.NewTicker(delay)
|
|
|
|
defer ticker.Stop()
|
|
|
|
for {
|
|
|
|
select {
|
|
|
|
case <-ticker.C:
|
|
|
|
var values []int
|
|
|
|
for i := 0; i < sl.ValueCapacity(); i++ {
|
|
|
|
values = append(values, int(rand.Int31n(max+1)))
|
|
|
|
}
|
|
|
|
if err := sl.Add(values); err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
case <-ctx.Done():
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-06-22 05:04:19 +08:00
|
|
|
func main() {
|
|
|
|
t, err := termbox.New()
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
defer t.Close()
|
|
|
|
|
|
|
|
ctx, cancel := context.WithCancel(context.Background())
|
2019-02-15 13:05:45 +08:00
|
|
|
green, err := sparkline.New(
|
2018-06-22 21:40:41 +08:00
|
|
|
sparkline.Label("Green SparkLine", cell.FgColor(cell.ColorBlue)),
|
2018-06-23 08:48:50 +08:00
|
|
|
sparkline.Color(cell.ColorGreen),
|
2018-06-22 21:40:41 +08:00
|
|
|
)
|
2019-02-15 13:05:45 +08:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2018-06-22 21:40:41 +08:00
|
|
|
go playSparkLine(ctx, green, 250*time.Millisecond)
|
2019-02-15 13:05:45 +08:00
|
|
|
red, err := sparkline.New(
|
2018-06-22 21:40:41 +08:00
|
|
|
sparkline.Label("Red SparkLine", cell.FgColor(cell.ColorBlue)),
|
|
|
|
sparkline.Color(cell.ColorRed),
|
|
|
|
)
|
2019-02-15 13:05:45 +08:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2018-06-22 21:40:41 +08:00
|
|
|
go playSparkLine(ctx, red, 500*time.Millisecond)
|
2019-02-15 13:05:45 +08:00
|
|
|
yellow, err := sparkline.New(
|
2018-06-22 21:40:41 +08:00
|
|
|
sparkline.Label("Yellow SparkLine", cell.FgColor(cell.ColorGreen)),
|
|
|
|
sparkline.Color(cell.ColorYellow),
|
|
|
|
)
|
2019-02-15 13:05:45 +08:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2019-03-04 07:13:17 +08:00
|
|
|
go fillSparkLine(ctx, yellow, 1*time.Second)
|
2018-06-22 05:04:19 +08:00
|
|
|
|
2019-01-14 13:08:20 +08:00
|
|
|
c, err := container.New(
|
2018-06-22 05:04:19 +08:00
|
|
|
t,
|
2019-02-24 14:51:50 +08:00
|
|
|
container.Border(linestyle.Light),
|
2018-06-22 05:04:19 +08:00
|
|
|
container.BorderTitle("PRESS Q TO QUIT"),
|
2018-06-22 21:40:41 +08:00
|
|
|
container.SplitVertical(
|
|
|
|
container.Left(
|
|
|
|
container.SplitHorizontal(
|
|
|
|
container.Top(),
|
|
|
|
container.Bottom(
|
2019-02-24 14:51:50 +08:00
|
|
|
container.Border(linestyle.Light),
|
2018-06-22 21:40:41 +08:00
|
|
|
container.BorderTitle("SparkLine group"),
|
|
|
|
container.SplitHorizontal(
|
|
|
|
container.Top(
|
|
|
|
container.PlaceWidget(green),
|
|
|
|
),
|
|
|
|
container.Bottom(
|
|
|
|
container.PlaceWidget(red),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
container.Right(
|
2019-02-24 14:51:50 +08:00
|
|
|
container.Border(linestyle.Light),
|
2018-06-22 21:40:41 +08:00
|
|
|
container.PlaceWidget(yellow),
|
|
|
|
),
|
|
|
|
),
|
2018-06-22 05:04:19 +08:00
|
|
|
)
|
2019-01-14 13:08:20 +08:00
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2018-06-22 05:04:19 +08:00
|
|
|
|
|
|
|
quitter := func(k *terminalapi.Keyboard) {
|
|
|
|
if k.Key == 'q' || k.Key == 'Q' {
|
|
|
|
cancel()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := termdash.Run(ctx, t, c, termdash.KeyboardSubscriber(quitter)); err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
}
|