D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
home3
/
encodto1
/
tapaslight.encodersunlimited.com
/
tadminl
/
assets
/
js
/
select2
/
Filename :
select3-custom.js
back
Copy
// Tagify JS (function () { ("use strict"); // 1. Basic Select // The DOM element you wish to replace with Tagify var input = document.querySelector("input[name=basic]"); // initialize Tagify on the above input node reference new Tagify(input); // 2. Random suggestions var input = document.querySelector('input[name="input-custom-dropdown"]'), // init Tagify script on the above inputs tagify = new Tagify(input, { whitelist: [ "A# .NET", "A# (Axiom)", "A-0 System", "A+", "A++", "ABAP", "ABC", "ABC ALGOL", "ABSET", "ABSYS", "ACC", "Accent", "Ace DASL", "ACL2", "Avicsoft", "ACT-III", "Action!", "ActionScript", "Ada", "Adenine", "Agda", "Agilent VEE", "Agora", "AIMMS", "Alef", "ALF", "ALGOL 58", "ALGOL 60", "ALGOL 68", "ALGOL W", "Alice", "Alma-0", "AmbientTalk", "Amiga E", "AMOS", "AMPL", "Apex (Salesforce.com)", "APL", "AppleScript", "Arc", "ARexx", "Argus", "AspectJ", "Assembly language", "ATS", "Ateji PX", "AutoHotkey", "Autocoder", "AutoIt", "AutoLISP / Visual LISP", "Averest", "AWK", "Axum", "Active Server Pages", "ASP.NET", "B", "Babbage", "Bash", "BASIC", "bc", "BCPL", "BeanShell", "Batch (Windows/Dos)", "Bertrand", "BETA", "Bigwig", "Bistro", "BitC", "BLISS", "Blockly", "BlooP", "Blue", "Boo", "Boomerang", "Bourne shell (including bash and ksh)", "BREW", "BPEL", "B", "C--", "C++ – ISO/IEC 14882", "C# – ISO/IEC 23270", "C/AL", "Caché ObjectScript", "C Shell", "Caml", "Cayenne", "CDuce", "Cecil", "Cesil", "Céu", "Ceylon", "CFEngine", "CFML", "Cg", "Ch", "Chapel", "Charity", "Charm", "Chef", "CHILL", "CHIP-8", "chomski", "ChucK", "CICS", "Cilk", "Citrine (programming language)", "CL (IBM)", "Claire", "Clarion", "Clean", "Clipper", "CLIPS", "CLIST", "Clojure", "CLU", "CMS-2", "COBOL – ISO/IEC 1989", "CobolScript – COBOL Scripting language", "Cobra", "CODE", "CoffeeScript", "ColdFusion", "COMAL", "Combined Programming Language (CPL)", "COMIT", "Common Intermediate Language (CIL)", "Common Lisp (also known as CL)", "COMPASS", "Component Pascal", "Constraint Handling Rules (CHR)", "COMTRAN", "Converge", "Cool", "Coq", "Coral 66", "Corn", "CorVision", "COWSEL", "CPL", "CPL", "Cryptol", "csh", "Csound", "CSP", "CUDA", "Curl", "Curry", "Cybil", "Cyclone", "Cython", "Java", "Javascript", "M2001", "M4", "M#", "Machine code", "MAD (Michigan Algorithm Decoder)", "MAD/I", "Magik", "Magma", "make", "Maple", "MAPPER now part of BIS", "MARK-IV now VISION:BUILDER", "Mary", "MASM Microsoft Assembly x86", "MATH-MATIC", "Mathematica", "MATLAB", "Maxima (see also Macsyma)", "Max (Max Msp – Graphical Programming Environment)", "Maya (MEL)", "MDL", "Mercury", "Mesa", "Metafont", "Microcode", "MicroScript", "MIIS", "Milk (programming language)", "MIMIC", "Mirah", "Miranda", "MIVA Script", "ML", "Model 204", "Modelica", "Modula", "Modula-2", "Modula-3", "Mohol", "MOO", "Mortran", "Mouse", "MPD", "Mathcad", "MSIL – deprecated name for CIL", "MSL", "MUMPS", "Mystic Programming L", ], maxTags: 10, dropdown: { maxItems: 20, // <- mixumum allowed rendered suggestions classname: "tags-look", // <- custom classname for this dropdown, so it could be targeted enabled: 0, // <- show suggestions on focus closeOnSelect: false, // <- do not hide the suggestions dropdown once an item has been selected }, }); // 3. Movie suggestions var input = document.querySelector("textarea[name=tags2]"), tagify = new Tagify(input, { enforceWhitelist: true, delimiters: null, whitelist: [ "The Shawshank Redemption", "The Godfather", "The Dark Knight", "12 Angry Men", "Hot Sit", "Avangers End Game", "Thor", "Schindler's List", "Pulp Fiction", "Fight Club", "Forrest Gump", "Inception", "Goodfellas", "The Matrix", "Seven Samurai", "City of God", "Se7en", "The Silence of the Lambs", "It's a Wonderful Life", "The Usual Suspects", "Life Is Beautiful", "Léon: The Professional", "Spirited Away", "Saving Private Ryan", "La La Land", "American History X", "Interstellar", "Casablanca", "Psycho", "City Lights", "The Green Mile", "Raiders of the Lost Ark", "The Intouchables", "Modern Times", "Rear Window", "The Pianist", "The Departed", "Terminator 2", "Back to the Future", "Whiplash", "Gladiator", "Memento", "Apocalypse Now", "The Prestige", "The Lion King", "Alien", "Sunset Boulevard", "The Great Dictator", "Cinema Paradiso", "The Lives of Others", "Paths of Glory", "Grave of the Fireflies", "Django Unchained", "The Shining", "WALL·E", "American Beauty", "The Dark Knight Rises", "Princess Mononoke", "Aliens", "Oldboy", "Once Upon a Time in America", "Citizen Kane", "Das Boot", "Witness for the Prosecution", "North by Northwest", "Vertigo", "Reservoir Dogs", "M", "Braveheart", "Amélie", "Requiem for a Dream", "A Clockwork Orange", "Taxi Driver", "Lawrence of Arabia", "Like Stars on Earth", "Double Indemnity", "To Kill a Mockingbird", "Toy Story 3", "Amadeus", "My Father and My Son", "Full Metal Jacket", "The Sting", "2001: A Space Odyssey", "Singin' in the Rain", "Bicycle Thieves", "Toy Story", "Dangal", "The Kid", "Inglourious Basterds", "Snatch", "Hacksaw Ridge", "Harry Potter", "3 Idiots", "L.A. Confidential", "For a Few Dollars More", "Scarface", "Rashomon", "The Apartment", "The Hunt", "Good Will Hunting", "A Separation", "Metropolis", "Yojimbo", "All About Eve", "Batman Begins", "Up", "Some Like It Hot", "Unforgiven", "Downfall", "Raging Bull", "The Third Man", "Die Hard", "Children of Heaven", "The Great Escape", "Heat", "Chinatown", "Inside Out", "Pan's Labyrinth", "Ikiru", "My Neighbor Totoro", "On the Waterfront", "Room", "Ran", "The Gold Rush", "Blade Runner", "Mr. Smith Goes to Washington", "The Seventh Seal", "Judgment at Nuremberg", "Casino", "The Bandit", "Incendies", "A Beautiful Mind", "A Wednesday", "The General", "The Elephant Man", "Wild Strawberries", "Arrival", "V for Vendetta", "Warrior", "Sunrise", "The Passion of Joan of Arc", "Gran Torino", "Rang De Basanti", "Trainspotting", "Dial M for Murder", "The Big Lebowski", "The Deer Hunter", "Tokyo Story", "Gone with the Wind", "Fargo", "Finding Nemo", "The Sixth Sense", "The Thing", "Hera Pheri", "Cool Hand Luke", "Andaz Apna Apna", "Rebecca", "No Country for Old Men", "How to Train Your Dragon", "Munna Bhai M.B.B.S.", "Sholay", "Kill Bill: Vol. 1", "Into the Wild", "Mary and Max", "Gone Girl", "There Will Be Blood", "Come and See", "It Happened One Night", "Life of Brian", "Rush", "Hotel Rwanda", "Platoon", "Shutter Island", "Network", "The Wages of Fear", "Stand by Me", "Wild Tales", "Spotlight", "The Nights of Cabiria", "The 400 Blows", "Mad Max: Fury Road", "The Maltese Falcon", "12 Years a Slave", "Ben-Hur", "The Grand Budapest Hotel", "Persona", "Million Dollar Baby", "Amores Perros", "Jurassic Park", "The Princess Bride", "Hachi: A Dog's Tale", "Memories of Murder", "Stalker", "Drishyam", "The Truman Show", "The Grapes of Wrath", "Before Sunrise", "Touch of Evil", "Annie Hall", "The Message", "Rocky", "Gandhi", "The Bourne Ultimatum", "Diabolique", "Donnie Darko", "Monsters, Inc.", "Prisoners", "8½", "The Terminator", "The Wizard of Oz", "Catch Me If You Can", "Groundhog Day", "Twelve Monkeys", "Zootopia", "La Haine", "Barry Lyndon", "Jaws", "The Best Years of Our Lives", "Infernal Affairs", "Udaan", "The Battle of Algiers", "Strangers on a Train", "Dog Day Afternoon", "Sin City", "Kind Hearts and Coronets", "Gangs of Wasseypur", "The Help", ], callbacks: { add: console.log, // callback when adding a tag remove: console.log, // callback when removing a tag }, }); // 4.Render Suggestions List Manually var input = document.querySelector("input[name=tags-manual-suggestions]"), // init Tagify script on the above inputs tagify = new Tagify(input, { whitelist: [ ".NET", "Software Enginner", " UI/UX Designer", "A+", "A++", "Electric Enginner", "Chemical Enginner", "Civil Engineer", "IT Field", "C#", "C++", "Crypography", "DBMS", "JS", "Painter", "CTC", "Typescript", "Vuejs", "React", "Government Exams", "Agda", "Agilent VEE", "Agora", "AIMMS", "Alef", "ALF", "ALGOL 58", "ALGOL 60", "ALGOL 68", "ALGOL W", "Alice", "Alma-0", "AmbientTalk", "Amiga E", "AMOS", "AMPL", "Apex (Salesforce.com)", "APL", "AppleScript", "Arc", "ARexx", "Argus", "AspectJ", "Assembly language", "ATS", "Ateji PX", "AutoHotkey", "Autocoder", "AutoIt", "AutoLISP / Visual LISP", "Averest", "AWK", "Axum", "Active Server Pages", "ASP.NET", "B", "BIOS", "Bash", "BASIC", "Boolean", "Buffer", "Bugs", "Batch (Windows/Dos)", "Debug", "BETA", "Disk Storage", "Bistro", "BitC", "BLISS", "Blockly", "BlooP", "Blue", "Boo", "Boomerang", "Bourne shell (including bash and ksh)", "BREW", "BPEL", "B", "C--", "C++ – ISO/IEC 14882", "C# – ISO/IEC 23270", "C/AL", "Caché ObjectScript", "C Shell", "Caml", "Cayenne", "CDuce", "Cecil", "Cesil", "Céu", "Ceylon", "CFEngine", "CFML", "Cg", "Ch", "Chapel", "Charity", "Charm", "Chef", "CHILL", "CHIP-8", "chomski", "ChucK", "CICS", "Cilk", "Citrine (programming language)", "CL (IBM)", "Claire", "Clarion", "Clean", "Clipper", "CLIPS", "CLIST", "Clojure", "CLU", "CMS-2", "COBOL – ISO/IEC 1989", "CobolScript – COBOL Scripting language", "Cobra", "CODE", "CoffeeScript", "ColdFusion", "COMAL", "Combined Programming Language (CPL)", "COMIT", "Common Intermediate Language (CIL)", "Common Lisp (also known as CL)", "COMPASS", "Component Pascal", "Constraint Handling Rules (CHR)", "COMTRAN", "Converge", "Cool", "Coq", "Coral 66", "Corn", "CorVision", "COWSEL", "CPL", "CPL", "Cryptol", "csh", "Csound", "CSP", "CUDA", "Curl", "Curry", "Cybil", "Cyclone", "Cython", "Java", "Javascript", "M2001", "M4", "M#", "Machine code", "MAD (Michigan Algorithm Decoder)", "MAD/I", "Magik", "Magma", "make", "Maple", "MAPPER now part of BIS", "MARK-IV now VISION:BUILDER", "Mary", "MASM Microsoft Assembly x86", "MATH-MATIC", "Mathematica", "MATLAB", "Maxima (see also Macsyma)", "Max (Max Msp – Graphical Programming Environment)", "Maya (MEL)", "MDL", "Mercury", "Mesa", "Metafont", "Microcode", "MicroScript", "MIIS", "Milk (programming language)", "MIMIC", "Mirah", "Miranda", "MIVA Script", "ML", "Model 204", "Modelica", "Modula", "Modula-2", "Modula-3", "Mohol", "MOO", "Mortran", "Mouse", "MPD", "Mathcad", "MSIL – deprecated name for CIL", "MSL", "MUMPS", "Mystic Programming L", ], dropdown: { position: "manual", maxItems: Infinity, enabled: 0, classname: "customSuggestionsList", }, templates: { dropdownItemNoMatch() { return `<div class='empty'>Nothing Found</div>`; }, }, enforceWhitelist: true, }); tagify .on("dropdown:show", onSuggestionsListUpdate) .on("dropdown:hide", onSuggestionsListHide) .on("dropdown:scroll", onDropdownScroll); renderSuggestionsList(); // defined down below // ES2015 argument destructuring function onSuggestionsListUpdate({ detail: suggestionsElm }) { console.log(suggestionsElm); } function onSuggestionsListHide() { console.log("hide dropdown"); } function onDropdownScroll(e) { console.log(e.detail); } // https://developer.mozilla.org/en-US/docs/Web/API/Element/insertAdjacentElement function renderSuggestionsList() { tagify.dropdown.show(); // load the list tagify.DOM.scope.parentNode.appendChild(tagify.DOM.dropdown); } // 5. Colors select options var input = document.querySelector("input[name=tags3]"), tagify = new Tagify(input, { pattern: /^.{0,20}$/, // Validate typed tag(s) by Regex. Here maximum chars length is defined as "20" delimiters: ",| ", // add new tags when a comma or a space character is entered trim: false, // if "delimiters" setting is using space as a delimeter, then "trim" should be set to "false" keepInvalidTags: true, // do not remove invalid tags (but keep them marked as invalid) // createInvalidTags: false, editTags: { clicks: 2, // single click to edit a tag keepInvalid: false, // if after editing, tag is invalid, auto-revert }, maxTags: 6, blacklist: ["foo", "bar", "baz"], whitelist: [ "temple", "stun", "detective", "sign", "passion", "routine", "deck", "discriminate", "relaxation", "fraud", "attractive", "soft", "forecast", "point", "thank", "stage", "eliminate", "effective", "flood", "passive", "skilled", "separation", "contact", "compromise", "reality", "district", "nationalist", "leg", "porter", "conviction", "worker", "vegetable", "commerce", "conception", "particle", "honor", "stick", "tail", "pumpkin", "core", "mouse", "egg", "population", "unique", "behavior", "onion", "disaster", "cute", "pipe", "sock", "dialect", "horse", "swear", "owner", "cope", "global", "improvement", "artist", "shed", "constant", "bond", "brink", "shower", "spot", "inject", "bowel", "homosexual", "trust", "exclude", "tough", "sickness", "prevalence", "sister", "resolution", "cattle", "cultural", "innocent", "burial", "bundle", "thaw", "respectable", "thirsty", "exposure", "team", "creed", "facade", "calendar", "filter", "utter", "dominate", "predator", "discover", "theorist", "hospitality", "damage", "woman", "rub", "crop", "unpleasant", "halt", "inch", "birthday", "lack", "throne", "maximum", "pause", "digress", "fossil", "policy", "instrument", "trunk", "frame", "measure", "hall", "support", "convenience", "house", "partnership", "inspector", "looting", "ranch", "asset", "rally", "explicit", "leak", "monarch", "ethics", "applied", "aviation", "dentist", "great", "ethnic", "sodium", "truth", "constellation", "lease", "guide", "break", "conclusion", "button", "recording", "horizon", "council", "paradox", "bride", "weigh", "like", "noble", "transition", "accumulation", "arrow", "stitch", "academy", "glimpse", "case", "researcher", "constitutional", "notion", "bathroom", "revolutionary", "soldier", "vehicle", "betray", "gear", "pan", "quarter", "embarrassment", "golf", "shark", "constitution", "club", "college", "duty", "eaux", "know", "collection", "burst", "fun", "animal", "expectation", "persist", "insure", "tick", "account", "initiative", "tourist", "member", "example", "plant", "river", "ratio", "view", "coast", "latest", "invite", "help", "falsify", "allocation", "degree", "feel", "resort", "means", "excuse", "injury", "pupil", "shaft", "allow", "ton", "tube", "dress", "speaker", "double", "theater", "opposed", "holiday", "screw", "cutting", "picture", "laborer", "conservation", "kneel", "miracle", "brand", "nomination", "characteristic", "referral", "carbon", "valley", "hot", "climb", "wrestle", "motorist", "update", "loot", "mosquito", "delivery", "eagle", "guideline", "hurt", "feedback", "finish", "traffic", "competence", "serve", "archive", "feeling", "hope", "seal", "ear", "oven", "vote", "ballot", "study", "negative", "declaration", "particular", "pattern", "suburb", "intervention", "brake", "frequency", "drink", "affair", "contemporary", "prince", "dry", "mole", "lazy", "undermine", "radio", "legislation", "circumstance", "bear", "left", "pony", "industry", "mastermind", "criticism", "sheep", "failure", "chain", "depressed", "launch", "script", "green", "weave", "please", "surprise", "doctor", "revive", "banquet", "belong", "correction", "door", "image", "integrity", "intermediate", "sense", "formal", "cane", "gloom", "toast", "pension", "exception", "prey", "random", "nose", "predict", "needle", "satisfaction", "establish", "fit", "vigorous", "urgency", "X-ray", "equinox", "variety", "proclaim", "conceive", "bulb", "vegetarian", "available", "stake", "publicity", "strikebreaker", "portrait", "sink", "frog", "ruin", "studio", "match", "electron", "captain", "channel", "navy", "set", "recommend", "appoint", "liberal", "missile", "sample", "result", "poor", "efflux", "glance", "timetable", "advertise", "personality", "aunt", "dog", ], transformTag: transformTag, backspace: "edit", placeholder: "Type something", dropdown: { enabled: 1, // show suggestion after 1 typed character fuzzySearch: false, // match only suggestions that starts with the typed characters position: "text", // position suggestions list next to typed text caseSensitive: true, // allow adding duplicate items if their case is different }, templates: { dropdownItemNoMatch: function (data) { return `<div class='${this.settings.classNames.dropdownItem}' value="noMatch" tabindex="0" role="option"> No suggestion found for: <strong>${data.value}</strong> </div>`; }, }, }); // generate a random color (in HSL format, which I like to use) function getRandomColor() { function rand(min, max) { return min + Math.random() * (max - min); } var h = rand(1, 360) | 0, s = rand(40, 70) | 0, l = rand(65, 72) | 0; return "hsl(" + h + "," + s + "%," + l + "%)"; } function transformTag(tagData) { tagData.color = getRandomColor(); tagData.style = "--tag-bg:" + tagData.color; if (tagData.value.toLowerCase() == "shit") tagData.value = "s✲✲t"; } tagify.on("add", function (e) { console.log(e.detail); }); tagify.on("invalid", function (e) { console.log(e, e.detail); }); var clickDebounce; tagify.on("click", function (e) { const { tag: tagElm, data: tagData } = e.detail; // a delay is needed to distinguish between regular click and double-click. // this allows enough time for a possible double-click, and noly fires if such // did not occur. clearTimeout(clickDebounce); clickDebounce = setTimeout(() => { tagData.color = getRandomColor(); tagData.style = "--tag-bg:" + tagData.color; tagify.replaceTag(tagElm, tagData); }, 200); }); tagify.on("dblclick", function (e) { // when souble clicking, do not change the color of the tag clearTimeout(clickDebounce); }); CSS; // 6. Flag Selections var tagify = new Tagify(document.querySelector("input[name=tags3-1]"), { delimiters: null, templates: { tag: function (tagData) { try { return `<tag title='${ tagData.value }' contenteditable='false' spellcheck="false" class='tagify__tag ${ tagData.class ? tagData.class : "" }' ${this.getAttributes(tagData)}> <x title='remove tag' class='tagify__tag__removeBtn'></x> <div> ${ tagData.code ? `<img onerror="this.style.visibility='hidden'" src='https://flagicons.lipis.dev/flags/4x3/${tagData.code.toLowerCase()}.svg'>` : "" } <span class='tagify__tag-text'>${tagData.value}</span> </div> </tag>`; } catch (err) {} }, dropdownItem: function (tagData) { try { return `<div ${this.getAttributes( tagData )} class='tagify__dropdown__item ${ tagData.class ? tagData.class : "" }' > <img onerror="this.style.visibility = 'hidden'" src='https://flagicons.lipis.dev/flags/4x3/${tagData.code.toLowerCase()}.svg'> <span>${tagData.value}</span> </div>`; } catch (err) { console.error(err); } }, }, enforceWhitelist: true, whitelist: [ { value: "Afghanistan", code: "AF" }, { value: "Åland Islands", code: "AX" }, { value: "Albania", code: "AL" }, { value: "Algeria", code: "DZ" }, { value: "American Samoa", code: "AS" }, { value: "Andorra", code: "AD" }, { value: "Angola", code: "AO" }, { value: "Anguilla", code: "AI" }, { value: "Antarctica", code: "AQ" }, { value: "Antigua and Barbuda", code: "AG" }, { value: "Argentina", code: "AR" }, { value: "Armenia", code: "AM" }, { value: "Aruba", code: "AW" }, { value: "Australia", code: "AU", searchBy: "beach, sub-tropical" }, { value: "Austria", code: "AT" }, { value: "Azerbaijan", code: "AZ" }, { value: "Bahamas", code: "BS" }, { value: "Bahrain", code: "BH" }, { value: "Bangladesh", code: "BD" }, { value: "Barbados", code: "BB" }, { value: "Belarus", code: "BY" }, { value: "Belgium", code: "BE" }, { value: "Belize", code: "BZ" }, { value: "Benin", code: "BJ" }, { value: "Bermuda", code: "BM" }, { value: "Bhutan", code: "BT" }, { value: "Bolivia", code: "BO" }, { value: "Bosnia and Herzegovina", code: "BA" }, { value: "Botswana", code: "BW" }, { value: "Bouvet Island", code: "BV" }, { value: "Brazil", code: "BR" }, { value: "British Indian Ocean Territory", code: "IO" }, { value: "Brunei Darussalam", code: "BN" }, { value: "Bulgaria", code: "BG" }, { value: "Burkina Faso", code: "BF" }, { value: "Burundi", code: "BI" }, { value: "Cambodia", code: "KH" }, { value: "Cameroon", code: "CM" }, { value: "Canada", code: "CA" }, { value: "Cape Verde", code: "CV" }, { value: "Cayman Islands", code: "KY" }, { value: "Central African Republic", code: "CF" }, { value: "Chad", code: "TD" }, { value: "Chile", code: "CL" }, { value: "China", code: "CN" }, { value: "Christmas Island", code: "CX" }, { value: "Cocos (Keeling) Islands", code: "CC" }, { value: "Colombia", code: "CO" }, { value: "Comoros", code: "KM" }, { value: "Congo", code: "CG" }, { value: "Congo, The Democratic Republic of the", code: "CD" }, { value: "Cook Islands", code: "CK" }, { value: "Costa Rica", code: "CR" }, { value: "Cote D'Ivoire", code: "CI" }, { value: "Croatia", code: "HR" }, { value: "Crocs", code: "CU" }, { value: "Cyprus", code: "CY" }, { value: "Czech Republic", code: "CZ" }, { value: "Denmark", code: "DK" }, { value: "Djibouti", code: "DJ" }, { value: "Dominica", code: "DM" }, { value: "Dominican Republic", code: "DO" }, { value: "Ecuador", code: "EC" }, { value: "Egypt", code: "EG" }, { value: "El Salvador", code: "SV" }, { value: "Equatorial Guinea", code: "GQ" }, { value: "Eritrea", code: "ER" }, { value: "Estonia", code: "EE" }, { value: "Ethiopia", code: "ET" }, { value: "Falkland Islands (Malvinas)", code: "FK" }, { value: "Faroe Islands", code: "FO" }, { value: "Fiji", code: "FJ" }, { value: "Finland", code: "FI" }, { value: "France", code: "FR" }, { value: "French Guiana", code: "GF" }, { value: "French Polynesia", code: "PF" }, { value: "French Southern Territories", code: "TF" }, { value: "Gabon", code: "GA" }, { value: "Gambia", code: "GM" }, { value: "Georgia", code: "GE" }, { value: "Germany", code: "DE" }, { value: "Ghana", code: "GH" }, { value: "Gibraltar", code: "GI" }, { value: "Greece", code: "GR" }, { value: "Greenland", code: "GL" }, { value: "Grenada", code: "GD" }, { value: "Guadeloupe", code: "GP" }, { value: "Guam", code: "GU" }, { value: "Guatemala", code: "GT" }, { value: "Guernsey", code: "GG" }, { value: "Guinea", code: "GN" }, { value: "Guinea-Bissau", code: "GW" }, { value: "Guyana", code: "GY" }, { value: "Haiti", code: "HT" }, { value: "Heard Island and Mcdonald Islands", code: "HM" }, { value: "Holy See (Vatican City State)", code: "VA" }, { value: "Honduras", code: "HN" }, { value: "Hong Kong", code: "HK" }, { value: "Hungary", code: "HU" }, { value: "Iceland", code: "IS" }, { value: "India", code: "IN" }, { value: "Indonesia", code: "ID" }, { value: "Iran, Islamic Republic Of", code: "IR" }, { value: "Iraq", code: "IQ" }, { value: "Ireland", code: "IE" }, { value: "Isle of Man", code: "IM" }, { value: "Israel", code: "IL", searchBy: "holy land, desert" }, { value: "Italy", code: "IT" }, { value: "Jamaica", code: "JM" }, { value: "Japan", code: "JP" }, { value: "Jersey", code: "JE" }, { value: "Jordan", code: "JO" }, { value: "Kazakhstan", code: "KZ" }, { value: "Kenya", code: "KE" }, { value: "Kiribati", code: "KI" }, { value: "Korea, Democratic People'S Republic of", code: "KP" }, { value: "Korea, Republic of", code: "KR" }, { value: "Kuwait", code: "KW" }, { value: "Kyrgyzstan", code: "KG" }, { value: "Lao People'S Democratic Republic", code: "LA" }, { value: "Latvia", code: "LV" }, { value: "Lebanon", code: "LB" }, { value: "Lesotho", code: "LS" }, { value: "Liberia", code: "LR" }, { value: "Libyan Arab Jamahiriya", code: "LY" }, { value: "Liechtenstein", code: "LI" }, { value: "Lithuania", code: "LT" }, { value: "Luxembourg", code: "LU" }, { value: "Macao", code: "MO" }, { value: "Macedonia, The Former Yugoslav Republic of", code: "MK" }, { value: "Madagascar", code: "MG" }, { value: "Malawi", code: "MW" }, { value: "Malaysia", code: "MY" }, { value: "Maldives", code: "MV" }, { value: "Mali", code: "ML" }, { value: "Malta", code: "MT" }, { value: "Marshall Islands", code: "MH" }, { value: "Martinique", code: "MQ" }, { value: "Mauritania", code: "MR" }, { value: "Mauritius", code: "MU" }, { value: "Mayotte", code: "YT" }, { value: "Mexico", code: "MX" }, { value: "Micronesia, Federated States of", code: "FM" }, { value: "Moldova, Republic of", code: "MD" }, { value: "Monaco", code: "MC" }, { value: "Mongolia", code: "MN" }, { value: "Montserrat", code: "MS" }, { value: "Morocco", code: "MA" }, { value: "Mozambique", code: "MZ" }, { value: "Myanmar", code: "MM" }, { value: "Namibia", code: "NA" }, { value: "Nauru", code: "NR" }, { value: "Nepal", code: "NP" }, { value: "Netherlands", code: "NL" }, { value: "Netherlands Antilles", code: "AN" }, { value: "New Caledonia", code: "NC" }, { value: "New Zealand", code: "NZ" }, { value: "Nicaragua", code: "NI" }, { value: "Niger", code: "NE" }, { value: "Nigeria", code: "NG" }, { value: "Niue", code: "NU" }, { value: "Norfolk Island", code: "NF" }, { value: "Northern Mariana Islands", code: "MP" }, { value: "Norway", code: "NO" }, { value: "Oman", code: "OM" }, { value: "Pakistan", code: "PK" }, { value: "Palau", code: "PW" }, { value: "Palestinian Territory, Occupied", code: "PS" }, { value: "Panama", code: "PA" }, { value: "Papua New Guinea", code: "PG" }, { value: "Paraguay", code: "PY" }, { value: "Peru", code: "PE" }, { value: "Philippines", code: "PH" }, { value: "Pitcairn", code: "PN" }, { value: "Poland", code: "PL" }, { value: "Portugal", code: "PT" }, { value: "Puerto Rico", code: "PR" }, { value: "Qatar", code: "QA" }, { value: "Reunion", code: "RE" }, { value: "Romania", code: "RO" }, { value: "Russian Federation", code: "RU" }, { value: "RWANDA", code: "RW" }, { value: "Saint Helena", code: "SH" }, { value: "Saint Kitts and Nevis", code: "KN" }, { value: "Saint Lucia", code: "LC" }, { value: "Saint Pierre and Miquelon", code: "PM" }, { value: "Saint Vincent and the Grenadines", code: "VC" }, { value: "Samoa", code: "WS" }, { value: "San Marino", code: "SM" }, { value: "Sao Tome and Principe", code: "ST" }, { value: "Saudi Arabia", code: "SA" }, { value: "Senegal", code: "SN" }, { value: "Serbia and Montenegro", code: "CS" }, { value: "Seychelles", code: "SC" }, { value: "Sierra Leone", code: "SL" }, { value: "Singapore", code: "SG" }, { value: "Slovakia", code: "SK" }, { value: "Slovenia", code: "SI" }, { value: "Solomon Islands", code: "SB" }, { value: "Somalia", code: "SO" }, { value: "South Africa", code: "ZA" }, { value: "South Georgia and the South Sandwich Islands", code: "GS" }, { value: "Spain", code: "ES" }, { value: "Sri Lanka", code: "LK" }, { value: "Sudan", code: "SD" }, { value: "Suriname", code: "SR" }, { value: "Svalbard and Jan Mayen", code: "SJ" }, { value: "Swaziland", code: "SZ" }, { value: "Sweden", code: "SE" }, { value: "Switzerland", code: "CH" }, { value: "Syrian Arab Republic", code: "SY" }, { value: "Taiwan", code: "TW" }, { value: "Tajikistan", code: "TJ" }, { value: "Tanzania, United Republic of", code: "TZ" }, { value: "Thailand", code: "TH" }, { value: "Timor-Leste", code: "TL" }, { value: "Togo", code: "TG" }, { value: "Tokelau", code: "TK" }, { value: "Tonga", code: "TO" }, { value: "Trinidad and Tobago", code: "TT" }, { value: "Tunisia", code: "TN" }, { value: "Turkey", code: "TR" }, { value: "Turkmenistan", code: "TM" }, { value: "Turks and Caicos Islands", code: "TC" }, { value: "Tuvalu", code: "TV" }, { value: "Uganda", code: "UG" }, { value: "Ukraine", code: "UA" }, { value: "United Arab Emirates", code: "AE" }, { value: "United Kingdom", code: "GB" }, { value: "United States", code: "US" }, { value: "United States Minor Outlying Islands", code: "UM" }, { value: "Uruguay", code: "UY" }, { value: "Uzbekistan", code: "UZ" }, { value: "Vanuatu", code: "VU" }, { value: "Venezuela", code: "VE" }, { value: "Viet Nam", code: "VN" }, { value: "Virgin Islands, British", code: "VG" }, { value: "Virgin Islands, U.S.", code: "VI" }, { value: "Wallis and Futuna", code: "WF" }, { value: "Western Sahara", code: "EH" }, { value: "Yemen", code: "YE" }, { value: "Zambia", code: "ZM" }, { value: "Zimbabwe", code: "ZW" }, ], dropdown: { enabled: 1, // suggest tags after a single character input classname: "extra-properties", // custom class for the suggestions dropdown }, // map tags' values to this property name, so this property will be the actual value and not the printed value on the screen }); tagify.on("click", function (e) { console.log(e.detail); }); tagify.on("remove", function (e) { console.log(e.detail); }); tagify.on("add", function (e) { console.log("original Input:", tagify.DOM.originalInput); console.log("original Input's value:", tagify.DOM.originalInput.value); console.log("event detail:", e.detail); }); // add the first 2 tags and makes them readonly var tagsToAdd = tagify.whitelist.slice(0, 3); tagify.addTags(tagsToAdd); // 7. Readonly options var input = document.querySelector("input[name=tags4]"), tagify = new Tagify(input); // 8. Read and write options var input = document.querySelector("input[name=tags-readonly-mix]"), tagify = new Tagify(input); // 9. Disabled readonly var input = document.querySelector("input[name=disabledInput]"), tagify = new Tagify(input); // 10. Single-Value Select var input = document.querySelector("input[name=tags-select-mode]"); var input1 = document.querySelector("input[name=tags-select-value-mode"); var input2 = document.querySelector("input[name=tags-select-v-mode"); var input3 = document.querySelector("input[name=tags-s-value-mode"); tagify = new Tagify(input, { enforceWhitelist: true, mode: "select", whitelist: ["Crocs", "Roxo", "Tivo"], blacklist: ["foo", "bar"], }); tagify = new Tagify(input1, { enforceWhitelist: true, mode: "select", whitelist: ["Web designer", "UI/UX designer", "Web devloper"], blacklist: ["foo", "bar"], }); tagify = new Tagify(input2, { enforceWhitelist: true, mode: "select", whitelist: ["UI Kits", "Bonus UI", "Bookmarks"], blacklist: ["foo", "bar"], }); tagify = new Tagify(input3, { enforceWhitelist: true, mode: "select", whitelist: ["Forms", "Charts", "Blog"], blacklist: ["foo", "bar"], }); // bind events tagify.on("add", onAddTag); tagify.DOM.input.addEventListener("focus", onSelectFocus); function onAddTag(e) { console.log(e.detail); } function onSelectFocus(e) { console.log(e); } // 11. Customize emails // generate random whilist items var randomStringsArr = Array.apply(null, Array(100)).map(function () { return ( Array.apply(null, Array(~~(Math.random() * 10 + 3))) .map(function () { return String.fromCharCode(Math.random() * (123 - 97) + 97); }) .join("") + "@gmail.com" ); }); var emailsearch = document.querySelector(".customLook"), tagify = new Tagify(emailsearch, { // email address validation (https://stackoverflow.com/a/46181/104380) pattern: /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/, whitelist: randomStringsArr, callbacks: { invalid: onInvalidTag, }, dropdown: { position: "text", enabled: 1, // show suggestions dropdown after 1 typed character }, }), button = emailsearch.nextElementSibling; // "add new tag" action-button button.addEventListener("click", onAddButtonClick); function onAddButtonClick() { tagify.addEmptyTag(); } function onInvalidTag(e) { console.log("invalid", e.detail); } })();