mirror of
https://github.com/grafana/grafana.git
synced 2025-02-20 11:48:34 -06:00
* Enable jsx-a11y/alt-text rule * Fix errors * Fix tests * Enable jsx-a11y/alt-text rule after solving merge conflict * Delete unused import * Modify files according to the reviewer's comments * Revert test changes and update snapshot * tweaks to image alt names Co-authored-by: Ashley Harrison <ashley.harrison@grafana.com>
103 lines
3.0 KiB
TypeScript
103 lines
3.0 KiB
TypeScript
import React, { PureComponent } from 'react';
|
|
|
|
import { Button, CollapsableSection, FileUpload } from '@grafana/ui';
|
|
import { getBackendSrv } from 'app/core/services/backend_srv';
|
|
import { getThumbnailURL } from 'app/features/search/components/SearchCard';
|
|
|
|
interface Props {
|
|
uid: string;
|
|
}
|
|
|
|
interface State {}
|
|
|
|
export class PreviewSettings extends PureComponent<Props, State> {
|
|
state: State = {};
|
|
|
|
doUpload = (evt: EventTarget & HTMLInputElement, isLight?: boolean) => {
|
|
const file = evt?.files && evt.files[0];
|
|
if (!file) {
|
|
console.log('NOPE!', evt);
|
|
return;
|
|
}
|
|
|
|
const url = getThumbnailURL(this.props.uid, isLight);
|
|
const formData = new FormData();
|
|
formData.append('file', file);
|
|
|
|
fetch(url, {
|
|
method: 'POST',
|
|
body: formData,
|
|
})
|
|
.then((response) => response.json())
|
|
.then((result) => {
|
|
console.log('Success:', result);
|
|
location.reload(); //HACK
|
|
})
|
|
.catch((error) => {
|
|
console.error('Error:', error);
|
|
});
|
|
};
|
|
|
|
markAsStale = (isLight: boolean) => async () => {
|
|
return getBackendSrv().put(getThumbnailURL(this.props.uid, isLight), { state: 'stale' });
|
|
};
|
|
|
|
render() {
|
|
const { uid } = this.props;
|
|
const imgstyle = { maxWidth: 300, maxHeight: 300 };
|
|
return (
|
|
<CollapsableSection label="Preview settings" isOpen={true}>
|
|
<div>DUMMY UI just so we have an upload button!</div>
|
|
<table cellSpacing="4">
|
|
<thead>
|
|
<tr>
|
|
<td>[DARK]</td>
|
|
<td>[LIGHT]</td>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
<tr>
|
|
<td>
|
|
<Button type="button" variant="primary" onClick={this.markAsStale(false)} fill="outline">
|
|
Mark as stale
|
|
</Button>
|
|
</td>
|
|
<td>
|
|
<Button type="button" variant="primary" onClick={this.markAsStale(true)} fill="outline">
|
|
Mark as stale
|
|
</Button>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>
|
|
<img src={getThumbnailURL(uid, false)} alt="Preview of dashboard in dark theme" style={imgstyle} />
|
|
</td>
|
|
<td>
|
|
<img src={getThumbnailURL(uid, true)} alt="Preview of dashboard in light theme" style={imgstyle} />
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>
|
|
<FileUpload
|
|
accept="image/png, image/webp"
|
|
onFileUpload={({ currentTarget }) => this.doUpload(currentTarget, false)}
|
|
>
|
|
Upload dark
|
|
</FileUpload>
|
|
</td>
|
|
<td>
|
|
<FileUpload
|
|
accept="image/png, image/webp"
|
|
onFileUpload={({ currentTarget }) => this.doUpload(currentTarget, true)}
|
|
>
|
|
Upload light
|
|
</FileUpload>
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</CollapsableSection>
|
|
);
|
|
}
|
|
}
|