houston-core 0.5.4 → 0.5.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (54) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile.lock +20 -22
  3. data/README.md +1 -1
  4. data/app/adapters/houston/adapters/version_control/git_adapter/repo.rb +6 -3
  5. data/app/assets/javascripts/app/boot.coffee +9 -0
  6. data/app/assets/javascripts/app/infinite_scroll.coffee +6 -3
  7. data/app/assets/javascripts/app/models/ticket.coffee +1 -1
  8. data/app/assets/javascripts/core/app.coffee +4 -1
  9. data/app/assets/javascripts/core/core_ext/array.coffee +11 -0
  10. data/app/assets/javascripts/core/core_ext/date.coffee +8 -0
  11. data/app/assets/javascripts/core/handlebars_helpers.coffee +12 -8
  12. data/app/assets/javascripts/vendor.js +2 -2
  13. data/app/assets/stylesheets/application/mobile.scss +96 -0
  14. data/app/assets/stylesheets/application/test.scss +58 -0
  15. data/app/assets/stylesheets/application/test_run.scss +14 -5
  16. data/app/assets/stylesheets/application/timeline.scss +2 -4
  17. data/app/concerns/commit_synchronizer.rb +38 -2
  18. data/app/controllers/application_controller.rb +3 -0
  19. data/app/controllers/hooks_controller.rb +18 -0
  20. data/app/controllers/project_tests_controller.rb +46 -0
  21. data/app/helpers/commit_helper.rb +7 -0
  22. data/app/helpers/test_run_helper.rb +16 -0
  23. data/app/models/commit.rb +4 -0
  24. data/app/models/github/pull_request.rb +7 -7
  25. data/app/models/milestone.rb +1 -1
  26. data/app/models/run_tests_on_post_receive.rb +2 -0
  27. data/app/models/test.rb +4 -0
  28. data/app/models/test_result.rb +1 -1
  29. data/app/models/test_run.rb +25 -2
  30. data/app/views/layouts/_mobile_navigation.html.erb +100 -0
  31. data/app/views/layouts/application.html.erb +20 -10
  32. data/app/views/layouts/dashboard.html.erb +1 -1
  33. data/app/views/layouts/minimal.html.erb +1 -1
  34. data/app/views/layouts/naked_dashboard.html.erb +1 -1
  35. data/app/views/project_notification/test_run.html.erb +97 -120
  36. data/app/views/project_tests/_commits.html.erb +14 -0
  37. data/app/views/project_tests/index.html.erb +39 -0
  38. data/app/views/projects/_form.html.erb +6 -2
  39. data/config/application.rb +1 -2
  40. data/config/routes.rb +2 -0
  41. data/db/migrate/20151108221505_convert_pull_request_labels_to_array.rb +22 -0
  42. data/db/migrate/20151108223154_sync_body_also_for_pull_requests.rb +5 -0
  43. data/db/migrate/20151108233510_add_props_to_pull_requests.rb +5 -0
  44. data/db/structure.sql +10 -1
  45. data/houston.gemspec +4 -5
  46. data/lib/houston/version.rb +1 -1
  47. data/test/integration/web_hook_test.rb +7 -1
  48. data/test/unit/concerns/commit_synchronizer_test.rb +13 -0
  49. data/test/unit/models/pull_request_test.rb +17 -0
  50. data/vendor/assets/javascripts/showdown.js +2489 -0
  51. data/vendor/assets/javascripts/slideout.js +493 -0
  52. metadata +25 -29
  53. data/lib/tasks/config.rake +0 -255
  54. data/vendor/assets/javascripts/Markdown.Converter.js +0 -1412
@@ -0,0 +1,493 @@
1
+ !function(e){if("object"==typeof exports&&"undefined"!=typeof module)module.exports=e();else if("function"==typeof define&&define.amd)define([],e);else{var f;"undefined"!=typeof window?f=window:"undefined"!=typeof global?f=global:"undefined"!=typeof self&&(f=self),f.Slideout=e()}}(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){
2
+ 'use strict';
3
+
4
+ /**
5
+ * Module dependencies
6
+ */
7
+ var decouple = require('decouple');
8
+ var Emitter = require('emitter');
9
+
10
+ /**
11
+ * Privates
12
+ */
13
+ var scrollTimeout;
14
+ var scrolling = false;
15
+ var doc = window.document;
16
+ var html = doc.documentElement;
17
+ var msPointerSupported = window.navigator.msPointerEnabled;
18
+ var touch = {
19
+ 'start': msPointerSupported ? 'MSPointerDown' : 'touchstart',
20
+ 'move': msPointerSupported ? 'MSPointerMove' : 'touchmove',
21
+ 'end': msPointerSupported ? 'MSPointerUp' : 'touchend'
22
+ };
23
+ var prefix = (function prefix() {
24
+ var regex = /^(Webkit|Khtml|Moz|ms|O)(?=[A-Z])/;
25
+ var styleDeclaration = doc.getElementsByTagName('script')[0].style;
26
+ for (var prop in styleDeclaration) {
27
+ if (regex.test(prop)) {
28
+ return '-' + prop.match(regex)[0].toLowerCase() + '-';
29
+ }
30
+ }
31
+ // Nothing found so far? Webkit does not enumerate over the CSS properties of the style object.
32
+ // However (prop in style) returns the correct value, so we'll have to test for
33
+ // the precence of a specific property
34
+ if ('WebkitOpacity' in styleDeclaration) { return '-webkit-'; }
35
+ if ('KhtmlOpacity' in styleDeclaration) { return '-khtml-'; }
36
+ return '';
37
+ }());
38
+ function extend(destination, from) {
39
+ for (var prop in from) {
40
+ if (from[prop]) {
41
+ destination[prop] = from[prop];
42
+ }
43
+ }
44
+ return destination;
45
+ }
46
+ function inherits(child, uber) {
47
+ child.prototype = extend(child.prototype || {}, uber.prototype);
48
+ }
49
+
50
+ /**
51
+ * Slideout constructor
52
+ */
53
+ function Slideout(options) {
54
+ options = options || {};
55
+
56
+ // Sets default values
57
+ this._startOffsetX = 0;
58
+ this._currentOffsetX = 0;
59
+ this._opening = false;
60
+ this._moved = false;
61
+ this._opened = false;
62
+ this._preventOpen = false;
63
+ this._touch = options.touch === undefined ? true : options.touch && true;
64
+
65
+ // Sets panel
66
+ this.panel = options.panel;
67
+ this.menu = options.menu;
68
+
69
+ // Sets classnames
70
+ if(this.panel.className.search('slideout-panel') === -1) { this.panel.className += ' slideout-panel'; }
71
+ if(this.menu.className.search('slideout-menu') === -1) { this.menu.className += ' slideout-menu'; }
72
+
73
+
74
+ // Sets options
75
+ this._fx = options.fx || 'ease';
76
+ this._duration = parseInt(options.duration, 10) || 300;
77
+ this._tolerance = parseInt(options.tolerance, 10) || 70;
78
+ this._padding = this._translateTo = parseInt(options.padding, 10) || 256;
79
+ this._orientation = options.side === 'right' ? -1 : 1;
80
+ this._translateTo *= this._orientation;
81
+
82
+ // Init touch events
83
+ if (this._touch) {
84
+ this._initTouchEvents();
85
+ }
86
+ }
87
+
88
+ /**
89
+ * Inherits from Emitter
90
+ */
91
+ inherits(Slideout, Emitter);
92
+
93
+ /**
94
+ * Opens the slideout menu.
95
+ */
96
+ Slideout.prototype.open = function() {
97
+ var self = this;
98
+ this.emit('beforeopen');
99
+ if (html.className.search('slideout-open') === -1) { html.className += ' slideout-open'; }
100
+ this._setTransition();
101
+ this._translateXTo(this._translateTo);
102
+ this._opened = true;
103
+ setTimeout(function() {
104
+ self.panel.style.transition = self.panel.style['-webkit-transition'] = '';
105
+ self.emit('open');
106
+ }, this._duration + 50);
107
+ return this;
108
+ };
109
+
110
+ /**
111
+ * Closes slideout menu.
112
+ */
113
+ Slideout.prototype.close = function() {
114
+ var self = this;
115
+ if (!this.isOpen() && !this._opening) { return this; }
116
+ this.emit('beforeclose');
117
+ this._setTransition();
118
+ this._translateXTo(0);
119
+ this._opened = false;
120
+ setTimeout(function() {
121
+ html.className = html.className.replace(/ slideout-open/, '');
122
+ self.panel.style.transition = self.panel.style['-webkit-transition'] = self.panel.style[prefix + 'transform'] = self.panel.style.transform = '';
123
+ self.emit('close');
124
+ }, this._duration + 50);
125
+ return this;
126
+ };
127
+
128
+ /**
129
+ * Toggles (open/close) slideout menu.
130
+ */
131
+ Slideout.prototype.toggle = function() {
132
+ return this.isOpen() ? this.close() : this.open();
133
+ };
134
+
135
+ /**
136
+ * Returns true if the slideout is currently open, and false if it is closed.
137
+ */
138
+ Slideout.prototype.isOpen = function() {
139
+ return this._opened;
140
+ };
141
+
142
+ /**
143
+ * Translates panel and updates currentOffset with a given X point
144
+ */
145
+ Slideout.prototype._translateXTo = function(translateX) {
146
+ this._currentOffsetX = translateX;
147
+ this.panel.style[prefix + 'transform'] = this.panel.style.transform = 'translate3d(' + translateX + 'px, 0, 0)';
148
+ };
149
+
150
+ /**
151
+ * Set transition properties
152
+ */
153
+ Slideout.prototype._setTransition = function() {
154
+ this.panel.style[prefix + 'transition'] = this.panel.style.transition = prefix + 'transform ' + this._duration + 'ms ' + this._fx;
155
+ };
156
+
157
+ /**
158
+ * Initializes touch event
159
+ */
160
+ Slideout.prototype._initTouchEvents = function() {
161
+ var self = this;
162
+
163
+ /**
164
+ * Decouple scroll event
165
+ */
166
+ this._onScrollFn = decouple(doc, 'scroll', function() {
167
+ if (!self._moved) {
168
+ clearTimeout(scrollTimeout);
169
+ scrolling = true;
170
+ scrollTimeout = setTimeout(function() {
171
+ scrolling = false;
172
+ }, 250);
173
+ }
174
+ });
175
+
176
+ /**
177
+ * Prevents touchmove event if slideout is moving
178
+ */
179
+ this._preventMove = function(eve) {
180
+ if (self._moved) {
181
+ eve.preventDefault();
182
+ }
183
+ };
184
+ doc.addEventListener(touch.move, this._preventMove);
185
+
186
+ /**
187
+ * Resets values on touchstart
188
+ */
189
+ this._resetTouchFn = function(eve) {
190
+ if (typeof eve.touches === 'undefined') { return; }
191
+
192
+ self._moved = false;
193
+ self._opening = false;
194
+ self._startOffsetX = eve.touches[0].pageX;
195
+ self._preventOpen = (!self._touch || (!self.isOpen() && self.menu.clientWidth !== 0));
196
+ };
197
+ this.panel.addEventListener(touch.start, this._resetTouchFn);
198
+
199
+ /**
200
+ * Resets values on touchcancel
201
+ */
202
+ this._onTouchCancelFn = function() {
203
+ self._moved = false;
204
+ self._opening = false;
205
+ };
206
+ this.panel.addEventListener('touchcancel', this._onTouchCancelFn);
207
+
208
+ /**
209
+ * Toggles slideout on touchend
210
+ */
211
+ this._onTouchEndFn = function() {
212
+ if (self._moved) {
213
+ (self._opening && Math.abs(self._currentOffsetX) > self._tolerance) ? self.open() : self.close();
214
+ }
215
+ self._moved = false;
216
+ };
217
+ this.panel.addEventListener(touch.end, this._onTouchEndFn);
218
+
219
+ /**
220
+ * Translates panel on touchmove
221
+ */
222
+ this._onTouchMoveFn = function(eve) {
223
+
224
+ if (scrolling || self._preventOpen || typeof eve.touches === 'undefined') { return; }
225
+
226
+ var dif_x = eve.touches[0].clientX - self._startOffsetX;
227
+ var translateX = self._currentOffsetX = dif_x;
228
+
229
+ if (Math.abs(translateX) > self._padding) { return; }
230
+
231
+ if (Math.abs(dif_x) > 20) {
232
+ self._opening = true;
233
+
234
+ var oriented_dif_x = dif_x * self._orientation;
235
+ if (self._opened && oriented_dif_x > 0 || !self._opened && oriented_dif_x < 0) { return; }
236
+ if (oriented_dif_x <= 0) {
237
+ translateX = dif_x + self._padding * self._orientation;
238
+ self._opening = false;
239
+ }
240
+
241
+ if (!self._moved && html.className.search('slideout-open') === -1) {
242
+ html.className += ' slideout-open';
243
+ }
244
+
245
+ self.panel.style[prefix + 'transform'] = self.panel.style.transform = 'translate3d(' + translateX + 'px, 0, 0)';
246
+ self.emit('translate', translateX);
247
+ self._moved = true;
248
+ }
249
+
250
+ };
251
+ this.panel.addEventListener(touch.move, this._onTouchMoveFn);
252
+ };
253
+
254
+ /**
255
+ * Enable opening the slideout via touch events.
256
+ */
257
+ Slideout.prototype.enableTouch = function() {
258
+ this._touch = true;
259
+ return this;
260
+ };
261
+
262
+ /**
263
+ * Disable opening the slideout via touch events.
264
+ */
265
+ Slideout.prototype.disableTouch = function() {
266
+ this._touch = false;
267
+ return this;
268
+ };
269
+
270
+ /**
271
+ * Destroy an instance of slideout.
272
+ */
273
+ Slideout.prototype.destroy = function() {
274
+ // Close before clean
275
+ this.close();
276
+
277
+ // Remove event listeners
278
+ doc.removeEventListener(touch.move, this._preventMove);
279
+ this.panel.removeEventListener(touch.start, this._resetTouchFn);
280
+ this.panel.removeEventListener('touchcancel', this._onTouchCancelFn);
281
+ this.panel.removeEventListener(touch.end, this._onTouchEndFn);
282
+ this.panel.removeEventListener(touch.move, this._onTouchMoveFn);
283
+ doc.removeEventListener('scroll', this._onScrollFn);
284
+
285
+ // Remove methods
286
+ this.open = this.close = function() {};
287
+
288
+ // Return the instance so it can be easily dereferenced
289
+ return this;
290
+ };
291
+
292
+ /**
293
+ * Expose Slideout
294
+ */
295
+ module.exports = Slideout;
296
+
297
+ },{"decouple":2,"emitter":3}],2:[function(require,module,exports){
298
+ 'use strict';
299
+
300
+ var requestAnimFrame = (function() {
301
+ return window.requestAnimationFrame ||
302
+ window.webkitRequestAnimationFrame ||
303
+ function (callback) {
304
+ window.setTimeout(callback, 1000 / 60);
305
+ };
306
+ }());
307
+
308
+ function decouple(node, event, fn) {
309
+ var eve,
310
+ tracking = false;
311
+
312
+ function captureEvent(e) {
313
+ eve = e;
314
+ track();
315
+ }
316
+
317
+ function track() {
318
+ if (!tracking) {
319
+ requestAnimFrame(update);
320
+ tracking = true;
321
+ }
322
+ }
323
+
324
+ function update() {
325
+ fn.call(node, eve);
326
+ tracking = false;
327
+ }
328
+
329
+ node.addEventListener(event, captureEvent, false);
330
+ }
331
+
332
+ /**
333
+ * Expose decouple
334
+ */
335
+ module.exports = decouple;
336
+
337
+ },{}],3:[function(require,module,exports){
338
+ "use strict";
339
+
340
+ var _classCallCheck = function (instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } };
341
+
342
+ exports.__esModule = true;
343
+ /**
344
+ * Creates a new instance of Emitter.
345
+ * @class
346
+ * @returns {Object} Returns a new instance of Emitter.
347
+ * @example
348
+ * // Creates a new instance of Emitter.
349
+ * var Emitter = require('emitter');
350
+ *
351
+ * var emitter = new Emitter();
352
+ */
353
+
354
+ var Emitter = (function () {
355
+ function Emitter() {
356
+ _classCallCheck(this, Emitter);
357
+ }
358
+
359
+ /**
360
+ * Adds a listener to the collection for the specified event.
361
+ * @memberof! Emitter.prototype
362
+ * @function
363
+ * @param {String} event - The event name.
364
+ * @param {Function} listener - A listener function to add.
365
+ * @returns {Object} Returns an instance of Emitter.
366
+ * @example
367
+ * // Add an event listener to "foo" event.
368
+ * emitter.on('foo', listener);
369
+ */
370
+
371
+ Emitter.prototype.on = function on(event, listener) {
372
+ // Use the current collection or create it.
373
+ this._eventCollection = this._eventCollection || {};
374
+
375
+ // Use the current collection of an event or create it.
376
+ this._eventCollection[event] = this._eventCollection[event] || [];
377
+
378
+ // Appends the listener into the collection of the given event
379
+ this._eventCollection[event].push(listener);
380
+
381
+ return this;
382
+ };
383
+
384
+ /**
385
+ * Adds a listener to the collection for the specified event that will be called only once.
386
+ * @memberof! Emitter.prototype
387
+ * @function
388
+ * @param {String} event - The event name.
389
+ * @param {Function} listener - A listener function to add.
390
+ * @returns {Object} Returns an instance of Emitter.
391
+ * @example
392
+ * // Will add an event handler to "foo" event once.
393
+ * emitter.once('foo', listener);
394
+ */
395
+
396
+ Emitter.prototype.once = function once(event, listener) {
397
+ var self = this;
398
+
399
+ function fn() {
400
+ self.off(event, fn);
401
+ listener.apply(this, arguments);
402
+ }
403
+
404
+ fn.listener = listener;
405
+
406
+ this.on(event, fn);
407
+
408
+ return this;
409
+ };
410
+
411
+ /**
412
+ * Removes a listener from the collection for the specified event.
413
+ * @memberof! Emitter.prototype
414
+ * @function
415
+ * @param {String} event - The event name.
416
+ * @param {Function} listener - A listener function to remove.
417
+ * @returns {Object} Returns an instance of Emitter.
418
+ * @example
419
+ * // Remove a given listener.
420
+ * emitter.off('foo', listener);
421
+ */
422
+
423
+ Emitter.prototype.off = function off(event, listener) {
424
+
425
+ var listeners = undefined;
426
+
427
+ // Defines listeners value.
428
+ if (!this._eventCollection || !(listeners = this._eventCollection[event])) {
429
+ return this;
430
+ }
431
+
432
+ listeners.forEach(function (fn, i) {
433
+ if (fn === listener || fn.listener === listener) {
434
+ // Removes the given listener.
435
+ listeners.splice(i, 1);
436
+ }
437
+ });
438
+
439
+ // Removes an empty event collection.
440
+ if (listeners.length === 0) {
441
+ delete this._eventCollection[event];
442
+ }
443
+
444
+ return this;
445
+ };
446
+
447
+ /**
448
+ * Execute each item in the listener collection in order with the specified data.
449
+ * @memberof! Emitter.prototype
450
+ * @function
451
+ * @param {String} event - The name of the event you want to emit.
452
+ * @param {...Object} data - Data to pass to the listeners.
453
+ * @returns {Object} Returns an instance of Emitter.
454
+ * @example
455
+ * // Emits the "foo" event with 'param1' and 'param2' as arguments.
456
+ * emitter.emit('foo', 'param1', 'param2');
457
+ */
458
+
459
+ Emitter.prototype.emit = function emit(event) {
460
+ var _this = this;
461
+
462
+ for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
463
+ args[_key - 1] = arguments[_key];
464
+ }
465
+
466
+ var listeners = undefined;
467
+
468
+ // Defines listeners value.
469
+ if (!this._eventCollection || !(listeners = this._eventCollection[event])) {
470
+ return this;
471
+ }
472
+
473
+ // Clone listeners
474
+ listeners = listeners.slice(0);
475
+
476
+ listeners.forEach(function (fn) {
477
+ return fn.apply(_this, args);
478
+ });
479
+
480
+ return this;
481
+ };
482
+
483
+ return Emitter;
484
+ })();
485
+
486
+ /**
487
+ * Exports Emitter
488
+ */
489
+ exports["default"] = Emitter;
490
+ module.exports = exports["default"];
491
+ },{}]},{},[1])(1)
492
+ });
493
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["node_modules/browserify/node_modules/browser-pack/_prelude.js","index.js","node_modules/decouple/index.js","node_modules/emitter/dist/index.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","'use strict';\n\n/**\n * Module dependencies\n */\nvar decouple = require('decouple');\nvar Emitter = require('emitter');\n\n/**\n * Privates\n */\nvar scrollTimeout;\nvar scrolling = false;\nvar doc = window.document;\nvar html = doc.documentElement;\nvar msPointerSupported = window.navigator.msPointerEnabled;\nvar touch = {\n  'start': msPointerSupported ? 'MSPointerDown' : 'touchstart',\n  'move': msPointerSupported ? 'MSPointerMove' : 'touchmove',\n  'end': msPointerSupported ? 'MSPointerUp' : 'touchend'\n};\nvar prefix = (function prefix() {\n  var regex = /^(Webkit|Khtml|Moz|ms|O)(?=[A-Z])/;\n  var styleDeclaration = doc.getElementsByTagName('script')[0].style;\n  for (var prop in styleDeclaration) {\n    if (regex.test(prop)) {\n      return '-' + prop.match(regex)[0].toLowerCase() + '-';\n    }\n  }\n  // Nothing found so far? Webkit does not enumerate over the CSS properties of the style object.\n  // However (prop in style) returns the correct value, so we'll have to test for\n  // the precence of a specific property\n  if ('WebkitOpacity' in styleDeclaration) { return '-webkit-'; }\n  if ('KhtmlOpacity' in styleDeclaration) { return '-khtml-'; }\n  return '';\n}());\nfunction extend(destination, from) {\n  for (var prop in from) {\n    if (from[prop]) {\n      destination[prop] = from[prop];\n    }\n  }\n  return destination;\n}\nfunction inherits(child, uber) {\n  child.prototype = extend(child.prototype || {}, uber.prototype);\n}\n\n/**\n * Slideout constructor\n */\nfunction Slideout(options) {\n  options = options || {};\n\n  // Sets default values\n  this._startOffsetX = 0;\n  this._currentOffsetX = 0;\n  this._opening = false;\n  this._moved = false;\n  this._opened = false;\n  this._preventOpen = false;\n  this._touch = options.touch === undefined ? true : options.touch && true;\n\n  // Sets panel\n  this.panel = options.panel;\n  this.menu = options.menu;\n\n  // Sets  classnames\n  if(this.panel.className.search('slideout-panel') === -1) { this.panel.className += ' slideout-panel'; }\n  if(this.menu.className.search('slideout-menu') === -1) { this.menu.className += ' slideout-menu'; }\n\n\n  // Sets options\n  this._fx = options.fx || 'ease';\n  this._duration = parseInt(options.duration, 10) || 300;\n  this._tolerance = parseInt(options.tolerance, 10) || 70;\n  this._padding = this._translateTo = parseInt(options.padding, 10) || 256;\n  this._orientation = options.side === 'right' ? -1 : 1;\n  this._translateTo *= this._orientation;\n\n  // Init touch events\n  if (this._touch) {\n    this._initTouchEvents();\n  }\n}\n\n/**\n * Inherits from Emitter\n */\ninherits(Slideout, Emitter);\n\n/**\n * Opens the slideout menu.\n */\nSlideout.prototype.open = function() {\n  var self = this;\n  this.emit('beforeopen');\n  if (html.className.search('slideout-open') === -1) { html.className += ' slideout-open'; }\n  this._setTransition();\n  this._translateXTo(this._translateTo);\n  this._opened = true;\n  setTimeout(function() {\n    self.panel.style.transition = self.panel.style['-webkit-transition'] = '';\n    self.emit('open');\n  }, this._duration + 50);\n  return this;\n};\n\n/**\n * Closes slideout menu.\n */\nSlideout.prototype.close = function() {\n  var self = this;\n  if (!this.isOpen() && !this._opening) { return this; }\n  this.emit('beforeclose');\n  this._setTransition();\n  this._translateXTo(0);\n  this._opened = false;\n  setTimeout(function() {\n    html.className = html.className.replace(/ slideout-open/, '');\n    self.panel.style.transition = self.panel.style['-webkit-transition'] = self.panel.style[prefix + 'transform'] = self.panel.style.transform = '';\n    self.emit('close');\n  }, this._duration + 50);\n  return this;\n};\n\n/**\n * Toggles (open/close) slideout menu.\n */\nSlideout.prototype.toggle = function() {\n  return this.isOpen() ? this.close() : this.open();\n};\n\n/**\n * Returns true if the slideout is currently open, and false if it is closed.\n */\nSlideout.prototype.isOpen = function() {\n  return this._opened;\n};\n\n/**\n * Translates panel and updates currentOffset with a given X point\n */\nSlideout.prototype._translateXTo = function(translateX) {\n  this._currentOffsetX = translateX;\n  this.panel.style[prefix + 'transform'] = this.panel.style.transform = 'translate3d(' + translateX + 'px, 0, 0)';\n};\n\n/**\n * Set transition properties\n */\nSlideout.prototype._setTransition = function() {\n  this.panel.style[prefix + 'transition'] = this.panel.style.transition = prefix + 'transform ' + this._duration + 'ms ' + this._fx;\n};\n\n/**\n * Initializes touch event\n */\nSlideout.prototype._initTouchEvents = function() {\n  var self = this;\n\n  /**\n   * Decouple scroll event\n   */\n  this._onScrollFn = decouple(doc, 'scroll', function() {\n    if (!self._moved) {\n      clearTimeout(scrollTimeout);\n      scrolling = true;\n      scrollTimeout = setTimeout(function() {\n        scrolling = false;\n      }, 250);\n    }\n  });\n\n  /**\n   * Prevents touchmove event if slideout is moving\n   */\n  this._preventMove = function(eve) {\n    if (self._moved) {\n      eve.preventDefault();\n    }\n  };\n  doc.addEventListener(touch.move, this._preventMove);\n\n  /**\n   * Resets values on touchstart\n   */\n  this._resetTouchFn = function(eve) {\n    if (typeof eve.touches === 'undefined') { return; }\n\n    self._moved = false;\n    self._opening = false;\n    self._startOffsetX = eve.touches[0].pageX;\n    self._preventOpen = (!self._touch || (!self.isOpen() && self.menu.clientWidth !== 0));\n  };\n  this.panel.addEventListener(touch.start, this._resetTouchFn);\n\n  /**\n   * Resets values on touchcancel\n   */\n  this._onTouchCancelFn = function() {\n    self._moved = false;\n    self._opening = false;\n  };\n  this.panel.addEventListener('touchcancel', this._onTouchCancelFn);\n\n  /**\n   * Toggles slideout on touchend\n   */\n  this._onTouchEndFn = function() {\n    if (self._moved) {\n      (self._opening && Math.abs(self._currentOffsetX) > self._tolerance) ? self.open() : self.close();\n    }\n    self._moved = false;\n  };\n  this.panel.addEventListener(touch.end, this._onTouchEndFn);\n\n  /**\n   * Translates panel on touchmove\n   */\n  this._onTouchMoveFn = function(eve) {\n\n    if (scrolling || self._preventOpen || typeof eve.touches === 'undefined') { return; }\n\n    var dif_x = eve.touches[0].clientX - self._startOffsetX;\n    var translateX = self._currentOffsetX = dif_x;\n\n    if (Math.abs(translateX) > self._padding) { return; }\n\n    if (Math.abs(dif_x) > 20) {\n      self._opening = true;\n\n      var oriented_dif_x = dif_x * self._orientation;\n      if (self._opened && oriented_dif_x > 0 || !self._opened && oriented_dif_x < 0) { return; }\n      if (oriented_dif_x <= 0) {\n        translateX = dif_x + self._padding * self._orientation;\n        self._opening = false;\n      }\n\n      if (!self._moved && html.className.search('slideout-open') === -1) {\n        html.className += ' slideout-open';\n      }\n\n      self.panel.style[prefix + 'transform'] = self.panel.style.transform = 'translate3d(' + translateX + 'px, 0, 0)';\n      self.emit('translate', translateX);\n      self._moved = true;\n    }\n\n  };\n  this.panel.addEventListener(touch.move, this._onTouchMoveFn);\n};\n\n/**\n * Enable opening the slideout via touch events.\n */\nSlideout.prototype.enableTouch = function() {\n  this._touch = true;\n  return this;\n};\n\n/**\n * Disable opening the slideout via touch events.\n */\nSlideout.prototype.disableTouch = function() {\n  this._touch = false;\n  return this;\n};\n\n/**\n * Destroy an instance of slideout.\n */\nSlideout.prototype.destroy = function() {\n  // Close before clean\n  this.close();\n\n  // Remove event listeners\n  doc.removeEventListener(touch.move, this._preventMove);\n  this.panel.removeEventListener(touch.start, this._resetTouchFn);\n  this.panel.removeEventListener('touchcancel', this._onTouchCancelFn);\n  this.panel.removeEventListener(touch.end, this._onTouchEndFn);\n  this.panel.removeEventListener(touch.move, this._onTouchMoveFn);\n  doc.removeEventListener('scroll', this._onScrollFn);\n\n  // Remove methods\n  this.open = this.close = function() {};\n\n  // Return the instance so it can be easily dereferenced\n  return this;\n};\n\n/**\n * Expose Slideout\n */\nmodule.exports = Slideout;\n","'use strict';\n\nvar requestAnimFrame = (function() {\n  return window.requestAnimationFrame ||\n    window.webkitRequestAnimationFrame ||\n    function (callback) {\n      window.setTimeout(callback, 1000 / 60);\n    };\n}());\n\nfunction decouple(node, event, fn) {\n  var eve,\n      tracking = false;\n\n  function captureEvent(e) {\n    eve = e;\n    track();\n  }\n\n  function track() {\n    if (!tracking) {\n      requestAnimFrame(update);\n      tracking = true;\n    }\n  }\n\n  function update() {\n    fn.call(node, eve);\n    tracking = false;\n  }\n\n  node.addEventListener(event, captureEvent, false);\n}\n\n/**\n * Expose decouple\n */\nmodule.exports = decouple;\n","\"use strict\";\n\nvar _classCallCheck = function (instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } };\n\nexports.__esModule = true;\n/**\n * Creates a new instance of Emitter.\n * @class\n * @returns {Object} Returns a new instance of Emitter.\n * @example\n * // Creates a new instance of Emitter.\n * var Emitter = require('emitter');\n *\n * var emitter = new Emitter();\n */\n\nvar Emitter = (function () {\n  function Emitter() {\n    _classCallCheck(this, Emitter);\n  }\n\n  /**\n   * Adds a listener to the collection for the specified event.\n   * @memberof! Emitter.prototype\n   * @function\n   * @param {String} event - The event name.\n   * @param {Function} listener - A listener function to add.\n   * @returns {Object} Returns an instance of Emitter.\n   * @example\n   * // Add an event listener to \"foo\" event.\n   * emitter.on('foo', listener);\n   */\n\n  Emitter.prototype.on = function on(event, listener) {\n    // Use the current collection or create it.\n    this._eventCollection = this._eventCollection || {};\n\n    // Use the current collection of an event or create it.\n    this._eventCollection[event] = this._eventCollection[event] || [];\n\n    // Appends the listener into the collection of the given event\n    this._eventCollection[event].push(listener);\n\n    return this;\n  };\n\n  /**\n   * Adds a listener to the collection for the specified event that will be called only once.\n   * @memberof! Emitter.prototype\n   * @function\n   * @param {String} event - The event name.\n   * @param {Function} listener - A listener function to add.\n   * @returns {Object} Returns an instance of Emitter.\n   * @example\n   * // Will add an event handler to \"foo\" event once.\n   * emitter.once('foo', listener);\n   */\n\n  Emitter.prototype.once = function once(event, listener) {\n    var self = this;\n\n    function fn() {\n      self.off(event, fn);\n      listener.apply(this, arguments);\n    }\n\n    fn.listener = listener;\n\n    this.on(event, fn);\n\n    return this;\n  };\n\n  /**\n   * Removes a listener from the collection for the specified event.\n   * @memberof! Emitter.prototype\n   * @function\n   * @param {String} event - The event name.\n   * @param {Function} listener - A listener function to remove.\n   * @returns {Object} Returns an instance of Emitter.\n   * @example\n   * // Remove a given listener.\n   * emitter.off('foo', listener);\n   */\n\n  Emitter.prototype.off = function off(event, listener) {\n\n    var listeners = undefined;\n\n    // Defines listeners value.\n    if (!this._eventCollection || !(listeners = this._eventCollection[event])) {\n      return this;\n    }\n\n    listeners.forEach(function (fn, i) {\n      if (fn === listener || fn.listener === listener) {\n        // Removes the given listener.\n        listeners.splice(i, 1);\n      }\n    });\n\n    // Removes an empty event collection.\n    if (listeners.length === 0) {\n      delete this._eventCollection[event];\n    }\n\n    return this;\n  };\n\n  /**\n   * Execute each item in the listener collection in order with the specified data.\n   * @memberof! Emitter.prototype\n   * @function\n   * @param {String} event - The name of the event you want to emit.\n   * @param {...Object} data - Data to pass to the listeners.\n   * @returns {Object} Returns an instance of Emitter.\n   * @example\n   * // Emits the \"foo\" event with 'param1' and 'param2' as arguments.\n   * emitter.emit('foo', 'param1', 'param2');\n   */\n\n  Emitter.prototype.emit = function emit(event) {\n    var _this = this;\n\n    for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n      args[_key - 1] = arguments[_key];\n    }\n\n    var listeners = undefined;\n\n    // Defines listeners value.\n    if (!this._eventCollection || !(listeners = this._eventCollection[event])) {\n      return this;\n    }\n\n    // Clone listeners\n    listeners = listeners.slice(0);\n\n    listeners.forEach(function (fn) {\n      return fn.apply(_this, args);\n    });\n\n    return this;\n  };\n\n  return Emitter;\n})();\n\n/**\n * Exports Emitter\n */\nexports[\"default\"] = Emitter;\nmodule.exports = exports[\"default\"];"]}