"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.isFunction = isFunction; exports.isUrl = isUrl; exports.arrayToObject = arrayToObject; exports.htmlEncode = htmlEncode; exports.renderContent = renderContent; exports.addImageProcess = addImageProcess; var _constant = require("./constant"); var _emoji = require("./emoji"); var _emoji2 = _interopRequireDefault(_emoji); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var emojiObejct = arrayToObject(_emoji2.default, "title"); function isFunction(functionToCheck) { return functionToCheck && {}.toString.call(functionToCheck) === "[object Function]"; } function isUrl(userInput) { // 需完整匹配 var regexp = /^((http(s)?:)?\/\/.)?(www\.)?[-a-zA-Z0-9@:%._+~#=]{2,256}\.[a-z]{2,6}\b([-a-zA-Z0-9@:%_+.~#?&//=]*)/g; var res = userInput.match(regexp); if (res === null) return false;else return true; } /** * 将对象数组转换为对象 * @param {array} array Array of Objects * @param {string} keyField string */ function arrayToObject(array, keyField) { return array.reduce(function (obj, item) { obj[item[keyField]] = item; return obj; }, {}); } /** * HTML 编码 * 将 < > 等字符串进行编码 * @param {string} str 文本 */ function htmlEncode(str) { if (!str) return ""; return str.replace(/[<>]/gim, function (i) { return "&#" + i.charCodeAt(0) + ";"; }); } /** * 渲染编辑器 * [x] => <img src="x" /> * @param {strig} content */ function renderContent(content, onClick) { var newContent = content; if (newContent.indexOf(_constant.IMAGE_SPLIT) !== -1) { newContent = newContent.split(_constant.IMAGE_SPLIT); newContent.pop(); newContent = newContent.join(""); } // 不包含在标签内的链接 var innerUrl = /((http(s)?:)?\/\/)?(www\.)?[-a-zA-Z0-9@:%._+~#=]{2,256}\.[a-z]{2,6}\b([-a-zA-Z0-9@:%_+.~#?&//=]*)(?![^<>]*>|[^"]*?<\/a)/g; var data = htmlEncode(newContent).replace(_constant.REGEXP, function (a, b) { var src = a.slice(1, -1); // 兼容旧的评 // 因为旧的评论用 [img url] 方式存储的 if (isUrl(src)) { return "<a href=\"" + src + "\" rel=\"noopener noreferrer\" target=\"_blank\"><img class=\"comment-img\" src=\"" + src + "\" alt=\"" + src + "\" /></a>"; } // 如果不存在对应的表情, 则返回原文 var emoji = emojiObejct[src]; if (emoji) { return "<img class=\"comment-emoji\" src=\"" + _emoji.prefixUrl + emoji.value + "." + emoji.ext + "\" alt=\"" + emoji.title + "\" />"; } return "[" + src + "]"; }).replace(innerUrl, function (a, b) { var protocol = /^(https?:)?\/\//; var hasProtocol = protocol.test(a); var url = hasProtocol ? a : "//" + a; // target="_blank" 存在安全性问题 // return `<a href="${url}" target="_blank" rel="noopener noreferrer" >${a}</a>`; return "<a href=\"" + url + "\">" + a + "</a>"; }).replace(/\n/g, "<br />"); return data; } function addImageProcess(url) { var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; if (options.small) { return url + _constant.IMAGE_PROCESS_SMALL; } if (options.large) { return url + _constant.IMAGE_PROCESS_LARGE; } return url + _constant.IMAGE_PROCESS; } //# sourceMappingURL=helper.js.map