ionic-logging-viewer 10.0.0 → 14.0.0

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 (52) hide show
  1. package/README.md +10 -6
  2. package/esm2020/ionic-logging-viewer.mjs +5 -0
  3. package/esm2020/lib/logging-viewer/logging-viewer.component.mjs +119 -0
  4. package/esm2020/lib/logging-viewer-filter.service.mjs +64 -0
  5. package/esm2020/lib/logging-viewer-levels/logging-viewer-levels.component.mjs +71 -0
  6. package/esm2020/lib/logging-viewer-modal/logging-viewer-modal-properties.model.mjs +2 -0
  7. package/esm2020/lib/logging-viewer-modal/logging-viewer-modal.component.mjs +141 -0
  8. package/esm2020/lib/logging-viewer-search/logging-viewer-search.component.mjs +73 -0
  9. package/esm2020/lib/logging-viewer-translation.model.mjs +2 -0
  10. package/esm2020/lib/logging-viewer.module.mjs +55 -0
  11. package/esm2020/public_api.mjs +11 -0
  12. package/fesm2015/ionic-logging-viewer.mjs +500 -0
  13. package/fesm2015/ionic-logging-viewer.mjs.map +1 -0
  14. package/fesm2020/ionic-logging-viewer.mjs +495 -0
  15. package/fesm2020/ionic-logging-viewer.mjs.map +1 -0
  16. package/ionic-logging-viewer.d.ts +1 -1
  17. package/lib/logging-viewer/logging-viewer.component.d.ts +3 -0
  18. package/lib/logging-viewer-filter.service.d.ts +8 -0
  19. package/lib/logging-viewer-levels/logging-viewer-levels.component.d.ts +3 -0
  20. package/lib/logging-viewer-modal/logging-viewer-modal.component.d.ts +3 -0
  21. package/lib/logging-viewer-search/logging-viewer-search.component.d.ts +3 -0
  22. package/lib/logging-viewer.module.d.ts +11 -0
  23. package/package.json +28 -16
  24. package/bundles/ionic-logging-viewer.umd.js +0 -782
  25. package/bundles/ionic-logging-viewer.umd.js.map +0 -1
  26. package/bundles/ionic-logging-viewer.umd.min.js +0 -16
  27. package/bundles/ionic-logging-viewer.umd.min.js.map +0 -1
  28. package/esm2015/ionic-logging-viewer.js +0 -6
  29. package/esm2015/lib/logging-viewer/logging-viewer.component.js +0 -127
  30. package/esm2015/lib/logging-viewer-filter.service.js +0 -60
  31. package/esm2015/lib/logging-viewer-levels/logging-viewer-levels.component.js +0 -74
  32. package/esm2015/lib/logging-viewer-modal/logging-viewer-modal-properties.model.js +0 -1
  33. package/esm2015/lib/logging-viewer-modal/logging-viewer-modal.component.js +0 -158
  34. package/esm2015/lib/logging-viewer-search/logging-viewer-search.component.js +0 -79
  35. package/esm2015/lib/logging-viewer-translation.model.js +0 -1
  36. package/esm2015/lib/logging-viewer.module.js +0 -39
  37. package/esm2015/public_api.js +0 -9
  38. package/esm5/ionic-logging-viewer.js +0 -6
  39. package/esm5/lib/logging-viewer/logging-viewer.component.js +0 -144
  40. package/esm5/lib/logging-viewer-filter.service.js +0 -69
  41. package/esm5/lib/logging-viewer-levels/logging-viewer-levels.component.js +0 -76
  42. package/esm5/lib/logging-viewer-modal/logging-viewer-modal-properties.model.js +0 -1
  43. package/esm5/lib/logging-viewer-modal/logging-viewer-modal.component.js +0 -191
  44. package/esm5/lib/logging-viewer-search/logging-viewer-search.component.js +0 -81
  45. package/esm5/lib/logging-viewer-translation.model.js +0 -1
  46. package/esm5/lib/logging-viewer.module.js +0 -42
  47. package/esm5/public_api.js +0 -9
  48. package/fesm2015/ionic-logging-viewer.js +0 -519
  49. package/fesm2015/ionic-logging-viewer.js.map +0 -1
  50. package/fesm5/ionic-logging-viewer.js +0 -585
  51. package/fesm5/ionic-logging-viewer.js.map +0 -1
  52. package/ionic-logging-viewer.metadata.json +0 -1
@@ -1,158 +0,0 @@
1
- var LoggingViewerModalComponent_1;
2
- import { __awaiter, __decorate, __metadata } from "tslib";
3
- import { Component, Input } from "@angular/core";
4
- import { ModalController, Platform, AlertController } from "@ionic/angular";
5
- import { Logger, LoggingService } from "ionic-logging-service";
6
- /**
7
- * Ionic modal containing [LoggingViewerComponent](LoggingViewerComponent.html),
8
- * [LoggingViewerLevelsComponent](LoggingViewerLevelsComponent.html) and
9
- * [LoggingViewerSearchComponent](LoggingViewerSearchComponent.html).
10
- */
11
- let LoggingViewerModalComponent = LoggingViewerModalComponent_1 = class LoggingViewerModalComponent {
12
- /**
13
- * Creates a new instance of the component.
14
- */
15
- constructor(platform, alertController, modalController, loggingService) {
16
- this.alertController = alertController;
17
- this.modalController = modalController;
18
- this.loggingService = loggingService;
19
- this.logger = loggingService.getLogger("Ionic.Logging.Viewer.Modal.Component");
20
- const methodName = "ctor";
21
- this.logger.entry(methodName);
22
- this.isAndroid = platform.is("android");
23
- this.logger.exit(methodName);
24
- }
25
- /**
26
- * Initializes the LoggingViewerModalComponent.
27
- * It configures the supported translations.
28
- */
29
- ngOnInit() {
30
- // prepare translations
31
- this.translations = {};
32
- this.translations[LoggingViewerModalComponent_1.languageEn] = {
33
- cancel: "Cancel",
34
- confirmDelete: "Delete all log messages?",
35
- ok: "Ok",
36
- searchPlaceholder: "Search",
37
- title: "Logging",
38
- };
39
- this.translations[LoggingViewerModalComponent_1.languageDe] = {
40
- cancel: "Abbrechen",
41
- confirmDelete: "Alle Logs löschen?",
42
- ok: "Ok",
43
- searchPlaceholder: "Suchen",
44
- title: "Logging",
45
- };
46
- }
47
- /**
48
- * Eventhandler called by Ionic when the modal is opened.
49
- */
50
- ionViewDidEnter() {
51
- const methodName = "ionViewDidEnter";
52
- this.logger.entry(methodName);
53
- this.logger.exit(methodName);
54
- }
55
- /**
56
- * Eventhandler called when the cancel button is clicked.
57
- */
58
- onClose() {
59
- return __awaiter(this, void 0, void 0, function* () {
60
- const methodName = "onClose";
61
- this.logger.entry(methodName);
62
- yield this.modalController.dismiss();
63
- this.logger.exit(methodName);
64
- });
65
- }
66
- /**
67
- * Eventhandler called when the clear button is clicked.
68
- */
69
- onClearLogs() {
70
- return __awaiter(this, void 0, void 0, function* () {
71
- const methodName = "onClearLogs";
72
- this.logger.entry(methodName);
73
- const alert = yield this.alertController.create({
74
- header: this.getTranslation().confirmDelete,
75
- buttons: [
76
- {
77
- text: this.getTranslation().cancel,
78
- role: "cancel",
79
- cssClass: "secondary"
80
- },
81
- {
82
- text: this.getTranslation().ok,
83
- handler: this.clearLogs
84
- },
85
- ]
86
- });
87
- yield alert.present();
88
- this.logger.exit(methodName);
89
- });
90
- }
91
- /**
92
- * Clear logs.
93
- */
94
- clearLogs() {
95
- if (this.localStorageKeys) {
96
- for (const localStorageKey of this.localStorageKeys.split(",")) {
97
- this.loggingService.removeLogMessagesFromLocalStorage(localStorageKey);
98
- }
99
- }
100
- else {
101
- this.loggingService.removeLogMessages();
102
- }
103
- }
104
- /**
105
- * Helper method returning the current translation:
106
- * - the property translation if defined
107
- * - the translation according property language if valid
108
- * - English translation, otherwise
109
- */
110
- getTranslation() {
111
- if (typeof this.translation !== "undefined") {
112
- return this.translation;
113
- }
114
- else if (typeof this.language !== "undefined" && typeof this.translations[this.language] === "object") {
115
- return this.translations[this.language];
116
- }
117
- else {
118
- return this.translations[LoggingViewerModalComponent_1.languageEn];
119
- }
120
- }
121
- };
122
- LoggingViewerModalComponent.languageEn = "en";
123
- LoggingViewerModalComponent.languageDe = "de";
124
- LoggingViewerModalComponent.ctorParameters = () => [
125
- { type: Platform },
126
- { type: AlertController },
127
- { type: ModalController },
128
- { type: LoggingService }
129
- ];
130
- __decorate([
131
- Input(),
132
- __metadata("design:type", String)
133
- ], LoggingViewerModalComponent.prototype, "language", void 0);
134
- __decorate([
135
- Input(),
136
- __metadata("design:type", Object)
137
- ], LoggingViewerModalComponent.prototype, "translation", void 0);
138
- __decorate([
139
- Input(),
140
- __metadata("design:type", String)
141
- ], LoggingViewerModalComponent.prototype, "localStorageKeys", void 0);
142
- __decorate([
143
- Input(),
144
- __metadata("design:type", Boolean)
145
- ], LoggingViewerModalComponent.prototype, "allowClearLogs", void 0);
146
- LoggingViewerModalComponent = LoggingViewerModalComponent_1 = __decorate([
147
- Component({
148
- selector: "ionic-logging-viewer-modal",
149
- template: "<ion-header>\n\t<ion-toolbar color=primary>\n\t\t<ion-title>{{ getTranslation().title }}</ion-title>\n\t\t<ion-buttons slot=\"start\">\n\t\t\t<ion-button *ngIf=\"!isAndroid\" (click)=\"onClose()\">\n\t\t\t\t{{ getTranslation().cancel }}\n\t\t\t</ion-button>\n\t\t\t<ion-button *ngIf=\"isAndroid\" icon-only (click)=\"onClose()\">\n\t\t\t\t<ion-icon name=\"md-close\"></ion-icon>\n\t\t\t</ion-button>\n\t\t</ion-buttons>\n\t</ion-toolbar>\n\t<ion-toolbar>\n\t\t<ionic-logging-viewer-search [placeholder]=\"getTranslation().searchPlaceholder\"></ionic-logging-viewer-search>\n\t\t<ion-buttons slot=\"end\" *ngIf=\"allowClearLogs !== false\" class=\"clearLogs\">\n\t\t\t<ion-button (click)=\"onClearLogs()\">\n\t\t\t\t<ion-icon name=\"trash-outline\"></ion-icon>\n\t\t\t</ion-button>\n\t\t</ion-buttons>\n\t</ion-toolbar>\n\t<ion-toolbar>\n\t\t<ionic-logging-viewer-levels></ionic-logging-viewer-levels>\n\t</ion-toolbar>\n</ion-header>\n<ion-content>\n\t<ionic-logging-viewer [localStorageKeys]=\"localStorageKeys\"></ionic-logging-viewer>\n</ion-content>",
150
- styles: ["ionic-logging-viewer-levels{width:100%;padding-left:12px;padding-right:12px}.clearLogs{padding-top:3px}"]
151
- }),
152
- __metadata("design:paramtypes", [Platform,
153
- AlertController,
154
- ModalController,
155
- LoggingService])
156
- ], LoggingViewerModalComponent);
157
- export { LoggingViewerModalComponent };
158
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logging-viewer-modal.component.js","sourceRoot":"ng://ionic-logging-viewer/","sources":["lib/logging-viewer-modal/logging-viewer-modal.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input } from \"@angular/core\";\n\nimport { ModalController, Platform, AlertController } from \"@ionic/angular\";\n\nimport { Logger, LoggingService } from \"ionic-logging-service\";\n\nimport { LoggingViewerTranslation } from \"../logging-viewer-translation.model\";\n\n/**\n * Ionic modal containing [LoggingViewerComponent](LoggingViewerComponent.html),\n * [LoggingViewerLevelsComponent](LoggingViewerLevelsComponent.html) and\n * [LoggingViewerSearchComponent](LoggingViewerSearchComponent.html).\n */\n@Component({\n\tselector: \"ionic-logging-viewer-modal\",\n\ttemplateUrl: \"./logging-viewer-modal.component.html\",\n\tstyleUrls: [\"./logging-viewer-modal.component.scss\"]\n})\nexport class LoggingViewerModalComponent implements OnInit {\n\n\tprivate static languageEn = \"en\";\n\tprivate static languageDe = \"de\";\n\n\t/**\n\t * Language to be used for the modal.\n\t * Currently supported: en, de\n\t */\n\t@Input()\n\tpublic language: string;\n\n\t/**\n\t * Translation to be used for the modal.\n\t * If specified, the language is ignored.\n\t */\n\t@Input()\n\tpublic translation: LoggingViewerTranslation;\n\n\t/**\n\t * Comma-separated list of localStorageKeys. If set, the logs get loaded from localStorage instead of memory.\n\t */\n\t@Input()\n\tpublic localStorageKeys: string;\n\n\t/**\n\t * Flag showing a delete button, which removes all existing log messages.\n\t */\n\t@Input()\n\tpublic allowClearLogs: boolean;\n\n\t/**\n\t * Flag controlling which close button will be shown.\n\t */\n\tpublic isAndroid: boolean;\n\n\t// tslint:disable-next-line:completed-docs\n\tprivate logger: Logger;\n\n\t// tslint:disable-next-line:completed-docs\n\tprivate translations: { [language: string]: LoggingViewerTranslation; };\n\n\t/**\n\t * Creates a new instance of the component.\n\t */\n\tconstructor(\n\t\tplatform: Platform,\n\t\tprivate alertController: AlertController,\n\t\tprivate modalController: ModalController,\n\t\tprivate loggingService: LoggingService) {\n\n\t\tthis.logger = loggingService.getLogger(\"Ionic.Logging.Viewer.Modal.Component\");\n\t\tconst methodName = \"ctor\";\n\t\tthis.logger.entry(methodName);\n\n\t\tthis.isAndroid = platform.is(\"android\");\n\n\t\tthis.logger.exit(methodName);\n\t}\n\n\t/**\n\t * Initializes the LoggingViewerModalComponent.\n\t * It configures the supported translations.\n\t */\n\tpublic ngOnInit(): void {\n\t\t// prepare translations\n\t\tthis.translations = {};\n\t\tthis.translations[LoggingViewerModalComponent.languageEn] = {\n\t\t\tcancel: \"Cancel\",\n\t\t\tconfirmDelete: \"Delete all log messages?\",\n\t\t\tok: \"Ok\",\n\t\t\tsearchPlaceholder: \"Search\",\n\t\t\ttitle: \"Logging\",\n\t\t};\n\t\tthis.translations[LoggingViewerModalComponent.languageDe] = {\n\t\t\tcancel: \"Abbrechen\",\n\t\t\tconfirmDelete: \"Alle Logs löschen?\",\n\t\t\tok: \"Ok\",\n\t\t\tsearchPlaceholder: \"Suchen\",\n\t\t\ttitle: \"Logging\",\n\t\t};\n\t}\n\n\t/**\n\t * Eventhandler called by Ionic when the modal is opened.\n\t */\n\tpublic ionViewDidEnter(): void {\n\t\tconst methodName = \"ionViewDidEnter\";\n\t\tthis.logger.entry(methodName);\n\n\t\tthis.logger.exit(methodName);\n\t}\n\n\t/**\n\t * Eventhandler called when the cancel button is clicked.\n\t */\n\tpublic async onClose(): Promise<void> {\n\t\tconst methodName = \"onClose\";\n\t\tthis.logger.entry(methodName);\n\n\t\tawait this.modalController.dismiss();\n\n\t\tthis.logger.exit(methodName);\n\t}\n\n\t/**\n\t * Eventhandler called when the clear button is clicked.\n\t */\n\tpublic async onClearLogs(): Promise<void> {\n\t\tconst methodName = \"onClearLogs\";\n\t\tthis.logger.entry(methodName);\n\n\t\tconst alert = await this.alertController.create({\n\t\t\theader: this.getTranslation().confirmDelete,\n\t\t\tbuttons: [\n\t\t\t\t{\n\t\t\t\t\ttext: this.getTranslation().cancel,\n\t\t\t\t\trole: \"cancel\",\n\t\t\t\t\tcssClass: \"secondary\"\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\ttext: this.getTranslation().ok,\n\t\t\t\t\thandler: this.clearLogs\n\t\t\t\t},\n\t\t\t]\n\t\t});\n\t\tawait alert.present();\n\n\t\tthis.logger.exit(methodName);\n\t}\n\n\t/**\n\t * Clear logs.\n\t */\n\tpublic clearLogs(): void {\n\t\tif (this.localStorageKeys) {\n\t\t\tfor (const localStorageKey of this.localStorageKeys.split(\",\")) {\n\t\t\t\tthis.loggingService.removeLogMessagesFromLocalStorage(localStorageKey);\n\t\t\t}\n\t\t} else {\n\t\t\tthis.loggingService.removeLogMessages();\n\t\t}\n\t}\n\n\t/**\n\t * Helper method returning the current translation:\n\t * - the property translation if defined\n\t * - the translation according property language if valid\n\t * - English translation, otherwise\n\t */\n\tpublic getTranslation(): LoggingViewerTranslation {\n\t\tif (typeof this.translation !== \"undefined\") {\n\t\t\treturn this.translation;\n\t\t} else if (typeof this.language !== \"undefined\" && typeof this.translations[this.language] === \"object\") {\n\t\t\treturn this.translations[this.language];\n\t\t} else {\n\t\t\treturn this.translations[LoggingViewerModalComponent.languageEn];\n\t\t}\n\t}\n}\n"]}
@@ -1,79 +0,0 @@
1
- import { __decorate, __metadata } from "tslib";
2
- import { Component, Input } from "@angular/core";
3
- import { LoggingService, Logger } from "ionic-logging-service";
4
- import { LoggingViewerFilterService } from "../logging-viewer-filter.service";
5
- /**
6
- * Component for displaying the search bar for filtering the current logs.
7
- *
8
- * The component can be embedded in any web page using:
9
- *
10
- * &lt;ionic-logging-viewer-search placeholder="Search">&lt;/ionic-logging-viewer-search>
11
- */
12
- let LoggingViewerSearchComponent = class LoggingViewerSearchComponent {
13
- /**
14
- * Creates a new instance of the component.
15
- */
16
- constructor(loggingService, loggingViewerFilterService) {
17
- this.loggingViewerFilterService = loggingViewerFilterService;
18
- this.logger = loggingService.getLogger("Ionic.Logging.Viewer.Search.Component");
19
- const methodName = "ctor";
20
- this.logger.entry(methodName);
21
- this.logger.exit(methodName);
22
- }
23
- /**
24
- * Initialize the component.
25
- *
26
- * This is done by reading the filter data from [LoggingViewerFilterService](LoggingViewerFilterService.html).
27
- */
28
- ngOnInit() {
29
- const methodName = "ngOnInit";
30
- this.logger.entry(methodName);
31
- if (!this.placeholder) {
32
- this.placeholder = "Search";
33
- }
34
- this.search = this.loggingViewerFilterService.search;
35
- // subscribe to loggingViewerFilterService.filterChanged event, to refresh,
36
- // when someone else modifies the search value
37
- this.filterChangedSubscription = this.loggingViewerFilterService.filterChanged.subscribe(() => {
38
- this.search = this.loggingViewerFilterService.search;
39
- });
40
- this.logger.exit(methodName);
41
- }
42
- /**
43
- * Clean up.
44
- */
45
- ngOnDestroy() {
46
- const methodName = "ngOnDestroy";
47
- this.logger.entry(methodName);
48
- this.filterChangedSubscription.unsubscribe();
49
- this.logger.exit(methodName);
50
- }
51
- /**
52
- * Callback when the search value was changed in the UI.
53
- */
54
- onSearchChanged() {
55
- const methodName = "onSearchChanged";
56
- this.logger.entry(methodName, this.search);
57
- this.loggingViewerFilterService.search = this.search;
58
- this.logger.exit(methodName);
59
- }
60
- };
61
- LoggingViewerSearchComponent.ctorParameters = () => [
62
- { type: LoggingService },
63
- { type: LoggingViewerFilterService }
64
- ];
65
- __decorate([
66
- Input(),
67
- __metadata("design:type", String)
68
- ], LoggingViewerSearchComponent.prototype, "placeholder", void 0);
69
- LoggingViewerSearchComponent = __decorate([
70
- Component({
71
- selector: "ionic-logging-viewer-search",
72
- template: "<ion-searchbar placeholder=\"{{placeholder}}\" [(ngModel)]=\"search\" (ionChange)=\"onSearchChanged()\"></ion-searchbar>",
73
- styles: ["ion-searchbar{padding-top:3px;padding-bottom:0}"]
74
- }),
75
- __metadata("design:paramtypes", [LoggingService,
76
- LoggingViewerFilterService])
77
- ], LoggingViewerSearchComponent);
78
- export { LoggingViewerSearchComponent };
79
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2luZy12aWV3ZXItc2VhcmNoLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2lvbmljLWxvZ2dpbmctdmlld2VyLyIsInNvdXJjZXMiOlsibGliL2xvZ2dpbmctdmlld2VyLXNlYXJjaC9sb2dnaW5nLXZpZXdlci1zZWFyY2guY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFxQixLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFJcEUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUUvRCxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUU5RTs7Ozs7O0dBTUc7QUFNSCxJQUFhLDRCQUE0QixHQUF6QyxNQUFhLDRCQUE0QjtJQWdCeEM7O09BRUc7SUFDSCxZQUNDLGNBQThCLEVBQ3RCLDBCQUFzRDtRQUF0RCwrQkFBMEIsR0FBMUIsMEJBQTBCLENBQTRCO1FBRTlELElBQUksQ0FBQyxNQUFNLEdBQUcsY0FBYyxDQUFDLFNBQVMsQ0FBQyx1Q0FBdUMsQ0FBQyxDQUFDO1FBQ2hGLE1BQU0sVUFBVSxHQUFHLE1BQU0sQ0FBQztRQUMxQixJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUU5QixJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUM5QixDQUFDO0lBRUQ7Ozs7T0FJRztJQUNJLFFBQVE7UUFDZCxNQUFNLFVBQVUsR0FBRyxVQUFVLENBQUM7UUFDOUIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDLENBQUM7UUFFOUIsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUU7WUFDdEIsSUFBSSxDQUFDLFdBQVcsR0FBRyxRQUFRLENBQUM7U0FDNUI7UUFDRCxJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQywwQkFBMEIsQ0FBQyxNQUFNLENBQUM7UUFFckQsMkVBQTJFO1FBQzNFLDhDQUE4QztRQUM5QyxJQUFJLENBQUMseUJBQXlCLEdBQUcsSUFBSSxDQUFDLDBCQUEwQixDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQzdGLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLDBCQUEwQixDQUFDLE1BQU0sQ0FBQztRQUN0RCxDQUFDLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQzlCLENBQUM7SUFFRDs7T0FFRztJQUNJLFdBQVc7UUFDakIsTUFBTSxVQUFVLEdBQUcsYUFBYSxDQUFDO1FBQ2pDLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBRTlCLElBQUksQ0FBQyx5QkFBeUIsQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUU3QyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUM5QixDQUFDO0lBRUQ7O09BRUc7SUFDSSxlQUFlO1FBQ3JCLE1BQU0sVUFBVSxHQUFHLGlCQUFpQixDQUFDO1FBQ3JDLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLFVBQVUsRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFFM0MsSUFBSSxDQUFDLDBCQUEwQixDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDO1FBRXJELElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQzlCLENBQUM7Q0FDRCxDQUFBOztZQXhEaUIsY0FBYztZQUNNLDBCQUEwQjs7QUFmL0Q7SUFEQyxLQUFLLEVBQUU7O2lFQUNtQjtBQU5mLDRCQUE0QjtJQUx4QyxTQUFTLENBQUM7UUFDVixRQUFRLEVBQUUsNkJBQTZCO1FBQ3ZDLG9JQUFxRDs7S0FFckQsQ0FBQztxQ0FxQmdCLGNBQWM7UUFDTSwwQkFBMEI7R0FyQm5ELDRCQUE0QixDQTRFeEM7U0E1RVksNEJBQTRCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQsIE9uRGVzdHJveSwgSW5wdXQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuXG5pbXBvcnQgeyBTdWJzY3JpcHRpb24gfSBmcm9tIFwicnhqc1wiO1xuXG5pbXBvcnQgeyBMb2dnaW5nU2VydmljZSwgTG9nZ2VyIH0gZnJvbSBcImlvbmljLWxvZ2dpbmctc2VydmljZVwiO1xuXG5pbXBvcnQgeyBMb2dnaW5nVmlld2VyRmlsdGVyU2VydmljZSB9IGZyb20gXCIuLi9sb2dnaW5nLXZpZXdlci1maWx0ZXIuc2VydmljZVwiO1xuXG4vKipcbiAqIENvbXBvbmVudCBmb3IgZGlzcGxheWluZyB0aGUgc2VhcmNoIGJhciBmb3IgZmlsdGVyaW5nIHRoZSBjdXJyZW50IGxvZ3MuXG4gKlxuICogVGhlIGNvbXBvbmVudCBjYW4gYmUgZW1iZWRkZWQgaW4gYW55IHdlYiBwYWdlIHVzaW5nOlxuICpcbiAqICZsdDtpb25pYy1sb2dnaW5nLXZpZXdlci1zZWFyY2ggcGxhY2Vob2xkZXI9XCJTZWFyY2hcIj4mbHQ7L2lvbmljLWxvZ2dpbmctdmlld2VyLXNlYXJjaD5cbiAqL1xuQENvbXBvbmVudCh7XG5cdHNlbGVjdG9yOiBcImlvbmljLWxvZ2dpbmctdmlld2VyLXNlYXJjaFwiLFxuXHR0ZW1wbGF0ZVVybDogXCIuL2xvZ2dpbmctdmlld2VyLXNlYXJjaC5jb21wb25lbnQuaHRtbFwiLFxuXHRzdHlsZVVybHM6IFtcIi4vbG9nZ2luZy12aWV3ZXItc2VhcmNoLmNvbXBvbmVudC5zY3NzXCJdXG59KVxuZXhwb3J0IGNsYXNzIExvZ2dpbmdWaWV3ZXJTZWFyY2hDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG5cblx0LyoqXG5cdCAqIFBsYWNlaG9sZGVyIHRvIGJlIHNob3duIGluIHRoZSBlbXB0eSBzZWFyY2ggYmFyLlxuXHQgKi9cblx0QElucHV0KClcblx0cHVibGljIHBsYWNlaG9sZGVyOiBzdHJpbmc7XG5cblx0LyoqXG5cdCAqIEN1cnJlbnQgc2VhcmNoIHZhbHVlLlxuXHQgKi9cblx0cHVibGljIHNlYXJjaDogc3RyaW5nO1xuXG5cdHByaXZhdGUgbG9nZ2VyOiBMb2dnZXI7XG5cdHByaXZhdGUgZmlsdGVyQ2hhbmdlZFN1YnNjcmlwdGlvbjogU3Vic2NyaXB0aW9uO1xuXG5cdC8qKlxuXHQgKiBDcmVhdGVzIGEgbmV3IGluc3RhbmNlIG9mIHRoZSBjb21wb25lbnQuXG5cdCAqL1xuXHRjb25zdHJ1Y3Rvcihcblx0XHRsb2dnaW5nU2VydmljZTogTG9nZ2luZ1NlcnZpY2UsXG5cdFx0cHJpdmF0ZSBsb2dnaW5nVmlld2VyRmlsdGVyU2VydmljZTogTG9nZ2luZ1ZpZXdlckZpbHRlclNlcnZpY2UpIHtcblxuXHRcdHRoaXMubG9nZ2VyID0gbG9nZ2luZ1NlcnZpY2UuZ2V0TG9nZ2VyKFwiSW9uaWMuTG9nZ2luZy5WaWV3ZXIuU2VhcmNoLkNvbXBvbmVudFwiKTtcblx0XHRjb25zdCBtZXRob2ROYW1lID0gXCJjdG9yXCI7XG5cdFx0dGhpcy5sb2dnZXIuZW50cnkobWV0aG9kTmFtZSk7XG5cblx0XHR0aGlzLmxvZ2dlci5leGl0KG1ldGhvZE5hbWUpO1xuXHR9XG5cblx0LyoqXG5cdCAqIEluaXRpYWxpemUgdGhlIGNvbXBvbmVudC5cblx0ICpcblx0ICogVGhpcyBpcyBkb25lIGJ5IHJlYWRpbmcgdGhlIGZpbHRlciBkYXRhIGZyb20gW0xvZ2dpbmdWaWV3ZXJGaWx0ZXJTZXJ2aWNlXShMb2dnaW5nVmlld2VyRmlsdGVyU2VydmljZS5odG1sKS5cblx0ICovXG5cdHB1YmxpYyBuZ09uSW5pdCgpOiB2b2lkIHtcblx0XHRjb25zdCBtZXRob2ROYW1lID0gXCJuZ09uSW5pdFwiO1xuXHRcdHRoaXMubG9nZ2VyLmVudHJ5KG1ldGhvZE5hbWUpO1xuXG5cdFx0aWYgKCF0aGlzLnBsYWNlaG9sZGVyKSB7XG5cdFx0XHR0aGlzLnBsYWNlaG9sZGVyID0gXCJTZWFyY2hcIjtcblx0XHR9XG5cdFx0dGhpcy5zZWFyY2ggPSB0aGlzLmxvZ2dpbmdWaWV3ZXJGaWx0ZXJTZXJ2aWNlLnNlYXJjaDtcblxuXHRcdC8vIHN1YnNjcmliZSB0byBsb2dnaW5nVmlld2VyRmlsdGVyU2VydmljZS5maWx0ZXJDaGFuZ2VkIGV2ZW50LCB0byByZWZyZXNoLFxuXHRcdC8vIHdoZW4gc29tZW9uZSBlbHNlIG1vZGlmaWVzIHRoZSBzZWFyY2ggdmFsdWVcblx0XHR0aGlzLmZpbHRlckNoYW5nZWRTdWJzY3JpcHRpb24gPSB0aGlzLmxvZ2dpbmdWaWV3ZXJGaWx0ZXJTZXJ2aWNlLmZpbHRlckNoYW5nZWQuc3Vic2NyaWJlKCgpID0+IHtcblx0XHRcdHRoaXMuc2VhcmNoID0gdGhpcy5sb2dnaW5nVmlld2VyRmlsdGVyU2VydmljZS5zZWFyY2g7XG5cdFx0fSk7XG5cblx0XHR0aGlzLmxvZ2dlci5leGl0KG1ldGhvZE5hbWUpO1xuXHR9XG5cblx0LyoqXG5cdCAqIENsZWFuIHVwLlxuXHQgKi9cblx0cHVibGljIG5nT25EZXN0cm95KCk6IHZvaWQge1xuXHRcdGNvbnN0IG1ldGhvZE5hbWUgPSBcIm5nT25EZXN0cm95XCI7XG5cdFx0dGhpcy5sb2dnZXIuZW50cnkobWV0aG9kTmFtZSk7XG5cblx0XHR0aGlzLmZpbHRlckNoYW5nZWRTdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcblxuXHRcdHRoaXMubG9nZ2VyLmV4aXQobWV0aG9kTmFtZSk7XG5cdH1cblxuXHQvKipcblx0ICogQ2FsbGJhY2sgd2hlbiB0aGUgc2VhcmNoIHZhbHVlIHdhcyBjaGFuZ2VkIGluIHRoZSBVSS5cblx0ICovXG5cdHB1YmxpYyBvblNlYXJjaENoYW5nZWQoKTogdm9pZCB7XG5cdFx0Y29uc3QgbWV0aG9kTmFtZSA9IFwib25TZWFyY2hDaGFuZ2VkXCI7XG5cdFx0dGhpcy5sb2dnZXIuZW50cnkobWV0aG9kTmFtZSwgdGhpcy5zZWFyY2gpO1xuXG5cdFx0dGhpcy5sb2dnaW5nVmlld2VyRmlsdGVyU2VydmljZS5zZWFyY2ggPSB0aGlzLnNlYXJjaDtcblxuXHRcdHRoaXMubG9nZ2VyLmV4aXQobWV0aG9kTmFtZSk7XG5cdH1cbn1cbiJdfQ==
@@ -1 +0,0 @@
1
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2luZy12aWV3ZXItdHJhbnNsYXRpb24ubW9kZWwuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9pb25pYy1sb2dnaW5nLXZpZXdlci8iLCJzb3VyY2VzIjpbImxpYi9sb2dnaW5nLXZpZXdlci10cmFuc2xhdGlvbi5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBEZXNjcmliZXMgYWxsIHZhbHVlcyBuZWVkZWQgaW4gYSB0cmFuc2xhdGlvbiBmb3JcbiAqIFtMb2dnaW5nVmlld2VyTW9kYWxDb21wb25lbnRdKC4uL2NsYXNzZXMvTG9nZ2luZ1ZpZXdlck1vZGFsQ29tcG9uZW50Lmh0bWwpLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIExvZ2dpbmdWaWV3ZXJUcmFuc2xhdGlvbiB7XG5cdC8qKlxuXHQgKiBUaXRsZSBvZiB0aGUgbW9kYWwuXG5cdCAqL1xuXHR0aXRsZTogc3RyaW5nO1xuXG5cdC8qKlxuXHQgKiBDYW5jZWwgYnV0dG9uLlxuXHQgKiBUaGVyZSBhcmUgdHdvIGNhbmNlbCBidXR0b25zOiBpbiB0aGUgbW9kYWwgaXRzZWxmIChpT1Mgb25seSkgYW5kIHRoZSBjb25maXJtYXRpb24gZm9yIGRlbGV0aW5nIHRoZSBtZXNzYWdlcy5cblx0ICovXG5cdGNhbmNlbDogc3RyaW5nO1xuXG5cdC8qKlxuXHQgKiBPayBidXR0b24uXG5cdCAqL1xuXHRvazogc3RyaW5nO1xuXG5cdC8qKlxuXHQgKiBQbGFjZWhvbGRlciBmb3Igc2VhcmNoIGJhci5cblx0ICovXG5cdHNlYXJjaFBsYWNlaG9sZGVyOiBzdHJpbmc7XG5cblx0LyoqXG5cdCAqIENvbmZpcm1hdGlvbiBtZXNzYWdlIGZvciBkZWxldGluZyBsb2cgbWVzc2FnZXMuXG5cdCAqL1xuXHRjb25maXJtRGVsZXRlOiBzdHJpbmc7XG59XG4iXX0=
@@ -1,39 +0,0 @@
1
- import { __decorate } from "tslib";
2
- import { NgModule } from "@angular/core";
3
- import { CommonModule } from "@angular/common";
4
- import { FormsModule } from "@angular/forms";
5
- import { IonicModule } from "@ionic/angular";
6
- import { LoggingViewerComponent } from "./logging-viewer/logging-viewer.component";
7
- import { LoggingViewerFilterService } from "./logging-viewer-filter.service";
8
- import { LoggingViewerLevelsComponent } from "./logging-viewer-levels/logging-viewer-levels.component";
9
- import { LoggingViewerSearchComponent } from "./logging-viewer-search/logging-viewer-search.component";
10
- import { LoggingViewerModalComponent } from "./logging-viewer-modal/logging-viewer-modal.component";
11
- let LoggingViewerModule = class LoggingViewerModule {
12
- };
13
- LoggingViewerModule = __decorate([
14
- NgModule({
15
- imports: [
16
- CommonModule,
17
- FormsModule,
18
- IonicModule
19
- ],
20
- declarations: [
21
- LoggingViewerComponent,
22
- LoggingViewerSearchComponent,
23
- LoggingViewerLevelsComponent,
24
- LoggingViewerModalComponent
25
- ],
26
- entryComponents: [],
27
- exports: [
28
- LoggingViewerComponent,
29
- LoggingViewerSearchComponent,
30
- LoggingViewerLevelsComponent,
31
- LoggingViewerModalComponent
32
- ],
33
- providers: [
34
- LoggingViewerFilterService
35
- ]
36
- })
37
- ], LoggingViewerModule);
38
- export { LoggingViewerModule };
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2luZy12aWV3ZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vaW9uaWMtbG9nZ2luZy12aWV3ZXIvIiwic291cmNlcyI6WyJsaWIvbG9nZ2luZy12aWV3ZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFN0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRTdDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQzdFLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLHlEQUF5RCxDQUFDO0FBQ3ZHLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLHlEQUF5RCxDQUFDO0FBQ3ZHLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLHVEQUF1RCxDQUFDO0FBMEJwRyxJQUFhLG1CQUFtQixHQUFoQyxNQUFhLG1CQUFtQjtDQUFJLENBQUE7QUFBdkIsbUJBQW1CO0lBeEIvQixRQUFRLENBQUM7UUFDVCxPQUFPLEVBQUU7WUFDUixZQUFZO1lBQ1osV0FBVztZQUNYLFdBQVc7U0FDWDtRQUNELFlBQVksRUFBRTtZQUNiLHNCQUFzQjtZQUN0Qiw0QkFBNEI7WUFDNUIsNEJBQTRCO1lBQzVCLDJCQUEyQjtTQUMzQjtRQUNELGVBQWUsRUFBRSxFQUNoQjtRQUNELE9BQU8sRUFBRTtZQUNSLHNCQUFzQjtZQUN0Qiw0QkFBNEI7WUFDNUIsNEJBQTRCO1lBQzVCLDJCQUEyQjtTQUMzQjtRQUNELFNBQVMsRUFBRTtZQUNWLDBCQUEwQjtTQUMxQjtLQUNELENBQUM7R0FDVyxtQkFBbUIsQ0FBSTtTQUF2QixtQkFBbUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xuXG5pbXBvcnQgeyBJb25pY01vZHVsZSB9IGZyb20gXCJAaW9uaWMvYW5ndWxhclwiO1xuXG5pbXBvcnQgeyBMb2dnaW5nVmlld2VyQ29tcG9uZW50IH0gZnJvbSBcIi4vbG9nZ2luZy12aWV3ZXIvbG9nZ2luZy12aWV3ZXIuY29tcG9uZW50XCI7XG5pbXBvcnQgeyBMb2dnaW5nVmlld2VyRmlsdGVyU2VydmljZSB9IGZyb20gXCIuL2xvZ2dpbmctdmlld2VyLWZpbHRlci5zZXJ2aWNlXCI7XG5pbXBvcnQgeyBMb2dnaW5nVmlld2VyTGV2ZWxzQ29tcG9uZW50IH0gZnJvbSBcIi4vbG9nZ2luZy12aWV3ZXItbGV2ZWxzL2xvZ2dpbmctdmlld2VyLWxldmVscy5jb21wb25lbnRcIjtcbmltcG9ydCB7IExvZ2dpbmdWaWV3ZXJTZWFyY2hDb21wb25lbnQgfSBmcm9tIFwiLi9sb2dnaW5nLXZpZXdlci1zZWFyY2gvbG9nZ2luZy12aWV3ZXItc2VhcmNoLmNvbXBvbmVudFwiO1xuaW1wb3J0IHsgTG9nZ2luZ1ZpZXdlck1vZGFsQ29tcG9uZW50IH0gZnJvbSBcIi4vbG9nZ2luZy12aWV3ZXItbW9kYWwvbG9nZ2luZy12aWV3ZXItbW9kYWwuY29tcG9uZW50XCI7XG5cbkBOZ01vZHVsZSh7XG5cdGltcG9ydHM6IFtcblx0XHRDb21tb25Nb2R1bGUsXG5cdFx0Rm9ybXNNb2R1bGUsXG5cdFx0SW9uaWNNb2R1bGVcblx0XSxcblx0ZGVjbGFyYXRpb25zOiBbXG5cdFx0TG9nZ2luZ1ZpZXdlckNvbXBvbmVudCxcblx0XHRMb2dnaW5nVmlld2VyU2VhcmNoQ29tcG9uZW50LFxuXHRcdExvZ2dpbmdWaWV3ZXJMZXZlbHNDb21wb25lbnQsXG5cdFx0TG9nZ2luZ1ZpZXdlck1vZGFsQ29tcG9uZW50XG5cdF0sXG5cdGVudHJ5Q29tcG9uZW50czogW1xuXHRdLFxuXHRleHBvcnRzOiBbXG5cdFx0TG9nZ2luZ1ZpZXdlckNvbXBvbmVudCxcblx0XHRMb2dnaW5nVmlld2VyU2VhcmNoQ29tcG9uZW50LFxuXHRcdExvZ2dpbmdWaWV3ZXJMZXZlbHNDb21wb25lbnQsXG5cdFx0TG9nZ2luZ1ZpZXdlck1vZGFsQ29tcG9uZW50XG5cdF0sXG5cdHByb3ZpZGVyczogW1xuXHRcdExvZ2dpbmdWaWV3ZXJGaWx0ZXJTZXJ2aWNlXG5cdF1cbn0pXG5leHBvcnQgY2xhc3MgTG9nZ2luZ1ZpZXdlck1vZHVsZSB7IH1cbiJdfQ==
@@ -1,9 +0,0 @@
1
- /*
2
- * Public API Surface of ionic-logging-viewer
3
- */
4
- export * from "./lib/logging-viewer.module";
5
- export * from "./lib/logging-viewer/logging-viewer.component";
6
- export * from "./lib/logging-viewer-levels/logging-viewer-levels.component";
7
- export * from "./lib/logging-viewer-search/logging-viewer-search.component";
8
- export * from "./lib/logging-viewer-modal/logging-viewer-modal.component";
9
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL2lvbmljLWxvZ2dpbmctdmlld2VyLyIsInNvdXJjZXMiOlsicHVibGljX2FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLDZEQUE2RCxDQUFDO0FBQzVFLGNBQWMsNkRBQTZELENBQUM7QUFDNUUsY0FBYywyREFBMkQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgaW9uaWMtbG9nZ2luZy12aWV3ZXJcbiAqL1xuXG5leHBvcnQgKiBmcm9tIFwiLi9saWIvbG9nZ2luZy12aWV3ZXIubW9kdWxlXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvbG9nZ2luZy12aWV3ZXIvbG9nZ2luZy12aWV3ZXIuY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9saWIvbG9nZ2luZy12aWV3ZXItbGV2ZWxzL2xvZ2dpbmctdmlld2VyLWxldmVscy5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9sb2dnaW5nLXZpZXdlci1zZWFyY2gvbG9nZ2luZy12aWV3ZXItc2VhcmNoLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2xvZ2dpbmctdmlld2VyLW1vZGFsL2xvZ2dpbmctdmlld2VyLW1vZGFsLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL2xvZ2dpbmctdmlld2VyLW1vZGFsL2xvZ2dpbmctdmlld2VyLW1vZGFsLXByb3BlcnRpZXMubW9kZWxcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9sb2dnaW5nLXZpZXdlci10cmFuc2xhdGlvbi5tb2RlbFwiO1xuIl19
@@ -1,6 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './public_api';
5
- export { LoggingViewerFilterService as ɵa } from './lib/logging-viewer-filter.service';
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW9uaWMtbG9nZ2luZy12aWV3ZXIuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9pb25pYy1sb2dnaW5nLXZpZXdlci8iLCJzb3VyY2VzIjpbImlvbmljLWxvZ2dpbmctdmlld2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxjQUFjLENBQUM7QUFFN0IsT0FBTyxFQUFDLDBCQUEwQixJQUFJLEVBQUUsRUFBQyxNQUFNLHFDQUFxQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpY19hcGknO1xuXG5leHBvcnQge0xvZ2dpbmdWaWV3ZXJGaWx0ZXJTZXJ2aWNlIGFzIMm1YX0gZnJvbSAnLi9saWIvbG9nZ2luZy12aWV3ZXItZmlsdGVyLnNlcnZpY2UnOyJdfQ==
@@ -1,144 +0,0 @@
1
- import { __awaiter, __decorate, __generator, __metadata, __values } from "tslib";
2
- import { Component, Input } from "@angular/core";
3
- import { Logger, LoggingService, LogLevelConverter, LogMessage } from "ionic-logging-service";
4
- import { LoggingViewerFilterService } from "../logging-viewer-filter.service";
5
- /**
6
- * Component for displaying the current logs.
7
- *
8
- * The component can be embedded in any web page using:
9
- *
10
- * &lt;ionic-logging-viewer>&lt;/ionic-logging-viewer>
11
- */
12
- var LoggingViewerComponent = /** @class */ (function () {
13
- /**
14
- * Creates a new instance of the component.
15
- */
16
- function LoggingViewerComponent(loggingService, loggingViewerFilterService) {
17
- this.loggingService = loggingService;
18
- this.loggingViewerFilterService = loggingViewerFilterService;
19
- this.logger = loggingService.getLogger("Ionic.Logging.Viewer.Component");
20
- var methodName = "ctor";
21
- this.logger.entry(methodName);
22
- this.logger.exit(methodName);
23
- }
24
- /**
25
- * Initialize the component.
26
- *
27
- * This is done by reading the filter data from [LoggingViewerFilterService](LoggingViewerFilterService.html)
28
- * and the log messages from [LoggingService](../../../ionic-logging-service/typedoc/index.html).
29
- * If the localStorageKeys property is set, the messages are read from local storage.
30
- */
31
- LoggingViewerComponent.prototype.ngOnInit = function () {
32
- var _this = this;
33
- var methodName = "ngOnInit";
34
- this.logger.entry(methodName);
35
- this.loadLogMessages();
36
- this.filterLogMessages();
37
- // subscribe to loggingService.logMessagesChanged event, to refresh, when new message is logged
38
- this.logMessagesChangedSubscription = this.loggingService.logMessagesChanged.subscribe(function () { return __awaiter(_this, void 0, void 0, function () {
39
- return __generator(this, function (_a) {
40
- this.loadLogMessages();
41
- this.filterLogMessages();
42
- return [2 /*return*/];
43
- });
44
- }); });
45
- // subscribe to loggingViewerFilterService.filterChanged event, to refresh, when filter is modified
46
- this.filterChangedSubscription = this.loggingViewerFilterService.filterChanged.subscribe(function () {
47
- _this.filterLogMessages();
48
- });
49
- this.logger.exit(methodName);
50
- };
51
- /**
52
- * Clean up.
53
- */
54
- LoggingViewerComponent.prototype.ngOnDestroy = function () {
55
- var methodName = "ngOnDestroy";
56
- this.logger.entry(methodName);
57
- this.logMessagesChangedSubscription.unsubscribe();
58
- this.filterChangedSubscription.unsubscribe();
59
- this.logger.exit(methodName);
60
- };
61
- /**
62
- * Filter the log messages.
63
- */
64
- LoggingViewerComponent.prototype.filterLogMessages = function () {
65
- var _this = this;
66
- this.logMessagesForDisplay = this.logMessages.filter(function (message) {
67
- return _this.filterLogMessagesByLevel(message) && _this.filterLogMessagesBySearch(message);
68
- });
69
- };
70
- /**
71
- * Check if the log message's level fulfills the level condition.
72
- *
73
- * @param message the log message to check
74
- * @returns true if check was successful
75
- */
76
- LoggingViewerComponent.prototype.filterLogMessagesByLevel = function (message) {
77
- var levelValue = this.loggingViewerFilterService.level;
78
- return LogLevelConverter.levelFromString(message.level) >= LogLevelConverter.levelFromString(levelValue);
79
- };
80
- /**
81
- * Check if the log message fulfills the search condition.
82
- *
83
- * The search value gets searched in:
84
- * - logger name
85
- * - method name
86
- * - message
87
- *
88
- * @param message the log message to check
89
- * @returns true if check was successful
90
- */
91
- LoggingViewerComponent.prototype.filterLogMessagesBySearch = function (message) {
92
- var searchValue = new RegExp(this.loggingViewerFilterService.search, "i");
93
- return message.logger.search(searchValue) >= 0 ||
94
- message.methodName.search(searchValue) >= 0 ||
95
- message.message.join("|").search(searchValue) >= 0;
96
- };
97
- /**
98
- * Load the current log messages.
99
- * For unit test purposes mainly.
100
- */
101
- LoggingViewerComponent.prototype.loadLogMessages = function () {
102
- var e_1, _a;
103
- if (this.localStorageKeys) {
104
- this.logMessages = [];
105
- try {
106
- for (var _b = __values(this.localStorageKeys.split(",")), _c = _b.next(); !_c.done; _c = _b.next()) {
107
- var localStorageKey = _c.value;
108
- this.logMessages = this.logMessages.concat(this.loggingService.getLogMessagesFromLocalStorage(localStorageKey));
109
- }
110
- }
111
- catch (e_1_1) { e_1 = { error: e_1_1 }; }
112
- finally {
113
- try {
114
- if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
115
- }
116
- finally { if (e_1) throw e_1.error; }
117
- }
118
- this.logMessages = this.logMessages.sort(function (a, b) { return a.timeStamp.getTime() - b.timeStamp.getTime(); });
119
- }
120
- else {
121
- this.logMessages = this.loggingService.getLogMessages();
122
- }
123
- };
124
- LoggingViewerComponent.ctorParameters = function () { return [
125
- { type: LoggingService },
126
- { type: LoggingViewerFilterService }
127
- ]; };
128
- __decorate([
129
- Input(),
130
- __metadata("design:type", String)
131
- ], LoggingViewerComponent.prototype, "localStorageKeys", void 0);
132
- LoggingViewerComponent = __decorate([
133
- Component({
134
- selector: "ionic-logging-viewer",
135
- template: "<ion-list>\n\t<ion-item *ngFor=\"let logMessage of logMessagesForDisplay\">\n\t\t<ion-label>\n\t\t\t<p>{{ logMessage.timeStamp | date:'dd.MM.yyyy HH:mm:ss' }} {{ logMessage.level }}</p>\n\t\t\t<p>{{ logMessage.logger }}</p>\n\t\t\t<p>\n\t\t\t\t{{ logMessage.methodName }}\n\t\t\t\t<span *ngFor=\"let messagePart of logMessage.message\"> {{ messagePart }} </span>\n\t\t\t</p>\n\t\t</ion-label>\n\t</ion-item>\n</ion-list>",
136
- styles: [""]
137
- }),
138
- __metadata("design:paramtypes", [LoggingService,
139
- LoggingViewerFilterService])
140
- ], LoggingViewerComponent);
141
- return LoggingViewerComponent;
142
- }());
143
- export { LoggingViewerComponent };
144
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logging-viewer.component.js","sourceRoot":"ng://ionic-logging-viewer/","sources":["lib/logging-viewer/logging-viewer.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, OnInit, Input } from \"@angular/core\";\nimport { Subscription } from \"rxjs\";\n\nimport { Logger, LoggingService, LogLevelConverter, LogMessage } from \"ionic-logging-service\";\n\nimport { LoggingViewerFilterService } from \"../logging-viewer-filter.service\";\n\n/**\n * Component for displaying the current logs.\n *\n * The component can be embedded in any web page using:\n *\n * &lt;ionic-logging-viewer>&lt;/ionic-logging-viewer>\n */\n@Component({\n\tselector: \"ionic-logging-viewer\",\n\ttemplateUrl: \"./logging-viewer.component.html\",\n\tstyleUrls: [\"./logging-viewer.component.scss\"]\n})\nexport class LoggingViewerComponent implements OnInit, OnDestroy {\n\n\t/**\n\t * Comma-separated list of localStorageKeys. If set, the logs get loaded from localStorage instead of memory.\n\t */\n\t@Input()\n\tpublic localStorageKeys: string;\n\n\t/**\n\t * Log messages which fulfill the filter condition.\n\t */\n\tpublic logMessagesForDisplay: LogMessage[];\n\n\tprivate logger: Logger;\n\tprivate logMessages: LogMessage[];\n\tprivate logMessagesChangedSubscription: Subscription;\n\tprivate filterChangedSubscription: Subscription;\n\n\t/**\n\t * Creates a new instance of the component.\n\t */\n\tconstructor(\n\t\tprivate loggingService: LoggingService,\n\t\tprivate loggingViewerFilterService: LoggingViewerFilterService) {\n\n\t\tthis.logger = loggingService.getLogger(\"Ionic.Logging.Viewer.Component\");\n\t\tconst methodName = \"ctor\";\n\t\tthis.logger.entry(methodName);\n\n\t\tthis.logger.exit(methodName);\n\t}\n\n\t/**\n\t * Initialize the component.\n\t *\n\t * This is done by reading the filter data from [LoggingViewerFilterService](LoggingViewerFilterService.html)\n\t * and the log messages from [LoggingService](../../../ionic-logging-service/typedoc/index.html).\n\t * If the localStorageKeys property is set, the messages are read from local storage.\n\t */\n\tpublic ngOnInit(): void {\n\t\tconst methodName = \"ngOnInit\";\n\t\tthis.logger.entry(methodName);\n\n\t\tthis.loadLogMessages();\n\t\tthis.filterLogMessages();\n\n\t\t// subscribe to loggingService.logMessagesChanged event, to refresh, when new message is logged\n\t\tthis.logMessagesChangedSubscription = this.loggingService.logMessagesChanged.subscribe(async () => {\n\t\t\tthis.loadLogMessages();\n\t\t\tthis.filterLogMessages();\n\t\t});\n\n\t\t// subscribe to loggingViewerFilterService.filterChanged event, to refresh, when filter is modified\n\t\tthis.filterChangedSubscription = this.loggingViewerFilterService.filterChanged.subscribe(() => {\n\t\t\tthis.filterLogMessages();\n\t\t});\n\n\t\tthis.logger.exit(methodName);\n\t}\n\n\t/**\n\t * Clean up.\n\t */\n\tpublic ngOnDestroy(): void {\n\t\tconst methodName = \"ngOnDestroy\";\n\t\tthis.logger.entry(methodName);\n\n\t\tthis.logMessagesChangedSubscription.unsubscribe();\n\t\tthis.filterChangedSubscription.unsubscribe();\n\n\t\tthis.logger.exit(methodName);\n\t}\n\n\t/**\n\t * Filter the log messages.\n\t */\n\tpublic filterLogMessages(): void {\n\t\tthis.logMessagesForDisplay = this.logMessages.filter((message) => {\n\t\t\treturn this.filterLogMessagesByLevel(message) && this.filterLogMessagesBySearch(message);\n\t\t});\n\t}\n\n\t/**\n\t * Check if the log message's level fulfills the level condition.\n\t *\n\t * @param message the log message to check\n\t * @returns true if check was successful\n\t */\n\tpublic filterLogMessagesByLevel(message: LogMessage): boolean {\n\t\tconst levelValue = this.loggingViewerFilterService.level;\n\t\treturn LogLevelConverter.levelFromString(message.level) >= LogLevelConverter.levelFromString(levelValue);\n\t}\n\n\t/**\n\t * Check if the log message fulfills the search condition.\n\t *\n\t * The search value gets searched in:\n\t * - logger name\n\t * - method name\n\t * - message\n\t *\n\t * @param message the log message to check\n\t * @returns true if check was successful\n\t */\n\tpublic filterLogMessagesBySearch(message: LogMessage): boolean {\n\t\tconst searchValue = new RegExp(this.loggingViewerFilterService.search, \"i\");\n\t\treturn message.logger.search(searchValue) >= 0 ||\n\t\t\tmessage.methodName.search(searchValue) >= 0 ||\n\t\t\tmessage.message.join(\"|\").search(searchValue) >= 0;\n\t}\n\n\t/**\n\t * Load the current log messages.\n\t * For unit test purposes mainly.\n\t */\n\tpublic loadLogMessages(): void {\n\t\tif (this.localStorageKeys) {\n\t\t\tthis.logMessages = [];\n\t\t\tfor (const localStorageKey of this.localStorageKeys.split(\",\")) {\n\t\t\t\tthis.logMessages = this.logMessages.concat(this.loggingService.getLogMessagesFromLocalStorage(localStorageKey));\n\t\t\t}\n\t\t\tthis.logMessages = this.logMessages.sort((a, b) => a.timeStamp.getTime() - b.timeStamp.getTime());\n\t\t} else {\n\t\t\tthis.logMessages = this.loggingService.getLogMessages();\n\t\t}\n\t}\n}\n"]}
@@ -1,69 +0,0 @@
1
- import { __decorate, __metadata } from "tslib";
2
- import { EventEmitter, Injectable } from "@angular/core";
3
- import { Logger, LoggingService } from "ionic-logging-service";
4
- /**
5
- * Service for storing filter settings for logging viewer.
6
- */
7
- var LoggingViewerFilterService = /** @class */ (function () {
8
- /**
9
- * Creates a new instance of the service.
10
- * @param loggingService needed for internal logging.
11
- */
12
- function LoggingViewerFilterService(loggingService) {
13
- this.logger = loggingService.getLogger("Ionic.Logging.Viewer.Filter.Service");
14
- var methodName = "ctor";
15
- this.logger.entry(methodName);
16
- this.levelValue = "DEBUG";
17
- this.searchValue = "";
18
- this.filterChanged = new EventEmitter();
19
- this.logger.exit(methodName);
20
- }
21
- Object.defineProperty(LoggingViewerFilterService.prototype, "level", {
22
- /**
23
- * Gets the current log level.
24
- * @return log level
25
- */
26
- get: function () {
27
- return this.levelValue;
28
- },
29
- /**
30
- * Sets the new log level and emits a filterChanged event.
31
- * @param value new slog level
32
- */
33
- set: function (value) {
34
- this.levelValue = value;
35
- this.filterChanged.emit();
36
- },
37
- enumerable: true,
38
- configurable: true
39
- });
40
- Object.defineProperty(LoggingViewerFilterService.prototype, "search", {
41
- /**
42
- * Gets the current search value.
43
- * @return search value
44
- */
45
- get: function () {
46
- return this.searchValue;
47
- },
48
- /**
49
- * Sets the new search value and emits a filterChanged event.
50
- * @param value new search value
51
- */
52
- set: function (value) {
53
- this.searchValue = value;
54
- this.filterChanged.emit();
55
- },
56
- enumerable: true,
57
- configurable: true
58
- });
59
- LoggingViewerFilterService.ctorParameters = function () { return [
60
- { type: LoggingService }
61
- ]; };
62
- LoggingViewerFilterService = __decorate([
63
- Injectable(),
64
- __metadata("design:paramtypes", [LoggingService])
65
- ], LoggingViewerFilterService);
66
- return LoggingViewerFilterService;
67
- }());
68
- export { LoggingViewerFilterService };
69
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2luZy12aWV3ZXItZmlsdGVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9pb25pYy1sb2dnaW5nLXZpZXdlci8iLCJzb3VyY2VzIjpbImxpYi9sb2dnaW5nLXZpZXdlci1maWx0ZXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFekQsT0FBTyxFQUFFLE1BQU0sRUFBRSxjQUFjLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUUvRDs7R0FFRztBQUVIO0lBV0M7OztPQUdHO0lBQ0gsb0NBQ0MsY0FBOEI7UUFFOUIsSUFBSSxDQUFDLE1BQU0sR0FBRyxjQUFjLENBQUMsU0FBUyxDQUFDLHFDQUFxQyxDQUFDLENBQUM7UUFDOUUsSUFBTSxVQUFVLEdBQUcsTUFBTSxDQUFDO1FBQzFCLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBRTlCLElBQUksQ0FBQyxVQUFVLEdBQUcsT0FBTyxDQUFDO1FBQzFCLElBQUksQ0FBQyxXQUFXLEdBQUcsRUFBRSxDQUFDO1FBQ3RCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUU5QyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUM5QixDQUFDO0lBTUQsc0JBQVcsNkNBQUs7UUFKaEI7OztXQUdHO2FBQ0g7WUFDQyxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUM7UUFDeEIsQ0FBQztRQUVEOzs7V0FHRzthQUNILFVBQWlCLEtBQWE7WUFDN0IsSUFBSSxDQUFDLFVBQVUsR0FBRyxLQUFLLENBQUM7WUFDeEIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUMzQixDQUFDOzs7T0FUQTtJQWVELHNCQUFXLDhDQUFNO1FBSmpCOzs7V0FHRzthQUNIO1lBQ0MsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDO1FBQ3pCLENBQUM7UUFFRDs7O1dBR0c7YUFDSCxVQUFrQixLQUFhO1lBQzlCLElBQUksQ0FBQyxXQUFXLEdBQUcsS0FBSyxDQUFDO1lBQ3pCLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDM0IsQ0FBQzs7O09BVEE7O2dCQXBDZ0IsY0FBYzs7SUFoQm5CLDBCQUEwQjtRQUR0QyxVQUFVLEVBQUU7eUNBaUJLLGNBQWM7T0FoQm5CLDBCQUEwQixDQThEdEM7SUFBRCxpQ0FBQztDQUFBLEFBOURELElBOERDO1NBOURZLDBCQUEwQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEV2ZW50RW1pdHRlciwgSW5qZWN0YWJsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5cbmltcG9ydCB7IExvZ2dlciwgTG9nZ2luZ1NlcnZpY2UgfSBmcm9tIFwiaW9uaWMtbG9nZ2luZy1zZXJ2aWNlXCI7XG5cbi8qKlxuICogU2VydmljZSBmb3Igc3RvcmluZyBmaWx0ZXIgc2V0dGluZ3MgZm9yIGxvZ2dpbmcgdmlld2VyLlxuICovXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgTG9nZ2luZ1ZpZXdlckZpbHRlclNlcnZpY2Uge1xuXG5cdC8qKlxuXHQgKiBFdmVudCB0cmlnZ2VyZWQgd2hlbiB0aGUgZmlsdGVyIHdhcyBjaGFuZ2VkLlxuXHQgKi9cblx0cHVibGljIGZpbHRlckNoYW5nZWQ6IEV2ZW50RW1pdHRlcjx2b2lkPjtcblxuXHRwcml2YXRlIGxvZ2dlcjogTG9nZ2VyO1xuXHRwcml2YXRlIGxldmVsVmFsdWU6IHN0cmluZztcblx0cHJpdmF0ZSBzZWFyY2hWYWx1ZTogc3RyaW5nO1xuXG5cdC8qKlxuXHQgKiBDcmVhdGVzIGEgbmV3IGluc3RhbmNlIG9mIHRoZSBzZXJ2aWNlLlxuXHQgKiBAcGFyYW0gbG9nZ2luZ1NlcnZpY2UgbmVlZGVkIGZvciBpbnRlcm5hbCBsb2dnaW5nLlxuXHQgKi9cblx0Y29uc3RydWN0b3IoXG5cdFx0bG9nZ2luZ1NlcnZpY2U6IExvZ2dpbmdTZXJ2aWNlKSB7XG5cblx0XHR0aGlzLmxvZ2dlciA9IGxvZ2dpbmdTZXJ2aWNlLmdldExvZ2dlcihcIklvbmljLkxvZ2dpbmcuVmlld2VyLkZpbHRlci5TZXJ2aWNlXCIpO1xuXHRcdGNvbnN0IG1ldGhvZE5hbWUgPSBcImN0b3JcIjtcblx0XHR0aGlzLmxvZ2dlci5lbnRyeShtZXRob2ROYW1lKTtcblxuXHRcdHRoaXMubGV2ZWxWYWx1ZSA9IFwiREVCVUdcIjtcblx0XHR0aGlzLnNlYXJjaFZhbHVlID0gXCJcIjtcblx0XHR0aGlzLmZpbHRlckNoYW5nZWQgPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XG5cblx0XHR0aGlzLmxvZ2dlci5leGl0KG1ldGhvZE5hbWUpO1xuXHR9XG5cblx0LyoqXG5cdCAqIEdldHMgdGhlIGN1cnJlbnQgbG9nIGxldmVsLlxuXHQgKiBAcmV0dXJuIGxvZyBsZXZlbFxuXHQgKi9cblx0cHVibGljIGdldCBsZXZlbCgpOiBzdHJpbmcge1xuXHRcdHJldHVybiB0aGlzLmxldmVsVmFsdWU7XG5cdH1cblxuXHQvKipcblx0ICogU2V0cyB0aGUgbmV3IGxvZyBsZXZlbCBhbmQgZW1pdHMgYSBmaWx0ZXJDaGFuZ2VkIGV2ZW50LlxuXHQgKiBAcGFyYW0gdmFsdWUgbmV3IHNsb2cgbGV2ZWxcblx0ICovXG5cdHB1YmxpYyBzZXQgbGV2ZWwodmFsdWU6IHN0cmluZykge1xuXHRcdHRoaXMubGV2ZWxWYWx1ZSA9IHZhbHVlO1xuXHRcdHRoaXMuZmlsdGVyQ2hhbmdlZC5lbWl0KCk7XG5cdH1cblxuXHQvKipcblx0ICogR2V0cyB0aGUgY3VycmVudCBzZWFyY2ggdmFsdWUuXG5cdCAqIEByZXR1cm4gc2VhcmNoIHZhbHVlXG5cdCAqL1xuXHRwdWJsaWMgZ2V0IHNlYXJjaCgpOiBzdHJpbmcge1xuXHRcdHJldHVybiB0aGlzLnNlYXJjaFZhbHVlO1xuXHR9XG5cblx0LyoqXG5cdCAqIFNldHMgdGhlIG5ldyBzZWFyY2ggdmFsdWUgYW5kIGVtaXRzIGEgZmlsdGVyQ2hhbmdlZCBldmVudC5cblx0ICogQHBhcmFtIHZhbHVlIG5ldyBzZWFyY2ggdmFsdWVcblx0ICovXG5cdHB1YmxpYyBzZXQgc2VhcmNoKHZhbHVlOiBzdHJpbmcpIHtcblx0XHR0aGlzLnNlYXJjaFZhbHVlID0gdmFsdWU7XG5cdFx0dGhpcy5maWx0ZXJDaGFuZ2VkLmVtaXQoKTtcblx0fVxufVxuIl19