ok
Direktori : /proc/thread-self/root/proc/self/root/home2/selectio/www/application/models/ |
Current File : //proc/thread-self/root/proc/self/root/home2/selectio/www/application/models/Location_model.php |
<?php defined('BASEPATH') or exit('No direct script access allowed'); class Location_model extends CI_Model { //add country public function add_country() { $data = array( 'name' => $this->input->post('name', true), 'continent_code' => $this->input->post('continent_code', true), 'status' => $this->input->post('status', true) ); return $this->db->insert('location_countries', $data); } //update country public function update_country($id) { $data = array( 'name' => $this->input->post('name', true), 'continent_code' => $this->input->post('continent_code', true), 'status' => $this->input->post('status', true) ); $this->db->where('id', $id); return $this->db->update('location_countries', $data); } //add state public function add_state() { $data = array( 'name' => $this->input->post('name', true), 'country_id' => $this->input->post('country_id', true) ); return $this->db->insert('location_states', $data); } //update state public function update_state($id) { $data = array( 'name' => $this->input->post('name', true), 'country_id' => $this->input->post('country_id', true) ); $this->db->where('id', $id); return $this->db->update('location_states', $data); } //get active countries public function get_active_countries() { $result = get_cached_data($this, "active_countries", "st"); if (!empty($result)) { return $result; } $this->db->where('status', 1)->order_by('name'); $result = $this->db->get('location_countries')->result(); set_cache_data($this, "active_countries", $result, "st"); return $result; } //get countries public function get_countries() { $this->db->order_by('name'); $query = $this->db->get('location_countries'); return $query->result(); } //get countries by continent public function get_countries_by_continent($continent_code) { return $this->db->where('continent_code', clean_str($continent_code))->order_by('name')->get('location_countries')->result(); } //get paginated countries public function get_paginated_countries($per_page, $offset) { $q = trim($this->input->get('q', true)); if (!empty($q)) { $this->db->like('name', $q); } $this->db->order_by('id'); $this->db->limit($per_page, $offset); $query = $this->db->get('location_countries'); return $query->result(); } //get paginated countries count public function get_paginated_countries_count() { $q = trim($this->input->get('q', true)); if (!empty($q)) { $this->db->like('name', $q); } $query = $this->db->get('location_countries'); return $query->num_rows(); } //get country public function get_country($id) { $id = clean_number($id); $this->db->where('id', $id); $query = $this->db->get('location_countries'); return $query->row(); } //activate inactivate countries public function activate_inactivate_countries($action) { $status = 1; if ($action == "inactivate") { $status = 0; } $data = array( 'status' => $status ); $this->db->update('location_countries', $data); } //delete country public function delete_country($id) { $id = clean_number($id); $country = $this->get_country($id); if (!empty($country)) { $this->db->where('id', $id); return $this->db->delete('location_countries'); } return false; } //get states public function get_states() { $this->db->order_by('name'); $query = $this->db->get('location_states'); return $query->result(); } //get paginated states public function get_paginated_states($per_page, $offset) { $country = $this->input->get('country', true); $q = trim($this->input->get('q', true)); $this->db->join('location_countries', 'location_states.country_id = location_countries.id'); $this->db->select('location_states.*, location_countries.name as country_name, location_countries.status as country_status'); if (!empty($country)) { $this->db->where('location_states.country_id', $country); } if (!empty($q)) { $this->db->group_start(); $this->db->like('location_countries.name', $q); $this->db->or_like('location_states.name', $q); $this->db->group_end(); } $this->db->order_by('location_states.id'); $this->db->order_by('location_states.name'); $this->db->limit($per_page, $offset); $query = $this->db->get('location_states'); return $query->result(); } //get paginated states count public function get_paginated_states_count() { $country = $this->input->get('country', true); $q = trim($this->input->get('q', true)); $this->db->join('location_countries', 'location_states.country_id = location_countries.id'); $this->db->select('location_states.*, location_countries.name as country_name, location_countries.status as country_status'); if (!empty($country)) { $this->db->where('location_states.country_id', $country); } if (!empty($q)) { $this->db->group_start(); $this->db->like('location_countries.name', $q); $this->db->or_like('location_states.name', $q); $this->db->group_end(); } $query = $this->db->get('location_states'); return $query->num_rows(); } //get state public function get_state($id) { $id = clean_number($id); $this->db->where('id', $id); $query = $this->db->get('location_states'); return $query->row(); } //get states by country public function get_states_by_country($country_id) { $this->db->where('country_id', clean_number($country_id)); $this->db->order_by('name'); $query = $this->db->get('location_states'); return $query->result(); } //delete state public function delete_state($id) { $id = clean_number($id); $state = $this->get_state($id); if (!empty($state)) { $this->db->where('id', $id); return $this->db->delete('location_states'); } return false; } //add city public function add_city() { $data = array( 'name' => $this->input->post('name', true), 'country_id' => $this->input->post('country_id', true), 'state_id' => $this->input->post('state_id', true) ); return $this->db->insert('location_cities', $data); } //update city public function update_city($id) { $data = array( 'name' => $this->input->post('name', true), 'country_id' => $this->input->post('country_id', true), 'state_id' => $this->input->post('state_id', true) ); $this->db->where('id', $id); return $this->db->update('location_cities', $data); } //get cities public function get_cities() { $this->db->order_by('name'); $query = $this->db->get('location_cities'); return $query->result(); } //get paginated cities public function get_paginated_cities($per_page, $offset) { $country = $this->input->get('country', true); $state = $this->input->get('state', true); $q = trim($this->input->get('q', true)); $this->db->join('location_countries', 'location_cities.country_id = location_countries.id'); $this->db->join('location_states', 'location_cities.state_id = location_states.id'); $this->db->select('location_cities.*, location_countries.name as country_name, location_states.name as state_name'); if (!empty($country)) { $this->db->where('location_cities.country_id', $country); } if (!empty($state)) { $this->db->where('location_cities.state_id', $state); } if (!empty($q)) { $this->db->group_start(); $this->db->like('location_countries.name', $q); $this->db->or_like('location_cities.name', $q); $this->db->group_end(); } $this->db->limit($per_page, $offset); $query = $this->db->get('location_cities'); return $query->result(); } //get paginated cities count public function get_paginated_cities_count() { $country = $this->input->get('country', true); $state = $this->input->get('state', true); $q = trim($this->input->get('q', true)); $this->db->join('location_countries', 'location_cities.country_id = location_countries.id'); $this->db->join('location_states', 'location_cities.state_id = location_states.id'); $this->db->select('location_cities.*'); if (!empty($country)) { $this->db->where('location_cities.country_id', $country); } if (!empty($state)) { $this->db->where('location_cities.state_id', $state); } if (!empty($q)) { $this->db->group_start(); $this->db->like('location_countries.name', $q); $this->db->or_like('location_cities.name', $q); $this->db->group_end(); } $query = $this->db->get('location_cities'); return $query->num_rows(); } //get city public function get_city($id) { $id = clean_number($id); $this->db->where('id', $id); $query = $this->db->get('location_cities'); return $query->row(); } //get cities by country public function get_cities_by_country($country_id) { $country_id = clean_number($country_id); $this->db->where('location_cities.country_id', $country_id); $this->db->order_by('location_cities.name'); $query = $this->db->get('location_cities'); return $query->result(); } //get cities by state public function get_cities_by_state($state_id) { $this->db->where('location_cities.state_id', clean_number($state_id)); $this->db->order_by('location_cities.name'); $query = $this->db->get('location_cities'); return $query->result(); } //delete city public function delete_city($id) { $id = clean_number($id); $city = $this->get_city($id); if (!empty($city)) { $this->db->where('id', $id); return $this->db->delete('location_cities'); } return false; } //search countries public function search_countries($val) { $val = remove_special_characters($val); $this->db->like('name', $val); $this->db->where('status', 1); $query = $this->db->get('location_countries'); return $query->result(); } //search states public function search_states($val) { $val = remove_special_characters($val); $this->db->join('location_countries', 'location_states.country_id = location_countries.id AND location_countries.status = 1'); $this->db->select('location_states.*, location_countries.name as country_name, location_countries.id as country_id'); $this->db->like('location_countries.name', $val); $this->db->or_like('location_states.name', $val); $this->db->or_like('CONCAT(location_states.name, " ", location_countries.name)', $val); $this->db->limit(150); $query = $this->db->get('location_states'); return $query->result(); } //search cities public function search_cities($val) { $val = remove_special_characters($val); $this->db->join('location_countries', 'location_cities.country_id = location_countries.id AND location_countries.status = 1'); $this->db->join('location_states', 'location_cities.state_id = location_states.id'); $this->db->select('location_cities.*, location_countries.id as country_id, location_countries.name as country_name, location_states.id as state_id, location_states.name as state_name'); $this->db->like('location_countries.name', $val); $this->db->or_like('location_states.name', $val); $this->db->or_like('location_cities.name', $val); $this->db->or_like('CONCAT(location_cities.name, " ",location_states.name, " ", location_countries.name)', $val); $this->db->limit(300); $query = $this->db->get('location_cities'); return $query->result(); } //get default location input public function get_default_location_input() { $str = ""; $key = ""; if (!empty($this->default_location->country_id)) { $select = "location_countries.name AS country"; $key = $this->default_location->country_id; if (!empty($this->default_location->state_id)) { $select .= ",(SELECT location_states.name FROM location_states WHERE location_states.id = " . clean_number($this->default_location->state_id) . ") AS state"; $key .= "_" . $this->default_location->state_id; } if (!empty($this->default_location->city_id)) { $select .= ",(SELECT location_cities.name FROM location_cities WHERE location_cities.id = " . clean_number($this->default_location->city_id) . ") AS city"; $key .= "_" . $this->default_location->state_id; } $result_cache = get_cached_data($this, "default_location_input", "st"); if (!empty($result_cache)) { if (!empty($result_cache[$key])) { return $result_cache[$key]; } } $this->db->select($select); $this->db->where('id', clean_number($this->default_location->country_id)); $query = $this->db->get('location_countries'); $row = $query->row(); if (!empty($row->city)) { $str .= $row->city . ', '; } if (!empty($row->state)) { $str .= $row->state . ', '; } if (!empty($row->country)) { $str .= $row->country; } $result_cache[$key] = $str; set_cache_data($this, "default_location_input", $result_cache, "st"); } return $str; } //get default location public function get_default_location() { $location = new stdClass(); $location->country_id = ""; $location->state_id = ""; $location->city_id = ""; $sess_location = $this->session->userdata('mds_default_location'); if (!empty($sess_location)) { $sess_location = unserialize_data($sess_location); $location->country_id = $sess_location->country_id; $location->state_id = $sess_location->state_id; $location->city_id = $sess_location->city_id; } return $location; } //set default location public function set_default_location() { $country_id = $this->input->post('country_id', true); $state_id = $this->input->post('state_id', true); $city_id = $this->input->post('city_id', true); $location = new stdClass(); $location->country_id = !empty($country_id) ? $country_id : 0; $location->state_id = !empty($state_id) ? $state_id : 0; $location->city_id = !empty($city_id) ? $city_id : 0; $this->session->set_userdata('mds_default_location', serialize($location)); } }