mirror of
				https://github.com/crater-invoice/crater.git
				synced 2025-10-30 05:01:10 -04:00 
			
		
		
		
	Compare commits
	
		
			16 Commits
		
	
	
		
			dark-multi
			...
			dark-base-
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 04660c78f9 | |||
| c5acf1343e | |||
| 0321ca5515 | |||
| bd345949e5 | |||
| b4b00ebdd6 | |||
| 43316dae28 | |||
| 80e2548b38 | |||
| e8d92cd641 | |||
| 2c8bb38531 | |||
| 04c7ae39a2 | |||
| af2482a69c | |||
| cac35826c2 | |||
| 18b5705372 | |||
| c61fbad5ce | |||
| 2e93082282 | |||
| ca55221c4f | 
| @ -1,6 +1,6 @@ | |||||||
| <template> | <template> | ||||||
|   <nav> |   <nav> | ||||||
|     <ol class="flex flex-wrap py-4 text-gray-900 rounded list-reset"> |     <ol class="flex flex-wrap py-4 text-gray-900 rounded list-reset dark:text-gray-400"> | ||||||
|       <slot /> |       <slot /> | ||||||
|     </ol> |     </ol> | ||||||
|   </nav> |   </nav> | ||||||
|  | |||||||
| @ -8,7 +8,9 @@ | |||||||
|         font-medium |         font-medium | ||||||
|         leading-5 |         leading-5 | ||||||
|         text-gray-900 |         text-gray-900 | ||||||
|  |         dark:text-gray-400 | ||||||
|         outline-none |         outline-none | ||||||
|  |         dark:focus:ring-offset-gray-900 | ||||||
|         focus:ring-2 focus:ring-offset-2 focus:ring-primary-400 |         focus:ring-2 focus:ring-offset-2 focus:ring-primary-400 | ||||||
|       " |       " | ||||||
|       :to="to" |       :to="to" | ||||||
|  | |||||||
| @ -1,6 +1,7 @@ | |||||||
| <script setup> | <script setup> | ||||||
| import { computed, ref } from 'vue' | import { computed, ref } from 'vue' | ||||||
| import SpinnerIcon from '@/scripts/components/icons/SpinnerIcon.vue' | import SpinnerIcon from '@/scripts/components/icons/SpinnerIcon.vue' | ||||||
|  |  | ||||||
| const props = defineProps({ | const props = defineProps({ | ||||||
|   contentLoading: { |   contentLoading: { | ||||||
|     type: Boolean, |     type: Boolean, | ||||||
| @ -9,7 +10,7 @@ const props = defineProps({ | |||||||
|   defaultClass: { |   defaultClass: { | ||||||
|     type: String, |     type: String, | ||||||
|     default: |     default: | ||||||
|       'inline-flex whitespace-nowrap items-center border font-medium focus:outline-none focus:ring-2 focus:ring-offset-2', |       'inline-flex whitespace-nowrap items-center border font-medium focus:outline-none focus:ring-2 focus:ring-offset-2 dark:focus:ring-offset-gray-800', | ||||||
|   }, |   }, | ||||||
|   tag: { |   tag: { | ||||||
|     type: String, |     type: String, | ||||||
| @ -27,6 +28,10 @@ const props = defineProps({ | |||||||
|     type: Boolean, |     type: Boolean, | ||||||
|     default: false, |     default: false, | ||||||
|   }, |   }, | ||||||
|  |   loadingRight: { | ||||||
|  |     type: Boolean, | ||||||
|  |     default: false, | ||||||
|  |   }, | ||||||
|   size: { |   size: { | ||||||
|     type: String, |     type: String, | ||||||
|     default: 'md', |     default: 'md', | ||||||
| @ -81,17 +86,17 @@ const placeHolderSize = computed(() => { | |||||||
|  |  | ||||||
| const variantClass = computed(() => { | const variantClass = computed(() => { | ||||||
|   return { |   return { | ||||||
|     'border-transparent shadow-sm text-white bg-primary-600 hover:bg-primary-700 focus:ring-primary-500': |     'border-transparent shadow-sm text-white bg-primary-600 hover:bg-primary-700 focus:ring-primary-500 dark:bg-primary-500 dark:hover:bg-primary-600': | ||||||
|       props.variant === 'primary', |       props.variant === 'primary', | ||||||
|     'border-transparent text-primary-700 bg-primary-100 hover:bg-primary-200 focus:ring-primary-500': |     'border-transparent text-primary-700 bg-primary-100 hover:bg-primary-200 focus:ring-primary-500': | ||||||
|       props.variant === 'secondary', |       props.variant === 'secondary', | ||||||
|     'border-transparent  border-solid border-primary-500 font-normal transition ease-in-out duration-150 text-primary-500 hover:bg-primary-200 shadow-inner focus:ring-primary-500': |     'border-transparent border-solid border-primary-500 font-normal transition ease-in-out duration-150 text-primary-500 hover:bg-primary-100 shadow-inner focus:ring-primary-500 dark:text-primary-400 dark:border-primary-400 dark:hover:bg-transparent dark:hover:text-primary-500 dark:hover:border-primary-500': | ||||||
|       props.variant == 'primary-outline', |       props.variant == 'primary-outline', | ||||||
|     'border-gray-200 text-gray-700 bg-white hover:bg-gray-50 focus:ring-primary-500 focus:ring-offset-0': |     'border-gray-200 text-gray-700 bg-white hover:bg-gray-50 focus:ring-primary-500 focus:ring-offset-0 dark:bg-gray-800 dark:border-gray-600 dark:text-gray-300 dark:hover:bg-gray-900': | ||||||
|       props.variant == 'white', |       props.variant == 'white', | ||||||
|     'border-transparent shadow-sm text-white bg-red-600 hover:bg-red-700 focus:ring-red-500': |     'border-transparent shadow-sm text-white bg-red-600 hover:bg-red-700 focus:ring-red-500': | ||||||
|       props.variant === 'danger', |       props.variant === 'danger', | ||||||
|     'border-transparent bg-gray-200 border hover:bg-opacity-60 focus:ring-gray-500 focus:ring-offset-0': |     'border-transparent bg-gray-200 border hover:bg-opacity-60 focus:ring-gray-500 focus:ring-offset-0 dark:bg-gray-600 dark:text-white dark:hover:bg-opacity-60': | ||||||
|       props.variant === 'gray', |       props.variant === 'gray', | ||||||
|   } |   } | ||||||
| }) | }) | ||||||
| @ -124,6 +129,13 @@ const iconRightClass = computed(() => { | |||||||
|     'ml-3 -mr-1 h-5 w-5': props.size === 'lg' || props.size === 'xl', |     'ml-3 -mr-1 h-5 w-5': props.size === 'lg' || props.size === 'xl', | ||||||
|   } |   } | ||||||
| }) | }) | ||||||
|  |  | ||||||
|  | const buttonDisabledClass = computed(() => { | ||||||
|  |   if (props.disabled || props.loading) | ||||||
|  |     return 'cursor-not-allowed bg-opacity-70 dark:!bg-opacity-40 hover:!bg-opacity-70 pointer-event-none' | ||||||
|  |  | ||||||
|  |   return '' | ||||||
|  | }) | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <template> | <template> | ||||||
| @ -141,15 +153,17 @@ const iconRightClass = computed(() => { | |||||||
|   <BaseCustomTag |   <BaseCustomTag | ||||||
|     v-else |     v-else | ||||||
|     :tag="tag" |     :tag="tag" | ||||||
|     :disabled="disabled" |     :disabled="disabled || loading" | ||||||
|     :class="[defaultClass, sizeClass, variantClass, roundedClass]" |     :class="[defaultClass, sizeClass, variantClass, roundedClass, buttonDisabledClass]" | ||||||
|   > |   > | ||||||
|     <SpinnerIcon v-if="loading" :class="[iconLeftClass, iconVariantClass]" /> |     <SpinnerIcon v-if="loading && !loadingRight" :class="[iconLeftClass, iconVariantClass]" /> | ||||||
|  |  | ||||||
|     <slot v-else name="left" :class="iconLeftClass"></slot> |     <slot v-else name="left" :class="iconLeftClass" /> | ||||||
|  |  | ||||||
|     <slot /> |     <slot /> | ||||||
|  |  | ||||||
|     <slot name="right" :class="[iconRightClass, iconVariantClass]"></slot> |     <SpinnerIcon v-if="loading && loadingRight" :class="[iconRightClass, iconVariantClass]" /> | ||||||
|  |  | ||||||
|  |     <slot v-else name="right" :class="[iconRightClass, iconVariantClass]" /> | ||||||
|   </BaseCustomTag> |   </BaseCustomTag> | ||||||
| </template> | </template> | ||||||
|  | |||||||
| @ -1,5 +1,9 @@ | |||||||
| <template> | <template> | ||||||
|   <div class="bg-white rounded-lg shadow"> |   <div | ||||||
|  |     class="bg-white rounded-lg shadow dark:bg-gray-800 dark:text-white dark:shadow-glass dark:border dark:border-white/10 dark:bg-gray-800/70 relative" | ||||||
|  |   > | ||||||
|  |     <BaseDarkHighlight class="z-[-1] mt-10" /> | ||||||
|  |  | ||||||
|     <div |     <div | ||||||
|       v-if="hasHeaderSlot" |       v-if="hasHeaderSlot" | ||||||
|       class="px-5 py-4 text-black border-b border-gray-100 border-solid" |       class="px-5 py-4 text-black border-b border-gray-100 border-solid" | ||||||
|  | |||||||
| @ -39,6 +39,8 @@ $base-content-placeholders-border-radius: 6px !default; | |||||||
| $base-content-placeholders-line-height: 15px !default; | $base-content-placeholders-line-height: 15px !default; | ||||||
| $base-content-placeholders-spacing: 10px !default; | $base-content-placeholders-spacing: 10px !default; | ||||||
|  |  | ||||||
|  | $base-content-placeholders-primary-color-dark: rgb(71, 85, 105) !default; | ||||||
|  | $base-content-placeholders-secondary-color-dark: rgb(71, 85, 105) !default; | ||||||
| // Animations | // Animations | ||||||
| @keyframes vueContentPlaceholdersAnimation { | @keyframes vueContentPlaceholdersAnimation { | ||||||
|   0% { |   0% { | ||||||
| @ -57,6 +59,10 @@ $base-content-placeholders-spacing: 10px !default; | |||||||
|   min-height: $base-content-placeholders-line-height; |   min-height: $base-content-placeholders-line-height; | ||||||
|   background: $base-content-placeholders-secondary-color; |   background: $base-content-placeholders-secondary-color; | ||||||
|  |  | ||||||
|  |   .dark & { | ||||||
|  |     background: $base-content-placeholders-secondary-color-dark; | ||||||
|  |   } | ||||||
|  |  | ||||||
|   .base-content-placeholders-is-rounded & { |   .base-content-placeholders-is-rounded & { | ||||||
|     border-radius: $base-content-placeholders-border-radius; |     border-radius: $base-content-placeholders-border-radius; | ||||||
|   } |   } | ||||||
| @ -86,6 +92,15 @@ $base-content-placeholders-spacing: 10px !default; | |||||||
|     animation-name: vueContentPlaceholdersAnimation; |     animation-name: vueContentPlaceholdersAnimation; | ||||||
|     animation-timing-function: linear; |     animation-timing-function: linear; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   .dark .base-content-placeholders-is-animated &::before { | ||||||
|  |     background: linear-gradient( | ||||||
|  |       to right, | ||||||
|  |       transparent 0%, | ||||||
|  |       darken($base-content-placeholders-secondary-color-dark, 5%) 15%, | ||||||
|  |       transparent 30% | ||||||
|  |     ); | ||||||
|  |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| @mixin base-content-placeholders-spacing { | @mixin base-content-placeholders-spacing { | ||||||
| @ -156,6 +171,10 @@ $base-content-placeholders-spacing: 10px !default; | |||||||
|   min-height: $base-content-placeholders-line-height; |   min-height: $base-content-placeholders-line-height; | ||||||
|   background: $base-content-placeholders-secondary-color; |   background: $base-content-placeholders-secondary-color; | ||||||
|  |  | ||||||
|  |   .dark & { | ||||||
|  |     background: $base-content-placeholders-secondary-color-dark; | ||||||
|  |   } | ||||||
|  |    | ||||||
|   .base-content-placeholders-is-animated &::before { |   .base-content-placeholders-is-animated &::before { | ||||||
|     content: ''; |     content: ''; | ||||||
|     position: absolute; |     position: absolute; | ||||||
| @ -177,6 +196,14 @@ $base-content-placeholders-spacing: 10px !default; | |||||||
|     animation-timing-function: linear; |     animation-timing-function: linear; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |     .dark .base-content-placeholders-is-animated &::before { | ||||||
|  |       background: linear-gradient( | ||||||
|  |       to right, | ||||||
|  |       transparent 0%, | ||||||
|  |       darken($base-content-placeholders-secondary-color-dark, 5%) 15%, | ||||||
|  |       transparent 30% | ||||||
|  |     ); | ||||||
|  |   } | ||||||
|   // @include base-content-placeholders-spacing; |   // @include base-content-placeholders-spacing; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | |||||||
							
								
								
									
										21
									
								
								resources/scripts/components/base/BaseDarkHighlight.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								resources/scripts/components/base/BaseDarkHighlight.vue
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,21 @@ | |||||||
|  | <template> | ||||||
|  |   <div | ||||||
|  |     class=" | ||||||
|  |       hidden | ||||||
|  |       top-0 | ||||||
|  |       w-full | ||||||
|  |       absolute | ||||||
|  |       ml-auto | ||||||
|  |       mr-auto | ||||||
|  |       left-0 | ||||||
|  |       right-0 | ||||||
|  |       text-center | ||||||
|  |       h-full | ||||||
|  |       rounded-full | ||||||
|  |       bg-highlight/[.10] | ||||||
|  |       blur-2xl | ||||||
|  |       dark:block | ||||||
|  |       z-[-1] | ||||||
|  |     " | ||||||
|  |   /> | ||||||
|  | </template> | ||||||
| @ -30,8 +30,13 @@ | |||||||
|           leave-to="opacity-0" |           leave-to="opacity-0" | ||||||
|         > |         > | ||||||
|           <DialogOverlay |           <DialogOverlay | ||||||
|             class="fixed inset-0 transition-opacity bg-gray-500 bg-opacity-75" |             class="fixed inset-0 transition-opacity bg-gray-500 bg-opacity-75 dark:backdrop-blur-xl dark:bg-gray-900/80" | ||||||
|  |           > | ||||||
|  |            <BaseDarkHighlight | ||||||
|  |             class="!bg-highlight/[.17] !top-1/2 h-60 -translate-y-1/2 mt-5" | ||||||
|  |             :class="dialogSizeClasses" | ||||||
|           /> |           /> | ||||||
|  |           </DialogOverlay> | ||||||
|         </TransitionChild> |         </TransitionChild> | ||||||
|  |  | ||||||
|         <!-- This element is to trick the browser into centering the modal contents. --> |         <!-- This element is to trick the browser into centering the modal contents. --> | ||||||
| @ -64,6 +69,11 @@ | |||||||
|               shadow-xl |               shadow-xl | ||||||
|               sm:my-8 sm:align-middle sm:w-full sm:p-6 |               sm:my-8 sm:align-middle sm:w-full sm:p-6 | ||||||
|               relative |               relative | ||||||
|  |               dark:backdrop-blur-xl | ||||||
|  |               dark:shadow-glass | ||||||
|  |               dark:border | ||||||
|  |               dark:border-white/10 | ||||||
|  |               dark:bg-gray-800 | ||||||
|             " |             " | ||||||
|             :class="dialogSizeClasses" |             :class="dialogSizeClasses" | ||||||
|           > |           > | ||||||
| @ -80,31 +90,31 @@ | |||||||
|                   rounded-full |                   rounded-full | ||||||
|                 " |                 " | ||||||
|                 :class="{ |                 :class="{ | ||||||
|                   'bg-green-100': dialogStore.variant === 'primary', |                   'bg-green-100 dark:bg-primary-500': dialogStore.variant === 'primary', | ||||||
|                   'bg-red-100': dialogStore.variant === 'danger', |                   'bg-red-100 dark:bg-red-500': dialogStore.variant === 'danger', | ||||||
|                 }" |                 }" | ||||||
|               > |               > | ||||||
|                 <BaseIcon |                 <BaseIcon | ||||||
|                   v-if="dialogStore.variant === 'primary'" |                   v-if="dialogStore.variant === 'primary'" | ||||||
|                   name="CheckIcon" |                   name="CheckIcon" | ||||||
|                   class="w-6 h-6 text-green-600" |                   class="w-6 h-6 text-green-600 dark:text-white" | ||||||
|                 /> |                 /> | ||||||
|                 <BaseIcon |                 <BaseIcon | ||||||
|                   v-else |                   v-else | ||||||
|                   name="ExclamationIcon" |                   name="ExclamationIcon" | ||||||
|                   class="w-6 h-6 text-red-600" |                   class="w-6 h-6 text-red-600 dark:text-white" | ||||||
|                   aria-hidden="true" |                   aria-hidden="true" | ||||||
|                 /> |                 /> | ||||||
|               </div> |               </div> | ||||||
|               <div class="mt-3 text-center sm:mt-5"> |               <div class="mt-3 text-center sm:mt-5"> | ||||||
|                 <DialogTitle |                 <DialogTitle | ||||||
|                   as="h3" |                   as="h3" | ||||||
|                   class="text-lg font-medium leading-6 text-gray-900" |                   class="text-lg font-medium leading-6 text-gray-900 dark:text-white" | ||||||
|                 > |                 > | ||||||
|                   {{ dialogStore.title }} |                   {{ dialogStore.title }} | ||||||
|                 </DialogTitle> |                 </DialogTitle> | ||||||
|                 <div class="mt-2"> |                 <div class="mt-2"> | ||||||
|                   <p class="text-sm text-gray-500"> |                   <p class="text-sm text-gray-500 dark:text-gray-400"> | ||||||
|                     {{ dialogStore.message }} |                     {{ dialogStore.message }} | ||||||
|                   </p> |                   </p> | ||||||
|                 </div> |                 </div> | ||||||
|  | |||||||
| @ -7,7 +7,7 @@ | |||||||
|     leave-from-class="opacity-100" |     leave-from-class="opacity-100" | ||||||
|     leave-to-class="opacity-0" |     leave-to-class="opacity-0" | ||||||
|   > |   > | ||||||
|     <div v-show="show" class="relative z-10 p-4 md:p-8 bg-gray-200 rounded"> |     <div v-show="show" class="relative z-10 p-4 md:p-8 bg-gray-200 rounded dark:bg-gray-800"> | ||||||
|       <slot name="filter-header" /> |       <slot name="filter-header" /> | ||||||
|  |  | ||||||
|       <label |       <label | ||||||
| @ -20,6 +20,7 @@ | |||||||
|           hover:text-gray-700 |           hover:text-gray-700 | ||||||
|           top-2.5 |           top-2.5 | ||||||
|           right-3.5 |           right-3.5 | ||||||
|  |           dark:text-gray-300 | ||||||
|         " |         " | ||||||
|         @click="$emit('clear')" |         @click="$emit('clear')" | ||||||
|       > |       > | ||||||
|  | |||||||
| @ -12,6 +12,7 @@ | |||||||
|         bg-gray-200 |         bg-gray-200 | ||||||
|         border border-gray-200 border-solid |         border border-gray-200 border-solid | ||||||
|         rounded |         rounded | ||||||
|  |         dark:bg-gray-900/70 dark:border-gray-700 | ||||||
|       " |       " | ||||||
|     > |     > | ||||||
|       {{ item.name }} |       {{ item.name }} | ||||||
|  | |||||||
| @ -1,7 +1,7 @@ | |||||||
| <template> | <template> | ||||||
|   <div class="flex flex-wrap justify-between"> |   <div class="flex flex-wrap justify-between"> | ||||||
|     <div> |     <div> | ||||||
|       <h3 class="text-2xl font-bold text-left text-black"> |       <h3 class="text-2xl font-bold text-left text-black dark:text-white"> | ||||||
|         {{ title }} |         {{ title }} | ||||||
|       </h3> |       </h3> | ||||||
|       <slot /> |       <slot /> | ||||||
|  | |||||||
| @ -7,7 +7,7 @@ | |||||||
|  |  | ||||||
|       <Switch |       <Switch | ||||||
|         v-model="enabled" |         v-model="enabled" | ||||||
|         :class="enabled ? 'bg-primary-500' : 'bg-gray-300'" |         :class="enabled ? 'bg-primary-500' : 'bg-gray-300 dark:bg-gray-900'" | ||||||
|         class=" |         class=" | ||||||
|           relative |           relative | ||||||
|           inline-flex |           inline-flex | ||||||
| @ -21,7 +21,11 @@ | |||||||
|         v-bind="$attrs" |         v-bind="$attrs" | ||||||
|       > |       > | ||||||
|         <span |         <span | ||||||
|           :class="enabled ? 'translate-x-6' : 'translate-x-1'" |           :class=" | ||||||
|  |             enabled | ||||||
|  |               ? 'translate-x-6 dark:bg-white' | ||||||
|  |               : 'translate-x-1 dark:bg-gray-500' | ||||||
|  |           " | ||||||
|           class=" |           class=" | ||||||
|             inline-block |             inline-block | ||||||
|             w-4 |             w-4 | ||||||
|  | |||||||
| @ -5,12 +5,12 @@ | |||||||
|     <div class="flex flex-col"> |     <div class="flex flex-col"> | ||||||
|       <SwitchLabel |       <SwitchLabel | ||||||
|         as="p" |         as="p" | ||||||
|         class="p-0 mb-1 text-sm leading-snug text-black font-medium" |         class="p-0 mb-1 text-sm leading-snug text-black font-medium dark:text-white" | ||||||
|         passive |         passive | ||||||
|       > |       > | ||||||
|         {{ title }} |         {{ title }} | ||||||
|       </SwitchLabel> |       </SwitchLabel> | ||||||
|       <SwitchDescription class="text-sm text-gray-500"> |       <SwitchDescription class="text-sm text-gray-500 dark:text-gray-400"> | ||||||
|         {{ description }} |         {{ description }} | ||||||
|       </SwitchDescription> |       </SwitchDescription> | ||||||
|     </div> |     </div> | ||||||
| @ -18,7 +18,7 @@ | |||||||
|       :disabled="disabled" |       :disabled="disabled" | ||||||
|       :model-value="modelValue" |       :model-value="modelValue" | ||||||
|       :class="[ |       :class="[ | ||||||
|         modelValue ? 'bg-primary-500' : 'bg-gray-200', |         modelValue ? 'bg-primary-500' : 'bg-gray-200 dark:bg-gray-900', | ||||||
|         'ml-4 relative inline-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', |         'ml-4 relative inline-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', | ||||||
|       ]" |       ]" | ||||||
|       @update:modelValue="onUpdate" |       @update:modelValue="onUpdate" | ||||||
| @ -26,7 +26,7 @@ | |||||||
|       <span |       <span | ||||||
|         aria-hidden="true" |         aria-hidden="true" | ||||||
|         :class="[ |         :class="[ | ||||||
|           modelValue ? 'translate-x-5' : 'translate-x-0', |           modelValue ? 'translate-x-5 dark:bg-white' : 'translate-x-0 dark:bg-gray-500', | ||||||
|           'inline-block h-5 w-5 rounded-full bg-white shadow ring-0 transition ease-in-out duration-200', |           'inline-block h-5 w-5 rounded-full bg-white shadow ring-0 transition ease-in-out duration-200', | ||||||
|         ]" |         ]" | ||||||
|       /> |       /> | ||||||
|  | |||||||
| @ -36,6 +36,7 @@ module.exports = { | |||||||
|           900: withOpacityValue('--color-primary-900'), |           900: withOpacityValue('--color-primary-900'), | ||||||
|         }, |         }, | ||||||
|         black: '#040405', |         black: '#040405', | ||||||
|  |         highlight: 'rgb(56, 189, 248)', | ||||||
|         red: colors.red, |         red: colors.red, | ||||||
|         teal: colors.teal, |         teal: colors.teal, | ||||||
|         gray: colors.slate, |         gray: colors.slate, | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	