AsyncLoad.ts 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  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 Implements asynchronous loading of files
  19. *
  20. * @author dpvc@mathjax.org (Davide Cervone)
  21. */
  22. import {mathjax} from '../mathjax.js';
  23. /**
  24. * Load a file asynchronously using the mathjax.asynchLoad method, if there is one
  25. *
  26. * @param {string} name The name of the file to load
  27. * @return {Promise} The promise that is satisfied when the file is loaded
  28. */
  29. export function asyncLoad(name: string): Promise<void> {
  30. if (!mathjax.asyncLoad) {
  31. return Promise.reject(`Can't load '${name}': No asyncLoad method specified`);
  32. }
  33. return new Promise((ok, fail) => {
  34. const result = mathjax.asyncLoad(name);
  35. if (result instanceof Promise) {
  36. result.then((value: any) => ok(value)).catch((err: Error) => fail(err));
  37. } else {
  38. ok(result);
  39. }
  40. });
  41. }