thedesk/app/js/platform/first.js

196 lines
5.1 KiB
JavaScript
Raw Normal View History

2018-01-28 23:22:43 +11:00
//jQuery読む
2018-09-12 02:49:41 +10:00
window.jQuery = window.$ = require('../../js/common/jquery.js');
2018-12-09 05:46:01 +11:00
var Hammer = require('../../js/common/hammer.min.js');
2019-05-19 17:39:30 +10:00
$.strip_tags = function (str, allowed) {
if (!str) {
return "";
}
allowed = (((allowed || '') + '').toLowerCase().match(/<[a-z][a-z0-9]*>/g) || [])
.join('');
var tags = /<\/?([a-z][a-z0-9]*)\b[^>]*>?/gi,
commentsAndPhpTags = /<!--[\s\S]*?-->|<\?(?:php)?[\s\S]*?\?>/gi;
return str.replace(commentsAndPhpTags, '').replace(tags, function ($0, $1) {
return allowed.indexOf('<' + $1.toLowerCase() + '>') > -1 ? $0 : '';
});
};
function escapeHTML(str) {
if (!str) {
2018-12-09 05:46:01 +11:00
return "";
}
return str.replace(/&/g, '&amp;')
2019-05-19 17:39:30 +10:00
.replace(/</g, '&lt;')
.replace(/>/g, '&gt;')
.replace(/"/g, '&quot;')
.replace(/'/g, '&#039;');
}
//PHPのnl2brと同様
2018-12-09 05:46:01 +11:00
function nl2br(str) {
2019-05-19 17:39:30 +10:00
if (!str) {
2018-12-09 05:46:01 +11:00
return "";
}
2019-05-19 17:39:30 +10:00
str = str.replace(/\r\n/g, "<br />");
2018-12-09 05:46:01 +11:00
str = str.replace(/(\n|\r)/g, "<br />");
2019-05-19 17:39:30 +10:00
return str;
2019-01-22 03:25:40 +11:00
}
2019-04-14 02:42:18 +10:00
function br2nl(str) {
2019-05-19 17:39:30 +10:00
if (!str) {
2019-04-14 02:42:18 +10:00
return "";
}
2019-05-19 17:39:30 +10:00
str = str.replace(/<br \/>/g, "\r\n");
return str;
2019-04-14 02:42:18 +10:00
}
2019-05-19 17:39:30 +10:00
function formattime(date) {
var str = date.getFullYear() + "-";
if (date.getMonth() + 1 < 10) {
str = str + "0" + (date.getMonth() + 1) + "-";
} else {
str = str + (date.getMonth() + 1) + "-";
}
if (date.getDate() < 10) {
str = str + "0" + date.getDate()
} else {
str = str + date.getDate()
}
str = str + "T";
if (date.getHours() < 10) {
str = str + "0" + date.getHours() + ":"
} else {
str = str + date.getHours() + ":"
}
if (date.getMinutes() < 10) {
str = str + "0" + date.getMinutes()
} else {
str = str + date.getMinutes()
2019-01-22 03:25:40 +11:00
}
2019-04-23 00:16:57 +10:00
return escapeHTML(str);
2019-01-22 03:25:40 +11:00
}
2019-05-19 17:39:30 +10:00
function formattimeutc(date) {
var str = date.getUTCFullYear() + "-";
if (date.getUTCMonth() + 1 < 10) {
str = str + "0" + (date.getUTCMonth() + 1) + "-";
} else {
str = str + (date.getUTCMonth() + 1) + "-";
}
if (date.getUTCDate() < 10) {
str = str + "0" + date.getUTCDate()
} else {
str = str + date.getUTCDate()
}
str = str + "T";
if (date.getUTCHours() < 10) {
str = str + "0" + date.getUTCHours() + ":"
} else {
str = str + date.getUTCHours() + ":"
}
if (date.getUTCMinutes() < 10) {
str = str + "0" + date.getUTCMinutes()
} else {
str = str + date.getUTCMinutes()
2019-01-22 03:25:40 +11:00
}
2019-04-23 00:16:57 +10:00
return escapeHTML(str);
2019-03-08 05:19:26 +11:00
}
var electron = require("electron");
var ipc = electron.ipcRenderer;
ipc.send('custom-css-request', "");
ipc.on('custom-css-response', function (event, arg) {
2019-05-19 17:39:30 +10:00
if (arg == "") { return false; }
2019-03-08 05:19:26 +11:00
var styleNode = document.createElement("style");
2019-05-19 17:39:30 +10:00
styleNode.setAttribute("type", "text/css")
2019-03-08 05:19:26 +11:00
var content = document.createTextNode(arg)
styleNode.append(content)
document.getElementsByTagName("head")[0].append(styleNode)
})
ipc.on('theme-css-response', function (event, arg) {
2019-05-19 17:39:30 +10:00
if (arg == "") { return false; }
2019-03-08 05:19:26 +11:00
var styleNode = document.createElement("style");
2019-05-19 17:39:30 +10:00
styleNode.setAttribute("type", "text/css")
2019-03-08 05:19:26 +11:00
var content = document.createTextNode(arg)
styleNode.append(content)
document.getElementsByTagName("head")[0].append(styleNode)
})
2019-05-19 17:39:30 +10:00
function makeCID() {
return randomStr(8) + "-" + randomStr(4) + "-" + randomStr(4) + "-" + randomStr(4) + "-" + randomStr(12);
2019-03-08 05:19:26 +11:00
}
2019-05-19 17:39:30 +10:00
function randomStr(l) {
2019-03-08 05:19:26 +11:00
// 生成する文字列に含める文字セット
var c = "abcdefghijklmnopqrstuvwxyz0123456789";
var cl = c.length;
var r = "";
2019-05-19 17:39:30 +10:00
for (var i = 0; i < l; i++) {
r += c[Math.floor(Math.random() * cl)];
2019-03-08 05:19:26 +11:00
}
return r;
}
2019-05-19 17:39:30 +10:00
function rgbToHex(color) {
// HEXに変換したものを代入する変数
var hex = '';
// 第1引数がHEXのとき変換処理は必要ないのでそのままreturn
// IE8の場合はjQueryのcss()関数でHEXを返すので除外
if (color.match(/^#[a-f\d]{3}$|^#[a-f\d]{6}$/i)) {
return color;
}
// 正規表現
var regex = color.match(/^rgb\(([0-9.]+),\s*([0-9.]+),\s*([0-9.]+)\)$/);
// 正規表現でマッチしたとき
if (regex) {
var rgb =
[
// RGBからHEXへ変換
parseInt(regex[1]).toString(16),
parseInt(regex[2]).toString(16),
parseInt(regex[3]).toString(16)
];
for (var i = 0; i < rgb.length; ++i) {
// rgb(1,1,1)のようなときHEXに変換すると1桁になる
// 1桁のときは前に0を足す
if (rgb[i].length == 1) {
rgb[i] = '0' + rgb[i];
}
hex += rgb[i];
}
return hex;
}
console.error(color + ':第1引数はRGB形式で入力');
2019-05-19 16:17:05 +10:00
}
2019-05-19 17:39:30 +10:00
/*マルチバイト用切り出し*/
$.isSurrogatePear = function (upper, lower) {
return 0xD800 <= upper && upper <= 0xDBFF && 0xDC00 <= lower && lower <= 0xDFFF;
};
$.mb_strlen = function (str) {
var ret = 0;
for (var i = 0; i < str.length; i++ , ret++) {
var upper = str.charCodeAt(i);
var lower = str.length > (i + 1) ? str.charCodeAt(i + 1) : 0;
if ($.isSurrogatePear(upper, lower)) {
i++;
}
}
return ret;
};
$.mb_substr = function (str, begin, end) {
var ret = '';
for (var i = 0, len = 0; i < str.length; i++ , len++) {
var upper = str.charCodeAt(i);
var lower = str.length > (i + 1) ? str.charCodeAt(i + 1) : 0;
var s = '';
if ($.isSurrogatePear(upper, lower)) {
i++;
s = String.fromCharCode(upper, lower);
} else {
s = String.fromCharCode(upper);
}
if (begin <= len && len < end) {
ret += s;
}
}
return ret;
2019-05-26 21:42:52 +10:00
};
localStorage.removeItem("errors");