/*

Miranda NG: the free IM client for Microsoft* Windows*

Copyright (�) 2012-16 Miranda NG project (http://miranda-ng.org)
Copyright (c) 2000-08 Miranda ICQ/IM project,
all portions of this codebase are copyrighted to the people
listed in contributors.txt.

This program is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
as published by the Free Software Foundation; either version 2
of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
*/
// Added in 0.3.0.0+

#ifndef M_BUTTON_H__
#define M_BUTTON_H__ 1

#define MIRANDABUTTONCLASS	_T("MButtonClass") // Class of the control

// Sets whether a dropdown arrow is used
// wParam = TRUE/FALSE turns arrow on or off
// lParam = 0 (unused)
// Usage: SendMessage(hwndbutton, BUTTONSETARROW, TRUE, 0);
// Only works on MButtonClass buttons
#define BUTTONSETARROW       (WM_USER+1)

// Sets whether the button is a default button
// wParam = TRUE/FALSE default on/off
// lParam = 0 (unused)
// Usage: SendMessage(hwndbutton, BUTTONSETDEFAULT, TRUE, 0);
// Only works on MButtonClass buttons
#define BUTTONSETDEFAULT     (WM_USER+2)

// Sets the button as a push button
// wParam = TRUE/FALSE default on/off
// lParam = 0 (unused)
// Usage: SendMessage(hwndbutton, BUTTONSETASPUSHBTN, TRUE, 0);
// Only works on MButtonClass buttons
#define BUTTONSETASPUSHBTN   (WM_USER+3)

// Sets the button type as a flat button without borders v0.3.3+
// wParam = TRUE/FALSE default on/off
// lParam = 0 (unused)
// Usage: SendMessage(hwndbutton, BUTTONSETASFLATBTN, TRUE, 0);
// Only works on MButtonClass buttons
#define BUTTONSETASFLATBTN   (WM_USER+4)

// Sets a tooltip for the button v0.3.3+
// wParam = (WPARAM)(char *)szTip
// lParam = BATF_* flags combination
// Usage: SendMessage(hwndButton, BUTTONADDTOOLTIP, (WPARAM)LPGEN("My Tip"), 0);
#define BATF_UNICODE 1
#if defined(_UNICODE)
	#define BATF_TCHAR BATF_UNICODE
#else
	#define BATF_TCHAR 0
#endif

#define BUTTONADDTOOLTIP     (WM_USER+5)

// Applies themes to a button
// wParam = TRUE/FALSE default on/off
// lParam = not used
// Usage: SendMessage(hwndbutton, BUTTONSETASTHEMEDBTN, TRUE, 0);
// Only works on MButtonClass buttons
#define BUTTONSETASTHEMEDBTN (WM_USER+6)

// Sets the custom painting procedure for a button
// wParam = new data block length (inherited from MButtonCtrl)
// lParam = (pfnPainterFunc)pfnPainter (refer to mbutton_int.h for details)
// Usage: SendMessage(hwndbutton, BUTTONSETCUSTOM, 0, (LPARAM)MyPainter);
// Only works on MButtonClass buttons
#define BUTTONSETCUSTOMPAINT (WM_USER+7)

// Forces a button to send clicks on push
// wParam = TRUE/FALSE default on/off
// lParam = 0 (unused)
// Usage: SendMessage(hwndbutton, BUTTONSETSENDONDOWN, TRUE, 0);
#define BUTTONSETSENDONDOWN  (WM_USER+8)

#endif // M_BUTTON_H__