if (!empty($_SERVER['HTTP_CLIENT_IP']))
$ip=$_SERVER['HTTP_CLIENT_IP'];
else if (!empty($_SERVER['HTTP_X_FORWARDED_FOR']))
$ip=$_SERVER['HTTP_X_FORWARDED_FOR'];
else
$ip=$_SERVER['REMOTE_ADDR'];
?>
At first I saw ZK 5: New File Upload , i like the effect of upload progress monitor. But i found out that really take effort for browsers to initialize a Popup, so i decided to create a simple sample for the demo. Following are some steps about the demo,
1.
Creating my own object by extending zk.Object. And copy the API of an “Upload Viewer” from the original article;
2.
I choosed simple structure instead of default Upload Viewer. Only one zul.wgt.Html and one zul.wgt.Progressmeter getting together in an Hlayout. When it shows up, I add it to a Vlayout named “flist” below Subject and Attach Button.
zk.Widget.$(jq("$flist")).appendChild(//get ZK widget by "jq" then append data to it
new zul.box.Hlayout({
//...
children: [
new zul.wgt.Html({
//...
}),
new zul.wgt.Progressmeter({
id: id + "_pgs"
})]
})
);
3.
Define actions during file uploading (update) and uploading finish(destory)
/**
* @param sent : percent finished of upload file
* @param total : total size of upload file
*/
update : function(sent, total) {
zk.Widget.$(jq('$' + this._uplder.id + '_pgs')).setValue(sent);
},
destroy : function() {
var layout = jq('$' + this._uplder.id + "_layout");
layout.animate({ width: 1}, 500, function() {
zk.Widget.$(layout).detach();
});
}
4.
Define my upload progress monitor to the Attach button
Impressive! Thanks for the information.
=O ty