#include "CDPropertyEntranceComponentTable.h"

namespace {
	CDPropertyEntranceComponent defaultEntry{};
};

void CDPropertyEntranceComponentTable::LoadValuesFromDatabase() {

	// First, get the size of the table
	size_t size = 0;
	auto tableSize = CDClientDatabase::ExecuteQuery("SELECT COUNT(*) FROM PropertyEntranceComponent");
	while (!tableSize.eof()) {
		size = tableSize.getIntField(0, 0);
		tableSize.nextRow();
	}

	tableSize.finalize();

	auto& entries = GetEntriesMutable();
	entries.reserve(size);

	auto tableData = CDClientDatabase::ExecuteQuery("SELECT * FROM PropertyEntranceComponent;");
	while (!tableData.eof()) {
		auto entry = CDPropertyEntranceComponent{
			static_cast<uint32_t>(tableData.getIntField("id", -1)),
			static_cast<uint32_t>(tableData.getIntField("mapID", -1)),
			tableData.getStringField("propertyName", ""),
			static_cast<bool>(tableData.getIntField("isOnProperty", false)),
			tableData.getStringField("groupType", "")
		};

		entries.push_back(entry);
		tableData.nextRow();
	}

	tableData.finalize();
}

CDPropertyEntranceComponent CDPropertyEntranceComponentTable::GetByID(uint32_t id) {
	for (const auto& entry : GetEntries()) {
		if (entry.id == id)
			return entry;
	}

	return defaultEntry;
}