diff --git a/.gitignore b/.gitignore index d34e475636..3162730395 100644 --- a/.gitignore +++ b/.gitignore @@ -97,6 +97,7 @@ typings/ /ghost/core/content/adapters/storage/**/* /ghost/core/content/adapters/scheduling/**/* /ghost/core/content/themes/casper +/ghost/core/content/themes/source !/ghost/core/README.md !/ghost/core/content/**/README.md diff --git a/.gitmodules b/.gitmodules index db85f8f508..1df7c0ee43 100644 --- a/.gitmodules +++ b/.gitmodules @@ -2,3 +2,7 @@ path = ghost/core/content/themes/casper url = ../../TryGhost/Casper.git ignore = all +[submodule "ghost/core/content/themes/source"] + path = ghost/core/content/themes/source + url = ../../TryGhost/Source.git + ignore = all diff --git a/apps/admin-x-settings/src/api/themes.ts b/apps/admin-x-settings/src/api/themes.ts index 3b8b2a90f0..09e83dcb11 100644 --- a/apps/admin-x-settings/src/api/themes.ts +++ b/apps/admin-x-settings/src/api/themes.ts @@ -133,9 +133,13 @@ export function isActiveTheme(theme: Theme): boolean { } export function isDefaultTheme(theme: Theme): boolean { + return theme.name === 'source'; +} + +export function isLegacyTheme(theme: Theme): boolean { return theme.name === 'casper'; } export function isDeletableTheme(theme: Theme): boolean { - return !isDefaultTheme(theme) && !isActiveTheme(theme); + return !isDefaultTheme(theme) && !isLegacyTheme(theme) && !isActiveTheme(theme); } diff --git a/apps/admin-x-settings/src/components/settings/site/theme/AdvancedThemeSettings.tsx b/apps/admin-x-settings/src/components/settings/site/theme/AdvancedThemeSettings.tsx index 2188886fb2..bc0565cdaf 100644 --- a/apps/admin-x-settings/src/components/settings/site/theme/AdvancedThemeSettings.tsx +++ b/apps/admin-x-settings/src/components/settings/site/theme/AdvancedThemeSettings.tsx @@ -7,7 +7,7 @@ import ModalPage from '../../../../admin-x-ds/global/modal/ModalPage'; import NiceModal from '@ebay/nice-modal-react'; import React from 'react'; import useHandleError from '../../../../utils/api/handleError'; -import {Theme, isActiveTheme, isDefaultTheme, isDeletableTheme, useActivateTheme, useDeleteTheme} from '../../../../api/themes'; +import {Theme, isActiveTheme, isDefaultTheme, isDeletableTheme, isLegacyTheme, useActivateTheme, useDeleteTheme} from '../../../../api/themes'; import {downloadFile, getGhostPaths} from '../../../../utils/helpers'; interface ThemeActionProps { @@ -23,6 +23,8 @@ function getThemeLabel(theme: Theme): React.ReactNode { if (isDefaultTheme(theme)) { label += ' (default)'; + } else if (isLegacyTheme(theme)) { + label += ' (legacy)'; } else if (theme.package?.name !== theme.name) { label = diff --git a/apps/admin-x-settings/src/components/settings/site/theme/OfficialThemes.tsx b/apps/admin-x-settings/src/components/settings/site/theme/OfficialThemes.tsx index 860fb95053..39ddf9dd37 100644 --- a/apps/admin-x-settings/src/components/settings/site/theme/OfficialThemes.tsx +++ b/apps/admin-x-settings/src/components/settings/site/theme/OfficialThemes.tsx @@ -4,6 +4,13 @@ import ModalPage from '../../../../admin-x-ds/global/modal/ModalPage'; import React from 'react'; import {OfficialTheme, useOfficialThemes} from '../../../providers/ServiceProvider'; import {getGhostPaths, resolveAsset} from '../../../../utils/helpers'; +import {useEffect, useState} from 'react'; + +const sourceDemos = [ + {image: 'Source.png', category: 'News'}, + {image: 'Source-Magazine.png', category: 'Magazine'}, + {image: 'Source-Newsletter.png', category: 'Newsletter'} +]; const OfficialThemes: React.FC<{ onSelectTheme?: (theme: OfficialTheme) => void; @@ -12,6 +19,20 @@ const OfficialThemes: React.FC<{ }) => { const {adminRoot} = getGhostPaths(); const officialThemes = useOfficialThemes(); + const [currentSourceDemoIndex, setCurrentSourceDemoIndex] = useState(0); + const [isHovered, setIsHovered] = useState(false); + + useEffect(() => { + const interval = setInterval(() => { + if (isHovered) { + setCurrentSourceDemoIndex(prevIndex => (prevIndex + 1) % sourceDemos.length); + } + }, 3000); + + return () => { + clearInterval(interval); + }; + }, [isHovered]); return ( @@ -22,16 +43,33 @@ const OfficialThemes: React.FC<{ onSelectTheme?.(theme); }}> {/* {theme.name} */} -
- {`${theme.name} +
setIsHovered(true)} onMouseLeave={() => setIsHovered(false)}> + {theme.name !== 'Source' ? + {`${theme.name} : + <> + {sourceDemos.map((demo, index) => ( + {`${theme.name} + ))} + + }
-
+
{theme.name} - {theme.category} + {theme.name !== 'Source' ? + {theme.category} : + sourceDemos.map((demo, index) => ( + {demo.category} + )) + }
); diff --git a/apps/admin-x-settings/src/components/settings/site/theme/ThemePreview.tsx b/apps/admin-x-settings/src/components/settings/site/theme/ThemePreview.tsx index eefe52f479..31f185c89a 100644 --- a/apps/admin-x-settings/src/components/settings/site/theme/ThemePreview.tsx +++ b/apps/admin-x-settings/src/components/settings/site/theme/ThemePreview.tsx @@ -7,9 +7,16 @@ import MobileChrome from '../../../../admin-x-ds/global/chrome/MobileChrome'; import NiceModal from '@ebay/nice-modal-react'; import PageHeader from '../../../../admin-x-ds/global/layout/PageHeader'; import React, {useState} from 'react'; +import Select, {SelectOption} from '../../../../admin-x-ds/global/form/Select'; import {OfficialTheme} from '../../../providers/ServiceProvider'; import {Theme} from '../../../../api/themes'; +const sourceDemos = [ + {label: 'News', value: 'news', url: 'https://source.ghost.io'}, + {label: 'Magazine', value: 'magazine', url: 'https://source-magazine.ghost.io'}, + {label: 'Newsletter', value: 'newsletter', url: 'https://source-newsletter.ghost.io'} +]; + const ThemePreview: React.FC<{ selectedTheme?: OfficialTheme; isInstalling?: boolean; @@ -26,6 +33,7 @@ const ThemePreview: React.FC<{ onInstall }) => { const [previewMode, setPreviewMode] = useState('desktop'); + const [currentSourceDemo, setCurrentSourceDemo] = useState(sourceDemos[0]); if (!selectedTheme) { return null; @@ -68,6 +76,7 @@ const ThemePreview: React.FC<{
+ {selectedTheme.name === 'Source' ? + <> + + + + \ No newline at end of file diff --git a/ghost/core/test/utils/fixtures/themes/source/partials/feature-image.hbs b/ghost/core/test/utils/fixtures/themes/source/partials/feature-image.hbs new file mode 100644 index 0000000000..2dc4f73094 --- /dev/null +++ b/ghost/core/test/utils/fixtures/themes/source/partials/feature-image.hbs @@ -0,0 +1,17 @@ +{{#if feature_image}} +
+ {{title}} + {{#if feature_image_caption}} +
{{feature_image_caption}}
+ {{/if}} +
+{{/if}} \ No newline at end of file diff --git a/ghost/core/test/utils/fixtures/themes/source/partials/icons/arrow.hbs b/ghost/core/test/utils/fixtures/themes/source/partials/icons/arrow.hbs new file mode 100644 index 0000000000..babf7d93d6 --- /dev/null +++ b/ghost/core/test/utils/fixtures/themes/source/partials/icons/arrow.hbs @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/ghost/core/test/utils/fixtures/themes/source/partials/icons/avatar.hbs b/ghost/core/test/utils/fixtures/themes/source/partials/icons/avatar.hbs new file mode 100644 index 0000000000..af37fca396 --- /dev/null +++ b/ghost/core/test/utils/fixtures/themes/source/partials/icons/avatar.hbs @@ -0,0 +1 @@ + diff --git a/ghost/core/test/utils/fixtures/themes/source/partials/icons/burger.hbs b/ghost/core/test/utils/fixtures/themes/source/partials/icons/burger.hbs new file mode 100644 index 0000000000..e2f34637e2 --- /dev/null +++ b/ghost/core/test/utils/fixtures/themes/source/partials/icons/burger.hbs @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/ghost/core/test/utils/fixtures/themes/source/partials/icons/checkmark.hbs b/ghost/core/test/utils/fixtures/themes/source/partials/icons/checkmark.hbs new file mode 100644 index 0000000000..0d65d581c9 --- /dev/null +++ b/ghost/core/test/utils/fixtures/themes/source/partials/icons/checkmark.hbs @@ -0,0 +1,24 @@ + + + + \ No newline at end of file diff --git a/ghost/core/test/utils/fixtures/themes/source/partials/icons/close.hbs b/ghost/core/test/utils/fixtures/themes/source/partials/icons/close.hbs new file mode 100644 index 0000000000..d0bb34863d --- /dev/null +++ b/ghost/core/test/utils/fixtures/themes/source/partials/icons/close.hbs @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/ghost/core/test/utils/fixtures/themes/source/partials/icons/facebook.hbs b/ghost/core/test/utils/fixtures/themes/source/partials/icons/facebook.hbs new file mode 100644 index 0000000000..7c12d7c56e --- /dev/null +++ b/ghost/core/test/utils/fixtures/themes/source/partials/icons/facebook.hbs @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/ghost/core/test/utils/fixtures/themes/source/partials/icons/fire.hbs b/ghost/core/test/utils/fixtures/themes/source/partials/icons/fire.hbs new file mode 100644 index 0000000000..9978809a4d --- /dev/null +++ b/ghost/core/test/utils/fixtures/themes/source/partials/icons/fire.hbs @@ -0,0 +1,3 @@ + + + \ No newline at end of file diff --git a/ghost/core/test/utils/fixtures/themes/source/partials/icons/loader.hbs b/ghost/core/test/utils/fixtures/themes/source/partials/icons/loader.hbs new file mode 100644 index 0000000000..4616576d1b --- /dev/null +++ b/ghost/core/test/utils/fixtures/themes/source/partials/icons/loader.hbs @@ -0,0 +1,17 @@ + + + + + + + + + + \ No newline at end of file diff --git a/ghost/core/test/utils/fixtures/themes/source/partials/icons/lock.hbs b/ghost/core/test/utils/fixtures/themes/source/partials/icons/lock.hbs new file mode 100644 index 0000000000..0bbd8b405a --- /dev/null +++ b/ghost/core/test/utils/fixtures/themes/source/partials/icons/lock.hbs @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/ghost/core/test/utils/fixtures/themes/source/partials/icons/rss.hbs b/ghost/core/test/utils/fixtures/themes/source/partials/icons/rss.hbs new file mode 100644 index 0000000000..384023893c --- /dev/null +++ b/ghost/core/test/utils/fixtures/themes/source/partials/icons/rss.hbs @@ -0,0 +1 @@ + diff --git a/ghost/core/test/utils/fixtures/themes/source/partials/icons/search.hbs b/ghost/core/test/utils/fixtures/themes/source/partials/icons/search.hbs new file mode 100644 index 0000000000..369d7f9cc1 --- /dev/null +++ b/ghost/core/test/utils/fixtures/themes/source/partials/icons/search.hbs @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/ghost/core/test/utils/fixtures/themes/source/partials/icons/twitter.hbs b/ghost/core/test/utils/fixtures/themes/source/partials/icons/twitter.hbs new file mode 100644 index 0000000000..70b73bd3c3 --- /dev/null +++ b/ghost/core/test/utils/fixtures/themes/source/partials/icons/twitter.hbs @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/ghost/core/test/utils/fixtures/themes/source/partials/lightbox.hbs b/ghost/core/test/utils/fixtures/themes/source/partials/lightbox.hbs new file mode 100644 index 0000000000..642d86d14c --- /dev/null +++ b/ghost/core/test/utils/fixtures/themes/source/partials/lightbox.hbs @@ -0,0 +1,41 @@ + \ No newline at end of file diff --git a/ghost/core/test/utils/fixtures/themes/source/partials/post-card.hbs b/ghost/core/test/utils/fixtures/themes/source/partials/post-card.hbs new file mode 100644 index 0000000000..ca20282aa2 --- /dev/null +++ b/ghost/core/test/utils/fixtures/themes/source/partials/post-card.hbs @@ -0,0 +1,35 @@ + \ No newline at end of file diff --git a/ghost/core/test/utils/fixtures/themes/source/partials/search-toggle.hbs b/ghost/core/test/utils/fixtures/themes/source/partials/search-toggle.hbs new file mode 100644 index 0000000000..ab24c8230a --- /dev/null +++ b/ghost/core/test/utils/fixtures/themes/source/partials/search-toggle.hbs @@ -0,0 +1,3 @@ + \ No newline at end of file diff --git a/ghost/core/test/utils/fixtures/themes/source/post.hbs b/ghost/core/test/utils/fixtures/themes/source/post.hbs new file mode 100644 index 0000000000..efb90b52fb --- /dev/null +++ b/ghost/core/test/utils/fixtures/themes/source/post.hbs @@ -0,0 +1,63 @@ +{{!< default}} +{{!-- The tag above means: insert everything in this file into the body of the default.hbs template --}} + +{{#post}} + +
+ +
+ +
+ + {{#if primary_tag}} + + {{/if}} +

{{title}}

+ {{#if custom_excerpt}} +

{{custom_excerpt}}

+ {{/if}} + + + + {{> "feature-image"}} + +
+ +
+ {{content}} +
+ +
+ + {{#if comments}} +
+ {{comments}} +
+ {{/if}} + +
+ +{{/post}} + +{{> "components/post-list" feed="recent" postFeedStyle="Grid" title="Read more" showTitle=true showSidebar=false}} \ No newline at end of file diff --git a/ghost/core/test/utils/fixtures/themes/source/tag.hbs b/ghost/core/test/utils/fixtures/themes/source/tag.hbs new file mode 100644 index 0000000000..4ab5adf838 --- /dev/null +++ b/ghost/core/test/utils/fixtures/themes/source/tag.hbs @@ -0,0 +1,22 @@ +{{!< default}} +{{!-- The tag above means: insert everything in this file into the body of the default.hbs template --}} + +
+ + {{#tag}} +
+
+
+

{{name}}

+ {{#if description}} +

{{description}}

+ {{/if}} +
+ {{> "feature-image"}} +
+
+ {{/tag}} + + {{> "components/post-list" feed="archive" postFeedStyle=@custom.post_feed_style showTitle=false showSidebar=@custom.show_site_in_sidebar}} + +
\ No newline at end of file