Show service processes differently on the index. Expose manifests to package list. Add a work in process library of shared user interface code.

git-svn-id: https://www.unprompted.com/svn/projects/tildefriends/trunk@3193 ed5197a5-7fde-0310-b194-c3ffbd925b24
This commit is contained in:
2016-04-09 16:42:15 +00:00
parent 4d0fdfa484
commit 41a12fd1a7
3 changed files with 133 additions and 18 deletions

View File

@ -4,16 +4,25 @@ core.register("onSessionBegin", index);
core.register("onSessionEnd", index);
function index() {
Promise.all([core.getPackages(), core.getUsers()]).then(function(values) {
return Promise.all([core.getPackages(), core.getUsers()]).then(function(values) {
let packages = values[0];
let users = values[1];
let usersByApp = {};
let servicesByApp = {};
for (let i in users) {
let user = users[i];
if (!usersByApp["/~" + user.packageOwner + "/" + user.packageName]) {
usersByApp["/~" + user.packageOwner + "/" + user.packageName] = [];
let key = "/~" + user.packageOwner + "/" + user.packageName;
if (user.key.substring(0, "service_".length) == "service_") {
if (!servicesByApp[key]) {
servicesByApp[key] = [];
}
servicesByApp[key].push(user);
} else {
if (!usersByApp[key]) {
usersByApp[key] = [];
}
usersByApp[key].push(user.name);
}
usersByApp["/~" + user.packageOwner + "/" + user.packageName].push(user.name);
}
terminal.cork();
@ -23,23 +32,32 @@ function index() {
return Math.sign(x.owner.localeCompare(y.owner)) * 10 + Math.sign(x.name.localeCompare(y.name)) * 1;
}).forEach(function(app) {
let users = usersByApp["/~" + app.owner + "/" + app.name];
let services = servicesByApp["/~" + app.owner + "/" + app.name];
let message = [];
if (users) {
if (users || services) {
message.push(" [");
let counts = {};
for (let i = 0; i < users.length; i++) {
counts[users[i]] = (counts[users[i]] || 0) + 1;
if (users) {
let counts = {};
for (let i = 0; i < users.length; i++) {
counts[users[i]] = (counts[users[i]] || 0) + 1;
}
let names = Object.keys(counts).sort();
for (let i = 0; i < names.length; i++) {
var name = names[i];
if (message.length > 1) {
message.push(", ");
}
message.push({class: "orange", value: name});
if (counts[name] > 1) {
message.push({class: "base01", value: "(x" + counts[name] + ")"});
}
}
}
let names = Object.keys(counts).sort();
for (let i = 0; i < names.length; i++) {
var name = names[i];
if (message.length > 1) {
if (services) {
if (users) {
message.push(", ");
}
message.push({class: "orange", value: name});
if (counts[name] > 1) {
message.push({class: "base01", value: "(x" + counts[name] + ")"});
}
message.push("⚒".repeat(services.length));
}
message.push("]");
}
@ -52,4 +70,6 @@ function index() {
});
}
index();
index().catch(function(error) {
terminal.print("ERROR:", error);
});