2019-08-12 09:38:01 +00:00
|
|
|
import appleTouchIcon from "@assets/favicons/apple-touch-icon.png";
|
|
|
|
import favicon16 from "@assets/favicons/favicon-16x16.png";
|
|
|
|
import favicon32 from "@assets/favicons/favicon-32x32.png";
|
|
|
|
import safariPinnedTab from "@assets/favicons/safari-pinned-tab.svg";
|
2023-01-16 09:45:12 +00:00
|
|
|
import { useUser } from "@dashboard/auth";
|
|
|
|
import { ShopInfoQuery, useShopInfoQuery } from "@dashboard/graphql";
|
2020-05-14 09:30:32 +00:00
|
|
|
import React from "react";
|
|
|
|
import Helmet from "react-helmet";
|
|
|
|
|
2022-03-09 08:56:55 +00:00
|
|
|
type ShopContext = ShopInfoQuery["shop"];
|
2019-06-19 14:40:52 +00:00
|
|
|
|
2019-08-12 09:38:01 +00:00
|
|
|
export const ShopContext = React.createContext<ShopContext>(undefined);
|
2019-06-19 14:40:52 +00:00
|
|
|
|
2021-09-21 13:30:41 +00:00
|
|
|
export const ShopProvider: React.FC = ({ children }) => {
|
2022-10-06 11:46:23 +00:00
|
|
|
const { authenticated, user } = useUser();
|
2022-03-09 08:56:55 +00:00
|
|
|
const { data } = useShopInfoQuery({
|
2022-10-06 11:46:23 +00:00
|
|
|
skip: !authenticated || !user,
|
2022-03-09 08:56:55 +00:00
|
|
|
});
|
2021-09-21 13:30:41 +00:00
|
|
|
|
|
|
|
return (
|
2022-03-09 08:56:55 +00:00
|
|
|
<>
|
|
|
|
<Helmet>
|
|
|
|
<link rel="apple-touch-icon" sizes="180x180" href={appleTouchIcon} />
|
|
|
|
<link rel="icon" type="image/png" sizes="32x32" href={favicon32} />
|
|
|
|
<link rel="icon" type="image/png" sizes="16x16" href={favicon16} />
|
|
|
|
<link rel="mask-icon" href={safariPinnedTab} />
|
|
|
|
</Helmet>
|
|
|
|
<ShopContext.Provider value={data ? data.shop : undefined}>
|
|
|
|
{children}
|
|
|
|
</ShopContext.Provider>
|
|
|
|
</>
|
2021-09-21 13:30:41 +00:00
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2019-08-12 09:38:01 +00:00
|
|
|
export const Shop = ShopContext.Consumer;
|
2019-06-19 14:40:52 +00:00
|
|
|
export default Shop;
|