Add recommended instances (#97)

* Add recommended instances

* add translations

* dont pull submodule main branch in ci

* camelCase

* remove unused code
This commit is contained in:
Nutomic 2022-04-08 10:16:47 +00:00 committed by GitHub
parent fcd45027c4
commit 6e6d723f09
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 76 additions and 54 deletions

View File

@ -12,7 +12,7 @@ steps:
image: alpine/git image: alpine/git
commands: commands:
- git submodule init - git submodule init
- git submodule update --recursive --remote - git submodule update --recursive
- name: yarn - name: yarn
image: node:14-alpine image: node:14-alpine

View File

@ -1,21 +1,35 @@
import fs from 'fs'; import fs from 'fs';
import fetch from 'node-fetch';
import path from 'path'; import path from 'path';
const translationDir = "joinlemmy-translations/translations/"; const translationDir = "joinlemmy-translations/translations/";
const outDir = "src/shared/translations/"; const outDir = "src/shared/translations/";
const translatorsJsonFile = "lemmy-translations/translators.json"; const translatorsJsonFile = "lemmy-translations/translators.json";
const statsFile = "lemmy-instance-stats/stats.json"; const statsFile = "lemmy-instance-stats/stats.json";
const recommendationsFile = "lemmy-instance-stats/recommended-instances.csv";
const newsDir = "src/assets/news"; const newsDir = "src/assets/news";
const releasesLocation = "https://raw.githubusercontent.com/LemmyNet/lemmy/main/RELEASES.md";
fs.mkdirSync(outDir, { recursive: true }); fs.mkdirSync(outDir, { recursive: true });
// Write the stats file // Write the stats file
try { try {
const json = JSON.parse(fs.readFileSync(statsFile, "utf8")); const stats = JSON.parse(fs.readFileSync(statsFile, "utf8"));
const recommended_domains = fs.readFileSync(recommendationsFile, "utf8").split(',');
const recommended = stats.instance_details.filter(i =>
recommended_domains.includes(i.domain)
);
const remaining = stats.instance_details.filter(i =>
!recommended_domains.includes(i.domain)
);
let stats2 = {
crawled_instances: stats.crawled_instances,
total_users: stats.total_users,
recommended: recommended,
remaining: remaining,
}
let data = `export const instance_stats = \n `; let data = `export const instance_stats = \n `;
data += JSON.stringify(json, null, 2) + ";"; data += JSON.stringify(stats2, null, 2) + ";";
const target = outDir + "instance_stats.ts"; const target = outDir + "instance_stats.ts";
fs.writeFileSync(target, data); fs.writeFileSync(target, data);
} catch (err) { } catch (err) {

@ -1 +1 @@
Subproject commit 178c575193bf45cbf3d220f6a760961e95b09259 Subproject commit 6fc4a95b6eaf54e68983d217fb9a310e7c8ed63c

@ -1 +1 @@
Subproject commit 9d7a7f751aa43cbbf062244523d448b94a81e7ee Subproject commit 8c7a2e001508f40b171417d18952ad1896af85cd

@ -1 +1 @@
Subproject commit 2c557fdcf69659fb9ce587d786e362ca024bcca1 Subproject commit ad40feba4263a850f135946847d3ddd1a890a6e7

View File

@ -11,6 +11,25 @@ export class Instances extends Component<any, any> {
super(props, context); super(props, context);
} }
render() {
return (
<div class="container">
<Helmet title={title}>
<meta property={"title"} content={title} />
</Helmet>
<h1 class="is-marginless">{i18n.t("lemmy_servers")}</h1>
{this.header()}
<br />
<br />
{this.renderList(
i18n.t("recommended_instances"),
instance_stats.recommended
)}
{this.renderList(i18n.t("popular_instances"), instance_stats.remaining)}
</div>
);
}
header() { header() {
return ( return (
<i> <i>
@ -22,20 +41,10 @@ export class Instances extends Component<any, any> {
); );
} }
render() { renderList(header: string, instances: any[]) {
let instances = instance_stats.instance_details;
return ( return (
<div> <div>
<Helmet title={title}> <h2>{header}</h2>
<meta property={"title"} content={title} />
</Helmet>
<div class="container">
<h1 class="is-marginless">{i18n.t("lemmy_servers")}</h1>
{this.header()}
<br />
<br />
<p>{i18n.t("choose_and_join")}</p>
<div class="row"> <div class="row">
{instances.map(i => ( {instances.map(i => (
<div class="card col-6"> <div class="card col-6">
@ -73,7 +82,6 @@ export class Instances extends Component<any, any> {
))} ))}
</div> </div>
</div> </div>
</div>
); );
} }
} }