Added some code for searching for assignments. Needs a lot more.

This commit is contained in:
2022-08-14 13:18:50 -07:00
parent c96b4a6901
commit f3b1b38e82
3 changed files with 92 additions and 3684 deletions

View File

@@ -39,16 +39,29 @@ AssetAssignments.attachSchema(AssetAssignmentsSchema);
if (Meteor.isServer) { if (Meteor.isServer) {
// Drop any old indexes we no longer will use. Create indexes we need. // Drop any old indexes we no longer will use. Create indexes we need.
//try {AssetTypes._dropIndex("name")} catch(e) {} //try {AssetAssignments._dropIndex("name")} catch(e) {}
//AssetTypes.createIndex({name: "text"}, {name: "name", unique: false}); //AssetAssignments.createIndex({name: "text"}, {name: "name", unique: false});
AssetTypes.createIndex({assetId: 1}, {name: "AssetID", unique: false});
try {AssetTypes._dropIndex("AssetID")} catch(e) {} //Typo put this as an index in AssetTypes instead of AssetAssignments.
AssetAssignments.createIndex({assetId: 1}, {name: "AssetID", unique: false});
// This code only runs on the server // This code only runs on the server
Meteor.publish('assetAssignments', function() { Meteor.publish('assetAssignments', function(assetId) {
return AssetAssignments.find({}); let query = {};
if(assetId) {
query.assetId = assetId;
}
return AssetAssignments.find(query);
}); });
} }
Meteor.methods({ Meteor.methods({
'AssetAssignments.getOne'(assetId) {
check(assetId, String);
return AssetAssignments.findOne(assetId);
},
/** /**
* Assigns the asset to the assignee. The assignee should either be a Student or Staff member. * Assigns the asset to the assignee. The assignee should either be a Student or Staff member.
* @param assetId The Mongo ID of the asset (asset._id). * @param assetId The Mongo ID of the asset (asset._id).

View File

@@ -23,7 +23,7 @@
// Load the sites (reactive). // Load the sites (reactive).
let sites = Sites.find({}); let sites = Sites.find({});
let selectedSiteId; let selectedSiteId;
let categories = ['Email', 'First Name', 'Last Name']; let categories = ['Asset ID', 'Email', 'First Name', 'Last Name'];
let selectedCategory = 'Email'; let selectedCategory = 'Email';
let selectedGrade = 'All Grades'; let selectedGrade = 'All Grades';
let searchText = ""; let searchText = "";
@@ -46,18 +46,45 @@
// Require at least two characters in the search field before we start filtering. // Require at least two characters in the search field before we start filtering.
if(selectedSiteId && selectedGrade && selectedCategory) { if(selectedSiteId && selectedGrade && selectedCategory) {
let query = {}; let query = {};
let queryType = (selectedGrade === "Staff") ? 1 : 0;
if(searchText && searchText.length > 0) { if(searchText && searchText.length > 0) {
if (selectedCategory === 'Email') { if (selectedCategory === 'Email') {
query.email = {$regex: searchText, $options: 'i'}; query.email = {$regex: searchText, $options: 'i'};
} else if (selectedCategory === 'First Name') { } else if( selectedCategory === 'Asset ID') {
//Do not do anything yet...
} else if (selectedCategory === 'First Name') {
query.firstName = {$regex: searchText, $options: 'i'}; query.firstName = {$regex: searchText, $options: 'i'};
} else { } else {
query.lastName = {$regex: searchText, $options: 'i'}; query.lastName = {$regex: searchText, $options: 'i'};
} }
} }
if(selectedCategory === "Staff") { if(selectedCategory === 'Asset ID') {
Meteor.call('AssetAssignments.getOne', searchText, (err, result) => {
if(err) {
console.error(err);
}
else {
if(result && result.assigneeType && result.assigneeId) {
if (result.assigneeType === 'Staff') {
query._id = result.assigneeId;
queryType = 1;
} else if (result.assigneeType === 'Student') {
query._id = result.assigneeId;
queryType = 0;
} else {
console.error("Invalid AssigneeType");
}
}
else {
console.error('Invalid result from AssetAssignments.getOne');
}
}
});
}
if(queryType === 1) {
searchResults = Staff.find(query); searchResults = Staff.find(query);
} }
else { else {
@@ -65,8 +92,8 @@
query.grade = selectedGrade; query.grade = selectedGrade;
} }
console.log("Searching") // console.log("Searching")
console.log(query) // console.log(query)
searchResults = Students.find(query); searchResults = Students.find(query);
} }
} }

3716
package-lock.json generated

File diff suppressed because it is too large Load Diff