mirror of
				https://github.com/crater-invoice/crater.git
				synced 2025-10-28 04:01:10 -04:00 
			
		
		
		
	Compare commits
	
		
			2 Commits
		
	
	
		
			test-uffiz
			...
			dark-BaseT
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| a8ffd2cf12 | |||
| 15f3f566e3 | 
| @ -15,6 +15,13 @@ | ||||
|       bg-gradient-to-r | ||||
|       from-primary-500 | ||||
|       to-primary-400 | ||||
|       dark:from-gray-700/70 dark:to-gray-800/70 | ||||
|       bg-primary-500 | ||||
|       dark:bg-transparent | ||||
|       dark:backdrop-blur-xl | ||||
|       dark:shadow-glass | ||||
|       dark:border | ||||
|       dark:border-white/10 | ||||
|     " | ||||
|   > | ||||
|     <router-link | ||||
| @ -53,6 +60,7 @@ | ||||
|         cursor-pointer | ||||
|         md:hidden md:ml-0 | ||||
|         hover:bg-gray-100 | ||||
|         dark:bg-gray-800 dark:border-gray-500 dark:border | ||||
|       " | ||||
|       @click.prevent="onToggle" | ||||
|     > | ||||
|  | ||||
| @ -15,7 +15,9 @@ | ||||
|         leave-from="opacity-100" | ||||
|         leave-to="opacity-0" | ||||
|       > | ||||
|         <DialogOverlay class="fixed inset-0 bg-gray-600 bg-opacity-75" /> | ||||
|         <DialogOverlay | ||||
|           class="fixed inset-0 bg-gray-600 bg-opacity-75 dark:bg-gray-900/90" | ||||
|         /> | ||||
|       </TransitionChild> | ||||
|  | ||||
|       <TransitionChild | ||||
| @ -27,7 +29,9 @@ | ||||
|         leave-from="translate-x-0" | ||||
|         leave-to="-translate-x-full" | ||||
|       > | ||||
|         <div class="relative flex flex-col flex-1 w-full max-w-xs bg-white"> | ||||
|         <div | ||||
|           class="relative flex flex-col flex-1 w-full max-w-xs bg-white dark:bg-gray-800" | ||||
|         > | ||||
|           <TransitionChild | ||||
|             as="template" | ||||
|             enter="ease-in-out duration-300" | ||||
| @ -50,8 +54,7 @@ | ||||
|                 focus:outline-none | ||||
|                 focus:ring-2 | ||||
|                 focus:ring-inset | ||||
|                   focus:ring-white | ||||
|                 " | ||||
|                 focus:ring-white" | ||||
|                 @click="globalStore.setSidebarVisibility(false)" | ||||
|               > | ||||
|                 <span class="sr-only">Close sidebar</span> | ||||
| @ -82,8 +85,8 @@ | ||||
|                 :to="item.link" | ||||
|                 :class="[ | ||||
|                   hasActiveUrl(item.link) | ||||
|                     ? 'text-primary-500 border-primary-500 bg-gray-100 ' | ||||
|                     : 'text-black', | ||||
|                     ? 'text-primary-500 border-primary-500 bg-gray-100 dark:shadow-glass dark:backdrop-blur-xl dark:hover:bg-gray-700  dark:bg-gray-700/50 dark:text-primary-400 dark:font-medium' | ||||
|                     : 'text-black dark:text-gray-300', | ||||
|                   'cursor-pointer px-0 pl-4 py-3 border-transparent flex items-center border-l-4 border-solid text-sm not-italic font-medium', | ||||
|                 ]" | ||||
|                 @click="globalStore.setSidebarVisibility(false)" | ||||
| @ -100,6 +103,10 @@ | ||||
|                 /> | ||||
|                 {{ $t(item.title) }} | ||||
|               </router-link> | ||||
|               <LightDarkSwitch | ||||
|                 :show-label="false" | ||||
|                 class="absolute right-6 top-6 !w-auto" | ||||
|               /> | ||||
|             </nav> | ||||
|           </div> | ||||
|         </div> | ||||
| @ -116,14 +123,13 @@ | ||||
|     hidden | ||||
|     w-56 | ||||
|     h-screen | ||||
|       pb-32 | ||||
|       overflow-y-auto | ||||
|     bg-white | ||||
|     border-r border-gray-200 border-solid | ||||
|     xl:w-64 | ||||
|     md:fixed md:flex md:flex-col md:inset-y-0 | ||||
|     pt-16 | ||||
|     " | ||||
|     dark:border-gray-800 | ||||
|     dark:bg-gray-800/80" | ||||
|   > | ||||
|     <div | ||||
|       v-for="menu in globalStore.menuGroups" | ||||
| @ -136,8 +142,8 @@ | ||||
|         :to="item.link" | ||||
|         :class="[ | ||||
|           hasActiveUrl(item.link) | ||||
|             ? 'text-primary-500 border-primary-500 bg-gray-100 ' | ||||
|             : 'text-black', | ||||
|             ? 'text-primary-500 border-primary-500 bg-gray-100 dark:border-primary-400 dark:shadow-glass dark:backdrop-blur-xl dark:hover:bg-gray-700 dark:bg-gray-700/50 dark:text-primary-400 dark:font-medium' | ||||
|             : 'text-black dark:hover:bg-transparent dark:hover:text-white dark:text-gray-300', | ||||
|           'cursor-pointer px-0 pl-6 hover:bg-gray-50 py-3 group flex items-center border-l-4 border-solid border-transparent text-sm not-italic font-medium', | ||||
|         ]" | ||||
|       > | ||||
| @ -145,8 +151,8 @@ | ||||
|           :name="item.icon" | ||||
|           :class="[ | ||||
|             hasActiveUrl(item.link) | ||||
|               ? 'text-primary-500 group-hover:text-primary-500 ' | ||||
|               : 'text-gray-400 group-hover:text-black', | ||||
|               ? 'text-primary-500 group-hover:text-primary-500 dark:text-primary-400 dark:group-hover:text-primary-500 ' | ||||
|               : 'text-gray-400 group-hover:text-black dark:text-gray-400 dark:group-hover:text-white', | ||||
|             'mr-4 shrink-0 h-5 w-5 ', | ||||
|           ]" | ||||
|         /> | ||||
| @ -154,6 +160,9 @@ | ||||
|         {{ $t(item.title) }} | ||||
|       </router-link> | ||||
|     </div> | ||||
|     <LightDarkSwitch | ||||
|       class="absolute bottom-0 py-4 border-t border-gray-200 dark:border-gray-700" | ||||
|     /> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
| @ -169,6 +178,7 @@ import { | ||||
|  | ||||
| import { useRoute } from 'vue-router' | ||||
| import { useGlobalStore } from '@/scripts/admin/stores/global' | ||||
| import LightDarkSwitch from '@/scripts/components/LightDarkSwitcher.vue' | ||||
|  | ||||
| const route = useRoute() | ||||
| const globalStore = useGlobalStore() | ||||
|  | ||||
| @ -34,6 +34,7 @@ export const useGlobalStore = (useWindow = false) => { | ||||
|       isAppLoaded: false, | ||||
|       isSidebarOpen: false, | ||||
|       areCurrenciesLoading: false, | ||||
|       isDarkModeOn: false, | ||||
|  | ||||
|       downloadReport: null, | ||||
|     }), | ||||
|  | ||||
							
								
								
									
										101
									
								
								resources/scripts/components/LightDarkSwitcher.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										101
									
								
								resources/scripts/components/LightDarkSwitcher.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,101 @@ | ||||
| <!-- This example requires Tailwind CSS v2.0+ --> | ||||
| <script lang="ts" setup> | ||||
| import { Switch, SwitchGroup, SwitchLabel } from '@headlessui/vue' | ||||
| import { useGlobalStore } from '@/scripts/admin/stores/global' | ||||
| import { computed, ref } from 'vue' | ||||
| defineProps({ | ||||
|   showLabel: { | ||||
|     type: Boolean, | ||||
|     default: true, | ||||
|   }, | ||||
|   vertical: { | ||||
|     type: Boolean, | ||||
|     default: false, | ||||
|   }, | ||||
| }) | ||||
|  | ||||
| const globalStore = useGlobalStore() | ||||
|  | ||||
| const enabled = ref( | ||||
|   localStorage.getItem('theme') === 'dark' || | ||||
|     document.documentElement.classList.contains('dark') | ||||
| ) | ||||
|  | ||||
| globalStore.isDarkModeOn = enabled | ||||
|  | ||||
| function onChange(val) { | ||||
|   if (val) { | ||||
|     localStorage.theme = 'dark' | ||||
|     document.documentElement.classList.add('dark') | ||||
|     document.documentElement.style.setProperty('color-scheme', 'dark') | ||||
|     globalStore.isDarkModeOn = true | ||||
|   } else { | ||||
|     localStorage.theme = 'light' | ||||
|     document.documentElement.classList.remove('dark') | ||||
|     document.documentElement.style.setProperty('color-scheme', 'light') | ||||
|     globalStore.isDarkModeOn = false | ||||
|   } | ||||
| } | ||||
| </script> | ||||
|  | ||||
| <template> | ||||
|   <div class="w-full flex justify-center"> | ||||
|     <SwitchGroup | ||||
|       as="div" | ||||
|       class="flex items-center" | ||||
|       :class="vertical ? 'flex-col justify-center' : 'flex-row'" | ||||
|     > | ||||
|       <Switch | ||||
|         v-model="enabled" | ||||
|         class="relative inline-flex flex-shrink-0 h-6 w-11 border-2 border-transparent rounded-full cursor-pointer transition-colors ease-in-out duration-200 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-primary-500 dark:ring-offset-gray-700" | ||||
|         :class="[enabled ? 'bg-primary-600' : 'bg-gray-200']" | ||||
|         @update:modelValue="onChange" | ||||
|       > | ||||
|         <span class="sr-only">Use setting</span> | ||||
|         <span | ||||
|           class="pointer-events-none relative inline-block h-5 w-5 rounded-full bg-white shadow transform ring-0 transition ease-in-out duration-200" | ||||
|           :class="[enabled ? 'translate-x-5' : 'translate-x-0']" | ||||
|         > | ||||
|           <span | ||||
|             class="absolute inset-0 h-full w-full flex items-center justify-center transition-opacity" | ||||
|             :class="[ | ||||
|               enabled | ||||
|                 ? 'opacity-0 ease-out duration-100' | ||||
|                 : 'opacity-100 ease-in duration-200', | ||||
|             ]" | ||||
|             aria-hidden="true" | ||||
|           > | ||||
|             <BaseIcon class="h-3 w-3 text-yellow-500" name="SunIcon" /> | ||||
|           </span> | ||||
|           <span | ||||
|             class="absolute inset-0 h-full w-full flex items-center justify-center transition-opacity" | ||||
|             :class="[ | ||||
|               enabled | ||||
|                 ? 'opacity-100 ease-in duration-200' | ||||
|                 : 'opacity-0 ease-out duration-100', | ||||
|             ]" | ||||
|             aria-hidden="true" | ||||
|           > | ||||
|             <BaseIcon class="h-3 w-3 text-primary-500" name="MoonIcon" /> | ||||
|           </span> | ||||
|         </span> | ||||
|       </Switch> | ||||
|       <SwitchLabel | ||||
|         v-if="showLabel" | ||||
|         as="span" | ||||
|         class="cursor-pointer" | ||||
|         :class="vertical ? 'px-1 text-center mt-2' : 'ml-3'" | ||||
|       > | ||||
|         <span | ||||
|           v-if="enabled" | ||||
|           class="text-sm font-medium text-gray-500 dark:text-gray-400" | ||||
|         > | ||||
|           Dark Mode | ||||
|         </span> | ||||
|         <span v-else class="text-sm font-medium text-gray-500"> | ||||
|           Light Mode | ||||
|         </span> | ||||
|       </SwitchLabel> | ||||
|     </SwitchGroup> | ||||
|   </div> | ||||
| </template> | ||||
| @ -39,7 +39,7 @@ const props = defineProps({ | ||||
|   inputClass: { | ||||
|     type: String, | ||||
|     default: | ||||
|       'font-base block w-full sm:text-sm border-gray-200 rounded-md text-black', | ||||
|       'font-base block w-full sm:text-sm border-gray-200 rounded-md text-black  dark:bg-gray-700 dark:border-gray-600 dark:text-white dark:placeholder-gray-500', | ||||
|   }, | ||||
|   disabled: { | ||||
|     type: Boolean, | ||||
| @ -86,7 +86,7 @@ const currencyBindings = computed(() => { | ||||
|  | ||||
| const invalidClass = computed(() => { | ||||
|   if (props.invalid) { | ||||
|     return 'border-red-500 ring-red-500 focus:ring-red-500 focus:border-red-500' | ||||
|     return 'border-red-500 dark:border-red-500 ring-red-500 dark:ring-red-500 focus:ring-red-500 dark:focus:ring-red-500 focus:border-red-500 dark:focus:border-red-500' | ||||
|   } | ||||
|   return 'focus:ring-primary-400 focus:border-primary-400' | ||||
| }) | ||||
|  | ||||
| @ -45,7 +45,7 @@ const props = defineProps({ | ||||
|   defaultInputClass: { | ||||
|     type: String, | ||||
|     default: | ||||
|       'box-border w-full px-3 py-2 text-sm not-italic font-normal leading-snug text-left text-black placeholder-gray-400 bg-white border border-gray-200 border-solid rounded outline-none', | ||||
|       'box-border w-full px-3 py-2 text-sm not-italic font-normal leading-snug text-left text-black placeholder-gray-400 bg-white border border-gray-200 dark:border-gray-600 border-solid rounded outline-none  dark:bg-gray-700 dark:text-white', | ||||
|   }, | ||||
|   autosize: { | ||||
|     type: Boolean, | ||||
|  | ||||
| @ -25,7 +25,7 @@ | ||||
| </head> | ||||
|  | ||||
| <body | ||||
|     class="h-full overflow-hidden bg-gray-100 font-base | ||||
|     class="h-full overflow-hidden bg-gray-100 dark:bg-gray-900 dark:text-white font-base | ||||
|     @if (isset($current_theme)) theme-{{ $current_theme }} @else theme-{{ get_app_setting('admin_portal_theme') ?? 'crater' }} @endif "> | ||||
|  | ||||
|     <!-- Module Scripts --> | ||||
| @ -38,6 +38,14 @@ | ||||
|     @endforeach | ||||
|  | ||||
|     <script type="module"> | ||||
|         if (localStorage.theme === 'dark' || (!('theme' in localStorage) && window.matchMedia('(prefers-color-scheme: dark)').matches)) { | ||||
|             document.documentElement.classList.add('dark') | ||||
|             document.documentElement.style.setProperty('color-scheme', 'dark'); | ||||
|         } else { | ||||
|             document.documentElement.classList.remove('dark') | ||||
|             document.documentElement.style.setProperty('color-scheme', 'light') | ||||
|         } | ||||
|  | ||||
|         @if(isset($customer_logo)) | ||||
|  | ||||
|         window.customer_logo = "/storage/{{$customer_logo}}" | ||||
|  | ||||
| @ -19,6 +19,7 @@ module.exports = { | ||||
|     './resources/scripts/**/*.js', | ||||
|     './resources/scripts/**/*.vue', | ||||
|   ], | ||||
|   darkMode: 'class', | ||||
|   theme: { | ||||
|     extend: { | ||||
|       colors: { | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	