forked from joomla/Component-Builder
Added the return value if external component is detected in custom field gh-255
This commit is contained in:
parent
0a4b8f067f
commit
5d3a68b448
@ -126,7 +126,7 @@ Component Builder is mapped as a component in itself on my local development env
|
|||||||
+ *Author*: [Llewellyn van der Merwe](mailto:llewellyn@joomlacomponentbuilder.com)
|
+ *Author*: [Llewellyn van der Merwe](mailto:llewellyn@joomlacomponentbuilder.com)
|
||||||
+ *Name*: [Component Builder](http://joomlacomponentbuilder.com)
|
+ *Name*: [Component Builder](http://joomlacomponentbuilder.com)
|
||||||
+ *First Build*: 30th April, 2015
|
+ *First Build*: 30th April, 2015
|
||||||
+ *Last Build*: 30th March, 2018
|
+ *Last Build*: 2nd April, 2018
|
||||||
+ *Version*: 2.7.1
|
+ *Version*: 2.7.1
|
||||||
+ *Copyright*: Copyright (C) 2015. All Rights Reserved
|
+ *Copyright*: Copyright (C) 2015. All Rights Reserved
|
||||||
+ *License*: GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html
|
+ *License*: GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html
|
||||||
|
@ -126,7 +126,7 @@ Component Builder is mapped as a component in itself on my local development env
|
|||||||
+ *Author*: [Llewellyn van der Merwe](mailto:llewellyn@joomlacomponentbuilder.com)
|
+ *Author*: [Llewellyn van der Merwe](mailto:llewellyn@joomlacomponentbuilder.com)
|
||||||
+ *Name*: [Component Builder](http://joomlacomponentbuilder.com)
|
+ *Name*: [Component Builder](http://joomlacomponentbuilder.com)
|
||||||
+ *First Build*: 30th April, 2015
|
+ *First Build*: 30th April, 2015
|
||||||
+ *Last Build*: 30th March, 2018
|
+ *Last Build*: 2nd April, 2018
|
||||||
+ *Version*: 2.7.1
|
+ *Version*: 2.7.1
|
||||||
+ *Copyright*: Copyright (C) 2015. All Rights Reserved
|
+ *Copyright*: Copyright (C) 2015. All Rights Reserved
|
||||||
+ *License*: GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html
|
+ *License*: GNU/GPL Version 2 or later - http://www.gnu.org/licenses/gpl-2.0.html
|
||||||
|
@ -2800,6 +2800,46 @@ class Fields extends Structure
|
|||||||
isset($fieldData['view']) && isset($fieldData['views']) &&
|
isset($fieldData['view']) && isset($fieldData['views']) &&
|
||||||
ComponentbuilderHelper::checkString($fieldData['view']) && ComponentbuilderHelper::checkString($fieldData['views']))
|
ComponentbuilderHelper::checkString($fieldData['view']) && ComponentbuilderHelper::checkString($fieldData['views']))
|
||||||
{
|
{
|
||||||
|
// check that the component value is set
|
||||||
|
if (!isset($fieldData['component']) || !ComponentbuilderHelper::checkString($fieldData['component']))
|
||||||
|
{
|
||||||
|
$fieldData['component'] = "com_" . $this->fileContentStatic['###component###'];
|
||||||
|
}
|
||||||
|
// check that the componet has the com_ value in it
|
||||||
|
if (strpos($fieldData['component'], 'com_') === false || strpos($fieldData['component'], '=') !== false)
|
||||||
|
{
|
||||||
|
$fieldData['component'] = "com_" . $fieldData['component'];
|
||||||
|
}
|
||||||
|
// make sure the component is update if ### or [[[ component placeholder is used
|
||||||
|
if (strpos($fieldData['component'], '###') !== false || strpos($fieldData['component'], '[[[') !== false ) // should not be needed... but
|
||||||
|
{
|
||||||
|
$fieldData['component'] = $this->setPlaceholders($fieldData['component'], $this->placeholders);
|
||||||
|
}
|
||||||
|
// get core permissions
|
||||||
|
$coreLoad = false;
|
||||||
|
// add ref tags
|
||||||
|
$refLoad = true;
|
||||||
|
if (isset($this->permissionCore[$fieldData['view']]))
|
||||||
|
{
|
||||||
|
// get the core permission naming array
|
||||||
|
$core = $this->permissionCore[$fieldData['view']];
|
||||||
|
// set switch to activate easy update
|
||||||
|
$coreLoad = true;
|
||||||
|
// since the view is local to the component use this component name
|
||||||
|
$component = "com_" . $this->fileContentStatic['###component###'];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// fall back on the field component
|
||||||
|
$component = $fieldData['component'];
|
||||||
|
}
|
||||||
|
// check if we should add ref tags
|
||||||
|
if ($fieldData['component'] !== $component)
|
||||||
|
{
|
||||||
|
// do not add ref tags
|
||||||
|
$refLoad = false;
|
||||||
|
}
|
||||||
|
// start building the add buttons/s
|
||||||
$addButton = array();
|
$addButton = array();
|
||||||
$addButton[] = PHP_EOL . PHP_EOL . "\t/**";
|
$addButton[] = PHP_EOL . PHP_EOL . "\t/**";
|
||||||
$addButton[] = "\t * Override to add new button";
|
$addButton[] = "\t * Override to add new button";
|
||||||
@ -2831,45 +2871,29 @@ class Fields extends Structure
|
|||||||
$addButton[] = "\t\t\t//" . $this->setLine(__LINE__) . " check if new item";
|
$addButton[] = "\t\t\t//" . $this->setLine(__LINE__) . " check if new item";
|
||||||
$addButton[] = "\t\t\t\$ref = '';";
|
$addButton[] = "\t\t\t\$ref = '';";
|
||||||
$addButton[] = "\t\t\t\$refJ = '';";
|
$addButton[] = "\t\t\t\$refJ = '';";
|
||||||
$addButton[] = "\t\t\tif (!is_null(\$values['id']) && strlen(\$values['view']))";
|
if ($refLoad)
|
||||||
$addButton[] = "\t\t\t{";
|
|
||||||
$addButton[] = "\t\t\t\t//" . $this->setLine(__LINE__) . " only load referal if not new item.";
|
|
||||||
$addButton[] = "\t\t\t\t\$ref = '&ref=' . \$values['view'] . '&refid=' . \$values['id'];";
|
|
||||||
$addButton[] = "\t\t\t\t\$refJ = '&ref=' . \$values['view'] . '&refid=' . \$values['id'];";
|
|
||||||
$addButton[] = "\t\t\t}";
|
|
||||||
$addButton[] = "\t\t\t\$user = JFactory::getUser();";
|
|
||||||
$addButton[] = "\t\t\t//" . $this->setLine(__LINE__) . " only add if user allowed to create " . $fieldData['view'];
|
|
||||||
// check that the component value is set
|
|
||||||
if (!isset($fieldData['component']) || !ComponentbuilderHelper::checkString($fieldData['component']))
|
|
||||||
{
|
{
|
||||||
$fieldData['component'] = "com_" . $this->fileContentStatic['###component###'];
|
$addButton[] = "\t\t\tif (!is_null(\$values['id']) && strlen(\$values['view']))";
|
||||||
}
|
$addButton[] = "\t\t\t{";
|
||||||
// check that the componet has the com_ value in it
|
$addButton[] = "\t\t\t\t//" . $this->setLine(__LINE__) . " only load referal if not new item.";
|
||||||
if (strpos($fieldData['component'], 'com_') === false || strpos($fieldData['component'], '=') !== false)
|
$addButton[] = "\t\t\t\t\$ref = '&ref=' . \$values['view'] . '&refid=' . \$values['id'];";
|
||||||
{
|
$addButton[] = "\t\t\t\t\$refJ = '&ref=' . \$values['view'] . '&refid=' . \$values['id'];";
|
||||||
$fieldData['component'] = "com_" . $fieldData['component'];
|
$addButton[] = "\t\t\t}";
|
||||||
}
|
|
||||||
// make sure the component is update if ### or [[[ component placeholder is used
|
|
||||||
if (strpos($fieldData['component'], '###') !== false || strpos($fieldData['component'], '[[[') !== false ) // should not be needed... but
|
|
||||||
{
|
|
||||||
$fieldData['component'] = $this->setPlaceholders($fieldData['component'], $this->placeholders);
|
|
||||||
}
|
|
||||||
// get core permissions
|
|
||||||
$coreLoad = false;
|
|
||||||
if (isset($this->permissionCore[$fieldData['view']]))
|
|
||||||
{
|
|
||||||
// get the core permission naming array
|
|
||||||
$core = $this->permissionCore[$fieldData['view']];
|
|
||||||
// set switch to activate easy update
|
|
||||||
$coreLoad = true;
|
|
||||||
// since the view is local to the component use this component name
|
|
||||||
$component = "com_" . $this->fileContentStatic['###component###'];
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// fall back on the field component
|
$addButton[] = "\t\t\tif (!is_null(\$values['id']) && strlen(\$values['view']))";
|
||||||
$component = $fieldData['component'];
|
$addButton[] = "\t\t\t{";
|
||||||
|
$addButton[] = "\t\t\t\t//" . $this->setLine(__LINE__) . " get the return value.";
|
||||||
|
$addButton[] = "\t\t\t\t\$_uri = (string) JUri::getInstance();";
|
||||||
|
$addButton[] = "\t\t\t\t\$_return = urlencode(base64_encode(\$_uri));";
|
||||||
|
$addButton[] = "\t\t\t\t//" . $this->setLine(__LINE__) . " load return value.";
|
||||||
|
$addButton[] = "\t\t\t\t\$ref = '&return=' . \$_return;";
|
||||||
|
$addButton[] = "\t\t\t\t\$refJ = '&return=' . \$_return;";
|
||||||
|
$addButton[] = "\t\t\t}";
|
||||||
}
|
}
|
||||||
|
$addButton[] = "\t\t\t\$user = JFactory::getUser();";
|
||||||
|
$addButton[] = "\t\t\t//" . $this->setLine(__LINE__) . " only add if user allowed to create " . $fieldData['view'];
|
||||||
// check if the item has permissions.
|
// check if the item has permissions.
|
||||||
if ($coreLoad && isset($core['core.create']) && isset($this->permissionBuilder['global'][$core['core.create']]) && ComponentbuilderHelper::checkArray($this->permissionBuilder['global'][$core['core.create']]) && in_array($fieldData['view'], $this->permissionBuilder['global'][$core['core.create']]))
|
if ($coreLoad && isset($core['core.create']) && isset($this->permissionBuilder['global'][$core['core.create']]) && ComponentbuilderHelper::checkArray($this->permissionBuilder['global'][$core['core.create']]) && in_array($fieldData['view'], $this->permissionBuilder['global'][$core['core.create']]))
|
||||||
{
|
{
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<extension type="component" version="3.2" method="upgrade">
|
<extension type="component" version="3.2" method="upgrade">
|
||||||
<name>COM_COMPONENTBUILDER</name>
|
<name>COM_COMPONENTBUILDER</name>
|
||||||
<creationDate>30th March, 2018</creationDate>
|
<creationDate>2nd April, 2018</creationDate>
|
||||||
<author>Llewellyn van der Merwe</author>
|
<author>Llewellyn van der Merwe</author>
|
||||||
<authorEmail>llewellyn@joomlacomponentbuilder.com</authorEmail>
|
<authorEmail>llewellyn@joomlacomponentbuilder.com</authorEmail>
|
||||||
<authorUrl>http://joomlacomponentbuilder.com</authorUrl>
|
<authorUrl>http://joomlacomponentbuilder.com</authorUrl>
|
||||||
|
Loading…
Reference in New Issue
Block a user