add Index() methods

This commit is contained in:
Martin Angers
2012-08-30 17:24:18 -04:00
parent fe36d7039a
commit 85ad689f6a
3 changed files with 93 additions and 4 deletions

View File

@@ -41,3 +41,49 @@ func (this *Selection) Get(index int) *html.Node {
} }
return this.Nodes[index] return this.Nodes[index]
} }
// Index() returns the position of the first element within the Selection object relative to
// its sibling elements.
func (this *Selection) Index() int {
// TODO : Eventually refactor with prevAll(), like jQuery's code
if len(this.Nodes) > 0 {
n := this.Nodes[0]
if p := n.Parent; p != nil {
var i = 0
for _, c := range p.Child {
if c == n {
// This is the index of the element
return i
} else if c.Type == html.ElementNode {
i++
}
}
}
}
return -1
}
// IndexSelector() returns the position of the first element within the Selection object
// relative to the elements matched by the selector, or -1 if not found.
func (this *Selection) IndexSelector(selector string) int {
if len(this.Nodes) > 0 {
sel := this.document.Find(selector)
return indexInSlice(sel.Nodes, this.Nodes[0])
}
return -1
}
// IndexOfNode() returns the position of the specified node within the Selection object,
// or -1 if not found.
func (this *Selection) IndexOfNode(node *html.Node) int {
return indexInSlice(this.Nodes, node)
}
// IndexOfSelection() returns the position of the first node in the specified Selection object
// within this Selection object, or -1 if not found.
func (this *Selection) IndexOfSelection(s *Selection) int {
if len(s.Nodes) > 0 {
return indexInSlice(this.Nodes, s.Nodes[0])
}
return -1
}

View File

@@ -93,3 +93,39 @@ func TestGetInvalid(t *testing.T) {
sel := doc.Find(".pvk-content") sel := doc.Find(".pvk-content")
sel.Get(129) sel.Get(129)
} }
func TestIndex(t *testing.T) {
sel := doc.Find(".pvk-content")
if i := sel.Index(); i != 1 {
t.Errorf("Expected index of 1, got %v.", i)
}
}
func TestIndexSelector(t *testing.T) {
sel := doc.Find(".hero-unit")
if i := sel.IndexSelector("div"); i != 4 {
t.Errorf("Expected index of 4, got %v.", i)
}
}
func TestIndexOfNode(t *testing.T) {
sel := doc.Find("div.pvk-gutter")
if i := sel.IndexOfNode(sel.Nodes[1]); i != 1 {
t.Errorf("Expected index of 1, got %v.", i)
}
}
func TestIndexOfNilNode(t *testing.T) {
sel := doc.Find("div.pvk-gutter")
if i := sel.IndexOfNode(nil); i != -1 {
t.Errorf("Expected index of -1, got %v.", i)
}
}
func TestIndexOfSelection(t *testing.T) {
sel := doc.Find("div")
sel2 := doc.Find(".hero-unit")
if i := sel.IndexOfSelection(sel2); i != 4 {
t.Errorf("Expected index of 4, got %v.", i)
}
}

View File

@@ -47,12 +47,19 @@ func nodeContains(container *html.Node, contained *html.Node) bool {
// Checks if the target node is in the slice of nodes. // Checks if the target node is in the slice of nodes.
func isInSlice(slice []*html.Node, node *html.Node) bool { func isInSlice(slice []*html.Node, node *html.Node) bool {
for _, n := range slice { return indexInSlice(slice, node) > -1
if n == node { }
return true
// Returns the index of the target node in the slice, or -1.
func indexInSlice(slice []*html.Node, node *html.Node) int {
if node != nil {
for i, n := range slice {
if n == node {
return i
}
} }
} }
return false return -1
} }
// Appends the new nodes to the target slice, making sure no duplicate is added. // Appends the new nodes to the target slice, making sure no duplicate is added.