mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-13 22:41:32 -05:00
82 lines
3.3 KiB
JavaScript
82 lines
3.3 KiB
JavaScript
|
// # Ghost Mobile Interactions
|
||
|
|
||
|
/*global window, document, $ */
|
||
|
|
||
|
(function () {
|
||
|
"use strict";
|
||
|
|
||
|
// ## Touch Gestures
|
||
|
|
||
|
// Initiate Hammer.js
|
||
|
// `touchAction: true` Potentially fix problems in IE10 [Ref](https://github.com/EightMedia/hammer.js/wiki/Tips-&-Tricks)
|
||
|
// `drag: false` Removes the Hammer drag event listeners, as they were clashing with jQueryUI Draggable
|
||
|
var Hammer = $(document).hammer({stop_browser_behavior: { touchAction: true }, drag: false});
|
||
|
|
||
|
// ### Show left menu sidebar on right swipe
|
||
|
Hammer.on("swiperight", "#global-header", function (event) {
|
||
|
if (window.matchMedia('(max-width: 650px)').matches) {
|
||
|
event.gesture.preventDefault();
|
||
|
event.stopPropagation();
|
||
|
$('body').addClass('off-canvas');
|
||
|
}
|
||
|
});
|
||
|
|
||
|
// ### Hide left menu sidebar on swipe left
|
||
|
Hammer.on("swipeleft", "#main-menu", function (event) {
|
||
|
if (window.matchMedia('(max-width: 650px)').matches) {
|
||
|
event.gesture.preventDefault();
|
||
|
event.stopPropagation();
|
||
|
$('body').removeClass('off-canvas');
|
||
|
}
|
||
|
});
|
||
|
|
||
|
// ### Show content preview when swiping left on content list
|
||
|
Hammer.on("tap swipeleft", ".manage .content-list ol li", function (event) {
|
||
|
if (window.matchMedia('(max-width: 800px)').matches) {
|
||
|
event.gesture.preventDefault();
|
||
|
event.stopPropagation();
|
||
|
$(".content-list").animate({right: "100%", left: "-100%", 'margin-right': "15px"}, 300);
|
||
|
$(".content-preview").animate({right: "0", left: "0", 'margin-left': "0"}, 300);
|
||
|
}
|
||
|
});
|
||
|
|
||
|
// ### Show content list when swiping right on preview
|
||
|
Hammer.on("swiperight", ".content-preview", function (event) {
|
||
|
if (window.matchMedia('(max-width: 800px)').matches) {
|
||
|
event.gesture.preventDefault();
|
||
|
event.stopPropagation();
|
||
|
|
||
|
$(".content-list").animate({right: "0", left: "0", 'margin-right': "0"}, 300);
|
||
|
$(".content-preview").animate({right: "-100%", left: "100%", 'margin-left': "15px"}, 300);
|
||
|
}
|
||
|
});
|
||
|
|
||
|
// ### Show settings options page when swiping left on settings menu link
|
||
|
Hammer.on("tap swipeleft", ".settings .settings-menu li", function (event) {
|
||
|
if (window.matchMedia('(max-width: 800px)').matches) {
|
||
|
event.gesture.preventDefault();
|
||
|
event.stopPropagation();
|
||
|
$(".settings-sidebar").animate({right: "100%", left: "-102%", 'margin-right': "15px"}, 300);
|
||
|
$(".settings-content").animate({right: "0", left: "0", 'margin-left': "0"}, 300);
|
||
|
}
|
||
|
});
|
||
|
|
||
|
// ### Show settings menu when swiping right on settings options page
|
||
|
Hammer.on("swiperight", ".settings-content", function (event) {
|
||
|
if (window.matchMedia('(max-width: 800px)').matches) {
|
||
|
event.gesture.preventDefault();
|
||
|
event.stopPropagation();
|
||
|
$(".settings-sidebar").animate({right: "0", left: "0", 'margin-right': "0"}, 300);
|
||
|
$(".settings-content").animate({right: "-100%", left: "100%", 'margin-left': "15px"}, 300);
|
||
|
}
|
||
|
});
|
||
|
|
||
|
// ### Toggle the sidebar menu
|
||
|
$('[data-off-canvas]').on('click', function (e) {
|
||
|
if (window.matchMedia('(max-width: 650px)').matches) {
|
||
|
e.preventDefault();
|
||
|
$('body').toggleClass('off-canvas');
|
||
|
}
|
||
|
});
|
||
|
|
||
|
}());
|