Hide member last names from non-vetted members
This commit is contained in:
parent
c98efeff3a
commit
aa5a01681f
|
@ -100,7 +100,29 @@ class TransactionSerializer(serializers.ModelSerializer):
|
||||||
|
|
||||||
|
|
||||||
# member viewing other members
|
# member viewing other members
|
||||||
|
# hide info for non-vetted members so someone sitting
|
||||||
|
# in our parking lot can't scrape all our info
|
||||||
class OtherMemberSerializer(serializers.ModelSerializer):
|
class OtherMemberSerializer(serializers.ModelSerializer):
|
||||||
|
last_name = serializers.SerializerMethodField()
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
model = models.Member
|
||||||
|
fields = [
|
||||||
|
'id',
|
||||||
|
'preferred_name',
|
||||||
|
'last_name',
|
||||||
|
'status',
|
||||||
|
'current_start_date',
|
||||||
|
'application_date',
|
||||||
|
'photo_small',
|
||||||
|
'public_bio',
|
||||||
|
]
|
||||||
|
|
||||||
|
def get_last_name(self, obj):
|
||||||
|
return obj.last_name[0] + '.'
|
||||||
|
|
||||||
|
# vetted member viewing other members
|
||||||
|
class VettedOtherMemberSerializer(serializers.ModelSerializer):
|
||||||
class Meta:
|
class Meta:
|
||||||
model = models.Member
|
model = models.Member
|
||||||
fields = [
|
fields = [
|
||||||
|
@ -234,13 +256,23 @@ class SearchSerializer(serializers.Serializer):
|
||||||
serializer = OtherMemberSerializer(obj)
|
serializer = OtherMemberSerializer(obj)
|
||||||
return serializer.data
|
return serializer.data
|
||||||
|
|
||||||
|
# vetted member viewing member list or search result
|
||||||
|
class VettedSearchSerializer(serializers.Serializer):
|
||||||
|
q = serializers.CharField(write_only=True, max_length=64)
|
||||||
|
seq = serializers.IntegerField(write_only=True)
|
||||||
|
member = serializers.SerializerMethodField()
|
||||||
|
|
||||||
|
def get_member(self, obj):
|
||||||
|
serializer = VettedOtherMemberSerializer(obj)
|
||||||
|
return serializer.data
|
||||||
|
|
||||||
# instructor viewing search result
|
# instructor viewing search result
|
||||||
class InstructorSearchSerializer(serializers.Serializer):
|
class InstructorSearchSerializer(serializers.Serializer):
|
||||||
member = serializers.SerializerMethodField()
|
member = serializers.SerializerMethodField()
|
||||||
training = serializers.SerializerMethodField()
|
training = serializers.SerializerMethodField()
|
||||||
|
|
||||||
def get_member(self, obj):
|
def get_member(self, obj):
|
||||||
serializer = OtherMemberSerializer(obj)
|
serializer = VettedOtherMemberSerializer(obj)
|
||||||
return serializer.data
|
return serializer.data
|
||||||
|
|
||||||
def get_training(self, obj):
|
def get_training(self, obj):
|
||||||
|
@ -402,7 +434,7 @@ class SessionSerializer(serializers.ModelSerializer):
|
||||||
|
|
||||||
def get_instructor_name(self, obj):
|
def get_instructor_name(self, obj):
|
||||||
if obj.instructor and hasattr(obj.instructor, 'member'):
|
if obj.instructor and hasattr(obj.instructor, 'member'):
|
||||||
name = '{} {}'.format(obj.instructor.member.preferred_name, obj.instructor.member.last_name[0])
|
name = '{} {}.'.format(obj.instructor.member.preferred_name, obj.instructor.member.last_name[0])
|
||||||
else:
|
else:
|
||||||
name = 'Unknown'
|
name = 'Unknown'
|
||||||
return obj.old_instructor or name
|
return obj.old_instructor or name
|
||||||
|
|
|
@ -54,6 +54,8 @@ class SearchViewSet(Base, Retrieve):
|
||||||
return serializers.AdminSearchSerializer
|
return serializers.AdminSearchSerializer
|
||||||
elif self.request.user.member.is_instructor and self.action == 'retrieve':
|
elif self.request.user.member.is_instructor and self.action == 'retrieve':
|
||||||
return serializers.InstructorSearchSerializer
|
return serializers.InstructorSearchSerializer
|
||||||
|
elif self.request.user.member.vetted_date:
|
||||||
|
return serializers.VettedSearchSerializer
|
||||||
else:
|
else:
|
||||||
return serializers.SearchSerializer
|
return serializers.SearchSerializer
|
||||||
|
|
||||||
|
@ -126,7 +128,12 @@ class SearchViewSet(Base, Retrieve):
|
||||||
num_results = 100
|
num_results = 100
|
||||||
|
|
||||||
queryset = self.get_queryset()[:num_results]
|
queryset = self.get_queryset()[:num_results]
|
||||||
|
|
||||||
|
if self.request.user.member.vetted_date:
|
||||||
|
serializer = serializers.VettedSearchSerializer(queryset, many=True)
|
||||||
|
else:
|
||||||
serializer = serializers.SearchSerializer(queryset, many=True)
|
serializer = serializers.SearchSerializer(queryset, many=True)
|
||||||
|
|
||||||
return Response({'seq': seq, 'results': serializer.data})
|
return Response({'seq': seq, 'results': serializer.data})
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -73,8 +73,6 @@ export function Members(props) {
|
||||||
const [search, setSearch] = useState(searchDefault);
|
const [search, setSearch] = useState(searchDefault);
|
||||||
const { token } = props;
|
const { token } = props;
|
||||||
|
|
||||||
console.log(sort);
|
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
setResponse(false);
|
setResponse(false);
|
||||||
searchCache = search.q;
|
searchCache = search.q;
|
||||||
|
@ -197,6 +195,7 @@ export function MemberDetail(props) {
|
||||||
}, [refreshCount]);
|
}, [refreshCount]);
|
||||||
|
|
||||||
const member = result.member || false;
|
const member = result.member || false;
|
||||||
|
const photo = member?.photo_large || member?.photo_small || false;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Container>
|
<Container>
|
||||||
|
@ -208,7 +207,7 @@ export function MemberDetail(props) {
|
||||||
<Grid stackable columns={2}>
|
<Grid stackable columns={2}>
|
||||||
<Grid.Column width={isAdmin(user) ? 8 : 5}>
|
<Grid.Column width={isAdmin(user) ? 8 : 5}>
|
||||||
<p>
|
<p>
|
||||||
<Image rounded size='medium' src={member.photo_large ? staticUrl + '/' + member.photo_large : '/nophoto.png'} />
|
<Image rounded size='medium' src={photo ? staticUrl + '/' + photo : '/nophoto.png'} />
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
{isAdmin(user) ?
|
{isAdmin(user) ?
|
||||||
|
|
Loading…
Reference in New Issue
Block a user