HEX
Server: Apache
System: Linux srv13.cpanelhost.cl 3.10.0-962.3.2.lve1.5.38.el7.x86_64 #1 SMP Thu Jun 18 05:28:41 EDT 2020 x86_64
User: cca63905 (4205)
PHP: 7.3.20
Disabled: NONE
Upload Files
File: //proc/self/cwd/guiaweb/htdocs/core/class/html.formcategory.class.php
<?php
/* Copyright (C) 2020		Tobias Sekan	<tobias.sekan@startmail.com>
 * Copyright (C) 2024       Frédéric France             <frederic.france@free.fr>
 * Copyright (C) 2024		MDW							<mdeweerd@users.noreply.github.com>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program. If not, see <https://www.gnu.org/licenses/>.
 */

/**
 *	\file		htdocs/core/class/html.formcategory.class.php
 *	\ingroup	core
 *	\brief		File of class to build HTML component for category filtering
 */

require_once DOL_DOCUMENT_ROOT.'/core/class/html.form.class.php';
require_once DOL_DOCUMENT_ROOT.'/categories/class/categorie.class.php';


/**
 *	Class to manage forms for categories
 */
class FormCategory extends Form
{
	/**
	 * Return a HTML filter box for a list filter view
	 *
	 * @param 	string		$type								The categorie type (e.g Categorie::TYPE_WAREHOUSE)
	 * @param 	array<int|string>	$preSelected				A list with the elements that should pre-selected
	 * @param	string		$morecss							More CSS
	 * @param	int<-1,1>	$searchCategoryProductOperator		Used only if $multiselect is 1. Set to 0 or 1 to enable the checkbox to search with a or (0=not preselected, 1=preselected), -1=Checkbox never shown.
	 * @param	int<0,1>	$multiselect						0 or 1
	 * @param	int<0,1>	$nocateg							1=Add an entry '- No Category -'
	 * @param	int<1,1>|string	$showempty						1 or 'string' to add an empty entry
	 * @return 	string											A HTML filter box (Note: selected results can get with GETPOST("search_category_".$type."_list"))
	 */
	public function getFilterBox($type, array $preSelected, $morecss = "minwidth300imp widthcentpercentminusx", $searchCategoryProductOperator = -1, $multiselect = 1, $nocateg = 1, $showempty = '')
	{
		global $langs, $db;

		if (empty($preSelected) || !is_array($preSelected)) {
			$preSelected = array();
		}

		if ($showempty && !is_numeric($showempty)) {
			$tmptitle = $showempty;
		} else {
			$tmptitle = $langs->transnoentitiesnoconv("Category");
		}

		$filter = '';
		$filter .= '<div class="divsearchfield">';
		$filter .= img_picto($tmptitle, 'category', 'class="pictofixedwidth"');
		if ($multiselect) {
			$categoryArray = $this->select_all_categories($type, '', '', 64, 0, 2);
			if ($nocateg) {
				$langs->load("categories");
				$categoryArray[-2] = "- ".$langs->trans('NotCategorized')." -";
			}
			$htmlName = "search_category_".$type."_list";
			$htmlName2 = "search_category_".$type."_operator";

			$filter .= Form::multiselectarray($htmlName, $categoryArray, $preSelected, 0, 0, $morecss, 0, 0, '', '', $tmptitle);
		} else {
			$htmlName = "search_".$type."_category";
			$htmlName2 = "";
			require_once DOL_DOCUMENT_ROOT.'/core/class/html.formother.class.php';
			$formother = new FormOther($db);

			$filter .= $formother->select_categories($type, $preSelected[0], $htmlName, $nocateg, $tmptitle, $morecss);
		}
		if ($multiselect && $searchCategoryProductOperator >= 0) {
			$filter .= ' <input type="checkbox" class="valignmiddle '.$htmlName2.'" id="'.$htmlName2.'" name="'.$htmlName2.'" value="1"'.($searchCategoryProductOperator == 1 ? ' checked="checked"' : '').' title="'.dol_escape_htmltag($langs->trans('UseOrOperatorForCategories')).'" />';
			$filter .= '<label class="none valignmiddle '.$htmlName2.'" for="'.$htmlName2.'" title="'.dol_escape_htmltag($langs->trans('UseOrOperatorForCategories')).'">';
			$filter .= $langs->trans('UseOrOperatorShort');
			$filter .= '</label>';

			$filter .= '<script>'."\n";
			$filter .= "var nbSelected = jQuery('#".$htmlName."').val().length;";
			$filter .= "console.log('Nb of element now = '+nbSelected);\n";
			$filter .= "if (nbSelected > 1) { jQuery('.".$htmlName2."').show(); } else { jQuery('.".$htmlName2."').hide(); }\n";
			$filter .= "jQuery('#".$htmlName."').change(function() {\n";
			$filter .= "console.log('Content of select box has been modified.');";
			$filter .= 'var nbSelected = $(this).val().length;';
			$filter .= "console.log('Nb of element now = '+nbSelected);\n";
			$filter .= "if (nbSelected > 1) { jQuery('.".$htmlName2."').show(); } else { jQuery('.".$htmlName2."').hide(); }\n";
			$filter .= '});'."\n";
			$filter .= '</script>'."\n";
		}
		$filter .= "</div>";

		return $filter;
	}

	/**
	 *    Prints a select form for products categories
	 *    TODO Remove this. We should already have a generic method to get list of product category.
	 *
	 *    @param    int 	$selected          	Id category pre-selection
	 *    @param    string	$htmlname          	Name of HTML field
	 *    @param    int		$showempty         	Add an empty field
	 *    @return	int|null
	 */
	public function selectProductCategory($selected = 0, $htmlname = 'product_category_id', $showempty = 0)
	{
		$sql = "SELECT cat.rowid, cat.label";
		$sql .= " FROM ".MAIN_DB_PREFIX."categorie as cat";
		$sql .= " WHERE cat.type = 0";

		dol_syslog(get_class($this)."::selectProductCategory", LOG_DEBUG);
		$resql = $this->db->query($sql);
		if ($resql) {
			print '<select class="flat minwidth100" id="select_'.$htmlname.'" name="'.$htmlname.'">';
			if ($showempty) {
				print '<option value="0">&nbsp;</option>';
			}

			$i = 0;
			$num_rows = $this->db->num_rows($resql);
			while ($i < $num_rows) {
				$category = $this->db->fetch_object($resql);
				if ($selected && $selected == $category->rowid) {
					print '<option value="'.$category->rowid.'" selected>'.$category->label.'</option>';
				} else {
					print '<option value="'.$category->rowid.'">'.$category->label.'</option>';
				}
				$i++;
			}
			print('</select>');

			return $num_rows;
		} else {
			dol_print_error($this->db);
			return null;
		}
	}
}