2020-02-14 12:34:01 +03:00
|
|
|
|
<div class="flex items-stretch mt2">
|
|
|
|
|
<div class="flex-auto br4 shadow-1 bg-grouped-table mt2 flex flex-column justify-between items-stretch gh-member-settings-primary mr6">
|
|
|
|
|
<div class="pa5 pb0 pt4">
|
|
|
|
|
<GhFormGroup @errors={{this.member.errors}} @hasValidated={{this.member.hasValidated}} @property="name" @classNames="max-width">
|
2019-12-12 21:22:31 +03:00
|
|
|
|
<label for="member-name">Name</label>
|
2020-02-14 12:34:01 +03:00
|
|
|
|
<GhTextInput @id="member-name" @name="name" @value={{this.scratchMember.name}} @tabindex="1"
|
2020-01-16 18:14:03 +03:00
|
|
|
|
@focus-out={{action "setProperty" "name" this.scratchMember.name}} />
|
2019-12-13 19:11:49 +03:00
|
|
|
|
<GhErrorMessage @errors={{member.errors}} @property="name" />
|
2020-01-16 18:14:03 +03:00
|
|
|
|
</GhFormGroup>
|
2019-11-28 14:30:21 +03:00
|
|
|
|
|
2020-02-14 12:34:01 +03:00
|
|
|
|
<GhFormGroup @errors={{this.member.errors}} @hasValidated={{this.member.hasValidated}} @property="email" @classNames="max-width">
|
2019-12-12 21:22:31 +03:00
|
|
|
|
<label for="member-email">Email</label>
|
2020-02-14 12:34:01 +03:00
|
|
|
|
<GhTextInput @value={{this.scratchMember.email}} @id="member-email" @name="email" @tabindex="2"
|
|
|
|
|
@autocapitalize="off" @autocorrect="off" @autocomplete="off"
|
|
|
|
|
@focus-out={{action "setProperty" "email" this.scratchMember.email}} />
|
|
|
|
|
<GhErrorMessage @errors={{this.member.errors}} @property="email" />
|
2020-01-16 18:14:03 +03:00
|
|
|
|
</GhFormGroup>
|
2019-11-05 14:00:07 +03:00
|
|
|
|
</div>
|
2020-02-14 12:34:01 +03:00
|
|
|
|
<div class="pa5 pt5 pb6 bt b--whitegrey">
|
|
|
|
|
<GhFormGroup @classNames="gh-members-subscribed-checkbox mb0">
|
|
|
|
|
<div class="flex justify-between items-center">
|
|
|
|
|
<div>
|
|
|
|
|
<h4 class="gh-setting-title">Subscribed to newsletter</h4>
|
|
|
|
|
<p class="gh-setting-desc">If disabled, member will <em>not</em> receive newsletter emails</p>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="for-switch">
|
|
|
|
|
<label class="switch" for="subscribed-checkbox">
|
|
|
|
|
<Input @checked={{this.member.subscribed}} @type="checkbox" @id="subscribed-checkbox"
|
|
|
|
|
@name="subscribed" />
|
|
|
|
|
<span class="input-toggle-component"></span>
|
|
|
|
|
</label>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
2020-01-16 18:14:03 +03:00
|
|
|
|
</GhFormGroup>
|
2019-11-06 14:00:03 +03:00
|
|
|
|
</div>
|
|
|
|
|
</div>
|
2020-02-14 12:34:01 +03:00
|
|
|
|
<div class="flex-auto br4 shadow-1 bg-grouped-table mt2 flex flex-column items-stretch gh-member-settings-secondary">
|
|
|
|
|
<div class="pa5 pt4">
|
|
|
|
|
<GhFormGroup>
|
|
|
|
|
<label for="label-input">Labels</label>
|
|
|
|
|
<GhMemberLabelInput @member={{this.member}} @triggerId="label-input" />
|
|
|
|
|
</GhFormGroup>
|
|
|
|
|
<GhFormGroup @errors={{this.member.errors}} @hasValidated={{this.member.hasValidated}} @property="note" @classNames="mb0">
|
|
|
|
|
<label for="member-note">Note <span class="midgrey-l2 fw4">(not visible to member)</span></label>
|
|
|
|
|
<GhTextarea @id="member-note" @name="note" @class="gh-member-details-textarea" @tabindex="3"
|
|
|
|
|
@value={{this.scratchMember.note}} @focus-out={{action "setProperty" "note" this.scratchMember.note}} />
|
|
|
|
|
<GhErrorMessage @errors={{this.member.errors}} @property="note" />
|
|
|
|
|
<p> Maximum: <b>500</b> characters. You’ve used
|
|
|
|
|
{{gh-count-down-characters this.scratchMember.note 500}}</p>
|
|
|
|
|
</GhFormGroup>
|
|
|
|
|
</div>
|
2019-10-02 07:00:03 +03:00
|
|
|
|
</div>
|
2019-10-03 20:42:33 +03:00
|
|
|
|
</div>
|
|
|
|
|
|
2020-02-24 12:08:47 +03:00
|
|
|
|
{{#if canShowStripeInfo}}
|
2019-10-05 13:41:47 +03:00
|
|
|
|
<h4 class="midlightgrey f-small fw5 ttu mt12">Stripe info</h4>
|
2019-10-04 17:31:56 +03:00
|
|
|
|
|
2019-12-13 17:20:29 +03:00
|
|
|
|
{{#if this.isLoading}}
|
2019-10-05 14:01:43 +03:00
|
|
|
|
<div class="pa20 br4 shadow-1 bg-grouped-table mt2">
|
2019-10-07 15:26:32 +03:00
|
|
|
|
<div class="flex justify-center flex-auto">
|
|
|
|
|
<div class="gh-loading-spinner"> </div>
|
|
|
|
|
</div>
|
2019-10-04 17:31:56 +03:00
|
|
|
|
</div>
|
2019-10-07 15:26:32 +03:00
|
|
|
|
{{else}}
|
2020-01-28 07:27:19 +03:00
|
|
|
|
<div class="br4 shadow-1 bg-grouped-table mt2">
|
|
|
|
|
{{#if this.subscriptions}}
|
2019-12-13 17:20:29 +03:00
|
|
|
|
{{#if this.hasMultipleSubscriptions}}
|
2019-10-07 15:26:32 +03:00
|
|
|
|
<div class="pa2 flex flex-column flex-row-ns items-center justify-center f7 fw5 bg-whitegrey-l2 bb b--whitegrey br4 br--top">
|
|
|
|
|
{{svg-jar "info" class="gh-member-info-icon mr2 fill-darkgrey"}} Member has multiple Stripe subscriptions
|
|
|
|
|
</div>
|
|
|
|
|
{{/if}}
|
2019-12-13 17:20:29 +03:00
|
|
|
|
{{#each this.subscriptions as |subscription|}}
|
2019-10-07 15:26:32 +03:00
|
|
|
|
<section class="gh-member-stripe-info pa5 pb0 pt4 flex flex-column flex-row-ns items-start justify-between">
|
|
|
|
|
<div class="flex items-start w-100">
|
|
|
|
|
<div class="w-50 flex-auto mr8">
|
2019-12-12 16:00:57 +03:00
|
|
|
|
<h4 class="f8 fw6">Customer</h4>
|
2019-10-07 15:26:32 +03:00
|
|
|
|
<table class="gh-member-stripe-table">
|
|
|
|
|
<tr>
|
|
|
|
|
<td class="gh-member-stripe-label">Stripe customer ID</td>
|
2019-10-10 11:24:19 +03:00
|
|
|
|
<td class="gh-member-stripe-data">
|
2019-10-24 13:31:55 +03:00
|
|
|
|
<a href="https://dashboard.stripe.com/customers/{{subscription.customer.id}}" target="_blank" rel="noopener" data-tooltip="View on Stripe">
|
2019-10-10 11:24:19 +03:00
|
|
|
|
{{subscription.customer.id}}
|
|
|
|
|
</a>
|
|
|
|
|
</td>
|
2019-10-07 15:26:32 +03:00
|
|
|
|
</tr>
|
|
|
|
|
<tr>
|
|
|
|
|
<td class="gh-member-stripe-label">Name</td>
|
|
|
|
|
<td class="gh-member-stripe-data">
|
2019-10-21 18:24:57 +03:00
|
|
|
|
{{#if subscription.customer.name}}
|
|
|
|
|
{{subscription.customer.name}}
|
2019-10-07 15:26:32 +03:00
|
|
|
|
{{else}}
|
|
|
|
|
<span class="midlightgrey-l2">No name</span>
|
|
|
|
|
{{/if}}
|
|
|
|
|
</td>
|
|
|
|
|
</tr>
|
|
|
|
|
<tr>
|
|
|
|
|
<td class="gh-member-stripe-label">Email</td>
|
|
|
|
|
<td class="gh-member-stripe-data">
|
2019-10-10 11:24:19 +03:00
|
|
|
|
{{#if subscription.customer.email}}
|
|
|
|
|
{{subscription.customer.email}}
|
2019-10-07 15:26:32 +03:00
|
|
|
|
{{else}}
|
|
|
|
|
<span class="midlightgrey-l2">No email</span>
|
|
|
|
|
{{/if}}
|
|
|
|
|
</td>
|
|
|
|
|
</tr>
|
|
|
|
|
<tr>
|
|
|
|
|
<td class="gh-member-stripe-label">Customer since</td>
|
|
|
|
|
<td class="gh-member-stripe-data">
|
|
|
|
|
{{#if subscription.startDate}}
|
|
|
|
|
{{subscription.startDate}}
|
|
|
|
|
{{else}}
|
|
|
|
|
<span class="midlightgrey-l2">No data</span>
|
|
|
|
|
{{/if}}
|
|
|
|
|
</td>
|
|
|
|
|
</tr>
|
|
|
|
|
</table>
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<div class="w-50 flex-auto">
|
2019-12-12 16:00:57 +03:00
|
|
|
|
<h4 class="f8 fw6">Subscription</h4>
|
2019-10-07 15:26:32 +03:00
|
|
|
|
<table class="gh-member-stripe-table">
|
|
|
|
|
<tr>
|
2019-12-12 16:00:57 +03:00
|
|
|
|
<td class="gh-member-stripe-label">Stripe subscription ID</td>
|
|
|
|
|
<td class="gh-member-stripe-data">
|
|
|
|
|
<a href="https://dashboard.stripe.com/subscriptions/{{subscription.id}}" target="_blank" rel="noopener"
|
|
|
|
|
data-tooltip="View on Stripe">
|
|
|
|
|
{{subscription.id}}
|
|
|
|
|
</a>
|
|
|
|
|
</td>
|
2019-10-07 15:26:32 +03:00
|
|
|
|
</tr>
|
|
|
|
|
<tr>
|
2019-12-12 16:00:57 +03:00
|
|
|
|
<td class="gh-member-stripe-label">Plan</td>
|
|
|
|
|
<td class="gh-member-stripe-data">
|
2019-12-12 21:22:31 +03:00
|
|
|
|
{{subscription.plan.nickname}}
|
2020-03-04 08:31:39 +03:00
|
|
|
|
<span class="midgrey">({{subscription.amount}}
|
2019-12-12 16:00:57 +03:00
|
|
|
|
<span class="ttu">{{subscription.plan.currency}}</span>/{{subscription.plan.interval}})
|
|
|
|
|
</span>
|
|
|
|
|
</td>
|
2019-10-07 15:26:32 +03:00
|
|
|
|
</tr>
|
2019-12-12 16:00:57 +03:00
|
|
|
|
<tr>
|
|
|
|
|
<td class="gh-member-stripe-label">Status</td>
|
|
|
|
|
<td class="gh-member-stripe-data">
|
|
|
|
|
{{#if subscription.cancelAtPeriodEnd}}
|
|
|
|
|
<span class="gh-member-cancels-on-label">Cancels on {{subscription.validUntil}}</span>
|
|
|
|
|
{{else}}
|
|
|
|
|
<span class="gh-member-stripe-status">{{subscription.status}}</span>
|
|
|
|
|
{{/if}}
|
|
|
|
|
</td>
|
2019-12-12 21:22:31 +03:00
|
|
|
|
</tr>
|
2019-10-07 15:26:32 +03:00
|
|
|
|
<tr>
|
|
|
|
|
<td class="gh-member-stripe-label">Next renewal date</td>
|
2019-12-12 16:00:57 +03:00
|
|
|
|
<td class="gh-member-stripe-data">
|
|
|
|
|
{{#if subscription.cancelAtPeriodEnd}}
|
|
|
|
|
No further renewal
|
|
|
|
|
{{else}}
|
|
|
|
|
{{subscription.validUntil}}
|
|
|
|
|
{{/if}}
|
|
|
|
|
</td>
|
2019-10-07 15:26:32 +03:00
|
|
|
|
</tr>
|
|
|
|
|
</table>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</section>
|
|
|
|
|
{{/each}}
|
2020-01-28 07:27:19 +03:00
|
|
|
|
{{else}}
|
|
|
|
|
<div class="pa20">
|
|
|
|
|
<p class="ma0 pa0 tc midgrey">Member doesn't have an active Stripe subscription</p>
|
|
|
|
|
</div>
|
|
|
|
|
{{/if}}
|
|
|
|
|
<div class="pa5 pb0 pt4 flex flex-column justify-between bt b--whitegrey">
|
|
|
|
|
<GhFormGroup @classNames="gh-members-comped-checkbox">
|
|
|
|
|
<div class="flex justify-between items-center">
|
|
|
|
|
<div>
|
|
|
|
|
<h4 class="gh-setting-title">Complimentary premium plan</h4>
|
|
|
|
|
<p class="gh-setting-desc">If enabled, member will be placed onto a free of charge premium subscription</p>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="for-switch">
|
|
|
|
|
<label class="switch" for="comped-checkbox">
|
|
|
|
|
<Input @checked={{this.member.comped}} @type="checkbox" @id="comped-checkbox" @name="comped" />
|
|
|
|
|
<span class="input-toggle-component"></span>
|
|
|
|
|
</label>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</GhFormGroup>
|
2019-10-07 15:26:32 +03:00
|
|
|
|
</div>
|
2020-01-28 07:27:19 +03:00
|
|
|
|
</div>
|
2019-10-24 13:31:55 +03:00
|
|
|
|
{{/if}}
|
2020-02-24 12:08:47 +03:00
|
|
|
|
{{/if}}
|