0
0
mirror of https://github.com/salesagility/SuiteCRM.git synced 2025-01-03 09:08:37 +00:00
salesagility_SuiteCRM/modules/ModuleBuilder/MB/MBLanguage.php
2023-07-18 15:54:11 +01:00

319 lines
13 KiB
PHP
Executable File

<?php
/**
*
* SugarCRM Community Edition is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004-2013 SugarCRM Inc.
*
* SuiteCRM is an extension to SugarCRM Community Edition developed by SalesAgility Ltd.
* Copyright (C) 2011 - 2018 SalesAgility Ltd.
*
* This program is free software; you can redistribute it and/or modify it under
* the terms of the GNU Affero General Public License version 3 as published by the
* Free Software Foundation with the addition of the following permission added
* to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
* IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
* OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
*
* 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 Affero General Public License for more
* details.
*
* You should have received a copy of the GNU Affero General Public License along with
* this program; if not, see http://www.gnu.org/licenses or write to the Free
* Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
* 02110-1301 USA.
*
* You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
* SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
*
* The interactive user interfaces in modified source and object code versions
* of this program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU Affero General Public License version 3.
*
* In accordance with Section 7(b) of the GNU Affero General Public License version 3,
* these Appropriate Legal Notices must retain the display of the "Powered by
* SugarCRM" logo and "Supercharged by SuiteCRM" logo. If the display of the logos is not
* reasonably feasible for technical reasons, the Appropriate Legal Notices must
* display the words "Powered by SugarCRM" and "Supercharged by SuiteCRM".
*/
#[\AllowDynamicProperties]
class MBLanguage
{
public $iTemplates = array();
public $templates = array();
public function __construct($name, $path, $label, $key_name)
{
$this->path = $path;
$this->name = $name;
$this->key_name = $key_name;
$this->label = $label;
}
public function load()
{
$this->generateModStrings();
$this->generateAppStrings();
}
public function loadStrings($file)
{
global $mod_strings;
$mod_strings = $mod_strings ?? [];
$module = strtoupper($this->name);
$object_name = strtoupper($this->key_name);
$_object_name = strtolower($this->name);
if (!file_exists($file)) {
return;
}
$d = dir($file);
while ($e = $d->read()) {
if (substr($e, 0, 1) != '.' && is_file($file . '/' . $e)) {
include($file.'/'. $e);
if (empty($this->strings[$e])) {
$this->strings[$e] = $mod_strings;
} else {
$this->strings[$e] = array_merge($this->strings[$e], $mod_strings);
}
}
}
}
public function loadAppListStrings($file)
{
global $app_list_strings;
$app_list_strings = $app_list_strings ?? [];
if (!file_exists($file)) {
return;
}
//we may not need this when loading in the app strings, but there is no harm
//in setting it.
$object_name = strtolower($this->key_name);
$d = dir($file);
while ($e = $d->read()) {
if (substr($e, 0, 1) != '.' && is_file($file . '/' . $e)) {
include($file.'/'. $e);
if (empty($this->appListStrings[$e])) {
$this->appListStrings[$e] = $app_list_strings;
} else {
$this->appListStrings[$e] = array_merge($this->appListStrings[$e], $app_list_strings);
}
}
}
}
public function generateModStrings()
{
$this->strings = array();
$this->loadTemplates();
$current_mod_strings = $GLOBALS['mod_strings'];
foreach ($this->iTemplates as $template=>$val) {
$file = MB_IMPLEMENTS . '/' . $template . '/language';
$this->loadStrings($file);
}
foreach ($this->templates as $template=>$val) {
$file = MB_TEMPLATES . '/' . $template . '/language';
$this->loadStrings($file);
}
$this->loadStrings($this->path . '/language');
//reset global mod_string to prevent conflicts with Module Builder modules
$GLOBALS['mod_strings'] = $current_mod_strings;
}
public function getModStrings($language='en_us')
{
$language .= '.lang.php';
if (!empty($this->strings[$language]) && $language != 'en_us.lang.php') {
return sugarLangArrayMerge($this->strings['en_us.lang.php'], $this->strings[$language]);
}
if (!empty($this->strings['en_us.lang.php'])) {
return $this->strings['en_us.lang.php'];
}
$empty = array();
return $empty;
}
public function getAppListStrings($language='en_us')
{
$language .= '.lang.php';
if (!empty($this->appListStrings[$language]) && $language != 'en_us.lang.php') {
return sugarLangArrayMerge($this->appListStrings['en_us.lang.php'], $this->appListStrings[$language]);
}
if (!empty($this->appListStrings['en_us.lang.php'])) {
return $this->appListStrings['en_us.lang.php'];
}
$empty = array();
return $empty;
}
public function generateAppStrings($buildFromTemplate = true)
{
$this->appListStrings = array('en_us.lang.php'=>array());
//By default, generate app strings for the current language as well.
$this->appListStrings[$GLOBALS [ 'current_language' ] . ".lang.php"] = array();
$this->loadAppListStrings($this->path . '/../../language/application');
if ($buildFromTemplate) {
//go through the templates application strings and load anything that is needed
foreach ($this->iTemplates as $template=>$val) {
$file = MB_IMPLEMENTS . '/' . $template . '/language/application';
$this->loadAppListStrings($file);
}
foreach ($this->templates as $template=>$val) {
$file = MB_TEMPLATES . '/' . $template . '/language/application';
$this->loadAppListStrings($file);
}
}
}
public function save($key_name, $duplicate=false, $rename=false)
{
$header = file_get_contents('modules/ModuleBuilder/MB/header.php');
$save_path = $this->path . '/language';
mkdir_recursive($save_path);
foreach ($this->strings as $lang=>$values) {
//Check if the module Label has changed.
$renameLang = $rename || empty($values) || (isset($values['LBL_MODULE_NAME']) && $this->label != $values['LBL_MODULE_NAME']);
$mod_strings = return_module_language(str_replace('.lang.php', '', (string) $lang), 'ModuleBuilder');
$required = array(
'LBL_LIST_FORM_TITLE'=>$this->label . " " . $mod_strings['LBL_LIST'],
'LBL_MODULE_NAME'=>$this->label,
'LBL_MODULE_TITLE'=>$this->label,
'LBL_HOMEPAGE_TITLE'=>$mod_strings['LBL_HOMEPAGE_PREFIX'] . " " . $this->label,
//FOR GENERIC MENU
'LNK_NEW_RECORD'=>$mod_strings['LBL_CREATE'] ." ". $this->label,
'LNK_LIST'=>$mod_strings['LBL_VIEW'] ." ". $this->label,
'LNK_IMPORT_'.strtoupper($this->key_name)=>translate('LBL_IMPORT') ." ". $this->label,
'LBL_SEARCH_FORM_TITLE'=>$mod_strings['LBL_SEARCH_BUTTON'] ." ". $this->label,
'LBL_HISTORY_SUBPANEL_TITLE'=>$mod_strings['LBL_HISTORY'],
'LBL_ACTIVITIES_SUBPANEL_TITLE'=>$mod_strings['LBL_ACTIVITIES'],
'LBL_'.strtoupper($this->key_name).'_SUBPANEL_TITLE'=>$this->label,
'LBL_NEW_FORM_TITLE' => $mod_strings['LBL_NEW'] ." ". $this->label,
);
foreach ($required as $k=>$v) {
if (empty($values[$k]) || $renameLang) {
$values[$k] = $v;
}
}
write_array_to_file('mod_strings', $values, $save_path .'/'.$lang, 'w', $header);
}
$app_save_path = $this->path . '/../../language/application';
mkdir_recursive($app_save_path);
$key_changed = ($this->key_name != $key_name);
foreach ($this->appListStrings as $lang=>$values) {
// Load previously created modules data
// $app_list_strings = array (); --- fix for issue #305
$neededFile = $app_save_path . '/'. $lang;
if (file_exists($neededFile)) {
include $neededFile;
}
if (!$duplicate) {
unset($values['moduleList'][$this->key_name]);
}
// $values = sugarLangArrayMerge($values, $app_list_strings); --- fix for issue #305
$values['moduleList'][$key_name]= $this->label;
$appFile = $header. "\n";
require_once('include/utils/array_utils.php');
$this->getGlobalAppListStringsForMB($values);
foreach ($values as $key=>$array) {
if ($duplicate) {
//keep the original when duplicating
$appFile .= override_value_to_string_recursive2('app_list_strings', $key, $array);
}
$okey = $key;
if ($key_changed) {
$key = str_replace($this->key_name, $key_name, (string) $key);
}
if ($key_changed) {
$key = str_replace(strtolower($this->key_name), strtolower($key_name), (string) $key);
}
// if we aren't duplicating or the key has changed let's add it
if (!$duplicate || $okey != $key) {
$appFile .= override_value_to_string_recursive2('app_list_strings', $key, $array);
}
}
sugar_file_put_contents($app_save_path . '/'. $lang, $appFile);
}
}
/**
* If there is no this dropdown list in custom\modulebuilder\packages\$package\language\application\$lang.lang.php ,
* we will include it from global app_list_string array into custom\modulebuilder\packages\$package\language\application\$lang.lang.php
* when we create a dropdown filed and the value is created in MB.(#20728 )
**/
public function getGlobalAppListStringsForMB(&$values)
{
//Ensure it comes from MB
if (!empty($_REQUEST['view_package']) && !empty($_REQUEST['type']) && $_REQUEST['type'] == 'enum' && !empty($_REQUEST['options'])) {
if (!isset($values[$_REQUEST['options']])) {
global $app_list_strings;
if (!empty($app_list_strings[$_REQUEST['options']])) {
$values[$_REQUEST['options']] = $app_list_strings[$_REQUEST['options']];
}
}
}
}
public function build($path)
{
if (file_exists($this->path.'/language/')) {
copy_recursive($this->path.'/language/', $path . '/language/');
}
}
public function loadTemplates()
{
if (empty($this->templates)) {
if (file_exists("$this->path/config.php")) {
$config = [];
include "$this->path/config.php";
$this->templates = $config['templates'];
$this->iTemplates = array();
}
}
}
/**
* Reset the templates and load the language files again. This is called from
* MBModule->save() once the config file has been written.
*/
public function reload()
{
$this->templates = null;
$this->load();
}
/**
* Attempts to translate the given label if it is contained in this
* undeployed module's language strings
*
* @param string $label Label to translate
* @param string $language Language to use to translate the label
* @return string
*/
public function translate($label, $language = "en_us")
{
$language = $language . ".lang.php";
if (isset($this->strings[$language][$label])) {
return $this->strings[$language][$label];
}
if (isset($this->appListStrings[$language][$label])) {
return $this->appListStrings[$language][$label];
}
return $label;
}
}