d2tools/genDocs.php
2021-05-10 01:15:44 -06:00

467 lines
12 KiB
PHP
Executable File

<?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.
* 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';
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'];
$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">
<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">
<link rel="stylesheet" href="res/style.css">
<style>
body{
background: black;
text-align: center;
font-family: ExocetLight;
}
.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;
}
</style>
<script src="res/jquery-3.6.0.min.js"></script>
<script src="res/bootstrap.bundle.min.js"></script>
<script src="res/app.js"></script>
</script>
<title>D2Modder</title>
</head>
<body>
<div class="container container-top">
<h1>{$_SESSION['modname']} Unique Items</h1>
<p>Auto generated with D2Modder by Hash Casper</p>
EOT;
$htmlbottom = <<<EOT
</div>
</body>
</html>
EOT;
/*
*
*
*
*
*
@cmd = genDocUniqueItems
*
*
*
*
*
*/
if ($cmd == "genDocUniqueItems") {
// grab unique item index only (to save on memory)
$sql = "SELECT `index` FROM `uniqueitems` WHERE `enabled`='1'";
$uIndex = PDO_FetchAll($sql);
//ddump($uIndex);
$htmlFinal = '';
$htmlFinal .= $htmltop;
echo $htmltop;
ob_flush();
$dir = getcwd() . "/docs/{$_SESSION['modname']}";
mkdir($dir, 0777, true);
/*
START MAIN LOOP HERE
*
* For each unique item index, now grab item data
*
*/
foreach ($uIndex as $u) {
//$items[] = $idata->uniqueItems($u['index'], true);
//var_dump($u['index']);
$item = $idata->uniqueItems($u['index'], true);
$itemBoxTop = <<<EOT
<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="">
<div style="width:auto; margin: 0 auto; background:#111; display:inline-block;">
<p>
EOT;
$itemBoxBottom = <<<EOT
</p>
</div>
</div>
</div>
EOT;
echo $itemBoxTop;
ob_flush();
$htmlFinal .= $itemBoxTop;
//index
$props = "<ul><li class='statindex gold'>{$item['index']}</li>";
//type
$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
$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;
}// end loop
echo $htmlbottom;
$htmlFinal .= $htmlbottom;
file_put_contents("$dir/uniqueitems.html", $htmlFinal);
header("Location: /docs/{$_SESSION['modname']}/uniqueitems.html");
}
/*
*
*
*
*
*
@cmd = genDocCube
*
*
*
*
*
*/
if ($cmd == "genDocCube") {
$item_quality_params = [
"any" => "Any item (*Not Advised)",
"low" => "low quality",
"hiq" => "superior",
"nor" => "Normal",
"mag" => "Magic",
"rar" => "Rare",
"set" => "Set",
"uni" => "Unique",
"crf" => "Crafted",
"tmp" => "Tempered",
"eth" => "Ethereal",
"noe" => "Not Ethereal",
"nos" => "No Socket (for input)",
"sock" => "# sockets (eg: sock=>4)",
"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" => 'amount of same item(eg: "hpot, qty => 3" means 3 hp potions)',
"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";
$res = PDO_FetchAll($sql);
$desc = $res['description'];
/*
*
* Process each cube row here
for each cube row
*
*/
foreach ($res as $r) {
//ddump($r);
// 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"],
]
);
foreach ($input_codes as $inputNum => $value) {
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
$sql = "SELECT spelldescstr FROM `misc` WHERE `code`=\"{$oarray[0]}\"";
$spelldescstr = PDO_FetchOne($sql);
if (!empty($spelldescstr)) { // spelldescstr has value then grab it from tbl
$sql = "SELECT `String` FROM `strings` WHERE Key=\"$spelldescstr\"";
$str = PDO_FetchOne($sql);
} else { // grab item code's tbl string
$sql = "SELECT `String` FROM `strings` WHERE Key=\"{$oarray[0]}\"";
$str = PDO_FetchOne($sql);
}
// if empty str == 4-letter code, so just display
if (empty($str)) {
$input_codes[$inputNum][0] = $oarray[0];
} else {
$input_codes[$inputNum][0] = $str;
}
} else {
$sql = "SELECT spelldescstr FROM `misc` WHERE `code`=\"$value\"";
$spelldescstr = PDO_FetchOne($sql);
if (!empty($spelldescstr)) { // spelldescstr has value then grab it from tbl
$sql = "SELECT `String` FROM `strings` WHERE Key=\"$spelldescstr\"";
$str = PDO_FetchOne($sql);
} else { // grab item code's tbl string
$sql = "SELECT `String` FROM `strings` WHERE Key=\"$value\"";
$str = PDO_FetchOne($sql);
}
// if empty str == 4-letter code, so just display
if (empty($str)) {
$input_codes[$inputNum] = $value;
} else {
$input_codes[$inputNum] = $str;
}
}
}
/*
* TODO: processs output, output b, output c
*
*
*/
// 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]}\"";
$str = PDO_FetchOne($sql);
// if empty str == 4-letter code, so just display
if (empty($str)) {
$output_codes[$outputNum][0] = $oarray[0];
} else {
$output_codes[$outputNum][0] = $str;
}
} else { // else output code is three/four letter code
$sql = "SELECT `String` FROM `strings` WHERE Key=\"$value\"";
$str = PDO_FetchOne($sql);
// if empty str == 4-letter code, so just display
if (empty($str)) {
$output_codes[$outputNum] = $value;
} else {
$output_codes[$outputNum] = $str;
}
}
}
$output = array_merge($input_codes, $output_codes);
//var_dump($output);
/*
* TODO: process mods for each output
*
*
*/
$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);
var_dump($output);
unset($output);
}// end each row loop
}