aboutsummaryrefslogtreecommitdiff
path: root/build/static/js/main.542171da.chunk.js.map
blob: 9d32ed324acf2599b1d296369c1a5b53a10b49eb (plain) (blame)
1
{"version":3,"sources":["Logo.js","App.js","serviceWorker.js","index.js"],"names":["Logo","props","react_default","a","createElement","xmlns","viewBox","version","style","id","transform","points","fill","fontStyle","fontVariant","fontWeight","fontStretch","fontSize","fontFamily","default_chart_data","name","value","color","cyan","gapi_base","theme","createMuiTheme","palette","primary","light","orange","main","dark","contrastText","to_params","dict","Object","entries","map","_ref","_ref2","slicedToArray","k","v","concat","encodeURIComponent","join","getCalendars","token","fetch","access_token","method","async","then","response","json","data","items","getColors","customizedLabel","cx","cy","x","y","stroke","anchor","dx","dy","textAnchor","ChromiclePieChart","Grid_default","container","spacing","item","xs","lg","className","classes","patternTableWrapper","PieChart","width","height","pieChart","Pie","patternGraphData","outerRadius","deepOrange","label","Tooltip","formatter","toFixed","calendarGraphData","innerRadius","d","Cell","RegexField","_this","this","pitems","regex","push","MenuItem_default","key","Select_default","onChange","event","target","fieldStyles","noRegex","TextField_default","React","Component","Dashboard","state","open","patterns","page","rowsPerPage","timeRange","Promise","resolver","chrome","identity","getAuthToken","interactive","activePattern","cached","calendars","handleChangePage","_this2","setState","handleChangeRowsPerPage","updatePattern","field","idx","removePattern","splice","i","length","newPattern","cal","toConsumableArray","analyze","startDate","endDate","start","toISOString","end","event_pms","_loop","calId","timeMin","timeMax","events","all","results","cal_results","_loop2","calName","filter","p","RegExp","test","filterPatterns","forEach","status","summary","undefined","duration","Date","dateTime","background","alert","loadPatterns","colors","calendar","cals","_ref3","_ref4","colorId","_this3","_this$state","rows","nDummy","Math","min","styles","root","AppBar_default","position","appBar","Toolbar_default","disableGutters","toolbar","Typography_default","component","variant","noWrap","title","verticalAlign","marginRight","content","appBarSpacer","CssBaseline_default","md","FormControl_default","fullWidth","FormGroup_default","gutterBottom","IconButton_default","marginBottom","marginLeft","onClick","AddCircle_default","Table_default","patternTable","TableHead_default","TableRow_default","patternHead","s","TableCell_default","TableBody_default","slice","onMouseOver","onMouseOut","CustomText","elem","fieldNoRegex","fieldRegex","right","display","DeleteOutlined_default","cursor","colSpan","TablePagination_default","rowsPerPageOptions","count","backIconButtonProps","aria-label","nextIconButtonProps","onChangePage","onChangeRowsPerPage","textAlign","react_dates","startDateId","endDateId","onDatesChange","_ref5","focusedInput","onFocusChange","isOutsideRange","buttonSpacer","Button_default","TextField","App_RegexField","any","withStyles","zIndex","drawer","transition","transitions","create","easing","sharp","leavingScreen","flexGrow","sectionTitle","flex","mixins","padding","unit","overflow","overflowX","overflowY","minWidth","margin","fab","Boolean","window","location","hostname","match","ReactDOM","render","App","document","getElementById","navigator","serviceWorker","ready","registration","unregister"],"mappings":"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","file":"static/js/main.542171da.chunk.js","sourcesContent":["import React from 'react';\nexport default (props) =>\n  <svg\n     xmlns=\"http://www.w3.org/2000/svg\"\n     viewBox=\"0 0 98.905998 93.557997\"\n     version=\"1.1\"\n     style={props.style}>\n    <g id=\"g13\"\n       transform=\"translate(-153.533,-203.047)\">\n      <g id=\"g29\">\n        <g\n           id=\"g27\">\n          <polygon\n             id=\"polygon7\"\n             points=\"252.439,241.924 234.556,288.703 185.103,296.605 153.533,257.728 171.416,210.949 220.869,203.047 \"\n             style={{fill: '#ff8000'}} />\n          <g\n             id=\"g11\"\n             transform=\"translate(167.24355,224.20734)\">\n            <text\n               id=\"text9\"\n                style={{fontStyle:'normal',\n                    fontVariant:'normal',\n                    fontWeight:'normal',\n                    fontStretch:'normal',\n                    fontSize:75,\n                    fontFamily:'TypoPRO Fantasque Sans Mono',\n                    fill:'#ffeade'}}\n               transform=\"translate(0.586,49.072)\">Cr</text>\n          </g>\n        </g>\n      </g>\n    </g>\n  </svg>\n","import React from 'react';\nimport PropTypes from 'prop-types';\nimport 'typeface-roboto';\nimport 'react-dates/initialize';\nimport 'react-dates/lib/css/_datepicker.css';\nimport { DateRangePicker, DayPickerRangeController } from 'react-dates';\nimport classNames from 'classnames';\nimport { withStyles } from '@material-ui/core/styles';\nimport { MuiThemeProvider, createMuiTheme } from '@material-ui/core/styles';\nimport orange from '@material-ui/core/colors/orange';\nimport cyan from '@material-ui/core/colors/cyan';\nimport deepOrange from '@material-ui/core/colors/deepOrange';\nimport CssBaseline from '@material-ui/core/CssBaseline';\nimport AppBar from '@material-ui/core/AppBar';\nimport Toolbar from '@material-ui/core/Toolbar';\nimport TextField from '@material-ui/core/TextField';\nimport Typography from '@material-ui/core/Typography';\nimport Divider from '@material-ui/core/Divider';\nimport Table from '@material-ui/core/Table';\nimport TableBody from '@material-ui/core/TableBody';\nimport TableRow from '@material-ui/core/TableRow';\nimport TableCell from '@material-ui/core/TableCell';\nimport TableHead from '@material-ui/core/TableHead';\nimport TablePagination from '@material-ui/core/TablePagination';\nimport Paper from '@material-ui/core/Paper';\nimport Button from '@material-ui/core/Button';\nimport FormControl from '@material-ui/core/FormControl';\nimport FormGroup from '@material-ui/core/FormGroup';\nimport Grid from '@material-ui/core/Grid';\nimport DeleteOutlinedIcon from '@material-ui/icons/DeleteOutlined';\nimport AddCircleIcon from '@material-ui/icons/AddCircle';\nimport IconButton from '@material-ui/core/IconButton';\nimport MenuItem from '@material-ui/core/MenuItem';\nimport Select from '@material-ui/core/Select';\nimport { PieChart, Pie, Cell, Tooltip } from 'recharts';\nimport Logo from './Logo';\n\nconst default_chart_data = [{name: 'Work', value: 10, color: cyan[300]},\n                            {name: 'Wasted', value: 10, color: cyan[300]}];\n\nconst gapi_base = 'https://www.googleapis.com/calendar/v3';\n\nconst theme = createMuiTheme({\n    palette: {\n        primary: {\n            light: orange[300],\n            main: orange[500],\n            dark: orange[700],\n            contrastText: \"#fff\"\n        }\n    }\n});\n\n/* eslint-disable no-undef */\n\nfunction to_params(dict) {\n    return Object.entries(dict).map(([k, v]) => `${encodeURIComponent(k)}=${encodeURIComponent(v)}`).join('&');\n}\n\nfunction getAuthToken() {\n    return new Promise(resolver =>\n        chrome.identity.getAuthToken(\n            {interactive: true}, token => resolver(token)));\n}\n\nfunction getCalendars(token) {\n    return fetch(gapi_base + '/users/me/calendarList?' + to_params({access_token: token}),\n            { method: 'GET', async: true })\n        .then(response => response.json())\n        .then(data => data.items);\n}\n\nfunction genEventsGetter(calId, timeMin, timeMax) {\n    return token => fetch(gapi_base + '/calendars/' + calId + '/events?' + to_params({\n        access_token: token,\n        timeMin,\n        timeMax\n    }), { method: 'GET', async: true })\n        .then(response => response.json())\n        .then(data => data.items);\n}\n\nfunction getColors(token) {\n    return fetch(gapi_base + '/colors?' + to_params({access_token: token}), { method: 'GET', async: true })\n        .then(response => response.json());\n}\n\nfunction filterPatterns(patterns, calName) {\n    return patterns.filter(p => {\n        let re = new RegExp(p.cal.regex && p.cal.value || `^${p.cal.value}$`);\n        return re.test(calName);\n    });\n}\n\nconst styles = theme => ({\n    root: {\n        display: 'flex',\n        height: '100vh',\n    },\n    appBar: {\n        zIndex: theme.zIndex.drawer + 1,\n        transition: theme.transitions.create(['width', 'margin'], {\n            easing: theme.transitions.easing.sharp,\n            duration: theme.transitions.duration.leavingScreen,\n        }),\n    },\n    title: {\n        flexGrow: 1,\n    },\n    sectionTitle: {\n        flex: '0 0 auto'\n    },\n    appBarSpacer: theme.mixins.toolbar,\n    content: {\n        flexGrow: 1,\n        padding: theme.spacing.unit * 3,\n        overflow: 'auto',\n    },\n    buttonSpacer: {\n        marginBottom: theme.spacing.unit * 4,\n    },\n    patternTableWrapper: {\n        overflowX: 'auto',\n        overflowY: 'hidden'\n    },\n    patternTable: {\n        minWidth: 600\n    },\n    pieChart: {\n        margin: '0 auto',\n    },\n    fab: {\n        margin: theme.spacing.unit,\n    },\n    fieldNoRegex: {\n        width: 200\n    },\n    fieldRegex: {\n        marginRight: '0.5em'\n    }\n});\n\nfunction customizedLabel(props) {\n    const {cx, cy, x, y, stroke, fill, name, value} = props;\n    let anchor = \"middle\";\n    const EPS = 2;\n    let dx = 0;\n    let dy = 0;\n    if (x < cx - EPS) {\n        dx = -5;\n        anchor = \"end\"\n    } else if (x > cx + EPS) {\n        dx = 5;\n        anchor = \"start\";\n    }\n\n    if (y < cy - EPS) {\n        dy = -5;\n    } else if (y > cy + EPS) {\n        dy = 10;\n    }\n\n    return (<text x={x} y={y} dx={dx} dy={dy} fill={fill} textAnchor={anchor}>{`${name}`}</text>);\n}\n\nfunction ChromiclePieChart(props) {\n    return (\n    <Grid container spacing={0}>\n      <Grid item xs={12} lg={6}>\n        <div className={props.classes.patternTableWrapper}>\n        <PieChart width={400} height={250} className={props.classes.pieChart}>\n          <Pie data={props.patternGraphData}\n               cx={200}\n               cy={125}\n               outerRadius={60}\n               fill={deepOrange[300]}\n               label={customizedLabel}/>\n          <Tooltip formatter={(value) => `${value.toFixed(2)} hr`}/>\n        </PieChart>\n        </div>\n      </Grid>\n      <Grid item xs={12} lg={6}>\n        <div className={props.classes.patternTableWrapper}>\n        <PieChart width={400} height={250} className={props.classes.pieChart}>\n          <Pie data={props.calendarGraphData}\n               cx={200}\n               cy={125}\n               innerRadius={40}\n               outerRadius={70}\n               fill={cyan[300]}\n               label={customizedLabel}>\n            {props.calendarGraphData.map(d => <Cell fill={d.color}/>)}\n          </Pie>\n          <Tooltip formatter={(value) => `${value.toFixed(2)} hr`}/>\n        </PieChart>\n        </div>\n      </Grid>\n    </Grid>);\n}\n\nChromiclePieChart.propTypes = {\n    patternGraphData: PropTypes.object.isRequired,\n    patterncalendarData: PropTypes.object.isRequired,\n};\n\nclass RegexField extends React.Component {\n    render() {\n        var pitems = this.props.items;\n        let items = [];\n        pitems['0'] = {regex: true, label: null, id: '0'};\n        for (let id in pitems)\n        {\n            items.push(\n                <MenuItem key={id} value={id}>\n                    {pitems[id].label != null && pitems[id].label || 'Regex'}\n                </MenuItem>);\n        }\n        return (\n            <span>\n            <Select\n                value={this.props.value.id}\n                onChange={event => {\n                    let value;\n                    if (pitems[event.target.value].label == null) {\n                        if (this.props.value.regex)\n                            value = {regex: true, value: this.props.value.value, label: null, id: '0'};\n                        else\n                            value = {regex: true, value: `^${this.props.value.value}$`, label: null, id: '0'};\n                    } else {\n                        value = pitems[event.target.value];\n                    }\n                    this.props.onChange({target: {value}});\n                }}\n                className={this.props.value.regex &&\n                        this.props.fieldStyles.regex ||\n                        this.props.fieldStyles.noRegex}>{items}</Select>\n            {this.props.value.label == null && (\n                <TextField\n                 value={this.props.value.value}\n                 onChange={event =>\n                    this.props.onChange({target: { value: {regex: true, value: event.target.value, label: null, id: '0'}}})} />\n            )}\n            </span>\n        );\n    }\n}\n\nfunction CalendarField(props) {\n    let items = {};\n    for (let id in props.cached.calendars) {\n        items[id] = {\n            regex: false,\n            value: props.cached.calendars[id].name,\n            label: props.cached.calendars[id].name, id}\n    }\n    return (\n        <RegexField\n            value={props.value}\n            items={items}\n            fieldStyles={props.fieldStyles}\n            onChange={props.onChange} />);\n}\n\nfunction EventField(props) {\n    let items = {'any': {\n        regex: true,\n        value: '.*',\n        label: 'Any', id: 'any'}};\n    return (\n        <RegexField\n            value={props.value}\n            items={items}\n            fieldStyles={props.fieldStyles}\n            onChange={props.onChange} />);\n}\n\nclass Dashboard extends React.Component {\n    state = {\n        open: true,\n        patterns: [],\n        page: 0,\n        rowsPerPage: 5,\n        timeRange: null,\n        token: getAuthToken(),\n        patternGraphData: default_chart_data,\n        calendarGraphData: default_chart_data,\n        activePattern: null\n    };\n\n    cached = {\n        calendars: {}\n    };\n\n    static patternHead = [\n        {label: \"Name\", field: \"name\", elem: TextField},\n        {label: \"Calendar\", field: \"cal\", elem: CalendarField},\n        {label: \"Event\", field: 'event', elem: EventField}];\n\n    handleChangePage = (event, page) => {\n        this.setState({ page });\n    };\n\n    handleChangeRowsPerPage = event => {\n        this.setState({ rowsPerPage: event.target.value });\n    };\n\n    updatePattern = (field, idx, value) => {\n        let patterns = this.state.patterns;\n        patterns[idx][field] = value;\n        this.setState({ patterns });\n    };\n\n    removePattern = idx => {\n        let patterns = this.state.patterns;\n        patterns.splice(idx, 1);\n        for (let i = 0; i < patterns.length; i++)\n            patterns[i].idx = i;\n        this.setState({ patterns });\n    };\n\n    newPattern = () => {\n        let patterns = [{name: '',\n            cal: { regex: true, label: null, id: '0' },\n            event: { regex: true, value: '.*', label: 'Any', id: 'any' },\n            idx: 0 }, ...this.state.patterns];\n        for (let i = 1; i < patterns.length; i++)\n            patterns[i].idx = i;\n    \tthis.setState({ patterns });\n    };\n\n    analyze = () => {\n        if (!(this.state.startDate && this.state.endDate)) {\n            alert(\"Please choose a valid time range.\");\n            return;\n        }\n        let start = this.state.startDate.toISOString();\n        let end = this.state.endDate.toISOString();\n        let event_pms = [];\n        for (let id in this.cached.calendars) {\n            event_pms.push(\n                this.state.token\n                .then(genEventsGetter(id, start, end))\n                .then(items => this.cached.calendars[id].events = items));\n        }\n\n        Promise.all(event_pms).then(() => {\n            let results = {}; // pattern idx => time\n            let cal_results = {}; // cal id => time\n            for (let i = 0; i < this.state.patterns.length; i++)\n                results[i] = 0;\n            for (let id in this.cached.calendars) {\n                let patterns = filterPatterns(this.state.patterns, this.cached.calendars[id].name)\n                    .map(p => { return { regex: new RegExp(p.event.value), idx: p.idx } });\n                if (!this.cached.calendars[id].events) continue;\n                this.cached.calendars[id].events.forEach(event => {\n                    if (event.status != \"confirmed\") return;\n                    patterns.forEach(p => {\n                        if (!p.regex.test(event.summary)) return;\n                        if (cal_results[id] === undefined) {\n                            cal_results[id] = 0;\n                        }\n                        let duration = (new Date(event.end.dateTime) - new Date(event.start.dateTime)) / 60000;\n                        results[p.idx] += duration;\n                        cal_results[id] += duration;\n                    });\n                });\n            }\n            let patternGraphData = [];\n            let calendarGraphData = [];\n            for (let i = 0; i < this.state.patterns.length; i++) {\n                patternGraphData.push({ name: this.state.patterns[i].name, value: results[i] / 60.0 });\n            }\n            for (let id in cal_results) {\n                calendarGraphData.push({\n                    name: this.cached.calendars[id].name,\n                    value: (cal_results[id] / 60.0),\n                    color: this.cached.calendars[id].color.background});\n            }\n            this.setState({ patternGraphData, calendarGraphData });\n        });\n    };\n\n    loadPatterns = () => {\n        let token = this.state.token;\n        let colors = token.then(getColors).then(color => {\n            return color.calendar;\n        });\n        let cals = token.then(getCalendars);\n        Promise.all([colors, cals]).then(([colors, items]) => {\n            items.forEach(item => {\n                this.cached.calendars[item.id] = {\n                    name: item.summary,\n                    events: {},\n                    color: colors[item.colorId]\n                };\n            });\n            this.setState({ patterns: items.map((item, idx) => {\n                return { name: item.summary,\n                         cal: { regex: false, value: item.summary, label: item.summary, id: item.id },\n                         event: { regex: true, value: '.*', label: 'Any', id: 'any' },\n                         idx }\n            })});\n        });\n    };\n\n    render() {\n      const { classes } = this.props;\n      const { patterns, rows, rowsPerPage, page } = this.state;\n      const nDummy = rowsPerPage - Math.min(rowsPerPage, patterns.length - page * rowsPerPage);\n\n      return (\n      <MuiThemeProvider theme={theme}>\n        <div className={classes.root}>\n          <AppBar\n           position=\"absolute\"\n           className={classes.appBar}>\n            <Toolbar disableGutters={!this.state.open} className={classes.toolbar}>\n              <Typography component=\"h1\" variant=\"h6\" color=\"inherit\" noWrap className={classes.title}>\n                <Logo style={{width: '2em', verticalAlign: 'bottom', marginRight: '0.2em'}}/>Chromicle\n              </Typography>\n            </Toolbar>\n          </AppBar>\n          <main className={classes.content}>\n            <div className={classes.appBarSpacer} />\n              <Grid container  spacing={16}>\n              <CssBaseline />\n              <Grid item md={6} xs={12}>\n                <FormControl fullWidth={true}>\n                  <FormGroup>\n                    <Typography variant=\"h6\" component=\"h1\" gutterBottom>\n                      Event Patterns\n                      <IconButton\n                       style={{marginBottom: '0.12em', marginLeft: '0.5em'}}\n                       onClick={() => this.newPattern()}><AddCircleIcon /></IconButton>\n                    </Typography>\n                    <div className={classes.patternTableWrapper}>\n                    <Table className={classes.patternTable}>\n                      <TableHead>\n                        <TableRow>{Dashboard.patternHead.map(s => (<TableCell>{s.label}</TableCell>))}</TableRow>\n                      </TableHead>\n                      <TableBody>\n                        {patterns.slice(page * rowsPerPage, (page + 1) * rowsPerPage).map(p => (\n                            <TableRow\n                             onMouseOver={() => this.setState({ activePattern: p.idx })}\n                             onMouseOut={() => this.setState({ activePattern: null })}>\n                                {Dashboard.patternHead.map(s => {\n                                    const CustomText = s.elem;\n                                    return (\n                                <TableCell>\n                                  <CustomText\n                                   value={p[s.field]}\n                                   cached={this.cached}\n                                   fieldStyles={{noRegex: classes.fieldNoRegex, regex: classes.fieldRegex}}\n                                   onChange={event => this.updatePattern(s.field, p.idx, event.target.value)}/>\n                                  </TableCell>)})}\n                                  <span style={(this.state.activePattern == p.idx &&\n                                                  { position: 'absolute', right: 0, height: 48 }) ||\n                                                  { display: 'none' }}>\n                                    <DeleteOutlinedIcon\n                                     style={{ height: '100%', cursor: 'pointer' }}\n                                     onClick={() => this.removePattern(p.idx)} />\n                                  </span>\n                            </TableRow>))}\n                        {nDummy > 0 && (\n                            <TableRow style={{ height: 48 * nDummy }}>\n                              <TableCell colSpan={Dashboard.patternHead.length} />\n                            </TableRow>)}\n                      </TableBody>\n                    </Table>\n                    </div>\n                    <TablePagination\n                       rowsPerPageOptions={[5, 10, 25]}\n                       component=\"div\"\n                       count={patterns.length}\n                       rowsPerPage={rowsPerPage}\n                       page={page}\n                       backIconButtonProps={{'aria-label': 'Previous Page'}}\n                       nextIconButtonProps={{'aria-label': 'Next Page'}}\n                       onChangePage={this.handleChangePage}\n                       onChangeRowsPerPage={this.handleChangeRowsPerPage}/>\n                  </FormGroup>\n                  <FormGroup>\n            \t    <Typography variant=\"h6\" component=\"h1\" gutterBottom>\n            \t      Time Range\n            \t    </Typography>\n                    <div style={{textAlign: 'center'}}>\n                      <DateRangePicker\n    \t\t\t       startDate={this.state.startDate} // momentPropTypes.momentObj or null,\n    \t\t\t       startDateId=\"your_unique_start_date_id\" // PropTypes.string.isRequired,\n    \t\t\t       endDate={this.state.endDate} // momentPropTypes.momentObj or null,\n    \t\t\t       endDateId=\"your_unique_end_date_id\" // PropTypes.string.isRequired,\n    \t\t\t       onDatesChange={({ startDate, endDate }) => {\n                         //if (startDate && endDate)\n                         //    this.setState({ timeRange: [startDate.toISOString(), endDate.toISOString()]});\n                         this.setState({ startDate, endDate });\n                       }} // PropTypes.func.isRequired,\n    \t\t\t       focusedInput={this.state.focusedInput} // PropTypes.oneOf([START_DATE, END_DATE]) or null,\n    \t\t\t       onFocusChange={focusedInput => this.setState({ focusedInput })} // PropTypes.func.isRequired,\n                       isOutsideRange={() => false}/>\n                    </div>\n                  </FormGroup>\n                  <div className={classes.buttonSpacer} />\n                  <Grid container spacing={16}>\n                    <Grid item md={6} xs={12}>\n                      <FormGroup>\n                        <Button variant=\"contained\" color=\"primary\" onClick={this.loadPatterns}>Load</Button>\n                        </FormGroup>\n                    </Grid>\n                    <Grid item md={6} xs={12}>\n                      <FormGroup>\n                        <Button variant=\"contained\" color=\"primary\" onClick={this.analyze}>Analyze</Button>\n                      </FormGroup>\n                    </Grid>\n                  </Grid>\n                </FormControl>\n              </Grid>\n              <Grid item md={6} xs={12}>\n                <Typography variant=\"h6\" component=\"h1\" gutterBottom>\n                  Graph\n                </Typography>\n                  <ChromiclePieChart\n                   patternGraphData={this.state.patternGraphData}\n                   calendarGraphData={this.state.calendarGraphData}\n                   classes={classes}/>\n              </Grid>\n            </Grid>\n          </main>\n        </div>\n      </MuiThemeProvider>);\n    }\n}\n\nDashboard.propTypes = {\n  classes: PropTypes.object.isRequired,\n};\n\nexport default withStyles(styles)(Dashboard);\n","// This optional code is used to register a service worker.\n// register() is not called by default.\n\n// This lets the app load faster on subsequent visits in production, and gives\n// it offline capabilities. However, it also means that developers (and users)\n// will only see deployed updates on subsequent visits to a page, after all the\n// existing tabs open on the page have been closed, since previously cached\n// resources are updated in the background.\n\n// To learn more about the benefits of this model and instructions on how to\n// opt-in, read http://bit.ly/CRA-PWA\n\nconst isLocalhost = Boolean(\n  window.location.hostname === 'localhost' ||\n    // [::1] is the IPv6 localhost address.\n    window.location.hostname === '[::1]' ||\n    // 127.0.0.1/8 is considered localhost for IPv4.\n    window.location.hostname.match(\n      /^127(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/\n    )\n);\n\nexport function register(config) {\n  if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) {\n    // The URL constructor is available in all browsers that support SW.\n    const publicUrl = new URL(process.env.PUBLIC_URL, window.location.href);\n    if (publicUrl.origin !== window.location.origin) {\n      // Our service worker won't work if PUBLIC_URL is on a different origin\n      // from what our page is served on. This might happen if a CDN is used to\n      // serve assets; see https://github.com/facebook/create-react-app/issues/2374\n      return;\n    }\n\n    window.addEventListener('load', () => {\n      const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`;\n\n      if (isLocalhost) {\n        // This is running on localhost. Let's check if a service worker still exists or not.\n        checkValidServiceWorker(swUrl, config);\n\n        // Add some additional logging to localhost, pointing developers to the\n        // service worker/PWA documentation.\n        navigator.serviceWorker.ready.then(() => {\n          console.log(\n            'This web app is being served cache-first by a service ' +\n              'worker. To learn more, visit http://bit.ly/CRA-PWA'\n          );\n        });\n      } else {\n        // Is not localhost. Just register service worker\n        registerValidSW(swUrl, config);\n      }\n    });\n  }\n}\n\nfunction registerValidSW(swUrl, config) {\n  navigator.serviceWorker\n    .register(swUrl)\n    .then(registration => {\n      registration.onupdatefound = () => {\n        const installingWorker = registration.installing;\n        if (installingWorker == null) {\n          return;\n        }\n        installingWorker.onstatechange = () => {\n          if (installingWorker.state === 'installed') {\n            if (navigator.serviceWorker.controller) {\n              // At this point, the updated precached content has been fetched,\n              // but the previous service worker will still serve the older\n              // content until all client tabs are closed.\n              console.log(\n                'New content is available and will be used when all ' +\n                  'tabs for this page are closed. See http://bit.ly/CRA-PWA.'\n              );\n\n              // Execute callback\n              if (config && config.onUpdate) {\n                config.onUpdate(registration);\n              }\n            } else {\n              // At this point, everything has been precached.\n              // It's the perfect time to display a\n              // \"Content is cached for offline use.\" message.\n              console.log('Content is cached for offline use.');\n\n              // Execute callback\n              if (config && config.onSuccess) {\n                config.onSuccess(registration);\n              }\n            }\n          }\n        };\n      };\n    })\n    .catch(error => {\n      console.error('Error during service worker registration:', error);\n    });\n}\n\nfunction checkValidServiceWorker(swUrl, config) {\n  // Check if the service worker can be found. If it can't reload the page.\n  fetch(swUrl)\n    .then(response => {\n      // Ensure service worker exists, and that we really are getting a JS file.\n      const contentType = response.headers.get('content-type');\n      if (\n        response.status === 404 ||\n        (contentType != null && contentType.indexOf('javascript') === -1)\n      ) {\n        // No service worker found. Probably a different app. Reload the page.\n        navigator.serviceWorker.ready.then(registration => {\n          registration.unregister().then(() => {\n            window.location.reload();\n          });\n        });\n      } else {\n        // Service worker found. Proceed as normal.\n        registerValidSW(swUrl, config);\n      }\n    })\n    .catch(() => {\n      console.log(\n        'No internet connection found. App is running in offline mode.'\n      );\n    });\n}\n\nexport function unregister() {\n  if ('serviceWorker' in navigator) {\n    navigator.serviceWorker.ready.then(registration => {\n      registration.unregister();\n    });\n  }\n}\n","import React from 'react';\nimport ReactDOM from 'react-dom';\nimport App from './App';\nimport * as serviceWorker from './serviceWorker';\n\nReactDOM.render(<App />, document.getElementById('root'));\n\n// If you want your app to work offline and load faster, you can change\n// unregister() to register() below. Note this comes with some pitfalls.\n// Learn more about service workers: http://bit.ly/CRA-PWA\nserviceWorker.unregister();\n"],"sourceRoot":""}