Want to receive my work as I publish it?

LAB NOTES
LAB NOTES
LN 033
12•18•2022

These Lab Notes document my research in progress. My research area is in the future of personal computing.

TOC Previous Next Latest


LN 040

The venerable hyperlink

LN 039

Notes on time

LN 038

Semantic zoom

LN 037

Gestural view construction

LN 036

Free and easy organizations and associations

LN 035

The Messy Desktop

LN 034

Live items & Contextual notifications

LN 033

Swappable reference views

LN 032

System injections

LN 031

Fluid workspaces

LN 030

Foldable views

LN 029

Experimenting with the item as the core primitive

LN 028

Designing systems for computer literacy and evolvability

LN 027

Personal Computing Network & Devices

LN 026

Internet Modules

LN 025

Publishing items

LN 024

Mutations & Item change logs

LN 023

Higher-level primitives

LN 022

Undo Actions

LN 021

Automations

LN 020

Item Actions

LN 019

Notifications

LN 018

Services & Item Drives

LN 017

Today & Daily summary

LN 016

Calendar views

EXPERIMENT 001

Cross-reference Navigation in Obsidian

LN 015

Cross-references & References cloud

LN 014

The Graph OS

LN 013

Why is our thinking on computers so restrained?

LN 012

References box & Topics

LN 011

General purpose personal computing software

LN 010

User-created application and system views

LN 009

User-created item views

LN 008

Unified views

LN 007

Atomized apps

LN 006

Swappable views

LN 005

Associated items

LN 004

Browsing contexts & recent paths

LN 003

Universal reference containers

LN 002

Universal data portability

LN 001

Composing application interfaces

LN 000

The Lab Notes

Swappable reference views

We explored how you might use any item as a workspace in LN 031: Fluid workspaces. In this lab note, we’ll expand on that thinking, with a new example.

Consider: With fluid workspaces, you could open a todo item from your day’s list of tasks as your fullscreen workspace. In this workspace, you’d open any of the things you need while you work on the task. If you switched over to working on something else, when you wanted to return to that task, you could simply open it as a fullscreen workspace again, and all of the items that you’d arranged and used before would be available. Or, if you opened the task within some other workspace, you could see these items that it references in a list; you’d always have access to the things that you need to complete the task, whether you open it as a list of resources, or as a fullscreen workspace — even though this item is itself a todo.

This is a wonderful flexibility in our systems that might enrich our interactions with our digital things. But it leaves one question: We previously explored how items have swappable views (LN 006), including how one might define the small and large size views for items (LN 009). We probably have a small item view for todo items in our system that consists of a checkbox on the left and a text input beside it. But what is a todo item’s fullscreen view? We don’t actually need or want to define one; when a todo item is being used as a fullscreen workspace, we simply want to use our traditional workspace views, and we likely want to see the basic details of this todo: its completion status and title.

Further, as we look around the itemized system, we realize that many of our items do not actually need their own custom item views; they often simply display the items they reference in various ways (as a list, columns on a horizontal path, a canvas, and so forth). Even a note in the itemized environment may very well be a list of references to text / paragraph items. Besides a title at the top, the item view is primarily made up of its references (the blocks of text). A todo list is similar: it is a list of references to todo items, with a title, and maybe a summary, at the top.

We don’t need to define a custom item view for these, just as we don’t need to define a custom fullscreen workspace item view for our todo item to act as our workspace in the earlier example.

Instead, we will explore the concept of reference views, which give our systems more of their functionality and flexibility.


Consider: We might have an item that is a todo list associated with a date, but instead of having to build an item view for it, we can use a view that lists its references below its title. This reference list already works across our entire system, supports drag and drop, and so forth. We could also switch to an outline view (which lets us recursively open deeper lists of items’ references).

When we open one of these todos as our fullscreen workspace, our system can continue to make use of the available reference views.

Consider: Without a dedicated fullscreen item view for todos, our system can use one of our workspace views, such as a browsing path. It can include the todo’s usual item view in a column on the left. Its usual list of references below can operate like the foldable views we saw in LN 030.

We can move around this horizontal browsing path, and open any other needed items, just as we’ve seen in LN 004.

And, just as we saw in LN 030: Foldable views, we can collapse some of these items back under the primary todo view on the left, letting us focus on the resources we need right now.

It’s also swappable: This browsing path is simply a fullscreen view of the references from any item. We can swap it out for another, such as a canvas, if we need.

These items we open in the workspace are now references within the enclosing todo item. When we close this todo workspace, we know that everything we used in the course of this task is saved within it. Later, if we open it back up, everything will remain in this non-volatile workspace.

Or, if we open this todo within another workspace, its items will come with it.

Consider: When we open this todo as a column in another browsing path, we see its item view above a list of its references — all the items we used to work on this task so far.

With just one item view for todos — a simple view that horizontally stacks a checkbox and a text input — our system can use reference views to give us lots of other ways to make use of our todo items. We can swap these views out as needed, and new reference views can be built and used, with any item and its item view, to explore new ways of interacting with our things.

Something spark a thought? Email me, or come chat on Mastodon or on Twitter.


« Previous: LN 032

TOC

Next: LN 034 »


Want to receive my work as I publish it?