mathjax.ts 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. /*************************************************************
  2. *
  3. * Copyright (c) 2017-2022 The MathJax Consortium
  4. *
  5. * Licensed under the Apache License, Version 2.0 (the "License");
  6. * you may not use this file except in compliance with the License.
  7. * You may obtain a copy of the License at
  8. *
  9. * http://www.apache.org/licenses/LICENSE-2.0
  10. *
  11. * Unless required by applicable law or agreed to in writing, software
  12. * distributed under the License is distributed on an "AS IS" BASIS,
  13. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. * See the License for the specific language governing permissions and
  15. * limitations under the License.
  16. */
  17. /**
  18. * @fileoverview The main MathJax global object
  19. *
  20. * @author dpvc@mathjax.org (Davide Cervone)
  21. */
  22. import {VERSION} from './components/version.js';
  23. import {HandlerList} from './core/HandlerList.js';
  24. import {handleRetriesFor, retryAfter} from './util/Retries.js';
  25. import {OptionList} from './util/Options.js';
  26. import {MathDocument} from './core/MathDocument.js';
  27. /*****************************************************************/
  28. /**
  29. * The main MathJax global object
  30. */
  31. export const mathjax = {
  32. /**
  33. * The MathJax version number
  34. */
  35. version: VERSION,
  36. /**
  37. * The list of registers document handlers
  38. */
  39. handlers: new HandlerList<any, any, any>(),
  40. /**
  41. * Creates a MathDocument using a registered handler that knows how to handl it
  42. *
  43. * @param {any} document The document to handle
  44. * @param {OptionList} options The options to use for the document (e.g., input and output jax)
  45. * @return {MathDocument} The MathDocument to handle the document
  46. */
  47. document: function (document: any, options: OptionList): MathDocument<any, any, any> {
  48. return mathjax.handlers.document(document, options);
  49. },
  50. /**
  51. * The functions for handling retries if a file must be loaded dynamically
  52. */
  53. handleRetriesFor: handleRetriesFor,
  54. retryAfter: retryAfter,
  55. /**
  56. * A function for loading external files (can be changed for node/browser use)
  57. */
  58. asyncLoad: null as ((file: string) => any),
  59. };