google_forms/application/views/edit_form_view.php

362 lines
15 KiB
PHP
Raw Normal View History

2024-07-19 10:46:18 +00:00
<!DOCTYPE html>
<html lang="en">
2024-07-24 13:12:00 +00:00
2024-07-19 10:46:18 +00:00
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Edit Form</title>
2024-07-23 12:54:27 +00:00
<link rel="stylesheet" href="https://bootswatch.com/3/flatly/bootstrap.min.css">
2024-07-19 10:46:18 +00:00
<link rel="stylesheet" href="<?php echo base_url(); ?>assets/css/styles.css">
2024-07-23 12:54:27 +00:00
<link rel="stylesheet" href="<?php echo base_url(); ?>assets/css/header_new.css">
2024-07-19 10:46:18 +00:00
<link rel="stylesheet" href="<?php echo base_url(); ?>assets/css/jquery-ui.css">
2024-07-23 12:54:27 +00:00
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.3/css/all.min.css">
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
<script src="https://cdn.datatables.net/1.11.5/js/jquery.dataTables.min.js"></script>
2024-07-25 12:54:05 +00:00
<!-- Add SweetAlert CSS and JS -->
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/sweetalert2@11/dist/sweetalert2.min.css">
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
2024-07-19 10:46:18 +00:00
</head>
2024-07-24 13:12:00 +00:00
2024-07-19 10:46:18 +00:00
<body>
2024-07-25 12:54:05 +00:00
<style>
.form-header {
display: flex;
flex-direction: column;
margin-bottom: 20px;
}
.form-title,
.form-description {
border: none;
border-bottom: 1px solid #ccc;
margin-bottom: 10px;
padding-left: 0;
padding-right: 0;
width: 100%;
}
.form-title:focus,
.form-description:focus {
box-shadow: none;
outline: none;
border-bottom: 1px solid #007bff;
}
</style>
2024-07-23 12:54:27 +00:00
<!-- Navbar -->
<nav class="navbar navbar-custom">
2024-07-24 13:12:00 +00:00
<div class="container">
<?php if ($this->session->userdata('logged_in')): ?>
<div class="navbar-header">
<a class="navbar-brand" href="<?php echo base_url(); ?>">Google Forms</a>
2024-07-23 12:54:27 +00:00
</div>
2024-07-24 13:12:00 +00:00
<?php endif; ?>
<div id="navbar" class="navbar-collapse">
<ul class="nav navbar-nav">
<?php if ($this->session->userdata('logged_in')): ?>
<li><a href="<?php echo base_url(); ?>published_forms">Published Forms</a></li>
<li><a href="<?php echo base_url(); ?>drafts">Drafts</a></li>
<?php endif; ?>
</ul>
<ul class="nav navbar-nav navbar-right">
<?php if (!$this->session->userdata('logged_in')): ?>
<li><a href="<?php echo base_url(); ?>users/login">Login</a></li>
<li><a href="<?php echo base_url(); ?>users/register">Register</a></li>
<?php endif; ?>
<?php if ($this->session->userdata('logged_in')): ?>
<li><a href="<?php echo base_url(); ?>homepage/title">Create Form</a></li>
<li><a href="<?php echo base_url(); ?>users/logout">Logout</a></li>
<?php endif; ?>
</ul>
2024-07-23 12:54:27 +00:00
</div>
2024-07-24 13:12:00 +00:00
</div>
</nav>
2024-07-23 12:54:27 +00:00
<!-- Alert Messages -->
<div class="container">
<?php if ($this->session->flashdata('user_registered')): ?>
<p class="alert alert-success"><?php echo $this->session->flashdata('user_registered'); ?></p>
<?php endif; ?>
<?php if ($this->session->flashdata('login_failed')): ?>
<p class="alert alert-danger"><?php echo $this->session->flashdata('login_failed'); ?></p>
<?php endif; ?>
<?php if ($this->session->flashdata('user_loggedin')): ?>
<p class="alert alert-success"><?php echo $this->session->flashdata('user_loggedin'); ?></p>
<?php endif; ?>
<?php if ($this->session->flashdata('user_loggedout')): ?>
<p class="alert alert-success"><?php echo $this->session->flashdata('user_loggedout'); ?></p>
<?php endif; ?>
</div>
<!-- Form Editor -->
2024-07-19 10:46:18 +00:00
<div class="container">
<div class="form-header">
2024-07-24 13:12:00 +00:00
<!-- <button id="preview-btn" class="btn btn-info"><i class="fas fa-eye"></i></button> -->
2024-07-25 12:54:05 +00:00
<input type="text" id="form-title" class="form-control form-title" value="<?php echo $form['title']; ?>">
<input type="text" id="form-description" class="form-control form-description" value="<?php echo $form['description']; ?>">
2024-07-19 10:46:18 +00:00
<button id="add-section-btn" class="btn btn-primary">+</button>
</div>
<div id="form-container">
2024-07-22 09:49:37 +00:00
<?php foreach ($questions as $question): ?>
2024-07-24 13:12:00 +00:00
<div class="form-section" data-index="<?php echo $question['id']; ?>"
data-type="<?php echo $question['type']; ?>">
2024-07-22 09:49:37 +00:00
<div class="header-row">
2024-07-24 13:12:00 +00:00
<input type="text" class="form-control untitled-question" placeholder="Untitled Question" rows="1"
value="<?php echo $question['text']; ?>">
2024-07-22 09:49:37 +00:00
<select class="custom-select">
2024-07-24 13:12:00 +00:00
<option value="short-answer" <?php echo $question['type'] == 'short-answer' ? 'selected' : ''; ?>>
Short Answer</option>
<option value="paragraph" <?php echo $question['type'] == 'paragraph' ? 'selected' : ''; ?>>
Paragraph</option>
2024-07-22 09:49:37 +00:00
<option value="multiple-choice" <?php echo $question['type'] == 'multiple-choice' ? 'selected' : ''; ?>>Multiple Choice</option>
2024-07-24 13:12:00 +00:00
<option value="checkboxes" <?php echo $question['type'] == 'checkboxes' ? 'selected' : ''; ?>>
Checkboxes</option>
<option value="dropdown" <?php echo $question['type'] == 'dropdown' ? 'selected' : ''; ?>>Dropdown
</option>
2024-07-22 09:49:37 +00:00
</select>
<label class="toggle-switch">
<input type="checkbox" class="required-toggle" <?php echo $question['is_required'] ? 'checked' : ''; ?>>
<span class="slider"></span>
</label>
<span class="delete-section-icon"><i class="fas fa-trash-alt"></i></span>
</div>
<div class="options-container">
<?php
// Fetch options for this question only
$this->db->where('question_id', $question['id']);
$options = $this->db->get('options')->result_array();
foreach ($options as $option):
2024-07-24 13:12:00 +00:00
?>
2024-07-22 09:49:37 +00:00
<div class="option">
2024-07-24 13:12:00 +00:00
<input type="text" class="form-control option-label"
value="<?php echo $option['option_text']; ?>">
2024-07-22 09:49:37 +00:00
<span class="delete-option-icon">&times;</span>
</div>
<?php endforeach; ?>
</div>
<!-- Show or hide the "Add Option" button based on question type -->
<?php if ($question['type'] === 'multiple-choice' || $question['type'] === 'checkboxes' || $question['type'] === 'dropdown'): ?>
2024-07-24 13:12:00 +00:00
<button class="btn btn-primary add-option-btn">Add Option</button>
2024-07-22 09:49:37 +00:00
<?php endif; ?>
2024-07-19 10:46:18 +00:00
</div>
<?php endforeach; ?>
</div>
2024-07-23 12:54:27 +00:00
<button id="submit-btn" class="btn btn-success btn-custom">Submit</button>
2024-07-19 10:46:18 +00:00
</div>
2024-07-23 12:54:27 +00:00
2024-07-19 10:46:18 +00:00
<script src="<?php echo base_url('assets/js/jquery.min.js'); ?>"></script>
<script src="<?php echo base_url('assets/js/bootstrap.min.js'); ?>"></script>
<script src="<?php echo base_url('assets/js/jquery-ui.js'); ?>"></script>
2024-07-22 09:49:37 +00:00
<!-- <script src="<?php echo base_url('assets/js/scripts.js'); ?>"></script> -->
2024-07-19 10:46:18 +00:00
<script>
2024-07-24 13:12:00 +00:00
$(document).ready(function () {
var base_url = '<?php echo base_url(); ?>';
var index = 1;
var activeSection = null;
function positionAddSectionButton() {
if (activeSection) {
var position = activeSection.position();
var buttonWidth = $('#add-section-btn').outerWidth();
var buttonHeight = $('#add-section-btn').outerHeight();
$('#add-section-btn').css({
position: 'absolute',
left: position.left - buttonWidth - 47 + 'px',
top: position.top + activeSection.height() / 2 - buttonHeight / 2 + 'px'
});
}
}
// Add section button functionality
$('#add-section-btn').on('click', function () {
createFormSection();
$('.form-section').removeClass('active');
activeSection = $('.form-section').last();
activeSection.addClass('active');
positionAddSectionButton();
2024-07-23 12:54:27 +00:00
});
2024-07-24 13:12:00 +00:00
function createFormSection() {
var sectionHtml = `
2024-07-25 12:54:05 +00:00
<div class="form-section" data-type="">
<div class="header-row">
<input type="text" class="form-control untitled-question" placeholder="Untitled Question" rows="1">
<select class="custom-select">
<option value="short-answer">Short Answer</option>
<option value="paragraph">Paragraph</option>
<option value="multiple-choice">Multiple Choice</option>
<option value="checkboxes">Checkboxes</option>
<option value="dropdown">Dropdown</option>
</select>
<label class="toggle-switch">
<input type="checkbox" class="required-toggle">
<span class="slider"></span>
</label>
<span class="delete-section-icon"><i class="fas fa-trash-alt"></i></span>
</div>
<div class="options-container"></div>
<button class="btn btn-primary add-option-btn">Add Option</button>
2024-07-19 10:46:18 +00:00
</div>
2024-07-25 12:54:05 +00:00
`;
2024-07-24 13:12:00 +00:00
$('#form-container').append(sectionHtml);
2024-07-25 12:54:05 +00:00
// Add click event for the newly created section
$('.form-section').last().on('click', function () {
$('.form-section').removeClass('active');
$(this).addClass('active');
activeSection = $(this);
positionAddSectionButton();
});
positionAddSectionButton();
2024-07-24 13:12:00 +00:00
}
2024-07-19 10:46:18 +00:00
2024-07-24 13:12:00 +00:00
// Handle option button click
$(document).on('click', '.add-option-btn', function () {
var $section = $(this).closest('.form-section');
var optionHtml = `
2024-07-25 12:54:05 +00:00
<div class="option">
<input type="text" class="form-control option-label" value="">
<span class="delete-option-icon">&times;</span>
</div>
`;
2024-07-24 13:12:00 +00:00
$section.find('.options-container').append(optionHtml);
});
// Handle delete section button click
$(document).on('click', '.delete-section-icon', function () {
$(this).closest('.form-section').remove();
2024-07-25 12:54:05 +00:00
activeSection = null;
positionAddSectionButton();
2024-07-24 13:12:00 +00:00
});
// Handle delete option button click
$(document).on('click', '.delete-option-icon', function () {
$(this).closest('.option').remove();
});
2024-07-25 12:54:05 +00:00
$('.form-section').each(function () {
2024-07-24 13:12:00 +00:00
$(this).on('click', function () {
$('.form-section').removeClass('active');
$(this).addClass('active');
activeSection = $(this);
positionAddSectionButton();
});
});
// Handle window resize to reposition button
$(window).on('resize', function () {
positionAddSectionButton();
});
2024-07-25 12:54:05 +00:00
$(document).ready(function () {
var base_url = '<?php echo base_url(); ?>';
$('#submit-btn').on('click', function () {
var formData = collectFormData();
formData['form_id'] = <?php echo $form['id']; ?>;
let validation = validateFormData(formData);
if (!validation.isValid) {
alert(validation.message);
return;
}
$.ajax({
url: base_url + 'Form_controller/update_form',
type: 'POST',
data: { formData: formData },
dataType: 'JSON',
success: function (response) {
if (response.status === 'success') {
Swal.fire({
title: 'Success!',
text: 'Form updated successfully!',
icon: 'success',
confirmButtonText: 'OK'
}).then((result) => {
if (result.isConfirmed) {
2024-07-24 13:12:00 +00:00
window.location.href = base_url + 'drafts';
}
2024-07-25 12:54:05 +00:00
});
} else {
Swal.fire({
title: 'Error!',
text: response.message,
icon: 'error',
confirmButtonText: 'OK'
});
}
},
error: function (error) {
Swal.fire({
title: 'Error!',
text: 'Error updating form!',
icon: 'error',
confirmButtonText: 'OK'
2024-07-24 13:12:00 +00:00
});
2024-07-25 12:54:05 +00:00
console.log(error);
}
});
});
// Collect form data function
function collectFormData() {
var formData = {
title: $('#form-title').val(),
description: $('#form-description').val(),
questions: []
};
$('.form-section').each(function () {
var questionData = {
id: $(this).data('index'),
text: $(this).find('.untitled-question').val(),
type: $(this).find('.custom-select').val(),
required: $(this).find('.required-toggle').is(':checked') ? 1 : 0,
options: []
};
$(this).find('.option-label').each(function () {
questionData.options.push($(this).val());
2024-07-19 10:46:18 +00:00
});
2024-07-25 12:54:05 +00:00
formData.questions.push(questionData);
});
2024-07-24 13:12:00 +00:00
2024-07-25 12:54:05 +00:00
return formData;
}
2024-07-24 13:12:00 +00:00
2024-07-25 12:54:05 +00:00
function validateFormData(formData) {
for (let question of formData.questions) {
if (!question.text.trim()) {
return { isValid: false, message: 'All questions must have text.' };
2024-07-22 09:49:37 +00:00
}
2024-07-25 12:54:05 +00:00
if ((question.type === 'multiple-choice' || question.type === 'checkboxes' || question.type === 'dropdown') && question.options.length === 0) {
return { isValid: false, message: 'All options-based questions must have at least one option.' };
}
for (let option of question.options) {
if (!option.trim()) {
return { isValid: false, message: 'All options must have text.' };
2024-07-22 09:49:37 +00:00
}
}
2024-07-25 12:54:05 +00:00
}
return { isValid: true };
}
});
2024-07-23 12:54:27 +00:00
2024-07-24 13:12:00 +00:00
// Initialize
});
2024-07-19 10:46:18 +00:00
</script>
</body>
2024-07-24 13:12:00 +00:00
</html>