├── .gitignore
├── .jshintrc
├── CONTRIBUTING.md
├── Gruntfile.js
├── MIT-LICENSE.txt
├── README.md
├── bower.json
├── dist
├── demos
│ ├── loan_calculator.html
│ ├── purecss.html
│ ├── select_filter.html
│ ├── survey.html
│ ├── twitter_bootstrap.html
│ └── user_manager.html
├── index.html
├── jquery-impromptu.css
├── jquery-impromptu.js
├── jquery-impromptu.min.css
├── jquery-impromptu.min.js
└── themes
│ ├── base.css
│ ├── classic-impromptu.css
│ ├── clean-blue.css
│ ├── ext-blue.css
│ ├── smooth.css
│ └── zoo.css
├── jquery-impromptu.jquery.json
├── package.json
├── src
├── .jshintrc
├── demos
│ ├── loan_calculator.html
│ ├── purecss.html
│ ├── select_filter.html
│ ├── survey.html
│ ├── twitter_bootstrap.html
│ └── user_manager.html
├── index.html
├── jquery-impromptu.css
├── jquery-impromptu.js
└── themes
│ ├── base.css
│ ├── classic-impromptu.css
│ ├── clean-blue.css
│ ├── ext-blue.css
│ ├── smooth.css
│ └── zoo.css
└── test
├── .jshintrc
├── SpecRunner.html
├── jquery-impromptu_spec.js
└── lib
├── jasmine-2.0.3
├── boot.js
├── console.js
├── jasmine-html.js
├── jasmine.css
├── jasmine.js
└── jasmine_favicon.png
├── jasmine-jquery.js
└── jquery.min.js
/.gitignore:
--------------------------------------------------------------------------------
1 | /node_modules/
2 |
--------------------------------------------------------------------------------
/.jshintrc:
--------------------------------------------------------------------------------
1 | {
2 | "curly": true,
3 | "eqeqeq": true,
4 | "immed": true,
5 | "latedef": true,
6 | "newcap": true,
7 | "noarg": true,
8 | "sub": true,
9 | "undef": true,
10 | "unused": true,
11 | "boss": true,
12 | "eqnull": true,
13 | "node": true,
14 | "es5": true
15 | }
16 |
--------------------------------------------------------------------------------
/CONTRIBUTING.md:
--------------------------------------------------------------------------------
1 | # Contributing
2 |
3 | ## Important notes
4 | Please don't edit files in the `dist` subdirectory as they are generated via Grunt. You'll find source code in the `src` subdirectory!
5 |
6 | ### Code style
7 | Regarding code style like indentation and whitespace, **follow the conventions you see used in the source already (tabs).**
8 |
9 | ### PhantomJS
10 | While Grunt can run the included unit tests via [PhantomJS](http://phantomjs.org/), this shouldn't be considered a substitute for the real thing. Please be sure to test the `test/*.html` unit test file(s) in _actual_ browsers.
11 |
12 | ## Modifying the code
13 | First, ensure that you have the latest [Node.js](http://nodejs.org/) and [npm](http://npmjs.org/) installed.
14 |
15 | Test that Grunt's CLI is installed by running `grunt --version`. If the command isn't found, run `npm install -g grunt-cli`. For more information about installing Grunt, see the [getting started guide](http://gruntjs.com/getting-started).
16 |
17 | 1. Fork and clone the repo.
18 | 1. Run `npm install` to install all dependencies (including Grunt).
19 | 1. Run `grunt` to grunt this project.
20 |
21 | Assuming that you don't see any red, you're ready to go. Just be sure to run `grunt` after making any changes, to ensure that nothing is broken.
22 |
23 | ## Submitting pull requests
24 |
25 | 1. Create a new branch, please don't work in your `master` branch directly.
26 | 1. Add failing tests for the change you want to make. Run `grunt` to see the tests fail.
27 | 1. Fix stuff.
28 | 1. Run `grunt` to see if the tests pass. Repeat steps 2-4 until done.
29 | 1. Open `test/*.html` unit test file(s) in actual browser to ensure tests pass everywhere.
30 | 1. Update the documentation to reflect any changes.
31 | 1. Push to your fork and submit a pull request.
32 |
--------------------------------------------------------------------------------
/Gruntfile.js:
--------------------------------------------------------------------------------
1 | 'use strict';
2 |
3 | module.exports = function(grunt) {
4 |
5 | // Project configuration.
6 | grunt.initConfig({
7 |
8 | // Metadata.
9 | pkg: grunt.file.readJSON('jquery-impromptu.jquery.json'),
10 | banner: '/*! <%= pkg.title || pkg.name %> - v<%= pkg.version %>' +
11 | //' - <%= grunt.template.today("yyyy-mm-dd") %>\n' +
12 | ' - <%= pkg.modified %>\n' +
13 | '<%= pkg.homepage ? "* " + pkg.homepage + "\\n" : "" %>' +
14 | '* Copyright (c) <%= grunt.template.today("yyyy") %> <%= pkg.author.name %>;' +
15 | ' Licensed <%= _.pluck(pkg.licenses, "type").join(", ") %> */\n',
16 |
17 | // Task configuration.
18 | clean: {
19 | files: ['dist']
20 | },
21 | copy: {
22 | dist: {
23 | files: [
24 | { src: 'src/index.html', dest: 'dist/index.html' },
25 | { src: 'src/demos/*', dest: 'dist/demos/', expand:true, flatten: true },
26 | { src: 'src/themes/*', dest: 'dist/themes/', expand:true, flatten: true }
27 | ]
28 | }
29 | },
30 | concat: {
31 | dist: {
32 | options: {
33 | banner: '<%= banner %>',
34 | stripBanners: true
35 | },
36 | files: [
37 | { src: 'src/<%= pkg.name %>.js', dest: 'dist/<%= pkg.name %>.js' },
38 | { src: 'src/<%= pkg.name %>.css', dest: 'dist/<%= pkg.name %>.css' }
39 | ]
40 | }
41 | },
42 | uglify: {
43 | options: {
44 | banner: '<%= banner %>'
45 | },
46 | dist: {
47 | src: 'dist/<%= pkg.name %>.js',
48 | dest: 'dist/<%= pkg.name %>.min.js'
49 | },
50 | },
51 | cssmin: {
52 | options: {
53 | //banner: '<%= banner %>'
54 | },
55 | dist: {
56 | src: 'dist/<%= pkg.name %>.css',
57 | dest: 'dist/<%= pkg.name %>.min.css'
58 | },
59 | },
60 | replace: {
61 | dist: {
62 | options: {
63 | variables: {
64 | version: '<%= pkg.version %>',
65 | timestamp: '<%= pkg.modified %>'
66 | },
67 | prefix: '@@'
68 | },
69 | files: [
70 | //{ src: 'dist/<%= pkg.name %>.js', dest: 'dist/<%= pkg.name %>.js' },
71 | //{ src: 'dist/<%= pkg.name %>.css', dest: 'dist/<%= pkg.name %>.css' },
72 | { src: 'dist/index.html', dest: 'dist/index.html' }
73 | ]
74 | }
75 | },
76 | jasmine: {
77 | src: 'src/<%= pkg.name %>.js',
78 | options: {
79 | specs: 'test/*_spec.js',
80 | vendor: [
81 | 'test/lib/jquery.min.js',
82 | 'test/lib/jasmine-jquery.js'
83 | ]
84 | }
85 | },
86 | jshint: {
87 | gruntfile: {
88 | options: {
89 | jshintrc: '.jshintrc'
90 | },
91 | src: 'Gruntfile.js'
92 | },
93 | src: {
94 | options: {
95 | jshintrc: 'src/.jshintrc'
96 | },
97 | src: ['src/**/*.js']
98 | },
99 | test: {
100 | options: {
101 | jshintrc: 'test/.jshintrc'
102 | },
103 | src: ['test/*_spec.js']
104 | }
105 | },
106 | watch: {
107 | gruntfile: {
108 | files: '<%= jshint.gruntfile.src %>',
109 | tasks: ['jshint:gruntfile']
110 | },
111 | src: {
112 | files: 'src/**',//'<%= jshint.src.src %>',
113 | tasks: ['jshint:src', 'jasmine', 'clean', 'copy', 'concat', 'replace', 'uglify', 'cssmin']
114 | },
115 | test: {
116 | files: '<%= jshint.test.src %>',
117 | tasks: ['jshint:test', 'jasmine']
118 | }
119 | },
120 | });
121 |
122 | // These plugins provide necessary tasks.
123 | grunt.loadNpmTasks('grunt-contrib-clean');
124 | grunt.loadNpmTasks('grunt-contrib-concat');
125 | grunt.loadNpmTasks('grunt-contrib-copy');
126 | grunt.loadNpmTasks('grunt-replace');
127 | grunt.loadNpmTasks('grunt-contrib-uglify');
128 | grunt.loadNpmTasks('grunt-contrib-cssmin');
129 | grunt.loadNpmTasks('grunt-contrib-jasmine');
130 | grunt.loadNpmTasks('grunt-contrib-jshint');
131 | grunt.loadNpmTasks('grunt-contrib-watch');
132 |
133 | // Default task.
134 | grunt.registerTask('default', ['jshint', 'jasmine', 'clean', 'copy', 'concat', 'replace', 'uglify', 'cssmin']);
135 |
136 | // test task.
137 | grunt.registerTask('test', ['jshint', 'jasmine']);
138 |
139 | };
140 |
--------------------------------------------------------------------------------
/MIT-LICENSE.txt:
--------------------------------------------------------------------------------
1 | Copyright (c) 2009 Trent Richardson, http://trentrichardson.com/Impromptu/
2 |
3 | Permission is hereby granted, free of charge, to any person obtaining
4 | a copy of this software and associated documentation files (the
5 | "Software"), to deal in the Software without restriction, including
6 | without limitation the rights to use, copy, modify, merge, publish,
7 | distribute, sublicense, and/or sell copies of the Software, and to
8 | permit persons to whom the Software is furnished to do so, subject to
9 | the following conditions:
10 |
11 | The above copyright notice and this permission notice shall be
12 | included in all copies or substantial portions of the Software.
13 |
14 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17 | NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18 | LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19 | OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20 | WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
21 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | jQuery Impromptu
2 | ================
3 |
4 | About
5 | -----
6 | - Author: [Trent Richardson][author]
7 | - Documentation: [http://trentrichardson.com/Impromptu/][documentation]
8 | - Twitter: [@practicalweb][twitter]
9 | - eBook: [Impromptu - From I to U][ebook]
10 |
11 | [author]: (http://trentrichardson.com)
12 | [documentation]: http://trentrichardson.com/Impromptu/
13 | [twitter]: http://twitter.com/practicalweb
14 | [ebook]: http://sellfy.com/p/IrwS
15 |
16 | Use
17 | ---
18 | - Include jQuery and Impromptu into your page ([production version][jsmin] or the [development version][jsmax])
19 | - Add the CSS file or copy it to your CSS ([production version][cssmin] or the [development version][cssmax])
20 | - call using $.prompt('hello world!');
21 | - Visit the [Impromptu Documentation](http://trentrichardson.com/Impromptu/) for MUCH more advanced usage
22 |
23 | [jsmin]: dist/jquery-impromptu.min.js
24 | [jsmax]: dist/jquery-impromptu.js
25 | [cssmin]: dist/jquery-impromptu.min.css
26 | [cssmax]: dist/jquery-impromptu.css
27 |
28 | Contributing
29 | ------------
30 | jQuery Impromptu uses Grunt to automate the build, lint, minification.
31 | - Checkout the dev branch
32 | - Follow the [contributing instructions][contributing]
33 |
34 | [contributing]: CONTRIBUTING.md
35 |
36 | License
37 | -------
38 | Copyright 2011 Trent Richardson
39 |
40 | Licensed under the [MIT][mitlicense].
41 |
42 | [mitlicense]: MIT-LICENSE.txt
43 |
--------------------------------------------------------------------------------
/bower.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "jquery-impromptu",
3 | "main": [
4 | "dist/jquery-impromptu.css",
5 | "dist/jquery-impromptu.js"
6 | ],
7 | "keywords": ["impromptu","prompt","alert","modal","overlay","confirm"],
8 | "repository": {
9 | "type": "git",
10 | "url": "git://github.com/trentrichardson/jQuery-Impromptu.git"
11 | },
12 | "dependencies": {
13 | "jquery": ">=1.6"
14 | }
15 | }
--------------------------------------------------------------------------------
/dist/demos/loan_calculator.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | jQuery Impromptu States Example - Loan Calculator
6 |
7 |
8 |
9 |
10 |
11 |
12 |
18 |
19 |
99 |
100 |
101 |
102 | Test Impromptu Loan Calculator
103 |
104 |
105 |
--------------------------------------------------------------------------------
/dist/demos/purecss.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 | jQuery Impromptu with PureCSS
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
115 |
116 |
117 |
118 | Test Impromptu States Survey
119 |
120 |
121 |
--------------------------------------------------------------------------------
/dist/demos/select_filter.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 | jQuery Impromptu States Example - Select Dropdown Option Search
7 |
8 |
9 |
10 |
11 |
12 |
13 |
38 |
39 |
118 |
119 |
120 |
121 | Right click or ctrl click on the select for it to bring up a search for its options:
122 |
123 |
175 |
176 |
177 |
--------------------------------------------------------------------------------
/dist/demos/survey.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | jQuery Impromptu States Survey Example
6 |
7 |
8 |
9 |
15 |
16 |
17 |
18 |
19 |
20 |
94 |
95 |
96 |
97 | Test Impromptu States Survey
98 |
99 |
100 |
101 |
--------------------------------------------------------------------------------
/dist/demos/twitter_bootstrap.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 | jQuery Impromptu with Twitter Bootstrap
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
115 |
116 |
117 |
118 | Test Impromptu States Survey
119 |
120 |
121 |
--------------------------------------------------------------------------------
/dist/demos/user_manager.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | jQuery Impromptu - Demo 2
6 |
7 |
8 |
9 |
24 |
25 |
26 |
27 |
28 |
29 |
118 |
119 |
120 |
121 |
122 |
123 |
124 |
125 | Edit |
126 | Delete
127 |
128 |
John
129 |
Doe
130 |
131 |
132 |
133 |
134 | Edit |
135 | Delete
136 |
137 |
Jane
138 |
Doe
139 |
140 |
141 |
142 |
143 | Edit |
144 | Delete
145 |
146 |
Bill
147 |
Smith
148 |
149 |
150 |
151 |
152 | Edit |
153 | Delete
154 |
155 |
Steve
156 |
Jones
157 |
158 |
159 |
160 |
161 | Edit |
162 | Delete
163 |
164 |
Will
165 |
Johnson
166 |
167 |
168 |
169 |
170 | Edit |
171 | Delete
172 |
173 |
Harold
174 |
Anderson
175 |
176 |
177 |
178 |
179 |
180 |
181 |
182 |
--------------------------------------------------------------------------------
/dist/jquery-impromptu.css:
--------------------------------------------------------------------------------
1 | /*! jQuery-Impromptu - v6.2.2 - 2015-11-14
2 | * http://trentrichardson.com/Impromptu
3 | * Copyright (c) 2015 Trent Richardson; Licensed MIT */
4 | .jqifade{
5 | position: absolute;
6 | background-color: #777777;
7 | }
8 | iframe.jqifade{
9 | display:block;
10 | z-index:-1;
11 | }
12 | div.jqi{
13 | width: 400px;
14 | max-width:90%;
15 | font-family: Verdana, Geneva, Arial, Helvetica, sans-serif;
16 | position: absolute;
17 | background-color: #ffffff;
18 | font-size: 11px;
19 | text-align: left;
20 | border: solid 1px #eeeeee;
21 | border-radius: 6px;
22 | -moz-border-radius: 6px;
23 | -webkit-border-radius: 6px;
24 | padding: 7px;
25 | }
26 | div.jqi .jqicontainer{
27 | }
28 | div.jqi .jqiclose{
29 | position: absolute;
30 | top: 4px; right: -2px;
31 | width: 18px;
32 | cursor: default;
33 | color: #bbbbbb;
34 | font-weight: bold;
35 | }
36 | div.jqi .jqistate{
37 | background-color: #fff;
38 | }
39 | div.jqi .jqititle{
40 | padding: 5px 10px;
41 | font-size: 16px;
42 | line-height: 20px;
43 | border-bottom: solid 1px #eeeeee;
44 | }
45 | div.jqi .jqimessage{
46 | padding: 10px;
47 | line-height: 20px;
48 | color: #444444;
49 | overflow: auto;
50 | }
51 | div.jqi .jqibuttonshide{
52 | display: none;
53 | }
54 | div.jqi .jqibuttons{
55 | text-align: right;
56 | margin: 0 -7px -7px -7px;
57 | border-top: solid 1px #e4e4e4;
58 | background-color: #f4f4f4;
59 | border-radius: 0 0 6px 6px;
60 | -moz-border-radius: 0 0 6px 6px;
61 | -webkit-border-radius: 0 0 6px 6px;
62 | }
63 | div.jqi .jqibuttons button{
64 | margin: 0;
65 | padding: 15px 20px;
66 | background-color: transparent;
67 | font-weight: normal;
68 | border: none;
69 | border-left: solid 1px #e4e4e4;
70 | color: #777;
71 | font-weight: bold;
72 | font-size: 12px;
73 | }
74 | div.jqi .jqibuttons button.jqidefaultbutton{
75 | color: #489afe;
76 | }
77 | div.jqi .jqibuttons button:hover,
78 | div.jqi .jqibuttons button:focus{
79 | color: #287ade;
80 | outline: none;
81 | }
82 | div.jqi .jqibuttons button[disabled]{
83 | color: #aaa;
84 | }
85 | .jqiwarning .jqi .jqibuttons{
86 | background-color: #b95656;
87 | }
88 |
89 | /* sub states */
90 | div.jqi .jqiparentstate::after{
91 | background-color: #777;
92 | opacity: 0.6;
93 | filter: alpha(opacity=60);
94 | content: '';
95 | position: absolute;
96 | top:0;left:0;bottom:0;right:0;
97 | border-radius: 6px;
98 | -moz-border-radius: 6px;
99 | -webkit-border-radius: 6px;
100 | }
101 | div.jqi .jqisubstate{
102 | position: absolute;
103 | top:0;
104 | left: 20%;
105 | width: 60%;
106 | padding: 7px;
107 | border: solid 1px #eeeeee;
108 | border-top: none;
109 | border-radius: 0 0 6px 6px;
110 | -moz-border-radius: 0 0 6px 6px;
111 | -webkit-border-radius: 0 0 6px 6px;
112 | }
113 | div.jqi .jqisubstate .jqibuttons button{
114 | padding: 10px 18px;
115 | }
116 |
117 | /* arrows for tooltips/tours */
118 | .jqi .jqiarrow{ position: absolute; height: 0; width:0; line-height: 0; font-size: 0; border: solid 10px transparent;}
119 |
120 | .jqi .jqiarrowtl{ left: 10px; top: -20px; border-bottom-color: #ffffff; }
121 | .jqi .jqiarrowtc{ left: 50%; top: -20px; border-bottom-color: #ffffff; margin-left: -10px; }
122 | .jqi .jqiarrowtr{ right: 10px; top: -20px; border-bottom-color: #ffffff; }
123 |
124 | .jqi .jqiarrowbl{ left: 10px; bottom: -20px; border-top-color: #ffffff; }
125 | .jqi .jqiarrowbc{ left: 50%; bottom: -20px; border-top-color: #ffffff; margin-left: -10px; }
126 | .jqi .jqiarrowbr{ right: 10px; bottom: -20px; border-top-color: #ffffff; }
127 |
128 | .jqi .jqiarrowlt{ left: -20px; top: 10px; border-right-color: #ffffff; }
129 | .jqi .jqiarrowlm{ left: -20px; top: 50%; border-right-color: #ffffff; margin-top: -10px; }
130 | .jqi .jqiarrowlb{ left: -20px; bottom: 10px; border-right-color: #ffffff; }
131 |
132 | .jqi .jqiarrowrt{ right: -20px; top: 10px; border-left-color: #ffffff; }
133 | .jqi .jqiarrowrm{ right: -20px; top: 50%; border-left-color: #ffffff; margin-top: -10px; }
134 | .jqi .jqiarrowrb{ right: -20px; bottom: 10px; border-left-color: #ffffff; }
135 |
136 |
--------------------------------------------------------------------------------
/dist/jquery-impromptu.min.css:
--------------------------------------------------------------------------------
1 | /*! jQuery-Impromptu - v6.2.2 - 2015-11-14
2 | * http://trentrichardson.com/Impromptu
3 | * Copyright (c) 2015 Trent Richardson; Licensed MIT */.jqifade{position:absolute;background-color:#777}iframe.jqifade{display:block;z-index:-1}div.jqi{width:400px;max-width:90%;font-family:Verdana,Geneva,Arial,Helvetica,sans-serif;position:absolute;background-color:#fff;font-size:11px;text-align:left;border:solid 1px #eee;border-radius:6px;-moz-border-radius:6px;-webkit-border-radius:6px;padding:7px}div.jqi .jqicontainer{}div.jqi .jqiclose{position:absolute;top:4px;right:-2px;width:18px;cursor:default;color:#bbb;font-weight:700}div.jqi .jqistate{background-color:#fff}div.jqi .jqititle{padding:5px 10px;font-size:16px;line-height:20px;border-bottom:solid 1px #eee}div.jqi .jqimessage{padding:10px;line-height:20px;color:#444;overflow:auto}div.jqi .jqibuttonshide{display:none}div.jqi .jqibuttons{text-align:right;margin:0 -7px -7px -7px;border-top:solid 1px #e4e4e4;background-color:#f4f4f4;border-radius:0 0 6px 6px;-moz-border-radius:0 0 6px 6px;-webkit-border-radius:0 0 6px 6px}div.jqi .jqibuttons button{margin:0;padding:15px 20px;background-color:transparent;font-weight:400;border:0;border-left:solid 1px #e4e4e4;color:#777;font-weight:700;font-size:12px}div.jqi .jqibuttons button.jqidefaultbutton{color:#489afe}div.jqi .jqibuttons button:hover,div.jqi .jqibuttons button:focus{color:#287ade;outline:0}div.jqi .jqibuttons button[disabled]{color:#aaa}.jqiwarning .jqi .jqibuttons{background-color:#b95656}div.jqi .jqiparentstate::after{background-color:#777;opacity:.6;filter:alpha(opacity=60);content:'';position:absolute;top:0;left:0;bottom:0;right:0;border-radius:6px;-moz-border-radius:6px;-webkit-border-radius:6px}div.jqi .jqisubstate{position:absolute;top:0;left:20%;width:60%;padding:7px;border:solid 1px #eee;border-top:0;border-radius:0 0 6px 6px;-moz-border-radius:0 0 6px 6px;-webkit-border-radius:0 0 6px 6px}div.jqi .jqisubstate .jqibuttons button{padding:10px 18px}.jqi .jqiarrow{position:absolute;height:0;width:0;line-height:0;font-size:0;border:solid 10px transparent}.jqi .jqiarrowtl{left:10px;top:-20px;border-bottom-color:#fff}.jqi .jqiarrowtc{left:50%;top:-20px;border-bottom-color:#fff;margin-left:-10px}.jqi .jqiarrowtr{right:10px;top:-20px;border-bottom-color:#fff}.jqi .jqiarrowbl{left:10px;bottom:-20px;border-top-color:#fff}.jqi .jqiarrowbc{left:50%;bottom:-20px;border-top-color:#fff;margin-left:-10px}.jqi .jqiarrowbr{right:10px;bottom:-20px;border-top-color:#fff}.jqi .jqiarrowlt{left:-20px;top:10px;border-right-color:#fff}.jqi .jqiarrowlm{left:-20px;top:50%;border-right-color:#fff;margin-top:-10px}.jqi .jqiarrowlb{left:-20px;bottom:10px;border-right-color:#fff}.jqi .jqiarrowrt{right:-20px;top:10px;border-left-color:#fff}.jqi .jqiarrowrm{right:-20px;top:50%;border-left-color:#fff;margin-top:-10px}.jqi .jqiarrowrb{right:-20px;bottom:10px;border-left-color:#fff}
--------------------------------------------------------------------------------
/dist/jquery-impromptu.min.js:
--------------------------------------------------------------------------------
1 | /*! jQuery-Impromptu - v6.2.2 - 2015-11-14
2 | * http://trentrichardson.com/Impromptu
3 | * Copyright (c) 2015 Trent Richardson; Licensed MIT */
4 | !function(a,b){"function"==typeof define&&define.amd?define(["jquery"],b):b(a.jQuery)}(this,function(a){"use strict";var b=function(a,c){var d=this;return d.id=b.count++,b.lifo.push(d),a&&d.open(a,c),d};b.defaults={prefix:"jqi",classes:{box:"",fade:"",prompt:"",form:"",close:"",title:"",message:"",buttons:"",button:"",defaultButton:""},title:"",closeText:"×",buttons:{Ok:!0},buttonTimeout:1e3,loaded:function(a){},submit:function(a,b,c,d){},close:function(a,b,c,d){},statechanging:function(a,b,c){},statechanged:function(a,b){},opacity:.6,zIndex:999,overlayspeed:"slow",promptspeed:"fast",show:"fadeIn",hide:"fadeOut",focus:0,defaultButton:0,useiframe:!1,top:"15%",position:{container:null,x:null,y:null,arrow:null,width:null},persistent:!0,timeout:0,states:{},initialState:0,state:{name:null,title:"",html:"",buttons:{Ok:!0},focus:0,defaultButton:0,position:{container:null,x:null,y:null,arrow:null,width:null},submit:function(a,b,c,d){return!0}}},b.setDefaults=function(c){b.defaults=a.extend({},b.defaults,c)},b.setStateDefaults=function(c){b.defaults.state=a.extend({},b.defaults.state,c)},b.count=0,b.lifo=[],b.getLast=function(){var a=b.lifo.length;return a>0?b.lifo[a-1]:!1},b.removeFromStack=function(a){for(var c=b.lifo.length-1;c>=0;c--)if(b.lifo[c].id===a)return b.lifo.splice(c,1)[0]},b.prototype={id:null,open:function(c,d){var e=this;e.options=a.extend({},b.defaults,d),e.timeout&&clearTimeout(e.timeout),e.timeout=!1;var f=e.options,g=a(document.body),h=a(window),i='';i+=f.useiframe&&a("object, applet").length>0?'
':'
',i+='
',e.jqib=a(i).appendTo(g),e.jqi=e.jqib.children("."+f.prefix),e.jqif=e.jqib.children("."+f.prefix+"fade"),c.constructor===String&&(c={state0:{title:f.title,html:c,buttons:f.buttons,position:f.position,focus:f.focus,defaultButton:f.defaultButton,submit:f.submit}}),e.options.states={};var j,k;for(j in c)k=a.extend({},b.defaults.state,{name:j},c[j]),e.addState(k.name,k),""===e.currentStateName&&(e.currentStateName=k.name);e.jqi.on("click","."+f.prefix+"buttons button",function(b){var c=a(this),d=c.parents("."+f.prefix+"state"),g=d.data("jqi-name"),h=e.options.states[g],i=d.children("."+f.prefix+"message"),j=h.buttons[c.text()]||h.buttons[c.html()],k={};if(e.options.buttonTimeout>0&&(e.disableStateButtons(g),setTimeout(function(){e.enableStateButtons(g)},e.options.buttonTimeout)),void 0===j)for(var l in h.buttons)(h.buttons[l].title===c.text()||h.buttons[l].title===c.html())&&(j=h.buttons[l].value);a.each(e.jqi.children("form").serializeArray(),function(a,b){void 0===k[b.name]?k[b.name]=b.value:typeof k[b.name]===Array||"object"==typeof k[b.name]?k[b.name].push(b.value):k[b.name]=[k[b.name],b.value]});var m=new a.Event("impromptu:submit");m.stateName=h.name,m.state=d,d.trigger(m,[j,i,k]),m.isDefaultPrevented()||e.close(!0,j,i,k)});var l=function(){if(f.persistent){var b=f.top.toString().indexOf("%")>=0?h.height()*(parseInt(f.top,10)/100):parseInt(f.top,10),c=parseInt(e.jqi.css("top").replace("px",""),10)-b;a("html,body").animate({scrollTop:c},"fast",function(){var a=0;e.jqib.addClass(f.prefix+"warning");var b=setInterval(function(){e.jqib.toggleClass(f.prefix+"warning"),a++>1&&(clearInterval(b),e.jqib.removeClass(f.prefix+"warning"))},100)})}else e.close(!0)},m=function(b){var c=window.event?event.keyCode:b.keyCode;if(27===c&&l(),13===c){var d=e.getCurrentState().find("."+f.prefix+"defaultbutton"),g=a(b.target);g.is("textarea,."+f.prefix+"button")===!1&&d.length>0&&(b.preventDefault(),d.click())}if(9===c){var h=a("input,select,textarea,button",e.getCurrentState()),i=!b.shiftKey&&b.target===h[h.length-1],j=b.shiftKey&&b.target===h[0];if(i||j)return setTimeout(function(){if(h){var a=h[j===!0?h.length-1:0];a&&a.focus()}},10),!1}};return e.position(),e.style(),e._windowResize=function(a){e.position(a)},h.resize({animate:!1},e._windowResize),e.jqif.click(l),e.jqi.find("."+f.prefix+"close").click(function(){e.close()}),e.jqi.find("."+f.prefix+"form").submit(function(){return!1}),e.jqib.on("keydown",m).on("impromptu:loaded",f.loaded).on("impromptu:close",f.close).on("impromptu:statechanging",f.statechanging).on("impromptu:statechanged",f.statechanged),e.jqif[f.show](f.overlayspeed),e.jqi[f.show](f.promptspeed,function(){e.goToState(isNaN(f.initialState)?f.initialState:e.jqi.find("."+f.prefix+"states ."+f.prefix+"state").eq(f.initialState).data("jqi-name")),e.jqib.trigger("impromptu:loaded")}),f.timeout>0&&(e.timeout=setTimeout(function(){e.close(!0)},f.timeout)),e},close:function(c,d,e,f){var g=this;return b.removeFromStack(g.id),g.timeout&&(clearTimeout(g.timeout),g.timeout=!1),g.jqib&&g.jqib[g.options.hide]("fast",function(){g.jqib.trigger("impromptu:close",[d,e,f]),g.jqib.remove(),a(window).off("resize",g._windowResize),"function"==typeof c&&c()}),g.currentStateName="",g},addState:function(c,d,e){var f,g,h,i,j,k=this,l="",m=null,n="",o="",p=k.options,q=a.isFunction(d.position)?d.position():d.position,r=k.jqi.find("."+p.prefix+"states"),s=[],t=0;if(d=a.extend({},b.defaults.state,{name:c},d),a.isPlainObject(q)&&null!==q.arrow&&(n=''),d.title&&""!==d.title&&(o=''+d.title+"
"),f=d.html,"function"==typeof d.html&&(f="Error: html function must return text"),l+=''+n+o+'
'+f+'
',a.isArray(d.buttons))s=d.buttons;else if(a.isPlainObject(d.buttons))for(h in d.buttons)d.buttons.hasOwnProperty(h)&&s.push({title:h,value:d.buttons[h]});for(t=0,j=s.length;j>t;t++)i=s[t],g=d.focus===t||isNaN(d.focus)&&d.defaultButton===t?p.prefix+"defaultbutton "+p.classes.defaultButton:"",l+='";return l+="
",m=a(l).css({display:"none"}),m.on("impromptu:submit",d.submit),void 0!==e?k.getState(e).after(m):r.append(m),k.options.states[c]=d,m},removeState:function(a,b){var c=this,d=c.getState(a),e=function(){d.remove()};return 0===d.length?!1:("none"!==d.css("display")?void 0!==b&&c.getState(b).length>0?c.goToState(b,!1,e):d.next().length>0?c.nextState(e):d.prev().length>0?c.prevState(e):c.close():d.slideUp("slow",e),!0)},getApi:function(){return this},getBox:function(){return this.jqib},getPrompt:function(){return this.jqi},getState:function(a){return this.jqi.find('[data-jqi-name="'+a+'"]')},getCurrentState:function(){return this.getState(this.getCurrentStateName())},getCurrentStateName:function(){return this.currentStateName},disableStateButtons:function(b,c,d){var e=this;a.isArray(b)&&(c=b,b=null),e.getState(b||e.getCurrentStateName()).find("."+e.options.prefix+"button").each(function(b,e){(void 0===c||-1!==a.inArray(e.value,c))&&(e.disabled=!d)})},enableStateButtons:function(a,b){this.disableStateButtons(a,b,!0)},position:function(b){var c=this,d=a.fx.off,e=c.getCurrentState(),f=c.options.states[e.data("jqi-name")],g=f?a.isFunction(f.position)?f.position():f.position:void 0,h=a(window),i=document.body.scrollHeight,j=a(window).height(),k=(a(document).height(),i>j?i:j),l=parseInt(h.scrollTop(),10),m=l+(c.options.top.toString().indexOf("%")>=0?j*(parseInt(c.options.top,10)/100):parseInt(c.options.top,10));if(void 0!==b&&b.data.animate===!1&&(a.fx.off=!0),c.jqib.css({position:"absolute",height:k,width:"100%",top:0,left:0,right:0,bottom:0}),c.jqif.css({position:"fixed",height:k,width:"100%",top:0,left:0,right:0,bottom:0}),g&&g.container){var n=a(g.container).offset(),o=!1;a.isPlainObject(n)&&void 0!==n.top&&(m=n.top+g.y-(c.options.top.toString().indexOf("%")>=0?j*(parseInt(c.options.top,10)/100):parseInt(c.options.top,10)),c.jqi.css({position:"absolute"}),c.jqi.animate({top:n.top+g.y,left:n.left+g.x,marginLeft:0,width:void 0!==g.width?g.width:null},function(){!o&&n.top+g.y+c.jqi.outerHeight(!0)>l+j&&(a("html,body").animate({scrollTop:m},"slow","swing",function(){}),o=!0)}),(l>m||m>l+j)&&(a("html,body").animate({scrollTop:m},"slow","swing",function(){}),o=!0))}else g&&g.width?(c.jqi.css({position:"absolute",left:"50%"}),c.jqi.animate({top:g.y||m,left:g.x||"50%",marginLeft:g.width/2*-1,width:g.width})):c.jqi.css({position:"absolute",top:m,left:"50%",marginLeft:c.jqi.outerWidth(!1)/2*-1});void 0!==b&&b.data.animate===!1&&(a.fx.off=d)},style:function(){var a=this;a.jqif.css({zIndex:a.options.zIndex,display:"none",opacity:a.options.opacity}),a.jqi.css({zIndex:a.options.zIndex+1,display:"none"}),a.jqib.css({zIndex:a.options.zIndex})},goToState:function(b,c,d){var e=this,f=(e.jqi,e.options),g=e.getState(b),h=f.states[g.data("jqi-name")],i=new a.Event("impromptu:statechanging"),j=e.options;if(void 0!==h){if("function"==typeof h.html){var k=h.html;g.find("."+j.prefix+"message ").html(k())}"function"==typeof c&&(d=c,c=!1),e.jqib.trigger(i,[e.getCurrentStateName(),b]),!i.isDefaultPrevented()&&g.length>0&&(e.jqi.find("."+j.prefix+"parentstate").removeClass(j.prefix+"parentstate"),c?(e.jqi.find("."+j.prefix+"substate").not(g).slideUp(f.promptspeed).removeClass("."+j.prefix+"substate").find("."+j.prefix+"arrow").hide(),e.jqi.find("."+j.prefix+"state:visible").addClass(j.prefix+"parentstate"),g.addClass(j.prefix+"substate")):e.jqi.find("."+j.prefix+"state").not(g).slideUp(f.promptspeed).find("."+j.prefix+"arrow").hide(),e.currentStateName=h.name,g.slideDown(f.promptspeed,function(){var c=a(this);e.enableStateButtons(),"string"==typeof h.focus?c.find(h.focus).eq(0).focus():c.find("."+j.prefix+"defaultbutton").focus(),c.find("."+j.prefix+"arrow").show(f.promptspeed),"function"==typeof d&&e.jqib.on("impromptu:statechanged",d),e.jqib.trigger("impromptu:statechanged",[b]),"function"==typeof d&&e.jqib.off("impromptu:statechanged",d)}),c||e.position())}return g},nextState:function(a){var b=this,c=b.getCurrentState().next();return c.length>0&&b.goToState(c.data("jqi-name"),a),c},prevState:function(a){var b=this,c=b.getCurrentState().prev();return c.length>0&&b.goToState(c.data("jqi-name"),a),c}},a.prompt=function(a,c){var d=new b(a,c);return d.jqi},a.each(b,function(b,c){a.prompt[b]=c}),a.each(b.prototype,function(c,d){a.prompt[c]=function(){var a=b.getLast();return a&&"function"==typeof a[c]?a[c].apply(a,arguments):void 0}}),a.fn.prompt=function(b){void 0===b&&(b={}),void 0===b.withDataAndEvents&&(b.withDataAndEvents=!1),a.prompt(a(this).clone(b.withDataAndEvents).html(),b)},window.Impromptu=b});
--------------------------------------------------------------------------------
/dist/themes/base.css:
--------------------------------------------------------------------------------
1 | /*
2 | ------------------------------
3 | Impromptu Base Styles
4 | ------------------------------
5 | */
6 | .jqifade{
7 | position: absolute;
8 | background-color: #777777;
9 | }
10 | div.jqi{
11 | width: 400px;
12 | position: absolute;
13 | background-color: #ffffff;
14 | text-align: left;
15 | border: solid 1px #eeeeee;
16 | border-radius: 6px;
17 | -moz-border-radius: 6px;
18 | -webkit-border-radius: 6px;
19 | padding: 7px;
20 | }
21 | div.jqi .jqicontainer{
22 | }
23 | div.jqi .jqiclose{
24 | position: absolute;
25 | top: 4px; right: -2px;
26 | width: 18px;
27 | cursor: default;
28 | color: #bbbbbb;
29 | font-weight: bold;
30 | }
31 | div.jqi .jqistate{
32 | background-color: #fff;
33 | }
34 | div.jqi .jqiparentstate::after{
35 | background-color: #eee;
36 | opacity: 0.7;
37 | filter: alpha(opacity=70);
38 | content: '';
39 | position: absolute;
40 | top:0;left:0;bottom:0;right:0;
41 | border-radius: 6px;
42 | -moz-border-radius: 6px;
43 | -webkit-border-radius: 6px;
44 | }
45 | div.jqi .jqisubstate{
46 |
47 | position: absolute;
48 | top:0;
49 | left: 20%;
50 | width: 60%;
51 | padding: 7px;
52 | border: solid 1px #eeeeee;
53 | border-top: none;
54 | border-radius: 0 0 6px 6px;
55 | -moz-border-radius: 0 0 6px 6px;
56 | -webkit-border-radius: 0 0 6px 6px;
57 | }
58 | div.jqi .jqititle{
59 | padding: 5px 10px;
60 | border-bottom: solid 1px #eeeeee;
61 | }
62 | div.jqi .jqimessage{
63 | padding: 10px;
64 | color: #444444;
65 | }
66 | div.jqi .jqibuttons{
67 | padding: 5px;
68 | text-align: right;
69 | }
70 | div.jqi button{
71 | margin: 0 0 0 10px;
72 | }
73 |
74 | .jqi .jqiarrow{ position: absolute; height: 0; width:0; line-height: 0; font-size: 0; border: solid 10px transparent;}
75 |
76 | .jqi .jqiarrowtl{ left: 10px; top: -20px; border-bottom-color: #ffffff; }
77 | .jqi .jqiarrowtc{ left: 50%; top: -20px; border-bottom-color: #ffffff; margin-left: -10px; }
78 | .jqi .jqiarrowtr{ right: 10px; top: -20px; border-bottom-color: #ffffff; }
79 |
80 | .jqi .jqiarrowbl{ left: 10px; bottom: -20px; border-top-color: #ffffff; }
81 | .jqi .jqiarrowbc{ left: 50%; bottom: -20px; border-top-color: #ffffff; margin-left: -10px; }
82 | .jqi .jqiarrowbr{ right: 10px; bottom: -20px; border-top-color: #ffffff; }
83 |
84 | .jqi .jqiarrowlt{ left: -20px; top: 10px; border-right-color: #ffffff; }
85 | .jqi .jqiarrowlm{ left: -20px; top: 50%; border-right-color: #ffffff; margin-top: -10px; }
86 | .jqi .jqiarrowlb{ left: -20px; bottom: 10px; border-right-color: #ffffff; }
87 |
88 | .jqi .jqiarrowrt{ right: -20px; top: 10px; border-left-color: #ffffff; }
89 | .jqi .jqiarrowrm{ right: -20px; top: 50%; border-left-color: #ffffff; margin-top: -10px; }
90 | .jqi .jqiarrowrb{ right: -20px; bottom: 10px; border-left-color: #ffffff; }
91 |
92 |
--------------------------------------------------------------------------------
/dist/themes/classic-impromptu.css:
--------------------------------------------------------------------------------
1 | /*
2 | ------------------------------
3 | classic impromptu
4 | ------------------------------
5 | */
6 | .impromptuwarning .impromptu{ background-color: #aaaaaa; }
7 | .impromptufade{
8 | position: absolute;
9 | background-color: #ffffff;
10 | }
11 | div.impromptu{
12 | position: absolute;
13 | background-color: #cccccc;
14 | padding: 10px;
15 | width: 300px;
16 | text-align: left;
17 | }
18 | div.impromptu .impromptuclose{
19 | float: right;
20 | margin: -35px -10px 0 0;
21 | cursor: pointer;
22 | color: #213e80;
23 | }
24 | div.impromptu .impromptucontainer{
25 | background-color: #213e80;
26 | padding: 5px;
27 | color: #ffffff;
28 | font-weight: bold;
29 | }
30 | div.impromptu .impromptumessage{
31 | background-color: #415ea0;
32 | padding: 10px;
33 | }
34 | div.impromptu .impromptubuttons{
35 | text-align: center;
36 | padding: 5px 0 0 0;
37 | }
38 | div.impromptu button{
39 | padding: 3px 10px 3px 10px;
40 | margin: 0 10px;
41 | }
42 |
--------------------------------------------------------------------------------
/dist/themes/clean-blue.css:
--------------------------------------------------------------------------------
1 | /*
2 | ------------------------------
3 | clean blue
4 | ------------------------------
5 | */
6 | .cleanbluewarning .cleanblue{
7 | background-color: #acb4c4;
8 | }
9 | .cleanbluefade{
10 | position: absolute;
11 | background-color: #aaaaaa;
12 | }
13 | div.cleanblue{
14 | font-family: Verdana, Geneva, Arial, Helvetica, sans-serif;
15 | position: absolute;
16 | background-color: #ffffff;
17 | width: 300px;
18 | font-size: 11px;
19 | text-align: left;
20 | border: solid 1px #213e80;
21 | }
22 | div.cleanblue .cleanbluecontainer{
23 | background-color: #ffffff;
24 | border-top: solid 14px #213e80;
25 | padding: 5px;
26 | font-weight: bold;
27 | }
28 | div.cleanblue .cleanblueclose{
29 | float: right;
30 | width: 18px;
31 | cursor: default;
32 | margin: -19px -12px 0 0;
33 | color: #ffffff;
34 | font-weight: bold;
35 | }
36 | div.cleanblue .cleanbluemessage{
37 | padding: 10px;
38 | line-height: 20px;
39 | font-size: 11px;
40 | color: #333333;
41 | }
42 | div.cleanblue .cleanbluebuttons{
43 | text-align: right;
44 | padding: 5px 0 5px 0;
45 | border: solid 1px #eeeeee;
46 | background-color: #f4f4f4;
47 | }
48 | div.cleanblue button{
49 | padding: 3px 10px;
50 | margin: 0 10px;
51 | background-color: #314e90;
52 | border: solid 1px #f4f4f4;
53 | color: #ffffff;
54 | font-weight: bold;
55 | font-size: 12px;
56 | }
57 | div.cleanblue button:hover{
58 | border: solid 1px #d4d4d4;
59 | }
60 |
--------------------------------------------------------------------------------
/dist/themes/ext-blue.css:
--------------------------------------------------------------------------------
1 | /*
2 | ------------------------------
3 | Ext Blue
4 | ------------------------------
5 | */
6 | .extbluewarning .extblue{
7 | border:1px red solid;
8 | }
9 | .extbluefade{
10 | position: absolute;
11 | background-color: #ffffff;
12 | }
13 | div.extblue{
14 | border:1px #6289B6 solid;
15 | position: absolute;
16 | background-color: #CAD8EA;
17 | padding: 0;
18 | width: 300px;
19 | text-align: left;
20 | }
21 | div.extblue .extblueclose{
22 | background-color: #CAD8EA;
23 | margin:2px -2px 0 0;
24 | cursor: pointer;
25 | color: red;
26 | text-align: right;
27 | }
28 | div.extblue .extbluecontainer{
29 | background-color: #CAD8EA;
30 | padding: 0 5px 5px 5px;
31 | color: #000000;
32 | font:normal 11px Verdana;
33 | }
34 | div.extblue .extbluemessage{
35 | background-color: #CAD8EA;
36 | padding: 0;
37 | margin:0 15px 15px 15px;
38 | }
39 | div.extblue .extbluebuttons{
40 | text-align: center;
41 | padding: 0px 0 0 0;
42 | }
43 | div.extblue button{
44 | padding: 1px 4px;
45 | margin: 0 10px;
46 | background-color:#cccccc;
47 | font-weight:normal;
48 | font-family:Verdana;
49 | font-size:10px;
50 | }
51 |
--------------------------------------------------------------------------------
/dist/themes/smooth.css:
--------------------------------------------------------------------------------
1 | /*
2 | ------------------------------
3 | Smooth
4 | ------------------------------
5 | */
6 | .jqismoothfade{
7 | position: absolute;
8 | background-color: #333333;
9 | }
10 | div.jqismooth{
11 | width: 350px;
12 | font-family: Verdana, Geneva, Arial, Helvetica, sans-serif;
13 | position: absolute;
14 | background-color: #ffffff;
15 | font-size: 11px;
16 | text-align: left;
17 | border: solid 3px #e2e8e6;
18 | -moz-border-radius: 10px;
19 | -webkit-border-radius: 10px;
20 | padding: 7px;
21 | }
22 | div.jqismooth .jqismoothcontainer{
23 | font-weight: bold;
24 | }
25 | div.jqismooth .jqismoothclose{
26 | position: absolute;
27 | top: 0;
28 | right: 0;
29 | width: 18px;
30 | cursor: default;
31 | text-align: center;
32 | padding: 2px 0 4px 0;
33 | color: #727876;
34 | font-weight: bold;
35 | background-color: #e2e8e6;
36 | -moz-border-radius-bottomLeft: 5px;
37 | -webkit-border-bottom-left-radius: 5px;
38 | border-left: solid 1px #e2e8e6;
39 | border-bottom: solid 1px #e2e8e6;
40 | }
41 | div.jqismooth .jqismoothmessage{
42 | padding: 10px;
43 | line-height: 20px;
44 | color: #444444;
45 | }
46 | div.jqismooth .jqismoothbuttons{
47 | text-align: right;
48 | padding: 5px 0 5px 0;
49 | border: solid 1px #e2e8e6;
50 | background-color: #f2f8f6;
51 | }
52 | div.jqismooth button{
53 | padding: 3px 10px;
54 | margin: 0 10px;
55 | background-color: #2F6073;
56 | border: solid 1px #f4f4f4;
57 | color: #ffffff;
58 | font-weight: bold;
59 | font-size: 12px;
60 | }
61 | div.jqismooth button:hover{
62 | background-color: #728A8C;
63 | }
64 | div.jqismooth button.jqismoothdefaultbutton{
65 | background-color: #BF5E26;
66 | }
67 | .jqismoothwarning .jqismooth .jqismoothbuttons{
68 | background-color: #BF5E26;
69 | }
70 |
--------------------------------------------------------------------------------
/dist/themes/zoo.css:
--------------------------------------------------------------------------------
1 | /* The Impromptzoo theme by Trent Richardson, based on http://stammtec.de/work/upload-dialog/ */
2 |
3 | /* layout */
4 | .jqizoofade{ position: absolute; background-color: #000; }
5 | div.jqizoo{ width: 400px; font-family: Verdana, Geneva, Arial, Helvetica, sans-serif; position: absolute; background-color: #ffffff; font-size: 11px; text-align: left;
6 | border: solid 2px #333; border-radius: 5px; -moz-border-radius: 5px; -webkit-border-radius: 5px; }
7 |
8 | /* container */
9 | div.jqizoo .jqizoocontainer{ background-color: #5b6776; }
10 | div.jqizoo .jqizooclose{ position: absolute; top: 0; right: 8px; width: 20px; padding: 2px 0 2px 0; text-align: center; cursor: default; color: #fff; font-weight: bold; text-shadow: 1px 1px 1px #333;
11 | background-color: #d4797b; background-image: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#d4797b), to(#b34b4d)); background-image: -webkit-linear-gradient(top, #d4797b, #b34b4d); background-image: -moz-linear-gradient(top, #d4797b, #b34b4d); background-image: -ms-linear-gradient(top, #d4797b, #b34b4d); background-image: -o-linear-gradient(top, #d4797b, #b34b4d);
12 | border: solid 1px #555; border-top: none; border-radius: 0 0 5px 5px; -moz-border-radius: 0 0 5px 5px; -webkit-border-radius: 0 0 5px 5px;}
13 | div.jqizoo .jqizootitle{ padding: 10px 10px; font-size: 14px; color: #333; line-height: 20px; text-align: center; text-shadow: 1px 1px 1px #999; letter-spacing: 1px;
14 | background-color: #f0f0f0; background-image: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#f0f0f0), to(#dbdbdb)); background-image: -webkit-linear-gradient(top, #f0f0f0, #dbdbdb); background-image: -moz-linear-gradient(top, #f0f0f0, #dbdbdb); background-image: -ms-linear-gradient(top, #f0f0f0, #dbdbdb); background-image: -o-linear-gradient(top, #f0f0f0, #dbdbdb);
15 | border-bottom: solid 1px #949494; border-radius: 5px 5px 0 0; -moz-border-radius: 5px 5px 0 0; -webkit-border-radius: 5px 5px 0 0; }
16 | div.jqizoo .jqizoomessage{ padding: 10px; line-height: 20px; color: #444444; background-color: #fff;
17 | border-bottom: solid 1px #333; border-radius: 0 0 5px 5px; -moz-border-radius: 0 0 5px 5px; -webkit-border-radius: 0 0 5px 5px; }
18 |
19 | /* buttons */
20 | div.jqizoo .jqizoobuttons{ text-align: right; padding: 6px 0 6px 0;
21 | background-color: #5b6776; background-image: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#5b6776), to(#303940)); background-image: -webkit-linear-gradient(top, #5b6776, #303940); background-image: -moz-linear-gradient(top, #5b6776, #303940); background-image: -ms-linear-gradient(top, #5b6776, #303940); background-image: -o-linear-gradient(top, #5b6776, #303940);
22 | border-radius: 0 0 5px 5px; -moz-border-radius: 0 0 5px 5px; -webkit-border-radius: 0 0 5px 5px; }
23 | div.jqizoo button{ padding: 3px 10px; margin: 0 10px; background-color: #2F6073; color: #ffffff; font-weight: bold; font-size: 12px; text-shadow: 1px 1px 1px #333;
24 | background-color: #78a0ce; background-image: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#78a0ce), to(#516cb6)); background-image: -webkit-linear-gradient(top, #78a0ce, #516cb6); background-image: -moz-linear-gradient(top, #78a0ce, #516cb6); background-image: -ms-linear-gradient(top, #78a0ce, #516cb6); background-image: -o-linear-gradient(top, #78a0ce, #516cb6);
25 | /* yellow background-color: #dab150; background-image: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#dab150), to(#c49629)); background-image: -webkit-linear-gradient(top, #dab150, #c49629); background-image: -moz-linear-gradient(top, #dab150, #c49629); background-image: -ms-linear-gradient(top, #dab150, #c49629); background-image: -o-linear-gradient(top, #dab150, #c49629); */
26 | border: solid 1px #192432; border-radius: 3px; -moz-border-radius: 3px; -webkit-border-radius: 3px; }
27 | div.jqizoo button:hover{ color: #eee; }
28 | div.jqizoo button.jqizoodefaultbutton{ background-color: #d4797b; background-image: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#d4797b), to(#b34b4d)); background-image: -webkit-linear-gradient(top, #d4797b, #b34b4d); background-image: -moz-linear-gradient(top, #d4797b, #b34b4d); background-image: -ms-linear-gradient(top, #d4797b, #b34b4d); background-image: -o-linear-gradient(top, #d4797b, #b34b4d); }
29 | .jqizoowarning .jqizoo .jqizoobuttons button{ border-color: #dab150; }
30 |
31 | /* arrows */
32 | .jqizoo .jqizooarrow{ position: absolute; height: 0; width:0; line-height: 0; font-size: 0; border: solid 10px transparent; }
33 | .jqizoo .jqizooarrowtl{ left: 10px; top: -20px; border-bottom-color: #333; }
34 | .jqizoo .jqizooarrowtc{ left: 50%; top: -20px; border-bottom-color: #333; margin-left: -10px; }
35 | .jqizoo .jqizooarrowtr{ right: 10px; top: -20px; border-bottom-color: #333; }
36 | .jqizoo .jqizooarrowbl{ left: 10px; bottom: -20px; border-top-color: #333; }
37 | .jqizoo .jqizooarrowbc{ left: 50%; bottom: -20px; border-top-color: #333; margin-left: -10px; }
38 | .jqizoo .jqizooarrowbr{ right: 10px; bottom: -20px; border-top-color: #333; }
39 | .jqizoo .jqizooarrowlt{ left: -20px; top: 10px; border-right-color: #333; }
40 | .jqizoo .jqizooarrowlm{ left: -20px; top: 50%; border-right-color: #333; margin-top: -10px; }
41 | .jqizoo .jqizooarrowlb{ left: -20px; bottom: 10px; border-right-color: #333; }
42 | .jqizoo .jqizooarrowrt{ right: -20px; top: 10px; border-left-color: #333; }
43 | .jqizoo .jqizooarrowrm{ right: -20px; top: 50%; border-left-color: #333; margin-top: -10px; }
44 | .jqizoo .jqizooarrowrb{ right: -20px; bottom: 10px; border-left-color: #333; }
--------------------------------------------------------------------------------
/jquery-impromptu.jquery.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "jquery-impromptu",
3 | "title": "jQuery-Impromptu",
4 | "description": "An extension to help provide a more pleasant way to spontaneously prompt a user for input.",
5 | "version": "6.2.2",
6 | "modified": "2015-11-14",
7 | "homepage": "http://trentrichardson.com/Impromptu",
8 | "author": {
9 | "name": "Trent Richardson",
10 | "email": "trentdrichardson@gmail.com",
11 | "url": "http://trentrichardson.com"
12 | },
13 | "repository": {
14 | "type": "git",
15 | "url": "git://github.com/trentrichardson/jQuery-Impromptu.git"
16 | },
17 | "bugs": "https://github.com/trentrichardson/jQuery-Impromptu/issues",
18 | "licenses": [
19 | {
20 | "type": "MIT",
21 | "url": "http://trentrichardson.com/examples/jQuery-Impromptu/blob/master/MIT-LICENSE.txt"
22 | }
23 | ],
24 | "dependencies": {
25 | "jquery": "*"
26 | },
27 | "keywords": []
28 | }
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "jQuery-Impromptu",
3 | "version": "0.0.0-ignored",
4 | "engines": {
5 | "node": ">= 0.8.0"
6 | },
7 | "devDependencies": {
8 | "grunt-contrib-concat": "~0.1.2",
9 | "grunt-contrib-jshint": "~0.1.1",
10 | "grunt-contrib-jasmine": "~0.8.0",
11 | "grunt-contrib-uglify": "~0.9.1",
12 | "grunt-contrib-watch": "~0.2.0",
13 | "grunt-contrib-clean": "~0.4.0",
14 | "grunt-contrib-copy": "~0.4.0",
15 | "grunt-contrib-cssmin": "~0.6.0",
16 | "grunt-replace": "~0.4.4",
17 | "grunt": "~0.4.1"
18 | }
19 | }
--------------------------------------------------------------------------------
/src/.jshintrc:
--------------------------------------------------------------------------------
1 | {
2 | "curly": true,
3 | "eqeqeq": true,
4 | "immed": true,
5 | "latedef": true,
6 | "newcap": true,
7 | "noarg": true,
8 | "sub": true,
9 | "undef": true,
10 | "unused": false,
11 | "loopfunc": true,
12 | "boss": true,
13 | "eqnull": true,
14 | "browser": true,
15 | "predef": ["jQuery","define","Event"]
16 | }
17 |
--------------------------------------------------------------------------------
/src/demos/loan_calculator.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | jQuery Impromptu States Example - Loan Calculator
6 |
7 |
8 |
9 |
10 |
11 |
12 |
18 |
19 |
99 |
100 |
101 |
102 | Test Impromptu Loan Calculator
103 |
104 |
105 |
--------------------------------------------------------------------------------
/src/demos/purecss.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 | jQuery Impromptu with PureCSS
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
115 |
116 |
117 |
118 | Test Impromptu States Survey
119 |
120 |
121 |
--------------------------------------------------------------------------------
/src/demos/select_filter.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 | jQuery Impromptu States Example - Select Dropdown Option Search
7 |
8 |
9 |
10 |
11 |
12 |
13 |
38 |
39 |
118 |
119 |
120 |
121 | Right click or ctrl click on the select for it to bring up a search for its options:
122 |
123 |
175 |
176 |
177 |
--------------------------------------------------------------------------------
/src/demos/survey.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | jQuery Impromptu States Survey Example
6 |
7 |
8 |
9 |
15 |
16 |
17 |
18 |
19 |
20 |
94 |
95 |
96 |
97 | Test Impromptu States Survey
98 |
99 |
100 |
101 |
--------------------------------------------------------------------------------
/src/demos/twitter_bootstrap.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 | jQuery Impromptu with Twitter Bootstrap
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
115 |
116 |
117 |
118 | Test Impromptu States Survey
119 |
120 |
121 |
--------------------------------------------------------------------------------
/src/demos/user_manager.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | jQuery Impromptu - Demo 2
6 |
7 |
8 |
9 |
24 |
25 |
26 |
27 |
28 |
29 |
118 |
119 |
120 |
121 |
122 |
123 |
124 |
125 | Edit |
126 | Delete
127 |
128 |
John
129 |
Doe
130 |
131 |
132 |
133 |
134 | Edit |
135 | Delete
136 |
137 |
Jane
138 |
Doe
139 |
140 |
141 |
142 |
143 | Edit |
144 | Delete
145 |
146 |
Bill
147 |
Smith
148 |
149 |
150 |
151 |
152 | Edit |
153 | Delete
154 |
155 |
Steve
156 |
Jones
157 |
158 |
159 |
160 |
161 | Edit |
162 | Delete
163 |
164 |
Will
165 |
Johnson
166 |
167 |
168 |
169 |
170 | Edit |
171 | Delete
172 |
173 |
Harold
174 |
Anderson
175 |
176 |
177 |
178 |
179 |
180 |
181 |
182 |
--------------------------------------------------------------------------------
/src/jquery-impromptu.css:
--------------------------------------------------------------------------------
1 | .jqifade{
2 | position: absolute;
3 | background-color: #777777;
4 | }
5 | iframe.jqifade{
6 | display:block;
7 | z-index:-1;
8 | }
9 | div.jqi{
10 | width: 400px;
11 | max-width:90%;
12 | font-family: Verdana, Geneva, Arial, Helvetica, sans-serif;
13 | position: absolute;
14 | background-color: #ffffff;
15 | font-size: 11px;
16 | text-align: left;
17 | border: solid 1px #eeeeee;
18 | border-radius: 6px;
19 | -moz-border-radius: 6px;
20 | -webkit-border-radius: 6px;
21 | padding: 7px;
22 | }
23 | div.jqi .jqicontainer{
24 | }
25 | div.jqi .jqiclose{
26 | position: absolute;
27 | top: 4px; right: -2px;
28 | width: 18px;
29 | cursor: default;
30 | color: #bbbbbb;
31 | font-weight: bold;
32 | }
33 | div.jqi .jqistate{
34 | background-color: #fff;
35 | }
36 | div.jqi .jqititle{
37 | padding: 5px 10px;
38 | font-size: 16px;
39 | line-height: 20px;
40 | border-bottom: solid 1px #eeeeee;
41 | }
42 | div.jqi .jqimessage{
43 | padding: 10px;
44 | line-height: 20px;
45 | color: #444444;
46 | overflow: auto;
47 | }
48 | div.jqi .jqibuttonshide{
49 | display: none;
50 | }
51 | div.jqi .jqibuttons{
52 | text-align: right;
53 | margin: 0 -7px -7px -7px;
54 | border-top: solid 1px #e4e4e4;
55 | background-color: #f4f4f4;
56 | border-radius: 0 0 6px 6px;
57 | -moz-border-radius: 0 0 6px 6px;
58 | -webkit-border-radius: 0 0 6px 6px;
59 | }
60 | div.jqi .jqibuttons button{
61 | margin: 0;
62 | padding: 15px 20px;
63 | background-color: transparent;
64 | font-weight: normal;
65 | border: none;
66 | border-left: solid 1px #e4e4e4;
67 | color: #777;
68 | font-weight: bold;
69 | font-size: 12px;
70 | }
71 | div.jqi .jqibuttons button.jqidefaultbutton{
72 | color: #489afe;
73 | }
74 | div.jqi .jqibuttons button:hover,
75 | div.jqi .jqibuttons button:focus{
76 | color: #287ade;
77 | outline: none;
78 | }
79 | div.jqi .jqibuttons button[disabled]{
80 | color: #aaa;
81 | }
82 | .jqiwarning .jqi .jqibuttons{
83 | background-color: #b95656;
84 | }
85 |
86 | /* sub states */
87 | div.jqi .jqiparentstate::after{
88 | background-color: #777;
89 | opacity: 0.6;
90 | filter: alpha(opacity=60);
91 | content: '';
92 | position: absolute;
93 | top:0;left:0;bottom:0;right:0;
94 | border-radius: 6px;
95 | -moz-border-radius: 6px;
96 | -webkit-border-radius: 6px;
97 | }
98 | div.jqi .jqisubstate{
99 | position: absolute;
100 | top:0;
101 | left: 20%;
102 | width: 60%;
103 | padding: 7px;
104 | border: solid 1px #eeeeee;
105 | border-top: none;
106 | border-radius: 0 0 6px 6px;
107 | -moz-border-radius: 0 0 6px 6px;
108 | -webkit-border-radius: 0 0 6px 6px;
109 | }
110 | div.jqi .jqisubstate .jqibuttons button{
111 | padding: 10px 18px;
112 | }
113 |
114 | /* arrows for tooltips/tours */
115 | .jqi .jqiarrow{ position: absolute; height: 0; width:0; line-height: 0; font-size: 0; border: solid 10px transparent;}
116 |
117 | .jqi .jqiarrowtl{ left: 10px; top: -20px; border-bottom-color: #ffffff; }
118 | .jqi .jqiarrowtc{ left: 50%; top: -20px; border-bottom-color: #ffffff; margin-left: -10px; }
119 | .jqi .jqiarrowtr{ right: 10px; top: -20px; border-bottom-color: #ffffff; }
120 |
121 | .jqi .jqiarrowbl{ left: 10px; bottom: -20px; border-top-color: #ffffff; }
122 | .jqi .jqiarrowbc{ left: 50%; bottom: -20px; border-top-color: #ffffff; margin-left: -10px; }
123 | .jqi .jqiarrowbr{ right: 10px; bottom: -20px; border-top-color: #ffffff; }
124 |
125 | .jqi .jqiarrowlt{ left: -20px; top: 10px; border-right-color: #ffffff; }
126 | .jqi .jqiarrowlm{ left: -20px; top: 50%; border-right-color: #ffffff; margin-top: -10px; }
127 | .jqi .jqiarrowlb{ left: -20px; bottom: 10px; border-right-color: #ffffff; }
128 |
129 | .jqi .jqiarrowrt{ right: -20px; top: 10px; border-left-color: #ffffff; }
130 | .jqi .jqiarrowrm{ right: -20px; top: 50%; border-left-color: #ffffff; margin-top: -10px; }
131 | .jqi .jqiarrowrb{ right: -20px; bottom: 10px; border-left-color: #ffffff; }
132 |
133 |
--------------------------------------------------------------------------------
/src/themes/base.css:
--------------------------------------------------------------------------------
1 | /*
2 | ------------------------------
3 | Impromptu Base Styles
4 | ------------------------------
5 | */
6 | .jqifade{
7 | position: absolute;
8 | background-color: #777777;
9 | }
10 | div.jqi{
11 | width: 400px;
12 | position: absolute;
13 | background-color: #ffffff;
14 | text-align: left;
15 | border: solid 1px #eeeeee;
16 | border-radius: 6px;
17 | -moz-border-radius: 6px;
18 | -webkit-border-radius: 6px;
19 | padding: 7px;
20 | }
21 | div.jqi .jqicontainer{
22 | }
23 | div.jqi .jqiclose{
24 | position: absolute;
25 | top: 4px; right: -2px;
26 | width: 18px;
27 | cursor: default;
28 | color: #bbbbbb;
29 | font-weight: bold;
30 | }
31 | div.jqi .jqistate{
32 | background-color: #fff;
33 | }
34 | div.jqi .jqiparentstate::after{
35 | background-color: #eee;
36 | opacity: 0.7;
37 | filter: alpha(opacity=70);
38 | content: '';
39 | position: absolute;
40 | top:0;left:0;bottom:0;right:0;
41 | border-radius: 6px;
42 | -moz-border-radius: 6px;
43 | -webkit-border-radius: 6px;
44 | }
45 | div.jqi .jqisubstate{
46 |
47 | position: absolute;
48 | top:0;
49 | left: 20%;
50 | width: 60%;
51 | padding: 7px;
52 | border: solid 1px #eeeeee;
53 | border-top: none;
54 | border-radius: 0 0 6px 6px;
55 | -moz-border-radius: 0 0 6px 6px;
56 | -webkit-border-radius: 0 0 6px 6px;
57 | }
58 | div.jqi .jqititle{
59 | padding: 5px 10px;
60 | border-bottom: solid 1px #eeeeee;
61 | }
62 | div.jqi .jqimessage{
63 | padding: 10px;
64 | color: #444444;
65 | }
66 | div.jqi .jqibuttons{
67 | padding: 5px;
68 | text-align: right;
69 | }
70 | div.jqi button{
71 | margin: 0 0 0 10px;
72 | }
73 |
74 | .jqi .jqiarrow{ position: absolute; height: 0; width:0; line-height: 0; font-size: 0; border: solid 10px transparent;}
75 |
76 | .jqi .jqiarrowtl{ left: 10px; top: -20px; border-bottom-color: #ffffff; }
77 | .jqi .jqiarrowtc{ left: 50%; top: -20px; border-bottom-color: #ffffff; margin-left: -10px; }
78 | .jqi .jqiarrowtr{ right: 10px; top: -20px; border-bottom-color: #ffffff; }
79 |
80 | .jqi .jqiarrowbl{ left: 10px; bottom: -20px; border-top-color: #ffffff; }
81 | .jqi .jqiarrowbc{ left: 50%; bottom: -20px; border-top-color: #ffffff; margin-left: -10px; }
82 | .jqi .jqiarrowbr{ right: 10px; bottom: -20px; border-top-color: #ffffff; }
83 |
84 | .jqi .jqiarrowlt{ left: -20px; top: 10px; border-right-color: #ffffff; }
85 | .jqi .jqiarrowlm{ left: -20px; top: 50%; border-right-color: #ffffff; margin-top: -10px; }
86 | .jqi .jqiarrowlb{ left: -20px; bottom: 10px; border-right-color: #ffffff; }
87 |
88 | .jqi .jqiarrowrt{ right: -20px; top: 10px; border-left-color: #ffffff; }
89 | .jqi .jqiarrowrm{ right: -20px; top: 50%; border-left-color: #ffffff; margin-top: -10px; }
90 | .jqi .jqiarrowrb{ right: -20px; bottom: 10px; border-left-color: #ffffff; }
91 |
92 |
--------------------------------------------------------------------------------
/src/themes/classic-impromptu.css:
--------------------------------------------------------------------------------
1 | /*
2 | ------------------------------
3 | classic impromptu
4 | ------------------------------
5 | */
6 | .impromptuwarning .impromptu{ background-color: #aaaaaa; }
7 | .impromptufade{
8 | position: absolute;
9 | background-color: #ffffff;
10 | }
11 | div.impromptu{
12 | position: absolute;
13 | background-color: #cccccc;
14 | padding: 10px;
15 | width: 300px;
16 | text-align: left;
17 | }
18 | div.impromptu .impromptuclose{
19 | float: right;
20 | margin: -35px -10px 0 0;
21 | cursor: pointer;
22 | color: #213e80;
23 | }
24 | div.impromptu .impromptucontainer{
25 | background-color: #213e80;
26 | padding: 5px;
27 | color: #ffffff;
28 | font-weight: bold;
29 | }
30 | div.impromptu .impromptumessage{
31 | background-color: #415ea0;
32 | padding: 10px;
33 | }
34 | div.impromptu .impromptubuttons{
35 | text-align: center;
36 | padding: 5px 0 0 0;
37 | }
38 | div.impromptu button{
39 | padding: 3px 10px 3px 10px;
40 | margin: 0 10px;
41 | }
42 |
--------------------------------------------------------------------------------
/src/themes/clean-blue.css:
--------------------------------------------------------------------------------
1 | /*
2 | ------------------------------
3 | clean blue
4 | ------------------------------
5 | */
6 | .cleanbluewarning .cleanblue{
7 | background-color: #acb4c4;
8 | }
9 | .cleanbluefade{
10 | position: absolute;
11 | background-color: #aaaaaa;
12 | }
13 | div.cleanblue{
14 | font-family: Verdana, Geneva, Arial, Helvetica, sans-serif;
15 | position: absolute;
16 | background-color: #ffffff;
17 | width: 300px;
18 | font-size: 11px;
19 | text-align: left;
20 | border: solid 1px #213e80;
21 | }
22 | div.cleanblue .cleanbluecontainer{
23 | background-color: #ffffff;
24 | border-top: solid 14px #213e80;
25 | padding: 5px;
26 | font-weight: bold;
27 | }
28 | div.cleanblue .cleanblueclose{
29 | float: right;
30 | width: 18px;
31 | cursor: default;
32 | margin: -19px -12px 0 0;
33 | color: #ffffff;
34 | font-weight: bold;
35 | }
36 | div.cleanblue .cleanbluemessage{
37 | padding: 10px;
38 | line-height: 20px;
39 | font-size: 11px;
40 | color: #333333;
41 | }
42 | div.cleanblue .cleanbluebuttons{
43 | text-align: right;
44 | padding: 5px 0 5px 0;
45 | border: solid 1px #eeeeee;
46 | background-color: #f4f4f4;
47 | }
48 | div.cleanblue button{
49 | padding: 3px 10px;
50 | margin: 0 10px;
51 | background-color: #314e90;
52 | border: solid 1px #f4f4f4;
53 | color: #ffffff;
54 | font-weight: bold;
55 | font-size: 12px;
56 | }
57 | div.cleanblue button:hover{
58 | border: solid 1px #d4d4d4;
59 | }
60 |
--------------------------------------------------------------------------------
/src/themes/ext-blue.css:
--------------------------------------------------------------------------------
1 | /*
2 | ------------------------------
3 | Ext Blue
4 | ------------------------------
5 | */
6 | .extbluewarning .extblue{
7 | border:1px red solid;
8 | }
9 | .extbluefade{
10 | position: absolute;
11 | background-color: #ffffff;
12 | }
13 | div.extblue{
14 | border:1px #6289B6 solid;
15 | position: absolute;
16 | background-color: #CAD8EA;
17 | padding: 0;
18 | width: 300px;
19 | text-align: left;
20 | }
21 | div.extblue .extblueclose{
22 | background-color: #CAD8EA;
23 | margin:2px -2px 0 0;
24 | cursor: pointer;
25 | color: red;
26 | text-align: right;
27 | }
28 | div.extblue .extbluecontainer{
29 | background-color: #CAD8EA;
30 | padding: 0 5px 5px 5px;
31 | color: #000000;
32 | font:normal 11px Verdana;
33 | }
34 | div.extblue .extbluemessage{
35 | background-color: #CAD8EA;
36 | padding: 0;
37 | margin:0 15px 15px 15px;
38 | }
39 | div.extblue .extbluebuttons{
40 | text-align: center;
41 | padding: 0px 0 0 0;
42 | }
43 | div.extblue button{
44 | padding: 1px 4px;
45 | margin: 0 10px;
46 | background-color:#cccccc;
47 | font-weight:normal;
48 | font-family:Verdana;
49 | font-size:10px;
50 | }
51 |
--------------------------------------------------------------------------------
/src/themes/smooth.css:
--------------------------------------------------------------------------------
1 | /*
2 | ------------------------------
3 | Smooth
4 | ------------------------------
5 | */
6 | .jqismoothfade{
7 | position: absolute;
8 | background-color: #333333;
9 | }
10 | div.jqismooth{
11 | width: 350px;
12 | font-family: Verdana, Geneva, Arial, Helvetica, sans-serif;
13 | position: absolute;
14 | background-color: #ffffff;
15 | font-size: 11px;
16 | text-align: left;
17 | border: solid 3px #e2e8e6;
18 | -moz-border-radius: 10px;
19 | -webkit-border-radius: 10px;
20 | padding: 7px;
21 | }
22 | div.jqismooth .jqismoothcontainer{
23 | font-weight: bold;
24 | }
25 | div.jqismooth .jqismoothclose{
26 | position: absolute;
27 | top: 0;
28 | right: 0;
29 | width: 18px;
30 | cursor: default;
31 | text-align: center;
32 | padding: 2px 0 4px 0;
33 | color: #727876;
34 | font-weight: bold;
35 | background-color: #e2e8e6;
36 | -moz-border-radius-bottomLeft: 5px;
37 | -webkit-border-bottom-left-radius: 5px;
38 | border-left: solid 1px #e2e8e6;
39 | border-bottom: solid 1px #e2e8e6;
40 | }
41 | div.jqismooth .jqismoothmessage{
42 | padding: 10px;
43 | line-height: 20px;
44 | color: #444444;
45 | }
46 | div.jqismooth .jqismoothbuttons{
47 | text-align: right;
48 | padding: 5px 0 5px 0;
49 | border: solid 1px #e2e8e6;
50 | background-color: #f2f8f6;
51 | }
52 | div.jqismooth button{
53 | padding: 3px 10px;
54 | margin: 0 10px;
55 | background-color: #2F6073;
56 | border: solid 1px #f4f4f4;
57 | color: #ffffff;
58 | font-weight: bold;
59 | font-size: 12px;
60 | }
61 | div.jqismooth button:hover{
62 | background-color: #728A8C;
63 | }
64 | div.jqismooth button.jqismoothdefaultbutton{
65 | background-color: #BF5E26;
66 | }
67 | .jqismoothwarning .jqismooth .jqismoothbuttons{
68 | background-color: #BF5E26;
69 | }
70 |
--------------------------------------------------------------------------------
/src/themes/zoo.css:
--------------------------------------------------------------------------------
1 | /* The Impromptzoo theme by Trent Richardson, based on http://stammtec.de/work/upload-dialog/ */
2 |
3 | /* layout */
4 | .jqizoofade{ position: absolute; background-color: #000; }
5 | div.jqizoo{ width: 400px; font-family: Verdana, Geneva, Arial, Helvetica, sans-serif; position: absolute; background-color: #ffffff; font-size: 11px; text-align: left;
6 | border: solid 2px #333; border-radius: 5px; -moz-border-radius: 5px; -webkit-border-radius: 5px; }
7 |
8 | /* container */
9 | div.jqizoo .jqizoocontainer{ background-color: #5b6776; }
10 | div.jqizoo .jqizooclose{ position: absolute; top: 0; right: 8px; width: 20px; padding: 2px 0 2px 0; text-align: center; cursor: default; color: #fff; font-weight: bold; text-shadow: 1px 1px 1px #333;
11 | background-color: #d4797b; background-image: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#d4797b), to(#b34b4d)); background-image: -webkit-linear-gradient(top, #d4797b, #b34b4d); background-image: -moz-linear-gradient(top, #d4797b, #b34b4d); background-image: -ms-linear-gradient(top, #d4797b, #b34b4d); background-image: -o-linear-gradient(top, #d4797b, #b34b4d);
12 | border: solid 1px #555; border-top: none; border-radius: 0 0 5px 5px; -moz-border-radius: 0 0 5px 5px; -webkit-border-radius: 0 0 5px 5px;}
13 | div.jqizoo .jqizootitle{ padding: 10px 10px; font-size: 14px; color: #333; line-height: 20px; text-align: center; text-shadow: 1px 1px 1px #999; letter-spacing: 1px;
14 | background-color: #f0f0f0; background-image: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#f0f0f0), to(#dbdbdb)); background-image: -webkit-linear-gradient(top, #f0f0f0, #dbdbdb); background-image: -moz-linear-gradient(top, #f0f0f0, #dbdbdb); background-image: -ms-linear-gradient(top, #f0f0f0, #dbdbdb); background-image: -o-linear-gradient(top, #f0f0f0, #dbdbdb);
15 | border-bottom: solid 1px #949494; border-radius: 5px 5px 0 0; -moz-border-radius: 5px 5px 0 0; -webkit-border-radius: 5px 5px 0 0; }
16 | div.jqizoo .jqizoomessage{ padding: 10px; line-height: 20px; color: #444444; background-color: #fff;
17 | border-bottom: solid 1px #333; border-radius: 0 0 5px 5px; -moz-border-radius: 0 0 5px 5px; -webkit-border-radius: 0 0 5px 5px; }
18 |
19 | /* buttons */
20 | div.jqizoo .jqizoobuttons{ text-align: right; padding: 6px 0 6px 0;
21 | background-color: #5b6776; background-image: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#5b6776), to(#303940)); background-image: -webkit-linear-gradient(top, #5b6776, #303940); background-image: -moz-linear-gradient(top, #5b6776, #303940); background-image: -ms-linear-gradient(top, #5b6776, #303940); background-image: -o-linear-gradient(top, #5b6776, #303940);
22 | border-radius: 0 0 5px 5px; -moz-border-radius: 0 0 5px 5px; -webkit-border-radius: 0 0 5px 5px; }
23 | div.jqizoo button{ padding: 3px 10px; margin: 0 10px; background-color: #2F6073; color: #ffffff; font-weight: bold; font-size: 12px; text-shadow: 1px 1px 1px #333;
24 | background-color: #78a0ce; background-image: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#78a0ce), to(#516cb6)); background-image: -webkit-linear-gradient(top, #78a0ce, #516cb6); background-image: -moz-linear-gradient(top, #78a0ce, #516cb6); background-image: -ms-linear-gradient(top, #78a0ce, #516cb6); background-image: -o-linear-gradient(top, #78a0ce, #516cb6);
25 | /* yellow background-color: #dab150; background-image: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#dab150), to(#c49629)); background-image: -webkit-linear-gradient(top, #dab150, #c49629); background-image: -moz-linear-gradient(top, #dab150, #c49629); background-image: -ms-linear-gradient(top, #dab150, #c49629); background-image: -o-linear-gradient(top, #dab150, #c49629); */
26 | border: solid 1px #192432; border-radius: 3px; -moz-border-radius: 3px; -webkit-border-radius: 3px; }
27 | div.jqizoo button:hover{ color: #eee; }
28 | div.jqizoo button.jqizoodefaultbutton{ background-color: #d4797b; background-image: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#d4797b), to(#b34b4d)); background-image: -webkit-linear-gradient(top, #d4797b, #b34b4d); background-image: -moz-linear-gradient(top, #d4797b, #b34b4d); background-image: -ms-linear-gradient(top, #d4797b, #b34b4d); background-image: -o-linear-gradient(top, #d4797b, #b34b4d); }
29 | .jqizoowarning .jqizoo .jqizoobuttons button{ border-color: #dab150; }
30 |
31 | /* arrows */
32 | .jqizoo .jqizooarrow{ position: absolute; height: 0; width:0; line-height: 0; font-size: 0; border: solid 10px transparent; }
33 | .jqizoo .jqizooarrowtl{ left: 10px; top: -20px; border-bottom-color: #333; }
34 | .jqizoo .jqizooarrowtc{ left: 50%; top: -20px; border-bottom-color: #333; margin-left: -10px; }
35 | .jqizoo .jqizooarrowtr{ right: 10px; top: -20px; border-bottom-color: #333; }
36 | .jqizoo .jqizooarrowbl{ left: 10px; bottom: -20px; border-top-color: #333; }
37 | .jqizoo .jqizooarrowbc{ left: 50%; bottom: -20px; border-top-color: #333; margin-left: -10px; }
38 | .jqizoo .jqizooarrowbr{ right: 10px; bottom: -20px; border-top-color: #333; }
39 | .jqizoo .jqizooarrowlt{ left: -20px; top: 10px; border-right-color: #333; }
40 | .jqizoo .jqizooarrowlm{ left: -20px; top: 50%; border-right-color: #333; margin-top: -10px; }
41 | .jqizoo .jqizooarrowlb{ left: -20px; bottom: 10px; border-right-color: #333; }
42 | .jqizoo .jqizooarrowrt{ right: -20px; top: 10px; border-left-color: #333; }
43 | .jqizoo .jqizooarrowrm{ right: -20px; top: 50%; border-left-color: #333; margin-top: -10px; }
44 | .jqizoo .jqizooarrowrb{ right: -20px; bottom: 10px; border-left-color: #333; }
--------------------------------------------------------------------------------
/test/.jshintrc:
--------------------------------------------------------------------------------
1 | {
2 | "curly": true,
3 | "eqeqeq": true,
4 | "immed": true,
5 | "latedef": true,
6 | "newcap": true,
7 | "noarg": true,
8 | "sub": true,
9 | "undef": true,
10 | "unused": true,
11 | "boss": true,
12 | "eqnull": true,
13 | "browser": true,
14 | "predef": [
15 | "jQuery",
16 | "$",
17 | "QUnit",
18 | "module",
19 | "test",
20 | "asyncTest",
21 | "expect",
22 | "start",
23 | "stop",
24 | "ok",
25 | "equal",
26 | "notEqual",
27 | "deepEqual",
28 | "notDeepEqual",
29 | "strictEqual",
30 | "notStrictEqual",
31 | "throws",
32 | "describe",
33 | "it",
34 | "beforeEach",
35 | "afterEach",
36 | "spyOn",
37 | "spyOnEvent",
38 | "runs",
39 | "waitsFor",
40 | "affix",
41 | "xdescribe",
42 | "xit",
43 | "Impromptu",
44 | "Event"
45 | ]
46 | }
--------------------------------------------------------------------------------
/test/SpecRunner.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | jquery-impromptu Jasmine Spec Runner v2.0.3
6 |
7 |
8 |
9 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 |
30 |
31 |
32 |
--------------------------------------------------------------------------------
/test/lib/jasmine-2.0.3/boot.js:
--------------------------------------------------------------------------------
1 | /**
2 | Starting with version 2.0, this file "boots" Jasmine, performing all of the necessary initialization before executing the loaded environment and all of a project's specs. This file should be loaded after `jasmine.js`, but before any project source files or spec files are loaded. Thus this file can also be used to customize Jasmine for a project.
3 |
4 | If a project is using Jasmine via the standalone distribution, this file can be customized directly. If a project is using Jasmine via the [Ruby gem][jasmine-gem], this file can be copied into the support directory via `jasmine copy_boot_js`. Other environments (e.g., Python) will have different mechanisms.
5 |
6 | The location of `boot.js` can be specified and/or overridden in `jasmine.yml`.
7 |
8 | [jasmine-gem]: http://github.com/pivotal/jasmine-gem
9 | */
10 |
11 | (function() {
12 |
13 | /**
14 | * ## Require & Instantiate
15 | *
16 | * Require Jasmine's core files. Specifically, this requires and attaches all of Jasmine's code to the `jasmine` reference.
17 | */
18 | window.jasmine = jasmineRequire.core(jasmineRequire);
19 |
20 | /**
21 | * Since this is being run in a browser and the results should populate to an HTML page, require the HTML-specific Jasmine code, injecting the same reference.
22 | */
23 | jasmineRequire.html(jasmine);
24 |
25 | /**
26 | * Create the Jasmine environment. This is used to run all specs in a project.
27 | */
28 | var env = jasmine.getEnv();
29 |
30 | /**
31 | * ## The Global Interface
32 | *
33 | * Build up the functions that will be exposed as the Jasmine public interface. A project can customize, rename or alias any of these functions as desired, provided the implementation remains unchanged.
34 | */
35 | var jasmineInterface = jasmineRequire.interface(jasmine, env);
36 |
37 | /**
38 | * Add all of the Jasmine global/public interface to the proper global, so a project can use the public interface directly. For example, calling `describe` in specs instead of `jasmine.getEnv().describe`.
39 | */
40 | if (typeof window == "undefined" && typeof exports == "object") {
41 | extend(exports, jasmineInterface);
42 | } else {
43 | extend(window, jasmineInterface);
44 | }
45 |
46 | /**
47 | * ## Runner Parameters
48 | *
49 | * More browser specific code - wrap the query string in an object and to allow for getting/setting parameters from the runner user interface.
50 | */
51 |
52 | var queryString = new jasmine.QueryString({
53 | getWindowLocation: function() { return window.location; }
54 | });
55 |
56 | var catchingExceptions = queryString.getParam("catch");
57 | env.catchExceptions(typeof catchingExceptions === "undefined" ? true : catchingExceptions);
58 |
59 | /**
60 | * ## Reporters
61 | * The `HtmlReporter` builds all of the HTML UI for the runner page. This reporter paints the dots, stars, and x's for specs, as well as all spec names and all failures (if any).
62 | */
63 | var htmlReporter = new jasmine.HtmlReporter({
64 | env: env,
65 | onRaiseExceptionsClick: function() { queryString.setParam("catch", !env.catchingExceptions()); },
66 | getContainer: function() { return document.body; },
67 | createElement: function() { return document.createElement.apply(document, arguments); },
68 | createTextNode: function() { return document.createTextNode.apply(document, arguments); },
69 | timer: new jasmine.Timer()
70 | });
71 |
72 | /**
73 | * The `jsApiReporter` also receives spec results, and is used by any environment that needs to extract the results from JavaScript.
74 | */
75 | env.addReporter(jasmineInterface.jsApiReporter);
76 | env.addReporter(htmlReporter);
77 |
78 | /**
79 | * Filter which specs will be run by matching the start of the full name against the `spec` query param.
80 | */
81 | var specFilter = new jasmine.HtmlSpecFilter({
82 | filterString: function() { return queryString.getParam("spec"); }
83 | });
84 |
85 | env.specFilter = function(spec) {
86 | return specFilter.matches(spec.getFullName());
87 | };
88 |
89 | /**
90 | * Setting up timing functions to be able to be overridden. Certain browsers (Safari, IE 8, phantomjs) require this hack.
91 | */
92 | window.setTimeout = window.setTimeout;
93 | window.setInterval = window.setInterval;
94 | window.clearTimeout = window.clearTimeout;
95 | window.clearInterval = window.clearInterval;
96 |
97 | /**
98 | * ## Execution
99 | *
100 | * Replace the browser window's `onload`, ensure it's called, and then run all of the loaded specs. This includes initializing the `HtmlReporter` instance and then executing the loaded Jasmine environment. All of this will happen after all of the specs are loaded.
101 | */
102 | var currentWindowOnload = window.onload;
103 |
104 | window.onload = function() {
105 | if (currentWindowOnload) {
106 | currentWindowOnload();
107 | }
108 | htmlReporter.initialize();
109 | env.execute();
110 | };
111 |
112 | /**
113 | * Helper function for readability above.
114 | */
115 | function extend(destination, source) {
116 | for (var property in source) destination[property] = source[property];
117 | return destination;
118 | }
119 |
120 | }());
121 |
--------------------------------------------------------------------------------
/test/lib/jasmine-2.0.3/console.js:
--------------------------------------------------------------------------------
1 | /*
2 | Copyright (c) 2008-2014 Pivotal Labs
3 |
4 | Permission is hereby granted, free of charge, to any person obtaining
5 | a copy of this software and associated documentation files (the
6 | "Software"), to deal in the Software without restriction, including
7 | without limitation the rights to use, copy, modify, merge, publish,
8 | distribute, sublicense, and/or sell copies of the Software, and to
9 | permit persons to whom the Software is furnished to do so, subject to
10 | the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be
13 | included in all copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
16 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
17 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
18 | NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
19 | LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
20 | OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
21 | WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
22 | */
23 | function getJasmineRequireObj() {
24 | if (typeof module !== 'undefined' && module.exports) {
25 | return exports;
26 | } else {
27 | window.jasmineRequire = window.jasmineRequire || {};
28 | return window.jasmineRequire;
29 | }
30 | }
31 |
32 | getJasmineRequireObj().console = function(jRequire, j$) {
33 | j$.ConsoleReporter = jRequire.ConsoleReporter();
34 | };
35 |
36 | getJasmineRequireObj().ConsoleReporter = function() {
37 |
38 | var noopTimer = {
39 | start: function(){},
40 | elapsed: function(){ return 0; }
41 | };
42 |
43 | function ConsoleReporter(options) {
44 | var print = options.print,
45 | showColors = options.showColors || false,
46 | onComplete = options.onComplete || function() {},
47 | timer = options.timer || noopTimer,
48 | specCount,
49 | failureCount,
50 | failedSpecs = [],
51 | pendingCount,
52 | ansi = {
53 | green: '\x1B[32m',
54 | red: '\x1B[31m',
55 | yellow: '\x1B[33m',
56 | none: '\x1B[0m'
57 | };
58 |
59 | this.jasmineStarted = function() {
60 | specCount = 0;
61 | failureCount = 0;
62 | pendingCount = 0;
63 | print('Started');
64 | printNewline();
65 | timer.start();
66 | };
67 |
68 | this.jasmineDone = function() {
69 | printNewline();
70 | for (var i = 0; i < failedSpecs.length; i++) {
71 | specFailureDetails(failedSpecs[i]);
72 | }
73 |
74 | if(specCount > 0) {
75 | printNewline();
76 |
77 | var specCounts = specCount + ' ' + plural('spec', specCount) + ', ' +
78 | failureCount + ' ' + plural('failure', failureCount);
79 |
80 | if (pendingCount) {
81 | specCounts += ', ' + pendingCount + ' pending ' + plural('spec', pendingCount);
82 | }
83 |
84 | print(specCounts);
85 | } else {
86 | print('No specs found');
87 | }
88 |
89 | printNewline();
90 | var seconds = timer.elapsed() / 1000;
91 | print('Finished in ' + seconds + ' ' + plural('second', seconds));
92 |
93 | printNewline();
94 |
95 | onComplete(failureCount === 0);
96 | };
97 |
98 | this.specDone = function(result) {
99 | specCount++;
100 |
101 | if (result.status == 'pending') {
102 | pendingCount++;
103 | print(colored('yellow', '*'));
104 | return;
105 | }
106 |
107 | if (result.status == 'passed') {
108 | print(colored('green', '.'));
109 | return;
110 | }
111 |
112 | if (result.status == 'failed') {
113 | failureCount++;
114 | failedSpecs.push(result);
115 | print(colored('red', 'F'));
116 | }
117 | };
118 |
119 | return this;
120 |
121 | function printNewline() {
122 | print('\n');
123 | }
124 |
125 | function colored(color, str) {
126 | return showColors ? (ansi[color] + str + ansi.none) : str;
127 | }
128 |
129 | function plural(str, count) {
130 | return count == 1 ? str : str + 's';
131 | }
132 |
133 | function repeat(thing, times) {
134 | var arr = [];
135 | for (var i = 0; i < times; i++) {
136 | arr.push(thing);
137 | }
138 | return arr;
139 | }
140 |
141 | function indent(str, spaces) {
142 | var lines = (str || '').split('\n');
143 | var newArr = [];
144 | for (var i = 0; i < lines.length; i++) {
145 | newArr.push(repeat(' ', spaces).join('') + lines[i]);
146 | }
147 | return newArr.join('\n');
148 | }
149 |
150 | function specFailureDetails(result) {
151 | printNewline();
152 | print(result.fullName);
153 |
154 | for (var i = 0; i < result.failedExpectations.length; i++) {
155 | var failedExpectation = result.failedExpectations[i];
156 | printNewline();
157 | print(indent(failedExpectation.message, 2));
158 | print(indent(failedExpectation.stack, 2));
159 | }
160 |
161 | printNewline();
162 | }
163 | }
164 |
165 | return ConsoleReporter;
166 | };
167 |
--------------------------------------------------------------------------------
/test/lib/jasmine-2.0.3/jasmine-html.js:
--------------------------------------------------------------------------------
1 | /*
2 | Copyright (c) 2008-2014 Pivotal Labs
3 |
4 | Permission is hereby granted, free of charge, to any person obtaining
5 | a copy of this software and associated documentation files (the
6 | "Software"), to deal in the Software without restriction, including
7 | without limitation the rights to use, copy, modify, merge, publish,
8 | distribute, sublicense, and/or sell copies of the Software, and to
9 | permit persons to whom the Software is furnished to do so, subject to
10 | the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be
13 | included in all copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
16 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
17 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
18 | NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
19 | LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
20 | OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
21 | WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
22 | */
23 | jasmineRequire.html = function(j$) {
24 | j$.ResultsNode = jasmineRequire.ResultsNode();
25 | j$.HtmlReporter = jasmineRequire.HtmlReporter(j$);
26 | j$.QueryString = jasmineRequire.QueryString();
27 | j$.HtmlSpecFilter = jasmineRequire.HtmlSpecFilter();
28 | };
29 |
30 | jasmineRequire.HtmlReporter = function(j$) {
31 |
32 | var noopTimer = {
33 | start: function() {},
34 | elapsed: function() { return 0; }
35 | };
36 |
37 | function HtmlReporter(options) {
38 | var env = options.env || {},
39 | getContainer = options.getContainer,
40 | createElement = options.createElement,
41 | createTextNode = options.createTextNode,
42 | onRaiseExceptionsClick = options.onRaiseExceptionsClick || function() {},
43 | timer = options.timer || noopTimer,
44 | results = [],
45 | specsExecuted = 0,
46 | failureCount = 0,
47 | pendingSpecCount = 0,
48 | htmlReporterMain,
49 | symbols;
50 |
51 | this.initialize = function() {
52 | clearPrior();
53 | htmlReporterMain = createDom('div', {className: 'jasmine_html-reporter'},
54 | createDom('div', {className: 'banner'},
55 | createDom('a', {className: 'title', href: 'http://jasmine.github.io/', target: '_blank'}),
56 | createDom('span', {className: 'version'}, j$.version)
57 | ),
58 | createDom('ul', {className: 'symbol-summary'}),
59 | createDom('div', {className: 'alert'}),
60 | createDom('div', {className: 'results'},
61 | createDom('div', {className: 'failures'})
62 | )
63 | );
64 | getContainer().appendChild(htmlReporterMain);
65 |
66 | symbols = find('.symbol-summary');
67 | };
68 |
69 | var totalSpecsDefined;
70 | this.jasmineStarted = function(options) {
71 | totalSpecsDefined = options.totalSpecsDefined || 0;
72 | timer.start();
73 | };
74 |
75 | var summary = createDom('div', {className: 'summary'});
76 |
77 | var topResults = new j$.ResultsNode({}, '', null),
78 | currentParent = topResults;
79 |
80 | this.suiteStarted = function(result) {
81 | currentParent.addChild(result, 'suite');
82 | currentParent = currentParent.last();
83 | };
84 |
85 | this.suiteDone = function(result) {
86 | if (currentParent == topResults) {
87 | return;
88 | }
89 |
90 | currentParent = currentParent.parent;
91 | };
92 |
93 | this.specStarted = function(result) {
94 | currentParent.addChild(result, 'spec');
95 | };
96 |
97 | var failures = [];
98 | this.specDone = function(result) {
99 | if(noExpectations(result) && console && console.error) {
100 | console.error('Spec \'' + result.fullName + '\' has no expectations.');
101 | }
102 |
103 | if (result.status != 'disabled') {
104 | specsExecuted++;
105 | }
106 |
107 | symbols.appendChild(createDom('li', {
108 | className: noExpectations(result) ? 'empty' : result.status,
109 | id: 'spec_' + result.id,
110 | title: result.fullName
111 | }
112 | ));
113 |
114 | if (result.status == 'failed') {
115 | failureCount++;
116 |
117 | var failure =
118 | createDom('div', {className: 'spec-detail failed'},
119 | createDom('div', {className: 'description'},
120 | createDom('a', {title: result.fullName, href: specHref(result)}, result.fullName)
121 | ),
122 | createDom('div', {className: 'messages'})
123 | );
124 | var messages = failure.childNodes[1];
125 |
126 | for (var i = 0; i < result.failedExpectations.length; i++) {
127 | var expectation = result.failedExpectations[i];
128 | messages.appendChild(createDom('div', {className: 'result-message'}, expectation.message));
129 | messages.appendChild(createDom('div', {className: 'stack-trace'}, expectation.stack));
130 | }
131 |
132 | failures.push(failure);
133 | }
134 |
135 | if (result.status == 'pending') {
136 | pendingSpecCount++;
137 | }
138 | };
139 |
140 | this.jasmineDone = function() {
141 | var banner = find('.banner');
142 | banner.appendChild(createDom('span', {className: 'duration'}, 'finished in ' + timer.elapsed() / 1000 + 's'));
143 |
144 | var alert = find('.alert');
145 |
146 | alert.appendChild(createDom('span', { className: 'exceptions' },
147 | createDom('label', { className: 'label', 'for': 'raise-exceptions' }, 'raise exceptions'),
148 | createDom('input', {
149 | className: 'raise',
150 | id: 'raise-exceptions',
151 | type: 'checkbox'
152 | })
153 | ));
154 | var checkbox = find('#raise-exceptions');
155 |
156 | checkbox.checked = !env.catchingExceptions();
157 | checkbox.onclick = onRaiseExceptionsClick;
158 |
159 | if (specsExecuted < totalSpecsDefined) {
160 | var skippedMessage = 'Ran ' + specsExecuted + ' of ' + totalSpecsDefined + ' specs - run all';
161 | alert.appendChild(
162 | createDom('span', {className: 'bar skipped'},
163 | createDom('a', {href: '?', title: 'Run all specs'}, skippedMessage)
164 | )
165 | );
166 | }
167 | var statusBarMessage = '';
168 | var statusBarClassName = 'bar ';
169 |
170 | if (totalSpecsDefined > 0) {
171 | statusBarMessage += pluralize('spec', specsExecuted) + ', ' + pluralize('failure', failureCount);
172 | if (pendingSpecCount) { statusBarMessage += ', ' + pluralize('pending spec', pendingSpecCount); }
173 | statusBarClassName += (failureCount > 0) ? 'failed' : 'passed';
174 | } else {
175 | statusBarClassName += 'skipped';
176 | statusBarMessage += 'No specs found';
177 | }
178 |
179 | alert.appendChild(createDom('span', {className: statusBarClassName}, statusBarMessage));
180 |
181 | var results = find('.results');
182 | results.appendChild(summary);
183 |
184 | summaryList(topResults, summary);
185 |
186 | function summaryList(resultsTree, domParent) {
187 | var specListNode;
188 | for (var i = 0; i < resultsTree.children.length; i++) {
189 | var resultNode = resultsTree.children[i];
190 | if (resultNode.type == 'suite') {
191 | var suiteListNode = createDom('ul', {className: 'suite', id: 'suite-' + resultNode.result.id},
192 | createDom('li', {className: 'suite-detail'},
193 | createDom('a', {href: specHref(resultNode.result)}, resultNode.result.description)
194 | )
195 | );
196 |
197 | summaryList(resultNode, suiteListNode);
198 | domParent.appendChild(suiteListNode);
199 | }
200 | if (resultNode.type == 'spec') {
201 | if (domParent.getAttribute('class') != 'specs') {
202 | specListNode = createDom('ul', {className: 'specs'});
203 | domParent.appendChild(specListNode);
204 | }
205 | var specDescription = resultNode.result.description;
206 | if(noExpectations(resultNode.result)) {
207 | specDescription = 'SPEC HAS NO EXPECTATIONS ' + specDescription;
208 | }
209 | specListNode.appendChild(
210 | createDom('li', {
211 | className: resultNode.result.status,
212 | id: 'spec-' + resultNode.result.id
213 | },
214 | createDom('a', {href: specHref(resultNode.result)}, specDescription)
215 | )
216 | );
217 | }
218 | }
219 | }
220 |
221 | if (failures.length) {
222 | alert.appendChild(
223 | createDom('span', {className: 'menu bar spec-list'},
224 | createDom('span', {}, 'Spec List | '),
225 | createDom('a', {className: 'failures-menu', href: '#'}, 'Failures')));
226 | alert.appendChild(
227 | createDom('span', {className: 'menu bar failure-list'},
228 | createDom('a', {className: 'spec-list-menu', href: '#'}, 'Spec List'),
229 | createDom('span', {}, ' | Failures ')));
230 |
231 | find('.failures-menu').onclick = function() {
232 | setMenuModeTo('failure-list');
233 | };
234 | find('.spec-list-menu').onclick = function() {
235 | setMenuModeTo('spec-list');
236 | };
237 |
238 | setMenuModeTo('failure-list');
239 |
240 | var failureNode = find('.failures');
241 | for (var i = 0; i < failures.length; i++) {
242 | failureNode.appendChild(failures[i]);
243 | }
244 | }
245 | };
246 |
247 | return this;
248 |
249 | function find(selector) {
250 | return getContainer().querySelector('.jasmine_html-reporter ' + selector);
251 | }
252 |
253 | function clearPrior() {
254 | // return the reporter
255 | var oldReporter = find('');
256 |
257 | if(oldReporter) {
258 | getContainer().removeChild(oldReporter);
259 | }
260 | }
261 |
262 | function createDom(type, attrs, childrenVarArgs) {
263 | var el = createElement(type);
264 |
265 | for (var i = 2; i < arguments.length; i++) {
266 | var child = arguments[i];
267 |
268 | if (typeof child === 'string') {
269 | el.appendChild(createTextNode(child));
270 | } else {
271 | if (child) {
272 | el.appendChild(child);
273 | }
274 | }
275 | }
276 |
277 | for (var attr in attrs) {
278 | if (attr == 'className') {
279 | el[attr] = attrs[attr];
280 | } else {
281 | el.setAttribute(attr, attrs[attr]);
282 | }
283 | }
284 |
285 | return el;
286 | }
287 |
288 | function pluralize(singular, count) {
289 | var word = (count == 1 ? singular : singular + 's');
290 |
291 | return '' + count + ' ' + word;
292 | }
293 |
294 | function specHref(result) {
295 | return '?spec=' + encodeURIComponent(result.fullName);
296 | }
297 |
298 | function setMenuModeTo(mode) {
299 | htmlReporterMain.setAttribute('class', 'jasmine_html-reporter ' + mode);
300 | }
301 |
302 | function noExpectations(result) {
303 | return (result.failedExpectations.length + result.passedExpectations.length) === 0 &&
304 | result.status === 'passed';
305 | }
306 | }
307 |
308 | return HtmlReporter;
309 | };
310 |
311 | jasmineRequire.HtmlSpecFilter = function() {
312 | function HtmlSpecFilter(options) {
313 | var filterString = options && options.filterString() && options.filterString().replace(/[-[\]{}()*+?.,\\^$|#\s]/g, '\\$&');
314 | var filterPattern = new RegExp(filterString);
315 |
316 | this.matches = function(specName) {
317 | return filterPattern.test(specName);
318 | };
319 | }
320 |
321 | return HtmlSpecFilter;
322 | };
323 |
324 | jasmineRequire.ResultsNode = function() {
325 | function ResultsNode(result, type, parent) {
326 | this.result = result;
327 | this.type = type;
328 | this.parent = parent;
329 |
330 | this.children = [];
331 |
332 | this.addChild = function(result, type) {
333 | this.children.push(new ResultsNode(result, type, this));
334 | };
335 |
336 | this.last = function() {
337 | return this.children[this.children.length - 1];
338 | };
339 | }
340 |
341 | return ResultsNode;
342 | };
343 |
344 | jasmineRequire.QueryString = function() {
345 | function QueryString(options) {
346 |
347 | this.setParam = function(key, value) {
348 | var paramMap = queryStringToParamMap();
349 | paramMap[key] = value;
350 | options.getWindowLocation().search = toQueryString(paramMap);
351 | };
352 |
353 | this.getParam = function(key) {
354 | return queryStringToParamMap()[key];
355 | };
356 |
357 | return this;
358 |
359 | function toQueryString(paramMap) {
360 | var qStrPairs = [];
361 | for (var prop in paramMap) {
362 | qStrPairs.push(encodeURIComponent(prop) + '=' + encodeURIComponent(paramMap[prop]));
363 | }
364 | return '?' + qStrPairs.join('&');
365 | }
366 |
367 | function queryStringToParamMap() {
368 | var paramStr = options.getWindowLocation().search.substring(1),
369 | params = [],
370 | paramMap = {};
371 |
372 | if (paramStr.length > 0) {
373 | params = paramStr.split('&');
374 | for (var i = 0; i < params.length; i++) {
375 | var p = params[i].split('=');
376 | var value = decodeURIComponent(p[1]);
377 | if (value === 'true' || value === 'false') {
378 | value = JSON.parse(value);
379 | }
380 | paramMap[decodeURIComponent(p[0])] = value;
381 | }
382 | }
383 |
384 | return paramMap;
385 | }
386 |
387 | }
388 |
389 | return QueryString;
390 | };
391 |
--------------------------------------------------------------------------------
/test/lib/jasmine-2.0.3/jasmine.css:
--------------------------------------------------------------------------------
1 | body { overflow-y: scroll; }
2 |
3 | .jasmine_html-reporter { background-color: #eeeeee; padding: 5px; margin: -8px; font-size: 11px; font-family: Monaco, "Lucida Console", monospace; line-height: 14px; color: #333333; }
4 | .jasmine_html-reporter a { text-decoration: none; }
5 | .jasmine_html-reporter a:hover { text-decoration: underline; }
6 | .jasmine_html-reporter p, .jasmine_html-reporter h1, .jasmine_html-reporter h2, .jasmine_html-reporter h3, .jasmine_html-reporter h4, .jasmine_html-reporter h5, .jasmine_html-reporter h6 { margin: 0; line-height: 14px; }
7 | .jasmine_html-reporter .banner, .jasmine_html-reporter .symbol-summary, .jasmine_html-reporter .summary, .jasmine_html-reporter .result-message, .jasmine_html-reporter .spec .description, .jasmine_html-reporter .spec-detail .description, .jasmine_html-reporter .alert .bar, .jasmine_html-reporter .stack-trace { padding-left: 9px; padding-right: 9px; }
8 | .jasmine_html-reporter .banner { position: relative; }
9 | .jasmine_html-reporter .banner .title { background: url('') no-repeat; background: url('') no-repeat, none; -webkit-background-size: 100%; -moz-background-size: 100%; -o-background-size: 100%; background-size: 100%; display: block; float: left; width: 90px; height: 25px; }
10 | .jasmine_html-reporter .banner .version { margin-left: 14px; position: relative; top: 6px; }
11 | .jasmine_html-reporter .banner .duration { position: absolute; right: 14px; top: 6px; }
12 | .jasmine_html-reporter #jasmine_content { position: fixed; right: 100%; }
13 | .jasmine_html-reporter .version { color: #aaaaaa; }
14 | .jasmine_html-reporter .banner { margin-top: 14px; }
15 | .jasmine_html-reporter .duration { color: #aaaaaa; float: right; }
16 | .jasmine_html-reporter .symbol-summary { overflow: hidden; *zoom: 1; margin: 14px 0; }
17 | .jasmine_html-reporter .symbol-summary li { display: inline-block; height: 8px; width: 14px; font-size: 16px; }
18 | .jasmine_html-reporter .symbol-summary li.passed { font-size: 14px; }
19 | .jasmine_html-reporter .symbol-summary li.passed:before { color: #007069; content: "\02022"; }
20 | .jasmine_html-reporter .symbol-summary li.failed { line-height: 9px; }
21 | .jasmine_html-reporter .symbol-summary li.failed:before { color: #ca3a11; content: "\d7"; font-weight: bold; margin-left: -1px; }
22 | .jasmine_html-reporter .symbol-summary li.disabled { font-size: 14px; }
23 | .jasmine_html-reporter .symbol-summary li.disabled:before { color: #bababa; content: "\02022"; }
24 | .jasmine_html-reporter .symbol-summary li.pending { line-height: 17px; }
25 | .jasmine_html-reporter .symbol-summary li.pending:before { color: #ba9d37; content: "*"; }
26 | .jasmine_html-reporter .symbol-summary li.empty { font-size: 14px; }
27 | .jasmine_html-reporter .symbol-summary li.empty:before { color: #ba9d37; content: "\02022"; }
28 | .jasmine_html-reporter .exceptions { color: #fff; float: right; margin-top: 5px; margin-right: 5px; }
29 | .jasmine_html-reporter .bar { line-height: 28px; font-size: 14px; display: block; color: #eee; }
30 | .jasmine_html-reporter .bar.failed { background-color: #ca3a11; }
31 | .jasmine_html-reporter .bar.passed { background-color: #007069; }
32 | .jasmine_html-reporter .bar.skipped { background-color: #bababa; }
33 | .jasmine_html-reporter .bar.menu { background-color: #fff; color: #aaaaaa; }
34 | .jasmine_html-reporter .bar.menu a { color: #333333; }
35 | .jasmine_html-reporter .bar a { color: white; }
36 | .jasmine_html-reporter.spec-list .bar.menu.failure-list, .jasmine_html-reporter.spec-list .results .failures { display: none; }
37 | .jasmine_html-reporter.failure-list .bar.menu.spec-list, .jasmine_html-reporter.failure-list .summary { display: none; }
38 | .jasmine_html-reporter .running-alert { background-color: #666666; }
39 | .jasmine_html-reporter .results { margin-top: 14px; }
40 | .jasmine_html-reporter.showDetails .summaryMenuItem { font-weight: normal; text-decoration: inherit; }
41 | .jasmine_html-reporter.showDetails .summaryMenuItem:hover { text-decoration: underline; }
42 | .jasmine_html-reporter.showDetails .detailsMenuItem { font-weight: bold; text-decoration: underline; }
43 | .jasmine_html-reporter.showDetails .summary { display: none; }
44 | .jasmine_html-reporter.showDetails #details { display: block; }
45 | .jasmine_html-reporter .summaryMenuItem { font-weight: bold; text-decoration: underline; }
46 | .jasmine_html-reporter .summary { margin-top: 14px; }
47 | .jasmine_html-reporter .summary ul { list-style-type: none; margin-left: 14px; padding-top: 0; padding-left: 0; }
48 | .jasmine_html-reporter .summary ul.suite { margin-top: 7px; margin-bottom: 7px; }
49 | .jasmine_html-reporter .summary li.passed a { color: #007069; }
50 | .jasmine_html-reporter .summary li.failed a { color: #ca3a11; }
51 | .jasmine_html-reporter .summary li.empty a { color: #ba9d37; }
52 | .jasmine_html-reporter .summary li.pending a { color: #ba9d37; }
53 | .jasmine_html-reporter .description + .suite { margin-top: 0; }
54 | .jasmine_html-reporter .suite { margin-top: 14px; }
55 | .jasmine_html-reporter .suite a { color: #333333; }
56 | .jasmine_html-reporter .failures .spec-detail { margin-bottom: 28px; }
57 | .jasmine_html-reporter .failures .spec-detail .description { background-color: #ca3a11; }
58 | .jasmine_html-reporter .failures .spec-detail .description a { color: white; }
59 | .jasmine_html-reporter .result-message { padding-top: 14px; color: #333333; white-space: pre; }
60 | .jasmine_html-reporter .result-message span.result { display: block; }
61 | .jasmine_html-reporter .stack-trace { margin: 5px 0 0 0; max-height: 224px; overflow: auto; line-height: 18px; color: #666666; border: 1px solid #ddd; background: white; white-space: pre; }
62 |
--------------------------------------------------------------------------------
/test/lib/jasmine-2.0.3/jasmine_favicon.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/trentrichardson/jQuery-Impromptu/ef9596d302c2fa3fd7f789cdb192b12127934ee8/test/lib/jasmine-2.0.3/jasmine_favicon.png
--------------------------------------------------------------------------------
/test/lib/jasmine-jquery.js:
--------------------------------------------------------------------------------
1 | /*!
2 | Jasmine-jQuery: a set of jQuery helpers for Jasmine tests.
3 |
4 | Version 2.0.5
5 |
6 | https://github.com/velesin/jasmine-jquery
7 |
8 | Copyright (c) 2010-2014 Wojciech Zawistowski, Travis Jeffery
9 |
10 | Permission is hereby granted, free of charge, to any person obtaining
11 | a copy of this software and associated documentation files (the
12 | "Software"), to deal in the Software without restriction, including
13 | without limitation the rights to use, copy, modify, merge, publish,
14 | distribute, sublicense, and/or sell copies of the Software, and to
15 | permit persons to whom the Software is furnished to do so, subject to
16 | the following conditions:
17 |
18 | The above copyright notice and this permission notice shall be
19 | included in all copies or substantial portions of the Software.
20 |
21 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
22 | EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
23 | MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
24 | NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
25 | LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
26 | OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
27 | WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
28 | */
29 |
30 | +function (window, jasmine, $) { "use strict";
31 |
32 | jasmine.spiedEventsKey = function (selector, eventName) {
33 | return [$(selector).selector, eventName].toString()
34 | }
35 |
36 | jasmine.getFixtures = function () {
37 | return jasmine.currentFixtures_ = jasmine.currentFixtures_ || new jasmine.Fixtures()
38 | }
39 |
40 | jasmine.getStyleFixtures = function () {
41 | return jasmine.currentStyleFixtures_ = jasmine.currentStyleFixtures_ || new jasmine.StyleFixtures()
42 | }
43 |
44 | jasmine.Fixtures = function () {
45 | this.containerId = 'jasmine-fixtures'
46 | this.fixturesCache_ = {}
47 | this.fixturesPath = 'spec/javascripts/fixtures'
48 | }
49 |
50 | jasmine.Fixtures.prototype.set = function (html) {
51 | this.cleanUp()
52 | return this.createContainer_(html)
53 | }
54 |
55 | jasmine.Fixtures.prototype.appendSet= function (html) {
56 | this.addToContainer_(html)
57 | }
58 |
59 | jasmine.Fixtures.prototype.preload = function () {
60 | this.read.apply(this, arguments)
61 | }
62 |
63 | jasmine.Fixtures.prototype.load = function () {
64 | this.cleanUp()
65 | this.createContainer_(this.read.apply(this, arguments))
66 | }
67 |
68 | jasmine.Fixtures.prototype.appendLoad = function () {
69 | this.addToContainer_(this.read.apply(this, arguments))
70 | }
71 |
72 | jasmine.Fixtures.prototype.read = function () {
73 | var htmlChunks = []
74 | , fixtureUrls = arguments
75 |
76 | for(var urlCount = fixtureUrls.length, urlIndex = 0; urlIndex < urlCount; urlIndex++) {
77 | htmlChunks.push(this.getFixtureHtml_(fixtureUrls[urlIndex]))
78 | }
79 |
80 | return htmlChunks.join('')
81 | }
82 |
83 | jasmine.Fixtures.prototype.clearCache = function () {
84 | this.fixturesCache_ = {}
85 | }
86 |
87 | jasmine.Fixtures.prototype.cleanUp = function () {
88 | $('#' + this.containerId).remove()
89 | }
90 |
91 | jasmine.Fixtures.prototype.sandbox = function (attributes) {
92 | var attributesToSet = attributes || {}
93 | return $('').attr(attributesToSet)
94 | }
95 |
96 | jasmine.Fixtures.prototype.createContainer_ = function (html) {
97 | var container = $('')
98 | .attr('id', this.containerId)
99 | .html(html)
100 |
101 | $(document.body).append(container)
102 | return container
103 | }
104 |
105 | jasmine.Fixtures.prototype.addToContainer_ = function (html){
106 | var container = $(document.body).find('#'+this.containerId).append(html)
107 |
108 | if (!container.length) {
109 | this.createContainer_(html)
110 | }
111 | }
112 |
113 | jasmine.Fixtures.prototype.getFixtureHtml_ = function (url) {
114 | if (typeof this.fixturesCache_[url] === 'undefined') {
115 | this.loadFixtureIntoCache_(url)
116 | }
117 | return this.fixturesCache_[url]
118 | }
119 |
120 | jasmine.Fixtures.prototype.loadFixtureIntoCache_ = function (relativeUrl) {
121 | var self = this
122 | , url = this.makeFixtureUrl_(relativeUrl)
123 | , htmlText = ''
124 | , request = $.ajax({
125 | async: false, // must be synchronous to guarantee that no tests are run before fixture is loaded
126 | cache: false,
127 | url: url,
128 | success: function (data, status, $xhr) {
129 | htmlText = $xhr.responseText
130 | }
131 | }).fail(function ($xhr, status, err) {
132 | throw new Error('Fixture could not be loaded: ' + url + ' (status: ' + status + ', message: ' + err.message + ')')
133 | })
134 |
135 | var scripts = $($.parseHTML(htmlText, true)).find('script[src]') || [];
136 |
137 | scripts.each(function(){
138 | $.ajax({
139 | async: false, // must be synchronous to guarantee that no tests are run before fixture is loaded
140 | cache: false,
141 | dataType: 'script',
142 | url: $(this).attr('src'),
143 | success: function (data, status, $xhr) {
144 | htmlText += ''
145 | },
146 | error: function ($xhr, status, err) {
147 | throw new Error('Script could not be loaded: ' + scriptSrc + ' (status: ' + status + ', message: ' + err.message + ')')
148 | }
149 | });
150 | })
151 |
152 | self.fixturesCache_[relativeUrl] = htmlText;
153 | }
154 |
155 | jasmine.Fixtures.prototype.makeFixtureUrl_ = function (relativeUrl){
156 | return this.fixturesPath.match('/$') ? this.fixturesPath + relativeUrl : this.fixturesPath + '/' + relativeUrl
157 | }
158 |
159 | jasmine.Fixtures.prototype.proxyCallTo_ = function (methodName, passedArguments) {
160 | return this[methodName].apply(this, passedArguments)
161 | }
162 |
163 |
164 | jasmine.StyleFixtures = function () {
165 | this.fixturesCache_ = {}
166 | this.fixturesNodes_ = []
167 | this.fixturesPath = 'spec/javascripts/fixtures'
168 | }
169 |
170 | jasmine.StyleFixtures.prototype.set = function (css) {
171 | this.cleanUp()
172 | this.createStyle_(css)
173 | }
174 |
175 | jasmine.StyleFixtures.prototype.appendSet = function (css) {
176 | this.createStyle_(css)
177 | }
178 |
179 | jasmine.StyleFixtures.prototype.preload = function () {
180 | this.read_.apply(this, arguments)
181 | }
182 |
183 | jasmine.StyleFixtures.prototype.load = function () {
184 | this.cleanUp()
185 | this.createStyle_(this.read_.apply(this, arguments))
186 | }
187 |
188 | jasmine.StyleFixtures.prototype.appendLoad = function () {
189 | this.createStyle_(this.read_.apply(this, arguments))
190 | }
191 |
192 | jasmine.StyleFixtures.prototype.cleanUp = function () {
193 | while(this.fixturesNodes_.length) {
194 | this.fixturesNodes_.pop().remove()
195 | }
196 | }
197 |
198 | jasmine.StyleFixtures.prototype.createStyle_ = function (html) {
199 | var styleText = $('
').html(html).text()
200 | , style = $('')
201 |
202 | this.fixturesNodes_.push(style)
203 | $('head').append(style)
204 | }
205 |
206 | jasmine.StyleFixtures.prototype.clearCache = jasmine.Fixtures.prototype.clearCache
207 | jasmine.StyleFixtures.prototype.read_ = jasmine.Fixtures.prototype.read
208 | jasmine.StyleFixtures.prototype.getFixtureHtml_ = jasmine.Fixtures.prototype.getFixtureHtml_
209 | jasmine.StyleFixtures.prototype.loadFixtureIntoCache_ = jasmine.Fixtures.prototype.loadFixtureIntoCache_
210 | jasmine.StyleFixtures.prototype.makeFixtureUrl_ = jasmine.Fixtures.prototype.makeFixtureUrl_
211 | jasmine.StyleFixtures.prototype.proxyCallTo_ = jasmine.Fixtures.prototype.proxyCallTo_
212 |
213 | jasmine.getJSONFixtures = function () {
214 | return jasmine.currentJSONFixtures_ = jasmine.currentJSONFixtures_ || new jasmine.JSONFixtures()
215 | }
216 |
217 | jasmine.JSONFixtures = function () {
218 | this.fixturesCache_ = {}
219 | this.fixturesPath = 'spec/javascripts/fixtures/json'
220 | }
221 |
222 | jasmine.JSONFixtures.prototype.load = function () {
223 | this.read.apply(this, arguments)
224 | return this.fixturesCache_
225 | }
226 |
227 | jasmine.JSONFixtures.prototype.read = function () {
228 | var fixtureUrls = arguments
229 |
230 | for(var urlCount = fixtureUrls.length, urlIndex = 0; urlIndex < urlCount; urlIndex++) {
231 | this.getFixtureData_(fixtureUrls[urlIndex])
232 | }
233 |
234 | return this.fixturesCache_
235 | }
236 |
237 | jasmine.JSONFixtures.prototype.clearCache = function () {
238 | this.fixturesCache_ = {}
239 | }
240 |
241 | jasmine.JSONFixtures.prototype.getFixtureData_ = function (url) {
242 | if (!this.fixturesCache_[url]) this.loadFixtureIntoCache_(url)
243 | return this.fixturesCache_[url]
244 | }
245 |
246 | jasmine.JSONFixtures.prototype.loadFixtureIntoCache_ = function (relativeUrl) {
247 | var self = this
248 | , url = this.fixturesPath.match('/$') ? this.fixturesPath + relativeUrl : this.fixturesPath + '/' + relativeUrl
249 |
250 | $.ajax({
251 | async: false, // must be synchronous to guarantee that no tests are run before fixture is loaded
252 | cache: false,
253 | dataType: 'json',
254 | url: url,
255 | success: function (data) {
256 | self.fixturesCache_[relativeUrl] = data
257 | },
258 | error: function ($xhr, status, err) {
259 | throw new Error('JSONFixture could not be loaded: ' + url + ' (status: ' + status + ', message: ' + err.message + ')')
260 | }
261 | })
262 | }
263 |
264 | jasmine.JSONFixtures.prototype.proxyCallTo_ = function (methodName, passedArguments) {
265 | return this[methodName].apply(this, passedArguments)
266 | }
267 |
268 | jasmine.jQuery = function () {}
269 |
270 | jasmine.jQuery.browserTagCaseIndependentHtml = function (html) {
271 | return $('
').append(html).html()
272 | }
273 |
274 | jasmine.jQuery.elementToString = function (element) {
275 | return $(element).map(function () { return this.outerHTML; }).toArray().join(', ')
276 | }
277 |
278 | var data = {
279 | spiedEvents: {}
280 | , handlers: []
281 | }
282 |
283 | jasmine.jQuery.events = {
284 | spyOn: function (selector, eventName) {
285 | var handler = function (e) {
286 | data.spiedEvents[jasmine.spiedEventsKey(selector, eventName)] = jasmine.util.argsToArray(arguments)
287 | }
288 |
289 | $(selector).on(eventName, handler)
290 | data.handlers.push(handler)
291 |
292 | return {
293 | selector: selector,
294 | eventName: eventName,
295 | handler: handler,
296 | reset: function (){
297 | delete data.spiedEvents[jasmine.spiedEventsKey(selector, eventName)]
298 | }
299 | }
300 | },
301 |
302 | args: function (selector, eventName) {
303 | var actualArgs = data.spiedEvents[jasmine.spiedEventsKey(selector, eventName)]
304 |
305 | if (!actualArgs) {
306 | throw "There is no spy for " + eventName + " on " + selector.toString() + ". Make sure to create a spy using spyOnEvent."
307 | }
308 |
309 | return actualArgs
310 | },
311 |
312 | wasTriggered: function (selector, eventName) {
313 | return !!(data.spiedEvents[jasmine.spiedEventsKey(selector, eventName)])
314 | },
315 |
316 | wasTriggeredWith: function (selector, eventName, expectedArgs, util, customEqualityTesters) {
317 | var actualArgs = jasmine.jQuery.events.args(selector, eventName).slice(1)
318 |
319 | if (Object.prototype.toString.call(expectedArgs) !== '[object Array]')
320 | actualArgs = actualArgs[0]
321 |
322 | return util.equals(expectedArgs, actualArgs, customEqualityTesters)
323 | },
324 |
325 | wasPrevented: function (selector, eventName) {
326 | var args = data.spiedEvents[jasmine.spiedEventsKey(selector, eventName)]
327 | , e = args ? args[0] : undefined
328 |
329 | return e && e.isDefaultPrevented()
330 | },
331 |
332 | wasStopped: function (selector, eventName) {
333 | var args = data.spiedEvents[jasmine.spiedEventsKey(selector, eventName)]
334 | , e = args ? args[0] : undefined
335 | return e && e.isPropagationStopped()
336 | },
337 |
338 | cleanUp: function () {
339 | data.spiedEvents = {}
340 | data.handlers = []
341 | }
342 | }
343 |
344 | var hasProperty = function (actualValue, expectedValue) {
345 | if (expectedValue === undefined)
346 | return actualValue !== undefined
347 |
348 | return actualValue === expectedValue
349 | }
350 |
351 | beforeEach(function () {
352 | jasmine.addMatchers({
353 | toHaveClass: function () {
354 | return {
355 | compare: function (actual, className) {
356 | return { pass: $(actual).hasClass(className) }
357 | }
358 | }
359 | },
360 |
361 | toHaveCss: function () {
362 | return {
363 | compare: function (actual, css) {
364 | for (var prop in css){
365 | var value = css[prop]
366 | // see issue #147 on gh
367 | ;if (value === 'auto' && $(actual).get(0).style[prop] === 'auto') continue
368 | if ($(actual).css(prop) !== value) return { pass: false }
369 | }
370 | return { pass: true }
371 | }
372 | }
373 | },
374 |
375 | toBeVisible: function () {
376 | return {
377 | compare: function (actual) {
378 | return { pass: $(actual).is(':visible') }
379 | }
380 | }
381 | },
382 |
383 | toBeHidden: function () {
384 | return {
385 | compare: function (actual) {
386 | return { pass: $(actual).is(':hidden') }
387 | }
388 | }
389 | },
390 |
391 | toBeSelected: function () {
392 | return {
393 | compare: function (actual) {
394 | return { pass: $(actual).is(':selected') }
395 | }
396 | }
397 | },
398 |
399 | toBeChecked: function () {
400 | return {
401 | compare: function (actual) {
402 | return { pass: $(actual).is(':checked') }
403 | }
404 | }
405 | },
406 |
407 | toBeEmpty: function () {
408 | return {
409 | compare: function (actual) {
410 | return { pass: $(actual).is(':empty') }
411 | }
412 | }
413 | },
414 |
415 | toBeInDOM: function () {
416 | return {
417 | compare: function (actual) {
418 | return { pass: $.contains(document.documentElement, $(actual)[0]) }
419 | }
420 | }
421 | },
422 |
423 | toExist: function () {
424 | return {
425 | compare: function (actual) {
426 | return { pass: $(actual).length }
427 | }
428 | }
429 | },
430 |
431 | toHaveLength: function () {
432 | return {
433 | compare: function (actual, length) {
434 | return { pass: $(actual).length === length }
435 | }
436 | }
437 | },
438 |
439 | toHaveAttr: function () {
440 | return {
441 | compare: function (actual, attributeName, expectedAttributeValue) {
442 | return { pass: hasProperty($(actual).attr(attributeName), expectedAttributeValue) }
443 | }
444 | }
445 | },
446 |
447 | toHaveProp: function () {
448 | return {
449 | compare: function (actual, propertyName, expectedPropertyValue) {
450 | return { pass: hasProperty($(actual).prop(propertyName), expectedPropertyValue) }
451 | }
452 | }
453 | },
454 |
455 | toHaveId: function () {
456 | return {
457 | compare: function (actual, id) {
458 | return { pass: $(actual).attr('id') == id }
459 | }
460 | }
461 | },
462 |
463 | toHaveHtml: function () {
464 | return {
465 | compare: function (actual, html) {
466 | return { pass: $(actual).html() == jasmine.jQuery.browserTagCaseIndependentHtml(html) }
467 | }
468 | }
469 | },
470 |
471 | toContainHtml: function () {
472 | return {
473 | compare: function (actual, html) {
474 | var actualHtml = $(actual).html()
475 | , expectedHtml = jasmine.jQuery.browserTagCaseIndependentHtml(html)
476 |
477 | return { pass: (actualHtml.indexOf(expectedHtml) >= 0) }
478 | }
479 | }
480 | },
481 |
482 | toHaveText: function () {
483 | return {
484 | compare: function (actual, text) {
485 | var actualText = $(actual).text()
486 | var trimmedText = $.trim(actualText)
487 |
488 | if (text && $.isFunction(text.test)) {
489 | return { pass: text.test(actualText) || text.test(trimmedText) }
490 | } else {
491 | return { pass: (actualText == text || trimmedText == text) }
492 | }
493 | }
494 | }
495 | },
496 |
497 | toContainText: function () {
498 | return {
499 | compare: function (actual, text) {
500 | var trimmedText = $.trim($(actual).text())
501 |
502 | if (text && $.isFunction(text.test)) {
503 | return { pass: text.test(trimmedText) }
504 | } else {
505 | return { pass: trimmedText.indexOf(text) != -1 }
506 | }
507 | }
508 | }
509 | },
510 |
511 | toHaveValue: function () {
512 | return {
513 | compare: function (actual, value) {
514 | return { pass: $(actual).val() === value }
515 | }
516 | }
517 | },
518 |
519 | toHaveData: function () {
520 | return {
521 | compare: function (actual, key, expectedValue) {
522 | return { pass: hasProperty($(actual).data(key), expectedValue) }
523 | }
524 | }
525 | },
526 |
527 | toContainElement: function () {
528 | return {
529 | compare: function (actual, selector) {
530 | if (window.debug) debugger
531 | return { pass: $(actual).find(selector).length }
532 | }
533 | }
534 | },
535 |
536 | toBeMatchedBy: function () {
537 | return {
538 | compare: function (actual, selector) {
539 | return { pass: $(actual).filter(selector).length }
540 | }
541 | }
542 | },
543 |
544 | toBeDisabled: function () {
545 | return {
546 | compare: function (actual, selector) {
547 | return { pass: $(actual).is(':disabled') }
548 | }
549 | }
550 | },
551 |
552 | toBeFocused: function (selector) {
553 | return {
554 | compare: function (actual, selector) {
555 | return { pass: $(actual)[0] === $(actual)[0].ownerDocument.activeElement }
556 | }
557 | }
558 | },
559 |
560 | toHandle: function () {
561 | return {
562 | compare: function (actual, event) {
563 | var events = $._data($(actual).get(0), "events")
564 |
565 | if (!events || !event || typeof event !== "string") {
566 | return { pass: false }
567 | }
568 |
569 | var namespaces = event.split(".")
570 | , eventType = namespaces.shift()
571 | , sortedNamespaces = namespaces.slice(0).sort()
572 | , namespaceRegExp = new RegExp("(^|\\.)" + sortedNamespaces.join("\\.(?:.*\\.)?") + "(\\.|$)")
573 |
574 | if (events[eventType] && namespaces.length) {
575 | for (var i = 0; i < events[eventType].length; i++) {
576 | var namespace = events[eventType][i].namespace
577 |
578 | if (namespaceRegExp.test(namespace))
579 | return { pass: true }
580 | }
581 | } else {
582 | return { pass: (events[eventType] && events[eventType].length > 0) }
583 | }
584 |
585 | return { pass: false }
586 | }
587 | }
588 | },
589 |
590 | toHandleWith: function () {
591 | return {
592 | compare: function (actual, eventName, eventHandler) {
593 | var normalizedEventName = eventName.split('.')[0]
594 | , stack = $._data($(actual).get(0), "events")[normalizedEventName]
595 |
596 | for (var i = 0; i < stack.length; i++) {
597 | if (stack[i].handler == eventHandler) return { pass: true }
598 | }
599 |
600 | return { pass: false }
601 | }
602 | }
603 | },
604 |
605 | toHaveBeenTriggeredOn: function () {
606 | return {
607 | compare: function (actual, selector) {
608 | var result = { pass: jasmine.jQuery.events.wasTriggered(selector, actual) }
609 |
610 | result.message = result.pass ?
611 | "Expected event " + $(actual) + " not to have been triggered on " + selector :
612 | "Expected event " + $(actual) + " to have been triggered on " + selector
613 |
614 | return result;
615 | }
616 | }
617 | },
618 |
619 | toHaveBeenTriggered: function (){
620 | return {
621 | compare: function (actual) {
622 | var eventName = actual.eventName
623 | , selector = actual.selector
624 | , result = { pass: jasmine.jQuery.events.wasTriggered(selector, eventName) }
625 |
626 | result.message = result.pass ?
627 | "Expected event " + eventName + " not to have been triggered on " + selector :
628 | "Expected event " + eventName + " to have been triggered on " + selector
629 |
630 | return result
631 | }
632 | }
633 | },
634 |
635 | toHaveBeenTriggeredOnAndWith: function (j$, customEqualityTesters) {
636 | return {
637 | compare: function (actual, selector, expectedArgs) {
638 | var wasTriggered = jasmine.jQuery.events.wasTriggered(selector, actual)
639 | , result = { pass: wasTriggered && jasmine.jQuery.events.wasTriggeredWith(selector, actual, expectedArgs, j$, customEqualityTesters) }
640 |
641 | if (wasTriggered) {
642 | var actualArgs = jasmine.jQuery.events.args(selector, actual, expectedArgs)[1]
643 | result.message = result.pass ?
644 | "Expected event " + actual + " not to have been triggered with " + jasmine.pp(expectedArgs) + " but it was triggered with " + jasmine.pp(actualArgs) :
645 | "Expected event " + actual + " to have been triggered with " + jasmine.pp(expectedArgs) + " but it was triggered with " + jasmine.pp(actualArgs)
646 |
647 | } else {
648 | // todo check on this
649 | result.message = result.pass ?
650 | "Expected event " + actual + " not to have been triggered on " + selector :
651 | "Expected event " + actual + " to have been triggered on " + selector
652 | }
653 |
654 | return result
655 | }
656 | }
657 | },
658 |
659 | toHaveBeenPreventedOn: function () {
660 | return {
661 | compare: function (actual, selector) {
662 | var result = { pass: jasmine.jQuery.events.wasPrevented(selector, actual) }
663 |
664 | result.message = result.pass ?
665 | "Expected event " + actual + " not to have been prevented on " + selector :
666 | "Expected event " + actual + " to have been prevented on " + selector
667 |
668 | return result
669 | }
670 | }
671 | },
672 |
673 | toHaveBeenPrevented: function () {
674 | return {
675 | compare: function (actual) {
676 | var eventName = actual.eventName
677 | , selector = actual.selector
678 | , result = { pass: jasmine.jQuery.events.wasPrevented(selector, eventName) }
679 |
680 | result.message = result.pass ?
681 | "Expected event " + eventName + " not to have been prevented on " + selector :
682 | "Expected event " + eventName + " to have been prevented on " + selector
683 |
684 | return result
685 | }
686 | }
687 | },
688 |
689 | toHaveBeenStoppedOn: function () {
690 | return {
691 | compare: function (actual, selector) {
692 | var result = { pass: jasmine.jQuery.events.wasStopped(selector, actual) }
693 |
694 | result.message = result.pass ?
695 | "Expected event " + actual + " not to have been stopped on " + selector :
696 | "Expected event " + actual + " to have been stopped on " + selector
697 |
698 | return result;
699 | }
700 | }
701 | },
702 |
703 | toHaveBeenStopped: function () {
704 | return {
705 | compare: function (actual) {
706 | var eventName = actual.eventName
707 | , selector = actual.selector
708 | , result = { pass: jasmine.jQuery.events.wasStopped(selector, eventName) }
709 |
710 | result.message = result.pass ?
711 | "Expected event " + eventName + " not to have been stopped on " + selector :
712 | "Expected event " + eventName + " to have been stopped on " + selector
713 |
714 | return result
715 | }
716 | }
717 | }
718 | })
719 |
720 | jasmine.getEnv().addCustomEqualityTester(function(a, b) {
721 | if (a && b) {
722 | if (a instanceof $ || jasmine.isDomNode(a)) {
723 | var $a = $(a)
724 |
725 | if (b instanceof $)
726 | return $a.length == b.length && a.is(b)
727 |
728 | return $a.is(b);
729 | }
730 |
731 | if (b instanceof $ || jasmine.isDomNode(b)) {
732 | var $b = $(b)
733 |
734 | if (a instanceof $)
735 | return a.length == $b.length && $b.is(a)
736 |
737 | return $(b).is(a);
738 | }
739 | }
740 | })
741 |
742 | jasmine.getEnv().addCustomEqualityTester(function (a, b) {
743 | if (a instanceof $ && b instanceof $ && a.size() == b.size())
744 | return a.is(b)
745 | })
746 | })
747 |
748 | afterEach(function () {
749 | jasmine.getFixtures().cleanUp()
750 | jasmine.getStyleFixtures().cleanUp()
751 | jasmine.jQuery.events.cleanUp()
752 | })
753 |
754 | window.readFixtures = function () {
755 | return jasmine.getFixtures().proxyCallTo_('read', arguments)
756 | }
757 |
758 | window.preloadFixtures = function () {
759 | jasmine.getFixtures().proxyCallTo_('preload', arguments)
760 | }
761 |
762 | window.loadFixtures = function () {
763 | jasmine.getFixtures().proxyCallTo_('load', arguments)
764 | }
765 |
766 | window.appendLoadFixtures = function () {
767 | jasmine.getFixtures().proxyCallTo_('appendLoad', arguments)
768 | }
769 |
770 | window.setFixtures = function (html) {
771 | return jasmine.getFixtures().proxyCallTo_('set', arguments)
772 | }
773 |
774 | window.appendSetFixtures = function () {
775 | jasmine.getFixtures().proxyCallTo_('appendSet', arguments)
776 | }
777 |
778 | window.sandbox = function (attributes) {
779 | return jasmine.getFixtures().sandbox(attributes)
780 | }
781 |
782 | window.spyOnEvent = function (selector, eventName) {
783 | return jasmine.jQuery.events.spyOn(selector, eventName)
784 | }
785 |
786 | window.preloadStyleFixtures = function () {
787 | jasmine.getStyleFixtures().proxyCallTo_('preload', arguments)
788 | }
789 |
790 | window.loadStyleFixtures = function () {
791 | jasmine.getStyleFixtures().proxyCallTo_('load', arguments)
792 | }
793 |
794 | window.appendLoadStyleFixtures = function () {
795 | jasmine.getStyleFixtures().proxyCallTo_('appendLoad', arguments)
796 | }
797 |
798 | window.setStyleFixtures = function (html) {
799 | jasmine.getStyleFixtures().proxyCallTo_('set', arguments)
800 | }
801 |
802 | window.appendSetStyleFixtures = function (html) {
803 | jasmine.getStyleFixtures().proxyCallTo_('appendSet', arguments)
804 | }
805 |
806 | window.loadJSONFixtures = function () {
807 | return jasmine.getJSONFixtures().proxyCallTo_('load', arguments)
808 | }
809 |
810 | window.getJSONFixture = function (url) {
811 | return jasmine.getJSONFixtures().proxyCallTo_('read', arguments)[url]
812 | }
813 | }(window, window.jasmine, window.jQuery);
--------------------------------------------------------------------------------