mirror of
https://github.com/lingble/chatwoot.git
synced 2025-10-29 02:02:27 +00:00
Fixes https://github.com/chatwoot/chatwoot/issues/8436 Fixes https://github.com/chatwoot/chatwoot/issues/9767 Fixes https://github.com/chatwoot/chatwoot/issues/10156 Fixes https://github.com/chatwoot/chatwoot/issues/6031 Fixes https://github.com/chatwoot/chatwoot/issues/5696 Fixes https://github.com/chatwoot/chatwoot/issues/9250 Fixes https://github.com/chatwoot/chatwoot/issues/9762 --------- Co-authored-by: Pranav <pranavrajs@gmail.com> Co-authored-by: Sivin Varghese <64252451+iamsivin@users.noreply.github.com>
92 lines
2.1 KiB
Vue
92 lines
2.1 KiB
Vue
<script>
|
|
import { mapGetters } from 'vuex';
|
|
import { useAdmin } from 'dashboard/composables/useAdmin';
|
|
import { useAccount } from 'dashboard/composables/useAccount';
|
|
import Banner from 'dashboard/components/ui/Banner.vue';
|
|
|
|
const EMPTY_SUBSCRIPTION_INFO = {
|
|
status: null,
|
|
endsOn: null,
|
|
};
|
|
|
|
export default {
|
|
components: { Banner },
|
|
setup() {
|
|
const { isAdmin } = useAdmin();
|
|
|
|
const { accountId } = useAccount();
|
|
|
|
return {
|
|
accountId,
|
|
isAdmin,
|
|
};
|
|
},
|
|
computed: {
|
|
...mapGetters({
|
|
isOnChatwootCloud: 'globalConfig/isOnChatwootCloud',
|
|
getAccount: 'accounts/getAccount',
|
|
}),
|
|
bannerMessage() {
|
|
return this.$t('GENERAL_SETTINGS.PAYMENT_PENDING');
|
|
},
|
|
actionButtonMessage() {
|
|
return this.$t('GENERAL_SETTINGS.OPEN_BILLING');
|
|
},
|
|
shouldShowBanner() {
|
|
if (!this.isOnChatwootCloud) {
|
|
return false;
|
|
}
|
|
|
|
if (!this.isAdmin) {
|
|
return false;
|
|
}
|
|
|
|
return this.isPaymentPending();
|
|
},
|
|
},
|
|
methods: {
|
|
routeToBilling() {
|
|
this.$router.push({
|
|
name: 'billing_settings_index',
|
|
params: { accountId: this.accountId },
|
|
});
|
|
},
|
|
isPaymentPending() {
|
|
const { status, endsOn } = this.getSubscriptionInfo();
|
|
|
|
if (status && endsOn) {
|
|
const now = new Date();
|
|
if (status === 'past_due' && endsOn < now) {
|
|
return true;
|
|
}
|
|
}
|
|
|
|
return false;
|
|
},
|
|
getSubscriptionInfo() {
|
|
const account = this.getAccount(this.accountId);
|
|
if (!account) return EMPTY_SUBSCRIPTION_INFO;
|
|
|
|
const { custom_attributes: subscription } = account;
|
|
if (!subscription) return EMPTY_SUBSCRIPTION_INFO;
|
|
|
|
const { subscription_status: status, subscription_ends_on: endsOn } =
|
|
subscription;
|
|
|
|
return { status, endsOn: new Date(endsOn) };
|
|
},
|
|
},
|
|
};
|
|
</script>
|
|
|
|
<template>
|
|
<Banner
|
|
v-if="shouldShowBanner"
|
|
color-scheme="alert"
|
|
:banner-message="bannerMessage"
|
|
:action-button-label="actionButtonMessage"
|
|
has-action-button
|
|
@primaryAction="routeToBilling"
|
|
/>
|
|
</template>
|