@covalent/markdown-navigator 6.4.0 → 6.4.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.
@@ -1,11 +1,13 @@
1
+ @use '@angular/material' as mat;
2
+
1
3
  @mixin covalent-markdown-navigator-typography($fontConfig) {
2
4
  td-markdown-navigator {
3
5
  td-breadcrumbs .mat-button {
4
- @include mat-typography-level-to-styles($fontConfig, caption);
6
+ @include mat.typography-level($fontConfig, caption);
5
7
  }
6
8
 
7
9
  .breadcrumb-current-title {
8
- @include mat-typography-level-to-styles($fontConfig, headline);
10
+ @include mat.typography-level($fontConfig, headline);
9
11
  }
10
12
  }
11
13
  }
@@ -0,0 +1,87 @@
1
+ import { Component, Output, EventEmitter, Input, ChangeDetectionStrategy, Type, } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@covalent/core/dialogs";
4
+ import * as i2 from "../markdown-navigator.component";
5
+ export const DEFAULT_MARKDOWN_NAVIGATOR_WINDOW_LABELS = {
6
+ title: 'Help',
7
+ close: 'Close',
8
+ dock: 'Dock',
9
+ unDock: 'Undock',
10
+ };
11
+ export class TdMarkdownNavigatorWindowComponent {
12
+ constructor() {
13
+ this.toolbarColor = 'primary';
14
+ this.docked = false;
15
+ this.copyCodeToClipboard = false;
16
+ this.copyCodeTooltips = {};
17
+ this.closed = new EventEmitter();
18
+ this.dockToggled = new EventEmitter();
19
+ this.buttonClicked = new EventEmitter();
20
+ this.itemSelected = new EventEmitter();
21
+ }
22
+ get markdownNavigatorLabels() {
23
+ if (!this.labels) {
24
+ return undefined;
25
+ }
26
+ const { goHome, goBack, emptyState } = this.labels;
27
+ return {
28
+ goHome,
29
+ goBack,
30
+ emptyState,
31
+ };
32
+ }
33
+ get titleLabel() {
34
+ return ((this.labels && this.labels.title) ||
35
+ DEFAULT_MARKDOWN_NAVIGATOR_WINDOW_LABELS.title);
36
+ }
37
+ get closeLabel() {
38
+ return ((this.labels && this.labels.close) ||
39
+ DEFAULT_MARKDOWN_NAVIGATOR_WINDOW_LABELS.close);
40
+ }
41
+ get toggleDockedStateLabel() {
42
+ if (this.docked) {
43
+ return ((this.labels && this.labels.unDock) ||
44
+ DEFAULT_MARKDOWN_NAVIGATOR_WINDOW_LABELS.unDock);
45
+ }
46
+ else {
47
+ return ((this.labels && this.labels.dock) ||
48
+ DEFAULT_MARKDOWN_NAVIGATOR_WINDOW_LABELS.dock);
49
+ }
50
+ }
51
+ toggleDockedState() {
52
+ this.dockToggled.emit(this.docked);
53
+ }
54
+ }
55
+ TdMarkdownNavigatorWindowComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TdMarkdownNavigatorWindowComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
56
+ TdMarkdownNavigatorWindowComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TdMarkdownNavigatorWindowComponent, selector: "td-markdown-navigator-window", inputs: { items: "items", labels: "labels", toolbarColor: "toolbarColor", startAt: "startAt", compareWith: "compareWith", docked: "docked", copyCodeToClipboard: "copyCodeToClipboard", copyCodeTooltips: "copyCodeTooltips", footer: "footer" }, outputs: { closed: "closed", dockToggled: "dockToggled", buttonClicked: "buttonClicked", itemSelected: "itemSelected" }, ngImport: i0, template: "<td-window-dialog\n [toolbarColor]=\"toolbarColor\"\n [docked]=\"docked\"\n [title]=\"titleLabel\"\n [toggleDockedStateLabel]=\"toggleDockedStateLabel\"\n [closeLabel]=\"closeLabel\"\n (dockToggled)=\"toggleDockedState()\"\n (closed)=\"closed.emit()\"\n>\n <td-markdown-navigator\n [items]=\"items\"\n [labels]=\"markdownNavigatorLabels\"\n [style.display]=\"docked ? 'none' : 'inherit'\"\n [startAt]=\"startAt\"\n [compareWith]=\"compareWith\"\n [footer]=\"footer\"\n [copyCodeToClipboard]=\"copyCodeToClipboard\"\n [copyCodeTooltips]=\"copyCodeTooltips\"\n (buttonClicked)=\"buttonClicked.emit($event)\"\n (itemSelected)=\"itemSelected.emit($event)\"\n ></td-markdown-navigator>\n</td-window-dialog>\n", styles: [":host{height:100%;display:flex;flex-direction:column}td-markdown-navigator{height:calc(100% - 56px)}\n"], dependencies: [{ kind: "component", type: i1.TdWindowDialogComponent, selector: "td-window-dialog", inputs: ["toolbarColor", "docked", "title", "toggleDockedStateLabel", "closeLabel"], outputs: ["dockToggled", "closed"] }, { kind: "component", type: i2.TdMarkdownNavigatorComponent, selector: "td-markdown-navigator", inputs: ["items", "labels", "startAt", "copyCodeToClipboard", "copyCodeTooltips", "footer", "compareWith"], outputs: ["buttonClicked", "itemSelected"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
57
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TdMarkdownNavigatorWindowComponent, decorators: [{
58
+ type: Component,
59
+ args: [{ selector: 'td-markdown-navigator-window', changeDetection: ChangeDetectionStrategy.OnPush, template: "<td-window-dialog\n [toolbarColor]=\"toolbarColor\"\n [docked]=\"docked\"\n [title]=\"titleLabel\"\n [toggleDockedStateLabel]=\"toggleDockedStateLabel\"\n [closeLabel]=\"closeLabel\"\n (dockToggled)=\"toggleDockedState()\"\n (closed)=\"closed.emit()\"\n>\n <td-markdown-navigator\n [items]=\"items\"\n [labels]=\"markdownNavigatorLabels\"\n [style.display]=\"docked ? 'none' : 'inherit'\"\n [startAt]=\"startAt\"\n [compareWith]=\"compareWith\"\n [footer]=\"footer\"\n [copyCodeToClipboard]=\"copyCodeToClipboard\"\n [copyCodeTooltips]=\"copyCodeTooltips\"\n (buttonClicked)=\"buttonClicked.emit($event)\"\n (itemSelected)=\"itemSelected.emit($event)\"\n ></td-markdown-navigator>\n</td-window-dialog>\n", styles: [":host{height:100%;display:flex;flex-direction:column}td-markdown-navigator{height:calc(100% - 56px)}\n"] }]
60
+ }], propDecorators: { items: [{
61
+ type: Input
62
+ }], labels: [{
63
+ type: Input
64
+ }], toolbarColor: [{
65
+ type: Input
66
+ }], startAt: [{
67
+ type: Input
68
+ }], compareWith: [{
69
+ type: Input
70
+ }], docked: [{
71
+ type: Input
72
+ }], copyCodeToClipboard: [{
73
+ type: Input
74
+ }], copyCodeTooltips: [{
75
+ type: Input
76
+ }], footer: [{
77
+ type: Input
78
+ }], closed: [{
79
+ type: Output
80
+ }], dockToggled: [{
81
+ type: Output
82
+ }], buttonClicked: [{
83
+ type: Output
84
+ }], itemSelected: [{
85
+ type: Output
86
+ }] } });
87
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFya2Rvd24tbmF2aWdhdG9yLXdpbmRvdy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL21hcmtkb3duLW5hdmlnYXRvci9zcmMvbWFya2Rvd24tbmF2aWdhdG9yLXdpbmRvdy9tYXJrZG93bi1uYXZpZ2F0b3Itd2luZG93LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL2xpYnMvbWFya2Rvd24tbmF2aWdhdG9yL3NyYy9tYXJrZG93bi1uYXZpZ2F0b3Itd2luZG93L21hcmtkb3duLW5hdmlnYXRvci13aW5kb3cuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCxNQUFNLEVBQ04sWUFBWSxFQUNaLEtBQUssRUFDTCx1QkFBdUIsRUFDdkIsSUFBSSxHQUNMLE1BQU0sZUFBZSxDQUFDOzs7O0FBaUJ2QixNQUFNLENBQUMsTUFBTSx3Q0FBd0MsR0FDbkQ7SUFDRSxLQUFLLEVBQUUsTUFBTTtJQUNiLEtBQUssRUFBRSxPQUFPO0lBQ2QsSUFBSSxFQUFFLE1BQU07SUFDWixNQUFNLEVBQUUsUUFBUTtDQUNqQixDQUFDO0FBUUosTUFBTSxPQUFPLGtDQUFrQztJQU4vQztRQVNXLGlCQUFZLEdBQWlCLFNBQVMsQ0FBQztRQUd2QyxXQUFNLEdBQUksS0FBSyxDQUFDO1FBQ2hCLHdCQUFtQixHQUFJLEtBQUssQ0FBQztRQUM3QixxQkFBZ0IsR0FBdUIsRUFBRSxDQUFDO1FBR3pDLFdBQU0sR0FBdUIsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUNoRCxnQkFBVyxHQUEwQixJQUFJLFlBQVksRUFBRSxDQUFDO1FBQ3hELGtCQUFhLEdBQ3JCLElBQUksWUFBWSxFQUFFLENBQUM7UUFDWCxpQkFBWSxHQUNwQixJQUFJLFlBQVksRUFBRSxDQUFDO0tBOEN0QjtJQTVDQyxJQUFJLHVCQUF1QjtRQUN6QixJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRTtZQUNoQixPQUFPLFNBQVMsQ0FBQztTQUNsQjtRQUVELE1BQU0sRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxHQUNsQyxJQUFJLENBQUMsTUFBTSxDQUFDO1FBQ2QsT0FBTztZQUNMLE1BQU07WUFDTixNQUFNO1lBQ04sVUFBVTtTQUNYLENBQUM7SUFDSixDQUFDO0lBQ0QsSUFBSSxVQUFVO1FBQ1osT0FBTyxDQUNMLENBQUMsSUFBSSxDQUFDLE1BQU0sSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQztZQUNsQyx3Q0FBd0MsQ0FBQyxLQUFLLENBQy9DLENBQUM7SUFDSixDQUFDO0lBRUQsSUFBSSxVQUFVO1FBQ1osT0FBTyxDQUNMLENBQUMsSUFBSSxDQUFDLE1BQU0sSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQztZQUNsQyx3Q0FBd0MsQ0FBQyxLQUFLLENBQy9DLENBQUM7SUFDSixDQUFDO0lBRUQsSUFBSSxzQkFBc0I7UUFDeEIsSUFBSSxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ2YsT0FBTyxDQUNMLENBQUMsSUFBSSxDQUFDLE1BQU0sSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQztnQkFDbkMsd0NBQXdDLENBQUMsTUFBTSxDQUNoRCxDQUFDO1NBQ0g7YUFBTTtZQUNMLE9BQU8sQ0FDTCxDQUFDLElBQUksQ0FBQyxNQUFNLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUM7Z0JBQ2pDLHdDQUF3QyxDQUFDLElBQUksQ0FDOUMsQ0FBQztTQUNIO0lBQ0gsQ0FBQztJQUVELGlCQUFpQjtRQUNmLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNyQyxDQUFDOztnSUE3RFUsa0NBQWtDO29IQUFsQyxrQ0FBa0MsK2FDdEMvQyx3dUJBc0JBOzRGRGdCYSxrQ0FBa0M7a0JBTjlDLFNBQVM7K0JBQ0UsOEJBQThCLG1CQUd2Qix1QkFBdUIsQ0FBQyxNQUFNOzhCQUd0QyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csTUFBTTtzQkFBZCxLQUFLO2dCQUNHLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNHLFdBQVc7c0JBQW5CLEtBQUs7Z0JBQ0csTUFBTTtzQkFBZCxLQUFLO2dCQUNHLG1CQUFtQjtzQkFBM0IsS0FBSztnQkFDRyxnQkFBZ0I7c0JBQXhCLEtBQUs7Z0JBQ0csTUFBTTtzQkFBZCxLQUFLO2dCQUVJLE1BQU07c0JBQWYsTUFBTTtnQkFDRyxXQUFXO3NCQUFwQixNQUFNO2dCQUNHLGFBQWE7c0JBQXRCLE1BQU07Z0JBRUcsWUFBWTtzQkFBckIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENvbXBvbmVudCxcbiAgT3V0cHV0LFxuICBFdmVudEVtaXR0ZXIsXG4gIElucHV0LFxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgVHlwZSxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaGVtZVBhbGV0dGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jb3JlJztcbmltcG9ydCB7XG4gIElNYXJrZG93bk5hdmlnYXRvckl0ZW0sXG4gIElNYXJrZG93bk5hdmlnYXRvckxhYmVscyxcbiAgSU1hcmtkb3duTmF2aWdhdG9yQ29tcGFyZVdpdGgsXG59IGZyb20gJy4uL21hcmtkb3duLW5hdmlnYXRvci5jb21wb25lbnQnO1xuaW1wb3J0IHsgSVRkRmxhdm9yZWRNYXJrZG93bkJ1dHRvbkNsaWNrRXZlbnQgfSBmcm9tICdAY292YWxlbnQvZmxhdm9yZWQtbWFya2Rvd24nO1xuaW1wb3J0IHsgSUNvcHlDb2RlVG9vbHRpcHMgfSBmcm9tICdAY292YWxlbnQvaGlnaGxpZ2h0JztcblxuZXhwb3J0IGludGVyZmFjZSBJTWFya2Rvd25OYXZpZ2F0b3JXaW5kb3dMYWJlbHNcbiAgZXh0ZW5kcyBJTWFya2Rvd25OYXZpZ2F0b3JMYWJlbHMge1xuICB0aXRsZT86IHN0cmluZztcbiAgY2xvc2U/OiBzdHJpbmc7XG4gIGRvY2s/OiBzdHJpbmc7XG4gIHVuRG9jaz86IHN0cmluZztcbn1cbmV4cG9ydCBjb25zdCBERUZBVUxUX01BUktET1dOX05BVklHQVRPUl9XSU5ET1dfTEFCRUxTOiBJTWFya2Rvd25OYXZpZ2F0b3JXaW5kb3dMYWJlbHMgPVxuICB7XG4gICAgdGl0bGU6ICdIZWxwJyxcbiAgICBjbG9zZTogJ0Nsb3NlJyxcbiAgICBkb2NrOiAnRG9jaycsXG4gICAgdW5Eb2NrOiAnVW5kb2NrJyxcbiAgfTtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndGQtbWFya2Rvd24tbmF2aWdhdG9yLXdpbmRvdycsXG4gIHRlbXBsYXRlVXJsOiAnLi9tYXJrZG93bi1uYXZpZ2F0b3Itd2luZG93LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vbWFya2Rvd24tbmF2aWdhdG9yLXdpbmRvdy5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgVGRNYXJrZG93bk5hdmlnYXRvcldpbmRvd0NvbXBvbmVudCB7XG4gIEBJbnB1dCgpIGl0ZW1zPzogSU1hcmtkb3duTmF2aWdhdG9ySXRlbVtdO1xuICBASW5wdXQoKSBsYWJlbHM/OiBJTWFya2Rvd25OYXZpZ2F0b3JXaW5kb3dMYWJlbHM7XG4gIEBJbnB1dCgpIHRvb2xiYXJDb2xvcjogVGhlbWVQYWxldHRlID0gJ3ByaW1hcnknO1xuICBASW5wdXQoKSBzdGFydEF0PzogSU1hcmtkb3duTmF2aWdhdG9ySXRlbSB8IElNYXJrZG93bk5hdmlnYXRvckl0ZW1bXTtcbiAgQElucHV0KCkgY29tcGFyZVdpdGg/OiBJTWFya2Rvd25OYXZpZ2F0b3JDb21wYXJlV2l0aDtcbiAgQElucHV0KCkgZG9ja2VkPyA9IGZhbHNlO1xuICBASW5wdXQoKSBjb3B5Q29kZVRvQ2xpcGJvYXJkPyA9IGZhbHNlO1xuICBASW5wdXQoKSBjb3B5Q29kZVRvb2x0aXBzPzogSUNvcHlDb2RlVG9vbHRpcHMgPSB7fTtcbiAgQElucHV0KCkgZm9vdGVyPzogVHlwZTxhbnk+O1xuXG4gIEBPdXRwdXQoKSBjbG9zZWQ6IEV2ZW50RW1pdHRlcjx2b2lkPiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcbiAgQE91dHB1dCgpIGRvY2tUb2dnbGVkOiBFdmVudEVtaXR0ZXI8Ym9vbGVhbj4gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG4gIEBPdXRwdXQoKSBidXR0b25DbGlja2VkOiBFdmVudEVtaXR0ZXI8SVRkRmxhdm9yZWRNYXJrZG93bkJ1dHRvbkNsaWNrRXZlbnQ+ID1cbiAgICBuZXcgRXZlbnRFbWl0dGVyKCk7XG4gIEBPdXRwdXQoKSBpdGVtU2VsZWN0ZWQ6IEV2ZW50RW1pdHRlcjxJTWFya2Rvd25OYXZpZ2F0b3JJdGVtPiA9XG4gICAgbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIGdldCBtYXJrZG93bk5hdmlnYXRvckxhYmVscygpOiBJTWFya2Rvd25OYXZpZ2F0b3JMYWJlbHMgfCB1bmRlZmluZWQge1xuICAgIGlmICghdGhpcy5sYWJlbHMpIHtcbiAgICAgIHJldHVybiB1bmRlZmluZWQ7XG4gICAgfVxuXG4gICAgY29uc3QgeyBnb0hvbWUsIGdvQmFjaywgZW1wdHlTdGF0ZSB9OiBJTWFya2Rvd25OYXZpZ2F0b3JXaW5kb3dMYWJlbHMgPVxuICAgICAgdGhpcy5sYWJlbHM7XG4gICAgcmV0dXJuIHtcbiAgICAgIGdvSG9tZSxcbiAgICAgIGdvQmFjayxcbiAgICAgIGVtcHR5U3RhdGUsXG4gICAgfTtcbiAgfVxuICBnZXQgdGl0bGVMYWJlbCgpOiBzdHJpbmcgfCB1bmRlZmluZWQge1xuICAgIHJldHVybiAoXG4gICAgICAodGhpcy5sYWJlbHMgJiYgdGhpcy5sYWJlbHMudGl0bGUpIHx8XG4gICAgICBERUZBVUxUX01BUktET1dOX05BVklHQVRPUl9XSU5ET1dfTEFCRUxTLnRpdGxlXG4gICAgKTtcbiAgfVxuXG4gIGdldCBjbG9zZUxhYmVsKCk6IHN0cmluZyB8IHVuZGVmaW5lZCB7XG4gICAgcmV0dXJuIChcbiAgICAgICh0aGlzLmxhYmVscyAmJiB0aGlzLmxhYmVscy5jbG9zZSkgfHxcbiAgICAgIERFRkFVTFRfTUFSS0RPV05fTkFWSUdBVE9SX1dJTkRPV19MQUJFTFMuY2xvc2VcbiAgICApO1xuICB9XG5cbiAgZ2V0IHRvZ2dsZURvY2tlZFN0YXRlTGFiZWwoKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcbiAgICBpZiAodGhpcy5kb2NrZWQpIHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgICh0aGlzLmxhYmVscyAmJiB0aGlzLmxhYmVscy51bkRvY2spIHx8XG4gICAgICAgIERFRkFVTFRfTUFSS0RPV05fTkFWSUdBVE9SX1dJTkRPV19MQUJFTFMudW5Eb2NrXG4gICAgICApO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gKFxuICAgICAgICAodGhpcy5sYWJlbHMgJiYgdGhpcy5sYWJlbHMuZG9jaykgfHxcbiAgICAgICAgREVGQVVMVF9NQVJLRE9XTl9OQVZJR0FUT1JfV0lORE9XX0xBQkVMUy5kb2NrXG4gICAgICApO1xuICAgIH1cbiAgfVxuXG4gIHRvZ2dsZURvY2tlZFN0YXRlKCk6IHZvaWQge1xuICAgIHRoaXMuZG9ja1RvZ2dsZWQuZW1pdCh0aGlzLmRvY2tlZCk7XG4gIH1cbn1cbiIsIjx0ZC13aW5kb3ctZGlhbG9nXG4gIFt0b29sYmFyQ29sb3JdPVwidG9vbGJhckNvbG9yXCJcbiAgW2RvY2tlZF09XCJkb2NrZWRcIlxuICBbdGl0bGVdPVwidGl0bGVMYWJlbFwiXG4gIFt0b2dnbGVEb2NrZWRTdGF0ZUxhYmVsXT1cInRvZ2dsZURvY2tlZFN0YXRlTGFiZWxcIlxuICBbY2xvc2VMYWJlbF09XCJjbG9zZUxhYmVsXCJcbiAgKGRvY2tUb2dnbGVkKT1cInRvZ2dsZURvY2tlZFN0YXRlKClcIlxuICAoY2xvc2VkKT1cImNsb3NlZC5lbWl0KClcIlxuPlxuICA8dGQtbWFya2Rvd24tbmF2aWdhdG9yXG4gICAgW2l0ZW1zXT1cIml0ZW1zXCJcbiAgICBbbGFiZWxzXT1cIm1hcmtkb3duTmF2aWdhdG9yTGFiZWxzXCJcbiAgICBbc3R5bGUuZGlzcGxheV09XCJkb2NrZWQgPyAnbm9uZScgOiAnaW5oZXJpdCdcIlxuICAgIFtzdGFydEF0XT1cInN0YXJ0QXRcIlxuICAgIFtjb21wYXJlV2l0aF09XCJjb21wYXJlV2l0aFwiXG4gICAgW2Zvb3Rlcl09XCJmb290ZXJcIlxuICAgIFtjb3B5Q29kZVRvQ2xpcGJvYXJkXT1cImNvcHlDb2RlVG9DbGlwYm9hcmRcIlxuICAgIFtjb3B5Q29kZVRvb2x0aXBzXT1cImNvcHlDb2RlVG9vbHRpcHNcIlxuICAgIChidXR0b25DbGlja2VkKT1cImJ1dHRvbkNsaWNrZWQuZW1pdCgkZXZlbnQpXCJcbiAgICAoaXRlbVNlbGVjdGVkKT1cIml0ZW1TZWxlY3RlZC5lbWl0KCRldmVudClcIlxuICA+PC90ZC1tYXJrZG93bi1uYXZpZ2F0b3I+XG48L3RkLXdpbmRvdy1kaWFsb2c+XG4iXX0=
@@ -0,0 +1,32 @@
1
+ import { Directive, HostListener, Input } from '@angular/core';
2
+ import { TdMarkdownNavigatorWindowService, } from '../markdown-navigator-window-service/markdown-navigator-window.service';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../markdown-navigator-window-service/markdown-navigator-window.service";
5
+ export class TdMarkdownNavigatorWindowDirective {
6
+ constructor(_markdownNavigatorWindowService) {
7
+ this._markdownNavigatorWindowService = _markdownNavigatorWindowService;
8
+ this.disabled = false;
9
+ }
10
+ click() {
11
+ if (!this.disabled && this.config) {
12
+ this._markdownNavigatorWindowService.open(this.config);
13
+ }
14
+ }
15
+ }
16
+ TdMarkdownNavigatorWindowDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TdMarkdownNavigatorWindowDirective, deps: [{ token: i1.TdMarkdownNavigatorWindowService }], target: i0.ɵɵFactoryTarget.Directive });
17
+ TdMarkdownNavigatorWindowDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: TdMarkdownNavigatorWindowDirective, selector: "[tdMarkdownNavigatorWindow]", inputs: { config: ["tdMarkdownNavigatorWindow", "config"], disabled: "disabled" }, host: { listeners: { "click": "click()" } }, ngImport: i0 });
18
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TdMarkdownNavigatorWindowDirective, decorators: [{
19
+ type: Directive,
20
+ args: [{
21
+ selector: '[tdMarkdownNavigatorWindow]',
22
+ }]
23
+ }], ctorParameters: function () { return [{ type: i1.TdMarkdownNavigatorWindowService }]; }, propDecorators: { config: [{
24
+ type: Input,
25
+ args: ['tdMarkdownNavigatorWindow']
26
+ }], disabled: [{
27
+ type: Input
28
+ }], click: [{
29
+ type: HostListener,
30
+ args: ['click']
31
+ }] } });
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFya2Rvd24tbmF2aWdhdG9yLXdpbmRvdy5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL21hcmtkb3duLW5hdmlnYXRvci9zcmMvbWFya2Rvd24tbmF2aWdhdG9yLXdpbmRvdy1kaXJlY3RpdmUvbWFya2Rvd24tbmF2aWdhdG9yLXdpbmRvdy5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQy9ELE9BQU8sRUFDTCxnQ0FBZ0MsR0FFakMsTUFBTSx3RUFBd0UsQ0FBQzs7O0FBS2hGLE1BQU0sT0FBTyxrQ0FBa0M7SUFHN0MsWUFDVSwrQkFBaUU7UUFBakUsb0NBQStCLEdBQS9CLCtCQUErQixDQUFrQztRQUZsRSxhQUFRLEdBQUcsS0FBSyxDQUFDO0lBR3ZCLENBQUM7SUFFbUIsS0FBSztRQUMxQixJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ2pDLElBQUksQ0FBQywrQkFBK0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1NBQ3hEO0lBQ0gsQ0FBQzs7Z0lBWFUsa0NBQWtDO29IQUFsQyxrQ0FBa0M7NEZBQWxDLGtDQUFrQztrQkFIOUMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsNkJBQTZCO2lCQUN4Qzt1SEFFcUMsTUFBTTtzQkFBekMsS0FBSzt1QkFBQywyQkFBMkI7Z0JBQ3pCLFFBQVE7c0JBQWhCLEtBQUs7Z0JBS2lCLEtBQUs7c0JBQTNCLFlBQVk7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSG9zdExpc3RlbmVyLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgVGRNYXJrZG93bk5hdmlnYXRvcldpbmRvd1NlcnZpY2UsXG4gIElNYXJrZG93bk5hdmlnYXRvcldpbmRvd0NvbmZpZyxcbn0gZnJvbSAnLi4vbWFya2Rvd24tbmF2aWdhdG9yLXdpbmRvdy1zZXJ2aWNlL21hcmtkb3duLW5hdmlnYXRvci13aW5kb3cuc2VydmljZSc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1t0ZE1hcmtkb3duTmF2aWdhdG9yV2luZG93XScsXG59KVxuZXhwb3J0IGNsYXNzIFRkTWFya2Rvd25OYXZpZ2F0b3JXaW5kb3dEaXJlY3RpdmUge1xuICBASW5wdXQoJ3RkTWFya2Rvd25OYXZpZ2F0b3JXaW5kb3cnKSBjb25maWc/OiBJTWFya2Rvd25OYXZpZ2F0b3JXaW5kb3dDb25maWc7XG4gIEBJbnB1dCgpIGRpc2FibGVkID0gZmFsc2U7XG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgX21hcmtkb3duTmF2aWdhdG9yV2luZG93U2VydmljZTogVGRNYXJrZG93bk5hdmlnYXRvcldpbmRvd1NlcnZpY2VcbiAgKSB7fVxuXG4gIEBIb3N0TGlzdGVuZXIoJ2NsaWNrJykgY2xpY2soKTogdm9pZCB7XG4gICAgaWYgKCF0aGlzLmRpc2FibGVkICYmIHRoaXMuY29uZmlnKSB7XG4gICAgICB0aGlzLl9tYXJrZG93bk5hdmlnYXRvcldpbmRvd1NlcnZpY2Uub3Blbih0aGlzLmNvbmZpZyk7XG4gICAgfVxuICB9XG59XG4iXX0=
@@ -0,0 +1,130 @@
1
+ import { Injectable, Inject, RendererFactory2, } from '@angular/core';
2
+ import { TdMarkdownNavigatorWindowComponent, } from '../markdown-navigator-window/markdown-navigator-window.component';
3
+ import { TdDialogService, ResizableDraggableDialog, } from '@covalent/core/dialogs';
4
+ import { DOCUMENT } from '@angular/common';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@covalent/core/dialogs";
7
+ const CDK_OVERLAY_CUSTOM_CLASS = 'td-window-dialog';
8
+ const DEFAULT_POSITION = { bottom: '0px', right: '0px' };
9
+ const DEFAULT_WIDTH = '360px';
10
+ const DEFAULT_HEIGHT = '75vh';
11
+ const MIN_HEIGHT = '56px';
12
+ const MAX_WIDTH = '100vw';
13
+ const DEFAULT_DRAGGABLE_DIALOG_CONFIG = {
14
+ hasBackdrop: false,
15
+ closeOnNavigation: true,
16
+ panelClass: [CDK_OVERLAY_CUSTOM_CLASS],
17
+ position: DEFAULT_POSITION,
18
+ height: DEFAULT_HEIGHT,
19
+ width: DEFAULT_WIDTH,
20
+ maxWidth: MAX_WIDTH,
21
+ };
22
+ export class TdMarkdownNavigatorWindowService {
23
+ constructor(_tdDialogService, _document, rendererFactory) {
24
+ this._tdDialogService = _tdDialogService;
25
+ this._document = _document;
26
+ this.rendererFactory = rendererFactory;
27
+ this.markdownNavigatorWindowDialogsOpen = 0;
28
+ this._renderer2 = rendererFactory.createRenderer(undefined, null);
29
+ }
30
+ open(config) {
31
+ this.close();
32
+ const configClass = config?.dialogConfig?.panelClass;
33
+ const panelClass = configClass && !Array.isArray(configClass) ? [configClass] : [];
34
+ const draggableConfig = {
35
+ ...DEFAULT_DRAGGABLE_DIALOG_CONFIG,
36
+ ...config.dialogConfig,
37
+ ...panelClass,
38
+ };
39
+ const { matDialogRef, dragRefSubject, } = this._tdDialogService.openDraggable({
40
+ component: TdMarkdownNavigatorWindowComponent,
41
+ config: draggableConfig,
42
+ dragHandleSelectors: ['.td-window-dialog-toolbar'],
43
+ draggableClass: 'td-draggable-markdown-navigator-window',
44
+ });
45
+ this.markdownNavigatorWindowDialog = matDialogRef;
46
+ this.markdownNavigatorWindowDialog.componentInstance.items = config.items;
47
+ this.markdownNavigatorWindowDialog.componentInstance.labels = config.labels;
48
+ this.markdownNavigatorWindowDialog.componentInstance.startAt =
49
+ config.startAt;
50
+ this.markdownNavigatorWindowDialog.componentInstance.copyCodeToClipboard =
51
+ config.copyCodeToClipboard;
52
+ this.markdownNavigatorWindowDialog.componentInstance.copyCodeTooltips =
53
+ config.copyCodeTooltips;
54
+ this.markdownNavigatorWindowDialog.componentInstance.compareWith =
55
+ config.compareWith;
56
+ this.markdownNavigatorWindowDialog.componentInstance.toolbarColor =
57
+ 'toolbarColor' in config ? config.toolbarColor : 'primary';
58
+ this.markdownNavigatorWindowDialogsOpen++;
59
+ this.markdownNavigatorWindowDialog.componentInstance.footer = config.footer;
60
+ dragRefSubject.subscribe((dragRf) => {
61
+ this.dragRef = dragRf;
62
+ this.resizableDraggableDialog = new ResizableDraggableDialog(this._document, this._renderer2, this.markdownNavigatorWindowDialog, this.dragRef);
63
+ });
64
+ this._handleEvents();
65
+ return this.markdownNavigatorWindowDialog;
66
+ }
67
+ close() {
68
+ if (this.markdownNavigatorWindowDialog) {
69
+ if (this.resizableDraggableDialog) {
70
+ this.resizableDraggableDialog.detach();
71
+ }
72
+ this.markdownNavigatorWindowDialog.close();
73
+ }
74
+ }
75
+ get isOpen() {
76
+ return this.markdownNavigatorWindowDialogsOpen > 0;
77
+ }
78
+ _handleEvents() {
79
+ let position;
80
+ let dimensions;
81
+ this.markdownNavigatorWindowDialog.componentInstance.closed.subscribe(() => this.close());
82
+ this.markdownNavigatorWindowDialog.componentInstance.dockToggled.subscribe((docked) => {
83
+ if (docked) {
84
+ this.markdownNavigatorWindowDialog.componentInstance.docked = false;
85
+ this.markdownNavigatorWindowDialog.updateSize(dimensions.width, dimensions.height);
86
+ this.markdownNavigatorWindowDialog.updatePosition({
87
+ top: '0px',
88
+ right: '0px',
89
+ bottom: '0px',
90
+ left: '0px',
91
+ });
92
+ this.dragRef.setFreeDragPosition(position);
93
+ this.dragRef.disabled = false;
94
+ this.resizableDraggableDialog.attach();
95
+ }
96
+ else {
97
+ dimensions = this._getDialogSize(this.markdownNavigatorWindowDialog);
98
+ position = this.dragRef.getFreeDragPosition();
99
+ this.markdownNavigatorWindowDialog.componentInstance.docked = true;
100
+ this.markdownNavigatorWindowDialog.updateSize(DEFAULT_WIDTH, MIN_HEIGHT);
101
+ this.markdownNavigatorWindowDialog.updatePosition(DEFAULT_POSITION);
102
+ this.dragRef.reset();
103
+ this.dragRef.disabled = true;
104
+ this.resizableDraggableDialog.detach();
105
+ }
106
+ });
107
+ this.markdownNavigatorWindowDialog
108
+ .afterClosed()
109
+ .toPromise()
110
+ .then(() => {
111
+ this.markdownNavigatorWindowDialogsOpen--;
112
+ });
113
+ }
114
+ _getDialogSize(dialogRef) {
115
+ const { width, height } = getComputedStyle(this._document.getElementById(dialogRef.id).parentElement);
116
+ return {
117
+ width,
118
+ height,
119
+ };
120
+ }
121
+ }
122
+ TdMarkdownNavigatorWindowService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TdMarkdownNavigatorWindowService, deps: [{ token: i1.TdDialogService }, { token: DOCUMENT }, { token: i0.RendererFactory2 }], target: i0.ɵɵFactoryTarget.Injectable });
123
+ TdMarkdownNavigatorWindowService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TdMarkdownNavigatorWindowService });
124
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TdMarkdownNavigatorWindowService, decorators: [{
125
+ type: Injectable
126
+ }], ctorParameters: function () { return [{ type: i1.TdDialogService }, { type: undefined, decorators: [{
127
+ type: Inject,
128
+ args: [DOCUMENT]
129
+ }] }, { type: i0.RendererFactory2 }]; } });
130
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"markdown-navigator-window.service.js","sourceRoot":"","sources":["../../../../../libs/markdown-navigator/src/markdown-navigator-window-service/markdown-navigator-window.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Injectable,\n  Inject,\n  RendererFactory2,\n  Renderer2,\n  Type,\n} from '@angular/core';\nimport {\n  MatDialogRef,\n  MatDialogConfig,\n  DialogPosition,\n} from '@angular/material/dialog';\nimport { ThemePalette } from '@angular/material/core';\nimport {\n  TdMarkdownNavigatorWindowComponent,\n  IMarkdownNavigatorWindowLabels,\n} from '../markdown-navigator-window/markdown-navigator-window.component';\nimport {\n  TdDialogService,\n  IDraggableRefs,\n  ResizableDraggableDialog,\n} from '@covalent/core/dialogs';\nimport { DragRef, Point } from '@angular/cdk/drag-drop';\nimport { DOCUMENT } from '@angular/common';\nimport {\n  IMarkdownNavigatorItem,\n  IMarkdownNavigatorCompareWith,\n} from '../markdown-navigator.component';\nimport { ICopyCodeTooltips } from '@covalent/highlight';\n\nexport interface IMarkdownNavigatorWindowConfig {\n  items: IMarkdownNavigatorItem[];\n  dialogConfig?: MatDialogConfig;\n  labels?: IMarkdownNavigatorWindowLabels;\n  toolbarColor?: ThemePalette;\n  startAt?: IMarkdownNavigatorItem | IMarkdownNavigatorItem[];\n  compareWith?: IMarkdownNavigatorCompareWith;\n  copyCodeToClipboard?: boolean;\n  copyCodeTooltips?: ICopyCodeTooltips;\n  footer?: Type<any>;\n}\n\nconst CDK_OVERLAY_CUSTOM_CLASS = 'td-window-dialog';\n\nconst DEFAULT_POSITION: DialogPosition = { bottom: '0px', right: '0px' };\nconst DEFAULT_WIDTH = '360px';\nconst DEFAULT_HEIGHT = '75vh';\nconst MIN_HEIGHT = '56px';\nconst MAX_WIDTH = '100vw';\n\nconst DEFAULT_DRAGGABLE_DIALOG_CONFIG: MatDialogConfig = {\n  hasBackdrop: false,\n  closeOnNavigation: true,\n  panelClass: [CDK_OVERLAY_CUSTOM_CLASS],\n  position: DEFAULT_POSITION,\n  height: DEFAULT_HEIGHT,\n  width: DEFAULT_WIDTH,\n  maxWidth: MAX_WIDTH,\n};\n\ninterface IDialogDimensions {\n  width: string;\n  height: string;\n}\n\n@Injectable()\nexport class TdMarkdownNavigatorWindowService {\n  private _renderer2: Renderer2;\n  private dragRef!: DragRef;\n  private resizableDraggableDialog!: ResizableDraggableDialog;\n  private markdownNavigatorWindowDialog!: MatDialogRef<TdMarkdownNavigatorWindowComponent>;\n  private markdownNavigatorWindowDialogsOpen = 0;\n\n  constructor(\n    private _tdDialogService: TdDialogService,\n    @Inject(DOCUMENT) private _document: any,\n    private rendererFactory: RendererFactory2\n  ) {\n    this._renderer2 = rendererFactory.createRenderer(undefined, null);\n  }\n\n  public open(\n    config: IMarkdownNavigatorWindowConfig\n  ): MatDialogRef<TdMarkdownNavigatorWindowComponent> {\n    this.close();\n\n    const configClass = config?.dialogConfig?.panelClass;\n    const panelClass =\n      configClass && !Array.isArray(configClass) ? [configClass] : [];\n\n    const draggableConfig: MatDialogConfig = {\n      ...DEFAULT_DRAGGABLE_DIALOG_CONFIG,\n      ...config.dialogConfig,\n      ...panelClass,\n    };\n    const {\n      matDialogRef,\n      dragRefSubject,\n    }: IDraggableRefs<TdMarkdownNavigatorWindowComponent> =\n      this._tdDialogService.openDraggable({\n        component: TdMarkdownNavigatorWindowComponent,\n        config: draggableConfig,\n        dragHandleSelectors: ['.td-window-dialog-toolbar'],\n        draggableClass: 'td-draggable-markdown-navigator-window',\n      });\n    this.markdownNavigatorWindowDialog = matDialogRef;\n    this.markdownNavigatorWindowDialog.componentInstance.items = config.items;\n    this.markdownNavigatorWindowDialog.componentInstance.labels = config.labels;\n    this.markdownNavigatorWindowDialog.componentInstance.startAt =\n      config.startAt;\n    this.markdownNavigatorWindowDialog.componentInstance.copyCodeToClipboard =\n      config.copyCodeToClipboard;\n    this.markdownNavigatorWindowDialog.componentInstance.copyCodeTooltips =\n      config.copyCodeTooltips;\n    this.markdownNavigatorWindowDialog.componentInstance.compareWith =\n      config.compareWith;\n    this.markdownNavigatorWindowDialog.componentInstance.toolbarColor =\n      'toolbarColor' in config ? config.toolbarColor : 'primary';\n    this.markdownNavigatorWindowDialogsOpen++;\n    this.markdownNavigatorWindowDialog.componentInstance.footer = config.footer;\n    dragRefSubject.subscribe((dragRf: DragRef) => {\n      this.dragRef = dragRf;\n      this.resizableDraggableDialog = new ResizableDraggableDialog(\n        this._document,\n        this._renderer2,\n        this.markdownNavigatorWindowDialog,\n        this.dragRef\n      );\n    });\n    this._handleEvents();\n    return this.markdownNavigatorWindowDialog;\n  }\n\n  public close(): void {\n    if (this.markdownNavigatorWindowDialog) {\n      if (this.resizableDraggableDialog) {\n        this.resizableDraggableDialog.detach();\n      }\n      this.markdownNavigatorWindowDialog.close();\n    }\n  }\n\n  public get isOpen(): boolean {\n    return this.markdownNavigatorWindowDialogsOpen > 0;\n  }\n\n  private _handleEvents(): void {\n    let position: Point;\n    let dimensions: IDialogDimensions;\n    this.markdownNavigatorWindowDialog.componentInstance.closed.subscribe(() =>\n      this.close()\n    );\n    this.markdownNavigatorWindowDialog.componentInstance.dockToggled.subscribe(\n      (docked: boolean) => {\n        if (docked) {\n          this.markdownNavigatorWindowDialog.componentInstance.docked = false;\n          this.markdownNavigatorWindowDialog.updateSize(\n            dimensions.width,\n            dimensions.height\n          );\n          this.markdownNavigatorWindowDialog.updatePosition({\n            top: '0px',\n            right: '0px',\n            bottom: '0px',\n            left: '0px',\n          });\n          this.dragRef.setFreeDragPosition(position);\n          this.dragRef.disabled = false;\n          this.resizableDraggableDialog.attach();\n        } else {\n          dimensions = this._getDialogSize(this.markdownNavigatorWindowDialog);\n          position = this.dragRef.getFreeDragPosition();\n          this.markdownNavigatorWindowDialog.componentInstance.docked = true;\n          this.markdownNavigatorWindowDialog.updateSize(\n            DEFAULT_WIDTH,\n            MIN_HEIGHT\n          );\n          this.markdownNavigatorWindowDialog.updatePosition(DEFAULT_POSITION);\n          this.dragRef.reset();\n          this.dragRef.disabled = true;\n          this.resizableDraggableDialog.detach();\n        }\n      }\n    );\n    this.markdownNavigatorWindowDialog\n      .afterClosed()\n      .toPromise()\n      .then(() => {\n        this.markdownNavigatorWindowDialogsOpen--;\n      });\n  }\n\n  private _getDialogSize(\n    dialogRef: MatDialogRef<TdMarkdownNavigatorWindowComponent>\n  ): IDialogDimensions {\n    const { width, height } = getComputedStyle(\n      this._document.getElementById(dialogRef.id).parentElement\n    );\n    return {\n      width,\n      height,\n    };\n  }\n}\n"]}