summaryrefslogtreecommitdiffstats
path: root/core/js
diff options
context:
space:
mode:
authorJan-Christoph Borchardt <hey@jancborchardt.net>2016-04-03 12:26:22 +0200
committerJan-Christoph Borchardt <hey@jancborchardt.net>2016-04-03 12:26:22 +0200
commita0e2eae7de06ce31026ab0fbca9e86f8938bcd44 (patch)
tree76b6a7494e5c0e85d30b6a88ccbea6efffca3bde /core/js
parentdeca08a6833646028e995df7e090edb025d2bc13 (diff)
parentdcc28a3ad7168b68f337f002e953ba05e4053498 (diff)
downloadnextcloud-server-a0e2eae7de06ce31026ab0fbca9e86f8938bcd44.tar.gz
nextcloud-server-a0e2eae7de06ce31026ab0fbca9e86f8938bcd44.zip
Merge pull request #23638 from owncloud/new-placeholder-colours-generator
New colour generator
Diffstat (limited to 'core/js')
-rw-r--r--core/js/placeholder.js62
1 files changed, 56 insertions, 6 deletions
diff --git a/core/js/placeholder.js b/core/js/placeholder.js
index 5fb5b5b8f80..8eb17b43fa4 100644
--- a/core/js/placeholder.js
+++ b/core/js/placeholder.js
@@ -1,6 +1,8 @@
/**
* ownCloud
*
+ * @author John Molakvoæ
+ * @copyright 2016 John Molakvoæ <fremulon@protonmail.com>
* @author Morris Jobke
* @copyright 2013 Morris Jobke <morris.jobke@gmail.com>
*
@@ -48,16 +50,64 @@
(function ($) {
$.fn.imageplaceholder = function(seed, text, size) {
- // set optional argument "text" to value of "seed" if undefined
text = text || seed;
- var hash = md5(seed).substring(0, 4),
- maxRange = parseInt('ffff', 16),
- hue = parseInt(hash, 16) / maxRange * 256,
- height = this.height() || size || 32;
- this.css('background-color', 'hsl(' + hue + ', 90%, 65%)');
+ var hash = seed.toLowerCase().replace(/[^0-9a-f]+/g, '');
+
+ // Already a md5 hash?
+ if( !hash.match(/^[0-9a-f]{32}$/g) ) {
+ hash = md5(hash);
+ }
+
+ function rgbToHsl(r, g, b) {
+ r /= 255, g /= 255, b /= 255;
+ var max = Math.max(r, g, b), min = Math.min(r, g, b);
+ var h, s, l = (max + min) / 2;
+ if(max === min) {
+ h = s = 0; // achromatic
+ } else {
+ var d = max - min;
+ s = l > 0.5 ? d / (2 - max - min) : d / (max + min);
+ switch(max) {
+ case r: h = (g - b) / d + (g < b ? 6 : 0); break;
+ case g: h = (b - r) / d + 2; break;
+ case b: h = (r - g) / d + 4; break;
+ }
+ h /= 6;
+ }
+ return [h, s, l];
+ }
+
+ // Init vars
+ var result = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0];
+ var rgb = [0, 0, 0];
+ var sat = 80;
+ var lum = 68;
+ var modulo = 16;
+
+ // Splitting evenly the string
+ for(var i in hash) {
+ result[i%modulo] = result[i%modulo] + parseInt(hash.charAt(i), 16).toString();
+ }
+
+ // Converting our data into a usable rgb format
+ // Start at 1 because 16%3=1 but 15%3=0 and makes the repartition even
+ for(var count=1;count<modulo;count++) {
+ rgb[count%3] += parseInt(result[count]);
+ }
+ var hsl = rgbToHsl(rgb[0], rgb[1], rgb[2]);
+
+ // Classic formulla to check the brigtness for our eye
+ // If too bright, lower the sat
+ var bright = Math.sqrt( 0.299 * Math.pow(rgb[0], 2) + 0.587 * Math.pow(rgb[1], 2) + 0.114 * Math.pow(rgb[2], 2) );
+ if (bright >= 200) {
+ sat = 60;
+ }
+ var hue = parseInt(hsl[0] * 360);
+ this.css('background-color', 'hsl('+hue+', '+sat+'%, '+lum+'%)');
// Placeholders are square
+ var height = this.height() || size || 32;
this.height(height);
this.width(height);