Changelog
6.6.2
September 26th 2023
UPDATES
- Added attributes to Custom overlays to support auto rotation. See the overlay docs for more information.
6.6.1
September 20th 2023
UPDATES
- Added
dominant-baseline:middle
to labels rendered by shape libraries.
6.6.0
September 20th 2023
NEW FUNCTIONALITY
Support for SVG/PNG/JPG export for Surfaces that are using a ShapeLibrary was added.
The Angular service was augmented with new methods to support exporting to SVG/PNG/JPG
The ShapeLibrary component now supports rendering labels to shapes as part of their SVG element.
A new flag
useHTMLElement
is supported on Label overlays. Setting to false will result in the Toolkit using an SVGtext
element for the label overlay, rather than an HTML element.A new flag
useHTMLLabel
was added to edge definitions, which you can use to override the new default behaviour of using an SVG text element for the default label.
BREAKING
The ShapeLibraryPalette no longer registers a
jtk-shape
tag on the associated Surface. Instead, the shape library needs to be passed in the render options to the Surface. See shape library documentation for details.When you specify a
label
in an edge type, the Toolkit now creates an SVGtext
element for it, rather than an HTML element.By default, hover events are now switched off in the UI layer. We expect this change to affect almost nobody at all. For a full discussion of the reasoning behind this, see the documentation on rendering at https://docs.jsplumbtoolkit.com/toolkit/6.x/lib/rendering.
UPDATES
- Fixed an issue with the lasso plugin that would cause it to fail on devices with touch + pointer input methods.
- Fixed an issue whereby a
cssClass
defined on an edge mapping would not be applied to a newly created edge.
6.5.0
September 3rd 2023
NEW FUNCTIONALITY
A new connector type -
Segmented
- has been added. This connector consists of a set of straight line segments, and can be smoothed to a set of bezier curves.A path editor for the
Segmented
connector type has been added.
UPDATES
Orthogonal connector editor automatically trims any supplied geometry after load, to ensure the internal geometry is in a format that the editor can manage.
Fixed an issue whereby path tracing between groups was failing.
The
jsplumbtoolkit-connector-editors.css
stylesheet was refactored slightly, to introduce common base classes for edge handles, and to use CSS variables.The controls component now detects the existence - or otherwise - of a Lasso plugin on the associated Surface, and does not draw the mode change buttons if the Lasso is not present.
6.4.1
August 30th 2023
UPDATES
- Further fix for
Orthogonal
path recomputation when stubs are not active. - Fix for group load issue: when a group loaded via the
load
method declared it was a member of some group which was not part of the data load but was in the Toolkit, it could not be loaded.
6.4.0
August 30th 2023
BREAKING
- The
alwaysRespectStubs
flag defaults to true in the Orthogonal connector now.
UPDATES
- Fix for an issue with recomputing
Orthogonal
path when stubs are not active.
6.3.0
August 4th 2023
UPDATES
- When dragging an edge, the class
jtk-surface-edge-dragging
is added to the surface container. - For licensees who hold a team license - 5 seats or more - the ES6 source code is now available as a separate download.
- EdgePathEditor was updated so that it no longer requires
anchorPositions
to be passed in if these are defined on a node/port/group definition in the view.
BREAKING
- Version 2.x is no longer supported.
6.2.15
July 29th 2023
Further packaging updates. No code changes.
6.2.14
July 28th 2023
UPDATES
- Fixed an issue whereby overlays that had been programmatically added to an edge (eg via the edge path editor) would be hidden upon edge update.
- Improvements to packaging for evaluators to include types directory.
6.2.13
July 27th 2023
This release contains only internal updates to packaging. No code changes.
6.2.12
July 25th 2023
UPDATES
- EdgePathEditor was updated to ignore edges loaded programmatically via the
load
method of the Toolkit. Edges loaded in this way already have geometry set and do not need to be updated. - Updates to Orthogonal connector to better handle node drag when initial path consists of a single horizontal or vertical segment.
6.2.11
July 19th 2023
BREAKING
- The EdgePathEditor now defaults to
true
for theactiveMode
option. Although this is a breaking change it in fact brings the behaviour of the path editor more into line with what people expect: any new edge that is dragged automatically has a geometry attached to it, meaning if the dataset is exported without the edge being edited it will be reinstated with the same path.
UPDATES
- A fix was added to correct an issue introduced by the change to the EdgePathEditor in 6.2.10. Geometry is now correctly written to an edge that has been dragged by the user when
activeMode
is true (which, as mentioned above, is now the default).
6.2.10
July 14th 2023
BREAKING
- The
katavorio-drag-no-select
class is no longer added to the document body during element drag. There was no corresponding style declared in the default CSS stylesheet, so it is unlikely this class is being used by anyone.
UPDATES
- Inspectors were updated to ensure they close themselves if the object they are currently displaying is deleted from the dataset.
- An update was made to the EdgePathEditor to ensure that edge geometry is written correctly when
activeMode
is set to true. - In the base port component and the miniview component in the React integration, the overridden
props
andstate
class members were removed, as their presence was causing React to report a warning in the console.
6.2.9
June 28th 2023
UPDATES
- Added support for
addHelperClasses
flag in SurfacedragOptions
. Defaults to true. When false, prevents the Surface from adding classes to the canvas to indicate an element is being dragged.
6.2.8
June 23rd 2023
UPDATES
- Update generic type parameter bounds in
ShapeLibraryPalette
and Angular service shape library methods to satisfy strict TS builds.
6.2.7
June 23rd 2023
UPDATES
- Update
ShapeLibraryImpl
generic type parameter bounds to satisfy strict TS builds.
6.2.6
June 21st 2023
UPDATES
- update controls component to set state attributes on its rendered root element rather than the container in which it resides.
6.2.5
June 20th 2023
UPDATES
- added
jsplumbtoolkit-edge-type-picker.css
stylesheet - add
visibility:visible !important
to edge path delete button overlay.
6.2.4
June 20th 2023
GENERAL
- Updated EdgeTypePicker to repaint itself after a window resize event, to ensure edges are painted in the right place.
- added ControlsComponent, a component from our demonstration apps that might be useful for others.
- fixed issue in connector editor package where re-editing an edge that it was already editing would cause any extra overlays to be removed.
- fixed issue in bezier connector editor where control points were being dragged at twice the rate the mouse was moving.
BREAKING
- The
jsplumbtoolkit-connector-editors-orthogonal.css
andjsplumbtoolkit-connector-editors-bezier.css
stylesheets were removed. The styles contained in both of those stylesheets exist in thejsplumbtoolkit-connector-editors.css
stylesheet.
6.2.3
June 17th 2023
GENERAL
- Update shape library palette to support configurable
iconSize
property.
6.2.2
June 16th 2023
GENERAL
- Updates to custom tag registration to allow shape libraries to be used without a ShapeLibraryPalette.
6.2.1
June 16th 2023
GENERAL
- The default number of iterations for the
ForceDirected
layout was increased from 5 to 15. - Updated JS doc for
ShapeLibraryImpl
- Updated custom tag renderer to remove expectation that a
rendered
and/orupdated
function would always be provided.
6.2.0
June 16th 2023
GENERAL
Improvements to support for tree shaking
The drop manager now adds a
jtk-drag-drop-current
class to the element currently being draggedSeveral enhancements were made to the drawing tools plugin - placement of new nodes is now correct when the surface has a zoom level of anything other than 1, and if the surface has a grid applied this is also honoured.
The default styles for edge path editors no longer contain a rule for painting the edge path to a specific color. For applications in which the user has control over the edge color this is a better experience. For users who wish to add this functionality that can be done via the inclusion of a CSS rule - see documentation on CSS.
Updates to the default template engine to ensure that elements written by custom tags are correctly updated when their vertex is updated.
The default number of iterations for the
ForceDirected
layout was reduced from 50 to 5.
NEW FUNCTIONALITY
A new module
browser-ui-shape-library
was added. This package contains various helper components for working with SVG shapes, for applications such as flowchart builders, entity relationship diagrams, etc. For a full discussion of the capabilities of this module, see https://docs.jsplumbtoolkit.com/toolkit/6.x/lib/shape-libraries.Support for the
browser-ui-shape-library
module was added to the Angular, Vue2, Vue3, React and Svelte integrations.A new module
browser-ui-inspector
was added. This contains some support code for implementing form-based object inspectors that integrate tightly with a Surface/Toolkit instance. For a full discussion of the capabilities of this module, see https://docs.jsplumbtoolkit.com/toolkit/6.x/lib/inspectors.Support for the
browser-ui-inspector
module was added to the Angular, Vue2, Vue and React integrations.Added the
canvasDropFilter
toSurfaceDropManager
. The parent classDropManager
already supported this but it was not exposed on theSurfaceDropManager
prior to 6.2.0.An optional
dragSize
parameter can be supplied to the drop manager, to set the size of nodes/groups that are being dragged.Support for a
modelEvents
object has been added to the Surface's constructor. Instead of having to register model events after the fact you can now supply them with your render parameters.The concept of 'mode' was added to selections: you can specify that a given selection may only contain one type of object (eg nodes, groups or edges), or that it can contain a mix. For more information see the documentation at https://docs.jsplumbtoolkit.com/toolkit/6.x/lib/selections#selection-mode
Edge editors now snap anchor placeholders to the closest anchor when the user is relocating an anchor. Previously the placeholder would not be snapped until the use released the mouse button. The previous behaviour can be reinstated by setting
snapToAnchors:false
in the options you pass to thestartEditing
method.When dragging a new edge, the Surface element will now honour a
type
specifier returned from abeforeStartConnect
interceptor. In previous versions thetype
would only be honoured once a new connection had been established. For more information see https://docs.jsplumbtoolkit.com/toolkit/6.x/lib/interceptors#beforestartconnect.Support for 'fragments' was added to custom tags in the default template engine. This is more of an internal feature, but could be leveraged by advanced users of the Toolkit. See documentation on templating for further information.
Label overlays now have a
jtk-label-overlay
class added to their element.The default CSS stylesheet was updated with a
visibility:hidden
rule for.jtk-label-overlay:empty
. For label overlays on which the label's value is currently an empty string, this will hide the overlay.The CSS for the "controls" component that we ship along with each of the library integrations was copied out from
jsplumbtoolkit-demo-support.css
and intojsplumbtoolkit-controls.css
, and the various selectors were updated to be more specific.
BREAKING
Simple edge styles are now enabled by default on the Surface component. They can be switched off via
simpleEdgeStyles:false
in your render options.The
PanZoom
widget, which is used internally by theSurface
, has been decoupled from the Surface and its constructor parameters have been updated. This will only be an issue for licensees who use thePanZoom
stand alone.The
jsplumbtoolkit.css
defaults stylesheet was updated to use CSS variables. This is only really listed as a 'breaking' change out of an excess of caution. There are very few browsers in use nowadays that do not support CSS variables.The
important
modifier was removed from the default style for the.jtk-surface-selected-element
class, which is applied to vertices that are part of the Toolkit's current selection.
BUGFIXES
- Fixed issue with anchor placeholder not being centered correctly when editing an edge.
- Fixed issue with
Hierarchy
layout where certain combinations of unattached roots and multiple parents could cause the layout to fail, due to a cache not being cleared.
6.1.1
May 12th 2023
- Updates to build for evaluators
6.1.0
May 11th 2023
Angular integration is now built as an Ivy lib (necessary in order to support Angular 16)
Hierarchy
layout has been updated to support centering child nodes with respect to their parent, mimicking the behaviour of theHierarchical
layout.Hierarchical
layout is now marked deprecated. UseHierarchy
instead.
BREAKING
- Internally, the
Hierarchical
layout no longer uses agetChildEdges
helper function, but rather agetChildVertices
function. This change will only affect those who are using theHierarchical
layout with a custom edge finder. It has no impact on the functionality of the layout itself.
6.0.5
April 18th 2023
- Internal code reorganisation. No functional change.
6.0.4
April 14th 2023
- Fixed an issue in the Community edition where endpoints to set to invisible would be repainted under certain revalidation scenarios.
6.0.3
April 5th 2023
- Packaging updates for evaluation builds
6.0.2
April 4th 2023
- Fixed issue with the packaging of the Vue integration.
6.0.1
April 4th 2023
- Added bezier and statemachine connectors to
@jsplumbtoolkit/browser-ui
6.0.0
April 4th 2023
BREAKING
Support for the original templates syntax (where variable interpolations are of the form
${...}
) has been dropped, throughout the Vanilla toolkit and the dialogs. The code from the previoustemplates-2
,dialogs-2
andbrowser-ui-vanilla-2
packages has been retained in the@jsplumbtoolkit/browser-ui
package, and the code fromtemplates
,dialogs
andbrowser-ui-vanilla
has been dropped.The
Spring
layout has been removed. UseForceDirected
instead.
In order to support the single @jsplumbtoolkit/browser-ui
package, several factory methods were renamed/removed:
newInstance(surface)
in previous@jsplumbtoolkit/browser-ui-anim
removed. Usenew SurfaceAnimator(surface)
instead.createManager
in previous@jsplumbtoolkit/drop
package is now exposed ascreateDropManager
in@jsplumbtoolkit/browser-ui
createSurfaceManager
in previous@jsplumbtoolkit/drop
package is now exposed ascreateSurfaceDropManager
in@jsplumbtoolkit/browser-ui
newInstance(surface:Surface, options?:ConnectorEditorOptions)
from previous@jsplumbtoolkit/connector-editors
method removed - usenew EdgePathEditor(surface:Surface, options?:ConnectorEditorOptions)
instead.initialize()
method from previous@jsplumbtoolkit/connector-editors-bezier
is now exposed asinitializeBezierConnectorEditors()
on@jsplumbtoolkit/browser-ui
.initialize()
method from previous@jsplumbtoolkit/connector-editors-orthogonal
is now exposed asinitializeOrthogonalConnectorEditors()
on@jsplumbtoolkit/browser-ui
.newInstance(params:DialogsOptions)
from the previous@jsplumbtoolkit/dialogs-2
package has been removed. To instantiate Toolkit dialogs now, usenew Dialogs(params)
.The
HORIZONTAL
andVERTICAL
axis identifiers from theHierarchicalLayout
have been moved into the enumHierarchicalLayoutOrientations
.The code from the related
-drop
package for each library integration (@jsplumbtoolkit/browser-ui-angular-drop
etc) has now been pulled into the library integration's main package
5.13.7
March 28th 2023
- Added support for injecting props into components in the Vue2/Vue3 integration packages.
5.13.6
March 21st 2023
- Update to the fix applied in 5.13.5
5.13.5
March 18th 2023
- Fixed issue with endpoint cleanup after aborted connection drag
5.13.4
February 26th 2023
- Packaging updates for integrations
5.13.3
February 18th 2023
- Packaging updates for the layout-hierarchy package
5.13.2
December 7th 2022
- Updated the lasso plugin to remove a global reference to
document
and instead use a lazy init method
5.13.1
November 28th 2022
BREAKING
- The
getAllEdges
method of theGroup
class no longer returns edges connected to child vertices of the group, instead behaving exactly asgetAllEdges
does onNode
.
UPDATES
Group
now has the methodgetInternalEdges
, which returns edges connected to child vertices of the group.- Improvements to the placement stage of the Hierarchy layout when
invert
is set to true. - added support for
gatherUnattachedRoots
flag on the Hierarchy layout - see documentation for discussion.
5.12.6
November 9th 2022
- Internal refactoring of the templates-2 package
5.12.5
November 8th 2022
- Updates to Angular overlay handling when an edge factory is in place.
5.12.4
November 7th 2022
Updated Angular overlay handler to ensure correct initialisation when new edges are dragged.
Added support for Angular's
OnPush
change detection to node/group/port/overlay components.
5.12.3
October 27th 2022
Updates to community edition event generator to directly invoke event handlers instead of attempting to bind a context to them. This change is transparent to Toolkit users.
Update to Angular overlay to prevent an exception being thrown when the overlay is present on a connection that is being dragged (meaning that there is not yet an associated edge in the model)
5.12.2
October 12th 2022
- Improvements to Arrow overlay rendering
5.12.1
October 7th 2022
- updates to packaging for the background plugin
- addition of methods to hide/show backgrounds in the background plugin.
- ensure copy/paste of edge correctly clones the edge's data
5.12.0
September 22nd 2022
BREAKING
- In the generated grid background,
showMinorLines
is nowshowTickMarks
, andminorLinesPerCell
is nowtickMarksPerCell
.
UPDATES
Fix for an issue where the
node:move:end
event of the Surface did not contain all of the elements in the drag group.Added support for dotted background in generated grid background, via
gridType
parameter ("dotted" or "lines"). Default is for lines.Added
dotRadius
andtickDotRadius
options to generated grid background, for use with GridTypes.dotted.
5.11.3
August 23rd 2022
- Improvements to the documentation
- Addition of
setDraggable
method to Surface, to set the draggable state of individual vertices.
5.11.2
August 18th 2022
- Refactoring "simple edge styles" (color/line width) and edge labels. It is now possible to set an edge's color, line width, label (and its location) directly from the backing data for the edge.
5.11.1
August 18th 2022
- Refactoring "simple edge styles" (color/line width)
5.11.0
August 17th 2022
UPDATES
Added code to catch and report circular references in view dependencies
Updated the view code to support multiple parents for a given node/group/edge/port definition
Added the concept of "simple edge styles" - automatically mapping a few key properties from each edge's backing data to the appearance of its corresponding connection in the UI. See documentation for more details.
Added the concept of a "property mapper", an alternative to the existing concept of edge styles, which maps specific property values in edge data to appearance. See documentation for more details.
5.10.9
August 16th 2022
BREAKING
- the background plugin no longer assumes a type of "simple" by default: you have to always supply a type.
UPDATES
- grid backgrounds now have defaults for fill/stroke written into the svg.
- fixed issue with background plugin CSS stylesheet not being packaged.
5.10.8
August 16th 2022
- Internal refactoring of background plugin to expose type members that can be used when configuring backgrounds in an ES6/TS development environment, to avoid the code being omitted through tree shaking.
5.10.7
August 15th 2022
- Added support for generated grid backgrounds.
5.10.6
August 12th 2022
- Fixed a couple of issues with edge placement in nested nodes/groups in the underlying community edition
- Fixed an issue with the tiled background layer in the background plugin that was preventing it from rendering.
- Reinstated the
zoomToBackground
method on the Surface widget - Added
supportLegacyConnectorData
flag toOrthogonalConnectorOptions
. This offers a means for people migrating from 2.x to load datasets where there is path data for Orthogonal connectors in the 2.x format.
5.10.5
August 5th 2022
- Update to the Angular component overlay code to fix an issue that occurred when an edge deletion was undone via
undo()
.
5.10.4
August 3rd 2022
- Added support to the Angular integration for using Angular components as overlays.
5.10.3
July 25th 2022
- Minor internal refactoring. No functionality change.
5.10.2
July 22nd 2022
- Minor internal refactoring. No functionality change.
5.10.1
July 21st 2022
UPDATES
- Lasso plugin now updates the Toolkit's selection, rather than the Surface's drag selection, allowing the Surface to decide whether or not selected elements should be added to the drag selection.
5.10.0
July 21st 2022
UPDATES
- The Surface widget no longer by default adds an element in the Toolkit's current selection to the underlying drag selection, instead maintaining a separate drag group for selected elements. What this means is that if you have a few elements selected and you drag one that is not selected, the selected elements will not also be dragged.
5.9.4
July 19th 2022
- Upgraded to Typescript 4.x.
5.9.3
July 18th 2022
- Packaging updates. No code change.
5.9.2
July 18th 2022
UPDATES
The surface widget now supports an instantiated Decorator in its
decorators
constructor parameter. This can be useful in situations where your code needs to work closely with the decorator's behaviour.The args to the
decorate
method in a Decorator are now typed asDecorateParams
(no changes, just the introduction of this type definition)On a device that support touch events, the container element for a Surface is now assigned a
jtk-surface-touch-device
css class. The purpose of this is to allow you to style differently for touch devices, for instance by making visible elements that are only visible on hover on a device supporting pointer events.On a device that supports pointer events, the container element for a Surface is now assigned a
jtk-surface-pointer-device
css class.
Note that
5.9.1
14 Juillet 2022
UPDATES
- The
constrainFunction
that can be passed in thedragOptions
to a Surface can now return null, indicating that for the given tick of the drag lifecycle there is no suitable place for the element and the element should not be moved from its previous position.
5.9.0
July 7th 2022
BREAKING
Backgrounds for the Surface element have been moved to a separate plugin -
@jsplumbtoolkit/browser-ui-plugin-background
In the underlying Community edition, endpoints are no longer wrapped in a
div
element; instead theirsvg
element is appended directly to the container. This isn't a major change but may require some minor CSS updates.
UPDATES
The
jtk-endpoint
element has been updated to no longer require that adata-jtk-port
attribute be set. This enables you to declaratively register multiple endpoints that are mapped to the vertex itself in the data model rather than on logical ports on the vertex.The
onCanvasDrop
callback ofDropManager
is now passed the size of the dropped element, and also the related mouse event.You can now pass a
constrainFunction
to the Surface'sdragOptions
, which will be invoked whenever an element is dragged, allowing you to control where elements can be dragged.SurfaceDropManager
andDropManager
have received a few improvements:- When dragging an element onto a Surface, the element being dragged will, by default, be scaled so that it appears at the same size as it will be when it is dropped (by matching the Surface's zoom). This behaviour can be switched off if desired.
- When the underlying Surface has a
constrainFunction
that controls where its elements can be dragged, by default this function will also be used to control element dragging when the new element is in the Surface's viewport. This behaviour can be switched off if desired - You can pass an
elementGenerator
toSurfaceDropManager
andDropManager
, which is a function the Toolkit will use to get the element to drag, rather than cloning the drag element.
5.8.3
June 16th 2022
UPDATES
- Updated React integration to fix an inconsistency in the way state was cleared after the data model is emptied via
clear()
. A warning was reported by React in the console.
5.8.2
June 15th 2022
UPDATES
- fix for an issue in the node/group factories whereby a transaction could be left open if the user did not invoke either the continue or abort callback.
5.8.1
June 14th 2022
UPDATES
- added support for 'id' attribute on
SurfaceComponent
in Svelte integration. - fixed an intermittent issue with updating templates in the
templates-2
package: when an interpolated value was initially an empty string, the value could not be rewritten to boolean false.
5.8.0
June 9th 2022
BREAKING
- Surface no longer fires
EVENT_DATA_LOAD_END
orEVENT_DATA_LOAD_START
. It is unlikely these event subscriptions were in use, and they are a pass-through of the same event from the underlying Toolkit. If you want to listen for these events and you currently do so on the Surface, just bind to them on the Toolkit instead. - Drag groups have been extracted to a separate plugin
UPDATES
- Surface now fires
EVENT_RENDER_START
andEVENT_RENDER_END
at the beginning and end of the rendering of a set of data.EVENT_RENDER_END
does not fire until every vertex in the dataset has been rendered (taking into account asynchronous rendering) - Updates to Vue 3 to better integrate with the asynchronous paint mechanism (in particular, when bulk loading and then running a layout)
- Updates to React to better integrate with the asynchronous paint mechanism in React 18 (in particular, when bulk loading and then running a layout)
- Added support for 'temmplate macros' to the
@jsplumbtoolkit/templates-2
package. This bringstemplates-2
up to par with@jsplumbtoolkit/templates
in terms of the complexity supported in injected values.
NEW PACKAGES
@jsplumbtoolkit/browser-ui-plugin-drag-groups
contains the code that lets you manage "drag groups". See https://docs.jsplumbtoolkit.com/toolkit/5.x/lib/plugins#drag-groups
5.7.1
June 1st 2022
UPDATES
- Update to ForceDirected layout to better support positioning newly added nodes
5.7.0
June 1st 2022
UPDATES
- Reinstated support for
directRender
mode, which has not been properly supported in 5.x as of yet.
NEW PACKAGES
- added new
ForceDirected
layout. This is a rewrite of the originalSpring
layout, with several improvements and a shorter run time. Users of theSpring
layout are recommended to switch to this layout from 5.7.0 onwards. Available in the package@jsplumbtoolkit/layout-force-directed
.
5.6.5
May 24th 2022
UPDATES
- Updates to the Spring layout to ensure that running the spring layout over and over on a given dataset wont move nodes whose position has already been calculated (regardless of whether the position was initially in the model or calculated by the layout). This also applies when a new node is added to the dataset - existing nodes will not be moved.
5.6.4
May 21st 2022
UPDATES
- Added the related ComponentRef to the arguments passed to the
vertexEvent
callback exposed by the Surface element in Angular integration.
5.6.3
May 20th 2022
UPDATES
- Added optional
toolkitParams
as an Input to the Surface element in Angular integration.
5.6.2
May 6th 2022
UPDATES
- Updated miniview to render existing dataset if attached after Surface has initially rendered.
- Updated Surface to write positions to model after
relayout
andrefresh
if thestorePositionsInModel
flag was set to true
5.6.1
May 5th 2022
BREAKING
interceptors
support removed from theSurface
object. This was undocumented and unused, and interceptors are supported by the Toolkit.panDistance
moved fromSurfaceOptions
to thePanButtonsPluginOptions
interface in the pan buttons plugin.
UPDATES
- Updates to packaging for evaluation versions
- Update to the React integration to fix a rendering issue in React 18 when calling
load
with JS data during acomponentDidMount
oruseEffect
initialiser.
5.6.0
May 3rd 2022
BREAKING
@jsplumbtoolkit/dialogs
has now been renamed to@jsplumbtoolkit/dialogs-core
, and is a base package for two new packages -@jsplumbtoolkit/dialogs
and@jsplumbtoolkit/dialogs-2
. If you use@jsplumbtoolkit/dialogs
currently, thendialogs-core
will be automatically imported; the only thing you need to be aware of is that the dialogs CSS file is now indialogs-core
, and not indialogs
, so any references you have to that will need to be updated.dialogs-2
is discussed below.
NEW PACKAGES
- `@jsplumbtoolkit/browser-ui-svelte`
This is an integration package to facilitate using the Toolkit with Svelte 3. Docs are here: https://docs.jsplumbtoolkit.com/toolkit/5.x/lib/svelte-integration
- `@jsplumbtoolkit/browser-ui-templates-2`
This is a rewrite of the default templates package (used by the `@jsplumbtoolkit/browser-ui-vanilla` renderer, not by the Angular/React/Vue integrations) that addresses, primarily, the fact that in certain sandboxed environments (such as Salesforce Lightning), "strict" mode is enforced and so `eval` and `with` - both of which the original templates package uses internally - are not available.
Currently this package is still considered experimental, not having had the same battle testing that the original template package has had, but it has other advantages too, such as using `{{...}}` instead of `${...}` for variable substitution, making it play more nicely with template literals, and the speed with which an update occurs is vastly improved over the original templates package. We encourage licensees to give this new package a try and we invite all feedback.
Detailed information on the differences between this package and the original templates package, as well as instructions for how to use the package with your existing code, can be found here on our docs site: https://docs.jsplumbtoolkit.com/toolkit/5.x/lib/templating-2
- `@jsplumbtoolkit/browser-ui-vanilla-2`
The vanilla Toolkit renderer, but using the new templates package instead of the original templates package. This is the renderer that we use now in all of our demonstration pages. For users of the current vanilla renderer we recommend switching to this package, as the original templates package (and therefore browser-ui-vanilla) is now in a lightweight maintenance mode, and is unlikely to be continued from v6.0.0 onwards.
- `@jsplumbtoolkit/dialogs-2`
This is a port of the original `dialogs` package that uses the `templates-2` package under the hood. Functionally there is no change from the original `dialogs` package, but the format of the templates you use with `dialogs-2` corresponds to the changes in `templates-2`.
UPDATES
- Parameterised labels in views were updated to support
{{value}}
syntax as opposed to${value}
. This is to avoid confusion with JS string templates. The previous syntax is still supported for now but won't be as of v6.0.0. - The
beforeConnect
interceptor now takes an optional 4th argument which indicates whether the new edge is a result of user activity with a mouse/touch device, or if it is a programmatic edge addition. - Fixed an issue with the
beforeDetach
interceptor where in some cases thesource
andtarget
parameters were empty (although they could be retrieved from the edge that is passed in to that interceptor anyway)
5.5.5
April 5th 2022
UPDATES
- Fixed painting issue in orthogonal connector when a connection is established between endpoints on opposite faces of the same element.
5.5.4
April 5th 2022
UPDATES
- Update Community edition's event manager module to not reference
document
in its root.
5.5.3
April 1st 2022
UPDATES
- Optimising imports in both Toolkit and Community editions. No code change.
5.5.2
March 16th 2022
UPDATES
- Fixed an issue preventing the magnetizer from running ad-hoc with the Spring layout.
5.5.1
March 12th 2022
NEW PACKAGES
- New package
@jsplumbtoolkit/layout-hierarchy
added
This is a new layout that follows a slightly modified Sugiyama algorithm. Unlike the original Hierarchical
layout, there is no assumption that any given node will have at most one parent, and consequently this layout typically performs much better on real world datasets than the Hierarchical
layout. For more information - and future plans - see the Toolkit documentation.
5.5.0
March 10th 2022
BREAKING
Extracted "ui states" from the
@jsplumbtoolkit/browser-ui
package and put them into a plugin in the package@jsplumbtoolkit/browser-ui-plugin-ui-states
. This shaves a bunch of Kb off the size of thebrowser-ui
package. Details for how to migrate can be found in the documentation for UI States.Several Surface render parameters related to how the mouse wheel is handled, which were marked deprecated in 5.3.0, have now been removed, or rather, moved and renamed:
- wheelZoomMetaKey ->
wheel:{ useMetaKey:... }
- wheelReverse ->
wheel:{ reverse:... }
- wheelSensitivity ->
wheel:{ sensitivity:... }
- wheelFilter ->
wheel:{ filter:... }
- wheelPan ->
wheel:{ pan:... }
- enableWheelZoom ->
wheel:{ zoom:... }
- wheelZoomMetaKey ->
The default value for each of these parameters is still the same as in previous versions.
NEW PACKAGES
@jsplumbtoolkit/browser-ui-plugin-ui-states
, as discussed above.
5.4.1
February 15th 2022
BREAKING
- removed
getPosition(..)
method fromSurface
. UsegetCoordinates(..)
instead. - removed
setVertexPosition(..)
method fromSurface
. It was a duplicate ofsetPosition(..)
NEW PACKAGES
- Added new
@jsplumbtoolkit/copy-paste
and@jsplumbtoolkit/browser-ui-copy-paste
packages. See documentation for details.
UPDATES
Added
activeMode
optional constructor parameter forEdgePathEditor
. When set, any new connection that has just been dragged will be marked "edited", meaning the geometry from the initial path is then fixed. This is a useful toggle if you're using ananchorPositionFinder
in your code. See documentation for more details.fixed possible geometry load issue with Orthogonal connectors in certain circumstances.
updated Orthogonal connector geometry load to allow usage with static (ie. not just Continuous or Dynamic) anchors.
5.4.0
February 10th 2022
BREAKING
- Removed support for a
templateRenderer
declaration inside a node, group or port definition in a view. We know of no instances of this capability being used, and if it is needed, it can be handled inside atemplateRenderer
declared on the render params for a Surface.
UPDATES
- Fix for potential recursive loop when elements in Balloon layout have connections to themselves.
- Added support for
anchorPositionFinder
inside a node, group or port definition in a view. This provides a means for you to determine the anchor location for the source/target of some connection at drag time. - Added support for
anchorPositionFinder
to the connector editor package. Provides a means for you to determine where the source/target anchor of some connection can be dragged to when the connector is being edited.
5.3.11
February 6th 2022
UPDATES
- Added
checkValidity
method to the dialogs package. - exposed
extractValueFromElement
method to get the value from a single element to the dialogs package. - Internal refactoring of the connector editors to standardise their drag behaviour with other parts of the Toolkit.
5.3.10
February 4th 2022
UPDATES
- Added support to the dialogs
extract
andapply
methods for a custom binder.
5.3.9
February 1st 2022
UPDATES
- Refactored the dialogs internally to extract the DOM binding code for reuse in jsPlumb Toolkit Components.
- Added optional
autoCommit
flag to theshow
method ofDialogs
. By default this is true.
5.3.8
January 29th 2022
UPDATES
- Updated the underlying community edition renderer to ensure that a user-provided
anchor
callback in a target selector is honoured.
5.3.7
January 27th 2022
UPDATES
- Updated the drag handler in the underlying community edition renderer to ensure that a user-provided
start
callback cannot override the default drag start behaviour.
5.3.6
January 25th 2022
UPDATES
- Updated the
bindModelEvent
andon
methods of theSurface
to handle multiple:not(..)
selectors. - Fixed issue with
wheelPan:true
in pan/zoom widget not binding the wheel listener. - Updated
setOverlaysVisible
method ofSurface
to take an optional varargs list of overlay ids to operate on.
5.3.5
January 21st 2022
UPDATES
Fixed an issue whereby in some circumstances it was possible for a
bindModelObject
callback to be invoked without a model object supplied.added
setOverlaysVisible(Selection|Path|Edge|Array<Edge>, boolean)
method to theSurface
updated the drop manager to support overridden
left
/top
properties passed to the node factory callback.added optional
onVertexAdded
callback to SurfaceDropManager, which will be invoked whenever a group/node has been dropped onto the canvas and added to the dataset.
5.3.4
January 12th 2022
UPDATES
- Correction of the change in 5.3.3:
jtk-source-hover
andjtk-target-hover
are applied to the elements involved in a connection, not the endpoints.
5.3.3
January 11th 2022
UPDATES
- Reinstated the application of
jtk-source-hover
andjtk-target-hover
classes to the source and target endpoint for some connection on which the mouse is hovering.
5.3.2
January 10th 2022
- Fixed issue with endpoint hover: when hovering over an endpoint, endpoints at the other end of connections to that endpoint also hover.
- Fixed intermittent issue with multiple definitions on an element that have Continuous anchor definitions with different faces.
5.3.1
December 20th 2021
UPDATES
- added support for
maxConnections
inaddTargetSelector
method of Community edition.
5.3.0
December 15th 2021
UPDATES
- Updated the
exportData
method to ensure that its output is insulated from the Toolkit's internal dataset - Updated to ensure the
node:move:end
event is fired after any necessary changes to the model. - Added
toJson()
toJsPlumbToolkit
; you can now callJSON.stringify(someToolkitInstance)
to get the same output you'd get fromsomeToolkitInstance.exportData()
.
5.2.4
December 12th 2021
UPDATES
- Fixed intermittent issue with not all edges being deleted when a group they are attached to is deleted.
5.2.3
December 7th 2021
UPDATES
- Fixed issue with
uniqueEndpoint
on port definition not being honoured.
5.2.2
December 6th 2021
UPDATES
updated the
tracePath
method in@jsplumbtoolkit/browser-ui-anim
to set a.jtk-animate-source
class on the path source vertex and a.jtk-animate-target
class on the path target vertex for the duration of the trace.fixed issue with
maxConnections
on port definition not being honoured.
5.2.1
November 30th 2021
UPDATES
- Added fix for a node/edge asynchronous rendering issue when using the
data
prop of the Vue3 surface.
5.2.0
November 28th 2021
UPDATES
Replaced
Dictionary<T>
throughout the codebase withRecord<string, T>
. Dictionary had been marked deprecated for a few versions.Community edition updated to better handle anchor orientations with dynamic anchors.
5.1.2
November 26th 2021
UPDATES
- Fixed issue with parsing of nested groups via the
load
function.
5.1.1
November 26th 2021
UPDATES
- Small change to event registration for connection drag handlers. No functional change but this reduces any lag at the start of a drag.
5.1.0
November 25th 2021
UPDATES
compound
is no longer an available flag on the undo/redo parameters passed to a Toolkit constructor. If an edge is deleted as part of a call toremoveNode
orremoveGroup
, its deletion is automatically wrapped in a transaction by the Toolkit. But if an edge is deleted independently of a vertex then it has its own undo/redo stack entry.wheelFilter
was reinstated.
5.0.0
October 29th 2021
5.x is a rewrite to Typescript, with a focus on modules. This work presented a rare opportunity to perform refactoring for clarity and performance purposes. As the list of changes grew, it was decided to move them out of the changelog and into a dedicated migration guide document.
In 5.x, the Toolkit and Community edition versions will be kept in step: Toolkit: version 5.a.b of the Toolkit always corresponds to version 5.a.b of the Community edition.
2.1.3
11th June 2020
UPDATES
- Minor refactoring to the internals of the Surface when a node is removed. In certain rare circumstances there could be endpoints that did not get cleaned up.
2.1.2
30th May 2020
UPDATES
In the Angular integration,
jsPlumbDragDropComponent
andjsPlumbSurfaceDropComponent
refactored to beDirective
rather thanComponent
. This makes no difference to their operation, but it is more correct conceptually, and also allows you to extend them with your own Directives.updated types: added
elementFilter
as optional to MiniviewOptionsadded support for
[elementFilter]
onjsPlumbMiniview
Angular componentadded
redraw
method tojsPlumbMiniview
Angular component
2.1.1
19th May 2020
UPDATES
- added
onDemand
flag andedit
method to drawing tools, to enable on-demand attachment of drawing tools instead of via Toolkit selection. - fixed issue in which it was not possible to lasso nodes that were previously in a group that was deleted.
- ensure groups on which nodes are dropped have their layout re-run
- fixed a race condition in the auto save mechanism that could cause incorrect values for nodes previously belonging to a group that has been removed.
2.1.0
10th May 2020
BREAKING
jsplumbtoolkit-vue2.tgz
now contains a version of our components that require you to use theVue.use(...)
approach to including the library. For more information see https://docs.jsplumbtoolkit.com/toolkit/current/articles/demo-vue2.html#bootstrap
For the time being, the original version of the Vue integration is available in jsplumbtoolkit-vue2-runtime.tgz
, but
this will at some point be removed.
UPDATES
- Fixed issue in which a node removed from a group did not have its position updated in the model (when
storePositionsInModel
is set to true) - Added
jsplumbtoolkit-testing
package. This provides a set of helper methods for you to use when testing a UI that includes the jsPlumb Toolkit.
2.0.6
1st May 2020
UPDATES
- upgrade to Community edition 2.13.2
group:addMember
andgroup:removeMember
added to the list of events that instigate an auto save.- added
context
as an argument to edge factory. This provides all of the context information for the edge being created - source, target, etc. For more information search "edge factory" on docs.jsplumbtoolkit.com. - performance enhancements for large numbers of nodes/edges
2.0.5
27th April 2020
BREAKING
- The internal representation of
templateRenderer
now expects it to be an object containing arender
method and acleanup
method. If you have a custom template renderer then you need to update it to satisfy this contract. Therender
method should just be whatever your currenttemplateRenderer
function is.cleanup
is expected to perform any deregistration that is required, and also to remove the rendered element from the DOM.
UPDATES
- Fixed issue with miniview ignoring the
wheelReverse
setting of its associated surface. - Update Angular, React and Vue integrations to ensure components are destroyed when the Toolkit is cleared (via the
clear()
method). - added a
clear
button to all of the Flowchart demonstrations. - Undo/redo manager clears its history when the related Toolkit is cleared.
2.0.4
14th April 2020
UPDATES
Updated all Angular demonstrations to Angular 9 (with aot)
Minor updates to internal packaging of Toolkit code
Updates to the database visualizer demonstrations:
- separated out
id
andname
members of columns. Previously, theid
of the column was also its name, which was mostly just a conceptual problem, but for the React database visualizer it meant the inclusion of some extra code to generate a unique 'key' for each column. - introduced a 'contacts' table, linked to Author, Publisher
- set
detachable:false
on edge definition so the user has to use the X button to delete a relationship
- separated out
Added support in the Undo/redo manager for adding node to/removing node from Groups.
setPosition
method of Surface now stores new position in model if configured to do soAdded support in undo/redo for group drag
fixed an issue where in some cases a Node programmatically removed from a Group was not appended back to the canvas.
upgrade to Community edition 2.13.1
2.0.3
1st April 2020
UPDATES
Fixed an issue with
jtk-source
elements specifyingendpoint
: if their type definition was specifying amaxConnections
for the port, the Toolkit was overwriting that with a value of -1 (unlimited connections).Updated the template engine to cover a couple of edge cases when a template contains
r-if
statements and is updated. This only has any bearing if you use "vanilla" Toolkit and not Angular/React/Vue.added support for
autoSaveHandler
in the Toolkit constructor and in thesetAutoSave
method. If you supply this then the Toolkit will decide on when an auto save needs to occur, honouring anyautoSaveDebounceTimeout
you supply, but your function will handle the actual save.
2.0.2
23rd March 2020
UPDATES
- Surface correctly informs the underlying pan/zoom widget when a group has been removed.
2.0.1
20th March 2020
UPDATES
faster uuid method in util
updates to the typescript definitions.
Updated to Community edition 2.13.0. Versions 2.12.10 - 2.13.0 together contain:
- a performance enhancement for painting Bezier/StateMachine connectors
- a fix for connector overlays that can in some circumstances disappear when switching type
- a couple of fixes related to source/target drag methods when
setId
orsetIdChanged
is used (does not affect the Toolkit edition) - a fix for touch events on certain Windows computers running Chrome.
fixed an issue rendering Groups in the React integration
2.0.0
22nd February 2020
UPDATES
- added editable flowchart connectors
- added editable bezier connectors
- upgraded all flowchart demonstrations to use editable connectors and new flowchart example
- removed legacy Vue demonstration and support
- removed Webpack bundling demonstration (the React demonstrations use Webpack if you're looking for an example)
- Storage is now in jsPlumbUtil.Storage, not jsPlumbToolkit.util.Storage
- Cookie support removed from Storage. It was a fallback for browsers that did not support local storage.
- added getVersion() method to jsPlumbToolkit class
1.18.7
30th January 2020
UPDATES
- Updated to Community edition 2.12.9
1.18.6
11th December 2019
UPDATES
- Improve tracePath so that the tracing can be paused while traversing nodes.
- Updated to Community edition 2.12.8
1.18.5
3rd December 2019
UPDATES
- added optional
onReload
constructor parameter toSelection
. If agenerator
is provided, this function is called whenever the generator has been run. - added optional
onBeforeReload
constructor parameter toSelection
. If agenerator
is provided, this function is called before the Selection is cleared and then generator re-run. - added optional
autoFill
constructor parameter toSelection
. If true, and agenerator
is provided, whenever a new Node is added to the Toolkit, the selection is cleared and the generator run automatically. - refactored the
Hierarchical
andBalloon
layouts to extendAbsoluteBackedLayout
. By default this functionality is switched off, but settingabsoluteBacked:true
switches it on, and then any nodes that are disconnected from all other nodes can be placed via theirleft
andtop
properties. Useful for drag/drop when using these layouts.
1.18.4
30th November 2019
UPDATES
- Added
setSurface
method to the SurfaceDropManager and DropManager. This allows you to use a single drop manager with multiple Surfaces.
1.18.3
29th November 2019
UPDATES
Upgraded to community edition 2.12.7, which contains a couple of fixes for working with the drag selection:
- nodes inside groups cannot be added to the drag selection. Only "top level" nodes and groups can be added to the drag selection.
- nodes in the drag selection that are subsequently added to a group are removed from the drag selection
1.18.2
16th November 2019
UPDATES
added
addClass
,hasClass
andremoveClass
methods to the Surface widget. These wrap their corresponding methods on the underlying Community instance.some internal changes to support the upcoming ability to drag flowchart connector paths.
updated the
tracePath
method to return a handler that exposesplay()
,pause()
andcancel()
methods, so the animation can be started/stopped and cancelled.updated the
tracePath
method to supportpaused
as an argument. When this is set to true, the animation begins in the paused state.
1.18.1
29th October 2019
UPDATES
updated to Community edition 2.12.5
Added
setAutoSave(options)
method to Toolkit instance, to configure auto save after instantiation. This method can be called any number of times, and each time it is called any previous auto save setup is discarded.added
lassoEdges:boolean
constructor option for Surface widget. When true (defaults to false), edges are included in selections made with the lasso. All edges connecting any two nodes/groups (or ports on nodes/groups) that have been lassoed are included in the selection.added
jsPlumbToolkitLabelDragManager
in an optional include,jsplumbtoolkit-labels.tgz
. For a discussion of this and of labels in general, see https://docs.jsplumbtoolkit.com/toolkit/current/articles/labels.html.
1.18.0
16th October 2019
UPDATES
Updated the default template engine to reinstate support for custom tags. These were supported in Rotors, the original default template engine, but removed in Knockle, to which we updated recently. After some consideration we decided that custom tags can be useful, and so they're back in.
Added webpack dev server and associated npm script to all the React demonstrations
Updated the readme for licensed/evaluation distributions.
1.17.1
10th October 2019
UPDATES
- minor updates to the way updates are handled by the text search add-on
- fixed an issue with dragging elements from a palette on touch devices.
1.17.0
4th October 2019
UPDATES
- removed the
jsplumb-palette
component from the Angular integration. It had been deprecated for a few versions. Use the drop manager instead. - added
radius
to EndpointOptions in types - updated
eachNode
,eachGroup
andeachEdge
mthod signature in types; they were missing theidx
parameter. - added new full text search plugin. This is an optional import - jsplumbtoolkit-search. The
data
member of all nodes, groups, ports and edges is used to populate a reverse text index, which you can then search via an API. Full documentation available on https://docs.jsplumbtoolkit.com - search "text search". - extended the Undo/redo manager to support changes made to the dataset via the
update***
methods (updateNode
,updatePort
etc). - extended the Undo/redo manager to support node/group move events. To enable these events you now need to pass a Surface to the Undo/redo manager constructor, not a Toolkit, as move events are specific to the Surface widget and not something the Toolkit deals with.
1.16.2
24th September 2019
UPDATES
- support
autoSaveDebounceTimeout
parameter on Toolkit constructor. Allows requests generated by the auto save mechanism to be regulated a little.
1.16.1
23rd September 2019
UPDATES
- added support for specifying edge label directly in an edge definition in a view (without needing to declare it as a Label overlay)
- added support for specifying label location inside the backing data for an edge
1.16.0
UPDATES
17th September 2019
updated default template engine to Knockle, which is a port of the previous Rotors template engine, with some changes:
- adds/removes content inside `r-if` and `r-each` loops when updates occur. In Rotors these elements would run
a single time and not respond to changes in the dataset on update.
- does not support the `r-for` element
- does not support custom elements (Toolkit licensees are _extremely_ unlikely to be using these)
- does not support IE8 (which the Toolkit hasnt supported for some time)updates to code docs to improve generated API docs
1.15.4
30th August 2019
UPDATES
- updated the Angular 1.x integration to use the SurfaceDropManager instead of the now deleted
registerDroppableNodes
method from the Surface widget.
1.15.3
18th August 2019
UPDATES
- Updated the types of the
events
member of aViewOptions
object. It's not a Map; it's a plain JS object, but with a limited set of keys. - Updates to
ViewPortOptions
type to include missing possible values.
1.15.2
9th August 2019
UPDATES
- fixed issue with Toolkit firing an edgeAdded event even when the underlying graph rejected the edge addition.
- upgraded to Community edition 2.11.2
- setting type on Edge now honours any Endpoint definitions in the new type.
1.15.1
18th July 2019
UPDATES
- Updated to Community edition 2.11.1, which contains a fix for an issue where types were dropped after a reset.
- Update Angular code to better support situations where the 'id' property is not the one being used as node/port id.
1.15.0
17th July 2019
UPDATES
NOTE: you should use 1.15.1, and not this version. 1.15.1 has an important bugfix.
Removed the
registerDroppableNodes
method from the Surface widget. Use the drop manager package, or one of its library wrappers.Updated to Community edition 2.11.0, which includes some changes to the way types are merged by the Community edition, specifically that with the exception of
events
andoverlays
, everything is overwritten when merging types. This fixes an issue with edge definitions in the Toolkit, in whichanchor
values were being merged rather than overridden.Edge/node/port/group definitions in a View now support a
mergeStrategy
parameter. If set to "override", overlays and events will completely replace any overlays or events declared on parent definitions, rather than being merged with them.
1.14.11
4th July 2019
UPDATES
- Updated the drop manager to take into account any
translate
CSS rules applied to ancestors of the Surface it is registered against. - Tested against Angular 8
- Updated to work with the Ivy compiler in Angular 8 (need fix for Ivy bug https://github.com/angular/angular/issues/31160 in the version of Angular 8 you use)
- Marked deprecated the
registerDroppableNodes
method of Surface, as well asJsPlumbToolkitPaletteComponent
in the React integration,jsPlumbPaletteComponent
in the Angular integration, and thepalette
mixin in the Vue integration. Use the drop manager package, or one of its library wrappers.
1.14.10
27th June 2019
UPDATES
- Upgrade to Rotors 0.3.19, which supports multiple child elements in an
r-html
tag - Upgrade to community edition 2.10.1, which contains a fix allowing us to update source definitions after they have been created
- Update toolkit/surface code to properly detect and handle the case that a port's id changes.
- Update the React database visualizer demo to use a dedicated key for column loop, rather than using the column's id property. This allows the column to be renamed without React ditching the component and creating a new one.
1.14.9
6th June 2019
UPDATES
improvements to React integration:
- avoid possible NPE in React integration's JsPlumbToolkitSurfaceComponent when default template renderer is being used
- added
removeNode()
helper method toBaseNodeComponent
- added
removeGroup(alsoRemoveChildNodes:boolean)
helper method toBaseGroupComponent
- added
BasePortComponent
. React components can now be used to render ports. - added a React port of the Database Visualizer demonstration.
1.14.8
5th June 2019
UPDATES
- upgraded to version 2.10.0 of the Community edition.
1.14.7
20th May 2019
UPDATES
- added addFactoryGroup(..) method, which does for Group what addFactoryNode does for Nodes
- added SurfaceDropManager component, which simplifies drag/drop of nodes/groups onto a Surface (and also offers drop on edge), as well as Angular/React/Vue wrappers for it.
- fixed an issue in the drop manager that was polluting the count of nodes and groups
- rewrote various demonstration pages to use the SurfaceDropManager.
1.14.6
9th May 2019
UPDATES
- upgrade Katavorio to version 1.4.5
- upgrade Community edition to 2.9.3
- fixed issue with nodes dropped into groups not having their positions correctly adjusted.
1.14.5
4th May 2019
UPDATES
- fixed an issue with Auto save causing the dataLoadEnd event to be prematurely aborted.
1.14.4
16th April 2019
UPDATES
- internal refactoring of a few methods related to rendering ports
1.14.3
15th April 2019
UPDATES
- added support for
is-source
andis-target
on jtk-port elements.
1.14.2
12th April 2019
UPDATES
- Fixed issue with the packaging of the flowchart builder demonstration (the drop library was missing)
1.14.1
10th April 2019
UPDATES
- internal rewrite of the jsPlumbToolkitIO module from JS to Typescript
- internal rewrite of the Autosaver module from JS to Typescript
- expose
dropHandler
on JsPlumbToolkitPaletteComponent in the React integration - update Community edition to 2.9.1
1.14.0
6th March 2019
UPDATES
- Documentation removed from the license/evaluation bundles and moved to https://docs.jsplumbtoolkit.com
- update Community edition to 2.9.0
- in direct render mode, honor any max-width or max-height CSS properties applied to the container.
1.13.8
5th March 2019
UPDATES
- documentation updates
1.13.7
4th March 2019
UPDATES
- documentation updates
- verified that the Toolkit works with Angular 7
- inclusion of example package.json for Angular 7 applications
1.13.6
3rd March 2019
UPDATES
- add grunt as a dev dependency to package.json in the evaluation/license downloads
- update installation docs to show correct npm commands needed to run demonstration server
- added a Vue 2 mixin wrapper around the Drop Manager
- added a React component to wrap the Drop Manager
- added an Angular component to wrap the Drop Manager
- added drop on edge behaviour to Flowchart demo, plus the Vue/React/Angular versions
- fixed an issue that was preventing a node/group that had a loopback edge from being recognised as a valid root for the hierarchical layout.
- removed
allowDropOnCanvas
,allowDropOnNodesAndGroups
andallowDropOnEdges
parameters from the Drop Manager. These are inferred now from the presence of the associatedon**Drop
methods.
1.13.5
1st February 2019
UPDATES
- bugfix for addFactoryNode method on Toolkit class:
data
was ignored when calling the method with a callback.
1.13.4
13th December 2018
UPDATES
- minor tweak to the community edition ingest code
1.13.3
11th December 2018
UPDATES
- upgrade to Community edition 2.8.6.
1.13.2
7th December 2018
UPDATES
- improved community ingest support: endpoints are now modelled as ports on their parent nodes.
1.13.1
6th December 2018
UPDATES
- added support for drop on edge to Drop Manager
- documented the Drop Manager
- updated the Spring layout to correctly honour any
padding
value it is given - support user-specified number of iterations for magnetize to run on layouts.
- upgrade to Community edition 2.8.5.
1.13.0
29th November 2018
UPDATES
- updated Vue integration to provide an ES6 module package
- updated Vue integration to allow Vue components to be used as node/group renderers
- removed the
jsplumb-toolkit
Angular component. This has been deprecated for a while and unused in any of the jsPlumb demonstrations. Usejsplumb-surface
instead, and create instances of the Toolkit on the jsPlumb Angular service.
1.12.0
26th November 2018
UPDATES
- added support for "spacing" to the constructor params for the Hierarchical layout. See hierarchical layout documentation for a discussion.
- deprecated
compress:true
on Hierarchical layout. Usespacing:"compress"
instead. - Surface widget consumes the mouse events for pan/pinch zoom now. Fixes an issue seen on iPads where these operations were causing the page to begin to scroll.
- fixed issue with dialog loading in Vue demo
- improved handling of individual Selection rendering
1.11.9
16th November 2018
UPDATES
- fix for duplicated nodes appearing in miniview when ingesting a Community edition instance
- update the surface component to better support rendering the contents of individual groups
- added a cache for node/port/edge/group definitions. Since these cannot be reloaded anyway, we can safely cache them after compiling them for the first time.
1.11.8
4th November 2018
UPDATES
- Upgrade to Community edition 2.8.4.
1.11.7
2nd November 2018
UPDATES
- Fixed an issue causing edges whose type inherited from some other type to sometimes fail to update properly after updateEdge called.
- added support for "vertexId.portId" format for ports in the default json loader.
- updated IO docs.
1.11.6
28th October 2018
UPDATES
- Upgrade to Community edition 2.8.3. Fixes an intermittent issue with continuous anchors when edges are relocated to a new element.
1.11.5
26th October 2018
UPDATES
Updates to the Community edition ingest mechanism:
- default to Absolute layout for ingested Community edition instances
- ensure layout position for newly ingested elements is correct
- support optional
data
to be stored with each newly ingested element - the
ingest
method on the Surface component now handles appending the element to the underlying canvas.
Upgrade to Community edition 2.8.2
add
setEnabled(boolean)
method to jsPlumbToolkitDragManager.
1.11.4
18th October 2018
UPDATES
- update the event args passed by a Selection's reload method to be in line with those passed by a Toolkit instance
- if no container specified in render call, throw an Error. This is easier to debug.
- minor updates to drawing tools - an
onEdit
callback is supported, andreset
is exposed on the drawing tools object. - added support for 'align' to the Hierarchical layout, to alter how child groups are positioned with respect to their parent nodes
1.11.3
6th October 2018
UPDATES
- upgrade to Katavorio 1.1.0, to fix an issue that was causing multiple unnecessary nodeMoveEnd events to fire when a selection was dragged.
1.11.2
29th September 2018
UPDATES
- minor updates to the React typings
- updates for the React documentation
1.11.1
25th September 2018
UPDATES
- added Typescript definition file for the React integration.
- added Angular and React "skeleton" demonstrations - simple demonstrations designed to assist in getting something running.
1.11.0
24th September 2018
BREAKING
jsPlumbToolkitUtil
folded intojsPlumbUtil
- including the Selection class. Only a breaking change if your code usesjsPlumbToolkitUtil
directly of course.
UPDATES
- Updates to the React integration to support using React components to render nodes/groups.
- Added optional undo/redo support package for Node/Group/Edge/Port add/remove operations.
- Angular integration now supports referencing components directly in the view, instead of having to resolve them via a
nodeResolver
- Added an Angular version of the Database Visualizer demonstration
- Documentation updates
- Updated a couple of demonstrations to show usage of undo/redo
1.10.0
12th September 2018
UPDATES
- precompile React JSX components and package those instead of the original JSX files. This was done because of a compatibility issue with applications made with create-react-app: they do not compile JSX files outside of the
src
directory. - Remove unnecessary duplicated React demonstration
- Update React demonstration and docs to reflect changes in the React integration packaging.
1.9.2
7th September 2018
UPDATES
- added some more information to the Typescript typings file.
- fix in issue on Firefox Quantum with the drop manager.
1.9.1
6th September 2018
UPDATES
- Added
portOrderProperty
to the Toolkit to assist in automatically setting the order of ports in some node.
1.9.0
31st August 2018
UPDATES
- Upgrade to Community edition 2.8.0, which contains Mottle 1.0.0, which doesn't use document.createTouch/document.createTouchList, as these methods are not supported in latest Chrome and are becoming obsolete in all browsers. If you cannot upgrade to this version of jsPlumb and you're finding problems in Chrome on touch devices, there are shims available in the Mottle project on Github.
- minor updates to the Database Visualizer demonstration, to make it more usable on touch devices.
1.8.9
28th August 2018
UPDATES
- upgrade to Community edition 2.7.19
- update Angular docs to provide some tips on how to integrate with an existing application.
1.8.8
27th August 2018
UPDATES
- catch exceptions when trying to install and Typescript or Angular is not found.
- update code to work around a Typescript issue causing Angular CLI 6 production builds to fail.
1.8.7
24th August 2018
UPDATES
- pass node and group elements in callback to group:addMember and group:removeMember events from Surface.
- update to the Angular port renderer
- basic support for nodes with multiple parents in the Hierarchical layout.
- add jtk-most-recently-dragged class to the most recently dragged node/group in the Surface
1.8.6
20th August 2018
UPDATES
- improved rendering of Ports in Angular integration
- added
animateToSelection
method to Surface - fixed issue with
zoomToSelection
ignoring Groups. - added
getEdges
method to Selection - fixed documentation error that was causing
Selection.edgeEach
to be excluded. - upgrade to community edition 2.7.16
1.8.5
15th August 2018
UPDATES
- added
updateGroup
method to Toolkit
1.8.4
11th August 2018
UPDATES
- added a fix for the inverse lasso on IE11
- upgrade to community edition 2.7.15
1.8.3
10th August 2018
UPDATES
- added
getGroups
method to Toolkit class. - added
layout
entry to SurfaceOptions type definitions. - added
getPort(..)
to Node type definition - added
source
andtarget
to Edge type definition - fixed an issue with node removal in the miniview
- when removing a group from the UI and retaining its child nodes, the child nodes are drawn in the same page position as they were in when inside the group, and no relayout is called.
- upgrade to Community edition 2.7.14
1.8.2
4th August 2018
UPDATES
- added the concept of
portDataProperty
, a simple way to replaceportExtractor
andportUpdater
.
1.8.1
25th July 2018
UPDATES
- changed the format of some method declarations that were causing Angular's optimizer to confuse itself when running a production build.
- upgrade to Community edition 2.7.12
1.8.0
25th July 2018
UPDATES
- Added support for layouts to groups. Groups have an 'absolute' layout by default but can support any layout.
- fixed a few minor issues related to viewport size that were affecting the zoom to extents calculations.
- removed 'autoSizePadding' parameter from group definitions. Preferred method now is CSS.
- toolkit now fires a
group:addMember
event if a node added viaaddNode
that has a group reference in it. - fixed an issue in the Vue2 integration whereby user supplied dragOptions were ignored.
- updated all Angular demos to include the required polyfills for them to work with IE11.
- updated to Community edition 2.7.10
1.7.9
26th June 2018
UPDATES
- added support for 'invert' flag on Hierarchical layout - puts the root node at the bottom for horizontal layouts, or on the right for vertical layouts.
1.7.8
24th June 2018
UPDATES
- updated to Community edition 2.7.9
1.7.7
22nd June 2018
UPDATES
- updated to Community edition 2.7.8
- additions to Typescript typings file
- group:addMember and group:removeMember events optionally include the other group involved when the event was fired as the result of a member changing groups.
- updated the Surface to restore the current zoom, pan location and transform origin in the
loadState
method
1.7.6
21st June 2018
UPDATES
- updated to Community edition 2.7.7
- updated view documentation and database visualizer application to take out allowLoopback and allowNodeLoopback flags. These are supported, but not in a view, only in a model.
1.7.5
17th June 2018
UPDATES
- updated to Community edition 2.7.5
1.7.4
16th June 2018
UPDATES
- updates to documentation
1.7.3
14th June 2018
UPDATES
- fixed an issue where after
autoSizeGroups
had been called, the new group sizes were not known by the surface widget, causing zoomToFit to fail.
1.7.2
14th June 2018
UPDATES
locationFunction
in the Absolute layout is now given the current group as the second argument, when it is called during a group's layout of its child nodes.
1.7.1
27th May 2018
UPDATES
- upgrade to Community edition 2.7.3
1.7.0
25th May 2018
UPDATES
- upgrade to Community edition 2.7.2
- consolidated the various layout demonstrations into a single demonstration
1.6.18
16th May 2018
- added typings information for jsPlumbToolkitIO
- upgrade to Community edition 2.6.12
1.6.17
30th April 2018
UPDATES
- updates to the Typescript typings files
- moved
BaseNodeComponent
out of the angular demo code and into the core Toolkit Angular integration - reworked the Angular 4/2 demonstration to include the Angular router.
- added Angular 5 demonstration
- fixed an issue in
BaseNodeComponent
where the component did not clean itself up properly.
1.6.16
17th March 2018
UPDATES
- fix for nodes being made visible having edges to non visible nodes. previously these edges would be made visible.
1.6.15
16th March 2018
UPDATES
- fix for the
isVisible
test on nodes - added
zoomToVisible
method to the Surface widget - added
zoomToVisibleIfNecessary
method to the Surface widget - upgrade to Community edition 2.6.9
- added optional
filter
parameter tozoomToSelection
method on the Surface widget. - added
sizeGroupToFit(group)
method to Surface widget
1.6.14
9th March 2018
UPDATES
- upgrade to Community edition 2.6.8
- added support for multi selects to the Dialog helpers.
- Node factories and Group factories now return the newly created values.
1.6.13
8th February 2018
UPDATES
- upgrade to Community edition 2.6.7
- upgrade to Katavorio 0.25.0
1.6.12
4th February 2018
UPDATES
- fixed issue causing the community instance rendering content to be detached from the Surface if
clear
called before data loaded.
1.6.11
2nd February 2018
UPDATES
- upgrade to Community edition 2.6.5
- upgrade to Katavorio 0.24.0
- Added a CSS style rule to the defaults css to suppress the pointer events on an element that was created by Katavorio in response to a drag in which the element should first be cloned.
1.6.10
27th January 2018
UPDATES
- updates to the Angular system js demo to bring it back to working
1.6.9
26th January 2018
UPDATES
- The Toolkit's Typescript typings file now includes the type information for the Community edition, exported as module
jsPlumb
- Typescript typings added to
package.json
and included in built.tgz
package
1.6.8
26th January 2018
UPDATES
- typescript .d.ts updates
- upgrade to Community edition 2.6.3
1.6.7
24th January 2018
UPDATES
- upgrade to Community edition 2.6.2
- vast performance improvement in the
clear
method of the Toolkit.
1.6.6
20th January 2018
UPDATES
- upgrade to Community edition 2.6.0
- documentation updates
- Typescript .d.ts updates
- rename
generator
input on Angularjsplumb-palette
component todataGenerator
, which is the name that the docs discuss.
1.6.5
14th January 2018
UPDATES
- upgrade Community edition to 2.5.13
- fix for the setViewportCenter method of the Surface widget
- fix to ensure magnetize routine is aware of node size changes
- update docs to remove outdated references to refreshNode, refreshPort, refreshEdge and their related nodeRefreshed, portRefreshed, edgeRefreshed events.
1.6.4
29th December 2017
UPDATES
- improved location calculation for nodes dragged and dropped from a node palette.
1.6.3
23rd December 2017
UPDATES
- fix overzealous event consumption
1.6.2
21st December 2017
UPDATES
- upgraded to Community edition 2.5.10
- fix for the case that the surface widget is inside some element that has been scrolled; drop on canvas and zoom were deriving incorrect values for the mapped location on the canvas.
1.6.1
13th December 2017
UPDATES
- added experimental support for using the mouse wheel to pan (set
wheelPan:true
on a render call) - upgraded to Community Edition 2.5.9
1.6.0
8th December 2017
UPDATES
- added new layout type "Balloon". Arranges nodes in clusters.
- added HIDDEN and COLOR to supported input types for Dialogs
- exposed
apply
andextract
methods on Dialogs to allow users to bind data object to DOM manually. - upgrade to Community edition 2.5.8. Fixes an issue with disappearing connectors after
updateEdge
called.
1.5.12
12th November 2017
UPDATES
- Added optional basic connection debugging to the Surface widget.
1.5.11
7th November 2017
UPDATES
- Minor updates to the Angular Groups demo page.
1.5.10
1st November 2017
UPDATES
- Upgrade to Rotors 0.3.18, which contains a fix for the
r-html
tag.
1.5.9
29th October 2017
UPDATES
- Miniview hides/shows nodes when they are hidden/shown in its associated Surface.
1.5.8
22nd October 2017
UPDATES
- upgrade to Community edition 2.5.7.
- suppress node dragging when user is pinch-zooming.
1.5.7
18th October 2017
UPDATES
- added support for mouse events to
jtk-source
andjtk-target
elements that are declared as Ports (via the existence of aport-id
attribute). Previously these elements could only be mapped to mouse events if they were declared at a Node scope. - updated bundled Community edition to 2.5.6, which includes a minor fix for class name manipulations on SVG elements in Chrome.
1.5.6
11th October 2017
UPDATES
- minor updates to the layout magnetization engine
1.5.5
8th October 2017
UPDATES
- upgrade to community edition 2.5.5
- fix an issue with the Spring layout failing to treat
left:null
and/ortop:null
as an absence of value in the positioning data, when absolute backing is switched on.
1.5.4
4th October 2017
UPDATES
- upgrade to Community edition 2.5.2. Fixes an issue with dragging to any grid size other than [10,10].
1.5.3
6th September 2017
UPDATES
- No longer refresh the entire layout each time a new Edge is added. Add support for
refreshLayoutOnEdgeConnect
as a parameter on therender
call, to allow users to override this behaviour. - Angular 1.x revalidates a node after new edge added, to prevent errors resulting from the asynchronous nature of node painting.
- Add more methods to the Toolkit typings file
- Switched to a more consistently successful way of importing toolkit typings in package.json.
1.5.2
29th August 2017
UPDATES
- Added support for
autoSizePadding
to Group definitions.
1.5.1
28th August 2017
UPDATES
- Added support for optional
endpoint
attribute onjtk-source
andjtk-target
elements. If present, an endpoint is created for the node instead of its entire element being converted into a source or target. This is the equivalent of ajtk-port
element in that it creates an Endpoint, but connections are made directly on the Node. - Upgraded community edition to 2.5.1 (provides fix for an issue with overlays disappearing when calling
setType
on an Edge) - Added more methods to the Toolkit typings file
1.5.0
22nd August 2017
UPDATES
- added
originalData
to the params passed back tonodeUpdated
,portUpdated
andedgeUpdated
events. - upgraded CLI version to 1.3.0 in the Angular demos
- fix for the case that a new edge is added during the
edgeAdded
callback of the Surface class; the edge was being added to the model but the UI was not rendering it. - upgrade Community edition to 2.5.0
1.4.7
12th August 2017
UPDATES
- fix issue with safari zoom operating backwards to all other browsers
- add
portUpdater
- an optional function that is called when an update occurs to a Port.
1.4.6
28th July 2017
UPDATES
- fixed issue with rendering in Angular 4/2 Node components. The initial data was not being applied prior to the Toolkit checking a rendered Node's dimensions.
- code documentation updates
- improved the accuracy of the method by which the Toolkit determines that Nodes dragged from a palette have been dropped on a Group.
- package Angular 4 integration as a
tgz
, for inclusion in package.json. - add support for Groups to the active filtering support in the Surface.
1.4.5
18th July 2017
UPDATES
- added
wheelReverse
option to Surface widget.
1.4.4
14th July 2017
UPDATES
- support custom export type in syntax highlighter
1.4.3
10th July 2017
UPDATES
- added getViewportCenter method to Surface widget
- the
graphCleared
event is now fired after the graph is emptied, and before the graph is emptied, whengraphCleared
used to be fired,graphClearStart
is fired instead.
1.4.2
23rd June 2017
UPDATES
- fix an issue where hiding a connection that was attached to an endpoint that has other connections causes those other connections to be hidden too.
1.4.1
20th June 2017
UPDATES
- upgrade Rotors to 0.3.17
- upgrade Community edition to 2.4.3
1.4.0
15th June 2017
UPDATES
- fix to get the Surface class correctly exported from
jsplumbtoolkit
- workaround for AOT issue when lifecycle methods declared on superclasses
- use Angular CLI as the default for Angular demos
- fix issue with an edge dragged from one endpoint to another - the target was being incorrectly set as the Node on which the endpoint resided, not the endpoint's associated Port.
1.3.4
25th May 2017
UPDATES
- upgrade to community edition 2.4.2
- fix link to angular integration docs
1.3.3
10th May 2017
UPDATES
- updated to Rotors 0.3.16
1.3.2
10th May 2017
UPDATES
- updated the code that handles a moved connection to ensure it treats Ports correctly.
1.3.1
9th May 2017
UPDATES
- remove all String refs from React demo and from docs for React demo
- minor documentation updates
1.3.0
8th May 2017
UPDATES
- Upgrade to Community edition 2.4.0
- Support Angular 4 (when we say 'Angular' now, we mean Angular 4. Angular 2 and Angular 1.x are labelled specifically).
- Upgrade to Webpack 2 and related grunt-webpack in React and Webpack demo pages
- replaced String refs in React integration with the callback pattern.
- Added Angular CLI version of the Angular 4 flowchart demo
- Added support for onDrop to the
jsplumb-palette
directive in the Angular 1.x integration.
1.2.16
30th April 2017
UPDATES
- group auto size now correctly takes into account the group's drag area
- when adding a node to a group, if left/top properties are set in the data, they are used as the node's position.
- fixed an issue with groups not being cleared properly from the underlying Community instance when using the
clear
method
1.2.15
26th April 2017
UPDATES
- update to version 15.5.0 in the React integration demo.
1.2.14
24th April 2017
UPDATES
- added support for onBeforeAutoSave and onAfterAutoSave optional functions to Toolkit's auto save functionality.
1.2.13
24th April 2017
UPDATES
- upgrade to Community edition 2.3.5
- nodes dropped on groups now assigned their correct position
1.2.12
20th April 2017
UPDATES
- fix issue with
data
not being exported on edges whose source is a Group
1.2.11
8th April 2017
UPDATES
- Fixed issue with source element creating multiple connections after drag.
1.2.10
30th March 2017
UPDATES
- added support for
magnetize
option indragOptions
ofrender
call. Instructs jsPlumb to adjust a dragged Node/Group so that it does not overlap any other Nodes/Groups(at drag end).
1.2.9
22nd March 2017
UPDATES
- upgrade to Community edition 2.3.2 (which includes Katavorio 1.19.2)
1.2.8
16th March 2017
UPDATES
- upgrade to Community edition 2.3.1
- update to ensure that endpoints/anchors in Port definitions correctly override endpoints/anchors in Edge definitions.
1.2.7
8th March 2017
UPDATES
- Updated Angular 2 integration to force a render of each node as it is created. This ensures that any
jtk-port
,jtk-source
orjtk-target
elements are fully rendered before we try to process them.
1.2.6
8th March 2017
UPDATES
- added support for
isEndpoint
flag in port definitions in the view. Causes jsPlumb to use an Endpoint instead of making an entire element a source/target. - added support for
jtk-port
,jtk-source
andjtk-target
elements to Group templates. - updated the Surface widget to correctly render
isEndpoint
Ports when new Ports are added programmatically to a Toolkit instance. - updated the Angular docs with a short discussion on the perils of the asynchronous nature of Angular's rendering cycle.
1.2.5
1st March 2017
UPDATES
- added support for
anchor-x
,anchor-y
,orientation-x
,orientation-y
,offset-x
andoffset-y
attributes in thejtk-port
element.
1.2.4
27th February 2017
UPDATES
- updated the
exportData
method to correctly export edges between Groups.
1.2.3
27th February 2017
UPDATES
- add grunt to webpack package json
1.2.2
27th February 2017
UPDATES
- fix issue with preinstall script when running on Windows
1.2.1
21st February 2017
UPDATES
setPosition
method of Surface widget now works for Groups tooanimateToPosition
method of Surface widget now works for Groups too.toolkit
andrenderer
are now passed as arguments to any events defined in your views.
1.2.0
16th February 2017
UPDATES
- Upgrade to Community edition 2.3.0
- Community edition is now bundled into the Toolkit edition - no separate import is required.
- addition of Angular 2 integration support
- addition of Webpack bundling example
- addition of React integration support
- addition of Vue 2 integration support
- npm pack of the Toolkit code is shipped with licenses
- documentation updates
- fixed issue that was preventing deselection of Group elements
- fixed issue with update of moved nodes in miniview.
- fixed issue with duplicate Nodes being allowed inside Groups
doNotFireEvent
parameter removed from Toolkit'saddToGroup
method.- fixed issue with Groups not being removed from DOM on clear.
- Surface widget fires
lasso:end
event on lasso mouseup. No arguments are passed to the callback method.
1.1.6
3rd January 2017
UPDATES
- added getClusters method to Toolkit and to Graph
1.1.5
20th December 2016
UPDATES
- upgrade to Community edition 2.2.8
1.1.4
2nd December 2016
UPDATES
- added
getEdgeAt
method to Path - added support for custom buttons on dialogs.
1.1.3
29th November 2016
UPDATES
- documentation updates for Hierarchical layout
1.1.2
28th November 2016
UPDATES
- documentation updates.
1.1.1
27th November 2016
UPDATES
- upgrade to Community edition 2.2.6
setAbsolutePosition(el, xy[])
removed from the Surface widget. UsesetPosition(el, x, y)
instead.setAbsolutePosition
is still used by Decorators.- Nodes added programmatically to Groups (via the Toolkit's
addToGroup(Group, Node)
method) are placed in the center of the Group's drag area. Previously no change was made to their offset and this more often than not resulted in the Node not appearing inside the Group. - upgrade to Rotors 0.3.12
- support HTTP headers in
save
method and in auto save functionality.
1.1.0
28th October 2016
UPDATES
- added support for Groups
- added support for multiple root nodes in hierarchical layout
- aliased the
getEdge
method in Selection asgetEdgeAt
; this is more consistent with the API to access Nodes/Groups. - support for custom template resolver in
render
call - support for templates provided as a map of string s in
render
call. - added a couple of helper methods to the jsPlumbToolkitInstance class for working with Edges:
- selectAllEdges : Gets all edges in the Toolkit instance as a Selection object.
- addAllEdgesToSelection : Adds all the Edges in the Toolkit instance to the Toolkit's current selection.
1.0.31
18th October 2016
UPDATES
- fix issue with
ingestNode
method causing miniview to fail with ingested community instance. - ensure ingested nodes are registered with the layout.
1.0.30
20th September 2016
UPDATES
- fix issue that was causing a loopback to be added twice to the object it belonged to (although not to the Toolkit itself)
1.0.29
6th September 2016
UPDATES
- update to jsPlumb 2.1.7, containing a few minor connection fixes.
1.0.28
29th August 2016
UPDATES
- further small fix to whitespace rendering
1.0.27
28th August 2016
UPDATES
- fixed issue with whitespace rendering inside templates (in some cases whitespace was being trimmed when it should not have been)
- added
setSourceEnabled
,setTargetEnabled
,setEnabled
methods toSurface
widget
1.0.26
18th August 2016
UPDATES
- fixed issue with
setVisible
method on the Surface widget, in which connections from some element were made visible when the element was made visible, even if their other element was not currently visible.
1.0.25
12th August 2016
UPDATES
- upgraded Community edition to 2.1.5, which contains Mottle 0.7.3, which itself has a fix for the synthesized tap event on Safari and Firefox.
1.0.24
8th July 2016
UPDATES
- upgrade to community jsPlumb 2.1.4
- reinstate missing apps (hello world, skeleton app)
1.0.23
19th May 2016
UPDATES
- upgrade to jsPlumb Community 2.1.2, which contains a couple of bugfixes for click events and for overlays that were not being removed when switching types.
1.0.22
6th May 2016
UPDATES
- upgrade to jsPlumb Community 2.1.1
- fix for an operator precedence issue in the default object factory that was causing the object's type to be forgotten.
- upgrade to Rotors 0.3.11 (fix for deeply nested template rendering)
- fix for default JSON parser when Ports that have no nodeId are present.
1.0.21
21st April 2016
UPDATES
- api documentation fixes
- upgrade to jsPlumb community 2.1.0 (a couple of memory leak issue fixes)
- upgrade to Rotors 0.3.10
- upgrade to Farahey 0.7
- memory leak fixes
- fix issue with miniview not repainting after expansion
1.0.20
17th March 2016
UPDATES
- update Rotors to fix possible infinite loop with nested templates
1.0.19
9th March 2016
UPDATES
- update Rotors
1.0.18
9th March 2016
UPDATES
- fixed an issue with the auto save: it was not suspended during data load.
1.0.17
8th February 2016
UPDATES
- fix for inverse lasso: the mask does not appear until the user starts to drag.
1.0.16
1st February 2016
UPDATES
- fix for state deactivate - parameterised overlays now retain their values.
1.0.15
25th January 2016
UPDATES
- internal build script update to community 2.0.6
1.0.14
24th January 2016
UPDATES
- update to Rotors 0.3.7, which contains a fix for parameterised attributes on custom elements, and support for an 'updated' callback in custom tags.
- add support for
inverted
mode to lasso, in which unselected parts of the UI are masked, rather than the default behaviour of drawing an element to represent the selected area. - update community jsPlumb to 2.0.6. Not a required update for 1.0.14; 2.0.5 is ok.
1.0.13
11th January 2016
UPDATES
getAllEdges
injsPlumbToolkit
no longer takes parameters, and actually works properly now.- added
getAllEdges
toGraph
class. - small tidy up in Angular demo templates to fix IE* rendering issue.
1.0.12
14th December 2015
UPDATES
- Update to Rotors to support attributes with colons (such as
xlink:href
on an svg image) - Fix updateNode bug: nodes were not being removed from previous posses before being possibly added to new ones.
- Posses are assigned to elements in bulk after load, in case one of them has tried to access a node that is not yet loaded.
- Added
batch
function to Surface widget, to run a function while rendering and events are both suspended. - Added support for rectangular tiles in the tiled background of a Surface widget
- Fixed issue that caused an error when dragging an existing edge from one source to another.
zoomToFit
on the Surface widget now defaults to filling 90% of the viewport. This can be overriden by supplying afill
parameter:
surface.zoomToFit({fill:0.75});
- The link to
filters
in the documentation no longer gives a 404. - Fixed an issue that was occasionally causing multiple buttons in dialogs.
- Fixed an issue that was causing dynamically populated overlays to revert when a new State was applied.
- Introduced the concept of
typeProperty
(andedgeTypeProperty
/portTypeProperty
). This reflects the fact that for the majority of applications, the function used to determine some object'stype
simply looks at the value of some given property. By providing the name of this property, rather than atypeFunction
, the Toolkit is then able to write an object's type as well as read it. - Added support for setType method
- Added small fix to avoid buttons being added more than once to a dialog.
1.0.11
23rd October 2015
UPDATES
- upgrade to Community edition 2.0.4. Contains a couple of changes to the way posses are handled, and the ability to drop elements onto other elements. Also contains a fix for the computation of offsets when dragging nested elements.
- update to Rotors to support attributes with colons (such as
xlink:href
on an svg image) - update to Rotors to include
<r-html>
tag (for embedding HTMl rather than plain text) - change pan/zoom widget so it no longer consumes all mouse events it does not process.
jsPlumbToolkitUtil.ajax
takes optionalheaders
map (for setting http headers).jsPlumbToolkitInstance.load
takes optionalheaders
map (for setting http headers).jsPlumbToolkitInstance.load
setsAccept:application/json
HTTP header if headers not supplied.
1.0.10
16th October 2015
UPDATES
- added
adHocLayout
method to Surface widget. This lets you run a named layout one time on your data.
1.0.9
16th October 2015
UPDATES
- upgrade to Community edition 2.0.3 (changes to Posse dragging, minor bugfixes)
- Removed a number of spurious animations that were unnecessarily occurring while the Surface widget initialised a paint.
1.0.8
12th October 2015
UPDATES
- Upgrade to Community edition 2.0.2 (for documentation improvements)
1.0.7
7th October 2015
UPDATES
- Upgrade to Community edition 2.0.1
- Documentation improvements
1.0.6
6th October 2015
UPDATES
- upgrade to Community edition 2.0.0
- upgrade to Rotors 0.3.5
- nodeUpdated/edgeUpdated/portUpdated events are given the updates that the user passed in (issue 61)
- beforeConnect interceptor gets edgeData as third argument (if some data was returned from beforeStartConnect) (issue 62)
- Add the ability to 'refresh' the set of nodes registered via a
registerDroppableNodes
call on a Surface. - Add
centerOnAndZoom
function toSurface
modelLeftAttribute
andmodelTopAttribute
, which specify the left/top attribute against which to store node positions, now support dotted notation, ie. can refer to a nested element.- Added
zoomToSelection
to Surface widget.
1.0.5
UPDATES
31st August 2015
- Reinstate animation when panning the surface
- Expose
setPan
method on the surface - Support animation in the
setPan
method - Support enableAnimation:false flag in
render
method. default is true. - Upgrade to Community edition 1.7.10 (bugfix for animation when providing 0 as param value)
1.0.4
29th August 2015
UPDATES
- Several improvements to the ingest functionality, including the ability to subsequently ingest new elements.
- Upgrade to Community edition 1.7.9
1.0.3
21st August 2015
UPDATES
- Fix loading issue with directed edges in basic JSON parser.
- Add setDirected method to Edge
- Add tracePath method to Renderer
- Add Path Tracing demo
1.0.2
10th August 2015
UPDATES
- Add
traversePath
method to Surface (andanimateOverlay
method to Connection) - Upgrade to Rotors 0.3.0
- Fix issue in Hierarchical layout in which circular references in the hierarchy cause an infinite loop.
1.0.1
1st August 2015
UPDATES
- Addition of
fixElement
andfloatElement
methods to pan/zoom widget and Surface, and exposing of these methods to the layout decorator functionality.
1.0.0
19th July 2015
Initial release.