';
+
return $html;
}
@@ -82,33 +121,199 @@ public function isDisplayed(): bool
return count($this->warnings) > 0;
}
+ /**
+ * @return void
+ * @throws NoSuchEntityException
+ */
private function addMessages()
{
$this->addEnvorimentMessages();
$this->addConfigMessages();
+ $this->addDashSettingsMessages();
}
+ /**
+ * @return void
+ */
private function addEnvorimentMessages()
{
if (!$this->config->isHubEnabled()) {
- $this->warnings[] = __('Pagar.me module is not yet integrated to the HUB. Complete the integration to start selling!');
+ $this->warnings[] = __(
+ 'Pagar.me module is not yet integrated to the HUB. Complete the integration to start selling!'
+ );
}
if ($this->config->isSandboxMode()) {
- $this->warnings[] = __('This store is linked to the Pagar.me test environment. This environment is intended for integration validation and does not generate real financial transactions.');
+ $this->warnings[] = __(
+ 'This store is linked to the Pagar.me test environment. This environment is intended for integration'
+ . ' validation and does not generate real financial transactions.'
+ );
}
}
+ /**
+ * @return void
+ */
private function addConfigMessages()
{
$customerConfigs = $this->config->getPagarmeCustomerConfigs();
+ $customerUrl = $this->urlInterface->getUrl('adminhtml/system_config/edit/section/customer');
if ($customerConfigs['showVatNumber'] != 1) {
- $this->warnings[] = __("Show VAT Number on Storefront must be defined as 'Yes' on Stores > Configuration > Customer > Customer Configuration > Create New Account Options for Pagar.me module to work on your store.");
+ $this->warnings[] = sprintf(
+ __(
+ 'Show VAT Number on Storefront must be defined as "Yes" on Stores > '
+ . 'Configuration > Customers > %sCustomer Configuration%s > '
+ . 'Create New Account Options for Pagar.me module to work on your store.'
+ ),
+ "",
+ ''
+ );
}
if ($customerConfigs['streetLinesNumber'] != 4) {
- $this->warnings[] = __("Number of Lines in a Street Address must be defined as '4' on Stores > Configuration > Customer > Customer Configuration > Name and Address Options for Pagar.me module to work on your store.");
+ $this->warnings[] = sprintf(
+ __(
+ 'Number of Lines in a Street Address must be defined as "4" on '
+ . 'Stores > Configuration > Customers > %sCustomer Configuration%s > '
+ . 'Name and Address options for Pagar.me module to work on your store.'
+ ),
+ "",
+ ''
+ );
}
}
+
+ /**
+ * @return void
+ * @throws NoSuchEntityException
+ */
+ private function addDashSettingsMessages()
+ {
+ $dashSettings = $this->account->getDashSettingsErrors();
+
+ if (empty($dashSettings)) {
+ return;
+ }
+
+ $linkLabel = __('Dash configurations');
+ $linkAccount = 'account-config';
+ $linkOrder = 'order-config';
+ $linkPayment = 'payment-methods';
+
+ $noticesList = [
+ CoreAccount::ACCOUNT_DISABLED => __('Your account is disabled on Pagar.me Dash. '
+ . 'Please, contact our support team to enable it.'),
+ CoreAccount::DOMAIN_EMPTY => sprintf(
+ __('No domain registered on Pagar.me Dash. Please enter your website\'s domain on the %s '
+ . 'to be able to process payment in your store.'),
+ $this->buildDashLink($linkLabel, $linkAccount)
+ ),
+ CoreAccount::DOMAIN_INCORRECT => sprintf(
+ __('The registered domain is different from the URL of your website. Please correct the '
+ . 'domain configured on the %s to be able to process payment in your store.'),
+ $this->buildDashLink($linkLabel, $linkAccount),
+ ),
+ CoreAccount::WEBHOOK_INCORRECT => sprintf(
+ __('The URL for receiving webhooks registered in Pagar.me Dash is different from the URL of '
+ . 'your website. Please, %s to access the Hub and click the Delete > Confirm '
+ . 'button. Then return to your store and integrate again.'),
+ $this->buildHubLink(__('click here'))
+ ),
+ CoreAccount::MULTIPAYMENTS_DISABLED => sprintf(
+ __('Multipayment option is disabled on Pagar.me Dash. Please, access the %s '
+ . 'and enable it to be able to process payment in your store.'),
+ $this->buildDashLink($linkLabel, $linkOrder)
+ ),
+ CoreAccount::MULTIBUYERS_DISABLED => sprintf(
+ __('Multibuyers option is disabled on Pagar.me Dash. Please, access the %s '
+ . 'and enable it to be able to process payment in your store.'),
+ $this->buildDashLink($linkLabel, $linkOrder)
+ ),
+ PaymentMethodSettings::PIX_DISABLED => sprintf(
+ __(self::PAYMENT_DISABLED_MESSAGE),
+ 'Pix',
+ $this->buildDashLink($linkLabel, $linkPayment)
+ ),
+ PaymentMethodSettings::CREDITCARD_DISABLED => sprintf(
+ __(self::PAYMENT_DISABLED_MESSAGE),
+ __('Credit Card'),
+ $this->buildDashLink($linkLabel, $linkPayment)
+ ),
+ PaymentMethodSettings::BILLET_DISABLED => sprintf(
+ __(self::PAYMENT_DISABLED_MESSAGE),
+ __('Billet'),
+ $this->buildDashLink($linkLabel, $linkPayment)
+ ),
+ PaymentMethodSettings::VOUCHER_DISABLED => sprintf(
+ __(self::PAYMENT_DISABLED_MESSAGE),
+ 'Voucher',
+ $this->buildDashLink($linkLabel, $linkPayment)
+ ),
+ PaymentMethodSettings::DEBITCARD_DISABLED => sprintf(
+ __(self::PAYMENT_DISABLED_MESSAGE),
+ __('Debit Card'),
+ $this->buildDashLink($linkLabel, $linkPayment)
+ )
+ ];
+
+ foreach ($dashSettings as $error) {
+ $this->warnings[] = $noticesList[$error];
+ }
+
+ $this->addVerifyDashButton();
+ }
+
+ /**
+ * @param string $label
+ * @param string $dashPage
+ * @return string
+ */
+ private function buildDashLink(string $label, string $dashPage = '')
+ {
+ if (!$this->account->hasMerchantAndAccountIds()) {
+ return $label;
+ }
+
+ $dashSettings = !empty($dashPage) ? "settings/{$dashPage}/" : '';
+ $url = $this->account->getDashUrl() . $dashSettings;
+
+ return sprintf(
+ '%s',
+ $url,
+ $label
+ );
+ }
+
+ /**
+ * @param string $label
+ * @return string
+ */
+ private function buildHubLink(string $label)
+ {
+ $installId = Magento2CoreSetup::getModuleConfiguration()->getHubInstallId();
+ $hubUrl = $this->hubIntegration->getHubUrl($installId);
+
+ return sprintf(
+ '%s',
+ $hubUrl,
+ $label
+ );
+ }
+
+ /**
+ * @return array
+ */
+ private function addVerifyDashButton()
+ {
+ $paymentUrl = $this->urlInterface->getUrl('adminhtml/system_config/edit/section/payment');
+ return $this->warnings[] = sprintf(
+ __(
+ 'Access %sPayment Methods%s configurations page to clear messages for errors already corrected in '
+ . 'the Pagar.me Dash.'
+ ),
+ "",
+ ''
+ );
+ }
}
diff --git a/Model/PagarmeConfigProvider.php b/Model/PagarmeConfigProvider.php
index 7fba0886..2917e363 100644
--- a/Model/PagarmeConfigProvider.php
+++ b/Model/PagarmeConfigProvider.php
@@ -5,7 +5,10 @@
use Magento\Checkout\Model\ConfigProviderInterface;
use Magento\Framework\App\Config\ConfigResource\ConfigInterface;
use Magento\Framework\App\Config\ScopeConfigInterface;
+use Magento\Framework\Exception\NoSuchEntityException;
use Magento\Store\Model\ScopeInterface;
+use Magento\Store\Model\StoreManagerInterface;
+use Pagarme\Core\Middle\Model\Account\PaymentEnum;
use Pagarme\Pagarme\Gateway\Transaction\Base\Config\ConfigInterface as PagarmeConfigInterface;
/**
@@ -33,6 +36,37 @@ class PagarmeConfigProvider implements ConfigProviderInterface
const PATH_CUSTOMER_NUMBER = 'payment/pagarme_customer_address/number_attribute';
const PATH_CUSTOMER_COMPLEMENT = 'payment/pagarme_customer_address/complement_attribute';
const PATH_CUSTOMER_DISTRICT = 'payment/pagarme_customer_address/district_attribute';
+ const PATH_ACCOUNT_ID = 'pagarme_pagarme/hub/account_id';
+
+ const PATH_PIX_ENABLED = 'payment/pagarme_pix/active';
+
+ const PATH_CREDIT_CARD_ENABLED = 'payment/pagarme_creditcard/active';
+
+ const PATH_BILLET_AND_CREDIT_CARD_ENABLED = 'payment/pagarme_multipleactionscreditcardbillet/active';
+
+ const PATH_TWO_CREDIT_CARD_ENABLED = 'payment/pagarme_multipleactionstwocreditcard/active';
+
+ const PATH_BILLET_ENABLED = 'payment/pagarme_billet/active';
+
+ const PATH_VOUCHER_ENABLED = 'payment/pagarme_voucher/active';
+
+ const PATH_DEBIT_ENABLED = 'payment/pagarme_debit/active';
+
+ const PATH_IS_PAYMENT_GATEWAY_TYPE = 'pagarme_pagarme/%s/is_payment_gateway';
+
+ const PATH_IS_PAYMENT_PSP_TYPE = 'pagarme_pagarme/%s/is_payment_psp';
+
+ const BILLET_PAYMENT_CONFIG = 'pagarme_billet';
+
+ const CREDIT_CARD_PAYMENT_CONFIG = 'pagarme_creditcard';
+
+ const DEBIT_PAYMENT_CONFIG = 'pagarme_debit';
+
+ const PIX_PAYMENT_CONFIG = 'pagarme_pix';
+
+ const VOUCHER_PAYMENT_CONFIG = 'pagarme_voucher';
+
+ const PATH_DASH_ERRORS = 'pagarme_pagarme/hub/account_errors';
/**
* Contains scope config of Magento
@@ -49,7 +83,12 @@ class PagarmeConfigProvider implements ConfigProviderInterface
protected $config;
/** @var PagarmeConfigInterface */
- private $pagarmeConfig;
+ protected $pagarmeConfig;
+
+ /**
+ * @var StoreManagerInterface
+ */
+ protected $storeManager;
/**
* @param PagarmeConfigInterface $pagarmeConfig
@@ -59,11 +98,13 @@ class PagarmeConfigProvider implements ConfigProviderInterface
public function __construct(
PagarmeConfigInterface $pagarmeConfig,
ScopeConfigInterface $scopeConfig,
- ConfigInterface $config
+ ConfigInterface $config,
+ StoreManagerInterface $storeManager
) {
$this->scopeConfig = $scopeConfig;
$this->config = $config;
$this->pagarmeConfig = $pagarmeConfig;
+ $this->storeManager = $storeManager;
}
/**
@@ -91,7 +132,7 @@ public function isGatewayIntegrationType()
{
return $this->scopeConfig->getValue(
self::XML_PATH_IS_GATEWAY_INTEGRATION_TYPE,
- ScopeInterface::SCOPE_STORE
+ ScopeInterface::SCOPE_WEBSITES
);
}
@@ -231,56 +272,136 @@ public function isModuleOrRecurrenceDisabled()
|| !$this->isRecurrenceEnabled();
}
- public function disableVoucher()
+ /**
+ * @return string
+ */
+ public function getAccountId($website = null)
{
- $this->config->saveConfig(
- self::XML_PATH_VOUCHER_ACTIVE,
- 0,
- 'default',
- 0
+ return $this->scopeConfig->getValue(
+ self::PATH_ACCOUNT_ID,
+ ScopeInterface::SCOPE_WEBSITES,
+ $this->getWebsiteId($website)
);
}
- public function disableDebit()
+ /**
+ * @return bool
+ */
+ public function isPixEnabled($website = null)
{
- $this->config->saveConfig(
- self::XML_PATH_DEBIT_ACTIVE,
- 0,
- 'default',
- 0
+ return (bool) $this->scopeConfig->getValue(
+ self::PATH_PIX_ENABLED,
+ ScopeInterface::SCOPE_WEBSITES,
+ $this->getWebsiteId($website)
);
}
- public function disableRecurrence()
+ /**
+ * @return bool
+ */
+ public function isCreditCardEnabled($website = null)
{
- $this->config->saveConfig(
- self::XML_PATH_RECURRENCE_ACTIVE,
- 0,
- 'default',
- 0
+ return (bool) $this->scopeConfig->getValue(
+ self::PATH_CREDIT_CARD_ENABLED,
+ ScopeInterface::SCOPE_WEBSITES,
+ $this->getWebsiteId($website)
+ );
+ }
+
+ /**
+ * @return bool
+ */
+ public function isBilletAndCreditCardEnabled($website = null)
+ {
+ return (bool) $this->scopeConfig->getValue(
+ self::PATH_BILLET_AND_CREDIT_CARD_ENABLED,
+ ScopeInterface::SCOPE_WEBSITES,
+ $this->getWebsiteId($website)
+ );
+ }
+
+ /**
+ * @return bool
+ */
+ public function isTwoCreditCardEnabled($website = null)
+ {
+ return (bool) $this->scopeConfig->getValue(
+ self::PATH_TWO_CREDIT_CARD_ENABLED,
+ ScopeInterface::SCOPE_WEBSITES,
+ $this->getWebsiteId($website)
);
}
- public function disableAntifraud()
+ /**
+ * @return bool
+ */
+ public function isAnyCreditCardMethodEnabled($website = null)
{
- $this->config->saveConfig(
- self::XML_PATH_ANTIFRAUD_ACTIVE,
- 0,
- 'default',
- 0
+ return $this->isCreditCardEnabled($website)
+ || $this->isBilletAndCreditCardEnabled($website)
+ || $this->isTwoCreditCardEnabled($website);
+ }
+
+ /**
+ * @return bool
+ */
+ public function isBilletEnabled($website = null)
+ {
+ return (bool) $this->scopeConfig->getValue(
+ self::PATH_BILLET_ENABLED,
+ ScopeInterface::SCOPE_WEBSITES,
+ $this->getWebsiteId($website)
);
}
- public function disableSavedCard()
+ /**
+ * @return bool
+ */
+ public function isAnyBilletMethodEnabled($website = null)
+ {
+ return $this->isBilletEnabled($website)
+ || $this->isBilletAndCreditCardEnabled($website);
+ }
+
+ /**
+ * @return bool
+ */
+ public function isVoucherEnabled($website = null)
{
- $this->config->saveConfig(
- self::XML_PATH_IS_ENABLE_SAVED_CARDS,
- 0,
- 'default',
- 0
+ return (bool) $this->scopeConfig->getValue(
+ self::PATH_VOUCHER_ENABLED,
+ ScopeInterface::SCOPE_WEBSITES,
+ $this->getWebsiteId($website)
);
}
+ /**
+ * @return bool
+ */
+ public function isDebitEnabled($website = null)
+ {
+ return (bool) $this->scopeConfig->getValue(
+ self::PATH_DEBIT_ENABLED,
+ ScopeInterface::SCOPE_WEBSITES,
+ $website
+ );
+ }
+
+ /**
+ * @param mixed $website
+ * @return array
+ */
+ public function availablePaymentMethods($website = null)
+ {
+ return [
+ PaymentEnum::PIX => $this->isPixEnabled($website),
+ PaymentEnum::DEBIT_CARD => $this->isDebitEnabled($website),
+ PaymentEnum::BILLET => $this->isAnyBilletMethodEnabled($website),
+ PaymentEnum::CREDIT_CARD => $this->isAnyCreditCardMethodEnabled($website),
+ PaymentEnum::VOUCHER => $this->isVoucherEnabled($website)
+ ];
+ }
+
/**
* @return array
*/
@@ -292,4 +413,14 @@ public function getConfig(): array
'pagarme_customer_configs' => $this->pagarmeConfig->getPagarmeCustomerConfigs(),
] ;
}
+
+ /**
+ * @param mixed $websiteId
+ * @return int|mixed
+ * @throws NoSuchEntityException
+ */
+ private function getWebsiteId($websiteId = null)
+ {
+ return $websiteId ?? $this->storeManager->getStore()->getWebsiteId();
+ }
}
diff --git a/Model/Source/PixTypes.php b/Model/Source/PixTypes.php
deleted file mode 100644
index 7866ee8f..00000000
--- a/Model/Source/PixTypes.php
+++ /dev/null
@@ -1,26 +0,0 @@
- 'pagarme',
- 'label' => __('Pagar.me'),
- ]
- ];
- }
-}
diff --git a/Model/WebhookManagement.php b/Model/WebhookManagement.php
index b2f8b670..a1edf9cb 100644
--- a/Model/WebhookManagement.php
+++ b/Model/WebhookManagement.php
@@ -12,25 +12,37 @@
use Pagarme\Core\Webhook\Services\WebhookReceiverService;
use Pagarme\Pagarme\Api\WebhookManagementInterface;
use Pagarme\Pagarme\Concrete\Magento2CoreSetup;
+use Pagarme\Pagarme\Model\Account;
class WebhookManagement implements WebhookManagementInterface
{
- protected OrderFactory $orderFactory;
+ /**
+ * @var OrderFactory
+ */
+ protected $orderFactory;
+
+ /**
+ * @var Account
+ */
+ protected $account;
public function __construct(
- OrderFactory $orderFactory
+ OrderFactory $orderFactory,
+ Account $account
) {
$this->orderFactory = $orderFactory;
+ $this->account = $account;
}
/**
* @api
* @param mixed $id
+ * @param mixed $account
* @param mixed $type
* @param mixed $data
* @return array|bool
*/
- public function save($id, $type, $data)
+ public function save($id, $type, $data, $account)
{
try {
Magento2CoreSetup::bootstrap();
@@ -48,18 +60,17 @@ public function save($id, $type, $data)
];
}
+ if ($type === 'charge.paid') {
+ $this->account->saveAccountIdFromWebhook($account);
+ }
+
$webhookReceiverService = new WebhookReceiverService();
return $webhookReceiverService->handle($postData);
- } catch (WebhookHandlerNotFoundException $e) {
+ } catch (WebhookHandlerNotFoundException | WebhookAlreadyHandledException $e) {
return [
"message" => $e->getMessage(),
"code" => 200
];
- } catch (WebhookAlreadyHandledException $e) {
- return [
- "message" => $e->getMessage(),
- "code" => 200
- ];
} catch(AbstractPagarmeCoreException $e) {
throw new M2WebApiException(
new Phrase($e->getMessage()),
diff --git a/Observer/DashConfigValidatorObserver.php b/Observer/DashConfigValidatorObserver.php
new file mode 100644
index 00000000..f33b2c1f
--- /dev/null
+++ b/Observer/DashConfigValidatorObserver.php
@@ -0,0 +1,54 @@
+account = $account;
+ $this->storeManager = $storeManager;
+ }
+
+ /**
+ * @param Observer $observer
+ * @return $this
+ * @throws NoSuchEntityException
+ */
+ public function execute(Observer $observer)
+ {
+ $section = $observer->getRequest()
+ ->getParam('section');
+ if ($section !== 'payment') {
+ return $this;
+ }
+
+ $website = $observer->getRequest()
+ ->getParam('website', $this->storeManager->getStore()->getWebsiteId());
+
+ $this->account->validateDashSettings($website);
+ return $this;
+ }
+}
diff --git a/Observer/DataValidateAdmin.php b/Observer/DataValidateAdmin.php
index d1e92197..d839d709 100644
--- a/Observer/DataValidateAdmin.php
+++ b/Observer/DataValidateAdmin.php
@@ -1,13 +1,8 @@
storeManager = $storeManager;
$this->messageManager = $messageManager;
$this->urlBuilder = $urlBuilder;
$this->responseFactory = $responseFactory;
$this->cacheTypeList = $cacheTypeList;
$this->cacheFrontendPool = $cacheFrontendPool;
$this->configProviderPagarme = $configProviderPagarme;
+ $this->account = $account;
}
/**
@@ -89,17 +84,7 @@ public function execute(\Magento\Framework\Event\Observer $observer)
}
$this->validateConfigMagento();
-
- if (!$this->isGatewayIntegrationType()) {
- $this->configProviderPagarme->disableVoucher();
- $this->configProviderPagarme->disableDebit();
- $this->configProviderPagarme->disableRecurrence();
- $this->configProviderPagarme->disableSavedCard();
- $this->configProviderPagarme->disableAntifraud();
-
- ObjectManager::getInstance()->get(Cache::class)
- ->clean(Config::CACHE_TAG);
- }
+ $this->account->clearWebsiteId();
return $this;
}
@@ -136,15 +121,10 @@ public function moduleIsEnable()
return $this->configProviderPagarme->getModuleStatus();
}
- public function isGatewayIntegrationType()
- {
- return $this->configProviderPagarme->isGatewayIntegrationType();
- }
-
protected function validateConfigMagento()
{
$disableModule = false;
- $disableMessage;
+ $disableMessage = [];
$url = $this->urlBuilder->getUrl('adminhtml/system_config/edit/section/payment');
if (!$this->configProviderPagarme->validateMaxInstallment()) {
diff --git a/Service/AccountService.php b/Service/AccountService.php
new file mode 100644
index 00000000..a2ffa1c9
--- /dev/null
+++ b/Service/AccountService.php
@@ -0,0 +1,93 @@
+coreAuth = new CoreAuth();
+ $this->storeManager = $storeManager;
+ $this->config = $config;
+ $this->configProvider = $configProvider;
+ }
+
+ /**
+ * @param mixed $accountId
+ * @param mixed $website
+ * @return Account
+ * @throws NoSuchEntityException
+ * @throws LocalizedException
+ */
+ public function getAccountWithValidation($accountId, $website)
+ {
+ $storeSettings = new StoreSettings();
+ $storeSettings->setSandbox($this->config->isSandboxMode());
+ $stores = $this->storeManager->getWebsite($website)
+ ->getStores();
+ $storeSettings->setStoreUrls(
+ array_map([$this, 'mapBaseUrlFromStore'], $stores)
+ );
+ $storeSettings->setEnabledPaymentMethods($this->configProvider->availablePaymentMethods($website));
+
+ $accountResponse = $this->getAccountOnPagarme($accountId);
+
+ $account = Account::createFromSdk($accountResponse);
+ return $account->validate($storeSettings);
+ }
+
+ /**
+ * @param mixed $accountId
+ * @return GetAccountResponse
+ */
+ private function getAccountOnPagarme($accountId)
+ {
+ $accountService = new AccountProxy($this->coreAuth);
+ return $accountService->getAccount($accountId);
+ }
+
+ /**
+ * @param StoreInterface $store
+ * @return string
+ */
+ private function mapBaseUrlFromStore($store)
+ {
+ return $store->getBaseUrl();
+ }
+}
diff --git a/composer.json b/composer.json
index 338db8fd..8f5f2c30 100755
--- a/composer.json
+++ b/composer.json
@@ -1,12 +1,12 @@
{
"name": "pagarme/pagarme-magento2-module",
"license": "MIT",
- "version": "2.2.5",
+ "version": "2.3.0",
"type": "magento2-module",
"description": "Magento 2 Module Pagar.me",
"require": {
"php": ">=7.1",
- "pagarme/ecommerce-module-core": "2.2.*"
+ "pagarme/ecommerce-module-core": "2.3.*"
},
"require-dev": {
"phpunit/phpunit": "4.1.0",
diff --git a/etc/adminhtml/di.xml b/etc/adminhtml/di.xml
index d2a45e36..223503e2 100644
--- a/etc/adminhtml/di.xml
+++ b/etc/adminhtml/di.xml
@@ -48,4 +48,42 @@
+
+
+
+ pagarme_billet
+
+
+
+
+ pagarme_creditcard
+
+
+
+
+
+ pagarme_creditcard
+
+
+
+
+ pagarme_debit
+
+
+
+
+ pagarme_voucher
+
+
+
+
+
+ pagarme_debit
+
+
+
+
+ pagarme_voucher
+
+
diff --git a/etc/adminhtml/system/global.xml b/etc/adminhtml/system/global.xml
index 79df5fbf..f2f6b03c 100644
--- a/etc/adminhtml/system/global.xml
+++ b/etc/adminhtml/system/global.xml
@@ -4,6 +4,7 @@
+
Pagarme\Pagarme\Block\Adminhtml\System\Config\Form\Field\HubIntegration
@@ -32,6 +33,7 @@
Warning! Configurations that only work for Gateway customers, who have a direct contract with an acquirer.]]>Magento\Config\Model\Config\Source\Yesnopagarme_pagarme/global/is_gateway_integration_type
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\EnableAdvanceSettings
diff --git a/etc/adminhtml/system/recurrence.xml b/etc/adminhtml/system/recurrence.xml
index c6ef5c2e..fe8cf91b 100644
--- a/etc/adminhtml/system/recurrence.xml
+++ b/etc/adminhtml/system/recurrence.xml
@@ -84,8 +84,5 @@
1
-
- 1
-
diff --git a/etc/adminhtml/system/transaction/billet.xml b/etc/adminhtml/system/transaction/billet.xml
index d82eb5f3..63b22fb2 100644
--- a/etc/adminhtml/system/transaction/billet.xml
+++ b/etc/adminhtml/system/transaction/billet.xml
@@ -18,6 +18,9 @@
payment/pagarme_billet/titlerequired-entry
+
+ 1
+
@@ -32,10 +35,11 @@
Pagarme\Pagarme\Model\Source\BilletTypespayment/pagarme_billet/types
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\BilletGatewayField1
- 1
+ required-entry
@@ -58,6 +62,9 @@
payment/pagarme_billet/sort_order
+
+ 1
+
diff --git a/etc/adminhtml/system/transaction/creditcard.xml b/etc/adminhtml/system/transaction/creditcard.xml
index d42588bc..9471620b 100644
--- a/etc/adminhtml/system/transaction/creditcard.xml
+++ b/etc/adminhtml/system/transaction/creditcard.xml
@@ -18,22 +18,36 @@
payment/pagarme_creditcard/titlerequired-entry
+
+ 1
+ Max size: . / ]]>payment/pagarme_creditcard/soft_description
+ validate-length maximum-length-13
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\CreditCardSoftDescriptor
+
+ 1
+ Pagarme\Pagarme\Model\Source\PaymentActionpayment/pagarme_creditcard/payment_action
+
+ 1
+ payment/pagarme_creditcard/sort_order
+
+ 1
+
@@ -41,7 +55,7 @@
Magento\Config\Model\Config\Source\Yesnopayment/pagarme_creditcard/enabled_saved_cards
- 1
+ 1
@@ -50,8 +64,9 @@
Pagarme\Pagarme\Model\Source\Cctypepayment/pagarme_creditcard/cctypesvalidate-select
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\CreditCardGatewayField
- 1
+ 1
@@ -60,8 +75,9 @@
Pagarme\Pagarme\Model\Source\CctypePSPpayment/pagarme_creditcard/cctypesvalidate-select
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\CreditCardPspField
- 0
+ 1
diff --git a/etc/adminhtml/system/transaction/creditcard/antifraud.xml b/etc/adminhtml/system/transaction/creditcard/antifraud.xml
index ee153fad..6ccf4060 100644
--- a/etc/adminhtml/system/transaction/creditcard/antifraud.xml
+++ b/etc/adminhtml/system/transaction/creditcard/antifraud.xml
@@ -8,6 +8,7 @@
+ Pagarme\Pagarme\Block\Adminhtml\Form\Fieldset\CreditCardGatewayFieldset
@@ -25,7 +26,7 @@
- 1
+ 1
diff --git a/etc/adminhtml/system/transaction/creditcard/installments.xml b/etc/adminhtml/system/transaction/creditcard/installments.xml
index 85bc8c98..b9f4eb4d 100644
--- a/etc/adminhtml/system/transaction/creditcard/installments.xml
+++ b/etc/adminhtml/system/transaction/creditcard/installments.xml
@@ -25,9 +25,10 @@
Pagarme\Pagarme\Model\Validation\GenericValidation
- Insert a number between 1 and .]]>
+ Insert a number between 1 and 12.]]>payment/pagarme_creditcard/installments_numberrequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber11
@@ -84,6 +85,7 @@
Insert a number between 1 and the Max number of installments.]]>payment/pagarme_creditcard/installments_max_without_interestrequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber11
@@ -102,5 +104,8 @@
+
+ 1
+
diff --git a/etc/adminhtml/system/transaction/creditcard/installments/amex.xml b/etc/adminhtml/system/transaction/creditcard/installments/amex.xml
index 1d0b71b6..abc7052d 100644
--- a/etc/adminhtml/system/transaction/creditcard/installments/amex.xml
+++ b/etc/adminhtml/system/transaction/creditcard/installments/amex.xml
@@ -15,9 +15,10 @@
Pagarme\Pagarme\Model\Validation\GenericValidation
- Insert a number between 1 and .]]>
+ Insert a number between 1 and 12.]]>payment/pagarme_creditcard/installments_number_amexrequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber
@@ -58,6 +59,7 @@
Insert a number between 1 and the Max number of installments.]]>payment/pagarme_creditcard/installments_max_without_interest_amexrequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber1
diff --git a/etc/adminhtml/system/transaction/creditcard/installments/aura.xml b/etc/adminhtml/system/transaction/creditcard/installments/aura.xml
index 6e6801b2..847d49c2 100644
--- a/etc/adminhtml/system/transaction/creditcard/installments/aura.xml
+++ b/etc/adminhtml/system/transaction/creditcard/installments/aura.xml
@@ -15,9 +15,10 @@
Pagarme\Pagarme\Model\Validation\GenericValidation
- Insert a number between 1 and .]]>
+ Insert a number between 1 and 12.]]>payment/pagarme_creditcard/installments_number_aurarequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber
@@ -58,6 +59,7 @@
Insert a number between 1 and the Max number of installments.]]>payment/pagarme_creditcard/installments_max_without_interest_aurarequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber1
diff --git a/etc/adminhtml/system/transaction/creditcard/installments/banese.xml b/etc/adminhtml/system/transaction/creditcard/installments/banese.xml
index d8cfcd9f..b1c320c4 100644
--- a/etc/adminhtml/system/transaction/creditcard/installments/banese.xml
+++ b/etc/adminhtml/system/transaction/creditcard/installments/banese.xml
@@ -19,6 +19,7 @@
Insert a number between 1 and 24.]]>payment/pagarme_creditcard/installments_number_baneserequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber
@@ -59,6 +60,7 @@
Insert a number between 1 and the Max number of installments.]]>payment/pagarme_creditcard/installments_max_without_interest_baneserequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber1
diff --git a/etc/adminhtml/system/transaction/creditcard/installments/cabal.xml b/etc/adminhtml/system/transaction/creditcard/installments/cabal.xml
index 896e1722..676baacc 100644
--- a/etc/adminhtml/system/transaction/creditcard/installments/cabal.xml
+++ b/etc/adminhtml/system/transaction/creditcard/installments/cabal.xml
@@ -19,6 +19,7 @@
Insert a number between 1 and 24.]]>payment/pagarme_creditcard/installments_number_cabalrequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber
@@ -59,6 +60,7 @@
Insert a number between 1 and the Max number of installments.]]>payment/pagarme_creditcard/installments_max_without_interest_cabalrequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber1
diff --git a/etc/adminhtml/system/transaction/creditcard/installments/credz.xml b/etc/adminhtml/system/transaction/creditcard/installments/credz.xml
index ade8d964..2b71bf47 100644
--- a/etc/adminhtml/system/transaction/creditcard/installments/credz.xml
+++ b/etc/adminhtml/system/transaction/creditcard/installments/credz.xml
@@ -19,6 +19,7 @@
Insert a number between 1 and 24.]]>payment/pagarme_creditcard/installments_number_credzrequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber
@@ -59,6 +60,7 @@
Insert a number between 1 and the Max number of installments.]]>payment/pagarme_creditcard/installments_max_without_interest_credzrequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber1
diff --git a/etc/adminhtml/system/transaction/creditcard/installments/diners.xml b/etc/adminhtml/system/transaction/creditcard/installments/diners.xml
index fa50a86b..0484266e 100644
--- a/etc/adminhtml/system/transaction/creditcard/installments/diners.xml
+++ b/etc/adminhtml/system/transaction/creditcard/installments/diners.xml
@@ -15,9 +15,10 @@
Pagarme\Pagarme\Model\Validation\GenericValidation
- Insert a number between 1 and .]]>
+ Insert a number between 1 and 12.]]>payment/pagarme_creditcard/installments_number_dinersrequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber
@@ -58,6 +59,7 @@
Insert a number between 1 and the Max number of installments.]]>payment/pagarme_creditcard/installments_max_without_interest_dinersrequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber1
diff --git a/etc/adminhtml/system/transaction/creditcard/installments/discover.xml b/etc/adminhtml/system/transaction/creditcard/installments/discover.xml
index 56885e03..0354a61b 100644
--- a/etc/adminhtml/system/transaction/creditcard/installments/discover.xml
+++ b/etc/adminhtml/system/transaction/creditcard/installments/discover.xml
@@ -15,9 +15,10 @@
Pagarme\Pagarme\Model\Validation\GenericValidation
- Insert a number between 1 and .]]>
+ Insert a number between 1 and 12.]]>payment/pagarme_creditcard/installments_number_discoverrequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumberPagarme\Pagarme\Model\Validation\GenericValidation
@@ -58,6 +59,7 @@
Insert a number between 1 and the Max number of installments.]]>payment/pagarme_creditcard/installments_max_without_interest_discoverrequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber1
diff --git a/etc/adminhtml/system/transaction/creditcard/installments/elo.xml b/etc/adminhtml/system/transaction/creditcard/installments/elo.xml
index e24c3495..bf419cb6 100644
--- a/etc/adminhtml/system/transaction/creditcard/installments/elo.xml
+++ b/etc/adminhtml/system/transaction/creditcard/installments/elo.xml
@@ -15,9 +15,10 @@
Pagarme\Pagarme\Model\Validation\GenericValidation
- Insert a number between 1 and .]]>
+ Insert a number between 1 and 12.]]>payment/pagarme_creditcard/installments_number_elorequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber
@@ -58,6 +59,7 @@
Insert a number between 1 and the Max number of installments.]]>payment/pagarme_creditcard/installments_max_without_interest_elorequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber1
diff --git a/etc/adminhtml/system/transaction/creditcard/installments/hipercard.xml b/etc/adminhtml/system/transaction/creditcard/installments/hipercard.xml
index f880245c..a1c27f50 100644
--- a/etc/adminhtml/system/transaction/creditcard/installments/hipercard.xml
+++ b/etc/adminhtml/system/transaction/creditcard/installments/hipercard.xml
@@ -15,9 +15,10 @@
Pagarme\Pagarme\Model\Validation\GenericValidation
- Insert a number between 1 and .]]>
+ Insert a number between 1 and 12.]]>payment/pagarme_creditcard/installments_number_hipercardrequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber
@@ -58,6 +59,7 @@
Insert a number between 1 and the Max number of installments.]]>payment/pagarme_creditcard/installments_max_without_interest_hipercardrequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber1
diff --git a/etc/adminhtml/system/transaction/creditcard/installments/jcb.xml b/etc/adminhtml/system/transaction/creditcard/installments/jcb.xml
index bcdaeb76..c589dc64 100644
--- a/etc/adminhtml/system/transaction/creditcard/installments/jcb.xml
+++ b/etc/adminhtml/system/transaction/creditcard/installments/jcb.xml
@@ -15,9 +15,10 @@
Pagarme\Pagarme\Model\Validation\GenericValidation
- Insert a number between 1 and .]]>
+ Insert a number between 1 and 12.]]>payment/pagarme_creditcard/installments_number_jcbrequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber
@@ -58,6 +59,7 @@
Insert a number between 1 and the Max number of installments.]]>payment/pagarme_creditcard/installments_max_without_interest_jcbrequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber1
diff --git a/etc/adminhtml/system/transaction/creditcard/installments/mastercard.xml b/etc/adminhtml/system/transaction/creditcard/installments/mastercard.xml
index dc381409..a341bd90 100644
--- a/etc/adminhtml/system/transaction/creditcard/installments/mastercard.xml
+++ b/etc/adminhtml/system/transaction/creditcard/installments/mastercard.xml
@@ -15,9 +15,10 @@
Pagarme\Pagarme\Model\Validation\GenericValidation
- Insert a number between 1 and .]]>
+ Insert a number between 1 and 12.]]>payment/pagarme_creditcard/installments_number_mastercardrequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber
@@ -58,6 +59,7 @@
Insert a number between 1 and the Max number of installments.]]>payment/pagarme_creditcard/installments_max_without_interest_mastercardrequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber1
diff --git a/etc/adminhtml/system/transaction/creditcard/installments/visa.xml b/etc/adminhtml/system/transaction/creditcard/installments/visa.xml
index 5d57a9b4..a14a6094 100644
--- a/etc/adminhtml/system/transaction/creditcard/installments/visa.xml
+++ b/etc/adminhtml/system/transaction/creditcard/installments/visa.xml
@@ -15,9 +15,10 @@
Pagarme\Pagarme\Model\Validation\GenericValidation
- Insert a number between 1 and .]]>
+ Insert a number between 1 and 12.]]>payment/pagarme_creditcard/installments_number_visarequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber
@@ -58,6 +59,7 @@
Insert a number between 1 and the Max number of installments.]]>payment/pagarme_creditcard/installments_max_without_interest_visarequired-entry validate-number-range number-range-1-12
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\InstallmentsNumber1
diff --git a/etc/adminhtml/system/transaction/debit.xml b/etc/adminhtml/system/transaction/debit.xml
index bcfb62c9..d75b6fe4 100644
--- a/etc/adminhtml/system/transaction/debit.xml
+++ b/etc/adminhtml/system/transaction/debit.xml
@@ -8,6 +8,7 @@
+ Pagarme\Pagarme\Block\Adminhtml\Form\Fieldset\DebitCardFieldset
@@ -18,22 +19,36 @@
payment/pagarme_debit/titlerequired-entry
+
+ 1
+ payment/pagarme_debit/soft_description
- Max size: 22. / 22]]>
+ Max size: . / ]]>
+ validate-length maximum-length-13
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\DebitCardSoftDescriptor
+
+ 1
+ payment/pagarme_debit/sort_order
+
+ 1
+ Magento\Config\Model\Config\Source\Yesnopayment/pagarme_debit/enabled_saved_cards
+
+ 1
+
@@ -41,10 +56,9 @@
Pagarme\Pagarme\Model\Source\Debittypepayment/pagarme_debit/cctypesvalidate-select
+
+ 1
+
-
-
- 1
-
diff --git a/etc/adminhtml/system/transaction/multipleactionscreditcardbillet.xml b/etc/adminhtml/system/transaction/multipleactionscreditcardbillet.xml
index 1cfbf53a..84775552 100644
--- a/etc/adminhtml/system/transaction/multipleactionscreditcardbillet.xml
+++ b/etc/adminhtml/system/transaction/multipleactionscreditcardbillet.xml
@@ -18,11 +18,17 @@
payment/pagarme_billet_creditcard/titlerequired-entry
+
+ 1
+ payment/pagarme_billet_creditcard/sort_order
+
+ 1
+
diff --git a/etc/adminhtml/system/transaction/multipleactionstwocreditcard.xml b/etc/adminhtml/system/transaction/multipleactionstwocreditcard.xml
index 67764c1b..760ab2bc 100644
--- a/etc/adminhtml/system/transaction/multipleactionstwocreditcard.xml
+++ b/etc/adminhtml/system/transaction/multipleactionstwocreditcard.xml
@@ -18,11 +18,17 @@
payment/pagarme_two_creditcard/titlerequired-entry
+
+ 1
+ payment/pagarme_two_creditcard/sort_order
+
+ 1
+
diff --git a/etc/adminhtml/system/transaction/pix.xml b/etc/adminhtml/system/transaction/pix.xml
index bcd641c9..eb3a08eb 100644
--- a/etc/adminhtml/system/transaction/pix.xml
+++ b/etc/adminhtml/system/transaction/pix.xml
@@ -18,6 +18,9 @@
payment/pagarme_pix/titlerequired-entry
+
+ 1
+
@@ -28,20 +31,13 @@
1
-
-
-
- Pagarme\Pagarme\Model\Source\PixTypes
- payment/pagarme_pix/types
-
- 1
- 1
-
- payment/pagarme_pix/sort_order
+
+ 1
+
diff --git a/etc/adminhtml/system/transaction/voucher.xml b/etc/adminhtml/system/transaction/voucher.xml
index 827fa5d6..04c146ff 100644
--- a/etc/adminhtml/system/transaction/voucher.xml
+++ b/etc/adminhtml/system/transaction/voucher.xml
@@ -8,6 +8,7 @@
+ Pagarme\Pagarme\Block\Adminhtml\Form\Fieldset\VoucherFieldset
@@ -18,22 +19,36 @@
payment/pagarme_voucher/titlerequired-entry
+
+ 1
+ payment/pagarme_voucher/soft_description
- Max size: 22. / 22]]>
+ Max size: . / ]]>
+ validate-length maximum-length-13
+ Pagarme\Pagarme\Block\Adminhtml\Form\Field\VoucherSoftDescriptor
+
+ 1
+ payment/pagarme_voucher/sort_order
+
+ 1
+ Magento\Config\Model\Config\Source\Yesnopayment/pagarme_voucher/enabled_saved_cards
+
+ 1
+
@@ -41,10 +56,9 @@
Pagarme\Pagarme\Model\Source\Vouchertypepayment/pagarme_voucher/cctypesvalidate-select
+
+ 1
+
-
-
- 1
-
diff --git a/etc/db_schema.xml b/etc/db_schema.xml
index 40393d5d..bd27c3f8 100644
--- a/etc/db_schema.xml
+++ b/etc/db_schema.xml
@@ -58,9 +58,9 @@
-
-
-
+
+
+
diff --git a/etc/events.xml b/etc/events.xml
index 91cc58e3..159c8a46 100644
--- a/etc/events.xml
+++ b/etc/events.xml
@@ -65,4 +65,8 @@
+
+
+
+
diff --git a/etc/module.xml b/etc/module.xml
index 8d4024ec..b8794923 100755
--- a/etc/module.xml
+++ b/etc/module.xml
@@ -9,7 +9,7 @@
*/
-->
-
+
diff --git a/i18n/en_US.csv b/i18n/en_US.csv
index a31f36a3..62e5620e 100644
--- a/i18n/en_US.csv
+++ b/i18n/en_US.csv
@@ -1,338 +1 @@
-"Print Billet","Print Billet"
-"without interest","without interest"
-"with interest","with interest"
-"Authorize Only","Authorize Only"
-"Authorize and Capture","Authorize and Capture"
-"On Success","On Success"
-"Always","Always"
-"Analyse First","Analyse First"
-"Authorize First","Authorize First"
-"Configure","Configure"
-"Close","Close"
-"Place Order","Place Order"
-"Credit Card Information","Credit Card Information"
-"Credit Card Number","Credit Card Number"
-"Name on Card","Name on Card"
-"Expiration Date", "Expiration Date"
-"Invalid Expiration Date","Invalida Expiration Date"
-"Card Verification Number","Card Verification Number"
-"What is this?","What is this?"
-"Installments","Installments"
-"Address","Address"
-"Number Attribute","Number Attribute"
-"Complement Attribute","Complement Attribute"
-"Pagar.me AntiFraud","Pagar.me AntiFraud"
-"General","General"
-"Enabled","Enabled"
-"Installments Sodexo Premium","Installments Sodexo Premium"
-"Number Sodexo Premium","Number Sodexo Premium"
-"Min Amount Sodexo Premium","Min Amount Sodexo Premium"
-"Interest by issuer Sodexo Premium","Interest by issuer Sodexo Premium"
-"Interest Rate Initial (%) Sodexo Premium","Interest Rate Initial (%) Sodexo Premium"
-"Interest Rate Incremental (%) Sodexo Premium","Interest Rate Incremental (%) Sodexo Premium"
-"Max Without Interest Sodexo Premium","Max Without Interest Sodexo Premium"
-"Installments VR","Installments VR"
-"Number VR","Number VR"
-"Min Amount VR","Min Amount VR"
-"Interest by issuer VR","Interest by issuer VR"
-"Interest Rate Initial (%) VR","Interest Rate Initial (%) VR"
-"Interest Rate Incremental (%) VR","Interest Rate Incremental (%) VR"
-"Max Without Interest VR","Max Without Interest VR"
-"Installments Diners","Installments Diners"
-"Number Diners","Number Diners"
-"Min Amount Diners","Min Amount Diners"
-"Interest by issuer Diners","Interest by issuer Diners"
-"Interest Rate Initial (%) Diners","Interest Rate Initial (%) Diners"
-"Interest Rate Incremental (%) Diners","Interest Rate Incremental (%) Diners"
-"Max Without Interest Diners","Max Without Interest Diners"
-"Installments Elo","Installments Elo"
-"Number Elo","Number Elo"
-"Min Amount Elo","Min Amount Elo"
-"Interest by issuer Elo","Interest by issuer Elo"
-"Interest Rate Initial (%) Elo","Interest Rate Initial (%) Elo"
-"Interest Rate Incremental (%) Elo","Interest Rate Incremental (%) Elo"
-"Max Without Interest Elo","Max Without Interest Elo"
-"Installments JCB","Installments JCB"
-"Number JCB","Number JCB"
-"Min Amount JCB","Min Amount JCB"
-"Interest by issuer JCB","Interest by issuer JCB"
-"Interest Rate Initial (%) JCB","Interest Rate Initial (%) JCB"
-"Interest Rate Incremental (%) JCB","Interest Rate Incremental (%) JCB"
-"Max Without Interest JCB","Max Without Interest JCB"
-"Installments Amex","Installments Amex"
-"Number Amex","Number Amex"
-"Min Amount Amex","Min Amount Amex"
-"Interest by issuer Amex","Interest by issuer Amex"
-"Interest Rate Initial (%) Amex","Interest Rate Initial (%) Amex"
-"Interest Rate Incremental (%) Amex","Interest Rate Incremental (%) Amex"
-"Max Without Interest Amex","Max Without Interest Amex"
-"Installments Aura","Installments Aura"
-"Number Aura","Number Aura"
-"Min Amount Aura","Min Amount Aura"
-"Interest by issuer Aura","Interest by issuer Aura"
-"Interest Rate Initial (%) Aura","Interest Rate Initial (%) Aura"
-"Interest Rate Incremental (%) Aura","Interest Rate Incremental (%) Aura"
-"Max Without Interest Aura","Max Without Interest Aura"
-"Installments Visa","Installments Visa"
-"Number Visa","Number Visa"
-"Min Amount Visa","Min Amount Visa"
-"Interest by issuer Visa","Interest by issuer Visa"
-"Interest Rate Initial (%) Visa","Interest Rate Initial (%) Visa"
-"Interest Rate Incremental (%) Visa","Interest Rate Incremental (%) Visa"
-"Max Without Interest Visa","Max Without Interest Visa"
-"Installments Alelo","Installments Alelo"
-"Number Alelo","Number Alelo"
-"Min Amount Alelo","Min Amount Alelo"
-"Interest by issuer Alelo","Interest by issuer Alelo"
-"Interest Rate Initial (%) Alelo","Interest Rate Initial (%) Alelo"
-"Interest Rate Incremental (%) Alelo","Interest Rate Incremental (%) Alelo"
-"Max Without Interest Alelo","Max Without Interest Alelo"
-"Installments Cabal","Installments Cabal"
-"Number Cabal","Number Cabal"
-"Min Amount Cabal","Min Amount Cabal"
-"Interest by issuer Cabal","Interest by issuer Cabal"
-"Interest Rate Initial (%) Cabal","Interest Rate Initial (%) Cabal"
-"Interest Rate Incremental (%) Cabal","Interest Rate Incremental (%) Cabal"
-"Max Without Interest Cabal","Max Without Interest Cabal"
-"Installments Credz","Installments Credz"
-"Number Credz","Number Credz"
-"Min Amount Credz","Min Amount Credz"
-"Interest by issuer Credz","Interest by issuer Credz"
-"Interest Rate Initial (%) Credz","Interest Rate Initial (%) Credz"
-"Interest Rate Incremental (%) Credz","Interest Rate Incremental (%) Credz"
-"Max Without Interest Credz","Max Without Interest Credz"
-"Installments Banese","Installments Banese"
-"Number Banese","Number Banese"
-"Min Amount Banese","Min Amount Banese"
-"Interest by issuer Banese","Interest by issuer Banese"
-"Interest Rate Initial (%) Banese","Interest Rate Initial (%) Banese"
-"Interest Rate Incremental (%) Banese","Interest Rate Incremental (%) Banese"
-"Max Without Interest Banese","Max Without Interest Banese"
-"Installments Discover","Installments Discover"
-"Number Discover","Number Discover"
-"Min Amount Discover","Min Amount Discover"
-"Interest by issuer Discover","Interest by issuer Discover"
-"Interest Rate Initial (%) Discover","Interest Rate Initial (%) Discover"
-"Interest Rate Incremental (%) Discover","Interest Rate Incremental (%) Discover"
-"Max Without Interest Discover","Max Without Interest Discover"
-"Installments Hipercard","Installments Hipercard"
-"Number Hipercard","Number Hipercard"
-"Min Amount Hipercard","Min Amount Hipercard"
-"Interest by issuer Hipercard","Interest by issuer Hipercard"
-"Interest Rate Initial (%) Hipercard","Interest Rate Initial (%) Hipercard"
-"Interest Rate Incremental (%) Hipercard","Interest Rate Incremental (%) Hipercard"
-"Max Without Interest Hipercard","Max Without Interest Hipercard"
-"Installments Mastercard","Installments Mastercard"
-"Number Mastercard","Number Mastercard"
-"Min Amount Mastercard","Min Amount Mastercard"
-"Interest by issuer Mastercard","Interest by issuer Mastercard"
-"Interest Rate Initial (%) Mastercard","Interest Rate Initial (%) Mastercard"
-"Interest Rate Incremental (%) Mastercard","Interest Rate Incremental (%) Mastercard"
-"Max Without Interest Mastercard","Max Without Interest Mastercard"
-"Installments Sodexo Gift","Installments Sodexo Gift"
-"Number Sodexo Gift","Number Sodexo Gift"
-"Min Amount Sodexo Gift","Min Amount Sodexo Gift"
-"Interest by issuer Sodexo Gift","Interest by issuer Sodexo Gift"
-"Interest Rate Initial (%) Sodexo Gift","Interest Rate Initial (%) Sodexo Gift"
-"Interest Rate Incremental (%) Sodexo Gift","Interest Rate Incremental (%) Sodexo Gift"
-"Max Without Interest Sodexo Gift","Max Without Interest Sodexo Gift"
-"Installments Sodexo Combustivel","Installments Sodexo Combustivel"
-"Number Sodexo Combustivel","Number Sodexo Combustivel"
-"Min Amount Sodexo Combustivel","Min Amount Sodexo Combustivel"
-"Interest by issuer Sodexo Combustivel","Interest by issuer Sodexo Combustivel"
-"Interest Rate Initial (%) Sodexo Combustivel","Interest Rate Initial (%) Sodexo Combustivel"
-"Interest Rate Incremental (%) Sodexo Combustivel","Interest Rate Incremental (%) Sodexo Combustivel"
-"Max Without Interest Sodexo Combustivel","Max Without Interest Sodexo Combustivel"
-"Pagar.me Pagar.me","Pagar.me Pagar.me"
-"Payment Solutions.","Payment Solutions."
-"Global Settings","Global Settings"
-"Customer Config","Customer Config"
-"Pagar.me Transaction","Pagar.me Transaction"
-"Street Attibute","Street Attibute"
-"District Attribute","District Attribute"
-"Credit Card","Credit Card"
-"Billet","Billet"
-"Multiple Actions Two Credit Card","Multiple Actions Two Credit Card"
-"Title","Title"
-"New Order Status","New Order Status"
-"Reject Order Status","Reject Order Status"
-"Review Order Status","Review Order Status"
-"Sort Order","Sort Order"
-"Multiple Actions Credit Card and Billet","Multiple Actions Credit Card and Billet"
-"Payment from Applicable Countries","Payment from Applicable Countries"
-"Payment from Specific Countries","Payment from Specific Countries"
-"Make Check Payable to","Make Check Payable to"
-"Send Check to","Send Check to"
-"Minimum Order Total","Minimum Order Total"
-"Maximum Order Total","Maximum Order Total"
-"Payment Action","Payment Action"
-"Transaction Key\","Transaction Key\"
-"Test Mode","Test Mode"
-"Gateway URL","Gateway URL"
-"Transaction Details URL","Transaction Details URL"
-"Accepted Currency","Accepted Currency"
-"Debug","Debug"
-"Merchant's Email","Merchant's Email"
-"Active","Active"
-"Type","Type"
-"Types","Types"
-"Expirations Day","Expirations Day"
-"Instructions","Instructions"
-"Text to Checkout","Text to Checkout"
-"Pagar.me Credit Card","Pagar.me Credit Card"
-"Pagar.me Billet","Pagar.me Billet"
-"Pagar.me Pix","Pagar.me Pix"
-"Pagar.me Voucher","Pagar.me Voucher"
-"Pagar.me Debit Card","Pagar.me Debit Card"
-"Credit Card Number","Credit Card Number"
-"Name on Card","Name on Card"
-"Expiration Date","Expiration Date"
-"Card Verification Number","Card Verification Number"
-"Installments","Installments"
-"My billing and shipping address are the same","My billing and shipping address are the same"
-"Payment Method","Payment Method"
-"Month","Month"
-"Year","Year"
-"Apply Discount Code","Apply Discount Code"
-"Enter discount code","Enter discount code"
-"Apply Discount","Apply Discount"
-"Shipping Methods","Shipping Methods"
-"Shipping","Shipping"
-"Flat Rate","Flat Rate"
-"Fixed","Fixed"
-"New Address","New Address"
-"Shipping Address","Shipping Address"
-"Order Summary","Order Summary"
-"Items in Cart","Items in Cart"
-"View Details","View Details"
-"Size","Size"
-"Color","Color"
-"Next","Next"
-"Review & Payments","Review & Payments"
-"Ship To:","Ship To:"
-"Shipping Method:","Shipping Method:"
-"Cart Subtotal","Cart Subtotal"
-"Flat Rate - Fixed","Flat Rate - Fixed"
-"Order Total","Order Total"
-"Your order number is: %s","Your order number is: %s"
-"Your order number is: ","Your order number is: "
-"We'll email you an order confirmation with details and tracking info.","We'll email you an order confirmation with details and tracking info."
-"Continue Shopping","Continue Shopping"
-"Type installments Unique","Type installments Unique"
-"Number","Number"
-"Min Amount","Min Amount"
-"Interest by issuer","Interest by issuer"
-"Interest Rate Initial (%)","Interest Rate Initial (%)"
-"Interest Rate Incremental (%)","Interest Rate Incremental (%)"
-"Max Without Interest","Max Without Interest"
-"Customer Identity (CPF/CNPJ) Attribute","Customer Identity (CPF/CNPJ) Attribute"
-"Installments Sodexo Alimentacao","Installments Sodexo Alimentacao"
-"Number Sodexo Alimentacao","Number Sodexo Alimentacao"
-"Min Amount Sodexo Alimentacao","Min Amount Sodexo Alimentacao"
-"Interest by issuer Sodexo Alimentacao","Interest by issuer Sodexo Alimentacao"
-"Interest Rate Initial (%) Sodexo Alimentacao","Interest Rate Initial (%) Sodexo Alimentacao"
-"Interest Rate Incremental (%) Sodexo Alimentacao","Interest Rate Incremental (%) Sodexo Alimentacao"
-"Max Without Interest Sodexo Alimentacao","Max Without Interest Sodexo Alimentacao"
-"Installments Sodexo Refeição","Installments Sodexo Refeição"
-"Number Sodexo Refeição","Number Sodexo Refeição"
-"Min Amount Sodexo Refeição","Min Amount Sodexo Refeição"
-"Interest by issuer Sodexo Refeição","Interest by issuer Sodexo Refeição"
-"Interest Rate Initial (%) Sodexo Refeição","Interest Rate Initial (%) Sodexo Refeição"
-"Interest Rate Incremental (%) Sodexo Refeição","Interest Rate Incremental (%) Sodexo Refeição"
-"Max Without Interest Sodexo Refeição","Max Without Interest Sodexo Refeição"
-"Anti fraud","Anti fraud"
-"Yes","Yes"
-"No","No"
-"Pending","Pending"
-"Pending Payment","Pending Payment"
-"-- Please Select --","-- Please Select --"
-"Installments Sodexo Cultura","Installments Sodexo Cultura"
-"Number Sodexo Cultura","Number Sodexo Cultura"
-"Min Amount Sodexo Cultura","Min Amount Sodexo Cultura"
-"Interest by issuer Sodexo Cultura","Interest by issuer Sodexo Cultura"
-"Interest Rate Initial (%) Sodexo Cultura","Interest Rate Initial (%) Sodexo Cultura"
-"Interest Rate Incremental (%) Sodexo Cultura","Interest Rate Incremental (%) Sodexo Cultura"
-"Max Without Interest Sodexo Cultura","Max Without Interest Sodexo Cultura"
-"Brand","Brand"
-"Shipping & Handling","Shipping & Handling"
-"Grand Total","Grand Total"
-"Subtotal","Subtotal"
-"Product Name","Product Name"
-"Price","Price"
-"Qty","Qty"
-"Billing Address","Billing Address"
-"Order Information","Order Information"
-"Processing","Processing"
-"Print Order","Print Order"
-"Reorder","Reorder"
-"Ordered","Ordered"
-"Order","Order"
-"Order #","Order #"
-"Order #%1","Order #%1"
-"Order #%order_id","Order #%order_id"
-"Items Ordered","Items Ordered"
-"Send order status changes by e-mail", "Send order status changes by e-mail"
-"Send an e-mail every time when an order status is changed by a Pagar.me's webhook.
Warning! Make sure you have set up your mail server correctly before enable it, otherwise you will run the risk of slowdowns and crashes of your platform.
", "Send an e-mail every time when an order status is changed by a Pagar.me's webhook.
Warning! Make sure you have set up your mail server correctly before enable it, otherwise you will run the risk of slowdowns and crashes of your platform.
"
-"Our Number", "Our Number"
-"NSU from capture", "NSU from capture"
-"Document Number", "Document Number"
-"Card Number", "Card Number"
-"Module Version", "Module Version"
-"No brands available", "No brands available"
-"Create Magento's order even with failed payments", "Create Magento's order even with failed payments"
-"Payment action", "Payment action"
-"Sandbox Mode Active", "Sandbox Mode Active"
-"Always creates order", "Always creates order"
-"
Warning! Configurations that only work for Gateway customers, who have a direct contract with an acquirer.
", "
Warning! Configurations that only work for Gateway customers, who have a direct contract with an acquirer.
Warning! Don't forget to add your store's domain on Pagar.me dashboard
", "
Warning! Don't forget to add your store's domain on Pagar.me dashboard
"
-"View Integration", "View Integration"
-"Integrate With Pagar.me", "Integrate With Pagar.me"
-"Important! This store is linked to the Pagar.me test environment. This environment is intended for integration validation and does not generate real financial transactions.","Important! This store is linked to the Pagar.me test environment. This environment is intended for integration validation and does not generate real financial transactions."
-"Important! This store is in the testing phase. Orders placed in this environment will not be carried out.","Important! This store is in the testing phase. Orders placed in this environment will not be carried out."
"Please enter a valid $ amount. For example $100.00.", "Please enter a valid $ amount. For example: 1000.00"
-"This order does not belong to this user","This order does not belong to this user"
-"Do you want to capture this charge?","Do you want to capture this charge?"
-"Do you want to cancel this charge?","Do you want to cancel this charge?"
-"Charges","Charges"
-"Charge ID","Charge ID"
-"Paid Amount","Paid Amount"
-"Canceled Amount","Canceled Amount"
-"Refunded Amount","Refunded Amount"
-"Capture","Capture"
-"Cancel","Cancel",
-"Failed to copy! Please, manually copy the code using the field bellow the button.","Failed to copy! Please, manually copy the code using the field bellow the button."
-"PIX code copied!","PIX code copied!"
-"Copy PIX code","Copy PIX code"
-"Open your bank app","Open your bank app"
-"Scan the QR Code","Scan the QR Code"
-"Confirm the payment","Confirm the payment"
-"View Billet","View Billet"
-"Error updating cycles options for product with id %s. Error message: %s","Error updating cycles options for product with id %s. Error message: %s"
-"Subscription product with id %s not founded","Subscription product with id %s not founded"
-"Brands","Brands"
-"Select a brand","Select a brand"
-"Please, select a brand","Please, select a brand"
-"Please, enter valid Credit Card Number","Please, enter valid Credit Card Number"
-"Please, enter valid Name on Card","Please, enter valid Name on Card"
-"Please, enter valid Expiration Date","Please, enter valid Expiration Date"
-"The cvv field must be a minimum length of 3 and a maximum length of 4.","The cvv field must be a minimum length of 3 and a maximum length of 4."
-"Error in trying to create a plan type product","Error in trying to create a plan type product"
-"Please add subproducts before saving the plan","Please add subproducts before saving the plan"
-"Plan product not found","Plan product not found"
-"List of plan products not found","List of plan products not found"
-"Plan Product saved","Plan Product saved"
-"Subscription Product not found","Subscription Product not found"
-"Subscription Products not found","Subscription Products not found"
-"Error saving the subscription product","Error saving the subscription product"
-"Subscription product saved","Subscription product saved"
-"No product founded with name: %1","No product founded with name: %1"
-"Bundle product not selected","Bundle product not selected"
-"Select at last one payment method","Select at last one payment method"
-"Fill at last one cycle option","Fill at last one cycle option"
-"It was not possible to find the subproducts for this bundle. Check your configuration and try again","It was not possible to find the subproducts for this bundle. Check your configuration and try again"
-"Cart Discount","Cart Discount"
-"Apply cart discount to all subscription charges","Apply cart discount to all subscription charges"
-"For plans, when enabling this options, the discount will be applied to all charges, even when the products have different cycles.","For plans, when enabling this options, the discount will be applied to all charges, even when the products have different cycles."
-"For plans, when enabling this options, the shipping will be applied to all charges, even when the products have different cycles.","For plans, when enabling this options, the shipping will be applied to all charges, even when the products have different cycles."
-"For plans, when enabling this options, the taxes will be applied to all charges, even when the products have different cycles.","For plans, when enabling this options, the taxes will be applied to all charges, even when the products have different cycles."
diff --git a/i18n/pt_BR.csv b/i18n/pt_BR.csv
index 6cadb357..5f7f288c 100644
--- a/i18n/pt_BR.csv
+++ b/i18n/pt_BR.csv
@@ -8,6 +8,7 @@
"Subscriptions","Assinaturas"
"Pagar.me Payment Solutions.","Pagar.me Soluções de Pagamento."
"General Settings","Configurações Gerais"
+"Pagar.me integration","Integração Pagar.me"
"Integration Environment","Ambiente de Integração"
"Enable this Solution","Habilitar esta Solução"
"Enable Multi Buyer","Habilitar Multicompradores"
@@ -403,8 +404,8 @@
"Integrate With Pagar.me", "Integrar com Pagar.me"
"Important!","Importante!"
"This store is linked to the Pagar.me test environment. This environment is intended for integration validation and does not generate real financial transactions.","Esta loja está vinculada ao ambiente de testes da Pagar.me. Este ambiente é destinado a validação de integração e não gera operações financeiras reais."
-"Show VAT Number on Storefront must be defined as 'Yes' on Stores > Configuration > Customer > Customer Configuration > Create New Account Options for Pagar.me module to work on your store.","Mostrar Número VAT na Vitrine deve ser definido como 'Sim' em Cliente > Configurações de cliente > Criar Novas Opções de Conta para que o módulo da Pagar.me funcione na sua loja."
-"Number of Lines in a Street Address must be defined as '4' on Stores > Configuration > Customer > Customer Configuration > Name and Address Options for Pagar.me module to work on your store.","Numero de Linhas em Endereço deve ser definido como '4' em Cliente > Configurações de cliente > Opções de Nome e Endereço para que o módulo da Pagar.me funcione na sua loja."
+"Show VAT Number on Storefront must be defined as "Yes" on Stores > Configuration > Customers > %sCustomer Configuration%s > Create New Account Options for Pagar.me module to work on your store.","Mostrar Número VAT na Vitrine deve ser definido como "Sim" em Lojas > Configuração > Clientes > %sConfigurações de cliente%s > Criar Novas Opções de Conta para que o módulo da Pagar.me funcione na sua loja."
+"Number of Lines in a Street Address must be defined as "4" on Stores > Configuration > Customers > %sCustomer Configuration%s > Name and Address options for Pagar.me module to work on your store.","Numero de Linhas em Endereço deve ser definido como "4" em Lojas > Configuração > Clientes > %sConfigurações de cliente%s > Opções de Nome e Endereço para que o módulo da Pagar.me funcione na sua loja."
"Important! This store is not yet integrated to Pagar.me HUB. Orders placed now will not be carried out.","Importante! Esta loja ainda não está integrada ao HUB da Pagar.me. Pedidos efetuados agora não serão concluídos."
"Important! This store is in the testing phase. Orders placed in this environment will not be carried out.","Importante! Esta loja está em fase de testes. Os pedidos realizados neste ambiente não serão concluídos."
"Important! There are configurations that need to be fixed. If you are an administrator, check the admin for more details. This order will not be carried out!","Importante! Há configurações que precisam ser ajustadas. Se você é um administrador, verifique o admin para mais detalhes. Este pedido não será concluído!"
@@ -518,3 +519,15 @@
"For plans, when enabling this options, the discount will be applied to all charges, even when the products have different cycles.","Para planos, ao habilitar esta opção, o desconto será aplicado em todas as cobranças, mesmo quando os produtos tiverem ciclos diferentes."
"For plans, when enabling this options, the shipping will be applied to all charges, even when the products have different cycles.","Para planos, ao habilitar esta opção, o frete será aplicado em todas as cobranças, mesmo quando os produtos tiverem ciclos diferentes."
"For plans, when enabling this options, the taxes will be applied to all charges, even when the products have different cycles.","Para planos, ao habilitar esta opção, as taxas serão aplicadas sobre todas as cobranças, mesmo quando os produtos tiverem ciclos diferentes."
+"Dash configurations","configurações da Dash"
+"Your account is disabled on Pagar.me Dash. Please, contact our support team to enable it.","Sua conta está desativada na Dash da Pagar.me. Por favor, entre em contato com o nosso time de atendimento para habilitá-la."
+"No domain registered on Pagar.me Dash. Please enter your website's domain on the %s to be able to process payment in your store.","Nenhum domínio cadastrado na Dash da Pagar.me. Por favor, insira o domínio do seu site nas %s para poder processar o pagamento em sua loja."
+"The registered domain is different from the URL of your website. Please correct the domain configured on the %s to be able to process payment in your store.","O domínio cadastrado é diferente da URL do seu site. Por favor, corrija o domínio configurado nas %s para poder processar o pagamento em sua loja."
+"The URL for receiving webhooks registered in Pagar.me Dash is different from the URL of your website. Please, %s to access the Hub and click the Delete > Confirm button. Then return to your store and integrate again.","A URL de recebimento de webhooks cadastrado na Dash da Pagar.me é diferente da URL do seu site. Por favor, %s para acessar o Hub e clique no botão Excluir > Confirmar. Depois retorne à sua loja e integre novamente."
+"click here","clique aqui"
+"Multipayment option is disabled on Pagar.me Dash. Please, access the %s and enable it to be able to process payment in your store.","A opção Multimeio de pagamentos está desabilitada na Dash da Pagar.me. Por favor, acesse as %s e habilite para poder processar o pagamento em sua loja."
+"Multibuyers option is disabled on Pagar.me Dash. Please, access the %s and enable it to be able to process payment in your store.","A opção Multicompradores está desabilitada na Dash da Pagar.me. Por favor, acesse as %s e habilite para poder processar o pagamento em sua loja."
+"%1$s payment method is enabled on your store, but disabled on Pagar.me Dash. Please, access the %2$s and enable it to be able to process %1$s payment on your store.","A forma de pagamento %1$s está habilitada na sua loja, mas desabilitada na Dash da Pagar.me. Por favor, acesse as %2$s e habilite para poder processar o pagamento via %1$s na sua loja."
+"%sClick here%s to verify Pagar.me Dash Configurations after you correct then.","%sClique aqui%s para verificar as configurações da Dash do Pagar.me após corrigi-las."
+"Access %sPayment Methods%s configurations page to clear messages for errors already corrected in the Pagar.me Dash.","Acesse a página de configurações %sMétodos de Pagamento%s para limpar as mensagens dos erros já corrigidos na Dash do Pagar.me."
+"Failed to get account information: %1","Falha ao pegar informações da conta: %1"
diff --git a/view/adminhtml/layout/adminhtml_system_config_edit.xml b/view/adminhtml/layout/adminhtml_system_config_edit.xml
index 429d3a2b..998a8f56 100644
--- a/view/adminhtml/layout/adminhtml_system_config_edit.xml
+++ b/view/adminhtml/layout/adminhtml_system_config_edit.xml
@@ -3,10 +3,9 @@
-
+
-
diff --git a/view/adminhtml/layout/default.xml b/view/adminhtml/layout/default.xml
index 8e6e17dd..1194df79 100644
--- a/view/adminhtml/layout/default.xml
+++ b/view/adminhtml/layout/default.xml
@@ -2,5 +2,6 @@
+
-
\ No newline at end of file
+
diff --git a/view/adminhtml/web/css/hub_button.css b/view/adminhtml/web/css/hub_button.css
deleted file mode 100644
index ddeafaba..00000000
--- a/view/adminhtml/web/css/hub_button.css
+++ /dev/null
@@ -1,32 +0,0 @@
-#botao-hub span {
- background-color: #65a300;
- border-color: rgb(101, 163, 0);
- border-radius: 4px;
- border-style: solid;
- border-width: 2px;
- cursor: pointer;
- letter-spacing: .04em;
- display: inline-block;
- font-size: 14px;
- font-weight: 600;
- font-family: Open Sans, sans-serif;
- outline: none;
- padding: 8px 12px;
- text-transform: uppercase;
- text-align: center;
- color: #fff;
- user-select: none;
- white-space: normal;
- transition: all .3s ease-in-out;
-}
-
-#botao-hub span:hover, #botao-hub span:active, #botao-hub span:focus {
- background-color: rgb(125, 163, 0);
- border-color: rgb(125, 163, 0);
-}
-
-#botao-hub span img {
- width: 16px;
- margin-bottom: -3px;
- margin-top: -3px;
-}
diff --git a/view/adminhtml/web/css/integration_buttons.css b/view/adminhtml/web/css/integration_buttons.css
new file mode 100644
index 00000000..59b87f70
--- /dev/null
+++ b/view/adminhtml/web/css/integration_buttons.css
@@ -0,0 +1,48 @@
+#pagarme-hub-button, #pagarme-dash-button {
+ background-color: #65a300;
+ border-color: #65a300;
+ border-radius: 2px;
+ border-style: solid;
+ border-width: 1px;
+ letter-spacing: .04em;
+ display: inline-block;
+ font-size: 14px;
+ font-weight: 600;
+ font-family: Open Sans, sans-serif;
+ outline: none;
+ padding: 8px 12px;
+ text-decoration: none;
+ text-transform: uppercase;
+ text-align: center;
+ color: #fff;
+ user-select: none;
+ transition: background-color .2s ease-in-out, border-color .2s ease-in-out;
+ margin: 0 1rem 1rem 0;
+}
+
+#pagarme-dash-button {
+ background-color: #e3e3e3;
+ border-color: #adadad;
+ color: #514943;
+ text-transform: none;
+}
+
+#pagarme-hub-button:hover, #pagarme-hub-button:active, #pagarme-hub-button:focus {
+ background-color: #7da300;
+ border-color: #7da300;
+}
+
+#pagarme-dash-button:hover, #pagarme-dash-button:active, #pagarme-dash-button:focus {
+ background-color: #dbdbdb;
+}
+
+#pagarme-hub-button:after {
+ content: "";
+ background: url("");
+ background-size: 16px 16px;
+ background-repeat: no-repeat;
+ display: inline-block;
+ width: 16px;
+ height: 16px;
+ margin: 2px 0 -2px .8rem;
+}
diff --git a/view/adminhtml/web/css/menu.css b/view/adminhtml/web/css/menu.css
index 26d067c7..3c1c590a 100644
--- a/view/adminhtml/web/css/menu.css
+++ b/view/adminhtml/web/css/menu.css
@@ -1,5 +1,5 @@
.admin__menu .level-0.item-pagarme > a:before {
- content: url('../images/avatar-pagarme.svg');
+ content: url('../images/avatar-pagarme-white.svg');
height: 28px;
margin: 0 auto;
width: 30px;
diff --git a/view/adminhtml/web/css/warnings.css b/view/adminhtml/web/css/warnings.css
new file mode 100644
index 00000000..c521addd
--- /dev/null
+++ b/view/adminhtml/web/css/warnings.css
@@ -0,0 +1,22 @@
+.message.message-warning .pagarme-admin-warnings > h3 {
+ display: flex;
+ align-items: center;
+ margin-bottom: .5rem;
+ padding: 0.5rem 0;
+}
+
+.message.message-warning .pagarme-admin-warnings > h3:before {
+ content: url('../images/avatar-pagarme.svg');
+ height: 28px;
+ margin-right: 0.5rem;
+ background: rgba(255,255,255,.7);
+ border-radius: 0.6rem;
+}
+
+.message.message-warning .pagarme-admin-warnings > div {
+ padding: 1rem 0;
+}
+
+.message.message-warning .pagarme-admin-warnings > div:not(:last-child) {
+ border-bottom: 1px dashed #d1d1d1;
+}
diff --git a/view/adminhtml/web/images/avatar-pagarme-white.svg b/view/adminhtml/web/images/avatar-pagarme-white.svg
new file mode 100644
index 00000000..362293e3
--- /dev/null
+++ b/view/adminhtml/web/images/avatar-pagarme-white.svg
@@ -0,0 +1,6 @@
+
diff --git a/view/adminhtml/web/images/avatar-pagarme.svg b/view/adminhtml/web/images/avatar-pagarme.svg
index 7bb3cf41..2ce96344 100644
--- a/view/adminhtml/web/images/avatar-pagarme.svg
+++ b/view/adminhtml/web/images/avatar-pagarme.svg
@@ -1,13 +1,6 @@
diff --git a/view/adminhtml/web/js/hubIntegration.js b/view/adminhtml/web/js/hubIntegration.js
deleted file mode 100644
index 397e54c0..00000000
--- a/view/adminhtml/web/js/hubIntegration.js
+++ /dev/null
@@ -1,47 +0,0 @@
-require([
- "jquery",
- "jquery/ui",
-], function ($) {
- function Hub(config) {
- this.hubLogo = ""
- this.space = " ";
- this.elementType = "span";
- this.containerId = "botao-hub";
-
- this.setup = function() {
- var container = document.getElementById(this.containerId);
-
- if (!container){
- return;
- }
-
- const url = container.getAttribute("hub-url").replace("{redirectUrl}");
- const text = container.getAttribute("button-text");
-
- createButton(text, function(event) {
- });
- };
-
- this.createButton = function(text, func) {
- var container = document.getElementById(this.containerId);
- var button = document.createElement(this.elementType);
- button.innerHTML = text + this.space + this.space + this.getImageTag(hubLogo);
- container.appendChild(button);
- };
-
- this.getImageTag = function(src) {
- return "";
- };
-
- this.setup();
-
- return this;
- }
-
-
- $(document).ready(function (){
- Hub();
- });
-
-
-});
diff --git a/view/adminhtml/web/js/integrationType.js b/view/adminhtml/web/js/integrationType.js
index 8b1359ea..cd14b146 100644
--- a/view/adminhtml/web/js/integrationType.js
+++ b/view/adminhtml/web/js/integrationType.js
@@ -3,42 +3,54 @@ require([
"jquery/ui",
], function ($) {
"use strict";
- $(document).ready(function(){
+ $(document).ready(function () {
const integrationTypeElement = $('select[id*="pagarme_pagarme_global_is_gateway_integration_type"]'),
- softDescriptionElements = $('input[id$="_soft_description"]'),
- installmentsNumberElements = $('input[id*="pagarme_creditcard_installments"][id*="installments_number"]'),
- installmentsWithoutInterestElements = $('input[id*="pagarme_creditcard_installments"][id*="max_without_interest"]');
+ softDescriptionElements = $('input[id$="_soft_description"]'),
+ installmentsNumberElements = $('input[id*="pagarme_creditcard_installments"][id*="installments_number"]'),
+ installmentsWithoutInterestElements = $('input[id*="pagarme_creditcard_installments"][id*="max_without_interest"]');
- integrationTypeElement.change(function() {
- var integrationType = $(this).val(),
+ integrationTypeElement.change(function () {
+ const integrationType = $(this).val(),
creditcardSoftDescriptionElement = $('input[id$="_creditcard_soft_description"]'),
softDescriptionMaxLength = integrationType === '0' ? 13 : 22;
- changeCommentsByIntegrionType(integrationType);
+ changeCommentsByIntegrationType(integrationType);
softDescriptionCounter(creditcardSoftDescriptionElement, softDescriptionMaxLength);
changeInstallmentsValidation(integrationType);
})
- .change();
+ .change();
- softDescriptionElements.keyup(function() {
- var integrationType = integrationTypeElement.val(),
+ softDescriptionElements.keyup(function () {
+ const cssClasses = $(this).attr('class')
+ const maximumLengthCssClass = 'maximum-length-';
+ const positionMaximumLength = cssClasses.indexOf(maximumLengthCssClass) + maximumLengthCssClass.length;
+ let softDescriptionMaxLength = cssClasses.substring(
+ positionMaximumLength,
+ positionMaximumLength + 2
+ );
+
+ if (integrationTypeElement.length > 0) {
+ const integrationType = integrationTypeElement.val();
softDescriptionMaxLength = integrationType === '0' ? 13 : 22;
+ }
+
+ changeSoftDescriptionComment($(this), softDescriptionMaxLength);
softDescriptionCounter($(this), softDescriptionMaxLength);
})
- .keyup();
+ .keyup();
- softDescriptionElements.change(function() {
- var softDescription = $(this).val();
- softDescriptionElements.each(function() {
- if(softDescription !== '' && $(this).val() === '') {
+ softDescriptionElements.change(function () {
+ const softDescription = $(this).val();
+ softDescriptionElements.each(function () {
+ if (softDescription !== '' && $(this).val() === '') {
$(this).val(softDescription);
}
$(this).keyup();
});
})
- .change();
+ .change();
- installmentsNumberElements.change(function() {
- var installmentsNumberVal = $(this).val(),
+ installmentsNumberElements.change(function () {
+ const installmentsNumberVal = $(this).val(),
installmentsWithoutInterestElement = $(this).closest('fieldset[id*="pagarme_creditcard_installments"]')
.find('input[id*="_pagarme_creditcard_installments_"][id*="_max_without_interest"]').first();
@@ -46,18 +58,18 @@ require([
changeInstallmentsWithoutInterestValidation(installmentsWithoutInterestElement, installmentsNumberVal)
}
})
- .change();
+ .change();
- installmentsWithoutInterestElements.change(function(){
- var installmentsNumberParent = $(this).closest('fieldset.config')
+ installmentsWithoutInterestElements.change(function () {
+ const installmentsNumberParent = $(this).closest('fieldset.config')
.find('input[id*="_pagarme_creditcard_installments_"][id*="_installments_number"]').first();
-
+
if (installmentsNumberParent.val() === '') {
$(this).val('');
}
});
- function changeCommentsByIntegrionType(integrationType) {
+ function changeCommentsByIntegrationType(integrationType) {
const softDescriptionMaxSizeElement =
document.getElementById('soft_description_max_size');
@@ -67,25 +79,41 @@ require([
const installmentsMaxSizeElements =
$('[id^="installments_max_size"]');
- if (softDescriptionMaxSizeElement){
+ if (softDescriptionMaxSizeElement) {
softDescriptionMaxSizeElement.innerHTML =
integrationType === '0' ? 13 : 22;
}
- if (softDescriptionCounterMaxSizeElement){
+ if (softDescriptionCounterMaxSizeElement) {
softDescriptionCounterMaxSizeElement.innerHTML =
integrationType === '0' ? 13 : 22;
}
- if (installmentsMaxSizeElements){
- installmentsMaxSizeElements.each(function(){
+ if (installmentsMaxSizeElements) {
+ installmentsMaxSizeElements.each(function () {
$(this).html(integrationType === '0' ? 12 : 24);
});
}
- };
+ }
+
+ function changeSoftDescriptionComment(element, maxSize) {
+ const softDescriptionMaxSizeElement =
+ element.closest('td.value').find('#soft_description_max_size');
+
+ const softDescriptionCounterMaxSizeElement =
+ element.closest('td.value').find('#creditcard_soft_description_counter_max_size');
+
+ if (softDescriptionMaxSizeElement.length > 0) {
+ softDescriptionMaxSizeElement.html(maxSize);
+ }
+
+ if (softDescriptionCounterMaxSizeElement.length > 0) {
+ softDescriptionCounterMaxSizeElement.html(maxSize);
+ }
+ }
function softDescriptionCounter(element, maxLength) {
- var counter = element.parent().find('[id$="_soft_description_counter_current"]'),
+ const counter = element.parent().find('[id$="_soft_description_counter_current"]'),
length = element.val().length;
if (length >= maxLength) {
element.val(element.val().substring(0, maxLength));
@@ -95,7 +123,7 @@ require([
counter.text(length);
counter.parent().removeClass('limit-reached');
}
- };
+ }
function changeInstallmentsValidation(integrationType) {
if (integrationType === '0') {
@@ -105,13 +133,13 @@ require([
installmentsNumberElements.toggleClass('number-range-1-12', false);
installmentsNumberElements.toggleClass('number-range-1-24', true);
}
- };
+ }
function changeInstallmentsWithoutInterestValidation(element, maxRange) {
- element.removeClass(function(index, classNames) {
+ element.removeClass(function (index, classNames) {
return (classNames.match(/(^|\s)number-range-1-\S+/g) || []).join(' ');
})
- .addClass('number-range-1-' + maxRange);
- };
+ .addClass('number-range-1-' + maxRange);
+ }
});
});
diff --git a/view/frontend/web/js/core/checkout/PaymentMethodController.js b/view/frontend/web/js/core/checkout/PaymentMethodController.js
index 04fcc195..d2879915 100644
--- a/view/frontend/web/js/core/checkout/PaymentMethodController.js
+++ b/view/frontend/web/js/core/checkout/PaymentMethodController.js
@@ -85,6 +85,24 @@ define([
this.addCreditCardListeners(this.formObject);
this.modelToken = new CreditCardToken(this.formObject);
+
+ this.subscribeTotal();
+ }
+
+ subscribeTotal() {
+ const _self = this;
+
+ this.platformConfig.updateTotals.totals.subscribe(function(){
+ if (_self.methodCode === 'twocreditcards' || _self.methodCode === 'boletoCreditcard') {
+ for (let i = 0, len = _self.formObject.numberOfPaymentForms; i < len; i++) {
+ _self.fillCardAmount(_self.formObject[i], 2, i);
+ _self.fillInstallments(_self.formObject[i]);
+ }
+ return;
+ }
+ _self.fillCardAmount(_self.formObject, 1);
+ _self.fillInstallments(_self.formObject);
+ });
}
voucherInit() {
@@ -196,6 +214,7 @@ define([
}
this.modelToken = new CreditCardToken(this.formObject);
+ this.subscribeTotal();
}
pixInit() {
@@ -291,6 +310,8 @@ define([
this.formObject,
this.platformConfig.publicKey
);
+
+ this.subscribeTotal();
}
addCreditCardListeners(formObject) {
diff --git a/view/frontend/web/js/core/checkout/PlatformConfig.js b/view/frontend/web/js/core/checkout/PlatformConfig.js
index 9fcf6999..3889e35e 100644
--- a/view/frontend/web/js/core/checkout/PlatformConfig.js
+++ b/view/frontend/web/js/core/checkout/PlatformConfig.js
@@ -16,7 +16,7 @@ define([], () => {
availableBrands[i] = {
'title': brands[i],
- 'image': url
+ 'image': jQuery.isArray(url) ? url.find(element => element.includes('Pagarme')) : url
};
}