{"__v":23,"_id":"5544d76bd8833c0d00582828","category":{"__v":1,"_id":"5544d76ad8833c0d00582804","pages":["5544d76bd8833c0d00582824","5544d76bd8833c0d00582825","5544d76bd8833c0d00582826","5544d76bd8833c0d00582827","5544d76bd8833c0d00582828","5544d76bd8833c0d00582829","5544d76bd8833c0d0058282a","5544d76bd8833c0d0058282b","5544d76bd8833c0d0058282c","5544d76bd8833c0d0058282d","5544d76bd8833c0d0058282e","5544d76bd8833c0d0058282f","5544d76bd8833c0d00582830","5544d76bd8833c0d00582831"],"project":"55227389b4a0de0d00de7e28","version":"5544d76ad8833c0d00582801","sync":{"url":"","isSync":false},"reference":false,"createdAt":"2015-04-09T09:27:58.538Z","from_sync":false,"order":2,"slug":"_-1","title":"アドオン開発"},"project":"55227389b4a0de0d00de7e28","user":"552342f6e20da719000e7925","version":{"__v":1,"_id":"5544d76ad8833c0d00582801","forked_from":"55227389b4a0de0d00de7e2b","project":"55227389b4a0de0d00de7e28","createdAt":"2015-05-02T13:55:54.059Z","releaseDate":"2015-05-02T13:55:54.059Z","categories":["5544d76ad8833c0d00582802","5544d76ad8833c0d00582803","5544d76ad8833c0d00582804","5544d76ad8833c0d00582805","5544d76ad8833c0d00582806"],"is_deprecated":false,"is_hidden":false,"is_beta":false,"is_stable":true,"codename":"","version_clean":"4.0.0","version":"4.0"},"updates":[],"next":{"pages":[],"description":""},"createdAt":"2015-04-10T08:30:04.293Z","link_external":false,"link_url":"","githubsync":"","sync_unique":"","hidden":false,"api":{"results":{"codes":[]},"auth":"required","params":[],"url":""},"isReference":false,"order":4,"body":"このチュートリアルでは [**フック**](doc:hooking) や[**Pre- and Post- コントローラー**](doc:pre-and-post-controllers) を使用するような高度なテクニックのアドオン作成方法を説明します。\n[block:callout]\n{\n  \"type\": \"info\",\n  \"body\": \"*フック*はとてもパワフルな技術で、CS-Cartではこれが多用されています。\\n\\nPHPフックは追加の処理をデフォルト処理の前後で実行する、またはデフォルトの処理ルーチーンをオーバーライド(上書き)するために使用されます。\\n\\nテンプレートフックはテンプレートのレンダリングを処理するため使用します。例えば、オリジナルテンプレートを修正することなく、追加データを表示したりすることが可能です。\\n\\nプレまたはポストコントローラーは特別なPHPファイル(アドオンディレクトリ内に置かれたファイルの名前による)で、特定のコントローラーが実行される前か後に呼び出されます。\",\n  \"title\": \"情報\"\n}\n[/block]\nこのチュートリアルでは [PHPフック](doc:php-hooks)  と [テンプレートフック](doc:tpl-hooks) の両方を使うアドオンを作成します。\n\nこのチュートリアルで作成するアドオンはログイン済みのユーザーが閲覧したカテゴリーの情報を収集します。さらに、ユーザーが閲覧したカテゴリーのアクセス数を管理パネルのダッシュボードに表として表示します。\n[block:api-header]\n{\n  \"type\": \"basic\",\n  \"title\": \"必要環境\"\n}\n[/block]\nこのチュートリアルを行うためは、インストールされたCS-Carが必要になります。公式サイトからCS-Cartを[ダウンロード](http://cs-cart.jp/)し、フリーモードで使用してください。\n\n**PHPやSmarty、CS-Cartアドオンディレクトリ構造に慣れることが重要です。**\n\nこのチュートリアルを進める前に [「Hello World」Addonチュートリアル](doc:hello-world-add-on-tutorial) を先に行うことをお勧めします。\n[block:api-header]\n{\n  \"type\": \"basic\",\n  \"title\": \"アドオン初期設定: addon.xmlとinit.phpの作成\"\n}\n[/block]\nインストールしたCS-Cartのルートディレクトリ内の*app/addons* ディレクトリに移動し、*advanced_addon*というサブディレクトリを作成します。\n\nこのディレクトリに以下の内容を含んだaddon.xml ファイルを作成します:\n\n*addons/advanced_addon/addon.xml*\n[block:code]\n{\n  \"codes\": [\n    {\n      \"code\": \"<?xml version=\\\"1.0\\\"?>\\n<addon scheme=\\\"3.0\\\">\\n   <id>advanced_addon</id>\\n   <version>1.0</version>\\n   <priority>100500</priority>\\n   <position>0</position>\\n   <status>active</status>\\n   <default_language>ja</default_language>\\n   <queries>\\n        <item>DROP TABLE IF EXISTS ?:advanced_addon_data;</item>\\n        <item>\\n            CREATE TABLE `?:advanced_addon_data` (\\n            `user_id` int(11) unsigned NOT NULL DEFAULT 0,\\n            `categories` text NOT NULL DEFAULT '',\\n            PRIMARY KEY (`user_id`)\\n            ) Engine=MyISAM DEFAULT CHARSET UTF8;\\n        </item>\\n        <item for=\\\"uninstall\\\">DROP TABLE IF EXISTS ?:advanced_addon_data;</item>\\n    </queries>\\n</addon>\",\n      \"language\": \"xml\"\n    }\n  ]\n}\n[/block]\n[addon.xml ダウンロード](https://gist.github.com/cscartjp/fa514bef48ca4bdea551)\n\nこれに対応する言語ファイルは以下となります。\n> /var/langs/ja/addons/advanced_addon.po\n[block:code]\n{\n  \"codes\": [\n    {\n      \"code\": \"msgid \\\"\\\"\\nmsgstr \\\"Project-Id-Version: tygh\\\"\\n\\\"Content-Type: text/plain; charset=UTF-8\\\\n\\\"\\n\\\"Language-Team: Japanese\\\\n\\\"\\n\\\"Language: ja_JP\\\\n\\\"\\n\\nmsgctxt \\\"Addons::name::advanced_addon\\\"\\nmsgid \\\"Advanced Add-on\\\"\\nmsgstr \\\"アドバンスド・アドオン\\\"\\n\\nmsgctxt \\\"Addons::description::advanced_addon\\\"\\nmsgid \\\"This is Advanced Add-on tutolial.\\\"\\nmsgstr \\\"アドオンの学習を行います。\\\"\",\n      \"language\": \"c\",\n      \"name\": null\n    }\n  ]\n}\n[/block]\n[advanced_addon.po ダウンロード](https://gist.github.com/cscartjp/fa514bef48ca4bdea551)\n\n---------------------\n\nさらに同じディレクトリに以下の内容を含んだ*init.php*ファイルを作成します。\n\n> addons/advanced_addon/init.php\n[block:code]\n{\n  \"codes\": [\n    {\n      \"code\": \"<?php\\n/***************************************************************************\\n*                                                                          *\\n*   (c) 2004 Vladimir V. Kalynyak, Alexey V. Vinokurov, Ilya M. Shalnev    *\\n*                                                                          *\\n* This  is  commercial  software,  only  users  who have purchased a valid *\\n* license  and  accept  to the terms of the  License Agreement can install *\\n* and use this program.                                                    *\\n*                                                                          *\\n****************************************************************************\\n* PLEASE READ THE FULL TEXT  OF THE SOFTWARE  LICENSE   AGREEMENT  IN  THE *\\n* \\\"copyright.txt\\\" FILE PROVIDED WITH THIS DISTRIBUTION PACKAGE.            *\\n****************************************************************************/\\n\\nif (!defined('BOOTSTRAP')) { die('Access denied'); }\\n\\nfn_register_hooks(\\n    'get_category_data_pre'\\n);\\n\",\n      \"language\": \"php\"\n    }\n  ]\n}\n[/block]\n[init.php ダウンロード](https://gist.github.com/cscartjp/8aaee0a0ea7b46b026fe):\n[block:callout]\n{\n  \"type\": \"success\",\n  \"body\": \"通常、関数名はひと目で分かるように書かれています。\\n(例えば、`get_product`は”一つの”商品情報を取得する関数です)\\n\\nフックは通常、 (例えばget_products_preとget_products_post )名称に応じて前処理や後処理のフックのために`_pre`または`_post`という接尾辞が付いていて、中に置かれている機能にちなんで命名されています。\",\n  \"title\": \"ヒント\"\n}\n[/block]\nこのファイル(init.php)では、カテゴリーデータを取得する特定のクエリの前に呼び出される`get_category_data_pre `フックに接続しようとしていることを表しています。\n\n[Hooks baseツール](http://www.cs-cart.com/api)では、この他のフックについての情報を検索することが出来ます。\n[block:api-header]\n{\n  \"type\": \"basic\",\n  \"title\": \"データの取得: func.php\"\n}\n[/block]\nアドオンディレクトリ(*app/addons/advanced_addon* ) に*func.php* ファイルを作成します。このPHPファイルは、フックを埋め込むための関数を含んでいます。\n\n> *addons/advanced_addon/func.php*\n[block:code]\n{\n  \"codes\": [\n    {\n      \"code\": \"<?php\\n/***************************************************************************\\n*                                                                          *\\n*   (c) 2004 Vladimir V. Kalynyak, Alexey V. Vinokurov, Ilya M. Shalnev    *\\n*                                                                          *\\n* This  is  commercial  software,  only  users  who have purchased a valid *\\n* license  and  accept  to the terms of the  License Agreement can install *\\n* and use this program.                                                    *\\n*                                                                          *\\n****************************************************************************\\n* PLEASE READ THE FULL TEXT  OF THE SOFTWARE  LICENSE   AGREEMENT  IN  THE *\\n* \\\"copyright.txt\\\" FILE PROVIDED WITH THIS DISTRIBUTION PACKAGE.            *\\n****************************************************************************/\\n\\nif (!defined('BOOTSTRAP')) { die('Access denied'); }\\n\\nfunction fn_advanced_addon_get_category_data_pre($category_id, $field_list, $get_main_pair, $skip_company_condition, $lang_code)\\n{\\n    //ログイン中のユーザーIDをセッションから取得する\\n    $auth = $_SESSION['auth'];\\n    \\n    //ログイン中のユーザーがストアフロントにいるかどうかの判定\\n    if (!empty($auth['user_id']) && AREA == 'C') {\\n        //データベースにユーザーのデータが存在するかチェック\\n        //必要に応じてアクセスデータを作成\\n        $viewed_categories = db_get_field('SELECT categories FROM ?:advanced_addon_data WHERE user_id = ?i', $auth['user_id']);\\n        \\n        if (!empty($viewed_categories)) {\\n            $viewed_categories = unserialize($viewed_categories);\\n        }\\n        \\n        $viewed_categories[$category_id] = true;\\n        $viewed_categories = serialize($viewed_categories);\\n        \\n        //データベースに書き込む\\n        db_query('REPLACE INTO ?:advanced_addon_data VALUES (?i, ?s)', $auth['user_id'], $viewed_categories);\\n    }\\n}\",\n      \"language\": \"php\"\n    }\n  ]\n}\n[/block]\n[func.php ダウンロード](https://gist.github.com/cscartjp/0f4588e1667a21bbeb00):\n\n関数`fn_advanced_addon_get_category_data_pre()` は現在表示されているカテゴリーを取得し、ストアを閲覧している人とリンクしてこのデータベースを格納します。\n[block:callout]\n{\n  \"type\": \"success\",\n  \"body\": \"PHPコード・フックの関数名は命名規則に従って書いて下さい:\\n\\n**fn_** + [**addon id**] +**_**+ [**hook name**]\\n\\n命名規則が正しくない関数は無視されます。\",\n  \"title\": \"ヒント\"\n}\n[/block]\n\n[block:api-header]\n{\n  \"type\": \"basic\",\n  \"title\": \"管理パネルにデータを表示する(index.post.tpl, index.post.php)\"\n}\n[/block]\n管理パネルに取り出したデータを表示するためには、管理パネルのダッジュボードテンプレート(*design/backend/templates/views/index/index.tpl* )のフックを利用して新しいデータブロックを表示します。\n\n1. *design/backend/templates/addons* ディレクトリに移動し、*advanced_addon* ディレクトリを作成してください。\n2. このディレクトリにサブディレクトリとして*hooks*を作成し、さらにその中に*index*ディレクトリを作成します。\n3. このディレクトリ(*design/backend/templates/addons/advanced_addon/hooks/index*)に次の内容を含んだ *index.post.tpl* ファイルを作成します:\n\n> *design/backend/templates/addons/advanced_addon/hooks/index/index.post.tpl*\n[block:code]\n{\n  \"codes\": [\n    {\n      \"code\": \"<div class=\\\"dashboard-row-bottom\\\">\\n    <div class=\\\"dashboard-viewed-category\\\">\\n        <h4>Viewed categories</h4>\\n        <div class=\\\"dashboard-viewed-category-list\\\">\\n            {if $viewed_categories}\\n            <ul>\\n                {foreach from=$viewed_categories item=\\\"category_data\\\"}\\n                <li><strong><a href=\\\"{\\\"profiles.update?user_id=`$category_data.user_id`\\\"|fn_url}\\\">{$category_data.user_name}</a></strong>:&nbsp;\\n                    {foreach from=$category_data.categories key=\\\"category_id\\\" item=\\\"category_name\\\"}\\n                    <a href=\\\"{\\\"categories.update?category_id=`$category_id`\\\"|fn_url}\\\">{$category_name}</a>, \\n                    {/foreach}\\n                </li>\\n                {/foreach}\\n            </ul>\\n            {else}\\n            <ul>\\n                <li>No data found</li>\\n            </ul>\\n            {/if}\\n        </div>\\n    </div>\\n</div>\",\n      \"language\": \"php\"\n    }\n  ]\n}\n[/block]\n [ダウンロード](https://gist.github.com/cscartjp/3f95c6843c81eb4205bb)\n[block:callout]\n{\n  \"type\": \"success\",\n  \"body\": \"PHPコード・フックとは違い、テンプレート・フックは、他のファイルで宣言する必要はありません。\\n\\n適切な名前のついたディレクトリに適切に名前の付けられたテンプレートを置くだけで動作します。その条件は以下の通りです:\\n\\n- **design/backend/templates/addons/<addon name>/hooks** ・・・管理パネル用ディレクトリ\\n- **var/themes_repository/basic/templates/addons/<addon name>/hooks** ・・・ショップフロント用ディレクトリ\\n- **var/themes_repository/basic/mail/templates/addons/<addon name>/hooks** ・・・メールテンプレート用ディレクトリ\\n\\nさらに上記のディレクトリの中に次のような名称のテンプレートファイル(.tplファイル)を作成する必要があります。:  \\n**<template name>/<hook name>.[pre|post].tpl**\",\n  \"title\": \"ヒント\"\n}\n[/block]\nテンプレートファイルだけでは、データベースからデータを取得することはできません。これらの処理は、*index.php*のコントローラの「ポストコントローラ」で実行する必要があります。\n\n*app/addons/advanced_addon* ディレクトリに移動し、サブディレクトリ*controllers/backend* を作成します。\n\n作成したディレクトリで *index.post.php*という名称で下記の内容が書かれたPHPファイルを作成してください:\n\n> app/addons/advanced_addon/controllers/backend/index.post.php\n[block:code]\n{\n  \"codes\": [\n    {\n      \"code\": \"<?php\\n/***************************************************************************\\n*                                                                          *\\n*   (c) 2004 Vladimir V. Kalynyak, Alexey V. Vinokurov, Ilya M. Shalnev    *\\n*                                                                          *\\n* This  is  commercial  software,  only  users  who have purchased a valid *\\n* license  and  accept  to the terms of the  License Agreement can install *\\n* and use this program.                                                    *\\n*                                                                          *\\n****************************************************************************\\n* PLEASE READ THE FULL TEXT  OF THE SOFTWARE  LICENSE   AGREEMENT  IN  THE *\\n* \\\"copyright.txt\\\" FILE PROVIDED WITH THIS DISTRIBUTION PACKAGE.            *\\n****************************************************************************/\\n\\nuse Tygh\\\\Registry;\\n\\nif (!defined('BOOTSTRAP')) { die('Access denied'); }\\n\\n$viewed_categories = db_get_array('SELECT * FROM ?:advanced_addon_data');\\n\\nif (!empty($viewed_categories)) {\\n    foreach ($viewed_categories as $key => $category_data) {\\n        $category_data['user_name'] = fn_get_user_name($category_data['user_id']);\\n        $category_data['categories'] = unserialize($category_data['categories']);\\n        $category_data['categories']  = fn_get_category_name(array_keys($category_data['categories']));\\n\\n        $viewed_categories[$key] = $category_data;\\n    }\\n\\n    Registry::get('view')->assign('viewed_categories', $viewed_categories);\\n}\",\n      \"language\": \"php\"\n    }\n  ]\n}\n[/block]\n[ダウンロード](https://gist.github.com/cscartjp/0e5b7525a12fe6e23fed)\n\nすべてのファイルパスや名前、ファイルの内容が正常に作動することをよく確認して下さい。\n[block:api-header]\n{\n  \"type\": \"basic\",\n  \"title\": \"動作確認\"\n}\n[/block]\nファイルをアップロード後、まずはアドオンを確認します。\nCS-Cartの管理パネルの*アドオン→アドオン管理*に移動します。\n\nリストから**Advanced Add-on**を探し、アドオン名の近くにある【**インストール**】をクリックします。\n[block:image]\n{\n  \"images\": [\n    {\n      \"image\": [\n        \"https://files.readme.io/AtlKIfU4Tyeca7W5mdCg_advc_installed.png\",\n        \"advc_installed.png\",\n        \"616\",\n        \"171\",\n        \"#518a62\",\n        \"\"\n      ]\n    }\n  ]\n}\n[/block]\nインストールが無事に完了すると通知が表示されます。\n\nダッジュボードに移動して、ページの下部を確認して下さい。\n以下の画像に似た新しいセクションが表示されているはずです。\n[block:image]\n{\n  \"images\": [\n    {\n      \"image\": [\n        \"https://files.readme.io/pJ8psw3ISIiC263Cqguk_advdbd.png\",\n        \"advdbd.png\",\n        \"552\",\n        \"332\",\n        \"#a62021\",\n        \"\"\n      ]\n    }\n  ]\n}\n[/block]\nご覧の通り、これといったデータはありませんがダッシュボードに新しいセクションが表示されました。\n\nブラウザをショップフロントに切り替えて、お客様としてログインしてストア内をいろいろ検索してみてください。ランダムにカテゴリーを表示するだけでも結構です。さらに、これとは異なるユーザーアカウントでも同じように試してみてください。\n\n管理パネルのダッシュボードページをリロードし、**Viewed categories**の状態を確認してください:\n[block:image]\n{\n  \"images\": [\n    {\n      \"image\": [\n        \"https://files.readme.io/IpiVCbrSQUmPQublGvKl_advc.png\",\n        \"advc.png\",\n        \"599\",\n        \"425\",\n        \"#346080\",\n        \"\"\n      ]\n    }\n  ]\n}\n[/block]\nこのセクションにはあなたが閲覧したカテゴリーが表示されているはずです。\n[block:api-header]\n{\n  \"type\": \"basic\",\n  \"title\": \"独自のスタイルを適用する\"\n}\n[/block]\n管理パネルのデザインに合わせて作成したアドオンから特別なCSSを読み込む方法を説明します。\n\n1. CSS(.less)を作成する。\n2. 1で作成したファイルを読み込むテンプレートフックを作成する。\n\n## このアドオンから利用するCSS(.less)は以下のディレクトリに作成します。\n> /design/backend/css/addons/advanced_addon/styles.less\n(ファイル名は自由に決めることが出来ます。)\n[block:code]\n{\n  \"codes\": [\n    {\n      \"code\": \".dashboard-viewed-category{\\n    margin-top: 32px;\\n    width: 50%;\\n    \\n    .dashboard-viewed-category-list{\\n        padding: 8px 0;\\n        -webkit-border-radius: 4px;\\n        -moz-border-radius: 4px;\\n        border-radius: 4px;\\n        overflow-y: scroll;\\n        min-height: 200px;\\n        max-height: 290px;\\n        overflow-y: auto;\\n        border: 1px solid #eee;\\n        background: #fcfcfc;\\n        \\n        \\n        ul{\\n            margin: 0;\\n            list-style: none;\\n            \\n            li{\\n                padding: 7px 10px;\\n                border-top: 1px solid #eee;\\n            }\\n            \\n            li:first-child{\\n               border: none; \\n            }\\n        }\\n    }\\n}\",\n      \"language\": \"css\"\n    }\n  ]\n}\n[/block]\n[ダウンロード](https://gist.github.com/cscartjp/15bdd1d147a83a8284ff)\n\n\n## CSSを読み込むテンプレートフックのファイルを作成する。\n> /design/backend/templates/addons/advanced_addon/hooks/index/styles.post.tpl\n\nファイルの中には以下のようにします。\nこれで1で作成したファイルを読み込むHTMLソースが書き出されます。\n[block:code]\n{\n  \"codes\": [\n    {\n      \"code\": \"{style src=\\\"addons/advanced_addon/styles.less\\\"}\",\n      \"language\": \"php\"\n    }\n  ]\n}\n[/block]\nテンプレートキャッシュをクリアし、再度ダッシュボードを表示してください。\nこのようにアドオンで使用するCSSファイルやJavascriptファイルを作成し、読み込むことが出来ます。\n[block:image]\n{\n  \"images\": [\n    {\n      \"image\": [\n        \"https://files.readme.io/2LGmbVzUTleSBmwvxO9l_advcfinal.png\",\n        \"advcfinal.png\",\n        \"693\",\n        \"349\",\n        \"#277caf\",\n        \"\"\n      ]\n    }\n  ]\n}\n[/block]","excerpt":"","slug":"advanced-add-on-tutorial","type":"basic","title":"Advanced Add-on チュートリアル"}

Advanced Add-on チュートリアル


このチュートリアルでは [**フック**](doc:hooking) や[**Pre- and Post- コントローラー**](doc:pre-and-post-controllers) を使用するような高度なテクニックのアドオン作成方法を説明します。 [block:callout] { "type": "info", "body": "*フック*はとてもパワフルな技術で、CS-Cartではこれが多用されています。\n\nPHPフックは追加の処理をデフォルト処理の前後で実行する、またはデフォルトの処理ルーチーンをオーバーライド(上書き)するために使用されます。\n\nテンプレートフックはテンプレートのレンダリングを処理するため使用します。例えば、オリジナルテンプレートを修正することなく、追加データを表示したりすることが可能です。\n\nプレまたはポストコントローラーは特別なPHPファイル(アドオンディレクトリ内に置かれたファイルの名前による)で、特定のコントローラーが実行される前か後に呼び出されます。", "title": "情報" } [/block] このチュートリアルでは [PHPフック](doc:php-hooks) と [テンプレートフック](doc:tpl-hooks) の両方を使うアドオンを作成します。 このチュートリアルで作成するアドオンはログイン済みのユーザーが閲覧したカテゴリーの情報を収集します。さらに、ユーザーが閲覧したカテゴリーのアクセス数を管理パネルのダッシュボードに表として表示します。 [block:api-header] { "type": "basic", "title": "必要環境" } [/block] このチュートリアルを行うためは、インストールされたCS-Carが必要になります。公式サイトからCS-Cartを[ダウンロード](http://cs-cart.jp/)し、フリーモードで使用してください。 **PHPやSmarty、CS-Cartアドオンディレクトリ構造に慣れることが重要です。** このチュートリアルを進める前に [「Hello World」Addonチュートリアル](doc:hello-world-add-on-tutorial) を先に行うことをお勧めします。 [block:api-header] { "type": "basic", "title": "アドオン初期設定: addon.xmlとinit.phpの作成" } [/block] インストールしたCS-Cartのルートディレクトリ内の*app/addons* ディレクトリに移動し、*advanced_addon*というサブディレクトリを作成します。 このディレクトリに以下の内容を含んだaddon.xml ファイルを作成します: *addons/advanced_addon/addon.xml* [block:code] { "codes": [ { "code": "<?xml version=\"1.0\"?>\n<addon scheme=\"3.0\">\n <id>advanced_addon</id>\n <version>1.0</version>\n <priority>100500</priority>\n <position>0</position>\n <status>active</status>\n <default_language>ja</default_language>\n <queries>\n <item>DROP TABLE IF EXISTS ?:advanced_addon_data;</item>\n <item>\n CREATE TABLE `?:advanced_addon_data` (\n `user_id` int(11) unsigned NOT NULL DEFAULT 0,\n `categories` text NOT NULL DEFAULT '',\n PRIMARY KEY (`user_id`)\n ) Engine=MyISAM DEFAULT CHARSET UTF8;\n </item>\n <item for=\"uninstall\">DROP TABLE IF EXISTS ?:advanced_addon_data;</item>\n </queries>\n</addon>", "language": "xml" } ] } [/block] [addon.xml ダウンロード](https://gist.github.com/cscartjp/fa514bef48ca4bdea551) これに対応する言語ファイルは以下となります。 > /var/langs/ja/addons/advanced_addon.po [block:code] { "codes": [ { "code": "msgid \"\"\nmsgstr \"Project-Id-Version: tygh\"\n\"Content-Type: text/plain; charset=UTF-8\\n\"\n\"Language-Team: Japanese\\n\"\n\"Language: ja_JP\\n\"\n\nmsgctxt \"Addons::name::advanced_addon\"\nmsgid \"Advanced Add-on\"\nmsgstr \"アドバンスド・アドオン\"\n\nmsgctxt \"Addons::description::advanced_addon\"\nmsgid \"This is Advanced Add-on tutolial.\"\nmsgstr \"アドオンの学習を行います。\"", "language": "c", "name": null } ] } [/block] [advanced_addon.po ダウンロード](https://gist.github.com/cscartjp/fa514bef48ca4bdea551) --------------------- さらに同じディレクトリに以下の内容を含んだ*init.php*ファイルを作成します。 > addons/advanced_addon/init.php [block:code] { "codes": [ { "code": "<?php\n/***************************************************************************\n* *\n* (c) 2004 Vladimir V. Kalynyak, Alexey V. Vinokurov, Ilya M. Shalnev *\n* *\n* This is commercial software, only users who have purchased a valid *\n* license and accept to the terms of the License Agreement can install *\n* and use this program. *\n* *\n****************************************************************************\n* PLEASE READ THE FULL TEXT OF THE SOFTWARE LICENSE AGREEMENT IN THE *\n* \"copyright.txt\" FILE PROVIDED WITH THIS DISTRIBUTION PACKAGE. *\n****************************************************************************/\n\nif (!defined('BOOTSTRAP')) { die('Access denied'); }\n\nfn_register_hooks(\n 'get_category_data_pre'\n);\n", "language": "php" } ] } [/block] [init.php ダウンロード](https://gist.github.com/cscartjp/8aaee0a0ea7b46b026fe): [block:callout] { "type": "success", "body": "通常、関数名はひと目で分かるように書かれています。\n(例えば、`get_product`は”一つの”商品情報を取得する関数です)\n\nフックは通常、 (例えばget_products_preとget_products_post )名称に応じて前処理や後処理のフックのために`_pre`または`_post`という接尾辞が付いていて、中に置かれている機能にちなんで命名されています。", "title": "ヒント" } [/block] このファイル(init.php)では、カテゴリーデータを取得する特定のクエリの前に呼び出される`get_category_data_pre `フックに接続しようとしていることを表しています。 [Hooks baseツール](http://www.cs-cart.com/api)では、この他のフックについての情報を検索することが出来ます。 [block:api-header] { "type": "basic", "title": "データの取得: func.php" } [/block] アドオンディレクトリ(*app/addons/advanced_addon* ) に*func.php* ファイルを作成します。このPHPファイルは、フックを埋め込むための関数を含んでいます。 > *addons/advanced_addon/func.php* [block:code] { "codes": [ { "code": "<?php\n/***************************************************************************\n* *\n* (c) 2004 Vladimir V. Kalynyak, Alexey V. Vinokurov, Ilya M. Shalnev *\n* *\n* This is commercial software, only users who have purchased a valid *\n* license and accept to the terms of the License Agreement can install *\n* and use this program. *\n* *\n****************************************************************************\n* PLEASE READ THE FULL TEXT OF THE SOFTWARE LICENSE AGREEMENT IN THE *\n* \"copyright.txt\" FILE PROVIDED WITH THIS DISTRIBUTION PACKAGE. *\n****************************************************************************/\n\nif (!defined('BOOTSTRAP')) { die('Access denied'); }\n\nfunction fn_advanced_addon_get_category_data_pre($category_id, $field_list, $get_main_pair, $skip_company_condition, $lang_code)\n{\n //ログイン中のユーザーIDをセッションから取得する\n $auth = $_SESSION['auth'];\n \n //ログイン中のユーザーがストアフロントにいるかどうかの判定\n if (!empty($auth['user_id']) && AREA == 'C') {\n //データベースにユーザーのデータが存在するかチェック\n //必要に応じてアクセスデータを作成\n $viewed_categories = db_get_field('SELECT categories FROM ?:advanced_addon_data WHERE user_id = ?i', $auth['user_id']);\n \n if (!empty($viewed_categories)) {\n $viewed_categories = unserialize($viewed_categories);\n }\n \n $viewed_categories[$category_id] = true;\n $viewed_categories = serialize($viewed_categories);\n \n //データベースに書き込む\n db_query('REPLACE INTO ?:advanced_addon_data VALUES (?i, ?s)', $auth['user_id'], $viewed_categories);\n }\n}", "language": "php" } ] } [/block] [func.php ダウンロード](https://gist.github.com/cscartjp/0f4588e1667a21bbeb00): 関数`fn_advanced_addon_get_category_data_pre()` は現在表示されているカテゴリーを取得し、ストアを閲覧している人とリンクしてこのデータベースを格納します。 [block:callout] { "type": "success", "body": "PHPコード・フックの関数名は命名規則に従って書いて下さい:\n\n**fn_** + [**addon id**] +**_**+ [**hook name**]\n\n命名規則が正しくない関数は無視されます。", "title": "ヒント" } [/block] [block:api-header] { "type": "basic", "title": "管理パネルにデータを表示する(index.post.tpl, index.post.php)" } [/block] 管理パネルに取り出したデータを表示するためには、管理パネルのダッジュボードテンプレート(*design/backend/templates/views/index/index.tpl* )のフックを利用して新しいデータブロックを表示します。 1. *design/backend/templates/addons* ディレクトリに移動し、*advanced_addon* ディレクトリを作成してください。 2. このディレクトリにサブディレクトリとして*hooks*を作成し、さらにその中に*index*ディレクトリを作成します。 3. このディレクトリ(*design/backend/templates/addons/advanced_addon/hooks/index*)に次の内容を含んだ *index.post.tpl* ファイルを作成します: > *design/backend/templates/addons/advanced_addon/hooks/index/index.post.tpl* [block:code] { "codes": [ { "code": "<div class=\"dashboard-row-bottom\">\n <div class=\"dashboard-viewed-category\">\n <h4>Viewed categories</h4>\n <div class=\"dashboard-viewed-category-list\">\n {if $viewed_categories}\n <ul>\n {foreach from=$viewed_categories item=\"category_data\"}\n <li><strong><a href=\"{\"profiles.update?user_id=`$category_data.user_id`\"|fn_url}\">{$category_data.user_name}</a></strong>:&nbsp;\n {foreach from=$category_data.categories key=\"category_id\" item=\"category_name\"}\n <a href=\"{\"categories.update?category_id=`$category_id`\"|fn_url}\">{$category_name}</a>, \n {/foreach}\n </li>\n {/foreach}\n </ul>\n {else}\n <ul>\n <li>No data found</li>\n </ul>\n {/if}\n </div>\n </div>\n</div>", "language": "php" } ] } [/block] [ダウンロード](https://gist.github.com/cscartjp/3f95c6843c81eb4205bb) [block:callout] { "type": "success", "body": "PHPコード・フックとは違い、テンプレート・フックは、他のファイルで宣言する必要はありません。\n\n適切な名前のついたディレクトリに適切に名前の付けられたテンプレートを置くだけで動作します。その条件は以下の通りです:\n\n- **design/backend/templates/addons/<addon name>/hooks** ・・・管理パネル用ディレクトリ\n- **var/themes_repository/basic/templates/addons/<addon name>/hooks** ・・・ショップフロント用ディレクトリ\n- **var/themes_repository/basic/mail/templates/addons/<addon name>/hooks** ・・・メールテンプレート用ディレクトリ\n\nさらに上記のディレクトリの中に次のような名称のテンプレートファイル(.tplファイル)を作成する必要があります。: \n**<template name>/<hook name>.[pre|post].tpl**", "title": "ヒント" } [/block] テンプレートファイルだけでは、データベースからデータを取得することはできません。これらの処理は、*index.php*のコントローラの「ポストコントローラ」で実行する必要があります。 *app/addons/advanced_addon* ディレクトリに移動し、サブディレクトリ*controllers/backend* を作成します。 作成したディレクトリで *index.post.php*という名称で下記の内容が書かれたPHPファイルを作成してください: > app/addons/advanced_addon/controllers/backend/index.post.php [block:code] { "codes": [ { "code": "<?php\n/***************************************************************************\n* *\n* (c) 2004 Vladimir V. Kalynyak, Alexey V. Vinokurov, Ilya M. Shalnev *\n* *\n* This is commercial software, only users who have purchased a valid *\n* license and accept to the terms of the License Agreement can install *\n* and use this program. *\n* *\n****************************************************************************\n* PLEASE READ THE FULL TEXT OF THE SOFTWARE LICENSE AGREEMENT IN THE *\n* \"copyright.txt\" FILE PROVIDED WITH THIS DISTRIBUTION PACKAGE. *\n****************************************************************************/\n\nuse Tygh\\Registry;\n\nif (!defined('BOOTSTRAP')) { die('Access denied'); }\n\n$viewed_categories = db_get_array('SELECT * FROM ?:advanced_addon_data');\n\nif (!empty($viewed_categories)) {\n foreach ($viewed_categories as $key => $category_data) {\n $category_data['user_name'] = fn_get_user_name($category_data['user_id']);\n $category_data['categories'] = unserialize($category_data['categories']);\n $category_data['categories'] = fn_get_category_name(array_keys($category_data['categories']));\n\n $viewed_categories[$key] = $category_data;\n }\n\n Registry::get('view')->assign('viewed_categories', $viewed_categories);\n}", "language": "php" } ] } [/block] [ダウンロード](https://gist.github.com/cscartjp/0e5b7525a12fe6e23fed) すべてのファイルパスや名前、ファイルの内容が正常に作動することをよく確認して下さい。 [block:api-header] { "type": "basic", "title": "動作確認" } [/block] ファイルをアップロード後、まずはアドオンを確認します。 CS-Cartの管理パネルの*アドオン→アドオン管理*に移動します。 リストから**Advanced Add-on**を探し、アドオン名の近くにある【**インストール**】をクリックします。 [block:image] { "images": [ { "image": [ "https://files.readme.io/AtlKIfU4Tyeca7W5mdCg_advc_installed.png", "advc_installed.png", "616", "171", "#518a62", "" ] } ] } [/block] インストールが無事に完了すると通知が表示されます。 ダッジュボードに移動して、ページの下部を確認して下さい。 以下の画像に似た新しいセクションが表示されているはずです。 [block:image] { "images": [ { "image": [ "https://files.readme.io/pJ8psw3ISIiC263Cqguk_advdbd.png", "advdbd.png", "552", "332", "#a62021", "" ] } ] } [/block] ご覧の通り、これといったデータはありませんがダッシュボードに新しいセクションが表示されました。 ブラウザをショップフロントに切り替えて、お客様としてログインしてストア内をいろいろ検索してみてください。ランダムにカテゴリーを表示するだけでも結構です。さらに、これとは異なるユーザーアカウントでも同じように試してみてください。 管理パネルのダッシュボードページをリロードし、**Viewed categories**の状態を確認してください: [block:image] { "images": [ { "image": [ "https://files.readme.io/IpiVCbrSQUmPQublGvKl_advc.png", "advc.png", "599", "425", "#346080", "" ] } ] } [/block] このセクションにはあなたが閲覧したカテゴリーが表示されているはずです。 [block:api-header] { "type": "basic", "title": "独自のスタイルを適用する" } [/block] 管理パネルのデザインに合わせて作成したアドオンから特別なCSSを読み込む方法を説明します。 1. CSS(.less)を作成する。 2. 1で作成したファイルを読み込むテンプレートフックを作成する。 ## このアドオンから利用するCSS(.less)は以下のディレクトリに作成します。 > /design/backend/css/addons/advanced_addon/styles.less (ファイル名は自由に決めることが出来ます。) [block:code] { "codes": [ { "code": ".dashboard-viewed-category{\n margin-top: 32px;\n width: 50%;\n \n .dashboard-viewed-category-list{\n padding: 8px 0;\n -webkit-border-radius: 4px;\n -moz-border-radius: 4px;\n border-radius: 4px;\n overflow-y: scroll;\n min-height: 200px;\n max-height: 290px;\n overflow-y: auto;\n border: 1px solid #eee;\n background: #fcfcfc;\n \n \n ul{\n margin: 0;\n list-style: none;\n \n li{\n padding: 7px 10px;\n border-top: 1px solid #eee;\n }\n \n li:first-child{\n border: none; \n }\n }\n }\n}", "language": "css" } ] } [/block] [ダウンロード](https://gist.github.com/cscartjp/15bdd1d147a83a8284ff) ## CSSを読み込むテンプレートフックのファイルを作成する。 > /design/backend/templates/addons/advanced_addon/hooks/index/styles.post.tpl ファイルの中には以下のようにします。 これで1で作成したファイルを読み込むHTMLソースが書き出されます。 [block:code] { "codes": [ { "code": "{style src=\"addons/advanced_addon/styles.less\"}", "language": "php" } ] } [/block] テンプレートキャッシュをクリアし、再度ダッシュボードを表示してください。 このようにアドオンで使用するCSSファイルやJavascriptファイルを作成し、読み込むことが出来ます。 [block:image] { "images": [ { "image": [ "https://files.readme.io/2LGmbVzUTleSBmwvxO9l_advcfinal.png", "advcfinal.png", "693", "349", "#277caf", "" ] } ] } [/block]