Français
💻 To developpers
This is a CSS overlay that can be applied to the advanced web interface of Mastodon websites.
(Don't worry, you don't need to know CSS or what “CSS” even means.)
It brings:
- The ability to control the width of the columns (by dragging their lower right corner),
- A more rounded feel,
- The columns are spread rather than stacked to the left,
- The decorative image (bottom left) can be better handled in some instances, and the possibility to choose a custom one instead.
- If not already done, enable the Dark theme* and the advanced web interface for Mastodon:
Go in Mastodon “Preferences” (on the right side of the default Mastodon view). Then, in “Appearance”, check “Enable advanced web interface”, and select “Mastodon (Dark)” as the “Site them”.
* Alternatively, if you do not want to use a dark theme, you can remove the additional recoloring provided by this tool. - Install the Stylus browser extension, or any other extension that allows to apply custom CSS to a web page. Stylus is available on Firefox and Chrome).
- Add a style for your Mastodon web page. Typically, for Stylus:
- Go to your Mastodon web page,
- Click the button of the extension, then click “Write style for …”. (Stop at the first slash, thus including the name of your instance but not more than that.)
- Select the right CSS file, copy-paste the CSS code in the Stylus window.
- Customize if need be.
The only difference between the proposed CSS files lies in how the decorative bottom left image is handled. The optimal choice depends on what your Mastodon instance uses or what you want to use instead.
- If you want to keep the instance image:
- If your instance uses something that is integrated to the design with transparency, and that shall be kept to the lower left corner (which is the case for many instances that keep the default mastodon 🐘 drawing), use
mastodon.css
. - If your instance uses a custom picture with no transparency that should be properly framed and centered, use
instance.css
.
- If your instance uses something that is integrated to the design with transparency, and that shall be kept to the lower left corner (which is the case for many instances that keep the default mastodon 🐘 drawing), use
- If you want to use you own image (or no image):
- If it has transparency and be kept to the lower left corner, use
custom-transp.css
. - If it has no transparency and shall be properly framed, used
custom.css
.
(Whileinstance.css
will center the image when the column is too wide for it,custom.css
was created to use higher resolution images that would take the whole available width, and be cropped accordingly to fit a target height.)
- If it has transparency and be kept to the lower left corner, use
If you are using custom.css
or custom-transp.css
, find these lines (toward the end) and put the URL of the image you want to use in between the parentheses:
.drawer__inner__mastodon {
background: url(""); /* 👈 Put image url here. */
With custom.css
, by default, when the image is cropped, its center is kept. It might not perfectly fit your picture, but you can change that by modifying the next line:
background-position: center center;
The first center
can be replaced with top
or bottom
, and the second center
with left
or right
, depending on the area of the picture you want to keep.
You can modify the rest of the code to your liking. For those unfamiliar with CSS, here are a few things you might want to do and how…
Not happy with the new colors?
Just remove the whole Recolor section (from /* Recolor */
to /* Roundness */
).
If just don't like the gradient on the leftmost column, remove this:
.drawer__inner {
background: linear-gradient(0deg, $left-bottom 0%, $left-top 100%);
}
For keeping a slightly darker color with no gradient, you can also replace it with:
.drawer__inner {
background: #333746;
}
The bottom left image is too small or grows too big?
Find these lines and change the maximal height (by default, 200px
) as you see fit:
.drawer__inner__mastodon {
max-height: 200px; /* 💡 If the bottom-left picture grows to big, change that. */
Defining default column widths
It is not possible to memorize the column widths to be reused the next time you open the web page. However, you can define default column widths by adding lines to the CSS code.
For the leftmost column:
.drawer { width: 20%; }
For the other columns:
.column { width: 20%; }
For the 2nd column (“Home”):
.column:nth-of-type(2) { width: 20%; }
For the 3rd column (“Notifications”):
.column:nth-of-type(2) { width: 20%; }
In the previous examples, the column width(s) were set to 20% of the total width of the page; but you can put whatever size you want. You can also use pixels as the unit (e.g., by replacing 20%
by 400px
), or even do calculations between percents and pixels (e.g., ny replacing 20%
by calc( 25% - 30px )
).
Il s'agit d'une surcouche CSS qui peut être appliquée à l'interface web avancée des sites Mastodon. (Ne vous en faites pas, vous n'avez pas besoin de connaître le CSS, ou même ce que “CSS” signifie.)
Ça vous apportera :
- La possibilité de contrôler la largeur des colonnes (en tirant le coin en bas à droite de chaque colonne),
- Un design plus rond,
- Des colonnes réparties sur la page web et non regroupées à gauche,
- Une meilleure prise en charge de l'image décorative (en bas à gauche) sur certaines instances, et la possibilité de mettre la vôtre à la place.
- Si vous ne l'avez pas déjà fait, activez le thème sombre* et l'interface web avancée de Mastodon :
Cliquez sur “Préférences” (à droite dans la vue simple par défaut de Mastodon).
*Alternativement, si vous ne voulez pas un thème sombre, vous pourrez retirer les couleurs créées pas cet outil. - Installez l'extension de navigateur Stylus, ou tout autre extension permettant d'appliquer un code CSS personnalisé à une page web. Stylus est disponible sur Firefox et Chrome).
- Ajoutez un style pour votre site Mastodon. Typiquement, avec *Stylus" :
- Allez sur votre site Mastodon,
- Cliquez le bouton de l'extension, puis cliquez sur “Write style for …”. (Arrêtez-vous à la première barre oblique, incluant ainsi le nom de votre instance Mastodon mais pas plus que ça.)
- Sélectionnez le bon fichier CSS, et copiez-collez le code dans la fenêtre ouverte par Stylus à l'étape précédente.
- Personnalisez si nécessaire.
La seule différence entre les fichiers CSS proposés est dans le traitement de l'image décorative en bas à gauche. Le choix optimal dépend de ce que votre instance Mastodon utilise, ou si vous voulez choisir votre propre image.
- Si vous voulez garder l'image de l'instance :
- Si l'image est intégrée au design du site avec de la transparence, et gagne à rester dans le coin en bas à gauche (ce qui est le cas de bien des instances, utilisant le dessin de mastodonte 🐘 par défaut), utilisez
mastodon.css
. - Si l'image est une image sans transparence qui gagne à être proprement cadrée et centrée, utilisez
instance.css
.
- Si l'image est intégrée au design du site avec de la transparence, et gagne à rester dans le coin en bas à gauche (ce qui est le cas de bien des instances, utilisant le dessin de mastodonte 🐘 par défaut), utilisez
- Si vous voulez utilisez une image de votre choix (ou pas d'image) :
- Si elle a de la transparence et gagne à rester dans le coin en bas à gauche, utilisez
custom-transp.css
. - Si elle n'a pas de transparence, et gagne à être cadrée et centrée, utilisez
custom.css
.
(Tandis queinstance.css
centrera l'image quand la colonne de gauche est trop large pour elle,custom.css
a été créé pour utiliser une image de plus grande résolution qui prendra toute la largeur disponible, et rognera pour atteindre la hauteur attendue. Typiquement,piaille.css
a été créé pour piaille.fr, et remplace la photo d'oiseau de l'instance par une version de meilleure qualité.)
- Si elle a de la transparence et gagne à rester dans le coin en bas à gauche, utilisez
Si vous utilisez custom.css
ou custom-transp.css
, trouvez ces lignes (vers la fin), et mettez l'url de l'image que vous voulez utiliser entre les parenthèses :
.drawer__inner__mastodon {
background: url(""); /* 👈 Put image url here. */
Avec custom.css
, par défaut, quand l'image est rognée, c'est son centre qui est gardé. Ce n'est peut-être pas le comportement idéal pour votre image, mais vous pouvez le changer en modifiant la ligne suivante :
background-position: center center;
Le premier center
(centre) peut être remplacé avec top
(haut) ou bottom
(bas), et le second center
par left
(gauche) or right
(droite), selon la zone de l'image que vous souhaitez garder.
Vous pouvez modifier le reste du code comme vous le souhaitez. Pour ceux et celles qui ne maîtrisent pas le CSS, voilà quelques modifications que vous pourriez vouloir faire et comment :
Vous n'aimez pas les nouvelles couleurs ?
Retirez simplement toute la section Recolor dans le code (de /* Recolor */
à /* Roundness */
).
Si vous n'aimez juste pas le gradient dans la colonne de gauche, retirez :
.drawer__inner {
background: linear-gradient(0deg, $left-bottom 0%, $left-top 100%);
}
Pour toutefois garder une couleur légèrement plus sombre mais sans gradient, vous pouvez aussi remplacer ce code par :
.drawer__inner {
background: #333746;
}
L'image en pas à gauche est trop petite ou devient trop grande ?
Cherchez ces lignes et changez la hauteur maximale (max-height
, qui est par défaut à 200 px) comme vous le souhaitez :
.drawer__inner__mastodon {
max-height: 200px; /* 💡 If the bottom-left picture grows to big, change that. */
Fixer des largeurs de colonne par défaut
Il n'est pas possible de mémoriser les largeurs des colonnes pour les réutiliser la prochaine fois où vous ouvrirez la page. En revanche il est possible de fixer des largeurs par défaut en ajoutant des lignes au code CSS.
Pour la colonne de gauche :
.drawer { width: 20%; }
Pour les autres colonnes :
.column { width: 20%; }
Pour la deuxième colonne (“Accueil”) :
.column:nth-of-type(2) { width: 20%; }
Pour la troisième colonne (“Notifications”) :
.column:nth-of-type(2) { width: 20%; }
Les exemples précédents fixent la largeur de la ou des colonnes à 20% de la largeur de la page, mais vous pouvez mettre ce que vous voulez. Vous pouvez aussi utiliser des pixels comme unité (ex. en remplaçant 20%
par 400px
), ou même des calculs entre pourcents et pixels (ex. en remplaçant 20%
par calc( 25% - 30px )
).
If you want to toy with this project, know that the CSS files are compiled from the SCSS files in the sccs/
folder.
This avoids to manually duplicate the same pieces of code throughout the various CSS files.
The CSS might not be optimally organized: some selectors can appear several times. This is because I prioritized ease of modification for the users (including those not knowing CSS). Thus, the CSS is thematically organized (based on what it does), and a user can easily delete a whole section if they do not like what it does.