"use strict"; class Dev_Modals { static on_app_ready() { if (!$('.Dev_Modals').exists()) return; Dev_Modals.init(); } static init() { // Simple Dialogs $('#test-alert').on('click', async () => { await Modal.alert('This is a simple alert message'); Dev_Modals.show_result('simple', 'Alert acknowledged'); }); $('#test-alert-title').on('click', async () => { await Modal.alert('Custom Title', 'This alert has a custom title'); Dev_Modals.show_result('simple', 'Alert with title acknowledged'); }); $('#test-confirm').on('click', async () => { const result = await Modal.confirm('Are you sure you want to proceed?'); Dev_Modals.show_result('simple', `Confirm result: ${result}`); }); $('#test-confirm-title').on('click', async () => { const result = await Modal.confirm('Delete Item', 'Are you sure you want to delete this item?'); Dev_Modals.show_result('simple', `Confirm with title result: ${result}`); }); $('#test-prompt').on('click', async () => { const result = await Modal.prompt('What is your name?'); Dev_Modals.show_result('simple', `Prompt result: ${result === false ? 'Cancelled' : result}`); }); $('#test-prompt-default').on('click', async () => { const result = await Modal.prompt('Enter your email:', null, 'user@example.com'); Dev_Modals.show_result('simple', `Prompt with default result: ${result === false ? 'Cancelled' : result}`); }); $('#test-prompt-multiline').on('click', async () => { const result = await Modal.prompt('Enter your feedback:', null, 'Type your feedback here...', true); Dev_Modals.show_result('simple', `Multiline prompt result: ${result === false ? 'Cancelled' : result}`); }); $('#test-prompt-rich').on('click', async () => { // Create rich formatted content above the input const $rich_content = $('
').html('Please enter your full name as it appears on your ' + 'official documents.')).append($('
').html('Required fields must be completed before submission.')).append($('
').text('Example: John Michael Smith')); const result = await Modal.prompt($rich_content, null, '', false); Dev_Modals.show_result('simple', `Rich text prompt result: ${result === false ? 'Cancelled' : result}`); }); $('#test-prompt-validation').on('click', async () => { // Demonstrate validation pattern: keep reopening until valid or cancelled let email = ''; let error = null; let valid = false; while (!valid) { email = await Modal.prompt('Email Validation', 'Please enter a valid email address:', email, false, error); // User cancelled if (email === false) { Dev_Modals.show_result('simple', 'Prompt cancelled'); return; } // Validate email (simple check) if (!email || email.trim() === '') { error = 'Email address is required'; } else if (!email.includes('@') || !email.includes('.')) { error = 'Please enter a valid email address (must contain @ and .)'; } else if (email.length < 5) { error = 'Email address is too short'; } else { // Valid! valid = true; } } Dev_Modals.show_result('simple', `Valid email entered: ${email}`); }); // Custom Modals $('#test-custom-2btn').on('click', async () => { const result = await Modal.show({ title: 'Custom Two Button Modal', body: 'This modal has two custom buttons with different values', buttons: [{ label: 'Option A', value: 'option_a', class: 'btn-secondary' }, { label: 'Option B', value: 'option_b', class: 'btn-primary', default: true }] }); Dev_Modals.show_result('custom', `Two button result: ${result}`); }); $('#test-custom-3btn').on('click', async () => { const result = await Modal.show({ title: 'Three Button Modal', body: 'Choose one of three options', buttons: [{ label: 'Cancel', value: false, class: 'btn-secondary' }, { label: 'Save Draft', value: 'draft', class: 'btn-info' }, { label: 'Publish', value: 'publish', class: 'btn-success', default: true }] }); Dev_Modals.show_result('custom', `Three button result: ${result}`); }); $('#test-custom-danger').on('click', async () => { const result = await Modal.show({ title: 'Dangerous Action', body: 'This action cannot be undone. Are you absolutely sure?', buttons: [{ label: 'Cancel', value: false, class: 'btn-secondary' }, { label: 'Delete Forever', value: true, class: 'btn-danger', default: true }] }); Dev_Modals.show_result('custom', `Dangerous action result: ${result}`); }); $('#test-custom-jquery').on('click', async () => { const $content = $('
').text('This modal body contains jQuery elements')).append($('
').html('Formatted text and styling')); const result = await Modal.show({ title: 'jQuery Content', body: $content, buttons: [{ label: 'Close', value: true, class: 'btn-primary', default: true }] }); Dev_Modals.show_result('custom', 'jQuery content modal closed'); }); $('#test-custom-wide').on('click', async () => { const result = await Modal.show({ title: 'Wide Modal (1200px)', body: 'This modal has a max width of 1200px, useful for forms or data tables that need more horizontal space.', max_width: 1200, buttons: [{ label: 'Close', value: true, class: 'btn-primary', default: true }] }); Dev_Modals.show_result('custom', 'Wide modal closed'); }); // Special Behaviors $('#test-unclosable').on('click', async () => { Modal.unclosable('Processing', 'Please wait while we process your request...'); // Simulate processing setTimeout(async () => { await Modal.close(); Dev_Modals.show_result('special', 'Unclosable modal was closed programmatically after 3 seconds'); }, 3000); }); $('#test-queue').on('click', async () => { // Queue 3 modals const promise1 = Modal.alert('First Modal', 'This is the first modal in the queue'); const promise2 = Modal.alert('Second Modal', 'This is the second modal in the queue'); const promise3 = Modal.alert('Third Modal', 'This is the third and final modal'); await Promise.all([promise1, promise2, promise3]); Dev_Modals.show_result('special', 'All 3 queued modals completed'); }); $('#test-error').on('click', async () => { const error_obj = { message: 'An error occurred while processing your request' }; await Modal.error(error_obj, 'Error'); Dev_Modals.show_result('special', 'Error modal shown'); }); $('#test-tall').on('click', async () => { let tall_content = '
Paragraph ${i}: This is a long paragraph that helps demonstrate scrolling behavior when content exceeds the 80% viewport height threshold.
`; } const result = await Modal.show({ title: 'Tall Content (Scrolling Test)', body: tall_content, buttons: [{ label: 'Close', value: true, class: 'btn-primary', default: true }] }); Dev_Modals.show_result('special', 'Tall content modal closed'); }); // Form Modals $('#test-form-simple').on('click', async () => { const result = await Modal.form({ title: 'User Registration', component: 'Test_Modal_Form', on_submit: async form => { // Get form values const values = form.vals(); // Simple validation - just check required fields if (!values.name || !values.email || !values.role) { Form_Utils.apply_form_errors(form.$, 'Please fill in all required fields'); return false; // Keep modal open } // Simulate saving await sleep(500); // Return data to close modal return values; } }); if (result) { Dev_Modals.show_result('form', `Form submitted: ${json_encode(result)}`); } else { Dev_Modals.show_result('form', 'Form cancelled'); } }); $('#test-form-validation').on('click', async () => { const result = await Modal.form({ title: 'User Registration (With Server Validation)', component: 'Test_Modal_Form', on_submit: async form => { // Get form values const values = form.vals(); // Simulate server-side validation await sleep(500); // Simulate validation errors const errors = {}; if (!values.name || values.name.length < 3) { errors.name = 'Name must be at least 3 characters'; } if (!values.email || !values.email.includes('@')) { errors.email = 'Please enter a valid email address'; } if (!values.role) { errors.role = 'Please select a role'; } // If there are errors, show them and keep modal open if (Object.keys(errors).length > 0) { Form_Utils.apply_form_errors(form.$, errors); return false; // Keep modal open } // Success - return data return values; } }); if (result) { Dev_Modals.show_result('form', `Form submitted successfully: ${json_encode(result)}`); } else { Dev_Modals.show_result('form', 'Form cancelled'); } }); $('#test-form-prefilled').on('click', async () => { const result = await Modal.form({ title: 'Edit User Profile', component: 'Test_Modal_Form', component_args: { data: { name: 'John Smith', email: 'john.smith@example.com', role: 'manager' } }, submit_label: 'Update', on_submit: async form => { const values = form.vals(); // Simple validation if (!values.name || !values.email || !values.role) { await Modal.alert('Please fill in all required fields'); return false; } // Simulate update await sleep(500); return values; } }); if (result) { Dev_Modals.show_result('form', `Profile updated: ${json_encode(result)}`); } else { Dev_Modals.show_result('form', 'Update cancelled'); } }); $('#test-form-pin').on('click', async () => { const result = await Modal.form({ title: 'Enter Verification Code', component: 'Pin_Verification_Form', submit_label: 'Verify', max_width: 450, on_submit: async form => { const pin = form.val(); // Validate PIN is complete if (pin.length !== 6) { Form_Utils.apply_form_errors(form.$, 'Please enter all 6 digits'); return false; } // Simulate PIN verification await sleep(800); // Simulate checking against correct PIN const correct_pin = '123456'; if (pin !== correct_pin) { Form_Utils.apply_form_errors(form.$, `Incorrect PIN. (Hint: try ${correct_pin})`); // Clear the PIN and refocus first input form.val(''); return false; } // Success return { pin: pin, verified: true }; } }); if (result) { Dev_Modals.show_result('form', `PIN verified successfully: ${result.pin}`); } else { Dev_Modals.show_result('form', 'PIN verification cancelled'); } }); // Modal State $('#check-state').on('click', () => { const state = { is_open: Modal.is_open(), current_modal: Modal.get_current() !== null ? 'Modal instance exists' : null }; const formatted = json_encode(state, null, 2); $('#state-result').show(); $('#state-result-text').text(formatted); }); $('#force-close').on('click', async () => { if (Modal.is_open()) { await Modal.close(); Dev_Modals.show_result('special', 'Modal was force closed'); } else { Dev_Modals.show_result('special', 'No modal is currently open'); } }); } static show_result(section, message) { const $result = $(`#${section}-result`); const $text = $(`#${section}-result-text`); $text.text(message); $result.show(); // Hide after 5 seconds setTimeout(() => { $result.fadeOut(); }, 5000); } } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Dev_Modals","on_app_ready","$","exists","init","on","Modal","alert","show_result","result","confirm","prompt","$rich_content","append","text","html","email","error","valid","trim","includes","length","show","title","body","buttons","label","value","class","default","$content","max_width","unclosable","setTimeout","close","promise1","promise2","promise3","Promise","all","error_obj","message","tall_content","i","form","component","on_submit","values","vals","name","role","Form_Utils","apply_form_errors","sleep","json_encode","errors","Object","keys","component_args","data","submit_label","pin","val","correct_pin","verified","state","is_open","current_modal","get_current","formatted","section","$result","$text","fadeOut"],"sources":["rsx/app/dev/modals/dev_modals.js"],"sourcesContent":["class Dev_Modals {\n    static on_app_ready() {\n        if (!$('.Dev_Modals').exists()) return;\n        Dev_Modals.init();\n    }\n\n    static init() {\n        // Simple Dialogs\n        $('#test-alert').on('click', async () => {\n            await Modal.alert('This is a simple alert message');\n            Dev_Modals.show_result('simple', 'Alert acknowledged');\n        });\n\n        $('#test-alert-title').on('click', async () => {\n            await Modal.alert('Custom Title', 'This alert has a custom title');\n            Dev_Modals.show_result('simple', 'Alert with title acknowledged');\n        });\n\n        $('#test-confirm').on('click', async () => {\n            const result = await Modal.confirm('Are you sure you want to proceed?');\n            Dev_Modals.show_result('simple', `Confirm result: ${result}`);\n        });\n\n        $('#test-confirm-title').on('click', async () => {\n            const result = await Modal.confirm('Delete Item', 'Are you sure you want to delete this item?');\n            Dev_Modals.show_result('simple', `Confirm with title result: ${result}`);\n        });\n\n        $('#test-prompt').on('click', async () => {\n            const result = await Modal.prompt('What is your name?');\n            Dev_Modals.show_result('simple', `Prompt result: ${result === false ? 'Cancelled' : result}`);\n        });\n\n        $('#test-prompt-default').on('click', async () => {\n            const result = await Modal.prompt('Enter your email:', null, 'user@example.com');\n            Dev_Modals.show_result('simple', `Prompt with default result: ${result === false ? 'Cancelled' : result}`);\n        });\n\n        $('#test-prompt-multiline').on('click', async () => {\n            const result = await Modal.prompt('Enter your feedback:', null, 'Type your feedback here...', true);\n            Dev_Modals.show_result('simple', `Multiline prompt result: ${result === false ? 'Cancelled' : result}`);\n        });\n\n        $('#test-prompt-rich').on('click', async () => {\n            // Create rich formatted content above the input\n            const $rich_content = $('<div>')\n                .append($('<h5 style=\"color: #2c3e50; margin-bottom: 15px;\">').text('User Registration Form'))\n                .append(\n                    $('<p style=\"margin-bottom: 10px;\">').html(\n                        'Please enter your <strong style=\"color: #e74c3c;\">full name</strong> as it appears on your ' +\n                            '<em style=\"color: #3498db;\">official documents</em>.'\n                    )\n                )\n                .append(\n                    $('<p style=\"margin-bottom: 10px;\">').html(\n                        '<span style=\"text-decoration: underline; color: #27ae60;\">Required fields</span> must be completed before submission.'\n                    )\n                )\n                .append(\n                    $('<div style=\"background-color: #fff3cd; border-left: 4px solid #ffc107; padding: 10px; margin-bottom: 20px;\">').html(\n                        '<strong>⚠ Note:</strong> <span style=\"font-size: 14px;\">Your name will be used for all official correspondence.</span>'\n                    )\n                )\n                .append($('<p style=\"font-size: 13px; color: #7f8c8d; margin-bottom: 25px;\">').text('Example: John Michael Smith'));\n\n            const result = await Modal.prompt($rich_content, null, '', false);\n            Dev_Modals.show_result('simple', `Rich text prompt result: ${result === false ? 'Cancelled' : result}`);\n        });\n\n        $('#test-prompt-validation').on('click', async () => {\n            // Demonstrate validation pattern: keep reopening until valid or cancelled\n            let email = '';\n            let error = null;\n            let valid = false;\n\n            while (!valid) {\n                email = await Modal.prompt('Email Validation', 'Please enter a valid email address:', email, false, error);\n\n                // User cancelled\n                if (email === false) {\n                    Dev_Modals.show_result('simple', 'Prompt cancelled');\n                    return;\n                }\n\n                // Validate email (simple check)\n                if (!email || email.trim() === '') {\n                    error = 'Email address is required';\n                } else if (!email.includes('@') || !email.includes('.')) {\n                    error = 'Please enter a valid email address (must contain @ and .)';\n                } else if (email.length < 5) {\n                    error = 'Email address is too short';\n                } else {\n                    // Valid!\n                    valid = true;\n                }\n            }\n\n            Dev_Modals.show_result('simple', `Valid email entered: ${email}`);\n        });\n\n        // Custom Modals\n        $('#test-custom-2btn').on('click', async () => {\n            const result = await Modal.show({\n                title: 'Custom Two Button Modal',\n                body: 'This modal has two custom buttons with different values',\n                buttons: [\n                    { label: 'Option A', value: 'option_a', class: 'btn-secondary' },\n                    { label: 'Option B', value: 'option_b', class: 'btn-primary', default: true },\n                ],\n            });\n            Dev_Modals.show_result('custom', `Two button result: ${result}`);\n        });\n\n        $('#test-custom-3btn').on('click', async () => {\n            const result = await Modal.show({\n                title: 'Three Button Modal',\n                body: 'Choose one of three options',\n                buttons: [\n                    { label: 'Cancel', value: false, class: 'btn-secondary' },\n                    { label: 'Save Draft', value: 'draft', class: 'btn-info' },\n                    { label: 'Publish', value: 'publish', class: 'btn-success', default: true },\n                ],\n            });\n            Dev_Modals.show_result('custom', `Three button result: ${result}`);\n        });\n\n        $('#test-custom-danger').on('click', async () => {\n            const result = await Modal.show({\n                title: 'Dangerous Action',\n                body: 'This action cannot be undone. Are you absolutely sure?',\n                buttons: [\n                    { label: 'Cancel', value: false, class: 'btn-secondary' },\n                    { label: 'Delete Forever', value: true, class: 'btn-danger', default: true },\n                ],\n            });\n            Dev_Modals.show_result('custom', `Dangerous action result: ${result}`);\n        });\n\n        $('#test-custom-jquery').on('click', async () => {\n            const $content = $('<div>')\n                .append($('<p>').text('This modal body contains jQuery elements'))\n                .append(\n                    $('<ul>')\n                        .append($('<li>').text('First item'))\n                        .append($('<li>').text('Second item'))\n                        .append($('<li>').text('Third item'))\n                )\n                .append($('<p>').html('<strong>Formatted text</strong> and <em>styling</em>'));\n\n            const result = await Modal.show({\n                title: 'jQuery Content',\n                body: $content,\n                buttons: [{ label: 'Close', value: true, class: 'btn-primary', default: true }],\n            });\n            Dev_Modals.show_result('custom', 'jQuery content modal closed');\n        });\n\n        $('#test-custom-wide').on('click', async () => {\n            const result = await Modal.show({\n                title: 'Wide Modal (1200px)',\n                body: 'This modal has a max width of 1200px, useful for forms or data tables that need more horizontal space.',\n                max_width: 1200,\n                buttons: [{ label: 'Close', value: true, class: 'btn-primary', default: true }],\n            });\n            Dev_Modals.show_result('custom', 'Wide modal closed');\n        });\n\n        // Special Behaviors\n        $('#test-unclosable').on('click', async () => {\n            Modal.unclosable('Processing', 'Please wait while we process your request...');\n\n            // Simulate processing\n            setTimeout(async () => {\n                await Modal.close();\n                Dev_Modals.show_result('special', 'Unclosable modal was closed programmatically after 3 seconds');\n            }, 3000);\n        });\n\n        $('#test-queue').on('click', async () => {\n            // Queue 3 modals\n            const promise1 = Modal.alert('First Modal', 'This is the first modal in the queue');\n            const promise2 = Modal.alert('Second Modal', 'This is the second modal in the queue');\n            const promise3 = Modal.alert('Third Modal', 'This is the third and final modal');\n\n            await Promise.all([promise1, promise2, promise3]);\n            Dev_Modals.show_result('special', 'All 3 queued modals completed');\n        });\n\n        $('#test-error').on('click', async () => {\n            const error_obj = {\n                message: 'An error occurred while processing your request',\n            };\n\n            await Modal.error(error_obj, 'Error');\n            Dev_Modals.show_result('special', 'Error modal shown');\n        });\n\n        $('#test-tall').on('click', async () => {\n            let tall_content = '<h6>Scrollable Content</h6>';\n            for (let i = 1; i <= 50; i++) {\n                tall_content += `<p>Paragraph ${i}: This is a long paragraph that helps demonstrate scrolling behavior when content exceeds the 80% viewport height threshold.</p>`;\n            }\n\n            const result = await Modal.show({\n                title: 'Tall Content (Scrolling Test)',\n                body: tall_content,\n                buttons: [{ label: 'Close', value: true, class: 'btn-primary', default: true }],\n            });\n            Dev_Modals.show_result('special', 'Tall content modal closed');\n        });\n\n        // Form Modals\n        $('#test-form-simple').on('click', async () => {\n            const result = await Modal.form({\n                title: 'User Registration',\n                component: 'Test_Modal_Form',\n                on_submit: async (form) => {\n                    // Get form values\n                    const values = form.vals();\n\n                    // Simple validation - just check required fields\n                    if (!values.name || !values.email || !values.role) {\n                        Form_Utils.apply_form_errors(form.$, 'Please fill in all required fields');\n                        return false; // Keep modal open\n                    }\n\n                    // Simulate saving\n                    await sleep(500);\n\n                    // Return data to close modal\n                    return values;\n                },\n            });\n\n            if (result) {\n                Dev_Modals.show_result('form', `Form submitted: ${json_encode(result)}`);\n            } else {\n                Dev_Modals.show_result('form', 'Form cancelled');\n            }\n        });\n\n        $('#test-form-validation').on('click', async () => {\n            const result = await Modal.form({\n                title: 'User Registration (With Server Validation)',\n                component: 'Test_Modal_Form',\n                on_submit: async (form) => {\n                    // Get form values\n                    const values = form.vals();\n\n                    // Simulate server-side validation\n                    await sleep(500);\n\n                    // Simulate validation errors\n                    const errors = {};\n                    if (!values.name || values.name.length < 3) {\n                        errors.name = 'Name must be at least 3 characters';\n                    }\n                    if (!values.email || !values.email.includes('@')) {\n                        errors.email = 'Please enter a valid email address';\n                    }\n                    if (!values.role) {\n                        errors.role = 'Please select a role';\n                    }\n\n                    // If there are errors, show them and keep modal open\n                    if (Object.keys(errors).length > 0) {\n                        Form_Utils.apply_form_errors(form.$, errors);\n                        return false; // Keep modal open\n                    }\n\n                    // Success - return data\n                    return values;\n                },\n            });\n\n            if (result) {\n                Dev_Modals.show_result('form', `Form submitted successfully: ${json_encode(result)}`);\n            } else {\n                Dev_Modals.show_result('form', 'Form cancelled');\n            }\n        });\n\n        $('#test-form-prefilled').on('click', async () => {\n            const result = await Modal.form({\n                title: 'Edit User Profile',\n                component: 'Test_Modal_Form',\n                component_args: {\n                    data: {\n                        name: 'John Smith',\n                        email: 'john.smith@example.com',\n                        role: 'manager',\n                    },\n                },\n                submit_label: 'Update',\n                on_submit: async (form) => {\n                    const values = form.vals();\n\n                    // Simple validation\n                    if (!values.name || !values.email || !values.role) {\n                        await Modal.alert('Please fill in all required fields');\n                        return false;\n                    }\n\n                    // Simulate update\n                    await sleep(500);\n                    return values;\n                },\n            });\n\n            if (result) {\n                Dev_Modals.show_result('form', `Profile updated: ${json_encode(result)}`);\n            } else {\n                Dev_Modals.show_result('form', 'Update cancelled');\n            }\n        });\n\n        $('#test-form-pin').on('click', async () => {\n            const result = await Modal.form({\n                title: 'Enter Verification Code',\n                component: 'Pin_Verification_Form',\n                submit_label: 'Verify',\n                max_width: 450,\n                on_submit: async (form) => {\n                    const pin = form.val();\n\n                    // Validate PIN is complete\n                    if (pin.length !== 6) {\n                        Form_Utils.apply_form_errors(form.$, 'Please enter all 6 digits');\n                        return false;\n                    }\n\n                    // Simulate PIN verification\n                    await sleep(800);\n\n                    // Simulate checking against correct PIN\n                    const correct_pin = '123456';\n                    if (pin !== correct_pin) {\n                        Form_Utils.apply_form_errors(form.$, `Incorrect PIN. (Hint: try ${correct_pin})`);\n                        // Clear the PIN and refocus first input\n                        form.val('');\n                        return false;\n                    }\n\n                    // Success\n                    return { pin: pin, verified: true };\n                },\n            });\n\n            if (result) {\n                Dev_Modals.show_result('form', `PIN verified successfully: ${result.pin}`);\n            } else {\n                Dev_Modals.show_result('form', 'PIN verification cancelled');\n            }\n        });\n\n        // Modal State\n        $('#check-state').on('click', () => {\n            const state = {\n                is_open: Modal.is_open(),\n                current_modal: Modal.get_current() !== null ? 'Modal instance exists' : null,\n            };\n\n            const formatted = json_encode(state, null, 2);\n            $('#state-result').show();\n            $('#state-result-text').text(formatted);\n        });\n\n        $('#force-close').on('click', async () => {\n            if (Modal.is_open()) {\n                await Modal.close();\n                Dev_Modals.show_result('special', 'Modal was force closed');\n            } else {\n                Dev_Modals.show_result('special', 'No modal is currently open');\n            }\n        });\n    }\n\n    static show_result(section, message) {\n        const $result = $(`#${section}-result`);\n        const $text = $(`#${section}-result-text`);\n\n        $text.text(message);\n        $result.show();\n\n        // Hide after 5 seconds\n        setTimeout(() => {\n            $result.fadeOut();\n        }, 5000);\n    }\n}\n"],"mappings":"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","ignoreList":[]}