public int DeleteFilesInFolder(MainForm mainForm, TreeViewFolderBrowser folderTreeViewFolder, string folder) { string[] subFolders = Directory.GetDirectories(folder + (folder.EndsWith(@"\") ? "" : @"\"), "*", SearchOption.AllDirectories); FileHandler.DirectoryDelete(folder, true); int recordAffected = 0; foreach (string directory in subFolders) { mainForm.UpdateStatusAction("Delete all data and files from folder: " + directory); recordAffected += this.DeleteDirectoryAndHistory(directory); } mainForm.UpdateStatusAction("Delete all data and files from folder: " + folder); recordAffected += this.DeleteDirectoryAndHistory(folder); TreeNode selectedNode = folderTreeViewFolder.SelectedNode; TreeNode parentNode = folderTreeViewFolder.SelectedNode.Parent; #region Update Node in TreeView GlobalData.DoNotTrigger_TreeViewFolder_BeforeAndAfterSelect = true; TreeViewFolderBrowserHandler.RemoveTreeNode(folderTreeViewFolder, selectedNode); if (parentNode != null) { TreeViewFolderBrowserHandler.RefreshTreeNode(folderTreeViewFolder, parentNode); } GlobalData.DoNotTrigger_TreeViewFolder_BeforeAndAfterSelect = false; #endregion return(recordAffected); }
private void CopyFiles_UpdateTreeViewFolderBrowser(TreeViewFolderBrowser folderTreeView, StringCollection files, string targetNodeDirectory, TreeNode targetNode) { using (new WaitCursor()) { foreach (string oldPath in files) //Move all files to target directory { string sourceFullFilename = oldPath; string filename = Path.GetFileName(sourceFullFilename); string targetFullFilename = Path.Combine(targetNodeDirectory, filename); try { bool directoryCreated = filesCutCopyPasteDrag.CopyFile(sourceFullFilename, targetFullFilename); if (directoryCreated) { GlobalData.DoNotTrigger_TreeViewFolder_BeforeAndAfterSelect = true; TreeViewFolderBrowserHandler.RefreshTreeNode(folderTreeView, targetNode); GlobalData.DoNotTrigger_TreeViewFolder_BeforeAndAfterSelect = false; } } catch (Exception ex) { DateTime dateTimeLastWriteTime = DateTime.Now; try { dateTimeLastWriteTime = FileHandler.GetLastWriteTime(sourceFullFilename); } catch { } FileStatus fileStatusSource = FileHandler.GetFileStatus( sourceFullFilename, checkLockedStatus: true, hasErrorOccured: true, errorMessage: ex.Message); ImageListView_UpdateItemFileStatusInvoke(sourceFullFilename, fileStatusSource); FileStatus fileStatusTarget = FileHandler.GetFileStatus( targetFullFilename, checkLockedStatus: true); AddError( Path.GetDirectoryName(sourceFullFilename), Path.GetFileName(sourceFullFilename), dateTimeLastWriteTime, sourceFullFilename, targetFullFilename, AddErrorFileSystemRegion, AddErrorFileSystemCopy, "Issue: Failed copying the file.\r\n" + "From File Name: " + sourceFullFilename + "\r\n" + "From File Staus: " + fileStatusSource.ToString() + "\r\n" + "To File Name: " + targetFullFilename + "\r\n" + "To File Staus: " + fileStatusTarget.ToString() + "\r\n" + "Error message: " + ex.Message); Logger.Error(ex, "Error when copy file."); } } } ImageListView_SelectionChanged_Action_ImageListView_DataGridView(false); }
private void AfterAfterLabelEdit(TreeNode node, string newLabel, string oldLabel) { try { using (new WaitCursor()) { treeViewFolderBrowser1.SuspendLayout(); string sourceDirectory = GetSelectedNodeFullRealPath(); if (Directory.Exists(sourceDirectory)) { string newTagretDirectory = Path.Combine((new DirectoryInfo(sourceDirectory).Parent).FullName, newLabel); TreeNode treeNodeParent = node.Parent; treeNodeParent.Collapse(); MoveFolder_UpdateTreeViewFolderBrowser(treeViewFolderBrowser1, sourceDirectory, newTagretDirectory, treeNodeParent); TreeViewFolderBrowserHandler.RefreshTreeNode(treeViewFolderBrowser1, treeNodeParent); //Need refresh, don't know why yet, it should already been done //Set Selected Node back to the node that was renamed foreach (TreeNode treeNode in treeNodeParent.Nodes) { if (treeNode.Text == newLabel || treeNode.Text == oldLabel) //Select the node with new name or old name, in case rename failed { treeNode.TreeView.SelectedNode = treeNode; treeNode.Expand(); break; } } } else { KryptonMessageBox.Show("Can't edit folder name. No valid folder selected.", "Invalid folder...", MessageBoxButtons.OK, MessageBoxIcon.Warning, showCtrlCopy: true); } treeViewFolderBrowser1.ResumeLayout(); } } catch (Exception ex) { Logger.Error(ex, ""); KryptonMessageBox.Show("Following error occured: \r\n" + ex.Message, "Was not able to complete operation", MessageBoxButtons.OK, MessageBoxIcon.Error, showCtrlCopy: true); } }
private void CopyFolder_UpdateTreeViewFolderBrowser(TreeViewFolderBrowser folderTreeView, string sourceDirectory, string tagretDirectory, TreeNode targetNode) { IEnumerable <FileData> allSourceFileDatas = ImageAndMovieFileExtentionsUtility.GetFilesByEnumerableFast(sourceDirectory, true); //----- Create directories and sub-directories Directory.CreateDirectory(tagretDirectory); foreach (string dirPath in Directory.GetDirectories(sourceDirectory, "*", SearchOption.AllDirectories)) { try { Directory.CreateDirectory(dirPath.Replace(sourceDirectory, tagretDirectory)); } catch (SystemException ex) { Logger.Error(ex, "Error when create directory when copy all files from folder"); AddError( dirPath, AddErrorFileSystemRegion, AddErrorFileSystemCreateFolder, dirPath.Replace(sourceDirectory, tagretDirectory), dirPath.Replace(sourceDirectory, tagretDirectory), "Issue: Failed create directory\r\n" + "Directory: " + dirPath + "\r\n" + "Error message: " + ex.Message); } } using (new WaitCursor()) { //Copy all the files & Replaces any files with the same name foreach (FileData sourceFileData in allSourceFileDatas) { string sourceFilename = Path.GetFileName(sourceFileData.Path); string targetFullFilename = Path.Combine(tagretDirectory, sourceFilename); try { Logger.Trace("Copy from:" + sourceFileData.Path + " to: " + targetFullFilename); File.Copy(sourceFileData.Path, sourceFileData.Path.Replace(sourceDirectory, tagretDirectory), false); if (targetNode != null) { TreeViewFolderBrowserHandler.RefreshTreeNode(folderTreeView, targetNode); } databaseAndCacheMetadataExiftool.Copy( Path.GetDirectoryName(sourceFileData.Path), Path.GetFileName(sourceFileData.Path), Path.GetDirectoryName(sourceFileData.Path), Path.GetFileName(sourceFileData.Path)); } catch (SystemException ex) { DateTime dateTimeLastWriteTime = DateTime.Now; try { dateTimeLastWriteTime = FileHandler.GetLastWriteTime(sourceFileData.Path); } catch { } FileStatus fileStatusSource = FileHandler.GetFileStatus( sourceFileData.Path, checkLockedStatus: true, hasErrorOccured: true, errorMessage: ex.Message); ImageListView_UpdateItemFileStatusInvoke(sourceFileData.Path, fileStatusSource); FileStatus fileStatusTarget = FileHandler.GetFileStatus( targetFullFilename, checkLockedStatus: true); //ImageListView_UpdateItemFileStatusInvoke(targetFullFilename, fileStatusTarget); AddError( Path.GetDirectoryName(sourceFileData.Path), Path.GetFileName(sourceFileData.Path), dateTimeLastWriteTime, AddErrorFileSystemRegion, AddErrorFileSystemCopy, sourceFileData.Path, targetFullFilename, "Issue: Failed copying file.\r\n" + "From File Name: " + sourceFileData.Path + "\r\n" + "From File Staus: " + fileStatusSource.ToString() + "\r\n" + "To File Name: " + targetFullFilename + "\r\n" + "To File Staus: " + fileStatusTarget.ToString() + "\r\n" + "Error message: " + ex.Message); } } } //------ Update node tree ----- GlobalData.DoNotTrigger_TreeViewFolder_BeforeAndAfterSelect = true; TreeViewFolderBrowserHandler.RefreshTreeNode(folderTreeView, targetNode); GlobalData.DoNotTrigger_TreeViewFolder_BeforeAndAfterSelect = false; }
private void MoveFilesNoRename_UpdateTreeViewFolderBrowser(TreeViewFolderBrowser folderTreeView, ImageListView imageListView, StringCollection files, string targetNodeDirectory, TreeNode treeNodeTarget) { if (GlobalData.IsApplicationClosing) { return; } if (InvokeRequired) { this.BeginInvoke(new Action <TreeViewFolderBrowser, ImageListView, StringCollection, string, TreeNode>(MoveFilesNoRename_UpdateTreeViewFolderBrowser), folderTreeView, imageListView, files, targetNodeDirectory, treeNodeTarget); return; } if (GlobalData.IsApplicationClosing) { return; } if (DoNotTrigger_ImageListView_SelectionChanged()) { return; } try { GlobalData.DoNotTrigger_ImageListView_SelectionChanged = true; ImageListViewHandler.SuspendLayout(imageListView1); #region Do the work using (new WaitCursor()) { foreach (string oldPath in files) //Move all files to target directory { string sourceFullFilename = oldPath; string filename = Path.GetFileName(sourceFullFilename); string targetFullFilename = Path.Combine(targetNodeDirectory, filename); try { bool directoryCreated = filesCutCopyPasteDrag.MoveFile(sourceFullFilename, targetFullFilename); //------ Update node tree ----- GlobalData.DoNotTrigger_TreeViewFolder_BeforeAndAfterSelect = true; if (treeNodeTarget == null) { string targetFolder = Path.GetDirectoryName(targetFullFilename); TreeViewFolderBrowserHandler.RemoveFolderWithName(folderTreeView, targetFolder); } else { TreeViewFolderBrowserHandler.RefreshTreeNode(folderTreeView, treeNodeTarget); } GlobalData.DoNotTrigger_TreeViewFolder_BeforeAndAfterSelect = false; ImageListViewItem foundItem = ImageListViewHandler.FindItem(imageListView.Items, sourceFullFilename); if (foundItem != null) { ImageListViewHandler.ImageListViewRemoveItem(imageListView, foundItem); } } catch (Exception ex) { DateTime dateTimeLastWriteTime = DateTime.Now; try { dateTimeLastWriteTime = FileHandler.GetLastWriteTime(sourceFullFilename); } catch { } FileStatus fileStatus = FileHandler.GetFileStatus( sourceFullFilename, checkLockedStatus: true, hasErrorOccured: true, errorMessage: ex.Message); ImageListView_UpdateItemFileStatusInvoke(sourceFullFilename, fileStatus); FileStatus fileStatusTarget = FileHandler.GetFileStatus( targetFullFilename, checkLockedStatus: true, hasErrorOccured: true, errorMessage: ex.Message, exiftoolProcessStatus: ExiftoolProcessStatus.DoNotUpdate); ImageListView_UpdateItemFileStatusInvoke(targetFullFilename, fileStatus); AddError( Path.GetDirectoryName(sourceFullFilename), Path.GetFileName(sourceFullFilename), dateTimeLastWriteTime, AddErrorFileSystemRegion, AddErrorFileSystemMove, sourceFullFilename, targetFullFilename, "Issue: Failed moving file.\r\n" + "From File name : " + sourceFullFilename + "\r\n" + "From File staus: " + fileStatus.ToString() + "\r\n" + "To File name : " + targetFullFilename + "\r\n" + "To File staus: " + fileStatusTarget.ToString() + "\r\n" + "Error message: " + ex.Message); Logger.Error(ex, "Error when move file."); } } } #endregion } catch (Exception ex) { Logger.Error(ex); KryptonMessageBox.Show("Unexpected error occur.\r\nException message:" + ex.Message + "\r\n", "Unexpected error occur", MessageBoxButtons.OK, MessageBoxIcon.Error, showCtrlCopy: true); } finally { GlobalData.IsPerformingAButtonAction = false; ImageListViewHandler.ResumeLayout(imageListView1); GlobalData.DoNotTrigger_ImageListView_SelectionChanged = false; ImageListView_SelectionChanged_Action_ImageListView_DataGridView(false); } }