mirror of
https://codeberg.org/fediverse/fediparty.git
synced 2025-01-25 10:16:40 +00:00
Add temporary filter by license in Misc
This commit is contained in:
parent
e18077d9cb
commit
2321786a24
|
@ -335,7 +335,7 @@
|
||||||
"description": "Federated, ActivityPub-compatible social network with friends, walls, and groups.",
|
"description": "Federated, ActivityPub-compatible social network with friends, walls, and groups.",
|
||||||
"codeLanguage": "Java",
|
"codeLanguage": "Java",
|
||||||
"techStack": "",
|
"techStack": "",
|
||||||
"license": "Unlicense (public domain)",
|
"license": "Public domain",
|
||||||
"FediAccount": "@grishka@mastodon.social",
|
"FediAccount": "@grishka@mastodon.social",
|
||||||
"apClass": true,
|
"apClass": true,
|
||||||
"zotClass": false,
|
"zotClass": false,
|
||||||
|
@ -677,7 +677,7 @@
|
||||||
"description": "Federating guild website using GuildWars2 API.",
|
"description": "Federating guild website using GuildWars2 API.",
|
||||||
"codeLanguage": "Go",
|
"codeLanguage": "Go",
|
||||||
"techStack": "",
|
"techStack": "",
|
||||||
"license": "-",
|
"license": "Unknown",
|
||||||
"FediAccount": "@ben@mastodon.lubar.me",
|
"FediAccount": "@ben@mastodon.lubar.me",
|
||||||
"apClass": true,
|
"apClass": true,
|
||||||
"zotClass": false,
|
"zotClass": false,
|
||||||
|
@ -731,7 +731,7 @@
|
||||||
"description": "A distributed social network by ActivityPub specification co-author Christopher Lemmer Webber.",
|
"description": "A distributed social network by ActivityPub specification co-author Christopher Lemmer Webber.",
|
||||||
"codeLanguage": "Racket",
|
"codeLanguage": "Racket",
|
||||||
"techStack": "",
|
"techStack": "",
|
||||||
"license": "Apache-2",
|
"license": "Apache-2.0",
|
||||||
"FediAccount": "@spritelyproject@octodon.social",
|
"FediAccount": "@spritelyproject@octodon.social",
|
||||||
"apClass": true,
|
"apClass": true,
|
||||||
"zotClass": false,
|
"zotClass": false,
|
||||||
|
@ -1289,7 +1289,7 @@
|
||||||
"description": "ActivityPub compliant, Mastodon-compatible transit alerts generated from GTFS-realtime Service Alerts",
|
"description": "ActivityPub compliant, Mastodon-compatible transit alerts generated from GTFS-realtime Service Alerts",
|
||||||
"codeLanguage": "Typescript",
|
"codeLanguage": "Typescript",
|
||||||
"techStack": "",
|
"techStack": "",
|
||||||
"license": "",
|
"license": "Unknown",
|
||||||
"FediAccount": "",
|
"FediAccount": "",
|
||||||
"apClass": true,
|
"apClass": true,
|
||||||
"zotClass": false,
|
"zotClass": false,
|
||||||
|
@ -1343,7 +1343,7 @@
|
||||||
"description": "Minimal ActivityPub server built with Laravel.",
|
"description": "Minimal ActivityPub server built with Laravel.",
|
||||||
"codeLanguage": "PHP",
|
"codeLanguage": "PHP",
|
||||||
"techStack": "Laravel",
|
"techStack": "Laravel",
|
||||||
"license": "-",
|
"license": "Unknown",
|
||||||
"FediAccount": "@bugle@bugle.lol",
|
"FediAccount": "@bugle@bugle.lol",
|
||||||
"apClass": true,
|
"apClass": true,
|
||||||
"zotClass": false,
|
"zotClass": false,
|
||||||
|
@ -1397,7 +1397,7 @@
|
||||||
"description": "Social networking platform compatible with Mastodon, Pleroma, etc.",
|
"description": "Social networking platform compatible with Mastodon, Pleroma, etc.",
|
||||||
"codeLanguage": "Rust",
|
"codeLanguage": "Rust",
|
||||||
"techStack": "Svelte",
|
"techStack": "Svelte",
|
||||||
"license": "-",
|
"license": "Unknown",
|
||||||
"FediAccount": "",
|
"FediAccount": "",
|
||||||
"apClass": true,
|
"apClass": true,
|
||||||
"zotClass": false,
|
"zotClass": false,
|
||||||
|
|
|
@ -3,28 +3,48 @@ layout: layout
|
||||||
---
|
---
|
||||||
|
|
||||||
<%
|
<%
|
||||||
function langCount(arr) {
|
// function langCount(arr) {
|
||||||
let langs = [];
|
// let langs = [];
|
||||||
|
// arr.forEach(function(item) {
|
||||||
|
// let lang = item.codeLanguage;
|
||||||
|
// if (!lang) {return};
|
||||||
|
// let check = langs.findIndex(function(x) {return x.language === lang});
|
||||||
|
// if (check>=0) {
|
||||||
|
// langs[check].count +=1;
|
||||||
|
// } else {
|
||||||
|
// let newLang = {};
|
||||||
|
// newLang.language = lang;
|
||||||
|
// newLang.count = 1;
|
||||||
|
// langs.push(newLang);
|
||||||
|
// }
|
||||||
|
// });
|
||||||
|
// return langs;
|
||||||
|
// }
|
||||||
|
|
||||||
|
function groupByKey(arr, key) {
|
||||||
|
let results = [];
|
||||||
arr.forEach(function(item) {
|
arr.forEach(function(item) {
|
||||||
let lang = item.codeLanguage;
|
let keyValue = item[key];
|
||||||
if (!lang) {return};
|
if (!keyValue) {return};
|
||||||
let check = langs.findIndex(function(x) {return x.language === lang});
|
let check = results.findIndex(function(x) {return x.name === keyValue});
|
||||||
if (check>=0) {
|
if (check>=0) {
|
||||||
langs[check].count +=1;
|
results[check].count +=1;
|
||||||
} else {
|
} else {
|
||||||
let newLang = {};
|
let newGroup = {};
|
||||||
newLang.language = lang;
|
newGroup.name = keyValue;
|
||||||
newLang.count = 1;
|
newGroup.count = 1;
|
||||||
langs.push(newLang);
|
results.push(newGroup);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
return langs;
|
return results;
|
||||||
}
|
}
|
||||||
|
|
||||||
const apps = site.data.miscellaneous.apps;
|
const apps = site.data.miscellaneous.apps;
|
||||||
const langList = langCount(apps).sort((a,b) => b.count - a.count);
|
const langList = groupByKey(apps, "codeLanguage").sort((a,b) => b.count - a.count);
|
||||||
|
const licenseList = groupByKey(apps, "license").sort((a,b) => b.count - a.count);
|
||||||
const byCategory = [['snMacro', 'Social network (macro)'], ['snMicro', 'Social network (micro)'], ['blogPub', 'Blog and Publishing'], ['media', 'Media sharing'], ['links', 'Link sharing'], ['evMeet', 'Events and Meetups'], ['files', 'File hosting'], ['data', 'Open data'], ['reviews', 'Reviewing'], ['games', 'Gaming'], ['dev', 'Software development'], ['extend', 'Extensions'], ['forums', 'Forums, boards'], ['other', 'Other']];
|
const byCategory = [['snMacro', 'Social network (macro)'], ['snMicro', 'Social network (micro)'], ['blogPub', 'Blog and Publishing'], ['media', 'Media sharing'], ['links', 'Link sharing'], ['evMeet', 'Events and Meetups'], ['files', 'File hosting'], ['data', 'Open data'], ['reviews', 'Reviewing'], ['games', 'Gaming'], ['dev', 'Software development'], ['extend', 'Extensions'], ['forums', 'Forums, boards'], ['other', 'Other']];
|
||||||
const byProtocol = [['sortDiaspora', 'diaspora'], ['sortZot', 'Zot'], ['sortAP', 'ActivityPub'], ['sortOstatus', 'OStatus']];
|
const byProtocol = [['sortDiaspora', 'diaspora'], ['sortZot', 'Zot'], ['sortAP', 'ActivityPub'], ['sortOstatus', 'OStatus']];
|
||||||
|
const pattern = /[\s0.-]/g;
|
||||||
%>
|
%>
|
||||||
|
|
||||||
<%- partial('_partial/heroheader') %>
|
<%- partial('_partial/heroheader') %>
|
||||||
|
@ -46,7 +66,13 @@ layout: layout
|
||||||
<h4>Sort by code language:</h4>
|
<h4>Sort by code language:</h4>
|
||||||
<label class="option" for="all">All</label><input id="all" type="radio" name="radio">
|
<label class="option" for="all">All</label><input id="all" type="radio" name="radio">
|
||||||
<% for (i in langList) { %>
|
<% for (i in langList) { %>
|
||||||
<label class="option" for="<%= langList[i].language.toLowerCase() %>"><%= langList[i].language %> <span>(<%= langList[i].count %>)</span></label><input id="<%= langList[i].language.toLowerCase() %>" type="radio" name="radio">
|
<label class="option" for="<%= langList[i].name.toLowerCase() %>"><%= langList[i].name %> <span>(<%= langList[i].count %>)</span></label><input id="<%= langList[i].name.toLowerCase() %>" type="radio" name="radio">
|
||||||
|
<% } %>
|
||||||
|
|
||||||
|
<h4>Sort by license:</h4>
|
||||||
|
<label class="option" for="all">All</label><input id="all" type="radio" name="radio">
|
||||||
|
<% for (i in licenseList) { %>
|
||||||
|
<label class="option" for="<%= licenseList[i].name.toLowerCase().replace(pattern, '') %>"><%= licenseList[i].name %> <span>(<%= licenseList[i].count %>)</span></label><input id="<%= licenseList[i].name.toLowerCase().replace(pattern, '') %>" type="radio" name="radio">
|
||||||
<% } %>
|
<% } %>
|
||||||
|
|
||||||
<section class="grid misc__grid cards">
|
<section class="grid misc__grid cards">
|
||||||
|
@ -54,7 +80,7 @@ layout: layout
|
||||||
<% let type = apps[item].categories %>
|
<% let type = apps[item].categories %>
|
||||||
<% let lang = apps[item].codeLanguage.toLowerCase() %>
|
<% let lang = apps[item].codeLanguage.toLowerCase() %>
|
||||||
|
|
||||||
<button class="card <%= lang %> <% if (apps[item].apClass) { %>ap<% } %> <% if (apps[item].zotClass) { %>zot<% } %> <% if (apps[item].diasporaClass) { %>dia<% } %> <% if (apps[item].OStatusClass) { %>os<% } %> <% for (t in type) { %> <%=type[t]%> <% } %>">
|
<button class="card <%= lang %> <%= apps[item].license.toLowerCase().replace(pattern, '') %> <% if (apps[item].apClass) { %>ap<% } %> <% if (apps[item].zotClass) { %>zot<% } %> <% if (apps[item].diasporaClass) { %>dia<% } %> <% if (apps[item].OStatusClass) { %>os<% } %> <% for (t in type) { %> <%=type[t]%> <% } %>">
|
||||||
|
|
||||||
<div class="card__content">
|
<div class="card__content">
|
||||||
<div class="card__title">
|
<div class="card__title">
|
||||||
|
|
|
@ -284,7 +284,20 @@
|
||||||
#lisp:checked ~ .misc__grid .card:not(.lisp),
|
#lisp:checked ~ .misc__grid .card:not(.lisp),
|
||||||
#clojure:checked ~ .misc__grid .card:not(.clojure),
|
#clojure:checked ~ .misc__grid .card:not(.clojure),
|
||||||
#hare:checked ~ .misc__grid .card:not(.hare),
|
#hare:checked ~ .misc__grid .card:not(.hare),
|
||||||
#nim:checked ~ .misc__grid .card:not(.nim) {
|
#nim:checked ~ .misc__grid .card:not(.nim),
|
||||||
|
#agpl3:checked ~ .misc__grid .card:not(.agpl3),
|
||||||
|
#mit:checked ~ .misc__grid .card:not(.mit),
|
||||||
|
#gpl3:checked ~ .misc__grid .card:not(.gpl3),
|
||||||
|
#apache2:checked ~ .misc__grid .card:not(.apache2),
|
||||||
|
#unknown:checked ~ .misc__grid .card:not(.unknown),
|
||||||
|
#bsd3clause:checked ~ .misc__grid .card:not(.bsd3clause),
|
||||||
|
#isc:checked ~ .misc__grid .card:not(.isc),
|
||||||
|
#publicdomain:checked ~ .misc__grid .card:not(.publicdomain),
|
||||||
|
#anticapitalist14:checked ~ .misc__grid .card:not(.anticapitalist14),
|
||||||
|
#lgpl3:checked ~ .misc__grid .card:not(.lgpl3),
|
||||||
|
#gpl2:checked ~ .misc__grid .card:not(.gpl2),
|
||||||
|
#ppl3:checked ~ .misc__grid .card:not(.ppl3),
|
||||||
|
#blueoak:checked ~ .misc__grid .card:not(.blueoak) {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue