Merge branch 'z411/welcome_join' into 'master'
authorterencehill <piuntn@gmail.com>
Sat, 4 Jun 2022 21:05:48 +0000 (21:05 +0000)
committerterencehill <piuntn@gmail.com>
Sat, 4 Jun 2022 21:05:48 +0000 (21:05 +0000)
Add join button to Welcome dialog and make it default

See merge request xonotic/xonotic-data.pk3dir!1021

qcsrc/menu/xonotic/commandbutton.qh
qcsrc/menu/xonotic/dialog_welcome.qc
qcsrc/menu/xonotic/dialog_welcome.qh

index cd1063523d59f7d3273e17b5eb5800d8aecaa2a9..7e5044c24fa8708378e07ac2fa1f02073ee757f5 100644 (file)
@@ -9,6 +9,7 @@ ENDCLASS(XonoticCommandButton)
 
 entity makeXonoticCommandButton_T(string theText, vector theColor, string theCommand, int theFlags, string theTooltip);
 entity makeXonoticCommandButton(string theText, vector theColor, string theCommand, int theFlags);
+void XonoticCommandButton_Click(entity me, entity other);
 
 #ifndef COMMANDBUTTON_CLOSE
 # define COMMANDBUTTON_CLOSE 1
index 5da6f8b1ea9a0bb30aba0786c0bba645f59f2d3b..6448a0fca5333b3f71e0bc5ea736e74cf9435d7e 100644 (file)
@@ -20,7 +20,7 @@ float XonoticWelcomeDialog_keyDown(entity me, float key, float ascii, float shif
                case K_KP_ENTER:
                case K_ENTER:
                case K_SPACE:
-                       me.close(me);
+                       XonoticCommandButton_Click(me.joinButton_ent, me);
                        return true;
                default:
                        return SUPER(XonoticWelcomeDialog).keyDown(me, key, ascii, shift);
@@ -99,8 +99,7 @@ void XonoticWelcomeDialog_fill(entity me)
                        me.serverinfo_MOTD_ent.allowColors = true;
                        me.serverinfo_MOTD_ent.escapedNewLines = true;
        me.gotoRC(me, me.rows - 1, 0);
-               me.TD(me, 1, me.columns, e = makeXonoticButton(_("OK"), '0 0 0'));
-                       e.onClick = Dialog_Close;
-                       e.onClickEntity = me;
-                       e.preferredFocusPriority = 1;
+               me.TD(me, 1, me.columns / 2, me.joinButton_ent = makeXonoticCommandButton(_("Join"), '0 1 0', "cmd join", COMMANDBUTTON_CLOSE));
+                       me.joinButton_ent.preferredFocusPriority = 1;
+               me.TD(me, 1, me.columns / 2, makeXonoticCommandButton(_("Spectate"), '0 0 0', "cmd spectate", COMMANDBUTTON_CLOSE));
 }
index d02cd6e73ca1c8ed99d75169f0d79ef88010235e..bca7e56e6e96d4eda373a949a9a466ec3c238b22 100644 (file)
@@ -19,5 +19,6 @@ CLASS(XonoticWelcomeDialog, XonoticRootDialog)
        //ATTRIB(XonoticWelcomeDialog, serverinfo_name_ent, entity, world);
        ATTRIB(XonoticWelcomeDialog, serverinfo_MOTD, string, string_null);
        ATTRIB(XonoticWelcomeDialog, serverinfo_MOTD_ent, entity, world);
+       ATTRIB(XonoticWelcomeDialog, joinButton_ent, entity, world);
        ATTRIB(XonoticWelcomeDialog, requiresConnection, bool, true);
 ENDCLASS(XonoticWelcomeDialog)