{ Miranda IM: the free IM client for Microsoft* Windows* Copyright 2000-2003 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. } {$IFNDEF M_CLUI} {$DEFINE M_CLUI} {<</ this header was created for use for v0.1.1.0, most of it's UI related stuff and you probably don't need to call it, see m_clist.inc instead. -- There are some functions that were implemented in v0.1.2.0 though />>} const { wParam : 0 lParam : 0 Affects: Returns a window handle for the contact list window, see notes Returns: "" Notes : This call has a very specific purpose internally Miranda and shouldn't be used gratuitously, in almost all cases there's another call to do whatever it is that you're trying to do. } MS_CLUI_GETHWND:PAnsiChar = 'CLUI/GetHwnd'; //get ContactTree hwnd MS_CLUI_GETHWNDTREE:PAnsiChar = 'CLUI/GetHwndTree'; { wParam : new status lParam : null terminated string to a protocol ID Affects: Change the protocol specific status indicators, see notes! Returns: 0 on success, [non zero] on failure Notes : protocol modules don't want to call this, they want clist/protocolstatuschanged instead } MS_CLUI_PROTOCOLSTATUSCHANGED:PAnsiChar = 'CLUI/ProtocolStatusChanged'; { wParam : Handle to a group lParam : 1 or 0 Affect : A new group was created, add it to the list, see notes Notes : lParam is set to 1 or 0 if the user just created the group or not. - this is also called when the contact list is being rebuilt, new groups are always created with the name 'New group' } MS_CLUI_GROUPADDED:PAnsiChar = 'CLUI/GroupCreated'; { wParam : HCONTACT lParam : ICON_ID Affect : Change the icon for a contact, see notes Returns: 0 on success, [non zero] on failure Notes : ICON_ID is an offset in the imagelist, see clist/geticonsimagelist } MS_CLUI_CONTACTSETICON:PAnsiChar = 'CLUI/ContactSetIcon'; { wParam : HCONTACT lParam : 0 Affect : Remove a contact from the list, see notes Returns: 0 on success, [non zereo] on failure Notes : this contact is NOT actually being deleted, since if a contact goes offline while 'hide offline' option is sset, this service will be called then ALSO } MS_CLUI_CONTACTDELETED:PAnsiChar = 'CLUI/ContactDeleted'; { wParam : HCONTACT lParam : ICON_ID Affect : Add a contact to the list, see note returns: 0 on success, [non zero] on failure Notes : the caller processes the 'hide offline' setting, so the callee should not do further processing based on the value of this setting - WARNING: this will be called to re-add a contact when they come online if 'hide offline' is on, but it cannot determine if the contact is already on the list, so you may get requests to add a contact when it is already on the list, which you should ignore. - You'll also get this whenever an event is added for a contact, since if the contact was offline, it needs to be shown to display the mesage, even if 'hide offlines' is on. - you should not resort the list on this call, a seperate resort request will be sent. - ICON_ID is an offset in the image list, see clist/geticonsimagelist } MS_CLUI_CONTACTADDED:PAnsiChar = 'CLUI/ContactAdded'; { wParam : HCONTACT lParam : 0 Affect : Reename a contact in the lists, see notes Returns: 0 on success, [non zero] on failure Notes : You should not re-sort the list on this call, a separate resort request will be sent, you can get the new name from clist/getcontactdisplayname } MS_CLUI_CONTACTRENAMED:PAnsiChar = 'CLUI/ContactRenamed'; { wParam : 0 lParam : 0 Affect : Start a rebuild of the contact list, see notes Returns: 0 on success, [non zero] on failure Notes : this is the cue to clear the existing content of the list expect to get a series of : clui/groupadded clui/contactadded clui/resortlist } MS_CLUI_LISTBEGINREBUILD:PAnsiChar = 'CLUI/ListBeginRebuild'; { wParam : 0 lParam : 0 Affect : End a rebuild of the contact list, see notes Returns: 0 on success, [non zero] on error Notes : if you dissplayed an hourglass in beginbuild, set it back here, you do not need to explicitly sort the list } MS_CLUI_LISTENDREBUILD:PAnsiChar = 'CLUI/ListEndRebuild'; { wParam : 0 lParam : 0 Affect : Sort the contact list now, see notes Returns: 0 success, [non zero] on failure Notes : Sorts are buffered so you won't get this message lots of times if the lists needs to be resorted many times rapidly } MS_CLUI_SORTLIST:PAnsiChar = 'CLUI/SortList'; { wParam : CLUICAPS_* lParam : 0 Affect : Gets a load of capabilites for the loaded CLUI, see notes Returns: the requested value, 0 of wParam is unknown -- if this service is not implemented it is assumed all return values will be 0. Version: v0.1.2.1+ } { CLUIF2_PLUGININFO = 1; // returns pointer to plugininfo CLUIF2_CLISTTYPE = 2; // the genaration of list in chronologic // modern layered return 0x07 (assuming classic, // mw, meta, nicer1, modern1, nicer++, modernLayered) // +0x0100 for unicode CLUIF2_EXTRACOLUMNCOUNT = 3; // return max number of extra icon available to // be set in main window CLUIF2_USEREXTRASTART = 4; // return index of first 'advanced' image except // Adv1 and Adv2 } // can only provide this flag to return the following set of caps, the strings // show the database setting/type to store the list option, changing the value // does not reflect what the change is, i.e. ontop can only be affected with // a call to SetWindowPos() CLUICAPS_FLAGS1 = 0; // empty groups aren't shown, 'CList/HideEmptyGroups' (byte) [changes make the list reload] CLUIF_HIDEEMPTYGROUPS = 1; // groups can be disabled, lists can be merged into one seamlessly, (byte) 'CList/UseGroups' CLUIF_DISABLEGROUPS = 2; // list can be displayed 'on top' of all other windows, 4 (byte) 'CList/OnTop' CLUIF_HASONTOPOPTION = 4; // can disappear after a while of inactive use, // (byte) 'CList/AutoHide' (word) 'CList/HideTime' CLUIF_HASAUTOHIDEOPTION = 8; CLUICAPS_FLAGS2 = 1; // Returns info about extra icons // HIWORD is the first extra icon number, LOWORD is the extra icons count //LPARAMS for CLUICAPS_FLAGS1 CLUIF2_PLUGININFO = 1; //returns pointer to plugininfo CLUIF2_CLISTTYPE = 2; // the genaration of list in chronologic // modern layered return 0x07 // (assuming classic, mw, meta, nicer1, modern1, nicer++, modernLayered) // +0x0100 for unicode CLUIF2_EXTRACOLUMNCOUNT = 3; // return max number of extra icon available to be set in main window MS_CLUI_GETCAPS:PAnsiChar = 'CLUI/GetCaps'; { wParam : HCONTACT lParam : MAKELPARAM(screenX, screenY) Affect : A contact is being dragged outside the main window Return : return [non zero] to show the drag cursor as "accepting" the drag or zero to show the circle/slash 'not allowed' Version: v0.1.2.0+ } ME_CLUI_CONTACTDRAGGING:PAnsiChar = 'CLUI/ContactDragging'; { wParam : HCONTACT lParam : MAKELPARAM(screenX, screenY) Affect : a contact has just been dropped outside the main window, see notes Notes : return non zero to stop other hooks processing this event. Version: v0.1.2.0+ } ME_CLUI_CONTACTDROPPED:PAnsiChar = 'CLUI/ContactDropped'; { wParam : HCONTACT lParam : 0 Affect : A contact that *was* being dragged outside the main window has gone back to the main window Return : always return 0 Version: v0.1.2.1+ } ME_CLUI_CONTACTDRAGSTOP:PAnsiChar = 'CLUI/ContactDragStop'; // return TRUE if Clist Module Support Metacontacts ME_CLUI_METASUPPORT:PAnsiChar = 'CLUI/MetaContactSupport'; // return pointer to PLUGININFO structure // MS_CLIST_GETCLISTCAPS = 'CList/GetCaps'; {$ENDIF}