@cesium/widgets
Version:
A widgets library for use with CesiumJS. CesiumJS is a JavaScript library for creating 3D globes and 2D maps in a web browser without a plugin.
79 lines (68 loc) • 2.61 kB
JavaScript
const svgNS = "http://www.w3.org/2000/svg";
const svgClassName = "cesium-svgPath-svg";
/**
* A Knockout binding handler that creates a DOM element for a single SVG path.
* This binding handler will be registered as cesiumSvgPath.
*
* <p>
* The parameter to this binding is an object with the following properties:
* </p>
*
* <ul>
* <li>path: The SVG path as a string.</li>
* <li>width: The width of the SVG path with no transformations applied.</li>
* <li>height: The height of the SVG path with no transformations applied.</li>
* <li>css: Optional. A string containing additional CSS classes to apply to the SVG. 'cesium-svgPath-svg' is always applied.</li>
* </ul>
*
* @namespace SvgPathBindingHandler
*
* @example
* // Create an SVG as a child of a div
* <div data-bind="cesiumSvgPath: { path: 'M 100 100 L 300 100 L 200 300 z', width: 28, height: 28 }"></div>
*
* // parameters can be observable from the view model
* <div data-bind="cesiumSvgPath: { path: currentPath, width: currentWidth, height: currentHeight }"></div>
*
* // or the whole object can be observable from the view model
* <div data-bind="cesiumSvgPath: svgPathOptions"></div>
*/
const SvgPathBindingHandler = {
/**
* @function
*/
register: function (knockout) {
knockout.bindingHandlers.cesiumSvgPath = {
init: function (element, valueAccessor) {
const svg = document.createElementNS(svgNS, "svg:svg");
svg.setAttribute("class", svgClassName);
const pathElement = document.createElementNS(svgNS, "path");
svg.appendChild(pathElement);
knockout.virtualElements.setDomNodeChildren(element, [svg]);
knockout.computed({
read: function () {
const value = knockout.unwrap(valueAccessor());
pathElement.setAttribute("d", knockout.unwrap(value.path));
const pathWidth = knockout.unwrap(value.width);
const pathHeight = knockout.unwrap(value.height);
svg.setAttribute("width", pathWidth);
svg.setAttribute("height", pathHeight);
svg.setAttribute("viewBox", `0 0 ${pathWidth} ${pathHeight}`);
if (value.css) {
svg.setAttribute(
"class",
`${svgClassName} ${knockout.unwrap(value.css)}`,
);
}
},
disposeWhenNodeIsRemoved: element,
});
return {
controlsDescendantBindings: true,
};
},
};
knockout.virtualElements.allowedBindings.cesiumSvgPath = true;
},
};
export default SvgPathBindingHandler;