NT IRN app tweaks, bugfixes and code refactor (#20421)

* nod

* mhm

* doomed

* woooop

* should

* Update Cargo.js
This commit is contained in:
Bop
2023-10-01 10:50:23 +07:00
committed by GitHub
parent 9fdbd85811
commit d646ecc5bd
6 changed files with 63 additions and 25 deletions

View File

@@ -90,7 +90,8 @@
"cost" = SO.pack.get_cost(),
"id" = SO.id,
"orderer" = SO.orderer,
"paid" = !isnull(SO.paying_account) //paid by requester
"paid" = !isnull(SO.paying_account), //paid by requester
"budget" = SO.budget
))
data["requests"] = list()
@@ -100,7 +101,8 @@
"cost" = SO.pack.get_cost(),
"orderer" = SO.orderer,
"reason" = SO.reason,
"id" = SO.id
"id" = SO.id,
"budget" = SO.budget
))
return data

View File

@@ -27,10 +27,11 @@
var/orderer_rank
var/orderer_ckey
var/reason
var/budget
var/datum/supply_pack/pack
var/datum/bank_account/paying_account
/datum/supply_order/New(datum/supply_pack/pack, orderer, orderer_rank, orderer_ckey, reason, paying_account)
/datum/supply_order/New(datum/supply_pack/pack, orderer, orderer_rank, orderer_ckey, reason, paying_account, budget)
id = SSshuttle.ordernum++
src.pack = pack
src.orderer = orderer
@@ -38,6 +39,7 @@
src.orderer_ckey = orderer_ckey
src.reason = reason
src.paying_account = paying_account
src.budget = budget
/datum/supply_order/proc/generateRequisition(turf/T)
var/obj/item/paper/P = new(T)
@@ -51,6 +53,7 @@
P.info += "Requested by: [orderer]<br/>"
if(paying_account)
P.info += "Paid by: [paying_account.account_holder]<br/>"
P.info += "Crate Type: [budget? "[paying_account.account_holder] Crate":"Normal Crate"]<br/>"
P.info += "Rank: [orderer_rank]<br/>"
P.info += "Comment: [reason]<br/>"
@@ -70,6 +73,7 @@
P.name += " - Purchased by [owner]"
P.info += "Order[packname?"":"s"]: [id]<br/>"
P.info += "Destination: [station_name]<br/>"
P.info += "Crate Type: [budget? "[paying_account.account_holder] Crate":"Normal Crate"]<br/>"
if(packname)
P.info += "Item: [packname]<br/>"
P.info += "Contents: <br/>"

View File

@@ -30,8 +30,11 @@
if(id)
return id.registered_name
var/obj/item/pda/pda = wear_id
var/obj/item/modular_computer/tablet/tablet = wear_id
if(istype(pda))
return pda.owner
if(istype(tablet))
return tablet.name
return if_no_id
//repurposed proc. Now it combines get_id_name() and get_face_name() to determine a mob's name variable. Made into a separate proc as it'll be useful elsewhere

View File

@@ -27,6 +27,12 @@
var/blockade_warning = "Bluespace instability detected. Shuttle movement impossible."
/// Can send the shuttle **AWAY** from the station
var/can_send = FALSE
///Is it being bought from a departmental budget?
var/budget_order = FALSE
///If this is true, unlock the ability to order through budgets
var/unlock_budget = TRUE
///account for everything
var/datum/bank_account/account
/datum/computer_file/program/budgetorders/proc/get_export_categories()
. = EXPORT_CARGO
@@ -67,14 +73,17 @@
. = ..()
var/list/data = get_header_data()
data["location"] = SSshuttle.supply.getStatusText()
var/datum/bank_account/buyer = SSeconomy.get_dep_account(ACCOUNT_CAR)
account = SSeconomy.get_dep_account(ACCOUNT_CAR)
var/obj/item/computer_hardware/card_slot/card_slot = computer.all_components[MC_CARD]
var/obj/item/card/id/id_card = card_slot?.GetID()
if(id_card?.registered_account)
unlock_budget = TRUE
if(id_card?.registered_account?.account_job?.paycheck_department == ACCOUNT_CAR)
unlock_budget = FALSE //cargo tech is already using the same budget.
if(id_card?.registered_account?.account_job?.paycheck_department && budget_order)
account = SSeconomy.get_dep_account(id_card.registered_account.account_job.paycheck_department)
if((ACCESS_HEADS in id_card.access) || (ACCESS_QM in id_card.access) || (ACCESS_CARGO in id_card.access))
requestonly = FALSE
if(id_card?.registered_account?.account_job?.paycheck_department)
buyer = SSeconomy.get_dep_account(id_card.registered_account.account_job.paycheck_department)
can_approve_requests = TRUE
can_send = TRUE
else
@@ -83,8 +92,9 @@
can_send = FALSE
else
requestonly = TRUE
if(buyer)
data["points"] = buyer.account_balance
unlock_budget = FALSE //none registered account shouldnt be using budget order
if(account)
data["points"] = account.account_balance
//Otherwise static data, that is being applied in ui_data as the crates visible and buyable are not static, and are determined by inserted ID.
data["requestonly"] = requestonly
@@ -109,9 +119,10 @@
))
//Data regarding the User's capability to buy things.
data["has_id"] = id_card
data["away"] = SSshuttle.supply.getDockedId() == "supply_away"
data["self_paid"] = self_paid
data["unlock_budget"] = unlock_budget
data["budget_order"] = budget_order
data["docked"] = SSshuttle.supply.mode == SHUTTLE_IDLE
data["loan"] = !!SSshuttle.shuttle_loan
data["loan_dispatched"] = SSshuttle.shuttle_loan && SSshuttle.shuttle_loan.dispatched
@@ -131,7 +142,8 @@
"cost" = SO.pack.cost,
"id" = SO.id,
"orderer" = SO.orderer,
"paid" = !isnull(SO.paying_account) //paid by requester
"paid" = !isnull(SO.paying_account), //paid by requester
"budget" = SO.budget
))
data["requests"] = list()
@@ -141,7 +153,8 @@
"cost" = SO.pack.cost,
"orderer" = SO.orderer,
"reason" = SO.reason,
"id" = SO.id
"id" = SO.id,
"budget" = SO.budget
))
return data
@@ -197,13 +210,14 @@
var/ckey = usr.ckey
if(ishuman(usr))
var/mob/living/carbon/human/H = usr
name = H.get_authentification_name()
if(budget_order)
name = account.account_holder
else
name = H.get_authentification_name()
rank = H.get_assignment(hand_first = TRUE)
else if(issilicon(usr))
name = usr.real_name
rank = "Silicon"
var/datum/bank_account/account
if(self_paid && ishuman(usr))
var/mob/living/carbon/human/H = usr
var/obj/item/card/id/id_card = H.get_idcard(TRUE)
@@ -226,16 +240,17 @@
if(!self_paid && ishuman(usr) && !account)
var/obj/item/card/id/id_card = card_slot?.GetID()
account = SSeconomy.get_dep_account(id_card?.registered_account?.account_job.paycheck_department)
if(budget_order)
account = SSeconomy.get_dep_account(id_card?.registered_account?.account_job.paycheck_department)
var/turf/T = get_turf(src)
var/datum/supply_order/SO = new(pack, name, rank, ckey, reason, account)
var/turf/T = get_turf(computer)
var/datum/supply_order/SO = new(pack, name, rank, ckey, reason, account, account.account_holder)
SO.generateRequisition(T)
if((requestonly && !self_paid) || !(card_slot?.GetID()))
SSshuttle.requestlist += SO
else
SSshuttle.shoppinglist += SO
if(self_paid)
if(self_paid || budget_order)
computer.say("Order processed. The price will be charged to [account.account_holder]'s bank account on delivery.")
. = TRUE
if("remove")
@@ -252,9 +267,6 @@
var/id = text2num(params["id"])
for(var/datum/supply_order/SO in SSshuttle.requestlist)
if(SO.id == id)
var/obj/item/card/id/id_card = card_slot?.GetID()
if(id_card && id_card?.registered_account)
SO.paying_account = SSeconomy.get_dep_account(id_card?.registered_account?.account_job.paycheck_department)
SSshuttle.requestlist -= SO
SSshuttle.shoppinglist += SO
. = TRUE
@@ -271,6 +283,13 @@
. = TRUE
if("toggleprivate")
self_paid = !self_paid
if(budget_order)
budget_order = FALSE //incase something fucked
. = TRUE
if("togglebudget")
budget_order = !budget_order
if(self_paid)
self_paid = FALSE //incase something fucked
. = TRUE
if(.)
post_signal("supply")

View File

@@ -26,7 +26,6 @@ GLOBAL_LIST_INIT(blacklisted_cargo_types, typecacheof(list(
/obj/structure/extraction_point,
/obj/machinery/syndicatebomb,
/obj/item/hilbertshotel,
/obj/structure/closet/crate/secure/owned,
/obj/structure/closet/bluespace // yogs - nope nice try
)))
@@ -61,6 +60,9 @@ GLOBAL_LIST_INIT(blacklisted_cargo_types, typecacheof(list(
for(var/trf in shuttle_area)
var/turf/T = trf
for(var/a in T.get_all_contents())
for(var/obj/structure/closet/crate/secure/owned/crate in a)
if(crate.locked)
return FALSE
if(is_type_in_typecache(a, GLOB.blacklisted_cargo_types))
return FALSE
return TRUE

View File

@@ -128,7 +128,7 @@ export const CargoCatalog = (props, context) => {
const { express } = props;
const { act, data } = useBackend(context);
const { self_paid, app_cost } = data;
const { self_paid, app_cost, budget_order, unlock_budget } = data;
const supplies = Object.values(data.supplies);
const [
@@ -144,11 +144,16 @@ export const CargoCatalog = (props, context) => {
buttons={!express && (
<>
<CargoCartButtons />
<Button.Checkbox
{!budget_order && <Button.Checkbox
ml={2}
content="Buy Privately"
checked={self_paid}
onClick={() => act('toggleprivate')} />
onClick={() => act('toggleprivate')} />}
{!self_paid && !!unlock_budget && <Button.Checkbox
ml={2}
content="Departmental Purchasing"
checked={budget_order}
onClick={() => act('togglebudget')} />}
</>
)}>
<Flex>
@@ -347,6 +352,9 @@ const CargoCart = (props, context) => {
{entry.object}
</Table.Cell>
<Table.Cell collapsing>
{!!entry.budget && (
<b>[{entry.budget}]</b>
)}
{!!entry.paid && (
<b>[Paid Privately]</b>
)}