"use strict"; class Inline_Edit_Field extends Component { on_ready() { this.current_value = this.args.value || ''; // Enter edit mode this.$sid('display_mode').on('click', () => { this.enter_edit_mode(); }); // Save this.$sid('save_btn').on('click', () => { this.save(); }); // Cancel this.$sid('cancel_btn').on('click', () => { this.cancel(); }); // Save on Enter, cancel on Escape this.$sid('input').on('keydown', e => { if (e.key === 'Enter') { e.preventDefault(); this.save(); } else if (e.key === 'Escape') { e.preventDefault(); this.cancel(); } }); } enter_edit_mode() { const $input = this.$sid('input'); $input.val(this.current_value); this.$sid('display_mode').hide(); this.$sid('edit_mode').show(); $input.focus(); $input.select(); } exit_edit_mode() { this.$sid('edit_mode').hide(); this.$sid('display_mode').show(); } save() { const new_value = this.$sid('input').val(); if (new_value === this.current_value) { this.exit_edit_mode(); return; } // Trigger callback if (this.args.on_save) { const result = this.args.on_save(new_value, this.current_value); // If callback returns false, don't save if (result === false) { return; } // If callback returns a promise, wait for it if (result && typeof result.then === 'function') { this.show_saving(); result.then(() => { this.current_value = new_value; this.update_display(); this.exit_edit_mode(); }).catch(() => { this.exit_edit_mode(); }); return; } } this.current_value = new_value; this.update_display(); this.exit_edit_mode(); } cancel() { this.exit_edit_mode(); } update_display() { const display = this.current_value || this.args.placeholder || 'Click to edit'; this.$sid('value_display').text(display); } show_saving() { this.$sid('save_btn').prop('disabled', true).html(''); this.$sid('cancel_btn').prop('disabled', true); } get_value() { return this.current_value; } set_value(value) { this.current_value = value; this.update_display(); } } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Inline_Edit_Field","Jqhtml_Component","on_ready","current_value","args","value","$id","on","enter_edit_mode","save","cancel","e","key","preventDefault","$input","val","hide","show","focus","select","exit_edit_mode","new_value","on_save","result","then","show_saving","update_display","catch","display","placeholder","text","prop","html","get_value","set_value"],"sources":["rsx/theme/components/_archived/unfinished/Inline_Edit_Field.js"],"sourcesContent":["class Inline_Edit_Field extends Jqhtml_Component {\n    on_ready() {\n        this.current_value = this.args.value || '';\n\n        // Enter edit mode\n        this.$id('display_mode').on('click', () => {\n            this.enter_edit_mode();\n        });\n\n        // Save\n        this.$id('save_btn').on('click', () => {\n            this.save();\n        });\n\n        // Cancel\n        this.$id('cancel_btn').on('click', () => {\n            this.cancel();\n        });\n\n        // Save on Enter, cancel on Escape\n        this.$id('input').on('keydown', (e) => {\n            if (e.key === 'Enter') {\n                e.preventDefault();\n                this.save();\n            } else if (e.key === 'Escape') {\n                e.preventDefault();\n                this.cancel();\n            }\n        });\n    }\n\n    enter_edit_mode() {\n        const $input = this.$id('input');\n        $input.val(this.current_value);\n\n        this.$id('display_mode').hide();\n        this.$id('edit_mode').show();\n\n        $input.focus();\n        $input.select();\n    }\n\n    exit_edit_mode() {\n        this.$id('edit_mode').hide();\n        this.$id('display_mode').show();\n    }\n\n    save() {\n        const new_value = this.$id('input').val();\n\n        if (new_value === this.current_value) {\n            this.exit_edit_mode();\n            return;\n        }\n\n        // Trigger callback\n        if (this.args.on_save) {\n            const result = this.args.on_save(new_value, this.current_value);\n\n            // If callback returns false, don't save\n            if (result === false) {\n                return;\n            }\n\n            // If callback returns a promise, wait for it\n            if (result && typeof result.then === 'function') {\n                this.show_saving();\n                result.then(() => {\n                    this.current_value = new_value;\n                    this.update_display();\n                    this.exit_edit_mode();\n                }).catch(() => {\n                    this.exit_edit_mode();\n                });\n                return;\n            }\n        }\n\n        this.current_value = new_value;\n        this.update_display();\n        this.exit_edit_mode();\n    }\n\n    cancel() {\n        this.exit_edit_mode();\n    }\n\n    update_display() {\n        const display = this.current_value || this.args.placeholder || 'Click to edit';\n        this.$id('value_display').text(display);\n    }\n\n    show_saving() {\n        this.$id('save_btn').prop('disabled', true).html('<span class=\"spinner-border spinner-border-sm\"></span>');\n        this.$id('cancel_btn').prop('disabled', true);\n    }\n\n    get_value() {\n        return this.current_value;\n    }\n\n    set_value(value) {\n        this.current_value = value;\n        this.update_display();\n    }\n}\n"],"mappings":"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","ignoreList":[]}