From 7aec1289ccc2f5044dfda62d48a62dec50db5577 Mon Sep 17 00:00:00 2001 From: SergeyNefyodov Date: Thu, 18 Apr 2024 17:25:30 +0200 Subject: [PATCH] Add support to View class methods --- .../Descriptors/ViewDescriptor.cs | 76 ++++++++++++++++++- 1 file changed, 75 insertions(+), 1 deletion(-) diff --git a/source/RevitLookup/Core/ComponentModel/Descriptors/ViewDescriptor.cs b/source/RevitLookup/Core/ComponentModel/Descriptors/ViewDescriptor.cs index 1901175c..dc51d9db 100644 --- a/source/RevitLookup/Core/ComponentModel/Descriptors/ViewDescriptor.cs +++ b/source/RevitLookup/Core/ComponentModel/Descriptors/ViewDescriptor.cs @@ -36,6 +36,11 @@ public ResolveSet Resolve(Document context, string target, ParameterInfo[] param nameof(View.GetFilterOverrides) => ResolveFilterOverrides(), nameof(View.GetFilterVisibility) => ResolveFilterVisibility(), nameof(View.GetWorksetVisibility) => ResolveWorksetVisibility(), + nameof(View.IsCategoryOverridable) => ResolveIsCategoryOverridable(), + nameof(View.IsFilterApplied) => ResolveIsFilterApplied(), + nameof(View.IsInTemporaryViewMode) => ResolveIsInTemporaryViewMode(), + nameof(View.IsValidViewTemplate) => ResolveIsValidViewTemplate(), + nameof(View.IsWorksetVisible) => ResolveIsWorksetVisible(), #if REVIT2022_OR_GREATER nameof(View.GetColorFillSchemeId) => ResolveColorFillSchemeId(), #endif @@ -72,6 +77,21 @@ ResolveSet ResolveCategoryOverrides() return resolveSummary; } + ResolveSet ResolveIsCategoryOverridable() + { + var categories = context.Settings.Categories; + var resolveSummary = new ResolveSet(categories.Size); + foreach (Category category in categories) + { + if (!category.IsVisibleInUI) continue; + + var result = view.IsCategoryOverridable(category.Id); + resolveSummary.AppendVariant(result, category.Name); + } + + return resolveSummary; + } + ResolveSet ResolveFilterOverrides() { var filters = view.GetFilters(); @@ -114,9 +134,63 @@ ResolveSet ResolveFilterEnabled() return resolveSummary; } + ResolveSet ResolveIsFilterApplied() + { + var filters = view.GetFilters(); + var resolveSummary = new ResolveSet(filters.Count); + foreach (var filterId in filters) + { + var filter = filterId.ToElement(context)!; + var result = view.IsFilterApplied(filterId); + resolveSummary.AppendVariant(result, $"{filter.Name}: {result}"); + } + + return resolveSummary; + } + + + ResolveSet ResolveIsInTemporaryViewMode() + { + var values = Enum.GetValues(typeof(TemporaryViewMode)); + var resolveSummary = new ResolveSet(values.Length); + + foreach (TemporaryViewMode mode in values) + { + resolveSummary.AppendVariant(view.IsInTemporaryViewMode(mode), mode.ToString()); + } + + return resolveSummary; + } + + ResolveSet ResolveIsValidViewTemplate() + { + var templates = context.EnumerateInstances().Where(x => x.IsTemplate).ToArray(); + var resolveSummary = new ResolveSet(templates.Length); + foreach (var template in templates) + { + var result = view.IsValidViewTemplate(template.Id); + resolveSummary.AppendVariant(result, $"{template.Name}: {result}"); + } + + return resolveSummary; + } + + ResolveSet ResolveIsWorksetVisible() + { + var workSets = new FilteredWorksetCollector(context).OfKind(WorksetKind.UserWorkset).ToWorksets(); + var resolveSummary = new ResolveSet(workSets.Count); + foreach (var workSet in workSets) + { + var result = view.IsWorksetVisible(workSet.Id); + resolveSummary.AppendVariant(result, $"{workSet.Name}: {result}"); + } + + return resolveSummary; + } + ResolveSet ResolveWorksetVisibility() { - var workSets = new FilteredWorksetCollector(Context.Document).OfKind(WorksetKind.UserWorkset).ToWorksets(); + var workSets = new FilteredWorksetCollector(context).OfKind(WorksetKind.UserWorkset).ToWorksets(); var resolveSummary = new ResolveSet(workSets.Count); foreach (var workSet in workSets) {