mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-20 18:48:28 +02:00
51 lines
2.0 KiB
TypeScript
51 lines
2.0 KiB
TypeScript
|
import Logger from '@joplin/utils/Logger';
|
||
|
import time from '../../time';
|
||
|
import { TagEntity } from '../database/types';
|
||
|
import { ListRendererDependency, RenderNoteView } from '../plugins/api/noteListType';
|
||
|
|
||
|
const logger = Logger.create('renderViewProps');
|
||
|
|
||
|
export interface RenderViewPropsOptions {
|
||
|
// Note that we don't render the title here, because it requires the mark.js package which is
|
||
|
// only available on the `app-desktop` package. So the caller needs to pre-render the title and
|
||
|
// pass it as an option.
|
||
|
noteTitleHtml: string;
|
||
|
}
|
||
|
|
||
|
const renderViewProp = (name: ListRendererDependency, value: any, options: RenderViewPropsOptions) => {
|
||
|
const renderers: Partial<Record<ListRendererDependency, ()=> string>> = {
|
||
|
'note.user_updated_time': () => time.unixMsToLocalDateTime(value),
|
||
|
'note.user_created_time': () => time.unixMsToLocalDateTime(value),
|
||
|
'note.updated_time': () => time.unixMsToLocalDateTime(value),
|
||
|
'note.created_time': () => time.unixMsToLocalDateTime(value),
|
||
|
'note.todo_completed': () => value ? time.unixMsToLocalDateTime(value) : '',
|
||
|
'note.tags': () => value ? value.map((t: TagEntity) => t.title).join(', ') : '',
|
||
|
'note.title': () => options.noteTitleHtml,
|
||
|
};
|
||
|
|
||
|
try {
|
||
|
const renderer = renderers[name];
|
||
|
if (renderer) return renderer();
|
||
|
} catch (error) {
|
||
|
// If the input value doesn't have the expected format, it may have been changed by the
|
||
|
// user. In that case we return the value without rendering it.
|
||
|
logger.warn('Could not render property:', name, 'With value:', value, 'Error:', error);
|
||
|
return value;
|
||
|
}
|
||
|
|
||
|
return value;
|
||
|
};
|
||
|
|
||
|
const renderViewProps = async (view: RenderNoteView, parentPath: string[], options: RenderViewPropsOptions) => {
|
||
|
for (const [name, value] of Object.entries(view)) {
|
||
|
const currentPath = parentPath.concat([name]);
|
||
|
if (value && typeof value === 'object' && !Array.isArray(value)) {
|
||
|
await renderViewProps(value, currentPath, options);
|
||
|
} else {
|
||
|
view[name] = renderViewProp(currentPath.join('.') as ListRendererDependency, value, options);
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
|
||
|
export default renderViewProps;
|