David Karich

Module: AIOM+ (All In One Minify) for CSS, LESS, JS and HTML

169 posts in this topic

i've just created a pull request that makes it possible to modify less variables. it also adds a check if the js/css file exists and throws a note either in console if tracy is installed or in the processwire log.

that's how you can modify your less variables:

<?php
$config->styles->append('less/theme.less');
$lessVars = array(
    'tm-primary-bg' => '#568AEA',
    'background-image' => 'url("' . $page->backgroundimage->url . '")',
);
?>
<link rel="stylesheet" href="<?php echo AIOM::CSS($config->styles->unique(), $lessVars); ?>">

https://github.com/FlipZoomMedia/ProcessWire-AIOM-All-In-One-Minify/pull/57

3 people like this

Share this post


Link to post
Share on other sites

I've installed the module and it works fine.

But:

When I set Development Mode to "yes" the files get combined. Is there a way to disable this? I cannot track the root css files this way...

Share this post


Link to post
Share on other sites

you'd need to make some function to output the individual assets, for example when an admin is logged in..

(very basic example)
 

if($user->isLoggedin) {
  listAssets($stylesheets);
} else {
  echo AllInOneMinify::CSS($stylesheets));
}

that's how i do it..

4 people like this

Share this post


Link to post
Share on other sites

Uh now I understand the question..development mode is just disabling minification and caching..maybe file "seperation" could be included as separate option, I for myself like files being concatenated while uncompressed for development..and if I really don't now which file a line belongs to I just Sublime search in all files and done.. ;-)

Share this post


Link to post
Share on other sites
5 hours ago, Macrura said:

 


if($user->isLoggedin) {
  listAssets($stylesheets);
} else {
  echo AllInOneMinify::CSS($stylesheets));
}

 

My conditional is:

$skipMinify = $config->debug || $user->isSuperuser() ? true : false;

 

1 person likes this

Share this post


Link to post
Share on other sites

@horst How about this?

$skipMinify = $config->debug || $user->isSuperuser();

5 people like this

Share this post


Link to post
Share on other sites

:o OMG. I shouldn't post in the morning before the first cup of coffee. :)

 

4 people like this

Share this post


Link to post
Share on other sites
3 hours ago, tpr said:

@horst How about this?

$skipMinify = $config->debug || $user->isSuperuser();

Where does this code snippet go?

Right now I am using this code in my header which is not very professional but it works ;-)

	<? if ($config->debug) { ?>
		<link rel="stylesheet" type="text/css" href="<?php echo $config->urls->templates?>styles/styles.css" />
	<? }
	else { ?>
		<link rel="stylesheet" type="text/css" href="<?php echo AIOM::CSS('styles/styles.css'); ?>" />
	<? } ?>

 

Share this post


Link to post
Share on other sites

For me, it goes here:

// condition
<?php if ($config->debug) { ?>

// condition as variable
<?php
$skipMinify = $config->debug || $user->isSuperuser();
if ($skipMinify) { ?>

// or, if you have only one occurence in your code where you check this condition, 
// ommit the temorary variable and write it direct into the condition
<?php if ($config->debug || $user->isSuperuser()) { ?>

$config->debug is true when developing, and additionally I use superuser condition for later, when in production mode!

1 person likes this

Share this post


Link to post
Share on other sites

PHP 7.1 is returning a:

A non well formed numeric value encountered on line 713 notice

because you are relying on PHP's auto int casting.

I didn't do a thorough check to see if this is ok, but so far it's working for me:

$_timestamp = ((int)$_timestamp + $file['last_modified']);

 

Share this post


Link to post
Share on other sites
On 11/25/2015 at 5:17 PM, Russ Parker said:

Any ideas how to stop it minifying the spaces in CSS calc?

having a problem with this as well, any solutions ?

Share this post


Link to post
Share on other sites

Hi.

Is it possible to disable HTML minifing or activate "Developement mode" from config file? 

Thanks 

Share this post


Link to post
Share on other sites

Hi,

first I couldn't install the module on a 3.0.47 installation, I've added  namespace ProcessWire;, which did the trick, but then I have this:

Error: Class 'ProcessWire\RecursiveDirectoryIterator' not found (line 658 of /public_html/site/modules/AllInOneMinify/AllInOneMinify.module)

Kind Regards!

Share this post


Link to post
Share on other sites
On 18.11.2016 at 4:48 PM, Zeka said:

Hi.

Is it possible to disable HTML minifing or activate "Developement mode" from config file? 

Thanks 

Not directly, but I had the same "problem" and now I do it this way:

// when debug mode is ON -> do not compress the styles 
if ($config->debug) { ?>
	<link rel="stylesheet" type="text/css" href="/path/to/css/..."/>
<? } else { ?>
	<link rel="stylesheet" type="text/css" href="<?php echo AIOM::CSS(/path/to/css/...); ?>"/>
<? }

 

1 person likes this

Share this post


Link to post
Share on other sites
13 hours ago, videokid said:

Hi,

first I couldn't install the module on a 3.0.47 installation, I've added  namespace ProcessWire;, which did the trick, but then I have this:


Error: Class 'ProcessWire\RecursiveDirectoryIterator' not found (line 658 of /public_html/site/modules/AllInOneMinify/AllInOneMinify.module)

Kind Regards!

you either leave the namespace or need to prepend all php function like RecursiveDirectoryIterator with an \ backslash like \RecursiveDirectoryIterator so it knows this function is not in the ProcessWire but in the root namespace..

2 people like this

Share this post


Link to post
Share on other sites

Yes,

I left the ' namespace Processwire ' and added the backslash, and that did the trick!

Thank you!

Share this post


Link to post
Share on other sites
On 19.01.2017 at 11:06 AM, Stefanowitsch said:

Not directly, but I had the same "problem" and now I do it this way:


// when debug mode is ON -> do not compress the styles 
if ($config->debug) { ?>
	<link rel="stylesheet" type="text/css" href="/path/to/css/..."/>
<? } else { ?>
	<link rel="stylesheet" type="text/css" href="<?php echo AIOM::CSS(/path/to/css/...); ?>"/>
<? }

 

 
 

@Stefanowitsch Thanks for tip, but it isn't relative to HTML minifying.

Share this post


Link to post
Share on other sites

I just found a collision cache file naming issue if all files have the same modified timestamp regardless of the array contents.

Simple fix to ensure the filename itself is included in the MD5($_timestamp)

$_timestamp = ($_timestamp + $file['last_modified'] . basename($file['absolute_path']));

https://github.com/FlipZoomMedia/ProcessWire-AIOM-All-In-One-Minify/issues/64

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!


Register a new account

Sign in

Already have an account? Sign in here.


Sign In Now

  • Recently Browsing   0 members

    No registered users viewing this page.

  • Similar Content

    • By matjazp
      Module: Auto Smush PDF
      https://github.com/matjazpotocnik/AutoSmushPDF 
      Compress PDF files automatically on upload,  manually by clicking the link for each file and in bulk mode for all PDF files.
      In Automatic mode PDF files that are uploaded are automatically compressed.
      In Manual mode "Compress" link will be present. This allows manual compression of the individual PDF file.
      In Bulk mode all PDF files can be compressed in one click. Will process PDF files sitewide, use with caution! 
      Using https://labstack.com/, free (at the moment) online web service that provides compressing of PDF files. There is no limit in file size and no limit on number of uploaded PDF's. No privacy policy available. 
       
      EDIT April 30 2017: This module is not working anymore as Labstack removed support for pdf compression.
    • By abdus
      After this tutorial you'll have learned how to:
      Build a Process module Make an AJAX request to backend Serve JSON as response Let's say you want to display the latest orders in a dashboard that you can access from admin panel. And you want it to refresh its content with a button click. Most straightforward and proper way (that I know of) is to create a Process module, as they're built for this purpose.
      First, create a directory under /site/modules/, call it ProcessDashboard, and create a file named ProcessDashboard.module under that directory. Following is about the least amount of code you need to create a Process module.
      <?php namespace ProcessWire; class ProcessDashboard extends Process implements Module { public static function getModuleInfo() { return [ 'title' => 'Orders Dashboard', 'summary' => 'Shows latest orders', 'version' => '0.0.1', 'author' => 'abdus', 'autoload' => true, // to automatically create process page 'page' => [ 'name' => 'order-dashboard', 'title' => 'Orders', 'template' => 'admin' ] ]; } public function install() { parent::install(); // to create process page } public function uninstall() { parent::uninstall(); // to the remove process page when uninstalling } public function ___execute() { return 'hello'; } } Once you refresh module cache from Modules > Refresh, you'll see your module. Install it.

      It will create an admin page under admin (/processwire/) and will show up as a new item in top menu, and when you click on it, it will show the markup we've built in execute() function.

       
      All right, now let's make it do something useful. Let's add create a data list to display latest orders. We'll change execute() function to render a data table.
      public function ___execute() { /* @var $table MarkupAdminDataTable */ $table = $this->modules->MarkupAdminDataTable; $table->setID($this->className . 'Table'); // "#ProcessDashboardTable" $table->headerRow([ 'Product', 'Date', 'Total' ]); // fill the table foreach ($this->getLatest(10) as $order) { $table->row([ $order['title'], $order['date'], $order['total'] ]); } // to refresh items $refreshButton = $this->modules->InputfieldSubmit; $refreshButton->name = 'refresh'; $refreshButton->id = $this->className . 'Refresh'; // "#ProcessDashboardRefresh" $refreshButton->value = 'Refresh'; // label of the button return $table->render() . $refreshButton->render(); } where getLatest() function finds and returns the latest orders (with only title, date and total fields)
      protected function getLatest($limit = 5, $start = 0) { // find last $limit orders, starting from $start $orders = $this->pages->find("template=order, sort=-created, limit=$limit, start=$start"); // Only return what's necessary return $orders->explode(function ($order) { return [ 'title' => $order->title, 'date' => date('Y-m-d h:i:s', $order->created), 'total' => $order->total ]; }); } When you refresh the page, you should see a table like this

      Now we'll make that Refresh button work. When the button is clicked, it will make an AJAX request to ./latest endpoint, which will return a JSON of latest orders. We need some JS to make AJAX request and render new values. Create a JS file ./assets/dashboard.js inside the module directory.
      window.addEventListener('DOMContentLoaded', function () { let refresh = document.querySelector('#ProcessDashboardRefresh'); let table = document.querySelector('#ProcessDashboardTable'); refresh.addEventListener('click', function (e) { // https://developer.mozilla.org/en/docs/Web/API/Event/preventDefault e.preventDefault(); // Send a GET request to ./latest // http://api.jquery.com/jquery.getjson/ $.getJSON('./latest', { limit: 10 }, function (data) { // check if data is how we want it // if (data.length) {} etc // it's good to go, update the table updateTable(data); }); }); function renderRow(row) { return `<tr> <td>${row.title}</td> <td>${row.date}</td> <td>${row.total}</td> </tr>`; } function updateTable(rows) { table.tBodies[0].innerHTML = rows.map(renderRow).join(''); } }); And we'll add this to list of JS that runs on backend inside init() function
      public function init() { $scriptUrl = $this->urls->$this . 'assets/dashboard.js'; $this->config->scripts->add($scriptUrl); } Requests to ./latest will be handled by ___executeLatest() function inside the module, just creating the function is enough, PW will do the routing. Here you should notice how we're getting query parameters that are sent with the request.
      // handles ./latest endpoint public function ___executeLatest() { // get limit from request, if not provided, default to 10 $limit = $this->sanitizer->int($this->input->get->limit) ?? 10; return json_encode($this->getRandom($limit)); } Here getRandom() returns random orders to make it look like there's new orders coming in. 
      protected function getRandom($limit = 5) { $orders = $this->pages->find("template=order, sort=random, limit=$limit"); return $orders->explode(function ($order) { return [ 'title' => $order->title, 'date' => date('Y-m-d h:i:s', $order->created), 'total' => $order->total ]; }); } And we're done. When refresh button is clicked, the table is refreshed with new data.
      Here it is in action: 
      2017-04-29_19-01-40.mp4 (227KB MP4, 0m4sec)
      Here's the source code:
      https://gist.github.com/abdusco/2bb649cd2fc181734a132b0e660f64a2
    • By justb3a
      Little admin helper module: Using this module you can view all template cache settings at once. E.g. cache status, cache time (configurable). Furthermore it adds the functionality to clear the entire template cache or just the template cache for a given template. Note that this may cause a temporary delay for one or more requests while pages are re-cached.

      GitHub: https://github.com/justb3a/processwire-templatecacheoverview
    • By blad
       
      Hi guys!
      I'm creating a module to manage, edit, publish ... pages. It is very similar to ProcessBatcher.
       
       
      Changelog:
      In progress 
      Features:



      Select pages with your mouse like a desktop enviroment. If you press "edit" the selected pages will appear in a lightbox.


      Drag pages to do actions.
      Any feedback is welcome
       
       
    • By abdus
      I dont know how they work internally, whether they depend on each other, but I'd love to be able to test and buy RepeaterMatrix or Multiplier or Table (or any other) module individually. Whole pack of ProFields modules seems awesome to have, however, being able to buy one for ~$30 --instead of all for $130-- sounds much more affordable and this way I could buy the whole pack part by part in several months and wouldn't think twice. But $130 at once, I can't really justify it (and still havent been able to) just as easily with low (to none) disposable student income.  Or instead, having sales one - twice a year would be great as well.
      One advantage of this change would be allowing more people to buy -> support the development & community -> give feedback -> improve these products. This could also potentially pose a disadvantage where requests from people would increase the headache and time required to respond to all these requests, but this community is more than able to handle that.
      I'm sure there's a reason to why these modules are sold together, and I'd love to hear your side as well, @ryan, (and all other maintainers).
      Regards,
      Abdus.