diff --git a/plugins/joint.shapes.logic.js b/plugins/joint.shapes.logic.js new file mode 100644 index 000000000..506ed2b9e --- /dev/null +++ b/plugins/joint.shapes.logic.js @@ -0,0 +1,283 @@ +// JointJS library. +// (c) 2011-2013 client IO + + +if (typeof exports === 'object') { + + var joint = { + util: require('../src/core').util, + shapes: { + basic: require('./joint.shapes.basic') + }, + dia: { + Link: require('../src/joint.dia.link').Link + } + }; +} + +joint.shapes.logic = {}; + +joint.shapes.logic.Gate = joint.shapes.basic.Generic.extend({ + + defaults: joint.util.deepSupplement({ + + type: 'logic.Gate', + size: { width: 80, height: 40 }, + attrs: { + '.': { magnet: false }, + '.body': { width: 100, height: 50 }, + circle: { r: 7, stroke: 'black', fill: 'transparent', 'stroke-width': 2 } + } + + }, joint.shapes.basic.Generic.prototype.defaults), + + operation: function() { return true; } +}); + +joint.shapes.logic.IO = joint.shapes.logic.Gate.extend({ + + markup: '', + + defaults: joint.util.deepSupplement({ + + type: 'logic.IO', + size: { width: 60, height: 30 }, + attrs: { + '.body': { fill: 'white', stroke: 'black', 'stroke-width': 2 }, + '.wire': { ref: '.body', 'ref-y': .5, stroke: 'black'}, + text: { + fill: 'black', + ref: '.body', 'ref-x': .5, 'ref-y': .5, 'y-alignment': 'middle', + 'text-anchor': 'middle', + 'font-weight': 'bold', + 'font-variant': 'small-caps', + 'text-transform': 'capitalize', + 'font-size': '14px' + } + } + + }, joint.shapes.logic.Gate.prototype.defaults) + +}); + +joint.shapes.logic.Input = joint.shapes.logic.IO.extend({ + + defaults: joint.util.deepSupplement({ + + type: 'logic.Input', + attrs: { + '.wire': { 'ref-dx': 0, d: 'M 0 0 L 23 0' }, + circle: { ref: '.body', 'ref-dx': 30, 'ref-y': 0.5, magnet: true, 'class': 'output', port: 'out' }, + text: { text: 'input' } + } + + }, joint.shapes.logic.IO.prototype.defaults) +}); + +joint.shapes.logic.Output = joint.shapes.logic.IO.extend({ + + defaults: joint.util.deepSupplement({ + + type: 'logic.Output', + attrs: { + '.wire': { 'ref-x': 0, d: 'M 0 0 L -23 0' }, + circle: { ref: '.body', 'ref-x': -30, 'ref-y': 0.5, magnet: 'passive', 'class': 'input', port: 'in' }, + text: { text: 'output' } + } + + }, joint.shapes.logic.IO.prototype.defaults) + +}); + + +joint.shapes.logic.Gate11 = joint.shapes.logic.Gate.extend({ + + markup: '', + + defaults: joint.util.deepSupplement({ + + type: 'logic.Gate11', + attrs: { + '.input': { ref: '.body', 'ref-x': -2, 'ref-y': 0.5, magnet: 'passive', port: 'in' }, + '.output': { ref: '.body', 'ref-dx': 2, 'ref-y': 0.5, magnet: true, port: 'out' } + } + + }, joint.shapes.logic.Gate.prototype.defaults) +}); + +joint.shapes.logic.Gate21 = joint.shapes.logic.Gate.extend({ + + markup: '', + + defaults: joint.util.deepSupplement({ + + type: 'logic.Gate21', + attrs: { + '.input1': { ref: '.body', 'ref-x': -2, 'ref-y': 0.3, magnet: 'passive', port: 'in1' }, + '.input2': { ref: '.body', 'ref-x': -2, 'ref-y': 0.7, magnet: 'passive', port: 'in2' }, + '.output': { ref: '.body', 'ref-dx': 2, 'ref-y': 0.5, magnet: true, port: 'out' } + } + + }, joint.shapes.logic.Gate.prototype.defaults), + +}); + +joint.shapes.logic.Repeater = joint.shapes.logic.Gate11.extend({ + + defaults: joint.util.deepSupplement({ + + type: 'logic.Repeater', + attrs: { image: { 'xlink:href': '' }} + + }, joint.shapes.logic.Gate11.prototype.defaults), + + operation: function(input) { + return input; + } + +}); + +joint.shapes.logic.Not = joint.shapes.logic.Gate11.extend({ + + defaults: joint.util.deepSupplement({ + + type: 'logic.Not', + attrs: { image: { 'xlink:href': '' }} + + }, joint.shapes.logic.Gate11.prototype.defaults), + + operation: function(input) { + return !input; + } + +}); + +joint.shapes.logic.Or = joint.shapes.logic.Gate21.extend({ + + defaults: joint.util.deepSupplement({ + + type: 'logic.Or', + attrs: { image: { 'xlink:href': '' }} + + }, joint.shapes.logic.Gate21.prototype.defaults), + + operation: function(input1, input2) { + return input1 || input2; + } + +}); + +joint.shapes.logic.And = joint.shapes.logic.Gate21.extend({ + + defaults: joint.util.deepSupplement({ + + type: 'logic.And', + attrs: { image: { 'xlink:href': '' }} + + }, joint.shapes.logic.Gate21.prototype.defaults), + + operation: function(input1, input2) { + return input1 && input2; + } + +}); + +joint.shapes.logic.Nor = joint.shapes.logic.Gate21.extend({ + + defaults: joint.util.deepSupplement({ + + type: 'logic.Nor', + attrs: { image: { 'xlink:href': '' }} + + }, joint.shapes.logic.Gate21.prototype.defaults), + + operation: function(input1, input2) { + return !(input1 || input2); + } + +}); + +joint.shapes.logic.Nand = joint.shapes.logic.Gate21.extend({ + + defaults: joint.util.deepSupplement({ + + type: 'logic.Nand', + attrs: { image: { 'xlink:href': '' }} + + }, joint.shapes.logic.Gate21.prototype.defaults), + + operation: function(input1, input2) { + return !(input1 && input2); + } + +}); + +joint.shapes.logic.Xor = joint.shapes.logic.Gate21.extend({ + + defaults: joint.util.deepSupplement({ + + type: 'logic.Xor', + attrs: { image: { 'xlink:href': '' }} + + }, joint.shapes.logic.Gate21.prototype.defaults), + + operation: function(input1, input2) { + return (!input1 || input2) && (input1 || !input2); + } + +}); + +joint.shapes.logic.Xnor = joint.shapes.logic.Gate21.extend({ + + defaults: joint.util.deepSupplement({ + + type: 'logic.Xnor', + attrs: { image: { 'xlink:href': '' }} + + }, joint.shapes.logic.Gate21.prototype.defaults), + + operation: function(input1, input2) { + return (!input1 || !input2) && (input1 || input2); + } + +}); + +joint.shapes.logic.Wire = joint.dia.Link.extend({ + + arrowheadMarkup: [ + '', + '', + '' + ].join(''), + + vertexMarkup: [ + '', + '', + '', + '', + '', + 'Remove vertex.', + '', + '', + '' + ].join(''), + + defaults: joint.util.deepSupplement({ + + type: 'logic.Wire', + + attrs: { + '.connection': { 'stroke-width': 2 }, + '.marker-vertex': { r: 7 } + }, + + manhattan: true + + }, joint.dia.Link.prototype.defaults) + +}); + +if (typeof exports === 'object') { + + module.exports = joint.shapes.logic; +}