背景が黒いページは『アングラ』?いいえ『エコ』です。

背景やページ全体が黒ベースのウェブサイト。さらにテキストベースで構成されているとパッと見、アングラサイトに見えてしまいます。

真っ黒な背景に白いテキスト、時々赤文字で強調されていると何かイケナイ事を書いてあるんじゃないかと不安になってしまうかも。

ところが、そんなイメージとはウラハラに実はとっても“エコ” だったという話。

背景が黒い「Black Google」は地球を救う – GIGAZINE

ウェブページにはさまざまな色が用いられていますが、なんと表示する色によって消費電力が異なるそうです。たとえばGoogleの背景が黒になっただけで、下がる消費電力はかなりのものだとか。だいたい年間30万ドルほどだそうです。

GIGAZINEの引用元から再計算してみました。

黒ページ 白ページ 黒ページにすると・・
消費電力 59W 74W -15W
10秒間 0.1638W 0.2055W -0.0417W
2億PV 32.76MWh 41.10MWh -8.34MWh
21.62円/kWh 708,271円 888,582円 -180,311円
1年間(365日) 258,518,915円 324,332,430円 -65,813,515円

電気量単価は、使用料や契約によって変わるのですが、それぞれの単価の「高い料金」を足して平均値として「21.62円/kWh」としました。

Googleの検索ページの表示が約10秒間。
Googleの1日当たりのPVが約2億PV。

1年間で 6581万3515円 も節約できてしまうんですね!

てな結果があるわけで、当ブログも エコな ブラックテーマなんです。

【注意】
GoogleのPV2億というのは、Google全体のことなので、6500万円の節約も世界全体で年間6500万円という事です。投稿日現在の世界の人口が 約67億3000万人 なので、年間一人当たり 0.9銭 の節約になります。
(´・ω・`)ショボーン

more_information はいらない子?

Zen Cart には、固定ページを作成するために Information と more_information という二つのサイドボックスが用意されているのですが。

S-Page さんの WordPress on ZenCart を使うようになってからは、more_information は「いらない子」なのかなと思うようになってきています。

Zen Cart のサイドボックス「more_information」でページを追加するには、languages、modules、templates、html_includesと、いくつものファイルを更新・追加しなければいけないのですが、WordPress on ZenCart を入れておけば、WordPress側でページ追加するだけで、いとも簡単にページ追加できちゃいます。

項目の並べ替えも、WordPress 側で制御できるので、メンテナンスも楽々です。

MODxの時(WordPress Integrator)は、WordPress のページを表示するのに、不安定な部分があり、大丈夫かなと思ったのですが、この WordPress on ZenCart は、非常に動作も安定していて安心して使えてます。

※WordPress Integrator では、MODx で404エラーの場合に WordPress を読み込むトリガーを動かしていたのですが、この404エラーを判別するパースタイムがサーバーによって、非常に遅かったりすることがある。

一般価格と会員価格 Zen Cart [Group Pricing(per Item)]

ゲストユーザーには、一般小売価格を表示しておき、会員登録すると「会員向けの価格」を表示。

日本語フォーラムでも何度か取り上げられていた話題ですが、本家Zen Cart .comの方に、いい感じのモジュールがあったので、日本語ファイルをつくってみた。

Group Pricing (per Item)

モジュール概要

  • 割引グループを機能拡張
    Group Pricing用の割引グループを4つまで設定可能。
    デフォルトでは、グループごとに割引%での設定しかできなかったのが「グループごとの『会員価格』」を「商品ごと」に設定できるようになります。
  • 商品価格の項目拡張
    商品価格の設定をデフォルトの1個の他に、割引グループごとに4個の設定項目を追加。 「これがやりたかった」まさにそんな機能!商品に複数の価格を設定でき、割引グループに応じて表示価格を設定できます。

インストール自体は、割と簡単。おまけにアンインストール用のSQLも付属しているので、安心感(信頼感)高いです。
(国産リソースには、まだこの辺が足りなくて、アンインストールに四苦八苦する事が多い)

ただし、今現在のバージョン(V.1.3.1)は、最近のMySQLインジェクション関係のパッチが当たってないので、その辺をZen Cart に導入済みの物と比較して編集が必要です。

私の場合、ゲスト購入モジュールも導入しているので、ゲストには、「一般価格で販売」会員には、「会員価格で販売」ができるように、登録時のデフォルトグループを Group Pricing の割引グループになるように修正。

登録時のデフォルト割引グループ設定

includes/modules/YOUR_TEMPLATE/create_account.php

zen_db_perform(TABLE_CUSTOMERS, $sql_data_array);

という行の直前に、

$sql_data_array[‘customers_group_pricing’] = 1;

の行を追加。(1は、設定したい割引グループID)

結果、サイトの表示は・・

(ゲスト(未ログイン)の時)
Ci081018194135 
一般価格:29,800円
会員価格:ログインして下さい。

(会員ログインしている時)
Ci081018194208 
一般価格:29,800円
会員価格:22,000円

なんて感じの表現が可能になりました。
(ログイン時の「一般価格」を表示するには、function_price.php をちょこっといじる必要があります)

管理画面ではこんな感じ

Ci081022155500

一般価格の下に4種類の会員価格設定欄があるのが分かると思います。
これが、それぞれの割引グループでログインした際の商品価格になります。

インストールしたベースの Zen Cart は bigmouse さんとこの Zen Cart v.1.3.8a です。

Zen Cart でのリンクを記述する方法(おさらい)

Zen Cart 内でリンクを記述する時は、 html_output.php にある zen_href_link() を使用します。

HTMLテンプレート内に記述する方法は、以下の通り。

<?php echo zen_href_link(‘PAGENAME’,’QUERYSTRING’,'{SSL | NONSSL}’); ?>

  • PAGENAME
    ページ名、Zen Cart 内のURLでいうと、/index.php?main_page=contact_us の「contact_us」の部分。
    ちなみに、filenames.php などで、定数(define(‘FILENAME_***’,’***’); とか)が指定されている場合は、定数を記述する事も可能。
  • QUERYSTRING
    zen_href_link ファンクションで展開されたURLの最後にQUERYSTRINGを追加する場合に使用。
    例えば、指定したページの<a name="link1"></a>にページ内リンクしたい場合に「#link1」と記述しておく。
  • {SSL | NONSSL}
    SSL が有効な場合に SSL でアクセスするかどうか。
    NONSSL を指定した場合は、常に http:// でリンクする事になり、 SSL を指定すれば、SSL が有効な場合に https:// でリンクするようになる。

例1: 利用規約ページ(conditions)の第5条(<a name="jou_5">)にリンクする場合。

<a href="<?php echo zen_href_link(‘conditions’,’#jou_5′,’NONSSL’); ?>">利用規約 第5条</a>

例2: ログインページ(login)にリンクする場合。

<a href="<?php echo zen_href_link(‘login’,”,’SSL’); ?>">ログインはこちら</a>

例3: ページ内リンクするだけなら、こういった方法も

<a href="<?php echo zen_href_link(‘conditions’,”,’NONSSL’); ?>#jou_5">利用規約 第5条</a>

インフォメーションに項目追加

ZenCartには、「インフォメーション」と「追加情報」があり、「定番ページの編集」でページの編集ができます。

今回は、S-Pageのhiraさんの「定番ページのタイトルの編集モジュール」を使いつつ、インフォメーションに項目を追加してみます。

今回は、aboutus というページを作ってみます。
URLはhttp://~~~~~.com/index.php?main_page=aboutus といった感じに。

includes/modules/pages/aboutus/header_php.php を作成
header_php.php 内の FILENAME_DEFINE_***** を変更。
$define_page = zen_get_file_directory(DIR_FS_DEFINE_PAGES_DATA . $_SESSION[‘language’] . ‘/html_includes/’, FILENAME_DEFINE_ABOUTUS, ‘false’);

includes/modules/sideboxes/YOUR_TEMPLATE/information.php を編集。
if(DEFINE_TITLE_INFORMATION_ABOUTUS != ”){
$information[] = ‘<a href="’ . zen_href_link(FILENAME_ABOUTUS) . ‘">’ . DEFINE_TITLE_INFORMATION_ABOUTUS . ‘</a>’;
}
適当なところに記述するのですが、メニューの並び替えもここで記述された順になるので、サイトのメニューレイアウトに合わせて編集。

includes/languages/japanese/extra_definitions/YOUR_TEMPLATE/define_title.php を編集。
define(‘DEFINE_TITLE_INFORMATION_ABOUTUS’, $define_title[‘define_aboutus.php’]);

includes/languages/japanese/html_includes/YOUR_TEMPLATE/define_aboutus.php を作成
(内容は管理画面で編集するので、とりあえずこのまま)

includes/languages/japanese/html_includes/define_aboutus.php も作成。
YOUR_TEMPLATE でオーバーライドするのですが、html_includes 直下にもファイルを置いておかないと管理画面(admin)でリスト表示されません。
※html_includes 以下のファイルは、パーミッション(ファイル属性)を666に設定忘れずに!

includes/languages/japanese/YOUR_TEMPLATE/aboutus.php を作成
define(‘NAVBAR_TITLE’, DEFINE_TITLE_INFORMATION_ABOUTUS);
define(‘HEADING_TITLE’, $ini_heading_title[‘define_aboutus.php’]);
define(‘TEXT_INFORMATION’, ”);

includes/extra_datafiles/extra_filename.php を編集。
define(‘FILENAME_ABOUTUS’, ‘aboutus’);
define(‘FILENAME_DEFINE_ABOUTUS’, ‘define_aboutus’);

includes/extra_datafiles/define_titles_data/ 以下のファイルを編集。
[define_titles.php]
define_abutus.php="会社概要"
[define_headings.php]
define_aboutus.php="運営会社について"
englishフォルダも内容に応じて編集、今回は日本語のみの運用なので、japaneseフォルダのみ。

includes/templates/YOUR_TEMPLATE/templates/tpl_aboutus_default.php を編集。

【まとめ】 ★・・既存ファイル更新 ☆・・新規作成

/includes
├ /extra_datafiles/extra_filename.php ★
│ ├ /define_titles_data/japanese/define_titles.php ★
│ └ /define_titles_data/japanese/define_heading_title.php ★
├ /languages
├ └/japanese
├ ├ /extra_definitions/YOUR_TEMPLATE/define_titles.php ★
├ ├ /html_includes/define_aboutus.php ☆
├ ├ /html_includes/YOUR_TEMPLATE/define_aboutus.php ☆
├ └ /YOUR_TEMPLATE/aboutus.php ☆
├ /modules
├ ├ /pages/aboutus/header_php.php ☆
├ └ /sideboxes/YOUR_TEMPLATE/information.php ★
└ /templates/YOUR_TEMPLATE/templates/tpl_aboutus_default.php ☆

今回は、「インフォメーション」に項目を追加したのですが、「追加情報(more_information)」に項目を追加したい場合は、/modules/sideboxes/information.php を more_information.php に置き換えて編集すればOKだと思います。

追記::
定番ページ関連で、これも使える。
WordPressの「最近の投稿」をZen-Cartの定番ページに表示する方法