rulers.js 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. // CodeMirror, copyright (c) by Marijn Haverbeke and others
  2. // Distributed under an MIT license: https://codemirror.net/LICENSE
  3. ;(function (mod) {
  4. if (typeof exports == 'object' && typeof module == 'object')
  5. // CommonJS
  6. mod(require('../../lib/codemirror'))
  7. else if (typeof define == 'function' && define.amd)
  8. // AMD
  9. define(['../../lib/codemirror'], mod)
  10. // Plain browser env
  11. else mod(CodeMirror)
  12. })(function (CodeMirror) {
  13. 'use strict'
  14. CodeMirror.defineOption('rulers', false, function (cm, val) {
  15. if (cm.state.rulerDiv) {
  16. cm.state.rulerDiv.parentElement.removeChild(cm.state.rulerDiv)
  17. cm.state.rulerDiv = null
  18. cm.off('refresh', drawRulers)
  19. }
  20. if (val && val.length) {
  21. cm.state.rulerDiv = cm.display.lineSpace.parentElement.insertBefore(document.createElement('div'), cm.display.lineSpace)
  22. cm.state.rulerDiv.className = 'CodeMirror-rulers'
  23. drawRulers(cm)
  24. cm.on('refresh', drawRulers)
  25. }
  26. })
  27. function drawRulers(cm) {
  28. cm.state.rulerDiv.textContent = ''
  29. var val = cm.getOption('rulers')
  30. var cw = cm.defaultCharWidth()
  31. var left = cm.charCoords(CodeMirror.Pos(cm.firstLine(), 0), 'div').left
  32. cm.state.rulerDiv.style.minHeight = cm.display.scroller.offsetHeight + 30 + 'px'
  33. for (var i = 0; i < val.length; i++) {
  34. var elt = document.createElement('div')
  35. elt.className = 'CodeMirror-ruler'
  36. var col,
  37. conf = val[i]
  38. if (typeof conf == 'number') {
  39. col = conf
  40. } else {
  41. col = conf.column
  42. if (conf.className) elt.className += ' ' + conf.className
  43. if (conf.color) elt.style.borderColor = conf.color
  44. if (conf.lineStyle) elt.style.borderLeftStyle = conf.lineStyle
  45. if (conf.width) elt.style.borderLeftWidth = conf.width
  46. }
  47. elt.style.left = left + col * cw + 'px'
  48. cm.state.rulerDiv.appendChild(elt)
  49. }
  50. }
  51. })