messages.js 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. md.messages = ({storage: {defaults, state, set}, compilers, mathjax, xhr, webrequest, icon}) => {
  2. return (req, sender, sendResponse) => {
  3. // content
  4. if (req.message === 'markdown') {
  5. var markdown = req.markdown
  6. if (state.content.mathjax) {
  7. var jax = mathjax()
  8. markdown = jax.tokenize(markdown)
  9. }
  10. var html = compilers[state.compiler].compile(markdown)
  11. if (state.content.mathjax) {
  12. html = jax.detokenize(html)
  13. }
  14. sendResponse({message: 'html', html})
  15. }
  16. else if (req.message === 'autoreload') {
  17. xhr.get(req.location, (err, body) => {
  18. sendResponse({err, body})
  19. })
  20. }
  21. else if (req.message === 'mathjax') {
  22. chrome.scripting.executeScript({
  23. target: {tabId: sender.tab.id},
  24. files: [
  25. `/vendor/mathjax/extensions/${req.extension}.js`,
  26. ],
  27. injectImmediately: true
  28. }, sendResponse)
  29. }
  30. // popup
  31. else if (req.message === 'popup') {
  32. sendResponse(Object.assign({}, state, {
  33. options: state[state.compiler],
  34. description: compilers[state.compiler].description,
  35. compilers: Object.keys(compilers),
  36. themes: state.themes,
  37. }))
  38. }
  39. else if (req.message === 'popup.theme') {
  40. set({theme: req.theme})
  41. notifyContent({message: 'theme', theme: req.theme})
  42. sendResponse()
  43. }
  44. else if (req.message === 'popup.raw') {
  45. set({raw: req.raw})
  46. notifyContent({message: 'raw', raw: req.raw})
  47. sendResponse()
  48. }
  49. else if (req.message === 'popup.themes') {
  50. set({themes: req.themes})
  51. notifyContent({message: 'themes', themes: req.themes})
  52. sendResponse()
  53. }
  54. else if (req.message === 'popup.defaults') {
  55. var options = Object.assign({}, defaults)
  56. options.origins = state.origins
  57. set(options)
  58. notifyContent({message: 'reload'})
  59. sendResponse()
  60. }
  61. else if (req.message === 'popup.compiler.name') {
  62. set({compiler: req.compiler})
  63. notifyContent({message: 'reload'})
  64. sendResponse()
  65. }
  66. else if (req.message === 'popup.compiler.options') {
  67. set({[req.compiler]: req.options})
  68. notifyContent({message: 'reload'})
  69. sendResponse()
  70. }
  71. else if (req.message === 'popup.content') {
  72. set({content: req.content})
  73. notifyContent({message: 'reload'})
  74. webrequest()
  75. sendResponse()
  76. }
  77. else if (req.message === 'popup.advanced') {
  78. // ff: opens up about:addons with openOptionsPage
  79. if (/Firefox/.test(navigator.userAgent)) {
  80. chrome.management.getSelf((extension) => {
  81. chrome.tabs.create({url: extension.optionsUrl})
  82. })
  83. }
  84. else {
  85. chrome.runtime.openOptionsPage()
  86. }
  87. sendResponse()
  88. }
  89. // origins view
  90. else if (req.message === 'options.origins') {
  91. sendResponse({
  92. origins: state.origins,
  93. match: state.match,
  94. })
  95. }
  96. // origins options
  97. else if (req.message === 'origin.add') {
  98. state.origins[req.origin] = {
  99. header: true,
  100. path: true,
  101. match: defaults.match,
  102. }
  103. set({origins: state.origins})
  104. sendResponse()
  105. }
  106. else if (req.message === 'origin.remove') {
  107. delete state.origins[req.origin]
  108. set({origins: state.origins})
  109. webrequest()
  110. sendResponse()
  111. }
  112. else if (req.message === 'origin.update') {
  113. state.origins[req.origin] = req.options
  114. set({origins: state.origins})
  115. webrequest()
  116. sendResponse()
  117. }
  118. // settings view
  119. else if (req.message === 'options.settings') {
  120. sendResponse({
  121. icon: state.icon,
  122. })
  123. }
  124. // settings options
  125. else if (req.message === 'options.icon') {
  126. set({icon: req.icon})
  127. icon()
  128. sendResponse()
  129. }
  130. return true
  131. }
  132. function notifyContent (req, res) {
  133. chrome.tabs.query({active: true, currentWindow: true}, (tabs) => {
  134. chrome.tabs.sendMessage(tabs[0].id, req, res)
  135. })
  136. }
  137. }