@covalent/markdown-navigator 4.0.0-alpha.0 → 4.0.0-beta.4

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
@@ -1,698 +0,0 @@
1
- /**
2
- * @fileoverview added by tsickle
3
- * Generated from: markdown-navigator.component.ts
4
- * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
5
- */
6
- import { __awaiter } from "tslib";
7
- import { Component, Input, HostListener, ViewChild, ElementRef, ChangeDetectorRef, ChangeDetectionStrategy, Type, Output, EventEmitter, SecurityContext, } from '@angular/core';
8
- import { removeLeadingHash, isAnchorLink, TdMarkdownLoaderService } from '@covalent/markdown';
9
- import { DomSanitizer } from '@angular/platform-browser';
10
- import { HttpClient } from '@angular/common/http';
11
- /**
12
- * @record
13
- */
14
- export function IMarkdownNavigatorItem() { }
15
- if (false) {
16
- /** @type {?|undefined} */
17
- IMarkdownNavigatorItem.prototype.id;
18
- /** @type {?|undefined} */
19
- IMarkdownNavigatorItem.prototype.title;
20
- /** @type {?|undefined} */
21
- IMarkdownNavigatorItem.prototype.url;
22
- /** @type {?|undefined} */
23
- IMarkdownNavigatorItem.prototype.httpOptions;
24
- /** @type {?|undefined} */
25
- IMarkdownNavigatorItem.prototype.markdownString;
26
- /** @type {?|undefined} */
27
- IMarkdownNavigatorItem.prototype.anchor;
28
- /** @type {?|undefined} */
29
- IMarkdownNavigatorItem.prototype.children;
30
- /** @type {?|undefined} */
31
- IMarkdownNavigatorItem.prototype.childrenUrl;
32
- /** @type {?|undefined} */
33
- IMarkdownNavigatorItem.prototype.description;
34
- /** @type {?|undefined} */
35
- IMarkdownNavigatorItem.prototype.icon;
36
- /** @type {?|undefined} */
37
- IMarkdownNavigatorItem.prototype.footer;
38
- /** @type {?|undefined} */
39
- IMarkdownNavigatorItem.prototype.startAtLink;
40
- }
41
- /**
42
- * @record
43
- */
44
- export function IMarkdownNavigatorLabels() { }
45
- if (false) {
46
- /** @type {?|undefined} */
47
- IMarkdownNavigatorLabels.prototype.goHome;
48
- /** @type {?|undefined} */
49
- IMarkdownNavigatorLabels.prototype.goBack;
50
- /** @type {?|undefined} */
51
- IMarkdownNavigatorLabels.prototype.emptyState;
52
- }
53
- /** @type {?} */
54
- export const DEFAULT_MARKDOWN_NAVIGATOR_LABELS = {
55
- goHome: 'Go home',
56
- goBack: 'Go back',
57
- emptyState: 'No item(s) to display',
58
- };
59
- /**
60
- * @param {?} url
61
- * @return {?}
62
- */
63
- function getTitleFromUrl(url) {
64
- if (url) {
65
- /** @type {?} */
66
- const temp = new URL(url);
67
- if (temp.hash) {
68
- return removeLeadingHash(temp.hash);
69
- }
70
- else {
71
- /** @type {?} */
72
- const path = temp.pathname.split('/');
73
- /** @type {?} */
74
- const fileName = path[path.length - 1];
75
- return fileName.replace(/\.[^/.]+$/, ''); // remove .md
76
- }
77
- }
78
- return undefined;
79
- }
80
- /**
81
- * @param {?} markdownString
82
- * @return {?}
83
- */
84
- function getTitleFromMarkdownString(markdownString) {
85
- if (markdownString) {
86
- /** @type {?} */
87
- const firstLine = markdownString.split(/[\r\n]+/).find((/**
88
- * @param {?} line
89
- * @return {?}
90
- */
91
- (line) => !!line));
92
- return removeLeadingHash(firstLine).trim();
93
- }
94
- return undefined;
95
- }
96
- /**
97
- * @param {?} anchor
98
- * @return {?}
99
- */
100
- function isMarkdownHref(anchor) {
101
- return !isAnchorLink(anchor) && anchor.pathname.endsWith('.md');
102
- }
103
- /**
104
- * @param {?} o1
105
- * @param {?} o2
106
- * @return {?}
107
- */
108
- function defaultCompareWith(o1, o2) {
109
- if (o1.id && o2.id) {
110
- return o1.id === o2.id;
111
- }
112
- return o1 === o2;
113
- }
114
- export class TdMarkdownNavigatorComponent {
115
- /**
116
- * @param {?} _markdownUrlLoaderService
117
- * @param {?} _changeDetectorRef
118
- * @param {?} _sanitizer
119
- * @param {?} _http
120
- */
121
- constructor(_markdownUrlLoaderService, _changeDetectorRef, _sanitizer, _http) {
122
- this._markdownUrlLoaderService = _markdownUrlLoaderService;
123
- this._changeDetectorRef = _changeDetectorRef;
124
- this._sanitizer = _sanitizer;
125
- this._http = _http;
126
- /**
127
- * copyCodeToClipboard?: boolean
128
- *
129
- * Display copy button on code snippets to copy code to clipboard.
130
- *
131
- */
132
- this.copyCodeToClipboard = false;
133
- /**
134
- * copyCodeTooltips?: ICopyCodeTooltips
135
- *
136
- * Tooltips for copy button to copy and upon copying.
137
- */
138
- this.copyCodeTooltips = {};
139
- this.buttonClicked = new EventEmitter();
140
- this.historyStack = []; // history
141
- // currently rendered
142
- this.currentMenuItems = []; // current menu items
143
- // current menu items
144
- this.loading = false;
145
- }
146
- /**
147
- * @param {?} event
148
- * @return {?}
149
- */
150
- clickListener(event) {
151
- /** @type {?} */
152
- const element = (/** @type {?} */ (event.srcElement));
153
- if (element.matches('a[href]') && isMarkdownHref((/** @type {?} */ (element)))) {
154
- this.handleLinkClick(event);
155
- }
156
- }
157
- /**
158
- * @return {?}
159
- */
160
- get showGoBackButton() {
161
- return this.historyStack.length > 0;
162
- }
163
- /**
164
- * @return {?}
165
- */
166
- get showHomeButton() {
167
- return this.historyStack.length > 1;
168
- }
169
- /**
170
- * @return {?}
171
- */
172
- get showHeader() {
173
- return this.showHomeButton || this.showGoBackButton || !!this.currentItemTitle;
174
- }
175
- /**
176
- * @return {?}
177
- */
178
- get showMenu() {
179
- return this.currentMenuItems && this.currentMenuItems.length > 0;
180
- }
181
- /**
182
- * @return {?}
183
- */
184
- get showTdMarkdownLoader() {
185
- return !!this.currentMarkdownItem && !!this.currentMarkdownItem.url && !this.showTdMarkdown;
186
- }
187
- /**
188
- * @return {?}
189
- */
190
- get showTdMarkdown() {
191
- return !!this.currentMarkdownItem && !!this.currentMarkdownItem.markdownString;
192
- }
193
- /**
194
- * @return {?}
195
- */
196
- get url() {
197
- if (this.currentMarkdownItem) {
198
- return this.currentMarkdownItem.url;
199
- }
200
- return undefined;
201
- }
202
- /**
203
- * @return {?}
204
- */
205
- get footerComponent() {
206
- if (this.currentMarkdownItem && this.currentMarkdownItem.footer) {
207
- return this.currentMarkdownItem.footer;
208
- }
209
- return this.footer;
210
- }
211
- /**
212
- * @return {?}
213
- */
214
- get httpOptions() {
215
- if (this.currentMarkdownItem) {
216
- return this.currentMarkdownItem.httpOptions;
217
- }
218
- }
219
- /**
220
- * @return {?}
221
- */
222
- get markdownString() {
223
- if (this.currentMarkdownItem) {
224
- return this.currentMarkdownItem.markdownString;
225
- }
226
- }
227
- /**
228
- * @return {?}
229
- */
230
- get anchor() {
231
- if (this.currentMarkdownItem) {
232
- return this.currentMarkdownItem.anchor;
233
- }
234
- }
235
- /**
236
- * @return {?}
237
- */
238
- get showEmptyState() {
239
- return !this.items || this.items.length < 1;
240
- }
241
- /**
242
- * @return {?}
243
- */
244
- get goHomeLabel() {
245
- return (this.labels && this.labels.goHome) || DEFAULT_MARKDOWN_NAVIGATOR_LABELS.goHome;
246
- }
247
- /**
248
- * @return {?}
249
- */
250
- get goBackLabel() {
251
- return (this.labels && this.labels.goBack) || DEFAULT_MARKDOWN_NAVIGATOR_LABELS.goBack;
252
- }
253
- /**
254
- * @return {?}
255
- */
256
- get emptyStateLabel() {
257
- return (this.labels && this.labels.emptyState) || DEFAULT_MARKDOWN_NAVIGATOR_LABELS.emptyState;
258
- }
259
- /**
260
- * @return {?}
261
- */
262
- get currentItemTitle() {
263
- if (this.historyStack.length < 1) {
264
- return '';
265
- }
266
- else if (this.currentMarkdownItem) {
267
- return this.getTitle(this.currentMarkdownItem);
268
- }
269
- else if (this.historyStack.length > 0) {
270
- return this.getTitle(this.historyStack[this.historyStack.length - 1]);
271
- }
272
- return '';
273
- }
274
- /**
275
- * @param {?} changes
276
- * @return {?}
277
- */
278
- ngOnChanges(changes) {
279
- return __awaiter(this, void 0, void 0, function* () {
280
- if (changes.items) {
281
- this.reset();
282
- }
283
- if (changes.startAt && this.items && this.startAt) {
284
- this._jumpTo(this.startAt, undefined);
285
- }
286
- });
287
- }
288
- /**
289
- * @param {?} item
290
- * @return {?}
291
- */
292
- hasChildrenOrChildrenUrl(item) {
293
- return (item.children && item.children.length > 0) || !!item.childrenUrl;
294
- }
295
- /**
296
- * @return {?}
297
- */
298
- clearErrors() {
299
- this.markdownLoaderError = undefined;
300
- this.childrenUrlError = undefined;
301
- }
302
- /**
303
- * @return {?}
304
- */
305
- reset() {
306
- this.loading = false;
307
- this.clearErrors();
308
- // if single item and no children
309
- if (this.items && this.items.length === 1 && !this.hasChildrenOrChildrenUrl(this.items[0])) {
310
- this.currentMenuItems = [];
311
- this.currentMarkdownItem = this.items[0];
312
- }
313
- else {
314
- this.currentMenuItems = this.items;
315
- this.currentMarkdownItem = undefined;
316
- }
317
- this.historyStack = [];
318
- this._changeDetectorRef.markForCheck();
319
- }
320
- /**
321
- * @return {?}
322
- */
323
- goBack() {
324
- this.loading = false;
325
- this.clearErrors();
326
- if (this.historyStack.length > 1) {
327
- /** @type {?} */
328
- let parent = this.historyStack[this.historyStack.length - 2];
329
- if (parent.startAtLink) {
330
- parent = this.historyStack[this.historyStack.length - 3]
331
- ? this.historyStack[this.historyStack.length - 3]
332
- : undefined;
333
- this.historyStack = this.historyStack.slice(0, -1);
334
- }
335
- if (parent) {
336
- this.currentMarkdownItem = parent;
337
- this.historyStack = this.historyStack.slice(0, -1);
338
- this.setChildrenAsCurrentMenuItems(parent);
339
- }
340
- else {
341
- this.reset();
342
- }
343
- }
344
- else {
345
- // one level down just go to root
346
- this.reset();
347
- }
348
- this._changeDetectorRef.markForCheck();
349
- }
350
- /**
351
- * @param {?} item
352
- * @return {?}
353
- */
354
- handleItemSelected(item) {
355
- this.clearErrors();
356
- this.currentMarkdownItem = item;
357
- this.historyStack = [...this.historyStack, item];
358
- this.setChildrenAsCurrentMenuItems(item);
359
- this._changeDetectorRef.markForCheck();
360
- }
361
- /**
362
- * @param {?} item
363
- * @return {?}
364
- */
365
- setChildrenAsCurrentMenuItems(item) {
366
- return __awaiter(this, void 0, void 0, function* () {
367
- this.currentMenuItems = [];
368
- this.loading = true;
369
- this._changeDetectorRef.markForCheck();
370
- /** @type {?} */
371
- const stackSnapshot = this.historyStack;
372
- /** @type {?} */
373
- let children = [];
374
- if (item.children) {
375
- children = item.children;
376
- }
377
- else if (item.childrenUrl) {
378
- children = yield this.loadChildrenUrl(item);
379
- }
380
- if (children && children.length && item.startAtLink) {
381
- this._jumpTo(item.startAtLink, children);
382
- }
383
- /** @type {?} */
384
- const newStackSnapshot = this.historyStack;
385
- if (stackSnapshot.length === newStackSnapshot.length &&
386
- stackSnapshot.every((/**
387
- * @param {?} stackItem
388
- * @param {?} index
389
- * @return {?}
390
- */
391
- (stackItem, index) => stackItem === newStackSnapshot[index]))) {
392
- this.currentMenuItems = children;
393
- }
394
- this.loading = false;
395
- this._changeDetectorRef.markForCheck();
396
- });
397
- }
398
- /**
399
- * @param {?} item
400
- * @return {?}
401
- */
402
- loadChildrenUrl(item) {
403
- return __awaiter(this, void 0, void 0, function* () {
404
- /** @type {?} */
405
- const sanitizedUrl = this._sanitizer.sanitize(SecurityContext.URL, item.childrenUrl);
406
- try {
407
- return yield this._http.get(sanitizedUrl, Object.assign({}, item.httpOptions)).toPromise();
408
- }
409
- catch (error) {
410
- this.handleChildrenUrlError(error);
411
- return [];
412
- }
413
- });
414
- }
415
- /**
416
- * @param {?} item
417
- * @return {?}
418
- */
419
- getTitle(item) {
420
- if (item) {
421
- return (removeLeadingHash(item.anchor) ||
422
- item.title ||
423
- getTitleFromUrl(item.url) ||
424
- getTitleFromMarkdownString(item.markdownString) ||
425
- '').trim();
426
- }
427
- }
428
- /**
429
- * @param {?} item
430
- * @return {?}
431
- */
432
- getIcon(item) {
433
- if (item) {
434
- return item.icon || 'subject';
435
- }
436
- }
437
- /**
438
- * @param {?} error
439
- * @return {?}
440
- */
441
- handleChildrenUrlError(error) {
442
- this.childrenUrlError = error.message;
443
- this._changeDetectorRef.markForCheck();
444
- }
445
- /**
446
- * @param {?} error
447
- * @return {?}
448
- */
449
- handleMarkdownLoaderError(error) {
450
- this.markdownLoaderError = error.message;
451
- this._changeDetectorRef.markForCheck();
452
- }
453
- /**
454
- * @private
455
- * @param {?} itemOrPath
456
- * @param {?} children
457
- * @return {?}
458
- */
459
- _jumpTo(itemOrPath, children) {
460
- return __awaiter(this, void 0, void 0, function* () {
461
- /** @type {?} */
462
- const historyStack = this.historyStack;
463
- this.reset();
464
- if (this.items && this.items.length > 0) {
465
- /** @type {?} */
466
- let path = [];
467
- if (Array.isArray(itemOrPath)) {
468
- path = yield this.followPath(this.items, itemOrPath);
469
- }
470
- else if (children && children.length > 0) {
471
- this.historyStack = historyStack;
472
- path = this.findPath(children, itemOrPath);
473
- }
474
- else {
475
- path = this.findPath(this.items, itemOrPath);
476
- }
477
- (path || []).forEach((/**
478
- * @param {?} pathItem
479
- * @return {?}
480
- */
481
- (pathItem) => this.handleItemSelected(pathItem)));
482
- }
483
- this._changeDetectorRef.markForCheck();
484
- });
485
- }
486
- /**
487
- * @private
488
- * @param {?} items
489
- * @param {?} path
490
- * @return {?}
491
- */
492
- followPath(items, path) {
493
- return __awaiter(this, void 0, void 0, function* () {
494
- /** @type {?} */
495
- let pathItems = [];
496
- /** @type {?} */
497
- let currentLevel = items;
498
- /** @type {?} */
499
- const compareWith = this.compareWith || defaultCompareWith;
500
- for (const pathItem of path) {
501
- /** @type {?} */
502
- const foundItem = currentLevel.find((/**
503
- * @param {?} item
504
- * @return {?}
505
- */
506
- (item) => compareWith(pathItem, item)));
507
- if (foundItem) {
508
- pathItems = [...pathItems, foundItem];
509
- if (foundItem.children) {
510
- currentLevel = foundItem.children;
511
- }
512
- else if (foundItem.childrenUrl) {
513
- currentLevel = yield this.loadChildrenUrl(foundItem);
514
- }
515
- }
516
- else {
517
- break;
518
- }
519
- }
520
- if (pathItems.length !== path.length) {
521
- pathItems = [];
522
- }
523
- return pathItems;
524
- });
525
- }
526
- /**
527
- * @private
528
- * @param {?} items
529
- * @param {?} item
530
- * @return {?}
531
- */
532
- findPath(items, item) {
533
- /** @type {?} */
534
- const compareWith = this.compareWith || defaultCompareWith;
535
- if (items) {
536
- for (const child of items) {
537
- if (compareWith(child, item)) {
538
- return [child];
539
- }
540
- /** @type {?} */
541
- const ancestors = this.findPath(child.children, item);
542
- if (ancestors) {
543
- return [child, ...ancestors];
544
- }
545
- }
546
- }
547
- return undefined;
548
- }
549
- /**
550
- * @private
551
- * @param {?} event
552
- * @return {?}
553
- */
554
- handleLinkClick(event) {
555
- return __awaiter(this, void 0, void 0, function* () {
556
- event.preventDefault();
557
- /** @type {?} */
558
- const link = (/** @type {?} */ (event.target));
559
- /** @type {?} */
560
- const url = new URL(link.href);
561
- this.loading = true;
562
- this._changeDetectorRef.markForCheck();
563
- try {
564
- /** @type {?} */
565
- const markdownString = yield this._markdownUrlLoaderService.load(url.href);
566
- // pass in url to be able to use currentMarkdownItem.url later on
567
- this.handleItemSelected({ markdownString, url: url.href });
568
- this.markdownWrapper.nativeElement.scrollTop = 0;
569
- }
570
- catch (error) {
571
- /** @type {?} */
572
- const win = window.open(url.href, '_blank');
573
- win.focus();
574
- }
575
- finally {
576
- this.loading = false;
577
- }
578
- this._changeDetectorRef.markForCheck();
579
- });
580
- }
581
- }
582
- TdMarkdownNavigatorComponent.decorators = [
583
- { type: Component, args: [{
584
- selector: 'td-markdown-navigator',
585
- 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",
586
- changeDetection: ChangeDetectionStrategy.OnPush,
587
- styles: [":host{-ms-flex-direction:column;box-sizing:border-box;display:-ms-flexbox;display:flex;flex-direction:column;height:inherit;height:100%;position:relative}:host .scroll-area{-ms-flex:1;box-sizing:border-box;flex:1;min-height:1px;overflow-y:auto}: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{left:0;position:absolute;right:0;top:0}:host .title{display:inline-block;margin:8px 0;padding-left:16px;vertical-align:middle}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.empty-state{padding:32px}.empty-state mat-icon{font-size:4em}"]
588
- }] }
589
- ];
590
- /** @nocollapse */
591
- TdMarkdownNavigatorComponent.ctorParameters = () => [
592
- { type: TdMarkdownLoaderService },
593
- { type: ChangeDetectorRef },
594
- { type: DomSanitizer },
595
- { type: HttpClient }
596
- ];
597
- TdMarkdownNavigatorComponent.propDecorators = {
598
- items: [{ type: Input }],
599
- labels: [{ type: Input }],
600
- startAt: [{ type: Input }],
601
- copyCodeToClipboard: [{ type: Input }],
602
- copyCodeTooltips: [{ type: Input }],
603
- footer: [{ type: Input }],
604
- compareWith: [{ type: Input }],
605
- buttonClicked: [{ type: Output }],
606
- markdownWrapper: [{ type: ViewChild, args: ['markdownWrapper',] }],
607
- clickListener: [{ type: HostListener, args: ['click', ['$event'],] }]
608
- };
609
- if (false) {
610
- /**
611
- * items: IMarkdownNavigatorItem[]
612
- *
613
- * List of IMarkdownNavigatorItems to be rendered
614
- * @type {?}
615
- */
616
- TdMarkdownNavigatorComponent.prototype.items;
617
- /**
618
- * labels?: IMarkdownNavigatorLabels
619
- *
620
- * Translated labels
621
- * @type {?}
622
- */
623
- TdMarkdownNavigatorComponent.prototype.labels;
624
- /**
625
- * startAt?: IMarkdownNavigatorItem | IMarkdownNavigatorItem[];
626
- *
627
- * Item or path to start at
628
- * @type {?}
629
- */
630
- TdMarkdownNavigatorComponent.prototype.startAt;
631
- /**
632
- * copyCodeToClipboard?: boolean
633
- *
634
- * Display copy button on code snippets to copy code to clipboard.
635
- *
636
- * @type {?}
637
- */
638
- TdMarkdownNavigatorComponent.prototype.copyCodeToClipboard;
639
- /**
640
- * copyCodeTooltips?: ICopyCodeTooltips
641
- *
642
- * Tooltips for copy button to copy and upon copying.
643
- * @type {?}
644
- */
645
- TdMarkdownNavigatorComponent.prototype.copyCodeTooltips;
646
- /**
647
- * footer?: Type<any>
648
- *
649
- * Component to be displayed in footer
650
- * @type {?}
651
- */
652
- TdMarkdownNavigatorComponent.prototype.footer;
653
- /**
654
- * compareWith?: IMarkdownNavigatorCompareWith
655
- *
656
- * Function used to find startAt item
657
- * Defaults to comparison by strict equality (===)
658
- * @type {?}
659
- */
660
- TdMarkdownNavigatorComponent.prototype.compareWith;
661
- /** @type {?} */
662
- TdMarkdownNavigatorComponent.prototype.buttonClicked;
663
- /** @type {?} */
664
- TdMarkdownNavigatorComponent.prototype.markdownWrapper;
665
- /** @type {?} */
666
- TdMarkdownNavigatorComponent.prototype.historyStack;
667
- /** @type {?} */
668
- TdMarkdownNavigatorComponent.prototype.currentMarkdownItem;
669
- /** @type {?} */
670
- TdMarkdownNavigatorComponent.prototype.currentMenuItems;
671
- /** @type {?} */
672
- TdMarkdownNavigatorComponent.prototype.loading;
673
- /** @type {?} */
674
- TdMarkdownNavigatorComponent.prototype.markdownLoaderError;
675
- /** @type {?} */
676
- TdMarkdownNavigatorComponent.prototype.childrenUrlError;
677
- /**
678
- * @type {?}
679
- * @private
680
- */
681
- TdMarkdownNavigatorComponent.prototype._markdownUrlLoaderService;
682
- /**
683
- * @type {?}
684
- * @private
685
- */
686
- TdMarkdownNavigatorComponent.prototype._changeDetectorRef;
687
- /**
688
- * @type {?}
689
- * @private
690
- */
691
- TdMarkdownNavigatorComponent.prototype._sanitizer;
692
- /**
693
- * @type {?}
694
- * @private
695
- */
696
- TdMarkdownNavigatorComponent.prototype._http;
697
- }
698
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"markdown-navigator.component.js","sourceRoot":"../../../../src/platform/markdown-navigator/","sources":["markdown-navigator.component.ts"],"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"]}