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