mirror of
				https://github.com/grafana/grafana.git
				synced 2025-02-25 18:55:37 -06:00 
			
		
		
		
	
		
			
				
	
	
		
			57 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			57 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import React, { useState } from 'react';
 | |
| 
 | |
| import { SelectableValue, UrlQueryMap, urlUtil } from '@grafana/data';
 | |
| import { locationService } from '@grafana/runtime';
 | |
| import { Button, Checkbox, Field, FieldSet, Modal, RadioButtonGroup } from '@grafana/ui';
 | |
| 
 | |
| import { Playlist, PlaylistMode } from './types';
 | |
| 
 | |
| export interface Props {
 | |
|   playlist: Playlist;
 | |
|   onDismiss: () => void;
 | |
| }
 | |
| 
 | |
| export const StartModal = ({ playlist, onDismiss }: Props) => {
 | |
|   const [mode, setMode] = useState<PlaylistMode>(false);
 | |
|   const [autoFit, setAutofit] = useState(false);
 | |
| 
 | |
|   const modes: Array<SelectableValue<PlaylistMode>> = [
 | |
|     { label: 'Normal', value: false },
 | |
|     { label: 'TV', value: 'tv' },
 | |
|     { label: 'Kiosk', value: true },
 | |
|   ];
 | |
| 
 | |
|   const onStart = () => {
 | |
|     const params: UrlQueryMap = {};
 | |
|     if (mode) {
 | |
|       params.kiosk = mode;
 | |
|     }
 | |
|     if (autoFit) {
 | |
|       params.autofitpanels = true;
 | |
|     }
 | |
|     locationService.push(urlUtil.renderUrl(`/playlists/play/${playlist.uid}`, params));
 | |
|   };
 | |
| 
 | |
|   return (
 | |
|     <Modal isOpen={true} icon="play" title="Start playlist" onDismiss={onDismiss}>
 | |
|       <FieldSet>
 | |
|         <Field label="Mode">
 | |
|           <RadioButtonGroup value={mode} options={modes} onChange={setMode} />
 | |
|         </Field>
 | |
|         <Checkbox
 | |
|           label="Autofit"
 | |
|           description="Panel heights will be adjusted to fit screen size"
 | |
|           name="autofix"
 | |
|           value={autoFit}
 | |
|           onChange={(e) => setAutofit(e.currentTarget.checked)}
 | |
|         />
 | |
|       </FieldSet>
 | |
|       <Modal.ButtonRow>
 | |
|         <Button variant="primary" onClick={onStart}>
 | |
|           Start {playlist.name}
 | |
|         </Button>
 | |
|       </Modal.ButtonRow>
 | |
|     </Modal>
 | |
|   );
 | |
| };
 |