& etc.
$FILTER=utf8_strtoupper($FILTER);
$OPTION=safe_GET('option');
$FORMAT=safe_GET('fmt');
$FIELD =safe_GET('field');
switch ($FIELD) {
case 'INDI':
$data=autocomplete_INDI($FILTER, $OPTION);
break;
case 'FAM':
$data=autocomplete_FAM($FILTER, $OPTION);
break;
case 'NOTE':
$data=autocomplete_NOTE($FILTER);
break;
case 'SOUR':
$data=autocomplete_SOUR($FILTER);
break;
case 'SOUR_TITL':
$data=autocomplete_SOUR($FILTER);
break;
case 'INDI_BURI_CEME':
$data=autocomplete_INDI_BURI_CEME($FILTER);
break;
case 'INDI_SOUR_PAGE':
$data=autocomplete_INDI_SOUR_PAGE($FILTER, $OPTION);
break;
case 'FAM_SOUR_PAGE':
$data=autocomplete_FAM_SOUR_PAGE($FILTER, $OPTION);
break;
case 'SOUR_PAGE':
$data=autocomplete_SOUR_PAGE($FILTER, $OPTION);
break;
case 'REPO':
$data=autocomplete_REPO($FILTER);
break;
case 'REPO_NAME':
$data=autocomplete_REPO_NAME($FILTER);
break;
case 'OBJE':
$data=autocomplete_OBJE($FILTER);
break;
case 'IFSRO':
$data=autocomplete_IFSRO($FILTER);
break;
case 'SURN':
$data=autocomplete_SURN($FILTER);
break;
case 'GIVN':
$data=autocomplete_GIVN($FILTER);
break;
case 'NAME':
$data=autocomplete_NAME($FILTER);
break;
case 'PLAC':
$data=autocomplete_PLAC($FILTER, $OPTION);
break;
default:
die("Bad arg: field={$FIELD}");
}
//-- sort
$data = array_unique($data);
uasort($data, "utf8_strcasecmp");
//-- output
if ($FORMAT=="json") {
//echo json_encode(array($FILTER, $data));//does not seem to work for some reason
$results=array();
foreach ($data as $k=>$v) {
$results[]=$v;
}
printf('["%s", %s]',$FILTER, json_encode($results));
} else {
foreach ($data as $k=>$v) {
echo "$v|$k\n";
}
}
/**
* returns INDIviduals matching filter
* @return Array of string
*/
function autocomplete_INDI($FILTER, $OPTION) {
global $MAX_ALIVE_AGE;
// when adding ASSOciate $OPTION may contain :
// current INDI/FAM [, current event date]
if ($OPTION) {
list($pid, $event_date) = explode("|", $OPTION."|");
$record=GedcomRecord::getInstance($pid); // INDI or FAM
$tmp=new GedcomDate($event_date);
$event_jd=$tmp->JD();
// INDI
$indi_birth_jd = 0;
if ($record && $record->getType()=="INDI") {
$indi_birth_jd=$record->getEstimatedBirthDate()->minJD();
}
// HUSB & WIFE
$husb_birth_jd = 0;
$wife_birth_jd = 0;
if ($record && $record->getType()=="FAM") {
$husb=$record->getHusband();
if ($husb) {
$husb_birth_jd = $husb->getEstimatedBirthDate()->minJD();
}
$wife=$record->getWife();
if ($wife) {
$wife_birth_jd = $wife->getEstimatedBirthDate()->minJD();
}
}
}
$rows=get_autocomplete_INDI($FILTER);
$data=array();
foreach ($rows as $row) {
$person=Person::getInstance($row);
if ($person->canDisplayName()) {
// filter ASSOciate
if ($OPTION && $event_jd) {
// no self-ASSOciate
if ($pid && $person->getXref()==$pid) {
continue;
}
// filter by birth date
$person_birth_jd=$person->getEstimatedBirthDate()->minJD();
if ($person_birth_jd) {
// born after event or not a contemporary
if ($event_jd && $person_birth_jd>$event_jd) {
continue;
} elseif ($indi_birth_jd && abs($indi_birth_jd-$person_birth_jd)>$MAX_ALIVE_AGE*365) {
continue;
} elseif ($husb_birth_jd && $wife_birth_jd && abs($husb_birth_jd-$person_birth_jd)>$MAX_ALIVE_AGE*365 && abs($wife_birth_jd-$person_birth_jd)>$MAX_ALIVE_AGE*365) {
continue;
} elseif ($husb_birth_jd && abs($husb_birth_jd-$person_birth_jd)>$MAX_ALIVE_AGE*365) {
continue;
} elseif ($wife_birth_jd && abs($wife_birth_jd-$person_birth_jd)>$MAX_ALIVE_AGE*365) {
continue;
}
}
// filter by death date
$person_death_jd=$person->getEstimatedDeathDate()->MaxJD();
if ($person_death_jd) {
// dead before event or not a contemporary
if ($event_jd && $person_death_jd<$event_jd) {
continue;
} elseif ($indi_birth_jd && $person_death_jd<$indi_birth_jd) {
continue;
} elseif ($husb_birth_jd && $wife_birth_jd && $person_death_jd<$husb_birth_jd && $person_death_jd<$wife_birth_jd) {
continue;
} elseif ($husb_birth_jd && $person_death_jd<$husb_birth_jd) {
continue;
} elseif ($wife_birth_jd && $person_death_jd<$wife_birth_jd) {
continue;
}
}
}
// display
$data[$person->getXref()]=$person->getFullName();
if ($OPTION && $event_date && $person->getBirthDate()->isOK()) {
$data[$person->getXref()].=" (".i18n::translate('Age')." ".$person->getBirthDate()->MinDate()->getAge(false, $event_jd).")";
} else {
$data[$person->getXref()].=" ".ltrim($person->getBirthYear(), "0")."-".ltrim($person->getDeathYear(), "0")."";
}
}
}
return $data;
}
/**
* returns FAMilies matching filter
* @return Array of string
*/
function autocomplete_FAM($FILTER, $OPTION) {
//-- search for INDI names
$ids=array_keys(autocomplete_INDI($FILTER, $OPTION));
$rows=get_autocomplete_FAM($FILTER, $ids);
$data=array();
foreach ($rows as $row) {
$family = Family::getInstance($row);
if ($family->canDisplayName()) {
$data[$row["xref"]] =
$family->getFullName().
" ".
ltrim($family->getMarriageYear(), "0").
"";
}
}
return $data;
}
/**
* returns NOTEs (Shared) matching filter
* @return Array of string
*/
function autocomplete_NOTE($FILTER) {
$rows=get_autocomplete_NOTE($FILTER);
$data=array();
foreach ($rows as $row) {
$note = Note::getInstance($row);
if ($note->canDisplayName()) {
$data[$row["xref"]] = $note->getFullName();
}
}
return $data;
}
/**
* returns SOURces matching filter
* @return Array of string
*/
function autocomplete_SOUR($FILTER) {
$rows=get_autocomplete_SOUR($FILTER);
$data=array();
foreach ($rows as $row) {
$source = Source::getInstance($row);
if ($source->canDisplayName()) {
$data[$row["xref"]] = $source->getFullName();
}
}
return $data;
}
/**
* returns SOUR:TITL matching filter
* @return Array of string
*/
function autocomplete_SOUR_TITL($FILTER) {
$rows=get_autocomplete_SOUR_TITL($FILTER);
$data=array();
foreach ($rows as $row) {
$source = Source::getInstance($row);
if ($source->canDisplayName()) {
$data[] = $source->getFullName();
}
}
return $data;
}
/**
* returns INDI_BURI_CEME matching filter
* @return Array of string
*/
function autocomplete_INDI_BURI_CEME($FILTER) {
$rows=get_autocomplete_INDI_BURI_CEME($FILTER);
$data=array();
foreach ($rows as $row) {
$person = Person::getInstance($row);
if ($person->canDisplayDetails()) {
$i = 1;
do {
$srec = get_sub_record("BURI", 1, $person->gedrec, $i++);
$ceme = get_gedcom_value("CEME", 2, $srec);
if (stripos($ceme, $FILTER)!==false || empty($FILTER)) {
$data[] = $ceme;
}
} while ($srec);
}
}
return $data;
}
/**
* returns INDI:SOUR:PAGE matching filter
* @return Array of string
*/
function autocomplete_INDI_SOUR_PAGE($FILTER, $OPTION) {
$rows=get_autocomplete_INDI_SOUR_PAGE($FILTER, $OPTION);
$data=array();
foreach ($rows as $row) {
$person = Person::getInstance($row);
if ($person->canDisplayDetails()) {
// a single INDI may have multiple level 1 and level 2 sources
for ($level=1; $level<=2; $level++) {
$i = 1;
do {
$srec = get_sub_record("SOUR @{$OPTION}@", $level, $person->gedrec, $i++);
$page = get_gedcom_value("PAGE", $level+1, $srec);
if (stripos($page, $FILTER)!==false || empty($FILTER)) {
$data[] = $page;
}
} while ($srec);
}
}
}
return $data;
}
/**
* returns FAM:SOUR:PAGE matching filter
* @return Array of string
*/
function autocomplete_FAM_SOUR_PAGE($FILTER, $OPTION) {
$rows=get_autocomplete_FAM_SOUR_PAGE($FILTER, $OPTION);
$data=array();
foreach ($rows as $row) {
$family = Family::getInstance($row);
if ($family->canDisplayDetails()) {
// a single FAM may have multiple level 1 and level 2 sources
for ($level=1; $level<=2; $level++) {
$i = 1;
do {
$srec = get_sub_record("SOUR @{$OPTION}@", $level, $family->gedrec, $i++);
$page = get_gedcom_value("PAGE", $level+1, $srec);
if (stripos($page, $FILTER)!==false || empty($FILTER)) {
$data[] = $page;
}
} while ($srec);
}
}
}
return $data;
}
/**
* returns SOUR:PAGE matching filter
* @return Array of string
*/
function autocomplete_SOUR_PAGE($FILTER, $OPTION) {
return array_merge(
autocomplete_INDI_SOUR_PAGE($FILTER, $OPTION),
autocomplete_FAM_SOUR_PAGE($FILTER, $OPTION));
}
/**
* returns REPOsitories matching filter
* @return Array of string
*/
function autocomplete_REPO($FILTER) {
$rows=get_autocomplete_REPO($FILTER);
$data=array();
foreach ($rows as $row) {
$repository = Repository::getInstance($row);
if ($repository->canDisplayName()) {
$data[$row["xref"]] = $repository->getFullName();
}
}
return $data;
}
/**
* returns REPO:NAME matching filter
* @return Array of string
*/
function autocomplete_REPO_NAME($FILTER) {
$rows=get_autocomplete_REPO_NAME($FILTER);
$data=array();
foreach ($rows as $row) {
$repository = Repository::getInstance($row);
if ($repository->canDisplayName()) {
$data[] = $repository->getFullName();
}
}
return $data;
}
/**
* returns OBJEcts matching filter
* @return Array of string
*/
function autocomplete_OBJE($FILTER) {
$rows=get_autocomplete_OBJE($FILTER);
$data=array();
foreach ($rows as $row) {
$media = Media::getInstance($row["m_media"]);
if ($media && $media->canDisplayDetails()) {
$data[$row["m_media"]] =
"
getXref().
"\" src=\"".
$media->getThumbnail().
"\" width=\"40\" /> ".
$media->getFullName();
}
}
return $data;
}
/**
* returns INDI FAM SOUR NOTE REPO OBJE matching filter
* @return Array of string
*/
function autocomplete_IFSRO() {
global $GEDCOM_ID_PREFIX, $FAM_ID_PREFIX, $SOURCE_ID_PREFIX, $NOTE_ID_PREFIX, $REPO_ID_PREFIX, $MEDIA_ID_PREFIX, $FILTER;
// is input text a gedcom xref ?
$prefix = strtoupper(substr($FILTER, 0, 1));
if (ctype_digit(substr($FILTER, 1))) {
if ($prefix == $GEDCOM_ID_PREFIX) {
return autocomplete_INDI($FILTER, '');
} elseif ($prefix == $FAM_ID_PREFIX) {
return autocomplete_FAM($FILTER, '');
} elseif ($prefix == $SOURCE_ID_PREFIX) {
return autocomplete_SOUR($FILTER);
} elseif ($prefix == $NOTE_ID_PREFIX) {
return autocomplete_NOTE($FILTER);
} elseif ($prefix == $REPO_ID_PREFIX) {
return autocomplete_REPO($FILTER);
} elseif ($prefix == $MEDIA_ID_PREFIX) {
return autocomplete_OBJE($FILTER);
}
}
return array_merge(
autocomplete_INDI($FILTER, ''),
autocomplete_FAM($FILTER, ''),
autocomplete_SOUR($FILTER),
autocomplete_NOTE($FILTER),
autocomplete_REPO($FILTER),
autocomplete_OBJE($FILTER)
);
}
/**
* returns SURNames matching filter
* @return Array of string
*/
function autocomplete_SURN($FILTER) {
return get_autocomplete_SURN($FILTER);
}
/**
* returns GIVenNames matching filter
* @return Array of string
*/
function autocomplete_GIVN($FILTER) {
$rows=get_autocomplete_GIVN($FILTER);
$data=array();
foreach ($rows as $row) {
$givn=$row->n_givn;
list($givn) = explode("/", $givn);
list($givn) = explode(",", $givn);
list($givn) = explode("*", $givn);
list($givn) = explode(" ", $givn);
if ($givn) {
$data[]=$row->n_givn;
}
}
return $data;
}
/**
* returns NAMEs matching filter
* @return Array of string
*/
function autocomplete_NAME($FILTER) {
return array_merge(autocomplete_GIVN($FILTER), autocomplete_SURN($FILTER));
}
/**
* returns PLACes matching filter
* @return Array of string City, County, State/Province, Country
*/
function autocomplete_PLAC($FILTER, $OPTION) {
global $USE_GEONAMES;
$data=get_autocomplete_PLAC($FILTER);
//-- no match => perform a geoNames query if enabled
if (empty($data) && $USE_GEONAMES) {
$url = "http://ws5.geonames.org/searchJSON".
"?name_startsWith=".urlencode($FILTER).
"&lang=".WT_LOCALE.
"&fcode=CMTY&fcode=ADM4&fcode=PPL&fcode=PPLA&fcode=PPLC".
"&style=full";
// try to use curl when file_get_contents not allowed
if (ini_get('allow_url_fopen')) {
$json = file_get_contents($url);
} elseif (function_exists('curl_init')) {
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
$json = curl_exec($ch);
curl_close($ch);
} else {
return $data;
}
$places = json_decode($json, true);
if ($places["geonames"]) {
foreach ($places["geonames"] as $k => $place) {
$data[] = $place["name"].", ".
$place["adminName2"].", ".
$place["adminName1"].", ".
$place["countryName"];
}
}
}
// split ?
if ($OPTION=="split") {
foreach ($data as $k=>$v) {
list($data[$k]) = explode(",", $v);
}
}
return $data;
}
?>