mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-07 13:22:07 -05:00
Improve Palette and Component code.
- Only create label elements when they are set for the first time. - Give created elements clear class and id names.
This commit is contained in:
parent
e541b10e89
commit
c2cb3e3342
2 changed files with 47 additions and 34 deletions
|
@ -81,24 +81,23 @@ var Component = Base.extend(Callback, /** @lends Component# */{
|
||||||
|
|
||||||
initialize: function Component(obj) {
|
initialize: function Component(obj) {
|
||||||
this._id = Component._id = (Component._id || 0) + 1;
|
this._id = Component._id = (Component._id || 0) + 1;
|
||||||
this._type = obj.type in this._types
|
var type = this._type = obj.type in this._types
|
||||||
? obj.type
|
? obj.type
|
||||||
: 'options' in obj
|
: 'options' in obj
|
||||||
? 'list'
|
? 'list'
|
||||||
: 'onClick' in obj
|
: 'onClick' in obj
|
||||||
? 'button'
|
? 'button'
|
||||||
: typeof obj.value;
|
: typeof obj.value,
|
||||||
this._meta = this._types[this._type] || { type: this._type };
|
meta = this._meta = this._types[type] || { type: type },
|
||||||
var that = this,
|
name = this._name = obj.name || 'component-' + this._id,
|
||||||
id = 'component-' + this._id;
|
that = this;
|
||||||
this._dontFire = true;
|
this._input = DomElement.create(meta.tag || 'input', {
|
||||||
this._input = DomElement.create(this._meta.tag || 'input', {
|
id: 'palettejs-input-' + name,
|
||||||
id: id,
|
type: meta.type,
|
||||||
type: this._meta.type,
|
|
||||||
events: {
|
events: {
|
||||||
change: function() {
|
change: function() {
|
||||||
that.setValue(
|
that.setValue(
|
||||||
DomElement.get(this, that._meta.value || 'value'));
|
DomElement.get(this, meta.value || 'value'));
|
||||||
},
|
},
|
||||||
click: function() {
|
click: function() {
|
||||||
that.fire('click');
|
that.fire('click');
|
||||||
|
@ -108,17 +107,22 @@ var Component = Base.extend(Callback, /** @lends Component# */{
|
||||||
// Attach default 'change' even that delegates to palette
|
// Attach default 'change' even that delegates to palette
|
||||||
this.attach('change', function(value) {
|
this.attach('change', function(value) {
|
||||||
if (!this._dontFire)
|
if (!this._dontFire)
|
||||||
this._palette.fire('change', this, this.name, value);
|
this._palette.fire('change', this, this._name, value);
|
||||||
});
|
});
|
||||||
this._element = DomElement.create('tr', [
|
this._element = DomElement.create('tr',
|
||||||
'td', [this._label = DomElement.create('label', { 'for': id })],
|
{ class: 'palettejs-row', id: 'palettejs-row-' + name }, [
|
||||||
'td', [this._input]
|
this._labelCell = DomElement.create('td',
|
||||||
|
{ class: 'palettejs-label' }),
|
||||||
|
'td', { class: 'palettejs-input' }, [this._input]
|
||||||
]);
|
]);
|
||||||
Base.each(obj, function(value, key) {
|
this._dontFire = true;
|
||||||
this[key] = value;
|
// Now that everything is set up, copy over values fro obj.
|
||||||
}, this);
|
// NOTE: This triggers setters, which is why we set _dontFire = true,
|
||||||
this._defaultValue = this._value;
|
// and why we can only call this after everything else is set up (e.g.
|
||||||
// Start firing change events after we have initalized.
|
// setLabel() requires this._labelCell).
|
||||||
|
Base.set(this, obj);
|
||||||
|
this._defaultValue = this._value; // after Base.set, through #setValue()
|
||||||
|
// Start firing change events after we have initialized.
|
||||||
this._dontFire = false;
|
this._dontFire = false;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -126,14 +130,20 @@ var Component = Base.extend(Callback, /** @lends Component# */{
|
||||||
return this._type;
|
return this._type;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
getName: function() {
|
||||||
|
return this._name;
|
||||||
|
},
|
||||||
|
|
||||||
getLabel: function() {
|
getLabel: function() {
|
||||||
// Prefix wit '__' since _label is already the element.
|
return this._label;
|
||||||
return this.__label;
|
|
||||||
},
|
},
|
||||||
|
|
||||||
setLabel: function(label) {
|
setLabel: function(label) {
|
||||||
this.__label = label;
|
this._label = label;
|
||||||
DomElement.set(this._label, 'text', label + ':');
|
DomElement.set(this._labelNode = this._labelNode
|
||||||
|
|| this._labelCell.appendChild(DomElement.create('label',
|
||||||
|
{ 'for': 'palettejs-input-' + this._name })),
|
||||||
|
'text', label + ':');
|
||||||
},
|
},
|
||||||
|
|
||||||
getOptions: function() {
|
getOptions: function() {
|
||||||
|
@ -154,14 +164,16 @@ var Component = Base.extend(Callback, /** @lends Component# */{
|
||||||
},
|
},
|
||||||
|
|
||||||
setValue: function(value) {
|
setValue: function(value) {
|
||||||
var key = this._meta.value || 'value',
|
var meta = this._meta,
|
||||||
setValue = this._meta.setValue;
|
key = meta.value || 'value',
|
||||||
|
setValue = meta.setValue;
|
||||||
if (setValue)
|
if (setValue)
|
||||||
value = setValue.call(this, value);
|
value = setValue.call(this, value);
|
||||||
|
console.log('setValue', this.name, key, value);
|
||||||
DomElement.set(this._input, key, value);
|
DomElement.set(this._input, key, value);
|
||||||
// Read back and convert from input again, to make sure we're in sync
|
// Read back and convert from input again, to make sure we're in sync
|
||||||
value = DomElement.get(this._input, key);
|
value = DomElement.get(this._input, key);
|
||||||
if (this._meta.number)
|
if (meta.number)
|
||||||
value = parseFloat(value, 10);
|
value = parseFloat(value, 10);
|
||||||
if (this._value !== value) {
|
if (this._value !== value) {
|
||||||
this._value = value;
|
this._value = value;
|
||||||
|
|
|
@ -26,26 +26,27 @@
|
||||||
initialize: function Palette(title, components, values) {
|
initialize: function Palette(title, components, values) {
|
||||||
var parent = DomElement.find('.palettejs-panel')
|
var parent = DomElement.find('.palettejs-panel')
|
||||||
|| DomElement.find('body').appendChild(
|
|| DomElement.find('body').appendChild(
|
||||||
DomElement.create('div', { 'class': 'palettejs-panel' }));
|
DomElement.create('div', { class: 'palettejs-panel' }));
|
||||||
this._element = parent.appendChild(
|
this._element = parent.appendChild(
|
||||||
DomElement.create('table', { 'class': 'palettejs-pane' }));
|
DomElement.create('table', { class: 'palettejs-pane' }));
|
||||||
this._title = title;
|
this._title = title;
|
||||||
if (!values)
|
if (!values)
|
||||||
values = {};
|
values = {};
|
||||||
for (var name in (this.components = components)) {
|
for (var name in (this.components = components)) {
|
||||||
var component = components[name];
|
var component = components[name];
|
||||||
if (!(component instanceof Component)) {
|
if (!(component instanceof Component)) {
|
||||||
if (component.value == null)
|
component = components[name] = new Component(
|
||||||
component.value = values[name];
|
new Base(component, {
|
||||||
component.name = name;
|
value: Base.pick(component.value, values[name]),
|
||||||
component = components[name] = new Component(component);
|
name: name
|
||||||
|
}));
|
||||||
}
|
}
|
||||||
this._element.appendChild(component._element);
|
this._element.appendChild(component._element);
|
||||||
component._palette = this;
|
component._palette = this;
|
||||||
// Make sure each component has an entry in values, so observers get
|
// Make sure each component has an entry in values, so observers get
|
||||||
// installed further down.
|
// installed further down.
|
||||||
if (values[name] === undefined)
|
if (values[name] === undefined)
|
||||||
values[name] = component.value;
|
values[name] = component._value;
|
||||||
}
|
}
|
||||||
// Now replace each entry in values with a getter / setters so we can
|
// Now replace each entry in values with a getter / setters so we can
|
||||||
// directly link the value to the component and observe change.
|
// directly link the value to the component and observe change.
|
||||||
|
|
Loading…
Reference in a new issue