123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408 |
- using Compdfkit_Tools.Helper;
- using Compdfkit_Tools.PDFControl;
- using Dragablz;
- using System;
- using System.ComponentModel;
- using System.Runtime.CompilerServices;
- using System.Windows;
- using System.Windows.Controls;
- using System.Windows.Input;
- using System.Windows.Media;
- using Path = System.IO.Path;
- namespace PDFViewer
- {
- public partial class MainWindow : Window
- {
- #region Property
- private PDFViewControl passwordViewer;
- private PDFViewControl pdfViewControl = new PDFViewControl();
- private string[] oldAndNewFilePath;
- #endregion
- public MainWindow()
- {
- InitializeComponent();
- Loaded += MainWindow_Loaded;
- }
- private void MainWindow_Loaded(object sender, RoutedEventArgs e)
- {
- PasswordUI.Closed -= PasswordUI_Closed;
- PasswordUI.Canceled -= PasswordUI_Canceled;
- PasswordUI.Confirmed -= PasswordUI_Confirmed;
- PasswordUI.Confirmed += PasswordUI_Confirmed;
- PasswordUI.Canceled += PasswordUI_Canceled;
- PasswordUI.Closed += PasswordUI_Closed;
- if (App.DefaultPDFLoaded == false)
- {
- LoadDefaultDocument();
- App.DefaultPDFLoaded = true;
- }
- }
- #region Load document
- private void LoadDefaultDocument()
- {
- string defaultFilePath = "PDF32000_2008.pdf";
- TabControlLoadDocument(defaultFilePath);
- }
- private void TabControlLoadDocument(string filePath)
- {
- if (App.OpenedFilePathList.Contains(filePath))
- {
- for (int i = 0; i < App.Current.Windows.Count; i++)
- {
- MainWindow win = App.Current.Windows[i] as MainWindow;
- if (win != null)
- {
- var items = win.TabControl.Items;
- foreach (TabItemExt item in items)
- {
- if (item.Tag.ToString().ToLower() == filePath.ToLower())
- {
- win.Activate();
- item.IsSelected = true;
- return;
- }
- }
- }
- }
- }
- TabItemExt tabItem = new TabItemExt();
- MainPage viewPage = new MainPage();
- viewPage.CheckExistBeforeOpenFileEvent -= ViewPage_CheckExistBeforeOpenFileEvent;
- viewPage.FileChangeEvent -= ViewPage_FileChangeEvent;
- viewPage.CheckExistBeforeOpenFileEvent += ViewPage_CheckExistBeforeOpenFileEvent;
- viewPage.FileChangeEvent += ViewPage_FileChangeEvent;
- passwordViewer = new PDFViewControl();
- passwordViewer.PDFView.InitDocument(filePath);
- if (passwordViewer.PDFView.Document == null)
- {
- MessageBox.Show("Open File Failed");
- return;
- }
- if (passwordViewer.PDFView.Document.IsLocked)
- {
- PasswordUI.SetShowText(System.IO.Path.GetFileName(filePath) + " password encrypted.");
- PasswordUI.ClearPassword();
- PopupBorder.Visibility = Visibility.Visible;
- PasswordUI.Visibility = Visibility.Visible;
- }
- else
- {
- viewPage.InitWithFilePath(filePath);
- tabItem.Content = viewPage;
- tabItem.IsSelected = true;
- tabItem.FileName = Path.GetFileName(filePath);
- tabItem.Tag = filePath;
- App.OpenedFilePathList.Add(filePath);
- TabControl.Items.Add(tabItem);
- }
- }
- private void ViewPage_FileChangeEvent(object sender, EventArgs e)
- {
- for (int i = 0; i < App.Current.Windows.Count; i++)
- {
- MainWindow win = App.Current.Windows[i] as MainWindow;
- if (win != null)
- {
- var items = win.TabControl.Items;
- foreach (TabItemExt item in items)
- {
- if (item.Tag.ToString().ToLower() == oldAndNewFilePath[1].ToLower())
- {
- item.IsSelected = true;
- item.FileName = Path.GetFileName(oldAndNewFilePath[0]);
- item.IsSelected = true;
- item.Tag = oldAndNewFilePath[0];
- }
- }
- }
- }
- for (int i = 0; i < App.OpenedFilePathList.Count; i++)
- {
- if (oldAndNewFilePath[1].ToLower() == App.OpenedFilePathList[i].ToLower())
- {
- App.OpenedFilePathList[i] = oldAndNewFilePath[0];
- break;
- }
- }
- }
- private bool ViewPage_CheckExistBeforeOpenFileEvent(string[] arg)
- {
- if (App.OpenedFilePathList.Contains(arg[0]))
- {
- for (int i = 0; i < App.Current.Windows.Count; i++)
- {
- MainWindow win = App.Current.Windows[i] as MainWindow;
- if (win != null)
- {
- var items = win.TabControl.Items;
- foreach (TabItemExt item in items)
- {
- if (item.Tag.ToString().ToLower() == arg[0].ToLower())
- {
- win.Activate();
- item.IsSelected = true;
- return true;
- }
- }
- }
- }
- }
- oldAndNewFilePath = arg;
- return false;
- }
- #endregion
- #region password
- private void PasswordUI_Closed(object sender, EventArgs e)
- {
- PopupBorder.Visibility = Visibility.Collapsed;
- PasswordUI.Visibility = Visibility.Collapsed;
- }
- private void PasswordUI_Canceled(object sender, EventArgs e)
- {
- PopupBorder.Visibility = Visibility.Collapsed;
- PasswordUI.Visibility = Visibility.Collapsed;
- }
- private void PasswordUI_Confirmed(object sender, string e)
- {
- if (passwordViewer != null && passwordViewer.PDFView != null && passwordViewer.PDFView.Document != null)
- {
- passwordViewer.PDFView.Document.UnlockWithPassword(e);
- if (passwordViewer.PDFView.Document.IsLocked == false)
- {
- PasswordUI.SetShowError("", Visibility.Collapsed);
- PasswordUI.ClearPassword();
- PasswordUI.Visibility = Visibility.Collapsed;
- PopupBorder.Visibility = Visibility.Collapsed;
- pdfViewControl = passwordViewer;
- string filePath = passwordViewer.PDFView.Document.FilePath;
- TabItemExt tabItem = new TabItemExt();
- MainPage viewPage = new MainPage();
- tabItem.Content = viewPage;
- tabItem.IsSelected = true;
- tabItem.FileName = Path.GetFileName(filePath);
- tabItem.Tag = filePath;
- viewPage.SetPDFViewer(pdfViewControl);
- App.OpenedFilePathList.Add(filePath);
- TabControl.Items.Add(tabItem);
- }
- else
- {
- PasswordUI.SetShowError("error", Visibility.Visible);
- }
- }
- }
- #endregion
- #region UI
- private void Grid_MouseLeftButtonDown(object sender, MouseButtonEventArgs e)
- {
- DragMove();
- }
- private void CloseFileButton_Click(object sender, RoutedEventArgs e)
- {
- var button = sender as Button;
- var dragablzItem = FindParentDragablzItem(button);
- var tabControl = FindParentTabControl(dragablzItem);
- MainPage mainPage = (dragablzItem.Content as TabItemExt).Content as MainPage;
- if (mainPage.CanSave)
- {
- string fileName = (dragablzItem.Content as TabItemExt).FileName;
- var message = string.Format("Do you want to save the changes in {0}?", fileName);
- var result = MessageBox.Show(message, "Alert", MessageBoxButton.YesNoCancel, MessageBoxImage.Question);
- if (result == MessageBoxResult.Yes)
- {
- mainPage.SaveFile();
- App.OpenedFilePathList.Remove((dragablzItem.Content as TabItemExt).Tag.ToString());
- tabControl.Items.Remove(dragablzItem.Content);
- }
- else if (result == MessageBoxResult.No)
- {
- App.OpenedFilePathList.Remove((dragablzItem.Content as TabItemExt).Tag.ToString());
- tabControl.Items.Remove(dragablzItem.Content);
- }
- else
- {
- }
- }
- else
- {
- App.OpenedFilePathList.Remove((dragablzItem.Content as TabItemExt).Tag.ToString());
- tabControl.Items.Remove(dragablzItem.Content);
- }
- if (tabControl.Items.Count == 0)
- {
- SystemCommands.CloseWindow(this);
- }
- }
- private DragablzItem FindParentDragablzItem(DependencyObject element)
- {
- while (element != null && !(element is DragablzItem))
- {
- element = VisualTreeHelper.GetParent(element);
- }
- return element as DragablzItem;
- }
- private TabControl FindParentTabControl(DependencyObject element)
- {
- while (element != null && !(element is TabControl))
- {
- element = VisualTreeHelper.GetParent(element);
- }
- return element as TabControl;
- }
- private void MinimizeButton_Click(object sender, RoutedEventArgs e)
- {
- SystemCommands.MinimizeWindow(this);
- }
- private void MaximizeRestoreButton_Click(object sender, RoutedEventArgs e)
- {
- if (this.WindowState == WindowState.Maximized)
- {
- SystemCommands.RestoreWindow(this);
- }
- else
- {
- SystemCommands.MaximizeWindow(this);
- }
- }
- private void CloseButton_Click(object sender, RoutedEventArgs e)
- {
- int count = TabControl.Items.Count;
- while (count > 0)
- {
- TabItemExt item = TabControl.Items[0] as TabItemExt;
- MainPage mainPage = item.Content as MainPage;
- if (mainPage.CanSave)
- {
- string fileName = item.FileName;
- var message = string.Format("Do you want to save the changes in {0}?", fileName);
- var result = MessageBox.Show(message, "Alert", MessageBoxButton.YesNoCancel, MessageBoxImage.Question);
- if (result == MessageBoxResult.Yes)
- {
- mainPage.SaveFile();
- App.OpenedFilePathList.Remove(item.Tag.ToString());
- TabControl.Items.Remove(item);
- count--;
- }
- else if (result == MessageBoxResult.No)
- {
- App.OpenedFilePathList.Remove(item.Tag.ToString());
- TabControl.Items.Remove(item);
- count--;
- }
- else
- {
- break;
- }
- }
- else
- {
- App.OpenedFilePathList.Remove(item.Tag.ToString());
- TabControl.Items.Remove(item);
- count--;
- }
- }
- if (count == 0)
- {
- SystemCommands.CloseWindow(this);
- }
- }
- private void DefaultAddButton_Click(object sender, RoutedEventArgs e)
- {
- string filePath = CommonHelper.GetFilePathOrEmpty();
- if (filePath != string.Empty)
- {
- TabControlLoadDocument(filePath);
- }
- }
- #endregion
- public class TabItemExt : TabItem, INotifyPropertyChanged
- {
- public event PropertyChangedEventHandler PropertyChanged;
- private string _fileName;
- public string FileName
- {
- get
- {
- return _fileName;
- }
- set
- {
- if (_fileName != value)
- {
- _fileName = value;
- OnPropertyChanged();
- }
- }
- }
- private Visibility _fileChanged = Visibility.Hidden;
- public Visibility FileChanged
- {
- get
- {
- return _fileChanged;
- }
- set
- {
- if (_fileChanged != value)
- {
- _fileChanged = value;
- OnPropertyChanged();
- }
- }
- }
- public void OnPropertyChanged([CallerMemberName] string name = null)
- {
- PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(name));
- }
- }
- }
- }
|