import PropTypes from 'prop-types'; import React, { Component } from 'react'; import { icons, inputTypes, kinds, sizes } from 'Helpers/Props'; import Icon from 'Components/Icon'; import Button from 'Components/Link/Button'; import ClipboardButton from 'Components/Link/ClipboardButton'; import Form from 'Components/Form/Form'; import FormGroup from 'Components/Form/FormGroup'; import FormLabel from 'Components/Form/FormLabel'; import FormInputGroup from 'Components/Form/FormInputGroup'; import FormInputButton from 'Components/Form/FormInputButton'; import ModalContent from 'Components/Modal/ModalContent'; import ModalHeader from 'Components/Modal/ModalHeader'; import ModalBody from 'Components/Modal/ModalBody'; import ModalFooter from 'Components/Modal/ModalFooter'; function getUrls(state) { const { unmonitored, pastDays, futureDays, tags } = state; let icalUrl = `${window.location.host}${window.Readarr.urlBase}/feed/v1/calendar/Readarr.ics?`; if (unmonitored) { icalUrl += 'unmonitored=true&'; } if (tags.length) { icalUrl += `tags=${tags.toString()}&`; } icalUrl += `pastDays=${pastDays}&futureDays=${futureDays}&apikey=${window.Readarr.apiKey}`; const iCalHttpUrl = `${window.location.protocol}//${icalUrl}`; const iCalWebCalUrl = `webcal://${icalUrl}`; return { iCalHttpUrl, iCalWebCalUrl }; } class CalendarLinkModalContent extends Component { // // Lifecycle constructor(props, context) { super(props, context); const defaultState = { unmonitored: false, pastDays: 7, futureDays: 28, tags: [] }; const urls = getUrls(defaultState); this.state = { ...defaultState, ...urls }; } // // Listeners onInputChange = ({ name, value }) => { const state = { ...this.state, [name]: value }; const urls = getUrls(state); this.setState({ [name]: value, ...urls }); } onLinkFocus = (event) => { event.target.select(); } // // Render render() { const { onModalClose } = this.props; const { unmonitored, pastDays, futureDays, tags, iCalHttpUrl, iCalWebCalUrl } = this.state; return ( Readarr Calendar Feed
Include Unmonitored Past Days Future Days Tags iCal Feed , ]} onChange={this.onInputChange} onFocus={this.onLinkFocus} />
); } } CalendarLinkModalContent.propTypes = { tagList: PropTypes.arrayOf(PropTypes.object).isRequired, onModalClose: PropTypes.func.isRequired }; export default CalendarLinkModalContent;