@covalent/markdown-navigator 3.1.2-beta.6 → 4.0.0-beta.1

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/covalent-markdown-navigator.d.ts +1 -1
  2. package/esm2020/covalent-markdown-navigator.mjs +5 -0
  3. package/esm2020/index.mjs +2 -0
  4. package/esm2020/markdown-navigator-window/markdown-navigator-window.component.mjs +91 -0
  5. package/esm2020/markdown-navigator-window-directive/markdown-navigator-window.directive.mjs +34 -0
  6. package/esm2020/markdown-navigator-window-service/markdown-navigator-window.service.mjs +129 -0
  7. package/esm2020/markdown-navigator.component.mjs +587 -0
  8. package/esm2020/markdown-navigator.module.mjs +62 -0
  9. package/esm2020/public-api.mjs +6 -0
  10. package/fesm2015/covalent-markdown-navigator.mjs +968 -0
  11. package/fesm2015/covalent-markdown-navigator.mjs.map +1 -0
  12. package/fesm2020/covalent-markdown-navigator.mjs +889 -0
  13. package/fesm2020/covalent-markdown-navigator.mjs.map +1 -0
  14. package/markdown-navigator-window/markdown-navigator-window.component.d.ts +3 -0
  15. package/markdown-navigator-window/markdown-navigator-window.component.scss +1 -0
  16. package/markdown-navigator-window-directive/markdown-navigator-window.directive.d.ts +3 -0
  17. package/markdown-navigator-window-service/markdown-navigator-window.service.d.ts +3 -0
  18. package/markdown-navigator.component.d.ts +3 -0
  19. package/markdown-navigator.component.scss +5 -0
  20. package/markdown-navigator.module.d.ts +16 -0
  21. package/package.json +30 -15
  22. package/public-api.d.ts +1 -0
  23. package/bundles/covalent-markdown-navigator.umd.js +0 -1650
  24. package/bundles/covalent-markdown-navigator.umd.js.map +0 -1
  25. package/bundles/covalent-markdown-navigator.umd.min.js +0 -16
  26. package/bundles/covalent-markdown-navigator.umd.min.js.map +0 -1
  27. package/covalent-markdown-navigator.metadata.json +0 -1
  28. package/esm2015/covalent-markdown-navigator.js +0 -11
  29. package/esm2015/index.js +0 -7
  30. package/esm2015/markdown-navigator-window/markdown-navigator-window.component.js +0 -129
  31. package/esm2015/markdown-navigator-window-directive/markdown-navigator-window.directive.js +0 -50
  32. package/esm2015/markdown-navigator-window-service/markdown-navigator-window.service.js +0 -254
  33. package/esm2015/markdown-navigator.component.js +0 -698
  34. package/esm2015/markdown-navigator.module.js +0 -41
  35. package/esm2015/public-api.js +0 -10
  36. package/fesm2015/covalent-markdown-navigator.js +0 -1181
  37. package/fesm2015/covalent-markdown-navigator.js.map +0 -1
@@ -0,0 +1,587 @@
1
+ import { Component, Input, HostListener, ViewChild, ElementRef, ChangeDetectorRef, ChangeDetectionStrategy, Type, Output, EventEmitter, SecurityContext, } from '@angular/core';
2
+ import { removeLeadingHash, isAnchorLink, TdMarkdownLoaderService } from '@covalent/markdown';
3
+ import { DomSanitizer } from '@angular/platform-browser';
4
+ import { HttpClient } from '@angular/common/http';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@covalent/markdown";
7
+ import * as i2 from "@angular/platform-browser";
8
+ import * as i3 from "@angular/common/http";
9
+ import * as i4 from "@angular/common";
10
+ import * as i5 from "@angular/material/progress-bar";
11
+ import * as i6 from "@angular/material/button";
12
+ import * as i7 from "@angular/material/tooltip";
13
+ import * as i8 from "@angular/material/icon";
14
+ import * as i9 from "@angular/material/divider";
15
+ import * as i10 from "@covalent/core/message";
16
+ import * as i11 from "@covalent/flavored-markdown";
17
+ import * as i12 from "@angular/material/list";
18
+ import * as i13 from "@angular/material/core";
19
+ const _c0 = ["markdownWrapper"];
20
+ function TdMarkdownNavigatorComponent_ng_container_0_mat_progress_bar_1_Template(rf, ctx) { if (rf & 1) {
21
+ i0.ɵɵelement(0, "mat-progress-bar", 8);
22
+ } }
23
+ function TdMarkdownNavigatorComponent_ng_container_0_ng_container_2_button_2_Template(rf, ctx) { if (rf & 1) {
24
+ const _r12 = i0.ɵɵgetCurrentView();
25
+ i0.ɵɵelementStart(0, "button", 12);
26
+ i0.ɵɵlistener("click", function TdMarkdownNavigatorComponent_ng_container_0_ng_container_2_button_2_Template_button_click_0_listener() { i0.ɵɵrestoreView(_r12); const ctx_r11 = i0.ɵɵnextContext(3); return ctx_r11.reset(); });
27
+ i0.ɵɵelementStart(1, "mat-icon");
28
+ i0.ɵɵtext(2, "home");
29
+ i0.ɵɵelementEnd();
30
+ i0.ɵɵelementEnd();
31
+ } if (rf & 2) {
32
+ const ctx_r8 = i0.ɵɵnextContext(3);
33
+ i0.ɵɵproperty("matTooltip", ctx_r8.goHomeLabel);
34
+ i0.ɵɵattribute("data-test", "home-button");
35
+ i0.ɵɵadvance(1);
36
+ i0.ɵɵattribute("aria-label", ctx_r8.goHomeLabel);
37
+ } }
38
+ function TdMarkdownNavigatorComponent_ng_container_0_ng_container_2_button_3_Template(rf, ctx) { if (rf & 1) {
39
+ const _r14 = i0.ɵɵgetCurrentView();
40
+ i0.ɵɵelementStart(0, "button", 13);
41
+ i0.ɵɵlistener("click", function TdMarkdownNavigatorComponent_ng_container_0_ng_container_2_button_3_Template_button_click_0_listener() { i0.ɵɵrestoreView(_r14); const ctx_r13 = i0.ɵɵnextContext(3); return ctx_r13.goBack(); });
42
+ i0.ɵɵelementStart(1, "mat-icon");
43
+ i0.ɵɵtext(2, "arrow_back");
44
+ i0.ɵɵelementEnd();
45
+ i0.ɵɵelementEnd();
46
+ } if (rf & 2) {
47
+ const ctx_r9 = i0.ɵɵnextContext(3);
48
+ i0.ɵɵproperty("matTooltip", ctx_r9.goBackLabel);
49
+ i0.ɵɵattribute("data-test", "back-button");
50
+ i0.ɵɵadvance(1);
51
+ i0.ɵɵattribute("aria-label", ctx_r9.goBackLabel);
52
+ } }
53
+ function TdMarkdownNavigatorComponent_ng_container_0_ng_container_2_span_4_Template(rf, ctx) { if (rf & 1) {
54
+ i0.ɵɵelementStart(0, "span", 14);
55
+ i0.ɵɵtext(1);
56
+ i0.ɵɵelementEnd();
57
+ } if (rf & 2) {
58
+ const ctx_r10 = i0.ɵɵnextContext(3);
59
+ i0.ɵɵattribute("data-test", "title");
60
+ i0.ɵɵadvance(1);
61
+ i0.ɵɵtextInterpolate1(" ", ctx_r10.currentItemTitle, " ");
62
+ } }
63
+ function TdMarkdownNavigatorComponent_ng_container_0_ng_container_2_Template(rf, ctx) { if (rf & 1) {
64
+ i0.ɵɵelementContainerStart(0);
65
+ i0.ɵɵelementStart(1, "div");
66
+ i0.ɵɵtemplate(2, TdMarkdownNavigatorComponent_ng_container_0_ng_container_2_button_2_Template, 3, 3, "button", 9);
67
+ i0.ɵɵtemplate(3, TdMarkdownNavigatorComponent_ng_container_0_ng_container_2_button_3_Template, 3, 3, "button", 10);
68
+ i0.ɵɵtemplate(4, TdMarkdownNavigatorComponent_ng_container_0_ng_container_2_span_4_Template, 2, 2, "span", 11);
69
+ i0.ɵɵelementEnd();
70
+ i0.ɵɵelement(5, "mat-divider");
71
+ i0.ɵɵelementContainerEnd();
72
+ } if (rf & 2) {
73
+ const ctx_r3 = i0.ɵɵnextContext(2);
74
+ i0.ɵɵadvance(1);
75
+ i0.ɵɵstyleProp("display", "flex");
76
+ i0.ɵɵadvance(1);
77
+ i0.ɵɵproperty("ngIf", ctx_r3.showHomeButton);
78
+ i0.ɵɵadvance(1);
79
+ i0.ɵɵproperty("ngIf", ctx_r3.showGoBackButton);
80
+ i0.ɵɵadvance(1);
81
+ i0.ɵɵproperty("ngIf", ctx_r3.currentItemTitle);
82
+ i0.ɵɵadvance(1);
83
+ i0.ɵɵstyleProp("position", "relative");
84
+ } }
85
+ function TdMarkdownNavigatorComponent_ng_container_0_div_4_td_message_2_Template(rf, ctx) { if (rf & 1) {
86
+ i0.ɵɵelement(0, "td-message", 19);
87
+ } if (rf & 2) {
88
+ const ctx_r16 = i0.ɵɵnextContext(3);
89
+ i0.ɵɵproperty("sublabel", ctx_r16.markdownLoaderError);
90
+ i0.ɵɵattribute("data-test", "markdown-loader-error");
91
+ } }
92
+ function TdMarkdownNavigatorComponent_ng_container_0_div_4_td_flavored_markdown_loader_3_Template(rf, ctx) { if (rf & 1) {
93
+ const _r20 = i0.ɵɵgetCurrentView();
94
+ i0.ɵɵelementStart(0, "td-flavored-markdown-loader", 20);
95
+ i0.ɵɵlistener("loadFailed", function TdMarkdownNavigatorComponent_ng_container_0_div_4_td_flavored_markdown_loader_3_Template_td_flavored_markdown_loader_loadFailed_0_listener($event) { i0.ɵɵrestoreView(_r20); const ctx_r19 = i0.ɵɵnextContext(3); return ctx_r19.handleMarkdownLoaderError($event); });
96
+ i0.ɵɵelementEnd();
97
+ } if (rf & 2) {
98
+ const ctx_r17 = i0.ɵɵnextContext(3);
99
+ i0.ɵɵproperty("url", ctx_r17.url)("httpOptions", ctx_r17.httpOptions)("anchor", ctx_r17.anchor)("copyCodeToClipboard", ctx_r17.copyCodeToClipboard)("copyCodeTooltips", ctx_r17.copyCodeTooltips);
100
+ } }
101
+ function TdMarkdownNavigatorComponent_ng_container_0_div_4_td_flavored_markdown_4_Template(rf, ctx) { if (rf & 1) {
102
+ const _r22 = i0.ɵɵgetCurrentView();
103
+ i0.ɵɵelementStart(0, "td-flavored-markdown", 21);
104
+ i0.ɵɵlistener("buttonClicked", function TdMarkdownNavigatorComponent_ng_container_0_div_4_td_flavored_markdown_4_Template_td_flavored_markdown_buttonClicked_0_listener($event) { i0.ɵɵrestoreView(_r22); const ctx_r21 = i0.ɵɵnextContext(3); return ctx_r21.buttonClicked.emit($event); });
105
+ i0.ɵɵelementEnd();
106
+ } if (rf & 2) {
107
+ const ctx_r18 = i0.ɵɵnextContext(3);
108
+ i0.ɵɵproperty("content", ctx_r18.markdownString)("hostedUrl", ctx_r18.url)("anchor", ctx_r18.anchor)("copyCodeToClipboard", ctx_r18.copyCodeToClipboard)("copyCodeTooltips", ctx_r18.copyCodeTooltips);
109
+ } }
110
+ function TdMarkdownNavigatorComponent_ng_container_0_div_4_Template(rf, ctx) { if (rf & 1) {
111
+ i0.ɵɵelementStart(0, "div", 15, 16);
112
+ i0.ɵɵtemplate(2, TdMarkdownNavigatorComponent_ng_container_0_div_4_td_message_2_Template, 1, 2, "td-message", 5);
113
+ i0.ɵɵtemplate(3, TdMarkdownNavigatorComponent_ng_container_0_div_4_td_flavored_markdown_loader_3_Template, 1, 5, "td-flavored-markdown-loader", 17);
114
+ i0.ɵɵtemplate(4, TdMarkdownNavigatorComponent_ng_container_0_div_4_td_flavored_markdown_4_Template, 1, 5, "td-flavored-markdown", 18);
115
+ i0.ɵɵelementEnd();
116
+ } if (rf & 2) {
117
+ const ctx_r4 = i0.ɵɵnextContext(2);
118
+ i0.ɵɵadvance(2);
119
+ i0.ɵɵproperty("ngIf", ctx_r4.markdownLoaderError);
120
+ i0.ɵɵadvance(1);
121
+ i0.ɵɵproperty("ngIf", ctx_r4.showTdMarkdownLoader);
122
+ i0.ɵɵadvance(1);
123
+ i0.ɵɵproperty("ngIf", ctx_r4.showTdMarkdown);
124
+ } }
125
+ function TdMarkdownNavigatorComponent_ng_container_0_td_message_5_Template(rf, ctx) { if (rf & 1) {
126
+ i0.ɵɵelement(0, "td-message", 19);
127
+ } if (rf & 2) {
128
+ const ctx_r5 = i0.ɵɵnextContext(2);
129
+ i0.ɵɵproperty("sublabel", ctx_r5.childrenUrlError);
130
+ i0.ɵɵattribute("data-test", "children-url-error");
131
+ } }
132
+ function TdMarkdownNavigatorComponent_ng_container_0_div_6_button_2_Template(rf, ctx) { if (rf & 1) {
133
+ const _r27 = i0.ɵɵgetCurrentView();
134
+ i0.ɵɵelementStart(0, "button", 24);
135
+ i0.ɵɵlistener("click", function TdMarkdownNavigatorComponent_ng_container_0_div_6_button_2_Template_button_click_0_listener() { const restoredCtx = i0.ɵɵrestoreView(_r27); const item_r24 = restoredCtx.$implicit; const ctx_r26 = i0.ɵɵnextContext(3); return ctx_r26.handleItemSelected(item_r24); });
136
+ i0.ɵɵelementStart(1, "mat-icon", 25);
137
+ i0.ɵɵtext(2);
138
+ i0.ɵɵelementEnd();
139
+ i0.ɵɵelementStart(3, "span", 26);
140
+ i0.ɵɵtext(4);
141
+ i0.ɵɵelementEnd();
142
+ i0.ɵɵelementStart(5, "span", 26);
143
+ i0.ɵɵtext(6);
144
+ i0.ɵɵelementEnd();
145
+ i0.ɵɵelement(7, "mat-divider");
146
+ i0.ɵɵelementEnd();
147
+ } if (rf & 2) {
148
+ const item_r24 = ctx.$implicit;
149
+ const index_r25 = ctx.index;
150
+ const ctx_r23 = i0.ɵɵnextContext(3);
151
+ i0.ɵɵproperty("id", "td-markdown-navigator-list-item-" + (item_r24.id ? item_r24.id : index_r25))("matTooltip", ctx_r23.getTitle(item_r24));
152
+ i0.ɵɵadvance(2);
153
+ i0.ɵɵtextInterpolate1(" ", ctx_r23.getIcon(item_r24), " ");
154
+ i0.ɵɵadvance(2);
155
+ i0.ɵɵtextInterpolate1(" ", ctx_r23.getTitle(item_r24), " ");
156
+ i0.ɵɵadvance(2);
157
+ i0.ɵɵtextInterpolate(item_r24.description);
158
+ } }
159
+ function TdMarkdownNavigatorComponent_ng_container_0_div_6_Template(rf, ctx) { if (rf & 1) {
160
+ i0.ɵɵelementStart(0, "div", 22);
161
+ i0.ɵɵelementStart(1, "mat-action-list");
162
+ i0.ɵɵtemplate(2, TdMarkdownNavigatorComponent_ng_container_0_div_6_button_2_Template, 8, 5, "button", 23);
163
+ i0.ɵɵelementEnd();
164
+ i0.ɵɵelementEnd();
165
+ } if (rf & 2) {
166
+ const ctx_r6 = i0.ɵɵnextContext(2);
167
+ i0.ɵɵadvance(2);
168
+ i0.ɵɵproperty("ngForOf", ctx_r6.currentMenuItems);
169
+ } }
170
+ function TdMarkdownNavigatorComponent_ng_container_0_ng_container_7_Template(rf, ctx) { if (rf & 1) {
171
+ i0.ɵɵelementContainer(0);
172
+ } }
173
+ function TdMarkdownNavigatorComponent_ng_container_0_Template(rf, ctx) { if (rf & 1) {
174
+ i0.ɵɵelementContainerStart(0);
175
+ i0.ɵɵtemplate(1, TdMarkdownNavigatorComponent_ng_container_0_mat_progress_bar_1_Template, 1, 0, "mat-progress-bar", 2);
176
+ i0.ɵɵtemplate(2, TdMarkdownNavigatorComponent_ng_container_0_ng_container_2_Template, 6, 7, "ng-container", 0);
177
+ i0.ɵɵelementStart(3, "div", 3);
178
+ i0.ɵɵtemplate(4, TdMarkdownNavigatorComponent_ng_container_0_div_4_Template, 5, 3, "div", 4);
179
+ i0.ɵɵtemplate(5, TdMarkdownNavigatorComponent_ng_container_0_td_message_5_Template, 1, 2, "td-message", 5);
180
+ i0.ɵɵtemplate(6, TdMarkdownNavigatorComponent_ng_container_0_div_6_Template, 3, 1, "div", 6);
181
+ i0.ɵɵtemplate(7, TdMarkdownNavigatorComponent_ng_container_0_ng_container_7_Template, 1, 0, "ng-container", 7);
182
+ i0.ɵɵelementEnd();
183
+ i0.ɵɵelementContainerEnd();
184
+ } if (rf & 2) {
185
+ const ctx_r0 = i0.ɵɵnextContext();
186
+ i0.ɵɵadvance(1);
187
+ i0.ɵɵproperty("ngIf", ctx_r0.loading);
188
+ i0.ɵɵadvance(1);
189
+ i0.ɵɵproperty("ngIf", ctx_r0.showHeader);
190
+ i0.ɵɵadvance(2);
191
+ i0.ɵɵproperty("ngIf", ctx_r0.showTdMarkdownLoader || ctx_r0.showTdMarkdown);
192
+ i0.ɵɵadvance(1);
193
+ i0.ɵɵproperty("ngIf", ctx_r0.childrenUrlError);
194
+ i0.ɵɵadvance(1);
195
+ i0.ɵɵproperty("ngIf", ctx_r0.showMenu);
196
+ i0.ɵɵadvance(1);
197
+ i0.ɵɵproperty("ngComponentOutlet", ctx_r0.footerComponent);
198
+ } }
199
+ function TdMarkdownNavigatorComponent_div_1_Template(rf, ctx) { if (rf & 1) {
200
+ i0.ɵɵelementStart(0, "div", 27);
201
+ i0.ɵɵelementStart(1, "mat-icon", 28);
202
+ i0.ɵɵtext(2, "subject");
203
+ i0.ɵɵelementEnd();
204
+ i0.ɵɵelementStart(3, "h2");
205
+ i0.ɵɵtext(4);
206
+ i0.ɵɵelementEnd();
207
+ i0.ɵɵelementEnd();
208
+ } if (rf & 2) {
209
+ const ctx_r1 = i0.ɵɵnextContext();
210
+ i0.ɵɵadvance(4);
211
+ i0.ɵɵtextInterpolate(ctx_r1.emptyStateLabel);
212
+ } }
213
+ export const DEFAULT_MARKDOWN_NAVIGATOR_LABELS = {
214
+ goHome: 'Go home',
215
+ goBack: 'Go back',
216
+ emptyState: 'No item(s) to display',
217
+ };
218
+ function getTitleFromUrl(url) {
219
+ if (url) {
220
+ const temp = new URL(url);
221
+ if (temp.hash) {
222
+ return removeLeadingHash(temp.hash);
223
+ }
224
+ else {
225
+ const path = temp.pathname.split('/');
226
+ const fileName = path[path.length - 1];
227
+ return fileName.replace(/\.[^/.]+$/, ''); // remove .md
228
+ }
229
+ }
230
+ return undefined;
231
+ }
232
+ function getTitleFromMarkdownString(markdownString) {
233
+ if (markdownString) {
234
+ const firstLine = markdownString.split(/[\r\n]+/).find((line) => !!line);
235
+ return removeLeadingHash(firstLine).trim();
236
+ }
237
+ return undefined;
238
+ }
239
+ function isMarkdownHref(anchor) {
240
+ return !isAnchorLink(anchor) && anchor.pathname.endsWith('.md');
241
+ }
242
+ function defaultCompareWith(o1, o2) {
243
+ if (o1.id && o2.id) {
244
+ return o1.id === o2.id;
245
+ }
246
+ return o1 === o2;
247
+ }
248
+ export class TdMarkdownNavigatorComponent {
249
+ constructor(_markdownUrlLoaderService, _changeDetectorRef, _sanitizer, _http) {
250
+ this._markdownUrlLoaderService = _markdownUrlLoaderService;
251
+ this._changeDetectorRef = _changeDetectorRef;
252
+ this._sanitizer = _sanitizer;
253
+ this._http = _http;
254
+ /**
255
+ * copyCodeToClipboard?: boolean
256
+ *
257
+ * Display copy button on code snippets to copy code to clipboard.
258
+ *
259
+ */
260
+ this.copyCodeToClipboard = false;
261
+ /**
262
+ * copyCodeTooltips?: ICopyCodeTooltips
263
+ *
264
+ * Tooltips for copy button to copy and upon copying.
265
+ */
266
+ this.copyCodeTooltips = {};
267
+ this.buttonClicked = new EventEmitter();
268
+ this.historyStack = []; // history
269
+ this.currentMenuItems = []; // current menu items
270
+ this.loading = false;
271
+ }
272
+ clickListener(event) {
273
+ const element = event.srcElement;
274
+ if (element.matches('a[href]') && isMarkdownHref(element)) {
275
+ this.handleLinkClick(event);
276
+ }
277
+ }
278
+ get showGoBackButton() {
279
+ return this.historyStack.length > 0;
280
+ }
281
+ get showHomeButton() {
282
+ return this.historyStack.length > 1;
283
+ }
284
+ get showHeader() {
285
+ return this.showHomeButton || this.showGoBackButton || !!this.currentItemTitle;
286
+ }
287
+ get showMenu() {
288
+ return this.currentMenuItems && this.currentMenuItems.length > 0;
289
+ }
290
+ get showTdMarkdownLoader() {
291
+ return !!this.currentMarkdownItem && !!this.currentMarkdownItem.url && !this.showTdMarkdown;
292
+ }
293
+ get showTdMarkdown() {
294
+ return !!this.currentMarkdownItem && !!this.currentMarkdownItem.markdownString;
295
+ }
296
+ get url() {
297
+ if (this.currentMarkdownItem) {
298
+ return this.currentMarkdownItem.url;
299
+ }
300
+ return undefined;
301
+ }
302
+ get footerComponent() {
303
+ if (this.currentMarkdownItem && this.currentMarkdownItem.footer) {
304
+ return this.currentMarkdownItem.footer;
305
+ }
306
+ return this.footer;
307
+ }
308
+ get httpOptions() {
309
+ if (this.currentMarkdownItem) {
310
+ return this.currentMarkdownItem.httpOptions;
311
+ }
312
+ }
313
+ get markdownString() {
314
+ if (this.currentMarkdownItem) {
315
+ return this.currentMarkdownItem.markdownString;
316
+ }
317
+ }
318
+ get anchor() {
319
+ if (this.currentMarkdownItem) {
320
+ return this.currentMarkdownItem.anchor;
321
+ }
322
+ }
323
+ get showEmptyState() {
324
+ return !this.items || this.items.length < 1;
325
+ }
326
+ get goHomeLabel() {
327
+ return (this.labels && this.labels.goHome) || DEFAULT_MARKDOWN_NAVIGATOR_LABELS.goHome;
328
+ }
329
+ get goBackLabel() {
330
+ return (this.labels && this.labels.goBack) || DEFAULT_MARKDOWN_NAVIGATOR_LABELS.goBack;
331
+ }
332
+ get emptyStateLabel() {
333
+ return (this.labels && this.labels.emptyState) || DEFAULT_MARKDOWN_NAVIGATOR_LABELS.emptyState;
334
+ }
335
+ get currentItemTitle() {
336
+ if (this.historyStack.length < 1) {
337
+ return '';
338
+ }
339
+ else if (this.currentMarkdownItem) {
340
+ return this.getTitle(this.currentMarkdownItem);
341
+ }
342
+ else if (this.historyStack.length > 0) {
343
+ return this.getTitle(this.historyStack[this.historyStack.length - 1]);
344
+ }
345
+ return '';
346
+ }
347
+ async ngOnChanges(changes) {
348
+ if (changes.items) {
349
+ this.reset();
350
+ }
351
+ if (changes.startAt && this.items && this.startAt) {
352
+ this._jumpTo(this.startAt, undefined);
353
+ }
354
+ }
355
+ hasChildrenOrChildrenUrl(item) {
356
+ return (item.children && item.children.length > 0) || !!item.childrenUrl;
357
+ }
358
+ clearErrors() {
359
+ this.markdownLoaderError = undefined;
360
+ this.childrenUrlError = undefined;
361
+ }
362
+ reset() {
363
+ this.loading = false;
364
+ this.clearErrors();
365
+ // if single item and no children
366
+ if (this.items && this.items.length === 1 && !this.hasChildrenOrChildrenUrl(this.items[0])) {
367
+ this.currentMenuItems = [];
368
+ this.currentMarkdownItem = this.items[0];
369
+ }
370
+ else {
371
+ this.currentMenuItems = this.items;
372
+ this.currentMarkdownItem = undefined;
373
+ }
374
+ this.historyStack = [];
375
+ this._changeDetectorRef.markForCheck();
376
+ }
377
+ goBack() {
378
+ this.loading = false;
379
+ this.clearErrors();
380
+ if (this.historyStack.length > 1) {
381
+ let parent = this.historyStack[this.historyStack.length - 2];
382
+ if (parent.startAtLink) {
383
+ parent = this.historyStack[this.historyStack.length - 3]
384
+ ? this.historyStack[this.historyStack.length - 3]
385
+ : undefined;
386
+ this.historyStack = this.historyStack.slice(0, -1);
387
+ }
388
+ if (parent) {
389
+ this.currentMarkdownItem = parent;
390
+ this.historyStack = this.historyStack.slice(0, -1);
391
+ this.setChildrenAsCurrentMenuItems(parent);
392
+ }
393
+ else {
394
+ this.reset();
395
+ }
396
+ }
397
+ else {
398
+ // one level down just go to root
399
+ this.reset();
400
+ }
401
+ this._changeDetectorRef.markForCheck();
402
+ }
403
+ handleItemSelected(item) {
404
+ this.clearErrors();
405
+ this.currentMarkdownItem = item;
406
+ this.historyStack = [...this.historyStack, item];
407
+ this.setChildrenAsCurrentMenuItems(item);
408
+ this._changeDetectorRef.markForCheck();
409
+ }
410
+ async setChildrenAsCurrentMenuItems(item) {
411
+ this.currentMenuItems = [];
412
+ this.loading = true;
413
+ this._changeDetectorRef.markForCheck();
414
+ const stackSnapshot = this.historyStack;
415
+ let children = [];
416
+ if (item.children) {
417
+ children = item.children;
418
+ }
419
+ else if (item.childrenUrl) {
420
+ children = await this.loadChildrenUrl(item);
421
+ }
422
+ if (children && children.length && item.startAtLink) {
423
+ this._jumpTo(item.startAtLink, children);
424
+ }
425
+ const newStackSnapshot = this.historyStack;
426
+ if (stackSnapshot.length === newStackSnapshot.length &&
427
+ stackSnapshot.every((stackItem, index) => stackItem === newStackSnapshot[index])) {
428
+ this.currentMenuItems = children;
429
+ }
430
+ this.loading = false;
431
+ this._changeDetectorRef.markForCheck();
432
+ }
433
+ async loadChildrenUrl(item) {
434
+ const sanitizedUrl = this._sanitizer.sanitize(SecurityContext.URL, item.childrenUrl);
435
+ try {
436
+ return await this._http.get(sanitizedUrl, { ...item.httpOptions }).toPromise();
437
+ }
438
+ catch (error) {
439
+ this.handleChildrenUrlError(error);
440
+ return [];
441
+ }
442
+ }
443
+ getTitle(item) {
444
+ if (item) {
445
+ return (removeLeadingHash(item.anchor) ||
446
+ item.title ||
447
+ getTitleFromUrl(item.url) ||
448
+ getTitleFromMarkdownString(item.markdownString) ||
449
+ '').trim();
450
+ }
451
+ }
452
+ getIcon(item) {
453
+ if (item) {
454
+ return item.icon || 'subject';
455
+ }
456
+ }
457
+ handleChildrenUrlError(error) {
458
+ this.childrenUrlError = error.message;
459
+ this._changeDetectorRef.markForCheck();
460
+ }
461
+ handleMarkdownLoaderError(error) {
462
+ this.markdownLoaderError = error.message;
463
+ this._changeDetectorRef.markForCheck();
464
+ }
465
+ async _jumpTo(itemOrPath, children) {
466
+ const historyStack = this.historyStack;
467
+ this.reset();
468
+ if (this.items && this.items.length > 0) {
469
+ let path = [];
470
+ if (Array.isArray(itemOrPath)) {
471
+ path = await this.followPath(this.items, itemOrPath);
472
+ }
473
+ else if (children && children.length > 0) {
474
+ this.historyStack = historyStack;
475
+ path = this.findPath(children, itemOrPath);
476
+ }
477
+ else {
478
+ path = this.findPath(this.items, itemOrPath);
479
+ }
480
+ (path || []).forEach((pathItem) => this.handleItemSelected(pathItem));
481
+ }
482
+ this._changeDetectorRef.markForCheck();
483
+ }
484
+ async followPath(items, path) {
485
+ let pathItems = [];
486
+ let currentLevel = items;
487
+ const compareWith = this.compareWith || defaultCompareWith;
488
+ for (const pathItem of path) {
489
+ const foundItem = currentLevel.find((item) => compareWith(pathItem, item));
490
+ if (foundItem) {
491
+ pathItems = [...pathItems, foundItem];
492
+ if (foundItem.children) {
493
+ currentLevel = foundItem.children;
494
+ }
495
+ else if (foundItem.childrenUrl) {
496
+ currentLevel = await this.loadChildrenUrl(foundItem);
497
+ }
498
+ }
499
+ else {
500
+ break;
501
+ }
502
+ }
503
+ if (pathItems.length !== path.length) {
504
+ pathItems = [];
505
+ }
506
+ return pathItems;
507
+ }
508
+ findPath(items, item) {
509
+ const compareWith = this.compareWith || defaultCompareWith;
510
+ if (items) {
511
+ for (const child of items) {
512
+ if (compareWith(child, item)) {
513
+ return [child];
514
+ }
515
+ const ancestors = this.findPath(child.children, item);
516
+ if (ancestors) {
517
+ return [child, ...ancestors];
518
+ }
519
+ }
520
+ }
521
+ return undefined;
522
+ }
523
+ async handleLinkClick(event) {
524
+ event.preventDefault();
525
+ const link = event.target;
526
+ const url = new URL(link.href);
527
+ this.loading = true;
528
+ this._changeDetectorRef.markForCheck();
529
+ try {
530
+ const markdownString = await this._markdownUrlLoaderService.load(url.href);
531
+ // pass in url to be able to use currentMarkdownItem.url later on
532
+ this.handleItemSelected({ markdownString, url: url.href });
533
+ this.markdownWrapper.nativeElement.scrollTop = 0;
534
+ }
535
+ catch (error) {
536
+ const win = window.open(url.href, '_blank');
537
+ win.focus();
538
+ }
539
+ finally {
540
+ this.loading = false;
541
+ }
542
+ this._changeDetectorRef.markForCheck();
543
+ }
544
+ }
545
+ /** @nocollapse */ /** @nocollapse */ TdMarkdownNavigatorComponent.ɵfac = function TdMarkdownNavigatorComponent_Factory(t) { return new (t || TdMarkdownNavigatorComponent)(i0.ɵɵdirectiveInject(i1.TdMarkdownLoaderService), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i2.DomSanitizer), i0.ɵɵdirectiveInject(i3.HttpClient)); };
546
+ /** @nocollapse */ /** @nocollapse */ TdMarkdownNavigatorComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: TdMarkdownNavigatorComponent, selectors: [["td-markdown-navigator"]], viewQuery: function TdMarkdownNavigatorComponent_Query(rf, ctx) { if (rf & 1) {
547
+ i0.ɵɵviewQuery(_c0, 5);
548
+ } if (rf & 2) {
549
+ let _t;
550
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.markdownWrapper = _t.first);
551
+ } }, hostBindings: function TdMarkdownNavigatorComponent_HostBindings(rf, ctx) { if (rf & 1) {
552
+ i0.ɵɵlistener("click", function TdMarkdownNavigatorComponent_click_HostBindingHandler($event) { return ctx.clickListener($event); });
553
+ } }, inputs: { items: "items", labels: "labels", startAt: "startAt", copyCodeToClipboard: "copyCodeToClipboard", copyCodeTooltips: "copyCodeTooltips", footer: "footer", compareWith: "compareWith" }, outputs: { buttonClicked: "buttonClicked" }, features: [i0.ɵɵNgOnChangesFeature], decls: 2, vars: 2, consts: [[4, "ngIf"], ["layout", "column", "layout-align", "center center", "class", "empty-state", 4, "ngIf"], ["mode", "indeterminate", "color", "accent", 4, "ngIf"], ["id", "td-markdown-navigator-content", 1, "scroll-area"], ["class", "markdown-wrapper", 4, "ngIf"], ["color", "warn", "icon", "error", 3, "sublabel", 4, "ngIf"], ["class", "td-markdown-list", 4, "ngIf"], [4, "ngComponentOutlet"], ["mode", "indeterminate", "color", "accent"], ["id", "td-markdown-navigator-home-button", "mat-icon-button", "", 3, "matTooltip", "click", 4, "ngIf"], ["id", "td-markdown-navigator-back-button", "mat-icon-button", "", 3, "matTooltip", "click", 4, "ngIf"], ["flex", "", "class", "mat-body-2 title truncate", 4, "ngIf"], ["id", "td-markdown-navigator-home-button", "mat-icon-button", "", 3, "matTooltip", "click"], ["id", "td-markdown-navigator-back-button", "mat-icon-button", "", 3, "matTooltip", "click"], ["flex", "", 1, "mat-body-2", "title", "truncate"], [1, "markdown-wrapper"], ["markdownWrapper", ""], [3, "url", "httpOptions", "anchor", "copyCodeToClipboard", "copyCodeTooltips", "loadFailed", 4, "ngIf"], [3, "content", "hostedUrl", "anchor", "copyCodeToClipboard", "copyCodeTooltips", "buttonClicked", 4, "ngIf"], ["color", "warn", "icon", "error", 3, "sublabel"], [3, "url", "httpOptions", "anchor", "copyCodeToClipboard", "copyCodeTooltips", "loadFailed"], [3, "content", "hostedUrl", "anchor", "copyCodeToClipboard", "copyCodeTooltips", "buttonClicked"], [1, "td-markdown-list"], ["mat-list-item", "", "matTooltipPosition", "before", "matTooltipShowDelay", "500", 3, "id", "matTooltip", "click", 4, "ngFor", "ngForOf"], ["mat-list-item", "", "matTooltipPosition", "before", "matTooltipShowDelay", "500", 3, "id", "matTooltip", "click"], ["matListIcon", ""], ["matLine", "", 1, "truncate"], ["layout", "column", "layout-align", "center center", 1, "empty-state"], ["matListAvatar", ""]], template: function TdMarkdownNavigatorComponent_Template(rf, ctx) { if (rf & 1) {
554
+ i0.ɵɵtemplate(0, TdMarkdownNavigatorComponent_ng_container_0_Template, 8, 6, "ng-container", 0);
555
+ i0.ɵɵtemplate(1, TdMarkdownNavigatorComponent_div_1_Template, 5, 1, "div", 1);
556
+ } if (rf & 2) {
557
+ i0.ɵɵproperty("ngIf", !ctx.showEmptyState);
558
+ i0.ɵɵadvance(1);
559
+ i0.ɵɵproperty("ngIf", ctx.showEmptyState);
560
+ } }, directives: [i4.NgIf, i5.MatProgressBar, i6.MatButton, i7.MatTooltip, i8.MatIcon, i9.MatDivider, i10.TdMessageComponent, i11.TdFlavoredMarkdownLoaderComponent, i11.TdFlavoredMarkdownComponent, i12.MatList, i4.NgForOf, i12.MatListItem, i12.MatListIconCssMatStyler, i13.MatLine, i4.NgComponentOutlet, i12.MatListAvatarCssMatStyler], styles: ["[_nghost-%COMP%]{position:relative;height:inherit;height:100%;box-sizing:border-box;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column}[_nghost-%COMP%] .scroll-area[_ngcontent-%COMP%]{min-height:1px;overflow-y:auto;-ms-flex:1;flex:1;box-sizing:border-box}[_nghost-%COMP%] .markdown-wrapper[_ngcontent-%COMP%]{padding:16px 16px 0}[_nghost-%COMP%] .td-markdown-list[_ngcontent-%COMP%] > .mat-list[_ngcontent-%COMP%]{padding-top:0}[_nghost-%COMP%] td-flavored-markdown-loader[_ngcontent-%COMP%] .mat-progress-bar{top:0;left:0;right:0;position:absolute}[_nghost-%COMP%] .title[_ngcontent-%COMP%]{display:inline-block;vertical-align:middle;margin:8px 0;padding-left:16px}.truncate[_ngcontent-%COMP%]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.empty-state[_ngcontent-%COMP%]{padding:32px}.empty-state[_ngcontent-%COMP%] mat-icon[_ngcontent-%COMP%]{font-size:4em}"], changeDetection: 0 });
561
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TdMarkdownNavigatorComponent, [{
562
+ type: Component,
563
+ args: [{ selector: 'td-markdown-navigator', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"!showEmptyState\">\n <mat-progress-bar *ngIf=\"loading\" mode=\"indeterminate\" color=\"accent\"></mat-progress-bar>\n\n <ng-container *ngIf=\"showHeader\">\n <div [style.display]=\"'flex'\">\n <button\n id=\"td-markdown-navigator-home-button\"\n *ngIf=\"showHomeButton\"\n mat-icon-button\n [matTooltip]=\"goHomeLabel\"\n (click)=\"reset()\"\n [attr.data-test]=\"'home-button'\"\n >\n <mat-icon [attr.aria-label]=\"goHomeLabel\">home</mat-icon>\n </button>\n\n <button\n id=\"td-markdown-navigator-back-button\"\n *ngIf=\"showGoBackButton\"\n mat-icon-button\n [matTooltip]=\"goBackLabel\"\n (click)=\"goBack()\"\n [attr.data-test]=\"'back-button'\"\n >\n <mat-icon [attr.aria-label]=\"goBackLabel\">arrow_back</mat-icon>\n </button>\n <span flex *ngIf=\"currentItemTitle\" class=\"mat-body-2 title truncate\" [attr.data-test]=\"'title'\">\n {{ currentItemTitle }}\n </span>\n </div>\n\n <mat-divider [style.position]=\"'relative'\"></mat-divider>\n </ng-container>\n\n <div class=\"scroll-area\" id=\"td-markdown-navigator-content\">\n <div *ngIf=\"showTdMarkdownLoader || showTdMarkdown\" class=\"markdown-wrapper\" #markdownWrapper>\n <td-message\n *ngIf=\"markdownLoaderError\"\n [sublabel]=\"markdownLoaderError\"\n color=\"warn\"\n icon=\"error\"\n [attr.data-test]=\"'markdown-loader-error'\"\n ></td-message>\n <td-flavored-markdown-loader\n *ngIf=\"showTdMarkdownLoader\"\n [url]=\"url\"\n [httpOptions]=\"httpOptions\"\n [anchor]=\"anchor\"\n [copyCodeToClipboard]=\"copyCodeToClipboard\"\n [copyCodeTooltips]=\"copyCodeTooltips\"\n (loadFailed)=\"handleMarkdownLoaderError($event)\"\n ></td-flavored-markdown-loader>\n <td-flavored-markdown\n *ngIf=\"showTdMarkdown\"\n [content]=\"markdownString\"\n [hostedUrl]=\"url\"\n [anchor]=\"anchor\"\n [copyCodeToClipboard]=\"copyCodeToClipboard\"\n [copyCodeTooltips]=\"copyCodeTooltips\"\n (buttonClicked)=\"buttonClicked.emit($event)\"\n ></td-flavored-markdown>\n </div>\n\n <td-message\n *ngIf=\"childrenUrlError\"\n [sublabel]=\"childrenUrlError\"\n color=\"warn\"\n icon=\"error\"\n [attr.data-test]=\"'children-url-error'\"\n ></td-message>\n <div *ngIf=\"showMenu\" class=\"td-markdown-list\">\n <mat-action-list>\n <button\n *ngFor=\"let item of currentMenuItems; index as index\"\n [id]=\"'td-markdown-navigator-list-item-' + (item.id ? item.id : index)\"\n (click)=\"handleItemSelected(item)\"\n mat-list-item\n [matTooltip]=\"getTitle(item)\"\n matTooltipPosition=\"before\"\n matTooltipShowDelay=\"500\"\n >\n <mat-icon matListIcon>\n {{ getIcon(item) }}\n </mat-icon>\n <span matLine class=\"truncate\">\n {{ getTitle(item) }}\n </span>\n <span matLine class=\"truncate\">{{ item.description }}</span>\n <mat-divider></mat-divider>\n </button>\n </mat-action-list>\n </div>\n\n <ng-container *ngComponentOutlet=\"footerComponent\"></ng-container>\n </div>\n</ng-container>\n\n<div *ngIf=\"showEmptyState\" layout=\"column\" layout-align=\"center center\" class=\"empty-state\">\n <mat-icon matListAvatar>subject</mat-icon>\n <h2>{{ emptyStateLabel }}</h2>\n</div>\n", styles: [":host{position:relative;height:inherit;height:100%;box-sizing:border-box;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column}:host .scroll-area{min-height:1px;overflow-y:auto;-ms-flex:1;flex:1;box-sizing:border-box}:host .markdown-wrapper{padding:16px 16px 0}:host .td-markdown-list>.mat-list{padding-top:0}:host td-flavored-markdown-loader ::ng-deep .mat-progress-bar{top:0;left:0;right:0;position:absolute}:host .title{display:inline-block;vertical-align:middle;margin:8px 0;padding-left:16px}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.empty-state{padding:32px}.empty-state mat-icon{font-size:4em}\n"] }]
564
+ }], function () { return [{ type: i1.TdMarkdownLoaderService }, { type: i0.ChangeDetectorRef }, { type: i2.DomSanitizer }, { type: i3.HttpClient }]; }, { items: [{
565
+ type: Input
566
+ }], labels: [{
567
+ type: Input
568
+ }], startAt: [{
569
+ type: Input
570
+ }], copyCodeToClipboard: [{
571
+ type: Input
572
+ }], copyCodeTooltips: [{
573
+ type: Input
574
+ }], footer: [{
575
+ type: Input
576
+ }], compareWith: [{
577
+ type: Input
578
+ }], buttonClicked: [{
579
+ type: Output
580
+ }], markdownWrapper: [{
581
+ type: ViewChild,
582
+ args: ['markdownWrapper']
583
+ }], clickListener: [{
584
+ type: HostListener,
585
+ args: ['click', ['$event']]
586
+ }] }); })();
587
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"markdown-navigator.component.js","sourceRoot":"","sources":["../../../../src/platform/markdown-navigator/markdown-navigator.component.ts","../../../../src/platform/markdown-navigator/markdown-navigator.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  OnChanges,\n  SimpleChanges,\n  HostListener,\n  ViewChild,\n  ElementRef,\n  ChangeDetectorRef,\n  ChangeDetectionStrategy,\n  Type,\n  Output,\n  EventEmitter,\n  SecurityContext,\n} from '@angular/core';\nimport { removeLeadingHash, isAnchorLink, TdMarkdownLoaderService } from '@covalent/markdown';\nimport { ITdFlavoredMarkdownButtonClickEvent } from '@covalent/flavored-markdown';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { HttpClient } from '@angular/common/http';\nimport { ICopyCodeTooltips } from '@covalent/highlight';\n\nexport interface IMarkdownNavigatorItem {\n  id?: string;\n  title?: string;\n  url?: string;\n  httpOptions?: object;\n  markdownString?: string; // raw markdown\n  anchor?: string;\n  children?: IMarkdownNavigatorItem[];\n  childrenUrl?: string;\n  description?: string;\n  icon?: string;\n  footer?: Type<any>;\n  startAtLink?: IMarkdownNavigatorItem;\n}\n\nexport interface IMarkdownNavigatorLabels {\n  goHome?: string;\n  goBack?: string;\n  emptyState?: string;\n}\n\nexport type IMarkdownNavigatorCompareWith = (o1: IMarkdownNavigatorItem, o2: IMarkdownNavigatorItem) => boolean;\n\nexport const DEFAULT_MARKDOWN_NAVIGATOR_LABELS: IMarkdownNavigatorLabels = {\n  goHome: 'Go home',\n  goBack: 'Go back',\n  emptyState: 'No item(s) to display',\n};\n\nfunction getTitleFromUrl(url: string): string {\n  if (url) {\n    const temp: URL = new URL(url);\n    if (temp.hash) {\n      return removeLeadingHash(temp.hash);\n    } else {\n      const path: string[] = temp.pathname.split('/');\n      const fileName: string = path[path.length - 1];\n      return fileName.replace(/\\.[^/.]+$/, ''); // remove .md\n    }\n  }\n  return undefined;\n}\n\nfunction getTitleFromMarkdownString(markdownString: string): string {\n  if (markdownString) {\n    const firstLine: string = markdownString.split(/[\\r\\n]+/).find((line: string) => !!line);\n    return removeLeadingHash(firstLine).trim();\n  }\n  return undefined;\n}\n\nfunction isMarkdownHref(anchor: HTMLAnchorElement): boolean {\n  return !isAnchorLink(anchor) && anchor.pathname.endsWith('.md');\n}\nfunction defaultCompareWith(o1: IMarkdownNavigatorItem, o2: IMarkdownNavigatorItem): boolean {\n  if (o1.id && o2.id) {\n    return o1.id === o2.id;\n  }\n  return o1 === o2;\n}\n\n@Component({\n  selector: 'td-markdown-navigator',\n  templateUrl: './markdown-navigator.component.html',\n  styleUrls: ['./markdown-navigator.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TdMarkdownNavigatorComponent implements OnChanges {\n  /**\n   * items: IMarkdownNavigatorItem[]\n   *\n   * List of IMarkdownNavigatorItems to be rendered\n   */\n  @Input() items: IMarkdownNavigatorItem[];\n\n  /**\n   * labels?: IMarkdownNavigatorLabels\n   *\n   * Translated labels\n   */\n  @Input() labels: IMarkdownNavigatorLabels;\n\n  /**\n   * startAt?: IMarkdownNavigatorItem | IMarkdownNavigatorItem[];\n   *\n   * Item or path to start at\n   */\n  @Input() startAt: IMarkdownNavigatorItem | IMarkdownNavigatorItem[];\n\n  /**\n   * copyCodeToClipboard?: boolean\n   *\n   * Display copy button on code snippets to copy code to clipboard.\n   *\n   */\n  @Input() copyCodeToClipboard: boolean = false;\n\n  /**\n   * copyCodeTooltips?: ICopyCodeTooltips\n   *\n   * Tooltips for copy button to copy and upon copying.\n   */\n  @Input() copyCodeTooltips: ICopyCodeTooltips = {};\n\n  /**\n   * footer?: Type<any>\n   *\n   * Component to be displayed in footer\n   */\n  @Input() footer: Type<any>;\n\n  /**\n   * compareWith?: IMarkdownNavigatorCompareWith\n   *\n   * Function used to find startAt item\n   * Defaults to comparison by strict equality (===)\n   */\n  @Input() compareWith: IMarkdownNavigatorCompareWith;\n\n  @Output() buttonClicked: EventEmitter<ITdFlavoredMarkdownButtonClickEvent> = new EventEmitter();\n\n  @ViewChild('markdownWrapper') markdownWrapper: ElementRef;\n\n  historyStack: IMarkdownNavigatorItem[] = []; // history\n  currentMarkdownItem: IMarkdownNavigatorItem; // currently rendered\n  currentMenuItems: IMarkdownNavigatorItem[] = []; // current menu items\n\n  loading: boolean = false;\n\n  markdownLoaderError: string;\n  childrenUrlError: string;\n\n  constructor(\n    private _markdownUrlLoaderService: TdMarkdownLoaderService,\n    private _changeDetectorRef: ChangeDetectorRef,\n    private _sanitizer: DomSanitizer,\n    private _http: HttpClient,\n  ) {}\n\n  @HostListener('click', ['$event'])\n  clickListener(event: Event): void {\n    const element: HTMLElement = <HTMLElement>event.srcElement;\n    if (element.matches('a[href]') && isMarkdownHref(<HTMLAnchorElement>element)) {\n      this.handleLinkClick(event);\n    }\n  }\n\n  get showGoBackButton(): boolean {\n    return this.historyStack.length > 0;\n  }\n\n  get showHomeButton(): boolean {\n    return this.historyStack.length > 1;\n  }\n\n  get showHeader(): boolean {\n    return this.showHomeButton || this.showGoBackButton || !!this.currentItemTitle;\n  }\n\n  get showMenu(): boolean {\n    return this.currentMenuItems && this.currentMenuItems.length > 0;\n  }\n\n  get showTdMarkdownLoader(): boolean {\n    return !!this.currentMarkdownItem && !!this.currentMarkdownItem.url && !this.showTdMarkdown;\n  }\n\n  get showTdMarkdown(): boolean {\n    return !!this.currentMarkdownItem && !!this.currentMarkdownItem.markdownString;\n  }\n\n  get url(): string {\n    if (this.currentMarkdownItem) {\n      return this.currentMarkdownItem.url;\n    }\n    return undefined;\n  }\n\n  get footerComponent(): any {\n    if (this.currentMarkdownItem && this.currentMarkdownItem.footer) {\n      return this.currentMarkdownItem.footer;\n    }\n    return this.footer;\n  }\n  get httpOptions(): object {\n    if (this.currentMarkdownItem) {\n      return this.currentMarkdownItem.httpOptions;\n    }\n  }\n  get markdownString(): string {\n    if (this.currentMarkdownItem) {\n      return this.currentMarkdownItem.markdownString;\n    }\n  }\n\n  get anchor(): string {\n    if (this.currentMarkdownItem) {\n      return this.currentMarkdownItem.anchor;\n    }\n  }\n\n  get showEmptyState(): boolean {\n    return !this.items || this.items.length < 1;\n  }\n\n  get goHomeLabel(): string {\n    return (this.labels && this.labels.goHome) || DEFAULT_MARKDOWN_NAVIGATOR_LABELS.goHome;\n  }\n\n  get goBackLabel(): string {\n    return (this.labels && this.labels.goBack) || DEFAULT_MARKDOWN_NAVIGATOR_LABELS.goBack;\n  }\n\n  get emptyStateLabel(): string {\n    return (this.labels && this.labels.emptyState) || DEFAULT_MARKDOWN_NAVIGATOR_LABELS.emptyState;\n  }\n\n  get currentItemTitle(): string {\n    if (this.historyStack.length < 1) {\n      return '';\n    } else if (this.currentMarkdownItem) {\n      return this.getTitle(this.currentMarkdownItem);\n    } else if (this.historyStack.length > 0) {\n      return this.getTitle(this.historyStack[this.historyStack.length - 1]);\n    }\n    return '';\n  }\n\n  async ngOnChanges(changes: SimpleChanges): Promise<void> {\n    if (changes.items) {\n      this.reset();\n    }\n    if (changes.startAt && this.items && this.startAt) {\n      this._jumpTo(this.startAt, undefined);\n    }\n  }\n\n  hasChildrenOrChildrenUrl(item: IMarkdownNavigatorItem): boolean {\n    return (item.children && item.children.length > 0) || !!item.childrenUrl;\n  }\n  clearErrors(): void {\n    this.markdownLoaderError = undefined;\n    this.childrenUrlError = undefined;\n  }\n\n  reset(): void {\n    this.loading = false;\n    this.clearErrors();\n    // if single item and no children\n    if (this.items && this.items.length === 1 && !this.hasChildrenOrChildrenUrl(this.items[0])) {\n      this.currentMenuItems = [];\n      this.currentMarkdownItem = this.items[0];\n    } else {\n      this.currentMenuItems = this.items;\n      this.currentMarkdownItem = undefined;\n    }\n    this.historyStack = [];\n    this._changeDetectorRef.markForCheck();\n  }\n\n  goBack(): void {\n    this.loading = false;\n    this.clearErrors();\n    if (this.historyStack.length > 1) {\n      let parent: IMarkdownNavigatorItem = this.historyStack[this.historyStack.length - 2];\n\n      if (parent.startAtLink) {\n        parent = this.historyStack[this.historyStack.length - 3]\n          ? this.historyStack[this.historyStack.length - 3]\n          : undefined;\n        this.historyStack = this.historyStack.slice(0, -1);\n      }\n\n      if (parent) {\n        this.currentMarkdownItem = parent;\n        this.historyStack = this.historyStack.slice(0, -1);\n        this.setChildrenAsCurrentMenuItems(parent);\n      } else {\n        this.reset();\n      }\n    } else {\n      // one level down just go to root\n      this.reset();\n    }\n    this._changeDetectorRef.markForCheck();\n  }\n\n  handleItemSelected(item: IMarkdownNavigatorItem): void {\n    this.clearErrors();\n    this.currentMarkdownItem = item;\n    this.historyStack = [...this.historyStack, item];\n    this.setChildrenAsCurrentMenuItems(item);\n    this._changeDetectorRef.markForCheck();\n  }\n\n  async setChildrenAsCurrentMenuItems(item: IMarkdownNavigatorItem): Promise<void> {\n    this.currentMenuItems = [];\n    this.loading = true;\n    this._changeDetectorRef.markForCheck();\n\n    const stackSnapshot: IMarkdownNavigatorItem[] = this.historyStack;\n    let children: IMarkdownNavigatorItem[] = [];\n    if (item.children) {\n      children = item.children;\n    } else if (item.childrenUrl) {\n      children = await this.loadChildrenUrl(item);\n    }\n    if (children && children.length && item.startAtLink) {\n      this._jumpTo(item.startAtLink, children);\n    }\n    const newStackSnapshot: IMarkdownNavigatorItem[] = this.historyStack;\n    if (\n      stackSnapshot.length === newStackSnapshot.length &&\n      stackSnapshot.every((stackItem: IMarkdownNavigatorItem, index: number) => stackItem === newStackSnapshot[index])\n    ) {\n      this.currentMenuItems = children;\n    }\n\n    this.loading = false;\n    this._changeDetectorRef.markForCheck();\n  }\n\n  async loadChildrenUrl(item: IMarkdownNavigatorItem): Promise<IMarkdownNavigatorItem[]> {\n    const sanitizedUrl: string = this._sanitizer.sanitize(SecurityContext.URL, item.childrenUrl);\n    try {\n      return await this._http.get<IMarkdownNavigatorItem[]>(sanitizedUrl, { ...item.httpOptions }).toPromise();\n    } catch (error) {\n      this.handleChildrenUrlError(error);\n      return [];\n    }\n  }\n\n  getTitle(item: IMarkdownNavigatorItem): string {\n    if (item) {\n      return (\n        removeLeadingHash(item.anchor) ||\n        item.title ||\n        getTitleFromUrl(item.url) ||\n        getTitleFromMarkdownString(item.markdownString) ||\n        ''\n      ).trim();\n    }\n  }\n\n  getIcon(item: IMarkdownNavigatorItem): string {\n    if (item) {\n      return item.icon || 'subject';\n    }\n  }\n\n  handleChildrenUrlError(error: Error): void {\n    this.childrenUrlError = error.message;\n    this._changeDetectorRef.markForCheck();\n  }\n  handleMarkdownLoaderError(error: Error): void {\n    this.markdownLoaderError = error.message;\n    this._changeDetectorRef.markForCheck();\n  }\n\n  private async _jumpTo(\n    itemOrPath: IMarkdownNavigatorItem | IMarkdownNavigatorItem[],\n    children: IMarkdownNavigatorItem[],\n  ): Promise<void> {\n    const historyStack: IMarkdownNavigatorItem[] = this.historyStack;\n    this.reset();\n    if (this.items && this.items.length > 0) {\n      let path: IMarkdownNavigatorItem[] = [];\n      if (Array.isArray(itemOrPath)) {\n        path = await this.followPath(this.items, itemOrPath);\n      } else if (children && children.length > 0) {\n        this.historyStack = historyStack;\n        path = this.findPath(children, itemOrPath);\n      } else {\n        path = this.findPath(this.items, itemOrPath);\n      }\n      (path || []).forEach((pathItem: IMarkdownNavigatorItem) => this.handleItemSelected(pathItem));\n    }\n    this._changeDetectorRef.markForCheck();\n  }\n\n  private async followPath(\n    items: IMarkdownNavigatorItem[],\n    path: IMarkdownNavigatorItem[],\n  ): Promise<IMarkdownNavigatorItem[]> {\n    let pathItems: IMarkdownNavigatorItem[] = [];\n    let currentLevel: IMarkdownNavigatorItem[] = items;\n    const compareWith: IMarkdownNavigatorCompareWith = this.compareWith || defaultCompareWith;\n    for (const pathItem of path) {\n      const foundItem: IMarkdownNavigatorItem = currentLevel.find((item: IMarkdownNavigatorItem) =>\n        compareWith(pathItem, item),\n      );\n\n      if (foundItem) {\n        pathItems = [...pathItems, foundItem];\n\n        if (foundItem.children) {\n          currentLevel = foundItem.children;\n        } else if (foundItem.childrenUrl) {\n          currentLevel = await this.loadChildrenUrl(foundItem);\n        }\n      } else {\n        break;\n      }\n    }\n    if (pathItems.length !== path.length) {\n      pathItems = [];\n    }\n    return pathItems;\n  }\n\n  private findPath(items: IMarkdownNavigatorItem[], item: IMarkdownNavigatorItem): IMarkdownNavigatorItem[] {\n    const compareWith: IMarkdownNavigatorCompareWith = this.compareWith || defaultCompareWith;\n    if (items) {\n      for (const child of items) {\n        if (compareWith(child, item)) {\n          return [child];\n        }\n        const ancestors: IMarkdownNavigatorItem[] = this.findPath(child.children, item);\n        if (ancestors) {\n          return [child, ...ancestors];\n        }\n      }\n    }\n    return undefined;\n  }\n\n  private async handleLinkClick(event: Event): Promise<void> {\n    event.preventDefault();\n    const link: HTMLAnchorElement = <HTMLAnchorElement>event.target;\n    const url: URL = new URL(link.href);\n    this.loading = true;\n    this._changeDetectorRef.markForCheck();\n    try {\n      const markdownString: string = await this._markdownUrlLoaderService.load(url.href);\n      // pass in url to be able to use currentMarkdownItem.url later on\n      this.handleItemSelected({ markdownString, url: url.href });\n      this.markdownWrapper.nativeElement.scrollTop = 0;\n    } catch (error) {\n      const win: Window = window.open(url.href, '_blank');\n      win.focus();\n    } finally {\n      this.loading = false;\n    }\n    this._changeDetectorRef.markForCheck();\n  }\n}\n","<ng-container *ngIf=\"!showEmptyState\">\n  <mat-progress-bar *ngIf=\"loading\" mode=\"indeterminate\" color=\"accent\"></mat-progress-bar>\n\n  <ng-container *ngIf=\"showHeader\">\n    <div [style.display]=\"'flex'\">\n      <button\n        id=\"td-markdown-navigator-home-button\"\n        *ngIf=\"showHomeButton\"\n        mat-icon-button\n        [matTooltip]=\"goHomeLabel\"\n        (click)=\"reset()\"\n        [attr.data-test]=\"'home-button'\"\n      >\n        <mat-icon [attr.aria-label]=\"goHomeLabel\">home</mat-icon>\n      </button>\n\n      <button\n        id=\"td-markdown-navigator-back-button\"\n        *ngIf=\"showGoBackButton\"\n        mat-icon-button\n        [matTooltip]=\"goBackLabel\"\n        (click)=\"goBack()\"\n        [attr.data-test]=\"'back-button'\"\n      >\n        <mat-icon [attr.aria-label]=\"goBackLabel\">arrow_back</mat-icon>\n      </button>\n      <span flex *ngIf=\"currentItemTitle\" class=\"mat-body-2 title truncate\" [attr.data-test]=\"'title'\">\n        {{ currentItemTitle }}\n      </span>\n    </div>\n\n    <mat-divider [style.position]=\"'relative'\"></mat-divider>\n  </ng-container>\n\n  <div class=\"scroll-area\" id=\"td-markdown-navigator-content\">\n    <div *ngIf=\"showTdMarkdownLoader || showTdMarkdown\" class=\"markdown-wrapper\" #markdownWrapper>\n      <td-message\n        *ngIf=\"markdownLoaderError\"\n        [sublabel]=\"markdownLoaderError\"\n        color=\"warn\"\n        icon=\"error\"\n        [attr.data-test]=\"'markdown-loader-error'\"\n      ></td-message>\n      <td-flavored-markdown-loader\n        *ngIf=\"showTdMarkdownLoader\"\n        [url]=\"url\"\n        [httpOptions]=\"httpOptions\"\n        [anchor]=\"anchor\"\n        [copyCodeToClipboard]=\"copyCodeToClipboard\"\n        [copyCodeTooltips]=\"copyCodeTooltips\"\n        (loadFailed)=\"handleMarkdownLoaderError($event)\"\n      ></td-flavored-markdown-loader>\n      <td-flavored-markdown\n        *ngIf=\"showTdMarkdown\"\n        [content]=\"markdownString\"\n        [hostedUrl]=\"url\"\n        [anchor]=\"anchor\"\n        [copyCodeToClipboard]=\"copyCodeToClipboard\"\n        [copyCodeTooltips]=\"copyCodeTooltips\"\n        (buttonClicked)=\"buttonClicked.emit($event)\"\n      ></td-flavored-markdown>\n    </div>\n\n    <td-message\n      *ngIf=\"childrenUrlError\"\n      [sublabel]=\"childrenUrlError\"\n      color=\"warn\"\n      icon=\"error\"\n      [attr.data-test]=\"'children-url-error'\"\n    ></td-message>\n    <div *ngIf=\"showMenu\" class=\"td-markdown-list\">\n      <mat-action-list>\n        <button\n          *ngFor=\"let item of currentMenuItems; index as index\"\n          [id]=\"'td-markdown-navigator-list-item-' + (item.id ? item.id : index)\"\n          (click)=\"handleItemSelected(item)\"\n          mat-list-item\n          [matTooltip]=\"getTitle(item)\"\n          matTooltipPosition=\"before\"\n          matTooltipShowDelay=\"500\"\n        >\n          <mat-icon matListIcon>\n            {{ getIcon(item) }}\n          </mat-icon>\n          <span matLine class=\"truncate\">\n            {{ getTitle(item) }}\n          </span>\n          <span matLine class=\"truncate\">{{ item.description }}</span>\n          <mat-divider></mat-divider>\n        </button>\n      </mat-action-list>\n    </div>\n\n    <ng-container *ngComponentOutlet=\"footerComponent\"></ng-container>\n  </div>\n</ng-container>\n\n<div *ngIf=\"showEmptyState\" layout=\"column\" layout-align=\"center center\" class=\"empty-state\">\n  <mat-icon matListAvatar>subject</mat-icon>\n  <h2>{{ emptyStateLabel }}</h2>\n</div>\n"]}