FANDOM


EmoticonsWindow adds a window with all emoticons listed. Users can select emoticons and they will be added to their text box.

This plugin is especially useful for wikis with lots of emoticons, so users don't need to remember all emoticons or use MediaWiki:Emoticons all the time.

Installation

Add this code to your wiki's MediaWiki:Chat.js or Special:Mypage/chat.js

importArticles({
    type: 'script',
    articles: [
        // ...
        'u:dev:MediaWiki:EmoticonsWindow/code.js',
        // ...
    ]
});
importArticles — Best Practices for installing JavaScript on FANDOM
The importArticles statement is designed to combine multiple HTTP requests into a single data transfer, allowing multiple scripts to load and execute faster. If you've been installing several different scripts, your JavaScript file has probably accumulated unnecessary import statements. Click "Expand" to learn how to efficiently batch import scripts to speed up performance and make your code look cleaner. One other approach is by using the MediaWiki:ImportJS.
If your JavaScript file has several lines of code that say importScript, importScriptPage, or importArticles, you may be able to combine them! By batch importing a collection of scripts with a single import, your JavaScript code will load faster and look cleaner. Consider the example below. On the left is an example of what your JavaScript file might currently look like. On the right is how you could improve that code.
Multiple imports — messy and slow One import — clean and efficient
importScriptPage('AjaxRC/code.js','dev');
 
importScript('MediaWiki:localScript.js');
 
importArticle({
  type: 'script',
  article: 'u:dev:FloatingToc/code.js'
});
 
importScriptPage('page1.js', 'wikiname');
 
importScriptPage('page2.js', 'wikiname');
importArticles({
    type: 'script',
    articles: [
        'u:dev:AjaxRC/code.js',
        'MediaWiki:localScript.js',
        'u:dev:FloatingToc/code.js',
        'u:wikiname:page1.js',
        'u:wikiname:page2.js'
    ]
});
Note: In this example, pay close attention to the placement of commas and other punctuation. For people who aren't familiar with programming (and even those who are!), a common mistake when writing code is to accidentally delete, forget, or misplace critical symbols like commas or quotation marks. This can cause a syntax error that breaks the code. Carefully follow the convention shown here when using importArticles.
But there's much more to importArticles than just this! For more examples and advanced usage, see the help page at Help:Including additional JavaScript and CSS.


Translation

This script can be translated through the translations editor.

Changelog

v1.0 (2016-03-08)
Initial revision
v1.1 (2016-04-10 • diff)
Credits for suggesting fixes below to Dorumin
When hovering over an emoticon, it displays its name
When inserting an emoticon, a space is inserted in front of it
Help text is now fixed to the top
Added an exception for Steven Universe wiki
v1.2 (2016-05-19 • diff)
Cached the modal content
Changed "kockaEmoticons" to "EmoticonsWindow" in CSS elements
v1.3 (2016-07-09 • diff)
Updated the general layout of the script
Updated the internationalization system
The script now uses the same method as FANDOM does for parsing emoticons
Added full support for ChatOptions integration
v1.4 (2016-07-29 • diff)
Updated the internationalization system again
v1.5 (2016-10-20 • diff)
Reformatted the code again
Removed kockaEmoticons completely
Changed the button from an actual button element into a link with wikia-button class
v1.6 (2017-12-10)
Reformatted the code yet again
Removed ChatOptions integration
Background of emoticon icons respects local wiki colors
Script is translatable through the translations editor
Moved from personal test wiki
Prevented double-loading
Fixed issue with emoticons button interfering with ChatHacks ping phrases