Add default select option. See #492
This commit is contained in:
parent
74892a3130
commit
9b483d993b
|
@ -177,6 +177,7 @@ var usercss = (() => {
|
||||||
result.label = state.value;
|
result.label = state.value;
|
||||||
|
|
||||||
const {re, type, text} = state;
|
const {re, type, text} = state;
|
||||||
|
let deflt;
|
||||||
|
|
||||||
switch (type === 'image' && state.key === 'var' ? '@image@var' : type) {
|
switch (type === 'image' && state.key === 'var' ? '@image@var' : type) {
|
||||||
case 'checkbox': {
|
case 'checkbox': {
|
||||||
|
@ -195,11 +196,24 @@ var usercss = (() => {
|
||||||
parseJSONValue(state);
|
parseJSONValue(state);
|
||||||
state.errorPrefix = '';
|
state.errorPrefix = '';
|
||||||
if (Array.isArray(state.value)) {
|
if (Array.isArray(state.value)) {
|
||||||
result.options = state.value.map(text => createOption(text));
|
result.options = state.value.map(text => {
|
||||||
|
if (text.endsWith('*')) {
|
||||||
|
text = text.replace(/\*$/, '');
|
||||||
|
deflt = text;
|
||||||
|
}
|
||||||
|
return createOption(text);
|
||||||
|
});
|
||||||
} else {
|
} else {
|
||||||
result.options = Object.keys(state.value).map(k => createOption(k, state.value[k]));
|
result.options = Object.keys(state.value).map(k => {
|
||||||
|
if (k.endsWith('*')) {
|
||||||
|
state.value[k] = state.value[k].replace(/\*$/, '');
|
||||||
|
k = k.replace(/\*$/, '');
|
||||||
|
deflt = k;
|
||||||
|
}
|
||||||
|
return createOption(k, state.value[k]);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
result.default = (result.options[0] || {}).name || '';
|
result.default = typeof deflt !== 'undefined' ? deflt : (result.options[0] || {}).name || '';
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user