diff --git a/.gitmodules b/.gitmodules index 2a7690ae..bc01ee6e 100644 --- a/.gitmodules +++ b/.gitmodules @@ -7,3 +7,6 @@ [submodule "lib/chibi-sql"] path = lib/chibi-sql url = https://github.com/rr-/chibi-sql.git +[submodule "lib/TextCaseConverter"] + path = lib/TextCaseConverter + url = https://gist.github.com/rr-/10522533.git diff --git a/lib/TextCaseConverter b/lib/TextCaseConverter new file mode 160000 index 00000000..eabd7f5f --- /dev/null +++ b/lib/TextCaseConverter @@ -0,0 +1 @@ +Subproject commit eabd7f5ff2a1d1eb8a683e6bc658d613a56980b0 diff --git a/src/Enum.php b/src/Enum.php index e4bcb8ca..ad74989a 100644 --- a/src/Enum.php +++ b/src/Enum.php @@ -8,6 +8,13 @@ class Enum return array_search($constant, $constants); } + public static function toDisplayString($constant) + { + TextCaseConverter::convert(static::toString($constant), + TextCaseConverter::SNAKE_CASE, + TextCaseConverter::BLANK_CASE); + } + public static function getAll() { $cls = new ReflectionClass(get_called_class()); diff --git a/src/Helpers/PrivilegesHelper.php b/src/Helpers/PrivilegesHelper.php index 2e2a7654..5252b736 100644 --- a/src/Helpers/PrivilegesHelper.php +++ b/src/Helpers/PrivilegesHelper.php @@ -11,8 +11,14 @@ class PrivilegesHelper if (strpos($key, '.') === false) $key .= '.'; list ($privilegeName, $subPrivilegeName) = explode('.', $key); - $privilegeName = TextHelper::camelCaseToKebabCase($privilegeName); - $subPrivilegeName = TextHelper::camelCaseToKebabCase($subPrivilegeName); + + $privilegeName = TextCaseConverter::convert($privilegeName, + TextCaseConverter::CAMEL_CASE, + TextCaseConverter::SPINAL_CASE); + $subPrivilegeName = TextCaseConverter::convert($subPrivilegeName, + TextCaseConverter::CAMEL_CASE, + TextCaseConverter::SPINAL_CASE); + $key = rtrim($privilegeName . '.' . $subPrivilegeName, '.'); $minAccessRank = TextHelper::resolveConstant($minAccessRankName, 'AccessRank'); @@ -34,7 +40,10 @@ class PrivilegesHelper $user = \Chibi\Registry::getContext()->user; $minAccessRank = AccessRank::Admin; - $key = TextHelper::camelCaseToKebabCase(Privilege::toString($privilege)); + $key = TextCaseConverter::convert(Privilege::toString($privilege), + TextCaseConverter::CAMEL_CASE, + TextCaseConverter::SPINAL_CASE); + if (isset(self::$privileges[$key])) { $minAccessRank = self::$privileges[$key]; diff --git a/src/Helpers/TextHelper.php b/src/Helpers/TextHelper.php index 30b212e1..f798ea0e 100644 --- a/src/Helpers/TextHelper.php +++ b/src/Helpers/TextHelper.php @@ -17,61 +17,12 @@ class TextHelper return $text; } - //todo: convert to enum and make one method - public static function snakeCaseToCamelCase($string, $lower = false) - { - $string = explode('_', $string); - $string = array_map('trim', $string); - $string = array_map('ucfirst', $string); - $string = join('', $string); - if ($lower) - $string = lcfirst($string); - return $string; - } - - public static function kebabCaseToCamelCase($string) - { - $string = explode('-', $string); - $string = array_map('trim', $string); - $string = array_map('ucfirst', $string); - $string = join('', $string); - return $string; - } - - public static function camelCaseToKebabCase($string) - { - $string = preg_replace_callback('/[A-Z]/', function($x) - { - return '-' . strtolower($x[0]); - }, $string); - $string = trim($string, '-'); - return $string; - } - - public static function camelCaseToHumanCase($string, $ucfirst = false) - { - $string = preg_replace_callback('/[A-Z]/', function($x) - { - return ' ' . strtolower($x[0]); - }, $string); - $string = trim($string); - if ($ucfirst) - $string = ucfirst($string); - return $string; - } - - public static function humanCaseToKebabCase($string) - { - $string = trim($string); - $string = str_replace(' ', '-', $string); - $string = strtolower($string); - return $string; - } - public static function resolveConstant($constantName, $className = null) { - $constantName = self::kebabCaseToCamelCase($constantName); - //convert from kebab-case to CamelCase + $constantName = TextCaseConverter::convert($constantName, + TextCaseConverter::SPINAL_CASE, + TextCaseConverter::CAMEL_CASE); + if ($className !== null) { $constantName = $className . '::' . $constantName; diff --git a/src/Models/AbstractCrudModel.php b/src/Models/AbstractCrudModel.php index 1e8d779f..f6c6b503 100644 --- a/src/Models/AbstractCrudModel.php +++ b/src/Models/AbstractCrudModel.php @@ -75,7 +75,10 @@ abstract class AbstractCrudModel implements IModel $entity = self::spawn(); foreach ($row as $key => $val) { - $key = TextHelper::snakeCaseToCamelCase($key, true); + $key = TextCaseConverter::convert($key, + TextCaseConverter::SNAKE_CASE, + TextCaseConverter::LOWER_CAMEL_CASE); + $entity->$key = $val; } return $entity; @@ -93,7 +96,12 @@ abstract class AbstractCrudModel implements IModel if (isset($keyCache[$key])) $key = $keyCache[$key]; else - $key = $keyCache[$key] = TextHelper::snakeCaseToCamelCase($key, true); + { + $key = $keyCache[$key] = TextCaseConverter::convert($key, + TextCaseConverter::SNAKE_CASE, + TextCaseConverter::LOWER_CAMEL_CASE); + } + $entity->$key = $val; } $entities[$i] = $entity; diff --git a/src/Views/post-edit.phtml b/src/Views/post-edit.phtml index 4d2d2ab7..f24af211 100644 --- a/src/Views/post-edit.phtml +++ b/src/Views/post-edit.phtml @@ -7,7 +7,7 @@ diff --git a/src/Views/post-list-wrapper.phtml b/src/Views/post-list-wrapper.phtml index 05012c5d..45e5fdad 100644 --- a/src/Views/post-list-wrapper.phtml +++ b/src/Views/post-list-wrapper.phtml @@ -44,9 +44,9 @@ if (PrivilegesHelper::confirm(Privilege::MassTag)) $tab): ?> -