hotspots: Refactor backend for hotspots v2.

This commit is contained in:
Jack Zhang
2017-07-13 18:20:27 -07:00
committed by Tim Abbott
parent 691aff55a3
commit 11c27015f0
3 changed files with 26 additions and 8 deletions

View File

@@ -3,15 +3,31 @@ from zerver.models import UserProfile, UserHotspot
from typing import List, Text, Dict
ALL_HOTSPOTS = {
'click_to_reply': 'Click anywhere on a message to reply.',
'new_topic_botton': 'Click the "New topic" button to start a new conversation.',
'stream_settings': 'Most discussion on Zulip happens in streams. Click here to create or join additional streams.',
}
# TODO: Tag these for translation once we've finalized the content.
'click_to_reply': {
'title': 'Respond to a message',
'description': 'Click anywhere on a message to reply.',
},
'new_topic_button': {
'title': 'Start a new topic',
'description': 'Click the "New topic" button to start a new conversation.',
},
'stream_settings': {
'title': 'Stream settings',
'description': 'Most discussion on Zulip happens in streams. Click here to create or join additional streams.',
},
} # type Dict[str, Dict[str, Text]]
def get_next_hotspots(user):
# type: (UserProfile) -> List[Dict[str, Text]]
# type: (UserProfile) -> List[Dict[str, object]]
seen_hotspots = frozenset(UserHotspot.objects.filter(user=user).values_list('hotspot', flat=True))
for hotspot in ['click_to_reply', 'new_topic_botton', 'stream_settings']:
for hotspot in ['click_to_reply', 'new_topic_button', 'stream_settings']:
if hotspot not in seen_hotspots:
return [{'name': hotspot, 'description': ALL_HOTSPOTS[hotspot]}]
return [{
'name': hotspot,
'title': ALL_HOTSPOTS[hotspot]['title'],
'description': ALL_HOTSPOTS[hotspot]['description'],
'delay': 5,
}]
return []