123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274 |
- if(typeof jQuery !== 'undefined'){
- (function ($, win) {
- 'use strict';
- var emoji = lsxEmojiData;
- var settings = {};
- $.fn.lsxEmojiPicker = function(options) {
- if(options == "destroy") {
- $(this).off("click");
- $(this).children(".lsx-emojipicker-appender").remove();
- }
- else {
- settings = $.extend({
- width: 280,
- height: 200,
- twemoji: false,
- closeOnSelect: true,
- customEmojis: true,
- onSelect: function(em){},
- onClose: function(){}
- }, options);
- var appender = $('<div></div>')
- .addClass('lsx-emojipicker-appender');
- var container = $('<div></div>')
- .addClass('lsx-emojipicker-container')
- var wrapper = $('<div></div>')
- .addClass('lsx-emojipicker-wrapper');
- var spinnerContainer = $('<div></div>')
- .addClass('spinner-container');
- var spinner = $('<div></div>')
- .addClass('loader');
- spinnerContainer.append(spinner);
- var customemojis = JSON.parse(localStorage.current_custom_emojis);
- var addhide = "";
- if(customemojis.length > 0 && settings.customEmojis) {
- addhide = " hidden";
- var emojiCustomContainer = $('<div></div>')
- .addClass('lsx-emojipicker-emoji lsx-emoji-tab lsx-emoji-custom')
- .css({'width': settings.width, 'height': settings.height});
- }
- var emojiPeopleContainer = $('<div></div>')
- .addClass('lsx-emojipicker-emoji lsx-emoji-tab lsx-emoji-people'+addhide)
- .css({'width': settings.width, 'height': settings.height});
- var emojiNatureContainer = $('<div></div>')
- .addClass('lsx-emojipicker-emoji lsx-emoji-tab lsx-emoji-nature hidden')
- .css({'width': settings.width, 'height': settings.height});
- var emojiFoodsContainer = $('<div></div>')
- .addClass('lsx-emojipicker-emoji lsx-emoji-tab lsx-emoji-foods hidden')
- .css({'width': settings.width, 'height': settings.height});
- var emojiActivityContainer = $('<div></div>')
- .addClass('lsx-emojipicker-emoji lsx-emoji-tab lsx-emoji-activity hidden')
- .css({'width': settings.width, 'height': settings.height});
- var emojiPlacesContainer = $('<div></div>')
- .addClass('lsx-emojipicker-emoji lsx-emoji-tab lsx-emoji-places hidden')
- .css({'width': settings.width, 'height': settings.height});
- var emojiObjectsContainer = $('<div></div>')
- .addClass('lsx-emojipicker-emoji lsx-emoji-tab lsx-emoji-objects hidden')
- .css({'width': settings.width, 'height': settings.height});
- var emojiSymbolsContainer = $('<div></div>')
- .addClass('lsx-emojipicker-emoji lsx-emoji-tab lsx-emoji-symbols hidden')
- .css({'width': settings.width, 'height': settings.height});
- var emojiFlagsContainer = $('<div></div>')
- .addClass('lsx-emojipicker-emoji lsx-emoji-tab lsx-emoji-flags hidden')
- .css({'width': settings.width, 'height': settings.height});
- var tabs = $('<ul></ul>')
- .addClass('lsx-emojipicker-tabs');
- if(customemojis.length > 0 && settings.customEmojis) {
- var customEmoji = $('<li></li>')
- .addClass('selected')
- .html("*⃣")
- .click(function(e){
- e.preventDefault();
- $('ul.lsx-emojipicker-tabs li').removeClass('selected');
- $(this).addClass('selected');
- $('.lsx-emoji-tab').addClass('hidden');
- emojiCustomContainer.removeClass('hidden');
- });
- }
- var peopleEmoji = $('<li></li>')
- .html("😀")
- .click(function(e){
- e.preventDefault();
- $('ul.lsx-emojipicker-tabs li').removeClass('selected');
- $(this).addClass('selected');
- $('.lsx-emoji-tab').addClass('hidden');
- emojiPeopleContainer.removeClass('hidden');
- });
- if(customemojis.length == 0 || !settings.customEmojis) {
- peopleEmoji.addClass("selected");
- }
- var natureEmoji = $('<li></li>')
- .html("🐶")
- .click(function(e){
- e.preventDefault();
- $('ul.lsx-emojipicker-tabs li').removeClass('selected');
- $(this).addClass('selected');
- $('.lsx-emoji-tab').addClass('hidden');
- emojiNatureContainer.removeClass('hidden');
- });
- var foodsEmoji = $('<li></li>')
- .html("🍏")
- .click(function(e){
- e.preventDefault();
- $('ul.lsx-emojipicker-tabs li').removeClass('selected');
- $(this).addClass('selected');
- $('.lsx-emoji-tab').addClass('hidden');
- emojiFoodsContainer.removeClass('hidden');
- });
- var activityEmoji = $('<li></li>')
- .html("⚽")
- .click(function(e){
- e.preventDefault();
- $('ul.lsx-emojipicker-tabs li').removeClass('selected');
- $(this).addClass('selected');
- $('.lsx-emoji-tab').addClass('hidden');
- emojiActivityContainer.removeClass('hidden');
- });
- var placesEmoji = $('<li></li>')
- .html("🚗")
- .click(function(e){
- e.preventDefault();
- $('ul.lsx-emojipicker-tabs li').removeClass('selected');
- $(this).addClass('selected');
- $('.lsx-emoji-tab').addClass('hidden');
- emojiPlacesContainer.removeClass('hidden');
- });
- var objectsEmoji = $('<li></li>')
- .html("⌚")
- .click(function(e){
- e.preventDefault();
- $('ul.lsx-emojipicker-tabs li').removeClass('selected');
- $(this).addClass('selected');
- $('.lsx-emoji-tab').addClass('hidden');
- emojiObjectsContainer.removeClass('hidden');
- });
- var symbolsEmoji = $('<li></li>')
- .html("💯")
- .click(function(e){
- e.preventDefault();
- $('ul.lsx-emojipicker-tabs li').removeClass('selected');
- $(this).addClass('selected');
- $('.lsx-emoji-tab').addClass('hidden');
- emojiSymbolsContainer.removeClass('hidden');
- });
- var flagsEmoji = $('<li></li>')
- .html("🇦🇫")
- .click(function(e){
- e.preventDefault();
- $('ul.lsx-emojipicker-tabs li').removeClass('selected');
- $(this).addClass('selected');
- $('.lsx-emoji-tab').addClass('hidden');
- emojiFlagsContainer.removeClass('hidden');
- });
- if(customemojis.length > 0 && settings.customEmojis) {
- tabs.append(customEmoji);
- }
- tabs.append(peopleEmoji)
- .append(natureEmoji)
- .append(placesEmoji)
- .append(foodsEmoji)
- .append(activityEmoji)
- .append(objectsEmoji)
- .append(symbolsEmoji)
- .append(flagsEmoji);
- if(customemojis.length > 0 && settings.customEmojis) {
- createCustomEmojiTab(emojiCustomContainer,container);
- }
- createEmojiTab('people',emojiPeopleContainer,container);
- createEmojiTab('nature',emojiNatureContainer,container);
- createEmojiTab('foods',emojiFoodsContainer,container);
- createEmojiTab('activity',emojiActivityContainer,container);
- createEmojiTab('places',emojiPlacesContainer,container);
- createEmojiTab('objects',emojiObjectsContainer,container);
- createEmojiTab('symbols',emojiSymbolsContainer,container);
- createEmojiTab('flags',emojiFlagsContainer,container);
- //wrapper.append(spinnerContainer);
- wrapper.append(tabs);
- if(customemojis.length > 0 && settings.customEmojis) {
- wrapper.append(emojiCustomContainer);
- }
- wrapper.append(emojiPeopleContainer)
- .append(emojiNatureContainer)
- .append(emojiFoodsContainer)
- .append(emojiActivityContainer)
- .append(emojiPlacesContainer)
- .append(emojiObjectsContainer)
- .append(emojiSymbolsContainer)
- .append(emojiFlagsContainer);
- container.append(wrapper);
- appender.append(container);
- this.append(appender);
- if(settings.twemoji){
- twemoji.parse(emojiPeopleContainer[0],{base:"https://"+current_instance,ext:".svg",folder:"/emoji"});
- twemoji.parse(emojiNatureContainer[0],{base:"https://"+current_instance,ext:".svg",folder:"/emoji"});
- twemoji.parse(emojiFoodsContainer[0],{base:"https://"+current_instance,ext:".svg",folder:"/emoji"});
- twemoji.parse(emojiActivityContainer[0],{base:"https://"+current_instance,ext:".svg",folder:"/emoji"});
- twemoji.parse(emojiPlacesContainer[0],{base:"https://"+current_instance,ext:".svg",folder:"/emoji"});
- twemoji.parse(emojiObjectsContainer[0],{base:"https://"+current_instance,ext:".svg",folder:"/emoji"});
- twemoji.parse(emojiSymbolsContainer[0],{base:"https://"+current_instance,ext:".svg",folder:"/emoji"});
- twemoji.parse(emojiFlagsContainer[0],{base:"https://"+current_instance,ext:".svg",folder:"/emoji"});
- twemoji.parse(tabs[0],{base:"https://"+current_instance,ext:".svg",folder:"/emoji"});
- }
- this.click(function(e){
- e.preventDefault();
- if(!$(e.target).parent().hasClass('lsx-emojipicker-tabs')
- && !$(e.target).parent().parent().hasClass('lsx-emojipicker-tabs')
- && !$(e.target).parent().hasClass('lsx-emoji-tab')
- && !$(e.target).parent().parent().hasClass('lsx-emoji-tab')){
- if(container.is(':visible')){
- container.hide();
- settings.onClose();
- } else {
- container.show();
- }
- }
- });
- return this;
- }
- }
- function createEmojiTab(type,container,wrapper) {
- for(var i = 0;i < emoji[type].length;i++){
- var selectedEmoji = emoji[type][i];
- var emoticon = $('<span></span>')
- .data('value',selectedEmoji.value)
- .attr('title',selectedEmoji.name)
- .html(selectedEmoji.value);
- emoticon.click(function(e){
- e.preventDefault();
- settings.onSelect({
- 'name':$(this).attr('title'),
- 'value':$(this).data('value')
- });
- if(settings.closeOnSelect){
- wrapper.hide();
- settings.onClose();
- }
- });
- container.append(emoticon);
- }
- }
- function createCustomEmojiTab(container,wrapper) {
- var customemojis = JSON.parse(localStorage.current_custom_emojis);
- var sortedemojis = new Object();
- for(var i = 0;i < customemojis.length;i++) {
- if(!customemojis[i].category) customemojis[i].category = __("General");
- if(!sortedemojis[customemojis[i].category]) sortedemojis[customemojis[i].category] = new Array();
- sortedemojis[customemojis[i].category].push(customemojis[i]);
- }
- for(var category in sortedemojis) {
- if(sortedemojis.hasOwnProperty(category)) {
- if(Object.keys(sortedemojis).length != 1 || !sortedemojis.hasOwnProperty(__("General"))) container.append($("<p>").text(category));
- for(var i=0;i < sortedemojis[category].length;i++) {
- var selectedEmoji = sortedemojis[category][i];
- var emoticon = $('<span></span>')
- .attr('title',selectedEmoji.code)
- .html($("<img>").addClass("emoji").attr("src",selectedEmoji.url));
- emoticon.click(function(e){
- e.preventDefault();
- settings.onSelect({
- 'name':$(this).attr('title'),
- 'value':$(this).attr('title')
- });
- if(settings.closeOnSelect){
- wrapper.hide();
- settings.onClose();
- }
- });
- container.append(emoticon);
- }
- }
- }
- }
- }(jQuery, window));
- }
|