![]() System : Linux absol.cf 5.4.0-198-generic #218-Ubuntu SMP Fri Sep 27 20:18:53 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.33 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, Directory : /var/www/html/libs/absol-full/dist/js/ |
Upload File : |
/*** module: node_modules/absol-acomp/js/EmojiPickerTooltip.js ***/ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; require("../css/emojipickertooltip.css"); var _Tooltip = require("./Tooltip"); var _ACore = _interopRequireDefault(require("../ACore")); var _EmojiPicker = _interopRequireDefault(require("./EmojiPicker")); var _EmojiAnims = _interopRequireDefault(require("./EmojiAnims")); var _PositionTracker = _interopRequireDefault(require("./PositionTracker")); var _ResizeSystem = _interopRequireDefault(require("absol/src/HTML5/ResizeSystem")); var _Dom = require("absol/src/HTML5/Dom"); var _Rectangle = _interopRequireDefault(require("absol/src/Math/Rectangle")); var _EventEmitter = require("absol/src/HTML5/EventEmitter"); var _BrowserDetector = _interopRequireDefault(require("absol/src/Detector/BrowserDetector")); var _PageIndicator = _interopRequireDefault(require("./PageIndicator")); var _Hanger = _interopRequireDefault(require("./Hanger")); var _ = _ACore.default._; var $ = _ACore.default.$; var isMobile = _BrowserDetector.default.isMobile; /*** * @augments Tooltip * @augments AElement * @augments Hanger * @constructor */ function EmojiPickerTooltip() { if (isMobile) { _({ tag: _Hanger.default.tag, elt: this, on: { predrag: this.eventHandler.preDragTT, dragstart: this.eventHandler.dragStartTT, drag: this.eventHandler.dragTT, dragend: this.eventHandler.dragEndTT } }); } this.$iconList = $('.as-emoji-picker-tooltip-icon-list', this); this.$leftBtn = $('.as-emoji-picker-tooltip-left-btn', this).on('click', this.eventHandler.clickLeft); this.$scroller = $('.as-emoji-picker-tooltip-scroller', this); this.$rightBtn = $('.as-emoji-picker-tooltip-right-btn', this).on('click', this.eventHandler.clickRight); this.$removeBtn = $('.as-emoji-picker-tooltip-remove-btn', this).on('click', this.eventHandler.clickRemove); this.$pageIndicatior = $('pageindicator', this); this._iconButtonCache = {}; this._icons = []; this.icons = EmojiPickerTooltip.defaultIcons; } EmojiPickerTooltip.tag = 'EmojiPickerTooltip'.toLowerCase(); EmojiPickerTooltip.defaultIcons = [';(', '(sarcastic)', ':O', '(cwl)', '(heart)', '(y)', '(n)', '(rock)', '(facepalm)', '(xd)', ':$', '(waiting)', '(headbang)', '(ghost)', '(clap)', '(punch)', '(ok)', '(angry)']; EmojiPickerTooltip.emojiDict = _EmojiAnims.default.reduce(function (ac, cr) { ac[cr[0]] = { imageFileName: cr[1], text: cr[0], desc: cr[2] }; return ac; }, {}); EmojiPickerTooltip.render = function () { return _({ tag: 'tooltip', extendEvent: ['pick'], class: ['as-emoji-picker-tooltip'].concat(isMobile ? ['as-mobile'] : []), child: [{ tag: 'button', class: 'as-emoji-picker-tooltip-left-btn', child: 'span.mdi.mdi-chevron-left' }, { class: 'as-emoji-picker-tooltip-scroller', child: { class: 'as-emoji-picker-tooltip-icon-list' } }, { tag: 'button', class: 'as-emoji-picker-tooltip-right-btn', child: 'span.mdi.mdi-chevron-right' }, { tag: 'button', attr: { title: 'Remove Emoji' }, class: 'as-emoji-picker-tooltip-remove-btn', child: 'span.mdi.mdi-close' }, { tag: 'pageindicator', class: 'as-emoji-picker-tooltip-page-indicator', props: { length: 3, idx: 0 } }] }, true); }; /*var */ EmojiPickerTooltip.prototype._makeIconBtn = function (iconText) { var icon = EmojiPickerTooltip.emojiDict[iconText]; var url = _EmojiPicker.default.assetRoot + '/anim/x40/' + icon.imageFileName; var spriteElt = _({ tag: 'sprite', class: 'as-emoji-picker-tooltip-icon', attr: { title: icon.desc }, props: { src: url, loop: true, fps: 30, debug: true }, on: { ready: function () { this.frames = { type: 'grid', col: 1, row: this.texture.naturalHeight / this.texture.naturalWidth }; this.frameIndex = 0; } } }); var buttonElt = _({ tag: 'button', class: 'as-emoji-picker-tooltip-icon-btn', child: spriteElt, on: { click: this.eventHandler.clickIconBtn.bind(null, icon) } }); buttonElt.on('mouseenter', function () { spriteElt.play(); }).on('mouseleave', function () { spriteElt.stop(); spriteElt.frameIndex = 0; }); return buttonElt; }; EmojiPickerTooltip.prototype._updateIconList = function () { this.$iconList.clearChild(); var iconText; for (var i = 0; i < this._icons.length; ++i) { iconText = this._icons[i]; this._iconButtonCache[iconText] = this._iconButtonCache[iconText] || this._makeIconBtn(iconText); this.$iconList.addChild(this._iconButtonCache[iconText]); } }; EmojiPickerTooltip.property = {}; EmojiPickerTooltip.property.icons = { set: function (icons) { this._icons = icons || []; this._updateIconList(); this.viewOffset = 0; this.$pageIndicatior.length = Math.ceil(this._icons.length / 6); }, get: function () { return this._icons; } }; EmojiPickerTooltip.property.viewOffset = { set: function (value) { this._viewOffset = Math.max(0, Math.min(value, this._icons.length - 6)); this.$iconList.addStyle('left', -(100 * this._viewOffset / 6) + '%'); this.$leftBtn.disabled = this._viewOffset === 0; this.$rightBtn.disabled = this._viewOffset === this._icons.length - 6; this.$pageIndicatior.idx = Math.floor(this._viewOffset / 6); }, get: function () { return this._viewOffset; } }; EmojiPickerTooltip.eventHandler = {}; EmojiPickerTooltip.eventHandler.clickLeft = function () { this.viewOffset -= 6; }; EmojiPickerTooltip.eventHandler.clickRight = function () { this.viewOffset += 6; }; EmojiPickerTooltip.eventHandler.clickIconBtn = function (icon) { if (this._preventClick) return; this.emit('pick', Object.assign({ type: 'pick', icon: icon, target: this }, icon), this); }; EmojiPickerTooltip.eventHandler.clickRemove = function () { this.emit('pick', Object.assign({ type: 'pressremove', icon: "REMOVE", target: this }), this); }; EmojiPickerTooltip.eventHandler.preDragTT = function (event) { var scrollerBound = this.$scroller.getBoundingClientRect(); var listBound = this.$iconList.getBoundingClientRect(); this._scrollData = { left: listBound.left - scrollerBound.left, scrollerWidth: scrollerBound.width, newLeft: listBound.left - scrollerBound.left }; }; EmojiPickerTooltip.eventHandler.dragStartTT = function () { this.addClass('as-scrolling'); this._preventClick = true; }; EmojiPickerTooltip.eventHandler.dragTT = function (event) { event.preventDefault(); var dx = event.currentPoint.sub(event.startingPoint).x; var newLeft = Math.min(0, Math.max(-this._scrollData.scrollerWidth * 2, this._scrollData.left + dx)); this._scrollData.newLeft = newLeft; this.$iconList.addStyle('left', newLeft + 'px'); }; EmojiPickerTooltip.eventHandler.dragEndTT = function (event) { event.preventDefault(); this.removeClass('as-scrolling'); var dOffset = (this._scrollData.left - this._scrollData.newLeft) / this._scrollData.scrollerWidth; if (dOffset > 0.25) { dOffset = 1; } else if (dOffset < -0.25) { dOffset = -1; } else { dOffset = 0; } this.viewOffset += dOffset * 6; setTimeout(function () { this._preventClick = false; }.bind(this), 5); }; _ACore.default.install(EmojiPickerTooltip); EmojiPickerTooltip._session = Math.random() * 10000000000 >> 0; function prepare() { if (EmojiPickerTooltip.$holder) return; EmojiPickerTooltip.$holder = _('.absol-tooltip-root-holder'); EmojiPickerTooltip.$tooltip = _('emojipickertooltip.top').addTo(EmojiPickerTooltip.$holder).on('pick', function (event) { EmojiPickerTooltip._listener && EmojiPickerTooltip._listener(event.icon); }); /*** * * @type {PositionTracker|undefined} */ EmojiPickerTooltip.$element = undefined; EmojiPickerTooltip.$content = undefined; EmojiPickerTooltip._orientation = 'auto'; EmojiPickerTooltip._session = Math.random() * 10000000000 >> 0; EmojiPickerTooltip._listener = undefined; EmojiPickerTooltip._scrollOutListener = undefined; EmojiPickerTooltip.$tooltip.$arrow.updateSize = EmojiPickerTooltip.updatePosition; } EmojiPickerTooltip.updatePosition = function () { if (!EmojiPickerTooltip.$element) return; var outBound = _Rectangle.default.fromClientRect((0, _Dom.traceOutBoundingClientRect)(EmojiPickerTooltip.$element)); var eBound = _Rectangle.default.fromClientRect(EmojiPickerTooltip.$element.getBoundingClientRect()); if (!outBound.isCollapse(eBound, 0)) { EmojiPickerTooltip._scrollOutListener && EmojiPickerTooltip._scrollOutListener(); } (0, _Tooltip.updateTooltipPosition)(EmojiPickerTooltip); }; EmojiPickerTooltip.updatePosition = EmojiPickerTooltip.updatePosition.bind(EmojiPickerTooltip); EmojiPickerTooltip.show = function (element, menuListener, orientation) { prepare(); if (EmojiPickerTooltip.$element) { EmojiPickerTooltip.$element.stopTrackPosition(); EmojiPickerTooltip.$element.off('positionchange', EmojiPickerTooltip.updatePosition); } if (!element.startTrackPosition) { _({ tag: _PositionTracker.default.tag, elt: element }); } element.startTrackPosition(); EmojiPickerTooltip.$element = element; EmojiPickerTooltip.$element.on('positionchange', EmojiPickerTooltip.updatePosition); EmojiPickerTooltip._listener = menuListener; EmojiPickerTooltip._session = Math.random() * 10000000000 >> 0; EmojiPickerTooltip._orientation = orientation || 'auto'; EmojiPickerTooltip.$holder.addTo(document.body); _ResizeSystem.default.add(EmojiPickerTooltip.$tooltip.$arrow); EmojiPickerTooltip.$tooltip.viewOffset = 0; EmojiPickerTooltip.$tooltip.addClass('top').removeClass('left').removeClass('right').removeClass('bottom').removeClass('ne').removeClass('nw').removeClass('auto'); EmojiPickerTooltip.updatePosition(); return EmojiPickerTooltip._session; }; EmojiPickerTooltip.close = function (token) { if (EmojiPickerTooltip._session !== token) return; if (EmojiPickerTooltip.$element) { EmojiPickerTooltip.$element.stopTrackPosition(); EmojiPickerTooltip.$element.off('positionchange', EmojiPickerTooltip.updatePosition); } EmojiPickerTooltip.$element = undefined; EmojiPickerTooltip._listener = undefined; EmojiPickerTooltip._session = Math.random() * 10000000000 >> 0; EmojiPickerTooltip.$holder.remove(); }; EmojiPickerTooltip.toggleWhenClick = function (trigger, adaptor) { var res = { trigger: trigger, adaptor: adaptor, currentSession: undefined }; function clickHandler(event) { if (res.currentSession === EmojiPickerTooltip._session) return; res.currentSession = EmojiPickerTooltip.show(res.adaptor.getFlowedElement ? res.adaptor.getFlowedElement() : trigger, res.adaptor.onSelect, res.adaptor.orientation || 'auto'); if (res.adaptor.onOpen) res.adaptor.onOpen(); var finish = function (event) { if (event && ((0, _EventEmitter.hitElement)(EmojiPickerTooltip.$tooltip.$leftBtn, event) || (0, _EventEmitter.hitElement)(EmojiPickerTooltip.$tooltip.$rightBtn, event)) || event && event.target && event.target.classList.contains('absol-tooltip-content')) return; document.body.removeEventListener('click', finish, false); EmojiPickerTooltip.close(res.currentSession); if (adaptor.onClose) adaptor.onClose(); res.currentSession = undefined; if (EmojiPickerTooltip._scrollOutListener === EmojiPickerTooltip) EmojiPickerTooltip._scrollOutListener = undefined; }; EmojiPickerTooltip._scrollOutListener = finish; setTimeout(function () { document.body.addEventListener('click', finish, false); }, 10); } res.remove = function () { trigger.removeEventListener('click', clickHandler, false); trigger.classList.remove('as-emoji-picker-tooltip-trigger'); }; trigger.addEventListener('click', clickHandler, false); trigger.classList.add('as-emoji-picker-tooltip-trigger'); return res; }; var _default = EmojiPickerTooltip; exports.default = _default;