Repository with sources and generator of https://larlet.fr/david/ https://larlet.fr/david/
Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.

index.html 28KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506
  1. <!DOCTYPE html><!-- This is a valid HTML5 document. -->
  2. <!-- Screen readers, SEO, extensions and so on. -->
  3. <html lang="fr">
  4. <!-- Has to be within the first 1024 bytes, hence before the `title` element
  5. See: https://www.w3.org/TR/2012/CR-html5-20121217/document-metadata.html#charset -->
  6. <meta charset="utf-8">
  7. <!-- Why no `X-UA-Compatible` meta: https://stackoverflow.com/a/6771584 -->
  8. <!-- The viewport meta is quite crowded and we are responsible for that.
  9. See: https://codepen.io/tigt/post/meta-viewport-for-2015 -->
  10. <meta name="viewport" content="width=device-width,initial-scale=1">
  11. <!-- Required to make a valid HTML5 document. -->
  12. <title>
  13. Légitimité
  14. — David Larlet</title>
  15. <script>
  16. function toggleTheme(themeName) {
  17. document.documentElement.classList.toggle(
  18. 'forced-dark',
  19. themeName === 'dark'
  20. )
  21. document.documentElement.classList.toggle(
  22. 'forced-light',
  23. themeName === 'light'
  24. )
  25. }
  26. const selectedTheme = localStorage.getItem('theme')
  27. if (selectedTheme !== 'undefined') {
  28. toggleTheme(selectedTheme)
  29. }
  30. </script>
  31. <!-- Documented, feel free to shoot an email. -->
  32. <link rel="stylesheet" href="/static/david/css/style_2024-03-09.css">
  33. <!-- See https://www.zachleat.com/web/comprehensive-webfonts/ for the trade-off. -->
  34. <link rel="preload"
  35. href="/static/david/css/fonts/century_supra_ot_a_regular.woff2"
  36. as="font"
  37. type="font/woff2"
  38. media="(prefers-color-scheme: light), (prefers-color-scheme: no-preference)"
  39. crossorigin>
  40. <link rel="preload"
  41. href="/static/david/css/fonts/century_supra_ot_a_bold.woff2"
  42. as="font"
  43. type="font/woff2"
  44. media="(prefers-color-scheme: light), (prefers-color-scheme: no-preference)"
  45. crossorigin>
  46. <link rel="preload"
  47. href="/static/david/css/fonts/century_supra_ot_a_italic.woff2"
  48. as="font"
  49. type="font/woff2"
  50. media="(prefers-color-scheme: light), (prefers-color-scheme: no-preference)"
  51. crossorigin>
  52. <link rel="preload"
  53. href="/static/david/css/fonts/century_supra_ot_b_regular.woff2"
  54. as="font"
  55. type="font/woff2"
  56. media="(prefers-color-scheme: dark)"
  57. crossorigin>
  58. <link rel="preload"
  59. href="/static/david/css/fonts/century_supra_ot_b_bold.woff2"
  60. as="font"
  61. type="font/woff2"
  62. media="(prefers-color-scheme: dark)"
  63. crossorigin>
  64. <link rel="preload"
  65. href="/static/david/css/fonts/century_supra_ot_b_italic.woff2"
  66. as="font"
  67. type="font/woff2"
  68. media="(prefers-color-scheme: dark)"
  69. crossorigin>
  70. <meta name="description" content="Car comment écrire le monde, en particulier celui qui souffre, suffoque et se bat, depuis une situation privilégiée ? Comment, dans un monde baigné de superflu, mener une analyse fine et lucide sur la nécessité ? Peut-on en appeler à la beauté dans un monde de violence ? Et comment combattre le sentiment d’imposture ? Comment concilier lucidité et poésie, politique et esthétique, sentiment de classe et pulsions d’universalité, comment enfin écrire sur ce qu’on ne fait parfois qu’effleurer, sans l’avoir parfaitement, longuement et profondément éprouvé ?">
  71. <!-- That good ol' feed, subscribe :). -->
  72. <link rel="alternate"
  73. type="application/atom+xml"
  74. title="Feed"
  75. href="/david/log/">
  76. <!-- Generated from https://realfavicongenerator.net/ such a mess. -->
  77. <link rel="apple-touch-icon"
  78. sizes="180x180"
  79. href="/static/david/icons2/apple-touch-icon.png">
  80. <link rel="icon"
  81. type="image/png"
  82. sizes="32x32"
  83. href="/static/david/icons2/favicon-32x32.png">
  84. <link rel="icon"
  85. type="image/png"
  86. sizes="16x16"
  87. href="/static/david/icons2/favicon-16x16.png">
  88. <link rel="manifest" href="/static/david/icons2/site.webmanifest">
  89. <link rel="mask-icon"
  90. href="/static/david/icons2/safari-pinned-tab.svg"
  91. color="#07486c">
  92. <link rel="shortcut icon" href="/static/david/icons2/favicon.ico">
  93. <meta name="msapplication-TileColor" content="#f7f7f7">
  94. <meta name="msapplication-config"
  95. content="/static/david/icons2/browserconfig.xml">
  96. <meta name="theme-color"
  97. content="#f7f7f7"
  98. media="(prefers-color-scheme: light)">
  99. <meta name="theme-color"
  100. content="#272727"
  101. media="(prefers-color-scheme: dark)">
  102. <!-- Is that even respected? Retrospectively? What a shAItshow…
  103. https://neil-clarke.com/block-the-bots-that-feed-ai-models-by-scraping-your-website/ -->
  104. <meta name="robots" content="noai, noimageai">
  105. <!-- To get attribution when linking on mastodon. -->
  106. <meta name="fediverse:creator" content="@david@larlet.fr">
  107. <style type="text/css">
  108. .tippy-content {
  109. min-width: 280px;
  110. padding: .5rem;
  111. font-size: calc(var(--fluid-0) * 0.8);
  112. font-family: var(--labor-font);
  113. letter-spacing: initial;
  114. text-align: left;
  115. }
  116. .tippy-content h3 {
  117. margin-top: 0;
  118. }
  119. .tippy-content h3 img {
  120. max-width: 2rem;
  121. max-height: 2rem;
  122. display: inline-block;
  123. }
  124. .tippy-content .tippy-links {
  125. display: flex;
  126. justify-content: space-around;
  127. }
  128. .tippy-content a {
  129. padding: .4rem;
  130. color: #F06048;
  131. }
  132. </style>
  133. <body data-instant-intensity="viewport-all">
  134. <article>
  135. <header>
  136. <hgroup>
  137. <h1>Légitimité</h1>
  138. <p>Le <time datetime="2024-01-22">22 janvier 2024</time></p>
  139. </hgroup>
  140. </header>
  141. <nav>
  142. <p>
  143. <a rel="prev"
  144. href="/david/2024/01/21/"
  145. title="Publication précédente : Bois">← Précédent</a> •
  146. <a href="/david/" title="Aller à l’accueil" rel="up">Accueil</a>
  147. <a href="/david/recherche/"
  148. title="Aller à la page de recherche"
  149. rel="search" data-no-instant>Recherche</a>
  150. • <a rel="next"
  151. href="/david/2024/01/23/"
  152. title="Publication suivante : Thèse">Suivant →</a>
  153. </p>
  154. </nav>
  155. <blockquote>
  156. <p>Car comment écrire le monde, en particulier celui qui souffre, suffoque et se bat, depuis une situation privilégiée&#8239;? Comment, dans un monde baigné de superflu, mener une analyse fine et lucide sur la nécessité&#8239;? Peut-on en appeler à la beauté dans un monde de violence&#8239;? Et comment combattre le sentiment d’imposture&#8239;? Comment concilier lucidité et poésie, politique et esthétique, sentiment de classe et pulsions d’universalité, comment enfin écrire sur ce qu’on ne fait parfois qu’effleurer, sans l’avoir parfaitement, longuement et profondément&nbsp;éprouvé&#8239;?</p>
  157. <p>En étant honnête, sans doute. […] <mark>Mais l’écriture, une fois entravée d’un tel filet de précautions et de prudences, ne perd-elle pas en&nbsp;sincérité&#8239;?</mark></p>
  158. <p>Le désir de beauté, les envies de mots débridés, le souci même de l’éthique viennent souvent se fracasser sur la réalité sociale, le prosaïque du quotidien et <em>in fine</em> la crainte de l’indécence. C’est un souci salutaire sans aucun doute, mais aussi un brise-l’élan qui, depuis des années, me détourne de&nbsp;l’essai.</p>
  159. <p>La critique est tellement facile et le dénigrement si prisé dans les milieux militants que je ne dois pas être la seule, parfois, à me sentir dissuadée d’écrire sur certains sujets. Pourtant, faut-il s’empêcher d’explorer de nouveaux espaces, d’écrire ses impressions, de poser des intuitions et des sensations, de formuler des hypothèses? Faut-il s’interdire certains&nbsp;thèmes&#8239;?</p>
  160. <p>Doit-on être spécialiste d’un sujet pour en parler&#8239;? Rien ne peut fonctionner si seuls les universitaires peuvent écrire des essais, si les romancières sont cantonnées à raconter des histoires, si seuls les insurgés sont légitimes à parler de révolution, les pauvres de misère, les racisés de discrimination, si les déserteurs sont trop diplômés et si les écrivains ne peuvent disserter que sur la&nbsp;création.</p>
  161. <p><cite><em>Alors nous irons trouver la beauté ailleurs</em>, Corinne Morel&nbsp;Darleux</cite></p>
  162. </blockquote>
  163. <p>La légitimité de la personne qui écrit est importante —&nbsp;notamment en terme de crédibilité&nbsp;— et j’apprécie qu’IA Writer <a data-link-domain="ia.net" href="https://ia.net/topics/writing-with-ai" hreflang="en"
  164. title="Consultation de l’article (anglais)">expérimente des choses</a>
  165. <a href="/david/cache/2024/291cddda62f18ec9355ec98761b7e9d9/" hreflang="en"
  166. data-tippy data-description="When ChatGPT came out one year ago, we wanted to know whether and how it could be used for writing. We put it to the test."
  167. data-source="https://ia.net/topics/writing-with-ai"
  168. data-date="2024-01-21"
  169. data-favicon="https://ia.net/wp-content/themes/iA-library/assets/favicons/favicon.ico"
  170. data-domain="ia.net"
  171. ><svg xmlns="http://www.w3.org/2000/svg"
  172. width="24" height="24" viewBox="0 0 24 24" fill="none"
  173. stroke="currentColor" stroke-width="2" stroke-linecap="square"
  174. stroke-linejoin="round"><circle cx="12" cy="12" r="10"></circle>
  175. <path d="M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3"></path>
  176. <line x1="12" y1="17" x2="12.01" y2="17"></line>
  177. </svg>
  178. <span class="sr-only">[archive]</span></a> dans le domaine et peut-être que leur <a data-link-domain="github.com" href="https://github.com/iainc/Markdown-Annotations">spécification pour annotations</a> pourrait être détournée pour mentionner où l’auteur·ice <em>se situe</em> explicitement dans (la partie de) l’article. J’écris ce paragraphe avec ma casquette de développeur, ou en ayant expérimenté l’expatriation, ou en étant membre d’une coopérative, ou en ayant l’habitude d’écrire des trucs sur le net. On pourrait annoter les intentions aussi&nbsp;: j’écris cela en voulant être informatif, ou troll, ou militant, etc.</p>
  179. <p>C’est l’une des choses que rend possible le numérique. Légitimité sans argument d’autorité, tout un programme. Et si je tentais des choses ces prochains&nbsp;jours&#8239;?</p>
  180. <blockquote lang="en">
  181. <p>optionally followed by author annotation session, with a format <mark>to be announced</mark> in a future version of the spec, separated from the author name either by the author identifier or a&nbsp;comma</p>
  182. <p><cite><em><a data-link-domain="github.com" href="https://github.com/iainc/Markdown-Annotations#author-annotations">Author&nbsp;Annotations</a></em></cite></p>
  183. </blockquote>
  184. <a href="#hr-43" title="Lien vers cette section de la page"><hr id="hr-43" /></a>
  185. <blockquote lang="en">
  186. <p>Sometimes I’d have a realization that I was doing something for the first time since I had left home, 16&nbsp;months earlier. First time pumping gas. First time ringing a doorbell. First time going to a grocery store. First time swimming. Each of these instances brought with it a small feeling of novelty, but it didn’t amount to much. It took conscious effort to remember that I was pumping gas for the first time in 16&nbsp;months. It felt&nbsp;normal.</p>
  187. <p>I was back in my real life, and although I put it on hold for Antarctica, it was waiting for me when I got back. <mark>Antarctica was a a different world, a radical departure from my normal reality.</mark> It was so different, in fact, that I simply could not merge the two realities into one. I had my real life, and I had my Antarctica life. When my Antarctica life finished, I resumed my real&nbsp;life.</p>
  188. <p><cite><em><a data-link-domain="brr.fyi" href="https://brr.fyi/posts/redeployment-part-three" hreflang="en"
  189. title="Consultation de l’article (anglais)">Redeployment Part Three</a>
  190. <a href="/david/cache/2024/e8748af541273328d9aa9f1aeb1087b2/" hreflang="en"
  191. data-tippy data-description="Departing Antarctica after 446 days on-ice. Relaxing in Christchurch, then heading home. What an adventure!"
  192. data-source="https://brr.fyi/posts/redeployment-part-three"
  193. data-date="2024-01-21"
  194. data-favicon="https://brr.fyi/favicon-32x32.png"
  195. data-domain="brr.fyi"
  196. ><svg xmlns="http://www.w3.org/2000/svg"
  197. width="24" height="24" viewBox="0 0 24 24" fill="none"
  198. stroke="currentColor" stroke-width="2" stroke-linecap="square"
  199. stroke-linejoin="round"><circle cx="12" cy="12" r="10"></circle>
  200. <path d="M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3"></path>
  201. <line x1="12" y1="17" x2="12.01" y2="17"></line>
  202. </svg>
  203. <span class="sr-only">[archive]</span></a></em></cite></p>
  204. </blockquote>
  205. <p>Troisième partie (<a data-link-domain="brr.fyi" href="https://brr.fyi/posts/redeployment-part-one" hreflang="en"
  206. title="Consultation de l’article (anglais)">1</a>
  207. <a href="/david/cache/2024/da7e5578fd96fe31d46bfb207d041880/" hreflang="en"
  208. data-tippy data-description="Sunrise at the bottom of the world. Preparing South Pole Station to welcome its first new arrivals in almost nine months."
  209. data-source="https://brr.fyi/posts/redeployment-part-one"
  210. data-date="2024-01-21"
  211. data-favicon="https://brr.fyi/favicon-32x32.png"
  212. data-domain="brr.fyi"
  213. ><svg xmlns="http://www.w3.org/2000/svg"
  214. width="24" height="24" viewBox="0 0 24 24" fill="none"
  215. stroke="currentColor" stroke-width="2" stroke-linecap="square"
  216. stroke-linejoin="round"><circle cx="12" cy="12" r="10"></circle>
  217. <path d="M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3"></path>
  218. <line x1="12" y1="17" x2="12.01" y2="17"></line>
  219. </svg>
  220. <span class="sr-only">[archive]</span></a>, <a data-link-domain="brr.fyi" href="https://brr.fyi/posts/redeployment-part-two" hreflang="en"
  221. title="Consultation de l’article (anglais)">2</a>
  222. <a href="/david/cache/2024/284205d0f99390dd18d3af12ff53227c/" hreflang="en"
  223. data-tippy data-description="First flight to the South Pole after a long, isolated winter. Winterover staff handing over their work and preparing to depart."
  224. data-source="https://brr.fyi/posts/redeployment-part-two"
  225. data-date="2024-01-21"
  226. data-favicon="https://brr.fyi/favicon-32x32.png"
  227. data-domain="brr.fyi"
  228. ><svg xmlns="http://www.w3.org/2000/svg"
  229. width="24" height="24" viewBox="0 0 24 24" fill="none"
  230. stroke="currentColor" stroke-width="2" stroke-linecap="square"
  231. stroke-linejoin="round"><circle cx="12" cy="12" r="10"></circle>
  232. <path d="M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3"></path>
  233. <line x1="12" y1="17" x2="12.01" y2="17"></line>
  234. </svg>
  235. <span class="sr-only">[archive]</span></a>) d’un retour sur la terre non gelée. Merci pour ce voyage par procuration cette dernière année, les détails et les anecdotes étaient&nbsp;parfaits.</p>
  236. <p><em>Je remarque au passage qu’iels chaussent les mêmes bottes Baffin que moi par grand&nbsp;froid.</em></p>
  237. <a href="#hr-44" title="Lien vers cette section de la page"><hr id="hr-44" /></a>
  238. <blockquote>
  239. <p>Il est largement prouvé qu’il n’y a qu’un moyen de faire entrer plus de femmes dans la tech. C’est par le biais de la <strong>représentativité</strong>. <mark>Les jeunes femmes ne peuvent pas se projeter dans des rôles qu’elles ne connaissent pas.</mark> J’espère qu’à un moment où un autre, vous aurez vous aussi envie d’occuper l’espace et de vous rendre visible, pour montrer que les femmes dans la tech existent et que c’est une voie royale. Vous pouvez aussi être <strong>marraine</strong> et intervenir dans des écoles avec <a data-link-domain="ellesbougent.com" href="https://www.ellesbougent.com/">Elles bougent</a> ou <a data-link-domain="intrepidesdelatech.org" href="https://www.intrepidesdelatech.org/">Les intrépides de la tech</a>.</p>
  240. <p><cite><em><a data-link-domain="duchess-france.fr" href="https://www.duchess-france.fr/dossier/women%20in%20tech/alli%C3%A9s/2023/01/15/manuel-survie-femme-tech.html" hreflang="en"
  241. title="Consultation de l’article (anglais)">Manuel de survie de la femme dans la tech</a>
  242. <a href="/david/cache/2024/c4751e7c80b292e3533ee6b3e057b702/" hreflang="en"
  243. data-tippy data-description="Je vois de plus en plus de femmes rejoindre l’informatique, et c’est une très bonne chose. Je vois aussi trop de femmes patir de sexisme ordinaire, se remettre en question encore et encore… et quitter le milieu au bout de quelques années. J’ai mis du temps à apprendre certaines choses."
  244. data-source="https://www.duchess-france.fr/dossier/women%20in%20tech/alli%C3%A9s/2023/01/15/manuel-survie-femme-tech.html"
  245. data-date="2024-01-21"
  246. data-favicon="https://www.duchess-france.fr/favicon.ico"
  247. data-domain="duchess-france.fr"
  248. ><svg xmlns="http://www.w3.org/2000/svg"
  249. width="24" height="24" viewBox="0 0 24 24" fill="none"
  250. stroke="currentColor" stroke-width="2" stroke-linecap="square"
  251. stroke-linejoin="round"><circle cx="12" cy="12" r="10"></circle>
  252. <path d="M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3"></path>
  253. <line x1="12" y1="17" x2="12.01" y2="17"></line>
  254. </svg>
  255. <span class="sr-only">[archive]</span></a></em></cite></p>
  256. </blockquote>
  257. <p>Superbe manuel de Florence Chabanois avec plein de conseils et de liens pour creuser. J’appuie le fait qu’il est important d’être bien entourée pour rentrer dans ce domaine, pas seulement pour l’apprentissage de la technique mais pour déconstruire des situations sans se sentir démunie face à une culture toxique. N’hésitez pas à rejoindre l’un des collectifs&nbsp;listés.</p>
  258. <p>Je peux faire le <em>parrain-à-6000km</em>, mon adresse de courriel est en pied de&nbsp;page.</p>
  259. <p><mark>@nnotation(intention)</mark>&nbsp;: Je précise la distance depuis la France car ça réduit les possibilités d’agressions physiques… et malheureusement c’est non&nbsp;négligeable.&nbsp;😢</p>
  260. <blockquote>
  261. <p>La technique de l’amplification, popularisée à la Maison Blanche à l’époque d’Obama, consiste à répéter l’idée en lui reconnaissant la maternité, ce qui permet d’augmenter son audibilité. Sachez aussi que nous n’apprenons pas à nous exprimer de la même façon selon notre genre. Quand les femmes prennent la parole, elles l’encombrent plus souvent de termes parasites minimisant comme <em>“peut-être”</em>, <em>“je pense que”</em>, <em>“c’est juste mon avis”</em>. <mark>Les femmes enrobent plus leurs propos, ce qui peut limiter sa portée et/ou nuire à sa clarté, et surtout minimiser des propos pas moins importants.</mark> Elles s’excusent aussi plus souvent de déranger (à tort). À l’écrit, ce sont les points d’exclamation et les smileys qui sont sur représentés, pour adoucir le ton et paraître sympathique. Dans tous les cas, ces parasites réduisent l’impact des messages exprimés. En gros, il vaut mieux faire court pour limiter la charge cognitive et répéter plusieurs fois le&nbsp;message…</p>
  262. <p><cite><em>Ibid.</em></cite></p>
  263. </blockquote>
  264. <p>… ou que les personnes à l’écoute apprennent à communiquer de cette façon&#8239;? À donner le temps nécessaire à la prise de soin plutôt que de formater d’autres personnes à ce qui peut être interprété comme de l’«&nbsp;efficacité&nbsp;» analytique (telle que définie par des hommes)&#8239;? L’adaptation peut et doit se faire dans les deux&nbsp;sens.</p>
  265. <p><mark>@nnotation(légitimité)</mark>&nbsp;: Je propose cela alors qu’il y a 6&nbsp;femmes sur les 8&nbsp;membres de Scopyleft, à la création nous étions 4&nbsp;hommes. Le changement dans nos interactions a été&nbsp;radical.</p>
  266. <nav>
  267. <p>
  268. <a href="/david/2024/echanges/"
  269. title="Liste de tous les articles 2024 associés à cette étiquette"
  270. rel="tag">#échanges</a>
  271. <a href="/david/2024/experience/"
  272. title="Liste de tous les articles 2024 associés à cette étiquette"
  273. rel="tag">#expérience</a>
  274. <a href="/david/2024/gratitude/"
  275. title="Liste de tous les articles 2024 associés à cette étiquette"
  276. rel="tag">#gratitude</a>
  277. <a href="/david/2024/#tags" title="Liste de toutes les étiquettes 2024">tous ?</a>
  278. </p>
  279. </nav>
  280. <nav>
  281. <p>
  282. <a rel="prev"
  283. href="/david/2024/01/21/"
  284. title="Publication précédente : Bois">← Précédent</a> •
  285. <a href="/david/2024/" title="Liste des publications récentes">↑ En 2024</a>
  286. • <a rel="next"
  287. href="/david/2024/01/23/"
  288. title="Publication suivante : Thèse">Suivant →</a>
  289. </p>
  290. </nav>
  291. <form action="/david/recherche/" method="get">
  292. <fieldset>
  293. <legend>Recherche</legend>
  294. <label for="input-search">Termes de votre recherche :</label>
  295. <input id="input-search" type="search" name="s" aria-describedby="indexation-infos" required>
  296. <input type="submit" value="Chercher">
  297. <p id="indexation-infos">
  298. <small>
  299. Seuls les contenus de ces 8 dernières années sont indexés.
  300. </small>
  301. </p>
  302. </fieldset>
  303. </form>
  304. <aside>
  305. <theme-toggle></theme-toggle>
  306. </aside>
  307. </article>
  308. <hr>
  309. <footer>
  310. <p>
  311. <a href="/david/" title="Aller à l’accueil">Accueil</a>
  312. <a href="/david/log/" title="Accès au flux RSS">Suivre</a>
  313. <a href="http://larlet.com"
  314. title="Go to my English profile"
  315. data-instant>Pro</a>
  316. <a href="mailto:david%40larlet.fr" title="Envoyer un courriel">Email</a>
  317. <abbr title="Hébergeur : Alwaysdata, 62 rue Tiquetonne 75002 Paris, +33184162340">Légal</abbr>
  318. </p>
  319. <template id="theme-selector">
  320. <form>
  321. <style type="text/css">
  322. fieldset div {
  323. text-align: center;
  324. }
  325. </style>
  326. <fieldset>
  327. <legend>Thème</legend>
  328. <div>
  329. <label>
  330. <input type="radio" value="auto" name="chosen-color-scheme" checked>
  331. Auto
  332. </label>
  333. <label>
  334. <input type="radio" value="dark" name="chosen-color-scheme">
  335. Foncé
  336. </label>
  337. <label>
  338. <input type="radio" value="light" name="chosen-color-scheme">
  339. Clair
  340. </label>
  341. </div>
  342. </fieldset>
  343. </form>
  344. </template>
  345. </footer>
  346. <script src="/static/david/js/instantpage-5.1.0.min.js" type="module"></script>
  347. <script>
  348. class ThemeToggle extends HTMLElement {
  349. constructor() {
  350. super()
  351. const themeSelectorTemplate = document.querySelector('#theme-selector')
  352. const form = themeSelectorTemplate.content.firstElementChild
  353. this.attachShadow({ mode: 'open' })
  354. this.shadowRoot.appendChild(form.cloneNode(true))
  355. }
  356. connectedCallback() {
  357. const form = this.shadowRoot.querySelector('form')
  358. form.addEventListener('change', (e) => {
  359. const chosenColorScheme = e.target.value
  360. localStorage.setItem('theme', chosenColorScheme)
  361. toggleTheme(chosenColorScheme)
  362. })
  363. const selectedTheme = localStorage.getItem('theme')
  364. if (selectedTheme && selectedTheme !== 'undefined') {
  365. form.querySelector(`[value="${selectedTheme}"]`).checked = true
  366. }
  367. }
  368. }
  369. const prefersColorSchemeDark = '(prefers-color-scheme: dark)'
  370. window.addEventListener('load', () => {
  371. let colorsLayer = undefined
  372. let hasDarkRules = false
  373. for (const styleSheet of Array.from(document.styleSheets)) {
  374. let mediaRules = []
  375. for (const layerRule of styleSheet.cssRules) {
  376. if (!(layerRule instanceof CSSLayerBlockRule)) {
  377. continue
  378. }
  379. if (layerRule.name === 'colors') {
  380. colorsLayer = layerRule
  381. }
  382. for (const cssRule of layerRule.cssRules) {
  383. if (cssRule.type !== CSSRule.MEDIA_RULE) {
  384. continue
  385. }
  386. // WARNING: Safari does not have/supports `conditionText`.
  387. if (cssRule.conditionText) {
  388. if (cssRule.conditionText !== prefersColorSchemeDark) {
  389. continue
  390. }
  391. } else {
  392. if (cssRule.cssText.startsWith(prefersColorSchemeDark)) {
  393. continue
  394. }
  395. }
  396. mediaRules = mediaRules.concat(Array.from(cssRule.cssRules))
  397. }
  398. }
  399. // WARNING: do not try to insert a Rule to a styleSheet you are
  400. // currently iterating on, otherwise the browser will be stuck
  401. // in a infinite loop…
  402. for (const mediaRule of mediaRules) {
  403. // Safari requires the `0` second parameter (even if default).
  404. colorsLayer.insertRule(mediaRule.cssText, 0)
  405. hasDarkRules = true
  406. }
  407. }
  408. if (hasDarkRules) {
  409. if ('customElements' in window && !customElements.get('theme-toggle')) {
  410. customElements.define('theme-toggle', ThemeToggle)
  411. }
  412. }
  413. })
  414. </script>
  415. <script src="/static/david/js/popper-2.11.8.min.js"></script>
  416. <script src="/static/david/js/tippy-bundle-6.3.7.umd.min.js"></script>
  417. <script>
  418. tippy('[data-tippy]', {
  419. content(reference) {
  420. reference.addEventListener('click', (e) => e.preventDefault())
  421. return `
  422. <h3 lang="fr">
  423. <img src="${reference.dataset.favicon}" loading="lazy">
  424. <a href="${reference.dataset.source}"
  425. >Article sur ${reference.dataset.domain}</a></h3>
  426. <p lang="${reference.hreflang}"><em>${reference.dataset.description}</em></p>
  427. <div class="tippy-links" lang="fr">
  428. <a href="${reference.href}">Archive au ${reference.dataset.date}</a>
  429. </div>
  430. `
  431. },
  432. allowHTML: true,
  433. interactive: true,
  434. delay: [150, 700],
  435. hideOnClick: false
  436. })
  437. </script>
  438. <script type="module">
  439. import { annotate } from '/static/david/js/rough-notation-0.5.1.esm.min.js'
  440. const markObserver = new IntersectionObserver((entries, observer) => {
  441. const computedStyle = getComputedStyle(document.documentElement)
  442. const markBackground = computedStyle.getPropertyValue('--mark-background')
  443. for (const entry of entries) {
  444. if (entry.intersectionRatio === 0) continue
  445. const markElement = entry.target
  446. markElement.style.backgroundColor = 'inherit'
  447. const annotation = annotate(
  448. markElement, {
  449. type: 'highlight',
  450. multiline: true,
  451. color: markBackground,
  452. // animate: !window.matchMedia('(prefers-reduced-motion: reduce)').matches
  453. animate: false
  454. }
  455. )
  456. annotation.show()
  457. observer.unobserve(markElement)
  458. }
  459. }, {threshold: 1.0})
  460. for (const markElement of document.querySelectorAll('mark')) {
  461. markObserver.observe(markElement)
  462. }
  463. </script>
  464. </body>
  465. </html>