Merge remote-tracking branch 'twbs/v4-dev' into v4-dev
4
.gitignore
vendored
@ -38,10 +38,6 @@ Thumbs.db
|
|||||||
.komodotools
|
.komodotools
|
||||||
*.komodoproject
|
*.komodoproject
|
||||||
|
|
||||||
# grunt-html-validation
|
|
||||||
validation-report.json
|
|
||||||
validation-status.json
|
|
||||||
|
|
||||||
# SCSS-Lint
|
# SCSS-Lint
|
||||||
scss-lint-report.xml
|
scss-lint-report.xml
|
||||||
|
|
||||||
|
@ -10,7 +10,7 @@ javascript:
|
|||||||
|
|
||||||
eslint:
|
eslint:
|
||||||
enabled: true
|
enabled: true
|
||||||
config_file: js/.eslintrc
|
config_file: js/.eslintrc.json
|
||||||
|
|
||||||
jscs:
|
jscs:
|
||||||
enabled: true
|
enabled: true
|
||||||
|
@ -5,7 +5,7 @@ git:
|
|||||||
depth: 10
|
depth: 10
|
||||||
node_js:
|
node_js:
|
||||||
- "4"
|
- "4"
|
||||||
- "5"
|
- "6"
|
||||||
before_install:
|
before_install:
|
||||||
# Remove ./node_modules/.bin from PATH so node-which doesn't replace Unix which and cause RVM to barf. See https://github.com/travis-ci/travis-ci/issues/5092
|
# Remove ./node_modules/.bin from PATH so node-which doesn't replace Unix which and cause RVM to barf. See https://github.com/travis-ci/travis-ci/issues/5092
|
||||||
- export PATH=$(python -c 'from sys import argv;from collections import OrderedDict as od;print(":".join(od((p,None) for p in argv[1].split(":") if p.startswith("/")).keys()))' "$PATH")
|
- export PATH=$(python -c 'from sys import argv;from collections import OrderedDict as od;print(":".join(od((p,None) for p in argv[1].split(":") if p.startswith("/")).keys()))' "$PATH")
|
||||||
@ -19,12 +19,12 @@ before_install:
|
|||||||
install:
|
install:
|
||||||
- bundle install --deployment --jobs=3
|
- bundle install --deployment --jobs=3
|
||||||
- cp grunt/npm-shrinkwrap.json ./
|
- cp grunt/npm-shrinkwrap.json ./
|
||||||
- npm install -g grunt-cli
|
|
||||||
- npm install
|
- npm install
|
||||||
cache:
|
cache:
|
||||||
directories:
|
directories:
|
||||||
- node_modules
|
- node_modules
|
||||||
- vendor/bundle
|
- vendor/bundle
|
||||||
|
- "$HOME/google-cloud-sdk"
|
||||||
env:
|
env:
|
||||||
global:
|
global:
|
||||||
- NPM_CONFIG_PROGRESS="false"
|
- NPM_CONFIG_PROGRESS="false"
|
||||||
|
@ -233,7 +233,7 @@ includes code changes) and under the terms of the
|
|||||||
[Adhere to the Code Guide.](http://codeguide.co/#css)
|
[Adhere to the Code Guide.](http://codeguide.co/#css)
|
||||||
|
|
||||||
- When feasible, default color palettes should comply with [WCAG color contrast guidelines](http://www.w3.org/TR/WCAG20/#visual-audio-contrast).
|
- When feasible, default color palettes should comply with [WCAG color contrast guidelines](http://www.w3.org/TR/WCAG20/#visual-audio-contrast).
|
||||||
- Except in rare cases, don't remove default `:focus` styles (via e.g. `outline: none;`) without providing alternative styles. See [this A11Y Project post](http://a11yproject.com/posts/never-remove-css-outlines/) for more details.
|
- Except in rare cases, don't remove default `:focus` styles (via e.g. `outline: none;`) without providing alternative styles. See [this A11Y Project post](http://a11yproject.com/posts/never-remove-css-outlines) for more details.
|
||||||
|
|
||||||
### JS
|
### JS
|
||||||
|
|
||||||
|
6
Gemfile
@ -2,7 +2,7 @@ source 'https://rubygems.org'
|
|||||||
|
|
||||||
group :development, :test do
|
group :development, :test do
|
||||||
gem 'jekyll', '~> 3.1.2'
|
gem 'jekyll', '~> 3.1.2'
|
||||||
gem 'jekyll-redirect-from', '~> 0.10.0'
|
gem 'jekyll-redirect-from', '~> 0.11.0'
|
||||||
gem 'jekyll-sitemap', '~> 0.10.0'
|
gem 'jekyll-sitemap', '~> 0.11.0'
|
||||||
gem 'scss_lint', '~> 0.47.1'
|
gem 'scss_lint', '~> 0.49.0'
|
||||||
end
|
end
|
||||||
|
46
Gemfile.lock
@ -1,10 +1,11 @@
|
|||||||
GEM
|
GEM
|
||||||
remote: https://rubygems.org/
|
remote: https://rubygems.org/
|
||||||
specs:
|
specs:
|
||||||
|
addressable (2.4.0)
|
||||||
colorator (0.1)
|
colorator (0.1)
|
||||||
ffi (1.9.10)
|
ffi (1.9.13)
|
||||||
ffi (1.9.10-x64-mingw32)
|
ffi (1.9.13-x64-mingw32)
|
||||||
jekyll (3.1.2)
|
jekyll (3.1.6)
|
||||||
colorator (~> 0.1)
|
colorator (~> 0.1)
|
||||||
jekyll-sass-converter (~> 1.0)
|
jekyll-sass-converter (~> 1.0)
|
||||||
jekyll-watch (~> 1.1)
|
jekyll-watch (~> 1.1)
|
||||||
@ -13,29 +14,30 @@ GEM
|
|||||||
mercenary (~> 0.3.3)
|
mercenary (~> 0.3.3)
|
||||||
rouge (~> 1.7)
|
rouge (~> 1.7)
|
||||||
safe_yaml (~> 1.0)
|
safe_yaml (~> 1.0)
|
||||||
jekyll-redirect-from (0.10.0)
|
jekyll-redirect-from (0.11.0)
|
||||||
jekyll (>= 2.0)
|
jekyll (>= 2.0)
|
||||||
jekyll-sass-converter (1.4.0)
|
jekyll-sass-converter (1.4.0)
|
||||||
sass (~> 3.4)
|
sass (~> 3.4)
|
||||||
jekyll-sitemap (0.10.0)
|
jekyll-sitemap (0.11.0)
|
||||||
jekyll-watch (1.3.1)
|
addressable (~> 2.4.0)
|
||||||
listen (~> 3.0)
|
jekyll-watch (1.4.0)
|
||||||
kramdown (1.10.0)
|
listen (~> 3.0, < 3.1)
|
||||||
|
kramdown (1.11.1)
|
||||||
liquid (3.0.6)
|
liquid (3.0.6)
|
||||||
listen (3.0.6)
|
listen (3.0.8)
|
||||||
rb-fsevent (>= 0.9.3)
|
rb-fsevent (~> 0.9, >= 0.9.4)
|
||||||
rb-inotify (>= 0.9.7)
|
rb-inotify (~> 0.9, >= 0.9.7)
|
||||||
mercenary (0.3.5)
|
mercenary (0.3.6)
|
||||||
rake (10.5.0)
|
rake (11.2.2)
|
||||||
rb-fsevent (0.9.7)
|
rb-fsevent (0.9.7)
|
||||||
rb-inotify (0.9.7)
|
rb-inotify (0.9.7)
|
||||||
ffi (>= 0.5.0)
|
ffi (>= 0.5.0)
|
||||||
rouge (1.10.1)
|
rouge (1.11.1)
|
||||||
safe_yaml (1.0.4)
|
safe_yaml (1.0.4)
|
||||||
sass (3.4.21)
|
sass (3.4.22)
|
||||||
scss_lint (0.47.1)
|
scss_lint (0.49.0)
|
||||||
rake (>= 0.9, < 11)
|
rake (>= 0.9, < 12)
|
||||||
sass (~> 3.4.15)
|
sass (~> 3.4.20)
|
||||||
|
|
||||||
PLATFORMS
|
PLATFORMS
|
||||||
ruby
|
ruby
|
||||||
@ -43,9 +45,9 @@ PLATFORMS
|
|||||||
|
|
||||||
DEPENDENCIES
|
DEPENDENCIES
|
||||||
jekyll (~> 3.1.2)
|
jekyll (~> 3.1.2)
|
||||||
jekyll-redirect-from (~> 0.10.0)
|
jekyll-redirect-from (~> 0.11.0)
|
||||||
jekyll-sitemap (~> 0.10.0)
|
jekyll-sitemap (~> 0.11.0)
|
||||||
scss_lint (~> 0.47.1)
|
scss_lint (~> 0.49.0)
|
||||||
|
|
||||||
BUNDLED WITH
|
BUNDLED WITH
|
||||||
1.11.2
|
1.12.5
|
||||||
|
159
Gruntfile.js
@ -19,16 +19,12 @@ module.exports = function (grunt) {
|
|||||||
var fs = require('fs');
|
var fs = require('fs');
|
||||||
var path = require('path');
|
var path = require('path');
|
||||||
var isTravis = require('is-travis');
|
var isTravis = require('is-travis');
|
||||||
var mq4HoverShim = require('mq4-hover-shim');
|
|
||||||
var autoprefixerSettings = require('./grunt/autoprefixer-settings.js');
|
|
||||||
var autoprefixer = require('autoprefixer')(autoprefixerSettings);
|
|
||||||
|
|
||||||
var generateCommonJSModule = require('./grunt/bs-commonjs-generator.js');
|
|
||||||
var configBridge = grunt.file.readJSON('./grunt/configBridge.json', { encoding: 'utf8' });
|
var configBridge = grunt.file.readJSON('./grunt/configBridge.json', { encoding: 'utf8' });
|
||||||
|
|
||||||
Object.keys(configBridge.paths).forEach(function (key) {
|
Object.keys(configBridge.paths).forEach(function (key) {
|
||||||
configBridge.paths[key].forEach(function (val, i, arr) {
|
configBridge.paths[key].forEach(function (val, i, arr) {
|
||||||
arr[i] = path.join('./docs/assets', val);
|
arr[i] = path.join('./docs', val);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -47,8 +43,8 @@ module.exports = function (grunt) {
|
|||||||
'}\n',
|
'}\n',
|
||||||
jqueryVersionCheck: '+function ($) {\n' +
|
jqueryVersionCheck: '+function ($) {\n' +
|
||||||
' var version = $.fn.jquery.split(\' \')[0].split(\'.\')\n' +
|
' var version = $.fn.jquery.split(\' \')[0].split(\'.\')\n' +
|
||||||
' if ((version[0] < 2 && version[1] < 9) || (version[0] == 1 && version[1] == 9 && version[2] < 1) || (version[0] >= 3)) {\n' +
|
' if ((version[0] < 2 && version[1] < 9) || (version[0] == 1 && version[1] == 9 && version[2] < 1) || (version[0] >= 4)) {\n' +
|
||||||
' throw new Error(\'Bootstrap\\\'s JavaScript requires at least jQuery v1.9.1 but less than v3.0.0\')\n' +
|
' throw new Error(\'Bootstrap\\\'s JavaScript requires at least jQuery v1.9.1 but less than v4.0.0\')\n' +
|
||||||
' }\n' +
|
' }\n' +
|
||||||
'}(jQuery);\n\n',
|
'}(jQuery);\n\n',
|
||||||
|
|
||||||
@ -86,52 +82,6 @@ module.exports = function (grunt) {
|
|||||||
files: {
|
files: {
|
||||||
'<%= concat.bootstrap.dest %>' : '<%= concat.bootstrap.dest %>'
|
'<%= concat.bootstrap.dest %>' : '<%= concat.bootstrap.dest %>'
|
||||||
}
|
}
|
||||||
},
|
|
||||||
umd: {
|
|
||||||
options: {
|
|
||||||
modules: 'umd'
|
|
||||||
},
|
|
||||||
files: {
|
|
||||||
'dist/js/umd/util.js' : 'js/src/util.js',
|
|
||||||
'dist/js/umd/alert.js' : 'js/src/alert.js',
|
|
||||||
'dist/js/umd/button.js' : 'js/src/button.js',
|
|
||||||
'dist/js/umd/carousel.js' : 'js/src/carousel.js',
|
|
||||||
'dist/js/umd/collapse.js' : 'js/src/collapse.js',
|
|
||||||
'dist/js/umd/dropdown.js' : 'js/src/dropdown.js',
|
|
||||||
'dist/js/umd/modal.js' : 'js/src/modal.js',
|
|
||||||
'dist/js/umd/scrollspy.js' : 'js/src/scrollspy.js',
|
|
||||||
'dist/js/umd/tab.js' : 'js/src/tab.js',
|
|
||||||
'dist/js/umd/tooltip.js' : 'js/src/tooltip.js',
|
|
||||||
'dist/js/umd/popover.js' : 'js/src/popover.js'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
eslint: {
|
|
||||||
options: {
|
|
||||||
configFile: 'js/.eslintrc'
|
|
||||||
},
|
|
||||||
target: 'js/src/*.js'
|
|
||||||
},
|
|
||||||
|
|
||||||
jscs: {
|
|
||||||
options: {
|
|
||||||
config: 'js/.jscsrc'
|
|
||||||
},
|
|
||||||
grunt: {
|
|
||||||
src: ['Gruntfile.js', 'grunt/*.js']
|
|
||||||
},
|
|
||||||
core: {
|
|
||||||
src: 'js/src/*.js'
|
|
||||||
},
|
|
||||||
test: {
|
|
||||||
src: 'js/tests/unit/*.js'
|
|
||||||
},
|
|
||||||
assets: {
|
|
||||||
options: {
|
|
||||||
requireCamelCaseOrUpperCaseIdentifiers: null
|
|
||||||
},
|
|
||||||
src: ['docs/assets/js/src/*.js', 'docs/assets/js/*.js', '!docs/assets/js/*.min.js']
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -213,38 +163,6 @@ module.exports = function (grunt) {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
postcss: {
|
|
||||||
core: {
|
|
||||||
options: {
|
|
||||||
map: true,
|
|
||||||
processors: [
|
|
||||||
mq4HoverShim.postprocessorFor({ hoverSelectorPrefix: '.bs-true-hover ' }),
|
|
||||||
autoprefixer
|
|
||||||
]
|
|
||||||
},
|
|
||||||
src: 'dist/css/*.css'
|
|
||||||
},
|
|
||||||
docs: {
|
|
||||||
options: {
|
|
||||||
processors: [
|
|
||||||
autoprefixer
|
|
||||||
]
|
|
||||||
},
|
|
||||||
src: 'docs/assets/css/docs.min.css'
|
|
||||||
},
|
|
||||||
examples: {
|
|
||||||
options: {
|
|
||||||
processors: [
|
|
||||||
autoprefixer
|
|
||||||
]
|
|
||||||
},
|
|
||||||
expand: true,
|
|
||||||
cwd: 'docs/examples/',
|
|
||||||
src: ['**/*.css'],
|
|
||||||
dest: 'docs/examples/'
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
cssmin: {
|
cssmin: {
|
||||||
options: {
|
options: {
|
||||||
// TODO: disable `zeroUnits` optimization once clean-css 3.2 is released
|
// TODO: disable `zeroUnits` optimization once clean-css 3.2 is released
|
||||||
@ -266,8 +184,15 @@ module.exports = function (grunt) {
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
docs: {
|
docs: {
|
||||||
src: 'docs/assets/css/docs.min.css',
|
files: [
|
||||||
dest: 'docs/assets/css/docs.min.css'
|
{
|
||||||
|
expand: true,
|
||||||
|
cwd: 'docs/assets/css',
|
||||||
|
src: ['*.css', '!*.min.css'],
|
||||||
|
dest: 'docs/assets/css',
|
||||||
|
ext: '.min.css'
|
||||||
|
}
|
||||||
|
]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -308,14 +233,14 @@ module.exports = function (grunt) {
|
|||||||
htmllint: {
|
htmllint: {
|
||||||
options: {
|
options: {
|
||||||
ignore: [
|
ignore: [
|
||||||
'Element “img” is missing required attribute “src”.',
|
'Attribute “autocomplete” is only allowed when the input type is “color”, “date”, “datetime”, “datetime-local”, “email”, “hidden”, “month”, “number”, “password”, “range”, “search”, “tel”, “text”, “time”, “url”, or “week”.',
|
||||||
'Attribute “autocomplete” is only allowed when the input type is “color”, “date”, “datetime”, “datetime-local”, “email”, “month”, “number”, “password”, “range”, “search”, “tel”, “text”, “time”, “url”, or “week”.',
|
|
||||||
'Attribute “autocomplete” not allowed on element “button” at this point.',
|
'Attribute “autocomplete” not allowed on element “button” at this point.',
|
||||||
'Element “div” not allowed as child of element “progress” in this context. (Suppressing further errors from this subtree.)',
|
|
||||||
'Consider using the “h1” element as a top-level heading only (all “h1” elements are treated as top-level headings by many screen readers and other tools).',
|
'Consider using the “h1” element as a top-level heading only (all “h1” elements are treated as top-level headings by many screen readers and other tools).',
|
||||||
'The “datetime” input type is not supported in all browsers. Please be sure to test, and consider using a polyfill.',
|
'Element “div” not allowed as child of element “progress” in this context. (Suppressing further errors from this subtree.)',
|
||||||
|
'Element “img” is missing required attribute “src”.',
|
||||||
'The “color” input type is not supported in all browsers. Please be sure to test, and consider using a polyfill.',
|
'The “color” input type is not supported in all browsers. Please be sure to test, and consider using a polyfill.',
|
||||||
'The “date” input type is not supported in all browsers. Please be sure to test, and consider using a polyfill.',
|
'The “date” input type is not supported in all browsers. Please be sure to test, and consider using a polyfill.',
|
||||||
|
'The “datetime” input type is not supported in all browsers. Please be sure to test, and consider using a polyfill.',
|
||||||
'The “datetime-local” input type is not supported in all browsers. Please be sure to test, and consider using a polyfill.',
|
'The “datetime-local” input type is not supported in all browsers. Please be sure to test, and consider using a polyfill.',
|
||||||
'The “month” input type is not supported in all browsers. Please be sure to test, and consider using a polyfill.',
|
'The “month” input type is not supported in all browsers. Please be sure to test, and consider using a polyfill.',
|
||||||
'The “time” input type is not supported in all browsers. Please be sure to test, and consider using a polyfill.',
|
'The “time” input type is not supported in all browsers. Please be sure to test, and consider using a polyfill.',
|
||||||
@ -327,7 +252,7 @@ module.exports = function (grunt) {
|
|||||||
|
|
||||||
watch: {
|
watch: {
|
||||||
src: {
|
src: {
|
||||||
files: '<%= jscs.core.src %>',
|
files: '<%= concat.bootstrap.src %>',
|
||||||
tasks: ['babel:dev']
|
tasks: ['babel:dev']
|
||||||
},
|
},
|
||||||
sass: {
|
sass: {
|
||||||
@ -354,8 +279,17 @@ module.exports = function (grunt) {
|
|||||||
},
|
},
|
||||||
|
|
||||||
exec: {
|
exec: {
|
||||||
npmUpdate: {
|
postcss: {
|
||||||
command: 'npm update'
|
command: 'npm run postcss'
|
||||||
|
},
|
||||||
|
'postcss-docs': {
|
||||||
|
command: 'npm run postcss-docs'
|
||||||
|
},
|
||||||
|
htmlhint: {
|
||||||
|
command: 'npm run htmlhint'
|
||||||
|
},
|
||||||
|
'upload-preview': {
|
||||||
|
command: './grunt/upload-preview.sh'
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -403,7 +337,7 @@ module.exports = function (grunt) {
|
|||||||
require('time-grunt')(grunt);
|
require('time-grunt')(grunt);
|
||||||
|
|
||||||
// Docs HTML validation task
|
// Docs HTML validation task
|
||||||
grunt.registerTask('validate-html', ['jekyll:docs', 'htmllint']);
|
grunt.registerTask('validate-html', ['jekyll:docs', 'htmllint', 'exec:htmlhint']);
|
||||||
|
|
||||||
var runSubset = function (subset) {
|
var runSubset = function (subset) {
|
||||||
return !process.env.TWBS_TEST || process.env.TWBS_TEST === subset;
|
return !process.env.TWBS_TEST || process.env.TWBS_TEST === subset;
|
||||||
@ -418,7 +352,7 @@ module.exports = function (grunt) {
|
|||||||
if (runSubset('core') &&
|
if (runSubset('core') &&
|
||||||
// Skip core tests if this is a Savage build
|
// Skip core tests if this is a Savage build
|
||||||
process.env.TRAVIS_REPO_SLUG !== 'twbs-savage/bootstrap') {
|
process.env.TRAVIS_REPO_SLUG !== 'twbs-savage/bootstrap') {
|
||||||
testSubtasks = testSubtasks.concat(['dist-css', 'dist-js', 'test-scss', 'test-js', 'docs']);
|
testSubtasks = testSubtasks.concat(['dist-css', 'dist-js', 'test-scss', 'qunit', 'docs']);
|
||||||
}
|
}
|
||||||
// Skip HTML validation if running a different subset of the test suite
|
// Skip HTML validation if running a different subset of the test suite
|
||||||
if (runSubset('validate-html') &&
|
if (runSubset('validate-html') &&
|
||||||
@ -430,18 +364,18 @@ module.exports = function (grunt) {
|
|||||||
// Only run Sauce Labs tests if there's a Sauce access key
|
// Only run Sauce Labs tests if there's a Sauce access key
|
||||||
if (typeof process.env.SAUCE_ACCESS_KEY !== 'undefined' &&
|
if (typeof process.env.SAUCE_ACCESS_KEY !== 'undefined' &&
|
||||||
// Skip Sauce if running a different subset of the test suite
|
// Skip Sauce if running a different subset of the test suite
|
||||||
runSubset('sauce-js-unit') &&
|
runSubset('sauce-js-unit')) {
|
||||||
// Skip Sauce on Travis when [skip sauce] is in the commit message
|
testSubtasks = testSubtasks.concat(['dist', 'docs-css', 'docs-js', 'clean:docs', 'copy:docs', 'exec:upload-preview']);
|
||||||
isUndefOrNonZero(process.env.TWBS_DO_SAUCE)) {
|
// Skip Sauce on Travis when [skip sauce] is in the commit message
|
||||||
testSubtasks.push('babel:dev');
|
if (isUndefOrNonZero(process.env.TWBS_DO_SAUCE)) {
|
||||||
testSubtasks.push('connect');
|
testSubtasks.push('connect');
|
||||||
testSubtasks.push('saucelabs-qunit');
|
testSubtasks.push('saucelabs-qunit');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
grunt.registerTask('test', testSubtasks);
|
grunt.registerTask('test', testSubtasks);
|
||||||
grunt.registerTask('test-js', ['eslint', 'jscs:core', 'jscs:test', 'jscs:grunt', 'qunit']);
|
|
||||||
|
|
||||||
// JS distribution task.
|
// JS distribution task.
|
||||||
grunt.registerTask('dist-js', ['babel:dev', 'concat', 'babel:dist', 'stamp', 'uglify:core', 'commonjs']);
|
grunt.registerTask('dist-js', ['babel:dev', 'concat', 'babel:dist', 'stamp', 'uglify:core']);
|
||||||
|
|
||||||
grunt.registerTask('test-scss', ['scsslint:core']);
|
grunt.registerTask('test-scss', ['scsslint:core']);
|
||||||
|
|
||||||
@ -453,7 +387,7 @@ module.exports = function (grunt) {
|
|||||||
// grunt.registerTask('sass-compile', ['sass:core', 'sass:extras', 'sass:docs']);
|
// grunt.registerTask('sass-compile', ['sass:core', 'sass:extras', 'sass:docs']);
|
||||||
grunt.registerTask('sass-compile', ['sass:core', 'sass:docs']);
|
grunt.registerTask('sass-compile', ['sass:core', 'sass:docs']);
|
||||||
|
|
||||||
grunt.registerTask('dist-css', ['sass-compile', 'postcss:core', 'cssmin:core', 'cssmin:docs']);
|
grunt.registerTask('dist-css', ['sass-compile', 'exec:postcss', 'cssmin:core', 'cssmin:docs']);
|
||||||
|
|
||||||
// Full distribution task.
|
// Full distribution task.
|
||||||
grunt.registerTask('dist', ['clean:dist', 'dist-css', 'dist-js']);
|
grunt.registerTask('dist', ['clean:dist', 'dist-css', 'dist-js']);
|
||||||
@ -461,22 +395,11 @@ module.exports = function (grunt) {
|
|||||||
// Default task.
|
// Default task.
|
||||||
grunt.registerTask('default', ['clean:dist', 'test']);
|
grunt.registerTask('default', ['clean:dist', 'test']);
|
||||||
|
|
||||||
grunt.registerTask('commonjs', ['babel:umd', 'npm-js']);
|
|
||||||
|
|
||||||
grunt.registerTask('npm-js', 'Generate npm-js entrypoint module in dist dir.', function () {
|
|
||||||
var srcFiles = Object.keys(grunt.config.get('babel.umd.files')).map(function (filename) {
|
|
||||||
return './' + path.join('umd', path.basename(filename))
|
|
||||||
})
|
|
||||||
var destFilepath = 'dist/js/npm.js';
|
|
||||||
generateCommonJSModule(grunt, srcFiles, destFilepath);
|
|
||||||
});
|
|
||||||
|
|
||||||
// Docs task.
|
// Docs task.
|
||||||
grunt.registerTask('docs-css', ['postcss:docs', 'postcss:examples', 'cssmin:docs']);
|
grunt.registerTask('docs-css', ['cssmin:docs', 'exec:postcss-docs']);
|
||||||
grunt.registerTask('lint-docs-css', ['scsslint:docs']);
|
grunt.registerTask('lint-docs-css', ['scsslint:docs']);
|
||||||
grunt.registerTask('docs-js', ['uglify:docsJs']);
|
grunt.registerTask('docs-js', ['uglify:docsJs']);
|
||||||
grunt.registerTask('lint-docs-js', ['jscs:assets']);
|
grunt.registerTask('docs', ['lint-docs-css', 'docs-css', 'docs-js', 'clean:docs', 'copy:docs']);
|
||||||
grunt.registerTask('docs', ['lint-docs-css', 'docs-css', 'docs-js', 'lint-docs-js', 'clean:docs', 'copy:docs']);
|
|
||||||
grunt.registerTask('docs-github', ['jekyll:github']);
|
grunt.registerTask('docs-github', ['jekyll:github']);
|
||||||
|
|
||||||
grunt.registerTask('prep-release', ['dist', 'docs', 'docs-github', 'compress']);
|
grunt.registerTask('prep-release', ['dist', 'docs', 'docs-github', 'compress']);
|
||||||
|
@ -5,7 +5,7 @@ Before opening an issue:
|
|||||||
- Prepare a [reduced test case](https://css-tricks.com/reduced-test-cases/) for any bugs
|
- Prepare a [reduced test case](https://css-tricks.com/reduced-test-cases/) for any bugs
|
||||||
- Read the [contributing guidelines](https://github.com/twbs/bootstrap/blob/master/CONTRIBUTING.md)
|
- Read the [contributing guidelines](https://github.com/twbs/bootstrap/blob/master/CONTRIBUTING.md)
|
||||||
|
|
||||||
When asking general "how to" questons:
|
When asking general "how to" questions:
|
||||||
|
|
||||||
- Please do not open an issue here
|
- Please do not open an issue here
|
||||||
- Instead, ask for help on [StackOverflow, IRC, or Slack](https://github.com/twbs/bootstrap/blob/master/README.md#community)
|
- Instead, ask for help on [StackOverflow, IRC, or Slack](https://github.com/twbs/bootstrap/blob/master/README.md#community)
|
||||||
|
10
README.md
@ -8,7 +8,7 @@
|
|||||||
[![devDependency Status](https://img.shields.io/david/dev/twbs/bootstrap.svg)](https://david-dm.org/twbs/bootstrap#info=devDependencies)
|
[![devDependency Status](https://img.shields.io/david/dev/twbs/bootstrap.svg)](https://david-dm.org/twbs/bootstrap#info=devDependencies)
|
||||||
[![Meteor Atmosphere](https://img.shields.io/badge/meteor-twbs%3Abootstrap-blue.svg)](https://atmospherejs.com/twbs/bootstrap)
|
[![Meteor Atmosphere](https://img.shields.io/badge/meteor-twbs%3Abootstrap-blue.svg)](https://atmospherejs.com/twbs/bootstrap)
|
||||||
[![Packagist Prerelease](https://img.shields.io/packagist/vpre/twbs/bootstrap.svg)](https://packagist.org/packages/twbs/bootstrap)
|
[![Packagist Prerelease](https://img.shields.io/packagist/vpre/twbs/bootstrap.svg)](https://packagist.org/packages/twbs/bootstrap)
|
||||||
[![NuGet](https://img.shields.io/nuget/vpre/bootstrap.svg)](https://www.nuget.org/packages/bootstrap/4.0.0-alpha2)
|
[![NuGet](https://img.shields.io/nuget/vpre/bootstrap.svg)](https://www.nuget.org/packages/bootstrap/4.0.0-alpha3)
|
||||||
[![Selenium Test Status](https://saucelabs.com/browser-matrix/bootstrap.svg)](https://saucelabs.com/u/bootstrap)
|
[![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](https://twitter.com/mdo) and [Jacob Thornton](https://twitter.com/fat), and maintained by the [core team](https://github.com/orgs/twbs/people) with the massive support and involvement of the community.
|
Bootstrap is a sleek, intuitive, and powerful front-end framework for faster and easier web development, created by [Mark Otto](https://twitter.com/mdo) and [Jacob Thornton](https://twitter.com/fat), and maintained by the [core team](https://github.com/orgs/twbs/people) with the massive support and involvement of the community.
|
||||||
@ -30,12 +30,12 @@ To get started, check out <http://getbootstrap.com>!
|
|||||||
|
|
||||||
Several quick start options are available:
|
Several quick start options are available:
|
||||||
|
|
||||||
- [Download the latest release.](https://github.com/twbs/bootstrap/archive/v4.0.0-alpha.2.zip)
|
- [Download the latest release.](https://github.com/twbs/bootstrap/archive/v4.0.0-alpha.3.zip)
|
||||||
- Clone the repo: `git clone https://github.com/twbs/bootstrap.git`
|
- Clone the repo: `git clone https://github.com/twbs/bootstrap.git`
|
||||||
- Install with [npm](https://www.npmjs.com): `npm install bootstrap@4.0.0-alpha.2`
|
- Install with [npm](https://www.npmjs.com): `npm install bootstrap@4.0.0-alpha.3`
|
||||||
- Install with [Meteor](https://www.meteor.com): `meteor add twbs:bootstrap@=4.0.0-alpha.2`
|
- Install with [Meteor](https://www.meteor.com): `meteor add twbs:bootstrap@=4.0.0-alpha.3`
|
||||||
- Install with [Composer](https://getcomposer.org): `composer require twbs/bootstrap`
|
- Install with [Composer](https://getcomposer.org): `composer require twbs/bootstrap`
|
||||||
- Install with [Bower](http://bower.io): `bower install bootstrap#v4.0.0-alpha.2`
|
- Install with [Bower](http://bower.io): `bower install bootstrap#v4.0.0-alpha.3`
|
||||||
- Install with [NuGet](https://www.nuget.org): CSS: `Install-Package bootstrap -Pre` Sass: `Install-Package bootstrap.sass -Pre` (`-Pre` is only required until Bootstrap v4 has a stable release).
|
- Install with [NuGet](https://www.nuget.org): CSS: `Install-Package bootstrap -Pre` Sass: `Install-Package bootstrap.sass -Pre` (`-Pre` is only required until Bootstrap v4 has a stable release).
|
||||||
|
|
||||||
Read the [Getting started page](http://getbootstrap.com/getting-started/) for information on the framework contents, templates and examples, and more.
|
Read the [Getting started page](http://getbootstrap.com/getting-started/) for information on the framework contents, templates and examples, and more.
|
||||||
|
18
_config.yml
@ -23,13 +23,13 @@ gems:
|
|||||||
- jekyll-sitemap
|
- jekyll-sitemap
|
||||||
|
|
||||||
# Custom vars
|
# Custom vars
|
||||||
current_version: 4.0.0-alpha.2
|
current_version: 4.0.0-alpha.3
|
||||||
repo: https://github.com/twbs/bootstrap
|
repo: https://github.com/twbs/bootstrap
|
||||||
slack: https://bootstrap-slack.herokuapp.com
|
slack: https://bootstrap-slack.herokuapp.com
|
||||||
|
|
||||||
download:
|
download:
|
||||||
source: https://github.com/twbs/bootstrap/archive/v4.0.0-alpha.2.zip
|
source: https://github.com/twbs/bootstrap/archive/v4.0.0-alpha.3.zip
|
||||||
dist: https://github.com/twbs/bootstrap/releases/download/v4.0.0-alpha.2/bootstrap-4.0.0-alpha.2-dist.zip
|
dist: https://github.com/twbs/bootstrap/releases/download/v4.0.0-alpha.3/bootstrap-4.0.0-alpha.3-dist.zip
|
||||||
|
|
||||||
blog: http://blog.getbootstrap.com
|
blog: http://blog.getbootstrap.com
|
||||||
expo: http://expo.getbootstrap.com
|
expo: http://expo.getbootstrap.com
|
||||||
@ -37,11 +37,11 @@ themes: http://themes.getbootstrap.com
|
|||||||
|
|
||||||
cdn:
|
cdn:
|
||||||
# See https://www.srihash.org for info on how to generate the hashes
|
# See https://www.srihash.org for info on how to generate the hashes
|
||||||
css: https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.2/css/bootstrap.min.css
|
css: https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.3/css/bootstrap.min.css
|
||||||
css_hash: "sha384-y3tfxAZXuh4HwSYylfB+J125MxIs6mR5FOHamPBG064zB+AFeWH94NdvaCBm8qnd"
|
css_hash: "sha384-MIwDKRSSImVFAZCVLtU0LMDdON6KVCrZHyVQQj6e8wIEJkW4tvwqXrbMIya1vriY"
|
||||||
js: https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.2/js/bootstrap.min.js
|
js: https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.3/js/bootstrap.min.js
|
||||||
js_hash: "sha384-vZ2WRJMwsjRMW/8U7i6PWi6AlO1L79snBrmgiDpgIWJ82z8eA5lenwvxbMV1PAh7"
|
js_hash: "sha384-ux8v3A6CPtOTqOzMKiuo3d/DomGaaClxFYdCu2HPMBEkf6x2xiDyJ7gkXU0MWwaD"
|
||||||
jquery: https://ajax.googleapis.com/ajax/libs/jquery/2.2.2/jquery.min.js
|
jquery: https://ajax.googleapis.com/ajax/libs/jquery/3.0.0/jquery.min.js
|
||||||
jquery_hash: "sha384-mXQoED/lFIuocc//nss8aJOIrz7X7XruhR6bO+sGceiSyMELoVdZkN7F0oYwcFH+"
|
jquery_hash: "sha384-THPy051/pYDQGanwU6poAc/hOdQxjnOEXzbT+OuUAFqNqFjL+4IGLBgCJC3ZOShY"
|
||||||
tether: https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js
|
tether: https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js
|
||||||
tether_hash: "sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB"
|
tether_hash: "sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB"
|
||||||
|
@ -29,7 +29,7 @@
|
|||||||
"test-infra"
|
"test-infra"
|
||||||
],
|
],
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"jquery": "1.9.1 - 2",
|
"jquery": "1.9.1 - 3",
|
||||||
"tether": "^1.1.1"
|
"tether": "^1.1.1"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
/*!
|
/*!
|
||||||
* Bootstrap v4.0.0-alpha.2 (http://getbootstrap.com)
|
* Bootstrap v4.0.0-alpha.3 (http://getbootstrap.com)
|
||||||
|
* Copyright 2011-2016 The Bootstrap Authors
|
||||||
* Copyright 2011-2016 Twitter, Inc.
|
* Copyright 2011-2016 Twitter, Inc.
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
*/
|
*/
|
||||||
@ -320,7 +321,7 @@ html {
|
|||||||
}
|
}
|
||||||
|
|
||||||
body {
|
body {
|
||||||
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", Arial, sans-serif;
|
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
|
||||||
font-size: 1rem;
|
font-size: 1rem;
|
||||||
line-height: 1.5;
|
line-height: 1.5;
|
||||||
color: #373a3c;
|
color: #373a3c;
|
||||||
@ -391,22 +392,21 @@ a:focus, a:hover {
|
|||||||
}
|
}
|
||||||
|
|
||||||
a:focus {
|
a:focus {
|
||||||
outline: thin dotted;
|
|
||||||
outline: 5px auto -webkit-focus-ring-color;
|
outline: 5px auto -webkit-focus-ring-color;
|
||||||
outline-offset: -2px;
|
outline-offset: -2px;
|
||||||
}
|
}
|
||||||
|
|
||||||
a:not([href]) {
|
a:not([href]):not([tabindex]) {
|
||||||
color: inherit;
|
color: inherit;
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
a:not([href]):focus, a:not([href]):hover {
|
a:not([href]):not([tabindex]):focus, a:not([href]):not([tabindex]):hover {
|
||||||
color: inherit;
|
color: inherit;
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
a:not([href]):focus {
|
a:not([href]):not([tabindex]):focus {
|
||||||
outline: none;
|
outline: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -811,110 +811,69 @@ pre code {
|
|||||||
clear: both;
|
clear: both;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-1 {
|
.col-xs-1, .col-xs-2, .col-xs-3, .col-xs-4, .col-xs-5, .col-xs-6, .col-xs-7, .col-xs-8, .col-xs-9, .col-xs-10, .col-xs-11, .col-xs-12, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12, .col-xl-1, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-10, .col-xl-11, .col-xl-12 {
|
||||||
position: relative;
|
position: relative;
|
||||||
min-height: 1px;
|
min-height: 1px;
|
||||||
padding-right: 15px;
|
padding-right: 15px;
|
||||||
padding-left: 15px;
|
padding-left: 15px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.col-xs-1 {
|
||||||
float: left;
|
float: left;
|
||||||
width: 8.333333%;
|
width: 8.333333%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-2 {
|
.col-xs-2 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 16.666667%;
|
width: 16.666667%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-3 {
|
.col-xs-3 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 25%;
|
width: 25%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-4 {
|
.col-xs-4 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 33.333333%;
|
width: 33.333333%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-5 {
|
.col-xs-5 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 41.666667%;
|
width: 41.666667%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-6 {
|
.col-xs-6 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 50%;
|
width: 50%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-7 {
|
.col-xs-7 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 58.333333%;
|
width: 58.333333%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-8 {
|
.col-xs-8 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 66.666667%;
|
width: 66.666667%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-9 {
|
.col-xs-9 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 75%;
|
width: 75%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-10 {
|
.col-xs-10 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 83.333333%;
|
width: 83.333333%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-11 {
|
.col-xs-11 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 91.666667%;
|
width: 91.666667%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-12 {
|
.col-xs-12 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
@ -1069,98 +1028,50 @@ pre code {
|
|||||||
|
|
||||||
@media (min-width: 544px) {
|
@media (min-width: 544px) {
|
||||||
.col-sm-1 {
|
.col-sm-1 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 8.333333%;
|
width: 8.333333%;
|
||||||
}
|
}
|
||||||
.col-sm-2 {
|
.col-sm-2 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 16.666667%;
|
width: 16.666667%;
|
||||||
}
|
}
|
||||||
.col-sm-3 {
|
.col-sm-3 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 25%;
|
width: 25%;
|
||||||
}
|
}
|
||||||
.col-sm-4 {
|
.col-sm-4 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 33.333333%;
|
width: 33.333333%;
|
||||||
}
|
}
|
||||||
.col-sm-5 {
|
.col-sm-5 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 41.666667%;
|
width: 41.666667%;
|
||||||
}
|
}
|
||||||
.col-sm-6 {
|
.col-sm-6 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 50%;
|
width: 50%;
|
||||||
}
|
}
|
||||||
.col-sm-7 {
|
.col-sm-7 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 58.333333%;
|
width: 58.333333%;
|
||||||
}
|
}
|
||||||
.col-sm-8 {
|
.col-sm-8 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 66.666667%;
|
width: 66.666667%;
|
||||||
}
|
}
|
||||||
.col-sm-9 {
|
.col-sm-9 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 75%;
|
width: 75%;
|
||||||
}
|
}
|
||||||
.col-sm-10 {
|
.col-sm-10 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 83.333333%;
|
width: 83.333333%;
|
||||||
}
|
}
|
||||||
.col-sm-11 {
|
.col-sm-11 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 91.666667%;
|
width: 91.666667%;
|
||||||
}
|
}
|
||||||
.col-sm-12 {
|
.col-sm-12 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
@ -1282,98 +1193,50 @@ pre code {
|
|||||||
|
|
||||||
@media (min-width: 768px) {
|
@media (min-width: 768px) {
|
||||||
.col-md-1 {
|
.col-md-1 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 8.333333%;
|
width: 8.333333%;
|
||||||
}
|
}
|
||||||
.col-md-2 {
|
.col-md-2 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 16.666667%;
|
width: 16.666667%;
|
||||||
}
|
}
|
||||||
.col-md-3 {
|
.col-md-3 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 25%;
|
width: 25%;
|
||||||
}
|
}
|
||||||
.col-md-4 {
|
.col-md-4 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 33.333333%;
|
width: 33.333333%;
|
||||||
}
|
}
|
||||||
.col-md-5 {
|
.col-md-5 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 41.666667%;
|
width: 41.666667%;
|
||||||
}
|
}
|
||||||
.col-md-6 {
|
.col-md-6 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 50%;
|
width: 50%;
|
||||||
}
|
}
|
||||||
.col-md-7 {
|
.col-md-7 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 58.333333%;
|
width: 58.333333%;
|
||||||
}
|
}
|
||||||
.col-md-8 {
|
.col-md-8 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 66.666667%;
|
width: 66.666667%;
|
||||||
}
|
}
|
||||||
.col-md-9 {
|
.col-md-9 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 75%;
|
width: 75%;
|
||||||
}
|
}
|
||||||
.col-md-10 {
|
.col-md-10 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 83.333333%;
|
width: 83.333333%;
|
||||||
}
|
}
|
||||||
.col-md-11 {
|
.col-md-11 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 91.666667%;
|
width: 91.666667%;
|
||||||
}
|
}
|
||||||
.col-md-12 {
|
.col-md-12 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
@ -1495,98 +1358,50 @@ pre code {
|
|||||||
|
|
||||||
@media (min-width: 992px) {
|
@media (min-width: 992px) {
|
||||||
.col-lg-1 {
|
.col-lg-1 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 8.333333%;
|
width: 8.333333%;
|
||||||
}
|
}
|
||||||
.col-lg-2 {
|
.col-lg-2 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 16.666667%;
|
width: 16.666667%;
|
||||||
}
|
}
|
||||||
.col-lg-3 {
|
.col-lg-3 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 25%;
|
width: 25%;
|
||||||
}
|
}
|
||||||
.col-lg-4 {
|
.col-lg-4 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 33.333333%;
|
width: 33.333333%;
|
||||||
}
|
}
|
||||||
.col-lg-5 {
|
.col-lg-5 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 41.666667%;
|
width: 41.666667%;
|
||||||
}
|
}
|
||||||
.col-lg-6 {
|
.col-lg-6 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 50%;
|
width: 50%;
|
||||||
}
|
}
|
||||||
.col-lg-7 {
|
.col-lg-7 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 58.333333%;
|
width: 58.333333%;
|
||||||
}
|
}
|
||||||
.col-lg-8 {
|
.col-lg-8 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 66.666667%;
|
width: 66.666667%;
|
||||||
}
|
}
|
||||||
.col-lg-9 {
|
.col-lg-9 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 75%;
|
width: 75%;
|
||||||
}
|
}
|
||||||
.col-lg-10 {
|
.col-lg-10 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 83.333333%;
|
width: 83.333333%;
|
||||||
}
|
}
|
||||||
.col-lg-11 {
|
.col-lg-11 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 91.666667%;
|
width: 91.666667%;
|
||||||
}
|
}
|
||||||
.col-lg-12 {
|
.col-lg-12 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
@ -1708,98 +1523,50 @@ pre code {
|
|||||||
|
|
||||||
@media (min-width: 1200px) {
|
@media (min-width: 1200px) {
|
||||||
.col-xl-1 {
|
.col-xl-1 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 8.333333%;
|
width: 8.333333%;
|
||||||
}
|
}
|
||||||
.col-xl-2 {
|
.col-xl-2 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 16.666667%;
|
width: 16.666667%;
|
||||||
}
|
}
|
||||||
.col-xl-3 {
|
.col-xl-3 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 25%;
|
width: 25%;
|
||||||
}
|
}
|
||||||
.col-xl-4 {
|
.col-xl-4 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 33.333333%;
|
width: 33.333333%;
|
||||||
}
|
}
|
||||||
.col-xl-5 {
|
.col-xl-5 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 41.666667%;
|
width: 41.666667%;
|
||||||
}
|
}
|
||||||
.col-xl-6 {
|
.col-xl-6 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 50%;
|
width: 50%;
|
||||||
}
|
}
|
||||||
.col-xl-7 {
|
.col-xl-7 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 58.333333%;
|
width: 58.333333%;
|
||||||
}
|
}
|
||||||
.col-xl-8 {
|
.col-xl-8 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 66.666667%;
|
width: 66.666667%;
|
||||||
}
|
}
|
||||||
.col-xl-9 {
|
.col-xl-9 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 75%;
|
width: 75%;
|
||||||
}
|
}
|
||||||
.col-xl-10 {
|
.col-xl-10 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 83.333333%;
|
width: 83.333333%;
|
||||||
}
|
}
|
||||||
.col-xl-11 {
|
.col-xl-11 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 91.666667%;
|
width: 91.666667%;
|
||||||
}
|
}
|
||||||
.col-xl-12 {
|
.col-xl-12 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
@ -2491,7 +2258,6 @@ select.form-control-lg:not([size]):not([multiple]), .input-group-lg > select.for
|
|||||||
}
|
}
|
||||||
|
|
||||||
.btn:focus, .btn.focus, .btn:active:focus, .btn:active.focus, .btn.active:focus, .btn.active.focus {
|
.btn:focus, .btn.focus, .btn:active:focus, .btn:active.focus, .btn.active:focus, .btn.active.focus {
|
||||||
outline: thin dotted;
|
|
||||||
outline: 5px auto -webkit-focus-ring-color;
|
outline: 5px auto -webkit-focus-ring-color;
|
||||||
outline-offset: -2px;
|
outline-offset: -2px;
|
||||||
}
|
}
|
||||||
@ -4046,24 +3812,6 @@ input[type="button"].btn-block {
|
|||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
@media (min-width: 544px) {
|
|
||||||
.navbar-toggleable-xs {
|
|
||||||
display: block !important;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (min-width: 768px) {
|
|
||||||
.navbar-toggleable-sm {
|
|
||||||
display: block !important;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (min-width: 992px) {
|
|
||||||
.navbar-toggleable-md {
|
|
||||||
display: block !important;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.navbar-nav .nav-item {
|
.navbar-nav .nav-item {
|
||||||
float: left;
|
float: left;
|
||||||
}
|
}
|
||||||
@ -4148,6 +3896,63 @@ input[type="button"].btn-block {
|
|||||||
background-color: rgba(255, 255, 255, 0.075);
|
background-color: rgba(255, 255, 255, 0.075);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.navbar-toggleable-xs::after {
|
||||||
|
content: "";
|
||||||
|
display: table;
|
||||||
|
clear: both;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 543px) {
|
||||||
|
.navbar-toggleable-xs .navbar-nav .nav-item {
|
||||||
|
float: none;
|
||||||
|
margin-left: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 544px) {
|
||||||
|
.navbar-toggleable-xs {
|
||||||
|
display: block !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.navbar-toggleable-sm::after {
|
||||||
|
content: "";
|
||||||
|
display: table;
|
||||||
|
clear: both;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 767px) {
|
||||||
|
.navbar-toggleable-sm .navbar-nav .nav-item {
|
||||||
|
float: none;
|
||||||
|
margin-left: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 768px) {
|
||||||
|
.navbar-toggleable-sm {
|
||||||
|
display: block !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.navbar-toggleable-md::after {
|
||||||
|
content: "";
|
||||||
|
display: table;
|
||||||
|
clear: both;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 991px) {
|
||||||
|
.navbar-toggleable-md .navbar-nav .nav-item {
|
||||||
|
float: none;
|
||||||
|
margin-left: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 992px) {
|
||||||
|
.navbar-toggleable-md {
|
||||||
|
display: block !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
.card {
|
.card {
|
||||||
position: relative;
|
position: relative;
|
||||||
display: block;
|
display: block;
|
||||||
@ -5454,7 +5259,7 @@ button.close {
|
|||||||
position: absolute;
|
position: absolute;
|
||||||
z-index: 1070;
|
z-index: 1070;
|
||||||
display: block;
|
display: block;
|
||||||
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", Arial, sans-serif;
|
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
|
||||||
font-style: normal;
|
font-style: normal;
|
||||||
font-weight: normal;
|
font-weight: normal;
|
||||||
letter-spacing: normal;
|
letter-spacing: normal;
|
||||||
@ -5554,7 +5359,7 @@ button.close {
|
|||||||
display: block;
|
display: block;
|
||||||
max-width: 276px;
|
max-width: 276px;
|
||||||
padding: 1px;
|
padding: 1px;
|
||||||
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", Arial, sans-serif;
|
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
|
||||||
font-style: normal;
|
font-style: normal;
|
||||||
font-weight: normal;
|
font-weight: normal;
|
||||||
letter-spacing: normal;
|
letter-spacing: normal;
|
||||||
@ -5666,6 +5471,10 @@ button.close {
|
|||||||
border-radius: 0.2375rem 0.2375rem 0 0;
|
border-radius: 0.2375rem 0.2375rem 0 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.popover-title:empty {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
.popover-content {
|
.popover-content {
|
||||||
padding: 9px 14px;
|
padding: 9px 14px;
|
||||||
}
|
}
|
||||||
@ -5921,10 +5730,6 @@ button.close {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.bg-inverse {
|
|
||||||
background-color: #373a3c;
|
|
||||||
}
|
|
||||||
|
|
||||||
.bg-faded {
|
.bg-faded {
|
||||||
background-color: #f7f7f9;
|
background-color: #f7f7f9;
|
||||||
}
|
}
|
||||||
@ -5974,6 +5779,15 @@ a.bg-danger:focus, a.bg-danger:hover {
|
|||||||
background-color: #c9302c !important;
|
background-color: #c9302c !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.bg-inverse {
|
||||||
|
color: #fff !important;
|
||||||
|
background-color: #373a3c !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
a.bg-inverse:focus, a.bg-inverse:hover {
|
||||||
|
background-color: #1f2021 !important;
|
||||||
|
}
|
||||||
|
|
||||||
.clearfix::after {
|
.clearfix::after {
|
||||||
content: "";
|
content: "";
|
||||||
display: table;
|
display: table;
|
||||||
|
2
dist/css/bootstrap.css.map
vendored
5
dist/css/bootstrap.min.css
vendored
2
dist/css/bootstrap.min.css.map
vendored
@ -1,6 +1,6 @@
|
|||||||
/*!
|
/*!
|
||||||
* Bootstrap v4.0.0-alpha.2 (http://getbootstrap.com)
|
* Bootstrap v4.0.0-alpha.3 (http://getbootstrap.com)
|
||||||
* Copyright 2011-2016 Twitter, Inc.
|
* Copyright 2011-2016 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors)
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -10,8 +10,8 @@ if (typeof jQuery === 'undefined') {
|
|||||||
|
|
||||||
+function ($) {
|
+function ($) {
|
||||||
var version = $.fn.jquery.split(' ')[0].split('.')
|
var version = $.fn.jquery.split(' ')[0].split('.')
|
||||||
if ((version[0] < 2 && version[1] < 9) || (version[0] == 1 && version[1] == 9 && version[2] < 1) || (version[0] >= 3)) {
|
if ((version[0] < 2 && version[1] < 9) || (version[0] == 1 && version[1] == 9 && version[2] < 1) || (version[0] >= 4)) {
|
||||||
throw new Error('Bootstrap\'s JavaScript requires at least jQuery v1.9.1 but less than v3.0.0')
|
throw new Error('Bootstrap\'s JavaScript requires at least jQuery v1.9.1 but less than v4.0.0')
|
||||||
}
|
}
|
||||||
}(jQuery);
|
}(jQuery);
|
||||||
|
|
||||||
@ -20,7 +20,7 @@ if (typeof jQuery === 'undefined') {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): util.js
|
* Bootstrap (v4.0.0-alpha.3): util.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -45,6 +45,8 @@ var Util = (function ($) {
|
|||||||
|
|
||||||
var transition = false;
|
var transition = false;
|
||||||
|
|
||||||
|
var MAX_UID = 1000000;
|
||||||
|
|
||||||
var TransitionEndEvent = {
|
var TransitionEndEvent = {
|
||||||
WebkitTransition: 'webkitTransitionEnd',
|
WebkitTransition: 'webkitTransitionEnd',
|
||||||
MozTransition: 'transitionend',
|
MozTransition: 'transitionend',
|
||||||
@ -67,8 +69,9 @@ var Util = (function ($) {
|
|||||||
delegateType: transition.end,
|
delegateType: transition.end,
|
||||||
handle: function handle(event) {
|
handle: function handle(event) {
|
||||||
if ($(event.target).is(this)) {
|
if ($(event.target).is(this)) {
|
||||||
return event.handleObj.handler.apply(this, arguments);
|
return event.handleObj.handler.apply(this, arguments); // eslint-disable-line prefer-rest-params
|
||||||
}
|
}
|
||||||
|
return undefined;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
@ -130,7 +133,7 @@ var Util = (function ($) {
|
|||||||
getUID: function getUID(prefix) {
|
getUID: function getUID(prefix) {
|
||||||
do {
|
do {
|
||||||
/* eslint-disable no-bitwise */
|
/* eslint-disable no-bitwise */
|
||||||
prefix += ~ ~(Math.random() * 1000000); // "~~" acts like a faster Math.floor() here
|
prefix += ~ ~(Math.random() * MAX_UID); // "~~" acts like a faster Math.floor() here
|
||||||
/* eslint-enable no-bitwise */
|
/* eslint-enable no-bitwise */
|
||||||
} while (document.getElementById(prefix));
|
} while (document.getElementById(prefix));
|
||||||
return prefix;
|
return prefix;
|
||||||
@ -187,7 +190,7 @@ var Util = (function ($) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): alert.js
|
* Bootstrap (v4.0.0-alpha.3): alert.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -201,7 +204,7 @@ var Alert = (function ($) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
var NAME = 'alert';
|
var NAME = 'alert';
|
||||||
var VERSION = '4.0.0-alpha.2';
|
var VERSION = '4.0.0-alpha.3';
|
||||||
var DATA_KEY = 'bs.alert';
|
var DATA_KEY = 'bs.alert';
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
var EVENT_KEY = '.' + DATA_KEY;
|
||||||
var DATA_API_KEY = '.data-api';
|
var DATA_API_KEY = '.data-api';
|
||||||
@ -373,7 +376,7 @@ var Alert = (function ($) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): button.js
|
* Bootstrap (v4.0.0-alpha.3): button.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -387,7 +390,7 @@ var Button = (function ($) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
var NAME = 'button';
|
var NAME = 'button';
|
||||||
var VERSION = '4.0.0-alpha.2';
|
var VERSION = '4.0.0-alpha.3';
|
||||||
var DATA_KEY = 'bs.button';
|
var DATA_KEY = 'bs.button';
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
var EVENT_KEY = '.' + DATA_KEY;
|
||||||
var DATA_API_KEY = '.data-api';
|
var DATA_API_KEY = '.data-api';
|
||||||
@ -541,7 +544,7 @@ var Button = (function ($) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): carousel.js
|
* Bootstrap (v4.0.0-alpha.3): carousel.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -555,12 +558,14 @@ var Carousel = (function ($) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
var NAME = 'carousel';
|
var NAME = 'carousel';
|
||||||
var VERSION = '4.0.0-alpha.2';
|
var VERSION = '4.0.0-alpha.3';
|
||||||
var DATA_KEY = 'bs.carousel';
|
var DATA_KEY = 'bs.carousel';
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
var EVENT_KEY = '.' + DATA_KEY;
|
||||||
var DATA_API_KEY = '.data-api';
|
var DATA_API_KEY = '.data-api';
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
||||||
var TRANSITION_DURATION = 600;
|
var TRANSITION_DURATION = 600;
|
||||||
|
var ARROW_LEFT_KEYCODE = 37; // KeyboardEvent.which value for left arrow key
|
||||||
|
var ARROW_RIGHT_KEYCODE = 39; // KeyboardEvent.which value for right arrow key
|
||||||
|
|
||||||
var Default = {
|
var Default = {
|
||||||
interval: 5000,
|
interval: 5000,
|
||||||
@ -776,10 +781,12 @@ var Carousel = (function ($) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
switch (event.which) {
|
switch (event.which) {
|
||||||
case 37:
|
case ARROW_LEFT_KEYCODE:
|
||||||
this.prev();break;
|
this.prev();
|
||||||
case 39:
|
break;
|
||||||
this.next();break;
|
case ARROW_RIGHT_KEYCODE:
|
||||||
|
this.next();
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1013,7 +1020,7 @@ var Carousel = (function ($) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): collapse.js
|
* Bootstrap (v4.0.0-alpha.3): collapse.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -1027,7 +1034,7 @@ var Collapse = (function ($) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
var NAME = 'collapse';
|
var NAME = 'collapse';
|
||||||
var VERSION = '4.0.0-alpha.2';
|
var VERSION = '4.0.0-alpha.3';
|
||||||
var DATA_KEY = 'bs.collapse';
|
var DATA_KEY = 'bs.collapse';
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
var EVENT_KEY = '.' + DATA_KEY;
|
||||||
var DATA_API_KEY = '.data-api';
|
var DATA_API_KEY = '.data-api';
|
||||||
@ -1371,7 +1378,7 @@ var Collapse = (function ($) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): dropdown.js
|
* Bootstrap (v4.0.0-alpha.3): dropdown.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -1385,11 +1392,15 @@ var Dropdown = (function ($) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
var NAME = 'dropdown';
|
var NAME = 'dropdown';
|
||||||
var VERSION = '4.0.0-alpha.2';
|
var VERSION = '4.0.0-alpha.3';
|
||||||
var DATA_KEY = 'bs.dropdown';
|
var DATA_KEY = 'bs.dropdown';
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
var EVENT_KEY = '.' + DATA_KEY;
|
||||||
var DATA_API_KEY = '.data-api';
|
var DATA_API_KEY = '.data-api';
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
||||||
|
var ESCAPE_KEYCODE = 27; // KeyboardEvent.which value for Escape (Esc) key
|
||||||
|
var ARROW_UP_KEYCODE = 38; // KeyboardEvent.which value for up arrow key
|
||||||
|
var ARROW_DOWN_KEYCODE = 40; // KeyboardEvent.which value for down arrow key
|
||||||
|
var RIGHT_MOUSE_BUTTON_WHICH = 3; // MouseEvent.which value for the right button (assuming a right-handed mouse)
|
||||||
|
|
||||||
var Event = {
|
var Event = {
|
||||||
HIDE: 'hide' + EVENT_KEY,
|
HIDE: 'hide' + EVENT_KEY,
|
||||||
@ -1524,7 +1535,7 @@ var Dropdown = (function ($) {
|
|||||||
}, {
|
}, {
|
||||||
key: '_clearMenus',
|
key: '_clearMenus',
|
||||||
value: function _clearMenus(event) {
|
value: function _clearMenus(event) {
|
||||||
if (event && event.which === 3) {
|
if (event && event.which === RIGHT_MOUSE_BUTTON_WHICH) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1587,9 +1598,9 @@ var Dropdown = (function ($) {
|
|||||||
var parent = Dropdown._getParentFromElement(this);
|
var parent = Dropdown._getParentFromElement(this);
|
||||||
var isActive = $(parent).hasClass(ClassName.OPEN);
|
var isActive = $(parent).hasClass(ClassName.OPEN);
|
||||||
|
|
||||||
if (!isActive && event.which !== 27 || isActive && event.which === 27) {
|
if (!isActive && event.which !== ESCAPE_KEYCODE || isActive && event.which === ESCAPE_KEYCODE) {
|
||||||
|
|
||||||
if (event.which === 27) {
|
if (event.which === ESCAPE_KEYCODE) {
|
||||||
var toggle = $(parent).find(Selector.DATA_TOGGLE)[0];
|
var toggle = $(parent).find(Selector.DATA_TOGGLE)[0];
|
||||||
$(toggle).trigger('focus');
|
$(toggle).trigger('focus');
|
||||||
}
|
}
|
||||||
@ -1610,12 +1621,12 @@ var Dropdown = (function ($) {
|
|||||||
|
|
||||||
var index = items.indexOf(event.target);
|
var index = items.indexOf(event.target);
|
||||||
|
|
||||||
if (event.which === 38 && index > 0) {
|
if (event.which === ARROW_UP_KEYCODE && index > 0) {
|
||||||
// up
|
// up
|
||||||
index--;
|
index--;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (event.which === 40 && index < items.length - 1) {
|
if (event.which === ARROW_DOWN_KEYCODE && index < items.length - 1) {
|
||||||
// down
|
// down
|
||||||
index++;
|
index++;
|
||||||
}
|
}
|
||||||
@ -1658,7 +1669,7 @@ var Dropdown = (function ($) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): modal.js
|
* Bootstrap (v4.0.0-alpha.3): modal.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -1672,13 +1683,14 @@ var Modal = (function ($) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
var NAME = 'modal';
|
var NAME = 'modal';
|
||||||
var VERSION = '4.0.0-alpha.2';
|
var VERSION = '4.0.0-alpha.3';
|
||||||
var DATA_KEY = 'bs.modal';
|
var DATA_KEY = 'bs.modal';
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
var EVENT_KEY = '.' + DATA_KEY;
|
||||||
var DATA_API_KEY = '.data-api';
|
var DATA_API_KEY = '.data-api';
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
||||||
var TRANSITION_DURATION = 300;
|
var TRANSITION_DURATION = 300;
|
||||||
var BACKDROP_TRANSITION_DURATION = 150;
|
var BACKDROP_TRANSITION_DURATION = 150;
|
||||||
|
var ESCAPE_KEYCODE = 27; // KeyboardEvent.which value for Escape (Esc) key
|
||||||
|
|
||||||
var Default = {
|
var Default = {
|
||||||
backdrop: true,
|
backdrop: true,
|
||||||
@ -1874,6 +1886,7 @@ var Modal = (function ($) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
this._element.style.display = 'block';
|
this._element.style.display = 'block';
|
||||||
|
this._element.removeAttribute('aria-hidden');
|
||||||
this._element.scrollTop = 0;
|
this._element.scrollTop = 0;
|
||||||
|
|
||||||
if (transition) {
|
if (transition) {
|
||||||
@ -1922,7 +1935,7 @@ var Modal = (function ($) {
|
|||||||
|
|
||||||
if (this._isShown && this._config.keyboard) {
|
if (this._isShown && this._config.keyboard) {
|
||||||
$(this._element).on(Event.KEYDOWN_DISMISS, function (event) {
|
$(this._element).on(Event.KEYDOWN_DISMISS, function (event) {
|
||||||
if (event.which === 27) {
|
if (event.which === ESCAPE_KEYCODE) {
|
||||||
_this10.hide();
|
_this10.hide();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -1945,6 +1958,7 @@ var Modal = (function ($) {
|
|||||||
var _this11 = this;
|
var _this11 = this;
|
||||||
|
|
||||||
this._element.style.display = 'none';
|
this._element.style.display = 'none';
|
||||||
|
this._element.setAttribute('aria-hidden', 'true');
|
||||||
this._showBackdrop(function () {
|
this._showBackdrop(function () {
|
||||||
$(document.body).removeClass(ClassName.OPEN);
|
$(document.body).removeClass(ClassName.OPEN);
|
||||||
_this11._resetAdjustments();
|
_this11._resetAdjustments();
|
||||||
@ -2050,7 +2064,7 @@ var Modal = (function ($) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (this._isBodyOverflowing && !isModalOverflowing) {
|
if (this._isBodyOverflowing && !isModalOverflowing) {
|
||||||
this._element.style.paddingRight = this._scrollbarWidth + 'px~';
|
this._element.style.paddingRight = this._scrollbarWidth + 'px';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}, {
|
}, {
|
||||||
@ -2182,7 +2196,7 @@ var Modal = (function ($) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): scrollspy.js
|
* Bootstrap (v4.0.0-alpha.3): scrollspy.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -2196,7 +2210,7 @@ var ScrollSpy = (function ($) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
var NAME = 'scrollspy';
|
var NAME = 'scrollspy';
|
||||||
var VERSION = '4.0.0-alpha.2';
|
var VERSION = '4.0.0-alpha.3';
|
||||||
var DATA_KEY = 'bs.scrollspy';
|
var DATA_KEY = 'bs.scrollspy';
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
var EVENT_KEY = '.' + DATA_KEY;
|
||||||
var DATA_API_KEY = '.data-api';
|
var DATA_API_KEY = '.data-api';
|
||||||
@ -2311,6 +2325,7 @@ var ScrollSpy = (function ($) {
|
|||||||
// todo (fat): remove sketch reliance on jQuery position/offset
|
// todo (fat): remove sketch reliance on jQuery position/offset
|
||||||
return [$(target)[offsetMethod]().top + offsetBase, targetSelector];
|
return [$(target)[offsetMethod]().top + offsetBase, targetSelector];
|
||||||
}
|
}
|
||||||
|
return null;
|
||||||
}).filter(function (item) {
|
}).filter(function (item) {
|
||||||
return item;
|
return item;
|
||||||
}).sort(function (a, b) {
|
}).sort(function (a, b) {
|
||||||
@ -2496,7 +2511,7 @@ var ScrollSpy = (function ($) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): tab.js
|
* Bootstrap (v4.0.0-alpha.3): tab.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -2510,7 +2525,7 @@ var Tab = (function ($) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
var NAME = 'tab';
|
var NAME = 'tab';
|
||||||
var VERSION = '4.0.0-alpha.2';
|
var VERSION = '4.0.0-alpha.3';
|
||||||
var DATA_KEY = 'bs.tab';
|
var DATA_KEY = 'bs.tab';
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
var EVENT_KEY = '.' + DATA_KEY;
|
||||||
var DATA_API_KEY = '.data-api';
|
var DATA_API_KEY = '.data-api';
|
||||||
@ -2755,7 +2770,7 @@ var Tab = (function ($) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): tooltip.js
|
* Bootstrap (v4.0.0-alpha.3): tooltip.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -2777,7 +2792,7 @@ var Tooltip = (function ($) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
var NAME = 'tooltip';
|
var NAME = 'tooltip';
|
||||||
var VERSION = '4.0.0-alpha.2';
|
var VERSION = '4.0.0-alpha.3';
|
||||||
var DATA_KEY = 'bs.tooltip';
|
var DATA_KEY = 'bs.tooltip';
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
var EVENT_KEY = '.' + DATA_KEY;
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
||||||
@ -3366,7 +3381,7 @@ var Tooltip = (function ($) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): popover.js
|
* Bootstrap (v4.0.0-alpha.3): popover.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -3380,7 +3395,7 @@ var Popover = (function ($) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
var NAME = 'popover';
|
var NAME = 'popover';
|
||||||
var VERSION = '4.0.0-alpha.2';
|
var VERSION = '4.0.0-alpha.3';
|
||||||
var DATA_KEY = 'bs.popover';
|
var DATA_KEY = 'bs.popover';
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
var EVENT_KEY = '.' + DATA_KEY;
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
||||||
|
8
dist/js/bootstrap.min.js
vendored
12
dist/js/npm.js
vendored
@ -1,12 +0,0 @@
|
|||||||
// This file is autogenerated via the `commonjs` Grunt task. You can require() this file in a CommonJS environment.
|
|
||||||
require('./umd/util.js')
|
|
||||||
require('./umd/alert.js')
|
|
||||||
require('./umd/button.js')
|
|
||||||
require('./umd/carousel.js')
|
|
||||||
require('./umd/collapse.js')
|
|
||||||
require('./umd/dropdown.js')
|
|
||||||
require('./umd/modal.js')
|
|
||||||
require('./umd/scrollspy.js')
|
|
||||||
require('./umd/tab.js')
|
|
||||||
require('./umd/tooltip.js')
|
|
||||||
require('./umd/popover.js')
|
|
211
dist/js/umd/alert.js
vendored
@ -1,211 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module', './util'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module, require('./util'));
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod, global.Util);
|
|
||||||
global.alert = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module, _util) {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
|
||||||
|
|
||||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
|
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
|
||||||
|
|
||||||
var _Util = _interopRequireDefault(_util);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): alert.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Alert = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Constants
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var NAME = 'alert';
|
|
||||||
var VERSION = '4.0.0-alpha.2';
|
|
||||||
var DATA_KEY = 'bs.alert';
|
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
|
||||||
var DATA_API_KEY = '.data-api';
|
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
|
||||||
var TRANSITION_DURATION = 150;
|
|
||||||
|
|
||||||
var Selector = {
|
|
||||||
DISMISS: '[data-dismiss="alert"]'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Event = {
|
|
||||||
CLOSE: 'close' + EVENT_KEY,
|
|
||||||
CLOSED: 'closed' + EVENT_KEY,
|
|
||||||
CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY
|
|
||||||
};
|
|
||||||
|
|
||||||
var ClassName = {
|
|
||||||
ALERT: 'alert',
|
|
||||||
FADE: 'fade',
|
|
||||||
IN: 'in'
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Class Definition
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Alert = (function () {
|
|
||||||
function Alert(element) {
|
|
||||||
_classCallCheck(this, Alert);
|
|
||||||
|
|
||||||
this._element = element;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Data Api implementation
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
// getters
|
|
||||||
|
|
||||||
_createClass(Alert, [{
|
|
||||||
key: 'close',
|
|
||||||
|
|
||||||
// public
|
|
||||||
|
|
||||||
value: function close(element) {
|
|
||||||
element = element || this._element;
|
|
||||||
|
|
||||||
var rootElement = this._getRootElement(element);
|
|
||||||
var customEvent = this._triggerCloseEvent(rootElement);
|
|
||||||
|
|
||||||
if (customEvent.isDefaultPrevented()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._removeElement(rootElement);
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'dispose',
|
|
||||||
value: function dispose() {
|
|
||||||
$.removeData(this._element, DATA_KEY);
|
|
||||||
this._element = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// private
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: '_getRootElement',
|
|
||||||
value: function _getRootElement(element) {
|
|
||||||
var selector = _Util['default'].getSelectorFromElement(element);
|
|
||||||
var parent = false;
|
|
||||||
|
|
||||||
if (selector) {
|
|
||||||
parent = $(selector)[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!parent) {
|
|
||||||
parent = $(element).closest('.' + ClassName.ALERT)[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_triggerCloseEvent',
|
|
||||||
value: function _triggerCloseEvent(element) {
|
|
||||||
var closeEvent = $.Event(Event.CLOSE);
|
|
||||||
|
|
||||||
$(element).trigger(closeEvent);
|
|
||||||
return closeEvent;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_removeElement',
|
|
||||||
value: function _removeElement(element) {
|
|
||||||
$(element).removeClass(ClassName.IN);
|
|
||||||
|
|
||||||
if (!_Util['default'].supportsTransitionEnd() || !$(element).hasClass(ClassName.FADE)) {
|
|
||||||
this._destroyElement(element);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$(element).one(_Util['default'].TRANSITION_END, $.proxy(this._destroyElement, this, element)).emulateTransitionEnd(TRANSITION_DURATION);
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_destroyElement',
|
|
||||||
value: function _destroyElement(element) {
|
|
||||||
$(element).detach().trigger(Event.CLOSED).remove();
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
|
|
||||||
}], [{
|
|
||||||
key: '_jQueryInterface',
|
|
||||||
value: function _jQueryInterface(config) {
|
|
||||||
return this.each(function () {
|
|
||||||
var $element = $(this);
|
|
||||||
var data = $element.data(DATA_KEY);
|
|
||||||
|
|
||||||
if (!data) {
|
|
||||||
data = new Alert(this);
|
|
||||||
$element.data(DATA_KEY, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (config === 'close') {
|
|
||||||
data[config](this);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_handleDismiss',
|
|
||||||
value: function _handleDismiss(alertInstance) {
|
|
||||||
return function (event) {
|
|
||||||
if (event) {
|
|
||||||
event.preventDefault();
|
|
||||||
}
|
|
||||||
|
|
||||||
alertInstance.close(this);
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'VERSION',
|
|
||||||
get: function get() {
|
|
||||||
return VERSION;
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
return Alert;
|
|
||||||
})();
|
|
||||||
|
|
||||||
$(document).on(Event.CLICK_DATA_API, Selector.DISMISS, Alert._handleDismiss(new Alert()));
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* jQuery
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
$.fn[NAME] = Alert._jQueryInterface;
|
|
||||||
$.fn[NAME].Constructor = Alert;
|
|
||||||
$.fn[NAME].noConflict = function () {
|
|
||||||
$.fn[NAME] = JQUERY_NO_CONFLICT;
|
|
||||||
return Alert._jQueryInterface;
|
|
||||||
};
|
|
||||||
|
|
||||||
return Alert;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = Alert;
|
|
||||||
});
|
|
189
dist/js/umd/button.js
vendored
@ -1,189 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module);
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod);
|
|
||||||
global.button = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module) {
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): button.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
|
||||||
|
|
||||||
var Button = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Constants
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var NAME = 'button';
|
|
||||||
var VERSION = '4.0.0-alpha.2';
|
|
||||||
var DATA_KEY = 'bs.button';
|
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
|
||||||
var DATA_API_KEY = '.data-api';
|
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
|
||||||
|
|
||||||
var ClassName = {
|
|
||||||
ACTIVE: 'active',
|
|
||||||
BUTTON: 'btn',
|
|
||||||
FOCUS: 'focus'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Selector = {
|
|
||||||
DATA_TOGGLE_CARROT: '[data-toggle^="button"]',
|
|
||||||
DATA_TOGGLE: '[data-toggle="buttons"]',
|
|
||||||
INPUT: 'input',
|
|
||||||
ACTIVE: '.active',
|
|
||||||
BUTTON: '.btn'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Event = {
|
|
||||||
CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY,
|
|
||||||
FOCUS_BLUR_DATA_API: 'focus' + EVENT_KEY + DATA_API_KEY + ' ' + ('blur' + EVENT_KEY + DATA_API_KEY)
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Class Definition
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Button = (function () {
|
|
||||||
function Button(element) {
|
|
||||||
_classCallCheck(this, Button);
|
|
||||||
|
|
||||||
this._element = element;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Data Api implementation
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
// getters
|
|
||||||
|
|
||||||
_createClass(Button, [{
|
|
||||||
key: 'toggle',
|
|
||||||
|
|
||||||
// public
|
|
||||||
|
|
||||||
value: function toggle() {
|
|
||||||
var triggerChangeEvent = true;
|
|
||||||
var rootElement = $(this._element).closest(Selector.DATA_TOGGLE)[0];
|
|
||||||
|
|
||||||
if (rootElement) {
|
|
||||||
var input = $(this._element).find(Selector.INPUT)[0];
|
|
||||||
|
|
||||||
if (input) {
|
|
||||||
if (input.type === 'radio') {
|
|
||||||
if (input.checked && $(this._element).hasClass(ClassName.ACTIVE)) {
|
|
||||||
triggerChangeEvent = false;
|
|
||||||
} else {
|
|
||||||
var activeElement = $(rootElement).find(Selector.ACTIVE)[0];
|
|
||||||
|
|
||||||
if (activeElement) {
|
|
||||||
$(activeElement).removeClass(ClassName.ACTIVE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (triggerChangeEvent) {
|
|
||||||
input.checked = !$(this._element).hasClass(ClassName.ACTIVE);
|
|
||||||
$(this._element).trigger('change');
|
|
||||||
}
|
|
||||||
|
|
||||||
input.focus();
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
this._element.setAttribute('aria-pressed', !$(this._element).hasClass(ClassName.ACTIVE));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (triggerChangeEvent) {
|
|
||||||
$(this._element).toggleClass(ClassName.ACTIVE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'dispose',
|
|
||||||
value: function dispose() {
|
|
||||||
$.removeData(this._element, DATA_KEY);
|
|
||||||
this._element = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
|
|
||||||
}], [{
|
|
||||||
key: '_jQueryInterface',
|
|
||||||
value: function _jQueryInterface(config) {
|
|
||||||
return this.each(function () {
|
|
||||||
var data = $(this).data(DATA_KEY);
|
|
||||||
|
|
||||||
if (!data) {
|
|
||||||
data = new Button(this);
|
|
||||||
$(this).data(DATA_KEY, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (config === 'toggle') {
|
|
||||||
data[config]();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'VERSION',
|
|
||||||
get: function get() {
|
|
||||||
return VERSION;
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
return Button;
|
|
||||||
})();
|
|
||||||
|
|
||||||
$(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE_CARROT, function (event) {
|
|
||||||
event.preventDefault();
|
|
||||||
|
|
||||||
var button = event.target;
|
|
||||||
|
|
||||||
if (!$(button).hasClass(ClassName.BUTTON)) {
|
|
||||||
button = $(button).closest(Selector.BUTTON);
|
|
||||||
}
|
|
||||||
|
|
||||||
Button._jQueryInterface.call($(button), 'toggle');
|
|
||||||
}).on(Event.FOCUS_BLUR_DATA_API, Selector.DATA_TOGGLE_CARROT, function (event) {
|
|
||||||
var button = $(event.target).closest(Selector.BUTTON)[0];
|
|
||||||
$(button).toggleClass(ClassName.FOCUS, /^focus(in)?$/.test(event.type));
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* jQuery
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
$.fn[NAME] = Button._jQueryInterface;
|
|
||||||
$.fn[NAME].Constructor = Button;
|
|
||||||
$.fn[NAME].noConflict = function () {
|
|
||||||
$.fn[NAME] = JQUERY_NO_CONFLICT;
|
|
||||||
return Button._jQueryInterface;
|
|
||||||
};
|
|
||||||
|
|
||||||
return Button;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = Button;
|
|
||||||
});
|
|
497
dist/js/umd/carousel.js
vendored
@ -1,497 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module', './util'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module, require('./util'));
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod, global.Util);
|
|
||||||
global.carousel = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module, _util) {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
|
||||||
|
|
||||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
|
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
|
||||||
|
|
||||||
var _Util = _interopRequireDefault(_util);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): carousel.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Carousel = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Constants
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var NAME = 'carousel';
|
|
||||||
var VERSION = '4.0.0-alpha.2';
|
|
||||||
var DATA_KEY = 'bs.carousel';
|
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
|
||||||
var DATA_API_KEY = '.data-api';
|
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
|
||||||
var TRANSITION_DURATION = 600;
|
|
||||||
|
|
||||||
var Default = {
|
|
||||||
interval: 5000,
|
|
||||||
keyboard: true,
|
|
||||||
slide: false,
|
|
||||||
pause: 'hover',
|
|
||||||
wrap: true
|
|
||||||
};
|
|
||||||
|
|
||||||
var DefaultType = {
|
|
||||||
interval: '(number|boolean)',
|
|
||||||
keyboard: 'boolean',
|
|
||||||
slide: '(boolean|string)',
|
|
||||||
pause: '(string|boolean)',
|
|
||||||
wrap: 'boolean'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Direction = {
|
|
||||||
NEXT: 'next',
|
|
||||||
PREVIOUS: 'prev'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Event = {
|
|
||||||
SLIDE: 'slide' + EVENT_KEY,
|
|
||||||
SLID: 'slid' + EVENT_KEY,
|
|
||||||
KEYDOWN: 'keydown' + EVENT_KEY,
|
|
||||||
MOUSEENTER: 'mouseenter' + EVENT_KEY,
|
|
||||||
MOUSELEAVE: 'mouseleave' + EVENT_KEY,
|
|
||||||
LOAD_DATA_API: 'load' + EVENT_KEY + DATA_API_KEY,
|
|
||||||
CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY
|
|
||||||
};
|
|
||||||
|
|
||||||
var ClassName = {
|
|
||||||
CAROUSEL: 'carousel',
|
|
||||||
ACTIVE: 'active',
|
|
||||||
SLIDE: 'slide',
|
|
||||||
RIGHT: 'right',
|
|
||||||
LEFT: 'left',
|
|
||||||
ITEM: 'carousel-item'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Selector = {
|
|
||||||
ACTIVE: '.active',
|
|
||||||
ACTIVE_ITEM: '.active.carousel-item',
|
|
||||||
ITEM: '.carousel-item',
|
|
||||||
NEXT_PREV: '.next, .prev',
|
|
||||||
INDICATORS: '.carousel-indicators',
|
|
||||||
DATA_SLIDE: '[data-slide], [data-slide-to]',
|
|
||||||
DATA_RIDE: '[data-ride="carousel"]'
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Class Definition
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Carousel = (function () {
|
|
||||||
function Carousel(element, config) {
|
|
||||||
_classCallCheck(this, Carousel);
|
|
||||||
|
|
||||||
this._items = null;
|
|
||||||
this._interval = null;
|
|
||||||
this._activeElement = null;
|
|
||||||
|
|
||||||
this._isPaused = false;
|
|
||||||
this._isSliding = false;
|
|
||||||
|
|
||||||
this._config = this._getConfig(config);
|
|
||||||
this._element = $(element)[0];
|
|
||||||
this._indicatorsElement = $(this._element).find(Selector.INDICATORS)[0];
|
|
||||||
|
|
||||||
this._addEventListeners();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Data Api implementation
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
// getters
|
|
||||||
|
|
||||||
_createClass(Carousel, [{
|
|
||||||
key: 'next',
|
|
||||||
|
|
||||||
// public
|
|
||||||
|
|
||||||
value: function next() {
|
|
||||||
if (!this._isSliding) {
|
|
||||||
this._slide(Direction.NEXT);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'nextWhenVisible',
|
|
||||||
value: function nextWhenVisible() {
|
|
||||||
// Don't call next when the page isn't visible
|
|
||||||
if (!document.hidden) {
|
|
||||||
this.next();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'prev',
|
|
||||||
value: function prev() {
|
|
||||||
if (!this._isSliding) {
|
|
||||||
this._slide(Direction.PREVIOUS);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'pause',
|
|
||||||
value: function pause(event) {
|
|
||||||
if (!event) {
|
|
||||||
this._isPaused = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($(this._element).find(Selector.NEXT_PREV)[0] && _Util['default'].supportsTransitionEnd()) {
|
|
||||||
_Util['default'].triggerTransitionEnd(this._element);
|
|
||||||
this.cycle(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
clearInterval(this._interval);
|
|
||||||
this._interval = null;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'cycle',
|
|
||||||
value: function cycle(event) {
|
|
||||||
if (!event) {
|
|
||||||
this._isPaused = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._interval) {
|
|
||||||
clearInterval(this._interval);
|
|
||||||
this._interval = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._config.interval && !this._isPaused) {
|
|
||||||
this._interval = setInterval($.proxy(document.visibilityState ? this.nextWhenVisible : this.next, this), this._config.interval);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'to',
|
|
||||||
value: function to(index) {
|
|
||||||
var _this = this;
|
|
||||||
|
|
||||||
this._activeElement = $(this._element).find(Selector.ACTIVE_ITEM)[0];
|
|
||||||
|
|
||||||
var activeIndex = this._getItemIndex(this._activeElement);
|
|
||||||
|
|
||||||
if (index > this._items.length - 1 || index < 0) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._isSliding) {
|
|
||||||
$(this._element).one(Event.SLID, function () {
|
|
||||||
return _this.to(index);
|
|
||||||
});
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (activeIndex === index) {
|
|
||||||
this.pause();
|
|
||||||
this.cycle();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var direction = index > activeIndex ? Direction.NEXT : Direction.PREVIOUS;
|
|
||||||
|
|
||||||
this._slide(direction, this._items[index]);
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'dispose',
|
|
||||||
value: function dispose() {
|
|
||||||
$(this._element).off(EVENT_KEY);
|
|
||||||
$.removeData(this._element, DATA_KEY);
|
|
||||||
|
|
||||||
this._items = null;
|
|
||||||
this._config = null;
|
|
||||||
this._element = null;
|
|
||||||
this._interval = null;
|
|
||||||
this._isPaused = null;
|
|
||||||
this._isSliding = null;
|
|
||||||
this._activeElement = null;
|
|
||||||
this._indicatorsElement = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// private
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: '_getConfig',
|
|
||||||
value: function _getConfig(config) {
|
|
||||||
config = $.extend({}, Default, config);
|
|
||||||
_Util['default'].typeCheckConfig(NAME, config, DefaultType);
|
|
||||||
return config;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_addEventListeners',
|
|
||||||
value: function _addEventListeners() {
|
|
||||||
if (this._config.keyboard) {
|
|
||||||
$(this._element).on(Event.KEYDOWN, $.proxy(this._keydown, this));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._config.pause === 'hover' && !('ontouchstart' in document.documentElement)) {
|
|
||||||
$(this._element).on(Event.MOUSEENTER, $.proxy(this.pause, this)).on(Event.MOUSELEAVE, $.proxy(this.cycle, this));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_keydown',
|
|
||||||
value: function _keydown(event) {
|
|
||||||
event.preventDefault();
|
|
||||||
|
|
||||||
if (/input|textarea/i.test(event.target.tagName)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (event.which) {
|
|
||||||
case 37:
|
|
||||||
this.prev();break;
|
|
||||||
case 39:
|
|
||||||
this.next();break;
|
|
||||||
default:
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_getItemIndex',
|
|
||||||
value: function _getItemIndex(element) {
|
|
||||||
this._items = $.makeArray($(element).parent().find(Selector.ITEM));
|
|
||||||
return this._items.indexOf(element);
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_getItemByDirection',
|
|
||||||
value: function _getItemByDirection(direction, activeElement) {
|
|
||||||
var isNextDirection = direction === Direction.NEXT;
|
|
||||||
var isPrevDirection = direction === Direction.PREVIOUS;
|
|
||||||
var activeIndex = this._getItemIndex(activeElement);
|
|
||||||
var lastItemIndex = this._items.length - 1;
|
|
||||||
var isGoingToWrap = isPrevDirection && activeIndex === 0 || isNextDirection && activeIndex === lastItemIndex;
|
|
||||||
|
|
||||||
if (isGoingToWrap && !this._config.wrap) {
|
|
||||||
return activeElement;
|
|
||||||
}
|
|
||||||
|
|
||||||
var delta = direction === Direction.PREVIOUS ? -1 : 1;
|
|
||||||
var itemIndex = (activeIndex + delta) % this._items.length;
|
|
||||||
|
|
||||||
return itemIndex === -1 ? this._items[this._items.length - 1] : this._items[itemIndex];
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_triggerSlideEvent',
|
|
||||||
value: function _triggerSlideEvent(relatedTarget, directionalClassname) {
|
|
||||||
var slideEvent = $.Event(Event.SLIDE, {
|
|
||||||
relatedTarget: relatedTarget,
|
|
||||||
direction: directionalClassname
|
|
||||||
});
|
|
||||||
|
|
||||||
$(this._element).trigger(slideEvent);
|
|
||||||
|
|
||||||
return slideEvent;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_setActiveIndicatorElement',
|
|
||||||
value: function _setActiveIndicatorElement(element) {
|
|
||||||
if (this._indicatorsElement) {
|
|
||||||
$(this._indicatorsElement).find(Selector.ACTIVE).removeClass(ClassName.ACTIVE);
|
|
||||||
|
|
||||||
var nextIndicator = this._indicatorsElement.children[this._getItemIndex(element)];
|
|
||||||
|
|
||||||
if (nextIndicator) {
|
|
||||||
$(nextIndicator).addClass(ClassName.ACTIVE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_slide',
|
|
||||||
value: function _slide(direction, element) {
|
|
||||||
var _this2 = this;
|
|
||||||
|
|
||||||
var activeElement = $(this._element).find(Selector.ACTIVE_ITEM)[0];
|
|
||||||
var nextElement = element || activeElement && this._getItemByDirection(direction, activeElement);
|
|
||||||
|
|
||||||
var isCycling = Boolean(this._interval);
|
|
||||||
|
|
||||||
var directionalClassName = direction === Direction.NEXT ? ClassName.LEFT : ClassName.RIGHT;
|
|
||||||
|
|
||||||
if (nextElement && $(nextElement).hasClass(ClassName.ACTIVE)) {
|
|
||||||
this._isSliding = false;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var slideEvent = this._triggerSlideEvent(nextElement, directionalClassName);
|
|
||||||
if (slideEvent.isDefaultPrevented()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!activeElement || !nextElement) {
|
|
||||||
// some weirdness is happening, so we bail
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._isSliding = true;
|
|
||||||
|
|
||||||
if (isCycling) {
|
|
||||||
this.pause();
|
|
||||||
}
|
|
||||||
|
|
||||||
this._setActiveIndicatorElement(nextElement);
|
|
||||||
|
|
||||||
var slidEvent = $.Event(Event.SLID, {
|
|
||||||
relatedTarget: nextElement,
|
|
||||||
direction: directionalClassName
|
|
||||||
});
|
|
||||||
|
|
||||||
if (_Util['default'].supportsTransitionEnd() && $(this._element).hasClass(ClassName.SLIDE)) {
|
|
||||||
|
|
||||||
$(nextElement).addClass(direction);
|
|
||||||
|
|
||||||
_Util['default'].reflow(nextElement);
|
|
||||||
|
|
||||||
$(activeElement).addClass(directionalClassName);
|
|
||||||
$(nextElement).addClass(directionalClassName);
|
|
||||||
|
|
||||||
$(activeElement).one(_Util['default'].TRANSITION_END, function () {
|
|
||||||
$(nextElement).removeClass(directionalClassName).removeClass(direction);
|
|
||||||
|
|
||||||
$(nextElement).addClass(ClassName.ACTIVE);
|
|
||||||
|
|
||||||
$(activeElement).removeClass(ClassName.ACTIVE).removeClass(direction).removeClass(directionalClassName);
|
|
||||||
|
|
||||||
_this2._isSliding = false;
|
|
||||||
|
|
||||||
setTimeout(function () {
|
|
||||||
return $(_this2._element).trigger(slidEvent);
|
|
||||||
}, 0);
|
|
||||||
}).emulateTransitionEnd(TRANSITION_DURATION);
|
|
||||||
} else {
|
|
||||||
$(activeElement).removeClass(ClassName.ACTIVE);
|
|
||||||
$(nextElement).addClass(ClassName.ACTIVE);
|
|
||||||
|
|
||||||
this._isSliding = false;
|
|
||||||
$(this._element).trigger(slidEvent);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isCycling) {
|
|
||||||
this.cycle();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
|
|
||||||
}], [{
|
|
||||||
key: '_jQueryInterface',
|
|
||||||
value: function _jQueryInterface(config) {
|
|
||||||
return this.each(function () {
|
|
||||||
var data = $(this).data(DATA_KEY);
|
|
||||||
var _config = $.extend({}, Default, $(this).data());
|
|
||||||
|
|
||||||
if (typeof config === 'object') {
|
|
||||||
$.extend(_config, config);
|
|
||||||
}
|
|
||||||
|
|
||||||
var action = typeof config === 'string' ? config : _config.slide;
|
|
||||||
|
|
||||||
if (!data) {
|
|
||||||
data = new Carousel(this, _config);
|
|
||||||
$(this).data(DATA_KEY, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (typeof config === 'number') {
|
|
||||||
data.to(config);
|
|
||||||
} else if (typeof action === 'string') {
|
|
||||||
if (data[action] === undefined) {
|
|
||||||
throw new Error('No method named "' + action + '"');
|
|
||||||
}
|
|
||||||
data[action]();
|
|
||||||
} else if (_config.interval) {
|
|
||||||
data.pause();
|
|
||||||
data.cycle();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_dataApiClickHandler',
|
|
||||||
value: function _dataApiClickHandler(event) {
|
|
||||||
var selector = _Util['default'].getSelectorFromElement(this);
|
|
||||||
|
|
||||||
if (!selector) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var target = $(selector)[0];
|
|
||||||
|
|
||||||
if (!target || !$(target).hasClass(ClassName.CAROUSEL)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var config = $.extend({}, $(target).data(), $(this).data());
|
|
||||||
var slideIndex = this.getAttribute('data-slide-to');
|
|
||||||
|
|
||||||
if (slideIndex) {
|
|
||||||
config.interval = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
Carousel._jQueryInterface.call($(target), config);
|
|
||||||
|
|
||||||
if (slideIndex) {
|
|
||||||
$(target).data(DATA_KEY).to(slideIndex);
|
|
||||||
}
|
|
||||||
|
|
||||||
event.preventDefault();
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'VERSION',
|
|
||||||
get: function get() {
|
|
||||||
return VERSION;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'Default',
|
|
||||||
get: function get() {
|
|
||||||
return Default;
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
return Carousel;
|
|
||||||
})();
|
|
||||||
|
|
||||||
$(document).on(Event.CLICK_DATA_API, Selector.DATA_SLIDE, Carousel._dataApiClickHandler);
|
|
||||||
|
|
||||||
$(window).on(Event.LOAD_DATA_API, function () {
|
|
||||||
$(Selector.DATA_RIDE).each(function () {
|
|
||||||
var $carousel = $(this);
|
|
||||||
Carousel._jQueryInterface.call($carousel, $carousel.data());
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* jQuery
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
$.fn[NAME] = Carousel._jQueryInterface;
|
|
||||||
$.fn[NAME].Constructor = Carousel;
|
|
||||||
$.fn[NAME].noConflict = function () {
|
|
||||||
$.fn[NAME] = JQUERY_NO_CONFLICT;
|
|
||||||
return Carousel._jQueryInterface;
|
|
||||||
};
|
|
||||||
|
|
||||||
return Carousel;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = Carousel;
|
|
||||||
});
|
|
383
dist/js/umd/collapse.js
vendored
@ -1,383 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module', './util'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module, require('./util'));
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod, global.Util);
|
|
||||||
global.collapse = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module, _util) {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
|
||||||
|
|
||||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
|
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
|
||||||
|
|
||||||
var _Util = _interopRequireDefault(_util);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): collapse.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Collapse = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Constants
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var NAME = 'collapse';
|
|
||||||
var VERSION = '4.0.0-alpha.2';
|
|
||||||
var DATA_KEY = 'bs.collapse';
|
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
|
||||||
var DATA_API_KEY = '.data-api';
|
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
|
||||||
var TRANSITION_DURATION = 600;
|
|
||||||
|
|
||||||
var Default = {
|
|
||||||
toggle: true,
|
|
||||||
parent: ''
|
|
||||||
};
|
|
||||||
|
|
||||||
var DefaultType = {
|
|
||||||
toggle: 'boolean',
|
|
||||||
parent: 'string'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Event = {
|
|
||||||
SHOW: 'show' + EVENT_KEY,
|
|
||||||
SHOWN: 'shown' + EVENT_KEY,
|
|
||||||
HIDE: 'hide' + EVENT_KEY,
|
|
||||||
HIDDEN: 'hidden' + EVENT_KEY,
|
|
||||||
CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY
|
|
||||||
};
|
|
||||||
|
|
||||||
var ClassName = {
|
|
||||||
IN: 'in',
|
|
||||||
COLLAPSE: 'collapse',
|
|
||||||
COLLAPSING: 'collapsing',
|
|
||||||
COLLAPSED: 'collapsed'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Dimension = {
|
|
||||||
WIDTH: 'width',
|
|
||||||
HEIGHT: 'height'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Selector = {
|
|
||||||
ACTIVES: '.panel > .in, .panel > .collapsing',
|
|
||||||
DATA_TOGGLE: '[data-toggle="collapse"]'
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Class Definition
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Collapse = (function () {
|
|
||||||
function Collapse(element, config) {
|
|
||||||
_classCallCheck(this, Collapse);
|
|
||||||
|
|
||||||
this._isTransitioning = false;
|
|
||||||
this._element = element;
|
|
||||||
this._config = this._getConfig(config);
|
|
||||||
this._triggerArray = $.makeArray($('[data-toggle="collapse"][href="#' + element.id + '"],' + ('[data-toggle="collapse"][data-target="#' + element.id + '"]')));
|
|
||||||
|
|
||||||
this._parent = this._config.parent ? this._getParent() : null;
|
|
||||||
|
|
||||||
if (!this._config.parent) {
|
|
||||||
this._addAriaAndCollapsedClass(this._element, this._triggerArray);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._config.toggle) {
|
|
||||||
this.toggle();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Data Api implementation
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
// getters
|
|
||||||
|
|
||||||
_createClass(Collapse, [{
|
|
||||||
key: 'toggle',
|
|
||||||
|
|
||||||
// public
|
|
||||||
|
|
||||||
value: function toggle() {
|
|
||||||
if ($(this._element).hasClass(ClassName.IN)) {
|
|
||||||
this.hide();
|
|
||||||
} else {
|
|
||||||
this.show();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'show',
|
|
||||||
value: function show() {
|
|
||||||
var _this = this;
|
|
||||||
|
|
||||||
if (this._isTransitioning || $(this._element).hasClass(ClassName.IN)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var actives = undefined;
|
|
||||||
var activesData = undefined;
|
|
||||||
|
|
||||||
if (this._parent) {
|
|
||||||
actives = $.makeArray($(Selector.ACTIVES));
|
|
||||||
if (!actives.length) {
|
|
||||||
actives = null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (actives) {
|
|
||||||
activesData = $(actives).data(DATA_KEY);
|
|
||||||
if (activesData && activesData._isTransitioning) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var startEvent = $.Event(Event.SHOW);
|
|
||||||
$(this._element).trigger(startEvent);
|
|
||||||
if (startEvent.isDefaultPrevented()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (actives) {
|
|
||||||
Collapse._jQueryInterface.call($(actives), 'hide');
|
|
||||||
if (!activesData) {
|
|
||||||
$(actives).data(DATA_KEY, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var dimension = this._getDimension();
|
|
||||||
|
|
||||||
$(this._element).removeClass(ClassName.COLLAPSE).addClass(ClassName.COLLAPSING);
|
|
||||||
|
|
||||||
this._element.style[dimension] = 0;
|
|
||||||
this._element.setAttribute('aria-expanded', true);
|
|
||||||
|
|
||||||
if (this._triggerArray.length) {
|
|
||||||
$(this._triggerArray).removeClass(ClassName.COLLAPSED).attr('aria-expanded', true);
|
|
||||||
}
|
|
||||||
|
|
||||||
this.setTransitioning(true);
|
|
||||||
|
|
||||||
var complete = function complete() {
|
|
||||||
$(_this._element).removeClass(ClassName.COLLAPSING).addClass(ClassName.COLLAPSE).addClass(ClassName.IN);
|
|
||||||
|
|
||||||
_this._element.style[dimension] = '';
|
|
||||||
|
|
||||||
_this.setTransitioning(false);
|
|
||||||
|
|
||||||
$(_this._element).trigger(Event.SHOWN);
|
|
||||||
};
|
|
||||||
|
|
||||||
if (!_Util['default'].supportsTransitionEnd()) {
|
|
||||||
complete();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var capitalizedDimension = dimension[0].toUpperCase() + dimension.slice(1);
|
|
||||||
var scrollSize = 'scroll' + capitalizedDimension;
|
|
||||||
|
|
||||||
$(this._element).one(_Util['default'].TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION);
|
|
||||||
|
|
||||||
this._element.style[dimension] = this._element[scrollSize] + 'px';
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'hide',
|
|
||||||
value: function hide() {
|
|
||||||
var _this2 = this;
|
|
||||||
|
|
||||||
if (this._isTransitioning || !$(this._element).hasClass(ClassName.IN)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var startEvent = $.Event(Event.HIDE);
|
|
||||||
$(this._element).trigger(startEvent);
|
|
||||||
if (startEvent.isDefaultPrevented()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var dimension = this._getDimension();
|
|
||||||
var offsetDimension = dimension === Dimension.WIDTH ? 'offsetWidth' : 'offsetHeight';
|
|
||||||
|
|
||||||
this._element.style[dimension] = this._element[offsetDimension] + 'px';
|
|
||||||
|
|
||||||
_Util['default'].reflow(this._element);
|
|
||||||
|
|
||||||
$(this._element).addClass(ClassName.COLLAPSING).removeClass(ClassName.COLLAPSE).removeClass(ClassName.IN);
|
|
||||||
|
|
||||||
this._element.setAttribute('aria-expanded', false);
|
|
||||||
|
|
||||||
if (this._triggerArray.length) {
|
|
||||||
$(this._triggerArray).addClass(ClassName.COLLAPSED).attr('aria-expanded', false);
|
|
||||||
}
|
|
||||||
|
|
||||||
this.setTransitioning(true);
|
|
||||||
|
|
||||||
var complete = function complete() {
|
|
||||||
_this2.setTransitioning(false);
|
|
||||||
$(_this2._element).removeClass(ClassName.COLLAPSING).addClass(ClassName.COLLAPSE).trigger(Event.HIDDEN);
|
|
||||||
};
|
|
||||||
|
|
||||||
this._element.style[dimension] = 0;
|
|
||||||
|
|
||||||
if (!_Util['default'].supportsTransitionEnd()) {
|
|
||||||
complete();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$(this._element).one(_Util['default'].TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION);
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'setTransitioning',
|
|
||||||
value: function setTransitioning(isTransitioning) {
|
|
||||||
this._isTransitioning = isTransitioning;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'dispose',
|
|
||||||
value: function dispose() {
|
|
||||||
$.removeData(this._element, DATA_KEY);
|
|
||||||
|
|
||||||
this._config = null;
|
|
||||||
this._parent = null;
|
|
||||||
this._element = null;
|
|
||||||
this._triggerArray = null;
|
|
||||||
this._isTransitioning = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// private
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: '_getConfig',
|
|
||||||
value: function _getConfig(config) {
|
|
||||||
config = $.extend({}, Default, config);
|
|
||||||
config.toggle = Boolean(config.toggle); // coerce string values
|
|
||||||
_Util['default'].typeCheckConfig(NAME, config, DefaultType);
|
|
||||||
return config;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_getDimension',
|
|
||||||
value: function _getDimension() {
|
|
||||||
var hasWidth = $(this._element).hasClass(Dimension.WIDTH);
|
|
||||||
return hasWidth ? Dimension.WIDTH : Dimension.HEIGHT;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_getParent',
|
|
||||||
value: function _getParent() {
|
|
||||||
var _this3 = this;
|
|
||||||
|
|
||||||
var parent = $(this._config.parent)[0];
|
|
||||||
var selector = '[data-toggle="collapse"][data-parent="' + this._config.parent + '"]';
|
|
||||||
|
|
||||||
$(parent).find(selector).each(function (i, element) {
|
|
||||||
_this3._addAriaAndCollapsedClass(Collapse._getTargetFromElement(element), [element]);
|
|
||||||
});
|
|
||||||
|
|
||||||
return parent;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_addAriaAndCollapsedClass',
|
|
||||||
value: function _addAriaAndCollapsedClass(element, triggerArray) {
|
|
||||||
if (element) {
|
|
||||||
var isOpen = $(element).hasClass(ClassName.IN);
|
|
||||||
element.setAttribute('aria-expanded', isOpen);
|
|
||||||
|
|
||||||
if (triggerArray.length) {
|
|
||||||
$(triggerArray).toggleClass(ClassName.COLLAPSED, !isOpen).attr('aria-expanded', isOpen);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
|
|
||||||
}], [{
|
|
||||||
key: '_getTargetFromElement',
|
|
||||||
value: function _getTargetFromElement(element) {
|
|
||||||
var selector = _Util['default'].getSelectorFromElement(element);
|
|
||||||
return selector ? $(selector)[0] : null;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_jQueryInterface',
|
|
||||||
value: function _jQueryInterface(config) {
|
|
||||||
return this.each(function () {
|
|
||||||
var $this = $(this);
|
|
||||||
var data = $this.data(DATA_KEY);
|
|
||||||
var _config = $.extend({}, Default, $this.data(), typeof config === 'object' && config);
|
|
||||||
|
|
||||||
if (!data && _config.toggle && /show|hide/.test(config)) {
|
|
||||||
_config.toggle = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!data) {
|
|
||||||
data = new Collapse(this, _config);
|
|
||||||
$this.data(DATA_KEY, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (typeof config === 'string') {
|
|
||||||
if (data[config] === undefined) {
|
|
||||||
throw new Error('No method named "' + config + '"');
|
|
||||||
}
|
|
||||||
data[config]();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'VERSION',
|
|
||||||
get: function get() {
|
|
||||||
return VERSION;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'Default',
|
|
||||||
get: function get() {
|
|
||||||
return Default;
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
return Collapse;
|
|
||||||
})();
|
|
||||||
|
|
||||||
$(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE, function (event) {
|
|
||||||
event.preventDefault();
|
|
||||||
|
|
||||||
var target = Collapse._getTargetFromElement(this);
|
|
||||||
var data = $(target).data(DATA_KEY);
|
|
||||||
var config = data ? 'toggle' : $(this).data();
|
|
||||||
|
|
||||||
Collapse._jQueryInterface.call($(target), config);
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* jQuery
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
$.fn[NAME] = Collapse._jQueryInterface;
|
|
||||||
$.fn[NAME].Constructor = Collapse;
|
|
||||||
$.fn[NAME].noConflict = function () {
|
|
||||||
$.fn[NAME] = JQUERY_NO_CONFLICT;
|
|
||||||
return Collapse._jQueryInterface;
|
|
||||||
};
|
|
||||||
|
|
||||||
return Collapse;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = Collapse;
|
|
||||||
});
|
|
312
dist/js/umd/dropdown.js
vendored
@ -1,312 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module', './util'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module, require('./util'));
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod, global.Util);
|
|
||||||
global.dropdown = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module, _util) {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
|
||||||
|
|
||||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
|
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
|
||||||
|
|
||||||
var _Util = _interopRequireDefault(_util);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): dropdown.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Dropdown = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Constants
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var NAME = 'dropdown';
|
|
||||||
var VERSION = '4.0.0-alpha.2';
|
|
||||||
var DATA_KEY = 'bs.dropdown';
|
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
|
||||||
var DATA_API_KEY = '.data-api';
|
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
|
||||||
|
|
||||||
var Event = {
|
|
||||||
HIDE: 'hide' + EVENT_KEY,
|
|
||||||
HIDDEN: 'hidden' + EVENT_KEY,
|
|
||||||
SHOW: 'show' + EVENT_KEY,
|
|
||||||
SHOWN: 'shown' + EVENT_KEY,
|
|
||||||
CLICK: 'click' + EVENT_KEY,
|
|
||||||
CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY,
|
|
||||||
KEYDOWN_DATA_API: 'keydown' + EVENT_KEY + DATA_API_KEY
|
|
||||||
};
|
|
||||||
|
|
||||||
var ClassName = {
|
|
||||||
BACKDROP: 'dropdown-backdrop',
|
|
||||||
DISABLED: 'disabled',
|
|
||||||
OPEN: 'open'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Selector = {
|
|
||||||
BACKDROP: '.dropdown-backdrop',
|
|
||||||
DATA_TOGGLE: '[data-toggle="dropdown"]',
|
|
||||||
FORM_CHILD: '.dropdown form',
|
|
||||||
ROLE_MENU: '[role="menu"]',
|
|
||||||
ROLE_LISTBOX: '[role="listbox"]',
|
|
||||||
NAVBAR_NAV: '.navbar-nav',
|
|
||||||
VISIBLE_ITEMS: '[role="menu"] li:not(.disabled) a, ' + '[role="listbox"] li:not(.disabled) a'
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Class Definition
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Dropdown = (function () {
|
|
||||||
function Dropdown(element) {
|
|
||||||
_classCallCheck(this, Dropdown);
|
|
||||||
|
|
||||||
this._element = element;
|
|
||||||
|
|
||||||
this._addEventListeners();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Data Api implementation
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
// getters
|
|
||||||
|
|
||||||
_createClass(Dropdown, [{
|
|
||||||
key: 'toggle',
|
|
||||||
|
|
||||||
// public
|
|
||||||
|
|
||||||
value: function toggle() {
|
|
||||||
if (this.disabled || $(this).hasClass(ClassName.DISABLED)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
var parent = Dropdown._getParentFromElement(this);
|
|
||||||
var isActive = $(parent).hasClass(ClassName.OPEN);
|
|
||||||
|
|
||||||
Dropdown._clearMenus();
|
|
||||||
|
|
||||||
if (isActive) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ('ontouchstart' in document.documentElement && !$(parent).closest(Selector.NAVBAR_NAV).length) {
|
|
||||||
|
|
||||||
// if mobile we use a backdrop because click events don't delegate
|
|
||||||
var dropdown = document.createElement('div');
|
|
||||||
dropdown.className = ClassName.BACKDROP;
|
|
||||||
$(dropdown).insertBefore(this);
|
|
||||||
$(dropdown).on('click', Dropdown._clearMenus);
|
|
||||||
}
|
|
||||||
|
|
||||||
var relatedTarget = { relatedTarget: this };
|
|
||||||
var showEvent = $.Event(Event.SHOW, relatedTarget);
|
|
||||||
|
|
||||||
$(parent).trigger(showEvent);
|
|
||||||
|
|
||||||
if (showEvent.isDefaultPrevented()) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
this.focus();
|
|
||||||
this.setAttribute('aria-expanded', 'true');
|
|
||||||
|
|
||||||
$(parent).toggleClass(ClassName.OPEN);
|
|
||||||
$(parent).trigger($.Event(Event.SHOWN, relatedTarget));
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'dispose',
|
|
||||||
value: function dispose() {
|
|
||||||
$.removeData(this._element, DATA_KEY);
|
|
||||||
$(this._element).off(EVENT_KEY);
|
|
||||||
this._element = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// private
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: '_addEventListeners',
|
|
||||||
value: function _addEventListeners() {
|
|
||||||
$(this._element).on(Event.CLICK, this.toggle);
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
|
|
||||||
}], [{
|
|
||||||
key: '_jQueryInterface',
|
|
||||||
value: function _jQueryInterface(config) {
|
|
||||||
return this.each(function () {
|
|
||||||
var data = $(this).data(DATA_KEY);
|
|
||||||
|
|
||||||
if (!data) {
|
|
||||||
$(this).data(DATA_KEY, data = new Dropdown(this));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (typeof config === 'string') {
|
|
||||||
if (data[config] === undefined) {
|
|
||||||
throw new Error('No method named "' + config + '"');
|
|
||||||
}
|
|
||||||
data[config].call(this);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_clearMenus',
|
|
||||||
value: function _clearMenus(event) {
|
|
||||||
if (event && event.which === 3) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var backdrop = $(Selector.BACKDROP)[0];
|
|
||||||
if (backdrop) {
|
|
||||||
backdrop.parentNode.removeChild(backdrop);
|
|
||||||
}
|
|
||||||
|
|
||||||
var toggles = $.makeArray($(Selector.DATA_TOGGLE));
|
|
||||||
|
|
||||||
for (var i = 0; i < toggles.length; i++) {
|
|
||||||
var _parent = Dropdown._getParentFromElement(toggles[i]);
|
|
||||||
var relatedTarget = { relatedTarget: toggles[i] };
|
|
||||||
|
|
||||||
if (!$(_parent).hasClass(ClassName.OPEN)) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (event && event.type === 'click' && /input|textarea/i.test(event.target.tagName) && $.contains(_parent, event.target)) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
var hideEvent = $.Event(Event.HIDE, relatedTarget);
|
|
||||||
$(_parent).trigger(hideEvent);
|
|
||||||
if (hideEvent.isDefaultPrevented()) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
toggles[i].setAttribute('aria-expanded', 'false');
|
|
||||||
|
|
||||||
$(_parent).removeClass(ClassName.OPEN).trigger($.Event(Event.HIDDEN, relatedTarget));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_getParentFromElement',
|
|
||||||
value: function _getParentFromElement(element) {
|
|
||||||
var parent = undefined;
|
|
||||||
var selector = _Util['default'].getSelectorFromElement(element);
|
|
||||||
|
|
||||||
if (selector) {
|
|
||||||
parent = $(selector)[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent || element.parentNode;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_dataApiKeydownHandler',
|
|
||||||
value: function _dataApiKeydownHandler(event) {
|
|
||||||
if (!/(38|40|27|32)/.test(event.which) || /input|textarea/i.test(event.target.tagName)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
|
|
||||||
if (this.disabled || $(this).hasClass(ClassName.DISABLED)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var parent = Dropdown._getParentFromElement(this);
|
|
||||||
var isActive = $(parent).hasClass(ClassName.OPEN);
|
|
||||||
|
|
||||||
if (!isActive && event.which !== 27 || isActive && event.which === 27) {
|
|
||||||
|
|
||||||
if (event.which === 27) {
|
|
||||||
var toggle = $(parent).find(Selector.DATA_TOGGLE)[0];
|
|
||||||
$(toggle).trigger('focus');
|
|
||||||
}
|
|
||||||
|
|
||||||
$(this).trigger('click');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var items = $.makeArray($(Selector.VISIBLE_ITEMS));
|
|
||||||
|
|
||||||
items = items.filter(function (item) {
|
|
||||||
return item.offsetWidth || item.offsetHeight;
|
|
||||||
});
|
|
||||||
|
|
||||||
if (!items.length) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var index = items.indexOf(event.target);
|
|
||||||
|
|
||||||
if (event.which === 38 && index > 0) {
|
|
||||||
// up
|
|
||||||
index--;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (event.which === 40 && index < items.length - 1) {
|
|
||||||
// down
|
|
||||||
index++;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (index < 0) {
|
|
||||||
index = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
items[index].focus();
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'VERSION',
|
|
||||||
get: function get() {
|
|
||||||
return VERSION;
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
return Dropdown;
|
|
||||||
})();
|
|
||||||
|
|
||||||
$(document).on(Event.KEYDOWN_DATA_API, Selector.DATA_TOGGLE, Dropdown._dataApiKeydownHandler).on(Event.KEYDOWN_DATA_API, Selector.ROLE_MENU, Dropdown._dataApiKeydownHandler).on(Event.KEYDOWN_DATA_API, Selector.ROLE_LISTBOX, Dropdown._dataApiKeydownHandler).on(Event.CLICK_DATA_API, Dropdown._clearMenus).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE, Dropdown.prototype.toggle).on(Event.CLICK_DATA_API, Selector.FORM_CHILD, function (e) {
|
|
||||||
e.stopPropagation();
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* jQuery
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
$.fn[NAME] = Dropdown._jQueryInterface;
|
|
||||||
$.fn[NAME].Constructor = Dropdown;
|
|
||||||
$.fn[NAME].noConflict = function () {
|
|
||||||
$.fn[NAME] = JQUERY_NO_CONFLICT;
|
|
||||||
return Dropdown._jQueryInterface;
|
|
||||||
};
|
|
||||||
|
|
||||||
return Dropdown;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = Dropdown;
|
|
||||||
});
|
|
549
dist/js/umd/modal.js
vendored
@ -1,549 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module', './util'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module, require('./util'));
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod, global.Util);
|
|
||||||
global.modal = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module, _util) {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
|
||||||
|
|
||||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
|
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
|
||||||
|
|
||||||
var _Util = _interopRequireDefault(_util);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): modal.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Modal = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Constants
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var NAME = 'modal';
|
|
||||||
var VERSION = '4.0.0-alpha.2';
|
|
||||||
var DATA_KEY = 'bs.modal';
|
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
|
||||||
var DATA_API_KEY = '.data-api';
|
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
|
||||||
var TRANSITION_DURATION = 300;
|
|
||||||
var BACKDROP_TRANSITION_DURATION = 150;
|
|
||||||
|
|
||||||
var Default = {
|
|
||||||
backdrop: true,
|
|
||||||
keyboard: true,
|
|
||||||
focus: true,
|
|
||||||
show: true
|
|
||||||
};
|
|
||||||
|
|
||||||
var DefaultType = {
|
|
||||||
backdrop: '(boolean|string)',
|
|
||||||
keyboard: 'boolean',
|
|
||||||
focus: 'boolean',
|
|
||||||
show: 'boolean'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Event = {
|
|
||||||
HIDE: 'hide' + EVENT_KEY,
|
|
||||||
HIDDEN: 'hidden' + EVENT_KEY,
|
|
||||||
SHOW: 'show' + EVENT_KEY,
|
|
||||||
SHOWN: 'shown' + EVENT_KEY,
|
|
||||||
FOCUSIN: 'focusin' + EVENT_KEY,
|
|
||||||
RESIZE: 'resize' + EVENT_KEY,
|
|
||||||
CLICK_DISMISS: 'click.dismiss' + EVENT_KEY,
|
|
||||||
KEYDOWN_DISMISS: 'keydown.dismiss' + EVENT_KEY,
|
|
||||||
MOUSEUP_DISMISS: 'mouseup.dismiss' + EVENT_KEY,
|
|
||||||
MOUSEDOWN_DISMISS: 'mousedown.dismiss' + EVENT_KEY,
|
|
||||||
CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY
|
|
||||||
};
|
|
||||||
|
|
||||||
var ClassName = {
|
|
||||||
SCROLLBAR_MEASURER: 'modal-scrollbar-measure',
|
|
||||||
BACKDROP: 'modal-backdrop',
|
|
||||||
OPEN: 'modal-open',
|
|
||||||
FADE: 'fade',
|
|
||||||
IN: 'in'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Selector = {
|
|
||||||
DIALOG: '.modal-dialog',
|
|
||||||
DATA_TOGGLE: '[data-toggle="modal"]',
|
|
||||||
DATA_DISMISS: '[data-dismiss="modal"]',
|
|
||||||
FIXED_CONTENT: '.navbar-fixed-top, .navbar-fixed-bottom, .is-fixed'
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Class Definition
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Modal = (function () {
|
|
||||||
function Modal(element, config) {
|
|
||||||
_classCallCheck(this, Modal);
|
|
||||||
|
|
||||||
this._config = this._getConfig(config);
|
|
||||||
this._element = element;
|
|
||||||
this._dialog = $(element).find(Selector.DIALOG)[0];
|
|
||||||
this._backdrop = null;
|
|
||||||
this._isShown = false;
|
|
||||||
this._isBodyOverflowing = false;
|
|
||||||
this._ignoreBackdropClick = false;
|
|
||||||
this._originalBodyPadding = 0;
|
|
||||||
this._scrollbarWidth = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Data Api implementation
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
// getters
|
|
||||||
|
|
||||||
_createClass(Modal, [{
|
|
||||||
key: 'toggle',
|
|
||||||
|
|
||||||
// public
|
|
||||||
|
|
||||||
value: function toggle(relatedTarget) {
|
|
||||||
return this._isShown ? this.hide() : this.show(relatedTarget);
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'show',
|
|
||||||
value: function show(relatedTarget) {
|
|
||||||
var _this = this;
|
|
||||||
|
|
||||||
var showEvent = $.Event(Event.SHOW, {
|
|
||||||
relatedTarget: relatedTarget
|
|
||||||
});
|
|
||||||
|
|
||||||
$(this._element).trigger(showEvent);
|
|
||||||
|
|
||||||
if (this._isShown || showEvent.isDefaultPrevented()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._isShown = true;
|
|
||||||
|
|
||||||
this._checkScrollbar();
|
|
||||||
this._setScrollbar();
|
|
||||||
|
|
||||||
$(document.body).addClass(ClassName.OPEN);
|
|
||||||
|
|
||||||
this._setEscapeEvent();
|
|
||||||
this._setResizeEvent();
|
|
||||||
|
|
||||||
$(this._element).on(Event.CLICK_DISMISS, Selector.DATA_DISMISS, $.proxy(this.hide, this));
|
|
||||||
|
|
||||||
$(this._dialog).on(Event.MOUSEDOWN_DISMISS, function () {
|
|
||||||
$(_this._element).one(Event.MOUSEUP_DISMISS, function (event) {
|
|
||||||
if ($(event.target).is(_this._element)) {
|
|
||||||
_this._ignoreBackdropClick = true;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
this._showBackdrop($.proxy(this._showElement, this, relatedTarget));
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'hide',
|
|
||||||
value: function hide(event) {
|
|
||||||
if (event) {
|
|
||||||
event.preventDefault();
|
|
||||||
}
|
|
||||||
|
|
||||||
var hideEvent = $.Event(Event.HIDE);
|
|
||||||
|
|
||||||
$(this._element).trigger(hideEvent);
|
|
||||||
|
|
||||||
if (!this._isShown || hideEvent.isDefaultPrevented()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._isShown = false;
|
|
||||||
|
|
||||||
this._setEscapeEvent();
|
|
||||||
this._setResizeEvent();
|
|
||||||
|
|
||||||
$(document).off(Event.FOCUSIN);
|
|
||||||
|
|
||||||
$(this._element).removeClass(ClassName.IN);
|
|
||||||
|
|
||||||
$(this._element).off(Event.CLICK_DISMISS);
|
|
||||||
$(this._dialog).off(Event.MOUSEDOWN_DISMISS);
|
|
||||||
|
|
||||||
if (_Util['default'].supportsTransitionEnd() && $(this._element).hasClass(ClassName.FADE)) {
|
|
||||||
|
|
||||||
$(this._element).one(_Util['default'].TRANSITION_END, $.proxy(this._hideModal, this)).emulateTransitionEnd(TRANSITION_DURATION);
|
|
||||||
} else {
|
|
||||||
this._hideModal();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'dispose',
|
|
||||||
value: function dispose() {
|
|
||||||
$.removeData(this._element, DATA_KEY);
|
|
||||||
|
|
||||||
$(window).off(EVENT_KEY);
|
|
||||||
$(document).off(EVENT_KEY);
|
|
||||||
$(this._element).off(EVENT_KEY);
|
|
||||||
$(this._backdrop).off(EVENT_KEY);
|
|
||||||
|
|
||||||
this._config = null;
|
|
||||||
this._element = null;
|
|
||||||
this._dialog = null;
|
|
||||||
this._backdrop = null;
|
|
||||||
this._isShown = null;
|
|
||||||
this._isBodyOverflowing = null;
|
|
||||||
this._ignoreBackdropClick = null;
|
|
||||||
this._originalBodyPadding = null;
|
|
||||||
this._scrollbarWidth = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// private
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: '_getConfig',
|
|
||||||
value: function _getConfig(config) {
|
|
||||||
config = $.extend({}, Default, config);
|
|
||||||
_Util['default'].typeCheckConfig(NAME, config, DefaultType);
|
|
||||||
return config;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_showElement',
|
|
||||||
value: function _showElement(relatedTarget) {
|
|
||||||
var _this2 = this;
|
|
||||||
|
|
||||||
var transition = _Util['default'].supportsTransitionEnd() && $(this._element).hasClass(ClassName.FADE);
|
|
||||||
|
|
||||||
if (!this._element.parentNode || this._element.parentNode.nodeType !== Node.ELEMENT_NODE) {
|
|
||||||
// don't move modals dom position
|
|
||||||
document.body.appendChild(this._element);
|
|
||||||
}
|
|
||||||
|
|
||||||
this._element.style.display = 'block';
|
|
||||||
this._element.scrollTop = 0;
|
|
||||||
|
|
||||||
if (transition) {
|
|
||||||
_Util['default'].reflow(this._element);
|
|
||||||
}
|
|
||||||
|
|
||||||
$(this._element).addClass(ClassName.IN);
|
|
||||||
|
|
||||||
if (this._config.focus) {
|
|
||||||
this._enforceFocus();
|
|
||||||
}
|
|
||||||
|
|
||||||
var shownEvent = $.Event(Event.SHOWN, {
|
|
||||||
relatedTarget: relatedTarget
|
|
||||||
});
|
|
||||||
|
|
||||||
var transitionComplete = function transitionComplete() {
|
|
||||||
if (_this2._config.focus) {
|
|
||||||
_this2._element.focus();
|
|
||||||
}
|
|
||||||
$(_this2._element).trigger(shownEvent);
|
|
||||||
};
|
|
||||||
|
|
||||||
if (transition) {
|
|
||||||
$(this._dialog).one(_Util['default'].TRANSITION_END, transitionComplete).emulateTransitionEnd(TRANSITION_DURATION);
|
|
||||||
} else {
|
|
||||||
transitionComplete();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_enforceFocus',
|
|
||||||
value: function _enforceFocus() {
|
|
||||||
var _this3 = this;
|
|
||||||
|
|
||||||
$(document).off(Event.FOCUSIN) // guard against infinite focus loop
|
|
||||||
.on(Event.FOCUSIN, function (event) {
|
|
||||||
if (document !== event.target && _this3._element !== event.target && !$(_this3._element).has(event.target).length) {
|
|
||||||
_this3._element.focus();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_setEscapeEvent',
|
|
||||||
value: function _setEscapeEvent() {
|
|
||||||
var _this4 = this;
|
|
||||||
|
|
||||||
if (this._isShown && this._config.keyboard) {
|
|
||||||
$(this._element).on(Event.KEYDOWN_DISMISS, function (event) {
|
|
||||||
if (event.which === 27) {
|
|
||||||
_this4.hide();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else if (!this._isShown) {
|
|
||||||
$(this._element).off(Event.KEYDOWN_DISMISS);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_setResizeEvent',
|
|
||||||
value: function _setResizeEvent() {
|
|
||||||
if (this._isShown) {
|
|
||||||
$(window).on(Event.RESIZE, $.proxy(this._handleUpdate, this));
|
|
||||||
} else {
|
|
||||||
$(window).off(Event.RESIZE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_hideModal',
|
|
||||||
value: function _hideModal() {
|
|
||||||
var _this5 = this;
|
|
||||||
|
|
||||||
this._element.style.display = 'none';
|
|
||||||
this._showBackdrop(function () {
|
|
||||||
$(document.body).removeClass(ClassName.OPEN);
|
|
||||||
_this5._resetAdjustments();
|
|
||||||
_this5._resetScrollbar();
|
|
||||||
$(_this5._element).trigger(Event.HIDDEN);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_removeBackdrop',
|
|
||||||
value: function _removeBackdrop() {
|
|
||||||
if (this._backdrop) {
|
|
||||||
$(this._backdrop).remove();
|
|
||||||
this._backdrop = null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_showBackdrop',
|
|
||||||
value: function _showBackdrop(callback) {
|
|
||||||
var _this6 = this;
|
|
||||||
|
|
||||||
var animate = $(this._element).hasClass(ClassName.FADE) ? ClassName.FADE : '';
|
|
||||||
|
|
||||||
if (this._isShown && this._config.backdrop) {
|
|
||||||
var doAnimate = _Util['default'].supportsTransitionEnd() && animate;
|
|
||||||
|
|
||||||
this._backdrop = document.createElement('div');
|
|
||||||
this._backdrop.className = ClassName.BACKDROP;
|
|
||||||
|
|
||||||
if (animate) {
|
|
||||||
$(this._backdrop).addClass(animate);
|
|
||||||
}
|
|
||||||
|
|
||||||
$(this._backdrop).appendTo(document.body);
|
|
||||||
|
|
||||||
$(this._element).on(Event.CLICK_DISMISS, function (event) {
|
|
||||||
if (_this6._ignoreBackdropClick) {
|
|
||||||
_this6._ignoreBackdropClick = false;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (event.target !== event.currentTarget) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (_this6._config.backdrop === 'static') {
|
|
||||||
_this6._element.focus();
|
|
||||||
} else {
|
|
||||||
_this6.hide();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
if (doAnimate) {
|
|
||||||
_Util['default'].reflow(this._backdrop);
|
|
||||||
}
|
|
||||||
|
|
||||||
$(this._backdrop).addClass(ClassName.IN);
|
|
||||||
|
|
||||||
if (!callback) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!doAnimate) {
|
|
||||||
callback();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$(this._backdrop).one(_Util['default'].TRANSITION_END, callback).emulateTransitionEnd(BACKDROP_TRANSITION_DURATION);
|
|
||||||
} else if (!this._isShown && this._backdrop) {
|
|
||||||
$(this._backdrop).removeClass(ClassName.IN);
|
|
||||||
|
|
||||||
var callbackRemove = function callbackRemove() {
|
|
||||||
_this6._removeBackdrop();
|
|
||||||
if (callback) {
|
|
||||||
callback();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
if (_Util['default'].supportsTransitionEnd() && $(this._element).hasClass(ClassName.FADE)) {
|
|
||||||
$(this._backdrop).one(_Util['default'].TRANSITION_END, callbackRemove).emulateTransitionEnd(BACKDROP_TRANSITION_DURATION);
|
|
||||||
} else {
|
|
||||||
callbackRemove();
|
|
||||||
}
|
|
||||||
} else if (callback) {
|
|
||||||
callback();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------
|
|
||||||
// the following methods are used to handle overflowing modals
|
|
||||||
// todo (fat): these should probably be refactored out of modal.js
|
|
||||||
// ----------------------------------------------------------------------
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: '_handleUpdate',
|
|
||||||
value: function _handleUpdate() {
|
|
||||||
this._adjustDialog();
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_adjustDialog',
|
|
||||||
value: function _adjustDialog() {
|
|
||||||
var isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight;
|
|
||||||
|
|
||||||
if (!this._isBodyOverflowing && isModalOverflowing) {
|
|
||||||
this._element.style.paddingLeft = this._scrollbarWidth + 'px';
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._isBodyOverflowing && !isModalOverflowing) {
|
|
||||||
this._element.style.paddingRight = this._scrollbarWidth + 'px~';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_resetAdjustments',
|
|
||||||
value: function _resetAdjustments() {
|
|
||||||
this._element.style.paddingLeft = '';
|
|
||||||
this._element.style.paddingRight = '';
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_checkScrollbar',
|
|
||||||
value: function _checkScrollbar() {
|
|
||||||
this._isBodyOverflowing = document.body.clientWidth < window.innerWidth;
|
|
||||||
this._scrollbarWidth = this._getScrollbarWidth();
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_setScrollbar',
|
|
||||||
value: function _setScrollbar() {
|
|
||||||
var bodyPadding = parseInt($(Selector.FIXED_CONTENT).css('padding-right') || 0, 10);
|
|
||||||
|
|
||||||
this._originalBodyPadding = document.body.style.paddingRight || '';
|
|
||||||
|
|
||||||
if (this._isBodyOverflowing) {
|
|
||||||
document.body.style.paddingRight = bodyPadding + this._scrollbarWidth + 'px';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_resetScrollbar',
|
|
||||||
value: function _resetScrollbar() {
|
|
||||||
document.body.style.paddingRight = this._originalBodyPadding;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_getScrollbarWidth',
|
|
||||||
value: function _getScrollbarWidth() {
|
|
||||||
// thx d.walsh
|
|
||||||
var scrollDiv = document.createElement('div');
|
|
||||||
scrollDiv.className = ClassName.SCROLLBAR_MEASURER;
|
|
||||||
document.body.appendChild(scrollDiv);
|
|
||||||
var scrollbarWidth = scrollDiv.offsetWidth - scrollDiv.clientWidth;
|
|
||||||
document.body.removeChild(scrollDiv);
|
|
||||||
return scrollbarWidth;
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
|
|
||||||
}], [{
|
|
||||||
key: '_jQueryInterface',
|
|
||||||
value: function _jQueryInterface(config, relatedTarget) {
|
|
||||||
return this.each(function () {
|
|
||||||
var data = $(this).data(DATA_KEY);
|
|
||||||
var _config = $.extend({}, Modal.Default, $(this).data(), typeof config === 'object' && config);
|
|
||||||
|
|
||||||
if (!data) {
|
|
||||||
data = new Modal(this, _config);
|
|
||||||
$(this).data(DATA_KEY, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (typeof config === 'string') {
|
|
||||||
if (data[config] === undefined) {
|
|
||||||
throw new Error('No method named "' + config + '"');
|
|
||||||
}
|
|
||||||
data[config](relatedTarget);
|
|
||||||
} else if (_config.show) {
|
|
||||||
data.show(relatedTarget);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'VERSION',
|
|
||||||
get: function get() {
|
|
||||||
return VERSION;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'Default',
|
|
||||||
get: function get() {
|
|
||||||
return Default;
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
return Modal;
|
|
||||||
})();
|
|
||||||
|
|
||||||
$(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE, function (event) {
|
|
||||||
var _this7 = this;
|
|
||||||
|
|
||||||
var target = undefined;
|
|
||||||
var selector = _Util['default'].getSelectorFromElement(this);
|
|
||||||
|
|
||||||
if (selector) {
|
|
||||||
target = $(selector)[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
var config = $(target).data(DATA_KEY) ? 'toggle' : $.extend({}, $(target).data(), $(this).data());
|
|
||||||
|
|
||||||
if (this.tagName === 'A') {
|
|
||||||
event.preventDefault();
|
|
||||||
}
|
|
||||||
|
|
||||||
var $target = $(target).one(Event.SHOW, function (showEvent) {
|
|
||||||
if (showEvent.isDefaultPrevented()) {
|
|
||||||
// only register focus restorer if modal will actually get shown
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$target.one(Event.HIDDEN, function () {
|
|
||||||
if ($(_this7).is(':visible')) {
|
|
||||||
_this7.focus();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
Modal._jQueryInterface.call($(target), config, this);
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* jQuery
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
$.fn[NAME] = Modal._jQueryInterface;
|
|
||||||
$.fn[NAME].Constructor = Modal;
|
|
||||||
$.fn[NAME].noConflict = function () {
|
|
||||||
$.fn[NAME] = JQUERY_NO_CONFLICT;
|
|
||||||
return Modal._jQueryInterface;
|
|
||||||
};
|
|
||||||
|
|
||||||
return Modal;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = Modal;
|
|
||||||
});
|
|
220
dist/js/umd/popover.js
vendored
@ -1,220 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module', './tooltip'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module, require('./tooltip'));
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod, global.Tooltip);
|
|
||||||
global.popover = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module, _tooltip) {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
|
||||||
|
|
||||||
var _get = function get(_x, _x2, _x3) { var _again = true; _function: while (_again) { var object = _x, property = _x2, receiver = _x3; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x = parent; _x2 = property; _x3 = receiver; _again = true; desc = parent = undefined; continue _function; } } else if ('value' in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };
|
|
||||||
|
|
||||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
|
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
|
||||||
|
|
||||||
function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
|
|
||||||
|
|
||||||
var _Tooltip2 = _interopRequireDefault(_tooltip);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): popover.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Popover = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Constants
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var NAME = 'popover';
|
|
||||||
var VERSION = '4.0.0-alpha.2';
|
|
||||||
var DATA_KEY = 'bs.popover';
|
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
|
||||||
|
|
||||||
var Default = $.extend({}, _Tooltip2['default'].Default, {
|
|
||||||
placement: 'right',
|
|
||||||
trigger: 'click',
|
|
||||||
content: '',
|
|
||||||
template: '<div class="popover" role="tooltip">' + '<div class="popover-arrow"></div>' + '<h3 class="popover-title"></h3>' + '<div class="popover-content"></div></div>'
|
|
||||||
});
|
|
||||||
|
|
||||||
var DefaultType = $.extend({}, _Tooltip2['default'].DefaultType, {
|
|
||||||
content: '(string|element|function)'
|
|
||||||
});
|
|
||||||
|
|
||||||
var ClassName = {
|
|
||||||
FADE: 'fade',
|
|
||||||
IN: 'in'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Selector = {
|
|
||||||
TITLE: '.popover-title',
|
|
||||||
CONTENT: '.popover-content',
|
|
||||||
ARROW: '.popover-arrow'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Event = {
|
|
||||||
HIDE: 'hide' + EVENT_KEY,
|
|
||||||
HIDDEN: 'hidden' + EVENT_KEY,
|
|
||||||
SHOW: 'show' + EVENT_KEY,
|
|
||||||
SHOWN: 'shown' + EVENT_KEY,
|
|
||||||
INSERTED: 'inserted' + EVENT_KEY,
|
|
||||||
CLICK: 'click' + EVENT_KEY,
|
|
||||||
FOCUSIN: 'focusin' + EVENT_KEY,
|
|
||||||
FOCUSOUT: 'focusout' + EVENT_KEY,
|
|
||||||
MOUSEENTER: 'mouseenter' + EVENT_KEY,
|
|
||||||
MOUSELEAVE: 'mouseleave' + EVENT_KEY
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Class Definition
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Popover = (function (_Tooltip) {
|
|
||||||
_inherits(Popover, _Tooltip);
|
|
||||||
|
|
||||||
function Popover() {
|
|
||||||
_classCallCheck(this, Popover);
|
|
||||||
|
|
||||||
_get(Object.getPrototypeOf(Popover.prototype), 'constructor', this).apply(this, arguments);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* jQuery
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
_createClass(Popover, [{
|
|
||||||
key: 'isWithContent',
|
|
||||||
|
|
||||||
// overrides
|
|
||||||
|
|
||||||
value: function isWithContent() {
|
|
||||||
return this.getTitle() || this._getContent();
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'getTipElement',
|
|
||||||
value: function getTipElement() {
|
|
||||||
return this.tip = this.tip || $(this.config.template)[0];
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'setContent',
|
|
||||||
value: function setContent() {
|
|
||||||
var $tip = $(this.getTipElement());
|
|
||||||
|
|
||||||
// we use append for html objects to maintain js events
|
|
||||||
this.setElementContent($tip.find(Selector.TITLE), this.getTitle());
|
|
||||||
this.setElementContent($tip.find(Selector.CONTENT), this._getContent());
|
|
||||||
|
|
||||||
$tip.removeClass(ClassName.FADE).removeClass(ClassName.IN);
|
|
||||||
|
|
||||||
this.cleanupTether();
|
|
||||||
}
|
|
||||||
|
|
||||||
// private
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: '_getContent',
|
|
||||||
value: function _getContent() {
|
|
||||||
return this.element.getAttribute('data-content') || (typeof this.config.content === 'function' ? this.config.content.call(this.element) : this.config.content);
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
|
|
||||||
}], [{
|
|
||||||
key: '_jQueryInterface',
|
|
||||||
value: function _jQueryInterface(config) {
|
|
||||||
return this.each(function () {
|
|
||||||
var data = $(this).data(DATA_KEY);
|
|
||||||
var _config = typeof config === 'object' ? config : null;
|
|
||||||
|
|
||||||
if (!data && /destroy|hide/.test(config)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!data) {
|
|
||||||
data = new Popover(this, _config);
|
|
||||||
$(this).data(DATA_KEY, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (typeof config === 'string') {
|
|
||||||
if (data[config] === undefined) {
|
|
||||||
throw new Error('No method named "' + config + '"');
|
|
||||||
}
|
|
||||||
data[config]();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'VERSION',
|
|
||||||
|
|
||||||
// getters
|
|
||||||
|
|
||||||
get: function get() {
|
|
||||||
return VERSION;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'Default',
|
|
||||||
get: function get() {
|
|
||||||
return Default;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'NAME',
|
|
||||||
get: function get() {
|
|
||||||
return NAME;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'DATA_KEY',
|
|
||||||
get: function get() {
|
|
||||||
return DATA_KEY;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'Event',
|
|
||||||
get: function get() {
|
|
||||||
return Event;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'EVENT_KEY',
|
|
||||||
get: function get() {
|
|
||||||
return EVENT_KEY;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'DefaultType',
|
|
||||||
get: function get() {
|
|
||||||
return DefaultType;
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
return Popover;
|
|
||||||
})(_Tooltip2['default']);
|
|
||||||
|
|
||||||
$.fn[NAME] = Popover._jQueryInterface;
|
|
||||||
$.fn[NAME].Constructor = Popover;
|
|
||||||
$.fn[NAME].noConflict = function () {
|
|
||||||
$.fn[NAME] = JQUERY_NO_CONFLICT;
|
|
||||||
return Popover._jQueryInterface;
|
|
||||||
};
|
|
||||||
|
|
||||||
return Popover;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = Popover;
|
|
||||||
});
|
|
339
dist/js/umd/scrollspy.js
vendored
@ -1,339 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module', './util'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module, require('./util'));
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod, global.Util);
|
|
||||||
global.scrollspy = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module, _util) {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
|
||||||
|
|
||||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
|
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
|
||||||
|
|
||||||
var _Util = _interopRequireDefault(_util);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): scrollspy.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var ScrollSpy = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Constants
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var NAME = 'scrollspy';
|
|
||||||
var VERSION = '4.0.0-alpha.2';
|
|
||||||
var DATA_KEY = 'bs.scrollspy';
|
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
|
||||||
var DATA_API_KEY = '.data-api';
|
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
|
||||||
|
|
||||||
var Default = {
|
|
||||||
offset: 10,
|
|
||||||
method: 'auto',
|
|
||||||
target: ''
|
|
||||||
};
|
|
||||||
|
|
||||||
var DefaultType = {
|
|
||||||
offset: 'number',
|
|
||||||
method: 'string',
|
|
||||||
target: '(string|element)'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Event = {
|
|
||||||
ACTIVATE: 'activate' + EVENT_KEY,
|
|
||||||
SCROLL: 'scroll' + EVENT_KEY,
|
|
||||||
LOAD_DATA_API: 'load' + EVENT_KEY + DATA_API_KEY
|
|
||||||
};
|
|
||||||
|
|
||||||
var ClassName = {
|
|
||||||
DROPDOWN_ITEM: 'dropdown-item',
|
|
||||||
DROPDOWN_MENU: 'dropdown-menu',
|
|
||||||
NAV_LINK: 'nav-link',
|
|
||||||
NAV: 'nav',
|
|
||||||
ACTIVE: 'active'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Selector = {
|
|
||||||
DATA_SPY: '[data-spy="scroll"]',
|
|
||||||
ACTIVE: '.active',
|
|
||||||
LIST_ITEM: '.list-item',
|
|
||||||
LI: 'li',
|
|
||||||
LI_DROPDOWN: 'li.dropdown',
|
|
||||||
NAV_LINKS: '.nav-link',
|
|
||||||
DROPDOWN: '.dropdown',
|
|
||||||
DROPDOWN_ITEMS: '.dropdown-item',
|
|
||||||
DROPDOWN_TOGGLE: '.dropdown-toggle'
|
|
||||||
};
|
|
||||||
|
|
||||||
var OffsetMethod = {
|
|
||||||
OFFSET: 'offset',
|
|
||||||
POSITION: 'position'
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Class Definition
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var ScrollSpy = (function () {
|
|
||||||
function ScrollSpy(element, config) {
|
|
||||||
_classCallCheck(this, ScrollSpy);
|
|
||||||
|
|
||||||
this._element = element;
|
|
||||||
this._scrollElement = element.tagName === 'BODY' ? window : element;
|
|
||||||
this._config = this._getConfig(config);
|
|
||||||
this._selector = this._config.target + ' ' + Selector.NAV_LINKS + ',' + (this._config.target + ' ' + Selector.DROPDOWN_ITEMS);
|
|
||||||
this._offsets = [];
|
|
||||||
this._targets = [];
|
|
||||||
this._activeTarget = null;
|
|
||||||
this._scrollHeight = 0;
|
|
||||||
|
|
||||||
$(this._scrollElement).on(Event.SCROLL, $.proxy(this._process, this));
|
|
||||||
|
|
||||||
this.refresh();
|
|
||||||
this._process();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Data Api implementation
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
// getters
|
|
||||||
|
|
||||||
_createClass(ScrollSpy, [{
|
|
||||||
key: 'refresh',
|
|
||||||
|
|
||||||
// public
|
|
||||||
|
|
||||||
value: function refresh() {
|
|
||||||
var _this = this;
|
|
||||||
|
|
||||||
var autoMethod = this._scrollElement !== this._scrollElement.window ? OffsetMethod.POSITION : OffsetMethod.OFFSET;
|
|
||||||
|
|
||||||
var offsetMethod = this._config.method === 'auto' ? autoMethod : this._config.method;
|
|
||||||
|
|
||||||
var offsetBase = offsetMethod === OffsetMethod.POSITION ? this._getScrollTop() : 0;
|
|
||||||
|
|
||||||
this._offsets = [];
|
|
||||||
this._targets = [];
|
|
||||||
|
|
||||||
this._scrollHeight = this._getScrollHeight();
|
|
||||||
|
|
||||||
var targets = $.makeArray($(this._selector));
|
|
||||||
|
|
||||||
targets.map(function (element) {
|
|
||||||
var target = undefined;
|
|
||||||
var targetSelector = _Util['default'].getSelectorFromElement(element);
|
|
||||||
|
|
||||||
if (targetSelector) {
|
|
||||||
target = $(targetSelector)[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (target && (target.offsetWidth || target.offsetHeight)) {
|
|
||||||
// todo (fat): remove sketch reliance on jQuery position/offset
|
|
||||||
return [$(target)[offsetMethod]().top + offsetBase, targetSelector];
|
|
||||||
}
|
|
||||||
}).filter(function (item) {
|
|
||||||
return item;
|
|
||||||
}).sort(function (a, b) {
|
|
||||||
return a[0] - b[0];
|
|
||||||
}).forEach(function (item) {
|
|
||||||
_this._offsets.push(item[0]);
|
|
||||||
_this._targets.push(item[1]);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'dispose',
|
|
||||||
value: function dispose() {
|
|
||||||
$.removeData(this._element, DATA_KEY);
|
|
||||||
$(this._scrollElement).off(EVENT_KEY);
|
|
||||||
|
|
||||||
this._element = null;
|
|
||||||
this._scrollElement = null;
|
|
||||||
this._config = null;
|
|
||||||
this._selector = null;
|
|
||||||
this._offsets = null;
|
|
||||||
this._targets = null;
|
|
||||||
this._activeTarget = null;
|
|
||||||
this._scrollHeight = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// private
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: '_getConfig',
|
|
||||||
value: function _getConfig(config) {
|
|
||||||
config = $.extend({}, Default, config);
|
|
||||||
|
|
||||||
if (typeof config.target !== 'string') {
|
|
||||||
var id = $(config.target).attr('id');
|
|
||||||
if (!id) {
|
|
||||||
id = _Util['default'].getUID(NAME);
|
|
||||||
$(config.target).attr('id', id);
|
|
||||||
}
|
|
||||||
config.target = '#' + id;
|
|
||||||
}
|
|
||||||
|
|
||||||
_Util['default'].typeCheckConfig(NAME, config, DefaultType);
|
|
||||||
|
|
||||||
return config;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_getScrollTop',
|
|
||||||
value: function _getScrollTop() {
|
|
||||||
return this._scrollElement === window ? this._scrollElement.scrollY : this._scrollElement.scrollTop;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_getScrollHeight',
|
|
||||||
value: function _getScrollHeight() {
|
|
||||||
return this._scrollElement.scrollHeight || Math.max(document.body.scrollHeight, document.documentElement.scrollHeight);
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_process',
|
|
||||||
value: function _process() {
|
|
||||||
var scrollTop = this._getScrollTop() + this._config.offset;
|
|
||||||
var scrollHeight = this._getScrollHeight();
|
|
||||||
var maxScroll = this._config.offset + scrollHeight - this._scrollElement.offsetHeight;
|
|
||||||
|
|
||||||
if (this._scrollHeight !== scrollHeight) {
|
|
||||||
this.refresh();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (scrollTop >= maxScroll) {
|
|
||||||
var target = this._targets[this._targets.length - 1];
|
|
||||||
|
|
||||||
if (this._activeTarget !== target) {
|
|
||||||
this._activate(target);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._activeTarget && scrollTop < this._offsets[0]) {
|
|
||||||
this._activeTarget = null;
|
|
||||||
this._clear();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (var i = this._offsets.length; i--;) {
|
|
||||||
var isActiveTarget = this._activeTarget !== this._targets[i] && scrollTop >= this._offsets[i] && (this._offsets[i + 1] === undefined || scrollTop < this._offsets[i + 1]);
|
|
||||||
|
|
||||||
if (isActiveTarget) {
|
|
||||||
this._activate(this._targets[i]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_activate',
|
|
||||||
value: function _activate(target) {
|
|
||||||
this._activeTarget = target;
|
|
||||||
|
|
||||||
this._clear();
|
|
||||||
|
|
||||||
var queries = this._selector.split(',');
|
|
||||||
queries = queries.map(function (selector) {
|
|
||||||
return selector + '[data-target="' + target + '"],' + (selector + '[href="' + target + '"]');
|
|
||||||
});
|
|
||||||
|
|
||||||
var $link = $(queries.join(','));
|
|
||||||
|
|
||||||
if ($link.hasClass(ClassName.DROPDOWN_ITEM)) {
|
|
||||||
$link.closest(Selector.DROPDOWN).find(Selector.DROPDOWN_TOGGLE).addClass(ClassName.ACTIVE);
|
|
||||||
$link.addClass(ClassName.ACTIVE);
|
|
||||||
} else {
|
|
||||||
// todo (fat) this is kinda sus...
|
|
||||||
// recursively add actives to tested nav-links
|
|
||||||
$link.parents(Selector.LI).find(Selector.NAV_LINKS).addClass(ClassName.ACTIVE);
|
|
||||||
}
|
|
||||||
|
|
||||||
$(this._scrollElement).trigger(Event.ACTIVATE, {
|
|
||||||
relatedTarget: target
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_clear',
|
|
||||||
value: function _clear() {
|
|
||||||
$(this._selector).filter(Selector.ACTIVE).removeClass(ClassName.ACTIVE);
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
|
|
||||||
}], [{
|
|
||||||
key: '_jQueryInterface',
|
|
||||||
value: function _jQueryInterface(config) {
|
|
||||||
return this.each(function () {
|
|
||||||
var data = $(this).data(DATA_KEY);
|
|
||||||
var _config = typeof config === 'object' && config || null;
|
|
||||||
|
|
||||||
if (!data) {
|
|
||||||
data = new ScrollSpy(this, _config);
|
|
||||||
$(this).data(DATA_KEY, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (typeof config === 'string') {
|
|
||||||
if (data[config] === undefined) {
|
|
||||||
throw new Error('No method named "' + config + '"');
|
|
||||||
}
|
|
||||||
data[config]();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'VERSION',
|
|
||||||
get: function get() {
|
|
||||||
return VERSION;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'Default',
|
|
||||||
get: function get() {
|
|
||||||
return Default;
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
return ScrollSpy;
|
|
||||||
})();
|
|
||||||
|
|
||||||
$(window).on(Event.LOAD_DATA_API, function () {
|
|
||||||
var scrollSpys = $.makeArray($(Selector.DATA_SPY));
|
|
||||||
|
|
||||||
for (var i = scrollSpys.length; i--;) {
|
|
||||||
var $spy = $(scrollSpys[i]);
|
|
||||||
ScrollSpy._jQueryInterface.call($spy, $spy.data());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* jQuery
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
$.fn[NAME] = ScrollSpy._jQueryInterface;
|
|
||||||
$.fn[NAME].Constructor = ScrollSpy;
|
|
||||||
$.fn[NAME].noConflict = function () {
|
|
||||||
$.fn[NAME] = JQUERY_NO_CONFLICT;
|
|
||||||
return ScrollSpy._jQueryInterface;
|
|
||||||
};
|
|
||||||
|
|
||||||
return ScrollSpy;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = ScrollSpy;
|
|
||||||
});
|
|
282
dist/js/umd/tab.js
vendored
@ -1,282 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module', './util'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module, require('./util'));
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod, global.Util);
|
|
||||||
global.tab = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module, _util) {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
|
||||||
|
|
||||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
|
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
|
||||||
|
|
||||||
var _Util = _interopRequireDefault(_util);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): tab.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Tab = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Constants
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var NAME = 'tab';
|
|
||||||
var VERSION = '4.0.0-alpha.2';
|
|
||||||
var DATA_KEY = 'bs.tab';
|
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
|
||||||
var DATA_API_KEY = '.data-api';
|
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
|
||||||
var TRANSITION_DURATION = 150;
|
|
||||||
|
|
||||||
var Event = {
|
|
||||||
HIDE: 'hide' + EVENT_KEY,
|
|
||||||
HIDDEN: 'hidden' + EVENT_KEY,
|
|
||||||
SHOW: 'show' + EVENT_KEY,
|
|
||||||
SHOWN: 'shown' + EVENT_KEY,
|
|
||||||
CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY
|
|
||||||
};
|
|
||||||
|
|
||||||
var ClassName = {
|
|
||||||
DROPDOWN_MENU: 'dropdown-menu',
|
|
||||||
ACTIVE: 'active',
|
|
||||||
FADE: 'fade',
|
|
||||||
IN: 'in'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Selector = {
|
|
||||||
A: 'a',
|
|
||||||
LI: 'li',
|
|
||||||
DROPDOWN: '.dropdown',
|
|
||||||
UL: 'ul:not(.dropdown-menu)',
|
|
||||||
FADE_CHILD: '> .nav-item .fade, > .fade',
|
|
||||||
ACTIVE: '.active',
|
|
||||||
ACTIVE_CHILD: '> .nav-item > .active, > .active',
|
|
||||||
DATA_TOGGLE: '[data-toggle="tab"], [data-toggle="pill"]',
|
|
||||||
DROPDOWN_TOGGLE: '.dropdown-toggle',
|
|
||||||
DROPDOWN_ACTIVE_CHILD: '> .dropdown-menu .active'
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Class Definition
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Tab = (function () {
|
|
||||||
function Tab(element) {
|
|
||||||
_classCallCheck(this, Tab);
|
|
||||||
|
|
||||||
this._element = element;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Data Api implementation
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
// getters
|
|
||||||
|
|
||||||
_createClass(Tab, [{
|
|
||||||
key: 'show',
|
|
||||||
|
|
||||||
// public
|
|
||||||
|
|
||||||
value: function show() {
|
|
||||||
var _this = this;
|
|
||||||
|
|
||||||
if (this._element.parentNode && this._element.parentNode.nodeType === Node.ELEMENT_NODE && $(this._element).hasClass(ClassName.ACTIVE)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var target = undefined;
|
|
||||||
var previous = undefined;
|
|
||||||
var ulElement = $(this._element).closest(Selector.UL)[0];
|
|
||||||
var selector = _Util['default'].getSelectorFromElement(this._element);
|
|
||||||
|
|
||||||
if (ulElement) {
|
|
||||||
previous = $.makeArray($(ulElement).find(Selector.ACTIVE));
|
|
||||||
previous = previous[previous.length - 1];
|
|
||||||
}
|
|
||||||
|
|
||||||
var hideEvent = $.Event(Event.HIDE, {
|
|
||||||
relatedTarget: this._element
|
|
||||||
});
|
|
||||||
|
|
||||||
var showEvent = $.Event(Event.SHOW, {
|
|
||||||
relatedTarget: previous
|
|
||||||
});
|
|
||||||
|
|
||||||
if (previous) {
|
|
||||||
$(previous).trigger(hideEvent);
|
|
||||||
}
|
|
||||||
|
|
||||||
$(this._element).trigger(showEvent);
|
|
||||||
|
|
||||||
if (showEvent.isDefaultPrevented() || hideEvent.isDefaultPrevented()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (selector) {
|
|
||||||
target = $(selector)[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
this._activate(this._element, ulElement);
|
|
||||||
|
|
||||||
var complete = function complete() {
|
|
||||||
var hiddenEvent = $.Event(Event.HIDDEN, {
|
|
||||||
relatedTarget: _this._element
|
|
||||||
});
|
|
||||||
|
|
||||||
var shownEvent = $.Event(Event.SHOWN, {
|
|
||||||
relatedTarget: previous
|
|
||||||
});
|
|
||||||
|
|
||||||
$(previous).trigger(hiddenEvent);
|
|
||||||
$(_this._element).trigger(shownEvent);
|
|
||||||
};
|
|
||||||
|
|
||||||
if (target) {
|
|
||||||
this._activate(target, target.parentNode, complete);
|
|
||||||
} else {
|
|
||||||
complete();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'dispose',
|
|
||||||
value: function dispose() {
|
|
||||||
$.removeClass(this._element, DATA_KEY);
|
|
||||||
this._element = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// private
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: '_activate',
|
|
||||||
value: function _activate(element, container, callback) {
|
|
||||||
var active = $(container).find(Selector.ACTIVE_CHILD)[0];
|
|
||||||
var isTransitioning = callback && _Util['default'].supportsTransitionEnd() && (active && $(active).hasClass(ClassName.FADE) || Boolean($(container).find(Selector.FADE_CHILD)[0]));
|
|
||||||
|
|
||||||
var complete = $.proxy(this._transitionComplete, this, element, active, isTransitioning, callback);
|
|
||||||
|
|
||||||
if (active && isTransitioning) {
|
|
||||||
$(active).one(_Util['default'].TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION);
|
|
||||||
} else {
|
|
||||||
complete();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (active) {
|
|
||||||
$(active).removeClass(ClassName.IN);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_transitionComplete',
|
|
||||||
value: function _transitionComplete(element, active, isTransitioning, callback) {
|
|
||||||
if (active) {
|
|
||||||
$(active).removeClass(ClassName.ACTIVE);
|
|
||||||
|
|
||||||
var dropdownChild = $(active).find(Selector.DROPDOWN_ACTIVE_CHILD)[0];
|
|
||||||
|
|
||||||
if (dropdownChild) {
|
|
||||||
$(dropdownChild).removeClass(ClassName.ACTIVE);
|
|
||||||
}
|
|
||||||
|
|
||||||
active.setAttribute('aria-expanded', false);
|
|
||||||
}
|
|
||||||
|
|
||||||
$(element).addClass(ClassName.ACTIVE);
|
|
||||||
element.setAttribute('aria-expanded', true);
|
|
||||||
|
|
||||||
if (isTransitioning) {
|
|
||||||
_Util['default'].reflow(element);
|
|
||||||
$(element).addClass(ClassName.IN);
|
|
||||||
} else {
|
|
||||||
$(element).removeClass(ClassName.FADE);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (element.parentNode && $(element.parentNode).hasClass(ClassName.DROPDOWN_MENU)) {
|
|
||||||
|
|
||||||
var dropdownElement = $(element).closest(Selector.DROPDOWN)[0];
|
|
||||||
if (dropdownElement) {
|
|
||||||
$(dropdownElement).find(Selector.DROPDOWN_TOGGLE).addClass(ClassName.ACTIVE);
|
|
||||||
}
|
|
||||||
|
|
||||||
element.setAttribute('aria-expanded', true);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (callback) {
|
|
||||||
callback();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
|
|
||||||
}], [{
|
|
||||||
key: '_jQueryInterface',
|
|
||||||
value: function _jQueryInterface(config) {
|
|
||||||
return this.each(function () {
|
|
||||||
var $this = $(this);
|
|
||||||
var data = $this.data(DATA_KEY);
|
|
||||||
|
|
||||||
if (!data) {
|
|
||||||
data = data = new Tab(this);
|
|
||||||
$this.data(DATA_KEY, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (typeof config === 'string') {
|
|
||||||
if (data[config] === undefined) {
|
|
||||||
throw new Error('No method named "' + config + '"');
|
|
||||||
}
|
|
||||||
data[config]();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'VERSION',
|
|
||||||
get: function get() {
|
|
||||||
return VERSION;
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
return Tab;
|
|
||||||
})();
|
|
||||||
|
|
||||||
$(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE, function (event) {
|
|
||||||
event.preventDefault();
|
|
||||||
Tab._jQueryInterface.call($(this), 'show');
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* jQuery
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
$.fn[NAME] = Tab._jQueryInterface;
|
|
||||||
$.fn[NAME].Constructor = Tab;
|
|
||||||
$.fn[NAME].noConflict = function () {
|
|
||||||
$.fn[NAME] = JQUERY_NO_CONFLICT;
|
|
||||||
return Tab._jQueryInterface;
|
|
||||||
};
|
|
||||||
|
|
||||||
return Tab;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = Tab;
|
|
||||||
});
|
|
638
dist/js/umd/tooltip.js
vendored
@ -1,638 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module', './util'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module, require('./util'));
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod, global.Util);
|
|
||||||
global.tooltip = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module, _util) {
|
|
||||||
/* global Tether */
|
|
||||||
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
|
||||||
|
|
||||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
|
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
|
||||||
|
|
||||||
var _Util = _interopRequireDefault(_util);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): tooltip.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Tooltip = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check for Tether dependency
|
|
||||||
* Tether - http://github.hubspot.com/tether/
|
|
||||||
*/
|
|
||||||
if (window.Tether === undefined) {
|
|
||||||
throw new Error('Bootstrap tooltips require Tether (http://github.hubspot.com/tether/)');
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Constants
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var NAME = 'tooltip';
|
|
||||||
var VERSION = '4.0.0-alpha.2';
|
|
||||||
var DATA_KEY = 'bs.tooltip';
|
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
|
||||||
var TRANSITION_DURATION = 150;
|
|
||||||
var CLASS_PREFIX = 'bs-tether';
|
|
||||||
|
|
||||||
var Default = {
|
|
||||||
animation: true,
|
|
||||||
template: '<div class="tooltip" role="tooltip">' + '<div class="tooltip-arrow"></div>' + '<div class="tooltip-inner"></div></div>',
|
|
||||||
trigger: 'hover focus',
|
|
||||||
title: '',
|
|
||||||
delay: 0,
|
|
||||||
html: false,
|
|
||||||
selector: false,
|
|
||||||
placement: 'top',
|
|
||||||
offset: '0 0',
|
|
||||||
constraints: []
|
|
||||||
};
|
|
||||||
|
|
||||||
var DefaultType = {
|
|
||||||
animation: 'boolean',
|
|
||||||
template: 'string',
|
|
||||||
title: '(string|element|function)',
|
|
||||||
trigger: 'string',
|
|
||||||
delay: '(number|object)',
|
|
||||||
html: 'boolean',
|
|
||||||
selector: '(string|boolean)',
|
|
||||||
placement: '(string|function)',
|
|
||||||
offset: 'string',
|
|
||||||
constraints: 'array'
|
|
||||||
};
|
|
||||||
|
|
||||||
var AttachmentMap = {
|
|
||||||
TOP: 'bottom center',
|
|
||||||
RIGHT: 'middle left',
|
|
||||||
BOTTOM: 'top center',
|
|
||||||
LEFT: 'middle right'
|
|
||||||
};
|
|
||||||
|
|
||||||
var HoverState = {
|
|
||||||
IN: 'in',
|
|
||||||
OUT: 'out'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Event = {
|
|
||||||
HIDE: 'hide' + EVENT_KEY,
|
|
||||||
HIDDEN: 'hidden' + EVENT_KEY,
|
|
||||||
SHOW: 'show' + EVENT_KEY,
|
|
||||||
SHOWN: 'shown' + EVENT_KEY,
|
|
||||||
INSERTED: 'inserted' + EVENT_KEY,
|
|
||||||
CLICK: 'click' + EVENT_KEY,
|
|
||||||
FOCUSIN: 'focusin' + EVENT_KEY,
|
|
||||||
FOCUSOUT: 'focusout' + EVENT_KEY,
|
|
||||||
MOUSEENTER: 'mouseenter' + EVENT_KEY,
|
|
||||||
MOUSELEAVE: 'mouseleave' + EVENT_KEY
|
|
||||||
};
|
|
||||||
|
|
||||||
var ClassName = {
|
|
||||||
FADE: 'fade',
|
|
||||||
IN: 'in'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Selector = {
|
|
||||||
TOOLTIP: '.tooltip',
|
|
||||||
TOOLTIP_INNER: '.tooltip-inner'
|
|
||||||
};
|
|
||||||
|
|
||||||
var TetherClass = {
|
|
||||||
element: false,
|
|
||||||
enabled: false
|
|
||||||
};
|
|
||||||
|
|
||||||
var Trigger = {
|
|
||||||
HOVER: 'hover',
|
|
||||||
FOCUS: 'focus',
|
|
||||||
CLICK: 'click',
|
|
||||||
MANUAL: 'manual'
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Class Definition
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Tooltip = (function () {
|
|
||||||
function Tooltip(element, config) {
|
|
||||||
_classCallCheck(this, Tooltip);
|
|
||||||
|
|
||||||
// private
|
|
||||||
this._isEnabled = true;
|
|
||||||
this._timeout = 0;
|
|
||||||
this._hoverState = '';
|
|
||||||
this._activeTrigger = {};
|
|
||||||
this._tether = null;
|
|
||||||
|
|
||||||
// protected
|
|
||||||
this.element = element;
|
|
||||||
this.config = this._getConfig(config);
|
|
||||||
this.tip = null;
|
|
||||||
|
|
||||||
this._setListeners();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* jQuery
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
// getters
|
|
||||||
|
|
||||||
_createClass(Tooltip, [{
|
|
||||||
key: 'enable',
|
|
||||||
|
|
||||||
// public
|
|
||||||
|
|
||||||
value: function enable() {
|
|
||||||
this._isEnabled = true;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'disable',
|
|
||||||
value: function disable() {
|
|
||||||
this._isEnabled = false;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'toggleEnabled',
|
|
||||||
value: function toggleEnabled() {
|
|
||||||
this._isEnabled = !this._isEnabled;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'toggle',
|
|
||||||
value: function toggle(event) {
|
|
||||||
if (event) {
|
|
||||||
var dataKey = this.constructor.DATA_KEY;
|
|
||||||
var context = $(event.currentTarget).data(dataKey);
|
|
||||||
|
|
||||||
if (!context) {
|
|
||||||
context = new this.constructor(event.currentTarget, this._getDelegateConfig());
|
|
||||||
$(event.currentTarget).data(dataKey, context);
|
|
||||||
}
|
|
||||||
|
|
||||||
context._activeTrigger.click = !context._activeTrigger.click;
|
|
||||||
|
|
||||||
if (context._isWithActiveTrigger()) {
|
|
||||||
context._enter(null, context);
|
|
||||||
} else {
|
|
||||||
context._leave(null, context);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
|
|
||||||
if ($(this.getTipElement()).hasClass(ClassName.IN)) {
|
|
||||||
this._leave(null, this);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._enter(null, this);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'dispose',
|
|
||||||
value: function dispose() {
|
|
||||||
clearTimeout(this._timeout);
|
|
||||||
|
|
||||||
this.cleanupTether();
|
|
||||||
|
|
||||||
$.removeData(this.element, this.constructor.DATA_KEY);
|
|
||||||
|
|
||||||
$(this.element).off(this.constructor.EVENT_KEY);
|
|
||||||
|
|
||||||
if (this.tip) {
|
|
||||||
$(this.tip).remove();
|
|
||||||
}
|
|
||||||
|
|
||||||
this._isEnabled = null;
|
|
||||||
this._timeout = null;
|
|
||||||
this._hoverState = null;
|
|
||||||
this._activeTrigger = null;
|
|
||||||
this._tether = null;
|
|
||||||
|
|
||||||
this.element = null;
|
|
||||||
this.config = null;
|
|
||||||
this.tip = null;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'show',
|
|
||||||
value: function show() {
|
|
||||||
var _this = this;
|
|
||||||
|
|
||||||
var showEvent = $.Event(this.constructor.Event.SHOW);
|
|
||||||
|
|
||||||
if (this.isWithContent() && this._isEnabled) {
|
|
||||||
$(this.element).trigger(showEvent);
|
|
||||||
|
|
||||||
var isInTheDom = $.contains(this.element.ownerDocument.documentElement, this.element);
|
|
||||||
|
|
||||||
if (showEvent.isDefaultPrevented() || !isInTheDom) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var tip = this.getTipElement();
|
|
||||||
var tipId = _Util['default'].getUID(this.constructor.NAME);
|
|
||||||
|
|
||||||
tip.setAttribute('id', tipId);
|
|
||||||
this.element.setAttribute('aria-describedby', tipId);
|
|
||||||
|
|
||||||
this.setContent();
|
|
||||||
|
|
||||||
if (this.config.animation) {
|
|
||||||
$(tip).addClass(ClassName.FADE);
|
|
||||||
}
|
|
||||||
|
|
||||||
var placement = typeof this.config.placement === 'function' ? this.config.placement.call(this, tip, this.element) : this.config.placement;
|
|
||||||
|
|
||||||
var attachment = this._getAttachment(placement);
|
|
||||||
|
|
||||||
$(tip).data(this.constructor.DATA_KEY, this).appendTo(document.body);
|
|
||||||
|
|
||||||
$(this.element).trigger(this.constructor.Event.INSERTED);
|
|
||||||
|
|
||||||
this._tether = new Tether({
|
|
||||||
attachment: attachment,
|
|
||||||
element: tip,
|
|
||||||
target: this.element,
|
|
||||||
classes: TetherClass,
|
|
||||||
classPrefix: CLASS_PREFIX,
|
|
||||||
offset: this.config.offset,
|
|
||||||
constraints: this.config.constraints,
|
|
||||||
addTargetClasses: false
|
|
||||||
});
|
|
||||||
|
|
||||||
_Util['default'].reflow(tip);
|
|
||||||
this._tether.position();
|
|
||||||
|
|
||||||
$(tip).addClass(ClassName.IN);
|
|
||||||
|
|
||||||
var complete = function complete() {
|
|
||||||
var prevHoverState = _this._hoverState;
|
|
||||||
_this._hoverState = null;
|
|
||||||
|
|
||||||
$(_this.element).trigger(_this.constructor.Event.SHOWN);
|
|
||||||
|
|
||||||
if (prevHoverState === HoverState.OUT) {
|
|
||||||
_this._leave(null, _this);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
if (_Util['default'].supportsTransitionEnd() && $(this.tip).hasClass(ClassName.FADE)) {
|
|
||||||
$(this.tip).one(_Util['default'].TRANSITION_END, complete).emulateTransitionEnd(Tooltip._TRANSITION_DURATION);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
complete();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'hide',
|
|
||||||
value: function hide(callback) {
|
|
||||||
var _this2 = this;
|
|
||||||
|
|
||||||
var tip = this.getTipElement();
|
|
||||||
var hideEvent = $.Event(this.constructor.Event.HIDE);
|
|
||||||
var complete = function complete() {
|
|
||||||
if (_this2._hoverState !== HoverState.IN && tip.parentNode) {
|
|
||||||
tip.parentNode.removeChild(tip);
|
|
||||||
}
|
|
||||||
|
|
||||||
_this2.element.removeAttribute('aria-describedby');
|
|
||||||
$(_this2.element).trigger(_this2.constructor.Event.HIDDEN);
|
|
||||||
_this2.cleanupTether();
|
|
||||||
|
|
||||||
if (callback) {
|
|
||||||
callback();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
$(this.element).trigger(hideEvent);
|
|
||||||
|
|
||||||
if (hideEvent.isDefaultPrevented()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$(tip).removeClass(ClassName.IN);
|
|
||||||
|
|
||||||
if (_Util['default'].supportsTransitionEnd() && $(this.tip).hasClass(ClassName.FADE)) {
|
|
||||||
|
|
||||||
$(tip).one(_Util['default'].TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION);
|
|
||||||
} else {
|
|
||||||
complete();
|
|
||||||
}
|
|
||||||
|
|
||||||
this._hoverState = '';
|
|
||||||
}
|
|
||||||
|
|
||||||
// protected
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: 'isWithContent',
|
|
||||||
value: function isWithContent() {
|
|
||||||
return Boolean(this.getTitle());
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'getTipElement',
|
|
||||||
value: function getTipElement() {
|
|
||||||
return this.tip = this.tip || $(this.config.template)[0];
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'setContent',
|
|
||||||
value: function setContent() {
|
|
||||||
var $tip = $(this.getTipElement());
|
|
||||||
|
|
||||||
this.setElementContent($tip.find(Selector.TOOLTIP_INNER), this.getTitle());
|
|
||||||
|
|
||||||
$tip.removeClass(ClassName.FADE).removeClass(ClassName.IN);
|
|
||||||
|
|
||||||
this.cleanupTether();
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'setElementContent',
|
|
||||||
value: function setElementContent($element, content) {
|
|
||||||
var html = this.config.html;
|
|
||||||
if (typeof content === 'object' && (content.nodeType || content.jquery)) {
|
|
||||||
// content is a DOM node or a jQuery
|
|
||||||
if (html) {
|
|
||||||
if (!$(content).parent().is($element)) {
|
|
||||||
$element.empty().append(content);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$element.text($(content).text());
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$element[html ? 'html' : 'text'](content);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'getTitle',
|
|
||||||
value: function getTitle() {
|
|
||||||
var title = this.element.getAttribute('data-original-title');
|
|
||||||
|
|
||||||
if (!title) {
|
|
||||||
title = typeof this.config.title === 'function' ? this.config.title.call(this.element) : this.config.title;
|
|
||||||
}
|
|
||||||
|
|
||||||
return title;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'cleanupTether',
|
|
||||||
value: function cleanupTether() {
|
|
||||||
if (this._tether) {
|
|
||||||
this._tether.destroy();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// private
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: '_getAttachment',
|
|
||||||
value: function _getAttachment(placement) {
|
|
||||||
return AttachmentMap[placement.toUpperCase()];
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_setListeners',
|
|
||||||
value: function _setListeners() {
|
|
||||||
var _this3 = this;
|
|
||||||
|
|
||||||
var triggers = this.config.trigger.split(' ');
|
|
||||||
|
|
||||||
triggers.forEach(function (trigger) {
|
|
||||||
if (trigger === 'click') {
|
|
||||||
$(_this3.element).on(_this3.constructor.Event.CLICK, _this3.config.selector, $.proxy(_this3.toggle, _this3));
|
|
||||||
} else if (trigger !== Trigger.MANUAL) {
|
|
||||||
var eventIn = trigger === Trigger.HOVER ? _this3.constructor.Event.MOUSEENTER : _this3.constructor.Event.FOCUSIN;
|
|
||||||
var eventOut = trigger === Trigger.HOVER ? _this3.constructor.Event.MOUSELEAVE : _this3.constructor.Event.FOCUSOUT;
|
|
||||||
|
|
||||||
$(_this3.element).on(eventIn, _this3.config.selector, $.proxy(_this3._enter, _this3)).on(eventOut, _this3.config.selector, $.proxy(_this3._leave, _this3));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
if (this.config.selector) {
|
|
||||||
this.config = $.extend({}, this.config, {
|
|
||||||
trigger: 'manual',
|
|
||||||
selector: ''
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
this._fixTitle();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_fixTitle',
|
|
||||||
value: function _fixTitle() {
|
|
||||||
var titleType = typeof this.element.getAttribute('data-original-title');
|
|
||||||
if (this.element.getAttribute('title') || titleType !== 'string') {
|
|
||||||
this.element.setAttribute('data-original-title', this.element.getAttribute('title') || '');
|
|
||||||
this.element.setAttribute('title', '');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_enter',
|
|
||||||
value: function _enter(event, context) {
|
|
||||||
var dataKey = this.constructor.DATA_KEY;
|
|
||||||
|
|
||||||
context = context || $(event.currentTarget).data(dataKey);
|
|
||||||
|
|
||||||
if (!context) {
|
|
||||||
context = new this.constructor(event.currentTarget, this._getDelegateConfig());
|
|
||||||
$(event.currentTarget).data(dataKey, context);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (event) {
|
|
||||||
context._activeTrigger[event.type === 'focusin' ? Trigger.FOCUS : Trigger.HOVER] = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($(context.getTipElement()).hasClass(ClassName.IN) || context._hoverState === HoverState.IN) {
|
|
||||||
context._hoverState = HoverState.IN;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
clearTimeout(context._timeout);
|
|
||||||
|
|
||||||
context._hoverState = HoverState.IN;
|
|
||||||
|
|
||||||
if (!context.config.delay || !context.config.delay.show) {
|
|
||||||
context.show();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
context._timeout = setTimeout(function () {
|
|
||||||
if (context._hoverState === HoverState.IN) {
|
|
||||||
context.show();
|
|
||||||
}
|
|
||||||
}, context.config.delay.show);
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_leave',
|
|
||||||
value: function _leave(event, context) {
|
|
||||||
var dataKey = this.constructor.DATA_KEY;
|
|
||||||
|
|
||||||
context = context || $(event.currentTarget).data(dataKey);
|
|
||||||
|
|
||||||
if (!context) {
|
|
||||||
context = new this.constructor(event.currentTarget, this._getDelegateConfig());
|
|
||||||
$(event.currentTarget).data(dataKey, context);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (event) {
|
|
||||||
context._activeTrigger[event.type === 'focusout' ? Trigger.FOCUS : Trigger.HOVER] = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (context._isWithActiveTrigger()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
clearTimeout(context._timeout);
|
|
||||||
|
|
||||||
context._hoverState = HoverState.OUT;
|
|
||||||
|
|
||||||
if (!context.config.delay || !context.config.delay.hide) {
|
|
||||||
context.hide();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
context._timeout = setTimeout(function () {
|
|
||||||
if (context._hoverState === HoverState.OUT) {
|
|
||||||
context.hide();
|
|
||||||
}
|
|
||||||
}, context.config.delay.hide);
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_isWithActiveTrigger',
|
|
||||||
value: function _isWithActiveTrigger() {
|
|
||||||
for (var trigger in this._activeTrigger) {
|
|
||||||
if (this._activeTrigger[trigger]) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_getConfig',
|
|
||||||
value: function _getConfig(config) {
|
|
||||||
config = $.extend({}, this.constructor.Default, $(this.element).data(), config);
|
|
||||||
|
|
||||||
if (config.delay && typeof config.delay === 'number') {
|
|
||||||
config.delay = {
|
|
||||||
show: config.delay,
|
|
||||||
hide: config.delay
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
_Util['default'].typeCheckConfig(NAME, config, this.constructor.DefaultType);
|
|
||||||
|
|
||||||
return config;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_getDelegateConfig',
|
|
||||||
value: function _getDelegateConfig() {
|
|
||||||
var config = {};
|
|
||||||
|
|
||||||
if (this.config) {
|
|
||||||
for (var key in this.config) {
|
|
||||||
if (this.constructor.Default[key] !== this.config[key]) {
|
|
||||||
config[key] = this.config[key];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return config;
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
|
|
||||||
}], [{
|
|
||||||
key: '_jQueryInterface',
|
|
||||||
value: function _jQueryInterface(config) {
|
|
||||||
return this.each(function () {
|
|
||||||
var data = $(this).data(DATA_KEY);
|
|
||||||
var _config = typeof config === 'object' ? config : null;
|
|
||||||
|
|
||||||
if (!data && /destroy|hide/.test(config)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!data) {
|
|
||||||
data = new Tooltip(this, _config);
|
|
||||||
$(this).data(DATA_KEY, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (typeof config === 'string') {
|
|
||||||
if (data[config] === undefined) {
|
|
||||||
throw new Error('No method named "' + config + '"');
|
|
||||||
}
|
|
||||||
data[config]();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'VERSION',
|
|
||||||
get: function get() {
|
|
||||||
return VERSION;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'Default',
|
|
||||||
get: function get() {
|
|
||||||
return Default;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'NAME',
|
|
||||||
get: function get() {
|
|
||||||
return NAME;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'DATA_KEY',
|
|
||||||
get: function get() {
|
|
||||||
return DATA_KEY;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'Event',
|
|
||||||
get: function get() {
|
|
||||||
return Event;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'EVENT_KEY',
|
|
||||||
get: function get() {
|
|
||||||
return EVENT_KEY;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'DefaultType',
|
|
||||||
get: function get() {
|
|
||||||
return DefaultType;
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
return Tooltip;
|
|
||||||
})();
|
|
||||||
|
|
||||||
$.fn[NAME] = Tooltip._jQueryInterface;
|
|
||||||
$.fn[NAME].Constructor = Tooltip;
|
|
||||||
$.fn[NAME].noConflict = function () {
|
|
||||||
$.fn[NAME] = JQUERY_NO_CONFLICT;
|
|
||||||
return Tooltip._jQueryInterface;
|
|
||||||
};
|
|
||||||
|
|
||||||
return Tooltip;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = Tooltip;
|
|
||||||
});
|
|
174
dist/js/umd/util.js
vendored
@ -1,174 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module);
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod);
|
|
||||||
global.util = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module) {
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): util.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var Util = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Private TransitionEnd Helpers
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var transition = false;
|
|
||||||
|
|
||||||
var TransitionEndEvent = {
|
|
||||||
WebkitTransition: 'webkitTransitionEnd',
|
|
||||||
MozTransition: 'transitionend',
|
|
||||||
OTransition: 'oTransitionEnd otransitionend',
|
|
||||||
transition: 'transitionend'
|
|
||||||
};
|
|
||||||
|
|
||||||
// shoutout AngusCroll (https://goo.gl/pxwQGp)
|
|
||||||
function toType(obj) {
|
|
||||||
return ({}).toString.call(obj).match(/\s([a-zA-Z]+)/)[1].toLowerCase();
|
|
||||||
}
|
|
||||||
|
|
||||||
function isElement(obj) {
|
|
||||||
return (obj[0] || obj).nodeType;
|
|
||||||
}
|
|
||||||
|
|
||||||
function getSpecialTransitionEndEvent() {
|
|
||||||
return {
|
|
||||||
bindType: transition.end,
|
|
||||||
delegateType: transition.end,
|
|
||||||
handle: function handle(event) {
|
|
||||||
if ($(event.target).is(this)) {
|
|
||||||
return event.handleObj.handler.apply(this, arguments);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
function transitionEndTest() {
|
|
||||||
if (window.QUnit) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
var el = document.createElement('bootstrap');
|
|
||||||
|
|
||||||
for (var _name in TransitionEndEvent) {
|
|
||||||
if (el.style[_name] !== undefined) {
|
|
||||||
return { end: TransitionEndEvent[_name] };
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
function transitionEndEmulator(duration) {
|
|
||||||
var _this = this;
|
|
||||||
|
|
||||||
var called = false;
|
|
||||||
|
|
||||||
$(this).one(Util.TRANSITION_END, function () {
|
|
||||||
called = true;
|
|
||||||
});
|
|
||||||
|
|
||||||
setTimeout(function () {
|
|
||||||
if (!called) {
|
|
||||||
Util.triggerTransitionEnd(_this);
|
|
||||||
}
|
|
||||||
}, duration);
|
|
||||||
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
function setTransitionEndSupport() {
|
|
||||||
transition = transitionEndTest();
|
|
||||||
|
|
||||||
$.fn.emulateTransitionEnd = transitionEndEmulator;
|
|
||||||
|
|
||||||
if (Util.supportsTransitionEnd()) {
|
|
||||||
$.event.special[Util.TRANSITION_END] = getSpecialTransitionEndEvent();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Public Util Api
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Util = {
|
|
||||||
|
|
||||||
TRANSITION_END: 'bsTransitionEnd',
|
|
||||||
|
|
||||||
getUID: function getUID(prefix) {
|
|
||||||
do {
|
|
||||||
/* eslint-disable no-bitwise */
|
|
||||||
prefix += ~ ~(Math.random() * 1000000); // "~~" acts like a faster Math.floor() here
|
|
||||||
/* eslint-enable no-bitwise */
|
|
||||||
} while (document.getElementById(prefix));
|
|
||||||
return prefix;
|
|
||||||
},
|
|
||||||
|
|
||||||
getSelectorFromElement: function getSelectorFromElement(element) {
|
|
||||||
var selector = element.getAttribute('data-target');
|
|
||||||
|
|
||||||
if (!selector) {
|
|
||||||
selector = element.getAttribute('href') || '';
|
|
||||||
selector = /^#[a-z]/i.test(selector) ? selector : null;
|
|
||||||
}
|
|
||||||
|
|
||||||
return selector;
|
|
||||||
},
|
|
||||||
|
|
||||||
reflow: function reflow(element) {
|
|
||||||
new Function('bs', 'return bs')(element.offsetHeight);
|
|
||||||
},
|
|
||||||
|
|
||||||
triggerTransitionEnd: function triggerTransitionEnd(element) {
|
|
||||||
$(element).trigger(transition.end);
|
|
||||||
},
|
|
||||||
|
|
||||||
supportsTransitionEnd: function supportsTransitionEnd() {
|
|
||||||
return Boolean(transition);
|
|
||||||
},
|
|
||||||
|
|
||||||
typeCheckConfig: function typeCheckConfig(componentName, config, configTypes) {
|
|
||||||
for (var property in configTypes) {
|
|
||||||
if (configTypes.hasOwnProperty(property)) {
|
|
||||||
var expectedTypes = configTypes[property];
|
|
||||||
var value = config[property];
|
|
||||||
var valueType = undefined;
|
|
||||||
|
|
||||||
if (value && isElement(value)) {
|
|
||||||
valueType = 'element';
|
|
||||||
} else {
|
|
||||||
valueType = toType(value);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!new RegExp(expectedTypes).test(valueType)) {
|
|
||||||
throw new Error(componentName.toUpperCase() + ': ' + ('Option "' + property + '" provided type "' + valueType + '" ') + ('but expected type "' + expectedTypes + '".'));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
setTransitionEndSupport();
|
|
||||||
|
|
||||||
return Util;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = Util;
|
|
||||||
});
|
|
15
docs/.htmlhintrc
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
{
|
||||||
|
"attr-lowercase": true,
|
||||||
|
"attr-no-duplication": true,
|
||||||
|
"alt-require": true,
|
||||||
|
"attr-unsafe-chars": true,
|
||||||
|
"attr-value-double-quotes": true,
|
||||||
|
"doctype-first": true,
|
||||||
|
"doctype-html5": true,
|
||||||
|
"id-unique": true,
|
||||||
|
"spec-char-escape": true,
|
||||||
|
"src-not-empty": true,
|
||||||
|
"tag-pair": true,
|
||||||
|
"tagname-lowercase": true,
|
||||||
|
"title-require": true
|
||||||
|
}
|
@ -1,3 +1,13 @@
|
|||||||
|
-
|
||||||
|
browser: >
|
||||||
|
Microsoft Edge
|
||||||
|
summary: >
|
||||||
|
Dynamically generated `<label><input type="file"></label>` causes infinite loop of file dialogs.
|
||||||
|
upstream_bug: >
|
||||||
|
Edge#8282613
|
||||||
|
origin: >
|
||||||
|
Bootstrap#20335
|
||||||
|
|
||||||
-
|
-
|
||||||
browser: >
|
browser: >
|
||||||
Microsoft Edge
|
Microsoft Edge
|
||||||
@ -68,6 +78,16 @@
|
|||||||
origin: >
|
origin: >
|
||||||
Bootstrap#18228
|
Bootstrap#18228
|
||||||
|
|
||||||
|
-
|
||||||
|
browser: >
|
||||||
|
Microsoft Edge
|
||||||
|
summary: >
|
||||||
|
Hovering over descendant SVG element fires `mouseleave` event at ancestor
|
||||||
|
upstream_bug: >
|
||||||
|
Edge#7787318
|
||||||
|
origin: >
|
||||||
|
Bootstrap#19670
|
||||||
|
|
||||||
-
|
-
|
||||||
browser: >
|
browser: >
|
||||||
Firefox
|
Firefox
|
||||||
@ -102,11 +122,31 @@
|
|||||||
browser: >
|
browser: >
|
||||||
Firefox
|
Firefox
|
||||||
summary: >
|
summary: >
|
||||||
Fire `transitioncancel` event when a transition is canceled
|
Wide floated table doesn't wrap onto new line
|
||||||
upstream_bug: >
|
upstream_bug: >
|
||||||
Mozilla#1264125
|
Mozilla#1277782
|
||||||
origin: >
|
origin: >
|
||||||
Mozilla#1182856
|
Bootstrap#19839
|
||||||
|
|
||||||
|
-
|
||||||
|
browser: >
|
||||||
|
Firefox
|
||||||
|
summary: >
|
||||||
|
Mouse sometimes not within element for purposes of `mouseenter`/`mouseleave` when it's within SVG elements
|
||||||
|
upstream_bug: >
|
||||||
|
Mozilla#577785
|
||||||
|
origin: >
|
||||||
|
Bootstrap#19670
|
||||||
|
|
||||||
|
-
|
||||||
|
browser: >
|
||||||
|
Firefox
|
||||||
|
summary: >
|
||||||
|
`position: absolute` element that's wider than its column renders differently than other browsers
|
||||||
|
upstream_bug: >
|
||||||
|
Mozilla#1282363
|
||||||
|
origin: >
|
||||||
|
Bootstrap#20161
|
||||||
|
|
||||||
-
|
-
|
||||||
browser: >
|
browser: >
|
||||||
@ -148,16 +188,6 @@
|
|||||||
origin: >
|
origin: >
|
||||||
Offshoot of Bootstrap#8350 & Chromium#337668
|
Offshoot of Bootstrap#8350 & Chromium#337668
|
||||||
|
|
||||||
-
|
|
||||||
browser: >
|
|
||||||
Chrome (OS X)
|
|
||||||
summary: >
|
|
||||||
Caps Lock indicator not shown in `<input type="password">` with `display: block`
|
|
||||||
upstream_bug: >
|
|
||||||
Chromium#460200
|
|
||||||
origin: >
|
|
||||||
Bootstrap#15832
|
|
||||||
|
|
||||||
-
|
-
|
||||||
browser: >
|
browser: >
|
||||||
Chrome
|
Chrome
|
||||||
@ -178,16 +208,6 @@
|
|||||||
origin: >
|
origin: >
|
||||||
Bootstrap#16022
|
Bootstrap#16022
|
||||||
|
|
||||||
-
|
|
||||||
browser: >
|
|
||||||
Chrome
|
|
||||||
summary: >
|
|
||||||
`width: 1%` on nested table cell causes its table to hog horizontal space.
|
|
||||||
upstream_bug: >
|
|
||||||
Chromium#427994
|
|
||||||
origin: >
|
|
||||||
Bootstrap#16372
|
|
||||||
|
|
||||||
-
|
-
|
||||||
browser: >
|
browser: >
|
||||||
Chrome
|
Chrome
|
||||||
@ -198,6 +218,26 @@
|
|||||||
origin: >
|
origin: >
|
||||||
Bootstrap#17438, Bootstrap#14237
|
Bootstrap#17438, Bootstrap#14237
|
||||||
|
|
||||||
|
-
|
||||||
|
browser: >
|
||||||
|
Chrome
|
||||||
|
summary: >
|
||||||
|
Clicking scrollbar in `<select multiple>` with overflowed options will select nearby `<option>`
|
||||||
|
upstream_bug: >
|
||||||
|
Chromium#597642
|
||||||
|
origin: >
|
||||||
|
Bootstrap#19810
|
||||||
|
|
||||||
|
-
|
||||||
|
browser: >
|
||||||
|
Chrome
|
||||||
|
summary: >
|
||||||
|
Don't make `:hover` sticky on touch-friendly webpages
|
||||||
|
upstream_bug: >
|
||||||
|
Chromium#370155
|
||||||
|
origin: >
|
||||||
|
Bootstrap#12832
|
||||||
|
|
||||||
-
|
-
|
||||||
browser: >
|
browser: >
|
||||||
Chrome (Windows & Linux)
|
Chrome (Windows & Linux)
|
||||||
@ -208,16 +248,6 @@
|
|||||||
origin: >
|
origin: >
|
||||||
Bootstrap#15298
|
Bootstrap#15298
|
||||||
|
|
||||||
-
|
|
||||||
browser: >
|
|
||||||
Safari
|
|
||||||
summary: >
|
|
||||||
`width: 1%` on nested table cell causes its table to hog horizontal space.
|
|
||||||
upstream_bug: >
|
|
||||||
WebKit#144696, Safari#20839572
|
|
||||||
origin: >
|
|
||||||
Bootstrap#16372
|
|
||||||
|
|
||||||
-
|
-
|
||||||
browser: >
|
browser: >
|
||||||
Safari
|
Safari
|
||||||
@ -360,6 +390,36 @@
|
|||||||
origin: >
|
origin: >
|
||||||
Bootstrap#14839
|
Bootstrap#14839
|
||||||
|
|
||||||
|
-
|
||||||
|
browser: >
|
||||||
|
Safari (iOS)
|
||||||
|
summary: >
|
||||||
|
Tapping from one `<input>` to another in an overlay can cause shaking/jiggling effect
|
||||||
|
upstream_bug: >
|
||||||
|
WebKit#158276
|
||||||
|
origin: >
|
||||||
|
Bootstrap#19927
|
||||||
|
|
||||||
|
-
|
||||||
|
browser: >
|
||||||
|
Safari (iOS)
|
||||||
|
summary: >
|
||||||
|
Modal with `-webkit-overflow-scrolling: touch` doesn't become scrollable after added text makes it taller
|
||||||
|
upstream_bug: >
|
||||||
|
WebKit#158342
|
||||||
|
origin: >
|
||||||
|
Bootstrap#17695
|
||||||
|
|
||||||
|
-
|
||||||
|
browser: >
|
||||||
|
Safari (iOS)
|
||||||
|
summary: >
|
||||||
|
Don't make `:hover` sticky on touch-friendly webpages
|
||||||
|
upstream_bug: >
|
||||||
|
WebKit#158517
|
||||||
|
origin: >
|
||||||
|
Bootstrap#12832
|
||||||
|
|
||||||
-
|
-
|
||||||
browser: >
|
browser: >
|
||||||
Safari (iPad Pro)
|
Safari (iPad Pro)
|
||||||
|
99
docs/_data/browser-features.yml
Normal file
@ -0,0 +1,99 @@
|
|||||||
|
-
|
||||||
|
browser: >
|
||||||
|
Microsoft Edge
|
||||||
|
summary: >
|
||||||
|
Implement the [`:dir()` pseudo-class](https://developer.mozilla.org/en-US/docs/Web/CSS/:dir) from Selectors Level 4
|
||||||
|
upstream_bug: >
|
||||||
|
UserVoice#12299532
|
||||||
|
origin: >
|
||||||
|
Bootstrap#19984
|
||||||
|
|
||||||
|
-
|
||||||
|
browser: >
|
||||||
|
Microsoft Edge
|
||||||
|
summary: >
|
||||||
|
Implement [sticky positioning](http://html5please.com/#position:sticky) from CSS Positioned Layout Level 3
|
||||||
|
upstream_bug: >
|
||||||
|
UserVoice#6263621
|
||||||
|
origin: >
|
||||||
|
Bootstrap#17021
|
||||||
|
|
||||||
|
-
|
||||||
|
browser: >
|
||||||
|
Firefox
|
||||||
|
summary: >
|
||||||
|
Fire a [`transitioncancel` event](https://developer.mozilla.org/en-US/docs/Web/Events/transitioncancel) when a CSS transition is canceled
|
||||||
|
upstream_bug: >
|
||||||
|
Mozilla#1264125
|
||||||
|
origin: >
|
||||||
|
Mozilla#1182856
|
||||||
|
|
||||||
|
-
|
||||||
|
browser: >
|
||||||
|
Firefox
|
||||||
|
summary: >
|
||||||
|
Implement the [`of <selector-list>` clause](http://caniuse.com/#feat=css-nth-child-of) of the `:nth-child()` pseudo-class
|
||||||
|
upstream_bug: >
|
||||||
|
Mozilla#854148
|
||||||
|
origin: >
|
||||||
|
Bootstrap#20143
|
||||||
|
|
||||||
|
-
|
||||||
|
browser: >
|
||||||
|
Firefox
|
||||||
|
summary: >
|
||||||
|
Implement the HTML5 [`<dialog>` element](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/dialog)
|
||||||
|
upstream_bug: >
|
||||||
|
Mozilla#840640
|
||||||
|
origin: >
|
||||||
|
Bootstrap#20175
|
||||||
|
|
||||||
|
-
|
||||||
|
browser: >
|
||||||
|
Chrome
|
||||||
|
summary: >
|
||||||
|
Implement the [`of <selector-list>` clause](http://caniuse.com/#feat=css-nth-child-of) of the `:nth-child()` pseudo-class
|
||||||
|
upstream_bug: >
|
||||||
|
Chromium#304163
|
||||||
|
origin: >
|
||||||
|
Bootstrap#20143
|
||||||
|
|
||||||
|
-
|
||||||
|
browser: >
|
||||||
|
Chrome
|
||||||
|
summary: >
|
||||||
|
Implement the [`:dir()` pseudo-class](https://developer.mozilla.org/en-US/docs/Web/CSS/:dir) from Selectors Level 4
|
||||||
|
upstream_bug: >
|
||||||
|
Chromium#576815
|
||||||
|
origin: >
|
||||||
|
Bootstrap#19984
|
||||||
|
|
||||||
|
-
|
||||||
|
browser: >
|
||||||
|
Chrome
|
||||||
|
summary: >
|
||||||
|
Implement [sticky positioning](http://html5please.com/#position:sticky) from CSS Positioned Layout Level 3
|
||||||
|
upstream_bug: >
|
||||||
|
Chromium#231752
|
||||||
|
origin: >
|
||||||
|
Bootstrap#17021
|
||||||
|
|
||||||
|
-
|
||||||
|
browser: >
|
||||||
|
Safari
|
||||||
|
summary: >
|
||||||
|
Implement the [`:dir()` pseudo-class](https://developer.mozilla.org/en-US/docs/Web/CSS/:dir) from Selectors Level 4
|
||||||
|
upstream_bug: >
|
||||||
|
WebKit#64861
|
||||||
|
origin: >
|
||||||
|
Bootstrap#19984
|
||||||
|
|
||||||
|
-
|
||||||
|
browser: >
|
||||||
|
Safari
|
||||||
|
summary: >
|
||||||
|
Implement the HTML5 [`<dialog>` element](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/dialog)
|
||||||
|
upstream_bug: >
|
||||||
|
WebKit#84635
|
||||||
|
origin: >
|
||||||
|
Bootstrap#20175
|
@ -15,6 +15,9 @@
|
|||||||
<!-- Bootstrap core CSS -->
|
<!-- Bootstrap core CSS -->
|
||||||
{% if site.github %}
|
{% if site.github %}
|
||||||
<link href="{{ site.baseurl }}/dist/css/bootstrap.min.css" rel="stylesheet">
|
<link href="{{ site.baseurl }}/dist/css/bootstrap.min.css" rel="stylesheet">
|
||||||
|
{% if page.title == "Flexbox grid system" %}
|
||||||
|
<link href="{{ site.baseurl }}/assets/css/docs-flexbox.min.css" rel="stylesheet">
|
||||||
|
{% endif %}
|
||||||
{% else %}
|
{% else %}
|
||||||
<link href="{{ site.baseurl }}/dist/css/bootstrap.css" rel="stylesheet">
|
<link href="{{ site.baseurl }}/dist/css/bootstrap.css" rel="stylesheet">
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
@ -4,6 +4,7 @@ module Jekyll
|
|||||||
upstream_map = {
|
upstream_map = {
|
||||||
"Bootstrap" => "https://github.com/twbs/bootstrap/issues/",
|
"Bootstrap" => "https://github.com/twbs/bootstrap/issues/",
|
||||||
"Edge" => ["https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/", "Edge issue"],
|
"Edge" => ["https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/", "Edge issue"],
|
||||||
|
"UserVoice" => ["https://wpdev.uservoice.com/forums/257854-microsoft-edge-developer/suggestions/", "Edge UserVoice idea"],
|
||||||
"Mozilla" => ["https://bugzilla.mozilla.org/show_bug.cgi?id=", "Mozilla bug"],
|
"Mozilla" => ["https://bugzilla.mozilla.org/show_bug.cgi?id=", "Mozilla bug"],
|
||||||
"Chromium" => ["https://bugs.chromium.org/p/chromium/issues/detail?id=", "Chromium issue"],
|
"Chromium" => ["https://bugs.chromium.org/p/chromium/issues/detail?id=", "Chromium issue"],
|
||||||
"WebKit" => ["https://bugs.webkit.org/show_bug.cgi?id=", "WebKit bug"],
|
"WebKit" => ["https://bugs.webkit.org/show_bug.cgi?id=", "WebKit bug"],
|
||||||
|
@ -27,14 +27,14 @@ module Jekyll
|
|||||||
@options[key.to_sym] = value || true
|
@options[key.to_sym] = value || true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@options[:linenos] = "inline" if @options.key?(:linenos) and @options[:linenos] == true
|
@options[:linenos] = false
|
||||||
else
|
else
|
||||||
raise SyntaxError.new <<-eos
|
raise SyntaxError.new <<-eos
|
||||||
Syntax Error in tag 'highlight' while parsing the following markup:
|
Syntax Error in tag 'example' while parsing the following markup:
|
||||||
|
|
||||||
#{markup}
|
#{markup}
|
||||||
|
|
||||||
Valid syntax: highlight <lang> [linenos]
|
Valid syntax: example <lang>
|
||||||
eos
|
eos
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
1240
docs/assets/css/docs-flexbox.min.css
vendored
Normal file
@ -0,0 +1,1240 @@
|
|||||||
|
.flex-xs-first {
|
||||||
|
order: -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
.flex-xs-last {
|
||||||
|
order: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
.flex-xs-unordered {
|
||||||
|
order: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.flex-items-xs-top {
|
||||||
|
align-items: flex-start;
|
||||||
|
}
|
||||||
|
|
||||||
|
.flex-items-xs-middle {
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.flex-items-xs-bottom {
|
||||||
|
align-items: flex-end;
|
||||||
|
}
|
||||||
|
|
||||||
|
.flex-xs-top {
|
||||||
|
align-self: flex-start;
|
||||||
|
}
|
||||||
|
|
||||||
|
.flex-xs-middle {
|
||||||
|
align-self: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.flex-xs-bottom {
|
||||||
|
align-self: flex-end;
|
||||||
|
}
|
||||||
|
|
||||||
|
.flex-items-xs-left {
|
||||||
|
justify-content: flex-start;
|
||||||
|
}
|
||||||
|
|
||||||
|
.flex-items-xs-center {
|
||||||
|
justify-content: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.flex-items-xs-right {
|
||||||
|
justify-content: flex-end;
|
||||||
|
}
|
||||||
|
|
||||||
|
.flex-items-xs-around {
|
||||||
|
justify-content: space-around;
|
||||||
|
}
|
||||||
|
|
||||||
|
.flex-items-xs-between {
|
||||||
|
justify-content: space-between;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 544px) {
|
||||||
|
.flex-sm-first {
|
||||||
|
order: -1;
|
||||||
|
}
|
||||||
|
.flex-sm-last {
|
||||||
|
order: 1;
|
||||||
|
}
|
||||||
|
.flex-sm-unordered {
|
||||||
|
order: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 544px) {
|
||||||
|
.flex-items-sm-top {
|
||||||
|
align-items: flex-start;
|
||||||
|
}
|
||||||
|
.flex-items-sm-middle {
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
.flex-items-sm-bottom {
|
||||||
|
align-items: flex-end;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 544px) {
|
||||||
|
.flex-sm-top {
|
||||||
|
align-self: flex-start;
|
||||||
|
}
|
||||||
|
.flex-sm-middle {
|
||||||
|
align-self: center;
|
||||||
|
}
|
||||||
|
.flex-sm-bottom {
|
||||||
|
align-self: flex-end;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 544px) {
|
||||||
|
.flex-items-sm-left {
|
||||||
|
justify-content: flex-start;
|
||||||
|
}
|
||||||
|
.flex-items-sm-center {
|
||||||
|
justify-content: center;
|
||||||
|
}
|
||||||
|
.flex-items-sm-right {
|
||||||
|
justify-content: flex-end;
|
||||||
|
}
|
||||||
|
.flex-items-sm-around {
|
||||||
|
justify-content: space-around;
|
||||||
|
}
|
||||||
|
.flex-items-sm-between {
|
||||||
|
justify-content: space-between;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 768px) {
|
||||||
|
.flex-md-first {
|
||||||
|
order: -1;
|
||||||
|
}
|
||||||
|
.flex-md-last {
|
||||||
|
order: 1;
|
||||||
|
}
|
||||||
|
.flex-md-unordered {
|
||||||
|
order: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 768px) {
|
||||||
|
.flex-items-md-top {
|
||||||
|
align-items: flex-start;
|
||||||
|
}
|
||||||
|
.flex-items-md-middle {
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
.flex-items-md-bottom {
|
||||||
|
align-items: flex-end;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 768px) {
|
||||||
|
.flex-md-top {
|
||||||
|
align-self: flex-start;
|
||||||
|
}
|
||||||
|
.flex-md-middle {
|
||||||
|
align-self: center;
|
||||||
|
}
|
||||||
|
.flex-md-bottom {
|
||||||
|
align-self: flex-end;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 768px) {
|
||||||
|
.flex-items-md-left {
|
||||||
|
justify-content: flex-start;
|
||||||
|
}
|
||||||
|
.flex-items-md-center {
|
||||||
|
justify-content: center;
|
||||||
|
}
|
||||||
|
.flex-items-md-right {
|
||||||
|
justify-content: flex-end;
|
||||||
|
}
|
||||||
|
.flex-items-md-around {
|
||||||
|
justify-content: space-around;
|
||||||
|
}
|
||||||
|
.flex-items-md-between {
|
||||||
|
justify-content: space-between;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 992px) {
|
||||||
|
.flex-lg-first {
|
||||||
|
order: -1;
|
||||||
|
}
|
||||||
|
.flex-lg-last {
|
||||||
|
order: 1;
|
||||||
|
}
|
||||||
|
.flex-lg-unordered {
|
||||||
|
order: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 992px) {
|
||||||
|
.flex-items-lg-top {
|
||||||
|
align-items: flex-start;
|
||||||
|
}
|
||||||
|
.flex-items-lg-middle {
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
.flex-items-lg-bottom {
|
||||||
|
align-items: flex-end;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 992px) {
|
||||||
|
.flex-lg-top {
|
||||||
|
align-self: flex-start;
|
||||||
|
}
|
||||||
|
.flex-lg-middle {
|
||||||
|
align-self: center;
|
||||||
|
}
|
||||||
|
.flex-lg-bottom {
|
||||||
|
align-self: flex-end;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 992px) {
|
||||||
|
.flex-items-lg-left {
|
||||||
|
justify-content: flex-start;
|
||||||
|
}
|
||||||
|
.flex-items-lg-center {
|
||||||
|
justify-content: center;
|
||||||
|
}
|
||||||
|
.flex-items-lg-right {
|
||||||
|
justify-content: flex-end;
|
||||||
|
}
|
||||||
|
.flex-items-lg-around {
|
||||||
|
justify-content: space-around;
|
||||||
|
}
|
||||||
|
.flex-items-lg-between {
|
||||||
|
justify-content: space-between;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 1200px) {
|
||||||
|
.flex-xl-first {
|
||||||
|
order: -1;
|
||||||
|
}
|
||||||
|
.flex-xl-last {
|
||||||
|
order: 1;
|
||||||
|
}
|
||||||
|
.flex-xl-unordered {
|
||||||
|
order: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 1200px) {
|
||||||
|
.flex-items-xl-top {
|
||||||
|
align-items: flex-start;
|
||||||
|
}
|
||||||
|
.flex-items-xl-middle {
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
.flex-items-xl-bottom {
|
||||||
|
align-items: flex-end;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 1200px) {
|
||||||
|
.flex-xl-top {
|
||||||
|
align-self: flex-start;
|
||||||
|
}
|
||||||
|
.flex-xl-middle {
|
||||||
|
align-self: center;
|
||||||
|
}
|
||||||
|
.flex-xl-bottom {
|
||||||
|
align-self: flex-end;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 1200px) {
|
||||||
|
.flex-items-xl-left {
|
||||||
|
justify-content: flex-start;
|
||||||
|
}
|
||||||
|
.flex-items-xl-center {
|
||||||
|
justify-content: center;
|
||||||
|
}
|
||||||
|
.flex-items-xl-right {
|
||||||
|
justify-content: flex-end;
|
||||||
|
}
|
||||||
|
.flex-items-xl-around {
|
||||||
|
justify-content: space-around;
|
||||||
|
}
|
||||||
|
.flex-items-xl-between {
|
||||||
|
justify-content: space-between;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.container {
|
||||||
|
margin-left: auto;
|
||||||
|
margin-right: auto;
|
||||||
|
padding-left: 15px;
|
||||||
|
padding-right: 15px;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 544px) {
|
||||||
|
.container {
|
||||||
|
max-width: 576px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 768px) {
|
||||||
|
.container {
|
||||||
|
max-width: 720px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 992px) {
|
||||||
|
.container {
|
||||||
|
max-width: 940px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 1200px) {
|
||||||
|
.container {
|
||||||
|
max-width: 1140px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.container-fluid {
|
||||||
|
margin-left: auto;
|
||||||
|
margin-right: auto;
|
||||||
|
padding-left: 15px;
|
||||||
|
padding-right: 15px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.row {
|
||||||
|
display: flex;
|
||||||
|
flex-wrap: wrap;
|
||||||
|
margin-left: -15px;
|
||||||
|
margin-right: -15px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.col-xs-1, .col-xs-2, .col-xs-3, .col-xs-4, .col-xs-5, .col-xs-6, .col-xs-7, .col-xs-8, .col-xs-9, .col-xs-10, .col-xs-11, .col-xs-12, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12, .col-xl-1, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-10, .col-xl-11, .col-xl-12 {
|
||||||
|
position: relative;
|
||||||
|
min-height: 1px;
|
||||||
|
padding-right: 15px;
|
||||||
|
padding-left: 15px;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.col-xs {
|
||||||
|
position: relative;
|
||||||
|
flex-basis: 0;
|
||||||
|
flex-grow: 1;
|
||||||
|
max-width: 100%;
|
||||||
|
min-height: 1px;
|
||||||
|
padding-right: 15px;
|
||||||
|
padding-left: 15px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.col-xs-1 {
|
||||||
|
flex: 0 0 8.333333%;
|
||||||
|
max-width: 8.333333%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.col-xs-2 {
|
||||||
|
flex: 0 0 16.666667%;
|
||||||
|
max-width: 16.666667%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.col-xs-3 {
|
||||||
|
flex: 0 0 25%;
|
||||||
|
max-width: 25%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.col-xs-4 {
|
||||||
|
flex: 0 0 33.333333%;
|
||||||
|
max-width: 33.333333%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.col-xs-5 {
|
||||||
|
flex: 0 0 41.666667%;
|
||||||
|
max-width: 41.666667%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.col-xs-6 {
|
||||||
|
flex: 0 0 50%;
|
||||||
|
max-width: 50%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.col-xs-7 {
|
||||||
|
flex: 0 0 58.333333%;
|
||||||
|
max-width: 58.333333%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.col-xs-8 {
|
||||||
|
flex: 0 0 66.666667%;
|
||||||
|
max-width: 66.666667%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.col-xs-9 {
|
||||||
|
flex: 0 0 75%;
|
||||||
|
max-width: 75%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.col-xs-10 {
|
||||||
|
flex: 0 0 83.333333%;
|
||||||
|
max-width: 83.333333%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.col-xs-11 {
|
||||||
|
flex: 0 0 91.666667%;
|
||||||
|
max-width: 91.666667%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.col-xs-12 {
|
||||||
|
flex: 0 0 100%;
|
||||||
|
max-width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pull-xs-0 {
|
||||||
|
right: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pull-xs-1 {
|
||||||
|
right: 8.333333%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pull-xs-2 {
|
||||||
|
right: 16.666667%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pull-xs-3 {
|
||||||
|
right: 25%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pull-xs-4 {
|
||||||
|
right: 33.333333%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pull-xs-5 {
|
||||||
|
right: 41.666667%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pull-xs-6 {
|
||||||
|
right: 50%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pull-xs-7 {
|
||||||
|
right: 58.333333%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pull-xs-8 {
|
||||||
|
right: 66.666667%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pull-xs-9 {
|
||||||
|
right: 75%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pull-xs-10 {
|
||||||
|
right: 83.333333%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pull-xs-11 {
|
||||||
|
right: 91.666667%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.pull-xs-12 {
|
||||||
|
right: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.push-xs-0 {
|
||||||
|
left: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
.push-xs-1 {
|
||||||
|
left: 8.333333%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.push-xs-2 {
|
||||||
|
left: 16.666667%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.push-xs-3 {
|
||||||
|
left: 25%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.push-xs-4 {
|
||||||
|
left: 33.333333%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.push-xs-5 {
|
||||||
|
left: 41.666667%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.push-xs-6 {
|
||||||
|
left: 50%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.push-xs-7 {
|
||||||
|
left: 58.333333%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.push-xs-8 {
|
||||||
|
left: 66.666667%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.push-xs-9 {
|
||||||
|
left: 75%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.push-xs-10 {
|
||||||
|
left: 83.333333%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.push-xs-11 {
|
||||||
|
left: 91.666667%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.push-xs-12 {
|
||||||
|
left: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.offset-xs-1 {
|
||||||
|
margin-left: 8.333333%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.offset-xs-2 {
|
||||||
|
margin-left: 16.666667%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.offset-xs-3 {
|
||||||
|
margin-left: 25%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.offset-xs-4 {
|
||||||
|
margin-left: 33.333333%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.offset-xs-5 {
|
||||||
|
margin-left: 41.666667%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.offset-xs-6 {
|
||||||
|
margin-left: 50%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.offset-xs-7 {
|
||||||
|
margin-left: 58.333333%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.offset-xs-8 {
|
||||||
|
margin-left: 66.666667%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.offset-xs-9 {
|
||||||
|
margin-left: 75%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.offset-xs-10 {
|
||||||
|
margin-left: 83.333333%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.offset-xs-11 {
|
||||||
|
margin-left: 91.666667%;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 544px) {
|
||||||
|
.col-sm {
|
||||||
|
position: relative;
|
||||||
|
flex-basis: 0;
|
||||||
|
flex-grow: 1;
|
||||||
|
max-width: 100%;
|
||||||
|
min-height: 1px;
|
||||||
|
padding-right: 15px;
|
||||||
|
padding-left: 15px;
|
||||||
|
}
|
||||||
|
.col-sm-1 {
|
||||||
|
flex: 0 0 8.333333%;
|
||||||
|
max-width: 8.333333%;
|
||||||
|
}
|
||||||
|
.col-sm-2 {
|
||||||
|
flex: 0 0 16.666667%;
|
||||||
|
max-width: 16.666667%;
|
||||||
|
}
|
||||||
|
.col-sm-3 {
|
||||||
|
flex: 0 0 25%;
|
||||||
|
max-width: 25%;
|
||||||
|
}
|
||||||
|
.col-sm-4 {
|
||||||
|
flex: 0 0 33.333333%;
|
||||||
|
max-width: 33.333333%;
|
||||||
|
}
|
||||||
|
.col-sm-5 {
|
||||||
|
flex: 0 0 41.666667%;
|
||||||
|
max-width: 41.666667%;
|
||||||
|
}
|
||||||
|
.col-sm-6 {
|
||||||
|
flex: 0 0 50%;
|
||||||
|
max-width: 50%;
|
||||||
|
}
|
||||||
|
.col-sm-7 {
|
||||||
|
flex: 0 0 58.333333%;
|
||||||
|
max-width: 58.333333%;
|
||||||
|
}
|
||||||
|
.col-sm-8 {
|
||||||
|
flex: 0 0 66.666667%;
|
||||||
|
max-width: 66.666667%;
|
||||||
|
}
|
||||||
|
.col-sm-9 {
|
||||||
|
flex: 0 0 75%;
|
||||||
|
max-width: 75%;
|
||||||
|
}
|
||||||
|
.col-sm-10 {
|
||||||
|
flex: 0 0 83.333333%;
|
||||||
|
max-width: 83.333333%;
|
||||||
|
}
|
||||||
|
.col-sm-11 {
|
||||||
|
flex: 0 0 91.666667%;
|
||||||
|
max-width: 91.666667%;
|
||||||
|
}
|
||||||
|
.col-sm-12 {
|
||||||
|
flex: 0 0 100%;
|
||||||
|
max-width: 100%;
|
||||||
|
}
|
||||||
|
.pull-sm-0 {
|
||||||
|
right: auto;
|
||||||
|
}
|
||||||
|
.pull-sm-1 {
|
||||||
|
right: 8.333333%;
|
||||||
|
}
|
||||||
|
.pull-sm-2 {
|
||||||
|
right: 16.666667%;
|
||||||
|
}
|
||||||
|
.pull-sm-3 {
|
||||||
|
right: 25%;
|
||||||
|
}
|
||||||
|
.pull-sm-4 {
|
||||||
|
right: 33.333333%;
|
||||||
|
}
|
||||||
|
.pull-sm-5 {
|
||||||
|
right: 41.666667%;
|
||||||
|
}
|
||||||
|
.pull-sm-6 {
|
||||||
|
right: 50%;
|
||||||
|
}
|
||||||
|
.pull-sm-7 {
|
||||||
|
right: 58.333333%;
|
||||||
|
}
|
||||||
|
.pull-sm-8 {
|
||||||
|
right: 66.666667%;
|
||||||
|
}
|
||||||
|
.pull-sm-9 {
|
||||||
|
right: 75%;
|
||||||
|
}
|
||||||
|
.pull-sm-10 {
|
||||||
|
right: 83.333333%;
|
||||||
|
}
|
||||||
|
.pull-sm-11 {
|
||||||
|
right: 91.666667%;
|
||||||
|
}
|
||||||
|
.pull-sm-12 {
|
||||||
|
right: 100%;
|
||||||
|
}
|
||||||
|
.push-sm-0 {
|
||||||
|
left: auto;
|
||||||
|
}
|
||||||
|
.push-sm-1 {
|
||||||
|
left: 8.333333%;
|
||||||
|
}
|
||||||
|
.push-sm-2 {
|
||||||
|
left: 16.666667%;
|
||||||
|
}
|
||||||
|
.push-sm-3 {
|
||||||
|
left: 25%;
|
||||||
|
}
|
||||||
|
.push-sm-4 {
|
||||||
|
left: 33.333333%;
|
||||||
|
}
|
||||||
|
.push-sm-5 {
|
||||||
|
left: 41.666667%;
|
||||||
|
}
|
||||||
|
.push-sm-6 {
|
||||||
|
left: 50%;
|
||||||
|
}
|
||||||
|
.push-sm-7 {
|
||||||
|
left: 58.333333%;
|
||||||
|
}
|
||||||
|
.push-sm-8 {
|
||||||
|
left: 66.666667%;
|
||||||
|
}
|
||||||
|
.push-sm-9 {
|
||||||
|
left: 75%;
|
||||||
|
}
|
||||||
|
.push-sm-10 {
|
||||||
|
left: 83.333333%;
|
||||||
|
}
|
||||||
|
.push-sm-11 {
|
||||||
|
left: 91.666667%;
|
||||||
|
}
|
||||||
|
.push-sm-12 {
|
||||||
|
left: 100%;
|
||||||
|
}
|
||||||
|
.offset-sm-0 {
|
||||||
|
margin-left: 0%;
|
||||||
|
}
|
||||||
|
.offset-sm-1 {
|
||||||
|
margin-left: 8.333333%;
|
||||||
|
}
|
||||||
|
.offset-sm-2 {
|
||||||
|
margin-left: 16.666667%;
|
||||||
|
}
|
||||||
|
.offset-sm-3 {
|
||||||
|
margin-left: 25%;
|
||||||
|
}
|
||||||
|
.offset-sm-4 {
|
||||||
|
margin-left: 33.333333%;
|
||||||
|
}
|
||||||
|
.offset-sm-5 {
|
||||||
|
margin-left: 41.666667%;
|
||||||
|
}
|
||||||
|
.offset-sm-6 {
|
||||||
|
margin-left: 50%;
|
||||||
|
}
|
||||||
|
.offset-sm-7 {
|
||||||
|
margin-left: 58.333333%;
|
||||||
|
}
|
||||||
|
.offset-sm-8 {
|
||||||
|
margin-left: 66.666667%;
|
||||||
|
}
|
||||||
|
.offset-sm-9 {
|
||||||
|
margin-left: 75%;
|
||||||
|
}
|
||||||
|
.offset-sm-10 {
|
||||||
|
margin-left: 83.333333%;
|
||||||
|
}
|
||||||
|
.offset-sm-11 {
|
||||||
|
margin-left: 91.666667%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 768px) {
|
||||||
|
.col-md {
|
||||||
|
position: relative;
|
||||||
|
flex-basis: 0;
|
||||||
|
flex-grow: 1;
|
||||||
|
max-width: 100%;
|
||||||
|
min-height: 1px;
|
||||||
|
padding-right: 15px;
|
||||||
|
padding-left: 15px;
|
||||||
|
}
|
||||||
|
.col-md-1 {
|
||||||
|
flex: 0 0 8.333333%;
|
||||||
|
max-width: 8.333333%;
|
||||||
|
}
|
||||||
|
.col-md-2 {
|
||||||
|
flex: 0 0 16.666667%;
|
||||||
|
max-width: 16.666667%;
|
||||||
|
}
|
||||||
|
.col-md-3 {
|
||||||
|
flex: 0 0 25%;
|
||||||
|
max-width: 25%;
|
||||||
|
}
|
||||||
|
.col-md-4 {
|
||||||
|
flex: 0 0 33.333333%;
|
||||||
|
max-width: 33.333333%;
|
||||||
|
}
|
||||||
|
.col-md-5 {
|
||||||
|
flex: 0 0 41.666667%;
|
||||||
|
max-width: 41.666667%;
|
||||||
|
}
|
||||||
|
.col-md-6 {
|
||||||
|
flex: 0 0 50%;
|
||||||
|
max-width: 50%;
|
||||||
|
}
|
||||||
|
.col-md-7 {
|
||||||
|
flex: 0 0 58.333333%;
|
||||||
|
max-width: 58.333333%;
|
||||||
|
}
|
||||||
|
.col-md-8 {
|
||||||
|
flex: 0 0 66.666667%;
|
||||||
|
max-width: 66.666667%;
|
||||||
|
}
|
||||||
|
.col-md-9 {
|
||||||
|
flex: 0 0 75%;
|
||||||
|
max-width: 75%;
|
||||||
|
}
|
||||||
|
.col-md-10 {
|
||||||
|
flex: 0 0 83.333333%;
|
||||||
|
max-width: 83.333333%;
|
||||||
|
}
|
||||||
|
.col-md-11 {
|
||||||
|
flex: 0 0 91.666667%;
|
||||||
|
max-width: 91.666667%;
|
||||||
|
}
|
||||||
|
.col-md-12 {
|
||||||
|
flex: 0 0 100%;
|
||||||
|
max-width: 100%;
|
||||||
|
}
|
||||||
|
.pull-md-0 {
|
||||||
|
right: auto;
|
||||||
|
}
|
||||||
|
.pull-md-1 {
|
||||||
|
right: 8.333333%;
|
||||||
|
}
|
||||||
|
.pull-md-2 {
|
||||||
|
right: 16.666667%;
|
||||||
|
}
|
||||||
|
.pull-md-3 {
|
||||||
|
right: 25%;
|
||||||
|
}
|
||||||
|
.pull-md-4 {
|
||||||
|
right: 33.333333%;
|
||||||
|
}
|
||||||
|
.pull-md-5 {
|
||||||
|
right: 41.666667%;
|
||||||
|
}
|
||||||
|
.pull-md-6 {
|
||||||
|
right: 50%;
|
||||||
|
}
|
||||||
|
.pull-md-7 {
|
||||||
|
right: 58.333333%;
|
||||||
|
}
|
||||||
|
.pull-md-8 {
|
||||||
|
right: 66.666667%;
|
||||||
|
}
|
||||||
|
.pull-md-9 {
|
||||||
|
right: 75%;
|
||||||
|
}
|
||||||
|
.pull-md-10 {
|
||||||
|
right: 83.333333%;
|
||||||
|
}
|
||||||
|
.pull-md-11 {
|
||||||
|
right: 91.666667%;
|
||||||
|
}
|
||||||
|
.pull-md-12 {
|
||||||
|
right: 100%;
|
||||||
|
}
|
||||||
|
.push-md-0 {
|
||||||
|
left: auto;
|
||||||
|
}
|
||||||
|
.push-md-1 {
|
||||||
|
left: 8.333333%;
|
||||||
|
}
|
||||||
|
.push-md-2 {
|
||||||
|
left: 16.666667%;
|
||||||
|
}
|
||||||
|
.push-md-3 {
|
||||||
|
left: 25%;
|
||||||
|
}
|
||||||
|
.push-md-4 {
|
||||||
|
left: 33.333333%;
|
||||||
|
}
|
||||||
|
.push-md-5 {
|
||||||
|
left: 41.666667%;
|
||||||
|
}
|
||||||
|
.push-md-6 {
|
||||||
|
left: 50%;
|
||||||
|
}
|
||||||
|
.push-md-7 {
|
||||||
|
left: 58.333333%;
|
||||||
|
}
|
||||||
|
.push-md-8 {
|
||||||
|
left: 66.666667%;
|
||||||
|
}
|
||||||
|
.push-md-9 {
|
||||||
|
left: 75%;
|
||||||
|
}
|
||||||
|
.push-md-10 {
|
||||||
|
left: 83.333333%;
|
||||||
|
}
|
||||||
|
.push-md-11 {
|
||||||
|
left: 91.666667%;
|
||||||
|
}
|
||||||
|
.push-md-12 {
|
||||||
|
left: 100%;
|
||||||
|
}
|
||||||
|
.offset-md-0 {
|
||||||
|
margin-left: 0%;
|
||||||
|
}
|
||||||
|
.offset-md-1 {
|
||||||
|
margin-left: 8.333333%;
|
||||||
|
}
|
||||||
|
.offset-md-2 {
|
||||||
|
margin-left: 16.666667%;
|
||||||
|
}
|
||||||
|
.offset-md-3 {
|
||||||
|
margin-left: 25%;
|
||||||
|
}
|
||||||
|
.offset-md-4 {
|
||||||
|
margin-left: 33.333333%;
|
||||||
|
}
|
||||||
|
.offset-md-5 {
|
||||||
|
margin-left: 41.666667%;
|
||||||
|
}
|
||||||
|
.offset-md-6 {
|
||||||
|
margin-left: 50%;
|
||||||
|
}
|
||||||
|
.offset-md-7 {
|
||||||
|
margin-left: 58.333333%;
|
||||||
|
}
|
||||||
|
.offset-md-8 {
|
||||||
|
margin-left: 66.666667%;
|
||||||
|
}
|
||||||
|
.offset-md-9 {
|
||||||
|
margin-left: 75%;
|
||||||
|
}
|
||||||
|
.offset-md-10 {
|
||||||
|
margin-left: 83.333333%;
|
||||||
|
}
|
||||||
|
.offset-md-11 {
|
||||||
|
margin-left: 91.666667%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 992px) {
|
||||||
|
.col-lg {
|
||||||
|
position: relative;
|
||||||
|
flex-basis: 0;
|
||||||
|
flex-grow: 1;
|
||||||
|
max-width: 100%;
|
||||||
|
min-height: 1px;
|
||||||
|
padding-right: 15px;
|
||||||
|
padding-left: 15px;
|
||||||
|
}
|
||||||
|
.col-lg-1 {
|
||||||
|
flex: 0 0 8.333333%;
|
||||||
|
max-width: 8.333333%;
|
||||||
|
}
|
||||||
|
.col-lg-2 {
|
||||||
|
flex: 0 0 16.666667%;
|
||||||
|
max-width: 16.666667%;
|
||||||
|
}
|
||||||
|
.col-lg-3 {
|
||||||
|
flex: 0 0 25%;
|
||||||
|
max-width: 25%;
|
||||||
|
}
|
||||||
|
.col-lg-4 {
|
||||||
|
flex: 0 0 33.333333%;
|
||||||
|
max-width: 33.333333%;
|
||||||
|
}
|
||||||
|
.col-lg-5 {
|
||||||
|
flex: 0 0 41.666667%;
|
||||||
|
max-width: 41.666667%;
|
||||||
|
}
|
||||||
|
.col-lg-6 {
|
||||||
|
flex: 0 0 50%;
|
||||||
|
max-width: 50%;
|
||||||
|
}
|
||||||
|
.col-lg-7 {
|
||||||
|
flex: 0 0 58.333333%;
|
||||||
|
max-width: 58.333333%;
|
||||||
|
}
|
||||||
|
.col-lg-8 {
|
||||||
|
flex: 0 0 66.666667%;
|
||||||
|
max-width: 66.666667%;
|
||||||
|
}
|
||||||
|
.col-lg-9 {
|
||||||
|
flex: 0 0 75%;
|
||||||
|
max-width: 75%;
|
||||||
|
}
|
||||||
|
.col-lg-10 {
|
||||||
|
flex: 0 0 83.333333%;
|
||||||
|
max-width: 83.333333%;
|
||||||
|
}
|
||||||
|
.col-lg-11 {
|
||||||
|
flex: 0 0 91.666667%;
|
||||||
|
max-width: 91.666667%;
|
||||||
|
}
|
||||||
|
.col-lg-12 {
|
||||||
|
flex: 0 0 100%;
|
||||||
|
max-width: 100%;
|
||||||
|
}
|
||||||
|
.pull-lg-0 {
|
||||||
|
right: auto;
|
||||||
|
}
|
||||||
|
.pull-lg-1 {
|
||||||
|
right: 8.333333%;
|
||||||
|
}
|
||||||
|
.pull-lg-2 {
|
||||||
|
right: 16.666667%;
|
||||||
|
}
|
||||||
|
.pull-lg-3 {
|
||||||
|
right: 25%;
|
||||||
|
}
|
||||||
|
.pull-lg-4 {
|
||||||
|
right: 33.333333%;
|
||||||
|
}
|
||||||
|
.pull-lg-5 {
|
||||||
|
right: 41.666667%;
|
||||||
|
}
|
||||||
|
.pull-lg-6 {
|
||||||
|
right: 50%;
|
||||||
|
}
|
||||||
|
.pull-lg-7 {
|
||||||
|
right: 58.333333%;
|
||||||
|
}
|
||||||
|
.pull-lg-8 {
|
||||||
|
right: 66.666667%;
|
||||||
|
}
|
||||||
|
.pull-lg-9 {
|
||||||
|
right: 75%;
|
||||||
|
}
|
||||||
|
.pull-lg-10 {
|
||||||
|
right: 83.333333%;
|
||||||
|
}
|
||||||
|
.pull-lg-11 {
|
||||||
|
right: 91.666667%;
|
||||||
|
}
|
||||||
|
.pull-lg-12 {
|
||||||
|
right: 100%;
|
||||||
|
}
|
||||||
|
.push-lg-0 {
|
||||||
|
left: auto;
|
||||||
|
}
|
||||||
|
.push-lg-1 {
|
||||||
|
left: 8.333333%;
|
||||||
|
}
|
||||||
|
.push-lg-2 {
|
||||||
|
left: 16.666667%;
|
||||||
|
}
|
||||||
|
.push-lg-3 {
|
||||||
|
left: 25%;
|
||||||
|
}
|
||||||
|
.push-lg-4 {
|
||||||
|
left: 33.333333%;
|
||||||
|
}
|
||||||
|
.push-lg-5 {
|
||||||
|
left: 41.666667%;
|
||||||
|
}
|
||||||
|
.push-lg-6 {
|
||||||
|
left: 50%;
|
||||||
|
}
|
||||||
|
.push-lg-7 {
|
||||||
|
left: 58.333333%;
|
||||||
|
}
|
||||||
|
.push-lg-8 {
|
||||||
|
left: 66.666667%;
|
||||||
|
}
|
||||||
|
.push-lg-9 {
|
||||||
|
left: 75%;
|
||||||
|
}
|
||||||
|
.push-lg-10 {
|
||||||
|
left: 83.333333%;
|
||||||
|
}
|
||||||
|
.push-lg-11 {
|
||||||
|
left: 91.666667%;
|
||||||
|
}
|
||||||
|
.push-lg-12 {
|
||||||
|
left: 100%;
|
||||||
|
}
|
||||||
|
.offset-lg-0 {
|
||||||
|
margin-left: 0%;
|
||||||
|
}
|
||||||
|
.offset-lg-1 {
|
||||||
|
margin-left: 8.333333%;
|
||||||
|
}
|
||||||
|
.offset-lg-2 {
|
||||||
|
margin-left: 16.666667%;
|
||||||
|
}
|
||||||
|
.offset-lg-3 {
|
||||||
|
margin-left: 25%;
|
||||||
|
}
|
||||||
|
.offset-lg-4 {
|
||||||
|
margin-left: 33.333333%;
|
||||||
|
}
|
||||||
|
.offset-lg-5 {
|
||||||
|
margin-left: 41.666667%;
|
||||||
|
}
|
||||||
|
.offset-lg-6 {
|
||||||
|
margin-left: 50%;
|
||||||
|
}
|
||||||
|
.offset-lg-7 {
|
||||||
|
margin-left: 58.333333%;
|
||||||
|
}
|
||||||
|
.offset-lg-8 {
|
||||||
|
margin-left: 66.666667%;
|
||||||
|
}
|
||||||
|
.offset-lg-9 {
|
||||||
|
margin-left: 75%;
|
||||||
|
}
|
||||||
|
.offset-lg-10 {
|
||||||
|
margin-left: 83.333333%;
|
||||||
|
}
|
||||||
|
.offset-lg-11 {
|
||||||
|
margin-left: 91.666667%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 1200px) {
|
||||||
|
.col-xl {
|
||||||
|
position: relative;
|
||||||
|
flex-basis: 0;
|
||||||
|
flex-grow: 1;
|
||||||
|
max-width: 100%;
|
||||||
|
min-height: 1px;
|
||||||
|
padding-right: 15px;
|
||||||
|
padding-left: 15px;
|
||||||
|
}
|
||||||
|
.col-xl-1 {
|
||||||
|
flex: 0 0 8.333333%;
|
||||||
|
max-width: 8.333333%;
|
||||||
|
}
|
||||||
|
.col-xl-2 {
|
||||||
|
flex: 0 0 16.666667%;
|
||||||
|
max-width: 16.666667%;
|
||||||
|
}
|
||||||
|
.col-xl-3 {
|
||||||
|
flex: 0 0 25%;
|
||||||
|
max-width: 25%;
|
||||||
|
}
|
||||||
|
.col-xl-4 {
|
||||||
|
flex: 0 0 33.333333%;
|
||||||
|
max-width: 33.333333%;
|
||||||
|
}
|
||||||
|
.col-xl-5 {
|
||||||
|
flex: 0 0 41.666667%;
|
||||||
|
max-width: 41.666667%;
|
||||||
|
}
|
||||||
|
.col-xl-6 {
|
||||||
|
flex: 0 0 50%;
|
||||||
|
max-width: 50%;
|
||||||
|
}
|
||||||
|
.col-xl-7 {
|
||||||
|
flex: 0 0 58.333333%;
|
||||||
|
max-width: 58.333333%;
|
||||||
|
}
|
||||||
|
.col-xl-8 {
|
||||||
|
flex: 0 0 66.666667%;
|
||||||
|
max-width: 66.666667%;
|
||||||
|
}
|
||||||
|
.col-xl-9 {
|
||||||
|
flex: 0 0 75%;
|
||||||
|
max-width: 75%;
|
||||||
|
}
|
||||||
|
.col-xl-10 {
|
||||||
|
flex: 0 0 83.333333%;
|
||||||
|
max-width: 83.333333%;
|
||||||
|
}
|
||||||
|
.col-xl-11 {
|
||||||
|
flex: 0 0 91.666667%;
|
||||||
|
max-width: 91.666667%;
|
||||||
|
}
|
||||||
|
.col-xl-12 {
|
||||||
|
flex: 0 0 100%;
|
||||||
|
max-width: 100%;
|
||||||
|
}
|
||||||
|
.pull-xl-0 {
|
||||||
|
right: auto;
|
||||||
|
}
|
||||||
|
.pull-xl-1 {
|
||||||
|
right: 8.333333%;
|
||||||
|
}
|
||||||
|
.pull-xl-2 {
|
||||||
|
right: 16.666667%;
|
||||||
|
}
|
||||||
|
.pull-xl-3 {
|
||||||
|
right: 25%;
|
||||||
|
}
|
||||||
|
.pull-xl-4 {
|
||||||
|
right: 33.333333%;
|
||||||
|
}
|
||||||
|
.pull-xl-5 {
|
||||||
|
right: 41.666667%;
|
||||||
|
}
|
||||||
|
.pull-xl-6 {
|
||||||
|
right: 50%;
|
||||||
|
}
|
||||||
|
.pull-xl-7 {
|
||||||
|
right: 58.333333%;
|
||||||
|
}
|
||||||
|
.pull-xl-8 {
|
||||||
|
right: 66.666667%;
|
||||||
|
}
|
||||||
|
.pull-xl-9 {
|
||||||
|
right: 75%;
|
||||||
|
}
|
||||||
|
.pull-xl-10 {
|
||||||
|
right: 83.333333%;
|
||||||
|
}
|
||||||
|
.pull-xl-11 {
|
||||||
|
right: 91.666667%;
|
||||||
|
}
|
||||||
|
.pull-xl-12 {
|
||||||
|
right: 100%;
|
||||||
|
}
|
||||||
|
.push-xl-0 {
|
||||||
|
left: auto;
|
||||||
|
}
|
||||||
|
.push-xl-1 {
|
||||||
|
left: 8.333333%;
|
||||||
|
}
|
||||||
|
.push-xl-2 {
|
||||||
|
left: 16.666667%;
|
||||||
|
}
|
||||||
|
.push-xl-3 {
|
||||||
|
left: 25%;
|
||||||
|
}
|
||||||
|
.push-xl-4 {
|
||||||
|
left: 33.333333%;
|
||||||
|
}
|
||||||
|
.push-xl-5 {
|
||||||
|
left: 41.666667%;
|
||||||
|
}
|
||||||
|
.push-xl-6 {
|
||||||
|
left: 50%;
|
||||||
|
}
|
||||||
|
.push-xl-7 {
|
||||||
|
left: 58.333333%;
|
||||||
|
}
|
||||||
|
.push-xl-8 {
|
||||||
|
left: 66.666667%;
|
||||||
|
}
|
||||||
|
.push-xl-9 {
|
||||||
|
left: 75%;
|
||||||
|
}
|
||||||
|
.push-xl-10 {
|
||||||
|
left: 83.333333%;
|
||||||
|
}
|
||||||
|
.push-xl-11 {
|
||||||
|
left: 91.666667%;
|
||||||
|
}
|
||||||
|
.push-xl-12 {
|
||||||
|
left: 100%;
|
||||||
|
}
|
||||||
|
.offset-xl-0 {
|
||||||
|
margin-left: 0%;
|
||||||
|
}
|
||||||
|
.offset-xl-1 {
|
||||||
|
margin-left: 8.333333%;
|
||||||
|
}
|
||||||
|
.offset-xl-2 {
|
||||||
|
margin-left: 16.666667%;
|
||||||
|
}
|
||||||
|
.offset-xl-3 {
|
||||||
|
margin-left: 25%;
|
||||||
|
}
|
||||||
|
.offset-xl-4 {
|
||||||
|
margin-left: 33.333333%;
|
||||||
|
}
|
||||||
|
.offset-xl-5 {
|
||||||
|
margin-left: 41.666667%;
|
||||||
|
}
|
||||||
|
.offset-xl-6 {
|
||||||
|
margin-left: 50%;
|
||||||
|
}
|
||||||
|
.offset-xl-7 {
|
||||||
|
margin-left: 58.333333%;
|
||||||
|
}
|
||||||
|
.offset-xl-8 {
|
||||||
|
margin-left: 66.666667%;
|
||||||
|
}
|
||||||
|
.offset-xl-9 {
|
||||||
|
margin-left: 75%;
|
||||||
|
}
|
||||||
|
.offset-xl-10 {
|
||||||
|
margin-left: 83.333333%;
|
||||||
|
}
|
||||||
|
.offset-xl-11 {
|
||||||
|
margin-left: 91.666667%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*# sourceMappingURL=docs-flexbox.min.css.map */
|
17
docs/assets/css/docs-flexbox.min.css.map
Normal file
1546
docs/assets/css/docs.min.css
vendored
Before Width: | Height: | Size: 176 KiB After Width: | Height: | Size: 174 KiB |
Before Width: | Height: | Size: 3.0 KiB After Width: | Height: | Size: 2.9 KiB |
Before Width: | Height: | Size: 3.2 KiB After Width: | Height: | Size: 3.2 KiB |
Before Width: | Height: | Size: 11 KiB After Width: | Height: | Size: 11 KiB |
9
docs/assets/js/docs.min.js
vendored
@ -33,7 +33,7 @@
|
|||||||
$('.bd-example-indeterminate [type="checkbox"]').prop('indeterminate', true)
|
$('.bd-example-indeterminate [type="checkbox"]').prop('indeterminate', true)
|
||||||
|
|
||||||
// Disable empty links in docs examples
|
// Disable empty links in docs examples
|
||||||
$('.bd-example [href=#]').click(function (e) {
|
$('.bd-example [href="#"]').click(function (e) {
|
||||||
e.preventDefault()
|
e.preventDefault()
|
||||||
})
|
})
|
||||||
|
|
||||||
|
8
docs/assets/js/vendor/jquery.min.js
vendored
@ -1,6 +1,6 @@
|
|||||||
// clipboard.js
|
// clipboard.js
|
||||||
//
|
//
|
||||||
// Flash-based `Copy` buttons for code snippets.
|
// JS-based `Copy` buttons for code snippets.
|
||||||
|
|
||||||
.bd-clipboard {
|
.bd-clipboard {
|
||||||
position: relative;
|
position: relative;
|
||||||
|
@ -3,6 +3,9 @@
|
|||||||
//
|
//
|
||||||
|
|
||||||
.bd-navbar {
|
.bd-navbar {
|
||||||
|
padding-right: 0;
|
||||||
|
padding-left: 0;
|
||||||
|
|
||||||
.navbar-nav {
|
.navbar-nav {
|
||||||
.nav-link {
|
.nav-link {
|
||||||
color: $bd-graphite-light;
|
color: $bd-graphite-light;
|
||||||
|
@ -36,6 +36,7 @@
|
|||||||
margin-top: .25rem;
|
margin-top: .25rem;
|
||||||
}
|
}
|
||||||
.responsive-utilities-test .col-xs-6 {
|
.responsive-utilities-test .col-xs-6 {
|
||||||
|
margin-top: .5rem;
|
||||||
margin-bottom: .5rem;
|
margin-bottom: .5rem;
|
||||||
}
|
}
|
||||||
.responsive-utilities-test span {
|
.responsive-utilities-test span {
|
||||||
|
33
docs/assets/scss/flex-grid.scss
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
// Bootstrap flexbox grid for our docs page
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// Variables
|
||||||
|
//
|
||||||
|
|
||||||
|
@import "custom";
|
||||||
|
@import "variables";
|
||||||
|
|
||||||
|
// Override for flexbox mode
|
||||||
|
$enable-flex: true;
|
||||||
|
|
||||||
|
//
|
||||||
|
// Grid mixins
|
||||||
|
//
|
||||||
|
|
||||||
|
@import "mixins/clearfix";
|
||||||
|
@import "mixins/breakpoints";
|
||||||
|
@import "mixins/grid-framework";
|
||||||
|
@import "mixins/grid";
|
||||||
|
|
||||||
|
//
|
||||||
|
// Utilities for flex alignment
|
||||||
|
//
|
||||||
|
|
||||||
|
@import "utilities/flex";
|
||||||
|
|
||||||
|
//
|
||||||
|
// Generate the grid class
|
||||||
|
//
|
||||||
|
|
||||||
|
@import "grid";
|
@ -14,6 +14,7 @@ See also:
|
|||||||
|
|
||||||
* [Chromium issue 536263: [meta] Issues affecting Bootstrap](https://code.google.com/p/chromium/issues/detail?id=536263)
|
* [Chromium issue 536263: [meta] Issues affecting Bootstrap](https://code.google.com/p/chromium/issues/detail?id=536263)
|
||||||
* [Mozilla bug 1230801: Fix the issues that affect Bootstrap](https://bugzilla.mozilla.org/show_bug.cgi?id=1230801)
|
* [Mozilla bug 1230801: Fix the issues that affect Bootstrap](https://bugzilla.mozilla.org/show_bug.cgi?id=1230801)
|
||||||
|
* [WebKit bug 159753: [meta] Issues affecting Bootstrap](https://bugs.webkit.org/show_bug.cgi?id=159753)
|
||||||
* [jQuery's browser bug workarounds](https://docs.google.com/document/d/1LPaPA30bLUB_publLIMF0RlhdnPx_ePXm7oW02iiT6o)
|
* [jQuery's browser bug workarounds](https://docs.google.com/document/d/1LPaPA30bLUB_publLIMF0RlhdnPx_ePXm7oW02iiT6o)
|
||||||
|
|
||||||
<div class="table-responsive">
|
<div class="table-responsive">
|
||||||
@ -38,3 +39,32 @@ See also:
|
|||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
# Most wanted features
|
||||||
|
|
||||||
|
There are several features specified in Web standards which would allow us to make Bootstrap more robust, elegant, or performant, but aren't yet implemented in certain browsers, thus preventing us from taking advantage of them.
|
||||||
|
|
||||||
|
We publicly list these "most wanted" feature requests here, in the hopes of expediting the process of getting them implemented.
|
||||||
|
|
||||||
|
<div class="table-responsive">
|
||||||
|
<table class="bd-browser-bugs table table-bordered table-hover">
|
||||||
|
<thead>
|
||||||
|
<tr>
|
||||||
|
<th>Browser(s)</th>
|
||||||
|
<th>Summary of feature</th>
|
||||||
|
<th>Upstream issue(s)</th>
|
||||||
|
<th>Bootstrap issue(s)</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody>
|
||||||
|
{% for feat in site.data.browser-features %}
|
||||||
|
<tr>
|
||||||
|
<td>{{ feat.browser }}</td>
|
||||||
|
<td>{{ feat.summary | markdownify | bugify }}</td>
|
||||||
|
<td>{{ feat.upstream_bug | bugify }}</td>
|
||||||
|
<td>{{ feat.origin | bugify }}</td>
|
||||||
|
</tr>
|
||||||
|
{% endfor %}
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
@ -158,9 +158,9 @@ Options can be passed via data attributes or JavaScript. For data attributes, ap
|
|||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>pause</td>
|
<td>pause</td>
|
||||||
<td>string</td>
|
<td>string | null</td>
|
||||||
<td>"hover"</td>
|
<td>"hover"</td>
|
||||||
<td>Pauses the cycling of the carousel on mouseenter and resumes the cycling of the carousel on mouseleave.</td>
|
<td>If set to <code>"hover"</code>, pauses the cycling of the carousel on <code>mouseenter</code> and resumes the cycling of the carousel on <code>mouseleave</code>. If set to <code>null</code>, hovering over the carousel won't pause it.</td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>wrap</td>
|
<td>wrap</td>
|
||||||
|
@ -4,7 +4,7 @@ title: Collapse
|
|||||||
group: components
|
group: components
|
||||||
---
|
---
|
||||||
|
|
||||||
The Bootstrap collapse plugin allows you to toggle content on your pages with a bit of JavaScript and some classes. Flexible plugin that utilizes a handful of classes (from the **required [transitions plugin]({{ site.baseurl }}/components/transitions/)**) for easy toggle behavior.
|
The Bootstrap collapse plugin allows you to toggle content on your pages with a few classes thanks to some helpful JavaScript.
|
||||||
|
|
||||||
## Contents
|
## Contents
|
||||||
|
|
||||||
|
@ -49,25 +49,25 @@ Hover over the links below to see tooltips:
|
|||||||
Four options are available: top, right, bottom, and left aligned.
|
Four options are available: top, right, bottom, and left aligned.
|
||||||
|
|
||||||
<div class="bd-example bd-example-tooltip-static">
|
<div class="bd-example bd-example-tooltip-static">
|
||||||
<div class="tooltip top" role="tooltip">
|
<div class="tooltip tooltip-top" role="tooltip">
|
||||||
<div class="tooltip-arrow"></div>
|
<div class="tooltip-arrow"></div>
|
||||||
<div class="tooltip-inner">
|
<div class="tooltip-inner">
|
||||||
Tooltip on the top
|
Tooltip on the top
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="tooltip right" role="tooltip">
|
<div class="tooltip tooltip-right" role="tooltip">
|
||||||
<div class="tooltip-arrow"></div>
|
<div class="tooltip-arrow"></div>
|
||||||
<div class="tooltip-inner">
|
<div class="tooltip-inner">
|
||||||
Tooltip on the right
|
Tooltip on the right
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="tooltip bottom" role="tooltip">
|
<div class="tooltip tooltip-bottom" role="tooltip">
|
||||||
<div class="tooltip-arrow"></div>
|
<div class="tooltip-arrow"></div>
|
||||||
<div class="tooltip-inner">
|
<div class="tooltip-inner">
|
||||||
Tooltip on the bottom
|
Tooltip on the bottom
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="tooltip left" role="tooltip">
|
<div class="tooltip tooltip-left" role="tooltip">
|
||||||
<div class="tooltip-arrow"></div>
|
<div class="tooltip-arrow"></div>
|
||||||
<div class="tooltip-inner">
|
<div class="tooltip-inner">
|
||||||
Tooltip on the left
|
Tooltip on the left
|
||||||
@ -128,7 +128,7 @@ You should only add tooltips to HTML elements that are traditionally keyboard-fo
|
|||||||
<a href="#" data-toggle="tooltip" title="Some tooltip text!">Hover over me</a>
|
<a href="#" data-toggle="tooltip" title="Some tooltip text!">Hover over me</a>
|
||||||
|
|
||||||
<!-- Generated markup by the plugin -->
|
<!-- Generated markup by the plugin -->
|
||||||
<div class="tooltip top" role="tooltip">
|
<div class="tooltip tooltip-top" role="tooltip">
|
||||||
<div class="tooltip-arrow"></div>
|
<div class="tooltip-arrow"></div>
|
||||||
<div class="tooltip-inner">
|
<div class="tooltip-inner">
|
||||||
Some tooltip text!
|
Some tooltip text!
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
/*!
|
/*!
|
||||||
* Bootstrap v4.0.0-alpha.2 (http://getbootstrap.com)
|
* Bootstrap v4.0.0-alpha.3 (http://getbootstrap.com)
|
||||||
|
* Copyright 2011-2016 The Bootstrap Authors
|
||||||
* Copyright 2011-2016 Twitter, Inc.
|
* Copyright 2011-2016 Twitter, Inc.
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
*/
|
*/
|
||||||
@ -320,7 +321,7 @@ html {
|
|||||||
}
|
}
|
||||||
|
|
||||||
body {
|
body {
|
||||||
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", Arial, sans-serif;
|
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
|
||||||
font-size: 1rem;
|
font-size: 1rem;
|
||||||
line-height: 1.5;
|
line-height: 1.5;
|
||||||
color: #373a3c;
|
color: #373a3c;
|
||||||
@ -391,22 +392,21 @@ a:focus, a:hover {
|
|||||||
}
|
}
|
||||||
|
|
||||||
a:focus {
|
a:focus {
|
||||||
outline: thin dotted;
|
|
||||||
outline: 5px auto -webkit-focus-ring-color;
|
outline: 5px auto -webkit-focus-ring-color;
|
||||||
outline-offset: -2px;
|
outline-offset: -2px;
|
||||||
}
|
}
|
||||||
|
|
||||||
a:not([href]) {
|
a:not([href]):not([tabindex]) {
|
||||||
color: inherit;
|
color: inherit;
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
a:not([href]):focus, a:not([href]):hover {
|
a:not([href]):not([tabindex]):focus, a:not([href]):not([tabindex]):hover {
|
||||||
color: inherit;
|
color: inherit;
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
a:not([href]):focus {
|
a:not([href]):not([tabindex]):focus {
|
||||||
outline: none;
|
outline: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -811,110 +811,69 @@ pre code {
|
|||||||
clear: both;
|
clear: both;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-1 {
|
.col-xs-1, .col-xs-2, .col-xs-3, .col-xs-4, .col-xs-5, .col-xs-6, .col-xs-7, .col-xs-8, .col-xs-9, .col-xs-10, .col-xs-11, .col-xs-12, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12, .col-xl-1, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-10, .col-xl-11, .col-xl-12 {
|
||||||
position: relative;
|
position: relative;
|
||||||
min-height: 1px;
|
min-height: 1px;
|
||||||
padding-right: 15px;
|
padding-right: 15px;
|
||||||
padding-left: 15px;
|
padding-left: 15px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.col-xs-1 {
|
||||||
float: left;
|
float: left;
|
||||||
width: 8.333333%;
|
width: 8.333333%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-2 {
|
.col-xs-2 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 16.666667%;
|
width: 16.666667%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-3 {
|
.col-xs-3 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 25%;
|
width: 25%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-4 {
|
.col-xs-4 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 33.333333%;
|
width: 33.333333%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-5 {
|
.col-xs-5 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 41.666667%;
|
width: 41.666667%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-6 {
|
.col-xs-6 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 50%;
|
width: 50%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-7 {
|
.col-xs-7 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 58.333333%;
|
width: 58.333333%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-8 {
|
.col-xs-8 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 66.666667%;
|
width: 66.666667%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-9 {
|
.col-xs-9 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 75%;
|
width: 75%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-10 {
|
.col-xs-10 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 83.333333%;
|
width: 83.333333%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-11 {
|
.col-xs-11 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 91.666667%;
|
width: 91.666667%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.col-xs-12 {
|
.col-xs-12 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
@ -1069,98 +1028,50 @@ pre code {
|
|||||||
|
|
||||||
@media (min-width: 544px) {
|
@media (min-width: 544px) {
|
||||||
.col-sm-1 {
|
.col-sm-1 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 8.333333%;
|
width: 8.333333%;
|
||||||
}
|
}
|
||||||
.col-sm-2 {
|
.col-sm-2 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 16.666667%;
|
width: 16.666667%;
|
||||||
}
|
}
|
||||||
.col-sm-3 {
|
.col-sm-3 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 25%;
|
width: 25%;
|
||||||
}
|
}
|
||||||
.col-sm-4 {
|
.col-sm-4 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 33.333333%;
|
width: 33.333333%;
|
||||||
}
|
}
|
||||||
.col-sm-5 {
|
.col-sm-5 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 41.666667%;
|
width: 41.666667%;
|
||||||
}
|
}
|
||||||
.col-sm-6 {
|
.col-sm-6 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 50%;
|
width: 50%;
|
||||||
}
|
}
|
||||||
.col-sm-7 {
|
.col-sm-7 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 58.333333%;
|
width: 58.333333%;
|
||||||
}
|
}
|
||||||
.col-sm-8 {
|
.col-sm-8 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 66.666667%;
|
width: 66.666667%;
|
||||||
}
|
}
|
||||||
.col-sm-9 {
|
.col-sm-9 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 75%;
|
width: 75%;
|
||||||
}
|
}
|
||||||
.col-sm-10 {
|
.col-sm-10 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 83.333333%;
|
width: 83.333333%;
|
||||||
}
|
}
|
||||||
.col-sm-11 {
|
.col-sm-11 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 91.666667%;
|
width: 91.666667%;
|
||||||
}
|
}
|
||||||
.col-sm-12 {
|
.col-sm-12 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
@ -1282,98 +1193,50 @@ pre code {
|
|||||||
|
|
||||||
@media (min-width: 768px) {
|
@media (min-width: 768px) {
|
||||||
.col-md-1 {
|
.col-md-1 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 8.333333%;
|
width: 8.333333%;
|
||||||
}
|
}
|
||||||
.col-md-2 {
|
.col-md-2 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 16.666667%;
|
width: 16.666667%;
|
||||||
}
|
}
|
||||||
.col-md-3 {
|
.col-md-3 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 25%;
|
width: 25%;
|
||||||
}
|
}
|
||||||
.col-md-4 {
|
.col-md-4 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 33.333333%;
|
width: 33.333333%;
|
||||||
}
|
}
|
||||||
.col-md-5 {
|
.col-md-5 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 41.666667%;
|
width: 41.666667%;
|
||||||
}
|
}
|
||||||
.col-md-6 {
|
.col-md-6 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 50%;
|
width: 50%;
|
||||||
}
|
}
|
||||||
.col-md-7 {
|
.col-md-7 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 58.333333%;
|
width: 58.333333%;
|
||||||
}
|
}
|
||||||
.col-md-8 {
|
.col-md-8 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 66.666667%;
|
width: 66.666667%;
|
||||||
}
|
}
|
||||||
.col-md-9 {
|
.col-md-9 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 75%;
|
width: 75%;
|
||||||
}
|
}
|
||||||
.col-md-10 {
|
.col-md-10 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 83.333333%;
|
width: 83.333333%;
|
||||||
}
|
}
|
||||||
.col-md-11 {
|
.col-md-11 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 91.666667%;
|
width: 91.666667%;
|
||||||
}
|
}
|
||||||
.col-md-12 {
|
.col-md-12 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
@ -1495,98 +1358,50 @@ pre code {
|
|||||||
|
|
||||||
@media (min-width: 992px) {
|
@media (min-width: 992px) {
|
||||||
.col-lg-1 {
|
.col-lg-1 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 8.333333%;
|
width: 8.333333%;
|
||||||
}
|
}
|
||||||
.col-lg-2 {
|
.col-lg-2 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 16.666667%;
|
width: 16.666667%;
|
||||||
}
|
}
|
||||||
.col-lg-3 {
|
.col-lg-3 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 25%;
|
width: 25%;
|
||||||
}
|
}
|
||||||
.col-lg-4 {
|
.col-lg-4 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 33.333333%;
|
width: 33.333333%;
|
||||||
}
|
}
|
||||||
.col-lg-5 {
|
.col-lg-5 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 41.666667%;
|
width: 41.666667%;
|
||||||
}
|
}
|
||||||
.col-lg-6 {
|
.col-lg-6 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 50%;
|
width: 50%;
|
||||||
}
|
}
|
||||||
.col-lg-7 {
|
.col-lg-7 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 58.333333%;
|
width: 58.333333%;
|
||||||
}
|
}
|
||||||
.col-lg-8 {
|
.col-lg-8 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 66.666667%;
|
width: 66.666667%;
|
||||||
}
|
}
|
||||||
.col-lg-9 {
|
.col-lg-9 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 75%;
|
width: 75%;
|
||||||
}
|
}
|
||||||
.col-lg-10 {
|
.col-lg-10 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 83.333333%;
|
width: 83.333333%;
|
||||||
}
|
}
|
||||||
.col-lg-11 {
|
.col-lg-11 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 91.666667%;
|
width: 91.666667%;
|
||||||
}
|
}
|
||||||
.col-lg-12 {
|
.col-lg-12 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
@ -1708,98 +1523,50 @@ pre code {
|
|||||||
|
|
||||||
@media (min-width: 1200px) {
|
@media (min-width: 1200px) {
|
||||||
.col-xl-1 {
|
.col-xl-1 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 8.333333%;
|
width: 8.333333%;
|
||||||
}
|
}
|
||||||
.col-xl-2 {
|
.col-xl-2 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 16.666667%;
|
width: 16.666667%;
|
||||||
}
|
}
|
||||||
.col-xl-3 {
|
.col-xl-3 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 25%;
|
width: 25%;
|
||||||
}
|
}
|
||||||
.col-xl-4 {
|
.col-xl-4 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 33.333333%;
|
width: 33.333333%;
|
||||||
}
|
}
|
||||||
.col-xl-5 {
|
.col-xl-5 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 41.666667%;
|
width: 41.666667%;
|
||||||
}
|
}
|
||||||
.col-xl-6 {
|
.col-xl-6 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 50%;
|
width: 50%;
|
||||||
}
|
}
|
||||||
.col-xl-7 {
|
.col-xl-7 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 58.333333%;
|
width: 58.333333%;
|
||||||
}
|
}
|
||||||
.col-xl-8 {
|
.col-xl-8 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 66.666667%;
|
width: 66.666667%;
|
||||||
}
|
}
|
||||||
.col-xl-9 {
|
.col-xl-9 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 75%;
|
width: 75%;
|
||||||
}
|
}
|
||||||
.col-xl-10 {
|
.col-xl-10 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 83.333333%;
|
width: 83.333333%;
|
||||||
}
|
}
|
||||||
.col-xl-11 {
|
.col-xl-11 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 91.666667%;
|
width: 91.666667%;
|
||||||
}
|
}
|
||||||
.col-xl-12 {
|
.col-xl-12 {
|
||||||
position: relative;
|
|
||||||
min-height: 1px;
|
|
||||||
padding-right: 15px;
|
|
||||||
padding-left: 15px;
|
|
||||||
float: left;
|
float: left;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
@ -2491,7 +2258,6 @@ select.form-control-lg:not([size]):not([multiple]), .input-group-lg > select.for
|
|||||||
}
|
}
|
||||||
|
|
||||||
.btn:focus, .btn.focus, .btn:active:focus, .btn:active.focus, .btn.active:focus, .btn.active.focus {
|
.btn:focus, .btn.focus, .btn:active:focus, .btn:active.focus, .btn.active:focus, .btn.active.focus {
|
||||||
outline: thin dotted;
|
|
||||||
outline: 5px auto -webkit-focus-ring-color;
|
outline: 5px auto -webkit-focus-ring-color;
|
||||||
outline-offset: -2px;
|
outline-offset: -2px;
|
||||||
}
|
}
|
||||||
@ -4046,24 +3812,6 @@ input[type="button"].btn-block {
|
|||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
@media (min-width: 544px) {
|
|
||||||
.navbar-toggleable-xs {
|
|
||||||
display: block !important;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (min-width: 768px) {
|
|
||||||
.navbar-toggleable-sm {
|
|
||||||
display: block !important;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (min-width: 992px) {
|
|
||||||
.navbar-toggleable-md {
|
|
||||||
display: block !important;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.navbar-nav .nav-item {
|
.navbar-nav .nav-item {
|
||||||
float: left;
|
float: left;
|
||||||
}
|
}
|
||||||
@ -4148,6 +3896,63 @@ input[type="button"].btn-block {
|
|||||||
background-color: rgba(255, 255, 255, 0.075);
|
background-color: rgba(255, 255, 255, 0.075);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.navbar-toggleable-xs::after {
|
||||||
|
content: "";
|
||||||
|
display: table;
|
||||||
|
clear: both;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 543px) {
|
||||||
|
.navbar-toggleable-xs .navbar-nav .nav-item {
|
||||||
|
float: none;
|
||||||
|
margin-left: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 544px) {
|
||||||
|
.navbar-toggleable-xs {
|
||||||
|
display: block !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.navbar-toggleable-sm::after {
|
||||||
|
content: "";
|
||||||
|
display: table;
|
||||||
|
clear: both;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 767px) {
|
||||||
|
.navbar-toggleable-sm .navbar-nav .nav-item {
|
||||||
|
float: none;
|
||||||
|
margin-left: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 768px) {
|
||||||
|
.navbar-toggleable-sm {
|
||||||
|
display: block !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.navbar-toggleable-md::after {
|
||||||
|
content: "";
|
||||||
|
display: table;
|
||||||
|
clear: both;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 991px) {
|
||||||
|
.navbar-toggleable-md .navbar-nav .nav-item {
|
||||||
|
float: none;
|
||||||
|
margin-left: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (min-width: 992px) {
|
||||||
|
.navbar-toggleable-md {
|
||||||
|
display: block !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
.card {
|
.card {
|
||||||
position: relative;
|
position: relative;
|
||||||
display: block;
|
display: block;
|
||||||
@ -5454,7 +5259,7 @@ button.close {
|
|||||||
position: absolute;
|
position: absolute;
|
||||||
z-index: 1070;
|
z-index: 1070;
|
||||||
display: block;
|
display: block;
|
||||||
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", Arial, sans-serif;
|
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
|
||||||
font-style: normal;
|
font-style: normal;
|
||||||
font-weight: normal;
|
font-weight: normal;
|
||||||
letter-spacing: normal;
|
letter-spacing: normal;
|
||||||
@ -5554,7 +5359,7 @@ button.close {
|
|||||||
display: block;
|
display: block;
|
||||||
max-width: 276px;
|
max-width: 276px;
|
||||||
padding: 1px;
|
padding: 1px;
|
||||||
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", Arial, sans-serif;
|
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
|
||||||
font-style: normal;
|
font-style: normal;
|
||||||
font-weight: normal;
|
font-weight: normal;
|
||||||
letter-spacing: normal;
|
letter-spacing: normal;
|
||||||
@ -5666,6 +5471,10 @@ button.close {
|
|||||||
border-radius: 0.2375rem 0.2375rem 0 0;
|
border-radius: 0.2375rem 0.2375rem 0 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.popover-title:empty {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
.popover-content {
|
.popover-content {
|
||||||
padding: 9px 14px;
|
padding: 9px 14px;
|
||||||
}
|
}
|
||||||
@ -5921,10 +5730,6 @@ button.close {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.bg-inverse {
|
|
||||||
background-color: #373a3c;
|
|
||||||
}
|
|
||||||
|
|
||||||
.bg-faded {
|
.bg-faded {
|
||||||
background-color: #f7f7f9;
|
background-color: #f7f7f9;
|
||||||
}
|
}
|
||||||
@ -5974,6 +5779,15 @@ a.bg-danger:focus, a.bg-danger:hover {
|
|||||||
background-color: #c9302c !important;
|
background-color: #c9302c !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.bg-inverse {
|
||||||
|
color: #fff !important;
|
||||||
|
background-color: #373a3c !important;
|
||||||
|
}
|
||||||
|
|
||||||
|
a.bg-inverse:focus, a.bg-inverse:hover {
|
||||||
|
background-color: #1f2021 !important;
|
||||||
|
}
|
||||||
|
|
||||||
.clearfix::after {
|
.clearfix::after {
|
||||||
content: "";
|
content: "";
|
||||||
display: table;
|
display: table;
|
||||||
|
2
docs/dist/css/bootstrap.css.map
vendored
5
docs/dist/css/bootstrap.min.css
vendored
2
docs/dist/css/bootstrap.min.css.map
vendored
@ -1,6 +1,6 @@
|
|||||||
/*!
|
/*!
|
||||||
* Bootstrap v4.0.0-alpha.2 (http://getbootstrap.com)
|
* Bootstrap v4.0.0-alpha.3 (http://getbootstrap.com)
|
||||||
* Copyright 2011-2016 Twitter, Inc.
|
* Copyright 2011-2016 The Bootstrap Authors (https://github.com/twbs/bootstrap/graphs/contributors)
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -10,8 +10,8 @@ if (typeof jQuery === 'undefined') {
|
|||||||
|
|
||||||
+function ($) {
|
+function ($) {
|
||||||
var version = $.fn.jquery.split(' ')[0].split('.')
|
var version = $.fn.jquery.split(' ')[0].split('.')
|
||||||
if ((version[0] < 2 && version[1] < 9) || (version[0] == 1 && version[1] == 9 && version[2] < 1) || (version[0] >= 3)) {
|
if ((version[0] < 2 && version[1] < 9) || (version[0] == 1 && version[1] == 9 && version[2] < 1) || (version[0] >= 4)) {
|
||||||
throw new Error('Bootstrap\'s JavaScript requires at least jQuery v1.9.1 but less than v3.0.0')
|
throw new Error('Bootstrap\'s JavaScript requires at least jQuery v1.9.1 but less than v4.0.0')
|
||||||
}
|
}
|
||||||
}(jQuery);
|
}(jQuery);
|
||||||
|
|
||||||
@ -20,7 +20,7 @@ if (typeof jQuery === 'undefined') {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): util.js
|
* Bootstrap (v4.0.0-alpha.3): util.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -45,6 +45,8 @@ var Util = (function ($) {
|
|||||||
|
|
||||||
var transition = false;
|
var transition = false;
|
||||||
|
|
||||||
|
var MAX_UID = 1000000;
|
||||||
|
|
||||||
var TransitionEndEvent = {
|
var TransitionEndEvent = {
|
||||||
WebkitTransition: 'webkitTransitionEnd',
|
WebkitTransition: 'webkitTransitionEnd',
|
||||||
MozTransition: 'transitionend',
|
MozTransition: 'transitionend',
|
||||||
@ -67,8 +69,9 @@ var Util = (function ($) {
|
|||||||
delegateType: transition.end,
|
delegateType: transition.end,
|
||||||
handle: function handle(event) {
|
handle: function handle(event) {
|
||||||
if ($(event.target).is(this)) {
|
if ($(event.target).is(this)) {
|
||||||
return event.handleObj.handler.apply(this, arguments);
|
return event.handleObj.handler.apply(this, arguments); // eslint-disable-line prefer-rest-params
|
||||||
}
|
}
|
||||||
|
return undefined;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
@ -130,7 +133,7 @@ var Util = (function ($) {
|
|||||||
getUID: function getUID(prefix) {
|
getUID: function getUID(prefix) {
|
||||||
do {
|
do {
|
||||||
/* eslint-disable no-bitwise */
|
/* eslint-disable no-bitwise */
|
||||||
prefix += ~ ~(Math.random() * 1000000); // "~~" acts like a faster Math.floor() here
|
prefix += ~ ~(Math.random() * MAX_UID); // "~~" acts like a faster Math.floor() here
|
||||||
/* eslint-enable no-bitwise */
|
/* eslint-enable no-bitwise */
|
||||||
} while (document.getElementById(prefix));
|
} while (document.getElementById(prefix));
|
||||||
return prefix;
|
return prefix;
|
||||||
@ -187,7 +190,7 @@ var Util = (function ($) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): alert.js
|
* Bootstrap (v4.0.0-alpha.3): alert.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -201,7 +204,7 @@ var Alert = (function ($) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
var NAME = 'alert';
|
var NAME = 'alert';
|
||||||
var VERSION = '4.0.0-alpha.2';
|
var VERSION = '4.0.0-alpha.3';
|
||||||
var DATA_KEY = 'bs.alert';
|
var DATA_KEY = 'bs.alert';
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
var EVENT_KEY = '.' + DATA_KEY;
|
||||||
var DATA_API_KEY = '.data-api';
|
var DATA_API_KEY = '.data-api';
|
||||||
@ -373,7 +376,7 @@ var Alert = (function ($) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): button.js
|
* Bootstrap (v4.0.0-alpha.3): button.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -387,7 +390,7 @@ var Button = (function ($) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
var NAME = 'button';
|
var NAME = 'button';
|
||||||
var VERSION = '4.0.0-alpha.2';
|
var VERSION = '4.0.0-alpha.3';
|
||||||
var DATA_KEY = 'bs.button';
|
var DATA_KEY = 'bs.button';
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
var EVENT_KEY = '.' + DATA_KEY;
|
||||||
var DATA_API_KEY = '.data-api';
|
var DATA_API_KEY = '.data-api';
|
||||||
@ -541,7 +544,7 @@ var Button = (function ($) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): carousel.js
|
* Bootstrap (v4.0.0-alpha.3): carousel.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -555,12 +558,14 @@ var Carousel = (function ($) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
var NAME = 'carousel';
|
var NAME = 'carousel';
|
||||||
var VERSION = '4.0.0-alpha.2';
|
var VERSION = '4.0.0-alpha.3';
|
||||||
var DATA_KEY = 'bs.carousel';
|
var DATA_KEY = 'bs.carousel';
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
var EVENT_KEY = '.' + DATA_KEY;
|
||||||
var DATA_API_KEY = '.data-api';
|
var DATA_API_KEY = '.data-api';
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
||||||
var TRANSITION_DURATION = 600;
|
var TRANSITION_DURATION = 600;
|
||||||
|
var ARROW_LEFT_KEYCODE = 37; // KeyboardEvent.which value for left arrow key
|
||||||
|
var ARROW_RIGHT_KEYCODE = 39; // KeyboardEvent.which value for right arrow key
|
||||||
|
|
||||||
var Default = {
|
var Default = {
|
||||||
interval: 5000,
|
interval: 5000,
|
||||||
@ -776,10 +781,12 @@ var Carousel = (function ($) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
switch (event.which) {
|
switch (event.which) {
|
||||||
case 37:
|
case ARROW_LEFT_KEYCODE:
|
||||||
this.prev();break;
|
this.prev();
|
||||||
case 39:
|
break;
|
||||||
this.next();break;
|
case ARROW_RIGHT_KEYCODE:
|
||||||
|
this.next();
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1013,7 +1020,7 @@ var Carousel = (function ($) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): collapse.js
|
* Bootstrap (v4.0.0-alpha.3): collapse.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -1027,7 +1034,7 @@ var Collapse = (function ($) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
var NAME = 'collapse';
|
var NAME = 'collapse';
|
||||||
var VERSION = '4.0.0-alpha.2';
|
var VERSION = '4.0.0-alpha.3';
|
||||||
var DATA_KEY = 'bs.collapse';
|
var DATA_KEY = 'bs.collapse';
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
var EVENT_KEY = '.' + DATA_KEY;
|
||||||
var DATA_API_KEY = '.data-api';
|
var DATA_API_KEY = '.data-api';
|
||||||
@ -1371,7 +1378,7 @@ var Collapse = (function ($) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): dropdown.js
|
* Bootstrap (v4.0.0-alpha.3): dropdown.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -1385,11 +1392,15 @@ var Dropdown = (function ($) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
var NAME = 'dropdown';
|
var NAME = 'dropdown';
|
||||||
var VERSION = '4.0.0-alpha.2';
|
var VERSION = '4.0.0-alpha.3';
|
||||||
var DATA_KEY = 'bs.dropdown';
|
var DATA_KEY = 'bs.dropdown';
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
var EVENT_KEY = '.' + DATA_KEY;
|
||||||
var DATA_API_KEY = '.data-api';
|
var DATA_API_KEY = '.data-api';
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
||||||
|
var ESCAPE_KEYCODE = 27; // KeyboardEvent.which value for Escape (Esc) key
|
||||||
|
var ARROW_UP_KEYCODE = 38; // KeyboardEvent.which value for up arrow key
|
||||||
|
var ARROW_DOWN_KEYCODE = 40; // KeyboardEvent.which value for down arrow key
|
||||||
|
var RIGHT_MOUSE_BUTTON_WHICH = 3; // MouseEvent.which value for the right button (assuming a right-handed mouse)
|
||||||
|
|
||||||
var Event = {
|
var Event = {
|
||||||
HIDE: 'hide' + EVENT_KEY,
|
HIDE: 'hide' + EVENT_KEY,
|
||||||
@ -1524,7 +1535,7 @@ var Dropdown = (function ($) {
|
|||||||
}, {
|
}, {
|
||||||
key: '_clearMenus',
|
key: '_clearMenus',
|
||||||
value: function _clearMenus(event) {
|
value: function _clearMenus(event) {
|
||||||
if (event && event.which === 3) {
|
if (event && event.which === RIGHT_MOUSE_BUTTON_WHICH) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1587,9 +1598,9 @@ var Dropdown = (function ($) {
|
|||||||
var parent = Dropdown._getParentFromElement(this);
|
var parent = Dropdown._getParentFromElement(this);
|
||||||
var isActive = $(parent).hasClass(ClassName.OPEN);
|
var isActive = $(parent).hasClass(ClassName.OPEN);
|
||||||
|
|
||||||
if (!isActive && event.which !== 27 || isActive && event.which === 27) {
|
if (!isActive && event.which !== ESCAPE_KEYCODE || isActive && event.which === ESCAPE_KEYCODE) {
|
||||||
|
|
||||||
if (event.which === 27) {
|
if (event.which === ESCAPE_KEYCODE) {
|
||||||
var toggle = $(parent).find(Selector.DATA_TOGGLE)[0];
|
var toggle = $(parent).find(Selector.DATA_TOGGLE)[0];
|
||||||
$(toggle).trigger('focus');
|
$(toggle).trigger('focus');
|
||||||
}
|
}
|
||||||
@ -1610,12 +1621,12 @@ var Dropdown = (function ($) {
|
|||||||
|
|
||||||
var index = items.indexOf(event.target);
|
var index = items.indexOf(event.target);
|
||||||
|
|
||||||
if (event.which === 38 && index > 0) {
|
if (event.which === ARROW_UP_KEYCODE && index > 0) {
|
||||||
// up
|
// up
|
||||||
index--;
|
index--;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (event.which === 40 && index < items.length - 1) {
|
if (event.which === ARROW_DOWN_KEYCODE && index < items.length - 1) {
|
||||||
// down
|
// down
|
||||||
index++;
|
index++;
|
||||||
}
|
}
|
||||||
@ -1658,7 +1669,7 @@ var Dropdown = (function ($) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): modal.js
|
* Bootstrap (v4.0.0-alpha.3): modal.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -1672,13 +1683,14 @@ var Modal = (function ($) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
var NAME = 'modal';
|
var NAME = 'modal';
|
||||||
var VERSION = '4.0.0-alpha.2';
|
var VERSION = '4.0.0-alpha.3';
|
||||||
var DATA_KEY = 'bs.modal';
|
var DATA_KEY = 'bs.modal';
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
var EVENT_KEY = '.' + DATA_KEY;
|
||||||
var DATA_API_KEY = '.data-api';
|
var DATA_API_KEY = '.data-api';
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
||||||
var TRANSITION_DURATION = 300;
|
var TRANSITION_DURATION = 300;
|
||||||
var BACKDROP_TRANSITION_DURATION = 150;
|
var BACKDROP_TRANSITION_DURATION = 150;
|
||||||
|
var ESCAPE_KEYCODE = 27; // KeyboardEvent.which value for Escape (Esc) key
|
||||||
|
|
||||||
var Default = {
|
var Default = {
|
||||||
backdrop: true,
|
backdrop: true,
|
||||||
@ -1874,6 +1886,7 @@ var Modal = (function ($) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
this._element.style.display = 'block';
|
this._element.style.display = 'block';
|
||||||
|
this._element.removeAttribute('aria-hidden');
|
||||||
this._element.scrollTop = 0;
|
this._element.scrollTop = 0;
|
||||||
|
|
||||||
if (transition) {
|
if (transition) {
|
||||||
@ -1922,7 +1935,7 @@ var Modal = (function ($) {
|
|||||||
|
|
||||||
if (this._isShown && this._config.keyboard) {
|
if (this._isShown && this._config.keyboard) {
|
||||||
$(this._element).on(Event.KEYDOWN_DISMISS, function (event) {
|
$(this._element).on(Event.KEYDOWN_DISMISS, function (event) {
|
||||||
if (event.which === 27) {
|
if (event.which === ESCAPE_KEYCODE) {
|
||||||
_this10.hide();
|
_this10.hide();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@ -1945,6 +1958,7 @@ var Modal = (function ($) {
|
|||||||
var _this11 = this;
|
var _this11 = this;
|
||||||
|
|
||||||
this._element.style.display = 'none';
|
this._element.style.display = 'none';
|
||||||
|
this._element.setAttribute('aria-hidden', 'true');
|
||||||
this._showBackdrop(function () {
|
this._showBackdrop(function () {
|
||||||
$(document.body).removeClass(ClassName.OPEN);
|
$(document.body).removeClass(ClassName.OPEN);
|
||||||
_this11._resetAdjustments();
|
_this11._resetAdjustments();
|
||||||
@ -2050,7 +2064,7 @@ var Modal = (function ($) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (this._isBodyOverflowing && !isModalOverflowing) {
|
if (this._isBodyOverflowing && !isModalOverflowing) {
|
||||||
this._element.style.paddingRight = this._scrollbarWidth + 'px~';
|
this._element.style.paddingRight = this._scrollbarWidth + 'px';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}, {
|
}, {
|
||||||
@ -2182,7 +2196,7 @@ var Modal = (function ($) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): scrollspy.js
|
* Bootstrap (v4.0.0-alpha.3): scrollspy.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -2196,7 +2210,7 @@ var ScrollSpy = (function ($) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
var NAME = 'scrollspy';
|
var NAME = 'scrollspy';
|
||||||
var VERSION = '4.0.0-alpha.2';
|
var VERSION = '4.0.0-alpha.3';
|
||||||
var DATA_KEY = 'bs.scrollspy';
|
var DATA_KEY = 'bs.scrollspy';
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
var EVENT_KEY = '.' + DATA_KEY;
|
||||||
var DATA_API_KEY = '.data-api';
|
var DATA_API_KEY = '.data-api';
|
||||||
@ -2311,6 +2325,7 @@ var ScrollSpy = (function ($) {
|
|||||||
// todo (fat): remove sketch reliance on jQuery position/offset
|
// todo (fat): remove sketch reliance on jQuery position/offset
|
||||||
return [$(target)[offsetMethod]().top + offsetBase, targetSelector];
|
return [$(target)[offsetMethod]().top + offsetBase, targetSelector];
|
||||||
}
|
}
|
||||||
|
return null;
|
||||||
}).filter(function (item) {
|
}).filter(function (item) {
|
||||||
return item;
|
return item;
|
||||||
}).sort(function (a, b) {
|
}).sort(function (a, b) {
|
||||||
@ -2496,7 +2511,7 @@ var ScrollSpy = (function ($) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): tab.js
|
* Bootstrap (v4.0.0-alpha.3): tab.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -2510,7 +2525,7 @@ var Tab = (function ($) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
var NAME = 'tab';
|
var NAME = 'tab';
|
||||||
var VERSION = '4.0.0-alpha.2';
|
var VERSION = '4.0.0-alpha.3';
|
||||||
var DATA_KEY = 'bs.tab';
|
var DATA_KEY = 'bs.tab';
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
var EVENT_KEY = '.' + DATA_KEY;
|
||||||
var DATA_API_KEY = '.data-api';
|
var DATA_API_KEY = '.data-api';
|
||||||
@ -2755,7 +2770,7 @@ var Tab = (function ($) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): tooltip.js
|
* Bootstrap (v4.0.0-alpha.3): tooltip.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -2777,7 +2792,7 @@ var Tooltip = (function ($) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
var NAME = 'tooltip';
|
var NAME = 'tooltip';
|
||||||
var VERSION = '4.0.0-alpha.2';
|
var VERSION = '4.0.0-alpha.3';
|
||||||
var DATA_KEY = 'bs.tooltip';
|
var DATA_KEY = 'bs.tooltip';
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
var EVENT_KEY = '.' + DATA_KEY;
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
||||||
@ -3366,7 +3381,7 @@ var Tooltip = (function ($) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
* Bootstrap (v4.0.0-alpha.2): popover.js
|
* Bootstrap (v4.0.0-alpha.3): popover.js
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
||||||
* --------------------------------------------------------------------------
|
* --------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
@ -3380,7 +3395,7 @@ var Popover = (function ($) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
var NAME = 'popover';
|
var NAME = 'popover';
|
||||||
var VERSION = '4.0.0-alpha.2';
|
var VERSION = '4.0.0-alpha.3';
|
||||||
var DATA_KEY = 'bs.popover';
|
var DATA_KEY = 'bs.popover';
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
var EVENT_KEY = '.' + DATA_KEY;
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
||||||
|
8
docs/dist/js/bootstrap.min.js
vendored
12
docs/dist/js/npm.js
vendored
@ -1,12 +0,0 @@
|
|||||||
// This file is autogenerated via the `commonjs` Grunt task. You can require() this file in a CommonJS environment.
|
|
||||||
require('./umd/util.js')
|
|
||||||
require('./umd/alert.js')
|
|
||||||
require('./umd/button.js')
|
|
||||||
require('./umd/carousel.js')
|
|
||||||
require('./umd/collapse.js')
|
|
||||||
require('./umd/dropdown.js')
|
|
||||||
require('./umd/modal.js')
|
|
||||||
require('./umd/scrollspy.js')
|
|
||||||
require('./umd/tab.js')
|
|
||||||
require('./umd/tooltip.js')
|
|
||||||
require('./umd/popover.js')
|
|
211
docs/dist/js/umd/alert.js
vendored
@ -1,211 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module', './util'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module, require('./util'));
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod, global.Util);
|
|
||||||
global.alert = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module, _util) {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
|
||||||
|
|
||||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
|
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
|
||||||
|
|
||||||
var _Util = _interopRequireDefault(_util);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): alert.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Alert = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Constants
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var NAME = 'alert';
|
|
||||||
var VERSION = '4.0.0-alpha.2';
|
|
||||||
var DATA_KEY = 'bs.alert';
|
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
|
||||||
var DATA_API_KEY = '.data-api';
|
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
|
||||||
var TRANSITION_DURATION = 150;
|
|
||||||
|
|
||||||
var Selector = {
|
|
||||||
DISMISS: '[data-dismiss="alert"]'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Event = {
|
|
||||||
CLOSE: 'close' + EVENT_KEY,
|
|
||||||
CLOSED: 'closed' + EVENT_KEY,
|
|
||||||
CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY
|
|
||||||
};
|
|
||||||
|
|
||||||
var ClassName = {
|
|
||||||
ALERT: 'alert',
|
|
||||||
FADE: 'fade',
|
|
||||||
IN: 'in'
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Class Definition
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Alert = (function () {
|
|
||||||
function Alert(element) {
|
|
||||||
_classCallCheck(this, Alert);
|
|
||||||
|
|
||||||
this._element = element;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Data Api implementation
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
// getters
|
|
||||||
|
|
||||||
_createClass(Alert, [{
|
|
||||||
key: 'close',
|
|
||||||
|
|
||||||
// public
|
|
||||||
|
|
||||||
value: function close(element) {
|
|
||||||
element = element || this._element;
|
|
||||||
|
|
||||||
var rootElement = this._getRootElement(element);
|
|
||||||
var customEvent = this._triggerCloseEvent(rootElement);
|
|
||||||
|
|
||||||
if (customEvent.isDefaultPrevented()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._removeElement(rootElement);
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'dispose',
|
|
||||||
value: function dispose() {
|
|
||||||
$.removeData(this._element, DATA_KEY);
|
|
||||||
this._element = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// private
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: '_getRootElement',
|
|
||||||
value: function _getRootElement(element) {
|
|
||||||
var selector = _Util['default'].getSelectorFromElement(element);
|
|
||||||
var parent = false;
|
|
||||||
|
|
||||||
if (selector) {
|
|
||||||
parent = $(selector)[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!parent) {
|
|
||||||
parent = $(element).closest('.' + ClassName.ALERT)[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_triggerCloseEvent',
|
|
||||||
value: function _triggerCloseEvent(element) {
|
|
||||||
var closeEvent = $.Event(Event.CLOSE);
|
|
||||||
|
|
||||||
$(element).trigger(closeEvent);
|
|
||||||
return closeEvent;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_removeElement',
|
|
||||||
value: function _removeElement(element) {
|
|
||||||
$(element).removeClass(ClassName.IN);
|
|
||||||
|
|
||||||
if (!_Util['default'].supportsTransitionEnd() || !$(element).hasClass(ClassName.FADE)) {
|
|
||||||
this._destroyElement(element);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$(element).one(_Util['default'].TRANSITION_END, $.proxy(this._destroyElement, this, element)).emulateTransitionEnd(TRANSITION_DURATION);
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_destroyElement',
|
|
||||||
value: function _destroyElement(element) {
|
|
||||||
$(element).detach().trigger(Event.CLOSED).remove();
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
|
|
||||||
}], [{
|
|
||||||
key: '_jQueryInterface',
|
|
||||||
value: function _jQueryInterface(config) {
|
|
||||||
return this.each(function () {
|
|
||||||
var $element = $(this);
|
|
||||||
var data = $element.data(DATA_KEY);
|
|
||||||
|
|
||||||
if (!data) {
|
|
||||||
data = new Alert(this);
|
|
||||||
$element.data(DATA_KEY, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (config === 'close') {
|
|
||||||
data[config](this);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_handleDismiss',
|
|
||||||
value: function _handleDismiss(alertInstance) {
|
|
||||||
return function (event) {
|
|
||||||
if (event) {
|
|
||||||
event.preventDefault();
|
|
||||||
}
|
|
||||||
|
|
||||||
alertInstance.close(this);
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'VERSION',
|
|
||||||
get: function get() {
|
|
||||||
return VERSION;
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
return Alert;
|
|
||||||
})();
|
|
||||||
|
|
||||||
$(document).on(Event.CLICK_DATA_API, Selector.DISMISS, Alert._handleDismiss(new Alert()));
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* jQuery
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
$.fn[NAME] = Alert._jQueryInterface;
|
|
||||||
$.fn[NAME].Constructor = Alert;
|
|
||||||
$.fn[NAME].noConflict = function () {
|
|
||||||
$.fn[NAME] = JQUERY_NO_CONFLICT;
|
|
||||||
return Alert._jQueryInterface;
|
|
||||||
};
|
|
||||||
|
|
||||||
return Alert;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = Alert;
|
|
||||||
});
|
|
189
docs/dist/js/umd/button.js
vendored
@ -1,189 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module);
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod);
|
|
||||||
global.button = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module) {
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): button.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
|
||||||
|
|
||||||
var Button = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Constants
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var NAME = 'button';
|
|
||||||
var VERSION = '4.0.0-alpha.2';
|
|
||||||
var DATA_KEY = 'bs.button';
|
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
|
||||||
var DATA_API_KEY = '.data-api';
|
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
|
||||||
|
|
||||||
var ClassName = {
|
|
||||||
ACTIVE: 'active',
|
|
||||||
BUTTON: 'btn',
|
|
||||||
FOCUS: 'focus'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Selector = {
|
|
||||||
DATA_TOGGLE_CARROT: '[data-toggle^="button"]',
|
|
||||||
DATA_TOGGLE: '[data-toggle="buttons"]',
|
|
||||||
INPUT: 'input',
|
|
||||||
ACTIVE: '.active',
|
|
||||||
BUTTON: '.btn'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Event = {
|
|
||||||
CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY,
|
|
||||||
FOCUS_BLUR_DATA_API: 'focus' + EVENT_KEY + DATA_API_KEY + ' ' + ('blur' + EVENT_KEY + DATA_API_KEY)
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Class Definition
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Button = (function () {
|
|
||||||
function Button(element) {
|
|
||||||
_classCallCheck(this, Button);
|
|
||||||
|
|
||||||
this._element = element;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Data Api implementation
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
// getters
|
|
||||||
|
|
||||||
_createClass(Button, [{
|
|
||||||
key: 'toggle',
|
|
||||||
|
|
||||||
// public
|
|
||||||
|
|
||||||
value: function toggle() {
|
|
||||||
var triggerChangeEvent = true;
|
|
||||||
var rootElement = $(this._element).closest(Selector.DATA_TOGGLE)[0];
|
|
||||||
|
|
||||||
if (rootElement) {
|
|
||||||
var input = $(this._element).find(Selector.INPUT)[0];
|
|
||||||
|
|
||||||
if (input) {
|
|
||||||
if (input.type === 'radio') {
|
|
||||||
if (input.checked && $(this._element).hasClass(ClassName.ACTIVE)) {
|
|
||||||
triggerChangeEvent = false;
|
|
||||||
} else {
|
|
||||||
var activeElement = $(rootElement).find(Selector.ACTIVE)[0];
|
|
||||||
|
|
||||||
if (activeElement) {
|
|
||||||
$(activeElement).removeClass(ClassName.ACTIVE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (triggerChangeEvent) {
|
|
||||||
input.checked = !$(this._element).hasClass(ClassName.ACTIVE);
|
|
||||||
$(this._element).trigger('change');
|
|
||||||
}
|
|
||||||
|
|
||||||
input.focus();
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
this._element.setAttribute('aria-pressed', !$(this._element).hasClass(ClassName.ACTIVE));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (triggerChangeEvent) {
|
|
||||||
$(this._element).toggleClass(ClassName.ACTIVE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'dispose',
|
|
||||||
value: function dispose() {
|
|
||||||
$.removeData(this._element, DATA_KEY);
|
|
||||||
this._element = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
|
|
||||||
}], [{
|
|
||||||
key: '_jQueryInterface',
|
|
||||||
value: function _jQueryInterface(config) {
|
|
||||||
return this.each(function () {
|
|
||||||
var data = $(this).data(DATA_KEY);
|
|
||||||
|
|
||||||
if (!data) {
|
|
||||||
data = new Button(this);
|
|
||||||
$(this).data(DATA_KEY, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (config === 'toggle') {
|
|
||||||
data[config]();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'VERSION',
|
|
||||||
get: function get() {
|
|
||||||
return VERSION;
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
return Button;
|
|
||||||
})();
|
|
||||||
|
|
||||||
$(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE_CARROT, function (event) {
|
|
||||||
event.preventDefault();
|
|
||||||
|
|
||||||
var button = event.target;
|
|
||||||
|
|
||||||
if (!$(button).hasClass(ClassName.BUTTON)) {
|
|
||||||
button = $(button).closest(Selector.BUTTON);
|
|
||||||
}
|
|
||||||
|
|
||||||
Button._jQueryInterface.call($(button), 'toggle');
|
|
||||||
}).on(Event.FOCUS_BLUR_DATA_API, Selector.DATA_TOGGLE_CARROT, function (event) {
|
|
||||||
var button = $(event.target).closest(Selector.BUTTON)[0];
|
|
||||||
$(button).toggleClass(ClassName.FOCUS, /^focus(in)?$/.test(event.type));
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* jQuery
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
$.fn[NAME] = Button._jQueryInterface;
|
|
||||||
$.fn[NAME].Constructor = Button;
|
|
||||||
$.fn[NAME].noConflict = function () {
|
|
||||||
$.fn[NAME] = JQUERY_NO_CONFLICT;
|
|
||||||
return Button._jQueryInterface;
|
|
||||||
};
|
|
||||||
|
|
||||||
return Button;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = Button;
|
|
||||||
});
|
|
497
docs/dist/js/umd/carousel.js
vendored
@ -1,497 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module', './util'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module, require('./util'));
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod, global.Util);
|
|
||||||
global.carousel = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module, _util) {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
|
||||||
|
|
||||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
|
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
|
||||||
|
|
||||||
var _Util = _interopRequireDefault(_util);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): carousel.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Carousel = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Constants
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var NAME = 'carousel';
|
|
||||||
var VERSION = '4.0.0-alpha.2';
|
|
||||||
var DATA_KEY = 'bs.carousel';
|
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
|
||||||
var DATA_API_KEY = '.data-api';
|
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
|
||||||
var TRANSITION_DURATION = 600;
|
|
||||||
|
|
||||||
var Default = {
|
|
||||||
interval: 5000,
|
|
||||||
keyboard: true,
|
|
||||||
slide: false,
|
|
||||||
pause: 'hover',
|
|
||||||
wrap: true
|
|
||||||
};
|
|
||||||
|
|
||||||
var DefaultType = {
|
|
||||||
interval: '(number|boolean)',
|
|
||||||
keyboard: 'boolean',
|
|
||||||
slide: '(boolean|string)',
|
|
||||||
pause: '(string|boolean)',
|
|
||||||
wrap: 'boolean'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Direction = {
|
|
||||||
NEXT: 'next',
|
|
||||||
PREVIOUS: 'prev'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Event = {
|
|
||||||
SLIDE: 'slide' + EVENT_KEY,
|
|
||||||
SLID: 'slid' + EVENT_KEY,
|
|
||||||
KEYDOWN: 'keydown' + EVENT_KEY,
|
|
||||||
MOUSEENTER: 'mouseenter' + EVENT_KEY,
|
|
||||||
MOUSELEAVE: 'mouseleave' + EVENT_KEY,
|
|
||||||
LOAD_DATA_API: 'load' + EVENT_KEY + DATA_API_KEY,
|
|
||||||
CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY
|
|
||||||
};
|
|
||||||
|
|
||||||
var ClassName = {
|
|
||||||
CAROUSEL: 'carousel',
|
|
||||||
ACTIVE: 'active',
|
|
||||||
SLIDE: 'slide',
|
|
||||||
RIGHT: 'right',
|
|
||||||
LEFT: 'left',
|
|
||||||
ITEM: 'carousel-item'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Selector = {
|
|
||||||
ACTIVE: '.active',
|
|
||||||
ACTIVE_ITEM: '.active.carousel-item',
|
|
||||||
ITEM: '.carousel-item',
|
|
||||||
NEXT_PREV: '.next, .prev',
|
|
||||||
INDICATORS: '.carousel-indicators',
|
|
||||||
DATA_SLIDE: '[data-slide], [data-slide-to]',
|
|
||||||
DATA_RIDE: '[data-ride="carousel"]'
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Class Definition
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Carousel = (function () {
|
|
||||||
function Carousel(element, config) {
|
|
||||||
_classCallCheck(this, Carousel);
|
|
||||||
|
|
||||||
this._items = null;
|
|
||||||
this._interval = null;
|
|
||||||
this._activeElement = null;
|
|
||||||
|
|
||||||
this._isPaused = false;
|
|
||||||
this._isSliding = false;
|
|
||||||
|
|
||||||
this._config = this._getConfig(config);
|
|
||||||
this._element = $(element)[0];
|
|
||||||
this._indicatorsElement = $(this._element).find(Selector.INDICATORS)[0];
|
|
||||||
|
|
||||||
this._addEventListeners();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Data Api implementation
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
// getters
|
|
||||||
|
|
||||||
_createClass(Carousel, [{
|
|
||||||
key: 'next',
|
|
||||||
|
|
||||||
// public
|
|
||||||
|
|
||||||
value: function next() {
|
|
||||||
if (!this._isSliding) {
|
|
||||||
this._slide(Direction.NEXT);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'nextWhenVisible',
|
|
||||||
value: function nextWhenVisible() {
|
|
||||||
// Don't call next when the page isn't visible
|
|
||||||
if (!document.hidden) {
|
|
||||||
this.next();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'prev',
|
|
||||||
value: function prev() {
|
|
||||||
if (!this._isSliding) {
|
|
||||||
this._slide(Direction.PREVIOUS);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'pause',
|
|
||||||
value: function pause(event) {
|
|
||||||
if (!event) {
|
|
||||||
this._isPaused = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($(this._element).find(Selector.NEXT_PREV)[0] && _Util['default'].supportsTransitionEnd()) {
|
|
||||||
_Util['default'].triggerTransitionEnd(this._element);
|
|
||||||
this.cycle(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
clearInterval(this._interval);
|
|
||||||
this._interval = null;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'cycle',
|
|
||||||
value: function cycle(event) {
|
|
||||||
if (!event) {
|
|
||||||
this._isPaused = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._interval) {
|
|
||||||
clearInterval(this._interval);
|
|
||||||
this._interval = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._config.interval && !this._isPaused) {
|
|
||||||
this._interval = setInterval($.proxy(document.visibilityState ? this.nextWhenVisible : this.next, this), this._config.interval);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'to',
|
|
||||||
value: function to(index) {
|
|
||||||
var _this = this;
|
|
||||||
|
|
||||||
this._activeElement = $(this._element).find(Selector.ACTIVE_ITEM)[0];
|
|
||||||
|
|
||||||
var activeIndex = this._getItemIndex(this._activeElement);
|
|
||||||
|
|
||||||
if (index > this._items.length - 1 || index < 0) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._isSliding) {
|
|
||||||
$(this._element).one(Event.SLID, function () {
|
|
||||||
return _this.to(index);
|
|
||||||
});
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (activeIndex === index) {
|
|
||||||
this.pause();
|
|
||||||
this.cycle();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var direction = index > activeIndex ? Direction.NEXT : Direction.PREVIOUS;
|
|
||||||
|
|
||||||
this._slide(direction, this._items[index]);
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'dispose',
|
|
||||||
value: function dispose() {
|
|
||||||
$(this._element).off(EVENT_KEY);
|
|
||||||
$.removeData(this._element, DATA_KEY);
|
|
||||||
|
|
||||||
this._items = null;
|
|
||||||
this._config = null;
|
|
||||||
this._element = null;
|
|
||||||
this._interval = null;
|
|
||||||
this._isPaused = null;
|
|
||||||
this._isSliding = null;
|
|
||||||
this._activeElement = null;
|
|
||||||
this._indicatorsElement = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// private
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: '_getConfig',
|
|
||||||
value: function _getConfig(config) {
|
|
||||||
config = $.extend({}, Default, config);
|
|
||||||
_Util['default'].typeCheckConfig(NAME, config, DefaultType);
|
|
||||||
return config;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_addEventListeners',
|
|
||||||
value: function _addEventListeners() {
|
|
||||||
if (this._config.keyboard) {
|
|
||||||
$(this._element).on(Event.KEYDOWN, $.proxy(this._keydown, this));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._config.pause === 'hover' && !('ontouchstart' in document.documentElement)) {
|
|
||||||
$(this._element).on(Event.MOUSEENTER, $.proxy(this.pause, this)).on(Event.MOUSELEAVE, $.proxy(this.cycle, this));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_keydown',
|
|
||||||
value: function _keydown(event) {
|
|
||||||
event.preventDefault();
|
|
||||||
|
|
||||||
if (/input|textarea/i.test(event.target.tagName)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (event.which) {
|
|
||||||
case 37:
|
|
||||||
this.prev();break;
|
|
||||||
case 39:
|
|
||||||
this.next();break;
|
|
||||||
default:
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_getItemIndex',
|
|
||||||
value: function _getItemIndex(element) {
|
|
||||||
this._items = $.makeArray($(element).parent().find(Selector.ITEM));
|
|
||||||
return this._items.indexOf(element);
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_getItemByDirection',
|
|
||||||
value: function _getItemByDirection(direction, activeElement) {
|
|
||||||
var isNextDirection = direction === Direction.NEXT;
|
|
||||||
var isPrevDirection = direction === Direction.PREVIOUS;
|
|
||||||
var activeIndex = this._getItemIndex(activeElement);
|
|
||||||
var lastItemIndex = this._items.length - 1;
|
|
||||||
var isGoingToWrap = isPrevDirection && activeIndex === 0 || isNextDirection && activeIndex === lastItemIndex;
|
|
||||||
|
|
||||||
if (isGoingToWrap && !this._config.wrap) {
|
|
||||||
return activeElement;
|
|
||||||
}
|
|
||||||
|
|
||||||
var delta = direction === Direction.PREVIOUS ? -1 : 1;
|
|
||||||
var itemIndex = (activeIndex + delta) % this._items.length;
|
|
||||||
|
|
||||||
return itemIndex === -1 ? this._items[this._items.length - 1] : this._items[itemIndex];
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_triggerSlideEvent',
|
|
||||||
value: function _triggerSlideEvent(relatedTarget, directionalClassname) {
|
|
||||||
var slideEvent = $.Event(Event.SLIDE, {
|
|
||||||
relatedTarget: relatedTarget,
|
|
||||||
direction: directionalClassname
|
|
||||||
});
|
|
||||||
|
|
||||||
$(this._element).trigger(slideEvent);
|
|
||||||
|
|
||||||
return slideEvent;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_setActiveIndicatorElement',
|
|
||||||
value: function _setActiveIndicatorElement(element) {
|
|
||||||
if (this._indicatorsElement) {
|
|
||||||
$(this._indicatorsElement).find(Selector.ACTIVE).removeClass(ClassName.ACTIVE);
|
|
||||||
|
|
||||||
var nextIndicator = this._indicatorsElement.children[this._getItemIndex(element)];
|
|
||||||
|
|
||||||
if (nextIndicator) {
|
|
||||||
$(nextIndicator).addClass(ClassName.ACTIVE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_slide',
|
|
||||||
value: function _slide(direction, element) {
|
|
||||||
var _this2 = this;
|
|
||||||
|
|
||||||
var activeElement = $(this._element).find(Selector.ACTIVE_ITEM)[0];
|
|
||||||
var nextElement = element || activeElement && this._getItemByDirection(direction, activeElement);
|
|
||||||
|
|
||||||
var isCycling = Boolean(this._interval);
|
|
||||||
|
|
||||||
var directionalClassName = direction === Direction.NEXT ? ClassName.LEFT : ClassName.RIGHT;
|
|
||||||
|
|
||||||
if (nextElement && $(nextElement).hasClass(ClassName.ACTIVE)) {
|
|
||||||
this._isSliding = false;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var slideEvent = this._triggerSlideEvent(nextElement, directionalClassName);
|
|
||||||
if (slideEvent.isDefaultPrevented()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!activeElement || !nextElement) {
|
|
||||||
// some weirdness is happening, so we bail
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._isSliding = true;
|
|
||||||
|
|
||||||
if (isCycling) {
|
|
||||||
this.pause();
|
|
||||||
}
|
|
||||||
|
|
||||||
this._setActiveIndicatorElement(nextElement);
|
|
||||||
|
|
||||||
var slidEvent = $.Event(Event.SLID, {
|
|
||||||
relatedTarget: nextElement,
|
|
||||||
direction: directionalClassName
|
|
||||||
});
|
|
||||||
|
|
||||||
if (_Util['default'].supportsTransitionEnd() && $(this._element).hasClass(ClassName.SLIDE)) {
|
|
||||||
|
|
||||||
$(nextElement).addClass(direction);
|
|
||||||
|
|
||||||
_Util['default'].reflow(nextElement);
|
|
||||||
|
|
||||||
$(activeElement).addClass(directionalClassName);
|
|
||||||
$(nextElement).addClass(directionalClassName);
|
|
||||||
|
|
||||||
$(activeElement).one(_Util['default'].TRANSITION_END, function () {
|
|
||||||
$(nextElement).removeClass(directionalClassName).removeClass(direction);
|
|
||||||
|
|
||||||
$(nextElement).addClass(ClassName.ACTIVE);
|
|
||||||
|
|
||||||
$(activeElement).removeClass(ClassName.ACTIVE).removeClass(direction).removeClass(directionalClassName);
|
|
||||||
|
|
||||||
_this2._isSliding = false;
|
|
||||||
|
|
||||||
setTimeout(function () {
|
|
||||||
return $(_this2._element).trigger(slidEvent);
|
|
||||||
}, 0);
|
|
||||||
}).emulateTransitionEnd(TRANSITION_DURATION);
|
|
||||||
} else {
|
|
||||||
$(activeElement).removeClass(ClassName.ACTIVE);
|
|
||||||
$(nextElement).addClass(ClassName.ACTIVE);
|
|
||||||
|
|
||||||
this._isSliding = false;
|
|
||||||
$(this._element).trigger(slidEvent);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isCycling) {
|
|
||||||
this.cycle();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
|
|
||||||
}], [{
|
|
||||||
key: '_jQueryInterface',
|
|
||||||
value: function _jQueryInterface(config) {
|
|
||||||
return this.each(function () {
|
|
||||||
var data = $(this).data(DATA_KEY);
|
|
||||||
var _config = $.extend({}, Default, $(this).data());
|
|
||||||
|
|
||||||
if (typeof config === 'object') {
|
|
||||||
$.extend(_config, config);
|
|
||||||
}
|
|
||||||
|
|
||||||
var action = typeof config === 'string' ? config : _config.slide;
|
|
||||||
|
|
||||||
if (!data) {
|
|
||||||
data = new Carousel(this, _config);
|
|
||||||
$(this).data(DATA_KEY, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (typeof config === 'number') {
|
|
||||||
data.to(config);
|
|
||||||
} else if (typeof action === 'string') {
|
|
||||||
if (data[action] === undefined) {
|
|
||||||
throw new Error('No method named "' + action + '"');
|
|
||||||
}
|
|
||||||
data[action]();
|
|
||||||
} else if (_config.interval) {
|
|
||||||
data.pause();
|
|
||||||
data.cycle();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_dataApiClickHandler',
|
|
||||||
value: function _dataApiClickHandler(event) {
|
|
||||||
var selector = _Util['default'].getSelectorFromElement(this);
|
|
||||||
|
|
||||||
if (!selector) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var target = $(selector)[0];
|
|
||||||
|
|
||||||
if (!target || !$(target).hasClass(ClassName.CAROUSEL)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var config = $.extend({}, $(target).data(), $(this).data());
|
|
||||||
var slideIndex = this.getAttribute('data-slide-to');
|
|
||||||
|
|
||||||
if (slideIndex) {
|
|
||||||
config.interval = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
Carousel._jQueryInterface.call($(target), config);
|
|
||||||
|
|
||||||
if (slideIndex) {
|
|
||||||
$(target).data(DATA_KEY).to(slideIndex);
|
|
||||||
}
|
|
||||||
|
|
||||||
event.preventDefault();
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'VERSION',
|
|
||||||
get: function get() {
|
|
||||||
return VERSION;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'Default',
|
|
||||||
get: function get() {
|
|
||||||
return Default;
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
return Carousel;
|
|
||||||
})();
|
|
||||||
|
|
||||||
$(document).on(Event.CLICK_DATA_API, Selector.DATA_SLIDE, Carousel._dataApiClickHandler);
|
|
||||||
|
|
||||||
$(window).on(Event.LOAD_DATA_API, function () {
|
|
||||||
$(Selector.DATA_RIDE).each(function () {
|
|
||||||
var $carousel = $(this);
|
|
||||||
Carousel._jQueryInterface.call($carousel, $carousel.data());
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* jQuery
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
$.fn[NAME] = Carousel._jQueryInterface;
|
|
||||||
$.fn[NAME].Constructor = Carousel;
|
|
||||||
$.fn[NAME].noConflict = function () {
|
|
||||||
$.fn[NAME] = JQUERY_NO_CONFLICT;
|
|
||||||
return Carousel._jQueryInterface;
|
|
||||||
};
|
|
||||||
|
|
||||||
return Carousel;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = Carousel;
|
|
||||||
});
|
|
383
docs/dist/js/umd/collapse.js
vendored
@ -1,383 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module', './util'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module, require('./util'));
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod, global.Util);
|
|
||||||
global.collapse = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module, _util) {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
|
||||||
|
|
||||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
|
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
|
||||||
|
|
||||||
var _Util = _interopRequireDefault(_util);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): collapse.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Collapse = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Constants
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var NAME = 'collapse';
|
|
||||||
var VERSION = '4.0.0-alpha.2';
|
|
||||||
var DATA_KEY = 'bs.collapse';
|
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
|
||||||
var DATA_API_KEY = '.data-api';
|
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
|
||||||
var TRANSITION_DURATION = 600;
|
|
||||||
|
|
||||||
var Default = {
|
|
||||||
toggle: true,
|
|
||||||
parent: ''
|
|
||||||
};
|
|
||||||
|
|
||||||
var DefaultType = {
|
|
||||||
toggle: 'boolean',
|
|
||||||
parent: 'string'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Event = {
|
|
||||||
SHOW: 'show' + EVENT_KEY,
|
|
||||||
SHOWN: 'shown' + EVENT_KEY,
|
|
||||||
HIDE: 'hide' + EVENT_KEY,
|
|
||||||
HIDDEN: 'hidden' + EVENT_KEY,
|
|
||||||
CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY
|
|
||||||
};
|
|
||||||
|
|
||||||
var ClassName = {
|
|
||||||
IN: 'in',
|
|
||||||
COLLAPSE: 'collapse',
|
|
||||||
COLLAPSING: 'collapsing',
|
|
||||||
COLLAPSED: 'collapsed'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Dimension = {
|
|
||||||
WIDTH: 'width',
|
|
||||||
HEIGHT: 'height'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Selector = {
|
|
||||||
ACTIVES: '.panel > .in, .panel > .collapsing',
|
|
||||||
DATA_TOGGLE: '[data-toggle="collapse"]'
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Class Definition
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Collapse = (function () {
|
|
||||||
function Collapse(element, config) {
|
|
||||||
_classCallCheck(this, Collapse);
|
|
||||||
|
|
||||||
this._isTransitioning = false;
|
|
||||||
this._element = element;
|
|
||||||
this._config = this._getConfig(config);
|
|
||||||
this._triggerArray = $.makeArray($('[data-toggle="collapse"][href="#' + element.id + '"],' + ('[data-toggle="collapse"][data-target="#' + element.id + '"]')));
|
|
||||||
|
|
||||||
this._parent = this._config.parent ? this._getParent() : null;
|
|
||||||
|
|
||||||
if (!this._config.parent) {
|
|
||||||
this._addAriaAndCollapsedClass(this._element, this._triggerArray);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._config.toggle) {
|
|
||||||
this.toggle();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Data Api implementation
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
// getters
|
|
||||||
|
|
||||||
_createClass(Collapse, [{
|
|
||||||
key: 'toggle',
|
|
||||||
|
|
||||||
// public
|
|
||||||
|
|
||||||
value: function toggle() {
|
|
||||||
if ($(this._element).hasClass(ClassName.IN)) {
|
|
||||||
this.hide();
|
|
||||||
} else {
|
|
||||||
this.show();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'show',
|
|
||||||
value: function show() {
|
|
||||||
var _this = this;
|
|
||||||
|
|
||||||
if (this._isTransitioning || $(this._element).hasClass(ClassName.IN)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var actives = undefined;
|
|
||||||
var activesData = undefined;
|
|
||||||
|
|
||||||
if (this._parent) {
|
|
||||||
actives = $.makeArray($(Selector.ACTIVES));
|
|
||||||
if (!actives.length) {
|
|
||||||
actives = null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (actives) {
|
|
||||||
activesData = $(actives).data(DATA_KEY);
|
|
||||||
if (activesData && activesData._isTransitioning) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var startEvent = $.Event(Event.SHOW);
|
|
||||||
$(this._element).trigger(startEvent);
|
|
||||||
if (startEvent.isDefaultPrevented()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (actives) {
|
|
||||||
Collapse._jQueryInterface.call($(actives), 'hide');
|
|
||||||
if (!activesData) {
|
|
||||||
$(actives).data(DATA_KEY, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var dimension = this._getDimension();
|
|
||||||
|
|
||||||
$(this._element).removeClass(ClassName.COLLAPSE).addClass(ClassName.COLLAPSING);
|
|
||||||
|
|
||||||
this._element.style[dimension] = 0;
|
|
||||||
this._element.setAttribute('aria-expanded', true);
|
|
||||||
|
|
||||||
if (this._triggerArray.length) {
|
|
||||||
$(this._triggerArray).removeClass(ClassName.COLLAPSED).attr('aria-expanded', true);
|
|
||||||
}
|
|
||||||
|
|
||||||
this.setTransitioning(true);
|
|
||||||
|
|
||||||
var complete = function complete() {
|
|
||||||
$(_this._element).removeClass(ClassName.COLLAPSING).addClass(ClassName.COLLAPSE).addClass(ClassName.IN);
|
|
||||||
|
|
||||||
_this._element.style[dimension] = '';
|
|
||||||
|
|
||||||
_this.setTransitioning(false);
|
|
||||||
|
|
||||||
$(_this._element).trigger(Event.SHOWN);
|
|
||||||
};
|
|
||||||
|
|
||||||
if (!_Util['default'].supportsTransitionEnd()) {
|
|
||||||
complete();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var capitalizedDimension = dimension[0].toUpperCase() + dimension.slice(1);
|
|
||||||
var scrollSize = 'scroll' + capitalizedDimension;
|
|
||||||
|
|
||||||
$(this._element).one(_Util['default'].TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION);
|
|
||||||
|
|
||||||
this._element.style[dimension] = this._element[scrollSize] + 'px';
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'hide',
|
|
||||||
value: function hide() {
|
|
||||||
var _this2 = this;
|
|
||||||
|
|
||||||
if (this._isTransitioning || !$(this._element).hasClass(ClassName.IN)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var startEvent = $.Event(Event.HIDE);
|
|
||||||
$(this._element).trigger(startEvent);
|
|
||||||
if (startEvent.isDefaultPrevented()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var dimension = this._getDimension();
|
|
||||||
var offsetDimension = dimension === Dimension.WIDTH ? 'offsetWidth' : 'offsetHeight';
|
|
||||||
|
|
||||||
this._element.style[dimension] = this._element[offsetDimension] + 'px';
|
|
||||||
|
|
||||||
_Util['default'].reflow(this._element);
|
|
||||||
|
|
||||||
$(this._element).addClass(ClassName.COLLAPSING).removeClass(ClassName.COLLAPSE).removeClass(ClassName.IN);
|
|
||||||
|
|
||||||
this._element.setAttribute('aria-expanded', false);
|
|
||||||
|
|
||||||
if (this._triggerArray.length) {
|
|
||||||
$(this._triggerArray).addClass(ClassName.COLLAPSED).attr('aria-expanded', false);
|
|
||||||
}
|
|
||||||
|
|
||||||
this.setTransitioning(true);
|
|
||||||
|
|
||||||
var complete = function complete() {
|
|
||||||
_this2.setTransitioning(false);
|
|
||||||
$(_this2._element).removeClass(ClassName.COLLAPSING).addClass(ClassName.COLLAPSE).trigger(Event.HIDDEN);
|
|
||||||
};
|
|
||||||
|
|
||||||
this._element.style[dimension] = 0;
|
|
||||||
|
|
||||||
if (!_Util['default'].supportsTransitionEnd()) {
|
|
||||||
complete();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$(this._element).one(_Util['default'].TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION);
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'setTransitioning',
|
|
||||||
value: function setTransitioning(isTransitioning) {
|
|
||||||
this._isTransitioning = isTransitioning;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'dispose',
|
|
||||||
value: function dispose() {
|
|
||||||
$.removeData(this._element, DATA_KEY);
|
|
||||||
|
|
||||||
this._config = null;
|
|
||||||
this._parent = null;
|
|
||||||
this._element = null;
|
|
||||||
this._triggerArray = null;
|
|
||||||
this._isTransitioning = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// private
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: '_getConfig',
|
|
||||||
value: function _getConfig(config) {
|
|
||||||
config = $.extend({}, Default, config);
|
|
||||||
config.toggle = Boolean(config.toggle); // coerce string values
|
|
||||||
_Util['default'].typeCheckConfig(NAME, config, DefaultType);
|
|
||||||
return config;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_getDimension',
|
|
||||||
value: function _getDimension() {
|
|
||||||
var hasWidth = $(this._element).hasClass(Dimension.WIDTH);
|
|
||||||
return hasWidth ? Dimension.WIDTH : Dimension.HEIGHT;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_getParent',
|
|
||||||
value: function _getParent() {
|
|
||||||
var _this3 = this;
|
|
||||||
|
|
||||||
var parent = $(this._config.parent)[0];
|
|
||||||
var selector = '[data-toggle="collapse"][data-parent="' + this._config.parent + '"]';
|
|
||||||
|
|
||||||
$(parent).find(selector).each(function (i, element) {
|
|
||||||
_this3._addAriaAndCollapsedClass(Collapse._getTargetFromElement(element), [element]);
|
|
||||||
});
|
|
||||||
|
|
||||||
return parent;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_addAriaAndCollapsedClass',
|
|
||||||
value: function _addAriaAndCollapsedClass(element, triggerArray) {
|
|
||||||
if (element) {
|
|
||||||
var isOpen = $(element).hasClass(ClassName.IN);
|
|
||||||
element.setAttribute('aria-expanded', isOpen);
|
|
||||||
|
|
||||||
if (triggerArray.length) {
|
|
||||||
$(triggerArray).toggleClass(ClassName.COLLAPSED, !isOpen).attr('aria-expanded', isOpen);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
|
|
||||||
}], [{
|
|
||||||
key: '_getTargetFromElement',
|
|
||||||
value: function _getTargetFromElement(element) {
|
|
||||||
var selector = _Util['default'].getSelectorFromElement(element);
|
|
||||||
return selector ? $(selector)[0] : null;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_jQueryInterface',
|
|
||||||
value: function _jQueryInterface(config) {
|
|
||||||
return this.each(function () {
|
|
||||||
var $this = $(this);
|
|
||||||
var data = $this.data(DATA_KEY);
|
|
||||||
var _config = $.extend({}, Default, $this.data(), typeof config === 'object' && config);
|
|
||||||
|
|
||||||
if (!data && _config.toggle && /show|hide/.test(config)) {
|
|
||||||
_config.toggle = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!data) {
|
|
||||||
data = new Collapse(this, _config);
|
|
||||||
$this.data(DATA_KEY, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (typeof config === 'string') {
|
|
||||||
if (data[config] === undefined) {
|
|
||||||
throw new Error('No method named "' + config + '"');
|
|
||||||
}
|
|
||||||
data[config]();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'VERSION',
|
|
||||||
get: function get() {
|
|
||||||
return VERSION;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'Default',
|
|
||||||
get: function get() {
|
|
||||||
return Default;
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
return Collapse;
|
|
||||||
})();
|
|
||||||
|
|
||||||
$(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE, function (event) {
|
|
||||||
event.preventDefault();
|
|
||||||
|
|
||||||
var target = Collapse._getTargetFromElement(this);
|
|
||||||
var data = $(target).data(DATA_KEY);
|
|
||||||
var config = data ? 'toggle' : $(this).data();
|
|
||||||
|
|
||||||
Collapse._jQueryInterface.call($(target), config);
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* jQuery
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
$.fn[NAME] = Collapse._jQueryInterface;
|
|
||||||
$.fn[NAME].Constructor = Collapse;
|
|
||||||
$.fn[NAME].noConflict = function () {
|
|
||||||
$.fn[NAME] = JQUERY_NO_CONFLICT;
|
|
||||||
return Collapse._jQueryInterface;
|
|
||||||
};
|
|
||||||
|
|
||||||
return Collapse;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = Collapse;
|
|
||||||
});
|
|
312
docs/dist/js/umd/dropdown.js
vendored
@ -1,312 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module', './util'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module, require('./util'));
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod, global.Util);
|
|
||||||
global.dropdown = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module, _util) {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
|
||||||
|
|
||||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
|
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
|
||||||
|
|
||||||
var _Util = _interopRequireDefault(_util);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): dropdown.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Dropdown = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Constants
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var NAME = 'dropdown';
|
|
||||||
var VERSION = '4.0.0-alpha.2';
|
|
||||||
var DATA_KEY = 'bs.dropdown';
|
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
|
||||||
var DATA_API_KEY = '.data-api';
|
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
|
||||||
|
|
||||||
var Event = {
|
|
||||||
HIDE: 'hide' + EVENT_KEY,
|
|
||||||
HIDDEN: 'hidden' + EVENT_KEY,
|
|
||||||
SHOW: 'show' + EVENT_KEY,
|
|
||||||
SHOWN: 'shown' + EVENT_KEY,
|
|
||||||
CLICK: 'click' + EVENT_KEY,
|
|
||||||
CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY,
|
|
||||||
KEYDOWN_DATA_API: 'keydown' + EVENT_KEY + DATA_API_KEY
|
|
||||||
};
|
|
||||||
|
|
||||||
var ClassName = {
|
|
||||||
BACKDROP: 'dropdown-backdrop',
|
|
||||||
DISABLED: 'disabled',
|
|
||||||
OPEN: 'open'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Selector = {
|
|
||||||
BACKDROP: '.dropdown-backdrop',
|
|
||||||
DATA_TOGGLE: '[data-toggle="dropdown"]',
|
|
||||||
FORM_CHILD: '.dropdown form',
|
|
||||||
ROLE_MENU: '[role="menu"]',
|
|
||||||
ROLE_LISTBOX: '[role="listbox"]',
|
|
||||||
NAVBAR_NAV: '.navbar-nav',
|
|
||||||
VISIBLE_ITEMS: '[role="menu"] li:not(.disabled) a, ' + '[role="listbox"] li:not(.disabled) a'
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Class Definition
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Dropdown = (function () {
|
|
||||||
function Dropdown(element) {
|
|
||||||
_classCallCheck(this, Dropdown);
|
|
||||||
|
|
||||||
this._element = element;
|
|
||||||
|
|
||||||
this._addEventListeners();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Data Api implementation
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
// getters
|
|
||||||
|
|
||||||
_createClass(Dropdown, [{
|
|
||||||
key: 'toggle',
|
|
||||||
|
|
||||||
// public
|
|
||||||
|
|
||||||
value: function toggle() {
|
|
||||||
if (this.disabled || $(this).hasClass(ClassName.DISABLED)) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
var parent = Dropdown._getParentFromElement(this);
|
|
||||||
var isActive = $(parent).hasClass(ClassName.OPEN);
|
|
||||||
|
|
||||||
Dropdown._clearMenus();
|
|
||||||
|
|
||||||
if (isActive) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ('ontouchstart' in document.documentElement && !$(parent).closest(Selector.NAVBAR_NAV).length) {
|
|
||||||
|
|
||||||
// if mobile we use a backdrop because click events don't delegate
|
|
||||||
var dropdown = document.createElement('div');
|
|
||||||
dropdown.className = ClassName.BACKDROP;
|
|
||||||
$(dropdown).insertBefore(this);
|
|
||||||
$(dropdown).on('click', Dropdown._clearMenus);
|
|
||||||
}
|
|
||||||
|
|
||||||
var relatedTarget = { relatedTarget: this };
|
|
||||||
var showEvent = $.Event(Event.SHOW, relatedTarget);
|
|
||||||
|
|
||||||
$(parent).trigger(showEvent);
|
|
||||||
|
|
||||||
if (showEvent.isDefaultPrevented()) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
this.focus();
|
|
||||||
this.setAttribute('aria-expanded', 'true');
|
|
||||||
|
|
||||||
$(parent).toggleClass(ClassName.OPEN);
|
|
||||||
$(parent).trigger($.Event(Event.SHOWN, relatedTarget));
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'dispose',
|
|
||||||
value: function dispose() {
|
|
||||||
$.removeData(this._element, DATA_KEY);
|
|
||||||
$(this._element).off(EVENT_KEY);
|
|
||||||
this._element = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// private
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: '_addEventListeners',
|
|
||||||
value: function _addEventListeners() {
|
|
||||||
$(this._element).on(Event.CLICK, this.toggle);
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
|
|
||||||
}], [{
|
|
||||||
key: '_jQueryInterface',
|
|
||||||
value: function _jQueryInterface(config) {
|
|
||||||
return this.each(function () {
|
|
||||||
var data = $(this).data(DATA_KEY);
|
|
||||||
|
|
||||||
if (!data) {
|
|
||||||
$(this).data(DATA_KEY, data = new Dropdown(this));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (typeof config === 'string') {
|
|
||||||
if (data[config] === undefined) {
|
|
||||||
throw new Error('No method named "' + config + '"');
|
|
||||||
}
|
|
||||||
data[config].call(this);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_clearMenus',
|
|
||||||
value: function _clearMenus(event) {
|
|
||||||
if (event && event.which === 3) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var backdrop = $(Selector.BACKDROP)[0];
|
|
||||||
if (backdrop) {
|
|
||||||
backdrop.parentNode.removeChild(backdrop);
|
|
||||||
}
|
|
||||||
|
|
||||||
var toggles = $.makeArray($(Selector.DATA_TOGGLE));
|
|
||||||
|
|
||||||
for (var i = 0; i < toggles.length; i++) {
|
|
||||||
var _parent = Dropdown._getParentFromElement(toggles[i]);
|
|
||||||
var relatedTarget = { relatedTarget: toggles[i] };
|
|
||||||
|
|
||||||
if (!$(_parent).hasClass(ClassName.OPEN)) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (event && event.type === 'click' && /input|textarea/i.test(event.target.tagName) && $.contains(_parent, event.target)) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
var hideEvent = $.Event(Event.HIDE, relatedTarget);
|
|
||||||
$(_parent).trigger(hideEvent);
|
|
||||||
if (hideEvent.isDefaultPrevented()) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
toggles[i].setAttribute('aria-expanded', 'false');
|
|
||||||
|
|
||||||
$(_parent).removeClass(ClassName.OPEN).trigger($.Event(Event.HIDDEN, relatedTarget));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_getParentFromElement',
|
|
||||||
value: function _getParentFromElement(element) {
|
|
||||||
var parent = undefined;
|
|
||||||
var selector = _Util['default'].getSelectorFromElement(element);
|
|
||||||
|
|
||||||
if (selector) {
|
|
||||||
parent = $(selector)[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
return parent || element.parentNode;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_dataApiKeydownHandler',
|
|
||||||
value: function _dataApiKeydownHandler(event) {
|
|
||||||
if (!/(38|40|27|32)/.test(event.which) || /input|textarea/i.test(event.target.tagName)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
|
|
||||||
if (this.disabled || $(this).hasClass(ClassName.DISABLED)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var parent = Dropdown._getParentFromElement(this);
|
|
||||||
var isActive = $(parent).hasClass(ClassName.OPEN);
|
|
||||||
|
|
||||||
if (!isActive && event.which !== 27 || isActive && event.which === 27) {
|
|
||||||
|
|
||||||
if (event.which === 27) {
|
|
||||||
var toggle = $(parent).find(Selector.DATA_TOGGLE)[0];
|
|
||||||
$(toggle).trigger('focus');
|
|
||||||
}
|
|
||||||
|
|
||||||
$(this).trigger('click');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var items = $.makeArray($(Selector.VISIBLE_ITEMS));
|
|
||||||
|
|
||||||
items = items.filter(function (item) {
|
|
||||||
return item.offsetWidth || item.offsetHeight;
|
|
||||||
});
|
|
||||||
|
|
||||||
if (!items.length) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var index = items.indexOf(event.target);
|
|
||||||
|
|
||||||
if (event.which === 38 && index > 0) {
|
|
||||||
// up
|
|
||||||
index--;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (event.which === 40 && index < items.length - 1) {
|
|
||||||
// down
|
|
||||||
index++;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (index < 0) {
|
|
||||||
index = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
items[index].focus();
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'VERSION',
|
|
||||||
get: function get() {
|
|
||||||
return VERSION;
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
return Dropdown;
|
|
||||||
})();
|
|
||||||
|
|
||||||
$(document).on(Event.KEYDOWN_DATA_API, Selector.DATA_TOGGLE, Dropdown._dataApiKeydownHandler).on(Event.KEYDOWN_DATA_API, Selector.ROLE_MENU, Dropdown._dataApiKeydownHandler).on(Event.KEYDOWN_DATA_API, Selector.ROLE_LISTBOX, Dropdown._dataApiKeydownHandler).on(Event.CLICK_DATA_API, Dropdown._clearMenus).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE, Dropdown.prototype.toggle).on(Event.CLICK_DATA_API, Selector.FORM_CHILD, function (e) {
|
|
||||||
e.stopPropagation();
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* jQuery
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
$.fn[NAME] = Dropdown._jQueryInterface;
|
|
||||||
$.fn[NAME].Constructor = Dropdown;
|
|
||||||
$.fn[NAME].noConflict = function () {
|
|
||||||
$.fn[NAME] = JQUERY_NO_CONFLICT;
|
|
||||||
return Dropdown._jQueryInterface;
|
|
||||||
};
|
|
||||||
|
|
||||||
return Dropdown;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = Dropdown;
|
|
||||||
});
|
|
549
docs/dist/js/umd/modal.js
vendored
@ -1,549 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module', './util'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module, require('./util'));
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod, global.Util);
|
|
||||||
global.modal = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module, _util) {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
|
||||||
|
|
||||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
|
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
|
||||||
|
|
||||||
var _Util = _interopRequireDefault(_util);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): modal.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Modal = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Constants
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var NAME = 'modal';
|
|
||||||
var VERSION = '4.0.0-alpha.2';
|
|
||||||
var DATA_KEY = 'bs.modal';
|
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
|
||||||
var DATA_API_KEY = '.data-api';
|
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
|
||||||
var TRANSITION_DURATION = 300;
|
|
||||||
var BACKDROP_TRANSITION_DURATION = 150;
|
|
||||||
|
|
||||||
var Default = {
|
|
||||||
backdrop: true,
|
|
||||||
keyboard: true,
|
|
||||||
focus: true,
|
|
||||||
show: true
|
|
||||||
};
|
|
||||||
|
|
||||||
var DefaultType = {
|
|
||||||
backdrop: '(boolean|string)',
|
|
||||||
keyboard: 'boolean',
|
|
||||||
focus: 'boolean',
|
|
||||||
show: 'boolean'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Event = {
|
|
||||||
HIDE: 'hide' + EVENT_KEY,
|
|
||||||
HIDDEN: 'hidden' + EVENT_KEY,
|
|
||||||
SHOW: 'show' + EVENT_KEY,
|
|
||||||
SHOWN: 'shown' + EVENT_KEY,
|
|
||||||
FOCUSIN: 'focusin' + EVENT_KEY,
|
|
||||||
RESIZE: 'resize' + EVENT_KEY,
|
|
||||||
CLICK_DISMISS: 'click.dismiss' + EVENT_KEY,
|
|
||||||
KEYDOWN_DISMISS: 'keydown.dismiss' + EVENT_KEY,
|
|
||||||
MOUSEUP_DISMISS: 'mouseup.dismiss' + EVENT_KEY,
|
|
||||||
MOUSEDOWN_DISMISS: 'mousedown.dismiss' + EVENT_KEY,
|
|
||||||
CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY
|
|
||||||
};
|
|
||||||
|
|
||||||
var ClassName = {
|
|
||||||
SCROLLBAR_MEASURER: 'modal-scrollbar-measure',
|
|
||||||
BACKDROP: 'modal-backdrop',
|
|
||||||
OPEN: 'modal-open',
|
|
||||||
FADE: 'fade',
|
|
||||||
IN: 'in'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Selector = {
|
|
||||||
DIALOG: '.modal-dialog',
|
|
||||||
DATA_TOGGLE: '[data-toggle="modal"]',
|
|
||||||
DATA_DISMISS: '[data-dismiss="modal"]',
|
|
||||||
FIXED_CONTENT: '.navbar-fixed-top, .navbar-fixed-bottom, .is-fixed'
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Class Definition
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Modal = (function () {
|
|
||||||
function Modal(element, config) {
|
|
||||||
_classCallCheck(this, Modal);
|
|
||||||
|
|
||||||
this._config = this._getConfig(config);
|
|
||||||
this._element = element;
|
|
||||||
this._dialog = $(element).find(Selector.DIALOG)[0];
|
|
||||||
this._backdrop = null;
|
|
||||||
this._isShown = false;
|
|
||||||
this._isBodyOverflowing = false;
|
|
||||||
this._ignoreBackdropClick = false;
|
|
||||||
this._originalBodyPadding = 0;
|
|
||||||
this._scrollbarWidth = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Data Api implementation
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
// getters
|
|
||||||
|
|
||||||
_createClass(Modal, [{
|
|
||||||
key: 'toggle',
|
|
||||||
|
|
||||||
// public
|
|
||||||
|
|
||||||
value: function toggle(relatedTarget) {
|
|
||||||
return this._isShown ? this.hide() : this.show(relatedTarget);
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'show',
|
|
||||||
value: function show(relatedTarget) {
|
|
||||||
var _this = this;
|
|
||||||
|
|
||||||
var showEvent = $.Event(Event.SHOW, {
|
|
||||||
relatedTarget: relatedTarget
|
|
||||||
});
|
|
||||||
|
|
||||||
$(this._element).trigger(showEvent);
|
|
||||||
|
|
||||||
if (this._isShown || showEvent.isDefaultPrevented()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._isShown = true;
|
|
||||||
|
|
||||||
this._checkScrollbar();
|
|
||||||
this._setScrollbar();
|
|
||||||
|
|
||||||
$(document.body).addClass(ClassName.OPEN);
|
|
||||||
|
|
||||||
this._setEscapeEvent();
|
|
||||||
this._setResizeEvent();
|
|
||||||
|
|
||||||
$(this._element).on(Event.CLICK_DISMISS, Selector.DATA_DISMISS, $.proxy(this.hide, this));
|
|
||||||
|
|
||||||
$(this._dialog).on(Event.MOUSEDOWN_DISMISS, function () {
|
|
||||||
$(_this._element).one(Event.MOUSEUP_DISMISS, function (event) {
|
|
||||||
if ($(event.target).is(_this._element)) {
|
|
||||||
_this._ignoreBackdropClick = true;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
this._showBackdrop($.proxy(this._showElement, this, relatedTarget));
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'hide',
|
|
||||||
value: function hide(event) {
|
|
||||||
if (event) {
|
|
||||||
event.preventDefault();
|
|
||||||
}
|
|
||||||
|
|
||||||
var hideEvent = $.Event(Event.HIDE);
|
|
||||||
|
|
||||||
$(this._element).trigger(hideEvent);
|
|
||||||
|
|
||||||
if (!this._isShown || hideEvent.isDefaultPrevented()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._isShown = false;
|
|
||||||
|
|
||||||
this._setEscapeEvent();
|
|
||||||
this._setResizeEvent();
|
|
||||||
|
|
||||||
$(document).off(Event.FOCUSIN);
|
|
||||||
|
|
||||||
$(this._element).removeClass(ClassName.IN);
|
|
||||||
|
|
||||||
$(this._element).off(Event.CLICK_DISMISS);
|
|
||||||
$(this._dialog).off(Event.MOUSEDOWN_DISMISS);
|
|
||||||
|
|
||||||
if (_Util['default'].supportsTransitionEnd() && $(this._element).hasClass(ClassName.FADE)) {
|
|
||||||
|
|
||||||
$(this._element).one(_Util['default'].TRANSITION_END, $.proxy(this._hideModal, this)).emulateTransitionEnd(TRANSITION_DURATION);
|
|
||||||
} else {
|
|
||||||
this._hideModal();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'dispose',
|
|
||||||
value: function dispose() {
|
|
||||||
$.removeData(this._element, DATA_KEY);
|
|
||||||
|
|
||||||
$(window).off(EVENT_KEY);
|
|
||||||
$(document).off(EVENT_KEY);
|
|
||||||
$(this._element).off(EVENT_KEY);
|
|
||||||
$(this._backdrop).off(EVENT_KEY);
|
|
||||||
|
|
||||||
this._config = null;
|
|
||||||
this._element = null;
|
|
||||||
this._dialog = null;
|
|
||||||
this._backdrop = null;
|
|
||||||
this._isShown = null;
|
|
||||||
this._isBodyOverflowing = null;
|
|
||||||
this._ignoreBackdropClick = null;
|
|
||||||
this._originalBodyPadding = null;
|
|
||||||
this._scrollbarWidth = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// private
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: '_getConfig',
|
|
||||||
value: function _getConfig(config) {
|
|
||||||
config = $.extend({}, Default, config);
|
|
||||||
_Util['default'].typeCheckConfig(NAME, config, DefaultType);
|
|
||||||
return config;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_showElement',
|
|
||||||
value: function _showElement(relatedTarget) {
|
|
||||||
var _this2 = this;
|
|
||||||
|
|
||||||
var transition = _Util['default'].supportsTransitionEnd() && $(this._element).hasClass(ClassName.FADE);
|
|
||||||
|
|
||||||
if (!this._element.parentNode || this._element.parentNode.nodeType !== Node.ELEMENT_NODE) {
|
|
||||||
// don't move modals dom position
|
|
||||||
document.body.appendChild(this._element);
|
|
||||||
}
|
|
||||||
|
|
||||||
this._element.style.display = 'block';
|
|
||||||
this._element.scrollTop = 0;
|
|
||||||
|
|
||||||
if (transition) {
|
|
||||||
_Util['default'].reflow(this._element);
|
|
||||||
}
|
|
||||||
|
|
||||||
$(this._element).addClass(ClassName.IN);
|
|
||||||
|
|
||||||
if (this._config.focus) {
|
|
||||||
this._enforceFocus();
|
|
||||||
}
|
|
||||||
|
|
||||||
var shownEvent = $.Event(Event.SHOWN, {
|
|
||||||
relatedTarget: relatedTarget
|
|
||||||
});
|
|
||||||
|
|
||||||
var transitionComplete = function transitionComplete() {
|
|
||||||
if (_this2._config.focus) {
|
|
||||||
_this2._element.focus();
|
|
||||||
}
|
|
||||||
$(_this2._element).trigger(shownEvent);
|
|
||||||
};
|
|
||||||
|
|
||||||
if (transition) {
|
|
||||||
$(this._dialog).one(_Util['default'].TRANSITION_END, transitionComplete).emulateTransitionEnd(TRANSITION_DURATION);
|
|
||||||
} else {
|
|
||||||
transitionComplete();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_enforceFocus',
|
|
||||||
value: function _enforceFocus() {
|
|
||||||
var _this3 = this;
|
|
||||||
|
|
||||||
$(document).off(Event.FOCUSIN) // guard against infinite focus loop
|
|
||||||
.on(Event.FOCUSIN, function (event) {
|
|
||||||
if (document !== event.target && _this3._element !== event.target && !$(_this3._element).has(event.target).length) {
|
|
||||||
_this3._element.focus();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_setEscapeEvent',
|
|
||||||
value: function _setEscapeEvent() {
|
|
||||||
var _this4 = this;
|
|
||||||
|
|
||||||
if (this._isShown && this._config.keyboard) {
|
|
||||||
$(this._element).on(Event.KEYDOWN_DISMISS, function (event) {
|
|
||||||
if (event.which === 27) {
|
|
||||||
_this4.hide();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else if (!this._isShown) {
|
|
||||||
$(this._element).off(Event.KEYDOWN_DISMISS);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_setResizeEvent',
|
|
||||||
value: function _setResizeEvent() {
|
|
||||||
if (this._isShown) {
|
|
||||||
$(window).on(Event.RESIZE, $.proxy(this._handleUpdate, this));
|
|
||||||
} else {
|
|
||||||
$(window).off(Event.RESIZE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_hideModal',
|
|
||||||
value: function _hideModal() {
|
|
||||||
var _this5 = this;
|
|
||||||
|
|
||||||
this._element.style.display = 'none';
|
|
||||||
this._showBackdrop(function () {
|
|
||||||
$(document.body).removeClass(ClassName.OPEN);
|
|
||||||
_this5._resetAdjustments();
|
|
||||||
_this5._resetScrollbar();
|
|
||||||
$(_this5._element).trigger(Event.HIDDEN);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_removeBackdrop',
|
|
||||||
value: function _removeBackdrop() {
|
|
||||||
if (this._backdrop) {
|
|
||||||
$(this._backdrop).remove();
|
|
||||||
this._backdrop = null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_showBackdrop',
|
|
||||||
value: function _showBackdrop(callback) {
|
|
||||||
var _this6 = this;
|
|
||||||
|
|
||||||
var animate = $(this._element).hasClass(ClassName.FADE) ? ClassName.FADE : '';
|
|
||||||
|
|
||||||
if (this._isShown && this._config.backdrop) {
|
|
||||||
var doAnimate = _Util['default'].supportsTransitionEnd() && animate;
|
|
||||||
|
|
||||||
this._backdrop = document.createElement('div');
|
|
||||||
this._backdrop.className = ClassName.BACKDROP;
|
|
||||||
|
|
||||||
if (animate) {
|
|
||||||
$(this._backdrop).addClass(animate);
|
|
||||||
}
|
|
||||||
|
|
||||||
$(this._backdrop).appendTo(document.body);
|
|
||||||
|
|
||||||
$(this._element).on(Event.CLICK_DISMISS, function (event) {
|
|
||||||
if (_this6._ignoreBackdropClick) {
|
|
||||||
_this6._ignoreBackdropClick = false;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (event.target !== event.currentTarget) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (_this6._config.backdrop === 'static') {
|
|
||||||
_this6._element.focus();
|
|
||||||
} else {
|
|
||||||
_this6.hide();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
if (doAnimate) {
|
|
||||||
_Util['default'].reflow(this._backdrop);
|
|
||||||
}
|
|
||||||
|
|
||||||
$(this._backdrop).addClass(ClassName.IN);
|
|
||||||
|
|
||||||
if (!callback) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!doAnimate) {
|
|
||||||
callback();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$(this._backdrop).one(_Util['default'].TRANSITION_END, callback).emulateTransitionEnd(BACKDROP_TRANSITION_DURATION);
|
|
||||||
} else if (!this._isShown && this._backdrop) {
|
|
||||||
$(this._backdrop).removeClass(ClassName.IN);
|
|
||||||
|
|
||||||
var callbackRemove = function callbackRemove() {
|
|
||||||
_this6._removeBackdrop();
|
|
||||||
if (callback) {
|
|
||||||
callback();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
if (_Util['default'].supportsTransitionEnd() && $(this._element).hasClass(ClassName.FADE)) {
|
|
||||||
$(this._backdrop).one(_Util['default'].TRANSITION_END, callbackRemove).emulateTransitionEnd(BACKDROP_TRANSITION_DURATION);
|
|
||||||
} else {
|
|
||||||
callbackRemove();
|
|
||||||
}
|
|
||||||
} else if (callback) {
|
|
||||||
callback();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------
|
|
||||||
// the following methods are used to handle overflowing modals
|
|
||||||
// todo (fat): these should probably be refactored out of modal.js
|
|
||||||
// ----------------------------------------------------------------------
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: '_handleUpdate',
|
|
||||||
value: function _handleUpdate() {
|
|
||||||
this._adjustDialog();
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_adjustDialog',
|
|
||||||
value: function _adjustDialog() {
|
|
||||||
var isModalOverflowing = this._element.scrollHeight > document.documentElement.clientHeight;
|
|
||||||
|
|
||||||
if (!this._isBodyOverflowing && isModalOverflowing) {
|
|
||||||
this._element.style.paddingLeft = this._scrollbarWidth + 'px';
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._isBodyOverflowing && !isModalOverflowing) {
|
|
||||||
this._element.style.paddingRight = this._scrollbarWidth + 'px~';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_resetAdjustments',
|
|
||||||
value: function _resetAdjustments() {
|
|
||||||
this._element.style.paddingLeft = '';
|
|
||||||
this._element.style.paddingRight = '';
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_checkScrollbar',
|
|
||||||
value: function _checkScrollbar() {
|
|
||||||
this._isBodyOverflowing = document.body.clientWidth < window.innerWidth;
|
|
||||||
this._scrollbarWidth = this._getScrollbarWidth();
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_setScrollbar',
|
|
||||||
value: function _setScrollbar() {
|
|
||||||
var bodyPadding = parseInt($(Selector.FIXED_CONTENT).css('padding-right') || 0, 10);
|
|
||||||
|
|
||||||
this._originalBodyPadding = document.body.style.paddingRight || '';
|
|
||||||
|
|
||||||
if (this._isBodyOverflowing) {
|
|
||||||
document.body.style.paddingRight = bodyPadding + this._scrollbarWidth + 'px';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_resetScrollbar',
|
|
||||||
value: function _resetScrollbar() {
|
|
||||||
document.body.style.paddingRight = this._originalBodyPadding;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_getScrollbarWidth',
|
|
||||||
value: function _getScrollbarWidth() {
|
|
||||||
// thx d.walsh
|
|
||||||
var scrollDiv = document.createElement('div');
|
|
||||||
scrollDiv.className = ClassName.SCROLLBAR_MEASURER;
|
|
||||||
document.body.appendChild(scrollDiv);
|
|
||||||
var scrollbarWidth = scrollDiv.offsetWidth - scrollDiv.clientWidth;
|
|
||||||
document.body.removeChild(scrollDiv);
|
|
||||||
return scrollbarWidth;
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
|
|
||||||
}], [{
|
|
||||||
key: '_jQueryInterface',
|
|
||||||
value: function _jQueryInterface(config, relatedTarget) {
|
|
||||||
return this.each(function () {
|
|
||||||
var data = $(this).data(DATA_KEY);
|
|
||||||
var _config = $.extend({}, Modal.Default, $(this).data(), typeof config === 'object' && config);
|
|
||||||
|
|
||||||
if (!data) {
|
|
||||||
data = new Modal(this, _config);
|
|
||||||
$(this).data(DATA_KEY, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (typeof config === 'string') {
|
|
||||||
if (data[config] === undefined) {
|
|
||||||
throw new Error('No method named "' + config + '"');
|
|
||||||
}
|
|
||||||
data[config](relatedTarget);
|
|
||||||
} else if (_config.show) {
|
|
||||||
data.show(relatedTarget);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'VERSION',
|
|
||||||
get: function get() {
|
|
||||||
return VERSION;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'Default',
|
|
||||||
get: function get() {
|
|
||||||
return Default;
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
return Modal;
|
|
||||||
})();
|
|
||||||
|
|
||||||
$(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE, function (event) {
|
|
||||||
var _this7 = this;
|
|
||||||
|
|
||||||
var target = undefined;
|
|
||||||
var selector = _Util['default'].getSelectorFromElement(this);
|
|
||||||
|
|
||||||
if (selector) {
|
|
||||||
target = $(selector)[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
var config = $(target).data(DATA_KEY) ? 'toggle' : $.extend({}, $(target).data(), $(this).data());
|
|
||||||
|
|
||||||
if (this.tagName === 'A') {
|
|
||||||
event.preventDefault();
|
|
||||||
}
|
|
||||||
|
|
||||||
var $target = $(target).one(Event.SHOW, function (showEvent) {
|
|
||||||
if (showEvent.isDefaultPrevented()) {
|
|
||||||
// only register focus restorer if modal will actually get shown
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$target.one(Event.HIDDEN, function () {
|
|
||||||
if ($(_this7).is(':visible')) {
|
|
||||||
_this7.focus();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
Modal._jQueryInterface.call($(target), config, this);
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* jQuery
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
$.fn[NAME] = Modal._jQueryInterface;
|
|
||||||
$.fn[NAME].Constructor = Modal;
|
|
||||||
$.fn[NAME].noConflict = function () {
|
|
||||||
$.fn[NAME] = JQUERY_NO_CONFLICT;
|
|
||||||
return Modal._jQueryInterface;
|
|
||||||
};
|
|
||||||
|
|
||||||
return Modal;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = Modal;
|
|
||||||
});
|
|
220
docs/dist/js/umd/popover.js
vendored
@ -1,220 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module', './tooltip'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module, require('./tooltip'));
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod, global.Tooltip);
|
|
||||||
global.popover = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module, _tooltip) {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
|
||||||
|
|
||||||
var _get = function get(_x, _x2, _x3) { var _again = true; _function: while (_again) { var object = _x, property = _x2, receiver = _x3; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x = parent; _x2 = property; _x3 = receiver; _again = true; desc = parent = undefined; continue _function; } } else if ('value' in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };
|
|
||||||
|
|
||||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
|
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
|
||||||
|
|
||||||
function _inherits(subClass, superClass) { if (typeof superClass !== 'function' && superClass !== null) { throw new TypeError('Super expression must either be null or a function, not ' + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
|
|
||||||
|
|
||||||
var _Tooltip2 = _interopRequireDefault(_tooltip);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): popover.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Popover = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Constants
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var NAME = 'popover';
|
|
||||||
var VERSION = '4.0.0-alpha.2';
|
|
||||||
var DATA_KEY = 'bs.popover';
|
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
|
||||||
|
|
||||||
var Default = $.extend({}, _Tooltip2['default'].Default, {
|
|
||||||
placement: 'right',
|
|
||||||
trigger: 'click',
|
|
||||||
content: '',
|
|
||||||
template: '<div class="popover" role="tooltip">' + '<div class="popover-arrow"></div>' + '<h3 class="popover-title"></h3>' + '<div class="popover-content"></div></div>'
|
|
||||||
});
|
|
||||||
|
|
||||||
var DefaultType = $.extend({}, _Tooltip2['default'].DefaultType, {
|
|
||||||
content: '(string|element|function)'
|
|
||||||
});
|
|
||||||
|
|
||||||
var ClassName = {
|
|
||||||
FADE: 'fade',
|
|
||||||
IN: 'in'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Selector = {
|
|
||||||
TITLE: '.popover-title',
|
|
||||||
CONTENT: '.popover-content',
|
|
||||||
ARROW: '.popover-arrow'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Event = {
|
|
||||||
HIDE: 'hide' + EVENT_KEY,
|
|
||||||
HIDDEN: 'hidden' + EVENT_KEY,
|
|
||||||
SHOW: 'show' + EVENT_KEY,
|
|
||||||
SHOWN: 'shown' + EVENT_KEY,
|
|
||||||
INSERTED: 'inserted' + EVENT_KEY,
|
|
||||||
CLICK: 'click' + EVENT_KEY,
|
|
||||||
FOCUSIN: 'focusin' + EVENT_KEY,
|
|
||||||
FOCUSOUT: 'focusout' + EVENT_KEY,
|
|
||||||
MOUSEENTER: 'mouseenter' + EVENT_KEY,
|
|
||||||
MOUSELEAVE: 'mouseleave' + EVENT_KEY
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Class Definition
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Popover = (function (_Tooltip) {
|
|
||||||
_inherits(Popover, _Tooltip);
|
|
||||||
|
|
||||||
function Popover() {
|
|
||||||
_classCallCheck(this, Popover);
|
|
||||||
|
|
||||||
_get(Object.getPrototypeOf(Popover.prototype), 'constructor', this).apply(this, arguments);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* jQuery
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
_createClass(Popover, [{
|
|
||||||
key: 'isWithContent',
|
|
||||||
|
|
||||||
// overrides
|
|
||||||
|
|
||||||
value: function isWithContent() {
|
|
||||||
return this.getTitle() || this._getContent();
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'getTipElement',
|
|
||||||
value: function getTipElement() {
|
|
||||||
return this.tip = this.tip || $(this.config.template)[0];
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'setContent',
|
|
||||||
value: function setContent() {
|
|
||||||
var $tip = $(this.getTipElement());
|
|
||||||
|
|
||||||
// we use append for html objects to maintain js events
|
|
||||||
this.setElementContent($tip.find(Selector.TITLE), this.getTitle());
|
|
||||||
this.setElementContent($tip.find(Selector.CONTENT), this._getContent());
|
|
||||||
|
|
||||||
$tip.removeClass(ClassName.FADE).removeClass(ClassName.IN);
|
|
||||||
|
|
||||||
this.cleanupTether();
|
|
||||||
}
|
|
||||||
|
|
||||||
// private
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: '_getContent',
|
|
||||||
value: function _getContent() {
|
|
||||||
return this.element.getAttribute('data-content') || (typeof this.config.content === 'function' ? this.config.content.call(this.element) : this.config.content);
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
|
|
||||||
}], [{
|
|
||||||
key: '_jQueryInterface',
|
|
||||||
value: function _jQueryInterface(config) {
|
|
||||||
return this.each(function () {
|
|
||||||
var data = $(this).data(DATA_KEY);
|
|
||||||
var _config = typeof config === 'object' ? config : null;
|
|
||||||
|
|
||||||
if (!data && /destroy|hide/.test(config)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!data) {
|
|
||||||
data = new Popover(this, _config);
|
|
||||||
$(this).data(DATA_KEY, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (typeof config === 'string') {
|
|
||||||
if (data[config] === undefined) {
|
|
||||||
throw new Error('No method named "' + config + '"');
|
|
||||||
}
|
|
||||||
data[config]();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'VERSION',
|
|
||||||
|
|
||||||
// getters
|
|
||||||
|
|
||||||
get: function get() {
|
|
||||||
return VERSION;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'Default',
|
|
||||||
get: function get() {
|
|
||||||
return Default;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'NAME',
|
|
||||||
get: function get() {
|
|
||||||
return NAME;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'DATA_KEY',
|
|
||||||
get: function get() {
|
|
||||||
return DATA_KEY;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'Event',
|
|
||||||
get: function get() {
|
|
||||||
return Event;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'EVENT_KEY',
|
|
||||||
get: function get() {
|
|
||||||
return EVENT_KEY;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'DefaultType',
|
|
||||||
get: function get() {
|
|
||||||
return DefaultType;
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
return Popover;
|
|
||||||
})(_Tooltip2['default']);
|
|
||||||
|
|
||||||
$.fn[NAME] = Popover._jQueryInterface;
|
|
||||||
$.fn[NAME].Constructor = Popover;
|
|
||||||
$.fn[NAME].noConflict = function () {
|
|
||||||
$.fn[NAME] = JQUERY_NO_CONFLICT;
|
|
||||||
return Popover._jQueryInterface;
|
|
||||||
};
|
|
||||||
|
|
||||||
return Popover;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = Popover;
|
|
||||||
});
|
|
339
docs/dist/js/umd/scrollspy.js
vendored
@ -1,339 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module', './util'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module, require('./util'));
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod, global.Util);
|
|
||||||
global.scrollspy = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module, _util) {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
|
||||||
|
|
||||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
|
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
|
||||||
|
|
||||||
var _Util = _interopRequireDefault(_util);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): scrollspy.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var ScrollSpy = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Constants
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var NAME = 'scrollspy';
|
|
||||||
var VERSION = '4.0.0-alpha.2';
|
|
||||||
var DATA_KEY = 'bs.scrollspy';
|
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
|
||||||
var DATA_API_KEY = '.data-api';
|
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
|
||||||
|
|
||||||
var Default = {
|
|
||||||
offset: 10,
|
|
||||||
method: 'auto',
|
|
||||||
target: ''
|
|
||||||
};
|
|
||||||
|
|
||||||
var DefaultType = {
|
|
||||||
offset: 'number',
|
|
||||||
method: 'string',
|
|
||||||
target: '(string|element)'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Event = {
|
|
||||||
ACTIVATE: 'activate' + EVENT_KEY,
|
|
||||||
SCROLL: 'scroll' + EVENT_KEY,
|
|
||||||
LOAD_DATA_API: 'load' + EVENT_KEY + DATA_API_KEY
|
|
||||||
};
|
|
||||||
|
|
||||||
var ClassName = {
|
|
||||||
DROPDOWN_ITEM: 'dropdown-item',
|
|
||||||
DROPDOWN_MENU: 'dropdown-menu',
|
|
||||||
NAV_LINK: 'nav-link',
|
|
||||||
NAV: 'nav',
|
|
||||||
ACTIVE: 'active'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Selector = {
|
|
||||||
DATA_SPY: '[data-spy="scroll"]',
|
|
||||||
ACTIVE: '.active',
|
|
||||||
LIST_ITEM: '.list-item',
|
|
||||||
LI: 'li',
|
|
||||||
LI_DROPDOWN: 'li.dropdown',
|
|
||||||
NAV_LINKS: '.nav-link',
|
|
||||||
DROPDOWN: '.dropdown',
|
|
||||||
DROPDOWN_ITEMS: '.dropdown-item',
|
|
||||||
DROPDOWN_TOGGLE: '.dropdown-toggle'
|
|
||||||
};
|
|
||||||
|
|
||||||
var OffsetMethod = {
|
|
||||||
OFFSET: 'offset',
|
|
||||||
POSITION: 'position'
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Class Definition
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var ScrollSpy = (function () {
|
|
||||||
function ScrollSpy(element, config) {
|
|
||||||
_classCallCheck(this, ScrollSpy);
|
|
||||||
|
|
||||||
this._element = element;
|
|
||||||
this._scrollElement = element.tagName === 'BODY' ? window : element;
|
|
||||||
this._config = this._getConfig(config);
|
|
||||||
this._selector = this._config.target + ' ' + Selector.NAV_LINKS + ',' + (this._config.target + ' ' + Selector.DROPDOWN_ITEMS);
|
|
||||||
this._offsets = [];
|
|
||||||
this._targets = [];
|
|
||||||
this._activeTarget = null;
|
|
||||||
this._scrollHeight = 0;
|
|
||||||
|
|
||||||
$(this._scrollElement).on(Event.SCROLL, $.proxy(this._process, this));
|
|
||||||
|
|
||||||
this.refresh();
|
|
||||||
this._process();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Data Api implementation
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
// getters
|
|
||||||
|
|
||||||
_createClass(ScrollSpy, [{
|
|
||||||
key: 'refresh',
|
|
||||||
|
|
||||||
// public
|
|
||||||
|
|
||||||
value: function refresh() {
|
|
||||||
var _this = this;
|
|
||||||
|
|
||||||
var autoMethod = this._scrollElement !== this._scrollElement.window ? OffsetMethod.POSITION : OffsetMethod.OFFSET;
|
|
||||||
|
|
||||||
var offsetMethod = this._config.method === 'auto' ? autoMethod : this._config.method;
|
|
||||||
|
|
||||||
var offsetBase = offsetMethod === OffsetMethod.POSITION ? this._getScrollTop() : 0;
|
|
||||||
|
|
||||||
this._offsets = [];
|
|
||||||
this._targets = [];
|
|
||||||
|
|
||||||
this._scrollHeight = this._getScrollHeight();
|
|
||||||
|
|
||||||
var targets = $.makeArray($(this._selector));
|
|
||||||
|
|
||||||
targets.map(function (element) {
|
|
||||||
var target = undefined;
|
|
||||||
var targetSelector = _Util['default'].getSelectorFromElement(element);
|
|
||||||
|
|
||||||
if (targetSelector) {
|
|
||||||
target = $(targetSelector)[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (target && (target.offsetWidth || target.offsetHeight)) {
|
|
||||||
// todo (fat): remove sketch reliance on jQuery position/offset
|
|
||||||
return [$(target)[offsetMethod]().top + offsetBase, targetSelector];
|
|
||||||
}
|
|
||||||
}).filter(function (item) {
|
|
||||||
return item;
|
|
||||||
}).sort(function (a, b) {
|
|
||||||
return a[0] - b[0];
|
|
||||||
}).forEach(function (item) {
|
|
||||||
_this._offsets.push(item[0]);
|
|
||||||
_this._targets.push(item[1]);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'dispose',
|
|
||||||
value: function dispose() {
|
|
||||||
$.removeData(this._element, DATA_KEY);
|
|
||||||
$(this._scrollElement).off(EVENT_KEY);
|
|
||||||
|
|
||||||
this._element = null;
|
|
||||||
this._scrollElement = null;
|
|
||||||
this._config = null;
|
|
||||||
this._selector = null;
|
|
||||||
this._offsets = null;
|
|
||||||
this._targets = null;
|
|
||||||
this._activeTarget = null;
|
|
||||||
this._scrollHeight = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// private
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: '_getConfig',
|
|
||||||
value: function _getConfig(config) {
|
|
||||||
config = $.extend({}, Default, config);
|
|
||||||
|
|
||||||
if (typeof config.target !== 'string') {
|
|
||||||
var id = $(config.target).attr('id');
|
|
||||||
if (!id) {
|
|
||||||
id = _Util['default'].getUID(NAME);
|
|
||||||
$(config.target).attr('id', id);
|
|
||||||
}
|
|
||||||
config.target = '#' + id;
|
|
||||||
}
|
|
||||||
|
|
||||||
_Util['default'].typeCheckConfig(NAME, config, DefaultType);
|
|
||||||
|
|
||||||
return config;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_getScrollTop',
|
|
||||||
value: function _getScrollTop() {
|
|
||||||
return this._scrollElement === window ? this._scrollElement.scrollY : this._scrollElement.scrollTop;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_getScrollHeight',
|
|
||||||
value: function _getScrollHeight() {
|
|
||||||
return this._scrollElement.scrollHeight || Math.max(document.body.scrollHeight, document.documentElement.scrollHeight);
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_process',
|
|
||||||
value: function _process() {
|
|
||||||
var scrollTop = this._getScrollTop() + this._config.offset;
|
|
||||||
var scrollHeight = this._getScrollHeight();
|
|
||||||
var maxScroll = this._config.offset + scrollHeight - this._scrollElement.offsetHeight;
|
|
||||||
|
|
||||||
if (this._scrollHeight !== scrollHeight) {
|
|
||||||
this.refresh();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (scrollTop >= maxScroll) {
|
|
||||||
var target = this._targets[this._targets.length - 1];
|
|
||||||
|
|
||||||
if (this._activeTarget !== target) {
|
|
||||||
this._activate(target);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._activeTarget && scrollTop < this._offsets[0]) {
|
|
||||||
this._activeTarget = null;
|
|
||||||
this._clear();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (var i = this._offsets.length; i--;) {
|
|
||||||
var isActiveTarget = this._activeTarget !== this._targets[i] && scrollTop >= this._offsets[i] && (this._offsets[i + 1] === undefined || scrollTop < this._offsets[i + 1]);
|
|
||||||
|
|
||||||
if (isActiveTarget) {
|
|
||||||
this._activate(this._targets[i]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_activate',
|
|
||||||
value: function _activate(target) {
|
|
||||||
this._activeTarget = target;
|
|
||||||
|
|
||||||
this._clear();
|
|
||||||
|
|
||||||
var queries = this._selector.split(',');
|
|
||||||
queries = queries.map(function (selector) {
|
|
||||||
return selector + '[data-target="' + target + '"],' + (selector + '[href="' + target + '"]');
|
|
||||||
});
|
|
||||||
|
|
||||||
var $link = $(queries.join(','));
|
|
||||||
|
|
||||||
if ($link.hasClass(ClassName.DROPDOWN_ITEM)) {
|
|
||||||
$link.closest(Selector.DROPDOWN).find(Selector.DROPDOWN_TOGGLE).addClass(ClassName.ACTIVE);
|
|
||||||
$link.addClass(ClassName.ACTIVE);
|
|
||||||
} else {
|
|
||||||
// todo (fat) this is kinda sus...
|
|
||||||
// recursively add actives to tested nav-links
|
|
||||||
$link.parents(Selector.LI).find(Selector.NAV_LINKS).addClass(ClassName.ACTIVE);
|
|
||||||
}
|
|
||||||
|
|
||||||
$(this._scrollElement).trigger(Event.ACTIVATE, {
|
|
||||||
relatedTarget: target
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_clear',
|
|
||||||
value: function _clear() {
|
|
||||||
$(this._selector).filter(Selector.ACTIVE).removeClass(ClassName.ACTIVE);
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
|
|
||||||
}], [{
|
|
||||||
key: '_jQueryInterface',
|
|
||||||
value: function _jQueryInterface(config) {
|
|
||||||
return this.each(function () {
|
|
||||||
var data = $(this).data(DATA_KEY);
|
|
||||||
var _config = typeof config === 'object' && config || null;
|
|
||||||
|
|
||||||
if (!data) {
|
|
||||||
data = new ScrollSpy(this, _config);
|
|
||||||
$(this).data(DATA_KEY, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (typeof config === 'string') {
|
|
||||||
if (data[config] === undefined) {
|
|
||||||
throw new Error('No method named "' + config + '"');
|
|
||||||
}
|
|
||||||
data[config]();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'VERSION',
|
|
||||||
get: function get() {
|
|
||||||
return VERSION;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'Default',
|
|
||||||
get: function get() {
|
|
||||||
return Default;
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
return ScrollSpy;
|
|
||||||
})();
|
|
||||||
|
|
||||||
$(window).on(Event.LOAD_DATA_API, function () {
|
|
||||||
var scrollSpys = $.makeArray($(Selector.DATA_SPY));
|
|
||||||
|
|
||||||
for (var i = scrollSpys.length; i--;) {
|
|
||||||
var $spy = $(scrollSpys[i]);
|
|
||||||
ScrollSpy._jQueryInterface.call($spy, $spy.data());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* jQuery
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
$.fn[NAME] = ScrollSpy._jQueryInterface;
|
|
||||||
$.fn[NAME].Constructor = ScrollSpy;
|
|
||||||
$.fn[NAME].noConflict = function () {
|
|
||||||
$.fn[NAME] = JQUERY_NO_CONFLICT;
|
|
||||||
return ScrollSpy._jQueryInterface;
|
|
||||||
};
|
|
||||||
|
|
||||||
return ScrollSpy;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = ScrollSpy;
|
|
||||||
});
|
|
282
docs/dist/js/umd/tab.js
vendored
@ -1,282 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module', './util'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module, require('./util'));
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod, global.Util);
|
|
||||||
global.tab = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module, _util) {
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
|
||||||
|
|
||||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
|
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
|
||||||
|
|
||||||
var _Util = _interopRequireDefault(_util);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): tab.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Tab = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Constants
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var NAME = 'tab';
|
|
||||||
var VERSION = '4.0.0-alpha.2';
|
|
||||||
var DATA_KEY = 'bs.tab';
|
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
|
||||||
var DATA_API_KEY = '.data-api';
|
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
|
||||||
var TRANSITION_DURATION = 150;
|
|
||||||
|
|
||||||
var Event = {
|
|
||||||
HIDE: 'hide' + EVENT_KEY,
|
|
||||||
HIDDEN: 'hidden' + EVENT_KEY,
|
|
||||||
SHOW: 'show' + EVENT_KEY,
|
|
||||||
SHOWN: 'shown' + EVENT_KEY,
|
|
||||||
CLICK_DATA_API: 'click' + EVENT_KEY + DATA_API_KEY
|
|
||||||
};
|
|
||||||
|
|
||||||
var ClassName = {
|
|
||||||
DROPDOWN_MENU: 'dropdown-menu',
|
|
||||||
ACTIVE: 'active',
|
|
||||||
FADE: 'fade',
|
|
||||||
IN: 'in'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Selector = {
|
|
||||||
A: 'a',
|
|
||||||
LI: 'li',
|
|
||||||
DROPDOWN: '.dropdown',
|
|
||||||
UL: 'ul:not(.dropdown-menu)',
|
|
||||||
FADE_CHILD: '> .nav-item .fade, > .fade',
|
|
||||||
ACTIVE: '.active',
|
|
||||||
ACTIVE_CHILD: '> .nav-item > .active, > .active',
|
|
||||||
DATA_TOGGLE: '[data-toggle="tab"], [data-toggle="pill"]',
|
|
||||||
DROPDOWN_TOGGLE: '.dropdown-toggle',
|
|
||||||
DROPDOWN_ACTIVE_CHILD: '> .dropdown-menu .active'
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Class Definition
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Tab = (function () {
|
|
||||||
function Tab(element) {
|
|
||||||
_classCallCheck(this, Tab);
|
|
||||||
|
|
||||||
this._element = element;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Data Api implementation
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
// getters
|
|
||||||
|
|
||||||
_createClass(Tab, [{
|
|
||||||
key: 'show',
|
|
||||||
|
|
||||||
// public
|
|
||||||
|
|
||||||
value: function show() {
|
|
||||||
var _this = this;
|
|
||||||
|
|
||||||
if (this._element.parentNode && this._element.parentNode.nodeType === Node.ELEMENT_NODE && $(this._element).hasClass(ClassName.ACTIVE)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var target = undefined;
|
|
||||||
var previous = undefined;
|
|
||||||
var ulElement = $(this._element).closest(Selector.UL)[0];
|
|
||||||
var selector = _Util['default'].getSelectorFromElement(this._element);
|
|
||||||
|
|
||||||
if (ulElement) {
|
|
||||||
previous = $.makeArray($(ulElement).find(Selector.ACTIVE));
|
|
||||||
previous = previous[previous.length - 1];
|
|
||||||
}
|
|
||||||
|
|
||||||
var hideEvent = $.Event(Event.HIDE, {
|
|
||||||
relatedTarget: this._element
|
|
||||||
});
|
|
||||||
|
|
||||||
var showEvent = $.Event(Event.SHOW, {
|
|
||||||
relatedTarget: previous
|
|
||||||
});
|
|
||||||
|
|
||||||
if (previous) {
|
|
||||||
$(previous).trigger(hideEvent);
|
|
||||||
}
|
|
||||||
|
|
||||||
$(this._element).trigger(showEvent);
|
|
||||||
|
|
||||||
if (showEvent.isDefaultPrevented() || hideEvent.isDefaultPrevented()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (selector) {
|
|
||||||
target = $(selector)[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
this._activate(this._element, ulElement);
|
|
||||||
|
|
||||||
var complete = function complete() {
|
|
||||||
var hiddenEvent = $.Event(Event.HIDDEN, {
|
|
||||||
relatedTarget: _this._element
|
|
||||||
});
|
|
||||||
|
|
||||||
var shownEvent = $.Event(Event.SHOWN, {
|
|
||||||
relatedTarget: previous
|
|
||||||
});
|
|
||||||
|
|
||||||
$(previous).trigger(hiddenEvent);
|
|
||||||
$(_this._element).trigger(shownEvent);
|
|
||||||
};
|
|
||||||
|
|
||||||
if (target) {
|
|
||||||
this._activate(target, target.parentNode, complete);
|
|
||||||
} else {
|
|
||||||
complete();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'dispose',
|
|
||||||
value: function dispose() {
|
|
||||||
$.removeClass(this._element, DATA_KEY);
|
|
||||||
this._element = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// private
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: '_activate',
|
|
||||||
value: function _activate(element, container, callback) {
|
|
||||||
var active = $(container).find(Selector.ACTIVE_CHILD)[0];
|
|
||||||
var isTransitioning = callback && _Util['default'].supportsTransitionEnd() && (active && $(active).hasClass(ClassName.FADE) || Boolean($(container).find(Selector.FADE_CHILD)[0]));
|
|
||||||
|
|
||||||
var complete = $.proxy(this._transitionComplete, this, element, active, isTransitioning, callback);
|
|
||||||
|
|
||||||
if (active && isTransitioning) {
|
|
||||||
$(active).one(_Util['default'].TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION);
|
|
||||||
} else {
|
|
||||||
complete();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (active) {
|
|
||||||
$(active).removeClass(ClassName.IN);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_transitionComplete',
|
|
||||||
value: function _transitionComplete(element, active, isTransitioning, callback) {
|
|
||||||
if (active) {
|
|
||||||
$(active).removeClass(ClassName.ACTIVE);
|
|
||||||
|
|
||||||
var dropdownChild = $(active).find(Selector.DROPDOWN_ACTIVE_CHILD)[0];
|
|
||||||
|
|
||||||
if (dropdownChild) {
|
|
||||||
$(dropdownChild).removeClass(ClassName.ACTIVE);
|
|
||||||
}
|
|
||||||
|
|
||||||
active.setAttribute('aria-expanded', false);
|
|
||||||
}
|
|
||||||
|
|
||||||
$(element).addClass(ClassName.ACTIVE);
|
|
||||||
element.setAttribute('aria-expanded', true);
|
|
||||||
|
|
||||||
if (isTransitioning) {
|
|
||||||
_Util['default'].reflow(element);
|
|
||||||
$(element).addClass(ClassName.IN);
|
|
||||||
} else {
|
|
||||||
$(element).removeClass(ClassName.FADE);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (element.parentNode && $(element.parentNode).hasClass(ClassName.DROPDOWN_MENU)) {
|
|
||||||
|
|
||||||
var dropdownElement = $(element).closest(Selector.DROPDOWN)[0];
|
|
||||||
if (dropdownElement) {
|
|
||||||
$(dropdownElement).find(Selector.DROPDOWN_TOGGLE).addClass(ClassName.ACTIVE);
|
|
||||||
}
|
|
||||||
|
|
||||||
element.setAttribute('aria-expanded', true);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (callback) {
|
|
||||||
callback();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
|
|
||||||
}], [{
|
|
||||||
key: '_jQueryInterface',
|
|
||||||
value: function _jQueryInterface(config) {
|
|
||||||
return this.each(function () {
|
|
||||||
var $this = $(this);
|
|
||||||
var data = $this.data(DATA_KEY);
|
|
||||||
|
|
||||||
if (!data) {
|
|
||||||
data = data = new Tab(this);
|
|
||||||
$this.data(DATA_KEY, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (typeof config === 'string') {
|
|
||||||
if (data[config] === undefined) {
|
|
||||||
throw new Error('No method named "' + config + '"');
|
|
||||||
}
|
|
||||||
data[config]();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'VERSION',
|
|
||||||
get: function get() {
|
|
||||||
return VERSION;
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
return Tab;
|
|
||||||
})();
|
|
||||||
|
|
||||||
$(document).on(Event.CLICK_DATA_API, Selector.DATA_TOGGLE, function (event) {
|
|
||||||
event.preventDefault();
|
|
||||||
Tab._jQueryInterface.call($(this), 'show');
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* jQuery
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
$.fn[NAME] = Tab._jQueryInterface;
|
|
||||||
$.fn[NAME].Constructor = Tab;
|
|
||||||
$.fn[NAME].noConflict = function () {
|
|
||||||
$.fn[NAME] = JQUERY_NO_CONFLICT;
|
|
||||||
return Tab._jQueryInterface;
|
|
||||||
};
|
|
||||||
|
|
||||||
return Tab;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = Tab;
|
|
||||||
});
|
|
638
docs/dist/js/umd/tooltip.js
vendored
@ -1,638 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module', './util'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module, require('./util'));
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod, global.Util);
|
|
||||||
global.tooltip = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module, _util) {
|
|
||||||
/* global Tether */
|
|
||||||
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ('value' in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
|
||||||
|
|
||||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
|
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } }
|
|
||||||
|
|
||||||
var _Util = _interopRequireDefault(_util);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): tooltip.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Tooltip = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check for Tether dependency
|
|
||||||
* Tether - http://github.hubspot.com/tether/
|
|
||||||
*/
|
|
||||||
if (window.Tether === undefined) {
|
|
||||||
throw new Error('Bootstrap tooltips require Tether (http://github.hubspot.com/tether/)');
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Constants
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var NAME = 'tooltip';
|
|
||||||
var VERSION = '4.0.0-alpha.2';
|
|
||||||
var DATA_KEY = 'bs.tooltip';
|
|
||||||
var EVENT_KEY = '.' + DATA_KEY;
|
|
||||||
var JQUERY_NO_CONFLICT = $.fn[NAME];
|
|
||||||
var TRANSITION_DURATION = 150;
|
|
||||||
var CLASS_PREFIX = 'bs-tether';
|
|
||||||
|
|
||||||
var Default = {
|
|
||||||
animation: true,
|
|
||||||
template: '<div class="tooltip" role="tooltip">' + '<div class="tooltip-arrow"></div>' + '<div class="tooltip-inner"></div></div>',
|
|
||||||
trigger: 'hover focus',
|
|
||||||
title: '',
|
|
||||||
delay: 0,
|
|
||||||
html: false,
|
|
||||||
selector: false,
|
|
||||||
placement: 'top',
|
|
||||||
offset: '0 0',
|
|
||||||
constraints: []
|
|
||||||
};
|
|
||||||
|
|
||||||
var DefaultType = {
|
|
||||||
animation: 'boolean',
|
|
||||||
template: 'string',
|
|
||||||
title: '(string|element|function)',
|
|
||||||
trigger: 'string',
|
|
||||||
delay: '(number|object)',
|
|
||||||
html: 'boolean',
|
|
||||||
selector: '(string|boolean)',
|
|
||||||
placement: '(string|function)',
|
|
||||||
offset: 'string',
|
|
||||||
constraints: 'array'
|
|
||||||
};
|
|
||||||
|
|
||||||
var AttachmentMap = {
|
|
||||||
TOP: 'bottom center',
|
|
||||||
RIGHT: 'middle left',
|
|
||||||
BOTTOM: 'top center',
|
|
||||||
LEFT: 'middle right'
|
|
||||||
};
|
|
||||||
|
|
||||||
var HoverState = {
|
|
||||||
IN: 'in',
|
|
||||||
OUT: 'out'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Event = {
|
|
||||||
HIDE: 'hide' + EVENT_KEY,
|
|
||||||
HIDDEN: 'hidden' + EVENT_KEY,
|
|
||||||
SHOW: 'show' + EVENT_KEY,
|
|
||||||
SHOWN: 'shown' + EVENT_KEY,
|
|
||||||
INSERTED: 'inserted' + EVENT_KEY,
|
|
||||||
CLICK: 'click' + EVENT_KEY,
|
|
||||||
FOCUSIN: 'focusin' + EVENT_KEY,
|
|
||||||
FOCUSOUT: 'focusout' + EVENT_KEY,
|
|
||||||
MOUSEENTER: 'mouseenter' + EVENT_KEY,
|
|
||||||
MOUSELEAVE: 'mouseleave' + EVENT_KEY
|
|
||||||
};
|
|
||||||
|
|
||||||
var ClassName = {
|
|
||||||
FADE: 'fade',
|
|
||||||
IN: 'in'
|
|
||||||
};
|
|
||||||
|
|
||||||
var Selector = {
|
|
||||||
TOOLTIP: '.tooltip',
|
|
||||||
TOOLTIP_INNER: '.tooltip-inner'
|
|
||||||
};
|
|
||||||
|
|
||||||
var TetherClass = {
|
|
||||||
element: false,
|
|
||||||
enabled: false
|
|
||||||
};
|
|
||||||
|
|
||||||
var Trigger = {
|
|
||||||
HOVER: 'hover',
|
|
||||||
FOCUS: 'focus',
|
|
||||||
CLICK: 'click',
|
|
||||||
MANUAL: 'manual'
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Class Definition
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Tooltip = (function () {
|
|
||||||
function Tooltip(element, config) {
|
|
||||||
_classCallCheck(this, Tooltip);
|
|
||||||
|
|
||||||
// private
|
|
||||||
this._isEnabled = true;
|
|
||||||
this._timeout = 0;
|
|
||||||
this._hoverState = '';
|
|
||||||
this._activeTrigger = {};
|
|
||||||
this._tether = null;
|
|
||||||
|
|
||||||
// protected
|
|
||||||
this.element = element;
|
|
||||||
this.config = this._getConfig(config);
|
|
||||||
this.tip = null;
|
|
||||||
|
|
||||||
this._setListeners();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* jQuery
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
// getters
|
|
||||||
|
|
||||||
_createClass(Tooltip, [{
|
|
||||||
key: 'enable',
|
|
||||||
|
|
||||||
// public
|
|
||||||
|
|
||||||
value: function enable() {
|
|
||||||
this._isEnabled = true;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'disable',
|
|
||||||
value: function disable() {
|
|
||||||
this._isEnabled = false;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'toggleEnabled',
|
|
||||||
value: function toggleEnabled() {
|
|
||||||
this._isEnabled = !this._isEnabled;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'toggle',
|
|
||||||
value: function toggle(event) {
|
|
||||||
if (event) {
|
|
||||||
var dataKey = this.constructor.DATA_KEY;
|
|
||||||
var context = $(event.currentTarget).data(dataKey);
|
|
||||||
|
|
||||||
if (!context) {
|
|
||||||
context = new this.constructor(event.currentTarget, this._getDelegateConfig());
|
|
||||||
$(event.currentTarget).data(dataKey, context);
|
|
||||||
}
|
|
||||||
|
|
||||||
context._activeTrigger.click = !context._activeTrigger.click;
|
|
||||||
|
|
||||||
if (context._isWithActiveTrigger()) {
|
|
||||||
context._enter(null, context);
|
|
||||||
} else {
|
|
||||||
context._leave(null, context);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
|
|
||||||
if ($(this.getTipElement()).hasClass(ClassName.IN)) {
|
|
||||||
this._leave(null, this);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this._enter(null, this);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'dispose',
|
|
||||||
value: function dispose() {
|
|
||||||
clearTimeout(this._timeout);
|
|
||||||
|
|
||||||
this.cleanupTether();
|
|
||||||
|
|
||||||
$.removeData(this.element, this.constructor.DATA_KEY);
|
|
||||||
|
|
||||||
$(this.element).off(this.constructor.EVENT_KEY);
|
|
||||||
|
|
||||||
if (this.tip) {
|
|
||||||
$(this.tip).remove();
|
|
||||||
}
|
|
||||||
|
|
||||||
this._isEnabled = null;
|
|
||||||
this._timeout = null;
|
|
||||||
this._hoverState = null;
|
|
||||||
this._activeTrigger = null;
|
|
||||||
this._tether = null;
|
|
||||||
|
|
||||||
this.element = null;
|
|
||||||
this.config = null;
|
|
||||||
this.tip = null;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'show',
|
|
||||||
value: function show() {
|
|
||||||
var _this = this;
|
|
||||||
|
|
||||||
var showEvent = $.Event(this.constructor.Event.SHOW);
|
|
||||||
|
|
||||||
if (this.isWithContent() && this._isEnabled) {
|
|
||||||
$(this.element).trigger(showEvent);
|
|
||||||
|
|
||||||
var isInTheDom = $.contains(this.element.ownerDocument.documentElement, this.element);
|
|
||||||
|
|
||||||
if (showEvent.isDefaultPrevented() || !isInTheDom) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var tip = this.getTipElement();
|
|
||||||
var tipId = _Util['default'].getUID(this.constructor.NAME);
|
|
||||||
|
|
||||||
tip.setAttribute('id', tipId);
|
|
||||||
this.element.setAttribute('aria-describedby', tipId);
|
|
||||||
|
|
||||||
this.setContent();
|
|
||||||
|
|
||||||
if (this.config.animation) {
|
|
||||||
$(tip).addClass(ClassName.FADE);
|
|
||||||
}
|
|
||||||
|
|
||||||
var placement = typeof this.config.placement === 'function' ? this.config.placement.call(this, tip, this.element) : this.config.placement;
|
|
||||||
|
|
||||||
var attachment = this._getAttachment(placement);
|
|
||||||
|
|
||||||
$(tip).data(this.constructor.DATA_KEY, this).appendTo(document.body);
|
|
||||||
|
|
||||||
$(this.element).trigger(this.constructor.Event.INSERTED);
|
|
||||||
|
|
||||||
this._tether = new Tether({
|
|
||||||
attachment: attachment,
|
|
||||||
element: tip,
|
|
||||||
target: this.element,
|
|
||||||
classes: TetherClass,
|
|
||||||
classPrefix: CLASS_PREFIX,
|
|
||||||
offset: this.config.offset,
|
|
||||||
constraints: this.config.constraints,
|
|
||||||
addTargetClasses: false
|
|
||||||
});
|
|
||||||
|
|
||||||
_Util['default'].reflow(tip);
|
|
||||||
this._tether.position();
|
|
||||||
|
|
||||||
$(tip).addClass(ClassName.IN);
|
|
||||||
|
|
||||||
var complete = function complete() {
|
|
||||||
var prevHoverState = _this._hoverState;
|
|
||||||
_this._hoverState = null;
|
|
||||||
|
|
||||||
$(_this.element).trigger(_this.constructor.Event.SHOWN);
|
|
||||||
|
|
||||||
if (prevHoverState === HoverState.OUT) {
|
|
||||||
_this._leave(null, _this);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
if (_Util['default'].supportsTransitionEnd() && $(this.tip).hasClass(ClassName.FADE)) {
|
|
||||||
$(this.tip).one(_Util['default'].TRANSITION_END, complete).emulateTransitionEnd(Tooltip._TRANSITION_DURATION);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
complete();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'hide',
|
|
||||||
value: function hide(callback) {
|
|
||||||
var _this2 = this;
|
|
||||||
|
|
||||||
var tip = this.getTipElement();
|
|
||||||
var hideEvent = $.Event(this.constructor.Event.HIDE);
|
|
||||||
var complete = function complete() {
|
|
||||||
if (_this2._hoverState !== HoverState.IN && tip.parentNode) {
|
|
||||||
tip.parentNode.removeChild(tip);
|
|
||||||
}
|
|
||||||
|
|
||||||
_this2.element.removeAttribute('aria-describedby');
|
|
||||||
$(_this2.element).trigger(_this2.constructor.Event.HIDDEN);
|
|
||||||
_this2.cleanupTether();
|
|
||||||
|
|
||||||
if (callback) {
|
|
||||||
callback();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
$(this.element).trigger(hideEvent);
|
|
||||||
|
|
||||||
if (hideEvent.isDefaultPrevented()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$(tip).removeClass(ClassName.IN);
|
|
||||||
|
|
||||||
if (_Util['default'].supportsTransitionEnd() && $(this.tip).hasClass(ClassName.FADE)) {
|
|
||||||
|
|
||||||
$(tip).one(_Util['default'].TRANSITION_END, complete).emulateTransitionEnd(TRANSITION_DURATION);
|
|
||||||
} else {
|
|
||||||
complete();
|
|
||||||
}
|
|
||||||
|
|
||||||
this._hoverState = '';
|
|
||||||
}
|
|
||||||
|
|
||||||
// protected
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: 'isWithContent',
|
|
||||||
value: function isWithContent() {
|
|
||||||
return Boolean(this.getTitle());
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'getTipElement',
|
|
||||||
value: function getTipElement() {
|
|
||||||
return this.tip = this.tip || $(this.config.template)[0];
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'setContent',
|
|
||||||
value: function setContent() {
|
|
||||||
var $tip = $(this.getTipElement());
|
|
||||||
|
|
||||||
this.setElementContent($tip.find(Selector.TOOLTIP_INNER), this.getTitle());
|
|
||||||
|
|
||||||
$tip.removeClass(ClassName.FADE).removeClass(ClassName.IN);
|
|
||||||
|
|
||||||
this.cleanupTether();
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'setElementContent',
|
|
||||||
value: function setElementContent($element, content) {
|
|
||||||
var html = this.config.html;
|
|
||||||
if (typeof content === 'object' && (content.nodeType || content.jquery)) {
|
|
||||||
// content is a DOM node or a jQuery
|
|
||||||
if (html) {
|
|
||||||
if (!$(content).parent().is($element)) {
|
|
||||||
$element.empty().append(content);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$element.text($(content).text());
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$element[html ? 'html' : 'text'](content);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'getTitle',
|
|
||||||
value: function getTitle() {
|
|
||||||
var title = this.element.getAttribute('data-original-title');
|
|
||||||
|
|
||||||
if (!title) {
|
|
||||||
title = typeof this.config.title === 'function' ? this.config.title.call(this.element) : this.config.title;
|
|
||||||
}
|
|
||||||
|
|
||||||
return title;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'cleanupTether',
|
|
||||||
value: function cleanupTether() {
|
|
||||||
if (this._tether) {
|
|
||||||
this._tether.destroy();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// private
|
|
||||||
|
|
||||||
}, {
|
|
||||||
key: '_getAttachment',
|
|
||||||
value: function _getAttachment(placement) {
|
|
||||||
return AttachmentMap[placement.toUpperCase()];
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_setListeners',
|
|
||||||
value: function _setListeners() {
|
|
||||||
var _this3 = this;
|
|
||||||
|
|
||||||
var triggers = this.config.trigger.split(' ');
|
|
||||||
|
|
||||||
triggers.forEach(function (trigger) {
|
|
||||||
if (trigger === 'click') {
|
|
||||||
$(_this3.element).on(_this3.constructor.Event.CLICK, _this3.config.selector, $.proxy(_this3.toggle, _this3));
|
|
||||||
} else if (trigger !== Trigger.MANUAL) {
|
|
||||||
var eventIn = trigger === Trigger.HOVER ? _this3.constructor.Event.MOUSEENTER : _this3.constructor.Event.FOCUSIN;
|
|
||||||
var eventOut = trigger === Trigger.HOVER ? _this3.constructor.Event.MOUSELEAVE : _this3.constructor.Event.FOCUSOUT;
|
|
||||||
|
|
||||||
$(_this3.element).on(eventIn, _this3.config.selector, $.proxy(_this3._enter, _this3)).on(eventOut, _this3.config.selector, $.proxy(_this3._leave, _this3));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
if (this.config.selector) {
|
|
||||||
this.config = $.extend({}, this.config, {
|
|
||||||
trigger: 'manual',
|
|
||||||
selector: ''
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
this._fixTitle();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_fixTitle',
|
|
||||||
value: function _fixTitle() {
|
|
||||||
var titleType = typeof this.element.getAttribute('data-original-title');
|
|
||||||
if (this.element.getAttribute('title') || titleType !== 'string') {
|
|
||||||
this.element.setAttribute('data-original-title', this.element.getAttribute('title') || '');
|
|
||||||
this.element.setAttribute('title', '');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_enter',
|
|
||||||
value: function _enter(event, context) {
|
|
||||||
var dataKey = this.constructor.DATA_KEY;
|
|
||||||
|
|
||||||
context = context || $(event.currentTarget).data(dataKey);
|
|
||||||
|
|
||||||
if (!context) {
|
|
||||||
context = new this.constructor(event.currentTarget, this._getDelegateConfig());
|
|
||||||
$(event.currentTarget).data(dataKey, context);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (event) {
|
|
||||||
context._activeTrigger[event.type === 'focusin' ? Trigger.FOCUS : Trigger.HOVER] = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($(context.getTipElement()).hasClass(ClassName.IN) || context._hoverState === HoverState.IN) {
|
|
||||||
context._hoverState = HoverState.IN;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
clearTimeout(context._timeout);
|
|
||||||
|
|
||||||
context._hoverState = HoverState.IN;
|
|
||||||
|
|
||||||
if (!context.config.delay || !context.config.delay.show) {
|
|
||||||
context.show();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
context._timeout = setTimeout(function () {
|
|
||||||
if (context._hoverState === HoverState.IN) {
|
|
||||||
context.show();
|
|
||||||
}
|
|
||||||
}, context.config.delay.show);
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_leave',
|
|
||||||
value: function _leave(event, context) {
|
|
||||||
var dataKey = this.constructor.DATA_KEY;
|
|
||||||
|
|
||||||
context = context || $(event.currentTarget).data(dataKey);
|
|
||||||
|
|
||||||
if (!context) {
|
|
||||||
context = new this.constructor(event.currentTarget, this._getDelegateConfig());
|
|
||||||
$(event.currentTarget).data(dataKey, context);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (event) {
|
|
||||||
context._activeTrigger[event.type === 'focusout' ? Trigger.FOCUS : Trigger.HOVER] = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (context._isWithActiveTrigger()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
clearTimeout(context._timeout);
|
|
||||||
|
|
||||||
context._hoverState = HoverState.OUT;
|
|
||||||
|
|
||||||
if (!context.config.delay || !context.config.delay.hide) {
|
|
||||||
context.hide();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
context._timeout = setTimeout(function () {
|
|
||||||
if (context._hoverState === HoverState.OUT) {
|
|
||||||
context.hide();
|
|
||||||
}
|
|
||||||
}, context.config.delay.hide);
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_isWithActiveTrigger',
|
|
||||||
value: function _isWithActiveTrigger() {
|
|
||||||
for (var trigger in this._activeTrigger) {
|
|
||||||
if (this._activeTrigger[trigger]) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_getConfig',
|
|
||||||
value: function _getConfig(config) {
|
|
||||||
config = $.extend({}, this.constructor.Default, $(this.element).data(), config);
|
|
||||||
|
|
||||||
if (config.delay && typeof config.delay === 'number') {
|
|
||||||
config.delay = {
|
|
||||||
show: config.delay,
|
|
||||||
hide: config.delay
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
_Util['default'].typeCheckConfig(NAME, config, this.constructor.DefaultType);
|
|
||||||
|
|
||||||
return config;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: '_getDelegateConfig',
|
|
||||||
value: function _getDelegateConfig() {
|
|
||||||
var config = {};
|
|
||||||
|
|
||||||
if (this.config) {
|
|
||||||
for (var key in this.config) {
|
|
||||||
if (this.constructor.Default[key] !== this.config[key]) {
|
|
||||||
config[key] = this.config[key];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return config;
|
|
||||||
}
|
|
||||||
|
|
||||||
// static
|
|
||||||
|
|
||||||
}], [{
|
|
||||||
key: '_jQueryInterface',
|
|
||||||
value: function _jQueryInterface(config) {
|
|
||||||
return this.each(function () {
|
|
||||||
var data = $(this).data(DATA_KEY);
|
|
||||||
var _config = typeof config === 'object' ? config : null;
|
|
||||||
|
|
||||||
if (!data && /destroy|hide/.test(config)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!data) {
|
|
||||||
data = new Tooltip(this, _config);
|
|
||||||
$(this).data(DATA_KEY, data);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (typeof config === 'string') {
|
|
||||||
if (data[config] === undefined) {
|
|
||||||
throw new Error('No method named "' + config + '"');
|
|
||||||
}
|
|
||||||
data[config]();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'VERSION',
|
|
||||||
get: function get() {
|
|
||||||
return VERSION;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'Default',
|
|
||||||
get: function get() {
|
|
||||||
return Default;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'NAME',
|
|
||||||
get: function get() {
|
|
||||||
return NAME;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'DATA_KEY',
|
|
||||||
get: function get() {
|
|
||||||
return DATA_KEY;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'Event',
|
|
||||||
get: function get() {
|
|
||||||
return Event;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'EVENT_KEY',
|
|
||||||
get: function get() {
|
|
||||||
return EVENT_KEY;
|
|
||||||
}
|
|
||||||
}, {
|
|
||||||
key: 'DefaultType',
|
|
||||||
get: function get() {
|
|
||||||
return DefaultType;
|
|
||||||
}
|
|
||||||
}]);
|
|
||||||
|
|
||||||
return Tooltip;
|
|
||||||
})();
|
|
||||||
|
|
||||||
$.fn[NAME] = Tooltip._jQueryInterface;
|
|
||||||
$.fn[NAME].Constructor = Tooltip;
|
|
||||||
$.fn[NAME].noConflict = function () {
|
|
||||||
$.fn[NAME] = JQUERY_NO_CONFLICT;
|
|
||||||
return Tooltip._jQueryInterface;
|
|
||||||
};
|
|
||||||
|
|
||||||
return Tooltip;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = Tooltip;
|
|
||||||
});
|
|
174
docs/dist/js/umd/util.js
vendored
@ -1,174 +0,0 @@
|
|||||||
(function (global, factory) {
|
|
||||||
if (typeof define === 'function' && define.amd) {
|
|
||||||
define(['exports', 'module'], factory);
|
|
||||||
} else if (typeof exports !== 'undefined' && typeof module !== 'undefined') {
|
|
||||||
factory(exports, module);
|
|
||||||
} else {
|
|
||||||
var mod = {
|
|
||||||
exports: {}
|
|
||||||
};
|
|
||||||
factory(mod.exports, mod);
|
|
||||||
global.util = mod.exports;
|
|
||||||
}
|
|
||||||
})(this, function (exports, module) {
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Bootstrap (v4.0.0-alpha.2): util.js
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var Util = (function ($) {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
* Private TransitionEnd Helpers
|
|
||||||
* ------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var transition = false;
|
|
||||||
|
|
||||||
var TransitionEndEvent = {
|
|
||||||
WebkitTransition: 'webkitTransitionEnd',
|
|
||||||
MozTransition: 'transitionend',
|
|
||||||
OTransition: 'oTransitionEnd otransitionend',
|
|
||||||
transition: 'transitionend'
|
|
||||||
};
|
|
||||||
|
|
||||||
// shoutout AngusCroll (https://goo.gl/pxwQGp)
|
|
||||||
function toType(obj) {
|
|
||||||
return ({}).toString.call(obj).match(/\s([a-zA-Z]+)/)[1].toLowerCase();
|
|
||||||
}
|
|
||||||
|
|
||||||
function isElement(obj) {
|
|
||||||
return (obj[0] || obj).nodeType;
|
|
||||||
}
|
|
||||||
|
|
||||||
function getSpecialTransitionEndEvent() {
|
|
||||||
return {
|
|
||||||
bindType: transition.end,
|
|
||||||
delegateType: transition.end,
|
|
||||||
handle: function handle(event) {
|
|
||||||
if ($(event.target).is(this)) {
|
|
||||||
return event.handleObj.handler.apply(this, arguments);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
function transitionEndTest() {
|
|
||||||
if (window.QUnit) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
var el = document.createElement('bootstrap');
|
|
||||||
|
|
||||||
for (var _name in TransitionEndEvent) {
|
|
||||||
if (el.style[_name] !== undefined) {
|
|
||||||
return { end: TransitionEndEvent[_name] };
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
function transitionEndEmulator(duration) {
|
|
||||||
var _this = this;
|
|
||||||
|
|
||||||
var called = false;
|
|
||||||
|
|
||||||
$(this).one(Util.TRANSITION_END, function () {
|
|
||||||
called = true;
|
|
||||||
});
|
|
||||||
|
|
||||||
setTimeout(function () {
|
|
||||||
if (!called) {
|
|
||||||
Util.triggerTransitionEnd(_this);
|
|
||||||
}
|
|
||||||
}, duration);
|
|
||||||
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
function setTransitionEndSupport() {
|
|
||||||
transition = transitionEndTest();
|
|
||||||
|
|
||||||
$.fn.emulateTransitionEnd = transitionEndEmulator;
|
|
||||||
|
|
||||||
if (Util.supportsTransitionEnd()) {
|
|
||||||
$.event.special[Util.TRANSITION_END] = getSpecialTransitionEndEvent();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
* Public Util Api
|
|
||||||
* --------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Util = {
|
|
||||||
|
|
||||||
TRANSITION_END: 'bsTransitionEnd',
|
|
||||||
|
|
||||||
getUID: function getUID(prefix) {
|
|
||||||
do {
|
|
||||||
/* eslint-disable no-bitwise */
|
|
||||||
prefix += ~ ~(Math.random() * 1000000); // "~~" acts like a faster Math.floor() here
|
|
||||||
/* eslint-enable no-bitwise */
|
|
||||||
} while (document.getElementById(prefix));
|
|
||||||
return prefix;
|
|
||||||
},
|
|
||||||
|
|
||||||
getSelectorFromElement: function getSelectorFromElement(element) {
|
|
||||||
var selector = element.getAttribute('data-target');
|
|
||||||
|
|
||||||
if (!selector) {
|
|
||||||
selector = element.getAttribute('href') || '';
|
|
||||||
selector = /^#[a-z]/i.test(selector) ? selector : null;
|
|
||||||
}
|
|
||||||
|
|
||||||
return selector;
|
|
||||||
},
|
|
||||||
|
|
||||||
reflow: function reflow(element) {
|
|
||||||
new Function('bs', 'return bs')(element.offsetHeight);
|
|
||||||
},
|
|
||||||
|
|
||||||
triggerTransitionEnd: function triggerTransitionEnd(element) {
|
|
||||||
$(element).trigger(transition.end);
|
|
||||||
},
|
|
||||||
|
|
||||||
supportsTransitionEnd: function supportsTransitionEnd() {
|
|
||||||
return Boolean(transition);
|
|
||||||
},
|
|
||||||
|
|
||||||
typeCheckConfig: function typeCheckConfig(componentName, config, configTypes) {
|
|
||||||
for (var property in configTypes) {
|
|
||||||
if (configTypes.hasOwnProperty(property)) {
|
|
||||||
var expectedTypes = configTypes[property];
|
|
||||||
var value = config[property];
|
|
||||||
var valueType = undefined;
|
|
||||||
|
|
||||||
if (value && isElement(value)) {
|
|
||||||
valueType = 'element';
|
|
||||||
} else {
|
|
||||||
valueType = toType(value);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!new RegExp(expectedTypes).test(valueType)) {
|
|
||||||
throw new Error(componentName.toUpperCase() + ': ' + ('Option "' + property + '" provided type "' + valueType + '" ') + ('but expected type "' + expectedTypes + '".'));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
setTransitionEndSupport();
|
|
||||||
|
|
||||||
return Util;
|
|
||||||
})(jQuery);
|
|
||||||
|
|
||||||
module.exports = Util;
|
|
||||||
});
|
|
@ -115,7 +115,7 @@
|
|||||||
<!-- Bootstrap core JavaScript
|
<!-- Bootstrap core JavaScript
|
||||||
================================================== -->
|
================================================== -->
|
||||||
<!-- Placed at the end of the document so the pages load faster -->
|
<!-- Placed at the end of the document so the pages load faster -->
|
||||||
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.2/jquery.min.js" integrity="sha384-mXQoED/lFIuocc//nss8aJOIrz7X7XruhR6bO+sGceiSyMELoVdZkN7F0oYwcFH+" crossorigin="anonymous"></script>
|
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.0.0/jquery.min.js" integrity="sha384-THPy051/pYDQGanwU6poAc/hOdQxjnOEXzbT+OuUAFqNqFjL+4IGLBgCJC3ZOShY" crossorigin="anonymous"></script>
|
||||||
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
||||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
||||||
<script src="../../assets/js/vendor/holder.min.js"></script>
|
<script src="../../assets/js/vendor/holder.min.js"></script>
|
||||||
|
@ -158,7 +158,7 @@
|
|||||||
<!-- Bootstrap core JavaScript
|
<!-- Bootstrap core JavaScript
|
||||||
================================================== -->
|
================================================== -->
|
||||||
<!-- Placed at the end of the document so the pages load faster -->
|
<!-- Placed at the end of the document so the pages load faster -->
|
||||||
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.2/jquery.min.js" integrity="sha384-mXQoED/lFIuocc//nss8aJOIrz7X7XruhR6bO+sGceiSyMELoVdZkN7F0oYwcFH+" crossorigin="anonymous"></script>
|
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.0.0/jquery.min.js" integrity="sha384-THPy051/pYDQGanwU6poAc/hOdQxjnOEXzbT+OuUAFqNqFjL+4IGLBgCJC3ZOShY" crossorigin="anonymous"></script>
|
||||||
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
||||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
||||||
<script src="../../dist/js/bootstrap.min.js"></script>
|
<script src="../../dist/js/bootstrap.min.js"></script>
|
||||||
|
@ -174,7 +174,7 @@
|
|||||||
<!-- Bootstrap core JavaScript
|
<!-- Bootstrap core JavaScript
|
||||||
================================================== -->
|
================================================== -->
|
||||||
<!-- Placed at the end of the document so the pages load faster -->
|
<!-- Placed at the end of the document so the pages load faster -->
|
||||||
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.2/jquery.min.js" integrity="sha384-mXQoED/lFIuocc//nss8aJOIrz7X7XruhR6bO+sGceiSyMELoVdZkN7F0oYwcFH+" crossorigin="anonymous"></script>
|
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.0.0/jquery.min.js" integrity="sha384-THPy051/pYDQGanwU6poAc/hOdQxjnOEXzbT+OuUAFqNqFjL+4IGLBgCJC3ZOShY" crossorigin="anonymous"></script>
|
||||||
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
||||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
||||||
<script src="../../dist/js/bootstrap.min.js"></script>
|
<script src="../../dist/js/bootstrap.min.js"></script>
|
||||||
|
@ -60,7 +60,7 @@
|
|||||||
<!-- Bootstrap core JavaScript
|
<!-- Bootstrap core JavaScript
|
||||||
================================================== -->
|
================================================== -->
|
||||||
<!-- Placed at the end of the document so the pages load faster -->
|
<!-- Placed at the end of the document so the pages load faster -->
|
||||||
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.2/jquery.min.js" integrity="sha384-mXQoED/lFIuocc//nss8aJOIrz7X7XruhR6bO+sGceiSyMELoVdZkN7F0oYwcFH+" crossorigin="anonymous"></script>
|
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.0.0/jquery.min.js" integrity="sha384-THPy051/pYDQGanwU6poAc/hOdQxjnOEXzbT+OuUAFqNqFjL+4IGLBgCJC3ZOShY" crossorigin="anonymous"></script>
|
||||||
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
||||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
||||||
<script src="../../dist/js/bootstrap.min.js"></script>
|
<script src="../../dist/js/bootstrap.min.js"></script>
|
||||||
|
@ -224,7 +224,7 @@
|
|||||||
<!-- Bootstrap core JavaScript
|
<!-- Bootstrap core JavaScript
|
||||||
================================================== -->
|
================================================== -->
|
||||||
<!-- Placed at the end of the document so the pages load faster -->
|
<!-- Placed at the end of the document so the pages load faster -->
|
||||||
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.2/jquery.min.js" integrity="sha384-mXQoED/lFIuocc//nss8aJOIrz7X7XruhR6bO+sGceiSyMELoVdZkN7F0oYwcFH+" crossorigin="anonymous"></script>
|
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.0.0/jquery.min.js" integrity="sha384-THPy051/pYDQGanwU6poAc/hOdQxjnOEXzbT+OuUAFqNqFjL+4IGLBgCJC3ZOShY" crossorigin="anonymous"></script>
|
||||||
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
||||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
||||||
<script src="../../dist/js/bootstrap.min.js"></script>
|
<script src="../../dist/js/bootstrap.min.js"></script>
|
||||||
|
@ -157,11 +157,11 @@
|
|||||||
<p>Reset offsets, pushes, and pulls at specific breakpoints.</p>
|
<p>Reset offsets, pushes, and pulls at specific breakpoints.</p>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-sm-5 col-md-6">.col-sm-5 .col-md-6</div>
|
<div class="col-sm-5 col-md-6">.col-sm-5 .col-md-6</div>
|
||||||
<div class="col-sm-5 offset-sm-2 col-md-6 offset-md-0">.col-sm-5 .col-sm-offset-2 .col-md-6 .col-md-offset-0</div>
|
<div class="col-sm-5 offset-sm-2 col-md-6 offset-md-0">.col-sm-5 .offset-sm-2 .col-md-6 .offset-md-0</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-sm-6 col-md-5 col-lg-6">.col-sm-6 .col-md-5 .col-lg-6</div>
|
<div class="col-sm-6 col-md-5 col-lg-6">.col-sm-6 .col-md-5 .col-lg-6</div>
|
||||||
<div class="col-sm-6 col-md-5 offset-md-2 col-lg-6 offset-lg-0">.col-sm-6 .col-md-5 .col-md-offset-2 .col-lg-6 .col-lg-offset-0</div>
|
<div class="col-sm-6 col-md-5 offset-md-2 col-lg-6 offset-lg-0">.col-sm-6 .col-md-5 .offset-md-2 .col-lg-6 .offset-lg-0</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
@ -75,7 +75,7 @@
|
|||||||
<!-- Bootstrap core JavaScript
|
<!-- Bootstrap core JavaScript
|
||||||
================================================== -->
|
================================================== -->
|
||||||
<!-- Placed at the end of the document so the pages load faster -->
|
<!-- Placed at the end of the document so the pages load faster -->
|
||||||
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.2/jquery.min.js" integrity="sha384-mXQoED/lFIuocc//nss8aJOIrz7X7XruhR6bO+sGceiSyMELoVdZkN7F0oYwcFH+" crossorigin="anonymous"></script>
|
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.0.0/jquery.min.js" integrity="sha384-THPy051/pYDQGanwU6poAc/hOdQxjnOEXzbT+OuUAFqNqFjL+4IGLBgCJC3ZOShY" crossorigin="anonymous"></script>
|
||||||
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
||||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
||||||
<script src="../../dist/js/bootstrap.min.js"></script>
|
<script src="../../dist/js/bootstrap.min.js"></script>
|
||||||
|
@ -45,7 +45,7 @@
|
|||||||
<!-- Bootstrap core JavaScript
|
<!-- Bootstrap core JavaScript
|
||||||
================================================== -->
|
================================================== -->
|
||||||
<!-- Placed at the end of the document so the pages load faster -->
|
<!-- Placed at the end of the document so the pages load faster -->
|
||||||
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.2/jquery.min.js" integrity="sha384-mXQoED/lFIuocc//nss8aJOIrz7X7XruhR6bO+sGceiSyMELoVdZkN7F0oYwcFH+" crossorigin="anonymous"></script>
|
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.0.0/jquery.min.js" integrity="sha384-THPy051/pYDQGanwU6poAc/hOdQxjnOEXzbT+OuUAFqNqFjL+4IGLBgCJC3ZOShY" crossorigin="anonymous"></script>
|
||||||
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
||||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
||||||
<script src="../../dist/js/bootstrap.min.js"></script>
|
<script src="../../dist/js/bootstrap.min.js"></script>
|
||||||
|
@ -43,7 +43,7 @@
|
|||||||
<!-- Bootstrap core JavaScript
|
<!-- Bootstrap core JavaScript
|
||||||
================================================== -->
|
================================================== -->
|
||||||
<!-- Placed at the end of the document so the pages load faster -->
|
<!-- Placed at the end of the document so the pages load faster -->
|
||||||
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.2/jquery.min.js" integrity="sha384-mXQoED/lFIuocc//nss8aJOIrz7X7XruhR6bO+sGceiSyMELoVdZkN7F0oYwcFH+" crossorigin="anonymous"></script>
|
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.0.0/jquery.min.js" integrity="sha384-THPy051/pYDQGanwU6poAc/hOdQxjnOEXzbT+OuUAFqNqFjL+4IGLBgCJC3ZOShY" crossorigin="anonymous"></script>
|
||||||
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
||||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
||||||
<script src="../../dist/js/bootstrap.min.js"></script>
|
<script src="../../dist/js/bootstrap.min.js"></script>
|
||||||
|
@ -64,7 +64,7 @@
|
|||||||
<!-- Bootstrap core JavaScript
|
<!-- Bootstrap core JavaScript
|
||||||
================================================== -->
|
================================================== -->
|
||||||
<!-- Placed at the end of the document so the pages load faster -->
|
<!-- Placed at the end of the document so the pages load faster -->
|
||||||
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.2/jquery.min.js" integrity="sha384-mXQoED/lFIuocc//nss8aJOIrz7X7XruhR6bO+sGceiSyMELoVdZkN7F0oYwcFH+" crossorigin="anonymous"></script>
|
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.0.0/jquery.min.js" integrity="sha384-THPy051/pYDQGanwU6poAc/hOdQxjnOEXzbT+OuUAFqNqFjL+4IGLBgCJC3ZOShY" crossorigin="anonymous"></script>
|
||||||
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
||||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
||||||
<script src="../../dist/js/bootstrap.min.js"></script>
|
<script src="../../dist/js/bootstrap.min.js"></script>
|
||||||
|
@ -104,7 +104,7 @@
|
|||||||
<!-- Bootstrap core JavaScript
|
<!-- Bootstrap core JavaScript
|
||||||
================================================== -->
|
================================================== -->
|
||||||
<!-- Placed at the end of the document so the pages load faster -->
|
<!-- Placed at the end of the document so the pages load faster -->
|
||||||
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.2/jquery.min.js" integrity="sha384-mXQoED/lFIuocc//nss8aJOIrz7X7XruhR6bO+sGceiSyMELoVdZkN7F0oYwcFH+" crossorigin="anonymous"></script>
|
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.0.0/jquery.min.js" integrity="sha384-THPy051/pYDQGanwU6poAc/hOdQxjnOEXzbT+OuUAFqNqFjL+4IGLBgCJC3ZOShY" crossorigin="anonymous"></script>
|
||||||
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
||||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
||||||
<script src="../../dist/js/bootstrap.min.js"></script>
|
<script src="../../dist/js/bootstrap.min.js"></script>
|
||||||
|
@ -48,7 +48,7 @@
|
|||||||
<!-- Bootstrap core JavaScript
|
<!-- Bootstrap core JavaScript
|
||||||
================================================== -->
|
================================================== -->
|
||||||
<!-- Placed at the end of the document so the pages load faster -->
|
<!-- Placed at the end of the document so the pages load faster -->
|
||||||
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.2/jquery.min.js" integrity="sha384-mXQoED/lFIuocc//nss8aJOIrz7X7XruhR6bO+sGceiSyMELoVdZkN7F0oYwcFH+" crossorigin="anonymous"></script>
|
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.0.0/jquery.min.js" integrity="sha384-THPy051/pYDQGanwU6poAc/hOdQxjnOEXzbT+OuUAFqNqFjL+4IGLBgCJC3ZOShY" crossorigin="anonymous"></script>
|
||||||
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
||||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
||||||
<script src="../../dist/js/bootstrap.min.js"></script>
|
<script src="../../dist/js/bootstrap.min.js"></script>
|
||||||
|
@ -59,7 +59,7 @@
|
|||||||
<div class="m-t-1">
|
<div class="m-t-1">
|
||||||
<h1>Sticky footer with fixed navbar</h1>
|
<h1>Sticky footer with fixed navbar</h1>
|
||||||
</div>
|
</div>
|
||||||
<p class="lead">Pin a fixed-height footer to the bottom of the viewport in desktop browsers with this custom HTML and CSS. A fixed navbar has been added with <code>padding-top: 60px;</code> on the <code>body > .container</code>.</p>
|
<p class="lead">Pin a fixed-height footer to the bottom of the viewport in desktop browsers with this custom HTML and CSS. A fixed navbar has been added with <code>padding-top: 60px;</code> on the <code>body > .container</code>.</p>
|
||||||
<p>Back to <a href="../sticky-footer">the default sticky footer</a> minus the navbar.</p>
|
<p>Back to <a href="../sticky-footer">the default sticky footer</a> minus the navbar.</p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@ -73,7 +73,7 @@
|
|||||||
<!-- Bootstrap core JavaScript
|
<!-- Bootstrap core JavaScript
|
||||||
================================================== -->
|
================================================== -->
|
||||||
<!-- Placed at the end of the document so the pages load faster -->
|
<!-- Placed at the end of the document so the pages load faster -->
|
||||||
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.2/jquery.min.js" integrity="sha384-mXQoED/lFIuocc//nss8aJOIrz7X7XruhR6bO+sGceiSyMELoVdZkN7F0oYwcFH+" crossorigin="anonymous"></script>
|
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.0.0/jquery.min.js" integrity="sha384-THPy051/pYDQGanwU6poAc/hOdQxjnOEXzbT+OuUAFqNqFjL+4IGLBgCJC3ZOShY" crossorigin="anonymous"></script>
|
||||||
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
||||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
||||||
<script src="../../dist/js/bootstrap.min.js"></script>
|
<script src="../../dist/js/bootstrap.min.js"></script>
|
||||||
|
@ -39,7 +39,7 @@
|
|||||||
<!-- Bootstrap core JavaScript
|
<!-- Bootstrap core JavaScript
|
||||||
================================================== -->
|
================================================== -->
|
||||||
<!-- Placed at the end of the document so the pages load faster -->
|
<!-- Placed at the end of the document so the pages load faster -->
|
||||||
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.2/jquery.min.js" integrity="sha384-mXQoED/lFIuocc//nss8aJOIrz7X7XruhR6bO+sGceiSyMELoVdZkN7F0oYwcFH+" crossorigin="anonymous"></script>
|
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.0.0/jquery.min.js" integrity="sha384-THPy051/pYDQGanwU6poAc/hOdQxjnOEXzbT+OuUAFqNqFjL+4IGLBgCJC3ZOShY" crossorigin="anonymous"></script>
|
||||||
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
<script>window.jQuery || document.write('<script src="../../assets/js/vendor/jquery.min.js"><\/script>')</script>
|
||||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/tether/1.2.0/js/tether.min.js" integrity="sha384-Plbmg8JY28KFelvJVai01l8WyZzrYWG825m+cZ0eDDS1f7d/js6ikvy1+X+guPIB" crossorigin="anonymous"></script>
|
||||||
<script src="../../dist/js/bootstrap.min.js"></script>
|
<script src="../../dist/js/bootstrap.min.js"></script>
|
||||||
|
@ -22,10 +22,10 @@ In addition, groups and toolbars should be given an explicit label, as most assi
|
|||||||
|
|
||||||
## Skip navigation
|
## Skip navigation
|
||||||
|
|
||||||
If your navigation contains many links and comes before the main content in the DOM, add a `Skip to main content` link before the navigation (for a simple explanation, see this [A11Y Project article on skip navigation links](http://a11yproject.com/posts/skip-nav-links/)). Using the `.sr-only` class will visually hide the skip link, and the <code>.sr-only-focusable</code> class will ensure that the link becomes visible once focused (for sighted keyboard users).
|
If your navigation contains many links and comes before the main content in the DOM, add a `Skip to main content` link before the navigation (for a simple explanation, see this [A11Y Project article on skip navigation links](http://a11yproject.com/posts/skip-nav-links)). Using the `.sr-only` class will visually hide the skip link, and the <code>.sr-only-focusable</code> class will ensure that the link becomes visible once focused (for sighted keyboard users).
|
||||||
|
|
||||||
{% callout danger %}
|
{% callout danger %}
|
||||||
Due to long-standing shortcomings/bugs in Chrome (see [issue 454172 in the Chromium bug tracker](https://code.google.com/p/chromium/issues/detail?id=454172 "Chromium bug tracker - Issue 454172: Focus Link Target (sequential focus navigation starting point)")) and Internet Explorer (see this article on [in-page links and focus order](http://accessibleculture.org/articles/2010/05/in-page-links/)), you will need to make sure that the target of your skip link is at least programmatically focusable by adding `tabindex="-1"`.
|
Due to long-standing shortcomings/bugs in Internet Explorer (see this article on [in-page links and focus order](http://accessibleculture.org/articles/2010/05/in-page-links/)), you will need to make sure that the target of your skip link is at least programmatically focusable by adding `tabindex="-1"`.
|
||||||
|
|
||||||
In addition, you may want to explicitly suppress a visible focus indication on the target (particularly as Chrome currently also sets focus on elements with `tabindex="-1"` when they are clicked with the mouse) with `#content:focus { outline: none; }`.
|
In addition, you may want to explicitly suppress a visible focus indication on the target (particularly as Chrome currently also sets focus on elements with `tabindex="-1"` when they are clicked with the mouse) with `#content:focus { outline: none; }`.
|
||||||
|
|
||||||
|
@ -219,13 +219,7 @@ Bootstrap includes a workaround for this, although it is disabled by default. By
|
|||||||
|
|
||||||
Even in some modern browsers, printing can be quirky.
|
Even in some modern browsers, printing can be quirky.
|
||||||
|
|
||||||
In particular, as of Chrome v32 and regardless of margin settings, Chrome uses a viewport width significantly narrower than the physical paper size when resolving media queries while printing a webpage. This can result in Bootstrap's extra-small grid being unexpectedly activated when printing. See [issue #12078](https://github.com/twbs/bootstrap/issues/12078) and [Chrome bug #273306](https://bugs.chromium.org/p/chromium/issues/detail?id=273306) for some details. Suggested workarounds:
|
As of Safari v8.0, use of the fixed-width `.container` class can cause Safari to use an unusually small font size when printing. See [issue #14868](https://github.com/twbs/bootstrap/issues/14868) and [WebKit bug #138192](https://bugs.webkit.org/show_bug.cgi?id=138192) for more details. One potential workaround is the following CSS:
|
||||||
|
|
||||||
* Embrace the extra-small grid and make sure your page looks acceptable under it.
|
|
||||||
* Customize the value of the `$grid-breakpoints` Sass variable so that your printer paper is considered larger than extra-small.
|
|
||||||
* Add custom media queries to change the grid size breakpoints for print media only.
|
|
||||||
|
|
||||||
Also, as of Safari v8.0, use of the fixed-width `.container` class can cause Safari to use an unusually small font size when printing. See [issue #14868](https://github.com/twbs/bootstrap/issues/14868) and [WebKit bug #138192](https://bugs.webkit.org/show_bug.cgi?id=138192) for more details. One potential workaround is the following CSS:
|
|
||||||
|
|
||||||
{% highlight css %}
|
{% highlight css %}
|
||||||
@media print {
|
@media print {
|
||||||
|
@ -46,7 +46,7 @@ For example, run `TWBS_SASS=sass grunt` to test and build Bootstrap with Ruby Sa
|
|||||||
|
|
||||||
Bootstrap uses [Autoprefixer][autoprefixer] (included in our Gruntfile and build process) to automatically add vendor prefixes to some CSS properties at build time. Doing so saves us time and code by allowing us to write key parts of our CSS a single time while eliminating the need for vendor mixins like those found in v3.
|
Bootstrap uses [Autoprefixer][autoprefixer] (included in our Gruntfile and build process) to automatically add vendor prefixes to some CSS properties at build time. Doing so saves us time and code by allowing us to write key parts of our CSS a single time while eliminating the need for vendor mixins like those found in v3.
|
||||||
|
|
||||||
We maintain the list of browsers supported through Autoprefixer in a separate file within our GitHub repository. See [`/grunt/autoprefixer-settings.json`](https://github.com/twbs/bootstrap/blob/master/grunt/autoprefixer-settings.js) for details.
|
We maintain the list of browsers supported through Autoprefixer in a separate file within our GitHub repository. See [`/grunt/postcss.js`](https://github.com/twbs/bootstrap/blob/master/grunt/postcss.js) for details.
|
||||||
|
|
||||||
## Local documentation
|
## Local documentation
|
||||||
|
|
||||||
|
@ -6,31 +6,14 @@ group: getting-started
|
|||||||
|
|
||||||
**Bootstrap v{{ site.current_version}}** is available for download in several ways, including some of your favorite package managers. Choose from the options below to snag just what you need.
|
**Bootstrap v{{ site.current_version}}** is available for download in several ways, including some of your favorite package managers. Choose from the options below to snag just what you need.
|
||||||
|
|
||||||
<div class="row m-t-2">
|
|
||||||
<div class="col-sm-6">
|
|
||||||
{% markdown %}
|
|
||||||
### Compiled
|
|
||||||
Download just the compiled and minified CSS and JavaScript. Doesn't include any documentation or original source files.
|
|
||||||
|
|
||||||
{% comment %}
|
|
||||||
<a href="{{ site.download.dist }}" class="btn btn-bs btn-outline" onclick="ga('send', 'event', 'Getting started', 'Download', 'Download compiled');">Download Bootstrap</a>
|
|
||||||
{% endcomment %}
|
|
||||||
<span class="text-muted">Coming soon!</span>
|
|
||||||
{% endmarkdown %}
|
|
||||||
</div>
|
|
||||||
<div class="col-sm-6">
|
|
||||||
{% markdown %}
|
|
||||||
### Source files
|
### Source files
|
||||||
Download everything: source Sass, JavaScript, and documentation files. **Requires a Sass compiler, [Autoprefixer](https://github.com/postcss/autoprefixer), and [some setup]({{ site.baseurl }}/getting-started/build-tools/#tooling-setup).**
|
Download everything: source Sass, JavaScript, and documentation files. **Requires a Sass compiler, [Autoprefixer](https://github.com/postcss/autoprefixer), [postcss-flexbugs-fixes](https://github.com/luisrudge/postcss-flexbugs-fixes), and [some setup]({{ site.baseurl }}/getting-started/build-tools/#tooling-setup).**
|
||||||
|
|
||||||
<a href="{{ site.download.source }}" class="btn btn-bs btn-outline" onclick="ga('send', 'event', 'Getting started', 'Download', 'Download source');">Download source</a>
|
<a href="{{ site.download.source }}" class="btn btn-bs btn-outline" onclick="ga('send', 'event', 'Getting started', 'Download', 'Download source');">Download source</a>
|
||||||
{% endmarkdown %}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
## Package managers
|
## Package managers
|
||||||
|
|
||||||
Pull in Bootstrap's **source files** into nearly any project with some of the most popular package managers. No matter the package manager, Bootstrap will **require a Sass compiler and [Autoprefixer](https://github.com/postcss/autoprefixer)** for a setup that matches our official compiled versions.
|
Pull in Bootstrap's **source files** into nearly any project with some of the most popular package managers. No matter the package manager, Bootstrap will **require a Sass compiler, [Autoprefixer](https://github.com/postcss/autoprefixer), and [postcss-flexbugs-fixes](https://github.com/luisrudge/postcss-flexbugs-fixes)** for a setup that matches our official compiled versions.
|
||||||
|
|
||||||
{% callout warning %}
|
{% callout warning %}
|
||||||
**Heads up!** Not all package managers have the v4 alpha published yet, but we should have them up shortly!
|
**Heads up!** Not all package managers have the v4 alpha published yet, but we should have them up shortly!
|
||||||
@ -78,7 +61,7 @@ $ meteor add twbs:bootstrap@={{ site.current_version }}
|
|||||||
You can also install and manage Bootstrap's Sass and JavaScript using [Composer](https://getcomposer.org):
|
You can also install and manage Bootstrap's Sass and JavaScript using [Composer](https://getcomposer.org):
|
||||||
|
|
||||||
{% highlight bash %}
|
{% highlight bash %}
|
||||||
$ composer require twbs/bootstrap
|
$ composer require twbs/bootstrap:{{ site.current_version }}
|
||||||
{% endhighlight %}
|
{% endhighlight %}
|
||||||
|
|
||||||
### Bower
|
### Bower
|
||||||
@ -100,6 +83,7 @@ PM> Install-Package bootstrap.sass -Pre
|
|||||||
|
|
||||||
The `-Pre` is required until Bootstrap v4 has a stable release.
|
The `-Pre` is required until Bootstrap v4 has a stable release.
|
||||||
|
|
||||||
|
{% comment %}
|
||||||
## Custom builds
|
## Custom builds
|
||||||
|
|
||||||
Need only a part of Bootstrap's CSS or JS? Use one of the custom builds to snag just what you need.
|
Need only a part of Bootstrap's CSS or JS? Use one of the custom builds to snag just what you need.
|
||||||
@ -121,4 +105,4 @@ Need only a part of Bootstrap's CSS or JS? Use one of the custom builds to snag
|
|||||||
<a class="btn btn-bs btn-outline" href="#">Download</a>
|
<a class="btn btn-bs btn-outline" href="#">Download</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
{% endcomment %}
|
||||||
|
@ -19,7 +19,7 @@ Flexbox support is available for a number of Bootstrap's components:
|
|||||||
- Input groups, which move from `display: table;` to `display: flex;`.
|
- Input groups, which move from `display: table;` to `display: flex;`.
|
||||||
- The media component moves from `display: table;` and a number of hacky styles to a simple `display: flex;`.
|
- The media component moves from `display: table;` and a number of hacky styles to a simple `display: flex;`.
|
||||||
|
|
||||||
Vendor prefixes are provided in our compiled CSS with Autoprefixer via Grunt.
|
Vendor prefixes are provided in our compiled CSS with [Autoprefixer](https://github.com/postcss/autoprefixer) via Grunt. Some bugs in IE10-11's Flexbox implementation are worked around via [postcss-flexbugs-fixes](https://github.com/luisrudge/postcss-flexbugs-fixes).
|
||||||
|
|
||||||
## Why flexbox?
|
## Why flexbox?
|
||||||
|
|
||||||
|
@ -37,4 +37,4 @@ You can find and customize these variables for key global options in our `_varia
|
|||||||
| `$enable-gradients` | `true` or `false` (default) | Enables predefined gradients via `background-image` styles on various components. |
|
| `$enable-gradients` | `true` or `false` (default) | Enables predefined gradients via `background-image` styles on various components. |
|
||||||
| `$enable-transitions` | `true` (default) or `false` | Enables predefined `transition`s on various components. |
|
| `$enable-transitions` | `true` (default) or `false` | Enables predefined `transition`s on various components. |
|
||||||
| `$enable-hover-media-query` | `true` or `false` (default) | ... |
|
| `$enable-hover-media-query` | `true` or `false` (default) | ... |
|
||||||
| `$enable-grid-classes` | `true` (default) or `false` | Enables the generation of CSS classes for the grid system (e.g. `.col-md-1` etc.). |
|
| `$enable-grid-classes` | `true` (default) or `false` | Enables the generation of CSS classes for the grid system (e.g., `.container`, `.row`, `.col-md-1`, etc.). |
|
||||||
|
@ -9,7 +9,7 @@ Fancy a more modern grid system? [Enable flexbox support in Bootstrap](/getting-
|
|||||||
Bootstrap's flexbox grid includes support for every feature from our [default grid system](/layout/grid), and then some. Please read the [default grid system docs](/layout/grid) before proceeding through this page. Features that are covered there are only summarized here. Please note that **Internet Explorer 9 does not support flexbox**, so proceed with caution when enabling it.
|
Bootstrap's flexbox grid includes support for every feature from our [default grid system](/layout/grid), and then some. Please read the [default grid system docs](/layout/grid) before proceeding through this page. Features that are covered there are only summarized here. Please note that **Internet Explorer 9 does not support flexbox**, so proceed with caution when enabling it.
|
||||||
|
|
||||||
{% callout warning %}
|
{% callout warning %}
|
||||||
**Heads up!** The flexbox grid documentation is only functional when flexbox support is explicitly enabled.
|
**Heads up!** This flexbox grid documentation is powered by an additional CSS file that overrides our default grid system's CSS. This is only available in our hosted docs and is disabled in development.
|
||||||
{% endcallout %}
|
{% endcallout %}
|
||||||
|
|
||||||
## Contents
|
## Contents
|
||||||
|
@ -139,7 +139,7 @@ Variables and maps determine the number of columns, the gutter width, and the me
|
|||||||
|
|
||||||
{% highlight scss %}
|
{% highlight scss %}
|
||||||
$grid-columns: 12;
|
$grid-columns: 12;
|
||||||
$grid-gutter-width: 15px;
|
$grid-gutter-width: 30px;
|
||||||
|
|
||||||
$grid-breakpoints: (
|
$grid-breakpoints: (
|
||||||
// Extra small screen / phone
|
// Extra small screen / phone
|
||||||
@ -180,20 +180,21 @@ Mixins are used in conjunction with the grid variables to generate semantic CSS
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Make the element grid-ready (applying everything but the width)
|
// Make the element grid-ready (applying everything but the width)
|
||||||
@mixin make-col($gutter: $grid-gutter-width) {
|
@mixin make-col-ready($size, $columns: $grid-columns, $gutter: $grid-gutter-width) {
|
||||||
position: relative;
|
position: relative;
|
||||||
@if $enable-flex {
|
min-height: 1px; // Prevent collapsing
|
||||||
flex: 1;
|
|
||||||
} @else {
|
|
||||||
float: left;
|
|
||||||
}
|
|
||||||
min-height: 1px;
|
|
||||||
padding-left: ($gutter / 2);
|
|
||||||
padding-right: ($gutter / 2);
|
padding-right: ($gutter / 2);
|
||||||
|
padding-left: ($gutter / 2);
|
||||||
|
|
||||||
|
// Prevent columns from becoming too narrow when at smaller grid tiers by
|
||||||
|
// always setting `width: 100%;`. This works because we use `flex` values
|
||||||
|
// later on to override this initial width.
|
||||||
|
@if $enable-flex {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@mixin make-col-span($size, $columns: $grid-columns) {
|
@mixin make-col($size, $columns: $grid-columns, $gutter: $grid-gutter-width) {
|
||||||
// Set a width (to be used in or out of media queries)
|
|
||||||
@if $enable-flex {
|
@if $enable-flex {
|
||||||
flex: 0 0 percentage($size / $columns);
|
flex: 0 0 percentage($size / $columns);
|
||||||
// Add a `max-width` to ensure content within each column does not blow out
|
// Add a `max-width` to ensure content within each column does not blow out
|
||||||
@ -201,6 +202,7 @@ Mixins are used in conjunction with the grid variables to generate semantic CSS
|
|||||||
// do not appear to require this.
|
// do not appear to require this.
|
||||||
max-width: percentage($size / $columns);
|
max-width: percentage($size / $columns);
|
||||||
} @else {
|
} @else {
|
||||||
|
float: left;
|
||||||
width: percentage($size / $columns);
|
width: percentage($size / $columns);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -232,23 +234,23 @@ See it in action in <a href="http://jsbin.com/ruxona/edit">this rendered example
|
|||||||
@include make-row();
|
@include make-row();
|
||||||
}
|
}
|
||||||
.content-main {
|
.content-main {
|
||||||
@include make-col();
|
@include make-col-ready();
|
||||||
|
|
||||||
@media (max-width: 32em) {
|
@media (max-width: 32em) {
|
||||||
@include make-col-span(6);
|
@include make-col(6);
|
||||||
}
|
}
|
||||||
@media (min-width: 32.1em) {
|
@media (min-width: 32.1em) {
|
||||||
@include make-col-span(8);
|
@include make-col(8);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.content-secondary {
|
.content-secondary {
|
||||||
@include make-col();
|
@include make-col-ready();
|
||||||
|
|
||||||
@media (max-width: 32em) {
|
@media (max-width: 32em) {
|
||||||
@include make-col-span(6);
|
@include make-col(6);
|
||||||
}
|
}
|
||||||
@media (min-width: 32.1em) {
|
@media (min-width: 32.1em) {
|
||||||
@include make-col-span(4);
|
@include make-col(4);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
{% endhighlight %}
|
{% endhighlight %}
|
||||||
@ -268,36 +270,36 @@ In addition to our semantic mixins, Bootstrap includes an extensive set of prebu
|
|||||||
|
|
||||||
### Example: Stacked-to-horizontal
|
### Example: Stacked-to-horizontal
|
||||||
|
|
||||||
Using a single set of `.col-md-*` grid classes, you can create a basic grid system that starts out stacked on mobile devices and tablet devices (the extra small to small range) before becoming horizontal on desktop (medium) devices. Place grid columns with the `.col` base class and a modifier within any `.row`.
|
Using a single set of `.col-md-*` grid classes, you can create a basic grid system that starts out stacked on mobile devices and tablet devices (the extra small to small range) before becoming horizontal on desktop (medium) devices. Place grid columns within any `.row`.
|
||||||
|
|
||||||
<div class="bd-example-row">
|
<div class="bd-example-row">
|
||||||
{% example html %}
|
{% example html %}
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-1">md-1</div>
|
<div class="col-md-1">col-md-1</div>
|
||||||
<div class="col-md-1">md-1</div>
|
<div class="col-md-1">col-md-1</div>
|
||||||
<div class="col-md-1">md-1</div>
|
<div class="col-md-1">col-md-1</div>
|
||||||
<div class="col-md-1">md-1</div>
|
<div class="col-md-1">col-md-1</div>
|
||||||
<div class="col-md-1">md-1</div>
|
<div class="col-md-1">col-md-1</div>
|
||||||
<div class="col-md-1">md-1</div>
|
<div class="col-md-1">col-md-1</div>
|
||||||
<div class="col-md-1">md-1</div>
|
<div class="col-md-1">col-md-1</div>
|
||||||
<div class="col-md-1">md-1</div>
|
<div class="col-md-1">col-md-1</div>
|
||||||
<div class="col-md-1">md-1</div>
|
<div class="col-md-1">col-md-1</div>
|
||||||
<div class="col-md-1">md-1</div>
|
<div class="col-md-1">col-md-1</div>
|
||||||
<div class="col-md-1">md-1</div>
|
<div class="col-md-1">col-md-1</div>
|
||||||
<div class="col-md-1">md-1</div>
|
<div class="col-md-1">col-md-1</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-8">md-8</div>
|
<div class="col-md-8">col-md-8</div>
|
||||||
<div class="col-md-4">md-4</div>
|
<div class="col-md-4">col-md-4</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-4">md-4</div>
|
<div class="col-md-4">col-md-4</div>
|
||||||
<div class="col-md-4">md-4</div>
|
<div class="col-md-4">col-md-4</div>
|
||||||
<div class="col-md-4">md-4</div>
|
<div class="col-md-4">col-md-4</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-6">md-6</div>
|
<div class="col-md-6">col-md-6</div>
|
||||||
<div class="col-md-6">md-6</div>
|
<div class="col-md-6">col-md-6</div>
|
||||||
</div>
|
</div>
|
||||||
{% endexample %}
|
{% endexample %}
|
||||||
</div>
|
</div>
|
||||||
@ -442,7 +444,7 @@ To nest your content with the default grid, add a new `.row` and set of `.col-sm
|
|||||||
|
|
||||||
### Example: Column ordering
|
### Example: Column ordering
|
||||||
|
|
||||||
Easily change the order of our built-in grid columns with `.col-md-push-*` and `.col-md-pull-*` modifier classes.
|
Easily change the order of our built-in grid columns with `.push-md-*` and `.pull-md-*` modifier classes.
|
||||||
|
|
||||||
<div class="bd-example-row">
|
<div class="bd-example-row">
|
||||||
{% example html %}
|
{% example html %}
|
||||||
@ -457,7 +459,18 @@ Easily change the order of our built-in grid columns with `.col-md-push-*` and `
|
|||||||
|
|
||||||
Using our built-in grid Sass variables and maps, it's possible to completely customize the predefined grid classes. Change the number of tiers, the media query dimensions, and the container widths—then recompile.
|
Using our built-in grid Sass variables and maps, it's possible to completely customize the predefined grid classes. Change the number of tiers, the media query dimensions, and the container widths—then recompile.
|
||||||
|
|
||||||
For example, if you wanted just three grid tiers, you'd update the `$grid-breakpoints` and `$container-max-widths` to something like this:
|
### Columns and gutters
|
||||||
|
|
||||||
|
The number of grid columns and their horizontal padding (aka, gutters) can be modified via Sass variables. `$grid-columns` is used to generate the widths (in percent) of each individual column while `$grid-gutter-width` is divided evenly across `padding-left` and `padding-right` for the column gutters.
|
||||||
|
|
||||||
|
{% highlight scss %}
|
||||||
|
$grid-columns: 12;
|
||||||
|
$grid-gutter-width: 30px;
|
||||||
|
{% endhighlight %}
|
||||||
|
|
||||||
|
### Grid tiers
|
||||||
|
|
||||||
|
Moving beyond the columns themselves, you may also customize the number of grid tiers. If you wanted just three grid tiers, you'd update the `$grid-breakpoints` and `$container-max-widths` to something like this:
|
||||||
|
|
||||||
{% highlight scss %}
|
{% highlight scss %}
|
||||||
$grid-breakpoints: (
|
$grid-breakpoints: (
|
||||||
@ -473,4 +486,4 @@ $container-max-widths: (
|
|||||||
);
|
);
|
||||||
{% endhighlight %}
|
{% endhighlight %}
|
||||||
|
|
||||||
Save your changes and recompile to have a brand new set of predefined grid classes for column widths, offsets, pushes, and pulls. Responsive visibility utilities will also be updated to use the custom breakpoints.
|
When making any changes to the Sass variables or maps, you'll need to save your changes and recompile. Doing so will out a brand new set of predefined grid classes for column widths, offsets, pushes, and pulls. Responsive visibility utilities will also be updated to use the custom breakpoints.
|
||||||
|
@ -188,6 +188,9 @@ Green checkmarks indicate the element **is visible** in your current viewport.
|
|||||||
<span class="hidden-lg-down not-visible">Large or narrower</span>
|
<span class="hidden-lg-down not-visible">Large or narrower</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<hr>
|
||||||
|
|
||||||
<div class="row responsive-utilities-test visible-on">
|
<div class="row responsive-utilities-test visible-on">
|
||||||
<div class="col-xs-6 col-sm-3">
|
<div class="col-xs-6 col-sm-3">
|
||||||
<span class="hidden-xs-down visible">✔ Visible on small or wider</span>
|
<span class="hidden-xs-down visible">✔ Visible on small or wider</span>
|
||||||
@ -206,24 +209,30 @@ Green checkmarks indicate the element **is visible** in your current viewport.
|
|||||||
<span class="hidden-xl-up not-visible">Extra large</span>
|
<span class="hidden-xl-up not-visible">Extra large</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<hr>
|
||||||
|
|
||||||
<div class="row responsive-utilities-test visible-on">
|
<div class="row responsive-utilities-test visible-on">
|
||||||
<div class="col-xs-6 col-sm-3">
|
<div class="col-xs-6 col-sm-4">
|
||||||
<span class="hidden-sm-up visible">✔ Your viewport is exactly extra small</span>
|
<span class="hidden-sm-up visible">✔ Your viewport is exactly extra small</span>
|
||||||
<span class="hidden-xs-down not-visible">Your viewport is NOT exactly extra small</span>
|
<span class="hidden-xs-down not-visible">Your viewport is NOT exactly extra small</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-xs-6 col-sm-3">
|
<div class="col-xs-6 col-sm-4">
|
||||||
<span class="hidden-xs-down hidden-md-up visible">✔ Your viewport is exactly small</span>
|
<span class="hidden-xs-down hidden-md-up visible">✔ Your viewport is exactly small</span>
|
||||||
<span class="hidden-sm-only not-visible">Your viewport is NOT exactly small</span>
|
<span class="hidden-sm-only not-visible">Your viewport is NOT exactly small</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-xs-6 col-sm-3">
|
<div class="col-xs-6 col-sm-4">
|
||||||
<span class="hidden-sm-down hidden-lg-up visible">✔ Your viewport is exactly medium</span>
|
<span class="hidden-sm-down hidden-lg-up visible">✔ Your viewport is exactly medium</span>
|
||||||
<span class="hidden-md-only not-visible">Your viewport is NOT exactly medium</span>
|
<span class="hidden-md-only not-visible">Your viewport is NOT exactly medium</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-xs-6 col-sm-3">
|
</div>
|
||||||
|
|
||||||
|
<div class="row responsive-utilities-test visible-on">
|
||||||
|
<div class="col-xs-6 col-sm-4">
|
||||||
<span class="hidden-md-down hidden-xl-up visible">✔ Your viewport is exactly large</span>
|
<span class="hidden-md-down hidden-xl-up visible">✔ Your viewport is exactly large</span>
|
||||||
<span class="hidden-lg-only not-visible">Your viewport is NOT exactly large</span>
|
<span class="hidden-lg-only not-visible">Your viewport is NOT exactly large</span>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-xs-6 col-sm-3">
|
<div class="col-xs-6 col-sm-4">
|
||||||
<span class="hidden-lg-down visible">✔ Your viewport is exactly extra large</span>
|
<span class="hidden-lg-down visible">✔ Your viewport is exactly extra large</span>
|
||||||
<span class="hidden-xl-only not-visible">Your viewport is NOT exactly extra large</span>
|
<span class="hidden-xl-only not-visible">Your viewport is NOT exactly extra large</span>
|
||||||
</div>
|
</div>
|
||||||
|
@ -59,7 +59,7 @@ This list highlights key changes by component between v3.x.x and v4.0.0.
|
|||||||
|
|
||||||
### Reboot
|
### Reboot
|
||||||
|
|
||||||
New to Bootstrap 4 is the Reboot, a new stylesheet that builds on Normalize with our own somewhat opinionated reset styles. Selectors appearing in this file only use elements—there are no classes here. This isolates our reset styles from our component styles for a more modular approach. Some of the most important resets this includes are the `box-sizing: border` change, moving from `rem` to `em` units on many elements, link styles, and many form element resets.
|
New to Bootstrap 4 is the Reboot, a new stylesheet that builds on Normalize with our own somewhat opinionated reset styles. Selectors appearing in this file only use elements—there are no classes here. This isolates our reset styles from our component styles for a more modular approach. Some of the most important resets this includes are the `box-sizing: border-box` change, moving from `em` to `rem` units on many elements, link styles, and many form element resets.
|
||||||
|
|
||||||
### Typography
|
### Typography
|
||||||
|
|
||||||
@ -67,6 +67,7 @@ New to Bootstrap 4 is the Reboot, a new stylesheet that builds on Normalize with
|
|||||||
- Dropped `.page-header` as, aside from the border, all it's styles can be applied via utilities.
|
- Dropped `.page-header` as, aside from the border, all it's styles can be applied via utilities.
|
||||||
- `.dl-horizontal` has been dropped. Instead, use `.row` on `<dl>` and use grid column classes (or mixins) on its `<dt>` and `<dd>` children.
|
- `.dl-horizontal` has been dropped. Instead, use `.row` on `<dl>` and use grid column classes (or mixins) on its `<dt>` and `<dd>` children.
|
||||||
- Custom `<blockquote>` styling has moved to classes—`.blockquote` and the `.blockquote-reverse` modifier.
|
- Custom `<blockquote>` styling has moved to classes—`.blockquote` and the `.blockquote-reverse` modifier.
|
||||||
|
- `.list-inline` now requires that its children list items have the new `.list-inline-item` class applied to them.
|
||||||
|
|
||||||
### Images
|
### Images
|
||||||
|
|
||||||
@ -126,7 +127,7 @@ New to Bootstrap 4 is the Reboot, a new stylesheet that builds on Normalize with
|
|||||||
|
|
||||||
### Modal
|
### Modal
|
||||||
|
|
||||||
- The `remote` option (which could be used to automatically load and inject external content into a modal) and the correspending `loaded.bs.modal` event were removed. We recommend instead using client-side templating or a data binding framework, or calling [jQuery.load](http://api.jquery.com/load/) yourself.
|
- The `remote` option (which could be used to automatically load and inject external content into a modal) and the corresponding `loaded.bs.modal` event were removed. We recommend instead using client-side templating or a data binding framework, or calling [jQuery.load](http://api.jquery.com/load/) yourself.
|
||||||
|
|
||||||
### Navs
|
### Navs
|
||||||
|
|
||||||
@ -224,11 +225,7 @@ TODO: audit classes in v3 that aren't present in v4
|
|||||||
|
|
||||||
### Responsive utilities
|
### Responsive utilities
|
||||||
|
|
||||||
The following variables have been removed in v4.0.0. Use the `media-breakpoint-up()`, `media-breakpoint-down()`, or `media-breakpoint-only()` Sass mixins or the `$grid-breakpoints` Sass map instead of:
|
All `@screen-` variables have been removed in v4.0.0. Use the `media-breakpoint-up()`, `media-breakpoint-down()`, or `media-breakpoint-only()` Sass mixins or the `$grid-breakpoints` Sass map instead.
|
||||||
|
|
||||||
* `@screen-phone`, `@screen-tablet`, `@screen-desktop`, `@screen-lg-desktop`.
|
|
||||||
* `@screen-xs`, `@screen-sm`, `@screen-md`, `@screen-lg`.
|
|
||||||
* `@screen-xs-min`, `@screen-xs-max`, `@screen-sm-min`, `@screen-sm-max`, `@screen-md-min`, `@screen-md-max`, `@screen-lg-min`, `@screen-lg-max`
|
|
||||||
|
|
||||||
The responsive utility classes have also been overhauled.
|
The responsive utility classes have also been overhauled.
|
||||||
|
|
||||||
|
@ -1,31 +0,0 @@
|
|||||||
module.exports = {
|
|
||||||
browsers: [
|
|
||||||
//
|
|
||||||
// Official browser support policy:
|
|
||||||
// http://v4-alpha.getbootstrap.com/getting-started/browsers-devices/#supported-browsers
|
|
||||||
//
|
|
||||||
'Chrome >= 35', // Exact version number here is kinda arbitrary
|
|
||||||
// Rather than using Autoprefixer's native "Firefox ESR" version specifier string,
|
|
||||||
// we deliberately hardcode the number. This is to avoid unwittingly severely breaking the previous ESR in the event that:
|
|
||||||
// (a) we happen to ship a new Bootstrap release soon after the release of a new ESR,
|
|
||||||
// such that folks haven't yet had a reasonable amount of time to upgrade; and
|
|
||||||
// (b) the new ESR has unprefixed CSS properties/values whose absence would severely break webpages
|
|
||||||
// (e.g. `box-sizing`, as opposed to `background: linear-gradient(...)`).
|
|
||||||
// Since they've been unprefixed, Autoprefixer will stop prefixing them,
|
|
||||||
// thus causing them to not work in the previous ESR (where the prefixes were required).
|
|
||||||
'Firefox >= 38', // Current Firefox Extended Support Release (ESR); https://www.mozilla.org/en-US/firefox/organizations/faq/
|
|
||||||
// Note: Edge versions in Autoprefixer & Can I Use refer to the EdgeHTML rendering engine version,
|
|
||||||
// NOT the Edge app version shown in Edge's "About" screen.
|
|
||||||
// For example, at the time of writing, Edge 20 on an up-to-date system uses EdgeHTML 12.
|
|
||||||
// See also https://github.com/Fyrd/caniuse/issues/1928
|
|
||||||
'Edge >= 12',
|
|
||||||
'Explorer >= 9',
|
|
||||||
// Out of leniency, we prefix these 1 version further back than the official policy.
|
|
||||||
'iOS >= 8',
|
|
||||||
'Safari >= 8',
|
|
||||||
// The following remain NOT officially supported, but we're lenient and include their prefixes to avoid severely breaking in them.
|
|
||||||
'Android 2.3',
|
|
||||||
'Android >= 4',
|
|
||||||
'Opera >= 12'
|
|
||||||
]
|
|
||||||
}
|
|
@ -1,30 +0,0 @@
|
|||||||
/*!
|
|
||||||
* Bootstrap Grunt task for the CommonJS module generation
|
|
||||||
* http://getbootstrap.com
|
|
||||||
* Copyright 2014-2015 The Bootstrap Authors
|
|
||||||
* Copyright 2014-2015 Twitter, Inc.
|
|
||||||
* Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
|
|
||||||
*/
|
|
||||||
|
|
||||||
'use strict';
|
|
||||||
|
|
||||||
var fs = require('fs');
|
|
||||||
var path = require('path');
|
|
||||||
|
|
||||||
var COMMONJS_BANNER = '// This file is autogenerated via the `commonjs` Grunt task. You can require() this file in a CommonJS environment.\n';
|
|
||||||
|
|
||||||
module.exports = function generateCommonJSModule(grunt, srcFiles, destFilepath) {
|
|
||||||
var destDir = path.dirname(destFilepath);
|
|
||||||
|
|
||||||
function srcPathToDestRequire(srcFilepath) {
|
|
||||||
return 'require(\'' + srcFilepath.replace(/\\/g, '/') + '\')';
|
|
||||||
}
|
|
||||||
|
|
||||||
var moduleOutputJs = COMMONJS_BANNER + srcFiles.map(srcPathToDestRequire).join('\n');
|
|
||||||
try {
|
|
||||||
fs.writeFileSync(destFilepath, moduleOutputJs);
|
|
||||||
} catch (err) {
|
|
||||||
grunt.fail.warn(err);
|
|
||||||
}
|
|
||||||
grunt.log.writeln('File ' + destFilepath.cyan + ' created.');
|
|
||||||
};
|
|
@ -25,7 +25,8 @@ module.exports = function configureLibsass(grunt) {
|
|||||||
},
|
},
|
||||||
docs: {
|
docs: {
|
||||||
files: {
|
files: {
|
||||||
'docs/assets/css/docs.min.css': 'docs/assets/scss/docs.scss'
|
'docs/assets/css/docs.min.css': 'docs/assets/scss/docs.scss',
|
||||||
|
'docs/assets/css/docs-flexbox.min.css': 'docs/assets/scss/flex-grid.scss'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -29,7 +29,8 @@ module.exports = function configureRubySass(grunt) {
|
|||||||
docs: {
|
docs: {
|
||||||
options: options,
|
options: options,
|
||||||
files: {
|
files: {
|
||||||
'docs/assets/css/docs.min.css': 'docs/assets/scss/docs.scss'
|
'docs/assets/css/docs.min.css': 'docs/assets/scss/docs.scss',
|
||||||
|
'docs/assets/css/docs-flexbox.min.css': 'docs/assets/scss/flex-grid.scss'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|