1766812936a:1:{s:20:"snowboard/extras.htm";a:8:{s:8:"fileName";s:20:"snowboard/extras.htm";s:7:"content";s:13621:"title = "Utilities | Snowboard"
url = "/snowboard/extras"
layout = "snowboard"
==
<?php

function onValidate()
{
    $validator = Validator::make(post(), [
        'first_name' => 'required|regex:/^[a-z \-]+$/i',
        'surname' => 'regex:/^[a-z \-]+$/i',
        'email' => 'required|email',
        'website' => 'url',
    ], [
        'first_name.regex' => 'First name may only contain letters, spaces and hyphens.',
        'surname.regex' => 'Surname may only contain letters, spaces and hyphens',
        'website.url' => 'Please enter a valid website URL',
    ]);

    if ($validator->fails()) {
        throw new ValidationException($validator);
    }
}
==
<section id="body" class="py-20 flex-grow">
    <div class="container max-w-screen-xl">
        <div class="block lg:flex lg:flex-row divide-x divide-gray-100">
            <div class="flew-grow-0 px-8 lg:w-2/12 xl:pr-0">
                {% partial 'snowboard/sections-list' %}
            </div>

            <div class="flex-grow-0 px-8 mt-16 lg:w-10/12 lg:mt-0">
                <h2>Extra Features</h2>

                <h3>Flash</h3>

                <!-- BEGIN Flash -->
                <hr class="mb-8">

                <h4 class="mb-0">Flash message</h4>
                <p>Creates a flash message that is displayed to the user, optionally with an override that prepends the message and overrides the duration.</p>

                <form class="grid grid-cols-3 gap-4" id="flash-message">
                    <div>
                        <label class="font-bold block mb-2" for="name">Message</label>
                        <input class="block w-full border border-amber-600 p-4 rounded" type="text" name="message" placeholder="Enter flash message" value="This is a flash message">
                    </div>
                    <div>
                        <label class="font-bold block mb-2" for="email">Type</label>
                        <select name="type" class="block w-full border border-amber-600 p-4 rounded">
                            <option name="success" selected>success</option>
                            <option name="warning">warning</option>
                            <option name="error">error</option>
                            <option name="info">info</option>
                            <option name="default">default</option>
                        </select>
                    </div>
                    <div>
                        <label class="font-bold block mb-2" for="email">Duration (secs)</label>
                        <input class="block w-full border border-amber-600 p-4 rounded" type="number" name="time" value="7" step="1" min="0">
                    </div>
                    <div class="col-span-3">
                        {% partial 'ui/button' id="flash-message-submit" color="amber" text="Submit" %}
                        {% partial 'ui/button' id="flash-message-override" color="amber" text="Add override" %}
                        {% partial 'ui/button' id="flash-message-no-override" color="amber" text="Remove override" %}
                    </div>
                </form>

                <script>
                let overrideClass = null;

                document.querySelector('#flash-message-submit').addEventListener('click', function (event) {
                    event.preventDefault();

                    Snowboard.flash(
                        document.querySelector('#flash-message input[name="message"]').value,
                        document.querySelector('#flash-message select[name="type"]').value,
                        document.querySelector('#flash-message input[name="time"]').value
                    );
                });

                document.querySelector('#flash-message-override').addEventListener('click', function (event) {
                    event.preventDefault();

                    if (overrideClass === null) {
                        overrideClass = class FlashOverride extends Snowboard.Singleton {
                            listens() {
                                return {
                                    'flash.create': 'onFlashCreate',
                                };
                            }

                            onFlashCreate(flash) {
                                flash.message = 'ALERT! ' + flash.message;
                                flash.duration = 5;
                            }
                        };
                    }

                    Snowboard.addPlugin('flashOverride', overrideClass);
                });

                document.querySelector('#flash-message-no-override').addEventListener('click', function (event) {
                    event.preventDefault();
                    Snowboard.removePlugin('flashOverride');
                });
                </script>
                <!-- END Flash -->

                <h3 class="mt-10">Validation</h3>

                <!-- BEGIN Single Validation Error -->
                <hr class="mb-8">

                <h4 class="mb-0">Single Validation Error</h4>
                <p>Shows only the first validation error (<a href="https://wintercms.com/docs/snowboard/extras#error-messages" target="docs" class="text-amber-600">Docs</a>)</p>

                <form data-request="onValidate" data-request-validate id="single-validation-error">
                    <div class="bg-red-100 border border-red-600 my-4 p-4" data-validate-error>
                        Default error message
                    </div>

                    <div class="grid grid-cols-2 gap-4">
                        <div>
                            <label class="font-bold block mb-2" for="first_name">First Name</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Required, must contain only letters, spaces and dashes</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="text" name="first_name" placeholder="Enter name">
                        </div>
                        <div>
                            <label class="font-bold block mb-2" for="surname">Surname</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Not required, must contain only letters, spaces and dashes</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="text" name="surname" placeholder="Enter name">
                        </div>
                        <div>
                            <label class="font-bold block mb-2" for="email">Email</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Required, must be an email</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="email" name="email" placeholder="Enter email">
                        </div>
                        <div>
                            <label class="font-bold block mb-2" for="website">Website</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Not required, must be a URL</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="text" name="website" placeholder="Enter website URL">
                        </div>
                        <div class="col-span-2">
                            {% partial 'ui/button' color="amber" text="Submit" submit=true %}
                        </div>
                    </div>
                </form>
                <!-- END Single Validation Error -->

                <!-- BEGIN Multiple Validation Errors -->
                <hr class="my-8">

                <h4 class="mb-0">Multiple Validation Errors</h4>
                <p>Shows all validation errors within a dedicated error message container (<a href="https://wintercms.com/docs/snowboard/extras#error-messages" target="docs" class="text-amber-600">Docs</a>)</p>

                <form data-request="onValidate" data-request-validate id="single-validation-error">
                    <div class="bg-red-100 border border-red-600 my-4 p-4" data-validate-error>
                        <strong>The following errors were reported:</strong>

                        <ul class="list-disc my-2 ml-8">
                            <li data-message></li>
                        </ul>

                        <p>Please review all fields and resubmit.</p>
                    </div>

                    <div class="grid grid-cols-2 gap-4">
                        <div>
                            <label class="font-bold block mb-2" for="first_name">First Name</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Required, must contain only letters, spaces and dashes</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="text" name="first_name" placeholder="Enter name">
                        </div>
                        <div>
                            <label class="font-bold block mb-2" for="surname">Surname</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Not required, must contain only letters, spaces and dashes</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="text" name="surname" placeholder="Enter name">
                        </div>
                        <div>
                            <label class="font-bold block mb-2" for="email">Email</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Required, must be an email</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="email" name="email" placeholder="Enter email">
                        </div>
                        <div>
                            <label class="font-bold block mb-2" for="website">Website</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Not required, must be a URL</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="text" name="website" placeholder="Enter website URL">
                        </div>
                        <div class="col-span-2">
                            {% partial 'ui/button' color="amber" text="Submit" submit=true %}
                        </div>
                    </div>
                </form>
                <!-- END Multiple Validation Errors -->

                <!-- BEGIN Field-Level Validation Errors -->
                <hr class="my-8">

                <h4 class="mb-0">Field-Level Validation Errors</h4>
                <p>Shows error messages that target specific fields (<a href="https://wintercms.com/docs/snowboard/extras#field-errors" target="docs" class="text-amber-600">Docs</a>)</p>

                <form data-request="onValidate" data-request-validate id="single-validation-error">
                    <div class="grid grid-cols-2 gap-4">
                        <div>
                            <label class="font-bold block mb-2" for="first_name">First Name</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Required, must contain only letters, spaces and dashes</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="text" name="first_name" placeholder="Enter name">
                        </div>
                        <div>
                            <label class="font-bold block mb-2" for="surname">Surname</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Not required, must contain only letters, spaces and dashes</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="text" name="surname" placeholder="Enter name">
                        </div>

                        <div class="bg-red-100 border border-red-600 my-4 p-4 col-span-2" data-validate-for="first_name, surname"></div>

                        <div>
                            <label class="font-bold block mb-2" for="email">Email</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Required, must be an email</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="email" name="email" placeholder="Enter email">
                        </div>
                        <div>
                            <label class="font-bold block mb-2" for="website">Website</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Not required, must be a URL</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="text" name="website" placeholder="Enter website URL">
                        </div>

                        <div class="bg-red-100 border border-red-600 my-4 p-4 col-start-1 col-end-1" data-validate-for="email">
                            Oops, invalid email address provided.
                        </div>
                        <div class="bg-red-100 border border-red-600 my-4 p-4 col-start-2 col-end-2" data-validate-for="website"></div>

                        <div class="col-span-2">
                            {% partial 'ui/button' color="amber" text="Submit" submit=true %}
                        </div>
                    </div>
                </form>
                <!-- END Multiple Validation Errors -->
            </div>
        </div>
    </div>
</section>
";s:5:"mtime";i:1678627025;s:6:"markup";s:12952:"<section id="body" class="py-20 flex-grow">
    <div class="container max-w-screen-xl">
        <div class="block lg:flex lg:flex-row divide-x divide-gray-100">
            <div class="flew-grow-0 px-8 lg:w-2/12 xl:pr-0">
                {% partial 'snowboard/sections-list' %}
            </div>

            <div class="flex-grow-0 px-8 mt-16 lg:w-10/12 lg:mt-0">
                <h2>Extra Features</h2>

                <h3>Flash</h3>

                <!-- BEGIN Flash -->
                <hr class="mb-8">

                <h4 class="mb-0">Flash message</h4>
                <p>Creates a flash message that is displayed to the user, optionally with an override that prepends the message and overrides the duration.</p>

                <form class="grid grid-cols-3 gap-4" id="flash-message">
                    <div>
                        <label class="font-bold block mb-2" for="name">Message</label>
                        <input class="block w-full border border-amber-600 p-4 rounded" type="text" name="message" placeholder="Enter flash message" value="This is a flash message">
                    </div>
                    <div>
                        <label class="font-bold block mb-2" for="email">Type</label>
                        <select name="type" class="block w-full border border-amber-600 p-4 rounded">
                            <option name="success" selected>success</option>
                            <option name="warning">warning</option>
                            <option name="error">error</option>
                            <option name="info">info</option>
                            <option name="default">default</option>
                        </select>
                    </div>
                    <div>
                        <label class="font-bold block mb-2" for="email">Duration (secs)</label>
                        <input class="block w-full border border-amber-600 p-4 rounded" type="number" name="time" value="7" step="1" min="0">
                    </div>
                    <div class="col-span-3">
                        {% partial 'ui/button' id="flash-message-submit" color="amber" text="Submit" %}
                        {% partial 'ui/button' id="flash-message-override" color="amber" text="Add override" %}
                        {% partial 'ui/button' id="flash-message-no-override" color="amber" text="Remove override" %}
                    </div>
                </form>

                <script>
                let overrideClass = null;

                document.querySelector('#flash-message-submit').addEventListener('click', function (event) {
                    event.preventDefault();

                    Snowboard.flash(
                        document.querySelector('#flash-message input[name="message"]').value,
                        document.querySelector('#flash-message select[name="type"]').value,
                        document.querySelector('#flash-message input[name="time"]').value
                    );
                });

                document.querySelector('#flash-message-override').addEventListener('click', function (event) {
                    event.preventDefault();

                    if (overrideClass === null) {
                        overrideClass = class FlashOverride extends Snowboard.Singleton {
                            listens() {
                                return {
                                    'flash.create': 'onFlashCreate',
                                };
                            }

                            onFlashCreate(flash) {
                                flash.message = 'ALERT! ' + flash.message;
                                flash.duration = 5;
                            }
                        };
                    }

                    Snowboard.addPlugin('flashOverride', overrideClass);
                });

                document.querySelector('#flash-message-no-override').addEventListener('click', function (event) {
                    event.preventDefault();
                    Snowboard.removePlugin('flashOverride');
                });
                </script>
                <!-- END Flash -->

                <h3 class="mt-10">Validation</h3>

                <!-- BEGIN Single Validation Error -->
                <hr class="mb-8">

                <h4 class="mb-0">Single Validation Error</h4>
                <p>Shows only the first validation error (<a href="https://wintercms.com/docs/snowboard/extras#error-messages" target="docs" class="text-amber-600">Docs</a>)</p>

                <form data-request="onValidate" data-request-validate id="single-validation-error">
                    <div class="bg-red-100 border border-red-600 my-4 p-4" data-validate-error>
                        Default error message
                    </div>

                    <div class="grid grid-cols-2 gap-4">
                        <div>
                            <label class="font-bold block mb-2" for="first_name">First Name</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Required, must contain only letters, spaces and dashes</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="text" name="first_name" placeholder="Enter name">
                        </div>
                        <div>
                            <label class="font-bold block mb-2" for="surname">Surname</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Not required, must contain only letters, spaces and dashes</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="text" name="surname" placeholder="Enter name">
                        </div>
                        <div>
                            <label class="font-bold block mb-2" for="email">Email</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Required, must be an email</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="email" name="email" placeholder="Enter email">
                        </div>
                        <div>
                            <label class="font-bold block mb-2" for="website">Website</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Not required, must be a URL</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="text" name="website" placeholder="Enter website URL">
                        </div>
                        <div class="col-span-2">
                            {% partial 'ui/button' color="amber" text="Submit" submit=true %}
                        </div>
                    </div>
                </form>
                <!-- END Single Validation Error -->

                <!-- BEGIN Multiple Validation Errors -->
                <hr class="my-8">

                <h4 class="mb-0">Multiple Validation Errors</h4>
                <p>Shows all validation errors within a dedicated error message container (<a href="https://wintercms.com/docs/snowboard/extras#error-messages" target="docs" class="text-amber-600">Docs</a>)</p>

                <form data-request="onValidate" data-request-validate id="single-validation-error">
                    <div class="bg-red-100 border border-red-600 my-4 p-4" data-validate-error>
                        <strong>The following errors were reported:</strong>

                        <ul class="list-disc my-2 ml-8">
                            <li data-message></li>
                        </ul>

                        <p>Please review all fields and resubmit.</p>
                    </div>

                    <div class="grid grid-cols-2 gap-4">
                        <div>
                            <label class="font-bold block mb-2" for="first_name">First Name</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Required, must contain only letters, spaces and dashes</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="text" name="first_name" placeholder="Enter name">
                        </div>
                        <div>
                            <label class="font-bold block mb-2" for="surname">Surname</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Not required, must contain only letters, spaces and dashes</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="text" name="surname" placeholder="Enter name">
                        </div>
                        <div>
                            <label class="font-bold block mb-2" for="email">Email</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Required, must be an email</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="email" name="email" placeholder="Enter email">
                        </div>
                        <div>
                            <label class="font-bold block mb-2" for="website">Website</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Not required, must be a URL</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="text" name="website" placeholder="Enter website URL">
                        </div>
                        <div class="col-span-2">
                            {% partial 'ui/button' color="amber" text="Submit" submit=true %}
                        </div>
                    </div>
                </form>
                <!-- END Multiple Validation Errors -->

                <!-- BEGIN Field-Level Validation Errors -->
                <hr class="my-8">

                <h4 class="mb-0">Field-Level Validation Errors</h4>
                <p>Shows error messages that target specific fields (<a href="https://wintercms.com/docs/snowboard/extras#field-errors" target="docs" class="text-amber-600">Docs</a>)</p>

                <form data-request="onValidate" data-request-validate id="single-validation-error">
                    <div class="grid grid-cols-2 gap-4">
                        <div>
                            <label class="font-bold block mb-2" for="first_name">First Name</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Required, must contain only letters, spaces and dashes</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="text" name="first_name" placeholder="Enter name">
                        </div>
                        <div>
                            <label class="font-bold block mb-2" for="surname">Surname</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Not required, must contain only letters, spaces and dashes</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="text" name="surname" placeholder="Enter name">
                        </div>

                        <div class="bg-red-100 border border-red-600 my-4 p-4 col-span-2" data-validate-for="first_name, surname"></div>

                        <div>
                            <label class="font-bold block mb-2" for="email">Email</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Required, must be an email</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="email" name="email" placeholder="Enter email">
                        </div>
                        <div>
                            <label class="font-bold block mb-2" for="website">Website</label>
                            <span class="block text-gray-400 -mt-2 mb-2 text-xs">Not required, must be a URL</span>
                            <input class="block w-full border border-amber-600 p-4 rounded" type="text" name="website" placeholder="Enter website URL">
                        </div>

                        <div class="bg-red-100 border border-red-600 my-4 p-4 col-start-1 col-end-1" data-validate-for="email">
                            Oops, invalid email address provided.
                        </div>
                        <div class="bg-red-100 border border-red-600 my-4 p-4 col-start-2 col-end-2" data-validate-for="website"></div>

                        <div class="col-span-2">
                            {% partial 'ui/button' color="amber" text="Submit" submit=true %}
                        </div>
                    </div>
                </form>
                <!-- END Multiple Validation Errors -->
            </div>
        </div>
    </div>
</section>";s:4:"code";s:575:"function onValidate()
{
    $validator = Validator::make(post(), [
        'first_name' => 'required|regex:/^[a-z \-]+$/i',
        'surname' => 'regex:/^[a-z \-]+$/i',
        'email' => 'required|email',
        'website' => 'url',
    ], [
        'first_name.regex' => 'First name may only contain letters, spaces and hyphens.',
        'surname.regex' => 'Surname may only contain letters, spaces and hyphens',
        'website.url' => 'Please enter a valid website URL',
    ]);

    if ($validator->fails()) {
        throw new ValidationException($validator);
    }
}";s:5:"title";s:21:"Utilities | Snowboard";s:3:"url";s:17:"/snowboard/extras";s:6:"layout";s:9:"snowboard";}}