@covalent/markdown-navigator 4.0.0 → 4.1.0-develop.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (39) hide show
  1. package/README.md +70 -58
  2. package/_markdon-navigator-theme.scss +22 -0
  3. package/covalent-markdown-navigator.d.ts +2 -2
  4. package/esm2020/covalent-markdown-navigator.mjs +5 -0
  5. package/esm2020/markdown-navigator-window/markdown-navigator-window.component.mjs +84 -0
  6. package/esm2020/markdown-navigator-window-directive/markdown-navigator-window.directive.mjs +32 -0
  7. package/esm2020/markdown-navigator-window-service/markdown-navigator-window.service.mjs +130 -0
  8. package/esm2020/markdown-navigator.component.mjs +391 -0
  9. package/esm2020/markdown-navigator.module.mjs +77 -0
  10. package/esm2020/public_api.mjs +6 -0
  11. package/fesm2015/covalent-markdown-navigator.mjs +712 -0
  12. package/fesm2015/covalent-markdown-navigator.mjs.map +1 -0
  13. package/fesm2020/covalent-markdown-navigator.mjs +700 -0
  14. package/fesm2020/covalent-markdown-navigator.mjs.map +1 -0
  15. package/markdown-navigator-window/markdown-navigator-window.component.d.ts +15 -12
  16. package/markdown-navigator-window-directive/markdown-navigator-window.directive.d.ts +4 -1
  17. package/markdown-navigator-window-service/markdown-navigator-window.service.d.ts +3 -0
  18. package/markdown-navigator.component.d.ts +22 -20
  19. package/markdown-navigator.module.d.ts +17 -0
  20. package/package.json +38 -19
  21. package/{public-api.d.ts → public_api.d.ts} +1 -0
  22. package/bundles/covalent-markdown-navigator.umd.js +0 -1650
  23. package/bundles/covalent-markdown-navigator.umd.js.map +0 -1
  24. package/bundles/covalent-markdown-navigator.umd.min.js +0 -16
  25. package/bundles/covalent-markdown-navigator.umd.min.js.map +0 -1
  26. package/covalent-markdown-navigator.metadata.json +0 -1
  27. package/esm2015/covalent-markdown-navigator.js +0 -11
  28. package/esm2015/index.js +0 -7
  29. package/esm2015/markdown-navigator-window/markdown-navigator-window.component.js +0 -129
  30. package/esm2015/markdown-navigator-window-directive/markdown-navigator-window.directive.js +0 -50
  31. package/esm2015/markdown-navigator-window-service/markdown-navigator-window.service.js +0 -254
  32. package/esm2015/markdown-navigator.component.js +0 -698
  33. package/esm2015/markdown-navigator.module.js +0 -41
  34. package/esm2015/public-api.js +0 -10
  35. package/fesm2015/covalent-markdown-navigator.js +0 -1181
  36. package/fesm2015/covalent-markdown-navigator.js.map +0 -1
  37. package/index.d.ts +0 -1
  38. package/markdown-navigator-window/markdown-navigator-window.component.scss +0 -8
  39. package/markdown-navigator.component.scss +0 -50
package/README.md CHANGED
@@ -6,26 +6,26 @@ A component for rendering and navigating through markdown, such as documentation
6
6
 
7
7
  #### Inputs
8
8
 
9
- + items: IMarkdownNavigatorItem[]
10
- + List of IMarkdownNavigatorItems to be rendered
11
- + labels?: IMarkdownNavigatorLabels
12
- + Translated labels
13
- + startAt?: IMarkdownNavigatorItem | IMarkdownNavigatorItem[]
14
- + Item or path to jump to
15
- + compareWith?: IMarkdownNavigatorCompareWith
16
- + Function used to find startAt item
17
- + Defaults to comparison by strict equality (===)
18
- + footer:? Type<any>
19
- + Custom component to be used as global footer
20
- + copyCodeToClipboard?: boolean
21
- + Display copy button on code snippets to copy code to clipboard.
22
- + copyCodeTooltips?: ICopyCodeTooltips
23
- + Tooltips for copy button to copy and upon copying.
9
+ - items: IMarkdownNavigatorItem[]
10
+ - List of IMarkdownNavigatorItems to be rendered
11
+ - labels?: IMarkdownNavigatorLabels
12
+ - Translated labels
13
+ - startAt?: IMarkdownNavigatorItem | IMarkdownNavigatorItem[]
14
+ - Item or path to jump to
15
+ - compareWith?: IMarkdownNavigatorCompareWith
16
+ - Function used to find startAt item
17
+ - Defaults to comparison by strict equality (===)
18
+ - footer:? Type<any>
19
+ - Custom component to be used as global footer
20
+ - copyCodeToClipboard?: boolean
21
+ - Display copy button on code snippets to copy code to clipboard.
22
+ - copyCodeTooltips?: ICopyCodeTooltips
23
+ - Tooltips for copy button to copy and upon copying.
24
24
 
25
25
  #### Outputs
26
26
 
27
- + buttonClicked: ITdFlavoredMarkdownButtonClickEvent
28
- + Emitted when a button is clicked
27
+ - buttonClicked: ITdFlavoredMarkdownButtonClickEvent
28
+ - Emitted when a button is clicked
29
29
 
30
30
  For reference:
31
31
 
@@ -55,7 +55,7 @@ interface ICopyCodeTooltips {
55
55
  ```typescript
56
56
  import { CovalentMarkdownNavigatorModule } from '@covalent/markdown-navigator';
57
57
  @NgModule({
58
- imports: [CovalentMarkdownNavigatorModule]
58
+ imports: [CovalentMarkdownNavigatorModule],
59
59
  })
60
60
  export class MyModule {}
61
61
  ```
@@ -79,12 +79,12 @@ const items = [
79
79
  {
80
80
  id: 'td-loading',
81
81
  url: 'https://raw.githubusercontent.com/Teradata/covalent/develop/src/platform/core/loading/README.md',
82
- title: 'tdLoading'
83
- }
84
- ]
85
- }
86
- ]
87
- }
82
+ title: 'tdLoading',
83
+ },
84
+ ],
85
+ },
86
+ ],
87
+ },
88
88
  ];
89
89
  ```
90
90
 
@@ -96,35 +96,34 @@ A component that contains a MarkdownNavigator component and a toolbar
96
96
 
97
97
  #### Inputs
98
98
 
99
- + items: IMarkdownNavigatorItem[]
100
- + List of IMarkdownNavigatorItems to be rendered
101
- + labels?: IMarkdownNavigatorLabels
102
- + Translated labels
103
- + startAt?: IMarkdownNavigatorItem | IMarkdownNavigatorItem[]
104
- + Item or path to jump to
105
- + compareWith?: IMarkdownNavigatorCompareWith
106
- + Function used to find startAt item
107
- + Defaults to comparison by strict equality (===)
108
- + toolbarColor?: ThemePalette
109
- + Toolbar color
110
- + Defaults to 'primary'
111
- + footer:? Type<any>;
112
- + Custom component to be used as global footer
113
-
99
+ - items: IMarkdownNavigatorItem[]
100
+ - List of IMarkdownNavigatorItems to be rendered
101
+ - labels?: IMarkdownNavigatorLabels
102
+ - Translated labels
103
+ - startAt?: IMarkdownNavigatorItem | IMarkdownNavigatorItem[]
104
+ - Item or path to jump to
105
+ - compareWith?: IMarkdownNavigatorCompareWith
106
+ - Function used to find startAt item
107
+ - Defaults to comparison by strict equality (===)
108
+ - toolbarColor?: ThemePalette
109
+ - Toolbar color
110
+ - Defaults to 'primary'
111
+ - footer:? Type<any>;
112
+ - Custom component to be used as global footer
114
113
 
115
114
  #### Outputs
116
115
 
117
- + closed: void
118
- + Event emitted when the close button is clicked.
119
- + buttonClicked: ITdFlavoredMarkdownButtonClickEvent
120
- + Emitted when a button is clicked
116
+ - closed: void
117
+ - Event emitted when the close button is clicked.
118
+ - buttonClicked: ITdFlavoredMarkdownButtonClickEvent
119
+ - Emitted when a button is clicked
121
120
 
122
121
  ## Setup
123
122
 
124
123
  ```typescript
125
124
  import { CovalentMarkdownNavigatorModule } from '@covalent/markdown-navigator';
126
125
  @NgModule({
127
- imports: [CovalentMarkdownNavigatorModule]
126
+ imports: [CovalentMarkdownNavigatorModule],
128
127
  })
129
128
  export class MyModule {}
130
129
  ```
@@ -143,8 +142,8 @@ A service that opens a MarkdownNavigatorWindowComponent inside a draggable dialo
143
142
 
144
143
  #### Methods
145
144
 
146
- + open: function(config: IMarkdownNavigatorWindowConfig)
147
- + Opens a MarkdownNavigatorWindowComponent inside a draggable dialog.
145
+ - open: function(config: IMarkdownNavigatorWindowConfig)
146
+ - Opens a MarkdownNavigatorWindowComponent inside a draggable dialog.
148
147
 
149
148
  For reference:
150
149
 
@@ -165,7 +164,7 @@ interface IMarkdownNavigatorWindowConfig {
165
164
  ```typescript
166
165
  import { CovalentMarkdownNavigatorModule } from '@covalent/markdown-navigator';
167
166
  @NgModule({
168
- imports: [CovalentMarkdownNavigatorModule]
167
+ imports: [CovalentMarkdownNavigatorModule],
169
168
  })
170
169
  export class MyModule {}
171
170
  ```
@@ -176,17 +175,24 @@ export class MyModule {}
176
175
  import {
177
176
  TdMarkdownNavigatorWindowComponent,
178
177
  TdMarkdownNavigatorWindowService,
179
- IMarkdownNavigatorItem
178
+ IMarkdownNavigatorItem,
180
179
  } from '@covalent/markdown-navigator';
181
180
  import { MatDialogRef } from '@angular/material/dialog';
182
181
 
183
182
  export class SampleComponent {
184
- constructor(private _markdownNavigatorWindowService: TdMarkdownNavigatorWindowService) {}
183
+ constructor(
184
+ private _markdownNavigatorWindowService: TdMarkdownNavigatorWindowService
185
+ ) {}
185
186
 
186
187
  ngOnInit(): void {
187
- const ref: MatDialogRef<TdMarkdownNavigatorWindowComponent> = this._markdownNavigatorWindowService.open({
188
- items: [{ url: 'https://github.com/Teradata/covalent/blob/develop/README.md' }]
189
- });
188
+ const ref: MatDialogRef<TdMarkdownNavigatorWindowComponent> =
189
+ this._markdownNavigatorWindowService.open({
190
+ items: [
191
+ {
192
+ url: 'https://github.com/Teradata/covalent/blob/develop/README.md',
193
+ },
194
+ ],
195
+ });
190
196
  ref.afterOpened().subscribe(() => {});
191
197
  ref.afterClosed().subscribe(() => {});
192
198
  }
@@ -201,17 +207,17 @@ A directive that calls the TdMarkdownNavigatorWindowService open method on click
201
207
 
202
208
  #### Inputs
203
209
 
204
- + tdMarkdownNavigatorWindow: IMarkdownNavigatorWindowConfig
205
- + Config to open window with
206
- + disabled: boolean
207
- + Whether disabled or not
210
+ - tdMarkdownNavigatorWindow: IMarkdownNavigatorWindowConfig
211
+ - Config to open window with
212
+ - disabled: boolean
213
+ - Whether disabled or not
208
214
 
209
215
  ## Setup
210
216
 
211
217
  ```typescript
212
218
  import { CovalentMarkdownNavigatorModule } from '@covalent/markdown-navigator';
213
219
  @NgModule({
214
- imports: [CovalentMarkdownNavigatorModule]
220
+ imports: [CovalentMarkdownNavigatorModule],
215
221
  })
216
222
  export class MyModule {}
217
223
  ```
@@ -221,5 +227,11 @@ export class MyModule {}
221
227
  Example:
222
228
 
223
229
  ```html
224
- <button mat-button [tdMarkdownNavigatorWindow]="{ items: [] }" [disabled]="false">Open window</button>
230
+ <button
231
+ mat-button
232
+ [tdMarkdownNavigatorWindow]="{ items: [] }"
233
+ [disabled]="false"
234
+ >
235
+ Open window
236
+ </button>
225
237
  ```
@@ -0,0 +1,22 @@
1
+ @mixin covalent-markdown-navigator-typography($fontConfig) {
2
+ td-markdown-navigator {
3
+ td-breadcrumbs .mat-button {
4
+ @include mat-typography-level-to-styles($fontConfig, caption);
5
+ }
6
+
7
+ .breadcrumb-current-title {
8
+ @include mat-typography-level-to-styles($fontConfig, headline);
9
+ }
10
+ }
11
+ }
12
+
13
+ @mixin covalent-markdown-navigator-theme($theme) {
14
+ $foreground: map-get($theme, foreground);
15
+ $secondary: map-get($foreground, secondary-text);
16
+
17
+ td-markdown-navigator {
18
+ td-breadcrumbs {
19
+ color: $secondary;
20
+ }
21
+ }
22
+ }
@@ -1,5 +1,5 @@
1
1
  /**
2
2
  * Generated bundle index. Do not edit.
3
3
  */
4
- export * from './index';
5
- export { TdMarkdownNavigatorWindowDirective as ɵa } from './markdown-navigator-window-directive/markdown-navigator-window.directive';
4
+ /// <amd-module name="@covalent/markdown-navigator" />
5
+ export * from './public_api';
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public_api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY292YWxlbnQtbWFya2Rvd24tbmF2aWdhdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbGlicy9tYXJrZG93bi1uYXZpZ2F0b3Ivc3JjL2NvdmFsZW50LW1hcmtkb3duLW5hdmlnYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpY19hcGknO1xuIl19
@@ -0,0 +1,84 @@
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
+ }
21
+ get markdownNavigatorLabels() {
22
+ if (!this.labels) {
23
+ return undefined;
24
+ }
25
+ const { goHome, goBack, emptyState } = this.labels;
26
+ return {
27
+ goHome,
28
+ goBack,
29
+ emptyState,
30
+ };
31
+ }
32
+ get titleLabel() {
33
+ return ((this.labels && this.labels.title) ||
34
+ DEFAULT_MARKDOWN_NAVIGATOR_WINDOW_LABELS.title);
35
+ }
36
+ get closeLabel() {
37
+ return ((this.labels && this.labels.close) ||
38
+ DEFAULT_MARKDOWN_NAVIGATOR_WINDOW_LABELS.close);
39
+ }
40
+ get toggleDockedStateLabel() {
41
+ if (this.docked) {
42
+ return ((this.labels && this.labels.unDock) ||
43
+ DEFAULT_MARKDOWN_NAVIGATOR_WINDOW_LABELS.unDock);
44
+ }
45
+ else {
46
+ return ((this.labels && this.labels.dock) ||
47
+ DEFAULT_MARKDOWN_NAVIGATOR_WINDOW_LABELS.dock);
48
+ }
49
+ }
50
+ toggleDockedState() {
51
+ this.dockToggled.emit(this.docked);
52
+ }
53
+ }
54
+ TdMarkdownNavigatorWindowComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: TdMarkdownNavigatorWindowComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
55
+ TdMarkdownNavigatorWindowComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", 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" }, 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 ></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"], components: [{ type: i1.TdWindowDialogComponent, selector: "td-window-dialog", inputs: ["toolbarColor", "docked", "title", "toggleDockedStateLabel", "closeLabel"], outputs: ["dockToggled", "closed"] }, { type: i2.TdMarkdownNavigatorComponent, selector: "td-markdown-navigator", inputs: ["items", "labels", "startAt", "copyCodeToClipboard", "copyCodeTooltips", "footer", "compareWith"], outputs: ["buttonClicked"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
56
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: TdMarkdownNavigatorWindowComponent, decorators: [{
57
+ type: Component,
58
+ 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 ></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"] }]
59
+ }], propDecorators: { items: [{
60
+ type: Input
61
+ }], labels: [{
62
+ type: Input
63
+ }], toolbarColor: [{
64
+ type: Input
65
+ }], startAt: [{
66
+ type: Input
67
+ }], compareWith: [{
68
+ type: Input
69
+ }], docked: [{
70
+ type: Input
71
+ }], copyCodeToClipboard: [{
72
+ type: Input
73
+ }], copyCodeTooltips: [{
74
+ type: Input
75
+ }], footer: [{
76
+ type: Input
77
+ }], closed: [{
78
+ type: Output
79
+ }], dockToggled: [{
80
+ type: Output
81
+ }], buttonClicked: [{
82
+ type: Output
83
+ }] } });
84
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFya2Rvd24tbmF2aWdhdG9yLXdpbmRvdy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL21hcmtkb3duLW5hdmlnYXRvci9zcmMvbWFya2Rvd24tbmF2aWdhdG9yLXdpbmRvdy9tYXJrZG93bi1uYXZpZ2F0b3Itd2luZG93LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL2xpYnMvbWFya2Rvd24tbmF2aWdhdG9yL3NyYy9tYXJrZG93bi1uYXZpZ2F0b3Itd2luZG93L21hcmtkb3duLW5hdmlnYXRvci13aW5kb3cuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCxNQUFNLEVBQ04sWUFBWSxFQUNaLEtBQUssRUFDTCx1QkFBdUIsRUFDdkIsSUFBSSxHQUNMLE1BQU0sZUFBZSxDQUFDOzs7O0FBaUJ2QixNQUFNLENBQUMsTUFBTSx3Q0FBd0MsR0FDbkQ7SUFDRSxLQUFLLEVBQUUsTUFBTTtJQUNiLEtBQUssRUFBRSxPQUFPO0lBQ2QsSUFBSSxFQUFFLE1BQU07SUFDWixNQUFNLEVBQUUsUUFBUTtDQUNqQixDQUFDO0FBUUosTUFBTSxPQUFPLGtDQUFrQztJQU4vQztRQVNXLGlCQUFZLEdBQWlCLFNBQVMsQ0FBQztRQUd2QyxXQUFNLEdBQUksS0FBSyxDQUFDO1FBQ2hCLHdCQUFtQixHQUFJLEtBQUssQ0FBQztRQUM3QixxQkFBZ0IsR0FBdUIsRUFBRSxDQUFDO1FBR3pDLFdBQU0sR0FBdUIsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUNoRCxnQkFBVyxHQUEwQixJQUFJLFlBQVksRUFBRSxDQUFDO1FBQ3hELGtCQUFhLEdBQ3JCLElBQUksWUFBWSxFQUFFLENBQUM7S0E4Q3RCO0lBNUNDLElBQUksdUJBQXVCO1FBQ3pCLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ2hCLE9BQU8sU0FBUyxDQUFDO1NBQ2xCO1FBRUQsTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLEdBQ2xDLElBQUksQ0FBQyxNQUFNLENBQUM7UUFDZCxPQUFPO1lBQ0wsTUFBTTtZQUNOLE1BQU07WUFDTixVQUFVO1NBQ1gsQ0FBQztJQUNKLENBQUM7SUFDRCxJQUFJLFVBQVU7UUFDWixPQUFPLENBQ0wsQ0FBQyxJQUFJLENBQUMsTUFBTSxJQUFJLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDO1lBQ2xDLHdDQUF3QyxDQUFDLEtBQUssQ0FDL0MsQ0FBQztJQUNKLENBQUM7SUFFRCxJQUFJLFVBQVU7UUFDWixPQUFPLENBQ0wsQ0FBQyxJQUFJLENBQUMsTUFBTSxJQUFJLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDO1lBQ2xDLHdDQUF3QyxDQUFDLEtBQUssQ0FDL0MsQ0FBQztJQUNKLENBQUM7SUFFRCxJQUFJLHNCQUFzQjtRQUN4QixJQUFJLElBQUksQ0FBQyxNQUFNLEVBQUU7WUFDZixPQUFPLENBQ0wsQ0FBQyxJQUFJLENBQUMsTUFBTSxJQUFJLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDO2dCQUNuQyx3Q0FBd0MsQ0FBQyxNQUFNLENBQ2hELENBQUM7U0FDSDthQUFNO1lBQ0wsT0FBTyxDQUNMLENBQUMsSUFBSSxDQUFDLE1BQU0sSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQztnQkFDakMsd0NBQXdDLENBQUMsSUFBSSxDQUM5QyxDQUFDO1NBQ0g7SUFDSCxDQUFDO0lBRUQsaUJBQWlCO1FBQ2YsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3JDLENBQUM7OytIQTNEVSxrQ0FBa0M7bUhBQWxDLGtDQUFrQyxpWkN0Qy9DLHNyQkFxQkE7MkZEaUJhLGtDQUFrQztrQkFOOUMsU0FBUzsrQkFDRSw4QkFBOEIsbUJBR3ZCLHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csWUFBWTtzQkFBcEIsS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csbUJBQW1CO3NCQUEzQixLQUFLO2dCQUNHLGdCQUFnQjtzQkFBeEIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBRUksTUFBTTtzQkFBZixNQUFNO2dCQUNHLFdBQVc7c0JBQXBCLE1BQU07Z0JBQ0csYUFBYTtzQkFBdEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENvbXBvbmVudCxcbiAgT3V0cHV0LFxuICBFdmVudEVtaXR0ZXIsXG4gIElucHV0LFxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgVHlwZSxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaGVtZVBhbGV0dGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jb3JlJztcbmltcG9ydCB7XG4gIElNYXJrZG93bk5hdmlnYXRvckl0ZW0sXG4gIElNYXJrZG93bk5hdmlnYXRvckxhYmVscyxcbiAgSU1hcmtkb3duTmF2aWdhdG9yQ29tcGFyZVdpdGgsXG59IGZyb20gJy4uL21hcmtkb3duLW5hdmlnYXRvci5jb21wb25lbnQnO1xuaW1wb3J0IHsgSVRkRmxhdm9yZWRNYXJrZG93bkJ1dHRvbkNsaWNrRXZlbnQgfSBmcm9tICdAY292YWxlbnQvZmxhdm9yZWQtbWFya2Rvd24nO1xuaW1wb3J0IHsgSUNvcHlDb2RlVG9vbHRpcHMgfSBmcm9tICdAY292YWxlbnQvaGlnaGxpZ2h0JztcblxuZXhwb3J0IGludGVyZmFjZSBJTWFya2Rvd25OYXZpZ2F0b3JXaW5kb3dMYWJlbHNcbiAgZXh0ZW5kcyBJTWFya2Rvd25OYXZpZ2F0b3JMYWJlbHMge1xuICB0aXRsZT86IHN0cmluZztcbiAgY2xvc2U/OiBzdHJpbmc7XG4gIGRvY2s/OiBzdHJpbmc7XG4gIHVuRG9jaz86IHN0cmluZztcbn1cbmV4cG9ydCBjb25zdCBERUZBVUxUX01BUktET1dOX05BVklHQVRPUl9XSU5ET1dfTEFCRUxTOiBJTWFya2Rvd25OYXZpZ2F0b3JXaW5kb3dMYWJlbHMgPVxuICB7XG4gICAgdGl0bGU6ICdIZWxwJyxcbiAgICBjbG9zZTogJ0Nsb3NlJyxcbiAgICBkb2NrOiAnRG9jaycsXG4gICAgdW5Eb2NrOiAnVW5kb2NrJyxcbiAgfTtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndGQtbWFya2Rvd24tbmF2aWdhdG9yLXdpbmRvdycsXG4gIHRlbXBsYXRlVXJsOiAnLi9tYXJrZG93bi1uYXZpZ2F0b3Itd2luZG93LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vbWFya2Rvd24tbmF2aWdhdG9yLXdpbmRvdy5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgVGRNYXJrZG93bk5hdmlnYXRvcldpbmRvd0NvbXBvbmVudCB7XG4gIEBJbnB1dCgpIGl0ZW1zPzogSU1hcmtkb3duTmF2aWdhdG9ySXRlbVtdO1xuICBASW5wdXQoKSBsYWJlbHM/OiBJTWFya2Rvd25OYXZpZ2F0b3JXaW5kb3dMYWJlbHM7XG4gIEBJbnB1dCgpIHRvb2xiYXJDb2xvcjogVGhlbWVQYWxldHRlID0gJ3ByaW1hcnknO1xuICBASW5wdXQoKSBzdGFydEF0PzogSU1hcmtkb3duTmF2aWdhdG9ySXRlbSB8IElNYXJrZG93bk5hdmlnYXRvckl0ZW1bXTtcbiAgQElucHV0KCkgY29tcGFyZVdpdGg/OiBJTWFya2Rvd25OYXZpZ2F0b3JDb21wYXJlV2l0aDtcbiAgQElucHV0KCkgZG9ja2VkPyA9IGZhbHNlO1xuICBASW5wdXQoKSBjb3B5Q29kZVRvQ2xpcGJvYXJkPyA9IGZhbHNlO1xuICBASW5wdXQoKSBjb3B5Q29kZVRvb2x0aXBzPzogSUNvcHlDb2RlVG9vbHRpcHMgPSB7fTtcbiAgQElucHV0KCkgZm9vdGVyPzogVHlwZTxhbnk+O1xuXG4gIEBPdXRwdXQoKSBjbG9zZWQ6IEV2ZW50RW1pdHRlcjx2b2lkPiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcbiAgQE91dHB1dCgpIGRvY2tUb2dnbGVkOiBFdmVudEVtaXR0ZXI8Ym9vbGVhbj4gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG4gIEBPdXRwdXQoKSBidXR0b25DbGlja2VkOiBFdmVudEVtaXR0ZXI8SVRkRmxhdm9yZWRNYXJrZG93bkJ1dHRvbkNsaWNrRXZlbnQ+ID1cbiAgICBuZXcgRXZlbnRFbWl0dGVyKCk7XG5cbiAgZ2V0IG1hcmtkb3duTmF2aWdhdG9yTGFiZWxzKCk6IElNYXJrZG93bk5hdmlnYXRvckxhYmVscyB8IHVuZGVmaW5lZCB7XG4gICAgaWYgKCF0aGlzLmxhYmVscykge1xuICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICB9XG5cbiAgICBjb25zdCB7IGdvSG9tZSwgZ29CYWNrLCBlbXB0eVN0YXRlIH06IElNYXJrZG93bk5hdmlnYXRvcldpbmRvd0xhYmVscyA9XG4gICAgICB0aGlzLmxhYmVscztcbiAgICByZXR1cm4ge1xuICAgICAgZ29Ib21lLFxuICAgICAgZ29CYWNrLFxuICAgICAgZW1wdHlTdGF0ZSxcbiAgICB9O1xuICB9XG4gIGdldCB0aXRsZUxhYmVsKCk6IHN0cmluZyB8IHVuZGVmaW5lZCB7XG4gICAgcmV0dXJuIChcbiAgICAgICh0aGlzLmxhYmVscyAmJiB0aGlzLmxhYmVscy50aXRsZSkgfHxcbiAgICAgIERFRkFVTFRfTUFSS0RPV05fTkFWSUdBVE9SX1dJTkRPV19MQUJFTFMudGl0bGVcbiAgICApO1xuICB9XG5cbiAgZ2V0IGNsb3NlTGFiZWwoKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcbiAgICByZXR1cm4gKFxuICAgICAgKHRoaXMubGFiZWxzICYmIHRoaXMubGFiZWxzLmNsb3NlKSB8fFxuICAgICAgREVGQVVMVF9NQVJLRE9XTl9OQVZJR0FUT1JfV0lORE9XX0xBQkVMUy5jbG9zZVxuICAgICk7XG4gIH1cblxuICBnZXQgdG9nZ2xlRG9ja2VkU3RhdGVMYWJlbCgpOiBzdHJpbmcgfCB1bmRlZmluZWQge1xuICAgIGlmICh0aGlzLmRvY2tlZCkge1xuICAgICAgcmV0dXJuIChcbiAgICAgICAgKHRoaXMubGFiZWxzICYmIHRoaXMubGFiZWxzLnVuRG9jaykgfHxcbiAgICAgICAgREVGQVVMVF9NQVJLRE9XTl9OQVZJR0FUT1JfV0lORE9XX0xBQkVMUy51bkRvY2tcbiAgICAgICk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgICh0aGlzLmxhYmVscyAmJiB0aGlzLmxhYmVscy5kb2NrKSB8fFxuICAgICAgICBERUZBVUxUX01BUktET1dOX05BVklHQVRPUl9XSU5ET1dfTEFCRUxTLmRvY2tcbiAgICAgICk7XG4gICAgfVxuICB9XG5cbiAgdG9nZ2xlRG9ja2VkU3RhdGUoKTogdm9pZCB7XG4gICAgdGhpcy5kb2NrVG9nZ2xlZC5lbWl0KHRoaXMuZG9ja2VkKTtcbiAgfVxufVxuIiwiPHRkLXdpbmRvdy1kaWFsb2dcbiAgW3Rvb2xiYXJDb2xvcl09XCJ0b29sYmFyQ29sb3JcIlxuICBbZG9ja2VkXT1cImRvY2tlZFwiXG4gIFt0aXRsZV09XCJ0aXRsZUxhYmVsXCJcbiAgW3RvZ2dsZURvY2tlZFN0YXRlTGFiZWxdPVwidG9nZ2xlRG9ja2VkU3RhdGVMYWJlbFwiXG4gIFtjbG9zZUxhYmVsXT1cImNsb3NlTGFiZWxcIlxuICAoZG9ja1RvZ2dsZWQpPVwidG9nZ2xlRG9ja2VkU3RhdGUoKVwiXG4gIChjbG9zZWQpPVwiY2xvc2VkLmVtaXQoKVwiXG4+XG4gIDx0ZC1tYXJrZG93bi1uYXZpZ2F0b3JcbiAgICBbaXRlbXNdPVwiaXRlbXNcIlxuICAgIFtsYWJlbHNdPVwibWFya2Rvd25OYXZpZ2F0b3JMYWJlbHNcIlxuICAgIFtzdHlsZS5kaXNwbGF5XT1cImRvY2tlZCA/ICdub25lJyA6ICdpbmhlcml0J1wiXG4gICAgW3N0YXJ0QXRdPVwic3RhcnRBdFwiXG4gICAgW2NvbXBhcmVXaXRoXT1cImNvbXBhcmVXaXRoXCJcbiAgICBbZm9vdGVyXT1cImZvb3RlclwiXG4gICAgW2NvcHlDb2RlVG9DbGlwYm9hcmRdPVwiY29weUNvZGVUb0NsaXBib2FyZFwiXG4gICAgW2NvcHlDb2RlVG9vbHRpcHNdPVwiY29weUNvZGVUb29sdGlwc1wiXG4gICAgKGJ1dHRvbkNsaWNrZWQpPVwiYnV0dG9uQ2xpY2tlZC5lbWl0KCRldmVudClcIlxuICA+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: "13.2.2", ngImport: i0, type: TdMarkdownNavigatorWindowDirective, deps: [{ token: i1.TdMarkdownNavigatorWindowService }], target: i0.ɵɵFactoryTarget.Directive });
17
+ TdMarkdownNavigatorWindowDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.2", type: TdMarkdownNavigatorWindowDirective, selector: "[tdMarkdownNavigatorWindow]", inputs: { config: ["tdMarkdownNavigatorWindow", "config"], disabled: "disabled" }, host: { listeners: { "click": "click()" } }, ngImport: i0 });
18
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", 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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFya2Rvd24tbmF2aWdhdG9yLXdpbmRvdy5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL21hcmtkb3duLW5hdmlnYXRvci9zcmMvbWFya2Rvd24tbmF2aWdhdG9yLXdpbmRvdy1kaXJlY3RpdmUvbWFya2Rvd24tbmF2aWdhdG9yLXdpbmRvdy5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQy9ELE9BQU8sRUFDTCxnQ0FBZ0MsR0FFakMsTUFBTSx3RUFBd0UsQ0FBQzs7O0FBS2hGLE1BQU0sT0FBTyxrQ0FBa0M7SUFHN0MsWUFDVSwrQkFBaUU7UUFBakUsb0NBQStCLEdBQS9CLCtCQUErQixDQUFrQztRQUZsRSxhQUFRLEdBQUcsS0FBSyxDQUFDO0lBR3ZCLENBQUM7SUFFbUIsS0FBSztRQUMxQixJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ2pDLElBQUksQ0FBQywrQkFBK0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1NBQ3hEO0lBQ0gsQ0FBQzs7K0hBWFUsa0NBQWtDO21IQUFsQyxrQ0FBa0M7MkZBQWxDLGtDQUFrQztrQkFIOUMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsNkJBQTZCO2lCQUN4Qzt1SEFFcUMsTUFBTTtzQkFBekMsS0FBSzt1QkFBQywyQkFBMkI7Z0JBQ3pCLFFBQVE7c0JBQWhCLEtBQUs7Z0JBS2lCLEtBQUs7c0JBQTNCLFlBQVk7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSG9zdExpc3RlbmVyLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgVGRNYXJrZG93bk5hdmlnYXRvcldpbmRvd1NlcnZpY2UsXG4gIElNYXJrZG93bk5hdmlnYXRvcldpbmRvd0NvbmZpZyxcbn0gZnJvbSAnLi4vbWFya2Rvd24tbmF2aWdhdG9yLXdpbmRvdy1zZXJ2aWNlL21hcmtkb3duLW5hdmlnYXRvci13aW5kb3cuc2VydmljZSc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1t0ZE1hcmtkb3duTmF2aWdhdG9yV2luZG93XScsXG59KVxuZXhwb3J0IGNsYXNzIFRkTWFya2Rvd25OYXZpZ2F0b3JXaW5kb3dEaXJlY3RpdmUge1xuICBASW5wdXQoJ3RkTWFya2Rvd25OYXZpZ2F0b3JXaW5kb3cnKSBjb25maWc/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: "13.2.2", 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: "13.2.2", ngImport: i0, type: TdMarkdownNavigatorWindowService });
124
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", 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":"AAAA,OAAO,EACL,UAAU,EACV,MAAM,EACN,gBAAgB,GAGjB,MAAM,eAAe,CAAC;AAOvB,OAAO,EACL,kCAAkC,GAEnC,MAAM,kEAAkE,CAAC;AAC1E,OAAO,EACL,eAAe,EAEf,wBAAwB,GACzB,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;;;AAmB3C,MAAM,wBAAwB,GAAG,kBAAkB,CAAC;AAEpD,MAAM,gBAAgB,GAAmB,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;AACzE,MAAM,aAAa,GAAG,OAAO,CAAC;AAC9B,MAAM,cAAc,GAAG,MAAM,CAAC;AAC9B,MAAM,UAAU,GAAG,MAAM,CAAC;AAC1B,MAAM,SAAS,GAAG,OAAO,CAAC;AAE1B,MAAM,+BAA+B,GAAoB;IACvD,WAAW,EAAE,KAAK;IAClB,iBAAiB,EAAE,IAAI;IACvB,UAAU,EAAE,CAAC,wBAAwB,CAAC;IACtC,QAAQ,EAAE,gBAAgB;IAC1B,MAAM,EAAE,cAAc;IACtB,KAAK,EAAE,aAAa;IACpB,QAAQ,EAAE,SAAS;CACpB,CAAC;AAQF,MAAM,OAAO,gCAAgC;IAO3C,YACU,gBAAiC,EACf,SAAc,EAChC,eAAiC;QAFjC,qBAAgB,GAAhB,gBAAgB,CAAiB;QACf,cAAS,GAAT,SAAS,CAAK;QAChC,oBAAe,GAAf,eAAe,CAAkB;QALnC,uCAAkC,GAAG,CAAC,CAAC;QAO7C,IAAI,CAAC,UAAU,GAAG,eAAe,CAAC,cAAc,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;IACpE,CAAC;IAEM,IAAI,CACT,MAAsC;QAEtC,IAAI,CAAC,KAAK,EAAE,CAAC;QAEb,MAAM,WAAW,GAAG,MAAM,EAAE,YAAY,EAAE,UAAU,CAAC;QACrD,MAAM,UAAU,GACd,WAAW,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAElE,MAAM,eAAe,GAAoB;YACvC,GAAG,+BAA+B;YAClC,GAAG,MAAM,CAAC,YAAY;YACtB,GAAG,UAAU;SACd,CAAC;QACF,MAAM,EACJ,YAAY,EACZ,cAAc,GACf,GAAuD,IAAI,CAAC,gBAAgB,CAAC,aAAa,CACzF;YACE,SAAS,EAAE,kCAAkC;YAC7C,MAAM,EAAE,eAAe;YACvB,mBAAmB,EAAE,CAAC,2BAA2B,CAAC;YAClD,cAAc,EAAE,wCAAwC;SACzD,CACF,CAAC;QACF,IAAI,CAAC,6BAA6B,GAAG,YAAY,CAAC;QAClD,IAAI,CAAC,6BAA6B,CAAC,iBAAiB,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC;QAC1E,IAAI,CAAC,6BAA6B,CAAC,iBAAiB,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC;QAC5E,IAAI,CAAC,6BAA6B,CAAC,iBAAiB,CAAC,OAAO;YAC1D,MAAM,CAAC,OAAO,CAAC;QACjB,IAAI,CAAC,6BAA6B,CAAC,iBAAiB,CAAC,mBAAmB;YACtE,MAAM,CAAC,mBAAmB,CAAC;QAC7B,IAAI,CAAC,6BAA6B,CAAC,iBAAiB,CAAC,gBAAgB;YACnE,MAAM,CAAC,gBAAgB,CAAC;QAC1B,IAAI,CAAC,6BAA6B,CAAC,iBAAiB,CAAC,WAAW;YAC9D,MAAM,CAAC,WAAW,CAAC;QACrB,IAAI,CAAC,6BAA6B,CAAC,iBAAiB,CAAC,YAAY;YAC/D,cAAc,IAAI,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC;QAC7D,IAAI,CAAC,kCAAkC,EAAE,CAAC;QAC1C,IAAI,CAAC,6BAA6B,CAAC,iBAAiB,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC;QAC5E,cAAc,CAAC,SAAS,CAAC,CAAC,MAAe,EAAE,EAAE;YAC3C,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;YACtB,IAAI,CAAC,wBAAwB,GAAG,IAAI,wBAAwB,CAC1D,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,UAAU,EACf,IAAI,CAAC,6BAA6B,EAClC,IAAI,CAAC,OAAO,CACb,CAAC;QACJ,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,OAAO,IAAI,CAAC,6BAA6B,CAAC;IAC5C,CAAC;IAEM,KAAK;QACV,IAAI,IAAI,CAAC,6BAA6B,EAAE;YACtC,IAAI,IAAI,CAAC,wBAAwB,EAAE;gBACjC,IAAI,CAAC,wBAAwB,CAAC,MAAM,EAAE,CAAC;aACxC;YACD,IAAI,CAAC,6BAA6B,CAAC,KAAK,EAAE,CAAC;SAC5C;IACH,CAAC;IAED,IAAW,MAAM;QACf,OAAO,IAAI,CAAC,kCAAkC,GAAG,CAAC,CAAC;IACrD,CAAC;IAEO,aAAa;QACnB,IAAI,QAAe,CAAC;QACpB,IAAI,UAA6B,CAAC;QAClC,IAAI,CAAC,6BAA6B,CAAC,iBAAiB,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,EAAE,CACzE,IAAI,CAAC,KAAK,EAAE,CACb,CAAC;QACF,IAAI,CAAC,6BAA6B,CAAC,iBAAiB,CAAC,WAAW,CAAC,SAAS,CACxE,CAAC,MAAe,EAAE,EAAE;YAClB,IAAI,MAAM,EAAE;gBACV,IAAI,CAAC,6BAA6B,CAAC,iBAAiB,CAAC,MAAM,GAAG,KAAK,CAAC;gBACpE,IAAI,CAAC,6BAA6B,CAAC,UAAU,CAC3C,UAAU,CAAC,KAAK,EAChB,UAAU,CAAC,MAAM,CAClB,CAAC;gBACF,IAAI,CAAC,6BAA6B,CAAC,cAAc,CAAC;oBAChD,GAAG,EAAE,KAAK;oBACV,KAAK,EAAE,KAAK;oBACZ,MAAM,EAAE,KAAK;oBACb,IAAI,EAAE,KAAK;iBACZ,CAAC,CAAC;gBACH,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,QAAQ,CAAC,CAAC;gBAC3C,IAAI,CAAC,OAAO,CAAC,QAAQ,GAAG,KAAK,CAAC;gBAC9B,IAAI,CAAC,wBAAwB,CAAC,MAAM,EAAE,CAAC;aACxC;iBAAM;gBACL,UAAU,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAC;gBACrE,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,mBAAmB,EAAE,CAAC;gBAC9C,IAAI,CAAC,6BAA6B,CAAC,iBAAiB,CAAC,MAAM,GAAG,IAAI,CAAC;gBACnE,IAAI,CAAC,6BAA6B,CAAC,UAAU,CAC3C,aAAa,EACb,UAAU,CACX,CAAC;gBACF,IAAI,CAAC,6BAA6B,CAAC,cAAc,CAAC,gBAAgB,CAAC,CAAC;gBACpE,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;gBACrB,IAAI,CAAC,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC;gBAC7B,IAAI,CAAC,wBAAwB,CAAC,MAAM,EAAE,CAAC;aACxC;QACH,CAAC,CACF,CAAC;QACF,IAAI,CAAC,6BAA6B;aAC/B,WAAW,EAAE;aACb,SAAS,EAAE;aACX,IAAI,CAAC,GAAG,EAAE;YACT,IAAI,CAAC,kCAAkC,EAAE,CAAC;QAC5C,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,cAAc,CACpB,SAA2D;QAE3D,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,gBAAgB,CACxC,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,aAAa,CAC1D,CAAC;QACF,OAAO;YACL,KAAK;YACL,MAAM;SACP,CAAC;IACJ,CAAC;;6HAzIU,gCAAgC,iDASjC,QAAQ;iIATP,gCAAgC;2FAAhC,gCAAgC;kBAD5C,UAAU;;0BAUN,MAAM;2BAAC,QAAQ","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/drag-ref';\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> = this._tdDialogService.openDraggable(\n      {\n        component: TdMarkdownNavigatorWindowComponent,\n        config: draggableConfig,\n        dragHandleSelectors: ['.td-window-dialog-toolbar'],\n        draggableClass: 'td-draggable-markdown-navigator-window',\n      }\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"]}