mirror of
https://github.com/yude-jp/yude.jp
synced 2024-12-22 12:10:11 +09:00
Add sleep duration, heartrate on /profile
This commit is contained in:
parent
a08bd36c3e
commit
1411e37d8f
42
pages/api/Fitbit/Heartrate.js
Normal file
42
pages/api/Fitbit/Heartrate.js
Normal 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
43
pages/api/Fitbit/Sleep.js
Normal 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
|
36
pages/components/Fitbit/Heartrate.js
Normal file
36
pages/components/Fitbit/Heartrate.js
Normal 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;
|
42
pages/components/Fitbit/Sleep.js
Normal file
42
pages/components/Fitbit/Sleep.js
Normal 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;
|
@ -25,6 +25,8 @@ import PublicKeys from './components/Profile/PublicKeys'
|
||||
import Button from './components/Profile/Button'
|
||||
import Contact from './components/Profile/Contact'
|
||||
import NintendoSW from "./components/Profile/NintendoSW"
|
||||
import FitbitSleep from "./components/Fitbit/Sleep"
|
||||
import FitbitHeartrate from "./components/Fitbit/Heartrate"
|
||||
|
||||
// next-seo
|
||||
import { NextSeo } from 'next-seo';
|
||||
@ -61,6 +63,8 @@ export default function Profile(props) {
|
||||
<div>
|
||||
<DiscordPlaying />
|
||||
<Spotify />
|
||||
<FitbitSleep />
|
||||
<FitbitHeartrate />
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user