From 8cb1fc3ca6a8e9f04d6fd1ae40d2bf09b991d784 Mon Sep 17 00:00:00 2001 From: Dylan Hoefsloot Date: Fri, 12 Jan 2024 10:30:31 +1300 Subject: [PATCH] Add documentation for initial_transition feature --- README.md | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/README.md b/README.md index 600e20a3..972979dd 100644 --- a/README.md +++ b/README.md @@ -256,6 +256,23 @@ ActiveRecord adapter. Statesman will fallback to memory unless you specify a transition_class when instantiating your state machine. This allows you to only persist transitions on certain state machines in your app. +### `initial_transition` + +```ruby +def state_machine + @state_machine ||= OrderStateMachine.new(self, transition_class: OrderTransition, + association_name: :transitions, + initial_transition: true) +end +``` + +By default Statesman does not record a transition to the initial state of the state machine. + +You can configure Statesman to record a transition to the initial state, this will allow you to: +- Keep an accurate record of the intial state even if configuration changes +- Keep a record of how long the state machine spent in the initial state +- Utilise a transition hook for the transition to the initial state + ## Class methods ### `Machine.state`