Skip to content

Commit

Permalink
Load workflows with the project
Browse files Browse the repository at this point in the history
  • Loading branch information
eatyourgreens committed Jun 13, 2017
1 parent b399a74 commit b49dfdd
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 10 deletions.
11 changes: 5 additions & 6 deletions src/components/ProjectDashboard.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,11 +16,12 @@ function ProjectDashboard(props) {
<ProjectContentsContainer {...props}>
<ProjectContents />
</ProjectContentsContainer>
<h3>Workflows</h3>
<ul>
{project.links.workflows.map((id) => {
{project.workflows.map((workflow) => {
return (
<li key={id}>
<Link to={`/project/${project.id}/workflow/${id}`}>{id}</Link>
<li key={workflow.id}>
<Link to={`/project/${project.id}/workflow/${workflow.id}`}>{workflow.display_name}</Link>
</li>
);
})}
Expand All @@ -33,9 +34,7 @@ ProjectDashboard.propTypes = propTypes;

ProjectDashboard.defaultProps = {
project: {
links: {
workflows: []
}
workflows: []
}
};

Expand Down
31 changes: 27 additions & 4 deletions src/ducks/project.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,14 @@ import apiClient from 'panoptes-client/lib/api-client';
export const FETCH_PROJECT = 'FETCH_PROJECT';
export const FETCH_PROJECT_SUCCESS = 'FETCH_PROJECT_SUCCESS';
export const FETCH_PROJECT_ERROR = 'FETCH_PROJECT_ERROR';
export const FETCH_WORKFLOWS = 'FETCH_WORKFLOWS';
export const FETCH_WORKFLOWS_SUCCESS = 'FETCH_WORKFLOWS_SUCCESS';
export const FETCH_WORKFLOWS_ERROR = 'FETCH_WORKFLOWS_ERROR';

// Reducer
const initialState = {
data: {
links: {
workflows: []
}
workflows: []
},
error: false,
loading: false,
Expand All @@ -24,6 +25,10 @@ const projectReducer = (state = initialState, action) => {
return Object.assign({}, state, { data: action.payload, loading: false });
case FETCH_PROJECT_ERROR:
return Object.assign({}, state, { error: action.payload, loading: false });
case FETCH_WORKFLOWS:
return Object.assign({}, state, { loading: true });
case FETCH_WORKFLOWS_SUCCESS:
return Object.assign({}, state, { data: Object.assign(state.data, { workflows: action.payload }), loading: false });
default:
return state;
}
Expand All @@ -37,10 +42,13 @@ const fetchProject = (id) => {
});
const query = {
id,
current_user_roles: ['owner', 'translator']
current_user_roles: ['owner', 'translator'],
include: ['workflows']
};
apiClient.type('projects').get(query)
.then(([project]) => {
project.workflows = [];
dispatch(fetchWorkflows(project));
dispatch({
type: FETCH_PROJECT_SUCCESS,
payload: project,
Expand All @@ -49,6 +57,21 @@ const fetchProject = (id) => {
};
};

function fetchWorkflows(project) {
return (dispatch) => {
dispatch({
type: FETCH_WORKFLOWS,
});
apiClient.type('workflows').get(project.links.workflows)
.then((workflows) => {
dispatch({
type: FETCH_WORKFLOWS_SUCCESS,
payload: workflows,
});
});
};
}

// Exports
export default projectReducer;

Expand Down

0 comments on commit b49dfdd

Please sign in to comment.