mirror of
https://github.com/wekan/wekan.git
synced 2025-04-23 13:37:09 -04:00
Merge branch 'improve-info' of https://github.com/nztqa/wekan into nztqa-improve-info
This commit is contained in:
commit
8ad704ca0a
7 changed files with 166 additions and 3 deletions
51
client/components/settings/informationBody.jade
Normal file
51
client/components/settings/informationBody.jade
Normal file
|
@ -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}}
|
48
client/components/settings/informationBody.js
Normal file
48
client/components/settings/informationBody.js
Normal file
|
@ -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');
|
|
@ -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'}}
|
||||
|
|
|
@ -120,6 +120,26 @@ FlowRouter.route('/setting', {
|
|||
},
|
||||
});
|
||||
|
||||
FlowRouter.route('/information', {
|
||||
name: 'information',
|
||||
triggersEnter: [
|
||||
AccountsTemplates.ensureSignedIn,
|
||||
() => {
|
||||
Session.set('currentBoard', null);
|
||||
Session.set('currentCard', null);
|
||||
|
||||
Filter.reset();
|
||||
EscapeActions.executeAll();
|
||||
},
|
||||
],
|
||||
action() {
|
||||
BlazeLayout.render('defaultLayout', {
|
||||
headerBar: 'settingHeaderBar',
|
||||
content: 'information',
|
||||
});
|
||||
},
|
||||
});
|
||||
|
||||
FlowRouter.notFound = {
|
||||
action() {
|
||||
BlazeLayout.render('defaultLayout', { content: 'notFound' });
|
||||
|
|
|
@ -365,5 +365,19 @@
|
|||
"error-invitation-code-not-exist": "Invitation code doesn't exist",
|
||||
"error-notAuthorized": "You are not authorized to view this page.",
|
||||
"outgoing-webhooks": "Outgoing Webhooks",
|
||||
"outgoingWebhooksPopup-title": "Outgoing Webhooks"
|
||||
"outgoingWebhooksPopup-title": "Outgoing Webhooks",
|
||||
"Wekan_version": "Wekan version",
|
||||
"Node_version": "Node version",
|
||||
"OS_Arch": "OS Arch",
|
||||
"OS_Cpus": "OS CPU Count",
|
||||
"OS_Freemem": "OS Free Memory",
|
||||
"OS_Loadavg": "OS Load Average",
|
||||
"OS_Platform": "OS Platform",
|
||||
"OS_Release": "OS Release",
|
||||
"OS_Totalmem": "OS Total Memory",
|
||||
"OS_Type": "OS Type",
|
||||
"OS_Uptime": "OS Uptime",
|
||||
"hours": "hours",
|
||||
"minutes": "minutes",
|
||||
"seconds": "seconds"
|
||||
}
|
||||
|
|
|
@ -28,6 +28,7 @@
|
|||
"bson": "^1.0.4",
|
||||
"es6-promise": "^4.1.0",
|
||||
"meteor-node-stubs": "^0.2.6",
|
||||
"os": "^0.1.1",
|
||||
"winston": "^2.3.1",
|
||||
"winston-zulip": "0.0.6",
|
||||
"xss": "^0.3.3"
|
||||
|
|
26
server/statistics.js
Normal file
26
server/statistics.js
Normal file
|
@ -0,0 +1,26 @@
|
|||
Meteor.methods({
|
||||
getStatistics() {
|
||||
const os = require('os');
|
||||
const pjson = require('/package.json');
|
||||
const statistics = {};
|
||||
statistics.version = pjson.version;
|
||||
statistics.os = {
|
||||
type: os.type(),
|
||||
platform: os.platform(),
|
||||
arch: os.arch(),
|
||||
release: os.release(),
|
||||
uptime: os.uptime(),
|
||||
loadavg: os.loadavg(),
|
||||
totalmem: os.totalmem(),
|
||||
freemem: os.freemem(),
|
||||
cpus: os.cpus(),
|
||||
};
|
||||
statistics.process = {
|
||||
nodeVersion: process.version,
|
||||
pid: process.pid,
|
||||
uptime: process.uptime(),
|
||||
};
|
||||
|
||||
return statistics;
|
||||
},
|
||||
});
|
Loading…
Add table
Add a link
Reference in a new issue