mirror of
https://github.com/correl/mage.git
synced 2025-01-12 19:25:44 +00:00
* UI: added save/load/reset game settings for new tourney dialog;
This commit is contained in:
parent
1b79827b2d
commit
1942cd0dec
4 changed files with 566 additions and 365 deletions
|
@ -99,7 +99,7 @@
|
||||||
<EmptySpace max="-2" attributes="0"/>
|
<EmptySpace max="-2" attributes="0"/>
|
||||||
<Group type="103" groupAlignment="1" attributes="0">
|
<Group type="103" groupAlignment="1" attributes="0">
|
||||||
<Group type="102" alignment="1" attributes="0">
|
<Group type="102" alignment="1" attributes="0">
|
||||||
<Component id="jLabel3" min="-2" max="-2" attributes="0"/>
|
<Component id="lblSettings" min="-2" max="-2" attributes="0"/>
|
||||||
<EmptySpace max="-2" attributes="0"/>
|
<EmptySpace max="-2" attributes="0"/>
|
||||||
<Component id="btnSettingsLoad" min="-2" max="-2" attributes="0"/>
|
<Component id="btnSettingsLoad" min="-2" max="-2" attributes="0"/>
|
||||||
<EmptySpace max="-2" attributes="0"/>
|
<EmptySpace max="-2" attributes="0"/>
|
||||||
|
@ -192,8 +192,8 @@
|
||||||
</Group>
|
</Group>
|
||||||
<EmptySpace max="-2" attributes="0"/>
|
<EmptySpace max="-2" attributes="0"/>
|
||||||
<Group type="103" groupAlignment="0" attributes="0">
|
<Group type="103" groupAlignment="0" attributes="0">
|
||||||
<Component id="cbMulligan" alignment="0" min="-2" pref="92" max="-2" attributes="0"/>
|
<Component id="lblMullgian" min="-2" max="-2" attributes="0"/>
|
||||||
<Component id="lblMullgian" alignment="0" min="-2" max="-2" attributes="0"/>
|
<Component id="cbMulligan" min="-2" pref="149" max="-2" attributes="0"/>
|
||||||
</Group>
|
</Group>
|
||||||
<EmptySpace max="-2" attributes="0"/>
|
<EmptySpace max="-2" attributes="0"/>
|
||||||
<Group type="103" groupAlignment="0" attributes="0">
|
<Group type="103" groupAlignment="0" attributes="0">
|
||||||
|
@ -305,7 +305,7 @@
|
||||||
<EmptySpace min="-2" pref="16" max="-2" attributes="0"/>
|
<EmptySpace min="-2" pref="16" max="-2" attributes="0"/>
|
||||||
<Component id="jLabel2" min="-2" max="-2" attributes="0"/>
|
<Component id="jLabel2" min="-2" max="-2" attributes="0"/>
|
||||||
<EmptySpace max="-2" attributes="0"/>
|
<EmptySpace max="-2" attributes="0"/>
|
||||||
<Component id="pnlOtherPlayers" pref="90" max="32767" attributes="0"/>
|
<Component id="pnlOtherPlayers" pref="94" max="32767" attributes="0"/>
|
||||||
<EmptySpace min="-2" pref="9" max="-2" attributes="0"/>
|
<EmptySpace min="-2" pref="9" max="-2" attributes="0"/>
|
||||||
<Component id="jSeparator1" min="-2" max="-2" attributes="0"/>
|
<Component id="jSeparator1" min="-2" max="-2" attributes="0"/>
|
||||||
<EmptySpace max="-2" attributes="0"/>
|
<EmptySpace max="-2" attributes="0"/>
|
||||||
|
@ -314,7 +314,7 @@
|
||||||
<Component id="btnOK" alignment="3" min="-2" pref="30" max="-2" attributes="0"/>
|
<Component id="btnOK" alignment="3" min="-2" pref="30" max="-2" attributes="0"/>
|
||||||
<Component id="btnSettingsLoad" alignment="3" min="-2" pref="30" max="-2" attributes="0"/>
|
<Component id="btnSettingsLoad" alignment="3" min="-2" pref="30" max="-2" attributes="0"/>
|
||||||
<Component id="btnSettingsSave" alignment="3" min="-2" pref="30" max="-2" attributes="0"/>
|
<Component id="btnSettingsSave" alignment="3" min="-2" pref="30" max="-2" attributes="0"/>
|
||||||
<Component id="jLabel3" alignment="3" min="-2" max="-2" attributes="0"/>
|
<Component id="lblSettings" alignment="3" min="-2" max="-2" attributes="0"/>
|
||||||
</Group>
|
</Group>
|
||||||
<EmptySpace max="-2" attributes="0"/>
|
<EmptySpace max="-2" attributes="0"/>
|
||||||
</Group>
|
</Group>
|
||||||
|
@ -397,7 +397,7 @@
|
||||||
</Component>
|
</Component>
|
||||||
<Component class="javax.swing.JCheckBox" name="chkPlaneChase">
|
<Component class="javax.swing.JCheckBox" name="chkPlaneChase">
|
||||||
<Properties>
|
<Properties>
|
||||||
<Property name="text" type="java.lang.String" value="Use PlaneChase"/>
|
<Property name="text" type="java.lang.String" value="PlaneChase"/>
|
||||||
<Property name="toolTipText" type="java.lang.String" value="Use the PlaneChase variant for your game."/>
|
<Property name="toolTipText" type="java.lang.String" value="Use the PlaneChase variant for your game."/>
|
||||||
</Properties>
|
</Properties>
|
||||||
</Component>
|
</Component>
|
||||||
|
@ -598,7 +598,7 @@
|
||||||
<EventHandler event="mouseClicked" listener="java.awt.event.MouseListener" parameters="java.awt.event.MouseEvent" handler="btnSettingsSaveMouseClicked"/>
|
<EventHandler event="mouseClicked" listener="java.awt.event.MouseListener" parameters="java.awt.event.MouseEvent" handler="btnSettingsSaveMouseClicked"/>
|
||||||
</Events>
|
</Events>
|
||||||
</Component>
|
</Component>
|
||||||
<Component class="javax.swing.JLabel" name="jLabel3">
|
<Component class="javax.swing.JLabel" name="lblSettings">
|
||||||
<Properties>
|
<Properties>
|
||||||
<Property name="text" type="java.lang.String" value="Settings"/>
|
<Property name="text" type="java.lang.String" value="Settings"/>
|
||||||
</Properties>
|
</Properties>
|
||||||
|
|
|
@ -27,7 +27,7 @@ import java.util.List;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author BetaSteward_at_googlemail.com
|
* @author BetaSteward_at_googlemail.com, JayDi85
|
||||||
*/
|
*/
|
||||||
public class NewTableDialog extends MageDialog {
|
public class NewTableDialog extends MageDialog {
|
||||||
|
|
||||||
|
@ -121,7 +121,7 @@ public class NewTableDialog extends MageDialog {
|
||||||
chkRated = new javax.swing.JCheckBox();
|
chkRated = new javax.swing.JCheckBox();
|
||||||
btnSettingsLoad = new javax.swing.JButton();
|
btnSettingsLoad = new javax.swing.JButton();
|
||||||
btnSettingsSave = new javax.swing.JButton();
|
btnSettingsSave = new javax.swing.JButton();
|
||||||
jLabel3 = new javax.swing.JLabel();
|
lblSettings = new javax.swing.JLabel();
|
||||||
|
|
||||||
menuSaveSettings1.setText("Save to config 1");
|
menuSaveSettings1.setText("Save to config 1");
|
||||||
menuSaveSettings1.addActionListener(new java.awt.event.ActionListener() {
|
menuSaveSettings1.addActionListener(new java.awt.event.ActionListener() {
|
||||||
|
@ -207,7 +207,7 @@ public class NewTableDialog extends MageDialog {
|
||||||
chkSpectatorsAllowed.setText("Spectators allowed");
|
chkSpectatorsAllowed.setText("Spectators allowed");
|
||||||
chkSpectatorsAllowed.setToolTipText("Allow spectators to view your game.");
|
chkSpectatorsAllowed.setToolTipText("Allow spectators to view your game.");
|
||||||
|
|
||||||
chkPlaneChase.setText("Use PlaneChase");
|
chkPlaneChase.setText("PlaneChase");
|
||||||
chkPlaneChase.setToolTipText("Use the PlaneChase variant for your game.");
|
chkPlaneChase.setToolTipText("Use the PlaneChase variant for your game.");
|
||||||
|
|
||||||
lblNumPlayers.setLabelFor(spnNumPlayers);
|
lblNumPlayers.setLabelFor(spnNumPlayers);
|
||||||
|
@ -294,7 +294,7 @@ public class NewTableDialog extends MageDialog {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
jLabel3.setText("Settings");
|
lblSettings.setText("Settings");
|
||||||
|
|
||||||
javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane());
|
javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane());
|
||||||
getContentPane().setLayout(layout);
|
getContentPane().setLayout(layout);
|
||||||
|
@ -304,7 +304,7 @@ public class NewTableDialog extends MageDialog {
|
||||||
.addContainerGap()
|
.addContainerGap()
|
||||||
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING)
|
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING)
|
||||||
.addGroup(layout.createSequentialGroup()
|
.addGroup(layout.createSequentialGroup()
|
||||||
.addComponent(jLabel3)
|
.addComponent(lblSettings)
|
||||||
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
||||||
.addComponent(btnSettingsLoad)
|
.addComponent(btnSettingsLoad)
|
||||||
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
||||||
|
@ -383,8 +383,8 @@ public class NewTableDialog extends MageDialog {
|
||||||
.addComponent(lblNumWins))
|
.addComponent(lblNumWins))
|
||||||
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
||||||
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
||||||
.addComponent(cbMulligan, javax.swing.GroupLayout.PREFERRED_SIZE, 92, javax.swing.GroupLayout.PREFERRED_SIZE)
|
.addComponent(lblMullgian)
|
||||||
.addComponent(lblMullgian))
|
.addComponent(cbMulligan, javax.swing.GroupLayout.PREFERRED_SIZE, 149, javax.swing.GroupLayout.PREFERRED_SIZE))
|
||||||
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
||||||
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
||||||
.addGroup(layout.createSequentialGroup()
|
.addGroup(layout.createSequentialGroup()
|
||||||
|
@ -471,7 +471,7 @@ public class NewTableDialog extends MageDialog {
|
||||||
.addGap(16, 16, 16)
|
.addGap(16, 16, 16)
|
||||||
.addComponent(jLabel2)
|
.addComponent(jLabel2)
|
||||||
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
||||||
.addComponent(pnlOtherPlayers, javax.swing.GroupLayout.DEFAULT_SIZE, 90, Short.MAX_VALUE)
|
.addComponent(pnlOtherPlayers, javax.swing.GroupLayout.DEFAULT_SIZE, 94, Short.MAX_VALUE)
|
||||||
.addGap(9, 9, 9)
|
.addGap(9, 9, 9)
|
||||||
.addComponent(jSeparator1, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
|
.addComponent(jSeparator1, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
|
||||||
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
||||||
|
@ -480,7 +480,7 @@ public class NewTableDialog extends MageDialog {
|
||||||
.addComponent(btnOK, javax.swing.GroupLayout.PREFERRED_SIZE, 30, javax.swing.GroupLayout.PREFERRED_SIZE)
|
.addComponent(btnOK, javax.swing.GroupLayout.PREFERRED_SIZE, 30, javax.swing.GroupLayout.PREFERRED_SIZE)
|
||||||
.addComponent(btnSettingsLoad, javax.swing.GroupLayout.PREFERRED_SIZE, 30, javax.swing.GroupLayout.PREFERRED_SIZE)
|
.addComponent(btnSettingsLoad, javax.swing.GroupLayout.PREFERRED_SIZE, 30, javax.swing.GroupLayout.PREFERRED_SIZE)
|
||||||
.addComponent(btnSettingsSave, javax.swing.GroupLayout.PREFERRED_SIZE, 30, javax.swing.GroupLayout.PREFERRED_SIZE)
|
.addComponent(btnSettingsSave, javax.swing.GroupLayout.PREFERRED_SIZE, 30, javax.swing.GroupLayout.PREFERRED_SIZE)
|
||||||
.addComponent(jLabel3))
|
.addComponent(lblSettings))
|
||||||
.addContainerGap())
|
.addContainerGap())
|
||||||
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
||||||
.addGroup(layout.createSequentialGroup()
|
.addGroup(layout.createSequentialGroup()
|
||||||
|
@ -794,6 +794,7 @@ public class NewTableDialog extends MageDialog {
|
||||||
switch (version) {
|
switch (version) {
|
||||||
case -1:
|
case -1:
|
||||||
versionStr = "-1"; // default (empty)
|
versionStr = "-1"; // default (empty)
|
||||||
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
versionStr = "1";
|
versionStr = "1";
|
||||||
break;
|
break;
|
||||||
|
@ -939,7 +940,6 @@ public class NewTableDialog extends MageDialog {
|
||||||
private javax.swing.JCheckBox chkSpectatorsAllowed;
|
private javax.swing.JCheckBox chkSpectatorsAllowed;
|
||||||
private javax.swing.JLabel jLabel1;
|
private javax.swing.JLabel jLabel1;
|
||||||
private javax.swing.JLabel jLabel2;
|
private javax.swing.JLabel jLabel2;
|
||||||
private javax.swing.JLabel jLabel3;
|
|
||||||
private javax.swing.JSeparator jSeparator1;
|
private javax.swing.JSeparator jSeparator1;
|
||||||
private javax.swing.JSeparator jSeparator2;
|
private javax.swing.JSeparator jSeparator2;
|
||||||
private javax.swing.JSeparator jSeparator3;
|
private javax.swing.JSeparator jSeparator3;
|
||||||
|
@ -957,6 +957,7 @@ public class NewTableDialog extends MageDialog {
|
||||||
private javax.swing.JLabel lblPassword;
|
private javax.swing.JLabel lblPassword;
|
||||||
private javax.swing.JLabel lblQuitRatio;
|
private javax.swing.JLabel lblQuitRatio;
|
||||||
private javax.swing.JLabel lblRange;
|
private javax.swing.JLabel lblRange;
|
||||||
|
private javax.swing.JLabel lblSettings;
|
||||||
private javax.swing.JLabel lblSkillLevel;
|
private javax.swing.JLabel lblSkillLevel;
|
||||||
private javax.swing.JMenuItem menuLoadSettings1;
|
private javax.swing.JMenuItem menuLoadSettings1;
|
||||||
private javax.swing.JMenuItem menuLoadSettings2;
|
private javax.swing.JMenuItem menuLoadSettings2;
|
||||||
|
|
|
@ -1,6 +1,79 @@
|
||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
|
|
||||||
<Form version="1.5" maxVersion="1.7" type="org.netbeans.modules.form.forminfo.JInternalFrameFormInfo">
|
<Form version="1.5" maxVersion="1.7" type="org.netbeans.modules.form.forminfo.JInternalFrameFormInfo">
|
||||||
|
<NonVisualComponents>
|
||||||
|
<Container class="javax.swing.JPopupMenu" name="popupSaveSettings">
|
||||||
|
|
||||||
|
<Layout class="org.netbeans.modules.form.compat2.layouts.DesignAbsoluteLayout">
|
||||||
|
<Property name="useNullLayout" type="boolean" value="true"/>
|
||||||
|
</Layout>
|
||||||
|
<SubComponents>
|
||||||
|
<MenuItem class="javax.swing.JMenuItem" name="menuSaveSettings1">
|
||||||
|
<Properties>
|
||||||
|
<Property name="text" type="java.lang.String" value="Save to config 1"/>
|
||||||
|
</Properties>
|
||||||
|
<Events>
|
||||||
|
<EventHandler event="actionPerformed" listener="java.awt.event.ActionListener" parameters="java.awt.event.ActionEvent" handler="menuSaveSettings1ActionPerformed"/>
|
||||||
|
</Events>
|
||||||
|
</MenuItem>
|
||||||
|
<MenuItem class="javax.swing.JMenuItem" name="menuSaveSettings2">
|
||||||
|
<Properties>
|
||||||
|
<Property name="text" type="java.lang.String" value="Save to config 2"/>
|
||||||
|
</Properties>
|
||||||
|
<Events>
|
||||||
|
<EventHandler event="actionPerformed" listener="java.awt.event.ActionListener" parameters="java.awt.event.ActionEvent" handler="menuSaveSettings2ActionPerformed"/>
|
||||||
|
</Events>
|
||||||
|
</MenuItem>
|
||||||
|
</SubComponents>
|
||||||
|
</Container>
|
||||||
|
<Container class="javax.swing.JPopupMenu" name="popupLoadSettings">
|
||||||
|
|
||||||
|
<Layout class="org.netbeans.modules.form.compat2.layouts.DesignAbsoluteLayout">
|
||||||
|
<Property name="useNullLayout" type="boolean" value="true"/>
|
||||||
|
</Layout>
|
||||||
|
<SubComponents>
|
||||||
|
<MenuItem class="javax.swing.JMenuItem" name="menuLoadSettingsLast">
|
||||||
|
<Properties>
|
||||||
|
<Property name="text" type="java.lang.String" value="Load from last time"/>
|
||||||
|
<Property name="toolTipText" type="java.lang.String" value=""/>
|
||||||
|
</Properties>
|
||||||
|
<Events>
|
||||||
|
<EventHandler event="actionPerformed" listener="java.awt.event.ActionListener" parameters="java.awt.event.ActionEvent" handler="menuLoadSettingsLastActionPerformed"/>
|
||||||
|
</Events>
|
||||||
|
</MenuItem>
|
||||||
|
<Component class="javax.swing.JPopupMenu$Separator" name="separator1">
|
||||||
|
</Component>
|
||||||
|
<MenuItem class="javax.swing.JMenuItem" name="menuLoadSettings1">
|
||||||
|
<Properties>
|
||||||
|
<Property name="text" type="java.lang.String" value="Load from config 1"/>
|
||||||
|
<Property name="toolTipText" type="java.lang.String" value=""/>
|
||||||
|
</Properties>
|
||||||
|
<Events>
|
||||||
|
<EventHandler event="actionPerformed" listener="java.awt.event.ActionListener" parameters="java.awt.event.ActionEvent" handler="menuLoadSettings1ActionPerformed"/>
|
||||||
|
</Events>
|
||||||
|
</MenuItem>
|
||||||
|
<MenuItem class="javax.swing.JMenuItem" name="menuLoadSettings2">
|
||||||
|
<Properties>
|
||||||
|
<Property name="text" type="java.lang.String" value="Load from config 2"/>
|
||||||
|
</Properties>
|
||||||
|
<Events>
|
||||||
|
<EventHandler event="actionPerformed" listener="java.awt.event.ActionListener" parameters="java.awt.event.ActionEvent" handler="menuLoadSettings2ActionPerformed"/>
|
||||||
|
</Events>
|
||||||
|
</MenuItem>
|
||||||
|
<Component class="javax.swing.JPopupMenu$Separator" name="separator2">
|
||||||
|
</Component>
|
||||||
|
<MenuItem class="javax.swing.JMenuItem" name="menuLoadSettingsDefault">
|
||||||
|
<Properties>
|
||||||
|
<Property name="text" type="java.lang.String" value="Load default settings"/>
|
||||||
|
<Property name="toolTipText" type="java.lang.String" value=""/>
|
||||||
|
</Properties>
|
||||||
|
<Events>
|
||||||
|
<EventHandler event="actionPerformed" listener="java.awt.event.ActionListener" parameters="java.awt.event.ActionEvent" handler="menuLoadSettingsDefaultActionPerformed"/>
|
||||||
|
</Events>
|
||||||
|
</MenuItem>
|
||||||
|
</SubComponents>
|
||||||
|
</Container>
|
||||||
|
</NonVisualComponents>
|
||||||
<Properties>
|
<Properties>
|
||||||
<Property name="title" type="java.lang.String" value="New Tournament"/>
|
<Property name="title" type="java.lang.String" value="New Tournament"/>
|
||||||
</Properties>
|
</Properties>
|
||||||
|
@ -66,18 +139,18 @@
|
||||||
<EmptySpace min="-2" pref="95" max="-2" attributes="0"/>
|
<EmptySpace min="-2" pref="95" max="-2" attributes="0"/>
|
||||||
</Group>
|
</Group>
|
||||||
<Group type="102" alignment="1" attributes="0">
|
<Group type="102" alignment="1" attributes="0">
|
||||||
<EmptySpace min="0" pref="0" max="32767" attributes="0"/>
|
<Component id="lblSettings" min="-2" max="-2" attributes="0"/>
|
||||||
<Group type="103" groupAlignment="0" attributes="0">
|
|
||||||
<Group type="102" alignment="1" attributes="0">
|
|
||||||
<Component id="btnSavedConfiguration1" min="-2" max="-2" attributes="0"/>
|
|
||||||
<EmptySpace max="-2" attributes="0"/>
|
<EmptySpace max="-2" attributes="0"/>
|
||||||
<Component id="btnSavedConfiguration2" min="-2" max="-2" attributes="0"/>
|
<Component id="btnSettingsLoad" min="-2" max="-2" attributes="0"/>
|
||||||
<EmptySpace max="-2" attributes="0"/>
|
<EmptySpace max="-2" attributes="0"/>
|
||||||
<Component id="btnOk" min="-2" max="-2" attributes="0"/>
|
<Component id="btnSettingsSave" min="-2" max="-2" attributes="0"/>
|
||||||
|
<EmptySpace max="32767" attributes="0"/>
|
||||||
|
<Component id="btnOk" min="-2" pref="100" max="-2" attributes="0"/>
|
||||||
<EmptySpace max="-2" attributes="0"/>
|
<EmptySpace max="-2" attributes="0"/>
|
||||||
<Component id="btnCancel" min="-2" max="-2" attributes="0"/>
|
<Component id="btnCancel" min="-2" pref="100" max="-2" attributes="0"/>
|
||||||
</Group>
|
</Group>
|
||||||
<Group type="102" alignment="1" attributes="0">
|
<Group type="102" alignment="1" attributes="0">
|
||||||
|
<EmptySpace min="0" pref="0" max="32767" attributes="0"/>
|
||||||
<Group type="103" groupAlignment="1" attributes="0">
|
<Group type="103" groupAlignment="1" attributes="0">
|
||||||
<Group type="102" attributes="0">
|
<Group type="102" attributes="0">
|
||||||
<Group type="103" groupAlignment="1" attributes="0">
|
<Group type="103" groupAlignment="1" attributes="0">
|
||||||
|
@ -110,8 +183,8 @@
|
||||||
<Group type="103" groupAlignment="0" attributes="0">
|
<Group type="103" groupAlignment="0" attributes="0">
|
||||||
<Group type="102" alignment="0" attributes="0">
|
<Group type="102" alignment="0" attributes="0">
|
||||||
<Group type="103" groupAlignment="0" attributes="0">
|
<Group type="103" groupAlignment="0" attributes="0">
|
||||||
<Component id="cbMulligan" alignment="0" min="-2" pref="92" max="-2" attributes="0"/>
|
<Component id="lblMullgian" min="-2" max="-2" attributes="0"/>
|
||||||
<Component id="lblMullgian" alignment="0" min="-2" max="-2" attributes="0"/>
|
<Component id="cbMulligan" min="-2" pref="151" max="-2" attributes="0"/>
|
||||||
</Group>
|
</Group>
|
||||||
<EmptySpace max="-2" attributes="0"/>
|
<EmptySpace max="-2" attributes="0"/>
|
||||||
<Group type="103" groupAlignment="0" max="-2" attributes="0">
|
<Group type="103" groupAlignment="0" max="-2" attributes="0">
|
||||||
|
@ -150,8 +223,7 @@
|
||||||
<Component id="txtPassword" min="-2" pref="56" max="-2" attributes="0"/>
|
<Component id="txtPassword" min="-2" pref="56" max="-2" attributes="0"/>
|
||||||
<EmptySpace max="-2" attributes="0"/>
|
<EmptySpace max="-2" attributes="0"/>
|
||||||
<Component id="cbAllowSpectators" min="-2" max="-2" attributes="0"/>
|
<Component id="cbAllowSpectators" min="-2" max="-2" attributes="0"/>
|
||||||
</Group>
|
<EmptySpace min="0" pref="0" max="32767" attributes="0"/>
|
||||||
</Group>
|
|
||||||
</Group>
|
</Group>
|
||||||
<Component id="player1Panel" alignment="0" max="32767" attributes="0"/>
|
<Component id="player1Panel" alignment="0" max="32767" attributes="0"/>
|
||||||
<Component id="pnlRandomPacks" alignment="1" max="32767" attributes="0"/>
|
<Component id="pnlRandomPacks" alignment="1" max="32767" attributes="0"/>
|
||||||
|
@ -233,7 +305,7 @@
|
||||||
<Group type="102" attributes="0">
|
<Group type="102" attributes="0">
|
||||||
<Component id="pnlPacks" min="-2" max="-2" attributes="0"/>
|
<Component id="pnlPacks" min="-2" max="-2" attributes="0"/>
|
||||||
<EmptySpace max="-2" attributes="0"/>
|
<EmptySpace max="-2" attributes="0"/>
|
||||||
<Component id="pnlRandomPacks" pref="7" max="32767" attributes="0"/>
|
<Component id="pnlRandomPacks" pref="10" max="32767" attributes="0"/>
|
||||||
<EmptySpace max="-2" attributes="0"/>
|
<EmptySpace max="-2" attributes="0"/>
|
||||||
<Group type="103" groupAlignment="1" max="-2" attributes="0">
|
<Group type="103" groupAlignment="1" max="-2" attributes="0">
|
||||||
<Group type="103" alignment="1" groupAlignment="3" attributes="0">
|
<Group type="103" alignment="1" groupAlignment="3" attributes="0">
|
||||||
|
@ -264,10 +336,13 @@
|
||||||
<Component id="pnlPlayers" max="32767" attributes="0"/>
|
<Component id="pnlPlayers" max="32767" attributes="0"/>
|
||||||
<EmptySpace max="-2" attributes="0"/>
|
<EmptySpace max="-2" attributes="0"/>
|
||||||
<Group type="103" groupAlignment="3" attributes="0">
|
<Group type="103" groupAlignment="3" attributes="0">
|
||||||
<Component id="btnSavedConfiguration1" alignment="3" min="-2" max="-2" attributes="0"/>
|
<Component id="btnOk" alignment="3" min="-2" pref="30" max="-2" attributes="0"/>
|
||||||
<Component id="btnSavedConfiguration2" alignment="3" min="-2" max="-2" attributes="0"/>
|
<Component id="btnCancel" alignment="3" min="-2" pref="30" max="-2" attributes="0"/>
|
||||||
<Component id="btnOk" alignment="3" min="-2" max="-2" attributes="0"/>
|
<Group type="103" alignment="3" groupAlignment="3" attributes="0">
|
||||||
<Component id="btnCancel" alignment="3" min="-2" max="-2" attributes="0"/>
|
<Component id="btnSettingsLoad" alignment="3" min="-2" pref="30" max="-2" attributes="0"/>
|
||||||
|
<Component id="btnSettingsSave" alignment="3" min="-2" pref="30" max="-2" attributes="0"/>
|
||||||
|
<Component id="lblSettings" alignment="3" min="-2" max="-2" attributes="0"/>
|
||||||
|
</Group>
|
||||||
</Group>
|
</Group>
|
||||||
<EmptySpace max="-2" attributes="0"/>
|
<EmptySpace max="-2" attributes="0"/>
|
||||||
</Group>
|
</Group>
|
||||||
|
@ -517,7 +592,7 @@
|
||||||
</Component>
|
</Component>
|
||||||
<Component class="javax.swing.JCheckBox" name="cbPlaneChase">
|
<Component class="javax.swing.JCheckBox" name="cbPlaneChase">
|
||||||
<Properties>
|
<Properties>
|
||||||
<Property name="text" type="java.lang.String" value="Use PlaneChase"/>
|
<Property name="text" type="java.lang.String" value="PlaneChase"/>
|
||||||
<Property name="toolTipText" type="java.lang.String" value="Use Plane Chase for the tournament."/>
|
<Property name="toolTipText" type="java.lang.String" value="Use Plane Chase for the tournament."/>
|
||||||
</Properties>
|
</Properties>
|
||||||
</Component>
|
</Component>
|
||||||
|
@ -562,7 +637,7 @@
|
||||||
</DimensionLayout>
|
</DimensionLayout>
|
||||||
<DimensionLayout dim="1">
|
<DimensionLayout dim="1">
|
||||||
<Group type="103" groupAlignment="0" attributes="0">
|
<Group type="103" groupAlignment="0" attributes="0">
|
||||||
<Component id="pnlOtherPlayers" alignment="0" max="32767" attributes="0"/>
|
<Component id="pnlOtherPlayers" alignment="0" pref="5" max="32767" attributes="0"/>
|
||||||
</Group>
|
</Group>
|
||||||
</DimensionLayout>
|
</DimensionLayout>
|
||||||
</Layout>
|
</Layout>
|
||||||
|
@ -584,22 +659,6 @@
|
||||||
</Container>
|
</Container>
|
||||||
</SubComponents>
|
</SubComponents>
|
||||||
</Container>
|
</Container>
|
||||||
<Component class="javax.swing.JButton" name="btnSavedConfiguration1">
|
|
||||||
<Properties>
|
|
||||||
<Property name="text" type="java.lang.String" value="C1"/>
|
|
||||||
</Properties>
|
|
||||||
<Events>
|
|
||||||
<EventHandler event="actionPerformed" listener="java.awt.event.ActionListener" parameters="java.awt.event.ActionEvent" handler="btnSavedConfiguration1ActionPerformed"/>
|
|
||||||
</Events>
|
|
||||||
</Component>
|
|
||||||
<Component class="javax.swing.JButton" name="btnSavedConfiguration2">
|
|
||||||
<Properties>
|
|
||||||
<Property name="text" type="java.lang.String" value="C2"/>
|
|
||||||
</Properties>
|
|
||||||
<Events>
|
|
||||||
<EventHandler event="actionPerformed" listener="java.awt.event.ActionListener" parameters="java.awt.event.ActionEvent" handler="btnSavedConfiguration2ActionPerformed"/>
|
|
||||||
</Events>
|
|
||||||
</Component>
|
|
||||||
<Component class="javax.swing.JButton" name="btnOk">
|
<Component class="javax.swing.JButton" name="btnOk">
|
||||||
<Properties>
|
<Properties>
|
||||||
<Property name="text" type="java.lang.String" value="OK"/>
|
<Property name="text" type="java.lang.String" value="OK"/>
|
||||||
|
@ -677,5 +736,28 @@
|
||||||
<AuxValue name="JavaCodeGenerator_TypeParameters" type="java.lang.String" value="<String>"/>
|
<AuxValue name="JavaCodeGenerator_TypeParameters" type="java.lang.String" value="<String>"/>
|
||||||
</AuxValues>
|
</AuxValues>
|
||||||
</Component>
|
</Component>
|
||||||
|
<Component class="javax.swing.JButton" name="btnSettingsSave">
|
||||||
|
<Properties>
|
||||||
|
<Property name="text" type="java.lang.String" value="Save..."/>
|
||||||
|
<Property name="toolTipText" type="java.lang.String" value="Save settings"/>
|
||||||
|
</Properties>
|
||||||
|
<Events>
|
||||||
|
<EventHandler event="mouseClicked" listener="java.awt.event.MouseListener" parameters="java.awt.event.MouseEvent" handler="btnSettingsSaveMouseClicked"/>
|
||||||
|
</Events>
|
||||||
|
</Component>
|
||||||
|
<Component class="javax.swing.JButton" name="btnSettingsLoad">
|
||||||
|
<Properties>
|
||||||
|
<Property name="text" type="java.lang.String" value="Load..."/>
|
||||||
|
<Property name="toolTipText" type="java.lang.String" value="Load settings"/>
|
||||||
|
</Properties>
|
||||||
|
<Events>
|
||||||
|
<EventHandler event="mouseClicked" listener="java.awt.event.MouseListener" parameters="java.awt.event.MouseEvent" handler="btnSettingsLoadMouseClicked"/>
|
||||||
|
</Events>
|
||||||
|
</Component>
|
||||||
|
<Component class="javax.swing.JLabel" name="lblSettings">
|
||||||
|
<Properties>
|
||||||
|
<Property name="text" type="java.lang.String" value="Settings"/>
|
||||||
|
</Properties>
|
||||||
|
</Component>
|
||||||
</SubComponents>
|
</SubComponents>
|
||||||
</Form>
|
</Form>
|
||||||
|
|
|
@ -33,7 +33,7 @@ import java.util.List;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author BetaSteward_at_googlemail.com
|
* @author BetaSteward_at_googlemail.com, JayDi85
|
||||||
*/
|
*/
|
||||||
public class NewTournamentDialog extends MageDialog {
|
public class NewTournamentDialog extends MageDialog {
|
||||||
|
|
||||||
|
@ -54,9 +54,6 @@ public class NewTournamentDialog extends MageDialog {
|
||||||
private String cubeFromDeckFilename = "";
|
private String cubeFromDeckFilename = "";
|
||||||
private boolean automaticChange = false;
|
private boolean automaticChange = false;
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates new form NewTournamentDialog
|
|
||||||
*/
|
|
||||||
public NewTournamentDialog() {
|
public NewTournamentDialog() {
|
||||||
initComponents();
|
initComponents();
|
||||||
lastSessionId = "";
|
lastSessionId = "";
|
||||||
|
@ -95,8 +92,9 @@ public class NewTournamentDialog extends MageDialog {
|
||||||
this.setModal(true);
|
this.setModal(true);
|
||||||
this.setLocation(150, 100);
|
this.setLocation(150, 100);
|
||||||
}
|
}
|
||||||
currentSettingVersion = 0;
|
|
||||||
setTournamentSettingsFromPrefs(currentSettingVersion);
|
onLoadSettings(0);
|
||||||
|
|
||||||
this.setVisible(true);
|
this.setVisible(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -110,6 +108,16 @@ public class NewTournamentDialog extends MageDialog {
|
||||||
private void initComponents() {
|
private void initComponents() {
|
||||||
bindingGroup = new org.jdesktop.beansbinding.BindingGroup();
|
bindingGroup = new org.jdesktop.beansbinding.BindingGroup();
|
||||||
|
|
||||||
|
popupSaveSettings = new javax.swing.JPopupMenu();
|
||||||
|
menuSaveSettings1 = new javax.swing.JMenuItem();
|
||||||
|
menuSaveSettings2 = new javax.swing.JMenuItem();
|
||||||
|
popupLoadSettings = new javax.swing.JPopupMenu();
|
||||||
|
menuLoadSettingsLast = new javax.swing.JMenuItem();
|
||||||
|
separator1 = new javax.swing.JPopupMenu.Separator();
|
||||||
|
menuLoadSettings1 = new javax.swing.JMenuItem();
|
||||||
|
menuLoadSettings2 = new javax.swing.JMenuItem();
|
||||||
|
separator2 = new javax.swing.JPopupMenu.Separator();
|
||||||
|
menuLoadSettingsDefault = new javax.swing.JMenuItem();
|
||||||
lblName = new javax.swing.JLabel();
|
lblName = new javax.swing.JLabel();
|
||||||
txtName = new javax.swing.JTextField();
|
txtName = new javax.swing.JTextField();
|
||||||
lbTimeLimit = new javax.swing.JLabel();
|
lbTimeLimit = new javax.swing.JLabel();
|
||||||
|
@ -150,8 +158,6 @@ public class NewTournamentDialog extends MageDialog {
|
||||||
player1Panel = new mage.client.table.NewPlayerPanel();
|
player1Panel = new mage.client.table.NewPlayerPanel();
|
||||||
pnlPlayers = new javax.swing.JPanel();
|
pnlPlayers = new javax.swing.JPanel();
|
||||||
pnlOtherPlayers = new javax.swing.JPanel();
|
pnlOtherPlayers = new javax.swing.JPanel();
|
||||||
btnSavedConfiguration1 = new javax.swing.JButton();
|
|
||||||
btnSavedConfiguration2 = new javax.swing.JButton();
|
|
||||||
btnOk = new javax.swing.JButton();
|
btnOk = new javax.swing.JButton();
|
||||||
btnCancel = new javax.swing.JButton();
|
btnCancel = new javax.swing.JButton();
|
||||||
pnlRandomPacks = new javax.swing.JPanel();
|
pnlRandomPacks = new javax.swing.JPanel();
|
||||||
|
@ -162,6 +168,62 @@ public class NewTournamentDialog extends MageDialog {
|
||||||
chkRated = new javax.swing.JCheckBox();
|
chkRated = new javax.swing.JCheckBox();
|
||||||
lblMullgian = new javax.swing.JLabel();
|
lblMullgian = new javax.swing.JLabel();
|
||||||
cbMulligan = new javax.swing.JComboBox<>();
|
cbMulligan = new javax.swing.JComboBox<>();
|
||||||
|
btnSettingsSave = new javax.swing.JButton();
|
||||||
|
btnSettingsLoad = new javax.swing.JButton();
|
||||||
|
lblSettings = new javax.swing.JLabel();
|
||||||
|
|
||||||
|
menuSaveSettings1.setText("Save to config 1");
|
||||||
|
menuSaveSettings1.addActionListener(new java.awt.event.ActionListener() {
|
||||||
|
public void actionPerformed(java.awt.event.ActionEvent evt) {
|
||||||
|
menuSaveSettings1ActionPerformed(evt);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
popupSaveSettings.add(menuSaveSettings1);
|
||||||
|
|
||||||
|
menuSaveSettings2.setText("Save to config 2");
|
||||||
|
menuSaveSettings2.addActionListener(new java.awt.event.ActionListener() {
|
||||||
|
public void actionPerformed(java.awt.event.ActionEvent evt) {
|
||||||
|
menuSaveSettings2ActionPerformed(evt);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
popupSaveSettings.add(menuSaveSettings2);
|
||||||
|
|
||||||
|
menuLoadSettingsLast.setText("Load from last time");
|
||||||
|
menuLoadSettingsLast.setToolTipText("");
|
||||||
|
menuLoadSettingsLast.addActionListener(new java.awt.event.ActionListener() {
|
||||||
|
public void actionPerformed(java.awt.event.ActionEvent evt) {
|
||||||
|
menuLoadSettingsLastActionPerformed(evt);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
popupLoadSettings.add(menuLoadSettingsLast);
|
||||||
|
popupLoadSettings.add(separator1);
|
||||||
|
|
||||||
|
menuLoadSettings1.setText("Load from config 1");
|
||||||
|
menuLoadSettings1.setToolTipText("");
|
||||||
|
menuLoadSettings1.addActionListener(new java.awt.event.ActionListener() {
|
||||||
|
public void actionPerformed(java.awt.event.ActionEvent evt) {
|
||||||
|
menuLoadSettings1ActionPerformed(evt);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
popupLoadSettings.add(menuLoadSettings1);
|
||||||
|
|
||||||
|
menuLoadSettings2.setText("Load from config 2");
|
||||||
|
menuLoadSettings2.addActionListener(new java.awt.event.ActionListener() {
|
||||||
|
public void actionPerformed(java.awt.event.ActionEvent evt) {
|
||||||
|
menuLoadSettings2ActionPerformed(evt);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
popupLoadSettings.add(menuLoadSettings2);
|
||||||
|
popupLoadSettings.add(separator2);
|
||||||
|
|
||||||
|
menuLoadSettingsDefault.setText("Load default settings");
|
||||||
|
menuLoadSettingsDefault.setToolTipText("");
|
||||||
|
menuLoadSettingsDefault.addActionListener(new java.awt.event.ActionListener() {
|
||||||
|
public void actionPerformed(java.awt.event.ActionEvent evt) {
|
||||||
|
menuLoadSettingsDefaultActionPerformed(evt);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
popupLoadSettings.add(menuLoadSettingsDefault);
|
||||||
|
|
||||||
setTitle("New Tournament");
|
setTitle("New Tournament");
|
||||||
|
|
||||||
|
@ -293,7 +355,7 @@ public class NewTournamentDialog extends MageDialog {
|
||||||
cbAllowSpectators.setText("Allow spectators");
|
cbAllowSpectators.setText("Allow spectators");
|
||||||
cbAllowSpectators.setToolTipText("Allow other players to watch the games of this table.");
|
cbAllowSpectators.setToolTipText("Allow other players to watch the games of this table.");
|
||||||
|
|
||||||
cbPlaneChase.setText("Use PlaneChase");
|
cbPlaneChase.setText("PlaneChase");
|
||||||
cbPlaneChase.setToolTipText("Use Plane Chase for the tournament.");
|
cbPlaneChase.setToolTipText("Use Plane Chase for the tournament.");
|
||||||
|
|
||||||
lblPlayer1.setFont(new java.awt.Font("Tahoma", 1, 11)); // NOI18N
|
lblPlayer1.setFont(new java.awt.Font("Tahoma", 1, 11)); // NOI18N
|
||||||
|
@ -319,23 +381,9 @@ public class NewTournamentDialog extends MageDialog {
|
||||||
);
|
);
|
||||||
pnlPlayersLayout.setVerticalGroup(
|
pnlPlayersLayout.setVerticalGroup(
|
||||||
pnlPlayersLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
pnlPlayersLayout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
||||||
.addComponent(pnlOtherPlayers, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
|
.addComponent(pnlOtherPlayers, javax.swing.GroupLayout.DEFAULT_SIZE, 5, Short.MAX_VALUE)
|
||||||
);
|
);
|
||||||
|
|
||||||
btnSavedConfiguration1.setText("C1");
|
|
||||||
btnSavedConfiguration1.addActionListener(new java.awt.event.ActionListener() {
|
|
||||||
public void actionPerformed(java.awt.event.ActionEvent evt) {
|
|
||||||
btnSavedConfiguration1ActionPerformed(evt);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
btnSavedConfiguration2.setText("C2");
|
|
||||||
btnSavedConfiguration2.addActionListener(new java.awt.event.ActionListener() {
|
|
||||||
public void actionPerformed(java.awt.event.ActionEvent evt) {
|
|
||||||
btnSavedConfiguration2ActionPerformed(evt);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
btnOk.setText("OK");
|
btnOk.setText("OK");
|
||||||
btnOk.addActionListener(new java.awt.event.ActionListener() {
|
btnOk.addActionListener(new java.awt.event.ActionListener() {
|
||||||
public void actionPerformed(java.awt.event.ActionEvent evt) {
|
public void actionPerformed(java.awt.event.ActionEvent evt) {
|
||||||
|
@ -375,6 +423,24 @@ public class NewTournamentDialog extends MageDialog {
|
||||||
|
|
||||||
cbMulligan.setToolTipText("Selections the type of mulligan for games.");
|
cbMulligan.setToolTipText("Selections the type of mulligan for games.");
|
||||||
|
|
||||||
|
btnSettingsSave.setText("Save...");
|
||||||
|
btnSettingsSave.setToolTipText("Save settings");
|
||||||
|
btnSettingsSave.addMouseListener(new java.awt.event.MouseAdapter() {
|
||||||
|
public void mouseClicked(java.awt.event.MouseEvent evt) {
|
||||||
|
btnSettingsSaveMouseClicked(evt);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
btnSettingsLoad.setText("Load...");
|
||||||
|
btnSettingsLoad.setToolTipText("Load settings");
|
||||||
|
btnSettingsLoad.addMouseListener(new java.awt.event.MouseAdapter() {
|
||||||
|
public void mouseClicked(java.awt.event.MouseEvent evt) {
|
||||||
|
btnSettingsLoadMouseClicked(evt);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
lblSettings.setText("Settings");
|
||||||
|
|
||||||
javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane());
|
javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane());
|
||||||
getContentPane().setLayout(layout);
|
getContentPane().setLayout(layout);
|
||||||
layout.setHorizontalGroup(
|
layout.setHorizontalGroup(
|
||||||
|
@ -413,18 +479,18 @@ public class NewTournamentDialog extends MageDialog {
|
||||||
.addComponent(chkRollbackTurnsAllowed))
|
.addComponent(chkRollbackTurnsAllowed))
|
||||||
.addComponent(spnNumRounds, javax.swing.GroupLayout.PREFERRED_SIZE, 50, javax.swing.GroupLayout.PREFERRED_SIZE))
|
.addComponent(spnNumRounds, javax.swing.GroupLayout.PREFERRED_SIZE, 50, javax.swing.GroupLayout.PREFERRED_SIZE))
|
||||||
.addGap(95, 95, 95))
|
.addGap(95, 95, 95))
|
||||||
|
.addGroup(javax.swing.GroupLayout.Alignment.TRAILING, layout.createSequentialGroup()
|
||||||
|
.addComponent(lblSettings)
|
||||||
|
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
||||||
|
.addComponent(btnSettingsLoad)
|
||||||
|
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
||||||
|
.addComponent(btnSettingsSave)
|
||||||
|
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
|
||||||
|
.addComponent(btnOk, javax.swing.GroupLayout.PREFERRED_SIZE, 100, javax.swing.GroupLayout.PREFERRED_SIZE)
|
||||||
|
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
||||||
|
.addComponent(btnCancel, javax.swing.GroupLayout.PREFERRED_SIZE, 100, javax.swing.GroupLayout.PREFERRED_SIZE))
|
||||||
.addGroup(javax.swing.GroupLayout.Alignment.TRAILING, layout.createSequentialGroup()
|
.addGroup(javax.swing.GroupLayout.Alignment.TRAILING, layout.createSequentialGroup()
|
||||||
.addGap(0, 0, Short.MAX_VALUE)
|
.addGap(0, 0, Short.MAX_VALUE)
|
||||||
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
|
||||||
.addGroup(javax.swing.GroupLayout.Alignment.TRAILING, layout.createSequentialGroup()
|
|
||||||
.addComponent(btnSavedConfiguration1)
|
|
||||||
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
|
||||||
.addComponent(btnSavedConfiguration2)
|
|
||||||
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
|
||||||
.addComponent(btnOk)
|
|
||||||
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
|
||||||
.addComponent(btnCancel))
|
|
||||||
.addGroup(javax.swing.GroupLayout.Alignment.TRAILING, layout.createSequentialGroup()
|
|
||||||
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING)
|
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING)
|
||||||
.addGroup(layout.createSequentialGroup()
|
.addGroup(layout.createSequentialGroup()
|
||||||
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING)
|
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING)
|
||||||
|
@ -452,8 +518,8 @@ public class NewTournamentDialog extends MageDialog {
|
||||||
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
||||||
.addGroup(layout.createSequentialGroup()
|
.addGroup(layout.createSequentialGroup()
|
||||||
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
|
||||||
.addComponent(cbMulligan, javax.swing.GroupLayout.PREFERRED_SIZE, 92, javax.swing.GroupLayout.PREFERRED_SIZE)
|
.addComponent(lblMullgian)
|
||||||
.addComponent(lblMullgian))
|
.addComponent(cbMulligan, javax.swing.GroupLayout.PREFERRED_SIZE, 151, javax.swing.GroupLayout.PREFERRED_SIZE))
|
||||||
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
||||||
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING, false)
|
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING, false)
|
||||||
.addComponent(lblFreeMulligans, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
|
.addComponent(lblFreeMulligans, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
|
||||||
|
@ -483,7 +549,8 @@ public class NewTournamentDialog extends MageDialog {
|
||||||
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
||||||
.addComponent(txtPassword, javax.swing.GroupLayout.PREFERRED_SIZE, 56, javax.swing.GroupLayout.PREFERRED_SIZE)
|
.addComponent(txtPassword, javax.swing.GroupLayout.PREFERRED_SIZE, 56, javax.swing.GroupLayout.PREFERRED_SIZE)
|
||||||
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
||||||
.addComponent(cbAllowSpectators))))
|
.addComponent(cbAllowSpectators)
|
||||||
|
.addGap(0, 0, Short.MAX_VALUE))
|
||||||
.addComponent(player1Panel, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
|
.addComponent(player1Panel, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
|
||||||
.addComponent(pnlRandomPacks, javax.swing.GroupLayout.Alignment.TRAILING, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
|
.addComponent(pnlRandomPacks, javax.swing.GroupLayout.Alignment.TRAILING, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
|
||||||
.addContainerGap())
|
.addContainerGap())
|
||||||
|
@ -547,7 +614,7 @@ public class NewTournamentDialog extends MageDialog {
|
||||||
.addGroup(layout.createSequentialGroup()
|
.addGroup(layout.createSequentialGroup()
|
||||||
.addComponent(pnlPacks, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
|
.addComponent(pnlPacks, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
|
||||||
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
||||||
.addComponent(pnlRandomPacks, javax.swing.GroupLayout.DEFAULT_SIZE, 7, Short.MAX_VALUE)
|
.addComponent(pnlRandomPacks, javax.swing.GroupLayout.DEFAULT_SIZE, 10, Short.MAX_VALUE)
|
||||||
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
||||||
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING, false)
|
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.TRAILING, false)
|
||||||
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
|
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
|
||||||
|
@ -572,10 +639,12 @@ public class NewTournamentDialog extends MageDialog {
|
||||||
.addComponent(pnlPlayers, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
|
.addComponent(pnlPlayers, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
|
||||||
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
.addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
|
||||||
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
|
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
|
||||||
.addComponent(btnSavedConfiguration1)
|
.addComponent(btnOk, javax.swing.GroupLayout.PREFERRED_SIZE, 30, javax.swing.GroupLayout.PREFERRED_SIZE)
|
||||||
.addComponent(btnSavedConfiguration2)
|
.addComponent(btnCancel, javax.swing.GroupLayout.PREFERRED_SIZE, 30, javax.swing.GroupLayout.PREFERRED_SIZE)
|
||||||
.addComponent(btnOk)
|
.addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
|
||||||
.addComponent(btnCancel))
|
.addComponent(btnSettingsLoad, javax.swing.GroupLayout.PREFERRED_SIZE, 30, javax.swing.GroupLayout.PREFERRED_SIZE)
|
||||||
|
.addComponent(btnSettingsSave, javax.swing.GroupLayout.PREFERRED_SIZE, 30, javax.swing.GroupLayout.PREFERRED_SIZE)
|
||||||
|
.addComponent(lblSettings)))
|
||||||
.addContainerGap())
|
.addContainerGap())
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -589,104 +658,14 @@ public class NewTournamentDialog extends MageDialog {
|
||||||
}//GEN-LAST:event_cbTournamentTypeActionPerformed
|
}//GEN-LAST:event_cbTournamentTypeActionPerformed
|
||||||
|
|
||||||
private void btnOkActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_btnOkActionPerformed
|
private void btnOkActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_btnOkActionPerformed
|
||||||
TournamentTypeView tournamentType = (TournamentTypeView) cbTournamentType.getSelectedItem();
|
|
||||||
int numSeats = (Integer) this.spnNumSeats.getValue();
|
|
||||||
TournamentOptions tOptions = new TournamentOptions(this.txtName.getText(), "", numSeats);
|
|
||||||
tOptions.setTournamentType(tournamentType.getName());
|
|
||||||
tOptions.setPassword(txtPassword.getText());
|
|
||||||
tOptions.getPlayerTypes().add(PlayerType.HUMAN);
|
|
||||||
tOptions.setWatchingAllowed(cbAllowSpectators.isSelected());
|
|
||||||
tOptions.setPlaneChase(cbPlaneChase.isSelected());
|
|
||||||
tOptions.setQuitRatio((Integer) spnQuitRatio.getValue());
|
|
||||||
tOptions.setMinimumRating((Integer) spnMinimumRating.getValue());
|
|
||||||
for (TournamentPlayerPanel player : players) {
|
|
||||||
tOptions.getPlayerTypes().add((PlayerType) player.getPlayerType().getSelectedItem());
|
|
||||||
}
|
|
||||||
if (!tournamentType.isElimination()) {
|
|
||||||
tOptions.setNumberRounds((Integer) spnNumRounds.getValue());
|
|
||||||
}
|
|
||||||
if (tournamentType.isDraft()) {
|
|
||||||
DraftOptions options = new DraftOptions();
|
|
||||||
options.setDraftType("");
|
|
||||||
options.setTiming((TimingOption) this.cbDraftTiming.getSelectedItem());
|
|
||||||
tOptions.setLimitedOptions(options);
|
|
||||||
}
|
|
||||||
if (tOptions.getLimitedOptions() == null) {
|
|
||||||
tOptions.setLimitedOptions(new LimitedOptions());
|
|
||||||
}
|
|
||||||
if (tournamentType.isLimited()) {
|
|
||||||
tOptions.getLimitedOptions().setConstructionTime((Integer) this.spnConstructTime.getValue() * 60);
|
|
||||||
tOptions.getLimitedOptions().setIsRandom(tournamentType.isRandom());
|
|
||||||
if (tournamentType.isCubeBooster()) {
|
|
||||||
tOptions.getLimitedOptions().setDraftCubeName(this.cbDraftCube.getSelectedItem().toString());
|
|
||||||
if (!(cubeFromDeckFilename.isEmpty())) {
|
|
||||||
Deck cubeFromDeck = new Deck();
|
|
||||||
try {
|
|
||||||
cubeFromDeck = Deck.load(DeckImporter.importDeckFromFile(cubeFromDeckFilename), true, true);
|
|
||||||
} catch (GameException e1) {
|
|
||||||
JOptionPane.showMessageDialog(MageFrame.getDesktop(), e1.getMessage(), "Error loading deck", JOptionPane.ERROR_MESSAGE);
|
|
||||||
}
|
|
||||||
if (cubeFromDeck != null) {
|
|
||||||
cubeFromDeck.clearLayouts();
|
|
||||||
tOptions.getLimitedOptions().setCubeFromDeck(cubeFromDeck);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else if (tournamentType.isRandom() || tournamentType.isRichMan()) {
|
|
||||||
this.isRandom = tournamentType.isRandom();
|
|
||||||
this.isRichMan = tournamentType.isRichMan();
|
|
||||||
tOptions.getLimitedOptions().getSetCodes().clear();
|
|
||||||
ArrayList<String> selected = randomPackSelector.getSelectedPacks();
|
|
||||||
int maxPacks = 3 * (players.size() + 1);
|
|
||||||
if (tournamentType.isRichMan()) {
|
|
||||||
maxPacks = 36;
|
|
||||||
}
|
|
||||||
if (selected.size() > maxPacks) {
|
|
||||||
StringBuilder infoString = new StringBuilder("More sets were selected than needed. ");
|
|
||||||
infoString.append(maxPacks);
|
|
||||||
infoString.append(" sets will be randomly chosen.");
|
|
||||||
JOptionPane.showMessageDialog(MageFrame.getDesktop(), infoString, "Information", JOptionPane.INFORMATION_MESSAGE);
|
|
||||||
Collections.shuffle(selected);
|
|
||||||
tOptions.getLimitedOptions().getSetCodes().addAll(selected.subList(0, maxPacks));
|
|
||||||
} else {
|
|
||||||
tOptions.getLimitedOptions().getSetCodes().addAll(selected);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
for (JPanel panel : packPanels) {
|
|
||||||
JComboBox combo = findComboInComponent(panel);
|
|
||||||
if (combo != null) {
|
|
||||||
tOptions.getLimitedOptions().getSetCodes().add(((ExpansionInfo) combo.getSelectedItem()).getCode());
|
|
||||||
} else {
|
|
||||||
logger.error("Can't find combo component in " + panel.toString());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
tOptions.getMatchOptions().setDeckType("Limited");
|
|
||||||
tOptions.getMatchOptions().setGameType("Two Player Duel");
|
|
||||||
tOptions.getMatchOptions().setLimited(true);
|
|
||||||
} else {
|
|
||||||
tOptions.getLimitedOptions().setConstructionTime(0);
|
|
||||||
tOptions.getLimitedOptions().setNumberBoosters(0);
|
|
||||||
tOptions.getLimitedOptions().setDraftCube(null);
|
|
||||||
tOptions.getLimitedOptions().setDraftCubeName("");
|
|
||||||
tOptions.getMatchOptions().setDeckType((String) this.cbDeckType.getSelectedItem());
|
|
||||||
tOptions.getMatchOptions().setGameType(((GameTypeView) this.cbGameType.getSelectedItem()).getName());
|
|
||||||
tOptions.getMatchOptions().setLimited(false);
|
|
||||||
}
|
|
||||||
|
|
||||||
String serverAddress = SessionHandler.getSession().getServerHostname().orElseGet(() -> "");
|
// get settings
|
||||||
tOptions.getMatchOptions().setBannedUsers(IgnoreList.ignoreList(serverAddress));
|
TournamentOptions tOptions = getTournamentOptions();
|
||||||
|
|
||||||
tOptions.getMatchOptions().setMatchTimeLimit((MatchTimeLimit) this.cbTimeLimit.getSelectedItem());
|
// save last settings
|
||||||
tOptions.getMatchOptions().setSkillLevel((SkillLevel) this.cbSkillLevel.getSelectedItem());
|
onSaveSettings(0, tOptions);
|
||||||
tOptions.getMatchOptions().setWinsNeeded((Integer) this.spnNumWins.getValue());
|
|
||||||
tOptions.getMatchOptions().setFreeMulligans((Integer) this.spnFreeMulligans.getValue());
|
|
||||||
tOptions.getMatchOptions().setMullgianType((MulliganType) this.cbMulligan.getSelectedItem());
|
|
||||||
tOptions.getMatchOptions().setAttackOption(MultiplayerAttackOption.LEFT);
|
|
||||||
tOptions.getMatchOptions().setRange(RangeOfInfluence.ALL);
|
|
||||||
tOptions.getMatchOptions().setRollbackTurnsAllowed(this.chkRollbackTurnsAllowed.isSelected());
|
|
||||||
tOptions.getMatchOptions().setRated(this.chkRated.isSelected());
|
|
||||||
saveTournamentSettingsToPrefs(tOptions);
|
|
||||||
|
|
||||||
|
// run
|
||||||
table = SessionHandler.createTournamentTable(roomId, tOptions);
|
table = SessionHandler.createTournamentTable(roomId, tOptions);
|
||||||
if (table == null) {
|
if (table == null) {
|
||||||
// message must be send by server!
|
// message must be send by server!
|
||||||
|
@ -812,13 +791,37 @@ public class NewTournamentDialog extends MageDialog {
|
||||||
// TODO add your handling code here:
|
// TODO add your handling code here:
|
||||||
}//GEN-LAST:event_spnMinimumRatingnumPlayersChanged
|
}//GEN-LAST:event_spnMinimumRatingnumPlayersChanged
|
||||||
|
|
||||||
private void btnSavedConfiguration1ActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_btnSavedConfiguration1ActionPerformed
|
private void menuSaveSettings1ActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_menuSaveSettings1ActionPerformed
|
||||||
onSaveConfiguration(1);
|
onSaveSettings(1);
|
||||||
}//GEN-LAST:event_btnSavedConfiguration1ActionPerformed
|
}//GEN-LAST:event_menuSaveSettings1ActionPerformed
|
||||||
|
|
||||||
private void btnSavedConfiguration2ActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_btnSavedConfiguration2ActionPerformed
|
private void menuSaveSettings2ActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_menuSaveSettings2ActionPerformed
|
||||||
onSaveConfiguration(2);
|
onSaveSettings(2);
|
||||||
}//GEN-LAST:event_btnSavedConfiguration2ActionPerformed
|
}//GEN-LAST:event_menuSaveSettings2ActionPerformed
|
||||||
|
|
||||||
|
private void menuLoadSettingsLastActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_menuLoadSettingsLastActionPerformed
|
||||||
|
onLoadSettings(0);
|
||||||
|
}//GEN-LAST:event_menuLoadSettingsLastActionPerformed
|
||||||
|
|
||||||
|
private void menuLoadSettings1ActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_menuLoadSettings1ActionPerformed
|
||||||
|
onLoadSettings(1);
|
||||||
|
}//GEN-LAST:event_menuLoadSettings1ActionPerformed
|
||||||
|
|
||||||
|
private void menuLoadSettings2ActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_menuLoadSettings2ActionPerformed
|
||||||
|
onLoadSettings(2);
|
||||||
|
}//GEN-LAST:event_menuLoadSettings2ActionPerformed
|
||||||
|
|
||||||
|
private void menuLoadSettingsDefaultActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_menuLoadSettingsDefaultActionPerformed
|
||||||
|
onLoadSettings(-1);
|
||||||
|
}//GEN-LAST:event_menuLoadSettingsDefaultActionPerformed
|
||||||
|
|
||||||
|
private void btnSettingsSaveMouseClicked(java.awt.event.MouseEvent evt) {//GEN-FIRST:event_btnSettingsSaveMouseClicked
|
||||||
|
popupSaveSettings.show(evt.getComponent(), evt.getX(), evt.getY());
|
||||||
|
}//GEN-LAST:event_btnSettingsSaveMouseClicked
|
||||||
|
|
||||||
|
private void btnSettingsLoadMouseClicked(java.awt.event.MouseEvent evt) {//GEN-FIRST:event_btnSettingsLoadMouseClicked
|
||||||
|
popupLoadSettings.show(evt.getComponent(), evt.getX(), evt.getY());
|
||||||
|
}//GEN-LAST:event_btnSettingsLoadMouseClicked
|
||||||
|
|
||||||
private void setGameOptions() {
|
private void setGameOptions() {
|
||||||
GameTypeView gameType = (GameTypeView) cbGameType.getSelectedItem();
|
GameTypeView gameType = (GameTypeView) cbGameType.getSelectedItem();
|
||||||
|
@ -1107,23 +1110,154 @@ public class NewTournamentDialog extends MageDialog {
|
||||||
automaticChange = false;
|
automaticChange = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
private void loadBoosterPacks(String packString) {
|
||||||
* set the tournament settings from java prefs
|
if (!packString.isEmpty()) {
|
||||||
*/
|
String[] packsArray = packString.substring(1, packString.length() - 1).split(",");
|
||||||
int currentSettingVersion = 0;
|
int packNumber = 0;
|
||||||
|
for (String pack : packsArray) {
|
||||||
|
packNumber++;
|
||||||
|
if (this.packPanels.size() >= packNumber - 1) {
|
||||||
|
JPanel panel = packPanels.get(packNumber - 1);
|
||||||
|
JComboBox comboBox = findComboInComponent(panel);
|
||||||
|
|
||||||
private void setTournamentSettingsFromPrefs(int version) {
|
if (comboBox != null) {
|
||||||
currentSettingVersion = version;
|
ComboBoxModel model = comboBox.getModel();
|
||||||
String versionStr = "";
|
int size = model.getSize();
|
||||||
if (currentSettingVersion == 1) {
|
for (int i = 0; i < size; i++) {
|
||||||
versionStr = "1";
|
ExpansionInfo element = (ExpansionInfo) model.getElementAt(i);
|
||||||
btnSavedConfiguration1.requestFocus();
|
if (element.getCode().equals(pack.trim())) {
|
||||||
} else if (currentSettingVersion == 2) {
|
comboBox.setSelectedIndex(i);
|
||||||
versionStr = "2";
|
break;
|
||||||
btnSavedConfiguration2.requestFocus();
|
|
||||||
} else {
|
|
||||||
btnSavedConfiguration2.getParent().requestFocus();
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
logger.error("Can't find combo component in " + panel.toString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private TournamentOptions getTournamentOptions() {
|
||||||
|
TournamentTypeView tournamentType = (TournamentTypeView) cbTournamentType.getSelectedItem();
|
||||||
|
int numSeats = (Integer) this.spnNumSeats.getValue();
|
||||||
|
TournamentOptions tOptions = new TournamentOptions(this.txtName.getText(), "", numSeats);
|
||||||
|
tOptions.setTournamentType(tournamentType.getName());
|
||||||
|
tOptions.setPassword(txtPassword.getText());
|
||||||
|
tOptions.getPlayerTypes().add(PlayerType.HUMAN);
|
||||||
|
tOptions.setWatchingAllowed(cbAllowSpectators.isSelected());
|
||||||
|
tOptions.setPlaneChase(cbPlaneChase.isSelected());
|
||||||
|
tOptions.setQuitRatio((Integer) spnQuitRatio.getValue());
|
||||||
|
tOptions.setMinimumRating((Integer) spnMinimumRating.getValue());
|
||||||
|
for (TournamentPlayerPanel player : players) {
|
||||||
|
tOptions.getPlayerTypes().add((PlayerType) player.getPlayerType().getSelectedItem());
|
||||||
|
}
|
||||||
|
if (!tournamentType.isElimination()) {
|
||||||
|
tOptions.setNumberRounds((Integer) spnNumRounds.getValue());
|
||||||
|
}
|
||||||
|
if (tournamentType.isDraft()) {
|
||||||
|
DraftOptions options = new DraftOptions();
|
||||||
|
options.setDraftType("");
|
||||||
|
options.setTiming((TimingOption) this.cbDraftTiming.getSelectedItem());
|
||||||
|
tOptions.setLimitedOptions(options);
|
||||||
|
}
|
||||||
|
if (tOptions.getLimitedOptions() == null) {
|
||||||
|
tOptions.setLimitedOptions(new LimitedOptions());
|
||||||
|
}
|
||||||
|
if (tournamentType.isLimited()) {
|
||||||
|
tOptions.getLimitedOptions().setConstructionTime((Integer) this.spnConstructTime.getValue() * 60);
|
||||||
|
tOptions.getLimitedOptions().setIsRandom(tournamentType.isRandom());
|
||||||
|
if (tournamentType.isCubeBooster()) {
|
||||||
|
tOptions.getLimitedOptions().setDraftCubeName(this.cbDraftCube.getSelectedItem().toString());
|
||||||
|
if (!(cubeFromDeckFilename.isEmpty())) {
|
||||||
|
Deck cubeFromDeck = new Deck();
|
||||||
|
try {
|
||||||
|
cubeFromDeck = Deck.load(DeckImporter.importDeckFromFile(cubeFromDeckFilename), true, true);
|
||||||
|
} catch (GameException e1) {
|
||||||
|
JOptionPane.showMessageDialog(MageFrame.getDesktop(), e1.getMessage(), "Error loading deck", JOptionPane.ERROR_MESSAGE);
|
||||||
|
}
|
||||||
|
if (cubeFromDeck != null) {
|
||||||
|
cubeFromDeck.clearLayouts();
|
||||||
|
tOptions.getLimitedOptions().setCubeFromDeck(cubeFromDeck);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (tournamentType.isRandom() || tournamentType.isRichMan()) {
|
||||||
|
this.isRandom = tournamentType.isRandom();
|
||||||
|
this.isRichMan = tournamentType.isRichMan();
|
||||||
|
tOptions.getLimitedOptions().getSetCodes().clear();
|
||||||
|
ArrayList<String> selected = randomPackSelector.getSelectedPacks();
|
||||||
|
int maxPacks = 3 * (players.size() + 1);
|
||||||
|
if (tournamentType.isRichMan()) {
|
||||||
|
maxPacks = 36;
|
||||||
|
}
|
||||||
|
if (selected.size() > maxPacks) {
|
||||||
|
StringBuilder infoString = new StringBuilder("More sets were selected than needed. ");
|
||||||
|
infoString.append(maxPacks);
|
||||||
|
infoString.append(" sets will be randomly chosen.");
|
||||||
|
JOptionPane.showMessageDialog(MageFrame.getDesktop(), infoString, "Information", JOptionPane.INFORMATION_MESSAGE);
|
||||||
|
Collections.shuffle(selected);
|
||||||
|
tOptions.getLimitedOptions().getSetCodes().addAll(selected.subList(0, maxPacks));
|
||||||
|
} else {
|
||||||
|
tOptions.getLimitedOptions().getSetCodes().addAll(selected);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for (JPanel panel : packPanels) {
|
||||||
|
JComboBox combo = findComboInComponent(panel);
|
||||||
|
if (combo != null) {
|
||||||
|
tOptions.getLimitedOptions().getSetCodes().add(((ExpansionInfo) combo.getSelectedItem()).getCode());
|
||||||
|
} else {
|
||||||
|
logger.error("Can't find combo component in " + panel.toString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
tOptions.getMatchOptions().setDeckType("Limited");
|
||||||
|
tOptions.getMatchOptions().setGameType("Two Player Duel");
|
||||||
|
tOptions.getMatchOptions().setLimited(true);
|
||||||
|
} else {
|
||||||
|
tOptions.getLimitedOptions().setConstructionTime(0);
|
||||||
|
tOptions.getLimitedOptions().setNumberBoosters(0);
|
||||||
|
tOptions.getLimitedOptions().setDraftCube(null);
|
||||||
|
tOptions.getLimitedOptions().setDraftCubeName("");
|
||||||
|
tOptions.getMatchOptions().setDeckType((String) this.cbDeckType.getSelectedItem());
|
||||||
|
tOptions.getMatchOptions().setGameType(((GameTypeView) this.cbGameType.getSelectedItem()).getName());
|
||||||
|
tOptions.getMatchOptions().setLimited(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
String serverAddress = SessionHandler.getSession().getServerHostname().orElseGet(() -> "");
|
||||||
|
tOptions.getMatchOptions().setBannedUsers(IgnoreList.ignoreList(serverAddress));
|
||||||
|
|
||||||
|
tOptions.getMatchOptions().setMatchTimeLimit((MatchTimeLimit) this.cbTimeLimit.getSelectedItem());
|
||||||
|
tOptions.getMatchOptions().setSkillLevel((SkillLevel) this.cbSkillLevel.getSelectedItem());
|
||||||
|
tOptions.getMatchOptions().setWinsNeeded((Integer) this.spnNumWins.getValue());
|
||||||
|
tOptions.getMatchOptions().setFreeMulligans((Integer) this.spnFreeMulligans.getValue());
|
||||||
|
tOptions.getMatchOptions().setMullgianType((MulliganType) this.cbMulligan.getSelectedItem());
|
||||||
|
tOptions.getMatchOptions().setAttackOption(MultiplayerAttackOption.LEFT);
|
||||||
|
tOptions.getMatchOptions().setRange(RangeOfInfluence.ALL);
|
||||||
|
tOptions.getMatchOptions().setRollbackTurnsAllowed(this.chkRollbackTurnsAllowed.isSelected());
|
||||||
|
tOptions.getMatchOptions().setRated(this.chkRated.isSelected());
|
||||||
|
|
||||||
|
return tOptions;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void onLoadSettings(int version) {
|
||||||
|
|
||||||
|
String versionStr = "";
|
||||||
|
switch (version) {
|
||||||
|
case -1:
|
||||||
|
versionStr = "-1"; // default (empty)
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
versionStr = "1";
|
||||||
|
break;
|
||||||
|
case 2:
|
||||||
|
versionStr = "2";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
versionStr = "";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
int numPlayers;
|
int numPlayers;
|
||||||
txtName.setText(PreferencesDialog.getCachedValue(PreferencesDialog.KEY_NEW_TOURNAMENT_NAME + versionStr, "Tournament"));
|
txtName.setText(PreferencesDialog.getCachedValue(PreferencesDialog.KEY_NEW_TOURNAMENT_NAME + versionStr, "Tournament"));
|
||||||
txtPassword.setText(PreferencesDialog.getCachedValue(PreferencesDialog.KEY_NEW_TOURNAMENT_PASSWORD + versionStr, ""));
|
txtPassword.setText(PreferencesDialog.getCachedValue(PreferencesDialog.KEY_NEW_TOURNAMENT_PASSWORD + versionStr, ""));
|
||||||
|
@ -1191,48 +1325,26 @@ public class NewTournamentDialog extends MageDialog {
|
||||||
this.chkRated.setSelected(PreferencesDialog.getCachedValue(PreferencesDialog.KEY_NEW_TOURNAMENT_RATED + versionStr, "No").equals("Yes"));
|
this.chkRated.setSelected(PreferencesDialog.getCachedValue(PreferencesDialog.KEY_NEW_TOURNAMENT_RATED + versionStr, "No").equals("Yes"));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void loadBoosterPacks(String packString) {
|
private void onSaveSettings(int version) {
|
||||||
if (!packString.isEmpty()) {
|
TournamentOptions tOptions = getTournamentOptions();
|
||||||
String[] packsArray = packString.substring(1, packString.length() - 1).split(",");
|
onSaveSettings(version, tOptions);
|
||||||
int packNumber = 0;
|
}
|
||||||
for (String pack : packsArray) {
|
|
||||||
packNumber++;
|
|
||||||
if (this.packPanels.size() >= packNumber - 1) {
|
|
||||||
JPanel panel = packPanels.get(packNumber - 1);
|
|
||||||
JComboBox comboBox = findComboInComponent(panel);
|
|
||||||
|
|
||||||
if (comboBox != null) {
|
private void onSaveSettings(int version, TournamentOptions tOptions) {
|
||||||
ComboBoxModel model = comboBox.getModel();
|
|
||||||
int size = model.getSize();
|
String versionStr = "";
|
||||||
for (int i = 0; i < size; i++) {
|
switch (version) {
|
||||||
ExpansionInfo element = (ExpansionInfo) model.getElementAt(i);
|
case 1:
|
||||||
if (element.getCode().equals(pack.trim())) {
|
versionStr = "1";
|
||||||
comboBox.setSelectedIndex(i);
|
break;
|
||||||
|
case 2:
|
||||||
|
versionStr = "2";
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
versionStr = "";
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
} else {
|
|
||||||
logger.error("Can't find combo component in " + panel.toString());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Save the settings to java prefs to reload it next time the dialog will be
|
|
||||||
* created
|
|
||||||
*
|
|
||||||
* @param tOptions Tournament options
|
|
||||||
*/
|
|
||||||
private void saveTournamentSettingsToPrefs(TournamentOptions tOptions) {
|
|
||||||
String versionStr = "";
|
|
||||||
if (currentSettingVersion == 1) {
|
|
||||||
versionStr = "1";
|
|
||||||
} else if (currentSettingVersion == 2) {
|
|
||||||
versionStr = "2";
|
|
||||||
}
|
|
||||||
PreferencesDialog.saveValue(PreferencesDialog.KEY_NEW_TOURNAMENT_NAME + versionStr, tOptions.getName());
|
PreferencesDialog.saveValue(PreferencesDialog.KEY_NEW_TOURNAMENT_NAME + versionStr, tOptions.getName());
|
||||||
PreferencesDialog.saveValue(PreferencesDialog.KEY_NEW_TOURNAMENT_PASSWORD + versionStr, tOptions.getPassword());
|
PreferencesDialog.saveValue(PreferencesDialog.KEY_NEW_TOURNAMENT_PASSWORD + versionStr, tOptions.getPassword());
|
||||||
PreferencesDialog.saveValue(PreferencesDialog.KEY_NEW_TOURNAMENT_TIME_LIMIT + versionStr, Integer.toString(tOptions.getMatchOptions().getPriorityTime()));
|
PreferencesDialog.saveValue(PreferencesDialog.KEY_NEW_TOURNAMENT_TIME_LIMIT + versionStr, Integer.toString(tOptions.getMatchOptions().getPriorityTime()));
|
||||||
|
@ -1283,16 +1395,11 @@ public class NewTournamentDialog extends MageDialog {
|
||||||
return table;
|
return table;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onSaveConfiguration(int setting) {
|
|
||||||
currentSettingVersion = setting;
|
|
||||||
setTournamentSettingsFromPrefs(currentSettingVersion);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Variables declaration - do not modify//GEN-BEGIN:variables
|
// Variables declaration - do not modify//GEN-BEGIN:variables
|
||||||
private javax.swing.JButton btnCancel;
|
private javax.swing.JButton btnCancel;
|
||||||
private javax.swing.JButton btnOk;
|
private javax.swing.JButton btnOk;
|
||||||
private javax.swing.JButton btnSavedConfiguration1;
|
private javax.swing.JButton btnSettingsLoad;
|
||||||
private javax.swing.JButton btnSavedConfiguration2;
|
private javax.swing.JButton btnSettingsSave;
|
||||||
private javax.swing.JCheckBox cbAllowSpectators;
|
private javax.swing.JCheckBox cbAllowSpectators;
|
||||||
private javax.swing.JComboBox cbDeckType;
|
private javax.swing.JComboBox cbDeckType;
|
||||||
private javax.swing.JComboBox cbDraftCube;
|
private javax.swing.JComboBox cbDraftCube;
|
||||||
|
@ -1324,13 +1431,24 @@ public class NewTournamentDialog extends MageDialog {
|
||||||
private javax.swing.JLabel lblPassword;
|
private javax.swing.JLabel lblPassword;
|
||||||
private javax.swing.JLabel lblPlayer1;
|
private javax.swing.JLabel lblPlayer1;
|
||||||
private javax.swing.JLabel lblQuitRatio;
|
private javax.swing.JLabel lblQuitRatio;
|
||||||
|
private javax.swing.JLabel lblSettings;
|
||||||
private javax.swing.JLabel lblTournamentType;
|
private javax.swing.JLabel lblTournamentType;
|
||||||
|
private javax.swing.JMenuItem menuLoadSettings1;
|
||||||
|
private javax.swing.JMenuItem menuLoadSettings2;
|
||||||
|
private javax.swing.JMenuItem menuLoadSettingsDefault;
|
||||||
|
private javax.swing.JMenuItem menuLoadSettingsLast;
|
||||||
|
private javax.swing.JMenuItem menuSaveSettings1;
|
||||||
|
private javax.swing.JMenuItem menuSaveSettings2;
|
||||||
private mage.client.table.NewPlayerPanel player1Panel;
|
private mage.client.table.NewPlayerPanel player1Panel;
|
||||||
private javax.swing.JPanel pnlDraftOptions;
|
private javax.swing.JPanel pnlDraftOptions;
|
||||||
private javax.swing.JPanel pnlOtherPlayers;
|
private javax.swing.JPanel pnlOtherPlayers;
|
||||||
private javax.swing.JPanel pnlPacks;
|
private javax.swing.JPanel pnlPacks;
|
||||||
private javax.swing.JPanel pnlPlayers;
|
private javax.swing.JPanel pnlPlayers;
|
||||||
private javax.swing.JPanel pnlRandomPacks;
|
private javax.swing.JPanel pnlRandomPacks;
|
||||||
|
private javax.swing.JPopupMenu popupLoadSettings;
|
||||||
|
private javax.swing.JPopupMenu popupSaveSettings;
|
||||||
|
private javax.swing.JPopupMenu.Separator separator1;
|
||||||
|
private javax.swing.JPopupMenu.Separator separator2;
|
||||||
private javax.swing.JSpinner spnConstructTime;
|
private javax.swing.JSpinner spnConstructTime;
|
||||||
private javax.swing.JSpinner spnFreeMulligans;
|
private javax.swing.JSpinner spnFreeMulligans;
|
||||||
private javax.swing.JSpinner spnMinimumRating;
|
private javax.swing.JSpinner spnMinimumRating;
|
||||||
|
|
Loading…
Reference in a new issue