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>
102 lines
12 KiB
JavaScript
Executable File
102 lines
12 KiB
JavaScript
Executable File
"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":[]}
|