@xterm/xterm 6.1.0-beta.18 → 6.1.0-beta.180

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (156) hide show
  1. package/README.md +60 -38
  2. package/css/xterm.css +29 -22
  3. package/lib/xterm.js +1 -1
  4. package/lib/xterm.js.map +1 -1
  5. package/lib/xterm.mjs +8 -34
  6. package/lib/xterm.mjs.map +4 -4
  7. package/package.json +25 -14
  8. package/src/browser/AccessibilityManager.ts +6 -3
  9. package/src/browser/Clipboard.ts +6 -3
  10. package/src/browser/CoreBrowserTerminal.ts +142 -62
  11. package/src/browser/Dom.ts +178 -0
  12. package/src/browser/Linkifier.ts +3 -3
  13. package/src/browser/OscLinkProvider.ts +3 -1
  14. package/src/browser/RenderDebouncer.ts +2 -2
  15. package/src/browser/TimeBasedDebouncer.ts +2 -2
  16. package/src/browser/Types.ts +12 -11
  17. package/src/browser/Viewport.ts +40 -17
  18. package/src/browser/decorations/BufferDecorationRenderer.ts +1 -1
  19. package/src/browser/decorations/OverviewRulerRenderer.ts +15 -16
  20. package/src/browser/input/CompositionHelper.ts +16 -1
  21. package/src/browser/public/Terminal.ts +24 -27
  22. package/src/browser/renderer/dom/DomRenderer.ts +128 -8
  23. package/src/browser/renderer/dom/DomRendererRowFactory.ts +19 -13
  24. package/src/browser/renderer/dom/WidthCache.ts +54 -52
  25. package/src/browser/renderer/shared/Constants.ts +7 -0
  26. package/src/browser/renderer/shared/TextBlinkStateManager.ts +97 -0
  27. package/src/browser/renderer/shared/Types.ts +8 -2
  28. package/src/browser/scrollable/abstractScrollbar.ts +300 -0
  29. package/src/browser/scrollable/fastDomNode.ts +126 -0
  30. package/src/browser/scrollable/globalPointerMoveMonitor.ts +90 -0
  31. package/src/browser/scrollable/horizontalScrollbar.ts +85 -0
  32. package/src/browser/scrollable/mouseEvent.ts +292 -0
  33. package/src/browser/scrollable/scrollable.ts +486 -0
  34. package/src/browser/scrollable/scrollableElement.ts +579 -0
  35. package/src/browser/scrollable/scrollableElementOptions.ts +161 -0
  36. package/src/browser/scrollable/scrollbarArrow.ts +110 -0
  37. package/src/browser/scrollable/scrollbarState.ts +246 -0
  38. package/src/browser/scrollable/scrollbarVisibilityController.ts +113 -0
  39. package/src/browser/scrollable/touch.ts +481 -0
  40. package/src/browser/scrollable/verticalScrollbar.ts +143 -0
  41. package/src/browser/scrollable/widget.ts +23 -0
  42. package/src/browser/services/CharSizeService.ts +2 -2
  43. package/src/browser/services/CoreBrowserService.ts +7 -5
  44. package/src/browser/services/KeyboardService.ts +67 -0
  45. package/src/browser/services/LinkProviderService.ts +1 -1
  46. package/src/browser/services/MouseService.ts +2 -1
  47. package/src/browser/services/RenderService.ts +22 -15
  48. package/src/browser/services/SelectionService.ts +12 -4
  49. package/src/browser/services/Services.ts +24 -15
  50. package/src/browser/services/ThemeService.ts +2 -2
  51. package/src/common/Async.ts +105 -0
  52. package/src/common/CircularList.ts +2 -2
  53. package/src/common/Color.ts +8 -0
  54. package/src/common/CoreTerminal.ts +21 -11
  55. package/src/common/Event.ts +118 -0
  56. package/src/common/InputHandler.ts +244 -24
  57. package/src/common/Lifecycle.ts +113 -0
  58. package/src/common/Platform.ts +13 -3
  59. package/src/common/SortedList.ts +7 -3
  60. package/src/common/TaskQueue.ts +9 -3
  61. package/src/common/Types.ts +29 -9
  62. package/src/common/Version.ts +9 -0
  63. package/src/common/buffer/Buffer.ts +20 -14
  64. package/src/common/buffer/BufferLine.ts +4 -5
  65. package/src/common/buffer/BufferSet.ts +7 -6
  66. package/src/common/buffer/CellData.ts +57 -0
  67. package/src/common/buffer/Marker.ts +2 -2
  68. package/src/common/buffer/Types.ts +6 -2
  69. package/src/common/data/EscapeSequences.ts +71 -70
  70. package/src/common/input/Keyboard.ts +14 -7
  71. package/src/common/input/KittyKeyboard.ts +491 -0
  72. package/src/common/input/Win32InputMode.ts +297 -0
  73. package/src/common/input/WriteBuffer.ts +34 -2
  74. package/src/common/input/XParseColor.ts +2 -2
  75. package/src/common/parser/ApcParser.ts +245 -0
  76. package/src/common/parser/Constants.ts +22 -4
  77. package/src/common/parser/DcsParser.ts +5 -5
  78. package/src/common/parser/EscapeSequenceParser.ts +75 -22
  79. package/src/common/parser/OscParser.ts +5 -5
  80. package/src/common/parser/Types.ts +34 -1
  81. package/src/common/public/BufferLineApiView.ts +2 -2
  82. package/src/common/public/BufferNamespaceApi.ts +2 -2
  83. package/src/common/public/ParserApi.ts +3 -0
  84. package/src/common/services/BufferService.ts +8 -5
  85. package/src/common/services/CharsetService.ts +4 -0
  86. package/src/common/services/CoreMouseService.ts +2 -2
  87. package/src/common/services/CoreService.ts +18 -4
  88. package/src/common/services/DecorationService.ts +24 -8
  89. package/src/common/services/LogService.ts +1 -31
  90. package/src/common/services/OptionsService.ts +13 -4
  91. package/src/common/services/Services.ts +39 -16
  92. package/src/common/services/UnicodeService.ts +1 -1
  93. package/typings/xterm.d.ts +319 -35
  94. package/src/common/TypedArrayUtils.ts +0 -17
  95. package/src/vs/base/browser/browser.ts +0 -141
  96. package/src/vs/base/browser/canIUse.ts +0 -49
  97. package/src/vs/base/browser/dom.ts +0 -2369
  98. package/src/vs/base/browser/fastDomNode.ts +0 -316
  99. package/src/vs/base/browser/globalPointerMoveMonitor.ts +0 -112
  100. package/src/vs/base/browser/iframe.ts +0 -135
  101. package/src/vs/base/browser/keyboardEvent.ts +0 -213
  102. package/src/vs/base/browser/mouseEvent.ts +0 -229
  103. package/src/vs/base/browser/touch.ts +0 -372
  104. package/src/vs/base/browser/ui/scrollbar/abstractScrollbar.ts +0 -303
  105. package/src/vs/base/browser/ui/scrollbar/horizontalScrollbar.ts +0 -114
  106. package/src/vs/base/browser/ui/scrollbar/scrollableElement.ts +0 -720
  107. package/src/vs/base/browser/ui/scrollbar/scrollableElementOptions.ts +0 -165
  108. package/src/vs/base/browser/ui/scrollbar/scrollbarArrow.ts +0 -114
  109. package/src/vs/base/browser/ui/scrollbar/scrollbarState.ts +0 -243
  110. package/src/vs/base/browser/ui/scrollbar/scrollbarVisibilityController.ts +0 -118
  111. package/src/vs/base/browser/ui/scrollbar/verticalScrollbar.ts +0 -116
  112. package/src/vs/base/browser/ui/widget.ts +0 -57
  113. package/src/vs/base/browser/window.ts +0 -14
  114. package/src/vs/base/common/arrays.ts +0 -887
  115. package/src/vs/base/common/arraysFind.ts +0 -202
  116. package/src/vs/base/common/assert.ts +0 -71
  117. package/src/vs/base/common/async.ts +0 -1992
  118. package/src/vs/base/common/cancellation.ts +0 -148
  119. package/src/vs/base/common/charCode.ts +0 -450
  120. package/src/vs/base/common/collections.ts +0 -140
  121. package/src/vs/base/common/decorators.ts +0 -130
  122. package/src/vs/base/common/equals.ts +0 -146
  123. package/src/vs/base/common/errors.ts +0 -303
  124. package/src/vs/base/common/event.ts +0 -1778
  125. package/src/vs/base/common/functional.ts +0 -32
  126. package/src/vs/base/common/hash.ts +0 -316
  127. package/src/vs/base/common/iterator.ts +0 -159
  128. package/src/vs/base/common/keyCodes.ts +0 -526
  129. package/src/vs/base/common/keybindings.ts +0 -284
  130. package/src/vs/base/common/lazy.ts +0 -47
  131. package/src/vs/base/common/lifecycle.ts +0 -801
  132. package/src/vs/base/common/linkedList.ts +0 -142
  133. package/src/vs/base/common/map.ts +0 -202
  134. package/src/vs/base/common/numbers.ts +0 -98
  135. package/src/vs/base/common/observable.ts +0 -76
  136. package/src/vs/base/common/observableInternal/api.ts +0 -31
  137. package/src/vs/base/common/observableInternal/autorun.ts +0 -281
  138. package/src/vs/base/common/observableInternal/base.ts +0 -489
  139. package/src/vs/base/common/observableInternal/debugName.ts +0 -145
  140. package/src/vs/base/common/observableInternal/derived.ts +0 -428
  141. package/src/vs/base/common/observableInternal/lazyObservableValue.ts +0 -146
  142. package/src/vs/base/common/observableInternal/logging.ts +0 -328
  143. package/src/vs/base/common/observableInternal/promise.ts +0 -209
  144. package/src/vs/base/common/observableInternal/utils.ts +0 -610
  145. package/src/vs/base/common/platform.ts +0 -281
  146. package/src/vs/base/common/scrollable.ts +0 -522
  147. package/src/vs/base/common/sequence.ts +0 -34
  148. package/src/vs/base/common/stopwatch.ts +0 -43
  149. package/src/vs/base/common/strings.ts +0 -557
  150. package/src/vs/base/common/symbols.ts +0 -9
  151. package/src/vs/base/common/uint.ts +0 -59
  152. package/src/vs/patches/nls.ts +0 -90
  153. package/src/vs/typings/base-common.d.ts +0 -20
  154. package/src/vs/typings/require.d.ts +0 -42
  155. package/src/vs/typings/vscode-globals-nls.d.ts +0 -36
  156. package/src/vs/typings/vscode-globals-product.d.ts +0 -33
@@ -0,0 +1,481 @@
1
+ /*---------------------------------------------------------------------------------------------
2
+ * Copyright (c) Microsoft Corporation. All rights reserved.
3
+ * Licensed under the MIT License. See License.txt in the project root for license information.
4
+ *--------------------------------------------------------------------------------------------*/
5
+
6
+ import * as DomUtils from '../Dom';
7
+ import { Disposable, IDisposable, toDisposable } from 'common/Lifecycle';
8
+
9
+ const mainWindow = (typeof window === 'object' ? window : globalThis) as Window & typeof globalThis;
10
+
11
+ function tail<T>(array: ArrayLike<T>, n: number = 0): T | undefined {
12
+ return array[array.length - (1 + n)];
13
+ }
14
+
15
+ function memoize(_target: any, key: string, descriptor: PropertyDescriptor): void {
16
+ let fnKey: string | null = null;
17
+ let fn: Function | null = null;
18
+
19
+ if (typeof descriptor.value === 'function') {
20
+ fnKey = 'value';
21
+ fn = descriptor.value;
22
+
23
+ if (fn!.length !== 0) {
24
+ console.warn('Memoize should only be used in functions with zero parameters');
25
+ }
26
+ } else if (typeof descriptor.get === 'function') {
27
+ fnKey = 'get';
28
+ fn = descriptor.get;
29
+ }
30
+
31
+ if (!fn || !fnKey) {
32
+ throw new Error('not supported');
33
+ }
34
+
35
+ const memoizeKey = `$memoize$${key}`;
36
+ const descriptorAny = descriptor as { [key: string]: any };
37
+ descriptorAny[fnKey] = function (...args: any[]) {
38
+ if (!this.hasOwnProperty(memoizeKey)) {
39
+ Object.defineProperty(this, memoizeKey, {
40
+ configurable: false,
41
+ enumerable: false,
42
+ writable: false,
43
+ value: fn.apply(this, args)
44
+ });
45
+ }
46
+
47
+ return (this as { [key: string]: any })[memoizeKey];
48
+ };
49
+ }
50
+
51
+ class LinkedListNode<E> {
52
+
53
+ public static readonly Undefined = new LinkedListNode<any>(undefined);
54
+
55
+ public element: E;
56
+ public next: LinkedListNode<E>;
57
+ public prev: LinkedListNode<E>;
58
+
59
+ public constructor(element: E) {
60
+ this.element = element;
61
+ this.next = LinkedListNode.Undefined;
62
+ this.prev = LinkedListNode.Undefined;
63
+ }
64
+ }
65
+
66
+ class LinkedList<E> {
67
+
68
+ private _first: LinkedListNode<E> = LinkedListNode.Undefined;
69
+ private _last: LinkedListNode<E> = LinkedListNode.Undefined;
70
+
71
+ public push(element: E): () => void {
72
+ return this._insert(element, true);
73
+ }
74
+
75
+ private _insert(element: E, atTheEnd: boolean): () => void {
76
+ const newNode = new LinkedListNode(element);
77
+ if (this._first === LinkedListNode.Undefined) {
78
+ this._first = newNode;
79
+ this._last = newNode;
80
+
81
+ } else if (atTheEnd) {
82
+ const oldLast = this._last;
83
+ this._last = newNode;
84
+ newNode.prev = oldLast;
85
+ oldLast.next = newNode;
86
+
87
+ } else {
88
+ const oldFirst = this._first;
89
+ this._first = newNode;
90
+ newNode.next = oldFirst;
91
+ oldFirst.prev = newNode;
92
+ }
93
+ let didRemove = false;
94
+ return () => {
95
+ if (!didRemove) {
96
+ didRemove = true;
97
+ this._remove(newNode);
98
+ }
99
+ };
100
+ }
101
+
102
+ private _remove(node: LinkedListNode<E>): void {
103
+ if (node.prev !== LinkedListNode.Undefined && node.next !== LinkedListNode.Undefined) {
104
+ const anchor = node.prev;
105
+ anchor.next = node.next;
106
+ node.next.prev = anchor;
107
+
108
+ } else if (node.prev === LinkedListNode.Undefined && node.next === LinkedListNode.Undefined) {
109
+ this._first = LinkedListNode.Undefined;
110
+ this._last = LinkedListNode.Undefined;
111
+
112
+ } else if (node.next === LinkedListNode.Undefined) {
113
+ this._last = this._last.prev!;
114
+ this._last.next = LinkedListNode.Undefined;
115
+
116
+ } else if (node.prev === LinkedListNode.Undefined) {
117
+ this._first = this._first.next!;
118
+ this._first.prev = LinkedListNode.Undefined;
119
+ }
120
+ }
121
+
122
+ public *[Symbol.iterator](): Iterator<E> {
123
+ let node = this._first;
124
+ while (node !== LinkedListNode.Undefined) {
125
+ yield node.element;
126
+ node = node.next;
127
+ }
128
+ }
129
+ }
130
+
131
+ export namespace EventType {
132
+ export const TAP = '-xterm-gesturetap';
133
+ export const CHANGE = '-xterm-gesturechange';
134
+ export const START = '-xterm-gesturestart';
135
+ export const END = '-xterm-gesturesend';
136
+ export const CONTEXT_MENU = '-xterm-gesturecontextmenu';
137
+ }
138
+
139
+ interface ITouchData {
140
+ id: number;
141
+ initialTarget: EventTarget;
142
+ initialTimeStamp: number;
143
+ initialPageX: number;
144
+ initialPageY: number;
145
+ rollingTimestamps: number[];
146
+ rollingPageX: number[];
147
+ rollingPageY: number[];
148
+ }
149
+
150
+ export interface IGestureEvent extends MouseEvent {
151
+ initialTarget: EventTarget | undefined;
152
+ translationX: number;
153
+ translationY: number;
154
+ pageX: number;
155
+ pageY: number;
156
+ tapCount: number;
157
+ }
158
+
159
+ interface ITouch {
160
+ identifier: number;
161
+ screenX: number;
162
+ screenY: number;
163
+ clientX: number;
164
+ clientY: number;
165
+ pageX: number;
166
+ pageY: number;
167
+ radiusX: number;
168
+ radiusY: number;
169
+ rotationAngle: number;
170
+ force: number;
171
+ target: Element;
172
+ }
173
+
174
+ interface ITouchList {
175
+ [i: number]: ITouch;
176
+ length: number;
177
+ item(index: number): ITouch;
178
+ identifiedTouch(id: number): ITouch;
179
+ }
180
+
181
+ interface ITouchEvent extends Event {
182
+ touches: ITouchList;
183
+ targetTouches: ITouchList;
184
+ changedTouches: ITouchList;
185
+ }
186
+
187
+ export class Gesture extends Disposable {
188
+
189
+ private static readonly _scrollFriction = -0.005;
190
+ private static _instance: Gesture;
191
+ private static readonly _holdDelay = 700;
192
+
193
+ private _dispatched = false;
194
+ private readonly _targets = new LinkedList<HTMLElement>();
195
+ private readonly _ignoreTargets = new LinkedList<HTMLElement>();
196
+ private _handle: IDisposable | null;
197
+
198
+ private readonly _activeTouches: { [id: number]: ITouchData };
199
+
200
+ private _lastSetTapCountTime: number;
201
+
202
+ private static readonly _clearTapCountTime = 400; // ms
203
+
204
+
205
+ private constructor() {
206
+ super();
207
+
208
+ this._activeTouches = {};
209
+ this._handle = null;
210
+ this._lastSetTapCountTime = 0;
211
+
212
+ const targetWindow = mainWindow;
213
+ this._register(DomUtils.addDisposableListener(targetWindow.document, 'touchstart', (e: ITouchEvent) => this._handleTouchStart(e), { passive: false }));
214
+ this._register(DomUtils.addDisposableListener(targetWindow.document, 'touchend', (e: ITouchEvent) => this._handleTouchEnd(targetWindow, e)));
215
+ this._register(DomUtils.addDisposableListener(targetWindow.document, 'touchmove', (e: ITouchEvent) => this._handleTouchMove(e), { passive: false }));
216
+ }
217
+
218
+ public static addTarget(element: HTMLElement): IDisposable {
219
+ if (!Gesture.isTouchDevice()) {
220
+ return Disposable.None;
221
+ }
222
+ if (!Gesture._instance) {
223
+ Gesture._instance = new Gesture();
224
+ }
225
+
226
+ const remove = Gesture._instance._targets.push(element);
227
+ return toDisposable(remove);
228
+ }
229
+
230
+ public static ignoreTarget(element: HTMLElement): IDisposable {
231
+ if (!Gesture.isTouchDevice()) {
232
+ return Disposable.None;
233
+ }
234
+ if (!Gesture._instance) {
235
+ Gesture._instance = new Gesture();
236
+ }
237
+
238
+ const remove = Gesture._instance._ignoreTargets.push(element);
239
+ return toDisposable(remove);
240
+ }
241
+
242
+ @memoize
243
+ public static isTouchDevice(): boolean {
244
+ return 'ontouchstart' in mainWindow || navigator.maxTouchPoints > 0;
245
+ }
246
+
247
+ public override dispose(): void {
248
+ if (this._handle) {
249
+ this._handle.dispose();
250
+ this._handle = null;
251
+ }
252
+
253
+ super.dispose();
254
+ }
255
+
256
+ private _handleTouchStart(e: ITouchEvent): void {
257
+ const timestamp = Date.now();
258
+
259
+ if (this._handle) {
260
+ this._handle.dispose();
261
+ this._handle = null;
262
+ }
263
+
264
+ for (let i = 0, len = e.targetTouches.length; i < len; i++) {
265
+ const touch = e.targetTouches.item(i);
266
+
267
+ this._activeTouches[touch.identifier] = {
268
+ id: touch.identifier,
269
+ initialTarget: touch.target,
270
+ initialTimeStamp: timestamp,
271
+ initialPageX: touch.pageX,
272
+ initialPageY: touch.pageY,
273
+ rollingTimestamps: [timestamp],
274
+ rollingPageX: [touch.pageX],
275
+ rollingPageY: [touch.pageY]
276
+ };
277
+
278
+ const evt = this._newGestureEvent(EventType.START, touch.target);
279
+ evt.pageX = touch.pageX;
280
+ evt.pageY = touch.pageY;
281
+ this._dispatchEvent(evt);
282
+ }
283
+
284
+ if (this._dispatched) {
285
+ e.preventDefault();
286
+ e.stopPropagation();
287
+ this._dispatched = false;
288
+ }
289
+ }
290
+
291
+ private _handleTouchEnd(targetWindow: Window, e: ITouchEvent): void {
292
+ const timestamp = Date.now();
293
+
294
+ const activeTouchCount = Object.keys(this._activeTouches).length;
295
+
296
+ for (let i = 0, len = e.changedTouches.length; i < len; i++) {
297
+
298
+ const touch = e.changedTouches.item(i);
299
+
300
+ if (!this._activeTouches.hasOwnProperty(String(touch.identifier))) {
301
+ console.warn('move of an UNKNOWN touch', touch);
302
+ continue;
303
+ }
304
+
305
+ const data = this._activeTouches[touch.identifier];
306
+ const holdTime = Date.now() - data.initialTimeStamp;
307
+
308
+ if (holdTime < Gesture._holdDelay
309
+ && Math.abs(data.initialPageX - tail(data.rollingPageX)!) < 30
310
+ && Math.abs(data.initialPageY - tail(data.rollingPageY)!) < 30) {
311
+
312
+ const evt = this._newGestureEvent(EventType.TAP, data.initialTarget);
313
+ evt.pageX = tail(data.rollingPageX)!;
314
+ evt.pageY = tail(data.rollingPageY)!;
315
+ this._dispatchEvent(evt);
316
+
317
+ } else if (holdTime >= Gesture._holdDelay
318
+ && Math.abs(data.initialPageX - tail(data.rollingPageX)!) < 30
319
+ && Math.abs(data.initialPageY - tail(data.rollingPageY)!) < 30) {
320
+
321
+ const evt = this._newGestureEvent(EventType.CONTEXT_MENU, data.initialTarget);
322
+ evt.pageX = tail(data.rollingPageX)!;
323
+ evt.pageY = tail(data.rollingPageY)!;
324
+ this._dispatchEvent(evt);
325
+
326
+ } else if (activeTouchCount === 1) {
327
+ const finalX = tail(data.rollingPageX)!;
328
+ const finalY = tail(data.rollingPageY)!;
329
+
330
+ const deltaT = tail(data.rollingTimestamps)! - data.rollingTimestamps[0];
331
+ const deltaX = finalX - data.rollingPageX[0];
332
+ const deltaY = finalY - data.rollingPageY[0];
333
+
334
+ const dispatchTo = [...this._targets].filter(t => data.initialTarget instanceof Node && t.contains(data.initialTarget));
335
+ this._inertia(targetWindow, dispatchTo, timestamp,
336
+ Math.abs(deltaX) / deltaT,
337
+ deltaX > 0 ? 1 : -1,
338
+ finalX,
339
+ Math.abs(deltaY) / deltaT,
340
+ deltaY > 0 ? 1 : -1,
341
+ finalY
342
+ );
343
+ }
344
+
345
+
346
+ this._dispatchEvent(this._newGestureEvent(EventType.END, data.initialTarget));
347
+ delete this._activeTouches[touch.identifier];
348
+ }
349
+
350
+ if (this._dispatched) {
351
+ e.preventDefault();
352
+ e.stopPropagation();
353
+ this._dispatched = false;
354
+ }
355
+ }
356
+
357
+ private _newGestureEvent(type: string, initialTarget?: EventTarget): IGestureEvent {
358
+ const event = document.createEvent('CustomEvent') as unknown as IGestureEvent;
359
+ event.initEvent(type, false, true);
360
+ event.initialTarget = initialTarget;
361
+ event.tapCount = 0;
362
+ return event;
363
+ }
364
+
365
+ private _dispatchEvent(event: IGestureEvent): void {
366
+ if (event.type === EventType.TAP) {
367
+ const currentTime = (new Date()).getTime();
368
+ let setTapCount = 0;
369
+ if (currentTime - this._lastSetTapCountTime > Gesture._clearTapCountTime) {
370
+ setTapCount = 1;
371
+ } else {
372
+ setTapCount = 2;
373
+ }
374
+
375
+ this._lastSetTapCountTime = currentTime;
376
+ event.tapCount = setTapCount;
377
+ } else if (event.type === EventType.CHANGE || event.type === EventType.CONTEXT_MENU) {
378
+ this._lastSetTapCountTime = 0;
379
+ }
380
+
381
+ if (event.initialTarget instanceof Node) {
382
+ for (const ignoreTarget of this._ignoreTargets) {
383
+ if (ignoreTarget.contains(event.initialTarget)) {
384
+ return;
385
+ }
386
+ }
387
+
388
+ const targets: [number, HTMLElement][] = [];
389
+ for (const target of this._targets) {
390
+ if (target.contains(event.initialTarget)) {
391
+ let depth = 0;
392
+ let now: Node | null = event.initialTarget;
393
+ while (now && now !== target) {
394
+ depth++;
395
+ now = now.parentElement;
396
+ }
397
+ targets.push([depth, target]);
398
+ }
399
+ }
400
+
401
+ targets.sort((a, b) => a[0] - b[0]);
402
+
403
+ for (const [, target] of targets) {
404
+ target.dispatchEvent(event);
405
+ this._dispatched = true;
406
+ }
407
+ }
408
+ }
409
+
410
+ private _inertia(targetWindow: Window, dispatchTo: ReadonlyArray<EventTarget>, t1: number, vX: number, dirX: number, x: number, vY: number, dirY: number, y: number): void {
411
+ this._handle = DomUtils.scheduleAtNextAnimationFrame(targetWindow, () => {
412
+ const now = Date.now();
413
+
414
+ const deltaT = now - t1;
415
+ let deltaPosX = 0;
416
+ let deltaPosY = 0;
417
+ let stopped = true;
418
+
419
+ vX += Gesture._scrollFriction * deltaT;
420
+ vY += Gesture._scrollFriction * deltaT;
421
+
422
+ if (vX > 0) {
423
+ stopped = false;
424
+ deltaPosX = dirX * vX * deltaT;
425
+ }
426
+
427
+ if (vY > 0) {
428
+ stopped = false;
429
+ deltaPosY = dirY * vY * deltaT;
430
+ }
431
+
432
+ const evt = this._newGestureEvent(EventType.CHANGE);
433
+ evt.translationX = deltaPosX;
434
+ evt.translationY = deltaPosY;
435
+ dispatchTo.forEach(d => d.dispatchEvent(evt));
436
+
437
+ if (!stopped) {
438
+ this._inertia(targetWindow, dispatchTo, now, vX, dirX, x + deltaPosX, vY, dirY, y + deltaPosY);
439
+ }
440
+ });
441
+ }
442
+
443
+ private _handleTouchMove(e: ITouchEvent): void {
444
+ const timestamp = Date.now();
445
+
446
+ for (let i = 0, len = e.changedTouches.length; i < len; i++) {
447
+
448
+ const touch = e.changedTouches.item(i);
449
+
450
+ if (!this._activeTouches.hasOwnProperty(String(touch.identifier))) {
451
+ console.warn('end of an UNKNOWN touch', touch);
452
+ continue;
453
+ }
454
+
455
+ const data = this._activeTouches[touch.identifier];
456
+
457
+ const evt = this._newGestureEvent(EventType.CHANGE, data.initialTarget);
458
+ evt.translationX = touch.pageX - tail(data.rollingPageX)!;
459
+ evt.translationY = touch.pageY - tail(data.rollingPageY)!;
460
+ evt.pageX = touch.pageX;
461
+ evt.pageY = touch.pageY;
462
+ this._dispatchEvent(evt);
463
+
464
+ if (data.rollingPageX.length > 3) {
465
+ data.rollingPageX.shift();
466
+ data.rollingPageY.shift();
467
+ data.rollingTimestamps.shift();
468
+ }
469
+
470
+ data.rollingPageX.push(touch.pageX);
471
+ data.rollingPageY.push(touch.pageY);
472
+ data.rollingTimestamps.push(timestamp);
473
+ }
474
+
475
+ if (this._dispatched) {
476
+ e.preventDefault();
477
+ e.stopPropagation();
478
+ this._dispatched = false;
479
+ }
480
+ }
481
+ }
@@ -0,0 +1,143 @@
1
+ /*---------------------------------------------------------------------------------------------
2
+ * Copyright (c) Microsoft Corporation. All rights reserved.
3
+ * Licensed under the MIT License. See License.txt in the project root for license information.
4
+ *--------------------------------------------------------------------------------------------*/
5
+
6
+ import { AbstractScrollbar, ISimplifiedPointerEvent, IScrollbarHost } from './abstractScrollbar';
7
+ import { IScrollableElementResolvedOptions } from './scrollableElementOptions';
8
+ import { ScrollbarState } from './scrollbarState';
9
+ import { INewScrollPosition, Scrollable, ScrollbarVisibility, IScrollEvent } from './scrollable';
10
+ import type { ScrollbarArrow } from './scrollbarArrow';
11
+
12
+ export class VerticalScrollbar extends AbstractScrollbar {
13
+ private _arrowUp: ScrollbarArrow | undefined;
14
+ private _arrowDown: ScrollbarArrow | undefined;
15
+ private _arrowScrollDelta: number = 0;
16
+
17
+ constructor(scrollable: Scrollable, options: IScrollableElementResolvedOptions, host: IScrollbarHost) {
18
+ const scrollDimensions = scrollable.getScrollDimensions();
19
+ const scrollPosition = scrollable.getCurrentScrollPosition();
20
+ const hasArrows = options.verticalHasArrows;
21
+ super({
22
+ lazyRender: options.lazyRender,
23
+ host: host,
24
+ scrollbarState: new ScrollbarState(
25
+ (hasArrows ? options.verticalScrollbarSize : 0),
26
+ (options.vertical === ScrollbarVisibility.HIDDEN ? 0 : options.verticalScrollbarSize),
27
+ 0,
28
+ scrollDimensions.height,
29
+ scrollDimensions.scrollHeight,
30
+ scrollPosition.scrollTop
31
+ ),
32
+ visibility: options.vertical,
33
+ extraScrollbarClassName: 'xterm-vertical',
34
+ scrollable: scrollable,
35
+ scrollByPage: options.scrollByPage
36
+ });
37
+
38
+ this._setArrows(hasArrows, options.verticalScrollbarSize);
39
+
40
+ this._createSlider(0, Math.floor((options.verticalScrollbarSize - options.verticalSliderSize) / 2), options.verticalSliderSize, undefined);
41
+ }
42
+
43
+ protected _updateSlider(sliderSize: number, sliderPosition: number): void {
44
+ this.slider.setHeight(sliderSize);
45
+ this.slider.setTop(sliderPosition);
46
+ }
47
+
48
+ protected _renderDomNode(largeSize: number, smallSize: number): void {
49
+ this.domNode.setWidth(smallSize);
50
+ this.domNode.setHeight(largeSize);
51
+ this.domNode.setRight(0);
52
+ this.domNode.setTop(0);
53
+ }
54
+
55
+ public handleScroll(e: IScrollEvent): boolean {
56
+ this._shouldRender = this._handleElementScrollSize(e.scrollHeight) || this._shouldRender;
57
+ this._shouldRender = this._handleElementScrollPosition(e.scrollTop) || this._shouldRender;
58
+ this._shouldRender = this._handleElementSize(e.height) || this._shouldRender;
59
+ return this._shouldRender;
60
+ }
61
+
62
+ protected _pointerDownRelativePosition(offsetX: number, offsetY: number): number {
63
+ return offsetY;
64
+ }
65
+
66
+ protected _sliderPointerPosition(e: ISimplifiedPointerEvent): number {
67
+ return e.pageY;
68
+ }
69
+
70
+ protected _sliderOrthogonalPointerPosition(e: ISimplifiedPointerEvent): number {
71
+ return e.pageX;
72
+ }
73
+
74
+ protected _updateScrollbarSize(size: number): void {
75
+ this.slider.setWidth(size);
76
+ }
77
+
78
+ public writeScrollPosition(target: INewScrollPosition, scrollPosition: number): void {
79
+ target.scrollTop = scrollPosition;
80
+ }
81
+
82
+ private _arrowScroll(delta: number): void {
83
+ const currentPosition = this._scrollable.getCurrentScrollPosition();
84
+ this._scrollable.setScrollPositionNow({ scrollTop: currentPosition.scrollTop + delta });
85
+ }
86
+
87
+ private _setArrows(showArrows: boolean, size: number): void {
88
+ this._arrowScrollDelta = size;
89
+ if (!this._arrowUp || !this._arrowDown) {
90
+ const arrowDelta = 0;
91
+ this._arrowUp = this._createArrow({
92
+ className: 'xterm-scra xterm-arrow-up',
93
+ top: arrowDelta,
94
+ left: arrowDelta,
95
+ bgWidth: size,
96
+ bgHeight: size,
97
+ handleActivate: () => this._arrowScroll(-this._arrowScrollDelta)
98
+ });
99
+ this._arrowDown = this._createArrow({
100
+ className: 'xterm-scra xterm-arrow-down',
101
+ bottom: arrowDelta,
102
+ left: arrowDelta,
103
+ bgWidth: size,
104
+ bgHeight: size,
105
+ handleActivate: () => this._arrowScroll(this._arrowScrollDelta)
106
+ });
107
+ }
108
+
109
+ this._updateArrowSize(this._arrowUp, size);
110
+ this._updateArrowSize(this._arrowDown, size);
111
+
112
+ if (!this._arrowUp || !this._arrowDown) {
113
+ return;
114
+ }
115
+
116
+ const display = showArrows ? '' : 'none';
117
+ this._arrowUp.bgDomNode.style.display = display;
118
+ this._arrowUp.domNode.style.display = display;
119
+ this._arrowDown.bgDomNode.style.display = display;
120
+ this._arrowDown.domNode.style.display = display;
121
+ }
122
+
123
+ private _updateArrowSize(arrow: ScrollbarArrow | undefined, size: number): void {
124
+ if (!arrow) {
125
+ return;
126
+ }
127
+ arrow.bgDomNode.style.width = `${size}px`;
128
+ arrow.bgDomNode.style.height = `${size}px`;
129
+ arrow.domNode.style.width = `${size}px`;
130
+ arrow.domNode.style.height = `${size}px`;
131
+ }
132
+
133
+ public updateOptions(options: IScrollableElementResolvedOptions): void {
134
+ const arrowSize = options.verticalHasArrows ? options.verticalScrollbarSize : 0;
135
+ this._scrollbarState.setArrowSize(arrowSize);
136
+ this._setArrows(options.verticalHasArrows, options.verticalScrollbarSize);
137
+ this.updateScrollbarSize(options.vertical === ScrollbarVisibility.HIDDEN ? 0 : options.verticalScrollbarSize);
138
+ this._scrollbarState.setOppositeScrollbarSize(0);
139
+ this._visibilityController.setVisibility(options.vertical);
140
+ this._scrollByPage = options.scrollByPage;
141
+ }
142
+
143
+ }
@@ -0,0 +1,23 @@
1
+ /*---------------------------------------------------------------------------------------------
2
+ * Copyright (c) Microsoft Corporation. All rights reserved.
3
+ * Licensed under the MIT License. See License.txt in the project root for license information.
4
+ *--------------------------------------------------------------------------------------------*/
5
+
6
+ import * as dom from '../Dom';
7
+ import { IMouseEvent, StandardMouseEvent } from './mouseEvent';
8
+ import { Disposable } from 'common/Lifecycle';
9
+
10
+ export abstract class Widget extends Disposable {
11
+
12
+ protected _onclick(domNode: HTMLElement, listener: (e: IMouseEvent) => void): void {
13
+ this._register(dom.addDisposableListener(domNode, dom.eventType.CLICK, (e: MouseEvent) => listener(new StandardMouseEvent(dom.getWindow(domNode), e))));
14
+ }
15
+
16
+ protected _onmouseover(domNode: HTMLElement, listener: (e: IMouseEvent) => void): void {
17
+ this._register(dom.addDisposableListener(domNode, dom.eventType.MOUSE_OVER, (e: MouseEvent) => listener(new StandardMouseEvent(dom.getWindow(domNode), e))));
18
+ }
19
+
20
+ protected _onmouseleave(domNode: HTMLElement, listener: (e: IMouseEvent) => void): void {
21
+ this._register(dom.addDisposableListener(domNode, dom.eventType.MOUSE_LEAVE, (e: MouseEvent) => listener(new StandardMouseEvent(dom.getWindow(domNode), e))));
22
+ }
23
+ }
@@ -5,8 +5,8 @@
5
5
 
6
6
  import { IOptionsService } from 'common/services/Services';
7
7
  import { ICharSizeService } from 'browser/services/Services';
8
- import { Disposable } from 'vs/base/common/lifecycle';
9
- import { Emitter } from 'vs/base/common/event';
8
+ import { Disposable } from 'common/Lifecycle';
9
+ import { Emitter } from 'common/Event';
10
10
 
11
11
  export class CharSizeService extends Disposable implements ICharSizeService {
12
12
  public serviceBrand: undefined;
@@ -4,16 +4,16 @@
4
4
  */
5
5
 
6
6
  import { ICoreBrowserService } from './Services';
7
- import { Emitter, Event } from 'vs/base/common/event';
8
- import { addDisposableListener } from 'vs/base/browser/dom';
9
- import { Disposable, MutableDisposable, toDisposable } from 'vs/base/common/lifecycle';
7
+ import { Emitter, EventUtils } from 'common/Event';
8
+ import { addDisposableListener } from 'browser/Dom';
9
+ import { Disposable, MutableDisposable, toDisposable } from 'common/Lifecycle';
10
10
 
11
11
  export class CoreBrowserService extends Disposable implements ICoreBrowserService {
12
12
  public serviceBrand: undefined;
13
13
 
14
14
  private _isFocused = false;
15
15
  private _cachedIsFocused: boolean | undefined = undefined;
16
- private _screenDprMonitor = this._register(new ScreenDprMonitor(this._window));
16
+ private _screenDprMonitor: ScreenDprMonitor;
17
17
 
18
18
  private readonly _onDprChange = this._register(new Emitter<number>());
19
19
  public readonly onDprChange = this._onDprChange.event;
@@ -27,9 +27,11 @@ export class CoreBrowserService extends Disposable implements ICoreBrowserServic
27
27
  ) {
28
28
  super();
29
29
 
30
+ this._screenDprMonitor = this._register(new ScreenDprMonitor(this._window));
31
+
30
32
  // Monitor device pixel ratio
31
33
  this._register(this.onWindowChange(w => this._screenDprMonitor.setWindow(w)));
32
- this._register(Event.forward(this._screenDprMonitor.onDprChange, this._onDprChange));
34
+ this._register(EventUtils.forward(this._screenDprMonitor.onDprChange, this._onDprChange));
33
35
 
34
36
  this._register(addDisposableListener(this._textarea, 'focus', () => this._isFocused = true));
35
37
  this._register(addDisposableListener(this._textarea, 'blur', () => this._isFocused = false));