HEX
Server: Apache
System: Linux server2.voipitup.com.au 4.18.0-553.104.1.lve.el8.x86_64 #1 SMP Tue Feb 10 20:07:30 UTC 2026 x86_64
User: posscale (1027)
PHP: 8.2.29
Disabled: exec,passthru,shell_exec,system
Upload Files
File: /home/posscale/subdomains/Phone_directories/lib/types/pykotaBillingCodeType.inc
<?php
/*
$Id: pykotaBillingCodeType.inc 5062 2013-10-15 16:12:39Z gruberroland $

  This code is part of LDAP Account Manager (http://www.ldap-account-manager.org/)
  Copyright (C) 2013  Roland Gruber

  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 2 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, write to the Free Software
  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA

*/

/**
* The account type for PyKota billing codes.
*
* @package types
* @author Roland Gruber
*/

/**
* The account type for PyKota billing codes.
*
* @package types
*/
class pykotaBillingCodeType extends baseType {
	
	/**
	 * Constructs a new billing code object.
	 */
	public function __construct() {
		parent::__construct();
		$this->LABEL_CREATE_ANOTHER_ACCOUNT = _('Create another billing code');
		$this->LABEL_BACK_TO_ACCOUNT_LIST = _('Back to billing code list');
	}
	
	/**
	* Returns the alias name of this account type.
	*
	* @return string alias name
	*/
	function getAlias() {
		return _("Billing codes");
	}
	
	/**
	* Returns the description of this account type.
	*
	* @return string description
	*/
	function getDescription() {
		return _("PyKota billing codes");
	}
		
	/**
	* Returns the class name for the list object.
	*
	* @return string class name
	*/
	function getListClassName() {
		return "lamPykotaBillingCodeTypeList";
	}
	
	/**
	* Returns the default attribute list for this account type.
	*
	* @return string attribute list
	*/
	function getDefaultListAttributes() {
		return "#cn;#description;#pykotaBalance;#pykotaPageCounter";
	}

	/**
	* Returns a list of attributes which have a translated description.
	* This is used for the head row in the list view.
	*
	* @return array list of descriptions
	*/
	function getListAttributeDescriptions() {
		return array (
			"cn" => _('Billing code'),
			"description" => _('Description'),
			'pykotaBalance' => _('Balance'),
			'pykotaPageCounter' => _('Page count'),
		);
	}

	/**
	 * Returns the the title text for the title bar on the new/edit page.
	 *
	 * @param accountContainer $container account container
	 * @return String title text
	 */
	public function getTitleBarTitle($container) {
		// get attributes
		$attributes = array();
		if ($container->getAccountModule('pykotaBillingCode') != null) {
			$attributes = $container->getAccountModule('pykotaBillingCode')->getAttributes();
		}
		// check if pykotaBillingCode is set
		if (isset($attributes['pykotaBillingCode'][0])) {
			return htmlspecialchars($attributes['pykotaBillingCode'][0]);
		}
		// show new label
		if ($container->isNewAccount) {
			return _("New billing code");
		}
		// fall back to default
		return parent::getTitleBarTitle($container);
	}
	
	/**
	 * Returns the the subtitle text for the title bar on the new/edit page.
	 *
	 * @param accountContainer $container account container
	 * @return String title text
	 */
	public function getTitleBarSubtitle($container) {
		// get attributes
		$attributes = array();
		if ($container->getAccountModule('pykotaBillingCode') != null) {
			$attributes = $container->getAccountModule('pykotaBillingCode')->getAttributes();
		}
		// check if description is set
		if (isset($attributes['description'][0])) {
			return htmlspecialchars($attributes['description'][0]);
		}
		// fall back to default
		return parent::getTitleBarSubtitle($container);
	}

}


/**
 * Generates the list view.
 *
 * @package lists
 * @author Roland Gruber
 * 
 */
class lamPykotaBillingCodeTypeList extends lamList {

	/**
	 * Constructor
	 *
	 * @param string $type account type
	 * @return lamList list object
	 */
	function __construct($type) {
		parent::__construct($type);
		$this->labels = array(
			'nav' => _("Billing code count: %s"),
			'error_noneFound' => _("No billing codes found!"),
			'newEntry' => _("New billing code"),
			'deleteEntry' => _("Delete selected billing codes"));
	}
	
}


?>