Biblioteca de queriesInsertar un bloque en todos los posts
Insertar un bloque en todos los posts
Esta consulta identifica el enésimo bloque de un tipo dado ("wp:paragraph" por defecto) en todos los posts, y coloca el contenido HTML del bloque personalizado proporcionado justo después de él.
La variable $injectBlockMarkup debe recibir el marcado HTML completo para el bloque (con las comillas escapadas para la entrada JSON). Por ejemplo:
<!-- mycompany:black-friday-campaign-video --><figure class=\"wp-block-video\"><video controls src=\"https://mysite.com/videos/BlackFriday2023.mp4\"></video></figure><!-- /mycompany:black-friday-campaign-video -->Esta consulta requiere que el endpoint tenga habilitadas las Mutaciones Anidadas.
query CreateRegex(
$searchBlockType: String! = "wp:paragraph"
$injectAfterBlockCount: Int = 1
$injectBlockMarkup: String!
) {
endingBlockMarkup: _sprintf(
string: "<!-- /%s -->",
values: [$searchBlockType]
)
@remove
endingBlockMarkupArray: _arrayPad(
array: [],
length: $injectAfterBlockCount,
value: $__endingBlockMarkup
)
@remove
regexString: _arrayJoin(
array: $__endingBlockMarkupArray,
separator: "[\\s\\S]+"
)
@remove
regex: _sprintf(
string: "#(%s)#U",
values: [$__regexString]
)
@export(as: "regex")
@remove
replaceWith: _sprintf(
string: "$1%s",
values: [$injectBlockMarkup]
)
@export(as: "replaceWith")
@remove
}
mutation InsertBlockInAllPosts
@depends(on: "CreateRegex")
{
posts: posts(
pagination: { limit: -1 }
) {
id
rawContent
adaptedRawContent: _strRegexReplace(
in: $__rawContent,
searchRegex: $regex,
replaceWith: $replaceWith,
limit: 1
)
update(input: {
contentAs: { html: $__adaptedRawContent },
}) {
status
errors {
__typename
...on ErrorPayload {
message
}
}
post {
id
rawContent
}
}
}
}