2019-12-05 22:37:09 +01:00
|
|
|
import React from 'react';
|
2020-04-30 17:08:06 +02:00
|
|
|
import { KanboardCard } from '../../types/kanboard';
|
2019-12-05 22:37:09 +01:00
|
|
|
|
2020-04-30 15:43:40 +02:00
|
|
|
export interface IssueCardProps {
|
2020-04-30 17:08:06 +02:00
|
|
|
card: KanboardCard
|
|
|
|
compact: boolean
|
2020-04-30 15:43:40 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
export class IssueCard extends React.PureComponent<IssueCardProps> {
|
2019-12-05 22:37:09 +01:00
|
|
|
render() {
|
2020-04-30 17:08:06 +02:00
|
|
|
|
|
|
|
const { card, compact } = this.props;
|
2019-12-13 13:31:27 +01:00
|
|
|
const issueURLInfo = extractInfoFromIssueURL(card.issue.url);
|
|
|
|
const projectURL = `${issueURLInfo.baseURL}/${issueURLInfo.owner}/${issueURLInfo.projectName}`;
|
|
|
|
const issueURL = `${projectURL}/issues/${card.issue.number}`;
|
2020-04-30 17:08:06 +02:00
|
|
|
|
2019-12-05 22:37:09 +01:00
|
|
|
return (
|
|
|
|
<div className="kanboard-card">
|
2020-04-30 17:08:06 +02:00
|
|
|
<div className={`box ${compact ? 'has-padding-small': ''}`}>
|
2019-12-05 22:37:09 +01:00
|
|
|
<div className="media">
|
|
|
|
{
|
2020-04-30 17:08:06 +02:00
|
|
|
card.issue.assignee && !compact ?
|
2019-12-05 22:37:09 +01:00
|
|
|
<div className="media-left">
|
|
|
|
<figure className="image is-64x64">
|
|
|
|
<img src={card.issue.assignee.avatar_url} alt="Image" />
|
|
|
|
</figure>
|
|
|
|
<small>{`@${card.issue.assignee.login}`}</small>
|
|
|
|
</div>
|
|
|
|
: null
|
|
|
|
}
|
|
|
|
<div className="media-content">
|
|
|
|
<div className="content">
|
|
|
|
<p>
|
2020-04-30 17:08:06 +02:00
|
|
|
<a target="_blank" href={issueURL}><strong>{`#${card.issue.number}`}</strong></a>
|
|
|
|
{ !compact && card.issue.milestone ? <small>{`- ${card.issue.milestone.title}`}</small> : null }
|
|
|
|
{ !compact ? <br /> : ' - ' }
|
2019-12-05 22:37:09 +01:00
|
|
|
<span className="is-size-6">{card.issue.title}</span>
|
|
|
|
</p>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2020-04-30 17:08:06 +02:00
|
|
|
{
|
|
|
|
!compact ?
|
|
|
|
<div className="level is-mobile" style={{marginTop:'1rem'}}>
|
|
|
|
<div className="level-left">
|
|
|
|
<small className="level-item"><a href={projectURL}>{card.project}</a></small>
|
|
|
|
</div>
|
|
|
|
<div className="level-right">
|
|
|
|
|
|
|
|
</div>
|
|
|
|
</div> :
|
|
|
|
null
|
|
|
|
}
|
2019-12-05 22:37:09 +01:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
2019-12-13 13:31:27 +01:00
|
|
|
}
|
|
|
|
|
2020-04-30 15:43:40 +02:00
|
|
|
function extractInfoFromIssueURL(issueURL: string): any|void {
|
2019-12-13 13:31:27 +01:00
|
|
|
const pattern = /^(https?:\/\/[^\/]+)\/api\/v1\/repos\/([^\/]+)\/([^\/]+)\/.*$/;
|
|
|
|
const matches = pattern.exec(issueURL);
|
2020-04-30 15:43:40 +02:00
|
|
|
|
|
|
|
if (!matches) return;
|
|
|
|
|
2019-12-13 13:31:27 +01:00
|
|
|
return {
|
|
|
|
baseURL: matches[1],
|
|
|
|
owner: matches[2],
|
|
|
|
projectName: matches[3],
|
|
|
|
};
|
2019-12-05 22:37:09 +01:00
|
|
|
}
|