lemmy/ui/src/components/sponsors.tsx

155 lines
3.7 KiB
TypeScript
Raw Normal View History

2019-04-24 03:17:02 +00:00
import { Component } from 'inferno';
import { WebSocketService } from '../services';
import { i18n } from '../i18next';
import { T } from 'inferno-i18next';
import { repoUrl } 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-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> {
constructor(props: any, context: any) {
super(props, context);
}
componentDidMount() {
document.title = `${i18n.t('sponsors')} - ${
WebSocketService.Instance.site.name
}`;
2020-01-19 21:28:29 +00:00
window.scrollTo(0, 0);
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
}
}