content = new View("admin_product_lines.html"); $view->content->products = ORM::factory("product")->order_by("name")->find_all(); print $view; } public function add_product_form() { print product::get_add_form_admin(); } public function add_product() { access::verify_csrf(); $form = product::get_add_form_admin(); $valid = $form->validate(); $name = $form->add_product->inputs["name"]->value; $product = ORM::factory("product")->where("name", "=", $name)->find(); if ($product->loaded()) { $form->add_product->inputs["name"]->add_error("in_use", 1); $valid = false; } if ($valid) { $product = product::create( $name, $form->add_product->cost->value, $form->add_product->description->value, $form->add_product->postage_band->value ); $product->save(); message::success(t("Created product %product_name", array( "product_name" => html::clean($product->name)))); print json::reply(array("result" => "success")); } else { print $form; } } public function delete_product_form($id) { $product = ORM::factory("product", $id); if (!$product->loaded()) { kohana::show_404(); } print product::get_delete_form_admin($product); } public function delete_product($id) { access::verify_csrf(); $product = ORM::factory("product", $id); if (!$product->loaded()) { kohana::show_404(); } $form = product::get_delete_form_admin($product); if($form->validate()) { $name = $product->name; $product->delete(); } else { print $form; } $message = t("Deleted user %product_name", array("product_name" => html::clean($name))); log::success("user", $message); message::success($message); print json::reply(array("result" => "success")); } public function edit_product($id) { access::verify_csrf(); $product = ORM::factory("product", $id); if (!$product->loaded()) { kohana::show_404(); } $form = product::get_edit_form_admin($product); $valid = $form->validate(); if ($valid) { $new_name = $form->edit_product->inputs["name"]->value; if ($new_name != $product->name && ORM::factory("product") ->where("name", "=", $new_name) ->where("id","!=", $product->id) ->find() ->loaded()) { $form->edit_product->inputs["name"]->add_error("in_use", 1); $valid = false; } else { $product->name = $new_name; } } if ($valid) { $product->cost = $form->edit_product->cost->value; $product->description = $form->edit_product->description->value; $product->postage_band_id = $form->edit_product->postage_band->value; $product->save(); message::success(t("Changed product %product_name", array("product_name" => html::clean($product->name)))); print json::reply(array("result" => "success")); } else { print $form; } } public function edit_product_form($id) { $product = ORM::factory("product", $id); if (!$product->loaded()) { kohana::show_404(); } $form = product::get_edit_form_admin($product); print $form; } }