//========= Copyright © 1996-2005, Valve Corporation, All rights reserved. ============//
//
// Purpose: 
//
//=============================================================================//

#ifndef VGUI_HELPERS_H
#define VGUI_HELPERS_H
#ifdef _WIN32
#pragma once
#endif


#include <vgui_controls/TreeView.h>
#include <vgui_controls/CheckButton.h>


class KeyValues;
class ConVar;


// This control keeps a ConVar's value updated with a CheckButton's value.
class CConVarCheckButton : public vgui::CheckButton
{
public:
	
	typedef vgui::CheckButton BaseClass;


	CConVarCheckButton( vgui::Panel *parent, const char *panelName, const char *text );
	
	// Call this to initialize it with a cvar. The CheckButton will be set to the current
	// value of the ConVar.
	void SetConVar( ConVar *pVar );
	
	virtual void SetSelected( bool state );
	

public:
	
	ConVar *m_pConVar;
};




// Return true if the state was changed at all (in any way that would require an InvalidateLayout on the control).
typedef bool (*UpdateItemStateFn)(
	vgui::TreeView *pTree, 
	int iChildItemId, 
	KeyValues *pSub );


// This function takes a bunch of KeyValues entries and incrementally updates
// a tree control. This can be a lot more efficient than clearing the whole tree
// control and re-adding all the elements if most of the elements don't usually change.
//
// NOTE: Only KeyValues nodes with a string named "Text" will be treated as items
// that should be added to the tree.
//
// If iRoot is -1, then it uses GetRootItemIndex().
// 
// Returns true if any elements were added or changed.
bool IncrementalUpdateTree( 
	vgui::TreeView *pTree, 
	KeyValues *pValues,
	UpdateItemStateFn fn,
	int iRoot = -1
	);


// Copy the contents of the list panel to the clipboard in tab-delimited form for Excel.
void CopyListPanelToClipboard( vgui::ListPanel *pListPanel );


#endif // VGUI_HELPERS_H