mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-07 03:22:21 +03:00
Showed created at dates for complimentary subscriptions (#2089)
refs https://github.com/TryGhost/Team/issues/873 When we updated the UI to handle the default subscriptions for Complimentary subscriptions, we didn't update it to use any of the data. This updates the UI to share as much as possible for the display of subscriptions information, and only diverges for the menus which have different actions based on complimentary or not. This should ensure that we keep the UI in sync for both types of Member. * Hid Complimentary subscription CTA for members with one.
This commit is contained in:
parent
101b0061b5
commit
6c207f5e72
@ -165,41 +165,6 @@
|
||||
</h3>
|
||||
|
||||
{{#each product.subscriptions as |sub|}}
|
||||
{{#if sub.isComplimentary}}
|
||||
<div class="gh-memberproduct-subscription">
|
||||
<div>
|
||||
<div>
|
||||
<span class="gh-cp-memberproduct-pricelabel">Complimentary</span>
|
||||
<span class="gh-badge active">Active</span>
|
||||
</div>
|
||||
<div class="gh-memberproduct-created">Created on</div>
|
||||
</div>
|
||||
<div class="flex items-center">
|
||||
<div class="gh-product-card-price">
|
||||
<div class="flex items-start">
|
||||
<span class="currency-symbol">$</span>
|
||||
<span class="amount">0</span>
|
||||
</div>
|
||||
<div class="period">yearly</div>
|
||||
</div>
|
||||
<span class="action-menu">
|
||||
<GhDropdownButton @dropdownName="subscription-menu-complimentary" @classNames="gh-btn gh-btn-outline gh-btn-icon gh-btn-subscription-action icon-only" @title="Actions">
|
||||
<span>
|
||||
{{svg-jar "dotdotdot"}}
|
||||
<span class="hidden">Subscription menu</span>
|
||||
</span>
|
||||
</GhDropdownButton>
|
||||
<GhDropdown @name="subscription-menu-complimentary" @tagName="ul" @classNames="product-actions-menu dropdown-menu dropdown-align-right">
|
||||
<li>
|
||||
<button {{action "removeComplimentary" product.id}}>
|
||||
<span class="red">Remove complimentary subscription</span>
|
||||
</button>
|
||||
</li>
|
||||
</GhDropdown>
|
||||
</span>
|
||||
</div>
|
||||
</div>
|
||||
{{else}}
|
||||
<div class="gh-memberproduct-subscription">
|
||||
<div>
|
||||
<div>
|
||||
@ -227,7 +192,24 @@
|
||||
</div>
|
||||
<div class="period">{{if (eq sub.price.interval "year") "yearly" "monthly"}}</div>
|
||||
</div>
|
||||
{{#if sub.isComplimentary}}
|
||||
<span class="action-menu">
|
||||
<GhDropdownButton @dropdownName="subscription-menu-complimentary" @classNames="gh-btn gh-btn-outline gh-btn-icon gh-btn-subscription-action icon-only" @title="Actions">
|
||||
<span>
|
||||
{{svg-jar "dotdotdot"}}
|
||||
<span class="hidden">Subscription menu</span>
|
||||
</span>
|
||||
</GhDropdownButton>
|
||||
<GhDropdown @name="subscription-menu-complimentary" @tagName="ul" @classNames="product-actions-menu dropdown-menu dropdown-align-right">
|
||||
<li>
|
||||
<button {{action "removeComplimentary" product.id}}>
|
||||
<span class="red">Remove complimentary subscription</span>
|
||||
</button>
|
||||
</li>
|
||||
</GhDropdown>
|
||||
</span>
|
||||
|
||||
{{else}}
|
||||
<span class="action-menu">
|
||||
<GhDropdownButton @dropdownName="subscription-menu-{{sub.id}}" @classNames="gh-btn gh-btn-outline gh-btn-icon gh-btn-subscription-action icon-only" @title="Actions">
|
||||
<span>
|
||||
@ -260,9 +242,9 @@
|
||||
</li>
|
||||
</GhDropdown>
|
||||
</span>
|
||||
</div>
|
||||
</div>
|
||||
{{/if}}
|
||||
</div>
|
||||
</div>
|
||||
{{/each}}
|
||||
|
||||
{{#if (and (feature "multipleProducts") (eq product.subscriptions.length 0))}}
|
||||
|
@ -35,16 +35,13 @@ export default class extends Component {
|
||||
if (!this.membersUtils.isStripeEnabled) {
|
||||
return false;
|
||||
}
|
||||
if (this.feature.get('multipleProducts')) {
|
||||
return true;
|
||||
|
||||
let products = this.member.get('products');
|
||||
if (products && products.length > 0) {
|
||||
return false;
|
||||
}
|
||||
let subscriptions = this.member.get('subscriptions') || [];
|
||||
const hasZeroPriceSub = subscriptions.filter((sub) => {
|
||||
return ['active', 'trialing', 'unpaid', 'past_due'].includes(sub.status);
|
||||
}).find((sub) => {
|
||||
return !sub?.price?.amount;
|
||||
});
|
||||
return !hasZeroPriceSub;
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
get products() {
|
||||
|
Loading…
Reference in New Issue
Block a user