/*! http://mths.be/details v0.0.6 by @mathias | includes http://mths.be/noselect v1.0.3 */
define([
    "jquery",
    "modernizr/modernizr.details"
], function($){

    var proto = $.fn,
        details,
        // :'(
        isOpera = Object.prototype.toString.call(window.opera) == '[object Opera]',
        // Feature test for native `<details>` support
        isDetailsSupported = $('html').hasClass('details'),
        toggleOpen = function($details, $detailsSummary, $detailsNotSummary, toggle) {
            var isOpen = typeof $details.attr('open') == 'string',
                close = isOpen && toggle || !isOpen && !toggle;
            if (close) {
                $details.removeClass('open').prop('open', false).triggerHandler('close.details');
                $detailsSummary.attr('aria-expanded', false);
                $detailsNotSummary.hide();
            } else {
                $details.addClass('open').prop('open', true).triggerHandler('open.details');
                $detailsSummary.attr('aria-expanded', true);
                $detailsNotSummary.show();
            }
        };

    /* http://mths.be/noselect v1.0.3 */
    proto.noSelect = function() {

        // Since the string 'none' is used three times, storing it in a variable gives better results after minification
        var none = 'none';

        // onselectstart and ondragstart for WebKit & IE
        // onmousedown for WebKit & Opera
        return this.bind('selectstart dragstart mousedown', function() {
            return false;
        }).css({
            'MozUserSelect': none,
            'msUserSelect': none,
            'webkitUserSelect': none,
            'userSelect': none
        });

    };

    // Execute the fallback only if there’s no native `details` support
    if (isDetailsSupported) {
        details = proto.details = function() {

            return this.each(function() {
                var $details = $(this),
                    $summary = $('summary', $details).first();
                $summary.attr({
                    'role': 'button',
                    'aria-expanded': $details.prop('open')
                }).on('click.xxx', function() {
                    // the value of the `open` property is the old value
                    var close = $details.prop('open');
                    $summary.attr('aria-expanded', !close);
                    $details.triggerHandler((close ? 'close' : 'open') + '.details');
                });
            });

        };

        details.support = isDetailsSupported;

    } else {
        details = proto.details = function() {

            // Loop through all `details` elements
            return this.each(function() {

                // Store a reference to the current `details` element in a variable
                var $details = $(this),
                    // Store a reference to the `summary` element of the current `details` element (if any) in a variable
                    $detailsSummary = $('summary', $details).first(),
                    // Do the same for the info within the `details` element
                    $detailsNotSummary = $details.children(':not(summary)'),
                    // This will be used later to look for direct child text nodes
                    $detailsNotSummaryContents = $details.contents(':not(summary)');

                // If there is no `summary` in the current `details` element…
                if (!$detailsSummary.length) {
                    // …create one with default text
                    $detailsSummary = $('<summary>').text($.mage.__('Details')).prependTo($details);
                }

                // Look for direct child text nodes
                if ($detailsNotSummary.length != $detailsNotSummaryContents.length) {
                    // Wrap child text nodes in a `span` element
                    $detailsNotSummaryContents.filter(function() {
                        // Only keep the node in the collection if it’s a text node containing more than only whitespace
                        // http://www.whatwg.org/specs/web-apps/current-work/multipage/common-microsyntaxes.html#space-character
                        return this.nodeType == 3 && /[^ \t\n\f\r]/.test(this.data);
                    }).wrap('<span>');
                    // There are now no direct child text nodes anymore — they’re wrapped in `span` elements
                    $detailsNotSummary = $details.children(':not(summary)');
                }

                // Hide content unless there’s an `open` attribute
                toggleOpen($details, $detailsSummary, $detailsNotSummary);

                // Add `role=button` and set the `tabindex` of the `summary` element to `0` to make it keyboard accessible
                $detailsSummary.attr('role', 'button').noSelect().prop('tabIndex', 0).off('click').on('click.details', function() {
                    // Focus on the `summary` element
                    $detailsSummary.focus();
                    // Toggle the `open` and `aria-expanded` attributes and the `open` property of the `details` element and display the additional info
                    toggleOpen($details, $detailsSummary, $detailsNotSummary, true);
                }).keyup(function(event) {
                    if (32 == event.keyCode || (13 == event.keyCode && !isOpera)) {
                        // Space or Enter is pressed — trigger the `click` event on the `summary` element
                        // Opera already seems to trigger the `click` event when Enter is pressed
                        event.preventDefault();
                        $detailsSummary.click();
                    }
                });

            });

        };

        details.support = isDetailsSupported;

    }

});