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

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

/*
 * Copyright (c) 2011-2020, 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 javafx.{geometry => jfxg}
import scalafx.Includes._
import scalafx.beans.property.{BooleanProperty, DoubleProperty, ObjectProperty}
import scalafx.collections.ObservableBuffer
import scalafx.delegate.{SFXDelegate, SFXEnumDelegate, SFXEnumDelegateCompanion}
import scalafx.geometry.Side

import scala.language.implicitConversions

object TabPane {

  implicit def sfxTabPane2jfx(v: TabPane): jfxsc.TabPane = if (v != null) v.delegate else null

  object TabClosingPolicy
    extends SFXEnumDelegateCompanion[jfxsc.TabPane.TabClosingPolicy, TabClosingPolicy] {

    /**
     * All tabs will have the option to be closed.
     */
    case object AllTabs extends TabClosingPolicy(jfxsc.TabPane.TabClosingPolicy.ALL_TABS)

    @deprecated("Use AllTabs; ALL_TABS will be removed in a future release", "8.0.60-R10")
    val ALL_TABS: TabClosingPolicy = AllTabs

    /**
     * Only the currently selected tab will have the option to be closed, with a graphic next to the tab text being
     * shown.
     */
    case object SelectedTab extends TabClosingPolicy(jfxsc.TabPane.TabClosingPolicy.SELECTED_TAB)

    @deprecated("Use SelectedTab; SELECTED_TAB will be removed in a future release", "8.0.60-R10")
    val SELECTED_TAB: TabClosingPolicy = SelectedTab

    /**
     * Tabs can not be closed by the user.
     */
    case object Unavailable extends TabClosingPolicy(jfxsc.TabPane.TabClosingPolicy.UNAVAILABLE)

    @deprecated("Use Unavailable; UNAVAILABLE will be removed in a future release", "8.0.60-R10")
    val UNAVAILABLE: TabClosingPolicy = Unavailable

    protected override def unsortedValues: Array[TabClosingPolicy] = Array(AllTabs, SelectedTab, Unavailable)

  }

  /** Wrapper for [[http://docs.oracle.com/javase/8/javafx/api/javafx/scene/control/TabPane.TabClosingPolicy.html]] */
  sealed abstract class TabClosingPolicy(override val delegate: jfxsc.TabPane.TabClosingPolicy)
    extends SFXEnumDelegate[jfxsc.TabPane.TabClosingPolicy]

  /**
   * TabPane mode will be changed to floating allowing the TabPane to be placed alongside other control.
   */
  val StyleClassFloating: String = jfxsc.TabPane.STYLE_CLASS_FLOATING

}

class TabPane(override val delegate: jfxsc.TabPane = new jfxsc.TabPane)
  extends Control(delegate)
  with SFXDelegate[jfxsc.TabPane] {

  /**
   * The rotatedGraphic state of the tabs in the TabPane.
   */
  def rotateGraphic: BooleanProperty = delegate.rotateGraphicProperty

  def rotateGraphic_=(v: Boolean): Unit = {
    rotateGraphic() = v
  }

  /**
   * The selection model used for selecting tabs.
   */
  def selectionModel: ObjectProperty[jfxsc.SingleSelectionModel[jfxsc.Tab]] = delegate.selectionModelProperty

  def selectionModel_=(v: SingleSelectionModel[Tab]): Unit = {
    selectionModel() = v.asInstanceOf[jfxsc.SingleSelectionModel[jfxsc.Tab]]
  }

  /**
   * The position of the tabs in the TabPane.
   */
  def side: ObjectProperty[jfxg.Side] = delegate.sideProperty

  def side_=(v: Side): Unit = {
    side() = v
  }

  /**
   * The closing policy for the tabs.
   */
  def tabClosingPolicy: ObjectProperty[jfxsc.TabPane.TabClosingPolicy] = delegate.tabClosingPolicyProperty

  def tabClosingPolicy_=(v: TabPane.TabClosingPolicy): Unit = {
    tabClosingPolicy() = v
  }

  /**
   * The maximum height of the tabs in the TabPane.
   */
  def tabMaxHeight: DoubleProperty = delegate.tabMaxHeightProperty

  def tabMaxHeight_=(v: Double): Unit = {
    tabMaxHeight() = v
  }

  /**
   * The maximum width of the tabs in the TabPane.
   */
  def tabMaxWidth: DoubleProperty = delegate.tabMaxWidthProperty

  def tabMaxWidth_=(v: Double): Unit = {
    tabMaxWidth() = v
  }

  /**
   * The minimum height of the tab.
   */
  def tabMinHeight: DoubleProperty = delegate.tabMinHeightProperty

  def tabMinHeight_=(v: Double): Unit = {
    tabMinHeight() = v
  }

  /**
   * The minimum width of the tabs in the TabPane.
   */
  def tabMinWidth: DoubleProperty = delegate.tabMinWidthProperty

  def tabMinWidth_=(v: Double): Unit = {
    tabMinWidth() = v
  }

  /**
   * The tabs to display in this TabPane.
   */
  def tabs: ObservableBuffer[jfxsc.Tab] = delegate.getTabs

  def tabs_=(tabSeq: Seq[Tab]): Unit = {
    delegate.getTabs.clear()
    tabSeq.foreach(this += _)
  }

  /**
   * Append a new Tab to tabs
   */
  def +=(tab: Tab): TabPane = {
    tabs.add(tab)
    this
  }

  /**
   * The drag policy for the tabs. The policy can be changed dynamically.
   *
   * The default value is TabDragPolicy.FIXED
   * @return The tab drag policy property
   * @since 10
   */
  def tabDragPolicy: ObjectProperty[jfxsc.TabPane.TabDragPolicy] = delegate.tabDragPolicyProperty
  def tabDragPolicy_=(value: jfxsc.TabPane.TabDragPolicy): Unit = {
    tabDragPolicy() = value
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy