2014-11-22 17:29:41 +00:00
|
|
|
/*global define,Promise*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Module defining MCTInclude. Created by vwoeltje on 11/7/14.
|
|
|
|
*/
|
|
|
|
define(
|
|
|
|
[],
|
|
|
|
function () {
|
|
|
|
"use strict";
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Defines the mct-include directive. This acts like the
|
|
|
|
* ng-include directive, except it accepts a symbolic
|
2014-11-22 21:02:51 +00:00
|
|
|
* key which can be exposed by bundles, instead of requiring
|
|
|
|
* an explicit path.
|
|
|
|
*
|
|
|
|
* This directive uses two-way binding for three attributes:
|
|
|
|
*
|
|
|
|
* * `key`, matched against the key of a defined template extension
|
|
|
|
* in order to determine which actual template to include.
|
|
|
|
* * `ng-model`, populated as `ngModel` in the loaded template's
|
|
|
|
* scope; used for normal ng-model purposes (e.g. if the
|
|
|
|
* included template is meant to two-way bind to a data model.)
|
|
|
|
* * `parameters`, used to communicate display parameters to
|
|
|
|
* the included template (e.g. title.) The difference between
|
|
|
|
* `parameters` and `ngModel` is intent: Both are two-way
|
|
|
|
* bound, but `ngModel` is useful for data models (more like
|
|
|
|
* an output) and `parameters` is meant to be useful for
|
|
|
|
* display parameterization (more like an input.)
|
|
|
|
*
|
2014-11-22 17:29:41 +00:00
|
|
|
* @constructor
|
2014-11-22 21:02:51 +00:00
|
|
|
* @param {TemplateDefinition[]} templates an array of
|
|
|
|
* template extensions
|
2014-11-22 17:29:41 +00:00
|
|
|
*/
|
|
|
|
function MCTInclude(templates) {
|
|
|
|
var templateMap = {};
|
|
|
|
|
2014-11-22 21:02:51 +00:00
|
|
|
// Prepopulate templateMap for easy look up by key
|
2014-11-22 17:29:41 +00:00
|
|
|
templates.forEach(function (template) {
|
2015-01-14 18:51:38 +00:00
|
|
|
var key = template.key,
|
|
|
|
path = [
|
|
|
|
template.bundle.path,
|
|
|
|
template.bundle.resources,
|
|
|
|
template.templateUrl
|
|
|
|
].join("/");
|
|
|
|
// First found should win (priority ordering)
|
|
|
|
templateMap[key] = templateMap[key] || path;
|
2014-11-22 17:29:41 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
function controller($scope) {
|
2014-11-22 21:02:51 +00:00
|
|
|
// Pass the template URL to ng-include via scope.
|
2014-11-22 17:29:41 +00:00
|
|
|
$scope.inclusion = templateMap[$scope.key];
|
|
|
|
}
|
|
|
|
|
|
|
|
return {
|
2014-11-22 21:02:51 +00:00
|
|
|
// Only show at the element level
|
2014-11-22 17:29:41 +00:00
|
|
|
restrict: "E",
|
2014-11-22 21:02:51 +00:00
|
|
|
|
|
|
|
// Use the included controller to populate scope
|
2014-11-22 17:29:41 +00:00
|
|
|
controller: controller,
|
2014-11-22 21:02:51 +00:00
|
|
|
|
2014-11-23 23:28:46 +00:00
|
|
|
// Use ng-include as a template; "inclusion" will be the real
|
|
|
|
// template path
|
2014-11-22 17:29:41 +00:00
|
|
|
template: '<ng-include src="inclusion"></ng-include>',
|
2014-11-22 21:02:51 +00:00
|
|
|
|
|
|
|
// Two-way bind key, ngModel, and parameters
|
2014-11-22 17:29:41 +00:00
|
|
|
scope: { key: "=", ngModel: "=", parameters: "=" }
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
return MCTInclude;
|
|
|
|
}
|
|
|
|
);
|