2014-07-13 11:03:48 -06:00
|
|
|
/*global CodeMirror, device, FastClick*/
|
2014-06-23 21:17:57 -04:00
|
|
|
import createTouchEditor from 'ghost/assets/lib/touch-editor';
|
|
|
|
|
|
|
|
var setupMobileCodeMirror,
|
|
|
|
TouchEditor,
|
|
|
|
init;
|
|
|
|
|
|
|
|
setupMobileCodeMirror = function setupMobileCodeMirror() {
|
|
|
|
var noop = function () {},
|
|
|
|
key;
|
|
|
|
|
|
|
|
for (key in CodeMirror) {
|
|
|
|
if (CodeMirror.hasOwnProperty(key)) {
|
|
|
|
CodeMirror[key] = noop;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
CodeMirror.fromTextArea = function (el, options) {
|
|
|
|
return new TouchEditor(el, options);
|
|
|
|
};
|
|
|
|
|
|
|
|
CodeMirror.keyMap = { basic: {} };
|
|
|
|
};
|
|
|
|
|
|
|
|
init = function init() {
|
2014-06-30 12:29:36 -06:00
|
|
|
//Codemirror does not function on mobile devices,
|
|
|
|
// nor on any iDevice.
|
|
|
|
if (device.mobile() || (device.tablet() && device.ios())) {
|
2014-06-23 21:17:57 -04:00
|
|
|
$('body').addClass('touch-editor');
|
|
|
|
|
|
|
|
// make editor tabs touch-to-toggle in portrait mode
|
2014-08-07 09:32:10 -04:00
|
|
|
$('#entry-markdown-header').on('tap', function () {
|
|
|
|
$('.entry-markdown').addClass('active');
|
|
|
|
$('.entry-preview').removeClass('active');
|
2014-06-23 21:17:57 -04:00
|
|
|
});
|
|
|
|
|
2014-08-07 09:32:10 -04:00
|
|
|
$('#entry-preview-header').on('tap', function () {
|
|
|
|
$('.entry-markdown').removeClass('active');
|
|
|
|
$('.entry-preview').addClass('active');
|
|
|
|
});
|
|
|
|
|
|
|
|
|
2014-06-23 21:17:57 -04:00
|
|
|
Ember.touchEditor = true;
|
2014-07-13 11:03:48 -06:00
|
|
|
//initialize FastClick to remove touch delays
|
|
|
|
Ember.run.scheduleOnce('afterRender', null, function () {
|
|
|
|
FastClick.attach(document.body);
|
|
|
|
});
|
2014-06-23 21:17:57 -04:00
|
|
|
TouchEditor = createTouchEditor();
|
|
|
|
setupMobileCodeMirror();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
export default {
|
|
|
|
createIfMobile: init
|
|
|
|
};
|