WebSite X5Help Center

 
Donald M.
Donald M.
User

Drop-down list?  en

Auteur : Donald M.
Visité 2570, Followers 2, Partagé 0  

I have a page which is basically a list of text links to files/pages which are not part of the website.

I would like to put these links into a drop-down list but it cannot be part of the main menu.

I cannot see a way to do this, am I missing something?

Posté le
10 RéPONSES - 3 UTILE
Paul M.
Paul M.
Moderator

Hello Donald,

If you specifically want a drop-down list then this can't be done in WebSite X5 as standard: you would need to use custom code.

However, you can create additional menus in WebSite X5 (aside from the main menu) and this can be very useful.  These menus can be configured to show only certain levels in the main website map, and they can also be dropped into Objects (such as Text Objects) as an alternative to placing them in the header, footer or sidebar.

So, you could do something along these lines...

Create a hidden 'Level' in your sitemap.  Create visible levels (i.e. not hidden) underneath the hidden level.  These levels will be children to the parent level, and you need one for each external link to files/pages which are not part of your website.

Set the 'Properties' of each child level to open the URL of your choice, using the option 'Link to be executed on item click'

Insert a Menu Object onto the page where you want the links to be displayed.  In the Menu Object properties go to Main > View > Select the menu level of the items you want to display and select the 'hidden' parent level which you created above.

That's it...  it should work as intended, except that the links will show as an ordinary list instead of a drop-down list.

If you're comfortable with web programming then you could use the dropdown field in the Contact Form Object to offer your web visitors a choice of files/pages, then use the 'Send data to a file' option (on the Send tab of the Contact Form Object) to send this information to a script (e.g. PHP), which in turn opens the required file/webpage.

Kind regards,

Paul

Search the WebSite X5 Help Center

Lire plus
Posté le de Paul M.
John S.
John S.
User

You can make a level - and then hide that level

You can then use the level ( with pages ) in a menu you put on a page. You could make the menu as a hamburger menu.

Alternatively you can make the dropdown via code.

https://www.w3schools.com/howto/howto_css_dropdown.asp

Lire plus
Posté le de John S.
Donald M.
Donald M.
User
Auteur

The problem with your first solution is that the entire menu appears on the page and I need this drop-down menu to be completely independent.

I really don't want to start messing about with code.

Lire plus
Posté le de Donald M.
John S.
John S.
User

Hello Donald

If you put the code ( in my next post ) in a html-object and then set the height for the html-object to 160 then it will function out of the box.

You can then specify the links ( only link 2 in my example is active )  and also specify texts for the links.

Lire plus
Posté le de John S.
John S.
John S.
User

<style>
.dropbtn {
background-color: #4CAF50;
color: white;
padding: 16px;
font-size: 16px;
border: none;
}

.dropdown {
position: relative;
display: inline-block;

}

.dropdown-content {
display: none;
position: absolute;
background-color: #f1f1f1;
min-width: 160px;
box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
z-index: 1;
max-height:100px;
overflow:scroll;
}

.dropdown-content a {
color: black;
padding: 12px 16px;
text-decoration: none;
display: block;
}

.dropdown-content a:hover {background-color: #ddd;}

.dropdown:hover .dropdown-content {display: block;}

.dropdown:hover .dropbtn {background-color: #3e8e41;}
</style>

<div class="dropdown">
<button class="dropbtn">Dropdown</button>
<div class="dropdown-content">
<a href="#">Link 1</a>
<a href="http://calendarforum.dk/">Link 2</a>
<a href="#">Link 3</a>
<a href="#">Link 4</a>
<a href="#">Link 5</a>
<a href="#">Link 6</a>
</div>
</div>

Lire plus
Posté le de John S.
John S.
John S.
User

You can use the code as it is - but you can also set some colors and ather things so it suits your need.

Youn could say that the html-object is completely independent. But it is code - and so is every object you have on your page.

The advantage with this code is, that it can be copied and put into a page where you want. It will take up the space that you specify as height.

If you want the dropdown to be shown when the button is clicked and then disappear again by a new click it can be done - it only reguires some other code.

Lire plus
Posté le de John S.
John S.
John S.
User

Here is the code for a dropdown by click

<style>
.dropbtn {
background-color: #3498DB;
color: white;
padding: 16px;
font-size: 16px;
border: none;
cursor: pointer;
}

.dropbtn:hover, .dropbtn:focus {
background-color: #2980B9;
}

.dropdown {
position: relative;
display: inline-block;
}

.dropdown-content {
display: none;
position: absolute;
background-color: #f1f1f1;
min-width: 160px;
overflow: auto;
box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
z-index: 1;
max-height:100px;
overflow:scroll;
}

.dropdown-content a {
color: black;
padding: 12px 16px;
text-decoration: none;
display: block;
}

.dropdown a:hover {background-color: #ddd;}

.show {display: block;}
</style>


<div class="dropdown">
<button onclick="myFunction()" class="dropbtn">Dropdown</button>
<div id="myDropdown" class="dropdown-content">
<a href="#">Link 1</a>
<a href="http://calendarforum.dk/">Link 2</a>
<a href="#">Link 3</a>
<a href="#">Link 4</a>
<a href="#">Link 5</a>
<a href="#">Link 6</a>
</div>
</div>

<script>
/* When the user clicks on the button,
toggle between hiding and showing the dropdown content */
function myFunction() {
document.getElementById("myDropdown").classList.toggle("show");
}

// Close the dropdown if the user clicks outside of it
window.onclick = function(event) {
if (!event.target.matches('.dropbtn')) {
var dropdowns = document.getElementsByClassName("dropdown-content");
var i;
for (i = 0; i < dropdowns.length; i++) {
var openDropdown = dropdowns[i];
if (openDropdown.classList.contains('show')) {
openDropdown.classList.remove('show');
}
}
}
}
</script>

Lire plus
Posté le de John S.
Donald M.
Donald M.
User
Auteur

Thanks both, I now have a couple of options to work with.

Apologies for not marking either answer as correct, it seems I can only select one and not both!

Lire plus
Posté le de Donald M.
John S.
John S.
User

You can mark the post that is closest to or covers what you want - this way other users can see what helped.

You could also or instead mark posts as useful - again - others can see if something was helpful for you.

But - just wait until you have checked that something IS usefulwink

Lire plus
Posté le de John S.
 ‪ KolAsim ‪ ‪
 ‪ KolAsim ‪ ‪
Moderator
Donald M.
... ... ...  I really don't want to start messing about with code. 
   (It > En) ... without having to resort to extra codes, you could create the columned list of LINKS in a Text Object, applying the locked rollover, so that your scroll bar is activated; ...simple and immediate...

.

ciao

.

Lire plus
Posté le de  ‪ KolAsim ‪ ‪