"use strict"; class State_Select_Input extends Ajax_Select_Input { async on_load() { // Initialize country code from args or default to US if (!this.data.country_code) { this.data.country_code = this.args.country_code || 'US'; } // Load states via Ajax endpoint if country code is set if (this.data.country_code) { this.data.select_values = await Rsx_Reference_Data_Controller.states({ country: this.data.country_code }); // If no states returned, add N/A option if (!this.data.select_values || this.data.select_values.length === 0) { this.data.select_values = [{ value: 'N/A', label: 'N/A' }]; } } else { this.data.select_values = []; } } on_create() { // Set default placeholder if not provided if (!this.args.placeholder) { this.args.placeholder = 'Select State...'; } // Initialize country code in data this.data.country_code = this.args.country_code || ''; // Cache for selected state per country code this._state_cache = {}; // Call parent to initialize Ajax_Select_Input super.on_create(); } on_ready() { // Call parent to initialize Tom Select super.on_ready(); // Check if this is N/A case (no states for country) const is_na = this.data.select_values.length === 1 && this.data.select_values[0].value === 'N/A'; // Disable if no country code or N/A case if ((!this.data.country_code || is_na) && this.tom_select) { this.tom_select.disable(); } // Set value to N/A if that's the only option if (is_na) { this.val('N/A'); } } /** * Set country code and reload state list * @param {string} country_code - ISO country code (e.g., 'US', 'CA') */ async set_country_code(country_code) { // Cache the current value for the current country before switching const current_country = this.data.country_code; const current_value = this.val(); if (current_country && current_value && current_value !== 'N/A') { this._state_cache[current_country] = current_value; } // Update country code this.data.country_code = country_code; // Disable the selector while loading if (this.tom_select) { this.tom_select.disable(); } // Load new state list try { this.data.select_values = await Rsx_Reference_Data_Controller.states({ country: country_code }); // Race condition check: verify country hasn't changed during the request if (this.data.country_code !== country_code) { // Country changed while request was in flight - ignore this response return; } // If no states returned, add N/A option if (!this.data.select_values || this.data.select_values.length === 0) { this.data.select_values = [{ value: 'N/A', label: 'N/A' }]; } // Re-render the widget with new states this.redraw(); // Re-initialize Tom Select after redraw if (this.tom_select) { this.tom_select.destroy(); } // Re-run on_ready to set up Tom Select again this.on_ready(); // Check if this is N/A case const is_na = this.data.select_values.length === 1 && this.data.select_values[0].value === 'N/A'; if (is_na) { // Set to N/A and keep disabled this.val('N/A'); if (this.tom_select) { this.tom_select.disable(); } } else { // Try to restore cached value for this country const cached_value = this._state_cache[country_code]; if (cached_value) { const value_exists = this.data.select_values.some(opt => (typeof opt === 'object' ? opt.value : opt) === cached_value); if (value_exists) { this.val(cached_value); } else { this.val(''); // Clear if cached value not in new list } } else { this.val(''); // No cached value - leave empty } // Enable the widget now that we have a country with states if (this.tom_select) { this.tom_select.enable(); } } } catch (error) { console.error('Failed to load states for country:', country_code, error); this.data.select_values = []; // Re-enable even on error if (this.tom_select) { this.tom_select.enable(); } } } /** * Override val() to update cache when user manually selects a state */ val(value) { if (arguments.length === 0) { // Getter - use parent implementation return super.val(); } else { // Setter - update cache and call parent if (this.data.country_code && value && value !== 'N/A') { this._state_cache[this.data.country_code] = value; } return super.val(value); } } } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["State_Select_Input","Ajax_Select_Input","on_load","data","country_code","args","select_values","Rsx_Reference_Data_Controller","states","country","length","value","label","on_create","placeholder","_state_cache","on_ready","is_na","tom_select","disable","val","set_country_code","current_country","current_value","redraw","destroy","cached_value","value_exists","some","opt","enable","error","console","arguments"],"sources":["rsx/theme/components/inputs/state_select_input.js"],"sourcesContent":["class State_Select_Input extends Ajax_Select_Input {\n    async on_load() {\n        // Initialize country code from args or default to US\n        if (!this.data.country_code) {\n            this.data.country_code = this.args.country_code || 'US';\n        }\n\n        // Load states via Ajax endpoint if country code is set\n        if (this.data.country_code) {\n            this.data.select_values = await Rsx_Reference_Data_Controller.states({ country: this.data.country_code });\n\n            // If no states returned, add N/A option\n            if (!this.data.select_values || this.data.select_values.length === 0) {\n                this.data.select_values = [{ value: 'N/A', label: 'N/A' }];\n            }\n        } else {\n            this.data.select_values = [];\n        }\n    }\n\n    on_create() {\n        // Set default placeholder if not provided\n        if (!this.args.placeholder) {\n            this.args.placeholder = 'Select State...';\n        }\n\n        // Initialize country code in data\n        this.data.country_code = this.args.country_code || '';\n\n        // Cache for selected state per country code\n        this._state_cache = {};\n\n        // Call parent to initialize Ajax_Select_Input\n        super.on_create();\n    }\n\n    on_ready() {\n        // Call parent to initialize Tom Select\n        super.on_ready();\n\n        // Check if this is N/A case (no states for country)\n        const is_na = this.data.select_values.length === 1 && this.data.select_values[0].value === 'N/A';\n\n        // Disable if no country code or N/A case\n        if ((!this.data.country_code || is_na) && this.tom_select) {\n            this.tom_select.disable();\n        }\n\n        // Set value to N/A if that's the only option\n        if (is_na) {\n            this.val('N/A');\n        }\n    }\n\n    /**\n     * Set country code and reload state list\n     * @param {string} country_code - ISO country code (e.g., 'US', 'CA')\n     */\n    async set_country_code(country_code) {\n        // Cache the current value for the current country before switching\n        const current_country = this.data.country_code;\n        const current_value = this.val();\n        if (current_country && current_value && current_value !== 'N/A') {\n            this._state_cache[current_country] = current_value;\n        }\n\n        // Update country code\n        this.data.country_code = country_code;\n\n        // Disable the selector while loading\n        if (this.tom_select) {\n            this.tom_select.disable();\n        }\n\n        // Load new state list\n        try {\n            this.data.select_values = await Rsx_Reference_Data_Controller.states({ country: country_code });\n\n            // Race condition check: verify country hasn't changed during the request\n            if (this.data.country_code !== country_code) {\n                // Country changed while request was in flight - ignore this response\n                return;\n            }\n\n            // If no states returned, add N/A option\n            if (!this.data.select_values || this.data.select_values.length === 0) {\n                this.data.select_values = [{ value: 'N/A', label: 'N/A' }];\n            }\n\n            // Re-render the widget with new states\n            this.redraw();\n\n            // Re-initialize Tom Select after redraw\n            if (this.tom_select) {\n                this.tom_select.destroy();\n            }\n\n            // Re-run on_ready to set up Tom Select again\n            this.on_ready();\n\n            // Check if this is N/A case\n            const is_na = this.data.select_values.length === 1 && this.data.select_values[0].value === 'N/A';\n\n            if (is_na) {\n                // Set to N/A and keep disabled\n                this.val('N/A');\n                if (this.tom_select) {\n                    this.tom_select.disable();\n                }\n            } else {\n                // Try to restore cached value for this country\n                const cached_value = this._state_cache[country_code];\n\n                if (cached_value) {\n                    const value_exists = this.data.select_values.some((opt) => (typeof opt === 'object' ? opt.value : opt) === cached_value);\n\n                    if (value_exists) {\n                        this.val(cached_value);\n                    } else {\n                        this.val(''); // Clear if cached value not in new list\n                    }\n                } else {\n                    this.val(''); // No cached value - leave empty\n                }\n\n                // Enable the widget now that we have a country with states\n                if (this.tom_select) {\n                    this.tom_select.enable();\n                }\n            }\n        } catch (error) {\n            console.error('Failed to load states for country:', country_code, error);\n            this.data.select_values = [];\n\n            // Re-enable even on error\n            if (this.tom_select) {\n                this.tom_select.enable();\n            }\n        }\n    }\n\n    /**\n     * Override val() to update cache when user manually selects a state\n     */\n    val(value) {\n        if (arguments.length === 0) {\n            // Getter - use parent implementation\n            return super.val();\n        } else {\n            // Setter - update cache and call parent\n            if (this.data.country_code && value && value !== 'N/A') {\n                this._state_cache[this.data.country_code] = value;\n            }\n            return super.val(value);\n        }\n    }\n}\n"],"mappings":"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","ignoreList":[]}