jupyterlab-pioneer 0.1.2 → 0.1.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -1,4 +1,4 @@
1
- # JupyterLab Pioneer
1
+ # JupyterLab Pioneer
2
2
 
3
3
  [![PyPI](https://img.shields.io/pypi/v/jupyterlab-pioneer.svg)](https://pypi.org/project/jupyterlab-pioneer)
4
4
  [![npm](https://img.shields.io/npm/v/jupyterlab-pioneer.svg)](https://www.npmjs.com/package/jupyterlab-pioneer)
@@ -8,12 +8,16 @@ A JupyterLab extension for generating and exporting JupyterLab event telemetry d
8
8
  ## Get started
9
9
 
10
10
  ### Run the extension with docker compose
11
+
11
12
  ```bash
12
13
  # enter the configuration_examples directory and run
13
14
  docker compose -p jupyterlab-pioneer up --build
14
15
  ```
15
- A JupyterLab application with the extension installed and configured will run on localhost:8888.
16
-
16
+
17
+ A JupyterLab application with the extension installed and configured will run on localhost:8888.
18
+
19
+ (To play with different exporter configurations, edit [Dockerfile](https://github.com/educational-technology-collective/jupyterlab-pioneer/blob/main/configuration_examples/Dockerfile#L32-L36) and run docker compose again)
20
+
17
21
  ### Or install the extension and configure it manually
18
22
 
19
23
  To install the extension, execute:
@@ -21,15 +25,27 @@ To install the extension, execute:
21
25
  ```bash
22
26
  pip install jupyterlab-pioneer
23
27
  ```
28
+
24
29
  Before starting Jupyter Lab, users need to write their own configuration files (or use the provided configuration examples) and **place them in the correct directory**.
25
30
 
26
31
  Examples of configurations are [here](#configurations).
27
32
 
28
33
  ## Configurations
34
+
29
35
  ### Overview
36
+
30
37
  The configuration file controls the activated events and data exporters.
31
38
 
32
- To add a data exporter, users should assign a callable function along with function arguments when configuring `exporters`. This extension provides 4 [default exporters](https://github.com/educational-technology-collective/jupyterlab-pioneer/blob/b7eda5f4b286c7b0f7aa50df716b2795f180cc6e/jupyterlab_pioneer/handlers.py#L9), `command_line_exporter`, `console_exporter`, `file_exporter` and `remote_exporter`. Users can import default exporters or write customized exporters in the configuration file.
39
+ To add a data exporter, users should assign a callable function along with function arguments when configuring `exporters`.
40
+
41
+ This extension provides 4 default exporters.
42
+
43
+ - [`console_exporter`](https://github.com/educational-technology-collective/jupyterlab-pioneer/blob/main/jupyterlab_pioneer/handlers.py#L10), which sends telemetry data to the browser console
44
+ - [`command_line_exporter`](https://github.com/educational-technology-collective/jupyterlab-pioneer/blob/main/jupyterlab_pioneer/handlers.py#L33), which sends telemetry data to the python console jupyter is running on
45
+ - [`file_exporter`](https://github.com/educational-technology-collective/jupyterlab-pioneer/blob/main/jupyterlab_pioneer/handlers.py#L55), which saves telemetry data to local file
46
+ - [`remote_exporter`](https://github.com/educational-technology-collective/jupyterlab-pioneer/blob/main/jupyterlab_pioneer/handlers.py#L81), which sends telemetry data to a remote http endpoint
47
+
48
+ Additionally, users can import default exporters or write customized exporters in the configuration file.
33
49
 
34
50
  ### Configuration file name & path
35
51
 
@@ -38,6 +54,7 @@ Jupyter Server expects the configuration file to be named after the extension’
38
54
  Jupyter Server looks for an extension’s config file in a set of specific paths. **The configuration file should be saved into one of the config directories provided by `jupyter --path`.**
39
55
 
40
56
  Check jupyter server [doc](https://jupyter-server.readthedocs.io/en/latest/operators/configuring-extensions.html) for more details.
57
+
41
58
  ### Syntax
42
59
 
43
60
  `activateEvents`: An array of the ids of the events. Only valid events (1. has an id associated with the event class, and 2. the event id is included in `activatedEvents`) will be activated.
@@ -45,16 +62,23 @@ Check jupyter server [doc](https://jupyter-server.readthedocs.io/en/latest/opera
45
62
  `logNotebookContentEvents`: An array of the ids of the events. The extension will export the entire notebook content only for valid events (1. has an id associated with the event class, and 2. the event id is included in `logNotebookContentEvents`).
46
63
 
47
64
  `exporters`: An array of exporters. Each exporter should have the following structure:
65
+
48
66
  ```python
49
67
  {
50
68
  exporter: # a callable exporter function. Need to contain 'path' for file_exporter, 'url' for remote_exporter.
51
69
  args: # arguments passed to the exporter function
52
70
  }
53
71
  ```
54
- **The configuration file should be saved into one of the config directories provided by `jupyter --path`.**
55
72
 
56
73
  ### Example
57
- [jupyter_jupyterlab_pioneer_config.py](https://github.com/educational-technology-collective/jupyterlab-pioneer/blob/main/configuration_examples/jupyter_jupyterlab_pioneer_config.py)
74
+
75
+ #### Default exporters
76
+
77
+ [all_exporters/jupyter_jupyterlab_pioneer_config.py](https://github.com/educational-technology-collective/jupyterlab-pioneer/blob/main/configuration_examples/all_exporters/jupyter_jupyterlab_pioneer_config.py)
78
+
79
+ #### Custom exporter function
80
+
81
+ [custom_exporter/jupyter_jupyterlab_pioneer_config.py](https://github.com/educational-technology-collective/jupyterlab-pioneer/blob/main/configuration_examples/custom_exporter/jupyter_jupyterlab_pioneer_config.py)
58
82
 
59
83
  ## Uninstall
60
84
 
package/lib/index.d.ts CHANGED
@@ -1,3 +1,13 @@
1
1
  import { JupyterFrontEndPlugin } from '@jupyterlab/application';
2
- declare const plugin: JupyterFrontEndPlugin<void>;
2
+ import { Token } from '@lumino/coreutils';
3
+ import { Router } from './router';
4
+ export declare const IJupyterLabPioneer: Token<IJupyterLabPioneer>;
5
+ export interface IJupyterLabPioneer {
6
+ router: Router;
7
+ }
8
+ declare class JupyterLabPioneer implements IJupyterLabPioneer {
9
+ router: Router;
10
+ constructor();
11
+ }
12
+ declare const plugin: JupyterFrontEndPlugin<JupyterLabPioneer>;
3
13
  export default plugin;
package/lib/index.js CHANGED
@@ -1,26 +1,35 @@
1
1
  import { INotebookTracker } from '@jupyterlab/notebook';
2
- import { TelemetryRouter } from './router';
2
+ import { Token } from '@lumino/coreutils';
3
3
  import { requestAPI } from './handler';
4
- import { producerCollection } from './events';
4
+ import { Router } from './router';
5
+ import { producerCollection } from './producer';
5
6
  const PLUGIN_ID = 'jupyterlab-pioneer:plugin';
7
+ export const IJupyterLabPioneer = new Token(PLUGIN_ID);
8
+ class JupyterLabPioneer {
9
+ constructor() {
10
+ this.router = new Router();
11
+ }
12
+ }
6
13
  const plugin = {
7
14
  id: PLUGIN_ID,
8
15
  autoStart: true,
9
16
  requires: [INotebookTracker],
17
+ provides: IJupyterLabPioneer,
10
18
  activate: async (app, notebookTracker) => {
11
19
  const version = await requestAPI('version');
12
20
  console.log(`${PLUGIN_ID}: ${version}`);
13
21
  const config = await requestAPI('config');
14
- const telemetryRouter = new TelemetryRouter();
22
+ const pioneer = new JupyterLabPioneer();
15
23
  notebookTracker.widgetAdded.connect(async (_, notebookPanel) => {
16
24
  await notebookPanel.sessionContext.ready; // wait until session id is created
17
- await telemetryRouter.loadNotebookPanel(notebookPanel);
25
+ await pioneer.router.loadNotebookPanel(notebookPanel);
18
26
  producerCollection.forEach(producer => {
19
27
  if (config.activeEvents.includes(producer.id)) {
20
- new producer().listen(notebookPanel, telemetryRouter, config.logNotebookContentEvents.includes(producer.id));
28
+ new producer().listen(notebookPanel, pioneer, config.logNotebookContentEvents.includes(producer.id));
21
29
  }
22
30
  });
23
31
  });
32
+ return pioneer;
24
33
  }
25
34
  };
26
35
  export default plugin;
@@ -0,0 +1,53 @@
1
+ import { NotebookPanel } from '@jupyterlab/notebook';
2
+ import { IJupyterLabPioneer } from './index';
3
+ export declare class NotebookOpenEventProducer {
4
+ static id: string;
5
+ private produced;
6
+ listen(_: NotebookPanel, pioneer: IJupyterLabPioneer, logNotebookContentEvent: boolean): Promise<void>;
7
+ }
8
+ export declare class NotebookScrollProducer {
9
+ static id: string;
10
+ private timeout;
11
+ listen(notebookPanel: NotebookPanel, pioneer: IJupyterLabPioneer, logNotebookContentEvent: boolean): void;
12
+ }
13
+ export declare class NotebookVisibleEventProducer {
14
+ static id: string;
15
+ listen(notebookPanel: NotebookPanel, pioneer: IJupyterLabPioneer, logNotebookContentEvent: boolean): void;
16
+ }
17
+ export declare class NotebookHiddenEventProducer {
18
+ static id: string;
19
+ listen(_: NotebookPanel, pioneer: IJupyterLabPioneer, logNotebookContentEvent: boolean): void;
20
+ }
21
+ export declare class ClipboardCopyEventProducer {
22
+ static id: string;
23
+ listen(notebookPanel: NotebookPanel, pioneer: IJupyterLabPioneer, logNotebookContentEvent: boolean): void;
24
+ }
25
+ export declare class ClipboardCutEventProducer {
26
+ static id: string;
27
+ listen(notebookPanel: NotebookPanel, pioneer: IJupyterLabPioneer, logNotebookContentEvent: boolean): void;
28
+ }
29
+ export declare class ClipboardPasteEventProducer {
30
+ static id: string;
31
+ listen(notebookPanel: NotebookPanel, pioneer: IJupyterLabPioneer, logNotebookContentEvent: boolean): void;
32
+ }
33
+ export declare class ActiveCellChangeEventProducer {
34
+ static id: string;
35
+ listen(notebookPanel: NotebookPanel, pioneer: IJupyterLabPioneer, logNotebookContentEvent: boolean): void;
36
+ }
37
+ export declare class NotebookSaveEventProducer {
38
+ static id: string;
39
+ listen(notebookPanel: NotebookPanel, pioneer: IJupyterLabPioneer, logNotebookContentEvent: boolean): void;
40
+ }
41
+ export declare class CellExecuteEventProducer {
42
+ static id: string;
43
+ listen(_: any, pioneer: IJupyterLabPioneer, logNotebookContentEvent: boolean): void;
44
+ }
45
+ export declare class CellAddEventProducer {
46
+ static id: string;
47
+ listen(notebookPanel: NotebookPanel, pioneer: IJupyterLabPioneer, logNotebookContentEvent: boolean): void;
48
+ }
49
+ export declare class CellRemoveEventProducer {
50
+ static id: string;
51
+ listen(notebookPanel: NotebookPanel, pioneer: IJupyterLabPioneer, logNotebookContentEvent: boolean): void;
52
+ }
53
+ export declare const producerCollection: (typeof NotebookVisibleEventProducer)[];
@@ -4,7 +4,7 @@ class NotebookOpenEventProducer {
4
4
  constructor() {
5
5
  this.produced = false;
6
6
  }
7
- async listen(_, router, logNotebookContentEvent) {
7
+ async listen(_, pioneer, logNotebookContentEvent) {
8
8
  if (!this.produced) {
9
9
  const event = {
10
10
  eventName: NotebookOpenEventProducer.id,
@@ -13,7 +13,7 @@ class NotebookOpenEventProducer {
13
13
  environ: await requestAPI('environ')
14
14
  }
15
15
  };
16
- await router.publishEvent(event, logNotebookContentEvent);
16
+ await pioneer.router.publishEvent(event, logNotebookContentEvent);
17
17
  this.produced = true;
18
18
  }
19
19
  }
@@ -42,7 +42,7 @@ class NotebookScrollProducer {
42
42
  constructor() {
43
43
  this.timeout = 0;
44
44
  }
45
- listen(notebookPanel, router, logNotebookContentEvent) {
45
+ listen(notebookPanel, pioneer, logNotebookContentEvent) {
46
46
  notebookPanel.content.node.addEventListener('scroll', async (e) => {
47
47
  e.stopPropagation();
48
48
  clearTimeout(this.timeout);
@@ -54,14 +54,14 @@ class NotebookScrollProducer {
54
54
  cells: getVisibleCells(notebookPanel)
55
55
  }
56
56
  };
57
- await router.publishEvent(event, logNotebookContentEvent);
57
+ await pioneer.router.publishEvent(event, logNotebookContentEvent);
58
58
  });
59
59
  }
60
60
  }
61
61
  NotebookScrollProducer.id = 'NotebookScrollEvent';
62
62
  export { NotebookScrollProducer };
63
63
  class NotebookVisibleEventProducer {
64
- listen(notebookPanel, router, logNotebookContentEvent) {
64
+ listen(notebookPanel, pioneer, logNotebookContentEvent) {
65
65
  document.addEventListener('visibilitychange', async () => {
66
66
  if (document.visibilityState === 'visible') {
67
67
  const event = {
@@ -71,7 +71,7 @@ class NotebookVisibleEventProducer {
71
71
  cells: getVisibleCells(notebookPanel)
72
72
  }
73
73
  };
74
- await router.publishEvent(event, logNotebookContentEvent);
74
+ await pioneer.router.publishEvent(event, logNotebookContentEvent);
75
75
  }
76
76
  });
77
77
  }
@@ -79,14 +79,14 @@ class NotebookVisibleEventProducer {
79
79
  NotebookVisibleEventProducer.id = 'NotebookVisibleEvent';
80
80
  export { NotebookVisibleEventProducer };
81
81
  class NotebookHiddenEventProducer {
82
- listen(_, router, logNotebookContentEvent) {
82
+ listen(_, pioneer, logNotebookContentEvent) {
83
83
  document.addEventListener('visibilitychange', async (e) => {
84
84
  if (document.visibilityState === 'hidden') {
85
85
  const event = {
86
86
  eventName: NotebookHiddenEventProducer.id,
87
87
  eventTime: Date.now()
88
88
  };
89
- await router.publishEvent(event, logNotebookContentEvent);
89
+ await pioneer.router.publishEvent(event, logNotebookContentEvent);
90
90
  }
91
91
  });
92
92
  }
@@ -94,7 +94,7 @@ class NotebookHiddenEventProducer {
94
94
  NotebookHiddenEventProducer.id = 'NotebookHiddenEvent';
95
95
  export { NotebookHiddenEventProducer };
96
96
  class ClipboardCopyEventProducer {
97
- listen(notebookPanel, router, logNotebookContentEvent) {
97
+ listen(notebookPanel, pioneer, logNotebookContentEvent) {
98
98
  notebookPanel.node.addEventListener('copy', async () => {
99
99
  var _a, _b;
100
100
  const cell = {
@@ -110,14 +110,14 @@ class ClipboardCopyEventProducer {
110
110
  selection: text
111
111
  }
112
112
  };
113
- await router.publishEvent(event, logNotebookContentEvent);
113
+ await pioneer.router.publishEvent(event, logNotebookContentEvent);
114
114
  });
115
115
  }
116
116
  }
117
117
  ClipboardCopyEventProducer.id = 'ClipboardCopyEvent';
118
118
  export { ClipboardCopyEventProducer };
119
119
  class ClipboardCutEventProducer {
120
- listen(notebookPanel, router, logNotebookContentEvent) {
120
+ listen(notebookPanel, pioneer, logNotebookContentEvent) {
121
121
  notebookPanel.node.addEventListener('cut', async () => {
122
122
  var _a, _b;
123
123
  const cell = {
@@ -133,14 +133,14 @@ class ClipboardCutEventProducer {
133
133
  selection: text
134
134
  }
135
135
  };
136
- await router.publishEvent(event, logNotebookContentEvent);
136
+ await pioneer.router.publishEvent(event, logNotebookContentEvent);
137
137
  });
138
138
  }
139
139
  }
140
140
  ClipboardCutEventProducer.id = 'ClipboardCutEvent';
141
141
  export { ClipboardCutEventProducer };
142
142
  class ClipboardPasteEventProducer {
143
- listen(notebookPanel, router, logNotebookContentEvent) {
143
+ listen(notebookPanel, pioneer, logNotebookContentEvent) {
144
144
  notebookPanel.node.addEventListener('paste', async (e) => {
145
145
  var _a;
146
146
  const cell = {
@@ -156,14 +156,14 @@ class ClipboardPasteEventProducer {
156
156
  selection: text
157
157
  }
158
158
  };
159
- await router.publishEvent(event, logNotebookContentEvent);
159
+ await pioneer.router.publishEvent(event, logNotebookContentEvent);
160
160
  });
161
161
  }
162
162
  }
163
163
  ClipboardPasteEventProducer.id = 'ClipboardPasteEvent';
164
164
  export { ClipboardPasteEventProducer };
165
165
  class ActiveCellChangeEventProducer {
166
- listen(notebookPanel, router, logNotebookContentEvent) {
166
+ listen(notebookPanel, pioneer, logNotebookContentEvent) {
167
167
  notebookPanel.content.activeCellChanged.connect(async (_, cell) => {
168
168
  if (cell && notebookPanel.content.widgets) {
169
169
  const activatedCell = {
@@ -177,7 +177,7 @@ class ActiveCellChangeEventProducer {
177
177
  cells: [activatedCell] // activated cell
178
178
  }
179
179
  };
180
- await router.publishEvent(event, logNotebookContentEvent);
180
+ await pioneer.router.publishEvent(event, logNotebookContentEvent);
181
181
  }
182
182
  });
183
183
  }
@@ -185,14 +185,14 @@ class ActiveCellChangeEventProducer {
185
185
  ActiveCellChangeEventProducer.id = 'ActiveCellChangeEvent';
186
186
  export { ActiveCellChangeEventProducer };
187
187
  class NotebookSaveEventProducer {
188
- listen(notebookPanel, router, logNotebookContentEvent) {
188
+ listen(notebookPanel, pioneer, logNotebookContentEvent) {
189
189
  notebookPanel.context.saveState.connect(async (_, saveState) => {
190
190
  if (saveState.match('completed')) {
191
191
  const event = {
192
192
  eventName: NotebookSaveEventProducer.id,
193
193
  eventTime: Date.now()
194
194
  };
195
- await router.publishEvent(event, logNotebookContentEvent);
195
+ await pioneer.router.publishEvent(event, logNotebookContentEvent);
196
196
  }
197
197
  });
198
198
  }
@@ -200,7 +200,7 @@ class NotebookSaveEventProducer {
200
200
  NotebookSaveEventProducer.id = 'NotebookSaveEvent';
201
201
  export { NotebookSaveEventProducer };
202
202
  class CellExecuteEventProducer {
203
- listen(_, router, logNotebookContentEvent) {
203
+ listen(_, pioneer, logNotebookContentEvent) {
204
204
  NotebookActions.executed.connect(async (_, args) => {
205
205
  const executedCell = {
206
206
  id: args.cell.model.id,
@@ -215,14 +215,14 @@ class CellExecuteEventProducer {
215
215
  kernelError: args.success ? null : args.error
216
216
  }
217
217
  };
218
- await router.publishEvent(event, logNotebookContentEvent);
218
+ await pioneer.router.publishEvent(event, logNotebookContentEvent);
219
219
  });
220
220
  }
221
221
  }
222
222
  CellExecuteEventProducer.id = 'CellExecuteEvent';
223
223
  export { CellExecuteEventProducer };
224
224
  class CellAddEventProducer {
225
- listen(notebookPanel, router, logNotebookContentEvent) {
225
+ listen(notebookPanel, pioneer, logNotebookContentEvent) {
226
226
  var _a;
227
227
  (_a = notebookPanel.content.model) === null || _a === void 0 ? void 0 : _a.cells.changed.connect(async (_, args) => {
228
228
  if (args.type === 'add') {
@@ -237,7 +237,7 @@ class CellAddEventProducer {
237
237
  cells: [addedCell]
238
238
  }
239
239
  };
240
- await router.publishEvent(event, logNotebookContentEvent);
240
+ await pioneer.router.publishEvent(event, logNotebookContentEvent);
241
241
  }
242
242
  });
243
243
  }
@@ -245,7 +245,7 @@ class CellAddEventProducer {
245
245
  CellAddEventProducer.id = 'CellAddEvent';
246
246
  export { CellAddEventProducer };
247
247
  class CellRemoveEventProducer {
248
- listen(notebookPanel, router, logNotebookContentEvent) {
248
+ listen(notebookPanel, pioneer, logNotebookContentEvent) {
249
249
  var _a;
250
250
  (_a = notebookPanel.content.model) === null || _a === void 0 ? void 0 : _a.cells.changed.connect(async (_, args) => {
251
251
  if (args.type === 'remove') {
@@ -260,7 +260,7 @@ class CellRemoveEventProducer {
260
260
  cells: [removedCell]
261
261
  }
262
262
  };
263
- await router.publishEvent(event, logNotebookContentEvent);
263
+ await pioneer.router.publishEvent(event, logNotebookContentEvent);
264
264
  }
265
265
  });
266
266
  }
package/lib/router.d.ts CHANGED
@@ -1,9 +1,5 @@
1
1
  import { NotebookPanel } from '@jupyterlab/notebook';
2
- export interface ITelemetryRouter {
3
- loadNotebookPanel(notebookPanel: NotebookPanel): void;
4
- publishEvent(eventDetail: Object, logNotebookContent?: Boolean): void;
5
- }
6
- export declare class TelemetryRouter implements ITelemetryRouter {
2
+ export declare class Router {
7
3
  private sessionID?;
8
4
  private notebookPanel?;
9
5
  /**
package/lib/router.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import { requestAPI } from './handler';
2
- export class TelemetryRouter {
2
+ export class Router {
3
3
  /**
4
4
  * Load notebookPanel.
5
5
  *
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "jupyterlab-pioneer",
3
- "version": "0.1.2",
3
+ "version": "0.1.4",
4
4
  "description": "A JupyterLab extension.",
5
5
  "keywords": [
6
6
  "jupyter",
package/lib/events.d.ts DELETED
@@ -1,53 +0,0 @@
1
- import { NotebookPanel } from '@jupyterlab/notebook';
2
- import { ITelemetryRouter } from './router';
3
- export declare class NotebookOpenEventProducer {
4
- static id: string;
5
- private produced;
6
- listen(_: NotebookPanel, router: ITelemetryRouter, logNotebookContentEvent: boolean): Promise<void>;
7
- }
8
- export declare class NotebookScrollProducer {
9
- static id: string;
10
- private timeout;
11
- listen(notebookPanel: NotebookPanel, router: ITelemetryRouter, logNotebookContentEvent: boolean): void;
12
- }
13
- export declare class NotebookVisibleEventProducer {
14
- static id: string;
15
- listen(notebookPanel: NotebookPanel, router: ITelemetryRouter, logNotebookContentEvent: boolean): void;
16
- }
17
- export declare class NotebookHiddenEventProducer {
18
- static id: string;
19
- listen(_: NotebookPanel, router: ITelemetryRouter, logNotebookContentEvent: boolean): void;
20
- }
21
- export declare class ClipboardCopyEventProducer {
22
- static id: string;
23
- listen(notebookPanel: NotebookPanel, router: ITelemetryRouter, logNotebookContentEvent: boolean): void;
24
- }
25
- export declare class ClipboardCutEventProducer {
26
- static id: string;
27
- listen(notebookPanel: NotebookPanel, router: ITelemetryRouter, logNotebookContentEvent: boolean): void;
28
- }
29
- export declare class ClipboardPasteEventProducer {
30
- static id: string;
31
- listen(notebookPanel: NotebookPanel, router: ITelemetryRouter, logNotebookContentEvent: boolean): void;
32
- }
33
- export declare class ActiveCellChangeEventProducer {
34
- static id: string;
35
- listen(notebookPanel: NotebookPanel, router: ITelemetryRouter, logNotebookContentEvent: boolean): void;
36
- }
37
- export declare class NotebookSaveEventProducer {
38
- static id: string;
39
- listen(notebookPanel: NotebookPanel, router: ITelemetryRouter, logNotebookContentEvent: boolean): void;
40
- }
41
- export declare class CellExecuteEventProducer {
42
- static id: string;
43
- listen(_: any, router: ITelemetryRouter, logNotebookContentEvent: boolean): void;
44
- }
45
- export declare class CellAddEventProducer {
46
- static id: string;
47
- listen(notebookPanel: NotebookPanel, router: ITelemetryRouter, logNotebookContentEvent: boolean): void;
48
- }
49
- export declare class CellRemoveEventProducer {
50
- static id: string;
51
- listen(notebookPanel: NotebookPanel, router: ITelemetryRouter, logNotebookContentEvent: boolean): void;
52
- }
53
- export declare const producerCollection: (typeof NotebookVisibleEventProducer)[];