lemmy/ui/src/components/sponsors.tsx

189 lines
4.6 KiB
TypeScript
Raw Normal View History

2019-04-24 03:17:02 +00:00
import { Component } from 'inferno';
import { Subscription } from 'rxjs';
import { retryWhen, delay, take } from 'rxjs/operators';
import { WebSocketService } from '../services';
import {
GetSiteResponse,
WebSocketJsonResponse,
UserOperation,
} from '../interfaces';
import { i18n } from '../i18next';
import { T } from 'inferno-i18next';
import { repoUrl, wsJsonToRes, toast } from '../utils';
2019-04-24 03:17:02 +00:00
2020-05-17 20:49:34 +00:00
interface SilverUser {
name: string;
2020-07-02 02:50:55 +00:00
link?: string;
2020-05-17 20:49:34 +00:00
}
2020-02-03 23:01:14 +00:00
let general = [
2020-07-17 19:27:06 +00:00
'Rachel Schmitz',
'comradeda',
2020-07-05 20:01:41 +00:00
'ybaumy',
2020-07-03 21:56:50 +00:00
'dude in phx',
2020-07-02 02:50:55 +00:00
'twilight loki',
2020-06-29 13:38:50 +00:00
'Andrew Plaza',
'Jonathan Cremin',
'Arthur Nieuwland',
2020-06-07 01:22:39 +00:00
'Ernest Wiśniewski',
'HN',
2020-04-27 12:55:31 +00:00
'Forrest Weghorst',
2020-02-03 23:01:14 +00:00
'Andre Vallestero',
'NotTooHighToHack',
];
2020-07-02 02:54:52 +00:00
let highlighted = ['DiscountFuneral', 'Oskenso Kashi', 'Alex Benishek'];
2020-05-17 20:49:34 +00:00
let silver: Array<SilverUser> = [
{
name: 'Redjoker',
2020-05-22 01:15:39 +00:00
link: 'https://iww.org',
2020-05-17 20:49:34 +00:00
},
];
2019-04-24 03:17:02 +00:00
// let gold = [];
// let latinum = [];
export class Sponsors extends Component<any, any> {
private subscription: Subscription;
2019-04-24 03:17:02 +00:00
constructor(props: any, context: any) {
super(props, context);
this.subscription = WebSocketService.Instance.subject
.pipe(retryWhen(errors => errors.pipe(delay(3000), take(10))))
.subscribe(
msg => this.parseMessage(msg),
err => console.error(err),
() => console.log('complete')
);
WebSocketService.Instance.getSite();
2019-04-24 03:17:02 +00:00
}
componentDidMount() {
2020-01-19 21:28:29 +00:00
window.scrollTo(0, 0);
2019-04-24 03:17:02 +00:00
}
componentWillUnmount() {
this.subscription.unsubscribe();
}
2019-04-24 03:17:02 +00:00
render() {
return (
<div class="container text-center">
{this.topMessage()}
<hr />
{this.sponsors()}
<hr />
{this.bitcoin()}
</div>
);
2019-04-24 03:17:02 +00:00
}
topMessage() {
return (
<div>
<h5>{i18n.t('donate_to_lemmy')}</h5>
2019-04-24 03:17:02 +00:00
<p>
<T i18nKey="sponsor_message">
#<a href={repoUrl}>#</a>
</T>
2019-04-24 03:17:02 +00:00
</p>
2020-02-05 19:14:05 +00:00
<a class="btn btn-secondary" href="https://liberapay.com/Lemmy/">
{i18n.t('support_on_liberapay')}
</a>
<a
class="btn btn-secondary ml-2"
href="https://www.patreon.com/dessalines"
>
{i18n.t('support_on_patreon')}
</a>
<a
class="btn btn-secondary ml-2"
href="https://opencollective.com/lemmy"
>
{i18n.t('support_on_open_collective')}
</a>
2019-04-24 03:17:02 +00:00
</div>
);
2019-04-24 03:17:02 +00:00
}
sponsors() {
return (
2019-04-26 01:42:21 +00:00
<div class="container">
<h5>{i18n.t('sponsors')}</h5>
2020-05-17 20:49:34 +00:00
<p>{i18n.t('silver_sponsors')}</p>
<div class="row card-columns">
{silver.map(s => (
<div class="card col-12 col-md-2">
<div>
2020-07-02 02:50:55 +00:00
{s.link ? (
<a href={s.link} target="_blank" rel="noopener">
💎 {s.name}
</a>
) : (
<div>💎 {s.name}</div>
)}
2020-05-17 20:49:34 +00:00
</div>
</div>
))}
</div>
<p>{i18n.t('general_sponsors')}</p>
2019-04-26 01:42:21 +00:00
<div class="row card-columns">
2020-01-15 15:28:27 +00:00
{highlighted.map(s => (
<div class="card bg-primary col-12 col-md-2 font-weight-bold">
<div>{s}</div>
</div>
))}
{general.map(s => (
2019-04-24 03:17:02 +00:00
<div class="card col-12 col-md-2">
<div>{s}</div>
</div>
))}
2019-04-24 03:17:02 +00:00
</div>
</div>
);
2019-04-24 03:17:02 +00:00
}
bitcoin() {
return (
<div>
<h5>{i18n.t('crypto')}</h5>
<div class="table-responsive">
<table class="table table-hover text-center">
<tbody>
<tr>
<td>{i18n.t('bitcoin')}</td>
<td>
<code>1Hefs7miXS5ff5Ck5xvmjKjXf5242KzRtK</code>
</td>
</tr>
<tr>
<td>{i18n.t('ethereum')}</td>
<td>
<code>0x400c96c96acbC6E7B3B43B1dc1BB446540a88A01</code>
</td>
</tr>
<tr>
<td>{i18n.t('monero')}</td>
<td>
<code>
41taVyY6e1xApqKyMVDRVxJ76sPkfZhALLTjRvVKpaAh2pBd4wv9RgYj1tSPrx8wc6iE1uWUfjtQdTmTy2FGMeChGVKPQuV
</code>
</td>
</tr>
</tbody>
</table>
</div>
2019-04-24 03:17:02 +00:00
</div>
);
2019-04-24 03:17:02 +00:00
}
parseMessage(msg: WebSocketJsonResponse) {
console.log(msg);
let res = wsJsonToRes(msg);
if (msg.error) {
toast(i18n.t(msg.error), 'danger');
return;
} else if (res.op == UserOperation.GetSite) {
let data = res.data as GetSiteResponse;
document.title = `${i18n.t('sponsors')} - ${data.site.name}`;
}
}
2019-04-24 03:17:02 +00:00
}