summaryrefslogtreecommitdiffstats
path: root/client/components
diff options
context:
space:
mode:
authornztqa <nztqa@users.noreply.github.com>2017-08-03 09:24:40 +0900
committernztqa <nztqa@users.noreply.github.com>2017-08-03 09:24:40 +0900
commite407eb9a8b91d1100315f2fcab2cf8d184957929 (patch)
tree197510f28ad8ef829abc0f085a07dad2086eb943 /client/components
parent3085230b13e55542a4d95e9357366688b3e2fd1a (diff)
downloadwekan-e407eb9a8b91d1100315f2fcab2cf8d184957929.tar.gz
wekan-e407eb9a8b91d1100315f2fcab2cf8d184957929.tar.bz2
wekan-e407eb9a8b91d1100315f2fcab2cf8d184957929.zip
Add display wekan version number and runtime environment
Diffstat (limited to 'client/components')
-rw-r--r--client/components/settings/informationBody.jade51
-rw-r--r--client/components/settings/informationBody.js48
-rw-r--r--client/components/settings/settingHeader.jade7
3 files changed, 104 insertions, 2 deletions
diff --git a/client/components/settings/informationBody.jade b/client/components/settings/informationBody.jade
new file mode 100644
index 00000000..53907513
--- /dev/null
+++ b/client/components/settings/informationBody.jade
@@ -0,0 +1,51 @@
+template(name='information')
+ .setting-content
+ unless currentUser.isAdmin
+ | {{_ 'error-notAuthorized'}}
+ else
+ .content-title
+ span {{_ 'info'}}
+ .content-body
+ .side-menu
+ ul
+ li.active
+ a.js-setting-menu(data-id="information-display") {{_ 'info'}}
+ .main-body
+ +statistics
+
+template(name='statistics')
+ table
+ tbody
+ tr
+ th {{_ 'Wekan_version'}}
+ td {{statistics.version}}
+ tr
+ th {{_ 'Node_version'}}
+ td {{statistics.process.nodeVersion}}
+ tr
+ th {{_ 'OS_Type'}}
+ td {{statistics.os.type}}
+ tr
+ th {{_ 'OS_Platform'}}
+ td {{statistics.os.platform}}
+ tr
+ th {{_ 'OS_Arch'}}
+ td {{statistics.os.arch}}
+ tr
+ th {{_ 'OS_Release'}}
+ td {{statistics.os.release}}
+ tr
+ th {{_ 'OS_Uptime'}}
+ td {{humanReadableTime statistics.os.uptime}}
+ tr
+ th {{_ 'OS_Loadavg'}}
+ td {{numFormat statistics.os.loadavg.[0]}}, {{numFormat statistics.os.loadavg.[1]}}, {{numFormat statistics.os.loadavg.[2]}}
+ tr
+ th {{_ 'OS_Totalmem'}}
+ td {{bytesToSize statistics.os.totalmem}}
+ tr
+ th {{_ 'OS_Freemem'}}
+ td {{bytesToSize statistics.os.freemem}}
+ tr
+ th {{_ 'OS_Cpus'}}
+ td {{statistics.os.cpus.length}}
diff --git a/client/components/settings/informationBody.js b/client/components/settings/informationBody.js
new file mode 100644
index 00000000..4775bce6
--- /dev/null
+++ b/client/components/settings/informationBody.js
@@ -0,0 +1,48 @@
+BlazeComponent.extendComponent({
+ onCreated() {
+ this.info = new ReactiveVar({});
+ Meteor.call('getStatistics', (error, ret) => {
+ if (!error && ret) {
+ this.info.set(ret);
+ }
+ });
+ },
+
+ statistics() {
+ return this.info.get();
+ },
+
+ humanReadableTime(time) {
+ const days = Math.floor(time / 86400);
+ const hours = Math.floor((time % 86400) / 3600);
+ const minutes = Math.floor(((time % 86400) % 3600) / 60);
+ const seconds = Math.floor(((time % 86400) % 3600) % 60);
+ let out = '';
+ if (days > 0) {
+ out += `${days} ${TAPi18n.__('days')}, `;
+ }
+ if (hours > 0) {
+ out += `${hours} ${TAPi18n.__('hours')}, `;
+ }
+ if (minutes > 0) {
+ out += `${minutes} ${TAPi18n.__('minutes')}, `;
+ }
+ if (seconds > 0) {
+ out += `${seconds} ${TAPi18n.__('seconds')}`;
+ }
+ return out;
+ },
+
+ numFormat(number) {
+ return parseFloat(number).toFixed(2);
+ },
+
+ bytesToSize(bytes) {
+ const sizes = ['Bytes', 'KB', 'MB', 'GB', 'TB'];
+ if (bytes === 0) {
+ return '0 Byte';
+ }
+ const i = parseInt(Math.floor(Math.log(bytes) / Math.log(1024)), 10);
+ return `${Math.round(bytes / Math.pow(1024, i), 2)} ${sizes[i]}`;
+ },
+}).register('statistics');
diff --git a/client/components/settings/settingHeader.jade b/client/components/settings/settingHeader.jade
index fb884056..c22cf5c6 100644
--- a/client/components/settings/settingHeader.jade
+++ b/client/components/settings/settingHeader.jade
@@ -6,10 +6,13 @@ template(name="settingHeaderBar")
unless isMiniScreen
unless isSandstorm
if currentUser
- a.setting-header-btn.settings.active
+ a.setting-header-btn.settings(href="{{pathFor 'setting'}}")
i.fa(class="fa-cog")
span {{_ 'settings'}}
-//TODO
+ a.setting-header-btn.informations(href="{{pathFor 'information'}}")
+ i.fa(class="fa-info-circle")
+ span {{_ 'info'}}
+//TODO
// a.setting-header-btn.people
// i.fa(class="fa-users")
// span {{_ 'people'}}