context = window PLAYBACK_MONITOR_MODE = context.JK.PLAYBACK_MONITOR_MODE EVENTS = context.JK.EVENTS logger = context.JK.logger mixins = [] # this check ensures we attempt to listen if this component is created in a popup reactContext = if window.opener? then window.opener else window # make sure this is actually us opening the window, not someone else (by checking for MixerStore) if window.opener? try m = window.opener.MixerStore catch e reactContext = window MixerStore = reactContext.MixerStore MixerActions = reactContext.MixerActions MediaPlaybackStore = reactContext.MediaPlaybackStore SessionActions = reactContext.SessionActions MediaPlaybackActions = reactContext.MediaPlaybackActions mixins.push(Reflux.listenTo(MixerStore,"onInputsChanged")) mixins.push(Reflux.listenTo(MediaPlaybackStore, 'onMediaStateChanged')) @MediaControls = React.createClass({ mixins: mixins tempos : [ 40, 42, 44, 46, 48, 50, 52, 54, 56, 58, 60, 63, 66, 69, 72, 76, 80, 84, 88, 92, 96, 100, 104, 108, 112, 116, 120, 126, 132, 138, 144, 152, 160, 168, 176, 184, 192, 200, 208 ] onMediaStateChanged: (changes) -> if changes.playbackStateChanged if @state.controls? if changes.playbackState == 'play_start' @state.controls.onPlayStartEvent() else if changes.playbackState == 'play_stop' @state.controls.onPlayStopEvent() else if changes.playbackState == 'play_pause' @state.controls.onPlayPauseEvent(); else if changes.positionUpdateChanged if @state.controls? @state.controls.executeMonitor(changes.positionMs, changes.durationMs, changes.isPlaying) onInputsChanged: (sessionMixers) -> session = sessionMixers.session mixers = sessionMixers.mixers if @state.controls? mediaSummary = mixers.mediaSummary metro = mixers.metro @monitorControls(@state.controls, mediaSummary) @setState({mediaSummary: mediaSummary, metro: metro}) @updateMetronomeDetails(metro, @state.initializedMetronomeControls) updateMetronomeDetails: (metro, initializedMetronomeControls) -> logger.debug("MediaControls: setting tempo/sound/cricket", metro) $root = jQuery(this.getDOMNode()) $root.find("select.metro-tempo").val(metro.tempo) $root.find("select.metro-sound").val(metro.sound) if initializedMetronomeControls mode = if metro.cricket then 'cricket' else 'self' logger.debug("settingcricket", mode) $root.find('#metronome-playback-select').metronomeSetPlaybackMode(mode) monitorControls: (controls, mediaSummary) -> if mediaSummary.mediaOpen if mediaSummary.jamTrackOpen controls.startMonitor(PLAYBACK_MONITOR_MODE.JAMTRACK) else if mediaSummary.backingTrackOpen controls.startMonitor(PLAYBACK_MONITOR_MODE.MEDIA_FILE) else if mediaSummary.metronomeOpen controls.startMonitor(PLAYBACK_MONITOR_MODE.METRONOME) else if mediaSummary.recordingOpen controls.startMonitor(PLAYBACK_MONITOR_MODE.MEDIA_FILE) else logger.debug("unable to determine mediaOpen type", mediaSummary) controls.startMonitor(PLAYBACK_MONITOR_MODE.MEDIA_FILE) else controls.stopMonitor() metronomePlaybackModeChanged: (e, data) -> mode = data.playbackMode # will be either 'self' or 'cricket' logger.debug("setting metronome playback mode: ", mode) isCricket = mode == 'cricket'; SessionActions.metronomeCricketChange(isCricket) onMetronomeChanged: () -> @setMetronomeFromForm() setMetronomeFromForm: () -> $root = jQuery(this.getDOMNode()) tempo = $root.find("select.metro-tempo:visible option:selected").val() sound = $root.find("select.metro-sound:visible option:selected").val() t = parseInt(tempo) s = null if tempo == NaN || tempo == 0 || tempo == null t = 120 if sound == null || typeof(sound)=='undefined' || sound == "" s = "Beep" else s = sound logger.debug("Setting tempo and sound:", t, s) MixerActions.metronomeChanged(t, s, 1, 0) render: () -> tempo_options = [] for tempo in @tempos tempo_options.push(``) `
` getInitialState: () -> {controls: null, mediaSummary: {}, initializedMetronomeControls: false} tryPrepareMetronome: (metro) -> if @state.mediaSummary.metronomeOpen && !@state.initializedMetronomeControls $root = jQuery(this.getDOMNode()) $root.on("change", ".metronome-select", @onMetronomeChanged) $root.find('#metronome-playback-select').metronomePlaybackMode({positions:['bottom'], offsetParent:$('#minimal-container')}).on(EVENTS.METRONOME_PLAYBACK_MODE_SELECTED, @metronomePlaybackModeChanged) @updateMetronomeDetails(metro, true) @setState({initializedMetronomeControls: true}) componentDidUpdate: (prevProps, prevState) -> @tryPrepareMetronome(@state.metro) componentDidMount: () -> $root = jQuery(this.getDOMNode()) controls = context.JK.PlaybackControls($root, {mediaActions: MediaPlaybackActions}) mediaSummary = MixerStore.mixers.mediaSummary metro = MixerStore.mixers.metro @monitorControls(controls, mediaSummary) @tryPrepareMetronome(metro) @setState({mediaSummary: mediaSummary, controls: controls, metro: metro}) })