source-engine/game/client/tf/c_tf_notification.cpp

238 lines
6.2 KiB
C++
Raw Normal View History

2020-04-22 16:56:21 +00:00
//========= Copyright Valve Corporation, All rights reserved. ============//
//
// Purpose:
//
// $NoKeywords: $
//=============================================================================//
#include "cbase.h"
#include "tf_notification.h"
#include "c_tf_notification.h"
#include "tf_gc_client.h"
#include "econ/econ_notifications.h"
///
/// Support message notification dialog
///
class CTFSupportNotificationDialog : public CTFMessageBoxDialog
{
DECLARE_CLASS_SIMPLE( CTFSupportNotificationDialog, CTFMessageBoxDialog );
public:
CTFSupportNotificationDialog( int iNotificationID, const char *pszSupportMessage )
: CTFMessageBoxDialog( NULL, pszSupportMessage, NULL, NULL, NULL )
, m_iNotificationID( iNotificationID )
, m_pConfirmDialog( NULL )
{
SetDialogVariable( "text", GetText() );
}
void CleanupConfirmDialog()
{
if ( m_pConfirmDialog )
{
m_pConfirmDialog->SetVisible( false );
m_pConfirmDialog->MarkForDeletion();
m_pConfirmDialog = NULL;
}
}
virtual ~CTFSupportNotificationDialog() {
CleanupConfirmDialog();
}
void ConfirmDialogCallback( bool bConfirmed )
{
CleanupConfirmDialog();
if ( bConfirmed )
{
// User acknowledged the message, tell the notification it can go away now
CClientNotification *pNotification = dynamic_cast< CClientNotification * >( NotificationQueue_Get( m_iNotificationID ) );
if ( pNotification )
{
pNotification->OnDialogAcknowledged();
}
BaseClass::OnCommand( "confirm" );
}
}
static void StaticConfirmDialogCallback( bool bConfirmed, void *pContext )
{
static_cast< CTFSupportNotificationDialog * >( pContext )->ConfirmDialogCallback( bConfirmed );
}
virtual void OnCommand( const char *command ) OVERRIDE
{
if ( FStrEq( "acknowledge", command ) )
{
// Confirm this, it's going away forever!
CleanupConfirmDialog();
m_pConfirmDialog = ShowConfirmDialog( "#DeleteConfirmDefault",
"#TF_Support_Message_Confirm_Acknowledge_Text",
"#TF_Support_Message_Acknowledge", "#Cancel",
&StaticConfirmDialogCallback );
m_pConfirmDialog->SetContext( this );
return;
}
else if ( FStrEq( "show_later", command ) )
{
// User selected "show this later" -- leave notification as is and close.
CleanupConfirmDialog();
BaseClass::OnCommand( "confirm" );
return;
}
BaseClass::OnCommand( command );
}
virtual const char *GetResFile() OVERRIDE
{
return "Resource/UI/SupportNotificationDialog.res";
}
private:
// Associated notification to clear
int m_iNotificationID;
CTFGenericConfirmDialog *m_pConfirmDialog;
};
///
/// The notification class
///
CClientNotification::CClientNotification()
{
m_pText = NULL;
m_flExpireTime = CRTime::RTime32TimeCur();
m_ulNotificationID = 0;
m_unAccountID = 0;
m_bSupportMessage = false;
}
CClientNotification::~CClientNotification()
{}
void CClientNotification::Update( const CTFNotification* notification )
{
// Custom type handling. For now only support message does anything special.
m_bSupportMessage = false;
switch ( notification->Obj().type() )
{
case CMsgGCNotification_NotificationType_NOTIFICATION_REPORTED_PLAYER_BANNED:
case CMsgGCNotification_NotificationType_NOTIFICATION_CUSTOM_STRING:
case CMsgGCNotification_NotificationType_NOTIFICATION_MM_BAN_DUE_TO_EXCESSIVE_REPORTS:
case CMsgGCNotification_NotificationType_NOTIFICATION_REPORTED_PLAYER_WAS_BANNED:
// All identical.
//
// Really, the other types could be used to avoid having to send a localization string down? Otherwise
// they're all just redundant with CUSTOM_STRING for now.
break;
case CMsgGCNotification_NotificationType_NOTIFICATION_SUPPORT_MESSAGE:
m_bSupportMessage = true;
break;
default:
Assert( !"Unhandled enum value" );
}
m_pText = NULL;
m_strText = notification->Obj().notification_string().c_str();
if ( m_bSupportMessage )
{
// Use generic notification, save actual notification contents for dialog
m_pText = "#TF_Support_Message_Notification";
}
else
{
// Just use our message
m_pText = m_strText.Get();
}
// 0 -> does not expire
RTime32 rtExpire = notification->Obj().expiration_time();
m_flExpireTime = rtExpire > 0 ? (float)rtExpire : FLT_MAX;
m_ulNotificationID = notification->Obj().notification_id();
m_unAccountID = notification->Obj().account_id();
}
void CClientNotification::GCAcknowledge() {
GTFGCClientSystem()->AcknowledgeNotification( m_unAccountID, m_ulNotificationID );
}
void CClientNotification::Deleted()
{
if ( m_bSupportMessage )
{
AssertMsg( !m_bSupportMessage,
"Support messages should only be able to be triggered, not deleted" );
return;
}
GCAcknowledge();
}
void CClientNotification::Expired()
{
// No action, we don't want de-sync'd client clock to acknowledge these incorrectly, GC will expire them on its end.
}
CClientNotification::EType CClientNotification::NotificationType()
{
// Support messages are "must trigger" type -- no delete action, user must click "view"
if ( m_bSupportMessage )
{
return eType_MustTrigger;
}
return eType_Basic;
}
bool CClientNotification::BHighPriority()
{
return m_bSupportMessage;
}
void CClientNotification::Trigger()
{
if ( !m_bSupportMessage )
{
AssertMsg( m_bSupportMessage,
"Don't expect to be trigger-able when not in support message mode" );
return;
}
CTFSupportNotificationDialog *pDialog = vgui::SETUP_PANEL( new CTFSupportNotificationDialog( GetID(), m_strText.Get() ) );
pDialog->Show();
}
void CClientNotification::OnDialogAcknowledged()
{
if ( !m_bSupportMessage )
{
AssertMsg( m_bSupportMessage,
"Don't expect to be getting callbacks from the support message dialog when not in support message mode" );
return;
}
GCAcknowledge();
MarkForDeletion();
}
//-----------------------------------------------------------------------------
// CAutobalanceVolunteerNotification
//-----------------------------------------------------------------------------
void CAutobalanceVolunteerNotification::SendResponse( bool bResponse )
{
KeyValues *kv = new KeyValues( "AutoBalanceVolunteerReply" );
kv->SetBool( "response", bResponse );
engine->ServerCmdKeyValues( kv );
MarkForDeletion();
}