Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Debug mode not working as expected #80

Open
gregorybesson opened this issue Jun 25, 2013 · 23 comments
Open

Debug mode not working as expected #80

gregorybesson opened this issue Jun 25, 2013 · 23 comments
Labels

Comments

@gregorybesson
Copy link
Collaborator

Dear all,

First of all, I'm really thankfull for your work on Zf2-assetic. Thank you :)

I can't figure out how to set the debug mode so that the js and css aren't combined in one file but stay file by file so that debugging is feasable.

If I set debug as true, it doesn't produce anything... Any help would be appreciated (or is it a bug ?)

@widmogrod
Copy link
Owner

Hi, debug mode is working like here https://github.com/kriswallsmith/assetic#asset-factory
So in debug mode all filters that are prepended with question mark "?" wont be used.
This is great in development environment i.e when you using JSMinify

On devel branch, is new documentation (still in progress) but can be helpful.
https://github.com/widmogrod/zf2-assetic-module/blob/devel/docs/config.md

@gregorybesson
Copy link
Collaborator Author

Thanks a lot for your prompt reply.

Anyway, what we all need -I think- is about the feature explained in the twig section of https://github.com/kriswallsmith/assetic#asset-factory

When the extension is in debug mode, this same tag will render multiple link elements, one for each asset
referenced by the css/src/*.sass glob. The specified filters will still be applied, unless they are marked as optional
using the ? prefix.

This behavior can also be triggered by setting a debug attribute on the tag:

{% stylesheets 'css/*' debug=true %} ... {% stylesheets %}
These assets need to be written to the web directory so these URLs don't return 404 errors.

This behavior would be great in the view helper don't you think so ?

@widmogrod
Copy link
Owner

Good point.
In next version I will implement such view helper with similar functionality.

@gregorybesson
Copy link
Collaborator Author

Thanks a lot Gabriel,

If you need help, I'd be happy to collaborate ;) Just tell me how you'd like to implement it (I wonder if we could utilize the assetic file : functions.php

function _assetic_urls($inputs = array(), $filters = array(), array $options = array())
{
global $_assetic;

if (!is_array($inputs)) {
    $inputs = array_filter(array_map('trim', explode(',', $inputs)));
}

if (!is_array($filters)) {
    $filters = array_filter(array_map('trim', explode(',', $filters)));
}

$coll = $_assetic->factory->createAsset($inputs, $filters, $options);

$debug = isset($options['debug']) ? $options['debug'] : $_assetic->factory->isDebug();
$combine = isset($options['combine']) ? $options['combine'] : !$debug;

$one = $coll->getTargetPath();
if ($combine) {
    $many = array();
    foreach ($coll as $leaf) {
        $many[] = $leaf->getTargetPath();
    }
} else {
    $many = array($one);
}

return new TraversableString($one, $many);
}

@widmogrod
Copy link
Owner

I thinking of helper that will utilize AsseticBundle configuration,

For example, lets assume that we have following configuration:

<?php
return array(
    'assetic_configuration' => array(
        'modules' => array(
            'Your_Module_Name' => array(
                'collections' => array(
                    'my_css' => array(
                        'assets' => array(
                            // Relative to 'root_path'
                            'css/reset.css',
                            'css/global.css',

                        ),
                        'filters' => array(
                            '?CssRewriteFilter' => array(
                                'name' => 'Assetic\Filter\CssRewriteFilter'
                            ),
                            '?CssMinFilter' => array(
                                'name' => 'Assetic\Filter\CssMinFilter'

In layout.phtml in head section we use assetic helper like this:

echo $this->assetic('my_css');

In debug mode enabled will produce:

<link href="css/reset.css" >
<link href="css/global.css" >

In debug mode disabled will produce:

<link href="css/my.css" >

This is my proposition.

@widmogrod
Copy link
Owner

Greg, help as always, is welcome :)

@gregorybesson
Copy link
Collaborator Author

Ok for your proposal with a precision and maybe an improvement:

Today, for being able to render in the headscript, we have to put a "head_" prefix in the name of the asset. I don't like this.
What we could do is to add a new entry in your module.config.php (for example 'render'):

'base_js' => array(
    'assets' => array(
        'js/lib/jquery-1.9.0.min.js',
        'js/loader.js',
    ),
    'filters' => array(),
    'options' => array(),
    'render' => 'head' // (2 possible values : 'head', 'inline' which is the default)
),

So that we could use this 'render' option when each collection are rendered.

Then, in the View helper, we'd use your proposal to render the collections depending on the general debug option.

Of course, we can postpone this 'render' option after the debug view implementation. What do you think ?

@widmogrod
Copy link
Owner

Good idea.

Maybe even better would be to put render into options:

'base_js' => array(
    'assets' => array(
        'js/lib/jquery-1.9.0.min.js',
        'js/loader.js',
    ),
    'filters' => array(),
    'options' => array(
        'render' => 'head' // (2 possible values : 'head', 'inline' which is the default)
    ),
),

And thanks to that is even cleaner :)

@gregorybesson
Copy link
Collaborator Author

Fully agree !

Let's go ! How do you want to proceed and when ? Do you want me to do the dev and PR or do you have some time to help ?

@widmogrod
Copy link
Owner

Today I don't have time but tomorrow I can help.
I add you as collaborator to this project.
Please work on devel branch.
When I have time I will join you.

@gregorybesson
Copy link
Collaborator Author

Ok then,

I won't be able to work on it this week (but I'll be this week-end) : This is the big sales week in France !

I'll keep you informed

@widmogrod
Copy link
Owner

Ok.

@widmogrod
Copy link
Owner

Ok, debug mode now (in devel branch) is working as expected.
Asset collection are move as separate files not as single file.
Only thing to enable this functionality is to set debug to true.

This commit explains what was changed: 08e0c50

Only thing that remains is to set options to view renderer strategy.

@gregorybesson
Copy link
Collaborator Author

Ok then. Thanks for that. I'll take care of the remaining option

Cordialement,
*
*
GREGORY BESSON
CEO - Adfab Connect
CTO - Groupe Adfab

tel : +33 1 81 00 50 26 / mob : +33 6 85 88 55 00
[email protected] / Twitter : @gregorybesson
Immeuble Carré haussmann
4 allée du trait d'Union
77127 Lieusaint
www.adfab. http://www.adfab.fr/fr http://www.adfab.fr/

[image: logo_signature_email.jpg]

2013/6/28 Gabriel Habryn [email protected]

Ok, debug mode now (in devel branch) is working as expected.
Asset collection are move as separate files not as single file.
Only thing to enable this functionality is to set debug to true.

This commit explains what was changed: 08e0c5008e0c50

Only thing that remains is to set options to view renderer strategy.


Reply to this email directly or view it on GitHubhttps://github.com//issues/80#issuecomment-20177592
.

@tommyseus
Copy link

I don't like the solution. We have collections with 20 js files and in debug mode now 20 requests. It would be better to introduce the $combine option.

\Assetic\Extension\Twig\AsseticNode
The Twig Extension has this param too (ignores false at the moment).

@widmogrod
Copy link
Owner

Thanks for tip. I'll add something like this

@gregorybesson
Copy link
Collaborator Author

Tommy you're right,
Gabriel, you're a monster ;)

Cordialement,
*
*
GREGORY BESSON
CEO - Adfab Connect
CTO - Groupe Adfab

tel : +33 1 81 00 50 26 / mob : +33 6 85 88 55 00
[email protected] / Twitter : @gregorybesson
Immeuble Carré haussmann
4 allée du trait d'Union
77127 Lieusaint
www.adfab. http://www.adfab.fr/fr http://www.adfab.fr/

[image: logo_signature_email.jpg]

2013/6/28 Gabriel Habryn [email protected]

Thanks for tip. I'll add something like this


Reply to this email directly or view it on GitHubhttps://github.com//issues/80#issuecomment-20194377
.

@widmogrod
Copy link
Owner

Yes, I am ]:->

There is one use case that can give you benefit of such approach.

  • If you have 20 separate files and you changing one file then only this file will be updated by AsseticBundle; then browser should load only this one file (ofcorese you need have browser cache enabled)
  • If you combine those files to one, then on every small change AsseticBundle will update combined file - and this file won't be cached in browser, and additionally will take more time to load because of its size

@gregorybesson
Copy link
Collaborator Author

As explained and asked by Tommy,

I'll add the combine option on the same level as the debug one in compliancy with what is done in the original assetic stack.
I'll add the 'render' in options.

Plan to PR this tomorrow in the afternoon.

@widmogrod
Copy link
Owner

Exellent.

@andylib
Copy link

andylib commented Jul 21, 2013

Hi all,

What is the status of this discussion? Is this done?
I am waiting for this view helper also. Maybe I can help contributing something :)

@gregorybesson
Copy link
Collaborator Author

Hi Andy,

The combine option has been added and Gabriel has accepted the PR. However, I'm not sure if it has been tagged and released in the last stable version.

Gabriel ?

@widmogrod
Copy link
Owner

Hi, sorry for delay. I was on vacations.
Lateset tag is now 1.3.2.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

4 participants