<?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, $schemas; |
global $db, $schemas; |
|
$ignoreKeys = Array("metadata" ,"metaTags", "statistics","rtkURLs","rtkDescriptions"); |
if ($mode == "view") { |
if ($mode == "view") { |
|
if (strpos($key, "_") === 0 || in_array($key,$ignoreKeys)) |
|
return; |
echo "<tr>"; |
echo "<tr>"; |
|
|
echo "<td>" . $schemas['agency']["properties"][$key]['x-title'] . "<br><small>" . $schemas['agency']["properties"][$key]['description'] . "</small></td><td>"; |
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 "<ol>"; |
echo "<ol>"; |
foreach ($value as $subkey => $subvalue) { |
foreach ($value as $subkey => $subvalue) { |
if (isset($schemas['agency']["properties"][$key]['x-itemprop'])) { |
|
echo '<li itemprop="' . $schemas['agency']["properties"][$key]['x-itemprop'] . '">'; |
echo "<li "; |
} else { |
if (isset($schemas['agency']["properties"][$key]['x-property'])) { |
echo "<li>"; |
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 "$subvalue</li>"; |
} |
} |
echo "</ol></td></tr>"; |
echo "</ol></td></tr>"; |
} else { |
} else { |
if (isset($schemas['agency']["properties"][$key]['x-itemprop'])) { |
if (isset($schemas['agency']["properties"][$key]['x-property'])) { |
echo '<span itemprop="' . $schemas['agency']["properties"][$key]['x-itemprop'] . '">'; |
echo '<span property="' . $schemas['agency']["properties"][$key]['x-property'] . '">'; |
} else { |
} else { |
echo "<span>"; |
echo "<span>"; |
} |
} |
if ((strpos($key, "URL") > 0 || $key == 'website') && $value != "") { |
|
echo "<a href='$value'>view</a></span>"; |
if ((strpos($key, "URL") > 0 || $key == 'website') && $value != "") { |
} else { |
echo "<a " . ($key == 'website' ? 'itemprop="url"' : '') . " href='$value'>$value</a>"; |
echo "$value</span>"; |
} 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>"; |
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'><option value=''> Select... </option>"; |
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 == 'on' || $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"; |
|
} else { |
|
$row[$defaultField] = ""; |
|
} |
|
} |
} |
if ($schemas['agency']['properties'][$defaultField]['type'] == "array") { |
if ($schemas['agency']['properties'][$defaultField]['type'] == "array") { |
|
|
$row[$defaultField] = Array(""); |
$row[$defaultField] = Array(""); |
|
} |
|
} else if ($schemas['agency']['properties'][$defaultField]['type'] == "array") { |
|
if (is_array($row[$defaultField])) { |
|
$row[$defaultField][] = ""; |
|
$row[$defaultField][] = ""; |
|
$row[$defaultField][] = ""; |
|
} 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) { |
foreach ($_POST as $postkey => $postvalue) { |
if ($postvalue == "") { |
if ($postvalue == "") { |
unset($_POST[$postkey]); |
unset($_POST[$postkey]); |
} |
} |
if (is_array($postvalue) && count($postvalue) == 1 && $postvalue[0] == "") { |
if (is_array($postvalue)) { |
unset($_POST[$postkey]); |
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. Document not saved."; |
echo "ALERT doc revised by someone else while editing. Document not saved."; |
} |
} |
} |
} |
|
|
$mode = "edit"; |
$mode = "view"; |
if ($mode == "edit") { |
$rowArray = object_to_array($obj); |
$row = addDefaultFields(object_to_array($row)); |
ksort($rowArray); |
|
if ($mode == "edit") { |
|
$row = addDefaultFields($rowArray); |
} else { |
} else { |
$row = object_to_array($row); |
$row = $rowArray; |
} |
} |
|
|
if ($mode == "view") { |
if ($mode == "view") { |
echo '<div itemscope itemtype ="http://schema.org/GovernmentOrganisation"><table width="100%">'; |
echo ' <div class="container-fluid"> |
echo '<tr> <td colspan="2"><h3>' . $row['name'] . "</h3></td></tr>"; |
<div class="row-fluid"> |
|
<div class="span3"> |
|
<div class="well sidebar-nav"> |
|
<ul class="nav nav-list"> |
|
<li class="nav-header">Statistics</li>'; |
|
|
|
if (isset($row['statistics']['employees'])) { |
|
echo '<div><i class="icon-user" style="float:left"></i><p style="margin-left:16px;">'; |
|
$keys = array_keys($row['statistics']['employees']); |
|
$lastkey = $keys[count($keys)-1]; |
|
echo $row['statistics']['employees'][$lastkey]['value'].' employees <small>('.$lastkey.')</small>'; |
|
echo '</div>'; |
|
} |
|
if (isset($row['statistics']['budget'])) { |
|
echo '<div><i class="icon-shopping-cart" style="float:left"></i><p style="margin-left:16px;">'; |
|
$keys = array_keys($row['statistics']['budget']); |
|
$lastkey = $keys[count($keys)-1]; |
|
echo money_format("%#10i",(float)$row['statistics']['budget'][$lastkey]['value']).' <small>('.$lastkey.' budget)</small>'; |
|
echo '</div>'; |
|
} |
|
echo ' </ul> |
|
</div><!--/.well --> |
|
</div><!--/span--> |
|
<div class="span9">'; |
|
echo '<div itemscope itemtype="http://schema.org/GovernmentOrganization" typeof="schema:GovernmentOrganization" about="#' . $row['_id'] . '">'; |
|
echo '<div class="hero-unit"> |
|
<h1 itemprop="name">' . $row['name'] . '</h1>'; |
|
if (isset($row['description'])) { |
|
echo '<p>'.$row['description'].'</p>'; |
|
} |
|
echo '</div><table width="100%">'; |
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></div>"; |
echo "</table></div>"; |
|
echo ' </div><!--/span--> |
|
</div><!--/row--> |
|
</div><!--/span--> |
|
</div><!--/row-->'; |
} |
} |
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 |
|
include_header('Agencies'); |
|
echo ' <div class="container-fluid"> |
|
<div class="row-fluid"> |
|
<div class="span3"> |
|
<div class="well sidebar-nav"> |
|
<ul class="nav nav-list"> |
|
<li class="nav-header">Sidebar</li>'; |
|
echo ' </ul> |
|
</div><!--/.well --> |
|
</div><!--/span--> |
|
<div class="span9"> |
|
<div class="hero-unit"> |
|
<h1>Australian Government Agencies</h1> |
|
<p>Explore collected information about Australian Government Agencies below.</p> |
|
|
|
</div> |
|
<div class="row-fluid"> |
|
<div class="span4">'; |
try { |
try { |
/* $rows = $db->get_view("app", "showNamesABNs")->rows; |
$rows = $db->get_view("app", "byCanonicalName")->rows; |
//print_r($rows); |
|
foreach ($rows as $row) { |
|
// print_r($row); |
|
echo '<li><a href="getAgency.php?id=' . $row->key . '">' . |
|
(isset($row->value->name) && $row->value->name != "" ? $row->value->name : "NO NAME " . $row->value->abn) |
|
. '</a></li>'; |
|
} */ |
|
$rows = $db->get_view("app", "byName")->rows; |
|
//print_r($rows); |
//print_r($rows); |
foreach ($rows as $row) { |
$rowCount = count($rows); |
|
foreach ($rows as $i => $row) { |
|
if ($i % ($rowCount/3) == 0 && $i != 0 && $i != $rowCount -2 ) echo '</div><div class="span4">'; |
// print_r($row); |
// print_r($row); |
echo '<li itemscope itemtype="http://schema.org/GovernmentOrganization"><a href="getAgency.php?id=' . $row->value . '" itemprop="url"><span itemprop="name">' . |
echo '<span itemscope itemtype="http://schema.org/GovernmentOrganization" typeof="schema:GovernmentOrganization foaf:Organization" about="getAgency.php?id=' . $row->value->_id . '"> |
$row->key |
<a href="getAgency.php?id=' . $row->value->_id . '" rel="schema:url foaf:page" property="schema:name foaf:name" itemprop="url"><span itemprop="name">' . |
. '</span></a></li>'; |
(isset($row->value->name) ? $row->value->name : "ERROR NAME MISSING") |
} |
. '</span></a></span><br><br>'; |
|
} |
|
|
} catch (SetteeRestClientException $e) { |
} catch (SetteeRestClientException $e) { |
setteErrorHandler($e); |
setteErrorHandler($e); |
} |
} |
|
echo ' </div><!--/span--> |
|
</div><!--/row--> |
|
</div><!--/span--> |
|
</div><!--/row-->'; |
} |
} |
|
|
include_footer(); |
include_footer(); |
?> |
?> |
|
|