2022-09-28 20:04:00 -06:00
|
|
|
// Register all the things
|
2022-10-26 11:46:06 -04:00
|
|
|
CMS.init();
|
2022-09-28 20:04:00 -06:00
|
|
|
|
2023-01-13 11:46:56 -05:00
|
|
|
const PostPreview = ({ entry, widgetFor }) => {
|
2022-11-04 17:41:12 -04:00
|
|
|
return h(
|
|
|
|
'div',
|
|
|
|
{},
|
|
|
|
h('div', { className: 'cover' }, h('h1', {}, entry.data.title), widgetFor('image')),
|
|
|
|
h('p', {}, h('small', {}, 'Written ' + entry.data.date)),
|
|
|
|
h('div', { className: 'text' }, widgetFor('body')),
|
|
|
|
);
|
|
|
|
};
|
2022-09-28 20:04:00 -06:00
|
|
|
|
2023-05-25 07:12:08 -04:00
|
|
|
const PostPreviewCard = ({ entry, theme, hasLocalBackup, collection }) => {
|
2023-03-30 13:29:09 -04:00
|
|
|
const date = new Date(entry.data.date);
|
|
|
|
|
|
|
|
const month = date.getMonth() + 1;
|
|
|
|
const day = date.getDate();
|
|
|
|
|
2023-05-25 07:12:08 -04:00
|
|
|
const imageField = useMemo(() => collection.fields.find((f) => f.name === 'image'), []);
|
|
|
|
const image = useMediaAsset(entry.data.image, collection, imageField, entry);
|
2023-05-11 18:52:06 -04:00
|
|
|
|
2023-01-25 15:11:59 -05:00
|
|
|
return h(
|
|
|
|
'div',
|
|
|
|
{ style: { width: '100%' } },
|
2023-05-11 18:52:06 -04:00
|
|
|
h('div', {
|
|
|
|
style: {
|
|
|
|
width: '100%',
|
|
|
|
borderTopLeftRadius: '8px',
|
|
|
|
borderTopRightRadius: '8px',
|
|
|
|
overflow: 'hidden',
|
|
|
|
height: '140px',
|
|
|
|
backgroundSize: 'cover',
|
2023-05-19 09:59:04 -04:00
|
|
|
backgroundRepeat: 'no-repeat',
|
2023-05-11 18:52:06 -04:00
|
|
|
backgroundPosition: 'center',
|
|
|
|
objectFit: 'cover',
|
|
|
|
backgroundImage: `url('${image}')`,
|
|
|
|
},
|
|
|
|
}),
|
2023-01-25 15:11:59 -05:00
|
|
|
h(
|
|
|
|
'div',
|
|
|
|
{ style: { padding: '16px', width: '100%' } },
|
|
|
|
h(
|
|
|
|
'div',
|
|
|
|
{
|
|
|
|
style: {
|
|
|
|
display: 'flex',
|
|
|
|
width: '100%',
|
|
|
|
justifyContent: 'space-between',
|
|
|
|
alignItems: 'start',
|
2023-03-30 13:29:09 -04:00
|
|
|
gap: '4px',
|
|
|
|
color: theme === 'dark' ? 'white' : 'inherit',
|
2023-01-25 15:11:59 -05:00
|
|
|
},
|
|
|
|
},
|
|
|
|
h(
|
|
|
|
'div',
|
|
|
|
{
|
|
|
|
style: {
|
|
|
|
display: 'flex',
|
2023-03-30 13:29:09 -04:00
|
|
|
flexDirection: 'column',
|
2023-01-25 15:11:59 -05:00
|
|
|
alignItems: 'baseline',
|
2023-03-30 13:29:09 -04:00
|
|
|
gap: '4px',
|
2023-01-25 15:11:59 -05:00
|
|
|
},
|
|
|
|
},
|
2023-03-30 13:29:09 -04:00
|
|
|
h(
|
|
|
|
'div',
|
|
|
|
{
|
|
|
|
style: {
|
|
|
|
fontSize: '14px',
|
|
|
|
fontWeight: 700,
|
|
|
|
color: 'rgb(107, 114, 128)',
|
|
|
|
lineHeight: '18px',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
entry.data.title,
|
|
|
|
),
|
|
|
|
h(
|
|
|
|
'span',
|
|
|
|
{ style: { fontSize: '14px' } },
|
|
|
|
`${date.getFullYear()}-${month < 10 ? `0${month}` : month}-${
|
|
|
|
day < 10 ? `0${day}` : day
|
|
|
|
}`,
|
|
|
|
),
|
2023-01-25 15:11:59 -05:00
|
|
|
),
|
|
|
|
h(
|
|
|
|
'div',
|
|
|
|
{
|
|
|
|
style: {
|
2023-04-19 13:30:21 -04:00
|
|
|
display: 'flex',
|
|
|
|
alignItems: 'center',
|
|
|
|
whiteSpace: 'no-wrap',
|
|
|
|
gap: '8px',
|
2023-01-25 15:11:59 -05:00
|
|
|
},
|
|
|
|
},
|
2023-04-19 13:30:21 -04:00
|
|
|
hasLocalBackup
|
|
|
|
? h(
|
|
|
|
'div',
|
|
|
|
{
|
|
|
|
style: {
|
|
|
|
border: '2px solid rgb(147, 197, 253)',
|
|
|
|
borderRadius: '50%',
|
|
|
|
color: 'rgb(147, 197, 253)',
|
|
|
|
height: '18px',
|
|
|
|
width: '18px',
|
|
|
|
fontWeight: 'bold',
|
|
|
|
fontSize: '11px',
|
|
|
|
display: 'flex',
|
|
|
|
alignItems: 'center',
|
|
|
|
justifyContent: 'center',
|
|
|
|
textAlign: 'center',
|
|
|
|
},
|
2023-05-11 18:52:06 -04:00
|
|
|
title: 'Has local backup',
|
2023-04-19 13:30:21 -04:00
|
|
|
},
|
|
|
|
'i',
|
|
|
|
)
|
|
|
|
: null,
|
|
|
|
h(
|
|
|
|
'div',
|
|
|
|
{
|
|
|
|
style: {
|
|
|
|
backgroundColor:
|
|
|
|
entry.data.draft === true ? 'rgb(37, 99, 235)' : 'rgb(22, 163, 74)',
|
|
|
|
color: 'white',
|
|
|
|
border: 'none',
|
|
|
|
padding: '2px 6px',
|
|
|
|
textAlign: 'center',
|
|
|
|
textDecoration: 'none',
|
|
|
|
display: 'inline-block',
|
|
|
|
cursor: 'pointer',
|
|
|
|
borderRadius: '4px',
|
|
|
|
fontSize: '14px',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
entry.data.draft === true ? 'Draft' : 'Published',
|
|
|
|
),
|
2023-01-25 15:11:59 -05:00
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2023-03-30 13:29:09 -04:00
|
|
|
const PostDateFieldPreview = ({ value }) => {
|
|
|
|
const date = new Date(value);
|
|
|
|
|
|
|
|
const month = date.getMonth() + 1;
|
|
|
|
const day = date.getDate();
|
|
|
|
|
|
|
|
return h(
|
|
|
|
'div',
|
|
|
|
{},
|
|
|
|
`${date.getFullYear()}-${month < 10 ? `0${month}` : month}-${day < 10 ? `0${day}` : day}`,
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
const PostDraftFieldPreview = ({ value }) => {
|
|
|
|
return h(
|
|
|
|
'div',
|
|
|
|
{
|
|
|
|
style: {
|
|
|
|
backgroundColor: value === true ? 'rgb(37 99 235)' : 'rgb(22 163 74)',
|
|
|
|
color: 'white',
|
|
|
|
border: 'none',
|
|
|
|
padding: '2px 6px',
|
|
|
|
textAlign: 'center',
|
|
|
|
textDecoration: 'none',
|
|
|
|
display: 'inline-block',
|
|
|
|
cursor: 'pointer',
|
|
|
|
borderRadius: '4px',
|
|
|
|
fontSize: '14px',
|
2023-05-11 18:52:06 -04:00
|
|
|
lineHeight: '16px',
|
|
|
|
height: '20px',
|
2023-03-30 13:29:09 -04:00
|
|
|
},
|
|
|
|
},
|
|
|
|
value === true ? 'Draft' : 'Published',
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2023-01-10 12:49:12 -05:00
|
|
|
const GeneralPreview = ({ widgetsFor, entry, collection }) => {
|
2022-11-04 17:41:12 -04:00
|
|
|
const title = entry.data.site_title;
|
|
|
|
const posts = entry.data.posts;
|
|
|
|
const thumb = posts && posts.thumb;
|
2022-09-28 20:04:00 -06:00
|
|
|
|
2023-01-10 12:49:12 -05:00
|
|
|
const thumbUrl = useMediaAsset(thumb, collection, undefined, entry);
|
2022-11-01 14:07:30 -04:00
|
|
|
|
2022-11-04 17:41:12 -04:00
|
|
|
return h(
|
|
|
|
'div',
|
|
|
|
{},
|
|
|
|
h('h1', {}, title),
|
|
|
|
h(
|
|
|
|
'dl',
|
2022-09-28 20:04:00 -06:00
|
|
|
{},
|
2022-11-04 17:41:12 -04:00
|
|
|
h('dt', {}, 'Posts on Frontpage'),
|
|
|
|
h('dd', {}, widgetsFor('posts').widgets.front_limit ?? 0),
|
2022-09-28 20:04:00 -06:00
|
|
|
|
2022-11-04 17:41:12 -04:00
|
|
|
h('dt', {}, 'Default Author'),
|
|
|
|
h('dd', {}, widgetsFor('posts').data?.author ?? 'None'),
|
|
|
|
|
|
|
|
h('dt', {}, 'Default Thumbnail'),
|
|
|
|
h('dd', {}, thumb && h('img', { src: thumbUrl })),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
const AuthorsPreview = ({ widgetsFor }) => {
|
|
|
|
return h(
|
|
|
|
'div',
|
|
|
|
{},
|
|
|
|
h('h1', {}, 'Authors'),
|
|
|
|
widgetsFor('authors').map(function (author, index) {
|
|
|
|
return h(
|
|
|
|
'div',
|
|
|
|
{ key: index },
|
|
|
|
h('hr', {}),
|
|
|
|
h('strong', {}, author.data.name),
|
|
|
|
author.widgets.description,
|
|
|
|
);
|
|
|
|
}),
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
const RelationKitchenSinkPostPreview = ({ fieldsMetaData }) => {
|
|
|
|
// When a post is selected from the relation field, all of it's data
|
|
|
|
// will be available in the field's metadata nested under the collection
|
|
|
|
// name, and then further nested under the value specified in `value_field`.
|
|
|
|
// In this case, the post would be nested under "posts" and then under
|
|
|
|
// the title of the selected post, since our `value_field` in the config
|
|
|
|
// is "title".
|
|
|
|
const post = fieldsMetaData && fieldsMetaData.posts.value;
|
|
|
|
const style = { border: '2px solid #ccc', borderRadius: '8px', padding: '20px' };
|
|
|
|
return post
|
|
|
|
? h(
|
|
|
|
'div',
|
|
|
|
{ style: style },
|
|
|
|
h('h2', {}, 'Related Post'),
|
|
|
|
h('h3', {}, post.title),
|
|
|
|
h('img', { src: post.image }),
|
|
|
|
h('p', {}, (post.body ?? '').slice(0, 100) + '...'),
|
|
|
|
)
|
|
|
|
: null;
|
|
|
|
};
|
|
|
|
|
|
|
|
const CustomPage = () => {
|
|
|
|
return h('div', {}, 'I am a custom page!');
|
|
|
|
};
|
2022-09-28 20:04:00 -06:00
|
|
|
|
2022-10-26 11:46:06 -04:00
|
|
|
CMS.registerPreviewTemplate('posts', PostPreview);
|
2023-05-11 18:52:06 -04:00
|
|
|
CMS.registerPreviewCard('posts', PostPreviewCard, () => 240);
|
2023-03-30 13:29:09 -04:00
|
|
|
CMS.registerFieldPreview('posts', 'date', PostDateFieldPreview);
|
|
|
|
CMS.registerFieldPreview('posts', 'draft', PostDraftFieldPreview);
|
2022-11-04 17:41:12 -04:00
|
|
|
CMS.registerPreviewTemplate('general', GeneralPreview);
|
2022-10-26 11:46:06 -04:00
|
|
|
CMS.registerPreviewTemplate('authors', AuthorsPreview);
|
2022-09-28 20:04:00 -06:00
|
|
|
// Pass the name of a registered control to reuse with a new widget preview.
|
2022-10-26 11:46:06 -04:00
|
|
|
CMS.registerWidget('relationKitchenSinkPost', 'relation', RelationKitchenSinkPostPreview);
|
|
|
|
CMS.registerAdditionalLink({
|
2022-10-20 11:57:30 -04:00
|
|
|
id: 'example',
|
|
|
|
title: 'Example.com',
|
|
|
|
data: 'https://example.com',
|
|
|
|
options: {
|
|
|
|
icon: 'page',
|
|
|
|
},
|
|
|
|
});
|
2022-11-04 17:41:12 -04:00
|
|
|
CMS.registerAdditionalLink({
|
|
|
|
id: 'custom-page',
|
|
|
|
title: 'Custom Page',
|
|
|
|
data: CustomPage,
|
|
|
|
options: {
|
|
|
|
icon: 'page',
|
|
|
|
},
|
|
|
|
});
|
2022-12-11 09:03:53 -05:00
|
|
|
|
|
|
|
CMS.registerShortcode('youtube', {
|
|
|
|
label: 'YouTube',
|
|
|
|
openTag: '[',
|
|
|
|
closeTag: ']',
|
|
|
|
separator: '|',
|
|
|
|
toProps: args => {
|
|
|
|
if (args.length > 0) {
|
|
|
|
return { src: args[0] };
|
|
|
|
}
|
|
|
|
|
|
|
|
return { src: '' };
|
|
|
|
},
|
|
|
|
toArgs: ({ src }) => {
|
|
|
|
return [src];
|
|
|
|
},
|
2023-03-30 13:29:09 -04:00
|
|
|
control: ({ src, onChange, theme }) => {
|
2022-12-11 09:03:53 -05:00
|
|
|
return h('span', {}, [
|
|
|
|
h('input', {
|
|
|
|
key: 'control-input',
|
|
|
|
value: src,
|
|
|
|
onChange: event => {
|
|
|
|
onChange({ src: event.target.value });
|
|
|
|
},
|
2023-03-30 13:29:09 -04:00
|
|
|
style: {
|
|
|
|
width: '100%',
|
|
|
|
backgroundColor: theme === 'dark' ? 'rgb(30, 41, 59)' : 'white',
|
|
|
|
color: theme === 'dark' ? 'white' : 'black',
|
|
|
|
padding: '4px 8px',
|
|
|
|
},
|
2022-12-11 09:03:53 -05:00
|
|
|
}),
|
|
|
|
h(
|
|
|
|
'iframe',
|
|
|
|
{
|
|
|
|
key: 'control-preview',
|
2023-03-30 13:29:09 -04:00
|
|
|
width: '100%',
|
2022-12-11 09:03:53 -05:00
|
|
|
height: '315',
|
|
|
|
src: `https://www.youtube.com/embed/${src}`,
|
|
|
|
},
|
|
|
|
'',
|
|
|
|
),
|
|
|
|
]);
|
|
|
|
},
|
|
|
|
preview: ({ src }) => {
|
|
|
|
return h(
|
|
|
|
'span',
|
|
|
|
{},
|
|
|
|
h(
|
|
|
|
'iframe',
|
|
|
|
{
|
|
|
|
width: '420',
|
|
|
|
height: '315',
|
|
|
|
src: `https://www.youtube.com/embed/${src}`,
|
|
|
|
},
|
|
|
|
'',
|
|
|
|
),
|
|
|
|
);
|
|
|
|
},
|
|
|
|
});
|