chef 13.11.3 → 13.12.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile +4 -3
- data/README.md +35 -40
- data/Rakefile +18 -22
- data/chef-universal-mingw32.gemspec +1 -1
- data/chef.gemspec +3 -3
- data/lib/chef/client.rb +1 -1
- data/lib/chef/mixin/params_validate.rb +3 -1
- data/lib/chef/provider/script.rb +2 -2
- data/lib/chef/version.rb +1 -1
- data/spec/functional/http/simple_spec.rb +12 -6
- data/spec/functional/resource/remote_file_spec.rb +19 -15
- data/spec/support/platform_helpers.rb +2 -1
- data/tasks/announce.rb +1 -1
- data/tasks/dependencies.rb +5 -39
- data/tasks/maintainers.rb +10 -10
- data/tasks/rspec.rb +2 -2
- data/tasks/templates/prerelease.md.erb +11 -2
- data/tasks/templates/release.md.erb +9 -1
- metadata +6 -248
- data/CONTRIBUTING.md +0 -151
- data/VERSION +0 -1
- data/acceptance/.gitignore +0 -3
- data/acceptance/.shared/kitchen_acceptance/.kitchen.digitalocean.yml +0 -33
- data/acceptance/.shared/kitchen_acceptance/.kitchen.ec2.yml +0 -283
- data/acceptance/.shared/kitchen_acceptance/.kitchen.vagrant.yml +0 -59
- data/acceptance/.shared/kitchen_acceptance/libraries/kitchen.rb +0 -68
- data/acceptance/.shared/kitchen_acceptance/metadata.rb +0 -1
- data/acceptance/Gemfile +0 -19
- data/acceptance/Gemfile.lock +0 -266
- data/acceptance/README.md +0 -137
- data/acceptance/basics/.acceptance/acceptance-cookbook/.gitignore +0 -2
- data/acceptance/basics/.acceptance/acceptance-cookbook/metadata.rb +0 -3
- data/acceptance/basics/.acceptance/acceptance-cookbook/recipes/destroy.rb +0 -1
- data/acceptance/basics/.acceptance/acceptance-cookbook/recipes/provision.rb +0 -1
- data/acceptance/basics/.acceptance/acceptance-cookbook/recipes/verify.rb +0 -1
- data/acceptance/basics/.kitchen.yml +0 -4
- data/acceptance/basics/test/integration/chef-current-install/serverspec/chef_client_spec.rb +0 -19
- data/acceptance/basics/test/integration/chef-current-install/serverspec/spec_helper.rb +0 -6
- data/acceptance/basics/test/integration/helpers/serverspec/Gemfile +0 -8
- data/acceptance/data-collector/.acceptance/acceptance-cookbook/.gitignore +0 -2
- data/acceptance/data-collector/.acceptance/acceptance-cookbook/metadata.rb +0 -3
- data/acceptance/data-collector/.acceptance/acceptance-cookbook/recipes/destroy.rb +0 -2
- data/acceptance/data-collector/.acceptance/acceptance-cookbook/recipes/provision.rb +0 -2
- data/acceptance/data-collector/.acceptance/acceptance-cookbook/recipes/verify.rb +0 -2
- data/acceptance/data-collector/.acceptance/data-collector-test/.gitignore +0 -16
- data/acceptance/data-collector/.acceptance/data-collector-test/Berksfile +0 -3
- data/acceptance/data-collector/.acceptance/data-collector-test/files/default/api.rb +0 -101
- data/acceptance/data-collector/.acceptance/data-collector-test/files/default/apigemfile +0 -3
- data/acceptance/data-collector/.acceptance/data-collector-test/files/default/client-rb-both-mode.rb +0 -4
- data/acceptance/data-collector/.acceptance/data-collector-test/files/default/client-rb-client-mode.rb +0 -4
- data/acceptance/data-collector/.acceptance/data-collector-test/files/default/client-rb-no-endpoint.rb +0 -2
- data/acceptance/data-collector/.acceptance/data-collector-test/files/default/client-rb-solo-mode.rb +0 -4
- data/acceptance/data-collector/.acceptance/data-collector-test/files/default/config.ru +0 -2
- data/acceptance/data-collector/.acceptance/data-collector-test/metadata.rb +0 -7
- data/acceptance/data-collector/.acceptance/data-collector-test/recipes/default.rb +0 -44
- data/acceptance/data-collector/.kitchen.yml +0 -9
- data/acceptance/data-collector/Berksfile +0 -3
- data/acceptance/data-collector/test/integration/default/serverspec/default_spec.rb +0 -208
- data/acceptance/data-collector/test/integration/helpers/serverspec/Gemfile +0 -8
- data/acceptance/omnitruck/.acceptance/acceptance-cookbook/.gitignore +0 -2
- data/acceptance/omnitruck/.acceptance/acceptance-cookbook/metadata.rb +0 -1
- data/acceptance/omnitruck/.acceptance/acceptance-cookbook/recipes/destroy.rb +0 -1
- data/acceptance/omnitruck/.acceptance/acceptance-cookbook/recipes/provision.rb +0 -1
- data/acceptance/omnitruck/.acceptance/acceptance-cookbook/recipes/verify.rb +0 -61
- data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/.gitignore +0 -2
- data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/libraries/cookbook_kitchen.rb +0 -43
- data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/libraries/top_cookbooks.rb +0 -41
- data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/metadata.rb +0 -3
- data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/recipes/destroy.rb +0 -1
- data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/recipes/provision.rb +0 -1
- data/acceptance/top-cookbooks/.acceptance/acceptance-cookbook/recipes/verify.rb +0 -1
- data/acceptance/top-cookbooks/.gitignore +0 -1
- data/acceptance/top-cookbooks/.kitchen.chocolatey.yml +0 -6
- data/acceptance/top-cookbooks/.kitchen.iis.yml +0 -4
- data/acceptance/top-cookbooks/.kitchen.learn-the-basics-rhel.yml +0 -7
- data/acceptance/top-cookbooks/.kitchen.learn-the-basics-ubuntu.yml +0 -7
- data/acceptance/top-cookbooks/.kitchen.learn-the-basics-windows.yml +0 -7
- data/acceptance/top-cookbooks/.kitchen.powershell.yml +0 -4
- data/acceptance/top-cookbooks/.kitchen.sql_server.yml +0 -5
- data/acceptance/top-cookbooks/.kitchen.winbox.yml +0 -8
- data/acceptance/top-cookbooks/.kitchen.windows.yml +0 -38
- data/acceptance/trivial/.acceptance/acceptance-cookbook/.gitignore +0 -2
- data/acceptance/trivial/.acceptance/acceptance-cookbook/metadata.rb +0 -2
- data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/destroy.rb +0 -1
- data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/provision.rb +0 -1
- data/acceptance/trivial/.acceptance/acceptance-cookbook/recipes/verify.rb +0 -1
- data/acceptance/trivial/.kitchen.yml +0 -7
- data/acceptance/trivial/test/integration/chef-current-install/inspec/chef_client_spec.rb +0 -5
- data/acceptance/windows-service/.acceptance/acceptance-cookbook/.gitignore +0 -2
- data/acceptance/windows-service/.acceptance/acceptance-cookbook/metadata.rb +0 -2
- data/acceptance/windows-service/.acceptance/acceptance-cookbook/recipes/destroy.rb +0 -1
- data/acceptance/windows-service/.acceptance/acceptance-cookbook/recipes/provision.rb +0 -1
- data/acceptance/windows-service/.acceptance/acceptance-cookbook/recipes/verify.rb +0 -1
- data/acceptance/windows-service/.kitchen.yml +0 -7
- data/acceptance/windows-service/test/integration/chef-windows-service/inspec/chef_windows_service_spec.rb +0 -58
- data/distro/common/html/_sources/ctl_chef_client.txt +0 -36
- data/distro/common/html/_sources/ctl_chef_server.txt +0 -341
- data/distro/common/html/_sources/ctl_chef_shell.txt +0 -15
- data/distro/common/html/_sources/ctl_chef_solo.txt +0 -25
- data/distro/common/html/_sources/index.txt +0 -135
- data/distro/common/html/_sources/knife.txt +0 -74
- data/distro/common/html/_sources/knife_bootstrap.txt +0 -56
- data/distro/common/html/_sources/knife_client.txt +0 -151
- data/distro/common/html/_sources/knife_common_options.txt +0 -6
- data/distro/common/html/_sources/knife_configure.txt +0 -29
- data/distro/common/html/_sources/knife_cookbook.txt +0 -236
- data/distro/common/html/_sources/knife_cookbook_site.txt +0 -157
- data/distro/common/html/_sources/knife_data_bag.txt +0 -160
- data/distro/common/html/_sources/knife_delete.txt +0 -26
- data/distro/common/html/_sources/knife_deps.txt +0 -61
- data/distro/common/html/_sources/knife_diff.txt +0 -34
- data/distro/common/html/_sources/knife_download.txt +0 -44
- data/distro/common/html/_sources/knife_edit.txt +0 -26
- data/distro/common/html/_sources/knife_environment.txt +0 -158
- data/distro/common/html/_sources/knife_exec.txt +0 -47
- data/distro/common/html/_sources/knife_index_rebuild.txt +0 -21
- data/distro/common/html/_sources/knife_list.txt +0 -33
- data/distro/common/html/_sources/knife_node.txt +0 -250
- data/distro/common/html/_sources/knife_raw.txt +0 -35
- data/distro/common/html/_sources/knife_recipe_list.txt +0 -23
- data/distro/common/html/_sources/knife_role.txt +0 -157
- data/distro/common/html/_sources/knife_search.txt +0 -53
- data/distro/common/html/_sources/knife_serve.txt +0 -19
- data/distro/common/html/_sources/knife_show.txt +0 -27
- data/distro/common/html/_sources/knife_ssh.txt +0 -43
- data/distro/common/html/_sources/knife_ssl_check.txt +0 -41
- data/distro/common/html/_sources/knife_ssl_fetch.txt +0 -41
- data/distro/common/html/_sources/knife_status.txt +0 -37
- data/distro/common/html/_sources/knife_tag.txt +0 -69
- data/distro/common/html/_sources/knife_upload.txt +0 -49
- data/distro/common/html/_sources/knife_user.txt +0 -127
- data/distro/common/html/_sources/knife_using.txt +0 -43
- data/distro/common/html/_sources/knife_xargs.txt +0 -30
- data/distro/common/html/_static/ajax-loader.gif +0 -0
- data/distro/common/html/_static/basic.css +0 -537
- data/distro/common/html/_static/chef.ico +0 -0
- data/distro/common/html/_static/chef_html_logo.png +0 -0
- data/distro/common/html/_static/comment-bright.png +0 -0
- data/distro/common/html/_static/comment-close.png +0 -0
- data/distro/common/html/_static/comment.png +0 -0
- data/distro/common/html/_static/contents.png +0 -0
- data/distro/common/html/_static/doctools.js +0 -238
- data/distro/common/html/_static/down-pressed.png +0 -0
- data/distro/common/html/_static/down.png +0 -0
- data/distro/common/html/_static/file.png +0 -0
- data/distro/common/html/_static/guide.css +0 -505
- data/distro/common/html/_static/jquery.js +0 -2
- data/distro/common/html/_static/minus.png +0 -0
- data/distro/common/html/_static/navigation.png +0 -0
- data/distro/common/html/_static/plus.png +0 -0
- data/distro/common/html/_static/pygments.css +0 -62
- data/distro/common/html/_static/searchtools.js +0 -622
- data/distro/common/html/_static/underscore.js +0 -31
- data/distro/common/html/_static/up-pressed.png +0 -0
- data/distro/common/html/_static/up.png +0 -0
- data/distro/common/html/_static/websupport.js +0 -808
- data/distro/common/html/ctl_chef_client.html +0 -270
- data/distro/common/html/ctl_chef_server.html +0 -728
- data/distro/common/html/ctl_chef_shell.html +0 -163
- data/distro/common/html/ctl_chef_solo.html +0 -194
- data/distro/common/html/index.html +0 -202
- data/distro/common/html/knife.html +0 -170
- data/distro/common/html/knife_bootstrap.html +0 -285
- data/distro/common/html/knife_client.html +0 -285
- data/distro/common/html/knife_common_options.html +0 -96
- data/distro/common/html/knife_configure.html +0 -105
- data/distro/common/html/knife_cookbook.html +0 -487
- data/distro/common/html/knife_cookbook_site.html +0 -375
- data/distro/common/html/knife_data_bag.html +0 -374
- data/distro/common/html/knife_delete.html +0 -93
- data/distro/common/html/knife_deps.html +0 -143
- data/distro/common/html/knife_diff.html +0 -123
- data/distro/common/html/knife_download.html +0 -145
- data/distro/common/html/knife_edit.html +0 -89
- data/distro/common/html/knife_environment.html +0 -322
- data/distro/common/html/knife_exec.html +0 -220
- data/distro/common/html/knife_index_rebuild.html +0 -83
- data/distro/common/html/knife_list.html +0 -114
- data/distro/common/html/knife_node.html +0 -458
- data/distro/common/html/knife_raw.html +0 -110
- data/distro/common/html/knife_recipe_list.html +0 -91
- data/distro/common/html/knife_role.html +0 -295
- data/distro/common/html/knife_search.html +0 -203
- data/distro/common/html/knife_serve.html +0 -79
- data/distro/common/html/knife_show.html +0 -104
- data/distro/common/html/knife_ssh.html +0 -177
- data/distro/common/html/knife_ssl_check.html +0 -151
- data/distro/common/html/knife_ssl_fetch.html +0 -151
- data/distro/common/html/knife_status.html +0 -144
- data/distro/common/html/knife_tag.html +0 -138
- data/distro/common/html/knife_upload.html +0 -153
- data/distro/common/html/knife_user.html +0 -242
- data/distro/common/html/knife_using.html +0 -210
- data/distro/common/html/knife_xargs.html +0 -122
- data/distro/common/html/objects.inv +0 -0
- data/distro/common/html/search.html +0 -82
- data/distro/common/html/searchindex.js +0 -1
- data/distro/common/man/man1/README.md +0 -58
- data/distro/common/man/man1/chef-shell.1 +0 -194
- data/distro/common/man/man1/knife-bootstrap.1 +0 -215
- data/distro/common/man/man1/knife-client.1 +0 -443
- data/distro/common/man/man1/knife-configure.1 +0 -161
- data/distro/common/man/man1/knife-cookbook-site.1 +0 -552
- data/distro/common/man/man1/knife-cookbook.1 +0 -770
- data/distro/common/man/man1/knife-data-bag.1 +0 -617
- data/distro/common/man/man1/knife-delete.1 +0 -127
- data/distro/common/man/man1/knife-deps.1 +0 -246
- data/distro/common/man/man1/knife-diff.1 +0 -226
- data/distro/common/man/man1/knife-download.1 +0 -258
- data/distro/common/man/man1/knife-edit.1 +0 -121
- data/distro/common/man/man1/knife-environment.1 +0 -496
- data/distro/common/man/man1/knife-exec.1 +0 -362
- data/distro/common/man/man1/knife-index-rebuild.1 +0 -63
- data/distro/common/man/man1/knife-list.1 +0 -174
- data/distro/common/man/man1/knife-node.1 +0 -716
- data/distro/common/man/man1/knife-raw.1 +0 -172
- data/distro/common/man/man1/knife-recipe-list.1 +0 -85
- data/distro/common/man/man1/knife-role.1 +0 -426
- data/distro/common/man/man1/knife-search.1 +0 -359
- data/distro/common/man/man1/knife-serve.1 +0 -109
- data/distro/common/man/man1/knife-show.1 +0 -160
- data/distro/common/man/man1/knife-ssh.1 +0 -284
- data/distro/common/man/man1/knife-ssl-check.1 +0 -207
- data/distro/common/man/man1/knife-ssl-fetch.1 +0 -207
- data/distro/common/man/man1/knife-status.1 +0 -234
- data/distro/common/man/man1/knife-tag.1 +0 -189
- data/distro/common/man/man1/knife-upload.1 +0 -280
- data/distro/common/man/man1/knife-user.1 +0 -356
- data/distro/common/man/man1/knife-xargs.1 +0 -189
- data/distro/common/man/man1/knife.1 +0 -332
- data/distro/common/man/man8/chef-apply.8 +0 -86
- data/distro/common/man/man8/chef-client.8 +0 -398
- data/distro/common/man/man8/chef-solo.8 +0 -260
- data/distro/common/markdown/README +0 -3
- data/distro/common/markdown/man1/chef-shell.mkd +0 -195
- data/distro/common/markdown/man1/knife-bootstrap.mkd +0 -141
- data/distro/common/markdown/man1/knife-client.mkd +0 -103
- data/distro/common/markdown/man1/knife-configure.mkd +0 -71
- data/distro/common/markdown/man1/knife-cookbook-site.mkd +0 -123
- data/distro/common/markdown/man1/knife-cookbook.mkd +0 -263
- data/distro/common/markdown/man1/knife-data-bag.mkd +0 -121
- data/distro/common/markdown/man1/knife-environment.mkd +0 -151
- data/distro/common/markdown/man1/knife-exec.mkd +0 -42
- data/distro/common/markdown/man1/knife-index.mkd +0 -30
- data/distro/common/markdown/man1/knife-node.mkd +0 -130
- data/distro/common/markdown/man1/knife-role.mkd +0 -85
- data/distro/common/markdown/man1/knife-search.mkd +0 -180
- data/distro/common/markdown/man1/knife-ssh.mkd +0 -69
- data/distro/common/markdown/man1/knife-status.mkd +0 -36
- data/distro/common/markdown/man1/knife-tag.mkd +0 -39
- data/distro/common/markdown/man1/knife.mkd +0 -213
- data/distro/common/markdown/man8/chef-client.mkd +0 -75
- data/distro/common/markdown/man8/chef-expander.mkd +0 -81
- data/distro/common/markdown/man8/chef-expanderctl.mkd +0 -57
- data/distro/common/markdown/man8/chef-server-webui.mkd +0 -121
- data/distro/common/markdown/man8/chef-server.mkd +0 -120
- data/distro/common/markdown/man8/chef-solo.mkd +0 -107
- data/distro/common/markdown/man8/chef-solr.mkd +0 -89
- data/distro/powershell/chef/chef.psm1 +0 -459
- data/tasks/cbgb.rb +0 -84
@@ -1,31 +0,0 @@
|
|
1
|
-
// Underscore.js 1.3.1
|
2
|
-
// (c) 2009-2012 Jeremy Ashkenas, DocumentCloud Inc.
|
3
|
-
// Underscore is freely distributable under the MIT license.
|
4
|
-
// Portions of Underscore are inspired or borrowed from Prototype,
|
5
|
-
// Oliver Steele's Functional, and John Resig's Micro-Templating.
|
6
|
-
// For all details and documentation:
|
7
|
-
// http://documentcloud.github.com/underscore
|
8
|
-
(function(){function q(a,c,d){if(a===c)return a!==0||1/a==1/c;if(a==null||c==null)return a===c;if(a._chain)a=a._wrapped;if(c._chain)c=c._wrapped;if(a.isEqual&&b.isFunction(a.isEqual))return a.isEqual(c);if(c.isEqual&&b.isFunction(c.isEqual))return c.isEqual(a);var e=l.call(a);if(e!=l.call(c))return false;switch(e){case "[object String]":return a==String(c);case "[object Number]":return a!=+a?c!=+c:a==0?1/a==1/c:a==+c;case "[object Date]":case "[object Boolean]":return+a==+c;case "[object RegExp]":return a.source==
|
9
|
-
c.source&&a.global==c.global&&a.multiline==c.multiline&&a.ignoreCase==c.ignoreCase}if(typeof a!="object"||typeof c!="object")return false;for(var f=d.length;f--;)if(d[f]==a)return true;d.push(a);var f=0,g=true;if(e=="[object Array]"){if(f=a.length,g=f==c.length)for(;f--;)if(!(g=f in a==f in c&&q(a[f],c[f],d)))break}else{if("constructor"in a!="constructor"in c||a.constructor!=c.constructor)return false;for(var h in a)if(b.has(a,h)&&(f++,!(g=b.has(c,h)&&q(a[h],c[h],d))))break;if(g){for(h in c)if(b.has(c,
|
10
|
-
h)&&!f--)break;g=!f}}d.pop();return g}var r=this,G=r._,n={},k=Array.prototype,o=Object.prototype,i=k.slice,H=k.unshift,l=o.toString,I=o.hasOwnProperty,w=k.forEach,x=k.map,y=k.reduce,z=k.reduceRight,A=k.filter,B=k.every,C=k.some,p=k.indexOf,D=k.lastIndexOf,o=Array.isArray,J=Object.keys,s=Function.prototype.bind,b=function(a){return new m(a)};if(typeof exports!=="undefined"){if(typeof module!=="undefined"&&module.exports)exports=module.exports=b;exports._=b}else r._=b;b.VERSION="1.3.1";var j=b.each=
|
11
|
-
b.forEach=function(a,c,d){if(a!=null)if(w&&a.forEach===w)a.forEach(c,d);else if(a.length===+a.length)for(var e=0,f=a.length;e<f;e++){if(e in a&&c.call(d,a[e],e,a)===n)break}else for(e in a)if(b.has(a,e)&&c.call(d,a[e],e,a)===n)break};b.map=b.collect=function(a,c,b){var e=[];if(a==null)return e;if(x&&a.map===x)return a.map(c,b);j(a,function(a,g,h){e[e.length]=c.call(b,a,g,h)});if(a.length===+a.length)e.length=a.length;return e};b.reduce=b.foldl=b.inject=function(a,c,d,e){var f=arguments.length>2;a==
|
12
|
-
null&&(a=[]);if(y&&a.reduce===y)return e&&(c=b.bind(c,e)),f?a.reduce(c,d):a.reduce(c);j(a,function(a,b,i){f?d=c.call(e,d,a,b,i):(d=a,f=true)});if(!f)throw new TypeError("Reduce of empty array with no initial value");return d};b.reduceRight=b.foldr=function(a,c,d,e){var f=arguments.length>2;a==null&&(a=[]);if(z&&a.reduceRight===z)return e&&(c=b.bind(c,e)),f?a.reduceRight(c,d):a.reduceRight(c);var g=b.toArray(a).reverse();e&&!f&&(c=b.bind(c,e));return f?b.reduce(g,c,d,e):b.reduce(g,c)};b.find=b.detect=
|
13
|
-
function(a,c,b){var e;E(a,function(a,g,h){if(c.call(b,a,g,h))return e=a,true});return e};b.filter=b.select=function(a,c,b){var e=[];if(a==null)return e;if(A&&a.filter===A)return a.filter(c,b);j(a,function(a,g,h){c.call(b,a,g,h)&&(e[e.length]=a)});return e};b.reject=function(a,c,b){var e=[];if(a==null)return e;j(a,function(a,g,h){c.call(b,a,g,h)||(e[e.length]=a)});return e};b.every=b.all=function(a,c,b){var e=true;if(a==null)return e;if(B&&a.every===B)return a.every(c,b);j(a,function(a,g,h){if(!(e=
|
14
|
-
e&&c.call(b,a,g,h)))return n});return e};var E=b.some=b.any=function(a,c,d){c||(c=b.identity);var e=false;if(a==null)return e;if(C&&a.some===C)return a.some(c,d);j(a,function(a,b,h){if(e||(e=c.call(d,a,b,h)))return n});return!!e};b.include=b.contains=function(a,c){var b=false;if(a==null)return b;return p&&a.indexOf===p?a.indexOf(c)!=-1:b=E(a,function(a){return a===c})};b.invoke=function(a,c){var d=i.call(arguments,2);return b.map(a,function(a){return(b.isFunction(c)?c||a:a[c]).apply(a,d)})};b.pluck=
|
15
|
-
function(a,c){return b.map(a,function(a){return a[c]})};b.max=function(a,c,d){if(!c&&b.isArray(a))return Math.max.apply(Math,a);if(!c&&b.isEmpty(a))return-Infinity;var e={computed:-Infinity};j(a,function(a,b,h){b=c?c.call(d,a,b,h):a;b>=e.computed&&(e={value:a,computed:b})});return e.value};b.min=function(a,c,d){if(!c&&b.isArray(a))return Math.min.apply(Math,a);if(!c&&b.isEmpty(a))return Infinity;var e={computed:Infinity};j(a,function(a,b,h){b=c?c.call(d,a,b,h):a;b<e.computed&&(e={value:a,computed:b})});
|
16
|
-
return e.value};b.shuffle=function(a){var b=[],d;j(a,function(a,f){f==0?b[0]=a:(d=Math.floor(Math.random()*(f+1)),b[f]=b[d],b[d]=a)});return b};b.sortBy=function(a,c,d){return b.pluck(b.map(a,function(a,b,g){return{value:a,criteria:c.call(d,a,b,g)}}).sort(function(a,b){var c=a.criteria,d=b.criteria;return c<d?-1:c>d?1:0}),"value")};b.groupBy=function(a,c){var d={},e=b.isFunction(c)?c:function(a){return a[c]};j(a,function(a,b){var c=e(a,b);(d[c]||(d[c]=[])).push(a)});return d};b.sortedIndex=function(a,
|
17
|
-
c,d){d||(d=b.identity);for(var e=0,f=a.length;e<f;){var g=e+f>>1;d(a[g])<d(c)?e=g+1:f=g}return e};b.toArray=function(a){return!a?[]:a.toArray?a.toArray():b.isArray(a)?i.call(a):b.isArguments(a)?i.call(a):b.values(a)};b.size=function(a){return b.toArray(a).length};b.first=b.head=function(a,b,d){return b!=null&&!d?i.call(a,0,b):a[0]};b.initial=function(a,b,d){return i.call(a,0,a.length-(b==null||d?1:b))};b.last=function(a,b,d){return b!=null&&!d?i.call(a,Math.max(a.length-b,0)):a[a.length-1]};b.rest=
|
18
|
-
b.tail=function(a,b,d){return i.call(a,b==null||d?1:b)};b.compact=function(a){return b.filter(a,function(a){return!!a})};b.flatten=function(a,c){return b.reduce(a,function(a,e){if(b.isArray(e))return a.concat(c?e:b.flatten(e));a[a.length]=e;return a},[])};b.without=function(a){return b.difference(a,i.call(arguments,1))};b.uniq=b.unique=function(a,c,d){var d=d?b.map(a,d):a,e=[];b.reduce(d,function(d,g,h){if(0==h||(c===true?b.last(d)!=g:!b.include(d,g)))d[d.length]=g,e[e.length]=a[h];return d},[]);
|
19
|
-
return e};b.union=function(){return b.uniq(b.flatten(arguments,true))};b.intersection=b.intersect=function(a){var c=i.call(arguments,1);return b.filter(b.uniq(a),function(a){return b.every(c,function(c){return b.indexOf(c,a)>=0})})};b.difference=function(a){var c=b.flatten(i.call(arguments,1));return b.filter(a,function(a){return!b.include(c,a)})};b.zip=function(){for(var a=i.call(arguments),c=b.max(b.pluck(a,"length")),d=Array(c),e=0;e<c;e++)d[e]=b.pluck(a,""+e);return d};b.indexOf=function(a,c,
|
20
|
-
d){if(a==null)return-1;var e;if(d)return d=b.sortedIndex(a,c),a[d]===c?d:-1;if(p&&a.indexOf===p)return a.indexOf(c);for(d=0,e=a.length;d<e;d++)if(d in a&&a[d]===c)return d;return-1};b.lastIndexOf=function(a,b){if(a==null)return-1;if(D&&a.lastIndexOf===D)return a.lastIndexOf(b);for(var d=a.length;d--;)if(d in a&&a[d]===b)return d;return-1};b.range=function(a,b,d){arguments.length<=1&&(b=a||0,a=0);for(var d=arguments[2]||1,e=Math.max(Math.ceil((b-a)/d),0),f=0,g=Array(e);f<e;)g[f++]=a,a+=d;return g};
|
21
|
-
var F=function(){};b.bind=function(a,c){var d,e;if(a.bind===s&&s)return s.apply(a,i.call(arguments,1));if(!b.isFunction(a))throw new TypeError;e=i.call(arguments,2);return d=function(){if(!(this instanceof d))return a.apply(c,e.concat(i.call(arguments)));F.prototype=a.prototype;var b=new F,g=a.apply(b,e.concat(i.call(arguments)));return Object(g)===g?g:b}};b.bindAll=function(a){var c=i.call(arguments,1);c.length==0&&(c=b.functions(a));j(c,function(c){a[c]=b.bind(a[c],a)});return a};b.memoize=function(a,
|
22
|
-
c){var d={};c||(c=b.identity);return function(){var e=c.apply(this,arguments);return b.has(d,e)?d[e]:d[e]=a.apply(this,arguments)}};b.delay=function(a,b){var d=i.call(arguments,2);return setTimeout(function(){return a.apply(a,d)},b)};b.defer=function(a){return b.delay.apply(b,[a,1].concat(i.call(arguments,1)))};b.throttle=function(a,c){var d,e,f,g,h,i=b.debounce(function(){h=g=false},c);return function(){d=this;e=arguments;var b;f||(f=setTimeout(function(){f=null;h&&a.apply(d,e);i()},c));g?h=true:
|
23
|
-
a.apply(d,e);i();g=true}};b.debounce=function(a,b){var d;return function(){var e=this,f=arguments;clearTimeout(d);d=setTimeout(function(){d=null;a.apply(e,f)},b)}};b.once=function(a){var b=false,d;return function(){if(b)return d;b=true;return d=a.apply(this,arguments)}};b.wrap=function(a,b){return function(){var d=[a].concat(i.call(arguments,0));return b.apply(this,d)}};b.compose=function(){var a=arguments;return function(){for(var b=arguments,d=a.length-1;d>=0;d--)b=[a[d].apply(this,b)];return b[0]}};
|
24
|
-
b.after=function(a,b){return a<=0?b():function(){if(--a<1)return b.apply(this,arguments)}};b.keys=J||function(a){if(a!==Object(a))throw new TypeError("Invalid object");var c=[],d;for(d in a)b.has(a,d)&&(c[c.length]=d);return c};b.values=function(a){return b.map(a,b.identity)};b.functions=b.methods=function(a){var c=[],d;for(d in a)b.isFunction(a[d])&&c.push(d);return c.sort()};b.extend=function(a){j(i.call(arguments,1),function(b){for(var d in b)a[d]=b[d]});return a};b.defaults=function(a){j(i.call(arguments,
|
25
|
-
1),function(b){for(var d in b)a[d]==null&&(a[d]=b[d])});return a};b.clone=function(a){return!b.isObject(a)?a:b.isArray(a)?a.slice():b.extend({},a)};b.tap=function(a,b){b(a);return a};b.isEqual=function(a,b){return q(a,b,[])};b.isEmpty=function(a){if(b.isArray(a)||b.isString(a))return a.length===0;for(var c in a)if(b.has(a,c))return false;return true};b.isElement=function(a){return!!(a&&a.nodeType==1)};b.isArray=o||function(a){return l.call(a)=="[object Array]"};b.isObject=function(a){return a===Object(a)};
|
26
|
-
b.isArguments=function(a){return l.call(a)=="[object Arguments]"};if(!b.isArguments(arguments))b.isArguments=function(a){return!(!a||!b.has(a,"callee"))};b.isFunction=function(a){return l.call(a)=="[object Function]"};b.isString=function(a){return l.call(a)=="[object String]"};b.isNumber=function(a){return l.call(a)=="[object Number]"};b.isNaN=function(a){return a!==a};b.isBoolean=function(a){return a===true||a===false||l.call(a)=="[object Boolean]"};b.isDate=function(a){return l.call(a)=="[object Date]"};
|
27
|
-
b.isRegExp=function(a){return l.call(a)=="[object RegExp]"};b.isNull=function(a){return a===null};b.isUndefined=function(a){return a===void 0};b.has=function(a,b){return I.call(a,b)};b.noConflict=function(){r._=G;return this};b.identity=function(a){return a};b.times=function(a,b,d){for(var e=0;e<a;e++)b.call(d,e)};b.escape=function(a){return(""+a).replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,""").replace(/'/g,"'").replace(/\//g,"/")};b.mixin=function(a){j(b.functions(a),
|
28
|
-
function(c){K(c,b[c]=a[c])})};var L=0;b.uniqueId=function(a){var b=L++;return a?a+b:b};b.templateSettings={evaluate:/<%([\s\S]+?)%>/g,interpolate:/<%=([\s\S]+?)%>/g,escape:/<%-([\s\S]+?)%>/g};var t=/.^/,u=function(a){return a.replace(/\\\\/g,"\\").replace(/\\'/g,"'")};b.template=function(a,c){var d=b.templateSettings,d="var __p=[],print=function(){__p.push.apply(__p,arguments);};with(obj||{}){__p.push('"+a.replace(/\\/g,"\\\\").replace(/'/g,"\\'").replace(d.escape||t,function(a,b){return"',_.escape("+
|
29
|
-
u(b)+"),'"}).replace(d.interpolate||t,function(a,b){return"',"+u(b)+",'"}).replace(d.evaluate||t,function(a,b){return"');"+u(b).replace(/[\r\n\t]/g," ")+";__p.push('"}).replace(/\r/g,"\\r").replace(/\n/g,"\\n").replace(/\t/g,"\\t")+"');}return __p.join('');",e=new Function("obj","_",d);return c?e(c,b):function(a){return e.call(this,a,b)}};b.chain=function(a){return b(a).chain()};var m=function(a){this._wrapped=a};b.prototype=m.prototype;var v=function(a,c){return c?b(a).chain():a},K=function(a,c){m.prototype[a]=
|
30
|
-
function(){var a=i.call(arguments);H.call(a,this._wrapped);return v(c.apply(b,a),this._chain)}};b.mixin(b);j("pop,push,reverse,shift,sort,splice,unshift".split(","),function(a){var b=k[a];m.prototype[a]=function(){var d=this._wrapped;b.apply(d,arguments);var e=d.length;(a=="shift"||a=="splice")&&e===0&&delete d[0];return v(d,this._chain)}});j(["concat","join","slice"],function(a){var b=k[a];m.prototype[a]=function(){return v(b.apply(this._wrapped,arguments),this._chain)}});m.prototype.chain=function(){this._chain=
|
31
|
-
true;return this};m.prototype.value=function(){return this._wrapped}}).call(this);
|
Binary file
|
Binary file
|
@@ -1,808 +0,0 @@
|
|
1
|
-
/*
|
2
|
-
* websupport.js
|
3
|
-
* ~~~~~~~~~~~~~
|
4
|
-
*
|
5
|
-
* sphinx.websupport utilties for all documentation.
|
6
|
-
*
|
7
|
-
* :copyright: Copyright 2007-2016, by the Sphinx team, see AUTHORS.
|
8
|
-
* :license: BSD, see LICENSE for details.
|
9
|
-
*
|
10
|
-
*/
|
11
|
-
|
12
|
-
(function($) {
|
13
|
-
$.fn.autogrow = function() {
|
14
|
-
return this.each(function() {
|
15
|
-
var textarea = this;
|
16
|
-
|
17
|
-
$.fn.autogrow.resize(textarea);
|
18
|
-
|
19
|
-
$(textarea)
|
20
|
-
.focus(function() {
|
21
|
-
textarea.interval = setInterval(function() {
|
22
|
-
$.fn.autogrow.resize(textarea);
|
23
|
-
}, 500);
|
24
|
-
})
|
25
|
-
.blur(function() {
|
26
|
-
clearInterval(textarea.interval);
|
27
|
-
});
|
28
|
-
});
|
29
|
-
};
|
30
|
-
|
31
|
-
$.fn.autogrow.resize = function(textarea) {
|
32
|
-
var lineHeight = parseInt($(textarea).css('line-height'), 10);
|
33
|
-
var lines = textarea.value.split('\n');
|
34
|
-
var columns = textarea.cols;
|
35
|
-
var lineCount = 0;
|
36
|
-
$.each(lines, function() {
|
37
|
-
lineCount += Math.ceil(this.length / columns) || 1;
|
38
|
-
});
|
39
|
-
var height = lineHeight * (lineCount + 1);
|
40
|
-
$(textarea).css('height', height);
|
41
|
-
};
|
42
|
-
})(jQuery);
|
43
|
-
|
44
|
-
(function($) {
|
45
|
-
var comp, by;
|
46
|
-
|
47
|
-
function init() {
|
48
|
-
initEvents();
|
49
|
-
initComparator();
|
50
|
-
}
|
51
|
-
|
52
|
-
function initEvents() {
|
53
|
-
$('a.comment-close').live("click", function(event) {
|
54
|
-
event.preventDefault();
|
55
|
-
hide($(this).attr('id').substring(2));
|
56
|
-
});
|
57
|
-
$('a.vote').live("click", function(event) {
|
58
|
-
event.preventDefault();
|
59
|
-
handleVote($(this));
|
60
|
-
});
|
61
|
-
$('a.reply').live("click", function(event) {
|
62
|
-
event.preventDefault();
|
63
|
-
openReply($(this).attr('id').substring(2));
|
64
|
-
});
|
65
|
-
$('a.close-reply').live("click", function(event) {
|
66
|
-
event.preventDefault();
|
67
|
-
closeReply($(this).attr('id').substring(2));
|
68
|
-
});
|
69
|
-
$('a.sort-option').live("click", function(event) {
|
70
|
-
event.preventDefault();
|
71
|
-
handleReSort($(this));
|
72
|
-
});
|
73
|
-
$('a.show-proposal').live("click", function(event) {
|
74
|
-
event.preventDefault();
|
75
|
-
showProposal($(this).attr('id').substring(2));
|
76
|
-
});
|
77
|
-
$('a.hide-proposal').live("click", function(event) {
|
78
|
-
event.preventDefault();
|
79
|
-
hideProposal($(this).attr('id').substring(2));
|
80
|
-
});
|
81
|
-
$('a.show-propose-change').live("click", function(event) {
|
82
|
-
event.preventDefault();
|
83
|
-
showProposeChange($(this).attr('id').substring(2));
|
84
|
-
});
|
85
|
-
$('a.hide-propose-change').live("click", function(event) {
|
86
|
-
event.preventDefault();
|
87
|
-
hideProposeChange($(this).attr('id').substring(2));
|
88
|
-
});
|
89
|
-
$('a.accept-comment').live("click", function(event) {
|
90
|
-
event.preventDefault();
|
91
|
-
acceptComment($(this).attr('id').substring(2));
|
92
|
-
});
|
93
|
-
$('a.delete-comment').live("click", function(event) {
|
94
|
-
event.preventDefault();
|
95
|
-
deleteComment($(this).attr('id').substring(2));
|
96
|
-
});
|
97
|
-
$('a.comment-markup').live("click", function(event) {
|
98
|
-
event.preventDefault();
|
99
|
-
toggleCommentMarkupBox($(this).attr('id').substring(2));
|
100
|
-
});
|
101
|
-
}
|
102
|
-
|
103
|
-
/**
|
104
|
-
* Set comp, which is a comparator function used for sorting and
|
105
|
-
* inserting comments into the list.
|
106
|
-
*/
|
107
|
-
function setComparator() {
|
108
|
-
// If the first three letters are "asc", sort in ascending order
|
109
|
-
// and remove the prefix.
|
110
|
-
if (by.substring(0,3) == 'asc') {
|
111
|
-
var i = by.substring(3);
|
112
|
-
comp = function(a, b) { return a[i] - b[i]; };
|
113
|
-
} else {
|
114
|
-
// Otherwise sort in descending order.
|
115
|
-
comp = function(a, b) { return b[by] - a[by]; };
|
116
|
-
}
|
117
|
-
|
118
|
-
// Reset link styles and format the selected sort option.
|
119
|
-
$('a.sel').attr('href', '#').removeClass('sel');
|
120
|
-
$('a.by' + by).removeAttr('href').addClass('sel');
|
121
|
-
}
|
122
|
-
|
123
|
-
/**
|
124
|
-
* Create a comp function. If the user has preferences stored in
|
125
|
-
* the sortBy cookie, use those, otherwise use the default.
|
126
|
-
*/
|
127
|
-
function initComparator() {
|
128
|
-
by = 'rating'; // Default to sort by rating.
|
129
|
-
// If the sortBy cookie is set, use that instead.
|
130
|
-
if (document.cookie.length > 0) {
|
131
|
-
var start = document.cookie.indexOf('sortBy=');
|
132
|
-
if (start != -1) {
|
133
|
-
start = start + 7;
|
134
|
-
var end = document.cookie.indexOf(";", start);
|
135
|
-
if (end == -1) {
|
136
|
-
end = document.cookie.length;
|
137
|
-
by = unescape(document.cookie.substring(start, end));
|
138
|
-
}
|
139
|
-
}
|
140
|
-
}
|
141
|
-
setComparator();
|
142
|
-
}
|
143
|
-
|
144
|
-
/**
|
145
|
-
* Show a comment div.
|
146
|
-
*/
|
147
|
-
function show(id) {
|
148
|
-
$('#ao' + id).hide();
|
149
|
-
$('#ah' + id).show();
|
150
|
-
var context = $.extend({id: id}, opts);
|
151
|
-
var popup = $(renderTemplate(popupTemplate, context)).hide();
|
152
|
-
popup.find('textarea[name="proposal"]').hide();
|
153
|
-
popup.find('a.by' + by).addClass('sel');
|
154
|
-
var form = popup.find('#cf' + id);
|
155
|
-
form.submit(function(event) {
|
156
|
-
event.preventDefault();
|
157
|
-
addComment(form);
|
158
|
-
});
|
159
|
-
$('#s' + id).after(popup);
|
160
|
-
popup.slideDown('fast', function() {
|
161
|
-
getComments(id);
|
162
|
-
});
|
163
|
-
}
|
164
|
-
|
165
|
-
/**
|
166
|
-
* Hide a comment div.
|
167
|
-
*/
|
168
|
-
function hide(id) {
|
169
|
-
$('#ah' + id).hide();
|
170
|
-
$('#ao' + id).show();
|
171
|
-
var div = $('#sc' + id);
|
172
|
-
div.slideUp('fast', function() {
|
173
|
-
div.remove();
|
174
|
-
});
|
175
|
-
}
|
176
|
-
|
177
|
-
/**
|
178
|
-
* Perform an ajax request to get comments for a node
|
179
|
-
* and insert the comments into the comments tree.
|
180
|
-
*/
|
181
|
-
function getComments(id) {
|
182
|
-
$.ajax({
|
183
|
-
type: 'GET',
|
184
|
-
url: opts.getCommentsURL,
|
185
|
-
data: {node: id},
|
186
|
-
success: function(data, textStatus, request) {
|
187
|
-
var ul = $('#cl' + id);
|
188
|
-
var speed = 100;
|
189
|
-
$('#cf' + id)
|
190
|
-
.find('textarea[name="proposal"]')
|
191
|
-
.data('source', data.source);
|
192
|
-
|
193
|
-
if (data.comments.length === 0) {
|
194
|
-
ul.html('<li>No comments yet.</li>');
|
195
|
-
ul.data('empty', true);
|
196
|
-
} else {
|
197
|
-
// If there are comments, sort them and put them in the list.
|
198
|
-
var comments = sortComments(data.comments);
|
199
|
-
speed = data.comments.length * 100;
|
200
|
-
appendComments(comments, ul);
|
201
|
-
ul.data('empty', false);
|
202
|
-
}
|
203
|
-
$('#cn' + id).slideUp(speed + 200);
|
204
|
-
ul.slideDown(speed);
|
205
|
-
},
|
206
|
-
error: function(request, textStatus, error) {
|
207
|
-
showError('Oops, there was a problem retrieving the comments.');
|
208
|
-
},
|
209
|
-
dataType: 'json'
|
210
|
-
});
|
211
|
-
}
|
212
|
-
|
213
|
-
/**
|
214
|
-
* Add a comment via ajax and insert the comment into the comment tree.
|
215
|
-
*/
|
216
|
-
function addComment(form) {
|
217
|
-
var node_id = form.find('input[name="node"]').val();
|
218
|
-
var parent_id = form.find('input[name="parent"]').val();
|
219
|
-
var text = form.find('textarea[name="comment"]').val();
|
220
|
-
var proposal = form.find('textarea[name="proposal"]').val();
|
221
|
-
|
222
|
-
if (text == '') {
|
223
|
-
showError('Please enter a comment.');
|
224
|
-
return;
|
225
|
-
}
|
226
|
-
|
227
|
-
// Disable the form that is being submitted.
|
228
|
-
form.find('textarea,input').attr('disabled', 'disabled');
|
229
|
-
|
230
|
-
// Send the comment to the server.
|
231
|
-
$.ajax({
|
232
|
-
type: "POST",
|
233
|
-
url: opts.addCommentURL,
|
234
|
-
dataType: 'json',
|
235
|
-
data: {
|
236
|
-
node: node_id,
|
237
|
-
parent: parent_id,
|
238
|
-
text: text,
|
239
|
-
proposal: proposal
|
240
|
-
},
|
241
|
-
success: function(data, textStatus, error) {
|
242
|
-
// Reset the form.
|
243
|
-
if (node_id) {
|
244
|
-
hideProposeChange(node_id);
|
245
|
-
}
|
246
|
-
form.find('textarea')
|
247
|
-
.val('')
|
248
|
-
.add(form.find('input'))
|
249
|
-
.removeAttr('disabled');
|
250
|
-
var ul = $('#cl' + (node_id || parent_id));
|
251
|
-
if (ul.data('empty')) {
|
252
|
-
$(ul).empty();
|
253
|
-
ul.data('empty', false);
|
254
|
-
}
|
255
|
-
insertComment(data.comment);
|
256
|
-
var ao = $('#ao' + node_id);
|
257
|
-
ao.find('img').attr({'src': opts.commentBrightImage});
|
258
|
-
if (node_id) {
|
259
|
-
// if this was a "root" comment, remove the commenting box
|
260
|
-
// (the user can get it back by reopening the comment popup)
|
261
|
-
$('#ca' + node_id).slideUp();
|
262
|
-
}
|
263
|
-
},
|
264
|
-
error: function(request, textStatus, error) {
|
265
|
-
form.find('textarea,input').removeAttr('disabled');
|
266
|
-
showError('Oops, there was a problem adding the comment.');
|
267
|
-
}
|
268
|
-
});
|
269
|
-
}
|
270
|
-
|
271
|
-
/**
|
272
|
-
* Recursively append comments to the main comment list and children
|
273
|
-
* lists, creating the comment tree.
|
274
|
-
*/
|
275
|
-
function appendComments(comments, ul) {
|
276
|
-
$.each(comments, function() {
|
277
|
-
var div = createCommentDiv(this);
|
278
|
-
ul.append($(document.createElement('li')).html(div));
|
279
|
-
appendComments(this.children, div.find('ul.comment-children'));
|
280
|
-
// To avoid stagnating data, don't store the comments children in data.
|
281
|
-
this.children = null;
|
282
|
-
div.data('comment', this);
|
283
|
-
});
|
284
|
-
}
|
285
|
-
|
286
|
-
/**
|
287
|
-
* After adding a new comment, it must be inserted in the correct
|
288
|
-
* location in the comment tree.
|
289
|
-
*/
|
290
|
-
function insertComment(comment) {
|
291
|
-
var div = createCommentDiv(comment);
|
292
|
-
|
293
|
-
// To avoid stagnating data, don't store the comments children in data.
|
294
|
-
comment.children = null;
|
295
|
-
div.data('comment', comment);
|
296
|
-
|
297
|
-
var ul = $('#cl' + (comment.node || comment.parent));
|
298
|
-
var siblings = getChildren(ul);
|
299
|
-
|
300
|
-
var li = $(document.createElement('li'));
|
301
|
-
li.hide();
|
302
|
-
|
303
|
-
// Determine where in the parents children list to insert this comment.
|
304
|
-
for(i=0; i < siblings.length; i++) {
|
305
|
-
if (comp(comment, siblings[i]) <= 0) {
|
306
|
-
$('#cd' + siblings[i].id)
|
307
|
-
.parent()
|
308
|
-
.before(li.html(div));
|
309
|
-
li.slideDown('fast');
|
310
|
-
return;
|
311
|
-
}
|
312
|
-
}
|
313
|
-
|
314
|
-
// If we get here, this comment rates lower than all the others,
|
315
|
-
// or it is the only comment in the list.
|
316
|
-
ul.append(li.html(div));
|
317
|
-
li.slideDown('fast');
|
318
|
-
}
|
319
|
-
|
320
|
-
function acceptComment(id) {
|
321
|
-
$.ajax({
|
322
|
-
type: 'POST',
|
323
|
-
url: opts.acceptCommentURL,
|
324
|
-
data: {id: id},
|
325
|
-
success: function(data, textStatus, request) {
|
326
|
-
$('#cm' + id).fadeOut('fast');
|
327
|
-
$('#cd' + id).removeClass('moderate');
|
328
|
-
},
|
329
|
-
error: function(request, textStatus, error) {
|
330
|
-
showError('Oops, there was a problem accepting the comment.');
|
331
|
-
}
|
332
|
-
});
|
333
|
-
}
|
334
|
-
|
335
|
-
function deleteComment(id) {
|
336
|
-
$.ajax({
|
337
|
-
type: 'POST',
|
338
|
-
url: opts.deleteCommentURL,
|
339
|
-
data: {id: id},
|
340
|
-
success: function(data, textStatus, request) {
|
341
|
-
var div = $('#cd' + id);
|
342
|
-
if (data == 'delete') {
|
343
|
-
// Moderator mode: remove the comment and all children immediately
|
344
|
-
div.slideUp('fast', function() {
|
345
|
-
div.remove();
|
346
|
-
});
|
347
|
-
return;
|
348
|
-
}
|
349
|
-
// User mode: only mark the comment as deleted
|
350
|
-
div
|
351
|
-
.find('span.user-id:first')
|
352
|
-
.text('[deleted]').end()
|
353
|
-
.find('div.comment-text:first')
|
354
|
-
.text('[deleted]').end()
|
355
|
-
.find('#cm' + id + ', #dc' + id + ', #ac' + id + ', #rc' + id +
|
356
|
-
', #sp' + id + ', #hp' + id + ', #cr' + id + ', #rl' + id)
|
357
|
-
.remove();
|
358
|
-
var comment = div.data('comment');
|
359
|
-
comment.username = '[deleted]';
|
360
|
-
comment.text = '[deleted]';
|
361
|
-
div.data('comment', comment);
|
362
|
-
},
|
363
|
-
error: function(request, textStatus, error) {
|
364
|
-
showError('Oops, there was a problem deleting the comment.');
|
365
|
-
}
|
366
|
-
});
|
367
|
-
}
|
368
|
-
|
369
|
-
function showProposal(id) {
|
370
|
-
$('#sp' + id).hide();
|
371
|
-
$('#hp' + id).show();
|
372
|
-
$('#pr' + id).slideDown('fast');
|
373
|
-
}
|
374
|
-
|
375
|
-
function hideProposal(id) {
|
376
|
-
$('#hp' + id).hide();
|
377
|
-
$('#sp' + id).show();
|
378
|
-
$('#pr' + id).slideUp('fast');
|
379
|
-
}
|
380
|
-
|
381
|
-
function showProposeChange(id) {
|
382
|
-
$('#pc' + id).hide();
|
383
|
-
$('#hc' + id).show();
|
384
|
-
var textarea = $('#pt' + id);
|
385
|
-
textarea.val(textarea.data('source'));
|
386
|
-
$.fn.autogrow.resize(textarea[0]);
|
387
|
-
textarea.slideDown('fast');
|
388
|
-
}
|
389
|
-
|
390
|
-
function hideProposeChange(id) {
|
391
|
-
$('#hc' + id).hide();
|
392
|
-
$('#pc' + id).show();
|
393
|
-
var textarea = $('#pt' + id);
|
394
|
-
textarea.val('').removeAttr('disabled');
|
395
|
-
textarea.slideUp('fast');
|
396
|
-
}
|
397
|
-
|
398
|
-
function toggleCommentMarkupBox(id) {
|
399
|
-
$('#mb' + id).toggle();
|
400
|
-
}
|
401
|
-
|
402
|
-
/** Handle when the user clicks on a sort by link. */
|
403
|
-
function handleReSort(link) {
|
404
|
-
var classes = link.attr('class').split(/\s+/);
|
405
|
-
for (var i=0; i<classes.length; i++) {
|
406
|
-
if (classes[i] != 'sort-option') {
|
407
|
-
by = classes[i].substring(2);
|
408
|
-
}
|
409
|
-
}
|
410
|
-
setComparator();
|
411
|
-
// Save/update the sortBy cookie.
|
412
|
-
var expiration = new Date();
|
413
|
-
expiration.setDate(expiration.getDate() + 365);
|
414
|
-
document.cookie= 'sortBy=' + escape(by) +
|
415
|
-
';expires=' + expiration.toUTCString();
|
416
|
-
$('ul.comment-ul').each(function(index, ul) {
|
417
|
-
var comments = getChildren($(ul), true);
|
418
|
-
comments = sortComments(comments);
|
419
|
-
appendComments(comments, $(ul).empty());
|
420
|
-
});
|
421
|
-
}
|
422
|
-
|
423
|
-
/**
|
424
|
-
* Function to process a vote when a user clicks an arrow.
|
425
|
-
*/
|
426
|
-
function handleVote(link) {
|
427
|
-
if (!opts.voting) {
|
428
|
-
showError("You'll need to login to vote.");
|
429
|
-
return;
|
430
|
-
}
|
431
|
-
|
432
|
-
var id = link.attr('id');
|
433
|
-
if (!id) {
|
434
|
-
// Didn't click on one of the voting arrows.
|
435
|
-
return;
|
436
|
-
}
|
437
|
-
// If it is an unvote, the new vote value is 0,
|
438
|
-
// Otherwise it's 1 for an upvote, or -1 for a downvote.
|
439
|
-
var value = 0;
|
440
|
-
if (id.charAt(1) != 'u') {
|
441
|
-
value = id.charAt(0) == 'u' ? 1 : -1;
|
442
|
-
}
|
443
|
-
// The data to be sent to the server.
|
444
|
-
var d = {
|
445
|
-
comment_id: id.substring(2),
|
446
|
-
value: value
|
447
|
-
};
|
448
|
-
|
449
|
-
// Swap the vote and unvote links.
|
450
|
-
link.hide();
|
451
|
-
$('#' + id.charAt(0) + (id.charAt(1) == 'u' ? 'v' : 'u') + d.comment_id)
|
452
|
-
.show();
|
453
|
-
|
454
|
-
// The div the comment is displayed in.
|
455
|
-
var div = $('div#cd' + d.comment_id);
|
456
|
-
var data = div.data('comment');
|
457
|
-
|
458
|
-
// If this is not an unvote, and the other vote arrow has
|
459
|
-
// already been pressed, unpress it.
|
460
|
-
if ((d.value !== 0) && (data.vote === d.value * -1)) {
|
461
|
-
$('#' + (d.value == 1 ? 'd' : 'u') + 'u' + d.comment_id).hide();
|
462
|
-
$('#' + (d.value == 1 ? 'd' : 'u') + 'v' + d.comment_id).show();
|
463
|
-
}
|
464
|
-
|
465
|
-
// Update the comments rating in the local data.
|
466
|
-
data.rating += (data.vote === 0) ? d.value : (d.value - data.vote);
|
467
|
-
data.vote = d.value;
|
468
|
-
div.data('comment', data);
|
469
|
-
|
470
|
-
// Change the rating text.
|
471
|
-
div.find('.rating:first')
|
472
|
-
.text(data.rating + ' point' + (data.rating == 1 ? '' : 's'));
|
473
|
-
|
474
|
-
// Send the vote information to the server.
|
475
|
-
$.ajax({
|
476
|
-
type: "POST",
|
477
|
-
url: opts.processVoteURL,
|
478
|
-
data: d,
|
479
|
-
error: function(request, textStatus, error) {
|
480
|
-
showError('Oops, there was a problem casting that vote.');
|
481
|
-
}
|
482
|
-
});
|
483
|
-
}
|
484
|
-
|
485
|
-
/**
|
486
|
-
* Open a reply form used to reply to an existing comment.
|
487
|
-
*/
|
488
|
-
function openReply(id) {
|
489
|
-
// Swap out the reply link for the hide link
|
490
|
-
$('#rl' + id).hide();
|
491
|
-
$('#cr' + id).show();
|
492
|
-
|
493
|
-
// Add the reply li to the children ul.
|
494
|
-
var div = $(renderTemplate(replyTemplate, {id: id})).hide();
|
495
|
-
$('#cl' + id)
|
496
|
-
.prepend(div)
|
497
|
-
// Setup the submit handler for the reply form.
|
498
|
-
.find('#rf' + id)
|
499
|
-
.submit(function(event) {
|
500
|
-
event.preventDefault();
|
501
|
-
addComment($('#rf' + id));
|
502
|
-
closeReply(id);
|
503
|
-
})
|
504
|
-
.find('input[type=button]')
|
505
|
-
.click(function() {
|
506
|
-
closeReply(id);
|
507
|
-
});
|
508
|
-
div.slideDown('fast', function() {
|
509
|
-
$('#rf' + id).find('textarea').focus();
|
510
|
-
});
|
511
|
-
}
|
512
|
-
|
513
|
-
/**
|
514
|
-
* Close the reply form opened with openReply.
|
515
|
-
*/
|
516
|
-
function closeReply(id) {
|
517
|
-
// Remove the reply div from the DOM.
|
518
|
-
$('#rd' + id).slideUp('fast', function() {
|
519
|
-
$(this).remove();
|
520
|
-
});
|
521
|
-
|
522
|
-
// Swap out the hide link for the reply link
|
523
|
-
$('#cr' + id).hide();
|
524
|
-
$('#rl' + id).show();
|
525
|
-
}
|
526
|
-
|
527
|
-
/**
|
528
|
-
* Recursively sort a tree of comments using the comp comparator.
|
529
|
-
*/
|
530
|
-
function sortComments(comments) {
|
531
|
-
comments.sort(comp);
|
532
|
-
$.each(comments, function() {
|
533
|
-
this.children = sortComments(this.children);
|
534
|
-
});
|
535
|
-
return comments;
|
536
|
-
}
|
537
|
-
|
538
|
-
/**
|
539
|
-
* Get the children comments from a ul. If recursive is true,
|
540
|
-
* recursively include childrens' children.
|
541
|
-
*/
|
542
|
-
function getChildren(ul, recursive) {
|
543
|
-
var children = [];
|
544
|
-
ul.children().children("[id^='cd']")
|
545
|
-
.each(function() {
|
546
|
-
var comment = $(this).data('comment');
|
547
|
-
if (recursive)
|
548
|
-
comment.children = getChildren($(this).find('#cl' + comment.id), true);
|
549
|
-
children.push(comment);
|
550
|
-
});
|
551
|
-
return children;
|
552
|
-
}
|
553
|
-
|
554
|
-
/** Create a div to display a comment in. */
|
555
|
-
function createCommentDiv(comment) {
|
556
|
-
if (!comment.displayed && !opts.moderator) {
|
557
|
-
return $('<div class="moderate">Thank you! Your comment will show up '
|
558
|
-
+ 'once it is has been approved by a moderator.</div>');
|
559
|
-
}
|
560
|
-
// Prettify the comment rating.
|
561
|
-
comment.pretty_rating = comment.rating + ' point' +
|
562
|
-
(comment.rating == 1 ? '' : 's');
|
563
|
-
// Make a class (for displaying not yet moderated comments differently)
|
564
|
-
comment.css_class = comment.displayed ? '' : ' moderate';
|
565
|
-
// Create a div for this comment.
|
566
|
-
var context = $.extend({}, opts, comment);
|
567
|
-
var div = $(renderTemplate(commentTemplate, context));
|
568
|
-
|
569
|
-
// If the user has voted on this comment, highlight the correct arrow.
|
570
|
-
if (comment.vote) {
|
571
|
-
var direction = (comment.vote == 1) ? 'u' : 'd';
|
572
|
-
div.find('#' + direction + 'v' + comment.id).hide();
|
573
|
-
div.find('#' + direction + 'u' + comment.id).show();
|
574
|
-
}
|
575
|
-
|
576
|
-
if (opts.moderator || comment.text != '[deleted]') {
|
577
|
-
div.find('a.reply').show();
|
578
|
-
if (comment.proposal_diff)
|
579
|
-
div.find('#sp' + comment.id).show();
|
580
|
-
if (opts.moderator && !comment.displayed)
|
581
|
-
div.find('#cm' + comment.id).show();
|
582
|
-
if (opts.moderator || (opts.username == comment.username))
|
583
|
-
div.find('#dc' + comment.id).show();
|
584
|
-
}
|
585
|
-
return div;
|
586
|
-
}
|
587
|
-
|
588
|
-
/**
|
589
|
-
* A simple template renderer. Placeholders such as <%id%> are replaced
|
590
|
-
* by context['id'] with items being escaped. Placeholders such as <#id#>
|
591
|
-
* are not escaped.
|
592
|
-
*/
|
593
|
-
function renderTemplate(template, context) {
|
594
|
-
var esc = $(document.createElement('div'));
|
595
|
-
|
596
|
-
function handle(ph, escape) {
|
597
|
-
var cur = context;
|
598
|
-
$.each(ph.split('.'), function() {
|
599
|
-
cur = cur[this];
|
600
|
-
});
|
601
|
-
return escape ? esc.text(cur || "").html() : cur;
|
602
|
-
}
|
603
|
-
|
604
|
-
return template.replace(/<([%#])([\w\.]*)\1>/g, function() {
|
605
|
-
return handle(arguments[2], arguments[1] == '%' ? true : false);
|
606
|
-
});
|
607
|
-
}
|
608
|
-
|
609
|
-
/** Flash an error message briefly. */
|
610
|
-
function showError(message) {
|
611
|
-
$(document.createElement('div')).attr({'class': 'popup-error'})
|
612
|
-
.append($(document.createElement('div'))
|
613
|
-
.attr({'class': 'error-message'}).text(message))
|
614
|
-
.appendTo('body')
|
615
|
-
.fadeIn("slow")
|
616
|
-
.delay(2000)
|
617
|
-
.fadeOut("slow");
|
618
|
-
}
|
619
|
-
|
620
|
-
/** Add a link the user uses to open the comments popup. */
|
621
|
-
$.fn.comment = function() {
|
622
|
-
return this.each(function() {
|
623
|
-
var id = $(this).attr('id').substring(1);
|
624
|
-
var count = COMMENT_METADATA[id];
|
625
|
-
var title = count + ' comment' + (count == 1 ? '' : 's');
|
626
|
-
var image = count > 0 ? opts.commentBrightImage : opts.commentImage;
|
627
|
-
var addcls = count == 0 ? ' nocomment' : '';
|
628
|
-
$(this)
|
629
|
-
.append(
|
630
|
-
$(document.createElement('a')).attr({
|
631
|
-
href: '#',
|
632
|
-
'class': 'sphinx-comment-open' + addcls,
|
633
|
-
id: 'ao' + id
|
634
|
-
})
|
635
|
-
.append($(document.createElement('img')).attr({
|
636
|
-
src: image,
|
637
|
-
alt: 'comment',
|
638
|
-
title: title
|
639
|
-
}))
|
640
|
-
.click(function(event) {
|
641
|
-
event.preventDefault();
|
642
|
-
show($(this).attr('id').substring(2));
|
643
|
-
})
|
644
|
-
)
|
645
|
-
.append(
|
646
|
-
$(document.createElement('a')).attr({
|
647
|
-
href: '#',
|
648
|
-
'class': 'sphinx-comment-close hidden',
|
649
|
-
id: 'ah' + id
|
650
|
-
})
|
651
|
-
.append($(document.createElement('img')).attr({
|
652
|
-
src: opts.closeCommentImage,
|
653
|
-
alt: 'close',
|
654
|
-
title: 'close'
|
655
|
-
}))
|
656
|
-
.click(function(event) {
|
657
|
-
event.preventDefault();
|
658
|
-
hide($(this).attr('id').substring(2));
|
659
|
-
})
|
660
|
-
);
|
661
|
-
});
|
662
|
-
};
|
663
|
-
|
664
|
-
var opts = {
|
665
|
-
processVoteURL: '/_process_vote',
|
666
|
-
addCommentURL: '/_add_comment',
|
667
|
-
getCommentsURL: '/_get_comments',
|
668
|
-
acceptCommentURL: '/_accept_comment',
|
669
|
-
deleteCommentURL: '/_delete_comment',
|
670
|
-
commentImage: '/static/_static/comment.png',
|
671
|
-
closeCommentImage: '/static/_static/comment-close.png',
|
672
|
-
loadingImage: '/static/_static/ajax-loader.gif',
|
673
|
-
commentBrightImage: '/static/_static/comment-bright.png',
|
674
|
-
upArrow: '/static/_static/up.png',
|
675
|
-
downArrow: '/static/_static/down.png',
|
676
|
-
upArrowPressed: '/static/_static/up-pressed.png',
|
677
|
-
downArrowPressed: '/static/_static/down-pressed.png',
|
678
|
-
voting: false,
|
679
|
-
moderator: false
|
680
|
-
};
|
681
|
-
|
682
|
-
if (typeof COMMENT_OPTIONS != "undefined") {
|
683
|
-
opts = jQuery.extend(opts, COMMENT_OPTIONS);
|
684
|
-
}
|
685
|
-
|
686
|
-
var popupTemplate = '\
|
687
|
-
<div class="sphinx-comments" id="sc<%id%>">\
|
688
|
-
<p class="sort-options">\
|
689
|
-
Sort by:\
|
690
|
-
<a href="#" class="sort-option byrating">best rated</a>\
|
691
|
-
<a href="#" class="sort-option byascage">newest</a>\
|
692
|
-
<a href="#" class="sort-option byage">oldest</a>\
|
693
|
-
</p>\
|
694
|
-
<div class="comment-header">Comments</div>\
|
695
|
-
<div class="comment-loading" id="cn<%id%>">\
|
696
|
-
loading comments... <img src="<%loadingImage%>" alt="" /></div>\
|
697
|
-
<ul id="cl<%id%>" class="comment-ul"></ul>\
|
698
|
-
<div id="ca<%id%>">\
|
699
|
-
<p class="add-a-comment">Add a comment\
|
700
|
-
(<a href="#" class="comment-markup" id="ab<%id%>">markup</a>):</p>\
|
701
|
-
<div class="comment-markup-box" id="mb<%id%>">\
|
702
|
-
reStructured text markup: <i>*emph*</i>, <b>**strong**</b>, \
|
703
|
-
<tt>``code``</tt>, \
|
704
|
-
code blocks: <tt>::</tt> and an indented block after blank line</div>\
|
705
|
-
<form method="post" id="cf<%id%>" class="comment-form" action="">\
|
706
|
-
<textarea name="comment" cols="80"></textarea>\
|
707
|
-
<p class="propose-button">\
|
708
|
-
<a href="#" id="pc<%id%>" class="show-propose-change">\
|
709
|
-
Propose a change ▹\
|
710
|
-
</a>\
|
711
|
-
<a href="#" id="hc<%id%>" class="hide-propose-change">\
|
712
|
-
Propose a change ▿\
|
713
|
-
</a>\
|
714
|
-
</p>\
|
715
|
-
<textarea name="proposal" id="pt<%id%>" cols="80"\
|
716
|
-
spellcheck="false"></textarea>\
|
717
|
-
<input type="submit" value="Add comment" />\
|
718
|
-
<input type="hidden" name="node" value="<%id%>" />\
|
719
|
-
<input type="hidden" name="parent" value="" />\
|
720
|
-
</form>\
|
721
|
-
</div>\
|
722
|
-
</div>';
|
723
|
-
|
724
|
-
var commentTemplate = '\
|
725
|
-
<div id="cd<%id%>" class="sphinx-comment<%css_class%>">\
|
726
|
-
<div class="vote">\
|
727
|
-
<div class="arrow">\
|
728
|
-
<a href="#" id="uv<%id%>" class="vote" title="vote up">\
|
729
|
-
<img src="<%upArrow%>" />\
|
730
|
-
</a>\
|
731
|
-
<a href="#" id="uu<%id%>" class="un vote" title="vote up">\
|
732
|
-
<img src="<%upArrowPressed%>" />\
|
733
|
-
</a>\
|
734
|
-
</div>\
|
735
|
-
<div class="arrow">\
|
736
|
-
<a href="#" id="dv<%id%>" class="vote" title="vote down">\
|
737
|
-
<img src="<%downArrow%>" id="da<%id%>" />\
|
738
|
-
</a>\
|
739
|
-
<a href="#" id="du<%id%>" class="un vote" title="vote down">\
|
740
|
-
<img src="<%downArrowPressed%>" />\
|
741
|
-
</a>\
|
742
|
-
</div>\
|
743
|
-
</div>\
|
744
|
-
<div class="comment-content">\
|
745
|
-
<p class="tagline comment">\
|
746
|
-
<span class="user-id"><%username%></span>\
|
747
|
-
<span class="rating"><%pretty_rating%></span>\
|
748
|
-
<span class="delta"><%time.delta%></span>\
|
749
|
-
</p>\
|
750
|
-
<div class="comment-text comment"><#text#></div>\
|
751
|
-
<p class="comment-opts comment">\
|
752
|
-
<a href="#" class="reply hidden" id="rl<%id%>">reply ▹</a>\
|
753
|
-
<a href="#" class="close-reply" id="cr<%id%>">reply ▿</a>\
|
754
|
-
<a href="#" id="sp<%id%>" class="show-proposal">proposal ▹</a>\
|
755
|
-
<a href="#" id="hp<%id%>" class="hide-proposal">proposal ▿</a>\
|
756
|
-
<a href="#" id="dc<%id%>" class="delete-comment hidden">delete</a>\
|
757
|
-
<span id="cm<%id%>" class="moderation hidden">\
|
758
|
-
<a href="#" id="ac<%id%>" class="accept-comment">accept</a>\
|
759
|
-
</span>\
|
760
|
-
</p>\
|
761
|
-
<pre class="proposal" id="pr<%id%>">\
|
762
|
-
<#proposal_diff#>\
|
763
|
-
</pre>\
|
764
|
-
<ul class="comment-children" id="cl<%id%>"></ul>\
|
765
|
-
</div>\
|
766
|
-
<div class="clearleft"></div>\
|
767
|
-
</div>\
|
768
|
-
</div>';
|
769
|
-
|
770
|
-
var replyTemplate = '\
|
771
|
-
<li>\
|
772
|
-
<div class="reply-div" id="rd<%id%>">\
|
773
|
-
<form id="rf<%id%>">\
|
774
|
-
<textarea name="comment" cols="80"></textarea>\
|
775
|
-
<input type="submit" value="Add reply" />\
|
776
|
-
<input type="button" value="Cancel" />\
|
777
|
-
<input type="hidden" name="parent" value="<%id%>" />\
|
778
|
-
<input type="hidden" name="node" value="" />\
|
779
|
-
</form>\
|
780
|
-
</div>\
|
781
|
-
</li>';
|
782
|
-
|
783
|
-
$(document).ready(function() {
|
784
|
-
init();
|
785
|
-
});
|
786
|
-
})(jQuery);
|
787
|
-
|
788
|
-
$(document).ready(function() {
|
789
|
-
// add comment anchors for all paragraphs that are commentable
|
790
|
-
$('.sphinx-has-comment').comment();
|
791
|
-
|
792
|
-
// highlight search words in search results
|
793
|
-
$("div.context").each(function() {
|
794
|
-
var params = $.getQueryParameters();
|
795
|
-
var terms = (params.q) ? params.q[0].split(/\s+/) : [];
|
796
|
-
var result = $(this);
|
797
|
-
$.each(terms, function() {
|
798
|
-
result.highlightText(this.toLowerCase(), 'highlighted');
|
799
|
-
});
|
800
|
-
});
|
801
|
-
|
802
|
-
// directly open comment window if requested
|
803
|
-
var anchor = document.location.hash;
|
804
|
-
if (anchor.substring(0, 9) == '#comment-') {
|
805
|
-
$('#ao' + anchor.substring(9)).click();
|
806
|
-
document.location.hash = '#s' + anchor.substring(9);
|
807
|
-
}
|
808
|
-
});
|