/** * This object contains all possible options. It will check if the types are correct, if required if the option is one * of the allowed values. * * __any__ means that the name of the property does not matter. * __type__ is a required field for all objects and contains the allowed types of all objects */ let string = 'string'; let boolean = 'boolean'; let number = 'number'; let array = 'array'; let object = 'object'; let dom = 'dom'; let fn = 'function'; let undef = 'undefined'; let allOptions = { canvas: { width: {string}, height: {string}, autoResize: {boolean}, __type__: {object} }, rendering: { hideEdgesOnDrag: {boolean}, hideNodesOnDrag: {boolean}, __type__: {object} }, clustering: {}, configure: { enabled: {boolean}, filter: {boolean,string:['nodes','edges','layout','physics','manipulation','interaction','selection','rendering'],array}, container: {dom}, __type__: {object,boolean,string:['nodes','edges','layout','physics','manipulation','interaction','selection','rendering'],array} }, edges: { arrows: { to: {enabled: {boolean}, scaleFactor: {number}, __type__: {object}}, middle: {enabled: {boolean}, scaleFactor: {number}, __type__: {object}}, from: {enabled: {boolean}, scaleFactor: {number}, __type__: {object}}, __type__: {string:['from','to','middle'],object} }, color: { color: {string}, highlight: {string}, hover: {string}, inherit: {string:['from','to','both'],boolean}, opacity: {number}, __type__: {object} }, dashes: { enabled: {boolean}, pattern: {array}, __type__: {boolean,object} }, font: { color: {string}, size: {number}, // px face: {string}, background: {string}, stroke: {number}, // px strokeColor: {string}, align: {string:['horizontal','top','middle','bottom']}, __type__: {object,string} }, hidden: {boolean}, hoverWidth: {fn,number}, label: {string,undef}, length: {number,undef}, physics: {boolean}, scaling: { min: {number}, max: {number}, label: { enabled: {boolean}, min: {number}, max: {number}, maxVisible: {number}, drawThreshold: {number}, __type__: {object,boolean} }, customScalingFunction: {fn}, __type__: {object} }, selectionWidth: {fn,number}, selfReferenceSize: {number}, shadow: { enabled: {boolean}, size: {number}, x: {number}, y: {number}, __type__: {object,boolean} }, smooth: { enabled: {boolean}, dynamic: {boolean}, type: {string}, roundness: {number}, __type__: {object,boolean} }, title: {string, undef}, width: {number}, value: {number, undef}, __type__: {object} }, groups: { useDefaultGroups: {boolean}, __any__: ['__ref__','nodes'], __type__: {object} }, interaction: { dragNodes: {boolean}, dragView: {boolean}, zoomView: {boolean}, hoverEnabled: {boolean}, navigationButtons: {boolean}, tooltipDelay: {number}, keyboard: { enabled: {boolean}, speed: {x: {number}, y: {number}, zoom: {number}, __type__: {object}}, bindToWindow: {boolean}, __type__: {object,boolean} }, __type__: {object} }, layout: { randomSeed: {undef,number}, hierarchical: { enabled: {boolean}, levelSeparation: {number}, direction: {string:['UD','DU','LR','RL']}, // UD, DU, LR, RL sortMethod: {string:['hubsize','directed']}, // hubsize, directed __type__: {object,boolean} }, __type__: {object} }, manipulation: { enabled: {boolean}, initiallyActive: {boolean}, locale: {string}, locales: {object}, addNode: {boolean,fn}, addEdge: {boolean,fn}, editNode: {fn}, editEdge: {boolean,fn}, deleteNode: {boolean,fn}, deleteEdge: {boolean,fn}, controlNodeStyle: ['__ref__','nodes'], __type__: {object,boolean} }, nodes: { borderWidth: {number}, borderWidthSelected: {number,undef}, brokenImage: {string,undef}, color: { border: {string}, background: {string}, highlight: { border: {string}, background: {string}, __type__: {object,string} }, hover: { border: {string}, background: {string}, __type__: {object,string} }, __type__: {object,string} }, fixed: { x: {boolean}, y: {boolean}, __type__: {object,boolean} }, font: { color: {string}, size: {number}, // px face: {string}, background: {string}, stroke: {number}, // px strokeColor: {string}, __type__: {object,string} }, group: {string,number,undef}, hidden: {boolean}, icon: { face: {string}, code: {string}, //'\uf007', size: {number}, //50, color: {string}, __type__: {object} }, id: {string, number}, image: {string,undef}, // --> URL label: {string,undef}, level: {number,undef}, mass: {number}, physics: {boolean}, scaling: { min: {number}, max: {number}, label: { enabled: {boolean}, min: {number}, max: {number}, maxVisible: {number}, drawThreshold: {number}, __type__: {object, boolean} }, customScalingFunction: {fn}, __type__: {object} }, shadow: { enabled: {boolean}, size: {number}, x: {number}, y: {number}, __type__: {object,boolean} }, shape: {string:['ellipse', 'circle', 'database', 'box', 'text','image', 'circularImage','diamond', 'dot', 'star', 'triangle','triangleDown', 'square','icon']}, size: {number}, title: {string,undef}, value: {number,undef}, x: {number}, y: {number}, __type__: {object} }, physics: { barnesHut: { gravitationalConstant: {number}, centralGravity: {number}, springLength: {number}, springConstant: {number}, damping: {number}, __type__: {object} }, repulsion: { centralGravity: {number}, springLength: {number}, springConstant: {number}, nodeDistance: {number}, damping: {number}, __type__: {object} }, hierarchicalRepulsion: { centralGravity: {number}, springLength: {number}, springConstant: {number}, nodeDistance: {number}, damping: {number}, __type__: {object} }, maxVelocity: {number}, minVelocity: {number}, // px/s solver: {string:['barnesHut','repulsion','hierarchicalRepulsion']}, stabilization: { enabled: {boolean}, iterations: {number}, // maximum number of iteration to stabilize updateInterval: {number}, onlyDynamicEdges: {boolean}, fit: {boolean}, __type__: {object,boolean} }, timestep: {number}, __type__: {object,boolean} }, selection: { selectable: {boolean}, selectConnectedEdges: {boolean}, __type__: {object} }, view: {}, __type__: {object} }; allOptions.groups.__any__ = allOptions.nodes; allOptions.manipulation.controlNodeStyle = allOptions.nodes; let configureOptions = { nodes: { borderWidth: [1, 0, 10, 1], borderWidthSelected: [2, 0, 10, 1], color: { border: ['color','#2B7CE9'], background: ['color','#97C2FC'], highlight: { border: ['color','#2B7CE9'], background: ['color','#D2E5FF'] }, hover: { border: ['color','#2B7CE9'], background: ['color','#D2E5FF'] } }, fixed: { x: false, y: false }, font: { color: ['color','#343434'], size: [14, 0, 100, 1], // px face: ['arial', 'verdana', 'tahoma'], background: ['color','none'], stroke: [0, 0, 50, 1], // px strokeColor: ['color','#ffffff'] }, //group: 'string', hidden: false, //icon: { // face: 'string', //'FontAwesome', // code: 'string', //'\uf007', // size: [50, 0, 200, 1], //50, // color: ['color','#2B7CE9'] //'#aa00ff' //}, //image: 'string', // --> URL physics: true, scaling: { min: [10, 0, 200, 1], max: [30, 0, 200, 1], label: { enabled: true, min: [14, 0, 200, 1], max: [30, 0, 200, 1], maxVisible: [30, 0, 200, 1], drawThreshold: [3, 0, 20, 1] } }, shadow:{ enabled: false, size:[10, 0, 20, 1], x:[5, -30, 30, 1], y:[5, -30, 30, 1] }, shape: ['ellipse', 'box', 'circle', 'database', 'diamond', 'dot', 'square', 'star', 'text', 'triangle', 'triangleDown'], size: [25, 0, 200, 1] }, edges: { arrows: { to: {enabled: false, scaleFactor: [1, 0, 3, 0.05]}, // boolean / {arrowScaleFactor:1} / {enabled: false, arrowScaleFactor:1} middle: {enabled: false, scaleFactor: [1, 0, 3, 0.05]}, from: {enabled: false, scaleFactor: [1, 0, 3, 0.05]} }, color: { color: ['color','#848484'], highlight: ['color','#848484'], hover: ['color','#848484'], inherit: ['from','to','both',true, false], opacity: [1, 0, 1, 0.05] }, dashes: false, font: { color: ['color','#343434'], size: [14, 0, 100, 1], // px face: ['arial', 'verdana', 'tahoma'], background: ['color','none'], stroke: [1, 0, 50, 1], // px strokeColor: ['color','#ffffff'], align: ['horizontal', 'top', 'middle', 'bottom'] }, hidden: false, hoverWidth: [2, 0, 5, 0.1], physics: true, scaling: { min: [1, 0, 100, 1], max: [15, 0, 100, 1], label: { enabled: true, min: [14, 0, 200, 1], max: [30, 0, 200, 1], maxVisible: [30, 0, 200, 1], drawThreshold: [3, 0, 20, 1] } }, selectionWidth: [1.5, 0, 5, 0.1], selfReferenceSize: [20, 0, 200, 1], shadow:{ enabled: false, size:[10, 0, 20, 1], x:[5, -30, 30, 1], y:[5, -30, 30, 1] }, smooth: { enabled: true, dynamic: true, type: ['continuous', 'discrete', 'diagonalCross', 'straightCross', 'horizontal', 'vertical', 'curvedCW', 'curvedCCW'], roundness: [0.5, 0, 1, 0.05] }, width: [1, 0, 30, 1] }, layout: { randomSeed: [0, 0, 500, 1], hierarchical: { enabled: false, levelSeparation: [150, 20, 500, 5], direction: ['UD', 'DU', 'LR', 'RL'], // UD, DU, LR, RL sortMethod: ['hubsize', 'directed'] // hubsize, directed } }, interaction: { dragNodes: true, dragView: true, zoomView: true, hoverEnabled: false, navigationButtons: false, tooltipDelay: [300, 0, 1000, 25], keyboard: { enabled: false, speed: {x: [10, 0, 40, 1], y: [10, 0, 40, 1], zoom: [0.02, 0, 0.1, 0.005]}, bindToWindow: true } }, manipulation: { enabled: false, initiallyActive: false, locale: ['en', 'nl'] }, physics: { barnesHut: { //theta: [0.5, 0.1, 1, 0.05], gravitationalConstant: [-2000, -30000, 0, 50], centralGravity: [0.3, 0, 10, 0.05], springLength: [95, 0, 500, 5], springConstant: [0.04, 0, 5, 0.005], damping: [0.09, 0, 1, 0.01] }, repulsion: { centralGravity: [0.2, 0, 10, 0.05], springLength: [200, 0, 500, 5], springConstant: [0.05, 0, 5, 0.005], nodeDistance: [100, 0, 500, 5], damping: [0.09, 0, 1, 0.01] }, hierarchicalRepulsion: { centralGravity: [0.2, 0, 10, 0.05], springLength: [100, 0, 500, 5], springConstant: [0.01, 0, 5, 0.005], nodeDistance: [120, 0, 500, 5], damping: [0.09, 0, 1, 0.01] }, maxVelocity: [50, 0, 150, 1], minVelocity: [0.1, 0.01, 0.5, 0.01], solver: ['barnesHut', 'repulsion', 'hierarchicalRepulsion'], timestep: [0.5, 0, 1, 0.05] }, selection: { selectable: true, selectConnectedEdges: true }, rendering: { hideEdgesOnDrag: false, hideNodesOnDrag: false } }; export {allOptions, configureOptions};