-
Notifications
You must be signed in to change notification settings - Fork 15
Expand file tree
/
Copy pathAddElevationCommand.cs
More file actions
74 lines (61 loc) · 2.52 KB
/
AddElevationCommand.cs
File metadata and controls
74 lines (61 loc) · 2.52 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
using System;
using System.Collections.Generic;
using System.Linq;
using Autodesk.Revit.Attributes;
using Autodesk.Revit.DB;
using Autodesk.Revit.UI;
using dosymep.Bim4Everyone;
using dosymep.Revit;
using RevitCopyViews.ViewModels;
namespace RevitCopyViews;
[Transaction(TransactionMode.Manual)]
public class AddElevationCommand : BasePluginCommand {
public AddElevationCommand() {
PluginName = "Добавить отметки этажа";
}
protected override void Execute(UIApplication uiApplication) {
var uiDocument = uiApplication.ActiveUIDocument;
var document = uiDocument.Document;
string[] restrictedViewNames = new FilteredElementCollector(document)
.OfClass(typeof(View))
.Select(item => item.Name)
.OrderBy(item => item)
.Distinct()
.ToArray();
var errors = new List<View>();
using(var transaction = document.StartTransaction("Добавление отметки этажа")) {
var selectedViews = uiDocument.GetSelectedElements().OfType<View>();
foreach(var view in selectedViews) {
var splittedName = Delimiter.SplitViewName(
view.Name,
new SplitViewOptions {
ReplacePrefix = false,
ReplaceSuffix = false
});
splittedName.Elevations = SplittedViewName.GetElevation(view);
string viewName = Delimiter.CreateViewName(splittedName);
if(view.Name.Equals(viewName)) {
continue;
}
if(restrictedViewNames.Any(item => viewName.Equals(item))) {
errors.Add(view);
continue;
}
view.Name = Delimiter.CreateViewName(splittedName);
}
transaction.Commit();
}
if(errors.Count > 0) {
Notification(false);
string message = "Не были изменены имена у следующих видов:"
+ Environment.NewLine
+ " - "
+ string.Join(
Environment.NewLine + " - ",
errors.Select(item => $"{item.Id.GetIdValue()} - {item.Name}"));
TaskDialog.Show("Предупреждение!", message, TaskDialogCommonButtons.Ok);
} else {
Notification(true);
}
}
}