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