Skip to content

Commit

Permalink
Merge branch 'yihong0618:master' into master
Browse files Browse the repository at this point in the history
  • Loading branch information
tiny656 authored Sep 23, 2024
2 parents a6ca17d + 371ce67 commit 33e5816
Show file tree
Hide file tree
Showing 4 changed files with 19 additions and 2 deletions.
2 changes: 1 addition & 1 deletion run_page/gen_svg.py
Original file line number Diff line number Diff line change
Expand Up @@ -243,7 +243,7 @@ def main():
# circular not add footer and header
p.drawer_type = "plain" if is_circular else "title"
if args.type == "github":
p.height = 55 + p.years.count() * 43
p.height = 55 + p.years.real_year * 43
# for special circular
if is_circular:
years = p.years.all()[:]
Expand Down
5 changes: 4 additions & 1 deletion run_page/generator/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,10 @@ def sync(self, force):
if self.only_run and activity.type != "Run":
continue
if IGNORE_BEFORE_SAVING:
activity.summary_polyline = filter_out(activity.summary_polyline)
if activity.map and activity.map.summary_polyline:
activity.map.summary_polyline = filter_out(
activity.map.summary_polyline
)
created = update_or_create_activity(self.session, activity)
if created:
sys.stdout.write("+")
Expand Down
3 changes: 3 additions & 0 deletions run_page/gpxtrackposter/github_drawer.py
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,9 @@ def draw(self, dr: svgwrite.Drawing, size: XY, offset: XY):
)
year_length = total_length_year_dict.get(year, 0)
year_length = format_float(self.poster.m2u(year_length))

if str(year_length) == "0.0":
continue
try:
month_names = [
locale.nl_langinfo(day)[:3] # Get only first three letters
Expand Down
11 changes: 11 additions & 0 deletions run_page/gpxtrackposter/year_range.py
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ def __init__(self):
"""Inits YearRange with empty bounds -- to be built after init"""
self.from_year = None
self.to_year = None
self.years_dict = dict()

def parse(self, s: str) -> bool:
"""Parse a plaintext range of years into a pair of years
Expand Down Expand Up @@ -69,6 +70,11 @@ def add(self, t: datetime.datetime):
self.from_year = t.year
elif t.year > self.to_year:
self.to_year = t.year
"""record the year which has running data"""
if t.year not in self.years_dict:
self.years_dict[t.year] = 1
else:
self.years_dict[t.year] += 1

def contains(self, t: datetime.datetime) -> bool:
"""Return True if current year range contains t, False if not"""
Expand All @@ -82,5 +88,10 @@ def count(self) -> Optional[int]:
return None
return 1 + self.to_year - self.from_year

@property
def real_year(self):
"""Return number of years which has running data"""
return len(self.years_dict)

def all(self):
return list(range(int(self.from_year), int(self.to_year) + 1))

0 comments on commit 33e5816

Please sign in to comment.