@lava.ts/serializable
Name
Lava.ts Serializable
Description
Typescript classes for data serialization
Visuals
Depending on what you are making, it can be a good idea to include screenshots or even a video (you'll frequently see GIFs rather than actual videos). Tools like ttygif can help, but check out Asciinema for a more sophisticated method.
Installation
npm install @lava.ts/serializable
Usage
import { SerializableClass } from "@lava.ts/serializable/lib/SerializableClass";
import { AutoSerializer } from "@lava.ts/serializable/lib/AutoSerializer";
import { addSerializer } from "@lava.ts/serializable/lib/serializers";
export class MyDataClass extends SerializableClass {
static __name__ = "my-data-class";
declare $data: {
position: number,
type: string,
};
constructor(params: Record<string, unknown>) {
super({
position: 0,
type: "default",
...params,
});
}
get position() {
return this.$data.position;
}
set position(position) {
this.$data.position = position;
}
get type() {
return this.$data.type;
}
set type(type) {
this.$data.type = type;
}
get triple() {
"@serializable false";
return this.position * 3;
}
set triple(triple) {
this.position = triple / 3;
}
}
const autoserializer = new AutoSerializer(MyDataClass);
addSerializer(autoserializer);
export default MyDataClass;
Support
Submit issue on github or gitlab
Roadmap
- Project Manager with Structures
- History manager for undo/redo
- Integration with Vue.js reactivity
Contributing
Not open for contribution at the moment. Currently building the first steps of the librairy
Authors and acknowledgment
License
BSD-3-Clause
Project status
Currently building the first steps of the librairy