@ -19,14 +19,14 @@ 
			
		
	
		
		
			
				
					        / > < / a >         / > < / a >  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					        < div >         < div >  
			
		
	
		
		
			
				
					
					          < h3  class = "font-semibold" > < a  href = "" > [ POSTER_NAME ] < / a > < / h3 >           < h3  class = "font-semibold" >  
			
				
				
			
		
	
		
		
			
				
					
					          < p  class = "ms-auto text-xs text-slate-500 italic" > [ TIMESTAMP ] < / p >             < a  href = ""  class = "hover:underline"  >  
			
				
				
			
		
	
		
		
			
				
					
					          <!--  < p               { {  record . giver . known  ?  record . giver . displayName  :  'Anonymous Giver'  } }   
			
				
				
			
		
	
		
		
			
				
					
					            class = "ms-auto text-xs text-slate-500 italic"             < / a >  
			
				
				
			
		
	
		
		
			
				
					
					            : title = "record.timestamp"            < / h3 >  
			
				
				
			
		
	
		
		
			
				
					
					          >           < p  class = "ms-auto text-xs text-slate-500 italic" >  
			
				
				
			
		
	
		
		
			
				
					
					            { {  formattedTimestamp   } }             { {  friendlyDate   } }  
			
				
				
			
		
	
		
		
			
				
					
					          < / p >  -- >            < / p >  
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					        < / div >         < / div >  
			
		
	
		
		
			
				
					      < / div >       < / div >  
			
		
	
		
		
			
				
					
 
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -55,34 +55,35 @@ 
			
		
	
		
		
			
				
					          class = "w-28 sm:w-48 text-center bg-white border border-slate-200 rounded p-2 sm:p-3"           class = "w-28 sm:w-48 text-center bg-white border border-slate-200 rounded p-2 sm:p-3"  
			
		
	
		
		
			
				
					        >         >  
			
		
	
		
		
			
				
					          < div  class = "relative w-fit mx-auto" >           < div  class = "relative w-fit mx-auto" >  
			
		
	
		
		
			
				
					
					            <!--             < template  v-if ="record.giver.profileImageUrl" >  
			
				
				
			
		
	
		
		
			
				
					
					              If  unknown  user ,  icon = "person-circle-question"               < EntityIcon  
			
				
				
			
		
	
		
		
			
				
					
					              If  project  with  no  photo ,  icon = "image"                 : profile - image - url = "record.giver.profileImageUrl"  
			
				
				
			
		
	
		
		
			
				
					
					            -- >                 : class = " [  
			
				
				
			
		
	
		
		
			
				
					
					            < fa                   record . giver . known  
			
				
				
			
		
	
		
		
			
				
					
					              v - if = "!record.giver.profileImageUrl"                     ?  'rounded-full size-12 sm:size-24 object-cover'  
			
				
				
			
		
	
		
		
			
				
					
					              icon = "person-circle-question"                     :  'rounded size-12 sm:size-24 object-cover'  
			
				
				
			
		
	
		
		
			
				
					
					              class = "text-slate-300 text-5xl sm:text-8xl"                 ] "  
			
				
				
			
		
	
		
		
			
				
					
					            / >               / >  
			
				
				
			
		
	
		
		
			
				
					
					            < EntityIcon             < / template >  
			
				
				
			
		
	
		
		
			
				
					
					              v - else             < template  v-else >  
			
				
				
			
		
	
		
		
			
				
					
					              : profile - image - url = "record.giver.profileImageUrl"               <!--  Identicon  for  DIDs  -- >  
			
				
				
			
		
	
		
		
			
				
					
					              : class = "               < img  
			
				
				
			
		
	
		
		
			
				
					
					                record . giver . known                 v - if = "record.giver.did"  
			
				
				
			
		
	
		
		
			
				
					
					                  ?  'rounded-full size-12 sm:size-24 object-cover'                 : src = "`https://a.fsdn.com/con/app/proj/identicons/screenshots/225506.jpg`"  
			
				
				
			
		
	
		
		
			
				
					
					                  :  'rounded size-12 sm:size-24 object-cover'                 : class = " [  
			
				
				
			
		
	
		
		
			
				
					
					              "                   record . giver . known  
			
				
				
			
		
	
		
		
			
				
					
					            / >                     ?  'rounded-full size-12 sm:size-24'  
			
				
				
			
		
	
		
		
			
				
					
					            <!--                     :  'rounded size-12 sm:size-24'  
			
				
				
			
		
	
		
		
			
				
					
					            < span                 ] "  
			
				
				
			
		
	
		
		
			
				
					
					              class = "absolute -end-3 -bottom-2 bg-slate-400 rounded-full leading-1.25 p-1 sm:px-1.5 -mt-6 border sm:border-2 border-white text-xs sm:text-base"                 alt = "Identicon"  
			
				
				
			
		
	
		
		
			
				
					
					            >               / >  
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					              <!--  Fallback  icon  for  projects  -- >  
			
		
	
		
		
			
				
					              < fa               < fa  
			
		
	
		
		
			
				
					
					                : icon = "record.giver.known ? 'user' : 'hammer'"                 v - else  
			
				
				
			
		
	
		
		
			
				
					
					                class = "fa-fw text-white"                 icon = "person-circle-question"  
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					                class = "text-slate-300 text-5xl sm:text-8xl"  
			
		
	
		
		
			
				
					              / >               / >  
			
		
	
		
		
			
				
					
					            < / span >             < / template >  
			
				
				
			
		
	
		
		
			
				
					            -- >  
			
		
	
		
		
	
		
		
			
				
					          < / div >           < / div >  
			
		
	
		
		
			
				
					          < div  class = "text-xs mt-2 line-clamp-2" >           < div  class = "text-xs mt-2 line-clamp-2" >  
			
		
	
		
		
			
				
					            < fa             < fa  
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -109,34 +110,35 @@ 
			
		
	
		
		
			
				
					          class = "w-28 sm:w-48 text-center bg-white border border-slate-200 rounded p-2 sm:p-3"           class = "w-28 sm:w-48 text-center bg-white border border-slate-200 rounded p-2 sm:p-3"  
			
		
	
		
		
			
				
					        >         >  
			
		
	
		
		
			
				
					          < div  class = "relative w-fit mx-auto" >           < div  class = "relative w-fit mx-auto" >  
			
		
	
		
		
			
				
					
					            <!--             < template  v-if ="record.receiver.profileImageUrl" >  
			
				
				
			
		
	
		
		
			
				
					
					              If  unknown  user ,  icon = "person-circle-question"               < EntityIcon  
			
				
				
			
		
	
		
		
			
				
					
					              If  project  with  no  photo ,  icon = "image"                 : profile - image - url = "record.receiver.profileImageUrl"  
			
				
				
			
		
	
		
		
			
				
					
					            -- >                 : class = " [  
			
				
				
			
		
	
		
		
			
				
					
					            < fa                   record . receiver . known  
			
				
				
			
		
	
		
		
			
				
					
					              v - if = "!record.receiver.profileImageUrl"                     ?  'rounded-full size-12 sm:size-24 object-cover'  
			
				
				
			
		
	
		
		
			
				
					
					              icon = "image"                     :  'rounded size-12 sm:size-24 object-cover'  
			
				
				
			
		
	
		
		
			
				
					
					              class = "text-slate-300 text-5xl sm:text-8xl"                 ] "  
			
				
				
			
		
	
		
		
			
				
					
					            / >               / >  
			
				
				
			
		
	
		
		
			
				
					
					            < EntityIcon             < / template >  
			
				
				
			
		
	
		
		
			
				
					
					              v - else             < template  v-else >  
			
				
				
			
		
	
		
		
			
				
					
					              : profile - image - url = "record.receiver.profileImageUrl"               <!--  Identicon  for  DIDs  -- >  
			
				
				
			
		
	
		
		
			
				
					
					              : class = "               < img  
			
				
				
			
		
	
		
		
			
				
					
					                record . receiver . known                 v - if = "record.receiver.did"  
			
				
				
			
		
	
		
		
			
				
					
					                  ?  'rounded-full size-12 sm:size-24 object-cover'                 : src = "`https://a.fsdn.com/con/app/proj/identicons/screenshots/225506.jpg`"  
			
				
				
			
		
	
		
		
			
				
					
					                  :  'rounded size-12 sm:size-24 object-cover'                 : class = " [  
			
				
				
			
		
	
		
		
			
				
					
					              "                   record . receiver . known  
			
				
				
			
		
	
		
		
			
				
					
					            / >                     ?  'rounded-full size-12 sm:size-24'  
			
				
				
			
		
	
		
		
			
				
					
					            <!--                     :  'rounded size-12 sm:size-24'  
			
				
				
			
		
	
		
		
			
				
					
					            < span                 ] "  
			
				
				
			
		
	
		
		
			
				
					
					              class = "absolute -end-3 -bottom-2 bg-slate-400 rounded-full leading-1.25 p-1 sm:px-1.5 -mt-6 border sm:border-2 border-white text-xs sm:text-base"                 alt = "Identicon"  
			
				
				
			
		
	
		
		
			
				
					
					            >               / >  
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					              <!--  Fallback  icon  for  projects  -- >  
			
		
	
		
		
			
				
					              < fa               < fa  
			
		
	
		
		
			
				
					
					                : icon = "record.receiver.known ? 'user' : 'hammer'"                 v - else  
			
				
				
			
		
	
		
		
			
				
					
					                class = "fa-fw text-white"                 icon = "image"  
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					                class = "text-slate-300 text-5xl sm:text-8xl"  
			
		
	
		
		
			
				
					              / >               / >  
			
		
	
		
		
			
				
					
					            < / span >             < / template >  
			
				
				
			
		
	
		
		
			
				
					            -- >  
			
		
	
		
		
	
		
		
			
				
					          < / div >           < / div >  
			
		
	
		
		
			
				
					          < div  class = "text-xs mt-2 line-clamp-2" >           < div  class = "text-xs mt-2 line-clamp-2" >  
			
		
	
		
		
			
				
					            < fa             < fa  
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -164,7 +166,14 @@ 
			
		
	
		
		
			
				
					        < fa  icon = "circle-info"  class = "fa-fw text-slate-500"  / >         < fa  icon = "circle-info"  class = "fa-fw text-slate-500"  / >  
			
		
	
		
		
			
				
					      < / a >       < / a >  
			
		
	
		
		
			
				
					      < button       < button  
			
		
	
		
		
			
				
					
					        class = "text-sm text-white bg-gradient-to-b from-slate-400 to-slate-700 shadow-[inset_0_-1px_0_0_rgba(0,0,0,0.5)] px-3 py-1.5 ms-auto rounded-md"         @ click = "handleConfirmClick"  
			
				
				
			
		
	
		
		
	
		
		
			
				
					        : disabled = "!canConfirm"  
			
		
	
		
		
			
				
					        class = "text-sm text-white px-3 py-1.5 ms-auto rounded-md"  
			
		
	
		
		
			
				
					        : class = " [  
			
		
	
		
		
			
				
					          canConfirm   
			
		
	
		
		
			
				
					            ?  'bg-gradient-to-b from-blue-400 to-blue-700 shadow-[inset_0_-1px_0_0_rgba(0,0,0,0.5)]'  
			
		
	
		
		
			
				
					            :  'bg-gradient-to-b from-slate-400 to-slate-700 shadow-[inset_0_-1px_0_0_rgba(0,0,0,0.5)] opacity-50'  
			
		
	
		
		
			
				
					        ] "  
			
		
	
		
		
			
				
					      >       >  
			
		
	
		
		
			
				
					        Confirm         Confirm  
			
		
	
		
		
			
				
					      < / button >       < / button >  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -176,6 +185,8 @@ 
			
		
	
		
		
			
				
					import  {  Component ,  Prop ,  Vue  }  from  "vue-facing-decorator" ; import  {  Component ,  Prop ,  Vue  }  from  "vue-facing-decorator" ;  
			
		
	
		
		
			
				
					import  {  GiveRecordWithContactInfo  }  from  "../types" ; import  {  GiveRecordWithContactInfo  }  from  "../types" ;  
			
		
	
		
		
			
				
					import  EntityIcon  from  "./EntityIcon.vue" ; import  EntityIcon  from  "./EntityIcon.vue" ;  
			
		
	
		
		
			
				
					import  {  isGiveClaimType ,  notifyWhyCannotConfirm  }  from  "../libs/util" ;  
			
		
	
		
		
			
				
					import  {  containsHiddenDid  }  from  "../libs/endorserServer" ;  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					@ Component ( { @ Component ( {  
			
		
	
		
		
			
				
					  components :  {   components :  {  
			
		
	
	
		
		
			
				
					
						
						
						
							
								 
						
					 
					@ -185,6 +196,9 @@ import EntityIcon from "./EntityIcon.vue"; 
			
		
	
		
		
			
				
					export  default  class  ActivityListItem  extends  Vue  { export  default  class  ActivityListItem  extends  Vue  {  
			
		
	
		
		
			
				
					  @ Prop ( )  record ! :  GiveRecordWithContactInfo ;   @ Prop ( )  record ! :  GiveRecordWithContactInfo ;  
			
		
	
		
		
			
				
					  @ Prop ( )  lastViewedClaimId ? :  string ;   @ Prop ( )  lastViewedClaimId ? :  string ;  
			
		
	
		
		
			
				
					  @ Prop ( )  isRegistered ! :  boolean ;  
			
		
	
		
		
			
				
					  @ Prop ( )  activeDid ! :  string ;  
			
		
	
		
		
			
				
					  @ Prop ( )  confirmerIdList ? :  string [ ] ;  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					  private  formatAmount ( claim :  unknown ) :  string  {   private  formatAmount ( claim :  unknown ) :  string  {  
			
		
	
		
		
			
				
					    const  amount  =  claim . object ? . amountOfThisGood     const  amount  =  claim . object ? . amountOfThisGood  
			
		
	
	
		
		
			
				
					
						
							
								 
						
						
							
								 
						
						
					 
					@ -274,5 +288,39 @@ export default class ActivityListItem extends Vue { 
			
		
	
		
		
			
				
					    / /   A d d   y o u r   t i m e s t a m p   f o r m a t t i n g   l o g i c   h e r e     / /   A d d   y o u r   t i m e s t a m p   f o r m a t t i n g   l o g i c   h e r e  
			
		
	
		
		
			
				
					    return  this . record . timestamp ;     return  this . record . timestamp ;  
			
		
	
		
		
			
				
					  }   }  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					  get  canConfirm ( ) :  boolean  {  
			
		
	
		
		
			
				
					    if  ( ! this . isRegistered )  return  false ;  
			
		
	
		
		
			
				
					    if  ( ! isGiveClaimType ( this . record . fullClaim ? . [ "@type" ] ) )  return  false ;  
			
		
	
		
		
			
				
					    if  ( this . confirmerIdList ? . includes ( this . activeDid ) )  return  false ;  
			
		
	
		
		
			
				
					    if  ( this . record . issuerDid  ===  this . activeDid )  return  false ;  
			
		
	
		
		
			
				
					    if  ( containsHiddenDid ( this . record . fullClaim ) )  return  false ;  
			
		
	
		
		
			
				
					    return  true ;  
			
		
	
		
		
			
				
					  }  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					  handleConfirmClick ( )  {  
			
		
	
		
		
			
				
					    if  ( ! this . canConfirm )  {  
			
		
	
		
		
			
				
					      notifyWhyCannotConfirm (  
			
		
	
		
		
			
				
					        this . $notify ,  
			
		
	
		
		
			
				
					        this . isRegistered ,  
			
		
	
		
		
			
				
					        this . record . fullClaim ? . [ "@type" ] ,  
			
		
	
		
		
			
				
					        this . record ,  
			
		
	
		
		
			
				
					        this . activeDid ,  
			
		
	
		
		
			
				
					        this . confirmerIdList  
			
		
	
		
		
			
				
					      ) ;  
			
		
	
		
		
			
				
					      return ;  
			
		
	
		
		
			
				
					    }  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					    this . $emit ( 'confirmClaim' ,  this . record ) ;  
			
		
	
		
		
			
				
					  }  
			
		
	
		
		
			
				
					
 
			
		
	
		
		
			
				
					  get  friendlyDate ( ) :  string  {  
			
		
	
		
		
			
				
					    const  date  =  new  Date ( this . record . issuedAt ) ;  
			
		
	
		
		
			
				
					    return  date . toLocaleDateString ( undefined ,  {  
			
		
	
		
		
			
				
					      year :  'numeric' ,  
			
		
	
		
		
			
				
					      month :  'short' ,  
			
		
	
		
		
			
				
					      day :  'numeric'  
			
		
	
		
		
			
				
					    } ) ;  
			
		
	
		
		
			
				
					  }  
			
		
	
		
		
			
				
					} }  
			
		
	
		
		
			
				
					< / script > < / script >