NAME
    jQuery::Loader - Load (and cache) the jQuery JavaScript library

VERSION
    Version 0.03

jQuery VERSION
    Version 1.2.6

SYNOPSIS
        use jQuery::Loader;

        my $loader = jQuery::Loader->new_from_internet;
        print $loader->html;

        # The above will yield:
        # <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.2.6/jquery.js" type="text/javascript"></script>


        # If you need the minified version, you can use the following:
        $loader = jQuery::Loader->new_from_internet(filter => "min");

        # Which will yield:
        # <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.2.6/jquery.min.js" type="text/javascript"></script>

    You can also cache jQuery locally:

        my $loader = jQuery::Loader->new_from_internet(cache => { dir => "htdocs/assets/\%l", uri => "http://localhost/assets/\%l" });
        print $loader->html;

        # The above will yield:
        # <script src="http://localhost/assets/jquery-1.2.6.js">

DESCRIPTION
    jQuery::Loader is a tool for fetching and serving the jQuery JavaScript
    library. Using this package you can download jQuery directly from
    <http://code.google.com/p/jqueryjs/>, cache it locally, and serve it
    from a URI within your application.

Specifying URI/file locations for the jQuery .js asset
    90% of the time, you should be able to get by by specifying an absolute
    URI/file location. Something like this, for example:

        jQuery::Loader->new_from_internet(cache => { uri => "http://localhost/assets/jquery.js", file => "htdocs/assets/jquery.js" })

    However, if you want more control over the path (like specifying
    filter/version information, you can use the following conversion
    specifications:

        %l          The value of the location parameter as passed to the cache constructor
                    You can use this to specify a path common to both the uri-part and file-part of the cache
                    The location parameter value can also include %j, %v, $f, etc.

        %j          Equivalent to "jquery%-v%.f.js"

        %v          The number of the version jQuery being used (e.g. "1.2.6")
        %[./-]v     Preceding %v with a ., /, or - will put that same character in
                    front of the number, or a nothing for the whole specification if no version is given

        %f          The name of the filter being used (e.g. "min")
        %[./-]f     Preceding %f with a ., /, or - will put that same character in
                    front of the filter, or a nothing for the whole specification if no filter is in use

    Here is an example:

        location => "js/jq%-v.js"           # js/jq-1.2.6.js
        uri => "http://localhost/assets/%l" # http://localhost/assets/js/jq-1.2.6.js
        file => "./htdocs/static/%l"        # ./htdocs/static/js/jq-1.2.6.js

METHODS
  jQuery::Loader->new_from_internet([ version => <version>, cache => <cache> ])
    Return a new jQuery::Loader object configured to serve/fetch the jQuery
    .js asset from from the Internet (currently
    <http://jqueryjs.googlecode.com/files/jquery-1.2.6.js>)

  jQuery::Loader->new_from_uri([ uri => <uri>, cache => <cache> ])
    Return a new jQuery::Loader object configured to serve/fetch the jQuery
    .js asset from an arbitrary uri

    As an example, for a <uri> of "http://localhost/assets/%l", the jQuery
    asset uri should be

        http://localhost/assets/jquery-1.2.6.js

  jQuery::Loader->new_from_file([ file => <file>, cache => <cache> ])
    Return a new jQuery::Loader object configured to fetch/serve the jQuery
    .js asset from an arbitrary file

    As an example, for a file of "./assets/%l", the jQuery asset file should
    be

        ./assets/jquery-1.2.6.js

  $loader->filter( <filter> )
    Set or clear the current filter

    Currently, "min" is the only valid filter

    Pass "undef" to clear the filter

    These are equivalent:

        $loader->filter_min
        $loader->filter("min")

        $loader->no_filter
        $loader->filter(undef)

  $loader->version( <version> )
    Set which jQuery version you want to use

    This will also change the filename of the jQuery asset (unless the
    source/cache has been specially configured)

    By default, the latest version is used:

        $loader->version("1.2.6");

  $loader->filter_min
    Use the .min version of jQuery

  $loader->no_filter
    Disable filtering of included components (do not use the .min version)

  $loader->uri
    Attempt to fetch a URI for jQuery using the current filter setting of
    the loader (.min, etc.)

    If the loader has a cache, then this method will try to fetch from the
    cache. Otherwise it will use the source.

  $loader->file
    Attempt to fetch a Path::Class::File for jQuery using the current filter
    setting of the loader (.min, etc.)

    If the loader has a cache, then this method will try to fetch from the
    cache. Otherwise it will use the source.

  $loader->cache_uri
    Attempt to fetch a URI for jQuery using the current filter setting of
    the loader (.min, etc.) from the cache

  $loader->cache_file
    Attempt to fetch a Path::Class::File for jQuery using the current filter
    setting of the loader (.min, etc.) from the cache

  $loader->source_uri
    Attempt to fetch a URI for jQuery using the current filter setting of
    the loader (.min, etc.) from the source

  $loader->source_file
    Attempt to fetch a Path::Class::File for jQuery using the current filter
    setting of the loader (.min, etc.) from the source

  $loader->html
    Generate and return a string containing HTML describing how to include
    components. For example, you can use this in the <head> section of a web
    page.

    If the loader has a cache, then it will attempt to generate URIs from
    the cache, otherwise it will use the source.

    Here is an example:

        <script src="http://localhost/assets/jquery-1.2.6.js" type="text/javascript"></script>

  $loader->source_html
    Generate and return a string containing HTML describing how to include
    components. For example, you can use this in the <head> section of a web
    page.

    Here is an example:

        <script src="http://localhost/assets/jquery-1.2.6.js" type="text/javascript"></script>

AUTHOR
    Robert Krimen, "<rkrimen at cpan.org>"

SEE ALSO
    <http://jquery.com/>

    <http://code.google.com/p/jqueryjs/>

    jQuery

    YUI::Loader

BUGS
    Please report any bugs or feature requests to "bug-js-jquery-loader at
    rt.cpan.org", or through the web interface at
    <http://rt.cpan.org/NoAuth/ReportBug.html?Queue=jQuery-Loader>. I will
    be notified, and then you'll automatically be notified of progress on
    your bug as I make changes.

SUPPORT
    You can find documentation for this module with the perldoc command.

        perldoc jQuery::Loader

    You can also look for information at:

    *   RT: CPAN's request tracker

        <http://rt.cpan.org/NoAuth/Bugs.html?Dist=jQuery-Loader>

    *   AnnoCPAN: Annotated CPAN documentation

        <http://annocpan.org/dist/jQuery-Loader>

    *   CPAN Ratings

        <http://cpanratings.perl.org/d/jQuery-Loader>

    *   Search CPAN

        <http://search.cpan.org/dist/jQuery-Loader>

ACKNOWLEDGEMENTS
COPYRIGHT & LICENSE
    Copyright 2008 Robert Krimen, all rights reserved.

    This program is free software; you can redistribute it and/or modify it
    under the same terms as Perl itself.