parent
c19f405a2f
commit
a133123219
@ -1,5 +1,5 @@ |
|||||||
(function() { |
(function($, window) { |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}).call(this); |
}).call(this, jQuery, window); |
||||||
|
@ -0,0 +1,34 @@ |
|||||||
|
{ |
||||||
|
"name": "bootstrap", |
||||||
|
"version": "3.1.1", |
||||||
|
"main": [ |
||||||
|
"./dist/css/bootstrap.css", |
||||||
|
"./dist/js/bootstrap.js", |
||||||
|
"./dist/fonts/glyphicons-halflings-regular.eot", |
||||||
|
"./dist/fonts/glyphicons-halflings-regular.svg", |
||||||
|
"./dist/fonts/glyphicons-halflings-regular.ttf", |
||||||
|
"./dist/fonts/glyphicons-halflings-regular.woff" |
||||||
|
], |
||||||
|
"ignore": [ |
||||||
|
"**/.*", |
||||||
|
"_config.yml", |
||||||
|
"CNAME", |
||||||
|
"composer.json", |
||||||
|
"CONTRIBUTING.md", |
||||||
|
"docs", |
||||||
|
"js/tests" |
||||||
|
], |
||||||
|
"dependencies": { |
||||||
|
"jquery": ">= 1.9.0" |
||||||
|
}, |
||||||
|
"homepage": "https://github.com/twbs/bootstrap", |
||||||
|
"_release": "3.1.1", |
||||||
|
"_resolution": { |
||||||
|
"type": "version", |
||||||
|
"tag": "v3.1.1", |
||||||
|
"commit": "a365d8689c3f3cee7f1acf86b61270ecca8e106d" |
||||||
|
}, |
||||||
|
"_source": "git://github.com/twbs/bootstrap.git", |
||||||
|
"_target": ">=3.1.1", |
||||||
|
"_originalSource": "bootstrap" |
||||||
|
} |
@ -0,0 +1,421 @@ |
|||||||
|
/*! |
||||||
|
* Bootstrap's Gruntfile |
||||||
|
* http://getbootstrap.com
|
||||||
|
* Copyright 2013-2014 Twitter, Inc. |
||||||
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
|
*/ |
||||||
|
|
||||||
|
module.exports = function (grunt) { |
||||||
|
'use strict'; |
||||||
|
|
||||||
|
// Force use of Unix newlines
|
||||||
|
grunt.util.linefeed = '\n'; |
||||||
|
|
||||||
|
RegExp.quote = function (string) { |
||||||
|
return string.replace(/[-\\^$*+?.()|[\]{}]/g, '\\$&'); |
||||||
|
}; |
||||||
|
|
||||||
|
var fs = require('fs'); |
||||||
|
var path = require('path'); |
||||||
|
var generateGlyphiconsData = require('./grunt/bs-glyphicons-data-generator.js'); |
||||||
|
var BsLessdocParser = require('./grunt/bs-lessdoc-parser.js'); |
||||||
|
var generateRawFilesJs = require('./grunt/bs-raw-files-generator.js'); |
||||||
|
var updateShrinkwrap = require('./grunt/shrinkwrap.js'); |
||||||
|
|
||||||
|
// Project configuration.
|
||||||
|
grunt.initConfig({ |
||||||
|
|
||||||
|
// Metadata.
|
||||||
|
pkg: grunt.file.readJSON('package.json'), |
||||||
|
banner: '/*!\n' + |
||||||
|
' * Bootstrap v<%= pkg.version %> (<%= pkg.homepage %>)\n' + |
||||||
|
' * Copyright 2011-<%= grunt.template.today("yyyy") %> <%= pkg.author %>\n' + |
||||||
|
' * Licensed under <%= pkg.license.type %> (<%= pkg.license.url %>)\n' + |
||||||
|
' */\n', |
||||||
|
jqueryCheck: 'if (typeof jQuery === \'undefined\') { throw new Error(\'Bootstrap\\\'s JavaScript requires jQuery\') }\n\n', |
||||||
|
|
||||||
|
// Task configuration.
|
||||||
|
clean: { |
||||||
|
dist: ['dist', 'docs/dist'] |
||||||
|
}, |
||||||
|
|
||||||
|
jshint: { |
||||||
|
options: { |
||||||
|
jshintrc: 'js/.jshintrc' |
||||||
|
}, |
||||||
|
grunt: { |
||||||
|
options: { |
||||||
|
jshintrc: 'grunt/.jshintrc' |
||||||
|
}, |
||||||
|
src: ['Gruntfile.js', 'grunt/*.js'] |
||||||
|
}, |
||||||
|
src: { |
||||||
|
src: 'js/*.js' |
||||||
|
}, |
||||||
|
test: { |
||||||
|
src: 'js/tests/unit/*.js' |
||||||
|
}, |
||||||
|
assets: { |
||||||
|
src: ['docs/assets/js/application.js', 'docs/assets/js/customizer.js'] |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
jscs: { |
||||||
|
options: { |
||||||
|
config: 'js/.jscs.json', |
||||||
|
}, |
||||||
|
grunt: { |
||||||
|
src: ['Gruntfile.js', 'grunt/*.js'] |
||||||
|
}, |
||||||
|
src: { |
||||||
|
src: 'js/*.js' |
||||||
|
}, |
||||||
|
test: { |
||||||
|
src: 'js/tests/unit/*.js' |
||||||
|
}, |
||||||
|
assets: { |
||||||
|
src: ['docs/assets/js/application.js', 'docs/assets/js/customizer.js'] |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
csslint: { |
||||||
|
options: { |
||||||
|
csslintrc: 'less/.csslintrc' |
||||||
|
}, |
||||||
|
src: [ |
||||||
|
'dist/css/bootstrap.css', |
||||||
|
'dist/css/bootstrap-theme.css', |
||||||
|
'docs/assets/css/docs.css', |
||||||
|
'docs/examples/**/*.css' |
||||||
|
] |
||||||
|
}, |
||||||
|
|
||||||
|
concat: { |
||||||
|
options: { |
||||||
|
banner: '<%= banner %>\n<%= jqueryCheck %>', |
||||||
|
stripBanners: false |
||||||
|
}, |
||||||
|
bootstrap: { |
||||||
|
src: [ |
||||||
|
'js/transition.js', |
||||||
|
'js/alert.js', |
||||||
|
'js/button.js', |
||||||
|
'js/carousel.js', |
||||||
|
'js/collapse.js', |
||||||
|
'js/dropdown.js', |
||||||
|
'js/modal.js', |
||||||
|
'js/tooltip.js', |
||||||
|
'js/popover.js', |
||||||
|
'js/scrollspy.js', |
||||||
|
'js/tab.js', |
||||||
|
'js/affix.js' |
||||||
|
], |
||||||
|
dest: 'dist/js/<%= pkg.name %>.js' |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
uglify: { |
||||||
|
options: { |
||||||
|
report: 'min' |
||||||
|
}, |
||||||
|
bootstrap: { |
||||||
|
options: { |
||||||
|
banner: '<%= banner %>' |
||||||
|
}, |
||||||
|
src: '<%= concat.bootstrap.dest %>', |
||||||
|
dest: 'dist/js/<%= pkg.name %>.min.js' |
||||||
|
}, |
||||||
|
customize: { |
||||||
|
options: { |
||||||
|
preserveComments: 'some' |
||||||
|
}, |
||||||
|
src: [ |
||||||
|
'docs/assets/js/vendor/less.min.js', |
||||||
|
'docs/assets/js/vendor/jszip.min.js', |
||||||
|
'docs/assets/js/vendor/uglify.min.js', |
||||||
|
'docs/assets/js/vendor/blob.js', |
||||||
|
'docs/assets/js/vendor/filesaver.js', |
||||||
|
'docs/assets/js/raw-files.min.js', |
||||||
|
'docs/assets/js/customizer.js' |
||||||
|
], |
||||||
|
dest: 'docs/assets/js/customize.min.js' |
||||||
|
}, |
||||||
|
docsJs: { |
||||||
|
options: { |
||||||
|
preserveComments: 'some' |
||||||
|
}, |
||||||
|
src: [ |
||||||
|
'docs/assets/js/vendor/holder.js', |
||||||
|
'docs/assets/js/application.js' |
||||||
|
], |
||||||
|
dest: 'docs/assets/js/docs.min.js' |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
less: { |
||||||
|
compileCore: { |
||||||
|
options: { |
||||||
|
strictMath: true, |
||||||
|
sourceMap: true, |
||||||
|
outputSourceFiles: true, |
||||||
|
sourceMapURL: '<%= pkg.name %>.css.map', |
||||||
|
sourceMapFilename: 'dist/css/<%= pkg.name %>.css.map' |
||||||
|
}, |
||||||
|
files: { |
||||||
|
'dist/css/<%= pkg.name %>.css': 'less/bootstrap.less' |
||||||
|
} |
||||||
|
}, |
||||||
|
compileTheme: { |
||||||
|
options: { |
||||||
|
strictMath: true, |
||||||
|
sourceMap: true, |
||||||
|
outputSourceFiles: true, |
||||||
|
sourceMapURL: '<%= pkg.name %>-theme.css.map', |
||||||
|
sourceMapFilename: 'dist/css/<%= pkg.name %>-theme.css.map' |
||||||
|
}, |
||||||
|
files: { |
||||||
|
'dist/css/<%= pkg.name %>-theme.css': 'less/theme.less' |
||||||
|
} |
||||||
|
}, |
||||||
|
minify: { |
||||||
|
options: { |
||||||
|
cleancss: true, |
||||||
|
report: 'min' |
||||||
|
}, |
||||||
|
files: { |
||||||
|
'dist/css/<%= pkg.name %>.min.css': 'dist/css/<%= pkg.name %>.css', |
||||||
|
'dist/css/<%= pkg.name %>-theme.min.css': 'dist/css/<%= pkg.name %>-theme.css' |
||||||
|
} |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
cssmin: { |
||||||
|
compress: { |
||||||
|
options: { |
||||||
|
keepSpecialComments: '*', |
||||||
|
noAdvanced: true, // turn advanced optimizations off until the issue is fixed in clean-css
|
||||||
|
report: 'min', |
||||||
|
selectorsMergeMode: 'ie8' |
||||||
|
}, |
||||||
|
src: [ |
||||||
|
'docs/assets/css/docs.css', |
||||||
|
'docs/assets/css/pygments-manni.css' |
||||||
|
], |
||||||
|
dest: 'docs/assets/css/docs.min.css' |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
usebanner: { |
||||||
|
dist: { |
||||||
|
options: { |
||||||
|
position: 'top', |
||||||
|
banner: '<%= banner %>' |
||||||
|
}, |
||||||
|
files: { |
||||||
|
src: [ |
||||||
|
'dist/css/<%= pkg.name %>.css', |
||||||
|
'dist/css/<%= pkg.name %>.min.css', |
||||||
|
'dist/css/<%= pkg.name %>-theme.css', |
||||||
|
'dist/css/<%= pkg.name %>-theme.min.css' |
||||||
|
] |
||||||
|
} |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
csscomb: { |
||||||
|
options: { |
||||||
|
config: 'less/.csscomb.json' |
||||||
|
}, |
||||||
|
dist: { |
||||||
|
files: { |
||||||
|
'dist/css/<%= pkg.name %>.css': 'dist/css/<%= pkg.name %>.css', |
||||||
|
'dist/css/<%= pkg.name %>-theme.css': 'dist/css/<%= pkg.name %>-theme.css' |
||||||
|
} |
||||||
|
}, |
||||||
|
examples: { |
||||||
|
expand: true, |
||||||
|
cwd: 'docs/examples/', |
||||||
|
src: ['**/*.css'], |
||||||
|
dest: 'docs/examples/' |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
copy: { |
||||||
|
fonts: { |
||||||
|
expand: true, |
||||||
|
src: 'fonts/*', |
||||||
|
dest: 'dist/' |
||||||
|
}, |
||||||
|
docs: { |
||||||
|
expand: true, |
||||||
|
cwd: './dist', |
||||||
|
src: [ |
||||||
|
'{css,js}/*.min.*', |
||||||
|
'css/*.map', |
||||||
|
'fonts/*' |
||||||
|
], |
||||||
|
dest: 'docs/dist' |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
qunit: { |
||||||
|
options: { |
||||||
|
inject: 'js/tests/unit/phantom.js' |
||||||
|
}, |
||||||
|
files: 'js/tests/index.html' |
||||||
|
}, |
||||||
|
|
||||||
|
connect: { |
||||||
|
server: { |
||||||
|
options: { |
||||||
|
port: 3000, |
||||||
|
base: '.' |
||||||
|
} |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
jekyll: { |
||||||
|
docs: {} |
||||||
|
}, |
||||||
|
|
||||||
|
jade: { |
||||||
|
compile: { |
||||||
|
options: { |
||||||
|
pretty: true, |
||||||
|
data: function () { |
||||||
|
var filePath = path.join(__dirname, 'less/variables.less'); |
||||||
|
var fileContent = fs.readFileSync(filePath, {encoding: 'utf8'}); |
||||||
|
var parser = new BsLessdocParser(fileContent); |
||||||
|
return {sections: parser.parseFile()}; |
||||||
|
} |
||||||
|
}, |
||||||
|
files: { |
||||||
|
'docs/_includes/customizer-variables.html': 'docs/jade/customizer-variables.jade', |
||||||
|
'docs/_includes/nav-customize.html': 'docs/jade/customizer-nav.jade' |
||||||
|
} |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
validation: { |
||||||
|
options: { |
||||||
|
charset: 'utf-8', |
||||||
|
doctype: 'HTML5', |
||||||
|
failHard: true, |
||||||
|
reset: true, |
||||||
|
relaxerror: [ |
||||||
|
'Bad value X-UA-Compatible for attribute http-equiv on element meta.', |
||||||
|
'Element img is missing required attribute src.' |
||||||
|
] |
||||||
|
}, |
||||||
|
files: { |
||||||
|
src: '_gh_pages/**/*.html' |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
watch: { |
||||||
|
src: { |
||||||
|
files: '<%= jshint.src.src %>', |
||||||
|
tasks: ['jshint:src', 'qunit'] |
||||||
|
}, |
||||||
|
test: { |
||||||
|
files: '<%= jshint.test.src %>', |
||||||
|
tasks: ['jshint:test', 'qunit'] |
||||||
|
}, |
||||||
|
less: { |
||||||
|
files: 'less/*.less', |
||||||
|
tasks: 'less' |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
sed: { |
||||||
|
versionNumber: { |
||||||
|
pattern: (function () { |
||||||
|
var old = grunt.option('oldver'); |
||||||
|
return old ? RegExp.quote(old) : old; |
||||||
|
})(), |
||||||
|
replacement: grunt.option('newver'), |
||||||
|
recursive: true |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
'saucelabs-qunit': { |
||||||
|
all: { |
||||||
|
options: { |
||||||
|
build: process.env.TRAVIS_JOB_ID, |
||||||
|
concurrency: 10, |
||||||
|
urls: ['http://127.0.0.1:3000/js/tests/index.html'], |
||||||
|
browsers: grunt.file.readYAML('test-infra/sauce_browsers.yml') |
||||||
|
} |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
exec: { |
||||||
|
npmUpdate: { |
||||||
|
command: 'npm update' |
||||||
|
}, |
||||||
|
npmShrinkWrap: { |
||||||
|
command: 'npm shrinkwrap --dev' |
||||||
|
} |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
|
||||||
|
// These plugins provide necessary tasks.
|
||||||
|
require('load-grunt-tasks')(grunt, {scope: 'devDependencies'}); |
||||||
|
|
||||||
|
// Docs HTML validation task
|
||||||
|
grunt.registerTask('validate-html', ['jekyll', 'validation']); |
||||||
|
|
||||||
|
// Test task.
|
||||||
|
var testSubtasks = []; |
||||||
|
// Skip core tests if running a different subset of the test suite
|
||||||
|
if (!process.env.TWBS_TEST || process.env.TWBS_TEST === 'core') { |
||||||
|
testSubtasks = testSubtasks.concat(['dist-css', 'csslint', 'jshint', 'jscs', 'qunit', 'build-customizer-html']); |
||||||
|
} |
||||||
|
// Skip HTML validation if running a different subset of the test suite
|
||||||
|
if (!process.env.TWBS_TEST || process.env.TWBS_TEST === 'validate-html') { |
||||||
|
testSubtasks.push('validate-html'); |
||||||
|
} |
||||||
|
// Only run Sauce Labs tests if there's a Sauce access key
|
||||||
|
if (typeof process.env.SAUCE_ACCESS_KEY !== 'undefined' && |
||||||
|
// Skip Sauce if running a different subset of the test suite
|
||||||
|
(!process.env.TWBS_TEST || process.env.TWBS_TEST === 'sauce-js-unit')) { |
||||||
|
testSubtasks.push('connect'); |
||||||
|
testSubtasks.push('saucelabs-qunit'); |
||||||
|
} |
||||||
|
grunt.registerTask('test', testSubtasks); |
||||||
|
|
||||||
|
// JS distribution task.
|
||||||
|
grunt.registerTask('dist-js', ['concat', 'uglify']); |
||||||
|
|
||||||
|
// CSS distribution task.
|
||||||
|
grunt.registerTask('dist-css', ['less', 'cssmin', 'csscomb', 'usebanner']); |
||||||
|
|
||||||
|
// Docs distribution task.
|
||||||
|
grunt.registerTask('dist-docs', 'copy:docs'); |
||||||
|
|
||||||
|
// Full distribution task.
|
||||||
|
grunt.registerTask('dist', ['clean', 'dist-css', 'copy:fonts', 'dist-js', 'dist-docs']); |
||||||
|
|
||||||
|
// Default task.
|
||||||
|
grunt.registerTask('default', ['test', 'dist', 'build-glyphicons-data', 'build-customizer', 'update-shrinkwrap']); |
||||||
|
|
||||||
|
// Version numbering task.
|
||||||
|
// grunt change-version-number --oldver=A.B.C --newver=X.Y.Z
|
||||||
|
// This can be overzealous, so its changes should always be manually reviewed!
|
||||||
|
grunt.registerTask('change-version-number', 'sed'); |
||||||
|
|
||||||
|
grunt.registerTask('build-glyphicons-data', generateGlyphiconsData); |
||||||
|
|
||||||
|
// task for building customizer
|
||||||
|
grunt.registerTask('build-customizer', ['build-customizer-html', 'build-raw-files']); |
||||||
|
grunt.registerTask('build-customizer-html', 'jade'); |
||||||
|
grunt.registerTask('build-raw-files', 'Add scripts/less files to customizer.', function () { |
||||||
|
var banner = grunt.template.process('<%= banner %>'); |
||||||
|
generateRawFilesJs(banner); |
||||||
|
}); |
||||||
|
|
||||||
|
// Task for updating the npm packages used by the Travis build.
|
||||||
|
grunt.registerTask('update-shrinkwrap', ['exec:npmUpdate', 'exec:npmShrinkWrap', '_update-shrinkwrap']); |
||||||
|
grunt.registerTask('_update-shrinkwrap', function () { updateShrinkwrap.call(this, grunt); }); |
||||||
|
}; |
@ -0,0 +1,21 @@ |
|||||||
|
The MIT License (MIT) |
||||||
|
|
||||||
|
Copyright (c) 2011-2014 Twitter, Inc |
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy |
||||||
|
of this software and associated documentation files (the "Software"), to deal |
||||||
|
in the Software without restriction, including without limitation the rights |
||||||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |
||||||
|
copies of the Software, and to permit persons to whom the Software is |
||||||
|
furnished to do so, subject to the following conditions: |
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in |
||||||
|
all copies or substantial portions of the Software. |
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN |
||||||
|
THE SOFTWARE. |
@ -0,0 +1,173 @@ |
|||||||
|
# [Bootstrap](http://getbootstrap.com) [![Bower version](https://badge.fury.io/bo/bootstrap.png)](http://badge.fury.io/bo/bootstrap) [![Build Status](https://secure.travis-ci.org/twbs/bootstrap.png)](http://travis-ci.org/twbs/bootstrap) [![devDependency Status](https://david-dm.org/twbs/bootstrap/dev-status.png?theme=shields.io)](https://david-dm.org/twbs/bootstrap#info=devDependencies) |
||||||
|
[![Selenium Test Status](https://saucelabs.com/browser-matrix/bootstrap.svg)](https://saucelabs.com/u/bootstrap) |
||||||
|
|
||||||
|
Bootstrap is a sleek, intuitive, and powerful front-end framework for faster and easier web development, created by [Mark Otto](http://twitter.com/mdo) and [Jacob Thornton](http://twitter.com/fat), and maintained by the [core team](https://github.com/twbs?tab=members) with the massive support and involvement of the community. |
||||||
|
|
||||||
|
To get started, check out <http://getbootstrap.com>! |
||||||
|
|
||||||
|
## Table of contents |
||||||
|
|
||||||
|
- [Quick start](#quick-start) |
||||||
|
- [Bugs and feature requests](#bugs-and-feature-requests) |
||||||
|
- [Documentation](#documentation) |
||||||
|
- [Compiling CSS and JavaScript](#compiling-css-and-javascript) |
||||||
|
- [Contributing](#contributing) |
||||||
|
- [Community](#community) |
||||||
|
- [Versioning](#versioning) |
||||||
|
- [Authors](#authors) |
||||||
|
- [Copyright and license](#copyright-and-license) |
||||||
|
|
||||||
|
## Quick start |
||||||
|
|
||||||
|
Three quick start options are available: |
||||||
|
|
||||||
|
- [Download the latest release](https://github.com/twbs/bootstrap/archive/v3.1.1.zip). |
||||||
|
- Clone the repo: `git clone https://github.com/twbs/bootstrap.git`. |
||||||
|
- Install with [Bower](http://bower.io): `bower install bootstrap`. |
||||||
|
|
||||||
|
Read the [Getting Started page](http://getbootstrap.com/getting-started/) for information on the framework contents, templates and examples, and more. |
||||||
|
|
||||||
|
### What's included |
||||||
|
|
||||||
|
Within the download you'll find the following directories and files, logically grouping common assets and providing both compiled and minified variations. You'll see something like this: |
||||||
|
|
||||||
|
``` |
||||||
|
bootstrap/ |
||||||
|
├── css/ |
||||||
|
│ ├── bootstrap.css |
||||||
|
│ ├── bootstrap.min.css |
||||||
|
│ ├── bootstrap-theme.css |
||||||
|
│ └── bootstrap-theme.min.css |
||||||
|
├── js/ |
||||||
|
│ ├── bootstrap.js |
||||||
|
│ └── bootstrap.min.js |
||||||
|
└── fonts/ |
||||||
|
├── glyphicons-halflings-regular.eot |
||||||
|
├── glyphicons-halflings-regular.svg |
||||||
|
├── glyphicons-halflings-regular.ttf |
||||||
|
└── glyphicons-halflings-regular.woff |
||||||
|
``` |
||||||
|
|
||||||
|
We provide compiled CSS and JS (`bootstrap.*`), as well as compiled and minified CSS and JS (`bootstrap.min.*`). Fonts from Glyphicons are included, as is the optional Bootstrap theme. |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## Bugs and feature requests |
||||||
|
|
||||||
|
Have a bug or a feature request? Please first read the [issue guidelines](https://github.com/twbs/bootstrap/blob/master/CONTRIBUTING.md#using-the-issue-tracker) and search for existing and closed issues. If your problem or idea is not addressed yet, [please open a new issue](https://github.com/twbs/bootstrap/issues/new). |
||||||
|
|
||||||
|
|
||||||
|
## Documentation |
||||||
|
|
||||||
|
Bootstrap's documentation, included in this repo in the root directory, is built with [Jekyll](http://jekyllrb.com) and publicly hosted on GitHub Pages at <http://getbootstrap.com>. The docs may also be run locally. |
||||||
|
|
||||||
|
### Running documentation locally |
||||||
|
|
||||||
|
1. If necessary, [install Jekyll](http://jekyllrb.com/docs/installation) (requires v1.x). |
||||||
|
- **Windows users:** Read [this unofficial guide](https://github.com/juthilo/run-jekyll-on-windows/) to get Jekyll up and running without problems. We use Pygments for syntax highlighting, so make sure to read the sections on installing Python and Pygments. |
||||||
|
2. From the root `/bootstrap` directory, run `jekyll serve` in the command line. |
||||||
|
- **Windows users:** While we use Jekyll's `encoding` setting, you might still need to change the command prompt's character encoding ([code page](http://en.wikipedia.org/wiki/Windows_code_page)) to UTF-8 so Jekyll runs without errors. For Ruby 2.0.0, run `chcp 65001` first. For Ruby 1.9.3, you can alternatively do `SET LANG=en_EN.UTF-8`. |
||||||
|
3. Open <http://localhost:9001> in your browser, and voilà. |
||||||
|
|
||||||
|
Learn more about using Jekyll by reading its [documentation](http://jekyllrb.com/docs/home/). |
||||||
|
|
||||||
|
### Documentation for previous releases |
||||||
|
|
||||||
|
Documentation for v2.3.2 has been made available for the time being at <http://getbootstrap.com/2.3.2/> while folks transition to Bootstrap 3. |
||||||
|
|
||||||
|
[Previous releases](https://github.com/twbs/bootstrap/releases) and their documentation are also available for download. |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## Compiling CSS and JavaScript |
||||||
|
|
||||||
|
Bootstrap uses [Grunt](http://gruntjs.com/) with convenient methods for working with the framework. It's how we compile our code, run tests, and more. To use it, install the required dependencies as directed and then run some Grunt commands. |
||||||
|
|
||||||
|
### Install Grunt |
||||||
|
|
||||||
|
From the command line: |
||||||
|
|
||||||
|
1. Install `grunt-cli` globally with `npm install -g grunt-cli`. |
||||||
|
2. Navigate to the root `/bootstrap` directory, then run `npm install`. npm will look at [package.json](https://github.com/twbs/bootstrap/blob/master/package.json) and automatically install the necessary local dependencies listed there. |
||||||
|
|
||||||
|
When completed, you'll be able to run the various Grunt commands provided from the command line. |
||||||
|
|
||||||
|
**Unfamiliar with `npm`? Don't have node installed?** That's a-okay. npm stands for [node packaged modules](http://npmjs.org/) and is a way to manage development dependencies through node.js. [Download and install node.js](http://nodejs.org/download/) before proceeding. |
||||||
|
|
||||||
|
### Available Grunt commands |
||||||
|
|
||||||
|
#### Build - `grunt` |
||||||
|
Run `grunt` to run tests locally and compile the CSS and JavaScript into `/dist`. **Uses [Less](http://lesscss.org/) and [UglifyJS](http://lisperator.net/uglifyjs/).** |
||||||
|
|
||||||
|
#### Only compile CSS and JavaScript - `grunt dist` |
||||||
|
`grunt dist` creates the `/dist` directory with compiled files. **Uses [Less](http://lesscss.org/) and [UglifyJS](http://lisperator.net/uglifyjs/).** |
||||||
|
|
||||||
|
#### Tests - `grunt test` |
||||||
|
Runs [JSHint](http://jshint.com) and [QUnit](http://qunitjs.com/) tests headlessly in [PhantomJS](http://phantomjs.org/) (used for CI). |
||||||
|
|
||||||
|
#### Watch - `grunt watch` |
||||||
|
This is a convenience method for watching just Less files and automatically building them whenever you save. |
||||||
|
|
||||||
|
### Troubleshooting dependencies |
||||||
|
|
||||||
|
Should you encounter problems with installing dependencies or running Grunt commands, uninstall all previous dependency versions (global and local). Then, rerun `npm install`. |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## Contributing |
||||||
|
|
||||||
|
Please read through our [contributing guidelines](https://github.com/twbs/bootstrap/blob/master/CONTRIBUTING.md). Included are directions for opening issues, coding standards, and notes on development. |
||||||
|
|
||||||
|
Moreover, if your pull request contains JavaScript patches or features, you must include relevant unit tests. All HTML and CSS should conform to the [Code Guide](http://github.com/mdo/code-guide), maintained by [Mark Otto](http://github.com/mdo). |
||||||
|
|
||||||
|
Editor preferences are available in the [editor config](https://github.com/twbs/bootstrap/blob/master/.editorconfig) for easy use in common text editors. Read more and download plugins at <http://editorconfig.org>. |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## Community |
||||||
|
|
||||||
|
Keep track of development and community news. |
||||||
|
|
||||||
|
- Follow [@twbootstrap on Twitter](http://twitter.com/twbootstrap). |
||||||
|
- Read and subscribe to [The Official Bootstrap Blog](http://blog.getbootstrap.com). |
||||||
|
- Chat with fellow Bootstrappers in IRC. On the `irc.freenode.net` server, in the `##twitter-bootstrap` channel. |
||||||
|
- Implementation help may be found at Stack Overflow (tagged [`twitter-bootstrap-3`](http://stackoverflow.com/questions/tagged/twitter-bootstrap-3)). |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## Versioning |
||||||
|
|
||||||
|
For transparency into our release cycle and in striving to maintain backward compatibility, Bootstrap is maintained under the Semantic Versioning guidelines. Sometimes we screw up, but we'll adhere to these rules whenever possible. |
||||||
|
|
||||||
|
Releases will be numbered with the following format: |
||||||
|
|
||||||
|
`<major>.<minor>.<patch>` |
||||||
|
|
||||||
|
And constructed with the following guidelines: |
||||||
|
|
||||||
|
- Breaking backward compatibility **bumps the major** while resetting minor and patch |
||||||
|
- New additions without breaking backward compatibility **bumps the minor** while resetting the patch |
||||||
|
- Bug fixes and misc changes **bumps only the patch** |
||||||
|
|
||||||
|
For more information on SemVer, please visit <http://semver.org/>. |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## Authors |
||||||
|
|
||||||
|
**Mark Otto** |
||||||
|
|
||||||
|
- <http://twitter.com/mdo> |
||||||
|
- <http://github.com/mdo> |
||||||
|
|
||||||
|
**Jacob Thornton** |
||||||
|
|
||||||
|
- <http://twitter.com/fat> |
||||||
|
- <http://github.com/fat> |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
## Copyright and license |
||||||
|
|
||||||
|
Code and documentation copyright 2011-2014 Twitter, Inc. Code released under [the MIT license](LICENSE). Docs released under [Creative Commons](docs/LICENSE). |
@ -0,0 +1,24 @@ |
|||||||
|
{ |
||||||
|
"name": "bootstrap", |
||||||
|
"version": "3.1.1", |
||||||
|
"main": [ |
||||||
|
"./dist/css/bootstrap.css", |
||||||
|
"./dist/js/bootstrap.js", |
||||||
|
"./dist/fonts/glyphicons-halflings-regular.eot", |
||||||
|
"./dist/fonts/glyphicons-halflings-regular.svg", |
||||||
|
"./dist/fonts/glyphicons-halflings-regular.ttf", |
||||||
|
"./dist/fonts/glyphicons-halflings-regular.woff" |
||||||
|
], |
||||||
|
"ignore": [ |
||||||
|
"**/.*", |
||||||
|
"_config.yml", |
||||||
|
"CNAME", |
||||||
|
"composer.json", |
||||||
|
"CONTRIBUTING.md", |
||||||
|
"docs", |
||||||
|
"js/tests" |
||||||
|
], |
||||||
|
"dependencies": { |
||||||
|
"jquery": ">= 1.9.0" |
||||||
|
} |
||||||
|
} |
Binary file not shown.
Before Width: | Height: | Size: 61 KiB After Width: | Height: | Size: 62 KiB |
Binary file not shown.
Binary file not shown.
@ -0,0 +1,34 @@ |
|||||||
|
/*! |
||||||
|
* Bootstrap Grunt task for Glyphicons data generation |
||||||
|
* http://getbootstrap.com
|
||||||
|
* Copyright 2014 Twitter, Inc. |
||||||
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
|
*/ |
||||||
|
'use strict'; |
||||||
|
var fs = require('fs'); |
||||||
|
|
||||||
|
module.exports = function generateGlyphiconsData() { |
||||||
|
// Pass encoding, utf8, so `readFileSync` will return a string instead of a
|
||||||
|
// buffer
|
||||||
|
var glyphiconsFile = fs.readFileSync('less/glyphicons.less', 'utf8'); |
||||||
|
var glpyhiconsLines = glyphiconsFile.split('\n'); |
||||||
|
|
||||||
|
// Use any line that starts with ".glyphicon-" and capture the class name
|
||||||
|
var iconClassName = /^\.(glyphicon-[^\s]+)/; |
||||||
|
var glyphiconsData = '# This file is generated via Grunt task. **Do not edit directly.**\n' + |
||||||
|
'# See the \'build-glyphicons-data\' task in Gruntfile.js.\n\n'; |
||||||
|
for (var i = 0, len = glpyhiconsLines.length; i < len; i++) { |
||||||
|
var match = glpyhiconsLines[i].match(iconClassName); |
||||||
|
|
||||||
|
if (match !== null) { |
||||||
|
glyphiconsData += '- ' + match[1] + '\n'; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Create the `_data` directory if it doesn't already exist
|
||||||
|
if (!fs.existsSync('docs/_data')) { |
||||||
|
fs.mkdirSync('docs/_data'); |
||||||
|
} |
||||||
|
|
||||||
|
fs.writeFileSync('docs/_data/glyphicons.yml', glyphiconsData); |
||||||
|
}; |
@ -0,0 +1,236 @@ |
|||||||
|
/*! |
||||||
|
* Bootstrap Grunt task for parsing Less docstrings |
||||||
|
* http://getbootstrap.com
|
||||||
|
* Copyright 2014 Twitter, Inc. |
||||||
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
|
*/ |
||||||
|
'use strict'; |
||||||
|
|
||||||
|
var markdown = require('markdown').markdown; |
||||||
|
|
||||||
|
function markdown2html(markdownString) { |
||||||
|
// the slice removes the <p>...</p> wrapper output by Markdown processor
|
||||||
|
return markdown.toHTML(markdownString.trim()).slice(3, -4); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
/* |
||||||
|
Mini-language: |
||||||
|
//== This is a normal heading, which starts a section. Sections group variables together.
|
||||||
|
//## Optional description for the heading
|
||||||
|
|
||||||
|
//=== This is a subheading.
|
||||||
|
|
||||||
|
//** Optional description for the following variable. You **can** use Markdown in descriptions to discuss `<html>` stuff.
|
||||||
|
@foo: #ffff; |
||||||
|
|
||||||
|
//-- This is a heading for a section whose variables shouldn't be customizable
|
||||||
|
|
||||||
|
All other lines are ignored completely. |
||||||
|
*/ |
||||||
|
|
||||||
|
|
||||||
|
var CUSTOMIZABLE_HEADING = /^[/]{2}={2}(.*)$/; |
||||||
|
var UNCUSTOMIZABLE_HEADING = /^[/]{2}-{2}(.*)$/; |
||||||
|
var SUBSECTION_HEADING = /^[/]{2}={3}(.*)$/; |
||||||
|
var SECTION_DOCSTRING = /^[/]{2}#{2}(.*)$/; |
||||||
|
var VAR_ASSIGNMENT = /^(@[a-zA-Z0-9_-]+):[ ]*([^ ;][^;]+);[ ]*$/; |
||||||
|
var VAR_DOCSTRING = /^[/]{2}[*]{2}(.*)$/; |
||||||
|
|
||||||
|
function Section(heading, customizable) { |
||||||
|
this.heading = heading.trim(); |
||||||
|
this.id = this.heading.replace(/\s+/g, '-').toLowerCase(); |
||||||
|
this.customizable = customizable; |
||||||
|
this.docstring = null; |
||||||
|
this.subsections = []; |
||||||
|
} |
||||||
|
|
||||||
|
Section.prototype.addSubSection = function (subsection) { |
||||||
|
this.subsections.push(subsection); |
||||||
|
}; |
||||||
|
|
||||||
|
function SubSection(heading) { |
||||||
|
this.heading = heading.trim(); |
||||||
|
this.id = this.heading.replace(/\s+/g, '-').toLowerCase(); |
||||||
|
this.variables = []; |
||||||
|
} |
||||||
|
|
||||||
|
SubSection.prototype.addVar = function (variable) { |
||||||
|
this.variables.push(variable); |
||||||
|
}; |
||||||
|
|
||||||
|
function VarDocstring(markdownString) { |
||||||
|
this.html = markdown2html(markdownString); |
||||||
|
} |
||||||
|
|
||||||
|
function SectionDocstring(markdownString) { |
||||||
|
this.html = markdown2html(markdownString); |
||||||
|
} |
||||||
|
|
||||||
|
function Variable(name, defaultValue) { |
||||||
|
this.name = name; |
||||||
|
this.defaultValue = defaultValue; |
||||||
|
this.docstring = null; |
||||||
|
} |
||||||
|
|
||||||
|
function Tokenizer(fileContent) { |
||||||
|
this._lines = fileContent.split('\n'); |
||||||
|
this._next = undefined; |
||||||
|
} |
||||||
|
|
||||||
|
Tokenizer.prototype.unshift = function (token) { |
||||||
|
if (this._next !== undefined) { |
||||||
|
throw new Error('Attempted to unshift twice!'); |
||||||
|
} |
||||||
|
this._next = token; |
||||||
|
}; |
||||||
|
|
||||||
|
Tokenizer.prototype._shift = function () { |
||||||
|
// returning null signals EOF
|
||||||
|
// returning undefined means the line was ignored
|
||||||
|
if (this._next !== undefined) { |
||||||
|
var result = this._next; |
||||||
|
this._next = undefined; |
||||||
|
return result; |
||||||
|
} |
||||||
|
if (this._lines.length <= 0) { |
||||||
|
return null; |
||||||
|
} |
||||||
|
var line = this._lines.shift(); |
||||||
|
var match = null; |
||||||
|
match = SUBSECTION_HEADING.exec(line); |
||||||
|
if (match !== null) { |
||||||
|
return new SubSection(match[1]); |
||||||
|
} |
||||||
|
match = CUSTOMIZABLE_HEADING.exec(line); |
||||||
|
if (match !== null) { |
||||||
|
return new Section(match[1], true); |
||||||
|
} |
||||||
|
match = UNCUSTOMIZABLE_HEADING.exec(line); |
||||||
|
if (match !== null) { |
||||||
|
return new Section(match[1], false); |
||||||
|
} |
||||||
|
match = SECTION_DOCSTRING.exec(line); |
||||||
|
if (match !== null) { |
||||||
|
return new SectionDocstring(match[1]); |
||||||
|
} |
||||||
|
match = VAR_DOCSTRING.exec(line); |
||||||
|
if (match !== null) { |
||||||
|
return new VarDocstring(match[1]); |
||||||
|
} |
||||||
|
var commentStart = line.lastIndexOf('//'); |
||||||
|
var varLine = (commentStart === -1) ? line : line.slice(0, commentStart); |
||||||
|
match = VAR_ASSIGNMENT.exec(varLine); |
||||||
|
if (match !== null) { |
||||||
|
return new Variable(match[1], match[2]); |
||||||
|
} |
||||||
|
return undefined; |
||||||
|
}; |
||||||
|
|
||||||
|
Tokenizer.prototype.shift = function () { |
||||||
|
while (true) { |
||||||
|
var result = this._shift(); |
||||||
|
if (result === undefined) { |
||||||
|
continue; |
||||||
|
} |
||||||
|
return result; |
||||||
|
} |
||||||
|
}; |
||||||
|
|
||||||
|
function Parser(fileContent) { |
||||||
|
this._tokenizer = new Tokenizer(fileContent); |
||||||
|
} |
||||||
|
|
||||||
|
Parser.prototype.parseFile = function () { |
||||||
|
var sections = []; |
||||||
|
while (true) { |
||||||
|
var section = this.parseSection(); |
||||||
|
if (section === null) { |
||||||
|
if (this._tokenizer.shift() !== null) { |
||||||
|
throw new Error('Unexpected unparsed section of file remains!'); |
||||||
|
} |
||||||
|
return sections; |
||||||
|
} |
||||||
|
sections.push(section); |
||||||
|
} |
||||||
|
}; |
||||||
|
|
||||||
|
Parser.prototype.parseSection = function () { |
||||||
|
var section = this._tokenizer.shift(); |
||||||
|
if (section === null) { |
||||||
|
return null; |
||||||
|
} |
||||||
|
if (!(section instanceof Section)) { |
||||||
|
throw new Error('Expected section heading; got: ' + JSON.stringify(section)); |
||||||
|
} |
||||||
|
var docstring = this._tokenizer.shift(); |
||||||
|
if (docstring instanceof SectionDocstring) { |
||||||
|
section.docstring = docstring; |
||||||
|
} |
||||||
|
else { |
||||||
|
this._tokenizer.unshift(docstring); |
||||||
|
} |
||||||
|
this.parseSubSections(section); |
||||||
|
|
||||||
|
return section; |
||||||
|
}; |
||||||
|
|
||||||
|
Parser.prototype.parseSubSections = function (section) { |
||||||
|
while (true) { |
||||||
|
var subsection = this.parseSubSection(); |
||||||
|
if (subsection === null) { |
||||||
|
if (section.subsections.length === 0) { |
||||||
|
// Presume an implicit initial subsection
|
||||||
|
subsection = new SubSection(''); |
||||||
|
this.parseVars(subsection); |
||||||
|
} |
||||||
|
else { |
||||||
|
break; |
||||||
|
} |
||||||
|
} |
||||||
|
section.addSubSection(subsection); |
||||||
|
} |
||||||
|
|
||||||
|
if (section.subsections.length === 1 && !(section.subsections[0].heading) && section.subsections[0].variables.length === 0) { |
||||||
|
// Ignore lone empty implicit subsection
|
||||||
|
section.subsections = []; |
||||||
|
} |
||||||
|
}; |
||||||
|
|
||||||
|
Parser.prototype.parseSubSection = function () { |
||||||
|
var subsection = this._tokenizer.shift(); |
||||||
|
if (subsection instanceof SubSection) { |
||||||
|
this.parseVars(subsection); |
||||||
|
return subsection; |
||||||
|
} |
||||||
|
this._tokenizer.unshift(subsection); |
||||||
|
return null; |
||||||
|
}; |
||||||
|
|
||||||
|
Parser.prototype.parseVars = function (subsection) { |
||||||
|
while (true) { |
||||||
|
var variable = this.parseVar(); |
||||||
|
if (variable === null) { |
||||||
|
return; |
||||||
|
} |
||||||
|
subsection.addVar(variable); |
||||||
|
} |
||||||
|
}; |
||||||
|
|
||||||
|
Parser.prototype.parseVar = function () { |
||||||
|
var docstring = this._tokenizer.shift(); |
||||||
|
if (!(docstring instanceof VarDocstring)) { |
||||||
|
this._tokenizer.unshift(docstring); |
||||||
|
docstring = null; |
||||||
|
} |
||||||
|
var variable = this._tokenizer.shift(); |
||||||
|
if (variable instanceof Variable) { |
||||||
|
variable.docstring = docstring; |
||||||
|
return variable; |
||||||
|
} |
||||||
|
this._tokenizer.unshift(variable); |
||||||
|
return null; |
||||||
|
}; |
||||||
|
|
||||||
|
|
||||||
|
module.exports = Parser; |
@ -0,0 +1,31 @@ |
|||||||
|
/* global btoa: true */ |
||||||
|
/*! |
||||||
|
* Bootstrap Grunt task for generating raw-files.min.js for the Customizer |
||||||
|
* http://getbootstrap.com
|
||||||
|
* Copyright 2014 Twitter, Inc. |
||||||
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
|
*/ |
||||||
|
'use strict'; |
||||||
|
var btoa = require('btoa'); |
||||||
|
var fs = require('fs'); |
||||||
|
|
||||||
|
function getFiles(type) { |
||||||
|
var files = {}; |
||||||
|
fs.readdirSync(type) |
||||||
|
.filter(function (path) { |
||||||
|
return type === 'fonts' ? true : new RegExp('\\.' + type + '$').test(path); |
||||||
|
}) |
||||||
|
.forEach(function (path) { |
||||||
|
var fullPath = type + '/' + path; |
||||||
|
files[path] = (type === 'fonts' ? btoa(fs.readFileSync(fullPath)) : fs.readFileSync(fullPath, 'utf8')); |
||||||
|
}); |
||||||
|
return 'var __' + type + ' = ' + JSON.stringify(files) + '\n'; |
||||||
|
} |
||||||
|
|
||||||
|
module.exports = function generateRawFilesJs(banner) { |
||||||
|
if (!banner) { |
||||||
|
banner = ''; |
||||||
|
} |
||||||
|
var files = banner + getFiles('js') + getFiles('less') + getFiles('fonts'); |
||||||
|
fs.writeFileSync('docs/assets/js/raw-files.min.js', files); |
||||||
|
}; |
@ -0,0 +1,28 @@ |
|||||||
|
/*! |
||||||
|
* Bootstrap Grunt task for generating npm-shrinkwrap.canonical.json |
||||||
|
* http://getbootstrap.com
|
||||||
|
* Copyright 2014 Twitter, Inc. |
||||||
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
|
*/ |
||||||
|
/* |
||||||
|
This Grunt task updates the npm-shrinkwrap.canonical.json file that's used as the key for Bootstrap's npm packages cache. |
||||||
|
This task should be run and the updated file should be committed whenever Bootstrap's dependencies change. |
||||||
|
*/ |
||||||
|
'use strict'; |
||||||
|
var canonicallyJsonStringify = require('canonical-json'); |
||||||
|
var NON_CANONICAL_FILE = 'npm-shrinkwrap.json'; |
||||||
|
var DEST_FILE = 'test-infra/npm-shrinkwrap.canonical.json'; |
||||||
|
|
||||||
|
|
||||||
|
function updateShrinkwrap(grunt) { |
||||||
|
// Assumption: Non-canonical shrinkwrap already generated by prerequisite Grunt task
|
||||||
|
var shrinkwrapData = grunt.file.readJSON(NON_CANONICAL_FILE); |
||||||
|
grunt.log.writeln('Deleting ' + NON_CANONICAL_FILE.cyan + '...'); |
||||||
|
grunt.file.delete(NON_CANONICAL_FILE); |
||||||
|
// Output as Canonical JSON in correct location
|
||||||
|
grunt.file.write(DEST_FILE, canonicallyJsonStringify(shrinkwrapData)); |
||||||
|
grunt.log.writeln('File ' + DEST_FILE.cyan + ' updated.'); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
module.exports = updateShrinkwrap; |
@ -0,0 +1,137 @@ |
|||||||
|
/* ======================================================================== |
||||||
|
* Bootstrap: affix.js v3.1.1 |
||||||
|
* http://getbootstrap.com/javascript/#affix
|
||||||
|
* ======================================================================== |
||||||
|
* Copyright 2011-2014 Twitter, Inc. |
||||||
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
|
* ======================================================================== */ |
||||||
|
|
||||||
|
|
||||||
|
+function ($) { |
||||||
|
'use strict'; |
||||||
|
|
||||||
|
// AFFIX CLASS DEFINITION
|
||||||
|
// ======================
|
||||||
|
|
||||||
|
var Affix = function (element, options) { |
||||||
|
this.options = $.extend({}, Affix.DEFAULTS, options) |
||||||
|
this.$window = $(window) |
||||||
|
.on('scroll.bs.affix.data-api', $.proxy(this.checkPosition, this)) |
||||||
|
.on('click.bs.affix.data-api', $.proxy(this.checkPositionWithEventLoop, this)) |
||||||
|
|
||||||
|
this.$element = $(element) |
||||||
|
this.affixed = |
||||||
|
this.unpin = |
||||||
|
this.pinnedOffset = null |
||||||
|
|
||||||
|
this.checkPosition() |
||||||
|
} |
||||||
|
|
||||||
|
Affix.RESET = 'affix affix-top affix-bottom' |
||||||
|
|
||||||
|
Affix.DEFAULTS = { |
||||||
|
offset: 0 |
||||||
|
} |
||||||
|
|
||||||
|
Affix.prototype.getPinnedOffset = function () { |
||||||
|
if (this.pinnedOffset) return this.pinnedOffset |
||||||
|
this.$element.removeClass(Affix.RESET).addClass('affix') |
||||||
|
var scrollTop = this.$window.scrollTop() |
||||||
|
var position = this.$element.offset() |
||||||
|
return (this.pinnedOffset = position.top - scrollTop) |
||||||
|
} |
||||||
|
|
||||||
|
Affix.prototype.checkPositionWithEventLoop = function () { |
||||||
|
setTimeout($.proxy(this.checkPosition, this), 1) |
||||||
|
} |
||||||
|
|
||||||
|
Affix.prototype.checkPosition = function () { |
||||||
|
if (!this.$element.is(':visible')) return |
||||||
|
|
||||||
|
var scrollHeight = $(document).height() |
||||||
|
var scrollTop = this.$window.scrollTop() |
||||||
|
var position = this.$element.offset() |
||||||
|
var offset = this.options.offset |
||||||
|
var offsetTop = offset.top |
||||||
|
var offsetBottom = offset.bottom |
||||||
|
|
||||||
|
if (this.affixed == 'top') position.top += scrollTop |
||||||
|
|
||||||
|
if (typeof offset != 'object') offsetBottom = offsetTop = offset |
||||||
|
if (typeof offsetTop == 'function') offsetTop = offset.top(this.$element) |
||||||
|
if (typeof offsetBottom == 'function') offsetBottom = offset.bottom(this.$element) |
||||||
|
|
||||||
|
var affix = this.unpin != null && (scrollTop + this.unpin <= position.top) ? false : |
||||||
|
offsetBottom != null && (position.top + this.$element.height() >= scrollHeight - offsetBottom) ? 'bottom' : |
||||||
|
offsetTop != null && (scrollTop <= offsetTop) ? 'top' : false |
||||||
|
|
||||||
|
if (this.affixed === affix) return |
||||||
|
if (this.unpin) this.$element.css('top', '') |
||||||
|
|
||||||
|
var affixType = 'affix' + (affix ? '-' + affix : '') |
||||||
|
var e = $.Event(affixType + '.bs.affix') |
||||||
|
|
||||||
|
this.$element.trigger(e) |
||||||
|
|
||||||
|
if (e.isDefaultPrevented()) return |
||||||
|
|
||||||
|
this.affixed = affix |
||||||
|
this.unpin = affix == 'bottom' ? this.getPinnedOffset() : null |
||||||
|
|
||||||
|
this.$element |
||||||
|
.removeClass(Affix.RESET) |
||||||
|
.addClass(affixType) |
||||||
|
.trigger($.Event(affixType.replace('affix', 'affixed'))) |
||||||
|
|
||||||
|
if (affix == 'bottom') { |
||||||
|
this.$element.offset({ top: scrollHeight - offsetBottom - this.$element.height() }) |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// AFFIX PLUGIN DEFINITION
|
||||||
|
// =======================
|
||||||
|
|
||||||
|
var old = $.fn.affix |
||||||
|
|
||||||
|
$.fn.affix = function (option) { |
||||||
|
return this.each(function () { |
||||||
|
var $this = $(this) |
||||||
|
var data = $this.data('bs.affix') |
||||||
|
var options = typeof option == 'object' && option |
||||||
|
|
||||||
|
if (!data) $this.data('bs.affix', (data = new Affix(this, options))) |
||||||
|
if (typeof option == 'string') data[option]() |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
$.fn.affix.Constructor = Affix |
||||||
|
|
||||||
|
|
||||||
|
// AFFIX NO CONFLICT
|
||||||
|
// =================
|
||||||
|
|
||||||
|
$.fn.affix.noConflict = function () { |
||||||
|
$.fn.affix = old |
||||||
|
return this |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// AFFIX DATA-API
|
||||||
|
// ==============
|
||||||
|
|
||||||
|
$(window).on('load', function () { |
||||||
|
$('[data-spy="affix"]').each(function () { |
||||||
|
var $spy = $(this) |
||||||
|
var data = $spy.data() |
||||||
|
|
||||||
|
data.offset = data.offset || {} |
||||||
|
|
||||||
|
if (data.offsetBottom) data.offset.bottom = data.offsetBottom |
||||||
|
if (data.offsetTop) data.offset.top = data.offsetTop |
||||||
|
|
||||||
|
$spy.affix(data) |
||||||
|
}) |
||||||
|
}) |
||||||
|
|
||||||
|
}(jQuery); |
@ -0,0 +1,88 @@ |
|||||||
|
/* ======================================================================== |
||||||
|
* Bootstrap: alert.js v3.1.1 |
||||||
|
* http://getbootstrap.com/javascript/#alerts
|
||||||
|
* ======================================================================== |
||||||
|
* Copyright 2011-2014 Twitter, Inc. |
||||||
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
|
* ======================================================================== */ |
||||||
|
|
||||||
|
|
||||||
|
+function ($) { |
||||||
|
'use strict'; |
||||||
|
|
||||||
|
// ALERT CLASS DEFINITION
|
||||||
|
// ======================
|
||||||
|
|
||||||
|
var dismiss = '[data-dismiss="alert"]' |
||||||
|
var Alert = function (el) { |
||||||
|
$(el).on('click', dismiss, this.close) |
||||||
|
} |
||||||
|
|
||||||
|
Alert.prototype.close = function (e) { |
||||||
|
var $this = $(this) |
||||||
|
var selector = $this.attr('data-target') |
||||||
|
|
||||||
|
if (!selector) { |
||||||
|
selector = $this.attr('href') |
||||||
|
selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') // strip for ie7
|
||||||
|
} |
||||||
|
|
||||||
|
var $parent = $(selector) |
||||||
|
|
||||||
|
if (e) e.preventDefault() |
||||||
|
|
||||||
|
if (!$parent.length) { |
||||||
|
$parent = $this.hasClass('alert') ? $this : $this.parent() |
||||||
|
} |
||||||
|
|
||||||
|
$parent.trigger(e = $.Event('close.bs.alert')) |
||||||
|
|
||||||
|
if (e.isDefaultPrevented()) return |
||||||
|
|
||||||
|
$parent.removeClass('in') |
||||||
|
|
||||||
|
function removeElement() { |
||||||
|
$parent.trigger('closed.bs.alert').remove() |
||||||
|
} |
||||||
|
|
||||||
|
$.support.transition && $parent.hasClass('fade') ? |
||||||
|
$parent |
||||||
|
.one($.support.transition.end, removeElement) |
||||||
|
.emulateTransitionEnd(150) : |
||||||
|
removeElement() |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// ALERT PLUGIN DEFINITION
|
||||||
|
// =======================
|
||||||
|
|
||||||
|
var old = $.fn.alert |
||||||
|
|
||||||
|
$.fn.alert = function (option) { |
||||||
|
return this.each(function () { |
||||||
|
var $this = $(this) |
||||||
|
var data = $this.data('bs.alert') |
||||||
|
|
||||||
|
if (!data) $this.data('bs.alert', (data = new Alert(this))) |
||||||
|
if (typeof option == 'string') data[option].call($this) |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
$.fn.alert.Constructor = Alert |
||||||
|
|
||||||
|
|
||||||
|
// ALERT NO CONFLICT
|
||||||
|
// =================
|
||||||
|
|
||||||
|
$.fn.alert.noConflict = function () { |
||||||
|
$.fn.alert = old |
||||||
|
return this |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// ALERT DATA-API
|
||||||
|
// ==============
|
||||||
|
|
||||||
|
$(document).on('click.bs.alert.data-api', dismiss, Alert.prototype.close) |
||||||
|
|
||||||
|
}(jQuery); |
@ -0,0 +1,107 @@ |
|||||||
|
/* ======================================================================== |
||||||
|
* Bootstrap: button.js v3.1.1 |
||||||
|
* http://getbootstrap.com/javascript/#buttons
|
||||||
|
* ======================================================================== |
||||||
|
* Copyright 2011-2014 Twitter, Inc. |
||||||
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
|
* ======================================================================== */ |
||||||
|
|
||||||
|
|
||||||
|
+function ($) { |
||||||
|
'use strict'; |
||||||
|
|
||||||
|
// BUTTON PUBLIC CLASS DEFINITION
|
||||||
|
// ==============================
|
||||||
|
|
||||||
|
var Button = function (element, options) { |
||||||
|
this.$element = $(element) |
||||||
|
this.options = $.extend({}, Button.DEFAULTS, options) |
||||||
|
this.isLoading = false |
||||||
|
} |
||||||
|
|
||||||
|
Button.DEFAULTS = { |
||||||
|
loadingText: 'loading...' |
||||||
|
} |
||||||
|
|
||||||
|
Button.prototype.setState = function (state) { |
||||||
|
var d = 'disabled' |
||||||
|
var $el = this.$element |
||||||
|
var val = $el.is('input') ? 'val' : 'html' |
||||||
|
var data = $el.data() |
||||||
|
|
||||||
|
state = state + 'Text' |
||||||
|
|
||||||
|
if (!data.resetText) $el.data('resetText', $el[val]()) |
||||||
|
|
||||||
|
$el[val](data[state] || this.options[state]) |
||||||
|
|
||||||
|
// push to event loop to allow forms to submit
|
||||||
|
setTimeout($.proxy(function () { |
||||||
|
if (state == 'loadingText') { |
||||||
|
this.isLoading = true |
||||||
|
$el.addClass(d).attr(d, d) |
||||||
|
} else if (this.isLoading) { |
||||||
|
this.isLoading = false |
||||||
|
$el.removeClass(d).removeAttr(d) |
||||||
|
} |
||||||
|
}, this), 0) |
||||||
|
} |
||||||
|
|
||||||
|
Button.prototype.toggle = function () { |
||||||
|
var changed = true |
||||||
|
var $parent = this.$element.closest('[data-toggle="buttons"]') |
||||||
|
|
||||||
|
if ($parent.length) { |
||||||
|
var $input = this.$element.find('input') |
||||||
|
if ($input.prop('type') == 'radio') { |
||||||
|
if ($input.prop('checked') && this.$element.hasClass('active')) changed = false |
||||||
|
else $parent.find('.active').removeClass('active') |
||||||
|
} |
||||||
|
if (changed) $input.prop('checked', !this.$element.hasClass('active')).trigger('change') |
||||||
|
} |
||||||
|
|
||||||
|
if (changed) this.$element.toggleClass('active') |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// BUTTON PLUGIN DEFINITION
|
||||||
|
// ========================
|
||||||
|
|
||||||
|
var old = $.fn.button |
||||||
|
|
||||||
|
$.fn.button = function (option) { |
||||||
|
return this.each(function () { |
||||||
|
var $this = $(this) |
||||||
|
var data = $this.data('bs.button') |
||||||
|
var options = typeof option == 'object' && option |
||||||
|
|
||||||
|
if (!data) $this.data('bs.button', (data = new Button(this, options))) |
||||||
|
|
||||||
|
if (option == 'toggle') data.toggle() |
||||||
|
else if (option) data.setState(option) |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
$.fn.button.Constructor = Button |
||||||
|
|
||||||
|
|
||||||
|
// BUTTON NO CONFLICT
|
||||||
|
// ==================
|
||||||
|
|
||||||
|
$.fn.button.noConflict = function () { |
||||||
|
$.fn.button = old |
||||||
|
return this |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// BUTTON DATA-API
|
||||||
|
// ===============
|
||||||
|
|
||||||
|
$(document).on('click.bs.button.data-api', '[data-toggle^=button]', function (e) { |
||||||
|
var $btn = $(e.target) |
||||||
|
if (!$btn.hasClass('btn')) $btn = $btn.closest('.btn') |
||||||
|
$btn.button('toggle') |
||||||
|
e.preventDefault() |
||||||
|
}) |
||||||
|
|
||||||
|
}(jQuery); |
@ -0,0 +1,205 @@ |
|||||||
|
/* ======================================================================== |
||||||
|
* Bootstrap: carousel.js v3.1.1 |
||||||
|
* http://getbootstrap.com/javascript/#carousel
|
||||||
|
* ======================================================================== |
||||||
|
* Copyright 2011-2014 Twitter, Inc. |
||||||
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
|
* ======================================================================== */ |
||||||
|
|
||||||
|
|
||||||
|
+function ($) { |
||||||
|
'use strict'; |
||||||
|
|
||||||
|
// CAROUSEL CLASS DEFINITION
|
||||||
|
// =========================
|
||||||
|
|
||||||
|
var Carousel = function (element, options) { |
||||||
|
this.$element = $(element) |
||||||
|
this.$indicators = this.$element.find('.carousel-indicators') |
||||||
|
this.options = options |
||||||
|
this.paused = |
||||||
|
this.sliding = |
||||||
|
this.interval = |
||||||
|
this.$active = |
||||||
|
this.$items = null |
||||||
|
|
||||||
|
this.options.pause == 'hover' && this.$element |
||||||
|
.on('mouseenter', $.proxy(this.pause, this)) |
||||||
|
.on('mouseleave', $.proxy(this.cycle, this)) |
||||||
|
} |
||||||
|
|
||||||
|
Carousel.DEFAULTS = { |
||||||
|
interval: 5000, |
||||||
|
pause: 'hover', |
||||||
|
wrap: true |
||||||
|
} |
||||||
|
|
||||||
|
Carousel.prototype.cycle = function (e) { |
||||||
|
e || (this.paused = false) |
||||||
|
|
||||||
|
this.interval && clearInterval(this.interval) |
||||||
|
|
||||||
|
this.options.interval |
||||||
|
&& !this.paused |
||||||
|
&& (this.interval = setInterval($.proxy(this.next, this), this.options.interval)) |
||||||
|
|
||||||
|
return this |
||||||
|
} |
||||||
|
|
||||||
|
Carousel.prototype.getActiveIndex = function () { |
||||||
|
this.$active = this.$element.find('.item.active') |
||||||
|
this.$items = this.$active.parent().children() |
||||||
|
|
||||||
|
return this.$items.index(this.$active) |
||||||
|
} |
||||||
|
|
||||||
|
Carousel.prototype.to = function (pos) { |
||||||
|
var that = this |
||||||
|
var activeIndex = this.getActiveIndex() |
||||||
|
|
||||||
|
if (pos > (this.$items.length - 1) || pos < 0) return |
||||||
|
|
||||||
|
if (this.sliding) return this.$element.one('slid.bs.carousel', function () { that.to(pos) }) |
||||||
|
if (activeIndex == pos) return this.pause().cycle() |
||||||
|
|
||||||
|
return this.slide(pos > activeIndex ? 'next' : 'prev', $(this.$items[pos])) |
||||||
|
} |
||||||
|
|
||||||
|
Carousel.prototype.pause = function (e) { |
||||||
|
e || (this.paused = true) |
||||||
|
|
||||||
|
if (this.$element.find('.next, .prev').length && $.support.transition) { |
||||||
|
this.$element.trigger($.support.transition.end) |
||||||
|
this.cycle(true) |
||||||
|
} |
||||||
|
|
||||||
|
this.interval = clearInterval(this.interval) |
||||||
|
|
||||||
|
return this |
||||||
|
} |
||||||
|
|
||||||
|
Carousel.prototype.next = function () { |
||||||
|
if (this.sliding) return |
||||||
|
return this.slide('next') |
||||||
|
} |
||||||
|
|
||||||
|
Carousel.prototype.prev = function () { |
||||||
|
if (this.sliding) return |
||||||
|
return this.slide('prev') |
||||||
|
} |
||||||
|
|
||||||
|
Carousel.prototype.slide = function (type, next) { |
||||||
|
var $active = this.$element.find('.item.active') |
||||||
|
var $next = next || $active[type]() |
||||||
|
var isCycling = this.interval |
||||||
|
var direction = type == 'next' ? 'left' : 'right' |
||||||
|
var fallback = type == 'next' ? 'first' : 'last' |
||||||
|
var that = this |
||||||
|
|
||||||
|
if (!$next.length) { |
||||||
|
if (!this.options.wrap) return |
||||||
|
$next = this.$element.find('.item')[fallback]() |
||||||
|
} |
||||||
|
|
||||||
|
if ($next.hasClass('active')) return this.sliding = false |
||||||
|
|
||||||
|
var e = $.Event('slide.bs.carousel', { relatedTarget: $next[0], direction: direction }) |
||||||
|
this.$element.trigger(e) |
||||||
|
if (e.isDefaultPrevented()) return |
||||||
|
|
||||||
|
this.sliding = true |
||||||
|
|
||||||
|
isCycling && this.pause() |
||||||
|
|
||||||
|
if (this.$indicators.length) { |
||||||
|
this.$indicators.find('.active').removeClass('active') |
||||||
|
this.$element.one('slid.bs.carousel', function () { |
||||||
|
var $nextIndicator = $(that.$indicators.children()[that.getActiveIndex()]) |
||||||
|
$nextIndicator && $nextIndicator.addClass('active') |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
if ($.support.transition && this.$element.hasClass('slide')) { |
||||||
|
$next.addClass(type) |
||||||
|
$next[0].offsetWidth // force reflow
|
||||||
|
$active.addClass(direction) |
||||||
|
$next.addClass(direction) |
||||||
|
$active |
||||||
|
.one($.support.transition.end, function () { |
||||||
|
$next.removeClass([type, direction].join(' ')).addClass('active') |
||||||
|
$active.removeClass(['active', direction].join(' ')) |
||||||
|
that.sliding = false |
||||||
|
setTimeout(function () { that.$element.trigger('slid.bs.carousel') }, 0) |
||||||
|
}) |
||||||
|
.emulateTransitionEnd($active.css('transition-duration').slice(0, -1) * 1000) |
||||||
|
} else { |
||||||
|
$active.removeClass('active') |
||||||
|
$next.addClass('active') |
||||||
|
this.sliding = false |
||||||
|
this.$element.trigger('slid.bs.carousel') |
||||||
|
} |
||||||
|
|
||||||
|
isCycling && this.cycle() |
||||||
|
|
||||||
|
return this |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// CAROUSEL PLUGIN DEFINITION
|
||||||
|
// ==========================
|
||||||
|
|
||||||
|
var old = $.fn.carousel |
||||||
|
|
||||||
|
$.fn.carousel = function (option) { |
||||||
|
return this.each(function () { |
||||||
|
var $this = $(this) |
||||||
|
var data = $this.data('bs.carousel') |
||||||
|
var options = $.extend({}, Carousel.DEFAULTS, $this.data(), typeof option == 'object' && option) |
||||||
|
var action = typeof option == 'string' ? option : options.slide |
||||||
|
|
||||||
|
if (!data) $this.data('bs.carousel', (data = new Carousel(this, options))) |
||||||
|
if (typeof option == 'number') data.to(option) |
||||||
|
else if (action) data[action]() |
||||||
|
else if (options.interval) data.pause().cycle() |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
$.fn.carousel.Constructor = Carousel |
||||||
|
|
||||||
|
|
||||||
|
// CAROUSEL NO CONFLICT
|
||||||
|
// ====================
|
||||||
|
|
||||||
|
$.fn.carousel.noConflict = function () { |
||||||
|
$.fn.carousel = old |
||||||
|
return this |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// CAROUSEL DATA-API
|
||||||
|
// =================
|
||||||
|
|
||||||
|
$(document).on('click.bs.carousel.data-api', '[data-slide], [data-slide-to]', function (e) { |
||||||
|
var $this = $(this), href |
||||||
|
var $target = $($this.attr('data-target') || (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
|
||||||
|
var options = $.extend({}, $target.data(), $this.data()) |
||||||
|
var slideIndex = $this.attr('data-slide-to') |
||||||
|
if (slideIndex) options.interval = false |
||||||
|
|
||||||
|
$target.carousel(options) |
||||||
|
|
||||||
|
if (slideIndex = $this.attr('data-slide-to')) { |
||||||
|
$target.data('bs.carousel').to(slideIndex) |
||||||
|
} |
||||||
|
|
||||||
|
e.preventDefault() |
||||||
|
}) |
||||||
|
|
||||||
|
$(window).on('load', function () { |
||||||
|
$('[data-ride="carousel"]').each(function () { |
||||||
|
var $carousel = $(this) |
||||||
|
$carousel.carousel($carousel.data()) |
||||||
|
}) |
||||||
|
}) |
||||||
|
|
||||||
|
}(jQuery); |
@ -0,0 +1,170 @@ |
|||||||
|
/* ======================================================================== |
||||||
|
* Bootstrap: collapse.js v3.1.1 |
||||||
|
* http://getbootstrap.com/javascript/#collapse
|
||||||
|
* ======================================================================== |
||||||
|
* Copyright 2011-2014 Twitter, Inc. |
||||||
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
|
* ======================================================================== */ |
||||||
|
|
||||||
|
|
||||||
|
+function ($) { |
||||||
|
'use strict'; |
||||||
|
|
||||||
|
// COLLAPSE PUBLIC CLASS DEFINITION
|
||||||
|
// ================================
|
||||||
|
|
||||||
|
var Collapse = function (element, options) { |
||||||
|
this.$element = $(element) |
||||||
|
this.options = $.extend({}, Collapse.DEFAULTS, options) |
||||||
|
this.transitioning = null |
||||||
|
|
||||||
|
if (this.options.parent) this.$parent = $(this.options.parent) |
||||||
|
if (this.options.toggle) this.toggle() |
||||||
|
} |
||||||
|
|
||||||
|
Collapse.DEFAULTS = { |
||||||
|
toggle: true |
||||||
|
} |
||||||
|
|
||||||
|
Collapse.prototype.dimension = function () { |
||||||
|
var hasWidth = this.$element.hasClass('width') |
||||||
|
return hasWidth ? 'width' : 'height' |
||||||
|
} |
||||||
|
|
||||||
|
Collapse.prototype.show = function () { |
||||||
|
if (this.transitioning || this.$element.hasClass('in')) return |
||||||
|
|
||||||
|
var startEvent = $.Event('show.bs.collapse') |
||||||
|
this.$element.trigger(startEvent) |
||||||
|
if (startEvent.isDefaultPrevented()) return |
||||||
|
|
||||||
|
var actives = this.$parent && this.$parent.find('> .panel > .in') |
||||||
|
|
||||||
|
if (actives && actives.length) { |
||||||
|
var hasData = actives.data('bs.collapse') |
||||||
|
if (hasData && hasData.transitioning) return |
||||||
|
actives.collapse('hide') |
||||||
|
hasData || actives.data('bs.collapse', null) |
||||||
|
} |
||||||
|
|
||||||
|
var dimension = this.dimension() |
||||||
|
|
||||||
|
this.$element |
||||||
|
.removeClass('collapse') |
||||||
|
.addClass('collapsing') |
||||||
|
[dimension](0) |
||||||
|
|
||||||
|
this.transitioning = 1 |
||||||
|
|
||||||
|
var complete = function () { |
||||||
|
this.$element |
||||||
|
.removeClass('collapsing') |
||||||
|
.addClass('collapse in') |
||||||
|
[dimension]('auto') |
||||||
|
this.transitioning = 0 |
||||||
|
this.$element.trigger('shown.bs.collapse') |
||||||
|
} |
||||||
|
|
||||||
|
if (!$.support.transition) return complete.call(this) |
||||||
|
|
||||||
|
var scrollSize = $.camelCase(['scroll', dimension].join('-')) |
||||||
|
|
||||||
|
this.$element |
||||||
|
.one($.support.transition.end, $.proxy(complete, this)) |
||||||
|
.emulateTransitionEnd(350) |
||||||
|
[dimension](this.$element[0][scrollSize]) |
||||||
|
} |
||||||
|
|
||||||
|
Collapse.prototype.hide = function () { |
||||||
|
if (this.transitioning || !this.$element.hasClass('in')) return |
||||||
|
|
||||||
|
var startEvent = $.Event('hide.bs.collapse') |
||||||
|
this.$element.trigger(startEvent) |
||||||
|
if (startEvent.isDefaultPrevented()) return |
||||||
|
|
||||||
|
var dimension = this.dimension() |
||||||
|
|
||||||
|
this.$element |
||||||
|
[dimension](this.$element[dimension]()) |
||||||
|
[0].offsetHeight |
||||||
|
|
||||||
|
this.$element |
||||||
|
.addClass('collapsing') |
||||||
|
.removeClass('collapse') |
||||||
|
.removeClass('in') |
||||||
|
|
||||||
|
this.transitioning = 1 |
||||||
|
|
||||||
|
var complete = function () { |
||||||
|
this.transitioning = 0 |
||||||
|
this.$element |
||||||
|
.trigger('hidden.bs.collapse') |
||||||
|
.removeClass('collapsing') |
||||||
|
.addClass('collapse') |
||||||
|
} |
||||||
|
|
||||||
|
if (!$.support.transition) return complete.call(this) |
||||||
|
|
||||||
|
this.$element |
||||||
|
[dimension](0) |
||||||
|
.one($.support.transition.end, $.proxy(complete, this)) |
||||||
|
.emulateTransitionEnd(350) |
||||||
|
} |
||||||
|
|
||||||
|
Collapse.prototype.toggle = function () { |
||||||
|
this[this.$element.hasClass('in') ? 'hide' : 'show']() |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// COLLAPSE PLUGIN DEFINITION
|
||||||
|
// ==========================
|
||||||
|
|
||||||
|
var old = $.fn.collapse |
||||||
|
|
||||||
|
$.fn.collapse = function (option) { |
||||||
|
return this.each(function () { |
||||||
|
var $this = $(this) |
||||||
|
var data = $this.data('bs.collapse') |
||||||
|
var options = $.extend({}, Collapse.DEFAULTS, $this.data(), typeof option == 'object' && option) |
||||||
|
|
||||||
|
if (!data && options.toggle && option == 'show') option = !option |
||||||
|
if (!data) $this.data('bs.collapse', (data = new Collapse(this, options))) |
||||||
|
if (typeof option == 'string') data[option]() |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
$.fn.collapse.Constructor = Collapse |
||||||
|
|
||||||
|
|
||||||
|
// COLLAPSE NO CONFLICT
|
||||||
|
// ====================
|
||||||
|
|
||||||
|
$.fn.collapse.noConflict = function () { |
||||||
|
$.fn.collapse = old |
||||||
|
return this |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// COLLAPSE DATA-API
|
||||||
|
// =================
|
||||||
|
|
||||||
|
$(document).on('click.bs.collapse.data-api', '[data-toggle=collapse]', function (e) { |
||||||
|
var $this = $(this), href |
||||||
|
var target = $this.attr('data-target') |
||||||
|
|| e.preventDefault() |
||||||
|
|| (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '') //strip for ie7
|
||||||
|
var $target = $(target) |
||||||
|
var data = $target.data('bs.collapse') |
||||||
|
var option = data ? 'toggle' : $this.data() |
||||||
|
var parent = $this.attr('data-parent') |
||||||
|
var $parent = parent && $(parent) |
||||||
|
|
||||||
|
if (!data || !data.transitioning) { |
||||||
|
if ($parent) $parent.find('[data-toggle=collapse][data-parent="' + parent + '"]').not($this).addClass('collapsed') |
||||||
|
$this[$target.hasClass('in') ? 'addClass' : 'removeClass']('collapsed') |
||||||
|
} |
||||||
|
|
||||||
|
$target.collapse(option) |
||||||
|
}) |
||||||
|
|
||||||
|
}(jQuery); |
@ -0,0 +1,147 @@ |
|||||||
|
/* ======================================================================== |
||||||
|
* Bootstrap: dropdown.js v3.1.1 |
||||||
|
* http://getbootstrap.com/javascript/#dropdowns
|
||||||
|
* ======================================================================== |
||||||
|
* Copyright 2011-2014 Twitter, Inc. |
||||||
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
|
* ======================================================================== */ |
||||||
|
|
||||||
|
|
||||||
|
+function ($) { |
||||||
|
'use strict'; |
||||||
|
|
||||||
|
// DROPDOWN CLASS DEFINITION
|
||||||
|
// =========================
|
||||||
|
|
||||||
|
var backdrop = '.dropdown-backdrop' |
||||||
|
var toggle = '[data-toggle=dropdown]' |
||||||
|
var Dropdown = function (element) { |
||||||
|
$(element).on('click.bs.dropdown', this.toggle) |
||||||
|
} |
||||||
|
|
||||||
|
Dropdown.prototype.toggle = function (e) { |
||||||
|
var $this = $(this) |
||||||
|
|
||||||
|
if ($this.is('.disabled, :disabled')) return |
||||||
|
|
||||||
|
var $parent = getParent($this) |
||||||
|
var isActive = $parent.hasClass('open') |
||||||
|
|
||||||
|
clearMenus() |
||||||
|
|
||||||
|
if (!isActive) { |
||||||
|
if ('ontouchstart' in document.documentElement && !$parent.closest('.navbar-nav').length) { |
||||||
|
// if mobile we use a backdrop because click events don't delegate
|
||||||
|
$('<div class="dropdown-backdrop"/>').insertAfter($(this)).on('click', clearMenus) |
||||||
|
} |
||||||
|
|
||||||
|
var relatedTarget = { relatedTarget: this } |
||||||
|
$parent.trigger(e = $.Event('show.bs.dropdown', relatedTarget)) |
||||||
|
|
||||||
|
if (e.isDefaultPrevented()) return |
||||||
|
|
||||||
|
$parent |
||||||
|
.toggleClass('open') |
||||||
|
.trigger('shown.bs.dropdown', relatedTarget) |
||||||
|
|
||||||
|
$this.focus() |
||||||
|
} |
||||||
|
|
||||||
|
return false |
||||||
|
} |
||||||
|
|
||||||
|
Dropdown.prototype.keydown = function (e) { |
||||||
|
if (!/(38|40|27)/.test(e.keyCode)) return |
||||||
|
|
||||||
|
var $this = $(this) |
||||||
|
|
||||||
|
e.preventDefault() |
||||||
|
e.stopPropagation() |
||||||
|
|
||||||
|
if ($this.is('.disabled, :disabled')) return |
||||||
|
|
||||||
|
var $parent = getParent($this) |
||||||
|
var isActive = $parent.hasClass('open') |
||||||
|
|
||||||
|
if (!isActive || (isActive && e.keyCode == 27)) { |
||||||
|
if (e.which == 27) $parent.find(toggle).focus() |
||||||
|
return $this.click() |
||||||
|
} |
||||||
|
|
||||||
|
var desc = ' li:not(.divider):visible a' |
||||||
|
var $items = $parent.find('[role=menu]' + desc + ', [role=listbox]' + desc) |
||||||
|
|
||||||
|
if (!$items.length) return |
||||||
|
|
||||||
|
var index = $items.index($items.filter(':focus')) |
||||||
|
|
||||||
|
if (e.keyCode == 38 && index > 0) index-- // up
|
||||||
|
if (e.keyCode == 40 && index < $items.length - 1) index++ // down
|
||||||
|
if (!~index) index = 0 |
||||||
|
|
||||||
|
$items.eq(index).focus() |
||||||
|
} |
||||||
|
|
||||||
|
function clearMenus(e) { |
||||||
|
$(backdrop).remove() |
||||||
|
$(toggle).each(function () { |
||||||
|
var $parent = getParent($(this)) |
||||||
|
var relatedTarget = { relatedTarget: this } |
||||||
|
if (!$parent.hasClass('open')) return |
||||||
|
$parent.trigger(e = $.Event('hide.bs.dropdown', relatedTarget)) |
||||||
|
if (e.isDefaultPrevented()) return |
||||||
|
$parent.removeClass('open').trigger('hidden.bs.dropdown', relatedTarget) |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
function getParent($this) { |
||||||
|
var selector = $this.attr('data-target') |
||||||
|
|
||||||
|
if (!selector) { |
||||||
|
selector = $this.attr('href') |
||||||
|
selector = selector && /#[A-Za-z]/.test(selector) && selector.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
|
||||||
|
} |
||||||
|
|
||||||
|
var $parent = selector && $(selector) |
||||||
|
|
||||||
|
return $parent && $parent.length ? $parent : $this.parent() |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// DROPDOWN PLUGIN DEFINITION
|
||||||
|
// ==========================
|
||||||
|
|
||||||
|
var old = $.fn.dropdown |
||||||
|
|
||||||
|
$.fn.dropdown = function (option) { |
||||||
|
return this.each(function () { |
||||||
|
var $this = $(this) |
||||||
|
var data = $this.data('bs.dropdown') |
||||||
|
|
||||||
|
if (!data) $this.data('bs.dropdown', (data = new Dropdown(this))) |
||||||
|
if (typeof option == 'string') data[option].call($this) |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
$.fn.dropdown.Constructor = Dropdown |
||||||
|
|
||||||
|
|
||||||
|
// DROPDOWN NO CONFLICT
|
||||||
|
// ====================
|
||||||
|
|
||||||
|
$.fn.dropdown.noConflict = function () { |
||||||
|
$.fn.dropdown = old |
||||||
|
return this |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// APPLY TO STANDARD DROPDOWN ELEMENTS
|
||||||
|
// ===================================
|
||||||
|
|
||||||
|
$(document) |
||||||
|
.on('click.bs.dropdown.data-api', clearMenus) |
||||||
|
.on('click.bs.dropdown.data-api', '.dropdown form', function (e) { e.stopPropagation() }) |
||||||
|
.on('click.bs.dropdown.data-api', toggle, Dropdown.prototype.toggle) |
||||||
|
.on('keydown.bs.dropdown.data-api', toggle + ', [role=menu], [role=listbox]', Dropdown.prototype.keydown) |
||||||
|
|
||||||
|
}(jQuery); |
@ -0,0 +1,243 @@ |
|||||||
|
/* ======================================================================== |
||||||
|
* Bootstrap: modal.js v3.1.1 |
||||||
|
* http://getbootstrap.com/javascript/#modals
|
||||||
|
* ======================================================================== |
||||||
|
* Copyright 2011-2014 Twitter, Inc. |
||||||
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
|
* ======================================================================== */ |
||||||
|
|
||||||
|
|
||||||
|
+function ($) { |
||||||
|
'use strict'; |
||||||
|
|
||||||
|
// MODAL CLASS DEFINITION
|
||||||
|
// ======================
|
||||||
|
|
||||||
|
var Modal = function (element, options) { |
||||||
|
this.options = options |
||||||
|
this.$element = $(element) |
||||||
|
this.$backdrop = |
||||||
|
this.isShown = null |
||||||
|
|
||||||
|
if (this.options.remote) { |
||||||
|
this.$element |
||||||
|
.find('.modal-content') |
||||||
|
.load(this.options.remote, $.proxy(function () { |
||||||
|
this.$element.trigger('loaded.bs.modal') |
||||||
|
}, this)) |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
Modal.DEFAULTS = { |
||||||
|
backdrop: true, |
||||||
|
keyboard: true, |
||||||
|
show: true |
||||||
|
} |
||||||
|
|
||||||
|
Modal.prototype.toggle = function (_relatedTarget) { |
||||||
|
return this[!this.isShown ? 'show' : 'hide'](_relatedTarget) |
||||||
|
} |
||||||
|
|
||||||
|
Modal.prototype.show = function (_relatedTarget) { |
||||||
|
var that = this |
||||||
|
var e = $.Event('show.bs.modal', { relatedTarget: _relatedTarget }) |
||||||
|
|
||||||
|
this.$element.trigger(e) |
||||||
|
|
||||||
|
if (this.isShown || e.isDefaultPrevented()) return |
||||||
|
|
||||||
|
this.isShown = true |
||||||
|
|
||||||
|
this.escape() |
||||||
|
|
||||||
|
this.$element.on('click.dismiss.bs.modal', '[data-dismiss="modal"]', $.proxy(this.hide, this)) |
||||||
|
|
||||||
|
this.backdrop(function () { |
||||||
|
var transition = $.support.transition && that.$element.hasClass('fade') |
||||||
|
|
||||||
|
if (!that.$element.parent().length) { |
||||||
|
that.$element.appendTo(document.body) // don't move modals dom position
|
||||||
|
} |
||||||
|
|
||||||
|
that.$element |
||||||
|
.show() |
||||||
|
.scrollTop(0) |
||||||
|
|
||||||
|
if (transition) { |
||||||
|
that.$element[0].offsetWidth // force reflow
|
||||||
|
} |
||||||
|
|
||||||
|
that.$element |
||||||
|
.addClass('in') |
||||||
|
.attr('aria-hidden', false) |
||||||
|
|
||||||
|
that.enforceFocus() |
||||||
|
|
||||||
|
var e = $.Event('shown.bs.modal', { relatedTarget: _relatedTarget }) |
||||||
|
|
||||||
|
transition ? |
||||||
|
that.$element.find('.modal-dialog') // wait for modal to slide in
|
||||||
|
.one($.support.transition.end, function () { |
||||||
|
that.$element.focus().trigger(e) |
||||||
|
}) |
||||||
|
.emulateTransitionEnd(300) : |
||||||
|
that.$element.focus().trigger(e) |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
Modal.prototype.hide = function (e) { |
||||||
|
if (e) e.preventDefault() |
||||||
|
|
||||||
|
e = $.Event('hide.bs.modal') |
||||||
|
|
||||||
|
this.$element.trigger(e) |
||||||
|
|
||||||
|
if (!this.isShown || e.isDefaultPrevented()) return |
||||||
|
|
||||||
|
this.isShown = false |
||||||
|
|
||||||
|
this.escape() |
||||||
|
|
||||||
|
$(document).off('focusin.bs.modal') |
||||||
|
|
||||||
|
this.$element |
||||||
|
.removeClass('in') |
||||||
|
.attr('aria-hidden', true) |
||||||
|
.off('click.dismiss.bs.modal') |
||||||
|
|
||||||
|
$.support.transition && this.$element.hasClass('fade') ? |
||||||
|
this.$element |
||||||
|
.one($.support.transition.end, $.proxy(this.hideModal, this)) |
||||||
|
.emulateTransitionEnd(300) : |
||||||
|
this.hideModal() |
||||||
|
} |
||||||
|
|
||||||
|
Modal.prototype.enforceFocus = function () { |
||||||
|
$(document) |
||||||
|
.off('focusin.bs.modal') // guard against infinite focus loop
|
||||||
|
.on('focusin.bs.modal', $.proxy(function (e) { |
||||||
|
if (this.$element[0] !== e.target && !this.$element.has(e.target).length) { |
||||||
|
this.$element.focus() |
||||||
|
} |
||||||
|
}, this)) |
||||||
|
} |
||||||
|
|
||||||
|
Modal.prototype.escape = function () { |
||||||
|
if (this.isShown && this.options.keyboard) { |
||||||
|
this.$element.on('keyup.dismiss.bs.modal', $.proxy(function (e) { |
||||||
|
e.which == 27 && this.hide() |
||||||
|
}, this)) |
||||||
|
} else if (!this.isShown) { |
||||||
|
this.$element.off('keyup.dismiss.bs.modal') |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
Modal.prototype.hideModal = function () { |
||||||
|
var that = this |
||||||
|
this.$element.hide() |
||||||
|
this.backdrop(function () { |
||||||
|
that.removeBackdrop() |
||||||
|
that.$element.trigger('hidden.bs.modal') |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
Modal.prototype.removeBackdrop = function () { |
||||||
|
this.$backdrop && this.$backdrop.remove() |
||||||
|
this.$backdrop = null |
||||||
|
} |
||||||
|
|
||||||
|
Modal.prototype.backdrop = function (callback) { |
||||||
|
var animate = this.$element.hasClass('fade') ? 'fade' : '' |
||||||
|
|
||||||
|
if (this.isShown && this.options.backdrop) { |
||||||
|
var doAnimate = $.support.transition && animate |
||||||
|
|
||||||
|
this.$backdrop = $('<div class="modal-backdrop ' + animate + '" />') |
||||||
|
.appendTo(document.body) |
||||||
|
|
||||||
|
this.$element.on('click.dismiss.bs.modal', $.proxy(function (e) { |
||||||
|
if (e.target !== e.currentTarget) return |
||||||
|
this.options.backdrop == 'static' |
||||||
|
? this.$element[0].focus.call(this.$element[0]) |
||||||
|
: this.hide.call(this) |
||||||
|
}, this)) |
||||||
|
|
||||||
|
if (doAnimate) this.$backdrop[0].offsetWidth // force reflow
|
||||||
|
|
||||||
|
this.$backdrop.addClass('in') |
||||||
|
|
||||||
|
if (!callback) return |
||||||
|
|
||||||
|
doAnimate ? |
||||||
|
this.$backdrop |
||||||
|
.one($.support.transition.end, callback) |
||||||
|
.emulateTransitionEnd(150) : |
||||||
|
callback() |
||||||
|
|
||||||
|
} else if (!this.isShown && this.$backdrop) { |
||||||
|
this.$backdrop.removeClass('in') |
||||||
|
|
||||||
|
$.support.transition && this.$element.hasClass('fade') ? |
||||||
|
this.$backdrop |
||||||
|
.one($.support.transition.end, callback) |
||||||
|
.emulateTransitionEnd(150) : |
||||||
|
callback() |
||||||
|
|
||||||
|
} else if (callback) { |
||||||
|
callback() |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// MODAL PLUGIN DEFINITION
|
||||||
|
// =======================
|
||||||
|
|
||||||
|
var old = $.fn.modal |
||||||
|
|
||||||
|
$.fn.modal = function (option, _relatedTarget) { |
||||||
|
return this.each(function () { |
||||||
|
var $this = $(this) |
||||||
|
var data = $this.data('bs.modal') |
||||||
|
var options = $.extend({}, Modal.DEFAULTS, $this.data(), typeof option == 'object' && option) |
||||||
|
|
||||||
|
if (!data) $this.data('bs.modal', (data = new Modal(this, options))) |
||||||
|
if (typeof option == 'string') data[option](_relatedTarget) |
||||||
|
else if (options.show) data.show(_relatedTarget) |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
$.fn.modal.Constructor = Modal |
||||||
|
|
||||||
|
|
||||||
|
// MODAL NO CONFLICT
|
||||||
|
// =================
|
||||||
|
|
||||||
|
$.fn.modal.noConflict = function () { |
||||||
|
$.fn.modal = old |
||||||
|
return this |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// MODAL DATA-API
|
||||||
|
// ==============
|
||||||
|
|
||||||
|
$(document).on('click.bs.modal.data-api', '[data-toggle="modal"]', function (e) { |
||||||
|
var $this = $(this) |
||||||
|
var href = $this.attr('href') |
||||||
|
var $target = $($this.attr('data-target') || (href && href.replace(/.*(?=#[^\s]+$)/, ''))) //strip for ie7
|
||||||
|
var option = $target.data('bs.modal') ? 'toggle' : $.extend({ remote: !/#/.test(href) && href }, $target.data(), $this.data()) |
||||||
|
|
||||||
|
if ($this.is('a')) e.preventDefault() |
||||||
|
|
||||||
|
$target |
||||||
|
.modal(option, this) |
||||||
|
.one('hide', function () { |
||||||
|
$this.is(':visible') && $this.focus() |
||||||
|
}) |
||||||
|
}) |
||||||
|
|
||||||
|
$(document) |
||||||
|
.on('show.bs.modal', '.modal', function () { $(document.body).addClass('modal-open') }) |
||||||
|
.on('hidden.bs.modal', '.modal', function () { $(document.body).removeClass('modal-open') }) |
||||||
|
|
||||||
|
}(jQuery); |
@ -0,0 +1,110 @@ |
|||||||
|
/* ======================================================================== |
||||||
|
* Bootstrap: popover.js v3.1.1 |
||||||
|
* http://getbootstrap.com/javascript/#popovers
|
||||||
|
* ======================================================================== |
||||||
|
* Copyright 2011-2014 Twitter, Inc. |
||||||
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
|
* ======================================================================== */ |
||||||
|
|
||||||
|
|
||||||
|
+function ($) { |
||||||
|
'use strict'; |
||||||
|
|
||||||
|
// POPOVER PUBLIC CLASS DEFINITION
|
||||||
|
// ===============================
|
||||||
|
|
||||||
|
var Popover = function (element, options) { |
||||||
|
this.init('popover', element, options) |
||||||
|
} |
||||||
|
|
||||||
|
if (!$.fn.tooltip) throw new Error('Popover requires tooltip.js') |
||||||
|
|
||||||
|
Popover.DEFAULTS = $.extend({}, $.fn.tooltip.Constructor.DEFAULTS, { |
||||||
|
placement: 'right', |
||||||
|
trigger: 'click', |
||||||
|
content: '', |
||||||
|
template: '<div class="popover"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>' |
||||||
|
}) |
||||||
|
|
||||||
|
|
||||||
|
// NOTE: POPOVER EXTENDS tooltip.js
|
||||||
|
// ================================
|
||||||
|
|
||||||
|
Popover.prototype = $.extend({}, $.fn.tooltip.Constructor.prototype) |
||||||
|
|
||||||
|
Popover.prototype.constructor = Popover |
||||||
|
|
||||||
|
Popover.prototype.getDefaults = function () { |
||||||
|
return Popover.DEFAULTS |
||||||
|
} |
||||||
|
|
||||||
|
Popover.prototype.setContent = function () { |
||||||
|
var $tip = this.tip() |
||||||
|
var title = this.getTitle() |
||||||
|
var content = this.getContent() |
||||||
|
|
||||||
|
$tip.find('.popover-title')[this.options.html ? 'html' : 'text'](title) |
||||||
|
$tip.find('.popover-content')[ // we use append for html objects to maintain js events
|
||||||
|
this.options.html ? (typeof content == 'string' ? 'html' : 'append') : 'text' |
||||||
|
](content) |
||||||
|
|
||||||
|
$tip.removeClass('fade top bottom left right in') |
||||||
|
|
||||||
|
// IE8 doesn't accept hiding via the `:empty` pseudo selector, we have to do
|
||||||
|
// this manually by checking the contents.
|
||||||
|
if (!$tip.find('.popover-title').html()) $tip.find('.popover-title').hide() |
||||||
|
} |
||||||
|
|
||||||
|
Popover.prototype.hasContent = function () { |
||||||
|
return this.getTitle() || this.getContent() |
||||||
|
} |
||||||
|
|
||||||
|
Popover.prototype.getContent = function () { |
||||||
|
var $e = this.$element |
||||||
|
var o = this.options |
||||||
|
|
||||||
|
return $e.attr('data-content') |
||||||
|
|| (typeof o.content == 'function' ? |
||||||
|
o.content.call($e[0]) : |
||||||
|
o.content) |
||||||
|
} |
||||||
|
|
||||||
|
Popover.prototype.arrow = function () { |
||||||
|
return this.$arrow = this.$arrow || this.tip().find('.arrow') |
||||||
|
} |
||||||
|
|
||||||
|
Popover.prototype.tip = function () { |
||||||
|
if (!this.$tip) this.$tip = $(this.options.template) |
||||||
|
return this.$tip |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// POPOVER PLUGIN DEFINITION
|
||||||
|
// =========================
|
||||||
|
|
||||||
|
var old = $.fn.popover |
||||||
|
|
||||||
|
$.fn.popover = function (option) { |
||||||
|
return this.each(function () { |
||||||
|
var $this = $(this) |
||||||
|
var data = $this.data('bs.popover') |
||||||
|
var options = typeof option == 'object' && option |
||||||
|
|
||||||
|
if (!data && option == 'destroy') return |
||||||
|
if (!data) $this.data('bs.popover', (data = new Popover(this, options))) |
||||||
|
if (typeof option == 'string') data[option]() |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
$.fn.popover.Constructor = Popover |
||||||
|
|
||||||
|
|
||||||
|
// POPOVER NO CONFLICT
|
||||||
|
// ===================
|
||||||
|
|
||||||
|
$.fn.popover.noConflict = function () { |
||||||
|
$.fn.popover = old |
||||||
|
return this |
||||||
|
} |
||||||
|
|
||||||
|
}(jQuery); |
@ -0,0 +1,153 @@ |
|||||||
|
/* ======================================================================== |
||||||
|
* Bootstrap: scrollspy.js v3.1.1 |
||||||
|
* http://getbootstrap.com/javascript/#scrollspy
|
||||||
|
* ======================================================================== |
||||||
|
* Copyright 2011-2014 Twitter, Inc. |
||||||
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
|
* ======================================================================== */ |
||||||
|
|
||||||
|
|
||||||
|
+function ($) { |
||||||
|
'use strict'; |
||||||
|
|
||||||
|
// SCROLLSPY CLASS DEFINITION
|
||||||
|
// ==========================
|
||||||
|
|
||||||
|
function ScrollSpy(element, options) { |
||||||
|
var href |
||||||
|
var process = $.proxy(this.process, this) |
||||||
|
|
||||||
|
this.$element = $(element).is('body') ? $(window) : $(element) |
||||||
|
this.$body = $('body') |
||||||
|
this.$scrollElement = this.$element.on('scroll.bs.scroll-spy.data-api', process) |
||||||
|
this.options = $.extend({}, ScrollSpy.DEFAULTS, options) |
||||||
|
this.selector = (this.options.target |
||||||
|
|| ((href = $(element).attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
|
||||||
|
|| '') + ' .nav li > a' |
||||||
|
this.offsets = $([]) |
||||||
|
this.targets = $([]) |
||||||
|
this.activeTarget = null |
||||||
|
|
||||||
|
this.refresh() |
||||||
|
this.process() |
||||||
|
} |
||||||
|
|
||||||
|
ScrollSpy.DEFAULTS = { |
||||||
|
offset: 10 |
||||||
|
} |
||||||
|
|
||||||
|
ScrollSpy.prototype.refresh = function () { |
||||||
|
var offsetMethod = this.$element[0] == window ? 'offset' : 'position' |
||||||
|
|
||||||
|
this.offsets = $([]) |
||||||
|
this.targets = $([]) |
||||||
|
|
||||||
|
var self = this |
||||||
|
var $targets = this.$body |
||||||
|
.find(this.selector) |
||||||
|
.map(function () { |
||||||
|
var $el = $(this) |
||||||
|
var href = $el.data('target') || $el.attr('href') |
||||||
|
var $href = /^#./.test(href) && $(href) |
||||||
|
|
||||||
|
return ($href |
||||||
|
&& $href.length |
||||||
|
&& $href.is(':visible') |
||||||
|
&& [[ $href[offsetMethod]().top + (!$.isWindow(self.$scrollElement.get(0)) && self.$scrollElement.scrollTop()), href ]]) || null |
||||||
|
}) |
||||||
|
.sort(function (a, b) { return a[0] - b[0] }) |
||||||
|
.each(function () { |
||||||
|
self.offsets.push(this[0]) |
||||||
|
self.targets.push(this[1]) |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
ScrollSpy.prototype.process = function () { |
||||||
|
var scrollTop = this.$scrollElement.scrollTop() + this.options.offset |
||||||
|
var scrollHeight = this.$scrollElement[0].scrollHeight || this.$body[0].scrollHeight |
||||||
|
var maxScroll = scrollHeight - this.$scrollElement.height() |
||||||
|
var offsets = this.offsets |
||||||
|
var targets = this.targets |
||||||
|
var activeTarget = this.activeTarget |
||||||
|
var i |
||||||
|
|
||||||
|
if (scrollTop >= maxScroll) { |
||||||
|
return activeTarget != (i = targets.last()[0]) && this.activate(i) |
||||||
|
} |
||||||
|
|
||||||
|
if (activeTarget && scrollTop <= offsets[0]) { |
||||||
|
return activeTarget != (i = targets[0]) && this.activate(i) |
||||||
|
} |
||||||
|
|
||||||
|
for (i = offsets.length; i--;) { |
||||||
|
activeTarget != targets[i] |
||||||
|
&& scrollTop >= offsets[i] |
||||||
|
&& (!offsets[i + 1] || scrollTop <= offsets[i + 1]) |
||||||
|
&& this.activate( targets[i] ) |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
ScrollSpy.prototype.activate = function (target) { |
||||||
|
this.activeTarget = target |
||||||
|
|
||||||
|
$(this.selector) |
||||||
|
.parentsUntil(this.options.target, '.active') |
||||||
|
.removeClass('active') |
||||||
|
|
||||||
|
var selector = this.selector + |
||||||
|
'[data-target="' + target + '"],' + |
||||||
|
this.selector + '[href="' + target + '"]' |
||||||
|
|
||||||
|
var active = $(selector) |
||||||
|
.parents('li') |
||||||
|
.addClass('active') |
||||||
|
|
||||||
|
if (active.parent('.dropdown-menu').length) { |
||||||
|
active = active |
||||||
|
.closest('li.dropdown') |
||||||
|
.addClass('active') |
||||||
|
} |
||||||
|
|
||||||
|
active.trigger('activate.bs.scrollspy') |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// SCROLLSPY PLUGIN DEFINITION
|
||||||
|
// ===========================
|
||||||
|
|
||||||
|
var old = $.fn.scrollspy |
||||||
|
|
||||||
|
$.fn.scrollspy = function (option) { |
||||||
|
return this.each(function () { |
||||||
|
var $this = $(this) |
||||||
|
var data = $this.data('bs.scrollspy') |
||||||
|
var options = typeof option == 'object' && option |
||||||
|
|
||||||
|
if (!data) $this.data('bs.scrollspy', (data = new ScrollSpy(this, options))) |
||||||
|
if (typeof option == 'string') data[option]() |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
$.fn.scrollspy.Constructor = ScrollSpy |
||||||
|
|
||||||
|
|
||||||
|
// SCROLLSPY NO CONFLICT
|
||||||
|
// =====================
|
||||||
|
|
||||||
|
$.fn.scrollspy.noConflict = function () { |
||||||
|
$.fn.scrollspy = old |
||||||
|
return this |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// SCROLLSPY DATA-API
|
||||||
|
// ==================
|
||||||
|
|
||||||
|
$(window).on('load', function () { |
||||||
|
$('[data-spy="scroll"]').each(function () { |
||||||
|
var $spy = $(this) |
||||||
|
$spy.scrollspy($spy.data()) |
||||||
|
}) |
||||||
|
}) |
||||||
|
|
||||||
|
}(jQuery); |
@ -0,0 +1,125 @@ |
|||||||
|
/* ======================================================================== |
||||||
|
* Bootstrap: tab.js v3.1.1 |
||||||
|
* http://getbootstrap.com/javascript/#tabs
|
||||||
|
* ======================================================================== |
||||||
|
* Copyright 2011-2014 Twitter, Inc. |
||||||
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
|
* ======================================================================== */ |
||||||
|
|
||||||
|
|
||||||
|
+function ($) { |
||||||
|
'use strict'; |
||||||
|
|
||||||
|
// TAB CLASS DEFINITION
|
||||||
|
// ====================
|
||||||
|
|
||||||
|
var Tab = function (element) { |
||||||
|
this.element = $(element) |
||||||
|
} |
||||||
|
|
||||||
|
Tab.prototype.show = function () { |
||||||
|
var $this = this.element |
||||||
|
var $ul = $this.closest('ul:not(.dropdown-menu)') |
||||||
|
var selector = $this.data('target') |
||||||
|
|
||||||
|
if (!selector) { |
||||||
|
selector = $this.attr('href') |
||||||
|
selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
|
||||||
|
} |
||||||
|
|
||||||
|
if ($this.parent('li').hasClass('active')) return |
||||||
|
|
||||||
|
var previous = $ul.find('.active:last a')[0] |
||||||
|
var e = $.Event('show.bs.tab', { |
||||||
|
relatedTarget: previous |
||||||
|
}) |
||||||
|
|
||||||
|
$this.trigger(e) |
||||||
|
|
||||||
|
if (e.isDefaultPrevented()) return |
||||||
|
|
||||||
|
var $target = $(selector) |
||||||
|
|
||||||
|
this.activate($this.parent('li'), $ul) |
||||||
|
this.activate($target, $target.parent(), function () { |
||||||
|
$this.trigger({ |
||||||
|
type: 'shown.bs.tab', |
||||||
|
relatedTarget: previous |
||||||
|
}) |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
Tab.prototype.activate = function (element, container, callback) { |
||||||
|
var $active = container.find('> .active') |
||||||
|
var transition = callback |
||||||
|
&& $.support.transition |
||||||
|
&& $active.hasClass('fade') |
||||||
|
|
||||||
|
function next() { |
||||||
|
$active |
||||||
|
.removeClass('active') |
||||||
|
.find('> .dropdown-menu > .active') |
||||||
|
.removeClass('active') |
||||||
|
|
||||||
|
element.addClass('active') |
||||||
|
|
||||||
|
if (transition) { |
||||||
|
element[0].offsetWidth // reflow for transition
|
||||||
|
element.addClass('in') |
||||||
|
} else { |
||||||
|
element.removeClass('fade') |
||||||
|
} |
||||||
|
|
||||||
|
if (element.parent('.dropdown-menu')) { |
||||||
|
element.closest('li.dropdown').addClass('active') |
||||||
|
} |
||||||
|
|
||||||
|
callback && callback() |
||||||
|
} |
||||||
|
|
||||||
|
transition ? |
||||||
|
$active |
||||||
|
.one($.support.transition.end, next) |
||||||
|
.emulateTransitionEnd(150) : |
||||||
|
next() |
||||||
|
|
||||||
|
$active.removeClass('in') |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// TAB PLUGIN DEFINITION
|
||||||
|
// =====================
|
||||||
|
|
||||||
|
var old = $.fn.tab |
||||||
|
|
||||||
|
$.fn.tab = function ( option ) { |
||||||
|
return this.each(function () { |
||||||
|
var $this = $(this) |
||||||
|
var data = $this.data('bs.tab') |
||||||
|
|
||||||
|
if (!data) $this.data('bs.tab', (data = new Tab(this))) |
||||||
|
if (typeof option == 'string') data[option]() |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
$.fn.tab.Constructor = Tab |
||||||
|
|
||||||
|
|
||||||
|
// TAB NO CONFLICT
|
||||||
|
// ===============
|
||||||
|
|
||||||
|
$.fn.tab.noConflict = function () { |
||||||
|
$.fn.tab = old |
||||||
|
return this |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// TAB DATA-API
|
||||||
|
// ============
|
||||||
|
|
||||||
|
$(document).on('click.bs.tab.data-api', '[data-toggle="tab"], [data-toggle="pill"]', function (e) { |
||||||
|
e.preventDefault() |
||||||
|
$(this).tab('show') |
||||||
|
}) |
||||||
|
|
||||||
|
}(jQuery); |
@ -0,0 +1,399 @@ |
|||||||
|
/* ======================================================================== |
||||||
|
* Bootstrap: tooltip.js v3.1.1 |
||||||
|
* http://getbootstrap.com/javascript/#tooltip
|
||||||
|
* Inspired by the original jQuery.tipsy by Jason Frame |
||||||
|
* ======================================================================== |
||||||
|
* Copyright 2011-2014 Twitter, Inc. |
||||||
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
|
* ======================================================================== */ |
||||||
|
|
||||||
|
|
||||||
|
+function ($) { |
||||||
|
'use strict'; |
||||||
|
|
||||||
|
// TOOLTIP PUBLIC CLASS DEFINITION
|
||||||
|
// ===============================
|
||||||
|
|
||||||
|
var Tooltip = function (element, options) { |
||||||
|
this.type = |
||||||
|
this.options = |
||||||
|
this.enabled = |
||||||
|
this.timeout = |
||||||
|
this.hoverState = |
||||||
|
this.$element = null |
||||||
|
|
||||||
|
this.init('tooltip', element, options) |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.DEFAULTS = { |
||||||
|
animation: true, |
||||||
|
placement: 'top', |
||||||
|
selector: false, |
||||||
|
template: '<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>', |
||||||
|
trigger: 'hover focus', |
||||||
|
title: '', |
||||||
|
delay: 0, |
||||||
|
html: false, |
||||||
|
container: false |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.init = function (type, element, options) { |
||||||
|
this.enabled = true |
||||||
|
this.type = type |
||||||
|
this.$element = $(element) |
||||||
|
this.options = this.getOptions(options) |
||||||
|
|
||||||
|
var triggers = this.options.trigger.split(' ') |
||||||
|
|
||||||
|
for (var i = triggers.length; i--;) { |
||||||
|
var trigger = triggers[i] |
||||||
|
|
||||||
|
if (trigger == 'click') { |
||||||
|
this.$element.on('click.' + this.type, this.options.selector, $.proxy(this.toggle, this)) |
||||||
|
} else if (trigger != 'manual') { |
||||||
|
var eventIn = trigger == 'hover' ? 'mouseenter' : 'focusin' |
||||||
|
var eventOut = trigger == 'hover' ? 'mouseleave' : 'focusout' |
||||||
|
|
||||||
|
this.$element.on(eventIn + '.' + this.type, this.options.selector, $.proxy(this.enter, this)) |
||||||
|
this.$element.on(eventOut + '.' + this.type, this.options.selector, $.proxy(this.leave, this)) |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
this.options.selector ? |
||||||
|
(this._options = $.extend({}, this.options, { trigger: 'manual', selector: '' })) : |
||||||
|
this.fixTitle() |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.getDefaults = function () { |
||||||
|
return Tooltip.DEFAULTS |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.getOptions = function (options) { |
||||||
|
options = $.extend({}, this.getDefaults(), this.$element.data(), options) |
||||||
|
|
||||||
|
if (options.delay && typeof options.delay == 'number') { |
||||||
|
options.delay = { |
||||||
|
show: options.delay, |
||||||
|
hide: options.delay |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
return options |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.getDelegateOptions = function () { |
||||||
|
var options = {} |
||||||
|
var defaults = this.getDefaults() |
||||||
|
|
||||||
|
this._options && $.each(this._options, function (key, value) { |
||||||
|
if (defaults[key] != value) options[key] = value |
||||||
|
}) |
||||||
|
|
||||||
|
return options |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.enter = function (obj) { |
||||||
|
var self = obj instanceof this.constructor ? |
||||||
|
obj : $(obj.currentTarget)[this.type](this.getDelegateOptions()).data('bs.' + this.type) |
||||||
|
|
||||||
|
clearTimeout(self.timeout) |
||||||
|
|
||||||
|
self.hoverState = 'in' |
||||||
|
|
||||||
|
if (!self.options.delay || !self.options.delay.show) return self.show() |
||||||
|
|
||||||
|
self.timeout = setTimeout(function () { |
||||||
|
if (self.hoverState == 'in') self.show() |
||||||
|
}, self.options.delay.show) |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.leave = function (obj) { |
||||||
|
var self = obj instanceof this.constructor ? |
||||||
|
obj : $(obj.currentTarget)[this.type](this.getDelegateOptions()).data('bs.' + this.type) |
||||||
|
|
||||||
|
clearTimeout(self.timeout) |
||||||
|
|
||||||
|
self.hoverState = 'out' |
||||||
|
|
||||||
|
if (!self.options.delay || !self.options.delay.hide) return self.hide() |
||||||
|
|
||||||
|
self.timeout = setTimeout(function () { |
||||||
|
if (self.hoverState == 'out') self.hide() |
||||||
|
}, self.options.delay.hide) |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.show = function () { |
||||||
|
var e = $.Event('show.bs.' + this.type) |
||||||
|
|
||||||
|
if (this.hasContent() && this.enabled) { |
||||||
|
this.$element.trigger(e) |
||||||
|
|
||||||
|
if (e.isDefaultPrevented()) return |
||||||
|
var that = this; |
||||||
|
|
||||||
|
var $tip = this.tip() |
||||||
|
|
||||||
|
this.setContent() |
||||||
|
|
||||||
|
if (this.options.animation) $tip.addClass('fade') |
||||||
|
|
||||||
|
var placement = typeof this.options.placement == 'function' ? |
||||||
|
this.options.placement.call(this, $tip[0], this.$element[0]) : |
||||||
|
this.options.placement |
||||||
|
|
||||||
|
var autoToken = /\s?auto?\s?/i |
||||||
|
var autoPlace = autoToken.test(placement) |
||||||
|
if (autoPlace) placement = placement.replace(autoToken, '') || 'top' |
||||||
|
|
||||||
|
$tip |
||||||
|
.detach() |
||||||
|
.css({ top: 0, left: 0, display: 'block' }) |
||||||
|
.addClass(placement) |
||||||
|
|
||||||
|
this.options.container ? $tip.appendTo(this.options.container) : $tip.insertAfter(this.$element) |
||||||
|
|
||||||
|
var pos = this.getPosition() |
||||||
|
var actualWidth = $tip[0].offsetWidth |
||||||
|
var actualHeight = $tip[0].offsetHeight |
||||||
|
|
||||||
|
if (autoPlace) { |
||||||
|
var $parent = this.$element.parent() |
||||||
|
|
||||||
|
var orgPlacement = placement |
||||||
|
var docScroll = document.documentElement.scrollTop || document.body.scrollTop |
||||||
|
var parentWidth = this.options.container == 'body' ? window.innerWidth : $parent.outerWidth() |
||||||
|
var parentHeight = this.options.container == 'body' ? window.innerHeight : $parent.outerHeight() |
||||||
|
var parentLeft = this.options.container == 'body' ? 0 : $parent.offset().left |
||||||
|
|
||||||
|
placement = placement == 'bottom' && pos.top + pos.height + actualHeight - docScroll > parentHeight ? 'top' : |
||||||
|
placement == 'top' && pos.top - docScroll - actualHeight < 0 ? 'bottom' : |
||||||
|
placement == 'right' && pos.right + actualWidth > parentWidth ? 'left' : |
||||||
|
placement == 'left' && pos.left - actualWidth < parentLeft ? 'right' : |
||||||
|
placement |
||||||
|
|
||||||
|
$tip |
||||||
|
.removeClass(orgPlacement) |
||||||
|
.addClass(placement) |
||||||
|
} |
||||||
|
|
||||||
|
var calculatedOffset = this.getCalculatedOffset(placement, pos, actualWidth, actualHeight) |
||||||
|
|
||||||
|
this.applyPlacement(calculatedOffset, placement) |
||||||
|
this.hoverState = null |
||||||
|
|
||||||
|
var complete = function() { |
||||||
|
that.$element.trigger('shown.bs.' + that.type) |
||||||
|
} |
||||||
|
|
||||||
|
$.support.transition && this.$tip.hasClass('fade') ? |
||||||
|
$tip |
||||||
|
.one($.support.transition.end, complete) |
||||||
|
.emulateTransitionEnd(150) : |
||||||
|
complete() |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.applyPlacement = function (offset, placement) { |
||||||
|
var replace |
||||||
|
var $tip = this.tip() |
||||||
|
var width = $tip[0].offsetWidth |
||||||
|
var height = $tip[0].offsetHeight |
||||||
|
|
||||||
|
// manually read margins because getBoundingClientRect includes difference
|
||||||
|
var marginTop = parseInt($tip.css('margin-top'), 10) |
||||||
|
var marginLeft = parseInt($tip.css('margin-left'), 10) |
||||||
|
|
||||||
|
// we must check for NaN for ie 8/9
|
||||||
|
if (isNaN(marginTop)) marginTop = 0 |
||||||
|
if (isNaN(marginLeft)) marginLeft = 0 |
||||||
|
|
||||||
|
offset.top = offset.top + marginTop |
||||||
|
offset.left = offset.left + marginLeft |
||||||
|
|
||||||
|
// $.fn.offset doesn't round pixel values
|
||||||
|
// so we use setOffset directly with our own function B-0
|
||||||
|
$.offset.setOffset($tip[0], $.extend({ |
||||||
|
using: function (props) { |
||||||
|
$tip.css({ |
||||||
|
top: Math.round(props.top), |
||||||
|
left: Math.round(props.left) |
||||||
|
}) |
||||||
|
} |
||||||
|
}, offset), 0) |
||||||
|
|
||||||
|
$tip.addClass('in') |
||||||
|
|
||||||
|
// check to see if placing tip in new offset caused the tip to resize itself
|
||||||
|
var actualWidth = $tip[0].offsetWidth |
||||||
|
var actualHeight = $tip[0].offsetHeight |
||||||
|
|
||||||
|
if (placement == 'top' && actualHeight != height) { |
||||||
|
replace = true |
||||||
|
offset.top = offset.top + height - actualHeight |
||||||
|
} |
||||||
|
|
||||||
|
if (/bottom|top/.test(placement)) { |
||||||
|
var delta = 0 |
||||||
|
|
||||||
|
if (offset.left < 0) { |
||||||
|
delta = offset.left * -2 |
||||||
|
offset.left = 0 |
||||||
|
|
||||||
|
$tip.offset(offset) |
||||||
|
|
||||||
|
actualWidth = $tip[0].offsetWidth |
||||||
|
actualHeight = $tip[0].offsetHeight |
||||||
|
} |
||||||
|
|
||||||
|
this.replaceArrow(delta - width + actualWidth, actualWidth, 'left') |
||||||
|
} else { |
||||||
|
this.replaceArrow(actualHeight - height, actualHeight, 'top') |
||||||
|
} |
||||||
|
|
||||||
|
if (replace) $tip.offset(offset) |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.replaceArrow = function (delta, dimension, position) { |
||||||
|
this.arrow().css(position, delta ? (50 * (1 - delta / dimension) + '%') : '') |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.setContent = function () { |
||||||
|
var $tip = this.tip() |
||||||
|
var title = this.getTitle() |
||||||
|
|
||||||
|
$tip.find('.tooltip-inner')[this.options.html ? 'html' : 'text'](title) |
||||||
|
$tip.removeClass('fade in top bottom left right') |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.hide = function () { |
||||||
|
var that = this |
||||||
|
var $tip = this.tip() |
||||||
|
var e = $.Event('hide.bs.' + this.type) |
||||||
|
|
||||||
|
function complete() { |
||||||
|
if (that.hoverState != 'in') $tip.detach() |
||||||
|
that.$element.trigger('hidden.bs.' + that.type) |
||||||
|
} |
||||||
|
|
||||||
|
this.$element.trigger(e) |
||||||
|
|
||||||
|
if (e.isDefaultPrevented()) return |
||||||
|
|
||||||
|
$tip.removeClass('in') |
||||||
|
|
||||||
|
$.support.transition && this.$tip.hasClass('fade') ? |
||||||
|
$tip |
||||||
|
.one($.support.transition.end, complete) |
||||||
|
.emulateTransitionEnd(150) : |
||||||
|
complete() |
||||||
|
|
||||||
|
this.hoverState = null |
||||||
|
|
||||||
|
return this |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.fixTitle = function () { |
||||||
|
var $e = this.$element |
||||||
|
if ($e.attr('title') || typeof($e.attr('data-original-title')) != 'string') { |
||||||
|
$e.attr('data-original-title', $e.attr('title') || '').attr('title', '') |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.hasContent = function () { |
||||||
|
return this.getTitle() |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.getPosition = function () { |
||||||
|
var el = this.$element[0] |
||||||
|
return $.extend({}, (typeof el.getBoundingClientRect == 'function') ? el.getBoundingClientRect() : { |
||||||
|
width: el.offsetWidth, |
||||||
|
height: el.offsetHeight |
||||||
|
}, this.$element.offset()) |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.getCalculatedOffset = function (placement, pos, actualWidth, actualHeight) { |
||||||
|
return placement == 'bottom' ? { top: pos.top + pos.height, left: pos.left + pos.width / 2 - actualWidth / 2 } : |
||||||
|
placement == 'top' ? { top: pos.top - actualHeight, left: pos.left + pos.width / 2 - actualWidth / 2 } : |
||||||
|
placement == 'left' ? { top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left - actualWidth } : |
||||||
|
/* placement == 'right' */ { top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left + pos.width } |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.getTitle = function () { |
||||||
|
var title |
||||||
|
var $e = this.$element |
||||||
|
var o = this.options |
||||||
|
|
||||||
|
title = $e.attr('data-original-title') |
||||||
|
|| (typeof o.title == 'function' ? o.title.call($e[0]) : o.title) |
||||||
|
|
||||||
|
return title |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.tip = function () { |
||||||
|
return this.$tip = this.$tip || $(this.options.template) |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.arrow = function () { |
||||||
|
return this.$arrow = this.$arrow || this.tip().find('.tooltip-arrow') |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.validate = function () { |
||||||
|
if (!this.$element[0].parentNode) { |
||||||
|
this.hide() |
||||||
|
this.$element = null |
||||||
|
this.options = null |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.enable = function () { |
||||||
|
this.enabled = true |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.disable = function () { |
||||||
|
this.enabled = false |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.toggleEnabled = function () { |
||||||
|
this.enabled = !this.enabled |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.toggle = function (e) { |
||||||
|
var self = e ? $(e.currentTarget)[this.type](this.getDelegateOptions()).data('bs.' + this.type) : this |
||||||
|
self.tip().hasClass('in') ? self.leave(self) : self.enter(self) |
||||||
|
} |
||||||
|
|
||||||
|
Tooltip.prototype.destroy = function () { |
||||||
|
clearTimeout(this.timeout) |
||||||
|
this.hide().$element.off('.' + this.type).removeData('bs.' + this.type) |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// TOOLTIP PLUGIN DEFINITION
|
||||||
|
// =========================
|
||||||
|
|
||||||
|
var old = $.fn.tooltip |
||||||
|
|
||||||
|
$.fn.tooltip = function (option) { |
||||||
|
return this.each(function () { |
||||||
|
var $this = $(this) |
||||||
|
var data = $this.data('bs.tooltip') |
||||||
|
var options = typeof option == 'object' && option |
||||||
|
|
||||||
|
if (!data && option == 'destroy') return |
||||||
|
if (!data) $this.data('bs.tooltip', (data = new Tooltip(this, options))) |
||||||
|
if (typeof option == 'string') data[option]() |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
$.fn.tooltip.Constructor = Tooltip |
||||||
|
|
||||||
|
|
||||||
|
// TOOLTIP NO CONFLICT
|
||||||
|
// ===================
|
||||||
|
|
||||||
|
$.fn.tooltip.noConflict = function () { |
||||||
|
$.fn.tooltip = old |
||||||
|
return this |
||||||
|
} |
||||||
|
|
||||||
|
}(jQuery); |
@ -0,0 +1,48 @@ |
|||||||
|
/* ======================================================================== |
||||||
|
* Bootstrap: transition.js v3.1.1 |
||||||
|
* http://getbootstrap.com/javascript/#transitions
|
||||||
|
* ======================================================================== |
||||||
|
* Copyright 2011-2014 Twitter, Inc. |
||||||
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
|
* ======================================================================== */ |
||||||
|
|
||||||
|
|
||||||
|
+function ($) { |
||||||
|
'use strict'; |
||||||
|
|
||||||
|
// CSS TRANSITION SUPPORT (Shoutout: http://www.modernizr.com/)
|
||||||
|
// ============================================================
|
||||||
|
|
||||||
|
function transitionEnd() { |
||||||
|
var el = document.createElement('bootstrap') |
||||||
|
|
||||||
|
var transEndEventNames = { |
||||||
|
'WebkitTransition' : 'webkitTransitionEnd', |
||||||
|
'MozTransition' : 'transitionend', |
||||||
|
'OTransition' : 'oTransitionEnd otransitionend', |
||||||
|
'transition' : 'transitionend' |
||||||
|
} |
||||||
|
|
||||||
|
for (var name in transEndEventNames) { |
||||||
|
if (el.style[name] !== undefined) { |
||||||
|
return { end: transEndEventNames[name] } |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
return false // explicit for ie8 ( ._.)
|
||||||
|
} |
||||||
|
|
||||||
|
// http://blog.alexmaccaw.com/css-transitions
|
||||||
|
$.fn.emulateTransitionEnd = function (duration) { |
||||||
|
var called = false, $el = this |
||||||
|
$(this).one($.support.transition.end, function () { called = true }) |
||||||
|
var callback = function () { if (!called) $($el).trigger($.support.transition.end) } |
||||||
|
setTimeout(callback, duration) |
||||||
|
return this |
||||||
|
} |
||||||
|
|
||||||
|
$(function () { |
||||||
|
$.support.transition = transitionEnd() |
||||||
|
}) |
||||||
|
|
||||||
|
}(jQuery); |
@ -0,0 +1,67 @@ |
|||||||
|
// |
||||||
|
// Alerts |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// Base styles |
||||||
|
// ------------------------- |
||||||
|
|
||||||
|
.alert { |
||||||
|
padding: @alert-padding; |
||||||
|
margin-bottom: @line-height-computed; |
||||||
|
border: 1px solid transparent; |
||||||
|
border-radius: @alert-border-radius; |
||||||
|
|
||||||
|
// Headings for larger alerts |
||||||
|
h4 { |
||||||
|
margin-top: 0; |
||||||
|
// Specified for the h4 to prevent conflicts of changing @headings-color |
||||||
|
color: inherit; |
||||||
|
} |
||||||
|
// Provide class for links that match alerts |
||||||
|
.alert-link { |
||||||
|
font-weight: @alert-link-font-weight; |
||||||
|
} |
||||||
|
|
||||||
|
// Improve alignment and spacing of inner content |
||||||
|
> p, |
||||||
|
> ul { |
||||||
|
margin-bottom: 0; |
||||||
|
} |
||||||
|
> p + p { |
||||||
|
margin-top: 5px; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Dismissable alerts |
||||||
|
// |
||||||
|
// Expand the right padding and account for the close button's positioning. |
||||||
|
|
||||||
|
.alert-dismissable { |
||||||
|
padding-right: (@alert-padding + 20); |
||||||
|
|
||||||
|
// Adjust close link position |
||||||
|
.close { |
||||||
|
position: relative; |
||||||
|
top: -2px; |
||||||
|
right: -21px; |
||||||
|
color: inherit; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Alternate styles |
||||||
|
// |
||||||
|
// Generate contextual modifier classes for colorizing the alert. |
||||||
|
|
||||||
|
.alert-success { |
||||||
|
.alert-variant(@alert-success-bg; @alert-success-border; @alert-success-text); |
||||||
|
} |
||||||
|
.alert-info { |
||||||
|
.alert-variant(@alert-info-bg; @alert-info-border; @alert-info-text); |
||||||
|
} |
||||||
|
.alert-warning { |
||||||
|
.alert-variant(@alert-warning-bg; @alert-warning-border; @alert-warning-text); |
||||||
|
} |
||||||
|
.alert-danger { |
||||||
|
.alert-variant(@alert-danger-bg; @alert-danger-border; @alert-danger-text); |
||||||
|
} |
@ -0,0 +1,55 @@ |
|||||||
|
// |
||||||
|
// Badges |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// Base classes |
||||||
|
.badge { |
||||||
|
display: inline-block; |
||||||
|
min-width: 10px; |
||||||
|
padding: 3px 7px; |
||||||
|
font-size: @font-size-small; |
||||||
|
font-weight: @badge-font-weight; |
||||||
|
color: @badge-color; |
||||||
|
line-height: @badge-line-height; |
||||||
|
vertical-align: baseline; |
||||||
|
white-space: nowrap; |
||||||
|
text-align: center; |
||||||
|
background-color: @badge-bg; |
||||||
|
border-radius: @badge-border-radius; |
||||||
|
|
||||||
|
// Empty badges collapse automatically (not available in IE8) |
||||||
|
&:empty { |
||||||
|
display: none; |
||||||
|
} |
||||||
|
|
||||||
|
// Quick fix for badges in buttons |
||||||
|
.btn & { |
||||||
|
position: relative; |
||||||
|
top: -1px; |
||||||
|
} |
||||||
|
.btn-xs & { |
||||||
|
top: 0; |
||||||
|
padding: 1px 5px; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Hover state, but only for links |
||||||
|
a.badge { |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @badge-link-hover-color; |
||||||
|
text-decoration: none; |
||||||
|
cursor: pointer; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Account for counters in navs |
||||||
|
a.list-group-item.active > .badge, |
||||||
|
.nav-pills > .active > a > .badge { |
||||||
|
color: @badge-active-color; |
||||||
|
background-color: @badge-active-bg; |
||||||
|
} |
||||||
|
.nav-pills > li > a > .badge { |
||||||
|
margin-left: 3px; |
||||||
|
} |
@ -0,0 +1,49 @@ |
|||||||
|
// Core variables and mixins |
||||||
|
@import "variables.less"; |
||||||
|
@import "mixins.less"; |
||||||
|
|
||||||
|
// Reset |
||||||
|
@import "normalize.less"; |
||||||
|
@import "print.less"; |
||||||
|
|
||||||
|
// Core CSS |
||||||
|
@import "scaffolding.less"; |
||||||
|
@import "type.less"; |
||||||
|
@import "code.less"; |
||||||
|
@import "grid.less"; |
||||||
|
@import "tables.less"; |
||||||
|
@import "forms.less"; |
||||||
|
@import "buttons.less"; |
||||||
|
|
||||||
|
// Components |
||||||
|
@import "component-animations.less"; |
||||||
|
@import "glyphicons.less"; |
||||||
|
@import "dropdowns.less"; |
||||||
|
@import "button-groups.less"; |
||||||
|
@import "input-groups.less"; |
||||||
|
@import "navs.less"; |
||||||
|
@import "navbar.less"; |
||||||
|
@import "breadcrumbs.less"; |
||||||
|
@import "pagination.less"; |
||||||
|
@import "pager.less"; |
||||||
|
@import "labels.less"; |
||||||
|
@import "badges.less"; |
||||||
|
@import "jumbotron.less"; |
||||||
|
@import "thumbnails.less"; |
||||||
|
@import "alerts.less"; |
||||||
|
@import "progress-bars.less"; |
||||||
|
@import "media.less"; |
||||||
|
@import "list-group.less"; |
||||||
|
@import "panels.less"; |
||||||
|
@import "wells.less"; |
||||||
|
@import "close.less"; |
||||||
|
|
||||||
|
// Components w/ JavaScript |
||||||
|
@import "modals.less"; |
||||||
|
@import "tooltip.less"; |
||||||
|
@import "popovers.less"; |
||||||
|
@import "carousel.less"; |
||||||
|
|
||||||
|
// Utility classes |
||||||
|
@import "utilities.less"; |
||||||
|
@import "responsive-utilities.less"; |
@ -0,0 +1,26 @@ |
|||||||
|
// |
||||||
|
// Breadcrumbs |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
.breadcrumb { |
||||||
|
padding: @breadcrumb-padding-vertical @breadcrumb-padding-horizontal; |
||||||
|
margin-bottom: @line-height-computed; |
||||||
|
list-style: none; |
||||||
|
background-color: @breadcrumb-bg; |
||||||
|
border-radius: @border-radius-base; |
||||||
|
|
||||||
|
> li { |
||||||
|
display: inline-block; |
||||||
|
|
||||||
|
+ li:before { |
||||||
|
content: "@{breadcrumb-separator}\00a0"; // Unicode space added since inline-block means non-collapsing white-space |
||||||
|
padding: 0 5px; |
||||||
|
color: @breadcrumb-color; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
> .active { |
||||||
|
color: @breadcrumb-active-color; |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,226 @@ |
|||||||
|
// |
||||||
|
// Button groups |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
// Make the div behave like a button |
||||||
|
.btn-group, |
||||||
|
.btn-group-vertical { |
||||||
|
position: relative; |
||||||
|
display: inline-block; |
||||||
|
vertical-align: middle; // match .btn alignment given font-size hack above |
||||||
|
> .btn { |
||||||
|
position: relative; |
||||||
|
float: left; |
||||||
|
// Bring the "active" button to the front |
||||||
|
&:hover, |
||||||
|
&:focus, |
||||||
|
&:active, |
||||||
|
&.active { |
||||||
|
z-index: 2; |
||||||
|
} |
||||||
|
&:focus { |
||||||
|
// Remove focus outline when dropdown JS adds it after closing the menu |
||||||
|
outline: none; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Prevent double borders when buttons are next to each other |
||||||
|
.btn-group { |
||||||
|
.btn + .btn, |
||||||
|
.btn + .btn-group, |
||||||
|
.btn-group + .btn, |
||||||
|
.btn-group + .btn-group { |
||||||
|
margin-left: -1px; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Optional: Group multiple button groups together for a toolbar |
||||||
|
.btn-toolbar { |
||||||
|
margin-left: -5px; // Offset the first child's margin |
||||||
|
&:extend(.clearfix all); |
||||||
|
|
||||||
|
.btn-group, |
||||||
|
.input-group { |
||||||
|
float: left; |
||||||
|
} |
||||||
|
> .btn, |
||||||
|
> .btn-group, |
||||||
|
> .input-group { |
||||||
|
margin-left: 5px; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
.btn-group > .btn:not(:first-child):not(:last-child):not(.dropdown-toggle) { |
||||||
|
border-radius: 0; |
||||||
|
} |
||||||
|
|
||||||
|
// Set corners individual because sometimes a single button can be in a .btn-group and we need :first-child and :last-child to both match |
||||||
|
.btn-group > .btn:first-child { |
||||||
|
margin-left: 0; |
||||||
|
&:not(:last-child):not(.dropdown-toggle) { |
||||||
|
.border-right-radius(0); |
||||||
|
} |
||||||
|
} |
||||||
|
// Need .dropdown-toggle since :last-child doesn't apply given a .dropdown-menu immediately after it |
||||||
|
.btn-group > .btn:last-child:not(:first-child), |
||||||
|
.btn-group > .dropdown-toggle:not(:first-child) { |
||||||
|
.border-left-radius(0); |
||||||
|
} |
||||||
|
|
||||||
|
// Custom edits for including btn-groups within btn-groups (useful for including dropdown buttons within a btn-group) |
||||||
|
.btn-group > .btn-group { |
||||||
|
float: left; |
||||||
|
} |
||||||
|
.btn-group > .btn-group:not(:first-child):not(:last-child) > .btn { |
||||||
|
border-radius: 0; |
||||||
|
} |
||||||
|
.btn-group > .btn-group:first-child { |
||||||
|
> .btn:last-child, |
||||||
|
> .dropdown-toggle { |
||||||
|
.border-right-radius(0); |
||||||
|
} |
||||||
|
} |
||||||
|
.btn-group > .btn-group:last-child > .btn:first-child { |
||||||
|
.border-left-radius(0); |
||||||
|
} |
||||||
|
|
||||||
|
// On active and open, don't show outline |
||||||
|
.btn-group .dropdown-toggle:active, |
||||||
|
.btn-group.open .dropdown-toggle { |
||||||
|
outline: 0; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Sizing |
||||||
|
// |
||||||
|
// Remix the default button sizing classes into new ones for easier manipulation. |
||||||
|
|
||||||
|
.btn-group-xs > .btn { &:extend(.btn-xs); } |
||||||
|
.btn-group-sm > .btn { &:extend(.btn-sm); } |
||||||
|
.btn-group-lg > .btn { &:extend(.btn-lg); } |
||||||
|
|
||||||
|
|
||||||
|
// Split button dropdowns |
||||||
|
// ---------------------- |
||||||
|
|
||||||
|
// Give the line between buttons some depth |
||||||
|
.btn-group > .btn + .dropdown-toggle { |
||||||
|
padding-left: 8px; |
||||||
|
padding-right: 8px; |
||||||
|
} |
||||||
|
.btn-group > .btn-lg + .dropdown-toggle { |
||||||
|
padding-left: 12px; |
||||||
|
padding-right: 12px; |
||||||
|
} |
||||||
|
|
||||||
|
// The clickable button for toggling the menu |
||||||
|
// Remove the gradient and set the same inset shadow as the :active state |
||||||
|
.btn-group.open .dropdown-toggle { |
||||||
|
.box-shadow(inset 0 3px 5px rgba(0,0,0,.125)); |
||||||
|
|
||||||
|
// Show no shadow for `.btn-link` since it has no other button styles. |
||||||
|
&.btn-link { |
||||||
|
.box-shadow(none); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Reposition the caret |
||||||
|
.btn .caret { |
||||||
|
margin-left: 0; |
||||||
|
} |
||||||
|
// Carets in other button sizes |
||||||
|
.btn-lg .caret { |
||||||
|
border-width: @caret-width-large @caret-width-large 0; |
||||||
|
border-bottom-width: 0; |
||||||
|
} |
||||||
|
// Upside down carets for .dropup |
||||||
|
.dropup .btn-lg .caret { |
||||||
|
border-width: 0 @caret-width-large @caret-width-large; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Vertical button groups |
||||||
|
// ---------------------- |
||||||
|
|
||||||
|
.btn-group-vertical { |
||||||
|
> .btn, |
||||||
|
> .btn-group, |
||||||
|
> .btn-group > .btn { |
||||||
|
display: block; |
||||||
|
float: none; |
||||||
|
width: 100%; |
||||||
|
max-width: 100%; |
||||||
|
} |
||||||
|
|
||||||
|
// Clear floats so dropdown menus can be properly placed |
||||||
|
> .btn-group { |
||||||
|
&:extend(.clearfix all); |
||||||
|
> .btn { |
||||||
|
float: none; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
> .btn + .btn, |
||||||
|
> .btn + .btn-group, |
||||||
|
> .btn-group + .btn, |
||||||
|
> .btn-group + .btn-group { |
||||||
|
margin-top: -1px; |
||||||
|
margin-left: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
.btn-group-vertical > .btn { |
||||||
|
&:not(:first-child):not(:last-child) { |
||||||
|
border-radius: 0; |
||||||
|
} |
||||||
|
&:first-child:not(:last-child) { |
||||||
|
border-top-right-radius: @border-radius-base; |
||||||
|
.border-bottom-radius(0); |
||||||
|
} |
||||||
|
&:last-child:not(:first-child) { |
||||||
|
border-bottom-left-radius: @border-radius-base; |
||||||
|
.border-top-radius(0); |
||||||
|
} |
||||||
|
} |
||||||
|
.btn-group-vertical > .btn-group:not(:first-child):not(:last-child) > .btn { |
||||||
|
border-radius: 0; |
||||||
|
} |
||||||
|
.btn-group-vertical > .btn-group:first-child:not(:last-child) { |
||||||
|
> .btn:last-child, |
||||||
|
> .dropdown-toggle { |
||||||
|
.border-bottom-radius(0); |
||||||
|
} |
||||||
|
} |
||||||
|
.btn-group-vertical > .btn-group:last-child:not(:first-child) > .btn:first-child { |
||||||
|
.border-top-radius(0); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// Justified button groups |
||||||
|
// ---------------------- |
||||||
|
|
||||||
|
.btn-group-justified { |
||||||
|
display: table; |
||||||
|
width: 100%; |
||||||
|
table-layout: fixed; |
||||||
|
border-collapse: separate; |
||||||
|
> .btn, |
||||||
|
> .btn-group { |
||||||
|
float: none; |
||||||
|
display: table-cell; |
||||||
|
width: 1%; |
||||||
|
} |
||||||
|
> .btn-group .btn { |
||||||
|
width: 100%; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Checkbox and radio options |
||||||
|
[data-toggle="buttons"] > .btn > input[type="radio"], |
||||||
|
[data-toggle="buttons"] > .btn > input[type="checkbox"] { |
||||||
|
display: none; |
||||||
|
} |
@ -0,0 +1,159 @@ |
|||||||
|
// |
||||||
|
// Buttons |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// Base styles |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
.btn { |
||||||
|
display: inline-block; |
||||||
|
margin-bottom: 0; // For input.btn |
||||||
|
font-weight: @btn-font-weight; |
||||||
|
text-align: center; |
||||||
|
vertical-align: middle; |
||||||
|
cursor: pointer; |
||||||
|
background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214 |
||||||
|
border: 1px solid transparent; |
||||||
|
white-space: nowrap; |
||||||
|
.button-size(@padding-base-vertical; @padding-base-horizontal; @font-size-base; @line-height-base; @border-radius-base); |
||||||
|
.user-select(none); |
||||||
|
|
||||||
|
&, |
||||||
|
&:active, |
||||||
|
&.active { |
||||||
|
&:focus { |
||||||
|
.tab-focus(); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @btn-default-color; |
||||||
|
text-decoration: none; |
||||||
|
} |
||||||
|
|
||||||
|
&:active, |
||||||
|
&.active { |
||||||
|
outline: 0; |
||||||
|
background-image: none; |
||||||
|
.box-shadow(inset 0 3px 5px rgba(0,0,0,.125)); |
||||||
|
} |
||||||
|
|
||||||
|
&.disabled, |
||||||
|
&[disabled], |
||||||
|
fieldset[disabled] & { |
||||||
|
cursor: not-allowed; |
||||||
|
pointer-events: none; // Future-proof disabling of clicks |
||||||
|
.opacity(.65); |
||||||
|
.box-shadow(none); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Alternate buttons |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
.btn-default { |
||||||
|
.button-variant(@btn-default-color; @btn-default-bg; @btn-default-border); |
||||||
|
} |
||||||
|
.btn-primary { |
||||||
|
.button-variant(@btn-primary-color; @btn-primary-bg; @btn-primary-border); |
||||||
|
} |
||||||
|
// Success appears as green |
||||||
|
.btn-success { |
||||||
|
.button-variant(@btn-success-color; @btn-success-bg; @btn-success-border); |
||||||
|
} |
||||||
|
// Info appears as blue-green |
||||||
|
.btn-info { |
||||||
|
.button-variant(@btn-info-color; @btn-info-bg; @btn-info-border); |
||||||
|
} |
||||||
|
// Warning appears as orange |
||||||
|
.btn-warning { |
||||||
|
.button-variant(@btn-warning-color; @btn-warning-bg; @btn-warning-border); |
||||||
|
} |
||||||
|
// Danger and error appear as red |
||||||
|
.btn-danger { |
||||||
|
.button-variant(@btn-danger-color; @btn-danger-bg; @btn-danger-border); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Link buttons |
||||||
|
// ------------------------- |
||||||
|
|
||||||
|
// Make a button look and behave like a link |
||||||
|
.btn-link { |
||||||
|
color: @link-color; |
||||||
|
font-weight: normal; |
||||||
|
cursor: pointer; |
||||||
|
border-radius: 0; |
||||||
|
|
||||||
|
&, |
||||||
|
&:active, |
||||||
|
&[disabled], |
||||||
|
fieldset[disabled] & { |
||||||
|
background-color: transparent; |
||||||
|
.box-shadow(none); |
||||||
|
} |
||||||
|
&, |
||||||
|
&:hover, |
||||||
|
&:focus, |
||||||
|
&:active { |
||||||
|
border-color: transparent; |
||||||
|
} |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @link-hover-color; |
||||||
|
text-decoration: underline; |
||||||
|
background-color: transparent; |
||||||
|
} |
||||||
|
&[disabled], |
||||||
|
fieldset[disabled] & { |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @btn-link-disabled-color; |
||||||
|
text-decoration: none; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Button Sizes |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
.btn-lg { |
||||||
|
// line-height: ensure even-numbered height of button next to large input |
||||||
|
.button-size(@padding-large-vertical; @padding-large-horizontal; @font-size-large; @line-height-large; @border-radius-large); |
||||||
|
} |
||||||
|
.btn-sm { |
||||||
|
// line-height: ensure proper height of button next to small input |
||||||
|
.button-size(@padding-small-vertical; @padding-small-horizontal; @font-size-small; @line-height-small; @border-radius-small); |
||||||
|
} |
||||||
|
.btn-xs { |
||||||
|
.button-size(@padding-xs-vertical; @padding-xs-horizontal; @font-size-small; @line-height-small; @border-radius-small); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Block button |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
.btn-block { |
||||||
|
display: block; |
||||||
|
width: 100%; |
||||||
|
padding-left: 0; |
||||||
|
padding-right: 0; |
||||||
|
} |
||||||
|
|
||||||
|
// Vertically space out multiple block buttons |
||||||
|
.btn-block + .btn-block { |
||||||
|
margin-top: 5px; |
||||||
|
} |
||||||
|
|
||||||
|
// Specificity overrides |
||||||
|
input[type="submit"], |
||||||
|
input[type="reset"], |
||||||
|
input[type="button"] { |
||||||
|
&.btn-block { |
||||||
|
width: 100%; |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,232 @@ |
|||||||
|
// |
||||||
|
// Carousel |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// Wrapper for the slide container and indicators |
||||||
|
.carousel { |
||||||
|
position: relative; |
||||||
|
} |
||||||
|
|
||||||
|
.carousel-inner { |
||||||
|
position: relative; |
||||||
|
overflow: hidden; |
||||||
|
width: 100%; |
||||||
|
|
||||||
|
> .item { |
||||||
|
display: none; |
||||||
|
position: relative; |
||||||
|
.transition(.6s ease-in-out left); |
||||||
|
|
||||||
|
// Account for jankitude on images |
||||||
|
> img, |
||||||
|
> a > img { |
||||||
|
&:extend(.img-responsive); |
||||||
|
line-height: 1; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
> .active, |
||||||
|
> .next, |
||||||
|
> .prev { display: block; } |
||||||
|
|
||||||
|
> .active { |
||||||
|
left: 0; |
||||||
|
} |
||||||
|
|
||||||
|
> .next, |
||||||
|
> .prev { |
||||||
|
position: absolute; |
||||||
|
top: 0; |
||||||
|
width: 100%; |
||||||
|
} |
||||||
|
|
||||||
|
> .next { |
||||||
|
left: 100%; |
||||||
|
} |
||||||
|
> .prev { |
||||||
|
left: -100%; |
||||||
|
} |
||||||
|
> .next.left, |
||||||
|
> .prev.right { |
||||||
|
left: 0; |
||||||
|
} |
||||||
|
|
||||||
|
> .active.left { |
||||||
|
left: -100%; |
||||||
|
} |
||||||
|
> .active.right { |
||||||
|
left: 100%; |
||||||
|
} |
||||||
|
|
||||||
|
} |
||||||
|
|
||||||
|
// Left/right controls for nav |
||||||
|
// --------------------------- |
||||||
|
|
||||||
|
.carousel-control { |
||||||
|
position: absolute; |
||||||
|
top: 0; |
||||||
|
left: 0; |
||||||
|
bottom: 0; |
||||||
|
width: @carousel-control-width; |
||||||
|
.opacity(@carousel-control-opacity); |
||||||
|
font-size: @carousel-control-font-size; |
||||||
|
color: @carousel-control-color; |
||||||
|
text-align: center; |
||||||
|
text-shadow: @carousel-text-shadow; |
||||||
|
// We can't have this transition here because WebKit cancels the carousel |
||||||
|
// animation if you trip this while in the middle of another animation. |
||||||
|
|
||||||
|
// Set gradients for backgrounds |
||||||
|
&.left { |
||||||
|
#gradient > .horizontal(@start-color: rgba(0,0,0,.5); @end-color: rgba(0,0,0,.0001)); |
||||||
|
} |
||||||
|
&.right { |
||||||
|
left: auto; |
||||||
|
right: 0; |
||||||
|
#gradient > .horizontal(@start-color: rgba(0,0,0,.0001); @end-color: rgba(0,0,0,.5)); |
||||||
|
} |
||||||
|
|
||||||
|
// Hover/focus state |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
outline: none; |
||||||
|
color: @carousel-control-color; |
||||||
|
text-decoration: none; |
||||||
|
.opacity(.9); |
||||||
|
} |
||||||
|
|
||||||
|
// Toggles |
||||||
|
.icon-prev, |
||||||
|
.icon-next, |
||||||
|
.glyphicon-chevron-left, |
||||||
|
.glyphicon-chevron-right { |
||||||
|
position: absolute; |
||||||
|
top: 50%; |
||||||
|
z-index: 5; |
||||||
|
display: inline-block; |
||||||
|
} |
||||||
|
.icon-prev, |
||||||
|
.glyphicon-chevron-left { |
||||||
|
left: 50%; |
||||||
|
} |
||||||
|
.icon-next, |
||||||
|
.glyphicon-chevron-right { |
||||||
|
right: 50%; |
||||||
|
} |
||||||
|
.icon-prev, |
||||||
|
.icon-next { |
||||||
|
width: 20px; |
||||||
|
height: 20px; |
||||||
|
margin-top: -10px; |
||||||
|
margin-left: -10px; |
||||||
|
font-family: serif; |
||||||
|
} |
||||||
|
|
||||||
|
.icon-prev { |
||||||
|
&:before { |
||||||
|
content: '\2039';// SINGLE LEFT-POINTING ANGLE QUOTATION MARK (U+2039) |
||||||
|
} |
||||||
|
} |
||||||
|
.icon-next { |
||||||
|
&:before { |
||||||
|
content: '\203a';// SINGLE RIGHT-POINTING ANGLE QUOTATION MARK (U+203A) |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Optional indicator pips |
||||||
|
// |
||||||
|
// Add an unordered list with the following class and add a list item for each |
||||||
|
// slide your carousel holds. |
||||||
|
|
||||||
|
.carousel-indicators { |
||||||
|
position: absolute; |
||||||
|
bottom: 10px; |
||||||
|
left: 50%; |
||||||
|
z-index: 15; |
||||||
|
width: 60%; |
||||||
|
margin-left: -30%; |
||||||
|
padding-left: 0; |
||||||
|
list-style: none; |
||||||
|
text-align: center; |
||||||
|
|
||||||
|
li { |
||||||
|
display: inline-block; |
||||||
|
width: 10px; |
||||||
|
height: 10px; |
||||||
|
margin: 1px; |
||||||
|
text-indent: -999px; |
||||||
|
border: 1px solid @carousel-indicator-border-color; |
||||||
|
border-radius: 10px; |
||||||
|
cursor: pointer; |
||||||
|
|
||||||
|
// IE8-9 hack for event handling |
||||||
|
// |
||||||
|
// Internet Explorer 8-9 does not support clicks on elements without a set |
||||||
|
// `background-color`. We cannot use `filter` since that's not viewed as a |
||||||
|
// background color by the browser. Thus, a hack is needed. |
||||||
|
// |
||||||
|
// For IE8, we set solid black as it doesn't support `rgba()`. For IE9, we |
||||||
|
// set alpha transparency for the best results possible. |
||||||
|
background-color: #000 \9; // IE8 |
||||||
|
background-color: rgba(0,0,0,0); // IE9 |
||||||
|
} |
||||||
|
.active { |
||||||
|
margin: 0; |
||||||
|
width: 12px; |
||||||
|
height: 12px; |
||||||
|
background-color: @carousel-indicator-active-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Optional captions |
||||||
|
// ----------------------------- |
||||||
|
// Hidden by default for smaller viewports |
||||||
|
.carousel-caption { |
||||||
|
position: absolute; |
||||||
|
left: 15%; |
||||||
|
right: 15%; |
||||||
|
bottom: 20px; |
||||||
|
z-index: 10; |
||||||
|
padding-top: 20px; |
||||||
|
padding-bottom: 20px; |
||||||
|
color: @carousel-caption-color; |
||||||
|
text-align: center; |
||||||
|
text-shadow: @carousel-text-shadow; |
||||||
|
& .btn { |
||||||
|
text-shadow: none; // No shadow for button elements in carousel-caption |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Scale up controls for tablets and up |
||||||
|
@media screen and (min-width: @screen-sm-min) { |
||||||
|
|
||||||
|
// Scale up the controls a smidge |
||||||
|
.carousel-control { |
||||||
|
.glyphicon-chevron-left, |
||||||
|
.glyphicon-chevron-right, |
||||||
|
.icon-prev, |
||||||
|
.icon-next { |
||||||
|
width: 30px; |
||||||
|
height: 30px; |
||||||
|
margin-top: -15px; |
||||||
|
margin-left: -15px; |
||||||
|
font-size: 30px; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Show and left align the captions |
||||||
|
.carousel-caption { |
||||||
|
left: 20%; |
||||||
|
right: 20%; |
||||||
|
padding-bottom: 30px; |
||||||
|
} |
||||||
|
|
||||||
|
// Move up the indicators |
||||||
|
.carousel-indicators { |
||||||
|
bottom: 20px; |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,33 @@ |
|||||||
|
// |
||||||
|
// Close icons |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
.close { |
||||||
|
float: right; |
||||||
|
font-size: (@font-size-base * 1.5); |
||||||
|
font-weight: @close-font-weight; |
||||||
|
line-height: 1; |
||||||
|
color: @close-color; |
||||||
|
text-shadow: @close-text-shadow; |
||||||
|
.opacity(.2); |
||||||
|
|
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @close-color; |
||||||
|
text-decoration: none; |
||||||
|
cursor: pointer; |
||||||
|
.opacity(.5); |
||||||
|
} |
||||||
|
|
||||||
|
// Additional properties for button version |
||||||
|
// iOS requires the button element instead of an anchor tag. |
||||||
|
// If you want the anchor version, it requires `href="#"`. |
||||||
|
button& { |
||||||
|
padding: 0; |
||||||
|
cursor: pointer; |
||||||
|
background: transparent; |
||||||
|
border: 0; |
||||||
|
-webkit-appearance: none; |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,63 @@ |
|||||||
|
// |
||||||
|
// Code (inline and block) |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// Inline and block code styles |
||||||
|
code, |
||||||
|
kbd, |
||||||
|
pre, |
||||||
|
samp { |
||||||
|
font-family: @font-family-monospace; |
||||||
|
} |
||||||
|
|
||||||
|
// Inline code |
||||||
|
code { |
||||||
|
padding: 2px 4px; |
||||||
|
font-size: 90%; |
||||||
|
color: @code-color; |
||||||
|
background-color: @code-bg; |
||||||
|
white-space: nowrap; |
||||||
|
border-radius: @border-radius-base; |
||||||
|
} |
||||||
|
|
||||||
|
// User input typically entered via keyboard |
||||||
|
kbd { |
||||||
|
padding: 2px 4px; |
||||||
|
font-size: 90%; |
||||||
|
color: @kbd-color; |
||||||
|
background-color: @kbd-bg; |
||||||
|
border-radius: @border-radius-small; |
||||||
|
box-shadow: inset 0 -1px 0 rgba(0,0,0,.25); |
||||||
|
} |
||||||
|
|
||||||
|
// Blocks of code |
||||||
|
pre { |
||||||
|
display: block; |
||||||
|
padding: ((@line-height-computed - 1) / 2); |
||||||
|
margin: 0 0 (@line-height-computed / 2); |
||||||
|
font-size: (@font-size-base - 1); // 14px to 13px |
||||||
|
line-height: @line-height-base; |
||||||
|
word-break: break-all; |
||||||
|
word-wrap: break-word; |
||||||
|
color: @pre-color; |
||||||
|
background-color: @pre-bg; |
||||||
|
border: 1px solid @pre-border-color; |
||||||
|
border-radius: @border-radius-base; |
||||||
|
|
||||||
|
// Account for some code outputs that place code tags in pre tags |
||||||
|
code { |
||||||
|
padding: 0; |
||||||
|
font-size: inherit; |
||||||
|
color: inherit; |
||||||
|
white-space: pre-wrap; |
||||||
|
background-color: transparent; |
||||||
|
border-radius: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Enable scrollable blocks of code |
||||||
|
.pre-scrollable { |
||||||
|
max-height: @pre-scrollable-max-height; |
||||||
|
overflow-y: scroll; |
||||||
|
} |
@ -0,0 +1,29 @@ |
|||||||
|
// |
||||||
|
// Component animations |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
// Heads up! |
||||||
|
// |
||||||
|
// We don't use the `.opacity()` mixin here since it causes a bug with text |
||||||
|
// fields in IE7-8. Source: https://github.com/twitter/bootstrap/pull/3552. |
||||||
|
|
||||||
|
.fade { |
||||||
|
opacity: 0; |
||||||
|
.transition(opacity .15s linear); |
||||||
|
&.in { |
||||||
|
opacity: 1; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
.collapse { |
||||||
|
display: none; |
||||||
|
&.in { |
||||||
|
display: block; |
||||||
|
} |
||||||
|
} |
||||||
|
.collapsing { |
||||||
|
position: relative; |
||||||
|
height: 0; |
||||||
|
overflow: hidden; |
||||||
|
.transition(height .35s ease); |
||||||
|
} |
@ -0,0 +1,213 @@ |
|||||||
|
// |
||||||
|
// Dropdown menus |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// Dropdown arrow/caret |
||||||
|
.caret { |
||||||
|
display: inline-block; |
||||||
|
width: 0; |
||||||
|
height: 0; |
||||||
|
margin-left: 2px; |
||||||
|
vertical-align: middle; |
||||||
|
border-top: @caret-width-base solid; |
||||||
|
border-right: @caret-width-base solid transparent; |
||||||
|
border-left: @caret-width-base solid transparent; |
||||||
|
} |
||||||
|
|
||||||
|
// The dropdown wrapper (div) |
||||||
|
.dropdown { |
||||||
|
position: relative; |
||||||
|
} |
||||||
|
|
||||||
|
// Prevent the focus on the dropdown toggle when closing dropdowns |
||||||
|
.dropdown-toggle:focus { |
||||||
|
outline: 0; |
||||||
|
} |
||||||
|
|
||||||
|
// The dropdown menu (ul) |
||||||
|
.dropdown-menu { |
||||||
|
position: absolute; |
||||||
|
top: 100%; |
||||||
|
left: 0; |
||||||
|
z-index: @zindex-dropdown; |
||||||
|
display: none; // none by default, but block on "open" of the menu |
||||||
|
float: left; |
||||||
|
min-width: 160px; |
||||||
|
padding: 5px 0; |
||||||
|
margin: 2px 0 0; // override default ul |
||||||
|
list-style: none; |
||||||
|
font-size: @font-size-base; |
||||||
|
background-color: @dropdown-bg; |
||||||
|
border: 1px solid @dropdown-fallback-border; // IE8 fallback |
||||||
|
border: 1px solid @dropdown-border; |
||||||
|
border-radius: @border-radius-base; |
||||||
|
.box-shadow(0 6px 12px rgba(0,0,0,.175)); |
||||||
|
background-clip: padding-box; |
||||||
|
|
||||||
|
// Aligns the dropdown menu to right |
||||||
|
// |
||||||
|
// Deprecated as of 3.1.0 in favor of `.dropdown-menu-[dir]` |
||||||
|
&.pull-right { |
||||||
|
right: 0; |
||||||
|
left: auto; |
||||||
|
} |
||||||
|
|
||||||
|
// Dividers (basically an hr) within the dropdown |
||||||
|
.divider { |
||||||
|
.nav-divider(@dropdown-divider-bg); |
||||||
|
} |
||||||
|
|
||||||
|
// Links within the dropdown menu |
||||||
|
> li > a { |
||||||
|
display: block; |
||||||
|
padding: 3px 20px; |
||||||
|
clear: both; |
||||||
|
font-weight: normal; |
||||||
|
line-height: @line-height-base; |
||||||
|
color: @dropdown-link-color; |
||||||
|
white-space: nowrap; // prevent links from randomly breaking onto new lines |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Hover/Focus state |
||||||
|
.dropdown-menu > li > a { |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
text-decoration: none; |
||||||
|
color: @dropdown-link-hover-color; |
||||||
|
background-color: @dropdown-link-hover-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Active state |
||||||
|
.dropdown-menu > .active > a { |
||||||
|
&, |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @dropdown-link-active-color; |
||||||
|
text-decoration: none; |
||||||
|
outline: 0; |
||||||
|
background-color: @dropdown-link-active-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Disabled state |
||||||
|
// |
||||||
|
// Gray out text and ensure the hover/focus state remains gray |
||||||
|
|
||||||
|
.dropdown-menu > .disabled > a { |
||||||
|
&, |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @dropdown-link-disabled-color; |
||||||
|
} |
||||||
|
} |
||||||
|
// Nuke hover/focus effects |
||||||
|
.dropdown-menu > .disabled > a { |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
text-decoration: none; |
||||||
|
background-color: transparent; |
||||||
|
background-image: none; // Remove CSS gradient |
||||||
|
.reset-filter(); |
||||||
|
cursor: not-allowed; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Open state for the dropdown |
||||||
|
.open { |
||||||
|
// Show the menu |
||||||
|
> .dropdown-menu { |
||||||
|
display: block; |
||||||
|
} |
||||||
|
|
||||||
|
// Remove the outline when :focus is triggered |
||||||
|
> a { |
||||||
|
outline: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Menu positioning |
||||||
|
// |
||||||
|
// Add extra class to `.dropdown-menu` to flip the alignment of the dropdown |
||||||
|
// menu with the parent. |
||||||
|
.dropdown-menu-right { |
||||||
|
left: auto; // Reset the default from `.dropdown-menu` |
||||||
|
right: 0; |
||||||
|
} |
||||||
|
// With v3, we enabled auto-flipping if you have a dropdown within a right |
||||||
|
// aligned nav component. To enable the undoing of that, we provide an override |
||||||
|
// to restore the default dropdown menu alignment. |
||||||
|
// |
||||||
|
// This is only for left-aligning a dropdown menu within a `.navbar-right` or |
||||||
|
// `.pull-right` nav component. |
||||||
|
.dropdown-menu-left { |
||||||
|
left: 0; |
||||||
|
right: auto; |
||||||
|
} |
||||||
|
|
||||||
|
// Dropdown section headers |
||||||
|
.dropdown-header { |
||||||
|
display: block; |
||||||
|
padding: 3px 20px; |
||||||
|
font-size: @font-size-small; |
||||||
|
line-height: @line-height-base; |
||||||
|
color: @dropdown-header-color; |
||||||
|
} |
||||||
|
|
||||||
|
// Backdrop to catch body clicks on mobile, etc. |
||||||
|
.dropdown-backdrop { |
||||||
|
position: fixed; |
||||||
|
left: 0; |
||||||
|
right: 0; |
||||||
|
bottom: 0; |
||||||
|
top: 0; |
||||||
|
z-index: (@zindex-dropdown - 10); |
||||||
|
} |
||||||
|
|
||||||
|
// Right aligned dropdowns |
||||||
|
.pull-right > .dropdown-menu { |
||||||
|
right: 0; |
||||||
|
left: auto; |
||||||
|
} |
||||||
|
|
||||||
|
// Allow for dropdowns to go bottom up (aka, dropup-menu) |
||||||
|
// |
||||||
|
// Just add .dropup after the standard .dropdown class and you're set, bro. |
||||||
|
// TODO: abstract this so that the navbar fixed styles are not placed here? |
||||||
|
|
||||||
|
.dropup, |
||||||
|
.navbar-fixed-bottom .dropdown { |
||||||
|
// Reverse the caret |
||||||
|
.caret { |
||||||
|
border-top: 0; |
||||||
|
border-bottom: @caret-width-base solid; |
||||||
|
content: ""; |
||||||
|
} |
||||||
|
// Different positioning for bottom up menu |
||||||
|
.dropdown-menu { |
||||||
|
top: auto; |
||||||
|
bottom: 100%; |
||||||
|
margin-bottom: 1px; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Component alignment |
||||||
|
// |
||||||
|
// Reiterate per navbar.less and the modified component alignment there. |
||||||
|
|
||||||
|
@media (min-width: @grid-float-breakpoint) { |
||||||
|
.navbar-right { |
||||||
|
.dropdown-menu { |
||||||
|
.dropdown-menu-right(); |
||||||
|
} |
||||||
|
// Necessary for overrides of the default right aligned menu. |
||||||
|
// Will remove come v4 in all likelihood. |
||||||
|
.dropdown-menu-left { |
||||||
|
.dropdown-menu-left(); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
@ -0,0 +1,438 @@ |
|||||||
|
// |
||||||
|
// Forms |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// Normalize non-controls |
||||||
|
// |
||||||
|
// Restyle and baseline non-control form elements. |
||||||
|
|
||||||
|
fieldset { |
||||||
|
padding: 0; |
||||||
|
margin: 0; |
||||||
|
border: 0; |
||||||
|
// Chrome and Firefox set a `min-width: -webkit-min-content;` on fieldsets, |
||||||
|
// so we reset that to ensure it behaves more like a standard block element. |
||||||
|
// See https://github.com/twbs/bootstrap/issues/12359. |
||||||
|
min-width: 0; |
||||||
|
} |
||||||
|
|
||||||
|
legend { |
||||||
|
display: block; |
||||||
|
width: 100%; |
||||||
|
padding: 0; |
||||||
|
margin-bottom: @line-height-computed; |
||||||
|
font-size: (@font-size-base * 1.5); |
||||||
|
line-height: inherit; |
||||||
|
color: @legend-color; |
||||||
|
border: 0; |
||||||
|
border-bottom: 1px solid @legend-border-color; |
||||||
|
} |
||||||
|
|
||||||
|
label { |
||||||
|
display: inline-block; |
||||||
|
margin-bottom: 5px; |
||||||
|
font-weight: bold; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Normalize form controls |
||||||
|
// |
||||||
|
// While most of our form styles require extra classes, some basic normalization |
||||||
|
// is required to ensure optimum display with or without those classes to better |
||||||
|
// address browser inconsistencies. |
||||||
|
|
||||||
|
// Override content-box in Normalize (* isn't specific enough) |
||||||
|
input[type="search"] { |
||||||
|
.box-sizing(border-box); |
||||||
|
} |
||||||
|
|
||||||
|
// Position radios and checkboxes better |
||||||
|
input[type="radio"], |
||||||
|
input[type="checkbox"] { |
||||||
|
margin: 4px 0 0; |
||||||
|
margin-top: 1px \9; /* IE8-9 */ |
||||||
|
line-height: normal; |
||||||
|
} |
||||||
|
|
||||||
|
// Set the height of file controls to match text inputs |
||||||
|
input[type="file"] { |
||||||
|
display: block; |
||||||
|
} |
||||||
|
|
||||||
|
// Make range inputs behave like textual form controls |
||||||
|
input[type="range"] { |
||||||
|
display: block; |
||||||
|
width: 100%; |
||||||
|
} |
||||||
|
|
||||||
|
// Make multiple select elements height not fixed |
||||||
|
select[multiple], |
||||||
|
select[size] { |
||||||
|
height: auto; |
||||||
|
} |
||||||
|
|
||||||
|
// Focus for file, radio, and checkbox |
||||||
|
input[type="file"]:focus, |
||||||
|
input[type="radio"]:focus, |
||||||
|
input[type="checkbox"]:focus { |
||||||
|
.tab-focus(); |
||||||
|
} |
||||||
|
|
||||||
|
// Adjust output element |
||||||
|
output { |
||||||
|
display: block; |
||||||
|
padding-top: (@padding-base-vertical + 1); |
||||||
|
font-size: @font-size-base; |
||||||
|
line-height: @line-height-base; |
||||||
|
color: @input-color; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Common form controls |
||||||
|
// |
||||||
|
// Shared size and type resets for form controls. Apply `.form-control` to any |
||||||
|
// of the following form controls: |
||||||
|
// |
||||||
|
// select |
||||||
|
// textarea |
||||||
|
// input[type="text"] |
||||||
|
// input[type="password"] |
||||||
|
// input[type="datetime"] |
||||||
|
// input[type="datetime-local"] |
||||||
|
// input[type="date"] |
||||||
|
// input[type="month"] |
||||||
|
// input[type="time"] |
||||||
|
// input[type="week"] |
||||||
|
// input[type="number"] |
||||||
|
// input[type="email"] |
||||||
|
// input[type="url"] |
||||||
|
// input[type="search"] |
||||||
|
// input[type="tel"] |
||||||
|
// input[type="color"] |
||||||
|
|
||||||
|
.form-control { |
||||||
|
display: block; |
||||||
|
width: 100%; |
||||||
|
height: @input-height-base; // Make inputs at least the height of their button counterpart (base line-height + padding + border) |
||||||
|
padding: @padding-base-vertical @padding-base-horizontal; |
||||||
|
font-size: @font-size-base; |
||||||
|
line-height: @line-height-base; |
||||||
|
color: @input-color; |
||||||
|
background-color: @input-bg; |
||||||
|
background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214 |
||||||
|
border: 1px solid @input-border; |
||||||
|
border-radius: @input-border-radius; |
||||||
|
.box-shadow(inset 0 1px 1px rgba(0,0,0,.075)); |
||||||
|
.transition(~"border-color ease-in-out .15s, box-shadow ease-in-out .15s"); |
||||||
|
|
||||||
|
// Customize the `:focus` state to imitate native WebKit styles. |
||||||
|
.form-control-focus(); |
||||||
|
|
||||||
|
// Placeholder |
||||||
|
.placeholder(); |
||||||
|
|
||||||
|
// Disabled and read-only inputs |
||||||
|
// |
||||||
|
// HTML5 says that controls under a fieldset > legend:first-child won't be |
||||||
|
// disabled if the fieldset is disabled. Due to implementation difficulty, we |
||||||
|
// don't honor that edge case; we style them as disabled anyway. |
||||||
|
&[disabled], |
||||||
|
&[readonly], |
||||||
|
fieldset[disabled] & { |
||||||
|
cursor: not-allowed; |
||||||
|
background-color: @input-bg-disabled; |
||||||
|
opacity: 1; // iOS fix for unreadable disabled content |
||||||
|
} |
||||||
|
|
||||||
|
// Reset height for `textarea`s |
||||||
|
textarea& { |
||||||
|
height: auto; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Search inputs in iOS |
||||||
|
// |
||||||
|
// This overrides the extra rounded corners on search inputs in iOS so that our |
||||||
|
// `.form-control` class can properly style them. Note that this cannot simply |
||||||
|
// be added to `.form-control` as it's not specific enough. For details, see |
||||||
|
// https://github.com/twbs/bootstrap/issues/11586. |
||||||
|
|
||||||
|
input[type="search"] { |
||||||
|
-webkit-appearance: none; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Special styles for iOS date input |
||||||
|
// |
||||||
|
// In Mobile Safari, date inputs require a pixel line-height that matches the |
||||||
|
// given height of the input. |
||||||
|
|
||||||
|
input[type="date"] { |
||||||
|
line-height: @input-height-base; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Form groups |
||||||
|
// |
||||||
|
// Designed to help with the organization and spacing of vertical forms. For |
||||||
|
// horizontal forms, use the predefined grid classes. |
||||||
|
|
||||||
|
.form-group { |
||||||
|
margin-bottom: 15px; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Checkboxes and radios |
||||||
|
// |
||||||
|
// Indent the labels to position radios/checkboxes as hanging controls. |
||||||
|
|
||||||
|
.radio, |
||||||
|
.checkbox { |
||||||
|
display: block; |
||||||
|
min-height: @line-height-computed; // clear the floating input if there is no label text |
||||||
|
margin-top: 10px; |
||||||
|
margin-bottom: 10px; |
||||||
|
padding-left: 20px; |
||||||
|
label { |
||||||
|
display: inline; |
||||||
|
font-weight: normal; |
||||||
|
cursor: pointer; |
||||||
|
} |
||||||
|
} |
||||||
|
.radio input[type="radio"], |
||||||
|
.radio-inline input[type="radio"], |
||||||
|
.checkbox input[type="checkbox"], |
||||||
|
.checkbox-inline input[type="checkbox"] { |
||||||
|
float: left; |
||||||
|
margin-left: -20px; |
||||||
|
} |
||||||
|
.radio + .radio, |
||||||
|
.checkbox + .checkbox { |
||||||
|
margin-top: -5px; // Move up sibling radios or checkboxes for tighter spacing |
||||||
|
} |
||||||
|
|
||||||
|
// Radios and checkboxes on same line |
||||||
|
.radio-inline, |
||||||
|
.checkbox-inline { |
||||||
|
display: inline-block; |
||||||
|
padding-left: 20px; |
||||||
|
margin-bottom: 0; |
||||||
|
vertical-align: middle; |
||||||
|
font-weight: normal; |
||||||
|
cursor: pointer; |
||||||
|
} |
||||||
|
.radio-inline + .radio-inline, |
||||||
|
.checkbox-inline + .checkbox-inline { |
||||||
|
margin-top: 0; |
||||||
|
margin-left: 10px; // space out consecutive inline controls |
||||||
|
} |
||||||
|
|
||||||
|
// Apply same disabled cursor tweak as for inputs |
||||||
|
// |
||||||
|
// Note: Neither radios nor checkboxes can be readonly. |
||||||
|
input[type="radio"], |
||||||
|
input[type="checkbox"], |
||||||
|
.radio, |
||||||
|
.radio-inline, |
||||||
|
.checkbox, |
||||||
|
.checkbox-inline { |
||||||
|
&[disabled], |
||||||
|
fieldset[disabled] & { |
||||||
|
cursor: not-allowed; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Form control sizing |
||||||
|
// |
||||||
|
// Build on `.form-control` with modifier classes to decrease or increase the |
||||||
|
// height and font-size of form controls. |
||||||
|
|
||||||
|
.input-sm { |
||||||
|
.input-size(@input-height-small; @padding-small-vertical; @padding-small-horizontal; @font-size-small; @line-height-small; @border-radius-small); |
||||||
|
} |
||||||
|
|
||||||
|
.input-lg { |
||||||
|
.input-size(@input-height-large; @padding-large-vertical; @padding-large-horizontal; @font-size-large; @line-height-large; @border-radius-large); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Form control feedback states |
||||||
|
// |
||||||
|
// Apply contextual and semantic states to individual form controls. |
||||||
|
|
||||||
|
.has-feedback { |
||||||
|
// Enable absolute positioning |
||||||
|
position: relative; |
||||||
|
|
||||||
|
// Ensure icons don't overlap text |
||||||
|
.form-control { |
||||||
|
padding-right: (@input-height-base * 1.25); |
||||||
|
} |
||||||
|
|
||||||
|
// Feedback icon (requires .glyphicon classes) |
||||||
|
.form-control-feedback { |
||||||
|
position: absolute; |
||||||
|
top: (@line-height-computed + 5); // Height of the `label` and its margin |
||||||
|
right: 0; |
||||||
|
display: block; |
||||||
|
width: @input-height-base; |
||||||
|
height: @input-height-base; |
||||||
|
line-height: @input-height-base; |
||||||
|
text-align: center; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Feedback states |
||||||
|
.has-success { |
||||||
|
.form-control-validation(@state-success-text; @state-success-text; @state-success-bg); |
||||||
|
} |
||||||
|
.has-warning { |
||||||
|
.form-control-validation(@state-warning-text; @state-warning-text; @state-warning-bg); |
||||||
|
} |
||||||
|
.has-error { |
||||||
|
.form-control-validation(@state-danger-text; @state-danger-text; @state-danger-bg); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Static form control text |
||||||
|
// |
||||||
|
// Apply class to a `p` element to make any string of text align with labels in |
||||||
|
// a horizontal form layout. |
||||||
|
|
||||||
|
.form-control-static { |
||||||
|
margin-bottom: 0; // Remove default margin from `p` |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Help text |
||||||
|
// |
||||||
|
// Apply to any element you wish to create light text for placement immediately |
||||||
|
// below a form control. Use for general help, formatting, or instructional text. |
||||||
|
|
||||||
|
.help-block { |
||||||
|
display: block; // account for any element using help-block |
||||||
|
margin-top: 5px; |
||||||
|
margin-bottom: 10px; |
||||||
|
color: lighten(@text-color, 25%); // lighten the text some for contrast |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// Inline forms |
||||||
|
// |
||||||
|
// Make forms appear inline(-block) by adding the `.form-inline` class. Inline |
||||||
|
// forms begin stacked on extra small (mobile) devices and then go inline when |
||||||
|
// viewports reach <768px. |
||||||
|
// |
||||||
|
// Requires wrapping inputs and labels with `.form-group` for proper display of |
||||||
|
// default HTML form controls and our custom form controls (e.g., input groups). |
||||||
|
// |
||||||
|
// Heads up! This is mixin-ed into `.navbar-form` in navbars.less. |
||||||
|
|
||||||
|
.form-inline { |
||||||
|
|
||||||
|
// Kick in the inline |
||||||
|
@media (min-width: @screen-sm-min) { |
||||||
|
// Inline-block all the things for "inline" |
||||||
|
.form-group { |
||||||
|
display: inline-block; |
||||||
|
margin-bottom: 0; |
||||||
|
vertical-align: middle; |
||||||
|
} |
||||||
|
|
||||||
|
// In navbar-form, allow folks to *not* use `.form-group` |
||||||
|
.form-control { |
||||||
|
display: inline-block; |
||||||
|
width: auto; // Prevent labels from stacking above inputs in `.form-group` |
||||||
|
vertical-align: middle; |
||||||
|
} |
||||||
|
// Input groups need that 100% width though |
||||||
|
.input-group > .form-control { |
||||||
|
width: 100%; |
||||||
|
} |
||||||
|
|
||||||
|
.control-label { |
||||||
|
margin-bottom: 0; |
||||||
|
vertical-align: middle; |
||||||
|
} |
||||||
|
|
||||||
|
// Remove default margin on radios/checkboxes that were used for stacking, and |
||||||
|
// then undo the floating of radios and checkboxes to match (which also avoids |
||||||
|
// a bug in WebKit: https://github.com/twbs/bootstrap/issues/1969). |
||||||
|
.radio, |
||||||
|
.checkbox { |
||||||
|
display: inline-block; |
||||||
|
margin-top: 0; |
||||||
|
margin-bottom: 0; |
||||||
|
padding-left: 0; |
||||||
|
vertical-align: middle; |
||||||
|
} |
||||||
|
.radio input[type="radio"], |
||||||
|
.checkbox input[type="checkbox"] { |
||||||
|
float: none; |
||||||
|
margin-left: 0; |
||||||
|
} |
||||||
|
|
||||||
|
// Validation states |
||||||
|
// |
||||||
|
// Reposition the icon because it's now within a grid column and columns have |
||||||
|
// `position: relative;` on them. Also accounts for the grid gutter padding. |
||||||
|
.has-feedback .form-control-feedback { |
||||||
|
top: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Horizontal forms |
||||||
|
// |
||||||
|
// Horizontal forms are built on grid classes and allow you to create forms with |
||||||
|
// labels on the left and inputs on the right. |
||||||
|
|
||||||
|
.form-horizontal { |
||||||
|
|
||||||
|
// Consistent vertical alignment of labels, radios, and checkboxes |
||||||
|
.control-label, |
||||||
|
.radio, |
||||||
|
.checkbox, |
||||||
|
.radio-inline, |
||||||
|
.checkbox-inline { |
||||||
|
margin-top: 0; |
||||||
|
margin-bottom: 0; |
||||||
|
padding-top: (@padding-base-vertical + 1); // Default padding plus a border |
||||||
|
} |
||||||
|
// Account for padding we're adding to ensure the alignment and of help text |
||||||
|
// and other content below items |
||||||
|
.radio, |
||||||
|
.checkbox { |
||||||
|
min-height: (@line-height-computed + (@padding-base-vertical + 1)); |
||||||
|
} |
||||||
|
|
||||||
|
// Make form groups behave like rows |
||||||
|
.form-group { |
||||||
|
.make-row(); |
||||||
|
} |
||||||
|
|
||||||
|
.form-control-static { |
||||||
|
padding-top: (@padding-base-vertical + 1); |
||||||
|
} |
||||||
|
|
||||||
|
// Only right align form labels here when the columns stop stacking |
||||||
|
@media (min-width: @screen-sm-min) { |
||||||
|
.control-label { |
||||||
|
text-align: right; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Validation states |
||||||
|
// |
||||||
|
// Reposition the icon because it's now within a grid column and columns have |
||||||
|
// `position: relative;` on them. Also accounts for the grid gutter padding. |
||||||
|
.has-feedback .form-control-feedback { |
||||||
|
top: 0; |
||||||
|
right: (@grid-gutter-width / 2); |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,233 @@ |
|||||||
|
// |
||||||
|
// Glyphicons for Bootstrap |
||||||
|
// |
||||||
|
// Since icons are fonts, they can be placed anywhere text is placed and are |
||||||
|
// thus automatically sized to match the surrounding child. To use, create an |
||||||
|
// inline element with the appropriate classes, like so: |
||||||
|
// |
||||||
|
// <a href="#"><span class="glyphicon glyphicon-star"></span> Star</a> |
||||||
|
|
||||||
|
// Import the fonts |
||||||
|
@font-face { |
||||||
|
font-family: 'Glyphicons Halflings'; |
||||||
|
src: ~"url('@{icon-font-path}@{icon-font-name}.eot')"; |
||||||
|
src: ~"url('@{icon-font-path}@{icon-font-name}.eot?#iefix') format('embedded-opentype')", |
||||||
|
~"url('@{icon-font-path}@{icon-font-name}.woff') format('woff')", |
||||||
|
~"url('@{icon-font-path}@{icon-font-name}.ttf') format('truetype')", |
||||||
|
~"url('@{icon-font-path}@{icon-font-name}.svg#@{icon-font-svg-id}') format('svg')"; |
||||||
|
} |
||||||
|
|
||||||
|
// Catchall baseclass |
||||||
|
.glyphicon { |
||||||
|
position: relative; |
||||||
|
top: 1px; |
||||||
|
display: inline-block; |
||||||
|
font-family: 'Glyphicons Halflings'; |
||||||
|
font-style: normal; |
||||||
|
font-weight: normal; |
||||||
|
line-height: 1; |
||||||
|
-webkit-font-smoothing: antialiased; |
||||||
|
-moz-osx-font-smoothing: grayscale; |
||||||
|
} |
||||||
|
|
||||||
|
// Individual icons |
||||||
|
.glyphicon-asterisk { &:before { content: "\2a"; } } |
||||||
|
.glyphicon-plus { &:before { content: "\2b"; } } |
||||||
|
.glyphicon-euro { &:before { content: "\20ac"; } } |
||||||
|
.glyphicon-minus { &:before { content: "\2212"; } } |
||||||
|
.glyphicon-cloud { &:before { content: "\2601"; } } |
||||||
|
.glyphicon-envelope { &:before { content: "\2709"; } } |
||||||
|
.glyphicon-pencil { &:before { content: "\270f"; } } |
||||||
|
.glyphicon-glass { &:before { content: "\e001"; } } |
||||||
|
.glyphicon-music { &:before { content: "\e002"; } } |
||||||
|
.glyphicon-search { &:before { content: "\e003"; } } |
||||||
|
.glyphicon-heart { &:before { content: "\e005"; } } |
||||||
|
.glyphicon-star { &:before { content: "\e006"; } } |
||||||
|
.glyphicon-star-empty { &:before { content: "\e007"; } } |
||||||
|
.glyphicon-user { &:before { content: "\e008"; } } |
||||||
|
.glyphicon-film { &:before { content: "\e009"; } } |
||||||
|
.glyphicon-th-large { &:before { content: "\e010"; } } |
||||||
|
.glyphicon-th { &:before { content: "\e011"; } } |
||||||
|
.glyphicon-th-list { &:before { content: "\e012"; } } |
||||||
|
.glyphicon-ok { &:before { content: "\e013"; } } |
||||||
|
.glyphicon-remove { &:before { content: "\e014"; } } |
||||||
|
.glyphicon-zoom-in { &:before { content: "\e015"; } } |
||||||
|
.glyphicon-zoom-out { &:before { content: "\e016"; } } |
||||||
|
.glyphicon-off { &:before { content: "\e017"; } } |
||||||
|
.glyphicon-signal { &:before { content: "\e018"; } } |
||||||
|
.glyphicon-cog { &:before { content: "\e019"; } } |
||||||
|
.glyphicon-trash { &:before { content: "\e020"; } } |
||||||
|
.glyphicon-home { &:before { content: "\e021"; } } |
||||||
|
.glyphicon-file { &:before { content: "\e022"; } } |
||||||
|
.glyphicon-time { &:before { content: "\e023"; } } |
||||||
|
.glyphicon-road { &:before { content: "\e024"; } } |
||||||
|
.glyphicon-download-alt { &:before { content: "\e025"; } } |
||||||
|
.glyphicon-download { &:before { content: "\e026"; } } |
||||||
|
.glyphicon-upload { &:before { content: "\e027"; } } |
||||||
|
.glyphicon-inbox { &:before { content: "\e028"; } } |
||||||
|
.glyphicon-play-circle { &:before { content: "\e029"; } } |
||||||
|
.glyphicon-repeat { &:before { content: "\e030"; } } |
||||||
|
.glyphicon-refresh { &:before { content: "\e031"; } } |
||||||
|
.glyphicon-list-alt { &:before { content: "\e032"; } } |
||||||
|
.glyphicon-lock { &:before { content: "\e033"; } } |
||||||
|
.glyphicon-flag { &:before { content: "\e034"; } } |
||||||
|
.glyphicon-headphones { &:before { content: "\e035"; } } |
||||||
|
.glyphicon-volume-off { &:before { content: "\e036"; } } |
||||||
|
.glyphicon-volume-down { &:before { content: "\e037"; } } |
||||||
|
.glyphicon-volume-up { &:before { content: "\e038"; } } |
||||||
|
.glyphicon-qrcode { &:before { content: "\e039"; } } |
||||||
|
.glyphicon-barcode { &:before { content: "\e040"; } } |
||||||
|
.glyphicon-tag { &:before { content: "\e041"; } } |
||||||
|
.glyphicon-tags { &:before { content: "\e042"; } } |
||||||
|
.glyphicon-book { &:before { content: "\e043"; } } |
||||||
|
.glyphicon-bookmark { &:before { content: "\e044"; } } |
||||||
|
.glyphicon-print { &:before { content: "\e045"; } } |
||||||
|
.glyphicon-camera { &:before { content: "\e046"; } } |
||||||
|
.glyphicon-font { &:before { content: "\e047"; } } |
||||||
|
.glyphicon-bold { &:before { content: "\e048"; } } |
||||||
|
.glyphicon-italic { &:before { content: "\e049"; } } |
||||||
|
.glyphicon-text-height { &:before { content: "\e050"; } } |
||||||
|
.glyphicon-text-width { &:before { content: "\e051"; } } |
||||||
|
.glyphicon-align-left { &:before { content: "\e052"; } } |
||||||
|
.glyphicon-align-center { &:before { content: "\e053"; } } |
||||||
|
.glyphicon-align-right { &:before { content: "\e054"; } } |
||||||
|
.glyphicon-align-justify { &:before { content: "\e055"; } } |
||||||
|
.glyphicon-list { &:before { content: "\e056"; } } |
||||||
|
.glyphicon-indent-left { &:before { content: "\e057"; } } |
||||||
|
.glyphicon-indent-right { &:before { content: "\e058"; } } |
||||||
|
.glyphicon-facetime-video { &:before { content: "\e059"; } } |
||||||
|
.glyphicon-picture { &:before { content: "\e060"; } } |
||||||
|
.glyphicon-map-marker { &:before { content: "\e062"; } } |
||||||
|
.glyphicon-adjust { &:before { content: "\e063"; } } |
||||||
|
.glyphicon-tint { &:before { content: "\e064"; } } |
||||||
|
.glyphicon-edit { &:before { content: "\e065"; } } |
||||||
|
.glyphicon-share { &:before { content: "\e066"; } } |
||||||
|
.glyphicon-check { &:before { content: "\e067"; } } |
||||||
|
.glyphicon-move { &:before { content: "\e068"; } } |
||||||
|
.glyphicon-step-backward { &:before { content: "\e069"; } } |
||||||
|
.glyphicon-fast-backward { &:before { content: "\e070"; } } |
||||||
|
.glyphicon-backward { &:before { content: "\e071"; } } |
||||||
|
.glyphicon-play { &:before { content: "\e072"; } } |
||||||
|
.glyphicon-pause { &:before { content: "\e073"; } } |
||||||
|
.glyphicon-stop { &:before { content: "\e074"; } } |
||||||
|
.glyphicon-forward { &:before { content: "\e075"; } } |
||||||
|
.glyphicon-fast-forward { &:before { content: "\e076"; } } |
||||||
|
.glyphicon-step-forward { &:before { content: "\e077"; } } |
||||||
|
.glyphicon-eject { &:before { content: "\e078"; } } |
||||||
|
.glyphicon-chevron-left { &:before { content: "\e079"; } } |
||||||
|
.glyphicon-chevron-right { &:before { content: "\e080"; } } |
||||||
|
.glyphicon-plus-sign { &:before { content: "\e081"; } } |
||||||
|
.glyphicon-minus-sign { &:before { content: "\e082"; } } |
||||||
|
.glyphicon-remove-sign { &:before { content: "\e083"; } } |
||||||
|
.glyphicon-ok-sign { &:before { content: "\e084"; } } |
||||||
|
.glyphicon-question-sign { &:before { content: "\e085"; } } |
||||||
|
.glyphicon-info-sign { &:before { content: "\e086"; } } |
||||||
|
.glyphicon-screenshot { &:before { content: "\e087"; } } |
||||||
|
.glyphicon-remove-circle { &:before { content: "\e088"; } } |
||||||
|
.glyphicon-ok-circle { &:before { content: "\e089"; } } |
||||||
|
.glyphicon-ban-circle { &:before { content: "\e090"; } } |
||||||
|
.glyphicon-arrow-left { &:before { content: "\e091"; } } |
||||||
|
.glyphicon-arrow-right { &:before { content: "\e092"; } } |
||||||
|
.glyphicon-arrow-up { &:before { content: "\e093"; } } |
||||||
|
.glyphicon-arrow-down { &:before { content: "\e094"; } } |
||||||
|
.glyphicon-share-alt { &:before { content: "\e095"; } } |
||||||
|
.glyphicon-resize-full { &:before { content: "\e096"; } } |
||||||
|
.glyphicon-resize-small { &:before { content: "\e097"; } } |
||||||
|
.glyphicon-exclamation-sign { &:before { content: "\e101"; } } |
||||||
|
.glyphicon-gift { &:before { content: "\e102"; } } |
||||||
|
.glyphicon-leaf { &:before { content: "\e103"; } } |
||||||
|
.glyphicon-fire { &:before { content: "\e104"; } } |
||||||
|
.glyphicon-eye-open { &:before { content: "\e105"; } } |
||||||
|
.glyphicon-eye-close { &:before { content: "\e106"; } } |
||||||
|
.glyphicon-warning-sign { &:before { content: "\e107"; } } |
||||||
|
.glyphicon-plane { &:before { content: "\e108"; } } |
||||||
|
.glyphicon-calendar { &:before { content: "\e109"; } } |
||||||
|
.glyphicon-random { &:before { content: "\e110"; } } |
||||||
|
.glyphicon-comment { &:before { content: "\e111"; } } |
||||||
|
.glyphicon-magnet { &:before { content: "\e112"; } } |
||||||
|
.glyphicon-chevron-up { &:before { content: "\e113"; } } |
||||||
|
.glyphicon-chevron-down { &:before { content: "\e114"; } } |
||||||
|
.glyphicon-retweet { &:before { content: "\e115"; } } |
||||||
|
.glyphicon-shopping-cart { &:before { content: "\e116"; } } |
||||||
|
.glyphicon-folder-close { &:before { content: "\e117"; } } |
||||||
|
.glyphicon-folder-open { &:before { content: "\e118"; } } |
||||||
|
.glyphicon-resize-vertical { &:before { content: "\e119"; } } |
||||||
|
.glyphicon-resize-horizontal { &:before { content: "\e120"; } } |
||||||
|
.glyphicon-hdd { &:before { content: "\e121"; } } |
||||||
|
.glyphicon-bullhorn { &:before { content: "\e122"; } } |
||||||
|
.glyphicon-bell { &:before { content: "\e123"; } } |
||||||
|
.glyphicon-certificate { &:before { content: "\e124"; } } |
||||||
|
.glyphicon-thumbs-up { &:before { content: "\e125"; } } |
||||||
|
.glyphicon-thumbs-down { &:before { content: "\e126"; } } |
||||||
|
.glyphicon-hand-right { &:before { content: "\e127"; } } |
||||||
|
.glyphicon-hand-left { &:before { content: "\e128"; } } |
||||||
|
.glyphicon-hand-up { &:before { content: "\e129"; } } |
||||||
|
.glyphicon-hand-down { &:before { content: "\e130"; } } |
||||||
|
.glyphicon-circle-arrow-right { &:before { content: "\e131"; } } |
||||||
|
.glyphicon-circle-arrow-left { &:before { content: "\e132"; } } |
||||||
|
.glyphicon-circle-arrow-up { &:before { content: "\e133"; } } |
||||||
|
.glyphicon-circle-arrow-down { &:before { content: "\e134"; } } |
||||||
|
.glyphicon-globe { &:before { content: "\e135"; } } |
||||||
|
.glyphicon-wrench { &:before { content: "\e136"; } } |
||||||
|
.glyphicon-tasks { &:before { content: "\e137"; } } |
||||||
|
.glyphicon-filter { &:before { content: "\e138"; } } |
||||||
|
.glyphicon-briefcase { &:before { content: "\e139"; } } |
||||||
|
.glyphicon-fullscreen { &:before { content: "\e140"; } } |
||||||
|
.glyphicon-dashboard { &:before { content: "\e141"; } } |
||||||
|
.glyphicon-paperclip { &:before { content: "\e142"; } } |
||||||
|
.glyphicon-heart-empty { &:before { content: "\e143"; } } |
||||||
|
.glyphicon-link { &:before { content: "\e144"; } } |
||||||
|
.glyphicon-phone { &:before { content: "\e145"; } } |
||||||
|
.glyphicon-pushpin { &:before { content: "\e146"; } } |
||||||
|
.glyphicon-usd { &:before { content: "\e148"; } } |
||||||
|
.glyphicon-gbp { &:before { content: "\e149"; } } |
||||||
|
.glyphicon-sort { &:before { content: "\e150"; } } |
||||||
|
.glyphicon-sort-by-alphabet { &:before { content: "\e151"; } } |
||||||
|
.glyphicon-sort-by-alphabet-alt { &:before { content: "\e152"; } } |
||||||
|
.glyphicon-sort-by-order { &:before { content: "\e153"; } } |
||||||
|
.glyphicon-sort-by-order-alt { &:before { content: "\e154"; } } |
||||||
|
.glyphicon-sort-by-attributes { &:before { content: "\e155"; } } |
||||||
|
.glyphicon-sort-by-attributes-alt { &:before { content: "\e156"; } } |
||||||
|
.glyphicon-unchecked { &:before { content: "\e157"; } } |
||||||
|
.glyphicon-expand { &:before { content: "\e158"; } } |
||||||
|
.glyphicon-collapse-down { &:before { content: "\e159"; } } |
||||||
|
.glyphicon-collapse-up { &:before { content: "\e160"; } } |
||||||
|
.glyphicon-log-in { &:before { content: "\e161"; } } |
||||||
|
.glyphicon-flash { &:before { content: "\e162"; } } |
||||||
|
.glyphicon-log-out { &:before { content: "\e163"; } } |
||||||
|
.glyphicon-new-window { &:before { content: "\e164"; } } |
||||||
|
.glyphicon-record { &:before { content: "\e165"; } } |
||||||
|
.glyphicon-save { &:before { content: "\e166"; } } |
||||||
|
.glyphicon-open { &:before { content: "\e167"; } } |
||||||
|
.glyphicon-saved { &:before { content: "\e168"; } } |
||||||
|
.glyphicon-import { &:before { content: "\e169"; } } |
||||||
|
.glyphicon-export { &:before { content: "\e170"; } } |
||||||
|
.glyphicon-send { &:before { content: "\e171"; } } |
||||||
|
.glyphicon-floppy-disk { &:before { content: "\e172"; } } |
||||||
|
.glyphicon-floppy-saved { &:before { content: "\e173"; } } |
||||||
|
.glyphicon-floppy-remove { &:before { content: "\e174"; } } |
||||||
|
.glyphicon-floppy-save { &:before { content: "\e175"; } } |
||||||
|
.glyphicon-floppy-open { &:before { content: "\e176"; } } |
||||||
|
.glyphicon-credit-card { &:before { content: "\e177"; } } |
||||||
|
.glyphicon-transfer { &:before { content: "\e178"; } } |
||||||
|
.glyphicon-cutlery { &:before { content: "\e179"; } } |
||||||
|
.glyphicon-header { &:before { content: "\e180"; } } |
||||||
|
.glyphicon-compressed { &:before { content: "\e181"; } } |
||||||
|
.glyphicon-earphone { &:before { content: "\e182"; } } |
||||||
|
.glyphicon-phone-alt { &:before { content: "\e183"; } } |
||||||
|
.glyphicon-tower { &:before { content: "\e184"; } } |
||||||
|
.glyphicon-stats { &:before { content: "\e185"; } } |
||||||
|
.glyphicon-sd-video { &:before { content: "\e186"; } } |
||||||
|
.glyphicon-hd-video { &:before { content: "\e187"; } } |
||||||
|
.glyphicon-subtitles { &:before { content: "\e188"; } } |
||||||
|
.glyphicon-sound-stereo { &:before { content: "\e189"; } } |
||||||
|
.glyphicon-sound-dolby { &:before { content: "\e190"; } } |
||||||
|
.glyphicon-sound-5-1 { &:before { content: "\e191"; } } |
||||||
|
.glyphicon-sound-6-1 { &:before { content: "\e192"; } } |
||||||
|
.glyphicon-sound-7-1 { &:before { content: "\e193"; } } |
||||||
|
.glyphicon-copyright-mark { &:before { content: "\e194"; } } |
||||||
|
.glyphicon-registration-mark { &:before { content: "\e195"; } } |
||||||
|
.glyphicon-cloud-download { &:before { content: "\e197"; } } |
||||||
|
.glyphicon-cloud-upload { &:before { content: "\e198"; } } |
||||||
|
.glyphicon-tree-conifer { &:before { content: "\e199"; } } |
||||||
|
.glyphicon-tree-deciduous { &:before { content: "\e200"; } } |
@ -0,0 +1,84 @@ |
|||||||
|
// |
||||||
|
// Grid system |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// Container widths |
||||||
|
// |
||||||
|
// Set the container width, and override it for fixed navbars in media queries. |
||||||
|
|
||||||
|
.container { |
||||||
|
.container-fixed(); |
||||||
|
|
||||||
|
@media (min-width: @screen-sm-min) { |
||||||
|
width: @container-sm; |
||||||
|
} |
||||||
|
@media (min-width: @screen-md-min) { |
||||||
|
width: @container-md; |
||||||
|
} |
||||||
|
@media (min-width: @screen-lg-min) { |
||||||
|
width: @container-lg; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Fluid container |
||||||
|
// |
||||||
|
// Utilizes the mixin meant for fixed width containers, but without any defined |
||||||
|
// width for fluid, full width layouts. |
||||||
|
|
||||||
|
.container-fluid { |
||||||
|
.container-fixed(); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Row |
||||||
|
// |
||||||
|
// Rows contain and clear the floats of your columns. |
||||||
|
|
||||||
|
.row { |
||||||
|
.make-row(); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Columns |
||||||
|
// |
||||||
|
// Common styles for small and large grid columns |
||||||
|
|
||||||
|
.make-grid-columns(); |
||||||
|
|
||||||
|
|
||||||
|
// Extra small grid |
||||||
|
// |
||||||
|
// Columns, offsets, pushes, and pulls for extra small devices like |
||||||
|
// smartphones. |
||||||
|
|
||||||
|
.make-grid(xs); |
||||||
|
|
||||||
|
|
||||||
|
// Small grid |
||||||
|
// |
||||||
|
// Columns, offsets, pushes, and pulls for the small device range, from phones |
||||||
|
// to tablets. |
||||||
|
|
||||||
|
@media (min-width: @screen-sm-min) { |
||||||
|
.make-grid(sm); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Medium grid |
||||||
|
// |
||||||
|
// Columns, offsets, pushes, and pulls for the desktop device range. |
||||||
|
|
||||||
|
@media (min-width: @screen-md-min) { |
||||||
|
.make-grid(md); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Large grid |
||||||
|
// |
||||||
|
// Columns, offsets, pushes, and pulls for the large desktop device range. |
||||||
|
|
||||||
|
@media (min-width: @screen-lg-min) { |
||||||
|
.make-grid(lg); |
||||||
|
} |
@ -0,0 +1,162 @@ |
|||||||
|
// |
||||||
|
// Input groups |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
// Base styles |
||||||
|
// ------------------------- |
||||||
|
.input-group { |
||||||
|
position: relative; // For dropdowns |
||||||
|
display: table; |
||||||
|
border-collapse: separate; // prevent input groups from inheriting border styles from table cells when placed within a table |
||||||
|
|
||||||
|
// Undo padding and float of grid classes |
||||||
|
&[class*="col-"] { |
||||||
|
float: none; |
||||||
|
padding-left: 0; |
||||||
|
padding-right: 0; |
||||||
|
} |
||||||
|
|
||||||
|
.form-control { |
||||||
|
// Ensure that the input is always above the *appended* addon button for |
||||||
|
// proper border colors. |
||||||
|
position: relative; |
||||||
|
z-index: 2; |
||||||
|
|
||||||
|
// IE9 fubars the placeholder attribute in text inputs and the arrows on |
||||||
|
// select elements in input groups. To fix it, we float the input. Details: |
||||||
|
// https://github.com/twbs/bootstrap/issues/11561#issuecomment-28936855 |
||||||
|
float: left; |
||||||
|
|
||||||
|
width: 100%; |
||||||
|
margin-bottom: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Sizing options |
||||||
|
// |
||||||
|
// Remix the default form control sizing classes into new ones for easier |
||||||
|
// manipulation. |
||||||
|
|
||||||
|
.input-group-lg > .form-control, |
||||||
|
.input-group-lg > .input-group-addon, |
||||||
|
.input-group-lg > .input-group-btn > .btn { .input-lg(); } |
||||||
|
.input-group-sm > .form-control, |
||||||
|
.input-group-sm > .input-group-addon, |
||||||
|
.input-group-sm > .input-group-btn > .btn { .input-sm(); } |
||||||
|
|
||||||
|
|
||||||
|
// Display as table-cell |
||||||
|
// ------------------------- |
||||||
|
.input-group-addon, |
||||||
|
.input-group-btn, |
||||||
|
.input-group .form-control { |
||||||
|
display: table-cell; |
||||||
|
|
||||||
|
&:not(:first-child):not(:last-child) { |
||||||
|
border-radius: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
// Addon and addon wrapper for buttons |
||||||
|
.input-group-addon, |
||||||
|
.input-group-btn { |
||||||
|
width: 1%; |
||||||
|
white-space: nowrap; |
||||||
|
vertical-align: middle; // Match the inputs |
||||||
|
} |
||||||
|
|
||||||
|
// Text input groups |
||||||
|
// ------------------------- |
||||||
|
.input-group-addon { |
||||||
|
padding: @padding-base-vertical @padding-base-horizontal; |
||||||
|
font-size: @font-size-base; |
||||||
|
font-weight: normal; |
||||||
|
line-height: 1; |
||||||
|
color: @input-color; |
||||||
|
text-align: center; |
||||||
|
background-color: @input-group-addon-bg; |
||||||
|
border: 1px solid @input-group-addon-border-color; |
||||||
|
border-radius: @border-radius-base; |
||||||
|
|
||||||
|
// Sizing |
||||||
|
&.input-sm { |
||||||
|
padding: @padding-small-vertical @padding-small-horizontal; |
||||||
|
font-size: @font-size-small; |
||||||
|
border-radius: @border-radius-small; |
||||||
|
} |
||||||
|
&.input-lg { |
||||||
|
padding: @padding-large-vertical @padding-large-horizontal; |
||||||
|
font-size: @font-size-large; |
||||||
|
border-radius: @border-radius-large; |
||||||
|
} |
||||||
|
|
||||||
|
// Nuke default margins from checkboxes and radios to vertically center within. |
||||||
|
input[type="radio"], |
||||||
|
input[type="checkbox"] { |
||||||
|
margin-top: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Reset rounded corners |
||||||
|
.input-group .form-control:first-child, |
||||||
|
.input-group-addon:first-child, |
||||||
|
.input-group-btn:first-child > .btn, |
||||||
|
.input-group-btn:first-child > .btn-group > .btn, |
||||||
|
.input-group-btn:first-child > .dropdown-toggle, |
||||||
|
.input-group-btn:last-child > .btn:not(:last-child):not(.dropdown-toggle), |
||||||
|
.input-group-btn:last-child > .btn-group:not(:last-child) > .btn { |
||||||
|
.border-right-radius(0); |
||||||
|
} |
||||||
|
.input-group-addon:first-child { |
||||||
|
border-right: 0; |
||||||
|
} |
||||||
|
.input-group .form-control:last-child, |
||||||
|
.input-group-addon:last-child, |
||||||
|
.input-group-btn:last-child > .btn, |
||||||
|
.input-group-btn:last-child > .btn-group > .btn, |
||||||
|
.input-group-btn:last-child > .dropdown-toggle, |
||||||
|
.input-group-btn:first-child > .btn:not(:first-child), |
||||||
|
.input-group-btn:first-child > .btn-group:not(:first-child) > .btn { |
||||||
|
.border-left-radius(0); |
||||||
|
} |
||||||
|
.input-group-addon:last-child { |
||||||
|
border-left: 0; |
||||||
|
} |
||||||
|
|
||||||
|
// Button input groups |
||||||
|
// ------------------------- |
||||||
|
.input-group-btn { |
||||||
|
position: relative; |
||||||
|
// Jankily prevent input button groups from wrapping with `white-space` and |
||||||
|
// `font-size` in combination with `inline-block` on buttons. |
||||||
|
font-size: 0; |
||||||
|
white-space: nowrap; |
||||||
|
|
||||||
|
// Negative margin for spacing, position for bringing hovered/focused/actived |
||||||
|
// element above the siblings. |
||||||
|
> .btn { |
||||||
|
position: relative; |
||||||
|
+ .btn { |
||||||
|
margin-left: -1px; |
||||||
|
} |
||||||
|
// Bring the "active" button to the front |
||||||
|
&:hover, |
||||||
|
&:focus, |
||||||
|
&:active { |
||||||
|
z-index: 2; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Negative margin to only have a 1px border between the two |
||||||
|
&:first-child { |
||||||
|
> .btn, |
||||||
|
> .btn-group { |
||||||
|
margin-right: -1px; |
||||||
|
} |
||||||
|
} |
||||||
|
&:last-child { |
||||||
|
> .btn, |
||||||
|
> .btn-group { |
||||||
|
margin-left: -1px; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,44 @@ |
|||||||
|
// |
||||||
|
// Jumbotron |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
.jumbotron { |
||||||
|
padding: @jumbotron-padding; |
||||||
|
margin-bottom: @jumbotron-padding; |
||||||
|
color: @jumbotron-color; |
||||||
|
background-color: @jumbotron-bg; |
||||||
|
|
||||||
|
h1, |
||||||
|
.h1 { |
||||||
|
color: @jumbotron-heading-color; |
||||||
|
} |
||||||
|
p { |
||||||
|
margin-bottom: (@jumbotron-padding / 2); |
||||||
|
font-size: @jumbotron-font-size; |
||||||
|
font-weight: 200; |
||||||
|
} |
||||||
|
|
||||||
|
.container & { |
||||||
|
border-radius: @border-radius-large; // Only round corners at higher resolutions if contained in a container |
||||||
|
} |
||||||
|
|
||||||
|
.container { |
||||||
|
max-width: 100%; |
||||||
|
} |
||||||
|
|
||||||
|
@media screen and (min-width: @screen-sm-min) { |
||||||
|
padding-top: (@jumbotron-padding * 1.6); |
||||||
|
padding-bottom: (@jumbotron-padding * 1.6); |
||||||
|
|
||||||
|
.container & { |
||||||
|
padding-left: (@jumbotron-padding * 2); |
||||||
|
padding-right: (@jumbotron-padding * 2); |
||||||
|
} |
||||||
|
|
||||||
|
h1, |
||||||
|
.h1 { |
||||||
|
font-size: (@font-size-base * 4.5); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,64 @@ |
|||||||
|
// |
||||||
|
// Labels |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
.label { |
||||||
|
display: inline; |
||||||
|
padding: .2em .6em .3em; |
||||||
|
font-size: 75%; |
||||||
|
font-weight: bold; |
||||||
|
line-height: 1; |
||||||
|
color: @label-color; |
||||||
|
text-align: center; |
||||||
|
white-space: nowrap; |
||||||
|
vertical-align: baseline; |
||||||
|
border-radius: .25em; |
||||||
|
|
||||||
|
// Add hover effects, but only for links |
||||||
|
&[href] { |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @label-link-hover-color; |
||||||
|
text-decoration: none; |
||||||
|
cursor: pointer; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Empty labels collapse automatically (not available in IE8) |
||||||
|
&:empty { |
||||||
|
display: none; |
||||||
|
} |
||||||
|
|
||||||
|
// Quick fix for labels in buttons |
||||||
|
.btn & { |
||||||
|
position: relative; |
||||||
|
top: -1px; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Colors |
||||||
|
// Contextual variations (linked labels get darker on :hover) |
||||||
|
|
||||||
|
.label-default { |
||||||
|
.label-variant(@label-default-bg); |
||||||
|
} |
||||||
|
|
||||||
|
.label-primary { |
||||||
|
.label-variant(@label-primary-bg); |
||||||
|
} |
||||||
|
|
||||||
|
.label-success { |
||||||
|
.label-variant(@label-success-bg); |
||||||
|
} |
||||||
|
|
||||||
|
.label-info { |
||||||
|
.label-variant(@label-info-bg); |
||||||
|
} |
||||||
|
|
||||||
|
.label-warning { |
||||||
|
.label-variant(@label-warning-bg); |
||||||
|
} |
||||||
|
|
||||||
|
.label-danger { |
||||||
|
.label-variant(@label-danger-bg); |
||||||
|
} |
@ -0,0 +1,110 @@ |
|||||||
|
// |
||||||
|
// List groups |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// Base class |
||||||
|
// |
||||||
|
// Easily usable on <ul>, <ol>, or <div>. |
||||||
|
|
||||||
|
.list-group { |
||||||
|
// No need to set list-style: none; since .list-group-item is block level |
||||||
|
margin-bottom: 20px; |
||||||
|
padding-left: 0; // reset padding because ul and ol |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Individual list items |
||||||
|
// |
||||||
|
// Use on `li`s or `div`s within the `.list-group` parent. |
||||||
|
|
||||||
|
.list-group-item { |
||||||
|
position: relative; |
||||||
|
display: block; |
||||||
|
padding: 10px 15px; |
||||||
|
// Place the border on the list items and negative margin up for better styling |
||||||
|
margin-bottom: -1px; |
||||||
|
background-color: @list-group-bg; |
||||||
|
border: 1px solid @list-group-border; |
||||||
|
|
||||||
|
// Round the first and last items |
||||||
|
&:first-child { |
||||||
|
.border-top-radius(@list-group-border-radius); |
||||||
|
} |
||||||
|
&:last-child { |
||||||
|
margin-bottom: 0; |
||||||
|
.border-bottom-radius(@list-group-border-radius); |
||||||
|
} |
||||||
|
|
||||||
|
// Align badges within list items |
||||||
|
> .badge { |
||||||
|
float: right; |
||||||
|
} |
||||||
|
> .badge + .badge { |
||||||
|
margin-right: 5px; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Linked list items |
||||||
|
// |
||||||
|
// Use anchor elements instead of `li`s or `div`s to create linked list items. |
||||||
|
// Includes an extra `.active` modifier class for showing selected items. |
||||||
|
|
||||||
|
a.list-group-item { |
||||||
|
color: @list-group-link-color; |
||||||
|
|
||||||
|
.list-group-item-heading { |
||||||
|
color: @list-group-link-heading-color; |
||||||
|
} |
||||||
|
|
||||||
|
// Hover state |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
text-decoration: none; |
||||||
|
background-color: @list-group-hover-bg; |
||||||
|
} |
||||||
|
|
||||||
|
// Active class on item itself, not parent |
||||||
|
&.active, |
||||||
|
&.active:hover, |
||||||
|
&.active:focus { |
||||||
|
z-index: 2; // Place active items above their siblings for proper border styling |
||||||
|
color: @list-group-active-color; |
||||||
|
background-color: @list-group-active-bg; |
||||||
|
border-color: @list-group-active-border; |
||||||
|
|
||||||
|
// Force color to inherit for custom content |
||||||
|
.list-group-item-heading { |
||||||
|
color: inherit; |
||||||
|
} |
||||||
|
.list-group-item-text { |
||||||
|
color: @list-group-active-text-color; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Contextual variants |
||||||
|
// |
||||||
|
// Add modifier classes to change text and background color on individual items. |
||||||
|
// Organizationally, this must come after the `:hover` states. |
||||||
|
|
||||||
|
.list-group-item-variant(success; @state-success-bg; @state-success-text); |
||||||
|
.list-group-item-variant(info; @state-info-bg; @state-info-text); |
||||||
|
.list-group-item-variant(warning; @state-warning-bg; @state-warning-text); |
||||||
|
.list-group-item-variant(danger; @state-danger-bg; @state-danger-text); |
||||||
|
|
||||||
|
|
||||||
|
// Custom content options |
||||||
|
// |
||||||
|
// Extra classes for creating well-formatted content within `.list-group-item`s. |
||||||
|
|
||||||
|
.list-group-item-heading { |
||||||
|
margin-top: 0; |
||||||
|
margin-bottom: 5px; |
||||||
|
} |
||||||
|
.list-group-item-text { |
||||||
|
margin-bottom: 0; |
||||||
|
line-height: 1.3; |
||||||
|
} |
@ -0,0 +1,56 @@ |
|||||||
|
// Media objects |
||||||
|
// Source: http://stubbornella.org/content/?p=497 |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// Common styles |
||||||
|
// ------------------------- |
||||||
|
|
||||||
|
// Clear the floats |
||||||
|
.media, |
||||||
|
.media-body { |
||||||
|
overflow: hidden; |
||||||
|
zoom: 1; |
||||||
|
} |
||||||
|
|
||||||
|
// Proper spacing between instances of .media |
||||||
|
.media, |
||||||
|
.media .media { |
||||||
|
margin-top: 15px; |
||||||
|
} |
||||||
|
.media:first-child { |
||||||
|
margin-top: 0; |
||||||
|
} |
||||||
|
|
||||||
|
// For images and videos, set to block |
||||||
|
.media-object { |
||||||
|
display: block; |
||||||
|
} |
||||||
|
|
||||||
|
// Reset margins on headings for tighter default spacing |
||||||
|
.media-heading { |
||||||
|
margin: 0 0 5px; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Media image alignment |
||||||
|
// ------------------------- |
||||||
|
|
||||||
|
.media { |
||||||
|
> .pull-left { |
||||||
|
margin-right: 10px; |
||||||
|
} |
||||||
|
> .pull-right { |
||||||
|
margin-left: 10px; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Media list variation |
||||||
|
// ------------------------- |
||||||
|
|
||||||
|
// Undo default ul/ol styles |
||||||
|
.media-list { |
||||||
|
padding-left: 0; |
||||||
|
list-style: none; |
||||||
|
} |
@ -0,0 +1,929 @@ |
|||||||
|
// |
||||||
|
// Mixins |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// Utilities |
||||||
|
// ------------------------- |
||||||
|
|
||||||
|
// Clearfix |
||||||
|
// Source: http://nicolasgallagher.com/micro-clearfix-hack/ |
||||||
|
// |
||||||
|
// For modern browsers |
||||||
|
// 1. The space content is one way to avoid an Opera bug when the |
||||||
|
// contenteditable attribute is included anywhere else in the document. |
||||||
|
// Otherwise it causes space to appear at the top and bottom of elements |
||||||
|
// that are clearfixed. |
||||||
|
// 2. The use of `table` rather than `block` is only necessary if using |
||||||
|
// `:before` to contain the top-margins of child elements. |
||||||
|
.clearfix() { |
||||||
|
&:before, |
||||||
|
&:after { |
||||||
|
content: " "; // 1 |
||||||
|
display: table; // 2 |
||||||
|
} |
||||||
|
&:after { |
||||||
|
clear: both; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// WebKit-style focus |
||||||
|
.tab-focus() { |
||||||
|
// Default |
||||||
|
outline: thin dotted; |
||||||
|
// WebKit |
||||||
|
outline: 5px auto -webkit-focus-ring-color; |
||||||
|
outline-offset: -2px; |
||||||
|
} |
||||||
|
|
||||||
|
// Center-align a block level element |
||||||
|
.center-block() { |
||||||
|
display: block; |
||||||
|
margin-left: auto; |
||||||
|
margin-right: auto; |
||||||
|
} |
||||||
|
|
||||||
|
// Sizing shortcuts |
||||||
|
.size(@width; @height) { |
||||||
|
width: @width; |
||||||
|
height: @height; |
||||||
|
} |
||||||
|
.square(@size) { |
||||||
|
.size(@size; @size); |
||||||
|
} |
||||||
|
|
||||||
|
// Placeholder text |
||||||
|
.placeholder(@color: @input-color-placeholder) { |
||||||
|
&::-moz-placeholder { color: @color; // Firefox |
||||||
|
opacity: 1; } // See https://github.com/twbs/bootstrap/pull/11526 |
||||||
|
&:-ms-input-placeholder { color: @color; } // Internet Explorer 10+ |
||||||
|
&::-webkit-input-placeholder { color: @color; } // Safari and Chrome |
||||||
|
} |
||||||
|
|
||||||
|
// Text overflow |
||||||
|
// Requires inline-block or block for proper styling |
||||||
|
.text-overflow() { |
||||||
|
overflow: hidden; |
||||||
|
text-overflow: ellipsis; |
||||||
|
white-space: nowrap; |
||||||
|
} |
||||||
|
|
||||||
|
// CSS image replacement |
||||||
|
// |
||||||
|
// Heads up! v3 launched with with only `.hide-text()`, but per our pattern for |
||||||
|
// mixins being reused as classes with the same name, this doesn't hold up. As |
||||||
|
// of v3.0.1 we have added `.text-hide()` and deprecated `.hide-text()`. Note |
||||||
|
// that we cannot chain the mixins together in Less, so they are repeated. |
||||||
|
// |
||||||
|
// Source: https://github.com/h5bp/html5-boilerplate/commit/aa0396eae757 |
||||||
|
|
||||||
|
// Deprecated as of v3.0.1 (will be removed in v4) |
||||||
|
.hide-text() { |
||||||
|
font: ~"0/0" a; |
||||||
|
color: transparent; |
||||||
|
text-shadow: none; |
||||||
|
background-color: transparent; |
||||||
|
border: 0; |
||||||
|
} |
||||||
|
// New mixin to use as of v3.0.1 |
||||||
|
.text-hide() { |
||||||
|
.hide-text(); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// CSS3 PROPERTIES |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
// Single side border-radius |
||||||
|
.border-top-radius(@radius) { |
||||||
|
border-top-right-radius: @radius; |
||||||
|
border-top-left-radius: @radius; |
||||||
|
} |
||||||
|
.border-right-radius(@radius) { |
||||||
|
border-bottom-right-radius: @radius; |
||||||
|
border-top-right-radius: @radius; |
||||||
|
} |
||||||
|
.border-bottom-radius(@radius) { |
||||||
|
border-bottom-right-radius: @radius; |
||||||
|
border-bottom-left-radius: @radius; |
||||||
|
} |
||||||
|
.border-left-radius(@radius) { |
||||||
|
border-bottom-left-radius: @radius; |
||||||
|
border-top-left-radius: @radius; |
||||||
|
} |
||||||
|
|
||||||
|
// Drop shadows |
||||||
|
// |
||||||
|
// Note: Deprecated `.box-shadow()` as of v3.1.0 since all of Bootstrap's |
||||||
|
// supported browsers that have box shadow capabilities now support the |
||||||
|
// standard `box-shadow` property. |
||||||
|
.box-shadow(@shadow) { |
||||||
|
-webkit-box-shadow: @shadow; // iOS <4.3 & Android <4.1 |
||||||
|
box-shadow: @shadow; |
||||||
|
} |
||||||
|
|
||||||
|
// Transitions |
||||||
|
.transition(@transition) { |
||||||
|
-webkit-transition: @transition; |
||||||
|
transition: @transition; |
||||||
|
} |
||||||
|
.transition-property(@transition-property) { |
||||||
|
-webkit-transition-property: @transition-property; |
||||||
|
transition-property: @transition-property; |
||||||
|
} |
||||||
|
.transition-delay(@transition-delay) { |
||||||
|
-webkit-transition-delay: @transition-delay; |
||||||
|
transition-delay: @transition-delay; |
||||||
|
} |
||||||
|
.transition-duration(@transition-duration) { |
||||||
|
-webkit-transition-duration: @transition-duration; |
||||||
|
transition-duration: @transition-duration; |
||||||
|
} |
||||||
|
.transition-transform(@transition) { |
||||||
|
-webkit-transition: -webkit-transform @transition; |
||||||
|
-moz-transition: -moz-transform @transition; |
||||||
|
-o-transition: -o-transform @transition; |
||||||
|
transition: transform @transition; |
||||||
|
} |
||||||
|
|
||||||
|
// Transformations |
||||||
|
.rotate(@degrees) { |
||||||
|
-webkit-transform: rotate(@degrees); |
||||||
|
-ms-transform: rotate(@degrees); // IE9 only |
||||||
|
transform: rotate(@degrees); |
||||||
|
} |
||||||
|
.scale(@ratio; @ratio-y...) { |
||||||
|
-webkit-transform: scale(@ratio, @ratio-y); |
||||||
|
-ms-transform: scale(@ratio, @ratio-y); // IE9 only |
||||||
|
transform: scale(@ratio, @ratio-y); |
||||||
|
} |
||||||
|
.translate(@x; @y) { |
||||||
|
-webkit-transform: translate(@x, @y); |
||||||
|
-ms-transform: translate(@x, @y); // IE9 only |
||||||
|
transform: translate(@x, @y); |
||||||
|
} |
||||||
|
.skew(@x; @y) { |
||||||
|
-webkit-transform: skew(@x, @y); |
||||||
|
-ms-transform: skewX(@x) skewY(@y); // See https://github.com/twbs/bootstrap/issues/4885; IE9+ |
||||||
|
transform: skew(@x, @y); |
||||||
|
} |
||||||
|
.translate3d(@x; @y; @z) { |
||||||
|
-webkit-transform: translate3d(@x, @y, @z); |
||||||
|
transform: translate3d(@x, @y, @z); |
||||||
|
} |
||||||
|
|
||||||
|
.rotateX(@degrees) { |
||||||
|
-webkit-transform: rotateX(@degrees); |
||||||
|
-ms-transform: rotateX(@degrees); // IE9 only |
||||||
|
transform: rotateX(@degrees); |
||||||
|
} |
||||||
|
.rotateY(@degrees) { |
||||||
|
-webkit-transform: rotateY(@degrees); |
||||||
|
-ms-transform: rotateY(@degrees); // IE9 only |
||||||
|
transform: rotateY(@degrees); |
||||||
|
} |
||||||
|
.perspective(@perspective) { |
||||||
|
-webkit-perspective: @perspective; |
||||||
|
-moz-perspective: @perspective; |
||||||
|
perspective: @perspective; |
||||||
|
} |
||||||
|
.perspective-origin(@perspective) { |
||||||
|
-webkit-perspective-origin: @perspective; |
||||||
|
-moz-perspective-origin: @perspective; |
||||||
|
perspective-origin: @perspective; |
||||||
|
} |
||||||
|
.transform-origin(@origin) { |
||||||
|
-webkit-transform-origin: @origin; |
||||||
|
-moz-transform-origin: @origin; |
||||||
|
-ms-transform-origin: @origin; // IE9 only |
||||||
|
transform-origin: @origin; |
||||||
|
} |
||||||
|
|
||||||
|
// Animations |
||||||
|
.animation(@animation) { |
||||||
|
-webkit-animation: @animation; |
||||||
|
animation: @animation; |
||||||
|
} |
||||||
|
.animation-name(@name) { |
||||||
|
-webkit-animation-name: @name; |
||||||
|
animation-name: @name; |
||||||
|
} |
||||||
|
.animation-duration(@duration) { |
||||||
|
-webkit-animation-duration: @duration; |
||||||
|
animation-duration: @duration; |
||||||
|
} |
||||||
|
.animation-timing-function(@timing-function) { |
||||||
|
-webkit-animation-timing-function: @timing-function; |
||||||
|
animation-timing-function: @timing-function; |
||||||
|
} |
||||||
|
.animation-delay(@delay) { |
||||||
|
-webkit-animation-delay: @delay; |
||||||
|
animation-delay: @delay; |
||||||
|
} |
||||||
|
.animation-iteration-count(@iteration-count) { |
||||||
|
-webkit-animation-iteration-count: @iteration-count; |
||||||
|
animation-iteration-count: @iteration-count; |
||||||
|
} |
||||||
|
.animation-direction(@direction) { |
||||||
|
-webkit-animation-direction: @direction; |
||||||
|
animation-direction: @direction; |
||||||
|
} |
||||||
|
|
||||||
|
// Backface visibility |
||||||
|
// Prevent browsers from flickering when using CSS 3D transforms. |
||||||
|
// Default value is `visible`, but can be changed to `hidden` |
||||||
|
.backface-visibility(@visibility){ |
||||||
|
-webkit-backface-visibility: @visibility; |
||||||
|
-moz-backface-visibility: @visibility; |
||||||
|
backface-visibility: @visibility; |
||||||
|
} |
||||||
|
|
||||||
|
// Box sizing |
||||||
|
.box-sizing(@boxmodel) { |
||||||
|
-webkit-box-sizing: @boxmodel; |
||||||
|
-moz-box-sizing: @boxmodel; |
||||||
|
box-sizing: @boxmodel; |
||||||
|
} |
||||||
|
|
||||||
|
// User select |
||||||
|
// For selecting text on the page |
||||||
|
.user-select(@select) { |
||||||
|
-webkit-user-select: @select; |
||||||
|
-moz-user-select: @select; |
||||||
|
-ms-user-select: @select; // IE10+ |
||||||
|
user-select: @select; |
||||||
|
} |
||||||
|
|
||||||
|
// Resize anything |
||||||
|
.resizable(@direction) { |
||||||
|
resize: @direction; // Options: horizontal, vertical, both |
||||||
|
overflow: auto; // Safari fix |
||||||
|
} |
||||||
|
|
||||||
|
// CSS3 Content Columns |
||||||
|
.content-columns(@column-count; @column-gap: @grid-gutter-width) { |
||||||
|
-webkit-column-count: @column-count; |
||||||
|
-moz-column-count: @column-count; |
||||||
|
column-count: @column-count; |
||||||
|
-webkit-column-gap: @column-gap; |
||||||
|
-moz-column-gap: @column-gap; |
||||||
|
column-gap: @column-gap; |
||||||
|
} |
||||||
|
|
||||||
|
// Optional hyphenation |
||||||
|
.hyphens(@mode: auto) { |
||||||
|
word-wrap: break-word; |
||||||
|
-webkit-hyphens: @mode; |
||||||
|
-moz-hyphens: @mode; |
||||||
|
-ms-hyphens: @mode; // IE10+ |
||||||
|
-o-hyphens: @mode; |
||||||
|
hyphens: @mode; |
||||||
|
} |
||||||
|
|
||||||
|
// Opacity |
||||||
|
.opacity(@opacity) { |
||||||
|
opacity: @opacity; |
||||||
|
// IE8 filter |
||||||
|
@opacity-ie: (@opacity * 100); |
||||||
|
filter: ~"alpha(opacity=@{opacity-ie})"; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// GRADIENTS |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
#gradient { |
||||||
|
|
||||||
|
// Horizontal gradient, from left to right |
||||||
|
// |
||||||
|
// Creates two color stops, start and end, by specifying a color and position for each color stop. |
||||||
|
// Color stops are not available in IE9 and below. |
||||||
|
.horizontal(@start-color: #555; @end-color: #333; @start-percent: 0%; @end-percent: 100%) { |
||||||
|
background-image: -webkit-linear-gradient(left, color-stop(@start-color @start-percent), color-stop(@end-color @end-percent)); // Safari 5.1-6, Chrome 10+ |
||||||
|
background-image: linear-gradient(to right, @start-color @start-percent, @end-color @end-percent); // Standard, IE10, Firefox 16+, Opera 12.10+, Safari 7+, Chrome 26+ |
||||||
|
background-repeat: repeat-x; |
||||||
|
filter: e(%("progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=1)",argb(@start-color),argb(@end-color))); // IE9 and down |
||||||
|
} |
||||||
|
|
||||||
|
// Vertical gradient, from top to bottom |
||||||
|
// |
||||||
|
// Creates two color stops, start and end, by specifying a color and position for each color stop. |
||||||
|
// Color stops are not available in IE9 and below. |
||||||
|
.vertical(@start-color: #555; @end-color: #333; @start-percent: 0%; @end-percent: 100%) { |
||||||
|
background-image: -webkit-linear-gradient(top, @start-color @start-percent, @end-color @end-percent); // Safari 5.1-6, Chrome 10+ |
||||||
|
background-image: linear-gradient(to bottom, @start-color @start-percent, @end-color @end-percent); // Standard, IE10, Firefox 16+, Opera 12.10+, Safari 7+, Chrome 26+ |
||||||
|
background-repeat: repeat-x; |
||||||
|
filter: e(%("progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=0)",argb(@start-color),argb(@end-color))); // IE9 and down |
||||||
|
} |
||||||
|
|
||||||
|
.directional(@start-color: #555; @end-color: #333; @deg: 45deg) { |
||||||
|
background-repeat: repeat-x; |
||||||
|
background-image: -webkit-linear-gradient(@deg, @start-color, @end-color); // Safari 5.1-6, Chrome 10+ |
||||||
|
background-image: linear-gradient(@deg, @start-color, @end-color); // Standard, IE10, Firefox 16+, Opera 12.10+, Safari 7+, Chrome 26+ |
||||||
|
} |
||||||
|
.horizontal-three-colors(@start-color: #00b3ee; @mid-color: #7a43b6; @color-stop: 50%; @end-color: #c3325f) { |
||||||
|
background-image: -webkit-linear-gradient(left, @start-color, @mid-color @color-stop, @end-color); |
||||||
|
background-image: linear-gradient(to right, @start-color, @mid-color @color-stop, @end-color); |
||||||
|
background-repeat: no-repeat; |
||||||
|
filter: e(%("progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=1)",argb(@start-color),argb(@end-color))); // IE9 and down, gets no color-stop at all for proper fallback |
||||||
|
} |
||||||
|
.vertical-three-colors(@start-color: #00b3ee; @mid-color: #7a43b6; @color-stop: 50%; @end-color: #c3325f) { |
||||||
|
background-image: -webkit-linear-gradient(@start-color, @mid-color @color-stop, @end-color); |
||||||
|
background-image: linear-gradient(@start-color, @mid-color @color-stop, @end-color); |
||||||
|
background-repeat: no-repeat; |
||||||
|
filter: e(%("progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=0)",argb(@start-color),argb(@end-color))); // IE9 and down, gets no color-stop at all for proper fallback |
||||||
|
} |
||||||
|
.radial(@inner-color: #555; @outer-color: #333) { |
||||||
|
background-image: -webkit-radial-gradient(circle, @inner-color, @outer-color); |
||||||
|
background-image: radial-gradient(circle, @inner-color, @outer-color); |
||||||
|
background-repeat: no-repeat; |
||||||
|
} |
||||||
|
.striped(@color: rgba(255,255,255,.15); @angle: 45deg) { |
||||||
|
background-image: -webkit-linear-gradient(@angle, @color 25%, transparent 25%, transparent 50%, @color 50%, @color 75%, transparent 75%, transparent); |
||||||
|
background-image: linear-gradient(@angle, @color 25%, transparent 25%, transparent 50%, @color 50%, @color 75%, transparent 75%, transparent); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Reset filters for IE |
||||||
|
// |
||||||
|
// When you need to remove a gradient background, do not forget to use this to reset |
||||||
|
// the IE filter for IE9 and below. |
||||||
|
.reset-filter() { |
||||||
|
filter: e(%("progid:DXImageTransform.Microsoft.gradient(enabled = false)")); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// Retina images |
||||||
|
// |
||||||
|
// Short retina mixin for setting background-image and -size |
||||||
|
|
||||||
|
.img-retina(@file-1x; @file-2x; @width-1x; @height-1x) { |
||||||
|
background-image: url("@{file-1x}"); |
||||||
|
|
||||||
|
@media |
||||||
|
only screen and (-webkit-min-device-pixel-ratio: 2), |
||||||
|
only screen and ( min--moz-device-pixel-ratio: 2), |
||||||
|
only screen and ( -o-min-device-pixel-ratio: 2/1), |
||||||
|
only screen and ( min-device-pixel-ratio: 2), |
||||||
|
only screen and ( min-resolution: 192dpi), |
||||||
|
only screen and ( min-resolution: 2dppx) { |
||||||
|
background-image: url("@{file-2x}"); |
||||||
|
background-size: @width-1x @height-1x; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Responsive image |
||||||
|
// |
||||||
|
// Keep images from scaling beyond the width of their parents. |
||||||
|
|
||||||
|
.img-responsive(@display: block) { |
||||||
|
display: @display; |
||||||
|
max-width: 100%; // Part 1: Set a maximum relative to the parent |
||||||
|
height: auto; // Part 2: Scale the height according to the width, otherwise you get stretching |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// COMPONENT MIXINS |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
// Horizontal dividers |
||||||
|
// ------------------------- |
||||||
|
// Dividers (basically an hr) within dropdowns and nav lists |
||||||
|
.nav-divider(@color: #e5e5e5) { |
||||||
|
height: 1px; |
||||||
|
margin: ((@line-height-computed / 2) - 1) 0; |
||||||
|
overflow: hidden; |
||||||
|
background-color: @color; |
||||||
|
} |
||||||
|
|
||||||
|
// Panels |
||||||
|
// ------------------------- |
||||||
|
.panel-variant(@border; @heading-text-color; @heading-bg-color; @heading-border) { |
||||||
|
border-color: @border; |
||||||
|
|
||||||
|
& > .panel-heading { |
||||||
|
color: @heading-text-color; |
||||||
|
background-color: @heading-bg-color; |
||||||
|
border-color: @heading-border; |
||||||
|
|
||||||
|
+ .panel-collapse .panel-body { |
||||||
|
border-top-color: @border; |
||||||
|
} |
||||||
|
} |
||||||
|
& > .panel-footer { |
||||||
|
+ .panel-collapse .panel-body { |
||||||
|
border-bottom-color: @border; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Alerts |
||||||
|
// ------------------------- |
||||||
|
.alert-variant(@background; @border; @text-color) { |
||||||
|
background-color: @background; |
||||||
|
border-color: @border; |
||||||
|
color: @text-color; |
||||||
|
|
||||||
|
hr { |
||||||
|
border-top-color: darken(@border, 5%); |
||||||
|
} |
||||||
|
.alert-link { |
||||||
|
color: darken(@text-color, 10%); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Tables |
||||||
|
// ------------------------- |
||||||
|
.table-row-variant(@state; @background) { |
||||||
|
// Exact selectors below required to override `.table-striped` and prevent |
||||||
|
// inheritance to nested tables. |
||||||
|
.table > thead > tr, |
||||||
|
.table > tbody > tr, |
||||||
|
.table > tfoot > tr { |
||||||
|
> td.@{state}, |
||||||
|
> th.@{state}, |
||||||
|
&.@{state} > td, |
||||||
|
&.@{state} > th { |
||||||
|
background-color: @background; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Hover states for `.table-hover` |
||||||
|
// Note: this is not available for cells or rows within `thead` or `tfoot`. |
||||||
|
.table-hover > tbody > tr { |
||||||
|
> td.@{state}:hover, |
||||||
|
> th.@{state}:hover, |
||||||
|
&.@{state}:hover > td, |
||||||
|
&.@{state}:hover > th { |
||||||
|
background-color: darken(@background, 5%); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// List Groups |
||||||
|
// ------------------------- |
||||||
|
.list-group-item-variant(@state; @background; @color) { |
||||||
|
.list-group-item-@{state} { |
||||||
|
color: @color; |
||||||
|
background-color: @background; |
||||||
|
|
||||||
|
a& { |
||||||
|
color: @color; |
||||||
|
|
||||||
|
.list-group-item-heading { color: inherit; } |
||||||
|
|
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @color; |
||||||
|
background-color: darken(@background, 5%); |
||||||
|
} |
||||||
|
&.active, |
||||||
|
&.active:hover, |
||||||
|
&.active:focus { |
||||||
|
color: #fff; |
||||||
|
background-color: @color; |
||||||
|
border-color: @color; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Button variants |
||||||
|
// ------------------------- |
||||||
|
// Easily pump out default styles, as well as :hover, :focus, :active, |
||||||
|
// and disabled options for all buttons |
||||||
|
.button-variant(@color; @background; @border) { |
||||||
|
color: @color; |
||||||
|
background-color: @background; |
||||||
|
border-color: @border; |
||||||
|
|
||||||
|
&:hover, |
||||||
|
&:focus, |
||||||
|
&:active, |
||||||
|
&.active, |
||||||
|
.open .dropdown-toggle& { |
||||||
|
color: @color; |
||||||
|
background-color: darken(@background, 8%); |
||||||
|
border-color: darken(@border, 12%); |
||||||
|
} |
||||||
|
&:active, |
||||||
|
&.active, |
||||||
|
.open .dropdown-toggle& { |
||||||
|
background-image: none; |
||||||
|
} |
||||||
|
&.disabled, |
||||||
|
&[disabled], |
||||||
|
fieldset[disabled] & { |
||||||
|
&, |
||||||
|
&:hover, |
||||||
|
&:focus, |
||||||
|
&:active, |
||||||
|
&.active { |
||||||
|
background-color: @background; |
||||||
|
border-color: @border; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
.badge { |
||||||
|
color: @background; |
||||||
|
background-color: @color; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Button sizes |
||||||
|
// ------------------------- |
||||||
|
.button-size(@padding-vertical; @padding-horizontal; @font-size; @line-height; @border-radius) { |
||||||
|
padding: @padding-vertical @padding-horizontal; |
||||||
|
font-size: @font-size; |
||||||
|
line-height: @line-height; |
||||||
|
border-radius: @border-radius; |
||||||
|
} |
||||||
|
|
||||||
|
// Pagination |
||||||
|
// ------------------------- |
||||||
|
.pagination-size(@padding-vertical; @padding-horizontal; @font-size; @border-radius) { |
||||||
|
> li { |
||||||
|
> a, |
||||||
|
> span { |
||||||
|
padding: @padding-vertical @padding-horizontal; |
||||||
|
font-size: @font-size; |
||||||
|
} |
||||||
|
&:first-child { |
||||||
|
> a, |
||||||
|
> span { |
||||||
|
.border-left-radius(@border-radius); |
||||||
|
} |
||||||
|
} |
||||||
|
&:last-child { |
||||||
|
> a, |
||||||
|
> span { |
||||||
|
.border-right-radius(@border-radius); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Labels |
||||||
|
// ------------------------- |
||||||
|
.label-variant(@color) { |
||||||
|
background-color: @color; |
||||||
|
&[href] { |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
background-color: darken(@color, 10%); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Contextual backgrounds |
||||||
|
// ------------------------- |
||||||
|
.bg-variant(@color) { |
||||||
|
background-color: @color; |
||||||
|
a&:hover { |
||||||
|
background-color: darken(@color, 10%); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Typography |
||||||
|
// ------------------------- |
||||||
|
.text-emphasis-variant(@color) { |
||||||
|
color: @color; |
||||||
|
a&:hover { |
||||||
|
color: darken(@color, 10%); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Navbar vertical align |
||||||
|
// ------------------------- |
||||||
|
// Vertically center elements in the navbar. |
||||||
|
// Example: an element has a height of 30px, so write out `.navbar-vertical-align(30px);` to calculate the appropriate top margin. |
||||||
|
.navbar-vertical-align(@element-height) { |
||||||
|
margin-top: ((@navbar-height - @element-height) / 2); |
||||||
|
margin-bottom: ((@navbar-height - @element-height) / 2); |
||||||
|
} |
||||||
|
|
||||||
|
// Progress bars |
||||||
|
// ------------------------- |
||||||
|
.progress-bar-variant(@color) { |
||||||
|
background-color: @color; |
||||||
|
.progress-striped & { |
||||||
|
#gradient > .striped(); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Responsive utilities |
||||||
|
// ------------------------- |
||||||
|
// More easily include all the states for responsive-utilities.less. |
||||||
|
.responsive-visibility() { |
||||||
|
display: block !important; |
||||||
|
table& { display: table; } |
||||||
|
tr& { display: table-row !important; } |
||||||
|
th&, |
||||||
|
td& { display: table-cell !important; } |
||||||
|
} |
||||||
|
|
||||||
|
.responsive-invisibility() { |
||||||
|
display: none !important; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Grid System |
||||||
|
// ----------- |
||||||
|
|
||||||
|
// Centered container element |
||||||
|
.container-fixed() { |
||||||
|
margin-right: auto; |
||||||
|
margin-left: auto; |
||||||
|
padding-left: (@grid-gutter-width / 2); |
||||||
|
padding-right: (@grid-gutter-width / 2); |
||||||
|
&:extend(.clearfix all); |
||||||
|
} |
||||||
|
|
||||||
|
// Creates a wrapper for a series of columns |
||||||
|
.make-row(@gutter: @grid-gutter-width) { |
||||||
|
margin-left: (@gutter / -2); |
||||||
|
margin-right: (@gutter / -2); |
||||||
|
&:extend(.clearfix all); |
||||||
|
} |
||||||
|
|
||||||
|
// Generate the extra small columns |
||||||
|
.make-xs-column(@columns; @gutter: @grid-gutter-width) { |
||||||
|
position: relative; |
||||||
|
float: left; |
||||||
|
width: percentage((@columns / @grid-columns)); |
||||||
|
min-height: 1px; |
||||||
|
padding-left: (@gutter / 2); |
||||||
|
padding-right: (@gutter / 2); |
||||||
|
} |
||||||
|
.make-xs-column-offset(@columns) { |
||||||
|
@media (min-width: @screen-xs-min) { |
||||||
|
margin-left: percentage((@columns / @grid-columns)); |
||||||
|
} |
||||||
|
} |
||||||
|
.make-xs-column-push(@columns) { |
||||||
|
@media (min-width: @screen-xs-min) { |
||||||
|
left: percentage((@columns / @grid-columns)); |
||||||
|
} |
||||||
|
} |
||||||
|
.make-xs-column-pull(@columns) { |
||||||
|
@media (min-width: @screen-xs-min) { |
||||||
|
right: percentage((@columns / @grid-columns)); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Generate the small columns |
||||||
|
.make-sm-column(@columns; @gutter: @grid-gutter-width) { |
||||||
|
position: relative; |
||||||
|
min-height: 1px; |
||||||
|
padding-left: (@gutter / 2); |
||||||
|
padding-right: (@gutter / 2); |
||||||
|
|
||||||
|
@media (min-width: @screen-sm-min) { |
||||||
|
float: left; |
||||||
|
width: percentage((@columns / @grid-columns)); |
||||||
|
} |
||||||
|
} |
||||||
|
.make-sm-column-offset(@columns) { |
||||||
|
@media (min-width: @screen-sm-min) { |
||||||
|
margin-left: percentage((@columns / @grid-columns)); |
||||||
|
} |
||||||
|
} |
||||||
|
.make-sm-column-push(@columns) { |
||||||
|
@media (min-width: @screen-sm-min) { |
||||||
|
left: percentage((@columns / @grid-columns)); |
||||||
|
} |
||||||
|
} |
||||||
|
.make-sm-column-pull(@columns) { |
||||||
|
@media (min-width: @screen-sm-min) { |
||||||
|
right: percentage((@columns / @grid-columns)); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Generate the medium columns |
||||||
|
.make-md-column(@columns; @gutter: @grid-gutter-width) { |
||||||
|
position: relative; |
||||||
|
min-height: 1px; |
||||||
|
padding-left: (@gutter / 2); |
||||||
|
padding-right: (@gutter / 2); |
||||||
|
|
||||||
|
@media (min-width: @screen-md-min) { |
||||||
|
float: left; |
||||||
|
width: percentage((@columns / @grid-columns)); |
||||||
|
} |
||||||
|
} |
||||||
|
.make-md-column-offset(@columns) { |
||||||
|
@media (min-width: @screen-md-min) { |
||||||
|
margin-left: percentage((@columns / @grid-columns)); |
||||||
|
} |
||||||
|
} |
||||||
|
.make-md-column-push(@columns) { |
||||||
|
@media (min-width: @screen-md-min) { |
||||||
|
left: percentage((@columns / @grid-columns)); |
||||||
|
} |
||||||
|
} |
||||||
|
.make-md-column-pull(@columns) { |
||||||
|
@media (min-width: @screen-md-min) { |
||||||
|
right: percentage((@columns / @grid-columns)); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Generate the large columns |
||||||
|
.make-lg-column(@columns; @gutter: @grid-gutter-width) { |
||||||
|
position: relative; |
||||||
|
min-height: 1px; |
||||||
|
padding-left: (@gutter / 2); |
||||||
|
padding-right: (@gutter / 2); |
||||||
|
|
||||||
|
@media (min-width: @screen-lg-min) { |
||||||
|
float: left; |
||||||
|
width: percentage((@columns / @grid-columns)); |
||||||
|
} |
||||||
|
} |
||||||
|
.make-lg-column-offset(@columns) { |
||||||
|
@media (min-width: @screen-lg-min) { |
||||||
|
margin-left: percentage((@columns / @grid-columns)); |
||||||
|
} |
||||||
|
} |
||||||
|
.make-lg-column-push(@columns) { |
||||||
|
@media (min-width: @screen-lg-min) { |
||||||
|
left: percentage((@columns / @grid-columns)); |
||||||
|
} |
||||||
|
} |
||||||
|
.make-lg-column-pull(@columns) { |
||||||
|
@media (min-width: @screen-lg-min) { |
||||||
|
right: percentage((@columns / @grid-columns)); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Framework grid generation |
||||||
|
// |
||||||
|
// Used only by Bootstrap to generate the correct number of grid classes given |
||||||
|
// any value of `@grid-columns`. |
||||||
|
|
||||||
|
.make-grid-columns() { |
||||||
|
// Common styles for all sizes of grid columns, widths 1-12 |
||||||
|
.col(@index) when (@index = 1) { // initial |
||||||
|
@item: ~".col-xs-@{index}, .col-sm-@{index}, .col-md-@{index}, .col-lg-@{index}"; |
||||||
|
.col((@index + 1), @item); |
||||||
|
} |
||||||
|
.col(@index, @list) when (@index =< @grid-columns) { // general; "=<" isn't a typo |
||||||
|
@item: ~".col-xs-@{index}, .col-sm-@{index}, .col-md-@{index}, .col-lg-@{index}"; |
||||||
|
.col((@index + 1), ~"@{list}, @{item}"); |
||||||
|
} |
||||||
|
.col(@index, @list) when (@index > @grid-columns) { // terminal |
||||||
|
@{list} { |
||||||
|
position: relative; |
||||||
|
// Prevent columns from collapsing when empty |
||||||
|
min-height: 1px; |
||||||
|
// Inner gutter via padding |
||||||
|
padding-left: (@grid-gutter-width / 2); |
||||||
|
padding-right: (@grid-gutter-width / 2); |
||||||
|
} |
||||||
|
} |
||||||
|
.col(1); // kickstart it |
||||||
|
} |
||||||
|
|
||||||
|
.float-grid-columns(@class) { |
||||||
|
.col(@index) when (@index = 1) { // initial |
||||||
|
@item: ~".col-@{class}-@{index}"; |
||||||
|
.col((@index + 1), @item); |
||||||
|
} |
||||||
|
.col(@index, @list) when (@index =< @grid-columns) { // general |
||||||
|
@item: ~".col-@{class}-@{index}"; |
||||||
|
.col((@index + 1), ~"@{list}, @{item}"); |
||||||
|
} |
||||||
|
.col(@index, @list) when (@index > @grid-columns) { // terminal |
||||||
|
@{list} { |
||||||
|
float: left; |
||||||
|
} |
||||||
|
} |
||||||
|
.col(1); // kickstart it |
||||||
|
} |
||||||
|
|
||||||
|
.calc-grid-column(@index, @class, @type) when (@type = width) and (@index > 0) { |
||||||
|
.col-@{class}-@{index} { |
||||||
|
width: percentage((@index / @grid-columns)); |
||||||
|
} |
||||||
|
} |
||||||
|
.calc-grid-column(@index, @class, @type) when (@type = push) { |
||||||
|
.col-@{class}-push-@{index} { |
||||||
|
left: percentage((@index / @grid-columns)); |
||||||
|
} |
||||||
|
} |
||||||
|
.calc-grid-column(@index, @class, @type) when (@type = pull) { |
||||||
|
.col-@{class}-pull-@{index} { |
||||||
|
right: percentage((@index / @grid-columns)); |
||||||
|
} |
||||||
|
} |
||||||
|
.calc-grid-column(@index, @class, @type) when (@type = offset) { |
||||||
|
.col-@{class}-offset-@{index} { |
||||||
|
margin-left: percentage((@index / @grid-columns)); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Basic looping in LESS |
||||||
|
.loop-grid-columns(@index, @class, @type) when (@index >= 0) { |
||||||
|
.calc-grid-column(@index, @class, @type); |
||||||
|
// next iteration |
||||||
|
.loop-grid-columns((@index - 1), @class, @type); |
||||||
|
} |
||||||
|
|
||||||
|
// Create grid for specific class |
||||||
|
.make-grid(@class) { |
||||||
|
.float-grid-columns(@class); |
||||||
|
.loop-grid-columns(@grid-columns, @class, width); |
||||||
|
.loop-grid-columns(@grid-columns, @class, pull); |
||||||
|
.loop-grid-columns(@grid-columns, @class, push); |
||||||
|
.loop-grid-columns(@grid-columns, @class, offset); |
||||||
|
} |
||||||
|
|
||||||
|
// Form validation states |
||||||
|
// |
||||||
|
// Used in forms.less to generate the form validation CSS for warnings, errors, |
||||||
|
// and successes. |
||||||
|
|
||||||
|
.form-control-validation(@text-color: #555; @border-color: #ccc; @background-color: #f5f5f5) { |
||||||
|
// Color the label and help text |
||||||
|
.help-block, |
||||||
|
.control-label, |
||||||
|
.radio, |
||||||
|
.checkbox, |
||||||
|
.radio-inline, |
||||||
|
.checkbox-inline { |
||||||
|
color: @text-color; |
||||||
|
} |
||||||
|
// Set the border and box shadow on specific inputs to match |
||||||
|
.form-control { |
||||||
|
border-color: @border-color; |
||||||
|
.box-shadow(inset 0 1px 1px rgba(0,0,0,.075)); // Redeclare so transitions work |
||||||
|
&:focus { |
||||||
|
border-color: darken(@border-color, 10%); |
||||||
|
@shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 6px lighten(@border-color, 20%); |
||||||
|
.box-shadow(@shadow); |
||||||
|
} |
||||||
|
} |
||||||
|
// Set validation states also for addons |
||||||
|
.input-group-addon { |
||||||
|
color: @text-color; |
||||||
|
border-color: @border-color; |
||||||
|
background-color: @background-color; |
||||||
|
} |
||||||
|
// Optional feedback icon |
||||||
|
.form-control-feedback { |
||||||
|
color: @text-color; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Form control focus state |
||||||
|
// |
||||||
|
// Generate a customized focus state and for any input with the specified color, |
||||||
|
// which defaults to the `@input-focus-border` variable. |
||||||
|
// |
||||||
|
// We highly encourage you to not customize the default value, but instead use |
||||||
|
// this to tweak colors on an as-needed basis. This aesthetic change is based on |
||||||
|
// WebKit's default styles, but applicable to a wider range of browsers. Its |
||||||
|
// usability and accessibility should be taken into account with any change. |
||||||
|
// |
||||||
|
// Example usage: change the default blue border and shadow to white for better |
||||||
|
// contrast against a dark gray background. |
||||||
|
|
||||||
|
.form-control-focus(@color: @input-border-focus) { |
||||||
|
@color-rgba: rgba(red(@color), green(@color), blue(@color), .6); |
||||||
|
&:focus { |
||||||
|
border-color: @color; |
||||||
|
outline: 0; |
||||||
|
.box-shadow(~"inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px @{color-rgba}"); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Form control sizing |
||||||
|
// |
||||||
|
// Relative text size, padding, and border-radii changes for form controls. For |
||||||
|
// horizontal sizing, wrap controls in the predefined grid classes. `<select>` |
||||||
|
// element gets special love because it's special, and that's a fact! |
||||||
|
|
||||||
|
.input-size(@input-height; @padding-vertical; @padding-horizontal; @font-size; @line-height; @border-radius) { |
||||||
|
height: @input-height; |
||||||
|
padding: @padding-vertical @padding-horizontal; |
||||||
|
font-size: @font-size; |
||||||
|
line-height: @line-height; |
||||||
|
border-radius: @border-radius; |
||||||
|
|
||||||
|
select& { |
||||||
|
height: @input-height; |
||||||
|
line-height: @input-height; |
||||||
|
} |
||||||
|
|
||||||
|
textarea&, |
||||||
|
select[multiple]& { |
||||||
|
height: auto; |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,139 @@ |
|||||||
|
// |
||||||
|
// Modals |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
// .modal-open - body class for killing the scroll |
||||||
|
// .modal - container to scroll within |
||||||
|
// .modal-dialog - positioning shell for the actual modal |
||||||
|
// .modal-content - actual modal w/ bg and corners and shit |
||||||
|
|
||||||
|
// Kill the scroll on the body |
||||||
|
.modal-open { |
||||||
|
overflow: hidden; |
||||||
|
} |
||||||
|
|
||||||
|
// Container that the modal scrolls within |
||||||
|
.modal { |
||||||
|
display: none; |
||||||
|
overflow: auto; |
||||||
|
overflow-y: scroll; |
||||||
|
position: fixed; |
||||||
|
top: 0; |
||||||
|
right: 0; |
||||||
|
bottom: 0; |
||||||
|
left: 0; |
||||||
|
z-index: @zindex-modal; |
||||||
|
-webkit-overflow-scrolling: touch; |
||||||
|
|
||||||
|
// Prevent Chrome on Windows from adding a focus outline. For details, see |
||||||
|
// https://github.com/twbs/bootstrap/pull/10951. |
||||||
|
outline: 0; |
||||||
|
|
||||||
|
// When fading in the modal, animate it to slide down |
||||||
|
&.fade .modal-dialog { |
||||||
|
.translate(0, -25%); |
||||||
|
.transition-transform(~"0.3s ease-out"); |
||||||
|
} |
||||||
|
&.in .modal-dialog { .translate(0, 0)} |
||||||
|
} |
||||||
|
|
||||||
|
// Shell div to position the modal with bottom padding |
||||||
|
.modal-dialog { |
||||||
|
position: relative; |
||||||
|
width: auto; |
||||||
|
margin: 10px; |
||||||
|
} |
||||||
|
|
||||||
|
// Actual modal |
||||||
|
.modal-content { |
||||||
|
position: relative; |
||||||
|
background-color: @modal-content-bg; |
||||||
|
border: 1px solid @modal-content-fallback-border-color; //old browsers fallback (ie8 etc) |
||||||
|
border: 1px solid @modal-content-border-color; |
||||||
|
border-radius: @border-radius-large; |
||||||
|
.box-shadow(0 3px 9px rgba(0,0,0,.5)); |
||||||
|
background-clip: padding-box; |
||||||
|
// Remove focus outline from opened modal |
||||||
|
outline: none; |
||||||
|
} |
||||||
|
|
||||||
|
// Modal background |
||||||
|
.modal-backdrop { |
||||||
|
position: fixed; |
||||||
|
top: 0; |
||||||
|
right: 0; |
||||||
|
bottom: 0; |
||||||
|
left: 0; |
||||||
|
z-index: @zindex-modal-background; |
||||||
|
background-color: @modal-backdrop-bg; |
||||||
|
// Fade for backdrop |
||||||
|
&.fade { .opacity(0); } |
||||||
|
&.in { .opacity(@modal-backdrop-opacity); } |
||||||
|
} |
||||||
|
|
||||||
|
// Modal header |
||||||
|
// Top section of the modal w/ title and dismiss |
||||||
|
.modal-header { |
||||||
|
padding: @modal-title-padding; |
||||||
|
border-bottom: 1px solid @modal-header-border-color; |
||||||
|
min-height: (@modal-title-padding + @modal-title-line-height); |
||||||
|
} |
||||||
|
// Close icon |
||||||
|
.modal-header .close { |
||||||
|
margin-top: -2px; |
||||||
|
} |
||||||
|
|
||||||
|
// Title text within header |
||||||
|
.modal-title { |
||||||
|
margin: 0; |
||||||
|
line-height: @modal-title-line-height; |
||||||
|
} |
||||||
|
|
||||||
|
// Modal body |
||||||
|
// Where all modal content resides (sibling of .modal-header and .modal-footer) |
||||||
|
.modal-body { |
||||||
|
position: relative; |
||||||
|
padding: @modal-inner-padding; |
||||||
|
} |
||||||
|
|
||||||
|
// Footer (for actions) |
||||||
|
.modal-footer { |
||||||
|
margin-top: 15px; |
||||||
|
padding: (@modal-inner-padding - 1) @modal-inner-padding @modal-inner-padding; |
||||||
|
text-align: right; // right align buttons |
||||||
|
border-top: 1px solid @modal-footer-border-color; |
||||||
|
&:extend(.clearfix all); // clear it in case folks use .pull-* classes on buttons |
||||||
|
|
||||||
|
// Properly space out buttons |
||||||
|
.btn + .btn { |
||||||
|
margin-left: 5px; |
||||||
|
margin-bottom: 0; // account for input[type="submit"] which gets the bottom margin like all other inputs |
||||||
|
} |
||||||
|
// but override that for button groups |
||||||
|
.btn-group .btn + .btn { |
||||||
|
margin-left: -1px; |
||||||
|
} |
||||||
|
// and override it for block buttons as well |
||||||
|
.btn-block + .btn-block { |
||||||
|
margin-left: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Scale up the modal |
||||||
|
@media (min-width: @screen-sm-min) { |
||||||
|
// Automatically set modal's width for larger viewports |
||||||
|
.modal-dialog { |
||||||
|
width: @modal-md; |
||||||
|
margin: 30px auto; |
||||||
|
} |
||||||
|
.modal-content { |
||||||
|
.box-shadow(0 5px 15px rgba(0,0,0,.5)); |
||||||
|
} |
||||||
|
|
||||||
|
// Modal sizes |
||||||
|
.modal-sm { width: @modal-sm; } |
||||||
|
} |
||||||
|
|
||||||
|
@media (min-width: @screen-md-min) { |
||||||
|
.modal-lg { width: @modal-lg; } |
||||||
|
} |
@ -0,0 +1,616 @@ |
|||||||
|
// |
||||||
|
// Navbars |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// Wrapper and base class |
||||||
|
// |
||||||
|
// Provide a static navbar from which we expand to create full-width, fixed, and |
||||||
|
// other navbar variations. |
||||||
|
|
||||||
|
.navbar { |
||||||
|
position: relative; |
||||||
|
min-height: @navbar-height; // Ensure a navbar always shows (e.g., without a .navbar-brand in collapsed mode) |
||||||
|
margin-bottom: @navbar-margin-bottom; |
||||||
|
border: 1px solid transparent; |
||||||
|
|
||||||
|
// Prevent floats from breaking the navbar |
||||||
|
&:extend(.clearfix all); |
||||||
|
|
||||||
|
@media (min-width: @grid-float-breakpoint) { |
||||||
|
border-radius: @navbar-border-radius; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Navbar heading |
||||||
|
// |
||||||
|
// Groups `.navbar-brand` and `.navbar-toggle` into a single component for easy |
||||||
|
// styling of responsive aspects. |
||||||
|
|
||||||
|
.navbar-header { |
||||||
|
&:extend(.clearfix all); |
||||||
|
|
||||||
|
@media (min-width: @grid-float-breakpoint) { |
||||||
|
float: left; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Navbar collapse (body) |
||||||
|
// |
||||||
|
// Group your navbar content into this for easy collapsing and expanding across |
||||||
|
// various device sizes. By default, this content is collapsed when <768px, but |
||||||
|
// will expand past that for a horizontal display. |
||||||
|
// |
||||||
|
// To start (on mobile devices) the navbar links, forms, and buttons are stacked |
||||||
|
// vertically and include a `max-height` to overflow in case you have too much |
||||||
|
// content for the user's viewport. |
||||||
|
|
||||||
|
.navbar-collapse { |
||||||
|
max-height: @navbar-collapse-max-height; |
||||||
|
overflow-x: visible; |
||||||
|
padding-right: @navbar-padding-horizontal; |
||||||
|
padding-left: @navbar-padding-horizontal; |
||||||
|
border-top: 1px solid transparent; |
||||||
|
box-shadow: inset 0 1px 0 rgba(255,255,255,.1); |
||||||
|
&:extend(.clearfix all); |
||||||
|
-webkit-overflow-scrolling: touch; |
||||||
|
|
||||||
|
&.in { |
||||||
|
overflow-y: auto; |
||||||
|
} |
||||||
|
|
||||||
|
@media (min-width: @grid-float-breakpoint) { |
||||||
|
width: auto; |
||||||
|
border-top: 0; |
||||||
|
box-shadow: none; |
||||||
|
|
||||||
|
&.collapse { |
||||||
|
display: block !important; |
||||||
|
height: auto !important; |
||||||
|
padding-bottom: 0; // Override default setting |
||||||
|
overflow: visible !important; |
||||||
|
} |
||||||
|
|
||||||
|
&.in { |
||||||
|
overflow-y: visible; |
||||||
|
} |
||||||
|
|
||||||
|
// Undo the collapse side padding for navbars with containers to ensure |
||||||
|
// alignment of right-aligned contents. |
||||||
|
.navbar-fixed-top &, |
||||||
|
.navbar-static-top &, |
||||||
|
.navbar-fixed-bottom & { |
||||||
|
padding-left: 0; |
||||||
|
padding-right: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Both navbar header and collapse |
||||||
|
// |
||||||
|
// When a container is present, change the behavior of the header and collapse. |
||||||
|
|
||||||
|
.container, |
||||||
|
.container-fluid { |
||||||
|
> .navbar-header, |
||||||
|
> .navbar-collapse { |
||||||
|
margin-right: -@navbar-padding-horizontal; |
||||||
|
margin-left: -@navbar-padding-horizontal; |
||||||
|
|
||||||
|
@media (min-width: @grid-float-breakpoint) { |
||||||
|
margin-right: 0; |
||||||
|
margin-left: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// |
||||||
|
// Navbar alignment options |
||||||
|
// |
||||||
|
// Display the navbar across the entirety of the page or fixed it to the top or |
||||||
|
// bottom of the page. |
||||||
|
|
||||||
|
// Static top (unfixed, but 100% wide) navbar |
||||||
|
.navbar-static-top { |
||||||
|
z-index: @zindex-navbar; |
||||||
|
border-width: 0 0 1px; |
||||||
|
|
||||||
|
@media (min-width: @grid-float-breakpoint) { |
||||||
|
border-radius: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Fix the top/bottom navbars when screen real estate supports it |
||||||
|
.navbar-fixed-top, |
||||||
|
.navbar-fixed-bottom { |
||||||
|
position: fixed; |
||||||
|
right: 0; |
||||||
|
left: 0; |
||||||
|
z-index: @zindex-navbar-fixed; |
||||||
|
|
||||||
|
// Undo the rounded corners |
||||||
|
@media (min-width: @grid-float-breakpoint) { |
||||||
|
border-radius: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
.navbar-fixed-top { |
||||||
|
top: 0; |
||||||
|
border-width: 0 0 1px; |
||||||
|
} |
||||||
|
.navbar-fixed-bottom { |
||||||
|
bottom: 0; |
||||||
|
margin-bottom: 0; // override .navbar defaults |
||||||
|
border-width: 1px 0 0; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Brand/project name |
||||||
|
|
||||||
|
.navbar-brand { |
||||||
|
float: left; |
||||||
|
padding: @navbar-padding-vertical @navbar-padding-horizontal; |
||||||
|
font-size: @font-size-large; |
||||||
|
line-height: @line-height-computed; |
||||||
|
height: @navbar-height; |
||||||
|
|
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
text-decoration: none; |
||||||
|
} |
||||||
|
|
||||||
|
@media (min-width: @grid-float-breakpoint) { |
||||||
|
.navbar > .container &, |
||||||
|
.navbar > .container-fluid & { |
||||||
|
margin-left: -@navbar-padding-horizontal; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Navbar toggle |
||||||
|
// |
||||||
|
// Custom button for toggling the `.navbar-collapse`, powered by the collapse |
||||||
|
// JavaScript plugin. |
||||||
|
|
||||||
|
.navbar-toggle { |
||||||
|
position: relative; |
||||||
|
float: right; |
||||||
|
margin-right: @navbar-padding-horizontal; |
||||||
|
padding: 9px 10px; |
||||||
|
.navbar-vertical-align(34px); |
||||||
|
background-color: transparent; |
||||||
|
background-image: none; // Reset unusual Firefox-on-Android default style; see https://github.com/necolas/normalize.css/issues/214 |
||||||
|
border: 1px solid transparent; |
||||||
|
border-radius: @border-radius-base; |
||||||
|
|
||||||
|
// We remove the `outline` here, but later compensate by attaching `:hover` |
||||||
|
// styles to `:focus`. |
||||||
|
&:focus { |
||||||
|
outline: none; |
||||||
|
} |
||||||
|
|
||||||
|
// Bars |
||||||
|
.icon-bar { |
||||||
|
display: block; |
||||||
|
width: 22px; |
||||||
|
height: 2px; |
||||||
|
border-radius: 1px; |
||||||
|
} |
||||||
|
.icon-bar + .icon-bar { |
||||||
|
margin-top: 4px; |
||||||
|
} |
||||||
|
|
||||||
|
@media (min-width: @grid-float-breakpoint) { |
||||||
|
display: none; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Navbar nav links |
||||||
|
// |
||||||
|
// Builds on top of the `.nav` components with its own modifier class to make |
||||||
|
// the nav the full height of the horizontal nav (above 768px). |
||||||
|
|
||||||
|
.navbar-nav { |
||||||
|
margin: (@navbar-padding-vertical / 2) -@navbar-padding-horizontal; |
||||||
|
|
||||||
|
> li > a { |
||||||
|
padding-top: 10px; |
||||||
|
padding-bottom: 10px; |
||||||
|
line-height: @line-height-computed; |
||||||
|
} |
||||||
|
|
||||||
|
@media (max-width: @grid-float-breakpoint-max) { |
||||||
|
// Dropdowns get custom display when collapsed |
||||||
|
.open .dropdown-menu { |
||||||
|
position: static; |
||||||
|
float: none; |
||||||
|
width: auto; |
||||||
|
margin-top: 0; |
||||||
|
background-color: transparent; |
||||||
|
border: 0; |
||||||
|
box-shadow: none; |
||||||
|
> li > a, |
||||||
|
.dropdown-header { |
||||||
|
padding: 5px 15px 5px 25px; |
||||||
|
} |
||||||
|
> li > a { |
||||||
|
line-height: @line-height-computed; |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
background-image: none; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Uncollapse the nav |
||||||
|
@media (min-width: @grid-float-breakpoint) { |
||||||
|
float: left; |
||||||
|
margin: 0; |
||||||
|
|
||||||
|
> li { |
||||||
|
float: left; |
||||||
|
> a { |
||||||
|
padding-top: @navbar-padding-vertical; |
||||||
|
padding-bottom: @navbar-padding-vertical; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
&.navbar-right:last-child { |
||||||
|
margin-right: -@navbar-padding-horizontal; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Component alignment |
||||||
|
// |
||||||
|
// Repurpose the pull utilities as their own navbar utilities to avoid specificity |
||||||
|
// issues with parents and chaining. Only do this when the navbar is uncollapsed |
||||||
|
// though so that navbar contents properly stack and align in mobile. |
||||||
|
|
||||||
|
@media (min-width: @grid-float-breakpoint) { |
||||||
|
.navbar-left { .pull-left(); } |
||||||
|
.navbar-right { .pull-right(); } |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Navbar form |
||||||
|
// |
||||||
|
// Extension of the `.form-inline` with some extra flavor for optimum display in |
||||||
|
// our navbars. |
||||||
|
|
||||||
|
.navbar-form { |
||||||
|
margin-left: -@navbar-padding-horizontal; |
||||||
|
margin-right: -@navbar-padding-horizontal; |
||||||
|
padding: 10px @navbar-padding-horizontal; |
||||||
|
border-top: 1px solid transparent; |
||||||
|
border-bottom: 1px solid transparent; |
||||||
|
@shadow: inset 0 1px 0 rgba(255,255,255,.1), 0 1px 0 rgba(255,255,255,.1); |
||||||
|
.box-shadow(@shadow); |
||||||
|
|
||||||
|
// Mixin behavior for optimum display |
||||||
|
.form-inline(); |
||||||
|
|
||||||
|
.form-group { |
||||||
|
@media (max-width: @grid-float-breakpoint-max) { |
||||||
|
margin-bottom: 5px; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Vertically center in expanded, horizontal navbar |
||||||
|
.navbar-vertical-align(@input-height-base); |
||||||
|
|
||||||
|
// Undo 100% width for pull classes |
||||||
|
@media (min-width: @grid-float-breakpoint) { |
||||||
|
width: auto; |
||||||
|
border: 0; |
||||||
|
margin-left: 0; |
||||||
|
margin-right: 0; |
||||||
|
padding-top: 0; |
||||||
|
padding-bottom: 0; |
||||||
|
.box-shadow(none); |
||||||
|
|
||||||
|
// Outdent the form if last child to line up with content down the page |
||||||
|
&.navbar-right:last-child { |
||||||
|
margin-right: -@navbar-padding-horizontal; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Dropdown menus |
||||||
|
|
||||||
|
// Menu position and menu carets |
||||||
|
.navbar-nav > li > .dropdown-menu { |
||||||
|
margin-top: 0; |
||||||
|
.border-top-radius(0); |
||||||
|
} |
||||||
|
// Menu position and menu caret support for dropups via extra dropup class |
||||||
|
.navbar-fixed-bottom .navbar-nav > li > .dropdown-menu { |
||||||
|
.border-bottom-radius(0); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Buttons in navbars |
||||||
|
// |
||||||
|
// Vertically center a button within a navbar (when *not* in a form). |
||||||
|
|
||||||
|
.navbar-btn { |
||||||
|
.navbar-vertical-align(@input-height-base); |
||||||
|
|
||||||
|
&.btn-sm { |
||||||
|
.navbar-vertical-align(@input-height-small); |
||||||
|
} |
||||||
|
&.btn-xs { |
||||||
|
.navbar-vertical-align(22); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Text in navbars |
||||||
|
// |
||||||
|
// Add a class to make any element properly align itself vertically within the navbars. |
||||||
|
|
||||||
|
.navbar-text { |
||||||
|
.navbar-vertical-align(@line-height-computed); |
||||||
|
|
||||||
|
@media (min-width: @grid-float-breakpoint) { |
||||||
|
float: left; |
||||||
|
margin-left: @navbar-padding-horizontal; |
||||||
|
margin-right: @navbar-padding-horizontal; |
||||||
|
|
||||||
|
// Outdent the form if last child to line up with content down the page |
||||||
|
&.navbar-right:last-child { |
||||||
|
margin-right: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Alternate navbars |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
// Default navbar |
||||||
|
.navbar-default { |
||||||
|
background-color: @navbar-default-bg; |
||||||
|
border-color: @navbar-default-border; |
||||||
|
|
||||||
|
.navbar-brand { |
||||||
|
color: @navbar-default-brand-color; |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @navbar-default-brand-hover-color; |
||||||
|
background-color: @navbar-default-brand-hover-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
.navbar-text { |
||||||
|
color: @navbar-default-color; |
||||||
|
} |
||||||
|
|
||||||
|
.navbar-nav { |
||||||
|
> li > a { |
||||||
|
color: @navbar-default-link-color; |
||||||
|
|
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @navbar-default-link-hover-color; |
||||||
|
background-color: @navbar-default-link-hover-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
> .active > a { |
||||||
|
&, |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @navbar-default-link-active-color; |
||||||
|
background-color: @navbar-default-link-active-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
> .disabled > a { |
||||||
|
&, |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @navbar-default-link-disabled-color; |
||||||
|
background-color: @navbar-default-link-disabled-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
.navbar-toggle { |
||||||
|
border-color: @navbar-default-toggle-border-color; |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
background-color: @navbar-default-toggle-hover-bg; |
||||||
|
} |
||||||
|
.icon-bar { |
||||||
|
background-color: @navbar-default-toggle-icon-bar-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
.navbar-collapse, |
||||||
|
.navbar-form { |
||||||
|
border-color: @navbar-default-border; |
||||||
|
} |
||||||
|
|
||||||
|
// Dropdown menu items |
||||||
|
.navbar-nav { |
||||||
|
// Remove background color from open dropdown |
||||||
|
> .open > a { |
||||||
|
&, |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
background-color: @navbar-default-link-active-bg; |
||||||
|
color: @navbar-default-link-active-color; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
@media (max-width: @grid-float-breakpoint-max) { |
||||||
|
// Dropdowns get custom display when collapsed |
||||||
|
.open .dropdown-menu { |
||||||
|
> li > a { |
||||||
|
color: @navbar-default-link-color; |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @navbar-default-link-hover-color; |
||||||
|
background-color: @navbar-default-link-hover-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
> .active > a { |
||||||
|
&, |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @navbar-default-link-active-color; |
||||||
|
background-color: @navbar-default-link-active-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
> .disabled > a { |
||||||
|
&, |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @navbar-default-link-disabled-color; |
||||||
|
background-color: @navbar-default-link-disabled-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Links in navbars |
||||||
|
// |
||||||
|
// Add a class to ensure links outside the navbar nav are colored correctly. |
||||||
|
|
||||||
|
.navbar-link { |
||||||
|
color: @navbar-default-link-color; |
||||||
|
&:hover { |
||||||
|
color: @navbar-default-link-hover-color; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
} |
||||||
|
|
||||||
|
// Inverse navbar |
||||||
|
|
||||||
|
.navbar-inverse { |
||||||
|
background-color: @navbar-inverse-bg; |
||||||
|
border-color: @navbar-inverse-border; |
||||||
|
|
||||||
|
.navbar-brand { |
||||||
|
color: @navbar-inverse-brand-color; |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @navbar-inverse-brand-hover-color; |
||||||
|
background-color: @navbar-inverse-brand-hover-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
.navbar-text { |
||||||
|
color: @navbar-inverse-color; |
||||||
|
} |
||||||
|
|
||||||
|
.navbar-nav { |
||||||
|
> li > a { |
||||||
|
color: @navbar-inverse-link-color; |
||||||
|
|
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @navbar-inverse-link-hover-color; |
||||||
|
background-color: @navbar-inverse-link-hover-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
> .active > a { |
||||||
|
&, |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @navbar-inverse-link-active-color; |
||||||
|
background-color: @navbar-inverse-link-active-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
> .disabled > a { |
||||||
|
&, |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @navbar-inverse-link-disabled-color; |
||||||
|
background-color: @navbar-inverse-link-disabled-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Darken the responsive nav toggle |
||||||
|
.navbar-toggle { |
||||||
|
border-color: @navbar-inverse-toggle-border-color; |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
background-color: @navbar-inverse-toggle-hover-bg; |
||||||
|
} |
||||||
|
.icon-bar { |
||||||
|
background-color: @navbar-inverse-toggle-icon-bar-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
.navbar-collapse, |
||||||
|
.navbar-form { |
||||||
|
border-color: darken(@navbar-inverse-bg, 7%); |
||||||
|
} |
||||||
|
|
||||||
|
// Dropdowns |
||||||
|
.navbar-nav { |
||||||
|
> .open > a { |
||||||
|
&, |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
background-color: @navbar-inverse-link-active-bg; |
||||||
|
color: @navbar-inverse-link-active-color; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
@media (max-width: @grid-float-breakpoint-max) { |
||||||
|
// Dropdowns get custom display |
||||||
|
.open .dropdown-menu { |
||||||
|
> .dropdown-header { |
||||||
|
border-color: @navbar-inverse-border; |
||||||
|
} |
||||||
|
.divider { |
||||||
|
background-color: @navbar-inverse-border; |
||||||
|
} |
||||||
|
> li > a { |
||||||
|
color: @navbar-inverse-link-color; |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @navbar-inverse-link-hover-color; |
||||||
|
background-color: @navbar-inverse-link-hover-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
> .active > a { |
||||||
|
&, |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @navbar-inverse-link-active-color; |
||||||
|
background-color: @navbar-inverse-link-active-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
> .disabled > a { |
||||||
|
&, |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @navbar-inverse-link-disabled-color; |
||||||
|
background-color: @navbar-inverse-link-disabled-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
.navbar-link { |
||||||
|
color: @navbar-inverse-link-color; |
||||||
|
&:hover { |
||||||
|
color: @navbar-inverse-link-hover-color; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
} |
@ -0,0 +1,242 @@ |
|||||||
|
// |
||||||
|
// Navs |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// Base class |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
.nav { |
||||||
|
margin-bottom: 0; |
||||||
|
padding-left: 0; // Override default ul/ol |
||||||
|
list-style: none; |
||||||
|
&:extend(.clearfix all); |
||||||
|
|
||||||
|
> li { |
||||||
|
position: relative; |
||||||
|
display: block; |
||||||
|
|
||||||
|
> a { |
||||||
|
position: relative; |
||||||
|
display: block; |
||||||
|
padding: @nav-link-padding; |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
text-decoration: none; |
||||||
|
background-color: @nav-link-hover-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Disabled state sets text to gray and nukes hover/tab effects |
||||||
|
&.disabled > a { |
||||||
|
color: @nav-disabled-link-color; |
||||||
|
|
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @nav-disabled-link-hover-color; |
||||||
|
text-decoration: none; |
||||||
|
background-color: transparent; |
||||||
|
cursor: not-allowed; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Open dropdowns |
||||||
|
.open > a { |
||||||
|
&, |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
background-color: @nav-link-hover-bg; |
||||||
|
border-color: @link-color; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Nav dividers (deprecated with v3.0.1) |
||||||
|
// |
||||||
|
// This should have been removed in v3 with the dropping of `.nav-list`, but |
||||||
|
// we missed it. We don't currently support this anywhere, but in the interest |
||||||
|
// of maintaining backward compatibility in case you use it, it's deprecated. |
||||||
|
.nav-divider { |
||||||
|
.nav-divider(); |
||||||
|
} |
||||||
|
|
||||||
|
// Prevent IE8 from misplacing imgs |
||||||
|
// |
||||||
|
// See https://github.com/h5bp/html5-boilerplate/issues/984#issuecomment-3985989 |
||||||
|
> li > a > img { |
||||||
|
max-width: none; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Tabs |
||||||
|
// ------------------------- |
||||||
|
|
||||||
|
// Give the tabs something to sit on |
||||||
|
.nav-tabs { |
||||||
|
border-bottom: 1px solid @nav-tabs-border-color; |
||||||
|
> li { |
||||||
|
float: left; |
||||||
|
// Make the list-items overlay the bottom border |
||||||
|
margin-bottom: -1px; |
||||||
|
|
||||||
|
// Actual tabs (as links) |
||||||
|
> a { |
||||||
|
margin-right: 2px; |
||||||
|
line-height: @line-height-base; |
||||||
|
border: 1px solid transparent; |
||||||
|
border-radius: @border-radius-base @border-radius-base 0 0; |
||||||
|
&:hover { |
||||||
|
border-color: @nav-tabs-link-hover-border-color @nav-tabs-link-hover-border-color @nav-tabs-border-color; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Active state, and its :hover to override normal :hover |
||||||
|
&.active > a { |
||||||
|
&, |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @nav-tabs-active-link-hover-color; |
||||||
|
background-color: @nav-tabs-active-link-hover-bg; |
||||||
|
border: 1px solid @nav-tabs-active-link-hover-border-color; |
||||||
|
border-bottom-color: transparent; |
||||||
|
cursor: default; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
// pulling this in mainly for less shorthand |
||||||
|
&.nav-justified { |
||||||
|
.nav-justified(); |
||||||
|
.nav-tabs-justified(); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Pills |
||||||
|
// ------------------------- |
||||||
|
.nav-pills { |
||||||
|
> li { |
||||||
|
float: left; |
||||||
|
|
||||||
|
// Links rendered as pills |
||||||
|
> a { |
||||||
|
border-radius: @nav-pills-border-radius; |
||||||
|
} |
||||||
|
+ li { |
||||||
|
margin-left: 2px; |
||||||
|
} |
||||||
|
|
||||||
|
// Active state |
||||||
|
&.active > a { |
||||||
|
&, |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @nav-pills-active-link-hover-color; |
||||||
|
background-color: @nav-pills-active-link-hover-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Stacked pills |
||||||
|
.nav-stacked { |
||||||
|
> li { |
||||||
|
float: none; |
||||||
|
+ li { |
||||||
|
margin-top: 2px; |
||||||
|
margin-left: 0; // no need for this gap between nav items |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Nav variations |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
// Justified nav links |
||||||
|
// ------------------------- |
||||||
|
|
||||||
|
.nav-justified { |
||||||
|
width: 100%; |
||||||
|
|
||||||
|
> li { |
||||||
|
float: none; |
||||||
|
> a { |
||||||
|
text-align: center; |
||||||
|
margin-bottom: 5px; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
> .dropdown .dropdown-menu { |
||||||
|
top: auto; |
||||||
|
left: auto; |
||||||
|
} |
||||||
|
|
||||||
|
@media (min-width: @screen-sm-min) { |
||||||
|
> li { |
||||||
|
display: table-cell; |
||||||
|
width: 1%; |
||||||
|
> a { |
||||||
|
margin-bottom: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Move borders to anchors instead of bottom of list |
||||||
|
// |
||||||
|
// Mixin for adding on top the shared `.nav-justified` styles for our tabs |
||||||
|
.nav-tabs-justified { |
||||||
|
border-bottom: 0; |
||||||
|
|
||||||
|
> li > a { |
||||||
|
// Override margin from .nav-tabs |
||||||
|
margin-right: 0; |
||||||
|
border-radius: @border-radius-base; |
||||||
|
} |
||||||
|
|
||||||
|
> .active > a, |
||||||
|
> .active > a:hover, |
||||||
|
> .active > a:focus { |
||||||
|
border: 1px solid @nav-tabs-justified-link-border-color; |
||||||
|
} |
||||||
|
|
||||||
|
@media (min-width: @screen-sm-min) { |
||||||
|
> li > a { |
||||||
|
border-bottom: 1px solid @nav-tabs-justified-link-border-color; |
||||||
|
border-radius: @border-radius-base @border-radius-base 0 0; |
||||||
|
} |
||||||
|
> .active > a, |
||||||
|
> .active > a:hover, |
||||||
|
> .active > a:focus { |
||||||
|
border-bottom-color: @nav-tabs-justified-active-link-border-color; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Tabbable tabs |
||||||
|
// ------------------------- |
||||||
|
|
||||||
|
// Hide tabbable panes to start, show them when `.active` |
||||||
|
.tab-content { |
||||||
|
> .tab-pane { |
||||||
|
display: none; |
||||||
|
} |
||||||
|
> .active { |
||||||
|
display: block; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Dropdowns |
||||||
|
// ------------------------- |
||||||
|
|
||||||
|
// Specific dropdowns |
||||||
|
.nav-tabs .dropdown-menu { |
||||||
|
// make dropdown border overlap tab border |
||||||
|
margin-top: -1px; |
||||||
|
// Remove the top rounded corners here since there is a hard edge above the menu |
||||||
|
.border-top-radius(0); |
||||||
|
} |
@ -0,0 +1,423 @@ |
|||||||
|
/*! normalize.css v3.0.0 | MIT License | git.io/normalize */ |
||||||
|
|
||||||
|
// |
||||||
|
// 1. Set default font family to sans-serif. |
||||||
|
// 2. Prevent iOS text size adjust after orientation change, without disabling |
||||||
|
// user zoom. |
||||||
|
// |
||||||
|
|
||||||
|
html { |
||||||
|
font-family: sans-serif; // 1 |
||||||
|
-ms-text-size-adjust: 100%; // 2 |
||||||
|
-webkit-text-size-adjust: 100%; // 2 |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Remove default margin. |
||||||
|
// |
||||||
|
|
||||||
|
body { |
||||||
|
margin: 0; |
||||||
|
} |
||||||
|
|
||||||
|
// HTML5 display definitions |
||||||
|
// ========================================================================== |
||||||
|
|
||||||
|
// |
||||||
|
// Correct `block` display not defined in IE 8/9. |
||||||
|
// |
||||||
|
|
||||||
|
article, |
||||||
|
aside, |
||||||
|
details, |
||||||
|
figcaption, |
||||||
|
figure, |
||||||
|
footer, |
||||||
|
header, |
||||||
|
hgroup, |
||||||
|
main, |
||||||
|
nav, |
||||||
|
section, |
||||||
|
summary { |
||||||
|
display: block; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// 1. Correct `inline-block` display not defined in IE 8/9. |
||||||
|
// 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera. |
||||||
|
// |
||||||
|
|
||||||
|
audio, |
||||||
|
canvas, |
||||||
|
progress, |
||||||
|
video { |
||||||
|
display: inline-block; // 1 |
||||||
|
vertical-align: baseline; // 2 |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Prevent modern browsers from displaying `audio` without controls. |
||||||
|
// Remove excess height in iOS 5 devices. |
||||||
|
// |
||||||
|
|
||||||
|
audio:not([controls]) { |
||||||
|
display: none; |
||||||
|
height: 0; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Address `[hidden]` styling not present in IE 8/9. |
||||||
|
// Hide the `template` element in IE, Safari, and Firefox < 22. |
||||||
|
// |
||||||
|
|
||||||
|
[hidden], |
||||||
|
template { |
||||||
|
display: none; |
||||||
|
} |
||||||
|
|
||||||
|
// Links |
||||||
|
// ========================================================================== |
||||||
|
|
||||||
|
// |
||||||
|
// Remove the gray background color from active links in IE 10. |
||||||
|
// |
||||||
|
|
||||||
|
a { |
||||||
|
background: transparent; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Improve readability when focused and also mouse hovered in all browsers. |
||||||
|
// |
||||||
|
|
||||||
|
a:active, |
||||||
|
a:hover { |
||||||
|
outline: 0; |
||||||
|
} |
||||||
|
|
||||||
|
// Text-level semantics |
||||||
|
// ========================================================================== |
||||||
|
|
||||||
|
// |
||||||
|
// Address styling not present in IE 8/9, Safari 5, and Chrome. |
||||||
|
// |
||||||
|
|
||||||
|
abbr[title] { |
||||||
|
border-bottom: 1px dotted; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Address style set to `bolder` in Firefox 4+, Safari 5, and Chrome. |
||||||
|
// |
||||||
|
|
||||||
|
b, |
||||||
|
strong { |
||||||
|
font-weight: bold; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Address styling not present in Safari 5 and Chrome. |
||||||
|
// |
||||||
|
|
||||||
|
dfn { |
||||||
|
font-style: italic; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Address variable `h1` font-size and margin within `section` and `article` |
||||||
|
// contexts in Firefox 4+, Safari 5, and Chrome. |
||||||
|
// |
||||||
|
|
||||||
|
h1 { |
||||||
|
font-size: 2em; |
||||||
|
margin: 0.67em 0; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Address styling not present in IE 8/9. |
||||||
|
// |
||||||
|
|
||||||
|
mark { |
||||||
|
background: #ff0; |
||||||
|
color: #000; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Address inconsistent and variable font size in all browsers. |
||||||
|
// |
||||||
|
|
||||||
|
small { |
||||||
|
font-size: 80%; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Prevent `sub` and `sup` affecting `line-height` in all browsers. |
||||||
|
// |
||||||
|
|
||||||
|
sub, |
||||||
|
sup { |
||||||
|
font-size: 75%; |
||||||
|
line-height: 0; |
||||||
|
position: relative; |
||||||
|
vertical-align: baseline; |
||||||
|
} |
||||||
|
|
||||||
|
sup { |
||||||
|
top: -0.5em; |
||||||
|
} |
||||||
|
|
||||||
|
sub { |
||||||
|
bottom: -0.25em; |
||||||
|
} |
||||||
|
|
||||||
|
// Embedded content |
||||||
|
// ========================================================================== |
||||||
|
|
||||||
|
// |
||||||
|
// Remove border when inside `a` element in IE 8/9. |
||||||
|
// |
||||||
|
|
||||||
|
img { |
||||||
|
border: 0; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Correct overflow displayed oddly in IE 9. |
||||||
|
// |
||||||
|
|
||||||
|
svg:not(:root) { |
||||||
|
overflow: hidden; |
||||||
|
} |
||||||
|
|
||||||
|
// Grouping content |
||||||
|
// ========================================================================== |
||||||
|
|
||||||
|
// |
||||||
|
// Address margin not present in IE 8/9 and Safari 5. |
||||||
|
// |
||||||
|
|
||||||
|
figure { |
||||||
|
margin: 1em 40px; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Address differences between Firefox and other browsers. |
||||||
|
// |
||||||
|
|
||||||
|
hr { |
||||||
|
-moz-box-sizing: content-box; |
||||||
|
box-sizing: content-box; |
||||||
|
height: 0; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Contain overflow in all browsers. |
||||||
|
// |
||||||
|
|
||||||
|
pre { |
||||||
|
overflow: auto; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Address odd `em`-unit font size rendering in all browsers. |
||||||
|
// |
||||||
|
|
||||||
|
code, |
||||||
|
kbd, |
||||||
|
pre, |
||||||
|
samp { |
||||||
|
font-family: monospace, monospace; |
||||||
|
font-size: 1em; |
||||||
|
} |
||||||
|
|
||||||
|
// Forms |
||||||
|
// ========================================================================== |
||||||
|
|
||||||
|
// |
||||||
|
// Known limitation: by default, Chrome and Safari on OS X allow very limited |
||||||
|
// styling of `select`, unless a `border` property is set. |
||||||
|
// |
||||||
|
|
||||||
|
// |
||||||
|
// 1. Correct color not being inherited. |
||||||
|
// Known issue: affects color of disabled elements. |
||||||
|
// 2. Correct font properties not being inherited. |
||||||
|
// 3. Address margins set differently in Firefox 4+, Safari 5, and Chrome. |
||||||
|
// |
||||||
|
|
||||||
|
button, |
||||||
|
input, |
||||||
|
optgroup, |
||||||
|
select, |
||||||
|
textarea { |
||||||
|
color: inherit; // 1 |
||||||
|
font: inherit; // 2 |
||||||
|
margin: 0; // 3 |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Address `overflow` set to `hidden` in IE 8/9/10. |
||||||
|
// |
||||||
|
|
||||||
|
button { |
||||||
|
overflow: visible; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Address inconsistent `text-transform` inheritance for `button` and `select`. |
||||||
|
// All other form control elements do not inherit `text-transform` values. |
||||||
|
// Correct `button` style inheritance in Firefox, IE 8+, and Opera |
||||||
|
// Correct `select` style inheritance in Firefox. |
||||||
|
// |
||||||
|
|
||||||
|
button, |
||||||
|
select { |
||||||
|
text-transform: none; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio` |
||||||
|
// and `video` controls. |
||||||
|
// 2. Correct inability to style clickable `input` types in iOS. |
||||||
|
// 3. Improve usability and consistency of cursor style between image-type |
||||||
|
// `input` and others. |
||||||
|
// |
||||||
|
|
||||||
|
button, |
||||||
|
html input[type="button"], // 1 |
||||||
|
input[type="reset"], |
||||||
|
input[type="submit"] { |
||||||
|
-webkit-appearance: button; // 2 |
||||||
|
cursor: pointer; // 3 |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Re-set default cursor for disabled elements. |
||||||
|
// |
||||||
|
|
||||||
|
button[disabled], |
||||||
|
html input[disabled] { |
||||||
|
cursor: default; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Remove inner padding and border in Firefox 4+. |
||||||
|
// |
||||||
|
|
||||||
|
button::-moz-focus-inner, |
||||||
|
input::-moz-focus-inner { |
||||||
|
border: 0; |
||||||
|
padding: 0; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Address Firefox 4+ setting `line-height` on `input` using `!important` in |
||||||
|
// the UA stylesheet. |
||||||
|
// |
||||||
|
|
||||||
|
input { |
||||||
|
line-height: normal; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// It's recommended that you don't attempt to style these elements. |
||||||
|
// Firefox's implementation doesn't respect box-sizing, padding, or width. |
||||||
|
// |
||||||
|
// 1. Address box sizing set to `content-box` in IE 8/9/10. |
||||||
|
// 2. Remove excess padding in IE 8/9/10. |
||||||
|
// |
||||||
|
|
||||||
|
input[type="checkbox"], |
||||||
|
input[type="radio"] { |
||||||
|
box-sizing: border-box; // 1 |
||||||
|
padding: 0; // 2 |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Fix the cursor style for Chrome's increment/decrement buttons. For certain |
||||||
|
// `font-size` values of the `input`, it causes the cursor style of the |
||||||
|
// decrement button to change from `default` to `text`. |
||||||
|
// |
||||||
|
|
||||||
|
input[type="number"]::-webkit-inner-spin-button, |
||||||
|
input[type="number"]::-webkit-outer-spin-button { |
||||||
|
height: auto; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// 1. Address `appearance` set to `searchfield` in Safari 5 and Chrome. |
||||||
|
// 2. Address `box-sizing` set to `border-box` in Safari 5 and Chrome |
||||||
|
// (include `-moz` to future-proof). |
||||||
|
// |
||||||
|
|
||||||
|
input[type="search"] { |
||||||
|
-webkit-appearance: textfield; // 1 |
||||||
|
-moz-box-sizing: content-box; |
||||||
|
-webkit-box-sizing: content-box; // 2 |
||||||
|
box-sizing: content-box; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Remove inner padding and search cancel button in Safari and Chrome on OS X. |
||||||
|
// Safari (but not Chrome) clips the cancel button when the search input has |
||||||
|
// padding (and `textfield` appearance). |
||||||
|
// |
||||||
|
|
||||||
|
input[type="search"]::-webkit-search-cancel-button, |
||||||
|
input[type="search"]::-webkit-search-decoration { |
||||||
|
-webkit-appearance: none; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Define consistent border, margin, and padding. |
||||||
|
// |
||||||
|
|
||||||
|
fieldset { |
||||||
|
border: 1px solid #c0c0c0; |
||||||
|
margin: 0 2px; |
||||||
|
padding: 0.35em 0.625em 0.75em; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// 1. Correct `color` not being inherited in IE 8/9. |
||||||
|
// 2. Remove padding so people aren't caught out if they zero out fieldsets. |
||||||
|
// |
||||||
|
|
||||||
|
legend { |
||||||
|
border: 0; // 1 |
||||||
|
padding: 0; // 2 |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Remove default vertical scrollbar in IE 8/9. |
||||||
|
// |
||||||
|
|
||||||
|
textarea { |
||||||
|
overflow: auto; |
||||||
|
} |
||||||
|
|
||||||
|
// |
||||||
|
// Don't inherit the `font-weight` (applied by a rule above). |
||||||
|
// NOTE: the default cannot safely be changed in Chrome and Safari on OS X. |
||||||
|
// |
||||||
|
|
||||||
|
optgroup { |
||||||
|
font-weight: bold; |
||||||
|
} |
||||||
|
|
||||||
|
// Tables |
||||||
|
// ========================================================================== |
||||||
|
|
||||||
|
// |
||||||
|
// Remove most spacing between table cells. |
||||||
|
// |
||||||
|
|
||||||
|
table { |
||||||
|
border-collapse: collapse; |
||||||
|
border-spacing: 0; |
||||||
|
} |
||||||
|
|
||||||
|
td, |
||||||
|
th { |
||||||
|
padding: 0; |
||||||
|
} |
@ -0,0 +1,55 @@ |
|||||||
|
// |
||||||
|
// Pager pagination |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
.pager { |
||||||
|
padding-left: 0; |
||||||
|
margin: @line-height-computed 0; |
||||||
|
list-style: none; |
||||||
|
text-align: center; |
||||||
|
&:extend(.clearfix all); |
||||||
|
li { |
||||||
|
display: inline; |
||||||
|
> a, |
||||||
|
> span { |
||||||
|
display: inline-block; |
||||||
|
padding: 5px 14px; |
||||||
|
background-color: @pager-bg; |
||||||
|
border: 1px solid @pager-border; |
||||||
|
border-radius: @pager-border-radius; |
||||||
|
} |
||||||
|
|
||||||
|
> a:hover, |
||||||
|
> a:focus { |
||||||
|
text-decoration: none; |
||||||
|
background-color: @pager-hover-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
.next { |
||||||
|
> a, |
||||||
|
> span { |
||||||
|
float: right; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
.previous { |
||||||
|
> a, |
||||||
|
> span { |
||||||
|
float: left; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
.disabled { |
||||||
|
> a, |
||||||
|
> a:hover, |
||||||
|
> a:focus, |
||||||
|
> span { |
||||||
|
color: @pager-disabled-color; |
||||||
|
background-color: @pager-bg; |
||||||
|
cursor: not-allowed; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
} |
@ -0,0 +1,88 @@ |
|||||||
|
// |
||||||
|
// Pagination (multiple pages) |
||||||
|
// -------------------------------------------------- |
||||||
|
.pagination { |
||||||
|
display: inline-block; |
||||||
|
padding-left: 0; |
||||||
|
margin: @line-height-computed 0; |
||||||
|
border-radius: @border-radius-base; |
||||||
|
|
||||||
|
> li { |
||||||
|
display: inline; // Remove list-style and block-level defaults |
||||||
|
> a, |
||||||
|
> span { |
||||||
|
position: relative; |
||||||
|
float: left; // Collapse white-space |
||||||
|
padding: @padding-base-vertical @padding-base-horizontal; |
||||||
|
line-height: @line-height-base; |
||||||
|
text-decoration: none; |
||||||
|
color: @pagination-color; |
||||||
|
background-color: @pagination-bg; |
||||||
|
border: 1px solid @pagination-border; |
||||||
|
margin-left: -1px; |
||||||
|
} |
||||||
|
&:first-child { |
||||||
|
> a, |
||||||
|
> span { |
||||||
|
margin-left: 0; |
||||||
|
.border-left-radius(@border-radius-base); |
||||||
|
} |
||||||
|
} |
||||||
|
&:last-child { |
||||||
|
> a, |
||||||
|
> span { |
||||||
|
.border-right-radius(@border-radius-base); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
> li > a, |
||||||
|
> li > span { |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @pagination-hover-color; |
||||||
|
background-color: @pagination-hover-bg; |
||||||
|
border-color: @pagination-hover-border; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
> .active > a, |
||||||
|
> .active > span { |
||||||
|
&, |
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
z-index: 2; |
||||||
|
color: @pagination-active-color; |
||||||
|
background-color: @pagination-active-bg; |
||||||
|
border-color: @pagination-active-border; |
||||||
|
cursor: default; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
> .disabled { |
||||||
|
> span, |
||||||
|
> span:hover, |
||||||
|
> span:focus, |
||||||
|
> a, |
||||||
|
> a:hover, |
||||||
|
> a:focus { |
||||||
|
color: @pagination-disabled-color; |
||||||
|
background-color: @pagination-disabled-bg; |
||||||
|
border-color: @pagination-disabled-border; |
||||||
|
cursor: not-allowed; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Sizing |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
// Large |
||||||
|
.pagination-lg { |
||||||
|
.pagination-size(@padding-large-vertical; @padding-large-horizontal; @font-size-large; @border-radius-large); |
||||||
|
} |
||||||
|
|
||||||
|
// Small |
||||||
|
.pagination-sm { |
||||||
|
.pagination-size(@padding-small-vertical; @padding-small-horizontal; @font-size-small; @border-radius-small); |
||||||
|
} |
@ -0,0 +1,241 @@ |
|||||||
|
// |
||||||
|
// Panels |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// Base class |
||||||
|
.panel { |
||||||
|
margin-bottom: @line-height-computed; |
||||||
|
background-color: @panel-bg; |
||||||
|
border: 1px solid transparent; |
||||||
|
border-radius: @panel-border-radius; |
||||||
|
.box-shadow(0 1px 1px rgba(0,0,0,.05)); |
||||||
|
} |
||||||
|
|
||||||
|
// Panel contents |
||||||
|
.panel-body { |
||||||
|
padding: @panel-body-padding; |
||||||
|
&:extend(.clearfix all); |
||||||
|
} |
||||||
|
|
||||||
|
// Optional heading |
||||||
|
.panel-heading { |
||||||
|
padding: 10px 15px; |
||||||
|
border-bottom: 1px solid transparent; |
||||||
|
.border-top-radius((@panel-border-radius - 1)); |
||||||
|
|
||||||
|
> .dropdown .dropdown-toggle { |
||||||
|
color: inherit; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Within heading, strip any `h*` tag of its default margins for spacing. |
||||||
|
.panel-title { |
||||||
|
margin-top: 0; |
||||||
|
margin-bottom: 0; |
||||||
|
font-size: ceil((@font-size-base * 1.125)); |
||||||
|
color: inherit; |
||||||
|
|
||||||
|
> a { |
||||||
|
color: inherit; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Optional footer (stays gray in every modifier class) |
||||||
|
.panel-footer { |
||||||
|
padding: 10px 15px; |
||||||
|
background-color: @panel-footer-bg; |
||||||
|
border-top: 1px solid @panel-inner-border; |
||||||
|
.border-bottom-radius((@panel-border-radius - 1)); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// List groups in panels |
||||||
|
// |
||||||
|
// By default, space out list group content from panel headings to account for |
||||||
|
// any kind of custom content between the two. |
||||||
|
|
||||||
|
.panel { |
||||||
|
> .list-group { |
||||||
|
margin-bottom: 0; |
||||||
|
|
||||||
|
.list-group-item { |
||||||
|
border-width: 1px 0; |
||||||
|
border-radius: 0; |
||||||
|
} |
||||||
|
|
||||||
|
// Add border top radius for first one |
||||||
|
&:first-child { |
||||||
|
.list-group-item:first-child { |
||||||
|
border-top: 0; |
||||||
|
.border-top-radius((@panel-border-radius - 1)); |
||||||
|
} |
||||||
|
} |
||||||
|
// Add border bottom radius for last one |
||||||
|
&:last-child { |
||||||
|
.list-group-item:last-child { |
||||||
|
border-bottom: 0; |
||||||
|
.border-bottom-radius((@panel-border-radius - 1)); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
// Collapse space between when there's no additional content. |
||||||
|
.panel-heading + .list-group { |
||||||
|
.list-group-item:first-child { |
||||||
|
border-top-width: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Tables in panels |
||||||
|
// |
||||||
|
// Place a non-bordered `.table` within a panel (not within a `.panel-body`) and |
||||||
|
// watch it go full width. |
||||||
|
|
||||||
|
.panel { |
||||||
|
> .table, |
||||||
|
> .table-responsive > .table { |
||||||
|
margin-bottom: 0; |
||||||
|
} |
||||||
|
// Add border top radius for first one |
||||||
|
> .table:first-child, |
||||||
|
> .table-responsive:first-child > .table:first-child { |
||||||
|
.border-top-radius((@panel-border-radius - 1)); |
||||||
|
|
||||||
|
> thead:first-child, |
||||||
|
> tbody:first-child { |
||||||
|
> tr:first-child { |
||||||
|
td:first-child, |
||||||
|
th:first-child { |
||||||
|
border-top-left-radius: (@panel-border-radius - 1); |
||||||
|
} |
||||||
|
td:last-child, |
||||||
|
th:last-child { |
||||||
|
border-top-right-radius: (@panel-border-radius - 1); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
// Add border bottom radius for last one |
||||||
|
> .table:last-child, |
||||||
|
> .table-responsive:last-child > .table:last-child { |
||||||
|
.border-bottom-radius((@panel-border-radius - 1)); |
||||||
|
|
||||||
|
> tbody:last-child, |
||||||
|
> tfoot:last-child { |
||||||
|
> tr:last-child { |
||||||
|
td:first-child, |
||||||
|
th:first-child { |
||||||
|
border-bottom-left-radius: (@panel-border-radius - 1); |
||||||
|
} |
||||||
|
td:last-child, |
||||||
|
th:last-child { |
||||||
|
border-bottom-right-radius: (@panel-border-radius - 1); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
> .panel-body + .table, |
||||||
|
> .panel-body + .table-responsive { |
||||||
|
border-top: 1px solid @table-border-color; |
||||||
|
} |
||||||
|
> .table > tbody:first-child > tr:first-child th, |
||||||
|
> .table > tbody:first-child > tr:first-child td { |
||||||
|
border-top: 0; |
||||||
|
} |
||||||
|
> .table-bordered, |
||||||
|
> .table-responsive > .table-bordered { |
||||||
|
border: 0; |
||||||
|
> thead, |
||||||
|
> tbody, |
||||||
|
> tfoot { |
||||||
|
> tr { |
||||||
|
> th:first-child, |
||||||
|
> td:first-child { |
||||||
|
border-left: 0; |
||||||
|
} |
||||||
|
> th:last-child, |
||||||
|
> td:last-child { |
||||||
|
border-right: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
> thead, |
||||||
|
> tbody { |
||||||
|
> tr:first-child { |
||||||
|
> td, |
||||||
|
> th { |
||||||
|
border-bottom: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
> tbody, |
||||||
|
> tfoot { |
||||||
|
> tr:last-child { |
||||||
|
> td, |
||||||
|
> th { |
||||||
|
border-bottom: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
> .table-responsive { |
||||||
|
border: 0; |
||||||
|
margin-bottom: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Collapsable panels (aka, accordion) |
||||||
|
// |
||||||
|
// Wrap a series of panels in `.panel-group` to turn them into an accordion with |
||||||
|
// the help of our collapse JavaScript plugin. |
||||||
|
|
||||||
|
.panel-group { |
||||||
|
margin-bottom: @line-height-computed; |
||||||
|
|
||||||
|
// Tighten up margin so it's only between panels |
||||||
|
.panel { |
||||||
|
margin-bottom: 0; |
||||||
|
border-radius: @panel-border-radius; |
||||||
|
overflow: hidden; // crop contents when collapsed |
||||||
|
+ .panel { |
||||||
|
margin-top: 5px; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
.panel-heading { |
||||||
|
border-bottom: 0; |
||||||
|
+ .panel-collapse .panel-body { |
||||||
|
border-top: 1px solid @panel-inner-border; |
||||||
|
} |
||||||
|
} |
||||||
|
.panel-footer { |
||||||
|
border-top: 0; |
||||||
|
+ .panel-collapse .panel-body { |
||||||
|
border-bottom: 1px solid @panel-inner-border; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Contextual variations |
||||||
|
.panel-default { |
||||||
|
.panel-variant(@panel-default-border; @panel-default-text; @panel-default-heading-bg; @panel-default-border); |
||||||
|
} |
||||||
|
.panel-primary { |
||||||
|
.panel-variant(@panel-primary-border; @panel-primary-text; @panel-primary-heading-bg; @panel-primary-border); |
||||||
|
} |
||||||
|
.panel-success { |
||||||
|
.panel-variant(@panel-success-border; @panel-success-text; @panel-success-heading-bg; @panel-success-border); |
||||||
|
} |
||||||
|
.panel-info { |
||||||
|
.panel-variant(@panel-info-border; @panel-info-text; @panel-info-heading-bg; @panel-info-border); |
||||||
|
} |
||||||
|
.panel-warning { |
||||||
|
.panel-variant(@panel-warning-border; @panel-warning-text; @panel-warning-heading-bg; @panel-warning-border); |
||||||
|
} |
||||||
|
.panel-danger { |
||||||
|
.panel-variant(@panel-danger-border; @panel-danger-text; @panel-danger-heading-bg; @panel-danger-border); |
||||||
|
} |
@ -0,0 +1,133 @@ |
|||||||
|
// |
||||||
|
// Popovers |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
.popover { |
||||||
|
position: absolute; |
||||||
|
top: 0; |
||||||
|
left: 0; |
||||||
|
z-index: @zindex-popover; |
||||||
|
display: none; |
||||||
|
max-width: @popover-max-width; |
||||||
|
padding: 1px; |
||||||
|
text-align: left; // Reset given new insertion method |
||||||
|
background-color: @popover-bg; |
||||||
|
background-clip: padding-box; |
||||||
|
border: 1px solid @popover-fallback-border-color; |
||||||
|
border: 1px solid @popover-border-color; |
||||||
|
border-radius: @border-radius-large; |
||||||
|
.box-shadow(0 5px 10px rgba(0,0,0,.2)); |
||||||
|
|
||||||
|
// Overrides for proper insertion |
||||||
|
white-space: normal; |
||||||
|
|
||||||
|
// Offset the popover to account for the popover arrow |
||||||
|
&.top { margin-top: -@popover-arrow-width; } |
||||||
|
&.right { margin-left: @popover-arrow-width; } |
||||||
|
&.bottom { margin-top: @popover-arrow-width; } |
||||||
|
&.left { margin-left: -@popover-arrow-width; } |
||||||
|
} |
||||||
|
|
||||||
|
.popover-title { |
||||||
|
margin: 0; // reset heading margin |
||||||
|
padding: 8px 14px; |
||||||
|
font-size: @font-size-base; |
||||||
|
font-weight: normal; |
||||||
|
line-height: 18px; |
||||||
|
background-color: @popover-title-bg; |
||||||
|
border-bottom: 1px solid darken(@popover-title-bg, 5%); |
||||||
|
border-radius: 5px 5px 0 0; |
||||||
|
} |
||||||
|
|
||||||
|
.popover-content { |
||||||
|
padding: 9px 14px; |
||||||
|
} |
||||||
|
|
||||||
|
// Arrows |
||||||
|
// |
||||||
|
// .arrow is outer, .arrow:after is inner |
||||||
|
|
||||||
|
.popover > .arrow { |
||||||
|
&, |
||||||
|
&:after { |
||||||
|
position: absolute; |
||||||
|
display: block; |
||||||
|
width: 0; |
||||||
|
height: 0; |
||||||
|
border-color: transparent; |
||||||
|
border-style: solid; |
||||||
|
} |
||||||
|
} |
||||||
|
.popover > .arrow { |
||||||
|
border-width: @popover-arrow-outer-width; |
||||||
|
} |
||||||
|
.popover > .arrow:after { |
||||||
|
border-width: @popover-arrow-width; |
||||||
|
content: ""; |
||||||
|
} |
||||||
|
|
||||||
|
.popover { |
||||||
|
&.top > .arrow { |
||||||
|
left: 50%; |
||||||
|
margin-left: -@popover-arrow-outer-width; |
||||||
|
border-bottom-width: 0; |
||||||
|
border-top-color: @popover-arrow-outer-fallback-color; // IE8 fallback |
||||||
|
border-top-color: @popover-arrow-outer-color; |
||||||
|
bottom: -@popover-arrow-outer-width; |
||||||
|
&:after { |
||||||
|
content: " "; |
||||||
|
bottom: 1px; |
||||||
|
margin-left: -@popover-arrow-width; |
||||||
|
border-bottom-width: 0; |
||||||
|
border-top-color: @popover-arrow-color; |
||||||
|
} |
||||||
|
} |
||||||
|
&.right > .arrow { |
||||||
|
top: 50%; |
||||||
|
left: -@popover-arrow-outer-width; |
||||||
|
margin-top: -@popover-arrow-outer-width; |
||||||
|
border-left-width: 0; |
||||||
|
border-right-color: @popover-arrow-outer-fallback-color; // IE8 fallback |
||||||
|
border-right-color: @popover-arrow-outer-color; |
||||||
|
&:after { |
||||||
|
content: " "; |
||||||
|
left: 1px; |
||||||
|
bottom: -@popover-arrow-width; |
||||||
|
border-left-width: 0; |
||||||
|
border-right-color: @popover-arrow-color; |
||||||
|
} |
||||||
|
} |
||||||
|
&.bottom > .arrow { |
||||||
|
left: 50%; |
||||||
|
margin-left: -@popover-arrow-outer-width; |
||||||
|
border-top-width: 0; |
||||||
|
border-bottom-color: @popover-arrow-outer-fallback-color; // IE8 fallback |
||||||
|
border-bottom-color: @popover-arrow-outer-color; |
||||||
|
top: -@popover-arrow-outer-width; |
||||||
|
&:after { |
||||||
|
content: " "; |
||||||
|
top: 1px; |
||||||
|
margin-left: -@popover-arrow-width; |
||||||
|
border-top-width: 0; |
||||||
|
border-bottom-color: @popover-arrow-color; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
&.left > .arrow { |
||||||
|
top: 50%; |
||||||
|
right: -@popover-arrow-outer-width; |
||||||
|
margin-top: -@popover-arrow-outer-width; |
||||||
|
border-right-width: 0; |
||||||
|
border-left-color: @popover-arrow-outer-fallback-color; // IE8 fallback |
||||||
|
border-left-color: @popover-arrow-outer-color; |
||||||
|
&:after { |
||||||
|
content: " "; |
||||||
|
right: 1px; |
||||||
|
border-right-width: 0; |
||||||
|
border-left-color: @popover-arrow-color; |
||||||
|
bottom: -@popover-arrow-width; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
} |
@ -0,0 +1,101 @@ |
|||||||
|
// |
||||||
|
// Basic print styles |
||||||
|
// -------------------------------------------------- |
||||||
|
// Source: https://github.com/h5bp/html5-boilerplate/blob/master/css/main.css |
||||||
|
|
||||||
|
@media print { |
||||||
|
|
||||||
|
* { |
||||||
|
text-shadow: none !important; |
||||||
|
color: #000 !important; // Black prints faster: h5bp.com/s |
||||||
|
background: transparent !important; |
||||||
|
box-shadow: none !important; |
||||||
|
} |
||||||
|
|
||||||
|
a, |
||||||
|
a:visited { |
||||||
|
text-decoration: underline; |
||||||
|
} |
||||||
|
|
||||||
|
a[href]:after { |
||||||
|
content: " (" attr(href) ")"; |
||||||
|
} |
||||||
|
|
||||||
|
abbr[title]:after { |
||||||
|
content: " (" attr(title) ")"; |
||||||
|
} |
||||||
|
|
||||||
|
// Don't show links for images, or javascript/internal links |
||||||
|
a[href^="javascript:"]:after, |
||||||
|
a[href^="#"]:after { |
||||||
|
content: ""; |
||||||
|
} |
||||||
|
|
||||||
|
pre, |
||||||
|
blockquote { |
||||||
|
border: 1px solid #999; |
||||||
|
page-break-inside: avoid; |
||||||
|
} |
||||||
|
|
||||||
|
thead { |
||||||
|
display: table-header-group; // h5bp.com/t |
||||||
|
} |
||||||
|
|
||||||
|
tr, |
||||||
|
img { |
||||||
|
page-break-inside: avoid; |
||||||
|
} |
||||||
|
|
||||||
|
img { |
||||||
|
max-width: 100% !important; |
||||||
|
} |
||||||
|
|
||||||
|
p, |
||||||
|
h2, |
||||||
|
h3 { |
||||||
|
orphans: 3; |
||||||
|
widows: 3; |
||||||
|
} |
||||||
|
|
||||||
|
h2, |
||||||
|
h3 { |
||||||
|
page-break-after: avoid; |
||||||
|
} |
||||||
|
|
||||||
|
// Chrome (OSX) fix for https://github.com/twbs/bootstrap/issues/11245 |
||||||
|
// Once fixed, we can just straight up remove this. |
||||||
|
select { |
||||||
|
background: #fff !important; |
||||||
|
} |
||||||
|
|
||||||
|
// Bootstrap components |
||||||
|
.navbar { |
||||||
|
display: none; |
||||||
|
} |
||||||
|
.table { |
||||||
|
td, |
||||||
|
th { |
||||||
|
background-color: #fff !important; |
||||||
|
} |
||||||
|
} |
||||||
|
.btn, |
||||||
|
.dropup > .btn { |
||||||
|
> .caret { |
||||||
|
border-top-color: #000 !important; |
||||||
|
} |
||||||
|
} |
||||||
|
.label { |
||||||
|
border: 1px solid #000; |
||||||
|
} |
||||||
|
|
||||||
|
.table { |
||||||
|
border-collapse: collapse !important; |
||||||
|
} |
||||||
|
.table-bordered { |
||||||
|
th, |
||||||
|
td { |
||||||
|
border: 1px solid #ddd !important; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
} |
@ -0,0 +1,80 @@ |
|||||||
|
// |
||||||
|
// Progress bars |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// Bar animations |
||||||
|
// ------------------------- |
||||||
|
|
||||||
|
// WebKit |
||||||
|
@-webkit-keyframes progress-bar-stripes { |
||||||
|
from { background-position: 40px 0; } |
||||||
|
to { background-position: 0 0; } |
||||||
|
} |
||||||
|
|
||||||
|
// Spec and IE10+ |
||||||
|
@keyframes progress-bar-stripes { |
||||||
|
from { background-position: 40px 0; } |
||||||
|
to { background-position: 0 0; } |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// Bar itself |
||||||
|
// ------------------------- |
||||||
|
|
||||||
|
// Outer container |
||||||
|
.progress { |
||||||
|
overflow: hidden; |
||||||
|
height: @line-height-computed; |
||||||
|
margin-bottom: @line-height-computed; |
||||||
|
background-color: @progress-bg; |
||||||
|
border-radius: @border-radius-base; |
||||||
|
.box-shadow(inset 0 1px 2px rgba(0,0,0,.1)); |
||||||
|
} |
||||||
|
|
||||||
|
// Bar of progress |
||||||
|
.progress-bar { |
||||||
|
float: left; |
||||||
|
width: 0%; |
||||||
|
height: 100%; |
||||||
|
font-size: @font-size-small; |
||||||
|
line-height: @line-height-computed; |
||||||
|
color: @progress-bar-color; |
||||||
|
text-align: center; |
||||||
|
background-color: @progress-bar-bg; |
||||||
|
.box-shadow(inset 0 -1px 0 rgba(0,0,0,.15)); |
||||||
|
.transition(width .6s ease); |
||||||
|
} |
||||||
|
|
||||||
|
// Striped bars |
||||||
|
.progress-striped .progress-bar { |
||||||
|
#gradient > .striped(); |
||||||
|
background-size: 40px 40px; |
||||||
|
} |
||||||
|
|
||||||
|
// Call animation for the active one |
||||||
|
.progress.active .progress-bar { |
||||||
|
.animation(progress-bar-stripes 2s linear infinite); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// Variations |
||||||
|
// ------------------------- |
||||||
|
|
||||||
|
.progress-bar-success { |
||||||
|
.progress-bar-variant(@progress-bar-success-bg); |
||||||
|
} |
||||||
|
|
||||||
|
.progress-bar-info { |
||||||
|
.progress-bar-variant(@progress-bar-info-bg); |
||||||
|
} |
||||||
|
|
||||||
|
.progress-bar-warning { |
||||||
|
.progress-bar-variant(@progress-bar-warning-bg); |
||||||
|
} |
||||||
|
|
||||||
|
.progress-bar-danger { |
||||||
|
.progress-bar-variant(@progress-bar-danger-bg); |
||||||
|
} |
@ -0,0 +1,92 @@ |
|||||||
|
// |
||||||
|
// Responsive: Utility classes |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// IE10 in Windows (Phone) 8 |
||||||
|
// |
||||||
|
// Support for responsive views via media queries is kind of borked in IE10, for |
||||||
|
// Surface/desktop in split view and for Windows Phone 8. This particular fix |
||||||
|
// must be accompanied by a snippet of JavaScript to sniff the user agent and |
||||||
|
// apply some conditional CSS to *only* the Surface/desktop Windows 8. Look at |
||||||
|
// our Getting Started page for more information on this bug. |
||||||
|
// |
||||||
|
// For more information, see the following: |
||||||
|
// |
||||||
|
// Issue: https://github.com/twbs/bootstrap/issues/10497 |
||||||
|
// Docs: http://getbootstrap.com/getting-started/#browsers |
||||||
|
// Source: http://timkadlec.com/2012/10/ie10-snap-mode-and-responsive-design/ |
||||||
|
|
||||||
|
@-ms-viewport { |
||||||
|
width: device-width; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Visibility utilities |
||||||
|
.visible-xs, |
||||||
|
.visible-sm, |
||||||
|
.visible-md, |
||||||
|
.visible-lg { |
||||||
|
.responsive-invisibility(); |
||||||
|
} |
||||||
|
|
||||||
|
.visible-xs { |
||||||
|
@media (max-width: @screen-xs-max) { |
||||||
|
.responsive-visibility(); |
||||||
|
} |
||||||
|
} |
||||||
|
.visible-sm { |
||||||
|
@media (min-width: @screen-sm-min) and (max-width: @screen-sm-max) { |
||||||
|
.responsive-visibility(); |
||||||
|
} |
||||||
|
} |
||||||
|
.visible-md { |
||||||
|
@media (min-width: @screen-md-min) and (max-width: @screen-md-max) { |
||||||
|
.responsive-visibility(); |
||||||
|
} |
||||||
|
} |
||||||
|
.visible-lg { |
||||||
|
@media (min-width: @screen-lg-min) { |
||||||
|
.responsive-visibility(); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
.hidden-xs { |
||||||
|
@media (max-width: @screen-xs-max) { |
||||||
|
.responsive-invisibility(); |
||||||
|
} |
||||||
|
} |
||||||
|
.hidden-sm { |
||||||
|
@media (min-width: @screen-sm-min) and (max-width: @screen-sm-max) { |
||||||
|
.responsive-invisibility(); |
||||||
|
} |
||||||
|
} |
||||||
|
.hidden-md { |
||||||
|
@media (min-width: @screen-md-min) and (max-width: @screen-md-max) { |
||||||
|
.responsive-invisibility(); |
||||||
|
} |
||||||
|
} |
||||||
|
.hidden-lg { |
||||||
|
@media (min-width: @screen-lg-min) { |
||||||
|
.responsive-invisibility(); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Print utilities |
||||||
|
// |
||||||
|
// Media queries are placed on the inside to be mixin-friendly. |
||||||
|
|
||||||
|
.visible-print { |
||||||
|
.responsive-invisibility(); |
||||||
|
|
||||||
|
@media print { |
||||||
|
.responsive-visibility(); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
.hidden-print { |
||||||
|
@media print { |
||||||
|
.responsive-invisibility(); |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,134 @@ |
|||||||
|
// |
||||||
|
// Scaffolding |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// Reset the box-sizing |
||||||
|
// |
||||||
|
// Heads up! This reset may cause conflicts with some third-party widgets. |
||||||
|
// For recommendations on resolving such conflicts, see |
||||||
|
// http://getbootstrap.com/getting-started/#third-box-sizing |
||||||
|
* { |
||||||
|
.box-sizing(border-box); |
||||||
|
} |
||||||
|
*:before, |
||||||
|
*:after { |
||||||
|
.box-sizing(border-box); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Body reset |
||||||
|
|
||||||
|
html { |
||||||
|
font-size: 62.5%; |
||||||
|
-webkit-tap-highlight-color: rgba(0,0,0,0); |
||||||
|
} |
||||||
|
|
||||||
|
body { |
||||||
|
font-family: @font-family-base; |
||||||
|
font-size: @font-size-base; |
||||||
|
line-height: @line-height-base; |
||||||
|
color: @text-color; |
||||||
|
background-color: @body-bg; |
||||||
|
} |
||||||
|
|
||||||
|
// Reset fonts for relevant elements |
||||||
|
input, |
||||||
|
button, |
||||||
|
select, |
||||||
|
textarea { |
||||||
|
font-family: inherit; |
||||||
|
font-size: inherit; |
||||||
|
line-height: inherit; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Links |
||||||
|
|
||||||
|
a { |
||||||
|
color: @link-color; |
||||||
|
text-decoration: none; |
||||||
|
|
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
color: @link-hover-color; |
||||||
|
text-decoration: underline; |
||||||
|
} |
||||||
|
|
||||||
|
&:focus { |
||||||
|
.tab-focus(); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Figures |
||||||
|
// |
||||||
|
// We reset this here because previously Normalize had no `figure` margins. This |
||||||
|
// ensures we don't break anyone's use of the element. |
||||||
|
|
||||||
|
figure { |
||||||
|
margin: 0; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Images |
||||||
|
|
||||||
|
img { |
||||||
|
vertical-align: middle; |
||||||
|
} |
||||||
|
|
||||||
|
// Responsive images (ensure images don't scale beyond their parents) |
||||||
|
.img-responsive { |
||||||
|
.img-responsive(); |
||||||
|
} |
||||||
|
|
||||||
|
// Rounded corners |
||||||
|
.img-rounded { |
||||||
|
border-radius: @border-radius-large; |
||||||
|
} |
||||||
|
|
||||||
|
// Image thumbnails |
||||||
|
// |
||||||
|
// Heads up! This is mixin-ed into thumbnails.less for `.thumbnail`. |
||||||
|
.img-thumbnail { |
||||||
|
padding: @thumbnail-padding; |
||||||
|
line-height: @line-height-base; |
||||||
|
background-color: @thumbnail-bg; |
||||||
|
border: 1px solid @thumbnail-border; |
||||||
|
border-radius: @thumbnail-border-radius; |
||||||
|
.transition(all .2s ease-in-out); |
||||||
|
|
||||||
|
// Keep them at most 100% wide |
||||||
|
.img-responsive(inline-block); |
||||||
|
} |
||||||
|
|
||||||
|
// Perfect circle |
||||||
|
.img-circle { |
||||||
|
border-radius: 50%; // set radius in percents |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Horizontal rules |
||||||
|
|
||||||
|
hr { |
||||||
|
margin-top: @line-height-computed; |
||||||
|
margin-bottom: @line-height-computed; |
||||||
|
border: 0; |
||||||
|
border-top: 1px solid @hr-border; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Only display content to screen readers |
||||||
|
// |
||||||
|
// See: http://a11yproject.com/posts/how-to-hide-content/ |
||||||
|
|
||||||
|
.sr-only { |
||||||
|
position: absolute; |
||||||
|
width: 1px; |
||||||
|
height: 1px; |
||||||
|
margin: -1px; |
||||||
|
padding: 0; |
||||||
|
overflow: hidden; |
||||||
|
clip: rect(0,0,0,0); |
||||||
|
border: 0; |
||||||
|
} |
@ -0,0 +1,233 @@ |
|||||||
|
// |
||||||
|
// Tables |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
table { |
||||||
|
max-width: 100%; |
||||||
|
background-color: @table-bg; |
||||||
|
} |
||||||
|
th { |
||||||
|
text-align: left; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Baseline styles |
||||||
|
|
||||||
|
.table { |
||||||
|
width: 100%; |
||||||
|
margin-bottom: @line-height-computed; |
||||||
|
// Cells |
||||||
|
> thead, |
||||||
|
> tbody, |
||||||
|
> tfoot { |
||||||
|
> tr { |
||||||
|
> th, |
||||||
|
> td { |
||||||
|
padding: @table-cell-padding; |
||||||
|
line-height: @line-height-base; |
||||||
|
vertical-align: top; |
||||||
|
border-top: 1px solid @table-border-color; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
// Bottom align for column headings |
||||||
|
> thead > tr > th { |
||||||
|
vertical-align: bottom; |
||||||
|
border-bottom: 2px solid @table-border-color; |
||||||
|
} |
||||||
|
// Remove top border from thead by default |
||||||
|
> caption + thead, |
||||||
|
> colgroup + thead, |
||||||
|
> thead:first-child { |
||||||
|
> tr:first-child { |
||||||
|
> th, |
||||||
|
> td { |
||||||
|
border-top: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
// Account for multiple tbody instances |
||||||
|
> tbody + tbody { |
||||||
|
border-top: 2px solid @table-border-color; |
||||||
|
} |
||||||
|
|
||||||
|
// Nesting |
||||||
|
.table { |
||||||
|
background-color: @body-bg; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Condensed table w/ half padding |
||||||
|
|
||||||
|
.table-condensed { |
||||||
|
> thead, |
||||||
|
> tbody, |
||||||
|
> tfoot { |
||||||
|
> tr { |
||||||
|
> th, |
||||||
|
> td { |
||||||
|
padding: @table-condensed-cell-padding; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Bordered version |
||||||
|
// |
||||||
|
// Add borders all around the table and between all the columns. |
||||||
|
|
||||||
|
.table-bordered { |
||||||
|
border: 1px solid @table-border-color; |
||||||
|
> thead, |
||||||
|
> tbody, |
||||||
|
> tfoot { |
||||||
|
> tr { |
||||||
|
> th, |
||||||
|
> td { |
||||||
|
border: 1px solid @table-border-color; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
> thead > tr { |
||||||
|
> th, |
||||||
|
> td { |
||||||
|
border-bottom-width: 2px; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Zebra-striping |
||||||
|
// |
||||||
|
// Default zebra-stripe styles (alternating gray and transparent backgrounds) |
||||||
|
|
||||||
|
.table-striped { |
||||||
|
> tbody > tr:nth-child(odd) { |
||||||
|
> td, |
||||||
|
> th { |
||||||
|
background-color: @table-bg-accent; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Hover effect |
||||||
|
// |
||||||
|
// Placed here since it has to come after the potential zebra striping |
||||||
|
|
||||||
|
.table-hover { |
||||||
|
> tbody > tr:hover { |
||||||
|
> td, |
||||||
|
> th { |
||||||
|
background-color: @table-bg-hover; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Table cell sizing |
||||||
|
// |
||||||
|
// Reset default table behavior |
||||||
|
|
||||||
|
table col[class*="col-"] { |
||||||
|
position: static; // Prevent border hiding in Firefox and IE9/10 (see https://github.com/twbs/bootstrap/issues/11623) |
||||||
|
float: none; |
||||||
|
display: table-column; |
||||||
|
} |
||||||
|
table { |
||||||
|
td, |
||||||
|
th { |
||||||
|
&[class*="col-"] { |
||||||
|
position: static; // Prevent border hiding in Firefox and IE9/10 (see https://github.com/twbs/bootstrap/issues/11623) |
||||||
|
float: none; |
||||||
|
display: table-cell; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Table backgrounds |
||||||
|
// |
||||||
|
// Exact selectors below required to override `.table-striped` and prevent |
||||||
|
// inheritance to nested tables. |
||||||
|
|
||||||
|
// Generate the contextual variants |
||||||
|
.table-row-variant(active; @table-bg-active); |
||||||
|
.table-row-variant(success; @state-success-bg); |
||||||
|
.table-row-variant(info; @state-info-bg); |
||||||
|
.table-row-variant(warning; @state-warning-bg); |
||||||
|
.table-row-variant(danger; @state-danger-bg); |
||||||
|
|
||||||
|
|
||||||
|
// Responsive tables |
||||||
|
// |
||||||
|
// Wrap your tables in `.table-responsive` and we'll make them mobile friendly |
||||||
|
// by enabling horizontal scrolling. Only applies <768px. Everything above that |
||||||
|
// will display normally. |
||||||
|
|
||||||
|
@media (max-width: @screen-xs-max) { |
||||||
|
.table-responsive { |
||||||
|
width: 100%; |
||||||
|
margin-bottom: (@line-height-computed * 0.75); |
||||||
|
overflow-y: hidden; |
||||||
|
overflow-x: scroll; |
||||||
|
-ms-overflow-style: -ms-autohiding-scrollbar; |
||||||
|
border: 1px solid @table-border-color; |
||||||
|
-webkit-overflow-scrolling: touch; |
||||||
|
|
||||||
|
// Tighten up spacing |
||||||
|
> .table { |
||||||
|
margin-bottom: 0; |
||||||
|
|
||||||
|
// Ensure the content doesn't wrap |
||||||
|
> thead, |
||||||
|
> tbody, |
||||||
|
> tfoot { |
||||||
|
> tr { |
||||||
|
> th, |
||||||
|
> td { |
||||||
|
white-space: nowrap; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Special overrides for the bordered tables |
||||||
|
> .table-bordered { |
||||||
|
border: 0; |
||||||
|
|
||||||
|
// Nuke the appropriate borders so that the parent can handle them |
||||||
|
> thead, |
||||||
|
> tbody, |
||||||
|
> tfoot { |
||||||
|
> tr { |
||||||
|
> th:first-child, |
||||||
|
> td:first-child { |
||||||
|
border-left: 0; |
||||||
|
} |
||||||
|
> th:last-child, |
||||||
|
> td:last-child { |
||||||
|
border-right: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Only nuke the last row's bottom-border in `tbody` and `tfoot` since |
||||||
|
// chances are there will be only one `tr` in a `thead` and that would |
||||||
|
// remove the border altogether. |
||||||
|
> tbody, |
||||||
|
> tfoot { |
||||||
|
> tr:last-child { |
||||||
|
> th, |
||||||
|
> td { |
||||||
|
border-bottom: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
} |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,247 @@ |
|||||||
|
|
||||||
|
// |
||||||
|
// Load core variables and mixins |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
@import "variables.less"; |
||||||
|
@import "mixins.less"; |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// |
||||||
|
// Buttons |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
// Common styles |
||||||
|
.btn-default, |
||||||
|
.btn-primary, |
||||||
|
.btn-success, |
||||||
|
.btn-info, |
||||||
|
.btn-warning, |
||||||
|
.btn-danger { |
||||||
|
text-shadow: 0 -1px 0 rgba(0,0,0,.2); |
||||||
|
@shadow: inset 0 1px 0 rgba(255,255,255,.15), 0 1px 1px rgba(0,0,0,.075); |
||||||
|
.box-shadow(@shadow); |
||||||
|
|
||||||
|
// Reset the shadow |
||||||
|
&:active, |
||||||
|
&.active { |
||||||
|
.box-shadow(inset 0 3px 5px rgba(0,0,0,.125)); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Mixin for generating new styles |
||||||
|
.btn-styles(@btn-color: #555) { |
||||||
|
#gradient > .vertical(@start-color: @btn-color; @end-color: darken(@btn-color, 12%)); |
||||||
|
.reset-filter(); // Disable gradients for IE9 because filter bleeds through rounded corners |
||||||
|
background-repeat: repeat-x; |
||||||
|
border-color: darken(@btn-color, 14%); |
||||||
|
|
||||||
|
&:hover, |
||||||
|
&:focus { |
||||||
|
background-color: darken(@btn-color, 12%); |
||||||
|
background-position: 0 -15px; |
||||||
|
} |
||||||
|
|
||||||
|
&:active, |
||||||
|
&.active { |
||||||
|
background-color: darken(@btn-color, 12%); |
||||||
|
border-color: darken(@btn-color, 14%); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Common styles |
||||||
|
.btn { |
||||||
|
// Remove the gradient for the pressed/active state |
||||||
|
&:active, |
||||||
|
&.active { |
||||||
|
background-image: none; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Apply the mixin to the buttons |
||||||
|
.btn-default { .btn-styles(@btn-default-bg); text-shadow: 0 1px 0 #fff; border-color: #ccc; } |
||||||
|
.btn-primary { .btn-styles(@btn-primary-bg); } |
||||||
|
.btn-success { .btn-styles(@btn-success-bg); } |
||||||
|
.btn-info { .btn-styles(@btn-info-bg); } |
||||||
|
.btn-warning { .btn-styles(@btn-warning-bg); } |
||||||
|
.btn-danger { .btn-styles(@btn-danger-bg); } |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// |
||||||
|
// Images |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
.thumbnail, |
||||||
|
.img-thumbnail { |
||||||
|
.box-shadow(0 1px 2px rgba(0,0,0,.075)); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// |
||||||
|
// Dropdowns |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
.dropdown-menu > li > a:hover, |
||||||
|
.dropdown-menu > li > a:focus { |
||||||
|
#gradient > .vertical(@start-color: @dropdown-link-hover-bg; @end-color: darken(@dropdown-link-hover-bg, 5%)); |
||||||
|
background-color: darken(@dropdown-link-hover-bg, 5%); |
||||||
|
} |
||||||
|
.dropdown-menu > .active > a, |
||||||
|
.dropdown-menu > .active > a:hover, |
||||||
|
.dropdown-menu > .active > a:focus { |
||||||
|
#gradient > .vertical(@start-color: @dropdown-link-active-bg; @end-color: darken(@dropdown-link-active-bg, 5%)); |
||||||
|
background-color: darken(@dropdown-link-active-bg, 5%); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// |
||||||
|
// Navbar |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
// Default navbar |
||||||
|
.navbar-default { |
||||||
|
#gradient > .vertical(@start-color: lighten(@navbar-default-bg, 10%); @end-color: @navbar-default-bg); |
||||||
|
.reset-filter(); // Remove gradient in IE<10 to fix bug where dropdowns don't get triggered |
||||||
|
border-radius: @navbar-border-radius; |
||||||
|
@shadow: inset 0 1px 0 rgba(255,255,255,.15), 0 1px 5px rgba(0,0,0,.075); |
||||||
|
.box-shadow(@shadow); |
||||||
|
|
||||||
|
.navbar-nav > .active > a { |
||||||
|
#gradient > .vertical(@start-color: darken(@navbar-default-bg, 5%); @end-color: darken(@navbar-default-bg, 2%)); |
||||||
|
.box-shadow(inset 0 3px 9px rgba(0,0,0,.075)); |
||||||
|
} |
||||||
|
} |
||||||
|
.navbar-brand, |
||||||
|
.navbar-nav > li > a { |
||||||
|
text-shadow: 0 1px 0 rgba(255,255,255,.25); |
||||||
|
} |
||||||
|
|
||||||
|
// Inverted navbar |
||||||
|
.navbar-inverse { |
||||||
|
#gradient > .vertical(@start-color: lighten(@navbar-inverse-bg, 10%); @end-color: @navbar-inverse-bg); |
||||||
|
.reset-filter(); // Remove gradient in IE<10 to fix bug where dropdowns don't get triggered |
||||||
|
|
||||||
|
.navbar-nav > .active > a { |
||||||
|
#gradient > .vertical(@start-color: @navbar-inverse-bg; @end-color: lighten(@navbar-inverse-bg, 2.5%)); |
||||||
|
.box-shadow(inset 0 3px 9px rgba(0,0,0,.25)); |
||||||
|
} |
||||||
|
|
||||||
|
.navbar-brand, |
||||||
|
.navbar-nav > li > a { |
||||||
|
text-shadow: 0 -1px 0 rgba(0,0,0,.25); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Undo rounded corners in static and fixed navbars |
||||||
|
.navbar-static-top, |
||||||
|
.navbar-fixed-top, |
||||||
|
.navbar-fixed-bottom { |
||||||
|
border-radius: 0; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// |
||||||
|
// Alerts |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
// Common styles |
||||||
|
.alert { |
||||||
|
text-shadow: 0 1px 0 rgba(255,255,255,.2); |
||||||
|
@shadow: inset 0 1px 0 rgba(255,255,255,.25), 0 1px 2px rgba(0,0,0,.05); |
||||||
|
.box-shadow(@shadow); |
||||||
|
} |
||||||
|
|
||||||
|
// Mixin for generating new styles |
||||||
|
.alert-styles(@color) { |
||||||
|
#gradient > .vertical(@start-color: @color; @end-color: darken(@color, 7.5%)); |
||||||
|
border-color: darken(@color, 15%); |
||||||
|
} |
||||||
|
|
||||||
|
// Apply the mixin to the alerts |
||||||
|
.alert-success { .alert-styles(@alert-success-bg); } |
||||||
|
.alert-info { .alert-styles(@alert-info-bg); } |
||||||
|
.alert-warning { .alert-styles(@alert-warning-bg); } |
||||||
|
.alert-danger { .alert-styles(@alert-danger-bg); } |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// |
||||||
|
// Progress bars |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
// Give the progress background some depth |
||||||
|
.progress { |
||||||
|
#gradient > .vertical(@start-color: darken(@progress-bg, 4%); @end-color: @progress-bg) |
||||||
|
} |
||||||
|
|
||||||
|
// Mixin for generating new styles |
||||||
|
.progress-bar-styles(@color) { |
||||||
|
#gradient > .vertical(@start-color: @color; @end-color: darken(@color, 10%)); |
||||||
|
} |
||||||
|
|
||||||
|
// Apply the mixin to the progress bars |
||||||
|
.progress-bar { .progress-bar-styles(@progress-bar-bg); } |
||||||
|
.progress-bar-success { .progress-bar-styles(@progress-bar-success-bg); } |
||||||
|
.progress-bar-info { .progress-bar-styles(@progress-bar-info-bg); } |
||||||
|
.progress-bar-warning { .progress-bar-styles(@progress-bar-warning-bg); } |
||||||
|
.progress-bar-danger { .progress-bar-styles(@progress-bar-danger-bg); } |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// |
||||||
|
// List groups |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
.list-group { |
||||||
|
border-radius: @border-radius-base; |
||||||
|
.box-shadow(0 1px 2px rgba(0,0,0,.075)); |
||||||
|
} |
||||||
|
.list-group-item.active, |
||||||
|
.list-group-item.active:hover, |
||||||
|
.list-group-item.active:focus { |
||||||
|
text-shadow: 0 -1px 0 darken(@list-group-active-bg, 10%); |
||||||
|
#gradient > .vertical(@start-color: @list-group-active-bg; @end-color: darken(@list-group-active-bg, 7.5%)); |
||||||
|
border-color: darken(@list-group-active-border, 7.5%); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// |
||||||
|
// Panels |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
// Common styles |
||||||
|
.panel { |
||||||
|
.box-shadow(0 1px 2px rgba(0,0,0,.05)); |
||||||
|
} |
||||||
|
|
||||||
|
// Mixin for generating new styles |
||||||
|
.panel-heading-styles(@color) { |
||||||
|
#gradient > .vertical(@start-color: @color; @end-color: darken(@color, 5%)); |
||||||
|
} |
||||||
|
|
||||||
|
// Apply the mixin to the panel headings only |
||||||
|
.panel-default > .panel-heading { .panel-heading-styles(@panel-default-heading-bg); } |
||||||
|
.panel-primary > .panel-heading { .panel-heading-styles(@panel-primary-heading-bg); } |
||||||
|
.panel-success > .panel-heading { .panel-heading-styles(@panel-success-heading-bg); } |
||||||
|
.panel-info > .panel-heading { .panel-heading-styles(@panel-info-heading-bg); } |
||||||
|
.panel-warning > .panel-heading { .panel-heading-styles(@panel-warning-heading-bg); } |
||||||
|
.panel-danger > .panel-heading { .panel-heading-styles(@panel-danger-heading-bg); } |
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// |
||||||
|
// Wells |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
.well { |
||||||
|
#gradient > .vertical(@start-color: darken(@well-bg, 5%); @end-color: @well-bg); |
||||||
|
border-color: darken(@well-bg, 10%); |
||||||
|
@shadow: inset 0 1px 3px rgba(0,0,0,.05), 0 1px 0 rgba(255,255,255,.1); |
||||||
|
.box-shadow(@shadow); |
||||||
|
} |
@ -0,0 +1,36 @@ |
|||||||
|
// |
||||||
|
// Thumbnails |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// Mixin and adjust the regular image class |
||||||
|
.thumbnail { |
||||||
|
display: block; |
||||||
|
padding: @thumbnail-padding; |
||||||
|
margin-bottom: @line-height-computed; |
||||||
|
line-height: @line-height-base; |
||||||
|
background-color: @thumbnail-bg; |
||||||
|
border: 1px solid @thumbnail-border; |
||||||
|
border-radius: @thumbnail-border-radius; |
||||||
|
.transition(all .2s ease-in-out); |
||||||
|
|
||||||
|
> img, |
||||||
|
a > img { |
||||||
|
&:extend(.img-responsive); |
||||||
|
margin-left: auto; |
||||||
|
margin-right: auto; |
||||||
|
} |
||||||
|
|
||||||
|
// Add a hover state for linked versions only |
||||||
|
a&:hover, |
||||||
|
a&:focus, |
||||||
|
a&.active { |
||||||
|
border-color: @link-color; |
||||||
|
} |
||||||
|
|
||||||
|
// Image captions |
||||||
|
.caption { |
||||||
|
padding: @thumbnail-caption-padding; |
||||||
|
color: @thumbnail-caption-color; |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,95 @@ |
|||||||
|
// |
||||||
|
// Tooltips |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// Base class |
||||||
|
.tooltip { |
||||||
|
position: absolute; |
||||||
|
z-index: @zindex-tooltip; |
||||||
|
display: block; |
||||||
|
visibility: visible; |
||||||
|
font-size: @font-size-small; |
||||||
|
line-height: 1.4; |
||||||
|
.opacity(0); |
||||||
|
|
||||||
|
&.in { .opacity(@tooltip-opacity); } |
||||||
|
&.top { margin-top: -3px; padding: @tooltip-arrow-width 0; } |
||||||
|
&.right { margin-left: 3px; padding: 0 @tooltip-arrow-width; } |
||||||
|
&.bottom { margin-top: 3px; padding: @tooltip-arrow-width 0; } |
||||||
|
&.left { margin-left: -3px; padding: 0 @tooltip-arrow-width; } |
||||||
|
} |
||||||
|
|
||||||
|
// Wrapper for the tooltip content |
||||||
|
.tooltip-inner { |
||||||
|
max-width: @tooltip-max-width; |
||||||
|
padding: 3px 8px; |
||||||
|
color: @tooltip-color; |
||||||
|
text-align: center; |
||||||
|
text-decoration: none; |
||||||
|
background-color: @tooltip-bg; |
||||||
|
border-radius: @border-radius-base; |
||||||
|
} |
||||||
|
|
||||||
|
// Arrows |
||||||
|
.tooltip-arrow { |
||||||
|
position: absolute; |
||||||
|
width: 0; |
||||||
|
height: 0; |
||||||
|
border-color: transparent; |
||||||
|
border-style: solid; |
||||||
|
} |
||||||
|
.tooltip { |
||||||
|
&.top .tooltip-arrow { |
||||||
|
bottom: 0; |
||||||
|
left: 50%; |
||||||
|
margin-left: -@tooltip-arrow-width; |
||||||
|
border-width: @tooltip-arrow-width @tooltip-arrow-width 0; |
||||||
|
border-top-color: @tooltip-arrow-color; |
||||||
|
} |
||||||
|
&.top-left .tooltip-arrow { |
||||||
|
bottom: 0; |
||||||
|
left: @tooltip-arrow-width; |
||||||
|
border-width: @tooltip-arrow-width @tooltip-arrow-width 0; |
||||||
|
border-top-color: @tooltip-arrow-color; |
||||||
|
} |
||||||
|
&.top-right .tooltip-arrow { |
||||||
|
bottom: 0; |
||||||
|
right: @tooltip-arrow-width; |
||||||
|
border-width: @tooltip-arrow-width @tooltip-arrow-width 0; |
||||||
|
border-top-color: @tooltip-arrow-color; |
||||||
|
} |
||||||
|
&.right .tooltip-arrow { |
||||||
|
top: 50%; |
||||||
|
left: 0; |
||||||
|
margin-top: -@tooltip-arrow-width; |
||||||
|
border-width: @tooltip-arrow-width @tooltip-arrow-width @tooltip-arrow-width 0; |
||||||
|
border-right-color: @tooltip-arrow-color; |
||||||
|
} |
||||||
|
&.left .tooltip-arrow { |
||||||
|
top: 50%; |
||||||
|
right: 0; |
||||||
|
margin-top: -@tooltip-arrow-width; |
||||||
|
border-width: @tooltip-arrow-width 0 @tooltip-arrow-width @tooltip-arrow-width; |
||||||
|
border-left-color: @tooltip-arrow-color; |
||||||
|
} |
||||||
|
&.bottom .tooltip-arrow { |
||||||
|
top: 0; |
||||||
|
left: 50%; |
||||||
|
margin-left: -@tooltip-arrow-width; |
||||||
|
border-width: 0 @tooltip-arrow-width @tooltip-arrow-width; |
||||||
|
border-bottom-color: @tooltip-arrow-color; |
||||||
|
} |
||||||
|
&.bottom-left .tooltip-arrow { |
||||||
|
top: 0; |
||||||
|
left: @tooltip-arrow-width; |
||||||
|
border-width: 0 @tooltip-arrow-width @tooltip-arrow-width; |
||||||
|
border-bottom-color: @tooltip-arrow-color; |
||||||
|
} |
||||||
|
&.bottom-right .tooltip-arrow { |
||||||
|
top: 0; |
||||||
|
right: @tooltip-arrow-width; |
||||||
|
border-width: 0 @tooltip-arrow-width @tooltip-arrow-width; |
||||||
|
border-bottom-color: @tooltip-arrow-color; |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,293 @@ |
|||||||
|
// |
||||||
|
// Typography |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// Headings |
||||||
|
// ------------------------- |
||||||
|
|
||||||
|
h1, h2, h3, h4, h5, h6, |
||||||
|
.h1, .h2, .h3, .h4, .h5, .h6 { |
||||||
|
font-family: @headings-font-family; |
||||||
|
font-weight: @headings-font-weight; |
||||||
|
line-height: @headings-line-height; |
||||||
|
color: @headings-color; |
||||||
|
|
||||||
|
small, |
||||||
|
.small { |
||||||
|
font-weight: normal; |
||||||
|
line-height: 1; |
||||||
|
color: @headings-small-color; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
h1, .h1, |
||||||
|
h2, .h2, |
||||||
|
h3, .h3 { |
||||||
|
margin-top: @line-height-computed; |
||||||
|
margin-bottom: (@line-height-computed / 2); |
||||||
|
|
||||||
|
small, |
||||||
|
.small { |
||||||
|
font-size: 65%; |
||||||
|
} |
||||||
|
} |
||||||
|
h4, .h4, |
||||||
|
h5, .h5, |
||||||
|
h6, .h6 { |
||||||
|
margin-top: (@line-height-computed / 2); |
||||||
|
margin-bottom: (@line-height-computed / 2); |
||||||
|
|
||||||
|
small, |
||||||
|
.small { |
||||||
|
font-size: 75%; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
h1, .h1 { font-size: @font-size-h1; } |
||||||
|
h2, .h2 { font-size: @font-size-h2; } |
||||||
|
h3, .h3 { font-size: @font-size-h3; } |
||||||
|
h4, .h4 { font-size: @font-size-h4; } |
||||||
|
h5, .h5 { font-size: @font-size-h5; } |
||||||
|
h6, .h6 { font-size: @font-size-h6; } |
||||||
|
|
||||||
|
|
||||||
|
// Body text |
||||||
|
// ------------------------- |
||||||
|
|
||||||
|
p { |
||||||
|
margin: 0 0 (@line-height-computed / 2); |
||||||
|
} |
||||||
|
|
||||||
|
.lead { |
||||||
|
margin-bottom: @line-height-computed; |
||||||
|
font-size: floor((@font-size-base * 1.15)); |
||||||
|
font-weight: 200; |
||||||
|
line-height: 1.4; |
||||||
|
|
||||||
|
@media (min-width: @screen-sm-min) { |
||||||
|
font-size: (@font-size-base * 1.5); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Emphasis & misc |
||||||
|
// ------------------------- |
||||||
|
|
||||||
|
// Ex: 14px base font * 85% = about 12px |
||||||
|
small, |
||||||
|
.small { font-size: 85%; } |
||||||
|
|
||||||
|
// Undo browser default styling |
||||||
|
cite { font-style: normal; } |
||||||
|
|
||||||
|
// Alignment |
||||||
|
.text-left { text-align: left; } |
||||||
|
.text-right { text-align: right; } |
||||||
|
.text-center { text-align: center; } |
||||||
|
.text-justify { text-align: justify; } |
||||||
|
|
||||||
|
// Contextual colors |
||||||
|
.text-muted { |
||||||
|
color: @text-muted; |
||||||
|
} |
||||||
|
.text-primary { |
||||||
|
.text-emphasis-variant(@brand-primary); |
||||||
|
} |
||||||
|
.text-success { |
||||||
|
.text-emphasis-variant(@state-success-text); |
||||||
|
} |
||||||
|
.text-info { |
||||||
|
.text-emphasis-variant(@state-info-text); |
||||||
|
} |
||||||
|
.text-warning { |
||||||
|
.text-emphasis-variant(@state-warning-text); |
||||||
|
} |
||||||
|
.text-danger { |
||||||
|
.text-emphasis-variant(@state-danger-text); |
||||||
|
} |
||||||
|
|
||||||
|
// Contextual backgrounds |
||||||
|
// For now we'll leave these alongside the text classes until v4 when we can |
||||||
|
// safely shift things around (per SemVer rules). |
||||||
|
.bg-primary { |
||||||
|
// Given the contrast here, this is the only class to have its color inverted |
||||||
|
// automatically. |
||||||
|
color: #fff; |
||||||
|
.bg-variant(@brand-primary); |
||||||
|
} |
||||||
|
.bg-success { |
||||||
|
.bg-variant(@state-success-bg); |
||||||
|
} |
||||||
|
.bg-info { |
||||||
|
.bg-variant(@state-info-bg); |
||||||
|
} |
||||||
|
.bg-warning { |
||||||
|
.bg-variant(@state-warning-bg); |
||||||
|
} |
||||||
|
.bg-danger { |
||||||
|
.bg-variant(@state-danger-bg); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Page header |
||||||
|
// ------------------------- |
||||||
|
|
||||||
|
.page-header { |
||||||
|
padding-bottom: ((@line-height-computed / 2) - 1); |
||||||
|
margin: (@line-height-computed * 2) 0 @line-height-computed; |
||||||
|
border-bottom: 1px solid @page-header-border-color; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Lists |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
// Unordered and Ordered lists |
||||||
|
ul, |
||||||
|
ol { |
||||||
|
margin-top: 0; |
||||||
|
margin-bottom: (@line-height-computed / 2); |
||||||
|
ul, |
||||||
|
ol { |
||||||
|
margin-bottom: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// List options |
||||||
|
|
||||||
|
// Unstyled keeps list items block level, just removes default browser padding and list-style |
||||||
|
.list-unstyled { |
||||||
|
padding-left: 0; |
||||||
|
list-style: none; |
||||||
|
} |
||||||
|
|
||||||
|
// Inline turns list items into inline-block |
||||||
|
.list-inline { |
||||||
|
.list-unstyled(); |
||||||
|
margin-left: -5px; |
||||||
|
|
||||||
|
> li { |
||||||
|
display: inline-block; |
||||||
|
padding-left: 5px; |
||||||
|
padding-right: 5px; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Description Lists |
||||||
|
dl { |
||||||
|
margin-top: 0; // Remove browser default |
||||||
|
margin-bottom: @line-height-computed; |
||||||
|
} |
||||||
|
dt, |
||||||
|
dd { |
||||||
|
line-height: @line-height-base; |
||||||
|
} |
||||||
|
dt { |
||||||
|
font-weight: bold; |
||||||
|
} |
||||||
|
dd { |
||||||
|
margin-left: 0; // Undo browser default |
||||||
|
} |
||||||
|
|
||||||
|
// Horizontal description lists |
||||||
|
// |
||||||
|
// Defaults to being stacked without any of the below styles applied, until the |
||||||
|
// grid breakpoint is reached (default of ~768px). |
||||||
|
|
||||||
|
@media (min-width: @grid-float-breakpoint) { |
||||||
|
.dl-horizontal { |
||||||
|
dt { |
||||||
|
float: left; |
||||||
|
width: (@component-offset-horizontal - 20); |
||||||
|
clear: left; |
||||||
|
text-align: right; |
||||||
|
.text-overflow(); |
||||||
|
} |
||||||
|
dd { |
||||||
|
margin-left: @component-offset-horizontal; |
||||||
|
&:extend(.clearfix all); // Clear the floated `dt` if an empty `dd` is present |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// MISC |
||||||
|
// ---- |
||||||
|
|
||||||
|
// Abbreviations and acronyms |
||||||
|
abbr[title], |
||||||
|
// Add data-* attribute to help out our tooltip plugin, per https://github.com/twbs/bootstrap/issues/5257 |
||||||
|
abbr[data-original-title] { |
||||||
|
cursor: help; |
||||||
|
border-bottom: 1px dotted @abbr-border-color; |
||||||
|
} |
||||||
|
.initialism { |
||||||
|
font-size: 90%; |
||||||
|
text-transform: uppercase; |
||||||
|
} |
||||||
|
|
||||||
|
// Blockquotes |
||||||
|
blockquote { |
||||||
|
padding: (@line-height-computed / 2) @line-height-computed; |
||||||
|
margin: 0 0 @line-height-computed; |
||||||
|
font-size: @blockquote-font-size; |
||||||
|
border-left: 5px solid @blockquote-border-color; |
||||||
|
|
||||||
|
p, |
||||||
|
ul, |
||||||
|
ol { |
||||||
|
&:last-child { |
||||||
|
margin-bottom: 0; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Note: Deprecated small and .small as of v3.1.0 |
||||||
|
// Context: https://github.com/twbs/bootstrap/issues/11660 |
||||||
|
footer, |
||||||
|
small, |
||||||
|
.small { |
||||||
|
display: block; |
||||||
|
font-size: 80%; // back to default font-size |
||||||
|
line-height: @line-height-base; |
||||||
|
color: @blockquote-small-color; |
||||||
|
|
||||||
|
&:before { |
||||||
|
content: '\2014 \00A0'; // em dash, nbsp |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Opposite alignment of blockquote |
||||||
|
// |
||||||
|
// Heads up: `blockquote.pull-right` has been deprecated as of v3.1.0. |
||||||
|
.blockquote-reverse, |
||||||
|
blockquote.pull-right { |
||||||
|
padding-right: 15px; |
||||||
|
padding-left: 0; |
||||||
|
border-right: 5px solid @blockquote-border-color; |
||||||
|
border-left: 0; |
||||||
|
text-align: right; |
||||||
|
|
||||||
|
// Account for citation |
||||||
|
footer, |
||||||
|
small, |
||||||
|
.small { |
||||||
|
&:before { content: ''; } |
||||||
|
&:after { |
||||||
|
content: '\00A0 \2014'; // nbsp, em dash |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Quotes |
||||||
|
blockquote:before, |
||||||
|
blockquote:after { |
||||||
|
content: ""; |
||||||
|
} |
||||||
|
|
||||||
|
// Addresses |
||||||
|
address { |
||||||
|
margin-bottom: @line-height-computed; |
||||||
|
font-style: normal; |
||||||
|
line-height: @line-height-base; |
||||||
|
} |
@ -0,0 +1,56 @@ |
|||||||
|
// |
||||||
|
// Utility classes |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// Floats |
||||||
|
// ------------------------- |
||||||
|
|
||||||
|
.clearfix { |
||||||
|
.clearfix(); |
||||||
|
} |
||||||
|
.center-block { |
||||||
|
.center-block(); |
||||||
|
} |
||||||
|
.pull-right { |
||||||
|
float: right !important; |
||||||
|
} |
||||||
|
.pull-left { |
||||||
|
float: left !important; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Toggling content |
||||||
|
// ------------------------- |
||||||
|
|
||||||
|
// Note: Deprecated .hide in favor of .hidden or .sr-only (as appropriate) in v3.0.1 |
||||||
|
.hide { |
||||||
|
display: none !important; |
||||||
|
} |
||||||
|
.show { |
||||||
|
display: block !important; |
||||||
|
} |
||||||
|
.invisible { |
||||||
|
visibility: hidden; |
||||||
|
} |
||||||
|
.text-hide { |
||||||
|
.text-hide(); |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// Hide from screenreaders and browsers |
||||||
|
// |
||||||
|
// Credit: HTML5 Boilerplate |
||||||
|
|
||||||
|
.hidden { |
||||||
|
display: none !important; |
||||||
|
visibility: hidden !important; |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
// For Affix plugin |
||||||
|
// ------------------------- |
||||||
|
|
||||||
|
.affix { |
||||||
|
position: fixed; |
||||||
|
} |
@ -0,0 +1,829 @@ |
|||||||
|
// |
||||||
|
// Variables |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
//== Colors |
||||||
|
// |
||||||
|
//## Gray and brand colors for use across Bootstrap. |
||||||
|
|
||||||
|
@gray-darker: lighten(#000, 13.5%); // #222 |
||||||
|
@gray-dark: lighten(#000, 20%); // #333 |
||||||
|
@gray: lighten(#000, 33.5%); // #555 |
||||||
|
@gray-light: lighten(#000, 60%); // #999 |
||||||
|
@gray-lighter: lighten(#000, 93.5%); // #eee |
||||||
|
|
||||||
|
@brand-primary: #428bca; |
||||||
|
@brand-success: #5cb85c; |
||||||
|
@brand-info: #5bc0de; |
||||||
|
@brand-warning: #f0ad4e; |
||||||
|
@brand-danger: #d9534f; |
||||||
|
|
||||||
|
|
||||||
|
//== Scaffolding |
||||||
|
// |
||||||
|
// ## Settings for some of the most global styles. |
||||||
|
|
||||||
|
//** Background color for `<body>`. |
||||||
|
@body-bg: #fff; |
||||||
|
//** Global text color on `<body>`. |
||||||
|
@text-color: @gray-dark; |
||||||
|
|
||||||
|
//** Global textual link color. |
||||||
|
@link-color: @brand-primary; |
||||||
|
//** Link hover color set via `darken()` function. |
||||||
|
@link-hover-color: darken(@link-color, 15%); |
||||||
|
|
||||||
|
|
||||||
|
//== Typography |
||||||
|
// |
||||||
|
//## Font, line-height, and color for body text, headings, and more. |
||||||
|
|
||||||
|
@font-family-sans-serif: "Helvetica Neue", Helvetica, Arial, sans-serif; |
||||||
|
@font-family-serif: Georgia, "Times New Roman", Times, serif; |
||||||
|
//** Default monospace fonts for `<code>`, `<kbd>`, and `<pre>`. |
||||||
|
@font-family-monospace: Menlo, Monaco, Consolas, "Courier New", monospace; |
||||||
|
@font-family-base: @font-family-sans-serif; |
||||||
|
|
||||||
|
@font-size-base: 14px; |
||||||
|
@font-size-large: ceil((@font-size-base * 1.25)); // ~18px |
||||||
|
@font-size-small: ceil((@font-size-base * 0.85)); // ~12px |
||||||
|
|
||||||
|
@font-size-h1: floor((@font-size-base * 2.6)); // ~36px |
||||||
|
@font-size-h2: floor((@font-size-base * 2.15)); // ~30px |
||||||
|
@font-size-h3: ceil((@font-size-base * 1.7)); // ~24px |
||||||
|
@font-size-h4: ceil((@font-size-base * 1.25)); // ~18px |
||||||
|
@font-size-h5: @font-size-base; |
||||||
|
@font-size-h6: ceil((@font-size-base * 0.85)); // ~12px |
||||||
|
|
||||||
|
//** Unit-less `line-height` for use in components like buttons. |
||||||
|
@line-height-base: 1.428571429; // 20/14 |
||||||
|
//** Computed "line-height" (`font-size` * `line-height`) for use with `margin`, `padding`, etc. |
||||||
|
@line-height-computed: floor((@font-size-base * @line-height-base)); // ~20px |
||||||
|
|
||||||
|
//** By default, this inherits from the `<body>`. |
||||||
|
@headings-font-family: inherit; |
||||||
|
@headings-font-weight: 500; |
||||||
|
@headings-line-height: 1.1; |
||||||
|
@headings-color: inherit; |
||||||
|
|
||||||
|
|
||||||
|
//-- Iconography |
||||||
|
// |
||||||
|
//## Specify custom locations of the include Glyphicons icon font. Useful for those including Bootstrap via Bower. |
||||||
|
|
||||||
|
@icon-font-path: "../fonts/"; |
||||||
|
@icon-font-name: "glyphicons-halflings-regular"; |
||||||
|
@icon-font-svg-id: "glyphicons_halflingsregular"; |
||||||
|
|
||||||
|
//== Components |
||||||
|
// |
||||||
|
//## Define common padding and border radius sizes and more. Values based on 14px text and 1.428 line-height (~20px to start). |
||||||
|
|
||||||
|
@padding-base-vertical: 6px; |
||||||
|
@padding-base-horizontal: 12px; |
||||||
|
|
||||||
|
@padding-large-vertical: 10px; |
||||||
|
@padding-large-horizontal: 16px; |
||||||
|
|
||||||
|
@padding-small-vertical: 5px; |
||||||
|
@padding-small-horizontal: 10px; |
||||||
|
|
||||||
|
@padding-xs-vertical: 1px; |
||||||
|
@padding-xs-horizontal: 5px; |
||||||
|
|
||||||
|
@line-height-large: 1.33; |
||||||
|
@line-height-small: 1.5; |
||||||
|
|
||||||
|
@border-radius-base: 4px; |
||||||
|
@border-radius-large: 6px; |
||||||
|
@border-radius-small: 3px; |
||||||
|
|
||||||
|
//** Global color for active items (e.g., navs or dropdowns). |
||||||
|
@component-active-color: #fff; |
||||||
|
//** Global background color for active items (e.g., navs or dropdowns). |
||||||
|
@component-active-bg: @brand-primary; |
||||||
|
|
||||||
|
//** Width of the `border` for generating carets that indicator dropdowns. |
||||||
|
@caret-width-base: 4px; |
||||||
|
//** Carets increase slightly in size for larger components. |
||||||
|
@caret-width-large: 5px; |
||||||
|
|
||||||
|
|
||||||
|
//== Tables |
||||||
|
// |
||||||
|
//## Customizes the `.table` component with basic values, each used across all table variations. |
||||||
|
|
||||||
|
//** Padding for `<th>`s and `<td>`s. |
||||||
|
@table-cell-padding: 8px; |
||||||
|
//** Padding for cells in `.table-condensed`. |
||||||
|
@table-condensed-cell-padding: 5px; |
||||||
|
|
||||||
|
//** Default background color used for all tables. |
||||||
|
@table-bg: transparent; |
||||||
|
//** Background color used for `.table-striped`. |
||||||
|
@table-bg-accent: #f9f9f9; |
||||||
|
//** Background color used for `.table-hover`. |
||||||
|
@table-bg-hover: #f5f5f5; |
||||||
|
@table-bg-active: @table-bg-hover; |
||||||
|
|
||||||
|
//** Border color for table and cell borders. |
||||||
|
@table-border-color: #ddd; |
||||||
|
|
||||||
|
|
||||||
|
//== Buttons |
||||||
|
// |
||||||
|
//## For each of Bootstrap's buttons, define text, background and border color. |
||||||
|
|
||||||
|
@btn-font-weight: normal; |
||||||
|
|
||||||
|
@btn-default-color: #333; |
||||||
|
@btn-default-bg: #fff; |
||||||
|
@btn-default-border: #ccc; |
||||||
|
|
||||||
|
@btn-primary-color: #fff; |
||||||
|
@btn-primary-bg: @brand-primary; |
||||||
|
@btn-primary-border: darken(@btn-primary-bg, 5%); |
||||||
|
|
||||||
|
@btn-success-color: #fff; |
||||||
|
@btn-success-bg: @brand-success; |
||||||
|
@btn-success-border: darken(@btn-success-bg, 5%); |
||||||
|
|
||||||
|
@btn-info-color: #fff; |
||||||
|
@btn-info-bg: @brand-info; |
||||||
|
@btn-info-border: darken(@btn-info-bg, 5%); |
||||||
|
|
||||||
|
@btn-warning-color: #fff; |
||||||
|
@btn-warning-bg: @brand-warning; |
||||||
|
@btn-warning-border: darken(@btn-warning-bg, 5%); |
||||||
|
|
||||||
|
@btn-danger-color: #fff; |
||||||
|
@btn-danger-bg: @brand-danger; |
||||||
|
@btn-danger-border: darken(@btn-danger-bg, 5%); |
||||||
|
|
||||||
|
@btn-link-disabled-color: @gray-light; |
||||||
|
|
||||||
|
|
||||||
|
//== Forms |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
//** `<input>` background color |
||||||
|
@input-bg: #fff; |
||||||
|
//** `<input disabled>` background color |
||||||
|
@input-bg-disabled: @gray-lighter; |
||||||
|
|
||||||
|
//** Text color for `<input>`s |
||||||
|
@input-color: @gray; |
||||||
|
//** `<input>` border color |
||||||
|
@input-border: #ccc; |
||||||
|
//** `<input>` border radius |
||||||
|
@input-border-radius: @border-radius-base; |
||||||
|
//** Border color for inputs on focus |
||||||
|
@input-border-focus: #66afe9; |
||||||
|
|
||||||
|
//** Placeholder text color |
||||||
|
@input-color-placeholder: @gray-light; |
||||||
|
|
||||||
|
//** Default `.form-control` height |
||||||
|
@input-height-base: (@line-height-computed + (@padding-base-vertical * 2) + 2); |
||||||
|
//** Large `.form-control` height |
||||||
|
@input-height-large: (ceil(@font-size-large * @line-height-large) + (@padding-large-vertical * 2) + 2); |
||||||
|
//** Small `.form-control` height |
||||||
|
@input-height-small: (floor(@font-size-small * @line-height-small) + (@padding-small-vertical * 2) + 2); |
||||||
|
|
||||||
|
@legend-color: @gray-dark; |
||||||
|
@legend-border-color: #e5e5e5; |
||||||
|
|
||||||
|
//** Background color for textual input addons |
||||||
|
@input-group-addon-bg: @gray-lighter; |
||||||
|
//** Border color for textual input addons |
||||||
|
@input-group-addon-border-color: @input-border; |
||||||
|
|
||||||
|
|
||||||
|
//== Dropdowns |
||||||
|
// |
||||||
|
//## Dropdown menu container and contents. |
||||||
|
|
||||||
|
//** Background for the dropdown menu. |
||||||
|
@dropdown-bg: #fff; |
||||||
|
//** Dropdown menu `border-color`. |
||||||
|
@dropdown-border: rgba(0,0,0,.15); |
||||||
|
//** Dropdown menu `border-color` **for IE8**. |
||||||
|
@dropdown-fallback-border: #ccc; |
||||||
|
//** Divider color for between dropdown items. |
||||||
|
@dropdown-divider-bg: #e5e5e5; |
||||||
|
|
||||||
|
//** Dropdown link text color. |
||||||
|
@dropdown-link-color: @gray-dark; |
||||||
|
//** Hover color for dropdown links. |
||||||
|
@dropdown-link-hover-color: darken(@gray-dark, 5%); |
||||||
|
//** Hover background for dropdown links. |
||||||
|
@dropdown-link-hover-bg: #f5f5f5; |
||||||
|
|
||||||
|
//** Active dropdown menu item text color. |
||||||
|
@dropdown-link-active-color: @component-active-color; |
||||||
|
//** Active dropdown menu item background color. |
||||||
|
@dropdown-link-active-bg: @component-active-bg; |
||||||
|
|
||||||
|
//** Disabled dropdown menu item background color. |
||||||
|
@dropdown-link-disabled-color: @gray-light; |
||||||
|
|
||||||
|
//** Text color for headers within dropdown menus. |
||||||
|
@dropdown-header-color: @gray-light; |
||||||
|
|
||||||
|
// Note: Deprecated @dropdown-caret-color as of v3.1.0 |
||||||
|
@dropdown-caret-color: #000; |
||||||
|
|
||||||
|
|
||||||
|
//-- Z-index master list |
||||||
|
// |
||||||
|
// Warning: Avoid customizing these values. They're used for a bird's eye view |
||||||
|
// of components dependent on the z-axis and are designed to all work together. |
||||||
|
// |
||||||
|
// Note: These variables are not generated into the Customizer. |
||||||
|
|
||||||
|
@zindex-navbar: 1000; |
||||||
|
@zindex-dropdown: 1000; |
||||||
|
@zindex-popover: 1010; |
||||||
|
@zindex-tooltip: 1030; |
||||||
|
@zindex-navbar-fixed: 1030; |
||||||
|
@zindex-modal-background: 1040; |
||||||
|
@zindex-modal: 1050; |
||||||
|
|
||||||
|
|
||||||
|
//== Media queries breakpoints |
||||||
|
// |
||||||
|
//## Define the breakpoints at which your layout will change, adapting to different screen sizes. |
||||||
|
|
||||||
|
// Extra small screen / phone |
||||||
|
// Note: Deprecated @screen-xs and @screen-phone as of v3.0.1 |
||||||
|
@screen-xs: 480px; |
||||||
|
@screen-xs-min: @screen-xs; |
||||||
|
@screen-phone: @screen-xs-min; |
||||||
|
|
||||||
|
// Small screen / tablet |
||||||
|
// Note: Deprecated @screen-sm and @screen-tablet as of v3.0.1 |
||||||
|
@screen-sm: 768px; |
||||||
|
@screen-sm-min: @screen-sm; |
||||||
|
@screen-tablet: @screen-sm-min; |
||||||
|
|
||||||
|
// Medium screen / desktop |
||||||
|
// Note: Deprecated @screen-md and @screen-desktop as of v3.0.1 |
||||||
|
@screen-md: 992px; |
||||||
|
@screen-md-min: @screen-md; |
||||||
|
@screen-desktop: @screen-md-min; |
||||||
|
|
||||||
|
// Large screen / wide desktop |
||||||
|
// Note: Deprecated @screen-lg and @screen-lg-desktop as of v3.0.1 |
||||||
|
@screen-lg: 1200px; |
||||||
|
@screen-lg-min: @screen-lg; |
||||||
|
@screen-lg-desktop: @screen-lg-min; |
||||||
|
|
||||||
|
// So media queries don't overlap when required, provide a maximum |
||||||
|
@screen-xs-max: (@screen-sm-min - 1); |
||||||
|
@screen-sm-max: (@screen-md-min - 1); |
||||||
|
@screen-md-max: (@screen-lg-min - 1); |
||||||
|
|
||||||
|
|
||||||
|
//== Grid system |
||||||
|
// |
||||||
|
//## Define your custom responsive grid. |
||||||
|
|
||||||
|
//** Number of columns in the grid. |
||||||
|
@grid-columns: 12; |
||||||
|
//** Padding between columns. Gets divided in half for the left and right. |
||||||
|
@grid-gutter-width: 30px; |
||||||
|
// Navbar collapse |
||||||
|
//** Point at which the navbar becomes uncollapsed. |
||||||
|
@grid-float-breakpoint: @screen-sm-min; |
||||||
|
//** Point at which the navbar begins collapsing. |
||||||
|
@grid-float-breakpoint-max: (@grid-float-breakpoint - 1); |
||||||
|
|
||||||
|
|
||||||
|
//== Container sizes |
||||||
|
// |
||||||
|
//## Define the maximum width of `.container` for different screen sizes. |
||||||
|
|
||||||
|
// Small screen / tablet |
||||||
|
@container-tablet: ((720px + @grid-gutter-width)); |
||||||
|
//** For `@screen-sm-min` and up. |
||||||
|
@container-sm: @container-tablet; |
||||||
|
|
||||||
|
// Medium screen / desktop |
||||||
|
@container-desktop: ((940px + @grid-gutter-width)); |
||||||
|
//** For `@screen-md-min` and up. |
||||||
|
@container-md: @container-desktop; |
||||||
|
|
||||||
|
// Large screen / wide desktop |
||||||
|
@container-large-desktop: ((1140px + @grid-gutter-width)); |
||||||
|
//** For `@screen-lg-min` and up. |
||||||
|
@container-lg: @container-large-desktop; |
||||||
|
|
||||||
|
|
||||||
|
//== Navbar |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
// Basics of a navbar |
||||||
|
@navbar-height: 50px; |
||||||
|
@navbar-margin-bottom: @line-height-computed; |
||||||
|
@navbar-border-radius: @border-radius-base; |
||||||
|
@navbar-padding-horizontal: floor((@grid-gutter-width / 2)); |
||||||
|
@navbar-padding-vertical: ((@navbar-height - @line-height-computed) / 2); |
||||||
|
@navbar-collapse-max-height: 340px; |
||||||
|
|
||||||
|
@navbar-default-color: #777; |
||||||
|
@navbar-default-bg: #f8f8f8; |
||||||
|
@navbar-default-border: darken(@navbar-default-bg, 6.5%); |
||||||
|
|
||||||
|
// Navbar links |
||||||
|
@navbar-default-link-color: #777; |
||||||
|
@navbar-default-link-hover-color: #333; |
||||||
|
@navbar-default-link-hover-bg: transparent; |
||||||
|
@navbar-default-link-active-color: #555; |
||||||
|
@navbar-default-link-active-bg: darken(@navbar-default-bg, 6.5%); |
||||||
|
@navbar-default-link-disabled-color: #ccc; |
||||||
|
@navbar-default-link-disabled-bg: transparent; |
||||||
|
|
||||||
|
// Navbar brand label |
||||||
|
@navbar-default-brand-color: @navbar-default-link-color; |
||||||
|
@navbar-default-brand-hover-color: darken(@navbar-default-brand-color, 10%); |
||||||
|
@navbar-default-brand-hover-bg: transparent; |
||||||
|
|
||||||
|
// Navbar toggle |
||||||
|
@navbar-default-toggle-hover-bg: #ddd; |
||||||
|
@navbar-default-toggle-icon-bar-bg: #888; |
||||||
|
@navbar-default-toggle-border-color: #ddd; |
||||||
|
|
||||||
|
|
||||||
|
// Inverted navbar |
||||||
|
// Reset inverted navbar basics |
||||||
|
@navbar-inverse-color: @gray-light; |
||||||
|
@navbar-inverse-bg: #222; |
||||||
|
@navbar-inverse-border: darken(@navbar-inverse-bg, 10%); |
||||||
|
|
||||||
|
// Inverted navbar links |
||||||
|
@navbar-inverse-link-color: @gray-light; |
||||||
|
@navbar-inverse-link-hover-color: #fff; |
||||||
|
@navbar-inverse-link-hover-bg: transparent; |
||||||
|
@navbar-inverse-link-active-color: @navbar-inverse-link-hover-color; |
||||||
|
@navbar-inverse-link-active-bg: darken(@navbar-inverse-bg, 10%); |
||||||
|
@navbar-inverse-link-disabled-color: #444; |
||||||
|
@navbar-inverse-link-disabled-bg: transparent; |
||||||
|
|
||||||
|
// Inverted navbar brand label |
||||||
|
@navbar-inverse-brand-color: @navbar-inverse-link-color; |
||||||
|
@navbar-inverse-brand-hover-color: #fff; |
||||||
|
@navbar-inverse-brand-hover-bg: transparent; |
||||||
|
|
||||||
|
// Inverted navbar toggle |
||||||
|
@navbar-inverse-toggle-hover-bg: #333; |
||||||
|
@navbar-inverse-toggle-icon-bar-bg: #fff; |
||||||
|
@navbar-inverse-toggle-border-color: #333; |
||||||
|
|
||||||
|
|
||||||
|
//== Navs |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
//=== Shared nav styles |
||||||
|
@nav-link-padding: 10px 15px; |
||||||
|
@nav-link-hover-bg: @gray-lighter; |
||||||
|
|
||||||
|
@nav-disabled-link-color: @gray-light; |
||||||
|
@nav-disabled-link-hover-color: @gray-light; |
||||||
|
|
||||||
|
@nav-open-link-hover-color: #fff; |
||||||
|
|
||||||
|
//== Tabs |
||||||
|
@nav-tabs-border-color: #ddd; |
||||||
|
|
||||||
|
@nav-tabs-link-hover-border-color: @gray-lighter; |
||||||
|
|
||||||
|
@nav-tabs-active-link-hover-bg: @body-bg; |
||||||
|
@nav-tabs-active-link-hover-color: @gray; |
||||||
|
@nav-tabs-active-link-hover-border-color: #ddd; |
||||||
|
|
||||||
|
@nav-tabs-justified-link-border-color: #ddd; |
||||||
|
@nav-tabs-justified-active-link-border-color: @body-bg; |
||||||
|
|
||||||
|
//== Pills |
||||||
|
@nav-pills-border-radius: @border-radius-base; |
||||||
|
@nav-pills-active-link-hover-bg: @component-active-bg; |
||||||
|
@nav-pills-active-link-hover-color: @component-active-color; |
||||||
|
|
||||||
|
|
||||||
|
//== Pagination |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
@pagination-color: @link-color; |
||||||
|
@pagination-bg: #fff; |
||||||
|
@pagination-border: #ddd; |
||||||
|
|
||||||
|
@pagination-hover-color: @link-hover-color; |
||||||
|
@pagination-hover-bg: @gray-lighter; |
||||||
|
@pagination-hover-border: #ddd; |
||||||
|
|
||||||
|
@pagination-active-color: #fff; |
||||||
|
@pagination-active-bg: @brand-primary; |
||||||
|
@pagination-active-border: @brand-primary; |
||||||
|
|
||||||
|
@pagination-disabled-color: @gray-light; |
||||||
|
@pagination-disabled-bg: #fff; |
||||||
|
@pagination-disabled-border: #ddd; |
||||||
|
|
||||||
|
|
||||||
|
//== Pager |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
@pager-bg: @pagination-bg; |
||||||
|
@pager-border: @pagination-border; |
||||||
|
@pager-border-radius: 15px; |
||||||
|
|
||||||
|
@pager-hover-bg: @pagination-hover-bg; |
||||||
|
|
||||||
|
@pager-active-bg: @pagination-active-bg; |
||||||
|
@pager-active-color: @pagination-active-color; |
||||||
|
|
||||||
|
@pager-disabled-color: @pagination-disabled-color; |
||||||
|
|
||||||
|
|
||||||
|
//== Jumbotron |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
@jumbotron-padding: 30px; |
||||||
|
@jumbotron-color: inherit; |
||||||
|
@jumbotron-bg: @gray-lighter; |
||||||
|
@jumbotron-heading-color: inherit; |
||||||
|
@jumbotron-font-size: ceil((@font-size-base * 1.5)); |
||||||
|
|
||||||
|
|
||||||
|
//== Form states and alerts |
||||||
|
// |
||||||
|
//## Define colors for form feedback states and, by default, alerts. |
||||||
|
|
||||||
|
@state-success-text: #3c763d; |
||||||
|
@state-success-bg: #dff0d8; |
||||||
|
@state-success-border: darken(spin(@state-success-bg, -10), 5%); |
||||||
|
|
||||||
|
@state-info-text: #31708f; |
||||||
|
@state-info-bg: #d9edf7; |
||||||
|
@state-info-border: darken(spin(@state-info-bg, -10), 7%); |
||||||
|
|
||||||
|
@state-warning-text: #8a6d3b; |
||||||
|
@state-warning-bg: #fcf8e3; |
||||||
|
@state-warning-border: darken(spin(@state-warning-bg, -10), 5%); |
||||||
|
|
||||||
|
@state-danger-text: #a94442; |
||||||
|
@state-danger-bg: #f2dede; |
||||||
|
@state-danger-border: darken(spin(@state-danger-bg, -10), 5%); |
||||||
|
|
||||||
|
|
||||||
|
//== Tooltips |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
//** Tooltip max width |
||||||
|
@tooltip-max-width: 200px; |
||||||
|
//** Tooltip text color |
||||||
|
@tooltip-color: #fff; |
||||||
|
//** Tooltip background color |
||||||
|
@tooltip-bg: #000; |
||||||
|
@tooltip-opacity: .9; |
||||||
|
|
||||||
|
//** Tooltip arrow width |
||||||
|
@tooltip-arrow-width: 5px; |
||||||
|
//** Tooltip arrow color |
||||||
|
@tooltip-arrow-color: @tooltip-bg; |
||||||
|
|
||||||
|
|
||||||
|
//== Popovers |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
//** Popover body background color |
||||||
|
@popover-bg: #fff; |
||||||
|
//** Popover maximum width |
||||||
|
@popover-max-width: 276px; |
||||||
|
//** Popover border color |
||||||
|
@popover-border-color: rgba(0,0,0,.2); |
||||||
|
//** Popover fallback border color |
||||||
|
@popover-fallback-border-color: #ccc; |
||||||
|
|
||||||
|
//** Popover title background color |
||||||
|
@popover-title-bg: darken(@popover-bg, 3%); |
||||||
|
|
||||||
|
//** Popover arrow width |
||||||
|
@popover-arrow-width: 10px; |
||||||
|
//** Popover arrow color |
||||||
|
@popover-arrow-color: #fff; |
||||||
|
|
||||||
|
//** Popover outer arrow width |
||||||
|
@popover-arrow-outer-width: (@popover-arrow-width + 1); |
||||||
|
//** Popover outer arrow color |
||||||
|
@popover-arrow-outer-color: fadein(@popover-border-color, 5%); |
||||||
|
//** Popover outer arrow fallback color |
||||||
|
@popover-arrow-outer-fallback-color: darken(@popover-fallback-border-color, 20%); |
||||||
|
|
||||||
|
|
||||||
|
//== Labels |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
//** Default label background color |
||||||
|
@label-default-bg: @gray-light; |
||||||
|
//** Primary label background color |
||||||
|
@label-primary-bg: @brand-primary; |
||||||
|
//** Success label background color |
||||||
|
@label-success-bg: @brand-success; |
||||||
|
//** Info label background color |
||||||
|
@label-info-bg: @brand-info; |
||||||
|
//** Warning label background color |
||||||
|
@label-warning-bg: @brand-warning; |
||||||
|
//** Danger label background color |
||||||
|
@label-danger-bg: @brand-danger; |
||||||
|
|
||||||
|
//** Default label text color |
||||||
|
@label-color: #fff; |
||||||
|
//** Default text color of a linked label |
||||||
|
@label-link-hover-color: #fff; |
||||||
|
|
||||||
|
|
||||||
|
//== Modals |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
//** Padding applied to the modal body |
||||||
|
@modal-inner-padding: 20px; |
||||||
|
|
||||||
|
//** Padding applied to the modal title |
||||||
|
@modal-title-padding: 15px; |
||||||
|
//** Modal title line-height |
||||||
|
@modal-title-line-height: @line-height-base; |
||||||
|
|
||||||
|
//** Background color of modal content area |
||||||
|
@modal-content-bg: #fff; |
||||||
|
//** Modal content border color |
||||||
|
@modal-content-border-color: rgba(0,0,0,.2); |
||||||
|
//** Modal content border color **for IE8** |
||||||
|
@modal-content-fallback-border-color: #999; |
||||||
|
|
||||||
|
//** Modal backdrop background color |
||||||
|
@modal-backdrop-bg: #000; |
||||||
|
//** Modal backdrop opacity |
||||||
|
@modal-backdrop-opacity: .5; |
||||||
|
//** Modal header border color |
||||||
|
@modal-header-border-color: #e5e5e5; |
||||||
|
//** Modal footer border color |
||||||
|
@modal-footer-border-color: @modal-header-border-color; |
||||||
|
|
||||||
|
@modal-lg: 900px; |
||||||
|
@modal-md: 600px; |
||||||
|
@modal-sm: 300px; |
||||||
|
|
||||||
|
|
||||||
|
//== Alerts |
||||||
|
// |
||||||
|
//## Define alert colors, border radius, and padding. |
||||||
|
|
||||||
|
@alert-padding: 15px; |
||||||
|
@alert-border-radius: @border-radius-base; |
||||||
|
@alert-link-font-weight: bold; |
||||||
|
|
||||||
|
@alert-success-bg: @state-success-bg; |
||||||
|
@alert-success-text: @state-success-text; |
||||||
|
@alert-success-border: @state-success-border; |
||||||
|
|
||||||
|
@alert-info-bg: @state-info-bg; |
||||||
|
@alert-info-text: @state-info-text; |
||||||
|
@alert-info-border: @state-info-border; |
||||||
|
|
||||||
|
@alert-warning-bg: @state-warning-bg; |
||||||
|
@alert-warning-text: @state-warning-text; |
||||||
|
@alert-warning-border: @state-warning-border; |
||||||
|
|
||||||
|
@alert-danger-bg: @state-danger-bg; |
||||||
|
@alert-danger-text: @state-danger-text; |
||||||
|
@alert-danger-border: @state-danger-border; |
||||||
|
|
||||||
|
|
||||||
|
//== Progress bars |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
//** Background color of the whole progress component |
||||||
|
@progress-bg: #f5f5f5; |
||||||
|
//** Progress bar text color |
||||||
|
@progress-bar-color: #fff; |
||||||
|
|
||||||
|
//** Default progress bar color |
||||||
|
@progress-bar-bg: @brand-primary; |
||||||
|
//** Success progress bar color |
||||||
|
@progress-bar-success-bg: @brand-success; |
||||||
|
//** Warning progress bar color |
||||||
|
@progress-bar-warning-bg: @brand-warning; |
||||||
|
//** Danger progress bar color |
||||||
|
@progress-bar-danger-bg: @brand-danger; |
||||||
|
//** Info progress bar color |
||||||
|
@progress-bar-info-bg: @brand-info; |
||||||
|
|
||||||
|
|
||||||
|
//== List group |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
//** Background color on `.list-group-item` |
||||||
|
@list-group-bg: #fff; |
||||||
|
//** `.list-group-item` border color |
||||||
|
@list-group-border: #ddd; |
||||||
|
//** List group border radius |
||||||
|
@list-group-border-radius: @border-radius-base; |
||||||
|
|
||||||
|
//** Background color of single list elements on hover |
||||||
|
@list-group-hover-bg: #f5f5f5; |
||||||
|
//** Text color of active list elements |
||||||
|
@list-group-active-color: @component-active-color; |
||||||
|
//** Background color of active list elements |
||||||
|
@list-group-active-bg: @component-active-bg; |
||||||
|
//** Border color of active list elements |
||||||
|
@list-group-active-border: @list-group-active-bg; |
||||||
|
@list-group-active-text-color: lighten(@list-group-active-bg, 40%); |
||||||
|
|
||||||
|
@list-group-link-color: #555; |
||||||
|
@list-group-link-heading-color: #333; |
||||||
|
|
||||||
|
|
||||||
|
//== Panels |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
@panel-bg: #fff; |
||||||
|
@panel-body-padding: 15px; |
||||||
|
@panel-border-radius: @border-radius-base; |
||||||
|
|
||||||
|
//** Border color for elements within panels |
||||||
|
@panel-inner-border: #ddd; |
||||||
|
@panel-footer-bg: #f5f5f5; |
||||||
|
|
||||||
|
@panel-default-text: @gray-dark; |
||||||
|
@panel-default-border: #ddd; |
||||||
|
@panel-default-heading-bg: #f5f5f5; |
||||||
|
|
||||||
|
@panel-primary-text: #fff; |
||||||
|
@panel-primary-border: @brand-primary; |
||||||
|
@panel-primary-heading-bg: @brand-primary; |
||||||
|
|
||||||
|
@panel-success-text: @state-success-text; |
||||||
|
@panel-success-border: @state-success-border; |
||||||
|
@panel-success-heading-bg: @state-success-bg; |
||||||
|
|
||||||
|
@panel-info-text: @state-info-text; |
||||||
|
@panel-info-border: @state-info-border; |
||||||
|
@panel-info-heading-bg: @state-info-bg; |
||||||
|
|
||||||
|
@panel-warning-text: @state-warning-text; |
||||||
|
@panel-warning-border: @state-warning-border; |
||||||
|
@panel-warning-heading-bg: @state-warning-bg; |
||||||
|
|
||||||
|
@panel-danger-text: @state-danger-text; |
||||||
|
@panel-danger-border: @state-danger-border; |
||||||
|
@panel-danger-heading-bg: @state-danger-bg; |
||||||
|
|
||||||
|
|
||||||
|
//== Thumbnails |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
//** Padding around the thumbnail image |
||||||
|
@thumbnail-padding: 4px; |
||||||
|
//** Thumbnail background color |
||||||
|
@thumbnail-bg: @body-bg; |
||||||
|
//** Thumbnail border color |
||||||
|
@thumbnail-border: #ddd; |
||||||
|
//** Thumbnail border radius |
||||||
|
@thumbnail-border-radius: @border-radius-base; |
||||||
|
|
||||||
|
//** Custom text color for thumbnail captions |
||||||
|
@thumbnail-caption-color: @text-color; |
||||||
|
//** Padding around the thumbnail caption |
||||||
|
@thumbnail-caption-padding: 9px; |
||||||
|
|
||||||
|
|
||||||
|
//== Wells |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
@well-bg: #f5f5f5; |
||||||
|
@well-border: darken(@well-bg, 7%); |
||||||
|
|
||||||
|
|
||||||
|
//== Badges |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
@badge-color: #fff; |
||||||
|
//** Linked badge text color on hover |
||||||
|
@badge-link-hover-color: #fff; |
||||||
|
@badge-bg: @gray-light; |
||||||
|
|
||||||
|
//** Badge text color in active nav link |
||||||
|
@badge-active-color: @link-color; |
||||||
|
//** Badge background color in active nav link |
||||||
|
@badge-active-bg: #fff; |
||||||
|
|
||||||
|
@badge-font-weight: bold; |
||||||
|
@badge-line-height: 1; |
||||||
|
@badge-border-radius: 10px; |
||||||
|
|
||||||
|
|
||||||
|
//== Breadcrumbs |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
@breadcrumb-padding-vertical: 8px; |
||||||
|
@breadcrumb-padding-horizontal: 15px; |
||||||
|
//** Breadcrumb background color |
||||||
|
@breadcrumb-bg: #f5f5f5; |
||||||
|
//** Breadcrumb text color |
||||||
|
@breadcrumb-color: #ccc; |
||||||
|
//** Text color of current page in the breadcrumb |
||||||
|
@breadcrumb-active-color: @gray-light; |
||||||
|
//** Textual separator for between breadcrumb elements |
||||||
|
@breadcrumb-separator: "/"; |
||||||
|
|
||||||
|
|
||||||
|
//== Carousel |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
@carousel-text-shadow: 0 1px 2px rgba(0,0,0,.6); |
||||||
|
|
||||||
|
@carousel-control-color: #fff; |
||||||
|
@carousel-control-width: 15%; |
||||||
|
@carousel-control-opacity: .5; |
||||||
|
@carousel-control-font-size: 20px; |
||||||
|
|
||||||
|
@carousel-indicator-active-bg: #fff; |
||||||
|
@carousel-indicator-border-color: #fff; |
||||||
|
|
||||||
|
@carousel-caption-color: #fff; |
||||||
|
|
||||||
|
|
||||||
|
//== Close |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
@close-font-weight: bold; |
||||||
|
@close-color: #000; |
||||||
|
@close-text-shadow: 0 1px 0 #fff; |
||||||
|
|
||||||
|
|
||||||
|
//== Code |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
@code-color: #c7254e; |
||||||
|
@code-bg: #f9f2f4; |
||||||
|
|
||||||
|
@kbd-color: #fff; |
||||||
|
@kbd-bg: #333; |
||||||
|
|
||||||
|
@pre-bg: #f5f5f5; |
||||||
|
@pre-color: @gray-dark; |
||||||
|
@pre-border-color: #ccc; |
||||||
|
@pre-scrollable-max-height: 340px; |
||||||
|
|
||||||
|
|
||||||
|
//== Type |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
//** Text muted color |
||||||
|
@text-muted: @gray-light; |
||||||
|
//** Abbreviations and acronyms border color |
||||||
|
@abbr-border-color: @gray-light; |
||||||
|
//** Headings small color |
||||||
|
@headings-small-color: @gray-light; |
||||||
|
//** Blockquote small color |
||||||
|
@blockquote-small-color: @gray-light; |
||||||
|
//** Blockquote font size |
||||||
|
@blockquote-font-size: (@font-size-base * 1.25); |
||||||
|
//** Blockquote border color |
||||||
|
@blockquote-border-color: @gray-lighter; |
||||||
|
//** Page header border color |
||||||
|
@page-header-border-color: @gray-lighter; |
||||||
|
|
||||||
|
|
||||||
|
//== Miscellaneous |
||||||
|
// |
||||||
|
//## |
||||||
|
|
||||||
|
//** Horizontal line color. |
||||||
|
@hr-border: @gray-lighter; |
||||||
|
|
||||||
|
//** Horizontal offset for forms and lists. |
||||||
|
@component-offset-horizontal: 180px; |
@ -0,0 +1,29 @@ |
|||||||
|
// |
||||||
|
// Wells |
||||||
|
// -------------------------------------------------- |
||||||
|
|
||||||
|
|
||||||
|
// Base class |
||||||
|
.well { |
||||||
|
min-height: 20px; |
||||||
|
padding: 19px; |
||||||
|
margin-bottom: 20px; |
||||||
|
background-color: @well-bg; |
||||||
|
border: 1px solid @well-border; |
||||||
|
border-radius: @border-radius-base; |
||||||
|
.box-shadow(inset 0 1px 1px rgba(0,0,0,.05)); |
||||||
|
blockquote { |
||||||
|
border-color: #ddd; |
||||||
|
border-color: rgba(0,0,0,.15); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Sizes |
||||||
|
.well-lg { |
||||||
|
padding: 24px; |
||||||
|
border-radius: @border-radius-large; |
||||||
|
} |
||||||
|
.well-sm { |
||||||
|
padding: 9px; |
||||||
|
border-radius: @border-radius-small; |
||||||
|
} |
@ -0,0 +1,70 @@ |
|||||||
|
{ |
||||||
|
"name": "bootstrap", |
||||||
|
"description": "Sleek, intuitive, and powerful front-end framework for faster and easier web development.", |
||||||
|
"version": "3.1.1", |
||||||
|
"keywords": [ |
||||||
|
"bootstrap", |
||||||
|
"css" |
||||||
|
], |
||||||
|
"homepage": "http://getbootstrap.com", |
||||||
|
"author": "Twitter, Inc.", |
||||||
|
"scripts": { |
||||||
|
"test": "grunt test" |
||||||
|
}, |
||||||
|
"style": "./dist/css/bootstrap.css", |
||||||
|
"less": "./less/bootstrap.less", |
||||||
|
"repository": { |
||||||
|
"type": "git", |
||||||
|
"url": "https://github.com/twbs/bootstrap.git" |
||||||
|
}, |
||||||
|
"bugs": { |
||||||
|
"url": "https://github.com/twbs/bootstrap/issues" |
||||||
|
}, |
||||||
|
"license": { |
||||||
|
"type": "MIT", |
||||||
|
"url": "https://github.com/twbs/bootstrap/blob/master/LICENSE" |
||||||
|
}, |
||||||
|
"devDependencies": { |
||||||
|
"btoa": "~1.1.1", |
||||||
|
"canonical-json": "~0.0.3", |
||||||
|
"grunt": "~0.4.2", |
||||||
|
"grunt-banner": "~0.2.0", |
||||||
|
"grunt-contrib-clean": "~0.5.0", |
||||||
|
"grunt-contrib-concat": "~0.3.0", |
||||||
|
"grunt-contrib-connect": "~0.6.0", |
||||||
|
"grunt-contrib-copy": "~0.5.0", |
||||||
|
"grunt-contrib-csslint": "~0.2.0", |
||||||
|
"grunt-contrib-cssmin": "~0.7.0", |
||||||
|
"grunt-contrib-jade": "~0.9.1", |
||||||
|
"grunt-contrib-jshint": "~0.8.0", |
||||||
|
"grunt-contrib-less": "~0.9.0", |
||||||
|
"grunt-contrib-qunit": "~0.4.0", |
||||||
|
"grunt-contrib-uglify": "~0.3.0", |
||||||
|
"grunt-contrib-watch": "~0.5.3", |
||||||
|
"grunt-csscomb": "~2.0.1", |
||||||
|
"grunt-exec": "0.4.3", |
||||||
|
"grunt-html-validation": "~0.1.13", |
||||||
|
"grunt-jekyll": "~0.4.1", |
||||||
|
"grunt-jscs-checker": "~0.3.0", |
||||||
|
"grunt-saucelabs": "~5.0.0", |
||||||
|
"grunt-sed": "~0.1.1", |
||||||
|
"load-grunt-tasks": "~0.3.0", |
||||||
|
"markdown": "~0.5.0" |
||||||
|
}, |
||||||
|
"jspm": { |
||||||
|
"main": "js/bootstrap", |
||||||
|
"directories": { |
||||||
|
"example": "examples", |
||||||
|
"lib": "dist" |
||||||
|
}, |
||||||
|
"shim": { |
||||||
|
"js/bootstrap": { |
||||||
|
"imports": "jquery", |
||||||
|
"exports": "$" |
||||||
|
} |
||||||
|
}, |
||||||
|
"buildConfig": { |
||||||
|
"uglify": true |
||||||
|
} |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,100 @@ |
|||||||
|
## What does `s3_cache.py` do? |
||||||
|
|
||||||
|
### In general |
||||||
|
`s3_cache.py` maintains a cache, stored in an Amazon S3 (Simple Storage Service) bucket, of a given directory whose contents are considered non-critical and are completely & solely determined by (and should be able to be regenerated from) a single given file. |
||||||
|
|
||||||
|
The SHA-256 hash of the single file is used as the key for the cache. The directory is stored as a gzipped tarball. |
||||||
|
|
||||||
|
All the tarballs are stored in S3's Reduced Redundancy Storage (RRS) storage class, since this is cheaper and the data is non-critical. |
||||||
|
|
||||||
|
`s3_cache.py` itself never deletes cache entries; deletion should either be done manually or using automatic S3 lifecycle rules on the bucket. |
||||||
|
|
||||||
|
Similar to git, `s3_cache.py` makes the assumption that [SHA-256 will effectively never have a collision](http://stackoverflow.com/questions/4014090/is-it-safe-to-ignore-the-possibility-of-sha-collisions-in-practice). |
||||||
|
|
||||||
|
|
||||||
|
### For Bootstrap specifically |
||||||
|
`s3_cache.py` is used to cache the npm packages that our Grunt tasks depend on and the RubyGems that Jekyll depends on. (Jekyll is needed to compile our docs to HTML so that we can run them thru an HTML5 validator.) |
||||||
|
|
||||||
|
For npm, the `node_modules` directory is cached based on our `npm-shrinkwrap.canonical.json` file. |
||||||
|
|
||||||
|
For RubyGems, the `gemdir` of the current RVM-selected Ruby is cached based on the `pseudo_Gemfile.lock` file generated by our Travis build script. |
||||||
|
`pseudo_Gemfile.lock` contains the versions of Ruby and Jekyll that we're using (read our `.travis.yml` for details). |
||||||
|
|
||||||
|
|
||||||
|
## Why is `s3_cache.py` necessary? |
||||||
|
`s3_cache.py` is used to speed up Bootstrap's Travis builds. Installing npm packages and RubyGems used to take up a significant fraction of our total build times. Also, at the time that `s3_cache.py` was written, npm was occasionally unreliable. |
||||||
|
|
||||||
|
Travis does offer built-in caching on their paid plans, but this do-it-ourselves S3 solution is significantly cheaper since we only need caching and not Travis' other paid features. |
||||||
|
|
||||||
|
|
||||||
|
## Setup |
||||||
|
|
||||||
|
### Overview |
||||||
|
1. Create an Amazon Web Services (AWS) account. |
||||||
|
2. Create an Identity & Access Management (IAM) user, and note their credentials. |
||||||
|
3. Create an S3 bucket. |
||||||
|
4. Set permissions on the bucket to grant the user read+write access. |
||||||
|
5. Set the user credentials as secure Travis environment variables. |
||||||
|
|
||||||
|
### In detail |
||||||
|
1. Create an AWS account. |
||||||
|
2. Login to the [AWS Management Console](https://console.aws.amazon.com). |
||||||
|
3. Go to the IAM Management Console. |
||||||
|
4. Create a new user (named e.g. `travis-ci`) and generate an access key for them. Note both the Access Key ID and the Secret Access Key. |
||||||
|
5. Note the user's ARN (Amazon Resource Name), which can be found in the "Summary" tab of the user browser. This will be of the form: `arn:aws:iam::XXXXXXXXXXXXXX:user/the-username-goes-here` |
||||||
|
6. Note the user's access key, which can be found in the "Security Credentials" tab of the user browser. |
||||||
|
7. Go to the S3 Management Console. |
||||||
|
8. Create a new bucket. For a non-publicly-accessible bucket (like Bootstrap uses), it's recommended that the bucket name be random to increase security. On most *nix machines, you can easily generate a random UUID to use as the bucket name using Python: |
||||||
|
|
||||||
|
```bash |
||||||
|
python -c "import uuid; print(uuid.uuid4())" |
||||||
|
``` |
||||||
|
|
||||||
|
9. Determine and note what your bucket's ARN is. The ARN for an S3 bucket is of the form: `arn:aws:s3:::the-bucket-name-goes-here` |
||||||
|
10. In the bucket's Properties pane, in the "Permissions" section, click the "Edit bucket policy" button. |
||||||
|
11. Input and submit an IAM Policy that grants the user at least read+write rights to the bucket. AWS has a policy generator and some examples to help with crafting the policy. Here's the policy that Bootstrap uses, with the sensitive bits censored: |
||||||
|
|
||||||
|
```json |
||||||
|
{ |
||||||
|
"Version": "2012-10-17", |
||||||
|
"Id": "PolicyTravisReadWriteNoAdmin", |
||||||
|
"Statement": [ |
||||||
|
{ |
||||||
|
"Sid": "StmtXXXXXXXXXXXXXX", |
||||||
|
"Effect": "Allow", |
||||||
|
"Principal": { |
||||||
|
"AWS": "arn:aws:iam::XXXXXXXXXXXXXX:user/travis-ci" |
||||||
|
}, |
||||||
|
"Action": [ |
||||||
|
"s3:AbortMultipartUpload", |
||||||
|
"s3:GetObjectVersion", |
||||||
|
"s3:ListBucket", |
||||||
|
"s3:DeleteObject", |
||||||
|
"s3:DeleteObjectVersion", |
||||||
|
"s3:GetObject", |
||||||
|
"s3:PutObject" |
||||||
|
], |
||||||
|
"Resource": [ |
||||||
|
"arn:aws:s3:::XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX", |
||||||
|
"arn:aws:s3:::XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX/*" |
||||||
|
] |
||||||
|
} |
||||||
|
] |
||||||
|
} |
||||||
|
``` |
||||||
|
|
||||||
|
12. If you want deletion from the cache to be done automatically based on age (like Bootstrap does): In the bucket's Properties pane, in the "Lifecycle" section, add a rule to expire/delete files based on creation date. |
||||||
|
13. Install the [`travis` RubyGem](https://github.com/travis-ci/travis): `gem install travis` |
||||||
|
14. Encrypt the environment variables: |
||||||
|
|
||||||
|
```bash |
||||||
|
travis encrypt --repo twbs/bootstrap "AWS_ACCESS_KEY_ID=XXX" |
||||||
|
travis encrypt --repo twbs/bootstrap "AWS_SECRET_ACCESS_KEY=XXX" |
||||||
|
travis encrypt --repo twbs/bootstrap "TWBS_S3_BUCKET=XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX" |
||||||
|
``` |
||||||
|
|
||||||
|
14. Add the resulting secure environment variables to `.travis.yml`. |
||||||
|
|
||||||
|
|
||||||
|
## Usage |
||||||
|
Read `s3_cache.py`'s source code and Bootstrap's `.travis.yml` for how to invoke and make use of `s3_cache.py`. |
File diff suppressed because one or more lines are too long
@ -0,0 +1 @@ |
|||||||
|
boto==2.20.0 |
@ -0,0 +1,107 @@ |
|||||||
|
#!/usr/bin/env python2.7 |
||||||
|
from __future__ import absolute_import, unicode_literals, print_function, division |
||||||
|
|
||||||
|
from sys import argv |
||||||
|
from os import environ, stat, remove as _delete_file |
||||||
|
from os.path import isfile, dirname, basename, abspath |
||||||
|
from hashlib import sha256 |
||||||
|
from subprocess import check_call as run |
||||||
|
|
||||||
|
from boto.s3.connection import S3Connection |
||||||
|
from boto.s3.key import Key |
||||||
|
from boto.exception import S3ResponseError |
||||||
|
|
||||||
|
|
||||||
|
NEED_TO_UPLOAD_MARKER = '.need-to-upload' |
||||||
|
BYTES_PER_MB = 1024 * 1024 |
||||||
|
try: |
||||||
|
BUCKET_NAME = environ['TWBS_S3_BUCKET'] |
||||||
|
except KeyError: |
||||||
|
raise SystemExit("TWBS_S3_BUCKET environment variable not set!") |
||||||
|
|
||||||
|
|
||||||
|
def _sha256_of_file(filename): |
||||||
|
hasher = sha256() |
||||||
|
with open(filename, 'rb') as input_file: |
||||||
|
hasher.update(input_file.read()) |
||||||
|
file_hash = hasher.hexdigest() |
||||||
|
print('sha256({}) = {}'.format(filename, file_hash)) |
||||||
|
return file_hash |
||||||
|
|
||||||
|
|
||||||
|
def _delete_file_quietly(filename): |
||||||
|
try: |
||||||
|
_delete_file(filename) |
||||||
|
except (OSError, IOError): |
||||||
|
pass |
||||||
|
|
||||||
|
|
||||||
|
def _tarball_size(directory): |
||||||
|
kib = stat(_tarball_filename_for(directory)).st_size // BYTES_PER_MB |
||||||
|
return "{} MiB".format(kib) |
||||||
|
|
||||||
|
|
||||||
|
def _tarball_filename_for(directory): |
||||||
|
return abspath('./{}.tar.gz'.format(basename(directory))) |
||||||
|
|
||||||
|
|
||||||
|
def _create_tarball(directory): |
||||||
|
print("Creating tarball of {}...".format(directory)) |
||||||
|
run(['tar', '-czf', _tarball_filename_for(directory), '-C', dirname(directory), basename(directory)]) |
||||||
|
|
||||||
|
|
||||||
|
def _extract_tarball(directory): |
||||||
|
print("Extracting tarball of {}...".format(directory)) |
||||||
|
run(['tar', '-xzf', _tarball_filename_for(directory), '-C', dirname(directory)]) |
||||||
|
|
||||||
|
|
||||||
|
def download(directory): |
||||||
|
_delete_file_quietly(NEED_TO_UPLOAD_MARKER) |
||||||
|
try: |
||||||
|
print("Downloading {} tarball from S3...".format(friendly_name)) |
||||||
|
key.get_contents_to_filename(_tarball_filename_for(directory)) |
||||||
|
except S3ResponseError as err: |
||||||
|
open(NEED_TO_UPLOAD_MARKER, 'a').close() |
||||||
|
print(err) |
||||||
|
raise SystemExit("Cached {} download failed!".format(friendly_name)) |
||||||
|
print("Downloaded {}.".format(_tarball_size(directory))) |
||||||
|
_extract_tarball(directory) |
||||||
|
print("{} successfully installed from cache.".format(friendly_name)) |
||||||
|
|
||||||
|
|
||||||
|
def upload(directory): |
||||||
|
_create_tarball(directory) |
||||||
|
print("Uploading {} tarball to S3... ({})".format(friendly_name, _tarball_size(directory))) |
||||||
|
key.set_contents_from_filename(_tarball_filename_for(directory)) |
||||||
|
print("{} cache successfully updated.".format(friendly_name)) |
||||||
|
_delete_file_quietly(NEED_TO_UPLOAD_MARKER) |
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__': |
||||||
|
# Uses environment variables: |
||||||
|
# AWS_ACCESS_KEY_ID -- AWS Access Key ID |
||||||
|
# AWS_SECRET_ACCESS_KEY -- AWS Secret Access Key |
||||||
|
argv.pop(0) |
||||||
|
if len(argv) != 4: |
||||||
|
raise SystemExit("USAGE: s3_cache.py <download | upload> <friendly name> <dependencies file> <directory>") |
||||||
|
mode, friendly_name, dependencies_file, directory = argv |
||||||
|
|
||||||
|
conn = S3Connection() |
||||||
|
bucket = conn.lookup(BUCKET_NAME, validate=False) |
||||||
|
if bucket is None: |
||||||
|
raise SystemExit("Could not access bucket!") |
||||||
|
|
||||||
|
dependencies_file_hash = _sha256_of_file(dependencies_file) |
||||||
|
|
||||||
|
key = Key(bucket, dependencies_file_hash) |
||||||
|
key.storage_class = 'REDUCED_REDUNDANCY' |
||||||
|
|
||||||
|
if mode == 'download': |
||||||
|
download(directory) |
||||||
|
elif mode == 'upload': |
||||||
|
if isfile(NEED_TO_UPLOAD_MARKER): # FIXME |
||||||
|
upload(directory) |
||||||
|
else: |
||||||
|
print("No need to upload anything.") |
||||||
|
else: |
||||||
|
raise SystemExit("Unrecognized mode {!r}".format(mode)) |
@ -0,0 +1,83 @@ |
|||||||
|
[ |
||||||
|
# Docs: https://saucelabs.com/docs/platforms/webdriver |
||||||
|
|
||||||
|
{ |
||||||
|
browserName: "safari", |
||||||
|
platform: "OS X 10.9" |
||||||
|
}, |
||||||
|
# { |
||||||
|
# browserName: "googlechrome", |
||||||
|
# platform: "OS X 10.9", |
||||||
|
# version: "31" |
||||||
|
# }, |
||||||
|
{ |
||||||
|
browserName: "firefox", |
||||||
|
platform: "OS X 10.9" |
||||||
|
}, |
||||||
|
|
||||||
|
# Mac Opera not currently supported by Sauce Labs |
||||||
|
|
||||||
|
{ |
||||||
|
browserName: "internet explorer", |
||||||
|
version: "11", |
||||||
|
platform: "Windows 8.1" |
||||||
|
}, |
||||||
|
{ |
||||||
|
browserName: "internet explorer", |
||||||
|
version: "10", |
||||||
|
platform: "Windows 8" |
||||||
|
}, |
||||||
|
# { |
||||||
|
# browserName: "internet explorer", |
||||||
|
# version: "9", |
||||||
|
# platform: "Windows 7" |
||||||
|
# }, |
||||||
|
# { |
||||||
|
# browserName: "internet explorer", |
||||||
|
# version: "8", |
||||||
|
# platform: "Windows 7" |
||||||
|
# }, |
||||||
|
|
||||||
|
# { # Unofficial |
||||||
|
# browserName: "internet explorer", |
||||||
|
# version: "7", |
||||||
|
# platform: "Windows XP" |
||||||
|
# }, |
||||||
|
|
||||||
|
{ |
||||||
|
browserName: "googlechrome", |
||||||
|
platform: "Windows 8.1" |
||||||
|
}, |
||||||
|
{ |
||||||
|
browserName: "firefox", |
||||||
|
platform: "Windows 8.1" |
||||||
|
}, |
||||||
|
|
||||||
|
# Win Opera 15+ not currently supported by Sauce Labs |
||||||
|
|
||||||
|
{ |
||||||
|
browserName: "iphone", |
||||||
|
platform: "OS X 10.9", |
||||||
|
version: "7" |
||||||
|
}, |
||||||
|
|
||||||
|
# iOS Chrome not currently supported by Sauce Labs |
||||||
|
|
||||||
|
# Linux (unofficial) |
||||||
|
{ |
||||||
|
browserName: "googlechrome", |
||||||
|
platform: "Linux" |
||||||
|
}, |
||||||
|
{ |
||||||
|
browserName: "firefox", |
||||||
|
platform: "Linux" |
||||||
|
} |
||||||
|
|
||||||
|
# Android Chrome not currently supported by Sauce Labs |
||||||
|
|
||||||
|
# { # Android Browser (super-unofficial) |
||||||
|
# browserName: "android", |
||||||
|
# version: "4.0", |
||||||
|
# platform: "Linux" |
||||||
|
# } |
||||||
|
] |
@ -0,0 +1,4 @@ |
|||||||
|
#!/bin/bash |
||||||
|
cp test-infra/npm-shrinkwrap.canonical.json npm-shrinkwrap.json |
||||||
|
npm install |
||||||
|
rm npm-shrinkwrap.json |
@ -1,397 +0,0 @@ |
|||||||
/*! |
|
||||||
* Bootstrap v3.0.3 (http://getbootstrap.com) |
|
||||||
* Copyright 2013 Twitter, Inc. |
|
||||||
* Licensed under http://www.apache.org/licenses/LICENSE-2.0 |
|
||||||
*/ |
|
||||||
|
|
||||||
.btn-default, |
|
||||||
.btn-primary, |
|
||||||
.btn-success, |
|
||||||
.btn-info, |
|
||||||
.btn-warning, |
|
||||||
.btn-danger { |
|
||||||
text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.2); |
|
||||||
-webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15), 0 1px 1px rgba(0, 0, 0, 0.075); |
|
||||||
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15), 0 1px 1px rgba(0, 0, 0, 0.075); |
|
||||||
} |
|
||||||
|
|
||||||
.btn-default:active, |
|
||||||
.btn-primary:active, |
|
||||||
.btn-success:active, |
|
||||||
.btn-info:active, |
|
||||||
.btn-warning:active, |
|
||||||
.btn-danger:active, |
|
||||||
.btn-default.active, |
|
||||||
.btn-primary.active, |
|
||||||
.btn-success.active, |
|
||||||
.btn-info.active, |
|
||||||
.btn-warning.active, |
|
||||||
.btn-danger.active { |
|
||||||
-webkit-box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125); |
|
||||||
box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125); |
|
||||||
} |
|
||||||
|
|
||||||
.btn:active, |
|
||||||
.btn.active { |
|
||||||
background-image: none; |
|
||||||
} |
|
||||||
|
|
||||||
.btn-default { |
|
||||||
text-shadow: 0 1px 0 #fff; |
|
||||||
background-image: -webkit-linear-gradient(top, #ffffff 0%, #e0e0e0 100%); |
|
||||||
background-image: linear-gradient(to bottom, #ffffff 0%, #e0e0e0 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
border-color: #dbdbdb; |
|
||||||
border-color: #ccc; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffffff', endColorstr='#ffe0e0e0', GradientType=0); |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(enabled=false); |
|
||||||
} |
|
||||||
|
|
||||||
.btn-default:hover, |
|
||||||
.btn-default:focus { |
|
||||||
background-color: #e0e0e0; |
|
||||||
background-position: 0 -15px; |
|
||||||
} |
|
||||||
|
|
||||||
.btn-default:active, |
|
||||||
.btn-default.active { |
|
||||||
background-color: #e0e0e0; |
|
||||||
border-color: #dbdbdb; |
|
||||||
} |
|
||||||
|
|
||||||
.btn-primary { |
|
||||||
background-image: -webkit-linear-gradient(top, #428bca 0%, #2d6ca2 100%); |
|
||||||
background-image: linear-gradient(to bottom, #428bca 0%, #2d6ca2 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
border-color: #2b669a; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff428bca', endColorstr='#ff2d6ca2', GradientType=0); |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(enabled=false); |
|
||||||
} |
|
||||||
|
|
||||||
.btn-primary:hover, |
|
||||||
.btn-primary:focus { |
|
||||||
background-color: #2d6ca2; |
|
||||||
background-position: 0 -15px; |
|
||||||
} |
|
||||||
|
|
||||||
.btn-primary:active, |
|
||||||
.btn-primary.active { |
|
||||||
background-color: #2d6ca2; |
|
||||||
border-color: #2b669a; |
|
||||||
} |
|
||||||
|
|
||||||
.btn-success { |
|
||||||
background-image: -webkit-linear-gradient(top, #5cb85c 0%, #419641 100%); |
|
||||||
background-image: linear-gradient(to bottom, #5cb85c 0%, #419641 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
border-color: #3e8f3e; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff5cb85c', endColorstr='#ff419641', GradientType=0); |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(enabled=false); |
|
||||||
} |
|
||||||
|
|
||||||
.btn-success:hover, |
|
||||||
.btn-success:focus { |
|
||||||
background-color: #419641; |
|
||||||
background-position: 0 -15px; |
|
||||||
} |
|
||||||
|
|
||||||
.btn-success:active, |
|
||||||
.btn-success.active { |
|
||||||
background-color: #419641; |
|
||||||
border-color: #3e8f3e; |
|
||||||
} |
|
||||||
|
|
||||||
.btn-warning { |
|
||||||
background-image: -webkit-linear-gradient(top, #f0ad4e 0%, #eb9316 100%); |
|
||||||
background-image: linear-gradient(to bottom, #f0ad4e 0%, #eb9316 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
border-color: #e38d13; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff0ad4e', endColorstr='#ffeb9316', GradientType=0); |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(enabled=false); |
|
||||||
} |
|
||||||
|
|
||||||
.btn-warning:hover, |
|
||||||
.btn-warning:focus { |
|
||||||
background-color: #eb9316; |
|
||||||
background-position: 0 -15px; |
|
||||||
} |
|
||||||
|
|
||||||
.btn-warning:active, |
|
||||||
.btn-warning.active { |
|
||||||
background-color: #eb9316; |
|
||||||
border-color: #e38d13; |
|
||||||
} |
|
||||||
|
|
||||||
.btn-danger { |
|
||||||
background-image: -webkit-linear-gradient(top, #d9534f 0%, #c12e2a 100%); |
|
||||||
background-image: linear-gradient(to bottom, #d9534f 0%, #c12e2a 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
border-color: #b92c28; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffd9534f', endColorstr='#ffc12e2a', GradientType=0); |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(enabled=false); |
|
||||||
} |
|
||||||
|
|
||||||
.btn-danger:hover, |
|
||||||
.btn-danger:focus { |
|
||||||
background-color: #c12e2a; |
|
||||||
background-position: 0 -15px; |
|
||||||
} |
|
||||||
|
|
||||||
.btn-danger:active, |
|
||||||
.btn-danger.active { |
|
||||||
background-color: #c12e2a; |
|
||||||
border-color: #b92c28; |
|
||||||
} |
|
||||||
|
|
||||||
.btn-info { |
|
||||||
background-image: -webkit-linear-gradient(top, #5bc0de 0%, #2aabd2 100%); |
|
||||||
background-image: linear-gradient(to bottom, #5bc0de 0%, #2aabd2 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
border-color: #28a4c9; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff5bc0de', endColorstr='#ff2aabd2', GradientType=0); |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(enabled=false); |
|
||||||
} |
|
||||||
|
|
||||||
.btn-info:hover, |
|
||||||
.btn-info:focus { |
|
||||||
background-color: #2aabd2; |
|
||||||
background-position: 0 -15px; |
|
||||||
} |
|
||||||
|
|
||||||
.btn-info:active, |
|
||||||
.btn-info.active { |
|
||||||
background-color: #2aabd2; |
|
||||||
border-color: #28a4c9; |
|
||||||
} |
|
||||||
|
|
||||||
.thumbnail, |
|
||||||
.img-thumbnail { |
|
||||||
-webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.075); |
|
||||||
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.075); |
|
||||||
} |
|
||||||
|
|
||||||
.dropdown-menu > li > a:hover, |
|
||||||
.dropdown-menu > li > a:focus { |
|
||||||
background-color: #e8e8e8; |
|
||||||
background-image: -webkit-linear-gradient(top, #f5f5f5 0%, #e8e8e8 100%); |
|
||||||
background-image: linear-gradient(to bottom, #f5f5f5 0%, #e8e8e8 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff5f5f5', endColorstr='#ffe8e8e8', GradientType=0); |
|
||||||
} |
|
||||||
|
|
||||||
.dropdown-menu > .active > a, |
|
||||||
.dropdown-menu > .active > a:hover, |
|
||||||
.dropdown-menu > .active > a:focus { |
|
||||||
background-color: #357ebd; |
|
||||||
background-image: -webkit-linear-gradient(top, #428bca 0%, #357ebd 100%); |
|
||||||
background-image: linear-gradient(to bottom, #428bca 0%, #357ebd 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff428bca', endColorstr='#ff357ebd', GradientType=0); |
|
||||||
} |
|
||||||
|
|
||||||
.navbar-default { |
|
||||||
background-image: -webkit-linear-gradient(top, #ffffff 0%, #f8f8f8 100%); |
|
||||||
background-image: linear-gradient(to bottom, #ffffff 0%, #f8f8f8 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
border-radius: 4px; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffffff', endColorstr='#fff8f8f8', GradientType=0); |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(enabled=false); |
|
||||||
-webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15), 0 1px 5px rgba(0, 0, 0, 0.075); |
|
||||||
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15), 0 1px 5px rgba(0, 0, 0, 0.075); |
|
||||||
} |
|
||||||
|
|
||||||
.navbar-default .navbar-nav > .active > a { |
|
||||||
background-image: -webkit-linear-gradient(top, #ebebeb 0%, #f3f3f3 100%); |
|
||||||
background-image: linear-gradient(to bottom, #ebebeb 0%, #f3f3f3 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffebebeb', endColorstr='#fff3f3f3', GradientType=0); |
|
||||||
-webkit-box-shadow: inset 0 3px 9px rgba(0, 0, 0, 0.075); |
|
||||||
box-shadow: inset 0 3px 9px rgba(0, 0, 0, 0.075); |
|
||||||
} |
|
||||||
|
|
||||||
.navbar-brand, |
|
||||||
.navbar-nav > li > a { |
|
||||||
text-shadow: 0 1px 0 rgba(255, 255, 255, 0.25); |
|
||||||
} |
|
||||||
|
|
||||||
.navbar-inverse { |
|
||||||
background-image: -webkit-linear-gradient(top, #3c3c3c 0%, #222222 100%); |
|
||||||
background-image: linear-gradient(to bottom, #3c3c3c 0%, #222222 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff3c3c3c', endColorstr='#ff222222', GradientType=0); |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(enabled=false); |
|
||||||
} |
|
||||||
|
|
||||||
.navbar-inverse .navbar-nav > .active > a { |
|
||||||
background-image: -webkit-linear-gradient(top, #222222 0%, #282828 100%); |
|
||||||
background-image: linear-gradient(to bottom, #222222 0%, #282828 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff222222', endColorstr='#ff282828', GradientType=0); |
|
||||||
-webkit-box-shadow: inset 0 3px 9px rgba(0, 0, 0, 0.25); |
|
||||||
box-shadow: inset 0 3px 9px rgba(0, 0, 0, 0.25); |
|
||||||
} |
|
||||||
|
|
||||||
.navbar-inverse .navbar-brand, |
|
||||||
.navbar-inverse .navbar-nav > li > a { |
|
||||||
text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25); |
|
||||||
} |
|
||||||
|
|
||||||
.navbar-static-top, |
|
||||||
.navbar-fixed-top, |
|
||||||
.navbar-fixed-bottom { |
|
||||||
border-radius: 0; |
|
||||||
} |
|
||||||
|
|
||||||
.alert { |
|
||||||
text-shadow: 0 1px 0 rgba(255, 255, 255, 0.2); |
|
||||||
-webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25), 0 1px 2px rgba(0, 0, 0, 0.05); |
|
||||||
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25), 0 1px 2px rgba(0, 0, 0, 0.05); |
|
||||||
} |
|
||||||
|
|
||||||
.alert-success { |
|
||||||
background-image: -webkit-linear-gradient(top, #dff0d8 0%, #c8e5bc 100%); |
|
||||||
background-image: linear-gradient(to bottom, #dff0d8 0%, #c8e5bc 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
border-color: #b2dba1; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffdff0d8', endColorstr='#ffc8e5bc', GradientType=0); |
|
||||||
} |
|
||||||
|
|
||||||
.alert-info { |
|
||||||
background-image: -webkit-linear-gradient(top, #d9edf7 0%, #b9def0 100%); |
|
||||||
background-image: linear-gradient(to bottom, #d9edf7 0%, #b9def0 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
border-color: #9acfea; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffd9edf7', endColorstr='#ffb9def0', GradientType=0); |
|
||||||
} |
|
||||||
|
|
||||||
.alert-warning { |
|
||||||
background-image: -webkit-linear-gradient(top, #fcf8e3 0%, #f8efc0 100%); |
|
||||||
background-image: linear-gradient(to bottom, #fcf8e3 0%, #f8efc0 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
border-color: #f5e79e; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fffcf8e3', endColorstr='#fff8efc0', GradientType=0); |
|
||||||
} |
|
||||||
|
|
||||||
.alert-danger { |
|
||||||
background-image: -webkit-linear-gradient(top, #f2dede 0%, #e7c3c3 100%); |
|
||||||
background-image: linear-gradient(to bottom, #f2dede 0%, #e7c3c3 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
border-color: #dca7a7; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff2dede', endColorstr='#ffe7c3c3', GradientType=0); |
|
||||||
} |
|
||||||
|
|
||||||
.progress { |
|
||||||
background-image: -webkit-linear-gradient(top, #ebebeb 0%, #f5f5f5 100%); |
|
||||||
background-image: linear-gradient(to bottom, #ebebeb 0%, #f5f5f5 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffebebeb', endColorstr='#fff5f5f5', GradientType=0); |
|
||||||
} |
|
||||||
|
|
||||||
.progress-bar { |
|
||||||
background-image: -webkit-linear-gradient(top, #428bca 0%, #3071a9 100%); |
|
||||||
background-image: linear-gradient(to bottom, #428bca 0%, #3071a9 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff428bca', endColorstr='#ff3071a9', GradientType=0); |
|
||||||
} |
|
||||||
|
|
||||||
.progress-bar-success { |
|
||||||
background-image: -webkit-linear-gradient(top, #5cb85c 0%, #449d44 100%); |
|
||||||
background-image: linear-gradient(to bottom, #5cb85c 0%, #449d44 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff5cb85c', endColorstr='#ff449d44', GradientType=0); |
|
||||||
} |
|
||||||
|
|
||||||
.progress-bar-info { |
|
||||||
background-image: -webkit-linear-gradient(top, #5bc0de 0%, #31b0d5 100%); |
|
||||||
background-image: linear-gradient(to bottom, #5bc0de 0%, #31b0d5 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff5bc0de', endColorstr='#ff31b0d5', GradientType=0); |
|
||||||
} |
|
||||||
|
|
||||||
.progress-bar-warning { |
|
||||||
background-image: -webkit-linear-gradient(top, #f0ad4e 0%, #ec971f 100%); |
|
||||||
background-image: linear-gradient(to bottom, #f0ad4e 0%, #ec971f 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff0ad4e', endColorstr='#ffec971f', GradientType=0); |
|
||||||
} |
|
||||||
|
|
||||||
.progress-bar-danger { |
|
||||||
background-image: -webkit-linear-gradient(top, #d9534f 0%, #c9302c 100%); |
|
||||||
background-image: linear-gradient(to bottom, #d9534f 0%, #c9302c 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffd9534f', endColorstr='#ffc9302c', GradientType=0); |
|
||||||
} |
|
||||||
|
|
||||||
.list-group { |
|
||||||
border-radius: 4px; |
|
||||||
-webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.075); |
|
||||||
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.075); |
|
||||||
} |
|
||||||
|
|
||||||
.list-group-item.active, |
|
||||||
.list-group-item.active:hover, |
|
||||||
.list-group-item.active:focus { |
|
||||||
text-shadow: 0 -1px 0 #3071a9; |
|
||||||
background-image: -webkit-linear-gradient(top, #428bca 0%, #3278b3 100%); |
|
||||||
background-image: linear-gradient(to bottom, #428bca 0%, #3278b3 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
border-color: #3278b3; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff428bca', endColorstr='#ff3278b3', GradientType=0); |
|
||||||
} |
|
||||||
|
|
||||||
.panel { |
|
||||||
-webkit-box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05); |
|
||||||
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05); |
|
||||||
} |
|
||||||
|
|
||||||
.panel-default > .panel-heading { |
|
||||||
background-image: -webkit-linear-gradient(top, #f5f5f5 0%, #e8e8e8 100%); |
|
||||||
background-image: linear-gradient(to bottom, #f5f5f5 0%, #e8e8e8 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff5f5f5', endColorstr='#ffe8e8e8', GradientType=0); |
|
||||||
} |
|
||||||
|
|
||||||
.panel-primary > .panel-heading { |
|
||||||
background-image: -webkit-linear-gradient(top, #428bca 0%, #357ebd 100%); |
|
||||||
background-image: linear-gradient(to bottom, #428bca 0%, #357ebd 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff428bca', endColorstr='#ff357ebd', GradientType=0); |
|
||||||
} |
|
||||||
|
|
||||||
.panel-success > .panel-heading { |
|
||||||
background-image: -webkit-linear-gradient(top, #dff0d8 0%, #d0e9c6 100%); |
|
||||||
background-image: linear-gradient(to bottom, #dff0d8 0%, #d0e9c6 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffdff0d8', endColorstr='#ffd0e9c6', GradientType=0); |
|
||||||
} |
|
||||||
|
|
||||||
.panel-info > .panel-heading { |
|
||||||
background-image: -webkit-linear-gradient(top, #d9edf7 0%, #c4e3f3 100%); |
|
||||||
background-image: linear-gradient(to bottom, #d9edf7 0%, #c4e3f3 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffd9edf7', endColorstr='#ffc4e3f3', GradientType=0); |
|
||||||
} |
|
||||||
|
|
||||||
.panel-warning > .panel-heading { |
|
||||||
background-image: -webkit-linear-gradient(top, #fcf8e3 0%, #faf2cc 100%); |
|
||||||
background-image: linear-gradient(to bottom, #fcf8e3 0%, #faf2cc 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fffcf8e3', endColorstr='#fffaf2cc', GradientType=0); |
|
||||||
} |
|
||||||
|
|
||||||
.panel-danger > .panel-heading { |
|
||||||
background-image: -webkit-linear-gradient(top, #f2dede 0%, #ebcccc 100%); |
|
||||||
background-image: linear-gradient(to bottom, #f2dede 0%, #ebcccc 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff2dede', endColorstr='#ffebcccc', GradientType=0); |
|
||||||
} |
|
||||||
|
|
||||||
.well { |
|
||||||
background-image: -webkit-linear-gradient(top, #e8e8e8 0%, #f5f5f5 100%); |
|
||||||
background-image: linear-gradient(to bottom, #e8e8e8 0%, #f5f5f5 100%); |
|
||||||
background-repeat: repeat-x; |
|
||||||
border-color: #dcdcdc; |
|
||||||
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffe8e8e8', endColorstr='#fff5f5f5', GradientType=0); |
|
||||||
-webkit-box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.05), 0 1px 0 rgba(255, 255, 255, 0.1); |
|
||||||
box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.05), 0 1px 0 rgba(255, 255, 255, 0.1); |
|
||||||
} |
|
File diff suppressed because one or more lines are too long
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
Binary file not shown.
Binary file not shown.
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
@ -0,0 +1,37 @@ |
|||||||
|
{ |
||||||
|
"name": "jquery", |
||||||
|
"version": "2.1.0", |
||||||
|
"main": "dist/jquery.js", |
||||||
|
"license": "MIT", |
||||||
|
"ignore": [ |
||||||
|
"**/.*", |
||||||
|
"build", |
||||||
|
"speed", |
||||||
|
"test", |
||||||
|
"*.md", |
||||||
|
"AUTHORS.txt", |
||||||
|
"Gruntfile.js", |
||||||
|
"package.json" |
||||||
|
], |
||||||
|
"devDependencies": { |
||||||
|
"sizzle": "1.10.16", |
||||||
|
"requirejs": "~2.1.8", |
||||||
|
"qunit": "~1.12.0", |
||||||
|
"sinon": "~1.7.3" |
||||||
|
}, |
||||||
|
"keywords": [ |
||||||
|
"jquery", |
||||||
|
"javascript", |
||||||
|
"library" |
||||||
|
], |
||||||
|
"homepage": "https://github.com/jquery/jquery", |
||||||
|
"_release": "2.1.0", |
||||||
|
"_resolution": { |
||||||
|
"type": "version", |
||||||
|
"tag": "2.1.0", |
||||||
|
"commit": "9434e03193c45d51bbd063a0edd1a07a6178d33f" |
||||||
|
}, |
||||||
|
"_source": "git://github.com/jquery/jquery.git", |
||||||
|
"_target": ">= 1.9.0", |
||||||
|
"_originalSource": "jquery" |
||||||
|
} |
@ -0,0 +1,21 @@ |
|||||||
|
Copyright 2014 jQuery Foundation and other contributors |
||||||
|
http://jquery.com/ |
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining |
||||||
|
a copy of this software and associated documentation files (the |
||||||
|
"Software"), to deal in the Software without restriction, including |
||||||
|
without limitation the rights to use, copy, modify, merge, publish, |
||||||
|
distribute, sublicense, and/or sell copies of the Software, and to |
||||||
|
permit persons to whom the Software is furnished to do so, subject to |
||||||
|
the following conditions: |
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be |
||||||
|
included in all copies or substantial portions of the Software. |
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, |
||||||
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
||||||
|
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND |
||||||
|
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE |
||||||
|
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION |
||||||
|
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION |
||||||
|
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
@ -0,0 +1,27 @@ |
|||||||
|
{ |
||||||
|
"name": "jquery", |
||||||
|
"version": "2.1.0", |
||||||
|
"main": "dist/jquery.js", |
||||||
|
"license": "MIT", |
||||||
|
"ignore": [ |
||||||
|
"**/.*", |
||||||
|
"build", |
||||||
|
"speed", |
||||||
|
"test", |
||||||
|
"*.md", |
||||||
|
"AUTHORS.txt", |
||||||
|
"Gruntfile.js", |
||||||
|
"package.json" |
||||||
|
], |
||||||
|
"devDependencies": { |
||||||
|
"sizzle": "1.10.16", |
||||||
|
"requirejs": "~2.1.8", |
||||||
|
"qunit": "~1.12.0", |
||||||
|
"sinon": "~1.7.3" |
||||||
|
}, |
||||||
|
"keywords": [ |
||||||
|
"jquery", |
||||||
|
"javascript", |
||||||
|
"library" |
||||||
|
] |
||||||
|
} |
@ -0,0 +1,806 @@ |
|||||||
|
define([ |
||||||
|
"./core", |
||||||
|
"./var/rnotwhite", |
||||||
|
"./ajax/var/nonce", |
||||||
|
"./ajax/var/rquery", |
||||||
|
"./core/init", |
||||||
|
"./ajax/parseJSON", |
||||||
|
"./ajax/parseXML", |
||||||
|
"./deferred" |
||||||
|
], function( jQuery, rnotwhite, nonce, rquery ) { |
||||||
|
|
||||||
|
var |
||||||
|
// Document location
|
||||||
|
ajaxLocParts, |
||||||
|
ajaxLocation, |
||||||
|
|
||||||
|
rhash = /#.*$/, |
||||||
|
rts = /([?&])_=[^&]*/, |
||||||
|
rheaders = /^(.*?):[ \t]*([^\r\n]*)$/mg, |
||||||
|
// #7653, #8125, #8152: local protocol detection
|
||||||
|
rlocalProtocol = /^(?:about|app|app-storage|.+-extension|file|res|widget):$/, |
||||||
|
rnoContent = /^(?:GET|HEAD)$/, |
||||||
|
rprotocol = /^\/\//, |
||||||
|
rurl = /^([\w.+-]+:)(?:\/\/(?:[^\/?#]*@|)([^\/?#:]*)(?::(\d+)|)|)/, |
||||||
|
|
||||||
|
/* Prefilters |
||||||
|
* 1) They are useful to introduce custom dataTypes (see ajax/jsonp.js for an example) |
||||||
|
* 2) These are called: |
||||||
|
* - BEFORE asking for a transport |
||||||
|
* - AFTER param serialization (s.data is a string if s.processData is true) |
||||||
|
* 3) key is the dataType |
||||||
|
* 4) the catchall symbol "*" can be used |
||||||
|
* 5) execution will start with transport dataType and THEN continue down to "*" if needed |
||||||
|
*/ |
||||||
|
prefilters = {}, |
||||||
|
|
||||||
|
/* Transports bindings |
||||||
|
* 1) key is the dataType |
||||||
|
* 2) the catchall symbol "*" can be used |
||||||
|
* 3) selection will start with transport dataType and THEN go to "*" if needed |
||||||
|
*/ |
||||||
|
transports = {}, |
||||||
|
|
||||||
|
// Avoid comment-prolog char sequence (#10098); must appease lint and evade compression
|
||||||
|
allTypes = "*/".concat("*"); |
||||||
|
|
||||||
|
// #8138, IE may throw an exception when accessing
|
||||||
|
// a field from window.location if document.domain has been set
|
||||||
|
try { |
||||||
|
ajaxLocation = location.href; |
||||||
|
} catch( e ) { |
||||||
|
// Use the href attribute of an A element
|
||||||
|
// since IE will modify it given document.location
|
||||||
|
ajaxLocation = document.createElement( "a" ); |
||||||
|
ajaxLocation.href = ""; |
||||||
|
ajaxLocation = ajaxLocation.href; |
||||||
|
} |
||||||
|
|
||||||
|
// Segment location into parts
|
||||||
|
ajaxLocParts = rurl.exec( ajaxLocation.toLowerCase() ) || []; |
||||||
|
|
||||||
|
// Base "constructor" for jQuery.ajaxPrefilter and jQuery.ajaxTransport
|
||||||
|
function addToPrefiltersOrTransports( structure ) { |
||||||
|
|
||||||
|
// dataTypeExpression is optional and defaults to "*"
|
||||||
|
return function( dataTypeExpression, func ) { |
||||||
|
|
||||||
|
if ( typeof dataTypeExpression !== "string" ) { |
||||||
|
func = dataTypeExpression; |
||||||
|
dataTypeExpression = "*"; |
||||||
|
} |
||||||
|
|
||||||
|
var dataType, |
||||||
|
i = 0, |
||||||
|
dataTypes = dataTypeExpression.toLowerCase().match( rnotwhite ) || []; |
||||||
|
|
||||||
|
if ( jQuery.isFunction( func ) ) { |
||||||
|
// For each dataType in the dataTypeExpression
|
||||||
|
while ( (dataType = dataTypes[i++]) ) { |
||||||
|
// Prepend if requested
|
||||||
|
if ( dataType[0] === "+" ) { |
||||||
|
dataType = dataType.slice( 1 ) || "*"; |
||||||
|
(structure[ dataType ] = structure[ dataType ] || []).unshift( func ); |
||||||
|
|
||||||
|
// Otherwise append
|
||||||
|
} else { |
||||||
|
(structure[ dataType ] = structure[ dataType ] || []).push( func ); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
}; |
||||||
|
} |
||||||
|
|
||||||
|
// Base inspection function for prefilters and transports
|
||||||
|
function inspectPrefiltersOrTransports( structure, options, originalOptions, jqXHR ) { |
||||||
|
|
||||||
|
var inspected = {}, |
||||||
|
seekingTransport = ( structure === transports ); |
||||||
|
|
||||||
|
function inspect( dataType ) { |
||||||
|
var selected; |
||||||
|
inspected[ dataType ] = true; |
||||||
|
jQuery.each( structure[ dataType ] || [], function( _, prefilterOrFactory ) { |
||||||
|
var dataTypeOrTransport = prefilterOrFactory( options, originalOptions, jqXHR ); |
||||||
|
if ( typeof dataTypeOrTransport === "string" && !seekingTransport && !inspected[ dataTypeOrTransport ] ) { |
||||||
|
options.dataTypes.unshift( dataTypeOrTransport ); |
||||||
|
inspect( dataTypeOrTransport ); |
||||||
|
return false; |
||||||
|
} else if ( seekingTransport ) { |
||||||
|
return !( selected = dataTypeOrTransport ); |
||||||
|
} |
||||||
|
}); |
||||||
|
return selected; |
||||||
|
} |
||||||
|
|
||||||
|
return inspect( options.dataTypes[ 0 ] ) || !inspected[ "*" ] && inspect( "*" ); |
||||||
|
} |
||||||
|
|
||||||
|
// A special extend for ajax options
|
||||||
|
// that takes "flat" options (not to be deep extended)
|
||||||
|
// Fixes #9887
|
||||||
|
function ajaxExtend( target, src ) { |
||||||
|
var key, deep, |
||||||
|
flatOptions = jQuery.ajaxSettings.flatOptions || {}; |
||||||
|
|
||||||
|
for ( key in src ) { |
||||||
|
if ( src[ key ] !== undefined ) { |
||||||
|
( flatOptions[ key ] ? target : ( deep || (deep = {}) ) )[ key ] = src[ key ]; |
||||||
|
} |
||||||
|
} |
||||||
|
if ( deep ) { |
||||||
|
jQuery.extend( true, target, deep ); |
||||||
|
} |
||||||
|
|
||||||
|
return target; |
||||||
|
} |
||||||
|
|
||||||
|
/* Handles responses to an ajax request: |
||||||
|
* - finds the right dataType (mediates between content-type and expected dataType) |
||||||
|
* - returns the corresponding response |
||||||
|
*/ |
||||||
|
function ajaxHandleResponses( s, jqXHR, responses ) { |
||||||
|
|
||||||
|
var ct, type, finalDataType, firstDataType, |
||||||
|
contents = s.contents, |
||||||
|
dataTypes = s.dataTypes; |
||||||
|
|
||||||
|
// Remove auto dataType and get content-type in the process
|
||||||
|
while ( dataTypes[ 0 ] === "*" ) { |
||||||
|
dataTypes.shift(); |
||||||
|
if ( ct === undefined ) { |
||||||
|
ct = s.mimeType || jqXHR.getResponseHeader("Content-Type"); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Check if we're dealing with a known content-type
|
||||||
|
if ( ct ) { |
||||||
|
for ( type in contents ) { |
||||||
|
if ( contents[ type ] && contents[ type ].test( ct ) ) { |
||||||
|
dataTypes.unshift( type ); |
||||||
|
break; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Check to see if we have a response for the expected dataType
|
||||||
|
if ( dataTypes[ 0 ] in responses ) { |
||||||
|
finalDataType = dataTypes[ 0 ]; |
||||||
|
} else { |
||||||
|
// Try convertible dataTypes
|
||||||
|
for ( type in responses ) { |
||||||
|
if ( !dataTypes[ 0 ] || s.converters[ type + " " + dataTypes[0] ] ) { |
||||||
|
finalDataType = type; |
||||||
|
break; |
||||||
|
} |
||||||
|
if ( !firstDataType ) { |
||||||
|
firstDataType = type; |
||||||
|
} |
||||||
|
} |
||||||
|
// Or just use first one
|
||||||
|
finalDataType = finalDataType || firstDataType; |
||||||
|
} |
||||||
|
|
||||||
|
// If we found a dataType
|
||||||
|
// We add the dataType to the list if needed
|
||||||
|
// and return the corresponding response
|
||||||
|
if ( finalDataType ) { |
||||||
|
if ( finalDataType !== dataTypes[ 0 ] ) { |
||||||
|
dataTypes.unshift( finalDataType ); |
||||||
|
} |
||||||
|
return responses[ finalDataType ]; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
/* Chain conversions given the request and the original response |
||||||
|
* Also sets the responseXXX fields on the jqXHR instance |
||||||
|
*/ |
||||||
|
function ajaxConvert( s, response, jqXHR, isSuccess ) { |
||||||
|
var conv2, current, conv, tmp, prev, |
||||||
|
converters = {}, |
||||||
|
// Work with a copy of dataTypes in case we need to modify it for conversion
|
||||||
|
dataTypes = s.dataTypes.slice(); |
||||||
|
|
||||||
|
// Create converters map with lowercased keys
|
||||||
|
if ( dataTypes[ 1 ] ) { |
||||||
|
for ( conv in s.converters ) { |
||||||
|
converters[ conv.toLowerCase() ] = s.converters[ conv ]; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
current = dataTypes.shift(); |
||||||
|
|
||||||
|
// Convert to each sequential dataType
|
||||||
|
while ( current ) { |
||||||
|
|
||||||
|
if ( s.responseFields[ current ] ) { |
||||||
|
jqXHR[ s.responseFields[ current ] ] = response; |
||||||
|
} |
||||||
|
|
||||||
|
// Apply the dataFilter if provided
|
||||||
|
if ( !prev && isSuccess && s.dataFilter ) { |
||||||
|
response = s.dataFilter( response, s.dataType ); |
||||||
|
} |
||||||
|
|
||||||
|
prev = current; |
||||||
|
current = dataTypes.shift(); |
||||||
|
|
||||||
|
if ( current ) { |
||||||
|
|
||||||
|
// There's only work to do if current dataType is non-auto
|
||||||
|
if ( current === "*" ) { |
||||||
|
|
||||||
|
current = prev; |
||||||
|
|
||||||
|
// Convert response if prev dataType is non-auto and differs from current
|
||||||
|
} else if ( prev !== "*" && prev !== current ) { |
||||||
|
|
||||||
|
// Seek a direct converter
|
||||||
|
conv = converters[ prev + " " + current ] || converters[ "* " + current ]; |
||||||
|
|
||||||
|
// If none found, seek a pair
|
||||||
|
if ( !conv ) { |
||||||
|
for ( conv2 in converters ) { |
||||||
|
|
||||||
|
// If conv2 outputs current
|
||||||
|
tmp = conv2.split( " " ); |
||||||
|
if ( tmp[ 1 ] === current ) { |
||||||
|
|
||||||
|
// If prev can be converted to accepted input
|
||||||
|
conv = converters[ prev + " " + tmp[ 0 ] ] || |
||||||
|
converters[ "* " + tmp[ 0 ] ]; |
||||||
|
if ( conv ) { |
||||||
|
// Condense equivalence converters
|
||||||
|
if ( conv === true ) { |
||||||
|
conv = converters[ conv2 ]; |
||||||
|
|
||||||
|
// Otherwise, insert the intermediate dataType
|
||||||
|
} else if ( converters[ conv2 ] !== true ) { |
||||||
|
current = tmp[ 0 ]; |
||||||
|
dataTypes.unshift( tmp[ 1 ] ); |
||||||
|
} |
||||||
|
break; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Apply converter (if not an equivalence)
|
||||||
|
if ( conv !== true ) { |
||||||
|
|
||||||
|
// Unless errors are allowed to bubble, catch and return them
|
||||||
|
if ( conv && s[ "throws" ] ) { |
||||||
|
response = conv( response ); |
||||||
|
} else { |
||||||
|
try { |
||||||
|
response = conv( response ); |
||||||
|
} catch ( e ) { |
||||||
|
return { state: "parsererror", error: conv ? e : "No conversion from " + prev + " to " + current }; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
return { state: "success", data: response }; |
||||||
|
} |
||||||
|
|
||||||
|
jQuery.extend({ |
||||||
|
|
||||||
|
// Counter for holding the number of active queries
|
||||||
|
active: 0, |
||||||
|
|
||||||
|
// Last-Modified header cache for next request
|
||||||
|
lastModified: {}, |
||||||
|
etag: {}, |
||||||
|
|
||||||
|
ajaxSettings: { |
||||||
|
url: ajaxLocation, |
||||||
|
type: "GET", |
||||||
|
isLocal: rlocalProtocol.test( ajaxLocParts[ 1 ] ), |
||||||
|
global: true, |
||||||
|
processData: true, |
||||||
|
async: true, |
||||||
|
contentType: "application/x-www-form-urlencoded; charset=UTF-8", |
||||||
|
/* |
||||||
|
timeout: 0, |
||||||
|
data: null, |
||||||
|
dataType: null, |
||||||
|
username: null, |
||||||
|
password: null, |
||||||
|
cache: null, |
||||||
|
throws: false, |
||||||
|
traditional: false, |
||||||
|
headers: {}, |
||||||
|
*/ |
||||||
|
|
||||||
|
accepts: { |
||||||
|
"*": allTypes, |
||||||
|
text: "text/plain", |
||||||
|
html: "text/html", |
||||||
|
xml: "application/xml, text/xml", |
||||||
|
json: "application/json, text/javascript" |
||||||
|
}, |
||||||
|
|
||||||
|
contents: { |
||||||
|
xml: /xml/, |
||||||
|
html: /html/, |
||||||
|
json: /json/ |
||||||
|
}, |
||||||
|
|
||||||
|
responseFields: { |
||||||
|
xml: "responseXML", |
||||||
|
text: "responseText", |
||||||
|
json: "responseJSON" |
||||||
|
}, |
||||||
|
|
||||||
|
// Data converters
|
||||||
|
// Keys separate source (or catchall "*") and destination types with a single space
|
||||||
|
converters: { |
||||||
|
|
||||||
|
// Convert anything to text
|
||||||
|
"* text": String, |
||||||
|
|
||||||
|
// Text to html (true = no transformation)
|
||||||
|
"text html": true, |
||||||
|
|
||||||
|
// Evaluate text as a json expression
|
||||||
|
"text json": jQuery.parseJSON, |
||||||
|
|
||||||
|
// Parse text as xml
|
||||||
|
"text xml": jQuery.parseXML |
||||||
|
}, |
||||||
|
|
||||||
|
// For options that shouldn't be deep extended:
|
||||||
|
// you can add your own custom options here if
|
||||||
|
// and when you create one that shouldn't be
|
||||||
|
// deep extended (see ajaxExtend)
|
||||||
|
flatOptions: { |
||||||
|
url: true, |
||||||
|
context: true |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
// Creates a full fledged settings object into target
|
||||||
|
// with both ajaxSettings and settings fields.
|
||||||
|
// If target is omitted, writes into ajaxSettings.
|
||||||
|
ajaxSetup: function( target, settings ) { |
||||||
|
return settings ? |
||||||
|
|
||||||
|
// Building a settings object
|
||||||
|
ajaxExtend( ajaxExtend( target, jQuery.ajaxSettings ), settings ) : |
||||||
|
|
||||||
|
// Extending ajaxSettings
|
||||||
|
ajaxExtend( jQuery.ajaxSettings, target ); |
||||||
|
}, |
||||||
|
|
||||||
|
ajaxPrefilter: addToPrefiltersOrTransports( prefilters ), |
||||||
|
ajaxTransport: addToPrefiltersOrTransports( transports ), |
||||||
|
|
||||||
|
// Main method
|
||||||
|
ajax: function( url, options ) { |
||||||
|
|
||||||
|
// If url is an object, simulate pre-1.5 signature
|
||||||
|
if ( typeof url === "object" ) { |
||||||
|
options = url; |
||||||
|
url = undefined; |
||||||
|
} |
||||||
|
|
||||||
|
// Force options to be an object
|
||||||
|
options = options || {}; |
||||||
|
|
||||||
|
var transport, |
||||||
|
// URL without anti-cache param
|
||||||
|
cacheURL, |
||||||
|
// Response headers
|
||||||
|
responseHeadersString, |
||||||
|
responseHeaders, |
||||||
|
// timeout handle
|
||||||
|
timeoutTimer, |
||||||
|
// Cross-domain detection vars
|
||||||
|
parts, |
||||||
|
// To know if global events are to be dispatched
|
||||||
|
fireGlobals, |
||||||
|
// Loop variable
|
||||||
|
i, |
||||||
|
// Create the final options object
|
||||||
|
s = jQuery.ajaxSetup( {}, options ), |
||||||
|
// Callbacks context
|
||||||
|
callbackContext = s.context || s, |
||||||
|
// Context for global events is callbackContext if it is a DOM node or jQuery collection
|
||||||
|
globalEventContext = s.context && ( callbackContext.nodeType || callbackContext.jquery ) ? |
||||||
|
jQuery( callbackContext ) : |
||||||
|
jQuery.event, |
||||||
|
// Deferreds
|
||||||
|
deferred = jQuery.Deferred(), |
||||||
|
completeDeferred = jQuery.Callbacks("once memory"), |
||||||
|
// Status-dependent callbacks
|
||||||
|
statusCode = s.statusCode || {}, |
||||||
|
// Headers (they are sent all at once)
|
||||||
|
requestHeaders = {}, |
||||||
|
requestHeadersNames = {}, |
||||||
|
// The jqXHR state
|
||||||
|
state = 0, |
||||||
|
// Default abort message
|
||||||
|
strAbort = "canceled", |
||||||
|
// Fake xhr
|
||||||
|
jqXHR = { |
||||||
|
readyState: 0, |
||||||
|
|
||||||
|
// Builds headers hashtable if needed
|
||||||
|
getResponseHeader: function( key ) { |
||||||
|
var match; |
||||||
|
if ( state === 2 ) { |
||||||
|
if ( !responseHeaders ) { |
||||||
|
responseHeaders = {}; |
||||||
|
while ( (match = rheaders.exec( responseHeadersString )) ) { |
||||||
|
responseHeaders[ match[1].toLowerCase() ] = match[ 2 ]; |
||||||
|
} |
||||||
|
} |
||||||
|
match = responseHeaders[ key.toLowerCase() ]; |
||||||
|
} |
||||||
|
return match == null ? null : match; |
||||||
|
}, |
||||||
|
|
||||||
|
// Raw string
|
||||||
|
getAllResponseHeaders: function() { |
||||||
|
return state === 2 ? responseHeadersString : null; |
||||||
|
}, |
||||||
|
|
||||||
|
// Caches the header
|
||||||
|
setRequestHeader: function( name, value ) { |
||||||
|
var lname = name.toLowerCase(); |
||||||
|
if ( !state ) { |
||||||
|
name = requestHeadersNames[ lname ] = requestHeadersNames[ lname ] || name; |
||||||
|
requestHeaders[ name ] = value; |
||||||
|
} |
||||||
|
return this; |
||||||
|
}, |
||||||
|
|
||||||
|
// Overrides response content-type header
|
||||||
|
overrideMimeType: function( type ) { |
||||||
|
if ( !state ) { |
||||||
|
s.mimeType = type; |
||||||
|
} |
||||||
|
return this; |
||||||
|
}, |
||||||
|
|
||||||
|
// Status-dependent callbacks
|
||||||
|
statusCode: function( map ) { |
||||||
|
var code; |
||||||
|
if ( map ) { |
||||||
|
if ( state < 2 ) { |
||||||
|
for ( code in map ) { |
||||||
|
// Lazy-add the new callback in a way that preserves old ones
|
||||||
|
statusCode[ code ] = [ statusCode[ code ], map[ code ] ]; |
||||||
|
} |
||||||
|
} else { |
||||||
|
// Execute the appropriate callbacks
|
||||||
|
jqXHR.always( map[ jqXHR.status ] ); |
||||||
|
} |
||||||
|
} |
||||||
|
return this; |
||||||
|
}, |
||||||
|
|
||||||
|
// Cancel the request
|
||||||
|
abort: function( statusText ) { |
||||||
|
var finalText = statusText || strAbort; |
||||||
|
if ( transport ) { |
||||||
|
transport.abort( finalText ); |
||||||
|
} |
||||||
|
done( 0, finalText ); |
||||||
|
return this; |
||||||
|
} |
||||||
|
}; |
||||||
|
|
||||||
|
// Attach deferreds
|
||||||
|
deferred.promise( jqXHR ).complete = completeDeferred.add; |
||||||
|
jqXHR.success = jqXHR.done; |
||||||
|
jqXHR.error = jqXHR.fail; |
||||||
|
|
||||||
|
// Remove hash character (#7531: and string promotion)
|
||||||
|
// Add protocol if not provided (prefilters might expect it)
|
||||||
|
// Handle falsy url in the settings object (#10093: consistency with old signature)
|
||||||
|
// We also use the url parameter if available
|
||||||
|
s.url = ( ( url || s.url || ajaxLocation ) + "" ).replace( rhash, "" ) |
||||||
|
.replace( rprotocol, ajaxLocParts[ 1 ] + "//" ); |
||||||
|
|
||||||
|
// Alias method option to type as per ticket #12004
|
||||||
|
s.type = options.method || options.type || s.method || s.type; |
||||||
|
|
||||||
|
// Extract dataTypes list
|
||||||
|
s.dataTypes = jQuery.trim( s.dataType || "*" ).toLowerCase().match( rnotwhite ) || [ "" ]; |
||||||
|
|
||||||
|
// A cross-domain request is in order when we have a protocol:host:port mismatch
|
||||||
|
if ( s.crossDomain == null ) { |
||||||
|
parts = rurl.exec( s.url.toLowerCase() ); |
||||||
|
s.crossDomain = !!( parts && |
||||||
|
( parts[ 1 ] !== ajaxLocParts[ 1 ] || parts[ 2 ] !== ajaxLocParts[ 2 ] || |
||||||
|
( parts[ 3 ] || ( parts[ 1 ] === "http:" ? "80" : "443" ) ) !== |
||||||
|
( ajaxLocParts[ 3 ] || ( ajaxLocParts[ 1 ] === "http:" ? "80" : "443" ) ) ) |
||||||
|
); |
||||||
|
} |
||||||
|
|
||||||
|
// Convert data if not already a string
|
||||||
|
if ( s.data && s.processData && typeof s.data !== "string" ) { |
||||||
|
s.data = jQuery.param( s.data, s.traditional ); |
||||||
|
} |
||||||
|
|
||||||
|
// Apply prefilters
|
||||||
|
inspectPrefiltersOrTransports( prefilters, s, options, jqXHR ); |
||||||
|
|
||||||
|
// If request was aborted inside a prefilter, stop there
|
||||||
|
if ( state === 2 ) { |
||||||
|
return jqXHR; |
||||||
|
} |
||||||
|
|
||||||
|
// We can fire global events as of now if asked to
|
||||||
|
fireGlobals = s.global; |
||||||
|
|
||||||
|
// Watch for a new set of requests
|
||||||
|
if ( fireGlobals && jQuery.active++ === 0 ) { |
||||||
|
jQuery.event.trigger("ajaxStart"); |
||||||
|
} |
||||||
|
|
||||||
|
// Uppercase the type
|
||||||
|
s.type = s.type.toUpperCase(); |
||||||
|
|
||||||
|
// Determine if request has content
|
||||||
|
s.hasContent = !rnoContent.test( s.type ); |
||||||
|
|
||||||
|
// Save the URL in case we're toying with the If-Modified-Since
|
||||||
|
// and/or If-None-Match header later on
|
||||||
|
cacheURL = s.url; |
||||||
|
|
||||||
|
// More options handling for requests with no content
|
||||||
|
if ( !s.hasContent ) { |
||||||
|
|
||||||
|
// If data is available, append data to url
|
||||||
|
if ( s.data ) { |
||||||
|
cacheURL = ( s.url += ( rquery.test( cacheURL ) ? "&" : "?" ) + s.data ); |
||||||
|
// #9682: remove data so that it's not used in an eventual retry
|
||||||
|
delete s.data; |
||||||
|
} |
||||||
|
|
||||||
|
// Add anti-cache in url if needed
|
||||||
|
if ( s.cache === false ) { |
||||||
|
s.url = rts.test( cacheURL ) ? |
||||||
|
|
||||||
|
// If there is already a '_' parameter, set its value
|
||||||
|
cacheURL.replace( rts, "$1_=" + nonce++ ) : |
||||||
|
|
||||||
|
// Otherwise add one to the end
|
||||||
|
cacheURL + ( rquery.test( cacheURL ) ? "&" : "?" ) + "_=" + nonce++; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Set the If-Modified-Since and/or If-None-Match header, if in ifModified mode.
|
||||||
|
if ( s.ifModified ) { |
||||||
|
if ( jQuery.lastModified[ cacheURL ] ) { |
||||||
|
jqXHR.setRequestHeader( "If-Modified-Since", jQuery.lastModified[ cacheURL ] ); |
||||||
|
} |
||||||
|
if ( jQuery.etag[ cacheURL ] ) { |
||||||
|
jqXHR.setRequestHeader( "If-None-Match", jQuery.etag[ cacheURL ] ); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Set the correct header, if data is being sent
|
||||||
|
if ( s.data && s.hasContent && s.contentType !== false || options.contentType ) { |
||||||
|
jqXHR.setRequestHeader( "Content-Type", s.contentType ); |
||||||
|
} |
||||||
|
|
||||||
|
// Set the Accepts header for the server, depending on the dataType
|
||||||
|
jqXHR.setRequestHeader( |
||||||
|
"Accept", |
||||||
|
s.dataTypes[ 0 ] && s.accepts[ s.dataTypes[0] ] ? |
||||||
|
s.accepts[ s.dataTypes[0] ] + ( s.dataTypes[ 0 ] !== "*" ? ", " + allTypes + "; q=0.01" : "" ) : |
||||||
|
s.accepts[ "*" ] |
||||||
|
); |
||||||
|
|
||||||
|
// Check for headers option
|
||||||
|
for ( i in s.headers ) { |
||||||
|
jqXHR.setRequestHeader( i, s.headers[ i ] ); |
||||||
|
} |
||||||
|
|
||||||
|
// Allow custom headers/mimetypes and early abort
|
||||||
|
if ( s.beforeSend && ( s.beforeSend.call( callbackContext, jqXHR, s ) === false || state === 2 ) ) { |
||||||
|
// Abort if not done already and return
|
||||||
|
return jqXHR.abort(); |
||||||
|
} |
||||||
|
|
||||||
|
// aborting is no longer a cancellation
|
||||||
|
strAbort = "abort"; |
||||||
|
|
||||||
|
// Install callbacks on deferreds
|
||||||
|
for ( i in { success: 1, error: 1, complete: 1 } ) { |
||||||
|
jqXHR[ i ]( s[ i ] ); |
||||||
|
} |
||||||
|
|
||||||
|
// Get transport
|
||||||
|
transport = inspectPrefiltersOrTransports( transports, s, options, jqXHR ); |
||||||
|
|
||||||
|
// If no transport, we auto-abort
|
||||||
|
if ( !transport ) { |
||||||
|
done( -1, "No Transport" ); |
||||||
|
} else { |
||||||
|
jqXHR.readyState = 1; |
||||||
|
|
||||||
|
// Send global event
|
||||||
|
if ( fireGlobals ) { |
||||||
|
globalEventContext.trigger( "ajaxSend", [ jqXHR, s ] ); |
||||||
|
} |
||||||
|
// Timeout
|
||||||
|
if ( s.async && s.timeout > 0 ) { |
||||||
|
timeoutTimer = setTimeout(function() { |
||||||
|
jqXHR.abort("timeout"); |
||||||
|
}, s.timeout ); |
||||||
|
} |
||||||
|
|
||||||
|
try { |
||||||
|
state = 1; |
||||||
|
transport.send( requestHeaders, done ); |
||||||
|
} catch ( e ) { |
||||||
|
// Propagate exception as error if not done
|
||||||
|
if ( state < 2 ) { |
||||||
|
done( -1, e ); |
||||||
|
// Simply rethrow otherwise
|
||||||
|
} else { |
||||||
|
throw e; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Callback for when everything is done
|
||||||
|
function done( status, nativeStatusText, responses, headers ) { |
||||||
|
var isSuccess, success, error, response, modified, |
||||||
|
statusText = nativeStatusText; |
||||||
|
|
||||||
|
// Called once
|
||||||
|
if ( state === 2 ) { |
||||||
|
return; |
||||||
|
} |
||||||
|
|
||||||
|
// State is "done" now
|
||||||
|
state = 2; |
||||||
|
|
||||||
|
// Clear timeout if it exists
|
||||||
|
if ( timeoutTimer ) { |
||||||
|
clearTimeout( timeoutTimer ); |
||||||
|
} |
||||||
|
|
||||||
|
// Dereference transport for early garbage collection
|
||||||
|
// (no matter how long the jqXHR object will be used)
|
||||||
|
transport = undefined; |
||||||
|
|
||||||
|
// Cache response headers
|
||||||
|
responseHeadersString = headers || ""; |
||||||
|
|
||||||
|
// Set readyState
|
||||||
|
jqXHR.readyState = status > 0 ? 4 : 0; |
||||||
|
|
||||||
|
// Determine if successful
|
||||||
|
isSuccess = status >= 200 && status < 300 || status === 304; |
||||||
|
|
||||||
|
// Get response data
|
||||||
|
if ( responses ) { |
||||||
|
response = ajaxHandleResponses( s, jqXHR, responses ); |
||||||
|
} |
||||||
|
|
||||||
|
// Convert no matter what (that way responseXXX fields are always set)
|
||||||
|
response = ajaxConvert( s, response, jqXHR, isSuccess ); |
||||||
|
|
||||||
|
// If successful, handle type chaining
|
||||||
|
if ( isSuccess ) { |
||||||
|
|
||||||
|
// Set the If-Modified-Since and/or If-None-Match header, if in ifModified mode.
|
||||||
|
if ( s.ifModified ) { |
||||||
|
modified = jqXHR.getResponseHeader("Last-Modified"); |
||||||
|
if ( modified ) { |
||||||
|
jQuery.lastModified[ cacheURL ] = modified; |
||||||
|
} |
||||||
|
modified = jqXHR.getResponseHeader("etag"); |
||||||
|
if ( modified ) { |
||||||
|
jQuery.etag[ cacheURL ] = modified; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// if no content
|
||||||
|
if ( status === 204 || s.type === "HEAD" ) { |
||||||
|
statusText = "nocontent"; |
||||||
|
|
||||||
|
// if not modified
|
||||||
|
} else if ( status === 304 ) { |
||||||
|
statusText = "notmodified"; |
||||||
|
|
||||||
|
// If we have data, let's convert it
|
||||||
|
} else { |
||||||
|
statusText = response.state; |
||||||
|
success = response.data; |
||||||
|
error = response.error; |
||||||
|
isSuccess = !error; |
||||||
|
} |
||||||
|
} else { |
||||||
|
// We extract error from statusText
|
||||||
|
// then normalize statusText and status for non-aborts
|
||||||
|
error = statusText; |
||||||
|
if ( status || !statusText ) { |
||||||
|
statusText = "error"; |
||||||
|
if ( status < 0 ) { |
||||||
|
status = 0; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Set data for the fake xhr object
|
||||||
|
jqXHR.status = status; |
||||||
|
jqXHR.statusText = ( nativeStatusText || statusText ) + ""; |
||||||
|
|
||||||
|
// Success/Error
|
||||||
|
if ( isSuccess ) { |
||||||
|
deferred.resolveWith( callbackContext, [ success, statusText, jqXHR ] ); |
||||||
|
} else { |
||||||
|
deferred.rejectWith( callbackContext, [ jqXHR, statusText, error ] ); |
||||||
|
} |
||||||
|
|
||||||
|
// Status-dependent callbacks
|
||||||
|
jqXHR.statusCode( statusCode ); |
||||||
|
statusCode = undefined; |
||||||
|
|
||||||
|
if ( fireGlobals ) { |
||||||
|
globalEventContext.trigger( isSuccess ? "ajaxSuccess" : "ajaxError", |
||||||
|
[ jqXHR, s, isSuccess ? success : error ] ); |
||||||
|
} |
||||||
|
|
||||||
|
// Complete
|
||||||
|
completeDeferred.fireWith( callbackContext, [ jqXHR, statusText ] ); |
||||||
|
|
||||||
|
if ( fireGlobals ) { |
||||||
|
globalEventContext.trigger( "ajaxComplete", [ jqXHR, s ] ); |
||||||
|
// Handle the global AJAX counter
|
||||||
|
if ( !( --jQuery.active ) ) { |
||||||
|
jQuery.event.trigger("ajaxStop"); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
return jqXHR; |
||||||
|
}, |
||||||
|
|
||||||
|
getJSON: function( url, data, callback ) { |
||||||
|
return jQuery.get( url, data, callback, "json" ); |
||||||
|
}, |
||||||
|
|
||||||
|
getScript: function( url, callback ) { |
||||||
|
return jQuery.get( url, undefined, callback, "script" ); |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
jQuery.each( [ "get", "post" ], function( i, method ) { |
||||||
|
jQuery[ method ] = function( url, data, callback, type ) { |
||||||
|
// shift arguments if data argument was omitted
|
||||||
|
if ( jQuery.isFunction( data ) ) { |
||||||
|
type = type || callback; |
||||||
|
callback = data; |
||||||
|
data = undefined; |
||||||
|
} |
||||||
|
|
||||||
|
return jQuery.ajax({ |
||||||
|
url: url, |
||||||
|
type: method, |
||||||
|
dataType: type, |
||||||
|
data: data, |
||||||
|
success: callback |
||||||
|
}); |
||||||
|
}; |
||||||
|
}); |
||||||
|
|
||||||
|
// Attach a bunch of functions for handling common AJAX events
|
||||||
|
jQuery.each( [ "ajaxStart", "ajaxStop", "ajaxComplete", "ajaxError", "ajaxSuccess", "ajaxSend" ], function( i, type ) { |
||||||
|
jQuery.fn[ type ] = function( fn ) { |
||||||
|
return this.on( type, fn ); |
||||||
|
}; |
||||||
|
}); |
||||||
|
|
||||||
|
return jQuery; |
||||||
|
}); |
@ -0,0 +1,89 @@ |
|||||||
|
define([ |
||||||
|
"../core", |
||||||
|
"./var/nonce", |
||||||
|
"./var/rquery", |
||||||
|
"../ajax" |
||||||
|
], function( jQuery, nonce, rquery ) { |
||||||
|
|
||||||
|
var oldCallbacks = [], |
||||||
|
rjsonp = /(=)\?(?=&|$)|\?\?/; |
||||||
|
|
||||||
|
// Default jsonp settings
|
||||||
|
jQuery.ajaxSetup({ |
||||||
|
jsonp: "callback", |
||||||
|
jsonpCallback: function() { |
||||||
|
var callback = oldCallbacks.pop() || ( jQuery.expando + "_" + ( nonce++ ) ); |
||||||
|
this[ callback ] = true; |
||||||
|
return callback; |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
// Detect, normalize options and install callbacks for jsonp requests
|
||||||
|
jQuery.ajaxPrefilter( "json jsonp", function( s, originalSettings, jqXHR ) { |
||||||
|
|
||||||
|
var callbackName, overwritten, responseContainer, |
||||||
|
jsonProp = s.jsonp !== false && ( rjsonp.test( s.url ) ? |
||||||
|
"url" : |
||||||
|
typeof s.data === "string" && !( s.contentType || "" ).indexOf("application/x-www-form-urlencoded") && rjsonp.test( s.data ) && "data" |
||||||
|
); |
||||||
|
|
||||||
|
// Handle iff the expected data type is "jsonp" or we have a parameter to set
|
||||||
|
if ( jsonProp || s.dataTypes[ 0 ] === "jsonp" ) { |
||||||
|
|
||||||
|
// Get callback name, remembering preexisting value associated with it
|
||||||
|
callbackName = s.jsonpCallback = jQuery.isFunction( s.jsonpCallback ) ? |
||||||
|
s.jsonpCallback() : |
||||||
|
s.jsonpCallback; |
||||||
|
|
||||||
|
// Insert callback into url or form data
|
||||||
|
if ( jsonProp ) { |
||||||
|
s[ jsonProp ] = s[ jsonProp ].replace( rjsonp, "$1" + callbackName ); |
||||||
|
} else if ( s.jsonp !== false ) { |
||||||
|
s.url += ( rquery.test( s.url ) ? "&" : "?" ) + s.jsonp + "=" + callbackName; |
||||||
|
} |
||||||
|
|
||||||
|
// Use data converter to retrieve json after script execution
|
||||||
|
s.converters["script json"] = function() { |
||||||
|
if ( !responseContainer ) { |
||||||
|
jQuery.error( callbackName + " was not called" ); |
||||||
|
} |
||||||
|
return responseContainer[ 0 ]; |
||||||
|
}; |
||||||
|
|
||||||
|
// force json dataType
|
||||||
|
s.dataTypes[ 0 ] = "json"; |
||||||
|
|
||||||
|
// Install callback
|
||||||
|
overwritten = window[ callbackName ]; |
||||||
|
window[ callbackName ] = function() { |
||||||
|
responseContainer = arguments; |
||||||
|
}; |
||||||
|
|
||||||
|
// Clean-up function (fires after converters)
|
||||||
|
jqXHR.always(function() { |
||||||
|
// Restore preexisting value
|
||||||
|
window[ callbackName ] = overwritten; |
||||||
|
|
||||||
|
// Save back as free
|
||||||
|
if ( s[ callbackName ] ) { |
||||||
|
// make sure that re-using the options doesn't screw things around
|
||||||
|
s.jsonpCallback = originalSettings.jsonpCallback; |
||||||
|
|
||||||
|
// save the callback name for future use
|
||||||
|
oldCallbacks.push( callbackName ); |
||||||
|
} |
||||||
|
|
||||||
|
// Call if it was a function and we have a response
|
||||||
|
if ( responseContainer && jQuery.isFunction( overwritten ) ) { |
||||||
|
overwritten( responseContainer[ 0 ] ); |
||||||
|
} |
||||||
|
|
||||||
|
responseContainer = overwritten = undefined; |
||||||
|
}); |
||||||
|
|
||||||
|
// Delegate to script
|
||||||
|
return "script"; |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
}); |
@ -0,0 +1,75 @@ |
|||||||
|
define([ |
||||||
|
"../core", |
||||||
|
"../core/parseHTML", |
||||||
|
"../ajax", |
||||||
|
"../traversing", |
||||||
|
"../manipulation", |
||||||
|
"../selector", |
||||||
|
// Optional event/alias dependency
|
||||||
|
"../event/alias" |
||||||
|
], function( jQuery ) { |
||||||
|
|
||||||
|
// Keep a copy of the old load method
|
||||||
|
var _load = jQuery.fn.load; |
||||||
|
|
||||||
|
/** |
||||||
|
* Load a url into a page |
||||||
|
*/ |
||||||
|
jQuery.fn.load = function( url, params, callback ) { |
||||||
|
if ( typeof url !== "string" && _load ) { |
||||||
|
return _load.apply( this, arguments ); |
||||||
|
} |
||||||
|
|
||||||
|
var selector, type, response, |
||||||
|
self = this, |
||||||
|
off = url.indexOf(" "); |
||||||
|
|
||||||
|
if ( off >= 0 ) { |
||||||
|
selector = url.slice( off ); |
||||||
|
url = url.slice( 0, off ); |
||||||
|
} |
||||||
|
|
||||||
|
// If it's a function
|
||||||
|
if ( jQuery.isFunction( params ) ) { |
||||||
|
|
||||||
|
// We assume that it's the callback
|
||||||
|
callback = params; |
||||||
|
params = undefined; |
||||||
|
|
||||||
|
// Otherwise, build a param string
|
||||||
|
} else if ( params && typeof params === "object" ) { |
||||||
|
type = "POST"; |
||||||
|
} |
||||||
|
|
||||||
|
// If we have elements to modify, make the request
|
||||||
|
if ( self.length > 0 ) { |
||||||
|
jQuery.ajax({ |
||||||
|
url: url, |
||||||
|
|
||||||
|
// if "type" variable is undefined, then "GET" method will be used
|
||||||
|
type: type, |
||||||
|
dataType: "html", |
||||||
|
data: params |
||||||
|
}).done(function( responseText ) { |
||||||
|
|
||||||
|
// Save response for use in complete callback
|
||||||
|
response = arguments; |
||||||
|
|
||||||
|
self.html( selector ? |
||||||
|
|
||||||
|
// If a selector was specified, locate the right elements in a dummy div
|
||||||
|
// Exclude scripts to avoid IE 'Permission Denied' errors
|
||||||
|
jQuery("<div>").append( jQuery.parseHTML( responseText ) ).find( selector ) : |
||||||
|
|
||||||
|
// Otherwise use the full result
|
||||||
|
responseText ); |
||||||
|
|
||||||
|
}).complete( callback && function( jqXHR, status ) { |
||||||
|
self.each( callback, response || [ jqXHR.responseText, status, jqXHR ] ); |
||||||
|
}); |
||||||
|
} |
||||||
|
|
||||||
|
return this; |
||||||
|
}; |
||||||
|
|
||||||
|
}); |
@ -0,0 +1,13 @@ |
|||||||
|
define([ |
||||||
|
"../core" |
||||||
|
], function( jQuery ) { |
||||||
|
|
||||||
|
// Support: Android 2.3
|
||||||
|
// Workaround failure to string-cast null input
|
||||||
|
jQuery.parseJSON = function( data ) { |
||||||
|
return JSON.parse( data + "" ); |
||||||
|
}; |
||||||
|
|
||||||
|
return jQuery.parseJSON; |
||||||
|
|
||||||
|
}); |
@ -0,0 +1,28 @@ |
|||||||
|
define([ |
||||||
|
"../core" |
||||||
|
], function( jQuery ) { |
||||||
|
|
||||||
|
// Cross-browser xml parsing
|
||||||
|
jQuery.parseXML = function( data ) { |
||||||
|
var xml, tmp; |
||||||
|
if ( !data || typeof data !== "string" ) { |
||||||
|
return null; |
||||||
|
} |
||||||
|
|
||||||
|
// Support: IE9
|
||||||
|
try { |
||||||
|
tmp = new DOMParser(); |
||||||
|
xml = tmp.parseFromString( data, "text/xml" ); |
||||||
|
} catch ( e ) { |
||||||
|
xml = undefined; |
||||||
|
} |
||||||
|
|
||||||
|
if ( !xml || xml.getElementsByTagName( "parsererror" ).length ) { |
||||||
|
jQuery.error( "Invalid XML: " + data ); |
||||||
|
} |
||||||
|
return xml; |
||||||
|
}; |
||||||
|
|
||||||
|
return jQuery.parseXML; |
||||||
|
|
||||||
|
}); |
@ -0,0 +1,64 @@ |
|||||||
|
define([ |
||||||
|
"../core", |
||||||
|
"../ajax" |
||||||
|
], function( jQuery ) { |
||||||
|
|
||||||
|
// Install script dataType
|
||||||
|
jQuery.ajaxSetup({ |
||||||
|
accepts: { |
||||||
|
script: "text/javascript, application/javascript, application/ecmascript, application/x-ecmascript" |
||||||
|
}, |
||||||
|
contents: { |
||||||
|
script: /(?:java|ecma)script/ |
||||||
|
}, |
||||||
|
converters: { |
||||||
|
"text script": function( text ) { |
||||||
|
jQuery.globalEval( text ); |
||||||
|
return text; |
||||||
|
} |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
// Handle cache's special case and crossDomain
|
||||||
|
jQuery.ajaxPrefilter( "script", function( s ) { |
||||||
|
if ( s.cache === undefined ) { |
||||||
|
s.cache = false; |
||||||
|
} |
||||||
|
if ( s.crossDomain ) { |
||||||
|
s.type = "GET"; |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
// Bind script tag hack transport
|
||||||
|
jQuery.ajaxTransport( "script", function( s ) { |
||||||
|
// This transport only deals with cross domain requests
|
||||||
|
if ( s.crossDomain ) { |
||||||
|
var script, callback; |
||||||
|
return { |
||||||
|
send: function( _, complete ) { |
||||||
|
script = jQuery("<script>").prop({ |
||||||
|
async: true, |
||||||
|
charset: s.scriptCharset, |
||||||
|
src: s.url |
||||||
|
}).on( |
||||||
|
"load error", |
||||||
|
callback = function( evt ) { |
||||||
|
script.remove(); |
||||||
|
callback = null; |
||||||
|
if ( evt ) { |
||||||
|
complete( evt.type === "error" ? 404 : 200, evt.type ); |
||||||
|
} |
||||||
|
} |
||||||
|
); |
||||||
|
document.head.appendChild( script[ 0 ] ); |
||||||
|
}, |
||||||
|
abort: function() { |
||||||
|
if ( callback ) { |
||||||
|
callback(); |
||||||
|
} |
||||||
|
} |
||||||
|
}; |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
}); |
@ -0,0 +1,130 @@ |
|||||||
|
define([ |
||||||
|
"../core", |
||||||
|
"../var/support", |
||||||
|
"../ajax" |
||||||
|
], function( jQuery, support ) { |
||||||
|
|
||||||
|
jQuery.ajaxSettings.xhr = function() { |
||||||
|
try { |
||||||
|
return new XMLHttpRequest(); |
||||||
|
} catch( e ) {} |
||||||
|
}; |
||||||
|
|
||||||
|
var xhrId = 0, |
||||||
|
xhrCallbacks = {}, |
||||||
|
xhrSuccessStatus = { |
||||||
|
// file protocol always yields status code 0, assume 200
|
||||||
|
0: 200, |
||||||
|
// Support: IE9
|
||||||
|
// #1450: sometimes IE returns 1223 when it should be 204
|
||||||
|
1223: 204 |
||||||
|
}, |
||||||
|
xhrSupported = jQuery.ajaxSettings.xhr(); |
||||||
|
|
||||||
|
// Support: IE9
|
||||||
|
// Open requests must be manually aborted on unload (#5280)
|
||||||
|
if ( window.ActiveXObject ) { |
||||||
|
jQuery( window ).on( "unload", function() { |
||||||
|
for ( var key in xhrCallbacks ) { |
||||||
|
xhrCallbacks[ key ](); |
||||||
|
} |
||||||
|
}); |
||||||
|
} |
||||||
|
|
||||||
|
support.cors = !!xhrSupported && ( "withCredentials" in xhrSupported ); |
||||||
|
support.ajax = xhrSupported = !!xhrSupported; |
||||||
|
|
||||||
|
jQuery.ajaxTransport(function( options ) { |
||||||
|
var callback; |
||||||
|
|
||||||
|
// Cross domain only allowed if supported through XMLHttpRequest
|
||||||
|
if ( support.cors || xhrSupported && !options.crossDomain ) { |
||||||
|
return { |
||||||
|
send: function( headers, complete ) { |
||||||
|
var i, |
||||||
|
xhr = options.xhr(), |
||||||
|
id = ++xhrId; |
||||||
|
|
||||||
|
xhr.open( options.type, options.url, options.async, options.username, options.password ); |
||||||
|
|
||||||
|
// Apply custom fields if provided
|
||||||
|
if ( options.xhrFields ) { |
||||||
|
for ( i in options.xhrFields ) { |
||||||
|
xhr[ i ] = options.xhrFields[ i ]; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Override mime type if needed
|
||||||
|
if ( options.mimeType && xhr.overrideMimeType ) { |
||||||
|
xhr.overrideMimeType( options.mimeType ); |
||||||
|
} |
||||||
|
|
||||||
|
// X-Requested-With header
|
||||||
|
// For cross-domain requests, seeing as conditions for a preflight are
|
||||||
|
// akin to a jigsaw puzzle, we simply never set it to be sure.
|
||||||
|
// (it can always be set on a per-request basis or even using ajaxSetup)
|
||||||
|
// For same-domain requests, won't change header if already provided.
|
||||||
|
if ( !options.crossDomain && !headers["X-Requested-With"] ) { |
||||||
|
headers["X-Requested-With"] = "XMLHttpRequest"; |
||||||
|
} |
||||||
|
|
||||||
|
// Set headers
|
||||||
|
for ( i in headers ) { |
||||||
|
xhr.setRequestHeader( i, headers[ i ] ); |
||||||
|
} |
||||||
|
|
||||||
|
// Callback
|
||||||
|
callback = function( type ) { |
||||||
|
return function() { |
||||||
|
if ( callback ) { |
||||||
|
delete xhrCallbacks[ id ]; |
||||||
|
callback = xhr.onload = xhr.onerror = null; |
||||||
|
|
||||||
|
if ( type === "abort" ) { |
||||||
|
xhr.abort(); |
||||||
|
} else if ( type === "error" ) { |
||||||
|
complete( |
||||||
|
// file: protocol always yields status 0; see #8605, #14207
|
||||||
|
xhr.status, |
||||||
|
xhr.statusText |
||||||
|
); |
||||||
|
} else { |
||||||
|
complete( |
||||||
|
xhrSuccessStatus[ xhr.status ] || xhr.status, |
||||||
|
xhr.statusText, |
||||||
|
// Support: IE9
|
||||||
|
// Accessing binary-data responseText throws an exception
|
||||||
|
// (#11426)
|
||||||
|
typeof xhr.responseText === "string" ? { |
||||||
|
text: xhr.responseText |
||||||
|
} : undefined, |
||||||
|
xhr.getAllResponseHeaders() |
||||||
|
); |
||||||
|
} |
||||||
|
} |
||||||
|
}; |
||||||
|
}; |
||||||
|
|
||||||
|
// Listen to events
|
||||||
|
xhr.onload = callback(); |
||||||
|
xhr.onerror = callback("error"); |
||||||
|
|
||||||
|
// Create the abort callback
|
||||||
|
callback = xhrCallbacks[ id ] = callback("abort"); |
||||||
|
|
||||||
|
// Do send the request
|
||||||
|
// This may raise an exception which is actually
|
||||||
|
// handled in jQuery.ajax (so no try/catch here)
|
||||||
|
xhr.send( options.hasContent && options.data || null ); |
||||||
|
}, |
||||||
|
|
||||||
|
abort: function() { |
||||||
|
if ( callback ) { |
||||||
|
callback(); |
||||||
|
} |
||||||
|
} |
||||||
|
}; |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
}); |
@ -0,0 +1,11 @@ |
|||||||
|
define([ |
||||||
|
"./core", |
||||||
|
"./attributes/attr", |
||||||
|
"./attributes/prop", |
||||||
|
"./attributes/classes", |
||||||
|
"./attributes/val" |
||||||
|
], function( jQuery ) { |
||||||
|
|
||||||
|
// Return jQuery for attributes-only inclusion
|
||||||
|
return jQuery; |
||||||
|
}); |
@ -0,0 +1,143 @@ |
|||||||
|
define([ |
||||||
|
"../core", |
||||||
|
"../var/rnotwhite", |
||||||
|
"../var/strundefined", |
||||||
|
"../core/access", |
||||||
|
"./support", |
||||||
|
"../selector" |
||||||
|
], function( jQuery, rnotwhite, strundefined, access, support ) { |
||||||
|
|
||||||
|
var nodeHook, boolHook, |
||||||
|
attrHandle = jQuery.expr.attrHandle; |
||||||
|
|
||||||
|
jQuery.fn.extend({ |
||||||
|
attr: function( name, value ) { |
||||||
|
return access( this, jQuery.attr, name, value, arguments.length > 1 ); |
||||||
|
}, |
||||||
|
|
||||||
|
removeAttr: function( name ) { |
||||||
|
return this.each(function() { |
||||||
|
jQuery.removeAttr( this, name ); |
||||||
|
}); |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
jQuery.extend({ |
||||||
|
attr: function( elem, name, value ) { |
||||||
|
var hooks, ret, |
||||||
|
nType = elem.nodeType; |
||||||
|
|
||||||
|
// don't get/set attributes on text, comment and attribute nodes
|
||||||
|
if ( !elem || nType === 3 || nType === 8 || nType === 2 ) { |
||||||
|
return; |
||||||
|
} |
||||||
|
|
||||||
|
// Fallback to prop when attributes are not supported
|
||||||
|
if ( typeof elem.getAttribute === strundefined ) { |
||||||
|
return jQuery.prop( elem, name, value ); |
||||||
|
} |
||||||
|
|
||||||
|
// All attributes are lowercase
|
||||||
|
// Grab necessary hook if one is defined
|
||||||
|
if ( nType !== 1 || !jQuery.isXMLDoc( elem ) ) { |
||||||
|
name = name.toLowerCase(); |
||||||
|
hooks = jQuery.attrHooks[ name ] || |
||||||
|
( jQuery.expr.match.bool.test( name ) ? boolHook : nodeHook ); |
||||||
|
} |
||||||
|
|
||||||
|
if ( value !== undefined ) { |
||||||
|
|
||||||
|
if ( value === null ) { |
||||||
|
jQuery.removeAttr( elem, name ); |
||||||
|
|
||||||
|
} else if ( hooks && "set" in hooks && (ret = hooks.set( elem, value, name )) !== undefined ) { |
||||||
|
return ret; |
||||||
|
|
||||||
|
} else { |
||||||
|
elem.setAttribute( name, value + "" ); |
||||||
|
return value; |
||||||
|
} |
||||||
|
|
||||||
|
} else if ( hooks && "get" in hooks && (ret = hooks.get( elem, name )) !== null ) { |
||||||
|
return ret; |
||||||
|
|
||||||
|
} else { |
||||||
|
ret = jQuery.find.attr( elem, name ); |
||||||
|
|
||||||
|
// Non-existent attributes return null, we normalize to undefined
|
||||||
|
return ret == null ? |
||||||
|
undefined : |
||||||
|
ret; |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
removeAttr: function( elem, value ) { |
||||||
|
var name, propName, |
||||||
|
i = 0, |
||||||
|
attrNames = value && value.match( rnotwhite ); |
||||||
|
|
||||||
|
if ( attrNames && elem.nodeType === 1 ) { |
||||||
|
while ( (name = attrNames[i++]) ) { |
||||||
|
propName = jQuery.propFix[ name ] || name; |
||||||
|
|
||||||
|
// Boolean attributes get special treatment (#10870)
|
||||||
|
if ( jQuery.expr.match.bool.test( name ) ) { |
||||||
|
// Set corresponding property to false
|
||||||
|
elem[ propName ] = false; |
||||||
|
} |
||||||
|
|
||||||
|
elem.removeAttribute( name ); |
||||||
|
} |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
attrHooks: { |
||||||
|
type: { |
||||||
|
set: function( elem, value ) { |
||||||
|
if ( !support.radioValue && value === "radio" && |
||||||
|
jQuery.nodeName( elem, "input" ) ) { |
||||||
|
// Setting the type on a radio button after the value resets the value in IE6-9
|
||||||
|
// Reset value to default in case type is set after value during creation
|
||||||
|
var val = elem.value; |
||||||
|
elem.setAttribute( "type", value ); |
||||||
|
if ( val ) { |
||||||
|
elem.value = val; |
||||||
|
} |
||||||
|
return value; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
// Hooks for boolean attributes
|
||||||
|
boolHook = { |
||||||
|
set: function( elem, value, name ) { |
||||||
|
if ( value === false ) { |
||||||
|
// Remove boolean attributes when set to false
|
||||||
|
jQuery.removeAttr( elem, name ); |
||||||
|
} else { |
||||||
|
elem.setAttribute( name, name ); |
||||||
|
} |
||||||
|
return name; |
||||||
|
} |
||||||
|
}; |
||||||
|
jQuery.each( jQuery.expr.match.bool.source.match( /\w+/g ), function( i, name ) { |
||||||
|
var getter = attrHandle[ name ] || jQuery.find.attr; |
||||||
|
|
||||||
|
attrHandle[ name ] = function( elem, name, isXML ) { |
||||||
|
var ret, handle; |
||||||
|
if ( !isXML ) { |
||||||
|
// Avoid an infinite loop by temporarily removing this function from the getter
|
||||||
|
handle = attrHandle[ name ]; |
||||||
|
attrHandle[ name ] = ret; |
||||||
|
ret = getter( elem, name, isXML ) != null ? |
||||||
|
name.toLowerCase() : |
||||||
|
null; |
||||||
|
attrHandle[ name ] = handle; |
||||||
|
} |
||||||
|
return ret; |
||||||
|
}; |
||||||
|
}); |
||||||
|
|
||||||
|
}); |
@ -0,0 +1,158 @@ |
|||||||
|
define([ |
||||||
|
"../core", |
||||||
|
"../var/rnotwhite", |
||||||
|
"../var/strundefined", |
||||||
|
"../data/var/data_priv", |
||||||
|
"../core/init" |
||||||
|
], function( jQuery, rnotwhite, strundefined, data_priv ) { |
||||||
|
|
||||||
|
var rclass = /[\t\r\n\f]/g; |
||||||
|
|
||||||
|
jQuery.fn.extend({ |
||||||
|
addClass: function( value ) { |
||||||
|
var classes, elem, cur, clazz, j, finalValue, |
||||||
|
proceed = typeof value === "string" && value, |
||||||
|
i = 0, |
||||||
|
len = this.length; |
||||||
|
|
||||||
|
if ( jQuery.isFunction( value ) ) { |
||||||
|
return this.each(function( j ) { |
||||||
|
jQuery( this ).addClass( value.call( this, j, this.className ) ); |
||||||
|
}); |
||||||
|
} |
||||||
|
|
||||||
|
if ( proceed ) { |
||||||
|
// The disjunction here is for better compressibility (see removeClass)
|
||||||
|
classes = ( value || "" ).match( rnotwhite ) || []; |
||||||
|
|
||||||
|
for ( ; i < len; i++ ) { |
||||||
|
elem = this[ i ]; |
||||||
|
cur = elem.nodeType === 1 && ( elem.className ? |
||||||
|
( " " + elem.className + " " ).replace( rclass, " " ) : |
||||||
|
" " |
||||||
|
); |
||||||
|
|
||||||
|
if ( cur ) { |
||||||
|
j = 0; |
||||||
|
while ( (clazz = classes[j++]) ) { |
||||||
|
if ( cur.indexOf( " " + clazz + " " ) < 0 ) { |
||||||
|
cur += clazz + " "; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// only assign if different to avoid unneeded rendering.
|
||||||
|
finalValue = jQuery.trim( cur ); |
||||||
|
if ( elem.className !== finalValue ) { |
||||||
|
elem.className = finalValue; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
return this; |
||||||
|
}, |
||||||
|
|
||||||
|
removeClass: function( value ) { |
||||||
|
var classes, elem, cur, clazz, j, finalValue, |
||||||
|
proceed = arguments.length === 0 || typeof value === "string" && value, |
||||||
|
i = 0, |
||||||
|
len = this.length; |
||||||
|
|
||||||
|
if ( jQuery.isFunction( value ) ) { |
||||||
|
return this.each(function( j ) { |
||||||
|
jQuery( this ).removeClass( value.call( this, j, this.className ) ); |
||||||
|
}); |
||||||
|
} |
||||||
|
if ( proceed ) { |
||||||
|
classes = ( value || "" ).match( rnotwhite ) || []; |
||||||
|
|
||||||
|
for ( ; i < len; i++ ) { |
||||||
|
elem = this[ i ]; |
||||||
|
// This expression is here for better compressibility (see addClass)
|
||||||
|
cur = elem.nodeType === 1 && ( elem.className ? |
||||||
|
( " " + elem.className + " " ).replace( rclass, " " ) : |
||||||
|
"" |
||||||
|
); |
||||||
|
|
||||||
|
if ( cur ) { |
||||||
|
j = 0; |
||||||
|
while ( (clazz = classes[j++]) ) { |
||||||
|
// Remove *all* instances
|
||||||
|
while ( cur.indexOf( " " + clazz + " " ) >= 0 ) { |
||||||
|
cur = cur.replace( " " + clazz + " ", " " ); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// only assign if different to avoid unneeded rendering.
|
||||||
|
finalValue = value ? jQuery.trim( cur ) : ""; |
||||||
|
if ( elem.className !== finalValue ) { |
||||||
|
elem.className = finalValue; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
return this; |
||||||
|
}, |
||||||
|
|
||||||
|
toggleClass: function( value, stateVal ) { |
||||||
|
var type = typeof value; |
||||||
|
|
||||||
|
if ( typeof stateVal === "boolean" && type === "string" ) { |
||||||
|
return stateVal ? this.addClass( value ) : this.removeClass( value ); |
||||||
|
} |
||||||
|
|
||||||
|
if ( jQuery.isFunction( value ) ) { |
||||||
|
return this.each(function( i ) { |
||||||
|
jQuery( this ).toggleClass( value.call(this, i, this.className, stateVal), stateVal ); |
||||||
|
}); |
||||||
|
} |
||||||
|
|
||||||
|
return this.each(function() { |
||||||
|
if ( type === "string" ) { |
||||||
|
// toggle individual class names
|
||||||
|
var className, |
||||||
|
i = 0, |
||||||
|
self = jQuery( this ), |
||||||
|
classNames = value.match( rnotwhite ) || []; |
||||||
|
|
||||||
|
while ( (className = classNames[ i++ ]) ) { |
||||||
|
// check each className given, space separated list
|
||||||
|
if ( self.hasClass( className ) ) { |
||||||
|
self.removeClass( className ); |
||||||
|
} else { |
||||||
|
self.addClass( className ); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Toggle whole class name
|
||||||
|
} else if ( type === strundefined || type === "boolean" ) { |
||||||
|
if ( this.className ) { |
||||||
|
// store className if set
|
||||||
|
data_priv.set( this, "__className__", this.className ); |
||||||
|
} |
||||||
|
|
||||||
|
// If the element has a class name or if we're passed "false",
|
||||||
|
// then remove the whole classname (if there was one, the above saved it).
|
||||||
|
// Otherwise bring back whatever was previously saved (if anything),
|
||||||
|
// falling back to the empty string if nothing was stored.
|
||||||
|
this.className = this.className || value === false ? "" : data_priv.get( this, "__className__" ) || ""; |
||||||
|
} |
||||||
|
}); |
||||||
|
}, |
||||||
|
|
||||||
|
hasClass: function( selector ) { |
||||||
|
var className = " " + selector + " ", |
||||||
|
i = 0, |
||||||
|
l = this.length; |
||||||
|
for ( ; i < l; i++ ) { |
||||||
|
if ( this[i].nodeType === 1 && (" " + this[i].className + " ").replace(rclass, " ").indexOf( className ) >= 0 ) { |
||||||
|
return true; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
return false; |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
}); |
@ -0,0 +1,96 @@ |
|||||||
|
define([ |
||||||
|
"../core", |
||||||
|
"../core/access", |
||||||
|
"./support" |
||||||
|
], function( jQuery, access, support ) { |
||||||
|
|
||||||
|
var rfocusable = /^(?:input|select|textarea|button)$/i; |
||||||
|
|
||||||
|
jQuery.fn.extend({ |
||||||
|
prop: function( name, value ) { |
||||||
|
return access( this, jQuery.prop, name, value, arguments.length > 1 ); |
||||||
|
}, |
||||||
|
|
||||||
|
removeProp: function( name ) { |
||||||
|
return this.each(function() { |
||||||
|
delete this[ jQuery.propFix[ name ] || name ]; |
||||||
|
}); |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
jQuery.extend({ |
||||||
|
propFix: { |
||||||
|
"for": "htmlFor", |
||||||
|
"class": "className" |
||||||
|
}, |
||||||
|
|
||||||
|
prop: function( elem, name, value ) { |
||||||
|
var ret, hooks, notxml, |
||||||
|
nType = elem.nodeType; |
||||||
|
|
||||||
|
// don't get/set properties on text, comment and attribute nodes
|
||||||
|
if ( !elem || nType === 3 || nType === 8 || nType === 2 ) { |
||||||
|
return; |
||||||
|
} |
||||||
|
|
||||||
|
notxml = nType !== 1 || !jQuery.isXMLDoc( elem ); |
||||||
|
|
||||||
|
if ( notxml ) { |
||||||
|
// Fix name and attach hooks
|
||||||
|
name = jQuery.propFix[ name ] || name; |
||||||
|
hooks = jQuery.propHooks[ name ]; |
||||||
|
} |
||||||
|
|
||||||
|
if ( value !== undefined ) { |
||||||
|
return hooks && "set" in hooks && (ret = hooks.set( elem, value, name )) !== undefined ? |
||||||
|
ret : |
||||||
|
( elem[ name ] = value ); |
||||||
|
|
||||||
|
} else { |
||||||
|
return hooks && "get" in hooks && (ret = hooks.get( elem, name )) !== null ? |
||||||
|
ret : |
||||||
|
elem[ name ]; |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
propHooks: { |
||||||
|
tabIndex: { |
||||||
|
get: function( elem ) { |
||||||
|
return elem.hasAttribute( "tabindex" ) || rfocusable.test( elem.nodeName ) || elem.href ? |
||||||
|
elem.tabIndex : |
||||||
|
-1; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
// Support: IE9+
|
||||||
|
// Selectedness for an option in an optgroup can be inaccurate
|
||||||
|
if ( !support.optSelected ) { |
||||||
|
jQuery.propHooks.selected = { |
||||||
|
get: function( elem ) { |
||||||
|
var parent = elem.parentNode; |
||||||
|
if ( parent && parent.parentNode ) { |
||||||
|
parent.parentNode.selectedIndex; |
||||||
|
} |
||||||
|
return null; |
||||||
|
} |
||||||
|
}; |
||||||
|
} |
||||||
|
|
||||||
|
jQuery.each([ |
||||||
|
"tabIndex", |
||||||
|
"readOnly", |
||||||
|
"maxLength", |
||||||
|
"cellSpacing", |
||||||
|
"cellPadding", |
||||||
|
"rowSpan", |
||||||
|
"colSpan", |
||||||
|
"useMap", |
||||||
|
"frameBorder", |
||||||
|
"contentEditable" |
||||||
|
], function() { |
||||||
|
jQuery.propFix[ this.toLowerCase() ] = this; |
||||||
|
}); |
||||||
|
|
||||||
|
}); |
@ -0,0 +1,35 @@ |
|||||||
|
define([ |
||||||
|
"../var/support" |
||||||
|
], function( support ) { |
||||||
|
|
||||||
|
(function() { |
||||||
|
var input = document.createElement( "input" ), |
||||||
|
select = document.createElement( "select" ), |
||||||
|
opt = select.appendChild( document.createElement( "option" ) ); |
||||||
|
|
||||||
|
input.type = "checkbox"; |
||||||
|
|
||||||
|
// Support: iOS 5.1, Android 4.x, Android 2.3
|
||||||
|
// Check the default checkbox/radio value ("" on old WebKit; "on" elsewhere)
|
||||||
|
support.checkOn = input.value !== ""; |
||||||
|
|
||||||
|
// Must access the parent to make an option select properly
|
||||||
|
// Support: IE9, IE10
|
||||||
|
support.optSelected = opt.selected; |
||||||
|
|
||||||
|
// Make sure that the options inside disabled selects aren't marked as disabled
|
||||||
|
// (WebKit marks them as disabled)
|
||||||
|
select.disabled = true; |
||||||
|
support.optDisabled = !opt.disabled; |
||||||
|
|
||||||
|
// Check if an input maintains its value after becoming a radio
|
||||||
|
// Support: IE9, IE10
|
||||||
|
input = document.createElement( "input" ); |
||||||
|
input.value = "t"; |
||||||
|
input.type = "radio"; |
||||||
|
support.radioValue = input.value === "t"; |
||||||
|
})(); |
||||||
|
|
||||||
|
return support; |
||||||
|
|
||||||
|
}); |
@ -0,0 +1,153 @@ |
|||||||
|
define([ |
||||||
|
"../core", |
||||||
|
"./support", |
||||||
|
"../core/init" |
||||||
|
], function( jQuery, support ) { |
||||||
|
|
||||||
|
var rreturn = /\r/g; |
||||||
|
|
||||||
|
jQuery.fn.extend({ |
||||||
|
val: function( value ) { |
||||||
|
var hooks, ret, isFunction, |
||||||
|
elem = this[0]; |
||||||
|
|
||||||
|
if ( !arguments.length ) { |
||||||
|
if ( elem ) { |
||||||
|
hooks = jQuery.valHooks[ elem.type ] || jQuery.valHooks[ elem.nodeName.toLowerCase() ]; |
||||||
|
|
||||||
|
if ( hooks && "get" in hooks && (ret = hooks.get( elem, "value" )) !== undefined ) { |
||||||
|
return ret; |
||||||
|
} |
||||||
|
|
||||||
|
ret = elem.value; |
||||||
|
|
||||||
|
return typeof ret === "string" ? |
||||||
|
// handle most common string cases
|
||||||
|
ret.replace(rreturn, "") : |
||||||
|
// handle cases where value is null/undef or number
|
||||||
|
ret == null ? "" : ret; |
||||||
|
} |
||||||
|
|
||||||
|
return; |
||||||
|
} |
||||||
|
|
||||||
|
isFunction = jQuery.isFunction( value ); |
||||||
|
|
||||||
|
return this.each(function( i ) { |
||||||
|
var val; |
||||||
|
|
||||||
|
if ( this.nodeType !== 1 ) { |
||||||
|
return; |
||||||
|
} |
||||||
|
|
||||||
|
if ( isFunction ) { |
||||||
|
val = value.call( this, i, jQuery( this ).val() ); |
||||||
|
} else { |
||||||
|
val = value; |
||||||
|
} |
||||||
|
|
||||||
|
// Treat null/undefined as ""; convert numbers to string
|
||||||
|
if ( val == null ) { |
||||||
|
val = ""; |
||||||
|
|
||||||
|
} else if ( typeof val === "number" ) { |
||||||
|
val += ""; |
||||||
|
|
||||||
|
} else if ( jQuery.isArray( val ) ) { |
||||||
|
val = jQuery.map( val, function( value ) { |
||||||
|
return value == null ? "" : value + ""; |
||||||
|
}); |
||||||
|
} |
||||||
|
|
||||||
|
hooks = jQuery.valHooks[ this.type ] || jQuery.valHooks[ this.nodeName.toLowerCase() ]; |
||||||
|
|
||||||
|
// If set returns undefined, fall back to normal setting
|
||||||
|
if ( !hooks || !("set" in hooks) || hooks.set( this, val, "value" ) === undefined ) { |
||||||
|
this.value = val; |
||||||
|
} |
||||||
|
}); |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
jQuery.extend({ |
||||||
|
valHooks: { |
||||||
|
select: { |
||||||
|
get: function( elem ) { |
||||||
|
var value, option, |
||||||
|
options = elem.options, |
||||||
|
index = elem.selectedIndex, |
||||||
|
one = elem.type === "select-one" || index < 0, |
||||||
|
values = one ? null : [], |
||||||
|
max = one ? index + 1 : options.length, |
||||||
|
i = index < 0 ? |
||||||
|
max : |
||||||
|
one ? index : 0; |
||||||
|
|
||||||
|
// Loop through all the selected options
|
||||||
|
for ( ; i < max; i++ ) { |
||||||
|
option = options[ i ]; |
||||||
|
|
||||||
|
// IE6-9 doesn't update selected after form reset (#2551)
|
||||||
|
if ( ( option.selected || i === index ) && |
||||||
|
// Don't return options that are disabled or in a disabled optgroup
|
||||||
|
( support.optDisabled ? !option.disabled : option.getAttribute( "disabled" ) === null ) && |
||||||
|
( !option.parentNode.disabled || !jQuery.nodeName( option.parentNode, "optgroup" ) ) ) { |
||||||
|
|
||||||
|
// Get the specific value for the option
|
||||||
|
value = jQuery( option ).val(); |
||||||
|
|
||||||
|
// We don't need an array for one selects
|
||||||
|
if ( one ) { |
||||||
|
return value; |
||||||
|
} |
||||||
|
|
||||||
|
// Multi-Selects return an array
|
||||||
|
values.push( value ); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
return values; |
||||||
|
}, |
||||||
|
|
||||||
|
set: function( elem, value ) { |
||||||
|
var optionSet, option, |
||||||
|
options = elem.options, |
||||||
|
values = jQuery.makeArray( value ), |
||||||
|
i = options.length; |
||||||
|
|
||||||
|
while ( i-- ) { |
||||||
|
option = options[ i ]; |
||||||
|
if ( (option.selected = jQuery.inArray( jQuery(option).val(), values ) >= 0) ) { |
||||||
|
optionSet = true; |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// force browsers to behave consistently when non-matching value is set
|
||||||
|
if ( !optionSet ) { |
||||||
|
elem.selectedIndex = -1; |
||||||
|
} |
||||||
|
return values; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
// Radios and checkboxes getter/setter
|
||||||
|
jQuery.each([ "radio", "checkbox" ], function() { |
||||||
|
jQuery.valHooks[ this ] = { |
||||||
|
set: function( elem, value ) { |
||||||
|
if ( jQuery.isArray( value ) ) { |
||||||
|
return ( elem.checked = jQuery.inArray( jQuery(elem).val(), value ) >= 0 ); |
||||||
|
} |
||||||
|
} |
||||||
|
}; |
||||||
|
if ( !support.checkOn ) { |
||||||
|
jQuery.valHooks[ this ].get = function( elem ) { |
||||||
|
// Support: Webkit
|
||||||
|
// "" is returned instead of "on" if a value isn't specified
|
||||||
|
return elem.getAttribute("value") === null ? "on" : elem.value; |
||||||
|
}; |
||||||
|
} |
||||||
|
}); |
||||||
|
|
||||||
|
}); |
@ -0,0 +1,205 @@ |
|||||||
|
define([ |
||||||
|
"./core", |
||||||
|
"./var/rnotwhite" |
||||||
|
], function( jQuery, rnotwhite ) { |
||||||
|
|
||||||
|
// String to Object options format cache
|
||||||
|
var optionsCache = {}; |
||||||
|
|
||||||
|
// Convert String-formatted options into Object-formatted ones and store in cache
|
||||||
|
function createOptions( options ) { |
||||||
|
var object = optionsCache[ options ] = {}; |
||||||
|
jQuery.each( options.match( rnotwhite ) || [], function( _, flag ) { |
||||||
|
object[ flag ] = true; |
||||||
|
}); |
||||||
|
return object; |
||||||
|
} |
||||||
|
|
||||||
|
/* |
||||||
|
* Create a callback list using the following parameters: |
||||||
|
* |
||||||
|
* options: an optional list of space-separated options that will change how |
||||||
|
* the callback list behaves or a more traditional option object |
||||||
|
* |
||||||
|
* By default a callback list will act like an event callback list and can be |
||||||
|
* "fired" multiple times. |
||||||
|
* |
||||||
|
* Possible options: |
||||||
|
* |
||||||
|
* once: will ensure the callback list can only be fired once (like a Deferred) |
||||||
|
* |
||||||
|
* memory: will keep track of previous values and will call any callback added |
||||||
|
* after the list has been fired right away with the latest "memorized" |
||||||
|
* values (like a Deferred) |
||||||
|
* |
||||||
|
* unique: will ensure a callback can only be added once (no duplicate in the list) |
||||||
|
* |
||||||
|
* stopOnFalse: interrupt callings when a callback returns false |
||||||
|
* |
||||||
|
*/ |
||||||
|
jQuery.Callbacks = function( options ) { |
||||||
|
|
||||||
|
// Convert options from String-formatted to Object-formatted if needed
|
||||||
|
// (we check in cache first)
|
||||||
|
options = typeof options === "string" ? |
||||||
|
( optionsCache[ options ] || createOptions( options ) ) : |
||||||
|
jQuery.extend( {}, options ); |
||||||
|
|
||||||
|
var // Last fire value (for non-forgettable lists)
|
||||||
|
memory, |
||||||
|
// Flag to know if list was already fired
|
||||||
|
fired, |
||||||
|
// Flag to know if list is currently firing
|
||||||
|
firing, |
||||||
|
// First callback to fire (used internally by add and fireWith)
|
||||||
|
firingStart, |
||||||
|
// End of the loop when firing
|
||||||
|
firingLength, |
||||||
|
// Index of currently firing callback (modified by remove if needed)
|
||||||
|
firingIndex, |
||||||
|
// Actual callback list
|
||||||
|
list = [], |
||||||
|
// Stack of fire calls for repeatable lists
|
||||||
|
stack = !options.once && [], |
||||||
|
// Fire callbacks
|
||||||
|
fire = function( data ) { |
||||||
|
memory = options.memory && data; |
||||||
|
fired = true; |
||||||
|
firingIndex = firingStart || 0; |
||||||
|
firingStart = 0; |
||||||
|
firingLength = list.length; |
||||||
|
firing = true; |
||||||
|
for ( ; list && firingIndex < firingLength; firingIndex++ ) { |
||||||
|
if ( list[ firingIndex ].apply( data[ 0 ], data[ 1 ] ) === false && options.stopOnFalse ) { |
||||||
|
memory = false; // To prevent further calls using add
|
||||||
|
break; |
||||||
|
} |
||||||
|
} |
||||||
|
firing = false; |
||||||
|
if ( list ) { |
||||||
|
if ( stack ) { |
||||||
|
if ( stack.length ) { |
||||||
|
fire( stack.shift() ); |
||||||
|
} |
||||||
|
} else if ( memory ) { |
||||||
|
list = []; |
||||||
|
} else { |
||||||
|
self.disable(); |
||||||
|
} |
||||||
|
} |
||||||
|
}, |
||||||
|
// Actual Callbacks object
|
||||||
|
self = { |
||||||
|
// Add a callback or a collection of callbacks to the list
|
||||||
|
add: function() { |
||||||
|
if ( list ) { |
||||||
|
// First, we save the current length
|
||||||
|
var start = list.length; |
||||||
|
(function add( args ) { |
||||||
|
jQuery.each( args, function( _, arg ) { |
||||||
|
var type = jQuery.type( arg ); |
||||||
|
if ( type === "function" ) { |
||||||
|
if ( !options.unique || !self.has( arg ) ) { |
||||||
|
list.push( arg ); |
||||||
|
} |
||||||
|
} else if ( arg && arg.length && type !== "string" ) { |
||||||
|
// Inspect recursively
|
||||||
|
add( arg ); |
||||||
|
} |
||||||
|
}); |
||||||
|
})( arguments ); |
||||||
|
// Do we need to add the callbacks to the
|
||||||
|
// current firing batch?
|
||||||
|
if ( firing ) { |
||||||
|
firingLength = list.length; |
||||||
|
// With memory, if we're not firing then
|
||||||
|
// we should call right away
|
||||||
|
} else if ( memory ) { |
||||||
|
firingStart = start; |
||||||
|
fire( memory ); |
||||||
|
} |
||||||
|
} |
||||||
|
return this; |
||||||
|
}, |
||||||
|
// Remove a callback from the list
|
||||||
|
remove: function() { |
||||||
|
if ( list ) { |
||||||
|
jQuery.each( arguments, function( _, arg ) { |
||||||
|
var index; |
||||||
|
while ( ( index = jQuery.inArray( arg, list, index ) ) > -1 ) { |
||||||
|
list.splice( index, 1 ); |
||||||
|
// Handle firing indexes
|
||||||
|
if ( firing ) { |
||||||
|
if ( index <= firingLength ) { |
||||||
|
firingLength--; |
||||||
|
} |
||||||
|
if ( index <= firingIndex ) { |
||||||
|
firingIndex--; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
}); |
||||||
|
} |
||||||
|
return this; |
||||||
|
}, |
||||||
|
// Check if a given callback is in the list.
|
||||||
|
// If no argument is given, return whether or not list has callbacks attached.
|
||||||
|
has: function( fn ) { |
||||||
|
return fn ? jQuery.inArray( fn, list ) > -1 : !!( list && list.length ); |
||||||
|
}, |
||||||
|
// Remove all callbacks from the list
|
||||||
|
empty: function() { |
||||||
|
list = []; |
||||||
|
firingLength = 0; |
||||||
|
return this; |
||||||
|
}, |
||||||
|
// Have the list do nothing anymore
|
||||||
|
disable: function() { |
||||||
|
list = stack = memory = undefined; |
||||||
|
return this; |
||||||
|
}, |
||||||
|
// Is it disabled?
|
||||||
|
disabled: function() { |
||||||
|
return !list; |
||||||
|
}, |
||||||
|
// Lock the list in its current state
|
||||||
|
lock: function() { |
||||||
|
stack = undefined; |
||||||
|
if ( !memory ) { |
||||||
|
self.disable(); |
||||||
|
} |
||||||
|
return this; |
||||||
|
}, |
||||||
|
// Is it locked?
|
||||||
|
locked: function() { |
||||||
|
return !stack; |
||||||
|
}, |
||||||
|
// Call all callbacks with the given context and arguments
|
||||||
|
fireWith: function( context, args ) { |
||||||
|
if ( list && ( !fired || stack ) ) { |
||||||
|
args = args || []; |
||||||
|
args = [ context, args.slice ? args.slice() : args ]; |
||||||
|
if ( firing ) { |
||||||
|
stack.push( args ); |
||||||
|
} else { |
||||||
|
fire( args ); |
||||||
|
} |
||||||
|
} |
||||||
|
return this; |
||||||
|
}, |
||||||
|
// Call all the callbacks with the given arguments
|
||||||
|
fire: function() { |
||||||
|
self.fireWith( this, arguments ); |
||||||
|
return this; |
||||||
|
}, |
||||||
|
// To know if the callbacks have already been called at least once
|
||||||
|
fired: function() { |
||||||
|
return !!fired; |
||||||
|
} |
||||||
|
}; |
||||||
|
|
||||||
|
return self; |
||||||
|
}; |
||||||
|
|
||||||
|
return jQuery; |
||||||
|
}); |
@ -0,0 +1,500 @@ |
|||||||
|
define([ |
||||||
|
"./var/arr", |
||||||
|
"./var/slice", |
||||||
|
"./var/concat", |
||||||
|
"./var/push", |
||||||
|
"./var/indexOf", |
||||||
|
"./var/class2type", |
||||||
|
"./var/toString", |
||||||
|
"./var/hasOwn", |
||||||
|
"./var/trim", |
||||||
|
"./var/support" |
||||||
|
], function( arr, slice, concat, push, indexOf, class2type, toString, hasOwn, trim, support ) { |
||||||
|
|
||||||
|
var |
||||||
|
// Use the correct document accordingly with window argument (sandbox)
|
||||||
|
document = window.document, |
||||||
|
|
||||||
|
version = "@VERSION", |
||||||
|
|
||||||
|
// Define a local copy of jQuery
|
||||||
|
jQuery = function( selector, context ) { |
||||||
|
// The jQuery object is actually just the init constructor 'enhanced'
|
||||||
|
// Need init if jQuery is called (just allow error to be thrown if not included)
|
||||||
|
return new jQuery.fn.init( selector, context ); |
||||||
|
}, |
||||||
|
|
||||||
|
// Matches dashed string for camelizing
|
||||||
|
rmsPrefix = /^-ms-/, |
||||||
|
rdashAlpha = /-([\da-z])/gi, |
||||||
|
|
||||||
|
// Used by jQuery.camelCase as callback to replace()
|
||||||
|
fcamelCase = function( all, letter ) { |
||||||
|
return letter.toUpperCase(); |
||||||
|
}; |
||||||
|
|
||||||
|
jQuery.fn = jQuery.prototype = { |
||||||
|
// The current version of jQuery being used
|
||||||
|
jquery: version, |
||||||
|
|
||||||
|
constructor: jQuery, |
||||||
|
|
||||||
|
// Start with an empty selector
|
||||||
|
selector: "", |
||||||
|
|
||||||
|
// The default length of a jQuery object is 0
|
||||||
|
length: 0, |
||||||
|
|
||||||
|
toArray: function() { |
||||||
|
return slice.call( this ); |
||||||
|
}, |
||||||
|
|
||||||
|
// Get the Nth element in the matched element set OR
|
||||||
|
// Get the whole matched element set as a clean array
|
||||||
|
get: function( num ) { |
||||||
|
return num != null ? |
||||||
|
|
||||||
|
// Return a 'clean' array
|
||||||
|
( num < 0 ? this[ num + this.length ] : this[ num ] ) : |
||||||
|
|
||||||
|
// Return just the object
|
||||||
|
slice.call( this ); |
||||||
|
}, |
||||||
|
|
||||||
|
// Take an array of elements and push it onto the stack
|
||||||
|
// (returning the new matched element set)
|
||||||
|
pushStack: function( elems ) { |
||||||
|
|
||||||
|
// Build a new jQuery matched element set
|
||||||
|
var ret = jQuery.merge( this.constructor(), elems ); |
||||||
|
|
||||||
|
// Add the old object onto the stack (as a reference)
|
||||||
|
ret.prevObject = this; |
||||||
|
ret.context = this.context; |
||||||
|
|
||||||
|
// Return the newly-formed element set
|
||||||
|
return ret; |
||||||
|
}, |
||||||
|
|
||||||
|
// Execute a callback for every element in the matched set.
|
||||||
|
// (You can seed the arguments with an array of args, but this is
|
||||||
|
// only used internally.)
|
||||||
|
each: function( callback, args ) { |
||||||
|
return jQuery.each( this, callback, args ); |
||||||
|
}, |
||||||
|
|
||||||
|
map: function( callback ) { |
||||||
|
return this.pushStack( jQuery.map(this, function( elem, i ) { |
||||||
|
return callback.call( elem, i, elem ); |
||||||
|
})); |
||||||
|
}, |
||||||
|
|
||||||
|
slice: function() { |
||||||
|
return this.pushStack( slice.apply( this, arguments ) ); |
||||||
|
}, |
||||||
|
|
||||||
|
first: function() { |
||||||
|
return this.eq( 0 ); |
||||||
|
}, |
||||||
|
|
||||||
|
last: function() { |
||||||
|
return this.eq( -1 ); |
||||||
|
}, |
||||||
|
|
||||||
|
eq: function( i ) { |
||||||
|
var len = this.length, |
||||||
|
j = +i + ( i < 0 ? len : 0 ); |
||||||
|
return this.pushStack( j >= 0 && j < len ? [ this[j] ] : [] ); |
||||||
|
}, |
||||||
|
|
||||||
|
end: function() { |
||||||
|
return this.prevObject || this.constructor(null); |
||||||
|
}, |
||||||
|
|
||||||
|
// For internal use only.
|
||||||
|
// Behaves like an Array's method, not like a jQuery method.
|
||||||
|
push: push, |
||||||
|
sort: arr.sort, |
||||||
|
splice: arr.splice |
||||||
|
}; |
||||||
|
|
||||||
|
jQuery.extend = jQuery.fn.extend = function() { |
||||||
|
var options, name, src, copy, copyIsArray, clone, |
||||||
|
target = arguments[0] || {}, |
||||||
|
i = 1, |
||||||
|
length = arguments.length, |
||||||
|
deep = false; |
||||||
|
|
||||||
|
// Handle a deep copy situation
|
||||||
|
if ( typeof target === "boolean" ) { |
||||||
|
deep = target; |
||||||
|
|
||||||
|
// skip the boolean and the target
|
||||||
|
target = arguments[ i ] || {}; |
||||||
|
i++; |
||||||
|
} |
||||||
|
|
||||||
|
// Handle case when target is a string or something (possible in deep copy)
|
||||||
|
if ( typeof target !== "object" && !jQuery.isFunction(target) ) { |
||||||
|
target = {}; |
||||||
|
} |
||||||
|
|
||||||
|
// extend jQuery itself if only one argument is passed
|
||||||
|
if ( i === length ) { |
||||||
|
target = this; |
||||||
|
i--; |
||||||
|
} |
||||||
|
|
||||||
|
for ( ; i < length; i++ ) { |
||||||
|
// Only deal with non-null/undefined values
|
||||||
|
if ( (options = arguments[ i ]) != null ) { |
||||||
|
// Extend the base object
|
||||||
|
for ( name in options ) { |
||||||
|
src = target[ name ]; |
||||||
|
copy = options[ name ]; |
||||||
|
|
||||||
|
// Prevent never-ending loop
|
||||||
|
if ( target === copy ) { |
||||||
|
continue; |
||||||
|
} |
||||||
|
|
||||||
|
// Recurse if we're merging plain objects or arrays
|
||||||
|
if ( deep && copy && ( jQuery.isPlainObject(copy) || (copyIsArray = jQuery.isArray(copy)) ) ) { |
||||||
|
if ( copyIsArray ) { |
||||||
|
copyIsArray = false; |
||||||
|
clone = src && jQuery.isArray(src) ? src : []; |
||||||
|
|
||||||
|
} else { |
||||||
|
clone = src && jQuery.isPlainObject(src) ? src : {}; |
||||||
|
} |
||||||
|
|
||||||
|
// Never move original objects, clone them
|
||||||
|
target[ name ] = jQuery.extend( deep, clone, copy ); |
||||||
|
|
||||||
|
// Don't bring in undefined values
|
||||||
|
} else if ( copy !== undefined ) { |
||||||
|
target[ name ] = copy; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Return the modified object
|
||||||
|
return target; |
||||||
|
}; |
||||||
|
|
||||||
|
jQuery.extend({ |
||||||
|
// Unique for each copy of jQuery on the page
|
||||||
|
expando: "jQuery" + ( version + Math.random() ).replace( /\D/g, "" ), |
||||||
|
|
||||||
|
// Assume jQuery is ready without the ready module
|
||||||
|
isReady: true, |
||||||
|
|
||||||
|
error: function( msg ) { |
||||||
|
throw new Error( msg ); |
||||||
|
}, |
||||||
|
|
||||||
|
noop: function() {}, |
||||||
|
|
||||||
|
// See test/unit/core.js for details concerning isFunction.
|
||||||
|
// Since version 1.3, DOM methods and functions like alert
|
||||||
|
// aren't supported. They return false on IE (#2968).
|
||||||
|
isFunction: function( obj ) { |
||||||
|
return jQuery.type(obj) === "function"; |
||||||
|
}, |
||||||
|
|
||||||
|
isArray: Array.isArray, |
||||||
|
|
||||||
|
isWindow: function( obj ) { |
||||||
|
return obj != null && obj === obj.window; |
||||||
|
}, |
||||||
|
|
||||||
|
isNumeric: function( obj ) { |
||||||
|
// parseFloat NaNs numeric-cast false positives (null|true|false|"")
|
||||||
|
// ...but misinterprets leading-number strings, particularly hex literals ("0x...")
|
||||||
|
// subtraction forces infinities to NaN
|
||||||
|
return obj - parseFloat( obj ) >= 0; |
||||||
|
}, |
||||||
|
|
||||||
|
isPlainObject: function( obj ) { |
||||||
|
// Not plain objects:
|
||||||
|
// - Any object or value whose internal [[Class]] property is not "[object Object]"
|
||||||
|
// - DOM nodes
|
||||||
|
// - window
|
||||||
|
if ( jQuery.type( obj ) !== "object" || obj.nodeType || jQuery.isWindow( obj ) ) { |
||||||
|
return false; |
||||||
|
} |
||||||
|
|
||||||
|
// Support: Firefox <20
|
||||||
|
// The try/catch suppresses exceptions thrown when attempting to access
|
||||||
|
// the "constructor" property of certain host objects, ie. |window.location|
|
||||||
|
// https://bugzilla.mozilla.org/show_bug.cgi?id=814622
|
||||||
|
try { |
||||||
|
if ( obj.constructor && |
||||||
|
!hasOwn.call( obj.constructor.prototype, "isPrototypeOf" ) ) { |
||||||
|
return false; |
||||||
|
} |
||||||
|
} catch ( e ) { |
||||||
|
return false; |
||||||
|
} |
||||||
|
|
||||||
|
// If the function hasn't returned already, we're confident that
|
||||||
|
// |obj| is a plain object, created by {} or constructed with new Object
|
||||||
|
return true; |
||||||
|
}, |
||||||
|
|
||||||
|
isEmptyObject: function( obj ) { |
||||||
|
var name; |
||||||
|
for ( name in obj ) { |
||||||
|
return false; |
||||||
|
} |
||||||
|
return true; |
||||||
|
}, |
||||||
|
|
||||||
|
type: function( obj ) { |
||||||
|
if ( obj == null ) { |
||||||
|
return obj + ""; |
||||||
|
} |
||||||
|
// Support: Android < 4.0, iOS < 6 (functionish RegExp)
|
||||||
|
return typeof obj === "object" || typeof obj === "function" ? |
||||||
|
class2type[ toString.call(obj) ] || "object" : |
||||||
|
typeof obj; |
||||||
|
}, |
||||||
|
|
||||||
|
// Evaluates a script in a global context
|
||||||
|
globalEval: function( code ) { |
||||||
|
var script, |
||||||
|
indirect = eval; |
||||||
|
|
||||||
|
code = jQuery.trim( code ); |
||||||
|
|
||||||
|
if ( code ) { |
||||||
|
// If the code includes a valid, prologue position
|
||||||
|
// strict mode pragma, execute code by injecting a
|
||||||
|
// script tag into the document.
|
||||||
|
if ( code.indexOf("use strict") === 1 ) { |
||||||
|
script = document.createElement("script"); |
||||||
|
script.text = code; |
||||||
|
document.head.appendChild( script ).parentNode.removeChild( script ); |
||||||
|
} else { |
||||||
|
// Otherwise, avoid the DOM node creation, insertion
|
||||||
|
// and removal by using an indirect global eval
|
||||||
|
indirect( code ); |
||||||
|
} |
||||||
|
} |
||||||
|
}, |
||||||
|
|
||||||
|
// Convert dashed to camelCase; used by the css and data modules
|
||||||
|
// Microsoft forgot to hump their vendor prefix (#9572)
|
||||||
|
camelCase: function( string ) { |
||||||
|
return string.replace( rmsPrefix, "ms-" ).replace( rdashAlpha, fcamelCase ); |
||||||
|
}, |
||||||
|
|
||||||
|
nodeName: function( elem, name ) { |
||||||
|
return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase(); |
||||||
|
}, |
||||||
|
|
||||||
|
// args is for internal usage only
|
||||||
|
each: function( obj, callback, args ) { |
||||||
|
var value, |
||||||
|
i = 0, |
||||||
|
length = obj.length, |
||||||
|
isArray = isArraylike( obj ); |
||||||
|
|
||||||
|
if ( args ) { |
||||||
|
if ( isArray ) { |
||||||
|
for ( ; i < length; i++ ) { |
||||||
|
value = callback.apply( obj[ i ], args ); |
||||||
|
|
||||||
|
if ( value === false ) { |
||||||
|
break; |
||||||
|
} |
||||||
|
} |
||||||
|
} else { |
||||||
|
for ( i in obj ) { |
||||||
|
value = callback.apply( obj[ i ], args ); |
||||||
|
|
||||||
|
if ( value === false ) { |
||||||
|
break; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// A special, fast, case for the most common use of each
|
||||||
|
} else { |
||||||
|
if ( isArray ) { |
||||||
|
for ( ; i < length; i++ ) { |
||||||
|
value = callback.call( obj[ i ], i, obj[ i ] ); |
||||||
|
|
||||||
|
if ( value === false ) { |
||||||
|
break; |
||||||
|
} |
||||||
|
} |
||||||
|
} else { |
||||||
|
for ( i in obj ) { |
||||||
|
value = callback.call( obj[ i ], i, obj[ i ] ); |
||||||
|
|
||||||
|
if ( value === false ) { |
||||||
|
break; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
return obj; |
||||||
|
}, |
||||||
|
|
||||||
|
trim: function( text ) { |
||||||
|
return text == null ? "" : trim.call( text ); |
||||||
|
}, |
||||||
|
|
||||||
|
// results is for internal usage only
|
||||||
|
makeArray: function( arr, results ) { |
||||||
|
var ret = results || []; |
||||||
|
|
||||||
|
if ( arr != null ) { |
||||||
|
if ( isArraylike( Object(arr) ) ) { |
||||||
|
jQuery.merge( ret, |
||||||
|
typeof arr === "string" ? |
||||||
|
[ arr ] : arr |
||||||
|
); |
||||||
|
} else { |
||||||
|
push.call( ret, arr ); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
return ret; |
||||||
|
}, |
||||||
|
|
||||||
|
inArray: function( elem, arr, i ) { |
||||||
|
return arr == null ? -1 : indexOf.call( arr, elem, i ); |
||||||
|
}, |
||||||
|
|
||||||
|
merge: function( first, second ) { |
||||||
|
var len = +second.length, |
||||||
|
j = 0, |
||||||
|
i = first.length; |
||||||
|
|
||||||
|
for ( ; j < len; j++ ) { |
||||||
|
first[ i++ ] = second[ j ]; |
||||||
|
} |
||||||
|
|
||||||
|
first.length = i; |
||||||
|
|
||||||
|
return first; |
||||||
|
}, |
||||||
|
|
||||||
|
grep: function( elems, callback, invert ) { |
||||||
|
var callbackInverse, |
||||||
|
matches = [], |
||||||
|
i = 0, |
||||||
|
length = elems.length, |
||||||
|
callbackExpect = !invert; |
||||||
|
|
||||||
|
// Go through the array, only saving the items
|
||||||
|
// that pass the validator function
|
||||||
|
for ( ; i < length; i++ ) { |
||||||
|
callbackInverse = !callback( elems[ i ], i ); |
||||||
|
if ( callbackInverse !== callbackExpect ) { |
||||||
|
matches.push( elems[ i ] ); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
return matches; |
||||||
|
}, |
||||||
|
|
||||||
|
// arg is for internal usage only
|
||||||
|
map: function( elems, callback, arg ) { |
||||||
|
var value, |
||||||
|
i = 0, |
||||||
|
length = elems.length, |
||||||
|
isArray = isArraylike( elems ), |
||||||
|
ret = []; |
||||||
|
|
||||||
|
// Go through the array, translating each of the items to their new values
|
||||||
|
if ( isArray ) { |
||||||
|
for ( ; i < length; i++ ) { |
||||||
|
value = callback( elems[ i ], i, arg ); |
||||||
|
|
||||||
|
if ( value != null ) { |
||||||
|
ret.push( value ); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Go through every key on the object,
|
||||||
|
} else { |
||||||
|
for ( i in elems ) { |
||||||
|
value = callback( elems[ i ], i, arg ); |
||||||
|
|
||||||
|
if ( value != null ) { |
||||||
|
ret.push( value ); |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// Flatten any nested arrays
|
||||||
|
return concat.apply( [], ret ); |
||||||
|
}, |
||||||
|
|
||||||
|
// A global GUID counter for objects
|
||||||
|
guid: 1, |
||||||
|
|
||||||
|
// Bind a function to a context, optionally partially applying any
|
||||||
|
// arguments.
|
||||||
|
proxy: function( fn, context ) { |
||||||
|
var tmp, args, proxy; |
||||||
|
|
||||||
|
if ( typeof context === "string" ) { |
||||||
|
tmp = fn[ context ]; |
||||||
|
context = fn; |
||||||
|
fn = tmp; |
||||||
|
} |
||||||
|
|
||||||
|
// Quick check to determine if target is callable, in the spec
|
||||||
|
// this throws a TypeError, but we will just return undefined.
|
||||||
|
if ( !jQuery.isFunction( fn ) ) { |
||||||
|
return undefined; |
||||||
|
} |
||||||
|
|
||||||
|
// Simulated bind
|
||||||
|
args = slice.call( arguments, 2 ); |
||||||
|
proxy = function() { |
||||||
|
return fn.apply( context || this, args.concat( slice.call( arguments ) ) ); |
||||||
|
}; |
||||||
|
|
||||||
|
// Set the guid of unique handler to the same of original handler, so it can be removed
|
||||||
|
proxy.guid = fn.guid = fn.guid || jQuery.guid++; |
||||||
|
|
||||||
|
return proxy; |
||||||
|
}, |
||||||
|
|
||||||
|
now: Date.now, |
||||||
|
|
||||||
|
// jQuery.support is not used in Core but other projects attach their
|
||||||
|
// properties to it so it needs to exist.
|
||||||
|
support: support |
||||||
|
}); |
||||||
|
|
||||||
|
// Populate the class2type map
|
||||||
|
jQuery.each("Boolean Number String Function Array Date RegExp Object Error".split(" "), function(i, name) { |
||||||
|
class2type[ "[object " + name + "]" ] = name.toLowerCase(); |
||||||
|
}); |
||||||
|
|
||||||
|
function isArraylike( obj ) { |
||||||
|
var length = obj.length, |
||||||
|
type = jQuery.type( obj ); |
||||||
|
|
||||||
|
if ( type === "function" || jQuery.isWindow( obj ) ) { |
||||||
|
return false; |
||||||
|
} |
||||||
|
|
||||||
|
if ( obj.nodeType === 1 && length ) { |
||||||
|
return true; |
||||||
|
} |
||||||
|
|
||||||
|
return type === "array" || length === 0 || |
||||||
|
typeof length === "number" && length > 0 && ( length - 1 ) in obj; |
||||||
|
} |
||||||
|
|
||||||
|
return jQuery; |
||||||
|
}); |
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in new issue