123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 |
- /**
- * Copyright © Magento, Inc. All rights reserved.
- * See COPYING.txt for license details.
- */
- define([
- 'jquery',
- 'jquery/ui'
- ], function ($) {
- 'use strict';
- $.widget('mage.giftOptions', {
- options: {
- mageError: 'mage-error',
- noDisplay: 'no-display',
- requiredEntry: 'required-entry'
- },
- /**
- * Initial toggle of the various gift options after widget instantiation.
- * @private
- */
- _init: function () {
- this._toggleVisibility();
- },
- /**
- * Bind a click handler to the widget's context element.
- * @private
- */
- _create: function () {
- this.element.on('click', $.proxy(this._toggleVisibility, this));
- $(this.element.data('selector').id).find('.giftmessage-area')
- .on('change', $.proxy(this._toggleRequired, this));
- },
- /**
- * Toggle the visibility of the widget's context element's selector(s).
- * @private
- * @param {jQuery.Event} event - Click event. Target is a checkbox.
- */
- _toggleVisibility: function (event) {
- var checkbox = event ? $(event.target) : this.element,
- container = $(checkbox.data('selector').id),
- _this;
- if (checkbox.is(':checked')) {
- container.show()
- .find('.giftmessage-area:not(:visible)').each(function (x, element) {
- if ($(element).val().length > 0) {
- $(element).change();
- container.find('a').click();
- }
- });
- } else {
- _this = this;
- container.hide()
- .find('.input-text:not(.giftmessage-area)').each(function (x, element) {
- $(element).val(element.defaultValue).removeClass(_this.options.mageError)
- .next('div.' + _this.options.mageError).remove();
- }).end()
- .find('.giftmessage-area').val('').change().end()
- .find('.select').val('').change().end()
- .find('.checkbox:checked').prop('checked', false).click().prop('checked', false).end()
- .find('.price-box').addClass(this.options.noDisplay).end();
- }
- },
- /**
- * Make the From and To input fields required if a gift message has been written.
- * @private
- * @param {jQuery.Event} event - Change event. Target is a textarea.
- */
- _toggleRequired: function (event) {
- var textArea = $(event.target),
- length = textArea.val().length;
- textArea.closest('li').prev('.fields')
- .find('.input-text').toggleClass(this.options.requiredEntry, length > 0);
- }
- });
- return $.mage.giftOptions;
- });
|