You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

gitea-ui.tmpl 7.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. {{template "base/head" .}}
  2. <link rel="stylesheet" href="{{AssetUrlPrefix}}/css/devtest.css?v={{AssetVersion}}">
  3. <div class="page-content devtest ui container">
  4. <div>
  5. <h1>Link</h1>
  6. <div>
  7. <a href="#">normal</a>
  8. <a class="muted" href="#">muted</a>
  9. <a class="suppressed" href="#">suppressed</a>
  10. <a class="silenced" href="#">silenced</a>
  11. </div>
  12. <h1>Button</h1>
  13. <div>
  14. Style:
  15. <label><input type="checkbox" name="button-style-compact" value="compact">compact</label>
  16. <label><input type="radio" name="button-style-size" value="">(normal)</label>
  17. <label><input type="radio" name="button-style-size" value="tiny">tiny</label>
  18. <label><input type="radio" name="button-style-size" value="mini">mini</label>
  19. </div>
  20. <div>
  21. State:
  22. <label><input type="checkbox" name="button-state-disabled" value="disabled">disabled</label>
  23. </div>
  24. <div id="devtest-button-samples">
  25. <ul class="button-sample-groups">
  26. <li class="sample-group">
  27. <h2>General purpose:</h2>
  28. <button class="ui button">Unclassed</button>
  29. <button class="ui basic button">Basic Unclassed</button>
  30. <button class="ui primary button">Primary</button>
  31. <button class="ui basic primary button">Basic Primary</button>
  32. </li>
  33. <li class="sample-group">
  34. <h2>Recommended colors:</h2>
  35. <button class="ui red button">Red</button>
  36. <button class="ui basic red button">Basic Red</button>
  37. <button class="ui green button">Green</button>
  38. <button class="ui basic green button">Basic Green</button>
  39. </li>
  40. <li class="sample-group">
  41. <h2>Inline / Plain:</h2>
  42. <div class="tw-my-1">
  43. <button class="btn tw-p-2">Plain button</button>
  44. <button class="btn interact-fg tw-p-2">Plain button with interact fg</button>
  45. <button class="btn interact-bg tw-p-2">Plain button with interact bg</button>
  46. </div>
  47. </li>
  48. </ul>
  49. <script type="module">
  50. const $buttons = $('#devtest-button-samples').find('button.ui');
  51. const $buttonStyles = $('input[name*="button-style"]');
  52. $buttonStyles.on('click', () => $buttonStyles.map((_ ,el) => $buttons.toggleClass(el.value, el.checked)));
  53. const $buttonStates = $('input[name*="button-state"]');
  54. $buttonStates.on('click', () => $buttonStates.map((_ ,el) => $buttons.prop(el.value, el.checked)));
  55. </script>
  56. </div>
  57. </div>
  58. <div>
  59. <h1>Buttons</h1>
  60. <div class="ui buttons"><button class="ui button">1</button><button class="ui button">2</button><button class="ui button">3</button></div>
  61. <div class="ui buttons"><button class="ui button active">1</button><button class="ui button">2</button><button class="ui button">3</button></div>
  62. <div class="ui buttons"><button class="ui button">1</button><button class="ui button active">2</button><button class="ui button">3</button></div>
  63. <div class="ui buttons"><button class="ui button">1</button><button class="ui button">2</button><button class="ui button active">3</button></div>
  64. </div>
  65. <div>
  66. <h1>Tooltip</h1>
  67. <div><span data-tooltip-content="test tooltip">text with tooltip</span></div>
  68. <div><span data-tooltip-content="test tooltip" data-tooltip-interactive="true">text with interactive tooltip</span></div>
  69. </div>
  70. <div>
  71. <h1>Loading</h1>
  72. <div class="is-loading loading-icon-2px tw-border tw-border-secondary tw-py-1"><span>loading ...</span></div>
  73. <div class="is-loading tw-border tw-border-secondary tw-py-4">
  74. <p>loading ...</p>
  75. <p>loading ...</p>
  76. <p>loading ...</p>
  77. <p>loading ...</p>
  78. </div>
  79. </div>
  80. <div>
  81. <h1>&lt;origin-url&gt;</h1>
  82. <div><origin-url data-url="test/url"></origin-url></div>
  83. <div><origin-url data-url="/test/url"></origin-url></div>
  84. </div>
  85. <div>
  86. <h1>&lt;overflow-menu&gt;</h1>
  87. <overflow-menu class="ui secondary pointing tabular borderless menu">
  88. <div class="overflow-menu-items">
  89. <a class="active item">item</a>
  90. <a class="item">item 1</a>
  91. <a class="item">item 2</a>
  92. <a class="item">item 3</a>
  93. <a class="item">item 4</a>
  94. <a class="item">item 5</a>
  95. <a class="item">item 6</a>
  96. <a class="item">item 7</a>
  97. <a class="item">item 8</a>
  98. <a class="item">item 9</a>
  99. <a class="item">item 10</a>
  100. <a class="item">item 11</a>
  101. <a class="item">item 12</a>
  102. <a class="item">item 13</a>
  103. <a class="item">item 14</a>
  104. <a class="item">item 15</a>
  105. <a class="item">item 16</a>
  106. <a class="item">item 17</a>
  107. <a class="item">item 18</a>
  108. </div>
  109. </overflow-menu>
  110. </div>
  111. <div>
  112. <h1>GiteaAbsoluteDate</h1>
  113. <div><absolute-date date="2024-03-11" year="numeric" day="numeric" month="short"></absolute-date></div>
  114. <div><absolute-date date="2024-03-11" year="numeric" day="numeric" month="long"></absolute-date></div>
  115. <div><absolute-date date="2024-03-11" year="" day="numeric" month="numeric"></absolute-date></div>
  116. <div><absolute-date date="2024-03-11" year="" day="numeric" month="numeric" weekday="long"></absolute-date></div>
  117. <div><absolute-date date="2024-03-11T19:00:00-05:00" year="" day="numeric" month="numeric" weekday="long"></absolute-date></div>
  118. <div class="tw-text-text-light-2">relative-time: <relative-time format="datetime" datetime="2024-03-11" year="" day="numeric" month="numeric"></relative-time></div>
  119. </div>
  120. <div>
  121. <h1>LocaleNumber</h1>
  122. <div>{{ctx.Locale.PrettyNumber 1}}</div>
  123. <div>{{ctx.Locale.PrettyNumber 12}}</div>
  124. <div>{{ctx.Locale.PrettyNumber 123}}</div>
  125. <div>{{ctx.Locale.PrettyNumber 1234}}</div>
  126. <div>{{ctx.Locale.PrettyNumber 12345}}</div>
  127. <div>{{ctx.Locale.PrettyNumber 123456}}</div>
  128. <div>{{ctx.Locale.PrettyNumber 1234567}}</div>
  129. </div>
  130. <div>
  131. <h1>TimeSince</h1>
  132. <div>Now: {{TimeSince .TimeNow ctx.Locale}}</div>
  133. <div>5s past: {{TimeSince .TimePast5s ctx.Locale}}</div>
  134. <div>5s future: {{TimeSince .TimeFuture5s ctx.Locale}}</div>
  135. <div>2m past: {{TimeSince .TimePast2m ctx.Locale}}</div>
  136. <div>2m future: {{TimeSince .TimeFuture2m ctx.Locale}}</div>
  137. <div>1y past: {{TimeSince .TimePast1y ctx.Locale}}</div>
  138. <div>1y future: {{TimeSince .TimeFuture1y ctx.Locale}}</div>
  139. </div>
  140. <div>
  141. <h1>SVG alignment</h1>
  142. <h2>Text with SVG</h2>
  143. <div class="flex-text-block">{{svg "octicon-alert"}} {{svg "octicon-x"}} text (block)</div>
  144. <div><div class="flex-text-inline">{{svg "octicon-alert"}} {{svg "octicon-x"}} text</div> (inline)</div>
  145. <div class="flex-text-block">{{svg "octicon-alert"}} flex item with very very very very very very very very long content</div>
  146. <div class="flex-items-block">
  147. <div class="item">{{svg "octicon-alert"}} flex every line</div>
  148. <div class="item">{{svg "octicon-alert"}} flex every item</div>
  149. <div class="item">{{svg "octicon-alert"}} flex item with very very very very very very very very long content</div>
  150. </div>
  151. <h2>Button with SVG</h2>
  152. <div>
  153. <button class="ui red button">{{svg "octicon-alert" 24}} {{svg "octicon-x" 24}} text</button>
  154. <div class="ui labeled button">
  155. <button class="ui basic button">labeled button</button>
  156. <a class="ui basic label">123</a>
  157. </div>
  158. <button class="ui button">{{svg "octicon-x" 16}} button with very very very very very very very very long text</button>
  159. </div>
  160. <h2>Input with SVG</h2>
  161. <div>
  162. <div class="ui icon search input">
  163. <i class="icon">{{svg "octicon-search"}}</i>
  164. <input type="text" placeholder="place holder">
  165. </div>
  166. </div>
  167. </div>
  168. <div>
  169. <h1>Toast</h1>
  170. <div>
  171. <button class="ui button" id="info-toast">Show Info Toast</button>
  172. <button class="ui button" id="warning-toast">Show Warning Toast</button>
  173. <button class="ui button" id="error-toast">Show Error Toast</button>
  174. </div>
  175. </div>
  176. <div>
  177. <h1>ComboMarkdownEditor</h1>
  178. <div>ps: no JS code attached, so just a layout</div>
  179. {{template "shared/combomarkdowneditor" .}}
  180. </div>
  181. <h1>Tailwind CSS Demo</h1>
  182. <div>
  183. <button class="{{if true}}tw-bg-red{{end}} tw-p-5 tw-border tw-rounded hover:tw-bg-blue active:tw-bg-yellow">Button</button>
  184. </div>
  185. <script src="{{AssetUrlPrefix}}/js/devtest.js?v={{AssetVersion}}"></script>
  186. </div>
  187. {{template "base/footer" .}}