Check in voting advice app in new repo
150
admin/add-candidate.php
Normal file
|
@ -0,0 +1,150 @@
|
|||
<?php
|
||||
include('../config/config.php');
|
||||
include(ADMIN_HTML.'html.inc.php');
|
||||
include(ADMIN_INCLUDES.'functions.php');
|
||||
checkLoginAdmin();
|
||||
|
||||
if ( isset($_POST['submit']) )
|
||||
{
|
||||
$fileName = time().str_replace(' ', '_', $_FILES['partyImage']['name']); // replace the space with '_'
|
||||
move_uploaded_file($_FILES['partyImage']['tmp_name'],UPLOADS_PATH.'partylogo/'.$fileName);
|
||||
|
||||
// Generate Images thunmnails
|
||||
generate_image_thumbnail(UPLOADS_PATH.'partylogo/'.$fileName, UPLOADS_PATH.'partylogo/thumbs/thumb_'.$fileName,80,60);
|
||||
|
||||
$insQry = "INSERT INTO tbl_candidate
|
||||
SET
|
||||
Name = '".clean($_POST['candi_title'])."',
|
||||
Description = '".clean($_POST['candiDes'])."',
|
||||
Party = '".clean($_POST['party_title'])."',
|
||||
Logo = '".$fileName."'";
|
||||
|
||||
mysql_query($insQry);
|
||||
|
||||
$redirectUrl = 'view-candidates.php';
|
||||
$_SESSION['succesMessage'] = 4;
|
||||
header("Location: $redirectUrl");
|
||||
}
|
||||
|
||||
startHtml($title = "Add Candidate");
|
||||
tophead($title);
|
||||
leftNav();
|
||||
|
||||
?>
|
||||
|
||||
<script type="text/javascript">
|
||||
tinyMCE.init({
|
||||
mode : "textareas",
|
||||
theme : "simple",
|
||||
// update validation status on change
|
||||
onchange_callback: function(editor) {
|
||||
tinyMCE.triggerSave();
|
||||
$("#" + editor.id).valid();
|
||||
}
|
||||
});
|
||||
|
||||
jQuery.validator.addMethod("imageExt", function(value, element) {
|
||||
return this.optional(element) || /^.*\.(jpg|jpeg|gif|JPG|png|PNG)$/.test(value);
|
||||
}, ("Only [jpeg, gif, JPG, PNG] formats are allowed."));
|
||||
|
||||
// Form validation
|
||||
$(function() {
|
||||
var validator = $("#addCandiForm").submit(function() {
|
||||
// update underlying textarea before submit validation
|
||||
tinyMCE.triggerSave();
|
||||
}).validate({
|
||||
ignore: "",
|
||||
rules: {
|
||||
candi_title: "required",
|
||||
candiDes: "required",
|
||||
party_title: "required",
|
||||
partyImage: {
|
||||
required: true,
|
||||
imageExt: true
|
||||
}
|
||||
},
|
||||
messages: {
|
||||
candi_title: "Enter candidate name.",
|
||||
candiDes: "Enter candidate description.",
|
||||
party_title: "Enter party name",
|
||||
partyImage: {
|
||||
required: 'Select Party image.'
|
||||
}
|
||||
|
||||
},
|
||||
errorPlacement: function(label, element) {
|
||||
// position error label after generated textarea
|
||||
if (element.is("textarea")) {
|
||||
label.insertAfter(element.next());
|
||||
} else {
|
||||
label.insertAfter(element)
|
||||
}
|
||||
}
|
||||
});
|
||||
validator.focusInvalid = function() {
|
||||
// put focus on tinymce on submit validation
|
||||
if( this.settings.focusInvalid ) {
|
||||
try {
|
||||
var toFocus = $(this.findLastActive() || this.errorList.length && this.errorList[0].element || []);
|
||||
if (toFocus.is("textarea")) {
|
||||
tinyMCE.get(toFocus.attr("id")).focus();
|
||||
} else {
|
||||
toFocus.filter(":visible").focus();
|
||||
}
|
||||
} catch(e) {
|
||||
// ignore IE throwing errors when focusing hidden elements
|
||||
}
|
||||
}
|
||||
}
|
||||
});
|
||||
</script>
|
||||
|
||||
<section id="main" class="column">
|
||||
<article class="module width_full">
|
||||
<header>
|
||||
<h3>Add Candidate</h3>
|
||||
</header>
|
||||
<form name="addCandiForm" id="addCandiForm" action="" method="post" enctype="multipart/form-data">
|
||||
<fieldset style="margin:15px">
|
||||
<table width="100%">
|
||||
<tr>
|
||||
<td>
|
||||
<label>Candidate Name</label>
|
||||
<input type="text" name="candi_title" id="candi_title" />
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>
|
||||
<label>Candidate Party</label>
|
||||
<input type="text" name="party_title" id="party_title" />
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>
|
||||
<label>Description</label>
|
||||
<span class="tinyMCE"><textarea id="candiDes" name="candiDes" rows="15" cols="80" style="width: 99%;float:left;"></textarea></span>
|
||||
<label for="candiDes" class="error" style="display:none;">Enter description.</label>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>
|
||||
<label>Party Logo</label>
|
||||
<input type="file" name="partyImage" id="partyImage" />
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>
|
||||
<input type="submit" name="submit" id="submit" value="Add Record" />
|
||||
<input type="button" name="cancel" id="cancel" value="Cancel" onclick="window.location='<?php echo ADMIN_URL;?>view-candidates.php'" />
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
</fieldset>
|
||||
</form>
|
||||
</article>
|
||||
<div class="spacer"></div>
|
||||
</section>
|
||||
|
||||
<?php
|
||||
endHtml();
|
||||
?>
|
114
admin/add-question.php
Normal file
|
@ -0,0 +1,114 @@
|
|||
<?php
|
||||
include('../config/config.php');
|
||||
include(ADMIN_HTML.'html.inc.php');
|
||||
include(ADMIN_INCLUDES.'functions.php');
|
||||
checkLoginAdmin();
|
||||
|
||||
if ( isset($_POST['submit']) )
|
||||
{
|
||||
if ( !empty($_POST['question']) )
|
||||
{
|
||||
$insQry = "INSERT INTO tbl_questions
|
||||
SET
|
||||
Heading = '".clean($_POST['title'])."',
|
||||
Question = '".clean($_POST['question'])."'";
|
||||
mysql_query($insQry);
|
||||
}
|
||||
$redirectUrl = 'view-questions.php';
|
||||
$_SESSION['succesMessage'] = 4;
|
||||
header("Location: $redirectUrl");
|
||||
}
|
||||
|
||||
startHtml($title = "Add Question");
|
||||
tophead($title);
|
||||
leftNav();
|
||||
?>
|
||||
|
||||
<script type="text/javascript">
|
||||
tinyMCE.init({
|
||||
mode : "textareas",
|
||||
theme : "simple",
|
||||
// update validation status on change
|
||||
onchange_callback: function(editor) {
|
||||
tinyMCE.triggerSave();
|
||||
$("#" + editor.id).valid();
|
||||
}
|
||||
});
|
||||
$(function() {
|
||||
var validator = $("#addQuestForm").submit(function() {
|
||||
// update underlying textarea before submit validation
|
||||
tinyMCE.triggerSave();
|
||||
}).validate({
|
||||
ignore: "",
|
||||
rules: {
|
||||
title: "required",
|
||||
question: "required"
|
||||
},
|
||||
messages: {
|
||||
title: "Enter question title.",
|
||||
question: "Enter question."
|
||||
},
|
||||
errorPlacement: function(label, element) {
|
||||
// position error label after generated textarea
|
||||
if (element.is("textarea")) {
|
||||
label.insertAfter(element.next());
|
||||
} else {
|
||||
label.insertAfter(element)
|
||||
}
|
||||
}
|
||||
});
|
||||
validator.focusInvalid = function() {
|
||||
// put focus on tinymce on submit validation
|
||||
if( this.settings.focusInvalid ) {
|
||||
try {
|
||||
var toFocus = $(this.findLastActive() || this.errorList.length && this.errorList[0].element || []);
|
||||
if (toFocus.is("textarea")) {
|
||||
tinyMCE.get(toFocus.attr("id")).focus();
|
||||
} else {
|
||||
toFocus.filter(":visible").focus();
|
||||
}
|
||||
} catch(e) {
|
||||
// ignore IE throwing errors when focusing hidden elements
|
||||
}
|
||||
}
|
||||
}
|
||||
});
|
||||
</script>
|
||||
|
||||
<section id="main" class="column">
|
||||
<article class="module width_full">
|
||||
<header>
|
||||
<h3>Add Question</h3>
|
||||
</header>
|
||||
<form name="addQuestForm" id="addQuestForm" action="" method="post">
|
||||
<fieldset style="margin:15px">
|
||||
<table width="100%">
|
||||
<tr>
|
||||
<td>
|
||||
<label>Title</label>
|
||||
<input type="text" name="title" id="title" />
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>
|
||||
<label>Question</label>
|
||||
<span class="tinyMCE"><textarea id="question" name="question" rows="15" cols="80" style="width: 99%;float:left;"></textarea></span>
|
||||
<label for="question" class="error" style="display:none;">Enter Question Description</label>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>
|
||||
<input type="submit" name="submit" id="submit" value="Add Record" />
|
||||
<input type="button" name="cancel" id="cancel" value="Cancel" onclick="window.location='<?php echo ADMIN_URL;?>view-questions.php'" />
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
</fieldset>
|
||||
</form>
|
||||
</article>
|
||||
<div class="spacer"></div>
|
||||
</section>
|
||||
|
||||
<?php
|
||||
endHtml();
|
||||
?>
|
191
admin/add-response.php
Normal file
|
@ -0,0 +1,191 @@
|
|||
<?php
|
||||
include('../config/config.php');
|
||||
include(ADMIN_HTML.'html.inc.php');
|
||||
include(ADMIN_INCLUDES.'functions.php');
|
||||
checkLoginAdmin();
|
||||
|
||||
if ( isset($_POST['submit']) )
|
||||
{
|
||||
if ( !empty($_POST['question']) )
|
||||
{
|
||||
for($i=0;$i<sizeof($_POST['question']);$i++)
|
||||
{
|
||||
$insQry = "INSERT INTO tbl_party_response
|
||||
SET
|
||||
CandidateId='".clean($_POST['candidate'])."',
|
||||
QuestionId = '".clean($_POST['question'][$i])."',
|
||||
Answer = '".clean($_POST['answer'][$i])."'";
|
||||
mysql_query($insQry);
|
||||
}
|
||||
|
||||
$checkBox=array();
|
||||
$checkBox=$_POST['check'];
|
||||
foreach($checkBox as $key=>$box)
|
||||
{
|
||||
$insQry = "UPDATE tbl_party_response
|
||||
SET
|
||||
PriorityBit='1'
|
||||
WHERE tbl_party_response.CandidateId='".$_POST['candidate']."' AND tbl_party_response.QuestionId='$key'";
|
||||
|
||||
mysql_query($insQry);
|
||||
}
|
||||
|
||||
}
|
||||
$redirectUrl = 'index.php';
|
||||
$_SESSION['succesMessage'] = 4;
|
||||
header("Location: $redirectUrl");
|
||||
}
|
||||
|
||||
startHtml($title = "Add Question Response");
|
||||
tophead($title);
|
||||
leftNav();
|
||||
?>
|
||||
|
||||
<script type="text/javascript">
|
||||
tinyMCE.init({
|
||||
mode : "textareas",
|
||||
theme : "simple",
|
||||
// update validation status on change
|
||||
onchange_callback: function(editor) {
|
||||
tinyMCE.triggerSave();
|
||||
$("#" + editor.id).valid();
|
||||
}
|
||||
});
|
||||
$(function() {
|
||||
var validator = $("#addQuestForm").submit(function() {
|
||||
// update underlying textarea before submit validation
|
||||
tinyMCE.triggerSave();
|
||||
}).validate({
|
||||
ignore: "",
|
||||
rules: {
|
||||
candidate: "required",
|
||||
},
|
||||
messages: {
|
||||
candidate: "Select Candidate",
|
||||
},
|
||||
errorPlacement: function(label, element) {
|
||||
// position error label after generated textarea
|
||||
if (element.is("textarea")) {
|
||||
label.insertAfter(element.next());
|
||||
} else {
|
||||
label.insertAfter(element)
|
||||
}
|
||||
}
|
||||
});
|
||||
validator.focusInvalid = function() {
|
||||
// put focus on tinymce on submit validation
|
||||
if( this.settings.focusInvalid ) {
|
||||
try {
|
||||
var toFocus = $(this.findLastActive() || this.errorList.length && this.errorList[0].element || []);
|
||||
if (toFocus.is("textarea")) {
|
||||
tinyMCE.get(toFocus.attr("id")).focus();
|
||||
} else {
|
||||
toFocus.filter(":visible").focus();
|
||||
}
|
||||
} catch(e) {
|
||||
// ignore IE throwing errors when focusing hidden elements
|
||||
}
|
||||
}
|
||||
}
|
||||
});
|
||||
</script>
|
||||
<style>
|
||||
.radio{
|
||||
cursor:pointer;
|
||||
}
|
||||
</style>
|
||||
|
||||
<section id="main" class="column">
|
||||
<article class="module width_full">
|
||||
<header>
|
||||
<h3>Add Questions Response</h3>
|
||||
</header>
|
||||
<form name="addQuestForm" id="addQuestForm" action="" method="post">
|
||||
<fieldset style="margin:15px">
|
||||
<table width="100%">
|
||||
<tr>
|
||||
<td>
|
||||
<label>Select Candidate</label>
|
||||
<select name="candidate" style="width:30%;">
|
||||
<option value="">-Select-</option>
|
||||
<?php
|
||||
$flag=false;
|
||||
$getRes = mysql_query("SELECT Id, Name FROM tbl_candidate ORDER BY Id DESC");
|
||||
while( $row = mysql_fetch_array($getRes) )
|
||||
{
|
||||
$qry="SELECT COUNT(tbl_party_response.Id) AS ROW FROM tbl_party_response WHERE tbl_party_response.CandidateId='".$row["Id"]."'";
|
||||
$getRemain=mysql_query($qry);
|
||||
$remain = mysql_fetch_array($getRemain);
|
||||
|
||||
if($remain["ROW"]<1)
|
||||
{
|
||||
$flag=true;
|
||||
?>
|
||||
<option value="<?php echo $row["Id"];?>"><?php echo $row["Name"];?></option>
|
||||
<?php
|
||||
}
|
||||
}
|
||||
?>
|
||||
<?php
|
||||
if($flag==false)
|
||||
{
|
||||
?>
|
||||
<option value="">No Candidate Left</option>
|
||||
<?php
|
||||
}
|
||||
?>
|
||||
</select>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>
|
||||
<label>Questions</label>
|
||||
</td>
|
||||
</tr>
|
||||
<tr><td><hr/></td></tr>
|
||||
<?php
|
||||
$getRes = mysql_query("SELECT Id, Heading,Question FROM tbl_questions ORDER BY Id DESC");
|
||||
$i=0;
|
||||
while( $row = mysql_fetch_array($getRes) )
|
||||
{
|
||||
?>
|
||||
<tr>
|
||||
<td>
|
||||
<label class="trigger" style="color:#00F"><?php echo $row['Heading'];?></label>
|
||||
<input type="hidden" name="question[<?php echo $i;?>]" value="<?php echo $row['Id']; ?>"/>
|
||||
<ul class="toggle" style="list-style:none;">
|
||||
<li><?php echo "<br/>".$row['Question'];?></li>
|
||||
</ul>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>
|
||||
<span style="padding-left:10px;">
|
||||
Agree<input type="radio" name="answer[<?php echo $i;?>]" value="A" class="radio" required="required"/>
|
||||
Neutral<input type="radio" name="answer[<?php echo $i;?>]" value="N" class="radio" required="required"/>
|
||||
Disagree<input type="radio" name="answer[<?php echo $i;?>]" value="D" class="radio" required="required"/>
|
||||
Priority<input type="checkbox" name="check[<?php echo $row['Id'];?>]" class="radio"/>
|
||||
</span>
|
||||
</td>
|
||||
</tr>
|
||||
<?php
|
||||
$i++;
|
||||
}
|
||||
?>
|
||||
<tr><td><hr/></td></tr>
|
||||
<tr>
|
||||
<td>
|
||||
<input type="submit" name="submit" id="submit" value="Add Record"/>
|
||||
<input type="button" name="cancel" id="cancel" value="Cancel" onclick="window.location='<?php echo ADMIN_URL;?>view-responses.php'" />
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
</fieldset>
|
||||
</form>
|
||||
</article>
|
||||
<div class="spacer"></div>
|
||||
</section>
|
||||
|
||||
<?php
|
||||
endHtml();
|
||||
?>
|
75
admin/change-password.php
Normal file
|
@ -0,0 +1,75 @@
|
|||
<?php
|
||||
include('../config/config.php');
|
||||
include(ADMIN_HTML.'html.inc.php');
|
||||
include(ADMIN_INCLUDES.'functions.php');
|
||||
checkLoginAdmin();
|
||||
|
||||
if ( isset($_POST['submit']) )
|
||||
{
|
||||
$updateQry = "UPDATE tbl_login
|
||||
SET
|
||||
Password = '".clean($_POST['newPassword'])."'
|
||||
WHERE Id = '".$_SESSION['user_login_id']."'";
|
||||
mysql_query($updateQry);
|
||||
$_SESSION['password'] = clean($_POST['newPassword']);
|
||||
|
||||
$_SESSION['succesMessage'] = 2;
|
||||
header("Location: $redirectUrl");
|
||||
exit;
|
||||
}
|
||||
|
||||
startHtml($title = "Change Password");
|
||||
tophead($title);
|
||||
leftNav();
|
||||
?>
|
||||
<script src="<?php echo ADMIN_JS;?>accounts.js" type="text/javascript"></script>
|
||||
|
||||
<?php
|
||||
if ( isset($_SESSION['succesMessage']) )
|
||||
{
|
||||
successMsg($_SESSION['succesMessage']);
|
||||
unset($_SESSION['succesMessage']);
|
||||
}
|
||||
?>
|
||||
<section id="main" class="column">
|
||||
<article class="module width_half">
|
||||
<header>
|
||||
<h3>Change Password</h3>
|
||||
</header>
|
||||
<form name="changePassForm" id="changePassForm" action="" method="post">
|
||||
<fieldset style="margin:15px">
|
||||
<table width="100%">
|
||||
<tr>
|
||||
<td>
|
||||
<label>Old Password</label>
|
||||
<input type="password" name="oldPassword" id="oldPassword">
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>
|
||||
<label>New Password</label>
|
||||
<input type="password" name="newPassword" id="newPassword">
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>
|
||||
<label>Confirm New Password</label>
|
||||
<input type="password" name="confirmPassword" id="confirmPassword">
|
||||
<input type="hidden" name="oldHidPass" id="oldHidPass" value="<?php echo $_SESSION['password'];?>" />
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>
|
||||
<input type="submit" name="submit" id="submit" value="Change Password" />
|
||||
<input type="button" name="cancel" id="cancel" value="Cancel" onclick="window.location='<?php echo ADMIN_URL;?>'" />
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
</fieldset>
|
||||
</form>
|
||||
</article>
|
||||
<div class="spacer"></div>
|
||||
</section>
|
||||
<?php
|
||||
endHtml();
|
||||
?>
|
551
admin/css/datatable_jui.css
Normal file
|
@ -0,0 +1,551 @@
|
|||
/*
|
||||
* File: demo_table_jui.css
|
||||
* CVS: $Id$
|
||||
* Description: CSS descriptions for DataTables demo pages
|
||||
* Author: Allan Jardine
|
||||
* Created: Tue May 12 06:47:22 BST 2009
|
||||
* Modified: $Date$ by $Author$
|
||||
* Language: CSS
|
||||
* Project: DataTables
|
||||
*
|
||||
* Copyright 2009 Allan Jardine. All Rights Reserved.
|
||||
*
|
||||
* ***************************************************************************
|
||||
* DESCRIPTION
|
||||
*
|
||||
* The styles given here are suitable for the demos that are used with the standard DataTables
|
||||
* distribution (see www.datatables.net). You will most likely wish to modify these styles to
|
||||
* meet the layout requirements of your site.
|
||||
*
|
||||
* Common issues:
|
||||
* 'full_numbers' pagination - I use an extra selector on the body tag to ensure that there is
|
||||
* no conflict between the two pagination types. If you want to use full_numbers pagination
|
||||
* ensure that you either have "example_alt_pagination" as a body class name, or better yet,
|
||||
* modify that selector.
|
||||
* Note that the path used for Images is relative. All images are by default located in
|
||||
* ../images/ - relative to this CSS file.
|
||||
*/
|
||||
|
||||
|
||||
/*
|
||||
* jQuery UI specific styling
|
||||
*/
|
||||
|
||||
.paging_two_button .ui-button {
|
||||
float: left;
|
||||
cursor: pointer;
|
||||
* cursor: hand;
|
||||
}
|
||||
|
||||
.paging_full_numbers .ui-button {
|
||||
padding: 2px 6px;
|
||||
margin: 0;
|
||||
cursor: pointer;
|
||||
* cursor: hand;
|
||||
}
|
||||
|
||||
.dataTables_paginate .ui-button {
|
||||
margin-right: -0.1em !important;
|
||||
}
|
||||
|
||||
.paging_full_numbers {
|
||||
width: 350px !important;
|
||||
}
|
||||
|
||||
.dataTables_wrapper .ui-toolbar {
|
||||
padding: 10px;
|
||||
}
|
||||
.dataTables_wrapper .ui-toolbar input, selectbox{
|
||||
margin:0px 7px;}
|
||||
|
||||
.dataTables_paginate {
|
||||
width: auto;
|
||||
}
|
||||
|
||||
.dataTables_info {
|
||||
padding-top: 3px;
|
||||
}
|
||||
|
||||
table.display thead th {
|
||||
padding: 3px 0px 3px 10px;
|
||||
cursor: pointer;
|
||||
* cursor: hand;
|
||||
}
|
||||
|
||||
div.dataTables_wrapper .ui-widget-header {
|
||||
font-weight: normal;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* Sort arrow icon positioning
|
||||
*/
|
||||
table.display thead th div.DataTables_sort_wrapper {
|
||||
position: relative;
|
||||
padding-right: 20px;
|
||||
padding-right: 20px;
|
||||
}
|
||||
|
||||
table.display thead th div.DataTables_sort_wrapper span {
|
||||
position: absolute;
|
||||
top: 50%;
|
||||
margin-top: -8px;
|
||||
right: 0;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
*
|
||||
* Everything below this line is the same as demo_table.css. This file is
|
||||
* required for 'cleanliness' of the markup
|
||||
*
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
|
||||
|
||||
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* DataTables features
|
||||
*/
|
||||
|
||||
.dataTables_wrapper {
|
||||
position: relative;
|
||||
min-height: 302px;
|
||||
_height: 302px;
|
||||
clear: both;
|
||||
border-top: 1px solid #ddd;
|
||||
}
|
||||
|
||||
.dataTables_processing {
|
||||
position: absolute;
|
||||
top: 0px;
|
||||
left: 50%;
|
||||
width: 250px;
|
||||
margin-left: -125px;
|
||||
border: 1px solid #ddd;
|
||||
text-align: center;
|
||||
color: #999;
|
||||
font-size: 11px;
|
||||
padding: 2px 0;
|
||||
}
|
||||
|
||||
.dataTables_length {
|
||||
width: 40%;
|
||||
float: left;
|
||||
}
|
||||
|
||||
.dataTables_filter {
|
||||
width: 50%;
|
||||
float: right;
|
||||
text-align: right;
|
||||
}
|
||||
|
||||
.dataTables_info {
|
||||
width: 50%;
|
||||
float: left;
|
||||
}
|
||||
|
||||
.dataTables_paginate {
|
||||
float: right;
|
||||
text-align: right;
|
||||
}
|
||||
|
||||
/* Pagination nested */
|
||||
.paginate_disabled_previous, .paginate_enabled_previous, .paginate_disabled_next, .paginate_enabled_next {
|
||||
height: 19px;
|
||||
width: 19px;
|
||||
margin-left: 3px;
|
||||
float: left;
|
||||
}
|
||||
|
||||
.paginate_disabled_previous {
|
||||
background-image: url('../images/back_disabled.jpg');
|
||||
}
|
||||
|
||||
.paginate_enabled_previous {
|
||||
background-image: url('../images/back_enabled.jpg');
|
||||
}
|
||||
|
||||
.paginate_disabled_next {
|
||||
background-image: url('../images/forward_disabled.jpg');
|
||||
}
|
||||
|
||||
.paginate_enabled_next {
|
||||
background-image: url('../images/forward_enabled.jpg');
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* DataTables display
|
||||
*/
|
||||
table.display {
|
||||
margin: 0 auto;
|
||||
width: 100%;
|
||||
clear: both;
|
||||
border-collapse: collapse;
|
||||
}
|
||||
|
||||
table.display tfoot th {
|
||||
padding: 3px 0px 3px 10px;
|
||||
font-weight: bold;
|
||||
font-weight: normal;
|
||||
}
|
||||
|
||||
table.display tr.heading2 td {
|
||||
border-bottom: 1px solid #aaa;
|
||||
}
|
||||
|
||||
table.display td {
|
||||
padding: 8px 10px;
|
||||
font-size:12px;
|
||||
}
|
||||
|
||||
table.display td.center {
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* DataTables sorting
|
||||
*/
|
||||
|
||||
.sorting_asc {
|
||||
background: url('../images/sort_asc.png') no-repeat center right;
|
||||
}
|
||||
|
||||
.sorting_desc {
|
||||
background: url('../images/sort_desc.png') no-repeat center right;
|
||||
}
|
||||
|
||||
.sorting {
|
||||
background: url('../images/sort_both.png') no-repeat center right;
|
||||
}
|
||||
|
||||
.sorting_asc_disabled {
|
||||
background: url('../images/sort_asc_disabled.png') no-repeat center right;
|
||||
}
|
||||
|
||||
.sorting_desc_disabled {
|
||||
background: url('../images/sort_desc_disabled.png') no-repeat center right;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* DataTables row classes
|
||||
*/
|
||||
table.display tr.odd.gradeA {
|
||||
background-color: #F8F8F8;
|
||||
}
|
||||
|
||||
table.display tr.even.gradeA {
|
||||
background-color: #FFFFFF;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
table.display tr.odd.gradeA {
|
||||
background-color: #F8F8F8;
|
||||
}
|
||||
|
||||
table.display tr.even.gradeA {
|
||||
background-color: #FFFFFF;
|
||||
}
|
||||
|
||||
table.display tr.odd.gradeC {
|
||||
background-color: #ddddff;
|
||||
}
|
||||
|
||||
table.display tr.even.gradeC {
|
||||
background-color: #eeeeff;
|
||||
}
|
||||
|
||||
table.display tr.odd.gradeX {
|
||||
background-color: #ffdddd;
|
||||
}
|
||||
|
||||
table.display tr.even.gradeX {
|
||||
background-color: #ffeeee;
|
||||
}
|
||||
|
||||
table.display tr.odd.gradeU {
|
||||
background-color: #ddd;
|
||||
}
|
||||
|
||||
table.display tr.even.gradeU {
|
||||
background-color: #eee;
|
||||
}
|
||||
|
||||
|
||||
tr.odd {
|
||||
background-color: #ECEDF1;
|
||||
}
|
||||
|
||||
tr.even {
|
||||
background-color: white;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* Misc
|
||||
*/
|
||||
.dataTables_scroll {
|
||||
clear: both;
|
||||
}
|
||||
|
||||
.top, .bottom {
|
||||
padding: 15px;
|
||||
background-color: #F5F5F5;
|
||||
border: 1px solid #CCCCCC;
|
||||
}
|
||||
|
||||
.top .dataTables_info {
|
||||
float: none;
|
||||
}
|
||||
|
||||
.clear {
|
||||
clear: both;
|
||||
}
|
||||
|
||||
.dataTables_empty {
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
tfoot input {
|
||||
margin: 0.5em 0;
|
||||
width: 100%;
|
||||
color: #444;
|
||||
}
|
||||
|
||||
tfoot input.search_init {
|
||||
color: #999;
|
||||
}
|
||||
|
||||
td.group {
|
||||
background-color: #d1cfd0;
|
||||
border-bottom: 2px solid #A19B9E;
|
||||
border-top: 2px solid #A19B9E;
|
||||
}
|
||||
|
||||
td.details {
|
||||
background-color: #d1cfd0;
|
||||
border: 2px solid #A19B9E;
|
||||
}
|
||||
|
||||
|
||||
.example_alt_pagination div.dataTables_info {
|
||||
width: 40%;
|
||||
}
|
||||
|
||||
.paging_full_numbers span.paginate_button,
|
||||
.paging_full_numbers span.paginate_active {
|
||||
border: 1px solid #aaa;
|
||||
-webkit-border-radius: 5px;
|
||||
-moz-border-radius: 5px;
|
||||
padding: 2px 5px;
|
||||
margin: 0 3px;
|
||||
cursor: pointer;
|
||||
*cursor: hand;
|
||||
}
|
||||
|
||||
.paging_full_numbers span.paginate_button {
|
||||
background-color: #ddd;
|
||||
}
|
||||
|
||||
.paging_full_numbers span.paginate_button:hover {
|
||||
background-color: #ccc;
|
||||
}
|
||||
|
||||
.paging_full_numbers span.paginate_active {
|
||||
background-color: #99B3FF;
|
||||
}
|
||||
|
||||
table.display tr.even.row_selected td {
|
||||
background-color: #B0BED9;
|
||||
}
|
||||
|
||||
table.display tr.odd.row_selected td {
|
||||
background-color: #9FAFD1;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* Sorting classes for columns
|
||||
*/
|
||||
/* For the standard odd/even */
|
||||
tr.odd td.sorting_1 {
|
||||
background-color: #ECEDF1;
|
||||
}
|
||||
|
||||
tr.odd td.sorting_2 {
|
||||
background-color: #ECEDF1;
|
||||
}
|
||||
|
||||
tr.odd td.sorting_3 {
|
||||
background-color: #ECEDF1;
|
||||
}
|
||||
|
||||
tr.even td.sorting_1 {
|
||||
background-color: #ECEDF1;
|
||||
}
|
||||
|
||||
tr.even td.sorting_2 {
|
||||
background-color: #ECEDF1;
|
||||
}
|
||||
|
||||
tr.even td.sorting_3 {
|
||||
background-color: #ECEDF1;
|
||||
}
|
||||
|
||||
|
||||
/* For the Conditional-CSS grading rows */
|
||||
/*
|
||||
Colour calculations (based off the main row colours)
|
||||
Level 1:
|
||||
dd > c4
|
||||
ee > d5
|
||||
Level 2:
|
||||
dd > d1
|
||||
ee > e2
|
||||
*/
|
||||
tr.odd.gradeA td.sorting_1 {
|
||||
background-color: #F5F5F5;
|
||||
}
|
||||
|
||||
tr.odd.gradeA td.sorting_2 {
|
||||
background-color: #d1ffd1;
|
||||
}
|
||||
|
||||
tr.odd.gradeA td.sorting_3 {
|
||||
background-color: #d1ffd1;
|
||||
}
|
||||
|
||||
tr.even.gradeA td.sorting_1 {
|
||||
background-color: #FBFBFB;
|
||||
}
|
||||
|
||||
tr.even.gradeA td.sorting_2 {
|
||||
background-color: #e2ffe2;
|
||||
}
|
||||
|
||||
tr.even.gradeA td.sorting_3 {
|
||||
background-color: #e2ffe2;
|
||||
}
|
||||
|
||||
tr.odd.gradeC td.sorting_1 {
|
||||
background-color: #c4c4ff;
|
||||
}
|
||||
|
||||
tr.odd.gradeC td.sorting_2 {
|
||||
background-color: #d1d1ff;
|
||||
}
|
||||
|
||||
tr.odd.gradeC td.sorting_3 {
|
||||
background-color: #d1d1ff;
|
||||
}
|
||||
|
||||
tr.even.gradeC td.sorting_1 {
|
||||
background-color: #d5d5ff;
|
||||
}
|
||||
|
||||
tr.even.gradeC td.sorting_2 {
|
||||
background-color: #e2e2ff;
|
||||
}
|
||||
|
||||
tr.even.gradeC td.sorting_3 {
|
||||
background-color: #e2e2ff;
|
||||
}
|
||||
|
||||
tr.odd.gradeX td.sorting_1 {
|
||||
background-color: #ffc4c4;
|
||||
}
|
||||
|
||||
tr.odd.gradeX td.sorting_2 {
|
||||
background-color: #ffd1d1;
|
||||
}
|
||||
|
||||
tr.odd.gradeX td.sorting_3 {
|
||||
background-color: #ffd1d1;
|
||||
}
|
||||
|
||||
tr.even.gradeX td.sorting_1 {
|
||||
background-color: #ffd5d5;
|
||||
}
|
||||
|
||||
tr.even.gradeX td.sorting_2 {
|
||||
background-color: #ffe2e2;
|
||||
}
|
||||
|
||||
tr.even.gradeX td.sorting_3 {
|
||||
background-color: #ffe2e2;
|
||||
}
|
||||
|
||||
tr.odd.gradeU td.sorting_1 {
|
||||
background-color: #c4c4c4;
|
||||
}
|
||||
|
||||
tr.odd.gradeU td.sorting_2 {
|
||||
background-color: #d1d1d1;
|
||||
}
|
||||
|
||||
tr.odd.gradeU td.sorting_3 {
|
||||
background-color: #d1d1d1;
|
||||
}
|
||||
|
||||
tr.even.gradeU td.sorting_1 {
|
||||
background-color: #d5d5d5;
|
||||
}
|
||||
|
||||
tr.even.gradeU td.sorting_2 {
|
||||
background-color: #e2e2e2;
|
||||
}
|
||||
|
||||
tr.even.gradeU td.sorting_3 {
|
||||
background-color: #e2e2e2;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
* Row highlighting example
|
||||
*/
|
||||
.ex_highlight #example tbody tr.even:hover, #example tbody tr.even td.highlighted {
|
||||
background-color: #ECFFB3;
|
||||
}
|
||||
|
||||
.ex_highlight #example tbody tr.odd:hover, #example tbody tr.odd td.highlighted {
|
||||
background-color: #E6FF99;
|
||||
}
|
||||
|
||||
.data-table td{
|
||||
border:1px solid #ccc;}
|
||||
.data-table tbody{
|
||||
color:#555555;
|
||||
border:1px solid #ccc;}
|
||||
.data-table thead{
|
||||
border-top:none;}
|
||||
.dataTables_wrapper .ui-toolbar .ui-state-default {
|
||||
color:#666;
|
||||
border:1px solid #ccc;
|
||||
border-radius:3px;
|
||||
background:#fff;
|
||||
font-weight:bold;
|
||||
padding:3px 8px;
|
||||
box-shadow:0px 1px 1px #EDEDED;
|
||||
margin-left:4px;
|
||||
}
|
||||
|
||||
.dataTables_wrapper .ui-toolbar{
|
||||
border:1px solid #ccc;
|
||||
border-top:none;}
|
||||
#myTable p{
|
||||
margin:0;
|
||||
padding:0;
|
||||
}
|
29
admin/css/ie.css
Normal file
|
@ -0,0 +1,29 @@
|
|||
.quick_search {
|
||||
text-align: center;
|
||||
padding: 14px 0 0px 0;
|
||||
}
|
||||
|
||||
.quick_search input[type=text] {
|
||||
text-align: left;
|
||||
height: 22px;
|
||||
width: 88%;
|
||||
color: #ccc;
|
||||
padding-left: 2%;
|
||||
padding-top: 5px;
|
||||
background: #fff url(../images/icn_search.png) no-repeat;
|
||||
background-position: 10px 6px;
|
||||
}
|
||||
|
||||
.toggleLink {
|
||||
display: inline;
|
||||
float: none;
|
||||
margin-left: 2%
|
||||
}
|
||||
|
||||
html ul.tabs li.active, html ul.tabs li.active a:hover {
|
||||
background: #ccc;
|
||||
}
|
||||
|
||||
input[type=submit].btn_post_message {
|
||||
background: url(../images/post_message.png) no-repeat;
|
||||
}
|
BIN
admin/css/images/Thumbs.db
Normal file
BIN
admin/css/images/datepicker-bg.png
Normal file
After Width: | Height: | Size: 807 B |
BIN
admin/css/images/ui-bg_flat_0_aaaaaa_40x100.png
Normal file
After Width: | Height: | Size: 180 B |
BIN
admin/css/images/ui-bg_flat_75_ffffff_40x100.png
Normal file
After Width: | Height: | Size: 178 B |
BIN
admin/css/images/ui-bg_glass_55_fbf9ee_1x400.png
Normal file
After Width: | Height: | Size: 120 B |
BIN
admin/css/images/ui-bg_glass_65_ffffff_1x400.png
Normal file
After Width: | Height: | Size: 105 B |
BIN
admin/css/images/ui-bg_glass_75_dadada_1x400.png
Normal file
After Width: | Height: | Size: 111 B |
BIN
admin/css/images/ui-bg_glass_75_e6e6e6_1+ù4030.png
Normal file
After Width: | Height: | Size: 110 B |
BIN
admin/css/images/ui-bg_glass_75_e6e6e6_1x400.png
Normal file
After Width: | Height: | Size: 110 B |
BIN
admin/css/images/ui-bg_glass_95_fef1ec_1x400.png
Normal file
After Width: | Height: | Size: 119 B |
BIN
admin/css/images/ui-bg_highlight-soft_75_cccccc_1x100.png
Normal file
After Width: | Height: | Size: 249 B |
BIN
admin/css/images/ui-icons_222222_256x240.png
Normal file
After Width: | Height: | Size: 4.3 KiB |
BIN
admin/css/images/ui-icons_2e83ff_256x240.png
Normal file
After Width: | Height: | Size: 4.3 KiB |
BIN
admin/css/images/ui-icons_454545_256x240.png
Normal file
After Width: | Height: | Size: 4.3 KiB |
BIN
admin/css/images/ui-icons_888888_256x240.png
Normal file
After Width: | Height: | Size: 4.3 KiB |
BIN
admin/css/images/ui-icons_cd0a0a_256x240.png
Normal file
After Width: | Height: | Size: 4.3 KiB |
11
admin/css/jquery-ui.css
vendored
Normal file
|
@ -0,0 +1,11 @@
|
|||
/*
|
||||
* jQuery UI CSS Framework 1.8.17
|
||||
*
|
||||
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI/Theming
|
||||
*/
|
||||
@import "jquery.ui/jquery.ui.base.css";
|
||||
@import "jquery.ui/jquery.ui.theme.css";
|
38
admin/css/jquery.ui.core.css
vendored
Normal file
|
@ -0,0 +1,38 @@
|
|||
/*
|
||||
* jQuery UI CSS Framework 1.8.17
|
||||
*
|
||||
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI/Theming/API
|
||||
*/
|
||||
|
||||
/* Layout helpers
|
||||
----------------------------------*/
|
||||
.ui-helper-hidden { display: none; }
|
||||
.ui-helper-hidden-accessible { position: absolute !important; clip: rect(1px 1px 1px 1px); clip: rect(1px,1px,1px,1px); }
|
||||
.ui-helper-reset { margin: 0; padding: 0; border: 0; outline: 0; line-height: 1.3; text-decoration: none; font-size: 100%; list-style: none; }
|
||||
.ui-helper-clearfix:before, .ui-helper-clearfix:after { content: ""; display: table; }
|
||||
.ui-helper-clearfix:after { clear: both; }
|
||||
.ui-helper-clearfix { zoom: 1; }
|
||||
.ui-helper-zfix { width: 100%; height: 100%; top: 0; left: 0; position: absolute; opacity: 0; filter:Alpha(Opacity=0); }
|
||||
|
||||
|
||||
/* Interaction Cues
|
||||
----------------------------------*/
|
||||
.ui-state-disabled { cursor: default !important; }
|
||||
|
||||
|
||||
/* Icons
|
||||
----------------------------------*/
|
||||
|
||||
/* states and images */
|
||||
.ui-icon { display: block; text-indent: -99999px; overflow: hidden; background-repeat: no-repeat; }
|
||||
|
||||
|
||||
/* Misc visuals
|
||||
----------------------------------*/
|
||||
|
||||
/* Overlays */
|
||||
.ui-widget-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
|
68
admin/css/jquery.ui.datepicker.css
vendored
Normal file
|
@ -0,0 +1,68 @@
|
|||
/*
|
||||
* jQuery UI Datepicker 1.8.17
|
||||
*
|
||||
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI/Datepicker#theming
|
||||
*/
|
||||
.ui-datepicker { width: 17em; padding: .2em .2em 0; display: none;box-shadow:0px 2px 15px 1px #ccc; }
|
||||
.ui-datepicker .ui-datepicker-header { position:relative; padding:.2em 0;background:#ccc; color:#333; border:1px solid #999;}
|
||||
.ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next { position:absolute; top: 2px; width: 1.8em; height: 1.8em; }
|
||||
.ui-datepicker .ui-datepicker-prev-hover, .ui-datepicker .ui-datepicker-next-hover { top: 1px; }
|
||||
.ui-datepicker .ui-datepicker-prev { left:2px; }
|
||||
.ui-datepicker .ui-datepicker-next { right:2px; }
|
||||
.ui-datepicker .ui-datepicker-prev-hover { left:1px; }
|
||||
.ui-datepicker .ui-datepicker-next-hover { right:1px; }
|
||||
.ui-datepicker .ui-datepicker-prev span, .ui-datepicker .ui-datepicker-next span { display: block; position: absolute; left: 50%; margin-left: -8px; top: 50%; margin-top: -8px; }
|
||||
.ui-datepicker .ui-datepicker-title { margin: 0 2.3em; line-height: 1.8em; text-align: center; }
|
||||
.ui-datepicker .ui-datepicker-title select { font-size:1em; margin:1px 0; }
|
||||
.ui-datepicker select.ui-datepicker-month-year {width: 100%;}
|
||||
.ui-datepicker select.ui-datepicker-month,
|
||||
.ui-datepicker select.ui-datepicker-year { width: 49%;}
|
||||
.ui-datepicker table {width: 100%; font-size: .9em; border-collapse: collapse; margin:0 0 .4em; }
|
||||
.ui-datepicker th { padding: .7em .3em; text-align: center; font-weight: bold; border: 0; }
|
||||
.ui-datepicker td { border: 0; padding: 1px; }
|
||||
.ui-datepicker td span, .ui-datepicker td a { display: block; padding: .4em; text-align: right; text-decoration: none; border-radius:8px;}
|
||||
.ui-datepicker .ui-datepicker-buttonpane { background-image: none; margin: .7em 0 0 0; padding:0 .2em; border-left: 0; border-right: 0; border-bottom: 0; }
|
||||
.ui-datepicker .ui-datepicker-buttonpane button { float: right; margin: .5em .2em .4em; cursor: pointer; padding: .2em .6em .3em .6em; width:auto; overflow:visible; }
|
||||
.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { float:left; }
|
||||
|
||||
/* with multiple calendars */
|
||||
.ui-datepicker.ui-datepicker-multi { width:auto; }
|
||||
.ui-datepicker-multi .ui-datepicker-group { float:left; }
|
||||
.ui-datepicker-multi .ui-datepicker-group table { width:95%; margin:0 auto .4em; }
|
||||
.ui-datepicker-multi-2 .ui-datepicker-group { width:50%; }
|
||||
.ui-datepicker-multi-3 .ui-datepicker-group { width:33.3%; }
|
||||
.ui-datepicker-multi-4 .ui-datepicker-group { width:25%; }
|
||||
.ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header { border-left-width:0; }
|
||||
.ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { border-left-width:0; }
|
||||
.ui-datepicker-multi .ui-datepicker-buttonpane { clear:left; }
|
||||
.ui-datepicker-row-break { clear:both; width:100%; font-size:0em; }
|
||||
|
||||
/* RTL support */
|
||||
.ui-datepicker-rtl { direction: rtl; }
|
||||
.ui-datepicker-rtl .ui-datepicker-prev { right: 2px; left: auto; }
|
||||
.ui-datepicker-rtl .ui-datepicker-next { left: 2px; right: auto; }
|
||||
.ui-datepicker-rtl .ui-datepicker-prev:hover { right: 1px; left: auto; }
|
||||
.ui-datepicker-rtl .ui-datepicker-next:hover { left: 1px; right: auto; }
|
||||
.ui-datepicker-rtl .ui-datepicker-buttonpane { clear:right; }
|
||||
.ui-datepicker-rtl .ui-datepicker-buttonpane button { float: left; }
|
||||
.ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current { float:right; }
|
||||
.ui-datepicker-rtl .ui-datepicker-group { float:right; }
|
||||
.ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header { border-right-width:0; border-left-width:1px; }
|
||||
.ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { border-right-width:0; border-left-width:1px; }
|
||||
|
||||
/* IE6 IFRAME FIX (taken from datepicker 1.5.3 */
|
||||
.ui-datepicker-cover {
|
||||
display: none; /*sorry for IE5*/
|
||||
display/**/: block; /*sorry for IE5*/
|
||||
position: absolute; /*must have*/
|
||||
z-index: -1; /*must have*/
|
||||
filter: mask(); /*must have*/
|
||||
top: -4px; /*must have*/
|
||||
left: -4px; /*must have*/
|
||||
width: 200px; /*must have*/
|
||||
height: 200px; /*must have*/
|
||||
}
|
242
admin/css/jquery.ui.theme.css
vendored
Normal file
|
@ -0,0 +1,242 @@
|
|||
/*
|
||||
* jQuery UI CSS Framework 1.8.17
|
||||
*
|
||||
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI/Theming/API
|
||||
*
|
||||
* To view and modify this theme, visit http://jqueryui.com/themeroller/
|
||||
*/
|
||||
|
||||
|
||||
/* Component containers
|
||||
----------------------------------*/
|
||||
.ui-widget { font-family:/*{ffDefault}*/; font-size: 1.1em/*{fsDefault}*/; }
|
||||
.ui-widget .ui-widget { font-size: 1em; }
|
||||
.ui-widget input, .ui-widget select, .ui-widget textarea, .ui-widget button { font-family: Verdana,Arial,sans-serif/*{ffDefault}*/; font-size: 1em; }
|
||||
.ui-widget-content { border: 1px solid #ccc/*{borderColorContent}*/; background: #ffffff/*{bgColorContent}*/ url(images/ui-bg_flat_75_ffffff_40x100.png)/*{bgImgUrlContent}*/ 50%/*{bgContentXPos}*/ 50%/*{bgContentYPos}*/ repeat-x/*{bgContentRepeat}*/; color: #222222/*{fcContent}*/; }
|
||||
.ui-widget-content a { color: #222222/*{fcContent}*/; }
|
||||
.ui-widget-header { border: 1px solid #CBDAE8/*{borderColorHeader}*/; background: #cccccc/*{bgColorHeader}*/ url(images/ui-bg_highlight-soft_75_cccccc_1x100.png)/*{bgImgUrlHeader}*/ 50%/*{bgHeaderXPos}*/ 50%/*{bgHeaderYPos}*/ repeat-x/*{bgHeaderRepeat}*/; color: #222222/*{fcHeader}*/; font-weight: bold; }
|
||||
.ui-widget-header a { color: #222222/*{fcHeader}*/; }
|
||||
|
||||
/* Interaction states
|
||||
----------------------------------*/
|
||||
.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default { border: 1px solid #ccc/*{borderColorDefault}*/; background: #fff/*{bgColorDefault}*/ /*{bgImgUrlDefault}*/ 50%/*{bgDefaultXPos}*/ 50%/*{bgDefaultYPos}*/ repeat-x/*{bgDefaultRepeat}*/; font-weight: bold/*{fwDefault}*/; color: #555555/*{fcDefault}*/; }
|
||||
.ui-state-default a, .ui-state-default a:link, .ui-state-default a:visited { color: #555555/*{fcDefault}*/; text-decoration: none; }
|
||||
.ui-state-hover, .ui-widget-content .ui-state-hover, .ui-widget-header .ui-state-hover, .ui-state-focus, .ui-widget-content .ui-state-focus, .ui-widget-header .ui-state-focus { border: 1px solid #999999/*{borderColorHover}*/; background: #dadada/*{bgColorHover}*/ url(images/ui-bg_glass_75_dadada_1x400.png)/*{bgImgUrlHover}*/ 50%/*{bgHoverXPos}*/ 50%/*{bgHoverYPos}*/ repeat-x/*{bgHoverRepeat}*/; font-weight: normal/*{fwDefault}*/; color: #212121/*{fcHover}*/; }
|
||||
.ui-state-hover a, .ui-state-hover a:hover { color: #212121/*{fcHover}*/; text-decoration: none; }
|
||||
.ui-state-active, .ui-widget-content .ui-state-active, .ui-widget-header .ui-state-active { border: 1px solid #aaaaaa/*{borderColorActive}*/; background: #ffffff/*{bgColorActive}*/ url(images/ui-bg_glass_65_ffffff_1x400.png)/*{bgImgUrlActive}*/ 50%/*{bgActiveXPos}*/ 50%/*{bgActiveYPos}*/ repeat-x/*{bgActiveRepeat}*/; font-weight: normal/*{fwDefault}*/; color: #212121/*{fcActive}*/; }
|
||||
.ui-state-active a, .ui-state-active a:link, .ui-state-active a:visited { color: #212121/*{fcActive}*/; text-decoration: none; }
|
||||
.ui-widget :active { outline: none; }
|
||||
|
||||
/* Interaction Cues
|
||||
----------------------------------*/
|
||||
.ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight {border: 1px solid #999/*{borderColorHighlight}*/; background: #CCCCCC /*{bgColorHighlight}*/ /*{bgImgUrlHighlight}*/ 50%/*{bgHighlightXPos}*/ 50%/*{bgHighlightYPos}*/ repeat-x/*{bgHighlightRepeat}*/; color: #363636/*{fcHighlight}*/; }
|
||||
.ui-state-highlight a, .ui-widget-content .ui-state-highlight a,.ui-widget-header .ui-state-highlight a { color: #363636/*{fcHighlight}*/; }
|
||||
.ui-state-error, .ui-widget-content .ui-state-error, .ui-widget-header .ui-state-error {border: 1px solid red/*{borderColorError}*/; background: #fef1ec/*{bgColorError}*/ url(images/ui-bg_glass_95_fef1ec_1x400.png)/*{bgImgUrlError}*/ 50%/*{bgErrorXPos}*/ 50%/*{bgErrorYPos}*/ repeat-x/*{bgErrorRepeat}*/; color: #cd0a0a/*{fcError}*/; }
|
||||
.ui-state-error a, .ui-widget-content .ui-state-error a, .ui-widget-header .ui-state-error a { color: #cd0a0a/*{fcError}*/; }
|
||||
.ui-state-error-text, .ui-widget-content .ui-state-error-text, .ui-widget-header .ui-state-error-text { color: #cd0a0a/*{fcError}*/; }
|
||||
.ui-priority-primary, .ui-widget-content .ui-priority-primary, .ui-widget-header .ui-priority-primary { font-weight: bold; }
|
||||
.ui-priority-secondary, .ui-widget-content .ui-priority-secondary, .ui-widget-header .ui-priority-secondary { opacity: .7; filter:Alpha(Opacity=70); font-weight: normal; }
|
||||
.ui-state-disabled, .ui-widget-content .ui-state-disabled, .ui-widget-header .ui-state-disabled { opacity: .35; filter:Alpha(Opacity=35); background-image: none; }
|
||||
|
||||
/* Icons
|
||||
----------------------------------*/
|
||||
|
||||
/* states and images */
|
||||
.ui-icon { width: 16px; height: 16px; background-image: url(images/ui-icons_222222_256x240.png)/*{iconsContent}*/; }
|
||||
.ui-widget-content .ui-icon {background-image: url(images/ui-icons_222222_256x240.png)/*{iconsContent}*/; }
|
||||
.ui-widget-header .ui-icon {background-image: url(images/ui-icons_222222_256x240.png)/*{iconsHeader}*/; }
|
||||
.ui-state-default .ui-icon { background-image: url(images/ui-icons_888888_256x240.png)/*{iconsDefault}*/; }
|
||||
.ui-state-hover .ui-icon, .ui-state-focus .ui-icon {background-image: url(images/ui-icons_454545_256x240.png)/*{iconsHover}*/; }
|
||||
.ui-state-active .ui-icon {background-image: url(images/ui-icons_454545_256x240.png)/*{iconsActive}*/; }
|
||||
.ui-state-highlight .ui-icon {background-image: url(images/ui-icons_2e83ff_256x240.png)/*{iconsHighlight}*/; }
|
||||
.ui-state-error .ui-icon, .ui-state-error-text .ui-icon {background-image: url(images/ui-icons_cd0a0a_256x240.png)/*{iconsError}*/; }
|
||||
|
||||
/* positioning */
|
||||
.ui-icon-carat-1-n { background-position: 0 0; }
|
||||
.ui-icon-carat-1-ne { background-position: -16px 0; }
|
||||
.ui-icon-carat-1-e { background-position: -32px 0; }
|
||||
.ui-icon-carat-1-se { background-position: -48px 0; }
|
||||
.ui-icon-carat-1-s { background-position: -64px 0; }
|
||||
.ui-icon-carat-1-sw { background-position: -80px 0; }
|
||||
.ui-icon-carat-1-w { background-position: -96px 0; }
|
||||
.ui-icon-carat-1-nw { background-position: -112px 0; }
|
||||
.ui-icon-carat-2-n-s { background-position: -128px 0; }
|
||||
.ui-icon-carat-2-e-w { background-position: -144px 0; }
|
||||
.ui-icon-triangle-1-n { background-position: 0 -16px; }
|
||||
.ui-icon-triangle-1-ne { background-position: -16px -16px; }
|
||||
.ui-icon-triangle-1-e { background-position: -32px -16px; }
|
||||
.ui-icon-triangle-1-se { background-position: -48px -16px; }
|
||||
.ui-icon-triangle-1-s { background-position: -64px -16px; }
|
||||
.ui-icon-triangle-1-sw { background-position: -80px -16px; }
|
||||
.ui-icon-triangle-1-w { background-position: -96px -16px; }
|
||||
.ui-icon-triangle-1-nw { background-position: -112px -16px; }
|
||||
.ui-icon-triangle-2-n-s { background-position: -128px -16px; }
|
||||
.ui-icon-triangle-2-e-w { background-position: -144px -16px; }
|
||||
.ui-icon-arrow-1-n { background-position: 0 -32px; }
|
||||
.ui-icon-arrow-1-ne { background-position: -16px -32px; }
|
||||
.ui-icon-arrow-1-e { background-position: -32px -32px; }
|
||||
.ui-icon-arrow-1-se { background-position: -48px -32px; }
|
||||
.ui-icon-arrow-1-s { background-position: -64px -32px; }
|
||||
.ui-icon-arrow-1-sw { background-position: -80px -32px; }
|
||||
.ui-icon-arrow-1-w { background-position: -96px -32px; }
|
||||
.ui-icon-arrow-1-nw { background-position: -112px -32px; }
|
||||
.ui-icon-arrow-2-n-s { background-position: -128px -32px; }
|
||||
.ui-icon-arrow-2-ne-sw { background-position: -144px -32px; }
|
||||
.ui-icon-arrow-2-e-w { background-position: -160px -32px; }
|
||||
.ui-icon-arrow-2-se-nw { background-position: -176px -32px; }
|
||||
.ui-icon-arrowstop-1-n { background-position: -192px -32px; }
|
||||
.ui-icon-arrowstop-1-e { background-position: -208px -32px; }
|
||||
.ui-icon-arrowstop-1-s { background-position: -224px -32px; }
|
||||
.ui-icon-arrowstop-1-w { background-position: -240px -32px; }
|
||||
.ui-icon-arrowthick-1-n { background-position: 0 -48px; }
|
||||
.ui-icon-arrowthick-1-ne { background-position: -16px -48px; }
|
||||
.ui-icon-arrowthick-1-e { background-position: -32px -48px; }
|
||||
.ui-icon-arrowthick-1-se { background-position: -48px -48px; }
|
||||
.ui-icon-arrowthick-1-s { background-position: -64px -48px; }
|
||||
.ui-icon-arrowthick-1-sw { background-position: -80px -48px; }
|
||||
.ui-icon-arrowthick-1-w { background-position: -96px -48px; }
|
||||
.ui-icon-arrowthick-1-nw { background-position: -112px -48px; }
|
||||
.ui-icon-arrowthick-2-n-s { background-position: -128px -48px; }
|
||||
.ui-icon-arrowthick-2-ne-sw { background-position: -144px -48px; }
|
||||
.ui-icon-arrowthick-2-e-w { background-position: -160px -48px; }
|
||||
.ui-icon-arrowthick-2-se-nw { background-position: -176px -48px; }
|
||||
.ui-icon-arrowthickstop-1-n { background-position: -192px -48px; }
|
||||
.ui-icon-arrowthickstop-1-e { background-position: -208px -48px; }
|
||||
.ui-icon-arrowthickstop-1-s { background-position: -224px -48px; }
|
||||
.ui-icon-arrowthickstop-1-w { background-position: -240px -48px; }
|
||||
.ui-icon-arrowreturnthick-1-w { background-position: 0 -64px; }
|
||||
.ui-icon-arrowreturnthick-1-n { background-position: -16px -64px; }
|
||||
.ui-icon-arrowreturnthick-1-e { background-position: -32px -64px; }
|
||||
.ui-icon-arrowreturnthick-1-s { background-position: -48px -64px; }
|
||||
.ui-icon-arrowreturn-1-w { background-position: -64px -64px; }
|
||||
.ui-icon-arrowreturn-1-n { background-position: -80px -64px; }
|
||||
.ui-icon-arrowreturn-1-e { background-position: -96px -64px; }
|
||||
.ui-icon-arrowreturn-1-s { background-position: -112px -64px; }
|
||||
.ui-icon-arrowrefresh-1-w { background-position: -128px -64px; }
|
||||
.ui-icon-arrowrefresh-1-n { background-position: -144px -64px; }
|
||||
.ui-icon-arrowrefresh-1-e { background-position: -160px -64px; }
|
||||
.ui-icon-arrowrefresh-1-s { background-position: -176px -64px; }
|
||||
.ui-icon-arrow-4 { background-position: 0 -80px; }
|
||||
.ui-icon-arrow-4-diag { background-position: -16px -80px; }
|
||||
.ui-icon-extlink { background-position: -32px -80px; }
|
||||
.ui-icon-newwin { background-position: -48px -80px; }
|
||||
.ui-icon-refresh { background-position: -64px -80px; }
|
||||
.ui-icon-shuffle { background-position: -80px -80px; }
|
||||
.ui-icon-transfer-e-w { background-position: -96px -80px; }
|
||||
.ui-icon-transferthick-e-w { background-position: -112px -80px; }
|
||||
.ui-icon-folder-collapsed { background-position: 0 -96px; }
|
||||
.ui-icon-folder-open { background-position: -16px -96px; }
|
||||
.ui-icon-document { background-position: -32px -96px; }
|
||||
.ui-icon-document-b { background-position: -48px -96px; }
|
||||
.ui-icon-note { background-position: -64px -96px; }
|
||||
.ui-icon-mail-closed { background-position: -80px -96px; }
|
||||
.ui-icon-mail-open { background-position: -96px -96px; }
|
||||
.ui-icon-suitcase { background-position: -112px -96px; }
|
||||
.ui-icon-comment { background-position: -128px -96px; }
|
||||
.ui-icon-person { background-position: -144px -96px; }
|
||||
.ui-icon-print { background-position: -160px -96px; }
|
||||
.ui-icon-trash { background-position: -176px -96px; }
|
||||
.ui-icon-locked { background-position: -192px -96px; }
|
||||
.ui-icon-unlocked { background-position: -208px -96px; }
|
||||
.ui-icon-bookmark { background-position: -224px -96px; }
|
||||
.ui-icon-tag { background-position: -240px -96px; }
|
||||
.ui-icon-home { background-position: 0 -112px; }
|
||||
.ui-icon-flag { background-position: -16px -112px; }
|
||||
.ui-icon-calendar { background-position: -32px -112px; }
|
||||
.ui-icon-cart { background-position: -48px -112px; }
|
||||
.ui-icon-pencil { background-position: -64px -112px; }
|
||||
.ui-icon-clock { background-position: -80px -112px; }
|
||||
.ui-icon-disk { background-position: -96px -112px; }
|
||||
.ui-icon-calculator { background-position: -112px -112px; }
|
||||
.ui-icon-zoomin { background-position: -128px -112px; }
|
||||
.ui-icon-zoomout { background-position: -144px -112px; }
|
||||
.ui-icon-search { background-position: -160px -112px; }
|
||||
.ui-icon-wrench { background-position: -176px -112px; }
|
||||
.ui-icon-gear { background-position: -192px -112px; }
|
||||
.ui-icon-heart { background-position: -208px -112px; }
|
||||
.ui-icon-star { background-position: -224px -112px; }
|
||||
.ui-icon-link { background-position: -240px -112px; }
|
||||
.ui-icon-cancel { background-position: 0 -128px; }
|
||||
.ui-icon-plus { background-position: -16px -128px; }
|
||||
.ui-icon-plusthick { background-position: -32px -128px; }
|
||||
.ui-icon-minus { background-position: -48px -128px; }
|
||||
.ui-icon-minusthick { background-position: -64px -128px; }
|
||||
.ui-icon-close { background-position: -80px -128px; }
|
||||
.ui-icon-closethick { background-position: -96px -128px; }
|
||||
.ui-icon-key { background-position: -112px -128px; }
|
||||
.ui-icon-lightbulb { background-position: -128px -128px; }
|
||||
.ui-icon-scissors { background-position: -144px -128px; }
|
||||
.ui-icon-clipboard { background-position: -160px -128px; }
|
||||
.ui-icon-copy { background-position: -176px -128px; }
|
||||
.ui-icon-contact { background-position: -192px -128px; }
|
||||
.ui-icon-image { background-position: -208px -128px; }
|
||||
.ui-icon-video { background-position: -224px -128px; }
|
||||
.ui-icon-script { background-position: -240px -128px; }
|
||||
.ui-icon-alert { background-position: 0 -144px; }
|
||||
.ui-icon-info { background-position: -16px -144px; }
|
||||
.ui-icon-notice { background-position: -32px -144px; }
|
||||
.ui-icon-help { background-position: -48px -144px; }
|
||||
.ui-icon-check { background-position: -64px -144px; }
|
||||
.ui-icon-bullet { background-position: -80px -144px; }
|
||||
.ui-icon-radio-off { background-position: -96px -144px; }
|
||||
.ui-icon-radio-on { background-position: -112px -144px; }
|
||||
.ui-icon-pin-w { background-position: -128px -144px; }
|
||||
.ui-icon-pin-s { background-position: -144px -144px; }
|
||||
.ui-icon-play { background-position: 0 -160px; }
|
||||
.ui-icon-pause { background-position: -16px -160px; }
|
||||
.ui-icon-seek-next { background-position: -32px -160px; }
|
||||
.ui-icon-seek-prev { background-position: -48px -160px; }
|
||||
.ui-icon-seek-end { background-position: -64px -160px; }
|
||||
.ui-icon-seek-start { background-position: -80px -160px; }
|
||||
/* ui-icon-seek-first is deprecated, use ui-icon-seek-start instead */
|
||||
.ui-icon-seek-first { background-position: -80px -160px; }
|
||||
.ui-icon-stop { background-position: -96px -160px; }
|
||||
.ui-icon-eject { background-position: -112px -160px; }
|
||||
.ui-icon-volume-off { background-position: -128px -160px; }
|
||||
.ui-icon-volume-on { background-position: -144px -160px; }
|
||||
.ui-icon-power { background-position: 0 -176px; }
|
||||
.ui-icon-signal-diag { background-position: -16px -176px; }
|
||||
.ui-icon-signal { background-position: -32px -176px; }
|
||||
.ui-icon-battery-0 { background-position: -48px -176px; }
|
||||
.ui-icon-battery-1 { background-position: -64px -176px; }
|
||||
.ui-icon-battery-2 { background-position: -80px -176px; }
|
||||
.ui-icon-battery-3 { background-position: -96px -176px; }
|
||||
.ui-icon-circle-plus { background-position: 0 -192px; }
|
||||
.ui-icon-circle-minus { background-position: -16px -192px; }
|
||||
.ui-icon-circle-close { background-position: -32px -192px; }
|
||||
.ui-icon-circle-triangle-e { background-position: -48px -192px; }
|
||||
.ui-icon-circle-triangle-s { background-position: -64px -192px; }
|
||||
.ui-icon-circle-triangle-w { background-position: -80px -192px; }
|
||||
.ui-icon-circle-triangle-n { background-position: -96px -192px; }
|
||||
.ui-icon-circle-arrow-e { background-position: -112px -192px; }
|
||||
.ui-icon-circle-arrow-s { background-position: -128px -192px; }
|
||||
.ui-icon-circle-arrow-w { background-position: -144px -192px; }
|
||||
.ui-icon-circle-arrow-n { background-position: -160px -192px; }
|
||||
.ui-icon-circle-zoomin { background-position: -176px -192px; }
|
||||
.ui-icon-circle-zoomout { background-position: -192px -192px; }
|
||||
.ui-icon-circle-check { background-position: -208px -192px; }
|
||||
.ui-icon-circlesmall-plus { background-position: 0 -208px; }
|
||||
.ui-icon-circlesmall-minus { background-position: -16px -208px; }
|
||||
.ui-icon-circlesmall-close { background-position: -32px -208px; }
|
||||
.ui-icon-squaresmall-plus { background-position: -48px -208px; }
|
||||
.ui-icon-squaresmall-minus { background-position: -64px -208px; }
|
||||
.ui-icon-squaresmall-close { background-position: -80px -208px; }
|
||||
.ui-icon-grip-dotted-vertical { background-position: 0 -224px; }
|
||||
.ui-icon-grip-dotted-horizontal { background-position: -16px -224px; }
|
||||
.ui-icon-grip-solid-vertical { background-position: -32px -224px; }
|
||||
.ui-icon-grip-solid-horizontal { background-position: -48px -224px; }
|
||||
.ui-icon-gripsmall-diagonal-se { background-position: -64px -224px; }
|
||||
.ui-icon-grip-diagonal-se { background-position: -80px -224px; }
|
||||
|
||||
|
||||
/* Misc visuals
|
||||
----------------------------------*/
|
||||
|
||||
|
||||
/* Overlays */
|
||||
.ui-widget-overlay { background: #aaaaaa/*{bgColorOverlay}*/ url(images/ui-bg_flat_0_aaaaaa_40x100.png)/*{bgImgUrlOverlay}*/ 50%/*{bgOverlayXPos}*/ 50%/*{bgOverlayYPos}*/ repeat-x/*{bgOverlayRepeat}*/; opacity: .3;filter:Alpha(Opacity=30)/*{opacityOverlay}*/; }
|
||||
.ui-widget-shadow { margin: -8px/*{offsetTopShadow}*/ 0 0 -8px/*{offsetLeftShadow}*/; padding: 8px/*{thicknessShadow}*/; background: #aaaaaa/*{bgColorShadow}*/ url(images/ui-bg_flat_0_aaaaaa_40x100.png)/*{bgImgUrlShadow}*/ 50%/*{bgShadowXPos}*/ 50%/*{bgShadowYPos}*/ repeat-x/*{bgShadowRepeat}*/; opacity: .3;filter:Alpha(Opacity=30)/*{opacityShadow}*/; -moz-border-radius: 8px/*{cornerRadiusShadow}*/; -khtml-border-radius: 8px/*{cornerRadiusShadow}*/; -webkit-border-radius: 8px/*{cornerRadiusShadow}*/; border-radius: 8px/*{cornerRadiusShadow}*/; }
|
950
admin/css/layout.css
Normal file
|
@ -0,0 +1,950 @@
|
|||
/* Essentials */
|
||||
|
||||
html, div, map, dt, isindex, form, header, aside, section, section, article, footer {
|
||||
display: block;
|
||||
}
|
||||
|
||||
html, body {
|
||||
height: 100%;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
font-family: "Helvetica Neue", Helvetica, Arial, Verdana, sans-serif;
|
||||
background: #F8F8F8;
|
||||
font-size: 12px;
|
||||
}
|
||||
|
||||
.clear {
|
||||
clear: both;
|
||||
}
|
||||
|
||||
.spacer {
|
||||
height: 20px;
|
||||
}
|
||||
|
||||
a:link, a:visited {
|
||||
color: #77BACE;
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
a:hover {
|
||||
text-decoration: underline;
|
||||
}
|
||||
|
||||
|
||||
/* Header */
|
||||
|
||||
header#header {
|
||||
height: 55px;
|
||||
width: 100%;
|
||||
background: #222222 url(../images/header_bg.png) repeat-x;
|
||||
}
|
||||
|
||||
header#header h1.site_title, header#header h2.section_title {
|
||||
float: left;
|
||||
margin: 0;
|
||||
font-size: 22px;
|
||||
display: block;
|
||||
width: 23%;
|
||||
height: 55px;
|
||||
font-weight: normal;
|
||||
text-align: left;
|
||||
text-indent: 1.8%;
|
||||
line-height: 55px;
|
||||
color: #fff;
|
||||
text-shadow: 0 -1px 0 #000;
|
||||
}
|
||||
|
||||
header#header h1.site_title a {
|
||||
color: #fff;
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
header#header h2.section_title {
|
||||
text-align: center;
|
||||
text-indent: 4.5%;
|
||||
width: 68%;
|
||||
background: url(../images/header_shadow.png) no-repeat left top;
|
||||
}
|
||||
|
||||
.btn_view_site {
|
||||
float: left;
|
||||
width: 9%;
|
||||
}
|
||||
|
||||
.btn_view_site a {
|
||||
display: block;
|
||||
margin-top: 12px;
|
||||
width: 91px;
|
||||
height: 27px;
|
||||
background: url(../images/btn_view_site.png) no-repeat;
|
||||
text-align: center;
|
||||
line-height: 29px;
|
||||
color: #fff;
|
||||
text-decoration: none;
|
||||
text-shadow: 0 -1px 0 #000;}
|
||||
|
||||
.btn_view_site a:hover {
|
||||
background-position: 0 -27px;
|
||||
}
|
||||
|
||||
/* Secondary Header Bar */
|
||||
|
||||
section#secondary_bar {
|
||||
height: 38px;
|
||||
width: 100%;
|
||||
background: #F1F1F4 url(../images/secondary_bar.png) repeat-x;
|
||||
}
|
||||
|
||||
section#secondary_bar .user {
|
||||
float: left;
|
||||
width: 23%;
|
||||
height: 38px;
|
||||
}
|
||||
|
||||
.user p {
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
color: #666666;
|
||||
font-weight: bold;
|
||||
display: block;
|
||||
float: left;
|
||||
width: 85%;
|
||||
height: 35px;
|
||||
line-height: 35px;
|
||||
text-indent: 25px;
|
||||
text-shadow: 0 1px 0 #fff;
|
||||
background: url(../images/icn_user.png) no-repeat center left;
|
||||
margin-left: 6%;
|
||||
}
|
||||
|
||||
.user a {
|
||||
text-decoration: none;
|
||||
color: #666666}
|
||||
|
||||
.user a:hover {
|
||||
color: #77BACE;
|
||||
}
|
||||
|
||||
.user a.logout_user {
|
||||
float: left;
|
||||
display: block;
|
||||
width: 16px;
|
||||
height: 35px;
|
||||
text-indent: -5000px;
|
||||
background: url(../images/icn_logout.png) center no-repeat;
|
||||
}
|
||||
|
||||
/* Breadcrumbs */
|
||||
|
||||
section#secondary_bar .breadcrumbs_container {
|
||||
float: left;
|
||||
width: 77%;
|
||||
background: url(../images/secondary_bar_shadow.png) no-repeat left top;
|
||||
height: 38px;
|
||||
}
|
||||
|
||||
article.breadcrumbs {
|
||||
float: left;
|
||||
padding: 0 10px;
|
||||
border: 1px solid #ccc;
|
||||
-webkit-border-radius: 5px;
|
||||
-moz-border-radius: 5px;
|
||||
border-radius: 5px;
|
||||
-webkit-box-shadow: 0 1px 0 #fff;
|
||||
-moz-box-shadow: 0 1px 0 #fff;
|
||||
box-shadow: 0 1px 0 #fff;
|
||||
height: 23px;
|
||||
margin: 4px 3%;
|
||||
}
|
||||
|
||||
.breadcrumbs a {
|
||||
display: inline-block;
|
||||
float: left;
|
||||
height: 24px;
|
||||
line-height: 23px;
|
||||
}
|
||||
|
||||
.breadcrumbs a.current, .breadcrumbs a.current:hover {
|
||||
color: #9E9E9E;
|
||||
font-weight: bold;
|
||||
text-shadow: 0 1px 0 #fff;
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
.breadcrumbs a:link, .breadcrumbs a:visited {
|
||||
color: #44474F;
|
||||
text-decoration: none;
|
||||
text-shadow: 0 1px 0 #fff;
|
||||
font-weight: bold;}
|
||||
|
||||
.breadcrumbs a:hover {
|
||||
color: #222222;
|
||||
}
|
||||
|
||||
.breadcrumb_divider {
|
||||
display: inline-block;
|
||||
width: 12px;
|
||||
height: 24px;
|
||||
background: url(../images/breadcrumb_divider.png) no-repeat;
|
||||
float: left;
|
||||
margin: 0 5px;
|
||||
}
|
||||
|
||||
/* Sidebar */
|
||||
|
||||
aside#sidebar {
|
||||
width: 23%;
|
||||
background: #E0E0E3 url(../images/sidebar.png) repeat;
|
||||
float: left;
|
||||
min-height: 100%;
|
||||
margin-top: -4px;
|
||||
height:auto;
|
||||
}
|
||||
|
||||
#sidebar hr {
|
||||
border: none;
|
||||
outline: none;
|
||||
background: url(../images/sidebar_divider.png) repeat-x;
|
||||
display: block;
|
||||
width: 100%;
|
||||
height: 2px;}
|
||||
|
||||
|
||||
/* Search */
|
||||
|
||||
.quick_search {
|
||||
text-align: center;
|
||||
padding: 14px 0 10px 0;
|
||||
}
|
||||
|
||||
.quick_search input[type=text] {
|
||||
-webkit-border-radius: 20px;
|
||||
-moz-border-radius: 20px;
|
||||
border-radius: 20px;
|
||||
border: 1px solid #bbb;
|
||||
height: 26px;
|
||||
width: 90%;
|
||||
color: #ccc;
|
||||
-webkit-box-shadow: inset 0 2px 2px #ccc, 0 1px 0 #fff;
|
||||
-moz-box-shadow: inset 0 2px 2px #ccc, 0 1px 0 #fff;
|
||||
box-shadow: inset 0 2px 2px #ccc, 0 1px 0 #fff;
|
||||
text-indent: 30px;
|
||||
background: #fff url(../images/icn_search.png) no-repeat;
|
||||
background-position: 10px 6px;
|
||||
}
|
||||
|
||||
.quick_search input[type=text]:focus {
|
||||
outline: none;
|
||||
color: #666666;
|
||||
border: 1px solid #77BACE;
|
||||
-webkit-box-shadow: inset 0 2px 2px #ccc, 0 0 10px #ADDCE6;
|
||||
-moz-box-shadow: inset 0 2px 2px #ccc, 0 0 10px #ADDCE6;
|
||||
box-shadow: inset 0 2px 2px #ccc, 0 0 10px #ADDCE6;
|
||||
}
|
||||
|
||||
/* Sidebar Menu */
|
||||
|
||||
#sidebar h3 {
|
||||
background:url("../images/secondary_bar.png") repeat-x scroll 0 0 #F1F1F4;
|
||||
color: #1F1F20;
|
||||
text-transform: uppercase;
|
||||
text-shadow: 0 1px 0 #fff;
|
||||
width: 94%;
|
||||
float: left;
|
||||
font-size: 13px;
|
||||
font-weight: bold;
|
||||
height: 28px;
|
||||
margin: 0 0 5px;
|
||||
padding: 7px 0 0 15px;
|
||||
|
||||
}
|
||||
|
||||
#sidebar ul, .width_quarter ul{
|
||||
clear: both;
|
||||
margin: 10px 0 10px 0; padding: 0;
|
||||
}
|
||||
|
||||
#sidebar li, .width_quarter li{
|
||||
list-style: none;
|
||||
margin: 0 0 0 25px; padding: 0;
|
||||
}
|
||||
|
||||
#sidebar li a, .width_quarter li a{
|
||||
color: #666666;
|
||||
padding-left: 25px;
|
||||
text-decoration: none;
|
||||
display: inline-block;
|
||||
height: 17px;
|
||||
line-height: 17px;
|
||||
text-shadow: 0 1px 0 #fff;
|
||||
margin: 2px 0;
|
||||
}
|
||||
|
||||
#sidebar li a:hover, .width_quarter li a:hover {
|
||||
color: #444444;
|
||||
}
|
||||
|
||||
/* Sidebar Icons */
|
||||
|
||||
li.icn_new_article a {
|
||||
background: url(../images/icn_new_article.png) no-repeat center left;
|
||||
line-height:20px;
|
||||
}
|
||||
li.icn_edit_article a{
|
||||
background: url(../images/icn_edit_article.png) no-repeat center left;
|
||||
}
|
||||
li.icn_view a{
|
||||
background: url(../images/view.png) no-repeat center left;
|
||||
}
|
||||
li.icn_categories a {
|
||||
background: url(../images/icn_categories.png) no-repeat center left;
|
||||
}
|
||||
li.icn_tags a {
|
||||
background: url(../images/icn_tags.png) no-repeat center left;
|
||||
}
|
||||
li.icn_add_user a {
|
||||
background: url(../images/icn_add_user.png) no-repeat center left;
|
||||
}
|
||||
li.icn_view_users a {
|
||||
background: url(../images/icn_view_users.png) no-repeat center left;
|
||||
}
|
||||
li.icn_profile a {
|
||||
background: url(../images/icn_profile.png) no-repeat center left;
|
||||
}
|
||||
li.icn_folder a {
|
||||
background: url(../images/icn_folder.png) no-repeat center left;
|
||||
}
|
||||
li.icn_photo a {
|
||||
background: url(../images/icn_photo.png) no-repeat center left;
|
||||
}
|
||||
li.icn_audio a {
|
||||
background: url(../images/icn_audio.png) no-repeat center left;
|
||||
}
|
||||
li.icn_video a {
|
||||
background: url(../images/icn_video.png) no-repeat center left;
|
||||
}
|
||||
li.icn_settings a {
|
||||
background: url(../images/icn_settings.png) no-repeat center left;
|
||||
}
|
||||
li.icn_security a {
|
||||
background: url(../images/icn_security.png) no-repeat center left;
|
||||
}
|
||||
li.icn_jump_back a {
|
||||
background: url(../images/icn_jump_back.png) no-repeat center left;
|
||||
}
|
||||
|
||||
#sidebar p {
|
||||
color: #666666;
|
||||
padding-left: 6%;
|
||||
text-shadow: 0 1px 0 #fff;
|
||||
margin: 10px 0 0 0;}
|
||||
|
||||
#sidebar a {
|
||||
color: #666666;
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
#sidebar a:hover {
|
||||
text-decoration: underline;
|
||||
}
|
||||
|
||||
#sidebar footer {
|
||||
margin-top: 20%;
|
||||
}
|
||||
|
||||
|
||||
/* Main Content */
|
||||
|
||||
|
||||
section#main {
|
||||
width: 77%;
|
||||
min-height: 100%;
|
||||
background: url(../images/sidebar_shadow.png) repeat-y left top;
|
||||
float: left;
|
||||
margin-top: -2px;
|
||||
height:auto;
|
||||
}
|
||||
|
||||
#main h3 {
|
||||
color: #1F1F20;
|
||||
text-transform: uppercase;
|
||||
text-shadow: 0 1px 0 #fff;
|
||||
font-size: 13px;
|
||||
margin: 8px 20px;
|
||||
}
|
||||
|
||||
/* Modules */
|
||||
|
||||
.module {
|
||||
border: 1px solid #9BA0AF;
|
||||
width: 100%;
|
||||
margin: 20px 3% 0 3%;
|
||||
margin-top: 20px;
|
||||
-webkit-border-radius: 5px;
|
||||
-moz-border-radius: 5px;
|
||||
border-radius: 5px;
|
||||
background: #ffffff;
|
||||
}
|
||||
|
||||
#main .module header h3 {
|
||||
display: block;
|
||||
width: 90%;
|
||||
float: left;
|
||||
}
|
||||
|
||||
.module header {
|
||||
height: 38px;
|
||||
width: 100%;
|
||||
background: #F1F1F4 url(../images/secondary_bar.png) repeat-x;
|
||||
-webkit-border-top-left-radius: 5px; -webkit-border-top-right-radius: 5px;
|
||||
-moz-border-radius-topleft: 5px; -moz-border-radius-topright: 5px;
|
||||
border-top-left-radius: 5px; border-top-right-radius: 5px;
|
||||
}
|
||||
|
||||
.module footer {
|
||||
height: 32px;
|
||||
width: 100%;
|
||||
border-top: 1px solid #9CA1B0;
|
||||
background: #F1F1F4 url(../images/module_footer_bg.png) repeat-x;
|
||||
-webkit-border-bottom-left-radius: 5px; -webkit-border-bottom-right-radius: 5px;
|
||||
-moz-border-radius-bottomleft: 5px; -moz-border-radius-bottomright: 5px;
|
||||
-webkit-border-bottom-left-radius: 5px; -webkit-border-bottom-right-radius: 5px;
|
||||
}
|
||||
|
||||
.module_content {
|
||||
margin: 10px 20px;
|
||||
color: #666;}
|
||||
|
||||
/* Module Widths */
|
||||
|
||||
.width_full {
|
||||
width: 95%;
|
||||
}
|
||||
|
||||
.width_half {
|
||||
width: 46%;
|
||||
margin-right: 0;
|
||||
float: left;
|
||||
}
|
||||
|
||||
.width_quarter {
|
||||
width: 26%;
|
||||
margin-right: 0;
|
||||
float: left;
|
||||
}
|
||||
|
||||
.width_3_quarter {
|
||||
width: 66%;
|
||||
margin-right: 0;
|
||||
float: left;
|
||||
}
|
||||
|
||||
/* Stats Module */
|
||||
|
||||
.stats_graph {
|
||||
width: 64%;
|
||||
float: left;
|
||||
}
|
||||
|
||||
.stats_overview {
|
||||
background: #F6F6F6;
|
||||
border: 1px solid #ccc;
|
||||
float: right;
|
||||
width: 26%;
|
||||
-webkit-border-radius: 5px;
|
||||
-moz-border-radius: 5px;
|
||||
border-radius: 5px;
|
||||
}
|
||||
|
||||
.overview_today, .overview_previous {
|
||||
width: 50%;
|
||||
float: left;}
|
||||
|
||||
.stats_overview p {
|
||||
margin: 0; padding: 0;
|
||||
text-align: center;
|
||||
text-transform: uppercase;
|
||||
text-shadow: 0 1px 0 #fff;
|
||||
}
|
||||
|
||||
.stats_overview p.overview_day {
|
||||
font-size: 12px;
|
||||
font-weight: bold;
|
||||
margin: 6px 0;
|
||||
}
|
||||
|
||||
.stats_overview p.overview_count {
|
||||
font-size: 26px;
|
||||
font-weight: bold;
|
||||
color: #333333;}
|
||||
|
||||
.stats_overview p.overview_type {
|
||||
font-size: 10px;
|
||||
color: #999999;
|
||||
margin-bottom: 8px}
|
||||
|
||||
/* Content Manager */
|
||||
|
||||
.tablesorter {
|
||||
width: 100%;
|
||||
margin: -5px 0 0 0;
|
||||
}
|
||||
|
||||
.tablesorter td{
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
border-bottom: 1px dotted #ccc;
|
||||
}
|
||||
|
||||
.tablesorter thead tr {
|
||||
height: 34px;
|
||||
background: url(../images/table_sorter_header.png) repeat-x;
|
||||
text-align: left;
|
||||
text-indent: 10px;
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
.tablesorter td {
|
||||
padding: 15px 10px;
|
||||
}
|
||||
|
||||
.tablesorter input[type=image] {
|
||||
margin-right: 10px;}
|
||||
|
||||
ul.tabs {
|
||||
margin: 3px 10px 0 0;
|
||||
padding: 0;
|
||||
float: right;
|
||||
list-style: none;
|
||||
height: 24px; /*--Set height of tabs--*/
|
||||
-webkit-border-radius: 5px;
|
||||
-moz-border-radius: 5px;
|
||||
border-radius: 5px;
|
||||
-webkit-box-shadow: 0 1px 0 #fff;
|
||||
-moz-box-shadow: 0 1px 0 #fff;
|
||||
box-shadow: 0 1px 0 #fff;
|
||||
border: 1px solid #ccc;
|
||||
font-weight: bold;
|
||||
text-shadow: 0 1px 0 #fff;
|
||||
}
|
||||
ul.tabs li {
|
||||
float: left;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
line-height: 24px;
|
||||
}
|
||||
ul.tabs li a {
|
||||
text-decoration: none;
|
||||
color: #999;
|
||||
display: block;
|
||||
padding: 0 10px;
|
||||
height: 24px;
|
||||
}
|
||||
|
||||
ul.tabs li a:hover {
|
||||
color: #44474F;
|
||||
}
|
||||
|
||||
html ul.tabs li.active a {
|
||||
color: #44474F;
|
||||
}
|
||||
|
||||
html ul.tabs li.active, html ul.tabs li.active a:hover {
|
||||
background: #F1F2F4;
|
||||
-webkit-box-shadow: inset 0 2px 3px #818181;
|
||||
-moz-box-shadow: inset 0 2px 3px #818181;
|
||||
box-shadow: inset 0 2px 3px #818181;
|
||||
}
|
||||
|
||||
html ul.tabs li:first-child, html ul.tabs li:first-child a {
|
||||
-webkit-border-top-left-radius: 5px; -webkit-border-bottom-left-radius: 5px;
|
||||
-moz-border-radius-topleft: 5px; -moz-border-radius-bottomleft: 5px;
|
||||
border-top-left-radius: 5px; border-bottom-left-radius: 5px;
|
||||
}
|
||||
|
||||
html ul.tabs li:last-child, html ul.tabs li:last-child a {
|
||||
-webkit-border-top-right-radius: 5px; -webkit-border-bottom-right-radius: 5px;
|
||||
-moz-border-radius-topright: 5px; -moz-border-radius-bottomright: 5px;
|
||||
border-top-right-radius: 5px; border-bottom-right-radius: 5px;
|
||||
}
|
||||
|
||||
#main .module header h3.tabs_involved {
|
||||
display: block;
|
||||
width: 60%;
|
||||
float: left;
|
||||
}
|
||||
|
||||
/* Messages */
|
||||
|
||||
.message {
|
||||
border-bottom: 1px dotted #cccccc;
|
||||
}
|
||||
|
||||
input[type="submit"],input[type="button"] {
|
||||
font-weight:bold;
|
||||
background: #eee; /* Old browsers */
|
||||
background: -moz-linear-gradient(top, rgba(255,255,255,.2) 0%, rgba(0,0,0,.2) 100%); /* FF3.6+ */
|
||||
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(255,255,255,.2)), color-stop(100%,rgba(0,0,0,.2))); /* Chrome,Safari4+ */
|
||||
background: -webkit-linear-gradient(top, rgba(255,255,255,.2) 0%,rgba(0,0,0,.2) 100%); /* Chrome10+,Safari5.1+ */
|
||||
background: -o-linear-gradient(top, rgba(255,255,255,.2) 0%,rgba(0,0,0,.2) 100%); /* Opera11.10+ */
|
||||
background: -ms-linear-gradient(top, rgba(255,255,255,.2) 0%,rgba(0,0,0,.2) 100%); /* IE10+ */
|
||||
background: linear-gradient(top, rgba(255,255,255,.2) 0%,rgba(0,0,0,.2) 100%); /* W3C */
|
||||
border: 1px solid #aaa;
|
||||
border-top: 1px solid #ccc;
|
||||
border-left: 1px solid #ccc;
|
||||
padding: 4px 12px;
|
||||
-moz-border-radius: 3px;
|
||||
-webkit-border-radius: 3px;
|
||||
border-radius: 3px;
|
||||
color: #444;
|
||||
display: inline-block;
|
||||
/*font-size: 11px; /* DISABLED FOR easydropdown */
|
||||
/*font-weight: bold; /* DISABLED FOR easydropdown */
|
||||
text-decoration: none;
|
||||
text-shadow: 0 1px rgba(255, 255, 255, .75);
|
||||
cursor: pointer;
|
||||
line-height: 21px;
|
||||
font-family: "HelveticaNeue", "Helvetica Neue", Helvetica, Arial, sans-serif;
|
||||
float:left;
|
||||
margin:10px 0 0 10px;
|
||||
}
|
||||
|
||||
input[type="submit"]:hover, input[type="button"]:hover {
|
||||
color: #222;
|
||||
background: #ddd; /* Old browsers */
|
||||
background: -moz-linear-gradient(top, rgba(255,255,255,.3) 0%, rgba(0,0,0,.3) 100%); /* FF3.6+ */
|
||||
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(255,255,255,.3)), color-stop(100%,rgba(0,0,0,.3))); /* Chrome,Safari4+ */
|
||||
background: -webkit-linear-gradient(top, rgba(255,255,255,.3) 0%,rgba(0,0,0,.3) 100%); /* Chrome10+,Safari5.1+ */
|
||||
background: -o-linear-gradient(top, rgba(255,255,255,.3) 0%,rgba(0,0,0,.3) 100%); /* Opera11.10+ */
|
||||
background: -ms-linear-gradient(top, rgba(255,255,255,.3) 0%,rgba(0,0,0,.3) 100%); /* IE10+ */
|
||||
background: linear-gradient(top, rgba(255,255,255,.3) 0%,rgba(0,0,0,.3) 100%); /* W3C */
|
||||
border: 1px solid #888;
|
||||
border-top: 1px solid #aaa;
|
||||
border-left: 1px solid #aaa;
|
||||
}
|
||||
|
||||
input[type=submit].alt_btn {
|
||||
background: #D0D1D4 url(../images/btn_submit_2.png) repeat-x;
|
||||
border: 1px solid#30B0C8;
|
||||
-webkit-box-shadow: 0 1px 0 #fff;
|
||||
-moz-box-shadow: 0 1px 0 #fff;
|
||||
box-shadow: 0 1px 0 #fff;
|
||||
font-weight: bold;
|
||||
height: 22px;
|
||||
-webkit-border-radius: 5px;
|
||||
-moz-border-radius: 5px;
|
||||
border-radius: 5px;
|
||||
padding: 0 10px;
|
||||
color: #003E49;
|
||||
text-shadow: 0 1px 0 #6CDCF9;
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
input[type=submit].alt_btn:hover {
|
||||
color: #001217;
|
||||
}
|
||||
|
||||
input[type=submit].btn_post_message {
|
||||
background: #D0D1D4 url(../images/post_message.png) no-repeat;
|
||||
display: block;
|
||||
width: 37px;
|
||||
border: none;
|
||||
height: 24px;
|
||||
cursor: pointer;
|
||||
text-indent: -5000px;
|
||||
}
|
||||
|
||||
input[type=submit].btn_post_message:hover {
|
||||
background-position: 0 -24px;
|
||||
}
|
||||
|
||||
.post_message {
|
||||
text-align: left;
|
||||
padding: 5px 0;
|
||||
}
|
||||
|
||||
.post_message input[type=text] {
|
||||
-webkit-border-radius: 5px;
|
||||
-moz-border-radius: 5px;
|
||||
border-radius: 5px;
|
||||
border: 1px solid #bbb;
|
||||
height: 20px;
|
||||
width: 70%;
|
||||
color: #ccc;
|
||||
-webkit-box-shadow: inset 0 2px 2px #ccc, 0 1px 0 #fff;
|
||||
-moz-box-shadow: inset 0 2px 2px #ccc, 0 1px 0 #fff;
|
||||
box-shadow: inset 0 2px 2px #ccc, 0 1px 0 #fff;
|
||||
text-indent: 10px;
|
||||
background-position: 10px 6px;
|
||||
float: left;
|
||||
margin: 0 3.5%;
|
||||
}
|
||||
|
||||
.post_message input[type=text]:focus {
|
||||
outline: none;
|
||||
border: 1px solid #77BACE;
|
||||
-webkit-box-shadow: inset 0 2px 2px #ccc, 0 0 10px #ADDCE6;
|
||||
-moz-box-shadow: inset 0 2px 2px #ccc, 0 0 10px #ADDCE6;
|
||||
box-shadow: inset 0 2px 2px #ccc, 0 0 10px #ADDCE6;
|
||||
color: #666666;
|
||||
}
|
||||
|
||||
.post_message input[type=image] {
|
||||
float: left;
|
||||
}
|
||||
|
||||
.message_list {
|
||||
height: 250px;
|
||||
overflow-x:hidden;
|
||||
overflow-y: scroll;
|
||||
}
|
||||
|
||||
/* New/Edit Article Module */
|
||||
|
||||
fieldset {
|
||||
-webkit-border-radius: 5px;
|
||||
-moz-border-radius: 5px;
|
||||
border-radius: 5px;
|
||||
background: #F6F6F6;
|
||||
border: 1px solid #ccc;
|
||||
padding: 1% 0%;
|
||||
margin: 10px 0;
|
||||
}
|
||||
|
||||
fieldset label {
|
||||
display: block;
|
||||
float: left;
|
||||
width: 96%;
|
||||
height: 25px;
|
||||
line-height: 25px;
|
||||
text-shadow: 0 1px 0 #fff;
|
||||
font-weight: bold;
|
||||
padding-left: 10px;
|
||||
margin: 5px 0 5px 0;
|
||||
text-transform: uppercase;
|
||||
}
|
||||
|
||||
fieldset input[type=text], fieldset input[type=password] {
|
||||
-webkit-border-radius: 5px;
|
||||
-moz-border-radius: 5px;
|
||||
border-radius: 5px;
|
||||
border: 1px solid #BBBBBB;
|
||||
height: 25px;
|
||||
color: #666666;
|
||||
-webkit-box-shadow: inset 0 2px 2px #ccc, 0 1px 0 #fff;
|
||||
-moz-box-shadow: inset 0 2px 2px #ccc, 0 1px 0 #fff;
|
||||
box-shadow: inset 0 2px 2px #ccc, 0 1px 0 #fff;
|
||||
padding-left: 10px;
|
||||
background-position: 10px 6px;
|
||||
margin: 0;
|
||||
display: block;
|
||||
float: left;
|
||||
width: 92%;
|
||||
margin: 0 10px;
|
||||
}
|
||||
fieldset .datepicker-input {
|
||||
background: url("images/datepicker-bg.png") repeat-x scroll right top #FFFFFF !important;
|
||||
}
|
||||
|
||||
fieldset input[type=file] {
|
||||
-webkit-border-radius: 5px;
|
||||
-moz-border-radius: 5px;
|
||||
border-radius: 5px;
|
||||
color: #666666;
|
||||
border: 1px solid #BBBBBB;
|
||||
background-position: 10px 6px;
|
||||
margin: 0;
|
||||
display: block;
|
||||
float: left;
|
||||
margin: 0 10px;
|
||||
height:25px;
|
||||
}
|
||||
fieldset input[type=text]:focus {
|
||||
outline: none;
|
||||
border: 1px solid #77BACE;
|
||||
-webkit-box-shadow: inset 0 2px 2px #ccc, 0 0 10px #ADDCE6;
|
||||
-moz-box-shadow: inset 0 2px 2px #ccc, 0 0 10px #ADDCE6;
|
||||
box-shadow: inset 0 2px 2px #ccc, 0 0 10px #ADDCE6;
|
||||
}
|
||||
|
||||
fieldset select {
|
||||
width: 96%;
|
||||
margin: 0 10px;
|
||||
border: 1px solid #bbb;
|
||||
height: 20px;
|
||||
color: #666666;
|
||||
}
|
||||
|
||||
fieldset textarea {
|
||||
-webkit-border-radius: 5px;
|
||||
-moz-border-radius: 5px;
|
||||
border-radius: 5px;
|
||||
border: 1px solid #BBBBBB;
|
||||
color: #666666;
|
||||
-webkit-box-shadow: inset 0 2px 2px #ccc, 0 1px 0 #fff;
|
||||
-moz-box-shadow: inset 0 2px 2px #ccc, 0 1px 0 #fff;
|
||||
box-shadow: inset 0 2px 2px #ccc, 0 1px 0 #fff;
|
||||
padding-left: 10px;
|
||||
background-position: 10px 6px;
|
||||
margin: 0 0.5%;
|
||||
display: block;
|
||||
float: left;
|
||||
width: 96%;
|
||||
margin: 0 10px;
|
||||
}
|
||||
|
||||
fieldset textarea:focus {
|
||||
outline: none;
|
||||
border: 1px solid #77BACE;
|
||||
-webkit-box-shadow: inset 0 2px 2px #ccc, 0 0 10px #ADDCE6;
|
||||
-moz-box-shadow: inset 0 2px 2px #ccc, 0 0 10px #ADDCE6;
|
||||
box-shadow: inset 0 2px 2px #ccc, 0 0 10px #ADDCE6;
|
||||
}
|
||||
|
||||
.submit_link {
|
||||
float: right;
|
||||
margin-right: 3%;
|
||||
padding: 5px 0;
|
||||
}
|
||||
|
||||
.submit_link select {
|
||||
width: 150px;
|
||||
border: 1px solid #bbb;
|
||||
height: 20px;
|
||||
color: #666666;
|
||||
}
|
||||
|
||||
#main .module_content h1 {
|
||||
color: #333333;
|
||||
text-transform: none;
|
||||
text-shadow: 0 1px 0 #fff;
|
||||
font-size: 22px;
|
||||
margin: 8px 0px;
|
||||
}
|
||||
|
||||
#main .module_content h2 {
|
||||
color: #444444;
|
||||
text-transform: none;
|
||||
text-shadow: 0 1px 0 #fff;
|
||||
font-size: 18px;
|
||||
margin: 8px 0px;
|
||||
}
|
||||
|
||||
#main .module_content h3 {
|
||||
color: #666666;
|
||||
text-transform: uppercase;
|
||||
text-shadow: 0 1px 0 #fff;
|
||||
font-size: 13px;
|
||||
margin: 8px 0px;
|
||||
}
|
||||
|
||||
#main .module_content h4 {
|
||||
color: #666666;
|
||||
text-transform: none;
|
||||
text-shadow: 0 1px 0 #fff;
|
||||
font-size: 13px;
|
||||
margin: 8px 0px;
|
||||
}
|
||||
|
||||
#main .module_content li {
|
||||
line-height: 150%;
|
||||
}
|
||||
|
||||
/* Alerts */
|
||||
|
||||
#main h4.alert_info {
|
||||
display: block;
|
||||
width: 95%;
|
||||
margin: 20px 3% 0 3%;
|
||||
margin-top: 20px;
|
||||
-webkit-border-radius: 5px;
|
||||
-moz-border-radius: 5px;
|
||||
border-radius: 5px;
|
||||
background: #B5E5EF url(../images/icn_alert_info.png) no-repeat;
|
||||
background-position: 10px 10px;
|
||||
border: 1px solid #77BACE;
|
||||
color: #082B33;
|
||||
padding: 10px 0;
|
||||
text-indent: 40px;
|
||||
font-size: 14px;}
|
||||
|
||||
#main h4.alert_warning {
|
||||
display: block;
|
||||
width: 95%;
|
||||
margin: 20px 3% 0 3%;
|
||||
margin-top: 20px;
|
||||
-webkit-border-radius: 5px;
|
||||
-moz-border-radius: 5px;
|
||||
border-radius: 5px;
|
||||
background: #F5F3BA url(../images/icn_alert_warning.png) no-repeat;
|
||||
background-position: 10px 10px;
|
||||
border: 1px solid #C7A20D;
|
||||
color: #796616;
|
||||
padding: 10px 0;
|
||||
text-indent: 40px;
|
||||
font-size: 14px;}
|
||||
|
||||
#main h4.alert_error {
|
||||
display: block;
|
||||
width: 95%;
|
||||
margin: 20px 3% 0 3%;
|
||||
margin-top: 20px;
|
||||
-webkit-border-radius: 5px;
|
||||
-moz-border-radius: 5px;
|
||||
border-radius: 5px;
|
||||
background: #F3D9D9 url(../images/icn_alert_error.png) no-repeat;
|
||||
background-position: 10px 10px;
|
||||
border: 1px solid #D20009;
|
||||
color: #7B040F;
|
||||
padding: 10px 0;
|
||||
text-indent: 40px;
|
||||
font-size: 14px;}
|
||||
|
||||
#main h4.alert_success {
|
||||
display: block;
|
||||
width: 95%;
|
||||
margin: 20px 3% 0 3%;
|
||||
margin-top: 20px;
|
||||
-webkit-border-radius: 5px;
|
||||
-moz-border-radius: 5px;
|
||||
border-radius: 5px;
|
||||
background: #E2F6C5 url(../images/icn_alert_success.png) no-repeat;
|
||||
background-position: 10px 10px;
|
||||
border: 1px solid #79C20D;
|
||||
color: #32510F;
|
||||
padding: 10px 0;
|
||||
text-indent: 40px;
|
||||
font-size: 14px;
|
||||
}
|
||||
.toggle{
|
||||
display:none;
|
||||
}
|
||||
.trigger{
|
||||
cursor:pointer;
|
||||
}
|
||||
.width_quarter li{
|
||||
line-height:230%;
|
||||
}
|
||||
|
||||
label.error {
|
||||
display:block;
|
||||
color:#B70000;
|
||||
font-size:11px;
|
||||
font-family:"Comic Sans MS", cursive;
|
||||
font-weight:normal;
|
||||
text-transform:capitalize;
|
||||
margin-top:0;
|
||||
margin-bottom:0;
|
||||
width:100%;
|
||||
}
|
||||
input.error{ border: 1px solid #F00 !important;}
|
||||
select.error{ border: 1px solid #F00 !important;}
|
||||
textarea.error{ border: 1px solid #F00 !important;}
|
||||
img {
|
||||
border:0;
|
||||
}
|
||||
.tinyMCE{
|
||||
float:left;
|
||||
width:99%;
|
||||
padding-left:10px;
|
||||
}
|
102
admin/css/login.css
Normal file
|
@ -0,0 +1,102 @@
|
|||
/* ================= Login Form ================= */
|
||||
body{
|
||||
font-family:"Trebuchet MS","Myriad Pro",Arial,sans-serif;
|
||||
}
|
||||
.loginform{
|
||||
width:360px;
|
||||
margin:0px auto;
|
||||
margin-top: 140px;
|
||||
box-shadow:0px 4px 90px #EEEEEE;
|
||||
}
|
||||
.title{
|
||||
background:url(../images/login-title.png) no-repeat;
|
||||
text-align:center;
|
||||
height:69px;
|
||||
}
|
||||
.form_wrapper{
|
||||
padding:23px 29px 40px 29px;
|
||||
background:url(../images/login-form-body-bg.png) repeat-x bottom;}
|
||||
#password{
|
||||
border:none;
|
||||
font:19px Arial, Helvetica, sans-serif;
|
||||
color:#ccc;
|
||||
width:250px;
|
||||
border:1px solid #CED3D8;
|
||||
border-radius:3px;
|
||||
border-top:1px solid #A0A4A9;
|
||||
padding:10px;
|
||||
padding-left:40px;
|
||||
margin-bottom:19px;
|
||||
background:url(../images/password-input.png) repeat-x top;}
|
||||
.login-input-pass-active{
|
||||
border:none;
|
||||
font:19px Arial, Helvetica, sans-serif;
|
||||
color:#999;
|
||||
width:250px;
|
||||
border:1px solid #CED3D8;
|
||||
border-radius:3px;
|
||||
border-top:1px solid #A0A4A9;
|
||||
padding:10px;
|
||||
padding-left:40px;
|
||||
margin-bottom:19px;
|
||||
background:url(../images/password-input.png) repeat-x top;}
|
||||
#username{
|
||||
border:none;
|
||||
font:19px Arial, Helvetica, sans-serif;
|
||||
color:#ccc;
|
||||
width:250px;
|
||||
border:1px solid #CED3D8;
|
||||
border-radius:3px;
|
||||
border-top:1px solid #A0A4A9;
|
||||
padding:10px;
|
||||
padding-left:40px;
|
||||
margin-bottom:19px;
|
||||
background:url(../images/username-input.png) repeat-x top;}
|
||||
.login-input-user-active{
|
||||
border:none;
|
||||
font:19px Arial, Helvetica, sans-serif;
|
||||
color:#999;
|
||||
width:250px;
|
||||
border:1px solid #CED3D8;
|
||||
border-radius:3px;
|
||||
border-top:1px solid #A0A4A9;
|
||||
padding:10px;
|
||||
padding-left:40px;
|
||||
margin-bottom:19px;
|
||||
background:url(../images/username-input.png) repeat-x top;}
|
||||
|
||||
.loginform .log-lab{
|
||||
color:#A4AAB2;
|
||||
font-size:14px;
|
||||
font-weight:bold;
|
||||
display:block;
|
||||
padding-bottom:11px;}
|
||||
.button{
|
||||
width:300px;
|
||||
height:49px;
|
||||
font:bold 16px Arial, Helvetica, sans-serif;
|
||||
color:#fff;
|
||||
background:url(../images/login-button.png) no-repeat 0px 0px;
|
||||
border:none;
|
||||
cursor:pointer;
|
||||
}
|
||||
.button:hover{
|
||||
background:url(../images/login-button.png) no-repeat 0px -50px;}
|
||||
.button:active{
|
||||
background:url(../images/login-button.png) no-repeat 0px -100px;}
|
||||
.form_wrapper a.forgot {
|
||||
color: #FFA800;
|
||||
float: right;
|
||||
font-style: italic;
|
||||
line-height: 24px;
|
||||
text-shadow: 1px 1px 1px #FFFFFF;
|
||||
font-size:14px;
|
||||
font-weight:bold;
|
||||
}
|
||||
|
||||
label.error {
|
||||
display:inline; color:#B70000; font-size:11px; font-family:"Comic Sans MS", cursive;
|
||||
}
|
||||
input.error{ border: 1px solid #F00 !important;}
|
||||
select.error{ border: 1px solid #F00 !important;}
|
||||
textarea.error{ border: 1px solid #F00 !important;}
|
174
admin/edit-candidate.php
Normal file
|
@ -0,0 +1,174 @@
|
|||
<?php
|
||||
include('../config/config.php');
|
||||
include(ADMIN_HTML.'html.inc.php');
|
||||
include(ADMIN_INCLUDES.'functions.php');
|
||||
checkLoginAdmin();
|
||||
|
||||
// Query to get the details of the event to be edited
|
||||
$eventId = base64_decode($_GET['event']);
|
||||
$qryRes = mysql_fetch_array(mysql_query("SELECT Name, Description, Logo, Party FROM tbl_candidate WHERE Id = '".$eventId."'"));
|
||||
$eventFile = $qryRes['Logo'];
|
||||
|
||||
// update record
|
||||
if ( isset($_POST['submit']) )
|
||||
{
|
||||
// If new file is uploaded
|
||||
if ( !empty($_FILES['partyImage']['name']) ){
|
||||
$fileName = time().str_replace(' ', '_', $_FILES['partyImage']['name']); // replace the space with '_'
|
||||
move_uploaded_file($_FILES['partyImage']['tmp_name'],UPLOADS_PATH.'partylogo/'.$fileName);
|
||||
|
||||
// Generate Images thunmnails
|
||||
generate_image_thumbnail(UPLOADS_PATH.'partylogo/'.$fileName, UPLOADS_PATH.'partylogo/thumbs/thumb_'.$fileName,80,60);
|
||||
deleteFile(UPLOADS_PATH.'partylogo/', $eventFile); // Delete the file
|
||||
deleteFile(UPLOADS_PATH.'partylogo/thumbs/', 'thumb_'.$eventFile); // Delete the thumbnail of the file
|
||||
|
||||
// Now update the record
|
||||
$updateQry = "UPDATE tbl_candidate
|
||||
SET
|
||||
Name = '".clean($_POST['candi_title'])."',
|
||||
Description = '".clean($_POST['candiDes'])."',
|
||||
Logo = '".$fileName."',
|
||||
Party = '".clean($_POST['candi_party'])."'
|
||||
WHERE Id = '".$eventId."'";
|
||||
mysql_query($updateQry);
|
||||
}
|
||||
else
|
||||
{
|
||||
$updateQry = "UPDATE tbl_candidate
|
||||
SET
|
||||
Name = '".clean($_POST['candi_title'])."',
|
||||
Description = '".clean($_POST['candiDes'])."',
|
||||
Party = '".clean($_POST['candi_party'])."'
|
||||
WHERE Id = '".$eventId."'";
|
||||
mysql_query($updateQry);
|
||||
}
|
||||
$redirectUrl = 'view-candidates.php';
|
||||
$_SESSION['succesMessage'] = 5;
|
||||
header("Location: $redirectUrl");
|
||||
}
|
||||
|
||||
|
||||
startHtml($title = "Edit Candidate");
|
||||
tophead($title);
|
||||
leftNav();
|
||||
|
||||
?>
|
||||
<script type="text/javascript">
|
||||
tinyMCE.init({
|
||||
mode : "textareas",
|
||||
theme : "simple",
|
||||
// update validation status on change
|
||||
onchange_callback: function(editor) {
|
||||
tinyMCE.triggerSave();
|
||||
$("#" + editor.id).valid();
|
||||
}
|
||||
});
|
||||
|
||||
jQuery.validator.addMethod("imageExt", function(value, element) {
|
||||
return this.optional(element) || /^.*\.(jpg|jpeg|gif|JPG|png|PNG)$/.test(value);
|
||||
}, ("Only [jpeg, gif, JPG, PNG] formats are allowed."));
|
||||
|
||||
// Form validation
|
||||
$(function() {
|
||||
var validator = $("#editEventForm").submit(function() {
|
||||
// update underlying textarea before submit validation
|
||||
tinyMCE.triggerSave();
|
||||
}).validate({
|
||||
ignore: "",
|
||||
rules: {
|
||||
event_title: "required",
|
||||
eventDes: "required",
|
||||
eventImage: "imageExt"
|
||||
},
|
||||
messages: {
|
||||
event_title: "Enter event title.",
|
||||
eventDes: "Enter event description."
|
||||
},
|
||||
errorPlacement: function(label, element) {
|
||||
// position error label after generated textarea
|
||||
if (element.is("textarea")) {
|
||||
label.insertAfter(element.next());
|
||||
} else {
|
||||
label.insertAfter(element)
|
||||
}
|
||||
}
|
||||
});
|
||||
validator.focusInvalid = function() {
|
||||
// put focus on tinymce on submit validation
|
||||
if( this.settings.focusInvalid ) {
|
||||
try {
|
||||
var toFocus = $(this.findLastActive() || this.errorList.length && this.errorList[0].element || []);
|
||||
if (toFocus.is("textarea")) {
|
||||
tinyMCE.get(toFocus.attr("id")).focus();
|
||||
} else {
|
||||
toFocus.filter(":visible").focus();
|
||||
}
|
||||
} catch(e) {
|
||||
// ignore IE throwing errors when focusing hidden elements
|
||||
}
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
</script>
|
||||
|
||||
<section id="main" class="column">
|
||||
<article class="module width_full">
|
||||
<header>
|
||||
<h3>Edit Candidate</h3>
|
||||
</header>
|
||||
<form name="editCandiForm" id="editCandiForm" action="" method="post" enctype="multipart/form-data">
|
||||
<fieldset style="margin:15px">
|
||||
<table width="100%">
|
||||
<tr>
|
||||
<td>
|
||||
<label>Candidate Name</label>
|
||||
<input type="text" name="candi_title" id="candi_title" value="<?php echo $qryRes['Name'];?>" />
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>
|
||||
<label>Party</label>
|
||||
<input type="text" name="candi_party" id="candi_party" value="<?php echo $qryRes['Party'];?>" />
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>
|
||||
<label>Event Description</label>
|
||||
<span class="tinyMCE"><textarea id="candiDes" name="candiDes" rows="15" cols="80" style="width: 99%;float:left;"><?php echo $qryRes['Description'];?></textarea></span>
|
||||
<label for="candiDes" class="error" style="display:none;">Enter event description.</label>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>
|
||||
<label>Event Image</label>
|
||||
<input type="file" name="partyImage" id="partyImage" />
|
||||
<a href="<?php echo UPLOADS_URL.'partylogo/'.$eventFile;?>" class="lightbox"><img src="<?php echo UPLOADS_URL.'partylogo/thumbs/thumb_'.$eventFile;?>" style="margin-top:-20px;" /></a>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>
|
||||
<input type="submit" name="submit" id="submit" value="Update" />
|
||||
<input type="button" name="cancel" id="cancel" value="Cancel" onclick="window.location='<?php echo ADMIN_URL;?>view-candidates.php'" />
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
</fieldset>
|
||||
</form>
|
||||
</article>
|
||||
<div class="spacer"></div>
|
||||
</section>
|
||||
|
||||
<script type="text/javascript" src="<?php echo LIGHTBOX;?>js/jquery.min.js"></script>
|
||||
<link rel="stylesheet" type="text/css" href="<?php echo LIGHTBOX;?>themes/default/jquery.lightbox.css" />
|
||||
<!--[if IE 6]><link rel="stylesheet" type="text/css" href="<?php echo LIGHTBOX;?>themes/default/jquery.lightbox.ie6.css" /><![endif]-->
|
||||
<script type="text/javascript" src="<?php echo LIGHTBOX;?>js/jquery.lightbox.js"></script>
|
||||
<script type="text/javascript">
|
||||
jQuery.noConflict();
|
||||
jQuery(document).ready(function(){
|
||||
jQuery('.lightbox').lightbox();
|
||||
});
|
||||
</script>
|
||||
<?php
|
||||
endHtml();
|
||||
?>
|
120
admin/edit-question.php
Normal file
|
@ -0,0 +1,120 @@
|
|||
<?php
|
||||
include('../config/config.php');
|
||||
include(ADMIN_HTML.'html.inc.php');
|
||||
include(ADMIN_INCLUDES.'functions.php');
|
||||
checkLoginAdmin();
|
||||
|
||||
// Query to get the details of the Question to be edited
|
||||
$faqId = clean(base64_decode($_GET['quest']));
|
||||
$qryRes = mysql_fetch_array(mysql_query("SELECT Id, Heading, Question FROM tbl_questions WHERE Id = '".$faqId."'"));
|
||||
|
||||
// Update the record
|
||||
if ( isset($_POST['submit']) ){
|
||||
|
||||
if ( !empty($_POST['question']) ){
|
||||
$updateQry = "UPDATE tbl_questions
|
||||
SET
|
||||
Heading = '".clean($_POST['title'])."',
|
||||
Question = '".clean($_POST['question'])."'
|
||||
WHERE Id = '".$faqId."'";
|
||||
mysql_query($updateQry);
|
||||
}
|
||||
$redirectUrl = 'view-questions.php';
|
||||
$_SESSION['succesMessage'] = 5;
|
||||
header("Location: $redirectUrl");
|
||||
}
|
||||
|
||||
|
||||
startHtml($title = "Edit Question");
|
||||
tophead($title);
|
||||
leftNav();
|
||||
?>
|
||||
|
||||
<script type="text/javascript" src="<?php echo TINYMCE;?>jscripts/tiny_mce/tiny_mce.js"></script>
|
||||
<script type="text/javascript">
|
||||
tinyMCE.init({
|
||||
mode : "textareas",
|
||||
theme : "simple",
|
||||
// update validation status on change
|
||||
onchange_callback: function(editor) {
|
||||
tinyMCE.triggerSave();
|
||||
$("#" + editor.id).valid();
|
||||
}
|
||||
});
|
||||
$(function() {
|
||||
var validator = $("#editQuestForm").submit(function() {
|
||||
// update underlying textarea before submit validation
|
||||
tinyMCE.triggerSave();
|
||||
}).validate({
|
||||
ignore: "",
|
||||
rules: {
|
||||
title: "required",
|
||||
question: "required"
|
||||
},
|
||||
messages: {
|
||||
title: "Enter question title.",
|
||||
question: "Enter question description."
|
||||
},
|
||||
errorPlacement: function(label, element) {
|
||||
// position error label after generated textarea
|
||||
if (element.is("textarea")) {
|
||||
label.insertAfter(element.next());
|
||||
} else {
|
||||
label.insertAfter(element)
|
||||
}
|
||||
}
|
||||
});
|
||||
validator.focusInvalid = function() {
|
||||
// put focus on tinymce on submit validation
|
||||
if( this.settings.focusInvalid ) {
|
||||
try {
|
||||
var toFocus = $(this.findLastActive() || this.errorList.length && this.errorList[0].element || []);
|
||||
if (toFocus.is("textarea")) {
|
||||
tinyMCE.get(toFocus.attr("id")).focus();
|
||||
} else {
|
||||
toFocus.filter(":visible").focus();
|
||||
}
|
||||
} catch(e) {
|
||||
// ignore IE throwing errors when focusing hidden elements
|
||||
}
|
||||
}
|
||||
}
|
||||
});
|
||||
</script>
|
||||
<section id="main" class="column">
|
||||
<article class="module width_full">
|
||||
<header>
|
||||
<h3>Edit Question</h3>
|
||||
</header>
|
||||
<form name="editQuestForm" id="editQuestForm" action="" method="post">
|
||||
<fieldset style="margin:15px">
|
||||
<table width="100%">
|
||||
<tr>
|
||||
<td>
|
||||
<label>Title</label>
|
||||
<input type="text" name="title" id="title" value="<?php echo $qryRes['Heading'];?>" />
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>
|
||||
<label>Question</label>
|
||||
<span class="tinyMCE"><textarea id="question" name="question" rows="15" cols="80" style="width: 99%;float:left;"><?php echo $qryRes['Question'];?></textarea></span>
|
||||
<label for="question" class="error" style="display:none;">Enter Question Description.</label>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>
|
||||
<input type="submit" name="submit" id="submit" value="Update" />
|
||||
<input type="button" name="cancel" id="cancel" value="Cancel" onclick="window.location='<?php echo ADMIN_URL;?>view-questions.php'" />
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
</fieldset>
|
||||
</form>
|
||||
</article>
|
||||
<div class="spacer"></div>
|
||||
</section>
|
||||
|
||||
<?php
|
||||
endHtml();
|
||||
?>
|
130
admin/html/html.inc.php
Normal file
|
@ -0,0 +1,130 @@
|
|||
<?php
|
||||
function startHtml($title)
|
||||
{
|
||||
?>
|
||||
<!doctype html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8"/>
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
|
||||
<title><?php echo "Voting Advice Application :: ". $title; ?></title>
|
||||
|
||||
<link rel="stylesheet" href="<?php echo ADMIN_CSS;?>layout.css" type="text/css" media="screen" />
|
||||
<link rel="stylesheet" href="<?php echo ADMIN_CSS;?>datatable_jui.css" type="text/css" media="screen" />
|
||||
<link rel="stylesheet" type="text/css" href="<?php echo ADMIN_CSS;?>jquery.ui.theme.css" />
|
||||
<link rel="stylesheet" type="text/css" href="<?php echo ADMIN_CSS;?>datatable_jui.css" />
|
||||
<link rel="stylesheet" type="text/css" href="<?php echo ADMIN_CSS;?>jquery.ui.core.css" />
|
||||
<link rel="stylesheet" type="text/css" href="<?php echo ADMIN_CSS;?>jquery.ui.datepicker.css" />
|
||||
<!--[if lt IE 9]>
|
||||
<link rel="stylesheet" href="<?php echo ADMIN_CSS;?>ie.css" type="text/css" media="screen" />
|
||||
<script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
|
||||
<![endif]-->
|
||||
<script src="<?php echo ADMIN_JS;?>jquery-1.7.min.js" type="text/javascript"></script>
|
||||
<script src="<?php echo ADMIN_JS;?>jquery.validate.js" type="text/javascript"></script>
|
||||
<script src="<?php echo ADMIN_JS;?>jquery.dataTables.js" type="text/javascript"></script>
|
||||
<script type="text/javascript" src="<?php echo ADMIN_JS;?>jquery.ui.datepicker.js"></script>
|
||||
<script type="text/javascript" src="<?php echo ADMIN_JS;?>jquery-ui-1.8.11.custom.min.js"></script>
|
||||
<script type="text/javascript" src="<?php echo ADMIN_JS;?>ddaccordion.js"> </script>
|
||||
<script type="text/javascript" src="<?php echo TINYMCE;?>tiny_mce.js"></script>
|
||||
<script type="text/javascript">
|
||||
$(document).ready(function() {
|
||||
oTable = $('#myTable').dataTable({
|
||||
"bJQueryUI": true,
|
||||
"sPaginationType": "full_numbers"
|
||||
});
|
||||
});
|
||||
</script>
|
||||
<script type="text/javascript">
|
||||
ddaccordion.init({
|
||||
headerclass: "trigger", //Shared CSS class name of headers group
|
||||
contentclass: "toggle", //Shared CSS class name of contents group
|
||||
revealtype: "click", //Reveal content when user clicks or onmouseover the header? Valid value: "click", "clickgo", or "mouseover"
|
||||
mouseoverdelay: 200, //if revealtype="mouseover", set delay in milliseconds before header expands onMouseover
|
||||
collapseprev: true, //Collapse previous content (so only one open at any time)? true/false
|
||||
defaultexpanded: [], //index of content(s) open by default [index1, index2, etc] [] denotes no content
|
||||
onemustopen: false, //Specify whether at least one header should be open always (so never all headers closed)
|
||||
animatedefault: false, //Should contents open by default be animated into view?
|
||||
persiststate: true, //persist state of opened contents within browser session?
|
||||
toggleclass: ["", "selected"], //Two CSS classes to be applied to the header when it's collapsed and expanded, respectively ["class1", "class2"]
|
||||
togglehtml: ["", "", ""], //Additional HTML added to the header when it's collapsed and expanded, respectively ["position", "html1", "html2"] (see docs)
|
||||
animatespeed: 300, //speed of animation: integer in milliseconds (ie: 200), or keywords "fast", "normal", or "slow"
|
||||
oninit:function(headers, expandedindices){ //custom code to run when headers have initalized
|
||||
//do nothing
|
||||
},
|
||||
onopenclose:function(header, index, state, isuseractivated){ //custom code to run whenever a header is opened or closed
|
||||
//do nothing
|
||||
}
|
||||
})
|
||||
</script>
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<?php
|
||||
}
|
||||
|
||||
function tophead($title)
|
||||
{
|
||||
?>
|
||||
|
||||
<header id="header">
|
||||
<hgroup>
|
||||
<h1 class="site_title"><a href="index.php">Website Setup</a></h1>
|
||||
<?php
|
||||
?>
|
||||
<h2 class="section_title">Voting Advice Application Dashboard</h2><div class="btn_view_site"><a href="<?php echo SITE_URL;?>delete.php" title="Finish Setup">Finish</a></div>
|
||||
<?php
|
||||
?>
|
||||
</hgroup>
|
||||
</header> <!-- end of header bar -->
|
||||
|
||||
<section id="secondary_bar">
|
||||
<div class="user">
|
||||
<p>Welcome</p>
|
||||
<a class="logout_user" href="<?php echo ADMIN_URL;?>logout.php" title="Logout">Logout</a>
|
||||
</div>
|
||||
<div class="breadcrumbs_container">
|
||||
<article class="breadcrumbs"><a href="<?php echo ADMIN_URL;?>">Website Admin</a> <div class="breadcrumb_divider"></div> <a class="current"><?php echo $title;?></a></article>
|
||||
</div>
|
||||
</section><!-- end of secondary bar -->
|
||||
<?php
|
||||
}
|
||||
|
||||
function leftNav()
|
||||
{
|
||||
?>
|
||||
<aside id="sidebar" class="column">
|
||||
|
||||
<h3 class="trigger" style="margin-top:20px;">Account Management</h3>
|
||||
<ul class="toggle">
|
||||
<li class="icn_edit_article"><a href="<?php echo ADMIN_URL;?>change-password.php">Change Password</a></li>
|
||||
</ul>
|
||||
<h3 class="trigger">Candidates Management</h3>
|
||||
<ul class="toggle">
|
||||
<li class="icn_new_article"><a href="<?php echo ADMIN_URL;?>add-candidate.php">Add Candidates</a></li>
|
||||
<li class="icn_view"><a href="<?php echo ADMIN_URL;?>view-candidates.php">View Candidates</a></li>
|
||||
</ul>
|
||||
<h3 class="trigger">Questions Management</h3>
|
||||
<ul class="toggle">
|
||||
<li class="icn_new_article"><a href="<?php echo ADMIN_URL;?>add-question.php">Add Questions</a></li>
|
||||
<li class="icn_view"><a href="<?php echo ADMIN_URL;?>view-questions.php">View Questions</a></li>
|
||||
</ul>
|
||||
<h3 class="trigger">Response Management</h3>
|
||||
<ul class="toggle">
|
||||
<li class="icn_new_article"><a href="<?php echo ADMIN_URL;?>add-response.php">Add Responses</a></li>
|
||||
</ul>
|
||||
|
||||
</aside>
|
||||
<!-- end of sidebar -->
|
||||
<?php
|
||||
}
|
||||
|
||||
function endHtml()
|
||||
{
|
||||
?>
|
||||
|
||||
</body>
|
||||
|
||||
</html>
|
||||
<?php
|
||||
}
|
||||
?>
|
BIN
admin/images/Thumbs.db
Normal file
BIN
admin/images/_btn_view_site.png
Normal file
After Width: | Height: | Size: 1.5 KiB |
BIN
admin/images/_header_bg.png
Normal file
After Width: | Height: | Size: 2.9 KiB |
BIN
admin/images/_header_shadow.png
Normal file
After Width: | Height: | Size: 1.1 KiB |
BIN
admin/images/_login-button.png
Normal file
After Width: | Height: | Size: 1.7 KiB |
BIN
admin/images/_login-title.png
Normal file
After Width: | Height: | Size: 623 B |
BIN
admin/images/breadcrumb_divider.png
Normal file
After Width: | Height: | Size: 210 B |
BIN
admin/images/btn_submit.png
Normal file
After Width: | Height: | Size: 217 B |
BIN
admin/images/btn_submit_2.png
Normal file
After Width: | Height: | Size: 214 B |
BIN
admin/images/btn_view_site.png
Normal file
After Width: | Height: | Size: 897 B |
BIN
admin/images/header-bg.png
Normal file
After Width: | Height: | Size: 910 B |
BIN
admin/images/header_bg.png
Normal file
After Width: | Height: | Size: 205 B |
BIN
admin/images/header_shadow.png
Normal file
After Width: | Height: | Size: 194 B |
BIN
admin/images/icn_add_user.png
Normal file
After Width: | Height: | Size: 462 B |
BIN
admin/images/icn_alert_error.png
Normal file
After Width: | Height: | Size: 386 B |
BIN
admin/images/icn_alert_info.png
Normal file
After Width: | Height: | Size: 434 B |
BIN
admin/images/icn_alert_success.png
Normal file
After Width: | Height: | Size: 347 B |
BIN
admin/images/icn_alert_warning.png
Normal file
After Width: | Height: | Size: 418 B |
BIN
admin/images/icn_audio.png
Normal file
After Width: | Height: | Size: 643 B |
BIN
admin/images/icn_categories.png
Normal file
After Width: | Height: | Size: 251 B |
BIN
admin/images/icn_edit.png
Normal file
After Width: | Height: | Size: 357 B |
BIN
admin/images/icn_edit_article.png
Normal file
After Width: | Height: | Size: 467 B |
BIN
admin/images/icn_folder.png
Normal file
After Width: | Height: | Size: 309 B |
BIN
admin/images/icn_jump_back.png
Normal file
After Width: | Height: | Size: 489 B |
BIN
admin/images/icn_logout.png
Normal file
After Width: | Height: | Size: 443 B |
BIN
admin/images/icn_new_article.png
Normal file
After Width: | Height: | Size: 290 B |
BIN
admin/images/icn_photo.png
Normal file
After Width: | Height: | Size: 336 B |
BIN
admin/images/icn_profile.png
Normal file
After Width: | Height: | Size: 485 B |
BIN
admin/images/icn_search.png
Normal file
After Width: | Height: | Size: 429 B |
BIN
admin/images/icn_security.png
Normal file
After Width: | Height: | Size: 465 B |
BIN
admin/images/icn_settings.png
Normal file
After Width: | Height: | Size: 272 B |
BIN
admin/images/icn_tags.png
Normal file
After Width: | Height: | Size: 292 B |
BIN
admin/images/icn_trash.png
Normal file
After Width: | Height: | Size: 284 B |
BIN
admin/images/icn_user.png
Normal file
After Width: | Height: | Size: 489 B |
BIN
admin/images/icn_video.png
Normal file
After Width: | Height: | Size: 311 B |
BIN
admin/images/icn_view_users.png
Normal file
After Width: | Height: | Size: 528 B |
BIN
admin/images/login-button.png
Normal file
After Width: | Height: | Size: 935 B |
BIN
admin/images/login-form-body-bg.png
Normal file
After Width: | Height: | Size: 2.4 KiB |
BIN
admin/images/login-title.png
Normal file
After Width: | Height: | Size: 582 B |
BIN
admin/images/logo.png
Normal file
After Width: | Height: | Size: 3.8 KiB |
BIN
admin/images/module_footer_bg.png
Normal file
After Width: | Height: | Size: 233 B |
BIN
admin/images/password-input.png
Normal file
After Width: | Height: | Size: 562 B |
BIN
admin/images/post_message.png
Normal file
After Width: | Height: | Size: 1.4 KiB |
BIN
admin/images/secondary_bar.png
Normal file
After Width: | Height: | Size: 263 B |
BIN
admin/images/secondary_bar_shadow.png
Normal file
After Width: | Height: | Size: 498 B |
BIN
admin/images/sidebar.png
Normal file
After Width: | Height: | Size: 1.9 KiB |
BIN
admin/images/sidebar_divider.png
Normal file
After Width: | Height: | Size: 203 B |
BIN
admin/images/sidebar_shadow.png
Normal file
After Width: | Height: | Size: 204 B |
BIN
admin/images/table_sorter_header.png
Normal file
After Width: | Height: | Size: 239 B |
BIN
admin/images/username-input.png
Normal file
After Width: | Height: | Size: 515 B |
BIN
admin/images/view.png
Normal file
After Width: | Height: | Size: 1.6 KiB |
BIN
admin/images/vote.png
Normal file
After Width: | Height: | Size: 17 KiB |
156
admin/includes/functions.php
Normal file
|
@ -0,0 +1,156 @@
|
|||
<?php
|
||||
/****************************************************/
|
||||
// Filename: functions.php
|
||||
// Author: Muhammad Waqas Azeem
|
||||
// Created Date: 2012-10-15
|
||||
// Description: Different functions used in the application
|
||||
/****************************************************/
|
||||
//// Function to protect SQL Injection
|
||||
function clean($str)
|
||||
{
|
||||
$str = @trim($str);
|
||||
if(get_magic_quotes_gpc()) {
|
||||
$str = addslashes($str);
|
||||
}
|
||||
return mysql_real_escape_string($str);
|
||||
}
|
||||
|
||||
// Function to check the login status For the ADMIN
|
||||
function checkLoginAdmin()
|
||||
{
|
||||
if (!isset($_SESSION['user_login_id']) || empty($_SESSION['user_login_id']) ){
|
||||
$url = ADMIN_URL."login.php";
|
||||
header("Location: $url");
|
||||
}
|
||||
}
|
||||
|
||||
/// Function that will capitalized 1st Chanrater of each word.
|
||||
function capitalize($str)
|
||||
{
|
||||
$lowercaseTitle = strtolower($str);
|
||||
$ucTitleString = ucwords($lowercaseTitle);
|
||||
return $ucTitleString;
|
||||
}
|
||||
// Function that will delete the file physically from the directory.
|
||||
function deleteFile($dir, $fileName)
|
||||
{
|
||||
$handle=opendir($dir);
|
||||
|
||||
while (($file = readdir($handle))!==false)
|
||||
{
|
||||
if ($file == $fileName)
|
||||
{
|
||||
@unlink($dir.'/'.$file);
|
||||
}
|
||||
}
|
||||
closedir($handle);
|
||||
}
|
||||
|
||||
//Generate thumbnail of Image file
|
||||
function generate_image_thumbnail($source_image_path, $thumbnail_image_path,$width,$height)
|
||||
{
|
||||
list( $source_image_width, $source_image_height, $source_image_type ) = getimagesize( $source_image_path );
|
||||
switch ( $source_image_type )
|
||||
{
|
||||
case IMAGETYPE_GIF:
|
||||
$source_gd_image = imagecreatefromgif( $source_image_path );
|
||||
break;
|
||||
|
||||
case IMAGETYPE_JPEG:
|
||||
$source_gd_image = imagecreatefromjpeg( $source_image_path );
|
||||
break;
|
||||
|
||||
case IMAGETYPE_PNG:
|
||||
$source_gd_image = imagecreatefrompng( $source_image_path );
|
||||
break;
|
||||
}
|
||||
|
||||
if ( $source_gd_image === false ) {
|
||||
return false;
|
||||
}
|
||||
|
||||
$thumbnail_image_width = $width;
|
||||
$thumbnail_image_height = $height;
|
||||
|
||||
$source_aspect_ratio = $source_image_width / $source_image_height;
|
||||
$thumbnail_aspect_ratio = $thumbnail_image_width / $thumbnail_image_height;
|
||||
|
||||
if ( $source_image_width <= $thumbnail_image_width && $source_image_height <= $thumbnail_image_height )
|
||||
{
|
||||
$thumbnail_image_width = $source_image_width;
|
||||
$thumbnail_image_height = $source_image_height;
|
||||
}
|
||||
elseif ( $thumbnail_aspect_ratio > $source_aspect_ratio )
|
||||
{
|
||||
$thumbnail_image_width = ( int ) ( $thumbnail_image_height * $source_aspect_ratio );
|
||||
}else
|
||||
{
|
||||
$thumbnail_image_height = ( int ) ( $thumbnail_image_width / $source_aspect_ratio );
|
||||
}
|
||||
|
||||
$thumbnail_gd_image = imagecreatetruecolor( $thumbnail_image_width, $thumbnail_image_height );
|
||||
/*var_export(imagecopyresampled( $thumbnail_gd_image, $source_gd_image, 0, 0, 0, 0, $thumbnail_image_width, $thumbnail_image_height, $source_image_width, $source_image_height ) ); exit();*/
|
||||
imagecopyresampled( $thumbnail_gd_image, $source_gd_image, 0, 0, 0, 0, $thumbnail_image_width, $thumbnail_image_height, $source_image_width, $source_image_height );
|
||||
|
||||
//var_export( imagejpeg( $thumbnail_gd_image, $thumbnail_image_path, 90 )); exit();
|
||||
imagejpeg( $thumbnail_gd_image, $thumbnail_image_path, 90 );
|
||||
|
||||
imagedestroy( $source_gd_image );
|
||||
|
||||
imagedestroy( $thumbnail_gd_image );
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
/// Functions to display error messages
|
||||
function successMsg($e)
|
||||
{
|
||||
if($e == 1){
|
||||
$msg = "Password has been sent to your email.";
|
||||
}if($e == 2){
|
||||
$msg = "Password has been updated.";
|
||||
}if($e == 3){
|
||||
$msg = "Email has been updated.";
|
||||
}if($e == 4){
|
||||
$msg = "Record has been added.";
|
||||
}if($e == 5){
|
||||
$msg = "Record has been updated.";
|
||||
}if($e == 6){
|
||||
$msg = "Record has been deleted.";
|
||||
}
|
||||
//echo "<div style='color:#060;font-family:\"Comic Sans MS\",cursive;font-size:15px;'>$msg</div>";
|
||||
|
||||
?>
|
||||
<link rel="stylesheet" type="text/css" href="<?php echo NOTIFICATIONS;?>css/jquery_notification.css" />
|
||||
<script type="text/javascript" src="<?php echo NOTIFICATIONS;?>js/jquery_notification_v.1.js"></script>
|
||||
<script type="text/javascript">
|
||||
showNotification({
|
||||
message: "<?php echo $msg; ?>",
|
||||
type: "success",
|
||||
autoClose: true,
|
||||
duration: 5
|
||||
});
|
||||
</script>
|
||||
<?php
|
||||
}
|
||||
|
||||
function errorMsg($error)
|
||||
{
|
||||
if($error == 1){
|
||||
$errMsg = "Invalid password.";
|
||||
}
|
||||
?>
|
||||
|
||||
<link rel="stylesheet" type="text/css" href="<?php echo NOTIFICATIONS;?>css/jquery_notification.css" />
|
||||
<script type="text/javascript" src="<?php echo NOTIFICATIONS;?>js/jquery_notification_v.1.js"></script>
|
||||
<script type="text/javascript">
|
||||
showNotification({
|
||||
message: "<?php echo $errMsg; ?>",
|
||||
type: "error",
|
||||
autoClose: true,
|
||||
duration: 5
|
||||
});
|
||||
</script>
|
||||
<?php
|
||||
}
|
||||
?>
|
57
admin/index.php
Normal file
|
@ -0,0 +1,57 @@
|
|||
<?php
|
||||
include('../config/config.php');
|
||||
include(ADMIN_HTML.'html.inc.php');
|
||||
include(ADMIN_INCLUDES.'functions.php');
|
||||
checkLoginAdmin();
|
||||
|
||||
startHtml($title = "Dashboard");
|
||||
tophead($title);
|
||||
leftNav();
|
||||
?>
|
||||
<?php
|
||||
if ( isset($_SESSION['succesMessage']) )
|
||||
{
|
||||
successMsg($_SESSION['succesMessage']);
|
||||
unset($_SESSION['succesMessage']);
|
||||
}
|
||||
?>
|
||||
<section id="main" class="column">
|
||||
|
||||
<article class="module width_quarter">
|
||||
<header>
|
||||
<h3>Candidates Management</h3>
|
||||
</header>
|
||||
<ul>
|
||||
<li class="icn_new_article"><a href="<?php echo ADMIN_URL;?>add-candidate.php">Add Candidate</a></li>
|
||||
<li class="icn_view"><a href="<?php echo ADMIN_URL;?>view-candidates.php">View Candidates</a></li>
|
||||
</ul>
|
||||
</article>
|
||||
|
||||
<article class="module width_quarter">
|
||||
<header>
|
||||
<h3>Questions Management</h3>
|
||||
</header>
|
||||
<ul>
|
||||
<li class="icn_new_article"><a href="<?php echo ADMIN_URL;?>add-question.php">Add Question</a></li>
|
||||
<li class="icn_view"><a href="<?php echo ADMIN_URL;?>view-questions.php">View Questions</a></li>
|
||||
</ul>
|
||||
</article>
|
||||
|
||||
<article class="module width_quarter">
|
||||
<header>
|
||||
<h3>Response Management</h3>
|
||||
</header>
|
||||
<ul>
|
||||
<li class="icn_new_article"><a href="<?php echo ADMIN_URL;?>add-response.php">Add Question Response</a></li>
|
||||
</ul>
|
||||
</article>
|
||||
|
||||
|
||||
|
||||
|
||||
<div class="spacer"></div>
|
||||
</section>
|
||||
|
||||
<?php
|
||||
endHtml();
|
||||
?>
|
60
admin/js/accounts.js
Normal file
|
@ -0,0 +1,60 @@
|
|||
// JavaScript Document
|
||||
//login page javascript
|
||||
|
||||
$(document).ready(function() {
|
||||
// Change password form validation
|
||||
$("#changePassForm").validate({
|
||||
rules: {
|
||||
oldPassword: {
|
||||
required: true,
|
||||
equalTo: "#oldHidPass"
|
||||
},
|
||||
newPassword: {
|
||||
required: true,
|
||||
minlength: 6
|
||||
},
|
||||
confirmPassword: {
|
||||
required: true,
|
||||
equalTo: "#newPassword"
|
||||
}
|
||||
},
|
||||
messages: {
|
||||
oldPassword: {
|
||||
required: "Enter old password.",
|
||||
equalTo: "Wrong old password."
|
||||
},
|
||||
newPassword: {
|
||||
required: "Enter new password.",
|
||||
minlength: "Enter at least 6 characters."
|
||||
},
|
||||
confirmPassword: {
|
||||
required: "Confirm new password.",
|
||||
equalTo: "Enter same password as above."
|
||||
}
|
||||
}
|
||||
});
|
||||
// Change Email form validation
|
||||
$("#changeEmailForm").validate({
|
||||
rules: {
|
||||
username: {
|
||||
required: true,
|
||||
equalTo: "#usernameHidd"
|
||||
},
|
||||
newEmail: {
|
||||
required: true,
|
||||
email: true
|
||||
}
|
||||
},
|
||||
messages: {
|
||||
username: {
|
||||
required: "Enter old email.",
|
||||
equalTo: "Old email did not match in the system."
|
||||
},
|
||||
newEmail: {
|
||||
required: "Enter new email address.",
|
||||
email: "Invalid email address."
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
});
|
209
admin/js/ddaccordion.js
Normal file
|
@ -0,0 +1,209 @@
|
|||
//** Accordion Content script: By Dynamic Drive, at http://www.dynamicdrive.com
|
||||
//** Created: Jan 7th, 08'
|
||||
|
||||
//Version 1.3: April 3rd, 08':
|
||||
//**1) Script now no longer conflicts with other JS frameworks
|
||||
//**2) Adds custom oninit() and onopenclose() event handlers that fire when Accordion Content instance has initialized, plus whenever a header is opened/closed
|
||||
//**3) Adds support for expanding header(s) using the URL parameter (ie: http://mysite.com/accordion.htm?headerclass=0,1)
|
||||
|
||||
//April 9th, 08': Fixed "defaultexpanded" setting not working when page first loads
|
||||
|
||||
//Version 1.4: June 4th, 08':
|
||||
//**1) Added option to activate a header "mouseover" instead of the default "click"
|
||||
//**2) Bug persistence not working when used with jquery 1.2.6
|
||||
|
||||
//Version 1.5: June 20th, 08':
|
||||
//**1) Adds new "onemustopen:true/false" parameter, which lets you set whether at least one header should be open at all times (so never all closed).
|
||||
//**2) Changed cookie path to site wide for persistence feature
|
||||
//**3) Fixed bug so "expandedindices" parameter in oninit(headers, expandedindices) returns empty array [] instead of [-1] when no expanded headers found
|
||||
|
||||
//**1) Version 1.5.1: June 27th, 08': Fixed "defaultexpanded" setting not working properly when used with jquery 1.2.6
|
||||
|
||||
//Version 1.6: Oct 3rd, 08':
|
||||
//**1) Adds new "mouseoverdelay" param that sets delay before headers are activated when "revealtype" param is set to "mouseover"
|
||||
//**2) Fixed bug with "onemustopen" param not working properly when "revealtype" is set to "click"
|
||||
|
||||
//Version 1.7: March 24th, 09': Adds a 3rd revealtype setting "clickgo", which causes browser to navigate to URL specified inside the header after expanding its contents.
|
||||
|
||||
//Version 1.7.1: May 28th, 09': Fixed issue that causes margins/paddings in accordion DIVs to be lost in IE8
|
||||
|
||||
|
||||
var ddaccordion={
|
||||
|
||||
contentclassname:{}, //object to store corresponding contentclass name based on headerclass
|
||||
|
||||
expandone:function(headerclass, selected){ //PUBLIC function to expand a particular header
|
||||
this.toggleone(headerclass, selected, "expand")
|
||||
},
|
||||
|
||||
collapseone:function(headerclass, selected){ //PUBLIC function to collapse a particular header
|
||||
this.toggleone(headerclass, selected, "collapse")
|
||||
},
|
||||
|
||||
expandall:function(headerclass){ //PUBLIC function to expand all headers based on their shared CSS classname
|
||||
var $=jQuery
|
||||
var $headers=$('.'+headerclass)
|
||||
$('.'+this.contentclassname[headerclass]+':hidden').each(function(){
|
||||
$headers.eq(parseInt($(this).attr('contentindex'))).trigger("evt_accordion")
|
||||
})
|
||||
},
|
||||
|
||||
collapseall:function(headerclass){ //PUBLIC function to collapse all headers based on their shared CSS classname
|
||||
var $=jQuery
|
||||
var $headers=$('.'+headerclass)
|
||||
$('.'+this.contentclassname[headerclass]+':visible').each(function(){
|
||||
$headers.eq(parseInt($(this).attr('contentindex'))).trigger("evt_accordion")
|
||||
})
|
||||
},
|
||||
|
||||
toggleone:function(headerclass, selected, optstate){ //PUBLIC function to expand/ collapse a particular header
|
||||
var $=jQuery
|
||||
var $targetHeader=$('.'+headerclass).eq(selected)
|
||||
var $subcontent=$('.'+this.contentclassname[headerclass]).eq(selected)
|
||||
if (typeof optstate=="undefined" || optstate=="expand" && $subcontent.is(":hidden") || optstate=="collapse" && $subcontent.is(":visible"))
|
||||
$targetHeader.trigger("evt_accordion")
|
||||
},
|
||||
|
||||
expandit:function($targetHeader, $targetContent, config, useractivated, directclick){
|
||||
this.transformHeader($targetHeader, config, "expand")
|
||||
$targetContent.slideDown(config.animatespeed, function(){
|
||||
config.onopenclose($targetHeader.get(0), parseInt($targetHeader.attr('headerindex')), $targetContent.css('display'), useractivated)
|
||||
if (config.postreveal=="gotourl" && directclick){ //if revealtype is "Go to Header URL upon click", and this is a direct click on the header
|
||||
var targetLink=($targetHeader.is("a"))? $targetHeader.get(0) : $targetHeader.find('a:eq(0)').get(0)
|
||||
if (targetLink) //if this header is a link
|
||||
setTimeout(function(){location=targetLink.href}, 200) //ignore link target, as window.open(targetLink, targetLink.target) doesn't work in FF if popup blocker enabled
|
||||
}
|
||||
})
|
||||
},
|
||||
|
||||
collapseit:function($targetHeader, $targetContent, config, isuseractivated){
|
||||
this.transformHeader($targetHeader, config, "collapse")
|
||||
$targetContent.slideUp(config.animatespeed, function(){config.onopenclose($targetHeader.get(0), parseInt($targetHeader.attr('headerindex')), $targetContent.css('display'), isuseractivated)})
|
||||
},
|
||||
|
||||
transformHeader:function($targetHeader, config, state){
|
||||
$targetHeader.addClass((state=="expand")? config.cssclass.expand : config.cssclass.collapse) //alternate btw "expand" and "collapse" CSS classes
|
||||
.removeClass((state=="expand")? config.cssclass.collapse : config.cssclass.expand)
|
||||
if (config.htmlsetting.location=='src'){ //Change header image (assuming header is an image)?
|
||||
$targetHeader=($targetHeader.is("img"))? $targetHeader : $targetHeader.find('img').eq(0) //Set target to either header itself, or first image within header
|
||||
$targetHeader.attr('src', (state=="expand")? config.htmlsetting.expand : config.htmlsetting.collapse) //change header image
|
||||
}
|
||||
else if (config.htmlsetting.location=="prefix") //if change "prefix" HTML, locate dynamically added ".accordprefix" span tag and change it
|
||||
$targetHeader.find('.accordprefix').html((state=="expand")? config.htmlsetting.expand : config.htmlsetting.collapse)
|
||||
else if (config.htmlsetting.location=="suffix")
|
||||
$targetHeader.find('.accordsuffix').html((state=="expand")? config.htmlsetting.expand : config.htmlsetting.collapse)
|
||||
},
|
||||
|
||||
urlparamselect:function(headerclass){
|
||||
var result=window.location.search.match(new RegExp(headerclass+"=((\\d+)(,(\\d+))*)", "i")) //check for "?headerclass=2,3,4" in URL
|
||||
if (result!=null)
|
||||
result=RegExp.$1.split(',')
|
||||
return result //returns null, [index], or [index1,index2,etc], where index are the desired selected header indices
|
||||
},
|
||||
|
||||
getCookie:function(Name){
|
||||
var re=new RegExp(Name+"=[^;]+", "i") //construct RE to search for target name/value pair
|
||||
if (document.cookie.match(re)) //if cookie found
|
||||
return document.cookie.match(re)[0].split("=")[1] //return its value
|
||||
return null
|
||||
},
|
||||
|
||||
setCookie:function(name, value){
|
||||
document.cookie = name + "=" + value + "; path=/"
|
||||
},
|
||||
|
||||
init:function(config){
|
||||
document.write('<style type="text/css">\n')
|
||||
document.write('.'+config.contentclass+'{display: none}\n') //generate CSS to hide contents
|
||||
document.write('<\/style>')
|
||||
jQuery(document).ready(function($){
|
||||
ddaccordion.urlparamselect(config.headerclass)
|
||||
var persistedheaders=ddaccordion.getCookie(config.headerclass)
|
||||
ddaccordion.contentclassname[config.headerclass]=config.contentclass //remember contentclass name based on headerclass
|
||||
config.cssclass={collapse: config.toggleclass[0], expand: config.toggleclass[1]} //store expand and contract CSS classes as object properties
|
||||
config.revealtype=config.revealtype || "click"
|
||||
config.revealtype=config.revealtype.replace(/mouseover/i, "mouseenter")
|
||||
if (config.revealtype=="clickgo"){
|
||||
config.postreveal="gotourl" //remember added action
|
||||
config.revealtype="click" //overwrite revealtype to "click" keyword
|
||||
}
|
||||
if (typeof config.togglehtml=="undefined")
|
||||
config.htmlsetting={location: "none"}
|
||||
else
|
||||
config.htmlsetting={location: config.togglehtml[0], collapse: config.togglehtml[1], expand: config.togglehtml[2]} //store HTML settings as object properties
|
||||
config.oninit=(typeof config.oninit=="undefined")? function(){} : config.oninit //attach custom "oninit" event handler
|
||||
config.onopenclose=(typeof config.onopenclose=="undefined")? function(){} : config.onopenclose //attach custom "onopenclose" event handler
|
||||
var lastexpanded={} //object to hold reference to last expanded header and content (jquery objects)
|
||||
var expandedindices=ddaccordion.urlparamselect(config.headerclass) || ((config.persiststate && persistedheaders!=null)? persistedheaders : config.defaultexpanded)
|
||||
if (typeof expandedindices=='string') //test for string value (exception is config.defaultexpanded, which is an array)
|
||||
expandedindices=expandedindices.replace(/c/ig, '').split(',') //transform string value to an array (ie: "c1,c2,c3" becomes [1,2,3]
|
||||
var $subcontents=$('.'+config["contentclass"])
|
||||
if (expandedindices.length==1 && expandedindices[0]=="-1") //check for expandedindices value of [-1], indicating persistence is on and no content expanded
|
||||
expandedindices=[]
|
||||
if (config["collapseprev"] && expandedindices.length>1) //only allow one content open?
|
||||
expandedindices=[expandedindices.pop()] //return last array element as an array (for sake of jQuery.inArray())
|
||||
if (config["onemustopen"] && expandedindices.length==0) //if at least one content should be open at all times and none are, open 1st header
|
||||
expandedindices=[0]
|
||||
$('.'+config["headerclass"]).each(function(index){ //loop through all headers
|
||||
if (/(prefix)|(suffix)/i.test(config.htmlsetting.location) && $(this).html()!=""){ //add a SPAN element to header depending on user setting and if header is a container tag
|
||||
$('<span class="accordprefix"></span>').prependTo(this)
|
||||
$('<span class="accordsuffix"></span>').appendTo(this)
|
||||
}
|
||||
$(this).attr('headerindex', index+'h') //store position of this header relative to its peers
|
||||
$subcontents.eq(index).attr('contentindex', index+'c') //store position of this content relative to its peers
|
||||
var $subcontent=$subcontents.eq(index)
|
||||
var needle=(typeof expandedindices[0]=="number")? index : index+'' //check for data type within expandedindices array- index should match that type
|
||||
if (jQuery.inArray(needle, expandedindices)!=-1){ //check for headers that should be expanded automatically (convert index to string first)
|
||||
if (config.animatedefault==false)
|
||||
$subcontent.show()
|
||||
ddaccordion.expandit($(this), $subcontent, config, false) //Last param sets 'isuseractivated' parameter
|
||||
lastexpanded={$header:$(this), $content:$subcontent}
|
||||
} //end check
|
||||
else{
|
||||
$subcontent.hide()
|
||||
config.onopenclose($(this).get(0), parseInt($(this).attr('headerindex')), $subcontent.css('display'), false) //Last Boolean value sets 'isuseractivated' parameter
|
||||
ddaccordion.transformHeader($(this), config, "collapse")
|
||||
}
|
||||
})
|
||||
$('.'+config["headerclass"]).bind("evt_accordion", function(e, isdirectclick){ //assign custom event handler that expands/ contacts a header
|
||||
var $subcontent=$subcontents.eq(parseInt($(this).attr('headerindex'))) //get subcontent that should be expanded/collapsed
|
||||
if ($subcontent.css('display')=="none"){
|
||||
ddaccordion.expandit($(this), $subcontent, config, true, isdirectclick) //2nd last param sets 'isuseractivated' parameter
|
||||
if (config["collapseprev"] && lastexpanded.$header && $(this).get(0)!=lastexpanded.$header.get(0)){ //collapse previous content?
|
||||
ddaccordion.collapseit(lastexpanded.$header, lastexpanded.$content, config, true) //Last Boolean value sets 'isuseractivated' parameter
|
||||
}
|
||||
lastexpanded={$header:$(this), $content:$subcontent}
|
||||
}
|
||||
else if (!config["onemustopen"] || config["onemustopen"] && lastexpanded.$header && $(this).get(0)!=lastexpanded.$header.get(0)){
|
||||
ddaccordion.collapseit($(this), $subcontent, config, true) //Last Boolean value sets 'isuseractivated' parameter
|
||||
}
|
||||
})
|
||||
$('.'+config["headerclass"]).bind(config.revealtype, function(){
|
||||
if (config.revealtype=="mouseenter"){
|
||||
clearTimeout(config.revealdelay)
|
||||
var headerindex=parseInt($(this).attr("headerindex"))
|
||||
config.revealdelay=setTimeout(function(){ddaccordion.expandone(config["headerclass"], headerindex)}, config.mouseoverdelay || 0)
|
||||
}
|
||||
else{
|
||||
$(this).trigger("evt_accordion", [true])
|
||||
return false //cancel default click behavior
|
||||
}
|
||||
})
|
||||
$('.'+config["headerclass"]).bind("mouseleave", function(){
|
||||
clearTimeout(config.revealdelay)
|
||||
})
|
||||
config.oninit($('.'+config["headerclass"]).get(), expandedindices)
|
||||
$(window).bind('unload', function(){ //clean up and persist on page unload
|
||||
$('.'+config["headerclass"]).unbind()
|
||||
var expandedindices=[]
|
||||
$('.'+config["contentclass"]+":visible").each(function(index){ //get indices of expanded headers
|
||||
expandedindices.push($(this).attr('contentindex'))
|
||||
})
|
||||
if (config.persiststate==true && $('.'+config["headerclass"]).length>0){ //persist state?
|
||||
expandedindices=(expandedindices.length==0)? '-1c' : expandedindices //No contents expanded, indicate that with dummy '-1c' value?
|
||||
ddaccordion.setCookie(config.headerclass, expandedindices)
|
||||
}
|
||||
})
|
||||
})
|
||||
}
|
||||
}
|
4
admin/js/jquery-1.7.min.js
vendored
Normal file
147
admin/js/jquery-ui-1.8.11.custom.min.js
vendored
Normal file
|
@ -0,0 +1,147 @@
|
|||
/*!
|
||||
* jQuery UI 1.8.11
|
||||
*
|
||||
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI
|
||||
*/
|
||||
(function(c,j){function k(a){return!c(a).parents().andSelf().filter(function(){return c.curCSS(this,"visibility")==="hidden"||c.expr.filters.hidden(this)}).length}c.ui=c.ui||{};if(!c.ui.version){c.extend(c.ui,{version:"1.8.11",keyCode:{ALT:18,BACKSPACE:8,CAPS_LOCK:20,COMMA:188,COMMAND:91,COMMAND_LEFT:91,COMMAND_RIGHT:93,CONTROL:17,DELETE:46,DOWN:40,END:35,ENTER:13,ESCAPE:27,HOME:36,INSERT:45,LEFT:37,MENU:93,NUMPAD_ADD:107,NUMPAD_DECIMAL:110,NUMPAD_DIVIDE:111,NUMPAD_ENTER:108,NUMPAD_MULTIPLY:106,
|
||||
NUMPAD_SUBTRACT:109,PAGE_DOWN:34,PAGE_UP:33,PERIOD:190,RIGHT:39,SHIFT:16,SPACE:32,TAB:9,UP:38,WINDOWS:91}});c.fn.extend({_focus:c.fn.focus,focus:function(a,b){return typeof a==="number"?this.each(function(){var d=this;setTimeout(function(){c(d).focus();b&&b.call(d)},a)}):this._focus.apply(this,arguments)},scrollParent:function(){var a;a=c.browser.msie&&/(static|relative)/.test(this.css("position"))||/absolute/.test(this.css("position"))?this.parents().filter(function(){return/(relative|absolute|fixed)/.test(c.curCSS(this,
|
||||
"position",1))&&/(auto|scroll)/.test(c.curCSS(this,"overflow",1)+c.curCSS(this,"overflow-y",1)+c.curCSS(this,"overflow-x",1))}).eq(0):this.parents().filter(function(){return/(auto|scroll)/.test(c.curCSS(this,"overflow",1)+c.curCSS(this,"overflow-y",1)+c.curCSS(this,"overflow-x",1))}).eq(0);return/fixed/.test(this.css("position"))||!a.length?c(document):a},zIndex:function(a){if(a!==j)return this.css("zIndex",a);if(this.length){a=c(this[0]);for(var b;a.length&&a[0]!==document;){b=a.css("position");
|
||||
if(b==="absolute"||b==="relative"||b==="fixed"){b=parseInt(a.css("zIndex"),10);if(!isNaN(b)&&b!==0)return b}a=a.parent()}}return 0},disableSelection:function(){return this.bind((c.support.selectstart?"selectstart":"mousedown")+".ui-disableSelection",function(a){a.preventDefault()})},enableSelection:function(){return this.unbind(".ui-disableSelection")}});c.each(["Width","Height"],function(a,b){function d(f,g,l,m){c.each(e,function(){g-=parseFloat(c.curCSS(f,"padding"+this,true))||0;if(l)g-=parseFloat(c.curCSS(f,
|
||||
"border"+this+"Width",true))||0;if(m)g-=parseFloat(c.curCSS(f,"margin"+this,true))||0});return g}var e=b==="Width"?["Left","Right"]:["Top","Bottom"],h=b.toLowerCase(),i={innerWidth:c.fn.innerWidth,innerHeight:c.fn.innerHeight,outerWidth:c.fn.outerWidth,outerHeight:c.fn.outerHeight};c.fn["inner"+b]=function(f){if(f===j)return i["inner"+b].call(this);return this.each(function(){c(this).css(h,d(this,f)+"px")})};c.fn["outer"+b]=function(f,g){if(typeof f!=="number")return i["outer"+b].call(this,f);return this.each(function(){c(this).css(h,
|
||||
d(this,f,true,g)+"px")})}});c.extend(c.expr[":"],{data:function(a,b,d){return!!c.data(a,d[3])},focusable:function(a){var b=a.nodeName.toLowerCase(),d=c.attr(a,"tabindex");if("area"===b){b=a.parentNode;d=b.name;if(!a.href||!d||b.nodeName.toLowerCase()!=="map")return false;a=c("img[usemap=#"+d+"]")[0];return!!a&&k(a)}return(/input|select|textarea|button|object/.test(b)?!a.disabled:"a"==b?a.href||!isNaN(d):!isNaN(d))&&k(a)},tabbable:function(a){var b=c.attr(a,"tabindex");return(isNaN(b)||b>=0)&&c(a).is(":focusable")}});
|
||||
c(function(){var a=document.body,b=a.appendChild(b=document.createElement("div"));c.extend(b.style,{minHeight:"100px",height:"auto",padding:0,borderWidth:0});c.support.minHeight=b.offsetHeight===100;c.support.selectstart="onselectstart"in b;a.removeChild(b).style.display="none"});c.extend(c.ui,{plugin:{add:function(a,b,d){a=c.ui[a].prototype;for(var e in d){a.plugins[e]=a.plugins[e]||[];a.plugins[e].push([b,d[e]])}},call:function(a,b,d){if((b=a.plugins[b])&&a.element[0].parentNode)for(var e=0;e<b.length;e++)a.options[b[e][0]]&&
|
||||
b[e][1].apply(a.element,d)}},contains:function(a,b){return document.compareDocumentPosition?a.compareDocumentPosition(b)&16:a!==b&&a.contains(b)},hasScroll:function(a,b){if(c(a).css("overflow")==="hidden")return false;b=b&&b==="left"?"scrollLeft":"scrollTop";var d=false;if(a[b]>0)return true;a[b]=1;d=a[b]>0;a[b]=0;return d},isOverAxis:function(a,b,d){return a>b&&a<b+d},isOver:function(a,b,d,e,h,i){return c.ui.isOverAxis(a,d,h)&&c.ui.isOverAxis(b,e,i)}})}})(jQuery);
|
||||
;/*!
|
||||
* jQuery UI Widget 1.8.11
|
||||
*
|
||||
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI/Widget
|
||||
*/
|
||||
(function(b,j){if(b.cleanData){var k=b.cleanData;b.cleanData=function(a){for(var c=0,d;(d=a[c])!=null;c++)b(d).triggerHandler("remove");k(a)}}else{var l=b.fn.remove;b.fn.remove=function(a,c){return this.each(function(){if(!c)if(!a||b.filter(a,[this]).length)b("*",this).add([this]).each(function(){b(this).triggerHandler("remove")});return l.call(b(this),a,c)})}}b.widget=function(a,c,d){var e=a.split(".")[0],f;a=a.split(".")[1];f=e+"-"+a;if(!d){d=c;c=b.Widget}b.expr[":"][f]=function(h){return!!b.data(h,
|
||||
a)};b[e]=b[e]||{};b[e][a]=function(h,g){arguments.length&&this._createWidget(h,g)};c=new c;c.options=b.extend(true,{},c.options);b[e][a].prototype=b.extend(true,c,{namespace:e,widgetName:a,widgetEventPrefix:b[e][a].prototype.widgetEventPrefix||a,widgetBaseClass:f},d);b.widget.bridge(a,b[e][a])};b.widget.bridge=function(a,c){b.fn[a]=function(d){var e=typeof d==="string",f=Array.prototype.slice.call(arguments,1),h=this;d=!e&&f.length?b.extend.apply(null,[true,d].concat(f)):d;if(e&&d.charAt(0)==="_")return h;
|
||||
e?this.each(function(){var g=b.data(this,a),i=g&&b.isFunction(g[d])?g[d].apply(g,f):g;if(i!==g&&i!==j){h=i;return false}}):this.each(function(){var g=b.data(this,a);g?g.option(d||{})._init():b.data(this,a,new c(d,this))});return h}};b.Widget=function(a,c){arguments.length&&this._createWidget(a,c)};b.Widget.prototype={widgetName:"widget",widgetEventPrefix:"",options:{disabled:false},_createWidget:function(a,c){b.data(c,this.widgetName,this);this.element=b(c);this.options=b.extend(true,{},this.options,
|
||||
this._getCreateOptions(),a);var d=this;this.element.bind("remove."+this.widgetName,function(){d.destroy()});this._create();this._trigger("create");this._init()},_getCreateOptions:function(){return b.metadata&&b.metadata.get(this.element[0])[this.widgetName]},_create:function(){},_init:function(){},destroy:function(){this.element.unbind("."+this.widgetName).removeData(this.widgetName);this.widget().unbind("."+this.widgetName).removeAttr("aria-disabled").removeClass(this.widgetBaseClass+"-disabled ui-state-disabled")},
|
||||
widget:function(){return this.element},option:function(a,c){var d=a;if(arguments.length===0)return b.extend({},this.options);if(typeof a==="string"){if(c===j)return this.options[a];d={};d[a]=c}this._setOptions(d);return this},_setOptions:function(a){var c=this;b.each(a,function(d,e){c._setOption(d,e)});return this},_setOption:function(a,c){this.options[a]=c;if(a==="disabled")this.widget()[c?"addClass":"removeClass"](this.widgetBaseClass+"-disabled ui-state-disabled").attr("aria-disabled",c);return this},
|
||||
enable:function(){return this._setOption("disabled",false)},disable:function(){return this._setOption("disabled",true)},_trigger:function(a,c,d){var e=this.options[a];c=b.Event(c);c.type=(a===this.widgetEventPrefix?a:this.widgetEventPrefix+a).toLowerCase();d=d||{};if(c.originalEvent){a=b.event.props.length;for(var f;a;){f=b.event.props[--a];c[f]=c.originalEvent[f]}}this.element.trigger(c,d);return!(b.isFunction(e)&&e.call(this.element[0],c,d)===false||c.isDefaultPrevented())}}})(jQuery);
|
||||
;/*!
|
||||
* jQuery UI Mouse 1.8.11
|
||||
*
|
||||
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI/Mouse
|
||||
*
|
||||
* Depends:
|
||||
* jquery.ui.widget.js
|
||||
*/
|
||||
(function(b){b.widget("ui.mouse",{options:{cancel:":input,option",distance:1,delay:0},_mouseInit:function(){var a=this;this.element.bind("mousedown."+this.widgetName,function(c){return a._mouseDown(c)}).bind("click."+this.widgetName,function(c){if(true===b.data(c.target,a.widgetName+".preventClickEvent")){b.removeData(c.target,a.widgetName+".preventClickEvent");c.stopImmediatePropagation();return false}});this.started=false},_mouseDestroy:function(){this.element.unbind("."+this.widgetName)},_mouseDown:function(a){a.originalEvent=
|
||||
a.originalEvent||{};if(!a.originalEvent.mouseHandled){this._mouseStarted&&this._mouseUp(a);this._mouseDownEvent=a;var c=this,e=a.which==1,f=typeof this.options.cancel=="string"?b(a.target).parents().add(a.target).filter(this.options.cancel).length:false;if(!e||f||!this._mouseCapture(a))return true;this.mouseDelayMet=!this.options.delay;if(!this.mouseDelayMet)this._mouseDelayTimer=setTimeout(function(){c.mouseDelayMet=true},this.options.delay);if(this._mouseDistanceMet(a)&&this._mouseDelayMet(a)){this._mouseStarted=
|
||||
this._mouseStart(a)!==false;if(!this._mouseStarted){a.preventDefault();return true}}true===b.data(a.target,this.widgetName+".preventClickEvent")&&b.removeData(a.target,this.widgetName+".preventClickEvent");this._mouseMoveDelegate=function(d){return c._mouseMove(d)};this._mouseUpDelegate=function(d){return c._mouseUp(d)};b(document).bind("mousemove."+this.widgetName,this._mouseMoveDelegate).bind("mouseup."+this.widgetName,this._mouseUpDelegate);a.preventDefault();return a.originalEvent.mouseHandled=
|
||||
true}},_mouseMove:function(a){if(b.browser.msie&&!(document.documentMode>=9)&&!a.button)return this._mouseUp(a);if(this._mouseStarted){this._mouseDrag(a);return a.preventDefault()}if(this._mouseDistanceMet(a)&&this._mouseDelayMet(a))(this._mouseStarted=this._mouseStart(this._mouseDownEvent,a)!==false)?this._mouseDrag(a):this._mouseUp(a);return!this._mouseStarted},_mouseUp:function(a){b(document).unbind("mousemove."+this.widgetName,this._mouseMoveDelegate).unbind("mouseup."+this.widgetName,this._mouseUpDelegate);
|
||||
if(this._mouseStarted){this._mouseStarted=false;a.target==this._mouseDownEvent.target&&b.data(a.target,this.widgetName+".preventClickEvent",true);this._mouseStop(a)}return false},_mouseDistanceMet:function(a){return Math.max(Math.abs(this._mouseDownEvent.pageX-a.pageX),Math.abs(this._mouseDownEvent.pageY-a.pageY))>=this.options.distance},_mouseDelayMet:function(){return this.mouseDelayMet},_mouseStart:function(){},_mouseDrag:function(){},_mouseStop:function(){},_mouseCapture:function(){return true}})})(jQuery);
|
||||
;/*
|
||||
* jQuery UI Draggable 1.8.11
|
||||
*
|
||||
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI/Draggables
|
||||
*
|
||||
* Depends:
|
||||
* jquery.ui.core.js
|
||||
* jquery.ui.mouse.js
|
||||
* jquery.ui.widget.js
|
||||
*/
|
||||
(function(d){d.widget("ui.draggable",d.ui.mouse,{widgetEventPrefix:"drag",options:{addClasses:true,appendTo:"parent",axis:false,connectToSortable:false,containment:false,cursor:"auto",cursorAt:false,grid:false,handle:false,helper:"original",iframeFix:false,opacity:false,refreshPositions:false,revert:false,revertDuration:500,scope:"default",scroll:true,scrollSensitivity:20,scrollSpeed:20,snap:false,snapMode:"both",snapTolerance:20,stack:false,zIndex:false},_create:function(){if(this.options.helper==
|
||||
"original"&&!/^(?:r|a|f)/.test(this.element.css("position")))this.element[0].style.position="relative";this.options.addClasses&&this.element.addClass("ui-draggable");this.options.disabled&&this.element.addClass("ui-draggable-disabled");this._mouseInit()},destroy:function(){if(this.element.data("draggable")){this.element.removeData("draggable").unbind(".draggable").removeClass("ui-draggable ui-draggable-dragging ui-draggable-disabled");this._mouseDestroy();return this}},_mouseCapture:function(a){var b=
|
||||
this.options;if(this.helper||b.disabled||d(a.target).is(".ui-resizable-handle"))return false;this.handle=this._getHandle(a);if(!this.handle)return false;return true},_mouseStart:function(a){var b=this.options;this.helper=this._createHelper(a);this._cacheHelperProportions();if(d.ui.ddmanager)d.ui.ddmanager.current=this;this._cacheMargins();this.cssPosition=this.helper.css("position");this.scrollParent=this.helper.scrollParent();this.offset=this.positionAbs=this.element.offset();this.offset={top:this.offset.top-
|
||||
this.margins.top,left:this.offset.left-this.margins.left};d.extend(this.offset,{click:{left:a.pageX-this.offset.left,top:a.pageY-this.offset.top},parent:this._getParentOffset(),relative:this._getRelativeOffset()});this.originalPosition=this.position=this._generatePosition(a);this.originalPageX=a.pageX;this.originalPageY=a.pageY;b.cursorAt&&this._adjustOffsetFromHelper(b.cursorAt);b.containment&&this._setContainment();if(this._trigger("start",a)===false){this._clear();return false}this._cacheHelperProportions();
|
||||
d.ui.ddmanager&&!b.dropBehaviour&&d.ui.ddmanager.prepareOffsets(this,a);this.helper.addClass("ui-draggable-dragging");this._mouseDrag(a,true);return true},_mouseDrag:function(a,b){this.position=this._generatePosition(a);this.positionAbs=this._convertPositionTo("absolute");if(!b){b=this._uiHash();if(this._trigger("drag",a,b)===false){this._mouseUp({});return false}this.position=b.position}if(!this.options.axis||this.options.axis!="y")this.helper[0].style.left=this.position.left+"px";if(!this.options.axis||
|
||||
this.options.axis!="x")this.helper[0].style.top=this.position.top+"px";d.ui.ddmanager&&d.ui.ddmanager.drag(this,a);return false},_mouseStop:function(a){var b=false;if(d.ui.ddmanager&&!this.options.dropBehaviour)b=d.ui.ddmanager.drop(this,a);if(this.dropped){b=this.dropped;this.dropped=false}if((!this.element[0]||!this.element[0].parentNode)&&this.options.helper=="original")return false;if(this.options.revert=="invalid"&&!b||this.options.revert=="valid"&&b||this.options.revert===true||d.isFunction(this.options.revert)&&
|
||||
this.options.revert.call(this.element,b)){var c=this;d(this.helper).animate(this.originalPosition,parseInt(this.options.revertDuration,10),function(){c._trigger("stop",a)!==false&&c._clear()})}else this._trigger("stop",a)!==false&&this._clear();return false},cancel:function(){this.helper.is(".ui-draggable-dragging")?this._mouseUp({}):this._clear();return this},_getHandle:function(a){var b=!this.options.handle||!d(this.options.handle,this.element).length?true:false;d(this.options.handle,this.element).find("*").andSelf().each(function(){if(this==
|
||||
a.target)b=true});return b},_createHelper:function(a){var b=this.options;a=d.isFunction(b.helper)?d(b.helper.apply(this.element[0],[a])):b.helper=="clone"?this.element.clone():this.element;a.parents("body").length||a.appendTo(b.appendTo=="parent"?this.element[0].parentNode:b.appendTo);a[0]!=this.element[0]&&!/(fixed|absolute)/.test(a.css("position"))&&a.css("position","absolute");return a},_adjustOffsetFromHelper:function(a){if(typeof a=="string")a=a.split(" ");if(d.isArray(a))a={left:+a[0],top:+a[1]||
|
||||
0};if("left"in a)this.offset.click.left=a.left+this.margins.left;if("right"in a)this.offset.click.left=this.helperProportions.width-a.right+this.margins.left;if("top"in a)this.offset.click.top=a.top+this.margins.top;if("bottom"in a)this.offset.click.top=this.helperProportions.height-a.bottom+this.margins.top},_getParentOffset:function(){this.offsetParent=this.helper.offsetParent();var a=this.offsetParent.offset();if(this.cssPosition=="absolute"&&this.scrollParent[0]!=document&&d.ui.contains(this.scrollParent[0],
|
||||
this.offsetParent[0])){a.left+=this.scrollParent.scrollLeft();a.top+=this.scrollParent.scrollTop()}if(this.offsetParent[0]==document.body||this.offsetParent[0].tagName&&this.offsetParent[0].tagName.toLowerCase()=="html"&&d.browser.msie)a={top:0,left:0};return{top:a.top+(parseInt(this.offsetParent.css("borderTopWidth"),10)||0),left:a.left+(parseInt(this.offsetParent.css("borderLeftWidth"),10)||0)}},_getRelativeOffset:function(){if(this.cssPosition=="relative"){var a=this.element.position();return{top:a.top-
|
||||
(parseInt(this.helper.css("top"),10)||0)+this.scrollParent.scrollTop(),left:a.left-(parseInt(this.helper.css("left"),10)||0)+this.scrollParent.scrollLeft()}}else return{top:0,left:0}},_cacheMargins:function(){this.margins={left:parseInt(this.element.css("marginLeft"),10)||0,top:parseInt(this.element.css("marginTop"),10)||0,right:parseInt(this.element.css("marginRight"),10)||0,bottom:parseInt(this.element.css("marginBottom"),10)||0}},_cacheHelperProportions:function(){this.helperProportions={width:this.helper.outerWidth(),
|
||||
height:this.helper.outerHeight()}},_setContainment:function(){var a=this.options;if(a.containment=="parent")a.containment=this.helper[0].parentNode;if(a.containment=="document"||a.containment=="window")this.containment=[(a.containment=="document"?0:d(window).scrollLeft())-this.offset.relative.left-this.offset.parent.left,(a.containment=="document"?0:d(window).scrollTop())-this.offset.relative.top-this.offset.parent.top,(a.containment=="document"?0:d(window).scrollLeft())+d(a.containment=="document"?
|
||||
document:window).width()-this.helperProportions.width-this.margins.left,(a.containment=="document"?0:d(window).scrollTop())+(d(a.containment=="document"?document:window).height()||document.body.parentNode.scrollHeight)-this.helperProportions.height-this.margins.top];if(!/^(document|window|parent)$/.test(a.containment)&&a.containment.constructor!=Array){var b=d(a.containment)[0];if(b){a=d(a.containment).offset();var c=d(b).css("overflow")!="hidden";this.containment=[a.left+(parseInt(d(b).css("borderLeftWidth"),
|
||||
10)||0)+(parseInt(d(b).css("paddingLeft"),10)||0),a.top+(parseInt(d(b).css("borderTopWidth"),10)||0)+(parseInt(d(b).css("paddingTop"),10)||0),a.left+(c?Math.max(b.scrollWidth,b.offsetWidth):b.offsetWidth)-(parseInt(d(b).css("borderLeftWidth"),10)||0)-(parseInt(d(b).css("paddingRight"),10)||0)-this.helperProportions.width-this.margins.left-this.margins.right,a.top+(c?Math.max(b.scrollHeight,b.offsetHeight):b.offsetHeight)-(parseInt(d(b).css("borderTopWidth"),10)||0)-(parseInt(d(b).css("paddingBottom"),
|
||||
10)||0)-this.helperProportions.height-this.margins.top-this.margins.bottom]}}else if(a.containment.constructor==Array)this.containment=a.containment},_convertPositionTo:function(a,b){if(!b)b=this.position;a=a=="absolute"?1:-1;var c=this.cssPosition=="absolute"&&!(this.scrollParent[0]!=document&&d.ui.contains(this.scrollParent[0],this.offsetParent[0]))?this.offsetParent:this.scrollParent,f=/(html|body)/i.test(c[0].tagName);return{top:b.top+this.offset.relative.top*a+this.offset.parent.top*a-(d.browser.safari&&
|
||||
d.browser.version<526&&this.cssPosition=="fixed"?0:(this.cssPosition=="fixed"?-this.scrollParent.scrollTop():f?0:c.scrollTop())*a),left:b.left+this.offset.relative.left*a+this.offset.parent.left*a-(d.browser.safari&&d.browser.version<526&&this.cssPosition=="fixed"?0:(this.cssPosition=="fixed"?-this.scrollParent.scrollLeft():f?0:c.scrollLeft())*a)}},_generatePosition:function(a){var b=this.options,c=this.cssPosition=="absolute"&&!(this.scrollParent[0]!=document&&d.ui.contains(this.scrollParent[0],
|
||||
this.offsetParent[0]))?this.offsetParent:this.scrollParent,f=/(html|body)/i.test(c[0].tagName),e=a.pageX,g=a.pageY;if(this.originalPosition){if(this.containment){if(a.pageX-this.offset.click.left<this.containment[0])e=this.containment[0]+this.offset.click.left;if(a.pageY-this.offset.click.top<this.containment[1])g=this.containment[1]+this.offset.click.top;if(a.pageX-this.offset.click.left>this.containment[2])e=this.containment[2]+this.offset.click.left;if(a.pageY-this.offset.click.top>this.containment[3])g=
|
||||
this.containment[3]+this.offset.click.top}if(b.grid){g=this.originalPageY+Math.round((g-this.originalPageY)/b.grid[1])*b.grid[1];g=this.containment?!(g-this.offset.click.top<this.containment[1]||g-this.offset.click.top>this.containment[3])?g:!(g-this.offset.click.top<this.containment[1])?g-b.grid[1]:g+b.grid[1]:g;e=this.originalPageX+Math.round((e-this.originalPageX)/b.grid[0])*b.grid[0];e=this.containment?!(e-this.offset.click.left<this.containment[0]||e-this.offset.click.left>this.containment[2])?
|
||||
e:!(e-this.offset.click.left<this.containment[0])?e-b.grid[0]:e+b.grid[0]:e}}return{top:g-this.offset.click.top-this.offset.relative.top-this.offset.parent.top+(d.browser.safari&&d.browser.version<526&&this.cssPosition=="fixed"?0:this.cssPosition=="fixed"?-this.scrollParent.scrollTop():f?0:c.scrollTop()),left:e-this.offset.click.left-this.offset.relative.left-this.offset.parent.left+(d.browser.safari&&d.browser.version<526&&this.cssPosition=="fixed"?0:this.cssPosition=="fixed"?-this.scrollParent.scrollLeft():
|
||||
f?0:c.scrollLeft())}},_clear:function(){this.helper.removeClass("ui-draggable-dragging");this.helper[0]!=this.element[0]&&!this.cancelHelperRemoval&&this.helper.remove();this.helper=null;this.cancelHelperRemoval=false},_trigger:function(a,b,c){c=c||this._uiHash();d.ui.plugin.call(this,a,[b,c]);if(a=="drag")this.positionAbs=this._convertPositionTo("absolute");return d.Widget.prototype._trigger.call(this,a,b,c)},plugins:{},_uiHash:function(){return{helper:this.helper,position:this.position,originalPosition:this.originalPosition,
|
||||
offset:this.positionAbs}}});d.extend(d.ui.draggable,{version:"1.8.11"});d.ui.plugin.add("draggable","connectToSortable",{start:function(a,b){var c=d(this).data("draggable"),f=c.options,e=d.extend({},b,{item:c.element});c.sortables=[];d(f.connectToSortable).each(function(){var g=d.data(this,"sortable");if(g&&!g.options.disabled){c.sortables.push({instance:g,shouldRevert:g.options.revert});g.refreshPositions();g._trigger("activate",a,e)}})},stop:function(a,b){var c=d(this).data("draggable"),f=d.extend({},
|
||||
b,{item:c.element});d.each(c.sortables,function(){if(this.instance.isOver){this.instance.isOver=0;c.cancelHelperRemoval=true;this.instance.cancelHelperRemoval=false;if(this.shouldRevert)this.instance.options.revert=true;this.instance._mouseStop(a);this.instance.options.helper=this.instance.options._helper;c.options.helper=="original"&&this.instance.currentItem.css({top:"auto",left:"auto"})}else{this.instance.cancelHelperRemoval=false;this.instance._trigger("deactivate",a,f)}})},drag:function(a,b){var c=
|
||||
d(this).data("draggable"),f=this;d.each(c.sortables,function(){this.instance.positionAbs=c.positionAbs;this.instance.helperProportions=c.helperProportions;this.instance.offset.click=c.offset.click;if(this.instance._intersectsWith(this.instance.containerCache)){if(!this.instance.isOver){this.instance.isOver=1;this.instance.currentItem=d(f).clone().appendTo(this.instance.element).data("sortable-item",true);this.instance.options._helper=this.instance.options.helper;this.instance.options.helper=function(){return b.helper[0]};
|
||||
a.target=this.instance.currentItem[0];this.instance._mouseCapture(a,true);this.instance._mouseStart(a,true,true);this.instance.offset.click.top=c.offset.click.top;this.instance.offset.click.left=c.offset.click.left;this.instance.offset.parent.left-=c.offset.parent.left-this.instance.offset.parent.left;this.instance.offset.parent.top-=c.offset.parent.top-this.instance.offset.parent.top;c._trigger("toSortable",a);c.dropped=this.instance.element;c.currentItem=c.element;this.instance.fromOutside=c}this.instance.currentItem&&
|
||||
this.instance._mouseDrag(a)}else if(this.instance.isOver){this.instance.isOver=0;this.instance.cancelHelperRemoval=true;this.instance.options.revert=false;this.instance._trigger("out",a,this.instance._uiHash(this.instance));this.instance._mouseStop(a,true);this.instance.options.helper=this.instance.options._helper;this.instance.currentItem.remove();this.instance.placeholder&&this.instance.placeholder.remove();c._trigger("fromSortable",a);c.dropped=false}})}});d.ui.plugin.add("draggable","cursor",
|
||||
{start:function(){var a=d("body"),b=d(this).data("draggable").options;if(a.css("cursor"))b._cursor=a.css("cursor");a.css("cursor",b.cursor)},stop:function(){var a=d(this).data("draggable").options;a._cursor&&d("body").css("cursor",a._cursor)}});d.ui.plugin.add("draggable","iframeFix",{start:function(){var a=d(this).data("draggable").options;d(a.iframeFix===true?"iframe":a.iframeFix).each(function(){d('<div class="ui-draggable-iframeFix" style="background: #fff;"></div>').css({width:this.offsetWidth+
|
||||
"px",height:this.offsetHeight+"px",position:"absolute",opacity:"0.001",zIndex:1E3}).css(d(this).offset()).appendTo("body")})},stop:function(){d("div.ui-draggable-iframeFix").each(function(){this.parentNode.removeChild(this)})}});d.ui.plugin.add("draggable","opacity",{start:function(a,b){a=d(b.helper);b=d(this).data("draggable").options;if(a.css("opacity"))b._opacity=a.css("opacity");a.css("opacity",b.opacity)},stop:function(a,b){a=d(this).data("draggable").options;a._opacity&&d(b.helper).css("opacity",
|
||||
a._opacity)}});d.ui.plugin.add("draggable","scroll",{start:function(){var a=d(this).data("draggable");if(a.scrollParent[0]!=document&&a.scrollParent[0].tagName!="HTML")a.overflowOffset=a.scrollParent.offset()},drag:function(a){var b=d(this).data("draggable"),c=b.options,f=false;if(b.scrollParent[0]!=document&&b.scrollParent[0].tagName!="HTML"){if(!c.axis||c.axis!="x")if(b.overflowOffset.top+b.scrollParent[0].offsetHeight-a.pageY<c.scrollSensitivity)b.scrollParent[0].scrollTop=f=b.scrollParent[0].scrollTop+
|
||||
c.scrollSpeed;else if(a.pageY-b.overflowOffset.top<c.scrollSensitivity)b.scrollParent[0].scrollTop=f=b.scrollParent[0].scrollTop-c.scrollSpeed;if(!c.axis||c.axis!="y")if(b.overflowOffset.left+b.scrollParent[0].offsetWidth-a.pageX<c.scrollSensitivity)b.scrollParent[0].scrollLeft=f=b.scrollParent[0].scrollLeft+c.scrollSpeed;else if(a.pageX-b.overflowOffset.left<c.scrollSensitivity)b.scrollParent[0].scrollLeft=f=b.scrollParent[0].scrollLeft-c.scrollSpeed}else{if(!c.axis||c.axis!="x")if(a.pageY-d(document).scrollTop()<
|
||||
c.scrollSensitivity)f=d(document).scrollTop(d(document).scrollTop()-c.scrollSpeed);else if(d(window).height()-(a.pageY-d(document).scrollTop())<c.scrollSensitivity)f=d(document).scrollTop(d(document).scrollTop()+c.scrollSpeed);if(!c.axis||c.axis!="y")if(a.pageX-d(document).scrollLeft()<c.scrollSensitivity)f=d(document).scrollLeft(d(document).scrollLeft()-c.scrollSpeed);else if(d(window).width()-(a.pageX-d(document).scrollLeft())<c.scrollSensitivity)f=d(document).scrollLeft(d(document).scrollLeft()+
|
||||
c.scrollSpeed)}f!==false&&d.ui.ddmanager&&!c.dropBehaviour&&d.ui.ddmanager.prepareOffsets(b,a)}});d.ui.plugin.add("draggable","snap",{start:function(){var a=d(this).data("draggable"),b=a.options;a.snapElements=[];d(b.snap.constructor!=String?b.snap.items||":data(draggable)":b.snap).each(function(){var c=d(this),f=c.offset();this!=a.element[0]&&a.snapElements.push({item:this,width:c.outerWidth(),height:c.outerHeight(),top:f.top,left:f.left})})},drag:function(a,b){for(var c=d(this).data("draggable"),
|
||||
f=c.options,e=f.snapTolerance,g=b.offset.left,n=g+c.helperProportions.width,m=b.offset.top,o=m+c.helperProportions.height,h=c.snapElements.length-1;h>=0;h--){var i=c.snapElements[h].left,k=i+c.snapElements[h].width,j=c.snapElements[h].top,l=j+c.snapElements[h].height;if(i-e<g&&g<k+e&&j-e<m&&m<l+e||i-e<g&&g<k+e&&j-e<o&&o<l+e||i-e<n&&n<k+e&&j-e<m&&m<l+e||i-e<n&&n<k+e&&j-e<o&&o<l+e){if(f.snapMode!="inner"){var p=Math.abs(j-o)<=e,q=Math.abs(l-m)<=e,r=Math.abs(i-n)<=e,s=Math.abs(k-g)<=e;if(p)b.position.top=
|
||||
c._convertPositionTo("relative",{top:j-c.helperProportions.height,left:0}).top-c.margins.top;if(q)b.position.top=c._convertPositionTo("relative",{top:l,left:0}).top-c.margins.top;if(r)b.position.left=c._convertPositionTo("relative",{top:0,left:i-c.helperProportions.width}).left-c.margins.left;if(s)b.position.left=c._convertPositionTo("relative",{top:0,left:k}).left-c.margins.left}var t=p||q||r||s;if(f.snapMode!="outer"){p=Math.abs(j-m)<=e;q=Math.abs(l-o)<=e;r=Math.abs(i-g)<=e;s=Math.abs(k-n)<=e;if(p)b.position.top=
|
||||
c._convertPositionTo("relative",{top:j,left:0}).top-c.margins.top;if(q)b.position.top=c._convertPositionTo("relative",{top:l-c.helperProportions.height,left:0}).top-c.margins.top;if(r)b.position.left=c._convertPositionTo("relative",{top:0,left:i}).left-c.margins.left;if(s)b.position.left=c._convertPositionTo("relative",{top:0,left:k-c.helperProportions.width}).left-c.margins.left}if(!c.snapElements[h].snapping&&(p||q||r||s||t))c.options.snap.snap&&c.options.snap.snap.call(c.element,a,d.extend(c._uiHash(),
|
||||
{snapItem:c.snapElements[h].item}));c.snapElements[h].snapping=p||q||r||s||t}else{c.snapElements[h].snapping&&c.options.snap.release&&c.options.snap.release.call(c.element,a,d.extend(c._uiHash(),{snapItem:c.snapElements[h].item}));c.snapElements[h].snapping=false}}}});d.ui.plugin.add("draggable","stack",{start:function(){var a=d(this).data("draggable").options;a=d.makeArray(d(a.stack)).sort(function(c,f){return(parseInt(d(c).css("zIndex"),10)||0)-(parseInt(d(f).css("zIndex"),10)||0)});if(a.length){var b=
|
||||
parseInt(a[0].style.zIndex)||0;d(a).each(function(c){this.style.zIndex=b+c});this[0].style.zIndex=b+a.length}}});d.ui.plugin.add("draggable","zIndex",{start:function(a,b){a=d(b.helper);b=d(this).data("draggable").options;if(a.css("zIndex"))b._zIndex=a.css("zIndex");a.css("zIndex",b.zIndex)},stop:function(a,b){a=d(this).data("draggable").options;a._zIndex&&d(b.helper).css("zIndex",a._zIndex)}})})(jQuery);
|
||||
;/*
|
||||
* jQuery UI Resizable 1.8.11
|
||||
*
|
||||
* Copyright 2011, AUTHORS.txt (http://jqueryui.com/about)
|
||||
* Dual licensed under the MIT or GPL Version 2 licenses.
|
||||
* http://jquery.org/license
|
||||
*
|
||||
* http://docs.jquery.com/UI/Resizables
|
||||
*
|
||||
* Depends:
|
||||
* jquery.ui.core.js
|
||||
* jquery.ui.mouse.js
|
||||
* jquery.ui.widget.js
|
||||
*/
|
||||
(function(e){e.widget("ui.resizable",e.ui.mouse,{widgetEventPrefix:"resize",options:{alsoResize:false,animate:false,animateDuration:"slow",animateEasing:"swing",aspectRatio:false,autoHide:false,containment:false,ghost:false,grid:false,handles:"e,s,se",helper:false,maxHeight:null,maxWidth:null,minHeight:10,minWidth:10,zIndex:1E3},_create:function(){var b=this,a=this.options;this.element.addClass("ui-resizable");e.extend(this,{_aspectRatio:!!a.aspectRatio,aspectRatio:a.aspectRatio,originalElement:this.element,
|
||||
_proportionallyResizeElements:[],_helper:a.helper||a.ghost||a.animate?a.helper||"ui-resizable-helper":null});if(this.element[0].nodeName.match(/canvas|textarea|input|select|button|img/i)){/relative/.test(this.element.css("position"))&&e.browser.opera&&this.element.css({position:"relative",top:"auto",left:"auto"});this.element.wrap(e('<div class="ui-wrapper" style="overflow: hidden;"></div>').css({position:this.element.css("position"),width:this.element.outerWidth(),height:this.element.outerHeight(),
|
||||
top:this.element.css("top"),left:this.element.css("left")}));this.element=this.element.parent().data("resizable",this.element.data("resizable"));this.elementIsWrapper=true;this.element.css({marginLeft:this.originalElement.css("marginLeft"),marginTop:this.originalElement.css("marginTop"),marginRight:this.originalElement.css("marginRight"),marginBottom:this.originalElement.css("marginBottom")});this.originalElement.css({marginLeft:0,marginTop:0,marginRight:0,marginBottom:0});this.originalResizeStyle=
|
||||
this.originalElement.css("resize");this.originalElement.css("resize","none");this._proportionallyResizeElements.push(this.originalElement.css({position:"static",zoom:1,display:"block"}));this.originalElement.css({margin:this.originalElement.css("margin")});this._proportionallyResize()}this.handles=a.handles||(!e(".ui-resizable-handle",this.element).length?"e,s,se":{n:".ui-resizable-n",e:".ui-resizable-e",s:".ui-resizable-s",w:".ui-resizable-w",se:".ui-resizable-se",sw:".ui-resizable-sw",ne:".ui-resizable-ne",
|
||||
nw:".ui-resizable-nw"});if(this.handles.constructor==String){if(this.handles=="all")this.handles="n,e,s,w,se,sw,ne,nw";var c=this.handles.split(",");this.handles={};for(var d=0;d<c.length;d++){var f=e.trim(c[d]),g=e('<div class="ui-resizable-handle '+("ui-resizable-"+f)+'"></div>');/sw|se|ne|nw/.test(f)&&g.css({zIndex:++a.zIndex});"se"==f&&g.addClass("ui-icon ui-icon-gripsmall-diagonal-se");this.handles[f]=".ui-resizable-"+f;this.element.append(g)}}this._renderAxis=function(h){h=h||this.element;for(var i in this.handles){if(this.handles[i].constructor==
|
||||
String)this.handles[i]=e(this.handles[i],this.element).show();if(this.elementIsWrapper&&this.originalElement[0].nodeName.match(/textarea|input|select|button/i)){var j=e(this.handles[i],this.element),k=0;k=/sw|ne|nw|se|n|s/.test(i)?j.outerHeight():j.outerWidth();j=["padding",/ne|nw|n/.test(i)?"Top":/se|sw|s/.test(i)?"Bottom":/^e$/.test(i)?"Right":"Left"].join("");h.css(j,k);this._proportionallyResize()}e(this.handles[i])}};this._renderAxis(this.element);this._handles=e(".ui-resizable-handle",this.element).disableSelection();
|
||||
this._handles.mouseover(function(){if(!b.resizing){if(this.className)var h=this.className.match(/ui-resizable-(se|sw|ne|nw|n|e|s|w)/i);b.axis=h&&h[1]?h[1]:"se"}});if(a.autoHide){this._handles.hide();e(this.element).addClass("ui-resizable-autohide").hover(function(){e(this).removeClass("ui-resizable-autohide");b._handles.show()},function(){if(!b.resizing){e(this).addClass("ui-resizable-autohide");b._handles.hide()}})}this._mouseInit()},destroy:function(){this._mouseDestroy();var b=function(c){e(c).removeClass("ui-resizable ui-resizable-disabled ui-resizable-resizing").removeData("resizable").unbind(".resizable").find(".ui-resizable-handle").remove()};
|
||||
if(this.elementIsWrapper){b(this.element);var a=this.element;a.after(this.originalElement.css({position:a.css("position"),width:a.outerWidth(),height:a.outerHeight(),top:a.css("top"),left:a.css("left")})).remove()}this.originalElement.css("resize",this.originalResizeStyle);b(this.originalElement);return this},_mouseCapture:function(b){var a=false;for(var c in this.handles)if(e(this.handles[c])[0]==b.target)a=true;return!this.options.disabled&&a},_mouseStart:function(b){var a=this.options,c=this.element.position(),
|
||||
d=this.element;this.resizing=true;this.documentScroll={top:e(document).scrollTop(),left:e(document).scrollLeft()};if(d.is(".ui-draggable")||/absolute/.test(d.css("position")))d.css({position:"absolute",top:c.top,left:c.left});e.browser.opera&&/relative/.test(d.css("position"))&&d.css({position:"relative",top:"auto",left:"auto"});this._renderProxy();c=m(this.helper.css("left"));var f=m(this.helper.css("top"));if(a.containment){c+=e(a.containment).scrollLeft()||0;f+=e(a.containment).scrollTop()||0}this.offset=
|
||||
this.helper.offset();this.position={left:c,top:f};this.size=this._helper?{width:d.outerWidth(),height:d.outerHeight()}:{width:d.width(),height:d.height()};this.originalSize=this._helper?{width:d.outerWidth(),height:d.outerHeight()}:{width:d.width(),height:d.height()};this.originalPosition={left:c,top:f};this.sizeDiff={width:d.outerWidth()-d.width(),height:d.outerHeight()-d.height()};this.originalMousePosition={left:b.pageX,top:b.pageY};this.aspectRatio=typeof a.aspectRatio=="number"?a.aspectRatio:
|
||||
this.originalSize.width/this.originalSize.height||1;a=e(".ui-resizable-"+this.axis).css("cursor");e("body").css("cursor",a=="auto"?this.axis+"-resize":a);d.addClass("ui-resizable-resizing");this._propagate("start",b);return true},_mouseDrag:function(b){var a=this.helper,c=this.originalMousePosition,d=this._change[this.axis];if(!d)return false;c=d.apply(this,[b,b.pageX-c.left||0,b.pageY-c.top||0]);if(this._aspectRatio||b.shiftKey)c=this._updateRatio(c,b);c=this._respectSize(c,b);this._propagate("resize",
|
||||
b);a.css({top:this.position.top+"px",left:this.position.left+"px",width:this.size.width+"px",height:this.size.height+"px"});!this._helper&&this._proportionallyResizeElements.length&&this._proportionallyResize();this._updateCache(c);this._trigger("resize",b,this.ui());return false},_mouseStop:function(b){this.resizing=false;var a=this.options,c=this;if(this._helper){var d=this._proportionallyResizeElements,f=d.length&&/textarea/i.test(d[0].nodeName);d=f&&e.ui.hasScroll(d[0],"left")?0:c.sizeDiff.height;
|
||||
f=f?0:c.sizeDiff.width;f={width:c.helper.width()-f,height:c.helper.height()-d};d=parseInt(c.element.css("left"),10)+(c.position.left-c.originalPosition.left)||null;var g=parseInt(c.element.css("top"),10)+(c.position.top-c.originalPosition.top)||null;a.animate||this.element.css(e.extend(f,{top:g,left:d}));c.helper.height(c.size.height);c.helper.width(c.size.width);this._helper&&!a.animate&&this._proportionallyResize()}e("body").css("cursor","auto");this.element.removeClass("ui-resizable-resizing");
|
||||
this._propagate("stop",b);this._helper&&this.helper.remove();return false},_updateCache:function(b){this.offset=this.helper.offset();if(l(b.left))this.position.left=b.left;if(l(b.top))this.position.top=b.top;if(l(b.height))this.size.height=b.height;if(l(b.width))this.size.width=b.width},_updateRatio:function(b){var a=this.position,c=this.size,d=this.axis;if(b.height)b.width=c.height*this.aspectRatio;else if(b.width)b.height=c.width/this.aspectRatio;if(d=="sw"){b.left=a.left+(c.width-b.width);b.top=
|
||||
null}if(d=="nw"){b.top=a.top+(c.height-b.height);b.left=a.left+(c.width-b.width)}return b},_respectSize:function(b){var a=this.options,c=this.axis,d=l(b.width)&&a.maxWidth&&a.maxWidth<b.width,f=l(b.height)&&a.maxHeight&&a.maxHeight<b.height,g=l(b.width)&&a.minWidth&&a.minWidth>b.width,h=l(b.height)&&a.minHeight&&a.minHeight>b.height;if(g)b.width=a.minWidth;if(h)b.height=a.minHeight;if(d)b.width=a.maxWidth;if(f)b.height=a.maxHeight;var i=this.originalPosition.left+this.originalSize.width,j=this.position.top+
|
||||
this.size.height,k=/sw|nw|w/.test(c);c=/nw|ne|n/.test(c);if(g&&k)b.left=i-a.minWidth;if(d&&k)b.left=i-a.maxWidth;if(h&&c)b.top=j-a.minHeight;if(f&&c)b.top=j-a.maxHeight;if((a=!b.width&&!b.height)&&!b.left&&b.top)b.top=null;else if(a&&!b.top&&b.left)b.left=null;return b},_proportionallyResize:function(){if(this._proportionallyResizeElements.length)for(var b=this.helper||this.element,a=0;a<this._proportionallyResizeElements.length;a++){var c=this._proportionallyResizeElements[a];if(!this.borderDif){var d=
|
||||
[c.css("borderTopWidth"),c.css("borderRightWidth"),c.css("borderBottomWidth"),c.css("borderLeftWidth")],f=[c.css("paddingTop"),c.css("paddingRight"),c.css("paddingBottom"),c.css("paddingLeft")];this.borderDif=e.map(d,function(g,h){g=parseInt(g,10)||0;h=parseInt(f[h],10)||0;return g+h})}e.browser.msie&&(e(b).is(":hidden")||e(b).parents(":hidden").length)||c.css({height:b.height()-this.borderDif[0]-this.borderDif[2]||0,width:b.width()-this.borderDif[1]-this.borderDif[3]||0})}},_renderProxy:function(){var b=
|
||||
this.options;this.elementOffset=this.element.offset();if(this._helper){this.helper=this.helper||e('<div style="overflow:hidden;"></div>');var a=e.browser.msie&&e.browser.version<7,c=a?1:0;a=a?2:-1;this.helper.addClass(this._helper).css({width:this.element.outerWidth()+a,height:this.element.outerHeight()+a,position:"absolute",left:this.elementOffset.left-c+"px",top:this.elementOffset.top-c+"px",zIndex:++b.zIndex});this.helper.appendTo("body").disableSelection()}else this.helper=this.element},_change:{e:function(b,
|
||||
a){return{width:this.originalSize.width+a}},w:function(b,a){return{left:this.originalPosition.left+a,width:this.originalSize.width-a}},n:function(b,a,c){return{top:this.originalPosition.top+c,height:this.originalSize.height-c}},s:function(b,a,c){return{height:this.originalSize.height+c}},se:function(b,a,c){return e.extend(this._change.s.apply(this,arguments),this._change.e.apply(this,[b,a,c]))},sw:function(b,a,c){return e.extend(this._change.s.apply(this,arguments),this._change.w.apply(this,[b,a,
|
||||
c]))},ne:function(b,a,c){return e.extend(this._change.n.apply(this,arguments),this._change.e.apply(this,[b,a,c]))},nw:function(b,a,c){return e.extend(this._change.n.apply(this,arguments),this._change.w.apply(this,[b,a,c]))}},_propagate:function(b,a){e.ui.plugin.call(this,b,[a,this.ui()]);b!="resize"&&this._trigger(b,a,this.ui())},plugins:{},ui:function(){return{originalElement:this.originalElement,element:this.element,helper:this.helper,position:this.position,size:this.size,originalSize:this.originalSize,
|
||||
originalPosition:this.originalPosition}}});e.extend(e.ui.resizable,{version:"1.8.11"});e.ui.plugin.add("resizable","alsoResize",{start:function(){var b=e(this).data("resizable").options,a=function(c){e(c).each(function(){var d=e(this);d.data("resizable-alsoresize",{width:parseInt(d.width(),10),height:parseInt(d.height(),10),left:parseInt(d.css("left"),10),top:parseInt(d.css("top"),10),position:d.css("position")})})};if(typeof b.alsoResize=="object"&&!b.alsoResize.parentNode)if(b.alsoResize.length){b.alsoResize=
|
||||
b.alsoResize[0];a(b.alsoResize)}else e.each(b.alsoResize,function(c){a(c)});else a(b.alsoResize)},resize:function(b,a){var c=e(this).data("resizable");b=c.options;var d=c.originalSize,f=c.originalPosition,g={height:c.size.height-d.height||0,width:c.size.width-d.width||0,top:c.position.top-f.top||0,left:c.position.left-f.left||0},h=function(i,j){e(i).each(function(){var k=e(this),q=e(this).data("resizable-alsoresize"),p={},r=j&&j.length?j:k.parents(a.originalElement[0]).length?["width","height"]:["width",
|
||||
"height","top","left"];e.each(r,function(n,o){if((n=(q[o]||0)+(g[o]||0))&&n>=0)p[o]=n||null});if(e.browser.opera&&/relative/.test(k.css("position"))){c._revertToRelativePosition=true;k.css({position:"absolute",top:"auto",left:"auto"})}k.css(p)})};typeof b.alsoResize=="object"&&!b.alsoResize.nodeType?e.each(b.alsoResize,function(i,j){h(i,j)}):h(b.alsoResize)},stop:function(){var b=e(this).data("resizable"),a=b.options,c=function(d){e(d).each(function(){var f=e(this);f.css({position:f.data("resizable-alsoresize").position})})};
|
||||
if(b._revertToRelativePosition){b._revertToRelativePosition=false;typeof a.alsoResize=="object"&&!a.alsoResize.nodeType?e.each(a.alsoResize,function(d){c(d)}):c(a.alsoResize)}e(this).removeData("resizable-alsoresize")}});e.ui.plugin.add("resizable","animate",{stop:function(b){var a=e(this).data("resizable"),c=a.options,d=a._proportionallyResizeElements,f=d.length&&/textarea/i.test(d[0].nodeName),g=f&&e.ui.hasScroll(d[0],"left")?0:a.sizeDiff.height;f={width:a.size.width-(f?0:a.sizeDiff.width),height:a.size.height-
|
||||
g};g=parseInt(a.element.css("left"),10)+(a.position.left-a.originalPosition.left)||null;var h=parseInt(a.element.css("top"),10)+(a.position.top-a.originalPosition.top)||null;a.element.animate(e.extend(f,h&&g?{top:h,left:g}:{}),{duration:c.animateDuration,easing:c.animateEasing,step:function(){var i={width:parseInt(a.element.css("width"),10),height:parseInt(a.element.css("height"),10),top:parseInt(a.element.css("top"),10),left:parseInt(a.element.css("left"),10)};d&&d.length&&e(d[0]).css({width:i.width,
|
||||
height:i.height});a._updateCache(i);a._propagate("resize",b)}})}});e.ui.plugin.add("resizable","containment",{start:function(){var b=e(this).data("resizable"),a=b.element,c=b.options.containment;if(a=c instanceof e?c.get(0):/parent/.test(c)?a.parent().get(0):c){b.containerElement=e(a);if(/document/.test(c)||c==document){b.containerOffset={left:0,top:0};b.containerPosition={left:0,top:0};b.parentData={element:e(document),left:0,top:0,width:e(document).width(),height:e(document).height()||document.body.parentNode.scrollHeight}}else{var d=
|
||||
e(a),f=[];e(["Top","Right","Left","Bottom"]).each(function(i,j){f[i]=m(d.css("padding"+j))});b.containerOffset=d.offset();b.containerPosition=d.position();b.containerSize={height:d.innerHeight()-f[3],width:d.innerWidth()-f[1]};c=b.containerOffset;var g=b.containerSize.height,h=b.containerSize.width;h=e.ui.hasScroll(a,"left")?a.scrollWidth:h;g=e.ui.hasScroll(a)?a.scrollHeight:g;b.parentData={element:a,left:c.left,top:c.top,width:h,height:g}}}},resize:function(b){var a=e(this).data("resizable"),c=a.options,
|
||||
d=a.containerOffset,f=a.position;b=a._aspectRatio||b.shiftKey;var g={top:0,left:0},h=a.containerElement;if(h[0]!=document&&/static/.test(h.css("position")))g=d;if(f.left<(a._helper?d.left:0)){a.size.width+=a._helper?a.position.left-d.left:a.position.left-g.left;if(b)a.size.height=a.size.width/c.aspectRatio;a.position.left=c.helper?d.left:0}if(f.top<(a._helper?d.top:0)){a.size.height+=a._helper?a.position.top-d.top:a.position.top;if(b)a.size.width=a.size.height*c.aspectRatio;a.position.top=a._helper?
|
||||
d.top:0}a.offset.left=a.parentData.left+a.position.left;a.offset.top=a.parentData.top+a.position.top;c=Math.abs((a._helper?a.offset.left-g.left:a.offset.left-g.left)+a.sizeDiff.width);d=Math.abs((a._helper?a.offset.top-g.top:a.offset.top-d.top)+a.sizeDiff.height);f=a.containerElement.get(0)==a.element.parent().get(0);g=/relative|absolute/.test(a.containerElement.css("position"));if(f&&g)c-=a.parentData.left;if(c+a.size.width>=a.parentData.width){a.size.width=a.parentData.width-c;if(b)a.size.height=
|
||||
a.size.width/a.aspectRatio}if(d+a.size.height>=a.parentData.height){a.size.height=a.parentData.height-d;if(b)a.size.width=a.size.height*a.aspectRatio}},stop:function(){var b=e(this).data("resizable"),a=b.options,c=b.containerOffset,d=b.containerPosition,f=b.containerElement,g=e(b.helper),h=g.offset(),i=g.outerWidth()-b.sizeDiff.width;g=g.outerHeight()-b.sizeDiff.height;b._helper&&!a.animate&&/relative/.test(f.css("position"))&&e(this).css({left:h.left-d.left-c.left,width:i,height:g});b._helper&&!a.animate&&
|
||||
/static/.test(f.css("position"))&&e(this).css({left:h.left-d.left-c.left,width:i,height:g})}});e.ui.plugin.add("resizable","ghost",{start:function(){var b=e(this).data("resizable"),a=b.options,c=b.size;b.ghost=b.originalElement.clone();b.ghost.css({opacity:0.25,display:"block",position:"relative",height:c.height,width:c.width,margin:0,left:0,top:0}).addClass("ui-resizable-ghost").addClass(typeof a.ghost=="string"?a.ghost:"");b.ghost.appendTo(b.helper)},resize:function(){var b=e(this).data("resizable");
|
||||
b.ghost&&b.ghost.css({position:"relative",height:b.size.height,width:b.size.width})},stop:function(){var b=e(this).data("resizable");b.ghost&&b.helper&&b.helper.get(0).removeChild(b.ghost.get(0))}});e.ui.plugin.add("resizable","grid",{resize:function(){var b=e(this).data("resizable"),a=b.options,c=b.size,d=b.originalSize,f=b.originalPosition,g=b.axis;a.grid=typeof a.grid=="number"?[a.grid,a.grid]:a.grid;var h=Math.round((c.width-d.width)/(a.grid[0]||1))*(a.grid[0]||1);a=Math.round((c.height-d.height)/
|
||||
(a.grid[1]||1))*(a.grid[1]||1);if(/^(se|s|e)$/.test(g)){b.size.width=d.width+h;b.size.height=d.height+a}else if(/^(ne)$/.test(g)){b.size.width=d.width+h;b.size.height=d.height+a;b.position.top=f.top-a}else{if(/^(sw)$/.test(g)){b.size.width=d.width+h;b.size.height=d.height+a}else{b.size.width=d.width+h;b.size.height=d.height+a;b.position.top=f.top-a}b.position.left=f.left-h}}});var m=function(b){return parseInt(b,10)||0},l=function(b){return!isNaN(parseInt(b,10))}})(jQuery);
|
||||
;
|
12092
admin/js/jquery.dataTables.js
vendored
Normal file
20
admin/js/jquery.equalHeight.js
Normal file
|
@ -0,0 +1,20 @@
|
|||
// make sure the $ is pointing to JQuery and not some other library
|
||||
(function($){
|
||||
// add a new method to JQuery
|
||||
|
||||
$.fn.equalHeight = function() {
|
||||
// find the tallest height in the collection
|
||||
// that was passed in (.column)
|
||||
tallest = 0;
|
||||
this.each(function(){
|
||||
thisHeight = $(this).height();
|
||||
if( thisHeight > tallest)
|
||||
tallest = thisHeight;
|
||||
});
|
||||
|
||||
// set each items height to use the tallest value found
|
||||
this.each(function(){
|
||||
$(this).height(tallest);
|
||||
});
|
||||
}
|
||||
})(jQuery);
|
1823
admin/js/jquery.ui.datepicker.js
vendored
Normal file
1248
admin/js/jquery.validate.js
vendored
Normal file
83
admin/js/login.js
Normal file
|
@ -0,0 +1,83 @@
|
|||
// JavaScript Document
|
||||
//login page javascript
|
||||
|
||||
$(document).ready(function() {
|
||||
//the form wrapper (includes all forms)
|
||||
var $form_wrapper = $('#form_wrapper'),
|
||||
//the current form is the one with class active
|
||||
$currentForm = $form_wrapper.children('form.active'),
|
||||
//the change form links
|
||||
$linkform = $form_wrapper.find('.linkform');
|
||||
|
||||
//get width and height of each form and store them for later
|
||||
$form_wrapper.children('form').each(function(i){
|
||||
var $theForm = $(this);
|
||||
//solve the inline display none problem when using fadeIn fadeOut
|
||||
if(!$theForm.hasClass('active'))
|
||||
$theForm.hide();
|
||||
$theForm.data({
|
||||
width : $theForm.width(),
|
||||
height : $theForm.height()
|
||||
});
|
||||
});
|
||||
|
||||
//set width and height of wrapper (same of current form)
|
||||
setWrapperWidth();
|
||||
|
||||
/*
|
||||
clicking a link (change form event) in the form
|
||||
makes the current form hide.
|
||||
The wrapper animates its width and height to the
|
||||
width and height of the new current form.
|
||||
After the animation, the new form is shown
|
||||
*/
|
||||
$linkform.bind('click',function(e){
|
||||
var $link = $(this);
|
||||
var target = $link.attr('rel');
|
||||
$currentForm.fadeOut(400,function(){
|
||||
//remove class active from current form
|
||||
$currentForm.removeClass('active');
|
||||
//new current form
|
||||
$currentForm= $form_wrapper.children('form.'+target);
|
||||
//animate the wrapper
|
||||
$form_wrapper.stop()
|
||||
.animate({
|
||||
width : $currentForm.data('width') + 'px',
|
||||
height : $currentForm.data('height') + 'px'
|
||||
},500,function(){
|
||||
//new form gets class active
|
||||
$currentForm.addClass('active');
|
||||
//show the new form
|
||||
$currentForm.fadeIn(400);
|
||||
});
|
||||
});
|
||||
e.preventDefault();
|
||||
});
|
||||
|
||||
function setWrapperWidth(){
|
||||
$form_wrapper.css({
|
||||
width : $currentForm.data('width') + 'px',
|
||||
height : $currentForm.data('height') + 'px'
|
||||
});
|
||||
}
|
||||
// Login form validation
|
||||
$("#loginInForm").validate({
|
||||
rules: {
|
||||
username: "required",
|
||||
password: "required"
|
||||
},
|
||||
messages: {
|
||||
username: "",
|
||||
password: ""
|
||||
}
|
||||
});
|
||||
// forgot password form validation
|
||||
$("#forgotForm").validate({
|
||||
rules: {
|
||||
username: "required"
|
||||
},
|
||||
messages: {
|
||||
username: ""
|
||||
}
|
||||
});
|
||||
});
|
8
admin/logout.php
Normal file
|
@ -0,0 +1,8 @@
|
|||
<?php
|
||||
include("../config/config.php");
|
||||
|
||||
session_destroy();
|
||||
|
||||
$url = ADMIN_URL;
|
||||
header("Location:$url");
|
||||
?>
|
38
admin/plugins/fckeditor/_documentation.html
Normal file
|
@ -0,0 +1,38 @@
|
|||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
||||
<!--
|
||||
* FCKeditor - The text editor for Internet - http://www.fckeditor.net
|
||||
* Copyright (C) 2003-2009 Frederico Caldeira Knabben
|
||||
*
|
||||
* == BEGIN LICENSE ==
|
||||
*
|
||||
* Licensed under the terms of any of the following licenses at your
|
||||
* choice:
|
||||
*
|
||||
* - GNU General Public License Version 2 or later (the "GPL")
|
||||
* http://www.gnu.org/licenses/gpl.html
|
||||
*
|
||||
* - GNU Lesser General Public License Version 2.1 or later (the "LGPL")
|
||||
* http://www.gnu.org/licenses/lgpl.html
|
||||
*
|
||||
* - Mozilla Public License Version 1.1 or later (the "MPL")
|
||||
* http://www.mozilla.org/MPL/MPL-1.1.html
|
||||
*
|
||||
* == END LICENSE ==
|
||||
-->
|
||||
<html xmlns="http://www.w3.org/1999/xhtml">
|
||||
<head>
|
||||
<title>FCKeditor - Documentation</title>
|
||||
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
|
||||
<style type="text/css">
|
||||
body { font-family: arial, verdana, sans-serif }
|
||||
p { margin-left: 20px }
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<h1>
|
||||
FCKeditor Documentation</h1>
|
||||
<p>
|
||||
You can find the official documentation for FCKeditor online, at <a href="http://docs.fckeditor.net/">
|
||||
http://docs.fckeditor.net/</a>.</p>
|
||||
</body>
|
||||
</html>
|
39
admin/plugins/fckeditor/_upgrade.html
Normal file
|
@ -0,0 +1,39 @@
|
|||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
||||
<!--
|
||||
* FCKeditor - The text editor for Internet - http://www.fckeditor.net
|
||||
* Copyright (C) 2003-2009 Frederico Caldeira Knabben
|
||||
*
|
||||
* == BEGIN LICENSE ==
|
||||
*
|
||||
* Licensed under the terms of any of the following licenses at your
|
||||
* choice:
|
||||
*
|
||||
* - GNU General Public License Version 2 or later (the "GPL")
|
||||
* http://www.gnu.org/licenses/gpl.html
|
||||
*
|
||||
* - GNU Lesser General Public License Version 2.1 or later (the "LGPL")
|
||||
* http://www.gnu.org/licenses/lgpl.html
|
||||
*
|
||||
* - Mozilla Public License Version 1.1 or later (the "MPL")
|
||||
* http://www.mozilla.org/MPL/MPL-1.1.html
|
||||
*
|
||||
* == END LICENSE ==
|
||||
-->
|
||||
<html xmlns="http://www.w3.org/1999/xhtml">
|
||||
<head>
|
||||
<title>FCKeditor - Upgrade</title>
|
||||
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
|
||||
<style type="text/css">
|
||||
body { font-family: arial, verdana, sans-serif }
|
||||
p { margin-left: 20px }
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<h1>
|
||||
FCKeditor Upgrade</h1>
|
||||
<p>
|
||||
Please check the following URL for notes regarding upgrade:<br />
|
||||
<a href="http://docs.fckeditor.net/FCKeditor_2.x/Developers_Guide/Installation/Upgrading">
|
||||
http://docs.fckeditor.net/FCKeditor_2.x/Developers_Guide/Installation/Upgrading</a></p>
|
||||
</body>
|
||||
</html>
|
170
admin/plugins/fckeditor/_whatsnew.html
Normal file
|
@ -0,0 +1,170 @@
|
|||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
||||
<!--
|
||||
* FCKeditor - The text editor for Internet - http://www.fckeditor.net
|
||||
* Copyright (C) 2003-2009 Frederico Caldeira Knabben
|
||||
*
|
||||
* == BEGIN LICENSE ==
|
||||
*
|
||||
* Licensed under the terms of any of the following licenses at your
|
||||
* choice:
|
||||
*
|
||||
* - GNU General Public License Version 2 or later (the "GPL")
|
||||
* http://www.gnu.org/licenses/gpl.html
|
||||
*
|
||||
* - GNU Lesser General Public License Version 2.1 or later (the "LGPL")
|
||||
* http://www.gnu.org/licenses/lgpl.html
|
||||
*
|
||||
* - Mozilla Public License Version 1.1 or later (the "MPL")
|
||||
* http://www.mozilla.org/MPL/MPL-1.1.html
|
||||
*
|
||||
* == END LICENSE ==
|
||||
-->
|
||||
<html xmlns="http://www.w3.org/1999/xhtml">
|
||||
<head>
|
||||
<title>FCKeditor ChangeLog - What's New?</title>
|
||||
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
|
||||
<style type="text/css">
|
||||
body { font-family: arial, verdana, sans-serif }
|
||||
p { margin-left: 20px }
|
||||
h1 { border-bottom: solid 1px gray; padding-bottom: 20px }
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<h1>
|
||||
FCKeditor ChangeLog - What's New?</h1>
|
||||
<h3>
|
||||
Version 2.6.4</h3>
|
||||
<p>
|
||||
Fixed Bugs:</p>
|
||||
<ul>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2777">#2777</a>] Merging
|
||||
cells between table header and body is no longer possible.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2815">#2815</a>] Fixed
|
||||
WSC issues at slow connection speed. Added SSL support.</li>
|
||||
<li>Language file updates for the following languages:
|
||||
<ul>
|
||||
<li>Chinese (Traditional)</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2846">#2846</a>] French</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2801">#2801</a>] Hebrew</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2824">#2824</a>] Russian</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2811">#2811</a>] Turkish</li>
|
||||
</ul>
|
||||
</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2757">#2757</a>] Fixed
|
||||
a minor bug which causes selection positions to be improperly restored during undos
|
||||
and redos.</li>
|
||||
</ul>
|
||||
<h3>
|
||||
Version 2.6.4 Beta</h3>
|
||||
<p>
|
||||
New Features and Improvements:</p>
|
||||
<ul>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2685">#2685</a>] Integration
|
||||
with "WebSpellChecker", a <strong>zero installation and free spell checker</strong>
|
||||
provided by SpellChecker.net. This is now the default spell checker in the editor
|
||||
(requires internet connection). All previous spell checking solutions are still
|
||||
available.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2430">#2430</a>] In the
|
||||
table dialog it's possible to create header cells in the first row (included in
|
||||
a thead element) or the first column of the table. </li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/822">#822</a>] The table
|
||||
cell dialog allows switching between normal data cells or header cells (TD vs. TH).
|
||||
</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2515">#2515</a>] New language
|
||||
file for Icelandic.</li>
|
||||
</ul>
|
||||
<p>
|
||||
Fixed Bugs:</p>
|
||||
<ul>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2381">#2381</a>] Protected
|
||||
the editor from duplicate iframes</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/1752">#1752</a>] Fixed
|
||||
the issue with tablecommands plugin and undefined tagName.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2333">#2333</a>] The &gt;
|
||||
character inside text wasn't encoded in Opera and Safari.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2467">#2467</a>] Fixed
|
||||
JavaScript error with the fit window command in source mode.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2472">#2472</a>] Splitting
|
||||
a TH will create a two TH, not a TH and a TD.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/1891">#1891</a>] Removed
|
||||
unnecessary name attributes in dialogs. </li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/798">#798</a>, <a target="_blank"
|
||||
href="http://dev.fckeditor.net/ticket/2495">#2495</a>] If an image was placed inside
|
||||
a container with dimensions or floating it wasn't possible to edit its properties
|
||||
from the toolbar or context menu.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/1982">#1982</a>] Submenus
|
||||
in IE7 now are shown properly.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2496">#2496</a>] Using
|
||||
the Paste dialogs in IE might insert the content at the start of the editor.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2349">#2496</a>] Fixed
|
||||
RTL dialog layout in Internet Explorer.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2488">#2488</a>] Fixed
|
||||
the issue where email links in IE would take the browser to a new page in addition
|
||||
to calling up the email client.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2519">#2519</a>] Fixed
|
||||
race condition at registering the FCKeditorAPI object in multiple editor scenarios.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2525">#2525</a>] Fixed
|
||||
JavaScript error in Google Chrome when StartupShowBlocks is set to true.</li>
|
||||
<li>Language file updates for the following languages:
|
||||
<ul>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2440">#2440</a>] Dutch</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2451">#2451</a>] Basque</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2451">#2650</a>] Danish</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2208">#2535</a>] German
|
||||
</li>
|
||||
</ul>
|
||||
</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2531">#2531</a>] The ENTER
|
||||
key will properly scroll to the cursor position when breaking long paragraphs.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2573">#2573</a>] The type
|
||||
name in configurations for the ASP connector are now case sensitive.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2503">#2503</a>] DL, DT
|
||||
and DD where missing the formatting in the generated HTML.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2516">#2516</a>] Replaced
|
||||
the extension AddItem of Array with the standard "push" method.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2486">#2486</a>] Vertically
|
||||
splitting cell with colspan > 1 breaks table layout.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2597">#2597</a>] Fixed
|
||||
the issue where dropping contents from outside of the editor doesn't work in Safari.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2412">#2412</a>] Fixed
|
||||
the issue where FCK.InsertHtml() is no longer removing selected contents after content
|
||||
insertion in Firefox.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2407">#2407</a>] Fixed
|
||||
the issue where the Div container command and the blockquote command would break
|
||||
lists.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2469">#2469</a>] Fixed
|
||||
a minor issue where FCK.SetData() may cause the editor to become unresponsive to
|
||||
the first click after being defocused.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2611">#2611</a>] Fixed
|
||||
an extra slash on quickupload of the asp connector.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2616">#2616</a>] Fixed
|
||||
another situation where new elements were inserted at the beginning of the content
|
||||
in IE.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2634">#2634</a>] Fixed
|
||||
two obsolete references to Array::AddItem() instances still in the code.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2679">#2679</a>] Fixed
|
||||
infinite loop problems with FCKDomRangeIterator class which causes some commands
|
||||
to hang when applied to certain document structures.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2649">#2649</a>] Fixed
|
||||
a JavaScript error in IE when user tries to search with the "Match whole word" option
|
||||
enabled and the matched word is at exactly the end of document.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2603">#2603</a>] Changed
|
||||
the <a href="http://docs.fckeditor.net/EMailProtection">EMailProtection</a> to "none"
|
||||
for better compatibility.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2612">#2612</a>] The 'ForcePasteAsPlainText'
|
||||
configuration option didn't work correctly in Safari and Chrome.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2696">#2696</a>] Fixed
|
||||
non-working autogrow plugin.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2753">#2753</a>] Fixed
|
||||
occasional exceptions in the dragersizetable plugin with IE.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/2653">#2653</a>] and [<a
|
||||
target="_blank" href="http://dev.fckeditor.net/ticket/2733">#2733</a>] Enable undo
|
||||
of changes to tables and table cells.</li>
|
||||
<li>[<a target="_blank" href="http://dev.fckeditor.net/ticket/1865">#1865</a>] The context
|
||||
menu is now working properly over the last row in a table with thead. Thanks to
|
||||
Koen Willems.</li>
|
||||
</ul>
|
||||
<p>
|
||||
<a href="_whatsnew_history.html">See previous versions history</a></p>
|
||||
</body>
|
||||
</html>
|
3916
admin/plugins/fckeditor/_whatsnew_history.html
Normal file
64
admin/plugins/fckeditor/custom_config.js
Normal file
|
@ -0,0 +1,64 @@
|
|||
/*
|
||||
* Custom Configuration file
|
||||
*
|
||||
*/
|
||||
|
||||
|
||||
// Allow QuickEdit style tags <quickedit:name />
|
||||
FCKConfig.ProtectedSource.Add( /(<quickedit:[^\>]+>[\s|\S]*?<\/quickedit:[^\>]+>)|(<quickedit:[^\>]+\/>)/gi );
|
||||
// For snippet calls, uncomment the next two lines if you wish to hide snippet calls from FCK visual editing mode (only show in source mode)
|
||||
// FCKConfig.ProtectedSource.Add( /\[\[[\s\S]*?\]\]/gi );
|
||||
// FCKConfig.ProtectedSource.Add( /\[\![\s\S]*?\!\]/gi );
|
||||
|
||||
/* *
|
||||
* Language settings
|
||||
*
|
||||
*/
|
||||
FCKConfig.AutoDetectLanguage = parent.FCKAutoLanguage;
|
||||
FCKConfig.DefaultLanguage = parent.FCKDefaultLanguage;
|
||||
|
||||
/* *
|
||||
* Other Settings
|
||||
*
|
||||
*/
|
||||
FCKConfig.FormatSource = false ;
|
||||
|
||||
/* *
|
||||
* setup toolbar sets
|
||||
*
|
||||
*/
|
||||
// basic
|
||||
FCKConfig.ToolbarSets["basic"] = [
|
||||
['Bold','Italic','-','OrderedList','UnorderedList','-','Link','Unlink','Image']
|
||||
];
|
||||
// standard
|
||||
FCKConfig.ToolbarSets["standard"] = [
|
||||
['Source','-','Preview','-','Templates'],
|
||||
['Cut','Copy','Paste','PasteText','PasteWord'],
|
||||
['Undo','Redo','-','Find','Replace','-','RemoveFormat'],
|
||||
['Bold','Italic','Underline'],
|
||||
['OrderedList','UnorderedList','-','Outdent','Indent'],
|
||||
['JustifyLeft','JustifyCenter','JustifyRight','JustifyFull'],
|
||||
['Link','Anchor'],
|
||||
['Image','Flash','Table','Rule','SpecialChar'],
|
||||
['Style'],['FontFormat'],['FontName'],['FontSize'],
|
||||
['TextColor','BGColor'],['FitWindow','-','About']
|
||||
];
|
||||
// advanced
|
||||
FCKConfig.ToolbarSets["advanced"] = [
|
||||
['Source','DocProps','-','NewPage','Preview','-','Templates'],
|
||||
['Cut','Copy','Paste','PasteText','PasteWord','-','Print','SpellCheck'],
|
||||
['Undo','Redo','-','Find','Replace','-','SelectAll','RemoveFormat'],
|
||||
['Bold','Italic','Underline','StrikeThrough','-','Subscript','Superscript'],
|
||||
['OrderedList','UnorderedList','-','Outdent','Indent'],
|
||||
['JustifyLeft','JustifyCenter','JustifyRight','JustifyFull'],
|
||||
['Link','Unlink','Anchor'],
|
||||
['Image','Flash','Table','Rule','Smiley','SpecialChar'],
|
||||
['Form','Checkbox','Radio','TextField','Textarea','Select','Button','ImageButton','HiddenField'],
|
||||
'/',
|
||||
['Style'],['FontFormat'],['FontName'],['FontSize'],
|
||||
['TextColor','BGColor'],['FitWindow','-','About']
|
||||
];
|
||||
// custom
|
||||
FCKConfig.ToolbarSets["custom"] = parent.FCKCustomToolbarSet;
|
||||
|