mol_plot_all 1.2.132 → 1.2.136

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.
package/node.esm.js CHANGED
@@ -3321,11 +3321,21 @@ var $;
3321
3321
  return val;
3322
3322
  return null;
3323
3323
  }
3324
+ draw_start(event) {
3325
+ if (event !== undefined)
3326
+ return event;
3327
+ return null;
3328
+ }
3324
3329
  draw(event) {
3325
3330
  if (event !== undefined)
3326
3331
  return event;
3327
3332
  return null;
3328
3333
  }
3334
+ draw_end(event) {
3335
+ if (event !== undefined)
3336
+ return event;
3337
+ return null;
3338
+ }
3329
3339
  style() {
3330
3340
  return {
3331
3341
  ...super.style(),
@@ -3339,7 +3349,7 @@ var $;
3339
3349
  pointerdown: (event) => this.event_start(event),
3340
3350
  pointermove: (event) => this.event_move(event),
3341
3351
  pointerup: (event) => this.event_end(event),
3342
- pointerleave: (event) => this.event_end(event),
3352
+ pointerleave: (event) => this.event_leave(event),
3343
3353
  wheel: (event) => this.event_wheel(event)
3344
3354
  };
3345
3355
  }
@@ -3358,6 +3368,11 @@ var $;
3358
3368
  return event;
3359
3369
  return null;
3360
3370
  }
3371
+ event_leave(event) {
3372
+ if (event !== undefined)
3373
+ return event;
3374
+ return null;
3375
+ }
3361
3376
  event_wheel(event) {
3362
3377
  if (event !== undefined)
3363
3378
  return event;
@@ -3427,9 +3442,15 @@ var $;
3427
3442
  __decorate([
3428
3443
  $.$mol_mem
3429
3444
  ], $mol_touch.prototype, "swipe_to_top", null);
3445
+ __decorate([
3446
+ $.$mol_mem
3447
+ ], $mol_touch.prototype, "draw_start", null);
3430
3448
  __decorate([
3431
3449
  $.$mol_mem
3432
3450
  ], $mol_touch.prototype, "draw", null);
3451
+ __decorate([
3452
+ $.$mol_mem
3453
+ ], $mol_touch.prototype, "draw_end", null);
3433
3454
  __decorate([
3434
3455
  $.$mol_mem
3435
3456
  ], $mol_touch.prototype, "event_start", null);
@@ -3439,6 +3460,9 @@ var $;
3439
3460
  __decorate([
3440
3461
  $.$mol_mem
3441
3462
  ], $mol_touch.prototype, "event_end", null);
3463
+ __decorate([
3464
+ $.$mol_mem
3465
+ ], $mol_touch.prototype, "event_leave", null);
3442
3466
  __decorate([
3443
3467
  $.$mol_mem
3444
3468
  ], $mol_touch.prototype, "event_wheel", null);
@@ -3462,7 +3486,7 @@ var $;
3462
3486
  const events = this.pointer_events();
3463
3487
  const touches = events.filter(e => e.pointerType === 'touch');
3464
3488
  const pens = events.filter(e => e.pointerType === 'pen');
3465
- const mouses = events.filter(e => e.pointerType === 'mouse');
3489
+ const mouses = events.filter(e => !e.pointerType || e.pointerType === 'mouse');
3466
3490
  const choosen = touches.length ? touches : pens.length ? pens : mouses;
3467
3491
  return new $.$mol_vector(...choosen.map(event => this.event_coords(event)));
3468
3492
  }
@@ -3484,11 +3508,17 @@ var $;
3484
3508
  }
3485
3509
  event_eat(event) {
3486
3510
  if (event instanceof PointerEvent) {
3487
- const events = this.pointer_events().filter(e => e.pointerId !== event.pointerId);
3488
- if (event.type !== 'pointerleave')
3511
+ const events = this.pointer_events()
3512
+ .filter(e => e instanceof PointerEvent)
3513
+ .filter(e => e.pointerId !== event.pointerId);
3514
+ if (event.type !== 'pointerup' && event.type !== 'pointerleave')
3489
3515
  events.push(event);
3490
3516
  this.pointer_events(events);
3491
- if (this.allow_zoom() && events.filter(e => e.pointerType === 'touch').length === 2) {
3517
+ const touch_count = events.filter(e => e.pointerType === 'touch').length;
3518
+ if (this.allow_zoom() && touch_count === 2) {
3519
+ return this.action_type('zoom');
3520
+ }
3521
+ if (this.action_type() === 'zoom' && touch_count === 1) {
3492
3522
  return this.action_type('zoom');
3493
3523
  }
3494
3524
  let button;
@@ -3508,6 +3538,7 @@ var $;
3508
3538
  return this.action_type('');
3509
3539
  }
3510
3540
  if (event instanceof WheelEvent) {
3541
+ this.pointer_events([event]);
3511
3542
  if (event.ctrlKey)
3512
3543
  return this.action_type('zoom');
3513
3544
  return this.action_type('pan');
@@ -3521,10 +3552,12 @@ var $;
3521
3552
  const action_type = this.event_eat(event);
3522
3553
  if (!action_type)
3523
3554
  return;
3524
- if (action_type === 'draw')
3525
- return;
3526
3555
  const coords = this.pointer_coords();
3527
3556
  this.start_pos(coords.center());
3557
+ if (action_type === 'draw') {
3558
+ this.draw_start(event);
3559
+ return;
3560
+ }
3528
3561
  this.start_distance(coords.distance());
3529
3562
  this.start_zoom(this.zoom());
3530
3563
  }
@@ -3536,14 +3569,17 @@ var $;
3536
3569
  return;
3537
3570
  const start_pan = this.start_pan();
3538
3571
  const action_type = this.event_eat(event);
3572
+ const start_pos = this.start_pos();
3539
3573
  let pos = this.pointer_center();
3540
3574
  if (!action_type)
3541
3575
  return;
3542
3576
  if (action_type === 'draw') {
3543
- this.draw(event);
3577
+ const distance = new $.$mol_vector(start_pos, pos).distance();
3578
+ if (distance >= 4) {
3579
+ this.draw(event);
3580
+ }
3544
3581
  return;
3545
3582
  }
3546
- const start_pos = this.start_pos();
3547
3583
  if (!start_pos)
3548
3584
  return;
3549
3585
  if (action_type === 'pan') {
@@ -3592,12 +3628,15 @@ var $;
3592
3628
  }
3593
3629
  }
3594
3630
  event_end(event) {
3631
+ const action = this.action_type();
3632
+ if (action === 'draw') {
3633
+ this.draw_end(event);
3634
+ }
3635
+ this.event_leave(event);
3636
+ }
3637
+ event_leave(event) {
3595
3638
  this.event_eat(event);
3596
3639
  this.dom_node().releasePointerCapture(event.pointerId);
3597
- if (!this.start_pos()) {
3598
- this.draw(event);
3599
- return;
3600
- }
3601
3640
  this.start_pos(null);
3602
3641
  }
3603
3642
  swipe_left(event) {
@@ -3840,11 +3879,21 @@ var $;
3840
3879
  allow_zoom() {
3841
3880
  return true;
3842
3881
  }
3882
+ draw_start(event) {
3883
+ if (event !== undefined)
3884
+ return event;
3885
+ return null;
3886
+ }
3843
3887
  draw(event) {
3844
3888
  if (event !== undefined)
3845
3889
  return event;
3846
3890
  return null;
3847
3891
  }
3892
+ draw_end(event) {
3893
+ if (event !== undefined)
3894
+ return event;
3895
+ return null;
3896
+ }
3848
3897
  cursor_position() {
3849
3898
  return this.Touch().pointer_center();
3850
3899
  }
@@ -3861,7 +3910,9 @@ var $;
3861
3910
  obj.allow_draw = () => this.allow_draw();
3862
3911
  obj.allow_pan = () => this.allow_pan();
3863
3912
  obj.allow_zoom = () => this.allow_zoom();
3913
+ obj.draw_start = (event) => this.draw_start(event);
3864
3914
  obj.draw = (event) => this.draw(event);
3915
+ obj.draw_end = (event) => this.draw_end(event);
3865
3916
  return obj;
3866
3917
  }
3867
3918
  }
@@ -3943,9 +3994,15 @@ var $;
3943
3994
  __decorate([
3944
3995
  $.$mol_mem
3945
3996
  ], $mol_plot_pane.prototype, "zoom", null);
3997
+ __decorate([
3998
+ $.$mol_mem
3999
+ ], $mol_plot_pane.prototype, "draw_start", null);
3946
4000
  __decorate([
3947
4001
  $.$mol_mem
3948
4002
  ], $mol_plot_pane.prototype, "draw", null);
4003
+ __decorate([
4004
+ $.$mol_mem
4005
+ ], $mol_plot_pane.prototype, "draw_end", null);
3949
4006
  __decorate([
3950
4007
  $.$mol_mem
3951
4008
  ], $mol_plot_pane.prototype, "Touch", null);