NAME
    Plack::App::Search - Plack search application.

SYNOPSIS
     use Plack::App::Search;

     my $obj = Plack::App::Search->new(%parameters);
     my $psgi_ar = $obj->call($env);
     my $app = $obj->to_app;

METHODS
  "new"
     my $obj = Plack::App::Search->new(%parameters);

    Constructor.

    *       "css"

            Instance of CSS::Struct::Output object.

            Default value is CSS::Struct::Output::Raw instance.

    *       "generator"

            HTML generator string.

            Default value is 'Plack::App::Search; Version: __VERSION__'

    *       "image_height"

            Image height.

            Default value is undef, this mean real height of image.

    *       "image_link"

            URL to image above form. Image is centered.

            Default value is undef.

    *       "image_radius"

            CSS radius of image.

            Default value is 0.

    *       "search_method"

            Search method.

            Default value is 'search'.

    *       "search_placeholder"

            Search placeholder text.

            It's optional.

            Default value is undef.

    *       "search_title"

            Search title. There will be button with text in this title if is
            defined. If not, form is without button.

            Default value is undef.

    *       "search_url"

            Search URL.

            Default value is 'https://env.skim.cz'.

    *       "tags"

            Instance of Tags::Output object.

            Default value is Tags::Output::Raw->new('xml' => 1) instance.

    *       "tags_after"

            Reference to array with Tags code to add after search field.

            Default value is undef.

    *       "title"

            Page title.

            Default value is 'Login page'.

    Returns instance of object.

  "call"
     my $psgi_ar = $obj->call($env);

    Implementation of search page.

    Returns reference to array (PSGI structure).

  "to_app"
     my $app = $obj->to_app;

    Creates Plack application.

    Returns Plack::Component object.

EXAMPLE1
     use strict;
     use warnings;

     use CSS::Struct::Output::Indent;
     use Plack::App::Search;
     use Plack::Runner;
     use Tags::Output::Indent;

     # Run application.
     my $app = Plack::App::Search->new(
             'css' => CSS::Struct::Output::Indent->new,
             'generator' => 'Plack::App::Search',
             'tags' => Tags::Output::Indent->new(
                     'preserved' => ['style'],
                     'xml' => 1,
             ),
     )->to_app;
     Plack::Runner->new->run($app);

     # Output:
     # HTTP::Server::PSGI: Accepting connections at http://0:5000/

     # > curl http://localhost:5000/
     # <!DOCTYPE html>
     # <html lang="en">
     #   <head>
     #     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
     #     <meta name="generator" content="Plack::App::Search" />
     #     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
     #     <title>
     #       Search page
     #     </title>
     #     <style type="text/css">
     # * {
     #      box-sizing: border-box;
     #      margin: 0;
     #      padding: 0;
     # }
     # .container {
     #      display: flex;
     #      align-items: center;
     #      justify-content: center;
     #      height: 100vh;
     # }
     # .search form {
     #      display: flex;
     #      align-items: center;
     # }
     # .search input[type="text"] {
     #      padding: 10px;
     #      border-radius: 4px;
     #      border: 1px solid #ccc;
     # }
     # .search button {
     #      margin-left: 10px;
     #      padding: 10px 20px;
     #      border-radius: 4px;
     #      background-color: #4CAF50;
     #      color: white;
     #      border: none;
     #      cursor: pointer;
     #      display: none;
     # }
     # .search button:hover {
     #      background-color: #45a049;
     # }
     # </style>
     #   </head>
     #   <body>
     #     <div class="container">
     #       <div class="search">
     #         <form method="get" action="https://env.skim.cz">
     #           <input type="text" autofocus="autofocus" />
     #           <button type="submit" />
     #         </form>
     #       </div>
     #     </div>
     #   </body>
     # </html>

EXAMPLE2
     use strict;
     use warnings;

     use CSS::Struct::Output::Indent;
     use Plack::App::Search;
     use Plack::Runner;
     use Tags::Output::Indent;

     # Run application.
     my $app = Plack::App::Search->new(
             'css' => CSS::Struct::Output::Indent->new,
             'generator' => 'Plack::App::Search',
             'search_title' => 'Search',
             'tags' => Tags::Output::Indent->new(
                     'preserved' => ['style'],
                     'xml' => 1,
             ),
     )->to_app;
     Plack::Runner->new->run($app);

     # Output:
     # HTTP::Server::PSGI: Accepting connections at http://0:5000/

     # > curl http://localhost:5000/
     # <!DOCTYPE html>
     # <html lang="en">
     #   <head>
     #     <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
     #     <meta name="generator" content="Plack::App::Search" />
     #     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
     #     <title>
     #       Search page
     #     </title>
     #     <style type="text/css">
     # * {
     #      box-sizing: border-box;
     #      margin: 0;
     #      padding: 0;
     # }
     # .container {
     #      display: flex;
     #      align-items: center;
     #      justify-content: center;
     #      height: 100vh;
     # }
     # .search form {
     #      display: flex;
     #      align-items: center;
     # }
     # .search input[type="text"] {
     #      padding: 10px;
     #      border-radius: 4px;
     #      border: 1px solid #ccc;
     # }
     # .search button {
     #      margin-left: 10px;
     #      padding: 10px 20px;
     #      border-radius: 4px;
     #      background-color: #4CAF50;
     #      color: white;
     #      border: none;
     #      cursor: pointer;
     # }
     # .search button:hover {
     #      background-color: #45a049;
     # }
     # </style>
     #   </head>
     #   <body>
     #     <div class="container">
     #       <div class="search">
     #         <form method="get" action="https://env.skim.cz">
     #           <input type="text" autofocus="autofocus" />
     #           <button type="submit">
     #             Search
     #           </button>
     #         </form>
     #       </div>
     #     </div>
     #   </body>
     # </html>

DEPENDENCIES
    Plack::Component::Tags::HTML, Plack::Util::Accessor,
    Tags::HTML::Container.

REPOSITORY
    <https://github.com/michal-josef-spacek/Plack-App-Search>

AUTHOR
    Michal Josef Špaček <mailto:skim@cpan.org>

    <http://skim.cz>

LICENSE AND COPYRIGHT
    © 2021-2024 Michal Josef Špaček

    BSD 2-Clause License

VERSION
    0.05