Node.js based smart shopping cart app

Information

In this page, there is English description followed by Japanese one.
本ページは英語の説明の後に日本語の説明が続きます。

Getting Started

Installing Node.js and npm

You need to have Node.js and npm installed.

To check if you have them installed, open a terminal or command prompt and run the following commands:

node --version
npm --version

If you see an number output similar to x.x.x for each command, then they are both installed and you can continue to the next section.

To install on Windows or mac, you can download the installer from https://nodejs.org/en/download.

To install on Linux, you can use a package manager. Instructions for installing Node.js on your distribution can be found in the following link:
https://nodejs.org/en/download/package-manager

Prerequisite

This example assumes that you've already run the following program that can communicate the decoded result of barcode data with mbed Device Connector:

Import programGR-PEACH_mbed-os-client-ZXingSample

Fork of https://developer.mbed.org/teams/Renesas/code/GR-PEACH_mbed-os-client-ZXingSample/

Configuring the Applition

In order to run this app, you need to set up the options shown below via .env file stored in the folder GR-PEACH_mbed-os-QRCode-ShoppingCart-node which should be automatically created when cloning this program.

  • ACCESS_KEY
    Set this variable to your Access Key that you can create on mbed Device Connector. if you don't have an Access Key yet, please create it in accordance with the following procedure.
    1. Access https://connector.mbed.com/#accesskeys.
    2. Click CREATE NEW ACCESS KEY.
    /media/uploads/HinoNaka/screenshot7.png
    3. When prompted, enter a name for the access key (e.g. "demo") and click ADD.
    /media/uploads/HinoNaka/screenshot8.png

    After an access key is successfully created, please copy the access key you just created and use it in .env file as follows:

.env

ACCESS_KEY=...
  • PORT
    Set this variable as follows to override the default port for this example if needed. The default port is 8080.

.env

PORT=...

Also, user need to prepare for the comma-delimited list which includes "Item Name" and "Price" which is added to shopping cart, and save it by the name klist.txt as follows:
/media/uploads/HinoNaka/mbed_shoppingcart_fig8.png
The list should be stored in GR-Peach_mbed-os_QRCode_ShoppingCart_node\public\list.

Application Execution

This application consists of 2 tabs. One is Shopping Cart and the other is QR Code Login. In this section, it is described that how those work.

As mentioned above, GR-PEACH_mbed-os-client-ZXingSample should be executed beforehand. For details on how to set up and execute GR-PEACH_mbed-os-client-ZXingSample, please refer to https://developer.mbed.org/teams/Renesas/code/GR-PEACH_mbed-os-client-ZXingSample/. If the program works properly, you can see the following message in your terminal: /media/uploads/HinoNaka/mbed_shoppingcart_fig4.png

After it is confirmed that the program works properly, please follow the procedure below in order to execute this Web Application.

  • How to invoke this Web Application
    You can now run the application by invoking the following: /media/uploads/HinoNaka/shoppingcart_fig1.png
    Then, you should see the following message if the configuration is successfully done, :
    /media/uploads/HinoNaka/shoppingcart_fig2.png
    Please note that 8080 might be changed. It should depends on your PORT setting mentioned above. If you access the above URL using Web browser, you can see the following Smart Shopping Cart tab by default: /media/uploads/HinoNaka/mbed_shoppingcart_fig3.png

  • How Shopping Cart tab works
    When you decode QR code stored in GR-Peach_mbed-os_QRCode_ShoppingCart_node\qrcode by GR-PEACH successfully, the item should be added to shopping cart as follows:
    /media/uploads/HinoNaka/mbed_shoppingcart_fig5.png

  • How QR Code Login tab works
    When you choose QR Code Login tab, you can see the following screen indicating it's Locked status.
    /media/uploads/HinoNaka/mbed_shoppingcart_fig6.png
    Then, if you decode the Unlock qrcode described in GR-Peach_mbed-os_QRCode_ShoppingCart_node\qrcode\qr.pdf, screen should transit to the following one indicating it's Unlocked status.
    /media/uploads/HinoNaka/mbed_shoppingcart_fig7.png
    After that if you you decode the Lock qrcode described in the above qr.pdf, screen should re-transit to Locked status. In this way, the screen transits to Locked and Unlocked status in accordance with the decoded result of QR code.

How to Deploy this app on HEROKU

HEROKU ( https://id.heroku.com ) is PaaS (Platform as a Service) on which Node.js application can deploy free-of charge. By utilizing it, you can access mbed Shopping Cart and QR Code Login from mobile terminal.

Here is the procedure to deploy this application on HEROKU:

  1. Create your HEROKU account at https://signup.heroku.com/login if you haven't created it yet.
  2. Install Heroku Toolbelt
    32-bit: https://cli-assets.heroku.com/heroku-cli/channels/stable/heroku-cli-x86.exe
    64-bit: https://cli-assets.heroku.com/heroku-cli/channels/stable/heroku-cli-x64.exe )
  3. Launch command prompt (e.g. Windows PowerShell) and move to the project root directory. Then, invoke the command heroku login. At the first time, Email and Password is thought to be required. At that time, please type Email address and password registered at the step 1.
  4. Invoke the command git init
  5. Invoke the command git add . to prepare all the files staged for the next commit
  6. Invoke the command git commit -m "[commit message]" to commit the files staged at the step 5
  7. Invoke the command heroku create. If the command is successfully terminated, the remote repository heroku should be created and associated with the local repository
  8. Invoke the command git push heroku master If the command is successfully terminated, this application should be deployed to HEROKU and its URL should be shown as follows:

remote: -----> Launching...
remote:        Released v3
remote:        https://hogeoge.herokuapp.com/ deployed to Heroku

After all the steps are completed without error, please access the URL http:hogehoge.herokuapp.com/ (i.e URL where https in the URL shown in the step 7 is replaced with http) with Web browser. You should be able to show mbed Shopping Cart on Web browser.

-------------------------------------------------------------------------------------------------------------------------------------------------

Node.jsとnpmのインストール

本アプリケーションを実行するにあたっては、Node.jsとnpmのインストールが必要です。
お使いの開発環境(PC)にNode.js、npmがインストールされているかどうかは、下記コマンドで確認する事ができます。

node --version
npm --version

上記コマンド実行後、x.x.x というバージョン・リビジョン番号が表示されれば、Node.js、npmは既にインストールされていますので、次節以降の手順にしたがってアプリケーションのセットアップを行ってください。未インストールの場合は以降の手順にしたがってNode.js、npmをインストールしてください。

開発環境のホストOSがWindowsまたはmacの場合はhttps://nodejs.org/en/download から入手可能なインストーラを使用してインストールします。

開発環境のホストOSがLinuxの場合は、お使いのディストリビーションに応じたパッケージ管理システムを用いたインストールが可能です。詳細はhttps://nodejs.org/en/download/package-manager を参照ください。

前提条件

本アプリケーションを実行するにあたっては、GR-PEACH上のバーコードデータのデコード結果にmbed Device Connectorからアクセスする下記プログラムを事前にセットアップしておく必要があります。

Import programGR-PEACH_mbed-os-client-ZXingSample

Fork of https://developer.mbed.org/teams/Renesas/code/GR-PEACH_mbed-os-client-ZXingSample/

アプリケーションの設定

本アプリケーションの実行するためには、.envファイルを介して以下に示すオプションを設定する必要があります。なお、.envファイルはGR-PEACH_mbed-os-QRCode-ShoppingCart-nodeフォルダに格納されています。

  • ACCESS_KEY 本変数にはmbed Device Connector上で生成可能なAccess Keyを設定します。Access Keyが未生成の場合は下記に従って作成してください。
    1. https://connector.mbed.com/#accesskeys にアクセスします。
    2. CREATE NEW ACCESS KEYをクリックします。
    /media/uploads/HinoNaka/screenshot7.png
    3. access keyの名称を入力するように促されたら、任意の名称(例えばdemo等)を入力し、ADDをクリックします。
    /media/uploads/HinoNaka/screenshot8.png

    access keyが正常に生成できたら、コピーして下記のように.envファイルでACCESS_KEYに設定します。

.env

ACCESS_KEY=...
  • PORT 本変数にはWebアプリへのアクセスに使用するポート番号を下記のように設定します。デフォルトのポート番号は 8080 です。8080から変更の必要がなければ、設定は省略可能です。

.env

PORT=...

また、ショッピングカートに追加する品目と値段をカンマ区切りで下記のように記載したリストを準備し、klist.txtという名称でGR-Peach_mbed-os_QRCode_ShoppingCart_node\public\listフォルダに格納してください。

/media/uploads/HinoNaka/mbed_shoppingcart_fig8.png

アプリケーションの実行

本アプリケーションでは、Shopping CartQR Code Loginという2つのタブが実装されています。以下、それぞれの動作方法について記載します。
なお上述の通り、本アプリケーションの実行に際しては、事前にGR-PEACH_mbed-os-client-ZXingSampleを実行しておく必要があります。GR-PEACH_mbed-os-client-ZXingSampleのセットアップ方法、および実行方法に関しては、https://developer.mbed.org/teams/Renesas/code/GR-PEACH_mbed-os-client-ZXingSample/ を参照ください。プログラムが正常に動作している場合、下記のメッセージがターミナルに表示されます。
/media/uploads/HinoNaka/mbed_shoppingcart_fig4.png

プログラムの正常動作が確認できたら、以降の手順に従ってWebアプリケーションを実行します。

  • Webアプリケーションの起動
    下記コマンドでWebアプリケーションを起動可能です。
    /media/uploads/HinoNaka/shoppingcart_fig1.png
    上述のアプリケーション設定が正常に行われていれば、下記メッセージが表示されます。
    /media/uploads/HinoNaka/shoppingcart_fig2.png
    なお、8080PORT設定に応じた値となります。
    続いて、上述のURLにWebブラウザでアクセスすると、下記のSmart Shopping Cartの画面が表示されます。
    /media/uploads/HinoNaka/mbed_shoppingcart_fig3.png

  • Shopping Cartタブ
    GR-Peach_mbed-os_QRCode_ShoppingCart_node\qrcode\qrcode.pdf に記載されている Birthday CakeParty CupsBeer KegsPound of beefBuflle-proof vest のQRコードをデコードすると、下記のようにデコードしたアイテムが都度ショッピングカートに追加されます。
    /media/uploads/HinoNaka/mbed_shoppingcart_fig5.png

  • QR Code Loginタブ
    このタブを選択すると、下記のLock状態を示す画面が表示されます。 /media/uploads/HinoNaka/mbed_shoppingcart_fig6.png
    ここで、GR-Peach_mbed-os_QRCode_ShoppingCart_node\qrcode\qrcode.pdf に記載のUnlock QRコードをデコードすると、Unlock状態を示す下記の画面に遷移します。 /media/uploads/HinoNaka/mbed_shoppingcart_fig7.png

    この後、Lock QRコードをデコードすると画面はLock状態に再度遷移します。

    このようにQR Code Loginタブでは、LockUnlockのQRコードをデコードする都度、対応する画面に遷移するアプリケーションです。

HEROKUへのデプロイ

HEROKU ( https://id.heroku.com) はNode.jsアプリが無償でデプロイ可能なPaaS (Platform as a Service)と呼ばれるサービスです。HEROKUを活用する事で、mbed Shopping CartQR Code Loginにモバイル端末等からアクセスする事が可能となります。

以下、HEROKUへ本アプリをデプロイする手順を説明します。

  1. HEROKUのアカウントを所有していない場合は https://signup.heroku.com/login でアカウントを作成してください
  2. Heroku Toolbeltをインストールします
    32-bit版: https://cli-assets.heroku.com/heroku-cli/channels/stable/heroku-cli-x86.exe
    64-bit版: https://cli-assets.heroku.com/heroku-cli/channels/stable/heroku-cli-x64.exe )
  3. ターミナルソフトウェア(例えばWindows PowerShell)を立上げます。そして本アプリのルートディレクトリへ移動し、heroku loginコマンドを実行します。Emailアドレスとパスワードの入力を求められた場合は、アカウント生成時に入力したアドレスとパスワードを入力してください。
  4. git initコマンドを実行します
  5. git add .コマンドを実行し、全ファイルをコミット対象に設定します
  6. git commit -m "[commit message]" で、全ファイルをコミットします
  7. heroku createを実行します。本コマンドが正常終了すると、リモートリポジトリ herokuが設定されます
  8. git push heroku master本コマンドが正常終了すると、HEROKUへのデプロイが完了し、下記のように本WebアプリのURLが表示されます

remote: -----> Launching...
remote:        Released v3
remote:        https://hogeoge.herokuapp.com/ deployed to Heroku

上記の全ての手順が完了したら、http:hogehoge.herokuapp.com/ ( 8. で表示されたURL中のhttpshttpに置換えたもの)へブラウザ等でアクセスします。途中でエラーが発生していなければ、mbed Shopping CartがWebブラウザ上に表示されます。

Committer:
Osamu Nakamura
Date:
Fri Jan 12 19:05:14 2018 +0900
Revision:
0:a40b9a259b52
Initial commit

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Osamu Nakamura 0:a40b9a259b52 1 /*-----------------------------------
Osamu Nakamura 0:a40b9a259b52 2 General Styles
Osamu Nakamura 0:a40b9a259b52 3 -----------------------------------*/
Osamu Nakamura 0:a40b9a259b52 4
Osamu Nakamura 0:a40b9a259b52 5 body{
Osamu Nakamura 0:a40b9a259b52 6 font-size : 14px;
Osamu Nakamura 0:a40b9a259b52 7 background-color: #f2f6f9;
Osamu Nakamura 0:a40b9a259b52 8 }
Osamu Nakamura 0:a40b9a259b52 9
Osamu Nakamura 0:a40b9a259b52 10 ul{
Osamu Nakamura 0:a40b9a259b52 11 list-style-type: none;
Osamu Nakamura 0:a40b9a259b52 12 }
Osamu Nakamura 0:a40b9a259b52 13
Osamu Nakamura 0:a40b9a259b52 14 a:hover {
Osamu Nakamura 0:a40b9a259b52 15 text-decoration:none;
Osamu Nakamura 0:a40b9a259b52 16 }
Osamu Nakamura 0:a40b9a259b52 17
Osamu Nakamura 0:a40b9a259b52 18
Osamu Nakamura 0:a40b9a259b52 19 /*-----------------------------------
Osamu Nakamura 0:a40b9a259b52 20 Navbar
Osamu Nakamura 0:a40b9a259b52 21 -----------------------------------*/
Osamu Nakamura 0:a40b9a259b52 22
Osamu Nakamura 0:a40b9a259b52 23 .minicart{
Osamu Nakamura 0:a40b9a259b52 24 background:url(../images/sprite.png);
Osamu Nakamura 0:a40b9a259b52 25 background-position: -156px 11px;
Osamu Nakamura 0:a40b9a259b52 26 background-repeat:no-repeat;
Osamu Nakamura 0:a40b9a259b52 27 width: 40px;
Osamu Nakamura 0:a40b9a259b52 28 height: 50px;
Osamu Nakamura 0:a40b9a259b52 29 padding-right: 32px;
Osamu Nakamura 0:a40b9a259b52 30 }
Osamu Nakamura 0:a40b9a259b52 31
Osamu Nakamura 0:a40b9a259b52 32 .navbar{
Osamu Nakamura 0:a40b9a259b52 33 background-color: #4ea6bc;
Osamu Nakamura 0:a40b9a259b52 34 padding: 15px ;
Osamu Nakamura 0:a40b9a259b52 35 border-radius: 0;
Osamu Nakamura 0:a40b9a259b52 36 margin: 0;
Osamu Nakamura 0:a40b9a259b52 37 }
Osamu Nakamura 0:a40b9a259b52 38
Osamu Nakamura 0:a40b9a259b52 39 .navbar-brand{
Osamu Nakamura 0:a40b9a259b52 40 color: #fff;
Osamu Nakamura 0:a40b9a259b52 41 font-family: Open Sans, sans-serif;
Osamu Nakamura 0:a40b9a259b52 42 padding-left: 32px;
Osamu Nakamura 0:a40b9a259b52 43 }
Osamu Nakamura 0:a40b9a259b52 44
Osamu Nakamura 0:a40b9a259b52 45 .navbar-brand:hover{
Osamu Nakamura 0:a40b9a259b52 46 color: #fff;
Osamu Nakamura 0:a40b9a259b52 47 }
Osamu Nakamura 0:a40b9a259b52 48
Osamu Nakamura 0:a40b9a259b52 49 /*-----------------------------------
Osamu Nakamura 0:a40b9a259b52 50 Breadcrumb
Osamu Nakamura 0:a40b9a259b52 51 -----------------------------------*/
Osamu Nakamura 0:a40b9a259b52 52
Osamu Nakamura 0:a40b9a259b52 53 .breadcrumb > .active a{
Osamu Nakamura 0:a40b9a259b52 54 color: #468595;
Osamu Nakamura 0:a40b9a259b52 55 font-weight: bold;
Osamu Nakamura 0:a40b9a259b52 56 text-transform: uppercase;
Osamu Nakamura 0:a40b9a259b52 57 }
Osamu Nakamura 0:a40b9a259b52 58
Osamu Nakamura 0:a40b9a259b52 59 .breadcrumb li a{
Osamu Nakamura 0:a40b9a259b52 60 color :#b3d4dc;
Osamu Nakamura 0:a40b9a259b52 61 font-weight: bold;
Osamu Nakamura 0:a40b9a259b52 62 text-transform: uppercase;
Osamu Nakamura 0:a40b9a259b52 63 }
Osamu Nakamura 0:a40b9a259b52 64
Osamu Nakamura 0:a40b9a259b52 65 .breadcrumb>li+li:before {
Osamu Nakamura 0:a40b9a259b52 66 content: "\00BB";
Osamu Nakamura 0:a40b9a259b52 67 }
Osamu Nakamura 0:a40b9a259b52 68
Osamu Nakamura 0:a40b9a259b52 69 .breadcrumb{
Osamu Nakamura 0:a40b9a259b52 70 margin-bottom: 100px;
Osamu Nakamura 0:a40b9a259b52 71 background-color: #ffffff;
Osamu Nakamura 0:a40b9a259b52 72 }
Osamu Nakamura 0:a40b9a259b52 73
Osamu Nakamura 0:a40b9a259b52 74 .breadcrumbBox{
Osamu Nakamura 0:a40b9a259b52 75 background-color: #ffffff;
Osamu Nakamura 0:a40b9a259b52 76 height: 100px;
Osamu Nakamura 0:a40b9a259b52 77 margin-bottom: 100px;
Osamu Nakamura 0:a40b9a259b52 78 padding-top: 32px;
Osamu Nakamura 0:a40b9a259b52 79 }
Osamu Nakamura 0:a40b9a259b52 80
Osamu Nakamura 0:a40b9a259b52 81 /*-----------------------------------
Osamu Nakamura 0:a40b9a259b52 82 Main
Osamu Nakamura 0:a40b9a259b52 83 -----------------------------------*/
Osamu Nakamura 0:a40b9a259b52 84
Osamu Nakamura 0:a40b9a259b52 85 .container.text-center{
Osamu Nakamura 0:a40b9a259b52 86 padding: 0 32px;
Osamu Nakamura 0:a40b9a259b52 87 }
Osamu Nakamura 0:a40b9a259b52 88
Osamu Nakamura 0:a40b9a259b52 89 /*-----------------------------------
Osamu Nakamura 0:a40b9a259b52 90 Logo and description
Osamu Nakamura 0:a40b9a259b52 91 ----------------------------------- */
Osamu Nakamura 0:a40b9a259b52 92
Osamu Nakamura 0:a40b9a259b52 93
Osamu Nakamura 0:a40b9a259b52 94 .col-md-5.col-sm-12{
Osamu Nakamura 0:a40b9a259b52 95 padding: 0;
Osamu Nakamura 0:a40b9a259b52 96 }
Osamu Nakamura 0:a40b9a259b52 97
Osamu Nakamura 0:a40b9a259b52 98 .col-md-5.col-sm-12 h1{
Osamu Nakamura 0:a40b9a259b52 99 color: #595c5f;
Osamu Nakamura 0:a40b9a259b52 100 font-size: 24px;
Osamu Nakamura 0:a40b9a259b52 101 font-weight: bold;
Osamu Nakamura 0:a40b9a259b52 102 margin-bottom:30px;
Osamu Nakamura 0:a40b9a259b52 103 text-align: left;
Osamu Nakamura 0:a40b9a259b52 104 }
Osamu Nakamura 0:a40b9a259b52 105
Osamu Nakamura 0:a40b9a259b52 106 .col-md-5.col-sm-12 p{
Osamu Nakamura 0:a40b9a259b52 107 color: #898e92;
Osamu Nakamura 0:a40b9a259b52 108 line-height: 1.5;
Osamu Nakamura 0:a40b9a259b52 109 max-width: 400px;
Osamu Nakamura 0:a40b9a259b52 110 text-align: justify;
Osamu Nakamura 0:a40b9a259b52 111 }
Osamu Nakamura 0:a40b9a259b52 112
Osamu Nakamura 0:a40b9a259b52 113 .bigcart{
Osamu Nakamura 0:a40b9a259b52 114 background:url(../images/sprite.png);
Osamu Nakamura 0:a40b9a259b52 115 background-position: 0px 11px;
Osamu Nakamura 0:a40b9a259b52 116 background-repeat:no-repeat;
Osamu Nakamura 0:a40b9a259b52 117 width: 155px;
Osamu Nakamura 0:a40b9a259b52 118 height: 120px;
Osamu Nakamura 0:a40b9a259b52 119 margin:0 0 40px 60px;
Osamu Nakamura 0:a40b9a259b52 120 }
Osamu Nakamura 0:a40b9a259b52 121
Osamu Nakamura 0:a40b9a259b52 122
Osamu Nakamura 0:a40b9a259b52 123 /*-----------------------------------
Osamu Nakamura 0:a40b9a259b52 124 Cart items list
Osamu Nakamura 0:a40b9a259b52 125 -----------------------------------*/
Osamu Nakamura 0:a40b9a259b52 126
Osamu Nakamura 0:a40b9a259b52 127 .col-md-7.col-sm-12{
Osamu Nakamura 0:a40b9a259b52 128 padding-left: 50px ;
Osamu Nakamura 0:a40b9a259b52 129 margin-bottom: 72px;
Osamu Nakamura 0:a40b9a259b52 130 }
Osamu Nakamura 0:a40b9a259b52 131
Osamu Nakamura 0:a40b9a259b52 132 .row{
Osamu Nakamura 0:a40b9a259b52 133 box-shadow: 0 1px 0 #e1e5e8;
Osamu Nakamura 0:a40b9a259b52 134 padding-bottom :0;
Osamu Nakamura 0:a40b9a259b52 135 padding-left: 15px;
Osamu Nakamura 0:a40b9a259b52 136 background-color: #ffffff;
Osamu Nakamura 0:a40b9a259b52 137 margin-bottom: 11px;
Osamu Nakamura 0:a40b9a259b52 138 }
Osamu Nakamura 0:a40b9a259b52 139
Osamu Nakamura 0:a40b9a259b52 140 .row span{
Osamu Nakamura 0:a40b9a259b52 141 padding: 20px 0 6px 0;
Osamu Nakamura 0:a40b9a259b52 142 }
Osamu Nakamura 0:a40b9a259b52 143
Osamu Nakamura 0:a40b9a259b52 144 /* Column Captions */
Osamu Nakamura 0:a40b9a259b52 145
Osamu Nakamura 0:a40b9a259b52 146 .columnCaptions{
Osamu Nakamura 0:a40b9a259b52 147 color: #7e93a7;
Osamu Nakamura 0:a40b9a259b52 148 font-size:12px;
Osamu Nakamura 0:a40b9a259b52 149 text-transform: uppercase;
Osamu Nakamura 0:a40b9a259b52 150 padding: 0;
Osamu Nakamura 0:a40b9a259b52 151 box-shadow: 0 0 0;
Osamu Nakamura 0:a40b9a259b52 152 background-color: #f2f6f9;
Osamu Nakamura 0:a40b9a259b52 153 }
Osamu Nakamura 0:a40b9a259b52 154
Osamu Nakamura 0:a40b9a259b52 155 .columnCaptions span:first-child{
Osamu Nakamura 0:a40b9a259b52 156 padding-left:8px;
Osamu Nakamura 0:a40b9a259b52 157 }
Osamu Nakamura 0:a40b9a259b52 158
Osamu Nakamura 0:a40b9a259b52 159 .columnCaptions span{
Osamu Nakamura 0:a40b9a259b52 160 padding: 0 21px 0 0;
Osamu Nakamura 0:a40b9a259b52 161 }
Osamu Nakamura 0:a40b9a259b52 162
Osamu Nakamura 0:a40b9a259b52 163 .columnCaptions span:last-child{
Osamu Nakamura 0:a40b9a259b52 164 float: right;
Osamu Nakamura 0:a40b9a259b52 165 padding-right: 72px;
Osamu Nakamura 0:a40b9a259b52 166 }
Osamu Nakamura 0:a40b9a259b52 167
Osamu Nakamura 0:a40b9a259b52 168
Osamu Nakamura 0:a40b9a259b52 169 /* Items */
Osamu Nakamura 0:a40b9a259b52 170
Osamu Nakamura 0:a40b9a259b52 171 .itemName{
Osamu Nakamura 0:a40b9a259b52 172 color: #727578;
Osamu Nakamura 0:a40b9a259b52 173 font-size :16px;
Osamu Nakamura 0:a40b9a259b52 174 font-weight: bold;
Osamu Nakamura 0:a40b9a259b52 175 float: left;
Osamu Nakamura 0:a40b9a259b52 176 padding-left:25px;
Osamu Nakamura 0:a40b9a259b52 177 }
Osamu Nakamura 0:a40b9a259b52 178
Osamu Nakamura 0:a40b9a259b52 179
Osamu Nakamura 0:a40b9a259b52 180 .quantity{
Osamu Nakamura 0:a40b9a259b52 181 color: #4ea6bc;
Osamu Nakamura 0:a40b9a259b52 182 font-size :18px;
Osamu Nakamura 0:a40b9a259b52 183 font-weight: bold;
Osamu Nakamura 0:a40b9a259b52 184 float : left;
Osamu Nakamura 0:a40b9a259b52 185 width: 42px;
Osamu Nakamura 0:a40b9a259b52 186 padding-left: 7px;
Osamu Nakamura 0:a40b9a259b52 187 }
Osamu Nakamura 0:a40b9a259b52 188
Osamu Nakamura 0:a40b9a259b52 189
Osamu Nakamura 0:a40b9a259b52 190 .popbtn{
Osamu Nakamura 0:a40b9a259b52 191 background-color: #e6edf3;
Osamu Nakamura 0:a40b9a259b52 192 margin-left: 25px;
Osamu Nakamura 0:a40b9a259b52 193 height: 63px;
Osamu Nakamura 0:a40b9a259b52 194 width: 40px;
Osamu Nakamura 0:a40b9a259b52 195 padding: 32px 0 0 14px !important;
Osamu Nakamura 0:a40b9a259b52 196 float: right;
Osamu Nakamura 0:a40b9a259b52 197 cursor: pointer;
Osamu Nakamura 0:a40b9a259b52 198 }
Osamu Nakamura 0:a40b9a259b52 199
Osamu Nakamura 0:a40b9a259b52 200 .arrow{
Osamu Nakamura 0:a40b9a259b52 201 width: 0;
Osamu Nakamura 0:a40b9a259b52 202 height: 0;
Osamu Nakamura 0:a40b9a259b52 203 border-left: 6px solid transparent;
Osamu Nakamura 0:a40b9a259b52 204 border-right: 6px solid transparent;
Osamu Nakamura 0:a40b9a259b52 205 border-top: 6px solid #858e97;
Osamu Nakamura 0:a40b9a259b52 206 }
Osamu Nakamura 0:a40b9a259b52 207
Osamu Nakamura 0:a40b9a259b52 208 .price{
Osamu Nakamura 0:a40b9a259b52 209 color: #f06953;
Osamu Nakamura 0:a40b9a259b52 210 font-size :18px;
Osamu Nakamura 0:a40b9a259b52 211 font-weight: bold;
Osamu Nakamura 0:a40b9a259b52 212 float: right;
Osamu Nakamura 0:a40b9a259b52 213 }
Osamu Nakamura 0:a40b9a259b52 214
Osamu Nakamura 0:a40b9a259b52 215
Osamu Nakamura 0:a40b9a259b52 216 /* Totals */
Osamu Nakamura 0:a40b9a259b52 217
Osamu Nakamura 0:a40b9a259b52 218 .totals{
Osamu Nakamura 0:a40b9a259b52 219 background-color: #f2f6f9;
Osamu Nakamura 0:a40b9a259b52 220 }
Osamu Nakamura 0:a40b9a259b52 221
Osamu Nakamura 0:a40b9a259b52 222 .totals span{
Osamu Nakamura 0:a40b9a259b52 223 padding: 40px 15px 40px 0;
Osamu Nakamura 0:a40b9a259b52 224 }
Osamu Nakamura 0:a40b9a259b52 225
Osamu Nakamura 0:a40b9a259b52 226 .totals .price{
Osamu Nakamura 0:a40b9a259b52 227 float: left;
Osamu Nakamura 0:a40b9a259b52 228 }
Osamu Nakamura 0:a40b9a259b52 229
Osamu Nakamura 0:a40b9a259b52 230 .totals .itemName{
Osamu Nakamura 0:a40b9a259b52 231 margin-top: 1px;
Osamu Nakamura 0:a40b9a259b52 232 }
Osamu Nakamura 0:a40b9a259b52 233
Osamu Nakamura 0:a40b9a259b52 234 .totals .order{
Osamu Nakamura 0:a40b9a259b52 235 float: right;
Osamu Nakamura 0:a40b9a259b52 236 padding: 0;
Osamu Nakamura 0:a40b9a259b52 237 margin-top: 40px;
Osamu Nakamura 0:a40b9a259b52 238 padding-left: 5px;
Osamu Nakamura 0:a40b9a259b52 239 cursor: pointer;
Osamu Nakamura 0:a40b9a259b52 240 }
Osamu Nakamura 0:a40b9a259b52 241
Osamu Nakamura 0:a40b9a259b52 242 .order a{
Osamu Nakamura 0:a40b9a259b52 243 background-color: #f08573;
Osamu Nakamura 0:a40b9a259b52 244 color: #fbfffa;
Osamu Nakamura 0:a40b9a259b52 245 font-weight: bold;
Osamu Nakamura 0:a40b9a259b52 246 border-radius: 2px;
Osamu Nakamura 0:a40b9a259b52 247 padding: 20px 30px;
Osamu Nakamura 0:a40b9a259b52 248 }
Osamu Nakamura 0:a40b9a259b52 249
Osamu Nakamura 0:a40b9a259b52 250
Osamu Nakamura 0:a40b9a259b52 251 /* Popovers */
Osamu Nakamura 0:a40b9a259b52 252
Osamu Nakamura 0:a40b9a259b52 253 .popover{
Osamu Nakamura 0:a40b9a259b52 254 border-radius: 3px;
Osamu Nakamura 0:a40b9a259b52 255 box-shadow: 0 0 1px 1px rgba(0,0,0,0.2);
Osamu Nakamura 0:a40b9a259b52 256 border: 0;
Osamu Nakamura 0:a40b9a259b52 257 background-color: #ffffff;
Osamu Nakamura 0:a40b9a259b52 258 }
Osamu Nakamura 0:a40b9a259b52 259
Osamu Nakamura 0:a40b9a259b52 260 .popover.bottom{
Osamu Nakamura 0:a40b9a259b52 261 margin-top: -9px;
Osamu Nakamura 0:a40b9a259b52 262 }
Osamu Nakamura 0:a40b9a259b52 263
Osamu Nakamura 0:a40b9a259b52 264 .glyphicon{
Osamu Nakamura 0:a40b9a259b52 265 width: 24px;
Osamu Nakamura 0:a40b9a259b52 266 font-size: 24px;
Osamu Nakamura 0:a40b9a259b52 267 padding: 0;
Osamu Nakamura 0:a40b9a259b52 268 }
Osamu Nakamura 0:a40b9a259b52 269
Osamu Nakamura 0:a40b9a259b52 270 .glyphicon-pencil{
Osamu Nakamura 0:a40b9a259b52 271 color: #858e97;
Osamu Nakamura 0:a40b9a259b52 272 margin: 7px 12px 7px 10px;
Osamu Nakamura 0:a40b9a259b52 273 }
Osamu Nakamura 0:a40b9a259b52 274
Osamu Nakamura 0:a40b9a259b52 275 .glyphicon-remove{
Osamu Nakamura 0:a40b9a259b52 276 color: #f06953;
Osamu Nakamura 0:a40b9a259b52 277 margin-right: 10px;
Osamu Nakamura 0:a40b9a259b52 278 }
Osamu Nakamura 0:a40b9a259b52 279
Osamu Nakamura 0:a40b9a259b52 280 /*-----------------------------------
Osamu Nakamura 0:a40b9a259b52 281 Media Queries
Osamu Nakamura 0:a40b9a259b52 282 ----------------------------------- */
Osamu Nakamura 0:a40b9a259b52 283
Osamu Nakamura 0:a40b9a259b52 284 /* Tablet size */
Osamu Nakamura 0:a40b9a259b52 285
Osamu Nakamura 0:a40b9a259b52 286 @media (max-width: 992px) {
Osamu Nakamura 0:a40b9a259b52 287
Osamu Nakamura 0:a40b9a259b52 288 .container.text-center{
Osamu Nakamura 0:a40b9a259b52 289 padding: 0 15px;
Osamu Nakamura 0:a40b9a259b52 290 }
Osamu Nakamura 0:a40b9a259b52 291
Osamu Nakamura 0:a40b9a259b52 292 .breadcrumb{
Osamu Nakamura 0:a40b9a259b52 293 margin-bottom: 32px;
Osamu Nakamura 0:a40b9a259b52 294 }
Osamu Nakamura 0:a40b9a259b52 295
Osamu Nakamura 0:a40b9a259b52 296 .bigcart{
Osamu Nakamura 0:a40b9a259b52 297 margin: 0 auto 40px auto;
Osamu Nakamura 0:a40b9a259b52 298 }
Osamu Nakamura 0:a40b9a259b52 299
Osamu Nakamura 0:a40b9a259b52 300 .col-md-5.col-sm-12 h1{
Osamu Nakamura 0:a40b9a259b52 301 text-align: center;
Osamu Nakamura 0:a40b9a259b52 302 }
Osamu Nakamura 0:a40b9a259b52 303
Osamu Nakamura 0:a40b9a259b52 304 .col-md-5.col-sm-12 p{
Osamu Nakamura 0:a40b9a259b52 305 margin: 0 auto 64px auto;
Osamu Nakamura 0:a40b9a259b52 306 text-align: justify;
Osamu Nakamura 0:a40b9a259b52 307 }
Osamu Nakamura 0:a40b9a259b52 308
Osamu Nakamura 0:a40b9a259b52 309 .col-md-7.col-sm-12{
Osamu Nakamura 0:a40b9a259b52 310 padding-left: 10px ;
Osamu Nakamura 0:a40b9a259b52 311 padding-right: 50px;
Osamu Nakamura 0:a40b9a259b52 312 }
Osamu Nakamura 0:a40b9a259b52 313
Osamu Nakamura 0:a40b9a259b52 314 .totals{
Osamu Nakamura 0:a40b9a259b52 315 box-shadow: 0 0 0;
Osamu Nakamura 0:a40b9a259b52 316 }
Osamu Nakamura 0:a40b9a259b52 317
Osamu Nakamura 0:a40b9a259b52 318 }
Osamu Nakamura 0:a40b9a259b52 319
Osamu Nakamura 0:a40b9a259b52 320
Osamu Nakamura 0:a40b9a259b52 321 /* Mobile device size */
Osamu Nakamura 0:a40b9a259b52 322
Osamu Nakamura 0:a40b9a259b52 323 @media (max-width: 768px) {
Osamu Nakamura 0:a40b9a259b52 324
Osamu Nakamura 0:a40b9a259b52 325 .navbar{
Osamu Nakamura 0:a40b9a259b52 326 padding:10px 0;
Osamu Nakamura 0:a40b9a259b52 327 }
Osamu Nakamura 0:a40b9a259b52 328
Osamu Nakamura 0:a40b9a259b52 329 .minicart{
Osamu Nakamura 0:a40b9a259b52 330 margin-right: -1px;
Osamu Nakamura 0:a40b9a259b52 331 padding-right: 0;
Osamu Nakamura 0:a40b9a259b52 332 }
Osamu Nakamura 0:a40b9a259b52 333
Osamu Nakamura 0:a40b9a259b52 334 .navbar-brand{
Osamu Nakamura 0:a40b9a259b52 335 padding-left: 0;
Osamu Nakamura 0:a40b9a259b52 336 }
Osamu Nakamura 0:a40b9a259b52 337
Osamu Nakamura 0:a40b9a259b52 338 .breadcrumbBox{
Osamu Nakamura 0:a40b9a259b52 339 height:80px;
Osamu Nakamura 0:a40b9a259b52 340 padding-top:21px;
Osamu Nakamura 0:a40b9a259b52 341 }
Osamu Nakamura 0:a40b9a259b52 342
Osamu Nakamura 0:a40b9a259b52 343 .col-md-5.col-sm-12 p{
Osamu Nakamura 0:a40b9a259b52 344 max-width: 300px;
Osamu Nakamura 0:a40b9a259b52 345 }
Osamu Nakamura 0:a40b9a259b52 346
Osamu Nakamura 0:a40b9a259b52 347 .col-md-7.col-sm-12{
Osamu Nakamura 0:a40b9a259b52 348 padding-left: 0;
Osamu Nakamura 0:a40b9a259b52 349 padding-right: 15px;
Osamu Nakamura 0:a40b9a259b52 350 margin-bottom: 32px;
Osamu Nakamura 0:a40b9a259b52 351 }
Osamu Nakamura 0:a40b9a259b52 352
Osamu Nakamura 0:a40b9a259b52 353 .col-md-7.col-sm-12 ul{
Osamu Nakamura 0:a40b9a259b52 354 padding-left: 15px ;
Osamu Nakamura 0:a40b9a259b52 355 }
Osamu Nakamura 0:a40b9a259b52 356
Osamu Nakamura 0:a40b9a259b52 357 .columnCaptions span{
Osamu Nakamura 0:a40b9a259b52 358 padding: 0 21px 0 0;
Osamu Nakamura 0:a40b9a259b52 359 }
Osamu Nakamura 0:a40b9a259b52 360
Osamu Nakamura 0:a40b9a259b52 361 .columnCaptions span:last-child{
Osamu Nakamura 0:a40b9a259b52 362 float: right;
Osamu Nakamura 0:a40b9a259b52 363 padding-right: 42px;
Osamu Nakamura 0:a40b9a259b52 364 }
Osamu Nakamura 0:a40b9a259b52 365
Osamu Nakamura 0:a40b9a259b52 366 .row{
Osamu Nakamura 0:a40b9a259b52 367 padding-bottom:10px;
Osamu Nakamura 0:a40b9a259b52 368 }
Osamu Nakamura 0:a40b9a259b52 369
Osamu Nakamura 0:a40b9a259b52 370 .quantity{
Osamu Nakamura 0:a40b9a259b52 371 width: 23px;
Osamu Nakamura 0:a40b9a259b52 372 padding-right: 40px !important;
Osamu Nakamura 0:a40b9a259b52 373 }
Osamu Nakamura 0:a40b9a259b52 374
Osamu Nakamura 0:a40b9a259b52 375 .popbtn{
Osamu Nakamura 0:a40b9a259b52 376 background-color: white;
Osamu Nakamura 0:a40b9a259b52 377 position: absolute;
Osamu Nakamura 0:a40b9a259b52 378 height:40px;
Osamu Nakamura 0:a40b9a259b52 379 right: 0;
Osamu Nakamura 0:a40b9a259b52 380 }
Osamu Nakamura 0:a40b9a259b52 381
Osamu Nakamura 0:a40b9a259b52 382 .price{
Osamu Nakamura 0:a40b9a259b52 383 position: absolute;
Osamu Nakamura 0:a40b9a259b52 384 right: 42px;
Osamu Nakamura 0:a40b9a259b52 385 }
Osamu Nakamura 0:a40b9a259b52 386
Osamu Nakamura 0:a40b9a259b52 387 .totals{
Osamu Nakamura 0:a40b9a259b52 388 padding: 0;
Osamu Nakamura 0:a40b9a259b52 389 }
Osamu Nakamura 0:a40b9a259b52 390
Osamu Nakamura 0:a40b9a259b52 391 .totals .price{
Osamu Nakamura 0:a40b9a259b52 392 position: static;
Osamu Nakamura 0:a40b9a259b52 393 }
Osamu Nakamura 0:a40b9a259b52 394
Osamu Nakamura 0:a40b9a259b52 395 /* Change Bootstrap's default popover to make it look nice on a mobile device */
Osamu Nakamura 0:a40b9a259b52 396
Osamu Nakamura 0:a40b9a259b52 397 .popover.bottom>.arrow{
Osamu Nakamura 0:a40b9a259b52 398 left: auto;
Osamu Nakamura 0:a40b9a259b52 399 margin-left: 0;
Osamu Nakamura 0:a40b9a259b52 400 right: 5px;
Osamu Nakamura 0:a40b9a259b52 401 }
Osamu Nakamura 0:a40b9a259b52 402
Osamu Nakamura 0:a40b9a259b52 403 .popover.bottom{
Osamu Nakamura 0:a40b9a259b52 404 margin-top: 7px;
Osamu Nakamura 0:a40b9a259b52 405 margin-left: -40px;
Osamu Nakamura 0:a40b9a259b52 406 }
Osamu Nakamura 0:a40b9a259b52 407
Osamu Nakamura 0:a40b9a259b52 408 }