diff --git a/libs/types/src/config/routing.d.ts b/libs/types/src/config/routing.d.ts index 53a1a91..89b460d 100644 --- a/libs/types/src/config/routing.d.ts +++ b/libs/types/src/config/routing.d.ts @@ -1,5 +1,5 @@ import { Router } from 'vue-router' -import { BlogEntry } from '../content/templates/blog-list' +import { ArticleEntry } from '../content/templates/article-list' import { GalleryEntry } from '../content/templates/gallery-list' import { TemplateType } from '../content/templates/templateType' import { WarningModal } from './warnings' @@ -39,10 +39,10 @@ export type MarkdownDefinition = ContentfulRouteDefintion & { } /** - * Defines the config for a route using the `blog-list` {@link TemplateType} + * Defines the config for a route using the `article-list` {@link TemplateType} */ -export type BlogListDefinition = ConfigfulRouteDefinition & { - template: 'blog-list' +export type ArticleListDefinition = ConfigfulRouteDefinition & { + template: 'article-list' view: { stylesheetUrls: string[] } @@ -63,7 +63,7 @@ export type GalleryListDefinition = ConfigfulRouteDefinition & { */ export type RouteDefinition = | MarkdownDefinition - | BlogListDefinition + | ArticleListDefinition | GalleryListDefinition /** @@ -77,9 +77,9 @@ export type RouteCollection = { [key: string]: RouteDefinition } export interface RoutedWindow extends Window { /** refers to a template's primary route config; may briefly refer to sub config until a view is fully resolved */ routeConfig: RouteDefinition - /** refers to a template's sub config in the case of child routes under a template (e.g. blog-view under blog-list) */ + /** refers to a template's sub config in the case of child routes under a template (e.g. article-view under article-list) */ routeSubConfig: any - /** refers to content config for various view routes (e.g. {@link GalleryEntry}, {@link BlogEntry}, etc.) */ + /** refers to content config for various view routes (e.g. {@link GalleryEntry}, {@link ArticleEntry}, etc.) */ routeContentConfig: any /** vue-router instance */ router?: Router diff --git a/libs/types/src/content/entryTag.d.ts b/libs/types/src/content/entryTag.d.ts index 14de5e0..9b7fa7c 100644 --- a/libs/types/src/content/entryTag.d.ts +++ b/libs/types/src/content/entryTag.d.ts @@ -1,5 +1,5 @@ /** - * Defines a tag used by entries in a gallery-list/blog-list, + * Defines a tag used by entries in a gallery-list/article-list, * used for filtering entries from view */ export type EntryTag = { @@ -19,11 +19,11 @@ export type EntryTag = { } /** - * Defines the list of tags in a gallery-list/blog-list, + * Defines the list of tags in a gallery-list/article-list, * a key-value object where the value is the entry, * and the key represents the id of a tag; * the id of a tag must be unique, - * and the ids specified in a gallery/blog entry must match + * and the ids specified in a gallery/article entry must match * the ids specified in `EntryTagCollection` in order for them to work effectively */ export type EntryTagCollection = { [id: string]: EntryTag } diff --git a/libs/types/src/content/templates/article-list.d.ts b/libs/types/src/content/templates/article-list.d.ts new file mode 100644 index 0000000..c0778fb --- /dev/null +++ b/libs/types/src/content/templates/article-list.d.ts @@ -0,0 +1,12 @@ +import type { MediaEntry } from './shared' + +/** + * This describes additional information about a article entry + * to display when listing the entry on the article-list page. + */ +export type ArticleEntry = { + /** + * URL to the markdown document of the article entry + */ + url: string +} & MediaEntry diff --git a/libs/types/src/content/templates/blog-list.d.ts b/libs/types/src/content/templates/blog-list.d.ts deleted file mode 100644 index 14b5d12..0000000 --- a/libs/types/src/content/templates/blog-list.d.ts +++ /dev/null @@ -1,12 +0,0 @@ -import type { MediaEntry } from './shared' - -/** - * This describes additional information about a blog entry - * to display when listing the entry on the blog-list page. - */ -export type BlogEntry = { - /** - * URL to the markdown document of the blog entry - */ - url: string -} & MediaEntry diff --git a/libs/types/src/content/templates/templateType.d.ts b/libs/types/src/content/templates/templateType.d.ts index 480d0b2..056baa6 100644 --- a/libs/types/src/content/templates/templateType.d.ts +++ b/libs/types/src/content/templates/templateType.d.ts @@ -4,5 +4,5 @@ */ export type TemplateType = | 'markdown' - | 'blog-list' + | 'article-list' | 'gallery-list' diff --git a/libs/types/src/index.d.ts b/libs/types/src/index.d.ts index 912396f..52639d8 100644 --- a/libs/types/src/index.d.ts +++ b/libs/types/src/index.d.ts @@ -8,7 +8,7 @@ export * from './content/dateRange' export * from './content/entryTag' export * from './content/link' -export * from './content/templates/blog-list' +export * from './content/templates/article-list' export * from './content/templates/gallery-list' export * from './content/templates/shared' export * from './content/templates/templateType' diff --git a/projects/frontend/src/routes.ts b/projects/frontend/src/routes.ts index 7706d60..57a0cfb 100644 --- a/projects/frontend/src/routes.ts +++ b/projects/frontend/src/routes.ts @@ -5,20 +5,20 @@ import type { GalleryListDefinition, HeaderEntry, Link, - BlogListDefinition, + ArticleListDefinition, RouteDefinition, SiteGlobals, TemplateType, } from '@goldenwere/mackenzii-types' const markdownBody = () => import ('./views/markdown/markdown.vue') -const blogViewBody = () => import ('./views/blog/blog-view.vue') +const articleViewBody = () => import ('./views/article/article-view.vue') const galleryViewBody = () => import ('./views/gallery/gallery-view.vue') const mediaListBody = () => import ('./views/shared/media-list.vue') export const templates: Record Promise> = { 'markdown': markdownBody, - 'blog-list': mediaListBody, + 'article-list': mediaListBody, 'gallery-list': mediaListBody, } @@ -32,11 +32,11 @@ export const createRoutes = (): RouteRecordRaw[] => { component: templates[routes[route].template], } - if (routes[route].template === 'blog-list') { + if (routes[route].template === 'article-list') { routeRecord.push({ - name: `${routes[route].id}: View Blog`, + name: `${routes[route].id}: View Article`, path: `${route}/view`, - component: blogViewBody, + component: articleViewBody, props: route => ({ id: route.query.id }), }) } else if (routes[route].template === 'gallery-list') { @@ -145,10 +145,10 @@ export const initializeRouteStore = (routerRoutes: readonly RouteRecordRaw[]) => ...routerRoutes.find(other => other.path === route) as RouteRecordRaw, ...routes[route] as RouteDefinition, } - if (routes[route].template === 'blog-list' || routes[route].template === 'gallery-list') { + if (routes[route].template === 'article-list' || routes[route].template === 'gallery-list') { routeStore._routes[`${route}/view`] = { ...routerRoutes.find(other => other.path === `${route}/view`) as RouteRecordRaw, - ...(routes[route] as BlogListDefinition | GalleryListDefinition).view, + ...(routes[route] as ArticleListDefinition | GalleryListDefinition).view, } as any } }) diff --git a/projects/frontend/src/views/blog/blog-tile.vue b/projects/frontend/src/views/article/article-tile.vue similarity index 93% rename from projects/frontend/src/views/blog/blog-tile.vue rename to projects/frontend/src/views/article/article-tile.vue index c886c9e..9fd0e7c 100644 --- a/projects/frontend/src/views/blog/blog-tile.vue +++ b/projects/frontend/src/views/article/article-tile.vue @@ -3,17 +3,17 @@ import { computed, onMounted, ref } from 'vue' import { marked } from 'marked' import { getFormattedDate } from 'src/utilities/parse' import type { - BlogEntry, + ArticleEntry, } from '@goldenwere/mackenzii-types' const props = defineProps<{ id: string, viewPath: string, isInternal: boolean, - entry: Promise + entry: Promise }>() -const resolved = ref({} as BlogEntry) +const resolved = ref({} as ArticleEntry) const thumbnail = computed(() => resolved.value.thumbnail) const description = computed(() => marked.parse(resolved.value.description || '')) const date = computed(() => !!resolved.value.date ? getFormattedDate(resolved.value.date) : null) @@ -46,7 +46,7 @@ mixin embedText v-if='date' ) span {{ date }} -.blog-embed +.article-embed .thumbnail-wrapper( v-if='!!thumbnail' ) diff --git a/projects/frontend/src/views/blog/blog-view.vue b/projects/frontend/src/views/article/article-view.vue similarity index 85% rename from projects/frontend/src/views/blog/blog-view.vue rename to projects/frontend/src/views/article/article-view.vue index 3136f9a..58dbd0f 100644 --- a/projects/frontend/src/views/blog/blog-view.vue +++ b/projects/frontend/src/views/article/article-view.vue @@ -2,8 +2,8 @@ import { onMounted, ref } from 'vue' import type { ListWithEntries, - BlogEntry, - BlogListDefinition, + ArticleEntry, + ArticleListDefinition, RoutedWindow, } from '@goldenwere/mackenzii-types' @@ -20,15 +20,15 @@ const emits = defineEmits<{ }>() const ready = ref(false) -const resolved = ref({} as BlogEntry) +const resolved = ref({} as ArticleEntry) const content = ref('') const currentRoute = getCurrentRoute() const routeStore = useRouteStore() -const routeConfig = routeStore._routes[currentRoute.path.substring(0, currentRoute.path.length - 5)] as BlogListDefinition +const routeConfig = routeStore._routes[currentRoute.path.substring(0, currentRoute.path.length - 5)] as ArticleListDefinition const routeSubConfig = routeStore._routes[currentRoute.path] onMounted(async () => { - const config = await fetchAndParseYaml>(routeConfig.config) + const config = await fetchAndParseYaml>(routeConfig.config) resolved.value = await fetchConfigByIdFromList(config, currentRoute.query.id as string) const md = await fetchAndParseMarkdown(resolved.value.url) content.value = md @@ -44,7 +44,7 @@ onMounted(async () => {