mirror of
https://github.com/RSS-Bridge/rss-bridge.git
synced 2025-04-04 16:49:35 +00:00
Merge 4ae6f847e6
into 3055e69c23
This commit is contained in:
commit
713dcec2f4
@ -146,6 +146,8 @@ final class BridgeCard
|
||||
$form .= self::getNumberInput($inputEntry, $idArg, $id);
|
||||
} elseif ($inputEntry['type'] === 'list') {
|
||||
$form .= self::getListInput($inputEntry, $idArg, $id) . "\n";
|
||||
} elseif ($inputEntry['type'] === 'dynamic_list') {
|
||||
$form .= self::getDynamicListInput($inputEntry, $idArg, $id) . "\n";
|
||||
} elseif ($inputEntry['type'] === 'checkbox') {
|
||||
$form .= self::getCheckboxInput($inputEntry, $idArg, $id);
|
||||
} else {
|
||||
@ -238,6 +240,109 @@ final class BridgeCard
|
||||
return $list;
|
||||
}
|
||||
|
||||
public static function getDynamicListInput(array $entry, string $id, string $name): string
|
||||
{
|
||||
$required = $entry['required'] ?? null;
|
||||
if ($required) {
|
||||
trigger_error('The required attribute is not supported for lists');
|
||||
unset($entry['required']);
|
||||
}
|
||||
|
||||
if (!isset($entry['ajax_route']) || !isset($entry['fields_name_used_as_value']) || !isset($entry['fields_name_used_for_display'])) {
|
||||
trigger_error('The ajax_route and fields_name_used_as_value and fields_name_used_for_display attributes are required');
|
||||
}
|
||||
|
||||
$attributes = self::getInputAttributes($entry);
|
||||
|
||||
$fieldsDisplayString = '';
|
||||
foreach ($entry['fields_name_used_for_display'] as $index => $field) {
|
||||
if ($index === 0) {
|
||||
$fieldsDisplayString = 'option.' . $field;
|
||||
} else {
|
||||
$fieldsDisplayString .= ' + \' - \' + option.' . $field;
|
||||
}
|
||||
}
|
||||
|
||||
$fieldsValueString = '';
|
||||
$fieldsNameUsedAsValueSeparator = isset($entry['fields_name_used_as_value_separator']) ? $entry['fields_name_used_as_value_separator'] : '-';
|
||||
foreach ($entry['fields_name_used_as_value'] as $index => $field) {
|
||||
if ($index === 0) {
|
||||
$fieldsValueString = 'option.' . $field;
|
||||
} else {
|
||||
$fieldsValueString .= ' + \'' . $fieldsNameUsedAsValueSeparator . '\' + option.' . $field;
|
||||
}
|
||||
}
|
||||
|
||||
$list = sprintf(
|
||||
'<input %s id="input-%s" name="%s" autocomplete="off" type="text" list="options-%s" onmousedown="
|
||||
const id = \'%s\';
|
||||
const inputElement = document.getElementById(\'input-\' + id);
|
||||
const errorElement = document.getElementById(\'error-\' + id);
|
||||
const datalist = document.getElementById(\'options-\' + id);
|
||||
const options = document.getElementById(\'options-\' + id).options;
|
||||
|
||||
let hasError = errorElement.innerHTML === \'\' ? false : true;
|
||||
if (!hasError && (!options || options.length === 0)) {
|
||||
// set himself disabled while the request is progressing
|
||||
inputElement.disabled = true;
|
||||
inputElement.value = \'loading...\';
|
||||
// used to not be blocked by cors
|
||||
const proxy = \'%s\';
|
||||
|
||||
// Perform AJAX request
|
||||
const xhr = new XMLHttpRequest();
|
||||
|
||||
xhr.open(\'GET\', proxy + \'%s\', true);
|
||||
xhr.onerror = function () {
|
||||
errorElement.innerHTML = \'failed fetching data\';
|
||||
inputElement.value = \'\';
|
||||
inputElement.disabled = false;
|
||||
hasError = true;
|
||||
}
|
||||
xhr.onload = function () {
|
||||
if (xhr.status === 200) {
|
||||
// Parse the response and update the datalist
|
||||
datalist.innerHTML = \'\'; // Clear existing options
|
||||
let options = JSON.parse(xhr.responseText); // Assuming JSON response
|
||||
if (%s) {
|
||||
options = options[\'%s\'];
|
||||
}
|
||||
options.forEach(option => {
|
||||
const opt = document.createElement(\'option\');
|
||||
|
||||
opt.innerHTML = %s; // the displayed value
|
||||
opt.value = %s; // the value
|
||||
datalist.appendChild(opt);
|
||||
});
|
||||
// set himself enabled when the request is done
|
||||
inputElement.value = \'\';
|
||||
inputElement.disabled = false;
|
||||
} else {
|
||||
errorElement.innerHTML = \'failed fetching data\';
|
||||
inputElement.value = \'\';
|
||||
inputElement.disabled = false;
|
||||
}
|
||||
};
|
||||
xhr.send();
|
||||
}
|
||||
" />' . "\n",
|
||||
$attributes,
|
||||
$id,
|
||||
$name,
|
||||
$id,
|
||||
$id,
|
||||
Configuration::getConfig('proxy', 'url') ?: 'https://cors-anywhere.herokuapp.com/',
|
||||
$entry['ajax_route'],
|
||||
isset($entry['field_for_options']) ? 'true' : 'false',
|
||||
isset($entry['field_for_options']) ? $entry['field_for_options'] : null,
|
||||
$fieldsDisplayString,
|
||||
$fieldsValueString,
|
||||
);
|
||||
$list .= sprintf('<datalist id="options-%s"></datalist>' . "\n", $id);
|
||||
$list .= sprintf('<br><div id="error-%s" style="color: red; height: 28px"></div>' . "\n", $id);
|
||||
|
||||
return $list;
|
||||
}
|
||||
|
||||
public static function getCheckboxInput(array $entry, string $id, string $name): string
|
||||
{
|
||||
|
Loading…
Reference in New Issue
Block a user