Block status
For the first version of the application, the block status is the central part of the user experience. The application is focused on letting users easily run a node, and the block status provides a simple visual to see the current status.
data:image/s3,"s3://crabby-images/311de/311de63748e13381278132f5790e25c03a633957" alt="Application screen showing the block status"
data:image/s3,"s3://crabby-images/609be/609be4b065e546897b50613024562fc82c9ec2c5" alt="Explanation of the block status elements"
data:image/s3,"s3://crabby-images/92b33/92b33cf38852bd4698699a380383ea04b28526c7" alt="Explanation of the peer indicator states"
Every element in the block status has a function. They can be combined to communicate different application states.
data:image/s3,"s3://crabby-images/e719d/e719d306403e779e4434847e0b2c0f4e9a53af80" alt="Various states of the block status"
It takes some time until the application can show initial progress and a somewhat reliable time estimate until completion of the initial block download. To the user, this can look like the application is broken. So a few adjustments are made:
- The progress circle always shows at least a small bit (even at 0%)
- While the percentage value is typically rounded, we show tenths and hundredths below 1% so users can see some progress
- While the estimated time fluctuates drastically and provides not useful information, we only show “Estimating”
- A “~” indicates that this is an estimate
- We only show minutes when we’re confident that they are somewhat accurate
data:image/s3,"s3://crabby-images/28878/288782f12b011171a54bac930398b1a1f6ab38bc" alt="Details of the initial block download state"
A network indicator appears below the block status when the application does not run on mainnet. We need to decide whether this element should have a tool tip, and/or tapping it navigates to the settings for more information and options.
data:image/s3,"s3://crabby-images/5fef8/5fef86c03a9a829eb3abe077e62566fbe57f3e90" alt="Visual states of the network indicator below the block status"
And the block status in light mode, which simply switches the color variables from the dark set to the light set.
data:image/s3,"s3://crabby-images/fe010/fe010ea76bf344f539e0d6baed4e9b147c5f8c9f" alt="The block status in light mode"
Layout logic
By default, the circular block status is 200x200px in size, centered on the screen. The top bar is 46px tall and absolutely positioned.
When a network indicator is shown, the bounding box of the block status and network indicator is used for centering within the window.
data:image/s3,"s3://crabby-images/4d1a1/4d1a1cae68883358e66c3e88f13629b87479dac9" alt="Default layout logic diagram"
In showcase mode, the block status tries to maintain 1/3 of the screen width or height, whichever value is smaller. It maintains a minimum size of 200x200px.
data:image/s3,"s3://crabby-images/a5569/a556927897490c492699d47255b023cee979308d" alt="Layout logic diagram for showcase mode"
At smaller sizes (height < 400), the network indicator moves to the top-left corner of the window, making more room for the block status, which tries to keep a size of 200x200px.
data:image/s3,"s3://crabby-images/4e000/4e0006c1ba7e129a42f1bc84d6c71f44fd95054c" alt="Layout logic diagram for small window sizes"
At even smaller sizes, the primary factor becomes a minimum side padding of 25px. The block status shrinks smaller than it’s 200x200px default size. The top bar height shrinks to 36px.
data:image/s3,"s3://crabby-images/9ce06/9ce063795c0eed2ff7894b3aff1a6e4fc16cfcd2" alt="Layout logic diagram for very small window sizes"
Prototype
This web prototype was done to validate if the block status dial renders well with realistic data (or if segments get too small), to explore animations & interactions, and test widgets.