aboutsummaryrefslogtreecommitdiffstats
path: root/src/Parent.js
blob: ce22f803055583dc8c0d2fe35a872d2df2247d10 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
import {makeInstance} from './helpers.js'
import Element from './Element.js'
import {adopt} from './tools.js'
import {map} from './utils.js'

export default class Parent extends Element {
  // Returns all child elements
  children () {
    return map(this.node.children, function (node) {
      return adopt(node)
    })
  }

  // Add given element at a position
  add (element, i) {
    element = makeInstance(element)

    if (element.node !== this.node.children[i]) {
      this.node.insertBefore(element.node, this.node.children[i] || null)
    }

    return this
  }

  // Basically does the same as `add()` but returns the added element instead
  put (element, i) {
    this.add(element, i)
    return element.instance || element
  }

  // Checks if the given element is a child
  has (element) {
    return this.index(element) >= 0
  }

  // Gets index of given element
  index (element) {
    return [].slice.call(this.node.children).indexOf(element.node)
  }

  // Get a element at the given index
  get (i) {
    return adopt(this.node.children[i])
  }

  // Get first child
  first () {
    return this.get(0)
  }

  // Get the last child
  last () {
    return this.get(this.node.children.length - 1)
  }

  // Iterates over all children and invokes a given block
  each (block, deep) {
    var children = this.children()
    var i, il

    for (i = 0, il = children.length; i < il; i++) {
      if (children[i] instanceof Element) {
        block.apply(children[i], [i, children])
      }

      if (deep && (children[i] instanceof Parent)) {
        children[i].each(block, deep)
      }
    }

    return this
  }

  // Remove a given child
  removeElement (element) {
    this.node.removeChild(element.node)

    return this
  }

  // Remove all elements in this container
  clear () {
    // remove children
    while (this.node.hasChildNodes()) {
      this.node.removeChild(this.node.lastChild)
    }

    // remove defs reference
    delete this._defs

    return this
  }
}