|
21 | 21 |
|
22 | 22 | if (isFirstRender)
|
23 | 23 | {
|
24 |
| - if (settings.HasInlineFilter && settings.InlineFilterTemplate == null && settings.Columns.Any(x => x.Filter != null)) |
| 24 | + if (settings.AllowedFilterModes == null) |
25 | 25 | {
|
26 |
| - settings.InlineFilterTemplate = (x) => RenderInlineFilters(x); |
| 26 | + FilterMode allowedModes = FilterMode.None; |
| 27 | + |
| 28 | + if (settings.InlineFilterTemplate != null || settings.Columns.Any(x => x.Filter != null)) |
| 29 | + { |
| 30 | + allowedModes |= FilterMode.Inline; |
| 31 | + } |
| 32 | + |
| 33 | + if (settings.FilterTemplate != null || (settings.Filters.Any(x => !settings.Columns.Any(y => y.Filter != x)))) |
| 34 | + { |
| 35 | + allowedModes |= FilterMode.Form; |
| 36 | + } |
| 37 | + |
| 38 | + settings.AllowedFilterModes = allowedModes; |
27 | 39 | }
|
| 40 | + |
| 41 | + if (settings.AllowedFilterModes != FilterMode.None) |
| 42 | + { |
| 43 | + if (settings.InitialFilterMode == null) |
| 44 | + { |
| 45 | + if (settings.AllowedFilterModes.Value.HasFlag(FilterMode.Inline)) |
| 46 | + { |
| 47 | + settings.InitialFilterMode = FilterMode.Inline; |
| 48 | + } |
| 49 | + else if (settings.AllowedFilterModes.Value.HasFlag(FilterMode.Form)) |
| 50 | + { |
| 51 | + settings.InitialFilterMode = FilterMode.Form; |
| 52 | + } |
| 53 | + |
| 54 | + if (settings.InitialFilterMode == null || settings.InitialFilterMode == FilterMode.Both) |
| 55 | + { |
| 56 | + throw new InvalidOperationException("Invalid InitialFilterMode: " + settings.InitialFilterMode + "."); |
| 57 | + } |
| 58 | + } |
| 59 | + |
| 60 | + if (settings.AllowedFilterModes.Value.HasFlag(FilterMode.Inline) && settings.InlineFilterTemplate == null && settings.Columns.Any(x => x.Filter != null)) |
| 61 | + { |
| 62 | + settings.InlineFilterTemplate = (x) => RenderInlineFilters(x); |
| 63 | + } |
28 | 64 |
|
29 |
| - if (settings.FilterTemplate == null && settings.Filters.Any()) |
| 65 | + if (settings.AllowedFilterModes.Value.HasFlag(FilterMode.Form) && settings.FilterTemplate == null && settings.Filters.Any()) |
| 66 | + { |
| 67 | + settings.FilterTemplate = (x) => RenderFilters(x); |
| 68 | + } |
| 69 | + } |
| 70 | + else |
30 | 71 | {
|
31 |
| - settings.FilterTemplate = (x) => RenderFilters(x); |
| 72 | + settings.InitialFilterMode = FilterMode.None; |
32 | 73 | }
|
33 | 74 |
|
34 | 75 | if (GriddlySettings.BeforeRender != null)
|
|
50 | 91 | @:<div class="griddly @settings.ClassName" data-role="griddly"
|
51 | 92 | @: @Html.AttributeNullable("data-griddly-url", !simple ? Url.Current() : null)
|
52 | 93 | @: data-griddly-count="@Model.Total"
|
| 94 | + @: @Html.AttributeNullable("data-griddly-filtermode", settings.InitialFilterMode != FilterMode.None ? settings.InitialFilterMode.ToString() : null) |
| 95 | + @: @Html.AttributeNullable("data-griddly-allowedfiltermodes", settings.AllowedFilterModes != FilterMode.None ? Json.Encode(Enum.GetValues(typeof(FilterMode)).Cast<FilterMode>().Where(x => settings.AllowedFilterModes.Value.HasFlag(x) && x != FilterMode.Both && x != FilterMode.None).Select(x => x.ToString())) : null) |
53 | 96 | @: data-griddly-pagesize="@(settings.PageSize ?? Model.PageSize)"
|
54 | 97 | @: @Html.AttributeNullable("data-griddly-rowclickmodal", settings.RowClickModal)
|
55 | 98 | @: data-griddly-defaultrowids="@Json.Encode(settings.DefaultRowIds != null ? settings.DefaultRowIds.Select(x => x.ToLower()).ToArray() : new[] { "value" })"
|
|
82 | 125 | <td colspan="@settings.Columns.Count">@settings.Title</td>
|
83 | 126 | </tr>
|
84 | 127 | }
|
85 |
| - <tr class="griddly-filters" style="@(settings.FilterTemplate == null || !settings.ShowFilterInitially ? "display:none" : null)"> |
| 128 | + @if (settings.AllowedFilterModes != FilterMode.None && settings.AllowedFilterModes.Value.HasFlag(FilterMode.Form)) |
| 129 | + { |
| 130 | + <tr class="griddly-filters griddly-filters-form" style="@(settings.InitialFilterMode == FilterMode.Form ? null : "display:none")"> |
86 | 131 | <td colspan="@settings.Columns.Count">
|
87 | 132 | <form class="filterForm novalidate">
|
88 | 133 | @if (settings.FilterTemplate != null)
|
|
97 | 142 | </form>
|
98 | 143 | </td>
|
99 | 144 | </tr>
|
| 145 | + } |
100 | 146 | <tr class="columnHeaders">
|
101 | 147 | @foreach (GriddlyColumn column in settings.Columns)
|
102 | 148 | {
|
|
117 | 163 | </th>
|
118 | 164 | }
|
119 | 165 | </tr>
|
120 |
| - @if (settings.InlineFilterTemplate != null && settings.HasInlineFilter) |
| 166 | + @if (settings.AllowedFilterModes != FilterMode.None && settings.AllowedFilterModes.Value.HasFlag(FilterMode.Inline)) |
121 | 167 | {
|
122 |
| - <tr class="griddly-filters griddly-filters-inline">@settings.InlineFilterTemplate(settings)</tr> |
| 168 | + <tr class="griddly-filters griddly-filters-inline" style="@(settings.InitialFilterMode == FilterMode.Inline ? null : "display:none")">@settings.InlineFilterTemplate(settings)</tr> |
123 | 169 | }
|
124 | 170 | @if (settings.ShowRowSelectCount)
|
125 | 171 | {
|
|
0 commit comments