diff --git a/blocks_fonctions.php b/blocks_fonctions.php index a30659d5444d35ce0059edbfa464f73b68122dce..500b5bd73bf35ff86c0e6b9e54454802bacd5a2e 100644 --- a/blocks_fonctions.php +++ b/blocks_fonctions.php @@ -500,3 +500,22 @@ function bloctypes_trouver_role($blocktype, $role): array { return []; } + +/** + * Génére la liste des objets (du type `article`) utilisable dans une saisie + * + * @return array + */ +function blocks_objets_config() { + include_spip('base/objets'); + $data = []; + if($objets = array_filter(lire_config('blocks/objets'))) { + foreach ($objets as $objet) { + $objet_type = objet_type($objet); + $infos = objet_info($objet_type,'texte_objet'); + $data[$objet_type] = _T($infos); + } + asort($data); + } + return $data; +} diff --git a/formulaires/editer_block.html b/formulaires/editer_block.html index 72b7166a906d9ea1af19c51b077f4c46e49297f2..933eeffa453ae62cd4bf278c54a101216d636d9f 100644 --- a/formulaires/editer_block.html +++ b/formulaires/editer_block.html @@ -13,6 +13,14 @@ <button type="submit" class="visually-hidden" aria-hidden="true" name="ajouter" value="1">[(#ENV{id_block}|?{<:block:bouton_enregistrer:/>,<:block:bouton_ajouter:/>})]</button> ] + [(#ENV{include}|non) + <div class="editer-groupe"> + <fieldset> + <legend><:block:info_objet_lie:/></legend> + [(#SAISIE{selection, objet, label=<:block:info_type_objet_lie:/>, data=#REM|blocks_objets_config})] + [(#SAISIE{input, id_objet, label=<:block:info_id_objet_lie:/> })] + </fieldset> + ] [(#ENV{include}|oui) <div class="objetblock__header [(#ENV{id_block}|non)collapsed]"> [(#ENV{id_block}|non) @@ -45,6 +53,10 @@ </div> ] + [(#ENV{include}|non) + </div> + ] + <div [(#ENV{id_block}|non) id="contentblocknew" role="region" aria-labelledby="titleblocknew-#OBJET-#ID_OBJET"] [(#ENV{deplie_block}|non) hidden ]> <div class="editer-groupe"> #GENERER_SAISIES{#ENV{_saisies}} diff --git a/lang/block_fr.php b/lang/block_fr.php index f226321c89dbffec1ee9b5c6732b129d502475fb..26c04901ce07be929429df9f4c5ddfe9865ef50d 100644 --- a/lang/block_fr.php +++ b/lang/block_fr.php @@ -35,9 +35,8 @@ return [ 'info_blocks_auteur' => 'Les blocs de cet auteur', 'info_nb_blocks' => '@nb@ blocs', 'info_objet_lie' => 'Objet lié', - - // O - 'objet_lie' => 'Objet lié', + 'info_type_objet_lie' => 'Type', + 'info_id_objet_lie' => 'N°', // R 'retirer_lien_block' => 'Retirer ce bloc',