feat(sterni/nix/html): make <html> also emit doctype
This makes the awkward withDoctype utility obsolete which is much nicer.
Technically, this is a BREAKING CHANGE since it was possible to create
valid documents without an <html> tag before:
withDoctype (lib.concatStrings [ (<head> { } …) (<body> { } …) ])
I don't think this usecase is worth preserving since this can just be
written as
<html> { } [ (<head> { } …) (<body> { } …) ]
and omitting the <html> tag is not recommended since it should be used
to set the language of the document (which we didn't in the example
above).
Change-Id: Idc5104ce88fe8bee965c076229b79387915c3605
Reviewed-on: https://cl.tvl.fyi/c/depot/+/12907
Autosubmit: sterni <sternenseemann@systemli.org>
Reviewed-by: sterni <sternenseemann@systemli.org>
Tested-by: BuildkiteCI
Reviewed-by: tazjin <tazjin@tvl.su>
This commit is contained in:
parent
9fa198f9ae
commit
d47c7fa12b
5 changed files with 20 additions and 24 deletions
|
|
@ -1,4 +1,4 @@
|
|||
# Copyright © 2021 sterni
|
||||
# SPDX-FileCopyrightText: Copyright © 2021, 2024 sterni
|
||||
# SPDX-License-Identifier: MIT
|
||||
#
|
||||
# This file provides a cursed HTML DSL for nix which works by overloading
|
||||
|
|
@ -58,6 +58,9 @@ let
|
|||
calls, we can't escape it automatically. Instead this must be done manually
|
||||
using `esc`.
|
||||
|
||||
If the tag is "html", e.g. in case of `<html> { } …`, "<!DOCTYPE html> will
|
||||
be prepended to the normal rendering of the text.
|
||||
|
||||
Type: string -> attrs<string> -> (list<string> | string | null) -> string
|
||||
|
||||
Example:
|
||||
|
|
@ -98,20 +101,16 @@ let
|
|||
then builtins.concatStringsSep "" (flatten content)
|
||||
else content;
|
||||
in
|
||||
if content == null
|
||||
(if tag == "html" then "<!DOCTYPE html>" else "") +
|
||||
(if content == null
|
||||
then "<${tag}${attrs'}/>"
|
||||
else "<${tag}${attrs'}>${content'}</${tag}>";
|
||||
else "<${tag}${attrs'}>${content'}</${tag}>");
|
||||
|
||||
/* Prepend "<!DOCTYPE html>" to a string.
|
||||
|
||||
Type: string -> string
|
||||
|
||||
Example:
|
||||
|
||||
withDoctype (<body> {} (esc "hello"))
|
||||
=> "<!DOCTYPE html><body>hello</body>"
|
||||
/* Deprecated, does nothing.
|
||||
*/
|
||||
withDoctype = doc: "<!DOCTYPE html>" + doc;
|
||||
withDoctype = doc: builtins.trace
|
||||
"WARN: withDoctype no longer does anything, `<html> { } [ … ]` takes care of rendering <!DOCTYPE html>"
|
||||
doc;
|
||||
|
||||
/* Taken from <nixpkgs/lib/lists.nix>. */
|
||||
flatten = x:
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue