/*** @jsx React.DOM */ var valid_versions = Object.keys(window.versions); var pagenav = new History(valid_versions); var menu_option_names = { 'alphabet': 'alphabet folders', 'difficulty': 'difficulty folders', 'disable_song_preview': 'disable song previews', 'effector_lock': 'lock effector', 'grade': 'grade folders', 'hide_play_count': 'hide play count on profile', 'rival_info': 'rival info box', 'rival_played': 'rival played folders', 'rival_win_lose': 'rival win/lose folders', 'status': 'status folders', }; var valid_menu_options = [ 'grade', 'status', 'difficulty', 'alphabet', 'rival_played', 'rival_win_lose', 'rival_info', 'hide_play_count', 'disable_song_preview', 'effector_lock', ]; var theme_option_names = { 'beam': 'Note Beam', 'bgm': 'Menu BGM', 'burst': 'Note Burst', 'frame': 'Frame', 'full_combo': 'Full Combo Effect', 'judge': 'Judge Font', 'noteskin': 'Note Skin', 'towel': 'Lane Cover', 'turntable': 'Turntable Decal', 'voice': 'Menu Announcer Voice', 'pacemaker': 'Pacemaker Skin', 'effector_preset': 'Effector Preset', }; var settings_view = React.createClass({ getInitialState: function(props) { var profiles = Object.keys(window.player); var version = pagenav.getInitialState(profiles[profiles.length - 1]); return { player: window.player, profiles: profiles, version: version, menu_changed: {}, theme_changed: {}, menu_saving: {}, theme_saving: {}, menu_saved: {}, theme_saved: {}, new_name: window.player[version].name, editing_name: false, new_prefecture: window.player[version].prefecture, editing_prefecture: false, }; }, componentDidMount: function() { pagenav.onChange(function(version) { this.setState({version: version}); }.bind(this)); }, componentDidUpdate: function() { if (this.focus_element && this.focus_element != this.already_focused) { this.focus_element.focus(); this.already_focused = this.focus_element; } }, setMenuChanged: function(val) { this.state.menu_changed[this.state.version] = val; return this.state.menu_changed; }, setMenuSaving: function(val) { this.state.menu_saving[this.state.version] = val; return this.state.menu_saving; }, setMenuSaved: function(val) { this.state.menu_saved[this.state.version] = val; return this.state.menu_saved; }, setThemeChanged: function(val) { this.state.theme_changed[this.state.version] = val; return this.state.theme_changed; }, setThemeSaving: function(val) { this.state.theme_saving[this.state.version] = val; return this.state.theme_saving; }, setThemeSaved: function(val) { this.state.theme_saved[this.state.version] = val; return this.state.theme_saved; }, saveMenuOptions: function(event) { this.setState({menu_saving: this.setMenuSaving(true), menu_saved: this.setMenuSaved(false)}); AJAX.post( Link.get('updateflags'), { version: this.state.version, flags: this.state.player[this.state.version].flags, }, function(response) { var player = this.state.player; player[response.version].flags = response.flags; this.setState({ player: player, menu_saving: this.setMenuSaving(false), menu_saved: this.setMenuSaved(true), menu_changed: this.setMenuChanged(false), }); }.bind(this) ); event.preventDefault(); }, saveThemeOptions: function(event) { this.setState({theme_saving: this.setThemeSaving(true), theme_saved: this.setThemeSaved(false)}); AJAX.post( Link.get('updatesettings'), { version: this.state.version, settings: this.state.player[this.state.version].settings, }, function(response) { var player = this.state.player; player[response.version].settings = response.settings; this.setState({ player: player, theme_saving: this.setThemeSaving(false), theme_saved: this.setThemeSaved(true), theme_changed: this.setThemeChanged(false), }); }.bind(this) ); event.preventDefault(); }, saveDJName: function(event) { AJAX.post( Link.get('updatename'), { version: this.state.version, name: this.state.new_name, }, function(response) { var player = this.state.player; player[response.version].name = response.name; this.setState({ player: player, new_name: this.state.player[response.version].name, editing_name: false, }); }.bind(this) ); event.preventDefault(); }, savePrefecture: function(event) { AJAX.post( Link.get('updateprefecture'), { version: this.state.version, prefecture: this.state.new_prefecture, }, function(response) { var player = this.state.player; player[response.version].prefecture = response.prefecture; this.setState({ player: player, new_prefecture: this.state.player[response.version].prefecture, editing_prefecture: false, }); }.bind(this) ); event.preventDefault(); }, leaveArcade: function(event) { AJAX.post( Link.get('leavearcade'), { version: this.state.version, }, function(response) { var player = this.state.player; player[response.version].arcade = ""; this.setState({ player: player, }); }.bind(this) ); event.preventDefault(); }, renderDJName: function(player) { return ( { !this.state.editing_name ? {player.name} :
(this.focus_element = c)} value={this.state.new_name} onChange={function(event) { var value = event.target.value.toUpperCase(); var intRegex = /^[-&$#\\.\\?\\*!A-Z0-9]*$/; if (value.length <= 6 && intRegex.test(value)) { this.setState({new_name: value}); } }.bind(this)} name="name" />
}
); }, renderPrefecture: function(player) { return ( { !this.state.editing_prefecture ? {Regions[player.prefecture]} :
}
); }, renderHomeArcade: function(player) { if (!player.arcade || player.arcade == "") { return ( no arcade ); } return ( {player.arcade} ); }, render: function() { if (this.state.player[this.state.version]) { var player = this.state.player[this.state.version]; return (
{this.state.profiles.map(function(version) { return (

User Profile

{this.renderDJName(player)} {this.renderPrefecture(player)} {this.renderHomeArcade(player)}

Theme

{Object.keys(IIDXOptions[this.state.version]).map(function(theme_option) { return ( ); }.bind(this))} { this.state.theme_saving[this.state.version] ? : null } { this.state.theme_saved[this.state.version] ? { "\u2713" } : null }

Menu Options

{valid_menu_options.map(function(menu_option) { return (
); }.bind(this))} { this.state.menu_saving[this.state.version] ? : null } { this.state.menu_saved[this.state.version] ? { "\u2713" } : null }
); } else { return (
You have no profile for {window.versions[this.state.version]}!
{this.state.profiles.map(function(version) { return (
); } }, }); ReactDOM.render( React.createElement(settings_view, null), document.getElementById('content') );