Remove unused blade settings pages not linked from UI Convert remaining frontend pages to SPA actions Convert settings user_settings and general to SPA actions Convert settings profile pages to SPA actions Convert contacts and projects add/edit pages to SPA actions Convert clients add/edit page to SPA action with loading pattern Refactor component scoped IDs from $id to $sid Fix jqhtml comment syntax and implement universal error component system Update all application code to use new unified error system Remove all backwards compatibility - unified error system complete Phase 5: Remove old response classes Phase 3-4: Ajax response handler sends new format, old helpers deprecated Phase 2: Add client-side unified error foundation Phase 1: Add server-side unified error foundation Add unified Ajax error response system with constants 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
96 lines
12 KiB
JavaScript
Executable File
96 lines
12 KiB
JavaScript
Executable File
"use strict";
|
|
|
|
class Select_Input extends Form_Input_Abstract {
|
|
on_create() {
|
|
this.data.value = '';
|
|
|
|
// Parse options if passed as JSON string
|
|
if (typeof this.args.options === 'string') {
|
|
try {
|
|
// Decode HTML entities before parsing JSON
|
|
// This handles cases where JSON is passed through Blade {!! !!} syntax
|
|
const decoded = $('<textarea>').html(this.args.options).text();
|
|
this.args.options = json_decode(decoded);
|
|
} catch (e) {
|
|
console.error('Failed to parse options JSON:', e);
|
|
this.args.options = [];
|
|
}
|
|
}
|
|
|
|
// Convert object options to array format
|
|
if (this.args.options && typeof this.args.options === 'object' && !is_array(this.args.options)) {
|
|
this.args.options = Object.entries(this.args.options).map(_ref => {
|
|
let [value, label] = _ref;
|
|
return {
|
|
value,
|
|
label
|
|
};
|
|
});
|
|
}
|
|
}
|
|
on_ready() {
|
|
// Initialize Tom Select
|
|
let config = {
|
|
placeholder: this.args.placeholder || '',
|
|
allowEmptyOption: true,
|
|
create: false,
|
|
maxOptions: null,
|
|
// Show all options (default is 50)
|
|
plugins: ['dropdown_input'],
|
|
// Enable search in dropdown
|
|
onInitialize: function () {
|
|
// Keep Bootstrap form-select class
|
|
this.control.classList.add('form-select');
|
|
}
|
|
};
|
|
this.tom_select = new TomSelect(this.$sid('input').get(0), config);
|
|
|
|
// Set initial value if provided
|
|
if (this.data.value) {
|
|
this.tom_select.setValue(this.data.value, true);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* val() - Get or set the selected value
|
|
* @param {string} [value] - If provided, sets the value
|
|
* @returns {string} The current value when called as getter
|
|
*/
|
|
val(value) {
|
|
if (arguments.length === 0) {
|
|
// Getter
|
|
if (this.tom_select) {
|
|
return this.tom_select.getValue();
|
|
}
|
|
return this.$sid('input').val();
|
|
} else {
|
|
// Setter
|
|
this.data.value = value || '';
|
|
if (this.tom_select) {
|
|
this.tom_select.setValue(this.data.value, true);
|
|
} else if (this.$sid('input').exists()) {
|
|
this.$sid('input').val(this.data.value);
|
|
}
|
|
}
|
|
}
|
|
async seed() {
|
|
if (this.args.seeder) {
|
|
// TODO: Implement Rsx_Random_Values endpoint
|
|
let value = 'Test ' + (this.args.seeder || 'Value');
|
|
this.val(value);
|
|
} else if (this.args.options && this.args.options.length > 0) {
|
|
// Select random option
|
|
let random_index = Math.floor(Math.random() * this.args.options.length);
|
|
let random_opt = this.args.options[random_index];
|
|
let random_value = typeof random_opt === 'object' ? random_opt.value : random_opt;
|
|
this.val(random_value);
|
|
}
|
|
}
|
|
on_destroy() {
|
|
// Clean up Tom Select instance
|
|
if (this.tom_select) {
|
|
this.tom_select.destroy();
|
|
}
|
|
}
|
|
}
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Select_Input","Form_Input_Abstract","on_create","data","value","args","options","decoded","$","html","text","json_decode","e","console","error","is_array","Object","entries","map","_ref","label","on_ready","config","placeholder","allowEmptyOption","create","maxOptions","plugins","onInitialize","control","classList","add","tom_select","TomSelect","$id","get","setValue","val","arguments","length","getValue","exists","seed","seeder","random_index","Math","floor","random","random_opt","random_value","on_destroy","destroy"],"sources":["rsx/theme/components/inputs/select_input.js"],"sourcesContent":["class Select_Input extends Form_Input_Abstract {\n    on_create() {\n        this.data.value = '';\n\n        // Parse options if passed as JSON string\n        if (typeof this.args.options === 'string') {\n            try {\n                // Decode HTML entities before parsing JSON\n                // This handles cases where JSON is passed through Blade {!! !!} syntax\n                const decoded = $('<textarea>').html(this.args.options).text();\n                this.args.options = json_decode(decoded);\n            } catch (e) {\n                console.error('Failed to parse options JSON:', e);\n                this.args.options = [];\n            }\n        }\n\n        // Convert object options to array format\n        if (this.args.options && typeof this.args.options === 'object' && !is_array(this.args.options)) {\n            this.args.options = Object.entries(this.args.options).map(([value, label]) => ({value, label}));\n        }\n    }\n\n    on_ready() {\n        // Initialize Tom Select\n        let config = {\n            placeholder: this.args.placeholder || '',\n            allowEmptyOption: true,\n            create: false,\n            maxOptions: null,  // Show all options (default is 50)\n            plugins: ['dropdown_input'],  // Enable search in dropdown\n            onInitialize: function() {\n                // Keep Bootstrap form-select class\n                this.control.classList.add('form-select');\n            }\n        };\n\n        this.tom_select = new TomSelect(this.$id('input').get(0), config);\n\n        // Set initial value if provided\n        if (this.data.value) {\n            this.tom_select.setValue(this.data.value, true);\n        }\n    }\n\n    /**\n     * val() - Get or set the selected value\n     * @param {string} [value] - If provided, sets the value\n     * @returns {string} The current value when called as getter\n     */\n    val(value) {\n        if (arguments.length === 0) {\n            // Getter\n            if (this.tom_select) {\n                return this.tom_select.getValue();\n            }\n            return this.$id('input').val();\n        } else {\n            // Setter\n            this.data.value = value || '';\n            if (this.tom_select) {\n                this.tom_select.setValue(this.data.value, true);\n            } else if (this.$id('input').exists()) {\n                this.$id('input').val(this.data.value);\n            }\n        }\n    }\n\n    async seed() {\n        if (this.args.seeder) {\n            // TODO: Implement Rsx_Random_Values endpoint\n            let value = 'Test ' + (this.args.seeder || 'Value');\n            this.val(value);\n        } else if (this.args.options && this.args.options.length > 0) {\n            // Select random option\n            let random_index = Math.floor(Math.random() * this.args.options.length);\n            let random_opt = this.args.options[random_index];\n            let random_value = typeof random_opt === 'object' ? random_opt.value : random_opt;\n            this.val(random_value);\n        }\n    }\n\n    on_destroy() {\n        // Clean up Tom Select instance\n        if (this.tom_select) {\n            this.tom_select.destroy();\n        }\n    }\n}\n"],"mappings":"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","ignoreList":[]}
|