Fixes for project manager

This commit is contained in:
Tiberiu Chibici 2014-08-16 14:35:54 +03:00
parent bedc107bb1
commit fb2929e02a
9 changed files with 38 additions and 40 deletions

View File

@ -51,14 +51,14 @@ namespace RainmeterStudio.Business
/// </summary>
/// <param name="name">Name of project</param>
/// <param name="path">Path of project file</param>
public void CreateProject(string name, string path)
public void CreateProject(string name, string path, IProjectTemplate template)
{
// If there is an opened project, close it
if (ActiveProject != null)
Close();
// Create project object
ActiveProject = new Project();
ActiveProject = template.CreateProject();
ActiveProject.Name = name;
ActiveProject.Path = path;

View File

@ -163,12 +163,12 @@ namespace RainmeterStudio.Properties {
[global::System.Configuration.UserScopedSettingAttribute()]
[global::System.Diagnostics.DebuggerNonUserCodeAttribute()]
[global::System.Configuration.DefaultSettingValueAttribute("")]
public string CreateProjectDialog_SavedLocation {
public string Project_SavedLocation {
get {
return ((string)(this["CreateProjectDialog_SavedLocation"]));
return ((string)(this["Project_SavedLocation"]));
}
set {
this["CreateProjectDialog_SavedLocation"] = value;
this["Project_SavedLocation"] = value;
}
}

View File

@ -35,7 +35,7 @@
<Setting Name="CreateProjectDialog_RecentLocations" Type="System.String" Scope="User">
<Value Profile="(Default)" />
</Setting>
<Setting Name="CreateProjectDialog_SavedLocation" Type="System.String" Scope="User">
<Setting Name="Project_SavedLocation" Type="System.String" Scope="User">
<Value Profile="(Default)" />
</Setting>
<Setting Name="CreateProjectDialog_CreateDirectoryCheckbox" Type="System.Boolean" Scope="User">

View File

@ -31,6 +31,8 @@ namespace RainmeterStudio.UI.Controller
public Command DocumentCreateCommand { get; private set; }
public Command DocumentOpenCommand { get; private set; }
#endregion
/// <summary>
@ -58,25 +60,22 @@ namespace RainmeterStudio.UI.Controller
DocumentManager = documentManager;
ProjectManager = projectManager;
DocumentCreateCommand = new Command("DocumentCreateCommand", () => CreateWindow());
DocumentCreateCommand = new Command("DocumentCreateCommand", () => Create(), () => ProjectManager.ActiveProject != null);
ProjectManager.ActiveProjectChanged += new EventHandler((obj, e) => DocumentCreateCommand.NotifyCanExecuteChanged());
}
public void CreateWindow(IDocumentTemplate defaultFormat = null, string defaultPath = "")
public void Create()
{
// Show dialog
var dialog = new CreateDocumentDialog(this)
{
Owner = OwnerWindow,
SelectedTemplate = new DocumentTemplateViewModel(defaultFormat),
SelectedPath = defaultPath
};
var dialog = new CreateDocumentDialog(this);
dialog.Owner = OwnerWindow;
bool? res = dialog.ShowDialog();
if (!res.HasValue || !res.Value)
return;
var format = dialog.SelectedTemplate;
var path = dialog.SelectedPath;
var path = dialog.SelectedName;
// Call manager
DocumentManager.Create(format.Template);

View File

@ -8,6 +8,7 @@ using RainmeterStudio.Business;
using RainmeterStudio.Core.Model;
using RainmeterStudio.UI.Dialogs;
using RainmeterStudio.UI.ViewModel;
using RainmeterStudio.Properties;
namespace RainmeterStudio.UI.Controller
{
@ -115,9 +116,10 @@ namespace RainmeterStudio.UI.Controller
string selectedName = dialog.SelectedName;
string selectedPath = dialog.SelectedPath;
IProjectTemplate selectedTemplate = dialog.SelectedTemplate;
// Call manager
Manager.CreateProject(selectedName, selectedPath);
Manager.CreateProject(selectedName, selectedPath, selectedTemplate);
}
/// <summary>
@ -132,6 +134,7 @@ namespace RainmeterStudio.UI.Controller
+ Resources.Strings.Dialog_FileType_AllFiles + "|*.*";
dialog.Title = Resources.Strings.Dialog_OpenProject_Title;
dialog.Multiselect = false;
dialog.InitialDirectory = Settings.Default.Project_SavedLocation;
// Show dialog
bool? res = dialog.ShowDialog(OwnerWindow);

View File

@ -34,7 +34,6 @@
<Grid Grid.Row="1">
<Grid.RowDefinitions>
<RowDefinition />
<RowDefinition />
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="Auto" />
@ -43,18 +42,14 @@
</Grid.ColumnDefinitions>
<TextBlock Grid.Row="0" Text="{x:Static r:Strings.CreateDocumentDialog_Name}" />
<TextBox Name="textPath" Grid.Row="0" Grid.Column="1" Margin="1px"></TextBox>
<TextBlock Grid.Row="1">Path:</TextBlock>
<TextBox Name="textPath1" Grid.Row="1" Grid.Column="1" Margin="1px"></TextBox>
<Button Grid.Row="1" Grid.Column="2">...</Button>
<TextBox Name="textName" Grid.Row="0" Grid.Column="1" Margin="1px" TextChanged="textName_TextChanged"/>
</Grid>
<StackPanel Grid.Row="2" Orientation="Horizontal"
HorizontalAlignment="Right">
<Button Name="buttonCreate" Click="buttonCreate_Click" IsDefault="True" Margin="1px">Create</Button>
<Button Name="buttonCancel" Click="buttonCancel_Click" IsCancel="True" Margin="1px">Cancel</Button>
<Button Name="buttonCreate" Content="{x:Static r:Strings.Dialog_Create}" IsDefault="True" Margin="1px" Click="buttonCreate_Click" />
<Button Name="buttonCancel" Content="{x:Static r:Strings.Dialog_Cancel}" IsCancel="True" Margin="1px" Click="buttonCancel_Click" />
</StackPanel>
</Grid>

View File

@ -2,6 +2,7 @@
using System.Linq;
using System.Windows;
using System.Windows.Controls;
using RainmeterStudio.Core.Utils;
using RainmeterStudio.UI.Controller;
using RainmeterStudio.UI.ViewModel;
@ -32,15 +33,15 @@ namespace RainmeterStudio.UI.Dialogs
/// <summary>
/// Gets or sets the path
/// </summary>
public string SelectedPath
public string SelectedName
{
get
{
return textPath.Text;
return textName.Text;
}
set
{
textPath.Text = value;
textName.Text = value;
}
}
@ -52,13 +53,9 @@ namespace RainmeterStudio.UI.Dialogs
InitializeComponent();
_documentController = docCtrl;
PopulateFormats();
Validate();
}
listTemplates.ItemsSource = _documentController.DocumentTemplates.OrderBy(x => x.DisplayText);
private void PopulateFormats()
{
listTemplates.ItemsSource = _documentController.DocumentTemplates;
Validate();
}
private void buttonCreate_Click(object sender, RoutedEventArgs e)
@ -77,9 +74,8 @@ namespace RainmeterStudio.UI.Dialogs
{
bool res = true;
res &= !String.IsNullOrWhiteSpace(textPath.Text);
res &= !textPath.Text.Intersect(System.IO.Path.GetInvalidFileNameChars()).Any();
res &= (listTemplates.SelectedItem != null);
res &= PathHelper.IsFileNameValid(SelectedName);
buttonCreate.IsEnabled = res;
}
@ -88,5 +84,10 @@ namespace RainmeterStudio.UI.Dialogs
{
Validate();
}
private void textName_TextChanged(object sender, TextChangedEventArgs e)
{
Validate();
}
}
}

View File

@ -32,11 +32,11 @@ namespace RainmeterStudio.UI.Dialogs
/// <summary>
/// Gets or sets the currently selected file format
/// </summary>
public IDocumentTemplate SelectedTemplate
public IProjectTemplate SelectedTemplate
{
get
{
return listTemplates.SelectedItem as IDocumentTemplate;
return listTemplates.SelectedItem as IProjectTemplate;
}
set
{
@ -125,7 +125,7 @@ namespace RainmeterStudio.UI.Dialogs
private string GetLocation()
{
// Get setting
string location = Settings.Default.CreateProjectDialog_SavedLocation;
string location = Settings.Default.Project_SavedLocation;
// No location provided, use default
if (String.IsNullOrEmpty(location))
@ -197,7 +197,7 @@ namespace RainmeterStudio.UI.Dialogs
// Save location
if (checkLocationDefault.IsChecked.HasValue && checkLocationDefault.IsChecked.Value)
{
Settings.Default.CreateProjectDialog_SavedLocation = SelectedLocation;
Settings.Default.Project_SavedLocation = SelectedLocation;
}
}
}

View File

@ -41,7 +41,7 @@
<setting name="CreateProjectDialog_RecentLocations" serializeAs="String">
<value />
</setting>
<setting name="CreateProjectDialog_SavedLocation" serializeAs="String">
<setting name="Project_SavedLocation" serializeAs="String">
<value />
</setting>
<setting name="CreateProjectDialog_CreateDirectoryCheckbox" serializeAs="String">