Files
opensourcepos/app/Models/Item_taxes.php
objec 1c2112a78b Add model functions needed for plugins
- getDateAdded and getDatesAdded in Inventory.php
- GetDistinctCategories in Item.php
- GetBulkItemQuantities in Item_quantity.php
- GetBulkInfo in Item_taxes.php
- GetStockLocationsByItem in Stock_location.php

Signed-off-by: objec <objecttothis@gmail.com>
2026-05-18 16:15:24 +04:00

119 lines
3.0 KiB
PHP

<?php
namespace App\Models;
use CodeIgniter\Model;
/**
* Item_taxes class
*/
class Item_taxes extends Model
{
protected $table = 'items_taxes';
protected $primaryKey = 'item_id';
protected $useAutoIncrement = false;
protected $useSoftDeletes = false;
protected $allowedFields = [
'name',
'percent'
];
/**
* Gets tax info for a particular item
*/
public function get_info(int $item_id): array
{
$builder = $this->db->table($this->table);
$builder->where('item_id', $item_id);
// Return an array of taxes for an item
return $builder->get()->getResultArray();
}
/**
* Get all the taxes of given items. Used by plugins. Do not remove from code.
*
* @param array $itemIds
* @param bool $getDeleted
* @return array
*/
public function getBulkInfo(array $itemIds, bool $getDeleted = false): array
{
$builder = $this->db->table($this->table);
$builder->whereIn('items_taxes.item_id', $itemIds);
if (!$getDeleted) {
$builder->join('items', 'items.item_id = items_taxes.item_id');
$builder->where('items.deleted', 0);
$builder->select('items_taxes.*');
}
return $builder->get()->getResultArray();
}
/**
* Inserts or updates an item's taxes
*/
public function save_value(array &$items_taxes_data, int $item_id): bool
{
$success = true;
// Run these queries as a transaction, we want to make sure we do all or nothing
$this->db->transStart();
$this->delete($item_id);
$builder = $this->db->table($this->table);
foreach ($items_taxes_data as $row) {
$row['item_id'] = $item_id;
$success &= $builder->insert($row);
}
$this->db->transComplete();
$success &= $this->db->transStatus();
return $success;
}
/**
* Saves taxes for multiple items
*/
public function save_multiple(array &$items_taxes_data, string $item_ids): bool // TODO: investigate why this is sent as a : delimited string rather than an array.
{
$success = true;
// Run these queries as a transaction, we want to make sure we do all or nothing
$this->db->transStart();
foreach (explode(':', $item_ids) as $item_id) {
$this->delete($item_id);
$builder = $this->db->table($this->table);
foreach ($items_taxes_data as $row) {
$row['item_id'] = $item_id;
$success &= $builder->insert($row);
}
}
$this->db->transComplete();
$success &= $this->db->transStatus();
return $success;
}
/**
* Deletes taxes given an item
*/
public function delete($item_id = null, bool $purge = false): bool
{
$builder = $this->db->table('items_taxes');
return $builder->delete(['item_id' => $item_id]);
}
}