0
0
mirror of https://github.com/yude-jp/yude.jp synced 2024-12-22 20:20:09 +09:00

Add sleep duration, heartrate on /profile

This commit is contained in:
yude 2021-10-02 12:45:12 +09:00
parent a08bd36c3e
commit 1411e37d8f
Signed by: yude
GPG Key ID: EB0FE5D925C4A968
5 changed files with 167 additions and 0 deletions

View File

@ -0,0 +1,42 @@
// React
import { format } from 'date-fns'
const {
FITBIT_TOKEN: bearer
} = process.env;
const today = format(new Date(), 'yyyy-MM-dd')
export const getName = async (props) => {
const uuid = props;
return fetch(
'https://api.fitbit.com/1/user/-/activities/heart/date/today/1d/1sec.json',
{
headers: {
Authorization: `Bearer ${bearer}`,
},
}
);
};
const FitbitHeartrate = async (req, res) => {
const { uuid } = req.query
const response = await getName(uuid);
const data = await response.json();
if (response.status === 204 || response.status > 400) {
return res.status(200).send("404");
}
const heartrate = data["activities-heart"].map((item, i) => {
if (item.dateTime = today) {
return item.value.restingHeartRate
} else {
return "Failed to retrieve data."
}
}
)
return res.status(200).json({
heartrate,
});
};
export default FitbitHeartrate

43
pages/api/Fitbit/Sleep.js Normal file
View File

@ -0,0 +1,43 @@
// React
import { format } from 'date-fns'
const {
FITBIT_TOKEN: bearer
} = process.env;
const today = format(new Date(), 'yyyy-MM-dd')
export const getName = async (props) => {
const uuid = props;
return fetch(
'https://api.fitbit.com/1.2/user/-/sleep/date/' + today + '.json',
{
headers: {
Authorization: `Bearer ${bearer}`,
},
}
);
};
const FitbitSleep = async (req, res) => {
const { uuid } = req.query
const response = await getName(uuid);
const data = await response.json();
if (response.status === 204 || response.status > 400) {
return res.status(200).send("404");
}
// const duration = data["sleep"].map((item, i) => {
// if (item.dateOfSleep = today) {
// return item.duration
// } else {
// return "Failed to retrieve data."
// }
// }
// )
const duration = data.summary.totalMinutesAsleep
return res.status(200).json({
duration,
});
};
export default FitbitSleep

View File

@ -0,0 +1,36 @@
// Data fetching
import useSwr from 'swr'
// Font Awesome
import { faHeartbeat } from '@fortawesome/free-solid-svg-icons'
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'
// Data fetching implements
const fetcher = (url) => fetch(url).then((res) => res.json())
function App (props) {
const { data, error } = useSwr(
'/api/Fitbit/Heartrate',
fetcher
)
if (error) {
return (
<>エラーが発生しました</>
)
} else {
if (!data) {
return (
<>読み込み中...</>
)
} else {
return (
<>
<FontAwesomeIcon icon={faHeartbeat} className="w-5 h-5 inline ml-3"/> {data.heartrate}
</>
)
}
}
}
export default App;

View File

@ -0,0 +1,42 @@
// Data fetching
import useSwr from 'swr'
// Font Awesome
import { faBed } from '@fortawesome/free-solid-svg-icons'
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'
// Data fetching implements
const fetcher = (url) => fetch(url).then((res) => res.json())
function App (props) {
const { data, error } = useSwr(
'/api/Fitbit/Sleep',
fetcher
)
if (error) {
return (
<>エラーが発生しました</>
)
} else {
if (!data) {
return (
<>読み込み中...</>
)
} else {
const duration = data.duration
const hours = Math.floor(duration / 60)
let minutes = duration % 60
if (minutes <= 9) {
minutes = '0' + minutes
}
return (
<>
<FontAwesomeIcon icon={faBed} className="w-5 h-5 inline"/> {hours}:{minutes}
</>
)
}
}
}
export default App;

View File

@ -25,6 +25,8 @@ import PublicKeys from './components/Profile/PublicKeys'
import Button from './components/Profile/Button' import Button from './components/Profile/Button'
import Contact from './components/Profile/Contact' import Contact from './components/Profile/Contact'
import NintendoSW from "./components/Profile/NintendoSW" import NintendoSW from "./components/Profile/NintendoSW"
import FitbitSleep from "./components/Fitbit/Sleep"
import FitbitHeartrate from "./components/Fitbit/Heartrate"
// next-seo // next-seo
import { NextSeo } from 'next-seo'; import { NextSeo } from 'next-seo';
@ -61,6 +63,8 @@ export default function Profile(props) {
<div> <div>
<DiscordPlaying /> <DiscordPlaying />
<Spotify /> <Spotify />
<FitbitSleep />
<FitbitHeartrate />
</div> </div>
</div> </div>