2018-01-30 18:18:08 +03:00
|
|
|
import createComponentCard from '../utils/create-component-card';
|
|
|
|
|
2018-08-29 20:17:49 +03:00
|
|
|
// map card names to component names
|
|
|
|
export const CARD_COMPONENT_MAP = {
|
|
|
|
hr: 'koenig-card-hr',
|
|
|
|
image: 'koenig-card-image',
|
|
|
|
markdown: 'koenig-card-markdown',
|
|
|
|
'card-markdown': 'koenig-card-markdown', // backwards-compat with markdown editor
|
|
|
|
html: 'koenig-card-html',
|
|
|
|
code: 'koenig-card-code',
|
|
|
|
embed: 'koenig-card-embed',
|
|
|
|
gallery: 'koenig-card-gallery'
|
|
|
|
};
|
|
|
|
|
2018-08-01 14:36:02 +03:00
|
|
|
// TODO: move koenigOptions directly into cards now that card components register
|
|
|
|
// themselves so that they are available on card.component
|
2018-01-30 18:18:08 +03:00
|
|
|
export default [
|
2018-06-14 18:55:02 +03:00
|
|
|
createComponentCard('card-markdown'), // backwards-compat with markdown editor
|
|
|
|
createComponentCard('code', {deleteIfEmpty: 'payload.code'}),
|
|
|
|
createComponentCard('embed', {hasEditMode: false, deleteIfEmpty: 'payload.html'}),
|
2018-04-18 12:52:49 +03:00
|
|
|
createComponentCard('hr', {hasEditMode: false, selectAfterInsert: false}),
|
2018-06-14 18:55:02 +03:00
|
|
|
createComponentCard('html', {deleteIfEmpty: 'payload.html'}),
|
2018-08-09 19:55:11 +03:00
|
|
|
createComponentCard('image', {hasEditMode: false, deleteIfEmpty(card) {
|
|
|
|
return card.payload.imageSelector && !card.payload.src;
|
|
|
|
}}),
|
2018-08-29 20:17:49 +03:00
|
|
|
createComponentCard('markdown', {deleteIfEmpty: 'payload.markdown'}),
|
|
|
|
createComponentCard('gallery', {hasEditMode: false})
|
2018-06-07 13:34:50 +03:00
|
|
|
];
|
|
|
|
|
|
|
|
export const CARD_MENU = [
|
|
|
|
{
|
2018-08-07 12:23:47 +03:00
|
|
|
title: 'Primary',
|
2018-06-07 13:34:50 +03:00
|
|
|
items: [{
|
|
|
|
label: 'Image',
|
2018-08-07 12:23:47 +03:00
|
|
|
icon: 'koenig/kg-card-type-image',
|
|
|
|
iconClass: 'kg-card-type-native',
|
2018-06-07 13:34:50 +03:00
|
|
|
matches: ['image', 'img'],
|
|
|
|
type: 'card',
|
2018-08-01 16:17:09 +03:00
|
|
|
replaceArg: 'image',
|
|
|
|
params: ['src']
|
2018-06-07 13:34:50 +03:00
|
|
|
},
|
|
|
|
{
|
|
|
|
label: 'Markdown',
|
2018-08-07 12:23:47 +03:00
|
|
|
icon: 'koenig/kg-card-type-markdown',
|
|
|
|
iconClass: 'kg-card-type-native',
|
2018-06-07 13:34:50 +03:00
|
|
|
matches: ['markdown', 'md'],
|
|
|
|
type: 'card',
|
|
|
|
replaceArg: 'markdown'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
label: 'HTML',
|
2018-08-07 12:23:47 +03:00
|
|
|
icon: 'koenig/kg-card-type-html',
|
|
|
|
iconClass: 'kg-card-type-native',
|
2018-06-07 13:34:50 +03:00
|
|
|
matches: ['html'],
|
|
|
|
type: 'card',
|
|
|
|
replaceArg: 'html'
|
|
|
|
},
|
2018-08-29 20:17:49 +03:00
|
|
|
{
|
|
|
|
label: 'Gallery',
|
|
|
|
icon: 'koenig/kg-card-type-gallery',
|
|
|
|
iconClass: 'kg-card-type-native',
|
|
|
|
matches: ['gallery'],
|
|
|
|
type: 'card',
|
|
|
|
replaceArg: 'gallery'
|
|
|
|
},
|
2018-06-07 13:34:50 +03:00
|
|
|
{
|
|
|
|
label: 'Divider',
|
2018-08-07 12:23:47 +03:00
|
|
|
icon: 'koenig/kg-card-type-divider',
|
|
|
|
iconClass: 'kg-card-type-native',
|
2018-06-07 13:34:50 +03:00
|
|
|
matches: ['divider', 'horizontal-rule', 'hr'],
|
|
|
|
type: 'card',
|
|
|
|
replaceArg: 'hr'
|
|
|
|
}]
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: 'Embed',
|
|
|
|
items: [{
|
|
|
|
label: 'YouTube',
|
2018-08-07 12:23:47 +03:00
|
|
|
icon: 'koenig/kg-card-type-youtube',
|
2018-06-07 13:34:50 +03:00
|
|
|
matches: ['youtube'],
|
|
|
|
type: 'card',
|
|
|
|
replaceArg: 'embed',
|
|
|
|
params: ['url']
|
|
|
|
},
|
|
|
|
{
|
|
|
|
label: 'Twitter',
|
2018-08-07 12:23:47 +03:00
|
|
|
icon: 'koenig/kg-card-type-twitter',
|
2018-06-07 13:34:50 +03:00
|
|
|
matches: ['twitter'],
|
|
|
|
type: 'card',
|
|
|
|
replaceArg: 'embed',
|
|
|
|
params: ['url']
|
|
|
|
},
|
|
|
|
{
|
2018-08-07 12:23:47 +03:00
|
|
|
label: 'Instagram',
|
|
|
|
icon: 'koenig/kg-card-type-instagram',
|
|
|
|
matches: ['instagram'],
|
|
|
|
type: 'card',
|
|
|
|
replaceArg: 'embed',
|
|
|
|
params: ['url']
|
|
|
|
},
|
|
|
|
{
|
|
|
|
label: 'Unsplash',
|
|
|
|
icon: 'koenig/kg-card-type-unsplash',
|
|
|
|
iconClass: 'kg-card-type-unsplash',
|
|
|
|
matches: ['unsplash'],
|
|
|
|
type: 'card',
|
2018-08-09 19:55:11 +03:00
|
|
|
replaceArg: 'image',
|
|
|
|
params: ['searchTerm'],
|
|
|
|
payload: {
|
|
|
|
imageSelector: 'unsplash'
|
|
|
|
}
|
2018-08-07 12:23:47 +03:00
|
|
|
},
|
|
|
|
{
|
|
|
|
label: 'Vimeo',
|
|
|
|
icon: 'koenig/kg-card-type-vimeo',
|
|
|
|
matches: ['vimeo'],
|
2018-06-07 13:34:50 +03:00
|
|
|
type: 'card',
|
|
|
|
replaceArg: 'embed',
|
|
|
|
params: ['url']
|
|
|
|
},
|
|
|
|
{
|
|
|
|
label: 'CodePen',
|
2018-08-07 12:23:47 +03:00
|
|
|
icon: 'koenig/kg-card-type-codepen',
|
|
|
|
iconClass: 'kg-card-type-codepen',
|
2018-06-07 13:34:50 +03:00
|
|
|
matches: ['codepen'],
|
|
|
|
type: 'card',
|
|
|
|
replaceArg: 'embed',
|
|
|
|
params: ['url']
|
|
|
|
},
|
2018-08-15 19:11:16 +03:00
|
|
|
{
|
|
|
|
label: 'Spotify',
|
|
|
|
icon: 'koenig/kg-card-type-spotify',
|
|
|
|
matches: ['spotify'],
|
|
|
|
type: 'card',
|
|
|
|
replaceArg: 'embed',
|
|
|
|
params: ['url']
|
|
|
|
},
|
2018-08-07 12:23:47 +03:00
|
|
|
{
|
|
|
|
label: 'SoundCloud',
|
|
|
|
icon: 'koenig/kg-card-type-soundcloud',
|
|
|
|
matches: ['soundcloud'],
|
|
|
|
type: 'card',
|
|
|
|
replaceArg: 'embed',
|
|
|
|
params: ['url']
|
|
|
|
},
|
2018-06-07 13:34:50 +03:00
|
|
|
{
|
|
|
|
label: 'Other...',
|
2018-08-07 12:23:47 +03:00
|
|
|
icon: 'koenig/kg-card-type-other',
|
|
|
|
iconClass: 'kg-card-type-native',
|
2018-06-07 13:34:50 +03:00
|
|
|
matches: ['embed'],
|
|
|
|
type: 'card',
|
|
|
|
replaceArg: 'embed',
|
|
|
|
params: ['url']
|
|
|
|
}]
|
|
|
|
}
|
2018-01-30 18:18:08 +03:00
|
|
|
];
|