@covalent/markdown 4.0.0 → 4.1.1-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 (37) hide show
  1. package/README.md +20 -20
  2. package/covalent-markdown.d.ts +2 -1
  3. package/esm2020/covalent-markdown.mjs +5 -0
  4. package/esm2020/lib/markdown-loader/markdown-loader.service.mjs +41 -0
  5. package/esm2020/lib/markdown-utils/markdown-utils.mjs +115 -0
  6. package/esm2020/lib/markdown.component.mjs +292 -0
  7. package/esm2020/lib/markdown.module.mjs +21 -0
  8. package/esm2020/public_api.mjs +5 -0
  9. package/fesm2015/covalent-markdown.mjs +467 -0
  10. package/fesm2015/covalent-markdown.mjs.map +1 -0
  11. package/fesm2020/covalent-markdown.mjs +464 -0
  12. package/fesm2020/covalent-markdown.mjs.map +1 -0
  13. package/{markdown-loader → lib/markdown-loader}/markdown-loader.service.d.ts +3 -0
  14. package/lib/markdown-utils/markdown-utils.d.ts +9 -0
  15. package/{markdown.component.d.ts → lib/markdown.component.d.ts} +9 -4
  16. package/lib/markdown.module.d.ts +9 -0
  17. package/package.json +28 -33
  18. package/public_api.d.ts +4 -4
  19. package/_markdown-theme.scss +0 -57
  20. package/bundles/covalent-markdown.umd.js +0 -1055
  21. package/bundles/covalent-markdown.umd.js.map +0 -1
  22. package/bundles/covalent-markdown.umd.min.js +0 -16
  23. package/bundles/covalent-markdown.umd.min.js.map +0 -1
  24. package/covalent-markdown.metadata.json +0 -1
  25. package/esm2015/covalent-markdown.js +0 -10
  26. package/esm2015/index.js +0 -7
  27. package/esm2015/markdown-loader/markdown-loader.service.js +0 -69
  28. package/esm2015/markdown-utils/markdown-utils.js +0 -183
  29. package/esm2015/markdown.component.js +0 -439
  30. package/esm2015/markdown.module.js +0 -21
  31. package/esm2015/public_api.js +0 -10
  32. package/fesm2015/covalent-markdown.js +0 -724
  33. package/fesm2015/covalent-markdown.js.map +0 -1
  34. package/index.d.ts +0 -1
  35. package/markdown-utils/markdown-utils.d.ts +0 -9
  36. package/markdown.component.scss +0 -641
  37. package/markdown.module.d.ts +0 -2
package/README.md CHANGED
@@ -12,25 +12,27 @@ By default, `--dev` build will log the following message in the console to let y
12
12
 
13
13
  #### Inputs
14
14
 
15
- + content?: string
16
- + Markdown format content to be parsed as html markup.
17
- + Used to load data dynamically. e.g. `README.md` content.
15
+ - content?: string
18
16
 
19
- + simpleLineBreaks?: string
20
- + Sets whether newline characters inside paragraphs and spans are parsed as <br/>.
21
- + Defaults to false.
17
+ - Markdown format content to be parsed as html markup.
18
+ - Used to load data dynamically. e.g. `README.md` content.
22
19
 
23
- + hostedUrl?: string
24
- + If markdown contains relative paths, this is required to generate correct urls.
20
+ - simpleLineBreaks?: string
25
21
 
26
- + anchor?: string
27
- + Anchor to jump to.
22
+ - Sets whether newline characters inside paragraphs and spans are parsed as <br/>.
23
+ - Defaults to false.
28
24
 
29
- #### Events
25
+ - hostedUrl?: string
26
+
27
+ - If markdown contains relative paths, this is required to generate correct urls.
28
+
29
+ - anchor?: string
30
+ - Anchor to jump to.
30
31
 
31
- + contentReady: undefined
32
- + Event emitted after the markdown content rendering is finished.
32
+ #### Events
33
33
 
34
+ - contentReady: undefined
35
+ - Event emitted after the markdown content rendering is finished.
34
36
 
35
37
  ## Installation
36
38
 
@@ -67,8 +69,8 @@ This module comes with its own Covalent theme which uses the material theme whic
67
69
  @include mat-core();
68
70
 
69
71
  $primary: mat-palette($mat-orange, 800);
70
- $accent: mat-palette($mat-light-blue, 600, A100, A400);
71
- $warn: mat-palette($mat-red, 600);
72
+ $accent: mat-palette($mat-light-blue, 600, A100, A400);
73
+ $warn: mat-palette($mat-red, 600);
72
74
 
73
75
  $theme: mat-light-theme($primary, $accent, $warn);
74
76
 
@@ -80,15 +82,13 @@ $theme: mat-light-theme($primary, $accent, $warn);
80
82
  **Html:**
81
83
 
82
84
  ```html
83
- <td-markdown>
84
- # Heading
85
- ## Sub Heading (H2)
86
- ### Steps (H2)
87
- </td-markdown>
85
+ <td-markdown> # Heading ## Sub Heading (H2) ### Steps (H2) </td-markdown>
88
86
  ```
89
87
 
90
88
  **Output:**
91
89
 
92
90
  # Heading
91
+
93
92
  ## Sub Heading (H2)
93
+
94
94
  ### Steps (H2)
@@ -1,4 +1,5 @@
1
1
  /**
2
2
  * Generated bundle index. Do not edit.
3
3
  */
4
- export * from './index';
4
+ /// <amd-module name="@covalent/markdown" />
5
+ export * from './public_api';
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public_api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY292YWxlbnQtbWFya2Rvd24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL21hcmtkb3duL3NyYy9jb3ZhbGVudC1tYXJrZG93bi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpY19hcGknO1xuIl19
@@ -0,0 +1,41 @@
1
+ import { Injectable, SecurityContext } from '@angular/core';
2
+ import { DomSanitizer } from '@angular/platform-browser';
3
+ import { HttpClient } from '@angular/common/http';
4
+ import { isGithubHref, rawGithubHref } from '../markdown-utils/markdown-utils';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/common/http";
7
+ import * as i2 from "@angular/platform-browser";
8
+ export class TdMarkdownLoaderService {
9
+ constructor(_http, _sanitizer) {
10
+ this._http = _http;
11
+ this._sanitizer = _sanitizer;
12
+ }
13
+ async load(url, httpOptions = {}) {
14
+ const sanitizedUrl = this._sanitizer.sanitize(SecurityContext.URL, url) ?? '';
15
+ let urlToGet = sanitizedUrl;
16
+ if (isGithubHref(sanitizedUrl)) {
17
+ urlToGet = rawGithubHref(sanitizedUrl);
18
+ }
19
+ const response = await this._http
20
+ .get(urlToGet, {
21
+ ...httpOptions,
22
+ responseType: 'text',
23
+ observe: 'response',
24
+ })
25
+ .toPromise();
26
+ const contentType = response?.headers.get('Content-Type') ?? '';
27
+ if (contentType.includes('text/plain') ||
28
+ contentType.includes('text/markdown')) {
29
+ return response?.body ?? '';
30
+ }
31
+ else {
32
+ throw Error(`${contentType} is not a handled content type`);
33
+ }
34
+ }
35
+ }
36
+ TdMarkdownLoaderService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: TdMarkdownLoaderService, deps: [{ token: i1.HttpClient }, { token: i2.DomSanitizer }], target: i0.ɵɵFactoryTarget.Injectable });
37
+ TdMarkdownLoaderService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: TdMarkdownLoaderService });
38
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: TdMarkdownLoaderService, decorators: [{
39
+ type: Injectable
40
+ }], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: i2.DomSanitizer }]; } });
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFya2Rvd24tbG9hZGVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL21hcmtkb3duL3NyYy9saWIvbWFya2Rvd24tbG9hZGVyL21hcmtkb3duLWxvYWRlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsZUFBZSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzVELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsVUFBVSxFQUFnQixNQUFNLHNCQUFzQixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxZQUFZLEVBQUUsYUFBYSxFQUFFLE1BQU0sa0NBQWtDLENBQUM7Ozs7QUFHL0UsTUFBTSxPQUFPLHVCQUF1QjtJQUNsQyxZQUFvQixLQUFpQixFQUFVLFVBQXdCO1FBQW5ELFVBQUssR0FBTCxLQUFLLENBQVk7UUFBVSxlQUFVLEdBQVYsVUFBVSxDQUFjO0lBQUcsQ0FBQztJQUUzRSxLQUFLLENBQUMsSUFBSSxDQUFDLEdBQVcsRUFBRSxjQUFzQixFQUFFO1FBQzlDLE1BQU0sWUFBWSxHQUNoQixJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxlQUFlLENBQUMsR0FBRyxFQUFFLEdBQUcsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUMzRCxJQUFJLFFBQVEsR0FBVyxZQUFZLENBQUM7UUFDcEMsSUFBSSxZQUFZLENBQUMsWUFBWSxDQUFDLEVBQUU7WUFDOUIsUUFBUSxHQUFHLGFBQWEsQ0FBQyxZQUFZLENBQUMsQ0FBQztTQUN4QztRQUVELE1BQU0sUUFBUSxHQUFxQyxNQUFNLElBQUksQ0FBQyxLQUFLO2FBQ2hFLEdBQUcsQ0FBQyxRQUFRLEVBQUU7WUFDYixHQUFHLFdBQVc7WUFDZCxZQUFZLEVBQUUsTUFBTTtZQUNwQixPQUFPLEVBQUUsVUFBVTtTQUNwQixDQUFDO2FBQ0QsU0FBUyxFQUFFLENBQUM7UUFDZixNQUFNLFdBQVcsR0FBVyxRQUFRLEVBQUUsT0FBTyxDQUFDLEdBQUcsQ0FBQyxjQUFjLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDeEUsSUFDRSxXQUFXLENBQUMsUUFBUSxDQUFDLFlBQVksQ0FBQztZQUNsQyxXQUFXLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FBQyxFQUNyQztZQUNBLE9BQU8sUUFBUSxFQUFFLElBQUksSUFBSSxFQUFFLENBQUM7U0FDN0I7YUFBTTtZQUNMLE1BQU0sS0FBSyxDQUFDLEdBQUcsV0FBVyxnQ0FBZ0MsQ0FBQyxDQUFDO1NBQzdEO0lBQ0gsQ0FBQzs7b0hBM0JVLHVCQUF1Qjt3SEFBdkIsdUJBQXVCOzJGQUF2Qix1QkFBdUI7a0JBRG5DLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBTZWN1cml0eUNvbnRleHQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERvbVNhbml0aXplciB9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xuaW1wb3J0IHsgSHR0cENsaWVudCwgSHR0cFJlc3BvbnNlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgaXNHaXRodWJIcmVmLCByYXdHaXRodWJIcmVmIH0gZnJvbSAnLi4vbWFya2Rvd24tdXRpbHMvbWFya2Rvd24tdXRpbHMnO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgVGRNYXJrZG93bkxvYWRlclNlcnZpY2Uge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIF9odHRwOiBIdHRwQ2xpZW50LCBwcml2YXRlIF9zYW5pdGl6ZXI6IERvbVNhbml0aXplcikge31cblxuICBhc3luYyBsb2FkKHVybDogc3RyaW5nLCBodHRwT3B0aW9uczogb2JqZWN0ID0ge30pOiBQcm9taXNlPHN0cmluZz4ge1xuICAgIGNvbnN0IHNhbml0aXplZFVybDogc3RyaW5nID1cbiAgICAgIHRoaXMuX3Nhbml0aXplci5zYW5pdGl6ZShTZWN1cml0eUNvbnRleHQuVVJMLCB1cmwpID8/ICcnO1xuICAgIGxldCB1cmxUb0dldDogc3RyaW5nID0gc2FuaXRpemVkVXJsO1xuICAgIGlmIChpc0dpdGh1YkhyZWYoc2FuaXRpemVkVXJsKSkge1xuICAgICAgdXJsVG9HZXQgPSByYXdHaXRodWJIcmVmKHNhbml0aXplZFVybCk7XG4gICAgfVxuXG4gICAgY29uc3QgcmVzcG9uc2U6IEh0dHBSZXNwb25zZTxzdHJpbmc+IHwgdW5kZWZpbmVkID0gYXdhaXQgdGhpcy5faHR0cFxuICAgICAgLmdldCh1cmxUb0dldCwge1xuICAgICAgICAuLi5odHRwT3B0aW9ucyxcbiAgICAgICAgcmVzcG9uc2VUeXBlOiAndGV4dCcsXG4gICAgICAgIG9ic2VydmU6ICdyZXNwb25zZScsXG4gICAgICB9KVxuICAgICAgLnRvUHJvbWlzZSgpO1xuICAgIGNvbnN0IGNvbnRlbnRUeXBlOiBzdHJpbmcgPSByZXNwb25zZT8uaGVhZGVycy5nZXQoJ0NvbnRlbnQtVHlwZScpID8/ICcnO1xuICAgIGlmIChcbiAgICAgIGNvbnRlbnRUeXBlLmluY2x1ZGVzKCd0ZXh0L3BsYWluJykgfHxcbiAgICAgIGNvbnRlbnRUeXBlLmluY2x1ZGVzKCd0ZXh0L21hcmtkb3duJylcbiAgICApIHtcbiAgICAgIHJldHVybiByZXNwb25zZT8uYm9keSA/PyAnJztcbiAgICB9IGVsc2Uge1xuICAgICAgdGhyb3cgRXJyb3IoYCR7Y29udGVudFR5cGV9IGlzIG5vdCBhIGhhbmRsZWQgY29udGVudCB0eXBlYCk7XG4gICAgfVxuICB9XG59XG4iXX0=
@@ -0,0 +1,115 @@
1
+ export function removeLeadingHash(str) {
2
+ if (str) {
3
+ return str.replace(/^#+/, '');
4
+ }
5
+ return '';
6
+ }
7
+ export function removeTrailingHash(str) {
8
+ if (str) {
9
+ return str.replace(/#.*/, '');
10
+ }
11
+ return '';
12
+ }
13
+ export function genHeadingId(str) {
14
+ if (str) {
15
+ return removeLeadingHash(str
16
+ .replace(/(_|-|\s)+/g, '')
17
+ // Remove certain special chars to create heading ids similar to those in github
18
+ // borrowed from showdown
19
+ // https://github.com/showdownjs/showdown/blob/develop/src/subParsers/makehtml/headers.js#L94
20
+ .replace(/[&+$,/:;=?@"#{}|^¨~[\]`\\*)(%.!'<>]/g, '')).toLowerCase();
21
+ }
22
+ return '';
23
+ }
24
+ export function scrollToAnchor(scope, anchor, tryParent) {
25
+ if (scope && anchor) {
26
+ const normalizedAnchor = genHeadingId(anchor);
27
+ let headingToJumpTo = null;
28
+ const headingWithinComponent = scope.querySelector(`[id="${normalizedAnchor}"]`);
29
+ if (headingWithinComponent) {
30
+ headingToJumpTo = headingWithinComponent;
31
+ }
32
+ else if (tryParent) {
33
+ const parent = scope.parentElement;
34
+ if (parent) {
35
+ headingToJumpTo = parent.querySelector(`[id="${normalizedAnchor}"]`);
36
+ }
37
+ }
38
+ if (headingToJumpTo) {
39
+ headingToJumpTo.scrollIntoView({ behavior: 'auto' });
40
+ return true;
41
+ }
42
+ }
43
+ return false;
44
+ }
45
+ export function isAnchorLink(anchor) {
46
+ if (anchor) {
47
+ const href = anchor.getAttribute('href');
48
+ if (href) {
49
+ return href.startsWith('#');
50
+ }
51
+ }
52
+ return false;
53
+ }
54
+ const RAW_GITHUB_HOSTNAME = 'raw.githubusercontent.com';
55
+ export function rawGithubHref(githubHref) {
56
+ if (githubHref) {
57
+ try {
58
+ const url = new URL(githubHref);
59
+ if (url.hostname === RAW_GITHUB_HOSTNAME) {
60
+ return url.href;
61
+ }
62
+ else if (isGithubHref(githubHref)) {
63
+ url.hostname = RAW_GITHUB_HOSTNAME;
64
+ url.pathname = url.pathname.split('/blob', 2).join('');
65
+ return url.href;
66
+ }
67
+ }
68
+ catch {
69
+ return '';
70
+ }
71
+ }
72
+ return '';
73
+ }
74
+ export function isGithubHref(href) {
75
+ try {
76
+ const temp = new URL(href ?? '');
77
+ return temp.hostname === 'github.com';
78
+ }
79
+ catch {
80
+ return false;
81
+ }
82
+ }
83
+ export function isRawGithubHref(href = '') {
84
+ try {
85
+ const temp = new URL(href);
86
+ return temp.hostname === RAW_GITHUB_HOSTNAME;
87
+ }
88
+ catch {
89
+ return false;
90
+ }
91
+ }
92
+ export function renderVideoElements(html) {
93
+ const ytLongEmbed = /!\[(?:(?:https?:)?(?:\/\/)?)(?:(?:www)?.)?youtube.(?:.+?)\/(?:(?:embed\/)([\w-]{11})(\?[\w%;-]+(?:=[\w%;-]+)?(?:&[\w%;-]+(?:=[\w%;-]+)?)*)?)]/gi;
94
+ const ytLongWatch = /!\[(?:(?:https?:)?(?:\/\/)?)(?:(?:www)?.)?youtube.(?:.+?)\/(?:(?:watch\?v=)([\w-]{11})(&[\w%;-]+(?:=[\w%;-]+)?)*)]/gi;
95
+ const ytShort = /!\[(?:(?:https?:)?(?:\/\/)?)?youtu.be\/([\w-]{11})\??([\w%;-]+(?:=[\w%;-]+)?(?:&[\w%;-]+(?:=[\w%;-]+)?)*)?]/gi;
96
+ const ytPlaylist = /!\[(?:(?:https?:)?(?:\/\/)?)(?:(?:www)?.)?youtube.(?:.+?)\/(?:(?:playlist\?list=)([\w-]{34})(&[\w%;-]+(?:=[\w%;-]+)?)*)]/gi;
97
+ function convert(match, id, flags) {
98
+ if (flags) {
99
+ id += '?' + flags.replace(/&amp;/gi, '&');
100
+ }
101
+ return `<iframe allow="fullscreen" frameborder="0" src="https://www.youtube.com/embed/${id}"></iframe>`;
102
+ }
103
+ function convertPL(match, id, flags) {
104
+ if (flags) {
105
+ id += flags.replace(/&amp;/gi, '&');
106
+ }
107
+ return `<iframe allow="fullscreen" frameborder="0" src="https://www.youtube.com/embed/videoseries?list=${id}"></iframe>`;
108
+ }
109
+ return html
110
+ .replace(ytLongWatch, convert)
111
+ .replace(ytLongEmbed, convert)
112
+ .replace(ytShort, convert)
113
+ .replace(ytPlaylist, convertPL);
114
+ }
115
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"markdown-utils.js","sourceRoot":"","sources":["../../../../../../libs/markdown/src/lib/markdown-utils/markdown-utils.ts"],"names":[],"mappings":"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","sourcesContent":["export function removeLeadingHash(str: string): string {\n  if (str) {\n    return str.replace(/^#+/, '');\n  }\n  return '';\n}\n\nexport function removeTrailingHash(str: string | null): string {\n  if (str) {\n    return str.replace(/#.*/, '');\n  }\n  return '';\n}\n\nexport function genHeadingId(str: string): string {\n  if (str) {\n    return removeLeadingHash(\n      str\n        .replace(/(_|-|\\s)+/g, '')\n        // Remove certain special chars to create heading ids similar to those in github\n        // borrowed from showdown\n        // https://github.com/showdownjs/showdown/blob/develop/src/subParsers/makehtml/headers.js#L94\n        .replace(/[&+$,/:;=?@\"#{}|^¨~[\\]`\\\\*)(%.!'<>]/g, '')\n    ).toLowerCase();\n  }\n  return '';\n}\n\nexport function scrollToAnchor(\n  scope: HTMLElement,\n  anchor: string,\n  tryParent: boolean\n): boolean {\n  if (scope && anchor) {\n    const normalizedAnchor: string = genHeadingId(anchor);\n    let headingToJumpTo: Element | null = null;\n    const headingWithinComponent = scope.querySelector(\n      `[id=\"${normalizedAnchor}\"]`\n    );\n\n    if (headingWithinComponent) {\n      headingToJumpTo = headingWithinComponent;\n    } else if (tryParent) {\n      const parent = scope.parentElement;\n      if (parent) {\n        headingToJumpTo = parent.querySelector(`[id=\"${normalizedAnchor}\"]`);\n      }\n    }\n    if (headingToJumpTo) {\n      headingToJumpTo.scrollIntoView({ behavior: 'auto' });\n      return true;\n    }\n  }\n  return false;\n}\n\nexport function isAnchorLink(anchor?: HTMLAnchorElement): boolean {\n  if (anchor) {\n    const href = anchor.getAttribute('href');\n    if (href) {\n      return href.startsWith('#');\n    }\n  }\n  return false;\n}\nconst RAW_GITHUB_HOSTNAME = 'raw.githubusercontent.com';\n\nexport function rawGithubHref(githubHref?: string): string {\n  if (githubHref) {\n    try {\n      const url: URL = new URL(githubHref);\n      if (url.hostname === RAW_GITHUB_HOSTNAME) {\n        return url.href;\n      } else if (isGithubHref(githubHref)) {\n        url.hostname = RAW_GITHUB_HOSTNAME;\n        url.pathname = url.pathname.split('/blob', 2).join('');\n        return url.href;\n      }\n    } catch {\n      return '';\n    }\n  }\n  return '';\n}\n\nexport function isGithubHref(href?: string): boolean {\n  try {\n    const temp: URL = new URL(href ?? '');\n    return temp.hostname === 'github.com';\n  } catch {\n    return false;\n  }\n}\n\nexport function isRawGithubHref(href: string = ''): boolean {\n  try {\n    const temp: URL = new URL(href);\n    return temp.hostname === RAW_GITHUB_HOSTNAME;\n  } catch {\n    return false;\n  }\n}\n\nexport function renderVideoElements(html: string): string {\n  const ytLongEmbed =\n    /!\\[(?:(?:https?:)?(?:\\/\\/)?)(?:(?:www)?.)?youtube.(?:.+?)\\/(?:(?:embed\\/)([\\w-]{11})(\\?[\\w%;-]+(?:=[\\w%;-]+)?(?:&[\\w%;-]+(?:=[\\w%;-]+)?)*)?)]/gi;\n  const ytLongWatch =\n    /!\\[(?:(?:https?:)?(?:\\/\\/)?)(?:(?:www)?.)?youtube.(?:.+?)\\/(?:(?:watch\\?v=)([\\w-]{11})(&[\\w%;-]+(?:=[\\w%;-]+)?)*)]/gi;\n  const ytShort =\n    /!\\[(?:(?:https?:)?(?:\\/\\/)?)?youtu.be\\/([\\w-]{11})\\??([\\w%;-]+(?:=[\\w%;-]+)?(?:&[\\w%;-]+(?:=[\\w%;-]+)?)*)?]/gi;\n  const ytPlaylist =\n    /!\\[(?:(?:https?:)?(?:\\/\\/)?)(?:(?:www)?.)?youtube.(?:.+?)\\/(?:(?:playlist\\?list=)([\\w-]{34})(&[\\w%;-]+(?:=[\\w%;-]+)?)*)]/gi;\n\n  function convert(match: string, id: string, flags: string): string {\n    if (flags) {\n      id += '?' + flags.replace(/&amp;/gi, '&');\n    }\n    return `<iframe allow=\"fullscreen\" frameborder=\"0\" src=\"https://www.youtube.com/embed/${id}\"></iframe>`;\n  }\n  function convertPL(match: string, id: string, flags: string): string {\n    if (flags) {\n      id += flags.replace(/&amp;/gi, '&');\n    }\n    return `<iframe allow=\"fullscreen\" frameborder=\"0\" src=\"https://www.youtube.com/embed/videoseries?list=${id}\"></iframe>`;\n  }\n\n  return html\n    .replace(ytLongWatch, convert)\n    .replace(ytLongEmbed, convert)\n    .replace(ytShort, convert)\n    .replace(ytPlaylist, convertPL);\n}\n"]}