@analogjs/content 1.9.2-beta.1 → 1.9.2-beta.3

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 (39) hide show
  1. package/fesm2022/analogjs-content-og.mjs.map +1 -1
  2. package/fesm2022/analogjs-content-prism-highlighter.mjs +3 -3
  3. package/fesm2022/analogjs-content-prism-highlighter.mjs.map +1 -1
  4. package/fesm2022/analogjs-content-shiki-highlighter.mjs.map +1 -1
  5. package/fesm2022/analogjs-content.mjs +24 -24
  6. package/fesm2022/analogjs-content.mjs.map +1 -1
  7. package/og/lib/og.d.ts +0 -1
  8. package/package.json +5 -13
  9. package/plugin/src/migrations/update-markdown-renderer-feature/update-markdown-renderer-feature.js +1 -1
  10. package/plugin/src/migrations/update-markdown-renderer-feature/update-markdown-renderer-feature.js.map +1 -1
  11. package/esm2022/analogjs-content.mjs +0 -5
  12. package/esm2022/index.mjs +0 -12
  13. package/esm2022/lib/anchor-navigation.directive.mjs +0 -46
  14. package/esm2022/lib/content-file.mjs +0 -2
  15. package/esm2022/lib/content-files-list-token.mjs +0 -22
  16. package/esm2022/lib/content-files-token.mjs +0 -32
  17. package/esm2022/lib/content-renderer.mjs +0 -53
  18. package/esm2022/lib/content.mjs +0 -85
  19. package/esm2022/lib/get-content-files.mjs +0 -25
  20. package/esm2022/lib/inject-content-files.mjs +0 -15
  21. package/esm2022/lib/markdown-content-renderer.service.mjs +0 -24
  22. package/esm2022/lib/markdown-route.component.mjs +0 -37
  23. package/esm2022/lib/markdown.component.mjs +0 -100
  24. package/esm2022/lib/marked-content-highlighter.mjs +0 -13
  25. package/esm2022/lib/marked-setup.service.mjs +0 -53
  26. package/esm2022/lib/parse-raw-content-file.mjs +0 -6
  27. package/esm2022/lib/provide-content.mjs +0 -30
  28. package/esm2022/lib/render-task.service.mjs +0 -17
  29. package/esm2022/lib/utils/zone-wait-for.mjs +0 -15
  30. package/esm2022/og/analogjs-content-og.mjs +0 -5
  31. package/esm2022/og/index.mjs +0 -2
  32. package/esm2022/og/lib/og.mjs +0 -41
  33. package/esm2022/og/lib/options.mjs +0 -2
  34. package/esm2022/prism-highlighter/analogjs-content-prism-highlighter.mjs +0 -5
  35. package/esm2022/prism-highlighter/index.mjs +0 -11
  36. package/esm2022/prism-highlighter/lib/prism/angular.mjs +0 -20
  37. package/esm2022/prism-highlighter/lib/prism-highlighter.mjs +0 -51
  38. package/esm2022/shiki-highlighter/analogjs-content-shiki-highlighter.mjs +0 -5
  39. package/esm2022/shiki-highlighter/index.mjs +0 -10
@@ -1,32 +0,0 @@
1
- import { InjectionToken, inject } from '@angular/core';
2
- import { getAgxFiles, getContentFiles } from './get-content-files';
3
- import { CONTENT_FILES_LIST_TOKEN } from './content-files-list-token';
4
- export const CONTENT_FILES_TOKEN = new InjectionToken('@analogjs/content Content Files', {
5
- providedIn: 'root',
6
- factory() {
7
- const contentFiles = getContentFiles();
8
- const agxFiles = getAgxFiles();
9
- const allFiles = { ...contentFiles, ...agxFiles };
10
- const contentFilesList = inject(CONTENT_FILES_LIST_TOKEN);
11
- const lookup = {};
12
- contentFilesList.forEach((item) => {
13
- const fileParts = item.filename.split('/');
14
- const filePath = fileParts.slice(0, fileParts.length - 1).join('/');
15
- const fileNameParts = fileParts[fileParts.length - 1].split('.');
16
- lookup[item.filename] = `${filePath}/${item.slug}.${fileNameParts[fileNameParts.length - 1]}`;
17
- });
18
- const objectUsingSlugAttribute = {};
19
- Object.entries(allFiles).forEach((entry) => {
20
- const filename = entry[0];
21
- const value = entry[1];
22
- const newFilename = lookup[filename];
23
- if (newFilename !== undefined) {
24
- const objectFilename = newFilename.replace(/^\/(.*?)\/content/, '/src/content');
25
- objectUsingSlugAttribute[objectFilename] =
26
- value;
27
- }
28
- });
29
- return objectUsingSlugAttribute;
30
- },
31
- });
32
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGVudC1maWxlcy10b2tlbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbnRlbnQvc3JjL2xpYi9jb250ZW50LWZpbGVzLXRva2VuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXZELE9BQU8sRUFBRSxXQUFXLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDbkUsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFFdEUsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQUcsSUFBSSxjQUFjLENBRW5ELGlDQUFpQyxFQUFFO0lBQ25DLFVBQVUsRUFBRSxNQUFNO0lBQ2xCLE9BQU87UUFDTCxNQUFNLFlBQVksR0FBRyxlQUFlLEVBQUUsQ0FBQztRQUN2QyxNQUFNLFFBQVEsR0FBRyxXQUFXLEVBQUUsQ0FBQztRQUMvQixNQUFNLFFBQVEsR0FBRyxFQUFFLEdBQUcsWUFBWSxFQUFFLEdBQUcsUUFBUSxFQUFFLENBQUM7UUFDbEQsTUFBTSxnQkFBZ0IsR0FBRyxNQUFNLENBQUMsd0JBQXdCLENBQUMsQ0FBQztRQUUxRCxNQUFNLE1BQU0sR0FBMkIsRUFBRSxDQUFDO1FBQzFDLGdCQUFnQixDQUFDLE9BQU8sQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFO1lBQ2hDLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQzNDLE1BQU0sUUFBUSxHQUFHLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLFNBQVMsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ3BFLE1BQU0sYUFBYSxHQUFHLFNBQVMsQ0FBQyxTQUFTLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUNqRSxNQUFNLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLEdBQUcsUUFBUSxJQUFJLElBQUksQ0FBQyxJQUFJLElBQzlDLGFBQWEsQ0FBQyxhQUFhLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FDeEMsRUFBRSxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7UUFFSCxNQUFNLHdCQUF3QixHQUEwQyxFQUFFLENBQUM7UUFDM0UsTUFBTSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtZQUN6QyxNQUFNLFFBQVEsR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDMUIsTUFBTSxLQUFLLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBRXZCLE1BQU0sV0FBVyxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUNyQyxJQUFJLFdBQVcsS0FBSyxTQUFTLEVBQUUsQ0FBQztnQkFDOUIsTUFBTSxjQUFjLEdBQUcsV0FBVyxDQUFDLE9BQU8sQ0FDeEMsbUJBQW1CLEVBQ25CLGNBQWMsQ0FDZixDQUFDO2dCQUNGLHdCQUF3QixDQUFDLGNBQWMsQ0FBQztvQkFDdEMsS0FBOEIsQ0FBQztZQUNuQyxDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7UUFFSCxPQUFPLHdCQUF3QixDQUFDO0lBQ2xDLENBQUM7Q0FDRixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IGdldEFneEZpbGVzLCBnZXRDb250ZW50RmlsZXMgfSBmcm9tICcuL2dldC1jb250ZW50LWZpbGVzJztcbmltcG9ydCB7IENPTlRFTlRfRklMRVNfTElTVF9UT0tFTiB9IGZyb20gJy4vY29udGVudC1maWxlcy1saXN0LXRva2VuJztcblxuZXhwb3J0IGNvbnN0IENPTlRFTlRfRklMRVNfVE9LRU4gPSBuZXcgSW5qZWN0aW9uVG9rZW48XG4gIFJlY29yZDxzdHJpbmcsICgpID0+IFByb21pc2U8c3RyaW5nPj5cbj4oJ0BhbmFsb2dqcy9jb250ZW50IENvbnRlbnQgRmlsZXMnLCB7XG4gIHByb3ZpZGVkSW46ICdyb290JyxcbiAgZmFjdG9yeSgpIHtcbiAgICBjb25zdCBjb250ZW50RmlsZXMgPSBnZXRDb250ZW50RmlsZXMoKTtcbiAgICBjb25zdCBhZ3hGaWxlcyA9IGdldEFneEZpbGVzKCk7XG4gICAgY29uc3QgYWxsRmlsZXMgPSB7IC4uLmNvbnRlbnRGaWxlcywgLi4uYWd4RmlsZXMgfTtcbiAgICBjb25zdCBjb250ZW50RmlsZXNMaXN0ID0gaW5qZWN0KENPTlRFTlRfRklMRVNfTElTVF9UT0tFTik7XG5cbiAgICBjb25zdCBsb29rdXA6IFJlY29yZDxzdHJpbmcsIHN0cmluZz4gPSB7fTtcbiAgICBjb250ZW50RmlsZXNMaXN0LmZvckVhY2goKGl0ZW0pID0+IHtcbiAgICAgIGNvbnN0IGZpbGVQYXJ0cyA9IGl0ZW0uZmlsZW5hbWUuc3BsaXQoJy8nKTtcbiAgICAgIGNvbnN0IGZpbGVQYXRoID0gZmlsZVBhcnRzLnNsaWNlKDAsIGZpbGVQYXJ0cy5sZW5ndGggLSAxKS5qb2luKCcvJyk7XG4gICAgICBjb25zdCBmaWxlTmFtZVBhcnRzID0gZmlsZVBhcnRzW2ZpbGVQYXJ0cy5sZW5ndGggLSAxXS5zcGxpdCgnLicpO1xuICAgICAgbG9va3VwW2l0ZW0uZmlsZW5hbWVdID0gYCR7ZmlsZVBhdGh9LyR7aXRlbS5zbHVnfS4ke1xuICAgICAgICBmaWxlTmFtZVBhcnRzW2ZpbGVOYW1lUGFydHMubGVuZ3RoIC0gMV1cbiAgICAgIH1gO1xuICAgIH0pO1xuXG4gICAgY29uc3Qgb2JqZWN0VXNpbmdTbHVnQXR0cmlidXRlOiBSZWNvcmQ8c3RyaW5nLCAoKSA9PiBQcm9taXNlPHN0cmluZz4+ID0ge307XG4gICAgT2JqZWN0LmVudHJpZXMoYWxsRmlsZXMpLmZvckVhY2goKGVudHJ5KSA9PiB7XG4gICAgICBjb25zdCBmaWxlbmFtZSA9IGVudHJ5WzBdO1xuICAgICAgY29uc3QgdmFsdWUgPSBlbnRyeVsxXTtcblxuICAgICAgY29uc3QgbmV3RmlsZW5hbWUgPSBsb29rdXBbZmlsZW5hbWVdO1xuICAgICAgaWYgKG5ld0ZpbGVuYW1lICE9PSB1bmRlZmluZWQpIHtcbiAgICAgICAgY29uc3Qgb2JqZWN0RmlsZW5hbWUgPSBuZXdGaWxlbmFtZS5yZXBsYWNlKFxuICAgICAgICAgIC9eXFwvKC4qPylcXC9jb250ZW50LyxcbiAgICAgICAgICAnL3NyYy9jb250ZW50J1xuICAgICAgICApO1xuICAgICAgICBvYmplY3RVc2luZ1NsdWdBdHRyaWJ1dGVbb2JqZWN0RmlsZW5hbWVdID1cbiAgICAgICAgICB2YWx1ZSBhcyAoKSA9PiBQcm9taXNlPHN0cmluZz47XG4gICAgICB9XG4gICAgfSk7XG5cbiAgICByZXR1cm4gb2JqZWN0VXNpbmdTbHVnQXR0cmlidXRlO1xuICB9LFxufSk7XG4iXX0=
@@ -1,53 +0,0 @@
1
- /// <reference types="vite/client" />
2
- import { Injectable, TransferState, inject, makeStateKey } from '@angular/core';
3
- import { getHeadingList } from 'marked-gfm-heading-id';
4
- import * as i0 from "@angular/core";
5
- export class ContentRenderer {
6
- async render(content) {
7
- return content;
8
- }
9
- getContentHeadings() {
10
- return [];
11
- }
12
- // eslint-disable-next-line
13
- enhance() { }
14
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: ContentRenderer, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
15
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: ContentRenderer }); }
16
- }
17
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: ContentRenderer, decorators: [{
18
- type: Injectable
19
- }] });
20
- export class NoopContentRenderer {
21
- constructor() {
22
- this.transferState = inject(TransferState);
23
- this.contentId = 0;
24
- }
25
- /**
26
- * Generates a hash from the content string
27
- * to be used with the transfer state
28
- */
29
- generateHash(str) {
30
- let hash = 0;
31
- for (let i = 0, len = str.length; i < len; i++) {
32
- let chr = str.charCodeAt(i);
33
- hash = (hash << 5) - hash + chr;
34
- hash |= 0; // Convert to 32bit integer
35
- }
36
- return hash;
37
- }
38
- async render(content) {
39
- this.contentId = this.generateHash(content);
40
- return content;
41
- }
42
- enhance() { }
43
- getContentHeadings() {
44
- const key = makeStateKey(`content-headings-${this.contentId}`);
45
- if (import.meta.env.SSR === true) {
46
- const headings = getHeadingList();
47
- this.transferState.set(key, headings);
48
- return headings;
49
- }
50
- return this.transferState.get(key, []);
51
- }
52
- }
53
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGVudC1yZW5kZXJlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbnRlbnQvc3JjL2xpYi9jb250ZW50LXJlbmRlcmVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLHFDQUFxQztBQUVyQyxPQUFPLEVBQUUsVUFBVSxFQUFFLGFBQWEsRUFBRSxNQUFNLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hGLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQzs7QUFTdkQsTUFBTSxPQUFnQixlQUFlO0lBQ25DLEtBQUssQ0FBQyxNQUFNLENBQUMsT0FBZTtRQUMxQixPQUFPLE9BQU8sQ0FBQztJQUNqQixDQUFDO0lBRUQsa0JBQWtCO1FBQ2hCLE9BQU8sRUFBRSxDQUFDO0lBQ1osQ0FBQztJQUVELDJCQUEyQjtJQUMzQixPQUFPLEtBQUksQ0FBQzs4R0FWUSxlQUFlO2tIQUFmLGVBQWU7OzJGQUFmLGVBQWU7a0JBRHBDLFVBQVU7O0FBY1gsTUFBTSxPQUFPLG1CQUFtQjtJQUFoQztRQUNtQixrQkFBYSxHQUFHLE1BQU0sQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUMvQyxjQUFTLEdBQUcsQ0FBQyxDQUFDO0lBbUN4QixDQUFDO0lBakNDOzs7T0FHRztJQUNLLFlBQVksQ0FBQyxHQUFXO1FBQzlCLElBQUksSUFBSSxHQUFHLENBQUMsQ0FBQztRQUNiLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEdBQUcsR0FBRyxHQUFHLENBQUMsTUFBTSxFQUFFLENBQUMsR0FBRyxHQUFHLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQztZQUMvQyxJQUFJLEdBQUcsR0FBRyxHQUFHLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQzVCLElBQUksR0FBRyxDQUFDLElBQUksSUFBSSxDQUFDLENBQUMsR0FBRyxJQUFJLEdBQUcsR0FBRyxDQUFDO1lBQ2hDLElBQUksSUFBSSxDQUFDLENBQUMsQ0FBQywyQkFBMkI7UUFDeEMsQ0FBQztRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVELEtBQUssQ0FBQyxNQUFNLENBQUMsT0FBZTtRQUMxQixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDNUMsT0FBTyxPQUFPLENBQUM7SUFDakIsQ0FBQztJQUNELE9BQU8sS0FBSSxDQUFDO0lBRVosa0JBQWtCO1FBQ2hCLE1BQU0sR0FBRyxHQUFHLFlBQVksQ0FDdEIsb0JBQW9CLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FDckMsQ0FBQztRQUVGLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxLQUFLLElBQUksRUFBRSxDQUFDO1lBQ2pDLE1BQU0sUUFBUSxHQUFHLGNBQWMsRUFBRSxDQUFDO1lBQ2xDLElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxRQUFRLENBQUMsQ0FBQztZQUN0QyxPQUFPLFFBQVEsQ0FBQztRQUNsQixDQUFDO1FBRUQsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDekMsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiLy8vIDxyZWZlcmVuY2UgdHlwZXM9XCJ2aXRlL2NsaWVudFwiIC8+XG5cbmltcG9ydCB7IEluamVjdGFibGUsIFRyYW5zZmVyU3RhdGUsIGluamVjdCwgbWFrZVN0YXRlS2V5IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBnZXRIZWFkaW5nTGlzdCB9IGZyb20gJ21hcmtlZC1nZm0taGVhZGluZy1pZCc7XG5cbmV4cG9ydCB0eXBlIFRhYmxlT2ZDb250ZW50SXRlbSA9IHtcbiAgaWQ6IHN0cmluZztcbiAgbGV2ZWw6IG51bWJlcjsgLy8gc3RhcnRzIGF0IDFcbiAgdGV4dDogc3RyaW5nO1xufTtcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIENvbnRlbnRSZW5kZXJlciB7XG4gIGFzeW5jIHJlbmRlcihjb250ZW50OiBzdHJpbmcpOiBQcm9taXNlPHN0cmluZz4ge1xuICAgIHJldHVybiBjb250ZW50O1xuICB9XG5cbiAgZ2V0Q29udGVudEhlYWRpbmdzKCk6IEFycmF5PFRhYmxlT2ZDb250ZW50SXRlbT4ge1xuICAgIHJldHVybiBbXTtcbiAgfVxuXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZVxuICBlbmhhbmNlKCkge31cbn1cblxuZXhwb3J0IGNsYXNzIE5vb3BDb250ZW50UmVuZGVyZXIgaW1wbGVtZW50cyBDb250ZW50UmVuZGVyZXIge1xuICBwcml2YXRlIHJlYWRvbmx5IHRyYW5zZmVyU3RhdGUgPSBpbmplY3QoVHJhbnNmZXJTdGF0ZSk7XG4gIHByaXZhdGUgY29udGVudElkID0gMDtcblxuICAvKipcbiAgICogR2VuZXJhdGVzIGEgaGFzaCBmcm9tIHRoZSBjb250ZW50IHN0cmluZ1xuICAgKiB0byBiZSB1c2VkIHdpdGggdGhlIHRyYW5zZmVyIHN0YXRlXG4gICAqL1xuICBwcml2YXRlIGdlbmVyYXRlSGFzaChzdHI6IHN0cmluZykge1xuICAgIGxldCBoYXNoID0gMDtcbiAgICBmb3IgKGxldCBpID0gMCwgbGVuID0gc3RyLmxlbmd0aDsgaSA8IGxlbjsgaSsrKSB7XG4gICAgICBsZXQgY2hyID0gc3RyLmNoYXJDb2RlQXQoaSk7XG4gICAgICBoYXNoID0gKGhhc2ggPDwgNSkgLSBoYXNoICsgY2hyO1xuICAgICAgaGFzaCB8PSAwOyAvLyBDb252ZXJ0IHRvIDMyYml0IGludGVnZXJcbiAgICB9XG4gICAgcmV0dXJuIGhhc2g7XG4gIH1cblxuICBhc3luYyByZW5kZXIoY29udGVudDogc3RyaW5nKSB7XG4gICAgdGhpcy5jb250ZW50SWQgPSB0aGlzLmdlbmVyYXRlSGFzaChjb250ZW50KTtcbiAgICByZXR1cm4gY29udGVudDtcbiAgfVxuICBlbmhhbmNlKCkge31cblxuICBnZXRDb250ZW50SGVhZGluZ3MoKTogQXJyYXk8VGFibGVPZkNvbnRlbnRJdGVtPiB7XG4gICAgY29uc3Qga2V5ID0gbWFrZVN0YXRlS2V5PFRhYmxlT2ZDb250ZW50SXRlbVtdPihcbiAgICAgIGBjb250ZW50LWhlYWRpbmdzLSR7dGhpcy5jb250ZW50SWR9YFxuICAgICk7XG5cbiAgICBpZiAoaW1wb3J0Lm1ldGEuZW52LlNTUiA9PT0gdHJ1ZSkge1xuICAgICAgY29uc3QgaGVhZGluZ3MgPSBnZXRIZWFkaW5nTGlzdCgpO1xuICAgICAgdGhpcy50cmFuc2ZlclN0YXRlLnNldChrZXksIGhlYWRpbmdzKTtcbiAgICAgIHJldHVybiBoZWFkaW5ncztcbiAgICB9XG5cbiAgICByZXR1cm4gdGhpcy50cmFuc2ZlclN0YXRlLmdldChrZXksIFtdKTtcbiAgfVxufVxuIl19
@@ -1,85 +0,0 @@
1
- /// <reference types="vite/client" />
2
- import { inject } from '@angular/core';
3
- import { ActivatedRoute } from '@angular/router';
4
- import { Observable, of } from 'rxjs';
5
- import { map, switchMap, tap } from 'rxjs/operators';
6
- import { CONTENT_FILES_TOKEN } from './content-files-token';
7
- import { parseRawContentFile } from './parse-raw-content-file';
8
- import { waitFor } from './utils/zone-wait-for';
9
- import { RenderTaskService } from './render-task.service';
10
- function getContentFile(contentFiles, prefix, slug, fallback, renderTaskService) {
11
- const filePath = `/src/content/${prefix}${slug}`;
12
- const contentFile = contentFiles[`${filePath}.md`] ?? contentFiles[`${filePath}.agx`];
13
- if (!contentFile) {
14
- return of({
15
- filename: filePath,
16
- attributes: {},
17
- slug: '',
18
- content: fallback,
19
- });
20
- }
21
- const contentTask = renderTaskService.addRenderTask();
22
- return new Observable((observer) => {
23
- const contentResolver = contentFile();
24
- if (import.meta.env.SSR === true) {
25
- waitFor(contentResolver).then((content) => {
26
- observer.next(content);
27
- observer.complete();
28
- setTimeout(() => renderTaskService.clearRenderTask(contentTask), 10);
29
- });
30
- }
31
- else {
32
- contentResolver.then((content) => {
33
- observer.next(content);
34
- observer.complete();
35
- });
36
- }
37
- }).pipe(map((contentFile) => {
38
- if (typeof contentFile === 'string') {
39
- const { content, attributes } = parseRawContentFile(contentFile);
40
- return {
41
- filename: filePath,
42
- slug,
43
- attributes,
44
- content,
45
- };
46
- }
47
- return {
48
- filename: filePath,
49
- slug,
50
- attributes: contentFile.metadata,
51
- content: contentFile.default,
52
- };
53
- }));
54
- }
55
- /**
56
- * Retrieves the static content using the provided param and/or prefix.
57
- *
58
- * @param param route parameter (default: 'slug')
59
- * @param fallback fallback text if content file is not found (default: 'No Content Found')
60
- */
61
- export function injectContent(param = 'slug', fallback = 'No Content Found') {
62
- const contentFiles = inject(CONTENT_FILES_TOKEN);
63
- const renderTaskService = inject(RenderTaskService);
64
- const task = renderTaskService.addRenderTask();
65
- if (typeof param === 'string' || 'param' in param) {
66
- const prefix = typeof param === 'string' ? '' : `${param.subdirectory}/`;
67
- const route = inject(ActivatedRoute);
68
- const paramKey = typeof param === 'string' ? param : param.param;
69
- return route.paramMap.pipe(map((params) => params.get(paramKey)), switchMap((slug) => {
70
- if (slug) {
71
- return getContentFile(contentFiles, prefix, slug, fallback, renderTaskService);
72
- }
73
- return of({
74
- filename: '',
75
- slug: '',
76
- attributes: {},
77
- content: fallback,
78
- });
79
- }), tap(() => renderTaskService.clearRenderTask(task)));
80
- }
81
- else {
82
- return getContentFile(contentFiles, '', param.customFilename, fallback, renderTaskService).pipe(tap(() => renderTaskService.clearRenderTask(task)));
83
- }
84
- }
85
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"content.js","sourceRoot":"","sources":["../../../../../packages/content/src/lib/content.ts"],"names":[],"mappings":"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","sourcesContent":["/// <reference types=\"vite/client\" />\n\nimport { inject } from '@angular/core';\nimport { ActivatedRoute } from '@angular/router';\nimport { Observable, of } from 'rxjs';\nimport { map, switchMap, tap } from 'rxjs/operators';\n\nimport { ContentFile } from './content-file';\nimport { CONTENT_FILES_TOKEN } from './content-files-token';\nimport { parseRawContentFile } from './parse-raw-content-file';\nimport { waitFor } from './utils/zone-wait-for';\nimport { RenderTaskService } from './render-task.service';\n\nfunction getContentFile<\n  Attributes extends Record<string, any> = Record<string, any>\n>(\n  contentFiles: Record<string, () => Promise<string>>,\n  prefix: string,\n  slug: string,\n  fallback: string,\n  renderTaskService: RenderTaskService\n): Observable<ContentFile<Attributes | Record<string, never>>> {\n  const filePath = `/src/content/${prefix}${slug}`;\n  const contentFile =\n    contentFiles[`${filePath}.md`] ?? contentFiles[`${filePath}.agx`];\n  if (!contentFile) {\n    return of({\n      filename: filePath,\n      attributes: {},\n      slug: '',\n      content: fallback,\n    });\n  }\n\n  const contentTask = renderTaskService.addRenderTask();\n  return new Observable<string | { default: any; metadata: any }>(\n    (observer) => {\n      const contentResolver = contentFile();\n\n      if (import.meta.env.SSR === true) {\n        waitFor(contentResolver).then((content) => {\n          observer.next(content);\n          observer.complete();\n\n          setTimeout(() => renderTaskService.clearRenderTask(contentTask), 10);\n        });\n      } else {\n        contentResolver.then((content) => {\n          observer.next(content);\n          observer.complete();\n        });\n      }\n    }\n  ).pipe(\n    map((contentFile) => {\n      if (typeof contentFile === 'string') {\n        const { content, attributes } =\n          parseRawContentFile<Attributes>(contentFile);\n\n        return {\n          filename: filePath,\n          slug,\n          attributes,\n          content,\n        };\n      }\n      return {\n        filename: filePath,\n        slug,\n        attributes: contentFile.metadata,\n        content: contentFile.default,\n      };\n    })\n  );\n}\n\n/**\n * Retrieves the static content using the provided param and/or prefix.\n *\n * @param param route parameter (default: 'slug')\n * @param fallback fallback text if content file is not found (default: 'No Content Found')\n */\nexport function injectContent<\n  Attributes extends Record<string, any> = Record<string, any>\n>(\n  param:\n    | string\n    | {\n        param: string;\n        subdirectory: string;\n      }\n    | {\n        customFilename: string;\n      } = 'slug',\n  fallback = 'No Content Found'\n): Observable<ContentFile<Attributes | Record<string, never>>> {\n  const contentFiles = inject(CONTENT_FILES_TOKEN);\n  const renderTaskService = inject(RenderTaskService);\n  const task = renderTaskService.addRenderTask();\n\n  if (typeof param === 'string' || 'param' in param) {\n    const prefix = typeof param === 'string' ? '' : `${param.subdirectory}/`;\n    const route = inject(ActivatedRoute);\n    const paramKey = typeof param === 'string' ? param : param.param;\n    return route.paramMap.pipe(\n      map((params) => params.get(paramKey)),\n      switchMap((slug) => {\n        if (slug) {\n          return getContentFile<Attributes>(\n            contentFiles,\n            prefix,\n            slug,\n            fallback,\n            renderTaskService\n          );\n        }\n        return of({\n          filename: '',\n          slug: '',\n          attributes: {},\n          content: fallback,\n        });\n      }),\n      tap(() => renderTaskService.clearRenderTask(task))\n    );\n  } else {\n    return getContentFile<Attributes>(\n      contentFiles,\n      '',\n      param.customFilename,\n      fallback,\n      renderTaskService\n    ).pipe(tap(() => renderTaskService.clearRenderTask(task)));\n  }\n}\n"]}
@@ -1,25 +0,0 @@
1
- /**
2
- * Returns the list of content files by filename with ?analog-content-list=true.
3
- * We use the query param to transform the return into an array of
4
- * just front matter attributes.
5
- *
6
- * @returns
7
- */
8
- export const getContentFilesList = () => {
9
- let ANALOG_CONTENT_FILE_LIST = {};
10
- return ANALOG_CONTENT_FILE_LIST;
11
- };
12
- /**
13
- * Returns the lazy loaded content files for lookups.
14
- *
15
- * @returns
16
- */
17
- export const getContentFiles = () => {
18
- let ANALOG_CONTENT_ROUTE_FILES = {};
19
- return ANALOG_CONTENT_ROUTE_FILES;
20
- };
21
- export const getAgxFiles = () => {
22
- let ANALOG_AGX_FILES = {};
23
- return ANALOG_AGX_FILES;
24
- };
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LWNvbnRlbnQtZmlsZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb250ZW50L3NyYy9saWIvZ2V0LWNvbnRlbnQtZmlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBQ0gsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQUcsR0FBRyxFQUFFO0lBQ3RDLElBQUksd0JBQXdCLEdBQUcsRUFBRSxDQUFDO0lBRWxDLE9BQU8sd0JBQStELENBQUM7QUFDekUsQ0FBQyxDQUFDO0FBRUY7Ozs7R0FJRztBQUNILE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRyxHQUFHLEVBQUU7SUFDbEMsSUFBSSwwQkFBMEIsR0FBRyxFQUFFLENBQUM7SUFFcEMsT0FBTywwQkFBMEIsQ0FBQztBQUNwQyxDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxXQUFXLEdBQUcsR0FBRyxFQUFFO0lBQzlCLElBQUksZ0JBQWdCLEdBQUcsRUFBRSxDQUFDO0lBRTFCLE9BQU8sZ0JBQWdCLENBQUM7QUFDMUIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBSZXR1cm5zIHRoZSBsaXN0IG9mIGNvbnRlbnQgZmlsZXMgYnkgZmlsZW5hbWUgd2l0aCA/YW5hbG9nLWNvbnRlbnQtbGlzdD10cnVlLlxuICogV2UgdXNlIHRoZSBxdWVyeSBwYXJhbSB0byB0cmFuc2Zvcm0gdGhlIHJldHVybiBpbnRvIGFuIGFycmF5IG9mXG4gKiBqdXN0IGZyb250IG1hdHRlciBhdHRyaWJ1dGVzLlxuICpcbiAqIEByZXR1cm5zXG4gKi9cbmV4cG9ydCBjb25zdCBnZXRDb250ZW50RmlsZXNMaXN0ID0gKCkgPT4ge1xuICBsZXQgQU5BTE9HX0NPTlRFTlRfRklMRV9MSVNUID0ge307XG5cbiAgcmV0dXJuIEFOQUxPR19DT05URU5UX0ZJTEVfTElTVCBhcyBSZWNvcmQ8c3RyaW5nLCBSZWNvcmQ8c3RyaW5nLCBhbnk+Pjtcbn07XG5cbi8qKlxuICogUmV0dXJucyB0aGUgbGF6eSBsb2FkZWQgY29udGVudCBmaWxlcyBmb3IgbG9va3Vwcy5cbiAqXG4gKiBAcmV0dXJuc1xuICovXG5leHBvcnQgY29uc3QgZ2V0Q29udGVudEZpbGVzID0gKCkgPT4ge1xuICBsZXQgQU5BTE9HX0NPTlRFTlRfUk9VVEVfRklMRVMgPSB7fTtcblxuICByZXR1cm4gQU5BTE9HX0NPTlRFTlRfUk9VVEVfRklMRVM7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0QWd4RmlsZXMgPSAoKSA9PiB7XG4gIGxldCBBTkFMT0dfQUdYX0ZJTEVTID0ge307XG5cbiAgcmV0dXJuIEFOQUxPR19BR1hfRklMRVM7XG59O1xuIl19
@@ -1,15 +0,0 @@
1
- import { inject } from '@angular/core';
2
- import { CONTENT_FILES_LIST_TOKEN } from './content-files-list-token';
3
- import { RenderTaskService } from './render-task.service';
4
- export function injectContentFiles(filterFn) {
5
- const renderTaskService = inject(RenderTaskService);
6
- const task = renderTaskService.addRenderTask();
7
- const allContentFiles = inject(CONTENT_FILES_LIST_TOKEN);
8
- renderTaskService.clearRenderTask(task);
9
- if (filterFn) {
10
- const filteredContentFiles = allContentFiles.filter(filterFn);
11
- return filteredContentFiles;
12
- }
13
- return allContentFiles;
14
- }
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5qZWN0LWNvbnRlbnQtZmlsZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb250ZW50L3NyYy9saWIvaW5qZWN0LWNvbnRlbnQtZmlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUN0RSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUUxRCxNQUFNLFVBQVUsa0JBQWtCLENBQ2hDLFFBQXVEO0lBRXZELE1BQU0saUJBQWlCLEdBQUcsTUFBTSxDQUFDLGlCQUFpQixDQUFDLENBQUM7SUFDcEQsTUFBTSxJQUFJLEdBQUcsaUJBQWlCLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDL0MsTUFBTSxlQUFlLEdBQUcsTUFBTSxDQUM1Qix3QkFBd0IsQ0FDSSxDQUFDO0lBQy9CLGlCQUFpQixDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUV4QyxJQUFJLFFBQVEsRUFBRSxDQUFDO1FBQ2IsTUFBTSxvQkFBb0IsR0FBRyxlQUFlLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRTlELE9BQU8sb0JBQW9CLENBQUM7SUFDOUIsQ0FBQztJQUVELE9BQU8sZUFBZSxDQUFDO0FBQ3pCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb250ZW50RmlsZSB9IGZyb20gJy4vY29udGVudC1maWxlJztcbmltcG9ydCB7IGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ09OVEVOVF9GSUxFU19MSVNUX1RPS0VOIH0gZnJvbSAnLi9jb250ZW50LWZpbGVzLWxpc3QtdG9rZW4nO1xuaW1wb3J0IHsgUmVuZGVyVGFza1NlcnZpY2UgfSBmcm9tICcuL3JlbmRlci10YXNrLnNlcnZpY2UnO1xuXG5leHBvcnQgZnVuY3Rpb24gaW5qZWN0Q29udGVudEZpbGVzPEF0dHJpYnV0ZXMgZXh0ZW5kcyBSZWNvcmQ8c3RyaW5nLCBhbnk+PihcbiAgZmlsdGVyRm4/OiBJbmplY3RDb250ZW50RmlsZXNGaWx0ZXJGdW5jdGlvbjxBdHRyaWJ1dGVzPlxuKTogQ29udGVudEZpbGU8QXR0cmlidXRlcz5bXSB7XG4gIGNvbnN0IHJlbmRlclRhc2tTZXJ2aWNlID0gaW5qZWN0KFJlbmRlclRhc2tTZXJ2aWNlKTtcbiAgY29uc3QgdGFzayA9IHJlbmRlclRhc2tTZXJ2aWNlLmFkZFJlbmRlclRhc2soKTtcbiAgY29uc3QgYWxsQ29udGVudEZpbGVzID0gaW5qZWN0KFxuICAgIENPTlRFTlRfRklMRVNfTElTVF9UT0tFTlxuICApIGFzIENvbnRlbnRGaWxlPEF0dHJpYnV0ZXM+W107XG4gIHJlbmRlclRhc2tTZXJ2aWNlLmNsZWFyUmVuZGVyVGFzayh0YXNrKTtcblxuICBpZiAoZmlsdGVyRm4pIHtcbiAgICBjb25zdCBmaWx0ZXJlZENvbnRlbnRGaWxlcyA9IGFsbENvbnRlbnRGaWxlcy5maWx0ZXIoZmlsdGVyRm4pO1xuXG4gICAgcmV0dXJuIGZpbHRlcmVkQ29udGVudEZpbGVzO1xuICB9XG5cbiAgcmV0dXJuIGFsbENvbnRlbnRGaWxlcztcbn1cblxuZXhwb3J0IHR5cGUgSW5qZWN0Q29udGVudEZpbGVzRmlsdGVyRnVuY3Rpb248VCBleHRlbmRzIFJlY29yZDxzdHJpbmcsIGFueT4+ID0gKFxuICB2YWx1ZTogQ29udGVudEZpbGU8VD4sXG4gIGluZGV4OiBudW1iZXIsXG4gIGFycmF5OiBDb250ZW50RmlsZTxUPltdXG4pID0+IGJvb2xlYW47XG4iXX0=
@@ -1,24 +0,0 @@
1
- import { inject, Injectable } from '@angular/core';
2
- import { getHeadingList } from 'marked-gfm-heading-id';
3
- import { MarkedSetupService } from './marked-setup.service';
4
- import * as i0 from "@angular/core";
5
- export class MarkdownContentRendererService {
6
- #marked = inject(MarkedSetupService, { self: true });
7
- async render(content) {
8
- return this.#marked.getMarkedInstance().parse(content);
9
- }
10
- /**
11
- * The method is meant to be called after `render()`
12
- */
13
- getContentHeadings() {
14
- return getHeadingList();
15
- }
16
- // eslint-disable-next-line
17
- enhance() { }
18
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: MarkdownContentRendererService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
19
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: MarkdownContentRendererService }); }
20
- }
21
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: MarkdownContentRendererService, decorators: [{
22
- type: Injectable
23
- }] });
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFya2Rvd24tY29udGVudC1yZW5kZXJlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29udGVudC9zcmMvbGliL21hcmtkb3duLWNvbnRlbnQtcmVuZGVyZXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFHdkQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7O0FBRzVELE1BQU0sT0FBTyw4QkFBOEI7SUFDekMsT0FBTyxHQUFHLE1BQU0sQ0FBQyxrQkFBa0IsRUFBRSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0lBRXJELEtBQUssQ0FBQyxNQUFNLENBQUMsT0FBZTtRQUMxQixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsaUJBQWlCLEVBQUUsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDekQsQ0FBQztJQUVEOztPQUVHO0lBQ0gsa0JBQWtCO1FBQ2hCLE9BQU8sY0FBYyxFQUFFLENBQUM7SUFDMUIsQ0FBQztJQUVELDJCQUEyQjtJQUMzQixPQUFPLEtBQUksQ0FBQzs4R0FmRCw4QkFBOEI7a0hBQTlCLDhCQUE4Qjs7MkZBQTlCLDhCQUE4QjtrQkFEMUMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGluamVjdCwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgZ2V0SGVhZGluZ0xpc3QgfSBmcm9tICdtYXJrZWQtZ2ZtLWhlYWRpbmctaWQnO1xuXG5pbXBvcnQgeyBDb250ZW50UmVuZGVyZXIsIFRhYmxlT2ZDb250ZW50SXRlbSB9IGZyb20gJy4vY29udGVudC1yZW5kZXJlcic7XG5pbXBvcnQgeyBNYXJrZWRTZXR1cFNlcnZpY2UgfSBmcm9tICcuL21hcmtlZC1zZXR1cC5zZXJ2aWNlJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIE1hcmtkb3duQ29udGVudFJlbmRlcmVyU2VydmljZSBpbXBsZW1lbnRzIENvbnRlbnRSZW5kZXJlciB7XG4gICNtYXJrZWQgPSBpbmplY3QoTWFya2VkU2V0dXBTZXJ2aWNlLCB7IHNlbGY6IHRydWUgfSk7XG5cbiAgYXN5bmMgcmVuZGVyKGNvbnRlbnQ6IHN0cmluZyk6IFByb21pc2U8c3RyaW5nPiB7XG4gICAgcmV0dXJuIHRoaXMuI21hcmtlZC5nZXRNYXJrZWRJbnN0YW5jZSgpLnBhcnNlKGNvbnRlbnQpO1xuICB9XG5cbiAgLyoqXG4gICAqIFRoZSBtZXRob2QgaXMgbWVhbnQgdG8gYmUgY2FsbGVkIGFmdGVyIGByZW5kZXIoKWBcbiAgICovXG4gIGdldENvbnRlbnRIZWFkaW5ncygpOiBUYWJsZU9mQ29udGVudEl0ZW1bXSB7XG4gICAgcmV0dXJuIGdldEhlYWRpbmdMaXN0KCk7XG4gIH1cblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmVcbiAgZW5oYW5jZSgpIHt9XG59XG4iXX0=
@@ -1,37 +0,0 @@
1
- import { AsyncPipe } from '@angular/common';
2
- import { Component, inject, Input, ViewEncapsulation, } from '@angular/core';
3
- import { DomSanitizer } from '@angular/platform-browser';
4
- import { ActivatedRoute } from '@angular/router';
5
- import { ContentRenderer } from './content-renderer';
6
- import { AnchorNavigationDirective } from './anchor-navigation.directive';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "./anchor-navigation.directive";
9
- export default class AnalogMarkdownRouteComponent {
10
- constructor() {
11
- this.sanitizer = inject(DomSanitizer);
12
- this.route = inject(ActivatedRoute);
13
- this.contentRenderer = inject(ContentRenderer);
14
- this.content = this.sanitizer.bypassSecurityTrustHtml(this.route.snapshot.data['renderedAnalogContent']);
15
- this.classes = 'analog-markdown-route';
16
- }
17
- ngAfterViewChecked() {
18
- this.contentRenderer.enhance();
19
- }
20
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: AnalogMarkdownRouteComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
21
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.4", type: AnalogMarkdownRouteComponent, isStandalone: true, selector: "analog-markdown-route", inputs: { classes: "classes" }, hostDirectives: [{ directive: i1.AnchorNavigationDirective }], ngImport: i0, template: `<div [innerHTML]="content" [class]="classes"></div>`, isInline: true, encapsulation: i0.ViewEncapsulation.None, preserveWhitespaces: true }); }
22
- }
23
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: AnalogMarkdownRouteComponent, decorators: [{
24
- type: Component,
25
- args: [{
26
- selector: 'analog-markdown-route',
27
- standalone: true,
28
- imports: [AsyncPipe],
29
- hostDirectives: [AnchorNavigationDirective],
30
- preserveWhitespaces: true,
31
- encapsulation: ViewEncapsulation.None,
32
- template: `<div [innerHTML]="content" [class]="classes"></div>`,
33
- }]
34
- }], propDecorators: { classes: [{
35
- type: Input
36
- }] } });
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFya2Rvd24tcm91dGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29udGVudC9zcmMvbGliL21hcmtkb3duLXJvdXRlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDNUMsT0FBTyxFQUVMLFNBQVMsRUFDVCxNQUFNLEVBQ04sS0FBSyxFQUNMLGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsWUFBWSxFQUFZLE1BQU0sMkJBQTJCLENBQUM7QUFDbkUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRWpELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQzs7O0FBVzFFLE1BQU0sQ0FBQyxPQUFPLE9BQU8sNEJBQTRCO0lBVGpEO1FBVVUsY0FBUyxHQUFHLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUNqQyxVQUFLLEdBQUcsTUFBTSxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBQ3ZDLG9CQUFlLEdBQUcsTUFBTSxDQUFDLGVBQWUsQ0FBQyxDQUFDO1FBRWhDLFlBQU8sR0FBYSxJQUFJLENBQUMsU0FBUyxDQUFDLHVCQUF1QixDQUNsRSxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsdUJBQXVCLENBQUMsQ0FDbEQsQ0FBQztRQUVPLFlBQU8sR0FBRyx1QkFBdUIsQ0FBQztLQUs1QztJQUhDLGtCQUFrQjtRQUNoQixJQUFJLENBQUMsZUFBZSxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ2pDLENBQUM7OEdBYmtCLDRCQUE0QjtrR0FBNUIsNEJBQTRCLGdMQUZyQyxxREFBcUQ7OzJGQUU1Qyw0QkFBNEI7a0JBVGhELFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHVCQUF1QjtvQkFDakMsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLE9BQU8sRUFBRSxDQUFDLFNBQVMsQ0FBQztvQkFDcEIsY0FBYyxFQUFFLENBQUMseUJBQXlCLENBQUM7b0JBQzNDLG1CQUFtQixFQUFFLElBQUk7b0JBQ3pCLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO29CQUNyQyxRQUFRLEVBQUUscURBQXFEO2lCQUNoRTs4QkFVVSxPQUFPO3NCQUFmLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBc3luY1BpcGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtcbiAgQWZ0ZXJWaWV3Q2hlY2tlZCxcbiAgQ29tcG9uZW50LFxuICBpbmplY3QsXG4gIElucHV0LFxuICBWaWV3RW5jYXBzdWxhdGlvbixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEb21TYW5pdGl6ZXIsIFNhZmVIdG1sIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XG5pbXBvcnQgeyBBY3RpdmF0ZWRSb3V0ZSB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5cbmltcG9ydCB7IENvbnRlbnRSZW5kZXJlciB9IGZyb20gJy4vY29udGVudC1yZW5kZXJlcic7XG5pbXBvcnQgeyBBbmNob3JOYXZpZ2F0aW9uRGlyZWN0aXZlIH0gZnJvbSAnLi9hbmNob3ItbmF2aWdhdGlvbi5kaXJlY3RpdmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhbmFsb2ctbWFya2Rvd24tcm91dGUnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQXN5bmNQaXBlXSxcbiAgaG9zdERpcmVjdGl2ZXM6IFtBbmNob3JOYXZpZ2F0aW9uRGlyZWN0aXZlXSxcbiAgcHJlc2VydmVXaGl0ZXNwYWNlczogdHJ1ZSxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgdGVtcGxhdGU6IGA8ZGl2IFtpbm5lckhUTUxdPVwiY29udGVudFwiIFtjbGFzc109XCJjbGFzc2VzXCI+PC9kaXY+YCxcbn0pXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBBbmFsb2dNYXJrZG93blJvdXRlQ29tcG9uZW50IGltcGxlbWVudHMgQWZ0ZXJWaWV3Q2hlY2tlZCB7XG4gIHByaXZhdGUgc2FuaXRpemVyID0gaW5qZWN0KERvbVNhbml0aXplcik7XG4gIHByaXZhdGUgcm91dGUgPSBpbmplY3QoQWN0aXZhdGVkUm91dGUpO1xuICBjb250ZW50UmVuZGVyZXIgPSBpbmplY3QoQ29udGVudFJlbmRlcmVyKTtcblxuICBwcm90ZWN0ZWQgY29udGVudDogU2FmZUh0bWwgPSB0aGlzLnNhbml0aXplci5ieXBhc3NTZWN1cml0eVRydXN0SHRtbChcbiAgICB0aGlzLnJvdXRlLnNuYXBzaG90LmRhdGFbJ3JlbmRlcmVkQW5hbG9nQ29udGVudCddXG4gICk7XG5cbiAgQElucHV0KCkgY2xhc3NlcyA9ICdhbmFsb2ctbWFya2Rvd24tcm91dGUnO1xuXG4gIG5nQWZ0ZXJWaWV3Q2hlY2tlZCgpIHtcbiAgICB0aGlzLmNvbnRlbnRSZW5kZXJlci5lbmhhbmNlKCk7XG4gIH1cbn1cbiJdfQ==
@@ -1,100 +0,0 @@
1
- import { AsyncPipe, isPlatformBrowser } from '@angular/common';
2
- import { Component, Input, NgZone, PLATFORM_ID, ViewChild, ViewContainerRef, ViewEncapsulation, inject, } from '@angular/core';
3
- import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
- import { DomSanitizer } from '@angular/platform-browser';
5
- import { ActivatedRoute } from '@angular/router';
6
- import { from, of } from 'rxjs';
7
- import { catchError, map, mergeMap, filter } from 'rxjs/operators';
8
- import { AnchorNavigationDirective } from './anchor-navigation.directive';
9
- import { ContentRenderer } from './content-renderer';
10
- import { MERMAID_IMPORT_TOKEN } from './provide-content';
11
- import * as i0 from "@angular/core";
12
- import * as i1 from "./anchor-navigation.directive";
13
- export default class AnalogMarkdownComponent {
14
- constructor() {
15
- this.sanitizer = inject(DomSanitizer);
16
- this.route = inject(ActivatedRoute);
17
- this.zone = inject(NgZone);
18
- this.platformId = inject(PLATFORM_ID);
19
- this.mermaidImport = inject(MERMAID_IMPORT_TOKEN, {
20
- optional: true,
21
- });
22
- this.content$ = this.getContentSource();
23
- this.classes = 'analog-markdown';
24
- this.contentRenderer = inject(ContentRenderer);
25
- if (isPlatformBrowser(this.platformId) && this.mermaidImport) {
26
- // Mermaid can only be loaded on client side
27
- this.loadMermaid(this.mermaidImport);
28
- }
29
- }
30
- ngOnInit() {
31
- this.updateContent();
32
- }
33
- ngOnChanges() {
34
- this.updateContent();
35
- }
36
- updateContent() {
37
- if (this.content && typeof this.content !== 'string') {
38
- this.container.clear();
39
- const componentRef = this.container.createComponent(this.content);
40
- componentRef.changeDetectorRef.detectChanges();
41
- }
42
- else {
43
- this.content$ = this.getContentSource();
44
- }
45
- }
46
- getContentSource() {
47
- return this.route.data.pipe(map((data) => this.content ?? data['_analogContent']), filter((content) => typeof content === 'string'), mergeMap((contentString) => this.renderContent(contentString)), map((content) => this.sanitizer.bypassSecurityTrustHtml(content)), catchError((e) => of(`There was an error ${e}`)));
48
- }
49
- async renderContent(content) {
50
- return this.contentRenderer.render(content);
51
- }
52
- ngAfterViewChecked() {
53
- this.contentRenderer.enhance();
54
- this.zone.runOutsideAngular(() => this.mermaid?.default.run());
55
- }
56
- loadMermaid(mermaidImport) {
57
- this.zone.runOutsideAngular(() =>
58
- // Wrap into an observable to avoid redundant initialization once
59
- // the markdown component is destroyed before the promise is resolved.
60
- from(mermaidImport)
61
- .pipe(takeUntilDestroyed())
62
- .subscribe((mermaid) => {
63
- this.mermaid = mermaid;
64
- this.mermaid.default.initialize({ startOnLoad: false });
65
- // Explicitly running mermaid as ngAfterViewChecked
66
- // has probably already been called
67
- this.mermaid?.default.run();
68
- }));
69
- }
70
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: AnalogMarkdownComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
71
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.4", type: AnalogMarkdownComponent, isStandalone: true, selector: "analog-markdown", inputs: { content: "content", classes: "classes" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true, read: ViewContainerRef, static: true }], usesOnChanges: true, hostDirectives: [{ directive: i1.AnchorNavigationDirective }], ngImport: i0, template: `<div
72
- #container
73
- [innerHTML]="content$ | async"
74
- [class]="classes"
75
- ></div>`, isInline: true, dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }], encapsulation: i0.ViewEncapsulation.None, preserveWhitespaces: true }); }
76
- }
77
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: AnalogMarkdownComponent, decorators: [{
78
- type: Component,
79
- args: [{
80
- selector: 'analog-markdown',
81
- standalone: true,
82
- imports: [AsyncPipe],
83
- hostDirectives: [AnchorNavigationDirective],
84
- preserveWhitespaces: true,
85
- encapsulation: ViewEncapsulation.None,
86
- template: `<div
87
- #container
88
- [innerHTML]="content$ | async"
89
- [class]="classes"
90
- ></div>`,
91
- }]
92
- }], ctorParameters: () => [], propDecorators: { content: [{
93
- type: Input
94
- }], classes: [{
95
- type: Input
96
- }], container: [{
97
- type: ViewChild,
98
- args: ['container', { static: true, read: ViewContainerRef }]
99
- }] } });
100
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"markdown.component.js","sourceRoot":"","sources":["../../../../../packages/content/src/lib/markdown.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AsyncPipe, isPlatformBrowser } from '@angular/common';\nimport {\n  AfterViewChecked,\n  Component,\n  Input,\n  NgZone,\n  OnChanges,\n  OnInit,\n  PLATFORM_ID,\n  ViewChild,\n  ViewContainerRef,\n  ViewEncapsulation,\n  inject,\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { ActivatedRoute, Data } from '@angular/router';\nimport { Observable, from, of } from 'rxjs';\nimport { catchError, map, mergeMap, filter } from 'rxjs/operators';\n\nimport { AnchorNavigationDirective } from './anchor-navigation.directive';\nimport { ContentRenderer } from './content-renderer';\nimport { MERMAID_IMPORT_TOKEN } from './provide-content';\n\n@Component({\n  selector: 'analog-markdown',\n  standalone: true,\n  imports: [AsyncPipe],\n  hostDirectives: [AnchorNavigationDirective],\n  preserveWhitespaces: true,\n  encapsulation: ViewEncapsulation.None,\n  template: `<div\n    #container\n    [innerHTML]=\"content$ | async\"\n    [class]=\"classes\"\n  ></div>`,\n})\nexport default class AnalogMarkdownComponent\n  implements OnInit, OnChanges, AfterViewChecked\n{\n  private sanitizer = inject(DomSanitizer);\n  private route = inject(ActivatedRoute);\n  private zone = inject(NgZone);\n  private readonly platformId = inject(PLATFORM_ID);\n  private readonly mermaidImport = inject(MERMAID_IMPORT_TOKEN, {\n    optional: true,\n  });\n  private mermaid: typeof import('mermaid') | undefined;\n\n  public content$: Observable<SafeHtml> = this.getContentSource();\n\n  @Input() content!: string | object | undefined | null;\n  @Input() classes = 'analog-markdown';\n\n  @ViewChild('container', { static: true, read: ViewContainerRef })\n  container!: ViewContainerRef;\n\n  contentRenderer = inject(ContentRenderer);\n\n  constructor() {\n    if (isPlatformBrowser(this.platformId) && this.mermaidImport) {\n      // Mermaid can only be loaded on client side\n      this.loadMermaid(this.mermaidImport);\n    }\n  }\n\n  ngOnInit(): void {\n    this.updateContent();\n  }\n\n  ngOnChanges(): void {\n    this.updateContent();\n  }\n\n  updateContent() {\n    if (this.content && typeof this.content !== 'string') {\n      this.container.clear();\n      const componentRef = this.container.createComponent(this.content as any);\n      componentRef.changeDetectorRef.detectChanges();\n    } else {\n      this.content$ = this.getContentSource();\n    }\n  }\n\n  getContentSource() {\n    return this.route.data.pipe(\n      map<Data, string>((data) => this.content ?? data['_analogContent']),\n      filter((content) => typeof content === 'string'),\n      mergeMap((contentString) => this.renderContent(contentString)),\n      map((content) => this.sanitizer.bypassSecurityTrustHtml(content)),\n      catchError((e) => of(`There was an error ${e}`))\n    );\n  }\n\n  async renderContent(content: string): Promise<string> {\n    return this.contentRenderer.render(content);\n  }\n\n  ngAfterViewChecked() {\n    this.contentRenderer.enhance();\n    this.zone.runOutsideAngular(() => this.mermaid?.default.run());\n  }\n\n  private loadMermaid(mermaidImport: Promise<typeof import('mermaid')>) {\n    this.zone.runOutsideAngular(() =>\n      // Wrap into an observable to avoid redundant initialization once\n      // the markdown component is destroyed before the promise is resolved.\n      from(mermaidImport)\n        .pipe(takeUntilDestroyed())\n        .subscribe((mermaid) => {\n          this.mermaid = mermaid;\n          this.mermaid.default.initialize({ startOnLoad: false });\n          // Explicitly running mermaid as ngAfterViewChecked\n          // has probably already been called\n          this.mermaid?.default.run();\n        })\n    );\n  }\n}\n"]}
@@ -1,13 +0,0 @@
1
- import { Injectable, } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export class MarkedContentHighlighter {
4
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: MarkedContentHighlighter, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
5
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: MarkedContentHighlighter }); }
6
- }
7
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: MarkedContentHighlighter, decorators: [{
8
- type: Injectable
9
- }] });
10
- export function withHighlighter(provider) {
11
- return { provide: MarkedContentHighlighter, ...provider };
12
- }
13
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFya2VkLWNvbnRlbnQtaGlnaGxpZ2h0ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb250ZW50L3NyYy9saWIvbWFya2VkLWNvbnRlbnQtaGlnaGxpZ2h0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLFVBQVUsR0FJWCxNQUFNLGVBQWUsQ0FBQzs7QUFPdkIsTUFBTSxPQUFnQix3QkFBd0I7OEdBQXhCLHdCQUF3QjtrSEFBeEIsd0JBQXdCOzsyRkFBeEIsd0JBQXdCO2tCQUQ3QyxVQUFVOztBQUtYLE1BQU0sVUFBVSxlQUFlLENBQzdCLFFBUW1DO0lBRW5DLE9BQU8sRUFBRSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsR0FBRyxRQUFRLEVBQWMsQ0FBQztBQUN4RSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQWJzdHJhY3RUeXBlLFxuICBJbmplY3RhYmxlLFxuICBQcm92aWRlcixcbiAgUHJvdmlkZXJUb2tlbixcbiAgVHlwZSxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWFya2VkQ29udGVudEhpZ2hsaWdodGVyIHtcbiAgYXVnbWVudENvZGVCbG9jaz8oY29kZTogc3RyaW5nLCBsYW5nOiBzdHJpbmcpOiBzdHJpbmc7XG59XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBNYXJrZWRDb250ZW50SGlnaGxpZ2h0ZXIge1xuICBhYnN0cmFjdCBnZXRIaWdobGlnaHRFeHRlbnNpb24oKTogaW1wb3J0KCdtYXJrZWQnKS5tYXJrZWQuTWFya2VkRXh0ZW5zaW9uO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gd2l0aEhpZ2hsaWdodGVyKFxuICBwcm92aWRlcjogKFxuICAgIHwgeyB1c2VWYWx1ZTogTWFya2VkQ29udGVudEhpZ2hsaWdodGVyIH1cbiAgICB8IHtcbiAgICAgICAgdXNlQ2xhc3M6XG4gICAgICAgICAgfCBUeXBlPE1hcmtlZENvbnRlbnRIaWdobGlnaHRlcj5cbiAgICAgICAgICB8IEFic3RyYWN0VHlwZTxNYXJrZWRDb250ZW50SGlnaGxpZ2h0ZXI+O1xuICAgICAgfVxuICAgIHwgeyB1c2VGYWN0b3J5OiAoLi4uZGVwczogYW55W10pID0+IE1hcmtlZENvbnRlbnRIaWdobGlnaHRlciB9XG4gICkgJiB7IGRlcHM/OiBQcm92aWRlclRva2VuPGFueT5bXSB9XG4pOiBQcm92aWRlciB7XG4gIHJldHVybiB7IHByb3ZpZGU6IE1hcmtlZENvbnRlbnRIaWdobGlnaHRlciwgLi4ucHJvdmlkZXIgfSBhcyBQcm92aWRlcjtcbn1cbiJdfQ==
@@ -1,53 +0,0 @@
1
- /**
2
- * Credit goes to Scully for original implementation
3
- * https://github.com/scullyio/scully/blob/main/libs/scully/src/lib/fileHanderPlugins/markdown.ts
4
- */
5
- import { inject, Injectable } from '@angular/core';
6
- import { marked } from 'marked';
7
- import { gfmHeadingId } from 'marked-gfm-heading-id';
8
- import { mangle } from 'marked-mangle';
9
- import { MarkedContentHighlighter } from './marked-content-highlighter';
10
- import * as i0 from "@angular/core";
11
- export class MarkedSetupService {
12
- constructor() {
13
- this.highlighter = inject(MarkedContentHighlighter, {
14
- optional: true,
15
- });
16
- const renderer = new marked.Renderer();
17
- renderer.code = (code, lang) => {
18
- // Let's do a language based detection like on GitHub
19
- // So we can still have non-interpreted mermaid code
20
- if (lang === 'mermaid') {
21
- return '<pre class="mermaid">' + code + '</pre>';
22
- }
23
- if (!lang) {
24
- return '<pre><code>' + code + '</code></pre>';
25
- }
26
- if (this.highlighter?.augmentCodeBlock) {
27
- return this.highlighter?.augmentCodeBlock(code, lang);
28
- }
29
- return `<pre class="language-${lang}"><code class="language-${lang}">${code}</code></pre>`;
30
- };
31
- const extensions = [gfmHeadingId(), mangle()];
32
- if (this.highlighter) {
33
- extensions.push(this.highlighter.getHighlightExtension());
34
- }
35
- marked.use(...extensions, {
36
- renderer,
37
- pedantic: false,
38
- gfm: true,
39
- breaks: false,
40
- mangle: false,
41
- });
42
- this.marked = marked;
43
- }
44
- getMarkedInstance() {
45
- return this.marked;
46
- }
47
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: MarkedSetupService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
48
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: MarkedSetupService }); }
49
- }
50
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: MarkedSetupService, decorators: [{
51
- type: Injectable
52
- }], ctorParameters: () => [] });
53
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFya2VkLXNldHVwLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb250ZW50L3NyYy9saWIvbWFya2VkLXNldHVwLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7OztHQUdHO0FBQ0gsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkQsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLFFBQVEsQ0FBQztBQUNoQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDckQsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQzs7QUFHeEUsTUFBTSxPQUFPLGtCQUFrQjtJQU03QjtRQUppQixnQkFBVyxHQUFHLE1BQU0sQ0FBQyx3QkFBd0IsRUFBRTtZQUM5RCxRQUFRLEVBQUUsSUFBSTtTQUNmLENBQUMsQ0FBQztRQUdELE1BQU0sUUFBUSxHQUFHLElBQUksTUFBTSxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ3ZDLFFBQVEsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxJQUFZLEVBQUUsSUFBWSxFQUFFLEVBQUU7WUFDN0MscURBQXFEO1lBQ3JELG9EQUFvRDtZQUNwRCxJQUFJLElBQUksS0FBSyxTQUFTLEVBQUUsQ0FBQztnQkFDdkIsT0FBTyx1QkFBdUIsR0FBRyxJQUFJLEdBQUcsUUFBUSxDQUFDO1lBQ25ELENBQUM7WUFFRCxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7Z0JBQ1YsT0FBTyxhQUFhLEdBQUcsSUFBSSxHQUFHLGVBQWUsQ0FBQztZQUNoRCxDQUFDO1lBRUQsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFLGdCQUFnQixFQUFFLENBQUM7Z0JBQ3ZDLE9BQU8sSUFBSSxDQUFDLFdBQVcsRUFBRSxnQkFBZ0IsQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUM7WUFDeEQsQ0FBQztZQUVELE9BQU8sd0JBQXdCLElBQUksMkJBQTJCLElBQUksS0FBSyxJQUFJLGVBQWUsQ0FBQztRQUM3RixDQUFDLENBQUM7UUFFRixNQUFNLFVBQVUsR0FBRyxDQUFDLFlBQVksRUFBRSxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7UUFFOUMsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDckIsVUFBVSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLHFCQUFxQixFQUFFLENBQUMsQ0FBQztRQUM1RCxDQUFDO1FBRUQsTUFBTSxDQUFDLEdBQUcsQ0FBQyxHQUFHLFVBQVUsRUFBRTtZQUN4QixRQUFRO1lBQ1IsUUFBUSxFQUFFLEtBQUs7WUFDZixHQUFHLEVBQUUsSUFBSTtZQUNULE1BQU0sRUFBRSxLQUFLO1lBQ2IsTUFBTSxFQUFFLEtBQUs7U0FDZCxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztJQUN2QixDQUFDO0lBRUQsaUJBQWlCO1FBQ2YsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDO0lBQ3JCLENBQUM7OEdBN0NVLGtCQUFrQjtrSEFBbEIsa0JBQWtCOzsyRkFBbEIsa0JBQWtCO2tCQUQ5QixVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDcmVkaXQgZ29lcyB0byBTY3VsbHkgZm9yIG9yaWdpbmFsIGltcGxlbWVudGF0aW9uXG4gKiBodHRwczovL2dpdGh1Yi5jb20vc2N1bGx5aW8vc2N1bGx5L2Jsb2IvbWFpbi9saWJzL3NjdWxseS9zcmMvbGliL2ZpbGVIYW5kZXJQbHVnaW5zL21hcmtkb3duLnRzXG4gKi9cbmltcG9ydCB7IGluamVjdCwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgbWFya2VkIH0gZnJvbSAnbWFya2VkJztcbmltcG9ydCB7IGdmbUhlYWRpbmdJZCB9IGZyb20gJ21hcmtlZC1nZm0taGVhZGluZy1pZCc7XG5pbXBvcnQgeyBtYW5nbGUgfSBmcm9tICdtYXJrZWQtbWFuZ2xlJztcbmltcG9ydCB7IE1hcmtlZENvbnRlbnRIaWdobGlnaHRlciB9IGZyb20gJy4vbWFya2VkLWNvbnRlbnQtaGlnaGxpZ2h0ZXInO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgTWFya2VkU2V0dXBTZXJ2aWNlIHtcbiAgcHJpdmF0ZSByZWFkb25seSBtYXJrZWQ6IHR5cGVvZiBtYXJrZWQ7XG4gIHByaXZhdGUgcmVhZG9ubHkgaGlnaGxpZ2h0ZXIgPSBpbmplY3QoTWFya2VkQ29udGVudEhpZ2hsaWdodGVyLCB7XG4gICAgb3B0aW9uYWw6IHRydWUsXG4gIH0pO1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIGNvbnN0IHJlbmRlcmVyID0gbmV3IG1hcmtlZC5SZW5kZXJlcigpO1xuICAgIHJlbmRlcmVyLmNvZGUgPSAoY29kZTogc3RyaW5nLCBsYW5nOiBzdHJpbmcpID0+IHtcbiAgICAgIC8vIExldCdzIGRvIGEgbGFuZ3VhZ2UgYmFzZWQgZGV0ZWN0aW9uIGxpa2Ugb24gR2l0SHViXG4gICAgICAvLyBTbyB3ZSBjYW4gc3RpbGwgaGF2ZSBub24taW50ZXJwcmV0ZWQgbWVybWFpZCBjb2RlXG4gICAgICBpZiAobGFuZyA9PT0gJ21lcm1haWQnKSB7XG4gICAgICAgIHJldHVybiAnPHByZSBjbGFzcz1cIm1lcm1haWRcIj4nICsgY29kZSArICc8L3ByZT4nO1xuICAgICAgfVxuXG4gICAgICBpZiAoIWxhbmcpIHtcbiAgICAgICAgcmV0dXJuICc8cHJlPjxjb2RlPicgKyBjb2RlICsgJzwvY29kZT48L3ByZT4nO1xuICAgICAgfVxuXG4gICAgICBpZiAodGhpcy5oaWdobGlnaHRlcj8uYXVnbWVudENvZGVCbG9jaykge1xuICAgICAgICByZXR1cm4gdGhpcy5oaWdobGlnaHRlcj8uYXVnbWVudENvZGVCbG9jayhjb2RlLCBsYW5nKTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIGA8cHJlIGNsYXNzPVwibGFuZ3VhZ2UtJHtsYW5nfVwiPjxjb2RlIGNsYXNzPVwibGFuZ3VhZ2UtJHtsYW5nfVwiPiR7Y29kZX08L2NvZGU+PC9wcmU+YDtcbiAgICB9O1xuXG4gICAgY29uc3QgZXh0ZW5zaW9ucyA9IFtnZm1IZWFkaW5nSWQoKSwgbWFuZ2xlKCldO1xuXG4gICAgaWYgKHRoaXMuaGlnaGxpZ2h0ZXIpIHtcbiAgICAgIGV4dGVuc2lvbnMucHVzaCh0aGlzLmhpZ2hsaWdodGVyLmdldEhpZ2hsaWdodEV4dGVuc2lvbigpKTtcbiAgICB9XG5cbiAgICBtYXJrZWQudXNlKC4uLmV4dGVuc2lvbnMsIHtcbiAgICAgIHJlbmRlcmVyLFxuICAgICAgcGVkYW50aWM6IGZhbHNlLFxuICAgICAgZ2ZtOiB0cnVlLFxuICAgICAgYnJlYWtzOiBmYWxzZSxcbiAgICAgIG1hbmdsZTogZmFsc2UsXG4gICAgfSk7XG5cbiAgICB0aGlzLm1hcmtlZCA9IG1hcmtlZDtcbiAgfVxuXG4gIGdldE1hcmtlZEluc3RhbmNlKCk6IHR5cGVvZiBtYXJrZWQge1xuICAgIHJldHVybiB0aGlzLm1hcmtlZDtcbiAgfVxufVxuIl19
@@ -1,6 +0,0 @@
1
- import fm from 'front-matter';
2
- export function parseRawContentFile(rawContentFile) {
3
- const { body, attributes } = fm(rawContentFile);
4
- return { content: body, attributes };
5
- }
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyc2UtcmF3LWNvbnRlbnQtZmlsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbnRlbnQvc3JjL2xpYi9wYXJzZS1yYXctY29udGVudC1maWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUU5QixNQUFNLFVBQVUsbUJBQW1CLENBQ2pDLGNBQXNCO0lBRXRCLE1BQU0sRUFBRSxJQUFJLEVBQUUsVUFBVSxFQUFFLEdBQUcsRUFBRSxDQUFhLGNBQWMsQ0FBQyxDQUFDO0lBQzVELE9BQU8sRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRSxDQUFDO0FBQ3ZDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgZm0gZnJvbSAnZnJvbnQtbWF0dGVyJztcblxuZXhwb3J0IGZ1bmN0aW9uIHBhcnNlUmF3Q29udGVudEZpbGU8QXR0cmlidXRlcyBleHRlbmRzIFJlY29yZDxzdHJpbmcsIGFueT4+KFxuICByYXdDb250ZW50RmlsZTogc3RyaW5nXG4pOiB7IGNvbnRlbnQ6IHN0cmluZzsgYXR0cmlidXRlczogQXR0cmlidXRlcyB9IHtcbiAgY29uc3QgeyBib2R5LCBhdHRyaWJ1dGVzIH0gPSBmbTxBdHRyaWJ1dGVzPihyYXdDb250ZW50RmlsZSk7XG4gIHJldHVybiB7IGNvbnRlbnQ6IGJvZHksIGF0dHJpYnV0ZXMgfTtcbn1cbiJdfQ==
@@ -1,30 +0,0 @@
1
- import { InjectionToken } from '@angular/core';
2
- import { ContentRenderer, NoopContentRenderer } from './content-renderer';
3
- import { RenderTaskService } from './render-task.service';
4
- const CONTENT_RENDERER_PROVIDERS = [
5
- {
6
- provide: ContentRenderer,
7
- useClass: NoopContentRenderer,
8
- },
9
- ];
10
- export function withMarkdownRenderer(options) {
11
- return [
12
- CONTENT_RENDERER_PROVIDERS,
13
- options?.loadMermaid
14
- ? [
15
- {
16
- provide: MERMAID_IMPORT_TOKEN,
17
- useFactory: options.loadMermaid,
18
- },
19
- ]
20
- : [],
21
- ];
22
- }
23
- export function provideContent(...features) {
24
- return [
25
- { provide: RenderTaskService, useClass: RenderTaskService },
26
- ...features,
27
- ];
28
- }
29
- export const MERMAID_IMPORT_TOKEN = new InjectionToken('mermaid_import');
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZS1jb250ZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29udGVudC9zcmMvbGliL3Byb3ZpZGUtY29udGVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQVksY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pELE9BQU8sRUFBRSxlQUFlLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUMxRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQU0xRCxNQUFNLDBCQUEwQixHQUFlO0lBQzdDO1FBQ0UsT0FBTyxFQUFFLGVBQWU7UUFDeEIsUUFBUSxFQUFFLG1CQUFtQjtLQUM5QjtDQUNGLENBQUM7QUFFRixNQUFNLFVBQVUsb0JBQW9CLENBQ2xDLE9BQWlDO0lBRWpDLE9BQU87UUFDTCwwQkFBMEI7UUFDMUIsT0FBTyxFQUFFLFdBQVc7WUFDbEIsQ0FBQyxDQUFDO2dCQUNFO29CQUNFLE9BQU8sRUFBRSxvQkFBb0I7b0JBQzdCLFVBQVUsRUFBRSxPQUFPLENBQUMsV0FBVztpQkFDaEM7YUFDRjtZQUNILENBQUMsQ0FBQyxFQUFFO0tBQ1AsQ0FBQztBQUNKLENBQUM7QUFFRCxNQUFNLFVBQVUsY0FBYyxDQUFDLEdBQUcsUUFBb0I7SUFDcEQsT0FBTztRQUNMLEVBQUUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLFFBQVEsRUFBRSxpQkFBaUIsRUFBRTtRQUMzRCxHQUFHLFFBQVE7S0FDWixDQUFDO0FBQ0osQ0FBQztBQUVELE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFHLElBQUksY0FBYyxDQUVwRCxnQkFBZ0IsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUHJvdmlkZXIsIEluamVjdGlvblRva2VuIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb250ZW50UmVuZGVyZXIsIE5vb3BDb250ZW50UmVuZGVyZXIgfSBmcm9tICcuL2NvbnRlbnQtcmVuZGVyZXInO1xuaW1wb3J0IHsgUmVuZGVyVGFza1NlcnZpY2UgfSBmcm9tICcuL3JlbmRlci10YXNrLnNlcnZpY2UnO1xuXG5leHBvcnQgaW50ZXJmYWNlIE1hcmtkb3duUmVuZGVyZXJPcHRpb25zIHtcbiAgbG9hZE1lcm1haWQ/OiAoKSA9PiBQcm9taXNlPHR5cGVvZiBpbXBvcnQoJ21lcm1haWQnKT47XG59XG5cbmNvbnN0IENPTlRFTlRfUkVOREVSRVJfUFJPVklERVJTOiBQcm92aWRlcltdID0gW1xuICB7XG4gICAgcHJvdmlkZTogQ29udGVudFJlbmRlcmVyLFxuICAgIHVzZUNsYXNzOiBOb29wQ29udGVudFJlbmRlcmVyLFxuICB9LFxuXTtcblxuZXhwb3J0IGZ1bmN0aW9uIHdpdGhNYXJrZG93blJlbmRlcmVyKFxuICBvcHRpb25zPzogTWFya2Rvd25SZW5kZXJlck9wdGlvbnNcbik6IFByb3ZpZGVyIHtcbiAgcmV0dXJuIFtcbiAgICBDT05URU5UX1JFTkRFUkVSX1BST1ZJREVSUyxcbiAgICBvcHRpb25zPy5sb2FkTWVybWFpZFxuICAgICAgPyBbXG4gICAgICAgICAge1xuICAgICAgICAgICAgcHJvdmlkZTogTUVSTUFJRF9JTVBPUlRfVE9LRU4sXG4gICAgICAgICAgICB1c2VGYWN0b3J5OiBvcHRpb25zLmxvYWRNZXJtYWlkLFxuICAgICAgICAgIH0sXG4gICAgICAgIF1cbiAgICAgIDogW10sXG4gIF07XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBwcm92aWRlQ29udGVudCguLi5mZWF0dXJlczogUHJvdmlkZXJbXSkge1xuICByZXR1cm4gW1xuICAgIHsgcHJvdmlkZTogUmVuZGVyVGFza1NlcnZpY2UsIHVzZUNsYXNzOiBSZW5kZXJUYXNrU2VydmljZSB9LFxuICAgIC4uLmZlYXR1cmVzLFxuICBdO1xufVxuXG5leHBvcnQgY29uc3QgTUVSTUFJRF9JTVBPUlRfVE9LRU4gPSBuZXcgSW5qZWN0aW9uVG9rZW48XG4gIFByb21pc2U8dHlwZW9mIGltcG9ydCgnbWVybWFpZCcpPlxuPignbWVybWFpZF9pbXBvcnQnKTtcbiJdfQ==
@@ -1,17 +0,0 @@
1
- import { Injectable, inject, ɵPendingTasks as PendingTasks, } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export class RenderTaskService {
4
- #pendingTasks = inject(PendingTasks);
5
- addRenderTask() {
6
- return this.#pendingTasks.add();
7
- }
8
- clearRenderTask(id) {
9
- this.#pendingTasks.remove(id);
10
- }
11
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: RenderTaskService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
12
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: RenderTaskService }); }
13
- }
14
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: RenderTaskService, decorators: [{
15
- type: Injectable
16
- }] });
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVuZGVyLXRhc2suc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbnRlbnQvc3JjL2xpYi9yZW5kZXItdGFzay5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxVQUFVLEVBQ1YsTUFBTSxFQUNOLGFBQWEsSUFBSSxZQUFZLEdBQzlCLE1BQU0sZUFBZSxDQUFDOztBQUd2QixNQUFNLE9BQU8saUJBQWlCO0lBQzVCLGFBQWEsR0FBRyxNQUFNLENBQUMsWUFBWSxDQUFDLENBQUM7SUFFckMsYUFBYTtRQUNYLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxHQUFHLEVBQUUsQ0FBQztJQUNsQyxDQUFDO0lBRUQsZUFBZSxDQUFDLEVBQVU7UUFDeEIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLENBQUM7SUFDaEMsQ0FBQzs4R0FUVSxpQkFBaUI7a0hBQWpCLGlCQUFpQjs7MkZBQWpCLGlCQUFpQjtrQkFEN0IsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEluamVjdGFibGUsXG4gIGluamVjdCxcbiAgybVQZW5kaW5nVGFza3MgYXMgUGVuZGluZ1Rhc2tzLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIFJlbmRlclRhc2tTZXJ2aWNlIHtcbiAgI3BlbmRpbmdUYXNrcyA9IGluamVjdChQZW5kaW5nVGFza3MpO1xuXG4gIGFkZFJlbmRlclRhc2soKSB7XG4gICAgcmV0dXJuIHRoaXMuI3BlbmRpbmdUYXNrcy5hZGQoKTtcbiAgfVxuXG4gIGNsZWFyUmVuZGVyVGFzayhpZDogbnVtYmVyKSB7XG4gICAgdGhpcy4jcGVuZGluZ1Rhc2tzLnJlbW92ZShpZCk7XG4gIH1cbn1cbiJdfQ==
@@ -1,15 +0,0 @@
1
- import { firstValueFrom, isObservable } from 'rxjs';
2
- export async function waitFor(prom) {
3
- if (isObservable(prom)) {
4
- prom = firstValueFrom(prom);
5
- }
6
- if (typeof Zone === 'undefined') {
7
- return prom;
8
- }
9
- const macroTask = Zone.current.scheduleMacroTask(`AnalogContentResolve-${Math.random()}`, () => { }, {}, () => { });
10
- return prom.then((p) => {
11
- macroTask.invoke();
12
- return p;
13
- });
14
- }
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiem9uZS13YWl0LWZvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbnRlbnQvc3JjL2xpYi91dGlscy96b25lLXdhaXQtZm9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsWUFBWSxFQUFjLE1BQU0sTUFBTSxDQUFDO0FBSWhFLE1BQU0sQ0FBQyxLQUFLLFVBQVUsT0FBTyxDQUFJLElBQWdDO0lBQy9ELElBQUksWUFBWSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUM7UUFDdkIsSUFBSSxHQUFHLGNBQWMsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUM5QixDQUFDO0lBRUQsSUFBSSxPQUFPLElBQUksS0FBSyxXQUFXLEVBQUUsQ0FBQztRQUNoQyxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFFRCxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLGlCQUFpQixDQUM5Qyx3QkFBd0IsSUFBSSxDQUFDLE1BQU0sRUFBRSxFQUFFLEVBQ3ZDLEdBQUcsRUFBRSxHQUFFLENBQUMsRUFDUixFQUFFLEVBQ0YsR0FBRyxFQUFFLEdBQUUsQ0FBQyxDQUNULENBQUM7SUFDRixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFJLEVBQUUsRUFBRTtRQUN4QixTQUFTLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDbkIsT0FBTyxDQUFDLENBQUM7SUFDWCxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmaXJzdFZhbHVlRnJvbSwgaXNPYnNlcnZhYmxlLCBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5cbmRlY2xhcmUgY29uc3QgWm9uZTogYW55O1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gd2FpdEZvcjxUPihwcm9tOiBQcm9taXNlPFQ+IHwgT2JzZXJ2YWJsZTxUPik6IFByb21pc2U8VD4ge1xuICBpZiAoaXNPYnNlcnZhYmxlKHByb20pKSB7XG4gICAgcHJvbSA9IGZpcnN0VmFsdWVGcm9tKHByb20pO1xuICB9XG5cbiAgaWYgKHR5cGVvZiBab25lID09PSAndW5kZWZpbmVkJykge1xuICAgIHJldHVybiBwcm9tO1xuICB9XG5cbiAgY29uc3QgbWFjcm9UYXNrID0gWm9uZS5jdXJyZW50LnNjaGVkdWxlTWFjcm9UYXNrKFxuICAgIGBBbmFsb2dDb250ZW50UmVzb2x2ZS0ke01hdGgucmFuZG9tKCl9YCxcbiAgICAoKSA9PiB7fSxcbiAgICB7fSxcbiAgICAoKSA9PiB7fVxuICApO1xuICByZXR1cm4gcHJvbS50aGVuKChwOiBUKSA9PiB7XG4gICAgbWFjcm9UYXNrLmludm9rZSgpO1xuICAgIHJldHVybiBwO1xuICB9KTtcbn1cbiJdfQ==
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './index';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5hbG9nanMtY29udGVudC1vZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbnRlbnQvb2cvc3JjL2FuYWxvZ2pzLWNvbnRlbnQtb2cudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
@@ -1,2 +0,0 @@
1
- export { ImageResponse } from './lib/og';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb250ZW50L29nL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sVUFBVSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgSW1hZ2VSZXNwb25zZSB9IGZyb20gJy4vbGliL29nJztcbmV4cG9ydCB7IEltYWdlUmVzcG9uc2VPcHRpb25zIH0gZnJvbSAnLi9saWIvb3B0aW9ucyc7XG4iXX0=