Multiple Row Tabs
-
Thanks for updating the code @fpdragon and @alexander-gorbovets - Vivaldi is now usable for me again!
Is it possible to have the tabs stretch to fit the row? Or some kind of max width? The latest code posted by Alexander seems to keep the tabs at a specific width no matter how many tabs fill the tab bar.
-
@fpdragon
I've managed to make the tabs a bit shorter, so they do better fit my (wide) screen and still remain readable (and this even although I have no clue of programming ).
One more question: is it possible to limit the number of visible lines to 3 lines and in case there are more tabs than fit on 3 lines, have a slider to move the invisible lines up (and down)?Thanks,
Sabine -
@sabine said in Multiple Row Tabs:
@fpdragon
I've managed to make the tabs a bit shorter, so they do better fit my (wide) screen and still remain readable (and this even although I have no clue of programming ).
One more question: is it possible to limit the number of visible lines to 3 lines and in case there are more tabs than fit on 3 lines, have a slider to move the invisible lines up (and down)?Dear @fpdragon and/or @alexander-gorbovets,
Happy New Year to you !
did you see my 2 contributions to this subject some 3 weeks ago?
Would love to hear your opinion to my sugestions.Thanks,
Sabine -
@sabine I'm sorry for not responding earlier, I was ignoring this thread as it produced too many comments.
I'm not sure if we can help you until you show us the code — every little change has impact (though sometimes not so big) and there are also many versions and I don't know which one you are using.
-
@potmeklecbohdan No problem :-). There's no hurry. Thank you for answering.
I'm using the code that was originally published by fpdragon and/or alexander.gorbovets on nov.15:
} .resize { display: block !important; } .tab-strip { display: block; } .tab-strip > span { display: inline-block; } .tab-strip > span > .tab-position { left: 0px !important; position: relative; height: auto !important; width: auto !important; } .tab-strip > span > .tab-position > .tab:not(.pinned){ width: 120px !important; } .tab-strip > span > .tab-position > .tab.pinned{ width: 120px !important; } .tab-strip > span > .tab-position > .tab.pinned > .tab-header > span.title:before { content: '*'; font-family: "Courier New", serif; margin-bottom: -20px; } .tab-strip > .newtab { left: 0px !important; top: 0px !important; position: relative !important; display: inline-block; padding: 0; vertical-align: top; } .tab-header > .favicon > svg { height: 17px; } #tabs-container .tab.tab-small.tab-mini .tab-header .title, #tabs-container .tab.pinned.tab-mini .tab-header .title { display: flex !important; } /* multiline tabs */ #tabs-container { height: auto !important; } .resize { display: block !important; } .tab-strip { display: block; position: relative; /* border-style: solid; */ /* border-width: 1px; */ /* border-color: green; */ } .tab-strip > span { display: inline-block; } .tab-strip > span > .tab-position { left: 0px !important; position: relative; height: 30px !important; width: auto !important; } .tab-strip > span > .tab-position:first-child{ left: 30px !important; } .tab-strip > span > .tab-position > .tab:not(.pinned){ width: 220px !important; left: 0px !important; position: relative; height: 30px !important; /* width: auto !important; */ border-style: solid; border-width: 1px; border-color: grey; } .tab-strip > span > .tab-position > .tab.pinned{ width: 30px !important; left: 0px !important; position: relative; height: 30px !important; /* width: auto !important; */ border-style: solid; border-width: 1px; border-color: grey; } .toolbar-tabbar { /* width: 30px; */ /* border-style: solid; */ /* border-width: 1px; */ /* border-color: lime; */ } .toolbar-tabbar > .newtab { top: 0px !important; left: 0px !important; position: absolute !important; /* border-style: solid; */ /* border-width: 1px; */ /* border-color: red; */ }
Thanks,
Sabine
modedit Fixed the code block
-
@sabine Sorry, but I cannot read or copy it easily now and it wastes quite much space on the page. Please add an otherwise empty line like this (see below) before and after the code (edit the post, do not make a new one).
```
-
@potmeklecbohdan
I don't know how to edit my message, but maybe this works :
} .resize { display: block !important; } .tab-strip { display: block; } .tab-strip > span { display: inline-block; } .tab-strip > span > .tab-position { left: 0px !important; position: relative; height: auto !important; width: auto !important; } .tab-strip > span > .tab-position > .tab:not(.pinned){ width: 120px !important; } .tab-strip > span > .tab-position > .tab.pinned{ width: 120px !important; } .tab-strip > span > .tab-position > .tab.pinned > .tab-header > span.title:before { content: '*'; font-family: "Courier New", serif; margin-bottom: -20px; } .tab-strip > .newtab { left: 0px !important; top: 0px !important; position: relative !important; display: inline-block; padding: 0; vertical-align: top; } .tab-header > .favicon > svg { height: 17px; } #tabs-container .tab.tab-small.tab-mini .tab-header .title, #tabs-container .tab.pinned.tab-mini .tab-header .title { display: flex !important; } /* multiline tabs */ #tabs-container { height: auto !important; } .resize { display: block !important; } .tab-strip { display: block; position: relative; /* border-style: solid; */ /* border-width: 1px; */ /* border-color: green; */ } .tab-strip > span { display: inline-block; } .tab-strip > span > .tab-position { left: 0px !important; position: relative; height: 30px !important; width: auto !important; } .tab-strip > span > .tab-position:first-child{ left: 30px !important; } .tab-strip > span > .tab-position > .tab:not(.pinned){ width: 220px !important; left: 0px !important; position: relative; height: 30px !important; /* width: auto !important; */ border-style: solid; border-width: 1px; border-color: grey; } .tab-strip > span > .tab-position > .tab.pinned{ width: 30px !important; left: 0px !important; position: relative; height: 30px !important; /* width: auto !important; */ border-style: solid; border-width: 1px; border-color: grey; } .toolbar-tabbar { /* width: 30px; */ /* border-style: solid; */ /* border-width: 1px; */ /* border-color: lime; */ } .toolbar-tabbar > .newtab { top: 0px !important; left: 0px !important; position: absolute !important; /* border-style: solid; */ /* border-width: 1px; */ /* border-color: red; */ }
-
@sabine You can edit a post by right-clicking the three dots in bottom right corner and choosing edit.
Here is the code:
For newer version see later post
/* multiline tabs */ #tabs-container { height: auto !important; } .resize { display: block !important; } .tab-strip { display: block; position: relative; /* border-style: solid; */ /* border-width: 1px; */ /* border-color: green; */ max-height: 90px; overflow-y: scroll; } .tab-strip::-webkit-scrollbar { background: transparent; border: none; width: 10px; height: 0; } .tab-strip::-webkit-scrollbar-corner, .tab-strip::-webkit-scrollbar-track { background: transparent; border: none; } .tab-strip::-webkit-scrollbar-button { display: none; } .tab-strip::-webkit-scrollbar-thumb { width: 10px; border: none; border-radius: min(5px, var(--radius)); } .tab-strip > span { display: inline-block; } .tab-strip > span > .tab-position { left: 26px !important; position: relative; height: 30px !important; width: auto !important; } .tab-strip > span > .tab-position > .tab { left: 0px !important; position: relative; height: 30px !important; /* width: auto !important; */ border: 1px solid grey; } .tab-strip > span > .tab-position > .tab:not(.pinned) { width: 220px !important; } .tab-strip > span > .tab-position > .tab.pinned { width: 30px !important; } .tab-strip > span > .tab-position > .tab.pinned > .tab-header > span.title:before { content: '*'; font-family: "Courier New", serif; margin-bottom: -20px; } .tab-header > .favicon > svg { height: 17px; } #tabs-container .tab.tab-small.tab-mini .tab-header .title, #tabs-container .tab.pinned.tab-mini .tab-header .title { display: flex !important; } .toolbar-tabbar > .newtab { top: 0px !important; left: 0px !important; position: fixed !important; display: inline-block; padding: 0; vertical-align: top; /* border-style: solid; */ /* border-width: 1px; */ /* border-color: red; */ } .toolbar-tabbar > .newtab > button { margin-right: 0 !important; height: 26px !important; width: 26px !important; min-height: 26px !important; min-width: 26px !important }
-
@potmeklecbohdan
The code does not yet work. I can still produce 50 tabs and 11 rows are created and visible. So no limitation to the rows.
I've probably not sufficiently made clear my point. I suggested an enhancement of the code so the number of tab-rows shown is limited to a predefined number. The number of rows (e.g. 3 or 4) can be configured in the code. Should there be more tabs than would fit within the 3 rows, there should pop-up a slider at the right that can be pulled up (or down) to see the next tab row. Like it used to be in old FF.Regards
-
@sabine I understand you very well and you can be sure that I wouldn't give you the code if it didn't work for me. There must be some difference between our setups that breaks it for you (and for me it makes it impossible to give you code that works for you).
-
@potmeklecbohdan Thank you very much for your efforts. I'll try to find out what the reason is and will let let you know, so other users can benefit from our findings. Have a nice evening.
Sabine
-
@potmeklecbohdan forgot to ask... where is the line in your code to configer the number of rows?
-
@sabine
max-height: 90px;
, line 14 -
@potmeklecbohdan I've just installed the latest build and now it works (more or less ). The scrollbar is now shown at the right, that's fine. But it is without function. The slider cannot be moved down (or up) hence the "hidden" tab lines cannot be "pulled up". Scrolling works though with the scrollwheel of the mouse when the mouse is hoovered over a tab row.
Also the "New Tab"-button has disappeared.I hope my feedback is of any help.
Rgds,
Sabine -
@sabine Ah yes, I see. Should work now.
/* multiline tabs */ #tabs-container { height: auto !important; } .resize { display: block !important; -webkit-app-region: none; } .tab-strip { display: block; position: relative; /* border-style: solid; */ /* border-width: 1px; */ /* border-color: green; */ max-height: 90px; overflow-y: scroll; } .tab-strip::-webkit-scrollbar { background: transparent; border: none; width: 10px; height: 0; } .tab-strip::-webkit-scrollbar-corner, .tab-strip::-webkit-scrollbar-track { background: transparent; border: none; } .tab-strip::-webkit-scrollbar-button { display: none; } .tab-strip::-webkit-scrollbar-thumb { width: 10px; border: none; border-radius: min(5px, var(--radius)); } .tab-strip > span { display: inline-block; } .tab-strip > span > .tab-position { left: 26px !important; position: relative; height: 30px !important; width: auto !important; } .tab-strip > span > .tab-position > .tab { left: 0px !important; position: relative; height: 30px !important; /* width: auto !important; */ border: 1px solid grey; } .tab-strip > span > .tab-position > .tab:not(.pinned) { width: 220px !important; } .tab-strip > span > .tab-position > .tab.pinned { width: 30px !important; } .tab-strip > span > .tab-position > .tab.pinned > .tab-header > span.title:before { content: '*'; font-family: "Courier New", serif; margin-bottom: -20px; } .tab-header > .favicon > svg { height: 17px; } #tabs-container .tab.tab-small.tab-mini .tab-header .title, #tabs-container .tab.pinned.tab-mini .tab-header .title { display: flex !important; } .toolbar-tabbar > .newtab { top: 7px !important; left: 30px !important; position: fixed !important; display: inline-block; padding: 0; vertical-align: top; /* border-style: solid; */ /* border-width: 1px; */ /* border-color: red; */ }
-
@potmeklecbohdan Hi, slider works now and... the "New Tab" button is back. Thanks a lot :-). However, the button is not at his correct position, see screenshot.
-
@sabine Play with the
7px
and30px
near the end. -
@potmeklecbohdan
Done! Works perfectly. Your my HERO :-). Thanks a lot again for your help.
One question: the "closing X" only pops up when hoovering over the active tab and not when hoovering over an non-active tab. This used to be the case in the non-modified version. (I've activated the option in settings). -
@sabine What's the question?
-
@potmeklecbohdan the question is, how to get back the "closing cross" on the non-activated tabs? I mean only while hoovering over the tab, of course.