load more stories on increasing size
This commit is contained in:
parent
4bd8d61d7c
commit
d238d1e962
12
hn.py
12
hn.py
@ -26,6 +26,7 @@ class Client:
|
|||||||
self.loadedstories = []
|
self.loadedstories = []
|
||||||
self.story_pos = 0
|
self.story_pos = 0
|
||||||
self.cursor_pos = 0
|
self.cursor_pos = 0
|
||||||
|
|
||||||
self.lines = curses.LINES
|
self.lines = curses.LINES
|
||||||
self.cols = curses.COLS
|
self.cols = curses.COLS
|
||||||
self.stories_in_a_site = self.lines - 3
|
self.stories_in_a_site = self.lines - 3
|
||||||
@ -33,7 +34,7 @@ class Client:
|
|||||||
def load_stories(self, from_pos, to_pos):
|
def load_stories(self, from_pos, to_pos):
|
||||||
for idx, i in enumerate(self.topstories[from_pos:to_pos]):
|
for idx, i in enumerate(self.topstories[from_pos:to_pos]):
|
||||||
#stdscr.clear()
|
#stdscr.clear()
|
||||||
self.set_footer(f'[{spinner_states[idx%4]}] Loading stories...')
|
self.set_footer(f'[{spinner_states[idx%4]}] Loading { to_pos - from_pos } stories...')
|
||||||
self.screen.refresh()
|
self.screen.refresh()
|
||||||
self.loadedstories.append(api.get_story(i))
|
self.loadedstories.append(api.get_story(i))
|
||||||
|
|
||||||
@ -41,7 +42,6 @@ class Client:
|
|||||||
self.screen.addstr(curses.LINES - 1, 0, footer, curses.A_REVERSE)
|
self.screen.addstr(curses.LINES - 1, 0, footer, curses.A_REVERSE)
|
||||||
|
|
||||||
def draw(self):
|
def draw(self):
|
||||||
|
|
||||||
self.screen.clear()
|
self.screen.clear()
|
||||||
self.lines = curses.LINES
|
self.lines = curses.LINES
|
||||||
self.cols = curses.COLS
|
self.cols = curses.COLS
|
||||||
@ -49,6 +49,7 @@ class Client:
|
|||||||
self.stories_in_a_site = self.lines - 3
|
self.stories_in_a_site = self.lines - 3
|
||||||
|
|
||||||
self.screen.addstr('Hacker News Top Stories:\n')
|
self.screen.addstr('Hacker News Top Stories:\n')
|
||||||
|
|
||||||
for i, story in enumerate(self.loadedstories[self.story_pos:self.story_pos + self.stories_in_a_site]):
|
for i, story in enumerate(self.loadedstories[self.story_pos:self.story_pos + self.stories_in_a_site]):
|
||||||
prefix = '>>> ' if i == self.cursor_pos else ' '
|
prefix = '>>> ' if i == self.cursor_pos else ' '
|
||||||
# calculate length of line
|
# calculate length of line
|
||||||
@ -66,7 +67,7 @@ class Client:
|
|||||||
if i == self.cursor_pos:
|
if i == self.cursor_pos:
|
||||||
detail = f' by {story.author} | {story.comments} comments | {story.votes} points\n'
|
detail = f' by {story.author} | {story.comments} comments | {story.votes} points\n'
|
||||||
self.screen.addstr(detail)
|
self.screen.addstr(detail)
|
||||||
self.set_footer(f'Loaded {self.stories_in_a_site} stories.')
|
self.set_footer(f'Loaded {len(self.loadedstories)} stories.')
|
||||||
|
|
||||||
def handle_input(self):
|
def handle_input(self):
|
||||||
c = self.screen.getch()
|
c = self.screen.getch()
|
||||||
@ -88,6 +89,9 @@ class Client:
|
|||||||
curses.resize_term(*self.screen.getmaxyx())
|
curses.resize_term(*self.screen.getmaxyx())
|
||||||
self.lines, self.cols = self.screen.getmaxyx()
|
self.lines, self.cols = self.screen.getmaxyx()
|
||||||
self.stories_in_a_site = self.lines - 3
|
self.stories_in_a_site = self.lines - 3
|
||||||
|
if len(self.loadedstories) < self.story_pos + self.stories_in_a_site:
|
||||||
|
# load more
|
||||||
|
self.load_stories(len(self.loadedstories), self.story_pos + self.stories_in_a_site)
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
self.load_stories(0, self.stories_in_a_site)
|
self.load_stories(0, self.stories_in_a_site)
|
||||||
@ -106,7 +110,7 @@ def main():
|
|||||||
client.run()
|
client.run()
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
curses.endwin()
|
curses.endwin()
|
||||||
print(e)
|
raise e
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
main()
|
main()
|
||||||
|
Loading…
Reference in New Issue
Block a user