valtech-components 2.0.445 → 2.0.446

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.
Files changed (50) hide show
  1. package/esm2022/public-api.mjs +9 -6
  2. package/fesm2022/valtech-components.mjs +5 -3237
  3. package/fesm2022/valtech-components.mjs.map +1 -1
  4. package/lib/components/organisms/article/article.component.d.ts +5 -5
  5. package/package.json +1 -1
  6. package/public-api.d.ts +0 -5
  7. package/esm2022/lib/components/molecules/feedback-form/feedback-form.component.mjs +0 -352
  8. package/esm2022/lib/components/molecules/feedback-form/types.mjs +0 -2
  9. package/esm2022/lib/services/auth/auth-state.service.mjs +0 -173
  10. package/esm2022/lib/services/auth/auth.service.mjs +0 -454
  11. package/esm2022/lib/services/auth/config.mjs +0 -76
  12. package/esm2022/lib/services/auth/guards.mjs +0 -194
  13. package/esm2022/lib/services/auth/index.mjs +0 -70
  14. package/esm2022/lib/services/auth/interceptor.mjs +0 -98
  15. package/esm2022/lib/services/auth/storage.service.mjs +0 -138
  16. package/esm2022/lib/services/auth/sync.service.mjs +0 -146
  17. package/esm2022/lib/services/auth/token.service.mjs +0 -113
  18. package/esm2022/lib/services/auth/types.mjs +0 -29
  19. package/esm2022/lib/services/content/content-types/blog.mjs +0 -275
  20. package/esm2022/lib/services/content/content-types/documentation.mjs +0 -303
  21. package/esm2022/lib/services/content/content-types/news.mjs +0 -277
  22. package/esm2022/lib/services/content/index.mjs +0 -51
  23. package/esm2022/lib/services/content/transformer.mjs +0 -265
  24. package/esm2022/lib/services/content/types.mjs +0 -41
  25. package/esm2022/lib/services/feedback/config.mjs +0 -49
  26. package/esm2022/lib/services/feedback/feedback.service.mjs +0 -174
  27. package/esm2022/lib/services/feedback/index.mjs +0 -44
  28. package/esm2022/lib/services/feedback/types.mjs +0 -30
  29. package/lib/components/molecules/feedback-form/feedback-form.component.d.ts +0 -56
  30. package/lib/components/molecules/feedback-form/types.d.ts +0 -54
  31. package/lib/services/auth/auth-state.service.d.ts +0 -85
  32. package/lib/services/auth/auth.service.d.ts +0 -146
  33. package/lib/services/auth/config.d.ts +0 -38
  34. package/lib/services/auth/guards.d.ts +0 -123
  35. package/lib/services/auth/index.d.ts +0 -63
  36. package/lib/services/auth/interceptor.d.ts +0 -22
  37. package/lib/services/auth/storage.service.d.ts +0 -48
  38. package/lib/services/auth/sync.service.d.ts +0 -49
  39. package/lib/services/auth/token.service.d.ts +0 -51
  40. package/lib/services/auth/types.d.ts +0 -315
  41. package/lib/services/content/content-types/blog.d.ts +0 -148
  42. package/lib/services/content/content-types/documentation.d.ts +0 -183
  43. package/lib/services/content/content-types/news.d.ts +0 -162
  44. package/lib/services/content/index.d.ts +0 -49
  45. package/lib/services/content/transformer.d.ts +0 -96
  46. package/lib/services/content/types.d.ts +0 -220
  47. package/lib/services/feedback/config.d.ts +0 -35
  48. package/lib/services/feedback/feedback.service.d.ts +0 -76
  49. package/lib/services/feedback/index.d.ts +0 -40
  50. package/lib/services/feedback/types.d.ts +0 -107
@@ -1,303 +0,0 @@
1
- /**
2
- * Documentation Content Type
3
- *
4
- * Represents technical documentation with navigation,
5
- * sections, and structured content blocks.
6
- */
7
- import { ContentTransformer } from '../transformer';
8
- /**
9
- * Generates a URL-friendly ID from text
10
- */
11
- function slugify(text) {
12
- return text
13
- .toLowerCase()
14
- .replace(/[^\w\s-]/g, '')
15
- .replace(/\s+/g, '-')
16
- .trim();
17
- }
18
- /**
19
- * Extracts table of contents from content blocks
20
- */
21
- function extractToc(content) {
22
- const toc = [];
23
- for (const block of content) {
24
- if (block.type === 'heading') {
25
- toc.push({
26
- text: block.text,
27
- level: block.level,
28
- id: slugify(block.text),
29
- });
30
- }
31
- }
32
- return toc;
33
- }
34
- /**
35
- * DocsBuilder provides a fluent API for creating documentation pages.
36
- *
37
- * @example
38
- * ```typescript
39
- * const docs = new DocsBuilder()
40
- * .title('Installation Guide')
41
- * .section('Getting Started')
42
- * .version('1.0.0')
43
- * .heading('Prerequisites', 1)
44
- * .paragraph('Before you begin, ensure you have...')
45
- * .callout('Node.js 18+ is required', 'warning')
46
- * .heading('Installation', 1)
47
- * .code('npm install valtech-components', 'bash')
48
- * .prevPage('Introduction', '/docs/intro')
49
- * .nextPage('Configuration', '/docs/config')
50
- * .build();
51
- *
52
- * // Convert to ArticleMetadata
53
- * const article = docs.toArticle();
54
- * ```
55
- */
56
- export class DocsBuilder {
57
- constructor() {
58
- this.doc = {
59
- type: 'docs',
60
- content: [],
61
- meta: {},
62
- config: { showMeta: false, showTableOfContents: true },
63
- };
64
- }
65
- /**
66
- * Sets the documentation page title
67
- */
68
- title(title) {
69
- this.doc.title = title;
70
- return this;
71
- }
72
- /**
73
- * Sets the section name
74
- */
75
- section(section) {
76
- this.doc.section = section;
77
- return this;
78
- }
79
- /**
80
- * Sets the documentation version
81
- */
82
- version(version) {
83
- this.doc.version = version;
84
- return this;
85
- }
86
- /**
87
- * Sets the previous page navigation
88
- */
89
- prevPage(title, slug) {
90
- this.doc.prevPage = { title, slug };
91
- return this;
92
- }
93
- /**
94
- * Sets the next page navigation
95
- */
96
- nextPage(title, slug) {
97
- this.doc.nextPage = { title, slug };
98
- return this;
99
- }
100
- /**
101
- * Sets the slug for the page
102
- */
103
- slug(slug) {
104
- this.doc.meta = {
105
- ...this.doc.meta,
106
- slug,
107
- };
108
- return this;
109
- }
110
- /**
111
- * Sets the ID for the page
112
- */
113
- id(id) {
114
- this.doc.meta = {
115
- ...this.doc.meta,
116
- id,
117
- };
118
- return this;
119
- }
120
- /**
121
- * Sets tags for the documentation page
122
- */
123
- tags(...tags) {
124
- this.doc.meta = {
125
- ...this.doc.meta,
126
- tags,
127
- };
128
- return this;
129
- }
130
- /**
131
- * Sets the category
132
- */
133
- category(category) {
134
- this.doc.meta = {
135
- ...this.doc.meta,
136
- category,
137
- };
138
- return this;
139
- }
140
- // Content block methods
141
- /**
142
- * Adds a heading block
143
- */
144
- heading(text, level = 2) {
145
- this.doc.content.push({ type: 'heading', level, text });
146
- return this;
147
- }
148
- /**
149
- * Adds a paragraph block
150
- */
151
- paragraph(text, emphasis) {
152
- this.doc.content.push({ type: 'paragraph', text, emphasis });
153
- return this;
154
- }
155
- /**
156
- * Adds a code block
157
- */
158
- code(code, language) {
159
- this.doc.content.push({ type: 'code', code, language });
160
- return this;
161
- }
162
- /**
163
- * Adds a command/terminal block
164
- */
165
- command(command) {
166
- this.doc.content.push({ type: 'command', command });
167
- return this;
168
- }
169
- /**
170
- * Adds a callout/note block
171
- */
172
- callout(text, variant = 'info', title) {
173
- this.doc.content.push({ type: 'callout', text, variant, title });
174
- return this;
175
- }
176
- /**
177
- * Adds an info callout (alias for callout with info variant)
178
- */
179
- info(text, title) {
180
- return this.callout(text, 'info', title);
181
- }
182
- /**
183
- * Adds a warning callout
184
- */
185
- warning(text, title) {
186
- return this.callout(text, 'warning', title);
187
- }
188
- /**
189
- * Adds an error callout
190
- */
191
- error(text, title) {
192
- return this.callout(text, 'error', title);
193
- }
194
- /**
195
- * Adds a success callout
196
- */
197
- success(text, title) {
198
- return this.callout(text, 'success', title);
199
- }
200
- /**
201
- * Adds an unordered list
202
- */
203
- list(items) {
204
- this.doc.content.push({ type: 'list', items });
205
- return this;
206
- }
207
- /**
208
- * Adds an ordered/numbered list
209
- */
210
- orderedList(items) {
211
- this.doc.content.push({ type: 'list', items, ordered: true });
212
- return this;
213
- }
214
- /**
215
- * Adds a checklist
216
- */
217
- checklist(items) {
218
- this.doc.content.push({ type: 'list', items, checklist: true });
219
- return this;
220
- }
221
- /**
222
- * Adds an image block
223
- */
224
- image(src, alt, caption) {
225
- this.doc.content.push({ type: 'image', src, alt, caption });
226
- return this;
227
- }
228
- /**
229
- * Adds a quote block
230
- */
231
- quote(text, author, source) {
232
- this.doc.content.push({ type: 'quote', text, author, source });
233
- return this;
234
- }
235
- /**
236
- * Adds a divider
237
- */
238
- divider(style) {
239
- this.doc.content.push({ type: 'divider', style });
240
- return this;
241
- }
242
- /**
243
- * Adds a button/CTA
244
- */
245
- button(text, href, color) {
246
- this.doc.content.push({ type: 'button', text, href, color });
247
- return this;
248
- }
249
- /**
250
- * Configures rendering options
251
- */
252
- config(config) {
253
- this.doc.config = { ...this.doc.config, ...config };
254
- return this;
255
- }
256
- /**
257
- * Builds the final Documentation object
258
- */
259
- build() {
260
- const content = this.doc.content || [];
261
- // Auto-generate TOC if not provided and showTableOfContents is enabled
262
- if (!this.doc.toc && this.doc.config?.showTableOfContents) {
263
- this.doc.toc = extractToc(content);
264
- }
265
- return {
266
- type: 'docs',
267
- title: this.doc.title || 'Untitled Documentation',
268
- section: this.doc.section,
269
- version: this.doc.version,
270
- prevPage: this.doc.prevPage,
271
- nextPage: this.doc.nextPage,
272
- toc: this.doc.toc,
273
- meta: this.doc.meta,
274
- content,
275
- config: this.doc.config,
276
- };
277
- }
278
- /**
279
- * Builds and converts to ArticleMetadata
280
- */
281
- toArticle() {
282
- return ContentTransformer.toArticle(this.build());
283
- }
284
- /**
285
- * Resets the builder for reuse
286
- */
287
- clear() {
288
- this.doc = {
289
- type: 'docs',
290
- content: [],
291
- meta: {},
292
- config: { showMeta: false, showTableOfContents: true },
293
- };
294
- return this;
295
- }
296
- }
297
- /**
298
- * Creates a new DocsBuilder instance
299
- */
300
- export function docs() {
301
- return new DocsBuilder();
302
- }
303
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documentation.js","sourceRoot":"","sources":["../../../../../../../src/lib/services/content/content-types/documentation.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Documentation Content Type\n *\n * Represents technical documentation with navigation,\n * sections, and structured content blocks.\n */\n\nimport { ArticleMetadata } from '../../../components/organisms/article/types';\nimport { ContentDocument, ContentMeta, ContentBlock, ContentConfig } from '../types';\nimport { ContentTransformer } from '../transformer';\n\n/**\n * Navigation link for prev/next page navigation\n */\nexport interface DocNavLink {\n  /** Page title */\n  title: string;\n  /** Page slug/URL */\n  slug: string;\n}\n\n/**\n * Documentation document interface\n */\nexport interface Documentation extends ContentDocument<'docs'> {\n  /** Documentation page title */\n  title: string;\n  /** Section name (e.g., \"Getting Started\", \"API Reference\") */\n  section?: string;\n  /** Version of the documentation */\n  version?: string;\n  /** Previous page navigation */\n  prevPage?: DocNavLink;\n  /** Next page navigation */\n  nextPage?: DocNavLink;\n  /** Table of contents items (auto-generated from headings if not provided) */\n  toc?: { text: string; level: number; id: string }[];\n}\n\n/**\n * Generates a URL-friendly ID from text\n */\nfunction slugify(text: string): string {\n  return text\n    .toLowerCase()\n    .replace(/[^\\w\\s-]/g, '')\n    .replace(/\\s+/g, '-')\n    .trim();\n}\n\n/**\n * Extracts table of contents from content blocks\n */\nfunction extractToc(content: ContentBlock[]): { text: string; level: number; id: string }[] {\n  const toc: { text: string; level: number; id: string }[] = [];\n\n  for (const block of content) {\n    if (block.type === 'heading') {\n      toc.push({\n        text: block.text,\n        level: block.level,\n        id: slugify(block.text),\n      });\n    }\n  }\n\n  return toc;\n}\n\n/**\n * DocsBuilder provides a fluent API for creating documentation pages.\n *\n * @example\n * ```typescript\n * const docs = new DocsBuilder()\n *   .title('Installation Guide')\n *   .section('Getting Started')\n *   .version('1.0.0')\n *   .heading('Prerequisites', 1)\n *   .paragraph('Before you begin, ensure you have...')\n *   .callout('Node.js 18+ is required', 'warning')\n *   .heading('Installation', 1)\n *   .code('npm install valtech-components', 'bash')\n *   .prevPage('Introduction', '/docs/intro')\n *   .nextPage('Configuration', '/docs/config')\n *   .build();\n *\n * // Convert to ArticleMetadata\n * const article = docs.toArticle();\n * ```\n */\nexport class DocsBuilder {\n  private doc: Partial<Documentation> = {\n    type: 'docs',\n    content: [],\n    meta: {},\n    config: { showMeta: false, showTableOfContents: true },\n  };\n\n  /**\n   * Sets the documentation page title\n   */\n  title(title: string): this {\n    this.doc.title = title;\n    return this;\n  }\n\n  /**\n   * Sets the section name\n   */\n  section(section: string): this {\n    this.doc.section = section;\n    return this;\n  }\n\n  /**\n   * Sets the documentation version\n   */\n  version(version: string): this {\n    this.doc.version = version;\n    return this;\n  }\n\n  /**\n   * Sets the previous page navigation\n   */\n  prevPage(title: string, slug: string): this {\n    this.doc.prevPage = { title, slug };\n    return this;\n  }\n\n  /**\n   * Sets the next page navigation\n   */\n  nextPage(title: string, slug: string): this {\n    this.doc.nextPage = { title, slug };\n    return this;\n  }\n\n  /**\n   * Sets the slug for the page\n   */\n  slug(slug: string): this {\n    this.doc.meta = {\n      ...this.doc.meta,\n      slug,\n    };\n    return this;\n  }\n\n  /**\n   * Sets the ID for the page\n   */\n  id(id: string): this {\n    this.doc.meta = {\n      ...this.doc.meta,\n      id,\n    };\n    return this;\n  }\n\n  /**\n   * Sets tags for the documentation page\n   */\n  tags(...tags: string[]): this {\n    this.doc.meta = {\n      ...this.doc.meta,\n      tags,\n    };\n    return this;\n  }\n\n  /**\n   * Sets the category\n   */\n  category(category: string): this {\n    this.doc.meta = {\n      ...this.doc.meta,\n      category,\n    };\n    return this;\n  }\n\n  // Content block methods\n\n  /**\n   * Adds a heading block\n   */\n  heading(text: string, level: 1 | 2 | 3 = 2): this {\n    this.doc.content!.push({ type: 'heading', level, text });\n    return this;\n  }\n\n  /**\n   * Adds a paragraph block\n   */\n  paragraph(text: string, emphasis?: boolean): this {\n    this.doc.content!.push({ type: 'paragraph', text, emphasis });\n    return this;\n  }\n\n  /**\n   * Adds a code block\n   */\n  code(code: string, language?: string): this {\n    this.doc.content!.push({ type: 'code', code, language });\n    return this;\n  }\n\n  /**\n   * Adds a command/terminal block\n   */\n  command(command: string): this {\n    this.doc.content!.push({ type: 'command', command });\n    return this;\n  }\n\n  /**\n   * Adds a callout/note block\n   */\n  callout(text: string, variant: 'info' | 'warning' | 'success' | 'error' = 'info', title?: string): this {\n    this.doc.content!.push({ type: 'callout', text, variant, title });\n    return this;\n  }\n\n  /**\n   * Adds an info callout (alias for callout with info variant)\n   */\n  info(text: string, title?: string): this {\n    return this.callout(text, 'info', title);\n  }\n\n  /**\n   * Adds a warning callout\n   */\n  warning(text: string, title?: string): this {\n    return this.callout(text, 'warning', title);\n  }\n\n  /**\n   * Adds an error callout\n   */\n  error(text: string, title?: string): this {\n    return this.callout(text, 'error', title);\n  }\n\n  /**\n   * Adds a success callout\n   */\n  success(text: string, title?: string): this {\n    return this.callout(text, 'success', title);\n  }\n\n  /**\n   * Adds an unordered list\n   */\n  list(items: string[]): this {\n    this.doc.content!.push({ type: 'list', items });\n    return this;\n  }\n\n  /**\n   * Adds an ordered/numbered list\n   */\n  orderedList(items: string[]): this {\n    this.doc.content!.push({ type: 'list', items, ordered: true });\n    return this;\n  }\n\n  /**\n   * Adds a checklist\n   */\n  checklist(items: string[]): this {\n    this.doc.content!.push({ type: 'list', items, checklist: true });\n    return this;\n  }\n\n  /**\n   * Adds an image block\n   */\n  image(src: string, alt: string, caption?: string): this {\n    this.doc.content!.push({ type: 'image', src, alt, caption });\n    return this;\n  }\n\n  /**\n   * Adds a quote block\n   */\n  quote(text: string, author?: string, source?: string): this {\n    this.doc.content!.push({ type: 'quote', text, author, source });\n    return this;\n  }\n\n  /**\n   * Adds a divider\n   */\n  divider(style?: 'line' | 'dots' | 'space'): this {\n    this.doc.content!.push({ type: 'divider', style });\n    return this;\n  }\n\n  /**\n   * Adds a button/CTA\n   */\n  button(text: string, href?: string, color?: 'primary' | 'secondary' | 'success'): this {\n    this.doc.content!.push({ type: 'button', text, href, color });\n    return this;\n  }\n\n  /**\n   * Configures rendering options\n   */\n  config(config: Partial<ContentConfig>): this {\n    this.doc.config = { ...this.doc.config, ...config };\n    return this;\n  }\n\n  /**\n   * Builds the final Documentation object\n   */\n  build(): Documentation {\n    const content = this.doc.content || [];\n\n    // Auto-generate TOC if not provided and showTableOfContents is enabled\n    if (!this.doc.toc && this.doc.config?.showTableOfContents) {\n      this.doc.toc = extractToc(content);\n    }\n\n    return {\n      type: 'docs',\n      title: this.doc.title || 'Untitled Documentation',\n      section: this.doc.section,\n      version: this.doc.version,\n      prevPage: this.doc.prevPage,\n      nextPage: this.doc.nextPage,\n      toc: this.doc.toc,\n      meta: this.doc.meta as ContentMeta,\n      content,\n      config: this.doc.config,\n    };\n  }\n\n  /**\n   * Builds and converts to ArticleMetadata\n   */\n  toArticle(): ArticleMetadata {\n    return ContentTransformer.toArticle(this.build());\n  }\n\n  /**\n   * Resets the builder for reuse\n   */\n  clear(): this {\n    this.doc = {\n      type: 'docs',\n      content: [],\n      meta: {},\n      config: { showMeta: false, showTableOfContents: true },\n    };\n    return this;\n  }\n}\n\n/**\n * Creates a new DocsBuilder instance\n */\nexport function docs(): DocsBuilder {\n  return new DocsBuilder();\n}\n"]}
@@ -1,277 +0,0 @@
1
- /**
2
- * News Article Content Type
3
- *
4
- * Represents a news article or announcement with headline,
5
- * summary, featured image, and structured content blocks.
6
- */
7
- import { ContentTransformer } from '../transformer';
8
- /**
9
- * Calculates estimated reading time based on word count
10
- * @param content - Array of content blocks
11
- * @returns Estimated minutes to read
12
- */
13
- function calculateReadingTime(content) {
14
- const wordsPerMinute = 200;
15
- let wordCount = 0;
16
- for (const block of content) {
17
- if ('text' in block && typeof block.text === 'string') {
18
- wordCount += block.text.split(/\s+/).length;
19
- }
20
- if (block.type === 'list') {
21
- wordCount += block.items.join(' ').split(/\s+/).length;
22
- }
23
- }
24
- return Math.max(1, Math.ceil(wordCount / wordsPerMinute));
25
- }
26
- /**
27
- * NewsBuilder provides a fluent API for creating news articles.
28
- *
29
- * @example
30
- * ```typescript
31
- * const news = new NewsBuilder()
32
- * .headline('New Product Launch Announced')
33
- * .summary('Company reveals groundbreaking new product...')
34
- * .author('Jane Smith', '/avatars/jane.jpg', 'Technology Reporter')
35
- * .publishedAt(new Date())
36
- * .breaking()
37
- * .featuredImage('/images/product-launch.jpg')
38
- * .paragraph('In a surprise announcement today...')
39
- * .quote('This is our most innovative product yet', 'CEO John Doe')
40
- * .build();
41
- *
42
- * // Convert to ArticleMetadata
43
- * const article = news.toArticle();
44
- * ```
45
- */
46
- export class NewsBuilder {
47
- constructor() {
48
- this.article = {
49
- type: 'news',
50
- content: [],
51
- meta: {},
52
- config: { showMeta: true },
53
- };
54
- }
55
- /**
56
- * Sets the news headline
57
- */
58
- headline(headline) {
59
- this.article.headline = headline;
60
- return this;
61
- }
62
- /**
63
- * Sets the news summary
64
- */
65
- summary(summary) {
66
- this.article.summary = summary;
67
- return this;
68
- }
69
- /**
70
- * Sets the featured image URL
71
- */
72
- featuredImage(url) {
73
- this.article.featuredImage = url;
74
- return this;
75
- }
76
- /**
77
- * Marks the article as breaking news
78
- */
79
- breaking(value = true) {
80
- this.article.breaking = value;
81
- return this;
82
- }
83
- /**
84
- * Sets the news source/outlet
85
- */
86
- source(source) {
87
- this.article.source = source;
88
- return this;
89
- }
90
- /**
91
- * Sets the article author
92
- */
93
- author(name, avatar, role) {
94
- this.article.meta = {
95
- ...this.article.meta,
96
- author: { name, avatar, role },
97
- };
98
- return this;
99
- }
100
- /**
101
- * Sets the publication date
102
- */
103
- publishedAt(date) {
104
- this.article.meta = {
105
- ...this.article.meta,
106
- publishedAt: date,
107
- };
108
- return this;
109
- }
110
- /**
111
- * Sets tags for the article
112
- */
113
- tags(...tags) {
114
- this.article.meta = {
115
- ...this.article.meta,
116
- tags,
117
- };
118
- return this;
119
- }
120
- /**
121
- * Sets the category
122
- */
123
- category(category) {
124
- this.article.meta = {
125
- ...this.article.meta,
126
- category,
127
- };
128
- return this;
129
- }
130
- /**
131
- * Sets the slug
132
- */
133
- slug(slug) {
134
- this.article.meta = {
135
- ...this.article.meta,
136
- slug,
137
- };
138
- return this;
139
- }
140
- /**
141
- * Sets the ID
142
- */
143
- id(id) {
144
- this.article.meta = {
145
- ...this.article.meta,
146
- id,
147
- };
148
- return this;
149
- }
150
- /**
151
- * Adds related articles
152
- */
153
- relatedArticles(articles) {
154
- this.article.relatedArticles = articles;
155
- return this;
156
- }
157
- // Content block methods
158
- /**
159
- * Adds a heading block
160
- */
161
- heading(text, level = 2) {
162
- this.article.content.push({ type: 'heading', level, text });
163
- return this;
164
- }
165
- /**
166
- * Adds a paragraph block
167
- */
168
- paragraph(text, emphasis) {
169
- this.article.content.push({ type: 'paragraph', text, emphasis });
170
- return this;
171
- }
172
- /**
173
- * Adds a quote block
174
- */
175
- quote(text, author, source) {
176
- this.article.content.push({ type: 'quote', text, author, source });
177
- return this;
178
- }
179
- /**
180
- * Adds an image block
181
- */
182
- image(src, alt, caption) {
183
- this.article.content.push({ type: 'image', src, alt, caption });
184
- return this;
185
- }
186
- /**
187
- * Adds an unordered list
188
- */
189
- list(items) {
190
- this.article.content.push({ type: 'list', items });
191
- return this;
192
- }
193
- /**
194
- * Adds an ordered/numbered list
195
- */
196
- orderedList(items) {
197
- this.article.content.push({ type: 'list', items, ordered: true });
198
- return this;
199
- }
200
- /**
201
- * Adds a callout/note block
202
- */
203
- callout(text, variant = 'info', title) {
204
- this.article.content.push({ type: 'callout', text, variant, title });
205
- return this;
206
- }
207
- /**
208
- * Adds a divider
209
- */
210
- divider(style) {
211
- this.article.content.push({ type: 'divider', style });
212
- return this;
213
- }
214
- /**
215
- * Adds a button/CTA
216
- */
217
- button(text, href, color) {
218
- this.article.content.push({ type: 'button', text, href, color });
219
- return this;
220
- }
221
- /**
222
- * Configures rendering options
223
- */
224
- config(config) {
225
- this.article.config = { ...this.article.config, ...config };
226
- return this;
227
- }
228
- /**
229
- * Builds the final NewsArticle object
230
- */
231
- build() {
232
- const content = this.article.content || [];
233
- return {
234
- type: 'news',
235
- headline: this.article.headline || 'Untitled News',
236
- summary: this.article.summary || '',
237
- featuredImage: this.article.featuredImage,
238
- breaking: this.article.breaking,
239
- source: this.article.source,
240
- relatedArticles: this.article.relatedArticles,
241
- meta: this.article.meta,
242
- content,
243
- config: this.article.config,
244
- };
245
- }
246
- /**
247
- * Builds and converts to ArticleMetadata
248
- */
249
- toArticle() {
250
- return ContentTransformer.toArticle(this.build());
251
- }
252
- /**
253
- * Gets the estimated reading time in minutes
254
- */
255
- getReadingTime() {
256
- return calculateReadingTime(this.article.content || []);
257
- }
258
- /**
259
- * Resets the builder for reuse
260
- */
261
- clear() {
262
- this.article = {
263
- type: 'news',
264
- content: [],
265
- meta: {},
266
- config: { showMeta: true },
267
- };
268
- return this;
269
- }
270
- }
271
- /**
272
- * Creates a new NewsBuilder instance
273
- */
274
- export function news() {
275
- return new NewsBuilder();
276
- }
277
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"news.js","sourceRoot":"","sources":["../../../../../../../src/lib/services/content/content-types/news.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * News Article Content Type\n *\n * Represents a news article or announcement with headline,\n * summary, featured image, and structured content blocks.\n */\n\nimport { ArticleMetadata } from '../../../components/organisms/article/types';\nimport { ContentDocument, ContentMeta, ContentBlock, ContentConfig } from '../types';\nimport { ContentTransformer } from '../transformer';\n\n/**\n * News article document interface\n */\nexport interface NewsArticle extends ContentDocument<'news'> {\n  /** News headline */\n  headline: string;\n  /** Short summary for listings */\n  summary: string;\n  /** Featured image URL */\n  featuredImage?: string;\n  /** Breaking news flag */\n  breaking?: boolean;\n  /** News source/outlet */\n  source?: string;\n  /** Related articles */\n  relatedArticles?: { title: string; slug: string }[];\n}\n\n/**\n * Calculates estimated reading time based on word count\n * @param content - Array of content blocks\n * @returns Estimated minutes to read\n */\nfunction calculateReadingTime(content: ContentBlock[]): number {\n  const wordsPerMinute = 200;\n  let wordCount = 0;\n\n  for (const block of content) {\n    if ('text' in block && typeof block.text === 'string') {\n      wordCount += block.text.split(/\\s+/).length;\n    }\n    if (block.type === 'list') {\n      wordCount += block.items.join(' ').split(/\\s+/).length;\n    }\n  }\n\n  return Math.max(1, Math.ceil(wordCount / wordsPerMinute));\n}\n\n/**\n * NewsBuilder provides a fluent API for creating news articles.\n *\n * @example\n * ```typescript\n * const news = new NewsBuilder()\n *   .headline('New Product Launch Announced')\n *   .summary('Company reveals groundbreaking new product...')\n *   .author('Jane Smith', '/avatars/jane.jpg', 'Technology Reporter')\n *   .publishedAt(new Date())\n *   .breaking()\n *   .featuredImage('/images/product-launch.jpg')\n *   .paragraph('In a surprise announcement today...')\n *   .quote('This is our most innovative product yet', 'CEO John Doe')\n *   .build();\n *\n * // Convert to ArticleMetadata\n * const article = news.toArticle();\n * ```\n */\nexport class NewsBuilder {\n  private article: Partial<NewsArticle> = {\n    type: 'news',\n    content: [],\n    meta: {},\n    config: { showMeta: true },\n  };\n\n  /**\n   * Sets the news headline\n   */\n  headline(headline: string): this {\n    this.article.headline = headline;\n    return this;\n  }\n\n  /**\n   * Sets the news summary\n   */\n  summary(summary: string): this {\n    this.article.summary = summary;\n    return this;\n  }\n\n  /**\n   * Sets the featured image URL\n   */\n  featuredImage(url: string): this {\n    this.article.featuredImage = url;\n    return this;\n  }\n\n  /**\n   * Marks the article as breaking news\n   */\n  breaking(value: boolean = true): this {\n    this.article.breaking = value;\n    return this;\n  }\n\n  /**\n   * Sets the news source/outlet\n   */\n  source(source: string): this {\n    this.article.source = source;\n    return this;\n  }\n\n  /**\n   * Sets the article author\n   */\n  author(name: string, avatar?: string, role?: string): this {\n    this.article.meta = {\n      ...this.article.meta,\n      author: { name, avatar, role },\n    };\n    return this;\n  }\n\n  /**\n   * Sets the publication date\n   */\n  publishedAt(date: Date | string): this {\n    this.article.meta = {\n      ...this.article.meta,\n      publishedAt: date,\n    };\n    return this;\n  }\n\n  /**\n   * Sets tags for the article\n   */\n  tags(...tags: string[]): this {\n    this.article.meta = {\n      ...this.article.meta,\n      tags,\n    };\n    return this;\n  }\n\n  /**\n   * Sets the category\n   */\n  category(category: string): this {\n    this.article.meta = {\n      ...this.article.meta,\n      category,\n    };\n    return this;\n  }\n\n  /**\n   * Sets the slug\n   */\n  slug(slug: string): this {\n    this.article.meta = {\n      ...this.article.meta,\n      slug,\n    };\n    return this;\n  }\n\n  /**\n   * Sets the ID\n   */\n  id(id: string): this {\n    this.article.meta = {\n      ...this.article.meta,\n      id,\n    };\n    return this;\n  }\n\n  /**\n   * Adds related articles\n   */\n  relatedArticles(articles: { title: string; slug: string }[]): this {\n    this.article.relatedArticles = articles;\n    return this;\n  }\n\n  // Content block methods\n\n  /**\n   * Adds a heading block\n   */\n  heading(text: string, level: 1 | 2 | 3 = 2): this {\n    this.article.content!.push({ type: 'heading', level, text });\n    return this;\n  }\n\n  /**\n   * Adds a paragraph block\n   */\n  paragraph(text: string, emphasis?: boolean): this {\n    this.article.content!.push({ type: 'paragraph', text, emphasis });\n    return this;\n  }\n\n  /**\n   * Adds a quote block\n   */\n  quote(text: string, author?: string, source?: string): this {\n    this.article.content!.push({ type: 'quote', text, author, source });\n    return this;\n  }\n\n  /**\n   * Adds an image block\n   */\n  image(src: string, alt: string, caption?: string): this {\n    this.article.content!.push({ type: 'image', src, alt, caption });\n    return this;\n  }\n\n  /**\n   * Adds an unordered list\n   */\n  list(items: string[]): this {\n    this.article.content!.push({ type: 'list', items });\n    return this;\n  }\n\n  /**\n   * Adds an ordered/numbered list\n   */\n  orderedList(items: string[]): this {\n    this.article.content!.push({ type: 'list', items, ordered: true });\n    return this;\n  }\n\n  /**\n   * Adds a callout/note block\n   */\n  callout(text: string, variant: 'info' | 'warning' | 'success' | 'error' = 'info', title?: string): this {\n    this.article.content!.push({ type: 'callout', text, variant, title });\n    return this;\n  }\n\n  /**\n   * Adds a divider\n   */\n  divider(style?: 'line' | 'dots' | 'space'): this {\n    this.article.content!.push({ type: 'divider', style });\n    return this;\n  }\n\n  /**\n   * Adds a button/CTA\n   */\n  button(text: string, href?: string, color?: 'primary' | 'secondary' | 'success'): this {\n    this.article.content!.push({ type: 'button', text, href, color });\n    return this;\n  }\n\n  /**\n   * Configures rendering options\n   */\n  config(config: Partial<ContentConfig>): this {\n    this.article.config = { ...this.article.config, ...config };\n    return this;\n  }\n\n  /**\n   * Builds the final NewsArticle object\n   */\n  build(): NewsArticle {\n    const content = this.article.content || [];\n\n    return {\n      type: 'news',\n      headline: this.article.headline || 'Untitled News',\n      summary: this.article.summary || '',\n      featuredImage: this.article.featuredImage,\n      breaking: this.article.breaking,\n      source: this.article.source,\n      relatedArticles: this.article.relatedArticles,\n      meta: this.article.meta as ContentMeta,\n      content,\n      config: this.article.config,\n    };\n  }\n\n  /**\n   * Builds and converts to ArticleMetadata\n   */\n  toArticle(): ArticleMetadata {\n    return ContentTransformer.toArticle(this.build());\n  }\n\n  /**\n   * Gets the estimated reading time in minutes\n   */\n  getReadingTime(): number {\n    return calculateReadingTime(this.article.content || []);\n  }\n\n  /**\n   * Resets the builder for reuse\n   */\n  clear(): this {\n    this.article = {\n      type: 'news',\n      content: [],\n      meta: {},\n      config: { showMeta: true },\n    };\n    return this;\n  }\n}\n\n/**\n * Creates a new NewsBuilder instance\n */\nexport function news(): NewsBuilder {\n  return new NewsBuilder();\n}\n"]}