"use strict"; class Input_With_Validation extends Component { on_ready() { const $input = this.$sid('input'); if (this.args.value) { $input.val(this.args.value); } if (this.args.name) { $input.attr('name', this.args.name); } if (this.args.required) { $input.prop('required', true); } if (this.args.disabled) { $input.prop('disabled', true); } if (this.args.readonly) { $input.prop('readonly', true); } // Real-time validation if (this.args.validate) { $input.on('blur', () => { this.validate(); }); $input.on('input', () => { if (this.$.hasClass('was-validated')) { this.validate(); } }); } if (this.args.on_change) { $input.on('change', e => { this.args.on_change(e.target.value); }); } } validate() { const value = this.$sid('input').val(); const $input = this.$sid('input'); this.$.addClass('was-validated'); // Run validation function if (this.args.validate) { const result = this.args.validate(value); if (result === true || result === null || result === undefined) { this.set_valid(); return true; } else { this.set_error(result); return false; } } // Basic required check if (this.args.required && !value) { this.set_error('This field is required'); return false; } this.set_valid(); return true; } set_error(message) { const $input = this.$sid('input'); const $error = this.$sid('error'); $input.removeClass('is-valid').addClass('is-invalid'); $error.text(message).css('display', 'block'); this.$sid('success').css('display', 'none'); } set_valid(message) { const $input = this.$sid('input'); const $success = this.$sid('success'); $input.removeClass('is-invalid').addClass('is-valid'); this.$sid('error').css('display', 'none'); if (message) { $success.text(message).css('display', 'block'); } else { $success.css('display', 'none'); } } clear_validation() { const $input = this.$sid('input'); $input.removeClass('is-valid is-invalid'); this.$sid('error').css('display', 'none'); this.$sid('success').css('display', 'none'); this.$.removeClass('was-validated'); } get_value() { return this.$sid('input').val(); } set_value(value) { this.$sid('input').val(value); if (this.$.hasClass('was-validated')) { this.validate(); } } focus() { this.$sid('input').focus(); } } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Input_With_Validation","Jqhtml_Component","on_ready","$input","$id","args","value","val","name","attr","required","prop","disabled","readonly","validate","on","$","hasClass","on_change","e","target","addClass","result","undefined","set_valid","set_error","message","$error","removeClass","text","css","$success","clear_validation","get_value","set_value","focus"],"sources":["rsx/theme/components/_archived/unfinished/Input_With_Validation.js"],"sourcesContent":["class Input_With_Validation extends Jqhtml_Component {\n    on_ready() {\n        const $input = this.$id('input');\n\n        if (this.args.value) {\n            $input.val(this.args.value);\n        }\n\n        if (this.args.name) {\n            $input.attr('name', this.args.name);\n        }\n\n        if (this.args.required) {\n            $input.prop('required', true);\n        }\n\n        if (this.args.disabled) {\n            $input.prop('disabled', true);\n        }\n\n        if (this.args.readonly) {\n            $input.prop('readonly', true);\n        }\n\n        // Real-time validation\n        if (this.args.validate) {\n            $input.on('blur', () => {\n                this.validate();\n            });\n\n            $input.on('input', () => {\n                if (this.$.hasClass('was-validated')) {\n                    this.validate();\n                }\n            });\n        }\n\n        if (this.args.on_change) {\n            $input.on('change', (e) => {\n                this.args.on_change(e.target.value);\n            });\n        }\n    }\n\n    validate() {\n        const value = this.$id('input').val();\n        const $input = this.$id('input');\n\n        this.$.addClass('was-validated');\n\n        // Run validation function\n        if (this.args.validate) {\n            const result = this.args.validate(value);\n\n            if (result === true || result === null || result === undefined) {\n                this.set_valid();\n                return true;\n            } else {\n                this.set_error(result);\n                return false;\n            }\n        }\n\n        // Basic required check\n        if (this.args.required && !value) {\n            this.set_error('This field is required');\n            return false;\n        }\n\n        this.set_valid();\n        return true;\n    }\n\n    set_error(message) {\n        const $input = this.$id('input');\n        const $error = this.$id('error');\n\n        $input.removeClass('is-valid').addClass('is-invalid');\n        $error.text(message).css('display', 'block');\n        this.$id('success').css('display', 'none');\n    }\n\n    set_valid(message) {\n        const $input = this.$id('input');\n        const $success = this.$id('success');\n\n        $input.removeClass('is-invalid').addClass('is-valid');\n        this.$id('error').css('display', 'none');\n\n        if (message) {\n            $success.text(message).css('display', 'block');\n        } else {\n            $success.css('display', 'none');\n        }\n    }\n\n    clear_validation() {\n        const $input = this.$id('input');\n        $input.removeClass('is-valid is-invalid');\n        this.$id('error').css('display', 'none');\n        this.$id('success').css('display', 'none');\n        this.$.removeClass('was-validated');\n    }\n\n    get_value() {\n        return this.$id('input').val();\n    }\n\n    set_value(value) {\n        this.$id('input').val(value);\n        if (this.$.hasClass('was-validated')) {\n            this.validate();\n        }\n    }\n\n    focus() {\n        this.$id('input').focus();\n    }\n}\n"],"mappings":"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","ignoreList":[]}