From 17412f629b6660deb4f29dedff8b12f86166c4a7 Mon Sep 17 00:00:00 2001 From: Matteo Velludini Date: Wed, 18 Apr 2018 17:48:07 +0200 Subject: [PATCH 1/2] Fix #2803 add popover overlay to the sync tool in feature grid --- .../actions/__tests__/featuregrid-test.js | 14 ++- web/client/actions/featuregrid.js | 14 +++ .../data/featuregrid/enhancers/withHint.js | 11 +++ .../data/featuregrid/enhancers/withPopover.js | 28 ++++++ .../data/featuregrid/enhancers/withTooltip.js | 8 ++ .../data/featuregrid/toolbars/TButton.jsx | 20 ++-- .../data/featuregrid/toolbars/Toolbar.jsx | 99 +++++++++++++------ .../components/misc/enhancers/tooltip.jsx | 1 - .../components/widgets/widget/InfoPopover.jsx | 2 +- web/client/epics/maplayout.js | 3 +- .../plugins/featuregrid/panels/index.jsx | 8 +- .../plugins/featuregrid/toolbarEvents.js | 4 + .../reducers/__tests__/featuregrid-test.js | 14 ++- web/client/reducers/featuregrid.js | 10 ++ .../selectors/__tests__/featuregrid-test.js | 20 ++++ web/client/selectors/featuregrid.js | 2 + web/client/themes/default/less/common.less | 23 +++++ web/client/themes/default/variables.less | 1 + web/client/translations/data.de-DE | 3 + web/client/translations/data.en-US | 3 + web/client/translations/data.es-ES | 3 + web/client/translations/data.fr-FR | 3 + web/client/translations/data.hr-HR | 3 + web/client/translations/data.it-IT | 3 + web/client/translations/data.nl-NL | 16 +++ web/client/translations/data.zh-ZH | 3 + 26 files changed, 275 insertions(+), 44 deletions(-) create mode 100644 web/client/components/data/featuregrid/enhancers/withHint.js create mode 100644 web/client/components/data/featuregrid/enhancers/withPopover.js create mode 100644 web/client/components/data/featuregrid/enhancers/withTooltip.js diff --git a/web/client/actions/__tests__/featuregrid-test.js b/web/client/actions/__tests__/featuregrid-test.js index 5980eef5f0..6dcb055aa8 100644 --- a/web/client/actions/__tests__/featuregrid-test.js +++ b/web/client/actions/__tests__/featuregrid-test.js @@ -41,7 +41,9 @@ const { START_SYNC_WMS, startSyncWMS, storeAdvancedSearchFilter, STORE_ADVANCED_SEARCH_FILTER, fatureGridQueryResult, GRID_QUERY_RESULT, - moreFeatures, LOAD_MORE_FEATURES + moreFeatures, LOAD_MORE_FEATURES, + hideSyncPopover, HIDE_SYNC_POPOVER, + toggleShowAgain, TOGGLE_SHOW_AGAIN_FLAG } = require('../featuregrid'); const idFeature = "2135"; @@ -96,6 +98,16 @@ describe('Test correctness of featurgrid actions', () => { expect(retval).toExist(); expect(retval.type).toBe(CLEAR_CHANGES_CONFIRMED); }); + it('Test hideSyncPopover action creator', () => { + const retval = hideSyncPopover(); + expect(retval).toExist(); + expect(retval.type).toBe(HIDE_SYNC_POPOVER); + }); + it('Test toggleShowAgain action creator', () => { + const retval = toggleShowAgain(); + expect(retval).toExist(); + expect(retval.type).toBe(TOGGLE_SHOW_AGAIN_FLAG); + }); it('Test startDrawingFeature action creator', () => { const retval = startDrawingFeature(); expect(retval).toExist(); diff --git a/web/client/actions/featuregrid.js b/web/client/actions/featuregrid.js index 90c661c6fd..0e5899cda6 100644 --- a/web/client/actions/featuregrid.js +++ b/web/client/actions/featuregrid.js @@ -45,6 +45,8 @@ const OPEN_ADVANCED_SEARCH = 'FEATUREGRID:ADVANCED_SEARCH'; const ZOOM_ALL = 'FEATUREGRID:ZOOM_ALL'; const INIT_PLUGIN = 'FEATUREGRID:INIT_PLUGIN'; const SIZE_CHANGE = 'FEATUREGRID:SIZE_CHANGE'; +const TOGGLE_SHOW_AGAIN_FLAG = 'FEATUREGRID:TOGGLE_SHOW_AGAIN_FLAG'; +const HIDE_SYNC_POPOVER = 'FEATUREGRID:HIDE_SYNC_POPOVER'; const MODES = { EDIT: "EDIT", @@ -56,6 +58,16 @@ const STORE_ADVANCED_SEARCH_FILTER = 'STORE_ADVANCED_SEARCH_FILTER'; const LOAD_MORE_FEATURES = "LOAD_MORE_FEATURES"; const GRID_QUERY_RESULT = 'FEATUREGRID:QUERY_RESULT'; +function toggleShowAgain() { + return { + type: TOGGLE_SHOW_AGAIN_FLAG + }; +} +function hideSyncPopover() { + return { + type: HIDE_SYNC_POPOVER + }; +} function fatureGridQueryResult(features, pages) { return { type: GRID_QUERY_RESULT, @@ -381,6 +393,8 @@ module.exports = { toggleEditMode, toggleViewMode, initPlugin, INIT_PLUGIN, + hideSyncPopover, HIDE_SYNC_POPOVER, + toggleShowAgain, TOGGLE_SHOW_AGAIN_FLAG, START_SYNC_WMS, startSyncWMS, STOP_SYNC_WMS, storeAdvancedSearchFilter, STORE_ADVANCED_SEARCH_FILTER, diff --git a/web/client/components/data/featuregrid/enhancers/withHint.js b/web/client/components/data/featuregrid/enhancers/withHint.js new file mode 100644 index 0000000000..b79616a43a --- /dev/null +++ b/web/client/components/data/featuregrid/enhancers/withHint.js @@ -0,0 +1,11 @@ + +const {compose, branch} = require('recompose'); +const tooltip = require('../../../misc/enhancers/tooltip'); +const withPopover = require('./withPopover'); +module.exports = compose( + branch( + (({renderPopover} = {}) => renderPopover), + withPopover, + tooltip + ) +); diff --git a/web/client/components/data/featuregrid/enhancers/withPopover.js b/web/client/components/data/featuregrid/enhancers/withPopover.js new file mode 100644 index 0000000000..9e311ba166 --- /dev/null +++ b/web/client/components/data/featuregrid/enhancers/withPopover.js @@ -0,0 +1,28 @@ +const React = require('react'); +const Overlay = require('../../../misc/Overlay'); +const {Popover} = require('react-bootstrap'); +const ReactDOM = require('react-dom'); + +/** + * An overlay popover is added to a Wrapped component + * @param {object} Wrapped must be a class component, do not use a functional + * component because it misses the refs property + * you can customize popover props, content and placement +*/ +module.exports = (Wrapped) => class WithPopover extends React.Component { + render() { + let target = null; + const {popoverOptions, ...props} = this.props; + return ( + + { target = button; }} /> + ReactDOM.findDOMNode(target)}> + + {popoverOptions.content} + + + + ); + } +}; diff --git a/web/client/components/data/featuregrid/enhancers/withTooltip.js b/web/client/components/data/featuregrid/enhancers/withTooltip.js new file mode 100644 index 0000000000..a15929e580 --- /dev/null +++ b/web/client/components/data/featuregrid/enhancers/withTooltip.js @@ -0,0 +1,8 @@ +const React = require('react'); +const OverlayTrigger = require('../../../misc/OverlayTrigger'); +const {Tooltip} = require('react-bootstrap'); + +module.exports = (Wrapped) => ({tooltip, id, placement, ...props}) => + ({tooltip}}> + + ); diff --git a/web/client/components/data/featuregrid/toolbars/TButton.jsx b/web/client/components/data/featuregrid/toolbars/TButton.jsx index 9ef3d06ed1..abf4e4e106 100644 --- a/web/client/components/data/featuregrid/toolbars/TButton.jsx +++ b/web/client/components/data/featuregrid/toolbars/TButton.jsx @@ -1,21 +1,21 @@ const React = require('react'); -const {Button, Glyphicon, Tooltip} = require('react-bootstrap'); -const OverlayTrigger = require('../../../misc/OverlayTrigger'); +const {Button, Glyphicon} = require('react-bootstrap'); const hideStyle = { width: 0, padding: 0, borderWidth: 0 }; -const normalStyle = { -}; - +const normalStyle = {}; const getStyle = (visible) => visible ? normalStyle : hideStyle; -module.exports = ({disabled, id, tooltip="", visible, onClick, glyph, active, className = "square-button"}) => - ({tooltip}}> - - ); + ); + } +}; diff --git a/web/client/components/data/featuregrid/toolbars/Toolbar.jsx b/web/client/components/data/featuregrid/toolbars/Toolbar.jsx index b61ff9a153..e40bcc85d5 100644 --- a/web/client/components/data/featuregrid/toolbars/Toolbar.jsx +++ b/web/client/components/data/featuregrid/toolbars/Toolbar.jsx @@ -1,8 +1,9 @@ const React = require('react'); -const {ButtonGroup} = require('react-bootstrap'); +const {ButtonGroup, Glyphicon, Checkbox} = require('react-bootstrap'); require("./toolbar.css"); const Message = require('../../../I18N/Message'); -const TButton = require("./TButton"); +const withHint = require("../enhancers/withHint"); +const TButton = withHint(require("./TButton")); const getDrawFeatureTooltip = (isDrawing, isSimpleGeom) => { if (isDrawing) { return "featuregrid.toolbar.stopDrawGeom"; @@ -15,48 +16,52 @@ const getSaveMessageId = ({saving, saved}) => { } return "featuregrid.toolbar.saveChanges"; }; - -module.exports = ({events = {}, mode = "VIEW", showChartButton = true, selectedCount, hasChanges, hasGeometry, hasNewFeatures, isSimpleGeom, isDrawing = false, isEditingAllowed, saving = false, saved = false, isDownloadOpen, isColumnsOpen, disableToolbar, isSearchAllowed, disableDownload, displayDownload, isSyncActive = false, hasSupportedGeometry = true, disableZoomAll = false} = {}) => - - ( +module.exports = ({events = {}, syncPopover = {showPopoverSync: true, dockSize: "32.2%"}, mode = "VIEW", showChartButton = true, selectedCount, hasChanges, hasGeometry, hasNewFeatures, isSimpleGeom, isDrawing = false, isEditingAllowed, saving = false, saved = false, isDownloadOpen, isColumnsOpen, disableToolbar, isSearchAllowed, disableDownload, displayDownload, isSyncActive = false, hasSupportedGeometry = true, disableZoomAll = false} = {}) => { + return ( } + key="edit-mode" + tooltipId="featuregrid.toolbar.editMode" disabled={disableToolbar} visible={mode === "VIEW" && isEditingAllowed} onClick={events.switchEditMode} glyph="pencil"/> } + key="search" + tooltipId="featuregrid.toolbar.advancedFilter" disabled={disableToolbar || !isSearchAllowed} visible={mode === "VIEW"} onClick={events.showQueryPanel} glyph="filter"/> } + key="zoom-all" + tooltipId="featuregrid.toolbar.zoomAll" disabled={disableToolbar || disableZoomAll} visible={mode === "VIEW"} onClick={events.zoomAll} glyph="zoom-to"/> } + key="back-view" + tooltipId="featuregrid.toolbar.quitEditMode" disabled={disableToolbar} visible={mode === "EDIT" && !hasChanges && !hasNewFeatures} onClick={events.switchViewMode} glyph="arrow-left"/> } + key="add-feature" + tooltipId="featuregrid.toolbar.addNewFeatures" disabled={disableToolbar} visible={mode === "EDIT" && !hasNewFeatures && !hasChanges && hasSupportedGeometry} onClick={events.createFeature} glyph="row-add"/> } + key="draw-feature" + tooltipId={getDrawFeatureTooltip(isDrawing, isSimpleGeom)} disabled={disableToolbar} visible={mode === "EDIT" && selectedCount === 1 && (!hasGeometry || hasGeometry && !isSimpleGeom) && hasSupportedGeometry} onClick={events.startDrawingFeature} @@ -64,14 +69,16 @@ module.exports = ({events = {}, mode = "VIEW", showChartButton = true, selectedC glyph="pencil-add"/> } + key="remove-features" + tooltipId="featuregrid.toolbar.deleteSelectedFeatures" disabled={disableToolbar} visible={mode === "EDIT" && selectedCount > 0 && !hasChanges && !hasNewFeatures} onClick={events.deleteFeatures} glyph="trash-square"/> } + key="save-feature" + tooltipId={getSaveMessageId({saving, saved})} disabled={saving || saved || disableToolbar} visible={mode === "EDIT" && hasChanges || hasNewFeatures} active={saved} @@ -79,21 +86,24 @@ module.exports = ({events = {}, mode = "VIEW", showChartButton = true, selectedC glyph="floppy-disk"/> } + key="cancel-editing" + tooltipId="featuregrid.toolbar.cancelChanges" disabled={disableToolbar} visible={mode === "EDIT" && hasChanges || hasNewFeatures} onClick={events.clearFeatureEditing} glyph="remove-square"/> } + key="delete-geometry" + tooltipId="featuregrid.toolbar.deleteGeometry" disabled={disableToolbar} visible={mode === "EDIT" && hasGeometry && selectedCount === 1 && hasSupportedGeometry} onClick={events.deleteGeometry} glyph="polygon-trash"/> } + key="download-grid" + tooltipId="featuregrid.toolbar.downloadGridData" disabled={disableToolbar || disableDownload} active={isDownloadOpen} visible={displayDownload && mode === "VIEW"} @@ -101,25 +111,58 @@ module.exports = ({events = {}, mode = "VIEW", showChartButton = true, selectedC glyph="features-grid-download"/> } + key="grid-settings" + tooltipId="featuregrid.toolbar.hideShowColumns" disabled={disableToolbar} active={isColumnsOpen} visible={selectedCount <= 1 && mode === "VIEW"} onClick={events.settings} glyph="features-grid-set"/> - } - disabled={disableToolbar} - active={isSyncActive} - visible={mode === "VIEW"} - onClick={events.sync} - glyph="map-filter"/> } + key="grid-map-chart" + tooltipId="featuregrid.toolbar.createNewChart" disabled={disableToolbar} visible={mode === "VIEW" && showChartButton} onClick={events.chart} glyph="stats"/> - ); + +

+

+ + + +

+ ), + props: { + id: "sync-popover", + title:
+ + +
, + style: { + bottom: syncPopover.dockSize + } + }} + } /> + +
); }; diff --git a/web/client/components/misc/enhancers/tooltip.jsx b/web/client/components/misc/enhancers/tooltip.jsx index ae4838a2e8..c5ae2178f6 100644 --- a/web/client/components/misc/enhancers/tooltip.jsx +++ b/web/client/components/misc/enhancers/tooltip.jsx @@ -30,7 +30,6 @@ const Message = require('../../I18N/Message'); */ module.exports = branch( ({tooltip, tooltipId} = {}) => tooltip || tooltipId, - // TODO return proper HOC (Wrapped) => ({tooltip, tooltipId, tooltipPosition = "top", tooltipTrigger, key, ...props} = {}) => () : [ this.renderContent(), - ReactDOM.findDOMNode(this.target)}> + ReactDOM.findDOMNode(this.target)}> {this.renderPopover()} ]} diff --git a/web/client/epics/maplayout.js b/web/client/epics/maplayout.js index 462458ab6e..d51f4c4df5 100644 --- a/web/client/epics/maplayout.js +++ b/web/client/epics/maplayout.js @@ -73,7 +73,8 @@ const updateMapLayoutEpic = (action$, store) => mapInfoRequestsSelector(store.getState()).length > 0 && {right: mapLayout.right.md} || null ].filter(panel => panel)) || {right: 0}; - const bottom = isFeatureGridOpen(store.getState()) && {bottom: getDockSize(store.getState()) * 100 + '%'} || {bottom: mapLayout.bottom.sm}; + const dockSize = getDockSize(store.getState()) * 100; + const bottom = isFeatureGridOpen(store.getState()) && {bottom: dockSize + '%', dockSize} || {bottom: mapLayout.bottom.sm}; const transform = isFeatureGridOpen(store.getState()) && {transform: 'translate(0, -' + mapLayout.bottom.sm + 'px)'} || {transform: 'none'}; const height = {height: 'calc(100% - ' + mapLayout.bottom.sm + 'px)'}; diff --git a/web/client/plugins/featuregrid/panels/index.jsx b/web/client/plugins/featuregrid/panels/index.jsx index ad1b93aa15..4d8ed0e436 100644 --- a/web/client/plugins/featuregrid/panels/index.jsx +++ b/web/client/plugins/featuregrid/panels/index.jsx @@ -15,7 +15,8 @@ const {paginationInfo, featureLoadingSelector, resultsSelector, isSyncWmsActive, const {getTitleSelector, modeSelector, selectedFeaturesCount, hasChangesSelector, hasGeometrySelector, isSimpleGeomSelector, hasNewFeaturesSelector, isSavingSelector, isSavedSelector, isDrawingSelector, canEditSelector, getAttributeFilter, hasSupportedGeometry, editingAllowedRolesSelector} = require('../../../selectors/featuregrid'); const {userRoleSelector} = require('../../../selectors/security'); const {isCesium} = require('../../../selectors/maptype'); -const {chartDisabledSelector} = require('../../../selectors/featuregrid'); +const {mapLayoutValuesSelector} = require('../../../selectors/mapLayout'); +const {chartDisabledSelector, showAgainSelector, showPopoverSyncSelector} = require('../../../selectors/featuregrid'); const {deleteFeatures, toggleTool, clearChangeConfirmed, closeFeatureGridConfirmed, closeFeatureGrid} = require('../../../actions/featuregrid'); const {toolbarEvents, pageEvents} = require('../index'); const {getAttributeFields} = require('../../../utils/FeatureGridUtils'); @@ -35,6 +36,11 @@ const Toolbar = connect( hasChanges: hasChangesSelector, hasNewFeatures: hasNewFeaturesSelector, hasGeometry: hasGeometrySelector, + syncPopover: state => ({ + showAgain: showAgainSelector(state), + showPopoverSync: showPopoverSyncSelector(state), + dockSize: mapLayoutValuesSelector(state, {dockSize: true}).dockSize + 3.2 + "%" + }), isDrawing: isDrawingSelector, showChartButton: state => !chartDisabledSelector(state) && widgetBuilderAvailable(state), isSimpleGeom: isSimpleGeomSelector, diff --git a/web/client/plugins/featuregrid/toolbarEvents.js b/web/client/plugins/featuregrid/toolbarEvents.js index b61f17f63a..1c93ea86fa 100644 --- a/web/client/plugins/featuregrid/toolbarEvents.js +++ b/web/client/plugins/featuregrid/toolbarEvents.js @@ -4,6 +4,8 @@ const {toggleTool, toggleViewMode, closeFeatureGridConfirm, saveChanges, + hideSyncPopover, + toggleShowAgain, createNewFeatures, startEditingFeature, startDrawingFeature, @@ -32,5 +34,7 @@ module.exports = { showQueryPanel: () => openAdvancedSearch(), zoomAll: () => zoomAll(), sync: () => toggleSyncWms(), + hideSyncPopover: () => hideSyncPopover(), + toggleShowAgain: () => toggleShowAgain(), chart: () => createChart() }; diff --git a/web/client/reducers/__tests__/featuregrid-test.js b/web/client/reducers/__tests__/featuregrid-test.js index 88c5f74ace..0970cb0dc9 100644 --- a/web/client/reducers/__tests__/featuregrid-test.js +++ b/web/client/reducers/__tests__/featuregrid-test.js @@ -46,7 +46,8 @@ const expect = require('expect'); const featuregrid = require('../featuregrid'); const {setFeatures, dockSizeFeatures, setLayer, toggleTool, customizeAttribute, selectFeatures, deselectFeatures, createNewFeatures, updateFilter, featureSaving, toggleSelection, clearSelection, MODES, toggleEditMode, toggleViewMode, saveSuccess, clearChanges, saveError, startDrawingFeature, - deleteGeometryFeature, geometryChanged, setSelectionOptions, changePage, featureModified, setPermission, disableToolbar, openFeatureGrid, closeFeatureGrid, initPlugin, sizeChange, storeAdvancedSearchFilter} = require('../../actions/featuregrid'); + deleteGeometryFeature, geometryChanged, setSelectionOptions, changePage, featureModified, setPermission, disableToolbar, openFeatureGrid, closeFeatureGrid, + toggleShowAgain, hideSyncPopover, initPlugin, sizeChange, storeAdvancedSearchFilter} = require('../../actions/featuregrid'); const {featureTypeLoaded, createQuery} = require('../../actions/wfsquery'); const {changeDrawingStatus} = require('../../actions/draw'); @@ -65,6 +66,17 @@ describe('Test the featuregrid reducer', () => { expect(state.select).toExist(); expect(state.features).toExist(); }); + it('hideSyncPopover', () => { + let state = featuregrid({}, hideSyncPopover()); + expect(state.showPopoverSync).toBe(false); + }); + it('toggleShowAgain toggling', () => { + let state = featuregrid({showAgain: false}, toggleShowAgain()); + expect(state).toExist(); + expect(state.showAgain).toBe(true); + let state2 = featuregrid({showAgain: true}, toggleShowAgain()); + expect(state2.showAgain).toBe(false); + }); it('initPlugin', () => { const someValue = "someValue"; const editingAllowedRoles = [someValue]; diff --git a/web/client/reducers/featuregrid.js b/web/client/reducers/featuregrid.js index 2ed75ba097..f6a3eb3799 100644 --- a/web/client/reducers/featuregrid.js +++ b/web/client/reducers/featuregrid.js @@ -27,6 +27,8 @@ const { TOGGLE_MODE, MODES, GEOMETRY_CHANGED, + HIDE_SYNC_POPOVER, + TOGGLE_SHOW_AGAIN_FLAG, DELETE_GEOMETRY_FEATURE, START_DRAWING_FEATURE, SET_PERMISSION, @@ -58,6 +60,8 @@ const emptyResultsState = { open: false, canEdit: false, focusOnEdit: true, + showAgain: true, + showPopoverSync: localStorage && localStorage.getItem("showPopoverSync") !== null ? localStorage.getItem("showPopoverSync") === "true" : true, mode: MODES.VIEW, changes: [], pagination: { @@ -368,6 +372,12 @@ function featuregrid(state = emptyResultsState, action) { case GRID_QUERY_RESULT: { return assign({}, state, {features: action.features || [], pages: action.pages || []}); } + case HIDE_SYNC_POPOVER: { + return assign({}, state, {showPopoverSync: false}); + } + case TOGGLE_SHOW_AGAIN_FLAG: { + return assign({}, state, {showAgain: !state.showAgain}); + } default: return state; } diff --git a/web/client/selectors/__tests__/featuregrid-test.js b/web/client/selectors/__tests__/featuregrid-test.js index 4864dd078e..24ab7c6f7c 100644 --- a/web/client/selectors/__tests__/featuregrid-test.js +++ b/web/client/selectors/__tests__/featuregrid-test.js @@ -27,6 +27,8 @@ const { isSavingSelector, isSavedSelector, canEditSelector, + showAgainSelector, + showPopoverSyncSelector, hasSupportedGeometry, getDockSize } = require('../featuregrid'); @@ -381,6 +383,24 @@ describe('Test featuregrid selectors', () => { expect(feature).toExist(); expect(feature.id).toBe(idFt1); }); + it('test showAgainSelector default ', () => { + const val = showAgainSelector(initialState); + expect(val).toExist(); + expect(val).toBe(true); + }); + it('test showAgainSelector default ', () => { + const val = showPopoverSyncSelector(initialState); + expect(val).toExist(); + expect(val).toBe(true); + }); + it('test showAgainSelector ', () => { + const val = showAgainSelector({featuregrid: {showAgain: false}}); + expect(val).toBe(false); + }); + it('test showPopoverSyncSelector ', () => { + const val = showPopoverSyncSelector({featuregrid: {showPopoverSync: false}}); + expect(val).toBe(false); + }); it('test selectedFeaturesSelector ', () => { const features = selectedFeaturesSelector(initialState); expect(features).toExist(); diff --git a/web/client/selectors/featuregrid.js b/web/client/selectors/featuregrid.js index 4a56e0874f..472c8d9c61 100644 --- a/web/client/selectors/featuregrid.js +++ b/web/client/selectors/featuregrid.js @@ -122,6 +122,8 @@ module.exports = { hasGeometrySelector: state => hasGeometrySelectedFeature(state), newFeaturesSelector, hasNewFeaturesSelector, + showAgainSelector: state => get(state, "featuregrid.showAgain", true), + showPopoverSyncSelector: state => get(state, "featuregrid.showPopoverSync", true), isSavingSelector: state => state && state.featuregrid && state.featuregrid.saving, editingAllowedRolesSelector: state => get(state, "featuregrid.editingAllowedRoles", ["ADMIN"]), isSavedSelector: state => state && state.featuregrid && state.featuregrid.saved, diff --git a/web/client/themes/default/less/common.less b/web/client/themes/default/less/common.less index 5f854060dc..a8d3d66885 100644 --- a/web/client/themes/default/less/common.less +++ b/web/client/themes/default/less/common.less @@ -153,3 +153,26 @@ textarea { top: 0; } } + + +div#sync-popover.popover { + top: auto !important; + padding: 0; + h3 { + background-color: @ms2-color-primary; + color: @ms2-color-text-primary; + } + .mapstore-switch-btn{ + margin-bottom: -5px; + } + .glyphicon-1-close:before { + font-size: @small-icon-size; + } + button.close{ + font-size: inherit; + } + button.close:first-child:before { + font-size: 0px; + } + +} diff --git a/web/client/themes/default/variables.less b/web/client/themes/default/variables.less index dcebd51d64..47dbe0e540 100644 --- a/web/client/themes/default/variables.less +++ b/web/client/themes/default/variables.less @@ -44,6 +44,7 @@ @icon-resize-ratio: 1.6; @icon-size: 26px; +@small-icon-size: 14px; @padding-left-square: floor(@icon-size/@icon-margin-ratio); @square-btn-size: @padding-left-square * 2 + @icon-size; diff --git a/web/client/translations/data.de-DE b/web/client/translations/data.de-DE index 570836c826..6c6f1e24c2 100644 --- a/web/client/translations/data.de-DE +++ b/web/client/translations/data.de-DE @@ -1042,6 +1042,9 @@ } }, "toolbar": { + "synchPopoverTitle": "Karte mit Filter synchronisieren ", + "synchPopoverText": "Verwenden Sie dieses Werkzeug, um die Karte mit dem ausgewählten Filter zu synchronisieren", + "notShowAgain": " Zeigen Sie diese Nachricht nicht erneut an", "editMode": "Bearbeitungsmodus", "advancedFilter": "Erweiterte Suche", "quitEditMode": "Beenden Sie den Bearbeitungsmodus", diff --git a/web/client/translations/data.en-US b/web/client/translations/data.en-US index 3709fc283d..a459727c5b 100644 --- a/web/client/translations/data.en-US +++ b/web/client/translations/data.en-US @@ -1043,6 +1043,9 @@ } }, "toolbar": { + "synchPopoverTitle": "Sync map with filter ", + "synchPopoverText": "Use this tool to synchronize the map with the selected filter", + "notShowAgain": " Don't show this message again", "editMode": "Edit mode", "advancedFilter": "Advanced Search", "quitEditMode": "Quit edit mode", diff --git a/web/client/translations/data.es-ES b/web/client/translations/data.es-ES index 173b951af3..07dc4e0612 100644 --- a/web/client/translations/data.es-ES +++ b/web/client/translations/data.es-ES @@ -1042,6 +1042,9 @@ } }, "toolbar": { + "synchPopoverTitle": "Sincronizar mapa con filtro ", + "synchPopoverText": "Use esta herramienta para sincronizar el mapa con el filtro seleccionado", + "notShowAgain": " No mostrar este mensaje otra vez", "editMode": "Modo de edición", "advancedFilter": "Búsqueda avanzada", "quitEditMode": "Salir del modo de edición", diff --git a/web/client/translations/data.fr-FR b/web/client/translations/data.fr-FR index 9572d4447d..752271cd49 100644 --- a/web/client/translations/data.fr-FR +++ b/web/client/translations/data.fr-FR @@ -1043,6 +1043,9 @@ } }, "toolbar": { + "synchPopoverTitle": "Synchroniser la carte avec un filtre ", + "synchPopoverText": "Utilisez cet outil pour synchroniser la carte avec le filtre sélectionné", + "notShowAgain": " Ne plus afficher ce message", "editMode": "Mode édition", "advancedFilter": "Recherche Avancée", "quitEditMode": "Quitter le mode d'édition", diff --git a/web/client/translations/data.hr-HR b/web/client/translations/data.hr-HR index 1cd18fd9ac..8034c803d2 100644 --- a/web/client/translations/data.hr-HR +++ b/web/client/translations/data.hr-HR @@ -1043,6 +1043,9 @@ } }, "toolbar": { + "synchPopoverTitle": "Sync map with filter ", + "synchPopoverText": "Use this tool to synchronize the map with the selected filter", + "notShowAgain": " Don't show this message again", "editMode": "Editiranje", "advancedFilter": "Napredna pretraga", "quitEditMode": "Napusti editiranje", diff --git a/web/client/translations/data.it-IT b/web/client/translations/data.it-IT index 8f067ea151..19fab4d838 100644 --- a/web/client/translations/data.it-IT +++ b/web/client/translations/data.it-IT @@ -1042,6 +1042,9 @@ } }, "toolbar": { + "synchPopoverTitle": "Sincronizza la mappa con il filtro ", + "synchPopoverText": "Usa questa icona per sincronizzare la mappa con il filtro selezionato", + "notShowAgain": " Non mostrare più", "editMode": "Entra in modalità editing", "advancedFilter": "Ricerca avanzata", "quitEditMode": "Esci dalla modalità editing", diff --git a/web/client/translations/data.nl-NL b/web/client/translations/data.nl-NL index 6b28063827..4f4cb5157f 100644 --- a/web/client/translations/data.nl-NL +++ b/web/client/translations/data.nl-NL @@ -865,7 +865,23 @@ "featureClose":"Wilt u echt het rooster sluiten?", "delete": "Valideren om de elementen te verwijderen?", "missingGeometry": "Ontbrekende geometrie", + "filter": { + "placeholders": { + "default": "Search...", + "string": "Type text to filter...", + "number": "Type number or expression..." + }, + "tooltips": { + "editMode": "Quick search is not available in edit mode", + "default": "Search...", + "string": "Type text to filter...", + "number": "Type a number or an expression. Examples: 10, > 2, < 10" + } + }, "toolbar": { + "synchPopoverTitle": "Sync map with filter ", + "synchPopoverText": "Use this tool to synchronize the map with the selected filter", + "notShowAgain": " Don't show this message again", "editMode": "Bewerkingsmodus", "advancedFilter": "Geavanceerd zoeken", "quitEditMode": "Verlaat de bewerkingsmodus", diff --git a/web/client/translations/data.zh-ZH b/web/client/translations/data.zh-ZH index b157dadbb2..6beb51cd1f 100644 --- a/web/client/translations/data.zh-ZH +++ b/web/client/translations/data.zh-ZH @@ -941,6 +941,9 @@ } }, "toolbar": { + "synchPopoverTitle": "Sync map with filter ", + "synchPopoverText": "Use this tool to synchronize the map with the selected filter", + "notShowAgain": " Don't show this message again", "editMode": "Edit mode", "advancedFilter": "Advanced Search", "quitEditMode": "Quit edit mode", From dde1fc491945b991e1524f29e9ef5542c2c6b697 Mon Sep 17 00:00:00 2001 From: Matteo Velludini Date: Wed, 18 Apr 2018 17:54:17 +0200 Subject: [PATCH 2/2] improved withHint enhancer --- web/client/components/data/featuregrid/enhancers/withHint.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/web/client/components/data/featuregrid/enhancers/withHint.js b/web/client/components/data/featuregrid/enhancers/withHint.js index b79616a43a..317fe5a5bf 100644 --- a/web/client/components/data/featuregrid/enhancers/withHint.js +++ b/web/client/components/data/featuregrid/enhancers/withHint.js @@ -4,7 +4,7 @@ const tooltip = require('../../../misc/enhancers/tooltip'); const withPopover = require('./withPopover'); module.exports = compose( branch( - (({renderPopover} = {}) => renderPopover), + (({renderPopover, popoverOptions} = {}) => renderPopover && !!popoverOptions), withPopover, tooltip )