mirror of
				https://github.com/hydralauncher/hydra.git
				synced 2025-03-09 15:40:26 +00:00 
			
		
		
		
	feat: save achievements cache
This commit is contained in:
		
							parent
							
								
									7e3cf0a00e
								
							
						
					
					
						commit
						f3a5f90bc7
					
				
					 4 changed files with 90 additions and 29 deletions
				
			
		| 
						 | 
				
			
			@ -1,4 +1,4 @@
 | 
			
		|||
import { formatDistance, subMilliseconds } from "date-fns";
 | 
			
		||||
import { format, formatDistance, subMilliseconds } from "date-fns";
 | 
			
		||||
import type { FormatDistanceOptions } from "date-fns";
 | 
			
		||||
import {
 | 
			
		||||
  ptBR,
 | 
			
		||||
| 
						 | 
				
			
			@ -67,5 +67,10 @@ export function useDate() {
 | 
			
		|||
        return "";
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
 | 
			
		||||
    format: (timestamp: number): string => {
 | 
			
		||||
      const locale = getDateLocale();
 | 
			
		||||
      return format(timestamp, locale == enUS ? "MM/dd/yyyy - HH:mm" : "dd/MM/yyyy - HH:mm");
 | 
			
		||||
    },
 | 
			
		||||
  };
 | 
			
		||||
}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -5,8 +5,9 @@ import { Button } from "@renderer/components";
 | 
			
		|||
 | 
			
		||||
import * as styles from "./sidebar.css";
 | 
			
		||||
import { gameDetailsContext } from "@renderer/context";
 | 
			
		||||
import { useFormat } from "@renderer/hooks";
 | 
			
		||||
import { useDate, useFormat } from "@renderer/hooks";
 | 
			
		||||
import { DownloadIcon, PeopleIcon } from "@primer/octicons-react";
 | 
			
		||||
import { SPACING_UNIT, vars } from "@renderer/theme.css";
 | 
			
		||||
 | 
			
		||||
export function Sidebar() {
 | 
			
		||||
  const [_howLongToBeat, _setHowLongToBeat] = useState<{
 | 
			
		||||
| 
						 | 
				
			
			@ -21,6 +22,7 @@ export function Sidebar() {
 | 
			
		|||
    useContext(gameDetailsContext);
 | 
			
		||||
 | 
			
		||||
  const { t } = useTranslation("game_details");
 | 
			
		||||
  const { format } = useDate();
 | 
			
		||||
 | 
			
		||||
  const { numberFormatter } = useFormat();
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -46,16 +48,42 @@ export function Sidebar() {
 | 
			
		|||
        isLoading={howLongToBeat.isLoading}
 | 
			
		||||
      /> */}
 | 
			
		||||
 | 
			
		||||
      {achievements.map((achievement, index) => (
 | 
			
		||||
        <div key={index}>
 | 
			
		||||
          <img
 | 
			
		||||
            src={achievement.unlocked ? achievement.icon : achievement.icongray}
 | 
			
		||||
          />
 | 
			
		||||
          <p>{achievement.displayName}</p>
 | 
			
		||||
          {achievement.unlockTime &&
 | 
			
		||||
            new Date(achievement.unlockTime).toDateString()}
 | 
			
		||||
      {achievements.length && (
 | 
			
		||||
        <div
 | 
			
		||||
          style={{
 | 
			
		||||
            display: "flex",
 | 
			
		||||
            flexDirection: "column",
 | 
			
		||||
            gap: `${SPACING_UNIT}px`,
 | 
			
		||||
            padding: `${SPACING_UNIT}px`,
 | 
			
		||||
          }}
 | 
			
		||||
        >
 | 
			
		||||
          {achievements.map((achievement, index) => (
 | 
			
		||||
            <div
 | 
			
		||||
              key={index}
 | 
			
		||||
              style={{
 | 
			
		||||
                display: "flex",
 | 
			
		||||
                flexDirection: "row",
 | 
			
		||||
                alignItems: "center",
 | 
			
		||||
                gap: `${SPACING_UNIT}px`,
 | 
			
		||||
              }}
 | 
			
		||||
              title={achievement.description}
 | 
			
		||||
            >
 | 
			
		||||
              <img
 | 
			
		||||
                style={{
 | 
			
		||||
                  height: "72px",
 | 
			
		||||
                }}
 | 
			
		||||
                src={
 | 
			
		||||
                  achievement.unlocked ? achievement.icon : achievement.icongray
 | 
			
		||||
                }
 | 
			
		||||
              />
 | 
			
		||||
              <div>
 | 
			
		||||
                <p>{achievement.displayName}</p>
 | 
			
		||||
                {achievement.unlockTime && format(achievement.unlockTime)}
 | 
			
		||||
              </div>
 | 
			
		||||
            </div>
 | 
			
		||||
          ))}
 | 
			
		||||
        </div>
 | 
			
		||||
      ))}
 | 
			
		||||
      )}
 | 
			
		||||
 | 
			
		||||
      {stats && (
 | 
			
		||||
        <>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue