jupyterlab-pioneer 0.1.3 → 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
@@ -13,9 +13,10 @@ A JupyterLab extension for generating and exporting JupyterLab event telemetry d
13
13
  # enter the configuration_examples directory and run
14
14
  docker compose -p jupyterlab-pioneer up --build
15
15
  ```
16
+
16
17
  A JupyterLab application with the extension installed and configured will run on localhost:8888.
17
18
 
18
- (To play with different exporter configurations, edit [Dockerfile](https://github.com/educational-technology-collective/jupyterlab-pioneer/blob/main/configuration_examples/Dockerfile#L28-L32) and run docker compose again)
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)
19
20
 
20
21
  ### Or install the extension and configure it manually
21
22
 
@@ -70,13 +71,14 @@ Check jupyter server [doc](https://jupyter-server.readthedocs.io/en/latest/opera
70
71
  ```
71
72
 
72
73
  ### Example
74
+
73
75
  #### Default exporters
74
76
 
75
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)
76
78
 
77
- #### Customized exporter function
79
+ #### Custom exporter function
78
80
 
79
- [custom_exporter/jupyter_jupyterlab_pioneer_config.py](https://github.com/educational-technology-collective/jupyterlab-pioneer/blob/main/configuration_examples/customized_exporter/jupyter_jupyterlab_pioneer_config.py)
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)
80
82
 
81
83
  ## Uninstall
82
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.3",
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)[];