mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-20 22:42:53 -05:00
Updated price/products data for portal settings
refs https://github.com/TryGhost/Team/issues/718 The ids for default prices for a product is now stored directly on product model instead of on global settings. This change updates - the products data sent to Portal to use list of products with their active monthly/yearly prices, as well as - the prices data sent to Portal to use the prices of default(first) product
This commit is contained in:
parent
ea9a83d444
commit
4e01fe9d09
1 changed files with 19 additions and 24 deletions
|
@ -77,29 +77,27 @@ const updateMemberData = async function (req, res) {
|
|||
}
|
||||
};
|
||||
|
||||
const getDefaultProductPrices = async function () {
|
||||
const getPortalProductPrices = async function () {
|
||||
const page = await membersService.api.productRepository.list({
|
||||
limit: 1
|
||||
});
|
||||
const [product] = page.data;
|
||||
if (product) {
|
||||
const model = await membersService.api.productRepository.get({id: product.get('id')}, {withRelated: ['stripePrices']});
|
||||
const productData = model.toJSON();
|
||||
const prices = productData.stripePrices || [];
|
||||
const activePrices = prices.filter((d) => {
|
||||
return !!d.active;
|
||||
});
|
||||
const monthlyPriceId = settingsCache.get('members_monthly_price_id');
|
||||
const yearlyPriceId = settingsCache.get('members_yearly_price_id');
|
||||
const filteredPrices = activePrices.filter((d) => {
|
||||
return [monthlyPriceId, yearlyPriceId].includes(d.id);
|
||||
withRelated: ['monthlyPrice', 'yearlyPrice']
|
||||
});
|
||||
|
||||
const products = page.data.map((productModel) => {
|
||||
const product = productModel.toJSON();
|
||||
|
||||
return {
|
||||
product: productData,
|
||||
prices: filteredPrices
|
||||
id: product.id,
|
||||
name: product.name,
|
||||
description: product.description || '',
|
||||
prices: [product.monthlyPrice, product.yearlyPrice]
|
||||
};
|
||||
});
|
||||
|
||||
const defaultPrices = products[0] ? products[0].prices : [];
|
||||
return {
|
||||
prices: defaultPrices,
|
||||
products: products
|
||||
};
|
||||
}
|
||||
return {};
|
||||
};
|
||||
|
||||
const getMemberSiteData = async function (req, res) {
|
||||
|
@ -111,7 +109,7 @@ const getMemberSiteData = async function (req, res) {
|
|||
if (!supportAddress.includes('@')) {
|
||||
supportAddress = `${supportAddress}@${blogDomain}`;
|
||||
}
|
||||
const {product = {}, prices = []} = await getDefaultProductPrices() || {};
|
||||
const {products = [], prices = []} = await getPortalProductPrices() || {};
|
||||
const response = {
|
||||
title: settingsCache.get('title'),
|
||||
description: settingsCache.get('description'),
|
||||
|
@ -122,10 +120,7 @@ const getMemberSiteData = async function (req, res) {
|
|||
version: ghostVersion.safe,
|
||||
plans: membersService.config.getPublicPlans(),
|
||||
prices,
|
||||
product: {
|
||||
name: product.name || '',
|
||||
description: product.description || ''
|
||||
},
|
||||
products,
|
||||
free_price_name: settingsCache.get('members_free_price_name'),
|
||||
free_price_description: settingsCache.get('members_free_price_description'),
|
||||
allow_self_signup: membersService.config.getAllowSelfSignup(),
|
||||
|
|
Loading…
Add table
Reference in a new issue