copy-tex.js 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. (function webpackUniversalModuleDefinition(root, factory) {
  2. if(typeof exports === 'object' && typeof module === 'object')
  3. module.exports = factory();
  4. else if(typeof define === 'function' && define.amd)
  5. define([], factory);
  6. else {
  7. var a = factory();
  8. for(var i in a) (typeof exports === 'object' ? exports : root)[i] = a[i];
  9. }
  10. })((typeof self !== 'undefined' ? self : this), function() {
  11. return /******/ (function(modules) { // webpackBootstrap
  12. /******/ // The module cache
  13. /******/ var installedModules = {};
  14. /******/
  15. /******/ // The require function
  16. /******/ function __webpack_require__(moduleId) {
  17. /******/
  18. /******/ // Check if module is in cache
  19. /******/ if(installedModules[moduleId]) {
  20. /******/ return installedModules[moduleId].exports;
  21. /******/ }
  22. /******/ // Create a new module (and put it into the cache)
  23. /******/ var module = installedModules[moduleId] = {
  24. /******/ i: moduleId,
  25. /******/ l: false,
  26. /******/ exports: {}
  27. /******/ };
  28. /******/
  29. /******/ // Execute the module function
  30. /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
  31. /******/
  32. /******/ // Flag the module as loaded
  33. /******/ module.l = true;
  34. /******/
  35. /******/ // Return the exports of the module
  36. /******/ return module.exports;
  37. /******/ }
  38. /******/
  39. /******/
  40. /******/ // expose the modules object (__webpack_modules__)
  41. /******/ __webpack_require__.m = modules;
  42. /******/
  43. /******/ // expose the module cache
  44. /******/ __webpack_require__.c = installedModules;
  45. /******/
  46. /******/ // define getter function for harmony exports
  47. /******/ __webpack_require__.d = function(exports, name, getter) {
  48. /******/ if(!__webpack_require__.o(exports, name)) {
  49. /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
  50. /******/ }
  51. /******/ };
  52. /******/
  53. /******/ // define __esModule on exports
  54. /******/ __webpack_require__.r = function(exports) {
  55. /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
  56. /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
  57. /******/ }
  58. /******/ Object.defineProperty(exports, '__esModule', { value: true });
  59. /******/ };
  60. /******/
  61. /******/ // create a fake namespace object
  62. /******/ // mode & 1: value is a module id, require it
  63. /******/ // mode & 2: merge all properties of value into the ns
  64. /******/ // mode & 4: return value when already ns object
  65. /******/ // mode & 8|1: behave like require
  66. /******/ __webpack_require__.t = function(value, mode) {
  67. /******/ if(mode & 1) value = __webpack_require__(value);
  68. /******/ if(mode & 8) return value;
  69. /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
  70. /******/ var ns = Object.create(null);
  71. /******/ __webpack_require__.r(ns);
  72. /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
  73. /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
  74. /******/ return ns;
  75. /******/ };
  76. /******/
  77. /******/ // getDefaultExport function for compatibility with non-harmony modules
  78. /******/ __webpack_require__.n = function(module) {
  79. /******/ var getter = module && module.__esModule ?
  80. /******/ function getDefault() { return module['default']; } :
  81. /******/ function getModuleExports() { return module; };
  82. /******/ __webpack_require__.d(getter, 'a', getter);
  83. /******/ return getter;
  84. /******/ };
  85. /******/
  86. /******/ // Object.prototype.hasOwnProperty.call
  87. /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
  88. /******/
  89. /******/ // __webpack_public_path__
  90. /******/ __webpack_require__.p = "";
  91. /******/
  92. /******/
  93. /******/ // Load entry module and return exports
  94. /******/ return __webpack_require__(__webpack_require__.s = 2);
  95. /******/ })
  96. /************************************************************************/
  97. /******/ ([
  98. /* 0 */
  99. /***/ (function(module, exports, __webpack_require__) {
  100. // extracted by mini-css-extract-plugin
  101. /***/ }),
  102. /* 1 */,
  103. /* 2 */
  104. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  105. "use strict";
  106. __webpack_require__.r(__webpack_exports__);
  107. // EXTERNAL MODULE: ./contrib/copy-tex/copy-tex.css
  108. var copy_tex = __webpack_require__(0);
  109. // CONCATENATED MODULE: ./contrib/copy-tex/katex2tex.js
  110. // Set these to how you want inline and display math to be delimited.
  111. var defaultCopyDelimiters = {
  112. inline: ['$', '$'], // alternative: ['\(', '\)']
  113. display: ['$$', '$$'] // alternative: ['\[', '\]']
  114. };
  115. // Replace .katex elements with their TeX source (<annotation> element).
  116. // Modifies fragment in-place. Useful for writing your own 'copy' handler,
  117. // as in copy-tex.js.
  118. var katexReplaceWithTex = function katexReplaceWithTex(fragment) {
  119. var copyDelimiters = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultCopyDelimiters;
  120. // Remove .katex-html blocks that are preceded by .katex-mathml blocks
  121. // (which will get replaced below).
  122. var katexHtml = fragment.querySelectorAll('.katex-mathml + .katex-html');
  123. for (var i = 0; i < katexHtml.length; i++) {
  124. var element = katexHtml[i];
  125. if (element.remove) {
  126. element.remove(null);
  127. } else {
  128. element.parentNode.removeChild(element);
  129. }
  130. }
  131. // Replace .katex-mathml elements with their annotation (TeX source)
  132. // descendant, with inline delimiters.
  133. var katexMathml = fragment.querySelectorAll('.katex-mathml');
  134. for (var _i = 0; _i < katexMathml.length; _i++) {
  135. var _element = katexMathml[_i];
  136. var texSource = _element.querySelector('annotation');
  137. if (texSource) {
  138. if (_element.replaceWith) {
  139. _element.replaceWith(texSource);
  140. } else {
  141. _element.parentNode.replaceChild(texSource, _element);
  142. }
  143. texSource.innerHTML = copyDelimiters.inline[0] + texSource.innerHTML + copyDelimiters.inline[1];
  144. }
  145. }
  146. // Switch display math to display delimiters.
  147. var displays = fragment.querySelectorAll('.katex-display annotation');
  148. for (var _i2 = 0; _i2 < displays.length; _i2++) {
  149. var _element2 = displays[_i2];
  150. _element2.innerHTML = copyDelimiters.display[0] + _element2.innerHTML.substr(copyDelimiters.inline[0].length, _element2.innerHTML.length - copyDelimiters.inline[0].length - copyDelimiters.inline[1].length) + copyDelimiters.display[1];
  151. }
  152. return fragment;
  153. };
  154. /* harmony default export */ var katex2tex = (katexReplaceWithTex);
  155. // CONCATENATED MODULE: ./contrib/copy-tex/copy-tex.js
  156. // Global copy handler to modify behavior on .katex elements.
  157. document.addEventListener('copy', function (event) {
  158. var selection = window.getSelection();
  159. if (selection.isCollapsed) {
  160. return; // default action OK if selection is empty
  161. }
  162. var fragment = selection.getRangeAt(0).cloneContents();
  163. if (!fragment.querySelector('.katex-mathml')) {
  164. return; // default action OK if no .katex-mathml elements
  165. }
  166. // Preserve usual HTML copy/paste behavior.
  167. var html = [];
  168. for (var i = 0; i < fragment.childNodes.length; i++) {
  169. html.push(fragment.childNodes[i].outerHTML);
  170. }
  171. event.clipboardData.setData('text/html', html.join(''));
  172. // Rewrite plain-text version.
  173. event.clipboardData.setData('text/plain', katex2tex(fragment).textContent);
  174. // Prevent normal copy handling.
  175. event.preventDefault();
  176. });
  177. /***/ })
  178. /******/ ])["default"];
  179. });