!menuItem.toState.includes('billing')
- );
- },
filterMenuItemsByRole(menuItems) {
if (!this.currentRole) {
return [];
diff --git a/app/javascript/dashboard/components/widgets/StatusBar.vue b/app/javascript/dashboard/components/widgets/StatusBar.vue
deleted file mode 100644
index 902c2515e..000000000
--- a/app/javascript/dashboard/components/widgets/StatusBar.vue
+++ /dev/null
@@ -1,24 +0,0 @@
-
-
-
{{message}}
-
- {{buttonText}}
-
-
-
-
-
diff --git a/app/javascript/dashboard/helper/APIHelper.js b/app/javascript/dashboard/helper/APIHelper.js
index b1692d492..03e902259 100644
--- a/app/javascript/dashboard/helper/APIHelper.js
+++ b/app/javascript/dashboard/helper/APIHelper.js
@@ -1,15 +1,8 @@
/* eslint no-console: 0 */
import constants from '../constants';
import Auth from '../api/auth';
-import router from '../routes';
const parseErrorCode = error => {
- const errorStatus = error.response ? error.response.status : undefined;
- // 901, 902 are used to identify billing related issues
- if ([901, 902].includes(errorStatus)) {
- const name = Auth.isAdmin() ? 'billing' : 'billing_deactivated';
- router.push({ name });
- }
return Promise.reject(error);
};
diff --git a/app/javascript/dashboard/i18n/default-sidebar.js b/app/javascript/dashboard/i18n/default-sidebar.js
index f1823915c..5ada97da4 100644
--- a/app/javascript/dashboard/i18n/default-sidebar.js
+++ b/app/javascript/dashboard/i18n/default-sidebar.js
@@ -8,7 +8,6 @@ export const getSidebarItems = accountId => ({
'inbox_conversation',
'conversation_through_inbox',
'settings_account_reports',
- 'billing_deactivated',
'profile_settings',
'profile_settings_index',
],
@@ -51,7 +50,6 @@ export const getSidebarItems = accountId => ({
'settings_inboxes_page_channel',
'settings_inboxes_add_agents',
'settings_inbox_finish',
- 'billing',
'settings_integrations',
'settings_integrations_webhook',
'general_settings',
@@ -88,13 +86,6 @@ export const getSidebarItems = accountId => ({
),
toStateName: 'canned_list',
},
- billing: {
- icon: 'ion-card',
- label: 'BILLING',
- hasSubMenu: false,
- toState: frontendURL(`accounts/${accountId}/settings/billing`),
- toStateName: 'billing',
- },
settings_integrations: {
icon: 'ion-flash',
label: 'INTEGRATIONS',
diff --git a/app/javascript/dashboard/i18n/locale/ca/billing.json b/app/javascript/dashboard/i18n/locale/ca/billing.json
deleted file mode 100644
index c44ba0dbf..000000000
--- a/app/javascript/dashboard/i18n/locale/ca/billing.json
+++ /dev/null
@@ -1,19 +0,0 @@
-{
- "BILLING": {
- "HEADER": "Facturació",
- "LOADING": "S'estan obtenin les suscripcions",
- "ACCOUNT_STATE": "Estat del compte",
- "AGENT_COUNT": "Compte d'agent",
- "PER_AGENT_COST": "Per cost d'agent",
- "TOTAL_COST": "Cost total",
- "BUTTON": {
- "ADD": "Afegir mètode de pagament",
- "EDIT": "EDITAR Mètode de pagament"
- },
- "TRIAL": {
- "TITLE": "S'ha acabat el període de prova",
- "MESSAGE": "Afegiu un mètode de pagament per continuar utilitzant Chatwoot."
- },
- "ACCOUNT_LOCKED": "El seu compte no està disponible de moment.
Poseu-vos en contacte amb l'administrador per reactivar-lo."
- }
-}
diff --git a/app/javascript/dashboard/i18n/locale/ca/index.js b/app/javascript/dashboard/i18n/locale/ca/index.js
index 351906dd9..558cc9b3a 100644
--- a/app/javascript/dashboard/i18n/locale/ca/index.js
+++ b/app/javascript/dashboard/i18n/locale/ca/index.js
@@ -1,6 +1,5 @@
/* eslint-disable */
import { default as _agentMgmt } from './agentMgmt.json';
-import { default as _billing } from './billing.json';
import { default as _cannedMgmt } from './cannedMgmt.json';
import { default as _chatlist } from './chatlist.json';
import { default as _contact } from './contact.json';
@@ -17,7 +16,6 @@ import { default as _generalSettings } from './generalSettings.json';
export default {
..._agentMgmt,
- ..._billing,
..._cannedMgmt,
..._chatlist,
..._contact,
diff --git a/app/javascript/dashboard/i18n/locale/ca/settings.json b/app/javascript/dashboard/i18n/locale/ca/settings.json
index a36b33447..bf2ffbe39 100644
--- a/app/javascript/dashboard/i18n/locale/ca/settings.json
+++ b/app/javascript/dashboard/i18n/locale/ca/settings.json
@@ -87,7 +87,6 @@
"AGENTS": "Agents",
"INBOXES": "Safates d'entrada",
"CANNED_RESPONSES": "Respostes Predeterminades",
- "BILLING": "Facturació",
"INTEGRATIONS": "Integracions",
"ACCOUNT_SETTINGS": "Configuració del compte"
}
diff --git a/app/javascript/dashboard/i18n/locale/cs/billing.json b/app/javascript/dashboard/i18n/locale/cs/billing.json
deleted file mode 100644
index cf6469e88..000000000
--- a/app/javascript/dashboard/i18n/locale/cs/billing.json
+++ /dev/null
@@ -1,19 +0,0 @@
-{
- "BILLING": {
- "HEADER": "Fakturace",
- "LOADING": "Načítání předplatného",
- "ACCOUNT_STATE": "Stav účtu",
- "AGENT_COUNT": "Počet agentů",
- "PER_AGENT_COST": "Náklady na jednoho agenta",
- "TOTAL_COST": "Celkové náklady",
- "BUTTON": {
- "ADD": "Přidat způsob platby",
- "EDIT": "Metoda platby EDIT"
- },
- "TRIAL": {
- "TITLE": "Vaše zkušební období skončilo",
- "MESSAGE": "Přidejte platební metodu a pokračujte v používání Chatwoot."
- },
- "ACCOUNT_LOCKED": "Váš účet není momentálně k dispozici.
Obraťte se na správce pro opětovné aktivaci."
- }
-}
diff --git a/app/javascript/dashboard/i18n/locale/de/billing.json b/app/javascript/dashboard/i18n/locale/de/billing.json
deleted file mode 100644
index 44f4f290f..000000000
--- a/app/javascript/dashboard/i18n/locale/de/billing.json
+++ /dev/null
@@ -1,19 +0,0 @@
-{
- "BILLING": {
- "HEADER": "Abrechnung",
- "LOADING": "Abonnements abrufen",
- "ACCOUNT_STATE": "Kontostatus",
- "AGENT_COUNT": "Anzahl der Agenten",
- "PER_AGENT_COST": "Kosten pro Agent",
- "TOTAL_COST": "Gesamtkosten",
- "BUTTON": {
- "ADD": "Zahlungsmethode hinzufügen",
- "EDIT": "Zahlungsmethode BEARBEITEN"
- },
- "TRIAL": {
- "TITLE": "Ihre Probezeit ist vorbei",
- "MESSAGE": "Fügen Sie eine Zahlungsmethode hinzu, um Chatwoot weiterhin zu verwenden."
- },
- "ACCOUNT_LOCKED": "Ihr Konto ist derzeit nicht verfügbar.
Bitte wenden Sie sich zur Reaktivierung an Ihren Administrator."
- }
-}
diff --git a/app/javascript/dashboard/i18n/locale/de/index.js b/app/javascript/dashboard/i18n/locale/de/index.js
index 351906dd9..558cc9b3a 100644
--- a/app/javascript/dashboard/i18n/locale/de/index.js
+++ b/app/javascript/dashboard/i18n/locale/de/index.js
@@ -1,6 +1,5 @@
/* eslint-disable */
import { default as _agentMgmt } from './agentMgmt.json';
-import { default as _billing } from './billing.json';
import { default as _cannedMgmt } from './cannedMgmt.json';
import { default as _chatlist } from './chatlist.json';
import { default as _contact } from './contact.json';
@@ -17,7 +16,6 @@ import { default as _generalSettings } from './generalSettings.json';
export default {
..._agentMgmt,
- ..._billing,
..._cannedMgmt,
..._chatlist,
..._contact,
diff --git a/app/javascript/dashboard/i18n/locale/de/settings.json b/app/javascript/dashboard/i18n/locale/de/settings.json
index 70a99e24b..c9ff6b118 100644
--- a/app/javascript/dashboard/i18n/locale/de/settings.json
+++ b/app/javascript/dashboard/i18n/locale/de/settings.json
@@ -90,7 +90,6 @@
"AGENTS": "Agenten",
"INBOXES": "Posteingänge",
"CANNED_RESPONSES": "Vorgefertigte Antworten",
- "BILLING": "Abrechnung",
"INTEGRATIONS": "Integrationen",
"ACCOUNT_SETTINGS": "Kontoeinstellungen"
}
diff --git a/app/javascript/dashboard/i18n/locale/el/billing.json b/app/javascript/dashboard/i18n/locale/el/billing.json
deleted file mode 100644
index 6a96433ff..000000000
--- a/app/javascript/dashboard/i18n/locale/el/billing.json
+++ /dev/null
@@ -1,19 +0,0 @@
-{
- "BILLING": {
- "HEADER": "Χρεώσεις",
- "LOADING": "Λήψη Συνδρομών",
- "ACCOUNT_STATE": "Κατάσταση Λογαριασμού",
- "AGENT_COUNT": "Αριθμός Πρακτόρων",
- "PER_AGENT_COST": "Κόστος ανά πράκτορα",
- "TOTAL_COST": "Συνολικό κόστος",
- "BUTTON": {
- "ADD": "Προσθήκη μεθόδου πληρωμής",
- "EDIT": "Επεξεργασία μεθόδου πληρωμής"
- },
- "TRIAL": {
- "TITLE": "Η δοκιμαστική περίοδος ολοκληρώθηκε",
- "MESSAGE": "Προσθέστε μια μέθοδο πληρωμής για να συνεχίσετε την χρήση του Chatwoot."
- },
- "ACCOUNT_LOCKED": "O Λογαριασμός σας δεν είναι ενεργός αυτήν τη στιγμή.
Παρακαλώ απευθυνθείτε στον διαχειριστή για ενεργοποίηση."
- }
-}
diff --git a/app/javascript/dashboard/i18n/locale/el/index.js b/app/javascript/dashboard/i18n/locale/el/index.js
index 351906dd9..558cc9b3a 100644
--- a/app/javascript/dashboard/i18n/locale/el/index.js
+++ b/app/javascript/dashboard/i18n/locale/el/index.js
@@ -1,6 +1,5 @@
/* eslint-disable */
import { default as _agentMgmt } from './agentMgmt.json';
-import { default as _billing } from './billing.json';
import { default as _cannedMgmt } from './cannedMgmt.json';
import { default as _chatlist } from './chatlist.json';
import { default as _contact } from './contact.json';
@@ -17,7 +16,6 @@ import { default as _generalSettings } from './generalSettings.json';
export default {
..._agentMgmt,
- ..._billing,
..._cannedMgmt,
..._chatlist,
..._contact,
diff --git a/app/javascript/dashboard/i18n/locale/el/settings.json b/app/javascript/dashboard/i18n/locale/el/settings.json
index 9f8790ffb..1af3e5b01 100644
--- a/app/javascript/dashboard/i18n/locale/el/settings.json
+++ b/app/javascript/dashboard/i18n/locale/el/settings.json
@@ -102,7 +102,6 @@
"AGENTS": "Πράκτορες",
"INBOXES": "Κιβώτια Εισερχομένων",
"CANNED_RESPONSES": "Έτοιμες Απαντήσεις",
- "BILLING": "Χρεώσεις",
"INTEGRATIONS": "Ενοποιήσεις",
"ACCOUNT_SETTINGS": "Ρυθμίσεις Λογαριασμού"
}
diff --git a/app/javascript/dashboard/i18n/locale/en/agentMgmt.json b/app/javascript/dashboard/i18n/locale/en/agentMgmt.json
index 6ec788207..633424fed 100644
--- a/app/javascript/dashboard/i18n/locale/en/agentMgmt.json
+++ b/app/javascript/dashboard/i18n/locale/en/agentMgmt.json
@@ -3,7 +3,7 @@
"HEADER": "Agents",
"HEADER_BTN_TXT": "Add Agent",
"LOADING": "Fetching Agent List",
- "SIDEBAR_TXT": "
Agents
An Agent is a member of your Customer Support team.
Agents will be able to view and reply to messages from your users. The list shows all agents currently in your account.
Click on Add Agent to add a new agent. Agent you add will receive an email with a confirmation link to activate their account, after which they can access Chatwoot and respond to messages.
Access to Chatwoot's features are based on following roles.
Agent - Agents with this role can only access inboxes, reports and conversations. They can assign conversations to other agents or themselves and resolve conversations.
Administrator - Administrator will have access to all Chatwoot features enabled for your account, including settings and billing, along with all of a normal agents' privileges.
",
+ "SIDEBAR_TXT": "
Agents
An Agent is a member of your Customer Support team.
Agents will be able to view and reply to messages from your users. The list shows all agents currently in your account.
Click on Add Agent to add a new agent. Agent you add will receive an email with a confirmation link to activate their account, after which they can access Chatwoot and respond to messages.
Access to Chatwoot's features are based on following roles.
Agent - Agents with this role can only access inboxes, reports and conversations. They can assign conversations to other agents or themselves and resolve conversations.
Administrator - Administrator will have access to all Chatwoot features enabled for your account, including settings, along with all of a normal agents' privileges.
",
"AGENT_TYPES": [
{
"name": "administrator",
diff --git a/app/javascript/dashboard/i18n/locale/en/billing.json b/app/javascript/dashboard/i18n/locale/en/billing.json
deleted file mode 100644
index 4d300775d..000000000
--- a/app/javascript/dashboard/i18n/locale/en/billing.json
+++ /dev/null
@@ -1,19 +0,0 @@
-{
- "BILLING": {
- "HEADER": "Billing",
- "LOADING": "Fetching Subscriptions",
- "ACCOUNT_STATE": "Account State",
- "AGENT_COUNT": "Agent Count",
- "PER_AGENT_COST": "Per Agent Cost",
- "TOTAL_COST": "Total Cost",
- "BUTTON": {
- "ADD": "Add Payment Method",
- "EDIT": "EDIT Payment Method"
- },
- "TRIAL": {
- "TITLE": "Your Trial period is over",
- "MESSAGE": "Add a payment method to continue using Chatwoot."
- },
- "ACCOUNT_LOCKED": "Your account is not available at the moment.
Please contact your administrator for reactivation."
- }
-}
diff --git a/app/javascript/dashboard/i18n/locale/en/index.js b/app/javascript/dashboard/i18n/locale/en/index.js
index 351906dd9..558cc9b3a 100644
--- a/app/javascript/dashboard/i18n/locale/en/index.js
+++ b/app/javascript/dashboard/i18n/locale/en/index.js
@@ -1,6 +1,5 @@
/* eslint-disable */
import { default as _agentMgmt } from './agentMgmt.json';
-import { default as _billing } from './billing.json';
import { default as _cannedMgmt } from './cannedMgmt.json';
import { default as _chatlist } from './chatlist.json';
import { default as _contact } from './contact.json';
@@ -17,7 +16,6 @@ import { default as _generalSettings } from './generalSettings.json';
export default {
..._agentMgmt,
- ..._billing,
..._cannedMgmt,
..._chatlist,
..._contact,
diff --git a/app/javascript/dashboard/i18n/locale/en/settings.json b/app/javascript/dashboard/i18n/locale/en/settings.json
index c1955d90d..38f5a4aac 100644
--- a/app/javascript/dashboard/i18n/locale/en/settings.json
+++ b/app/javascript/dashboard/i18n/locale/en/settings.json
@@ -102,7 +102,6 @@
"AGENTS": "Agents",
"INBOXES": "Inboxes",
"CANNED_RESPONSES": "Canned Responses",
- "BILLING": "Billing",
"INTEGRATIONS": "Integrations",
"ACCOUNT_SETTINGS": "Account Settings"
}
diff --git a/app/javascript/dashboard/i18n/locale/es/billing.json b/app/javascript/dashboard/i18n/locale/es/billing.json
deleted file mode 100644
index a7b7b58fb..000000000
--- a/app/javascript/dashboard/i18n/locale/es/billing.json
+++ /dev/null
@@ -1,19 +0,0 @@
-{
- "BILLING": {
- "HEADER": "Facturación",
- "LOADING": "Obteniendo suscripciones",
- "ACCOUNT_STATE": "Estado de cuenta",
- "AGENT_COUNT": "Contador de agentes",
- "PER_AGENT_COST": "Coste por agente",
- "TOTAL_COST": "Coste total",
- "BUTTON": {
- "ADD": "Añadir método de pago",
- "EDIT": "Método de pago EDIT"
- },
- "TRIAL": {
- "TITLE": "Su período de prueba ha terminado",
- "MESSAGE": "Añadir un método de pago para seguir usando Chatwoot."
- },
- "ACCOUNT_LOCKED": "Su cuenta no está disponible en este momento.
Póngase en contacto con su administrador para reactivación."
- }
-}
diff --git a/app/javascript/dashboard/i18n/locale/es/index.js b/app/javascript/dashboard/i18n/locale/es/index.js
index 351906dd9..558cc9b3a 100644
--- a/app/javascript/dashboard/i18n/locale/es/index.js
+++ b/app/javascript/dashboard/i18n/locale/es/index.js
@@ -1,6 +1,5 @@
/* eslint-disable */
import { default as _agentMgmt } from './agentMgmt.json';
-import { default as _billing } from './billing.json';
import { default as _cannedMgmt } from './cannedMgmt.json';
import { default as _chatlist } from './chatlist.json';
import { default as _contact } from './contact.json';
@@ -17,7 +16,6 @@ import { default as _generalSettings } from './generalSettings.json';
export default {
..._agentMgmt,
- ..._billing,
..._cannedMgmt,
..._chatlist,
..._contact,
diff --git a/app/javascript/dashboard/i18n/locale/es/settings.json b/app/javascript/dashboard/i18n/locale/es/settings.json
index bd1838a69..0833a8f34 100644
--- a/app/javascript/dashboard/i18n/locale/es/settings.json
+++ b/app/javascript/dashboard/i18n/locale/es/settings.json
@@ -102,7 +102,6 @@
"AGENTS": "Agentes",
"INBOXES": "Entradas",
"CANNED_RESPONSES": "Respuestas predefinidas",
- "BILLING": "Facturación",
"INTEGRATIONS": "Integraciones",
"ACCOUNT_SETTINGS": "Configuración de la cuenta"
}
diff --git a/app/javascript/dashboard/i18n/locale/fr/billing.json b/app/javascript/dashboard/i18n/locale/fr/billing.json
deleted file mode 100644
index f66afe559..000000000
--- a/app/javascript/dashboard/i18n/locale/fr/billing.json
+++ /dev/null
@@ -1,19 +0,0 @@
-{
- "BILLING": {
- "HEADER": "Facturation",
- "LOADING": "Récupération des abonnements",
- "ACCOUNT_STATE": "État du compte",
- "AGENT_COUNT": "Nombre d'agents",
- "PER_AGENT_COST": "Coût par agent",
- "TOTAL_COST": "Coût total",
- "BUTTON": {
- "ADD": "Ajouter une méthode de paiement",
- "EDIT": "MODIFIER la méthode de paiement"
- },
- "TRIAL": {
- "TITLE": "Votre période d'essai est terminée",
- "MESSAGE": "Ajoutez une méthode de paiement pour continuer à utiliser Chatwoot."
- },
- "ACCOUNT_LOCKED": "Votre compte n'est pas disponible pour le moment.
Veuillez contacter votre administrateur pour la réactivation."
- }
-}
diff --git a/app/javascript/dashboard/i18n/locale/fr/index.js b/app/javascript/dashboard/i18n/locale/fr/index.js
index 351906dd9..558cc9b3a 100644
--- a/app/javascript/dashboard/i18n/locale/fr/index.js
+++ b/app/javascript/dashboard/i18n/locale/fr/index.js
@@ -1,6 +1,5 @@
/* eslint-disable */
import { default as _agentMgmt } from './agentMgmt.json';
-import { default as _billing } from './billing.json';
import { default as _cannedMgmt } from './cannedMgmt.json';
import { default as _chatlist } from './chatlist.json';
import { default as _contact } from './contact.json';
@@ -17,7 +16,6 @@ import { default as _generalSettings } from './generalSettings.json';
export default {
..._agentMgmt,
- ..._billing,
..._cannedMgmt,
..._chatlist,
..._contact,
diff --git a/app/javascript/dashboard/i18n/locale/fr/settings.json b/app/javascript/dashboard/i18n/locale/fr/settings.json
index 7aca5abb1..ba7d64d0b 100644
--- a/app/javascript/dashboard/i18n/locale/fr/settings.json
+++ b/app/javascript/dashboard/i18n/locale/fr/settings.json
@@ -102,7 +102,6 @@
"AGENTS": "Agents",
"INBOXES": "Boîtes de réception",
"CANNED_RESPONSES": "Réponses standardisées",
- "BILLING": "Facturation",
"INTEGRATIONS": "Intégrations",
"ACCOUNT_SETTINGS": "Paramètres du compte"
}
diff --git a/app/javascript/dashboard/i18n/locale/it/billing.json b/app/javascript/dashboard/i18n/locale/it/billing.json
deleted file mode 100644
index af0c125e7..000000000
--- a/app/javascript/dashboard/i18n/locale/it/billing.json
+++ /dev/null
@@ -1,19 +0,0 @@
-{
- "BILLING": {
- "HEADER": "Fatturazione",
- "LOADING": "Recupero Iscrizioni",
- "ACCOUNT_STATE": "Stato del conto",
- "AGENT_COUNT": "Conteggio Agente",
- "PER_AGENT_COST": "Costo per agente",
- "TOTAL_COST": "Costo totale",
- "BUTTON": {
- "ADD": "Aggiungi metodo di pagamento",
- "EDIT": "Metodo di pagamento EDIT"
- },
- "TRIAL": {
- "TITLE": "Il tuo periodo di prova è finito",
- "MESSAGE": "Aggiungi un metodo di pagamento per continuare a utilizzare Chatwoot."
- },
- "ACCOUNT_LOCKED": "Il tuo account non è al momento disponibile.
Si prega di contattare l'amministratore per la riattivazione."
- }
-}
diff --git a/app/javascript/dashboard/i18n/locale/ml/billing.json b/app/javascript/dashboard/i18n/locale/ml/billing.json
deleted file mode 100644
index d44fdd661..000000000
--- a/app/javascript/dashboard/i18n/locale/ml/billing.json
+++ /dev/null
@@ -1,19 +0,0 @@
-{
- "BILLING": {
- "HEADER": "ബില്ലിംഗ്",
- "LOADING": "സബ്സ്ക്രിപ്ഷനുകൾ ലഭ്യമാക്കുന്നു",
- "ACCOUNT_STATE": "അക്കൗണ്ടിന്റെ അവസ്ഥ",
- "AGENT_COUNT": "ഏജന്റിന്റെ എണ്ണം ",
- "PER_AGENT_COST": "ഓരോ ഏജന്റിന്റെ വില",
- "TOTAL_COST": "ആകെ ചെലവ്",
- "BUTTON": {
- "ADD": "പേയ്മെന്റ് രീതി ചേർക്കുക",
- "EDIT": "പേയ്മെന്റ് രീതി എഡിറ്റുചെയ്യുക"
- },
- "TRIAL": {
- "TITLE": "നിങ്ങളുടെ ട്രയൽ കാലയളവ് അവസാനിച്ചു",
- "MESSAGE": "ചാറ്റ് വൂട്ട് ഉപയോഗിക്കുന്നത് തുടരാൻ ഒരു പേയ്മെന്റ് രീതി ചേർക്കുക."
- },
- "ACCOUNT_LOCKED": "നിങ്ങളുടെ അക്കൗണ്ട് ഇപ്പോൾ ലഭ്യമല്ല.
വീണ്ടും സജീവമാക്കുന്നതിന് ദയവായി നിങ്ങളുടെ അഡ്മിനിസ്ട്രേറ്ററുമായി ബന്ധപ്പെടുക."
- }
-}
diff --git a/app/javascript/dashboard/i18n/locale/ml/index.js b/app/javascript/dashboard/i18n/locale/ml/index.js
index 351906dd9..558cc9b3a 100644
--- a/app/javascript/dashboard/i18n/locale/ml/index.js
+++ b/app/javascript/dashboard/i18n/locale/ml/index.js
@@ -1,6 +1,5 @@
/* eslint-disable */
import { default as _agentMgmt } from './agentMgmt.json';
-import { default as _billing } from './billing.json';
import { default as _cannedMgmt } from './cannedMgmt.json';
import { default as _chatlist } from './chatlist.json';
import { default as _contact } from './contact.json';
@@ -17,7 +16,6 @@ import { default as _generalSettings } from './generalSettings.json';
export default {
..._agentMgmt,
- ..._billing,
..._cannedMgmt,
..._chatlist,
..._contact,
diff --git a/app/javascript/dashboard/i18n/locale/ml/settings.json b/app/javascript/dashboard/i18n/locale/ml/settings.json
index c768f6d1c..d7e89fb3f 100644
--- a/app/javascript/dashboard/i18n/locale/ml/settings.json
+++ b/app/javascript/dashboard/i18n/locale/ml/settings.json
@@ -90,7 +90,6 @@
"AGENTS": "ഏജന്റുമാർ",
"INBOXES": "ഇൻബോക്സുകൾ",
"CANNED_RESPONSES": "ക്യാൻഡ് പ്രതികരണങ്ങൾ",
- "BILLING": "ബില്ലിംഗ്",
"INTEGRATIONS": "സംയോജനങ്ങൾ",
"ACCOUNT_SETTINGS": "അക്കൗണ്ട് ക്രമീകരണങ്ങൾ"
}
diff --git a/app/javascript/dashboard/i18n/locale/nl/billing.json b/app/javascript/dashboard/i18n/locale/nl/billing.json
deleted file mode 100644
index d5a46cfd1..000000000
--- a/app/javascript/dashboard/i18n/locale/nl/billing.json
+++ /dev/null
@@ -1,19 +0,0 @@
-{
- "BILLING": {
- "HEADER": "Facturatie",
- "LOADING": "Ophalen Abonnementen",
- "ACCOUNT_STATE": "Accountstatus",
- "AGENT_COUNT": "Aantal Medewerkers",
- "PER_AGENT_COST": "Kosten per medewerker",
- "TOTAL_COST": "Totale kosten",
- "BUTTON": {
- "ADD": "Betaalmethode toevoegen",
- "EDIT": "Betalingsmethode bewerken"
- },
- "TRIAL": {
- "TITLE": "Uw proefperiode is voorbij",
- "MESSAGE": "Voeg een betaalmethode toe om Chatwoot te blijven gebruiken."
- },
- "ACCOUNT_LOCKED": "Uw account is op dit moment niet beschikbaar.
Neem contact op met uw beheerder voor heractivatie."
- }
-}
diff --git a/app/javascript/dashboard/i18n/locale/nl/index.js b/app/javascript/dashboard/i18n/locale/nl/index.js
index 351906dd9..558cc9b3a 100644
--- a/app/javascript/dashboard/i18n/locale/nl/index.js
+++ b/app/javascript/dashboard/i18n/locale/nl/index.js
@@ -1,6 +1,5 @@
/* eslint-disable */
import { default as _agentMgmt } from './agentMgmt.json';
-import { default as _billing } from './billing.json';
import { default as _cannedMgmt } from './cannedMgmt.json';
import { default as _chatlist } from './chatlist.json';
import { default as _contact } from './contact.json';
@@ -17,7 +16,6 @@ import { default as _generalSettings } from './generalSettings.json';
export default {
..._agentMgmt,
- ..._billing,
..._cannedMgmt,
..._chatlist,
..._contact,
diff --git a/app/javascript/dashboard/i18n/locale/nl/settings.json b/app/javascript/dashboard/i18n/locale/nl/settings.json
index a5f604209..e013885d4 100644
--- a/app/javascript/dashboard/i18n/locale/nl/settings.json
+++ b/app/javascript/dashboard/i18n/locale/nl/settings.json
@@ -102,7 +102,6 @@
"AGENTS": "Medewerkers",
"INBOXES": "Inboxen",
"CANNED_RESPONSES": "Standaard antwoorden",
- "BILLING": "Facturatie",
"INTEGRATIONS": "Integraties",
"ACCOUNT_SETTINGS": "Accountinstellingen"
}
diff --git a/app/javascript/dashboard/i18n/locale/pl/billing.json b/app/javascript/dashboard/i18n/locale/pl/billing.json
deleted file mode 100644
index 6a3a07496..000000000
--- a/app/javascript/dashboard/i18n/locale/pl/billing.json
+++ /dev/null
@@ -1,19 +0,0 @@
-{
- "BILLING": {
- "HEADER": "Płatność",
- "LOADING": "Pobieranie subskrypcji",
- "ACCOUNT_STATE": "Stan konta",
- "AGENT_COUNT": "Liczba agentów",
- "PER_AGENT_COST": "Koszt za agenta",
- "TOTAL_COST": "Całkowity koszt",
- "BUTTON": {
- "ADD": "Dodaj metodę płatności",
- "EDIT": "Metoda płatności EDIT"
- },
- "TRIAL": {
- "TITLE": "Twój okres próbny minął",
- "MESSAGE": "Dodaj metodę płatności, aby kontynuować korzystanie z Chatwoot."
- },
- "ACCOUNT_LOCKED": "Twoje konto nie jest obecnie dostępne.
Skontaktuj się z administratorem, aby reaktywować."
- }
-}
diff --git a/app/javascript/dashboard/i18n/locale/pt/billing.json b/app/javascript/dashboard/i18n/locale/pt/billing.json
deleted file mode 100644
index 07cc720f6..000000000
--- a/app/javascript/dashboard/i18n/locale/pt/billing.json
+++ /dev/null
@@ -1,19 +0,0 @@
-{
- "BILLING": {
- "HEADER": "Faturamento",
- "LOADING": "Buscando Assinaturas",
- "ACCOUNT_STATE": "Estado do cliente",
- "AGENT_COUNT": "Número de Representantes",
- "PER_AGENT_COST": "Custo por agente",
- "TOTAL_COST": "Custo Total",
- "BUTTON": {
- "ADD": "Adicionar método de pagamento",
- "EDIT": "EDIT Método de Pagamento"
- },
- "TRIAL": {
- "TITLE": "Seu período de avaliação terminou",
- "MESSAGE": "Adicione um método de pagamento para continuar usando o Chatwoot."
- },
- "ACCOUNT_LOCKED": "Sua conta não está disponível no momento.
Por favor, entre em contato com o administrador para reativação."
- }
-}
diff --git a/app/javascript/dashboard/i18n/locale/pt/index.js b/app/javascript/dashboard/i18n/locale/pt/index.js
index 351906dd9..558cc9b3a 100644
--- a/app/javascript/dashboard/i18n/locale/pt/index.js
+++ b/app/javascript/dashboard/i18n/locale/pt/index.js
@@ -1,6 +1,5 @@
/* eslint-disable */
import { default as _agentMgmt } from './agentMgmt.json';
-import { default as _billing } from './billing.json';
import { default as _cannedMgmt } from './cannedMgmt.json';
import { default as _chatlist } from './chatlist.json';
import { default as _contact } from './contact.json';
@@ -17,7 +16,6 @@ import { default as _generalSettings } from './generalSettings.json';
export default {
..._agentMgmt,
- ..._billing,
..._cannedMgmt,
..._chatlist,
..._contact,
diff --git a/app/javascript/dashboard/i18n/locale/pt/settings.json b/app/javascript/dashboard/i18n/locale/pt/settings.json
index 2d1c5d4d5..95d891773 100644
--- a/app/javascript/dashboard/i18n/locale/pt/settings.json
+++ b/app/javascript/dashboard/i18n/locale/pt/settings.json
@@ -67,7 +67,6 @@
"AGENTS": "Agentes",
"INBOXES": "Caixas de entrada",
"CANNED_RESPONSES": "Respostas Enlatadas",
- "BILLING": "Faturamento",
"INTEGRATIONS": "Integrações",
"ACCOUNT_SETTINGS": "Configurações da conta"
}
diff --git a/app/javascript/dashboard/i18n/locale/pt_BR/billing.json b/app/javascript/dashboard/i18n/locale/pt_BR/billing.json
deleted file mode 100644
index 2c7d5f390..000000000
--- a/app/javascript/dashboard/i18n/locale/pt_BR/billing.json
+++ /dev/null
@@ -1,19 +0,0 @@
-{
- "BILLING": {
- "HEADER": "Faturamento",
- "LOADING": "Buscando Assinaturas",
- "ACCOUNT_STATE": "Estado do cliente",
- "AGENT_COUNT": "Número de Agente",
- "PER_AGENT_COST": "Custo por agente",
- "TOTAL_COST": "Custo Total",
- "BUTTON": {
- "ADD": "Adicionar Forma de Pagamento",
- "EDIT": "Editar Forma de Pagamento"
- },
- "TRIAL": {
- "TITLE": "Seu período de avaliação terminou",
- "MESSAGE": "Adicione um método de pagamento para continuar usando o Chatwoot."
- },
- "ACCOUNT_LOCKED": "Sua conta não está disponível no momento.
Por favor, entre em contato com o administrador para reativação."
- }
-}
diff --git a/app/javascript/dashboard/i18n/locale/pt_BR/index.js b/app/javascript/dashboard/i18n/locale/pt_BR/index.js
index 351906dd9..558cc9b3a 100644
--- a/app/javascript/dashboard/i18n/locale/pt_BR/index.js
+++ b/app/javascript/dashboard/i18n/locale/pt_BR/index.js
@@ -1,6 +1,5 @@
/* eslint-disable */
import { default as _agentMgmt } from './agentMgmt.json';
-import { default as _billing } from './billing.json';
import { default as _cannedMgmt } from './cannedMgmt.json';
import { default as _chatlist } from './chatlist.json';
import { default as _contact } from './contact.json';
@@ -17,7 +16,6 @@ import { default as _generalSettings } from './generalSettings.json';
export default {
..._agentMgmt,
- ..._billing,
..._cannedMgmt,
..._chatlist,
..._contact,
diff --git a/app/javascript/dashboard/i18n/locale/pt_BR/settings.json b/app/javascript/dashboard/i18n/locale/pt_BR/settings.json
index 25c61cf86..65b7dc8e2 100644
--- a/app/javascript/dashboard/i18n/locale/pt_BR/settings.json
+++ b/app/javascript/dashboard/i18n/locale/pt_BR/settings.json
@@ -100,7 +100,6 @@
"AGENTS": "Agentes",
"INBOXES": "Caixas de Entrada",
"CANNED_RESPONSES": "Atalhos",
- "BILLING": "Faturamento",
"INTEGRATIONS": "Integrações",
"ACCOUNT_SETTINGS": "Configurações da conta"
}
diff --git a/app/javascript/dashboard/i18n/locale/ro/billing.json b/app/javascript/dashboard/i18n/locale/ro/billing.json
deleted file mode 100644
index fb5c851fd..000000000
--- a/app/javascript/dashboard/i18n/locale/ro/billing.json
+++ /dev/null
@@ -1,19 +0,0 @@
-{
- "BILLING": {
- "HEADER": "Facturare",
- "LOADING": "Preluare abonamente",
- "ACCOUNT_STATE": "Stare cont",
- "AGENT_COUNT": "Număr de agenți",
- "PER_AGENT_COST": "Cost per Agent",
- "TOTAL_COST": "Cost total",
- "BUTTON": {
- "ADD": "Adaugă metodă de plată",
- "EDIT": "Adaugă metodă de plată"
- },
- "TRIAL": {
- "TITLE": "Perioada de evaluare s-a încheiat",
- "MESSAGE": "Adaugă o metodă de plată pentru a continua să folosești Chatwoot."
- },
- "ACCOUNT_LOCKED": "Contul dvs. nu este disponibil momentan.
Vă rugăm să contactaţi administratorul pentru reactivare."
- }
-}
diff --git a/app/javascript/dashboard/i18n/locale/ro/index.js b/app/javascript/dashboard/i18n/locale/ro/index.js
index 7cc96f9eb..6b0a4bb4d 100644
--- a/app/javascript/dashboard/i18n/locale/ro/index.js
+++ b/app/javascript/dashboard/i18n/locale/ro/index.js
@@ -1,5 +1,4 @@
import { default as _agentMgmt } from './agentMgmt.json';
-import { default as _billing } from './billing.json';
import { default as _cannedMgmt } from './cannedMgmt.json';
import { default as _chatlist } from './chatlist.json';
import { default as _contact } from './contact.json';
@@ -16,7 +15,6 @@ import { default as _generalSettings } from './generalSettings.json';
export default {
..._agentMgmt,
- ..._billing,
..._cannedMgmt,
..._chatlist,
..._contact,
diff --git a/app/javascript/dashboard/i18n/locale/ro/settings.json b/app/javascript/dashboard/i18n/locale/ro/settings.json
index b85bdc9c0..0f8551131 100644
--- a/app/javascript/dashboard/i18n/locale/ro/settings.json
+++ b/app/javascript/dashboard/i18n/locale/ro/settings.json
@@ -102,7 +102,6 @@
"AGENTS": "Agenți",
"INBOXES": "Căsuțe",
"CANNED_RESPONSES": "Răspunsuri predefinite",
- "BILLING": "Facturare",
"INTEGRATIONS": "Integrări",
"ACCOUNT_SETTINGS": "Setările contului"
}
diff --git a/app/javascript/dashboard/i18n/locale/sv/billing.json b/app/javascript/dashboard/i18n/locale/sv/billing.json
deleted file mode 100644
index 2a2a1ba33..000000000
--- a/app/javascript/dashboard/i18n/locale/sv/billing.json
+++ /dev/null
@@ -1,19 +0,0 @@
-{
- "BILLING": {
- "HEADER": "Fakturering",
- "LOADING": "Hämtar prenumerationer",
- "ACCOUNT_STATE": "Kontots status",
- "AGENT_COUNT": "Agentkommando Antal",
- "PER_AGENT_COST": "Per agent: kostnad",
- "TOTAL_COST": "Total kostnad",
- "BUTTON": {
- "ADD": "Lägg till betalningsmetod",
- "EDIT": "EDIT betalningsmetod"
- },
- "TRIAL": {
- "TITLE": "Din provperiod är över",
- "MESSAGE": "Lägg till en betalningsmetod för att fortsätta använda Chatwoot."
- },
- "ACCOUNT_LOCKED": "Ditt konto är inte tillgängligt just nu.
Kontakta administratören för återaktivering."
- }
-}
diff --git a/app/javascript/dashboard/i18n/locale/uk/billing.json b/app/javascript/dashboard/i18n/locale/uk/billing.json
deleted file mode 100644
index 0363d000b..000000000
--- a/app/javascript/dashboard/i18n/locale/uk/billing.json
+++ /dev/null
@@ -1,19 +0,0 @@
-{
- "BILLING": {
- "HEADER": "Оплата",
- "LOADING": "Отримання підписок",
- "ACCOUNT_STATE": "Стан облікового запису",
- "AGENT_COUNT": "Кількість агентів",
- "PER_AGENT_COST": "Вартість одного агента",
- "TOTAL_COST": "Загальна вартість",
- "BUTTON": {
- "ADD": "Додати спосіб оплати",
- "EDIT": "РЕДАГУВАТИ спосіб оплати"
- },
- "TRIAL": {
- "TITLE": "Пробний період закінчився",
- "MESSAGE": "Додайте спосіб оплати, щоб продовжити використовувати Chatwoot."
- },
- "ACCOUNT_LOCKED": "На даний момент ваш обліковий запис недоступний.
Зверніться до свого адміністратора для повторної активації."
- }
-}
diff --git a/app/javascript/dashboard/routes/dashboard/settings/billing/AccountLocked.vue b/app/javascript/dashboard/routes/dashboard/settings/billing/AccountLocked.vue
deleted file mode 100644
index 1c26d0f48..000000000
--- a/app/javascript/dashboard/routes/dashboard/settings/billing/AccountLocked.vue
+++ /dev/null
@@ -1,22 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/app/javascript/dashboard/routes/dashboard/settings/billing/Index.vue b/app/javascript/dashboard/routes/dashboard/settings/billing/Index.vue
deleted file mode 100644
index 23099d858..000000000
--- a/app/javascript/dashboard/routes/dashboard/settings/billing/Index.vue
+++ /dev/null
@@ -1,124 +0,0 @@
-
-
-
-
-
-
- {{ $t('BILLING.ACCOUNT_STATE') }}
- {{ billingDetails.state }}
-
-
- {{ $t('BILLING.AGENT_COUNT') }}
- {{ billingDetails.agents_count }}
-
-
- {{ $t('BILLING.PER_AGENT_COST') }}
- ${{ billingDetails.per_agent_cost }}
-
-
-
- {{ $t('BILLING.TOTAL_COST') }}
- ${{ billingDetails.total_cost }}
-
-
-
-
-
-
-
-
diff --git a/app/javascript/dashboard/routes/dashboard/settings/billing/billing.routes.js b/app/javascript/dashboard/routes/dashboard/settings/billing/billing.routes.js
deleted file mode 100644
index 58bf309c3..000000000
--- a/app/javascript/dashboard/routes/dashboard/settings/billing/billing.routes.js
+++ /dev/null
@@ -1,32 +0,0 @@
-import Index from './Index';
-import SettingsContent from '../Wrapper';
-import AccountLocked from './AccountLocked';
-import { frontendURL } from '../../../../helper/URLHelper';
-
-export default {
- routes: [
- {
- path: frontendURL('accounts/:accountId/settings/billing'),
- component: SettingsContent,
- props: {
- headerTitle: 'BILLING.HEADER',
- icon: 'ion-card',
- },
- children: [
- {
- path: '',
- name: 'billing',
- component: Index,
- roles: ['administrator'],
- props: route => ({ state: route.query.state }),
- },
- ],
- },
- {
- path: '/deactivated',
- name: 'billing_deactivated',
- component: AccountLocked,
- roles: ['agent'],
- },
- ],
-};
diff --git a/app/javascript/dashboard/routes/dashboard/settings/settings.routes.js b/app/javascript/dashboard/routes/dashboard/settings/settings.routes.js
index 5907768cc..f2f0d186c 100644
--- a/app/javascript/dashboard/routes/dashboard/settings/settings.routes.js
+++ b/app/javascript/dashboard/routes/dashboard/settings/settings.routes.js
@@ -1,6 +1,5 @@
import { frontendURL } from '../../../helper/URLHelper';
import agent from './agents/agent.routes';
-import billing from './billing/billing.routes';
import canned from './canned/canned.routes';
import inbox from './inbox/inbox.routes';
import profile from './profile/profile.routes';
@@ -23,7 +22,6 @@ export default {
},
},
...agent.routes,
- ...billing.routes,
...canned.routes,
...inbox.routes,
...profile.routes,
diff --git a/app/javascript/dashboard/store/index.js b/app/javascript/dashboard/store/index.js
index f88139003..9df653765 100755
--- a/app/javascript/dashboard/store/index.js
+++ b/app/javascript/dashboard/store/index.js
@@ -4,7 +4,6 @@ import Vuex from 'vuex';
import accounts from './modules/accounts';
import agents from './modules/agents';
import auth from './modules/auth';
-import billing from './modules/billing';
import cannedResponse from './modules/cannedResponse';
import Channel from './modules/channels';
import contactConversations from './modules/contactConversations';
@@ -27,7 +26,6 @@ export default new Vuex.Store({
accounts,
agents,
auth,
- billing,
cannedResponse,
Channel,
contactConversations,
diff --git a/app/javascript/dashboard/store/modules/billing.js b/app/javascript/dashboard/store/modules/billing.js
deleted file mode 100644
index 4df528516..000000000
--- a/app/javascript/dashboard/store/modules/billing.js
+++ /dev/null
@@ -1,60 +0,0 @@
-/* eslint no-console: 0 */
-/* eslint no-param-reassign: 0 */
-/* eslint no-shadow: 0 */
-import * as types from '../mutation-types';
-import Billing from '../../api/billing';
-
-const state = {
- fetchingStatus: false,
- billingDetails: {},
- status: null,
-};
-
-const getters = {
- getBillingDetails(_state) {
- return _state.billingDetails;
- },
- billingFetchStatus(_state) {
- return _state.fetchingStatus;
- },
-};
-
-const actions = {
- fetchSubscription({ commit }) {
- commit(types.default.TOGGLE_SUBSCRIPTION_LOADING, true);
- Billing.getSubscription()
- .then(billingDetails => {
- commit(types.default.SET_SUBSCRIPTION, billingDetails.data);
- commit(
- types.default.TOGGLE_SUBSCRIPTION_LOADING,
- false,
- billingDetails.status
- );
- })
- .catch(error => {
- const { response } = error;
- commit(
- types.default.TOGGLE_SUBSCRIPTION_LOADING,
- false,
- response.status
- );
- });
- },
-};
-
-const mutations = {
- [types.default.SET_SUBSCRIPTION](_state, billingDetails) {
- _state.billingDetails = billingDetails;
- },
- [types.default.TOGGLE_SUBSCRIPTION_LOADING](_state, flag, apiStatus) {
- _state.fetchingStatus = flag;
- _state.status = apiStatus;
- },
-};
-
-export default {
- state,
- getters,
- actions,
- mutations,
-};
diff --git a/app/javascript/dashboard/store/mutation-types.js b/app/javascript/dashboard/store/mutation-types.js
index 5357415b2..15c5fe577 100755
--- a/app/javascript/dashboard/store/mutation-types.js
+++ b/app/javascript/dashboard/store/mutation-types.js
@@ -93,10 +93,6 @@ export default {
SET_ACCOUNT_SUMMARY: 'SET_ACCOUNT_SUMMARY',
TOGGLE_ACCOUNT_REPORT_LOADING: 'TOGGLE_ACCOUNT_REPORT_LOADING',
- // Billings
- SET_SUBSCRIPTION: 'SET_SUBSCRIPTION',
- TOGGLE_SUBSCRIPTION_LOADING: 'TOGGLE_SUBSCRIPTION_LOADING',
-
// Conversation Metadata
SET_CONVERSATION_METADATA: 'SET_CONVERSATION_METADATA',
diff --git a/app/listeners/subscription_listener.rb b/app/listeners/subscription_listener.rb
deleted file mode 100644
index 947bcdee7..000000000
--- a/app/listeners/subscription_listener.rb
+++ /dev/null
@@ -1,35 +0,0 @@
-# This listener is left over from the initial version of chatwoot
-# We might reuse this later in the hosted version of chatwoot.
-
-class SubscriptionListener < BaseListener
- def subscription_created(event)
- subscription = event.data[:subscription]
- account = subscription.account
- Subscription::ChargebeeService.create_subscription(account)
- end
-
- def account_destroyed(event)
- account = event.data[:account]
- Subscription::ChargebeeService.cancel_subscription(account)
- end
-
- def agent_added(event)
- account = event.data[:account]
- Subscription::ChargebeeService.update_subscription(account)
- end
-
- def agent_removed(event)
- account = event.data[:account]
- Subscription::ChargebeeService.update_subscription(account)
- end
-
- def subscription_reactivated(event)
- account = event.data[:account]
- Subscription::ChargebeeService.reactivate_subscription(account)
- end
-
- def subscription_deactivated(event)
- account = event.data[:account]
- Subscription::ChargebeeService.deactivate_subscription(account)
- end
-end
diff --git a/app/models/account.rb b/app/models/account.rb
index dbae201d3..3e5b48f00 100644
--- a/app/models/account.rb
+++ b/app/models/account.rb
@@ -46,13 +46,11 @@ class Account < ApplicationRecord
has_many :canned_responses, dependent: :destroy
has_many :webhooks, dependent: :destroy
has_many :labels, dependent: :destroy
- has_one :subscription, dependent: :destroy
has_many :notification_settings, dependent: :destroy
has_flags ACCOUNT_SETTINGS_FLAGS.merge(column: 'settings_flags').merge(DEFAULT_QUERY_SETTING)
enum locale: LANGUAGES_CONFIG.map { |key, val| [val[:iso_639_1_code], key] }.to_h
- after_create :create_subscription
after_create :notify_creation
after_destroy :notify_deletion
@@ -74,22 +72,6 @@ class Account < ApplicationRecord
.map { |_| _.tag.name }
end
- def subscription_data
- agents_count = users.count
- per_agent_price = Plan.paid_plan.price
- {
- state: subscription.state,
- expiry: subscription.expiry.to_i,
- agents_count: agents_count,
- per_agent_cost: per_agent_price,
- total_cost: (per_agent_price * agents_count),
- iframe_url: Subscription::ChargebeeService.hosted_page_url(self),
- trial_expired: subscription.trial_expired?,
- account_suspended: subscription.suspended?,
- payment_source_added: subscription.payment_source_added
- }
- end
-
def webhook_data
{
id: id,
@@ -99,11 +81,6 @@ class Account < ApplicationRecord
private
- def create_subscription
- subscription = build_subscription
- subscription.save
- end
-
def notify_creation
Rails.configuration.dispatcher.dispatch(ACCOUNT_CREATED, Time.zone.now, account: self)
end
diff --git a/app/models/channel/web_widget.rb b/app/models/channel/web_widget.rb
index 203049f64..5b3762a5b 100644
--- a/app/models/channel/web_widget.rb
+++ b/app/models/channel/web_widget.rb
@@ -2,16 +2,15 @@
#
# Table name: channel_web_widgets
#
-# id :integer not null, primary key
-# agent_away_message :string
-# website_token :string
-# website_url :string
-# welcome_tagline :string
-# welcome_title :string
-# widget_color :string default("#1f93ff")
-# created_at :datetime not null
-# updated_at :datetime not null
-# account_id :integer
+# id :integer not null, primary key
+# website_token :string
+# website_url :string
+# welcome_tagline :string
+# welcome_title :string
+# widget_color :string default("#1f93ff")
+# created_at :datetime not null
+# updated_at :datetime not null
+# account_id :integer
#
# Indexes
#
diff --git a/app/models/subscription.rb b/app/models/subscription.rb
deleted file mode 100644
index 8a3afebe3..000000000
--- a/app/models/subscription.rb
+++ /dev/null
@@ -1,57 +0,0 @@
-# == Schema Information
-#
-# Table name: subscriptions
-#
-# id :integer not null, primary key
-# billing_plan :string default("trial")
-# expiry :datetime
-# payment_source_added :boolean default(FALSE)
-# pricing_version :string
-# state :integer default("trial")
-# created_at :datetime not null
-# updated_at :datetime not null
-# account_id :integer
-# stripe_customer_id :string
-#
-
-class Subscription < ApplicationRecord
- include Events::Types
-
- belongs_to :account
- before_create :set_default_billing_params
- after_create :notify_creation
-
- enum state: [:trial, :active, :cancelled]
-
- def payment_source_added!
- self.payment_source_added = true
- save
- end
-
- def trial_expired?
- (trial? && expiry < Date.current) ||
- (cancelled? && !payment_source_added)
- end
-
- def suspended?
- cancelled? && payment_source_added
- end
-
- def summary
- {
- state: state,
- expiry: expiry.to_i
- }
- end
-
- private
-
- def set_default_billing_params
- self.expiry = Time.now + Plan.default_trial_period
- self.pricing_version = Plan.default_pricing_version
- end
-
- def notify_creation
- Rails.configuration.dispatcher.dispatch(SUBSCRIPTION_CREATED, Time.zone.now, subscription: self)
- end
-end
diff --git a/app/models/user.rb b/app/models/user.rb
index 2476f586e..6157767a2 100644
--- a/app/models/user.rb
+++ b/app/models/user.rb
@@ -118,7 +118,6 @@ class User < ApplicationRecord
def serializable_hash(options = nil)
serialized_user = super(options).merge(confirmed: confirmed?)
- serialized_user.merge(subscription: account.try(:subscription).try(:summary)) if ENV['BILLING_ENABLED']
serialized_user
end
diff --git a/app/services/subscription/chargebee_service.rb b/app/services/subscription/chargebee_service.rb
deleted file mode 100644
index 2df2af660..000000000
--- a/app/services/subscription/chargebee_service.rb
+++ /dev/null
@@ -1,70 +0,0 @@
-class Subscription::ChargebeeService
- class << self
- def create_subscription(account)
- result = ChargeBee::Subscription.create(
- plan_id: Plan.paid_plan.id,
- customer: {
- email: account.users.administrator.try(:first).try(:email),
- first_name: account.name,
- company: account.name
- }
- )
- subscription = account.subscription
- subscription.stripe_customer_id = result.subscription.customer_id
- subscription.save
- rescue StandardError => e
- Raven.capture_exception(e)
- end
-
- def update_subscription(account)
- subscription = account.subscription
- agents_count = account.users.count
- ChargeBee::Subscription.update(subscription.stripe_customer_id, plan_quantity: agents_count)
- rescue StandardError => e
- Raven.capture_exception(e)
- end
-
- def cancel_subscription(account)
- subscription = account.subscription
- ChargeBee::Subscription.delete(subscription.stripe_customer_id)
- rescue StandardError => e
- Raven.capture_exception(e)
- end
-
- def reactivate_subscription(account)
- subscription = account.subscription
- ChargeBee::Subscription.reactivate(subscription.stripe_customer_id)
- subscription.active!
- rescue StandardError => e
- Raven.capture_exception(e)
- end
-
- def deactivate_subscription(account)
- subscription = account.subscription
- ChargeBee::Subscription.cancel(subscription.stripe_customer_id)
- subscription.cancelled!
- rescue StandardError => e
- Raven.capture_exception(e)
- end
-
- def hosted_page_url(account)
- subscription = account.subscription
-
- # result = ChargeBee::HostedPage.checkout_existing({
- # :subscription => {
- # :id => subscription.stripe_customer_id,
- # :plan_id => Plan.paid_plan.id
- # }
- # })
-
- result = ChargeBee::HostedPage.update_payment_method(
- customer: {
- id: subscription.stripe_customer_id
- }
- )
- result.hosted_page.url
- rescue StandardError => e
- Raven.capture_exception(e)
- end
- end
-end
diff --git a/app/views/layouts/vueapp.html.erb b/app/views/layouts/vueapp.html.erb
index f93ccb464..c2dae5279 100644
--- a/app/views/layouts/vueapp.html.erb
+++ b/app/views/layouts/vueapp.html.erb
@@ -31,7 +31,6 @@
window.chatwootConfig = {
hostURL: '<%= ENV.fetch('FRONTEND_URL', '') %>',
fbAppId: '<%= ENV.fetch('FB_APP_ID', nil) %>',
- billingEnabled: <%= ActiveModel::Type::Boolean.new.cast(ENV.fetch('BILLING_ENABLED', false)) %>,
signupEnabled: '<%= ENV.fetch('ENABLE_ACCOUNT_SIGNUP', true) %>',
<% if ENV['VAPID_PUBLIC_KEY'] %>
vapidPublicKey: new Uint8Array(<%= Base64.urlsafe_decode64(ENV['VAPID_PUBLIC_KEY']).bytes %>),
diff --git a/config/initializers/00_init.rb b/config/initializers/00_init.rb
deleted file mode 100644
index f2fc3c112..000000000
--- a/config/initializers/00_init.rb
+++ /dev/null
@@ -1,2 +0,0 @@
-PLAN_CONFIG = YAML.load_file(File.join(Rails.root, 'config', 'plans.yml'))
-$chargebee = ChargeBee.configure(site: ENV['CHARGEBEE_SITE'], api_key: ENV['CHARGEBEE_API_KEY'])
diff --git a/config/plans.yml b/config/plans.yml
deleted file mode 100644
index a00917dd4..000000000
--- a/config/plans.yml
+++ /dev/null
@@ -1,17 +0,0 @@
-active:
- v1:
- paid:
- name: 'Platinum'
- id: 'v1-platinum'
- price: 29
- trial:
- name: 'Trial'
- id: 'v1Trial'
- price: 0
-inactive:
- v0:
- free:
- name: 'Free'
- price: 0
-trial_period: 365
-default_pricing_version: 'v1'
diff --git a/config/routes.rb b/config/routes.rb
index b0a9b9388..f1c3327d4 100644
--- a/config/routes.rb
+++ b/config/routes.rb
@@ -83,13 +83,6 @@ Rails.application.routes.draw do
resources :notifications, only: [:index, :update]
resource :notification_settings, only: [:show, :update]
- # this block is only required if subscription via chargebee is enabled
- resources :subscriptions, only: [:index] do
- collection do
- get :summary
- end
- end
-
resources :webhooks, except: [:show]
end
end
@@ -114,12 +107,6 @@ Rails.application.routes.draw do
resources :inbox_members, only: [:index]
resources :labels, only: [:create, :destroy]
end
-
- resources :webhooks, only: [] do
- collection do
- post :chargebee
- end
- end
end
namespace :v2 do
diff --git a/db/migrate/20200607140737_remove_subscriptions.rb b/db/migrate/20200607140737_remove_subscriptions.rb
new file mode 100644
index 000000000..33f756083
--- /dev/null
+++ b/db/migrate/20200607140737_remove_subscriptions.rb
@@ -0,0 +1,15 @@
+class RemoveSubscriptions < ActiveRecord::Migration[6.0]
+ def change
+ drop_table :subscriptions do |t|
+ t.string 'pricing_version'
+ t.integer 'account_id'
+ t.datetime 'expiry'
+ t.string 'billing_plan', default: 'trial'
+ t.string 'stripe_customer_id'
+ t.datetime 'created_at', null: false
+ t.datetime 'updated_at', null: false
+ t.integer 'state', default: 0
+ t.boolean 'payment_source_added', default: false
+ end
+ end
+end
diff --git a/db/schema.rb b/db/schema.rb
index 1ef9c48e1..914058c79 100644
--- a/db/schema.rb
+++ b/db/schema.rb
@@ -10,7 +10,7 @@
#
# It's strongly recommended that you check this file into your version control system.
-ActiveRecord::Schema.define(version: 2020_06_06_132552) do
+ActiveRecord::Schema.define(version: 2020_06_07_140737) do
# These are extensions that must be enabled in order to support this database
enable_extension "pg_stat_statements"
@@ -328,18 +328,6 @@ ActiveRecord::Schema.define(version: 2020_06_06_132552) do
t.index ["user_id"], name: "index_notifications_on_user_id"
end
- create_table "subscriptions", id: :serial, force: :cascade do |t|
- t.string "pricing_version"
- t.integer "account_id"
- t.datetime "expiry"
- t.string "billing_plan", default: "trial"
- t.string "stripe_customer_id"
- t.datetime "created_at", null: false
- t.datetime "updated_at", null: false
- t.integer "state", default: 0
- t.boolean "payment_source_added", default: false
- end
-
create_table "super_admins", force: :cascade do |t|
t.string "email", default: "", null: false
t.string "encrypted_password", default: "", null: false
diff --git a/lib/webhooks/chargebee.rb b/lib/webhooks/chargebee.rb
deleted file mode 100644
index dd28a110b..000000000
--- a/lib/webhooks/chargebee.rb
+++ /dev/null
@@ -1,86 +0,0 @@
-# frozen_string_literal: true
-
-class Webhooks::Chargebee
- SUPPORTED_EVENTS = [:subscription_created, :subscription_trial_end_reminder,
- :subscription_activated, :subscription_cancelled,
- :subscription_reactivated, :subscription_deleted,
- :subscription_renewed, :payment_source_added, :subscription_changed].freeze
-
- attr_accessor :params, :account
-
- def initialize(params)
- @params = params
- end
-
- def consume
- send(event_name) if supported_event?
- end
-
- private
-
- def event_name
- @params[:event_type]
- end
-
- def customer_id
- @params[:content][:customer][:id]
- end
-
- def trial_ends_on
- trial_end = @params[:content][:subscription][:trial_end]
- DateTime.strptime(trial_end, '%s')
- end
-
- def supported_event?
- SUPPORTED_EVENTS.include?(event_name.to_sym)
- end
-
- def subscription
- @subscriptiom ||= Subscription.find_by(stripe_customer_id: customer_id)
- end
-
- def subscription_created
- Raven.capture_message("subscription created for #{customer_id}")
- end
-
- def subscription_changed
- if subscription.expiry != trial_ends_on
- subscription.expiry = trial_ends_on
- subscription.save
- subscription.trial!
- end
- end
-
- def subscription_trial_end_reminder
- # Raven.capture_message("subscription trial end reminder for #{customer_id}")
- end
-
- def subscription_activated
- subscription.active!
- Raven.capture_message("subscription activated for #{customer_id}")
- end
-
- def subscription_cancelled
- # if there is a reason field in response. Then cancellation is due to payment failure
- subscription.cancelled!
- Raven.capture_message("subscription cancelled for #{customer_id}")
- end
-
- def subscription_reactivated
- # TODO: send mail to user that account is reactivated
- subscription.active!
- Raven.capture_message("subscription reactivated for #{customer_id}")
- end
-
- def subscription_renewed
- # TODO: Needs this to show payment history.
- Raven.capture_message("subscription renewed for #{customer_id}")
- end
-
- def subscription_deleted; end
-
- def payment_source_added
- Raven.capture_message("payment source added for #{customer_id}")
- subscription.payment_source_added!
- end
-end
diff --git a/spec/controllers/api/v1/accounts/subscriptions_controller_spec.rb b/spec/controllers/api/v1/accounts/subscriptions_controller_spec.rb
deleted file mode 100644
index af7071f21..000000000
--- a/spec/controllers/api/v1/accounts/subscriptions_controller_spec.rb
+++ /dev/null
@@ -1,46 +0,0 @@
-require 'rails_helper'
-
-RSpec.describe 'Subscriptions API', type: :request do
- let(:account) { create(:account) }
-
- describe 'GET /api/v1/accounts/{account.id}/subscriptions' do
- context 'when it is an unauthenticated user' do
- it 'returns unauthorized' do
- ENV['BILLING_ENABLED'] = 'true'
-
- get "/api/v1/accounts/#{account.id}/subscriptions"
-
- expect(response).to have_http_status(:unauthorized)
-
- ENV['BILLING_ENABLED'] = nil
- end
- end
-
- context 'when it is an authenticated user' do
- let(:agent) { create(:user, account: account, role: :agent) }
-
- it 'returns all subscriptions' do
- ENV['BILLING_ENABLED'] = 'true'
-
- get "/api/v1/accounts/#{account.id}/subscriptions",
- headers: agent.create_new_auth_token,
- as: :json
-
- expect(response).to have_http_status(:success)
- expect(JSON.parse(response.body)).to eq(account.subscription_data.as_json)
-
- ENV['BILLING_ENABLED'] = nil
- end
-
- it 'throws 404 error if env variable is not set' do
- ENV['BILLING_ENABLED'] = nil
-
- get "/api/v1/accounts/#{account.id}/subscriptions",
- headers: agent.create_new_auth_token,
- as: :json
-
- expect(response).to have_http_status(:not_found)
- end
- end
- end
-end
diff --git a/spec/fixtures/subscriptions.yml b/spec/fixtures/subscriptions.yml
deleted file mode 100644
index f279a5c48..000000000
--- a/spec/fixtures/subscriptions.yml
+++ /dev/null
@@ -1,15 +0,0 @@
-# Read about fixtures at http://api.rubyonrails.org/classes/ActiveRecord/FixtureSet.html
-
-one:
- pricing_version: MyString
- account_id: 1
- expiry: 2017-04-24 22:47:08
- billing_plan: MyString
- stripe_customer_id: MyString
-
-two:
- pricing_version: MyString
- account_id: 1
- expiry: 2017-04-24 22:47:08
- billing_plan: MyString
- stripe_customer_id: MyString
diff --git a/spec/models/account_spec.rb b/spec/models/account_spec.rb
index 821eb31ba..59929ae8f 100644
--- a/spec/models/account_spec.rb
+++ b/spec/models/account_spec.rb
@@ -14,7 +14,6 @@ RSpec.describe Account do
it { is_expected.to have_many(:canned_responses).dependent(:destroy) }
it { is_expected.to have_many(:facebook_pages).class_name('::Channel::FacebookPage').dependent(:destroy) }
it { is_expected.to have_many(:web_widgets).class_name('::Channel::WebWidget').dependent(:destroy) }
- it { is_expected.to have_one(:subscription).dependent(:destroy) }
it { is_expected.to have_many(:webhooks).dependent(:destroy) }
it { is_expected.to have_many(:notification_settings).dependent(:destroy) }
it { is_expected.to have_many(:events) }