Files
iD/modules/ui/feature_info.js
2022-07-11 20:26:05 +02:00

59 lines
1.8 KiB
JavaScript

import { t } from '../core/localizer';
import { uiTooltip } from './tooltip';
export function uiFeatureInfo(context) {
function update(selection) {
var features = context.features();
var stats = features.stats();
var count = 0;
var hiddenList = features.hidden().map(function(k) {
if (stats[k]) {
count += stats[k];
return t.append('inspector.title_count', {
title: t('feature.' + k + '.description'),
count: stats[k]
});
}
return null;
}).filter(Boolean);
selection.text('');
if (hiddenList.length) {
var tooltipBehavior = uiTooltip()
.placement('top')
.title(function() {
return selection => {
hiddenList.forEach(hiddenFeature => {
selection.append('div').call(hiddenFeature);
});
};
});
selection.append('a')
.attr('class', 'chip')
.attr('href', '#')
.call(t.append('feature_info.hidden_warning', { count: count }))
.call(tooltipBehavior)
.on('click', function(d3_event) {
tooltipBehavior.hide();
d3_event.preventDefault();
// open the Map Data pane
context.ui().togglePanes(context.container().select('.map-panes .map-data-pane'));
});
}
selection
.classed('hide', !hiddenList.length);
}
return function(selection) {
update(selection);
context.features().on('change.feature_info', function() {
update(selection);
});
};
}