/* Miranda NG: the free IM client for Microsoft* Windows* Copyright (C) 2012-24 Miranda NG team (https://miranda-ng.org) Copyright (c) 2000-02 Richard Hughes, Roland Rabien & Tristan Van de Vreede 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. */ #ifndef M_CLUIFRAMES_H__ #define M_CLUIFRAMES_H__ 1 #if !defined(M_GENMENU_H__) #include #endif /************************************************************************/ /* CLUI Frames Support */ /************************************************************************/ // frame alignment #define alTop 0x00001 #define alBottom 0x00002 #define alClient 0x00004 // only one alClient frame #define alLeft 0x00011 // frame is vertical #define alRight 0x00012 #define alVertFrameMask 0x00010 // frame flags #define F_VISIBLE 0x00001 // Frame visible #define F_SHOWTB 0x00002 // Show TitleBar #define F_UNCOLLAPSED 0x00004 // UnCollapse frame #define F_LOCKED 0x00008 // Lock Frame #define F_NOBORDER 0x00010 // Dont apply WS_BORDER style for window #define F_SHOWTBTIP 0x00020 // Show titlebar tooltip #define F_CANBEVERTICAL 0x00040 // frames can be vertical #define F_CANNOTBEHORIZONTAL 0x00080 // frames can NOT be horizontal F_CANBEVERTICAL have to be set #define F_NO_SUBCONTAINER 0x00400 // Support skining no subcontainer needed #define F_SKINNED 0x00800 // skinned frame (for owned subframe only) #define F_UNICODE 0x08000 // Use unicode text struct CLISTFrame { uint32_t cbSize; HWND hWnd; HICON hIcon; int align; // al flags below union { int height; int minSize; // the actual meaning depends from type of frame }; int Flags; // F_flags below MAllStrings szName; // frame window name indentifier (DO NOT TRANSLATE) MAllStrings szTBname; // titlebar & menu caption }; #define FU_TBREDRAW 1 // redraw titlebar #define FU_FMREDRAW 2 // redraw Frame #define FU_FMPOS 4 // update Frame position #define FO_FLAGS 0x0001 // return set of F_VISIBLE,F_SHOWTB,F_UNCOLLAPSED,F_LOCKED,F_NOBORDER,F_SHOWTBTIP #define FO_NAME 0x0002 // Change m_cacheTName #define FO_TBNAME 0x0003 // Change TB caption #define FO_TBSTYLE 0x0004 // Change TB style #define FO_TBEXSTYLE 0x0005 // Change TB exstyle #define FO_ICON 0x0006 // Change icon #define FO_HEIGHT 0x0007 // Change height #define FO_ALIGN 0x0008 // Change align #define FO_TBTIPNAME 0x0009 // Change TB tooltip #define FO_FLOATING 0x000a // Change floating mode #define FO_UNICODETEXT 0x8000 // flag for FO_NAME,FO_TBNAME, FO_TBTIPNAME set/get lPAram as unicode wchar_t ////////////////////////////////////////////////////////////////////////// // want show tooltip for statusbar // wparam=(char *)protocolname // lparam=0 #define ME_CLIST_FRAMES_SB_SHOW_TOOLTIP "CListFrames/StatusBarShowToolTip" ////////////////////////////////////////////////////////////////////////// //want hide tooltip for statusbar //wparam=lparam=0 #define ME_CLIST_FRAMES_SB_HIDE_TOOLTIP "CListFrames/StatusBarHideToolTip" ////////////////////////////////////////////////////////////////////////// // adds a frame window // wParam=(CLISTFrame*) // lParam=(HPLUGIN)&g_plugin // returns an integer, the frame id. #define MS_CLIST_FRAMES_ADDFRAME "CListFrames/AddFrame" ////////////////////////////////////////////////////////////////////////// // remove frame. It destroy your window // #define MS_CLIST_FRAMES_REMOVEFRAME "CListFrames/RemoveFrame" ////////////////////////////////////////////////////////////////////////// //shows all frames //wParam=lParam=0 //returns 0 on success, -1 on failure #define MS_CLIST_FRAMES_SHOWALLFRAMES "CListFrames/ShowALLFrames" ////////////////////////////////////////////////////////////////////////// //shows the titlebars of all frames //wParam=lParam=0 //returns 0 on success, -1 on failure #define MS_CLIST_FRAMES_SHOWALLFRAMESTB "CListFrames/ShowALLFramesTB" ////////////////////////////////////////////////////////////////////////// //hides the titlebars of all frames //wParam=lParam=0 //returns 0 on success, -1 on failure #define MS_CLIST_FRAMES_HIDEALLFRAMESTB "CListFrames/HideALLFramesTB" ////////////////////////////////////////////////////////////////////////// //shows the frame if it is hidden, //hides the frame if it is shown //wParam = FrameId //lParam = Frame number (can be shown in profile in CLUIFrames key) //returns 0 on success, -1 on failure //note that Frame number will be taken only if wParam == 0 #define MS_CLIST_FRAMES_SHFRAME "CListFrames/SHFrame" ////////////////////////////////////////////////////////////////////////// //shows the frame titlebar if it is hidden, //hides the frame titlebar if it is shown //wParam=FrameId //lParam = Frame number (can be shown in profile in CLUIFrames key) //returns 0 on success, -1 on failure //note that Frame number will be taken only if wParam == 0 #define MS_CLIST_FRAMES_SHFRAMETITLEBAR "CListFrame/SHFrameTitleBar" ////////////////////////////////////////////////////////////////////////// //locks the frame if it is unlocked, //unlock the frame if it is locked //wParam=FrameId //lParam = Frame number (can be shown in profile in CLUIFrames key) //returns 0 on success, -1 on failure //note that Frame number will be taken only if wParam == 0 #define MS_CLIST_FRAMES_ULFRAME "CListFrame/ULFrame" ////////////////////////////////////////////////////////////////////////// //collapses the frame if it is uncollapsed, //uncollapses the frame if it is collapsed //wParam=FrameId //lParam = Frame number (can be shown in profile in CLUIFrames key) //returns 0 on success, -1 on failure //note that Frame number will be taken only if wParam == 0 #define MS_CLIST_FRAMES_UCOLLFRAME "CListFrame/UCOLLFrame" ////////////////////////////////////////////////////////////////////////// //trigger border flags //wparam=frameid //lParam = Frame number (can be shown in profile in CLUIFrames key) //returns 0 on success, -1 on failure //note that Frame number will be taken only if wParam == 0 #define MS_CLIST_FRAMES_SETUNBORDER "CListFrame/SetUnBorder" ////////////////////////////////////////////////////////////////////////// //trigger skinned flags //wparam=frameid //lparam=0 #define MS_CLIST_FRAMES_SETSKINNED "CListFrame/SetSkinnedFrame" ////////////////////////////////////////////////////////////////////////// //redraws the frame //wParam=FrameId, -1 for all frames //lparam=FU_flags //returns a pointer to option, -1 on failure #define MS_CLIST_FRAMES_UPDATEFRAME "CListFrame/UpdateFrame" ////////////////////////////////////////////////////////////////////////// //gets the frame options //(HIWORD)wParam=FrameId //(LOWORD)wParam=FO_flag //lParam=0 //returns a pointer to option, -1 on failure #define MS_CLIST_FRAMES_GETFRAMEOPTIONS "CListFrame/GetFrameOptions" //sets the frame options //(HIWORLD)wParam=FrameId //(LOWORD)wParam=FO_flag //lParam=value //returns 0 on success, -1 on failure #define MS_CLIST_FRAMES_SETFRAMEOPTIONS "CListFrame/SetFrameOptions" ////////////////////////////////////////////////////////////////////////// //Frames related menu stuff ////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////// //add a new item to the context frame menu //wParam=0 //lParam=(LPARAM)(CLISTMENUITEM*)&mi //returns a handle to the new item //popupposition=frameid //contactowner=advanced parameter __forceinline HGENMENU Menu_AddContextFrameMenuItem(TMO_MenuItem *pmi) { return (HGENMENU)CallService("CList/AddContextFrameMenuItem", 0, (LPARAM)pmi); } ////////////////////////////////////////////////////////////////////////// //builds the context menu for a frame //wparam=frameid //lParam=0 //returns a HMENU on success, or NULL on failure #define MS_CLIST_MENUBUILDFRAMECONTEXT "CList/BuildContextFrameMenu" ////////////////////////////////////////////////////////////////////////// // the frame menu is about to be built // wparam=frameid // lparam= // -1 for build from titlebar, // use // MS_CLIST_ADDCONTEXTFRAMEMENUITEM // MS_CLIST_REMOVECONTEXTFRAMEMENUITEM // // >0 for build in main menu, // must be popupname=lparam to place your items in right popup of main menu. // use // MS_CLIST_ADDMAINMENUITEM // MS_CLIST_REMOVEMAINMENUITEM // #define ME_CLIST_PREBUILDFRAMEMENU "CList/PreBuildFrameMenu" ////////////////////////////////////////////////////////////////////////// //needed by cluiframes module to add frames menu to main menu. //it just calls NotifyEventHooks(hPreBuildFrameMenuEvent,wParam,lParam); #define MS_CLIST_FRAMEMENUNOTIFY "CList/ContextFrameMenuNotify" #endif /* M_CLUIFRAMES_H__ */