aboutsummaryrefslogtreecommitdiffstats
path: root/src/utils
diff options
context:
space:
mode:
Diffstat (limited to 'src/utils')
-rw-r--r--src/utils/adopter.js156
-rw-r--r--src/utils/methods.js50
-rw-r--r--src/utils/utils.js98
-rw-r--r--src/utils/window.js4
4 files changed, 212 insertions, 96 deletions
diff --git a/src/utils/adopter.js b/src/utils/adopter.js
index 80bfd8a..6e526e3 100644
--- a/src/utils/adopter.js
+++ b/src/utils/adopter.js
@@ -5,136 +5,190 @@ import { globals } from '../utils/window.js'
import Base from '../types/Base.js'
const elements = {}
-export const root = Symbol('root')
+export const root = Symbol( 'root' )
// Method for element creation
-export function makeNode (name) {
+export function makeNode ( name ) {
+
// create element
- return globals.document.createElementNS(ns, name)
+ return globals.document.createElementNS( ns, name )
+
}
-export function makeInstance (element) {
- if (element instanceof Base) return element
+export function makeInstance ( element ) {
+
+ if ( element instanceof Base ) return element
+
+ if ( typeof element === 'object' ) {
+
+ return adopt( element )
- if (typeof element === 'object') {
- return adopt(element)
}
- if (element == null) {
+ if ( element == null ) {
+
return new elements[root]()
+
}
- if (typeof element === 'string' && element.charAt(0) !== '<') {
- return adopt(globals.document.querySelector(element))
+ if ( typeof element === 'string' && element.charAt( 0 ) !== '<' ) {
+
+ return adopt( globals.document.querySelector( element ) )
+
}
- var node = makeNode('svg')
+ var node = makeNode( 'svg' )
node.innerHTML = element
// We can use firstChild here because we know,
// that the first char is < and thus an element
- element = adopt(node.firstChild)
+ element = adopt( node.firstChild )
return element
+
}
-export function nodeOrNew (name, node) {
- return node instanceof globals.window.Node ? node : makeNode(name)
+export function nodeOrNew ( name, node ) {
+
+ return node instanceof globals.window.Node ? node : makeNode( name )
+
}
// Adopt existing svg elements
-export function adopt (node) {
+export function adopt ( node ) {
+
// check for presence of node
- if (!node) return null
+ if ( !node ) return null
// make sure a node isn't already adopted
- if (node.instance instanceof Base) return node.instance
+ if ( node.instance instanceof Base ) return node.instance
+
+ if ( !( node instanceof globals.window.SVGElement ) ) {
+
+ return new elements.HtmlNode( node )
- if (!(node instanceof globals.window.SVGElement)) {
- return new elements.HtmlNode(node)
}
// initialize variables
var element
// adopt with element-specific settings
- if (node.nodeName === 'svg') {
- element = new elements[root](node)
- } else if (node.nodeName === 'linearGradient' || node.nodeName === 'radialGradient') {
- element = new elements.Gradient(node)
- } else if (elements[capitalize(node.nodeName)]) {
- element = new elements[capitalize(node.nodeName)](node)
+ if ( node.nodeName === 'svg' ) {
+
+ element = new elements[root]( node )
+
+ } else if ( node.nodeName === 'linearGradient' || node.nodeName === 'radialGradient' ) {
+
+ element = new elements.Gradient( node )
+
+ } else if ( elements[capitalize( node.nodeName )] ) {
+
+ element = new elements[capitalize( node.nodeName )]( node )
+
} else {
- element = new elements.Bare(node)
+
+ element = new elements.Bare( node )
+
}
return element
+
}
-export function register (element, name = element.name, asRoot = false) {
+export function register ( element, name = element.name, asRoot = false ) {
+
elements[name] = element
- if (asRoot) elements[root] = element
+ if ( asRoot ) elements[root] = element
- addMethodNames(Object.keys(element.prototype))
+ addMethodNames( Object.keys( element.prototype ) )
return element
+
}
-export function getClass (name) {
+export function getClass ( name ) {
+
return elements[name]
+
}
// Element id sequence
let did = 1000
// Get next named element id
-export function eid (name) {
- return 'Svgjs' + capitalize(name) + (did++)
+export function eid ( name ) {
+
+ return 'Svgjs' + capitalize( name ) + ( did++ )
+
}
// Deep new id assignment
-export function assignNewId (node) {
+export function assignNewId ( node ) {
+
// do the same for SVG child nodes as well
- for (var i = node.children.length - 1; i >= 0; i--) {
- assignNewId(node.children[i])
+ for ( var i = node.children.length - 1; i >= 0; i-- ) {
+
+ assignNewId( node.children[i] )
+
}
- if (node.id) {
- return adopt(node).id(eid(node.nodeName))
+ if ( node.id ) {
+
+ return adopt( node ).id( eid( node.nodeName ) )
+
}
- return adopt(node)
+ return adopt( node )
+
}
// Method for extending objects
-export function extend (modules, methods, attrCheck) {
+export function extend ( modules, methods, attrCheck ) {
+
var key, i
- modules = Array.isArray(modules) ? modules : [modules]
+ modules = Array.isArray( modules ) ? modules : [ modules ]
+
+ for ( i = modules.length - 1; i >= 0; i-- ) {
+
+ for ( key in methods ) {
- for (i = modules.length - 1; i >= 0; i--) {
- for (key in methods) {
let method = methods[key]
- if (attrCheck) {
- method = wrapWithAttrCheck(methods[key])
+ if ( attrCheck ) {
+
+ method = wrapWithAttrCheck( methods[key] )
+
}
modules[i].prototype[key] = method
+
}
+
}
+
}
-export function extendWithAttrCheck (...args) {
- extend(...args, true)
+export function extendWithAttrCheck ( ...args ) {
+
+ extend( ...args, true )
+
}
-export function wrapWithAttrCheck (fn) {
- return function (...args) {
+export function wrapWithAttrCheck ( fn ) {
+
+ return function ( ...args ) {
+
let o = args[args.length - 1]
- if (o && o.constructor === Object && !(o instanceof Array)) {
- return fn.apply(this, args.slice(0, -1)).attr(o)
+ if ( o && o.constructor === Object && !( o instanceof Array ) ) {
+
+ return fn.apply( this, args.slice( 0, -1 ) ).attr( o )
+
} else {
- return fn.apply(this, args)
+
+ return fn.apply( this, args )
+
}
+
}
+
}
diff --git a/src/utils/methods.js b/src/utils/methods.js
index 70f9329..4973d13 100644
--- a/src/utils/methods.js
+++ b/src/utils/methods.js
@@ -2,41 +2,61 @@ const methods = {}
const constructors = {}
const names = []
-export function registerMethods (name, m) {
- if (Array.isArray(name)) {
- for (let _name of name) {
- registerMethods(_name, m)
+export function registerMethods ( name, m ) {
+
+ if ( Array.isArray( name ) ) {
+
+ for ( let _name of name ) {
+
+ registerMethods( _name, m )
+
}
return
+
}
- if (typeof name === 'object') {
- for (let [_name, _m] of Object.entries(name)) {
- registerMethods(_name, _m)
+ if ( typeof name === 'object' ) {
+
+ for ( let [ _name, _m ] of Object.entries( name ) ) {
+
+ registerMethods( _name, _m )
+
}
return
+
}
- addMethodNames(Object.keys(m))
- methods[name] = Object.assign(methods[name] || {}, m)
+ addMethodNames( Object.keys( m ) )
+ methods[name] = Object.assign( methods[name] || {}, m )
+
}
-export function getMethodsFor (name) {
+export function getMethodsFor ( name ) {
+
return methods[name] || {}
+
}
export function getMethodNames () {
- return [...new Set(names)]
+
+ return [ ...new Set( names ) ]
+
}
-export function addMethodNames (_names) {
- names.push(..._names)
+export function addMethodNames ( _names ) {
+
+ names.push( ..._names )
+
}
-export function registerConstructor (name, setup) {
+export function registerConstructor ( name, setup ) {
+
constructors[name] = setup
+
}
-export function getConstructor (name) {
+export function getConstructor ( name ) {
+
return constructors[name] ? { setup: constructors[name], name } : {}
+
}
diff --git a/src/utils/utils.js b/src/utils/utils.js
index 64c0eed..01cd49f 100644
--- a/src/utils/utils.js
+++ b/src/utils/utils.js
@@ -1,103 +1,143 @@
// Map function
-export function map (array, block) {
+export function map ( array, block ) {
+
var i
var il = array.length
var result = []
- for (i = 0; i < il; i++) {
- result.push(block(array[i]))
+ for ( i = 0; i < il; i++ ) {
+
+ result.push( block( array[i] ) )
+
}
return result
+
}
// Filter function
-export function filter (array, block) {
+export function filter ( array, block ) {
+
var i
var il = array.length
var result = []
- for (i = 0; i < il; i++) {
- if (block(array[i])) { result.push(array[i]) }
+ for ( i = 0; i < il; i++ ) {
+
+ if ( block( array[i] ) ) {
+
+ result.push( array[i] )
+
+ }
+
}
return result
+
}
// Degrees to radians
-export function radians (d) {
+export function radians ( d ) {
+
return d % 360 * Math.PI / 180
+
}
// Radians to degrees
-export function degrees (r) {
+export function degrees ( r ) {
+
return r * 180 / Math.PI % 360
+
}
// Convert dash-separated-string to camelCase
-export function camelCase (s) {
- return s.toLowerCase().replace(/-(.)/g, function (m, g) {
+export function camelCase ( s ) {
+
+ return s.toLowerCase().replace( /-(.)/g, function ( m, g ) {
+
return g.toUpperCase()
- })
+
+ } )
+
}
// Convert camel cased string to string seperated
-export function unCamelCase (s) {
- return s.replace(/([A-Z])/g, function (m, g) {
+export function unCamelCase ( s ) {
+
+ return s.replace( /([A-Z])/g, function ( m, g ) {
+
return '-' + g.toLowerCase()
- })
+
+ } )
+
}
// Capitalize first letter of a string
-export function capitalize (s) {
- return s.charAt(0).toUpperCase() + s.slice(1)
+export function capitalize ( s ) {
+
+ return s.charAt( 0 ).toUpperCase() + s.slice( 1 )
+
}
// Calculate proportional width and height values when necessary
-export function proportionalSize (element, width, height) {
- if (width == null || height == null) {
+export function proportionalSize ( element, width, height ) {
+
+ if ( width == null || height == null ) {
+
var box = element.bbox()
- if (width == null) {
+ if ( width == null ) {
+
width = box.width / box.height * height
- } else if (height == null) {
+
+ } else if ( height == null ) {
+
height = box.height / box.width * width
+
}
+
}
return {
width: width,
height: height
}
+
}
-export function getOrigin (o, element) {
+export function getOrigin ( o, element ) {
+
// Allow origin or around as the names
let origin = o.origin // o.around == null ? o.origin : o.around
let ox, oy
// Allow the user to pass a string to rotate around a given point
- if (typeof origin === 'string' || origin == null) {
+ if ( typeof origin === 'string' || origin == null ) {
+
// Get the bounding box of the element with no transformations applied
- const string = (origin || 'center').toLowerCase().trim()
+ const string = ( origin || 'center' ).toLowerCase().trim()
const { height, width, x, y } = element.bbox()
// Calculate the transformed x and y coordinates
- let bx = string.includes('left') ? x
- : string.includes('right') ? x + width
- : x + width / 2
- let by = string.includes('top') ? y
- : string.includes('bottom') ? y + height
- : y + height / 2
+ let bx = string.includes( 'left' ) ? x
+ : string.includes( 'right' ) ? x + width
+ : x + width / 2
+ let by = string.includes( 'top' ) ? y
+ : string.includes( 'bottom' ) ? y + height
+ : y + height / 2
// Set the bounds eg : "bottom-left", "Top right", "middle" etc...
ox = o.ox != null ? o.ox : bx
oy = o.oy != null ? o.oy : by
+
} else {
+
ox = origin[0]
oy = origin[1]
+
}
// Return the origin as it is if it wasn't a string
return [ ox, oy ]
+
}
diff --git a/src/utils/window.js b/src/utils/window.js
index 9e51339..55f0bb6 100644
--- a/src/utils/window.js
+++ b/src/utils/window.js
@@ -3,7 +3,9 @@ export const globals = {
document: typeof document === 'undefined' ? null : document
}
-export function registerWindow (win = null, doc = null) {
+export function registerWindow ( win = null, doc = null ) {
+
globals.window = win
globals.document = doc
+
}