2022-09-08 21:40:48 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								import  {  TagConfigJson  }  from  "./TagConfigJson"  
						 
					
						
							
								
									
										
										
										
											2021-07-03 14:35:44 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								export  interface  DeleteConfigJson  {  
						 
					
						
							
								
									
										
										
										
											2023-06-23 16:14:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    / * * * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  By  default ,  the  contributor  needs  20  previous  changesets  to  delete  points  edited  by  others . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  For  some  small  features  ( e . g .  bicycle  racks )  this  is  too  much  and  this  requirement  can  be  lowered  or  dropped ,  which  can  be  done  here . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  type :  nat 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  question : How  many  changesets  must  a  contributor  have  before  being  allowed  to  delete  a  point ? 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     * / 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    neededChangesets? : number 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-07-03 14:35:44 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    / * * * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  By  default ,  three  reasons  to  delete  a  point  are  shown : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  -  The  point  does  not  exist  anymore 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  -  The  point  was  a  testing  point 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  -  THe  point  could  not  be  found 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  However ,  for  some  layers ,  there  might  be  different  or  more  specific  reasons  for  deletion  which  can  be  user  friendly  to  set ,  e . g . : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  -  the  shop  has  closed 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  -  the  climbing  route  has  been  closed  of  for  nature  conservation  reasons 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  -  . . . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  These  reasons  can  be  stated  here  and  will  be  shown  in  the  list  of  options  the  user  can  choose  from 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     * / 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    extraDeleteReasons ? :  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        / * * 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-23 16:14:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								         *  The  text  that  will  be  shown  to  the  user  as  option  for  why  this  point  does  not  exist  anymore . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								         *  Note  that  the  most  common  reasons  ( test  point ,  does  not  exist  anymore ,  cannot  be  found )  are  already  offered  by  default 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								         * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								         *  question : For  what  extra  reason  might  this  feature  be  removed  in  real - life ? 
							 
						 
					
						
							
								
									
										
										
										
											2021-07-03 14:35:44 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								         * / 
							 
						 
					
						
							
								
									
										
										
										
											2022-09-08 21:40:48 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        explanation : string  |  any 
							 
						 
					
						
							
								
									
										
										
										
											2021-07-03 14:35:44 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								        / * * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								         *  The  text  that  will  be  uploaded  into  the  changeset  or  will  be  used  in  the  fixme  in  case  of  a  soft  deletion 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								         *  Should  be  a  few  words ,  in  english 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-23 16:14:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								         * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								         *  question : What  should  be  added  to  the  changeset  as  delete  reason ? 
							 
						 
					
						
							
								
									
										
										
										
											2021-07-03 14:35:44 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								         * / 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        changesetMessage : string 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } [ ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    / * * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  In  some  cases ,  a  ( starting )  contributor  might  wish  to  delete  a  feature  even  though  deletion  is  not  appropriate . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  ( The  most  relevant  case  are  small  paths  running  over  private  property .  These  should  be  marked  as  'private'  instead  of  deleted ,  as  the  community  might  trace  the  path  again  from  aerial  imagery ,  gettting  us  back  to  the  original  situation ) . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  By  adding  a  'nonDeleteMapping' ,  an  option  can  be  added  into  the  list  which  will  retag  the  feature . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  It  is  important  that  the  feature  will  be  retagged  in  such  a  way  that  it  won ' t  be  picked  up  by  the  layer  anymore ! 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     * / 
							 
						 
					
						
							
								
									
										
										
										
											2022-05-01 04:17:40 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    nonDeleteMappings ? :  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        / * * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								         *  The  tags  that  will  be  given  to  the  object . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								         *  This  must  remove  tags  so  that  the  'source/osmTags'  won ' t  match  anymore 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-23 16:14:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								         * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								         *  question : What  tags  should  be  applied  to  the  object ? 
							 
						 
					
						
							
								
									
										
										
										
											2022-05-01 04:17:40 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								         * / 
							 
						 
					
						
							
								
									
										
										
										
											2022-09-08 21:40:48 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if :  TagConfigJson 
							 
						 
					
						
							
								
									
										
										
										
											2022-05-01 04:17:40 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        / * * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								         *  The  human  explanation  for  the  options 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-23 16:14:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								         * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								         *  question : What  text  should  be  shown  to  the  contributor  for  this  reason ? 
							 
						 
					
						
							
								
									
										
										
										
											2022-05-01 04:17:40 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								         * / 
							 
						 
					
						
							
								
									
										
										
										
											2022-09-08 21:40:48 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        then : string  |  any 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    } [ ] 
							 
						 
					
						
							
								
									
										
										
										
											2021-07-03 14:35:44 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    / * * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  In  some  cases ,  the  contributor  is  not  allowed  to  delete  the  current  feature  ( e . g .  because  it  isn 't a point, the point is referenced by a relation or the user isn' t  experienced  enough ) . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  To  still  offer  the  user  a  'delete' - option ,  the  feature  is  retagged  with  these  tags .  This  is  a  soft  deletion ,  as  the  point  isn 't actually removed from OSM but rather marked as ' disused ' 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  It  is  important  that  the  feature  will  be  retagged  in  such  a  way  that  it  won ' t  be  picked  up  by  the  layer  anymore ! 
							 
						 
					
						
							
								
									
										
										
										
											2021-08-07 23:11:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								     * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  Example  ( note  that  "amenity="  erases  the  'amenity' - key  alltogether ) : 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-23 16:14:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								     * 
							 
						 
					
						
							
								
									
										
										
										
											2021-07-03 14:35:44 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								     *  ` ` ` 
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *      "and" :  [ "disussed:amenity=public_bookcase" ,  "amenity=" ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  ` ` ` 
 
							 
						 
					
						
							
								
									
										
										
										
											2021-08-07 23:11:34 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								     * 
							 
						 
					
						
							
								
									
										
										
										
											2021-07-03 14:35:44 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								     *  or  ( notice  the  use  of  the  ':=' - tag  to  copy  the  old  value  of  'shop=*'  into  'disused:shop=' ) : 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-23 16:14:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								     * 
							 
						 
					
						
							
								
									
										
										
										
											2021-07-03 14:35:44 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								     *  ` ` ` 
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *      "and" :  [ "disused:shop:={shop}" ,  "shop=" ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  ` ` ` 
 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-23 16:14:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								     * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  question : If  a  hard  delete  is  not  possible ,  what  tags  should  be  applied  to  mark  this  feature  as  deleted ? 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  type :  tag 
							 
						 
					
						
							
								
									
										
										
										
											2021-07-03 14:35:44 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								     * / 
							 
						 
					
						
							
								
									
										
										
										
											2022-09-08 21:40:48 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    softDeletionTags? : TagConfigJson 
							 
						 
					
						
							
								
									
										
										
										
											2022-12-06 00:49:34 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    / * * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  Set  this  flag  if  the  default  delete  reasons  should  be  omitted  from  the  dialog . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  This  requires  at  least  one  extraDeleteReason  or  nonDeleteMapping 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-23 16:14:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								     * 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  question : Should  the  default  delete  reasons  be  hidden ? 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  iftrue : Hide  the  default  delete  reasons 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  iffalse : Show  the  default  delete  reasons 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     *  ifunset : Show  the  default  delete  reasons  ( default  behaviour ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-12-06 00:49:34 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								     * / 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    omitDefaultDeleteReasons? : false  |  boolean 
							 
						 
					
						
							
								
									
										
										
										
											2022-09-08 21:40:48 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								}