mutiny-rails 0.1.1 → 0.2.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,5 +1,5 @@
1
1
  module Mutiny
2
2
  module Rails
3
- VERSION = '0.1.1'
3
+ VERSION = '0.2.0'
4
4
  end
5
5
  end
@@ -1,208 +1,202 @@
1
- /*! Mutiny v0.1.1 - http://mutinyjs.com/ */
2
- var Mutiny = {
3
- init: function(dataAttr) {
4
- dataAttr = dataAttr || "mutiny";
5
- $("[data-" + dataAttr + "]").mutiny(dataAttr);
6
- }
7
- };
1
+ /*! Mutiny v0.2.0 - http://mutinyjs.com/ */
2
+ (function(window, $, undefined) {
3
+ $(function(){
4
+ Mutiny.init();
5
+ });
8
6
 
9
- $.fn.mutiny = function(dataAttr) {
10
- var mutiny_call = function($instigator, name, instance_options) {
11
- if (Mutiny[name] === undefined) {
12
- throw '"' + name + '" not found';
13
- }
14
- var options = $.extend({}, Mutiny[name].defaults);
15
- if (typeof instance_options === "string") {
16
- options[Mutiny[name].string_arg] = instance_options;
7
+ var Mutiny = window.Mutiny = {
8
+ init: function(el, namespace) {
9
+ namespace = namespace || 'mutiny';
10
+ el = el || $('*');
11
+
12
+ var mutiny_call = function($instigator, widget, instance_options){
13
+ if(Mutiny[widget] === undefined) {
14
+ throw '"' + widget + '" not found';
15
+ }
16
+
17
+ var options = $.extend({}, Mutiny[widget].defaults);
18
+ if(isString(instance_options)) {
19
+ options[Mutiny[widget].string_arg] = instance_options;
20
+ } else {
21
+ $.extend(options, instance_options);
22
+ }
23
+ Mutiny[widget].init($instigator, options);
24
+ };
25
+
26
+ el.each(function(i, e) {
27
+ var $e = $(e);
28
+ var data = $e.data();
29
+ if(namespace in data) {
30
+ var directives = data[namespace];
31
+ if(isString(directives)) {
32
+ /* data-mutiny='slider' */
33
+ mutiny_call($e, directives, {});
34
+ } else if(typeof data === 'object') {
35
+ /* data-mutiny='{"slider": {"some": "options"}}' */
36
+ for(var directive in directives) {
37
+ mutiny_call($e, directive, directives[directive]);
38
+ }
17
39
  } else {
18
- $.extend(options, instance_options);
40
+ throw 'Unsupported data';
19
41
  }
20
- Mutiny[name].init($instigator, options);
21
- };
22
- dataAttr = dataAttr || "mutiny";
23
- this.each(function(i, e) {
24
- var $e = $(e);
25
- var data = $e.data(dataAttr);
26
- switch (typeof data) {
27
- case "string":
28
- mutiny_call($e, data, {});
29
- break;
30
-
31
- case "object":
32
- for (var directive in data) {
33
- mutiny_call($e, directive, data[directive]);
34
- }
35
- break;
36
-
37
- default:
38
- throw "Unsupported data";
42
+ }
43
+
44
+ for(var key in data) {
45
+ if(key.indexOf(namespace) === 0 && key != namespace) {
46
+ var widget = key.replace(namespace, '').toLowerCase();
47
+ var options = data[key];
48
+ mutiny_call($e, widget, options || {});
39
49
  }
50
+ }
40
51
  });
41
- return this;
52
+ }
42
53
  };
43
54
 
44
- $(function() {
45
- Mutiny.init();
46
- });
55
+ function isString(obj) {
56
+ return !!obj.substring;
57
+ }
47
58
 
48
59
  Mutiny.accordion = {
49
- defaults: {
50
- autoHeight: false,
51
- collapsible: true,
52
- active: false
53
- },
54
- _hrefIndex: function($search, href) {
55
- var active_index = -1;
56
- $search.find("a").each(function(index, anchorEl) {
57
- if ($(anchorEl).attr("href") == href) {
58
- active_index = index;
59
- return false;
60
- }
61
- });
62
- return active_index;
63
- },
64
- init: function($instigator, options) {
65
- var hash = window.location.hash || undefined;
66
- var $menu = options.menu ? $(options.menu) : undefined;
67
- if (hash) {
68
- var active_index = this._hrefIndex($menu || $instigator, hash);
69
- if (active_index > -1) {
70
- options.active = active_index;
71
- }
72
- }
73
- if ($menu) {
74
- var self = this;
75
- $menu.find("a").click(function(event) {
76
- var toggle_index = self._hrefIndex($menu, $(event.target).attr("href"));
77
- if (toggle_index > -1) {
78
- $instigator.accordion("activate", toggle_index);
79
- }
80
- });
81
- }
82
- $instigator.accordion(options);
60
+ 'defaults': {'autoHeight': false, 'collapsible': true, 'active': false},
61
+ 'init': function($instigator, options){
62
+ var hash = window.location.hash;
63
+ if(hash && $instigator.find(hash).length > 0) {
64
+ options.active = hash;
83
65
  }
66
+ $instigator.accordion(options);
67
+
68
+ $(window).on('hashchange', function(event) {
69
+ var hash = window.location.hash;
70
+ if(hash && $instigator.find(hash).length > 0) {
71
+ $instigator.accordion('activate', hash);
72
+ }
73
+ });
74
+ }
84
75
  };
85
76
 
86
77
  Mutiny.datepicker = {
87
- init: function($instigator, options) {
88
- $instigator.datepicker(options);
89
- }
78
+ 'init': function($instigator, options) {
79
+ $instigator.datepicker(options);
80
+ }
90
81
  };
91
82
 
92
83
  Mutiny.slider = {
93
- defaults: {
94
- range: "min"
95
- },
96
- _createFormatSpan: function(format, value, className) {
97
- if (value === null || value === "") {
98
- value = " ";
99
- }
100
- var inner = format.replace("%s", "<span>" + value + "</span>");
101
- if (className) {
102
- return '<span class="' + className + '">' + inner + "</span>";
103
- } else {
104
- return "<span>" + inner + "</span>";
105
- }
106
- },
107
- init: function($instigator, options) {
108
- var $ui;
109
- if (options.target) {
110
- $ui = $(options.target);
111
- } else {
112
- var id = $instigator.attr("id");
113
- var extras = "";
114
- if (id) {
115
- extras = ' id="' + id + '-mutiny-slider"';
116
- }
117
- $ui = $("<div" + extras + "></div>").insertAfter($instigator);
118
- }
119
- options.value = $instigator.val();
120
- options.slide = function(event, slider) {
121
- $instigator.val(slider.value).change();
122
- };
123
- if ($instigator.is("select")) {
124
- var $options = $instigator.find("option");
125
- options.min = Number($options.first().val());
126
- options.max = Number($options.last().val());
127
- options.step = (options.max - options.min) / ($options.length - 1);
128
- } else {
129
- options.min = Number($instigator.attr("min") || $instigator.data("min"));
130
- options.max = Number($instigator.attr("max") || $instigator.data("max"));
131
- options.step = Number($instigator.attr("step") || $instigator.data("step"));
132
- }
133
- $instigator.change(function() {
134
- var val = Number($instigator.val());
135
- if (val > options.max) {
136
- val = options.max;
137
- }
138
- if (val < options.min) {
139
- val = options.min;
140
- }
141
- if (isNaN(val)) {
142
- val = options.value;
143
- }
144
- $instigator.val(val);
145
- $ui.slider("value", val);
146
- });
147
- if (options.minLabel) {
148
- $ui.append(this._createFormatSpan(options.minLabel, options.min, "min-label"));
149
- }
150
- if (options.maxLabel) {
151
- $ui.append(this._createFormatSpan(options.maxLabel, options.max, "max-label"));
152
- }
153
- $ui.slider(options);
154
- if (options.valueLabel) {
155
- var $valueLabel = $(this._createFormatSpan(options.valueLabel, options.value, "valueLabel")).appendTo($ui.find(".ui-slider-handle"));
156
- var $value = $valueLabel.find("span");
157
- $instigator.change(function() {
158
- $value.html($instigator.val());
159
- });
160
- }
84
+ 'defaults': {'range': 'min'},
85
+ '_createFormatSpan': function(format, value, className) {
86
+ if(value === null || value === '') {
87
+ /* If value does not exist, force a non-empty element draw. Starting with empty
88
+ * element prevents correct drawing when it has been replace with real contents.
89
+ */
90
+ value = '&nbsp;';
91
+ }
92
+ var inner = format.replace('%s', '<span>' + value + '</span>');
93
+ if(className) {
94
+ return '<span class="' + className + '">' + inner + '</span>';
95
+ } else {
96
+ return '<span>' + inner + '</span>';
97
+ }
98
+ },
99
+ 'init': function($instigator, options){
100
+ var $ui;
101
+ if(options.target) {
102
+ $ui = $(options.target);
103
+ } else {
104
+ var id = $instigator.attr('id');
105
+ var extras = '';
106
+ if(id) {
107
+ extras = ' id="' + id + '-mutiny-slider"';
108
+ }
109
+ $ui = $('<div' + extras + '></div>').insertAfter($instigator);
110
+ }
111
+
112
+ options.value = $instigator.val();
113
+ options.slide = function(event, slider) {
114
+ /* Force trigger of .change() to propagate the value elsewhere. */
115
+ $instigator.val(slider.value).change();
116
+ };
117
+
118
+ if ($instigator.is('select')) {
119
+ var $options = $instigator.find('option');
120
+ options.min = Number($options.first().val());
121
+ options.max = Number($options.last().val());
122
+ options.step = (options.max - options.min) / ($options.length - 1);
123
+ } else {
124
+ $.each(['min', 'max', 'step'], function(i, attr) {
125
+ options[attr] = Number(options[attr] || $instigator.attr(attr) || $instigator.data(attr));
126
+ });
161
127
  }
128
+
129
+ $instigator.change(function(){
130
+ var val = Number($instigator.val());
131
+ if (val > options.max) { val = options.max; }
132
+ if (val < options.min) { val = options.min; }
133
+ if (isNaN(val)) { val = options.value; }
134
+ $instigator.val(val);
135
+ $ui.slider('value', val);
136
+ });
137
+
138
+ if(options.minLabel) {
139
+ $ui.append(this._createFormatSpan(options.minLabel, options.min, 'min-label'));
140
+ }
141
+ if(options.maxLabel) {
142
+ $ui.append(this._createFormatSpan(options.maxLabel, options.max, 'max-label'));
143
+ }
144
+
145
+ $ui.slider(options);
146
+
147
+ /* Need to append the element to a DOM loaded slider so this occurs after the slider instantiation. */
148
+ if(options.valueLabel) {
149
+ var $valueLabel = $(this._createFormatSpan(options.valueLabel, options.value, 'value-label')).appendTo($ui.find('.ui-slider-handle'));
150
+ var $value = $valueLabel.find('span');
151
+ $instigator.change(function() {
152
+ $value.html($instigator.val());
153
+ });
154
+ }
155
+ }
162
156
  };
163
157
 
164
158
  Mutiny.toggler = {
165
- defaults: {
166
- style: {
167
- display: "none"
168
- },
169
- preventDefault: false,
170
- instigatorClass: "active"
171
- },
172
- string_arg: "target",
173
- init: function($instigator, options) {
174
- var $target = $(options.target);
175
- var targetFunc;
176
- if (options["class"]) {
177
- targetFunc = function(on) {
178
- $target.toggleClass(options["class"], on);
179
- };
180
- } else {
181
- var noStyle = {};
182
- for (var key in options.style) {
183
- noStyle[key] = $target.css(key);
184
- }
185
- targetFunc = function(on) {
186
- $target.css(on ? options.style : noStyle);
187
- };
188
- }
189
- if ($instigator.is("input[type=radio]")) {
190
- var name = $instigator.attr("name");
191
- $('input[name="' + name + '"]').change(function(event) {
192
- var active = $instigator.is(":checked");
193
- $instigator.toggleClass(options.instigatorClass, active);
194
- targetFunc(active);
195
- });
196
- } else {
197
- var active = false;
198
- $instigator.click(function(event) {
199
- active = !active;
200
- $instigator.toggleClass(options.instigatorClass, active);
201
- targetFunc(active);
202
- if (options.preventDefault) {
203
- event.preventDefault();
204
- }
205
- });
159
+ 'defaults': {'style': {'display': 'none'}, 'preventDefault': false, 'instigatorClass': 'active'},
160
+ 'string_arg': 'target',
161
+ 'init': function($instigator, options){
162
+ var $target = $(options.target);
163
+
164
+ var targetFunc;
165
+ if(options['class']) {
166
+ targetFunc = function(on) {
167
+ $target.toggleClass(options['class'], on);
168
+ };
169
+ } else {
170
+ var noStyle = {};
171
+ for(var key in options.style) {
172
+ noStyle[key] = $target.css(key);
173
+ }
174
+
175
+ targetFunc = function(on) {
176
+ $target.css(on ? options.style : noStyle);
177
+ };
178
+ }
179
+
180
+ if($instigator.is('input[type=radio]')) {
181
+ var name = $instigator.attr("name");
182
+ $('input[name="'+ name +'"]').change(function(event){
183
+ var active = $instigator.is(':checked');
184
+ $instigator.toggleClass(options.instigatorClass, active);
185
+ targetFunc(active);
186
+ });
187
+ } else {
188
+ var active = false;
189
+ $instigator.click(function(event) {
190
+ active = !active;
191
+ $instigator.toggleClass(options.instigatorClass, active);
192
+ targetFunc(active);
193
+
194
+ if(options.preventDefault) {
195
+ event.preventDefault();
206
196
  }
197
+ });
207
198
  }
208
- };
199
+ }
200
+ };
201
+
202
+ })(window, jQuery);
@@ -1,2 +1,2 @@
1
- /*! Mutiny v0.1.1 - http://mutinyjs.com/ */
2
- var Mutiny={init:function(a){a=a||"mutiny",$("[data-"+a+"]").mutiny(a)}};$.fn.mutiny=function(a){var t=function(a,t,n){if(void 0===Mutiny[t])throw'"'+t+'" not found';var e=$.extend({},Mutiny[t].defaults);"string"==typeof n?e[Mutiny[t].string_arg]=n:$.extend(e,n),Mutiny[t].init(a,e)};return a=a||"mutiny",this.each(function(n,e){var i=$(e),r=i.data(a);switch(typeof r){case"string":t(i,r,{});break;case"object":for(var s in r)t(i,s,r[s]);break;default:throw"Unsupported data"}}),this},$(function(){Mutiny.init()}),Mutiny.accordion={defaults:{autoHeight:!1,collapsible:!0,active:!1},_hrefIndex:function(a,t){var n=-1;return a.find("a").each(function(a,e){return $(e).attr("href")==t?(n=a,!1):void 0}),n},init:function(a,t){var n=window.location.hash||void 0,e=t.menu?$(t.menu):void 0;if(n){var i=this._hrefIndex(e||a,n);i>-1&&(t.active=i)}if(e){var r=this;e.find("a").click(function(t){var n=r._hrefIndex(e,$(t.target).attr("href"));n>-1&&a.accordion("activate",n)})}a.accordion(t)}},Mutiny.datepicker={init:function(a,t){a.datepicker(t)}},Mutiny.slider={defaults:{range:"min"},_createFormatSpan:function(a,t,n){(null===t||""===t)&&(t="&nbsp;");var e=a.replace("%s","<span>"+t+"</span>");return n?'<span class="'+n+'">'+e+"</span>":"<span>"+e+"</span>"},init:function(a,t){var n;if(t.target)n=$(t.target);else{var e=a.attr("id"),i="";e&&(i=' id="'+e+'-mutiny-slider"'),n=$("<div"+i+"></div>").insertAfter(a)}if(t.value=a.val(),t.slide=function(t,n){a.val(n.value).change()},a.is("select")){var r=a.find("option");t.min=Number(r.first().val()),t.max=Number(r.last().val()),t.step=(t.max-t.min)/(r.length-1)}else t.min=Number(a.attr("min")||a.data("min")),t.max=Number(a.attr("max")||a.data("max")),t.step=Number(a.attr("step")||a.data("step"));if(a.change(function(){var e=Number(a.val());e>t.max&&(e=t.max),t.min>e&&(e=t.min),isNaN(e)&&(e=t.value),a.val(e),n.slider("value",e)}),t.minLabel&&n.append(this._createFormatSpan(t.minLabel,t.min,"min-label")),t.maxLabel&&n.append(this._createFormatSpan(t.maxLabel,t.max,"max-label")),n.slider(t),t.valueLabel){var s=$(this._createFormatSpan(t.valueLabel,t.value,"valueLabel")).appendTo(n.find(".ui-slider-handle")),l=s.find("span");a.change(function(){l.html(a.val())})}}},Mutiny.toggler={defaults:{style:{display:"none"},preventDefault:!1,instigatorClass:"active"},string_arg:"target",init:function(a,t){var n,e=$(t.target);if(t["class"])n=function(a){e.toggleClass(t["class"],a)};else{var i={};for(var r in t.style)i[r]=e.css(r);n=function(a){e.css(a?t.style:i)}}if(a.is("input[type=radio]")){var s=a.attr("name");$('input[name="'+s+'"]').change(function(){var e=a.is(":checked");a.toggleClass(t.instigatorClass,e),n(e)})}else{var l=!1;a.click(function(e){l=!l,a.toggleClass(t.instigatorClass,l),n(l),t.preventDefault&&e.preventDefault()})}}};
1
+ /*! Mutiny v0.2.0 - http://mutinyjs.com/ */
2
+ (function(a,n,e){function t(a){return!!a.substring}n(function(){i.init()});var i=a.Mutiny={init:function(a,r){r=r||"mutiny",a=a||n("*");var l=function(a,r,l){if(i[r]===e)throw'"'+r+'" not found';var s=n.extend({},i[r].defaults);t(l)?s[i[r].string_arg]=l:n.extend(s,l),i[r].init(a,s)};a.each(function(a,e){var i=n(e),s=i.data();if(r in s){var o=s[r];if(t(o))l(i,o,{});else{if("object"!=typeof s)throw"Unsupported data";for(var c in o)l(i,c,o[c])}}for(var u in s)if(0===u.indexOf(r)&&u!=r){var f=u.replace(r,"").toLowerCase(),v=s[u];l(i,f,v||{})}})}};i.accordion={defaults:{autoHeight:!1,collapsible:!0,active:!1},init:function(e,t){var i=a.location.hash;i&&e.find(i).length>0&&(t.active=i),e.accordion(t),n(a).on("hashchange",function(){var n=a.location.hash;n&&e.find(n).length>0&&e.accordion("activate",n)})}},i.datepicker={init:function(a,n){a.datepicker(n)}},i.slider={defaults:{range:"min"},_createFormatSpan:function(a,n,e){(null===n||""===n)&&(n="&nbsp;");var t=a.replace("%s","<span>"+n+"</span>");return e?'<span class="'+e+'">'+t+"</span>":"<span>"+t+"</span>"},init:function(a,e){var t;if(e.target)t=n(e.target);else{var i=a.attr("id"),r="";i&&(r=' id="'+i+'-mutiny-slider"'),t=n("<div"+r+"></div>").insertAfter(a)}if(e.value=a.val(),e.slide=function(n,e){a.val(e.value).change()},a.is("select")){var l=a.find("option");e.min=Number(l.first().val()),e.max=Number(l.last().val()),e.step=(e.max-e.min)/(l.length-1)}else n.each(["min","max","step"],function(n,t){e[t]=Number(e[t]||a.attr(t)||a.data(t))});if(a.change(function(){var n=Number(a.val());n>e.max&&(n=e.max),e.min>n&&(n=e.min),isNaN(n)&&(n=e.value),a.val(n),t.slider("value",n)}),e.minLabel&&t.append(this._createFormatSpan(e.minLabel,e.min,"min-label")),e.maxLabel&&t.append(this._createFormatSpan(e.maxLabel,e.max,"max-label")),t.slider(e),e.valueLabel){var s=n(this._createFormatSpan(e.valueLabel,e.value,"value-label")).appendTo(t.find(".ui-slider-handle")),o=s.find("span");a.change(function(){o.html(a.val())})}}},i.toggler={defaults:{style:{display:"none"},preventDefault:!1,instigatorClass:"active"},string_arg:"target",init:function(a,e){var t,i=n(e.target);if(e["class"])t=function(a){i.toggleClass(e["class"],a)};else{var r={};for(var l in e.style)r[l]=i.css(l);t=function(a){i.css(a?e.style:r)}}if(a.is("input[type=radio]")){var s=a.attr("name");n('input[name="'+s+'"]').change(function(){var n=a.is(":checked");a.toggleClass(e.instigatorClass,n),t(n)})}else{var o=!1;a.click(function(n){o=!o,a.toggleClass(e.instigatorClass,o),t(o),e.preventDefault&&n.preventDefault()})}}}})(window,jQuery);
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: mutiny-rails
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.1
4
+ version: 0.2.0
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -9,7 +9,7 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2013-02-22 00:00:00.000000000 Z
12
+ date: 2013-04-03 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: rails