debugged state mismatch

This commit is contained in:
bill bittner 2018-02-07 20:15:44 -08:00
parent d219cbf1a2
commit d1a71cf74f
6 changed files with 71 additions and 63 deletions

View file

@ -9,16 +9,19 @@ export function updateRequestError (error) {
}
export function updateRequestWithChannelRequest (name, id) {
const requestId = `cr#${name}#${id}`;
return {
type: actions.REQUEST_CHANNEL_UPDATE,
data: { name, id },
data: { requestId, name, id },
};
};
export function updateRequestWithAssetRequest (name, id, channelName, channelId, extension) {
const requestId = `ar#${name}#${id}#${channelName}#${channelId}`;
return {
type: actions.REQUEST_CLAIM_UPDATE,
data: {
requestId,
name,
modifier: {
id,

View file

@ -5,15 +5,17 @@ import { newAssetRequest, updateRequestError, showNewAsset, updateShowAsset, cle
const mapStateToProps = ({ show }) => {
return {
// new
requestName : show.assetRequest.name,
requestModifier : show.assetRequest.modifier,
requestExtension: show.assetRequest.extension,
requestId : show.request.id,
requestName : show.request.data.name,
requestModifier : show.request.data.modifier,
requestExtension: show.request.data.extension,
assetRequests : show.assetRequests,
assets : show.assets,
// old
error : show.showAsset.error,
name : show.showAsset.name,
claimData : show.showAsset.claimData,
showAsset : show.assets[show.request.id],
};
};

View file

@ -3,44 +3,31 @@ import ErrorPage from 'components/ErrorPage';
import ShowAssetLite from 'components/ShowAssetLite';
import ShowAssetDetails from 'components/ShowAssetDetails';
function buildIdFromModifierObject (name, modifier) {
if (modifier) {
if (modifier.channel.name) {
return `${name}#${modifier.channel.name}#${modifier.channel.id}`;
}
return `${name}#${modifier.id}`;
}
return `${name}`;
}
function buildIdFromNameAndClaimId (name, claimId) {
return `${name}#${claimId}`;
}
class ShowAsset extends React.Component {
componentDidMount () {
const { requestName, requestModifier, assetRequests } = this.props;
const id = buildIdFromModifierObject(requestName, requestModifier);
const { requestId, requestName, requestModifier, assetRequests } = this.props;
// check to see if we have this asset
if (assetRequests[id]) { // case: the assetRequest exists
const request = assetRequests[id];
this.onRepeatRequest(id, request);
if (assetRequests[requestId]) { // case: the assetRequest exists
const request = assetRequests[requestId];
this.onRepeatRequest(requestId, request);
} else { // case: the asset request does not exist
this.onNewRequest(id, requestName, requestModifier);
this.onNewRequest(requestId, requestName, requestModifier);
}
}
componentWillReceiveProps (nextProps) {
if (nextProps.assetRequests !== this.props.assetRequests) {
console.log('assetRequests updated:');
const { requestName, requestModifier, assetRequests } = nextProps;
const id = buildIdFromModifierObject(requestName, requestModifier);
// case where componentDidMount triggered new props
if (nextProps.assetRequests !== this.props.assetRequests) { // note: reason for not showing small url requests?
console.log('show.assetRequests updated');
const { requestId, requestName, requestModifier, assetRequests } = nextProps;
// if the component received new assetRequests, check again to see if the current request matches one
if (assetRequests[id]) { // case: the assetRequest exists
const request = assetRequests[id];
this.onRepeatRequest(id, request);
if (assetRequests[requestId]) { // case: the assetRequest exists
const request = assetRequests[requestId];
this.onRepeatRequest(requestId, request);
} else { // case: the asset request does not exist
this.onNewRequest(id, requestName, requestModifier);
this.onNewRequest(requestId, requestName, requestModifier);
}
} else {
console.log('show.assetRequests did not update');
}
}
onNewRequest (id, requestName, requestModifier) {
@ -51,7 +38,7 @@ class ShowAsset extends React.Component {
console.log('repeat request');
const { assets } = this.props;
const { error: requestError, name, claimId } = request;
const assetId = buildIdFromNameAndClaimId(name, claimId);
const assetId = `a#${name}#${claimId}`;
// if error, return and update state with error
if (requestError) {
return this.props.onRequestError(requestError);
@ -74,7 +61,7 @@ class ShowAsset extends React.Component {
<ErrorPage error={error}/>
);
}
if (name) {
if (name) { // direct requests are passing because name is present so it just goes
if (requestExtension) {
return (
<ShowAssetLite />

View file

@ -4,8 +4,9 @@ import View from './view';
const mapStateToProps = ({ show }) => {
return {
requestName: show.channelRequest.name,
requestId : show.channelRequest.id,
requestId : show.request.id,
requestChannelName: show.request.data.name,
requestChannelId : show.request.data.id,
error : show.showChannel.error,
name : show.showChannel.channelData.name,
shortId : show.showChannel.channelData.shortId,

View file

@ -6,14 +6,18 @@ import request from 'utils/request';
class ShowChannel extends React.Component {
componentDidMount () {
this.getAndStoreChannelData(this.props.requestName, this.props.requestId);
console.log('showchannel did mount');
const {requestChannelName, requestChannelId} = this.props;
this.getAndStoreChannelData(requestChannelName, requestChannelId);
}
componentWillReceiveProps (nextProps) {
if (nextProps.requestName !== this.props.requestName || nextProps.requestId !== this.props.requestId) {
this.getAndStoreChannelData(nextProps.requestName, nextProps.requestId);
if (nextProps.channelRequests !== this.props.channelRequests) {
const {requestChannelName, requestChannelId} = nextProps;
this.getAndStoreChannelData(requestChannelName, requestChannelId);
}
}
getAndStoreChannelData (name, id) {
console.log('getting and storing channel data for channel:', name, id);
if (!id) id = 'none';
const url = `/api/channel/data/${name}/${id}`;
return request(url)

View file

@ -6,22 +6,24 @@ const initialState = {
request: {
error : null,
type : null,
data : null,
requestId: null,
},
channelRequest: {
name: null,
id : null,
},
assetRequest: {
name : null,
modifier: {
id : null,
channel: {
name: null,
id : null,
},
},
extension: null,
},
// channelRequest: {
// name: null,
// id : null,
// },
// assetRequest: {
// name : null,
// modifier: {
// id : null,
// channel: {
// name: null,
// id : null,
// },
// },
// extension: null,
// },
showChannel: {
error : null,
channelData: {
@ -71,21 +73,30 @@ export default function (state = initialState, action) {
request: {
type : CHANNEL,
error: null,
id : action.data.requestId,
data : {
name: action.data.name,
id : action.data.id,
},
},
channelRequest: action.data,
});
case actions.REQUEST_CLAIM_UPDATE:
return Object.assign({}, state, {
request: {
type : ASSET,
error: null,
id : action.data.requestId,
data : {
name : action.data.name,
modifier : action.data.modifier,
extension: action.data.extension,
},
},
assetRequest: action.data,
});
// request for an asset
case actions.ASSET_REQUEST_ADD:
return Object.assign({}, state, {
assetRequests: Object.assign({}, state.assets, {
assetRequests: Object.assign({}, state.assetRequests, {
[action.data.id]: {
error : action.data.error,
name : action.data.name,