SettingsModal.svelte 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. <script>
  2. import { getContext } from 'svelte';
  3. import Modal from '../common/Modal.svelte';
  4. import General from './Settings/General.svelte';
  5. import ChunkParams from './Settings/ChunkParams.svelte';
  6. import QueryParams from './Settings/QueryParams.svelte';
  7. import WebParams from './Settings/WebParams.svelte';
  8. import { toast } from 'svelte-sonner';
  9. const i18n = getContext('i18n');
  10. export let show = false;
  11. let selectedTab = 'general';
  12. </script>
  13. <Modal bind:show>
  14. <div>
  15. <div class=" flex justify-between dark:text-gray-300 px-5 pt-4">
  16. <div class=" text-lg font-medium self-center">{$i18n.t('Document Settings')}</div>
  17. <button
  18. class="self-center"
  19. on:click={() => {
  20. show = false;
  21. }}
  22. >
  23. <svg
  24. xmlns="http://www.w3.org/2000/svg"
  25. viewBox="0 0 20 20"
  26. fill="currentColor"
  27. class="w-5 h-5"
  28. >
  29. <path
  30. d="M6.28 5.22a.75.75 0 00-1.06 1.06L8.94 10l-3.72 3.72a.75.75 0 101.06 1.06L10 11.06l3.72 3.72a.75.75 0 101.06-1.06L11.06 10l3.72-3.72a.75.75 0 00-1.06-1.06L10 8.94 6.28 5.22z"
  31. />
  32. </svg>
  33. </button>
  34. </div>
  35. <div class="flex flex-col md:flex-row w-full p-4 md:space-x-4">
  36. <div
  37. class="tabs flex flex-row overflow-x-auto space-x-1 md:space-x-0 md:space-y-1 md:flex-col flex-1 md:flex-none md:w-40 dark:text-gray-200 text-xs text-left mb-3 md:mb-0"
  38. >
  39. <button
  40. class="px-2.5 py-2.5 min-w-fit rounded-lg flex-1 md:flex-none flex text-right transition {selectedTab ===
  41. 'general'
  42. ? 'bg-gray-200 dark:bg-gray-700'
  43. : ' hover:bg-gray-300 dark:hover:bg-gray-800'}"
  44. on:click={() => {
  45. selectedTab = 'general';
  46. }}
  47. >
  48. <div class=" self-center mr-2">
  49. <svg
  50. xmlns="http://www.w3.org/2000/svg"
  51. viewBox="0 0 16 16"
  52. fill="currentColor"
  53. class="w-4 h-4"
  54. >
  55. <path
  56. fill-rule="evenodd"
  57. d="M6.955 1.45A.5.5 0 0 1 7.452 1h1.096a.5.5 0 0 1 .497.45l.17 1.699c.484.12.94.312 1.356.562l1.321-1.081a.5.5 0 0 1 .67.033l.774.775a.5.5 0 0 1 .034.67l-1.08 1.32c.25.417.44.873.561 1.357l1.699.17a.5.5 0 0 1 .45.497v1.096a.5.5 0 0 1-.45.497l-1.699.17c-.12.484-.312.94-.562 1.356l1.082 1.322a.5.5 0 0 1-.034.67l-.774.774a.5.5 0 0 1-.67.033l-1.322-1.08c-.416.25-.872.44-1.356.561l-.17 1.699a.5.5 0 0 1-.497.45H7.452a.5.5 0 0 1-.497-.45l-.17-1.699a4.973 4.973 0 0 1-1.356-.562L4.108 13.37a.5.5 0 0 1-.67-.033l-.774-.775a.5.5 0 0 1-.034-.67l1.08-1.32a4.971 4.971 0 0 1-.561-1.357l-1.699-.17A.5.5 0 0 1 1 8.548V7.452a.5.5 0 0 1 .45-.497l1.699-.17c.12-.484.312-.94.562-1.356L2.629 4.107a.5.5 0 0 1 .034-.67l.774-.774a.5.5 0 0 1 .67-.033L5.43 3.71a4.97 4.97 0 0 1 1.356-.561l.17-1.699ZM6 8c0 .538.212 1.026.558 1.385l.057.057a2 2 0 0 0 2.828-2.828l-.058-.056A2 2 0 0 0 6 8Z"
  58. clip-rule="evenodd"
  59. />
  60. </svg>
  61. </div>
  62. <div class=" self-center">{$i18n.t('General')}</div>
  63. </button>
  64. <button
  65. class="px-2.5 py-2.5 min-w-fit rounded-lg flex-1 md:flex-none flex text-right transition {selectedTab ===
  66. 'chunk'
  67. ? 'bg-gray-200 dark:bg-gray-700'
  68. : ' hover:bg-gray-300 dark:hover:bg-gray-800'}"
  69. on:click={() => {
  70. selectedTab = 'chunk';
  71. }}
  72. >
  73. <div class=" self-center mr-2">
  74. <svg
  75. xmlns="http://www.w3.org/2000/svg"
  76. viewBox="0 0 24 24"
  77. fill="currentColor"
  78. class="w-4 h-4"
  79. >
  80. <path
  81. fill-rule="evenodd"
  82. d="M5.625 1.5H9a3.75 3.75 0 0 1 3.75 3.75v1.875c0 1.036.84 1.875 1.875 1.875H16.5a3.75 3.75 0 0 1 3.75 3.75v7.875c0 1.035-.84 1.875-1.875 1.875H5.625a1.875 1.875 0 0 1-1.875-1.875V3.375c0-1.036.84-1.875 1.875-1.875ZM12.75 12a.75.75 0 0 0-1.5 0v2.25H9a.75.75 0 0 0 0 1.5h2.25V18a.75.75 0 0 0 1.5 0v-2.25H15a.75.75 0 0 0 0-1.5h-2.25V12Z"
  83. clip-rule="evenodd"
  84. />
  85. <path
  86. d="M14.25 5.25a5.23 5.23 0 0 0-1.279-3.434 9.768 9.768 0 0 1 6.963 6.963A5.23 5.23 0 0 0 16.5 7.5h-1.875a.375.375 0 0 1-.375-.375V5.25Z"
  87. />
  88. </svg>
  89. </div>
  90. <div class=" self-center">{$i18n.t('Chunk Params')}</div>
  91. </button>
  92. <button
  93. class="px-2.5 py-2.5 min-w-fit rounded-lg flex-1 md:flex-none flex text-right transition {selectedTab ===
  94. 'query'
  95. ? 'bg-gray-200 dark:bg-gray-700'
  96. : ' hover:bg-gray-300 dark:hover:bg-gray-800'}"
  97. on:click={() => {
  98. selectedTab = 'query';
  99. }}
  100. >
  101. <div class=" self-center mr-2">
  102. <svg
  103. xmlns="http://www.w3.org/2000/svg"
  104. viewBox="0 0 24 24"
  105. fill="currentColor"
  106. class="w-4 h-4"
  107. >
  108. <path d="M11.625 16.5a1.875 1.875 0 1 0 0-3.75 1.875 1.875 0 0 0 0 3.75Z" />
  109. <path
  110. fill-rule="evenodd"
  111. d="M5.625 1.5H9a3.75 3.75 0 0 1 3.75 3.75v1.875c0 1.036.84 1.875 1.875 1.875H16.5a3.75 3.75 0 0 1 3.75 3.75v7.875c0 1.035-.84 1.875-1.875 1.875H5.625a1.875 1.875 0 0 1-1.875-1.875V3.375c0-1.036.84-1.875 1.875-1.875Zm6 16.5c.66 0 1.277-.19 1.797-.518l1.048 1.048a.75.75 0 0 0 1.06-1.06l-1.047-1.048A3.375 3.375 0 1 0 11.625 18Z"
  112. clip-rule="evenodd"
  113. />
  114. <path
  115. d="M14.25 5.25a5.23 5.23 0 0 0-1.279-3.434 9.768 9.768 0 0 1 6.963 6.963A5.23 5.23 0 0 0 16.5 7.5h-1.875a.375.375 0 0 1-.375-.375V5.25Z"
  116. />
  117. </svg>
  118. </div>
  119. <div class=" self-center">{$i18n.t('Query Params')}</div>
  120. </button>
  121. <button
  122. class="px-2.5 py-2.5 min-w-fit rounded-lg flex-1 md:flex-none flex text-right transition {selectedTab ===
  123. 'web'
  124. ? 'bg-gray-200 dark:bg-gray-700'
  125. : ' hover:bg-gray-300 dark:hover:bg-gray-800'}"
  126. on:click={() => {
  127. selectedTab = 'web';
  128. }}
  129. >
  130. <div class=" self-center mr-2">
  131. <svg
  132. xmlns="http://www.w3.org/2000/svg"
  133. viewBox="0 0 24 24"
  134. fill="currentColor"
  135. class="w-4 h-4"
  136. >
  137. <path
  138. d="M21.721 12.752a9.711 9.711 0 0 0-.945-5.003 12.754 12.754 0 0 1-4.339 2.708 18.991 18.991 0 0 1-.214 4.772 17.165 17.165 0 0 0 5.498-2.477ZM14.634 15.55a17.324 17.324 0 0 0 .332-4.647c-.952.227-1.945.347-2.966.347-1.021 0-2.014-.12-2.966-.347a17.515 17.515 0 0 0 .332 4.647 17.385 17.385 0 0 0 5.268 0ZM9.772 17.119a18.963 18.963 0 0 0 4.456 0A17.182 17.182 0 0 1 12 21.724a17.18 17.18 0 0 1-2.228-4.605ZM7.777 15.23a18.87 18.87 0 0 1-.214-4.774 12.753 12.753 0 0 1-4.34-2.708 9.711 9.711 0 0 0-.944 5.004 17.165 17.165 0 0 0 5.498 2.477ZM21.356 14.752a9.765 9.765 0 0 1-7.478 6.817 18.64 18.64 0 0 0 1.988-4.718 18.627 18.627 0 0 0 5.49-2.098ZM2.644 14.752c1.682.971 3.53 1.688 5.49 2.099a18.64 18.64 0 0 0 1.988 4.718 9.765 9.765 0 0 1-7.478-6.816ZM13.878 2.43a9.755 9.755 0 0 1 6.116 3.986 11.267 11.267 0 0 1-3.746 2.504 18.63 18.63 0 0 0-2.37-6.49ZM12 2.276a17.152 17.152 0 0 1 2.805 7.121c-.897.23-1.837.353-2.805.353-.968 0-1.908-.122-2.805-.353A17.151 17.151 0 0 1 12 2.276ZM10.122 2.43a18.629 18.629 0 0 0-2.37 6.49 11.266 11.266 0 0 1-3.746-2.504 9.754 9.754 0 0 1 6.116-3.985Z"
  139. />
  140. </svg>
  141. </div>
  142. <div class=" self-center">{$i18n.t('Web Params')}</div>
  143. </button>
  144. </div>
  145. <div class="flex-1 md:min-h-[380px]">
  146. {#if selectedTab === 'general'}
  147. <General
  148. saveHandler={() => {
  149. toast.success($i18n.t('Settings saved successfully!'));
  150. }}
  151. />
  152. {:else if selectedTab === 'chunk'}
  153. <ChunkParams
  154. saveHandler={() => {
  155. toast.success($i18n.t('Settings saved successfully!'));
  156. }}
  157. />
  158. {:else if selectedTab === 'query'}
  159. <QueryParams
  160. saveHandler={() => {
  161. toast.success($i18n.t('Settings saved successfully!'));
  162. }}
  163. />
  164. {:else if selectedTab === 'web'}
  165. <WebParams
  166. saveHandler={() => {
  167. toast.success($i18n.t('Settings saved successfully!'));
  168. }}
  169. />
  170. {/if}
  171. </div>
  172. </div>
  173. </div>
  174. </Modal>