PathStyle = Base.extend(new function() { var keys = ['windingRule', 'resolution', 'strokeColor', 'strokeWidth', 'strokeCap', 'strokeJoin', 'dashOffset','dashArray', 'miterLimit', 'strokeOverprint', 'fillColor', 'fillOverprint']; var fields = { beans: true, initialize: function(item, style) { this.item = item; if(style) { for (var i = 0, l = keys.length; i < l; i++) { var key = keys[i]; if(style[key]) this[key] = style[key]; } } } } var itemFields = { beans: true }; Base.each(keys, function(key) { fields['set' + key.capitalize()] = function(value) { if(this.item && this.item.children) { for (var i = 0, l = this.item.children.length; i < l; i++) { this.item.children[i].style[key] = value; } } else { this['_' + key] = value; } }; fields['get' + key.capitalize()] = function() { if(this.item && this.item.children) { var style; for (var i = 0, l = this.item.children.length; i < l; i++) { if(!style) { style = this.item.children[i].style[key]; } else if(style != this.item.children[i].style[key]) { // If there is another item with a different style: return null; } } return style; } else { return this['_' + key]; } }; itemFields['set' + key.capitalize()] = function(value) { this.style[key] = value; }; itemFields['get' + key.capitalize()] = function() { return this.style[key]; }; }); Item.inject(itemFields); return fields; });