var App = React.createClass({ getInitialState: function() { // For now, routes are in format ?page or ?page=args var match, param, val, viewingPage, drawerOpenRaw = sessionStorage.getItem('drawerOpen'); [match, param, val] = window.location.search.match(/\??([^=]*)(?:=(.*))?/); if (param && ['settings', 'discover', 'help', 'start', 'watch', 'report', 'files', 'claim', 'show', 'wallet', 'publish'].indexOf(param) != -1) { viewingPage = param; } return { viewingPage: viewingPage ? viewingPage : 'discover', drawerOpen: drawerOpenRaw !== null ? JSON.parse(drawerOpenRaw) : true, pageArgs: val, }; }, componentDidMount: function() { lbry.getStartNotice(function(notice) { if (notice) { alert(notice); } }); }, componentWillMount: function() { lbry.checkNewVersionAvailable(function(isAvailable) { if (!isAvailable || sessionStorage.getItem('upgradeSkipped')) { return; } var message = 'The version of LBRY you\'re using is not up to date.\n\n' + 'Choose "OK" to download the latest version.'; lbry.getVersionInfo(function(versionInfo) { if (versionInfo.os_system == 'Darwin') { var updateUrl = 'https://lbry.io/get/lbry.dmg'; var maj, min, patch; [maj, min, patch] = versionInfo.lbrynet_version.split('.'); if (maj == 0 && min <= 2 && patch <= 2) { // On OS X with version <= 0.2.2, we need to notify user to close manually close LBRY message += '\n\nBefore installing the new version, make sure to exit LBRY, if you started the app ' + 'click that LBRY icon in your status bar and choose "Quit."'; } } else { var updateUrl = 'https://lbry.io/get/lbry.deb'; } if (window.confirm(message)) { lbry.stop(); window.location = updateUrl; } else { sessionStorage.setItem('upgradeSkipped', true); }; }); }); }, openDrawer: function() { sessionStorage.setItem('drawerOpen', true); this.setState({ drawerOpen: true }); }, closeDrawer: function() { sessionStorage.setItem('drawerOpen', false); this.setState({ drawerOpen: false }); }, onSearch: function(term) { this.setState({ viewingPage: 'discover', pageArgs: term }); }, getMainContent: function() { switch(this.state.viewingPage) { case 'discover': return ; case 'settings': return ; case 'help': return ; case 'watch': return ; case 'report': return ; case 'files': return ; case 'start': return ; case 'claim': return ; case 'wallet': return ; case 'show': return ; case 'publish': return ; } }, render: function() { var mainContent = this.getMainContent(); return ( this.state.viewingPage == 'watch' ? mainContent :
{mainContent}
); } });