12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 |
- /*global define*/
- define(function() {
- "use strict";
- var svgNS = 'http://www.w3.org/2000/svg';
- var 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
- * @alias 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>
- */
- var SvgPathBindingHandler = {
- register : function(knockout) {
- knockout.bindingHandlers.cesiumSvgPath = {
- init : function(element, valueAccessor) {
- var svg = document.createElementNS(svgNS, 'svg:svg');
- svg.setAttribute('class', svgClassName);
- var pathElement = document.createElementNS(svgNS, 'path');
- svg.appendChild(pathElement);
- knockout.virtualElements.setDomNodeChildren(element, [svg]);
- knockout.computed({
- read : function() {
- var value = knockout.unwrap(valueAccessor());
- pathElement.setAttribute('d', knockout.unwrap(value.path));
- var pathWidth = knockout.unwrap(value.width);
- var 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;
- }
- };
- return SvgPathBindingHandler;
- });
|