MVC Display Templates
A display template describes how a (in this case) Episerver property should be rendered on a web page.
From ImageVault.EPiServer.UI version 4.9.7, we include display templates for both MediaReference
and MediaReferenceList<MediaReference>
.
Usage
To use the display template, just use the @Html.PropertyFor as usual
@using EPiServer.Web.Mvc.Html
@model MyBlockType
<div>
@Html.PropertyFor(m => m.MyMedia)
</div>
<div>
@Html.PropertyFor(m => m.MyMediaList)
</div>
Setting attributes
Since ImageVault.EPiServer.UI version 5.0.21 we also support setting some attributes (class, alt, title) on the resulting html tag for the media item.
Attributes for video text tracks
In the case a video player is rendered, you can control the initial text track of the video by supplying either ActiveTextTrackLanguage = "xx"
to set a specific text language or ShowSubtitles = true
to show a text track matching the Epi content language.
For example, setting ActiveTextTrackLanguage = "en"
will show a subtitle in English (if available). Setting ShowSubtitles = true
for an Epi site with content language Swedish will show Swedish subtitles (if available).
The user can still switch to any another language or disable the text using the video player settings.
MediaReference
To set the attributes on a MediaReference item, just pass them along as additional view data.
@using EPiServer.Web.Mvc.Html
@model MyBlockType
<div>
@Html.PropertyFor(m => m.MyMedia, new { @class = "img_single", alt = "My alt", title = "My title", ShowSubtitles = true })
</div>
MediaReferenceList<MediaReference>
Since the media reference list contains a list of items, we need to create a list of attributes to set for each individual item. This list is passed along as additional view data using the AttributeList property.
@using EPiServer.Web.Mvc.Html
@model MyBlockType
<div>
@{
var list = new List<Dictionary<string, string>>();
if (Model.MyMediaList != null) {
for (var i = 0; i < Model.MyMediaList.Count; i++) {
var media = Model.MyMediaList[i];
var d = new Dictionary<string, string>();
list.Add(d);
d.Add("class", "img_item_" + i);
d.Add("alt", "Id:" + media.Id);
d.Add("title", "My title");
}
}
}
@Html.PropertyFor(m => m.MyMediaList, new { AttributeList = list })
</div>
Customizing own MVC templates
If you would like to customize the appearance of an ImageVault property, you can start by checking out the examples below or check the ones supplied with the ImageVault.EPiServer.UI package (located at modules/_protected/ImageVault.EPiServer.UI/views/Shared/DisplayTemplates after installing the nuget package in your Episerver site).
PropertyMedia
The PropertyMedia type uses a model of type MediaReference. To create a display template for this model, create a display template in the folder /Views/Shared/DisplayTemplates/ and name it MediaReference.cshtml
@model MediaReference
@using EPiServer.Editor
@using ImageVault.Client
@using ImageVault.Common.Data
@using ImageVault.EPiServer
@{
var client = ImageVaultClient.GetPageClient();
var item = client.Load<WebMedia>(Model, ViewContext).FirstOrDefault();
}
@if (item != null) {
@Html.Raw(item.Html)
} else if (PageEditing.PageIsInEditMode) {
<div class="ivEmptyActions" style="padding-top: 150px; background-color: #fff; text-align: center; width: 100%; display: inline-block; background-position: 50% 30px; background-repeat: no-repeat; background-image: url();">
<p style="font-weight: bold;">Drag your ImageVault media here.</p>
</div>
}
The template will load the selected image and if any property settings is set for the property, use them as well. If no item was found and the page is in edit mode, a placeholder image will be placed there. The result will be cached if the Client cache is not disabled.
Note
Since version 5.3, the ImageVaultClient.GetPageClient method will return the correct client (internal/published) depending on the status of the page. The Load method that takes the ViewContext as parameter will in addition to adding editorial and property settings, also track the usage of the asset on the current page, if the current page is published.
PropertyMediaList
The PropertyMediaList type uses a model of type MediaReferenceList<MediaReference>
. To create a display template for this model,
create a display template in the folder /Views/Shared/DisplayTemplates/ and name it MediaReferenceList`1.cshtml
@model MediaReferenceList<MediaReference>
@using EPiServer.Editor
@using ImageVault.Client
@using ImageVault.Common.Data
@using ImageVault.EPiServer
@{
var client = ImageVaultClient.GetPageClient();
var items = client.Load<WebMedia>(Model, ViewContext).ToList();
}
@if (items.Count != 0) {
foreach (var media in items) {
@Html.Raw(media.Html)
}
} else if (PageEditing.PageIsInEditMode) {
<div class="ivEmptyActions" style="padding-top: 150px; background-color: #fff; text-align: center; width: 100%; display: inline-block; background-position: 50% 30px; background-repeat: no-repeat; background-image: url();">
<p style="font-weight: bold;">Add ImageVault media on the property page.</p>
</div>
}
The template will load the selected images and if any property settings is set for the property, use them as well. If no items was found and the page is in edit mode, a placeholder image will be placed there. The result will be cached if the Client cache is not disabled.
Note
Since version 5.3, the ImageVaultClient.GetPageClient method will return the correct client (internal/published) depending on the status of the page. The Load method that takes the ViewContext as parameter will in addition to adding editorial and property settings, also track the usage of the assets on the current page, if the current page is published.
Typed templates
If you would like to use the declarative model in your template you can do so by supplying the Type of the data you would like to retrieve.
Effects on media formats
Effects can be specified in different ways in the ImageVault.EPiServer plugin.
- Editorial effects: added by the cms editor when editing the property on the page. These effects are added using the ImageVault editor.
- Settings effects: effects that are applied using PropertyMediaSettings, either by decorating the property in code using the PropertySettingsAttribute or in CMS admin directly on the property.
- Declarative effects: effects that are applied on properties in the declarative model.
Declarative effects
When you add a property that should refer to a media (original or a conversion) you declare it as one of the supported Media types. The following types are supported:
- Media; refers to the original media. Can not apply any effects to this type. If you try to add declarative effects on a Media type you will get runtime errors.
- WebMedia; refers to a conversion of the original media (can be the same as the original if no effects are applied). If possible, the original content type is kept.
- Image; refers to a image conversion of the original media (if possible). Is a subclass of WebMedia so it follows the same rules as WebMedia.
- Video; refers to a video conversion of the original media (if possible). Is a subclass of WebMedia so it follows the same rules as WebMedia.
If a property defines a conversion that is not supported (ie. no registered converter is supporting), the property value will be null.
Omitting effects
Normally all available effects (editorial, settings, declarative) for a property is used (if possible) in that order. If you would like to skip effects from some of the layers, then use the IgnoreEffectsAttribute and supply any combination of the available EffectTypes.
Example
public class GalleryMedia : MediaItem {
public Media Original { get; set; }
public WebMedia Media { get; set; }
[ResizeEffect(Width = 300, Height = 300, ResizeMode = ResizeMode.ScaleToFill)]
[IgnoreEffects(EffectTypes.SettingsEffects)]
public Image Thumbnail { get; set; }
[ResizeEffect(Width = 800, Height = 0)]
[IgnoreEffects(EffectTypes.SettingsEffects | EffectTypes.EditorialEffects)]
public WebMedia Preview { get; set; }
}
The code above exemplifies the different aspects on what you can do with the different formats and effects.
Original; since this property declares a Media type, this will always give a link to the original media.
Media; since this property is declared as WebMedia, this format can utilize effects. No declarative effects are used but both editorial and settings effects will be applied.
Thumbnail; This property will return a Image conversion that first applies any editorial effects (ignoring settings effects using the IgnoreEffectsAttribute) and then resizes the image to a 300x300 auto cropped image.
Preview; will return a WebMedia of a width of 800px (keeping aspect ratio). Neither editorial or settings effects will be utilized.
Display template for typed model
To utilize the declarative model in a display template, just create a display template and place it under /views/shared/displaytemplates
and name it to some cool name (like GalleryList.cshtml)
@model MediaReferenceList<MediaReference>
@using EPiServer.Editor
@using ImageVault.Client
@using ImageVault.Common.Data
@using ImageVault.EPiServer
@{
var client = ClientFactory.GetSdkClient();
var items = client.Load<GalleryMedia>(Model, ViewContext.GetSettings<PropertyMediaSettings>()).ToList();
}
@if (items.Count != 0) {
foreach (var item in items) {
<img src="@item.Thumbnail.Url" width="@item.Thumbnail.Width" height="@item.Thumbnail.Height"
onclick="javascript:window.location = '@item.Preview.Url'" />
}
} else if (PageEditing.PageIsInEditMode) {
<div class="ivEmptyActions" style="padding-top: 150px; background-color: #fff; text-align: center; width: 100%; display: inline-block; background-position: 50% 30px; background-repeat: no-repeat; background-image: url();">
<p style="font-weight: bold;">Add ImageVault media on the property page.</p>
</div>
}
This template displays the thumbnail image and when the thumbnail is clicked, the preview image is displayed in the browser.
UIHint
To use this template in the ContentModel you need to supply a UIHint that refers to your display template. This can be done on the page/block view when using PropertyFor.
<div>
<h3>Media</h3>
@Html.PropertyFor(m => m.Images,"GalleryList")
</div>
You can also specify it using a UIHint attribute directly on the property of the content model.
[ContentType(GUID = "2F509C22-AC6E-4014-832D-08037BF387B9")]
public class GalleryPage : PageData {
[UIHint("GalleryList",PresentationLayer.Website)]
[Display(GroupName = SystemTabNames.Content, Order = 100)]
[BackingType(typeof(PropertyMediaList))]
public virtual MediaReferenceList<MediaReference> Images { get; set; }
}