mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-07 13:22:07 -05:00
Allow serialization values to mark themselves as _default.
Solves unnecessarily serialized leading values.
This commit is contained in:
parent
efe8bab129
commit
1eb6b49e8a
2 changed files with 12 additions and 2 deletions
|
@ -164,12 +164,16 @@ var Item = Base.extend(Callback, /** @lends Item# */{
|
||||||
function serialize(fields) {
|
function serialize(fields) {
|
||||||
for (var key in fields) {
|
for (var key in fields) {
|
||||||
var value = that[key];
|
var value = that[key];
|
||||||
if (!Base.equals(value, fields[key]))
|
// Allow returned values to mark themselves as default through
|
||||||
|
// the "hidden" _default property. See Style#getLeading()
|
||||||
|
if (!(value && value._default)
|
||||||
|
&& !Base.equals(value, fields[key])) {
|
||||||
props[key] = Base.serialize(value, options,
|
props[key] = Base.serialize(value, options,
|
||||||
// Do not use compact mode for data
|
// Do not use compact mode for data
|
||||||
key !== 'data', dictionary);
|
key !== 'data', dictionary);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Serialize fields that this Item subclass defines first
|
// Serialize fields that this Item subclass defines first
|
||||||
serialize(this._serializeFields);
|
serialize(this._serializeFields);
|
||||||
|
|
|
@ -238,7 +238,13 @@ var Style = Base.extend(new function() {
|
||||||
getLeading: function getLeading() {
|
getLeading: function getLeading() {
|
||||||
// Override leading to return fontSize * 1.2 by default.
|
// Override leading to return fontSize * 1.2 by default.
|
||||||
var leading = getLeading.base.call(this);
|
var leading = getLeading.base.call(this);
|
||||||
return leading != null ? leading : this.getFontSize() * 1.2;
|
if (leading == null) {
|
||||||
|
// Box default leading in a Number, and mark it as default, for
|
||||||
|
// serialization.
|
||||||
|
leading = new Number(this.getFontSize() * 1.2);
|
||||||
|
leading._default = true;
|
||||||
|
}
|
||||||
|
return leading;
|
||||||
},
|
},
|
||||||
|
|
||||||
getFontStyle: function() {
|
getFontStyle: function() {
|
||||||
|
|
Loading…
Reference in a new issue