mirror of
https://github.com/YunoHost-Apps/chtickynotes_ynh.git
synced 2024-09-03 18:15:57 +02:00
Created
Copied from ynh-chtickynotes and begining of boards management
This commit is contained in:
parent
a02b12114b
commit
c63ca08270
29 changed files with 14311 additions and 0 deletions
21
LICENSE.txt
Normal file
21
LICENSE.txt
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
The MIT License (MIT)
|
||||||
|
|
||||||
|
Copyright (c) 2014 Chtixof
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
in the Software without restriction, including without limitation the rights
|
||||||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
SOFTWARE.
|
17
README.md
Normal file
17
README.md
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
# chtickynotes_ynh : sticky notes for Yunohost #
|
||||||
|
|
||||||
|
chtickynotes_ynh is packaged to be installed on a [Yunohost](https://yunohost.org) server.
|
||||||
|
|
||||||
|
chtickynotes_ynh is a "simple post-it" application. Its main features are:
|
||||||
|
- notes movable and resizable
|
||||||
|
- edit note by just typing on it (or CTRL-V to paste chunks of HTML)
|
||||||
|
- menu on each note to change its color, and so on
|
||||||
|
- global menu to change board, and so on
|
||||||
|
- autosave every 10 seconds
|
||||||
|
- storage on the server (not on the browser local storage)
|
||||||
|
|
||||||
|
**Screen shot:**<br>
|
||||||
|

|
||||||
|
|
||||||
|
chtickynotes_ynh core is based on [Post It All!](https://github.com/txusko/PostItAll).
|
||||||
|
|
18
conf/nginx.conf
Normal file
18
conf/nginx.conf
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
location PATHTOCHANGE {
|
||||||
|
|
||||||
|
alias WWWPATH ;
|
||||||
|
|
||||||
|
index index.html index.php ;
|
||||||
|
try_files $uri $uri/ index.php;
|
||||||
|
location ~ [^/]\.php(/|$) {
|
||||||
|
fastcgi_split_path_info ^(.+?\.php)(/.*)$;
|
||||||
|
fastcgi_pass unix:/var/run/php5-fpm.sock;
|
||||||
|
fastcgi_index index.php;
|
||||||
|
include fastcgi_params;
|
||||||
|
fastcgi_param REMOTE_USER $remote_user;
|
||||||
|
fastcgi_param PATH_INFO $fastcgi_path_info;
|
||||||
|
}
|
||||||
|
|
||||||
|
# Include SSOWAT user panel.
|
||||||
|
include conf.d/yunohost_panel.conf.inc;
|
||||||
|
}
|
31
manifest.json
Normal file
31
manifest.json
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
{
|
||||||
|
"name": "ChtickyNotes",
|
||||||
|
"id": "chtickynotes",
|
||||||
|
"description": {
|
||||||
|
"en": "Generic sticky notes for all purpose",
|
||||||
|
"fr": "Des post-its génériques à tout faire"
|
||||||
|
},
|
||||||
|
"license": "MIT",
|
||||||
|
"developer": {
|
||||||
|
"name": "chtixof"
|
||||||
|
},
|
||||||
|
"multi_instance": "false",
|
||||||
|
"arguments": {
|
||||||
|
"install" : [ {
|
||||||
|
"name": "domain",
|
||||||
|
"ask": {
|
||||||
|
"en": "Choose a domain for ChtickyNotes",
|
||||||
|
"en": "Choisissez un domaine pour ChtickyNotes"
|
||||||
|
},
|
||||||
|
"example": "domain.org"
|
||||||
|
},{
|
||||||
|
"name": "path",
|
||||||
|
"ask": {
|
||||||
|
"en": "Choose a path for ChtickyNotes",
|
||||||
|
"en": "Choisissez un chemin pour ChtickyNotes"
|
||||||
|
},
|
||||||
|
"example": "/chtickynotes",
|
||||||
|
"default": "/chtickynotes"
|
||||||
|
} ]
|
||||||
|
}
|
||||||
|
}
|
15
scripts/backup
Normal file
15
scripts/backup
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
#!/bin/bash
|
||||||
|
app=chtickynotes
|
||||||
|
|
||||||
|
# The parameter $1 is the backup directory location
|
||||||
|
# which will be compressed afterward
|
||||||
|
backup_dir=$1/apps/$app
|
||||||
|
mkdir -p $backup_dir
|
||||||
|
|
||||||
|
# Backup sources & data
|
||||||
|
sudo cp -a /var/www/$app/. $backup_dir/sources
|
||||||
|
|
||||||
|
# Copy Nginx and YunoHost parameters to make the script "standalone"
|
||||||
|
sudo cp -a /etc/yunohost/apps/$app/. $backup_dir/yunohost
|
||||||
|
domain=$(sudo yunohost app setting $app domain)
|
||||||
|
sudo cp -a /etc/nginx/conf.d/$domain.d/$app.conf $backup_dir/nginx.conf
|
28
scripts/install
Normal file
28
scripts/install
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
#!/bin/bash
|
||||||
|
# Installation de ChtickyNotes dans Yunohost
|
||||||
|
app=chtickynotes
|
||||||
|
|
||||||
|
# Retrieve arguments
|
||||||
|
domain=$1
|
||||||
|
path=$2
|
||||||
|
|
||||||
|
# Check domain/path availability
|
||||||
|
sudo yunohost app checkurl $domain$path -a $app
|
||||||
|
if [[ ! $? -eq 0 ]]; then
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Copy files to the right place with the right permissions
|
||||||
|
final_path=/var/www/$app
|
||||||
|
sudo mkdir -p $final_path
|
||||||
|
sudo cp -a ../sources/* $final_path
|
||||||
|
sudo chown -R www-data: $final_path
|
||||||
|
|
||||||
|
# Modify Nginx configuration file and copy it to Nginx conf directory
|
||||||
|
sed -i "s@PATHTOCHANGE@$path@g" ../conf/nginx.conf
|
||||||
|
sed -i "s@WWWPATH@$final_path@g" ../conf/nginx.conf
|
||||||
|
sudo cp ../conf/nginx.conf /etc/nginx/conf.d/$domain.d/$app.conf
|
||||||
|
|
||||||
|
# Reload nginx and regenerate SSOwat conf
|
||||||
|
sudo service nginx reload
|
||||||
|
sudo yunohost app ssowatconf
|
15
scripts/remove
Normal file
15
scripts/remove
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
#!/bin/bash
|
||||||
|
app=chtickynotes
|
||||||
|
|
||||||
|
# Retrieve arguments
|
||||||
|
domain=$(sudo yunohost app setting $app domain)
|
||||||
|
|
||||||
|
# Remove sources
|
||||||
|
sudo rm -rf /var/www/$app
|
||||||
|
|
||||||
|
# Remove configuration files
|
||||||
|
sudo rm -f /etc/nginx/conf.d/$domain.d/$app.conf
|
||||||
|
|
||||||
|
# Restart services
|
||||||
|
sudo service nginx reload
|
||||||
|
sudo yunohost app ssowatconf
|
16
scripts/restore
Normal file
16
scripts/restore
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
#!/bin/bash
|
||||||
|
app=chtickynotes
|
||||||
|
|
||||||
|
# The parameter $1 is the uncompressed restore directory location
|
||||||
|
backup_dir=$1/apps/$app
|
||||||
|
|
||||||
|
# Restore sources & data
|
||||||
|
sudo cp -a $backup_dir/sources/. /var/www/$app
|
||||||
|
|
||||||
|
# Restore Nginx and YunoHost parameters
|
||||||
|
sudo cp -a $backup_dir/yunohost/. /etc/yunohost/apps/$app
|
||||||
|
domain=$(sudo yunohost app setting $app domain)
|
||||||
|
sudo cp -a $backup_dir/nginx.conf /etc/nginx/conf.d/$domain.d/$app.conf
|
||||||
|
|
||||||
|
# Restart webserver
|
||||||
|
sudo service nginx reload
|
24
scripts/upgrade
Normal file
24
scripts/upgrade
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
#!/bin/bash
|
||||||
|
app=chtickynotes
|
||||||
|
|
||||||
|
# Retrieve arguments
|
||||||
|
domain=$(sudo yunohost app setting $app domain)
|
||||||
|
path=$(sudo yunohost app setting $app path)
|
||||||
|
|
||||||
|
# Remove trailing "/" for next commands
|
||||||
|
path=${path%/}
|
||||||
|
|
||||||
|
# Copy source files
|
||||||
|
final_path=/var/www/$app
|
||||||
|
sudo mkdir -p $final_path
|
||||||
|
sudo cp -a ../sources/* $final_path
|
||||||
|
|
||||||
|
# Modify Nginx configuration file and copy it to Nginx conf directory
|
||||||
|
sed -i "s@PATHTOCHANGE@$path@g" ../conf/nginx.conf
|
||||||
|
sed -i "s@WWWPATH@$final_path@g" ../conf/nginx.conf
|
||||||
|
sudo cp ../conf/nginx.conf /etc/nginx/conf.d/$domain.d/$app.conf
|
||||||
|
|
||||||
|
# Restart services
|
||||||
|
sudo service nginx reload
|
||||||
|
sudo yunohost app ssowatconf
|
||||||
|
|
10
sources/fav.php
Normal file
10
sources/fav.php
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
<?php
|
||||||
|
$text=file_get_contents('php://input');
|
||||||
|
if ($text!="") {
|
||||||
|
file_put_contents('allnotes.json', $text);
|
||||||
|
header("Cache-Control: no-cache, must-revalidate");
|
||||||
|
header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");
|
||||||
|
header("Content-Type: application/json; charset=utf-8");
|
||||||
|
echo($text);
|
||||||
|
}
|
||||||
|
?>
|
250
sources/index.html
Normal file
250
sources/index.html
Normal file
|
@ -0,0 +1,250 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<head>
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
|
||||||
|
<title>ChtickyNotes
|
||||||
|
</title>
|
||||||
|
<meta name="description" content="">
|
||||||
|
<meta name="viewport" content="width=device-width">
|
||||||
|
<link rel="stylesheet" href="libs/jquery-ui-1.10.0.custom.css">
|
||||||
|
<link rel="stylesheet" href="libs/bootstrap.min.css">
|
||||||
|
<link rel="stylesheet" href="libs/bootstrap-responsive.min.css">
|
||||||
|
<link rel="stylesheet" href="libs/jquery.minicolors.css">
|
||||||
|
<link rel="stylesheet" href="plugin/jquery.postitall.css">
|
||||||
|
<link rel="stylesheet" href="libs/main.css">
|
||||||
|
<style>
|
||||||
|
body {
|
||||||
|
background: #41444f;
|
||||||
|
color: #bbb;
|
||||||
|
}
|
||||||
|
#chtimenu {
|
||||||
|
margin-left: 10px;
|
||||||
|
}
|
||||||
|
#chtimenu a, .chme a {
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
#chtimenu a:hover {
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
#saved {
|
||||||
|
position:absolute;
|
||||||
|
}
|
||||||
|
#saveallnotes {
|
||||||
|
position:absolute;
|
||||||
|
background: #41444f;
|
||||||
|
}
|
||||||
|
#chtoption {
|
||||||
|
background-image: url();
|
||||||
|
position:absolute;
|
||||||
|
top:15px;
|
||||||
|
right:15px;
|
||||||
|
cursor: pointer;
|
||||||
|
width: 20px;
|
||||||
|
height: 20px;
|
||||||
|
background-position: center;
|
||||||
|
background-repeat: no-repeat;
|
||||||
|
}
|
||||||
|
.chme {
|
||||||
|
position: absolute;
|
||||||
|
display: none;
|
||||||
|
z-index: 100000;
|
||||||
|
right: 15px;
|
||||||
|
}
|
||||||
|
#chtoptmenu {
|
||||||
|
width: 275px;
|
||||||
|
height: 40px;
|
||||||
|
top: 15px;
|
||||||
|
}
|
||||||
|
#chlist {
|
||||||
|
width: 400px;
|
||||||
|
height: 40px;
|
||||||
|
top: 45px;
|
||||||
|
}
|
||||||
|
.chme label{
|
||||||
|
display: inline;
|
||||||
|
}
|
||||||
|
#chtoptmenu ul {
|
||||||
|
top: 30px;
|
||||||
|
width: 275px;
|
||||||
|
}
|
||||||
|
#chlist ul {
|
||||||
|
width: 400px;
|
||||||
|
}
|
||||||
|
.chme ul {
|
||||||
|
margin: 0;
|
||||||
|
list-style: none;
|
||||||
|
padding: 0;
|
||||||
|
position: absolute;
|
||||||
|
}
|
||||||
|
.chme ul li {
|
||||||
|
font: 14px;
|
||||||
|
margin-right: -4px;
|
||||||
|
position: relative;
|
||||||
|
padding: 5px 20px;
|
||||||
|
cursor: pointer;
|
||||||
|
background: #555;
|
||||||
|
display: block;
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
.chme ul li:hover { background: #666; }
|
||||||
|
.center { text-align: center; }
|
||||||
|
.float-left { float: left; }
|
||||||
|
.float-right { float: right; }
|
||||||
|
.vertical-bottom { vertical-align: bottom; }
|
||||||
|
.vertical-middle { vertical-align: middle; }
|
||||||
|
.vertical-top { vertical-align: top; }
|
||||||
|
.clear { clear: both; }
|
||||||
|
.red { color: red; }
|
||||||
|
.red a { color: red; font-weight: bold; text-decoration: none; }
|
||||||
|
.red a:hover { text-decoration: underline; }
|
||||||
|
|
||||||
|
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<!--[if lt IE 7]>
|
||||||
|
<p class="chromeframe">You are using an <strong>outdated</strong> browser. Please <a href="http://browsehappy.com/">upgrade your browser</a> or <a href="http://www.google.com/chromeframe/?redirect=true">activate Google Chrome Frame</a> to improve your experience.</p>
|
||||||
|
<![endif]-->
|
||||||
|
<div id="chtimenu">
|
||||||
|
<a id="addanote" href="javascript:void(0)">Add a note</a>
|
||||||
|
<span id="saved">(saved)</span>
|
||||||
|
<a id="saveallnotes" href="javascript:void(0)">Save all notes</a>
|
||||||
|
</div>
|
||||||
|
<div id="addanote_result">
|
||||||
|
</div>
|
||||||
|
<div id="chtoption">
|
||||||
|
</div>
|
||||||
|
<div id="chtoptmenu" class="chme">
|
||||||
|
<ul>
|
||||||
|
<li id="chboard">Change board</li>
|
||||||
|
<li><a href="javascript:alert('tbd')">Background color</a></li>
|
||||||
|
<li><a href="javascript:alert('tbd')">Title</a></li>
|
||||||
|
<li><a href="javascript:alert('tbd')">This board is shared. Make it private?</a></li>
|
||||||
|
<li><a href="javascript:alert('tbd')">Delete this board</a></li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
<div id="chlist" class="chme">
|
||||||
|
<ul>
|
||||||
|
<li>First Board (shared)</li>
|
||||||
|
<li>Second Board (shared)</li>
|
||||||
|
<li><New board></a></li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
|
||||||
|
<script>window.jQuery || document.write('<script src="libs/jquery-1.9.1.min.js"><\/script>')</script>
|
||||||
|
<script src="//ajax.googleapis.com/ajax/libs/jqueryui/1.10.1/jquery-ui.min.js"></script>
|
||||||
|
<script>window.jQuery || document.write('<script src="libs/jquery-ui-1.10.1.min.js"><\/script>')</script>
|
||||||
|
<script src="libs/bootstrap.min.js"></script>
|
||||||
|
<script src="//google-code-prettify.googlecode.com/svn/loader/run_prettify.js?autoload=true&skin=sunburst&lang=css" defer="defer"></script>
|
||||||
|
<script src="libs/jquery.minicolors.js"></script>
|
||||||
|
<script src="plugin/jquery.postitall.js"></script>
|
||||||
|
<script src="libs/main.js"></script>
|
||||||
|
<script>
|
||||||
|
|
||||||
|
function saveallnotes(){}
|
||||||
|
|
||||||
|
//global reqini for ajax
|
||||||
|
var reqini = new XMLHttpRequest();
|
||||||
|
|
||||||
|
//here we go
|
||||||
|
$(document).ready(function() {
|
||||||
|
|
||||||
|
//Minicolors for the form
|
||||||
|
$('.minicolors').minicolors();
|
||||||
|
|
||||||
|
//Add a note
|
||||||
|
$('#addanote').click(function() {
|
||||||
|
$('#addanote_result').postitall();
|
||||||
|
});
|
||||||
|
|
||||||
|
// set function to save all notes in the z-index order
|
||||||
|
saveallnotes=function() {
|
||||||
|
var allnotes=[];
|
||||||
|
var req = new XMLHttpRequest();
|
||||||
|
$('.PIApostit').each(function() {
|
||||||
|
var thisone=$(this).postitall('options');
|
||||||
|
allnotes.push({
|
||||||
|
"date": thisone.date,
|
||||||
|
"showdate": thisone.showdate,
|
||||||
|
"title": thisone.title,
|
||||||
|
"backgroundcolor": thisone.backgroundcolor,
|
||||||
|
"textcolor": thisone.textcolor,
|
||||||
|
"posX": thisone.posX,
|
||||||
|
"posY": thisone.posY,
|
||||||
|
"height": thisone.height,
|
||||||
|
"width": thisone.width,
|
||||||
|
"description": thisone.description,
|
||||||
|
"zindex": parseInt($(this).css('z-index'))
|
||||||
|
});
|
||||||
|
});
|
||||||
|
allnotes.sort(function (a,b) {
|
||||||
|
if (a.zindex < b.zindex)
|
||||||
|
return -1;
|
||||||
|
if (a.zindex > b.zindex)
|
||||||
|
return 1;
|
||||||
|
return 0;
|
||||||
|
});
|
||||||
|
|
||||||
|
allnotes.forEach(function(thisone){
|
||||||
|
delete thisone.zindex;
|
||||||
|
});
|
||||||
|
|
||||||
|
text=JSON.stringify(allnotes);
|
||||||
|
//ajax out
|
||||||
|
req.open("POST", "fav.php", true);
|
||||||
|
req.setRequestHeader("Content-type", "application/json");
|
||||||
|
req.onreadystatechange = function()
|
||||||
|
{
|
||||||
|
if (req.readyState == 4) {
|
||||||
|
$('#saveallnotes').hide(); //=(saved)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
req.send(text);
|
||||||
|
}
|
||||||
|
|
||||||
|
$('#saveallnotes').click(saveallnotes); // set function to link
|
||||||
|
|
||||||
|
$('#chtoption').click(function () { // set function to menu for options
|
||||||
|
$('#chtoptmenu').show();
|
||||||
|
});
|
||||||
|
|
||||||
|
$('.chme').mouseleave(function(){
|
||||||
|
$(this).hide();
|
||||||
|
});
|
||||||
|
|
||||||
|
$('#chboard').click(function () {
|
||||||
|
$('#chlist').show();
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// ajax in
|
||||||
|
reqini.open("GET", "allnotes.json", true);
|
||||||
|
reqini.onreadystatechange = function()
|
||||||
|
{
|
||||||
|
if (reqini.readyState == 4) {
|
||||||
|
text=reqini.responseText;
|
||||||
|
try {
|
||||||
|
JSON.parse(text);
|
||||||
|
} catch (e) {
|
||||||
|
text = '[]';
|
||||||
|
}
|
||||||
|
JSON.parse(text).forEach(function(note){
|
||||||
|
$('#addanote_result').postitall(note);
|
||||||
|
});
|
||||||
|
$('.PIApostit').postitall('isittosave','#saveallnotes'); // prevents to save on load! and sets id to hide/show
|
||||||
|
$('#saveallnotes').hide(); //=(saved)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
reqini.send(null);
|
||||||
|
});
|
||||||
|
// timer to save every 10 s. if required
|
||||||
|
window.setInterval(function () {
|
||||||
|
if($('.PIApostit').postitall('isittosave')){saveallnotes()}
|
||||||
|
}, 10000);
|
||||||
|
</script>
|
||||||
|
</body>
|
||||||
|
</html>
|
1109
sources/libs/bootstrap-responsive.css
vendored
Normal file
1109
sources/libs/bootstrap-responsive.css
vendored
Normal file
File diff suppressed because it is too large
Load diff
9
sources/libs/bootstrap-responsive.min.css
vendored
Normal file
9
sources/libs/bootstrap-responsive.min.css
vendored
Normal file
File diff suppressed because one or more lines are too long
6158
sources/libs/bootstrap.css
vendored
Normal file
6158
sources/libs/bootstrap.css
vendored
Normal file
File diff suppressed because it is too large
Load diff
2268
sources/libs/bootstrap.js
vendored
Normal file
2268
sources/libs/bootstrap.js
vendored
Normal file
File diff suppressed because it is too large
Load diff
9
sources/libs/bootstrap.min.css
vendored
Normal file
9
sources/libs/bootstrap.min.css
vendored
Normal file
File diff suppressed because one or more lines are too long
6
sources/libs/bootstrap.min.js
vendored
Normal file
6
sources/libs/bootstrap.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
5
sources/libs/jquery-1.9.1.min.js
vendored
Normal file
5
sources/libs/jquery-1.9.1.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
1174
sources/libs/jquery-ui-1.10.0.custom.css
vendored
Normal file
1174
sources/libs/jquery-ui-1.10.0.custom.css
vendored
Normal file
File diff suppressed because it is too large
Load diff
5
sources/libs/jquery-ui-1.10.1.min.js
vendored
Normal file
5
sources/libs/jquery-ui-1.10.1.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
1174
sources/libs/jquery-ui.css
vendored
Normal file
1174
sources/libs/jquery-ui.css
vendored
Normal file
File diff suppressed because it is too large
Load diff
278
sources/libs/jquery.minicolors.css
Normal file
278
sources/libs/jquery.minicolors.css
Normal file
|
@ -0,0 +1,278 @@
|
||||||
|
.minicolors {
|
||||||
|
position: relative;
|
||||||
|
display: inline-block;
|
||||||
|
z-index: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-focus {
|
||||||
|
z-index: 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors.minicolors-theme-default .minicolors-input {
|
||||||
|
margin: 0px;
|
||||||
|
margin-right: 3px;
|
||||||
|
border: solid 1px #CCC;
|
||||||
|
font: 14px sans-serif;
|
||||||
|
width: 65px;
|
||||||
|
height: 16px;
|
||||||
|
border-radius: 0;
|
||||||
|
box-shadow: inset 0 2px 4px rgba(0, 0, 0, .04);
|
||||||
|
padding: 2px;
|
||||||
|
margin-right: -1px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-theme-default.minicolors .minicolors-input {
|
||||||
|
vertical-align: middle;
|
||||||
|
outline: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-theme-default.minicolors-swatch-left .minicolors-input {
|
||||||
|
margin-left: -1px;
|
||||||
|
margin-right: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-theme-default.minicolors-focus .minicolors-input,
|
||||||
|
.minicolors-theme-default.minicolors-focus .minicolors-swatch {
|
||||||
|
border-color: #999;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-hidden {
|
||||||
|
position: absolute;
|
||||||
|
left: -9999em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-swatch {
|
||||||
|
position: relative;
|
||||||
|
width: 20px;
|
||||||
|
height: 20px;
|
||||||
|
text-align: left;
|
||||||
|
background: url(jquery.minicolors.png) -80px 0;
|
||||||
|
border: solid 1px #CCC;
|
||||||
|
vertical-align: middle;
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-swatch SPAN {
|
||||||
|
position: absolute;
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
background: none;
|
||||||
|
box-shadow: inset 0 9px 0 rgba(255, 255, 255, .1);
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Panel */
|
||||||
|
.minicolors-panel {
|
||||||
|
position: absolute;
|
||||||
|
top: 26px;
|
||||||
|
left: 0;
|
||||||
|
width: 173px;
|
||||||
|
height: 152px;
|
||||||
|
background: white;
|
||||||
|
border: solid 1px #CCC;
|
||||||
|
box-shadow: 0 0 20px rgba(0, 0, 0, .2);
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-position-top .minicolors-panel {
|
||||||
|
top: -156px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-position-left .minicolors-panel {
|
||||||
|
left: -83px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-position-left.minicolors-with-opacity .minicolors-panel {
|
||||||
|
left: -104px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-with-opacity .minicolors-panel {
|
||||||
|
width: 194px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors .minicolors-grid {
|
||||||
|
position: absolute;
|
||||||
|
top: 1px;
|
||||||
|
left: 1px;
|
||||||
|
width: 150px;
|
||||||
|
height: 150px;
|
||||||
|
background: url(jquery.minicolors.png) -120px 0;
|
||||||
|
cursor: crosshair;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors .minicolors-grid-inner {
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
width: 150px;
|
||||||
|
height: 150px;
|
||||||
|
background: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-slider-saturation .minicolors-grid {
|
||||||
|
background-position: -420px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-slider-saturation .minicolors-grid-inner {
|
||||||
|
background: url(jquery.minicolors.png) -270px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-slider-brightness .minicolors-grid {
|
||||||
|
background-position: -570px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-slider-brightness .minicolors-grid-inner {
|
||||||
|
background: black;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-slider-wheel .minicolors-grid {
|
||||||
|
background-position: -720px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-slider,
|
||||||
|
.minicolors-opacity-slider {
|
||||||
|
position: absolute;
|
||||||
|
top: 1px;
|
||||||
|
left: 152px;
|
||||||
|
width: 20px;
|
||||||
|
height: 150px;
|
||||||
|
background: white url(jquery.minicolors.png) 0 0;
|
||||||
|
cursor: crosshair;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-slider-saturation .minicolors-slider {
|
||||||
|
background-position: -60px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-slider-brightness .minicolors-slider {
|
||||||
|
background-position: -20px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-slider-wheel .minicolors-slider {
|
||||||
|
background-position: -20px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-opacity-slider {
|
||||||
|
left: 173px;
|
||||||
|
background-position: -40px 0;
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-with-opacity .minicolors-opacity-slider {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Pickers */
|
||||||
|
.minicolors-grid .minicolors-picker {
|
||||||
|
position: absolute;
|
||||||
|
top: 70px;
|
||||||
|
left: 70px;
|
||||||
|
width: 10px;
|
||||||
|
height: 10px;
|
||||||
|
border: solid 1px black;
|
||||||
|
border-radius: 10px;
|
||||||
|
margin-top: -6px;
|
||||||
|
margin-left: -6px;
|
||||||
|
background: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-grid .minicolors-picker SPAN {
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
width: 6px;
|
||||||
|
height: 6px;
|
||||||
|
border-radius: 6px;
|
||||||
|
border: solid 2px white;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-picker {
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
width: 18px;
|
||||||
|
height: 2px;
|
||||||
|
background: white;
|
||||||
|
border: solid 1px black;
|
||||||
|
margin-top: -2px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Inline controls */
|
||||||
|
.minicolors-inline .minicolors-input,
|
||||||
|
.minicolors-inline .minicolors-swatch {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-inline .minicolors-panel {
|
||||||
|
position: relative;
|
||||||
|
top: auto;
|
||||||
|
left: auto;
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Bootstrap Theme (theme: 'bootstrap')
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Input styles */
|
||||||
|
.minicolors-theme-bootstrap .minicolors-input {
|
||||||
|
padding: 4px 6px;
|
||||||
|
padding-left: 30px;
|
||||||
|
background-color: white;
|
||||||
|
border: 1px solid #CCC;
|
||||||
|
border-radius: 3px;
|
||||||
|
color: #555;
|
||||||
|
font-family: Arial, 'Helvetica Neue', Helvetica, sans-serif;
|
||||||
|
font-size: 14px;
|
||||||
|
height: 19px;
|
||||||
|
margin: 0px;
|
||||||
|
box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* When the input has focus */
|
||||||
|
.minicolors-theme-bootstrap.minicolors-focus .minicolors-input {
|
||||||
|
border-color: #6fb8f1;
|
||||||
|
box-shadow: 0 0 10px #6fb8f1;
|
||||||
|
outline: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Swatch styles */
|
||||||
|
.minicolors-theme-bootstrap .minicolors-swatch {
|
||||||
|
position: absolute;
|
||||||
|
left: 4px;
|
||||||
|
top: 4px;
|
||||||
|
z-index: 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Handle swatch position (left = default / right) */
|
||||||
|
.minicolors-theme-bootstrap.minicolors-swatch-position-right .minicolors-input {
|
||||||
|
padding-left: 6px;
|
||||||
|
padding-right: 30px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-theme-bootstrap.minicolors-swatch-position-right .minicolors-swatch {
|
||||||
|
left: auto;
|
||||||
|
right: 4px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Panel styles */
|
||||||
|
.minicolors-theme-bootstrap .minicolors-panel {
|
||||||
|
top: 28px;
|
||||||
|
z-index: 3;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Handle panel positions (top / left) */
|
||||||
|
.minicolors-theme-bootstrap.minicolors-position-top .minicolors-panel {
|
||||||
|
top: -154px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.minicolors-theme-bootstrap.minicolors-position-left .minicolors-panel {
|
||||||
|
left: -63px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Don't forget to adjust the left position in case the opacity slider is visible! */
|
||||||
|
.minicolors-theme-bootstrap.minicolors-position-left.minicolors-with-opacity .minicolors-panel {
|
||||||
|
left: -84px;
|
||||||
|
}
|
857
sources/libs/jquery.minicolors.js
Normal file
857
sources/libs/jquery.minicolors.js
Normal file
|
@ -0,0 +1,857 @@
|
||||||
|
/*
|
||||||
|
* jQuery MiniColors: A tiny color picker built on jQuery
|
||||||
|
*
|
||||||
|
* Copyright Cory LaViska for A Beautiful Site, LLC. (http://www.abeautifulsite.net/)
|
||||||
|
*
|
||||||
|
* Dual-licensed under the MIT and GPL Version 2 licenses
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
if(jQuery) (function($) {
|
||||||
|
|
||||||
|
// Yay, MiniColors!
|
||||||
|
$.minicolors = {
|
||||||
|
// Default settings
|
||||||
|
defaultSettings: {
|
||||||
|
animationSpeed: 100,
|
||||||
|
animationEasing: 'swing',
|
||||||
|
change: null,
|
||||||
|
changeDelay: 0,
|
||||||
|
control: 'hue',
|
||||||
|
defaultValue: '',
|
||||||
|
hide: null,
|
||||||
|
hideSpeed: 100,
|
||||||
|
inline: false,
|
||||||
|
letterCase: 'lowercase',
|
||||||
|
opacity: false,
|
||||||
|
position: 'default',
|
||||||
|
show: null,
|
||||||
|
showSpeed: 100,
|
||||||
|
swatchPosition: 'left',
|
||||||
|
textfield: true,
|
||||||
|
theme: 'default'
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// Public methods
|
||||||
|
$.extend($.fn, {
|
||||||
|
minicolors: function(method, data) {
|
||||||
|
|
||||||
|
switch(method) {
|
||||||
|
|
||||||
|
// Destroy the control
|
||||||
|
case 'destroy':
|
||||||
|
$(this).each( function() {
|
||||||
|
destroy($(this));
|
||||||
|
});
|
||||||
|
return $(this);
|
||||||
|
|
||||||
|
// Hide the color picker
|
||||||
|
case 'hide':
|
||||||
|
hide();
|
||||||
|
return $(this);
|
||||||
|
|
||||||
|
// Get/set opacity
|
||||||
|
case 'opacity':
|
||||||
|
if( data === undefined ) {
|
||||||
|
// Getter
|
||||||
|
return $(this).attr('data-opacity');
|
||||||
|
} else {
|
||||||
|
// Setter
|
||||||
|
$(this).each( function() {
|
||||||
|
refresh($(this).attr('data-opacity', data));
|
||||||
|
});
|
||||||
|
return $(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get an RGB(A) object based on the current color/opacity
|
||||||
|
case 'rgbObject':
|
||||||
|
return rgbObject($(this), method === 'rgbaObject');
|
||||||
|
|
||||||
|
// Get an RGB(A) string based on the current color/opacity
|
||||||
|
case 'rgbString':
|
||||||
|
case 'rgbaString':
|
||||||
|
return rgbString($(this), method === 'rgbaString')
|
||||||
|
|
||||||
|
// Get/set settings on the fly
|
||||||
|
case 'settings':
|
||||||
|
if( data === undefined ) {
|
||||||
|
return $(this).data('minicolors-settings');
|
||||||
|
} else {
|
||||||
|
// Setter
|
||||||
|
$(this).each( function() {
|
||||||
|
var settings = $(this).data('minicolors-settings') || {};
|
||||||
|
destroy($(this));
|
||||||
|
$(this).minicolors($.extend(true, settings, data));
|
||||||
|
});
|
||||||
|
return $(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Show the color picker
|
||||||
|
case 'show':
|
||||||
|
show( $(this).eq(0) );
|
||||||
|
return $(this);
|
||||||
|
|
||||||
|
// Get/set the hex color value
|
||||||
|
case 'value':
|
||||||
|
if( data === undefined ) {
|
||||||
|
// Getter
|
||||||
|
return $(this).val();
|
||||||
|
} else {
|
||||||
|
// Setter
|
||||||
|
$(this).each( function() {
|
||||||
|
refresh($(this).val(data));
|
||||||
|
});
|
||||||
|
return $(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Initializes the control
|
||||||
|
case 'create':
|
||||||
|
default:
|
||||||
|
if( method !== 'create' ) data = method;
|
||||||
|
$(this).each( function() {
|
||||||
|
init($(this), data);
|
||||||
|
});
|
||||||
|
return $(this);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Initialize input elements
|
||||||
|
function init(input, settings) {
|
||||||
|
|
||||||
|
var minicolors = $('<span class="minicolors" />'),
|
||||||
|
defaultSettings = $.minicolors.defaultSettings;
|
||||||
|
|
||||||
|
// Do nothing if already initialized
|
||||||
|
if( input.data('minicolors-initialized') ) return;
|
||||||
|
|
||||||
|
// Handle settings
|
||||||
|
settings = $.extend(true, {}, defaultSettings, settings);
|
||||||
|
|
||||||
|
// The wrapper
|
||||||
|
minicolors
|
||||||
|
.addClass('minicolors-theme-' + settings.theme)
|
||||||
|
.addClass('minicolors-swatch-position-' + settings.swatchPosition)
|
||||||
|
.toggleClass('minicolors-swatch-left', settings.swatchPosition === 'left')
|
||||||
|
.toggleClass('minicolors-with-opacity', settings.opacity);
|
||||||
|
|
||||||
|
// Custom positioning
|
||||||
|
if( settings.position !== undefined ) {
|
||||||
|
$.each(settings.position.split(' '), function() {
|
||||||
|
minicolors.addClass('minicolors-position-' + this);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// The input
|
||||||
|
input
|
||||||
|
.addClass('minicolors-input')
|
||||||
|
.data('minicolors-initialized', true)
|
||||||
|
.data('minicolors-settings', settings)
|
||||||
|
.prop('size', 7)
|
||||||
|
.prop('maxlength', 7)
|
||||||
|
.wrap(minicolors)
|
||||||
|
.after(
|
||||||
|
'<span class="minicolors-panel minicolors-slider-' + settings.control + '">' +
|
||||||
|
'<span class="minicolors-slider">' +
|
||||||
|
'<span class="minicolors-picker"></span>' +
|
||||||
|
'</span>' +
|
||||||
|
'<span class="minicolors-opacity-slider">' +
|
||||||
|
'<span class="minicolors-picker"></span>' +
|
||||||
|
'</span>' +
|
||||||
|
'<span class="minicolors-grid">' +
|
||||||
|
'<span class="minicolors-grid-inner"></span>' +
|
||||||
|
'<span class="minicolors-picker"><span></span></span>' +
|
||||||
|
'</span>' +
|
||||||
|
'</span>'
|
||||||
|
);
|
||||||
|
|
||||||
|
// Prevent text selection in IE
|
||||||
|
input.parent().find('.minicolors-panel').on('selectstart', function() { return false; }).end();
|
||||||
|
|
||||||
|
// Detect swatch position
|
||||||
|
if( settings.swatchPosition === 'left' ) {
|
||||||
|
// Left
|
||||||
|
input.before('<span class="minicolors-swatch"><span></span></span>');
|
||||||
|
} else {
|
||||||
|
// Right
|
||||||
|
input.after('<span class="minicolors-swatch"><span></span></span>');
|
||||||
|
}
|
||||||
|
|
||||||
|
// Disable textfield
|
||||||
|
if( !settings.textfield ) input.addClass('minicolors-hidden');
|
||||||
|
|
||||||
|
// Inline controls
|
||||||
|
if( settings.inline ) input.parent().addClass('minicolors-inline');
|
||||||
|
|
||||||
|
updateFromInput(input, false, true);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Returns the input back to its original state
|
||||||
|
function destroy(input) {
|
||||||
|
|
||||||
|
var minicolors = input.parent();
|
||||||
|
|
||||||
|
// Revert the input element
|
||||||
|
input
|
||||||
|
.removeData('minicolors-initialized')
|
||||||
|
.removeData('minicolors-settings')
|
||||||
|
.removeProp('size')
|
||||||
|
.removeProp('maxlength')
|
||||||
|
.removeClass('minicolors-input');
|
||||||
|
|
||||||
|
// Remove the wrap and destroy whatever remains
|
||||||
|
minicolors.before(input).remove();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Refresh the specified control
|
||||||
|
function refresh(input) {
|
||||||
|
updateFromInput(input);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Shows the specified dropdown panel
|
||||||
|
function show(input) {
|
||||||
|
|
||||||
|
var minicolors = input.parent(),
|
||||||
|
panel = minicolors.find('.minicolors-panel'),
|
||||||
|
settings = input.data('minicolors-settings');
|
||||||
|
|
||||||
|
// Do nothing if uninitialized, disabled, inline, or already open
|
||||||
|
if( !input.data('minicolors-initialized') ||
|
||||||
|
input.prop('disabled') ||
|
||||||
|
minicolors.hasClass('minicolors-inline') ||
|
||||||
|
minicolors.hasClass('minicolors-focus')
|
||||||
|
) return;
|
||||||
|
|
||||||
|
hide();
|
||||||
|
|
||||||
|
minicolors.addClass('minicolors-focus');
|
||||||
|
panel
|
||||||
|
.stop(true, true)
|
||||||
|
.fadeIn(settings.showSpeed, function() {
|
||||||
|
if( settings.show ) settings.show.call(input);
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Hides all dropdown panels
|
||||||
|
function hide() {
|
||||||
|
|
||||||
|
$('.minicolors-input').each( function() {
|
||||||
|
|
||||||
|
var input = $(this),
|
||||||
|
settings = input.data('minicolors-settings'),
|
||||||
|
minicolors = input.parent();
|
||||||
|
|
||||||
|
// Don't hide inline controls
|
||||||
|
if( settings.inline ) return;
|
||||||
|
|
||||||
|
minicolors.find('.minicolors-panel').fadeOut(settings.hideSpeed, function() {
|
||||||
|
if(minicolors.hasClass('minicolors-focus')) {
|
||||||
|
if( settings.hide ) settings.hide.call(input);
|
||||||
|
}
|
||||||
|
minicolors.removeClass('minicolors-focus');
|
||||||
|
});
|
||||||
|
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// Moves the selected picker
|
||||||
|
function move(target, event, animate) {
|
||||||
|
|
||||||
|
var input = target.parents('.minicolors').find('.minicolors-input'),
|
||||||
|
settings = input.data('minicolors-settings'),
|
||||||
|
picker = target.find('[class$=-picker]'),
|
||||||
|
offsetX = target.offset().left,
|
||||||
|
offsetY = target.offset().top,
|
||||||
|
x = Math.round(event.pageX - offsetX),
|
||||||
|
y = Math.round(event.pageY - offsetY),
|
||||||
|
duration = animate ? settings.animationSpeed : 0,
|
||||||
|
wx, wy, r, phi;
|
||||||
|
|
||||||
|
|
||||||
|
// Touch support
|
||||||
|
if( event.originalEvent.changedTouches ) {
|
||||||
|
x = event.originalEvent.changedTouches[0].pageX - offsetX;
|
||||||
|
y = event.originalEvent.changedTouches[0].pageY - offsetY;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Constrain picker to its container
|
||||||
|
if( x < 0 ) x = 0;
|
||||||
|
if( y < 0 ) y = 0;
|
||||||
|
if( x > target.width() ) x = target.width();
|
||||||
|
if( y > target.height() ) y = target.height();
|
||||||
|
|
||||||
|
// Constrain color wheel values to the wheel
|
||||||
|
if( target.parent().is('.minicolors-slider-wheel') && picker.parent().is('.minicolors-grid') ) {
|
||||||
|
wx = 75 - x;
|
||||||
|
wy = 75 - y;
|
||||||
|
r = Math.sqrt(wx * wx + wy * wy);
|
||||||
|
phi = Math.atan2(wy, wx);
|
||||||
|
if( phi < 0 ) phi += Math.PI * 2;
|
||||||
|
if( r > 75 ) {
|
||||||
|
r = 75;
|
||||||
|
x = 75 - (75 * Math.cos(phi));
|
||||||
|
y = 75 - (75 * Math.sin(phi));
|
||||||
|
}
|
||||||
|
x = Math.round(x);
|
||||||
|
y = Math.round(y);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Move the picker
|
||||||
|
if( target.is('.minicolors-grid') ) {
|
||||||
|
picker
|
||||||
|
.stop(true)
|
||||||
|
.animate({
|
||||||
|
top: y + 'px',
|
||||||
|
left: x + 'px'
|
||||||
|
}, duration, settings.animationEasing, function() {
|
||||||
|
updateFromControl(input, target);
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
picker
|
||||||
|
.stop(true)
|
||||||
|
.animate({
|
||||||
|
top: y + 'px'
|
||||||
|
}, duration, settings.animationEasing, function() {
|
||||||
|
updateFromControl(input, target);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Sets the input based on the color picker values
|
||||||
|
function updateFromControl(input, target) {
|
||||||
|
|
||||||
|
function getCoords(picker, container) {
|
||||||
|
|
||||||
|
var left, top;
|
||||||
|
if( !picker.length || !container ) return null;
|
||||||
|
left = picker.offset().left;
|
||||||
|
top = picker.offset().top;
|
||||||
|
|
||||||
|
return {
|
||||||
|
x: left - container.offset().left + (picker.outerWidth() / 2),
|
||||||
|
y: top - container.offset().top + (picker.outerHeight() / 2)
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
var hue, saturation, brightness, rgb, x, y, r, phi,
|
||||||
|
|
||||||
|
hex = input.val(),
|
||||||
|
opacity = input.attr('data-opacity'),
|
||||||
|
|
||||||
|
// Helpful references
|
||||||
|
minicolors = input.parent(),
|
||||||
|
settings = input.data('minicolors-settings'),
|
||||||
|
panel = minicolors.find('.minicolors-panel'),
|
||||||
|
swatch = minicolors.find('.minicolors-swatch'),
|
||||||
|
|
||||||
|
// Panel objects
|
||||||
|
grid = minicolors.find('.minicolors-grid'),
|
||||||
|
slider = minicolors.find('.minicolors-slider'),
|
||||||
|
opacitySlider = minicolors.find('.minicolors-opacity-slider'),
|
||||||
|
|
||||||
|
// Picker objects
|
||||||
|
gridPicker = grid.find('[class$=-picker]'),
|
||||||
|
sliderPicker = slider.find('[class$=-picker]'),
|
||||||
|
opacityPicker = opacitySlider.find('[class$=-picker]'),
|
||||||
|
|
||||||
|
// Picker positions
|
||||||
|
gridPos = getCoords(gridPicker, grid),
|
||||||
|
sliderPos = getCoords(sliderPicker, slider),
|
||||||
|
opacityPos = getCoords(opacityPicker, opacitySlider);
|
||||||
|
|
||||||
|
// Handle colors
|
||||||
|
if( target.is('.minicolors-grid, .minicolors-slider') ) {
|
||||||
|
|
||||||
|
// Determine HSB values
|
||||||
|
switch(settings.control) {
|
||||||
|
|
||||||
|
case 'wheel':
|
||||||
|
// Calculate hue, saturation, and brightness
|
||||||
|
x = (grid.width() / 2) - gridPos.x;
|
||||||
|
y = (grid.height() / 2) - gridPos.y;
|
||||||
|
r = Math.sqrt(x * x + y * y);
|
||||||
|
phi = Math.atan2(y, x);
|
||||||
|
if( phi < 0 ) phi += Math.PI * 2;
|
||||||
|
if( r > 75 ) {
|
||||||
|
r = 75;
|
||||||
|
gridPos.x = 69 - (75 * Math.cos(phi));
|
||||||
|
gridPos.y = 69 - (75 * Math.sin(phi));
|
||||||
|
}
|
||||||
|
saturation = keepWithin(r / 0.75, 0, 100);
|
||||||
|
hue = keepWithin(phi * 180 / Math.PI, 0, 360);
|
||||||
|
brightness = keepWithin(100 - Math.floor(sliderPos.y * (100 / slider.height())), 0, 100);
|
||||||
|
hex = hsb2hex({
|
||||||
|
h: hue,
|
||||||
|
s: saturation,
|
||||||
|
b: brightness
|
||||||
|
});
|
||||||
|
|
||||||
|
// Update UI
|
||||||
|
slider.css('backgroundColor', hsb2hex({ h: hue, s: saturation, b: 100 }));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'saturation':
|
||||||
|
// Calculate hue, saturation, and brightness
|
||||||
|
hue = keepWithin(parseInt(gridPos.x * (360 / grid.width())), 0, 360);
|
||||||
|
saturation = keepWithin(100 - Math.floor(sliderPos.y * (100 / slider.height())), 0, 100);
|
||||||
|
brightness = keepWithin(100 - Math.floor(gridPos.y * (100 / grid.height())), 0, 100);
|
||||||
|
hex = hsb2hex({
|
||||||
|
h: hue,
|
||||||
|
s: saturation,
|
||||||
|
b: brightness
|
||||||
|
});
|
||||||
|
|
||||||
|
// Update UI
|
||||||
|
slider.css('backgroundColor', hsb2hex({ h: hue, s: 100, b: brightness }));
|
||||||
|
minicolors.find('.minicolors-grid-inner').css('opacity', saturation / 100);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'brightness':
|
||||||
|
// Calculate hue, saturation, and brightness
|
||||||
|
hue = keepWithin(parseInt(gridPos.x * (360 / grid.width())), 0, 360);
|
||||||
|
saturation = keepWithin(100 - Math.floor(gridPos.y * (100 / grid.height())), 0, 100);
|
||||||
|
brightness = keepWithin(100 - Math.floor(sliderPos.y * (100 / slider.height())), 0, 100);
|
||||||
|
hex = hsb2hex({
|
||||||
|
h: hue,
|
||||||
|
s: saturation,
|
||||||
|
b: brightness
|
||||||
|
});
|
||||||
|
|
||||||
|
// Update UI
|
||||||
|
slider.css('backgroundColor', hsb2hex({ h: hue, s: saturation, b: 100 }));
|
||||||
|
minicolors.find('.minicolors-grid-inner').css('opacity', 1 - (brightness / 100));
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
// Calculate hue, saturation, and brightness
|
||||||
|
hue = keepWithin(360 - parseInt(sliderPos.y * (360 / slider.height())), 0, 360);
|
||||||
|
saturation = keepWithin(Math.floor(gridPos.x * (100 / grid.width())), 0, 100);
|
||||||
|
brightness = keepWithin(100 - Math.floor(gridPos.y * (100 / grid.height())), 0, 100);
|
||||||
|
hex = hsb2hex({
|
||||||
|
h: hue,
|
||||||
|
s: saturation,
|
||||||
|
b: brightness
|
||||||
|
});
|
||||||
|
|
||||||
|
// Update UI
|
||||||
|
grid.css('backgroundColor', hsb2hex({ h: hue, s: 100, b: 100 }));
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Adjust case
|
||||||
|
input.val( convertCase(hex, settings.letterCase) );
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Handle opacity
|
||||||
|
if( target.is('.minicolors-opacity-slider') ) {
|
||||||
|
if( settings.opacity ) {
|
||||||
|
opacity = parseFloat(1 - (opacityPos.y / opacitySlider.height())).toFixed(2);
|
||||||
|
} else {
|
||||||
|
opacity = 1;
|
||||||
|
}
|
||||||
|
if( settings.opacity ) input.attr('data-opacity', opacity);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set swatch color
|
||||||
|
swatch.find('SPAN').css({
|
||||||
|
backgroundColor: hex,
|
||||||
|
opacity: opacity
|
||||||
|
});
|
||||||
|
|
||||||
|
// Handle change event
|
||||||
|
doChange(input, hex, opacity);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Sets the color picker values from the input
|
||||||
|
function updateFromInput(input, preserveInputValue, firstRun) {
|
||||||
|
|
||||||
|
var hex,
|
||||||
|
hsb,
|
||||||
|
opacity,
|
||||||
|
x, y, r, phi,
|
||||||
|
|
||||||
|
// Helpful references
|
||||||
|
minicolors = input.parent(),
|
||||||
|
settings = input.data('minicolors-settings'),
|
||||||
|
swatch = minicolors.find('.minicolors-swatch'),
|
||||||
|
|
||||||
|
// Panel objects
|
||||||
|
grid = minicolors.find('.minicolors-grid'),
|
||||||
|
slider = minicolors.find('.minicolors-slider'),
|
||||||
|
opacitySlider = minicolors.find('.minicolors-opacity-slider'),
|
||||||
|
|
||||||
|
// Picker objects
|
||||||
|
gridPicker = grid.find('[class$=-picker]'),
|
||||||
|
sliderPicker = slider.find('[class$=-picker]'),
|
||||||
|
opacityPicker = opacitySlider.find('[class$=-picker]');
|
||||||
|
|
||||||
|
// Determine hex/HSB values
|
||||||
|
hex = convertCase(parseHex(input.val(), true), settings.letterCase);
|
||||||
|
if( !hex ) hex = convertCase(parseHex(settings.defaultValue, true));
|
||||||
|
hsb = hex2hsb(hex);
|
||||||
|
|
||||||
|
// Update input value
|
||||||
|
if( !preserveInputValue ) input.val(hex);
|
||||||
|
|
||||||
|
// Determine opacity value
|
||||||
|
if( settings.opacity ) {
|
||||||
|
// Get from data-opacity attribute and keep within 0-1 range
|
||||||
|
opacity = input.attr('data-opacity') === '' ? 1 : keepWithin(parseFloat(input.attr('data-opacity')).toFixed(2), 0, 1);
|
||||||
|
if( isNaN(opacity) ) opacity = 1;
|
||||||
|
input.attr('data-opacity', opacity);
|
||||||
|
swatch.find('SPAN').css('opacity', opacity);
|
||||||
|
|
||||||
|
// Set opacity picker position
|
||||||
|
y = keepWithin(opacitySlider.height() - (opacitySlider.height() * opacity), 0, opacitySlider.height());
|
||||||
|
opacityPicker.css('top', y + 'px');
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update swatch
|
||||||
|
swatch.find('SPAN').css('backgroundColor', hex);
|
||||||
|
|
||||||
|
// Determine picker locations
|
||||||
|
switch(settings.control) {
|
||||||
|
|
||||||
|
case 'wheel':
|
||||||
|
// Set grid position
|
||||||
|
r = keepWithin(Math.ceil(hsb.s * 0.75), 0, grid.height() / 2);
|
||||||
|
phi = hsb.h * Math.PI / 180;
|
||||||
|
x = keepWithin(75 - Math.cos(phi) * r, 0, grid.width());
|
||||||
|
y = keepWithin(75 - Math.sin(phi) * r, 0, grid.height());
|
||||||
|
gridPicker.css({
|
||||||
|
top: y + 'px',
|
||||||
|
left: x + 'px'
|
||||||
|
});
|
||||||
|
|
||||||
|
// Set slider position
|
||||||
|
y = 150 - (hsb.b / (100 / grid.height()));
|
||||||
|
if( hex === '' ) y = 0;
|
||||||
|
sliderPicker.css('top', y + 'px');
|
||||||
|
|
||||||
|
// Update panel color
|
||||||
|
slider.css('backgroundColor', hsb2hex({ h: hsb.h, s: hsb.s, b: 100 }));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'saturation':
|
||||||
|
// Set grid position
|
||||||
|
x = keepWithin((5 * hsb.h) / 12, 0, 150);
|
||||||
|
y = keepWithin(grid.height() - Math.ceil(hsb.b / (100 / grid.height())), 0, grid.height());
|
||||||
|
gridPicker.css({
|
||||||
|
top: y + 'px',
|
||||||
|
left: x + 'px'
|
||||||
|
});
|
||||||
|
|
||||||
|
// Set slider position
|
||||||
|
y = keepWithin(slider.height() - (hsb.s * (slider.height() / 100)), 0, slider.height());
|
||||||
|
sliderPicker.css('top', y + 'px');
|
||||||
|
|
||||||
|
// Update UI
|
||||||
|
slider.css('backgroundColor', hsb2hex({ h: hsb.h, s: 100, b: hsb.b }));
|
||||||
|
minicolors.find('.minicolors-grid-inner').css('opacity', hsb.s / 100);
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'brightness':
|
||||||
|
// Set grid position
|
||||||
|
x = keepWithin((5 * hsb.h) / 12, 0, 150);
|
||||||
|
y = keepWithin(grid.height() - Math.ceil(hsb.s / (100 / grid.height())), 0, grid.height());
|
||||||
|
gridPicker.css({
|
||||||
|
top: y + 'px',
|
||||||
|
left: x + 'px'
|
||||||
|
});
|
||||||
|
|
||||||
|
// Set slider position
|
||||||
|
y = keepWithin(slider.height() - (hsb.b * (slider.height() / 100)), 0, slider.height());
|
||||||
|
sliderPicker.css('top', y + 'px');
|
||||||
|
|
||||||
|
// Update UI
|
||||||
|
slider.css('backgroundColor', hsb2hex({ h: hsb.h, s: hsb.s, b: 100 }));
|
||||||
|
minicolors.find('.minicolors-grid-inner').css('opacity', 1 - (hsb.b / 100));
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
// Set grid position
|
||||||
|
x = keepWithin(Math.ceil(hsb.s / (100 / grid.width())), 0, grid.width());
|
||||||
|
y = keepWithin(grid.height() - Math.ceil(hsb.b / (100 / grid.height())), 0, grid.height());
|
||||||
|
gridPicker.css({
|
||||||
|
top: y + 'px',
|
||||||
|
left: x + 'px'
|
||||||
|
});
|
||||||
|
|
||||||
|
// Set slider position
|
||||||
|
y = keepWithin(slider.height() - (hsb.h / (360 / slider.height())), 0, slider.height());
|
||||||
|
sliderPicker.css('top', y + 'px');
|
||||||
|
|
||||||
|
// Update panel color
|
||||||
|
grid.css('backgroundColor', hsb2hex({ h: hsb.h, s: 100, b: 100 }));
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Handle change event
|
||||||
|
if( !firstRun ) doChange(input, hex, opacity);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Runs the change and changeDelay callbacks
|
||||||
|
function doChange(input, hex, opacity) {
|
||||||
|
|
||||||
|
var settings = input.data('minicolors-settings');
|
||||||
|
|
||||||
|
// Only run if it actually changed
|
||||||
|
if( hex + opacity !== input.data('minicolors-lastChange') ) {
|
||||||
|
|
||||||
|
// Remember last-changed value
|
||||||
|
input.data('minicolors-lastChange', hex + opacity);
|
||||||
|
|
||||||
|
// Fire change event
|
||||||
|
if( settings.change ) {
|
||||||
|
if( settings.changeDelay ) {
|
||||||
|
// Call after a delay
|
||||||
|
clearTimeout(input.data('minicolors-changeTimeout'));
|
||||||
|
input.data('minicolors-changeTimeout', setTimeout( function() {
|
||||||
|
settings.change.call(input, hex, opacity);
|
||||||
|
}, settings.changeDelay));
|
||||||
|
} else {
|
||||||
|
// Call immediately
|
||||||
|
settings.change.call(input, hex, opacity);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Generates an RGB(A) object based on the input's value
|
||||||
|
function rgbObject(input) {
|
||||||
|
var hex = parseHex($(input).val(), true),
|
||||||
|
rgb = hex2rgb(hex),
|
||||||
|
opacity = $(input).attr('data-opacity');
|
||||||
|
if( !rgb ) return null;
|
||||||
|
if( opacity !== undefined ) $.extend(rgb, { a: parseFloat(opacity) });
|
||||||
|
return rgb;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Genearates an RGB(A) string based on the input's value
|
||||||
|
function rgbString(input, alpha) {
|
||||||
|
var hex = parseHex($(input).val(), true),
|
||||||
|
rgb = hex2rgb(hex),
|
||||||
|
opacity = $(input).attr('data-opacity');
|
||||||
|
if( !rgb ) return null;
|
||||||
|
if( opacity === undefined ) opacity = 1;
|
||||||
|
if( alpha ) {
|
||||||
|
return 'rgba(' + rgb.r + ', ' + rgb.g + ', ' + rgb.b + ', ' + parseFloat(opacity) + ')';
|
||||||
|
} else {
|
||||||
|
return 'rgb(' + rgb.r + ', ' + rgb.g + ', ' + rgb.b + ')';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Converts to the letter case specified in settings
|
||||||
|
function convertCase(string, letterCase) {
|
||||||
|
return letterCase === 'uppercase' ? string.toUpperCase() : string.toLowerCase();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Parses a string and returns a valid hex string when possible
|
||||||
|
function parseHex(string, expand) {
|
||||||
|
string = string.replace(/[^A-F0-9]/ig, '');
|
||||||
|
if( string.length !== 3 && string.length !== 6 ) return '';
|
||||||
|
if( string.length === 3 && expand ) {
|
||||||
|
string = string[0] + string[0] + string[1] + string[1] + string[2] + string[2];
|
||||||
|
}
|
||||||
|
return '#' + string;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Keeps value within min and max
|
||||||
|
function keepWithin(value, min, max) {
|
||||||
|
if( value < min ) value = min;
|
||||||
|
if( value > max ) value = max;
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Converts an HSB object to an RGB object
|
||||||
|
function hsb2rgb(hsb) {
|
||||||
|
var rgb = {};
|
||||||
|
var h = Math.round(hsb.h);
|
||||||
|
var s = Math.round(hsb.s * 255 / 100);
|
||||||
|
var v = Math.round(hsb.b * 255 / 100);
|
||||||
|
if(s === 0) {
|
||||||
|
rgb.r = rgb.g = rgb.b = v;
|
||||||
|
} else {
|
||||||
|
var t1 = v;
|
||||||
|
var t2 = (255 - s) * v / 255;
|
||||||
|
var t3 = (t1 - t2) * (h % 60) / 60;
|
||||||
|
if( h === 360 ) h = 0;
|
||||||
|
if( h < 60 ) { rgb.r = t1; rgb.b = t2; rgb.g = t2 + t3; }
|
||||||
|
else if( h < 120 ) {rgb.g = t1; rgb.b = t2; rgb.r = t1 - t3; }
|
||||||
|
else if( h < 180 ) {rgb.g = t1; rgb.r = t2; rgb.b = t2 + t3; }
|
||||||
|
else if( h < 240 ) {rgb.b = t1; rgb.r = t2; rgb.g = t1 - t3; }
|
||||||
|
else if( h < 300 ) {rgb.b = t1; rgb.g = t2; rgb.r = t2 + t3; }
|
||||||
|
else if( h < 360 ) {rgb.r = t1; rgb.g = t2; rgb.b = t1 - t3; }
|
||||||
|
else { rgb.r = 0; rgb.g = 0; rgb.b = 0; }
|
||||||
|
}
|
||||||
|
return {
|
||||||
|
r: Math.round(rgb.r),
|
||||||
|
g: Math.round(rgb.g),
|
||||||
|
b: Math.round(rgb.b)
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
// Converts an RGB object to a hex string
|
||||||
|
function rgb2hex(rgb) {
|
||||||
|
var hex = [
|
||||||
|
rgb.r.toString(16),
|
||||||
|
rgb.g.toString(16),
|
||||||
|
rgb.b.toString(16)
|
||||||
|
];
|
||||||
|
$.each(hex, function(nr, val) {
|
||||||
|
if (val.length === 1) hex[nr] = '0' + val;
|
||||||
|
});
|
||||||
|
return '#' + hex.join('');
|
||||||
|
}
|
||||||
|
|
||||||
|
// Converts an HSB object to a hex string
|
||||||
|
function hsb2hex(hsb) {
|
||||||
|
return rgb2hex(hsb2rgb(hsb));
|
||||||
|
}
|
||||||
|
|
||||||
|
// Converts a hex string to an HSB object
|
||||||
|
function hex2hsb(hex) {
|
||||||
|
var hsb = rgb2hsb(hex2rgb(hex));
|
||||||
|
if( hsb.s === 0 ) hsb.h = 360;
|
||||||
|
return hsb;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Converts an RGB object to an HSB object
|
||||||
|
function rgb2hsb(rgb) {
|
||||||
|
var hsb = { h: 0, s: 0, b: 0 };
|
||||||
|
var min = Math.min(rgb.r, rgb.g, rgb.b);
|
||||||
|
var max = Math.max(rgb.r, rgb.g, rgb.b);
|
||||||
|
var delta = max - min;
|
||||||
|
hsb.b = max;
|
||||||
|
hsb.s = max !== 0 ? 255 * delta / max : 0;
|
||||||
|
if( hsb.s !== 0 ) {
|
||||||
|
if( rgb.r === max ) {
|
||||||
|
hsb.h = (rgb.g - rgb.b) / delta;
|
||||||
|
} else if( rgb.g === max ) {
|
||||||
|
hsb.h = 2 + (rgb.b - rgb.r) / delta;
|
||||||
|
} else {
|
||||||
|
hsb.h = 4 + (rgb.r - rgb.g) / delta;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
hsb.h = -1;
|
||||||
|
}
|
||||||
|
hsb.h *= 60;
|
||||||
|
if( hsb.h < 0 ) {
|
||||||
|
hsb.h += 360;
|
||||||
|
}
|
||||||
|
hsb.s *= 100/255;
|
||||||
|
hsb.b *= 100/255;
|
||||||
|
return hsb;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Converts a hex string to an RGB object
|
||||||
|
function hex2rgb(hex) {
|
||||||
|
hex = parseInt(((hex.indexOf('#') > -1) ? hex.substring(1) : hex), 16);
|
||||||
|
return {
|
||||||
|
r: hex >> 16,
|
||||||
|
g: (hex & 0x00FF00) >> 8,
|
||||||
|
b: (hex & 0x0000FF)
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
// Handle events
|
||||||
|
$(document)
|
||||||
|
// Hide on clicks outside of the control
|
||||||
|
.on('mousedown.minicolors touchstart.minicolors', function(event) {
|
||||||
|
if( !$(event.target).parents().add(event.target).hasClass('minicolors') ) {
|
||||||
|
hide();
|
||||||
|
}
|
||||||
|
})
|
||||||
|
// Start moving
|
||||||
|
.on('mousedown.minicolors touchstart.minicolors', '.minicolors-grid, .minicolors-slider, .minicolors-opacity-slider', function(event) {
|
||||||
|
var target = $(this);
|
||||||
|
event.preventDefault();
|
||||||
|
$(document).data('minicolors-target', target);
|
||||||
|
move(target, event, true);
|
||||||
|
})
|
||||||
|
// Move pickers
|
||||||
|
.on('mousemove.minicolors touchmove.minicolors', function(event) {
|
||||||
|
var target = $(document).data('minicolors-target');
|
||||||
|
if( target ) move(target, event);
|
||||||
|
})
|
||||||
|
// Stop moving
|
||||||
|
.on('mouseup.minicolors touchend.minicolors', function() {
|
||||||
|
$(this).removeData('minicolors-target');
|
||||||
|
})
|
||||||
|
// Toggle panel when swatch is clicked
|
||||||
|
.on('mousedown.minicolors touchstart.minicolors', '.minicolors-swatch', function(event) {
|
||||||
|
var input = $(this).parent().find('.minicolors-input'),
|
||||||
|
minicolors = input.parent();
|
||||||
|
if( minicolors.hasClass('minicolors-focus') ) {
|
||||||
|
hide(input);
|
||||||
|
} else {
|
||||||
|
show(input);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
// Show on focus
|
||||||
|
.on('focus.minicolors', '.minicolors-input', function(event) {
|
||||||
|
var input = $(this);
|
||||||
|
if( !input.data('minicolors-initialized') ) return;
|
||||||
|
show(input);
|
||||||
|
})
|
||||||
|
// Fix hex on blur
|
||||||
|
.on('blur.minicolors', '.minicolors-input', function(event) {
|
||||||
|
var input = $(this),
|
||||||
|
settings = input.data('minicolors-settings');
|
||||||
|
if( !input.data('minicolors-initialized') ) return;
|
||||||
|
|
||||||
|
// Parse Hex
|
||||||
|
input.val(parseHex(input.val(), true));
|
||||||
|
|
||||||
|
// Is it blank?
|
||||||
|
if( input.val() === '' ) input.val(parseHex(settings.defaultValue, true));
|
||||||
|
|
||||||
|
// Adjust case
|
||||||
|
input.val( convertCase(input.val(), settings.letterCase) );
|
||||||
|
|
||||||
|
})
|
||||||
|
// Handle keypresses
|
||||||
|
.on('keydown.minicolors', '.minicolors-input', function(event) {
|
||||||
|
var input = $(this);
|
||||||
|
if( !input.data('minicolors-initialized') ) return;
|
||||||
|
switch(event.keyCode) {
|
||||||
|
case 9: // tab
|
||||||
|
hide();
|
||||||
|
break;
|
||||||
|
case 27: // esc
|
||||||
|
hide();
|
||||||
|
input.blur();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
})
|
||||||
|
// Update on keyup
|
||||||
|
.on('keyup.minicolors', '.minicolors-input', function(event) {
|
||||||
|
var input = $(this);
|
||||||
|
if( !input.data('minicolors-initialized') ) return;
|
||||||
|
updateFromInput(input, true);
|
||||||
|
})
|
||||||
|
// Update on paste
|
||||||
|
.on('paste.minicolors', '.minicolors-input', function(event) {
|
||||||
|
var input = $(this);
|
||||||
|
if( !input.data('minicolors-initialized') ) return;
|
||||||
|
setTimeout( function() {
|
||||||
|
updateFromInput(input, true);
|
||||||
|
}, 1);
|
||||||
|
});
|
||||||
|
|
||||||
|
})(jQuery);
|
BIN
sources/libs/jquery.minicolors.png
Normal file
BIN
sources/libs/jquery.minicolors.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 76 KiB |
150
sources/libs/main.css
Normal file
150
sources/libs/main.css
Normal file
|
@ -0,0 +1,150 @@
|
||||||
|
body {
|
||||||
|
padding-top: 20px;
|
||||||
|
padding-bottom: 60px;
|
||||||
|
color: #5a5a5a;
|
||||||
|
}
|
||||||
|
|
||||||
|
.float_right {
|
||||||
|
float: right;
|
||||||
|
}
|
||||||
|
.float_left {
|
||||||
|
float: left;
|
||||||
|
}
|
||||||
|
.clear {
|
||||||
|
clear: both;
|
||||||
|
}
|
||||||
|
|
||||||
|
.center {
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Custom container */
|
||||||
|
.container {
|
||||||
|
margin: 0 auto;
|
||||||
|
max-width: 1000px;
|
||||||
|
}
|
||||||
|
.container > hr {
|
||||||
|
margin: 60px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Main marketing message and sign up button */
|
||||||
|
.jumbotron {
|
||||||
|
margin: 80px 0px 40px 0px;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
.jumbotron h1 {
|
||||||
|
font-size: 100px;
|
||||||
|
line-height: 1;
|
||||||
|
}
|
||||||
|
.jumbotron .lead {
|
||||||
|
font-size: 24px;
|
||||||
|
line-height: 1.25;
|
||||||
|
}
|
||||||
|
.jumbotron .btn {
|
||||||
|
font-size: 21px;
|
||||||
|
padding: 14px 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Customize the navbar links to be fill the entire space of the .navbar */
|
||||||
|
.navbar .navbar-inner {
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
.navbar .nav {
|
||||||
|
margin: 0;
|
||||||
|
display: table;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
.navbar .nav li {
|
||||||
|
display: table-cell;
|
||||||
|
width: 1%;
|
||||||
|
float: none;
|
||||||
|
}
|
||||||
|
.navbar .nav li a {
|
||||||
|
font-weight: bold;
|
||||||
|
text-align: center;
|
||||||
|
border-left: 1px solid rgba(255,255,255,.75);
|
||||||
|
border-right: 1px solid rgba(0,0,0,.1);
|
||||||
|
}
|
||||||
|
.navbar .nav li:first-child a {
|
||||||
|
border-left: 0;
|
||||||
|
border-radius: 3px 0 0 3px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.navbar .nav li:last-child a {
|
||||||
|
border-right: 0;
|
||||||
|
border-radius: 0 3px 3px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* MARKETING CONTENT -------------------------------------------------- */
|
||||||
|
|
||||||
|
/* Center align the text within the three columns below the carousel */
|
||||||
|
.marketing .span4 {
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
.marketing h2 {
|
||||||
|
font-weight: normal;
|
||||||
|
}
|
||||||
|
.marketing .span4 p {
|
||||||
|
margin-left: 10px;
|
||||||
|
margin-right: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Featurettes ------------------------- */
|
||||||
|
|
||||||
|
.featurette-divider {
|
||||||
|
margin: 80px 0; /* Space out the Bootstrap <hr> more */
|
||||||
|
}
|
||||||
|
.featurette {
|
||||||
|
/*padding-top: 120px;*/ /* Vertically center images part 1: add padding above and below text. */
|
||||||
|
overflow: hidden; /* Vertically center images part 2: clear their floats. */
|
||||||
|
}
|
||||||
|
.featurette-image {
|
||||||
|
/*margin-top: -120px;*/ /* Vertically center images part 3: negative margin up the image the same amount of the padding to center it. */
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Give some space on the sides of the floated elements so text doesn't run right into it. */
|
||||||
|
.featurette-image.pull-left {
|
||||||
|
margin-right: 40px;
|
||||||
|
}
|
||||||
|
.featurette-image.pull-right {
|
||||||
|
margin-left: 40px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Thin out the marketing headings */
|
||||||
|
.featurette-heading {
|
||||||
|
font-size: 50px;
|
||||||
|
font-weight: 300;
|
||||||
|
line-height: 1;
|
||||||
|
letter-spacing: -1px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* RESPONSIVE CSS -------------------------------------------------- */
|
||||||
|
|
||||||
|
@media (max-width: 979px) {
|
||||||
|
|
||||||
|
.featurette {
|
||||||
|
height: auto;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
.featurette-image.pull-left,
|
||||||
|
.featurette-image.pull-right {
|
||||||
|
display: block;
|
||||||
|
float: none;
|
||||||
|
max-width: 40%;
|
||||||
|
margin: 0 auto 20px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@media (max-width: 767px) {
|
||||||
|
|
||||||
|
.featurette-heading {
|
||||||
|
font-size: 30px;
|
||||||
|
}
|
||||||
|
.featurette .lead {
|
||||||
|
font-size: 18px;
|
||||||
|
line-height: 1.5;
|
||||||
|
}
|
||||||
|
}
|
30
sources/libs/main.js
Normal file
30
sources/libs/main.js
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
//Navigation menu scroll
|
||||||
|
$(function() {
|
||||||
|
$('.navegable').click(function() {
|
||||||
|
$('#navigation li').removeClass('active');
|
||||||
|
$(this).parent('li').addClass('active');
|
||||||
|
if (location.pathname.replace(/^\//,'') == this.pathname.replace(/^\//,'') && location.hostname == this.hostname) {
|
||||||
|
var $target = $(this.hash);
|
||||||
|
$target = $target.length && $target || $('[name=' + this.hash.slice(1) +']');
|
||||||
|
if ($target.length) {
|
||||||
|
var targetOffset = $target.offset().top - 80;
|
||||||
|
$('html,body').animate({scrollTop: targetOffset}, 1000);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
function GetSitePath() {
|
||||||
|
var rootPath = window.location.protocol + "//" + window.location.host;
|
||||||
|
var path = window.location.pathname;
|
||||||
|
if (path.lastIndexOf("/") == 0) {
|
||||||
|
path = path.substring(1);
|
||||||
|
}
|
||||||
|
path = path.substr(0,path.lastIndexOf("/"));
|
||||||
|
if (path != "") {
|
||||||
|
rootPath = rootPath + path + '/';
|
||||||
|
}
|
||||||
|
return rootPath;
|
||||||
|
}
|
||||||
|
|
0
sources/libs/plugin.css
Normal file
0
sources/libs/plugin.css
Normal file
169
sources/plugin/jquery.postitall.css
Normal file
169
sources/plugin/jquery.postitall.css
Normal file
|
@ -0,0 +1,169 @@
|
||||||
|
.PIAtitle {
|
||||||
|
font-size: 14px;
|
||||||
|
margin-left: 5px;
|
||||||
|
}
|
||||||
|
.PIAdate {
|
||||||
|
float:left;
|
||||||
|
line-height:10px;
|
||||||
|
font-size: 9px;
|
||||||
|
}
|
||||||
|
.minicolors-panel {
|
||||||
|
border: solid 20px #555;
|
||||||
|
}
|
||||||
|
#chmenu {
|
||||||
|
position: absolute;
|
||||||
|
display: none;
|
||||||
|
z-index: 100000;
|
||||||
|
width: 275px;
|
||||||
|
height: 20px;
|
||||||
|
}
|
||||||
|
#chmenu label{
|
||||||
|
display: inline;
|
||||||
|
}
|
||||||
|
.PIAtoolbar .PIAchopt {
|
||||||
|
background-image: url();
|
||||||
|
float: right;
|
||||||
|
}
|
||||||
|
#chmenu ul {
|
||||||
|
top: 20px;
|
||||||
|
margin: 0;
|
||||||
|
list-style: none;
|
||||||
|
padding: 0;
|
||||||
|
position: absolute;
|
||||||
|
width: 275px;
|
||||||
|
}
|
||||||
|
#chmenu ul li {
|
||||||
|
font: 14px;
|
||||||
|
margin-right: -4px;
|
||||||
|
position: relative;
|
||||||
|
padding: 5px 20px;
|
||||||
|
cursor: pointer;
|
||||||
|
background: #555;
|
||||||
|
display: block;
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
#chmenu ul li:hover { background: #666; }
|
||||||
|
.center { text-align: center; }
|
||||||
|
.float-left { float: left; }
|
||||||
|
.float-right { float: right; }
|
||||||
|
.vertical-bottom { vertical-align: bottom; }
|
||||||
|
.vertical-middle { vertical-align: middle; }
|
||||||
|
.vertical-top { vertical-align: top; }
|
||||||
|
.clear { clear: both; }
|
||||||
|
.red { color: red; }
|
||||||
|
.red a { color: red; font-weight: bold; text-decoration: none; }
|
||||||
|
.red a:hover { text-decoration: underline; }
|
||||||
|
|
||||||
|
/* Postit */
|
||||||
|
.PIApostit {
|
||||||
|
/*color: #333;
|
||||||
|
min-width:130px;
|
||||||
|
min-height:150px;*/
|
||||||
|
padding:4px;
|
||||||
|
font-size:85%;
|
||||||
|
position:absolute;
|
||||||
|
display: none;
|
||||||
|
z-index: 9995;
|
||||||
|
|
||||||
|
background: -moz-linear-gradient(top, rgba(255,255,255,0.46) 0%, rgba(255,255,255,0) 100%);
|
||||||
|
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(255,255,255,0.46)), color-stop(100%,rgba(255,255,255,0)));
|
||||||
|
background: -webkit-linear-gradient(top, rgba(255,255,255,0.46) 0%,rgba(255,255,255,0) 100%);
|
||||||
|
background: -o-linear-gradient(top, rgba(255,255,255,0.46) 0%,rgba(255,255,255,0) 100%);
|
||||||
|
background: -ms-linear-gradient(top, rgba(255,255,255,0.46) 0%,rgba(255,255,255,0) 100%);
|
||||||
|
background: linear-gradient(to bottom, rgba(255,255,255,0.46) 0%,rgba(255,255,255,0) 100%);
|
||||||
|
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#75ffffff', endColorstr='#00ffffff',GradientType=0 );
|
||||||
|
|
||||||
|
}
|
||||||
|
.PIAicon {
|
||||||
|
cursor: pointer;
|
||||||
|
float: left;
|
||||||
|
width:20px;
|
||||||
|
height:20px;
|
||||||
|
background-position: center;
|
||||||
|
margin-right: 2px;
|
||||||
|
background-repeat: no-repeat;
|
||||||
|
/*background-color: #ffd;
|
||||||
|
-webkit-border-radius: 4px 4px 4px 4px;
|
||||||
|
-moz-border-radius: 4px 4px 4px 4px;
|
||||||
|
border-radius: 4px 4px 4px 4px;
|
||||||
|
border: 1px solid #bbb;*/
|
||||||
|
}
|
||||||
|
.PIApostit div.PIAtoolbar {
|
||||||
|
text-align:left;
|
||||||
|
cursor: move;
|
||||||
|
padding-bottom: 5px;
|
||||||
|
height: 16px;
|
||||||
|
color: #888;
|
||||||
|
}
|
||||||
|
.PIApostit div.PIAeditable {
|
||||||
|
clear: both;
|
||||||
|
cursor:pointer;
|
||||||
|
position:relative;
|
||||||
|
min-height:50px;
|
||||||
|
}
|
||||||
|
/** xxx **/
|
||||||
|
.PIAeditable > input, .PIAeditable > textarea, .PIAeditable[contenteditable="true"], .PIAeditable > select {
|
||||||
|
border: 0px;
|
||||||
|
background-color: transparent;
|
||||||
|
box-shadow: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.PIApostit div.PIAeditable:focus {
|
||||||
|
outline: none;
|
||||||
|
}
|
||||||
|
.PIApostit div.PIAcontent {
|
||||||
|
padding: 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.ui-resizable-helper { border: 1px dotted gray; }
|
||||||
|
|
||||||
|
/* FLIP-CARD */
|
||||||
|
.panel {
|
||||||
|
float: left;
|
||||||
|
|
||||||
|
border:1px solid gray;
|
||||||
|
-moz-box-shadow:4px 4px 4px #999999;
|
||||||
|
-webkit-box-shadow:4px 4px 4px #999999;
|
||||||
|
box-shadow:4px 4px 4px #999999;
|
||||||
|
|
||||||
|
-webkit-perspective: 600px;
|
||||||
|
-moz-perspective: 600px;
|
||||||
|
|
||||||
|
-webkit-border-radius: 3px;
|
||||||
|
border-radius: 3px;
|
||||||
|
|
||||||
|
}
|
||||||
|
/* -- make sure to declare a default for every property that you want animated -- */
|
||||||
|
/* -- general styles, including Y axis rotation -- */
|
||||||
|
.panel .front {
|
||||||
|
float: none;
|
||||||
|
position: absolute;
|
||||||
|
top: 5px;
|
||||||
|
|
||||||
|
width: 99%;
|
||||||
|
height: 99%;
|
||||||
|
|
||||||
|
-moz-transform: rotateX(0deg) rotateY(0deg); /* FF3.5/3.6 */
|
||||||
|
-o-transform: rotateX(0deg) rotateY(0deg); /* Opera 10.5 */
|
||||||
|
-webkit-transform: rotateX(0deg) rotateY(0deg); /* Saf3.1+ */
|
||||||
|
transform: rotateX(0deg) rotateY(0deg); /* Newer browsers (incl IE9) */
|
||||||
|
/*filter: progid:DXImageTransform.Microsoft.Matrix(sizingMethod='auto expand', M11=0.7071067811865476, M12=-0.7071067811865475, M21=0.7071067811865475, M22=0.7071067811865476); /* IE6,IE7 */
|
||||||
|
/*-ms-filter: "progid:DXImageTransform.Microsoft.Matrix(SizingMethod='auto expand', M11=0.7071067811865476, M12=-0.7071067811865475, M21=0.7071067811865475, M22=0.7071067811865476)"; /* IE8 */
|
||||||
|
|
||||||
|
-webkit-transform-style: preserve-3d;
|
||||||
|
-webkit-backface-visibility: hidden;
|
||||||
|
-moz-transform-style: preserve-3d;
|
||||||
|
-moz-backface-visibility: hidden;
|
||||||
|
-o-transform-style: preserve-3d;
|
||||||
|
-o-backface-visibility: hidden;
|
||||||
|
transform-style: preserve-3d;
|
||||||
|
backface-visibility: hidden;
|
||||||
|
|
||||||
|
/* -- transition is the magic sauce for animation -- */
|
||||||
|
-o-transition: all .4s ease-in-out;
|
||||||
|
-ms-transition: all .4s ease-in-out;
|
||||||
|
-moz-transition: all .4s ease-in-out;
|
||||||
|
-webkit-transition: all .4s ease-in-out;
|
||||||
|
transition: all .4s ease-in-out;
|
||||||
|
}
|
||||||
|
|
465
sources/plugin/jquery.postitall.js
Normal file
465
sources/plugin/jquery.postitall.js
Normal file
|
@ -0,0 +1,465 @@
|
||||||
|
/**
|
||||||
|
* jquery.postitall.js specific to ChtickyNotes by chtixof
|
||||||
|
* written on the basis of jquery.postitall.js v0.1 - 2015
|
||||||
|
* Original notice:
|
||||||
|
* jQuery Post It All Plugin - released under MIT License
|
||||||
|
* Author: Javi Filella <txusko@gmail.com>
|
||||||
|
* http://github.com/txusko/PostItAll
|
||||||
|
* Copyright (c) 2013 Javi Filella
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person
|
||||||
|
* obtaining a copy of this software and associated documentation
|
||||||
|
* files (the "Software"), to deal in the Software without
|
||||||
|
* restriction, including without limitation the rights to use,
|
||||||
|
* copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
* copies of the Software, and to permit persons to whom the
|
||||||
|
* Software is furnished to do so, subject to the following
|
||||||
|
* conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be
|
||||||
|
* included in all copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
|
||||||
|
* OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
||||||
|
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
||||||
|
* WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||||
|
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||||||
|
* OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
(function ($) {
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
// Global Vars
|
||||||
|
var options;
|
||||||
|
var nextid = -1;
|
||||||
|
var zindex=9995;
|
||||||
|
var tobesaved=false;
|
||||||
|
var cssidsave="";
|
||||||
|
var actson;
|
||||||
|
|
||||||
|
// for css color settings
|
||||||
|
function rgb2hex(rgb) {
|
||||||
|
if (/^#[0-9A-F]{6}$/i.test(rgb)) return rgb;
|
||||||
|
|
||||||
|
rgb = rgb.match(/^rgb\((\d+),\s*(\d+),\s*(\d+)\)$/);
|
||||||
|
function hex(x) {
|
||||||
|
return ("0" + parseInt(x).toString(16)).slice(-2);
|
||||||
|
}
|
||||||
|
return "#" + hex(rgb[1]) + hex(rgb[2]) + hex(rgb[3]);
|
||||||
|
}
|
||||||
|
|
||||||
|
// actions in case of any change
|
||||||
|
function settobesaved() {
|
||||||
|
tobesaved=true;
|
||||||
|
if(cssidsave!=="") {
|
||||||
|
$(cssidsave).css("display", "");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// menu items to select color
|
||||||
|
function selcolor(idli,idinput,label,cssatt,optvar){
|
||||||
|
$(idli).html("");
|
||||||
|
$(idli).append($('<label />',{'for': idinput}).html(label+' '))
|
||||||
|
.append($('<input />', {
|
||||||
|
'class': 'minicolors',
|
||||||
|
'id': idinput,
|
||||||
|
'type': 'text',
|
||||||
|
'value': rgb2hex($(actson).css(cssatt)),
|
||||||
|
'width': '75px'
|
||||||
|
}));
|
||||||
|
$('#'+idinput).minicolors({
|
||||||
|
change: function (hex) {
|
||||||
|
$(actson).css(cssatt, hex);
|
||||||
|
$(actson).data('PIA-options')[optvar]=hex;
|
||||||
|
settobesaved();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// displays option menu
|
||||||
|
function chopt(e) {
|
||||||
|
//right position
|
||||||
|
$('#chmenu').css('left',$(this).offset().left);
|
||||||
|
$('#chmenu').css('top',$(this).offset().top);
|
||||||
|
//what note menu acts on
|
||||||
|
actson = $(this).parent().parent().parent();
|
||||||
|
//set bgcolor
|
||||||
|
selcolor('#chbg', 'minicolors_bg', 'Background-color','background-color','backgroundcolor');
|
||||||
|
//set text color
|
||||||
|
selcolor('#chco', 'minicolors_tx', 'Text-color','color','textcolor');
|
||||||
|
//set hide/show date
|
||||||
|
$('#chda').html(actson.data('PIA-options').showdate ? 'Hide the date' : 'Display the date');
|
||||||
|
//show
|
||||||
|
$('#chmenu').show();
|
||||||
|
}
|
||||||
|
|
||||||
|
// action menu delete
|
||||||
|
function chdelete(e) {
|
||||||
|
$('#chmenu').hide();
|
||||||
|
destroy($(actson));
|
||||||
|
e.preventDefault();
|
||||||
|
return(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// action menu clone
|
||||||
|
function chclone(e) {
|
||||||
|
var options = $.extend({},$(actson).data('PIA-options'));
|
||||||
|
$('#chmenu').hide();
|
||||||
|
options.posX=(parseInt(options.posX)+50)+"px";
|
||||||
|
options.posY=(parseInt(options.posY)-50)+"px";
|
||||||
|
delete options.id;
|
||||||
|
delete options.date;
|
||||||
|
$('#addanote_result').postitall(options);
|
||||||
|
return(0);
|
||||||
|
}
|
||||||
|
// action menu display date
|
||||||
|
function chdate(e) {
|
||||||
|
$('#chmenu').hide();
|
||||||
|
actson.data('PIA-options').showdate = !actson.data('PIA-options').showdate ;
|
||||||
|
if (actson.data('PIA-options').showdate) {
|
||||||
|
$(".PIAdate",actson).show();
|
||||||
|
} else {
|
||||||
|
$(".PIAdate",actson).hide();
|
||||||
|
}
|
||||||
|
return(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
//Destroy object
|
||||||
|
function destroy(obj) {
|
||||||
|
var id = obj.data('PIA-id');
|
||||||
|
options = obj.data('PIA-options');
|
||||||
|
//Destroy object
|
||||||
|
obj
|
||||||
|
.removeData('PIA-id')
|
||||||
|
.removeData('PIA-settings')
|
||||||
|
.hide("slow", function () {
|
||||||
|
$(this).remove();
|
||||||
|
});
|
||||||
|
settobesaved();
|
||||||
|
}
|
||||||
|
|
||||||
|
//Autoresize postit
|
||||||
|
function autoresize(obj) {
|
||||||
|
var id = obj.data('PIA-id');
|
||||||
|
options = obj.data('PIA-options');
|
||||||
|
if (options.autoheight) {
|
||||||
|
var posY = $('#idPostIt_' + id).parent().css('left'),
|
||||||
|
posX = $('#idPostIt_' + id).parent().css('top'),
|
||||||
|
divWidth = $('#idPostIt_' + id).width(),
|
||||||
|
divHeight = $('#idPostIt_' + id).find('.PIAeditable').height(),
|
||||||
|
minDivHeight = options.minHeight;
|
||||||
|
if (divHeight >= minDivHeight) {
|
||||||
|
divHeight += 50;
|
||||||
|
options.height = divHeight;
|
||||||
|
obj.css('height', divHeight);
|
||||||
|
if ($.ui) {
|
||||||
|
if (options.resizable) {
|
||||||
|
obj.resizable({
|
||||||
|
minHeight: divHeight
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (divHeight < minDivHeight) {
|
||||||
|
options.height = minDivHeight;
|
||||||
|
minDivHeight += 50;
|
||||||
|
obj.css('height', minDivHeight);
|
||||||
|
}
|
||||||
|
options.posY = posY;
|
||||||
|
options.posX = posX;
|
||||||
|
options.width = divWidth;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set options
|
||||||
|
function setOptions(opt, save) {
|
||||||
|
if (typeof opt !== 'object') {
|
||||||
|
opt = {};
|
||||||
|
}
|
||||||
|
if (save === undefined) {
|
||||||
|
save = false;
|
||||||
|
}
|
||||||
|
options = $.extend(options, opt);
|
||||||
|
/*jslint unparam: true*/
|
||||||
|
$.each(['onChange', 'onSelect', 'onRelease', 'onDblClick'], function (i, e) {
|
||||||
|
if (typeof options[e] !== 'function') {
|
||||||
|
options[e] = function () { return undefined; };
|
||||||
|
}
|
||||||
|
});
|
||||||
|
/*jslint unparam: false*/
|
||||||
|
if (save) {
|
||||||
|
settobesaved();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//Create a postit
|
||||||
|
function create(obj, options) {
|
||||||
|
|
||||||
|
obj.data('PIA-id', nextid)
|
||||||
|
.data('PIA-options', options);
|
||||||
|
//Postit editable content
|
||||||
|
if (options.description === "") {
|
||||||
|
if (obj.html() !== "") {
|
||||||
|
options.description = obj.html();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//Front page: toolbar
|
||||||
|
var barCursor = "cursor: inherit;";
|
||||||
|
if (options.draggable) {
|
||||||
|
barCursor = "cursor: move;";
|
||||||
|
}
|
||||||
|
var toolbar = $('<div />', {
|
||||||
|
'id': 'pia_toolbar_' + nextid.toString(),
|
||||||
|
'class': 'PIAtoolbar',
|
||||||
|
'style': barCursor
|
||||||
|
});
|
||||||
|
//Drag support without jQuery UI
|
||||||
|
if (!$.ui) {
|
||||||
|
if (options.draggable) {
|
||||||
|
toolbar.drags();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
toolbar.html('<span class="PIAdate">'+options.date+'</span><span class="PIAtitle"></span>');
|
||||||
|
|
||||||
|
//Menu icon
|
||||||
|
toolbar.append($('<div />', {'class': 'PIAchopt PIAicon'}).click(chopt));
|
||||||
|
//Front page: content
|
||||||
|
var content = $('<div />', {
|
||||||
|
'id': 'pia_editable_' + nextid.toString(),
|
||||||
|
'class': 'PIAeditable PIAcontent'
|
||||||
|
}).change(function () {
|
||||||
|
options.description = $(this).html();
|
||||||
|
obj.data('PIA-options', options);
|
||||||
|
autoresize(obj);
|
||||||
|
settobesaved();
|
||||||
|
}).attr('contenteditable', true).html(options.description);
|
||||||
|
|
||||||
|
//Create postit
|
||||||
|
var postit = $('<div />', { 'id': 'idPostIt_' + nextid.toString(), 'data-id': nextid })
|
||||||
|
.append(toolbar).append(content);
|
||||||
|
//Convert relative position to prevent height and width in html layout
|
||||||
|
if (options.position === "relative") {
|
||||||
|
options.position = "absolute";
|
||||||
|
options.posX = obj.offset().top + parseInt(options.posX, 10) ;
|
||||||
|
options.posX += "px";
|
||||||
|
options.posY = obj.offset().left + parseInt(options.posY, 10) ;
|
||||||
|
options.posY += "px";
|
||||||
|
}
|
||||||
|
//Modify final Postit Object
|
||||||
|
obj.removeClass()
|
||||||
|
.addClass('block panel PIApostit')
|
||||||
|
.css('z-index', zindex++)
|
||||||
|
.css('position', options.position)
|
||||||
|
.css('left', options.posY)
|
||||||
|
.css('top', options.posX)
|
||||||
|
.css('width', options.width + 'px')
|
||||||
|
.css('height', (options.height + 30) + 'px') //Increase 30 pixels for the toolbar
|
||||||
|
.css('background-color', options.backgroundcolor)
|
||||||
|
.css('color', options.textcolor);
|
||||||
|
obj.html(postit)
|
||||||
|
.on('focus', '[contenteditable]', function () {
|
||||||
|
var objeto = $(this);
|
||||||
|
objeto.data('before', objeto.html());
|
||||||
|
return objeto;
|
||||||
|
}).on('blur keyup paste', '[contenteditable]', function () {
|
||||||
|
var objeto = $(this);
|
||||||
|
if (objeto.data('before') !== objeto.html()) {
|
||||||
|
objeto.data('before', objeto.html());
|
||||||
|
objeto.trigger('change');
|
||||||
|
}
|
||||||
|
return objeto;
|
||||||
|
}).click(function () {
|
||||||
|
$(this).css('z-index', zindex++);
|
||||||
|
settobesaved();
|
||||||
|
}).load(function () {
|
||||||
|
//Autoresize to fit content when content load is done
|
||||||
|
autoresize($(this));
|
||||||
|
});
|
||||||
|
if ($.ui) {
|
||||||
|
if (options.draggable) {
|
||||||
|
obj.draggable({
|
||||||
|
handle: ".PIAtoolbar",
|
||||||
|
scroll: false,
|
||||||
|
start: function () {
|
||||||
|
$(this).css('z-index', zindex++);
|
||||||
|
$(this).draggable('disable');
|
||||||
|
},
|
||||||
|
stop: function () {
|
||||||
|
$(this).draggable('enable');
|
||||||
|
autoresize($(this));
|
||||||
|
settobesaved();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
if (options.resizable) {
|
||||||
|
obj.resizable({
|
||||||
|
animate: false,
|
||||||
|
helper: 'ui-resizable-helper',
|
||||||
|
minHeight: options.minHeight,
|
||||||
|
minWidth: options.minWidth,
|
||||||
|
stop: function () {
|
||||||
|
autoresize($(this));
|
||||||
|
settobesaved();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
obj.slideDown('slow', function () {
|
||||||
|
});
|
||||||
|
settobesaved();
|
||||||
|
//chaining
|
||||||
|
return obj;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Initialize elements
|
||||||
|
function init(obj, opt) {
|
||||||
|
if (++nextid===0) {
|
||||||
|
obj.append($('<div />', { 'id' : 'chmenu'}).mouseleave(function(){$(this).hide();})
|
||||||
|
.append($('<ul/>')
|
||||||
|
.append($('<li/>',{'id': 'chbg'}))
|
||||||
|
.append($('<li/>',{'id': 'chco'}))
|
||||||
|
.append($('<li/>',{'id': 'chda'}).click(chdate))
|
||||||
|
.append($('<li/>').click(chclone).append('Clone'))
|
||||||
|
.append($('<li/>').click(chdelete).append('Delete'))
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
//Default options
|
||||||
|
options = $.extend({}, $.fn.postitall.defaults);
|
||||||
|
options.id=nextid;
|
||||||
|
options.date= (new Date ()).toLocaleDateString () +'<br>'+ (new Date ()).toLocaleTimeString();
|
||||||
|
|
||||||
|
//Set options
|
||||||
|
if (typeof opt !== 'object') {
|
||||||
|
opt = {};
|
||||||
|
}
|
||||||
|
setOptions(opt);
|
||||||
|
|
||||||
|
var PIAcontent = $('<div />', { 'id' : 'newPostIt_' + nextid });
|
||||||
|
obj.append(PIAcontent);
|
||||||
|
return create(PIAcontent, options);
|
||||||
|
}
|
||||||
|
|
||||||
|
// PLUGIN Public methods
|
||||||
|
$.extend($.fn, {
|
||||||
|
postitall: function (method, data) {
|
||||||
|
//Debugging
|
||||||
|
var debugging = true; // or true
|
||||||
|
if (typeof console === "undefined") {
|
||||||
|
console = {
|
||||||
|
log: function () { return undefined; }
|
||||||
|
};
|
||||||
|
} else if (!debugging || console.log === undefined) {
|
||||||
|
console.log = function () { return undefined; };
|
||||||
|
}
|
||||||
|
switch (method) {
|
||||||
|
// Destroy the control
|
||||||
|
case 'destroy':
|
||||||
|
$(this).each(function () {
|
||||||
|
destroy($(this));
|
||||||
|
});
|
||||||
|
return $(this);
|
||||||
|
// Get/set options on the fly
|
||||||
|
case 'options':
|
||||||
|
if (data === undefined) {
|
||||||
|
return $(this).data('PIA-options');
|
||||||
|
}
|
||||||
|
// Setter
|
||||||
|
$(this).each(function () {
|
||||||
|
options = $(this).data('PIA-options') || {};
|
||||||
|
destroy($(this));
|
||||||
|
$(this).postitall($.extend(true, options, data));
|
||||||
|
});
|
||||||
|
return $(this);
|
||||||
|
case 'isittosave':
|
||||||
|
var answer=tobesaved;
|
||||||
|
tobesaved=false;
|
||||||
|
if (data !== undefined) {
|
||||||
|
cssidsave=data;
|
||||||
|
}
|
||||||
|
return (answer);
|
||||||
|
// Initializes the control
|
||||||
|
default:
|
||||||
|
//case 'create' :
|
||||||
|
if (method !== 'create') {
|
||||||
|
data = method;
|
||||||
|
}
|
||||||
|
$(this).each(function () {
|
||||||
|
init($(this), data);
|
||||||
|
});
|
||||||
|
return $(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Default Plugin Vars
|
||||||
|
$.fn.postitall.defaults = {
|
||||||
|
// Basic Settings
|
||||||
|
showdate : true,
|
||||||
|
backgroundcolor : '#FFFC7F', //Background color
|
||||||
|
textcolor : '#333333', //Text color
|
||||||
|
position : 'absolute', //Position absolute or relative
|
||||||
|
posX : '50px', //top position
|
||||||
|
posY : '15px', //left position
|
||||||
|
height : 180, //height
|
||||||
|
width : 200, //width
|
||||||
|
minHeight : 152, //resizable min-width
|
||||||
|
minWidth : 131, //resizable min-height
|
||||||
|
description : '', //content
|
||||||
|
title : '',
|
||||||
|
autoheight : true, //Set autoheight feature on or off
|
||||||
|
draggable : true, //Set draggable feature on or off
|
||||||
|
resizable : true, //Set resizable feature on or off
|
||||||
|
removable : true, //Set removable feature on or off
|
||||||
|
// Callbacks / Event Handlers
|
||||||
|
onChange: function () { return undefined; },
|
||||||
|
onSelect: function () { return undefined; },
|
||||||
|
onDblClick: function () { return undefined; },
|
||||||
|
onRelease: function () { return undefined; }
|
||||||
|
};
|
||||||
|
|
||||||
|
//Drag postits
|
||||||
|
//used if jQuery UI is not loaded
|
||||||
|
$.fn.drags = function (opt) {
|
||||||
|
|
||||||
|
opt = $.extend({handle: "", cursor: "move"}, opt);
|
||||||
|
|
||||||
|
var $el = this;
|
||||||
|
if (opt.handle !== "") {
|
||||||
|
$el = this.find(opt.handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $el.css('cursor', opt.cursor).on("mousedown", function (e) {
|
||||||
|
var $drag;
|
||||||
|
if (opt.handle === "") {
|
||||||
|
$drag = $(this).parent().parent().parent().addClass('draggable');
|
||||||
|
} else {
|
||||||
|
$drag = $(this).parent().parent().parent().addClass('active-handle').parent().addClass('draggable');
|
||||||
|
}
|
||||||
|
var z_idx = $drag.css('z-index'),
|
||||||
|
drg_h = $drag.outerHeight(),
|
||||||
|
drg_w = $drag.outerWidth(),
|
||||||
|
pos_y = $drag.offset().top + drg_h - e.pageY,
|
||||||
|
pos_x = $drag.offset().left + drg_w - e.pageX;
|
||||||
|
$drag.css('z-index', 1000000).parents().on("mousemove", function (e) {
|
||||||
|
$('.draggable').offset({
|
||||||
|
top: e.pageY + pos_y - drg_h,
|
||||||
|
left: e.pageX + pos_x - drg_w
|
||||||
|
}).on("mouseup", function () {
|
||||||
|
$(this).removeClass('draggable').css('z-index', z_idx);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
e.preventDefault(); // disable selection
|
||||||
|
}).on("mouseup", function () {
|
||||||
|
if (opt.handle === "") {
|
||||||
|
$(this).removeClass('draggable');
|
||||||
|
} else {
|
||||||
|
$(this).removeClass('active-handle').parent().removeClass('draggable');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
}(jQuery));
|
Loading…
Add table
Reference in a new issue