diff --git a/.gitignore b/.gitignore index 1cb1d2ba..6dde0111 100644 --- a/.gitignore +++ b/.gitignore @@ -2,10 +2,9 @@ node_modules/ config.yaml .build/ .uibuild/ +.cache/ __* ui/misc/.iconfont ui/static/locale -.cache .webpackStats.json -module/** !.gitkeep diff --git a/hydro/handler/home.js b/hydro/handler/home.js index b15503ce..0229060c 100644 --- a/hydro/handler/home.js +++ b/hydro/handler/home.js @@ -80,11 +80,12 @@ class HomeSecurityHandler extends Handler { async get() { // TODO(iceboy): pagination? or limit session count for uid? + // TODO(masnn): UA & IP const sessions = await token.getSessionListByUid(this.user._id); const parsed = sessions.map((session) => ({ ...session, - updateUa: useragent.parse(session.updateUa || session.createUa || ''), - updateGeoip: geoip.ip2geo(session.updateIp || session.createIp, this.user.viewLang), + // updateUa: useragent.parse(session.updateUa || session.createUa || ''), + // updateGeoip: geoip.ip2geo(session.updateIp || session.createIp, this.user.viewLang), _id: md5(session._id), isCurrent: session._id === this.session._id, })); @@ -116,7 +117,7 @@ class HomeSecurityHandler extends Handler { async postDeleteToken({ tokenDigest }) { const sessions = await token.getSessionListByUid(this.user._id); - for (const session in sessions) { + for (const session of sessions) { if (tokenDigest === md5(session._id)) { // eslint-disable-next-line no-await-in-loop await token.delete(session._id, token.TYPE_SESSION); @@ -128,7 +129,7 @@ class HomeSecurityHandler extends Handler { async postDeleteAllTokens() { await token.deleteByUid(this.user._id); - this.back(); + this.response.redirect = '/login'; } } diff --git a/hydro/handler/import.js b/hydro/handler/import.js index e6bd284c..9f45a039 100644 --- a/hydro/handler/import.js +++ b/hydro/handler/import.js @@ -29,7 +29,6 @@ class ProblemImportHandler extends Handler { if (pid) pdoc.pid = pid; if (hidden) pdoc.hidden = true; const _id = await problem.add(pdoc); - console.log(_id); await problem.setTestdata(_id, testdata); this.response.body = { pid: pid || _id }; this.response.redirect = `/p/${pid || _id}/settings`; diff --git a/hydro/handler/problem.js b/hydro/handler/problem.js index ccbad0e2..559baa65 100644 --- a/hydro/handler/problem.js +++ b/hydro/handler/problem.js @@ -32,25 +32,26 @@ class ProblemHandler extends Handler { this.checkPerm(PERM_VIEW_PROBLEM); } - async get({ page = 1, category = null }) { + async get({ page = 1, category = '' }) { this.response.template = 'problem_main.html'; const q = {}; let psdict = {}; if (category) q.category = category; if (!this.user.hasPerm(PERM_VIEW_PROBLEM_HIDDEN)) q.hidden = false; - const pdocs = await problem.getMany(q, { pid: 1 }, page, constants.PROBLEM_PER_PAGE); + const [pdocs, pcount] = await paginate( + problem.getMulti(q).sort({ pid: 1 }), + page, + constants.PROBLEM_PER_PAGE, + ); if (this.user.hasPerm(PERM_LOGGEDIN)) { psdict = await problem.getListStatus(this.user._id, pdocs.map((pdoc) => pdoc._id)); } + const path = [ + ['Hydro', '/'], + ['problem_main', null], + ]; this.response.body = { - path: [ - ['Hydro', '/'], - ['problem_main', null], - ], - page, - pdocs, - psdict, - category: '', + path, page, pcount, pdocs, psdict, category, }; } } diff --git a/hydro/lib/template.js b/hydro/lib/template.js index 87551a28..66e1c997 100644 --- a/hydro/lib/template.js +++ b/hydro/lib/template.js @@ -38,6 +38,7 @@ module.exports = { gravatar: misc.gravatar, model, Context: global.Hydro.ui, + isIE: (str) => str.includes('MSIE') || str.includes('rv:11.0'), }); return new Promise((resolve, reject) => { env.render(name, state, (err, res) => { diff --git a/hydro/model/setting.js b/hydro/model/setting.js index 9d7ada57..5af46ca4 100644 --- a/hydro/model/setting.js +++ b/hydro/model/setting.js @@ -11,13 +11,13 @@ const Setting = ( }); const PREFERENCE_SETTINGS = [ - Setting('setting_display', 'view_lang', i18n, + Setting('setting_display', 'viewLang', i18n, options.default_locale, 'select', 'UI Language'), Setting('setting_display', 'timezone', [], // TODO(masnn) timezone 'Asia/Shanghai', 'select', 'Timezone'), - Setting('setting_usage', 'code_lang', builtin.LANG_TEXTS, + Setting('setting_usage', 'codeLang', builtin.LANG_TEXTS, null, 'select', 'Default Code Language'), - Setting('setting_usage', 'code_template', null, + Setting('setting_usage', 'codeTemplate', null, null, 'textarea', 'Default Code Template', 'If left blank, the built-in template of the corresponding language will be used.'), ]; @@ -28,22 +28,10 @@ const ACCOUNT_SETTINGS = [ 'We use Gravatar to present your avatar icon.'), Setting('setting_info', 'qq', null, null, null, 'QQ'), - Setting('setting_info', 'wechat', null, - null, null, 'WeChat'), Setting('setting_info', 'gender', builtin.USER_GENDER_RANGE, null, 'select', 'Gender'), Setting('setting_info', 'bio', null, null, 'markdown', 'Bio'), - Setting('setting_privacy', 'show_mail', builtin.PRIVACY_RANGE, - null, 'select', 'Email Visibility'), - Setting('setting_privacy', 'show_qq', builtin.PRIVACY_RANGE, - null, 'select', 'QQ Visibility'), - Setting('setting_privacy', 'show_wechat', builtin.PRIVACY_RANGE, - null, 'select', 'WeChat Visibility'), - Setting('setting_privacy', 'show_gender', builtin.PRIVACY_RANGE, - null, 'select', 'Gender Visibility'), - Setting('setting_privacy', 'show_bio', builtin.PRIVACY_RANGE, - null, 'select', 'Bio Visibility'), Setting('setting_customize', 'background_img', builtin.BACKGROUND_RANGE, null, 'image_radio', 'Profile Background Image', 'Choose the background image in your profile page.', diff --git a/hydro/model/token.js b/hydro/model/token.js index 07c80c79..1c2b73d1 100644 --- a/hydro/model/token.js +++ b/hydro/model/token.js @@ -77,9 +77,9 @@ module.exports = { return coll.deleteMany({ uid }); }, getMostRecentSessionByUid(uid) { - return coll.findOne({ uid, token_type: this.TYPE_SESSION }, { sort: { updateAt: -1 } }); + return coll.findOne({ uid, tokenType: this.TYPE_SESSION }, { sort: { updateAt: -1 } }); }, getSessionListByUid(uid) { - return coll.find({ uid, token_type: this.TYPE_SESSION }).sort('updateAt', -1).toArray(); + return coll.find({ uid, tokenType: this.TYPE_SESSION }).sort('updateAt', -1).toArray(); }, }; diff --git a/hydro/service/server.js b/hydro/service/server.js index 609efa1b..d9b9cd61 100644 --- a/hydro/service/server.js +++ b/hydro/service/server.js @@ -128,13 +128,12 @@ class Handler { this.now = new Date(); this._handler.sid = this.request.cookies.get('sid'); this._handler.save = this.request.cookies.get('save'); - this._handler.tokenType = token.TYPE_SESSION; if (this._handler.save) this._handler.expireSeconds = options.session.saved_expire_seconds; else this._handler.expireSeconds = options.session.unsaved_expire_seconds; this.session = this._handler.sid ? await token.update( this._handler.sid, - this._handler.tokenType, + token.TYPE_SESSION, this._handler.expireSeconds, { update_ip: this.request.ip, @@ -194,19 +193,16 @@ class Handler { } async saveCookie() { - if (this.session.sid) { + if (this.session._id) { await token.update( - this.session.sid, - this._handler.tokenType, + this.session._id, + token.TYPE_SESSION, this._handler.expireSeconds, - { - updateIp: this.request.ip, - updateUa: this.request.headers['user-agent'] || '', - }, + this.session, ); } else { - [this.session.sid] = await token.add( - this._handler.tokenType, + [this.session._id] = await token.add( + token.TYPE_SESSION, this._handler.expireSeconds, { createIp: this.request.ip, @@ -221,9 +217,9 @@ class Handler { if (this._handler.save) { cookie.expires = this.session.expireAt; cookie.maxAge = this._handler.expireSeconds; - this.request.cookies.set('save', 'true', cookie); + this.ctx.cookies.set('save', 'true', cookie); } - this.ctx.cookies.set('sid', this.session.sid, cookie); + this.ctx.cookies.set('sid', this.session._id, cookie); } async onerror(error) { diff --git a/locales/zh_CN.yaml b/locales/zh_CN.yaml index b82a7e14..ad3558b3 100644 --- a/locales/zh_CN.yaml +++ b/locales/zh_CN.yaml @@ -21,9 +21,7 @@ Bio Visibility: 个人简介可见性 Blog: 博客 Boom!: 炸了! Browser: 浏览器 -? By signing up a Hydro universal account, you can submit code and join discussions in all online - judging services provided by us. -: 注册一个 Hydro 通用账户,您就可以在我们提供的所有在线评测服务上提交代码、参与讨论。 +By signing up a Hydro universal account, you can submit code and join discussions in all online judging services provided by us.: 注册一个 Hydro 通用账户,您就可以在我们提供的所有在线评测服务上提交代码、参与讨论。 CLOSE: 关闭 Cancel: 取消 Ok: 确定 diff --git a/locales/zh_TW.yaml b/locales/zh_TW.yaml index 52e2d9ee..cd46174c 100644 --- a/locales/zh_TW.yaml +++ b/locales/zh_TW.yaml @@ -19,9 +19,7 @@ Bio Visibility: 個人簡介可見性 Blog: 部落格 Boom!: 炸了! Browser: 瀏覽器 -? By signing up a Hydro universal account, you can submit code and join discussions in all online - judging services provided by us. -: 註冊一個 Hydro 通用賬戶,您就可以在我們提供的所有線上評測服務上提交程式碼、參與討論。 +By signing up a Hydro universal account, you can submit code and join discussions in all online judging services provided by us.: 註冊一個 Hydro 通用賬戶,您就可以在我們提供的所有線上評測服務上提交程式碼、參與討論。 CLOSE: 關閉 Cancel: 取消 Ok: 確定 diff --git a/module/.gitkeep b/module/.gitkeep deleted file mode 100644 index e69de29b..00000000 diff --git a/module/module-pastebin/locale/zh_CN.yaml b/module/module-pastebin/locale/zh_CN.yaml new file mode 100644 index 00000000..bbf1830e --- /dev/null +++ b/module/module-pastebin/locale/zh_CN.yaml @@ -0,0 +1 @@ +pastebin: 剪贴板 \ No newline at end of file diff --git a/templates/about.html b/templates/about.html index 490a3b79..f7ac3bab 100644 --- a/templates/about.html +++ b/templates/about.html @@ -1,32 +1,5 @@ {% extends "layout/wiki_base.html" %} {% block wiki_content %} -
-
-

{{ _('About Vijos') }}

-
-
- {{ _('no_translation_warn')|safe }} -

Vijos 全称为 Velocious Informatics Judge Online System (高效信息学在线评测系统),致力于为用户提供安全、完善、开放的在线评测及题目交流等服务。

-

Vijos 是一个非营利性的公益网站,由 Mrw、同济大学和北京市第八十中学共同赞助。PingCAP、Google 和清华大学提供技术支持。

-
-
-
-
-

{{ _('Contact Us') }}

-
-
-

{{ _('Discussion') }}:

-
{{ _('QQ Group') }}: 248452688
-

{{ _('Manager') }}:

-
{{ _('QQ') }}: 514649176
{{ _('Email') }}: mrw # vijos.org
-

{{ _('Development') }}:

-
{{ _('QQ') }}: 490241327
{{ _('Email') }}: dev $ vijos.org
-

{{ _('Ops') }}:

-
{{ _('QQ') }}: 459834574
{{ _('Email') }}: ops [at] vijos.org
-

{{ _('Feedback') }}:

-
{{ _('QQ') }}: 1744540592
{{ _('Email') }}: feedback @ vijos.org
-
-

{{ _('Privacy') }}

@@ -36,20 +9,20 @@

1. 收集的信息

我们收集信息是为了向所有用户提供更好的服务。我们有两种信息收集方式:

2. 如何使用收集到的信息

-

我们利用从所有服务中收集的信息来提供、维护、保护和改进这些服务,同时开发新的服务并保护 Vijos 以及用户的隐私。

+

我们利用从所有服务中收集的信息来提供、维护、保护和改进这些服务,同时开发新的服务并保护 Hydro 以及用户的隐私。

当我们要将信息用于本隐私权政策未载明的其它用途时,则会事先征求您的同意。

3. 访问和更新您的个人信息

无论您在何时使用我们的服务,我们都力求让您能够访问自己的个人信息。如果这些信息有误,我们会努力通过各种方式让您快速更新信息或删除信息。在更新您的个人信息时,我们可能会要求您先验证自己的身份,然后再处理您的请求。

我们力求对服务进行完善的维护,以保护信息免遭意外或恶意的破坏。因此,当您从我们的服务中删除信息后,我们可能不会立即从在用的服务器中删除这些信息的残留副本,也可能不会从备份系统中删除相应的信息。

4. 信息安全

我们为您提供SSL加密访问服务,您可以通过SSL(https)使用我们的服务,这可以很大程度上保障在传输过程中您信息的安全。

-

对于敏感数据(如您的密码),我们承诺在存储时进行高强度不可逆加密。Vijos 的管理员、维护人员等均不能够访问到敏感数据的明文,所有操作均无人工介入。

+

对于敏感数据(如您的密码),我们承诺在存储时进行高强度不可逆加密。Hydro 的管理员、维护人员等均不能够访问到敏感数据的明文,所有操作均无人工介入。

@@ -58,8 +31,8 @@
{{ _('no_translation_warn')|safe }} -

0. 欢迎使用 Vijos

-

注册 Vijos 帐户和/或使用 Vijos 提供的服务(包括网页提供的在线服务和题目评测的非在线服务等),即表示您已同意本条款。请您务必审慎阅读,充分理解条款各项内容。

+

0. 欢迎使用 Hydro

+

注册 Hydro 帐户和/或使用 Hydro 提供的服务(包括网页提供的在线服务和题目评测的非在线服务等),即表示您已同意本条款。请您务必审慎阅读,充分理解条款各项内容。

1. 使用服务

您必须遵守各项服务中提供的所有政策(包括但不限于讨论和题解的版规)。

请勿滥用我们的服务。如,请勿干扰我们的服务,或尝试使用除我们提供的界面和指示以外的方法访问这些服务,或使用我们服务中出现的缺陷干扰其他网站或设施的正常运行。您仅能在法律允许的范围内使用我们的服务。

@@ -71,32 +44,32 @@
  • 发布、传送、传播广告信息及垃圾信息;
  • 其他法律法规禁止的行为。
  • -

    如果您违反了约定,相关国家相关机关或机构可能会对您提起诉讼、进行行政处罚或采取其他制裁措施,Vijos 将给于协助。造成损害的,您应依法予以赔偿,Vijos 不承担任何责任。

    -

    如果 Vijos 发现或收到他人举报您发布的信息违反约定,Vijos 有权进行独立判断并采取技术手段予以删除、屏蔽或断开链接。同时,Vijos 有权视用户的行为性质,采取包括但不限于暂停或终止服务,限制、冻结或终止账户使用,追究法律责任等措施。

    +

    如果您违反了约定,相关国家相关机关或机构可能会对您提起诉讼、进行行政处罚或采取其他制裁措施,Hydro 将给于协助。造成损害的,您应依法予以赔偿,Hydro 不承担任何责任。

    +

    如果 Hydro 发现或收到他人举报您发布的信息违反约定,Hydro 有权进行独立判断并采取技术手段予以删除、屏蔽或断开链接。同时,Hydro 有权视用户的行为性质,采取包括但不限于暂停或终止服务,限制、冻结或终止账户使用,追究法律责任等措施。

    2. 版权

    -

    使用我们的服务并不代表您拥有我们的服务或您所访问的内容的任何知识产权。网站上的所有材料(包括但不限于题目内容、用户界面、Wiki)版权均受保护,归 Vijos 所有。除非另有说明,本网站上的材料和服务仅用于个人和非商业用途,未经 Vijos 书面许可,不得复制、修改、创建衍生作品、传播、出版、公开演示、公开展示和分发从本网站获得的任何信息、文件、产品或服务。

    +

    使用我们的服务并不代表您拥有我们的服务或您所访问的内容的任何知识产权。网站上的所有材料(包括但不限于题目内容、用户界面、Wiki)版权均受保护,归 Hydro 所有。除非另有说明,本网站上的材料和服务仅用于个人和非商业用途,未经 Hydro 书面许可,不得复制、修改、创建衍生作品、传播、出版、公开演示、公开展示和分发从本网站获得的任何信息、文件、产品或服务。

    3. 您在我们服务中发布的内容

    我们的某些服务允许您提交内容。您保留对该内容持有的任何知识产权的所有权。

    -

    当您上传内容或通过其他方式向我们的服务提交内容时,您授予 Vijos 使用、持有、存储、复制、修改、创建衍生作品、传播、出版、公开演示、公开展示和分发此内容等权利。您在此许可中授予的权限,仅能用于运营、宣传和改进我们的服务,以及开发新的服务。该项许可在您停止使用我们的服务后依然有效。某些服务可能会向您提供一些方法,用于访问和删除您提供给该服务的内容。对于您提交至我们服务的任何内容,请确保您拥有向我们授予此许可的必要权利。我们有权在未通知您的情况下删除我们认为侵犯了知识产权或违反了相关法律法规的内容。

    +

    当您上传内容或通过其他方式向我们的服务提交内容时,您授予 Hydro 使用、持有、存储、复制、修改、创建衍生作品、传播、出版、公开演示、公开展示和分发此内容等权利。您在此许可中授予的权限,仅能用于运营、宣传和改进我们的服务,以及开发新的服务。该项许可在您停止使用我们的服务后依然有效。某些服务可能会向您提供一些方法,用于访问和删除您提供给该服务的内容。对于您提交至我们服务的任何内容,请确保您拥有向我们授予此许可的必要权利。我们有权在未通知您的情况下删除我们认为侵犯了知识产权或违反了相关法律法规的内容。

    4. 对于发布题目的附加条款

    -

    您可以在 Vijos 上创建新题目。您上传到 Vijos 的题目,除了适用于本协议第三条(即“您在我们服务中发布的内容”)条款,还包含以下附加条款(若有冲突的条款,以附加条款中的优先):

    +

    您可以在 Hydro 上创建新题目。您上传到 Hydro 的题目,除了适用于本协议第三条(即“您在我们服务中发布的内容”)条款,还包含以下附加条款(若有冲突的条款,以附加条款中的优先):

      -
    1. 您上传到 Vijos 上的题目版权为 Vijos 和您共同拥有,我们会在相关页面或在对其进行分发、传播等操作时标明版权所有者。 +

    2. 您上传到 Hydro 上的题目版权为 Hydro 和您共同拥有,我们会在相关页面或在对其进行分发、传播等操作时标明版权所有者。

    3. -
    4. Vijos 尊重他人知识产权和合法权益,请您在上传题目前确保拥有题目内容(包括但不限于题目描述、数据、图片等)的著作权及信息网络传播权或者已经取得上述全部权利人的许可并不存在任何著作权纠纷。Vijos有权在不通知的情况下删除被认为侵权的题目。 +

    5. Hydro 尊重他人知识产权和合法权益,请您在上传题目前确保拥有题目内容(包括但不限于题目描述、数据、图片等)的著作权及信息网络传播权或者已经取得上述全部权利人的许可并不存在任何著作权纠纷。Hydro有权在不通知的情况下删除被认为侵权的题目。

    6. 您可以申请将自己上传的优质题目合并到题库主干。我们的管理员会对您创建的题目的内容(包括但不限于评测数据等对用户不可见的信息)进行人工审核和适当修改以确认其符合国家基本法律法规。出于质量的考虑,我们也可能会拒绝您完全合法的合并到题库主干的请求。

    7. 我们会维护服务的稳定,并对数据(包括您递交的题目)进行定期的备份,并尽量在关闭服务前通知您,但我们仍然不对任何题目(包括主干和非主干)提供永久存储或保留的承诺,出于安全的考虑推荐您自行保留题目的内容。

    8. -
    9. 您有权决定 Vijos 是否公开您上传的题目的数据。公开题目数据意味着 Vijos 上的用户均有权利获取到您递交的题目的所有评测数据,但相关版权协议仍然生效。

      +
    10. 您有权决定 Hydro 是否公开您上传的题目的数据。公开题目数据意味着 Hydro 上的用户均有权利获取到您递交的题目的所有评测数据,但相关版权协议仍然生效。

    5. 隐私保护

    -

    Vijos 隐私声明介绍了您在使用我们的服务时,我们会如何处理您的个人数据和保护您的隐私。使用我们的服务即表示您同意 Vijos 可以按照我们的隐私权政策使用您的个人数据。

    +

    Hydro 隐私声明介绍了您在使用我们的服务时,我们会如何处理您的个人数据和保护您的隐私。使用我们的服务即表示您同意 Hydro 可以按照我们的隐私权政策使用您的个人数据。

    6. 修改和终止服务

    我们始终在不断更改和改进我们的服务。我们可能会增加或删除功能,也可能暂停或彻底停止某项服务。

    -

    您可以随时停止使用我们的服务,尽管我们对此表示非常遗憾。Vijos 也可能随时停止向您提供服务,或随时对我们的服务增加或设置新的限制。

    +

    您可以随时停止使用我们的服务,尽管我们对此表示非常遗憾。Hydro 也可能随时停止向您提供服务,或随时对我们的服务增加或设置新的限制。

    7. 保证和免责声明

    我们对服务内容、服务的具体功能,或其可靠性、可用性或满足您需要的能力不作任何承诺。我们的服务是按照现有技术和条件所能达到的现状提供的。我们会尽最大努力向您提供服务,确保服务的连贯性和安全性。但我们不能随时预见和防范法律、技术以及其他风险,包括但不限于不可抗力、病毒、木马、黑客攻击、系统不稳定、第三方服务瑕疵、政府行为等原因可能导致的服务中断、数据丢失以及其他的损失和风险。

    8. 关于本条款

    @@ -116,8 +89,8 @@

    第一次使用编辑器前,要先阅读编辑器快速入门和 Markdown 详细帮助。

    不得将讨论、题解混淆。例如,不得将题解发布到讨论中,题解应发布在相应题目的题解区中。

    -

    发布(或回复)的所有内容不得包含会干扰 Vijos 用户界面呈现的相关内容。

    -

    发布(或回复)的所有内容不得包含恶意代码和指向恶意网站或 Vijos 明确禁止的网站的链接。

    +

    发布(或回复)的所有内容不得包含会干扰 Hydro 用户界面呈现的相关内容。

    +

    发布(或回复)的所有内容不得包含恶意代码和指向恶意网站或 Hydro 明确禁止的网站的链接。

    特别地,发布(或回复)含有代码的内容时,应当将代码高亮。一个简单的方法是选中代码块然后按下 Tab 键。

    发布的题解禁止只包含无详细注释的代码。题解中难以理解的代码应当有尽可能详细的注释。

    打分、投票和评价应当客观。例如,对于题解的打分、投票和评价应当关注于题解本身的质量。

    diff --git a/templates/home_security.html b/templates/home_security.html index 8cb98817..7808b150 100644 --- a/templates/home_security.html +++ b/templates/home_security.html @@ -107,7 +107,7 @@
    - +
    diff --git a/templates/layout/html5.html b/templates/layout/html5.html index 65af835e..8d242b9f 100644 --- a/templates/layout/html5.html +++ b/templates/layout/html5.html @@ -5,7 +5,7 @@ {% import "components/noscript_note.html" as noscript_note with context %} {% import "components/user.html" as user with context %} - + @@ -24,20 +24,20 @@ {{ handler.renderTitle(page_title) }} + {% if not isIE(handler.request.headers['user-agent']) %} + {% endif %} {% block body %}{% endblock %} - - + {% if not isIE(handler.request.headers['user-agent']) %} + {% endif %} diff --git a/templates/partials/footer.html b/templates/partials/footer.html index 44aafde5..6f8eeb03 100644 --- a/templates/partials/footer.html +++ b/templates/partials/footer.html @@ -1,3 +1,4 @@ +{% if not isIE(handler.request.headers['user-agent']) %}
    +{% endif %} \ No newline at end of file diff --git a/templates/partials/nav.html b/templates/partials/nav.html index e40b4366..fd9d8cec 100644 --- a/templates/partials/nav.html +++ b/templates/partials/nav.html @@ -40,12 +40,12 @@