enzostvs HF staff commited on
Commit
eafbf42
·
1 Parent(s): eb54f99

monthly visualization

Browse files
src/lib/components/result/space/Space.svelte CHANGED
@@ -20,7 +20,7 @@
20
  <Author author={data?.author} />
21
  {/if}
22
  {#if data?.likers}
23
- <Likers likers={data?.likers} />
24
  {/if}
25
  {#if data?.runtime}
26
  <Runtime runtime={data?.runtime} />
 
20
  <Author author={data?.author} />
21
  {/if}
22
  {#if data?.likers}
23
+ <Likers likers={data?.likers} type={data?.likers_type} />
24
  {/if}
25
  {#if data?.runtime}
26
  <Runtime runtime={data?.runtime} />
src/lib/components/result/space/likers/Likers.svelte CHANGED
@@ -5,6 +5,7 @@
5
  import type { Liker } from "$lib/types";
6
 
7
  export let likers: Record<string, Array<Liker>>;
 
8
 
9
  let tab: "data-visualization" | "global" = "global";
10
  const tabs = [{
@@ -21,9 +22,17 @@
21
  tab = id as "data-visualization" | "global"
22
  }
23
 
 
 
 
 
 
 
 
 
24
  const options: EChartsOptions = {
25
  xAxis: {
26
- data: Object.keys(likers ?? []),
27
  type: 'category',
28
  },
29
  yAxis: {
@@ -79,23 +88,31 @@
79
  {/each}
80
  </div>
81
  {#if tab === "global"}
82
- <div class="">
83
- {#each Object.keys(likers ?? []) as year}
84
- <p class="uppercase text-zinc-600 dark:text-zinc-400 font-semibold font-title text-sm">{year}</p>
85
- <div class="flex items-center mt-3 flex-wrap">
86
- {#each likers[year].slice(0, 100) as like}
87
- <div class="flex items-center -mr-1.5 -mt-1.5 relative cursor-pointer group">
88
- <img src={like.avatarUrl.includes(".svg") ? `https://huggingface.co${like.avatarUrl}` : like.avatarUrl} alt={like.fullname} class="w-8 h-8 rounded-full ring-[1px] ring-white dark:ring-zinc-900" />
89
- <p class="font-title absolute left-full top-0 bg-zinc-100 shadow rounded px-2 py-0.5 text-zinc-600 text-xs opacity-0 group-hover:opacity-100 pointer-events-none z-10 whitespace-nowrap translate-y-1/2">{like.fullname}</p>
90
- </div>
91
- {/each}
92
- {#if likers[year].length > 100}
93
- <div class="w-8 h-8 flex items-center justify-center border rounded-full border-zinc-200 dark:border-zinc-800 bg-white dark:bg-zinc-900 z-10">
94
- <p class="text-xs font-title text-zinc-700">+{formatBigNumber(likers[year].length - 15)}</p>
95
- </div>
96
- {/if}
 
 
 
 
 
 
 
 
97
  </div>
98
- {/each}
99
  </div>
100
  {:else}
101
  <div class="h-[380px] -mx-8 -my-8">
 
5
  import type { Liker } from "$lib/types";
6
 
7
  export let likers: Record<string, Array<Liker>>;
8
+ export let likers_type: string;
9
 
10
  let tab: "data-visualization" | "global" = "global";
11
  const tabs = [{
 
22
  tab = id as "data-visualization" | "global"
23
  }
24
 
25
+ const formatNumberMonth = (num: number) => {
26
+ const months = [
27
+ "January", "February", "March", "April", "May", "June", "July", "August", "September",
28
+ "October", "November", "December"
29
+ ];
30
+ return months[num - 1];
31
+ }
32
+
33
  const options: EChartsOptions = {
34
  xAxis: {
35
+ data: likers_type === 'years' ? Object.keys(likers ?? []) : Object.keys(likers ?? []).map((key) => formatNumberMonth(parseInt(key))),
36
  type: 'category',
37
  },
38
  yAxis: {
 
88
  {/each}
89
  </div>
90
  {#if tab === "global"}
91
+ <div class="grid grid-cols-1 gap-4">
92
+ {#each Object.keys(likers ?? []) as period}
93
+ <div>
94
+ <p class="uppercase text-zinc-600 dark:text-zinc-400 font-semibold font-title text-sm mb-3">
95
+ {#if likers_type === "year"}
96
+ {period}
97
+ {:else}
98
+ {formatNumberMonth(parseInt(period))}
99
+ {/if}
100
+ </p>
101
+ <div class="flex items-center flex-wrap">
102
+ {#each likers[period].slice(0, 100) as like}
103
+ <div class="flex items-center -mr-1.5 -mt-1.5 relative cursor-pointer group">
104
+ <img src={like.avatarUrl.includes(".svg") ? `https://huggingface.co${like.avatarUrl}` : like.avatarUrl} alt={like.fullname} class="w-8 h-8 rounded-full ring-[1px] ring-white dark:ring-zinc-900" />
105
+ <p class="font-title absolute left-full top-0 bg-zinc-100 shadow rounded px-2 py-0.5 text-zinc-600 text-xs opacity-0 group-hover:opacity-100 pointer-events-none z-10 whitespace-nowrap translate-y-1/2">{like.fullname}</p>
106
+ </div>
107
+ {/each}
108
+ {#if likers[period].length > 100}
109
+ <div class="w-8 h-8 flex items-center justify-center border rounded-full border-zinc-200 dark:border-zinc-800 bg-white dark:bg-zinc-900 z-10">
110
+ <p class="text-xs font-title text-zinc-700">+{formatBigNumber(likers[period].length - 15)}</p>
111
+ </div>
112
+ {/if}
113
+ </div>
114
  </div>
115
+ {/each}
116
  </div>
117
  {:else}
118
  <div class="h-[380px] -mx-8 -my-8">
src/routes/api/search/+server.ts CHANGED
@@ -31,6 +31,8 @@ export async function POST({ request }: RequestEvent) {
31
  dataAuthor = null
32
  }
33
 
 
 
34
  const responseLikers = await fetch(`${env.PUBLIC_API_URL}/${body.namespace}/${body.repoId}/likers?expand[]=likeAt`, {
35
  method: "GET",
36
  headers: {
@@ -43,7 +45,7 @@ export async function POST({ request }: RequestEvent) {
43
  throw error(responseLikers.status, dataLikers.error);
44
  }
45
 
46
- const likers: Record<string, Liker[]> = {}
47
  dataLikers.forEach((liker: Liker) => {
48
  const year = liker.likedAt.split("-")[0]
49
  if (!likers[year]) {
@@ -52,6 +54,18 @@ export async function POST({ request }: RequestEvent) {
52
  likers[year].push(liker)
53
  })
54
 
 
 
 
 
 
 
 
 
 
 
 
 
55
 
56
  const formattedData = {
57
  ...data,
@@ -67,6 +81,7 @@ export async function POST({ request }: RequestEvent) {
67
  bgTo: colors[data?.cardData?.colorTo as keyof typeof colors]?.primary ?? "bg-blue-600",
68
  },
69
  likers,
 
70
  }
71
 
72
  return json(formattedData);
 
31
  dataAuthor = null
32
  }
33
 
34
+ let likers_type = "yearly";
35
+
36
  const responseLikers = await fetch(`${env.PUBLIC_API_URL}/${body.namespace}/${body.repoId}/likers?expand[]=likeAt`, {
37
  method: "GET",
38
  headers: {
 
45
  throw error(responseLikers.status, dataLikers.error);
46
  }
47
 
48
+ let likers: Record<string, Liker[]> = {}
49
  dataLikers.forEach((liker: Liker) => {
50
  const year = liker.likedAt.split("-")[0]
51
  if (!likers[year]) {
 
54
  likers[year].push(liker)
55
  })
56
 
57
+ if (Object.keys(likers).length < 2) {
58
+ likers_type = "monthly";
59
+ likers = {}
60
+ dataLikers.forEach((liker: Liker) => {
61
+ const month = liker.likedAt.split("-")[1]
62
+ if (!likers[month]) {
63
+ likers[month] = []
64
+ }
65
+ likers[month].push(liker)
66
+ })
67
+ }
68
+
69
 
70
  const formattedData = {
71
  ...data,
 
81
  bgTo: colors[data?.cardData?.colorTo as keyof typeof colors]?.primary ?? "bg-blue-600",
82
  },
83
  likers,
84
+ likers_type,
85
  }
86
 
87
  return json(formattedData);