-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathCreditAccount.php
89 lines (77 loc) · 3.13 KB
/
CreditAccount.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
<?php
/*************************************************************************************/
/* This file is part of the Thelia package. */
/* */
/* Copyright (c) OpenStudio */
/* email : dev@thelia.net */
/* web : http://www.thelia.net */
/* */
/* For the full copyright and license information, please view the LICENSE.txt */
/* file that was distributed with this source code. */
/*************************************************************************************/
namespace CreditAccount;
use CreditAccount\Model\CreditAccountExpirationQuery;
use CreditAccount\Model\CreditAccountQuery;
use CreditAccount\Model\CreditAmountHistoryQuery;
use Propel\Runtime\Connection\ConnectionInterface;
use Symfony\Component\DependencyInjection\Loader\Configurator\ServicesConfigurator;
use Thelia\Core\Template\TemplateDefinition;
use Thelia\Install\Database;
use Thelia\Module\BaseModule;
class CreditAccount extends BaseModule
{
const DOMAIN = 'creditaccount';
/**
* event send when credit account change
*/
const CREDIT_ACCOUNT_ADD_AMOUNT = 'creditAccount.addAccount';
/**
* Sent when credit account used change
*/
const CREDIT_ACCOUNT_USED = 'creditAccount.used.change';
public function postActivation(ConnectionInterface $con = null): void
{
$database = new Database($con);
try {
CreditAccountQuery::create()
->find();
} catch (\Exception $exception) {
$database->insertSql(null, [__DIR__ . "/Config/sql/credit_account.sql"]);
}
try {
CreditAccountExpirationQuery::create()
->find();
} catch (\Exception $exception) {
$database->insertSql(null, [__DIR__ . "/Config/sql/credit_account_expiration.sql"]);
}
try {
CreditAmountHistoryQuery::create()
->find();
} catch (\Exception $exception) {
$database->insertSql(null, [__DIR__ . "/Config/sql/credit_amount_history.sql"]);
}
}
/**
* @return array
*/
public function getHooks()
{
return array(
array(
"type" => TemplateDefinition::FRONT_OFFICE,
"code" => "order-invoice.before-discount",
"title" => array(
"en_US" => "Before discount code form block"
),
"active" => true
)
);
}
public static function configureServices(ServicesConfigurator $servicesConfigurator): void
{
$servicesConfigurator->load(self::getModuleCode().'\\', __DIR__)
->exclude([THELIA_MODULE_DIR . ucfirst(self::getModuleCode()). "/I18n/*"])
->autowire(true)
->autoconfigure(true);
}
}