vowel 0.1.1 → 0.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "vowel",
3
- "version": "0.1.1",
3
+ "version": "0.1.2",
4
4
  "bin": "./bin.js",
5
5
  "scripts": {
6
6
  "dev": "vite dev",
@@ -10,7 +10,9 @@
10
10
  */
11
11
  let { props } = $props();
12
12
  // TODO: Normalize frontmatter props
13
- let { properties, website } = $derived(props);
13
+ let { properties, website, format } = $derived(props);
14
+
15
+ console.log(`Frontmatter format ${format}`);
14
16
 
15
17
  const excludedProperties = [
16
18
  'title',
@@ -47,7 +49,7 @@
47
49
  {#if website.hasOwnProperty(key)}
48
50
  <FrontmatterTaxonomy {property} {key} {website} />
49
51
  {:else}
50
- <FrontmatterProperty {property} {key} />
52
+ <FrontmatterProperty {property} {key} {format} />
51
53
  {/if}
52
54
  {/if}
53
55
  {/each}
@@ -4,7 +4,9 @@
4
4
  import Image from './Markdown/Image.svelte';
5
5
 
6
6
  /** @type {{ property: any, key: string }}*/
7
- let { property, key } = $props();
7
+ let { property, key, format } = $props();
8
+
9
+ console.log(`Frontmatter property format: ${format}`);
8
10
  </script>
9
11
 
10
12
  {#if property}
@@ -30,7 +32,7 @@
30
32
  {#if value.type === 'array'}
31
33
  {@render array(value.output)}
32
34
  {:else if value.type === 'object'}
33
- <Frontmatter props={{ properties: value.output }} />
35
+ <Frontmatter props={{ properties: value.output, format }} />
34
36
  {:else if value.type === 'image'}
35
37
  {@render image(value.output)}
36
38
  {:else if value.type === 'date'}
@@ -52,19 +54,25 @@
52
54
  {/snippet}
53
55
 
54
56
  {#snippet url(value)}
55
- <article>
57
+ {#if format === 'rss'}
56
58
  <a href={value.url}>
57
- {#if value['og:image']}
58
- <img src={value['og:image']} alt="" />
59
- {/if}
60
- <h2>
61
- {value['og:title'] || value.title}
62
- </h2>
63
- <p>
64
- {value['og:description']}
65
- </p>
59
+ {value.title || value['og:title']}
66
60
  </a>
67
- </article>
61
+ {:else}
62
+ <article>
63
+ <a href={value.url}>
64
+ {#if value['og:image']}
65
+ <img src={value['og:image']} alt="" />
66
+ {/if}
67
+ <h2>
68
+ {value.title || value['og:title']}
69
+ </h2>
70
+ <p>
71
+ {value['og:description']}
72
+ </p>
73
+ </a>
74
+ </article>
75
+ {/if}
68
76
  {/snippet}
69
77
 
70
78
  {#snippet pdf(value)}
@@ -1,5 +1,5 @@
1
1
  <script>
2
- let { metadata, url } = $props();
2
+ let { metadata, url, format } = $props();
3
3
  let { image, description, author } = $derived(metadata || {});
4
4
 
5
5
  const href = $derived(metadata?.ogURL || metadata?.canonicalURL || url || '');
@@ -10,24 +10,30 @@
10
10
  </script>
11
11
 
12
12
  {#if metadata}
13
- <article class="link-preview">
14
- <a {href}>
15
- {#if image}
16
- <img src={image} alt="" />
17
- {/if}
18
- <h2>{title ? title + ' - ' : ''}<span class="host">{urlObject.host}</span></h2>
19
- {#if author}
20
- <p>
21
- By {author}
22
- </p>
23
- {/if}
24
- {#if description}
25
- <p>
26
- {description}
27
- </p>
28
- {/if}
29
- </a>
30
- </article>
13
+ {#if format === 'rss'}
14
+ <p><a {href}>{title ? title + ' - ' : ''}{urlObject.host}</a></p>
15
+ {:else}
16
+ <article class="link-preview">
17
+ <a {href}>
18
+ {#if image}
19
+ <img src={image} alt="" />
20
+ {/if}
21
+ <h2>{title ? title + ' - ' : ''}<span class="host">{urlObject.host}</span></h2>
22
+ {#if author}
23
+ <p>
24
+ By {author}
25
+ </p>
26
+ {/if}
27
+ {#if description}
28
+ <p>
29
+ {description}
30
+ </p>
31
+ {/if}
32
+ </a>
33
+ </article>
34
+ {/if}
35
+ {:else if format === 'rss'}
36
+ <p><a {href}>{urlObject.host}</a></p>
31
37
  {:else}
32
38
  <article class="link-preview">
33
39
  <a {href}>
@@ -11,7 +11,7 @@
11
11
 
12
12
  let { props } = $props();
13
13
 
14
- let { ast, level, website } = $derived(props);
14
+ let { ast, level, website, format } = $derived(props);
15
15
 
16
16
  function getElement(node) {
17
17
  if (node.type === 'heading') {
@@ -43,7 +43,7 @@
43
43
  <section class={createFolderClass(path)}>
44
44
  {#each pages as page}
45
45
  <article class={createPageClass(page.url, 'thumbnail')}>
46
- <Page link={true} {content} {page} level={level + 1} {website} />
46
+ <Page link={true} {content} {page} level={level + 1} {website} {format} />
47
47
  </article>
48
48
  {/each}
49
49
  </section>
@@ -55,6 +55,7 @@
55
55
  level={level + 1}
56
56
  {website}
57
57
  content={false}
58
+ {format}
58
59
  />
59
60
  </article>
60
61
  {:else if node.type === 'heading'}
@@ -62,16 +63,16 @@
62
63
  <svelte:self props={{ ast: node.children, level }} />
63
64
  </svelte:element>
64
65
  {:else if node.type === 'link' && node.children}
65
- <Link {node} {level} {website} />
66
+ <Link {node} {level} {website} {format} />
66
67
  {:else if node.type === 'thematicBreak'}
67
68
  <hr />
68
69
  {:else if node.type === 'image'}
69
70
  <Image {node} />
70
71
  {:else if node.type === 'url'}
71
- <LinkPreview url={node.value} metadata={node.metadata} />
72
+ <LinkPreview url={node.value} metadata={node.metadata} {format} />
72
73
  {:else if node.children}
73
74
  <svelte:element this={getElement(node)}>
74
- <svelte:self props={{ ast: node.children, level }} />
75
+ <svelte:self props={{ ast: node.children, level, format }} />
75
76
  </svelte:element>
76
77
  {:else if node.type === 'text'}
77
78
  <Text {node} />
@@ -5,6 +5,8 @@
5
5
  let { page, content = true, link, level = 0, website = {}, format = 'html' } = $props();
6
6
  let { ast, title, date, image, imputedProperties } = $derived(page || {});
7
7
 
8
+ console.log(`Page format: ${format}`);
9
+
8
10
  const dateObject = date?.type === 'date' && new Date(date.output);
9
11
  // TODO: Add conditional logic for format = 'xml'
10
12
  </script>
@@ -46,7 +48,7 @@
46
48
  <time datetime={dateObject.toISOString()}>{dateObject.toLocaleDateString()}</time>
47
49
  {/if}
48
50
 
49
- <Frontmatter props={{ properties: page, website }} />
51
+ <Frontmatter props={{ properties: page, website, format }} />
50
52
 
51
53
  {#if page?.description || (!content && page?.imputedProperties?.description)}
52
54
  <p class="description">{page?.description || page?.imputedProperties.description}</p>
@@ -54,6 +56,6 @@
54
56
 
55
57
  {#if level < 2 && content}
56
58
  <div class="content">
57
- <Markdown props={{ ast, level, website }} />
59
+ <Markdown props={{ ast, level, website, format }} />
58
60
  </div>
59
61
  {/if}
@@ -42,8 +42,8 @@
42
42
  }
43
43
 
44
44
  const breadcrumbs = getBreadcrumbs().slice(1, -1).reverse();
45
- const breadcrumbSegment = breadcrumbs.length ? `${breadcrumbs.join(' - ')}` : '';
46
- return `${pageMetaTitle} - ${breadcrumbSegment} - ${siteTitle}`;
45
+ const breadcrumbSegment = breadcrumbs.length ? ` - ${breadcrumbs.join(' - ')} - ` : '';
46
+ return `${pageMetaTitle}${breadcrumbSegment}${siteTitle}`;
47
47
  }
48
48
 
49
49
  function getFavicon() {
@@ -98,7 +98,7 @@ export async function GET({}) {
98
98
  entry.push({
99
99
  content: [
100
100
  { _attr: { type: 'html' } },
101
- render(Page, { props: { page, level: 0, format: 'xml' } }).html
101
+ render(Page, { props: { page, level: 0, format: 'rss' } }).html
102
102
  ]
103
103
  });
104
104