devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
138 lines (137 loc) • 5.05 kB
JavaScript
/**
* DevExtreme (esm/core/utils/template_manager.js)
* Version: 23.2.6
* Build date: Wed May 01 2024
*
* Copyright (c) 2012 - 2024 Developer Express Inc. ALL RIGHTS RESERVED
* Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/
*/
import _extends from "@babel/runtime/helpers/esm/extends";
import config from "../config";
import devices from "../devices";
import {
getPublicElement
} from "../element";
import Errors from "../errors";
import $ from "../renderer";
import {
ChildDefaultTemplate
} from "../templates/child_default_template";
import {
EmptyTemplate
} from "../templates/empty_template";
import {
Template
} from "../templates/template";
import {
TemplateBase
} from "../templates/template_base";
import {
groupBy
} from "./array";
import {
findBestMatches
} from "./common";
import {
normalizeTemplateElement
} from "./dom";
import {
extend
} from "./extend";
import {
isFunction,
isRenderer
} from "./type";
export var findTemplates = (element, name) => {
var templates = $(element).contents().filter("[".concat("data-options", '*="').concat(name, '"]'));
return [].slice.call(templates).map(element => {
var optionsString = $(element).attr("data-options") || "";
return {
element: element,
options: config().optionsParser(optionsString)[name]
}
}).filter(template => !!template.options)
};
export var suitableTemplatesByName = rawTemplates => {
var templatesMap = groupBy(rawTemplates, template => template.options.name);
if (templatesMap[void 0]) {
throw Errors.Error("E0023")
}
var result = {};
Object.keys(templatesMap).forEach(name => {
var _findBestMatches$;
var suitableTemplate = null === (_findBestMatches$ = findBestMatches(devices.current(), templatesMap[name], template => template.options)[0]) || void 0 === _findBestMatches$ ? void 0 : _findBestMatches$.element;
if (suitableTemplate) {
result[name] = suitableTemplate
}
});
return result
};
export var addOneRenderedCall = template => {
var render = template.render.bind(template);
return extend({}, template, {
render(options) {
var templateResult = render(options);
options && options.onRendered && options.onRendered();
return templateResult
}
})
};
export var addPublicElementNormalization = template => {
var render = template.render.bind(template);
return extend({}, template, {
render(options) {
var $container = $(options.container);
return render(_extends({}, options, {
container: getPublicElement($container)
}))
}
})
};
export var getNormalizedTemplateArgs = options => {
var args = [];
if ("model" in options) {
args.push(options.model)
}
if ("index" in options) {
args.push(options.index)
}
args.push(options.container);
return args
};
export var validateTemplateSource = templateSource => "string" === typeof templateSource ? normalizeTemplateElement(templateSource) : templateSource;
export var templateKey = templateSource => isRenderer(templateSource) && templateSource[0] || templateSource;
export var defaultCreateElement = element => new Template(element);
export var acquireIntegrationTemplate = (templateSource, templates, isAsyncTemplate, skipTemplates) => {
var integrationTemplate = null;
if (!skipTemplates || -1 === skipTemplates.indexOf(templateSource)) {
integrationTemplate = templates[templateSource];
if (integrationTemplate && !(integrationTemplate instanceof TemplateBase)) {
if (isFunction(integrationTemplate.render)) {
integrationTemplate = addPublicElementNormalization(integrationTemplate)
}
if (!isAsyncTemplate) {
integrationTemplate = addOneRenderedCall(integrationTemplate)
}
}
}
return integrationTemplate
};
export var acquireTemplate = (templateSource, createTemplate, templates, isAsyncTemplate, skipTemplates, defaultTemplates) => {
if (null == templateSource) {
return new EmptyTemplate
}
if (templateSource instanceof ChildDefaultTemplate) {
return defaultTemplates[templateSource.name]
}
if (templateSource instanceof TemplateBase) {
return templateSource
}
if (isFunction(templateSource.render) && !isRenderer(templateSource)) {
return isAsyncTemplate ? templateSource : addOneRenderedCall(templateSource)
}
if (templateSource.nodeType || isRenderer(templateSource)) {
return createTemplate($(templateSource))
}
return acquireIntegrationTemplate(templateSource, templates, isAsyncTemplate, skipTemplates) || defaultTemplates[templateSource] || createTemplate(templateSource)
};