SlideShare a Scribd company logo
Temporal Composability 
Undo / Redo in angular 
with promises 
and the command pattern 
Image by Gossins: Flow of Time
Undo / Redo 
 Native apps (including browser) support undo 
Web apps and Mobile apps do not 
 Power users produce more errors than consumers 
 Power users on a computer with native app 
 What happens when a power user uses a web app?
Power User
Use Case 
 I want to be able to build a collection 
 I want to be able to undo a price change without 
having to remember which price I destroyed.
Sets all items to 222% margin
function 
x f(x)
invertable 
x f(x) 
f-1(f(x))
State Machine 
Dual Transitions
Command Pattern
Double Stack
Double 
Stack 
 asdf
Discontinuity 
 Creating a collection 
 ID is returned asynchronously as a promise 
 ID not specified until after creation but needed for 
deletion
Promises and double closure 
*Each function has the result of its inverse as input 
msg 
Results Promise 
Context 
Arguments 
Function 
Results 
Promise 
inverse 
msg
Promises
Reusablility & Composiblity 
 F -> $q(f) - Function that generates a promise 
(reuse allows for unlimited undo/redo) 
 Asynchronous actions are handled (composition) 
 Anything can undo/redo if providing 2 functions 
 User messaging for current state of undo/redo
Answers & Questions

More Related Content

PDF
A little respect for MVC part 1 par Gegoire Lhotellier
PPTX
Decorator design pattern
PDF
Construção de instrumentos musicais
PPTX
Network Traffic Analysis at a financial institution with 788 branches for 350...
PDF
ReactiveCocoa - Functional Reactive Programming concepts in iOS
PDF
How to build a react native app with the help of react native hooks
PDF
From User Action to Framework Reaction
PDF
From User Action to Framework Reaction
A little respect for MVC part 1 par Gegoire Lhotellier
Decorator design pattern
Construção de instrumentos musicais
Network Traffic Analysis at a financial institution with 788 branches for 350...
ReactiveCocoa - Functional Reactive Programming concepts in iOS
How to build a react native app with the help of react native hooks
From User Action to Framework Reaction
From User Action to Framework Reaction

Similar to Temporal composability (20)

PDF
From User Action to Framework Reaction
ODP
From object oriented to functional domain modeling
PDF
From object oriented to functional domain modeling
PDF
Content-Driven Apps with React
PPTX
20190802 muhamad aldy b. status report
PPT
PDF
React loadable
PPTX
Modern app development with Jetpack Compose.pptx
PDF
Tech Talk on ReactJS
PDF
JOSA TechTalks - Better Web Apps with React and Redux
PDF
An approach to responsive, realtime with Backbone.js and WebSockets
PDF
Frontend Components Outside Main App by Adam Florczak
PDF
Analysing in depth work manager
ODP
AngularJs Crash Course
PDF
Fundamental concepts of react js
ODP
Scala Future & Promises
PPTX
Better web apps with React and Redux
PPTX
Meteor Meet-up San Diego December 2014
PDF
What’s new in Android: Embracing era of Generative AI
PPTX
React hooks
From User Action to Framework Reaction
From object oriented to functional domain modeling
From object oriented to functional domain modeling
Content-Driven Apps with React
20190802 muhamad aldy b. status report
React loadable
Modern app development with Jetpack Compose.pptx
Tech Talk on ReactJS
JOSA TechTalks - Better Web Apps with React and Redux
An approach to responsive, realtime with Backbone.js and WebSockets
Frontend Components Outside Main App by Adam Florczak
Analysing in depth work manager
AngularJs Crash Course
Fundamental concepts of react js
Scala Future & Promises
Better web apps with React and Redux
Meteor Meet-up San Diego December 2014
What’s new in Android: Embracing era of Generative AI
React hooks
Ad

Recently uploaded (20)

PDF
Audit Checklist Design Aligning with ISO, IATF, and Industry Standards — Omne...
PDF
Nekopoi APK 2025 free lastest update
PDF
Claude Code: Everyone is a 10x Developer - A Comprehensive AI-Powered CLI Tool
PPTX
Agentic AI : A Practical Guide. Undersating, Implementing and Scaling Autono...
PDF
Navsoft: AI-Powered Business Solutions & Custom Software Development
PPTX
Introduction to Artificial Intelligence
PPTX
ai tools demonstartion for schools and inter college
PDF
EN-Survey-Report-SAP-LeanIX-EA-Insights-2025.pdf
PDF
Odoo Companies in India – Driving Business Transformation.pdf
PDF
Internet Downloader Manager (IDM) Crack 6.42 Build 42 Updates Latest 2025
PDF
Design an Analysis of Algorithms I-SECS-1021-03
PDF
SAP S4 Hana Brochure 3 (PTS SYSTEMS AND SOLUTIONS)
PPTX
Reimagine Home Health with the Power of Agentic AI​
PDF
Wondershare Filmora 15 Crack With Activation Key [2025
PPTX
Agentic AI Use Case- Contract Lifecycle Management (CLM).pptx
PPTX
Transform Your Business with a Software ERP System
PDF
Upgrade and Innovation Strategies for SAP ERP Customers
PPTX
Lecture 3: Operating Systems Introduction to Computer Hardware Systems
PDF
Which alternative to Crystal Reports is best for small or large businesses.pdf
PDF
How to Migrate SBCGlobal Email to Yahoo Easily
Audit Checklist Design Aligning with ISO, IATF, and Industry Standards — Omne...
Nekopoi APK 2025 free lastest update
Claude Code: Everyone is a 10x Developer - A Comprehensive AI-Powered CLI Tool
Agentic AI : A Practical Guide. Undersating, Implementing and Scaling Autono...
Navsoft: AI-Powered Business Solutions & Custom Software Development
Introduction to Artificial Intelligence
ai tools demonstartion for schools and inter college
EN-Survey-Report-SAP-LeanIX-EA-Insights-2025.pdf
Odoo Companies in India – Driving Business Transformation.pdf
Internet Downloader Manager (IDM) Crack 6.42 Build 42 Updates Latest 2025
Design an Analysis of Algorithms I-SECS-1021-03
SAP S4 Hana Brochure 3 (PTS SYSTEMS AND SOLUTIONS)
Reimagine Home Health with the Power of Agentic AI​
Wondershare Filmora 15 Crack With Activation Key [2025
Agentic AI Use Case- Contract Lifecycle Management (CLM).pptx
Transform Your Business with a Software ERP System
Upgrade and Innovation Strategies for SAP ERP Customers
Lecture 3: Operating Systems Introduction to Computer Hardware Systems
Which alternative to Crystal Reports is best for small or large businesses.pdf
How to Migrate SBCGlobal Email to Yahoo Easily
Ad

Temporal composability