1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
|
if(!dojo._hasResource["dojox.wire.CompositeWire"]){ //_hasResource checks added by build. Do not use _hasResource directly in your code.
dojo._hasResource["dojox.wire.CompositeWire"] = true;
dojo.provide("dojox.wire.CompositeWire");
dojo.require("dojox.wire._base");
dojo.require("dojox.wire.Wire");
dojo.declare("dojox.wire.CompositeWire", dojox.wire.Wire, {
// summary:
// A Wire for composite values in object or array
// description:
// This class has multiple child Wires for object properties or array
// elements.
// When an object with Wires is specified to 'children' property, they
// are used to get or set an object with property values.
// When an array of Wiares is specified to 'children' property, they
// are used to get or set an array with element values.
_wireClass: "dojox.wire.CompositeWire",
constructor: function(/*Object*/args){
// summary:
// Initialize properties
// description:
// If object properties or array elements specified in 'children'
// property are not Wires, Wires are created from them as
// arguments, with 'parent' property set to this Wire instance.
// args:
// Arguments to initialize properties
// children:
// An object or array containing child Wires
this._initializeChildren(this.children);
},
_getValue: function(/*Object||Array*/object){
// summary:
// Return an object with property values or an array with element
// values
// description:
// This method calls getValue() method of the child Wires with
// 'object' argument and returns an object with the values as
// properties or an arary of the values as elements.
// object:
// A root object
// returns:
// An object or array with values
if(!object || !this.children){
return object; //Object||Array
}
var value = (dojo.isArray(this.children) ? [] : {}); // array or object
for(var c in this.children){
value[c] = this.children[c].getValue(object);
}
return value;//Object||Array
},
_setValue: function(/*Object||Array*/object, /*Object||Array*/value){
// summary:
// Set an object properties or an array elements to an object
// desription:
// This method calls setValues() method of the child Wires with
// a corresponding property or element in 'value' argument and
// 'object' argument.
// object:
// A root object
// value:
// An object or array with values to set
// returns:
// 'object'
if(!object || !this.children){
return object; //Object||Array
}
for(var c in this.children){
this.children[c].setValue(value[c], object);
}
return object; //Object||Array
},
_initializeChildren: function(/*Object||Array*/children){
// summary:
// Initialize child Wires
// description:
// If object properties or array elements specified in 'children'
// argument are not Wires, Wires are created from them as
// arguments, with 'parent' property set to this Wire instance.
// children:
// An object or array containing child Wires
if(!children){
return; //undefined
}
for(var c in children){
var child = children[c];
child.parent = this;
if(!dojox.wire.isWire(child)){
children[c] = dojox.wire.create(child);
}
}
}
});
}
|