220 lines
5.6 KiB
PHP
220 lines
5.6 KiB
PHP
<?php
|
|
/**
|
|
* Name: Converter App
|
|
* Description: Unit converter application
|
|
* Version: 1.0
|
|
* Author: Mike Macgirvin <http://macgirvin.com/profile/mike>
|
|
*/
|
|
|
|
use Friendica\App;
|
|
use Friendica\Core\Hook;
|
|
|
|
function convert_install() {
|
|
Hook::register('app_menu', 'addon/convert/convert.php', 'convert_app_menu');
|
|
}
|
|
|
|
function convert_app_menu(array &$b)
|
|
{
|
|
$b['app_menu'][] = '<div class="app-title"><a href="convert">Units Conversion</a></div>';
|
|
}
|
|
|
|
|
|
function convert_module() {}
|
|
|
|
function convert_content() {
|
|
// @TODO UnitConverter uses a deprecated constructor with the class' name
|
|
// @TODO Let's one day rewrite this to a modern composer package
|
|
include 'UnitConvertor.php';
|
|
|
|
class TP_Converter extends UnitConvertor
|
|
{
|
|
public function __construct(string $lang = 'en')
|
|
{
|
|
if ($lang == 'en' ) {
|
|
$dec_point = '.';
|
|
$thousand_sep = ',';
|
|
} else {
|
|
$dec_point = '.';
|
|
$thousand_sep = "'";
|
|
}
|
|
|
|
parent::UnitConvertor($dec_point, $thousand_sep );
|
|
}
|
|
|
|
private function findBaseUnit($from, $to)
|
|
{
|
|
while (list($skey, $sval) = each($this->bases)) {
|
|
if ($skey == $from || $to == $skey || in_array($to, $sval) || in_array($from, $sval)) {
|
|
return $skey;
|
|
}
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
public function getTable(int $value, $from_unit, $to_unit, $precision): string
|
|
{
|
|
$string = '';
|
|
|
|
if ($base_unit = $this->findBaseUnit($from_unit, $to_unit)) {
|
|
// A baseunit was found now lets convert from -> $base_unit
|
|
$cell ['value'] = $this->convert($value, $from_unit, $base_unit, $precision) . ' ' . $base_unit;
|
|
$cell ['class'] = ($base_unit == $from_unit || $base_unit == $to_unit) ? 'framedred' : '';
|
|
$cells[] = $cell;
|
|
|
|
// We now have the base unit and value now lets produce the table;
|
|
while (list($key, $val) = each($this->bases[$base_unit])) {
|
|
$cell ['value'] = $this->convert($value, $from_unit, $val, $precision) . ' ' . $val;
|
|
$cell ['class'] = ($val == $from_unit || $val == $to_unit) ? 'framedred' : '';
|
|
$cells[] = $cell;
|
|
}
|
|
|
|
$cc = count($cells);
|
|
$string = "<table class=\"framed grayish\" border=\"1\" cellpadding=\"5\" width=\"80%\" align=\"center\"><tr>";
|
|
$string .= "<td rowspan=\"$cc\" align=\"center\">$value $from_unit</td>";
|
|
$i = 0;
|
|
foreach ($cells as $cell) {
|
|
if ($i == 0) {
|
|
$string .= "<td class=\"" . $cell['class'] . "\">" . $cell['value'] . "</td>";
|
|
$i++;
|
|
} else {
|
|
$string .= "</tr><tr><td class=\"" . $cell['class'] . "\">" . $cell['value'] . "</td>";
|
|
}
|
|
}
|
|
$string .= "</tr></table>";
|
|
}
|
|
|
|
return $string;
|
|
}
|
|
}
|
|
|
|
$conv = new TP_Converter('en');
|
|
|
|
$conversions = [
|
|
'Temperature' => ['base' => 'Celsius',
|
|
'conv' => [
|
|
'Fahrenheit' => ['ratio' => 1.8, 'offset' => 32],
|
|
'Kelvin' => ['ratio' => 1, 'offset' => 273],
|
|
'Reaumur' => 0.8
|
|
]
|
|
],
|
|
'Weight' => ['base' => 'kg',
|
|
'conv' => [
|
|
'g' => 1000,
|
|
'mg' => 1000000,
|
|
't' => 0.001,
|
|
'grain' => 15432,
|
|
'oz' => 35.274,
|
|
'lb' => 2.2046,
|
|
'cwt(UK)' => 0.019684,
|
|
'cwt(US)' => 0.022046,
|
|
'ton (US)' => 0.0011023,
|
|
'ton (UK)' => 0.0009842
|
|
]
|
|
],
|
|
'Distance' => ['base' => 'km',
|
|
'conv' => [
|
|
'm' => 1000,
|
|
'dm' => 10000,
|
|
'cm' => 100000,
|
|
'mm' => 1000000,
|
|
'mile' => 0.62137,
|
|
'naut.mile' => 0.53996,
|
|
'inch(es)' => 39370,
|
|
'ft' => 3280.8,
|
|
'yd' => 1093.6,
|
|
'furlong' => 4.970969537898672,
|
|
'fathom' => 546.8066491688539
|
|
]
|
|
],
|
|
'Area' => ['base' => 'km 2',
|
|
'conv' => [
|
|
'ha' => 100,
|
|
'acre' => 247.105,
|
|
'm 2' => pow(1000,2),
|
|
'dm 2' => pow(10000,2),
|
|
'cm 2' => pow(100000,2),
|
|
'mm 2' => pow(1000000,2),
|
|
'mile 2' => pow(0.62137,2),
|
|
'naut.miles 2' => pow(0.53996,2),
|
|
'in 2' => pow(39370,2),
|
|
'ft 2' => pow(3280.8,2),
|
|
'yd 2' => pow(1093.6,2),
|
|
]
|
|
],
|
|
'Volume' => ['base' => 'm 3',
|
|
'conv' => [
|
|
'in 3' => 61023.6,
|
|
'ft 3' => 35.315,
|
|
'cm 3' => pow(10,6),
|
|
'dm 3' => 1000,
|
|
'litre' => 1000,
|
|
'hl' => 10,
|
|
'yd 3' => 1.30795,
|
|
'gal(US)' => 264.172,
|
|
'gal(UK)' => 219.969,
|
|
'pint' => 2113.376,
|
|
'quart' => 1056.688,
|
|
'cup' => 4266.753,
|
|
'fl oz' => 33814.02,
|
|
'tablespoon' => 67628.04,
|
|
'teaspoon' => 202884.1,
|
|
'pt (UK)' => 1000/0.56826,
|
|
'barrel petroleum' => 1000/158.99,
|
|
'Register Tons' => 2.832,
|
|
'Ocean Tons' => 1.1327
|
|
]
|
|
],
|
|
'Speed' => ['base' => 'kmph',
|
|
'conv' => [
|
|
'mps' => 0.0001726031,
|
|
'milesph' => 0.62137,
|
|
'knots' => 0.53996,
|
|
'mach STP' => 0.0008380431,
|
|
'c (warp)' => 9.265669e-10
|
|
]
|
|
]
|
|
];
|
|
|
|
while (list($key, $val) = each($conversions)) {
|
|
$conv->addConversion($val['base'], $val['conv']);
|
|
$list[$key][] = $val['base'];
|
|
while (list($ukey, $uval) = each($val['conv'])) {
|
|
$list[$key][] = $ukey;
|
|
}
|
|
}
|
|
|
|
$o .= '<h3>Unit Conversions</h3>';
|
|
|
|
if (isset($_POST['from_unit']) && isset($_POST['value'])) {
|
|
$o .= ($conv->getTable(intval($_POST['value']), $_POST['from_unit'], $_POST['to_unit'], 5)) . '</p>';
|
|
} else {
|
|
$o .= '<p>Select:</p>';
|
|
}
|
|
|
|
if (isset($_POST['value'])) {
|
|
$value = $_POST['value'];
|
|
} else {
|
|
$value = '';
|
|
}
|
|
|
|
$o .= '<form action="convert" method="post" name="conversion">';
|
|
$o .= '<input name="value" type="text" id="value" value="' . $value . '" size="10" maxlength="10" />';
|
|
$o .= '<select name="from_unit" size="12">';
|
|
|
|
reset($list);
|
|
while(list($key, $val) = each($list)) {
|
|
$o .= "\n\t<optgroup label=\"$key\">";
|
|
while(list($ukey, $uval) = each($val)) {
|
|
$selected = (($uval == $_POST['from_unit']) ? ' selected="selected" ' : '');
|
|
$o .= "\n\t\t<option value=\"$uval\" $selected >$uval</option>";
|
|
}
|
|
$o .= "\n\t</optgroup>";
|
|
}
|
|
|
|
$o .= '</select>';
|
|
$o .= '<input type="submit" name="Submit" value="Submit" /></form>';
|
|
|
|
return $o;
|
|
}
|