2014-02-14 15:25:39 -06:00
// 14 february 2014
2014-02-19 10:41:10 -06:00
package ui
2014-02-14 15:25:39 -06:00
import (
"sync"
)
// A Listbox is a vertical list of items, of which one or (optionally) more items can be selected at any given time.
type Listbox struct {
// TODO Select event
lock sync . Mutex
created bool
sysData * sysData
initItems [ ] string
}
// NewCombobox makes a new combobox with the given items. If multiple is true, the listbox allows multiple selection.
func NewListbox ( multiple bool , items ... string ) ( l * Listbox ) {
l = & Listbox {
sysData : mksysdata ( c_listbox ) ,
initItems : items ,
}
l . sysData . alternate = multiple
return l
}
2014-02-15 16:59:12 -06:00
// Append adds an item to the end of the Listbox's list.
func ( l * Listbox ) Append ( what string ) ( err error ) {
l . lock . Lock ( )
defer l . lock . Unlock ( )
if l . created {
return l . sysData . append ( what )
}
l . initItems = append ( l . initItems , what )
return nil
}
// InsertBefore inserts a new item in the Listbox before the item at the given position.
func ( l * Listbox ) InsertBefore ( what string , before int ) ( err error ) {
l . lock . Lock ( )
defer l . lock . Unlock ( )
if l . created {
return l . sysData . insertBefore ( what , before )
}
m := make ( [ ] string , 0 , len ( l . initItems ) + 1 )
m = append ( m , l . initItems [ : before ] ... )
m = append ( m , what )
l . initItems = append ( m , l . initItems [ before : ] ... )
return nil
}
2014-02-14 15:25:39 -06:00
2014-02-15 17:14:43 -06:00
// Delete removes the given item from the Listbox.
func ( l * Listbox ) Delete ( index int ) error {
l . lock . Lock ( )
defer l . lock . Unlock ( )
if l . created {
return l . sysData . delete ( index )
}
l . initItems = append ( l . initItems [ : index ] , l . initItems [ index + 1 : ] ... )
return nil
}
2014-02-15 17:36:14 -06:00
// Selection returns a list of strings currently selected in the Listbox, or an empty list if none have been selected. This list will have at most one item on a single-selection Listbox.
func ( l * Listbox ) Selection ( ) [ ] string {
l . lock . Lock ( )
defer l . lock . Unlock ( )
if l . created {
return l . sysData . selectedTexts ( )
}
return nil
}
2014-02-14 15:25:39 -06:00
2014-02-15 17:36:14 -06:00
// SelectedIndices returns a list of the currently selected indexes in the Listbox, or an empty list if none have been selected. This list will have at most one item on a single-selection Listbox.
func ( l * Listbox ) SelectedIndices ( ) [ ] int {
l . lock . Lock ( )
defer l . lock . Unlock ( )
if l . created {
return l . sysData . selectedIndices ( )
}
return nil
}
2014-02-14 15:25:39 -06:00
func ( l * Listbox ) make ( window * sysData ) ( err error ) {
l . lock . Lock ( )
defer l . lock . Unlock ( )
2014-02-15 12:07:46 -06:00
err = l . sysData . make ( "" , window )
2014-02-14 15:25:39 -06:00
if err != nil {
return err
}
for _ , s := range l . initItems {
err = l . sysData . append ( s )
if err != nil {
return err
}
}
2014-02-14 19:41:36 -06:00
l . created = true
2014-02-14 15:25:39 -06:00
return nil
}
func ( l * Listbox ) setRect ( x int , y int , width int , height int ) error {
l . lock . Lock ( )
defer l . lock . Unlock ( )
return l . sysData . setRect ( x , y , width , height )
}
2014-02-24 09:56:35 -06:00
func ( l * Listbox ) preferredSize ( ) ( width int , height int , err error ) {
l . lock . Lock ( )
defer l . lock . Unlock ( )
width , height = l . sysData . preferredSize ( )
return
}