1
0
mirror of https://github.com/owncloudarchive/contacts.git synced 2024-12-10 21:24:33 +01:00

Contacts: Cache thumbnails as base64 an load together with contacts.

Removes the massive amount of requests on first load.
This commit is contained in:
Thomas Tanghus 2013-04-04 17:00:22 +02:00
parent ed349ccab3
commit 9d313b1a1e
3 changed files with 9 additions and 11 deletions

View File

@ -1367,21 +1367,15 @@ OC.Contacts = OC.Contacts || {};
* Set a thumbnail for the contact if a PHOTO property exists * Set a thumbnail for the contact if a PHOTO property exists
*/ */
Contact.prototype.setThumbnail = function(refresh) { Contact.prototype.setThumbnail = function(refresh) {
if(this.getPreferredValue('PHOTO', null) === null) { if(!this.data.thumbnail) {
return; return;
} }
var $elem = this.getListItemElement().find('td.name'); var $elem = this.getListItemElement().find('td.name');
if(!$elem.hasClass('thumbnail')) { if(!$elem.hasClass('thumbnail') && !refresh) {
return; return;
} }
$elem.removeClass('thumbnail'); $elem.removeClass('thumbnail');
var refreshstr = refresh ? '&refresh='+Math.random() : ''; $elem.css('background-image', 'url(data:image/png;base64,' + this.data.thumbnail + ')');
$elem.css('background-image', 'url(' + OC.filePath('', '', 'remote.php')
+'/contactthumbnail?backend='
+this.metadata.backend+'&parent='
+this.metadata.parent+'&id='
+this.id+refreshstr + ')'
);
} }
/** /**

View File

@ -611,8 +611,8 @@ class Contact extends VObject\VCard implements IPIMObject {
\OCP\Util::ERROR); \OCP\Util::ERROR);
return false; return false;
} }
// Cache for around a month // Cache as base64 for around a month
\OC_Cache::set(self::THUMBNAIL_PREFIX . $key, $image->data(), 3000000); \OC_Cache::set(self::THUMBNAIL_PREFIX . $key, strval($image), 3000); //3000000);
\OCP\Util::writeLog('contacts', 'Caching ' . $key, \OCP\Util::DEBUG); \OCP\Util::writeLog('contacts', 'Caching ' . $key, \OCP\Util::DEBUG);
return \OC_Cache::get(self::THUMBNAIL_PREFIX . $key); return \OC_Cache::get(self::THUMBNAIL_PREFIX . $key);
} }

View File

@ -89,6 +89,10 @@ class JSONSerializer {
$details = array(); $details = array();
if(isset($contact->PHOTO) || isset($contact->LOGO)) {
$details['thumbnail'] = $contact->cacheThumbnail();
}
foreach($contact->children as $property) { foreach($contact->children as $property) {
$pname = $property->name; $pname = $property->name;
$temp = self::serializeProperty($property); $temp = self::serializeProperty($property);