Skip to content

Commit cc79bc3

Browse files
committed
fix missing icons in self contained knitr files
point to a http://cdn if protocol is a file. otherwise, let the protocol be used naturally.
1 parent 647d3aa commit cc79bc3

File tree

3 files changed

+55
-17
lines changed

3 files changed

+55
-17
lines changed

inst/htmlwidgets/leaflet.js

Lines changed: 47 additions & 15 deletions
Original file line numberDiff line numberDiff line change
@@ -59,7 +59,7 @@ var ClusterLayerStore = function () {
5959
exports.default = ClusterLayerStore;
6060

6161

62-
},{"./util":14}],2:[function(require,module,exports){
62+
},{"./util":15}],2:[function(require,module,exports){
6363
"use strict";
6464

6565
Object.defineProperty(exports, "__esModule", {
@@ -194,7 +194,7 @@ function getCRS(crsOptions) {
194194
}
195195

196196

197-
},{"./global/leaflet":7,"./global/proj4leaflet":8}],4:[function(require,module,exports){
197+
},{"./global/leaflet":8,"./global/proj4leaflet":9}],4:[function(require,module,exports){
198198
"use strict";
199199

200200
Object.defineProperty(exports, "__esModule", {
@@ -320,7 +320,39 @@ var DataFrame = function () {
320320
exports.default = DataFrame;
321321

322322

323-
},{"./util":14}],5:[function(require,module,exports){
323+
},{"./util":15}],5:[function(require,module,exports){
324+
"use strict";
325+
326+
var _leaflet = require("./global/leaflet");
327+
328+
var _leaflet2 = _interopRequireDefault(_leaflet);
329+
330+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
331+
332+
// In RMarkdown's self-contained mode, we don't have a way to carry around the
333+
// images that Leaflet needs but doesn't load into the page. Instead, we'll set
334+
// data URIs for the default marker, and let any others be loaded via CDN.
335+
if (typeof _leaflet2.default.Icon.Default.imagePath === "undefined") {
336+
// if in a local file, support http
337+
if (window.location.protocol === "file:") {
338+
_leaflet2.default.Icon.Default.imagePath = "http://cdn.leafletjs.com/leaflet/v1.3.1/images/";
339+
} else {
340+
// otherwise use same protocol
341+
_leaflet2.default.Icon.Default.imagePath = "//cdn.leafletjs.com/leaflet/v1.3.1/images/";
342+
}
343+
// don't know how to make this dataURI work since
344+
// will be appended to Defaul.imagePath above
345+
/*
346+
if (L.Browser.retina) {
347+
L.Icon.Default.prototype.options.iconUrl = "";
348+
} else {
349+
L.Icon.Default.prototype.options.iconUrl = "";
350+
}
351+
*/
352+
}
353+
354+
355+
},{"./global/leaflet":8}],6:[function(require,module,exports){
324356
(function (global){
325357
"use strict";
326358

@@ -331,7 +363,7 @@ exports.default = global.HTMLWidgets;
331363

332364

333365
}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
334-
},{}],6:[function(require,module,exports){
366+
},{}],7:[function(require,module,exports){
335367
(function (global){
336368
"use strict";
337369

@@ -342,7 +374,7 @@ exports.default = global.jQuery;
342374

343375

344376
}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
345-
},{}],7:[function(require,module,exports){
377+
},{}],8:[function(require,module,exports){
346378
(function (global){
347379
"use strict";
348380

@@ -353,7 +385,7 @@ exports.default = global.L;
353385

354386

355387
}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
356-
},{}],8:[function(require,module,exports){
388+
},{}],9:[function(require,module,exports){
357389
(function (global){
358390
"use strict";
359391

@@ -364,7 +396,7 @@ exports.default = global.L.Proj;
364396

365397

366398
}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
367-
},{}],9:[function(require,module,exports){
399+
},{}],10:[function(require,module,exports){
368400
(function (global){
369401
"use strict";
370402

@@ -375,7 +407,7 @@ exports.default = global.Shiny;
375407

376408

377409
}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
378-
},{}],10:[function(require,module,exports){
410+
},{}],11:[function(require,module,exports){
379411
"use strict";
380412

381413
var _jquery = require("./global/jquery");
@@ -410,6 +442,8 @@ var _methods = require("./methods");
410442

411443
var _methods2 = _interopRequireDefault(_methods);
412444

445+
require("./fixup-default-icon");
446+
413447
var _dataframe = require("./dataframe");
414448

415449
var _dataframe2 = _interopRequireDefault(_dataframe);
@@ -420,8 +454,6 @@ var _clusterLayerStore2 = _interopRequireDefault(_clusterLayerStore);
420454

421455
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
422456

423-
// import "./fixup-default-icon";
424-
425457
window.LeafletWidget = {};
426458
window.LeafletWidget.utils = {};
427459
var methods = window.LeafletWidget.methods = _jquery2.default.extend({}, _methods2.default);
@@ -693,7 +725,7 @@ if (_htmlwidgets2.default.shinyMode) {
693725
}
694726

695727

696-
},{"./cluster-layer-store":1,"./control-store":2,"./crs_utils":3,"./dataframe":4,"./global/htmlwidgets":5,"./global/jquery":6,"./global/leaflet":7,"./global/shiny":9,"./layer-manager":11,"./methods":12,"./util":14}],11:[function(require,module,exports){
728+
},{"./cluster-layer-store":1,"./control-store":2,"./crs_utils":3,"./dataframe":4,"./fixup-default-icon":5,"./global/htmlwidgets":6,"./global/jquery":7,"./global/leaflet":8,"./global/shiny":10,"./layer-manager":12,"./methods":13,"./util":15}],12:[function(require,module,exports){
697729
(function (global){
698730
"use strict";
699731

@@ -1118,7 +1150,7 @@ exports.default = LayerManager;
11181150

11191151

11201152
}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
1121-
},{"./global/jquery":6,"./global/leaflet":7,"./util":14}],12:[function(require,module,exports){
1153+
},{"./global/jquery":7,"./global/leaflet":8,"./util":15}],13:[function(require,module,exports){
11221154
(function (global){
11231155
"use strict";
11241156

@@ -2400,7 +2432,7 @@ methods.removeSelect = function () {
24002432

24012433

24022434
}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {})
2403-
},{"./cluster-layer-store":1,"./crs_utils":3,"./dataframe":4,"./global/htmlwidgets":5,"./global/jquery":6,"./global/leaflet":7,"./global/shiny":9,"./mipmapper":13,"./util":14}],13:[function(require,module,exports){
2435+
},{"./cluster-layer-store":1,"./crs_utils":3,"./dataframe":4,"./global/htmlwidgets":6,"./global/jquery":7,"./global/leaflet":8,"./global/shiny":10,"./mipmapper":14,"./util":15}],14:[function(require,module,exports){
24042436
"use strict";
24052437

24062438
Object.defineProperty(exports, "__esModule", {
@@ -2507,7 +2539,7 @@ var Mipmapper = function () {
25072539
exports.default = Mipmapper;
25082540

25092541

2510-
},{}],14:[function(require,module,exports){
2542+
},{}],15:[function(require,module,exports){
25112543
"use strict";
25122544

25132545
Object.defineProperty(exports, "__esModule", {
@@ -2549,4 +2581,4 @@ function asArray(value) {
25492581
}
25502582

25512583

2552-
},{}]},{},[10]);
2584+
},{}]},{},[11]);

javascript/src/fixup-default-icon.js

Lines changed: 7 additions & 1 deletion
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

javascript/src/index.js

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -11,7 +11,7 @@ import LayerManager from "./layer-manager";
1111

1212
import defaultMethods from "./methods";
1313

14-
// import "./fixup-default-icon";
14+
import "./fixup-default-icon";
1515

1616
import DataFrame from "./dataframe";
1717
import ClusterLayerStore from "./cluster-layer-store";

0 commit comments

Comments
 (0)