summaryrefslogtreecommitdiff
path: root/static/js/jquery.spin.js
diff options
context:
space:
mode:
Diffstat (limited to 'static/js/jquery.spin.js')
-rw-r--r--static/js/jquery.spin.js48
1 files changed, 48 insertions, 0 deletions
diff --git a/static/js/jquery.spin.js b/static/js/jquery.spin.js
new file mode 100644
index 0000000..0a7c2b5
--- /dev/null
+++ b/static/js/jquery.spin.js
@@ -0,0 +1,48 @@
+/*
+
+You can now create a spinner using any of the variants below:
+
+$("#el").spin(); // Produces default Spinner using the text color of #el.
+$("#el").spin("small"); // Produces a 'small' Spinner using the text color of #el.
+$("#el").spin("large", "white"); // Produces a 'large' Spinner in white (or any valid CSS color).
+$("#el").spin({ ... }); // Produces a Spinner using your custom settings.
+
+$("#el").spin(false); // Kills the spinner.
+
+*/
+(function($) {
+ $.fn.spin = function(opts, color) {
+ var presets = {
+ "custom": { lines: 7, length: 2, width: 2, radius: 2},
+ "tiny": { lines: 8, length: 2, width: 2, radius: 3 },
+ "small": { lines: 8, length: 4, width: 3, radius: 5 },
+ "large": { lines: 10, length: 8, width: 4, radius: 8 }
+ };
+ if (Spinner) {
+ return this.each(function() {
+ var $this = $(this),
+ data = $this.data();
+
+ if (data.spinner) {
+ data.spinner.stop();
+ delete data.spinner;
+ }
+ if (opts !== false) {
+ if (typeof opts === "string") {
+ if (opts in presets) {
+ opts = presets[opts];
+ } else {
+ opts = {};
+ }
+ if (color) {
+ opts.color = color;
+ }
+ }
+ data.spinner = new Spinner($.extend({color: $this.css('color')}, opts)).spin(this);
+ }
+ });
+ } else {
+ throw "Spinner class not available.";
+ }
+ };
+})(jQuery);