d2tools/genDocs.php

1399 lines
32 KiB
PHP
Raw Normal View History

<?php
error_reporting(E_ERROR | E_PARSE);
set_time_limit(-1);
ini_set('max_input_time', '-1');
ini_set('max_execution_time', '0');
session_start();
ob_start();
/*
Copyright (C) 2021 Hash Borgir
This file is part of D2Modder
Redistribution and use in source and binary forms, with
or without modification, are permitted provided that the
following conditions are met:
* Redistributions of source code must retain the above
copyright notice, this list of conditions and the
following disclaimer.
* Redistributions in binary form must reproduce the above
copyright notice, this list of conditions and the
following disclaimer in the documentation and/or other
materials provided with the distribution.
2021-05-10 07:15:44 +00:00
* This software must not be used for commercial purposes
* without my consent. Any sales or commercial use are prohibited
* without my express knowledge and consent.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY!
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND
CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
require_once './config.php';
require_once './_pdo.php';
require_once './src/D2ItemData.php';
require_once './src/D2ItemDesc.php';
$idata = new D2ItemData();
$idesc = new D2ItemDesc();
define('DB_FILE', $_SESSION['modname'] . ".db");
PDO_Connect("sqlite:" . DB_FILE);
require_once "./src/D2Functions.php";
require_once './src/D2ItemData.php';
$idata = new D2ItemData();
if (!empty($_GET['cmd']))
$cmd = $_GET['cmd'];
2021-05-10 16:41:26 +00:00
if ($cmd == 'genDocCube') {
$type = "Cube Recipes";
$align = 'left';
}
if ($cmd == 'genDocUniqueItems') {
$type = "Unique Items";
$align = 'center';
}
2021-05-15 07:23:25 +00:00
$sql = "
SELECT p.`code` as prop,
p.stat1,
i.descstrpos,
i.descstr2,
i.descfunc,
i.descval,
2021-05-15 07:23:25 +00:00
i.dgrp,
i.dgrpfunc,
i.dgrpval,
i.dgrpstrpos,
i.dgrpstrneg,
s1.String as string1,
2021-05-15 07:23:25 +00:00
s2.String as string2,
s3.String as gstring1,
s4.String as gstring2
FROM properties as p
LEFT JOIN itemstatcost as i
ON p.stat1 = i.Stat
LEFT JOIN strings as s1
ON i.descstrpos = s1.Key
LEFT JOIN strings as s2
ON i.descstr2 = s2.Key
LEFT JOIN strings as s3
ON i.dgrpstrpos = s3.Key
LEFT JOIN strings as s4
ON i.dgrpstr2= s4.Key
";
$res = PDO_FetchAll($sql);
$isc = null;
foreach ($res as $r) {
$isc[$r['prop']] = $r;
$isc[$r['prop']]['prop'] = $r['prop'];
}
2021-05-10 16:41:26 +00:00
2021-05-10 07:15:44 +00:00
$htmltop = <<<EOT
<!doctype html>
<html lang="en">
<head>
<!-- Required meta tags -->
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<!-- Bootstrap CSS -->
<link rel="stylesheet" href="res/bootstrap.min.css">
2021-05-10 07:15:44 +00:00
<link rel="stylesheet" href="res/font-awesome.min.css">
<link rel="preconnect" href="https://fonts.gstatic.com">
<link href="https://fonts.googleapis.com/css2?family=Lato:wght@300&display=swap" rel="stylesheet">
<link rel="stylesheet" href="https://bootswatch.com/4/sketchy/bootstrap.min.css">
2021-05-15 07:23:25 +00:00
<link rel="stylesheet" type="text/css" href="https://cdn.datatables.net/1.10.24/css/jquery.dataTables.css">
<link rel="stylesheet" href="res/style.css">
<style>
2021-05-10 07:15:44 +00:00
2021-05-07 09:18:29 +00:00
body{
background: white;
2021-05-15 07:23:25 +00:00
font-family: ExocetHeavy;
2021-05-07 09:18:29 +00:00
}
table, table th, table td, table tr {
background: #111;
color: #ccc;
2021-05-15 07:23:25 +00:00
}
.item {
text-align: center;
position:relative;
right:0px;
margin: 0 auto;
}
.item_desc {
height: 600px;
width: 620px;
position: relative;
left: 0px;
2021-05-15 07:23:25 +00:00
top: 0px;
text-align: center;
padding: 10px;
text-transform: uppercase;
}
2021-05-07 09:18:29 +00:00
.item_stats{
width: auto;
height: auto;
background: #111;
2021-05-15 07:23:25 +00:00
min-height: 260px;
2021-05-07 09:18:29 +00:00
}
.item_desc {
height: auto;
text-align: center;
padding: 10px;
text-transform: uppercase;
}
.green {
color: #00FF00; /*Set items*/
}
.gold{
color: #A59263; /*Set items*/
}
.orange{
color: #FFA500; /*Set items*/
}
.yellow {
color: #FFFF00; /*Set items*/
}
2021-05-07 09:18:29 +00:00
.blue {
color: #4169E1;
}
td {
2021-05-15 07:23:25 +00:00
height: 240px;
2021-05-15 07:23:25 +00:00
text-align: center;
vertical-align: middle;
padding: 10px;
}
2021-05-15 07:23:25 +00:00
.uname {
background: #222;
}
.ulvl {
2021-05-15 07:23:25 +00:00
}
.ulvlreq {
2021-05-15 07:23:25 +00:00
}
.utype {
background: #111;
}
.ucode {
2021-05-15 07:23:25 +00:00
}
.uitem {
2021-05-15 07:23:25 +00:00
}
2021-05-15 07:23:25 +00:00
</style>
2021-05-15 07:23:25 +00:00
2021-05-10 16:41:26 +00:00
<script src="res/jquery-3.5.1.min.js"></script>
2021-05-15 07:23:25 +00:00
<script type="text/javascript" charset="utf8" src="https://cdn.datatables.net/1.10.24/js/jquery.dataTables.js"></script>
<script src="res/bootstrap.bundle.min.js"></script>
2021-05-10 16:41:26 +00:00
<script>
2021-05-15 07:23:25 +00:00
2021-05-10 16:41:26 +00:00
$(document).ready(function() {
2021-05-15 07:23:25 +00:00
$('.cubetable').dataTable();
$('.utable').dataTable();
$('.gemtable').dataTable();
2021-05-10 16:41:26 +00:00
} );
2021-05-15 07:23:25 +00:00
</script>
2021-05-10 16:41:26 +00:00
<title>D2Modder</title>
</head>
2021-05-10 07:15:44 +00:00
<body>
<div class="">
2021-05-10 16:41:26 +00:00
<h1>{$_SESSION['modname']} $type</h1>
<p>Auto generated with D2Modder by Hash Casper</p>
2021-05-10 07:15:44 +00:00
EOT;
2021-05-10 07:15:44 +00:00
$htmlbottom = <<<EOT
</div>
2021-05-15 07:23:25 +00:00
</body>
2021-05-10 07:15:44 +00:00
</html>
EOT;
2021-05-10 07:15:44 +00:00
/*
*
*
*
*
*
@cmd = genDocUniqueItems
*
*
*
*
*
*/
$dir = getcwd() . "/docs/{$_SESSION['modname']}";
mkdir($dir, 0777, true);
2021-05-10 07:15:44 +00:00
if ($cmd == "genDocUniqueItems") {
$tableTop = <<<EOT
<table border=1 class="utable">
<thead>
<tr>
<th class="gold uname">Name</th>
2021-05-15 07:23:25 +00:00
<th class="orange ulvl">Lvl</th>
<th class="orange ulvlreq">Lvl Req</th>
<th class="yellow utype">Type</th>
<th class="green ucode">Code</th>
<th class="uitem">Item</th>
</tr>
</thead>
<tbody>
2021-05-15 07:23:25 +00:00
EOT;
$tableBottom = <<<EOT
</tbody>
</table>
2021-05-15 07:23:25 +00:00
EOT;
2021-05-10 07:15:44 +00:00
// grab unique item index only (to save on memory)
$sql = "SELECT `index` FROM `uniqueitems` WHERE `enabled`='1'";
$uIndex = PDO_FetchAll($sql);
//ddump($uIndex);
2021-05-15 07:23:25 +00:00
$htmlFinal = '';
2021-05-15 07:23:25 +00:00
$htmlFinal .= $htmltop . $tableTop;
echo $htmltop;
echo $tableTop;
ob_flush();
/*
2021-05-10 07:15:44 +00:00
START MAIN LOOP HERE
*
* For each unique item index, now grab item data
*
*/
2021-05-10 07:15:44 +00:00
2021-05-15 07:23:25 +00:00
foreach ($uIndex as $u) {
2021-05-15 07:23:25 +00:00
//var_dump($item);
//$items[] = $idata->uniqueItems($u['index'], true);
//var_dump($u['index']);
$item = $idata->uniqueItems($u['index'], true);
2021-05-10 07:15:44 +00:00
$itemBoxTop = "<tr>";
$itemBoxTop .= "<td class='gold uname' style=''>{$item['index']}</td>";
$itemBoxTop .= "<td class='orange ulvl' style=''>{$item['lvl']}</td>";
$itemBoxTop .= "<td class='orange ulvlreq' style=''>{$item["lvl req"]}</td>";
$itemBoxTop .= "<td class='utype' style=''>{$item["*type"]}</td>";
2021-05-15 07:23:25 +00:00
$itemBoxTop .= "<td class='ucode' style=''>{$item['code']}</td>";
$itemBoxTop .= <<<EOT
<td class='item' style=''>
<div class="center item_desc" style="">
<div style="height: 116px;background: url(img/items/bg.png) center top no-repeat;">
<img style="" class="item img-fluid" src="img/items/{$item["invfile"]}.png">
</div>
<div class="item_stats" style="">
2021-05-07 09:18:29 +00:00
<div style="width:auto; margin: 0 auto; background:#111; display:inline-block;">
<p>
2021-05-15 07:23:25 +00:00
EOT;
$itemBoxBottom = <<<EOT
</p>
</div>
</div>
</div>
</td>
2021-05-10 07:15:44 +00:00
EOT;
$itemBoxBottom .= "</tr>";
2021-05-10 07:15:44 +00:00
echo $itemBoxTop;
ob_flush();
2021-05-10 07:15:44 +00:00
$htmlFinal .= $itemBoxTop;
2021-05-10 07:15:44 +00:00
//index
2021-05-07 09:18:29 +00:00
$props = "<ul><li class='statindex gold'>{$item['index']}</li>";
//type
2021-05-07 09:18:29 +00:00
$props .= "<li class='stattype gold'>({$item["*type"]})</li>";
//level
$props .= "<li style='color: white;' class=''>Level: {$item["lvl"]}</li>";
//lvlreq
$props .= "<li style='color: white;' class=''>Level Required: {$item["lvl req"]}</li>";
//code
$props .= "<li style='color: #aaa;' class=''>Item Code: {$item["code"]}</li>";
//reqstr
if ($item["reqstr"]) {
$props .= "<li style='color: white;' class=''>{$item["reqstr"]}</li>";
}
//reqdex
if ($item["reqdex"]) {
$props .= "<li style='color: white;' class=''>{$item["reqdex"]}</li>";
}
//sock
2021-05-07 09:18:29 +00:00
$props .= "<li style='color: white;' class=''>{$item["gemsockets"]}</li>";
foreach ($item['props'] as $prop) {
if ($prop['string'][0]) {
$props .= "<li class='blue'>{$prop['string'][0]}</li>";
}
}
$props .= "</ul>";
// $itemFull .= $itemBoxTop . $props . $itemBoxBottom;
// echo $itemFull;
echo $props;
echo $itemBoxBottom;
ob_flush();
$htmlFinal .= $props . $itemBoxBottom . $tableBottom;
}// end loop
echo $htmlbottom;
$htmlFinal .= $htmlbottom;
file_put_contents("$dir/uniqueitems.html", $htmlFinal);
header("Location: /docs/{$_SESSION['modname']}/uniqueitems.html");
}
2021-05-10 07:15:44 +00:00
/*
*
*
*
*
*
@cmd = genDocCube
*
*
*
*
*
*/
2021-05-10 16:41:26 +00:00
function getImage($code) {
$sql = "SELECT invfile FROM armor WHERE `code`=\"$code\" OR `type`=\"$code\" OR `type2`=\"$code\"";
$img = PDO_FetchOne($sql);
if (empty($img)) {
$sql = "SELECT invfile FROM misc WHERE `code`=\"$code\" OR `type`=\"$code\" OR `type2`=\"$code\"";
$img = PDO_FetchOne($sql);
}
if (empty($img)) {
$sql = "SELECT invfile FROM weapons WHERE `code`=\"$code\" OR `type`=\"$code\" OR `type2`=\"$code\"";
$img = PDO_FetchOne($sql);
}
if (!empty($img)) {
return "$img.png";
} else {
return "1.png";
}
return "$img.png";
}
function getItemName($code) {
$sql = "SELECT name FROM armor WHERE `code`=\"$code\" OR `type`=\"$code\" OR `type2`=\"$code\"";
$name = PDO_FetchOne($sql);
if (empty($name)) {
$sql = "SELECT name FROM misc WHERE `code`=\"$code\" OR `type`=\"$code\" OR `type2`=\"$code\"";
$name = PDO_FetchOne($sql);
}
if (empty($name)) {
$sql = "SELECT name FROM weapons WHERE `code`=\"$code\" OR `type`=\"$code\" OR `type2`=\"$code\"";
$name = PDO_FetchOne($sql);
}
return $name;
}
2021-05-10 07:15:44 +00:00
if ($cmd == "genDocCube") {
$htmlFinal = '';
$htmlFinal .= $htmltop;
2021-05-15 07:23:25 +00:00
// echo $htmltop;
// ob_flush();
$css = <<<EOT
2021-05-10 16:41:26 +00:00
<style>
body{
background: white;
color: black;
font-family: ExocetHeavy;
2021-05-15 07:23:25 +00:00
text-transform: uppercase;
2021-05-10 16:41:26 +00:00
}
2021-05-15 07:23:25 +00:00
2021-05-10 16:41:26 +00:00
table, table th, table td, table tr {
background: #111;
2021-05-10 16:41:26 +00:00
color: #ccc;
}
.item_stats{
width: auto;
2021-05-15 07:23:25 +00:00
height: auto;
2021-05-10 16:41:26 +00:00
}
.item_desc {
height: auto;
text-align: center;
padding: 10px;
text-transform: uppercase;
}
.green {
color: #00FF00; /*Set items*/
}
.gold{
color: #A59263; /*Set items*/
}
.orange{
color: #FFA500; /*Set items*/
}
.yellow {
color: #FFFF00; /*Set items*/
}
.blue {
color: #4169E1;
}
table {
}
.desc {
width: 200px;
font-family: ExocetHeavy;
font-size: 1.25em;
text-transform: uppercase;
2021-05-15 07:23:25 +00:00
background: #111;
}
.input1,.input3,.input5,.input7{
background: #444;
}
.input2, .input4, .input6 {
background: #333;
}
.output1{
background: #222;
}
.output2 {
background: #222;
}
.output3 {
background: #222;
2021-05-15 07:23:25 +00:00
}
2021-05-10 16:41:26 +00:00
td {
2021-05-15 07:23:25 +00:00
height: 240px;
2021-05-15 07:23:25 +00:00
2021-05-10 16:41:26 +00:00
text-align: center;
vertical-align: middle;
padding: 10px;
2021-05-10 16:41:26 +00:00
}
2021-05-15 07:23:25 +00:00
</style>
2021-05-10 16:41:26 +00:00
EOT;
2021-05-15 07:23:25 +00:00
//echo $css;
$htmlFinal .= $css;
2021-05-15 07:23:25 +00:00
//ob_flush();
$table = <<<EOT
2021-05-10 16:41:26 +00:00
<table border=1 class="cubetable">
<thead>
<tr>
<th>Recipe</th>
2021-05-15 07:23:25 +00:00
<th>Input 1</th>
<th>Input 2</th>
<th>Input 3</th>
<th>Input 4</th>
<th>Input 5</th>
<th>Input 6</th>
<th>Input 7</th>
2021-05-10 16:41:26 +00:00
<th>Output 1</th>
<th>Output 2</th>
2021-05-15 07:23:25 +00:00
<th>Output 3</th>
2021-05-10 16:41:26 +00:00
</tr>
</thead>
<tbody>
EOT;
2021-05-15 07:23:25 +00:00
//echo $table;
$htmlFinal .= $table;
2021-05-15 07:23:25 +00:00
//ob_flush();
$i_params = [
"any" => "Any Item",
"low" => "Low Quality",
"hiq" => "Superior",
2021-05-10 07:15:44 +00:00
"nor" => "Normal",
"mag" => "<span class='blue'>Magic<span>",
"rar" => "<span class='yellow'>Rare<span>",
"set" => "<span class='green'>Set<span>",
"uni" => "<span class='gold'>Unique<span>",
"crf" => "<span class='orange'>Crafted<span>",
"tmp" => "<span class='orange'>Tempered<span>",
"eth" => "<span style='color: #ccc;'>Ethereal<span>",
"noe" => "<span style='color: #ccc;'>Not Ethereal<span>",
2021-05-10 07:15:44 +00:00
"nos" => "No Socket (for input)",
"sock" => "Sockets",
2021-05-10 07:15:44 +00:00
"pre" => "Prefix (ID from magicprefix.txt) - ID => (Row Number - 2)",
"suf" => "Suffix (ID from magicsuffix.txt) - ID => (Row Number - 2)",
"rep" => "Repair durability",
"rch" => "Recharge Quantity",
"qty" => 'Quantity',
2021-05-10 07:15:44 +00:00
"upg" => "For inputs only, Item is upgraded.",
"bas" => "Base item",
"exc" => "Exceptional",
"eli" => "Elite",
"usetype" => "Uses base type of input1 for output",
"useitem" => "Uses item from input 1",
"uns" => "Unsocket Item(destroys gems)",
"rem" => "Unsocket Item(removes gems)",
"reg" => "Regenerate? Seems to reroll the item",
"mod" => "Transfers properties from input1 to output item.",
];
// get all cube rows
$sql = "SELECT * FROM cubemain WHERE enabled=1";
2021-05-10 07:15:44 +00:00
$res = PDO_FetchAll($sql);
/*
2021-05-15 07:23:25 +00:00
*
2021-05-10 07:15:44 +00:00
* Process each cube row here
for each cube row
2021-05-15 07:23:25 +00:00
*
2021-05-10 07:15:44 +00:00
*/
foreach ($res as $r) {
$desc = str_replace('+', '<br>+<br>', $r['description']);
$desc = str_replace('->', '<br><span class="" style="color: gold;font-size:1.25em;">=<br>', $desc);
$desc .= "</span>";
//ddump($desc);
2021-05-10 16:41:26 +00:00
//var_dump($r);
2021-05-10 07:15:44 +00:00
// grab all inputs
$input_codes = array_filter(
[
"input 1" => $r["input 1"],
"input 2" => $r["input 2"],
"input 3" => $r["input 3"],
"input 4" => $r["input 4"],
"input 5" => $r["input 5"],
"input 6" => $r["input 6"],
"input 7" => $r["input 7"],
]
);
2021-05-10 16:41:26 +00:00
foreach ($input_codes as $inputNum => $value) {
2021-05-10 07:15:44 +00:00
if (str_contains($value, ',')) {
$input_codes[$inputNum] = explode(",", $value); // hpot,qty=3
$oarray = explode(",", $value); // hpot,qty=3
// For each input code // hpot,qty=3 like mpot/hpot/magharv
// if spelldescstr is set, use it. Else use item string tbl
// first find the item code in either armor, misc, or weapons
// then get spelldesc/spelldescstr
2021-05-10 16:41:26 +00:00
$sql = "SELECT `String` FROM `strings` WHERE Key=\"{$oarray[0]}\"";
$str = PDO_FetchOne($sql);
2021-05-10 07:15:44 +00:00
2021-05-10 16:41:26 +00:00
// if empty str == 4-letter code, call getItemName()
2021-05-10 07:15:44 +00:00
if (empty($str)) {
2021-05-10 16:41:26 +00:00
$input_codes[$inputNum][0] = ($oarray[0]);
2021-05-10 07:15:44 +00:00
} else {
$input_codes[$inputNum][0] = $str;
}
2021-05-10 16:41:26 +00:00
// get image
$input_codes[$inputNum]["img"] = getImage($oarray[0]);
2021-05-10 07:15:44 +00:00
} else {
2021-05-10 16:41:26 +00:00
$value .= ",";
$input_codes[$inputNum] = explode(",", $value); // hpot,qty=3
2021-05-10 07:15:44 +00:00
2021-05-10 16:41:26 +00:00
$oarray = explode(",", $value); // hpot,qty=3
// For each input code // hpot,qty=3 like mpot/hpot/magharv
// if spelldescstr is set, use it. Else use item string tbl
// first find the item code in either armor, misc, or weapons
// then get spelldesc/spelldescstr
2021-05-10 07:15:44 +00:00
2021-05-10 16:41:26 +00:00
$sql = "SELECT `String` FROM `strings` WHERE Key=\"{$oarray[0]}\"";
$str = PDO_FetchOne($sql);
2021-05-10 07:15:44 +00:00
// if empty str == 4-letter code, so just display
if (empty($str)) {
2021-05-10 16:41:26 +00:00
$input_codes[$inputNum][0] = ($oarray[0]);
2021-05-10 07:15:44 +00:00
} else {
2021-05-10 16:41:26 +00:00
$input_codes[$inputNum][0] = $str;
2021-05-10 07:15:44 +00:00
}
2021-05-10 16:41:26 +00:00
// get image
$input_codes[$inputNum]["img"] = getImage($oarray[0]);
2021-05-10 07:15:44 +00:00
}
}
/*
2021-05-15 07:23:25 +00:00
* processs output, output b, output c
*
*
2021-05-10 07:15:44 +00:00
*/
// grab all inputs
$output_codes = array_filter(
[
"output" => str_replace('"', "", $r["output"]),
"output b" => str_replace('"', "", $r["output b"]),
"output c" => str_replace('"', "", $r["output c"])
]
);
//var_dump($output_codes);
foreach ($output_codes as $outputNum => $value) {
if (str_contains($value, ',')) {
$output_codes[$outputNum] = explode(",", $value); // hpot,qty=3
$oarray = explode(",", $value); // hpot,qty=3
$sql = "SELECT `String` FROM `strings` WHERE Key=\"{$oarray[0]}\"";
2021-05-15 07:23:25 +00:00
// clean str
2021-05-10 07:15:44 +00:00
$str = PDO_FetchOne($sql);
2021-05-15 07:23:25 +00:00
if (str_contains($str, "ÿc")) {
$p = "/ÿc[\d:;\/.]/i";
$str = preg_replace($p, "", $str);
2021-05-15 07:23:25 +00:00
}
2021-05-10 07:15:44 +00:00
// if empty str == 4-letter code, so just display
if (empty($str)) {
2021-05-10 16:41:26 +00:00
$output_codes[$outputNum][0] = ($oarray[0]);
2021-05-10 07:15:44 +00:00
} else {
$output_codes[$outputNum][0] = $str;
}
2021-05-10 16:41:26 +00:00
$output_codes[$outputNum]["img"] = getImage($oarray[0]);
2021-05-10 07:15:44 +00:00
} else { // else output code is three/four letter code
2021-05-10 16:41:26 +00:00
$value .= ",";
$output_codes[$outputNum] = explode(",", $value); // hpot,qty=3
$oarray = explode(",", $value); // hpot,qty=3
$sql = "SELECT `String` FROM `strings` WHERE Key=\"{$oarray[0]}\"";
2021-05-15 07:23:25 +00:00
// clean color codes
2021-05-10 07:15:44 +00:00
$str = PDO_FetchOne($sql);
2021-05-15 07:23:25 +00:00
if (str_contains($str, "ÿc")) {
$p = "/ÿc[\d:;\/.]/i";
$str = preg_replace($p, "", $str);
2021-05-15 07:23:25 +00:00
}
2021-05-10 07:15:44 +00:00
// if empty str == 4-letter code, so just display
if (empty($str)) {
2021-05-10 16:41:26 +00:00
$output_codes[$outputNum][0] = ($oarray[0]);
2021-05-10 07:15:44 +00:00
} else {
2021-05-10 16:41:26 +00:00
$output_codes[$outputNum][0] = $str;
}
$output_codes[$outputNum]["img"] = getImage($oarray[0]);
}
// if output[1] or output[2], output[3], output[4] contains `=' sign
// parse_str or explode at = to get modifer and value
// if modifier = pre or suf, find ID in magic prefix/suffix line.
// if output is array we know it contains modifers and values
if (is_array($output_codes[$outputNum])) {
// 0 will always be item code.
// 1,2,3 can be mods, either can have =
// if 1,2,3 have = sign, explode and get mod = value
$itemcode = $output_codes[0];
$mod = array_filter([$output_codes[$outputNum][1], $output_codes[$outputNum][2], $output_codes[$outputNum][3]]);
//var_dump($mod);
foreach ($mod as $m) {
if (str_contains($m, '=')) {
$e = explode("=", $m);
$output_codes[$outputNum]['code'] = $e[0];
$output_codes[$outputNum]['value'] = $e[1];
}
2021-05-10 07:15:44 +00:00
}
}
}
2021-05-10 16:41:26 +00:00
2021-05-10 07:15:44 +00:00
$output = array_merge($input_codes, $output_codes);
2021-05-10 16:41:26 +00:00
// Set description
$output['desc'] = $desc;
2021-05-10 07:15:44 +00:00
/*
2021-05-15 07:23:25 +00:00
* process mods for each output
*
*
2021-05-10 07:15:44 +00:00
*/
$m = null;
for ($counter = 1; $counter <= 5; $counter++) {
$mods = array_filter([
"mod $counter" => $r["mod $counter"],
"mod $counter chance" => $r["mod $counter chance"],
"mod $counter param" => $r["mod $counter param"],
"mod $counter min" => $r["mod $counter min"],
"mod $counter max" => $r["mod $counter max"],
"b mod $counter" => $r["b mod $counter"],
"b mod $counter chance" => $r["b mod $counter chance"],
"b mod $counter param" => $r["b mod $counter param"],
"b mod $counter min" => $r["b mod $counter min"],
"b mod $counter max" => $r["b mod $counter max"],
"c mod $counter" => $r["c mod $counter"],
"c mod $counter chance" => $r["c mod $counter chance"],
"c mod $counter param" => $r["c mod $counter param"],
"c mod $counter min" => $r["c mod $counter min"],
"c mod $counter max" => $r["c mod $counter max"],
]);
$m[] = array_filter($mods);
}
$output['mods'] = array_filter($m);
$result = [];
2021-05-15 07:23:25 +00:00
//var_dump($output['mods']);
2021-05-15 07:23:25 +00:00
foreach ($output['mods'] as $k => $v) {
$prop = ($v["mod " . $k + 1]);
$par = ($v["mod " . $k + 1 . " param"]) ?? "";
$min = ($v["mod " . $k + 1 . " min"]) ?? $max;
$max = ($v["mod " . $k + 1 . " max"]) ?? $min;
2021-05-15 07:23:25 +00:00
//var_dump($min);
$output['mods'][$k]["isc"] = $isc[$prop];
$params = [
'string1' => $output['mods'][$k]["isc"]['string1'],
'string2' => $output['mods'][$k]["isc"]['string2'],
'descfunc' => $output['mods'][$k]["isc"]['descfunc'],
'descval' => $output['mods'][$k]["isc"]['descval'],
"prop" => $prop,
"par" => $par,
"min" => $min,
"max" => $max,
2021-05-15 07:23:25 +00:00
// "val1" => $funcval['val1'],
// "func1" => $funcval['func1']
// 'item' => $return
];
$output['mods'][$k]["str"] = $idesc->getDesc($params);
//var_dump($output['mods'][$k]["isc"]);
}
//ddump($idata->getIscStrings("energy"));
2021-05-10 16:41:26 +00:00
/*
* Echo out each row as HTML with all the data it may have
2021-05-15 07:23:25 +00:00
*
2021-05-10 16:41:26 +00:00
*/
// echo "<tr>";
// foreach ($output as $k => $v) {
2021-05-15 07:23:25 +00:00
//
2021-05-10 16:41:26 +00:00
// // if input 1, input 2 is an array
2021-05-15 07:23:25 +00:00
//
2021-05-10 16:41:26 +00:00
// if (is_array($v)){
// echo "<td><img src=\"/img/items/{$v['img']}\">{$v[0]}: {$v[1]}</td>";
// echo "<td><img src=\"/img/items/{$v['img']}\">{$v[0]}: {$v[1]}</td>";
// } else {
2021-05-15 07:23:25 +00:00
//
2021-05-10 16:41:26 +00:00
// $img = "";
2021-05-15 07:23:25 +00:00
// // if input 1, input 2 ... etc. are not arrays
2021-05-10 16:41:26 +00:00
// echo '<td><img src="'.$o.'"></td>';
// }
2021-05-15 07:23:25 +00:00
// }
2021-05-10 16:41:26 +00:00
// echo "</tr>";
$htmlRow = "<tr>";
$htmlRow .= "<td class='desc'>" . $output['desc'] . "</td>";
2021-05-10 16:41:26 +00:00
for ($i = 1; $i <= 7; $i++) {
2021-05-10 16:41:26 +00:00
$htmlRow .= "<td class='input$i'>";
if (!empty($output["input $i"]["img"])) {
$htmlRow .= "<img src='img/items/{$output["input $i"]["img"]}'><br>";
2021-05-15 07:23:25 +00:00
if (str_contains($output["input $i"][0], "ÿc")) {
$p = "/ÿc[\d:;\/.]/i";
$output["input $i"][0] = preg_replace($p, "", $output["input $i"][0]);
}
$ostr = implode("<br>", (array_reverse(explode('\n', $output["input $i"][0]))));
$htmlRow .= $ostr . "<br>";
if (str_contains($output["input $i"][1], "=")) {
$htmlRow .= $output["input $i"][1] . "<br>";
} else {
$htmlRow .= $i_params[$output["input $i"][1]] . "<br>";
}
}
$htmlRow .= "</td>";
}
$htmlRow .= "<td class='output1'>";
if (!empty($output["output"]["img"])) {
$htmlRow .= "<img src='img/items/{$output["output"]["img"]}'><br>";
2021-05-15 07:23:25 +00:00
if (str_contains($output["output"][0], "ÿc")) {
$p = "/ÿc[\d:;\/.]/i";
$output["output"][0] = preg_replace($p, "", $output["output"][0]);
}
2021-05-15 07:23:25 +00:00
if (str_contains($output["output"][1], "ÿc")) {
$p = "/ÿc[\d:;\/.]/i";
$output["output"][1] = preg_replace($p, "", $output["output"][1]);
2021-05-15 07:23:25 +00:00
}
if ($i_params[$output["output"][0]]) {
2021-05-15 07:23:25 +00:00
$htmlRow .= '<span style="color: #AF833B;">' . $output["output"][0] . "</span><br>";
} else {
2021-05-15 07:23:25 +00:00
$htmlRow .= $output["output"][0] . "<br>";
}
if ($i_params[$output["output"][1]]) {
2021-05-15 07:23:25 +00:00
$htmlRow .= $i_params[$output["output"][1]] . "<br>";
} else {
2021-05-15 07:23:25 +00:00
$htmlRow .= $output["output"][1] . "<br>";
}
for ($i = 1; $i <= 5; $i++) {
2021-05-15 07:23:25 +00:00
if ($output["mods"][0]["mod $i"]) {
2021-05-15 07:23:25 +00:00
if (str_contains($output["mods"][0]["str"], "ÿc")) {
$p = "/ÿc[\d:;\/.]/i";
$output["mods"][0]["str"] = preg_replace($p, "", $output["mods"][0]["str"]);
}
$htmlRow .= str_replace("\n", "<br>", "<span class='blue'>{$output["mods"][0]["str"]}</span><br><br>");
2021-05-10 16:41:26 +00:00
}
if ($output["mods"][0]["mod $i chance"]) {
$htmlRow .= "<span style='color: #FFA500'>Chance:{$output["mods"][0]["mod $i chance"]}</span><br>";
2021-05-10 16:41:26 +00:00
}
}
}
$htmlRow .= "</td>";
$htmlRow .= "<td class='output2'>";
if (!empty($output["output 2"]["img"])) {
$htmlRow .= "<img src='img/items/{$output["output 2"]["img"]}'><br>";
2021-05-15 07:23:25 +00:00
if (str_contains($output["output b"][0], "ÿc")) {
$p = "/ÿc[\d:;\/.]/i";
$output["output b"][0] = preg_replace($p, "", $output["output b"][0]);
}
2021-05-15 07:23:25 +00:00
if (str_contains($output["output b"][1], "ÿc")) {
$p = "/ÿc[\d:;\/.]/i";
$output["output b"][1] = preg_replace($p, "", $output["output b"][1]);
2021-05-15 07:23:25 +00:00
}
$htmlRow .= $output["output b"][0] . "<br>";
$htmlRow .= $output["output b"][1] . "<br>";
for ($i = 1; $i <= 5; $i++) {
if ($output["mods"][1]["mod $i"]) {
$htmlRow .= "{$output["mods"][1]["mod $i"]}<br>";
}
2021-05-10 16:41:26 +00:00
if ($output["mods"][1]["mod $i chance"]) {
$htmlRow .= "Chance:{$output["mods"][1]["mod $i chance"]}<br>";
2021-05-10 16:41:26 +00:00
}
if ($output["mods"][1]["mod $i min"]) {
$htmlRow .= "Min:{$output["mods"][1]["mod $i min"]}<br>";
}
if ($output["mods"][1]["mod $i max"]) {
$htmlRow .= "Max:{$output["mods"][1]["mod $i max"]}";
}
}
}
$htmlRow .= "</td>";
$htmlRow .= "<td class='output3'>";
if (!empty($output["output 3"]["img"])) {
$htmlRow .= "<img src='img/items/{$output["output 3"]["img"]}'><br>";
2021-05-15 07:23:25 +00:00
if (str_contains($output["output c"][0], "ÿc")) {
$p = "/ÿc[\d:;\/.]/i";
$output["output c"][0] = preg_replace($p, "", $output["output c"][0]);
}
2021-05-15 07:23:25 +00:00
if (str_contains($output["output c"][1], "ÿc")) {
$p = "/ÿc[\d:;\/.]/i";
$output["output c"][1] = preg_replace($p, "", $output["output c"][1]);
2021-05-15 07:23:25 +00:00
}
$htmlRow .= $output["output c"][0] . "<br>";
$htmlRow .= $output["output c"][1] . "<br>";
for ($i = 1; $i <= 5; $i++) {
if ($output["mods"][2]["mod $i"]) {
$htmlRow .= "{$output["mods"][2]["mod $i"]}<br>";
2021-05-10 16:41:26 +00:00
}
if ($output["mods"][2]["mod $i chance"]) {
$htmlRow .= "Chance:{$output["mods"][2]["mod $i chance"]}<br>";
}
2021-05-10 16:41:26 +00:00
if ($output["mods"][2]["mod $i min"]) {
$htmlRow .= "Min:{$output["mods"][2]["mod $i min"]}<br>";
}
if ($output["mods"][2]["mod $i max"]) {
$htmlRow .= "Max:{$output["mods"][2]["mod $i max"]}";
2021-05-10 16:41:26 +00:00
}
}
}
$htmlRow .= "</td>";
$htmlRow .= "</tr>";
2021-05-10 16:41:26 +00:00
2021-05-15 07:23:25 +00:00
// echo $htmlRow;
// ob_flush();
2021-05-10 16:41:26 +00:00
$htmlFinal .= $htmlRow;
2021-05-10 16:41:26 +00:00
//ddump($i_params['levelreq']);
//var_dump($output);
2021-05-15 07:23:25 +00:00
//ob_flush();
unset($output);
}// end each row loop
$tableBottom = <<<EOT
2021-05-10 16:41:26 +00:00
</tbody>
<table>
EOT;
2021-05-15 07:23:25 +00:00
//echo $tableBottom;
//echo $htmlbottom;
//ob_flush();
$htmlFinal .= $tableBottom . $htmlbottom;
file_put_contents("$dir/cubemain.html", $htmlFinal);
header("Location: docs/{$_SESSION['modname']}/cubemain.html");
}
//if ($cmd == "getIscStrings") {
//
//
//
// $sql = "
2021-05-15 07:23:25 +00:00
// SELECT p.`code` as prop,
// p.stat1,
// i.descstrpos,
// i.descstr2,
// i.descfunc,
// i.descval,
// i.dgrp,
// i.dgrpfunc,
// i.dgrpval,
// i.dgrpstrpos,
// i.dgrpstrneg,
// s1.String as string1,
// s2.String as string2,
// s3.String as gstring1,
2021-05-15 07:23:25 +00:00
// s4.String as gstring2
// FROM properties as p
//
// LEFT JOIN itemstatcost as i
// ON p.stat1 = i.Stat
//
// LEFT JOIN strings as s1
// ON i.descstrpos = s1.Key
// LEFT JOIN strings as s2
// ON i.descstr2 = s2.Key
//
// LEFT JOIN strings as s3
// ON i.dgrpstrpos = s3.Key
// LEFT JOIN strings as s4
// ON i.dgrpstr2= s4.Key
//";
2021-05-15 07:23:25 +00:00
//
// $res = PDO_FetchAll($sql);
//
// $isc = null;
// foreach ($res as $r) {
// $isc[$r['prop']] = $r;
// $isc[$r['prop']]['prop'] = $r['prop'];
// }
//
//
// var_dump($isc);
//}
if ($cmd == "getImages") {
$sql = "
2021-05-15 07:23:25 +00:00
SELECT code,invfile,type,type2 FROM armor
UNION ALL
SELECT code,invfile,type,type2 FROM misc
UNION ALL
SELECT code,invfile,type,type2 FROM weapons
";
2021-05-15 07:23:25 +00:00
$res = PDO_FetchAll($sql);
$isc = null;
foreach ($res as $r) {
$isc1[$r['code']] = $r;
$isc1[$r['code']]['code'] = $r['prop'];
2021-05-15 07:23:25 +00:00
$isc2[$r['type']] = $r;
2021-05-15 07:23:25 +00:00
$isc2[$r['type']]['type'] = $r['prop'];
}
$isc = array_merge($isc1, $isc2);
2021-05-15 07:23:25 +00:00
unset($isc1);
unset($isc2);
var_dump(($isc));
}
2021-05-15 07:23:25 +00:00
/*
* Gem Doc Generator
*
*
*
*/
if ($cmd == "genDocGems") {
$sql = "
SELECT g.*,m.invfile,m.type,m.type2,s.String
FROM gems as g
LEFT JOIN misc as m
ON g.code = m.code
LEFT JOIN strings as s
ON g.code = s.Key
";
$res = array_filter(PDO_FetchAll($sql));
//ddump($res);
foreach ($res as $r) {
for ($i = 1; $i <= 3; $i++) {
$params = [
'string1' => $isc[$r["weaponMod{$i}Code"]]['string1'],
'string2' => $isc[$r["weaponMod{$i}Code"]]['string2'],
'gstring1' => $isc[$r["weaponMod{$i}Code"]]['gstring'],
'gstring2' => $isc[$r["weaponMod{$i}Code"]]['gstring2'],
'descfunc' => $isc[$r["weaponMod{$i}Code"]]['descfunc'],
'descval' => $isc[$r["weaponMod{$i}Code"]]['descval'],
'dgrp' => $isc[$r["weaponMod{$i}Code"]]['dgrp'],
'dgrpfunc' => $isc[$r["weaponMod{$i}Code"]]['dgrpfunc'],
'dgrpval' => $isc[$r["weaponMod{$i}Code"]]['dgrpval'],
"prop" => $isc[$r["weaponMod{$i}Code"]]['prop']
];
// weapons
$params["par"] = $r["weaponMod{$i}Param"];
$params["min"] = $r["weaponMod{$i}Min"];
$params["max"] = $r["weaponMod{$i}Max"];
if ($r["weaponMod{$i}Code"]) {
$r["weaponMod{$i}Code"] = $idesc->getDesc($params);
}
//var_dump($params);
$params = [
'string1' => $isc[$r["helmMod{$i}Code"]]['string1'],
'string2' => $isc[$r["helmMod{$i}Code"]]['string2'],
'gstring1' => $isc[$r["helmMod{$i}Code"]]['gstring'],
'gstring2' => $isc[$r["helmMod{$i}Code"]]['gstring2'],
'descfunc' => $isc[$r["helmMod{$i}Code"]]['descfunc'],
'descval' => $isc[$r["helmMod{$i}Code"]]['descval'],
'dgrp' => $isc[$r["helmMod{$i}Code"]]['dgrp'],
'dgrpfunc' => $isc[$r["helmMod{$i}Code"]]['dgrpfunc'],
'dgrpval' => $isc[$r["helmMod{$i}Code"]]['dgrpval'],
"prop" => $isc[$r["helmMod{$i}Code"]]['prop']
];
// helms
$params["par"] = $r["helmMod{$i}Param"];
$params["min"] = $r["helmMod{$i}Min"];
$params["max"] = $r["helmMod{$i}Max"];
if ($r["helmMod{$i}Code"]) {
$r["helmMod{$i}Code"] = $idesc->getDesc($params);
}
//var_dump($params);
$params = [
'string1' => $isc[$r["helmMod{$i}Code"]]['string1'],
'string2' => $isc[$r["helmMod{$i}Code"]]['string2'],
'gstring1' => $isc[$r["helmMod{$i}Code"]]['gstring'],
'gstring2' => $isc[$r["helmMod{$i}Code"]]['gstring2'],
'descfunc' => $isc[$r["helmMod{$i}Code"]]['descfunc'],
'descval' => $isc[$r["helmMod{$i}Code"]]['descval'],
'dgrp' => $isc[$r["helmMod{$i}Code"]]['dgrp'],
'dgrpfunc' => $isc[$r["helmMod{$i}Code"]]['dgrpfunc'],
'dgrpval' => $isc[$r["helmMod{$i}Code"]]['dgrpval'],
"prop" => $isc[$r["helmMod{$i}Code"]]['prop']
];
//shields
$params["par"] = $r["shieldMod{$i}Param"];
$params["min"] = $r["shieldMod{$i}Min"];
$params["max"] = $r["shieldMod{$i}Max"];
if ($r["shieldMod{$i}Code"]) {
$r["shieldMod{$i}Code"] = $idesc->getDesc($params);
}
//var_dump($params);
if (str_contains($r['String'], "ÿc")) {
$p = "/ÿc[\d:;\/.]/i";
$r['String'] = preg_replace($p, "", $r['String']);
}
}
$gems[] = array_filter($r);
}
$htmlFinal = '';
$htmlFinal .= $htmltop;
//echo $htmltop;
//ob_flush();
$css = <<<EOT
<style>
body{
background: white;
color: black;
font-family: ExocetHeavy;
text-transform: uppercase;
}
table, table th, table td, table tr {
background: #111;
color: #ccc;
}
.item_stats{
width: auto;
height: auto;
}
.item_desc {
height: auto;
text-align: center;
padding: 10px;
text-transform: uppercase;
}
.green {
color: #00FF00; /*Set items*/
}
.gold{
color: #A59263; /*Set items*/
}
.orange{
color: #FFA500; /*Set items*/
}
.yellow {
color: #FFFF00; /*Set items*/
}
.blue {
color: #4169E1;
}
table {
}
.desc {
width: 200px;
font-family: ExocetHeavy;
font-size: 1.25em;
text-transform: uppercase;
background: #111;
}
.input1,.input3,.input5,.input7{
background: #444;
}
.input2, .input4, .input6 {
background: #333;
}
.output1{
background: #222;
}
.output2 {
background: #222;
}
.output3 {
background: #222;
}
td {
height: 240px;
text-align: center;
vertical-align: middle;
padding: 10px;
white-space: nowrap;
}
img {
height: 56px;
width: auto;
}
</style>
EOT;
//echo $css;
$htmlFinal .= $css;
//ob_flush();
$table = <<<EOT
<table border=1 class="gemtable">
<thead>
<tr>
<th>Name</th>
<th>Code</th>
<th>Type</th>
<th>Mods</th>
<th>Weapons</th>
<th>Helms</th>
<th>Shields</th>
</tr>
</thead>
<tbody>
EOT;
//echo $table;
$htmlFinal .= $table;
//ob_flush();
//ddump($isc);
//ddump($idesc->getDesc($isc['cold-len']));
//ddump($gems);
//$x = array_shift($gems);
foreach ($gems as $g) {
if ($g['name'] == "Expansion") {
continue;
}
$htmlRow = "<tr>";
$htmlRow .= "<td class='name'>
<img style='height: 28px;width:28px;' src='img/items/{$g["invfile"]}.png'><br>
{$g['String']}
</td>
";
$htmlRow .= "<td class='code'>
{$g['code']}
</td>
";
$htmlRow .= "<td class='type'>
{$g['type']}
</td>
";
$htmlRow .= "<td class='nummods'>
Mods: {$g['nummods']}
</td>
";
$htmlRow .= "<td class='weapons blue'>
<img src='img/weapon.png'><br>
{$g['weaponMod1Code']}<br>
{$g['weaponMod2Code']}<br>
{$g['weaponMod3Code']}<br>
</td>
";
$htmlRow .= "<td class='helms gold'>
<img src='img/helm.png'><br>
{$g['helmMod1Code']}<br>
{$g['helmMod2Code']}<br>
{$g['helmMod3Code']}<br>
</td>
";
$htmlRow .= "<td class='shields'>
<img src='img/shield.png'><br>
{$g['shieldMod1Code']}<br>
{$g['shieldMod2Code']}<br>
{$g['shieldMod3Code']}<br>
</td>
";
$htmlRow .= "</tr>";
$htmlFinal .= $htmlRow;
// echo $htmlRow;
// ob_flush();
}
$htmlFinal .= $tableBottom . $htmlbottom;
// echo $tableBottom . $htmlbottom;
// ob_flush();
//
// ob_start();
file_put_contents("$dir/gems.html", $htmlFinal);
header("Location: /docs/{$_SESSION['modname']}/gems.html");
}