Date de création

Un plugin qui ajoute une date de création sur tous les objets éditoriaux.

Ce plugin répond au besoin exprimé dans ce ticket : https://core.spip.net/issues/2173

A l’installation, il crée automatiquement un champ « date_creation » sur toutes les tables d’objets éditoriaux, si ce champ n’existe pas déjà, sur les objets natifs de SPIP (articles, auteurs, rubriques...) comme sur les objets créés par des plugins.

En cas de création d’un nouvel objet (lors de l’installation d’un nouveau plugin), ce champ y sera également ajouté.

La date de création est renseignée automatiquement à la création d’un nouvel objet, depuis le pipeline post_insertion().
Elle n’est ensuite plus modifiée.

La date de création est affichée sur la page de chaque objet dans l’espace privé.

Utilisation dans les squelettes

Pour chaque boucle sur un objet éditorial, on peut donc utiliser :

  • le critère {par date_creation} pour classer les objets par date de création,
  • la balise #DATE_CREATION pour afficher cette date.

Astuce : quand vous installez ce plugin sur votre site, les objets existants n’auront pas de date de création. Concrètement elle sera égale à ’0000-00-00 00:00:00’ dans la base de données.

La balise [(#DATE_CREATION|affdate)] afficherait alors : 0000.

Pour tester si une valeur de date est bien présente, et ne l’afficher que dans ce cas, vous pouvez tester la valeur de #DATE_CREATION|intval, qui doit retourner autre chose que 0 si une date est présente [1].

Exemple :

[(#DATE_CREATION|intval|oui) 
  [<:date_creation:date_creation:> (#DATE_CREATION|affdate)]
]

Cette astuce est valable pour tous les champs de date dans les squelettes.

Configuration

Quelques constantes peuvent être définies pour masquer les dates de création dans l’espace privé, si vous ne souhaitez pas les voir apparaître :

_MASQUER_DATE_CREATION pour les masquer partout,
_MASQUER_DATE_CREATION_NULLE pour masquer les dates non renseignées,
_MASQUER_DATE_CREATION_BIDULE pour les masquer sur les objets bidules.

Notes

[1Ce n’est pas tout à fait exact pour l’année 0, mais on ne vas pas chipoter :).

Discussion

2 discussions

  • Super ! Bravo pour ce plugin.

    A vocation pédagogique aussi, pour comprendre comment installer des champs automatiquement sur divers objets !

    Répondre à ce message

  • 1

    Sur la date à 0 sur les contenus déjà existant, est-ce qu’il n’aurait pas été possible de mettre la date d’installation du plugin ?
    Quelque chose comme : valeur par défaut = date courante

    Ça semblerait plus cohérent, et surtout, ça éviterait d’avoir à faire un test dans les squelettes.

    • Possible oui bien sûr, mais cohérent non.
      Ça ne me parait pas cohérent de mettre une date de création arbitraire à un contenu existant, ça n’aurait pas de sens, l’information ne serait pas « vraie ».

      Essayons d’éviter les fakenews par les temps qui courent :D

    Répondre à ce message

Ajouter un commentaire

Qui êtes-vous ?

Pour afficher votre trombine avec votre message, enregistrez-la d’abord sur gravatar.com (gratuit et indolore) et n’oubliez pas d’indiquer votre adresse e-mail ici.

Ajoutez votre commentaire ici

Ce champ accepte les raccourcis SPIP {{gras}} {italique} -*liste [texte->url] <quote> <code> et le code HTML <q> <del> <ins>. Pour créer des paragraphes, laissez simplement des lignes vides.

Ajouter un document

Suivre les commentaires : RSS 2.0 | Atom

Dernière modification de cette page le 15 janvier 2018