 
                    
                    - 
                              John DoeProjohndoe@gmail.com
- Profile
- Inbox
- Lock Screen
- Sign Out
- Components
- Sweet Alerts
Basic message
Code
<!-- basic message -->
<button type="button" class="btn btn-primary" @click="showAlert()">Basic message</button>
<!-- script -->
<script>
    async function showAlert() {
        new window.Swal({
            title: 'Saved succesfully',
            padding: '2em',
            customClass: 'sweet-alerts',
        });
    } 
</script>   
                
            Success message
Code
<!-- success message -->
<button type="button" class="btn btn-secondary" @click="showAlert()">Success message!</button>
<!-- script -->
<script>
    async function showAlert() {
        new window.Swal({
            icon: 'success',
            title: 'Good job!',
            text: 'You clicked the!',
            padding: '2em',
            customClass: 'sweet-alerts',
        });
    }
</script>
                
            Dynamic queue
Code
<!-- dynamic queue -->
<button type="button" class="btn btn-success" @click="showAlert()">Dynamic queue</button>
<!-- script -->
<script>
    async function showAlert() {
        const ipAPI = 'https://api.ipify.org?format=json';
        new window.Swal({
            title: 'Your public IP',
            confirmButtonText: 'Show my public IP',
            text: 'Your public IP will be received ' + 'via AJAX request',
            showLoaderOnConfirm: true,
            customClass: 'sweet-alerts',
            preConfirm: () => {
                return fetch(ipAPI)
                    .then((response) => {
                        return response.json();
                    })
                    .then((data) => {
                        new window.Swal({
                            title: data.ip,
                            customClass: 'sweet-alerts',
                        });
                    })
                    .catch(() => {
                        new window.Swal({
                            type: 'error',
                            title: 'Unable to get your public IP',
                            customClass: 'sweet-alerts',
                        });
                    });
            },
        });
    }
</script>
                
            A title with a text under
Code
<!-- success message -->
<button type="button" class="btn btn-danger" @click="showAlert()">Title & text</button>
<!-- script -->
<script>
    async function showAlert() {
        new window.Swal({
            icon: 'question',
            title: 'The Internet?',
            text: 'That thing is still around?',
            padding: '2em',
            customClass: 'sweet-alerts',
        });
    }
</script>
                
            Chaining modals (queue)
Code
<!-- success message -->
<button type="button" class="btn btn-warning" @click="showAlert()">Chaining modals (queue)</button>
<!-- script -->
<script>
    async function showAlert() {
        const steps = ['1', '2', '3'];
        const swalQueueStep = window.Swal.mixin({
            confirmButtonText: 'Next →',
            showCancelButton: true,
            progressSteps: steps,
            input: 'text',
            customClass: 'sweet-alerts',
            inputAttributes: {
                required: true,
            },
            validationMessage: 'This field is required',
            padding: '2em',
        });
        const values = [];
        let currentStep;
        for (currentStep = 0; currentStep < steps.length;) {
            const result = await swalQueueStep.fire({
                title: `Question ${steps[currentStep]}`,
                text: currentStep == 0 ? 'Chaining swal modals is easy.' : '',
                inputValue: values[currentStep],
                showCancelButton: currentStep > 0,
                currentProgressStep: currentStep,
            customClass: 'sweet-alerts',
            });
            if (result.value) {
                values[currentStep] = result.value;
                currentStep++;
            } else if (result.dismiss === Swal.DismissReason.cancel) {
                currentStep--;
            } else {
                break;
            }
        }
        if (currentStep === steps.length) {
            window.Swal.fire({
                title: 'All done!',
                padding: '2em',
                html: 'Your answers: <pre>' + JSON.stringify(values) + '</pre>',
                confirmButtonText: 'Lovely!',
            customClass: 'sweet-alerts',
            });
        }
    } else if (type === 6) {
        new window.Swal({
            title: 'Custom animation with Animate.css',
            animation: false,
            showClass: {
                popup: 'animate__animated animate__flip'
            },
            hideClass: {
                popup: 'animate__animated animate__fadeOutUp'
            },
            padding: '2em',
            customClass: 'sweet-alerts',
        });
    }
</script>
                
            Custom animation
Code
<!-- success message -->
<button type="button" class="btn btn-info" @click="showAlert()">Custom animation</button>
<!-- script -->
<script>
    async function showAlert() {
        new window.Swal({
            title: 'Custom animation with Animate.css',
            animation: false,
            showClass: {
                popup: 'animate__animated animate__flip'
            },
            hideClass: {
                popup: 'animate__animated animate__fadeOutUp'
            },
            padding: '2em',
            customClass: 'sweet-alerts',
        });
    }
</script>
                
            Message with auto close timer
Code
<!-- success message -->
<button type="button" class="btn btn-primary" @click="showAlert()">Message timer</button>
<!-- script -->
<script>
    async function showAlert() {
        let timerInterval;
        new window.Swal({
            title: 'Auto close alert!',
            html: 'I will close in <b></b> milliseconds.',
            timer: 2000,
            timerProgressBar: true,
            customClass: 'sweet-alerts',
            didOpen: () => {
                window.Swal.showLoading();
                const b = window.Swal.getHtmlContainer().querySelector('b');
                timerInterval = setInterval(() => {
                    b.textContent = window.Swal.getTimerLeft();
                }, 100);
            },
            willClose: () => {
                clearInterval(timerInterval);
            },
        }).then((result) => {
            if (result.dismiss === window.Swal.DismissReason.timer) {
                console.log('I was closed by the timer');
            }
        });
    }
</script>
                
            Message with custom image
Code
<!-- success message -->
<button type="button" class="btn btn-secondary" @click="showAlert()">Message with custom image</button>
<!-- script -->
<script>
    async function showAlert() {
        new window.Swal({
            title: 'Sweet!',
            text: 'Modal with a custom image.',
            imageUrl: ('/assets/images/thumbs-up.jpg'),
            imageWidth: 224,
            imageHeight: 200,
            imageAlt: 'Custom image',
            animation: false,
            padding: '2em',
            customClass: 'sweet-alerts',
        });
    }
</script>
                
            Custom HTML description and buttons
Code
<!-- success message -->
<button type="button" class="btn btn-danger" @click="showAlert()">Custom Description & buttons</button>
<!-- script -->
<script>
    async function showAlert() {
        new window.Swal({
            icon: 'info',
            title: '<i>HTML</i> <u>example</u>',
            html: 'You can use <b>bold text</b>, ' + '<a href="//github.com">links</a> ' + 'and other HTML tags',
            showCloseButton: true,
            showCancelButton: true,
            focusConfirm: false,
            confirmButtonText: '<i class="flaticon-checked-1"></i> Great!',
            confirmButtonAriaLabel: 'Thumbs up, great!',
            cancelButtonText: '<i class="flaticon-cancel-circle"></i> Cancel',
            cancelButtonAriaLabel: 'Thumbs down',
            padding: '2em',
            customClass: 'sweet-alerts',
        });
    }
</script>
                
            Warning message, with "Confirm" button
Code
<!-- success message -->
<button type="button" class="btn btn-success" @click="showAlert()">Confirm</button>
<!-- script -->
<script>
    async function showAlert() {
        new window.Swal({
            icon: 'warning',
            title: 'Are you sure?',
            text: "You won't be able to revert this!",
            showCancelButton: true,
            confirmButtonText: 'Delete',
            padding: '2em',
            customClass: 'sweet-alerts',
        }).then((result) => {
            if (result.value) {
                new window.Swal({title: 'Deleted!', text: 'Your file has been deleted.',i con: 'success',  customClass: 'sweet-alerts'  });
            }
        });
    }
</script>
                
            Execute something else for "Cancel".
Code
<!-- success message -->
<button type="button" class="btn btn-warning" @click="showAlert()">Addition else for "Cancel".</button>
<!-- script -->
<script>
    async function showAlert() {
        const swalWithBootstrapButtons = window.Swal.mixin({
            customClass: {
                popup: 'sweet-alerts',
                confirmButton: 'btn btn-secondary',
                cancelButton: 'btn btn-dark ltr:mr-3 rtl:ml-3',
            },
            buttonsStyling: false,
        });
        swalWithBootstrapButtons
        .fire({
            title: 'Are you sure?',
            text: "You won't be able to revert this!",
            icon: 'warning',
            showCancelButton: true,
            confirmButtonText: 'Yes, delete it!',
            cancelButtonText: 'No, cancel!',
            reverseButtons: true,
            padding: '2em',
        })
        .then((result) => {
            if (result.value) {
                swalWithBootstrapButtons.fire('Deleted!', 'Your file has been deleted.', 'success');
            } else if (result.dismiss === window.Swal.DismissReason.cancel) {
                swalWithBootstrapButtons.fire('Cancelled', 'Your imaginary file is safe :)', 'error');
            }
        });
    }
</script>
                
            A message with custom width, padding and background
Code
<!-- success message -->
<button type="button" class="btn btn-info" @click="showAlert()">Custom Message</button>
<!-- script -->
<script>
    async function showAlert() {
        new window.Swal({
            title: 'Custom width, padding, background.',
            width: 600,
            padding: '7em',
            customClass: 'background-modal sweet-alerts',
            background: '#fff url(' + ('/assets/images/sweet-bg.jpg') + ') no-repeat 100% 100%',
        });
    }
</script>
                
            With Footer
Code
<!-- success message -->
<button type="button" class="btn btn-dark" @click="showAlert()">With Footer</button>
<!-- script -->
<script>
    async function showAlert() {
        new window.Swal({
            icon: 'error',
            title: 'Oops...',
            text: 'Something went wrong!',
            footer: '<a href="javascript:;">Why do I have this issue?</a>',
            padding: '2em',
            customClass: 'sweet-alerts',
        });
    }
</script>
                
            RTL support
Code
<!-- success message -->
<button type="button" class="btn btn-primary" @click="showAlert()">RTL</button>
<!-- script -->
<script>
    async function showAlert() {
        new window.Swal({
            title: 'هل تريد الاستمرار؟',
            confirmButtonText: 'نعم',
            cancelButtonText: 'لا',
            showCancelButton: true,
            showCloseButton: true,
            padding: '2em',
            customClass: 'sweet-alerts',
        });
    }
</script>
                
            Mixin
Code
<!-- success message -->
<button type="button" class="btn btn-secondary" @click="showAlert()">Mixin</button>
<!-- script -->
<script>
    async function showAlert() {
        const toast = window.Swal.mixin({
            toast: true,
            position: 'top-end',
            showConfirmButton: false,
            timer: 3000,
            padding: '2em',
            customClass: 'sweet-alerts',
        });
        toast.fire({
            icon: 'success',
            title: 'Signed in successfully',
            padding: '2em',
            customClass: 'sweet-alerts',
        });
    }
</script>
                
            © . Vristo All rights reserved.