Use Elixir for asset management
- Set up Elixir for asset management - CSS + JS will be handled via Elixir/Gulp in gulpfile.js - Removed outdates public/js files
2
.bowerrc
@ -1,3 +1,3 @@
|
||||
{
|
||||
"directory": "./public/vendor"
|
||||
"directory": "resources/assets/bower"
|
||||
}
|
1
.gitignore
vendored
@ -8,6 +8,7 @@
|
||||
/public/build
|
||||
/public/packages
|
||||
/public/vendor
|
||||
/resources/assets/bower
|
||||
/storage
|
||||
/bootstrap/compiled.php
|
||||
/bootstrap/environment.php
|
||||
|
103
Gruntfile.js
@ -73,109 +73,6 @@ module.exports = function(grunt) {
|
||||
}
|
||||
},
|
||||
},
|
||||
js: {
|
||||
src: [
|
||||
'public/vendor/jquery/dist/jquery.js',
|
||||
'public/vendor/jquery-ui/jquery-ui.min.js',
|
||||
'public/vendor/bootstrap/dist/js/bootstrap.min.js',
|
||||
'public/vendor/datatables/media/js/jquery.dataTables.js',
|
||||
'public/vendor/datatables-bootstrap3/BS3/assets/js/datatables.js',
|
||||
'public/vendor/knockout.js/knockout.js',
|
||||
'public/vendor/knockout-mapping/build/output/knockout.mapping-latest.js',
|
||||
'public/vendor/knockout-sortable/build/knockout-sortable.min.js',
|
||||
'public/vendor/underscore/underscore.js',
|
||||
'public/vendor/bootstrap-datepicker/dist/js/bootstrap-datepicker.min.js',
|
||||
'public/vendor/bootstrap-datepicker/dist/locales/bootstrap-datepicker.de.min.js',
|
||||
'public/vendor/bootstrap-datepicker/dist/locales/bootstrap-datepicker.da.min.js',
|
||||
'public/vendor/bootstrap-datepicker/dist/locales/bootstrap-datepicker.pt-BR.min.js',
|
||||
'public/vendor/bootstrap-datepicker/dist/locales/bootstrap-datepicker.nl.min.js',
|
||||
'public/vendor/bootstrap-datepicker/dist/locales/bootstrap-datepicker.fr.min.js',
|
||||
'public/vendor/bootstrap-datepicker/dist/locales/bootstrap-datepicker.it.min.js',
|
||||
'public/vendor/bootstrap-datepicker/dist/locales/bootstrap-datepicker.lt.min.js',
|
||||
'public/vendor/bootstrap-datepicker/dist/locales/bootstrap-datepicker.no.min.js',
|
||||
'public/vendor/bootstrap-datepicker/dist/locales/bootstrap-datepicker.es.min.js',
|
||||
'public/vendor/bootstrap-datepicker/dist/locales/bootstrap-datepicker.sv.min.js',
|
||||
'public/vendor/dropzone/dist/min/dropzone.min.js',
|
||||
'public/vendor/typeahead.js/dist/typeahead.jquery.min.js',
|
||||
'public/vendor/accounting/accounting.min.js',
|
||||
'public/vendor/spectrum/spectrum.js',
|
||||
'public/vendor/jspdf/dist/jspdf.min.js',
|
||||
'public/vendor/moment/min/moment.min.js',
|
||||
'public/vendor/moment-timezone/builds/moment-timezone-with-data.min.js',
|
||||
'public/vendor/stacktrace-js/dist/stacktrace-with-polyfills.min.js',
|
||||
'public/vendor/fuse.js/src/fuse.min.js',
|
||||
//'public/vendor/moment-duration-format/lib/moment-duration-format.js',
|
||||
//'public/vendor/handsontable/dist/jquery.handsontable.full.min.js',
|
||||
//'public/vendor/pdfmake/build/pdfmake.min.js',
|
||||
//'public/vendor/pdfmake/build/vfs_fonts.js',
|
||||
//'public/js/vfs_fonts.js',
|
||||
'public/js/bootstrap-combobox.js',
|
||||
'public/js/script.js',
|
||||
'public/js/pdf.pdfmake.js',
|
||||
],
|
||||
dest: 'public/built.js',
|
||||
nonull: true
|
||||
},
|
||||
js_public: {
|
||||
src: [
|
||||
/*
|
||||
'public/js/simpleexpand.js',
|
||||
'public/js/valign.js',
|
||||
'public/js/bootstrap.min.js',
|
||||
'public/js/simpleexpand.js',
|
||||
*/
|
||||
'public/vendor/bootstrap/dist/js/bootstrap.min.js',
|
||||
'public/js/bootstrap-combobox.js',
|
||||
|
||||
],
|
||||
dest: 'public/built.public.js',
|
||||
nonull: true
|
||||
},
|
||||
css: {
|
||||
src: [
|
||||
'public/vendor/bootstrap/dist/css/bootstrap.min.css',
|
||||
'public/vendor/datatables/media/css/jquery.dataTables.css',
|
||||
'public/vendor/datatables-bootstrap3/BS3/assets/css/datatables.css',
|
||||
'public/vendor/font-awesome/css/font-awesome.min.css',
|
||||
'public/vendor/bootstrap-datepicker/dist/css/bootstrap-datepicker3.css',
|
||||
'public/vendor/dropzone/dist/min/dropzone.min.css',
|
||||
'public/vendor/spectrum/spectrum.css',
|
||||
'public/css/bootstrap-combobox.css',
|
||||
'public/css/typeahead.js-bootstrap.css',
|
||||
//'public/vendor/handsontable/dist/jquery.handsontable.full.css',
|
||||
'public/css/style.css',
|
||||
],
|
||||
dest: 'public/css/built.css',
|
||||
nonull: true,
|
||||
options: {
|
||||
process: false
|
||||
}
|
||||
},
|
||||
css_public: {
|
||||
src: [
|
||||
'public/vendor/bootstrap/dist/css/bootstrap.min.css',
|
||||
'public/vendor/font-awesome/css/font-awesome.min.css',
|
||||
'public/css/bootstrap-combobox.css',
|
||||
'public/vendor/datatables/media/css/jquery.dataTables.css',
|
||||
'public/vendor/datatables-bootstrap3/BS3/assets/css/datatables.css',
|
||||
'public/css/public.style.css',
|
||||
],
|
||||
dest: 'public/css/built.public.css',
|
||||
nonull: true,
|
||||
options: {
|
||||
process: false
|
||||
}
|
||||
},
|
||||
js_pdf: {
|
||||
src: [
|
||||
'public/js/pdf_viewer.js',
|
||||
'public/js/compatibility.js',
|
||||
'public/js/pdfmake.min.js',
|
||||
'public/js/vfs.js',
|
||||
],
|
||||
dest: 'public/pdf.built.js',
|
||||
nonull: true
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
|
11
bower.json
@ -3,8 +3,10 @@
|
||||
"version": "0.9.0",
|
||||
"dependencies": {
|
||||
"jquery": "1.11.3",
|
||||
"bootstrap": "3.3.1",
|
||||
"jquery-ui": "1.11.2",
|
||||
"bootstrap": "3.3.1",
|
||||
"bootstrap-combobox": "1.1.7",
|
||||
"bootstrap-datepicker": "1.4.0",
|
||||
"datatables": "1.10.4",
|
||||
"datatables-bootstrap3": "*",
|
||||
"knockout.js": "3.1.0",
|
||||
@ -13,13 +15,13 @@
|
||||
"font-awesome": "~4.*",
|
||||
"underscore": "1.7.0",
|
||||
"jspdf": "1.0.272",
|
||||
"bootstrap-datepicker": "1.4.0",
|
||||
"jsPDF-plugins": "*",
|
||||
"typeahead.js": "0.11.1",
|
||||
"accounting": "0.3.2",
|
||||
"spectrum": "1.3.4",
|
||||
"d3": "3.4.11",
|
||||
"handsontable": "*",
|
||||
"pdfmake": "*",
|
||||
"pdfmake": "0.1.17",
|
||||
"moment": "*",
|
||||
"jsoneditor": "*",
|
||||
"moment-timezone": "~0.4.0",
|
||||
@ -27,7 +29,8 @@
|
||||
"datetimepicker": "~2.4.5",
|
||||
"stacktrace-js": "~1.0.1",
|
||||
"fuse.js": "~2.0.2",
|
||||
"dropzone": "~4.3.0"
|
||||
"dropzone": "~4.3.0",
|
||||
"lightbox2": "~2.8.2"
|
||||
},
|
||||
"resolutions": {
|
||||
"jquery": "~1.11"
|
||||
|
140
gulpfile.js
@ -1,16 +1,136 @@
|
||||
var elixir = require('laravel-elixir');
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
| Elixir Asset Management
|
||||
|--------------------------------------------------------------------------
|
||||
|
|
||||
| Elixir provides a clean, fluent API for defining some basic Gulp tasks
|
||||
| for your Laravel application. By default, we are compiling the Less
|
||||
| file for our application, as well as publishing vendor resources.
|
||||
|
|
||||
/**
|
||||
* Configure Elixir to explicitly generate source maps
|
||||
*
|
||||
* @type {boolean}
|
||||
*/
|
||||
elixir.config.sourcemaps = true;
|
||||
|
||||
/**
|
||||
* Directory for JS source files that are handled by Bower.
|
||||
* Bower source file directory.
|
||||
*
|
||||
* @type {string}
|
||||
*/
|
||||
var bowerDirectoy = './resources/assets/bower/';
|
||||
|
||||
/**
|
||||
* Directory for JS assets that are not handled by Bower
|
||||
*
|
||||
* @type {string}
|
||||
*/
|
||||
var resourcesJsDirectory = './resources/assets/js/';
|
||||
|
||||
/**
|
||||
* Directory for CSS assets that are not handled by Bower
|
||||
*
|
||||
* @type {string}
|
||||
*/
|
||||
var resourcesCssDirectory = './resources/assets/css/';
|
||||
|
||||
elixir(function(mix) {
|
||||
mix.less('app.less');
|
||||
|
||||
// Built built.css
|
||||
mix.styles([
|
||||
bowerDirectoy + 'bootstrap/dist/css/bootstrap.css',
|
||||
bowerDirectoy + 'bootstrap-combobox/css/bootstrap-combobox.css',
|
||||
bowerDirectoy + 'bootstrap-datepicker/dist/css/bootstrap-datepicker3.css',
|
||||
bowerDirectoy + 'datatables/media/css/jquery.dataTables.css',
|
||||
bowerDirectoy + 'datatables-bootstrap3/BS3/assets/css/datatables.css',
|
||||
bowerDirectoy + 'font-awesome/css/font-awesome.css',
|
||||
bowerDirectoy + 'dropzone/dist/dropzone.css',
|
||||
bowerDirectoy + 'spectrum/spectrum.css',
|
||||
resourcesCssDirectory + 'typeahead.js-bootstrap.css',
|
||||
resourcesCssDirectory + 'style.css'
|
||||
], 'public/css/built.min.css');
|
||||
|
||||
// Built built.public.css
|
||||
mix.styles([
|
||||
bowerDirectoy + 'bootstrap/dist/css/bootstrap.css',
|
||||
bowerDirectoy + 'bootstrap-combobox/css/bootstrap-combobox.css',
|
||||
bowerDirectoy + 'font-awesome/css/font-awesome.css',
|
||||
bowerDirectoy + 'datatables/media/css/jquery.dataTables.css',
|
||||
bowerDirectoy + 'datatables-bootstrap3/BS3/assets/css/datatables.css',
|
||||
resourcesCssDirectory + 'public.style.css'
|
||||
], 'public/css/built.public.min.css');
|
||||
|
||||
mix.copy(resourcesCssDirectory + 'img', 'public/css/img')
|
||||
.copy(resourcesCssDirectory + 'themes', 'public/css/themes');
|
||||
|
||||
// Copy other CSS files to public
|
||||
mix.styles(bowerDirectoy + 'quill/dist/quill.snow.css', 'public/css/quill.snow.min.css')
|
||||
.styles(bowerDirectoy + 'lightbox2/dist/css/lightbox.css', 'public/css/lightbox.min.css')
|
||||
.styles(bowerDirectoy + 'datetimepicker/jquery.datetimepicker.css', 'public/css/jquery.datetimepicker.min.css')
|
||||
.styles(bowerDirectoy + 'jsoneditor/dist/jsoneditor.css', 'public/css/jsoneditor.min.css')
|
||||
.styles(bowerDirectoy + 'bootstrap/dist/css/bootstrap.css', 'public/css/bootstrap.min.css')
|
||||
.styles(resourcesCssDirectory + 'app.css', 'public/css/app.min.css')
|
||||
.styles(resourcesCssDirectory + 'customCss.css', 'public/css/customCss.min.css')
|
||||
.styles(resourcesCssDirectory + 'style.css', 'public/css/style.min.css')
|
||||
.styles(resourcesCssDirectory + 'public.style.css', 'public/public.style.min.css');
|
||||
|
||||
|
||||
// Built built.js
|
||||
mix.scripts([
|
||||
bowerDirectoy + 'jquery/dist/jquery.js',
|
||||
bowerDirectoy + 'jquery-ui/jquery-ui.js',
|
||||
bowerDirectoy + 'bootstrap/dist/js/bootstrap.js',
|
||||
bowerDirectoy + 'bootstrap-datepicker/dist/js/bootstrap-datepicker.js',
|
||||
bowerDirectoy + 'bootstrap-datepicker/dist/locales/bootstrap-datepicker.de.min.js',
|
||||
bowerDirectoy + 'bootstrap-datepicker/dist/locales/bootstrap-datepicker.da.min.js',
|
||||
bowerDirectoy + 'bootstrap-datepicker/dist/locales/bootstrap-datepicker.pt-BR.min.js',
|
||||
bowerDirectoy + 'bootstrap-datepicker/dist/locales/bootstrap-datepicker.nl.min.js',
|
||||
bowerDirectoy + 'bootstrap-datepicker/dist/locales/bootstrap-datepicker.fr.min.js',
|
||||
bowerDirectoy + 'bootstrap-datepicker/dist/locales/bootstrap-datepicker.it.min.js',
|
||||
bowerDirectoy + 'bootstrap-datepicker/dist/locales/bootstrap-datepicker.lt.min.js',
|
||||
bowerDirectoy + 'bootstrap-datepicker/dist/locales/bootstrap-datepicker.no.min.js',
|
||||
bowerDirectoy + 'bootstrap-datepicker/dist/locales/bootstrap-datepicker.es.min.js',
|
||||
bowerDirectoy + 'bootstrap-datepicker/dist/locales/bootstrap-datepicker.sv.min.js',
|
||||
bowerDirectoy + 'datatables/media/js/jquery.dataTables.js',
|
||||
bowerDirectoy + 'datatables-bootstrap3/BS3/assets/js/datatables.js',
|
||||
bowerDirectoy + 'knockout.js/knockout.js',
|
||||
bowerDirectoy + 'knockout-mapping/build/output/knockout.mapping-latest.js',
|
||||
bowerDirectoy + 'knockout-sortable/build/knockout-sortable.min.js',
|
||||
bowerDirectoy + 'underscore/underscore.js',
|
||||
bowerDirectoy + 'dropzone/dist/dropzone.js',
|
||||
bowerDirectoy + 'typeahead.js/dist/typeahead.jquery.js',
|
||||
bowerDirectoy + 'accounting/accounting.js',
|
||||
bowerDirectoy + 'spectrum/spectrum.js',
|
||||
bowerDirectoy + 'jspdf/dist/jspdf.min.js',
|
||||
bowerDirectoy + 'jspdf-plugins/plugins/split_text_to_size.js',
|
||||
bowerDirectoy + 'moment/moment.js',
|
||||
bowerDirectoy + 'moment-timezone/builds/moment-timezone-with-data.js',
|
||||
bowerDirectoy + 'stacktrace-js/dist/stacktrace-with-promises-and-json-polyfills.min.js',
|
||||
bowerDirectoy + 'fuse.js/src/fuse.js',
|
||||
bowerDirectoy + 'bootstrap-combobox/js/bootstrap-combobox.js',
|
||||
resourcesJsDirectory + 'script.js',
|
||||
resourcesJsDirectory + 'pdfmake-ninja.js'
|
||||
], 'public/built.js');
|
||||
|
||||
// Built built.public.js
|
||||
mix.scripts([
|
||||
bowerDirectoy + 'bootstrap/dist/js/bootstrap.js',
|
||||
bowerDirectoy + 'bootstrap-combobox/js/bootstrap-combobox.js'
|
||||
], 'public/built.public.js');
|
||||
|
||||
// Built pdf.built.js
|
||||
mix.scripts([
|
||||
resourcesJsDirectory + 'compatibility.js',
|
||||
resourcesJsDirectory + 'pdf_viewer.js',
|
||||
bowerDirectoy + 'pdfmake/build/pdfmake.js',
|
||||
resourcesJsDirectory + 'vfs.js'
|
||||
], 'public/pdf.built.js');
|
||||
|
||||
// Copy VFS Fonts to public directory
|
||||
mix.copy(resourcesJsDirectory + 'vfs_fonts', 'public/js/vfs_fonts');
|
||||
|
||||
// Copy other JS files to public
|
||||
mix.scripts(resourcesJsDirectory + 'Chart.js', 'public/js/Chart.min.js')
|
||||
.scripts(bowerDirectoy + 'datetimepicker/build/jquery.datetimepicker.full.js', 'public/js/jquery.datetimepicker.min.js')
|
||||
.scripts(bowerDirectoy + 'd3/d3.js', 'public/js/d3.min.js')
|
||||
.scripts(bowerDirectoy + 'quill/dist/quill.js', 'public/js/quill.min.js')
|
||||
.scripts(bowerDirectoy + 'lightbox2/dist/js/lightbox.js', 'public/js/lightbox.min.js')
|
||||
.scripts(bowerDirectoy + 'bootstrap-combobox/js/bootstrap-combobox.js', 'public/js/bootstrap-combobox.min.js')
|
||||
.scripts(resourcesJsDirectory + 'pdf.js', 'public/js/pdf.min.js')
|
||||
.scripts(resourcesJsDirectory + 'pdf_viewer.worker.js', 'public/js/pdf_viewer.worker.js');
|
||||
});
|
||||
|
31899
public/built.js
Normal file → Executable file
1
public/built.js.map
Normal file
429
public/built.public.js
Normal file → Executable file
1
public/built.public.js.map
Normal file
3
public/css/app.min.css
vendored
Normal file
1
public/css/app.min.css.map
Normal file
70
public/css/bootstrap-combobox.css
vendored
@ -1,70 +0,0 @@
|
||||
.combobox-container {
|
||||
margin-bottom: 5px;
|
||||
*zoom: 1;
|
||||
}
|
||||
.combobox-container:before,
|
||||
.combobox-container:after {
|
||||
display: table;
|
||||
content: "";
|
||||
}
|
||||
.combobox-container:after {
|
||||
clear: both;
|
||||
}
|
||||
.combobox-container input,
|
||||
.combobox-container .uneditable-input {
|
||||
-webkit-border-radius: 0 3px 3px 0;
|
||||
-moz-border-radius: 0 3px 3px 0;
|
||||
border-radius: 0 3px 3px 0;
|
||||
}
|
||||
.combobox-container input:focus,
|
||||
.combobox-container .uneditable-input:focus {
|
||||
position: relative;
|
||||
z-index: 2;
|
||||
}
|
||||
.combobox-container .uneditable-input {
|
||||
border-left-color: #ccc;
|
||||
}
|
||||
.combobox-container .active {
|
||||
background-color: #a9dba9;
|
||||
border-color: #46a546;
|
||||
}
|
||||
.combobox-container input,
|
||||
.combobox-container .uneditable-input {
|
||||
float: left;
|
||||
-webkit-border-radius: 3px 0 0 3px;
|
||||
-moz-border-radius: 3px 0 0 3px;
|
||||
border-radius: 3px 0 0 3px;
|
||||
}
|
||||
.combobox-container .uneditable-input {
|
||||
border-left-color: #eee;
|
||||
border-right-color: #ccc;
|
||||
}
|
||||
.combobox-container input:first-child {
|
||||
*margin-left: -160px;
|
||||
}
|
||||
.combobox-container select {
|
||||
display: inline-block;
|
||||
width: 0;
|
||||
height: 0;
|
||||
border: 0;
|
||||
padding: 0;
|
||||
margin: 0;
|
||||
text-indent: -99999px;
|
||||
*text-indent: 0;
|
||||
}
|
||||
.form-search .combobox-container,
|
||||
.form-inline .combobox-container {
|
||||
display: inline-block;
|
||||
margin-bottom: 0;
|
||||
vertical-align: top;
|
||||
}
|
||||
.combobox-selected .caret {
|
||||
display: none;
|
||||
}
|
||||
.typeahead-long {
|
||||
max-height: 300px;
|
||||
overflow-y: auto;
|
||||
}
|
||||
.combobox-container:not(.combobox-selected) .fa-times {
|
||||
display: none;
|
||||
}
|
6
public/css/bootstrap.min.css
vendored
1
public/css/bootstrap.min.css.map
Normal file
3234
public/css/built.css
vendored
21
public/css/built.min.css
vendored
Normal file
1
public/css/built.min.css.map
Normal file
972
public/css/built.public.css
vendored
14
public/css/built.public.min.css
vendored
Normal file
1
public/css/built.public.min.css.map
Normal file
2
public/css/customCss.min.css
vendored
Normal file
@ -0,0 +1,2 @@
|
||||
.customContainer{padding:40px 0;margin:0!important;background:-webkit-linear-gradient(#f5f5f5,#fff)}.customFontHead{font-size:20px;text-align:center}.customTextBorder{border-bottom:1px solid #c3c1c1;padding-bottom:5%;margin-bottom:5%}.customSubMenu{margin-left:2%}.customMenuOne{padding-left:5px;padding-right:5px}.shiftLeft{float:left}.customMenuDiv{padding-bottom:30px;float:left;width:100%}
|
||||
/*# sourceMappingURL=customCss.min.css.map */
|
1
public/css/customCss.min.css.map
Normal file
@ -0,0 +1 @@
|
||||
{"version":3,"sources":["customCss.css"],"names":[],"mappings":"AAAA,iBACA,eAAA,AACA,mBAAA,AACA,gDAAA,CACA,AACA,gBACA,eAAA,AACA,iBAAA,CACA,AACA,kBACA,gCAAA,AACA,kBAAA,AACA,gBAAA,CACA,AACA,eACA,cAAA,CACA,AACA,eACA,iBAAA,AACA,iBAAA,CACA,AACA,WACA,UAAA,CACA,AACA,eACA,oBAAA,AACA,WAAA,AACA,UAAA,CACA","file":"customCss.min.css","sourcesContent":[".customContainer{\n\tpadding: 40px 0;\n\tmargin: 0px 0 !important;\n\tbackground: -webkit-linear-gradient(rgb(245, 245, 245), white);\n}\t\n.customFontHead{\n\tfont-size: 20px;\n\ttext-align: center;\n}\t\n.customTextBorder{\n\tborder-bottom: 1px solid rgb(195, 193, 193);\n\tpadding-bottom: 5%;\n\tmargin-bottom: 5%;\n}\n.customSubMenu{\n\tmargin-left: 2%;\n}\n.customMenuOne{\n\tpadding-left: 5px;\n\tpadding-right: 5px;\n}\n.shiftLeft{\n\tfloat: left;\n}\n.customMenuDiv{\n\tpadding-bottom: 30px;\n\tfloat: left;\n\twidth: 100%;\n}"],"sourceRoot":"/source/"}
|
545
public/css/jquery.datetimepicker.css
vendored
@ -1,545 +0,0 @@
|
||||
.xdsoft_datetimepicker {
|
||||
box-shadow: 0 5px 15px -5px rgba(0, 0, 0, 0.506);
|
||||
background: #fff;
|
||||
border-bottom: 1px solid #bbb;
|
||||
border-left: 1px solid #ccc;
|
||||
border-right: 1px solid #ccc;
|
||||
border-top: 1px solid #ccc;
|
||||
color: #333;
|
||||
font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
|
||||
padding: 8px;
|
||||
padding-left: 0;
|
||||
padding-top: 2px;
|
||||
position: absolute;
|
||||
z-index: 9999;
|
||||
-moz-box-sizing: border-box;
|
||||
box-sizing: border-box;
|
||||
display: none;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker iframe {
|
||||
position: absolute;
|
||||
left: 0;
|
||||
top: 0;
|
||||
width: 75px;
|
||||
height: 210px;
|
||||
background: transparent;
|
||||
border: none;
|
||||
}
|
||||
|
||||
/*For IE8 or lower*/
|
||||
.xdsoft_datetimepicker button {
|
||||
border: none !important;
|
||||
}
|
||||
|
||||
.xdsoft_noselect {
|
||||
-webkit-touch-callout: none;
|
||||
-webkit-user-select: none;
|
||||
-khtml-user-select: none;
|
||||
-moz-user-select: none;
|
||||
-ms-user-select: none;
|
||||
-o-user-select: none;
|
||||
user-select: none;
|
||||
}
|
||||
|
||||
.xdsoft_noselect::selection { background: transparent }
|
||||
.xdsoft_noselect::-moz-selection { background: transparent }
|
||||
|
||||
.xdsoft_datetimepicker.xdsoft_inline {
|
||||
display: inline-block;
|
||||
position: static;
|
||||
box-shadow: none;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker * {
|
||||
-moz-box-sizing: border-box;
|
||||
box-sizing: border-box;
|
||||
padding: 0;
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_datepicker, .xdsoft_datetimepicker .xdsoft_timepicker {
|
||||
display: none;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_datepicker.active, .xdsoft_datetimepicker .xdsoft_timepicker.active {
|
||||
display: block;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_datepicker {
|
||||
width: 224px;
|
||||
float: left;
|
||||
margin-left: 8px;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker.xdsoft_showweeks .xdsoft_datepicker {
|
||||
width: 256px;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_timepicker {
|
||||
width: 58px;
|
||||
float: left;
|
||||
text-align: center;
|
||||
margin-left: 8px;
|
||||
margin-top: 0;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_datepicker.active+.xdsoft_timepicker {
|
||||
margin-top: 8px;
|
||||
margin-bottom: 3px
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_mounthpicker {
|
||||
position: relative;
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_label i,
|
||||
.xdsoft_datetimepicker .xdsoft_prev,
|
||||
.xdsoft_datetimepicker .xdsoft_next,
|
||||
.xdsoft_datetimepicker .xdsoft_today_button {
|
||||
background-image: url();
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_label i {
|
||||
opacity: 0.5;
|
||||
background-position: -92px -19px;
|
||||
display: inline-block;
|
||||
width: 9px;
|
||||
height: 20px;
|
||||
vertical-align: middle;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_prev {
|
||||
float: left;
|
||||
background-position: -20px 0;
|
||||
}
|
||||
.xdsoft_datetimepicker .xdsoft_today_button {
|
||||
float: left;
|
||||
background-position: -70px 0;
|
||||
margin-left: 5px;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_next {
|
||||
float: right;
|
||||
background-position: 0 0;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_next,
|
||||
.xdsoft_datetimepicker .xdsoft_prev ,
|
||||
.xdsoft_datetimepicker .xdsoft_today_button {
|
||||
background-color: transparent;
|
||||
background-repeat: no-repeat;
|
||||
border: 0 none;
|
||||
cursor: pointer;
|
||||
display: block;
|
||||
height: 30px;
|
||||
opacity: 0.5;
|
||||
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
|
||||
outline: medium none;
|
||||
overflow: hidden;
|
||||
padding: 0;
|
||||
position: relative;
|
||||
text-indent: 100%;
|
||||
white-space: nowrap;
|
||||
width: 20px;
|
||||
min-width: 0;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_prev,
|
||||
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_next {
|
||||
float: none;
|
||||
background-position: -40px -15px;
|
||||
height: 15px;
|
||||
width: 30px;
|
||||
display: block;
|
||||
margin-left: 14px;
|
||||
margin-top: 7px;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_prev {
|
||||
background-position: -40px 0;
|
||||
margin-bottom: 7px;
|
||||
margin-top: 0;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box {
|
||||
height: 151px;
|
||||
overflow: hidden;
|
||||
border-bottom: 1px solid #ddd;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div >div {
|
||||
background: #f5f5f5;
|
||||
border-top: 1px solid #ddd;
|
||||
color: #666;
|
||||
font-size: 12px;
|
||||
text-align: center;
|
||||
border-collapse: collapse;
|
||||
cursor: pointer;
|
||||
border-bottom-width: 0;
|
||||
height: 25px;
|
||||
line-height: 25px;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div > div:first-child {
|
||||
border-top-width: 0;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_today_button:hover,
|
||||
.xdsoft_datetimepicker .xdsoft_next:hover,
|
||||
.xdsoft_datetimepicker .xdsoft_prev:hover {
|
||||
opacity: 1;
|
||||
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_label {
|
||||
display: inline;
|
||||
position: relative;
|
||||
z-index: 9999;
|
||||
margin: 0;
|
||||
padding: 5px 3px;
|
||||
font-size: 14px;
|
||||
line-height: 20px;
|
||||
font-weight: bold;
|
||||
background-color: #fff;
|
||||
float: left;
|
||||
width: 182px;
|
||||
text-align: center;
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_label:hover>span {
|
||||
text-decoration: underline;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_label:hover i {
|
||||
opacity: 1.0;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select {
|
||||
border: 1px solid #ccc;
|
||||
position: absolute;
|
||||
right: 0;
|
||||
top: 30px;
|
||||
z-index: 101;
|
||||
display: none;
|
||||
background: #fff;
|
||||
max-height: 160px;
|
||||
overflow-y: hidden;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select.xdsoft_monthselect{ right: -7px }
|
||||
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select.xdsoft_yearselect{ right: 2px }
|
||||
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select > div > .xdsoft_option:hover {
|
||||
color: #fff;
|
||||
background: #ff8000;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select > div > .xdsoft_option {
|
||||
padding: 2px 10px 2px 5px;
|
||||
text-decoration: none !important;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_label > .xdsoft_select > div > .xdsoft_option.xdsoft_current {
|
||||
background: #33aaff;
|
||||
box-shadow: #178fe5 0 1px 3px 0 inset;
|
||||
color: #fff;
|
||||
font-weight: 700;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_month {
|
||||
width: 100px;
|
||||
text-align: right;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_calendar {
|
||||
clear: both;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_year{
|
||||
width: 48px;
|
||||
margin-left: 5px;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_calendar table {
|
||||
border-collapse: collapse;
|
||||
width: 100%;
|
||||
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_calendar td > div {
|
||||
padding-right: 5px;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_calendar th {
|
||||
height: 25px;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_calendar td,.xdsoft_datetimepicker .xdsoft_calendar th {
|
||||
width: 14.2857142%;
|
||||
background: #f5f5f5;
|
||||
border: 1px solid #ddd;
|
||||
color: #666;
|
||||
font-size: 12px;
|
||||
text-align: right;
|
||||
vertical-align: middle;
|
||||
padding: 0;
|
||||
border-collapse: collapse;
|
||||
cursor: pointer;
|
||||
height: 25px;
|
||||
}
|
||||
.xdsoft_datetimepicker.xdsoft_showweeks .xdsoft_calendar td,.xdsoft_datetimepicker.xdsoft_showweeks .xdsoft_calendar th {
|
||||
width: 12.5%;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_calendar th {
|
||||
background: #f1f1f1;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_today {
|
||||
color: #33aaff;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_highlighted_default {
|
||||
background: #ffe9d2;
|
||||
box-shadow: #ffb871 0 1px 4px 0 inset;
|
||||
color: #000;
|
||||
}
|
||||
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_highlighted_mint {
|
||||
background: #c1ffc9;
|
||||
box-shadow: #00dd1c 0 1px 4px 0 inset;
|
||||
color: #000;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_default,
|
||||
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_current,
|
||||
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div >div.xdsoft_current {
|
||||
background: #33aaff;
|
||||
box-shadow: #178fe5 0 1px 3px 0 inset;
|
||||
color: #fff;
|
||||
font-weight: 700;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_other_month,
|
||||
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_disabled,
|
||||
.xdsoft_datetimepicker .xdsoft_time_box >div >div.xdsoft_disabled {
|
||||
opacity: 0.5;
|
||||
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=50)";
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_other_month.xdsoft_disabled {
|
||||
opacity: 0.2;
|
||||
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=20)";
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_calendar td:hover,
|
||||
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div >div:hover {
|
||||
color: #fff !important;
|
||||
background: #ff8000 !important;
|
||||
box-shadow: none !important;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_current.xdsoft_disabled:hover,
|
||||
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box>div>div.xdsoft_current.xdsoft_disabled:hover {
|
||||
background: #33aaff !important;
|
||||
box-shadow: #178fe5 0 1px 3px 0 inset !important;
|
||||
color: #fff !important;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_calendar td.xdsoft_disabled:hover,
|
||||
.xdsoft_datetimepicker .xdsoft_timepicker .xdsoft_time_box >div >div.xdsoft_disabled:hover {
|
||||
color: inherit !important;
|
||||
background: inherit !important;
|
||||
box-shadow: inherit !important;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_calendar th {
|
||||
font-weight: 700;
|
||||
text-align: center;
|
||||
color: #999;
|
||||
cursor: default;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_copyright {
|
||||
color: #ccc !important;
|
||||
font-size: 10px;
|
||||
clear: both;
|
||||
float: none;
|
||||
margin-left: 8px;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker .xdsoft_copyright a { color: #eee !important }
|
||||
.xdsoft_datetimepicker .xdsoft_copyright a:hover { color: #aaa !important }
|
||||
|
||||
.xdsoft_time_box {
|
||||
position: relative;
|
||||
border: 1px solid #ccc;
|
||||
}
|
||||
.xdsoft_scrollbar >.xdsoft_scroller {
|
||||
background: #ccc !important;
|
||||
height: 20px;
|
||||
border-radius: 3px;
|
||||
}
|
||||
.xdsoft_scrollbar {
|
||||
position: absolute;
|
||||
width: 7px;
|
||||
right: 0;
|
||||
top: 0;
|
||||
bottom: 0;
|
||||
cursor: pointer;
|
||||
}
|
||||
.xdsoft_scroller_box {
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker.xdsoft_dark {
|
||||
box-shadow: 0 5px 15px -5px rgba(255, 255, 255, 0.506);
|
||||
background: #000;
|
||||
border-bottom: 1px solid #444;
|
||||
border-left: 1px solid #333;
|
||||
border-right: 1px solid #333;
|
||||
border-top: 1px solid #333;
|
||||
color: #ccc;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_timepicker .xdsoft_time_box {
|
||||
border-bottom: 1px solid #222;
|
||||
}
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_timepicker .xdsoft_time_box >div >div {
|
||||
background: #0a0a0a;
|
||||
border-top: 1px solid #222;
|
||||
color: #999;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_label {
|
||||
background-color: #000;
|
||||
}
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_label > .xdsoft_select {
|
||||
border: 1px solid #333;
|
||||
background: #000;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_label > .xdsoft_select > div > .xdsoft_option:hover {
|
||||
color: #000;
|
||||
background: #007fff;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_label > .xdsoft_select > div > .xdsoft_option.xdsoft_current {
|
||||
background: #cc5500;
|
||||
box-shadow: #b03e00 0 1px 3px 0 inset;
|
||||
color: #000;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_label i,
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_prev,
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_next,
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_today_button {
|
||||
background-image: url();
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td,
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar th {
|
||||
background: #0a0a0a;
|
||||
border: 1px solid #222;
|
||||
color: #999;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar th {
|
||||
background: #0e0e0e;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td.xdsoft_today {
|
||||
color: #cc5500;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td.xdsoft_highlighted_default {
|
||||
background: #ffe9d2;
|
||||
box-shadow: #ffb871 0 1px 4px 0 inset;
|
||||
color:#000;
|
||||
}
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td.xdsoft_highlighted_mint {
|
||||
background: #c1ffc9;
|
||||
box-shadow: #00dd1c 0 1px 4px 0 inset;
|
||||
color:#000;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td.xdsoft_default,
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td.xdsoft_current,
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_timepicker .xdsoft_time_box >div >div.xdsoft_current {
|
||||
background: #cc5500;
|
||||
box-shadow: #b03e00 0 1px 3px 0 inset;
|
||||
color: #000;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar td:hover,
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_timepicker .xdsoft_time_box >div >div:hover {
|
||||
color: #000 !important;
|
||||
background: #007fff !important;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_calendar th {
|
||||
color: #666;
|
||||
}
|
||||
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_copyright { color: #333 !important }
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_copyright a { color: #111 !important }
|
||||
.xdsoft_datetimepicker.xdsoft_dark .xdsoft_copyright a:hover { color: #555 !important }
|
||||
|
||||
.xdsoft_dark .xdsoft_time_box {
|
||||
border: 1px solid #333;
|
||||
}
|
||||
|
||||
.xdsoft_dark .xdsoft_scrollbar >.xdsoft_scroller {
|
||||
background: #333 !important;
|
||||
}
|
||||
.xdsoft_datetimepicker .xdsoft_save_selected {
|
||||
display: block;
|
||||
border: 1px solid #dddddd !important;
|
||||
margin-top: 5px;
|
||||
width: 100%;
|
||||
color: #454551;
|
||||
font-size: 13px;
|
||||
}
|
||||
.xdsoft_datetimepicker .blue-gradient-button {
|
||||
font-family: "museo-sans", "Book Antiqua", sans-serif;
|
||||
font-size: 12px;
|
||||
font-weight: 300;
|
||||
color: #82878c;
|
||||
height: 28px;
|
||||
position: relative;
|
||||
padding: 4px 17px 4px 33px;
|
||||
border: 1px solid #d7d8da;
|
||||
background: -moz-linear-gradient(top, #fff 0%, #f4f8fa 73%);
|
||||
/* FF3.6+ */
|
||||
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #fff), color-stop(73%, #f4f8fa));
|
||||
/* Chrome,Safari4+ */
|
||||
background: -webkit-linear-gradient(top, #fff 0%, #f4f8fa 73%);
|
||||
/* Chrome10+,Safari5.1+ */
|
||||
background: -o-linear-gradient(top, #fff 0%, #f4f8fa 73%);
|
||||
/* Opera 11.10+ */
|
||||
background: -ms-linear-gradient(top, #fff 0%, #f4f8fa 73%);
|
||||
/* IE10+ */
|
||||
background: linear-gradient(to bottom, #fff 0%, #f4f8fa 73%);
|
||||
/* W3C */
|
||||
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#fff', endColorstr='#f4f8fa',GradientType=0 );
|
||||
/* IE6-9 */
|
||||
}
|
||||
.xdsoft_datetimepicker .blue-gradient-button:hover, .xdsoft_datetimepicker .blue-gradient-button:focus, .xdsoft_datetimepicker .blue-gradient-button:hover span, .xdsoft_datetimepicker .blue-gradient-button:focus span {
|
||||
color: #454551;
|
||||
background: -moz-linear-gradient(top, #f4f8fa 0%, #FFF 73%);
|
||||
/* FF3.6+ */
|
||||
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #f4f8fa), color-stop(73%, #FFF));
|
||||
/* Chrome,Safari4+ */
|
||||
background: -webkit-linear-gradient(top, #f4f8fa 0%, #FFF 73%);
|
||||
/* Chrome10+,Safari5.1+ */
|
||||
background: -o-linear-gradient(top, #f4f8fa 0%, #FFF 73%);
|
||||
/* Opera 11.10+ */
|
||||
background: -ms-linear-gradient(top, #f4f8fa 0%, #FFF 73%);
|
||||
/* IE10+ */
|
||||
background: linear-gradient(to bottom, #f4f8fa 0%, #FFF 73%);
|
||||
/* W3C */
|
||||
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#f4f8fa', endColorstr='#FFF',GradientType=0 );
|
||||
/* IE6-9 */
|
||||
}
|
2
public/css/jquery.datetimepicker.min.css
vendored
Normal file
1
public/css/jquery.datetimepicker.min.css.map
Normal file
3
public/css/jsoneditor.min.css
vendored
1
public/css/jsoneditor.min.css.map
Normal file
210
public/css/lightbox.css
vendored
@ -1,210 +0,0 @@
|
||||
/* Preload images */
|
||||
body:after {
|
||||
content: url(../images/lightbox/close.png) url(../images/lightbox/loading.gif) url(../images/lightbox/prev.png) url(../images/lightbox/next.png);
|
||||
display: none;
|
||||
}
|
||||
|
||||
.lightboxOverlay {
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
z-index: 9999;
|
||||
background-color: black;
|
||||
filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80);
|
||||
opacity: 0.8;
|
||||
display: none;
|
||||
}
|
||||
|
||||
.lightbox {
|
||||
position: absolute;
|
||||
left: 0;
|
||||
width: 100%;
|
||||
z-index: 10000;
|
||||
text-align: center;
|
||||
line-height: 0;
|
||||
font-weight: normal;
|
||||
}
|
||||
|
||||
.lightbox .lb-image {
|
||||
display: block;
|
||||
height: auto;
|
||||
max-width: inherit;
|
||||
-webkit-border-radius: 3px;
|
||||
-moz-border-radius: 3px;
|
||||
-ms-border-radius: 3px;
|
||||
-o-border-radius: 3px;
|
||||
border-radius: 3px;
|
||||
}
|
||||
|
||||
.lightbox a img {
|
||||
border: none;
|
||||
}
|
||||
|
||||
.lb-outerContainer {
|
||||
position: relative;
|
||||
background-color: white;
|
||||
*zoom: 1;
|
||||
width: 250px;
|
||||
height: 250px;
|
||||
margin: 0 auto;
|
||||
-webkit-border-radius: 4px;
|
||||
-moz-border-radius: 4px;
|
||||
-ms-border-radius: 4px;
|
||||
-o-border-radius: 4px;
|
||||
border-radius: 4px;
|
||||
}
|
||||
|
||||
.lb-outerContainer:after {
|
||||
content: "";
|
||||
display: table;
|
||||
clear: both;
|
||||
}
|
||||
|
||||
.lb-container {
|
||||
padding: 4px;
|
||||
}
|
||||
|
||||
.lb-loader {
|
||||
position: absolute;
|
||||
top: 43%;
|
||||
left: 0;
|
||||
height: 25%;
|
||||
width: 100%;
|
||||
text-align: center;
|
||||
line-height: 0;
|
||||
}
|
||||
|
||||
.lb-cancel {
|
||||
display: block;
|
||||
width: 32px;
|
||||
height: 32px;
|
||||
margin: 0 auto;
|
||||
background: url(../images/lightbox/loading.gif) no-repeat;
|
||||
}
|
||||
|
||||
.lb-nav {
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
height: 100%;
|
||||
width: 100%;
|
||||
z-index: 10;
|
||||
}
|
||||
|
||||
.lb-container > .nav {
|
||||
left: 0;
|
||||
}
|
||||
|
||||
.lb-nav a {
|
||||
outline: none;
|
||||
background-image: url('');
|
||||
}
|
||||
|
||||
.lb-prev, .lb-next {
|
||||
height: 100%;
|
||||
cursor: pointer;
|
||||
display: block;
|
||||
}
|
||||
|
||||
.lb-nav a.lb-prev {
|
||||
width: 34%;
|
||||
left: 0;
|
||||
float: left;
|
||||
background: url(../images/lightbox/prev.png) left 48% no-repeat;
|
||||
filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=0);
|
||||
opacity: 0;
|
||||
-webkit-transition: opacity 0.6s;
|
||||
-moz-transition: opacity 0.6s;
|
||||
-o-transition: opacity 0.6s;
|
||||
transition: opacity 0.6s;
|
||||
}
|
||||
|
||||
.lb-nav a.lb-prev:hover {
|
||||
filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100);
|
||||
opacity: 1;
|
||||
}
|
||||
|
||||
.lb-nav a.lb-next {
|
||||
width: 64%;
|
||||
right: 0;
|
||||
float: right;
|
||||
background: url(../images/lightbox/next.png) right 48% no-repeat;
|
||||
filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=0);
|
||||
opacity: 0;
|
||||
-webkit-transition: opacity 0.6s;
|
||||
-moz-transition: opacity 0.6s;
|
||||
-o-transition: opacity 0.6s;
|
||||
transition: opacity 0.6s;
|
||||
}
|
||||
|
||||
.lb-nav a.lb-next:hover {
|
||||
filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100);
|
||||
opacity: 1;
|
||||
}
|
||||
|
||||
.lb-dataContainer {
|
||||
margin: 0 auto;
|
||||
padding-top: 5px;
|
||||
*zoom: 1;
|
||||
width: 100%;
|
||||
-moz-border-radius-bottomleft: 4px;
|
||||
-webkit-border-bottom-left-radius: 4px;
|
||||
border-bottom-left-radius: 4px;
|
||||
-moz-border-radius-bottomright: 4px;
|
||||
-webkit-border-bottom-right-radius: 4px;
|
||||
border-bottom-right-radius: 4px;
|
||||
}
|
||||
|
||||
.lb-dataContainer:after {
|
||||
content: "";
|
||||
display: table;
|
||||
clear: both;
|
||||
}
|
||||
|
||||
.lb-data {
|
||||
padding: 0 4px;
|
||||
color: #ccc;
|
||||
}
|
||||
|
||||
.lb-data .lb-details {
|
||||
width: 85%;
|
||||
float: left;
|
||||
text-align: left;
|
||||
line-height: 1.1em;
|
||||
}
|
||||
|
||||
.lb-data .lb-caption {
|
||||
font-size: 13px;
|
||||
font-weight: bold;
|
||||
line-height: 1em;
|
||||
}
|
||||
|
||||
.lb-data .lb-number {
|
||||
display: block;
|
||||
clear: left;
|
||||
padding-bottom: 1em;
|
||||
font-size: 12px;
|
||||
color: #999999;
|
||||
}
|
||||
|
||||
.lb-data .lb-close {
|
||||
display: block;
|
||||
float: right;
|
||||
width: 30px;
|
||||
height: 30px;
|
||||
background: url(../images/lightbox/close.png) top right no-repeat;
|
||||
text-align: right;
|
||||
outline: none;
|
||||
filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=70);
|
||||
opacity: 0.7;
|
||||
-webkit-transition: opacity 0.2s;
|
||||
-moz-transition: opacity 0.2s;
|
||||
-o-transition: opacity 0.2s;
|
||||
transition: opacity 0.2s;
|
||||
}
|
||||
|
||||
.lb-data .lb-close:hover {
|
||||
cursor: pointer;
|
||||
filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=100);
|
||||
opacity: 1;
|
||||
}
|
2
public/css/lightbox.min.css
vendored
Normal file
@ -0,0 +1,2 @@
|
||||
body:after{content:url(../images/close.png) url(../images/loading.gif) url(../images/prev.png) url(../images/next.png);display:none}body.lb-disable-scrolling{overflow:hidden}.lightboxOverlay{position:absolute;top:0;left:0;z-index:9999;background-color:#000;filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=80);opacity:.8;display:none}.lightbox{position:absolute;left:0;width:100%;z-index:10000;text-align:center;line-height:0;font-weight:400}.lightbox .lb-image{display:block;height:auto;max-width:inherit;border-radius:3px}.lightbox a img{border:none}.lb-outerContainer{position:relative;background-color:#fff;*zoom:1;width:250px;height:250px;margin:0 auto;border-radius:4px}.lb-outerContainer:after{content:"";display:table;clear:both}.lb-container{padding:4px}.lb-loader{position:absolute;top:43%;left:0;height:25%;width:100%;text-align:center;line-height:0}.lb-cancel{display:block;width:32px;height:32px;margin:0 auto;background:url(../images/loading.gif) no-repeat}.lb-nav{position:absolute;top:0;left:0;height:100%;width:100%;z-index:10}.lb-container>.nav{left:0}.lb-nav a{outline:none;background-image:url('')}.lb-next,.lb-prev{height:100%;cursor:pointer;display:block}.lb-nav a.lb-prev{width:34%;left:0;float:left;background:url(../images/prev.png) left 48% no-repeat;filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=0);opacity:0;-webkit-transition:opacity .6s;transition:opacity .6s}.lb-nav a.lb-prev:hover{filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=100);opacity:1}.lb-nav a.lb-next{width:64%;right:0;float:right;background:url(../images/next.png) right 48% no-repeat;filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=0);opacity:0;-webkit-transition:opacity .6s;transition:opacity .6s}.lb-nav a.lb-next:hover{filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=100);opacity:1}.lb-dataContainer{margin:0 auto;padding-top:5px;*zoom:1;width:100%;border-bottom-left-radius:4px;border-bottom-right-radius:4px}.lb-dataContainer:after{content:"";display:table;clear:both}.lb-data{padding:0 4px;color:#ccc}.lb-data .lb-details{width:85%;float:left;text-align:left;line-height:1.1em}.lb-data .lb-caption{font-size:13px;font-weight:700;line-height:1em}.lb-data .lb-number{display:block;clear:left;padding-bottom:1em;font-size:12px;color:#999}.lb-data .lb-close{display:block;float:right;width:30px;height:30px;background:url(../images/close.png) 100% 0 no-repeat;text-align:right;outline:none;filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=70);opacity:.7;-webkit-transition:opacity .2s;transition:opacity .2s}.lb-data .lb-close:hover{cursor:pointer;filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=100);opacity:1}
|
||||
/*# sourceMappingURL=lightbox.min.css.map */
|
1
public/css/lightbox.min.css.map
Normal file
917
public/css/quill.snow.css
vendored
@ -1,917 +0,0 @@
|
||||
/*! Quill Editor v0.20.0
|
||||
* https://quilljs.com/
|
||||
* Copyright (c) 2014, Jason Chen
|
||||
* Copyright (c) 2013, salesforce.com
|
||||
*/
|
||||
.ql-image-tooltip {
|
||||
padding: 10px;
|
||||
width: 300px;
|
||||
}
|
||||
.ql-image-tooltip:after {
|
||||
clear: both;
|
||||
content: "";
|
||||
display: table;
|
||||
}
|
||||
.ql-image-tooltip a {
|
||||
border: 1px solid #000;
|
||||
box-sizing: border-box;
|
||||
display: inline-block;
|
||||
float: left;
|
||||
padding: 5px;
|
||||
text-align: center;
|
||||
width: 50%;
|
||||
}
|
||||
.ql-image-tooltip img {
|
||||
bottom: 0;
|
||||
left: 0;
|
||||
margin: auto;
|
||||
max-height: 100%;
|
||||
max-width: 100%;
|
||||
position: absolute;
|
||||
right: 0;
|
||||
top: 0;
|
||||
}
|
||||
.ql-image-tooltip .input {
|
||||
box-sizing: border-box;
|
||||
width: 100%;
|
||||
}
|
||||
.ql-image-tooltip .preview {
|
||||
margin: 10px 0px;
|
||||
position: relative;
|
||||
border: 1px dashed #000;
|
||||
height: 200px;
|
||||
}
|
||||
.ql-image-tooltip .preview span {
|
||||
display: inline-block;
|
||||
position: absolute;
|
||||
text-align: center;
|
||||
top: 40%;
|
||||
width: 100%;
|
||||
}
|
||||
.ql-link-tooltip {
|
||||
padding: 5px 10px;
|
||||
}
|
||||
.ql-link-tooltip input.input {
|
||||
width: 170px;
|
||||
}
|
||||
.ql-link-tooltip input.input,
|
||||
.ql-link-tooltip a.done {
|
||||
display: none;
|
||||
}
|
||||
.ql-link-tooltip a.change {
|
||||
margin-right: 4px;
|
||||
}
|
||||
.ql-link-tooltip.editing input.input,
|
||||
.ql-link-tooltip.editing a.done {
|
||||
display: inline-block;
|
||||
}
|
||||
.ql-link-tooltip.editing a.url,
|
||||
.ql-link-tooltip.editing a.change,
|
||||
.ql-link-tooltip.editing a.remove {
|
||||
display: none;
|
||||
}
|
||||
.ql-multi-cursor {
|
||||
position: absolute;
|
||||
left: 0;
|
||||
top: 0;
|
||||
z-index: 1000;
|
||||
}
|
||||
.ql-multi-cursor .cursor {
|
||||
margin-left: -1px;
|
||||
position: absolute;
|
||||
}
|
||||
.ql-multi-cursor .cursor-flag {
|
||||
bottom: 100%;
|
||||
position: absolute;
|
||||
white-space: nowrap;
|
||||
}
|
||||
.ql-multi-cursor .cursor-name {
|
||||
display: inline-block;
|
||||
color: #fff;
|
||||
padding: 2px 8px;
|
||||
}
|
||||
.ql-multi-cursor .cursor-caret {
|
||||
height: 100%;
|
||||
position: absolute;
|
||||
width: 2px;
|
||||
}
|
||||
.ql-multi-cursor .cursor.hidden .cursor-flag {
|
||||
display: none;
|
||||
}
|
||||
.ql-multi-cursor .cursor.top .cursor-flag {
|
||||
bottom: auto;
|
||||
top: 100%;
|
||||
}
|
||||
.ql-multi-cursor .cursor.right .cursor-flag {
|
||||
right: -2px;
|
||||
}
|
||||
.ql-paste-manager {
|
||||
left: -100000px;
|
||||
position: absolute;
|
||||
top: 50%;
|
||||
}
|
||||
.ql-toolbar {
|
||||
box-sizing: border-box;
|
||||
}
|
||||
.ql-tooltip {
|
||||
background-color: #fff;
|
||||
border: 1px solid #000;
|
||||
box-sizing: border-box;
|
||||
position: absolute;
|
||||
top: 0px;
|
||||
white-space: nowrap;
|
||||
z-index: 2000;
|
||||
}
|
||||
.ql-tooltip a {
|
||||
cursor: pointer;
|
||||
text-decoration: none;
|
||||
}
|
||||
.ql-container {
|
||||
box-sizing: border-box;
|
||||
cursor: text;
|
||||
font-family: Helvetica, 'Arial', sans-serif;
|
||||
font-size: 13px;
|
||||
height: 100%;
|
||||
line-height: 1.42;
|
||||
margin: 0px;
|
||||
overflow-x: hidden;
|
||||
overflow-y: auto;
|
||||
padding: 12px 15px;
|
||||
position: relative;
|
||||
}
|
||||
.ql-editor {
|
||||
box-sizing: border-box;
|
||||
min-height: 100%;
|
||||
outline: none;
|
||||
tab-size: 4;
|
||||
white-space: pre-wrap;
|
||||
}
|
||||
.ql-editor div {
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
}
|
||||
.ql-editor a {
|
||||
text-decoration: underline;
|
||||
}
|
||||
.ql-editor b {
|
||||
font-weight: bold;
|
||||
}
|
||||
.ql-editor i {
|
||||
font-style: italic;
|
||||
}
|
||||
.ql-editor s {
|
||||
text-decoration: line-through;
|
||||
}
|
||||
.ql-editor u {
|
||||
text-decoration: underline;
|
||||
}
|
||||
.ql-editor a,
|
||||
.ql-editor b,
|
||||
.ql-editor i,
|
||||
.ql-editor s,
|
||||
.ql-editor u,
|
||||
.ql-editor span {
|
||||
background-color: inherit;
|
||||
}
|
||||
.ql-editor img {
|
||||
max-width: 100%;
|
||||
}
|
||||
.ql-editor blockquote,
|
||||
.ql-editor ol,
|
||||
.ql-editor ul {
|
||||
margin: 0 0 0 2em;
|
||||
padding: 0;
|
||||
}
|
||||
.ql-editor ol {
|
||||
list-style-type: decimal;
|
||||
}
|
||||
.ql-editor ul {
|
||||
list-style-type: disc;
|
||||
}
|
||||
.ql-editor.ql-ie-9 br,
|
||||
.ql-editor.ql-ie-10 br {
|
||||
display: none;
|
||||
}
|
||||
.ql-snow .ql-image-tooltip a {
|
||||
border: 1px solid #06c;
|
||||
}
|
||||
.ql-snow .ql-image-tooltip a.insert {
|
||||
background-color: #06c;
|
||||
color: #fff;
|
||||
}
|
||||
.ql-snow .ql-image-tooltip .preview {
|
||||
border-color: #ccc;
|
||||
color: #ccc;
|
||||
}
|
||||
.ql-snow .ql-link-tooltip a,
|
||||
.ql-snow .ql-link-tooltip span {
|
||||
line-height: 25px;
|
||||
}
|
||||
.ql-snow .ql-multi-cursor .cursor-name {
|
||||
border-radius: 4px;
|
||||
font-size: 11px;
|
||||
font-family: Arial;
|
||||
margin-left: -50%;
|
||||
padding: 4px 10px;
|
||||
}
|
||||
.ql-snow .ql-multi-cursor .cursor-triangle {
|
||||
border-left: 4px solid transparent;
|
||||
border-right: 4px solid transparent;
|
||||
height: 0px;
|
||||
margin-left: -3px;
|
||||
width: 0px;
|
||||
}
|
||||
.ql-snow .ql-multi-cursor .cursor.left .cursor-name {
|
||||
margin-left: -8px;
|
||||
}
|
||||
.ql-snow .ql-multi-cursor .cursor.right .cursor-flag {
|
||||
right: auto;
|
||||
}
|
||||
.ql-snow .ql-multi-cursor .cursor.right .cursor-name {
|
||||
margin-left: -100%;
|
||||
margin-right: -8px;
|
||||
}
|
||||
.ql-snow .ql-multi-cursor .cursor-triangle.bottom {
|
||||
border-top: 4px solid transparent;
|
||||
display: block;
|
||||
margin-bottom: -1px;
|
||||
}
|
||||
.ql-snow .ql-multi-cursor .cursor-triangle.top {
|
||||
border-bottom: 4px solid transparent;
|
||||
display: none;
|
||||
margin-top: -1px;
|
||||
}
|
||||
.ql-snow .ql-multi-cursor .cursor.top .cursor-triangle.bottom {
|
||||
display: none;
|
||||
}
|
||||
.ql-snow .ql-multi-cursor .cursor.top .cursor-triangle.top {
|
||||
display: block;
|
||||
}
|
||||
.ql-snow.ql-toolbar {
|
||||
box-sizing: border-box;
|
||||
padding: 8px;
|
||||
user-select: none;
|
||||
-webkit-user-select: none;
|
||||
-moz-user-select: none;
|
||||
-ms-user-select: none;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-group {
|
||||
display: inline-block;
|
||||
margin-right: 15px;
|
||||
vertical-align: middle;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-separator {
|
||||
box-sizing: border-box;
|
||||
background-color: #ddd;
|
||||
display: inline-block;
|
||||
height: 14px;
|
||||
margin-left: 4px;
|
||||
margin-right: 4px;
|
||||
vertical-align: middle;
|
||||
width: 1px;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button {
|
||||
box-sizing: border-box;
|
||||
display: inline-block;
|
||||
height: 24px;
|
||||
line-height: 24px;
|
||||
vertical-align: middle;
|
||||
background-position: center center;
|
||||
background-repeat: no-repeat;
|
||||
background-size: 18px 18px;
|
||||
box-sizing: border-box;
|
||||
cursor: pointer;
|
||||
text-align: center;
|
||||
width: 24px;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker {
|
||||
box-sizing: border-box;
|
||||
color: #444;
|
||||
display: inline-block;
|
||||
font-family: 'Helvetica Neue', 'Helvetica', 'Arial', sans-serif;
|
||||
font-size: 14px;
|
||||
font-weight: 500;
|
||||
position: relative;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label {
|
||||
box-sizing: border-box;
|
||||
display: inline-block;
|
||||
height: 24px;
|
||||
line-height: 24px;
|
||||
vertical-align: middle;
|
||||
background-color: #fff;
|
||||
background-position: right center;
|
||||
background-repeat: no-repeat;
|
||||
background-size: 18px 18px;
|
||||
border: 1px solid transparent;
|
||||
cursor: pointer;
|
||||
position: relative;
|
||||
width: 100%;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label:hover {
|
||||
color: #06c;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-options {
|
||||
background-color: #fff;
|
||||
border: 1px solid transparent;
|
||||
box-sizing: border-box;
|
||||
display: none;
|
||||
padding: 4px 8px;
|
||||
position: absolute;
|
||||
width: 100%;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-options .ql-picker-item {
|
||||
background-position: center center;
|
||||
background-repeat: no-repeat;
|
||||
background-size: 18px 18px;
|
||||
box-sizing: border-box;
|
||||
cursor: pointer;
|
||||
display: block;
|
||||
padding-bottom: 5px;
|
||||
padding-top: 5px;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-options .ql-picker-item.ql-selected,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-options .ql-picker-item:hover {
|
||||
color: #06c;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-expanded .ql-picker-label {
|
||||
border-color: #ccc;
|
||||
color: #ccc;
|
||||
z-index: 2;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-expanded .ql-picker-options {
|
||||
border-color: #ccc;
|
||||
box-shadow: rgba(0,0,0,0.2) 0 2px 8px;
|
||||
display: block;
|
||||
margin-top: -1px;
|
||||
z-index: 1;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-color-picker .ql-picker-label {
|
||||
background-position: center center;
|
||||
width: 28px;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-color-picker .ql-picker-options {
|
||||
padding: 5px;
|
||||
width: 152px;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-color-picker .ql-picker-options .ql-picker-item {
|
||||
border: 1px solid transparent;
|
||||
float: left;
|
||||
height: 16px;
|
||||
margin: 2px;
|
||||
padding: 0px;
|
||||
width: 16px;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-color-picker .ql-picker-options .ql-picker-item.ql-primary-color {
|
||||
margin-bottom: 8px;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-color-picker .ql-picker-options .ql-picker-item.ql-selected,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-color-picker .ql-picker-options .ql-picker-item:hover {
|
||||
border-color: #000;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-font {
|
||||
width: 105px;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-size {
|
||||
width: 80px;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-font .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-size .ql-picker-label {
|
||||
padding-left: 8px;
|
||||
padding-right: 8px;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-align .ql-picker-label {
|
||||
background-position: center center;
|
||||
width: 28px;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-align .ql-picker-item {
|
||||
box-sizing: border-box;
|
||||
display: inline-block;
|
||||
height: 24px;
|
||||
line-height: 24px;
|
||||
vertical-align: middle;
|
||||
padding: 0px;
|
||||
width: 28px;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-align .ql-picker-options {
|
||||
padding: 4px 0px;
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-expanded .ql-picker-label {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-active:not(.ql-expanded) .ql-picker-label,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker:not(.ql-expanded) .ql-picker-label:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-bold,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-bold .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=bold],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=bold] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-bold.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-bold .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=bold].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=bold].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-bold:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-bold .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=bold]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=bold]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-italic,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-italic .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=italic],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=italic] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-italic.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-italic .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=italic].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=italic].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-italic:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-italic .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=italic]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=italic]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-underline,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-underline .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=underline],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=underline] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-underline.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-underline .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=underline].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=underline].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-underline:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-underline .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=underline]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=underline]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-strike,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-strike .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=strike],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=strike] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-strike.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-strike .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=strike].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=strike].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-strike:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-strike .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=strike]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=strike]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-link,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-link .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=link],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=link] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-link.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-link .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=link].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=link].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-link:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-link .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=link]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=link]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-image,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-image .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=image],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=image] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-image.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-image .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=image].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=image].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-image:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-image .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=image]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=image]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-list,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-list .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=list],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=list] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-list.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-list .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=list].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=list].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-list:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-list .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=list]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=list]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-bullet,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-bullet .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=bullet],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=bullet] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-bullet.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-bullet .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=bullet].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=bullet].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-bullet:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-bullet .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=bullet]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=bullet]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-authorship,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-authorship .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=authorship],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=authorship] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-authorship.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-authorship .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=authorship].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=authorship].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-authorship:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-authorship .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=authorship]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=authorship]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-color,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-color .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=color],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=color] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-color.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-color .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=color].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=color].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-color:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-color .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=color]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=color]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-background,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-background .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=background],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=background] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-background.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-background .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=background].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=background].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-background:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-background .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=background]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=background]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-left,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-left .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=left],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=left] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-left.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-left .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=left].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=left].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-left:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-left .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=left]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=left]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-right,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-right .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=right],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=right] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-right.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-right .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=right].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=right].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-right:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-right .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=right]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=right]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-center,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-center .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=center],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=center] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-center.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-center .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=center].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=center].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-center:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-center .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=center]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=center]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-justify,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-justify .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=justify],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=justify] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-justify.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-justify .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=justify].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=justify].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-justify:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-justify .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=justify]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=justify]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
@media (-webkit-min-device-pixel-ratio: 2) {
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-expanded .ql-picker-label {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-active:not(.ql-expanded) .ql-picker-label,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker:not(.ql-expanded) .ql-picker-label:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-bold,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-bold .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=bold],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=bold] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-bold.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-bold .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=bold].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=bold].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-bold:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-bold .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=bold]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=bold]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-italic,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-italic .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=italic],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=italic] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-italic.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-italic .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=italic].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=italic].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-italic:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-italic .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=italic]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=italic]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-underline,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-underline .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=underline],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=underline] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-underline.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-underline .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=underline].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=underline].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-underline:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-underline .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=underline]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=underline]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-strike,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-strike .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=strike],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=strike] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-strike.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-strike .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=strike].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=strike].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-strike:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-strike .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=strike]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=strike]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-link,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-link .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=link],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=link] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-link.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-link .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=link].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=link].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-link:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-link .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=link]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=link]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-image,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-image .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=image],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=image] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-image.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-image .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=image].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=image].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-image:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-image .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=image]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=image]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-list,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-list .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=list],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=list] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-list.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-list .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=list].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=list].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-list:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-list .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=list]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=list]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-bullet,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-bullet .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=bullet],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=bullet] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-bullet.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-bullet .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=bullet].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=bullet].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-bullet:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-bullet .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=bullet]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=bullet]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-authorship,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-authorship .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=authorship],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=authorship] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-authorship.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-authorship .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=authorship].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=authorship].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-authorship:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-authorship .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=authorship]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=authorship]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-color,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-color .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=color],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=color] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-color.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-color .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=color].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=color].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-color:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-color .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=color]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=color]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-background,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-background .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=background],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=background] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-background.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-background .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=background].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=background].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-background:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-background .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=background]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=background]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-left,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-left .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=left],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=left] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-left.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-left .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=left].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=left].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-left:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-left .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=left]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=left]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-right,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-right .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=right],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=right] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-right.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-right .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=right].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=right].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-right:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-right .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=right]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=right]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-center,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-center .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=center],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=center] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-center.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-center .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=center].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=center].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-center:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-center .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=center]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=center]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-justify,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-justify .ql-picker-label,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=justify],
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=justify] {
|
||||
background-image: url("");
|
||||
}
|
||||
.ql-snow.ql-toolbar .ql-format-button.ql-justify.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker.ql-justify .ql-picker-label.ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-label[data-value=justify].ql-active,
|
||||
.ql-snow.ql-toolbar .ql-picker .ql-picker-item[data-value=justify].ql-selected,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-format-button.ql-justify:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker.ql-justify .ql-picker-label:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-label[data-value=justify]:hover,
|
||||
.ql-snow.ql-toolbar:not(.ios) .ql-picker .ql-picker-item[data-value=justify]:hover {
|
||||
background-image: url("");
|
||||
}
|
||||
}
|
||||
.ql-snow .ql-tooltip {
|
||||
border: 1px solid #ccc;
|
||||
box-shadow: 0px 0px 5px #ddd;
|
||||
color: #222;
|
||||
}
|
||||
.ql-snow .ql-tooltip a {
|
||||
color: #06c;
|
||||
}
|
||||
.ql-snow .ql-tooltip .input {
|
||||
border: 1px solid #ccc;
|
||||
margin: 0px;
|
||||
padding: 5px;
|
||||
}
|
||||
.ql-snow a {
|
||||
color: #06c;
|
||||
}
|
6
public/css/quill.snow.min.css
vendored
Normal file
1
public/css/quill.snow.min.css.map
Normal file
2
public/css/style.min.css
vendored
Normal file
1
public/css/style.min.css.map
Normal file
Before Width: | Height: | Size: 280 B After Width: | Height: | Size: 280 B |
Before Width: | Height: | Size: 8.3 KiB After Width: | Height: | Size: 8.3 KiB |
Before Width: | Height: | Size: 1.3 KiB After Width: | Height: | Size: 1.3 KiB |
Before Width: | Height: | Size: 1.3 KiB After Width: | Height: | Size: 1.3 KiB |
2
public/js/Chart.min.js
vendored
Normal file
1
public/js/Chart.min.js.map
Normal file
419
public/js/bootstrap-combobox.js
vendored
@ -1,419 +0,0 @@
|
||||
/* =============================================================
|
||||
* bootstrap-combobox.js v1.1.5
|
||||
* =============================================================
|
||||
* Copyright 2012 Daniel Farrell
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
* ============================================================ */
|
||||
|
||||
!function( $ ) {
|
||||
|
||||
"use strict";
|
||||
|
||||
/* COMBOBOX PUBLIC CLASS DEFINITION
|
||||
* ================================ */
|
||||
|
||||
var Combobox = function ( element, options ) {
|
||||
this.options = $.extend({}, $.fn.combobox.defaults, options);
|
||||
this.$source = $(element);
|
||||
this.$container = this.setup();
|
||||
this.$element = this.$container.find('input[type=text]');
|
||||
this.$target = this.$container.find('input[type=hidden]');
|
||||
this.$button = this.$container.find('.dropdown-toggle');
|
||||
this.$menu = $(this.options.menu).appendTo('body');
|
||||
this.matcher = this.options.matcher || this.matcher;
|
||||
this.sorter = this.options.sorter || this.sorter;
|
||||
this.highlighter = this.options.highlighter || this.highlighter;
|
||||
this.shown = false;
|
||||
this.selected = false;
|
||||
this.refresh();
|
||||
this.transferAttributes();
|
||||
this.listen();
|
||||
};
|
||||
|
||||
Combobox.prototype = {
|
||||
|
||||
constructor: Combobox
|
||||
|
||||
, setup: function () {
|
||||
var combobox = $(this.options.template);
|
||||
this.$source.before(combobox);
|
||||
this.$source.hide();
|
||||
return combobox;
|
||||
}
|
||||
|
||||
, parse: function () {
|
||||
var that = this
|
||||
, map = {}
|
||||
, source = []
|
||||
, selected = false
|
||||
, selectedValue = '';
|
||||
this.$source.find('option').each(function() {
|
||||
var option = $(this);
|
||||
if (option.val() === '') {
|
||||
that.options.placeholder = option.text();
|
||||
return;
|
||||
}
|
||||
map[option.text()] = option.val();
|
||||
source.push(option.text());
|
||||
if (option.prop('selected')) {
|
||||
selected = option.text();
|
||||
selectedValue = option.val();
|
||||
}
|
||||
})
|
||||
this.map = map;
|
||||
if (selected) {
|
||||
this.$element.val(selected);
|
||||
this.$target.val(selectedValue);
|
||||
this.$container.addClass('combobox-selected');
|
||||
this.selected = true;
|
||||
}
|
||||
return source;
|
||||
}
|
||||
|
||||
, transferAttributes: function() {
|
||||
this.options.placeholder = this.$source.attr('data-placeholder') || this.options.placeholder;
|
||||
this.$element.attr('placeholder', this.options.placeholder);
|
||||
this.$target.prop('name', this.$source.prop('name'));
|
||||
this.$target.val(this.$source.val());
|
||||
this.$source.removeAttr('name'); // Remove from source otherwise form will pass parameter twice.
|
||||
this.$element.attr('required', this.$source.attr('required'));
|
||||
this.$element.attr('rel', this.$source.attr('rel'));
|
||||
this.$element.attr('title', this.$source.attr('title'));
|
||||
this.$element.attr('class', this.$source.attr('class'));
|
||||
this.$element.attr('tabindex', this.$source.attr('tabindex'));
|
||||
this.$source.removeAttr('tabindex');
|
||||
this.$source.removeAttr('required');
|
||||
}
|
||||
|
||||
, setSelected: function() {
|
||||
this.selected = true;
|
||||
}
|
||||
|
||||
, select: function () {
|
||||
var val = this.$menu.find('.active').attr('data-value');
|
||||
this.$element.val(this.updater(val));
|
||||
this.$target.val(this.map[val]);
|
||||
this.$source.val(this.map[val]);
|
||||
this.$element.trigger('change');
|
||||
this.$target.trigger('change');
|
||||
this.$source.trigger('change');
|
||||
this.$container.addClass('combobox-selected');
|
||||
this.selected = true;
|
||||
return this.hide();
|
||||
}
|
||||
|
||||
, updater: function (item) {
|
||||
return item;
|
||||
}
|
||||
|
||||
, show: function () {
|
||||
var pos = $.extend({}, this.$element.position(), {
|
||||
height: this.$element[0].offsetHeight
|
||||
});
|
||||
|
||||
this.$menu
|
||||
.insertAfter(this.$element)
|
||||
.css({
|
||||
top: pos.top + pos.height
|
||||
, left: pos.left
|
||||
})
|
||||
.show();
|
||||
|
||||
this.shown = true;
|
||||
return this;
|
||||
}
|
||||
|
||||
, hide: function () {
|
||||
this.$menu.hide();
|
||||
this.shown = false;
|
||||
return this;
|
||||
}
|
||||
|
||||
, lookup: function (event) {
|
||||
this.query = this.$element.val();
|
||||
return this.process(this.source);
|
||||
}
|
||||
|
||||
, process: function (items) {
|
||||
var that = this;
|
||||
|
||||
items = $.grep(items, function (item) {
|
||||
return that.matcher(item);
|
||||
})
|
||||
|
||||
items = this.sorter(items);
|
||||
|
||||
if (!items.length) {
|
||||
return this.shown ? this.hide() : this;
|
||||
}
|
||||
|
||||
return this.render(items.slice(0, this.options.items)).show();
|
||||
}
|
||||
|
||||
, matcher: function (item) {
|
||||
return ~item.toLowerCase().indexOf(this.query.toLowerCase());
|
||||
}
|
||||
|
||||
, sorter: function (items) {
|
||||
var beginswith = []
|
||||
, caseSensitive = []
|
||||
, caseInsensitive = []
|
||||
, item;
|
||||
|
||||
while (item = items.shift()) {
|
||||
if (!item.toLowerCase().indexOf(this.query.toLowerCase())) {beginswith.push(item);}
|
||||
else if (~item.indexOf(this.query)) {caseSensitive.push(item);}
|
||||
else {caseInsensitive.push(item);}
|
||||
}
|
||||
|
||||
return beginswith.concat(caseSensitive, caseInsensitive);
|
||||
}
|
||||
|
||||
, highlighter: function (item) {
|
||||
var query = this.query.replace(/[\-\[\]{}()*+?.,\\\^$|#\s]/g, '\\$&');
|
||||
return item.replace(new RegExp('(' + query + ')', 'ig'), function ($1, match) {
|
||||
return '<strong>' + match + '</strong>';
|
||||
})
|
||||
}
|
||||
|
||||
, render: function (items) {
|
||||
var that = this;
|
||||
|
||||
items = $(items).map(function (i, item) {
|
||||
i = $(that.options.item).attr('data-value', item);
|
||||
i.find('a').html(that.highlighter(item));
|
||||
return i[0];
|
||||
})
|
||||
|
||||
items.first().addClass('active');
|
||||
this.$menu.html(items);
|
||||
return this;
|
||||
}
|
||||
|
||||
, next: function (event) {
|
||||
var active = this.$menu.find('.active').removeClass('active')
|
||||
, next = active.next();
|
||||
|
||||
if (!next.length) {
|
||||
next = $(this.$menu.find('li')[0]);
|
||||
}
|
||||
|
||||
next.addClass('active');
|
||||
}
|
||||
|
||||
, prev: function (event) {
|
||||
var active = this.$menu.find('.active').removeClass('active')
|
||||
, prev = active.prev();
|
||||
|
||||
if (!prev.length) {
|
||||
prev = this.$menu.find('li').last();
|
||||
}
|
||||
|
||||
prev.addClass('active');
|
||||
}
|
||||
|
||||
, toggle: function () {
|
||||
if (this.$container.hasClass('combobox-selected')) {
|
||||
this.clearTarget();
|
||||
this.triggerChange();
|
||||
this.clearElement();
|
||||
} else {
|
||||
if (this.shown) {
|
||||
this.hide();
|
||||
} else {
|
||||
this.clearElement();
|
||||
this.lookup();
|
||||
}
|
||||
}
|
||||
|
||||
this.$element.trigger('change');
|
||||
this.$target.trigger('change');
|
||||
this.$source.trigger('change');
|
||||
}
|
||||
|
||||
, clearElement: function () {
|
||||
this.$element.val('').focus();
|
||||
}
|
||||
|
||||
, clearTarget: function () {
|
||||
this.$source.val('');
|
||||
this.$target.val('');
|
||||
this.$container.removeClass('combobox-selected');
|
||||
this.selected = false;
|
||||
}
|
||||
|
||||
, triggerChange: function () {
|
||||
this.$source.trigger('change');
|
||||
}
|
||||
|
||||
, refresh: function () {
|
||||
this.source = this.parse();
|
||||
this.options.items = this.source.length;
|
||||
}
|
||||
|
||||
, listen: function () {
|
||||
this.$element
|
||||
.on('focus', $.proxy(this.focus, this))
|
||||
.on('blur', $.proxy(this.blur, this))
|
||||
.on('keypress', $.proxy(this.keypress, this))
|
||||
.on('keyup', $.proxy(this.keyup, this));
|
||||
|
||||
if (this.eventSupported('keydown')) {
|
||||
this.$element.on('keydown', $.proxy(this.keydown, this));
|
||||
}
|
||||
|
||||
this.$menu
|
||||
.on('click', $.proxy(this.click, this))
|
||||
.on('mouseenter', 'li', $.proxy(this.mouseenter, this))
|
||||
.on('mouseleave', 'li', $.proxy(this.mouseleave, this));
|
||||
|
||||
this.$button
|
||||
.on('click', $.proxy(this.toggle, this));
|
||||
}
|
||||
|
||||
, eventSupported: function(eventName) {
|
||||
var isSupported = eventName in this.$element;
|
||||
if (!isSupported) {
|
||||
this.$element.setAttribute(eventName, 'return;');
|
||||
isSupported = typeof this.$element[eventName] === 'function';
|
||||
}
|
||||
return isSupported;
|
||||
}
|
||||
|
||||
, move: function (e) {
|
||||
if (!this.shown) {return;}
|
||||
|
||||
switch(e.keyCode) {
|
||||
case 9: // tab
|
||||
case 13: // enter
|
||||
case 27: // escape
|
||||
e.preventDefault();
|
||||
break;
|
||||
|
||||
case 38: // up arrow
|
||||
e.preventDefault();
|
||||
this.prev();
|
||||
break;
|
||||
|
||||
case 40: // down arrow
|
||||
e.preventDefault();
|
||||
this.next();
|
||||
break;
|
||||
}
|
||||
|
||||
e.stopPropagation();
|
||||
}
|
||||
|
||||
, keydown: function (e) {
|
||||
this.suppressKeyPressRepeat = ~$.inArray(e.keyCode, [40,38,9,13,27]);
|
||||
this.move(e);
|
||||
}
|
||||
|
||||
, keypress: function (e) {
|
||||
if (this.suppressKeyPressRepeat) {return;}
|
||||
this.move(e);
|
||||
}
|
||||
|
||||
, keyup: function (e) {
|
||||
switch(e.keyCode) {
|
||||
case 40: // down arrow
|
||||
case 39: // right arrow
|
||||
case 38: // up arrow
|
||||
case 37: // left arrow
|
||||
case 36: // home
|
||||
case 35: // end
|
||||
case 33: // page up
|
||||
case 34: // page down
|
||||
case 16: // shift
|
||||
case 17: // ctrl
|
||||
case 18: // alt
|
||||
case 20: // cap lock
|
||||
break;
|
||||
|
||||
case 9: // tab
|
||||
case 13: // enter
|
||||
if (!this.shown) {return;}
|
||||
this.select();
|
||||
break;
|
||||
|
||||
case 27: // escape
|
||||
if (!this.shown) {return;}
|
||||
this.hide();
|
||||
break;
|
||||
|
||||
default:
|
||||
this.clearTarget();
|
||||
this.lookup();
|
||||
}
|
||||
|
||||
e.stopPropagation();
|
||||
e.preventDefault();
|
||||
}
|
||||
|
||||
, focus: function (e) {
|
||||
this.focused = true;
|
||||
}
|
||||
|
||||
, blur: function (e) {
|
||||
var that = this;
|
||||
this.focused = false;
|
||||
var val = this.$element.val();
|
||||
if (!this.selected && val !== '' ) {
|
||||
this.$element.val('');
|
||||
this.$source.val('').trigger('change');
|
||||
this.$target.val('').trigger('change');
|
||||
}
|
||||
if (!this.mousedover && this.shown) {setTimeout(function () { that.hide(); }, 200);}
|
||||
}
|
||||
|
||||
, click: function (e) {
|
||||
e.stopPropagation();
|
||||
e.preventDefault();
|
||||
this.select();
|
||||
this.$element.focus();
|
||||
}
|
||||
|
||||
, mouseenter: function (e) {
|
||||
this.mousedover = true;
|
||||
this.$menu.find('.active').removeClass('active');
|
||||
$(e.currentTarget).addClass('active');
|
||||
}
|
||||
|
||||
, mouseleave: function (e) {
|
||||
this.mousedover = false;
|
||||
}
|
||||
};
|
||||
|
||||
/* COMBOBOX PLUGIN DEFINITION
|
||||
* =========================== */
|
||||
|
||||
$.fn.combobox = function ( option ) {
|
||||
return this.each(function () {
|
||||
var $this = $(this)
|
||||
, data = $this.data('combobox')
|
||||
, options = typeof option == 'object' && option;
|
||||
if(!data) {$this.data('combobox', (data = new Combobox(this, options)));}
|
||||
if (typeof option == 'string') {data[option]();}
|
||||
});
|
||||
};
|
||||
|
||||
$.fn.combobox.defaults = {
|
||||
template: '<div class="combobox-container"> <input type="hidden" /> <div class="input-group"> <input type="text" autocomplete="off" /> <span class="input-group-addon dropdown-toggle" data-dropdown="dropdown"> <span class="caret" /> <i class="fa fa-times"></i> </span> </div> </div> '
|
||||
, menu: '<ul class="typeahead typeahead-long dropdown-menu"></ul>'
|
||||
, item: '<li><a href="#"></a></li>'
|
||||
};
|
||||
|
||||
$.fn.combobox.Constructor = Combobox;
|
||||
|
||||
}( window.jQuery );
|
2
public/js/bootstrap-combobox.min.js
vendored
Executable file
1
public/js/bootstrap-combobox.min.js.map
Normal file
219
public/js/bootstrap.js
vendored
@ -1,219 +0,0 @@
|
||||
/* ========================================================================
|
||||
* Bootstrap: collapse.js v3.1.1
|
||||
* http://getbootstrap.com/javascript/#collapse
|
||||
* ========================================================================
|
||||
* Copyright 2011-2014 Twitter, Inc.
|
||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||
* ======================================================================== */
|
||||
|
||||
|
||||
+function ($) {
|
||||
'use strict';
|
||||
|
||||
// COLLAPSE PUBLIC CLASS DEFINITION
|
||||
// ================================
|
||||
|
||||
var Collapse = function (element, options) {
|
||||
this.$element = $(element)
|
||||
this.options = $.extend({}, Collapse.DEFAULTS, options)
|
||||
this.transitioning = null
|
||||
|
||||
if (this.options.parent) this.$parent = $(this.options.parent)
|
||||
if (this.options.toggle) this.toggle()
|
||||
}
|
||||
|
||||
Collapse.DEFAULTS = {
|
||||
toggle: true
|
||||
}
|
||||
|
||||
Collapse.prototype.dimension = function () {
|
||||
var hasWidth = this.$element.hasClass('width')
|
||||
return hasWidth ? 'width' : 'height'
|
||||
}
|
||||
|
||||
Collapse.prototype.show = function () {
|
||||
if (this.transitioning || this.$element.hasClass('in')) return
|
||||
|
||||
var startEvent = $.Event('show.bs.collapse')
|
||||
this.$element.trigger(startEvent)
|
||||
if (startEvent.isDefaultPrevented()) return
|
||||
|
||||
var actives = this.$parent && this.$parent.find('> .panel > .in')
|
||||
|
||||
if (actives && actives.length) {
|
||||
var hasData = actives.data('bs.collapse')
|
||||
if (hasData && hasData.transitioning) return
|
||||
actives.collapse('hide')
|
||||
hasData || actives.data('bs.collapse', null)
|
||||
}
|
||||
|
||||
var dimension = this.dimension()
|
||||
|
||||
this.$element
|
||||
.removeClass('collapse')
|
||||
.addClass('collapsing')
|
||||
[dimension](0)
|
||||
|
||||
this.transitioning = 1
|
||||
|
||||
var complete = function () {
|
||||
this.$element
|
||||
.removeClass('collapsing')
|
||||
.addClass('collapse in')
|
||||
[dimension]('auto')
|
||||
this.transitioning = 0
|
||||
this.$element.trigger('shown.bs.collapse')
|
||||
}
|
||||
|
||||
if (!$.support.transition) return complete.call(this)
|
||||
|
||||
var scrollSize = $.camelCase(['scroll', dimension].join('-'))
|
||||
|
||||
this.$element
|
||||
.one($.support.transition.end, $.proxy(complete, this))
|
||||
.emulateTransitionEnd(350)
|
||||
[dimension](this.$element[0][scrollSize])
|
||||
}
|
||||
|
||||
Collapse.prototype.hide = function () {
|
||||
if (this.transitioning || !this.$element.hasClass('in')) return
|
||||
|
||||
var startEvent = $.Event('hide.bs.collapse')
|
||||
this.$element.trigger(startEvent)
|
||||
if (startEvent.isDefaultPrevented()) return
|
||||
|
||||
var dimension = this.dimension()
|
||||
|
||||
this.$element
|
||||
[dimension](this.$element[dimension]())
|
||||
[0].offsetHeight
|
||||
|
||||
this.$element
|
||||
.addClass('collapsing')
|
||||
.removeClass('collapse')
|
||||
.removeClass('in')
|
||||
|
||||
this.transitioning = 1
|
||||
|
||||
var complete = function () {
|
||||
this.transitioning = 0
|
||||
this.$element
|
||||
.trigger('hidden.bs.collapse')
|
||||
.removeClass('collapsing')
|
||||
.addClass('collapse')
|
||||
}
|
||||
|
||||
if (!$.support.transition) return complete.call(this)
|
||||
|
||||
this.$element
|
||||
[dimension](0)
|
||||
.one($.support.transition.end, $.proxy(complete, this))
|
||||
.emulateTransitionEnd(350)
|
||||
}
|
||||
|
||||
Collapse.prototype.toggle = function () {
|
||||
this[this.$element.hasClass('in') ? 'hide' : 'show']()
|
||||
}
|
||||
|
||||
|
||||
// COLLAPSE PLUGIN DEFINITION
|
||||
// ==========================
|
||||
|
||||
var old = $.fn.collapse
|
||||
|
||||
$.fn.collapse = function (option) {
|
||||
return this.each(function () {
|
||||
var $this = $(this)
|
||||
var data = $this.data('bs.collapse')
|
||||
var options = $.extend({}, Collapse.DEFAULTS, $this.data(), typeof option == 'object' && option)
|
||||
|
||||
if (!data && options.toggle && option == 'show') option = !option
|
||||
if (!data) $this.data('bs.collapse', (data = new Collapse(this, options)))
|
||||
if (typeof option == 'string') data[option]()
|
||||
})
|
||||
}
|
||||
|
||||
$.fn.collapse.Constructor = Collapse
|
||||
|
||||
|
||||
// COLLAPSE NO CONFLICT
|
||||
// ====================
|
||||
|
||||
$.fn.collapse.noConflict = function () {
|
||||
$.fn.collapse = old
|
||||
return this
|
||||
}
|
||||
|
||||
|
||||
// COLLAPSE DATA-API
|
||||
// =================
|
||||
|
||||
$(document).on('click.bs.collapse.data-api', '[data-toggle=collapse]', function (e) {
|
||||
var $this = $(this), href
|
||||
var target = $this.attr('data-target')
|
||||
|| e.preventDefault()
|
||||
|| (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '') //strip for ie7
|
||||
var $target = $(target)
|
||||
var data = $target.data('bs.collapse')
|
||||
var option = data ? 'toggle' : $this.data()
|
||||
var parent = $this.attr('data-parent')
|
||||
var $parent = parent && $(parent)
|
||||
|
||||
if (!data || !data.transitioning) {
|
||||
if ($parent) $parent.find('[data-toggle=collapse][data-parent="' + parent + '"]').not($this).addClass('collapsed')
|
||||
$this[$target.hasClass('in') ? 'addClass' : 'removeClass']('collapsed')
|
||||
}
|
||||
|
||||
$target.collapse(option)
|
||||
})
|
||||
|
||||
}(jQuery);
|
||||
|
||||
/* ========================================================================
|
||||
* Bootstrap: transition.js v3.1.1
|
||||
* http://getbootstrap.com/javascript/#transitions
|
||||
* ========================================================================
|
||||
* Copyright 2011-2014 Twitter, Inc.
|
||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||
* ======================================================================== */
|
||||
|
||||
|
||||
+function ($) {
|
||||
'use strict';
|
||||
|
||||
// CSS TRANSITION SUPPORT (Shoutout: http://www.modernizr.com/)
|
||||
// ============================================================
|
||||
|
||||
function transitionEnd() {
|
||||
var el = document.createElement('bootstrap')
|
||||
|
||||
var transEndEventNames = {
|
||||
'WebkitTransition' : 'webkitTransitionEnd',
|
||||
'MozTransition' : 'transitionend',
|
||||
'OTransition' : 'oTransitionEnd otransitionend',
|
||||
'transition' : 'transitionend'
|
||||
}
|
||||
|
||||
for (var name in transEndEventNames) {
|
||||
if (el.style[name] !== undefined) {
|
||||
return { end: transEndEventNames[name] }
|
||||
}
|
||||
}
|
||||
|
||||
return false // explicit for ie8 ( ._.)
|
||||
}
|
||||
|
||||
// http://blog.alexmaccaw.com/css-transitions
|
||||
$.fn.emulateTransitionEnd = function (duration) {
|
||||
var called = false, $el = this
|
||||
$(this).one($.support.transition.end, function () { called = true })
|
||||
var callback = function () { if (!called) $($el).trigger($.support.transition.end) }
|
||||
setTimeout(callback, duration)
|
||||
return this
|
||||
}
|
||||
|
||||
$(function () {
|
||||
$.support.transition = transitionEnd()
|
||||
})
|
||||
|
||||
}(jQuery);
|
7
public/js/bootstrap.min.js
vendored
@ -1,7 +0,0 @@
|
||||
/*!
|
||||
* Bootstrap v3.1.1 (http://getbootstrap.com)
|
||||
* Copyright 2011-2014 Twitter, Inc.
|
||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||
*/
|
||||
|
||||
+function(a){"use strict";var b=function(c,d){this.$element=a(c),this.options=a.extend({},b.DEFAULTS,d),this.transitioning=null,this.options.parent&&(this.$parent=a(this.options.parent)),this.options.toggle&&this.toggle()};b.DEFAULTS={toggle:!0},b.prototype.dimension=function(){var a=this.$element.hasClass("width");return a?"width":"height"},b.prototype.show=function(){if(this.transitioning||this.$element.hasClass("in"))return;var b=a.Event("show.bs.collapse");this.$element.trigger(b);if(b.isDefaultPrevented())return;var c=this.$parent&&this.$parent.find("> .panel > .in");if(c&&c.length){var d=c.data("bs.collapse");if(d&&d.transitioning)return;c.collapse("hide"),d||c.data("bs.collapse",null)}var e=this.dimension();this.$element.removeClass("collapse").addClass("collapsing")[e](0),this.transitioning=1;var f=function(){this.$element.removeClass("collapsing").addClass("collapse in")[e]("auto"),this.transitioning=0,this.$element.trigger("shown.bs.collapse")};if(!a.support.transition)return f.call(this);var g=a.camelCase(["scroll",e].join("-"));this.$element.one(a.support.transition.end,a.proxy(f,this)).emulateTransitionEnd(350)[e](this.$element[0][g])},b.prototype.hide=function(){if(this.transitioning||!this.$element.hasClass("in"))return;var b=a.Event("hide.bs.collapse");this.$element.trigger(b);if(b.isDefaultPrevented())return;var c=this.dimension();this.$element[c](this.$element[c]())[0].offsetHeight,this.$element.addClass("collapsing").removeClass("collapse").removeClass("in"),this.transitioning=1;var d=function(){this.transitioning=0,this.$element.trigger("hidden.bs.collapse").removeClass("collapsing").addClass("collapse")};if(!a.support.transition)return d.call(this);this.$element[c](0).one(a.support.transition.end,a.proxy(d,this)).emulateTransitionEnd(350)},b.prototype.toggle=function(){this[this.$element.hasClass("in")?"hide":"show"]()};var c=a.fn.collapse;a.fn.collapse=function(c){return this.each(function(){var d=a(this),e=d.data("bs.collapse"),f=a.extend({},b.DEFAULTS,d.data(),typeof c=="object"&&c);!e&&f.toggle&&c=="show"&&(c=!c),e||d.data("bs.collapse",e=new b(this,f)),typeof c=="string"&&e[c]()})},a.fn.collapse.Constructor=b,a.fn.collapse.noConflict=function(){return a.fn.collapse=c,this},a(document).on("click.bs.collapse.data-api","[data-toggle=collapse]",function(b){var c=a(this),d,e=c.attr("data-target")||b.preventDefault()||(d=c.attr("href"))&&d.replace(/.*(?=#[^\s]+$)/,""),f=a(e),g=f.data("bs.collapse"),h=g?"toggle":c.data(),i=c.attr("data-parent"),j=i&&a(i);if(!g||!g.transitioning)j&&j.find('[data-toggle=collapse][data-parent="'+i+'"]').not(c).addClass("collapsed"),c[f.hasClass("in")?"addClass":"removeClass"]("collapsed");f.collapse(h)})}(jQuery),+function(a){function b(){var a=document.createElement("bootstrap"),b={WebkitTransition:"webkitTransitionEnd",MozTransition:"transitionend",OTransition:"oTransitionEnd otransitionend",transition:"transitionend"};for(var c in b)if(a.style[c]!==undefined)return{end:b[c]};return!1}"use strict",a.fn.emulateTransitionEnd=function(b){var c=!1,d=this;a(this).one(a.support.transition.end,function(){c=!0});var e=function(){c||a(d).trigger(a.support.transition.end)};return setTimeout(e,b),this},a(function(){a.support.transition=b()})}(jQuery)
|
11
public/js/d3.min.js
vendored
1
public/js/d3.min.js.map
Normal file
3
public/js/jquery.datetimepicker.min.js
vendored
Normal file
1
public/js/jquery.datetimepicker.min.js.map
Normal file
44
public/js/jsoneditor.min.js
vendored
140
public/js/jspdf.min.js
vendored
@ -1,297 +0,0 @@
|
||||
/** @preserve
|
||||
jsPDF split_text_to_size plugin
|
||||
Copyright (c) 2012 Willow Systems Corporation, willow-systems.com
|
||||
MIT license.
|
||||
*/
|
||||
/**
|
||||
* 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(API) {
|
||||
'use strict'
|
||||
|
||||
/**
|
||||
Returns an array of length matching length of the 'word' string, with each
|
||||
cell ocupied by the width of the char in that position.
|
||||
|
||||
@function
|
||||
@param word {String}
|
||||
@param widths {Object}
|
||||
@param kerning {Object}
|
||||
@returns {Array}
|
||||
*/
|
||||
var getCharWidthsArray = API.getCharWidthsArray = function(text, options){
|
||||
if (!options) {
|
||||
options = {}
|
||||
}
|
||||
|
||||
var widths = options.widths ? options.widths : this.internal.getFont().metadata.Unicode.widths
|
||||
, widthsFractionOf = widths.fof ? widths.fof : 1
|
||||
, kerning = options.kerning ? options.kerning : this.internal.getFont().metadata.Unicode.kerning
|
||||
, kerningFractionOf = kerning.fof ? kerning.fof : 1
|
||||
|
||||
// console.log("widths, kergnings", widths, kerning)
|
||||
|
||||
var i, l
|
||||
, char_code
|
||||
, char_width
|
||||
, prior_char_code = 0 // for kerning
|
||||
, default_char_width = widths[0] || widthsFractionOf
|
||||
, output = []
|
||||
|
||||
for (i = 0, l = text.length; i < l; i++) {
|
||||
char_code = text.charCodeAt(i)
|
||||
output.push(
|
||||
( widths[char_code] || default_char_width ) / widthsFractionOf +
|
||||
( kerning[char_code] && kerning[char_code][prior_char_code] || 0 ) / kerningFractionOf
|
||||
)
|
||||
prior_char_code = char_code
|
||||
}
|
||||
|
||||
return output
|
||||
}
|
||||
var getArraySum = function(array){
|
||||
var i = array.length
|
||||
, output = 0
|
||||
while(i){
|
||||
;i--;
|
||||
output += array[i]
|
||||
}
|
||||
return output
|
||||
}
|
||||
/**
|
||||
Returns a widths of string in a given font, if the font size is set as 1 point.
|
||||
|
||||
In other words, this is "proportional" value. For 1 unit of font size, the length
|
||||
of the string will be that much.
|
||||
|
||||
Multiply by font size to get actual width in *points*
|
||||
Then divide by 72 to get inches or divide by (72/25.6) to get 'mm' etc.
|
||||
|
||||
@public
|
||||
@function
|
||||
@param
|
||||
@returns {Type}
|
||||
*/
|
||||
var getStringUnitWidth = API.getStringUnitWidth = function(text, options) {
|
||||
return getArraySum(getCharWidthsArray.call(this, text, options))
|
||||
}
|
||||
|
||||
/**
|
||||
returns array of lines
|
||||
*/
|
||||
var splitLongWord = function(word, widths_array, firstLineMaxLen, maxLen){
|
||||
var answer = []
|
||||
|
||||
// 1st, chop off the piece that can fit on the hanging line.
|
||||
var i = 0
|
||||
, l = word.length
|
||||
, workingLen = 0
|
||||
while (i !== l && workingLen + widths_array[i] < firstLineMaxLen){
|
||||
workingLen += widths_array[i]
|
||||
;i++;
|
||||
}
|
||||
// this is first line.
|
||||
answer.push(word.slice(0, i))
|
||||
|
||||
// 2nd. Split the rest into maxLen pieces.
|
||||
var startOfLine = i
|
||||
workingLen = 0
|
||||
while (i !== l){
|
||||
if (workingLen + widths_array[i] > maxLen) {
|
||||
answer.push(word.slice(startOfLine, i))
|
||||
workingLen = 0
|
||||
startOfLine = i
|
||||
}
|
||||
workingLen += widths_array[i]
|
||||
;i++;
|
||||
}
|
||||
if (startOfLine !== i) {
|
||||
answer.push(word.slice(startOfLine, i))
|
||||
}
|
||||
|
||||
return answer
|
||||
}
|
||||
|
||||
// Note, all sizing inputs for this function must be in "font measurement units"
|
||||
// By default, for PDF, it's "point".
|
||||
var splitParagraphIntoLines = function(text, maxlen, options){
|
||||
// at this time works only on Western scripts, ones with space char
|
||||
// separating the words. Feel free to expand.
|
||||
|
||||
if (!options) {
|
||||
options = {}
|
||||
}
|
||||
|
||||
var spaceCharWidth = getCharWidthsArray(' ', options)[0]
|
||||
|
||||
var words = text.split(' ')
|
||||
|
||||
var line = []
|
||||
, lines = [line]
|
||||
, line_length = options.textIndent || 0
|
||||
, separator_length = 0
|
||||
, current_word_length = 0
|
||||
, word
|
||||
, widths_array
|
||||
|
||||
var i, l, tmp
|
||||
for (i = 0, l = words.length; i < l; i++) {
|
||||
word = words[i]
|
||||
widths_array = getCharWidthsArray(word, options)
|
||||
current_word_length = getArraySum(widths_array)
|
||||
|
||||
if (line_length + separator_length + current_word_length > maxlen) {
|
||||
if (current_word_length > maxlen) {
|
||||
// this happens when you have space-less long URLs for example.
|
||||
// we just chop these to size. We do NOT insert hiphens
|
||||
tmp = splitLongWord(word, widths_array, maxlen - (line_length + separator_length), maxlen)
|
||||
// first line we add to existing line object
|
||||
line.push(tmp.shift()) // it's ok to have extra space indicator there
|
||||
// last line we make into new line object
|
||||
line = [tmp.pop()]
|
||||
// lines in the middle we apped to lines object as whole lines
|
||||
while(tmp.length){
|
||||
lines.push([tmp.shift()]) // single fragment occupies whole line
|
||||
}
|
||||
current_word_length = getArraySum( widths_array.slice(word.length - line[0].length) )
|
||||
} else {
|
||||
// just put it on a new line
|
||||
line = [word]
|
||||
}
|
||||
|
||||
// now we attach new line to lines
|
||||
lines.push(line)
|
||||
|
||||
line_length = current_word_length
|
||||
separator_length = spaceCharWidth
|
||||
|
||||
} else {
|
||||
line.push(word)
|
||||
|
||||
line_length += separator_length + current_word_length
|
||||
separator_length = spaceCharWidth
|
||||
}
|
||||
}
|
||||
|
||||
var output = []
|
||||
for (i = 0, l = lines.length; i < l; i++) {
|
||||
output.push( lines[i].join(' ') )
|
||||
}
|
||||
return output
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
Splits a given string into an array of strings. Uses 'size' value
|
||||
(in measurement units declared as default for the jsPDF instance)
|
||||
and the font's "widths" and "Kerning" tables, where availabe, to
|
||||
determine display length of a given string for a given font.
|
||||
|
||||
We use character's 100% of unit size (height) as width when Width
|
||||
table or other default width is not available.
|
||||
|
||||
@public
|
||||
@function
|
||||
@param text {String} Unencoded, regular JavaScript (Unicode, UTF-16 / UCS-2) string.
|
||||
@param size {Number} Nominal number, measured in units default to this instance of jsPDF.
|
||||
@param options {Object} Optional flags needed for chopper to do the right thing.
|
||||
@returns {Array} with strings chopped to size.
|
||||
*/
|
||||
API.splitTextToSize = function(text, maxlen, options) {
|
||||
'use strict'
|
||||
|
||||
if (!options) {
|
||||
options = {}
|
||||
}
|
||||
|
||||
var fsize = options.fontSize || this.internal.getFontSize()
|
||||
, newOptions = (function(options){
|
||||
var widths = {0:1}
|
||||
, kerning = {}
|
||||
|
||||
if (!options.widths || !options.kerning) {
|
||||
var f = this.internal.getFont(options.fontName, options.fontStyle)
|
||||
, encoding = 'Unicode'
|
||||
// NOT UTF8, NOT UTF16BE/LE, NOT UCS2BE/LE
|
||||
// Actual JavaScript-native String's 16bit char codes used.
|
||||
// no multi-byte logic here
|
||||
|
||||
if (f.metadata[encoding]) {
|
||||
return {
|
||||
widths: f.metadata[encoding].widths || widths
|
||||
, kerning: f.metadata[encoding].kerning || kerning
|
||||
}
|
||||
}
|
||||
} else {
|
||||
return {
|
||||
widths: options.widths
|
||||
, kerning: options.kerning
|
||||
}
|
||||
}
|
||||
|
||||
// then use default values
|
||||
return {
|
||||
widths: widths
|
||||
, kerning: kerning
|
||||
}
|
||||
}).call(this, options)
|
||||
|
||||
// first we split on end-of-line chars
|
||||
var paragraphs
|
||||
if (text.match(/[\n\r]/)) {
|
||||
paragraphs = text.split(/\r\n|\r|\n/g)
|
||||
} else {
|
||||
paragraphs = [text]
|
||||
}
|
||||
|
||||
// now we convert size (max length of line) into "font size units"
|
||||
// at present time, the "font size unit" is always 'point'
|
||||
// 'proportional' means, "in proportion to font size"
|
||||
var fontUnit_maxLen = 1.0 * this.internal.scaleFactor * maxlen / fsize
|
||||
// at this time, fsize is always in "points" regardless of the default measurement unit of the doc.
|
||||
// this may change in the future?
|
||||
// until then, proportional_maxlen is likely to be in 'points'
|
||||
|
||||
// If first line is to be indented (shorter or longer) than maxLen
|
||||
// we indicate that by using CSS-style "text-indent" option.
|
||||
// here it's in font units too (which is likely 'points')
|
||||
// it can be negative (which makes the first line longer than maxLen)
|
||||
newOptions.textIndent = options.textIndent ?
|
||||
options.textIndent * 1.0 * this.internal.scaleFactor / fsize :
|
||||
0
|
||||
|
||||
var i, l
|
||||
, output = []
|
||||
for (i = 0, l = paragraphs.length; i < l; i++) {
|
||||
output = output.concat(
|
||||
splitParagraphIntoLines(
|
||||
paragraphs[i]
|
||||
, fontUnit_maxLen
|
||||
, newOptions
|
||||
)
|
||||
)
|
||||
}
|
||||
|
||||
return output
|
||||
}
|
||||
|
||||
})(jsPDF.API);
|
11
public/js/lightbox.min.js
vendored
1
public/js/lightbox.min.js.map
Normal file
2
public/js/pdf.min.js
vendored
Normal file
@ -0,0 +1,2 @@
|
||||
"undefined"==typeof PDFJS&&(("undefined"!=typeof window?window:this).PDFJS={}),function(){"use strict"}.call("undefined"==typeof window?this:window),PDFJS.workerSrc||"undefined"==typeof document||(PDFJS.workerSrc=function(){"use strict";var e=document.body||document.getElementsByTagName("head")[0],n=e.lastChild.src;return n&&n.replace(/\.js$/i,".worker.js")}());
|
||||
//# sourceMappingURL=pdf.min.js.map
|
1
public/js/pdf.min.js.map
Normal file
@ -0,0 +1 @@
|
||||
{"version":3,"sources":["pdf.js"],"names":["PDFJS","window","this","call","workerSrc","document","scriptTagContainer","body","getElementsByTagName","pdfjsSrc","lastChild","src","replace"],"mappings":"AAkBA,mBAAAA,UACA,mBAAAC,QAAAA,OAAAC,MAAAF,UAUA,WAEA,cAIAG,KAAA,mBAAAF,QAAAC,KAAAD,QAGAD,MAAAI,WAAA,mBAAAC,YAEAL,MAAAI,UAAA,WACA,YACA,IAAAE,GAAAD,SAAAE,MACAF,SAAAG,qBAAA,QAAA,GACAC,EAAAH,EAAAI,UAAAC,GACA,OAAAF,IAAAA,EAAAG,QAAA,SAAA","file":"pdf.min.js","sourcesContent":["/* -*- Mode: Java; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */\n/* vim: set shiftwidth=2 tabstop=2 autoindent cindent expandtab: */\n/* Copyright 2012 Mozilla Foundation\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n// Initializing PDFJS global object (if still undefined)\nif (typeof PDFJS === 'undefined') {\n (typeof window !== 'undefined' ? window : this).PDFJS = {};\n}\n\n//#if BUNDLE_VERSION\n//#expand PDFJS.version = '__BUNDLE_VERSION__';\n//#endif\n//#if BUNDLE_BUILD\n//#expand PDFJS.build = '__BUNDLE_BUILD__';\n//#endif\n\n(function pdfjsWrapper() {\n // Use strict in our context only - users might not want it\n 'use strict';\n\n//#expand __BUNDLE__\n\n}).call((typeof window === 'undefined') ? this : window);\n\n//#if !(MOZCENTRAL || FIREFOX)\nif (!PDFJS.workerSrc && typeof document !== 'undefined') {\n // workerSrc is not set -- using last script url to define default location\n PDFJS.workerSrc = (function () {\n 'use strict';\n var scriptTagContainer = document.body ||\n document.getElementsByTagName('head')[0];\n var pdfjsSrc = scriptTagContainer.lastChild.src;\n return pdfjsSrc && pdfjsSrc.replace(/\\.js$/i, '.worker.js');\n })();\n}\n//#endif\n"],"sourceRoot":"/source/"}
|
1
public/js/pdf_viewer.worker.js.map
Normal file
66368
public/js/pdfmake.js
17
public/js/pdfmake.min.js
vendored
14
public/js/quill.min.js
vendored
1
public/js/quill.min.js.map
Normal file
10
public/js/retina-1.1.0.min.js
vendored
@ -1,10 +0,0 @@
|
||||
/*!
|
||||
* Retina.js v1.1.0
|
||||
*
|
||||
* Copyright 2013 Imulus, LLC
|
||||
* Released under the MIT license
|
||||
*
|
||||
* Retina.js is an open source script that makes it easy to serve
|
||||
* high-resolution images to devices with retina displays.
|
||||
*/
|
||||
(function(){var root=typeof exports=="undefined"?window:exports;var config={check_mime_type:true};root.Retina=Retina;function Retina(){}Retina.configure=function(options){if(options==null)options={};for(var prop in options)config[prop]=options[prop]};Retina.init=function(context){if(context==null)context=root;var existing_onload=context.onload||new Function;context.onload=function(){var images=document.getElementsByTagName("img"),retinaImages=[],i,image;for(i=0;i<images.length;i++){image=images[i];retinaImages.push(new RetinaImage(image))}existing_onload()}};Retina.isRetina=function(){var mediaQuery="(-webkit-min-device-pixel-ratio: 1.5), (min--moz-device-pixel-ratio: 1.5), (-o-min-device-pixel-ratio: 3/2), (min-resolution: 1.5dppx)";if(root.devicePixelRatio>1)return true;if(root.matchMedia&&root.matchMedia(mediaQuery).matches)return true;return false};root.RetinaImagePath=RetinaImagePath;function RetinaImagePath(path,at_2x_path){this.path=path;if(typeof at_2x_path!=="undefined"&&at_2x_path!==null){this.at_2x_path=at_2x_path;this.perform_check=false}else{this.at_2x_path=path.replace(/\.\w+$/,function(match){return"@2x"+match});this.perform_check=true}}RetinaImagePath.confirmed_paths=[];RetinaImagePath.prototype.is_external=function(){return!!(this.path.match(/^https?\:/i)&&!this.path.match("//"+document.domain))};RetinaImagePath.prototype.check_2x_variant=function(callback){var http,that=this;if(this.is_external()){return callback(false)}else if(!this.perform_check&&typeof this.at_2x_path!=="undefined"&&this.at_2x_path!==null){return callback(true)}else if(this.at_2x_path in RetinaImagePath.confirmed_paths){return callback(true)}else{http=new XMLHttpRequest;http.open("HEAD",this.at_2x_path);http.onreadystatechange=function(){if(http.readyState!=4){return callback(false)}if(http.status>=200&&http.status<=399){if(config.check_mime_type){var type=http.getResponseHeader("Content-Type");if(type==null||!type.match(/^image/i)){return callback(false)}}RetinaImagePath.confirmed_paths.push(that.at_2x_path);return callback(true)}else{return callback(false)}};http.send()}};function RetinaImage(el){this.el=el;this.path=new RetinaImagePath(this.el.getAttribute("src"),this.el.getAttribute("data-at2x"));var that=this;this.path.check_2x_variant(function(hasVariant){if(hasVariant)that.swap()})}root.RetinaImage=RetinaImage;RetinaImage.prototype.swap=function(path){if(typeof path=="undefined")path=this.path.at_2x_path;var that=this;function load(){if(!that.el.complete){setTimeout(load,5)}else{that.el.setAttribute("width",that.el.offsetWidth);that.el.setAttribute("height",that.el.offsetHeight);that.el.setAttribute("src",path)}}load()};if(Retina.isRetina()){Retina.init(root)}})();
|
@ -1,4 +0,0 @@
|
||||
/* Copyright (C) 2012 Sylvain Hamel
|
||||
Project: https://github.com/redhotsly/simple-expand
|
||||
MIT Licence: https://raw.github.com/redhotsly/simple-expand/master/licence-mit.txt */
|
||||
(function($){"use strict";function SimpleExpand(){var that=this;that.defaults={hideMode:"fadeToggle",defaultSearchMode:"parent",defaultTarget:".content",throwOnMissingTarget:true,keepStateInCookie:false,cookieName:"simple-expand"};that.settings={};$.extend(that.settings,that.defaults);that.findLevelOneDeep=function(parent,filterSelector,stopAtSelector){return parent.find(filterSelector).filter(function(){return!$(this).parentsUntil(parent,stopAtSelector).length})};that.setInitialState=function(expander,targets){var isExpanded=that.readState(expander);if(isExpanded){expander.removeClass("collapsed").addClass("expanded");that.show(targets)}else{expander.removeClass("expanded").addClass("collapsed");that.hide(targets)}};that.hide=function(targets){if(that.settings.hideMode==="fadeToggle"){targets.hide()}else if(that.settings.hideMode==="basic"){targets.hide()}};that.show=function(targets){if(that.settings.hideMode==="fadeToggle"){targets.show()}else if(that.settings.hideMode==="basic"){targets.show()}};that.checkKeepStateInCookiePreconditions=function(){if(that.settings.keepStateInCookie&&$.cookie===undefined){throw new Error("simple-expand: keepStateInCookie option requires $.cookie to be defined.")}};that.readCookie=function(){var jsonString=$.cookie(that.settings.cookieName);if(jsonString===null||jsonString===""){return{}}else{return JSON.parse(jsonString)}};that.readState=function(expander){if(!that.settings.keepStateInCookie){return expander.hasClass("expanded")}var id=expander.attr("Id");if(id===undefined){return}var cookie=that.readCookie();var cookieValue=cookie[id];if(typeof cookieValue!=="undefined"){return cookie[id]===true}else{return expander.hasClass("expanded")}};that.saveState=function(expander,isExpanded){if(!that.settings.keepStateInCookie){return}var id=expander.attr("Id");if(id===undefined){return}var cookie=that.readCookie();cookie[id]=isExpanded;$.cookie(that.settings.cookieName,JSON.stringify(cookie),{raw:true,path:window.location.pathname})};that.toggle=function(expander,targets){var isExpanded=that.toggleCss(expander);if(that.settings.hideMode==="fadeToggle"){targets.fadeToggle(150)}else if(that.settings.hideMode==="basic"){targets.toggle()}else if($.isFunction(that.settings.hideMode)){that.settings.hideMode(expander,targets,isExpanded)}that.saveState(expander,isExpanded);return false};that.toggleCss=function(expander){if(expander.hasClass("expanded")){expander.toggleClass("collapsed expanded");return false}else{expander.toggleClass("expanded collapsed");return true}};that.findTargets=function(expander,searchMode,targetSelector){var targets=[];if(searchMode==="absolute"){targets=$(targetSelector)}else if(searchMode==="relative"){targets=that.findLevelOneDeep(expander,targetSelector,targetSelector)}else if(searchMode==="parent"){var parent=expander.parent();do{targets=that.findLevelOneDeep(parent,targetSelector,targetSelector);if(targets.length===0){parent=parent.parent()}}while(targets.length===0&&parent.length!==0)}return targets};that.activate=function(jquery,options){$.extend(that.settings,options);that.checkKeepStateInCookiePreconditions();jquery.each(function(){var expander=$(this);var targetSelector=expander.attr("data-expander-target")||that.settings.defaultTarget;var searchMode=expander.attr("data-expander-target-search")||that.settings.defaultSearchMode;var targets=that.findTargets(expander,searchMode,targetSelector);if(targets.length===0){if(that.settings.throwOnMissingTarget){throw"simple-expand: Targets not found"}return this}that.setInitialState(expander,targets);expander.click(function(){return that.toggle(expander,targets)})})}}window.SimpleExpand=SimpleExpand;$.fn.simpleexpand=function(options){var instance=new SimpleExpand;instance.activate(this,options);return this}})(jQuery);
|
@ -1,485 +0,0 @@
|
||||
// Domain Public by Eric Wendelin http://eriwen.com/ (2008)
|
||||
// Luke Smith http://lucassmith.name/ (2008)
|
||||
// Loic Dachary <loic@dachary.org> (2008)
|
||||
// Johan Euphrosine <proppy@aminche.com> (2008)
|
||||
// Oyvind Sean Kinsey http://kinsey.no/blog (2010)
|
||||
// Victor Homyakov <victor-homyakov@users.sourceforge.net> (2010)
|
||||
/*global module, exports, define, ActiveXObject*/
|
||||
(function(global, factory) {
|
||||
if (typeof exports === 'object') {
|
||||
// Node
|
||||
module.exports = factory();
|
||||
} else if (typeof define === 'function' && define.amd) {
|
||||
// AMD
|
||||
define(factory);
|
||||
} else {
|
||||
// Browser globals
|
||||
global.printStackTrace = factory();
|
||||
}
|
||||
}(this, function() {
|
||||
/**
|
||||
* Main function giving a function stack trace with a forced or passed in Error
|
||||
*
|
||||
* @cfg {Error} e The error to create a stacktrace from (optional)
|
||||
* @cfg {Boolean} guess If we should try to resolve the names of anonymous functions
|
||||
* @return {Array} of Strings with functions, lines, files, and arguments where possible
|
||||
*/
|
||||
function printStackTrace(options) {
|
||||
options = options || {guess: true};
|
||||
var ex = options.e || null, guess = !!options.guess;
|
||||
var p = new printStackTrace.implementation(), result = p.run(ex);
|
||||
return (guess) ? p.guessAnonymousFunctions(result) : result;
|
||||
}
|
||||
|
||||
printStackTrace.implementation = function() {
|
||||
};
|
||||
|
||||
printStackTrace.implementation.prototype = {
|
||||
/**
|
||||
* @param {Error} [ex] The error to create a stacktrace from (optional)
|
||||
* @param {String} [mode] Forced mode (optional, mostly for unit tests)
|
||||
*/
|
||||
run: function(ex, mode) {
|
||||
ex = ex || this.createException();
|
||||
mode = mode || this.mode(ex);
|
||||
if (mode === 'other') {
|
||||
return this.other(arguments.callee);
|
||||
} else {
|
||||
return this[mode](ex);
|
||||
}
|
||||
},
|
||||
|
||||
createException: function() {
|
||||
try {
|
||||
this.undef();
|
||||
} catch (e) {
|
||||
return e;
|
||||
}
|
||||
},
|
||||
|
||||
/**
|
||||
* Mode could differ for different exception, e.g.
|
||||
* exceptions in Chrome may or may not have arguments or stack.
|
||||
*
|
||||
* @return {String} mode of operation for the exception
|
||||
*/
|
||||
mode: function(e) {
|
||||
if (e['arguments'] && e.stack) {
|
||||
return 'chrome';
|
||||
}
|
||||
|
||||
if (e.stack && e.sourceURL) {
|
||||
return 'safari';
|
||||
}
|
||||
|
||||
if (e.stack && e.number) {
|
||||
return 'ie';
|
||||
}
|
||||
|
||||
if (e.stack && e.fileName) {
|
||||
return 'firefox';
|
||||
}
|
||||
|
||||
if (e.message && e['opera#sourceloc']) {
|
||||
// e.message.indexOf("Backtrace:") > -1 -> opera9
|
||||
// 'opera#sourceloc' in e -> opera9, opera10a
|
||||
// !e.stacktrace -> opera9
|
||||
if (!e.stacktrace) {
|
||||
return 'opera9'; // use e.message
|
||||
}
|
||||
if (e.message.indexOf('\n') > -1 && e.message.split('\n').length > e.stacktrace.split('\n').length) {
|
||||
// e.message may have more stack entries than e.stacktrace
|
||||
return 'opera9'; // use e.message
|
||||
}
|
||||
return 'opera10a'; // use e.stacktrace
|
||||
}
|
||||
|
||||
if (e.message && e.stack && e.stacktrace) {
|
||||
// e.stacktrace && e.stack -> opera10b
|
||||
if (e.stacktrace.indexOf("called from line") < 0) {
|
||||
return 'opera10b'; // use e.stacktrace, format differs from 'opera10a'
|
||||
}
|
||||
// e.stacktrace && e.stack -> opera11
|
||||
return 'opera11'; // use e.stacktrace, format differs from 'opera10a', 'opera10b'
|
||||
}
|
||||
|
||||
if (e.stack && !e.fileName) {
|
||||
// Chrome 27 does not have e.arguments as earlier versions,
|
||||
// but still does not have e.fileName as Firefox
|
||||
return 'chrome';
|
||||
}
|
||||
|
||||
return 'other';
|
||||
},
|
||||
|
||||
/**
|
||||
* Given a context, function name, and callback function, overwrite it so that it calls
|
||||
* printStackTrace() first with a callback and then runs the rest of the body.
|
||||
*
|
||||
* @param {Object} context of execution (e.g. window)
|
||||
* @param {String} functionName to instrument
|
||||
* @param {Function} callback function to call with a stack trace on invocation
|
||||
*/
|
||||
instrumentFunction: function(context, functionName, callback) {
|
||||
context = context || window;
|
||||
var original = context[functionName];
|
||||
context[functionName] = function instrumented() {
|
||||
callback.call(this, printStackTrace().slice(4));
|
||||
return context[functionName]._instrumented.apply(this, arguments);
|
||||
};
|
||||
context[functionName]._instrumented = original;
|
||||
},
|
||||
|
||||
/**
|
||||
* Given a context and function name of a function that has been
|
||||
* instrumented, revert the function to it's original (non-instrumented)
|
||||
* state.
|
||||
*
|
||||
* @param {Object} context of execution (e.g. window)
|
||||
* @param {String} functionName to de-instrument
|
||||
*/
|
||||
deinstrumentFunction: function(context, functionName) {
|
||||
if (context[functionName].constructor === Function &&
|
||||
context[functionName]._instrumented &&
|
||||
context[functionName]._instrumented.constructor === Function) {
|
||||
context[functionName] = context[functionName]._instrumented;
|
||||
}
|
||||
},
|
||||
|
||||
/**
|
||||
* Given an Error object, return a formatted Array based on Chrome's stack string.
|
||||
*
|
||||
* @param e - Error object to inspect
|
||||
* @return Array<String> of function calls, files and line numbers
|
||||
*/
|
||||
chrome: function(e) {
|
||||
return (e.stack + '\n')
|
||||
.replace(/^[\s\S]+?\s+at\s+/, ' at ') // remove message
|
||||
.replace(/^\s+(at eval )?at\s+/gm, '') // remove 'at' and indentation
|
||||
.replace(/^([^\(]+?)([\n$])/gm, '{anonymous}() ($1)$2')
|
||||
.replace(/^Object.<anonymous>\s*\(([^\)]+)\)/gm, '{anonymous}() ($1)')
|
||||
.replace(/^(.+) \((.+)\)$/gm, '$1@$2')
|
||||
.split('\n')
|
||||
.slice(0, -1);
|
||||
},
|
||||
|
||||
/**
|
||||
* Given an Error object, return a formatted Array based on Safari's stack string.
|
||||
*
|
||||
* @param e - Error object to inspect
|
||||
* @return Array<String> of function calls, files and line numbers
|
||||
*/
|
||||
safari: function(e) {
|
||||
return e.stack.replace(/\[native code\]\n/m, '')
|
||||
.replace(/^(?=\w+Error\:).*$\n/m, '')
|
||||
.replace(/^@/gm, '{anonymous}()@')
|
||||
.split('\n');
|
||||
},
|
||||
|
||||
/**
|
||||
* Given an Error object, return a formatted Array based on IE's stack string.
|
||||
*
|
||||
* @param e - Error object to inspect
|
||||
* @return Array<String> of function calls, files and line numbers
|
||||
*/
|
||||
ie: function(e) {
|
||||
return e.stack
|
||||
.replace(/^\s*at\s+(.*)$/gm, '$1')
|
||||
.replace(/^Anonymous function\s+/gm, '{anonymous}() ')
|
||||
.replace(/^(.+)\s+\((.+)\)$/gm, '$1@$2')
|
||||
.split('\n')
|
||||
.slice(1);
|
||||
},
|
||||
|
||||
/**
|
||||
* Given an Error object, return a formatted Array based on Firefox's stack string.
|
||||
*
|
||||
* @param e - Error object to inspect
|
||||
* @return Array<String> of function calls, files and line numbers
|
||||
*/
|
||||
firefox: function(e) {
|
||||
return e.stack.replace(/(?:\n@:0)?\s+$/m, '')
|
||||
.replace(/^(?:\((\S*)\))?@/gm, '{anonymous}($1)@')
|
||||
.split('\n');
|
||||
},
|
||||
|
||||
opera11: function(e) {
|
||||
var ANON = '{anonymous}', lineRE = /^.*line (\d+), column (\d+)(?: in (.+))? in (\S+):$/;
|
||||
var lines = e.stacktrace.split('\n'), result = [];
|
||||
|
||||
for (var i = 0, len = lines.length; i < len; i += 2) {
|
||||
var match = lineRE.exec(lines[i]);
|
||||
if (match) {
|
||||
var location = match[4] + ':' + match[1] + ':' + match[2];
|
||||
var fnName = match[3] || "global code";
|
||||
fnName = fnName.replace(/<anonymous function: (\S+)>/, "$1").replace(/<anonymous function>/, ANON);
|
||||
result.push(fnName + '@' + location + ' -- ' + lines[i + 1].replace(/^\s+/, ''));
|
||||
}
|
||||
}
|
||||
|
||||
return result;
|
||||
},
|
||||
|
||||
opera10b: function(e) {
|
||||
// "<anonymous function: run>([arguments not available])@file://localhost/G:/js/stacktrace.js:27\n" +
|
||||
// "printStackTrace([arguments not available])@file://localhost/G:/js/stacktrace.js:18\n" +
|
||||
// "@file://localhost/G:/js/test/functional/testcase1.html:15"
|
||||
var lineRE = /^(.*)@(.+):(\d+)$/;
|
||||
var lines = e.stacktrace.split('\n'), result = [];
|
||||
|
||||
for (var i = 0, len = lines.length; i < len; i++) {
|
||||
var match = lineRE.exec(lines[i]);
|
||||
if (match) {
|
||||
var fnName = match[1] ? (match[1] + '()') : "global code";
|
||||
result.push(fnName + '@' + match[2] + ':' + match[3]);
|
||||
}
|
||||
}
|
||||
|
||||
return result;
|
||||
},
|
||||
|
||||
/**
|
||||
* Given an Error object, return a formatted Array based on Opera 10's stacktrace string.
|
||||
*
|
||||
* @param e - Error object to inspect
|
||||
* @return Array<String> of function calls, files and line numbers
|
||||
*/
|
||||
opera10a: function(e) {
|
||||
// " Line 27 of linked script file://localhost/G:/js/stacktrace.js\n"
|
||||
// " Line 11 of inline#1 script in file://localhost/G:/js/test/functional/testcase1.html: In function foo\n"
|
||||
var ANON = '{anonymous}', lineRE = /Line (\d+).*script (?:in )?(\S+)(?:: In function (\S+))?$/i;
|
||||
var lines = e.stacktrace.split('\n'), result = [];
|
||||
|
||||
for (var i = 0, len = lines.length; i < len; i += 2) {
|
||||
var match = lineRE.exec(lines[i]);
|
||||
if (match) {
|
||||
var fnName = match[3] || ANON;
|
||||
result.push(fnName + '()@' + match[2] + ':' + match[1] + ' -- ' + lines[i + 1].replace(/^\s+/, ''));
|
||||
}
|
||||
}
|
||||
|
||||
return result;
|
||||
},
|
||||
|
||||
// Opera 7.x-9.2x only!
|
||||
opera9: function(e) {
|
||||
// " Line 43 of linked script file://localhost/G:/js/stacktrace.js\n"
|
||||
// " Line 7 of inline#1 script in file://localhost/G:/js/test/functional/testcase1.html\n"
|
||||
var ANON = '{anonymous}', lineRE = /Line (\d+).*script (?:in )?(\S+)/i;
|
||||
var lines = e.message.split('\n'), result = [];
|
||||
|
||||
for (var i = 2, len = lines.length; i < len; i += 2) {
|
||||
var match = lineRE.exec(lines[i]);
|
||||
if (match) {
|
||||
result.push(ANON + '()@' + match[2] + ':' + match[1] + ' -- ' + lines[i + 1].replace(/^\s+/, ''));
|
||||
}
|
||||
}
|
||||
|
||||
return result;
|
||||
},
|
||||
|
||||
// Safari 5-, IE 9-, and others
|
||||
other: function(curr) {
|
||||
var ANON = '{anonymous}', fnRE = /function\s*([\w\-$]+)?\s*\(/i, stack = [], fn, args, maxStackSize = 10;
|
||||
var slice = Array.prototype.slice;
|
||||
while (curr && curr['arguments'] && stack.length < maxStackSize) {
|
||||
fn = fnRE.test(curr.toString()) ? RegExp.$1 || ANON : ANON;
|
||||
args = slice.call(curr['arguments'] || []);
|
||||
stack[stack.length] = fn + '(' + this.stringifyArguments(args) + ')';
|
||||
try {
|
||||
curr = curr.caller;
|
||||
} catch (e) {
|
||||
stack[stack.length] = '' + e;
|
||||
break;
|
||||
}
|
||||
}
|
||||
return stack;
|
||||
},
|
||||
|
||||
/**
|
||||
* Given arguments array as a String, substituting type names for non-string types.
|
||||
*
|
||||
* @param {Arguments,Array} args
|
||||
* @return {String} stringified arguments
|
||||
*/
|
||||
stringifyArguments: function(args) {
|
||||
var result = [];
|
||||
var slice = Array.prototype.slice;
|
||||
for (var i = 0; i < args.length; ++i) {
|
||||
var arg = args[i];
|
||||
if (arg === undefined) {
|
||||
result[i] = 'undefined';
|
||||
} else if (arg === null) {
|
||||
result[i] = 'null';
|
||||
} else if (arg.constructor) {
|
||||
// TODO constructor comparison does not work for iframes
|
||||
if (arg.constructor === Array) {
|
||||
if (arg.length < 3) {
|
||||
result[i] = '[' + this.stringifyArguments(arg) + ']';
|
||||
} else {
|
||||
result[i] = '[' + this.stringifyArguments(slice.call(arg, 0, 1)) + '...' + this.stringifyArguments(slice.call(arg, -1)) + ']';
|
||||
}
|
||||
} else if (arg.constructor === Object) {
|
||||
result[i] = '#object';
|
||||
} else if (arg.constructor === Function) {
|
||||
result[i] = '#function';
|
||||
} else if (arg.constructor === String) {
|
||||
result[i] = '"' + arg + '"';
|
||||
} else if (arg.constructor === Number) {
|
||||
result[i] = arg;
|
||||
} else {
|
||||
result[i] = '?';
|
||||
}
|
||||
}
|
||||
}
|
||||
return result.join(',');
|
||||
},
|
||||
|
||||
sourceCache: {},
|
||||
|
||||
/**
|
||||
* @return the text from a given URL
|
||||
*/
|
||||
ajax: function(url) {
|
||||
var req = this.createXMLHTTPObject();
|
||||
if (req) {
|
||||
try {
|
||||
req.open('GET', url, false);
|
||||
//req.overrideMimeType('text/plain');
|
||||
//req.overrideMimeType('text/javascript');
|
||||
req.send(null);
|
||||
//return req.status == 200 ? req.responseText : '';
|
||||
return req.responseText;
|
||||
} catch (e) {
|
||||
}
|
||||
}
|
||||
return '';
|
||||
},
|
||||
|
||||
/**
|
||||
* Try XHR methods in order and store XHR factory.
|
||||
*
|
||||
* @return <Function> XHR function or equivalent
|
||||
*/
|
||||
createXMLHTTPObject: function() {
|
||||
var xmlhttp, XMLHttpFactories = [
|
||||
function() {
|
||||
return new XMLHttpRequest();
|
||||
}, function() {
|
||||
return new ActiveXObject('Msxml2.XMLHTTP');
|
||||
}, function() {
|
||||
return new ActiveXObject('Msxml3.XMLHTTP');
|
||||
}, function() {
|
||||
return new ActiveXObject('Microsoft.XMLHTTP');
|
||||
}
|
||||
];
|
||||
for (var i = 0; i < XMLHttpFactories.length; i++) {
|
||||
try {
|
||||
xmlhttp = XMLHttpFactories[i]();
|
||||
// Use memoization to cache the factory
|
||||
this.createXMLHTTPObject = XMLHttpFactories[i];
|
||||
return xmlhttp;
|
||||
} catch (e) {
|
||||
}
|
||||
}
|
||||
},
|
||||
|
||||
/**
|
||||
* Given a URL, check if it is in the same domain (so we can get the source
|
||||
* via Ajax).
|
||||
*
|
||||
* @param url <String> source url
|
||||
* @return <Boolean> False if we need a cross-domain request
|
||||
*/
|
||||
isSameDomain: function(url) {
|
||||
return typeof location !== "undefined" && url.indexOf(location.hostname) !== -1; // location may not be defined, e.g. when running from nodejs.
|
||||
},
|
||||
|
||||
/**
|
||||
* Get source code from given URL if in the same domain.
|
||||
*
|
||||
* @param url <String> JS source URL
|
||||
* @return <Array> Array of source code lines
|
||||
*/
|
||||
getSource: function(url) {
|
||||
// TODO reuse source from script tags?
|
||||
if (!(url in this.sourceCache)) {
|
||||
this.sourceCache[url] = this.ajax(url).split('\n');
|
||||
}
|
||||
return this.sourceCache[url];
|
||||
},
|
||||
|
||||
guessAnonymousFunctions: function(stack) {
|
||||
for (var i = 0; i < stack.length; ++i) {
|
||||
var reStack = /\{anonymous\}\(.*\)@(.*)/,
|
||||
reRef = /^(.*?)(?::(\d+))(?::(\d+))?(?: -- .+)?$/,
|
||||
frame = stack[i], ref = reStack.exec(frame);
|
||||
|
||||
if (ref) {
|
||||
var m = reRef.exec(ref[1]);
|
||||
if (m) { // If falsey, we did not get any file/line information
|
||||
var file = m[1], lineno = m[2], charno = m[3] || 0;
|
||||
if (file && this.isSameDomain(file) && lineno) {
|
||||
var functionName = this.guessAnonymousFunction(file, lineno, charno);
|
||||
stack[i] = frame.replace('{anonymous}', functionName);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return stack;
|
||||
},
|
||||
|
||||
guessAnonymousFunction: function(url, lineNo, charNo) {
|
||||
var ret;
|
||||
try {
|
||||
ret = this.findFunctionName(this.getSource(url), lineNo);
|
||||
} catch (e) {
|
||||
ret = 'getSource failed with url: ' + url + ', exception: ' + e.toString();
|
||||
}
|
||||
return ret;
|
||||
},
|
||||
|
||||
findFunctionName: function(source, lineNo) {
|
||||
// FIXME findFunctionName fails for compressed source
|
||||
// (more than one function on the same line)
|
||||
// function {name}({args}) m[1]=name m[2]=args
|
||||
var reFunctionDeclaration = /function\s+([^(]*?)\s*\(([^)]*)\)/;
|
||||
// {name} = function ({args}) TODO args capture
|
||||
// /['"]?([0-9A-Za-z_]+)['"]?\s*[:=]\s*function(?:[^(]*)/
|
||||
var reFunctionExpression = /['"]?([$_A-Za-z][$_A-Za-z0-9]*)['"]?\s*[:=]\s*function\b/;
|
||||
// {name} = eval()
|
||||
var reFunctionEvaluation = /['"]?([$_A-Za-z][$_A-Za-z0-9]*)['"]?\s*[:=]\s*(?:eval|new Function)\b/;
|
||||
// Walk backwards in the source lines until we find
|
||||
// the line which matches one of the patterns above
|
||||
var code = "", line, maxLines = Math.min(lineNo, 20), m, commentPos;
|
||||
for (var i = 0; i < maxLines; ++i) {
|
||||
// lineNo is 1-based, source[] is 0-based
|
||||
line = source[lineNo - i - 1];
|
||||
commentPos = line.indexOf('//');
|
||||
if (commentPos >= 0) {
|
||||
line = line.substr(0, commentPos);
|
||||
}
|
||||
// TODO check other types of comments? Commented code may lead to false positive
|
||||
if (line) {
|
||||
code = line + code;
|
||||
m = reFunctionExpression.exec(code);
|
||||
if (m && m[1]) {
|
||||
return m[1];
|
||||
}
|
||||
m = reFunctionDeclaration.exec(code);
|
||||
if (m && m[1]) {
|
||||
//return m[1] + "(" + (m[2] || "") + ")";
|
||||
return m[1];
|
||||
}
|
||||
m = reFunctionEvaluation.exec(code);
|
||||
if (m && m[1]) {
|
||||
return m[1];
|
||||
}
|
||||
}
|
||||
}
|
||||
return '(?)';
|
||||
}
|
||||
};
|
||||
|
||||
return printStackTrace;
|
||||
}));
|
@ -1028,3 +1028,5 @@
|
||||
}());
|
||||
|
||||
}(this));
|
||||
|
||||
//# sourceMappingURL=typedarray.js.map
|
||||
|
1
public/js/typedarray.js.map
Normal file
@ -1,12 +0,0 @@
|
||||
(function ($) {
|
||||
$.fn.vAlign = function() {
|
||||
return this.each(function(i){
|
||||
$(this).children().wrapAll('<div class="nitinh-vAlign" style="position:relative;"></div>');
|
||||
var div = $(this).children('div.nitinh-vAlign');
|
||||
var ph = $(this).innerHeight();
|
||||
var dh = div.height();
|
||||
var mh = (ph - dh) / 2;
|
||||
div.css('top', mh);
|
||||
});
|
||||
};
|
||||
})(jQuery);
|
8061
public/pdf.built.js
1
public/pdf.built.js.map
Normal file
2
public/public.style.min.css
vendored
Normal file
@ -0,0 +1,2 @@
|
||||
body{font-family:Roboto,sans-serif;font-size:14px;background-color:#f8f8f8}html{overflow-y:scroll}.navbar-header{padding-top:4px;padding-bottom:4px}.navbar li a{padding-top:18px;font-weight:500;font-size:15px;font-weight:700;padding-left:20px;padding-right:20px}.navbar{x-moz-box-shadow:0 0 10px 2px rgba(0,0,0,.05);x-webkit-box-shadow:0 0 10px 2px rgba(0,0,0,.05);box-shadow:0 0 10px 2px rgba(0,0,0,.05)}#footer{text-align:center}#footer .top{background:#2e2b2b;font-size:12px;font-weight:900;text-transform:uppercase;padding:40px 0 27px}#footer .top li{display:inline-block;margin:0 30px 10px}#footer .top a{color:#fff;text-decoration:none}#footer .bottom{border-top:1px solid #5f5d5d;background:#211f1f;font-size:11px;font-weight:400;color:#636262;padding:28px 0}#footer .bottom a{color:#636262}#footer .menu-item-31 a:before{content:'';display:inline-block;width:9px;height:15px;background:url(../images/social/facebook.svg) no-repeat;margin:0 6px 0 0;position:relative;top:3px}#footer .menu-item-32 a:before{background:url(../images/social/twitter.svg) no-repeat}#footer .menu-item-32 a:before,#footer .menu-item-33 a:before{content:'';display:inline-block;width:19px;height:16px;margin:0 6px 0 0;position:relative;top:3px}#footer .menu-item-33 a:before{background:url(../images/social/github.png) no-repeat}table.table thead .sorting:after,table.table thead .sorting_asc:after,table.table thead .sorting_asc_disabled:after,table.table thead .sorting_desc:after,table.table thead .sorting_desc_disabled:after{content:''!important}.dataTables_length{padding-left:20px;padding-top:8px}.dataTables_length label{font-weight:500}@media screen and (min-width:700px){#footer .top{padding:27px 0}#footer .bottom{padding:25px 0}}table.dataTable{border-radius:3px;border-collapse:collapse}table.dataTable thead>tr>th,table.invoice-table thead>tr>th{color:#fff}th:first-child{border-radius:3px 0 0 0;border-left:none}th:last-child{border-radius:0 3px 0 0}tr{border:none}td{padding-top:16px!important;padding-bottom:16px!important}th{border-left:1px solid #fff}.table>tbody>tr>td,.table>tbody>tr>th,.table>tfoot>tr>td,.table>tfoot>tr>th,.table>thead>tr>td,.table>thead>tr>th{vertical-align:middle;border-top:none;border-bottom:1px solid #dfe0e1}table.dataTable.no-footer{border-bottom:none}.table-striped>tbody>tr:nth-child(odd)>td,.table-striped>tbody>tr:nth-child(odd)>th{background-color:#fdfdfd}table.table thead .sorting_asc{background:url(../images/sort_asc.png) no-repeat 90% 50%}table.table thead .sorting_desc{background:url(../images/sort_desc.png) no-repeat 90% 50%}table.dataTable thead td,table.dataTable thead th,table.invoice-table thead td,table.invoice-table thead th{padding:12px 10px}table.dataTable tbody td,table.dataTable tbody th{padding:10px}.dataTables_wrapper{padding-top:16px}table.table thead>tr>th{border-bottom-width:0}table td{max-width:250px}.pagination>li:first-child>a,.pagination>li:first-child>span{border-bottom-left-radius:3px;border-top-left-radius:3px}table.data-table thead .sorting{background:url(.) no-repeat 100%}
|
||||
/*# sourceMappingURL=public.style.min.css.map */
|
1
public/public.style.min.css.map
Normal file
BIN
resources/assets/css/img/jsoneditor-icons.png
Normal file
After Width: | Height: | Size: 14 KiB |