Skeleton: Fetch static data (teams/drivers/races/substitutions) in global layout asynchronously
All checks were successful
Build Formula11 Docker Image / pocketbase-docker (push) Successful in 29s
All checks were successful
Build Formula11 Docker Image / pocketbase-docker (push) Successful in 29s
This commit is contained in:
@ -12,28 +12,30 @@
|
||||
data_value_name: "race",
|
||||
label: "Step",
|
||||
valuefun: async (value: string): Promise<string> =>
|
||||
`<span class='badge variant-filled-surface'>${get_by_value(data.races, "id", value)?.step}</span>`,
|
||||
`<span class='badge variant-filled-surface'>${get_by_value(await data.races, "id", value)?.step}</span>`,
|
||||
},
|
||||
{
|
||||
data_value_name: "race",
|
||||
label: "Race",
|
||||
valuefun: async (value: string): Promise<string> =>
|
||||
`<span>${get_by_value(data.races, "id", value)?.name}</span>`,
|
||||
`<span>${get_by_value(await data.races, "id", value)?.name}</span>`,
|
||||
},
|
||||
{
|
||||
data_value_name: "race",
|
||||
label: "Guessed",
|
||||
valuefun: async (value: string): Promise<string> =>
|
||||
`<span>P${get_by_value(data.races, "id", value)?.pxx}</span>`,
|
||||
`<span>P${get_by_value(await data.races, "id", value)?.pxx}</span>`,
|
||||
},
|
||||
{
|
||||
data_value_name: "pxxs",
|
||||
label: "Standing",
|
||||
valuefun: async (value: string): Promise<string> => {
|
||||
const pxxs_array: string[] = value.toString().split(",");
|
||||
const pxxs_codes: string[] = pxxs_array.map(
|
||||
(id: string, index: number) =>
|
||||
`<span class='w-10 badge mr-2 text-center' style='background: ${PXX_COLORS[index]};'>${get_by_value(data.drivers, "id", id)?.code ?? "Invalid"}</span>`,
|
||||
const pxxs_codes: string[] = await Promise.all(
|
||||
pxxs_array.map(
|
||||
async (id: string, index: number) =>
|
||||
`<span class='w-10 badge mr-2 text-center' style='background: ${PXX_COLORS[index]};'>${get_by_value(await data.drivers, "id", id)?.code ?? "Invalid"}</span>`,
|
||||
),
|
||||
);
|
||||
|
||||
return pxxs_codes.join("");
|
||||
@ -46,9 +48,11 @@
|
||||
if (value.length === 0 || value === "") return "";
|
||||
|
||||
const dnfs_array: string[] = value.toString().split(",");
|
||||
const dnfs_codes: string[] = dnfs_array.map(
|
||||
(id: string) =>
|
||||
`<span class='w-10 text-center badge mr-2' style='background: ${PXX_COLORS[3]}'>${get_by_value(data.drivers, "id", id)?.code ?? "Invalid"}</span>`,
|
||||
const dnfs_codes: string[] = await Promise.all(
|
||||
dnfs_array.map(
|
||||
async (id: string) =>
|
||||
`<span class='w-10 text-center badge mr-2' style='background: ${PXX_COLORS[3]}'>${get_by_value(await data.drivers, "id", id)?.code ?? "Invalid"}</span>`,
|
||||
),
|
||||
);
|
||||
|
||||
return dnfs_codes.join("");
|
||||
@ -64,8 +68,8 @@
|
||||
component: "raceResultCard",
|
||||
meta: {
|
||||
disable_inputs: !data.admin,
|
||||
drivers: data.drivers,
|
||||
races: data.races,
|
||||
drivers: await data.drivers,
|
||||
races: await data.races,
|
||||
result: get_by_value(data.results, "id", id),
|
||||
},
|
||||
};
|
||||
@ -73,14 +77,14 @@
|
||||
modalStore.trigger(modalSettings);
|
||||
};
|
||||
|
||||
const create_result_handler = (event: Event) => {
|
||||
const create_result_handler = async (event: Event) => {
|
||||
const modalSettings: ModalSettings = {
|
||||
type: "component",
|
||||
component: "raceResultCard",
|
||||
meta: {
|
||||
disable_inputs: !data.admin,
|
||||
drivers: data.drivers,
|
||||
races: data.races,
|
||||
drivers: await data.drivers,
|
||||
races: await data.races,
|
||||
require_inputs: true,
|
||||
},
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user