forked from cory/tildefriends
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:
@ -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);
|
||||
});
|
Reference in New Issue
Block a user