/** * Magento * * NOTICE OF LICENSE * * This source file is subject to the Academic Free License (AFL 3.0) * that is bundled with this package in the file LICENSE_AFL.txt. * It is also available through the world-wide-web at this URL: * http://opensource.org/licenses/afl-3.0.php * If you did not receive a copy of the license and are unable to * obtain it through the world-wide-web, please send an email * to license@magentocommerce.com so we can send you a copy immediately. * * DISCLAIMER * * Do not edit or add to this file if you wish to upgrade Magento to newer * versions in the future. If you wish to customize Magento for your * needs please refer to http://www.magentocommerce.com for more information. * * @category Mage * @package Mage_Adminhtml * @copyright Copyright (c) 2012 Magento Inc. (http://www.magentocommerce.com) * @license http://opensource.org/licenses/afl-3.0.php Academic Free License (AFL 3.0) */ /** * Gift Options Tooltip Model * * @category Mage * @package Mage_Adminhtml * @author Magento Core Team */ GiftOptionsTooltip = Class.create(); GiftOptionsTooltip.prototype = { _tooltipLines: [], _tooltipWindow: null, _tooltipWindowContent: null, _targetLinks: [], _eventMouseOver: null, _eventMouseOut: null, _styleOptions: null, _tooltipContentLoaderFunction: null, /** * Initialize tooltip object */ initialize: function () { var options = Object.extend({ delta_x: 30, delta_y: 0, zindex: 1000 }); this._styleOptions = options; this._eventMouseOver = this.showTooltip.bindAsEventListener(this); this._eventMouseOut = this.hideTooltip.bindAsEventListener(this); }, /** * Set gift options tooltip window * * @param string windowId * @param string contentId * * @return boolean success */ setTooltipWindow: function (windowId, contentId) { if (!$(windowId) || !$(contentId)) { return false; } this._tooltipWindow = $(windowId); this._tooltipWindowContent = $(contentId); this.hideTooltip(); return true; }, /** * Add tooltip to specified link * * @param string linkId * @param string itemId identifier of the item related to link * * @return boolean success */ addTargetLink: function (linkId, itemId) { if ($(linkId)) { this._targetLinks[linkId] = []; this._targetLinks[linkId]['object'] = $(linkId); this._targetLinks[linkId]['itemId'] = itemId; this._registerEvents(this._targetLinks[linkId]['object']); return true; } return false; }, /** * Detach event listeners from target links when tooltip is destroyed */ destroy: function () { for (var linkId in this._targetLinks) { Event.stopObserving(this._targetLinks[linkId]['object'], 'mouseover', this._eventMouseOver); Event.stopObserving(this._targetLinks[linkId]['object'], 'mouseout', this._eventMouseOut); } }, /** * Register event listeners * * @param object element */ _registerEvents: function (element) { Event.observe(element, 'mouseover', this._eventMouseOver); Event.observe(element, 'mouseout', this._eventMouseOut); }, /** * Move tooltip to mouse position * * @patram object event */ _moveTooltip: function (event) { Event.stop(event); var mouseX = Event.pointerX(event); var mouseY = Event.pointerY(event); this.setStyles(mouseX, mouseY); }, /** * Show tooltip * * @param object event * * @return boolean success */ showTooltip: function (event) { Event.stop(event); if (this._tooltipWindow) { var link = Event.element(event); var itemId = this._targetLinks[link.id]['itemId']; var tooltipContent = ''; if (Object.isFunction(this._tooltipContentLoaderFunction)) { tooltipContent = this._tooltipContentLoaderFunction(itemId); } if (tooltipContent != '') { this._updateTooltipWindowContent(tooltipContent) this._moveTooltip(event); new Element.show(this._tooltipWindow); return true; } } return false; }, /** * Set tooltip window styles * * @param int x * @param int y */ setStyles: function (x, y) { Element.setStyle(this._tooltipWindow, { position:'absolute', top: y + this._styleOptions.delta_y + 'px', left: x + this._styleOptions.delta_x + 'px', zindex: this._styleOptions.zindex }); }, /** * Hide tooltip * * @param object event */ hideTooltip: function (event) { if (this._tooltipWindow) { new Element.hide(this._tooltipWindow); } }, /** * Set gift options tooltip content loader function * This function should accept at least one parameter that will serve as an item ID * * @param Function loaderFunction loader function */ setTooltipContentLoaderFunction: function (loaderFunction) { this._tooltipContentLoaderFunction = loaderFunction; }, /** * Update tooltip window content * * @param string content */ _updateTooltipWindowContent: function (content) { this._tooltipWindowContent.update(content); } } giftOptionsTooltip = new GiftOptionsTooltip();