Since state management is such a huge part of Ember.js it desrves a
dedicated article. I’m not going to explain the old router which used
Ember.StateManager to do it’s bidding. Those days are over and we
should all be moving towards the v2 router (or v2.2 so to speak).
Instead we’re going to go deep into the Ember.StateManager.
In the general concept, state manager is basically some object which manages states and the transitions between them, thus representing a finite state machine.
Let’s say we have a Post which can be in two states, draft and
published. It begins it’s life as a draft and when we publish it,
it should send out a notification email. The way Ember would handle this
is that it would assign a Ember.StateManager instance to the Post
instance and have that manage it’s state (that’s not exactly true in
Ember Data, but we’ll get into that).
For now let’s just say that this is the code we have
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 |  | 
This gives us a really basic implementation. I’m setting the
stateManager property in the init function to avoid sharing the
instance across multiple Post instances. I’ll explain this in a
followup article, for now just remember that if you need to set a
property to an object instance, you have to do that in the init
function, not directly like stateManager: PostManager.create().
OK, we are now ready to list all of the states a Post can have.
| 1 2 3 4 |  | 
We forgot to say which of the states should be the default. Let’s do that.
| 1 2 3 4 5 6 7 |  | 
From now every single post we create will be a draft
| 1 2 |  | 
And we can also make it transition into another state
| 1 2 3 |  | 
But Ember.StateManager can do more than that. We can hook into both
enter and exit events on each state and do some magic! Let’s
redefine our state manager as this
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |  | 
Understanding how this class works is essential for any Ember developer, as it is being used in almost every part of the framework. We’ll take at some specific examples in the second part of this artcile.