{
Miranda ICQ: the free icq client for MS Windows 
Copyright (C) 2000-2  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}
{$DEFINE M_CLUIFRAMES}

const
//  DEFAULT_TITLEBAR_HEIGHT = 18;

//this control will be the main contact list (v. 0.3.4.3+ 2004/11/02)
  CLS_SKINNEDFRAME = $0800;

//adds a frame window
//wParam=(CLISTFrame*)
//lParam=0
//returns an integer, the frame id.
type
  PCLISTFrame = ^TCLISTFrame;
  TCLISTFrame = record
    cbSize:dword;
    hWnd  :HWND;
    hIcon :HICON;
    align :int;   // al flags below
    height:int;   // or minSize - the actual meaning depends from type of frame
    Flags :int;   // F_flags below
    name  :TChar; // frame window name,will be shown in menu (DO NOT TRANSLATE)
    TBname:TChar; // titlebar caption
  // TBBackColour:COLORREF; //titlebar background colour
  end;
  PtagCLISTFrame = PCLISTFrame;
  tagCLISTFrame  = TCLISTFrame;

const
  F_VISIBLE            = 1;     // Frame visible
  F_SHOWTB             = 2;     // Show TitleBar
  F_UNCOLLAPSED        = 4;     // UnCollapse frame
  F_LOCKED             = 8;     // Lock Frame
  F_NOBORDER           = 16;    // Dont apply WS_BORDER style for window
  F_SHOWTBTIP          = 32;    // Show titlebar tooltip

  F_CANBEVERTICAL		   = 64;    // frames can be vertical
  F_CANNOTBEHORIZONTAL = 128;   // frames can NOT be horizontal	F_CANBEVERTICAL have to be set 
  F_NO_SUBCONTAINER    = 1024;  // Support skining no subcontainer needed

  F_SKINNED            = 2048;  // skinned frame (for owned subframe only)
  F_UNICODE            = 32768; // Use unicode text

// frame alignment
  alTop    = $00000001;
  alBottom = $00000002;
  alClient = $00000004; // only one alClient frame 

// since 0.7.0.20 
  alLeft   = $00000011; // frame is vertical
  alRight  = $00000012;

  alVertFrameMask = $00000010;

  FU_TBREDRAW = 1; // redraw titlebar
  FU_FMREDRAW = 2; // redraw Frame
  FU_FMPOS    = 4; // update Frame position

  FO_FLAGS       = $0001; // return set of F_VISIBLE,F_SHOWTB,F_UNCOLLAPSED,
                          // F_LOCKED,F_NOBORDER,F_SHOWTBTIP
  FO_NAME        = $0002; // Change m_cacheTName
  FO_TBNAME      = $0003; // Change TB caption
  FO_TBSTYLE     = $0004; // Change TB style
  FO_TBEXSTYLE   = $0005; // Change TB exstyle
  FO_ICON        = $0006; // Change icon
  FO_HEIGHT      = $0007; // Change height
  FO_ALIGN       = $0008; // Change align
  FO_TBTIPNAME   = $0009; // Change TB tooltip
  FO_FLOATING    = $000A; // Change floating mode

  FO_UNICODETEXT = $8000; // flag for	FO_NAME,FO_TBNAME, FO_TBTIPNAME set/get lPAram as unicode wchar_t

// want show tooltip for statusbar
// wparam=(AnsiChar *)protocolname
// lparam=0
  ME_CLIST_FRAMES_SB_SHOW_TOOLTIP:PAnsiChar = 'CListFrames/StatusBarShowToolTip';

// want hide tooltip for statusbar
// wparam=lparam=0
  ME_CLIST_FRAMES_SB_HIDE_TOOLTIP:PAnsiChar = 'CListFrames/StatusBarHideToolTip';

{
  adds a frame window
  wParam=(CLISTFrame*)
  lParam=0
  returns an integer, the frame id.
}
  MS_CLIST_FRAMES_ADDFRAME:PAnsiChar = 'CListFrames/AddFrame';

// remove frame
// wParam=Frame Id
// lParam=0
// window with hWnd field in CLISTFrame will be destroyed!!
  MS_CLIST_FRAMES_REMOVEFRAME:PAnsiChar = 'CListFrames/RemoveFrame';

//shows all frames
//wParam=lParam=0
//returns 0 on success, -1 on failure
  MS_CLIST_FRAMES_SHOWALLFRAMES:PAnsiChar = 'CListFrames/ShowALLFrames';

//shows the titlebars of all frames
//wParam=lParam=0
//returns 0 on success, -1 on failure
  MS_CLIST_FRAMES_SHOWALLFRAMESTB:PAnsiChar = 'CListFrames/ShowALLFramesTB';

//hides the titlebars of all frames
//wParam=lParam=0
//returns 0 on success, -1 on failure
  MS_CLIST_FRAMES_HIDEALLFRAMESTB:PAnsiChar = '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 
}
  MS_CLIST_FRAMES_SHFRAME:PAnsiChar = '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 
}
  MS_CLIST_FRAMES_SHFRAMETITLEBAR:PAnsiChar = '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 
}
  MS_CLIST_FRAMES_ULFRAME:PAnsiChar = '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 
}
  MS_CLIST_FRAMES_UCOLLFRAME:PAnsiChar = '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 
}
  MS_CLIST_FRAMES_SETUNBORDER:PAnsiChar = 'CListFrame/SetUnBorder';

//trigger skinned flags
//wparam=frameid
//lparam=0
  MS_CLIST_FRAMES_SETSKINNED:PAnsiChar = 'CListFrame/SetSkinnedFrame';

{
  redraws the frame
  wParam=FrameId, -1 for all frames
  lparam=FU_flags
  returns a pointer to option, -1 on failure
}
  MS_CLIST_FRAMES_UPDATEFRAME:PAnsiChar = 'CListFrame/UpdateFrame';

{
  gets the frame options
  (HIWORD)wParam=FrameId
  (LOWORD)wParam=FO_flag
  lParam=0
  returns a pointer to option, -1 on failure
}
  MS_CLIST_FRAMES_GETFRAMEOPTIONS:PAnsiChar = 'CListFrame/GetFrameOptions';

//sets the frame options
//(HIWORD)wParam=FrameId
//(LOWORD)wParam=FO_flag
//lParam=value
//returns 0 on success, -1 on failure
  MS_CLIST_FRAMES_SETFRAMEOPTIONS:PAnsiChar = 'CListFrame/SetFrameOptions';

//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
}
  MS_CLIST_ADDCONTEXTFRAMEMENUITEM:PAnsiChar = 'CList/AddContextFrameMenuItem';

{
  builds the context menu for a frame
  wparam=frameid
  lParam=0
  returns a HMENU on success, or NULL on failure
}
  MS_CLIST_MENUBUILDFRAMECONTEXT:PAnsiChar = '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
          MO_REMOVEMENUITEM

}
  ME_CLIST_PREBUILDFRAMEMENU:PAnsiChar = 'CList/PreBuildFrameMenu';

//needed by cluiframes module to add frames menu to main menu.
//it just calls NotifyEventHooks(hPreBuildFrameMenuEvent,wParam,lParam);
  MS_CLIST_FRAMEMENUNOTIFY:PAnsiChar = 'CList/ContextFrameMenuNotify';

//#define FONTID_STATUS 8
//#define FONTID_FRAMETITLE 9

//#undef FONTID_MAX
//#define FONTID_MAX 9

//  ME_CLIST_PREBUILDSTATUSMENU = 'CList/PreBuildStatusMenu';
//  MS_CLIST_ADDSTATUSMENUITEM = 'CList/AddStatusMenuItem';
{$ENDIF}