SettingsModal.svelte 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. <script>
  2. import Modal from '../common/Modal.svelte';
  3. import General from './Settings/General.svelte';
  4. export let show = false;
  5. let selectedTab = 'general';
  6. </script>
  7. <Modal bind:show>
  8. <div>
  9. <div class=" flex justify-between dark:text-gray-300 px-5 py-4">
  10. <div class=" text-lg font-medium self-center">Document Settings</div>
  11. <button
  12. class="self-center"
  13. on:click={() => {
  14. show = false;
  15. }}
  16. >
  17. <svg
  18. xmlns="http://www.w3.org/2000/svg"
  19. viewBox="0 0 20 20"
  20. fill="currentColor"
  21. class="w-5 h-5"
  22. >
  23. <path
  24. 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"
  25. />
  26. </svg>
  27. </button>
  28. </div>
  29. <hr class=" dark:border-gray-800" />
  30. <div class="flex flex-col md:flex-row w-full p-4 md:space-x-4">
  31. <div
  32. 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"
  33. >
  34. <button
  35. class="px-2.5 py-2.5 min-w-fit rounded-lg flex-1 md:flex-none flex text-right transition {selectedTab ===
  36. 'general'
  37. ? 'bg-gray-200 dark:bg-gray-700'
  38. : ' hover:bg-gray-300 dark:hover:bg-gray-800'}"
  39. on:click={() => {
  40. selectedTab = 'general';
  41. }}
  42. >
  43. <div class=" self-center mr-2">
  44. <svg
  45. xmlns="http://www.w3.org/2000/svg"
  46. viewBox="0 0 16 16"
  47. fill="currentColor"
  48. class="w-4 h-4"
  49. >
  50. <path
  51. fill-rule="evenodd"
  52. 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"
  53. clip-rule="evenodd"
  54. />
  55. </svg>
  56. </div>
  57. <div class=" self-center">General</div>
  58. </button>
  59. </div>
  60. <div class="flex-1 md:min-h-[380px]">
  61. {#if selectedTab === 'general'}
  62. <General
  63. saveHandler={() => {
  64. show = false;
  65. }}
  66. />
  67. <!-- <General
  68. saveHandler={() => {
  69. show = false;
  70. }}
  71. /> -->
  72. <!-- {:else if selectedTab === 'users'}
  73. <Users
  74. saveHandler={() => {
  75. show = false;
  76. }}
  77. /> -->
  78. {/if}
  79. </div>
  80. </div>
  81. </div>
  82. </Modal>