diff --git a/.gitignore b/.gitignore
index 089da2d..3fdc3ca 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,4 +1,5 @@
node_modules/
ling_chair_data/
ling_chair_config/
-ling_chair_http/
\ No newline at end of file
+ling_chair_http/
+build_cache/
diff --git a/babel_lib/.gitignore b/babel_lib/.gitignore
deleted file mode 100644
index c2658d7..0000000
--- a/babel_lib/.gitignore
+++ /dev/null
@@ -1 +0,0 @@
-node_modules/
diff --git a/babel_lib/readme.md b/babel_lib/readme.md
deleted file mode 100644
index 29a3d98..0000000
--- a/babel_lib/readme.md
+++ /dev/null
@@ -1,3 +0,0 @@
-## Babel
-
-请从本仓库根目录的 .github 文件夹内找到对应的zip文件,并把 node_modules 解压在此,方可使用
diff --git a/build_cache/chat-message.css b/build_cache/chat-message.css
deleted file mode 100644
index 46e0dcf..0000000
--- a/build_cache/chat-message.css
+++ /dev/null
@@ -1,85 +0,0 @@
-/*
- * 铃之椅 - 把选择权还给用户, 让聊天权掌握在用户手中
- * Copyright 2024 满月叶
- * GitHub: https://github.com/MoonLeeeaf/LingChair-Web-Client
- * 本项目使用 Apache 2.0 协议开源
- *
- * Copyright 2024 MoonLeeeaf
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-.chat-message-right {
- display: flex;
- justify-content: flex-end;
- align-items: flex-start;
- margin: 13px;
-}
-
-.chat-message-left {
- display: flex;
- justify-content: flex-start;
- align-items: flex-start;
- margin: 13px;
-}
-
-.message-content {
- margin-top: 13px;
- margin-bottom: 7px;
- margin-left: 5px;
- margin-right: 5px;
- max-width: 100%;
- white-space: normal;
- word-break: break-all;
- font-size: medium;
- /* 使用了 CardView 就不需要边框了 */
- /* border: 1.3px solid; */
- padding: 15px;
- border-radius: 15px;
- /* 添加圆角样式 */
- /* 设置外边距为 7px */
-}
-
-.message-content-with-nickname-right {
- display: flex;
- align-items: center;
- margin: 7px;
- flex-direction: column;
- /* 垂直排列元素 */
- align-items: flex-end;
- /* 左对齐元素 */
-}
-
-.message-content-with-nickname-left {
- display: flex;
- align-items: center;
- margin: 7px;
- flex-direction: column;
- /* 垂直排列元素 */
- align-items: flex-start;
- /* 左对齐元素 */
-}
-
-.chat-message-left .message-content-with-nickname-left .nickname,
-.chat-message-right .message-content-with-nickname-right .nickname {
- margin-right: 5px;
- font-size: medium;
- margin-top: 3px;
-}
-
-.chat-message-left > .avatar,
-.chat-message-right > .avatar {
- width: 45px;
- height: 45px;
- border-radius: 50%;
-}
\ No newline at end of file
diff --git a/build_cache/index.css b/build_cache/index.css
deleted file mode 100644
index debc8f2..0000000
--- a/build_cache/index.css
+++ /dev/null
@@ -1,54 +0,0 @@
-/*
- * 铃之椅 - 把选择权还给用户, 让聊天权掌握在用户手中
- * Copyright 2024 满月叶
- * GitHub: https://github.com/MoonLeeeaf/LingChair-Web-Client
- * 本项目使用 Apache 2.0 协议开源
- *
- * Copyright 2024 MoonLeeeaf
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
- html, body {
- max-height: 100%;
- margin: 0;
- padding: 0;
- /* overflow: hidden; */
- /*font: initial;*/
-}
-body {
- margin: 0;
- padding: 0;
-}
-.container {
- display: flex;
- flex-direction: column;
- overflow: auto;
-}
-.content {
- flex: 1;
-}
-
-.menu-on-message {
- margin-top: 60px;
- z-index: 100;
-}
-
-[n-id=pageChatSeesion]::after {
- content: "";
- position: sticky;
- bottom: 0;
- display: block;
- height: var(--pseudo-height); /* 设置伪元素的高度 */
- z-index: -1; /* 防止遮挡实际内容 */
- }
diff --git a/build_cache/index.html b/build_cache/index.html
deleted file mode 100644
index 8682440..0000000
--- a/build_cache/index.html
+++ /dev/null
@@ -1,339 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 铃之椅
-
-
-
-
-
-
-
-
-
-
- -
-
-

-
-
-
- -
- settings
-
设置
-
- -
- exit_to_app
-
登出
-
-
- -
-
-
-
-
-
-
-
-
-
- -
- account_circle
-
资料
-
- -
- person_add
-
新的好友
-
-
- -
- settings
-
设置
-
- -
- cloud_circle
-
更换服务器
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 登录到 铃之椅
-
-
-
-
-
-
-
-
-
-
-
-
-
-
![]()
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 修改昵称
-
-
-
-
-
-
-
-
-
-
-
- 新的好友请求
-
-
-
-
-
-
-
-
-
-
- 添加好友/群
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- 设置
-
-
-
-
- -
- edit
-
修改昵称
-
- -
- account_circle
-
上传头像
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/build_cache/index.js b/build_cache/index.js
deleted file mode 100644
index 8c77924..0000000
--- a/build_cache/index.js
+++ /dev/null
@@ -1,1272 +0,0 @@
-"use strict";
-
-function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
-function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return e; }; var t, e = {}, r = Object.prototype, n = r.hasOwnProperty, o = Object.defineProperty || function (t, e, r) { t[e] = r.value; }, i = "function" == typeof Symbol ? Symbol : {}, a = i.iterator || "@@iterator", c = i.asyncIterator || "@@asyncIterator", u = i.toStringTag || "@@toStringTag"; function define(t, e, r) { return Object.defineProperty(t, e, { value: r, enumerable: !0, configurable: !0, writable: !0 }), t[e]; } try { define({}, ""); } catch (t) { define = function define(t, e, r) { return t[e] = r; }; } function wrap(t, e, r, n) { var i = e && e.prototype instanceof Generator ? e : Generator, a = Object.create(i.prototype), c = new Context(n || []); return o(a, "_invoke", { value: makeInvokeMethod(t, r, c) }), a; } function tryCatch(t, e, r) { try { return { type: "normal", arg: t.call(e, r) }; } catch (t) { return { type: "throw", arg: t }; } } e.wrap = wrap; var h = "suspendedStart", l = "suspendedYield", f = "executing", s = "completed", y = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var p = {}; define(p, a, function () { return this; }); var d = Object.getPrototypeOf, v = d && d(d(values([]))); v && v !== r && n.call(v, a) && (p = v); var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p); function defineIteratorMethods(t) { ["next", "throw", "return"].forEach(function (e) { define(t, e, function (t) { return this._invoke(e, t); }); }); } function AsyncIterator(t, e) { function invoke(r, o, i, a) { var c = tryCatch(t[r], t, o); if ("throw" !== c.type) { var u = c.arg, h = u.value; return h && "object" == _typeof(h) && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) { invoke("next", t, i, a); }, function (t) { invoke("throw", t, i, a); }) : e.resolve(h).then(function (t) { u.value = t, i(u); }, function (t) { return invoke("throw", t, i, a); }); } a(c.arg); } var r; o(this, "_invoke", { value: function value(t, n) { function callInvokeWithMethodAndArg() { return new e(function (e, r) { invoke(t, n, e, r); }); } return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(e, r, n) { var o = h; return function (i, a) { if (o === f) throw Error("Generator is already running"); if (o === s) { if ("throw" === i) throw a; return { value: t, done: !0 }; } for (n.method = i, n.arg = a;;) { var c = n.delegate; if (c) { var u = maybeInvokeDelegate(c, n); if (u) { if (u === y) continue; return u; } } if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) { if (o === h) throw o = s, n.arg; n.dispatchException(n.arg); } else "return" === n.method && n.abrupt("return", n.arg); o = f; var p = tryCatch(e, r, n); if ("normal" === p.type) { if (o = n.done ? s : l, p.arg === y) continue; return { value: p.arg, done: n.done }; } "throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg); } }; } function maybeInvokeDelegate(e, r) { var n = r.method, o = e.iterator[n]; if (o === t) return r.delegate = null, "throw" === n && e.iterator["return"] && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y; var i = tryCatch(o, e.iterator, r.arg); if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y; var a = i.arg; return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y); } function pushTryEntry(t) { var e = { tryLoc: t[0] }; 1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e); } function resetTryEntry(t) { var e = t.completion || {}; e.type = "normal", delete e.arg, t.completion = e; } function Context(t) { this.tryEntries = [{ tryLoc: "root" }], t.forEach(pushTryEntry, this), this.reset(!0); } function values(e) { if (e || "" === e) { var r = e[a]; if (r) return r.call(e); if ("function" == typeof e.next) return e; if (!isNaN(e.length)) { var o = -1, i = function next() { for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next; return next.value = t, next.done = !0, next; }; return i.next = i; } } throw new TypeError(_typeof(e) + " is not iterable"); } return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), o(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) { var e = "function" == typeof t && t.constructor; return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name)); }, e.mark = function (t) { return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t; }, e.awrap = function (t) { return { __await: t }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () { return this; }), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) { void 0 === i && (i = Promise); var a = new AsyncIterator(wrap(t, r, n, o), i); return e.isGeneratorFunction(r) ? a : a.next().then(function (t) { return t.done ? t.value : a.next(); }); }, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () { return this; }), define(g, "toString", function () { return "[object Generator]"; }), e.keys = function (t) { var e = Object(t), r = []; for (var n in e) r.push(n); return r.reverse(), function next() { for (; r.length;) { var t = r.pop(); if (t in e) return next.value = t, next.done = !1, next; } return next.done = !0, next; }; }, e.values = values, Context.prototype = { constructor: Context, reset: function reset(e) { if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = "next", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) "t" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t); }, stop: function stop() { this.done = !0; var t = this.tryEntries[0].completion; if ("throw" === t.type) throw t.arg; return this.rval; }, dispatchException: function dispatchException(e) { if (this.done) throw e; var r = this; function handle(n, o) { return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o; } for (var o = this.tryEntries.length - 1; o >= 0; --o) { var i = this.tryEntries[o], a = i.completion; if ("root" === i.tryLoc) return handle("end"); if (i.tryLoc <= this.prev) { var c = n.call(i, "catchLoc"), u = n.call(i, "finallyLoc"); if (c && u) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } else if (c) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); } else { if (!u) throw Error("try statement without catch or finally"); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } } } }, abrupt: function abrupt(t, e) { for (var r = this.tryEntries.length - 1; r >= 0; --r) { var o = this.tryEntries[r]; if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) { var i = o; break; } } i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null); var a = i ? i.completion : {}; return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a); }, complete: function complete(t, e) { if ("throw" === t.type) throw t.arg; return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y; }, finish: function finish(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y; } }, "catch": function _catch(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.tryLoc === t) { var n = r.completion; if ("throw" === n.type) { var o = n.arg; resetTryEntry(r); } return o; } } throw Error("illegal catch attempt"); }, delegateYield: function delegateYield(e, r, n) { return this.delegate = { iterator: values(e), resultName: r, nextLoc: n }, "next" === this.method && (this.arg = t), y; } }, e; }
-function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
-function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
-function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
-function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
-function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }
-function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
-function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
-function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
-function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
-function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
-function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
-/*
- * 铃之椅 - 把选择权还给用户, 让聊天权掌握在用户手中
- * Copyright 2024 满月叶
- * GitHub: https://github.com/MoonLeeeaf/LingChair-Web-Client
- * 本项目使用 Apache 2.0 协议开源
- *
- * Copyright 2024 MoonLeeeaf
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-var UrlArgs = new URL(location.href).searchParams;
-
-// https://www.ruanyifeng.com/blog/2021/09/detecting-mobile-browser.html
-function isMobile() {
- return 'ontouchstart' in document.documentElement;
-}
-function setOnRightClick(e, cb) {
- if (!(e instanceof jQuery)) e = $(e);
- var longPressTimer;
- if (!cb) throw new Error("定义回调!!!!");
- e.on('contextmenu', function (e) {
- e.preventDefault(); // 阻止默认右键菜单
- cb();
- });
- e.on('mousedown', function () {
- longPressTimer = setTimeout(function () {
- cb();
- }, 1000);
- });
- e.on('mouseup', function () {
- clearTimeout(longPressTimer);
- });
-}
-if (UrlArgs.get("debug")) {
- var script = document.createElement('script');
- script.src = "//cdn.jsdelivr.net/npm/eruda";
- document.body.appendChild(script);
- script.onload = function () {
- return eruda.init();
- };
-}
-
-// 经常会因为这个指定ID为位置导致一些莫名BUG
-if (location.href.includes("#")) location.replace(location.href.substring(0, location.href.indexOf("#")));
-var mdui_snackbar = mdui.snackbar;
-mdui.snackbar = function (m) {
- var t = m;
- if (m instanceof Object) t = JSON.stringify(m);
- mdui_snackbar(t);
-};
-var checkEmpty = function checkEmpty(i) {
- if (i instanceof Array) {
- var _iterator = _createForOfIteratorHelper(i),
- _step;
- try {
- for (_iterator.s(); !(_step = _iterator.n()).done;) {
- var k = _step.value;
- if (checkEmpty(k)) return true;
- }
- } catch (err) {
- _iterator.e(err);
- } finally {
- _iterator.f();
- }
- }
- return i == null || "" === i || 0 === i;
-};
-function escapeHTML(str) {
- return str.replace(/[<>&"']/g, function (match) {
- switch (match) {
- case '<':
- return '<';
- case '>':
- return '>';
- case '&':
- return '&';
- case '"':
- return '"';
- case "'":
- return ''';
- default:
- return match;
- }
- });
-}
-var NData = /*#__PURE__*/function () {
- function NData() {
- _classCallCheck(this, NData);
- }
- return _createClass(NData, null, [{
- key: "mount",
- value: function mount(node) {
- // 便捷获得指定组件
- var es = node.querySelectorAll("[n-id]");
- var ls = {};
- es.forEach(function (i) {
- return ls[$(i).attr("n-id")] = $(i);
- });
-
- // input 组件与 localStorage 绑定
- es = node.querySelectorAll("[n-input-ls]");
- es.forEach(function (e) {
- var j = $(e);
- j.val(localStorage.getItem(j.attr("n-input-ls")));
- j.blur(function () {
- return localStorage.setItem(j.attr("n-input-ls"), j.val());
- });
- });
- return ls;
- }
- }]);
-}(); // 快捷获取指定视图
-var viewBinding = NData.mount($("#app").get(0));
-$.ajax({
- url: "res/config.json",
- dataType: "json",
- success: function success(c) {
- viewBinding.appTitle.text(c.appTitle);
- if (!c.canChangeServer) {
- viewBinding.dialogSignInServerLabel.hide();
- viewBinding.drawerChangeServer.hide();
- }
- }
-});
-
-/* // Toolbar 快捷按钮绑定
-viewBinding.contactsRefresh.hide()
-viewBinding.contactsAdd.hide()
-viewBinding.tabChatList.on("show.mdui.tab", () => {
- viewBinding.contactsRefresh.hide()
- viewBinding.contactsAdd.hide()
-})
-viewBinding.tabContacts.on("show.mdui.tab", () => {
- viewBinding.contactsRefresh.show()
- viewBinding.contactsAdd.show()
-})
-viewBinding.tabChatSeesion.on("show.mdui.tab", () => {
- viewBinding.contactsRefresh.hide()
- viewBinding.contactsAdd.hide()
-}) */
-
-/* viewBinding.tabChatSeesion.hide() */
-
-// 关于页面
-viewBinding.menuAbout.click(function () {
- return mdui.alert('这是一个开源项目
作者: MoonLeeeaf
欢迎访问我们的项目主页', '关于 铃之椅', function () {}, {
- confirmText: "关闭"
- });
-});
-viewBinding.drawerChangeServer.click(function () {
- mdui.prompt('输入服务器地址...(为空则使用当前页面地址)', function (value) {
- localStorage.server = value;
- mdui.snackbar("更新成功, 刷新页面生效");
- }, function () {}, {
- confirmText: "确定",
- cancelText: "取消"
- });
-});
-viewBinding.drawerSignOut.click(function () {
- mdui.confirm('确定要登出账号吗', function () {
- User.signOutAndReload();
- }, function () {}, {
- confirmText: "确定",
- cancelText: "取消"
- });
-});
-viewBinding.sendMsg.click(function (a) {
- var text = viewBinding.inputMsg.val();
- if (text.trim() !== "") ChatMsgAdapter.send(text);
-});
-viewBinding.inputMsg.keydown(function (e) {
- if (e.ctrlKey && e.keyCode === 13) viewBinding.sendMsg.click();
-});
-viewBinding.dialogSignInPasswd.keydown(function (e) {
- if (e.keyCode === 13) viewBinding.dialogSignInEnter.click();
-});
-viewBinding.switchNotifications.click(function (a) {
- if ((localStorage.useNotifications == "true" || localStorage.useNotifications != null) && localStorage.useNotifications != "false") {
- localStorage.useNotifications = "false";
- viewBinding.switchNotificationsIcon.text("notifications_off");
- } else {
- localStorage.useNotifications = "true";
- viewBinding.switchNotificationsIcon.text("notifications");
- }
-});
-if (localStorage.useNotifications == "true") viewBinding.switchNotificationsIcon.text("notifications");
-
-// https://www.runoob.com/w3cnote/javascript-copy-clipboard.html
-function copyText(t) {
- var btn = viewBinding.textCopierBtn;
- btn.attr("data-clipboard-text", t);
- new ClipboardJS(btn.get(0)).on('success', function (e) {
- e.clearSelection();
- });
- btn.click();
-}
-
-// https://zhuanlan.zhihu.com/p/162910462
-Date.prototype.format = function (tms, format) {
- var tmd = new Date(tms);
- /*
- * 例子: format="YYYY-MM-dd hh:mm:ss";
- */
- var o = {
- "M+": tmd.getMonth() + 1,
- // month
- "d+": tmd.getDate(),
- // day
- "h+": tmd.getHours(),
- // hour
- "m+": tmd.getMinutes(),
- // minute
- "s+": tmd.getSeconds(),
- // second
- "q+": Math.floor((tmd.getMonth() + 3) / 3),
- // quarter
- "S": tmd.getMilliseconds()
- // millisecond
- };
- if (/(y+)/.test(format)) {
- format = format.replace(RegExp.$1, (tmd.getFullYear() + "").substr(4 - RegExp.$1.length));
- }
- for (var k in o) {
- if (new RegExp("(" + k + ")").test(format)) {
- format = format.replace(RegExp.$1, RegExp.$1.length == 1 ? o[k] : ("00" + o[k]).substr(("" + o[k]).length));
- }
- }
- return format;
-};
-
-// new mdui.Drawer('#main-drawer').close()
-var NickCache = /*#__PURE__*/function () {
- function NickCache() {
- _classCallCheck(this, NickCache);
- }
- return _createClass(NickCache, null, [{
- key: "getNick",
- value: function () {
- var _getNick = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(name) {
- var _this = this;
- return _regeneratorRuntime().wrap(function _callee$(_context) {
- while (1) switch (_context.prev = _context.next) {
- case 0:
- _context.next = 2;
- return new Promise(function (res, rej) {
- // 这个this别摆着不放啊 不然两下就会去世
- var nick = _this.data[name];
- if (nick == null) client.emit("user.getNick", {
- name: localStorage.userName
- }, function (re) {
- var nk = re.data != null ? re.data.nick : name;
- if (nk == null) nk = name;
- _this.data[name] = nk;
- res(nk);
- });else res(nick);
- });
- case 2:
- return _context.abrupt("return", _context.sent);
- case 3:
- case "end":
- return _context.stop();
- }
- }, _callee);
- }));
- function getNick(_x) {
- return _getNick.apply(this, arguments);
- }
- return getNick;
- }()
- }]);
-}(); // 既然已经有 Notification 了, 那用回中文也不过分吧 :)
-_defineProperty(NickCache, "data", {});
-var 通知 = /*#__PURE__*/function () {
- function 通知() {
- _classCallCheck(this, 通知);
- this.args = {};
- this.title = "";
- }
- return _createClass(通知, [{
- key: "setId",
- value: function setId(id) {
- this.args.tag = id;
- return this;
- }
- }, {
- key: "setTitle",
- value: function setTitle(t) {
- this.title = t;
- return this;
- }
- }, {
- key: "setMessage",
- value: function setMessage(m) {
- this.args.body = m;
- return this;
- }
- }, {
- key: "setIcon",
- value: function setIcon(i) {
- this.args.icon = i;
- return this;
- }
- }, {
- key: "setImage",
- value: function setImage(i) {
- this.args.image = i;
- return this;
- }
- }, {
- key: "setData",
- value: function setData(data) {
- this.args.data = data;
- }
- }, {
- key: "show",
- value: function show(onclick /*, onclose*/) {
- if (!通知.checkAvailable()) return;
- if (localStorage.useNotifications !== "true") return;
- var n = new Notification(this.title, this.args);
- n.onclick = onclick == null ? function () {
- return n.close();
- } : function (n) {
- return onclick(n);
- };
- // n.onclose = onclose
- // n.close()
- return n;
- }
- }], [{
- key: "checkAvailable",
- value: function checkAvailable() {
- return "Notification" in window;
- }
- }, {
- key: "request",
- value: function () {
- var _request = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2() {
- return _regeneratorRuntime().wrap(function _callee2$(_context2) {
- while (1) switch (_context2.prev = _context2.next) {
- case 0:
- if (this.checkAvailable()) {
- _context2.next = 2;
- break;
- }
- return _context2.abrupt("return", false);
- case 2:
- _context2.next = 4;
- return Notification.requestPermission();
- case 4:
- return _context2.abrupt("return", _context2.sent);
- case 5:
- case "end":
- return _context2.stop();
- }
- }, _callee2, this);
- }));
- function request() {
- return _request.apply(this, arguments);
- }
- return request;
- }()
- }]);
-}();
-var ContactsList = /*#__PURE__*/function () {
- function ContactsList() {
- _classCallCheck(this, ContactsList);
- }
- return _createClass(ContactsList, null, [{
- key: "reloadList",
- value: function () {
- var _reloadList = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee4() {
- return _regeneratorRuntime().wrap(function _callee4$(_context5) {
- while (1) switch (_context5.prev = _context5.next) {
- case 0:
- _context5.t0 = client;
- _context5.t1 = localStorage.userName;
- _context5.next = 4;
- return User.getAccessToken();
- case 4:
- _context5.t2 = _context5.sent;
- _context5.t3 = {
- name: _context5.t1,
- accessToken: _context5.t2
- };
- _context5.t4 = /*#__PURE__*/function () {
- var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee3(re) {
- var ls, _loop, index;
- return _regeneratorRuntime().wrap(function _callee3$(_context4) {
- while (1) switch (_context4.prev = _context4.next) {
- case 0:
- if (!(re.code !== 0)) {
- _context4.next = 2;
- break;
- }
- return _context4.abrupt("return", mdui.snackbar(re.msg));
- case 2:
- viewBinding.contactsList.empty();
- ls = re.data.friends;
- _loop = /*#__PURE__*/_regeneratorRuntime().mark(function _loop() {
- var name, dick;
- return _regeneratorRuntime().wrap(function _loop$(_context3) {
- while (1) switch (_context3.prev = _context3.next) {
- case 0:
- name = ls[index];
- _context3.next = 3;
- return NickCache.getNick(name);
- case 3:
- dick = _context3.sent;
- /*client.emit("user.getNick", { name: localStorage.userName }, (re) => {
- let nick = re.data == null ? re.data.nick : null
- let name = ls[index]*/
- $($.parseHTML("" + dick + "
")).appendTo(viewBinding.contactsList).click(function () {
- ChatMsgAdapter.switchTo(name, "single");
- });
- //})
- case 5:
- case "end":
- return _context3.stop();
- }
- }, _loop);
- });
- _context4.t0 = _regeneratorRuntime().keys(ls);
- case 6:
- if ((_context4.t1 = _context4.t0()).done) {
- _context4.next = 11;
- break;
- }
- index = _context4.t1.value;
- return _context4.delegateYield(_loop(), "t2", 9);
- case 9:
- _context4.next = 6;
- break;
- case 11:
- case "end":
- return _context4.stop();
- }
- }, _callee3);
- }));
- return function (_x2) {
- return _ref.apply(this, arguments);
- };
- }();
- _context5.t0.emit.call(_context5.t0, "user.getFriends", _context5.t3, _context5.t4);
- case 8:
- case "end":
- return _context5.stop();
- }
- }, _callee4);
- }));
- function reloadList() {
- return _reloadList.apply(this, arguments);
- }
- return reloadList;
- }() // 添加联系人,好友或者群聊
- }, {
- key: "add",
- value: function add(name, type) {
- if (type == "single") {}
- }
- }, {
- key: "openAddDialog",
- value: function openAddDialog() {
- new mdui.Dialog(viewBinding.dialogNewContact.get(0)).open();
- }
- }]);
-}(); // 第一次写前端的消息加载, 代码很乱, 还请原谅~
-// v0.7.0 大改UI 畏惧了 太庞大了
-var ChatPage = /*#__PURE__*/function () {
- function ChatPage(name, type) {
- _classCallCheck(this, ChatPage);
- }
- return _createClass(ChatPage, null, [{
- key: "switchTo",
- value: function switchTo(name, type) {
- if (!this.cached[name]) this.cached[name] = new ChatPage(name, type);
- }
- }]);
-}();
-_defineProperty(ChatPage, "cached", {});
-var ChatMsgAdapter = /*#__PURE__*/function () {
- function ChatMsgAdapter() {
- _classCallCheck(this, ChatMsgAdapter);
- }
- return _createClass(ChatMsgAdapter, null, [{
- key: "switchTo",
- value: // 切换聊天对象
- function () {
- var _switchTo = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee5(name, type) {
- return _regeneratorRuntime().wrap(function _callee5$(_context6) {
- while (1) switch (_context6.prev = _context6.next) {
- case 0:
- viewBinding.tabChatSeesion.show();
- _context6.t0 = viewBinding.tabChatSeesion;
- _context6.next = 4;
- return NickCache.getNick(name);
- case 4:
- _context6.t1 = _context6.sent;
- _context6.t0.text.call(_context6.t0, _context6.t1);
- viewBinding.tabChatSeesion.get(0).click();
- this.type = type;
- this.target = name;
- // this.msgList = []
- this.minMsgId = null;
- viewBinding.pageChatSeesion.empty();
- _context6.next = 13;
- return this.loadMore();
- case 13:
- this.scrollToBottom();
- case 14:
- case "end":
- return _context6.stop();
- }
- }, _callee5, this);
- }));
- function switchTo(_x3, _x4) {
- return _switchTo.apply(this, arguments);
- }
- return switchTo;
- }() // 发送消息
- }, {
- key: "send",
- value: function () {
- var _send = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee7(msg) {
- return _regeneratorRuntime().wrap(function _callee7$(_context8) {
- while (1) switch (_context8.prev = _context8.next) {
- case 0:
- _context8.t0 = client;
- _context8.t1 = localStorage.userName;
- _context8.t2 = this.target;
- _context8.t3 = msg;
- _context8.next = 6;
- return User.getAccessToken();
- case 6:
- _context8.t4 = _context8.sent;
- _context8.t5 = {
- name: _context8.t1,
- target: _context8.t2,
- msg: _context8.t3,
- accessToken: _context8.t4
- };
- _context8.t6 = /*#__PURE__*/function () {
- var _ref2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee6(re) {
- var i;
- return _regeneratorRuntime().wrap(function _callee6$(_context7) {
- while (1) switch (_context7.prev = _context7.next) {
- case 0:
- if (!(re.code !== 0)) {
- _context7.next = 2;
- break;
- }
- return _context7.abrupt("return", mdui.snackbar(re.msg));
- case 2:
- viewBinding.inputMsg.val("");
-
- // 微机课闲的没事干玩玩 发现私聊会多发一个(一个是本地的, 另一个是发送成功的) 选择一个关掉就好了
- // 这里我选择服务端不发送回调, 不然多设备同步会吵死
- // 错了 应该是客户端少发条才对 不然不能多设备同步
- if (!(ChatMsgAdapter.target !== localStorage.userName && ChatMsgAdapter.type === "single")) {
- _context7.next = 8;
- break;
- }
- i = ChatMsgAdapter.isAtBottom();
- _context7.next = 7;
- return ChatMsgAdapter.addMsg(localStorage.userName, msg, re.data.time, re.data.msgid);
- case 7:
- if (i) ChatMsgAdapter.scrollToBottom();
- case 8:
- case "end":
- return _context7.stop();
- }
- }, _callee6);
- }));
- return function (_x6) {
- return _ref2.apply(this, arguments);
- };
- }();
- _context8.t0.emit.call(_context8.t0, "user.sendSingleMsg", _context8.t5, _context8.t6);
- case 10:
- case "end":
- return _context8.stop();
- }
- }, _callee7, this);
- }));
- function send(_x5) {
- return _send.apply(this, arguments);
- }
- return send;
- }()
- }, {
- key: "getHistroy",
- value: function () {
- var _getHistroy = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee9(start, limit) {
- var _this2 = this;
- return _regeneratorRuntime().wrap(function _callee9$(_context10) {
- while (1) switch (_context10.prev = _context10.next) {
- case 0:
- return _context10.abrupt("return", new Promise( /*#__PURE__*/function () {
- var _ref3 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee8(res, rej) {
- return _regeneratorRuntime().wrap(function _callee8$(_context9) {
- while (1) switch (_context9.prev = _context9.next) {
- case 0:
- _context9.t0 = client;
- _context9.t1 = localStorage.userName;
- _context9.t2 = _this2.target;
- _context9.t3 = limit;
- _context9.next = 6;
- return User.getAccessToken();
- case 6:
- _context9.t4 = _context9.sent;
- _context9.t5 = start;
- _context9.t6 = {
- name: _context9.t1,
- target: _context9.t2,
- limit: _context9.t3,
- accessToken: _context9.t4,
- startId: _context9.t5
- };
- _context9.t7 = function (re) {
- if (re.code !== 0) return mdui.snackbar(re.msg);
- res(re.data.histroy);
- };
- _context9.t0.emit.call(_context9.t0, "user.getSingleChatHistroy", _context9.t6, _context9.t7);
- case 11:
- case "end":
- return _context9.stop();
- }
- }, _callee8);
- }));
- return function (_x9, _x10) {
- return _ref3.apply(this, arguments);
- };
- }()));
- case 1:
- case "end":
- return _context10.stop();
- }
- }, _callee9);
- }));
- function getHistroy(_x7, _x8) {
- return _getHistroy.apply(this, arguments);
- }
- return getHistroy;
- }()
- }, {
- key: "loadMore",
- value: function () {
- var _loadMore = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee10(limit) {
- var histroy, re, sc, index, i, e;
- return _regeneratorRuntime().wrap(function _callee10$(_context11) {
- while (1) switch (_context11.prev = _context11.next) {
- case 0:
- _context11.next = 2;
- return this.getHistroy(this.minMsgId, limit == null ? 13 : limit);
- case 2:
- histroy = _context11.sent;
- if (!(histroy.length == 0)) {
- _context11.next = 5;
- break;
- }
- return _context11.abrupt("return", mdui.snackbar("已经加载完了~"));
- case 5:
- re = this.minMsgId != null;
- this.minMsgId = histroy[0].msgid - 1;
- sc = 0;
- if (re) histroy = histroy.reverse();
- _context11.t0 = _regeneratorRuntime().keys(histroy);
- case 10:
- if ((_context11.t1 = _context11.t0()).done) {
- _context11.next = 19;
- break;
- }
- index = _context11.t1.value;
- i = histroy[index];
- _context11.next = 15;
- return this.addMsg(i.name, i.msg, i.time, re, i.msgid);
- case 15:
- e = _context11.sent;
- // 因为某些因素直接DEBUG到吐血 断点继续都不报错 原因不明
- sc = sc + (e == null ? 25 : e.get(0).offsetTop);
- _context11.next = 10;
- break;
- case 19:
- window.scrollBy({
- top: sc,
- behavior: 'smooth'
- });
- case 20:
- case "end":
- return _context11.stop();
- }
- }, _callee10, this);
- }));
- function loadMore(_x11) {
- return _loadMore.apply(this, arguments);
- }
- return loadMore;
- }()
- }, {
- key: "addSystemMsg",
- value: function addSystemMsg(m, re) {
- var e;
- if (re)
- // 加到头部
- e = $($.parseHTML(m)).prependTo(viewBinding.pageChatSeesion);else
- // 加到尾部
- e = $($.parseHTML(m)).appendTo(viewBinding.pageChatSeesion);
- return e;
- }
- }, {
- key: "isAtBottom",
- value: function isAtBottom() {
- var elementRect = viewBinding.pageChatSeesion.get(0).getBoundingClientRect();
- return elementRect.bottom <= window.innerHeight;
- }
- // 添加消息 返回消息的JQ对象
- // name: 用户id m: 消息 t: 时间戳 re: 默认加到尾部 msgid: 消息id
- }, {
- key: "addMsg",
- value: function () {
- var _addMsg = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee11(name, m, t, re, msgid) {
- var nick, msg, temp, bn, e;
- return _regeneratorRuntime().wrap(function _callee11$(_context12) {
- while (1) switch (_context12.prev = _context12.next) {
- case 0:
- _context12.next = 2;
- return NickCache.getNick(name);
- case 2:
- nick = _context12.sent;
- // re.data == null ? name : re.data.nick
- msg = escapeHTML(m);
- if (name === localStorage.userName) temp = "\n
\n
" + nick + "\n
\n " + msg + "\n
\n
\n

\n
";else temp = "\n

\n
\n
" + nick + "\n
\n " + msg + "\n
\n
\n
";
- bn = new Date(t).getMinutes();
- if (re) {
- this.addSystemMsg(temp, re);
- if (this.bbn != bn) {
- e = this.addSystemMsg("" + new Date().format(t == null ? Date.parse("1000-1-1 00:00:00") : t, "yyyy年MM月dd日 hh:mm:ss") + "
", re);
- this.time = bn;
- }
- } else {
- if (this.bbn != bn) {
- e = this.addSystemMsg("" + new Date().format(t == null ? Date.parse("1000-1-1 00:00:00") : t, "yyyy年MM月dd日 hh:mm:ss") + "
", re);
- this.time = bn;
- }
- this.addSystemMsg(temp, re);
- }
- this.bbn = new Date(t).getMinutes();
- return _context12.abrupt("return", e);
- case 9:
- case "end":
- return _context12.stop();
- }
- }, _callee11, this);
- }));
- function addMsg(_x12, _x13, _x14, _x15, _x16) {
- return _addMsg.apply(this, arguments);
- }
- return addMsg;
- }() // 添加消息记录 作用在 UI 和 msgList
- /* static async addMsgLocal(name, m, t, msgid) {
- this.msgList.push({
- name: name,
- msg: m,
- msgid: msgid,
- })
- this.addMsg(name, m, t)
- } */
- // 从服务器加载一些聊天记录, limit默认=13
- }, {
- key: "loadMsgs",
- value: function () {
- var _loadMsgs = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee12(limit) {
- var histroy;
- return _regeneratorRuntime().wrap(function _callee12$(_context13) {
- while (1) switch (_context13.prev = _context13.next) {
- case 0:
- _context13.next = 2;
- return this.getHistroy(this.msgList[0] == null ? null : this.msgList[0].msgid - 1, limit == null ? 13 : limit);
- case 2:
- histroy = _context13.sent;
- this.msgList = histroy;
- case 4:
- case "end":
- return _context13.stop();
- }
- }, _callee12, this);
- }));
- function loadMsgs(_x17) {
- return _loadMsgs.apply(this, arguments);
- }
- return loadMsgs;
- }()
- /* static async loadMsgsFromList(lst) {
- for (let index in lst) {
- let i = lst[index]
- await this.addMsg(i.name, i.msg, i.time)
- }
- } */
- }, {
- key: "scrollToBottom",
- value: function scrollToBottom() {
- // 吐了啊 原来这样就行了 我何必在子element去整啊
- viewBinding.chatPager.get(0).scrollBy({
- top: 1145141919810,
- behavior: 'smooth'
- });
- }
- // 从本地加载
- /*static loadMsgsFromLocal(target) {
- let data = localStorage["chat_msg_" + target]
- if (data == null || data === "[]")
- return []
- return JSON.parse(data)
- }
- // 把当前聊天记录储存到本地
- static saveToLocal() {
- localStorage["chat_msg_" + this.target] = JSON.stringify(this.msgList)
- }*/
- // 自动调整使输入框置底 CSS真tm靠不住啊
- }, {
- key: "initInputResizer",
- value: function initInputResizer() {
- var _this3 = this;
- // 实验表面移动端切出输入法时会触发1-2次resize事件
- // 可以利用这个特性来实现自动滚动文本
- var resize = function resize() {
- viewBinding.pageChatSeesion.height(window.innerHeight - viewBinding.inputToolbar.height() - $("header.mdui-appbar").height() - viewBinding.chatTab.height() - 50);
- var ledi = _this3.resizeDick - window.innerHeight;
- if (isMobile()) viewBinding.chatPager.get(0).scrollBy({
- // 5.19晚10:56分调配出来的秘方
- // < 0 为窗口变大
- // cnm的,调试十万次就你tm检测不到底是吧,就你语法天天错误是吧
- // 欺负我现在用不了电脑
- top: -ledi * (ledi < 0 && _this3.isAtBottom() ? 6 : -1),
- // (ledi < 0 ? 6 : 6),
- behavior: 'smooth'
- });
- _this3.resizeDick = window.innerHeight;
- };
- window.addEventListener("resize", resize);
- resize();
- }
- // 为消息设置长按/右键事件
- }, {
- key: "initMsgElementEvents",
- value: function initMsgElementEvents() {
- var listeners = {};
- var menu;
- var callback = function callback(e) {
- if (menu) menu.close();
- // 从 span 切到 div
- if (e.get(0).tagName.toLowerCase() != "div") e = $(e.get(0).parentNode);
- // 从 消息框 切到 更上层
- e = $(e.get(0).parentNode);
- var menuHtml = $.parseHTML("");
- var $menu = $(menuHtml);
- e.before($menu);
- menu = new mdui.Menu(e.get(0), menuHtml, {
- position: "bottom",
- align: "right"
- // covered: true,
- });
- $menu.on('closed.mdui.menu', function () {
- $(menuHtml).remove();
- });
- menu.open();
- };
- viewBinding.pageChatSeesion.on('contextmenu mousedown mouseup', '.message-content', function (e) {
- var eventType = e.type;
- var self = $(e.target);
-
- // 根据事件类型执行不同操作
- switch (eventType) {
- case 'contextmenu':
- e.preventDefault(); // 阻止默认行为
- callback(self);
- break;
- case 'mousedown':
- listeners[self + ""] = setTimeout(function () {
- callback(self);
- }, 300); // 300颗够吗 应该够吧
- break;
- case 'mouseup':
- clearTimeout(listeners[self + ""]);
- listeners[self + ""] = null;
- break;
- }
- });
- }
- }]);
-}();
-_defineProperty(ChatMsgAdapter, "type", void 0);
-_defineProperty(ChatMsgAdapter, "target", void 0);
-// static msgList
-_defineProperty(ChatMsgAdapter, "minMsgId", void 0);
-_defineProperty(ChatMsgAdapter, "time", void 0);
-_defineProperty(ChatMsgAdapter, "bbn", void 0);
-_defineProperty(ChatMsgAdapter, "resizeDick", void 0);
-var Hash = /*#__PURE__*/function () {
- function Hash() {
- _classCallCheck(this, Hash);
- }
- return _createClass(Hash, null, [{
- key: "md5",
- value: function md5(data) {
- return CryptoJS.MD5(data).toString(CryptoJS.enc.Base64);
- }
- }, {
- key: "sha256",
- value: function sha256(data) {
- return CryptoJS.SHA256(data).toString(CryptoJS.enc.Base64);
- }
- }]);
-}();
-var User = /*#__PURE__*/function () {
- function User() {
- _classCallCheck(this, User);
- }
- return _createClass(User, null, [{
- key: "signIn",
- value:
- // 登录账号 通过回调函数返回刷新令牌
- function signIn(name, passwd, cb) {
- client.emit("user.signIn", {
- name: name,
- passwd: Hash.sha256(passwd) + Hash.md5(passwd)
- }, function (re) {
- if (re.code !== 0) return mdui.snackbar(re.msg);
- cb(re);
- });
- }
- }, {
- key: "signUp",
- value: function signUp(name, passwd, cb) {
- client.emit("user.signUp", {
- name: name,
- passwd: Hash.sha256(passwd) + Hash.md5(passwd)
- }, function (re) {
- if (re.code !== 0) return mdui.snackbar(re.msg);
- cb(re);
- });
- }
- // 为登录对话框编写的
- }, {
- key: "signInWithDialog",
- value: function signInWithDialog(name, passwd) {
- this.signIn(name, passwd, function (re) {
- localStorage.refreshToken = re.data.refreshToken;
- localStorage.isSignIn = true;
- location.reload();
- });
- }
- }, {
- key: "setNick",
- value: function () {
- var _setNick = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee13(nick, cb) {
- return _regeneratorRuntime().wrap(function _callee13$(_context14) {
- while (1) switch (_context14.prev = _context14.next) {
- case 0:
- _context14.t0 = client;
- _context14.t1 = localStorage.userName;
- _context14.next = 4;
- return this.getAccessToken();
- case 4:
- _context14.t2 = _context14.sent;
- _context14.t3 = nick;
- _context14.t4 = {
- name: _context14.t1,
- accessToken: _context14.t2,
- nick: _context14.t3
- };
- _context14.t5 = function (re) {
- if (re.code !== 0) return mdui.snackbar(re.msg);
- if (cb) cb();
- };
- _context14.t0.emit.call(_context14.t0, "user.setNick", _context14.t4, _context14.t5);
- case 9:
- case "end":
- return _context14.stop();
- }
- }, _callee13, this);
- }));
- function setNick(_x18, _x19) {
- return _setNick.apply(this, arguments);
- }
- return setNick;
- }() // 获取头像链接
- }, {
- key: "getUserHeadUrl",
- value: function getUserHeadUrl(name) {
- return client.io.uri + "/users_head/" + name + ".png";
- }
- }, {
- key: "getAccessToken",
- value: function () {
- var _getAccessToken = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee14(er) {
- return _regeneratorRuntime().wrap(function _callee14$(_context15) {
- while (1) switch (_context15.prev = _context15.next) {
- case 0:
- if (!(this.myAccessToken == null)) {
- _context15.next = 4;
- break;
- }
- _context15.next = 3;
- return new Promise(function (res) {
- client.emit("user.getAccessToken", {
- name: localStorage.userName,
- refreshToken: localStorage.refreshToken
- }, function (r) {
- if (r.data != null) res(r.data.accessToken);
- if (er != null) er(r.msg);
- });
- });
- case 3:
- this.myAccessToken = _context15.sent;
- case 4:
- return _context15.abrupt("return", this.myAccessToken);
- case 5:
- case "end":
- return _context15.stop();
- }
- }, _callee14, this);
- }));
- function getAccessToken(_x20) {
- return _getAccessToken.apply(this, arguments);
- }
- return getAccessToken;
- }()
- }, {
- key: "uploadHeadImage",
- value: function uploadHeadImage() {
- viewBinding.uploadHeadImage.click();
- }
- }, {
- key: "uploadHeadImageCallback",
- value: function () {
- var _uploadHeadImageCallback = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee15(self) {
- var img;
- return _regeneratorRuntime().wrap(function _callee15$(_context16) {
- while (1) switch (_context16.prev = _context16.next) {
- case 0:
- img = self.files[0];
- _context16.t0 = client;
- _context16.t1 = localStorage.userName;
- _context16.next = 5;
- return User.getAccessToken();
- case 5:
- _context16.t2 = _context16.sent;
- _context16.t3 = img;
- _context16.t4 = {
- name: _context16.t1,
- accessToken: _context16.t2,
- headImage: _context16.t3
- };
- _context16.t5 = function (re) {
- return mdui.snackbar(re.msg);
- };
- _context16.t0.emit.call(_context16.t0, "user.setHeadImage", _context16.t4, _context16.t5);
- case 10:
- case "end":
- return _context16.stop();
- }
- }, _callee15);
- }));
- function uploadHeadImageCallback(_x21) {
- return _uploadHeadImageCallback.apply(this, arguments);
- }
- return uploadHeadImageCallback;
- }()
- }, {
- key: "auth",
- value: function auth() {
- client.emit("user.auth", {
- name: localStorage.userName,
- refreshToken: localStorage.refreshToken
- }, function (re) {
- if (re.code !== 0) {
- console.error(re);
- if (!re.invalid) return mdui.snackbar("验证用户失败!");
- mdui.alert("账号刷新令牌已过期, 请重新登录哦", "提示", function () {
- return User.signOutAndReload();
- }, {
- confirmText: "确定",
- closeOnConfirm: false,
- closeOnEsc: false,
- modal: true
- });
- }
- });
- }
- }, {
- key: "signOutAndReload",
- value: function signOutAndReload() {
- localStorage.refreshToken = "";
- localStorage.isSignIn = false;
- setTimeout(function () {
- return location.reload();
- }, 300);
- }
- }, {
- key: "registerCallback",
- value: function registerCallback() {
- client.on("msg.receive", /*#__PURE__*/function () {
- var _ref4 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee17(a) {
- var i, n;
- return _regeneratorRuntime().wrap(function _callee17$(_context18) {
- while (1) switch (_context18.prev = _context18.next) {
- case 0:
- if (!checkEmpty([a.target, a.msg, a.type])) {
- _context18.next = 2;
- break;
- }
- return _context18.abrupt("return");
- case 2:
- if (!(ChatMsgAdapter.target === a.target && ChatMsgAdapter.type === a.type)) {
- _context18.next = 7;
- break;
- }
- i = ChatMsgAdapter.isAtBottom();
- _context18.next = 6;
- return ChatMsgAdapter.addMsg(a.target, a.msg.msg, a.msg.time);
- case 6:
- if (i) ChatMsgAdapter.scrollToBottom();
- case 7:
- _context18.t0 = new 通知();
- _context18.next = 10;
- return NickCache.getNick(a.target);
- case 10:
- _context18.t1 = _context18.sent;
- _context18.t2 = "新消息 - " + _context18.t1;
- n = _context18.t0.setTitle.call(_context18.t0, _context18.t2).setMessage(a.msg.msg).setIcon(User.getUserHeadUrl(a.target)).show( /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee16() {
- return _regeneratorRuntime().wrap(function _callee16$(_context17) {
- while (1) switch (_context17.prev = _context17.next) {
- case 0:
- _context17.next = 2;
- return ChatMsgAdapter.switchTo(a.target, a.type);
- case 2:
- location.replace("#msgid_" + a.msg.msgid);
- n.close();
- case 4:
- case "end":
- return _context17.stop();
- }
- }, _callee16);
- })));
- case 13:
- case "end":
- return _context18.stop();
- }
- }, _callee17);
- }));
- return function (_x22) {
- return _ref4.apply(this, arguments);
- };
- }());
- }
- }, {
- key: "openProfileDialog",
- value: function () {
- var _openProfileDialog = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee18(name) {
- return _regeneratorRuntime().wrap(function _callee18$(_context19) {
- while (1) switch (_context19.prev = _context19.next) {
- case 0:
- viewBinding.dialogProfileHead.attr("src", User.getUserHeadUrl(name));
- _context19.t0 = viewBinding.dialogProfileNick;
- _context19.next = 4;
- return NickCache.getNick(name);
- case 4:
- _context19.t1 = _context19.sent;
- _context19.t0.text.call(_context19.t0, _context19.t1);
- new mdui.Dialog(viewBinding.dialogProfile).open();
- case 7:
- case "end":
- return _context19.stop();
- }
- }, _callee18);
- }));
- function openProfileDialog(_x23) {
- return _openProfileDialog.apply(this, arguments);
- }
- return openProfileDialog;
- }()
- }]);
-}(); // 没有刷新令牌需要重新登录 或者初始化
-_defineProperty(User, "myAccessToken", void 0);
-if (!localStorage.refreshToken || localStorage.refreshToken === "") localStorage.isSignIn = false;
-var client;
-function setUpClient(server) {
- if (server && server !== "") client = new io(server, {
- auth: {
- name: localStorage.isSignIn === "false" ? null : localStorage.userName
- }
- });else client = new io({
- auth: {
- name: localStorage.isSignIn === "false" ? null : localStorage.userName
- }
- });
- client.on("connect", function () {
- User.auth();
- });
-}
-if (!localStorage.server || localStorage.server === "") setUpClient();else setUpClient(localStorage.server);
-
-// 登录到账号
-var dialogSignIn;
-// 谨防 localStorage 字符串数据大坑
-if (localStorage.isSignIn == "false") dialogSignIn = new mdui.Dialog(viewBinding.dialogSignIn.get(0), {
- modal: true,
- closeOnEsc: false,
- history: false
-}).open();else {
- _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee19() {
- return _regeneratorRuntime().wrap(function _callee19$(_context20) {
- while (1) switch (_context20.prev = _context20.next) {
- case 0:
- _context20.t0 = viewBinding.userNick;
- _context20.next = 3;
- return NickCache.getNick(localStorage.userName);
- case 3:
- _context20.t1 = _context20.sent;
- return _context20.abrupt("return", _context20.t0.text.call(_context20.t0, _context20.t1));
- case 5:
- case "end":
- return _context20.stop();
- }
- }, _callee19);
- }))();
- var hello;
- var nowHour = new Date().getHours();
- if (nowHour >= 6 && nowHour <= 11) hello = "早安";else if (nowHour == 12) hello = "中午好";else if (nowHour >= 13 && nowHour <= 18) hello = "下午好";else if (nowHour >= 19 && nowHour < 22) hello = "晚上好";else hello = "晚安";
- viewBinding.helloText.text(hello);
- viewBinding.userHead.attr("src", User.getUserHeadUrl(localStorage.userName));
- ContactsList.reloadList();
- User.registerCallback();
-}
-
-// 感谢AI的力量
-Stickyfill.add($("*").filter(function (a, b) {
- return $(b).css('position') === 'sticky';
-}));
-ChatMsgAdapter.initMsgElementEvents();
-ChatMsgAdapter.initInputResizer();
-function refreshAll() {
- ContactsList.reloadList();
- delete NickCache.data;
- NickCache.data = {};
-}
\ No newline at end of file
diff --git a/build_cache/mdui-prettier.css b/build_cache/mdui-prettier.css
deleted file mode 100644
index 4b86b3b..0000000
--- a/build_cache/mdui-prettier.css
+++ /dev/null
@@ -1,53 +0,0 @@
-/*
- * ©2024 满月叶
- * GitHub: MoonLeeeaf
- * 是 UI 美化,好耶!
- */
-
-/* 美化UI */
-
-body {
- font-family: -apple-system, system-ui, -webkit-system-font;
-}
-.mdui-dialog {
- border-radius: 23px;
-}
-.mdui-menu {
- border-radius: 10px;
-}
-.mdui-menu-item > a {
- padding-right: 3px;
-}
-.mdui-btn:not(.mdui-btn-icon, .mdui-dialog-actions button, .mdui-dialog-actions a) {
- padding-left: 20px;
- padding-right: 20px;
- height: 40px;
- border-radius: 10px;
-}
-.mdui-dialog-actions a,
-.mdui-dialog-actions button {
- padding-left: 20px;
- padding-right: 20px;
- height: 40px;
- border-radius: 40px;
-}
-.mdui-select-open {
- border-radius: 10px;
-}
-@media not screen and (min-width: 768px) {
- .mdui-snackbar {
- border-radius: 10px;
- }
-}
-
-/* 配色方案 */
-
-.mdui-theme-color-auto {
- background-color: #fff;
-}
-
-@media (prefers-color-scheme: dark) {
- .mdui-theme-color-auto {
- background-color: #303030;
- }
-}
diff --git a/build_cache/res/config.json b/build_cache/res/config.json
deleted file mode 100644
index d8ada1e..0000000
--- a/build_cache/res/config.json
+++ /dev/null
@@ -1,4 +0,0 @@
-{
- "appTitle": "",
- "canChangeServer": true
-}
\ No newline at end of file
diff --git a/build_cache/res/default_head.png b/build_cache/res/default_head.png
deleted file mode 100644
index 4f6f226..0000000
Binary files a/build_cache/res/default_head.png and /dev/null differ
diff --git a/build_cache/res/icon.ico b/build_cache/res/icon.ico
deleted file mode 100644
index 8677e11..0000000
Binary files a/build_cache/res/icon.ico and /dev/null differ
diff --git a/build_cache/res/license.txt b/build_cache/res/license.txt
deleted file mode 100644
index 5c226ee..0000000
--- a/build_cache/res/license.txt
+++ /dev/null
@@ -1,13 +0,0 @@
-Copyright 2024 MoonLeeeaf
-
-Licensed under the Apache License, Version 2.0 (the "License");
-you may not use this file except in compliance with the License.
-You may obtain a copy of the License at
-
- http://www.apache.org/licenses/LICENSE-2.0
-
-Unless required by applicable law or agreed to in writing, software
-distributed under the License is distributed on an "AS IS" BASIS,
-WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-See the License for the specific language governing permissions and
-limitations under the License.
\ No newline at end of file
diff --git a/client_src.zip b/client_src.zip
deleted file mode 100644
index 47c621a..0000000
Binary files a/client_src.zip and /dev/null differ
diff --git a/package-lock.json b/package-lock.json
index 9c64e96..d17e280 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -1,17 +1,20 @@
{
- "name": "LingChair-Node.js",
+ "name": "lingchair",
+ "version": "0.7.0",
"lockfileVersion": 3,
"requires": true,
"packages": {
"": {
+ "name": "lingchair",
+ "version": "0.7.0",
+ "license": "Apache License 2.0",
"dependencies": {
"express": "^4.19.2",
- "mime": "^4.0.1",
"socket.io": "^4.7.5"
}
},
"node_modules/@socket.io/component-emitter": {
- "version": "3.1.0",
+ "version": "3.1.2",
"license": "MIT"
},
"node_modules/@types/cookie": {
@@ -26,7 +29,7 @@
}
},
"node_modules/@types/node": {
- "version": "20.12.5",
+ "version": "20.12.12",
"license": "MIT",
"dependencies": {
"undici-types": "~5.26.4"
@@ -45,8 +48,7 @@
},
"node_modules/array-flatten": {
"version": "1.1.1",
- "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz",
- "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg=="
+ "license": "MIT"
},
"node_modules/base64id": {
"version": "2.0.0",
@@ -57,8 +59,7 @@
},
"node_modules/body-parser": {
"version": "1.20.2",
- "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.2.tgz",
- "integrity": "sha512-ml9pReCu3M61kGlqoTm2umSXTlRTuGTx0bfYj+uIUKKYycG5NtSbeetV3faSU6R7ajOPw0g/J1PvK4qNy7s5bA==",
+ "license": "MIT",
"dependencies": {
"bytes": "3.1.2",
"content-type": "~1.0.5",
@@ -80,29 +81,25 @@
},
"node_modules/body-parser/node_modules/debug": {
"version": "2.6.9",
- "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
- "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
+ "license": "MIT",
"dependencies": {
"ms": "2.0.0"
}
},
"node_modules/body-parser/node_modules/ms": {
"version": "2.0.0",
- "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
- "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A=="
+ "license": "MIT"
},
"node_modules/bytes": {
"version": "3.1.2",
- "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz",
- "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==",
+ "license": "MIT",
"engines": {
"node": ">= 0.8"
}
},
"node_modules/call-bind": {
"version": "1.0.7",
- "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.7.tgz",
- "integrity": "sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==",
+ "license": "MIT",
"dependencies": {
"es-define-property": "^1.0.0",
"es-errors": "^1.3.0",
@@ -119,8 +116,7 @@
},
"node_modules/content-disposition": {
"version": "0.5.4",
- "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz",
- "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==",
+ "license": "MIT",
"dependencies": {
"safe-buffer": "5.2.1"
},
@@ -130,14 +126,13 @@
},
"node_modules/content-type": {
"version": "1.0.5",
- "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz",
- "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==",
+ "license": "MIT",
"engines": {
"node": ">= 0.6"
}
},
"node_modules/cookie": {
- "version": "0.4.2",
+ "version": "0.6.0",
"license": "MIT",
"engines": {
"node": ">= 0.6"
@@ -145,8 +140,7 @@
},
"node_modules/cookie-signature": {
"version": "1.0.6",
- "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz",
- "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ=="
+ "license": "MIT"
},
"node_modules/cors": {
"version": "2.8.5",
@@ -176,8 +170,7 @@
},
"node_modules/define-data-property": {
"version": "1.1.4",
- "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz",
- "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==",
+ "license": "MIT",
"dependencies": {
"es-define-property": "^1.0.0",
"es-errors": "^1.3.0",
@@ -192,16 +185,14 @@
},
"node_modules/depd": {
"version": "2.0.0",
- "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz",
- "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==",
+ "license": "MIT",
"engines": {
"node": ">= 0.8"
}
},
"node_modules/destroy": {
"version": "1.2.0",
- "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz",
- "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==",
+ "license": "MIT",
"engines": {
"node": ">= 0.8",
"npm": "1.2.8000 || >= 1.4.16"
@@ -209,13 +200,11 @@
},
"node_modules/ee-first": {
"version": "1.1.1",
- "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz",
- "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow=="
+ "license": "MIT"
},
"node_modules/encodeurl": {
"version": "1.0.2",
- "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz",
- "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==",
+ "license": "MIT",
"engines": {
"node": ">= 0.8"
}
@@ -246,10 +235,16 @@
"node": ">=10.0.0"
}
},
+ "node_modules/engine.io/node_modules/cookie": {
+ "version": "0.4.2",
+ "license": "MIT",
+ "engines": {
+ "node": ">= 0.6"
+ }
+ },
"node_modules/es-define-property": {
"version": "1.0.0",
- "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.0.tgz",
- "integrity": "sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==",
+ "license": "MIT",
"dependencies": {
"get-intrinsic": "^1.2.4"
},
@@ -259,21 +254,18 @@
},
"node_modules/es-errors": {
"version": "1.3.0",
- "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz",
- "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==",
+ "license": "MIT",
"engines": {
"node": ">= 0.4"
}
},
"node_modules/escape-html": {
"version": "1.0.3",
- "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz",
- "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow=="
+ "license": "MIT"
},
"node_modules/etag": {
"version": "1.8.1",
- "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz",
- "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==",
+ "license": "MIT",
"engines": {
"node": ">= 0.6"
}
@@ -319,31 +311,20 @@
"node": ">= 0.10.0"
}
},
- "node_modules/express/node_modules/cookie": {
- "version": "0.6.0",
- "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.6.0.tgz",
- "integrity": "sha512-U71cyTamuh1CRNCfpGY6to28lxvNwPG4Guz/EVjgf3Jmzv0vlDp1atT9eS5dDjMYHucpHbWns6Lwf3BKz6svdw==",
- "engines": {
- "node": ">= 0.6"
- }
- },
"node_modules/express/node_modules/debug": {
"version": "2.6.9",
- "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
- "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
+ "license": "MIT",
"dependencies": {
"ms": "2.0.0"
}
},
"node_modules/express/node_modules/ms": {
"version": "2.0.0",
- "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
- "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A=="
+ "license": "MIT"
},
"node_modules/finalhandler": {
"version": "1.2.0",
- "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz",
- "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==",
+ "license": "MIT",
"dependencies": {
"debug": "2.6.9",
"encodeurl": "~1.0.2",
@@ -359,45 +340,39 @@
},
"node_modules/finalhandler/node_modules/debug": {
"version": "2.6.9",
- "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
- "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
+ "license": "MIT",
"dependencies": {
"ms": "2.0.0"
}
},
"node_modules/finalhandler/node_modules/ms": {
"version": "2.0.0",
- "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
- "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A=="
+ "license": "MIT"
},
"node_modules/forwarded": {
"version": "0.2.0",
- "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz",
- "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==",
+ "license": "MIT",
"engines": {
"node": ">= 0.6"
}
},
"node_modules/fresh": {
"version": "0.5.2",
- "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz",
- "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==",
+ "license": "MIT",
"engines": {
"node": ">= 0.6"
}
},
"node_modules/function-bind": {
"version": "1.1.2",
- "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz",
- "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==",
+ "license": "MIT",
"funding": {
"url": "https://github.com/sponsors/ljharb"
}
},
"node_modules/get-intrinsic": {
"version": "1.2.4",
- "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz",
- "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==",
+ "license": "MIT",
"dependencies": {
"es-errors": "^1.3.0",
"function-bind": "^1.1.2",
@@ -414,8 +389,7 @@
},
"node_modules/gopd": {
"version": "1.0.1",
- "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz",
- "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==",
+ "license": "MIT",
"dependencies": {
"get-intrinsic": "^1.1.3"
},
@@ -425,8 +399,7 @@
},
"node_modules/has-property-descriptors": {
"version": "1.0.2",
- "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz",
- "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==",
+ "license": "MIT",
"dependencies": {
"es-define-property": "^1.0.0"
},
@@ -436,8 +409,7 @@
},
"node_modules/has-proto": {
"version": "1.0.3",
- "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.3.tgz",
- "integrity": "sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==",
+ "license": "MIT",
"engines": {
"node": ">= 0.4"
},
@@ -447,8 +419,7 @@
},
"node_modules/has-symbols": {
"version": "1.0.3",
- "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz",
- "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==",
+ "license": "MIT",
"engines": {
"node": ">= 0.4"
},
@@ -458,8 +429,7 @@
},
"node_modules/hasown": {
"version": "2.0.2",
- "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz",
- "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==",
+ "license": "MIT",
"dependencies": {
"function-bind": "^1.1.2"
},
@@ -469,8 +439,7 @@
},
"node_modules/http-errors": {
"version": "2.0.0",
- "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz",
- "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==",
+ "license": "MIT",
"dependencies": {
"depd": "2.0.0",
"inherits": "2.0.4",
@@ -484,8 +453,7 @@
},
"node_modules/iconv-lite": {
"version": "0.4.24",
- "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz",
- "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==",
+ "license": "MIT",
"dependencies": {
"safer-buffer": ">= 2.1.2 < 3"
},
@@ -495,50 +463,41 @@
},
"node_modules/inherits": {
"version": "2.0.4",
- "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz",
- "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ=="
+ "license": "ISC"
},
"node_modules/ipaddr.js": {
"version": "1.9.1",
- "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz",
- "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==",
+ "license": "MIT",
"engines": {
"node": ">= 0.10"
}
},
"node_modules/media-typer": {
"version": "0.3.0",
- "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz",
- "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==",
+ "license": "MIT",
"engines": {
"node": ">= 0.6"
}
},
"node_modules/merge-descriptors": {
"version": "1.0.1",
- "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz",
- "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w=="
+ "license": "MIT"
},
"node_modules/methods": {
"version": "1.1.2",
- "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz",
- "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==",
+ "license": "MIT",
"engines": {
"node": ">= 0.6"
}
},
"node_modules/mime": {
- "version": "4.0.1",
- "resolved": "https://registry.npmjs.org/mime/-/mime-4.0.1.tgz",
- "integrity": "sha512-5lZ5tyrIfliMXzFtkYyekWbtRXObT9OWa8IwQ5uxTBDHucNNwniRqo0yInflj+iYi5CBa6qxadGzGarDfuEOxA==",
- "funding": [
- "https://github.com/sponsors/broofa"
- ],
+ "version": "1.6.0",
+ "license": "MIT",
"bin": {
- "mime": "bin/cli.js"
+ "mime": "cli.js"
},
"engines": {
- "node": ">=16"
+ "node": ">=4"
}
},
"node_modules/mime-db": {
@@ -578,16 +537,14 @@
},
"node_modules/object-inspect": {
"version": "1.13.1",
- "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.1.tgz",
- "integrity": "sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ==",
+ "license": "MIT",
"funding": {
"url": "https://github.com/sponsors/ljharb"
}
},
"node_modules/on-finished": {
"version": "2.4.1",
- "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz",
- "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==",
+ "license": "MIT",
"dependencies": {
"ee-first": "1.1.1"
},
@@ -597,21 +554,18 @@
},
"node_modules/parseurl": {
"version": "1.3.3",
- "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz",
- "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==",
+ "license": "MIT",
"engines": {
"node": ">= 0.8"
}
},
"node_modules/path-to-regexp": {
"version": "0.1.7",
- "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz",
- "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ=="
+ "license": "MIT"
},
"node_modules/proxy-addr": {
"version": "2.0.7",
- "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz",
- "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==",
+ "license": "MIT",
"dependencies": {
"forwarded": "0.2.0",
"ipaddr.js": "1.9.1"
@@ -622,8 +576,7 @@
},
"node_modules/qs": {
"version": "6.11.0",
- "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz",
- "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==",
+ "license": "BSD-3-Clause",
"dependencies": {
"side-channel": "^1.0.4"
},
@@ -636,16 +589,14 @@
},
"node_modules/range-parser": {
"version": "1.2.1",
- "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz",
- "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==",
+ "license": "MIT",
"engines": {
"node": ">= 0.6"
}
},
"node_modules/raw-body": {
"version": "2.5.2",
- "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.2.tgz",
- "integrity": "sha512-8zGqypfENjCIqGhgXToC8aB2r7YrBX+AQAfIPs/Mlk+BtPTztOvTS01NRW/3Eh60J+a48lt8qsCzirQ6loCVfA==",
+ "license": "MIT",
"dependencies": {
"bytes": "3.1.2",
"http-errors": "2.0.0",
@@ -658,8 +609,6 @@
},
"node_modules/safe-buffer": {
"version": "5.2.1",
- "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz",
- "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==",
"funding": [
{
"type": "github",
@@ -673,17 +622,16 @@
"type": "consulting",
"url": "https://feross.org/support"
}
- ]
+ ],
+ "license": "MIT"
},
"node_modules/safer-buffer": {
"version": "2.1.2",
- "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz",
- "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg=="
+ "license": "MIT"
},
"node_modules/send": {
"version": "0.18.0",
- "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz",
- "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==",
+ "license": "MIT",
"dependencies": {
"debug": "2.6.9",
"depd": "2.0.0",
@@ -705,37 +653,22 @@
},
"node_modules/send/node_modules/debug": {
"version": "2.6.9",
- "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz",
- "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==",
+ "license": "MIT",
"dependencies": {
"ms": "2.0.0"
}
},
"node_modules/send/node_modules/debug/node_modules/ms": {
"version": "2.0.0",
- "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
- "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A=="
- },
- "node_modules/send/node_modules/mime": {
- "version": "1.6.0",
- "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz",
- "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==",
- "bin": {
- "mime": "cli.js"
- },
- "engines": {
- "node": ">=4"
- }
+ "license": "MIT"
},
"node_modules/send/node_modules/ms": {
"version": "2.1.3",
- "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
- "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA=="
+ "license": "MIT"
},
"node_modules/serve-static": {
"version": "1.15.0",
- "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz",
- "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==",
+ "license": "MIT",
"dependencies": {
"encodeurl": "~1.0.2",
"escape-html": "~1.0.3",
@@ -748,8 +681,7 @@
},
"node_modules/set-function-length": {
"version": "1.2.2",
- "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.2.tgz",
- "integrity": "sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==",
+ "license": "MIT",
"dependencies": {
"define-data-property": "^1.1.4",
"es-errors": "^1.3.0",
@@ -764,13 +696,11 @@
},
"node_modules/setprototypeof": {
"version": "1.2.0",
- "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz",
- "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw=="
+ "license": "ISC"
},
"node_modules/side-channel": {
"version": "1.0.6",
- "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.6.tgz",
- "integrity": "sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==",
+ "license": "MIT",
"dependencies": {
"call-bind": "^1.0.7",
"es-errors": "^1.3.0",
@@ -786,7 +716,8 @@
},
"node_modules/socket.io": {
"version": "4.7.5",
- "license": "MIT",
+ "resolved": "https://registry.npmjs.org/socket.io/-/socket.io-4.7.5.tgz",
+ "integrity": "sha512-DmeAkF6cwM9jSfmp6Dr/5/mfMwb5Z5qRrSXLpo3Fq5SqyU8CMF15jIN4ZhfSwu35ksM1qmHZDQ/DK5XTccSTvA==",
"dependencies": {
"accepts": "~1.3.4",
"base64id": "~2.0.0",
@@ -821,24 +752,21 @@
},
"node_modules/statuses": {
"version": "2.0.1",
- "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz",
- "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==",
+ "license": "MIT",
"engines": {
"node": ">= 0.8"
}
},
"node_modules/toidentifier": {
"version": "1.0.1",
- "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz",
- "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==",
+ "license": "MIT",
"engines": {
"node": ">=0.6"
}
},
"node_modules/type-is": {
"version": "1.6.18",
- "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz",
- "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==",
+ "license": "MIT",
"dependencies": {
"media-typer": "0.3.0",
"mime-types": "~2.1.24"
@@ -853,16 +781,14 @@
},
"node_modules/unpipe": {
"version": "1.0.0",
- "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz",
- "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==",
+ "license": "MIT",
"engines": {
"node": ">= 0.8"
}
},
"node_modules/utils-merge": {
"version": "1.0.1",
- "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz",
- "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==",
+ "license": "MIT",
"engines": {
"node": ">= 0.4.0"
}
diff --git a/package.json b/package.json
index be99eaa..2785593 100644
--- a/package.json
+++ b/package.json
@@ -1,7 +1,7 @@
{
"name": "lingchair",
"description": "A simple, lightweight and powerful Instant Messaging application.",
- "version": "0.6.1",
+ "version": "0.7.0",
"license": "Apache License 2.0",
"author": {
"name": "MoonLeeeaf",
@@ -11,7 +11,7 @@
"start": "node ./server_src/main.js"
},
"dependencies": {
- "mime": "^4.0.1",
+ "express": "^4.19.2",
"socket.io": "^4.7.5"
},
"type": "commonjs"
diff --git a/run_build.sh b/run_build.sh
deleted file mode 100644
index 578e89a..0000000
--- a/run_build.sh
+++ /dev/null
@@ -1,11 +0,0 @@
-# 复制资源文件,这些文件不需要编译
-mkdir -p ling_chair_http
-cp -r client_src/* build_cache/
-
-# 向前兼容脚本
-cd babel_lib
-node node_modules/@babel/cli/bin/babel ../client_src --out-dir ../build_cache --presets=@babel/env
-
-# 打包以减小负载
-cd ../webpack_lib
-node node_modules/webpack-cli/bin/cli.js --config webpack_config.js
diff --git a/server_src/api-msgs.js b/server_src/api-msgs.js
index b196304..27ecf81 100644
--- a/server_src/api-msgs.js
+++ b/server_src/api-msgs.js
@@ -12,7 +12,7 @@ const users = require("./api-users")
let getSameHashedValue = (a, b) => {
let _a = [hash.md5(a) + hash.sha256(a), hash.md5(b) + hash.sha256(b)].sort()
let [_1, _2] = _a
- return hash.sha256hex(hash.sha256hex(_1) + hash.sha256hex(_2))
+ return hash.sha256(hash.sha256(_1) + hash.sha256(_2))
}
let getSingleChatDir = (a, b) => {
diff --git a/server_src/hashlib.js b/server_src/hashlib.js
index 83a6350..daffdbc 100644
--- a/server_src/hashlib.js
+++ b/server_src/hashlib.js
@@ -7,10 +7,8 @@
const crypto = require("crypto")
let apis = {
- sha256: (data) => crypto.createHash("sha256").update(data).digest("base64"),
- md5: (data) => crypto.createHash("md5").update(data).digest("base64"),
- sha256hex: (data) => crypto.createHash("sha256").update(data).digest("hex"),
- md5hex: (data) => crypto.createHash("md5").update(data).digest("hex"),
+ sha256: (data) => crypto.createHash("sha256").update(data).digest("hex"),
+ md5: (data) => crypto.createHash("md5").update(data).digest("hex"),
}
module.exports = apis
diff --git a/webpack_lib/.gitignore b/webpack_lib/.gitignore
deleted file mode 100644
index c2658d7..0000000
--- a/webpack_lib/.gitignore
+++ /dev/null
@@ -1 +0,0 @@
-node_modules/
diff --git a/webpack_lib/readme.md b/webpack_lib/readme.md
deleted file mode 100644
index f355d2b..0000000
--- a/webpack_lib/readme.md
+++ /dev/null
@@ -1,3 +0,0 @@
-## Webpack
-
-请从本仓库根目录的 .github 文件夹内找到对应的zip文件,并把 node_modules 解压在此,方可使用
diff --git a/webpack_lib/webpack_config.js b/webpack_lib/webpack_config.js
deleted file mode 100644
index 30b20f9..0000000
--- a/webpack_lib/webpack_config.js
+++ /dev/null
@@ -1,20 +0,0 @@
-const path = require('path')
-const { BannerPlugin } = require('webpack')
-const HtmlWebpackPlugin = require('html-webpack-plugin')
-const MiniCssExtractPlugin = require('mini-css-extract-plugin')
-
-module.exports = {
- entry: '../build_cache/index.js',
- output: {
- filename: 'index.js',
- path: path.resolve(__dirname, '../ling_chair_http'),
- },
- module: {
- rules: [
- {
- test: /\.css$/i,
- use: ['style-loader', 'css-loader'],
- },
- ],
- },
-}