field-details.blade.php 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. @php
  2. $hasChildren ??= false;
  3. $isArrayBody = $name == "[]";
  4. $expandable = $hasChildren && !$isArrayBody;
  5. @endphp
  6. <div class="sl-flex sl-relative sl-max-w-full sl-py-2 sl-pl-3">
  7. <div class="sl-w-1 sl-mt-2 sl-mr-3 sl--ml-3 sl-border-t"></div>
  8. <div class="sl-stack sl-stack--vertical sl-stack--1 sl-flex sl-flex-1 sl-flex-col sl-items-stretch sl-max-w-full sl-ml-2 @if($expandable) sl-cursor-pointer @endif">
  9. <div class="sl-flex sl-items-center sl-max-w-full">
  10. @if($expandable)
  11. <div class="sl-flex sl-justify-center sl-w-8 sl--ml-8 sl-pl-3 sl-text-muted expansion-chevrons" role="button">
  12. <svg aria-hidden="true" focusable="false" data-prefix="fas" data-icon="chevron-right"
  13. class="svg-inline--fa fa-chevron-right fa-fw fa-sm sl-icon" role="img"
  14. xmlns="http://www.w3.org/2000/svg" viewBox="0 0 320 512">
  15. <path fill="currentColor"
  16. d="M96 480c-8.188 0-16.38-3.125-22.62-9.375c-12.5-12.5-12.5-32.75 0-45.25L242.8 256L73.38 86.63c-12.5-12.5-12.5-32.75 0-45.25s32.75-12.5 45.25 0l192 192c12.5 12.5 12.5 32.75 0 45.25l-192 192C112.4 476.9 104.2 480 96 480z"></path>
  17. </svg>
  18. </div>
  19. @endif
  20. @unless($isArrayBody)
  21. <div class="sl-flex sl-items-baseline sl-text-base">
  22. <div class="sl-font-mono sl-font-semibold sl-mr-2">{{ $name }}</div>
  23. @if($type)
  24. <span class="sl-truncate sl-text-muted">{{ $type }}</span>
  25. @endif
  26. </div>
  27. @if($required)
  28. <div class="sl-flex-1 sl-h-px sl-mx-3"></div>
  29. <span class="sl-ml-2 sl-text-warning">required</span>
  30. @endif
  31. @endunless
  32. </div>
  33. @if($description)
  34. <div class="sl-prose sl-markdown-viewer" style="font-size: 12px;">
  35. {!! Parsedown::instance()->text($description) !!}
  36. </div>
  37. @endif
  38. @if(!empty($enumValues))
  39. Must be one of:
  40. <ul style="list-style-position: inside; list-style-type: square;">{!! implode(" ", array_map(fn($val) => "<li><code>$val</code></li>", $enumValues)) !!}</ul>
  41. @endif
  42. @if($isArrayBody)
  43. <div class="sl-flex sl-items-baseline sl-text-base">
  44. <div class="sl-font-mono sl-font-semibold sl-mr-2">array of:</div>
  45. @if($required)
  46. <div class="sl-flex-1 sl-h-px sl-mx-3"></div>
  47. <span class="sl-ml-2 sl-text-warning">required</span>
  48. @endif
  49. </div>
  50. @endif
  51. @if(!$hasChildren && !is_null($example) && $example !== '')
  52. <div class="sl-stack sl-stack--horizontal sl-stack--2 sl-flex sl-flex-row sl-items-baseline sl-text-muted">
  53. <span>Example:</span> <!-- <span> important for spacing -->
  54. <div class="sl-flex sl-flex-1 sl-flex-wrap" style="gap: 4px;">
  55. <div class="sl-max-w-full sl-break-all sl-px-1 sl-bg-canvas-tint sl-text-muted sl-rounded sl-border">
  56. {{ is_array($example) || is_bool($example) ? json_encode($example) : $example }}
  57. </div>
  58. </div>
  59. </div>
  60. @endif
  61. </div>
  62. </div>