mirror of
https://github.com/maputnik/editor.git
synced 2026-03-20 17:20:01 +00:00
It migrates to next gen translation extraction tool and updates other libraries with their relevant changes. --------- Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
66 lines
2.0 KiB
TypeScript
66 lines
2.0 KiB
TypeScript
import React from "react";
|
|
import { formatLayerId } from "../libs/format";
|
|
import { type LayerSpecification, type StyleSpecification } from "maplibre-gl";
|
|
import { type WithTranslation, withTranslation } from "react-i18next";
|
|
import { type MappedError } from "../libs/definitions";
|
|
|
|
type AppMessagePanelInternalProps = {
|
|
errors?: MappedError[]
|
|
infos?: string[]
|
|
mapStyle?: StyleSpecification
|
|
onLayerSelect?(index: number): void;
|
|
currentLayer?: LayerSpecification
|
|
selectedLayerIndex?: number
|
|
} & WithTranslation;
|
|
|
|
class AppMessagePanelInternal extends React.Component<AppMessagePanelInternalProps> {
|
|
static defaultProps = {
|
|
onLayerSelect: () => { },
|
|
};
|
|
|
|
render() {
|
|
const { t, selectedLayerIndex } = this.props;
|
|
const errors = this.props.errors?.map((error, idx) => {
|
|
let content;
|
|
if (error.parsed && error.parsed.type === "layer") {
|
|
const { parsed } = error;
|
|
const layerId = this.props.mapStyle?.layers[parsed.data.index].id;
|
|
content = (
|
|
<>
|
|
{t("Layer")} <span>{formatLayerId(layerId)}</span>: {parsed.data.message}
|
|
{selectedLayerIndex !== parsed.data.index &&
|
|
<>
|
|
—
|
|
<button
|
|
className="maputnik-message-panel__switch-button"
|
|
onClick={() => this.props.onLayerSelect!(parsed.data.index)}
|
|
>
|
|
{t("switch to layer")}
|
|
</button>
|
|
</>
|
|
}
|
|
</>
|
|
);
|
|
}
|
|
else {
|
|
content = error.message;
|
|
}
|
|
return <p key={"error-" + idx} className="maputnik-message-panel-error">
|
|
{content}
|
|
</p>;
|
|
});
|
|
|
|
const infos = this.props.infos?.map((m, i) => {
|
|
return <p key={"info-" + i}>{m}</p>;
|
|
});
|
|
|
|
return <div className="maputnik-message-panel">
|
|
{errors}
|
|
{infos}
|
|
</div>;
|
|
}
|
|
}
|
|
|
|
const AppMessagePanel = withTranslation()(AppMessagePanelInternal);
|
|
export default AppMessagePanel;
|