Readme.class.php 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. <?php
  2. class Readme {
  3. public static function manifest(){
  4. return array(
  5. 'uid' => 'readme',
  6. 'label' => 'README',
  7. 'description' => 'Fichier texte de type "lisez moi", utilise du markdown pour la mise en forme',
  8. 'fromExtension' => array('md'),
  9. 'toExtension' => 'md'
  10. );
  11. }
  12. //Import depuis un glisser déposé du fichier
  13. public static function fromFile($resource,$sketch){
  14. $enc = mb_detect_encoding($resource->content,"UTF-8, ISO-8859-1, GBK");
  15. if($enc!='UTF-8')
  16. $resource->content = iconv($enc,"utf-8",$resource->content);
  17. return $resource;
  18. }
  19. //Import depuis un flux json compressé de la ressource
  20. public static function fromJson($resource){
  21. return $resource;
  22. }
  23. //export en fichier JSON compressé de la ressource
  24. public static function toJson($resource){
  25. $resource = $resource->toArray();
  26. $resource['content'] = htmlspecialchars($resource['content']);
  27. return $resource;
  28. }
  29. public static function toFile($resource){
  30. $infos = self::manifest();
  31. return array(
  32. 'name'=> slugify($resource->label).'.'.$infos['toExtension'],
  33. 'content' => html_entity_decode($resource->content)
  34. );
  35. }
  36. public static function toHtml($resource,$sketch){
  37. $infos = self::manifest();
  38. return array(
  39. 'content'=>'<textarea>'.$resource->content.'</textarea>',
  40. 'codemirror' => array(
  41. 'mode'=>'markdown',
  42. //'theme'=>'monokai',
  43. 'lineNumbers' => true,
  44. 'readOnly' => false
  45. )
  46. );
  47. }
  48. }
  49. ?>