File manager - Edit - /home/u466501803/domains/qurdis.my.id/public_html/theme.zip
Back
PK =<�\_G~�0 0 image.phpnu �[��� <?php // This file is part of Moodle - http://moodle.org/ // // Moodle is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // Moodle 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 General Public License for more details. // // You should have received a copy of the GNU General Public License // along with Moodle. If not, see <http://www.gnu.org/licenses/>. /** * This file is responsible for serving the one theme and plugin images. * * @package core * @copyright 2009 Petr Skoda (skodak) {@link http://skodak.org} * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ // disable moodle specific debug messages and any errors in output, // comment out when debugging or better look into error log! define('NO_DEBUG_DISPLAY', true); // we need just the values from config.php and minlib.php define('ABORT_AFTER_CONFIG', true); require('../config.php'); // this stops immediately at the beginning of lib/setup.php if ($slashargument = min_get_slash_argument()) { $slashargument = ltrim($slashargument, '/'); if (substr_count($slashargument, '/') < 3) { image_not_found(); } if (strpos($slashargument, '_s/') === 0) { // Can't use SVG $slashargument = substr($slashargument, 3); $usesvg = false; } else { $usesvg = true; } // image must be last because it may contain "/" list($themename, $component, $rev, $image) = explode('/', $slashargument, 4); $themename = min_clean_param($themename, 'SAFEDIR'); $component = min_clean_param($component, 'SAFEDIR'); $rev = min_clean_param($rev, 'INT'); $image = min_clean_param($image, 'SAFEPATH'); } else { $themename = min_optional_param('theme', 'standard', 'SAFEDIR'); $component = min_optional_param('component', 'core', 'SAFEDIR'); $rev = min_optional_param('rev', -1, 'INT'); $image = min_optional_param('image', '', 'SAFEPATH'); $usesvg = (bool)min_optional_param('svg', '1', 'INT'); } if (!min_is_revision_valid_and_current($rev)) { // If the rev is invalid, normalise it to -1 to disable all caching. $rev = -1; } if (empty($component) or $component === 'moodle' or $component === 'core') { $component = 'core'; } if (empty($image)) { image_not_found(); } if (file_exists("$CFG->dirroot/theme/$themename/config.php")) { // exists } else if (!empty($CFG->themedir) and file_exists("$CFG->themedir/$themename/config.php")) { // exists } else { image_not_found(); } $candidatelocation = "$CFG->localcachedir/theme/$rev/$themename/pix/$component"; $etag = sha1("$rev/$themename/$component/$image"); if ($rev > 0) { if (file_exists("$candidatelocation/$image.error")) { // This is a major speedup if there are multiple missing images, // the only problem is that random requests may pollute our cache. image_not_found(); } $cacheimage = false; if ($usesvg && file_exists("$candidatelocation/$image.svg")) { $cacheimage = "$candidatelocation/$image.svg"; $ext = 'svg'; } else if (file_exists("$candidatelocation/$image.png")) { $cacheimage = "$candidatelocation/$image.png"; $ext = 'png'; } else if (file_exists("$candidatelocation/$image.gif")) { $cacheimage = "$candidatelocation/$image.gif"; $ext = 'gif'; } else if (file_exists("$candidatelocation/$image.jpg")) { $cacheimage = "$candidatelocation/$image.jpg"; $ext = 'jpg'; } else if (file_exists("$candidatelocation/$image.jpeg")) { $cacheimage = "$candidatelocation/$image.jpeg"; $ext = 'jpeg'; } else if (file_exists("$candidatelocation/$image.ico")) { $cacheimage = "$candidatelocation/$image.ico"; $ext = 'ico'; } if ($cacheimage) { if (!empty($_SERVER['HTTP_IF_NONE_MATCH']) || !empty($_SERVER['HTTP_IF_MODIFIED_SINCE'])) { // We do not actually need to verify the etag value because our files // never change in cache because we increment the rev parameter. // 90 days only - based on Moodle point release cadence being every 3 months. $lifetime = 60 * 60 * 24 * 90; $mimetype = get_contenttype_from_ext($ext); header('HTTP/1.1 304 Not Modified'); header('Expires: '. gmdate('D, d M Y H:i:s', time() + $lifetime) .' GMT'); header('Cache-Control: public, max-age='.$lifetime.', no-transform'); header('Content-Type: '.$mimetype); header('Etag: "'.$etag.'"'); die; } send_cached_image($cacheimage, $etag); } } //================================================================================= // ok, now we need to start normal moodle script, we need to load all libs and $DB define('ABORT_AFTER_CONFIG_CANCEL', true); define('NO_MOODLE_COOKIES', true); // Session not used here define('NO_UPGRADE_CHECK', true); // Ignore upgrade check require("$CFG->dirroot/lib/setup.php"); $theme = theme_config::load($themename); $themerev = theme_get_revision(); if ($themerev <= 0 or $rev != $themerev) { // Do not send caching headers if they do not request current revision, // we do not want to pollute browser caches with outdated images. $imagefile = $theme->resolve_image_location($image, $component, $usesvg); if (empty($imagefile) or !is_readable($imagefile)) { image_not_found(); } send_uncached_image($imagefile); } make_localcache_directory('theme', false); // At this stage caching is enabled, and either: // * we have no cached copy of the image in any format (either SVG, or non-SVG); or // * we have a cached copy of the SVG, but the non-SVG was requested by the browser. // // Because of the way in which the cache return code works above: // * if we are allowed to return SVG, we do not need to cache the non-SVG version; however // * if the browser has requested the non-SVG version, we *must* cache _both_ the SVG, and the non-SVG versions. // First get all copies - including, potentially, the SVG version. $imagefile = $theme->resolve_image_location($image, $component, true); if (empty($imagefile) || !is_readable($imagefile)) { // Unable to find a copy of the image file in any format. // We write a .error file for the image now - this will be used above when searching for cached copies to prevent // trying to find the image in the future. if (!file_exists($candidatelocation)) { @mkdir($candidatelocation, $CFG->directorypermissions, true); } // Make note we can not find this file. $cacheimage = "$candidatelocation/$image.error"; $fp = fopen($cacheimage, 'w'); fclose($fp); image_not_found(); } // The image was found, and it is readable. $pathinfo = pathinfo($imagefile); // Attempt to cache it if necessary. // We don't really want to overwrite any existing cache items just for the sake of it. $cacheimage = "$candidatelocation/$image.{$pathinfo['extension']}"; if (!file_exists($cacheimage)) { // We don't already hold a cached copy of this image. Cache it now. $cacheimage = cache_image($image, $imagefile, $candidatelocation); } if (!$usesvg && $pathinfo['extension'] === 'svg') { // The browser has requested that a non-SVG version be returned. // The version found so far is the SVG version - try and find the non-SVG version. $imagefile = $theme->resolve_image_location($image, $component, false); if (empty($imagefile) || !is_readable($imagefile)) { // A non-SVG file could not be found at all. // The browser has requested a non-SVG version, so we must return image_not_found(). // We must *not* write an .error file because the SVG is available. image_not_found(); } // An non-SVG version of image was found - cache it. // This will be used below in the image serving code. $cacheimage = cache_image($image, $imagefile, $candidatelocation); } if (connection_aborted()) { // Request was cancelled - do not send anything. die; } // Make sure nothing failed. clearstatcache(); if (file_exists($cacheimage)) { // The cached copy was found, and is accessible. Serve it. send_cached_image($cacheimage, $etag); } send_uncached_image($imagefile); //================================================================================= //=== utility functions == // we are not using filelib because we need to fine tune all header // parameters to get the best performance. function send_cached_image($imagepath, $etag) { global $CFG; require("$CFG->dirroot/lib/xsendfilelib.php"); // 90 days only - based on Moodle point release cadence being every 3 months. $lifetime = 60 * 60 * 24 * 90; $pathinfo = pathinfo($imagepath); $imagename = $pathinfo['filename'].'.'.$pathinfo['extension']; $mimetype = get_contenttype_from_ext($pathinfo['extension']); header('Etag: "'.$etag.'"'); header('Content-Disposition: inline; filename="'.$imagename.'"'); header('Last-Modified: '. gmdate('D, d M Y H:i:s', filemtime($imagepath)) .' GMT'); header('Expires: '. gmdate('D, d M Y H:i:s', time() + $lifetime) .' GMT'); header('Pragma: '); header('Cache-Control: public, max-age='.$lifetime.', no-transform, immutable'); header('Accept-Ranges: none'); header('Content-Type: '.$mimetype); if (xsendfile($imagepath)) { die; } if ($mimetype === 'image/svg+xml') { // SVG format is a text file. So we can compress SVG files. if (!min_enable_zlib_compression()) { header('Content-Length: '.filesize($imagepath)); } } else { // No need to compress other image formats. header('Content-Length: '.filesize($imagepath)); } readfile($imagepath); die; } function send_uncached_image($imagepath) { $pathinfo = pathinfo($imagepath); $imagename = $pathinfo['filename'].'.'.$pathinfo['extension']; $mimetype = get_contenttype_from_ext($pathinfo['extension']); header('Content-Disposition: inline; filename="'.$imagename.'"'); header('Last-Modified: '. gmdate('D, d M Y H:i:s', time()) .' GMT'); header('Expires: '. gmdate('D, d M Y H:i:s', time() + 15) .' GMT'); header('Pragma: '); header('Accept-Ranges: none'); header('Content-Type: '.$mimetype); header('Content-Length: '.filesize($imagepath)); readfile($imagepath); die; } function image_not_found() { header('HTTP/1.0 404 not found'); die('Image was not found, sorry.'); } function get_contenttype_from_ext($ext) { switch ($ext) { case 'svg': return 'image/svg+xml'; case 'png': return 'image/png'; case 'gif': return 'image/gif'; case 'jpg': case 'jpeg': return 'image/jpeg'; case 'ico': return 'image/vnd.microsoft.icon'; } return 'document/unknown'; } /** * Caches a given image file. * * @param string $image The name of the image that was requested. * @param string $imagefile The location of the image file we want to cache. * @param string $candidatelocation The location to cache it in. * @return string The path to the cached image. */ function cache_image($image, $imagefile, $candidatelocation) { global $CFG; $pathinfo = pathinfo($imagefile); $cacheimage = "$candidatelocation/$image.".$pathinfo['extension']; clearstatcache(); if (!file_exists(dirname($cacheimage))) { @mkdir(dirname($cacheimage), $CFG->directorypermissions, true); } // Prevent serving of incomplete file from concurrent request, // the rename() should be more atomic than copy(). ignore_user_abort(true); if (@copy($imagefile, $cacheimage.'.tmp')) { rename($cacheimage.'.tmp', $cacheimage); @chmod($cacheimage, $CFG->filepermissions); @unlink($cacheimage.'.tmp'); // just in case anything fails } return $cacheimage; } PK =<�\� �p p UPGRADING.mdnu �[��� # theme (plugin type) Upgrade notes ## 4.5 ### Added - Added a new `\renderer_base::get_page` getter method. For more information see [MDL-81597](https://tracker.moodle.org/browse/MDL-81597) - New `core/context_header` mustache template has been added. This template can be overridden by themes to modify the context header. For more information see [MDL-81597](https://tracker.moodle.org/browse/MDL-81597) ### Deprecated - The method `\core\output\core_renderer::render_context_header` has been deprecated please use `\core\output\core_renderer::render($contextheader)` instead For more information see [MDL-82160](https://tracker.moodle.org/browse/MDL-82160) ### Removed - Removed all references to `iconhelp`, `icon-pre`, `icon-post`, `iconlarge`, and `iconsort` CSS classes. For more information see [MDL-74251](https://tracker.moodle.org/browse/MDL-74251) PK =<�\�r�� � index.phpnu �[��� <?php // This file is part of Moodle - http://moodle.org/ // // Moodle is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // Moodle 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 General Public License for more details. // // You should have received a copy of the GNU General Public License // along with Moodle. If not, see <http://www.gnu.org/licenses/>. /** * This page provides the Administration -> ... -> Theme selector UI. * * @package core * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ require_once(__DIR__ . '/../config.php'); // Theme selector has been moved to admin/themeselector.php. redirect (new moodle_url('/admin/themeselector.php')); PK =<�\��z� styles_debug.phpnu �[��� <?php // This file is part of Moodle - http://moodle.org/ // // Moodle is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // Moodle 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 General Public License for more details. // // You should have received a copy of the GNU General Public License // along with Moodle. If not, see <http://www.gnu.org/licenses/>. /** * This file is responsible for serving of individual style sheets in designer mode. * * @package core * @copyright 2009 Petr Skoda (skodak) {@link http://skodak.org} * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ // Disable moodle specific debug messages and any errors in output, // comment out when debugging or better look into error log! define('NO_DEBUG_DISPLAY', true); define('NO_UPGRADE_CHECK', true); define('NO_MOODLE_COOKIES', true); require('../config.php'); require_once($CFG->dirroot.'/lib/csslib.php'); $themename = optional_param('theme', 'standard', PARAM_SAFEDIR); $type = optional_param('type', '', PARAM_SAFEDIR); $subtype = optional_param('subtype', '', PARAM_SAFEDIR); $sheet = optional_param('sheet', '', PARAM_SAFEDIR); $usesvg = optional_param('svg', 1, PARAM_BOOL); $rtl = optional_param('rtl', false, PARAM_BOOL); if (file_exists("$CFG->dirroot/theme/$themename/config.php")) { // The theme exists in standard location - ok. } else if (!empty($CFG->themedir) and file_exists("$CFG->themedir/$themename/config.php")) { // Alternative theme location contains this theme - ok. } else { css_send_css_not_found(); } $theme = theme_config::load($themename); $theme->force_svg_use($usesvg); $theme->set_rtl_mode($rtl); if ($type === 'editor') { $csscontent = $theme->get_css_content_editor(); css_send_uncached_css($csscontent); } // We need some kind of caching here because otherwise the page navigation becomes // way too slow in theme designer mode. Feel free to create full cache definition later... $key = "$type $subtype $sheet $usesvg $rtl"; $cache = cache::make_from_params(cache_store::MODE_APPLICATION, 'core', 'themedesigner', array('theme' => $themename)); if ($content = $cache->get($key)) { if ($content['created'] > time() - THEME_DESIGNER_CACHE_LIFETIME) { $csscontent = $content['data']; css_send_uncached_css($csscontent); } } $csscontent = $theme->get_css_content_debug($type, $subtype, $sheet); $cache->set($key, array('data' => $csscontent, 'created' => time())); css_send_uncached_css($csscontent); PK =<�\��u� � jquery.phpnu �[��� <?php // This file is part of Moodle - http://moodle.org/ // // Moodle is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // Moodle 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 General Public License for more details. // // You should have received a copy of the GNU General Public License // along with Moodle. If not, see <http://www.gnu.org/licenses/>. /** * jQuery serving script. * * Do not include jQuery scripts or CSS directly, always use * $PAGE->requires->jquery() or $PAGE->requires->jquery_plugin('xx', 'yy'). * * @package core * @copyright 2013 Petr Skoda {@link http://skodak.org} * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ // Disable moodle specific debug messages and any errors in output, // comment out when debugging or better look into error log! define('NO_DEBUG_DISPLAY', true); // We need just the values from config.php and minlib.php. define('ABORT_AFTER_CONFIG', true); require('../config.php'); // This stops immediately at the beginning of lib/setup.php. if ($slashargument = min_get_slash_argument()) { $path = ltrim($slashargument, '/'); } else { $path = min_optional_param('file', '', 'SAFEPATH'); $path = ltrim($path, '/'); } if (strpos($path, '/') === false) { jquery_file_not_found(); } list($component, $path) = explode('/', $path, 2); if (empty($path) or empty($component)) { jquery_file_not_found(); } // Find the jQuery dir for this component. if ($component === 'core') { $componentdir = "$CFG->dirroot/lib"; } else if (strpos($component, 'theme_')) { if (!empty($CFG->themedir)) { $componentdir = "$CFG->themedir/$component"; } else { $componentdir = "$CFG->dirroot/theme/$component"; } } else { $componentdir = core_component::get_component_directory($component); } if (!file_exists($componentdir) or !file_exists("$componentdir/jquery/plugins.php")) { jquery_file_not_found(); } $file = realpath("$componentdir/jquery/$path"); if (!$file or is_dir($file)) { jquery_file_not_found(); } $etag = sha1("$component/$path"); // 90 days only - based on Moodle point release cadence being every 3 months. $lifetime = 60 * 60 * 24 * 90; $pathinfo = pathinfo($path); if (empty($pathinfo['extension'])) { jquery_file_not_found(); } $filename = $pathinfo['filename'].'.'.$pathinfo['extension']; switch($pathinfo['extension']) { case 'gif' : $mimetype = 'image/gif'; break; case 'png' : $mimetype = 'image/png'; break; case 'jpg' : $mimetype = 'image/jpeg'; break; case 'jpeg' : $mimetype = 'image/jpeg'; break; case 'ico' : $mimetype = 'image/vnd.microsoft.icon'; break; case 'svg' : $mimetype = 'image/svg+xml'; break; case 'js' : $mimetype = 'application/javascript'; break; case 'css' : $mimetype = 'text/css'; break; case 'php' : jquery_file_not_found(); break; default : $mimetype = 'document/unknown'; } if (!empty($_SERVER['HTTP_IF_NONE_MATCH']) || !empty($_SERVER['HTTP_IF_MODIFIED_SINCE'])) { // We do not actually need to verify the etag value because these files // never change, devs need to change file names on update! header('HTTP/1.1 304 Not Modified'); header('Expires: '. gmdate('D, d M Y H:i:s', time() + $lifetime) .' GMT'); header('Cache-Control: public, max-age='.$lifetime); header('Content-Type: '.$mimetype); header('Etag: "'.$etag.'"'); die; } require_once("$CFG->dirroot/lib/xsendfilelib.php"); header('Etag: "'.$etag.'"'); header('Content-Disposition: inline; filename="'.$filename.'"'); header('Last-Modified: '. gmdate('D, d M Y H:i:s', filemtime($file)) .' GMT'); header('Expires: '. gmdate('D, d M Y H:i:s', time() + $lifetime) .' GMT'); header('Pragma: '); header('Cache-Control: public, max-age='.$lifetime.', immutable'); header('Accept-Ranges: none'); header('Content-Type: '.$mimetype); if (xsendfile($file)) { die; } if ($mimetype === 'text/css' or $mimetype === 'application/javascript') { if (!min_enable_zlib_compression()) { header('Content-Length: '.filesize($file)); } } else { // No need to compress images. header('Content-Length: '.filesize($file)); } readfile($file); die; function jquery_file_not_found() { // Note: we can not disclose the exact file path here, sorry. header('HTTP/1.0 404 not found'); die('File was not found, sorry.'); } PK =<�\l��� � boost/readme_moodle.txtnu �[��� Description of Twitter bootstrap import into Moodle Twitter bootstrap ----------------- Sass: This theme uses Bootstrap frontend toolkit. The Bootstrap repository is available on: https://github.com/twbs/bootstrap To update to the latest release of twitter bootstrap: * download bootstrap to your home folder * remove folder theme/boost/scss/bootstrap * copy the scss files from ~/bootstrap/scss to theme/boost/scss/bootstrap * comment out left: 0; from .popover {} in scss/bootstrap/_popover.scss. In RTL mode this prevents popovers from showing and it is not required in LTR mode. * comment out this line in theme/boost/scss/_print.scss @page { size: $print-page-size; } It breaks when compiled with phpscss. * update ./thirdpartylibs.xml * follow the instructions in admin/tool/component_library/readme_moodle.txt to update the Bootstrap documentation there. Javascript: * remove folder theme/boost/amd/src/bootstrap * copy the js files from ~/bootstrap/js/src to theme/boost/amd/src/bootstrap (including the subfolder) * copy index.js from ~/bootstrap/js to theme/boost/amd/src * edit theme/boost/amd/src/index.js and update import path (src -> bootstrap) * Moodle core includes the popper.js library, make sure each of the new Bootstrap js files includes the 'core/popper' library instead of 'popper.js'. For current version these files were: tooltip.js and dropdown.js * update ./thirdpartylibs.xml to include all new Bootstrap js files * run "grunt ignorefiles" to prevent linting errors appearing from the new Bootstrap js files. * in folder theme/boost run "grunt amd" to compile the bootstrap JS * in folder theme/boost run "grunt css" to compile scss PK =<�\�EV�t t boost/lib.phpnu �[��� <?php // This file is part of Moodle - http://moodle.org/ // // Moodle is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // Moodle 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 General Public License for more details. // // You should have received a copy of the GNU General Public License // along with Moodle. If not, see <http://www.gnu.org/licenses/>. /** * Theme functions. * * @package theme_boost * @copyright 2016 Frédéric Massart - FMCorz.net * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ defined('MOODLE_INTERNAL') || die(); /** * Post process the CSS tree. * * @param string $tree The CSS tree. * @param theme_config $theme The theme config object. */ function theme_boost_css_tree_post_processor($tree, $theme) { error_log('theme_boost_css_tree_post_processor() is deprecated. Required' . 'prefixes for Bootstrap are now in theme/boost/scss/moodle/prefixes.scss'); $prefixer = new theme_boost\autoprefixer($tree); $prefixer->prefix(); } /** * Inject additional SCSS. * * @param theme_config $theme The theme config object. * @return string */ function theme_boost_get_extra_scss($theme) { $content = ''; $imageurl = $theme->setting_file_url('backgroundimage', 'backgroundimage'); // Sets the background image, and its settings. if (!empty($imageurl)) { $content .= '@media (min-width: 768px) {'; $content .= 'body { '; $content .= "background-image: url('$imageurl'); background-size: cover;"; $content .= ' } }'; } // Sets the login background image. $loginbackgroundimageurl = $theme->setting_file_url('loginbackgroundimage', 'loginbackgroundimage'); if (!empty($loginbackgroundimageurl)) { $content .= 'body.pagelayout-login #page { '; $content .= "background-image: url('$loginbackgroundimageurl'); background-size: cover;"; $content .= ' }'; } // Always return the background image with the scss when we have it. return !empty($theme->settings->scss) ? "{$theme->settings->scss} \n {$content}" : $content; } /** * Serves any files associated with the theme settings. * * @param stdClass $course * @param stdClass $cm * @param context $context * @param string $filearea * @param array $args * @param bool $forcedownload * @param array $options * @return bool */ function theme_boost_pluginfile($course, $cm, $context, $filearea, $args, $forcedownload, array $options = array()) { if ($context->contextlevel == CONTEXT_SYSTEM && ($filearea === 'logo' || $filearea === 'backgroundimage' || $filearea === 'loginbackgroundimage')) { $theme = theme_config::load('boost'); // By default, theme files must be cache-able by both browsers and proxies. if (!array_key_exists('cacheability', $options)) { $options['cacheability'] = 'public'; } return $theme->setting_file_serve($filearea, $args, $forcedownload, $options); } else { send_file_not_found(); } } /** * Get the current user preferences that are available * * @return array[] */ function theme_boost_user_preferences(): array { return [ 'drawer-open-block' => [ 'type' => PARAM_BOOL, 'null' => NULL_NOT_ALLOWED, 'default' => false, 'permissioncallback' => [core_user::class, 'is_current_user'], ], 'drawer-open-index' => [ 'type' => PARAM_BOOL, 'null' => NULL_NOT_ALLOWED, 'default' => true, 'permissioncallback' => [core_user::class, 'is_current_user'], ], ]; } /** * Returns the main SCSS content. * * @param theme_config $theme The theme config object. * @return string */ function theme_boost_get_main_scss_content($theme) { global $CFG; $scss = ''; $filename = !empty($theme->settings->preset) ? $theme->settings->preset : null; $fs = get_file_storage(); $context = context_system::instance(); if ($filename == 'default.scss') { $scss .= file_get_contents($CFG->dirroot . '/theme/boost/scss/preset/default.scss'); } else if ($filename == 'plain.scss') { $scss .= file_get_contents($CFG->dirroot . '/theme/boost/scss/preset/plain.scss'); } else if ($filename && ($presetfile = $fs->get_file($context->id, 'theme_boost', 'preset', 0, '/', $filename))) { $scss .= $presetfile->get_content(); } else { // Safety fallback - maybe new installs etc. $scss .= file_get_contents($CFG->dirroot . '/theme/boost/scss/preset/default.scss'); } return $scss; } /** * Get compiled css. * * @return string compiled css */ function theme_boost_get_precompiled_css() { global $CFG; return file_get_contents($CFG->dirroot . '/theme/boost/style/moodle.css'); } /** * Get SCSS to prepend. * * @param theme_config $theme The theme config object. * @return string */ function theme_boost_get_pre_scss($theme) { global $CFG; $scss = ''; $configurable = [ // Config key => [variableName, ...]. 'brandcolor' => ['primary'], ]; // Prepend variables first. foreach ($configurable as $configkey => $targets) { $value = isset($theme->settings->{$configkey}) ? $theme->settings->{$configkey} : null; if (empty($value)) { continue; } array_map(function($target) use (&$scss, $value) { $scss .= '$' . $target . ': ' . $value . ";\n"; }, (array) $targets); } // Prepend pre-scss. if (!empty($theme->settings->scsspre)) { $scss .= $theme->settings->scsspre; } return $scss; } PK =<�\NbL�#! #! boost/thirdpartylibs.xmlnu �[��� <?xml version="1.0"?> <libraries> <library> <location>scss/bootstrap</location> <name>Twitter Bootstrap</name> <description>HTML, CSS, and JavaScript framework for developing responsive, mobile-first projects on the web.</description> <version>4.6.2</version> <license>MIT</license> <repository>https://github.com/twbs/bootstrap</repository> <copyrights> <copyright>2011-2021 Twitter, Inc</copyright> <copyright>2011-2021 The Bootstrap Authors</copyright> </copyrights> <customised/> </library> <library> <location>amd/src/bootstrap/alert.js</location> <name>bootstrap-alert</name> <description>HTML, CSS, and JavaScript framework for developing responsive, mobile-first projects on the web.</description> <version>4.6.2</version> <license>MIT</license> <repository>https://github.com/twbs/bootstrap</repository> <copyrights> <copyright>2011-2021 Twitter, Inc</copyright> <copyright>2011-2021 The Bootstrap Authors</copyright> </copyrights> <customised/> </library> <library> <location>amd/src/bootstrap/button.js</location> <name>bootstrap-button</name> <description>HTML, CSS, and JavaScript framework for developing responsive, mobile-first projects on the web.</description> <version>4.6.2</version> <license>MIT</license> <licenseversion></licenseversion> <repository>https://github.com/twbs/bootstrap</repository> <copyrights> <copyright>2011-2021 Twitter, Inc</copyright> <copyright>2011-2021 The Bootstrap Authors</copyright> </copyrights> <customised/> </library> <library> <location>amd/src/bootstrap/carousel.js</location> <name>bootstrap-carousel</name> <description>HTML, CSS, and JavaScript framework for developing responsive, mobile-first projects on the web.</description> <version>4.6.2</version> <license>MIT</license> <repository>https://github.com/twbs/bootstrap</repository> <copyrights> <copyright>2011-2021 Twitter, Inc</copyright> <copyright>2011-2021 The Bootstrap Authors</copyright> </copyrights> <customised/> </library> <library> <location>amd/src/bootstrap/collapse.js</location> <name>bootstrap-collapse</name> <description>HTML, CSS, and JavaScript framework for developing responsive, mobile-first projects on the web.</description> <version>4.6.2</version> <license>MIT</license> <repository>https://github.com/twbs/bootstrap</repository> <copyrights> <copyright>2011-2021 Twitter, Inc</copyright> <copyright>2011-2021 The Bootstrap Authors</copyright> </copyrights> <customised/> </library> <library> <location>amd/src/bootstrap/dropdown.js</location> <name>bootstrap-dropdown</name> <description>HTML, CSS, and JavaScript framework for developing responsive, mobile-first projects on the web.</description> <version>4.6.2</version> <license>MIT</license> <repository>https://github.com/twbs/bootstrap</repository> <copyrights> <copyright>2011-2021 Twitter, Inc</copyright> <copyright>2011-2021 The Bootstrap Authors</copyright> </copyrights> <customised/> </library> <library> <location>amd/src/bootstrap/modal.js</location> <name>bootstrap-modal</name> <description>HTML, CSS, and JavaScript framework for developing responsive, mobile-first projects on the web.</description> <version>4.6.2</version> <license>MIT</license> <repository>https://github.com/twbs/bootstrap</repository> <copyrights> <copyright>2011-2021 Twitter, Inc</copyright> <copyright>2011-2021 The Bootstrap Authors</copyright> </copyrights> <customised/> </library> <library> <location>amd/src/bootstrap/popover.js</location> <name>bootstrap-popover</name> <description>HTML, CSS, and JavaScript framework for developing responsive, mobile-first projects on the web.</description> <version>4.6.2</version> <license>MIT</license> <repository>https://github.com/twbs/bootstrap</repository> <copyrights> <copyright>2011-2021 Twitter, Inc</copyright> <copyright>2011-2021 The Bootstrap Authors</copyright> </copyrights> <customised/> </library> <library> <location>amd/src/bootstrap/tools/sanitizer.js</location> <name>bootstrap-sanitizer</name> <description>HTML, CSS, and JavaScript framework for developing responsive, mobile-first projects on the web.</description> <version>4.6.2</version> <license>MIT</license> <repository>https://github.com/twbs/bootstrap</repository> <copyrights> <copyright>2011-2021 Twitter, Inc</copyright> <copyright>2011-2021 The Bootstrap Authors</copyright> </copyrights> <customised/> </library> <library> <location>amd/src/bootstrap/scrollspy.js</location> <name>bootstrap-scrollspy</name> <description>HTML, CSS, and JavaScript framework for developing responsive, mobile-first projects on the web.</description> <version>4.6.2</version> <license>MIT</license> <repository>https://github.com/twbs/bootstrap</repository> <copyrights> <copyright>2011-2021 Twitter, Inc</copyright> <copyright>2011-2021 The Bootstrap Authors</copyright> </copyrights> <customised/> </library> <library> <location>amd/src/bootstrap/tab.js</location> <name>bootstrap-tab</name> <description>HTML, CSS, and JavaScript framework for developing responsive, mobile-first projects on the web.</description> <version>4.6.2</version> <license>MIT</license> <repository>https://github.com/twbs/bootstrap</repository> <copyrights> <copyright>2011-2021 Twitter, Inc</copyright> <copyright>2011-2021 The Bootstrap Authors</copyright> </copyrights> <customised/> </library> <library> <location>amd/src/bootstrap/toast.js</location> <name>bootstrap-toast</name> <description>HTML, CSS, and JavaScript framework for developing responsive, mobile-first projects on the web.</description> <version>4.6.2</version> <license>MIT</license> <repository>https://github.com/twbs/bootstrap</repository> <copyrights> <copyright>2011-2021 Twitter, Inc</copyright> <copyright>2011-2021 The Bootstrap Authors</copyright> </copyrights> <customised/> </library> <library> <location>amd/src/bootstrap/tooltip.js</location> <name>bootstrap-tooltip</name> <description>HTML, CSS, and JavaScript framework for developing responsive, mobile-first projects on the web.</description> <version>4.6.2</version> <license>MIT</license> <repository>https://github.com/twbs/bootstrap</repository> <copyrights> <copyright>2011-2021 Twitter, Inc</copyright> <copyright>2011-2021 The Bootstrap Authors</copyright> </copyrights> <customised/> </library> <library> <location>amd/src/bootstrap/util.js</location> <name>bootstrap-util</name> <description>HTML, CSS, and JavaScript framework for developing responsive, mobile-first projects on the web.</description> <version>4.6.2</version> <license>MIT</license> <repository>https://github.com/twbs/bootstrap</repository> <copyrights> <copyright>2011-2021 Twitter, Inc</copyright> <copyright>2011-2021 The Bootstrap Authors</copyright> </copyrights> <customised/> </library> <library> <location>amd/src/index.js</location> <name>bootstrap-util</name> <description>HTML, CSS, and JavaScript framework for developing responsive, mobile-first projects on the web.</description> <version>4.6.2</version> <license>MIT</license> <repository>https://github.com/twbs/bootstrap</repository> <copyrights> <copyright>2011-2021 Twitter, Inc</copyright> <copyright>2011-2021 The Bootstrap Authors</copyright> </copyrights> <customised/> </library> <library> <location>scss/fontawesome</location> <name>Font Awesome - http://fontawesome.com</name> <description>Font Awesome CSS, LESS, and Sass files. Font Awesome is the Internet's icon library and toolkit, used by millions of designers, developers, and content creators.</description> <version>6.5.2</version> <license>(MIT)</license> <repository>https://github.com/FortAwesome/Font-Awesome</repository> <copyrights> <copyright>2023 Fonticons, Inc</copyright> </copyrights> </library> </libraries> PK =<�\n��] ] boost/classes/autoprefixer.phpnu �[��� <?php // This file is part of Moodle - http://moodle.org/ // // Moodle is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // Moodle 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 General Public License for more details. // // You should have received a copy of the GNU General Public License // along with Moodle. If not, see <http://www.gnu.org/licenses/>. /** * Autoprefixer. * * This autoprefixer has been developed to satisfy the basic needs of the * theme Boost when working with Bootstrap 4 alpha. We do not recommend * that this tool is shared, nor used outside of this theme. * * @package theme_boost * @copyright 2016 Frédéric Massart - FMCorz.net * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ namespace theme_boost; defined('MOODLE_INTERNAL') || die(); use Sabberworm\CSS\CSSList\CSSList; use Sabberworm\CSS\CSSList\Document; use Sabberworm\CSS\CSSList\KeyFrame; use Sabberworm\CSS\OutputFormat; use Sabberworm\CSS\Parser; use Sabberworm\CSS\Property\AtRule; use Sabberworm\CSS\Property\Selector; use Sabberworm\CSS\Rule\Rule; use Sabberworm\CSS\RuleSet\AtRuleSet; use Sabberworm\CSS\RuleSet\DeclarationBlock; use Sabberworm\CSS\RuleSet\RuleSet; use Sabberworm\CSS\Settings; use Sabberworm\CSS\Value\CSSFunction; use Sabberworm\CSS\Value\CSSString; use Sabberworm\CSS\Value\PrimitiveValue; use Sabberworm\CSS\Value\RuleValueList; use Sabberworm\CSS\Value\Size; use Sabberworm\CSS\Value\ValueList; /** * Autoprefixer class. * * Very basic implementation covering simple needs for Bootstrap 4. * * @package theme_boost * @copyright 2016 Frédéric Massart - FMCorz.net * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class autoprefixer { /** @var object The CSS tree. */ protected $tree; /** @var string Pseudo classes regex. */ protected $pseudosregex; /** @var array At rules prefixes. */ protected static $atrules = [ 'keyframes' => ['-webkit-', '-o-'] ]; /** @var array Pseudo classes prefixes. */ protected static $pseudos = [ '::placeholder' => ['::-webkit-input-placeholder', '::-moz-placeholder', ':-ms-input-placeholder'] ]; /** @var array Rule properties prefixes. */ protected static $rules = [ 'animation' => ['-webkit-'], 'appearance' => ['-webkit-', '-moz-'], 'backface-visibility' => ['-webkit-'], 'box-sizing' => ['-webkit-'], 'box-shadow' => ['-webkit-'], 'background-clip' => ['-webkit-'], 'background-size' => ['-webkit-'], 'box-shadow' => ['-webkit-'], 'column-count' => ['-webkit-', '-moz-'], 'column-gap' => ['-webkit-', '-moz-'], 'perspective' => ['-webkit-'], 'touch-action' => ['-ms-'], 'transform' => ['-webkit-', '-moz-', '-ms-', '-o-'], 'transition' => ['-webkit-', '-o-'], 'transition-timing-function' => ['-webkit-', '-o-'], 'transition-duration' => ['-webkit-', '-o-'], 'transition-property' => ['-webkit-', '-o-'], 'user-select' => ['-webkit-', '-moz-', '-ms-'], ]; /** * Constructor. * * @param Document $tree The CSS tree. */ public function __construct(Document $tree) { debugging('theme_boost\autoprefixer() is deprecated. Required prefixes for Bootstrap ' . 'are now in theme/boost/scss/moodle/prefixes.scss', DEBUG_DEVELOPER); $this->tree = $tree; $pseudos = array_map(function($pseudo) { return '(' . preg_quote($pseudo) . ')'; }, array_keys(self::$pseudos)); $this->pseudosregex = '(' . implode('|', $pseudos) . ')'; } /** * Manipulate an array of rules to adapt their values. * * @param array $rules The rules. * @return New array of rules. */ protected function manipulateRuleValues(array $rules) { $finalrules = []; foreach ($rules as $rule) { $property = $rule->getRule(); $value = $rule->getValue(); if ($property === 'position' && $value === 'sticky') { $newrule = clone $rule; $newrule->setValue('-webkit-sticky'); $finalrules[] = $newrule; } else if ($property === 'background-image' && $value instanceof CSSFunction && $value->getName() === 'linear-gradient') { foreach (['-webkit-', '-o-'] as $prefix) { $newfunction = clone $value; $newfunction->setName($prefix . $value->getName()); $newrule = clone $rule; $newrule->setValue($newfunction); $finalrules[] = $newrule; } } $finalrules[] = $rule; } return $finalrules; } /** * Prefix all the things! */ public function prefix() { $this->processBlock($this->tree); } /** * Process block. * * @param object $block A block. * @param object $parent The parent of the block. */ protected function processBlock($block) { foreach ($block->getContents() as $node) { if ($node instanceof AtRule) { $name = $node->atRuleName(); if (isset(self::$atrules[$name])) { foreach (self::$atrules[$name] as $prefix) { $newname = $prefix . $name; $newnode = clone $node; if ($node instanceof KeyFrame) { $newnode->setVendorKeyFrame($newname); $block->insert($newnode, $node); } else { debugging('Unhandled atRule prefixing.', DEBUG_DEVELOPER); } } } } if ($node instanceof CSSList) { $this->processBlock($node); } else if ($node instanceof RuleSet) { $this->processDeclaration($node, $block); } } } /** * Process declaration. * * @param object $node The declaration block. * @param object $parent The parent. */ protected function processDeclaration($node, $parent) { $rules = []; foreach ($node->getRules() as $key => $rule) { $name = $rule->getRule(); $seen[$name] = true; if (!isset(self::$rules[$name])) { $rules[] = $rule; continue; } foreach (self::$rules[$name] as $prefix) { $newname = $prefix . $name; if (isset($seen[$newname])) { continue; } $newrule = clone $rule; $newrule->setRule($newname); $rules[] = $newrule; } $rules[] = $rule; } $node->setRules($this->manipulateRuleValues($rules)); if ($node instanceof DeclarationBlock) { $selectors = $node->getSelectors(); foreach ($selectors as $key => $selector) { $matches = []; if (preg_match($this->pseudosregex, $selector->getSelector(), $matches)) { $newnode = clone $node; foreach (self::$pseudos[$matches[1]] as $newpseudo) { $newselector = new Selector(str_replace($matches[1], $newpseudo, $selector->getSelector())); $selectors[$key] = $newselector; $newnode = clone $node; $newnode->setSelectors($selectors); $parent->insert($newnode, $node); } // We're only expecting one affected pseudo class per block. break; } } } } } PK =<�\�AVQ- Q- &