Skip to content

Latest commit

 

History

History
279 lines (185 loc) · 14.6 KB

ProjectOverview.md

File metadata and controls

279 lines (185 loc) · 14.6 KB

DRAFT

STRVCT / Project Overview

[TOC]

Abstract

Naked objects 1 aimed to simplify and accelerate software development by exposing domain (business) objects directly to users and automatically generating user interfaces and handling storage. Despite these advantages, usability limitations have restricted its adoption to internal tools and prototypes.

While functionally complete, these systems often lack the interface patterns expected in end-user applications. This paper describes a new approach to help address these limitations and introduces an open-source JavaScript client-side framework called Strvct that implements it.

Domain Model

In our system, the domain model is a cyclic graph of domain objects. Each domain object has:

  • Properties (instance variables) and actions (methods)
  • a subnodes property containing an ordered unique collection of child domain objects
  • a parentNode property pointing to its parent domain object
  • property annotations 2 which allow for the automatic handling of UI and storage mechanisms
  • title and subtitle properties
  • a unique ID

The domain model can be seen as an ownership tree of domain objects, which may also contain non-ownership links between nodes.

Collection Managers

Complex collections of domain objects use Collection Manager domain objects to encapsulate collection-specific logic and data. This pattern is essential for properly expressing domain models within Strvct.

For example, a Server class might have a guestConnections property referencing a GuestConnections instance (a DomainObject descendant) whose subnodes are GuestConnection instances.

Indirect UI Coupling

The domain model operates independently of UI, allowing for "headless" execution. It can, however, use annotations to provide optional UI hints without direct coupling. This is possible because model objects hold no references to UI objects and can only communicate with them via notifications.

User Interface

Note: the following diagrams are designed to illustrate view layouts and not their actual appearance.

Tiles

The core navigational elements, referred to as Tiles are used to present a single domain object or a single domain property. Tile subclasses can be used to customize the appearance of and interaction with these. Domain objects annotations can be used to request specific tiles to be used to represent them or their properties.

Domain Object Tiles

Summary Tiles are the default tiles used to represent domain objects and to navigate the domain model. They typically display a title, subtitle, and optional left and right sidebars. More specialized tiles can be also used to represent domain objects.

Summary Tile [SVG diagram]

Property Tiles

Property Tiles present a property of a domain object and typically display a name and value, and optionally a note, and/or error (i.e. validation error).

Property Tile [SVG diagram]

Strvct includes a number of specialized property tiles for common property types, such as Strings, Numbers, Dates, Times, and Images.

Dynamic Inspectors

Properties with complex structures, such as Dates, Times, valid value pickers, may dynamically create a transient domain model objects when accessed which can be navigated and interacted with as if they were part of the model.

Tile Stacks

A Tile Stack is a scrollable stacks of Tiles which are used to present the subnodes of a domain object. They support flexible orientation, and gestures for adding, removing, and reordering tiles. Optional support for grid or outline layouts could be added, but are not currently supported.

Tile Stack
[SVG diagram]

Master-Detail Views

A Master-Detail View is used to present a domain object. Its master section contains a Tile Stack presenting the subnodes of the domain object and its detail section presents the domain object for the selected subnode tile, which itself may be a master-detail view. The master section supports optional header and footer views which can be used to flexibly implement features like search, message input, or group actions. The divider between the master and detail sections can also be dragged to resize the sections if the domain object allows it.

Master-Detail View
[SVG diagram]

Flexible Orientation

Detail Views can be oriented to be be right-of, or below the Master View (which contains theTiles Stack). Both can be requested by the related domain object or overridden by the user interface, offering adaptability based on the content, display size, and user preference.

Master-Detail Orientations [SVG diagram]

Nesting

Nesting of master-detail views with flexible orientations allows for navigation structures which fit many common application design patterns.

Vertical [SVG diagram]
Horizontal
[SVG diagram]
Hybrid
[SVG diagram]

Auto Collapsing and Expanding

Chains of Master-Detail views automatically collapse/expand their tile views until there is space for the remaining master-details views. This allows for responsive and efficient use of display space across a wide range of viewport sizes.

Expanded
[SVG diagram]

Collapsed
[SVG diagram]

Navigation Path

Tiles on the selected are highlighted, and the focused tile (which represents the most recently selected location) is distinguished with a unique highlight.

These highlights and other visual attributes are customizable via themes.

Navigation Path
[SVG diagram]

Breadcrumbs

A BreadcrumbTile can be used to represent the current navigation path. It automatically compacts and expands to reveal more of the path based on the current viewport size, replacing the compacted path with a back arrow.

Breadcrumbs
[SVG diagram]

Menus

Tile navigation is very similar to menu navigation, and multiple levels of traditional menus can be constructed using various orientations of master-detail views.

Horizontal Menus
[SVG diagram]

Screenshots

Strvct framework as used in an AI based interactive fiction game.

Screenshot 1

Themes

Themes can be used to customize the appearance of the UI. Domain objects can also request object specific styles to be applied to them.

Importing and Exporting

Drag and drop of domain objects into the UI and out of it for export is also supported. Domain objects can register for which MIME type they can exported to and imported from. For example, if a domain object supports it, it can be dragged out of one browser window onto a user's desktop, or even dropped into another Strvct app that accepts that MIME type. Domain objects have a standard property which lists its valid subnode types, and this can be used to validate drops and auto generate subnodes for imported data.

JSON Schema

Domain objects can automatically generate JSON Schema for themselves based on their properties and annotations. These schemas are be used to export metadata about the domain model, which is particularly usefull when interacting with Large Language Models.

UI Synchronization

Model-view synchronization is managed by views, which either pull or push changes to the domain objects they are presenting. Views push changes when a view property changes, and pull changes from domain objects when those objects post change notifications. Only properties in views and domain objects which have the "sync" annotation will trigger sync operations. Both domain object change notifications and view push messages are coalesced and sent at the end of the event loop.

Sync Loop Avoidance

Bidirectional sync stops automatically as property changes trigger sync operations only when values actually differ, preventing infinite loops. If secondary changes do occur, the notification system detects the loop, halts it, and identifies the source.

Reference Loop Avoidance

Observations use weak references, allowing garbage collection of both posters and listeners. The Notification system automatically removes observations when the listener is collected.

Storage

Annotations

Domain objects have a property which determines whether the object persisted, as well as property annotations which determine which properties are persisted. Using this information, the system automatically manages persistence.

Transactions

Mutations on persistent properties auto-queue domain objects for storage. Queued objects are bundled into a transaction committed at the end of the current event loop.

Garbage Collection

Automatic garbage collection of the stored object graph occurs on startup, or when requested. Only objects reachable from the root domain object remain after garbage collection.

Native Collections

Native JavaScript collections (Array, ArrayBuffer, Map, Object, Set, and TypedArray) referenced by persistent properties of domain objects are also automatically persisted in their own records.

Local Storage

Persistent domain objects are stored client side in IndexedDB in a single Object Store of records whose keys are the domain object unique ID and values are the domain objects JSON records. Currently, the only index is on the unique ID.