SuiteCRM-Core/lib/Robo/Plugin/Commands/BuildCommands.php
Clemente Raposo d075ac6581 Squashed 'public/legacy/' changes from 23d711b70..bb959a145
bb959a145 SuiteCRM 7.12.1 release changes
9ad0a7fe5 Use wildcard rather than the defunct "_all" field
d9f34d544 Prevent Email Reminders - Inactive Users
72557797d Create Standardised isEnabled User Check
c1f5c8c62 Fix #8432 - Remove index limit from mssql index names upon create and repair
edf9ff254 Fix #9217 - Revert "Fix Users index incompatible with MSSQL"
91035782b Fix #9119 - Rebuild theme cache after custom property changed in Studio
dd000459c Fix typo in word administrator
8bb65887d Fix Issue #9192: Fix duplication of folders_rel table entries.
4104e5c5c Fix #9367 - Update PDF template warning
86b04461a Fix #9358 - Meeting invite notification emails not sending to all invitees.
e55657e18 Fix #6994: Update pollMonitoredInboxesAOP to check SugarFolder has been retrieved correctly.
8211f43fb Update PDF references
63d63e520 Implement PDF extension
75553a9ee Update MPDF structure
1960e8364 Fix rebuild scss

git-subtree-dir: public/legacy
git-subtree-split: bb959a1451f926ccf5bb7b0da1909435e5450d05
2021-11-22 10:21:47 +00:00

144 lines
5.5 KiB
PHP

<?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".
*/
namespace SuiteCRM\Robo\Plugin\Commands;
use Robo\Tasks;
use RuntimeException;
use SuiteCRM\Utility\OperatingSystem;
use SuiteCRM\Robo\Traits\RoboTrait;
class BuildCommands extends Tasks
{
use RoboTrait;
// define public methods as commands
/**
* Compile a theme (SASS) based in SuiteP
* @param array $opts optional command line arguments
* theme - The name of the theme you want to compile css
* color-scheme - set which color scheme you wish to build
* @throws RuntimeException
*/
public function buildTheme(array $opts = ['theme' => '', 'color-scheme' => ''])
{
if (empty($opts['theme'])) {
$this->say("Please specify the name of the theme you want to compile with '--theme=SuiteP'");
return;
}
$this->say("Compile {$opts['theme']} Theme (SASS)");
if (empty($opts['color-scheme'])) {
/** Look for Subthemes in the {$opts['theme']} theme Dir **/
$std = "themes/{$opts['theme']}/css/";
$this->locateSubTheme($std);
/** Look for Subthemes in the custom/theme Dir **/
// Good opportunity to refactor here.
// Does the same as above just looks in the custom directory.
$ctd = "custom/themes/{$opts['theme']}/css/";
$this->locateSubTheme($ctd);
return;
}
$location = "themes/{$opts['theme']}/css/";
if (is_array($opts['color-scheme'])) {
foreach ($opts['color-scheme'] as $colorScheme) {
$this->buildColorScheme($colorScheme, $location);
}
return;
}
$this->buildColorScheme($opts['color-scheme'], $location);
$this->say("Compile {$opts['theme']} Theme (SASS) Complete");
}
/**
* Build SuiteP theme
* @param array $opts optional command line arguments
* color-scheme - set which color scheme you wish to build
* @throws RuntimeException
*/
public function buildSuiteP(array $opts = ['color-scheme' => ''])
{
$this->buildTheme(['theme' => 'SuiteP', 'color-scheme' => $opts['color-scheme']]);
}
/**
* @param string $colorScheme eg Dawn
* @param string $location eg Directory to work from
* @throws RuntimeException
*/
private function buildColorScheme($colorScheme, $location)
{
$os = new OperatingSystem();
$command =
$os->toOsPath('./vendor/bin/pscss')
. ' -s compressed '
. $os->toOsPath("{$location}{$colorScheme}/style.scss")
. ' > '
. $os->toOsPath("{$location}{$colorScheme}/style.css");
$this->_exec($command);
}
/**
* @param string $directory
*/
private function locateSubTheme($directory)
{
if (is_dir($directory) && $dir = opendir($directory)) {
while (false !== ($file = readdir($dir))) {
if (filetype($directory . $file) === 'dir' && file_exists($directory . $file . '/style.scss')) {
if (file_exists($directory . $file . '/style.css')) {
$this->say("Found style.css for {$file}, Removing");
unlink($directory . $file . '/style.css');
}
$this->say("Found style.scss for {$file}, Compiling");
$this->buildColorScheme($file, $directory);
}
}
} else {
$this->say("The folder {$directory} does not exists or it's not possible to open it.");
}
}
}