Subversion-Projekte lars-tiefland.ci

Revision

Details | Letzte Änderung | Log anzeigen | RSS feed

Revision Autor Zeilennr. Zeile
776 lars 1
// CodeMirror, copyright (c) by Marijn Haverbeke and others
2
// Distributed under an MIT license: http://codemirror.net/LICENSE
3
 
4
(function(mod) {
5
  if (typeof exports == "object" && typeof module == "object") // CommonJS
6
    mod(require("../../lib/codemirror"));
7
  else if (typeof define == "function" && define.amd) // AMD
8
    define(["../../lib/codemirror"], mod);
9
  else // Plain browser env
10
    mod(CodeMirror);
11
})(function(CodeMirror) {
12
  "use strict";
13
 
14
  function Bar(cls, orientation, scroll) {
15
    this.orientation = orientation;
16
    this.scroll = scroll;
17
    this.screen = this.total = this.size = 1;
18
    this.pos = 0;
19
 
20
    this.node = document.createElement("div");
21
    this.node.className = cls + "-" + orientation;
22
    this.inner = this.node.appendChild(document.createElement("div"));
23
 
24
    var self = this;
25
    CodeMirror.on(this.inner, "mousedown", function(e) {
26
      if (e.which != 1) return;
27
      CodeMirror.e_preventDefault(e);
28
      var axis = self.orientation == "horizontal" ? "pageX" : "pageY";
29
      var start = e[axis], startpos = self.pos;
30
      function done() {
31
        CodeMirror.off(document, "mousemove", move);
32
        CodeMirror.off(document, "mouseup", done);
33
      }
34
      function move(e) {
35
        if (e.which != 1) return done();
36
        self.moveTo(startpos + (e[axis] - start) * (self.total / self.size));
37
      }
38
      CodeMirror.on(document, "mousemove", move);
39
      CodeMirror.on(document, "mouseup", done);
40
    });
41
 
42
    CodeMirror.on(this.node, "click", function(e) {
43
      CodeMirror.e_preventDefault(e);
44
      var innerBox = self.inner.getBoundingClientRect(), where;
45
      if (self.orientation == "horizontal")
46
        where = e.clientX < innerBox.left ? -1 : e.clientX > innerBox.right ? 1 : 0;
47
      else
48
        where = e.clientY < innerBox.top ? -1 : e.clientY > innerBox.bottom ? 1 : 0;
49
      self.moveTo(self.pos + where * self.screen);
50
    });
51
 
52
    function onWheel(e) {
53
      var moved = CodeMirror.wheelEventPixels(e)[self.orientation == "horizontal" ? "x" : "y"];
54
      var oldPos = self.pos;
55
      self.moveTo(self.pos + moved);
56
      if (self.pos != oldPos) CodeMirror.e_preventDefault(e);
57
    }
58
    CodeMirror.on(this.node, "mousewheel", onWheel);
59
    CodeMirror.on(this.node, "DOMMouseScroll", onWheel);
60
  }
61
 
62
  Bar.prototype.moveTo = function(pos, update) {
63
    if (pos < 0) pos = 0;
64
    if (pos > this.total - this.screen) pos = this.total - this.screen;
65
    if (pos == this.pos) return;
66
    this.pos = pos;
67
    this.inner.style[this.orientation == "horizontal" ? "left" : "top"] =
68
      (pos * (this.size / this.total)) + "px";
69
    if (update !== false) this.scroll(pos, this.orientation);
70
  };
71
 
72
  var minButtonSize = 10;
73
 
74
  Bar.prototype.update = function(scrollSize, clientSize, barSize) {
75
    this.screen = clientSize;
76
    this.total = scrollSize;
77
    this.size = barSize;
78
 
79
    var buttonSize = this.screen * (this.size / this.total);
80
    if (buttonSize < minButtonSize) {
81
      this.size -= minButtonSize - buttonSize;
82
      buttonSize = minButtonSize;
83
    }
84
    this.inner.style[this.orientation == "horizontal" ? "width" : "height"] =
85
      buttonSize + "px";
86
    this.inner.style[this.orientation == "horizontal" ? "left" : "top"] =
87
      this.pos * (this.size / this.total) + "px";
88
  };
89
 
90
  function SimpleScrollbars(cls, place, scroll) {
91
    this.addClass = cls;
92
    this.horiz = new Bar(cls, "horizontal", scroll);
93
    place(this.horiz.node);
94
    this.vert = new Bar(cls, "vertical", scroll);
95
    place(this.vert.node);
96
    this.width = null;
97
  }
98
 
99
  SimpleScrollbars.prototype.update = function(measure) {
100
    if (this.width == null) {
101
      var style = window.getComputedStyle ? window.getComputedStyle(this.horiz.node) : this.horiz.node.currentStyle;
102
      if (style) this.width = parseInt(style.height);
103
    }
104
    var width = this.width || 0;
105
 
106
    var needsH = measure.scrollWidth > measure.clientWidth + 1;
107
    var needsV = measure.scrollHeight > measure.clientHeight + 1;
108
    this.vert.node.style.display = needsV ? "block" : "none";
109
    this.horiz.node.style.display = needsH ? "block" : "none";
110
 
111
    if (needsV) {
112
      this.vert.update(measure.scrollHeight, measure.clientHeight,
113
                       measure.viewHeight - (needsH ? width : 0));
114
      this.vert.node.style.display = "block";
115
      this.vert.node.style.bottom = needsH ? width + "px" : "0";
116
    }
117
    if (needsH) {
118
      this.horiz.update(measure.scrollWidth, measure.clientWidth,
119
                        measure.viewWidth - (needsV ? width : 0) - measure.barLeft);
120
      this.horiz.node.style.right = needsV ? width + "px" : "0";
121
      this.horiz.node.style.left = measure.barLeft + "px";
122
    }
123
 
124
    return {right: needsV ? width : 0, bottom: needsH ? width : 0};
125
  };
126
 
127
  SimpleScrollbars.prototype.setScrollTop = function(pos) {
128
    this.vert.moveTo(pos, false);
129
  };
130
 
131
  SimpleScrollbars.prototype.setScrollLeft = function(pos) {
132
    this.horiz.moveTo(pos, false);
133
  };
134
 
135
  SimpleScrollbars.prototype.clear = function() {
136
    var parent = this.horiz.node.parentNode;
137
    parent.removeChild(this.horiz.node);
138
    parent.removeChild(this.vert.node);
139
  };
140
 
141
  CodeMirror.scrollbarModel.simple = function(place, scroll) {
142
    return new SimpleScrollbars("CodeMirror-simplescroll", place, scroll);
143
  };
144
  CodeMirror.scrollbarModel.overlay = function(place, scroll) {
145
    return new SimpleScrollbars("CodeMirror-overlayscroll", place, scroll);
146
  };
147
});