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.
- data/.gitignore +1 -0
- data/Rakefile +1 -1
- data/lib/metro/ui/rails/engine.rb +1 -1
- data/lib/metro/ui/rails/version.rb +1 -1
- data/vendor/assets/fonts/metro-ui/iconFont.eot +0 -0
- data/vendor/assets/fonts/metro-ui/iconFont.svg +383 -334
- data/vendor/assets/fonts/metro-ui/iconFont.ttf +0 -0
- data/vendor/assets/fonts/metro-ui/iconFont.woff +0 -0
- data/vendor/assets/javascripts/metro-ui.js +6 -5
- data/vendor/assets/javascripts/metro-ui/accordion.js +2 -2
- data/vendor/assets/javascripts/metro-ui/input-control.js +3 -3
- data/vendor/assets/javascripts/metro-ui/tile-drag.js +332 -0
- data/vendor/toolkit/metro-ui/buttons.less +9 -0
- data/vendor/toolkit/metro-ui/forms.less +55 -11
- data/vendor/toolkit/metro-ui/icons.less +93 -9
- data/vendor/toolkit/metro-ui/jqgrid.less +12 -0
- data/vendor/toolkit/metro-ui/layout.less +4 -4
- data/vendor/toolkit/metro-ui/listview.less +7 -7
- data/vendor/toolkit/metro-ui/menus.less +23 -2
- data/vendor/toolkit/metro-ui/notices.less +2 -0
- data/vendor/toolkit/metro-ui/routines.less +5 -5
- data/vendor/toolkit/metro-ui/typography.less +12 -12
- metadata +4 -3
Binary file
|
Binary file
|
@@ -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 = $
|
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 = $
|
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],
|
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
|
-
|
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:
|
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
|
-
|
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
|
-
|
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
|
-
|
378
|
+
font-family: iconFont;
|
379
|
+
font-size: 12px;
|
380
|
+
content: "\e089";
|
351
381
|
left: 7px;
|
352
|
-
top:
|
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
|
}
|