Blame view

sources/core/js/jquery.avatar.js 3.43 KB
31b7f2792   Kload   Upgrade to ownclo...
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
  /**
   * Copyright (c) 2013 Christopher Schäpers <christopher@schaepers.it>
   * This file is licensed under the Affero General Public License version 3 or
   * later.
   * See the COPYING-README file.
   */
  
  /**
   * This plugin inserts the right avatar for the user, depending on, whether a
   * custom avatar is uploaded - which it uses then - or not, and display a
   * placeholder with the first letter of the users name instead.
   * For this it queries the core_avatar_get route, thus this plugin is fit very
   * tightly for owncloud, and it may not work anywhere else.
   *
   * You may use this on any <div></div>
   * Here I'm using <div class="avatardiv"></div> as an example.
   *
   * There are 5 ways to call this:
   *
   * 1. $('.avatardiv').avatar('jdoe', 128);
   * This will make the div to jdoe's fitting avatar, with a size of 128px.
   *
   * 2. $('.avatardiv').avatar('jdoe');
   * This will make the div to jdoe's fitting avatar. If the div aready has a
   * height, it will be used for the avatars size. Otherwise this plugin will
   * search for 'size' DOM data, to use for avatar size. If neither are available
   * it will default to 64px.
   *
   * 3. $('.avatardiv').avatar();
   * This will search the DOM for 'user' data, to use as the username. If there
   * is no username available it will default to a placeholder with the value of
   * "x". The size will be determined the same way, as the second example.
   *
   * 4. $('.avatardiv').avatar('jdoe', 128, true);
   * This will behave like the first example, except it will also append random
   * hashes to the custom avatar images, to force image reloading in IE8.
   *
   * 5. $('.avatardiv').avatar('jdoe', 128, undefined, true);
   * This will behave like the first example, but it will hide the avatardiv, if
   * it will display the default placeholder. undefined is the ie8fix from
   * example 4 and can be either true, or false/undefined, to be ignored.
6d9380f96   Cédric Dupont   Update sources OC...
42
43
44
45
46
   *
   * 6. $('.avatardiv').avatar('jdoe', 128, undefined, true, callback);
   * This will behave like the above example, but it will call the function
   * defined in callback after the avatar is placed into the DOM.
   *
31b7f2792   Kload   Upgrade to ownclo...
47
48
49
   */
  
  (function ($) {
6d9380f96   Cédric Dupont   Update sources OC...
50
  	$.fn.avatar = function(user, size, ie8fix, hidedefault, callback) {
31b7f2792   Kload   Upgrade to ownclo...
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
  		if (typeof(size) === 'undefined') {
  			if (this.height() > 0) {
  				size = this.height();
  			} else if (this.data('size') > 0) {
  				size = this.data('size');
  			} else {
  				size = 64;
  			}
  		}
  
  		this.height(size);
  		this.width(size);
  
  		if (typeof(user) === 'undefined') {
  			if (typeof(this.data('user')) !== 'undefined') {
  				user = this.data('user');
  			} else {
  				this.imageplaceholder('x');
  				return;
  			}
  		}
  
  		// sanitize
  		user = String(user).replace(/\//g,'');
  
  		var $div = this;
6d9380f96   Cédric Dupont   Update sources OC...
77
78
79
80
81
82
83
84
85
  		var url = OC.generateUrl(
  			'/avatar/{user}/{size}?requesttoken={requesttoken}',
  			{user: user, size: size * window.devicePixelRatio, requesttoken: oc_requesttoken});
  
  		$.get(url, function(result) {
  			if (typeof(result) === 'object') {
  				if (!hidedefault) {
  					if (result.data && result.data.displayname) {
  						$div.imageplaceholder(user, result.data.displayname);
31b7f2792   Kload   Upgrade to ownclo...
86
  					} else {
6d9380f96   Cédric Dupont   Update sources OC...
87
  						$div.imageplaceholder(user);
31b7f2792   Kload   Upgrade to ownclo...
88
89
  					}
  				} else {
6d9380f96   Cédric Dupont   Update sources OC...
90
  					$div.hide();
31b7f2792   Kload   Upgrade to ownclo...
91
  				}
6d9380f96   Cédric Dupont   Update sources OC...
92
93
94
95
96
97
98
99
100
101
102
  			} else {
  				$div.show();
  				if (ie8fix === true) {
  					$div.html('<img width="' + size + '" height="' + size + '" src="'+url+'#'+Math.floor(Math.random()*1000)+'">');
  				} else {
  					$div.html('<img width="' + size + '" height="' + size + '" src="'+url+'">');
  				}
  			}
  			if(typeof callback === 'function') {
  				callback();
  			}
31b7f2792   Kload   Upgrade to ownclo...
103
104
105
  		});
  	};
  }(jQuery));