devexpress-diagram 2.1.43 → 2.1.44

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.
@@ -1,9 +1,9 @@
1
1
  /*!
2
2
  * DevExpress Diagram (dx-diagram)
3
- * Version: 2.1.43
4
- * Build date: Wed Dec 29 2021
3
+ * Version: 2.1.44
4
+ * Build date: Wed Jan 12 2022
5
5
  *
6
- * Copyright (c) 2012 - 2021 Developer Express Inc. ALL RIGHTS RESERVED
6
+ * Copyright (c) 2012 - 2022 Developer Express Inc. ALL RIGHTS RESERVED
7
7
  * Read about DevExpress licensing here: https://www.devexpress.com/Support/EULAs
8
8
  */
9
9
  .dxdi-control {
@@ -1,9 +1,9 @@
1
1
  /*!
2
2
  * DevExpress Diagram (dx-diagram)
3
- * Version: 2.1.43
4
- * Build date: Wed Dec 29 2021
3
+ * Version: 2.1.44
4
+ * Build date: Wed Jan 12 2022
5
5
  *
6
- * Copyright (c) 2012 - 2021 Developer Express Inc. ALL RIGHTS RESERVED
6
+ * Copyright (c) 2012 - 2022 Developer Express Inc. ALL RIGHTS RESERVED
7
7
  * Read about DevExpress licensing here: https://www.devexpress.com/Support/EULAs
8
8
  */
9
9
  (function webpackUniversalModuleDefinition(root, factory) {
@@ -3912,11 +3912,10 @@ var DiagramMouseEventBase = /** @class */ (function (_super) {
3912
3912
  exports.DiagramMouseEventBase = DiagramMouseEventBase;
3913
3913
  var DiagramMouseEvent = /** @class */ (function (_super) {
3914
3914
  __extends(DiagramMouseEvent, _super);
3915
- function DiagramMouseEvent(modifiers, button, pagePoint, offsetPoint, modelPoint, source, touches, pointerType) {
3915
+ function DiagramMouseEvent(modifiers, button, offsetPoint, modelPoint, source, touches, pointerType) {
3916
3916
  if (touches === void 0) { touches = []; }
3917
3917
  var _this = _super.call(this, modifiers, offsetPoint, modelPoint, source) || this;
3918
3918
  _this.button = button;
3919
- _this.pagePoint = pagePoint;
3920
3919
  _this.touches = touches;
3921
3920
  _this.pointerType = pointerType;
3922
3921
  _this.scrollX = 0;
@@ -3944,13 +3943,6 @@ var DiagramMouseEvent = /** @class */ (function (_super) {
3944
3943
  enumerable: false,
3945
3944
  configurable: true
3946
3945
  });
3947
- DiagramMouseEvent.prototype.clone = function () {
3948
- return new DiagramMouseEvent(this.modifiers, this.button, this.pagePoint.clone(), this.offsetPoint.clone(), this.modelPoint.clone(), this.source, this.cloneTouches(), this.pointerType);
3949
- };
3950
- DiagramMouseEvent.prototype.cloneTouches = function () {
3951
- if (common_1.isDefined(this.touches))
3952
- return this.touches.map(function (t) { return new DiagramMouseEventTouch(t.offsetPoint.clone(), t.modelPoint.clone()); });
3953
- };
3954
3946
  return DiagramMouseEvent;
3955
3947
  }(DiagramMouseEventBase));
3956
3948
  exports.DiagramMouseEvent = DiagramMouseEvent;
@@ -17870,10 +17862,6 @@ var MouseHandlerDragDiagramItemStateBase = /** @class */ (function (_super) {
17870
17862
  };
17871
17863
  MouseHandlerDragDiagramItemStateBase.prototype.onMouseMove = function (evt) {
17872
17864
  this.mouseMoveEvent = evt;
17873
- if (evt.button !== Event_1.MouseButton.Left) {
17874
- this.cancelChanges();
17875
- this.handler.switchToDefaultState();
17876
- }
17877
17865
  if (!this.canApplyChangesOnMouseMove(this.startPoint, evt.modelPoint))
17878
17866
  return;
17879
17867
  if (this.handler.canCopySelectedItems(evt))
@@ -17887,6 +17875,8 @@ var MouseHandlerDragDiagramItemStateBase = /** @class */ (function (_super) {
17887
17875
  this.onApplyChanges(evt);
17888
17876
  this.onAfterApplyChanges();
17889
17877
  this.updateContainers(evt);
17878
+ if (evt.button !== Event_1.MouseButton.Left)
17879
+ this.handler.switchToDefaultState();
17890
17880
  };
17891
17881
  MouseHandlerDragDiagramItemStateBase.prototype.updateContainers = function (evt) {
17892
17882
  this.visualizerManager.setExtensionLines(this.selection.getSelectedShapes(false, true));
@@ -30662,9 +30652,6 @@ var EventManager = /** @class */ (function () {
30662
30652
  this.control.captureFocus();
30663
30653
  }
30664
30654
  };
30665
- EventManager.prototype.onDragOverFromToolbox = function (evt) {
30666
- this.mouseHandler.onMouseMove(evt);
30667
- };
30668
30655
  EventManager.prototype.onDragEndFromToolbox = function (evt) {
30669
30656
  if (this.draggingEvent) {
30670
30657
  delete this.draggingEvent;
@@ -34380,58 +34367,57 @@ var RenderManager = /** @class */ (function () {
34380
34367
  this.selection.clear();
34381
34368
  };
34382
34369
  RenderManager.prototype.onMouseEnter = function (evt) {
34383
- var diagramEvt = this.createDiagramMouseEvent(evt, this.getEventSourceByEvent(evt));
34370
+ var diagramEvt = this.createInnerDiagramMouseEvent(evt, this.getEventSourceByEvent(evt));
34384
34371
  this.events.onMouseEnter(diagramEvt);
34385
34372
  this.preventEvent(evt, diagramEvt);
34386
34373
  };
34387
34374
  RenderManager.prototype.onMouseLeave = function (evt) {
34388
- var diagramEvt = this.createDiagramMouseEvent(evt, this.getEventSourceByEvent(evt));
34375
+ var diagramEvt = this.createInnerDiagramMouseEvent(evt, this.getEventSourceByEvent(evt));
34389
34376
  this.stopScrolling();
34390
34377
  this.events.onMouseLeave(diagramEvt);
34391
34378
  this.preventEvent(evt, diagramEvt);
34392
34379
  };
34393
34380
  RenderManager.prototype.onMouseDown = function (evt) {
34394
34381
  this.lastDownMouseElement = this.getEventSourceByEvent(evt);
34395
- this.lastDownMouseEvent = this.createDiagramMouseEvent(evt, this.lastDownMouseElement);
34382
+ this.lastDownMouseEvent = this.createInnerDiagramMouseEvent(evt, this.lastDownMouseElement);
34396
34383
  this.onMouseDownCore(this.lastDownMouseEvent);
34397
34384
  this.preventEvent(evt, this.lastDownMouseEvent);
34398
34385
  };
34399
34386
  RenderManager.prototype.onTouchDown = function (evt) {
34400
34387
  this.lastDownMouseElement = this.getEventSourceByEvent(evt);
34401
- this.lastDownMouseEvent = this.createDiagramMouseEvent(evt, this.lastDownMouseElement);
34388
+ this.lastDownMouseEvent = this.createInnerDiagramMouseEvent(evt, this.lastDownMouseElement);
34402
34389
  this.onMouseDownCore(this.lastDownMouseEvent);
34403
34390
  this.emulateLongTouchEvent(this.lastDownMouseEvent);
34404
34391
  this.preventEvent(evt, this.lastDownMouseEvent);
34405
34392
  };
34406
34393
  RenderManager.prototype.onMouseMove = function (evt) {
34407
- var diagramEvt = this.createDiagramMouseEvent(evt, this.getEventSourceByEvent(evt));
34408
- this.onMoveCore(diagramEvt);
34394
+ this.onBeforeMouseMove();
34395
+ var diagramEvt = common_1.isDefined(this.toolboxDraggingObject) ?
34396
+ this.onDragFromToolbox(evt, this.getEventSourceByEvent(evt)) :
34397
+ this.onInnerMove(evt, this.getEventSourceByEvent(evt));
34409
34398
  this.preventEvent(evt, diagramEvt);
34410
34399
  };
34411
34400
  RenderManager.prototype.onTouchMove = function (evt) {
34412
- var diagramEvt = this.createDiagramMouseEvent(evt, this.getEventSourceByPosition(evt));
34413
- this.onMoveCore(diagramEvt);
34414
- this.preventEvent(evt, diagramEvt);
34415
- if (this.lastDownMouseEvent) {
34416
- var offsetPoint = diagramEvt.actualOffsetPoint;
34417
- var startOffsetPoint = this.lastDownMouseEvent.actualOffsetPoint;
34418
- if (startOffsetPoint && offsetPoint)
34419
- if ((Math.abs(startOffsetPoint.x - offsetPoint.x) > this.touchPositionLimit ||
34420
- Math.abs(startOffsetPoint.y - offsetPoint.y) > this.touchPositionLimit))
34421
- this.resetTimers();
34401
+ this.onBeforeMouseMove();
34402
+ if (common_1.isDefined(this.toolboxDraggingObject))
34403
+ this.preventEvent(evt, this.onDragFromToolbox(evt, this.getEventSourceByPosition(evt)));
34404
+ else {
34405
+ var diagramEvt = this.onInnerMove(evt, this.getEventSourceByPosition(evt));
34406
+ this.onAfterTouchMove(diagramEvt);
34407
+ this.preventEvent(evt, diagramEvt);
34422
34408
  }
34423
34409
  };
34424
34410
  RenderManager.prototype.onMouseUp = function (evt) {
34425
34411
  this.stopScrolling();
34426
34412
  if (common_1.isDefined(this.lastDownMouseEvent)) {
34427
- var diagramEvt = this.createDiagramMouseEvent(evt, this.lastDownMouseElement);
34413
+ var diagramEvt = this.createInnerDiagramMouseEvent(evt, this.lastDownMouseElement);
34428
34414
  this.preventDiagramEventByImage(this.lastDownMouseElement, diagramEvt);
34429
34415
  this.events.onMouseUp(diagramEvt);
34430
34416
  this.emulateClickEvents(diagramEvt);
34431
34417
  this.preventEvent(evt, diagramEvt);
34432
34418
  }
34433
34419
  else {
34434
- var diagramEvt = this.createDiagramMouseEvent(evt, this.getEventSourceByEvent(evt));
34420
+ var diagramEvt = this.createInnerDiagramMouseEvent(evt, this.getEventSourceByEvent(evt));
34435
34421
  this.events.onMouseUp(diagramEvt);
34436
34422
  this.resetTimers();
34437
34423
  this.preventEvent(evt, diagramEvt);
@@ -34513,12 +34499,12 @@ var RenderManager = /** @class */ (function () {
34513
34499
  var scrollContainer = this.getScrollContainer();
34514
34500
  return new point_1.Point(dom_1.DomUtils.getAbsolutePositionX(scrollContainer) + pos.x, dom_1.DomUtils.getAbsolutePositionY(scrollContainer) + pos.y);
34515
34501
  };
34516
- RenderManager.prototype.hasDiagramPoint = function (evt) {
34517
- if (!this.diagramRectangle)
34502
+ RenderManager.prototype.hasViewPoint = function (pagePoint) {
34503
+ if (!this.viewRectangle)
34518
34504
  return false;
34519
- var x = evt.pagePoint.x - this.diagramRectangle.x;
34520
- var y = evt.pagePoint.y - this.diagramRectangle.y;
34521
- return x >= 0 && y >= 0 && x <= this.diagramRectangle.width && y <= this.diagramRectangle.height;
34505
+ var x = pagePoint.x - this.viewRectangle.x;
34506
+ var y = pagePoint.y - this.viewRectangle.y;
34507
+ return x >= 0 && y >= 0 && x <= this.viewRectangle.width && y <= this.viewRectangle.height;
34522
34508
  };
34523
34509
  RenderManager.prototype.attachEvents = function () {
34524
34510
  this.onMouseWheelHandler = this.onMouseWheel.bind(this);
@@ -34549,57 +34535,65 @@ var RenderManager = /** @class */ (function () {
34549
34535
  this.captureFocus(this.events.canFinishTextEditing());
34550
34536
  this.preventDiagramEvent(evt);
34551
34537
  };
34552
- RenderManager.prototype.onMoveCore = function (evt) {
34553
- if (!common_1.isDefined(this.diagramRectangle))
34554
- this.diagramRectangle = this.createDiagramRectangle();
34538
+ RenderManager.prototype.onBeforeMouseMove = function () {
34539
+ if (this.isStartedDrag)
34540
+ return;
34541
+ if (!common_1.isDefined(this.viewRectangle))
34542
+ this.viewRectangle = this.createViewRectangle();
34555
34543
  if (!common_1.isDefined(this.toolboxDraggingObject))
34556
34544
  this.toolboxDraggingObject = this.events.getToolboxDraggingObject();
34557
- if (common_1.isDefined(this.toolboxDraggingObject))
34558
- this.onDragFromToolbox(evt);
34559
- else
34560
- this.onInnerMove(evt);
34561
34545
  };
34562
- RenderManager.prototype.onDragFromToolbox = function (evt) {
34546
+ RenderManager.prototype.onAfterTouchMove = function (diagramEvt) {
34547
+ if (this.lastDownMouseEvent) {
34548
+ var offsetPoint = diagramEvt.actualOffsetPoint;
34549
+ var startOffsetPoint = this.lastDownMouseEvent.actualOffsetPoint;
34550
+ if (startOffsetPoint && offsetPoint)
34551
+ if ((Math.abs(startOffsetPoint.x - offsetPoint.x) > this.touchPositionLimit ||
34552
+ Math.abs(startOffsetPoint.y - offsetPoint.y) > this.touchPositionLimit))
34553
+ this.resetTimers();
34554
+ }
34555
+ };
34556
+ RenderManager.prototype.onDragFromToolbox = function (evt, element) {
34563
34557
  var _this = this;
34564
- if (!common_1.isDefined(evt.source) || evt.source.type <= 1)
34565
- evt.source = new Event_1.MouseEventSource(this.getMouseEventElementTypeFromToolbox(evt));
34566
- if (evt.button !== Event_1.MouseButton.Left) {
34558
+ if (!Utils_1.isLeftButtonPressed(evt)) {
34567
34559
  this.stopScrolling();
34568
- this.events.onDragEndFromToolbox(evt);
34560
+ var diagramEvt = this.createDiagramMouseEventFromToolbox(evt, element);
34561
+ this.events.onDragEndFromToolbox(diagramEvt);
34569
34562
  this.resetTimers();
34570
34563
  this.clearDrag();
34571
- return;
34564
+ return diagramEvt;
34572
34565
  }
34573
34566
  if (this.isStartedDrag) {
34574
- this.continueScrolling(evt, function () { return _this.events.onDragOverFromToolbox(evt); });
34575
- this.events.onDragOverFromToolbox(evt);
34576
- return;
34567
+ this.continueScrolling(evt, function () { return _this.onMouseMoveCore(_this.createDiagramMouseEventFromToolbox(evt, element)); });
34568
+ var diagramEvt = this.createDiagramMouseEventFromToolbox(evt, element);
34569
+ this.onMouseMoveCore(diagramEvt);
34570
+ return diagramEvt;
34577
34571
  }
34578
34572
  this.isStartedDrag = true;
34579
34573
  setTimeout(function () { return _this.startScrolling(); }, START_SCROLLING_TIMEOUT);
34580
34574
  this.events.onDragStartFromToolbox(this.toolboxDraggingObject.evt);
34581
34575
  };
34582
- RenderManager.prototype.onInnerMove = function (evt) {
34576
+ RenderManager.prototype.onInnerMove = function (evt, element) {
34583
34577
  var _this = this;
34584
- if (!common_1.isDefined(this.lastDownMouseEvent)) {
34578
+ if (!common_1.isDefined(this.lastDownMouseEvent))
34585
34579
  this.stopScrolling();
34586
- this.events.onMouseMove(evt);
34587
- return;
34588
- }
34589
- if (!this.isStartedDrag) {
34580
+ else if (!this.isStartedDrag) {
34590
34581
  this.isStartedDrag = true;
34591
34582
  setTimeout(function () { return _this.startScrolling(); }, START_SCROLLING_TIMEOUT);
34592
- this.events.onMouseMove(evt);
34593
- return;
34594
34583
  }
34595
- if (evt.button === Event_1.MouseButton.Left) {
34596
- this.continueScrolling(evt, function () { return _this.events.onMouseMove(evt); });
34597
- this.events.onMouseMove(evt);
34598
- return;
34584
+ else if (Utils_1.isLeftButtonPressed(evt))
34585
+ this.continueScrolling(evt, function () { return _this.onMouseMoveCore(_this.createInnerDiagramMouseEvent(evt, element)); });
34586
+ else {
34587
+ this.stopScrolling();
34588
+ this.resetTimers();
34589
+ this.clearDrag();
34599
34590
  }
34600
- this.stopScrolling();
34601
- this.resetTimers();
34602
- this.clearDrag();
34591
+ var diagramEvt = this.createInnerDiagramMouseEvent(evt, element);
34592
+ this.onMouseMoveCore(diagramEvt);
34593
+ return diagramEvt;
34594
+ };
34595
+ RenderManager.prototype.onMouseMoveCore = function (evt) {
34596
+ this.events.onMouseMove(evt);
34603
34597
  };
34604
34598
  RenderManager.prototype.emulateLongTouchEvent = function (evt) {
34605
34599
  var _this = this;
@@ -34636,7 +34630,7 @@ var RenderManager = /** @class */ (function () {
34636
34630
  delete this.lastDownMouseEvent;
34637
34631
  delete this.lastDownMouseElement;
34638
34632
  delete this.toolboxDraggingObject;
34639
- delete this.diagramRectangle;
34633
+ delete this.viewRectangle;
34640
34634
  delete this.isStartedDrag;
34641
34635
  };
34642
34636
  RenderManager.prototype.resetTimers = function () {
@@ -34671,7 +34665,7 @@ var RenderManager = /** @class */ (function () {
34671
34665
  evt.preventDefault = true;
34672
34666
  };
34673
34667
  RenderManager.prototype.preventEvent = function (evt, diagramEvt) {
34674
- diagramEvt.preventEvent(evt);
34668
+ diagramEvt && diagramEvt.preventEvent(evt);
34675
34669
  };
34676
34670
  RenderManager.prototype.startScrolling = function () {
34677
34671
  this.autoScroll.startScrolling(this.svgElement);
@@ -34687,17 +34681,17 @@ var RenderManager = /** @class */ (function () {
34687
34681
  if (can)
34688
34682
  this.input.captureFocus();
34689
34683
  };
34690
- RenderManager.prototype.createDiagramRectangle = function () {
34684
+ RenderManager.prototype.createViewRectangle = function () {
34691
34685
  var scrollContainer = this.getScrollContainer();
34692
34686
  var size = this.scroll.getSize();
34693
34687
  return new rectangle_1.Rectangle(dom_1.DomUtils.getAbsolutePositionX(scrollContainer), dom_1.DomUtils.getAbsolutePositionY(scrollContainer), size.width, size.height);
34694
34688
  };
34695
34689
  RenderManager.prototype.createRelativePoint = function (evt) {
34696
- var pagePoint = evt.pagePoint;
34697
- return new point_1.Point(pagePoint.x - this.diagramRectangle.x, pagePoint.y - this.diagramRectangle.y);
34690
+ var pagePoint = this.createPagePoint(evt);
34691
+ return new point_1.Point(pagePoint.x - this.viewRectangle.x, pagePoint.y - this.viewRectangle.y);
34698
34692
  };
34699
- RenderManager.prototype.getMouseEventElementTypeFromToolbox = function (evt) {
34700
- if (this.hasDiagramPoint(evt) && this.toolboxDraggingObject.isLeavedToolbox(evt.offsetPoint))
34693
+ RenderManager.prototype.getMouseEventElementTypeFromToolbox = function (pagePoint, offsetPoint) {
34694
+ if (this.hasViewPoint(pagePoint) && this.toolboxDraggingObject.isLeavedToolbox(offsetPoint))
34701
34695
  return Event_1.MouseEventElementType.Document;
34702
34696
  return Event_1.MouseEventElementType.Undefined;
34703
34697
  };
@@ -34710,12 +34704,30 @@ var RenderManager = /** @class */ (function () {
34710
34704
  RenderManager.prototype.getEventSourceByPosition = function (evt) {
34711
34705
  return evt_1.EvtUtils.getEventSourceByPosition(evt);
34712
34706
  };
34713
- RenderManager.prototype.createDiagramMouseEvent = function (evt, element) {
34707
+ RenderManager.prototype.createDiagramMouseEventFromToolbox = function (evt, element) {
34714
34708
  var offsetPoint = this.getOffsetPointByEvent(evt);
34715
- return new Event_1.DiagramMouseEvent(key_1.KeyUtils.getKeyModifiers(evt), Utils_1.isLeftButtonPressed(evt) ? Event_1.MouseButton.Left : Event_1.MouseButton.Right, new point_1.Point(evt.pageX, evt.pageY), offsetPoint, this.view.getModelPoint(offsetPoint), this.getEventSource(element), this.createDiagramMouseEventTouches(evt["touches"]), evt.pointerType);
34709
+ return this.createDiagramMouseEventCore(evt, offsetPoint, this.createEventSourceFromToolbox(evt, offsetPoint, element));
34710
+ };
34711
+ RenderManager.prototype.createEventSourceFromToolbox = function (evt, offsetPoint, element) {
34712
+ var source = this.getEventSource(element);
34713
+ if (!common_1.isDefined(source) || source.type <= 1)
34714
+ return new Event_1.MouseEventSource(this.getMouseEventElementTypeFromToolbox(this.createPagePoint(evt), offsetPoint));
34715
+ return source;
34716
+ };
34717
+ RenderManager.prototype.createInnerDiagramMouseEvent = function (evt, element) {
34718
+ return this.createDiagramMouseEventCore(evt, this.getOffsetPointByEvent(evt), this.getEventSource(element));
34719
+ };
34720
+ RenderManager.prototype.createDiagramMouseEventCore = function (evt, offsetPoint, source) {
34721
+ return new Event_1.DiagramMouseEvent(key_1.KeyUtils.getKeyModifiers(evt), this.createMouseButton(evt), offsetPoint, this.view.getModelPoint(offsetPoint), source, this.createDiagramMouseEventTouches(evt["touches"]), evt.pointerType);
34722
+ };
34723
+ RenderManager.prototype.createMouseButton = function (evt) {
34724
+ return Utils_1.isLeftButtonPressed(evt) ? Event_1.MouseButton.Left : Event_1.MouseButton.Right;
34725
+ };
34726
+ RenderManager.prototype.createPagePoint = function (evt) {
34727
+ return new point_1.Point(evt.pageX, evt.pageY);
34716
34728
  };
34717
34729
  RenderManager.prototype.createDiagramContextMenuEvent = function (evt) {
34718
- return new Event_1.DiagramContextMenuEvent(key_1.KeyUtils.getKeyModifiers(evt), new point_1.Point(evt.pageX, evt.pageY), this.view.getModelPoint(this.getOffsetPointByEvent(evt)));
34730
+ return new Event_1.DiagramContextMenuEvent(key_1.KeyUtils.getKeyModifiers(evt), this.createPagePoint(evt), this.view.getModelPoint(this.getOffsetPointByEvent(evt)));
34719
34731
  };
34720
34732
  RenderManager.prototype.createDiagramWheelEvent = function (evt) {
34721
34733
  var offsetPoint = this.getOffsetPointByEvent(evt);
@@ -1,8 +1,8 @@
1
1
  /*!
2
2
  * DevExpress Diagram (dx-diagram.min)
3
- * Version: 2.1.43
4
- * Build date: Wed Dec 29 2021
3
+ * Version: 2.1.44
4
+ * Build date: Wed Jan 12 2022
5
5
  *
6
- * Copyright (c) 2012 - 2021 Developer Express Inc. ALL RIGHTS RESERVED
6
+ * Copyright (c) 2012 - 2022 Developer Express Inc. ALL RIGHTS RESERVED
7
7
  * Read about DevExpress licensing here: https://www.devexpress.com/Support/EULAs
8
8
  */.dxdi-control{overflow:visible;box-sizing:border-box;position:relative}.dxdi-control.dxdi-read-only .dxdi-canvas.dxdi-drag-scroll{cursor:grab!important}.dxdi-control.dxdi-read-only .dxdi-canvas.dxdi-drag-scroll .shape,.dxdi-control.dxdi-read-only .dxdi-canvas.dxdi-drag-scroll .shape-expand-btn,.dxdi-control.dxdi-read-only .dxdi-canvas.dxdi-drag-scroll text{cursor:grab}.dxdi-control.dxdi-read-only .dxdi-canvas .shape,.dxdi-control.dxdi-read-only .dxdi-canvas .shape-expand-btn,.dxdi-control.dxdi-read-only .dxdi-canvas text{cursor:default}.dxdi-control .dxdi-canvas{display:block;background-color:#d9d9d9;transform-origin:0 0;overflow:hidden}.dxdi-canvas.dxdi-drag-scroll{cursor:grab!important}.dxdi-canvas.dxdi-drag-scroll .connection-point,.dxdi-canvas.dxdi-drag-scroll .connector,.dxdi-canvas.dxdi-drag-scroll .connector-side-mark.horizontal,.dxdi-canvas.dxdi-drag-scroll .connector-side-mark.vertical,.dxdi-canvas.dxdi-drag-scroll .connector text,.dxdi-canvas.dxdi-drag-scroll .selection-mark[data-type="4"],.dxdi-canvas.dxdi-drag-scroll .selection-mark[data-type="5"],.dxdi-canvas.dxdi-drag-scroll .selection-mark[data-type="9"][data-value="1"],.dxdi-canvas.dxdi-drag-scroll .selection-mark[data-type="9"][data-value="2"],.dxdi-canvas.dxdi-drag-scroll .selection-mark[data-type="9"][data-value="3"],.dxdi-canvas.dxdi-drag-scroll .selection-mark[data-type="9"][data-value="4"],.dxdi-canvas.dxdi-drag-scroll .selection-mark[data-type="9"][data-value="5"],.dxdi-canvas.dxdi-drag-scroll .selection-mark[data-type="9"][data-value="6"],.dxdi-canvas.dxdi-drag-scroll .selection-mark[data-type="9"][data-value="7"],.dxdi-canvas.dxdi-drag-scroll .selection-mark[data-type="9"][data-value="8"],.dxdi-canvas.dxdi-drag-scroll .shape,.dxdi-canvas.dxdi-drag-scroll .shape .shape-expand-btn{cursor:grab}.dxdi-canvas *{user-select:none}.dxdi-canvas text{font-family:arial,helvetica,sans-serif;font-size:10pt}.dxdi-canvas .page{fill:#fff}.dxdi-canvas .pages-grid-line{fill:none;stroke:rgba(0,0,0,.15);stroke-dasharray:8;stroke-width:2}.dxdi-canvas .grid-inner-line,.dxdi-canvas .grid-outer-line{fill:none}.dxdi-canvas .grid-outer-line{stroke:rgba(0,0,0,.1)}.dxdi-canvas .grid-inner-line{stroke:rgba(0,0,0,.05)}.dxdi-canvas .shape,.dxdi-canvas .toolbox-item{pointer-events:bounding-box}.dxdi-canvas .shape ellipse,.dxdi-canvas .shape line,.dxdi-canvas .shape path,.dxdi-canvas .shape rect,.dxdi-canvas .toolbox-item ellipse,.dxdi-canvas .toolbox-item line,.dxdi-canvas .toolbox-item path,.dxdi-canvas .toolbox-item rect{fill:#fff;stroke-width:2;stroke:#000}.dxdi-canvas .shape text,.dxdi-canvas .toolbox-item text{fill:#000;text-anchor:middle}.dxdi-canvas .shape rect.selector,.dxdi-canvas .toolbox-item rect.selector{stroke-width:48;stroke:transparent;fill:transparent;pointer-events:auto}.dxdi-canvas .shape.not-valid ellipse,.dxdi-canvas .shape.not-valid line,.dxdi-canvas .shape.not-valid path,.dxdi-canvas .shape.not-valid rect{stroke:red}.dxdi-canvas .shape{cursor:move}.dxdi-canvas .shape.text-input>text{display:none}.dxdi-canvas .shape.container>rect:first-child{fill:none}.dxdi-canvas .shape .shape-expand-btn{cursor:pointer}.dxdi-canvas .shape .shape-expand-btn>path,.dxdi-canvas .shape .shape-expand-btn>rect{stroke-dasharray:initial!important}.dxdi-canvas .shape .shape-expand-btn>path{stroke-width:2!important}.dxdi-canvas .shape .dxdi-image .dxdi-spinner{animation:loading-spinner 1s linear infinite}.dxdi-canvas .shape .dxdi-image .dxdi-spinner ellipse{stroke:#000;stroke-opacity:.2}.dxdi-canvas .shape .dxdi-image .dxdi-spinner path{stroke:#fd7010;stroke-linecap:round}.dxdi-canvas .shape .dxdi-image .dxdi-spinner ellipse,.dxdi-canvas .shape .dxdi-image .dxdi-spinner path{fill:none;stroke-width:5}@keyframes loading-spinner{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.dxdi-canvas .shape .dxdi-image .dxdi-user .dxdi-background{fill:#000;opacity:.2;stroke:none}.dxdi-canvas .shape .dxdi-image .dxdi-user ellipse,.dxdi-canvas .shape .dxdi-image .dxdi-user path{fill:#fff;stroke:none}.dxdi-canvas .shape .dxdi-image .dxdi-warning ellipse{stroke:none;fill:#ee1616}.dxdi-canvas .shape .dxdi-image .dxdi-warning rect{stroke:none;fill:#fff}.dxdi-canvas .shape.locked,.dxdi-canvas .shape.locked+.container-children .shape,.dxdi-canvas .shape.locked+.container-children .shape .shape-expand-btn,.dxdi-canvas .shape.locked .shape-expand-btn{cursor:inherit!important}.dxdi-canvas .container-children .shape .selector{stroke-width:8}.dxdi-canvas .toolbox-item{cursor:pointer}.dxdi-canvas .toolbox-item .selector{stroke-width:0!important}.dxdi-canvas .connector line,.dxdi-canvas .connector path{stroke-width:2;stroke:#000;stroke-linejoin:round;pointer-events:stroke}.dxdi-canvas .connector path:not(.outlined-line-ending):not(.filled-line-ending){fill:none!important}.dxdi-canvas .connector path.outlined-line-ending{fill:#fff}.dxdi-canvas .connector path.filled-line-ending{fill:#000}.dxdi-canvas .connector line.selector,.dxdi-canvas .connector path.selector{stroke-width:16;stroke:transparent}.dxdi-canvas .connector text{cursor:move;fill:#000;text-anchor:middle}.dxdi-canvas .connector .text-filter-flood{flood-color:#fff}.dxdi-canvas .connector.not-valid line,.dxdi-canvas .connector.not-valid path{stroke:red}.dxdi-canvas .connector.can-move{cursor:move}.dxdi-canvas .connection-mark,.dxdi-canvas .connection-point,.dxdi-canvas .connector-point-mark,.dxdi-canvas .connector-side-mark,.dxdi-canvas .geometry-mark,.dxdi-canvas .selection-mark{fill:#fff;stroke-width:2}.dxdi-canvas .selection-mark{stroke:#1e90ff}.dxdi-canvas .selection-mark[data-type="9"][data-value="1"]{cursor:nw-resize}.dxdi-canvas .selection-mark[data-type="9"][data-value="2"]{cursor:ne-resize}.dxdi-canvas .selection-mark[data-type="9"][data-value="3"]{cursor:se-resize}.dxdi-canvas .selection-mark[data-type="9"][data-value="4"]{cursor:sw-resize}.dxdi-canvas .selection-mark[data-type="9"][data-value="5"]{cursor:n-resize}.dxdi-canvas .selection-mark[data-type="9"][data-value="6"]{cursor:e-resize}.dxdi-canvas .selection-mark[data-type="9"][data-value="7"]{cursor:s-resize}.dxdi-canvas .selection-mark[data-type="9"][data-value="8"]{cursor:w-resize}.dxdi-canvas .selection-mark[data-type="4"],.dxdi-canvas .selection-mark[data-type="5"]{cursor:move}.dxdi-canvas .locked-selection-mark{fill:#fff;stroke-width:1;stroke:#666}.dxdi-canvas .geometry-mark{cursor:pointer;stroke:#daa520}.dxdi-canvas .connection-target,.dxdi-canvas .container-target{fill:transparent;stroke:orchid;stroke-width:2;pointer-events:none}.dxdi-canvas .connection-point{cursor:crosshair;stroke:orchid}.dxdi-canvas .connection-point.not-valid{stroke:grey;display:none}.dxdi-canvas .connection-mark{cursor:crosshair;stroke:orchid}.dxdi-canvas .connection-mark.selector,.dxdi-canvas .connection-point.selector{stroke-width:10px;stroke:transparent;fill:transparent}.dxdi-canvas .connection-mark.active,.dxdi-canvas .connection-point.active{fill:orchid}.dxdi-canvas .connector-point-mark,.dxdi-canvas .connector-side-mark{cursor:move;stroke:#1e90ff}.dxdi-canvas .connector-point-mark.disabled{cursor:default;display:none}.dxdi-canvas .connector-side-mark{fill:#1e90ff}.dxdi-canvas .connector-side-mark.vertical{cursor:col-resize}.dxdi-canvas .connector-side-mark.horizontal{cursor:row-resize}.dxdi-canvas .item-selection-rect,.dxdi-canvas .items-selection-rect{fill:transparent;stroke-width:1;stroke:#1e90ff;stroke-dasharray:2px;pointer-events:none}.dxdi-canvas .items-selection-rect{fill:rgba(30,144,255,.02)}.dxdi-canvas .item-multi-selection-rect{fill:rgba(30,144,255,.02);stroke-width:1;stroke:#1e90ff;pointer-events:none}.dxdi-canvas .selection-rect{fill:rgba(30,144,255,.2);stroke-width:1;stroke:#1e90ff;pointer-events:none}.dxdi-canvas .connector-multi-selection,.dxdi-canvas .connector-selection{fill:transparent;stroke-width:1;stroke:#1e90ff;pointer-events:none}.dxdi-canvas .connector-multi-selection.text,.dxdi-canvas .connector-selection.text{fill:transparent;stroke-width:1}.dxdi-canvas .connector-selection{stroke-dasharray:2px}.dxdi-canvas .connector-selection-mask rect{fill:#000}.dxdi-canvas .connector-selection-mask rect.background{fill:#fff}.dxdi-canvas .connector-selection-mask line,.dxdi-canvas .connector-selection-mask path{fill:#fff;stroke:#000;stroke-width:4}.dxdi-canvas .connector-selection-mask text{text-anchor:middle}.dxdi-canvas .extension-line path{stroke:#1e90ff;stroke-width:1}.dxdi-canvas .extension-line path.size-line{stroke-dasharray:4px}.dxdi-canvas .extension-line text{fill:#1e90ff;font-size:.8em;text-anchor:middle}.dxdi-canvas .extension-line.center>path.size-line,.dxdi-canvas .extension-line.page>path.size-line{stroke-dasharray:0}.dxdi-canvas .extension-line:not(.center)>path:not(:first-child){display:none}.dxdi-canvas .resize-info text{fill:rgba(0,0,0,.8);font-size:.8em;text-anchor:middle}.dxdi-canvas .resize-info rect{fill:#fff;stroke:rgba(0,0,0,.3);stroke-width:1}.dxdi-canvas .dxdi-active-selection .shape{cursor:default}.dxdi-control:not(.focused) .dxdi-canvas .geometry-mark,.dxdi-control:not(.focused) .dxdi-canvas .selection-mark{stroke:#666}.dxdi-control:not(.focused) .dxdi-canvas .item-selection-rect,.dxdi-control:not(.focused) .dxdi-canvas .items-selection-rect{fill:transparent;stroke:#666}.dxdi-control:not(.focused) .dxdi-canvas .items-selection-rect{fill:hsla(0,0%,56.5%,.02)}.dxdi-control:not(.focused) .dxdi-canvas .item-multi-selection-rect{fill:hsla(0,0%,56.5%,.02);stroke:#666}.dxdi-control:not(.focused) .dxdi-canvas .connection-mark,.dxdi-control:not(.focused) .dxdi-canvas .connection-mark.selector,.dxdi-control:not(.focused) .dxdi-canvas .connection-point,.dxdi-control:not(.focused) .dxdi-canvas .connection-point.selector{display:none}.dxdi-control:not(.focused) .dxdi-canvas .connector-multi-selection,.dxdi-control:not(.focused) .dxdi-canvas .connector-point-mark,.dxdi-control:not(.focused) .dxdi-canvas .connector-selection,.dxdi-control:not(.focused) .dxdi-canvas .connector-side-mark{stroke:#666}.dxdi-control:not(.focused) .dxdi-canvas .connector-side-mark{fill:#666}.dxdi-dragging,.dxdi-dragging *{user-select:none}.dxdi-touch-action{touch-action:none}.dxdi-canvas.export *{cursor:inherit!important;pointer-events:all!important}.dxdi-toolbox,.dxdi-toolbox svg{user-select:none;outline:none}.dxdi-toolbox,.dxdi-toolbox-drag-item .dxdi-canvas,.dxdi-toolbox .dxdi-canvas{width:100%;height:100%}.dxdi-toolbox .dxdi-canvas .toolbox-item ellipse,.dxdi-toolbox .dxdi-canvas .toolbox-item line,.dxdi-toolbox .dxdi-canvas .toolbox-item path,.dxdi-toolbox .dxdi-canvas .toolbox-item rect{fill:transparent;stroke:currentColor}.dxdi-toolbox .dxdi-canvas .toolbox-item .dxdi-image-placeholder{opacity:.75;fill:currentColor;stroke:none}.dxdi-toolbox .dxdi-canvas .toolbox-item .dxdi-shape-text{opacity:.25}.dxdi-toolbox-drag-item .dxdi-canvas text,.dxdi-toolbox .dxdi-canvas .toolbox-item text{font-weight:700;font-family:Segoe UI,Helvetica Neue,Helvetica,arial,sans-serif;fill:currentColor}.dxdi-toolbox-drag-item .dxdi-canvas .dxdi-image-placeholder{opacity:.75;fill:currentColor;stroke:none}.dxdi-toolbox-drag-item .dxdi-canvas .dxdi-shape-text{display:none}.dxdi-toolbox .toolbox-text-item{cursor:pointer;user-select:none;margin:0 0 .6em}.dxdi-toolbox-drag-item,.dxdi-toolbox-drag-text-item{font-family:arial,helvetica,sans-serif;font-size:10pt;color:#000;position:absolute;z-index:10000;pointer-events:none!important}.dxdi-toolbox-drag-item *,.dxdi-toolbox-drag-text-item *{pointer-events:none!important}.dxdi-toolbox-drag-item text{pointer-events:none}.dxdi-toolbox-drag-text-item{background-color:#fff;border:2px solid #000;padding:.5em}.dxdi-tb-drag-captured{display:none}.dxdi-focus-input,.dxdi-text-input,.dxdi-text-input-container{padding:0;outline:none;border:none;resize:none}.dxdi-clipboard-input,.dxdi-focus-input{position:absolute;overflow:hidden;left:-1000px!important;top:-1000px!important;opacity:0}.dxdi-text-input-container{display:none}.dxdi-text-input-container.connector-text,.dxdi-text-input-container.shape-text{display:inherit;position:absolute;overflow:hidden;background-color:transparent;transform-origin:0 0}.dxdi-text-input-container.shape-text .dxdi-text-input{display:table-cell;overflow:hidden;padding:1px 0 0;outline:none;background-color:transparent;font-family:arial,helvetica,sans-serif;font-size:10pt;color:#000;line-height:1.1em;text-align:center;vertical-align:middle}.dxdi-text-input-container.connector-text{overflow:visible}.dxdi-text-input-container.connector-text .dxdi-text-input{padding:2px;outline:none;height:calc(1.1em + 6px);width:calc(8em + 6px);margin-top:calc(-.55em - 3px);margin-left:calc(-4em - 3px);background-color:#fff;border:1px solid #1e90ff;font-family:arial,helvetica,sans-serif;font-size:10pt;color:#000;line-height:1.1em;text-align:center;vertical-align:middle;overflow:hidden}.dxdi-page-shadow{fill:grey}