style: prettier
This commit is contained in:
		
							parent
							
								
									fe032622fa
								
							
						
					
					
						commit
						b217907768
					
				
					 2 changed files with 72 additions and 44 deletions
				
			
		|  | @ -7,7 +7,10 @@ interface Props { | |||
| const { href, text } = Astro.props as Props; | ||||
| --- | ||||
| 
 | ||||
| <div class="mt-6 not-prose"> | ||||
| <div | ||||
|   class="mt-6 not-prose" | ||||
|   class:list={[position === "centre" ? "flex justify-center" : null]} | ||||
| > | ||||
|   <a | ||||
|     class="inline-flex justify-center items-center py-3 px-6 w-full text-base font-medium text-white no-underline rounded-md duration-200 ease-in-out md:w-auto hover:bg-white focus:bg-white bg-blue-primary transition-color hover:text-blue-primary focus:text-blue-primary" | ||||
|     href={href} | ||||
|  |  | |||
|  | @ -1,5 +1,5 @@ | |||
| --- | ||||
| import { getCollection } from 'astro:content'; | ||||
| import { getCollection } from "astro:content"; | ||||
| import _ from "lodash"; | ||||
| 
 | ||||
| interface Props { | ||||
|  | @ -9,58 +9,83 @@ interface Props { | |||
| } | ||||
| 
 | ||||
| const defaultNames = [ | ||||
|   'mike-karthauser', | ||||
|   'tawny-bartlett', | ||||
|   'joe-howell', | ||||
|   'michael-itkoff', | ||||
|   'mick-felton', | ||||
|   'duncan-davidson', | ||||
|   'adam-cuddihy', | ||||
|   'huw-davies', | ||||
|   'scott-euser', | ||||
|   'brian-hartwell', | ||||
|   'alan-hatch', | ||||
|   'holly-ross', | ||||
|   'josh-mitchell', | ||||
|   'brian-healy', | ||||
|   'chris-jarvis', | ||||
|   'daniel-easterbrook', | ||||
|   'anonymous', | ||||
|   "mike-karthauser", | ||||
|   "tawny-bartlett", | ||||
|   "joe-howell", | ||||
|   "michael-itkoff", | ||||
|   "mick-felton", | ||||
|   "duncan-davidson", | ||||
|   "adam-cuddihy", | ||||
|   "huw-davies", | ||||
|   "scott-euser", | ||||
|   "brian-hartwell", | ||||
|   "alan-hatch", | ||||
|   "holly-ross", | ||||
|   "josh-mitchell", | ||||
|   "brian-healy", | ||||
|   "chris-jarvis", | ||||
|   "daniel-easterbrook", | ||||
|   "anonymous", | ||||
| ]; | ||||
| 
 | ||||
| const { title, titleClasses } = Astro.props as Props; | ||||
| const names = _(Astro.props.names || defaultNames); | ||||
| 
 | ||||
| const testimonials = await getCollection('testimonial', ({ id }) => names.includes(id)); | ||||
| const testimonials = await getCollection("testimonial", ({ id }) => | ||||
|   names.includes(id) | ||||
| ); | ||||
| 
 | ||||
| const sortedTestimonials = _(names) | ||||
|   .flatMap(name => testimonials.filter(testimonial => testimonial.id === name)) | ||||
|   .flatMap((name) => | ||||
|     testimonials.filter((testimonial) => testimonial.id === name) | ||||
|   ) | ||||
|   .value(); | ||||
| --- | ||||
| 
 | ||||
| {testimonials && ( | ||||
|   <h2 class={titleClasses ? titleClasses.join(' ') : null}>{title ?? 'What others have said'}</h2> | ||||
| { | ||||
|   testimonials && ( | ||||
|     <section> | ||||
|       <h2 class={titleClasses ? titleClasses.join(" ") : null}> | ||||
|         {title ?? "What others have said"} | ||||
|       </h2> | ||||
| 
 | ||||
|   <div class="mt-6 space-y-14"> | ||||
|     {_(sortedTestimonials).map(({ data: { image, name, tagline, text, url } }) => ( | ||||
|       <article> | ||||
|         <blockquote class="mt-4" set:html={text} /> | ||||
|       <div class="mt-8 space-y-10"> | ||||
|         {_(sortedTestimonials).map( | ||||
|           ({ data: { image, name, tagline, text, url } }) => ( | ||||
|             <article> | ||||
|               <blockquote class="mt-4" set:html={text} /> | ||||
| 
 | ||||
|         <footer class="flex items-center space-x-4 space-x-reverse"> | ||||
|           <span class="text-base"> | ||||
|             {url | ||||
|               ? <a href={url}>{name}{tagline && (<> - {tagline}</>)}</a> | ||||
|               : <>{name}{tagline && (<> - {tagline}</>)}</> | ||||
|             } | ||||
|           </span> | ||||
|               <footer class="flex items-center space-x-4 space-x-reverse"> | ||||
|                 <span class="text-base"> | ||||
|                   {url ? ( | ||||
|                     <a href={url}> | ||||
|                       {name} | ||||
|                       {tagline && <> - {tagline}</>} | ||||
|                     </a> | ||||
|                   ) : ( | ||||
|                     <> | ||||
|                       {name} | ||||
|                       {tagline && <> - {tagline}</>} | ||||
|                     </> | ||||
|                   )} | ||||
|                 </span> | ||||
| 
 | ||||
|           {image && ( | ||||
|             <span class="order-first not-prose"> | ||||
|               <img width="50" height="50" class="rounded-full border w-15 h-15" alt={`Photo of ${name}`} src={`/images/recommendations/${image}`} /> | ||||
|             </span> | ||||
|           )} | ||||
|         </footer> | ||||
|       </article> | ||||
|     ))} | ||||
|   </div> | ||||
| )} | ||||
|                 {image && ( | ||||
|                   <span class="order-first not-prose"> | ||||
|                     <img | ||||
|                       alt={`Photo of ${name}`} | ||||
|                       class="rounded-full border" | ||||
|                       height="50px" | ||||
|                       src={`/images/recommendations/${image}`} | ||||
|                       width="50px" | ||||
|                     /> | ||||
|                   </span> | ||||
|                 )} | ||||
|               </footer> | ||||
|             </article> | ||||
|           ) | ||||
|         )} | ||||
|       </div> | ||||
|     </section> | ||||
|   ) | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue