Skip to content

Commit

Permalink
Fix #9653 embedded icons are correctly loaded (#9660)
Browse files Browse the repository at this point in the history
  • Loading branch information
MV88 authored Nov 27, 2023
1 parent a5c87ed commit 69b29cf
Show file tree
Hide file tree
Showing 9 changed files with 50 additions and 385 deletions.
10 changes: 10 additions & 0 deletions docs/developer-guide/mapstore-migration-guide.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,16 @@ This is a list of things to check if you want to update from a previous version

## Migration from 2023.02.xx to 2024.01.00

### Removing possibility to add custom fonts to the Map

From this version we limited the load of the font to FontAwesome.

If you have changed the property **fonts** inside Map plugin it will not longer load the font. A possible fix would be to add the font to the `*.html` files in your application.

- make sure that the `localConfig.json` does not have **fonts** property in **Map** plugin

The following css is added automatically if needed `<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css"/>` inside the *head* tag.

### Fixing background config

From this version in order to fix default 3d background config a change is needed here:
Expand Down
1 change: 0 additions & 1 deletion project/standard/templates/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,6 @@
</style>
<link rel="preconnect" href="https://fonts.gstatic.com">
<link href="https://fonts.googleapis.com/css2?family=Noto+Sans&display=swap" rel="stylesheet">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css" />
<link rel="shortcut icon" type="image/png" href="https://cdn.jslibs.mapstore2.geo-solutions.it/leaflet/favicon.ico" />
<!--script src="https://maps.google.com/maps/api/js?v=3"></script-->
<!--script src="https://cdnjs.cloudflare.com/ajax/libs/proj4js/2.3.10/proj4.js"></script-->
Expand Down
1 change: 0 additions & 1 deletion project/standard/templates/indexTemplate.html
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,6 @@
</style>
<link rel="preconnect" href="https://fonts.gstatic.com">
<link href="https://fonts.googleapis.com/css2?family=Noto+Sans&display=swap" rel="stylesheet">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css" />
<link rel="shortcut icon" type="image/png" href="https://cdn.jslibs.mapstore2.geo-solutions.it/leaflet/favicon.ico" />
<!--script src="https://maps.google.com/maps/api/js?v=3"></script-->
<script async type="text/javascript" src="https://unpkg.com/[email protected]/es5.js" onload="checkBrowser()"></script>
Expand Down
1 change: 0 additions & 1 deletion web/client/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,6 @@
</style>
<link rel="preconnect" href="https://fonts.gstatic.com">
<link href="https://fonts.googleapis.com/css2?family=Noto+Sans&display=swap" rel="stylesheet">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css" />
<link rel="shortcut icon" type="image/png" href="https://cdn.jslibs.mapstore2.geo-solutions.it/leaflet/favicon.ico" />
<!--script src="https://maps.google.com/maps/api/js?v=3"></script-->
<!--script src="https://cdnjs.cloudflare.com/ajax/libs/proj4js/2.3.10/proj4.js"></script-->
Expand Down
1 change: 0 additions & 1 deletion web/client/indexTemplate.html
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,6 @@
</style>
<link rel="preconnect" href="https://fonts.gstatic.com">
<link href="https://fonts.googleapis.com/css2?family=Noto+Sans&display=swap" rel="stylesheet">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css" />
<link rel="shortcut icon" type="image/png" href="https://cdn.jslibs.mapstore2.geo-solutions.it/leaflet/favicon.ico" />
<!--script src="https://maps.google.com/maps/api/js?v=3"></script-->
<script async type="text/javascript" src="https://unpkg.com/[email protected]/es5.js" onload="checkBrowser()"></script>
Expand Down
43 changes: 3 additions & 40 deletions web/client/plugins/Map.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@
import PropTypes from 'prop-types';
import React from 'react';
import { connect, createPlugin } from '../utils/PluginsUtils';
import { loadFont } from '../utils/AgentUtils';
import Spinner from 'react-spinkit';
import './map/css/map.css';
import Message from '../components/I18N/Message';
Expand Down Expand Up @@ -108,8 +107,6 @@ import {getHighlightLayerOptions} from "../utils/HighlightUtils";
* {
* "name": "Map",
* "cfg": {
* "shouldLoadFont": true,
* "fonts": ['FontAwesome'],
* "tools": ["overview", "scalebar", "draw", {
* "leaflet": {
* "name": "test",
Expand All @@ -128,20 +125,8 @@ import {getHighlightLayerOptions} from "../utils/HighlightUtils";
* - name is a unique name for the tool
* - impl is a placeholder (“{context.ToolName}”) where ToolName is the name you gave the tool in plugins.js (TestSupportLeaflet in our example)
*
* You can also specify a list of fonts that have to be loaded before map rendering
* if the shouldLoadFont is true
* This font pre-load list is required if you're using canvas based mapping libraries (e.g. OpenLayers) and you need to show markers with symbols (e.g. Annotations).
* For each font you must specify the font name used in the `@font-face` inside the "fonts" array property. Note: the `@font-face` declaration must be present in css of the page, otherwise the font can not be loaded anyway.
* ```
* {
* "name": "Map",
* "cfg": {
* "shouldLoadFont": true,
* "fonts": ['FontAwesome']
* }
* }
* ```
* For more info on metadata visit [fontfaceobserver](https://github.com/bramstein/fontfaceobserver)
* You can no longer specify a list of fonts that have to be loaded before map rendering, we are now only loading FontAwesome for the icons
* We will pre-load FontAwesome only if needed, i.e you need to show markers with symbols (e.g. Annotations).
*
* An additional feature to is limit the area and/or the minimum level of zoom in the localConfig.json file using "mapConstraints" property
*
Expand Down Expand Up @@ -210,7 +195,6 @@ class MapPlugin extends React.Component {
loadingSpinner: PropTypes.bool,
loadingError: PropTypes.string,
tools: PropTypes.array,
fonts: PropTypes.array,
options: PropTypes.object,
mapOptions: PropTypes.object,
projectionDefs: PropTypes.array,
Expand All @@ -219,7 +203,6 @@ class MapPlugin extends React.Component {
actions: PropTypes.object,
features: PropTypes.array,
securityToken: PropTypes.string,
shouldLoadFont: PropTypes.bool,
elevationEnabled: PropTypes.bool,
isLocalizedLayerStylesEnabled: PropTypes.bool,
localizedLayerStylesName: PropTypes.string,
Expand All @@ -239,7 +222,6 @@ class MapPlugin extends React.Component {
tools: ["scalebar", "draw", "highlight", "popup", "box"],
options: {},
mapOptions: {},
fonts: ['FontAwesome'],
toolsOptions: {
measurement: {},
locate: {},
Expand All @@ -261,7 +243,6 @@ class MapPlugin extends React.Component {
},
securityToken: '',
additionalLayers: [],
shouldLoadFont: false,
elevationEnabled: false,
onResolutionsChange: () => {},
items: [],
Expand All @@ -274,25 +255,7 @@ class MapPlugin extends React.Component {
};

UNSAFE_componentWillMount() {
const {shouldLoadFont, fonts} = this.props;

// load each font before rendering (see issue #3155)
if (shouldLoadFont && fonts) {
this.setState({canRender: false});

Promise.all(
fonts.map(f =>
loadFont(f, {
timeoutAfter: 5000 // 5 seconds in milliseconds
}).catch((error) => {
console.warn("Fonts loading check for map style responded slowly or with an error. Fonts in map may not be rendered correctly. This is not necessarily an issue.", error); // eslint-disable-line no-console
}
))
).then(() => {
this.setState({canRender: true});
});

}
// moved the font load of FontAwesome only to styleParseUtils (#9653)
this.updatePlugins(this.props);
this._isMounted = true;
}
Expand Down
6 changes: 2 additions & 4 deletions web/client/plugins/map/selector.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { mapSelector, projectionDefsSelector, isMouseMoveCoordinatesActiveSelector } from '../../selectors/map';
import { mapTypeSelector, isOpenlayers } from '../../selectors/maptype';
import { mapTypeSelector } from '../../selectors/maptype';
import { layerSelectorWithMarkers } from '../../selectors/layers';
import { highlighedFeatures } from '../../selectors/highlight';
import { securityTokenSelector } from '../../selectors/security';
Expand All @@ -21,11 +21,10 @@ export default createShallowSelectorCreator(isEqual)(
state => state.mapInitialConfig && state.mapInitialConfig.loadingError && state.mapInitialConfig.loadingError.data,
securityTokenSelector,
isMouseMoveCoordinatesActiveSelector,
isOpenlayers,
isLocalizedLayerStylesEnabledSelector,
localizedLayerStylesNameSelector,
currentLocaleLanguageSelector,
(projectionDefs, map, mapType, layers, features, loadingError, securityToken, elevationEnabled, shouldLoadFont, isLocalizedLayerStylesEnabled, localizedLayerStylesName, currentLocaleLanguage) => ({
(projectionDefs, map, mapType, layers, features, loadingError, securityToken, elevationEnabled, isLocalizedLayerStylesEnabled, localizedLayerStylesName, currentLocaleLanguage) => ({
projectionDefs,
map,
mapType,
Expand All @@ -34,7 +33,6 @@ export default createShallowSelectorCreator(isEqual)(
loadingError,
securityToken,
elevationEnabled,
shouldLoadFont,
isLocalizedLayerStylesEnabled,
localizedLayerStylesName,
currentLocaleLanguage
Expand Down
Loading

0 comments on commit 69b29cf

Please sign in to comment.