Merge pull request #93 from Protospace/google-calendar-support
Google calendar support
This commit is contained in:
		| @@ -450,19 +450,61 @@ export function ICalButtons(props) { | |||||||
| 		}); | 		}); | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
|  | 	const addToGoogleCalendar = (e) => { | ||||||
|  | 		e.preventDefault(); | ||||||
|  |  | ||||||
|  | 		// construct and set the dates format that google calendar links require | ||||||
|  | 		let starttime = moment(clazz.datetime); | ||||||
|  | 		let endtime = starttime.clone().add(1, 'hour'); | ||||||
|  | 		const datestringfmt = 'YYYYMMDDTkkmmss'; | ||||||
|  | 		let dates = `${starttime.format(datestringfmt)}/${endtime.format(datestringfmt)}` | ||||||
|  |  | ||||||
|  | 		// send user to google calendar | ||||||
|  | 		window.location = `https://www.google.com/calendar/render?action=TEMPLATE&text=${clazz.course_data.name}&dates=${dates}`; | ||||||
|  | 	}; | ||||||
|  |  | ||||||
|  | 	const options = [ | ||||||
|  | 		{ key: 'email', icon: 'mail outline', text: 'Email ICS Event', value: 'Email', action: handleEmail }, | ||||||
|  | 		{ key: 'download', icon: 'download', text: 'Download ICS Event', value: 'Download', action: handleDownload }, | ||||||
|  | 		{ key: 'google', icon: 'google', text: 'Add to Google Calendar', value: 'Google', action: addToGoogleCalendar }, | ||||||
|  | 	]; | ||||||
|  |  | ||||||
|  | 	// get default option from local storage or default to first item in options list | ||||||
|  | 	const calendarValue = localStorage.getItem('calendarPreference') || 'Email'; | ||||||
|  | 	const defaultOption = options.find(x => x.value === calendarValue); | ||||||
|  |  | ||||||
|  | 	const [selectedOption, setOption] = useState(defaultOption); | ||||||
|  |  | ||||||
|  | 	const onChange = (e, data) => { | ||||||
|  | 		const newOption = options.find(x => x.value === data.value); | ||||||
|  | 		setOption(newOption); | ||||||
|  |  | ||||||
|  | 		// set the option as users preference | ||||||
|  | 		localStorage.setItem('calendarPreference', newOption.value); | ||||||
|  | 	}; | ||||||
|  |  | ||||||
| 	return ( | 	return ( | ||||||
| 		<> | 		<> | ||||||
| 			<Button compact onClick={handleDownload}> | 		{success ? | ||||||
| 				Download | 			<span>  Sent!</span> | ||||||
| 			</Button> | 		: | ||||||
| 			{success ? | 			<Button.Group> | ||||||
| 				<span>  Sent!</span> | 				<Button | ||||||
| 			: | 					loading={loading} | ||||||
| 				<Button compact loading={loading} onClick={handleEmail}> | 					onClick={selectedOption.action} | ||||||
| 					Email | 				> | ||||||
|  | 					<Icon name={selectedOption.icon} />{selectedOption.value} | ||||||
| 				</Button> | 				</Button> | ||||||
| 			} | 				<Dropdown | ||||||
| 			{error && <span>Error.</span>} | 					className='button icon' | ||||||
|  | 					floating | ||||||
|  | 					onChange={onChange} | ||||||
|  | 					options={options} | ||||||
|  | 					trigger={<></>} | ||||||
|  | 					selectOnBlur={false} | ||||||
|  | 				/> | ||||||
|  | 			</Button.Group> | ||||||
|  | 		} | ||||||
| 		</> | 		</> | ||||||
| 	); | 	); | ||||||
| }; | }; | ||||||
|   | |||||||
| @@ -99,6 +99,12 @@ body { | |||||||
| 	padding-top: 1rem; | 	padding-top: 1rem; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | .ui.floating.dropdown.button.icon { | ||||||
|  | 	border-left: 1px; | ||||||
|  | 	border-left-color: #c0c1c2; | ||||||
|  | 	border-left-style: solid; | ||||||
|  | } | ||||||
|  |  | ||||||
| .attendance-row { | .attendance-row { | ||||||
| 	margin-top: 1rem; | 	margin-top: 1rem; | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user