mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-08 01:04:39 +08:00
77 lines
1.9 KiB
React
77 lines
1.9 KiB
React
|
import React from 'react';
|
||
|
import { Utils } from 'mailspring-exports';
|
||
|
import { InjectedComponentSet, ListTabular } from 'mailspring-component-kit';
|
||
|
|
||
|
function snippet(html) {
|
||
|
if (!(html && typeof html === 'string')) {
|
||
|
return '';
|
||
|
}
|
||
|
try {
|
||
|
return Utils.extractTextFromHtml(html, { maxLength: 400 }).substr(0, 200);
|
||
|
} catch (err) {
|
||
|
return '';
|
||
|
}
|
||
|
}
|
||
|
|
||
|
function subject(subj) {
|
||
|
if ((subj || '').trim().length === 0) {
|
||
|
return <span className="no-subject">(No Subject)</span>;
|
||
|
}
|
||
|
return Utils.extractTextFromHtml(subj);
|
||
|
}
|
||
|
|
||
|
const ParticipantsColumn = new ListTabular.Column({
|
||
|
name: 'Participants',
|
||
|
width: 200,
|
||
|
resolver: draft => {
|
||
|
const list = [].concat(draft.to, draft.cc, draft.bcc);
|
||
|
|
||
|
if (list.length > 0) {
|
||
|
return (
|
||
|
<div className="participants">
|
||
|
<span>{list.map(p => p.displayName()).join(', ')}</span>
|
||
|
</div>
|
||
|
);
|
||
|
} else {
|
||
|
return <div className="participants no-recipients">(No Recipients)</div>;
|
||
|
}
|
||
|
},
|
||
|
});
|
||
|
|
||
|
const ContentsColumn = new ListTabular.Column({
|
||
|
name: 'Contents',
|
||
|
flex: 4,
|
||
|
resolver: draft => {
|
||
|
let attachments = [];
|
||
|
if (draft.files && draft.files.length > 0) {
|
||
|
attachments = <div className="thread-icon thread-icon-attachment" />;
|
||
|
}
|
||
|
return (
|
||
|
<span className="details">
|
||
|
<span className="subject">{subject(draft.subject)}</span>
|
||
|
<span className="snippet">{snippet(draft.body)}</span>
|
||
|
{attachments}
|
||
|
</span>
|
||
|
);
|
||
|
},
|
||
|
});
|
||
|
|
||
|
const StatusColumn = new ListTabular.Column({
|
||
|
name: 'State',
|
||
|
resolver: draft => {
|
||
|
return (
|
||
|
<InjectedComponentSet
|
||
|
inline={true}
|
||
|
containersRequired={false}
|
||
|
matching={{ role: 'DraftList:DraftStatus' }}
|
||
|
className="draft-list-injected-state"
|
||
|
exposedProps={{ draft }}
|
||
|
/>
|
||
|
);
|
||
|
},
|
||
|
});
|
||
|
|
||
|
module.exports = {
|
||
|
Wide: [ParticipantsColumn, ContentsColumn, StatusColumn],
|
||
|
};
|