2016-11-23 16:23:32 -02:00
|
|
|
import React from 'react';
|
|
|
|
|
2022-10-20 11:57:30 -04:00
|
|
|
import type { ReactNode } from 'react';
|
|
|
|
|
2021-03-11 12:08:46 +02:00
|
|
|
export const IDENTIFIER_FIELDS = ['title', 'path'] as const;
|
2018-05-25 10:15:01 -06:00
|
|
|
|
2021-03-11 12:08:46 +02:00
|
|
|
export const SORTABLE_FIELDS = ['title', 'date', 'author', 'description'] as const;
|
2020-04-01 06:13:27 +03:00
|
|
|
|
2022-10-20 11:57:30 -04:00
|
|
|
export interface InferredField {
|
|
|
|
type: string;
|
|
|
|
secondaryTypes: string[];
|
|
|
|
synonyms: string[];
|
|
|
|
defaultPreview: (value: string | boolean | number) => JSX.Element | ReactNode;
|
|
|
|
fallbackToFirstField: boolean;
|
|
|
|
showError: boolean;
|
|
|
|
}
|
|
|
|
|
|
|
|
export const INFERABLE_FIELDS: Record<string, InferredField> = {
|
2016-11-23 16:23:32 -02:00
|
|
|
title: {
|
|
|
|
type: 'string',
|
|
|
|
secondaryTypes: [],
|
2017-01-19 13:44:40 -02:00
|
|
|
synonyms: ['title', 'name', 'label', 'headline', 'header'],
|
2022-10-20 11:57:30 -04:00
|
|
|
defaultPreview: value => <h1>{value}</h1>, // eslint-disable-line react/display-name
|
2016-11-23 16:23:32 -02:00
|
|
|
fallbackToFirstField: true,
|
|
|
|
showError: true,
|
|
|
|
},
|
|
|
|
shortTitle: {
|
|
|
|
type: 'string',
|
|
|
|
secondaryTypes: [],
|
2017-01-19 13:44:40 -02:00
|
|
|
synonyms: ['short_title', 'shortTitle', 'short'],
|
2022-10-20 11:57:30 -04:00
|
|
|
defaultPreview: value => <h2>{value}</h2>, // eslint-disable-line react/display-name
|
2016-11-23 16:23:32 -02:00
|
|
|
fallbackToFirstField: false,
|
|
|
|
showError: false,
|
|
|
|
},
|
|
|
|
author: {
|
|
|
|
type: 'string',
|
|
|
|
secondaryTypes: [],
|
2017-01-19 13:44:40 -02:00
|
|
|
synonyms: ['author', 'name', 'by', 'byline', 'owner'],
|
2022-10-20 11:57:30 -04:00
|
|
|
defaultPreview: value => <strong>{value}</strong>, // eslint-disable-line react/display-name
|
2016-11-23 16:23:32 -02:00
|
|
|
fallbackToFirstField: false,
|
|
|
|
showError: false,
|
|
|
|
},
|
2019-02-08 12:26:59 -05:00
|
|
|
date: {
|
|
|
|
type: 'datetime',
|
|
|
|
secondaryTypes: ['date'],
|
|
|
|
synonyms: ['date', 'publishDate', 'publish_date'],
|
2022-10-20 11:57:30 -04:00
|
|
|
defaultPreview: value => value,
|
2019-02-08 12:26:59 -05:00
|
|
|
fallbackToFirstField: false,
|
|
|
|
showError: false,
|
|
|
|
},
|
2016-11-23 16:23:32 -02:00
|
|
|
description: {
|
|
|
|
type: 'string',
|
|
|
|
secondaryTypes: ['text', 'markdown'],
|
2018-08-07 14:46:54 -06:00
|
|
|
synonyms: [
|
|
|
|
'shortDescription',
|
|
|
|
'short_description',
|
|
|
|
'shortdescription',
|
|
|
|
'description',
|
|
|
|
'intro',
|
|
|
|
'introduction',
|
|
|
|
'brief',
|
|
|
|
'content',
|
|
|
|
'biography',
|
|
|
|
'bio',
|
|
|
|
'summary',
|
|
|
|
],
|
2022-10-20 11:57:30 -04:00
|
|
|
defaultPreview: value => value,
|
2016-11-23 16:23:32 -02:00
|
|
|
fallbackToFirstField: false,
|
|
|
|
showError: false,
|
|
|
|
},
|
|
|
|
image: {
|
|
|
|
type: 'image',
|
|
|
|
secondaryTypes: [],
|
2020-03-26 19:23:31 +02:00
|
|
|
synonyms: [
|
|
|
|
'image',
|
|
|
|
'thumbnail',
|
|
|
|
'thumb',
|
|
|
|
'picture',
|
|
|
|
'avatar',
|
|
|
|
'photo',
|
|
|
|
'cover',
|
|
|
|
'hero',
|
|
|
|
'logo',
|
|
|
|
],
|
2022-10-20 11:57:30 -04:00
|
|
|
defaultPreview: value => value,
|
2016-11-23 16:23:32 -02:00
|
|
|
fallbackToFirstField: false,
|
|
|
|
showError: false,
|
|
|
|
},
|
|
|
|
};
|