2023-04-15 14:49:41 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* @package Joomla.Component.Builder
|
|
|
|
*
|
|
|
|
* @created 3rd September, 2020
|
|
|
|
* @author Llewellyn van der Merwe <https://dev.vdm.io>
|
|
|
|
* @git Joomla Component Builder <https://git.vdm.dev/joomla/Component-Builder>
|
|
|
|
* @copyright Copyright (C) 2015 Vast Development Method. All rights reserved.
|
|
|
|
* @license GNU General Public License version 2 or later; see LICENSE.txt
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace VDM\Joomla\Utilities\String;
|
|
|
|
|
|
|
|
|
|
|
|
use Joomla\CMS\Component\ComponentHelper;
|
|
|
|
use VDM\Joomla\Utilities\StringHelper;
|
|
|
|
use VDM\Joomla\Utilities\Component\Helper;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Control the naming of a field type
|
|
|
|
*
|
|
|
|
* @since 3.0.9
|
|
|
|
*/
|
|
|
|
abstract class TypeHelper
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* The field builder switch
|
|
|
|
*
|
|
|
|
* @since 3.0.9
|
|
|
|
*/
|
|
|
|
protected static $builder = false;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Making field type name safe
|
|
|
|
*
|
|
|
|
* @param String $string The you would like to make safe
|
|
|
|
* @param String $option The option for the component.
|
|
|
|
*
|
|
|
|
* @returns string on success
|
|
|
|
*
|
|
|
|
* @since 3.0.9
|
|
|
|
*/
|
|
|
|
public static function safe($string, $option = null)
|
|
|
|
{
|
|
|
|
// get global value
|
|
|
|
if (self::$builder === false)
|
|
|
|
{
|
|
|
|
self::$builder = Helper::getParams($option)->get('type_name_builder', 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
// use the new convention
|
|
|
|
if (2 == self::$builder)
|
|
|
|
{
|
|
|
|
// 0nly continue if we have a string
|
|
|
|
if (StringHelper::check($string))
|
|
|
|
{
|
|
|
|
// check that the first character is not a number
|
|
|
|
if (is_numeric(substr($string, 0, 1)))
|
|
|
|
{
|
|
|
|
$string = StringHelper::numbers($string);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Transliterate string
|
|
|
|
$string = StringHelper::transliterate($string);
|
|
|
|
|
|
|
|
// remove all and keep only characters and numbers and point (TODO just one point)
|
2023-10-24 08:36:53 +00:00
|
|
|
$string = trim(preg_replace("/[^A-Za-z0-9_\.]/", '', (string) $string));
|
2023-04-15 14:49:41 +00:00
|
|
|
|
|
|
|
// best is to return lower (for all string equality in compiler)
|
|
|
|
return strtolower($string);
|
|
|
|
}
|
|
|
|
// not a string
|
|
|
|
return '';
|
|
|
|
}
|
|
|
|
|
|
|
|
// use the default (original behaviour/convention)
|
|
|
|
return StringHelper::safe($string);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|