import { ComposeType, SaveSettingsStep, FolderType } from 'Common/Enums'; import { Mime } from 'Common/Mime'; const doc = document, $ = jQuery, $div = $('
'), isArray = Array.isArray, htmlmap = { '&': '&', '<': '<', '>': '>', '"': '"', "'": ''' }, htmlspecialchars = str => (''+str).replace(/[&<>"']/g, m => htmlmap[m]); /** * @param {(string|number)} value * @param {boolean=} includeZero = true * @returns {boolean} */ export function isPosNumeric(value, includeZero = true) { return null != value && (includeZero ? /^[0-9]*$/ : /^[1-9]+[0-9]*$/).test(value.toString()); } /** * @param {*} value * @param {number=} defaultValue = 0 * @returns {number} */ export function pInt(value, defaultValue = 0) { value = parseInt(value, 10); return isNaN(value) || !isFinite(value) ? defaultValue : value; } /** * @param {*} value * @returns {string} */ export function pString(value) { return null != value ? '' + value : ''; } /** * @param {*} values * @returns {boolean} */ export function isNonEmptyArray(values) { return isArray(values) && values.length; } /** * @param {string} queryString * @returns {Object} */ export function simpleQueryParser(queryString) { const queries = queryString.split('&'), params = {}; queries.forEach(temp => { temp = temp.split('='); params[decodeURIComponent(temp[0])] = decodeURIComponent(temp[1]); }); return params; } /** * @param {number=} len = 32 * @returns {string} */ export function fakeMd5(len = 32) { const line = '0123456789abcdefghijklmnopqrstuvwxyz'; len = pInt(len); let result = ''; while (len--) result += line.substr(Math.round(Math.random() * 36), 1); return result; } /** * @param {string} text * @returns {string} */ export function encodeHtml(text) { return null != text ? htmlspecialchars(text.toString()) : ''; } /** * @param {string} text * @param {number=} len = 100 * @returns {string} */ export function splitPlainText(text, len = 100) { let prefix = '', subText = '', result = text, spacePos = 0, newLinePos = 0; while (result.length > len) { subText = result.substring(0, len); spacePos = subText.lastIndexOf(' '); newLinePos = subText.lastIndexOf('\n'); if (-1 !== newLinePos) { spacePos = newLinePos; } if (-1 === spacePos) { spacePos = len; } prefix += subText.substring(0, spacePos) + '\n'; result = result.substring(spacePos + 1); } return prefix + result; } /** * @param {any} m * @returns {any} */ export function deModule(m) { return (m && m.default ? m.default : m) || ''; } /** * @returns {boolean} */ export function inFocus() { try { if (doc.activeElement) { if (undefined === doc.activeElement.__inFocusCache) { doc.activeElement.__inFocusCache = $(doc.activeElement).is( 'input,textarea,iframe,.cke_editable' ); } return !!doc.activeElement.__inFocusCache; } } catch (e) {} // eslint-disable-line no-empty return false; } /** * @param {boolean} force * @returns {void} */ export function removeInFocus(force) { if (doc.activeElement && doc.activeElement.blur) { try { const activeEl = $(doc.activeElement); if (force || (activeEl && activeEl.is('input,textarea'))) { doc.activeElement.blur(); } } catch (e) {} // eslint-disable-line no-empty } } /** * @returns {void} */ export function removeSelection() { try { getSelection().removeAllRanges(); } catch (e) {} // eslint-disable-line no-empty } /** * @param {string} prefix * @param {string} subject * @returns {string} */ export function replySubjectAdd(prefix, subject) { prefix = prefix.toUpperCase().trim(); subject = subject.replace(/[\s]+/g, ' ').trim(); let drop = false, re = 'RE' === prefix, fwd = 'FWD' === prefix; const parts = [], prefixIsRe = !fwd; if (subject) { subject.split(':').forEach(part => { const trimmedPart = part.trim(); if (!drop && (/^(RE|FWD)$/i.test(trimmedPart) || /^(RE|FWD)[[(][\d]+[\])]$/i.test(trimmedPart))) { if (!re) { re = !!/^RE/i.test(trimmedPart); } if (!fwd) { fwd = !!/^FWD/i.test(trimmedPart); } } else { parts.push(part); drop = true; } }); } if (prefixIsRe) { re = false; } else { fwd = false; } return ((prefixIsRe ? 'Re: ' : 'Fwd: ') + (re ? 'Re: ' : '') + (fwd ? 'Fwd: ' : '') + parts.join(':').trim()).trim(); } /** * @param {number} num * @param {number} dec * @returns {number} */ export function roundNumber(num, dec) { return Math.round(num * Math.pow(10, dec)) / Math.pow(10, dec); } /** * @param {(number|string)} sizeInBytes * @returns {string} */ export function friendlySize(sizeInBytes) { sizeInBytes = pInt(sizeInBytes); switch (true) { case 1073741824 <= sizeInBytes: return roundNumber(sizeInBytes / 1073741824, 1) + 'GB'; case 1048576 <= sizeInBytes: return roundNumber(sizeInBytes / 1048576, 1) + 'MB'; case 1024 <= sizeInBytes: return roundNumber(sizeInBytes / 1024, 0) + 'KB'; // no default } return sizeInBytes + 'B'; } /** * @param {string} theme * @returns {string} */ export const convertThemeName = theme => { if ('@custom' === theme.substr(-7)) { theme = theme.substring(0, theme.length - 7).trim(); } return theme .replace(/[^a-zA-Z0-9]+/g, ' ') .replace(/([A-Z])/g, ' $1') .replace(/\s+/g, ' ') .trim(); }; /** * * @param {string} language * @param {boolean=} isEng = false * @returns {string} */ export function convertLangName(language, isEng = false) { return require('Common/Translator').i18n( 'LANGS_NAMES' + (true === isEng ? '_EN' : '') + '/LANG_' + language.toUpperCase().replace(/[^a-zA-Z0-9]+/g, '_'), null, language ); } /** * @returns {object} */ export function draggablePlace() { return $( ']*><\/p>/gi, '') .replace(/
]*>([\s\S\r\n\t]*)<\/pre>/gim, convertPre) .replace(/[\s]+/gm, ' ') .replace(/((?:href|data)\s?=\s?)("[^"]+?"|'[^']+?')/gim, fixAttibuteValue) .replace(/
]*>/gim, '\n') .replace(/<\/h[\d]>/gi, '\n') .replace(/<\/p>/gi, '\n\n') .replace(/
]*>/gim, '\n__bq__start__\n') .replace(/<\/blockquote>/gim, '\n__bq__end__\n') .replace(/]*>([\s\S\r\n]*?)<\/a>/gim, convertLinks) .replace(/<\/div>/gi, '\n') .replace(/ /gi, ' ') .replace(/"/gi, '"') .replace(/<[^>]*>/gm, ''); text = $div.html(text).text(); text = text .replace(/\n[ \t]+/gm, '\n') .replace(/[\n]{3,}/gm, '\n\n') .replace(/>/gi, '>') .replace(/</gi, '<') .replace(/&/gi, '&'); text = splitPlainText(text); pos = 0; limit = 800; while (0 < limit) { limit -= 1; iP1 = text.indexOf('__bq__start__', pos); if (-1 < iP1) { iP2 = text.indexOf('__bq__start__', iP1 + 5); iP3 = text.indexOf('__bq__end__', iP1 + 5); if ((-1 === iP2 || iP3 < iP2) && iP1 < iP3) { text = text.substring(0, iP1) + convertBlockquote(text.substring(iP1 + 13, iP3)) + text.substring(iP3 + 11); pos = 0; } else if (-1 < iP2 && iP2 < iP3) { pos = iP2 - 1; } else { pos = 0; } } else { break; } } text = text.replace(/__bq__start__/gm, '').replace(/__bq__end__/gm, ''); return text; } /** * @param {string} plain * @param {boolean} findEmailAndLinksInText = false * @returns {string} */ export function plainToHtml(plain, findEmailAndLinksInText = false) { plain = plain.toString().replace(/\r/g, ''); plain = plain.replace(/^>[> ]>+/gm, ([match]) => (match ? match.replace(/[ ]+/g, '') : match)); let bIn = false, bDo = true, bStart = true, aNextText = [], aText = plain.split('\n'); do { bDo = false; aNextText = []; aText.forEach(sLine => { bStart = '>' === sLine.substr(0, 1); if (bStart && !bIn) { bDo = true; bIn = true; aNextText.push('~~~blockquote~~~'); aNextText.push(sLine.substr(1)); } else if (!bStart && bIn) { if (sLine) { bIn = false; aNextText.push('~~~/blockquote~~~'); aNextText.push(sLine); } else { aNextText.push(sLine); } } else if (bStart && bIn) { aNextText.push(sLine.substr(1)); } else { aNextText.push(sLine); } }); if (bIn) { bIn = false; aNextText.push('~~~/blockquote~~~'); } aText = aNextText; } while (bDo); plain = aText.join('\n'); plain = plain // .replace(/~~~\/blockquote~~~\n~~~blockquote~~~/g, '\n') .replace(/&/g, '&') .replace(/>/g, '>') .replace(/') .replace(/[\s]*~~~\/blockquote~~~/g, '') .replace(/\n/g, '