} * * @param string $name the name of the item -- required * @param string $desc the description of the item -- required * @param integer $qty the number of units of this item the customer has * in its shopping cart -- required * @param double $price the unit price of the item -- required * @param string $item_weight the weight unit used to specify the item's * weight, * one of 'LB' (pounds) or 'KG' (kilograms) * @param double $numeric_weight the weight of the item * */ function GoogleItem($name, $desc, $qty, $price, $item_weight='', $numeric_weight='') { $this->item_name = $name; $this->item_description= $desc; $this->unit_price = (float)$price; $this->quantity = (int)$qty; if ($item_weight != '' && $numeric_weight !== '') { switch(strtoupper($item_weight)){ case 'KG': $this->item_weight = strtoupper($item_weight); break; case 'LB': default: $this->item_weight = 'LB'; } $this->numeric_weight = (double)$numeric_weight; } } function SetMerchantPrivateItemData($private_data) { $this->merchant_private_item_data = $private_data; } /** * Set the merchant item id that the merchant uses to uniquely identify an * item. Google Checkout will include this value in the * merchant calculation callbacks * * GC tag: {@link http://code.google.com/apis/checkout/developer/index.html#tag_merchant-item-id } * * @param mixed $item_id the value that identifies this item on the * merchant's side * * @return void */ function SetMerchantItemId($item_id) { $this->merchant_item_id = $item_id; } /** * Sets the tax table selector which identifies an alternate tax table that * should be used to calculate tax for a particular item. * * GC tag: {@link http://code.google.com/apis/checkout/developer/index.html#tag_tax-table-selector } * * @param string $tax_selector this value should correspond to the name * of an alternate-tax-table. * * @return void */ function SetTaxTableSelector($tax_selector) { $this->tax_table_selector = $tax_selector; } /** * Used when the item's content is digital, sets whether the merchant will * send an email to the buyer explaining how to access the digital content. * Email delivery allows the merchant to charge the buyer for an order * before allowing the buyer to access the digital content. * * GC tag: {@link http://code.google.com/apis/checkout/developer/index.html#tag_email-delivery } * * @param bool $email_delivery true if email_delivery applies, defaults to * false * * @return void */ function SetEmailDigitalDelivery($email_delivery='false') { $this->digital_url = ''; $this->digital_key = ''; $this->digital_description = ''; $this->email_delivery = $email_delivery; $this->digital_content=true; } /** * Sets the information related to the digital delivery of the item. * * GC tag: {@link http://code.google.com/apis/checkout/developer/index.html#tag_digital-content } * * @param string $digital_url the url the customer must go to download the * item. --optional * @param string $digital_key the key which allows to download or unlock the * digital content item -- optional * @param string $digital_description instructions for downloading adigital * content item, 1024 characters max, can * contain xml-escaped HTML -- optional * * @return void */ function SetURLDigitalContent($digital_url, $digital_key, $digital_description) { $this->digital_url = $digital_url; $this->digital_key = $digital_key; $this->digital_description = $digital_description; $this->email_delivery = 'false'; $this->digital_content = true; } }