mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-10 02:03:07 +08:00
df38008c56
Summary: This diff includes a few small things: - Menu: Don't select the first item until the user taps down arrow, and allow the user to use the arrow keys to move up and down through Menu items. - Menu: Make scroll code from MultiselectList re-usable, use in Menu. Now if you use the keys to move to an item that is offscreen it will follow. - Popover: Tapping the button that opened popover should close it - Make sure buttons in toolbars are at least standard height - Re-enable Markdown processing via `grunt docs` - A bit of initial inline documentation for crosjdoc. Need to evaluate whether this is worth doing everywhere. - New `search-playground` package for experimenting with search and search weights. - Swap itemClassProvider for more generic itemPropProvider - Add crojsdoc config file - Export React, because third party packages can't require things from our app - [FEATURE] Bring back static file support in third party packages via `nylas://translate/IMG_20150417_124142.jpg` - Fix invariant error with search bar - [FEATURE] "Show Original" under Message actions - Fix DatabaseView so that many archives at once don't cause problems Test Plan: Run specs Reviewers: evan Reviewed By: evan Differential Revision: https://review.inboxapp.com/D1426
75 lines
2.6 KiB
Markdown
75 lines
2.6 KiB
Markdown
## Serialization in Atom
|
|
|
|
When a window is refreshed or restored from a previous session, the view and its
|
|
associated objects are *deserialized* from a JSON representation that was stored
|
|
during the window's previous shutdown. For your own views and objects to be
|
|
compatible with refreshing, you'll need to make them play nicely with the
|
|
serializing and deserializing.
|
|
|
|
### Package Serialization Hook
|
|
|
|
Your package's main module can optionally include a `serialize` method, which
|
|
will be called before your package is deactivated. You should return JSON, which
|
|
will be handed back to you as an argument to `activate` next time it is called.
|
|
In the following example, the package keeps an instance of `MyObject` in the
|
|
same state across refreshes.
|
|
|
|
```coffee-script
|
|
module.exports =
|
|
activate: (state) ->
|
|
@myObject =
|
|
if state
|
|
atom.deserializers.deserialize(state)
|
|
else
|
|
new MyObject("Hello")
|
|
|
|
serialize: ->
|
|
@myObject.serialize()
|
|
```
|
|
|
|
### Serialization Methods
|
|
|
|
```coffee-script
|
|
class MyObject
|
|
atom.deserializers.add(this)
|
|
|
|
@deserialize: ({data}) -> new MyObject(data)
|
|
constructor: (@data) ->
|
|
serialize: -> { deserializer: 'MyObject', data: @data }
|
|
```
|
|
|
|
#### .serialize()
|
|
Objects that you want to serialize should implement `.serialize()`. This method
|
|
should return a serializable object, and it must contain a key named
|
|
`deserializer` whose value is the name of a registered deserializer that can
|
|
convert the rest of the data to an object. It's usually just the name of the
|
|
class itself.
|
|
|
|
#### @deserialize(data)
|
|
The other side of the coin is the `deserialize` method, which is usually a
|
|
class-level method on the same class that implements `serialize`. This method's
|
|
job is to convert a state object returned from a previous call `serialize` back
|
|
into a genuine object.
|
|
|
|
#### atom.deserializers.add(klass)
|
|
You need to call the `atom.deserializers.add` method with your class in
|
|
order to make it available to the deserialization system. Now you can call the
|
|
global `deserialize` method with state returned from `serialize`, and your
|
|
class's `deserialize` method will be selected automatically.
|
|
|
|
### Versioning
|
|
|
|
```coffee-script
|
|
class MyObject
|
|
atom.deserializers.add(this)
|
|
|
|
@version: 2
|
|
@deserialize: (state) -> ...
|
|
serialize: -> { version: @constructor.version, ... }
|
|
```
|
|
|
|
Your serializable class can optionally have a class-level `@version` property
|
|
and include a `version` key in its serialized state. When deserializing, Atom
|
|
will only attempt to call deserialize if the two versions match, and otherwise
|
|
return undefined. We plan on implementing a migration system in the future, but
|
|
this at least protects you from improperly deserializing old state.
|