Journal list: improve look.
parent
1bf6314ac3
commit
b0741978d0
|
@ -1,4 +1,8 @@
|
|||
import * as React from 'react';
|
||||
import { List, ListItem } from 'material-ui/List';
|
||||
import IconAdd from 'material-ui/svg-icons/content/add';
|
||||
import IconDelete from 'material-ui/svg-icons/action/delete';
|
||||
import IconEdit from 'material-ui/svg-icons/editor/mode-edit';
|
||||
|
||||
import * as ICAL from 'ical.js';
|
||||
|
||||
|
@ -22,24 +26,53 @@ export class JournalViewEntries extends React.Component {
|
|||
const entries = this.props.entries.map((syncEntry, idx) => {
|
||||
const comp = new ICAL.Component(ICAL.parse(syncEntry.content));
|
||||
|
||||
let icon;
|
||||
if (syncEntry.action === EteSync.SyncEntryAction.Add) {
|
||||
icon = (<IconAdd color="#16B14B" />);
|
||||
} else if (syncEntry.action === EteSync.SyncEntryAction.Change) {
|
||||
icon = (<IconEdit color="#FEB115" />);
|
||||
} else if (syncEntry.action === EteSync.SyncEntryAction.Delete) {
|
||||
icon = (<IconDelete color="#F20C0C" />);
|
||||
}
|
||||
|
||||
if (comp.name === 'vcalendar') {
|
||||
const vevent = new ICAL.Event(comp.getFirstSubcomponent('vevent'));
|
||||
return (<li key={idx}>{syncEntry.action}: {vevent.summary} ({vevent.uid})</li>);
|
||||
return (
|
||||
<ListItem
|
||||
key={idx}
|
||||
leftIcon={icon}
|
||||
primaryText={vevent.summary}
|
||||
secondaryText={vevent.uid}
|
||||
/>
|
||||
);
|
||||
} else if (comp.name === 'vcard') {
|
||||
const vcard = comp;
|
||||
const name = vcard.getFirstPropertyValue('fn');
|
||||
const uid = vcard.getFirstPropertyValue('uid');
|
||||
return (<li key={idx}>{syncEntry.action}: {name} ({uid})</li>);
|
||||
return (
|
||||
<ListItem
|
||||
key={idx}
|
||||
leftIcon={icon}
|
||||
primaryText={name}
|
||||
secondaryText={uid}
|
||||
/>
|
||||
);
|
||||
} else {
|
||||
return (<li key={idx}>{syncEntry.action}: {syncEntry.content}</li>);
|
||||
return (
|
||||
<ListItem
|
||||
key={idx}
|
||||
leftIcon={icon}
|
||||
primaryText="Error processing entry"
|
||||
/>
|
||||
);
|
||||
}
|
||||
}).reverse();
|
||||
|
||||
return (
|
||||
<div>
|
||||
<ul>
|
||||
<List>
|
||||
{entries}
|
||||
</ul>
|
||||
</List>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue