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

68 lines
2.1 KiB
TypeScript
Raw Normal View History

/*
This file is part of the Notesnook project (https://notesnook.com/)
2023-01-16 13:44:52 +05:00
Copyright (C) 2023 Streetwriters (Private) Limited
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
2022-08-30 16:13:11 +05:00
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";
2024-09-23 15:18:44 +05:00
import { Product } from "@notesnook/core";
2022-04-05 00:50:02 +05:00
const skuInfos: { [name: string]: Product | undefined } = {};
2022-04-05 00:50:02 +05:00
export const usePricing = (period: "monthly" | "yearly") => {
2022-07-09 17:04:53 +05:00
const [current, setCurrent] = useState<{
period: string;
info?: Product;
2022-07-09 17:04:53 +05:00
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 () => {
const skuInfo =
2022-04-05 00:50:02 +05:00
skuInfos[period] ||
(await db.pricing?.sku(
Platform.OS === "android" ? "android" : "ios",
period
));
2022-04-05 00:50:02 +05:00
skuInfos[period] = skuInfo;
2025-07-01 12:13:03 +05:00
const products = (await (
await PremiumService.loadProductsAndSubs()
).subs) as Subscription[];
let product = products.find((p) => p.productId === skuInfo?.sku);
if (!product)
product = products.find((p) => p.productId === getDefaultSku(period));
2022-04-05 00:50:02 +05:00
setCurrent({
info: skuInfo,
period,
product
});
})();
}, [period]);
return current;
};