mirror of
				https://github.com/grafana/grafana.git
				synced 2025-02-25 18:55:37 -06:00 
			
		
		
		
	* Export other components as Legacy * More Select Legacy * Add namespacing to more files * Export new elements * Move Legacy Select folder * Let's not forget the scss file * Move new Select folder * Move new Select from Forms namespace * Little oopsie * Fix errors * Fix merge issues
		
			
				
	
	
		
			70 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import React, { PureComponent } from 'react';
 | |
| import { AsyncSelect } from '@grafana/ui';
 | |
| import { getBackendSrv } from 'app/core/services/backend_srv';
 | |
| import { Organization } from 'app/types';
 | |
| import { SelectableValue } from '@grafana/data';
 | |
| 
 | |
| export interface OrgSelectItem {
 | |
|   id: number;
 | |
|   value: number;
 | |
|   label: string;
 | |
|   name: string;
 | |
| }
 | |
| 
 | |
| export interface Props {
 | |
|   onSelected: (org: OrgSelectItem) => void;
 | |
|   className?: string;
 | |
| }
 | |
| 
 | |
| export interface State {
 | |
|   isLoading: boolean;
 | |
| }
 | |
| 
 | |
| export class OrgPicker extends PureComponent<Props, State> {
 | |
|   orgs: Organization[];
 | |
| 
 | |
|   state: State = {
 | |
|     isLoading: false,
 | |
|   };
 | |
| 
 | |
|   async loadOrgs() {
 | |
|     this.setState({ isLoading: true });
 | |
|     const orgs = await getBackendSrv().get('/api/orgs');
 | |
|     this.orgs = orgs;
 | |
|     this.setState({ isLoading: false });
 | |
|     return orgs;
 | |
|   }
 | |
| 
 | |
|   getOrgOptions = async (query: string): Promise<Array<SelectableValue<number>>> => {
 | |
|     if (!this.orgs) {
 | |
|       await this.loadOrgs();
 | |
|     }
 | |
|     return this.orgs.map(
 | |
|       (org: Organization): SelectableValue<number> => ({
 | |
|         id: org.id,
 | |
|         value: org.id,
 | |
|         label: org.name,
 | |
|         name: org.name,
 | |
|       })
 | |
|     );
 | |
|   };
 | |
| 
 | |
|   render() {
 | |
|     const { className, onSelected } = this.props;
 | |
|     const { isLoading } = this.state;
 | |
| 
 | |
|     return (
 | |
|       <AsyncSelect
 | |
|         className={className}
 | |
|         isLoading={isLoading}
 | |
|         defaultOptions={true}
 | |
|         isSearchable={false}
 | |
|         loadOptions={this.getOrgOptions}
 | |
|         onChange={onSelected}
 | |
|         placeholder="Select organization"
 | |
|         noOptionsMessage="No organizations found"
 | |
|       />
 | |
|     );
 | |
|   }
 | |
| }
 |