initial commit

This commit is contained in:
Francis 2022-07-20 21:49:04 +08:00
commit 1b9c1e5ea5
2 changed files with 97 additions and 0 deletions

81
script.js Normal file
View File

@ -0,0 +1,81 @@
var x = document.getElementById('ff_8_dropdown'); //Get the form element
const optionsList = []; //Array that will store options data
/**
* Iterates on each option, gets the value and data-calc_value generated by fluentforms.
* The reason for this is when choices.js is used on the select element, the data-calc_value
* is removed and only the value is retained.
*
*/
for( let i=0; i < x.length; i++ ) {
var tempObj = {
value: x.options[i].getAttribute('value'),
calcValue: x.options[i].getAttribute('data-calc_value'),
}
optionsList.push(tempObj);
}
/**
* Gets the choices.js script using CDN.
*
* Then Converts the select element using choices.js plugin. Customized it so that we can use the
* data-calc_value option of fluent forms.
*/
$.getScript("https://cdn.jsdelivr.net/npm/choices.js/public/assets/scripts/choices.min.js", function(){
const choices = new Choices(x, {
callbackOnCreateTemplates: function(template) {
return {
choice: ({ classNames }, data) => {
const val = data.value;
const calcValue = getCalcValue(val);
const color = getColor( parseInt( calcValue ) );
/**
* This returns the default template used by choices.js.
* Only the {$color} attribute is added for the custom color of the option.
* The rest are default.
*/
return template(`
<div class="${classNames.item} ${classNames.itemChoice} ${
data.disabled ? classNames.itemDisabled : classNames.itemSelectable
} ${color}" data-select-text="${this.config.itemSelectText}" data-choice ${
data.disabled
? 'data-choice-disabled aria-disabled="true"'
: 'data-choice-selectable'
} data-id="${data.id}" data-value="${data.value}" ${
data.groupId > 0 ? 'role="treeitem"' : 'role="option"'
}>
${data.label}
</div>
`);
},
};
},
});
/**
* Compares the value from the optionsList and the one generated in choices.js. If equal, returns
* the data-calc_value of the option.
*/
function getCalcValue( val ) {
var length = optionsList.length;
for( let x = 0; x < optionsList.length; x++ ){
if( val === optionsList[x].value ){
return optionsList[x].calcValue;
}
}
}
/**
* Uses the data-calc_value to identify the color of the option field.
* Returns a custom class name that will be used to identify the color of the option field using CSS.
*/
function getColor( calcValue ){
switch( calcValue ) {
case 1:
return 'option_blue';
case 2:
return 'option_green';
case 3:
return 'option_red';
}
}
});

16
style.css Normal file
View File

@ -0,0 +1,16 @@
@import url('https://cdn.jsdelivr.net/npm/choices.js/public/assets/styles/choices.min.css');
.option_blue{
border-left: solid;
border-color: blue;
}
.option_green{
border-left: solid;
border-color: green;
}
.option_red{
border-left: solid;
border-color: red;
}