All Downloads are FREE. Search and download functionalities are using the official Maven repository.

scalafx.scene.control.MultipleSelectionModel.scala Maven / Gradle / Ivy

/*
 * Copyright (c) 2011-2019, ScalaFX Project
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *     * Redistributions of source code must retain the above copyright
 *       notice, this list of conditions and the following disclaimer.
 *     * Redistributions in binary form must reproduce the above copyright
 *       notice, this list of conditions and the following disclaimer in the
 *       documentation and/or other materials provided with the distribution.
 *     * Neither the name of the ScalaFX Project nor the
 *       names of its contributors may be used to endorse or promote products
 *       derived from this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED. IN NO EVENT SHALL THE SCALAFX PROJECT OR ITS CONTRIBUTORS BE LIABLE
 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */
package scalafx.scene.control

import javafx.scene.{control => jfxsc}
import scalafx.Includes._
import scalafx.beans.property.ObjectProperty
import scalafx.collections.ObservableBuffer
import scalafx.delegate.SFXDelegate

import scala.language.implicitConversions

object MultipleSelectionModel {
  implicit def sfxMultipleSelectionModel2jfx[T](v: MultipleSelectionModel[T]): jfxsc.MultipleSelectionModel[T] =
    if (v != null) v.delegate else null
}

abstract class MultipleSelectionModel[T](override val delegate: jfxsc.MultipleSelectionModel[T])
  extends SelectionModel[T](delegate)
  with SFXDelegate[jfxsc.MultipleSelectionModel[T]] {

  /**
   * Specifies the selection mode to use in this selection model. 
   * The selection mode specifies how many items in the underlying data model 
   * can be selected at
   * any one time.
   *
   * By default, the selection mode is SelectionMode.SINGLE.
   */
  def selectionMode: ObjectProperty[jfxsc.SelectionMode] = delegate.selectionModeProperty

  def selectionMode_=(v: SelectionMode): Unit = {
    selectionMode() = v
  }

  /**
   * Returns a read-only ObservableList of all selected indices. The 
   * ObservableList will be updated by the selection model to always reflect 
   * changes in selection. This can be observed by adding a ListChangeListener 
   * to the returned ObservableList.
   */
  def selectedIndices: ObservableBuffer[Integer] = delegate.getSelectedIndices

  /**
   * Returns a read-only ObservableList of all selected items. The 
   * ObservableList will be updated further by the selection model to always 
   * reflect changes in selection. This can be observed by adding a 
   * ListChangeListener to the returned ObservableList.
   */
  def selectedItems: ObservableBuffer[T] = delegate.getSelectedItems

  /**
   * This method allows for one or more selections to be set at the same time. 
   * It will ignore any value that is not within the valid range (i.e. greater 
   * than or equal to zero, and less than the total number of items in the 
   * underlying data model). Any duplication of indices will be ignored.
   *
   * If there is already one or more indices selected in this model, calling 
   * this method will not clear these selections - to do so it is necessary to 
   * first call clearSelection.
   *
   * The last valid value given will become the selected index / selected item.
   *
   */
  // To convert Scala varargs to Java varargs, see http://stackoverflow.com/questions/2334200/transforming-scala-varargs-into-java-object-varargs
  def selectIndices(index: Int, indices: Int*): Unit = {
    delegate.selectIndices(index, indices.map(_.asInstanceOf[Int]): _*)
  }

  /**
   * Selects all indices from the given start index to the item before the 
   * given end index. This means that the selection is inclusive of the start 
   * index, and exclusive of the end index. This method will work regardless 
   * of whether start < end or start > end: the only constant is that the index 
   * before the given end index will become the selected index.
   *
   * If there is already one or more indices selected in this model, calling 
   * this method will not clear these selections - to do so it is necessary to 
   * first call clearSelection.
   *
   * @param start The first index to select - this index will be selected.
   * @param end The last index of the selection - this index will not be selected.
   */
  def selectRange(start: Int, end: Int): Unit = {
    delegate.selectRange(start, end)
  }

  /**
   * Convenience method to select all available indices.
   */
  def selectAll(): Unit = {
    delegate.selectAll()
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy