index.js 1.95 KB
// import { StudentDataController }            from '/imports/client/views/org/admin/students/index'
import _                                  from 'lodash';
import {
         composeWithTracker,
         compose,
         composeAll
       }                                  from 'react-komposer';
import { Loading }                        from '/imports/client/components/Loading';

import { Orgs }                           from '/imports/collections/orgs/index';
import { Users }                          from '/imports/collections/users/index';
import { StudentView }                    from './StudentView';
import { Students }                       from '/imports/collections/students/index';


const meteorTick = (props, onData) => {

  const handles = [
    Meteor.subscribe('users.current'),
    Meteor.subscribe('orgs.current'),
    Meteor.subscribe('users.forMyOrg'),
    Meteor.subscribe('student.forMyOrg'),
  ];

  if(_.every(handles, (handle) => (handle.ready()) )) {
    const user = Users.current();
    const org = Orgs.current();
    students = Users.find({"role":"STUDENT"}).fetch() ? Users.find({"role":"STUDENT"}).fetch() : "";
    console.log(students);
    studentData = Students.find().fetch() ? Students.find().fetch() : "";
    for(var i=0; i< students.length; i++){
      for(var j=0; j< studentData.length; j++){
        if(students[i]._id == studentData[j].userId){
          students[i].class = studentData[j].class;
          students[i].dob = studentData[j].dob;
        }
      }
    }
    onData(null, {
      data: {
        user:         user,
        org:          org,
        students:     students,
        studentData:  studentData
      },
    });
  }

  return () => {
    _.each(handles, (handle) => handle.stop() );
  };
};


const reduxTick = (props, onData) => {
  onData(null, {
    data: {}
  });
};


export const StudentDataController = composeAll(
  composeWithTracker(meteorTick, Loading),
  compose(reduxTick, Loading),
)(StudentView);