Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

profiler.js 3.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. const config = require('../../../db/data-generator/config.json')
  2. const tagger = require('./tagger')
  3. /**
  4. * Class to hold our retrieved profile information
  5. * in a convenient wrapper
  6. * !: This needs to match the responseSchema in profiles.js
  7. */
  8. class CompleteProfile {
  9. constructor(profile, type, includeResponses = false) {
  10. this.user_id = profile.user_id // int user_id
  11. this.profile_id = profile.profile_id // int profile_id
  12. this.user_name = profile.user.user_name // string user_name
  13. this.user_email = profile.user.user_email
  14. this.responses = []
  15. this.user_type = type
  16. this.tags = profile.tags.filter(t => t.category != 'reveal')
  17. // TODO: generalize this for multiple images, and languages
  18. this.profile_description = ''
  19. this.profile_media = []
  20. this.profile_languages = []
  21. this.profile_prefs = {}
  22. // TODO: Use reveal tags to add or remove information from profile!
  23. // TODO: ---
  24. // TODO: Use reveal tags to rebuild profile based on group/membership
  25. // TODO: and include for certain profiles
  26. this.reveal = profile.tags.filter(t => t.category == 'reveal')
  27. // TODO: filter these correctly
  28. if (profile?.responses?.length && includeResponses) {
  29. // [] of all "profile" responses
  30. this.responses = profile.responses
  31. // image, language, duration, presence, blurb, urgency, role, pronouns, distance
  32. const prefs = ['zipcode', 'duration', 'presence', 'urgency', 'role', 'pronouns', 'distance']
  33. const prefsKeys = config.prefKeys
  34. prefs.forEach((pref, i) => {
  35. this.profile_prefs[pref] = this.responses.filter(
  36. r => r.response_key_id === prefsKeys[i]
  37. )[0]
  38. })
  39. this.profile_description = this.responses.filter(r => r.response_key_id === config.blurbKey).map(r => r.val)[0]
  40. this.profile_media = this.responses.filter(r => r.response_key_id === config.mediaKey).map(r => r.val)
  41. this.profile_languages = this.responses.filter(r => r.response_key_id === config.langKey).map(r => r.val)
  42. }
  43. }
  44. }
  45. const makeCompleteProfiles = (profileIdArray, profilesEntries, type, includeResponses, tagLookup) => {
  46. const completeProfiles = []
  47. profileIdArray.forEach(pid => {
  48. profilesEntries.forEach(entry => {
  49. if (entry.profile_id == pid) {
  50. const complete = new CompleteProfile(entry, type, includeResponses)
  51. tagger.setProfileTags(entry, complete, tagLookup)
  52. completeProfiles.push(complete)
  53. }
  54. })
  55. })
  56. return completeProfiles
  57. }
  58. const makeCompleteProfilesFromProfile = (profilesEntries, type, tagLookup)=> {
  59. profilesEntries.forEach(profile => {
  60. tagger.setProfileTags(profile, profile, tagLookup)
  61. })
  62. //** Get responses asociated with each profile_id */
  63. return profilesEntries.map(profile => {
  64. return new CompleteProfile(profile, type)
  65. })
  66. }
  67. module.exports = {
  68. CompleteProfile,
  69. makeCompleteProfiles,
  70. makeCompleteProfilesFromProfile
  71. }