Add inviting client tile
This commit is contained in:
parent
dd8aa3d074
commit
6e7a119831
3 changed files with 98 additions and 2 deletions
23
src/components/InvitingClientTile.stories.tsx
Normal file
23
src/components/InvitingClientTile.stories.tsx
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
/*
|
||||||
|
Copyright 2020 The Matrix.org Foundation C.I.C.
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import React from 'react';
|
||||||
|
|
||||||
|
import ClientTile from './InvitingClientTile';
|
||||||
|
|
||||||
|
export default { title: 'ClientTile' };
|
||||||
|
|
||||||
|
export const Element = <ClientTile clientName={'element.io'} />;
|
58
src/components/InvitingClientTile.tsx
Normal file
58
src/components/InvitingClientTile.tsx
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
/*
|
||||||
|
Copyright 2020 The Matrix.org Foundation C.I.C.
|
||||||
|
|
||||||
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
you may not use this file except in compliance with the License.
|
||||||
|
You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing, software
|
||||||
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
See the License for the specific language governing permissions and
|
||||||
|
limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import React from 'react';
|
||||||
|
import Tile from './Tile';
|
||||||
|
|
||||||
|
import { clientMap } from '../clients';
|
||||||
|
import './MatrixTile.scss';
|
||||||
|
|
||||||
|
interface IProps {
|
||||||
|
clientName: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
const InvitingClientTile: React.FC<IProps> = ({ clientName }: IProps) => {
|
||||||
|
const client = clientMap[clientName];
|
||||||
|
|
||||||
|
if (!client) {
|
||||||
|
return (
|
||||||
|
<Tile className="matrixTile">
|
||||||
|
{/* TODO: add gh link */}
|
||||||
|
<p>
|
||||||
|
The client that created this link "{clientName}" is not a
|
||||||
|
recognised client. If this is a mistake and you'd like a
|
||||||
|
nice advertisement for it here please{' '}
|
||||||
|
<a href="https://github.com/matrix-org/matrix.to">
|
||||||
|
open a pr
|
||||||
|
</a>
|
||||||
|
.
|
||||||
|
</p>
|
||||||
|
</Tile>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Tile className="matrixTile">
|
||||||
|
<img src={client.logo} alt={client.name} />
|
||||||
|
<h2>
|
||||||
|
Invite created with <a href={client.homepage}>{client.name}</a>
|
||||||
|
</h2>
|
||||||
|
<div>{client.description}</div>
|
||||||
|
</Tile>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
export default InvitingClientTile;
|
|
@ -18,6 +18,7 @@ import React from 'react';
|
||||||
|
|
||||||
import Tile from '../components/Tile';
|
import Tile from '../components/Tile';
|
||||||
import LinkPreview from '../components/LinkPreview';
|
import LinkPreview from '../components/LinkPreview';
|
||||||
|
import InvitingClientTile from '../components/InvitingClientTile';
|
||||||
import { parseHash } from '../parser/parser';
|
import { parseHash } from '../parser/parser';
|
||||||
import { LinkKind } from '../parser/types';
|
import { LinkKind } from '../parser/types';
|
||||||
|
|
||||||
|
@ -28,9 +29,9 @@ interface IProps {
|
||||||
const LinkRouter: React.FC<IProps> = ({ link }: IProps) => {
|
const LinkRouter: React.FC<IProps> = ({ link }: IProps) => {
|
||||||
// our room id's will be stored in the hash
|
// our room id's will be stored in the hash
|
||||||
const parsedLink = parseHash(link);
|
const parsedLink = parseHash(link);
|
||||||
console.log({ link });
|
|
||||||
|
|
||||||
let feedback: JSX.Element;
|
let feedback: JSX.Element;
|
||||||
|
let client: JSX.Element = <></>;
|
||||||
switch (parsedLink.kind) {
|
switch (parsedLink.kind) {
|
||||||
case LinkKind.ParseFailed:
|
case LinkKind.ParseFailed:
|
||||||
feedback = (
|
feedback = (
|
||||||
|
@ -41,7 +42,21 @@ const LinkRouter: React.FC<IProps> = ({ link }: IProps) => {
|
||||||
);
|
);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
feedback = <LinkPreview link={parsedLink} />;
|
if (parsedLink.arguments.client) {
|
||||||
|
client = (
|
||||||
|
<InvitingClientTile
|
||||||
|
clientName={parsedLink.arguments.client}
|
||||||
|
/>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
feedback = (
|
||||||
|
<>
|
||||||
|
<LinkPreview link={parsedLink} />
|
||||||
|
<hr />
|
||||||
|
{client}
|
||||||
|
</>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
return feedback;
|
return feedback;
|
||||||
|
|
Loading…
Reference in a new issue