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
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
|
dojo.require("dojo.io.script")
dojo.require("dojox.rpc.Service");
// model that works with Yahoo Search API
dojo.declare("dojox.grid.data.yahooSearch", dojox.grid.data.Dynamic, {
constructor: function(inFields, inData, inSearchNode){
this.rowsPerPage = 20;
this.searchNode = inSearchNode;
this.fieldNames = dojo.map(inFields, "return item.name;");
this.yahoo = new dojox.rpc.Service(
dojo.moduleUrl("dojox.rpc.SMDLibrary", "yahoo.smd")
);
},
// server send / receive
send: function(inAsync, inParams, inOnReceive, inOnError){
var d = this.yahoo.imageSearch(
dojo.mixin({
results: this.rowsPerPage,
query: this.getQuery()
}, inParams)
);
d.addCallbacks(
dojo.hitch(this, "receive", inOnReceive, inOnError),
dojo.hitch(this, "error", inOnError)
);
this.onSend(inParams);
return d;
},
receive: function(inOnReceive, inOnError, inData){
try{
inData = inData.ResultSet;
inOnReceive(inData);
this.onReceive(inData);
}catch(e){
if(inOnError){
inOnError(inData);
}
}
},
error: function(inOnError, inErr) {
var m = 'io error: ' + inErr.message;
alert(m);
if (inOnError)
inOnError(m);
},
encodeParam: function(inName, inValue) {
return dojo.string.substitute('&${0}=${1}', [inName, inValue]);
},
getQuery: function(){
return dojo.byId(this.searchNode).value.replace(/ /g, '+');
},
fetchRowCount: function(inCallback){
this.send(true, inCallback);
},
// request data
requestRows: function(inRowIndex, inCount){
inRowIndex = (inRowIndex == undefined ? 0 : inRowIndex);
var params = {
start: inRowIndex + 1
}
this.send(true, params, dojo.hitch(this, this.processRows));
},
// server callbacks
processRows: function(inData){
for(var i=0, l=inData.totalResultsReturned, s=inData.firstResultPosition; i<l; i++){
this.setRow(inData.Result[i], s - 1 + i);
}
// yahoo says 1000 is max results to return
var c = Math.min(1000, inData.totalResultsAvailable);
if(this.count != c){
this.setRowCount(c);
this.allChange();
this.onInitializeData(inData);
}
},
getDatum: function(inRowIndex, inColIndex){
var row = this.getRow(inRowIndex);
var field = this.fields.get(inColIndex);
return (inColIndex == undefined ? row : (row ? row[field.name] : field.na));
},
// events
onInitializeData: function(){ },
onSend: function(){ },
onReceive: function(){ }
});
// report
modelChange = function(){
var n = dojo.byId('rowCount');
if(n){
n.innerHTML = dojo.string.substitute('about ${0} row(s)', [model.count]);
}
}
// some data formatters
getCellData = function(inCell, inRowIndex, inField){
var m = inCell.grid.model;
return m.getDatum(inRowIndex, inField);
}
formatLink = function(inData, inRowIndex){
if(!inData){ return ' '; }
var text = getCellData(this, inRowIndex, this.extraField);
return dojo.string.substitute(
'<a target="_blank" href="${href}">${text}</a>',
{ href: inData, text: text }
);
};
formatImage = function(inData, inRowIndex){
if(!inData){ return ' '; }
var info = getCellData(this, inRowIndex, this.extraField);
var o = {
href: inData,
src: info.Url,
width: info.Width,
height: info.Height
}
return dojo.string.substitute(
'<a href="${href}" target="_blank"><img border=0 src="${src}" width="${width}" height="${height}"></a>', o);
};
formatDate = function(inDatum, inRowIndex){
if(!inDatum){ return ' '; }
var d = new Date(inDatum * 1000);
return dojo.string.substitute(
"${0}/${1}/${2}",
[ d.getMonth()+1, d.getDate(), d.getFullYear() ]
);
};
formatDimensions = function(inData, inRowIndex){
if(!inData){ return ' '; }
var w = inData, h = getCellData(this, inRowIndex, this.extraField);
return w + ' x ' + h;
}
|