diff --git a/Source/Assets/Images/bing_maps_credit.png b/Source/Assets/Images/bing_maps_credit.png new file mode 100644 index 000000000000..15109db3cd49 Binary files /dev/null and b/Source/Assets/Images/bing_maps_credit.png differ diff --git a/Source/Assets/Images/cesium_credit.png b/Source/Assets/Images/cesium_credit.png new file mode 100644 index 000000000000..4d1722b6ba90 Binary files /dev/null and b/Source/Assets/Images/cesium_credit.png differ diff --git a/Source/Assets/Images/google_earth_credit.png b/Source/Assets/Images/google_earth_credit.png new file mode 100644 index 000000000000..a7622d822d38 Binary files /dev/null and b/Source/Assets/Images/google_earth_credit.png differ diff --git a/Source/Core/CesiumTerrainProvider.js b/Source/Core/CesiumTerrainProvider.js index 9df474437931..97760891cde1 100644 --- a/Source/Core/CesiumTerrainProvider.js +++ b/Source/Core/CesiumTerrainProvider.js @@ -163,12 +163,11 @@ define([ var uri = new Uri(metadataResource.url); if (uri.authority === 'assets.agi.com') { - var deprecationText = 'The STK World Terrain tileset is deprecated and will be available until September 1, 2018'; + var deprecationText = 'The STK World Terrain tileset is deprecated and will be available until September 1, 2018.'; var deprecationLinkText = 'Check out the new high-resolution Cesium World Terrain'; var deprecationLink = 'https://cesium.com/blog/2018/03/01/introducing-cesium-world-terrain/'; that._tileCredits = [ - new Credit(deprecationText, true), - new Credit('' + deprecationLinkText + '', true) + new Credit('' + deprecationText + ' ' + deprecationLinkText + '', true) ]; deprecationWarning('assets.agi.com', deprecationText + ' ' + deprecationLinkText + ' ' + deprecationLink); } else { diff --git a/Source/Core/Credit.js b/Source/Core/Credit.js index 1dc134a2d278..556d525b35a4 100644 --- a/Source/Core/Credit.js +++ b/Source/Core/Credit.js @@ -21,7 +21,7 @@ define([ var div = document.createElement('span'); div.innerHTML = html; - if (div.children.length === 1) { + if (div.childNodes.length === 1) { return div.removeChild(div.firstChild); } @@ -57,7 +57,7 @@ define([ var key; if (typeof html !== 'string') { var options = defaultValue(html, defaultValue.EMPTY_OBJECT); - deprecationWarning('Credit options', 'The options paramater has been deprecated and will be removed in Cesium 1.46. Instead, pass in an html string (or a string of text)'); + deprecationWarning('Credit options', 'The options parameter has been deprecated and will be removed in Cesium 1.46. Instead, pass in an HTML string (or a string of text)'); showOnScreen = defaultValue(options.showOnScreen, showOnScreen); var text = options.text; var imageUrl = options.imageUrl; @@ -170,7 +170,7 @@ define([ */ imageUrl : { get : function() { - deprecationWarning('Credit.text', 'Credit.text is deprecated and will be removed in Cesium 1.46. Instead, use Credit.html to get the credit content.'); + deprecationWarning('Credit.imageUrl', 'Credit.imageUrl is deprecated and will be removed in Cesium 1.46. Instead, use Credit.html to get the credit content.'); return this._imageUrl; } }, @@ -183,7 +183,7 @@ define([ */ link : { get : function() { - deprecationWarning('Credit.text', 'Credit.text is deprecated and will be removed in Cesium 1.46. Instead, use Credit.html to get the credit content.'); + deprecationWarning('Credit.link', 'Credit.link is deprecated and will be removed in Cesium 1.46. Instead, use Credit.html to get the credit content.'); return this._link; } }, @@ -294,5 +294,8 @@ define([ return credit; }; + // Exposed for testing + Credit._createDomNode = createDomNode; + return Credit; }); diff --git a/Source/Scene/BingMapsImageryProvider.js b/Source/Scene/BingMapsImageryProvider.js index 3cd7567024c1..ef450efe5d6c 100644 --- a/Source/Scene/BingMapsImageryProvider.js +++ b/Source/Scene/BingMapsImageryProvider.js @@ -1,5 +1,6 @@ define([ '../Core/BingMapsApi', + '../Core/buildModuleUrl', '../Core/Cartesian2', '../Core/Credit', '../Core/defaultValue', @@ -20,6 +21,7 @@ define([ './ImageryProvider' ], function( BingMapsApi, + buildModuleUrl, Cartesian2, Credit, defaultValue, @@ -568,7 +570,7 @@ define([ return undefined; }; - BingMapsImageryProvider._logoData = ''; + BingMapsImageryProvider._logoData = buildModuleUrl('Assets/Images/bing_maps_credit.png'); /** * Converts a tiles (x, y, level) position into a quadkey used to request an image diff --git a/Source/Scene/CreditDisplay.js b/Source/Scene/CreditDisplay.js index a332d99d9c41..d513f937f8c6 100644 --- a/Source/Scene/CreditDisplay.js +++ b/Source/Scene/CreditDisplay.js @@ -1,10 +1,12 @@ define([ + '../Core/buildModuleUrl', '../Core/Check', '../Core/Credit', '../Core/defaultValue', '../Core/defined', '../Core/destroyObject' ], function( + buildModuleUrl, Check, Credit, defaultValue, @@ -195,11 +197,11 @@ define([ margin : 'auto' }); - style += addStyle('.cesium-credit-lightbox > ul > li > span > a, .cesium-credit-lightbox > ul > li > span > a:visited', { + style += addStyle('.cesium-credit-lightbox > ul > li > span a, .cesium-credit-lightbox > ul > li > span a:visited', { color: textColor }); - style += addStyle('.cesium-credit-lightbox > ul > li > span > a:hover', { + style += addStyle('.cesium-credit-lightbox > ul > li > span a:hover', { color: highlightColor }); @@ -260,7 +262,7 @@ define([ head.insertBefore(css, head.firstChild); } - var cesiumLogo = ''; + var cesiumLogo = buildModuleUrl('Assets/Images/cesium_credit.png'); var cesiumCredit = new Credit('', true); /** diff --git a/Source/Scene/GoogleEarthEnterpriseMapsProvider.js b/Source/Scene/GoogleEarthEnterpriseMapsProvider.js index 3adcb5b5bde6..3a961721987a 100644 --- a/Source/Scene/GoogleEarthEnterpriseMapsProvider.js +++ b/Source/Scene/GoogleEarthEnterpriseMapsProvider.js @@ -1,4 +1,5 @@ define([ + '../Core/buildModuleUrl', '../Core/Credit', '../Core/defaultValue', '../Core/defined', @@ -15,6 +16,7 @@ define([ '../ThirdParty/when', './ImageryProvider' ], function( + buildModuleUrl, Credit, defaultValue, defined, @@ -603,7 +605,7 @@ define([ return undefined; }; - GoogleEarthEnterpriseMapsProvider._logoData = ''; + GoogleEarthEnterpriseMapsProvider._logoData = buildModuleUrl('Assets/Images/google_earth_credit.png'); return GoogleEarthEnterpriseMapsProvider; }); diff --git a/Source/Scene/MapboxImageryProvider.js b/Source/Scene/MapboxImageryProvider.js index bbca7a95ff6d..037d93b46b5b 100644 --- a/Source/Scene/MapboxImageryProvider.js +++ b/Source/Scene/MapboxImageryProvider.js @@ -21,7 +21,7 @@ define([ 'use strict'; var trailingSlashRegex = /\/$/; - var defaultCredit = new Credit('© Mapbox © OpenStreetMap Improve this map'); + var defaultCredit = new Credit('© Mapbox © OpenStreetMap Improve this map'); /** * Provides tiled imagery hosted by Mapbox. diff --git a/Source/ThirdParty/xss.js b/Source/ThirdParty/xss.js index 89e1e9b8c838..24871d6276b4 100644 --- a/Source/ThirdParty/xss.js +++ b/Source/ThirdParty/xss.js @@ -7,7 +7,6 @@ // Built using: browserify lib/index.js --standalone xss > xss.js // From: git@github.com:leizongmin/js-xss.git tag: v0.3.5 -// Added L174 to whitelist img src data URIs (function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.xss = f()}})(function(){var define,module,exports;return (function(){function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o