mirror of
https://github.com/the-djmaze/snappymail.git
synced 2024-09-20 07:35:55 +08:00
Cleanup CSS and JS code
This commit is contained in:
parent
0eea2cb5ad
commit
6c75dd12f8
|
@ -1 +0,0 @@
|
|||
Name this file as "MULTIPLY" to enable multiple domain installation.
|
|
@ -4,7 +4,11 @@
|
|||
|
||||
//header('Strict-Transport-Security: max-age=31536000');
|
||||
|
||||
//define('USE_GZIP', true); // to use gzip encoded output
|
||||
// Uncomment to use gzip encoded output
|
||||
//define('USE_GZIP', 1);
|
||||
|
||||
// Uncomment to enable multiple domain installation.
|
||||
//define('MULTIDOMAIN', 1);
|
||||
|
||||
/**
|
||||
* @return string
|
||||
|
|
13
dev/External/SquireUI.js
vendored
13
dev/External/SquireUI.js
vendored
|
@ -1,18 +1,15 @@
|
|||
/* eslint max-len: 0 */
|
||||
|
||||
(() => {
|
||||
|
||||
'use strict';
|
||||
|
||||
const doc = document,
|
||||
(doc => {
|
||||
|
||||
const
|
||||
removeElements = 'HEAD,LINK,META,NOSCRIPT,SCRIPT,TEMPLATE,TITLE',
|
||||
allowedElements = 'A,B,BLOCKQUOTE,BR,DIV,FONT,H1,H2,H3,H4,H5,H6,HR,IMG,LI,OL,P,SPAN,STRONG,TABLE,TD,TH,TR,U,UL',
|
||||
allowedAttributes = 'abbr,align,background,bgcolor,border,cellpadding,cellspacing,class,color,colspan,dir,face,frame,height,href,hspace,id,lang,rowspan,rules,scope,size,src,style,target,type,usemap,valign,vspace,width'.split(','),
|
||||
|
||||
i18n = (str, def) => rl.i18n(str) || def,
|
||||
|
||||
ctrlKey = /Mac OS X/.test( navigator.userAgent ) ? '⌘ + ' : 'Ctrl + ',
|
||||
ctrlKey = shortcuts.getMetaKey().replace('meta','⌘') + ' + ',
|
||||
|
||||
tpl = doc.createElement('template'),
|
||||
clr = doc.createElement('input'),
|
||||
|
@ -568,6 +565,6 @@ class SquireUI
|
|||
}
|
||||
}
|
||||
|
||||
window.SquireUI = SquireUI;
|
||||
this.SquireUI = SquireUI;
|
||||
|
||||
})();
|
||||
})(document);
|
||||
|
|
|
@ -281,8 +281,13 @@ html:not(.rl-left-panel-disabled) #rl-left.resizable > .resizer,
|
|||
}
|
||||
}
|
||||
|
||||
.visible-on-ctrl,
|
||||
.visible-on-ctrl-btn,
|
||||
.hidden-on-ctrl-btn,
|
||||
.visible-on-ctrl-btn {
|
||||
display: inline-block;
|
||||
}
|
||||
|
||||
html:not(.rl-ctrl-key-pressed) .visible-on-ctrl-btn,
|
||||
html.rl-ctrl-key-pressed .hidden-on-ctrl-btn,
|
||||
.show-on-panel-disabled {
|
||||
display: none;
|
||||
}
|
||||
|
@ -314,28 +319,16 @@ html.rl-left-panel-disabled {
|
|||
}
|
||||
}
|
||||
|
||||
html.rl-left-panel-short {
|
||||
|
||||
#rl-left {
|
||||
html.rl-left-panel-short #rl-left,
|
||||
html.rl-left-panel-short #rl-right {
|
||||
width: 60px !important;
|
||||
}
|
||||
|
||||
#rl-right {
|
||||
left: 60px !important;
|
||||
}
|
||||
}
|
||||
|
||||
html.rl-left-panel-none {
|
||||
|
||||
#rl-left {
|
||||
html.rl-left-panel-none #rl-left,
|
||||
html.rl-left-panel-none #rl-right {
|
||||
width: 10px !important;
|
||||
}
|
||||
|
||||
#rl-right {
|
||||
left: 10px !important;
|
||||
}
|
||||
}
|
||||
|
||||
html.rl-no-preview-pane {
|
||||
|
||||
#rl-sub-left {
|
||||
|
@ -391,37 +384,11 @@ html.rl-bottom-preview-pane {
|
|||
}
|
||||
}
|
||||
|
||||
.hidden-on-ctrl-btn {
|
||||
display: inline-block;
|
||||
}
|
||||
|
||||
html.rl-ctrl-key-pressed {
|
||||
|
||||
.visible-on-ctrl {
|
||||
display: inline-block;
|
||||
}
|
||||
|
||||
.btn-group.open .visible-on-ctrl-btn {
|
||||
display: inline-block;
|
||||
}
|
||||
|
||||
.hidden-on-ctrl {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.btn-group.open .hidden-on-ctrl-btn {
|
||||
display: none;
|
||||
}
|
||||
}
|
||||
|
||||
.show-on-mobile,
|
||||
html.rl-mobile .hide-on-mobile {
|
||||
display: none !important;
|
||||
}
|
||||
|
||||
.show-on-mobile {
|
||||
display: none !important;
|
||||
}
|
||||
|
||||
html.rl-mobile .show-on-mobile {
|
||||
display: initial !important;
|
||||
}
|
||||
|
|
|
@ -6,8 +6,6 @@
|
|||
*/
|
||||
|
||||
(doc => {
|
||||
'use strict';
|
||||
|
||||
let ua = navigator.userAgent.toLowerCase(),
|
||||
|
||||
dropEffect = 'move',
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
'use strict';
|
||||
|
||||
(w=>{
|
||||
|
||||
Array.prototype.flat || Object.defineProperty(Array.prototype, 'flat', {
|
||||
|
@ -30,4 +32,4 @@ w.ResizeObserver || (w.ResizeObserver = class {
|
|||
}
|
||||
});
|
||||
|
||||
})(window);
|
||||
})(this);
|
||||
|
|
|
@ -3,7 +3,6 @@
|
|||
if (!defined('APP_VERSION'))
|
||||
{
|
||||
define('APP_VERSION', '0.0.0');
|
||||
define('APP_VERSION_TYPE', 'source');
|
||||
define('APP_INDEX_ROOT_FILE', __FILE__);
|
||||
define('APP_INDEX_ROOT_PATH', str_replace('\\', '/', rtrim(dirname(__FILE__), '\\/').'/'));
|
||||
}
|
||||
|
|
|
@ -38,7 +38,7 @@
|
|||
|
||||
define('APP_DEFAULT_PRIVATE_DATA_NAME', '_default_');
|
||||
|
||||
$sPrivateDataFolderInternalName = is_file(APP_INDEX_ROOT_PATH.'MULTIPLY') ? APP_SITE : '';
|
||||
$sPrivateDataFolderInternalName = defined('MULTIDOMAIN') ? APP_SITE : '';
|
||||
define('APP_PRIVATE_DATA_NAME', 0 === strlen($sPrivateDataFolderInternalName) ? APP_DEFAULT_PRIVATE_DATA_NAME : $sPrivateDataFolderInternalName);
|
||||
define('APP_MULTIPLY', 0 < strlen($sPrivateDataFolderInternalName) && APP_DEFAULT_PRIVATE_DATA_NAME !== APP_PRIVATE_DATA_NAME);
|
||||
|
||||
|
|
|
@ -76,13 +76,13 @@ config.paths.js = {
|
|||
'dev/External/ifvisible.js',
|
||||
'dev/dragdropgecko.js',
|
||||
'dev/shortcuts.js',
|
||||
'vendors/inputosaurus/inputosaurus.js', // custom (modified)
|
||||
'vendors/routes/signals.min.js', // fixed
|
||||
'vendors/routes/hasher.min.js', // fixed
|
||||
'vendors/routes/crossroads.min.js', // fixed
|
||||
'vendors/jua/jua.min.js', // custom
|
||||
'vendors/qr.js/qr.min.js', // fixed (license)
|
||||
'vendors/bootstrap/js/bootstrap.native.min.js', // fixed
|
||||
'vendors/inputosaurus/inputosaurus.js',
|
||||
'vendors/routes/signals.min.js',
|
||||
'vendors/routes/hasher.min.js',
|
||||
'vendors/routes/crossroads.min.js',
|
||||
'vendors/jua/jua.min.js',
|
||||
'vendors/qr.js/qr.min.js',
|
||||
'vendors/bootstrap/js/bootstrap.native.js',
|
||||
'vendors/knockout/build/output/knockout-latest.js',
|
||||
'vendors/squire/build/squire-raw.js',
|
||||
'dev/External/SquireUI.js'
|
||||
|
|
|
@ -32,10 +32,6 @@ const rainloopSetup = (done) => {
|
|||
fs
|
||||
.readFileSync('index.php', 'utf8')
|
||||
.replace("'APP_VERSION', '0.0.0'", "'APP_VERSION', '" + versionFull + "'")
|
||||
.replace(
|
||||
"'APP_VERSION_TYPE', 'source'",
|
||||
"'APP_VERSION_TYPE', '" + (config.community ? 'community' : 'standard') + "'"
|
||||
)
|
||||
);
|
||||
|
||||
fs.writeFileSync(dist + 'rainloop/v/' + versionFull + '/index.php.root', fs.readFileSync(dist + 'index.php'));
|
||||
|
|
BIN
vendors/bootstrap/img/glyphicons-halflings-white.png
vendored
BIN
vendors/bootstrap/img/glyphicons-halflings-white.png
vendored
Binary file not shown.
Before Width: | Height: | Size: 8.6 KiB |
BIN
vendors/bootstrap/img/glyphicons-halflings.png
vendored
BIN
vendors/bootstrap/img/glyphicons-halflings.png
vendored
Binary file not shown.
Before Width: | Height: | Size: 12 KiB |
47
vendors/bootstrap/js/bootstrap.native.js
vendored
47
vendors/bootstrap/js/bootstrap.native.js
vendored
|
@ -4,13 +4,10 @@
|
|||
* Licensed under MIT (https://github.com/thednp/bootstrap.native/blob/master/LICENSE)
|
||||
*/
|
||||
|
||||
window.BSN = (() => {
|
||||
'use strict';
|
||||
(doc => {
|
||||
const setFocus = element => element.focus ? element.focus() : element.setActive();
|
||||
|
||||
const doc = document,
|
||||
setFocus = element => element.focus ? element.focus() : element.setActive();
|
||||
|
||||
return {
|
||||
this.BSN = {
|
||||
Dropdown: function(element) {
|
||||
let menu, menuItems = [];
|
||||
const self = this,
|
||||
|
@ -20,30 +17,29 @@ window.BSN = (() => {
|
|||
(href && href.slice(-1) === '#') && e.preventDefault();
|
||||
},
|
||||
toggleEvents = () => {
|
||||
let action = element.open ? 'addEventListener' : 'removeEventListener';
|
||||
doc[action]('click',dismissHandler,false);
|
||||
doc[action]('keydown',preventScroll,false);
|
||||
doc[action]('keyup',keyHandler,false);
|
||||
doc[action]('focus',dismissHandler,false);
|
||||
let action = (element.open ? 'add' : 'remove') + 'EventListener';
|
||||
doc[action]('click',dismissHandler);
|
||||
doc[action]('keydown',preventScroll);
|
||||
doc[action]('keyup',keyHandler);
|
||||
doc[action]('focus',dismissHandler);
|
||||
},
|
||||
dismissHandler = e => {
|
||||
let eventTarget = e.target,
|
||||
inside = menu.contains(eventTarget),
|
||||
hasData = eventTarget && (eventTarget.getAttribute('data-toggle')
|
||||
|| (eventTarget.parentNode && eventTarget.parentNode.getAttribute('data-toggle')));
|
||||
if ((e.type === 'focus' && (eventTarget === element || inside))
|
||||
|| (hasData && inside)
|
||||
if (!(hasData && inside)
|
||||
&& !(e.type === 'focus' && (inside || eventTarget === element))
|
||||
) {
|
||||
return;
|
||||
}
|
||||
self.hide();
|
||||
preventEmptyAnchor(e);
|
||||
}
|
||||
},
|
||||
clickHandler = e => {
|
||||
self.show();
|
||||
preventEmptyAnchor(e);
|
||||
},
|
||||
preventScroll = e => (e.code === 'ArrowUp' || e.code === 'ArrowDown') && e.preventDefault(),
|
||||
preventScroll = e => (e.key === 'ArrowUp' || e.key === 'ArrowDown') && e.preventDefault(),
|
||||
keyHandler = e => {
|
||||
let activeItem = doc.activeElement,
|
||||
isSameElement = activeItem === element,
|
||||
|
@ -52,14 +48,14 @@ window.BSN = (() => {
|
|||
idx = menuItems.indexOf(activeItem);
|
||||
if ( isMenuItem ) {
|
||||
idx = isSameElement ? 0
|
||||
: e.code === 'ArrowUp' ? (idx>1?idx-1:0)
|
||||
: e.code === 'ArrowDown' ? (idx<menuItems.length-1?idx+1:idx) : idx;
|
||||
: e.key === 'ArrowUp' ? (idx>1?idx-1:0)
|
||||
: e.key === 'ArrowDown' ? (idx<menuItems.length-1?idx+1:idx) : idx;
|
||||
menuItems[idx] && setFocus(menuItems[idx]);
|
||||
}
|
||||
if ( (menuItems.length && isMenuItem
|
||||
|| !menuItems.length && (isInsideMenu || isSameElement)
|
||||
|| !isInsideMenu )
|
||||
&& element.open && e.code === 'Escape'
|
||||
&& element.open && e.key === 'Escape'
|
||||
) {
|
||||
self.toggle();
|
||||
}
|
||||
|
@ -76,7 +72,7 @@ window.BSN = (() => {
|
|||
parent.classList.add('show');
|
||||
element.setAttribute('aria-expanded',true);
|
||||
element.open = true;
|
||||
element.removeEventListener('click',clickHandler,false);
|
||||
element.removeEventListener('click',clickHandler);
|
||||
setTimeout(() => {
|
||||
setFocus( menu.getElementsByTagName('INPUT')[0] || element );
|
||||
toggleEvents();
|
||||
|
@ -89,10 +85,10 @@ window.BSN = (() => {
|
|||
element.open = false;
|
||||
toggleEvents();
|
||||
setFocus(element);
|
||||
setTimeout(() => element.Dropdown && element.addEventListener('click',clickHandler,false), 1);
|
||||
setTimeout(() => element.Dropdown && element.addEventListener('click',clickHandler), 1);
|
||||
};
|
||||
self.toggle = () => (parent.classList.contains('show') && element.open) ? self.hide() : self.show();
|
||||
element.addEventListener('click',clickHandler,false);
|
||||
element.addEventListener('click',clickHandler);
|
||||
element.open = false;
|
||||
element.Dropdown = self;
|
||||
},
|
||||
|
@ -101,7 +97,10 @@ window.BSN = (() => {
|
|||
constructor(element) {
|
||||
this.element = element
|
||||
element.Tab = this;
|
||||
element.addEventListener('click', e => {e.preventDefault();this.show();});
|
||||
element.addEventListener('click', e => {
|
||||
e.preventDefault();
|
||||
this.show();
|
||||
});
|
||||
}
|
||||
|
||||
show() {
|
||||
|
@ -117,4 +116,4 @@ window.BSN = (() => {
|
|||
}
|
||||
};
|
||||
|
||||
})();
|
||||
})(document);
|
||||
|
|
7
vendors/bootstrap/js/bootstrap.native.min.js
vendored
7
vendors/bootstrap/js/bootstrap.native.min.js
vendored
|
@ -1,7 +0,0 @@
|
|||
/*!
|
||||
* Native JavaScript for Bootstrap v3.0.10 (https://thednp.github.io/bootstrap.native/)
|
||||
* Copyright 2015-2020 © dnp_theme
|
||||
* Licensed under MIT (https://github.com/thednp/bootstrap.native/blob/master/LICENSE)
|
||||
*/
|
||||
|
||||
window.BSN=(()=>{"use strict";const e=document,t=e=>e.focus?e.focus():e.setActive();return{Dropdown:function(s){let o,n=[];const r=this,i=s.parentNode,a=e=>{const t=e.target,s=t.href||t.parentNode&&t.parentNode.href;s&&"#"===s.slice(-1)&&e.preventDefault()},c=()=>{let t=s.open?"addEventListener":"removeEventListener";e[t]("click",d,!1),e[t]("keydown",h,!1),e[t]("keyup",p,!1),e[t]("focus",d,!1)},d=e=>{let t=e.target,n=o.contains(t),i=t&&(t.getAttribute("data-toggle")||t.parentNode&&t.parentNode.getAttribute("data-toggle"));"focus"===e.type&&(t===s||n)||i&&n||(r.hide(),a(e))},l=e=>{r.show(),a(e)},h=e=>("ArrowUp"===e.code||"ArrowDown"===e.code)&&e.preventDefault(),p=i=>{let a=e.activeElement,c=a===s,d=o.contains(a),l=a.parentNode===o||a.parentNode.parentNode===o,h=n.indexOf(a);l&&(h=c?0:"ArrowUp"===i.code?h>1?h-1:0:"ArrowDown"===i.code&&h<n.length-1?h+1:h,n[h]&&t(n[h])),(n.length&&l||!n.length&&(d||c)||!d)&&s.open&&"Escape"===i.code&&r.toggle()};r.show=(()=>{o=i.querySelector(".dropdown-menu"),n=[],[...o.children].forEach(e=>{e.children.length&&"A"===e.children[0].tagName&&n.push(e.children[0]),"A"===e.tagName&&n.push(e)}),!("tabindex"in o)&&o.setAttribute("tabindex","0"),o.classList.add("show"),i.classList.add("show"),s.setAttribute("aria-expanded",!0),s.open=!0,s.removeEventListener("click",l,!1),setTimeout(()=>{t(o.getElementsByTagName("INPUT")[0]||s),c()},1)}),r.hide=(()=>{o.classList.remove("show"),i.classList.remove("show"),s.setAttribute("aria-expanded",!1),s.open=!1,c(),t(s),setTimeout(()=>s.Dropdown&&s.addEventListener("click",l,!1),1)}),r.toggle=(()=>i.classList.contains("show")&&s.open?r.hide():r.show()),s.addEventListener("click",l,!1),s.open=!1,s.Dropdown=r},Tab:class{constructor(e){this.element=e,e.Tab=this,e.addEventListener("click",e=>{e.preventDefault(),this.show()})}show(){const t=this.element,s=t.closest("li");if(!s.classList.contains("active")){const o=t.closest("ul").querySelector(".active a");o.closest("li").classList.remove("active"),e.querySelector(o.getAttribute("href")).classList.remove("active"),s.classList.add("active"),e.querySelector(t.getAttribute("href")).classList.add("active")}}}}})();
|
6
vendors/bootstrap/less/variables.less
vendored
6
vendors/bootstrap/less/variables.less
vendored
|
@ -130,12 +130,6 @@
|
|||
@zindexModal: 1101;
|
||||
|
||||
|
||||
// Sprite icons path
|
||||
// -------------------------
|
||||
@iconSpritePath: "../img/glyphicons-halflings.png";
|
||||
@iconWhiteSpritePath: "../img/glyphicons-halflings-white.png";
|
||||
|
||||
|
||||
// Input placeholder text color
|
||||
// -------------------------
|
||||
@placeholderText: @grayLight;
|
||||
|
|
9
vendors/inputosaurus/inputosaurus.js
vendored
9
vendors/inputosaurus/inputosaurus.js
vendored
|
@ -12,10 +12,9 @@
|
|||
* @modified by DJMaze
|
||||
*/
|
||||
|
||||
(() => {
|
||||
(doc => {
|
||||
|
||||
const doc = document,
|
||||
createEl = (name, attr) => {
|
||||
const createEl = (name, attr) => {
|
||||
let el = doc.createElement(name);
|
||||
attr && Object.entries(attr).forEach(([k,v]) => el.setAttribute(k,v));
|
||||
return el;
|
||||
|
@ -29,7 +28,7 @@ doc.body.append(fakeSpan, datalist);
|
|||
|
||||
let dragData;
|
||||
|
||||
window.Inputosaurus = class {
|
||||
this.Inputosaurus = class {
|
||||
|
||||
constructor(element, options) {
|
||||
|
||||
|
@ -500,4 +499,4 @@ window.Inputosaurus = class {
|
|||
}
|
||||
};
|
||||
|
||||
})();
|
||||
})(document);
|
||||
|
|
40
vendors/jua/jua.js
vendored
40
vendors/jua/jua.js
vendored
|
@ -1,9 +1,6 @@
|
|||
/* RainLoop Webmail (c) RainLoop Team | MIT */
|
||||
(()=>{
|
||||
'use strict';
|
||||
|
||||
(doc => {
|
||||
const
|
||||
doc = document,
|
||||
iDefLimit = 20,
|
||||
defined = v => undefined !== v,
|
||||
/**
|
||||
|
@ -42,9 +39,8 @@
|
|||
}
|
||||
},
|
||||
|
||||
addEventListeners = (element, obj) => {
|
||||
Object.entries(obj).forEach(([key, value]) => element.addEventListener(key, value));
|
||||
},
|
||||
addEventListeners = (element, obj) =>
|
||||
Object.entries(obj).forEach(([key, value]) => element.addEventListener(key, value)),
|
||||
|
||||
/**
|
||||
* @param {*} oFile
|
||||
|
@ -214,24 +210,24 @@
|
|||
if (oClickElement)
|
||||
{
|
||||
const self = this,
|
||||
oLabel = doc.createElement('label'),
|
||||
oInput = oLabel.appendChild(doc.createElement('input'));
|
||||
oInput = doc.createElement('input'),
|
||||
onClick = ()=>oInput.click();
|
||||
|
||||
oInput.type = 'file';
|
||||
oInput.tabIndex = -1;
|
||||
oInput.style.cssText = 'position:absolute;left:-9999px;';
|
||||
oInput.style.display = 'none';
|
||||
oInput.multiple = !self.oOptions.disableMultiple;
|
||||
|
||||
oLabel.style.cssText = 'position:absolute;background-color:#fff;right:0;top:0;left:0;bottom:0;margin:0;padding:0;cursor:pointer;opacity:0';
|
||||
|
||||
oClickElement.append(oLabel);
|
||||
oClickElement.addEventListener('click', onClick);
|
||||
|
||||
oInput.addEventListener('input', () => {
|
||||
const fFileCallback = oFile => {
|
||||
self.oJua.addNewFile(oFile);
|
||||
setTimeout(() => {
|
||||
oInput.remove();
|
||||
oClickElement.removeEventListener('click', onClick);
|
||||
self.generateNewInput(oClickElement);
|
||||
|
||||
setTimeout(() => oLabel.remove(), 10);
|
||||
}, 10);
|
||||
};
|
||||
if (oInput.files && oInput.files.length) {
|
||||
getDataFromFiles(oInput.files, fFileCallback,
|
||||
|
@ -258,10 +254,7 @@
|
|||
{
|
||||
try
|
||||
{
|
||||
if (this.oXhrs[sUid].abort)
|
||||
{
|
||||
this.oXhrs[sUid].abort();
|
||||
}
|
||||
this.oXhrs[sUid].abort && this.oXhrs[sUid].abort();
|
||||
}
|
||||
catch (oError)
|
||||
{
|
||||
|
@ -496,11 +489,10 @@
|
|||
addNewFile(oFileInfo)
|
||||
{
|
||||
let iLen = 16,
|
||||
fakeMd5 = '',
|
||||
sLine = '0123456789abcdefghijklmnopqrstuvwxyz';
|
||||
fakeMd5 = '';
|
||||
|
||||
while (iLen--)
|
||||
fakeMd5 += sLine.substr(Math.round(Math.random() * 36), 1);
|
||||
fakeMd5 += '0123456789abcdefghijklmnopqrstuvwxyz'.substr(Math.round(Math.random() * 36), 1);
|
||||
|
||||
this.addFile('jua-uid-' + fakeMd5 + '-' + (new Date()).getTime().toString(), oFileInfo);
|
||||
}
|
||||
|
@ -538,6 +530,6 @@
|
|||
}
|
||||
};
|
||||
|
||||
window.Jua = Jua;
|
||||
this.Jua = Jua;
|
||||
|
||||
})();
|
||||
})(document);
|
||||
|
|
2
vendors/jua/jua.min.js
vendored
2
vendors/jua/jua.min.js
vendored
File diff suppressed because one or more lines are too long
5
vendors/squire/build/squire-raw.js
vendored
5
vendors/squire/build/squire-raw.js
vendored
|
@ -10,8 +10,6 @@
|
|||
|
||||
( doc => {
|
||||
|
||||
"use strict";
|
||||
|
||||
const
|
||||
DOCUMENT_POSITION_PRECEDING = 2, // Node.DOCUMENT_POSITION_PRECEDING
|
||||
ELEMENT_NODE = 1, // Node.ELEMENT_NODE,
|
||||
|
@ -35,8 +33,7 @@ const
|
|||
|
||||
isMac = /Mac OS X/.test( ua ),
|
||||
isWin = /Windows NT/.test( ua ),
|
||||
isIOS = /iP(?:ad|hone|od)/.test( ua ) ||
|
||||
( isMac && !!navigator.maxTouchPoints ),
|
||||
isIOS = /iP(?:ad|hone|od)/.test( ua ) || ( isMac && !!navigator.maxTouchPoints ),
|
||||
|
||||
isGecko = /Gecko\//.test( ua ),
|
||||
isEdge = /Edge\//.test( ua ),
|
||||
|
|
Loading…
Reference in a new issue