2020-09-30 16:53:55 +02:00

1315 lines
38 KiB
C++

// cmndlgs.cpp - Common Dialogs
#include "stdafx.h"
#include <adext.h>
#include <windowsx.h>
#include <algorithm>
#include "cmndlgs.h"
#include "query.h"
#include "rowitem.h"
#include "scopenode.h"
#include "namemap.h"
#include "menuCmd.h"
#include "util.h"
//////////////////////////////////////////////////////////////////////////////////
// CAddColumnDlg
LRESULT CAddColumnDlg::OnInitDialog( UINT mMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled )
{
ASSERT(!m_strClassName.empty());
DisplayNameMap* pNameMap = DisplayNames::GetMap(m_strClassName.c_str());
if (pNameMap == NULL)
return TRUE;
SetDlgItemText( IDC_OBJCLASS, pNameMap->GetClassDisplayName() );
pNameMap->GetFriendlyNames(&m_vstrAllColumns);
HWND hwndList = GetDlgItem(IDC_COLUMNLIST);
if( hwndList && ::IsWindow(hwndList) )
{
ConfigSingleColumnListView(hwndList);
if (!m_vstrAllColumns.empty())
{
LV_ITEM lvi;
lvi.mask = LVIF_TEXT | LVIF_PARAM;
lvi.iItem = 0;
lvi.iSubItem = 0;
string_vector::iterator itStr;
for (itStr = m_vstrAllColumns.begin(); itStr != m_vstrAllColumns.end(); itStr++)
{
lvi.pszText = const_cast<LPWSTR>(pNameMap->GetAttributeDisplayName(itStr->c_str()));
lvi.lParam = (LPARAM)itStr->c_str();
int iPos = ListView_InsertItem(hwndList, &lvi);
ASSERT(iPos >= 0);
}
}
}
EnableDlgItem( m_hWnd, IDOK, FALSE );
return TRUE;
}
LRESULT CAddColumnDlg::OnClose( WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled )
{
if (wID == IDOK)
{
HWND hwndList = GetDlgItem(IDC_COLUMNLIST);
ASSERT(hwndList != NULL);
m_vstrColumns.clear();
// copy LDAP names of selected items to vector
int iIndex = -1;
while ((iIndex = ListView_GetNextItem(hwndList, iIndex, LVNI_SELECTED)) != -1)
{
LVITEM lvi;
lvi.mask = LVIF_PARAM;
lvi.iItem = iIndex;
lvi.iSubItem = 0;
BOOL bStat = ListView_GetItem(hwndList, &lvi);
ASSERT(bStat);
m_vstrColumns.push_back(reinterpret_cast<LPWSTR>(lvi.lParam));
}
}
EndDialog(wID);
return 0;
}
LRESULT CAddColumnDlg::OnColumnChanged(int idCtrl, LPNMHDR pNMHDR, BOOL& bHandled)
{
LPNMLISTVIEW pnmv = reinterpret_cast<LPNMLISTVIEW>(pNMHDR);
if( !pnmv ) return 0;
// if selection change, update OK button
if ((pnmv->uChanged & LVIF_STATE))
{
EnableDlgItem( m_hWnd, IDOK, (ListView_GetSelectedCount(GetDlgItem(idCtrl)) > 0) );
}
return 0;
}
LRESULT CAddColumnDlg::OnColumnActivate(int idCtrl, LPNMHDR pNMHDR, BOOL& bHandled)
{
SendDlgItemMessage( IDOK, BM_CLICK, (WPARAM)0, (LPARAM)0 );
return 0;
}
//////////////////////////////////////////////////////////////////////////////////
// CAddMenuDlg
CAddMenuDlg::~CAddMenuDlg()
{
m_MenuTypeCB.Detach();
DeleteObject(m_hbmArrow);
}
LRESULT CAddMenuDlg::OnInitDialog( UINT mMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled )
{
DisplayNameMap* pNameMap = DisplayNames::GetMap(m_ClassInfo.Name());
if (pNameMap == NULL)
return TRUE;
SetDlgItemText( IDC_OBJCLASS, pNameMap->GetClassDisplayName() );
HWND hwndMenuType = GetDlgItem(IDC_COMMANDTYPE);
if( hwndMenuType && ::IsWindow(hwndMenuType) )
{
m_MenuTypeCB.Attach( hwndMenuType );
}
// Set menu arrow bitmap in param menu button
m_hbmArrow = LoadBitmap(NULL, MAKEINTRESOURCE(OBM_MNARROW));
if( m_hbmArrow )
{
SendDlgItemMessage( IDC_PARAMS_MENU, BM_SETIMAGE, IMAGE_BITMAP, (LPARAM)m_hbmArrow );
}
COMBOBOXEXITEM cbi;
cbi.mask = CBEIF_TEXT|CBEIF_LPARAM;
cbi.iItem = -1;
tstring strMenuType = StrLoadString(IDS_ACTDIRCMD);
cbi.pszText = const_cast<LPWSTR>(strMenuType.c_str());
cbi.lParam = MENUTYPE_ACTDIR;
m_MenuTypeCB.InsertItem(&cbi);
strMenuType = StrLoadString(IDS_SHELLCMD);
cbi.pszText = const_cast<LPWSTR>(strMenuType.c_str());
cbi.lParam = MENUTYPE_SHELL;
m_MenuTypeCB.InsertItem(&cbi);
Edit_LimitText(GetDlgItem(IDC_NAME), 255);
Edit_LimitText(GetDlgItem(IDC_COMMAND), 255);
Edit_LimitText(GetDlgItem(IDC_STARTIN), 500);
LoadClassMenuCmds();
// If editing an existing menu
if (m_pMenuCmd != NULL)
{
// Set name modified so that it won't be changed to default
m_bUserModifiedName = TRUE;
// Display info for selected menu
LoadMenuInfo(m_pMenuCmd);
}
else
{
m_MenuTypeCB.SetCurSel(0);
SetMenuType(MENUTYPE_ACTDIR);
}
m_bCommandChg = FALSE;
m_bStartDirChg = FALSE;
EnableOKButton();
return TRUE;
}
void CAddMenuDlg::LoadMenuInfo(CMenuCmd* pMenuCmd)
{
if( !pMenuCmd ) return;
SetDlgItemText( IDC_NAME, pMenuCmd->Name() );
Button_SetCheck(GetDlgItem(IDC_REFRESH), pMenuCmd->IsAutoRefresh() ? BST_CHECKED : BST_UNCHECKED);
switch (pMenuCmd->MenuType())
{
case MENUTYPE_SHELL:
{
CShellMenuCmd* pShellCmd = static_cast<CShellMenuCmd*>(pMenuCmd);
SetDlgItemText( IDC_COMMAND, pShellCmd->m_strProgPath.c_str() );
SetDlgItemText( IDC_STARTIN, pShellCmd->m_strStartDir.c_str() );
// Convert parameters from LDAP names to display names
tstring strParams = pShellCmd->m_strCmdLine;
DisplayNameMap* pNameMap = DisplayNames::GetMap(m_ClassInfo.Name());
if (pNameMap != NULL)
{
// Create function object to do parameter translation
CLookupDisplayName lookup(m_ClassInfo.Columns(), pNameMap);
ReplaceParameters(strParams, lookup, TRUE);
}
SetDlgItemText( IDC_PARAMS, strParams.c_str() );
m_MenuTypeCB.SetCurSel(1);
SetMenuType(MENUTYPE_SHELL);
}
break;
case MENUTYPE_ACTDIR:
{
CActDirMenuCmd* pADCmd = static_cast<CActDirMenuCmd*>(pMenuCmd);
LVFINDINFO lvfi;
lvfi.flags = LVFI_STRING;
lvfi.psz = pADCmd->m_strADName.c_str();
HWND hwndLV = GetDlgItem(IDC_MENULIST);
int iItem = ListView_FindItem(hwndLV, -1, &lvfi);
if( iItem == -1 )
{
// Couldn't find the language dependant string, try the language independant string
int nItems = ListView_GetItemCount(hwndLV);
for( int i = 0; i < nItems; i++ )
{
LVITEM lvi;
ZeroMemory( &lvi, sizeof(lvi) );
lvi.mask = LVIF_PARAM;
lvi.iItem = i;
ListView_GetItem( hwndLV, &lvi );
if( lvi.lParam )
{
LPCWSTR pszMenuNoLoc = pADCmd->ADNoLocName();
// Compare the stored string with the menu string
if( pszMenuNoLoc && (wcscmp( (LPCWSTR)(lvi.lParam), pszMenuNoLoc ) == 0) )
{
iItem = i;
break;
}
}
}
}
// If we found the string, default the value
if (iItem != -1)
ListView_SetItemState(hwndLV, iItem, LVIS_SELECTED, LVIS_SELECTED);
m_MenuTypeCB.SetCurSel(0);
SetMenuType(MENUTYPE_ACTDIR);
}
break;
default:
ASSERT(FALSE);
}
}
void CAddMenuDlg::LoadClassMenuCmds()
{
// Use a directory extension proxy to query for menu items
// because this dialog may run on a secondary thread and some
// directory extensions (dsadmin.dll!!) can only run on the main thread.
CActDirExtProxy adext;
// Initialize it with selected class name
HRESULT hr = adext.Initialize(m_ClassInfo.Name());
if (FAILED(hr))
return;
// Get menu commands for the selected class
menu_vector vMenuNames;
hr = adext.GetMenuItems(vMenuNames);
if (FAILED(hr))
return;
HWND hwndLV = GetDlgItem(IDC_MENULIST);
ASSERT(::IsWindow(hwndLV));
ConfigSingleColumnListView(hwndLV);
LV_ITEM lvi;
lvi.mask = LVIF_TEXT | LVIF_PARAM;
lvi.iItem = 0;
lvi.iSubItem = 0;
menu_vector::iterator itstr;
for (itstr = vMenuNames.begin(); itstr < vMenuNames.end(); ++itstr)
{
TCHAR* szNoLoc = new TCHAR[itstr->strNoLoc.length() + 1];
if( szNoLoc )
{
_tcscpy(szNoLoc, itstr->strNoLoc.c_str());
}
lvi.pszText = const_cast<LPWSTR>(itstr->strPlain.c_str());
lvi.lParam = reinterpret_cast<LPARAM>(szNoLoc);
int iPos = ListView_InsertItem(hwndLV, &lvi);
ASSERT(iPos >= 0);
if( iPos == -1 )
{
// Error, need to clean up here
delete [] szNoLoc;
continue;
}
// After adding the first item, default the selection to the first item
if( iPos == 0 )
{
ListView_SetItemState(hwndLV, 0, LVIS_FOCUSED|LVIS_SELECTED, LVIS_FOCUSED|LVIS_SELECTED);
}
lvi.iItem++;
}
}
LRESULT CAddMenuDlg::OnTypeSelect( WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled )
{
int iItem = m_MenuTypeCB.GetCurSel();
ASSERT(iItem >= 0);
if( iItem >= 0 )
{
MENUTYPE type = static_cast<MENUTYPE>(m_MenuTypeCB.GetItemData(iItem));
SetMenuType(type);
}
return 0;
}
LRESULT CAddMenuDlg::OnBrowseForCommand( WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled )
{
tstring strCommand;
GetItemText( GetDlgItem(IDC_COMMAND), strCommand );
tstring strFilter = StrLoadString(IDS_EXEFILTER);
/*
* The file dialog expects embedded \0's in the string, but those
* don't load well. The string in the resource file has \\ where
* the \0 should be, so let's make the substitution now.
*/
LPTSTR pchTemp = (LPTSTR)strFilter.data();
for( LPTSTR pch = pchTemp; *pch != _T('\0'); pch = pchTemp )
{
pchTemp = CharNext(pch);
if (*pch == _T('\\'))
*pch = _T('\0');
}
// don't call ReleaseBuffer, since the string now contains \0 chars
CFileDialog dlg (true, NULL, strCommand.c_str(), OFN_FILEMUSTEXIST | OFN_HIDEREADONLY, strFilter.c_str(), m_hWnd);
if (dlg.DoModal() == IDOK)
{
SetDlgItemText (IDC_COMMAND, dlg.m_szFileName);
}
return (0);
}
// Define private CFolderDialog to handle the OnInitialized callback
class CFolderDialogPriv : public CFolderDialogImpl<CFolderDialogPriv>
{
public:
CFolderDialogPriv(HWND hWndParent, LPCWSTR pszTitle, UINT uFlags, LPCWSTR pszCurFolder )
: CFolderDialogImpl<CFolderDialogPriv>(hWndParent, pszTitle, uFlags), m_pszCurFolder(pszCurFolder) {}
void OnInitialized() { if (m_pszCurFolder) SetSelection(m_pszCurFolder); }
LPCWSTR m_pszCurFolder;
};
LRESULT CAddMenuDlg::OnBrowseForStartIn( WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled )
{
tstring strCaption = StrLoadString(IDS_SELECT_STARTDIR);
tstring strDir;
GetItemText( GetDlgItem(IDC_STARTIN), strDir );
CFolderDialogPriv dlg( m_hWnd, strCaption.c_str(), BIF_RETURNONLYFSDIRS|BIF_NEWDIALOGSTYLE, strDir.c_str() );
if (dlg.DoModal() == IDOK)
SetDlgItemText (IDC_STARTIN, dlg.GetFolderPath());
return (0);
}
LRESULT CAddMenuDlg::OnNameChange( WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled )
{
m_bUserModifiedName = TRUE;
EnableOKButton();
return 0;
}
LRESULT CAddMenuDlg::OnCommandChange( WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled )
{
EnableOKButton();
m_bCommandChg = TRUE;
return 0;
}
LRESULT CAddMenuDlg::OnStartDirChange( WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled )
{
m_bStartDirChg = TRUE;
return 0;
}
LRESULT CAddMenuDlg::OnMenuChanged(int idCtrl, LPNMHDR pNMHDR, BOOL& bHandled)
{
LPNMLISTVIEW pnmv = reinterpret_cast<LPNMLISTVIEW>(pNMHDR);
if( !pnmv ) return 0;
// if new item selected user hasn't entered a name, default name to the menu
if ((pnmv->uChanged & LVIF_STATE) && (pnmv->uNewState & LVIS_SELECTED))
{
// If user hasn't modified the name or the name is empty, default to the menu name
if (!m_bUserModifiedName || ::Edit_GetTextLength(GetDlgItem(IDC_NAME)) == 0)
{
WCHAR szName[256];
ListView_GetItemText(GetDlgItem(IDC_MENULIST), pnmv->iItem, 0, szName, lengthof(szName));
::Edit_SetText(GetDlgItem(IDC_NAME), szName);
// reset user modified flag becuase it will be set by the Edit_SetText call
m_bUserModifiedName = FALSE;
}
}
EnableOKButton();
return 0;
}
void CAddMenuDlg::EnableOKButton()
{
BOOL bEnable = TRUE;
if (::Edit_GetTextLength(GetDlgItem(IDC_NAME)) == 0)
{
bEnable = FALSE;
}
else
{
if (m_menutype == MENUTYPE_SHELL)
{
if (::Edit_GetTextLength(GetDlgItem(IDC_COMMAND)) == 0)
bEnable = FALSE;
}
else
{
if (ListView_GetSelectedCount(GetDlgItem(IDC_MENULIST)) == 0)
bEnable = FALSE;
}
}
EnableDlgItem( m_hWnd, IDOK, bEnable );
}
void CAddMenuDlg::SetMenuType(MENUTYPE type)
{
static int aiActDirItems[] = {IDC_OBJCLASS_LBL, IDC_OBJCLASS, IDC_MENULIST_LBL, IDC_MENULIST, 0};
static int aiShellItems[] = {IDC_COMMAND_LBL, IDC_COMMAND, IDC_COMMAND_BROWSE, IDC_PARAMS_LBL,
IDC_PARAMS, IDC_STARTIN_LBL, IDC_STARTIN, IDC_STARTIN_BROWSE,
IDC_PARAMS_MENU, 0};
int* piItem = (type == MENUTYPE_SHELL) ? aiActDirItems : aiShellItems;
while (*piItem)
{
EnableDlgItem( m_hWnd, *piItem, FALSE );
::ShowWindow(GetDlgItem(*piItem), SW_HIDE);
piItem++;
}
piItem = (type == MENUTYPE_SHELL) ? aiShellItems : aiActDirItems;
while (*piItem)
{
::ShowWindow(GetDlgItem(*piItem), SW_SHOW);
EnableDlgItem( m_hWnd, *piItem, TRUE );
piItem++;
}
m_menutype = type;
EnableOKButton();
}
LRESULT CAddMenuDlg::OnParameterMenu(WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled)
{
// Construct parameter menu
CMenu menu;
menu.CreatePopupMenu();
// Add standard parameters first
UINT uID = 1;
for( int i = 0; i < lengthof(MenuParamTable); i++ )
{
if (MenuParamTable[i].ID == 0)
{
menu.AppendMenu(MF_SEPARATOR);
}
else
{
CString str;
str.LoadString(MenuParamTable[i].rsrcID);
menu.AppendMenu(MF_STRING, uID++, str);
}
}
// Then add class attributes
DisplayNameMap* pNameMap = DisplayNames::GetMap(m_ClassInfo.Name());
if (pNameMap != NULL)
{
string_vector& vColumns = m_ClassInfo.Columns();
string_vector::iterator itCol;
for (itCol = vColumns.begin(); itCol != vColumns.end(); itCol++)
{
menu.AppendMenu(MF_STRING, uID++, pNameMap->GetAttributeDisplayName(itCol->c_str()));
}
}
// Pop-up menu at menu button
RECT rc;
::GetWindowRect(GetDlgItem(IDC_PARAMS_MENU), &rc);
long cx = (rc.right + rc.left) / 2;
long cy = (rc.top + rc.bottom) / 2;
UINT uCmd = menu.TrackPopupMenu(TPM_LEFTALIGN|TPM_TOPALIGN|TPM_RETURNCMD|TPM_LEFTBUTTON,
cx, cy, m_hWnd);
if (uCmd != 0)
{
WCHAR szBuf[128] = {0};
// Convert menu name to parameter format: $<name>
wcscpy(szBuf, L"$<");
// BUGBUG - Don't depend on count returned by GetMenuString. For some locales
// it returns a byte count rather than a character count.
int iLen = menu.GetMenuString(uCmd, szBuf+2, lengthof(szBuf)-5, MF_BYCOMMAND);
ASSERT(iLen != 0);
// Add closing '>' and one trailing space so user can add multiple parameters
// without manually entering separating spaces
wcscat(szBuf, L"> ");
Edit_ReplaceSel(GetDlgItem(IDC_PARAMS), szBuf);
::SetFocus(GetDlgItem(IDC_PARAMS));
}
return 0;
}
LRESULT CAddMenuDlg::OnClose( WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled )
{
if (wID == IDOK)
{
CMenuCmd* pMenu = NULL;
// Get menu name
tstring strName;
GetItemText( GetDlgItem(IDC_NAME), strName );
// Name without the hotkey
tstring strPlainName = strName;
// Validate hotkey selection
int posKey = strName.find(L"&", 0);
if (posKey != tstring::npos)
{
WCHAR chKey = posKey < strName.length() - 1 ? strName[posKey+1] : 0;
if (!( (chKey >= L'A' && chKey <= L'Z') ||
(chKey >= L'a' && chKey <= L'z') ||
(chKey >= L'0' && chKey <= L'9') ))
{
DisplayMessageBox(m_hWnd, IDS_ERRORTITLE_MENUNAME, IDS_ERROR_BADACCESSKEY);
return 0;
}
if (strName.find(L"&", posKey+1) != tstring::npos)
{
DisplayMessageBox(m_hWnd, IDS_ERRORTITLE_MENUNAME, IDS_ERROR_MULTIACCESSKEY);
return 0;
}
// remove '&'
strPlainName.erase(posKey, 1);
}
// Check for duplicated name
menucmd_vector::iterator itMenu;
for (itMenu = m_ClassInfo.Menus().begin(); itMenu != m_ClassInfo.Menus().end(); ++itMenu)
{
// if editing a an existing menu, don't compare to itself
if (*itMenu == m_pMenuCmd)
continue;
// Compare names, skipping '&'s
LPCWSTR pszName = (*itMenu)->Name();
LPCWSTR pszNewName = strPlainName.c_str();
if( pszName && pszNewName )
{
while (*pszName && *pszNewName)
{
if (*pszName == L'&')
++pszName;
if (*pszName != *pszNewName)
break;
++pszName;
++pszNewName;
}
// if duplicate name
if (*pszName == *pszNewName)
{
DisplayMessageBox(m_hWnd, IDS_ERRORTITLE_MENUNAME, IDS_ERROR_DUPMENUNAME, MB_OK|MB_ICONEXCLAMATION, strPlainName.c_str());
return 0;
}
}
}
switch (m_menutype)
{
case MENUTYPE_SHELL:
{
CShellMenuCmd* pShellMenu = new CShellMenuCmd();
if (pShellMenu != NULL)
{
GetItemText( GetDlgItem(IDC_COMMAND), pShellMenu->m_strProgPath );
if (m_bCommandChg && ValidateFile(pShellMenu->m_strProgPath) != S_OK)
{
int iRet = DisplayMessageBox(m_hWnd, IDS_ERRORTITLE_MENUCMD, IDS_ERROR_MENUCMD,
MB_ICONINFORMATION | MB_YESNO, pShellMenu->m_strProgPath.c_str());
if (iRet != IDYES)
{
delete pShellMenu;
return 0;
}
}
GetItemText( GetDlgItem(IDC_STARTIN), pShellMenu->m_strStartDir );
if (m_bStartDirChg && !pShellMenu->m_strStartDir.empty() &&
ValidateDirectory(pShellMenu->m_strStartDir) != S_OK)
{
int iRet = DisplayMessageBox(m_hWnd, IDS_ERRORTITLE_STARTDIR, IDS_ERROR_STARTDIR,
MB_ICONINFORMATION | MB_YESNO, pShellMenu->m_strStartDir.c_str());
if (iRet != IDYES)
{
delete pShellMenu;
return 0;
}
}
tstring strParams;
GetItemText( GetDlgItem(IDC_PARAMS), strParams );
// Convert parameters from display names to LDAP names
DisplayNameMap* pNameMap = DisplayNames::GetMap(m_ClassInfo.Name());
if (pNameMap != NULL)
{
// Create function object to do parameter translation
CLookupLDAPName lookup(m_ClassInfo.Columns(), pNameMap);
ReplaceParameters(strParams, lookup, TRUE);
}
pShellMenu->m_strCmdLine.erase();
pShellMenu->m_strCmdLine = strParams;
pMenu = pShellMenu;
}
}
break;
case MENUTYPE_ACTDIR:
{
CActDirMenuCmd* pADMenu = new CActDirMenuCmd();
if (pADMenu != NULL)
{
HWND hwndLV = GetDlgItem(IDC_MENULIST);
int iItem = ListView_GetNextItem(hwndLV, -1, LVNI_SELECTED);
ASSERT(iItem != -1);
LV_ITEM lvi;
lvi.mask = LVIF_TEXT | LVIF_PARAM;
lvi.iItem = iItem;
lvi.iSubItem = 0;
WCHAR szBuf[MAX_PATH];
szBuf[0] = 0;
lvi.pszText = szBuf;
lvi.cchTextMax = MAX_PATH;
ListView_GetItem(hwndLV, &lvi);
pADMenu->m_strADName = szBuf;
pADMenu->m_strADNoLocName = (TCHAR*)lvi.lParam;
pMenu = pADMenu;
}
}
break;
default:
ASSERT(FALSE);
}
if (pMenu != NULL)
{
pMenu->m_strName = strName;
m_pMenuCmd = pMenu;
pMenu->SetAutoRefresh(Button_GetCheck(GetDlgItem(IDC_REFRESH)) == BST_CHECKED);
}
}
//Iterate through list and delete lParams
HWND hwndLV = GetDlgItem(IDC_MENULIST);
int nItems = ListView_GetItemCount(hwndLV);
for( int i = 0; i < nItems; i++ )
{
LVITEM lvi;
ZeroMemory( &lvi, sizeof(lvi) );
lvi.mask = LVIF_PARAM;
lvi.iItem = i;
ListView_GetItem( hwndLV, &lvi );
if( lvi.lParam )
{
delete [] (TCHAR*)lvi.lParam;
lvi.lParam = NULL;
ListView_SetItem( hwndLV, &lvi );
}
}
EndDialog(wID);
return 0;
}
//////////////////////////////////////////////////////////////////////////////////
// CAddQNMenuDlg
LRESULT CAddQNMenuDlg::OnInitDialog( UINT mMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled )
{
// If editing an existing menu
if (m_pMenuCmd != NULL)
{
// Set name modified so that it won't be changed to default
m_bUserModifiedName = TRUE;
// Display info for selected menu
LoadMenuInfo(m_pMenuCmd);
}
m_bCommandChg = FALSE;
m_bStartDirChg = FALSE;
EnableOKButton();
return TRUE;
}
void CAddQNMenuDlg::LoadMenuInfo(CMenuCmd* pMenuCmd)
{
SetDlgItemText( IDC_NAME, pMenuCmd->Name() );
Button_SetCheck(GetDlgItem(IDC_REFRESH), pMenuCmd->IsAutoRefresh() ? BST_CHECKED : BST_UNCHECKED);
CShellMenuCmd* pShellCmd = static_cast<CShellMenuCmd*>(pMenuCmd);
SetDlgItemText( IDC_COMMAND, pShellCmd->m_strProgPath.c_str() );
SetDlgItemText( IDC_STARTIN, pShellCmd->m_strStartDir.c_str() );
SetDlgItemText( IDC_PARAMS, pShellCmd->m_strCmdLine.c_str() );
SetMenuType(MENUTYPE_SHELL);
}
LRESULT CAddQNMenuDlg::OnBrowseForCommand( WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled )
{
tstring strCommand;
GetItemText( GetDlgItem(IDC_COMMAND), strCommand );
tstring strFilter = StrLoadString(IDS_EXEFILTER);
/*
* The file dialog expects embedded \0's in the string, but those
* don't load well. The string in the resource file has \\ where
* the \0 should be, so let's make the substitution now.
*/
LPTSTR pchTemp = (LPTSTR)strFilter.data();
for (LPTSTR pch = pchTemp; *pch != _T('\0'); pch = pchTemp )
{
pchTemp = CharNext(pch);
if (*pch == _T('\\'))
*pch = _T('\0');
}
// don't call ReleaseBuffer, since the string now contains \0 chars
CFileDialog dlg (true, NULL, strCommand.c_str(), OFN_FILEMUSTEXIST | OFN_HIDEREADONLY, strFilter.c_str(), m_hWnd);
if (dlg.DoModal() == IDOK)
{
SetDlgItemText (IDC_COMMAND, dlg.m_szFileName);
}
return (0);
}
LRESULT CAddQNMenuDlg::OnBrowseForStartIn( WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled )
{
tstring strCaption = StrLoadString(IDS_SELECT_STARTDIR);
tstring strDir;
GetItemText( GetDlgItem(IDC_STARTIN), strDir );
CFolderDialogPriv dlg( m_hWnd, strCaption.c_str(), BIF_RETURNONLYFSDIRS|BIF_NEWDIALOGSTYLE, strDir.c_str() );
if (dlg.DoModal() == IDOK)
{
SetDlgItemText (IDC_STARTIN, dlg.GetFolderPath());
}
return (0);
}
LRESULT CAddQNMenuDlg::OnNameChange( WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled )
{
m_bUserModifiedName = TRUE;
EnableOKButton();
return 0;
}
LRESULT CAddQNMenuDlg::OnCommandChange( WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled )
{
EnableOKButton();
m_bCommandChg = TRUE;
return 0;
}
LRESULT CAddQNMenuDlg::OnStartDirChange( WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled )
{
m_bStartDirChg = TRUE;
return 0;
}
void CAddQNMenuDlg::EnableOKButton()
{
BOOL bEnable = TRUE;
if (::Edit_GetTextLength(GetDlgItem(IDC_NAME)) == 0)
{
bEnable = FALSE;
}
else
{
if (::Edit_GetTextLength(GetDlgItem(IDC_COMMAND)) == 0)
bEnable = FALSE;
}
EnableDlgItem( m_hWnd, IDOK, bEnable );
}
void CAddQNMenuDlg::SetMenuType(MENUTYPE type)
{
m_menutype = type;
EnableOKButton();
}
LRESULT CAddQNMenuDlg::OnClose( WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled )
{
if (wID == IDOK)
{
CMenuCmd* pMenu = NULL;
// Get menu name
tstring strName;
GetItemText( GetDlgItem(IDC_NAME), strName );
// Name without the hotkey
tstring strPlainName = strName;
// Validate hotkey selection
int posKey = strName.find(L"&", 0);
if (posKey != tstring::npos)
{
WCHAR chKey = posKey < strName.size() - 1 ? strName[posKey+1] : 0;
if (!( (chKey >= L'A' && chKey <= L'Z') ||
(chKey >= L'a' && chKey <= L'z') ||
(chKey >= L'0' && chKey <= L'9') ))
{
DisplayMessageBox(m_hWnd, IDS_ERRORTITLE_MENUNAME, IDS_ERROR_BADACCESSKEY);
return 0;
}
if (strName.find(L"&", posKey+1) != tstring::npos)
{
DisplayMessageBox(m_hWnd, IDS_ERRORTITLE_MENUNAME, IDS_ERROR_MULTIACCESSKEY);
return 0;
}
// remove '&'
strPlainName.erase(posKey, 1);
}
// Check for duplicated name
menucmd_vector::iterator itMenu;
for (itMenu = m_EditObject.Menus().begin(); itMenu != m_EditObject.Menus().end(); ++itMenu)
{
// if editing a an existing menu, don't compare to itself
if (*itMenu == m_pMenuCmd)
continue;
// Compare names, skipping '&'s
LPCWSTR pszName = (*itMenu)->Name();
LPCWSTR pszNewName = strPlainName.c_str();
while (*pszName && *pszNewName)
{
if (*pszName == L'&')
++pszName;
if (*pszName != *pszNewName)
break;
++pszName;
++pszNewName;
}
// if duplicate name
if (*pszName == *pszNewName)
{
DisplayMessageBox(m_hWnd, IDS_ERRORTITLE_MENUNAME, IDS_ERROR_DUPMENUNAME, MB_OK|MB_ICONEXCLAMATION, strPlainName.c_str());
return 0;
}
}
CShellMenuCmd* pShellMenu = new CShellMenuCmd();
if (pShellMenu != NULL)
{
GetItemText( GetDlgItem(IDC_COMMAND), pShellMenu->m_strProgPath );
if (m_bCommandChg && ValidateFile(pShellMenu->m_strProgPath) != S_OK)
{
int iRet = DisplayMessageBox(m_hWnd, IDS_ERRORTITLE_MENUCMD, IDS_ERROR_MENUCMD,
MB_ICONINFORMATION | MB_YESNO, pShellMenu->m_strProgPath.c_str());
if (iRet != IDYES)
{
delete pShellMenu;
return 0;
}
}
GetItemText( GetDlgItem(IDC_STARTIN), pShellMenu->m_strStartDir );
if (m_bStartDirChg && !pShellMenu->m_strStartDir.empty() &&
ValidateDirectory(pShellMenu->m_strStartDir) != S_OK)
{
int iRet = DisplayMessageBox(m_hWnd, IDS_ERRORTITLE_STARTDIR, IDS_ERROR_STARTDIR,
MB_ICONINFORMATION | MB_YESNO, pShellMenu->m_strStartDir.c_str());
if (iRet != IDYES)
{
delete pShellMenu;
return 0;
}
}
tstring strParams;
GetItemText( GetDlgItem(IDC_PARAMS), strParams );
pShellMenu->m_strCmdLine.erase();
pShellMenu->m_strCmdLine = strParams;
pMenu = pShellMenu;
}
if (pMenu != NULL)
{
pMenu->m_strName = strName;
m_pMenuCmd = pMenu;
pMenu->SetAutoRefresh(Button_GetCheck(GetDlgItem(IDC_REFRESH)) == BST_CHECKED);
}
}
EndDialog(wID);
return 0;
}
//////////////////////////////////////////////////////////////////////////////////////////////
// Add Group Node Dialog
LRESULT CAddGroupNodeDlg::OnInitDialog( UINT mMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled )
{
EnableDlgItem( m_hWnd, IDC_SCOPE_LBL, FALSE );
EnableDlgItem( m_hWnd, IDC_SCOPE, FALSE );
EnableDlgItem( m_hWnd, IDC_SCOPE_BROWSE, FALSE );
EnableDlgItem( m_hWnd, IDC_FILTER_LBL, FALSE );
EnableDlgItem( m_hWnd, IDC_FILTER, FALSE );
EnableDlgItem( m_hWnd, IDOK, FALSE );
SendDlgItemMessage( IDC_NAME, EM_LIMITTEXT, 255, 0);
return TRUE;
}
LRESULT CAddGroupNodeDlg::OnApplyScopeClicked(WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled)
{
BOOL bEnable = Button_GetCheck(GetDlgItem(IDC_APPLYSCOPE)) == BST_CHECKED;
EnableDlgItem( m_hWnd, IDC_SCOPE_LBL, bEnable );
EnableDlgItem( m_hWnd, IDC_SCOPE, bEnable );
EnableDlgItem( m_hWnd, IDC_SCOPE_BROWSE, bEnable );
EnableOKButton();
return 0;
}
LRESULT CAddGroupNodeDlg::OnApplyFilterClicked(WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled)
{
BOOL bEnable = Button_GetCheck(GetDlgItem(IDC_APPLYFILTER)) == BST_CHECKED;
EnableDlgItem( m_hWnd, IDC_FILTER_LBL, bEnable );
EnableDlgItem( m_hWnd, IDC_FILTER, bEnable );
EnableOKButton();
return 0;
}
LRESULT CAddGroupNodeDlg::OnScopeBrowse(WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled)
{
HRESULT hr = GetQueryScope(m_hWnd, m_strScope);
if (hr == S_OK)
{
tstring strDisplay;
GetScopeDisplayString(m_strScope, strDisplay);
SetDlgItemText( IDC_SCOPE, strDisplay.c_str() );
}
EnableOKButton();
return 0;
}
LRESULT CAddGroupNodeDlg::OnEditChange( WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled )
{
EnableOKButton();
return 0;
}
void CAddGroupNodeDlg::EnableOKButton()
{
BOOL bEnable;
if ( (::Edit_GetTextLength(GetDlgItem(IDC_NAME)) == 0) ||
(Button_GetCheck(GetDlgItem(IDC_APPLYFILTER)) == BST_CHECKED &&
::Edit_GetTextLength(GetDlgItem(IDC_FILTER)) == 0) ||
(Button_GetCheck(GetDlgItem(IDC_APPLYSCOPE)) == BST_CHECKED &&
m_strScope.size() == 0) )
{
bEnable = FALSE;
}
else
{
bEnable = TRUE;
}
EnableDlgItem( m_hWnd, IDOK, bEnable );
}
LRESULT CAddGroupNodeDlg::OnClose( WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled )
{
if (wID == IDOK)
{
if( !m_pnode ) return 0;
bool bScope = Button_GetCheck(GetDlgItem(IDC_APPLYSCOPE)) == BST_CHECKED;
m_pnode->SetApplyScope(bScope);
m_pnode->SetScope(m_strScope.c_str());
bool bFilter = Button_GetCheck(GetDlgItem(IDC_APPLYFILTER)) == BST_CHECKED;
m_pnode->SetApplyFilter(bFilter);
tstring strFilter;
GetItemText( GetDlgItem(IDC_FILTER), strFilter );
m_pnode->SetFilter(strFilter.c_str());
GetItemText( GetDlgItem(IDC_NAME), m_strName );
}
EndDialog(wID);
return 0;
}
//////////////////////////////////////////////////////////////////////////////////
// CMoveQueryDlg
LRESULT CMoveQueryDlg::OnInitDialog( UINT mMsg, WPARAM wParam, LPARAM lParam, BOOL& bHandled )
{
if( !m_pnodeCurFolder ) return 0;
CRootNode* pRootNode = m_pnodeCurFolder->GetRootNode();
if( !pRootNode ) return 0;
HWND hwndTree = GetDlgItem(IDC_FOLDERTREE);
// Create a node image list and assign to folder tree
CImageList images;
if (images.Create(IDB_QUERY16, 16, 100, RGB(255,0,255)))
TreeView_SetImageList(hwndTree, images.Detach(), TVSIL_NORMAL);
// Set snap-in root node as root of tree
TV_INSERTSTRUCT tvi;
tvi.hParent = TVI_ROOT;
tvi.hInsertAfter = TVI_ROOT;
tvi.item.mask = TVIF_TEXT|TVIF_IMAGE|TVIF_SELECTEDIMAGE|TVIF_PARAM;
tvi.item.pszText = const_cast<LPWSTR>(pRootNode->GetName());
tvi.item.iImage = pRootNode->GetImage();
tvi.item.iSelectedImage = tvi.item.iImage;
tvi.item.lParam = reinterpret_cast<LPARAM>(pRootNode);
HTREEITEM hti = TreeView_InsertItem(hwndTree, &tvi);
if( !hti ) return 0;
// Insert all group nodes as children of root
tvi.hParent = hti;
tvi.hInsertAfter = TVI_LAST;
CScopeNode* pnode = pRootNode->FirstChild();
while (pnode != NULL)
{
if (pnode->NodeType() == GROUP_NODETYPE)
{
tvi.item.pszText = const_cast<LPWSTR>(pnode->GetName());
tvi.item.iImage = pnode->GetImage();
tvi.item.iSelectedImage = tvi.item.iImage;
tvi.item.lParam = reinterpret_cast<LPARAM>(pnode);
HTREEITEM hti2 = TreeView_InsertItem(hwndTree, &tvi);
ASSERT(hti2 != NULL);
}
pnode = pnode->Next();
}
// Show the group nodes
TreeView_Expand(hwndTree, hti, TVE_EXPAND);
return TRUE;
}
LRESULT CMoveQueryDlg::OnClose( WORD wNotifyCode, WORD wID, HWND hWndCtl, BOOL& bHandled )
{
if( (wID == IDOK) && m_ppnodeDestFolder )
{
HWND hwndTree = GetDlgItem(IDC_FOLDERTREE);
// Get the node pointer (lparam) of the selected tree item
HTREEITEM hti = TreeView_GetSelection(hwndTree);
if( !hti ) return 0;
TVITEM tvi;
tvi.hItem = hti;
tvi.mask = TVIF_PARAM;
tvi.lParam = NULL;
BOOL bStat = TreeView_GetItem(hwndTree, &tvi);
ASSERT(bStat && tvi.lParam != NULL);
*m_ppnodeDestFolder = reinterpret_cast<CScopeNode*>(tvi.lParam);
}
EndDialog(wID);
return 0;
}
////////////////////////////////////////////////////////////////////////////////////
// Parameter translation classes
//
// LDAP to Display translator
BOOL CLookupDisplayName::operator() (tstring& strParam, tstring& strValue)
{
// Check for special parameter ID value
if (strParam.size() == 1 && strParam[0] <= MENU_PARAM_LAST)
{
// Find entry in param table and return display string
for (int i = 0; i<lengthof(MenuParamTable); i++)
{
if (MenuParamTable[i].ID == strParam[0])
{
CString str;
str.LoadString(MenuParamTable[i].rsrcID);
strValue = str;
return TRUE;
}
}
}
// check for class attribute name
string_vector::iterator itstr = std::find(m_vstrParam.begin(), m_vstrParam.end(), strParam);
if (itstr == m_vstrParam.end())
return FALSE;
strValue = m_pNameMap->GetAttributeDisplayName(itstr->c_str());
return TRUE;
}
// Display to LDAP translator
BOOL CLookupLDAPName::operator() (tstring& strParam, tstring& strValue)
{
// Check for standard parameter name
for (int i=0; i<lengthof(MenuParamTable); i++)
{
CString str;
str.LoadString(MenuParamTable[i].rsrcID);
// if match, return single wchar equal to param ID
if (_wcsicmp(strParam.c_str(), str) == 0)
{
strValue = (WCHAR)MenuParamTable[i].ID;
return TRUE;
}
}
// Check for class attribute display name
string_vector::iterator itstr;
for (itstr = m_vstrParam.begin(); itstr != m_vstrParam.end(); ++itstr)
{
if (_wcsicmp(strParam.c_str(), m_pNameMap->GetAttributeDisplayName(itstr->c_str())) == 0)
{
strValue = (*itstr);
return TRUE;
}
}
return FALSE;
}