From 62025c490d9158d780dcb973680a3f3907e87e8e Mon Sep 17 00:00:00 2001 From: josdejong Date: Sun, 24 May 2020 16:02:04 +0200 Subject: [PATCH] Implemented option `limitDragging`, see #962 --- HISTORY.md | 6 ++++++ docs/api.md | 8 ++++++-- src/js/JSONEditor.js | 2 +- src/js/Node.js | 11 +++++++++-- src/js/treemode.js | 6 ++++++ test/test_build.html | 3 ++- 6 files changed, 30 insertions(+), 6 deletions(-) diff --git a/HISTORY.md b/HISTORY.md index 91e97b969..9034eef88 100644 --- a/HISTORY.md +++ b/HISTORY.md @@ -3,6 +3,12 @@ https://github.com/josdejong/jsoneditor +## not yet published, version 9.0.0 + +- Implemented option `limitDragging`, see #962. This is a breaking change when + using a JSON schema: dragging is restricted in that case. + + ## 2020-05-13, version 8.6.8 - Fix #936: too many return characters inserted when pasting formatted text diff --git a/docs/api.md b/docs/api.md index ef47c3cea..c0d1f126c 100644 --- a/docs/api.md +++ b/docs/api.md @@ -222,11 +222,15 @@ Constructs a new JSONEditor. - `{boolean} escapeUnicode` - If true, unicode characters are escaped and displayed as their hexadecimal code (like `\u260E`) instead of of the character itself (like `☎`). `false` by default. + If `true`, unicode characters are escaped and displayed as their hexadecimal code (like `\u260E`) instead of of the character itself (like `☎`). `false` by default. - `{boolean} sortObjectKeys` - If true, object keys in 'tree', 'view' or 'form' mode list be listed alphabetically instead by their insertion order. Sorting is performed using a natural sort algorithm, which makes it easier to see objects that have string numbers as keys. `false` by default. + If `true`, object keys in 'tree', 'view' or 'form' mode list be listed alphabetically instead by their insertion order. Sorting is performed using a natural sort algorithm, which makes it easier to see objects that have string numbers as keys. `false` by default. + +- `{boolean} limitDragging` + + If `false`, nodes can be dragged from any parent node to any other parent node. If `true`, nodes can only be dragged inside the same parent node, which effectively only allows reordering of nodes. By default, `limitDragging` is `true` when no JSON `schema` is defined, and `false` otherwise. - `{boolean} history` diff --git a/src/js/JSONEditor.js b/src/js/JSONEditor.js index a5b026e4e..b7fb38556 100644 --- a/src/js/JSONEditor.js +++ b/src/js/JSONEditor.js @@ -184,7 +184,7 @@ JSONEditor.VALID_OPTIONS = [ 'colorPicker', 'onColorPicker', 'timestampTag', 'timestampFormat', 'escapeUnicode', 'history', 'search', 'mode', 'modes', 'name', 'indentation', - 'sortObjectKeys', 'navigationBar', 'statusBar', 'mainMenuBar', 'languages', 'language', 'enableSort', 'enableTransform', + 'sortObjectKeys', 'navigationBar', 'statusBar', 'mainMenuBar', 'languages', 'language', 'enableSort', 'enableTransform', 'limitDragging', 'maxVisibleChilds', 'onValidationError', 'modalAnchor', 'popupAnchor', 'createQuery', 'executeQuery', 'queryDescription' diff --git a/src/js/Node.js b/src/js/Node.js index a5fea7810..ba5d5a3fd 100644 --- a/src/js/Node.js +++ b/src/js/Node.js @@ -4209,7 +4209,10 @@ Node.onDrag = (nodes, event) => { } } - if (nodePrev) { + if ( + nodePrev && + (editor.options.limitDragging === false || nodePrev.parent === nodes[0].parent) + ) { nodes.forEach(node => { nodePrev.parent.moveBefore(node, nodePrev) }) @@ -4285,7 +4288,11 @@ Node.onDrag = (nodes, event) => { } // move the node when its position is changed - if (nodeNext && nodeNext.dom.tr && trLast.nextSibling !== nodeNext.dom.tr) { + if ( + nodeNext && + (editor.options.limitDragging === false || nodeNext.parent === nodes[0].parent) && + nodeNext.dom.tr && nodeNext.dom.tr !== trLast.nextSibling + ) { nodes.forEach(node => { nodeNext.parent.moveBefore(node, nodeNext) }) diff --git a/src/js/treemode.js b/src/js/treemode.js index 1eae6d9c7..b8c748a5a 100644 --- a/src/js/treemode.js +++ b/src/js/treemode.js @@ -127,6 +127,7 @@ treemode._setOptions = function (options) { autocomplete: null, navigationBar: true, mainMenuBar: true, + limitDragging: false, onSelectionChange: null, colorPicker: true, onColorPicker: function (parent, color, onChange) { @@ -169,6 +170,11 @@ treemode._setOptions = function (options) { Object.keys(options).forEach(prop => { this.options[prop] = options[prop] }) + + // default limitDragging to true when a JSON schema is defined + if (options.limitDragging == null && options.schema != null) { + this.options.limitDragging = true + } } // compile a JSON schema validator if a JSON schema is provided diff --git a/test/test_build.html b/test/test_build.html index 6119366ab..8945378c3 100644 --- a/test/test_build.html +++ b/test/test_build.html @@ -71,7 +71,8 @@ console.log("Blur : ",event); }, indentation: 4, - escapeUnicode: true + escapeUnicode: true, + limitDragging: true }; json = {