Browse Source
git-svn-id: svn://svn.sharpdevelop.net/sharpdevelop/trunk@4333 1ccf3a8d-04fe-1044-b7c0-cef0b8235c61shortcuts
13 changed files with 305 additions and 50 deletions
@ -0,0 +1,28 @@
@@ -0,0 +1,28 @@
|
||||
// <file>
|
||||
// <copyright see="prj:///doc/copyright.txt"/>
|
||||
// <license see="prj:///doc/license.txt"/>
|
||||
// <owner name="Siegfried Pammer" email="sie_pam@gmx.at"/>
|
||||
// <version>$Revision$</version>
|
||||
// </file>
|
||||
|
||||
using System; |
||||
using System.Collections.Generic; |
||||
using System.Windows.Controls; |
||||
|
||||
namespace ICSharpCode.XamlBinding.PowerToys.Commands |
||||
{ |
||||
/// <summary>
|
||||
/// Description of GroupIntoMenuBuilder
|
||||
/// </summary>
|
||||
public class GroupIntoMenuBuilder : XamlMenuBuilder |
||||
{ |
||||
public override MenuItem[] BuildItems() |
||||
{ |
||||
List<MenuItem> list = new List<MenuItem>(); |
||||
|
||||
|
||||
|
||||
return list.ToArray(); |
||||
} |
||||
} |
||||
} |
||||
@ -0,0 +1,60 @@
@@ -0,0 +1,60 @@
|
||||
// <file>
|
||||
// <copyright see="prj:///doc/copyright.txt"/>
|
||||
// <license see="prj:///doc/license.txt"/>
|
||||
// <owner name="Siegfried Pammer" email="sie_pam@gmx.at"/>
|
||||
// <version>$Revision$</version>
|
||||
// </file>
|
||||
|
||||
using ICSharpCode.Core; |
||||
using System; |
||||
using System.Linq; |
||||
using System.Xml; |
||||
using ICSharpCode.SharpDevelop.Editor; |
||||
using ICSharpCode.XamlBinding; |
||||
|
||||
namespace ICSharpCode.XamlBinding.PowerToys.Commands |
||||
{ |
||||
public class RemoveMarginCommand : XamlMenuCommand |
||||
{ |
||||
protected override void Refactor(ITextEditor editor, XmlDocument document) |
||||
{ |
||||
RemoveRecursive(document, "Margin"); |
||||
} |
||||
|
||||
protected void RemoveRecursive(XmlNode pNode, string name) |
||||
{ |
||||
foreach (XmlNode node in pNode.ChildNodes) { |
||||
node.Attributes.Remove(name); |
||||
RemoveRecursive(node, name); |
||||
} |
||||
} |
||||
|
||||
protected void RemoveRecursive(XmlNode pNode, string name, string namespaceURI) |
||||
{ |
||||
foreach (XmlNode node in pNode.ChildNodes) { |
||||
node.Attributes.Remove(name, namespaceURI); |
||||
RemoveRecursive(node, name, namespaceURI); |
||||
} |
||||
} |
||||
} |
||||
|
||||
public class GroupIntoMenuItem : XamlMenuCommand |
||||
{ |
||||
protected sealed override void Refactor(ITextEditor editor, XmlDocument document) |
||||
{ |
||||
if (editor.SelectionLength == 0) { |
||||
MessageService.ShowError("The selected XAML is invalid!"); |
||||
} |
||||
} |
||||
} |
||||
|
||||
public class ExtractPropertiesAsStyleCommand : XamlMenuCommand |
||||
{ |
||||
protected override void Refactor(ITextEditor editor, XmlDocument document) |
||||
{ |
||||
string[] attributes = Utils.GetListOfExistingAttributeNames(editor.Document.Text, editor.Caret.Line, editor.Caret.Column); |
||||
|
||||
|
||||
} |
||||
} |
||||
} |
||||
@ -0,0 +1,31 @@
@@ -0,0 +1,31 @@
|
||||
// <file>
|
||||
// <copyright see="prj:///doc/copyright.txt"/>
|
||||
// <license see="prj:///doc/license.txt"/>
|
||||
// <owner name="Siegfried Pammer" email="sie_pam@gmx.at"/>
|
||||
// <version>$Revision$</version>
|
||||
// </file>
|
||||
|
||||
using System; |
||||
using System.Windows.Forms; |
||||
|
||||
using ICSharpCode.Core; |
||||
using ICSharpCode.SharpDevelop; |
||||
|
||||
namespace ICSharpCode.XamlBinding.PowerToys.Commands |
||||
{ |
||||
/// <summary>
|
||||
/// Description of RemoveUnneccessaryAttributesCommand
|
||||
/// </summary>
|
||||
public class RemoveUnnecessaryAttributesCommand : RemoveMarginCommand |
||||
{ |
||||
protected override void Refactor(ICSharpCode.SharpDevelop.Editor.ITextEditor editor, System.Xml.XmlDocument document) |
||||
{ |
||||
RemoveRecursive(document, "Margin"); |
||||
RemoveRecursive(document, "Name"); |
||||
RemoveRecursive(document, "Name", CompletionDataHelper.XamlNamespace); |
||||
RemoveRecursive(document, "MinWidth"); |
||||
RemoveRecursive(document, "MinHeight"); |
||||
// set all row and column definitions to Auto
|
||||
} |
||||
} |
||||
} |
||||
@ -0,0 +1,52 @@
@@ -0,0 +1,52 @@
|
||||
// <file>
|
||||
// <copyright see="prj:///doc/copyright.txt"/>
|
||||
// <license see="prj:///doc/license.txt"/>
|
||||
// <owner name="Siegfried Pammer" email="sie_pam@gmx.at"/>
|
||||
// <version>$Revision$</version>
|
||||
// </file>
|
||||
|
||||
using System; |
||||
using System.IO; |
||||
using System.Windows.Forms; |
||||
using System.Xml; |
||||
|
||||
using ICSharpCode.Core; |
||||
using ICSharpCode.SharpDevelop; |
||||
using ICSharpCode.SharpDevelop.Editor; |
||||
using ICSharpCode.SharpDevelop.Gui; |
||||
|
||||
namespace ICSharpCode.XamlBinding.PowerToys |
||||
{ |
||||
/// <summary>
|
||||
/// Description of XamlMenuCommand
|
||||
/// </summary>
|
||||
public abstract class XamlMenuCommand : AbstractMenuCommand |
||||
{ |
||||
/// <summary>
|
||||
/// Starts the command
|
||||
/// </summary>
|
||||
public sealed override void Run() |
||||
{ |
||||
try { |
||||
ITextEditorProvider provider = WorkbenchSingleton.Workbench.ActiveViewContent as ITextEditorProvider; |
||||
|
||||
if (provider != null) { |
||||
TextReader reader = provider.TextEditor.Document.CreateReader(); |
||||
XmlDocument document = new XmlDocument(); |
||||
document.Load(reader); |
||||
Refactor(provider.TextEditor, document); |
||||
StringWriter sWriter = new StringWriter(); |
||||
XmlTextWriter writer = new XmlTextWriter(sWriter); |
||||
writer.Formatting = Formatting.Indented; |
||||
document.WriteTo(writer); |
||||
writer.Flush(); |
||||
provider.TextEditor.Document.Text = sWriter.ToString(); |
||||
} |
||||
} catch (XmlException e) { |
||||
MessageService.ShowError(e.Message); |
||||
} |
||||
} |
||||
|
||||
protected abstract void Refactor(ITextEditor editor, XmlDocument document); |
||||
} |
||||
} |
||||
Loading…
Reference in new issue