metro-ui-rails 0.15.8.4 → 0.15.8.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,9 +1,10 @@
1
- //= require metro-ui/accordion
2
- //= require metro-ui/buttonset
3
- //= require metro-ui/carousel
4
- //= require metro-ui/dropdown
5
1
  //= require metro-ui/input-control
6
- //= require metro-ui/pagecontrol
7
2
  //= require metro-ui/rating
3
+ //= require metro-ui/dropdown
8
4
  //= require metro-ui/slider
9
5
  //= require metro-ui/tile-slider
6
+ //= require metro-ui/tile-drag
7
+ //= require metro-ui/pagecontrol
8
+ //= require metro-ui/carousel
9
+ //= require metro-ui/buttonset
10
+ //= require metro-ui/accordion
@@ -6,14 +6,14 @@
6
6
  var $this = $(this)
7
7
  , $li = $this.children("li")
8
8
  , $triggers = $li.children("a")
9
- , $frames = $this.find("li div")
9
+ , $frames = $li.children("div")
10
10
  ;
11
11
 
12
12
  var initTriggers = function(triggers){
13
13
  triggers.on('click', function(e){
14
14
  e.preventDefault();
15
15
  var $a = $(this)
16
- , target = $($a.parent('li').children("div"));
16
+ , target = $a.parent('li').children("div");
17
17
 
18
18
  if ( $a.parent('li').hasClass('active') ) {
19
19
  target.slideUp();
@@ -42,7 +42,7 @@
42
42
  input = $element.children('input');
43
43
  input.attr('value', '');
44
44
  input.focus();
45
- });
45
+ }).on('click', function(e){e.preventDefault(); return false;});
46
46
  };
47
47
 
48
48
  /**
@@ -67,14 +67,14 @@
67
67
  password.hide();
68
68
  text.insertAfter(password);
69
69
  text.attr('value', password.attr('value'));
70
- });
70
+ }).on('click', function(e){e.preventDefault(); return false;});
71
71
 
72
72
  // return password and remove text element
73
73
  $helper.on('mouseup, mouseout', function () {
74
74
  text.detach();
75
75
  password.show();
76
76
  password.focus();
77
- });
77
+ }).on('click', function(e){e.preventDefault(); return false;});
78
78
  };
79
79
 
80
80
  plugin.init();
@@ -0,0 +1,332 @@
1
+ /**
2
+ * jQuery plugin for drag'n'drop tiles
3
+ *
4
+ * to init plugin just add class 'tile-drag' to your tile-group element
5
+ * or add attribute data-role="tile-drag"
6
+ *
7
+ * to handle drag/drop events use next code
8
+
9
+ $(function(){
10
+ $('#tile_group_id').on('drag', function(e, draggingTile, parentGroup){
11
+ ... your code ...
12
+ });
13
+ $('#tile_group_id').on('drop', function(e, draggingTile, targetGroup){
14
+ ... your code ...
15
+ });
16
+ });
17
+
18
+ *
19
+ * if you want to use drag'n'drop between groups use attribute data-param-group="any_id" to link groups
20
+ */
21
+ (function($) {
22
+
23
+ $.TileDrag = function(element, options) {
24
+
25
+ var defaults = {
26
+ // if group sets and exists other same groups, it is possible to drag'n'drop from one group to another
27
+ group: null
28
+ };
29
+
30
+ var plugin = this;
31
+
32
+ plugin.settings = {};
33
+
34
+ var $element = $(element),
35
+ $groups,
36
+ settings,
37
+ tiles,
38
+ $draggingTile,
39
+ $parentGroup, // parent group for dragging tile
40
+ draggingTileWidth,
41
+ draggingTileHeight,
42
+ $phantomTile,
43
+ tileDeltaX,
44
+ tileDeltaY,
45
+ groupOffsetX,
46
+ groupOffsetY,
47
+ tilesCoordinates,
48
+ tileSearchCount = 0, // uses for findTileUnderCursor function
49
+ tileUnderCursorIndex,
50
+ tileUnderCursorSide;
51
+
52
+ plugin.init = function() {
53
+ settings = plugin.settings = $.extend({}, defaults, options);
54
+
55
+ // if group is set
56
+ if (settings.group) {
57
+ // search other elements with same group
58
+ $groups = $('[data-role=tile-drag], .tile-drag').filter('[data-param-group=' + settings.group + ']');
59
+ } else {
60
+ $groups = $element;
61
+ }
62
+
63
+ // any tile-group must be relative
64
+ $groups.css({
65
+ 'position': 'relative'
66
+ });
67
+
68
+ // select all tiles within group
69
+ tiles = $groups.children('.tile');
70
+
71
+ tiles.on('mousedown', startDrag);
72
+
73
+ };
74
+
75
+ var startDrag = function(event) {
76
+ var $tile,
77
+ tilePosition,
78
+ tilePositionX,
79
+ tilePositionY,
80
+ groupOffset;
81
+
82
+ event.preventDefault();
83
+
84
+ // currently dragging tile
85
+ $draggingTile = $tile = $(this);
86
+
87
+ // search parent group
88
+ $parentGroup = $tile.parents('.tile-drag');
89
+
90
+ // dragging tile dimentions
91
+ draggingTileWidth = $tile.outerWidth();
92
+ draggingTileHeight = $tile.outerHeight();
93
+
94
+ // hidden tile to place it where dragging tile will dropped
95
+ $phantomTile = $('<div></div>');
96
+ $phantomTile.css({
97
+ 'background': 'none'
98
+ });
99
+ $phantomTile.addClass('tile');
100
+ if ($tile.hasClass('double')) {
101
+ $phantomTile.addClass('double');
102
+ } else if ($tile.hasClass('triple')) {
103
+ $phantomTile.addClass('triple');
104
+ } else if ($tile.hasClass('quadro')) {
105
+ $phantomTile.addClass('quadro');
106
+ } else if ($tile.hasClass('double-vertical')) {
107
+ $phantomTile.addClass('double-vertical');
108
+ } else if ($tile.hasClass('triple-vertical')) {
109
+ $phantomTile.addClass('triple-vertical');
110
+ } else if ($tile.hasClass('quadro-vertical')) {
111
+ $phantomTile.addClass('quadro-vertical');
112
+ }
113
+
114
+ // dragging tile position within group
115
+ tilePosition = $tile.position();
116
+ tilePositionX = tilePosition.left;
117
+ tilePositionY = tilePosition.top;
118
+
119
+ // group element offset relate to document border
120
+ groupOffset = $parentGroup.offset();
121
+ groupOffsetX = groupOffset.left;
122
+ groupOffsetY = groupOffset.top;
123
+
124
+ // pixels count between cursor and dragging tile border
125
+ tileDeltaX = event.pageX - groupOffsetX - tilePositionX;
126
+ tileDeltaY = event.pageY - groupOffsetY - tilePositionY;
127
+
128
+ // place phantom tile instead dragging one
129
+ $phantomTile.insertAfter($tile);
130
+
131
+ /*$tile.detach();
132
+ $tile.appendTo($parentGroup);*/
133
+
134
+ // still now it absolutely positioned
135
+ $tile.css({
136
+ 'position': 'absolute',
137
+ 'left': tilePositionX,
138
+ 'top': tilePositionY,
139
+ 'z-index': 100000
140
+ });
141
+
142
+ // store it for future
143
+ $tile.data('dragging', true);
144
+ storeTilesCoordinates();
145
+
146
+ // some necessary event handlers
147
+ $(document).on('mousemove.tiledrag', dragTile);
148
+ $(document).on('mouseup.tiledrag', dragStop);
149
+
150
+ // triggering event
151
+ $groups.trigger('drag', [$draggingTile, $parentGroup]);
152
+ };
153
+
154
+ /**
155
+ * it function called on every mousemove event
156
+ */
157
+ var dragTile = function (event) {
158
+
159
+ // all we need is index of tile under cursor (and under dragging tile) if it exists
160
+ var findTileIndex;
161
+
162
+ event.preventDefault();
163
+
164
+ // move dragging tile
165
+ $draggingTile.css({
166
+ 'left': event.pageX - groupOffsetX - tileDeltaX,
167
+ 'top': event.pageY - groupOffsetY - tileDeltaY
168
+ });
169
+
170
+ findTileIndex = findTileUnderCursor(event);
171
+ if (findTileIndex) {
172
+ clearPlaceForTile($(tiles[findTileIndex]));
173
+ }
174
+ };
175
+
176
+ /**
177
+ * when this function called dragging tile dropping to clear place (instead phantom tile)
178
+ * removing events
179
+ * and some other necessary changes
180
+ */
181
+ var dragStop = function (event) {
182
+ var targetGroup;
183
+
184
+ event.preventDefault();
185
+
186
+ $(document).off('mousemove.tiledrag');
187
+ $(document).off('mouseup.tiledrag');
188
+
189
+ $draggingTile.detach();
190
+ $draggingTile.insertAfter($phantomTile);
191
+
192
+ targetGroup = $phantomTile.parents('.tile-drag');
193
+ $phantomTile.remove();
194
+
195
+ $draggingTile.css({
196
+ 'position': '',
197
+ 'left': '',
198
+ 'top': '',
199
+ 'z-index': ''
200
+ });
201
+
202
+ $draggingTile.data('dragging', false);
203
+
204
+ $groups.trigger('drop', [$draggingTile, targetGroup]);
205
+ };
206
+
207
+ /*
208
+ * stores tiles coordinates for future finding one tile under cursor
209
+ * excluding current dragging tile
210
+ */
211
+ var storeTilesCoordinates = function () {
212
+ tilesCoordinates = {};
213
+ tiles.each(function (index, tile) {
214
+ var $tile, offset;
215
+
216
+ $tile = $(tile);
217
+
218
+ // we dont need dragging tile coordinates
219
+ if ($tile.data('dragging')) return;
220
+
221
+ offset = $tile.offset();
222
+ // it is not real coordinates related to document border
223
+ // but corrected for less computing during dragging (tile moving)
224
+ tilesCoordinates[index] = {
225
+ x1: offset.left + tileDeltaX - draggingTileWidth / 2,
226
+ y1: offset.top + tileDeltaY - draggingTileHeight / 2,
227
+ x2: offset.left + $tile.outerWidth() + tileDeltaX - draggingTileWidth / 2,
228
+ y2: offset.top + $tile.outerHeight() + tileDeltaY - draggingTileHeight / 2
229
+ }
230
+ });
231
+ };
232
+
233
+ /**
234
+ * search tile under cursor using tileCoordinates from storeTilesCoordinates function
235
+ * search occurred only one time per ten times for less load and more smooth
236
+ */
237
+ var findTileUnderCursor = function (event) {
238
+ var i, coord,
239
+ tileIndex = false,
240
+ tileSide;
241
+
242
+ if (tileSearchCount < 10) {
243
+ tileSearchCount++;
244
+ return false;
245
+ }
246
+ tileSearchCount = 0;
247
+
248
+ for (i in tilesCoordinates) {
249
+ if (!tilesCoordinates.hasOwnProperty(i)) return;
250
+ coord = tilesCoordinates[i];
251
+ if (coord.x1 < event.pageX && event.pageX < coord.x2 && coord.y1 < event.pageY && event.pageY < coord.y2) {
252
+ tileIndex = i;
253
+ break;
254
+ }
255
+ }
256
+
257
+ // detect side of tile (left or right) to clear place before or after tile
258
+ if (tileIndex) {
259
+ if (event.pageX < coord.x1 + $(tiles[tileIndex]).outerWidth() / 2) {
260
+ tileSide = 'before';
261
+ } else {
262
+ tileSide = 'after';
263
+ }
264
+ }
265
+ if (tileSide === tileUnderCursorSide && tileIndex === tileUnderCursorIndex) {
266
+ return false;
267
+ }
268
+ tileUnderCursorSide = tileSide;
269
+ tileUnderCursorIndex = tileIndex;
270
+
271
+ return tileIndex;
272
+ };
273
+
274
+ /**
275
+ * just put phantom tile near tile under cursor (before or after)
276
+ * and remove previous phantom tile
277
+ */
278
+ var clearPlaceForTile = function ($tileUnderCursor) {
279
+ var $oldPhantomTile,
280
+ groupOffset;
281
+
282
+ $oldPhantomTile = $phantomTile;
283
+ $phantomTile = $oldPhantomTile.clone();
284
+
285
+ // before or after, this is question ...
286
+ if (tileUnderCursorSide === 'before') {
287
+ $phantomTile.insertBefore($tileUnderCursor);
288
+ } else {
289
+ $phantomTile.insertAfter($tileUnderCursor);
290
+ }
291
+
292
+ $oldPhantomTile.remove();
293
+ // it is necessary to store new tile coordinates
294
+ storeTilesCoordinates();
295
+ // and parent group coordinates
296
+ groupOffset = $parentGroup.offset();
297
+ groupOffsetX = groupOffset.left;
298
+ groupOffsetY = groupOffset.top;
299
+ };
300
+
301
+ // return all groups involved to this plugin
302
+ plugin.getGroups = function () {
303
+ return $groups;
304
+ };
305
+
306
+ plugin.init();
307
+
308
+ };
309
+
310
+ $.fn.TileDrag = function(options) {
311
+
312
+ return this.each(function() {
313
+ if (undefined == $(this).data('TileDrag')) {
314
+ var plugin = new $.TileDrag(this, options);
315
+ var $groups = plugin.getGroups();
316
+ $groups.data('TileDrag', plugin);
317
+ }
318
+ });
319
+
320
+ };
321
+
322
+ })(jQuery);
323
+
324
+ $(function(){
325
+ var allTileGroups = $('[data-role=tile-drag], .tile-drag');
326
+ allTileGroups.each(function (index, tileGroup) {
327
+ var params = {};
328
+ $tileGroup = $(tileGroup);
329
+ params.group = $tileGroup.data('paramGroup');
330
+ $tileGroup.TileDrag(params);
331
+ });
332
+ });
@@ -8,6 +8,8 @@
8
8
 
9
9
  @logo: url();
10
10
  @img-back-button: url();
11
+ @img-back-button-white: url();
12
+
11
13
 
12
14
  .modern-ui-logo, .metro-ui-logo {
13
15
  height: 28px;
@@ -38,6 +40,10 @@
38
40
  }
39
41
  &.page-back {
40
42
  }
43
+
44
+ &.white {
45
+ background-image: @img-back-button-white;
46
+ }
41
47
  }
42
48
 
43
49
  button, .button {
@@ -89,6 +95,9 @@ a.button {
89
95
  &:hover, &:active {
90
96
  color: inherit;
91
97
  }
98
+ &.big {
99
+ padding: 14px 10px;
100
+ }
92
101
  }
93
102
 
94
103
  button, .button, .tool-button {
@@ -260,15 +260,22 @@
260
260
 
261
261
  //Input text, password, ...
262
262
 
263
- .input-control > input[type=text], .input-control > input[type=email], .input-control > input[type=url], .input-control > input[type=phone], .input-control > input[type=password], .input-control > select, .input-control > textarea {
263
+ .input-control > input[type=text],
264
+ .input-control > input[type=email],
265
+ .input-control > input[type=url],
266
+ .input-control > input[type=phone],
267
+ .input-control > input[type=password],
268
+ .input-control > select,
269
+ .input-control > textarea {
264
270
  border: 2px #bababa solid;
265
271
  width: 100%;
266
272
  padding: 4px 32px 6px 5px;
267
- .pos-rel;
268
273
  background-color: #fff;
269
274
  outline: 0;
270
275
  margin-right: 32px;
271
- width: 100%;
276
+ min-height: 32px;
277
+ .pos-rel;
278
+
272
279
 
273
280
  &:disabled {
274
281
  background-color: #eaeaea;
@@ -278,6 +285,17 @@
278
285
  }
279
286
  }
280
287
 
288
+ .input-control > input[type=text]::-ms-clear,
289
+ .input-control > input[type=email]::-ms-clear,
290
+ .input-control > input[type=url]::-ms-clear,
291
+ .input-control > input[type=phone]::-ms-clear {
292
+ display: none;
293
+ }
294
+ .input-control > input[type=password]::-ms-reveal {
295
+ display: none;
296
+ }
297
+
298
+
281
299
  .input-control > select {
282
300
  padding-right: 5px;
283
301
  }
@@ -307,31 +325,40 @@
307
325
  position: relative;
308
326
 
309
327
  &.text, &.password {
310
- .helper {
328
+ .helper, .btn-search {
311
329
  background: #fff;// @textbox_pass_inactive_icon 50% no-repeat;
312
- right: 3px;
313
330
  top: 2px;
314
- width: 26px;
315
- height: 26px;
331
+ width: 26px !important;
332
+ height: 27px !important;
333
+ min-width: 26px !important;
334
+ min-height: 27px !important;
316
335
  cursor: pointer;
317
336
  color: #000;
318
- .pos-abs;
337
+ position: absolute;
338
+ left: 100%;
339
+ margin-left: -28px;
340
+ display: block;
341
+ border: 1px #fff solid;
319
342
 
320
343
  &:before {
344
+ //content: "";
321
345
  font-size: 12pt;
322
- .pos-abs;
346
+ position: absolute;
323
347
  #font > .normal;
324
348
  }
325
349
 
350
+
326
351
  &:hover {
327
352
  background: #d9d9d9;// @textbox_pass_inactive_icon 50% no-repeat;
328
353
  }
329
354
 
330
355
  &:active {
331
356
  background-color: #000;
357
+
332
358
  &:before {
333
359
  color: #fff;
334
360
  }
361
+
335
362
  }
336
363
  }
337
364
  }
@@ -346,11 +373,28 @@
346
373
  }
347
374
  &.text {
348
375
  .helper {
376
+
349
377
  &:before {
350
- content: "\2715";
378
+ font-family: iconFont;
379
+ font-size: 12px;
380
+ content: "\e089";
351
381
  left: 7px;
352
- top: 4px;
382
+ top: 3px;
353
383
  }
384
+
385
+ }
386
+ }
387
+ &.text {
388
+ .btn-search {
389
+
390
+ &:before {
391
+ font-family: iconFont;
392
+ font-size: 12px;
393
+ content: "\e041";
394
+ left: 7px;
395
+ top: 3px;
396
+ }
397
+
354
398
  }
355
399
  }
356
400
  }