/**
* Copyright (C) 2005-2016 Alfresco Software Limited.
*
* This file is part of Alfresco
*
* Alfresco is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Alfresco is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
*/
/**
* This is a simple layout structure that allows for a title and description to be specified as properties and for the
* configured widgets to be placed underneath.
*
* @module alfresco/layout/TitleDescriptionAndContent
* @extends external:dijit/_WidgetBase
* @mixes external:dojo/_TemplatedMixin
* @mixes module:alfresco/core/Core
* @mixes module:alfresco/core/CoreWidgetProcessing
* @author Dave Draper
*/
define(["dojo/_base/declare",
"dijit/_WidgetBase",
"dijit/_TemplatedMixin",
"dojo/text!./templates/TitleDescriptionAndContent.html",
"alfresco/core/Core",
"alfresco/core/CoreWidgetProcessing",
"dojo/_base/lang"],
function(declare, _WidgetBase, _TemplatedMixin, template, AlfCore, CoreWidgetProcessing, lang) {
return declare([_WidgetBase, _TemplatedMixin, AlfCore, CoreWidgetProcessing], {
/**
* An array of the CSS files to use with this widget.
*
* @instance
* @type {object[]}
* @default [{cssFile:"./css/TitleDescriptionAndContent"}]
*/
cssRequirements: [{cssFile:"./css/TitleDescriptionAndContent.css"}],
/**
* The HTML template to use for the widget.
* @instance
* @type {string}
*/
templateString: template,
/**
* The title to be rendered
*
* @instance
* @type {string}
* @default
*/
title: "",
/**
* The description to be rendered.
*
* @instance
* @type {string}
* @default
*/
description: "",
/**
* This is the property that is used to uniquely identify the item that this widget is being used
* to provide a title for. It is used to ensure that the any publications made on the
* [subscriptionTopic]{@link module:alfresco/layout/TitleDescriptionAndContent#subscriptionTopic}
* relate to the current instance.
*
* @instance
* @type {string}
* @default
* @since 1.0.85
*/
itemKeyProperty: "nodeRef",
/**
* A topic to subscribe to that when published can update the title and description shown.
*
* @instance
* @type {string}
* @default
* @since 1.0.85
*/
subscriptionTopic: null,
/**
* Indicates whether the [subscriptionTopic]{@link module:alfresco/layout/TitleDescriptionAndContent#subscriptionTopic}
* should be subscribed to globally.
*
* @instance
* @type {boolean}
* @default
* @since 1.0.85
*/
subscribeGlobal: false,
/**
* Ensures that the title and description are converted from key to localised message.
*
* @instance
*/
postMixInProperties: function alfresco_layout_TitleDescriptionAndContent__postMixInProperties() {
if (this.title !== "")
{
this.title = this.message(this.title);
}
if (this.description !== "")
{
this.description = this.message(this.description);
}
},
/**
* Processes the widgets into the content node.
*
* @instance
*/
postCreate: function alfresco_layout_TitleDescriptionAndContent__postCreate() {
/*jshint eqnull:true*/
this.alfSubscribe(this.subscriptionTopic, lang.hitch(this, this.update), this.subscribeGlobal);
if (this.widgets != null)
{
this.processWidgets(this.widgets, this.contentNode);
}
},
/**
*
* @instance
* @param {object} payload The payload containing the details to update
*/
update: function alfresco_layout_TitleDescriptionAndContent__update(payload) {
if (this.itemKeyProperty && this.currentItem)
{
var itemKey = lang.getObject(this.itemKeyProperty, false, this.currentItem);
var payloadKey = lang.getObject(this.itemKeyProperty, false, payload);
if (itemKey && itemKey === payloadKey)
{
this.setTitleAndDescription(payload.title, payload.description);
}
}
else
{
this.setTitleAndDescription(payload.title, payload.description);
}
},
/**
* Updates the title and description
*
* @instance
* @param {string} title The title to set
* @param {string} description The description to set
* @since 1.0.85
*/
setTitleAndDescription: function alfresco_layout_TitleDescriptionAndContent__setTitleAndDescription(title, description) {
if (title)
{
this.titleNode.textContent = title;
}
if (description)
{
this.descriptionNode.textContent = description;
}
}
});
});