Platform
Resources
Pricing
Sign in
Get started
Devin Bayly
Workspace
Fork
Published
By
Devin Bayly
Edited
Apr 15, 2022
Insert cell
#
Globus task-event visualizer
Insert cell
Insert cell
html
`<svg width =${
width
} height=${
graphHeight
*
2
+
50
}>
<g transform="translate(0,25)">
<text>${
uploadData
.
name
}</text>
<g>${
totals
}</g>
<g transform="translate(0,${
graphHeight
})">${
mbps
}</g>
</g>
</svg>`
Insert cell
graphHeight
=
200
Insert cell
progress
=
uploadData
.
data
.
DATA
.
filter
(
(
e
)
=>
e
.
code
==
"PROGRESS"
)
.
map
(
(
e
)
=>
{
let
{
details
,
time
,
...
rest
}
=
e
;
time
=
new
Date
(
time
)
;
details
=
JSON
.
parse
(
details
)
;
return
{
details
,
time
,
...
rest
}
;
}
)
Insert cell
bytes
=
d3
.
cumsum
(
progress
.
map
(
(
e
)
=>
e
.
details
[
"bytes_transferred"
]
/
1e9
)
.
reverse
(
)
)
Insert cell
cprog
=
progress
.
map
(
(
e
,
i
)
=>
(
{
...
e
,
MBSoFar
:
bytes
[
bytes
.
length
-
1
-
i
]
}
)
)
Insert cell
totals
=
Plot
.
plot
(
{
grid
:
true
,
marginLeft
:
50
,
height
:
graphHeight
,
y
:
{
label
:
"GB transferred"
}
,
marks
:
[
Plot
.
line
(
cprog
,
{
x
:
"time"
,
y
:
(
e
)
=>
e
.
MBSoFar
}
)
]
}
)
Insert cell
mbps
=
Plot
.
plot
(
{
grid
:
true
,
height
:
graphHeight
,
y
:
{
label
:
"MB/s"
}
,
marks
:
[
Plot
.
line
(
progress
,
{
x
:
"time"
,
y
:
(
e
)
=>
e
.
details
.
mbps
/
8
}
)
]
}
)
Insert cell
Purpose-built for displays of data
Observable is your go-to platform for exploring data and creating expressive data visualizations. Use reactive JavaScript notebooks for prototyping and a collaborative canvas for visual data exploration and dashboard creation.
Try it for free
Learn more
Fork
View
Export
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
uploadData
Edit
Pin
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
graphHeight
Unpin
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
progress
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
bytes
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
cprog
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
totals
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
mbps
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
JavaScript
Markdown
HTML