Skip to content

LightWeight Javascript Library for making custom contextMenu for your website

Notifications You must be signed in to change notification settings

mboussaid/contextMenu.js

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

27 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ContextMenu.js

LightWeight Javascript Library for making your own contextmenu

dddd

Quick Start

<script src="https://unpkg.com/@mboussaid/contextmenu.js@1.0.0" ></script>

How to Use

contextMenu({
//// array of items 
    items:[

        {
            
            template:"", ///html template
            onClick:function(item,index){
                /// callback function

            }
        }
    ] 
}).init(document /* where you want to add contextmenu document by default */)

Example

contextMenu({
    items:[
        {
            template:"<a href='#'>Github</a>",
            onClick:function(item,index){
                console.log("you have clicked on github link !!!!!!")
            }
        },
        {
            template:"<a href='#'>Facebook</a>",
            onClick:function(item,index){
                console.log("you have clicked on Facebook link !!!!!!")
            }
        },
        {
            template:"<a href='#'>Youtube</a>",
            onClick:function(item,index){
                console.log("you have clicked on Youtube link !!!!!!")
            }
        }
    ]
}).init();

Styling

/* The main container */
.contextMenu{

}


/* The ul element */
.contextMenuList{

}


/* The li  item element  */
.contextMenuItem{

}

Using Custom Classes and id

contextMenu({
    className:"myCustomClassName",
    id:"myCustomIdHere",
    items:[]
}).init(document);

Example

Html

<html>
<body>
<textarea></textarea>
    </body>
    </html>

Javascript

contextMenu({
items:[
{
template:`<img src=""/> <span>Github</span>`,
onClick:function(){
window.open('https://www.github.com','_blank');
}
},

{
template:`<img src=""/> <span>Google</span>`,
onClick:function(){
window.open('https://www.google.com','_blank');
}
}
]
}).init(document.querySelector("textarea"));

CSS

    .contextMenu{
            background-color: gray;
         
         
            color:#fff;
        }
        .contextMenuItem{
            padding: 5px 10px;
            display: flex;
            align-items: center;
        justify-content: center;
        justify-items: center;
        }
        .contextMenuItem{
            margin-top: 5px;
        }
        .contextMenuItem span{
            margin-left: 5px;
        }
        .contextMenuItem:hover{
            background-color: green;
            color:#fff;
        }

Wacth the Example Demo