Files
rspade_system/storage-broken/rsx-tmp/babel_df5c9efac86147294cfc845822e1058a.js
root 78553d4edf Fix code quality violations for publish
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>
2025-11-21 04:35:01 +00:00

112 lines
14 KiB
JavaScript
Executable File

"use strict";
class Filter_Bar extends Component {
on_ready() {
this.active_filters = {};
// Populate status options if provided
if (this.args.status_options) {
const $status = this.$sid('status');
this.args.status_options.forEach(opt => {
$status.append($('<option>').val(opt.value).text(opt.label));
});
}
// Date range change handler
this.$sid('date_range').on('change', e => {
if (e.target.value === 'custom') {
this.$sid('custom_dates').show();
this.$sid('custom_dates_end').show();
} else {
this.$sid('custom_dates').hide();
this.$sid('custom_dates_end').hide();
}
});
// Search with debounce
let search_timeout;
this.$sid('search').$.find('input').on('input', e => {
clearTimeout(search_timeout);
search_timeout = setTimeout(() => {
this.add_filter('search', e.target.value);
}, 500);
});
// Apply button
this.$sid('apply_btn').on('click', () => {
this.apply_filters();
});
// Clear button
this.$sid('clear_btn').on('click', () => {
this.clear_filters();
});
}
add_filter(key, value) {
if (value) {
this.active_filters[key] = value;
} else {
delete this.active_filters[key];
}
this.update_filter_display();
}
apply_filters() {
// Collect all filter values
const search = this.$sid('search').get_value();
const status = this.$sid('status').val();
const date_range = this.$sid('date_range').val();
this.active_filters = {};
if (search) this.active_filters.search = search;
if (status) this.active_filters.status = status;
if (date_range) this.active_filters.date_range = date_range;
if (date_range === 'custom') {
const start_date = this.$sid('start_date').get_value();
const end_date = this.$sid('end_date').get_value();
if (start_date) this.active_filters.start_date = start_date;
if (end_date) this.active_filters.end_date = end_date;
}
this.update_filter_display();
if (this.args.on_apply) {
this.args.on_apply(this.active_filters);
}
}
clear_filters() {
this.active_filters = {};
this.$sid('search').set_value('');
this.$sid('status').val('');
this.$sid('date_range').val('');
this.$sid('custom_dates').hide();
this.$sid('custom_dates_end').hide();
this.update_filter_display();
if (this.args.on_clear) {
this.args.on_clear();
}
}
update_filter_display() {
const count = Object.keys(this.active_filters).length;
const $container = this.$sid('active_filters');
const $tags = this.$sid('filter_tags');
if (count === 0) {
$container.hide();
return;
}
$container.show();
$tags.empty();
for (let key in this.active_filters) {
const $tag = $('<span>').addClass('badge bg-primary me-1');
$tag.text(`${key}: ${this.active_filters[key]}`);
const $remove = $('<i>').addClass('bi bi-x-circle ms-1').css('cursor', 'pointer');
$remove.on('click', () => {
delete this.active_filters[key];
this.update_filter_display();
this.apply_filters();
});
$tag.append($remove);
$tags.append($tag);
}
}
get_filters() {
return this.active_filters;
}
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Filter_Bar","Jqhtml_Component","on_ready","active_filters","args","status_options","$status","$id","forEach","opt","append","$","val","value","text","label","on","e","target","show","hide","search_timeout","find","clearTimeout","setTimeout","add_filter","apply_filters","clear_filters","key","update_filter_display","search","get_value","status","date_range","start_date","end_date","on_apply","set_value","on_clear","count","Object","keys","length","$container","$tags","empty","$tag","addClass","$remove","css","get_filters"],"sources":["rsx/theme/components/_archived/unfinished/Filter_Bar.js"],"sourcesContent":["class Filter_Bar extends Jqhtml_Component {\n    on_ready() {\n        this.active_filters = {};\n\n        // Populate status options if provided\n        if (this.args.status_options) {\n            const $status = this.$id('status');\n            this.args.status_options.forEach(opt => {\n                $status.append($('<option>').val(opt.value).text(opt.label));\n            });\n        }\n\n        // Date range change handler\n        this.$id('date_range').on('change', (e) => {\n            if (e.target.value === 'custom') {\n                this.$id('custom_dates').show();\n                this.$id('custom_dates_end').show();\n            } else {\n                this.$id('custom_dates').hide();\n                this.$id('custom_dates_end').hide();\n            }\n        });\n\n        // Search with debounce\n        let search_timeout;\n        this.$id('search').$.find('input').on('input', (e) => {\n            clearTimeout(search_timeout);\n            search_timeout = setTimeout(() => {\n                this.add_filter('search', e.target.value);\n            }, 500);\n        });\n\n        // Apply button\n        this.$id('apply_btn').on('click', () => {\n            this.apply_filters();\n        });\n\n        // Clear button\n        this.$id('clear_btn').on('click', () => {\n            this.clear_filters();\n        });\n    }\n\n    add_filter(key, value) {\n        if (value) {\n            this.active_filters[key] = value;\n        } else {\n            delete this.active_filters[key];\n        }\n        this.update_filter_display();\n    }\n\n    apply_filters() {\n        // Collect all filter values\n        const search = this.$id('search').get_value();\n        const status = this.$id('status').val();\n        const date_range = this.$id('date_range').val();\n\n        this.active_filters = {};\n\n        if (search) this.active_filters.search = search;\n        if (status) this.active_filters.status = status;\n        if (date_range) this.active_filters.date_range = date_range;\n\n        if (date_range === 'custom') {\n            const start_date = this.$id('start_date').get_value();\n            const end_date = this.$id('end_date').get_value();\n            if (start_date) this.active_filters.start_date = start_date;\n            if (end_date) this.active_filters.end_date = end_date;\n        }\n\n        this.update_filter_display();\n\n        if (this.args.on_apply) {\n            this.args.on_apply(this.active_filters);\n        }\n    }\n\n    clear_filters() {\n        this.active_filters = {};\n\n        this.$id('search').set_value('');\n        this.$id('status').val('');\n        this.$id('date_range').val('');\n        this.$id('custom_dates').hide();\n        this.$id('custom_dates_end').hide();\n\n        this.update_filter_display();\n\n        if (this.args.on_clear) {\n            this.args.on_clear();\n        }\n    }\n\n    update_filter_display() {\n        const count = Object.keys(this.active_filters).length;\n        const $container = this.$id('active_filters');\n        const $tags = this.$id('filter_tags');\n\n        if (count === 0) {\n            $container.hide();\n            return;\n        }\n\n        $container.show();\n        $tags.empty();\n\n        for (let key in this.active_filters) {\n            const $tag = $('<span>').addClass('badge bg-primary me-1');\n            $tag.text(`${key}: ${this.active_filters[key]}`);\n\n            const $remove = $('<i>').addClass('bi bi-x-circle ms-1').css('cursor', 'pointer');\n            $remove.on('click', () => {\n                delete this.active_filters[key];\n                this.update_filter_display();\n                this.apply_filters();\n            });\n\n            $tag.append($remove);\n            $tags.append($tag);\n        }\n    }\n\n    get_filters() {\n        return this.active_filters;\n    }\n}\n"],"mappings":"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","ignoreList":[]}