Update options
* Separate Urukul 4412 * Add options for LVDS TTL * Remove usb flash option * Add cable lengths for fiber and copper options * Add IP option for Stabilizer and Pounder * Added note that most options can be changed after shipment Signed-off-by: Egor Savkin <es@m-labs.hk>
This commit is contained in:
parent
a4ff9f7057
commit
f11ebc1152
File diff suppressed because one or more lines are too long
After Width: | Height: | Size: 28 KiB |
File diff suppressed because one or more lines are too long
|
@ -2406,7 +2406,7 @@ class Shop extends React.PureComponent {
|
||||||
isMobile={isMobile}
|
isMobile={isMobile}
|
||||||
title="Order hardware"
|
title="Order hardware"
|
||||||
description="
|
description="
|
||||||
Drag and drop the cards you want into the crate below to see how the combination would look like. Setup card's configuration by tapping at the top of the card. If you have any issues with this ordering system, or if you need other configurations, email us directly anytime at sales@m-****.hk. The price is estimated and must be confirmed by a quote."
|
Drag and drop the cards you want into the crate below to see how the combination would look like. Setup card's configuration by tapping at the top of the card, most of the options can be modified after shipment. If you have any issues with this ordering system, or if you need other configurations, email us directly anytime at sales@m-****.hk. The price is estimated and must be confirmed by a quote."
|
||||||
crateMode={
|
crateMode={
|
||||||
<CrateMode
|
<CrateMode
|
||||||
items={crateModeItems}
|
items={crateModeItems}
|
||||||
|
|
|
@ -443,9 +443,8 @@ export function OptionsSummaryPopup({id, options, data}) {
|
||||||
|
|
||||||
export function FillExtData(data, index) {
|
export function FillExtData(data, index) {
|
||||||
return {
|
return {
|
||||||
has_previous_carrier: data.filter((value, item_index) => index > item_index && value.name === "Carrier").length > 0,
|
|
||||||
has_other_dio: data.filter((value, item_index) => index !== item_index && value.name &&value.name.endsWith("-TTL")).length > 0,
|
has_other_dio: data.filter((value, item_index) => index !== item_index && value.name &&value.name.endsWith("-TTL")).length > 0,
|
||||||
has_dds: data.filter(((value, _) => value.name === "DDS" && (!value.options_data || !value.options_data.mono_eem))).length > 0,
|
has_dds: data.filter(((value, _) => value.name === "DDS" && value.name_number === "4410" && (!value.options_data || !value.options_data.mono_eem))).length > 0,
|
||||||
has_sampler: data.filter(((value, _) => value.name === "Sampler" && (!value.options_data || !value.options_data.mono_eem))).length > 0,
|
has_sampler: data.filter(((value, _) => value.name === "Sampler" && (!value.options_data || !value.options_data.mono_eem))).length > 0,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -78,14 +78,15 @@ const shop_data = {
|
||||||
[
|
[
|
||||||
{type: "Line", args: {title: "IPv4", outvar: "ipv4", fallback: "192.168.1.75/24", tip: "Set up IPv4 address used by core device"}},
|
{type: "Line", args: {title: "IPv4", outvar: "ipv4", fallback: "192.168.1.75/24", tip: "Set up IPv4 address used by core device"}},
|
||||||
{type: "SwitchLine", args: {title: "IPv6", outvar: "ipv6"}},
|
{type: "SwitchLine", args: {title: "IPv6", outvar: "ipv6"}},
|
||||||
{type: "SwitchLine", args: {title: "Ext CLK", outvar: "ext_clk", fallback: {text: "125 MHz", checked: false}, tip: "Use external clock reference: 10, 80 (beta), 100 or 125 MHz. Other variants may be provided if needed."}},
|
{type: "SwitchLine", args: {title: "Ext CLK", outvar: "ext_clk", fallback: {text: "125 MHz", checked: false}, tip: "Use external clock reference: 10, 80 (beta), 100 or 125 MHz. Other variants may be provided if needed."}}
|
||||||
{"if": [
|
|
||||||
{"!": {"var": "ext_data.has_previous_carrier"}},
|
|
||||||
{type: "Switch", args: {title: "Opt out from promotional USB-stick", outvar: "usb_opt_out", tip: "Do not ship a promotional USB-stick"}}
|
|
||||||
]}
|
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
{type: "Switch", args: {title: "Optic fiber", outvar: "optics", tip: "Use optic fiber instead of direct attach copper cable"}}
|
{type: "Switch", args: {title: "Optical fiber", outvar: "optics", tip: "Use optical fiber instead of direct attach copper cable"}},
|
||||||
|
{"if": [
|
||||||
|
{"var": "optics"},
|
||||||
|
{type: "Radio", args: {title: "Fiber cable length", outvar: "cable_len", variants: ["1 M", "3 M", "5 M"], tip: "The desired length of the optical fiber cable", fallback: 1}},
|
||||||
|
{type: "Radio", args: {title: "Copper cable length", outvar: "cable_len", variants: ["0.5 M", "1 M", "2 M"], tip: "The desired length of the direct attach copper cable", fallback: 0}},
|
||||||
|
]}
|
||||||
]
|
]
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
@ -165,14 +166,15 @@ const shop_data = {
|
||||||
[
|
[
|
||||||
{type: "Line", args: {title: "IPv4", outvar: "ipv4", fallback: "192.168.1.75/24", tip: "Set up IPv4 address used by core device"}},
|
{type: "Line", args: {title: "IPv4", outvar: "ipv4", fallback: "192.168.1.75/24", tip: "Set up IPv4 address used by core device"}},
|
||||||
{type: "SwitchLine", args: {title: "IPv6", outvar: "ipv6"}},
|
{type: "SwitchLine", args: {title: "IPv6", outvar: "ipv6"}},
|
||||||
{type: "SwitchLine", args: {title: "Ext CLK", outvar: "ext_clk", fallback: {text: "125 MHz", checked: false}, tip: "Use external clock reference: 10, 80 (beta), 100 or 125 MHz. Other variants may be provided if needed."}},
|
{type: "SwitchLine", args: {title: "Ext CLK", outvar: "ext_clk", fallback: {text: "125 MHz", checked: false}, tip: "Use external clock reference: 10, 80 (beta), 100 or 125 MHz. Other variants may be provided if needed."}}
|
||||||
{"if": [
|
|
||||||
{"!": {"var": "ext_data.has_previous_carrier"}},
|
|
||||||
{type: "Switch", args: {title: "Opt out from promotional USB-stick", outvar: "usb_opt_out", tip: "Do not ship a promotional USB-stick"}}
|
|
||||||
]}
|
|
||||||
],
|
],
|
||||||
[
|
[
|
||||||
{type: "Switch", args: {title: "Optic fiber", outvar: "optics", tip: "Use optic fiber instead of direct attach copper cable"}}
|
{type: "Switch", args: {title: "Optical fiber", outvar: "optics", tip: "Use optical fiber instead of direct attach copper cable"}},
|
||||||
|
{"if": [
|
||||||
|
{"var": "optics"},
|
||||||
|
{type: "Radio", args: {title: "Fiber cable length", outvar: "cable_len", variants: ["1 M", "3 M", "5 M"], tip: "The desired length of the optical fiber cable", fallback: 1}},
|
||||||
|
{type: "Radio", args: {title: "Copper cable length", outvar: "cable_len", variants: ["0.5 M", "1 M", "2 M"], tip: "The desired length of the direct attach copper cable", fallback: 0}},
|
||||||
|
]}
|
||||||
]
|
]
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
@ -533,6 +535,67 @@ const shop_data = {
|
||||||
],
|
],
|
||||||
datasheet_file: '/docs/sinara-datasheets/2245.pdf',
|
datasheet_file: '/docs/sinara-datasheets/2245.pdf',
|
||||||
datasheet_name: '2245 LVDS-TTL datasheet',
|
datasheet_name: '2245 LVDS-TTL datasheet',
|
||||||
|
options: [
|
||||||
|
{type: "Switch", args: {title: "Configure first RJ45", fallback: false, outvar: "conf_first_rj45", tip: "Configure channels 0-3"}},
|
||||||
|
{
|
||||||
|
"if": [
|
||||||
|
{"var": "conf_first_rj45"},
|
||||||
|
{type: "Group", items: [
|
||||||
|
{type: "Switch", args: {title: "Output channel #0", fallback: true, outvar: "output_0", tip: "Set channel #0 to output"}},
|
||||||
|
{type: "Switch", args: {title: "Output channel #1", fallback: true, outvar: "output_1", tip: "Set channel #1 to output"}},
|
||||||
|
{type: "Switch", args: {title: "Output channel #2", fallback: true, outvar: "output_2", tip: "Set channel #2 to output"}},
|
||||||
|
{type: "Switch", args: {title: "Output channel #3", fallback: true, outvar: "output_3", tip: "Set channel #3 to output"}},
|
||||||
|
]}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{type: "Switch", args: {title: "Configure second RJ45", fallback: false, outvar: "conf_second_rj45", tip: "Configure channels 4-7"}},
|
||||||
|
{
|
||||||
|
"if": [
|
||||||
|
{"var": "conf_second_rj45"},
|
||||||
|
{type: "Group", items: [
|
||||||
|
{type: "Switch", args: {title: "Output channel #4", fallback: true, outvar: "output_4", tip: "Set channel #4 to output"}},
|
||||||
|
{type: "Switch", args: {title: "Output channel #5", fallback: true, outvar: "output_5", tip: "Set channel #5 to output"}},
|
||||||
|
{type: "Switch", args: {title: "Output channel #6", fallback: true, outvar: "output_6", tip: "Set channel #6 to output"}},
|
||||||
|
{type: "Switch", args: {title: "Output channel #7", fallback: true, outvar: "output_7", tip: "Set channel #7 to output"}},
|
||||||
|
]}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{type: "Switch", args: {title: "Configure third RJ45", fallback: false, outvar: "conf_third_rj45", tip: "Configure channels 8-11"}},
|
||||||
|
{
|
||||||
|
"if": [
|
||||||
|
{"var": "conf_third_rj45"},
|
||||||
|
{type: "Group", items: [
|
||||||
|
{type: "Switch", args: {title: "Output channel #8", fallback: true, outvar: "output_8", tip: "Set channel #8 to output"}},
|
||||||
|
{type: "Switch", args: {title: "Output channel #9", fallback: true, outvar: "output_9", tip: "Set channel #9 to output"}},
|
||||||
|
{type: "Switch", args: {title: "Output channel #10", fallback: true, outvar: "output_10", tip: "Set channel #10 to output"}},
|
||||||
|
{type: "Switch", args: {title: "Output channel #11", fallback: true, outvar: "output_11", tip: "Set channel #11 to output"}},
|
||||||
|
]}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{type: "Switch", args: {title: "Configure fourth RJ45", fallback: false, outvar: "conf_fourth_rj45", tip: "Configure channels 12-15"}},
|
||||||
|
{
|
||||||
|
"if": [
|
||||||
|
{"var": "conf_fourth_rj45"},
|
||||||
|
{type: "Group", items: [
|
||||||
|
{type: "Switch", args: {title: "Output channel #12", fallback: true, outvar: "output_12", tip: "Set channel #12 to output"}},
|
||||||
|
{type: "Switch", args: {title: "Output channel #13", fallback: true, outvar: "output_13", tip: "Set channel #13 to output"}},
|
||||||
|
{type: "Switch", args: {title: "Output channel #14", fallback: true, outvar: "output_14", tip: "Set channel #14 to output"}},
|
||||||
|
{type: "Switch", args: {title: "Output channel #15", fallback: true, outvar: "output_15", tip: "Set channel #15 to output"}},
|
||||||
|
]}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"if": [
|
||||||
|
{"or": [
|
||||||
|
{"and": [{"var": "conf_first_rj45"}, {"!": {"missing": ["output_0", "output_1", "output_2", "output_3"]}}, {"!": {"and": [{"var": "output_0"}, {"var": "output_1"}, {"var": "output_2"},{"var": "output_3"}]}}]},
|
||||||
|
{"and": [{"var": "conf_second_rj45"}, {"!": {"missing": ["output_4", "output_5", "output_6", "output_7"]}}, {"!": {"and": [{"var": "output_4"}, {"var": "output_5"}, {"var": "output_6"},{"var": "output_7"}]}}]},
|
||||||
|
{"and": [{"var": "conf_third_rj45"}, {"!": {"missing": ["output_8", "output_9", "output_10", "output_11"]}}, {"!": {"and": [{"var": "output_8"}, {"var": "output_9"}, {"var": "output_10"},{"var": "output_11"}]}}]},
|
||||||
|
{"and": [{"var": "conf_fourth_rj45"}, {"!": {"missing": ["output_12", "output_13", "output_14", "output_15"]}}, {"!": {"and": [{"var": "output_12"}, {"var": "output_13"}, {"var": "output_14"},{"var": "output_15"}]}}]}
|
||||||
|
]},
|
||||||
|
{type: "Switch", args: {title: "Edge counter", outvar: "edge_counter", tip: "Enable edge counter for inputs"}}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
],
|
||||||
size: 'small',
|
size: 'small',
|
||||||
type: null,
|
type: null,
|
||||||
hp: 4,
|
hp: 4,
|
||||||
|
@ -560,22 +623,20 @@ const shop_data = {
|
||||||
specs: [
|
specs: [
|
||||||
'4 channel 1GS/s DDS.',
|
'4 channel 1GS/s DDS.',
|
||||||
'Output frequency (-3 dB): <1 to >400 MHz.',
|
'Output frequency (-3 dB): <1 to >400 MHz.',
|
||||||
|
'Frequency resolution ~0.25 Hz (32 bit)',
|
||||||
'Nominal max output power 10 dBm.',
|
'Nominal max output power 10 dBm.',
|
||||||
'Digital step attenuator 0 to -31.5dB.',
|
'Digital step attenuator 0 to -31.5dB.',
|
||||||
'RF switch (1ns temporal resolution), 70dB isolation.',
|
'RF switch (1ns temporal resolution), 70dB isolation.',
|
||||||
'AD9910 or AD9912 chip.',
|
|
||||||
'By default, we use the AD9910 as it provides more features. If you need the higher frequency resolution of the AD9912, leave us a note.',
|
|
||||||
'AD9910 and AD9912 cards can be used at the same time in the same crate.',
|
'AD9910 and AD9912 cards can be used at the same time in the same crate.',
|
||||||
'External 5W power amplifier is available separately, leave us a note if interested.'
|
'External 5W power amplifier is available separately, leave us a note if interested.'
|
||||||
],
|
],
|
||||||
datasheet_file: '/docs/sinara-datasheets/4410-4412.pdf',
|
datasheet_file: '/docs/sinara-datasheets/4410-4412.pdf',
|
||||||
datasheet_name: '4410/4412 Urukul datasheet',
|
datasheet_name: '4410/4412 Urukul datasheet',
|
||||||
options: [
|
options: [
|
||||||
{type: "Switch", args: {title: "AD9912", outvar: "ad9912", tip: "AD9912 chip instead of AD9910"}},
|
|
||||||
{type: "Switch", args: {title: "Use 1 EEM", outvar: "mono_eem", tip: "Use one EEM port setup. RF switch and synchronization will be unavailable."}},
|
{type: "Switch", args: {title: "Use 1 EEM", outvar: "mono_eem", tip: "Use one EEM port setup. RF switch and synchronization will be unavailable."}},
|
||||||
{
|
{
|
||||||
"if": [
|
"if": [
|
||||||
{"or": [{"var": "ad9912"}, {"var": "mono_eem"}]},
|
{"var": "mono_eem"},
|
||||||
[
|
[
|
||||||
{type: "SwitchLine", args: {title: "Ext CLK", outvar: "ext_clk", fallback: {text: "125 MHz", checked: false}}},
|
{type: "SwitchLine", args: {title: "Ext CLK", outvar: "ext_clk", fallback: {text: "125 MHz", checked: false}}},
|
||||||
],
|
],
|
||||||
|
@ -618,6 +679,47 @@ const shop_data = {
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
'urukul_4412': {
|
||||||
|
id: 'urukul_4412',
|
||||||
|
name: 'DDS',
|
||||||
|
name_number: '4412',
|
||||||
|
name_codename: 'Urukul',
|
||||||
|
price: 2350,
|
||||||
|
image: '/shop/graphic-03_Urukul-4412.svg',
|
||||||
|
specs: [
|
||||||
|
'4 channel 1GS/s DDS.',
|
||||||
|
'Higher frequency resolution ~8 µHz (47 bit)',
|
||||||
|
'Output frequency (-3 dB): <1 to >400 MHz.',
|
||||||
|
'Nominal max output power 10 dBm.',
|
||||||
|
'Digital step attenuator 0 to -31.5dB.',
|
||||||
|
'RF switch (1ns temporal resolution), 70dB isolation.',
|
||||||
|
'AD9912 chip.',
|
||||||
|
'AD9910 and AD9912 cards can be used at the same time in the same crate.',
|
||||||
|
'External 5W power amplifier is available separately, leave us a note if interested.'
|
||||||
|
],
|
||||||
|
datasheet_file: '/docs/sinara-datasheets/4410-4412.pdf',
|
||||||
|
datasheet_name: '4410/4412 Urukul datasheet',
|
||||||
|
options: [
|
||||||
|
{type: "Switch", args: {title: "Use 1 EEM", outvar: "mono_eem", tip: "Use one EEM port setup. RF switch and synchronization will be unavailable."}},
|
||||||
|
{type: "SwitchLine", args: {title: "Ext CLK", outvar: "ext_clk", fallback: {text: "125 MHz", checked: false}}}
|
||||||
|
],
|
||||||
|
size: 'small',
|
||||||
|
type: 'urukul',
|
||||||
|
hp: 4,
|
||||||
|
nbrSlotMin: 0,
|
||||||
|
nbrSlotMax: 0,
|
||||||
|
nbrClockMax: 0,
|
||||||
|
slotOccupied: 2,
|
||||||
|
clockOccupied: 1,
|
||||||
|
rules: {
|
||||||
|
resources: {
|
||||||
|
type: 'urukul',
|
||||||
|
icon: '/shop/icon-warning.svg',
|
||||||
|
name: 'Urukul',
|
||||||
|
message: 'This card needs a card that provides EEM and clocking connectors (e.g. Kasli) at its left.',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
'phaser': {
|
'phaser': {
|
||||||
id: 'phaser',
|
id: 'phaser',
|
||||||
name: 'AWG',
|
name: 'AWG',
|
||||||
|
@ -852,7 +954,7 @@ const shop_data = {
|
||||||
type: 'hd68',
|
type: 'hd68',
|
||||||
hp: 4,
|
hp: 4,
|
||||||
options: [
|
options: [
|
||||||
{type: "Radio", args: {title: "Cable length", outvar: "hd68_cable_len", variants: ["1 M", "2 M", "3 M"], tip: "The desired length of the HD68 cable", fallback: 1}},
|
{type: "Radio", args: {title: "Cable length", outvar: "cable_len", variants: ["1 M", "2 M", "3 M"], tip: "The desired length of the HD68 cable", fallback: 1}},
|
||||||
],
|
],
|
||||||
options_class: "hd68-idc",
|
options_class: "hd68-idc",
|
||||||
nbrSlotMin: 1,
|
nbrSlotMin: 1,
|
||||||
|
@ -1032,6 +1134,7 @@ const shop_data = {
|
||||||
'Can be controlled by Kasli or work stand-alone with PoE supply.'
|
'Can be controlled by Kasli or work stand-alone with PoE supply.'
|
||||||
],
|
],
|
||||||
options: [
|
options: [
|
||||||
|
{type: "SwitchLine", args: {title: "IP", outvar: "ip", fallback: {text: "DHCP", checked: false}, tip: "Set up IP address used by the device"}},
|
||||||
{type: "Switch", args: {title: "Ext power", outvar: "ext_pwr", "tip": "Use external power supply in order to reduce number of used EEM connectors"}},
|
{type: "Switch", args: {title: "Ext power", outvar: "ext_pwr", "tip": "Use external power supply in order to reduce number of used EEM connectors"}},
|
||||||
{type: "Switch", args: {title: "Term #0", outvar: "term_0", tip: "Enable termination on ADC channel #0"}},
|
{type: "Switch", args: {title: "Term #0", outvar: "term_0", tip: "Enable termination on ADC channel #0"}},
|
||||||
{type: "Switch", args: {title: "Term #1", outvar: "term_1", tip: "Enable termination on ADC channel #1"}}
|
{type: "Switch", args: {title: "Term #1", outvar: "term_1", tip: "Enable termination on ADC channel #1"}}
|
||||||
|
@ -1185,6 +1288,7 @@ const shop_data = {
|
||||||
'AD9959 DDS (500MSPS, 10-bit).'
|
'AD9959 DDS (500MSPS, 10-bit).'
|
||||||
],
|
],
|
||||||
options: [
|
options: [
|
||||||
|
{type: "SwitchLine", args: {title: "IP", outvar: "ip", fallback: {text: "DHCP", checked: false}, tip: "Set up IP address used by the device"}},
|
||||||
{type: "Switch", args: {title: "Ext power", outvar: "ext_pwr", "tip": "Use external power supply in order to reduce number of used EEM connectors"}},
|
{type: "Switch", args: {title: "Ext power", outvar: "ext_pwr", "tip": "Use external power supply in order to reduce number of used EEM connectors"}},
|
||||||
{type: "SwitchLine", args: {title: "Ext CLK", outvar: "ext_clk", fallback: {text: "125 MHz", checked: false}}},
|
{type: "SwitchLine", args: {title: "Ext CLK", outvar: "ext_clk", fallback: {text: "125 MHz", checked: false}}},
|
||||||
{type: "Switch", args: {title: "Termination #0", outvar: "term_0", tip: "Enable termination on ADC channel #0"}},
|
{type: "Switch", args: {title: "Termination #0", outvar: "term_0", tip: "Enable termination on ADC channel #0"}},
|
||||||
|
@ -1252,6 +1356,7 @@ const shop_data = {
|
||||||
itemIds: [
|
itemIds: [
|
||||||
'clocker',
|
'clocker',
|
||||||
'urukul',
|
'urukul',
|
||||||
|
'urukul_4412',
|
||||||
'phaser',
|
'phaser',
|
||||||
'mirny',
|
'mirny',
|
||||||
'almazny',
|
'almazny',
|
||||||
|
|
Loading…
Reference in New Issue