Skip to content

kurozumi/CustomerGroupRank

Repository files navigation

会員グループ管理::会員ランク管理アドオン

本プラグインは会員グループ管理プラグイン をインストール・有効化する必要があります。

会員グループ管理::会員ランク管理アドオンは、購入金額や購入回数に応じて会員グループを自動登録することができるプラグインです。

ゴールド会員、シルバー会員、ブロンズ会員などの会員グループを登録してそれぞれに購入金額と購入回数を登録しておくと、会員がログインしたときに条件にマッチした会員グループが会員に登録されます。
条件にマッチした会員グループが複数あった場合、優先度が最上位の会員グループが登録されます。

会員グループの優先度は会員グループ一覧ページで設定できます。
会員グループをドラッグアンドドロップで並べ替えるだけで設定できます。

設定方法

  • 会員グループを作成
  • 会員グループに購入回数と購入金額を設定

会員グループが会員に登録されるタイミング

  • 会員ログイン時に条件にマッチした会員グループが会員に登録されます。

ランク昇格条件のカスタマイズ方法

本プラグインはランク昇格(※会員グループの自動登録)条件を変更することができます。
デフォルトの条件は購入金額と購入回数ですが、例えば会員の最終購入日から1ヶ月過ぎていたら会員グループから除外するといったことも可能です。

Customizeディレクトリで以下の実装を行う必要があります。

  • RankInterfaceを実装したランク決定クラス。
  • services.yamlにRankInterfaceを実装したクラスを設定。priorityを99以下にすると反映されます。

ランク決定クラスの実装例

以下は本プラグインの実装です。

namespace Plugin\CustomerGroupRank42\Service\Rank;


use Doctrine\Common\Collections\ArrayCollection;
use Doctrine\ORM\EntityManagerInterface;
use Eccube\Entity\Customer;
use Plugin\CustomerGroup42\Entity\Group;

class Rank implements RankInterface
{
    /**
     * @var EntityManagerInterface
     */
    protected $entityManager;

    public function __construct(EntityManagerInterface $entityManager)
    {
        $this->entityManager = $entityManager;
    }

    /**
     * 優先度が最上位のグループを会員に設定する
     *
     * @param Customer $customer
     * @return void
     */
    public function decide(Customer $customer): void
    {
        // 会員グループをクリアする
        $customer->getGroups()->clear();

        // 対象の会員ブループが見つかったら登録
        $groups = $this->getGroups($customer);
        if ($groups->count() > 0) {
            /** @var Group $group */
            $group = $groups->first();
            $customer->addGroup($group);
        }
    }

    /**
     * 会員に適用可能なグループ一覧を取得
     *
     * @param Customer $customer
     * @return ArrayCollection
     */
    protected function getGroups(Customer $customer): ArrayCollection
    {
        $searchData = [
            'buyTimes' => $customer->getBuyTimes(),
            'buyTotal' => $customer->getBuyTotal()
        ];
        $groups = $this->entityManager->getRepository(Group::class)->getQueryBuilderBySearchData($searchData)
            ->getQuery()
            ->getResult();

        return new ArrayCollection($groups);
    }
}

services.yamlの設定例

以下は本プラグインの設定です。

services:
  Plugin\CustomerGroupRank42\Service\Rank\Rank:
    tags:
      - { name: 'plugin.customer.group.rank', priority: 100 }
    arguments:
      - '@doctrine.orm.default_entity_manager'

カスタマイズ、または他社プラグインとの競合による動作不良つきましてはサポート対象外です。

本プラグインを導入したことによる不具合や被った不利益につきましては一切責任を負いません。 ご理解の程よろしくお願いいたします。