<?php |
<?php |
|
|
include_once('include/common.inc.php'); |
include_once('include/common.inc.php'); |
include_header(); |
|
|
|
function displayValue($key, $value, $mode) { |
function displayValue($key, $value, $mode) { |
global $db; |
global $db, $schemas; |
if ($mode == "view") { |
if ($mode == "view") { |
|
if (strpos($key, "_") === 0 || $key == "metadata" || $key == "metaTags" || $key == "statistics") |
|
return; |
|
echo "<tr>"; |
|
|
|
echo "<td class='$key'>"; |
|
if (isset($schemas['agency']["properties"][$key])) { |
|
echo $schemas['agency']["properties"][$key]['x-title'] . "<br><small>" . $schemas['agency']["properties"][$key]['description'] . "</small>"; |
|
} |
|
echo "</td><td>"; |
if (is_array($value)) { |
if (is_array($value)) { |
echo "<tr><td>$key</td><td><ol>"; |
echo "<ol>"; |
foreach ($value as $subkey => $subvalue) { |
foreach ($value as $subkey => $subvalue) { |
echo "<li>$subvalue</li>"; |
|
|
echo "<li "; |
|
if (isset($schemas['agency']["properties"][$key]['x-property'])) { |
|
echo ' property="' . $schemas['agency']["properties"][$key]['x-property'] . '" '; |
|
} if (isset($schemas['agency']["properties"][$key]['x-itemprop'])) { |
|
echo ' itemprop="' . $schemas['agency']["properties"][$key]['x-itemprop'] . '" '; |
|
} |
|
echo " >"; |
|
|
|
echo "$subvalue</li>"; |
} |
} |
echo "</ol></td></tr>"; |
echo "</ol></td></tr>"; |
} else { |
} else { |
echo "<tr><td>$key</td><td>$value</td></tr>"; |
if (isset($schemas['agency']["properties"][$key]['x-property'])) { |
} |
echo '<span property="' . $schemas['agency']["properties"][$key]['x-property'] . '">'; |
|
} else { |
|
echo "<span>"; |
|
} |
|
|
|
if ((strpos($key, "URL") > 0 || $key == 'website') && $value != "") { |
|
echo "<a " . ($key == 'website' ? 'itemprop="url"' : '') . " href='$value'>$value</a>"; |
|
} else if ($key == 'abn') { |
|
echo "<a href='http://www.abr.business.gov.au/SearchByAbn.aspx?SearchText=$value'>$value</a>"; |
|
} else { |
|
echo "$value"; |
|
} |
|
echo "</span>"; |
|
} |
|
echo "</td></tr>"; |
} |
} |
if ($mode == "edit") { |
if ($mode == "edit") { |
if (is_array($value)) { |
if (is_array($value)) { |
echo '<div class="row"> |
echo '<div class="row"> |
<div class="seven columns"> |
<div class="seven columns"> |
<fieldset> |
<fieldset> |
<h5>' . $key . '</h5>'; |
<h5>' . $key . '</h5>'; |
foreach ($value as $subkey => $subvalue) { |
foreach ($value as $subkey => $subvalue) { |
echo "<label>$subkey</label><input class='input-text' type='text' id='$key$subkey' name='$key" . '[' . $subkey . "]' value='$subvalue'/></tr>"; |
echo "<label>$subkey</label><input class='input-text' type='text' id='$key$subkey' name='$key" . '[' . $subkey . "]' value='$subvalue'/></tr>"; |
} |
} |
echo "</fieldset> |
echo "</fieldset> |
</div> |
</div> |
</div>"; |
</div>"; |
} else { |
} else { |
if (strpos($key, "_") === 0) { |
if (strpos($key, "_") === 0) { |
echo"<input type='hidden' id='$key' name='$key' value='$value'/>"; |
echo"<input type='hidden' id='$key' name='$key' value='$value'/>"; |
} else if ($key == "parentOrg") { |
} else if ($key == "parentOrg") { |
echo "<label for='$key'>$key</label><select id='$key' name='$key'>"; |
echo "<label for='$key'>$key</label><select id='$key' name='$key'><option value=''> Select... </option>"; |
$rows = $db->get_view("app", "byDeptStateName")->rows; |
$rows = $db->get_view("app", "byDeptStateName")->rows; |
//print_r($rows); |
//print_r($rows); |
foreach ($rows as $row) { |
foreach ($rows as $row) { |
echo "<option value='{$row->value}'".(($row->value == $value) ? "SELECTED":"")." >".str_replace("Department of ","",$row->key)."</option>"; |
echo "<option value='{$row->value}'" . (($row->value == $value) ? "SELECTED" : "") . " >" . str_replace("Department of ", "", $row->key) . "</option>"; |
} |
} |
echo" </select>"; |
echo" </select>"; |
} else if (strpos($key, "has") === 0) { |
|
echo "<label for='$key'><input type='checkbox' id='$key' name='$key' ".(($value=='true')?"checked='$value'":"")."> $key</label>"; |
|
} else { |
} else { |
echo "<label>$key</label><input class='input-text' type='text' id='$key' name='$key' value='$value'/>"; |
echo "<label>$key</label><input class='input-text' type='text' id='$key' name='$key' value='$value'/>"; |
if ((strpos($key,"URL") > 0 || $key == 'website')&& $value != "") { |
if ((strpos($key, "URL") > 0 || $key == 'website') && $value != "") { |
echo "<a href='$value'>view</a>"; |
echo "<a " . ($key == 'website' ? 'itemprop="url"' : '') . " href='$value'>view</a>"; |
} |
} |
if ($key == 'abn') { |
if ($key == 'abn') { |
echo "<a href='http://www.abr.business.gov.au/SearchByAbn.aspx?SearchText=$value'>view abn</a>"; |
echo "<a href='http://www.abr.business.gov.au/SearchByAbn.aspx?SearchText=$value'>view abn</a>"; |
} |
} |
} |
} |
} |
} |
} |
} |
// |
// |
} |
} |
|
|
function addDefaultFields($row) { |
function addDefaultFields($row) { |
global $schemas; |
global $schemas; |
$defaultFields = array_keys($schemas['agency']['properties']); |
$defaultFields = array_keys($schemas['agency']['properties']); |
foreach ($defaultFields as $defaultField) { |
foreach ($defaultFields as $defaultField) { |
if (!isset($row[$defaultField])) { |
if (!isset($row[$defaultField])) { |
if ($schemas['agency']['properties'][$defaultField]['type'] == "string") { |
if ($schemas['agency']['properties'][$defaultField]['type'] == "string") { |
if (strpos($defaultField, "has") === 0) { |
$row[$defaultField] = ""; |
$row[$defaultField] = "false"; |
} |
|
if ($schemas['agency']['properties'][$defaultField]['type'] == "array") { |
} else { |
$row[$defaultField] = Array(""); |
$row[$defaultField] = ""; |
} |
} |
} else if ($schemas['agency']['properties'][$defaultField]['type'] == "array") { |
|
if (is_array($row[$defaultField])) { |
} |
$row[$defaultField][] = ""; |
if ($schemas['agency']['properties'][$defaultField]['type'] == "array") { |
$row[$defaultField][] = ""; |
|
$row[$defaultField][] = ""; |
$row[$defaultField] = Array(""); |
} else { |
|
$value = $row[$defaultField]; |
|
$row[$defaultField] = Array($value); |
|
$row[$defaultField][] = ""; |
|
$row[$defaultField][] = ""; |
} |
} |
} |
} |
} |
} |
return $row; |
return $row; |
} |
} |
|
|
$db = $server->get_db('disclosr-agencies'); |
$db = $server->get_db('disclosr-agencies'); |
|
|
if (isset($_REQUEST['id'])) { |
if (isset($_REQUEST['id'])) { |
//get an agency record as json/html, search by name/abn/id |
//get an agency record as json/html, search by name/abn/id |
// by name = startkey="Ham"&endkey="Ham\ufff0" |
// by name = startkey="Ham"&endkey="Ham\ufff0" |
// edit? |
// edit? |
|
|
$row = $db->get($_REQUEST['id']); |
$obj = $db->get($_REQUEST['id']); |
//print_r($row); |
include_header(isset($obj->name) ? $obj->name : ""); |
|
//print_r($row); |
if (sizeof($_POST) > 0) { |
if (sizeof($_POST) > 0) { |
//print_r($_POST); |
//print_r($_POST); |
|
foreach ($_POST as $postkey => $postvalue) { |
|
if ($postvalue == "") { |
|
unset($_POST[$postkey]); |
|
} |
|
if (is_array($postvalue)) { |
|
if (count($postvalue) == 1 && $postvalue[0] == "") { |
|
unset($_POST[$postkey]); |
|
} else { |
|
foreach ($_POST[$postkey] as $key => &$value) { |
|
if ($value == "") { |
|
unset($_POST[$postkey][$key]); |
|
} |
|
} |
|
} |
|
} |
|
} |
if (isset($_POST['_id']) && $db->get_rev($_POST['_id']) == $_POST['_rev']) { |
if (isset($_POST['_id']) && $db->get_rev($_POST['_id']) == $_POST['_rev']) { |
echo "Edited version was latest version, continue saving"; |
echo "Edited version was latest version, continue saving"; |
$newdoc = $_POST; |
$newdoc = $_POST; |
$newdoc['metadata']['lastModified'] = time(); |
$newdoc['metadata']['lastModified'] = time(); |
$row = $db->save($newdoc); |
$obj = $db->save($newdoc); |
} else { |
} else { |
echo "ALERT doc revised by someone else while editing."; |
echo "ALERT doc revised by someone else while editing. Document not saved."; |
} |
} |
} |
} |
|
|
$mode = "edit"; |
$mode = "view"; |
$row = addDefaultFields(object_to_array($row)); |
$rowArray = object_to_array($obj); |
|
ksort($rowArray); |
|
if ($mode == "edit") { |
|
$row = addDefaultFields($rowArray); |
|
} else { |
|
$row = $rowArray; |
|
} |
|
|
if ($mode == "view") { |
if ($mode == "view") { |
echo '<table width="100%">'; |
echo '<div itemscope itemtype="http://schema.org/GovernmentOrganization" typeof="schema:GovernmentOrganization" about="#' . $row['_id'] . '"><table width="100%">'; |
echo '<tr> <td colspan="2"><h3>' . $row['name'] . "</h3></td></tr>"; |
echo '<tr> <td colspan="2"><h3 itemprop="name">' . $row['name'] . "</h3></td></tr>"; |
echo "<tr><th>Field Name</th><th>Field Value</th></tr>"; |
echo "<tr><th>Field Name</th><th>Field Value</th></tr>"; |
} |
} |
if ($mode == "edit") { |
if ($mode == "edit") { |
?> |
?> |
<input id="addfield" type="button" value="Add Field"/> |
<input id="addfield" type="button" value="Add Field"/> |
<script> |
<script> |
window.onload = function() { |
window.onload = function() { |
$(document).ready(function() { |
$(document).ready(function() { |
// put all your jQuery goodness in here. |
// put all your jQuery goodness in here. |
// http://charlie.griefer.com/blog/2009/09/17/jquery-dynamically-adding-form-elements/ |
// http://charlie.griefer.com/blog/2009/09/17/jquery-dynamically-adding-form-elements/ |
$('#addfield').click(function() { |
$('#addfield').click(function() { |
var field_name=window.prompt("fieldname?",""); |
var field_name=window.prompt("fieldname?",""); |
if (field_name !="") { |
if (field_name !="") { |
$('#submitbutton').before($('<span></span>') |
$('#submitbutton').before($('<span></span>') |
.append("<label>"+field_name+"</label>") |
.append("<label>"+field_name+"</label>") |
.append("<input class='input-text' type='text' id='"+field_name+"' name='"+field_name+"'/>") |
.append("<input class='input-text' type='text' id='"+field_name+"' name='"+field_name+"'/>") |
); |
); |
} |
} |
}); |
}); |
}); |
}); |
}; |
}; |
</script> |
</script> |
<form id="editform" class="nice" method="post"> |
<form id="editform" class="nice" method="post"> |
<?php |
<?php |
|
|
} |
} |
foreach ($row as $key => $value) { |
foreach ($row as $key => $value) { |
echo displayValue($key, $value, $mode); |
echo displayValue($key, $value, $mode); |
} |
} |
if ($mode == "view") { |
if ($mode == "view") { |
echo "</table>"; |
echo "</table></div>"; |
} |
} |
if ($mode == "edit") { |
if ($mode == "edit") { |
echo '<input id="submitbutton" type="submit"/></form>'; |
echo '<input id="submitbutton" type="submit"/></form>'; |
} |
} |
} else { |
} else { |
|
// show all list |
try { |
include_header('Agencies'); |
/*$rows = $db->get_view("app", "showNamesABNs")->rows; |
try { |
//print_r($rows); |
$rows = $db->get_view("app", "byCanonicalName")->rows; |
foreach ($rows as $row) { |
//print_r($rows); |
// print_r($row); |
$rowCount = count($rows); |
echo '<li><a href="getAgency.php?id=' . $row->key . '">' . |
echo '<ul>'; |
(isset($row->value->name) && $row->value->name != "" ? $row->value->name : "NO NAME " . $row->value->abn) |
foreach ($rows as $i => $row) { |
. '</a></li>'; |
if ($i % ($rowCount/3) == 0 && $i != 0 && $i != $rowCount -2 ) echo "<hr/>"; |
}*/ |
// print_r($row); |
$rows = $db->get_view("app", "byName")->rows; |
echo '<li itemscope itemtype="http://schema.org/GovernmentOrganization" typeof="schema:GovernmentOrganization foaf:Organization" about="getAgency.php?id=' . $row->value->_id . '"> |
//print_r($rows); |
<a href="getAgency.php?id=' . $row->value->_id . '" rel="schema:url foaf:page" property="schema:name foaf:name" itemprop="url"><span itemprop="name">' . |
foreach ($rows as $row) { |
(isset($row->value->name) ? $row->value->name : "ERROR NAME MISSING") |
// print_r($row); |
. '</span></a></li>'; |
echo '<li><a href="getAgency.php?id=' . $row->value . '">' . |
} |
$row->key |
echo "</ul>"; |
. '</a></li>'; |
} catch (SetteeRestClientException $e) { |
} |
setteErrorHandler($e); |
} catch (SetteeRestClientException $e) { |
} |
setteErrorHandler($e); |
} |
} |
include_footer(); |
} |
?> |
include_footer(); |
|
?> |
|