forked from M-Labs/web2019
Compare commits
3 Commits
fb817e8f6d
...
86668f598f
Author | SHA1 | Date |
---|---|---|
Egor Savkin | 86668f598f | |
Egor Savkin | 1337250b07 | |
Egor Savkin | 43a0b0c10f |
File diff suppressed because one or more lines are too long
|
@ -480,7 +480,7 @@ const useCart = ((set, get) => ({
|
||||||
let itemsCopy = Array.from(crate.items);
|
let itemsCopy = Array.from(crate.items);
|
||||||
const disabled = !!get().crateParams(crate.crate_mode).warnings_disabled;
|
const disabled = !!get().crateParams(crate.crate_mode).warnings_disabled;
|
||||||
itemsCopy = FillResources(itemsCopy, disabled);
|
itemsCopy = FillResources(itemsCopy, disabled);
|
||||||
itemsCopy = TriggerWarnings(itemsCopy, disabled);
|
itemsCopy = TriggerWarnings(itemsCopy, disabled, crate);
|
||||||
const [crate_warnings, occupied] = TriggerCrateWarnings(crate);
|
const [crate_warnings, occupied] = TriggerCrateWarnings(crate);
|
||||||
return {
|
return {
|
||||||
...crate,
|
...crate,
|
||||||
|
|
|
@ -30,14 +30,14 @@ const find_next_source_index = (data, index, source) => {
|
||||||
}
|
}
|
||||||
|
|
||||||
const not_enough_resource_trigger = (name) => {
|
const not_enough_resource_trigger = (name) => {
|
||||||
return (_data, _index, counters) => {
|
return (_data, _index, counters, _crate) => {
|
||||||
const resource = find_in_counters(counters, name);
|
const resource = find_in_counters(counters, name);
|
||||||
return resource.occupied > resource.max;
|
return resource.occupied > resource.max;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const no_source_trigger = (name) => {
|
const no_source_trigger = (name) => {
|
||||||
return (data, index, _counters) => {
|
return (data, index, _counters, _crate) => {
|
||||||
const occupied = item_occupied_counters[name](data[index]);
|
const occupied = item_occupied_counters[name](data[index]);
|
||||||
if (occupied > 0)
|
if (occupied > 0)
|
||||||
return !find_previous_source(data, index, name);
|
return !find_previous_source(data, index, name);
|
||||||
|
@ -46,12 +46,20 @@ const no_source_trigger = (name) => {
|
||||||
}
|
}
|
||||||
|
|
||||||
const wiring_constraint = (name) => {
|
const wiring_constraint = (name) => {
|
||||||
return (data, index, _counters) => {
|
return (data, index, _counters, _crate) => {
|
||||||
const next = find_next_source_index(data, index, name);
|
const next = find_next_source_index(data, index, name);
|
||||||
return next - index === 1;
|
return next - index === 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const phaser_next_card_long = (data, index, counters, crate) => {
|
||||||
|
const nbrOccupied = resource_counters.hp(crate.items, -1);
|
||||||
|
const nbrHP = useShopStore.getState().crateParams(crate.crate_mode).hp;
|
||||||
|
return (index < data.length - 1) ? (
|
||||||
|
(data[index+1].consumes && data[index+1].consumes.depth && data[index+1].consumes.depth >= 8.5)
|
||||||
|
) : (nbrOccupied >= nbrHP && nbrHP > 0)
|
||||||
|
}
|
||||||
|
|
||||||
const Types = {
|
const Types = {
|
||||||
"eem_resource": {
|
"eem_resource": {
|
||||||
level: "warning",
|
level: "warning",
|
||||||
|
@ -88,22 +96,27 @@ const Types = {
|
||||||
trigger: wiring_constraint("eem"),
|
trigger: wiring_constraint("eem"),
|
||||||
message: "Due to wiring constraints, the carrier can only connect to EEM cards immediately at its right, without crossing another carrier."
|
message: "Due to wiring constraints, the carrier can only connect to EEM cards immediately at its right, without crossing another carrier."
|
||||||
},
|
},
|
||||||
|
"phaser_next_card_long": {
|
||||||
|
level: "reminder",
|
||||||
|
trigger: phaser_next_card_long,
|
||||||
|
message: "Next card may interfere with this Phaser. Consider placing a short card after this Phaser."
|
||||||
|
},
|
||||||
"default": {
|
"default": {
|
||||||
level: "warning",
|
level: "warning",
|
||||||
trigger: (_a, _b, _c) => {
|
trigger: (_a, _b, _c, _d) => {
|
||||||
return true;
|
return true;
|
||||||
},
|
},
|
||||||
message: 'This item has unimplemented warning'
|
message: 'This item has unimplemented warning'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export function TriggerWarnings(data, disabled) {
|
export function TriggerWarnings(data, disabled, crate) {
|
||||||
return data.map((element, index) => {
|
return data.map((element, index) => {
|
||||||
if (!element.warnings) return element;
|
if (!element.warnings) return element;
|
||||||
element.show_warnings = disabled ? [] :element.warnings
|
element.show_warnings = disabled ? [] :element.warnings
|
||||||
.map((warning, _) => {
|
.map((warning, _) => {
|
||||||
if (!!Types[warning])
|
if (!!Types[warning])
|
||||||
return Types[warning].trigger(data, index, element.counted_resources) ? {trigger: undefined, name: warning, ...Types[warning]} : null;
|
return Types[warning].trigger(data, index, element.counted_resources, crate) ? {trigger: undefined, name: warning, ...Types[warning]} : null;
|
||||||
else
|
else
|
||||||
return Types.default;
|
return Types.default;
|
||||||
})
|
})
|
||||||
|
@ -143,6 +156,22 @@ const crate_warnings = {
|
||||||
const nbrHPDesktop = useShopStore.getState().crate_modes.desktop.hp;
|
const nbrHPDesktop = useShopStore.getState().crate_modes.desktop.hp;
|
||||||
return crate.crate_mode === useShopStore.getState().crate_modes.rack.id && occupied < nbrHPDesktop;
|
return crate.crate_mode === useShopStore.getState().crate_modes.rack.id && occupied < nbrHPDesktop;
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"phaser_not_fit": {
|
||||||
|
message: "Since one or more Phasers may interfere with their next cards, they may additional space, that wouldn't fit into the crate. Consider removing cards, placing short cards after Phaser(s), or choosing larger crate.",
|
||||||
|
level: "warning",
|
||||||
|
trigger: (crate, occupied) => {
|
||||||
|
const nbrHP = useShopStore.getState().crateParams(crate.crate_mode).hp;
|
||||||
|
const stacked_phasers = crate.items.filter((elem, index, data) => {
|
||||||
|
return (elem.name_codename === "Phaser") && ((index < data.length - 1) ? (
|
||||||
|
(data[index + 1].consumes && data[index + 1].consumes.depth && data[index + 1].consumes.depth >= 8.5)
|
||||||
|
) : (occupied >= nbrHP && nbrHP > 0))
|
||||||
|
}
|
||||||
|
).length;
|
||||||
|
// #!debug
|
||||||
|
console.log(stacked_phasers, occupied)
|
||||||
|
return stacked_phasers > 0 && (occupied + stacked_phasers*2 >= nbrHP) && nbrHP >0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -221,7 +221,8 @@ const shop_data = {
|
||||||
"eem_wiring_constraint"
|
"eem_wiring_constraint"
|
||||||
],
|
],
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 8
|
hp: 8,
|
||||||
|
depth: 20
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
'kaslisoc': {
|
'kaslisoc': {
|
||||||
|
@ -297,7 +298,8 @@ const shop_data = {
|
||||||
"eem_wiring_constraint"
|
"eem_wiring_constraint"
|
||||||
],
|
],
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 8
|
hp: 8,
|
||||||
|
depth: 20
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
'vhdcicarrier': {
|
'vhdcicarrier': {
|
||||||
|
@ -322,7 +324,8 @@ const shop_data = {
|
||||||
"eem_wiring_constraint"
|
"eem_wiring_constraint"
|
||||||
],
|
],
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 8
|
hp: 8,
|
||||||
|
depth: 16
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
'bnc-dio': {
|
'bnc-dio': {
|
||||||
|
@ -393,7 +396,8 @@ const shop_data = {
|
||||||
],
|
],
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 8,
|
hp: 8,
|
||||||
eem: 1
|
eem: 1,
|
||||||
|
depth: 7
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
'sma-dio': {
|
'sma-dio': {
|
||||||
|
@ -458,7 +462,8 @@ const shop_data = {
|
||||||
],
|
],
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 4,
|
hp: 4,
|
||||||
eem: 1
|
eem: 1,
|
||||||
|
depth: 7
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
'mcx-dio': {
|
'mcx-dio': {
|
||||||
|
@ -549,7 +554,8 @@ const shop_data = {
|
||||||
],
|
],
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 4,
|
hp: 4,
|
||||||
eem: 2
|
eem: 2,
|
||||||
|
depth: 23
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
'rj45-dio': {
|
'rj45-dio': {
|
||||||
|
@ -635,7 +641,8 @@ const shop_data = {
|
||||||
],
|
],
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 4,
|
hp: 4,
|
||||||
eem: 2
|
eem: 2,
|
||||||
|
depth: 7
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
'urukul': {
|
'urukul': {
|
||||||
|
@ -700,7 +707,8 @@ const shop_data = {
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 4,
|
hp: 4,
|
||||||
eem: 2,
|
eem: 2,
|
||||||
clk: 1
|
clk: 1,
|
||||||
|
depth: 16
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
'urukul_4412': {
|
'urukul_4412': {
|
||||||
|
@ -738,7 +746,8 @@ const shop_data = {
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 4,
|
hp: 4,
|
||||||
eem: 2,
|
eem: 2,
|
||||||
clk: 1
|
clk: 1,
|
||||||
|
depth: 16
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
'phaser': {
|
'phaser': {
|
||||||
|
@ -766,12 +775,14 @@ const shop_data = {
|
||||||
size: 'small',
|
size: 'small',
|
||||||
warnings: [
|
warnings: [
|
||||||
"no_eem_source",
|
"no_eem_source",
|
||||||
"no_clk_source"
|
"no_clk_source",
|
||||||
|
"phaser_next_card_long"
|
||||||
],
|
],
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 4,
|
hp: 4,
|
||||||
eem: 1,
|
eem: 1,
|
||||||
clk: 1
|
clk: 1,
|
||||||
|
depth: 16 // heatsink 8.5
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
'zotino': {
|
'zotino': {
|
||||||
|
@ -813,7 +824,8 @@ const shop_data = {
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 4,
|
hp: 4,
|
||||||
eem: 1,
|
eem: 1,
|
||||||
tec: 1
|
tec: 1,
|
||||||
|
depth: 16
|
||||||
},
|
},
|
||||||
resources: [
|
resources: [
|
||||||
{name: "idc", max: 4}
|
{name: "idc", max: 4}
|
||||||
|
@ -841,7 +853,8 @@ const shop_data = {
|
||||||
],
|
],
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 4,
|
hp: 4,
|
||||||
eem: 1
|
eem: 1,
|
||||||
|
depth: 17
|
||||||
},
|
},
|
||||||
resources: [
|
resources: [
|
||||||
{name: "idc", max: 4}
|
{name: "idc", max: 4}
|
||||||
|
@ -865,7 +878,8 @@ const shop_data = {
|
||||||
],
|
],
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 8,
|
hp: 8,
|
||||||
idc: 1
|
idc: 1,
|
||||||
|
depth: 6
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
'hvamp32': {
|
'hvamp32': {
|
||||||
|
@ -902,7 +916,8 @@ const shop_data = {
|
||||||
],
|
],
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 4,
|
hp: 4,
|
||||||
idc: 4
|
idc: 4,
|
||||||
|
depth: 16
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
'idc-sma-adapter': {
|
'idc-sma-adapter': {
|
||||||
|
@ -923,7 +938,8 @@ const shop_data = {
|
||||||
],
|
],
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 4,
|
hp: 4,
|
||||||
idc: 1
|
idc: 1,
|
||||||
|
depth: 6
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
'hd68-idc-adapter': {
|
'hd68-idc-adapter': {
|
||||||
|
@ -945,7 +961,8 @@ const shop_data = {
|
||||||
"idc_resource"
|
"idc_resource"
|
||||||
],
|
],
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 4
|
hp: 4,
|
||||||
|
depth: 5
|
||||||
},
|
},
|
||||||
resources: [
|
resources: [
|
||||||
{name: "idc", max: 4}
|
{name: "idc", max: 4}
|
||||||
|
@ -998,7 +1015,8 @@ const shop_data = {
|
||||||
],
|
],
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 8,
|
hp: 8,
|
||||||
eem: 2
|
eem: 2,
|
||||||
|
depth: 16
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
'koster': {
|
'koster': {
|
||||||
|
@ -1024,7 +1042,8 @@ const shop_data = {
|
||||||
],
|
],
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 4,
|
hp: 4,
|
||||||
eem: 2
|
eem: 2,
|
||||||
|
depth: 7.5
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
'clocker': {
|
'clocker': {
|
||||||
|
@ -1055,7 +1074,8 @@ const shop_data = {
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 4,
|
hp: 4,
|
||||||
eem: 1,
|
eem: 1,
|
||||||
clk: 1
|
clk: 1,
|
||||||
|
depth: 7
|
||||||
},
|
},
|
||||||
resources: [
|
resources: [
|
||||||
{name: "clk", max: 6}
|
{name: "clk", max: 6}
|
||||||
|
@ -1092,7 +1112,8 @@ const shop_data = {
|
||||||
],
|
],
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 4,
|
hp: 4,
|
||||||
eem: 1
|
eem: 1,
|
||||||
|
depth: 16
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
'fast_servo': {
|
'fast_servo': {
|
||||||
|
@ -1126,7 +1147,8 @@ const shop_data = {
|
||||||
],
|
],
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 4,
|
hp: 4,
|
||||||
eem: 1
|
eem: 1,
|
||||||
|
depth: 16
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
'mirny': {
|
'mirny': {
|
||||||
|
@ -1157,7 +1179,8 @@ const shop_data = {
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 4,
|
hp: 4,
|
||||||
eem: 1,
|
eem: 1,
|
||||||
clk: 1
|
clk: 1,
|
||||||
|
depth: 16
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
'almazny': {
|
'almazny': {
|
||||||
|
@ -1185,7 +1208,8 @@ const shop_data = {
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 8,
|
hp: 8,
|
||||||
eem: 1,
|
eem: 1,
|
||||||
clk: 1
|
clk: 1,
|
||||||
|
depth: 16
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
'thermostat-eem': {
|
'thermostat-eem': {
|
||||||
|
@ -1213,6 +1237,7 @@ const shop_data = {
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 4,
|
hp: 4,
|
||||||
eem: 1,
|
eem: 1,
|
||||||
|
depth: 16
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
'thermostat2ch': {
|
'thermostat2ch': {
|
||||||
|
@ -1231,7 +1256,8 @@ const shop_data = {
|
||||||
],
|
],
|
||||||
size: 'small',
|
size: 'small',
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 4
|
hp: 4,
|
||||||
|
depth: 12
|
||||||
},
|
},
|
||||||
resources: [
|
resources: [
|
||||||
{name: "tec", max: 2}
|
{name: "tec", max: 2}
|
||||||
|
@ -1260,7 +1286,8 @@ const shop_data = {
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 8,
|
hp: 8,
|
||||||
eem: 1,
|
eem: 1,
|
||||||
clk: 1
|
clk: 1,
|
||||||
|
depth: 8
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
'pounder': {
|
'pounder': {
|
||||||
|
@ -1294,7 +1321,8 @@ const shop_data = {
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 8,
|
hp: 8,
|
||||||
eem: 1,
|
eem: 1,
|
||||||
clk: 1
|
clk: 1,
|
||||||
|
depth: 16
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
'eem_pwr_mod': {
|
'eem_pwr_mod': {
|
||||||
|
@ -1319,6 +1347,7 @@ const shop_data = {
|
||||||
warnings: [],
|
warnings: [],
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 8,
|
hp: 8,
|
||||||
|
depth: 20
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
'kirdy': {
|
'kirdy': {
|
||||||
|
@ -1350,6 +1379,7 @@ const shop_data = {
|
||||||
warnings: [],
|
warnings: [],
|
||||||
consumes: {
|
consumes: {
|
||||||
hp: 8,
|
hp: 8,
|
||||||
|
depth: 16
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
Loading…
Reference in New Issue