Files
notesnook/apps/mobile/app/hooks/use-pricing.ts

59 lines
1.5 KiB
TypeScript
Raw Normal View History

import { useEffect, useState } from "react";
import { Platform } from "react-native";
import { Subscription } from "react-native-iap";
import PremiumService from "../services/premium";
import { db } from "../common/database";
2022-04-05 00:50:02 +05:00
type PurchaseInfo = {
country: string;
countryCode: string;
sku: string;
discount: number;
};
const skuInfos: { [name: string]: PurchaseInfo | undefined } = {};
export const usePricing = (period: "monthly" | "yearly") => {
2022-07-09 17:04:53 +05:00
const [current, setCurrent] = useState<{
period: string;
info?: PurchaseInfo;
product?: Subscription;
}>();
2022-04-05 00:50:02 +05:00
const getDefaultSku = (period: "monthly" | "yearly") => {
return period === "monthly"
? "com.streetwriters.notesnook.sub.mo"
: "com.streetwriters.notesnook.sub.yr";
2022-04-05 00:50:02 +05:00
};
useEffect(() => {
(async () => {
let skuInfo =
skuInfos[period] ||
(await db.pricing?.sku(
Platform.OS === "android" ? "android" : "ios",
period
));
2022-04-05 00:50:02 +05:00
skuInfos[period] = skuInfo;
let products = (await PremiumService.getProducts()) as Subscription[];
let product = products.find((p) => p.productId === skuInfo?.sku);
if (!product)
product = products.find((p) => p.productId === getDefaultSku(period));
console.log(
"skuInfos: ",
skuInfos,
product?.productId,
product?.price,
products.length
);
2022-04-05 00:50:02 +05:00
setCurrent({
info: skuInfo,
period,
product
});
})();
}, [period]);
return current;
};