utils.ts 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231
  1. // Copyright (c) Jupyter Development Team.
  2. // Distributed under the terms of the Modified BSD License.
  3. // tslint:disable-next-line
  4. /// <reference path="./typings/json-to-html/json-to-html.d.ts"/>
  5. import json2html = require('json-to-html');
  6. import {
  7. simulate
  8. } from 'simulate-event';
  9. import {
  10. ServiceManager
  11. } from '@jupyterlab/services';
  12. import {
  13. ClientSession
  14. } from '@jupyterlab/apputils';
  15. import {
  16. nbformat, uuid
  17. } from '@jupyterlab/coreutils';
  18. import {
  19. TextModelFactory, DocumentRegistry, Context
  20. } from '@jupyterlab/docregistry';
  21. import {
  22. INotebookModel, NotebookModelFactory
  23. } from '@jupyterlab/notebook';
  24. import {
  25. IRenderMime, RenderMimeRegistry, RenderedHTML, standardRendererFactories
  26. } from '@jupyterlab/rendermime';
  27. /**
  28. * Get a copy of the default rendermime instance.
  29. */
  30. export
  31. function defaultRenderMime(): RenderMimeRegistry {
  32. return Private.rendermime.clone();
  33. }
  34. /**
  35. * Create a client session object.
  36. */
  37. export
  38. function createClientSession(options: Partial<ClientSession.IOptions> = {}): Promise<ClientSession> {
  39. let manager = options.manager || Private.manager.sessions;
  40. return manager.ready.then(() => {
  41. return new ClientSession({
  42. manager,
  43. path: options.path || uuid(),
  44. name: options.name,
  45. type: options.type,
  46. kernelPreference: options.kernelPreference || {
  47. shouldStart: true,
  48. canStart: true,
  49. name: manager.specs.default
  50. }
  51. });
  52. });
  53. }
  54. /**
  55. * Create a context for a file.
  56. */
  57. export
  58. function createFileContext(path?: string, manager?: ServiceManager.IManager): Context<DocumentRegistry.IModel> {
  59. manager = manager || Private.manager;
  60. let factory = Private.textFactory;
  61. path = path || uuid() + '.txt';
  62. return new Context({ manager, factory, path });
  63. }
  64. /**
  65. * Create a context for a notebook.
  66. */
  67. export
  68. function createNotebookContext(path?: string, manager?: ServiceManager.IManager): Promise<Context<INotebookModel>> {
  69. manager = manager || Private.manager;
  70. return manager.ready.then(() => {
  71. let factory = Private.notebookFactory;
  72. path = path || uuid() + '.ipynb';
  73. return new Context({
  74. manager, factory, path, kernelPreference: { name: manager.specs.default }
  75. });
  76. });
  77. }
  78. /**
  79. * Wait for a dialog to be attached to an element.
  80. */
  81. export
  82. function waitForDialog(host: HTMLElement = document.body): Promise<void> {
  83. return new Promise<void>((resolve, reject) => {
  84. let refresh = () => {
  85. let node = host.getElementsByClassName('jp-Dialog')[0];
  86. if (node) {
  87. resolve(void 0);
  88. return;
  89. }
  90. setTimeout(refresh, 10);
  91. };
  92. refresh();
  93. });
  94. }
  95. /**
  96. * Accept a dialog after it is attached by accepting the default button.
  97. */
  98. export
  99. function acceptDialog(host: HTMLElement = document.body): Promise<void> {
  100. return waitForDialog(host).then(() => {
  101. let node = host.getElementsByClassName('jp-Dialog')[0];
  102. if (node) {
  103. simulate(node as HTMLElement, 'keydown', { keyCode: 13 });
  104. }
  105. });
  106. }
  107. /**
  108. * Dismiss a dialog after it is attached.
  109. */
  110. export
  111. function dismissDialog(host: HTMLElement = document.body): Promise<void> {
  112. return waitForDialog(host).then(() => {
  113. let node = host.getElementsByClassName('jp-Dialog')[0];
  114. if (node) {
  115. simulate(node as HTMLElement, 'keydown', { keyCode: 27 });
  116. }
  117. });
  118. }
  119. /**
  120. * A namespace for private data.
  121. */
  122. namespace Private {
  123. export
  124. const manager = new ServiceManager();
  125. export
  126. const textFactory = new TextModelFactory();
  127. export
  128. const notebookFactory = new NotebookModelFactory({});
  129. class JSONRenderer extends RenderedHTML {
  130. mimeType = 'text/html';
  131. renderModel(model: IRenderMime.IMimeModel): Promise<void> {
  132. let source = model.data['application/json'];
  133. model.setData({ data: { 'text/html': json2html(source) } });
  134. return super.renderModel(model);
  135. }
  136. }
  137. const jsonRendererFactory = {
  138. mimeTypes: ['application/json'],
  139. safe: true,
  140. createRenderer(options: IRenderMime.IRendererOptions): IRenderMime.IRenderer {
  141. return new JSONRenderer(options);
  142. }
  143. };
  144. export
  145. const rendermime = new RenderMimeRegistry({
  146. initialFactories: standardRendererFactories
  147. });
  148. rendermime.addFactory(jsonRendererFactory, 10);
  149. }
  150. /**
  151. * The default outputs used for testing.
  152. */
  153. export
  154. const DEFAULT_OUTPUTS: nbformat.IOutput[] = [
  155. {
  156. name: 'stdout',
  157. output_type: 'stream',
  158. text: [
  159. 'hello world\n',
  160. '0\n',
  161. '1\n',
  162. '2\n'
  163. ]
  164. },
  165. {
  166. name: 'stderr',
  167. output_type: 'stream',
  168. text: [
  169. 'output to stderr\n'
  170. ]
  171. },
  172. {
  173. name: 'stderr',
  174. output_type: 'stream',
  175. text: [
  176. 'output to stderr2\n'
  177. ]
  178. },
  179. {
  180. output_type: 'execute_result',
  181. execution_count: 1,
  182. data: { 'text/plain': 'foo' },
  183. metadata: {}
  184. },
  185. {
  186. output_type: 'display_data',
  187. data: { 'text/plain': 'hello, world' },
  188. metadata: {}
  189. },
  190. {
  191. output_type: 'error',
  192. ename: 'foo',
  193. evalue: 'bar',
  194. traceback: ['fizz', 'buzz']
  195. }
  196. ];