Changeset - ecd9ba4a37ca
[Not reviewed]
! ! !
Joar Wandborg - 10 years ago 2013-10-23 14:17:17
joar@wandborg.se
Initial templating
34 files changed:
Changeset was too big and was cut off... Show full diff anyway
0 comments (0 inline, 0 general)
bootstrap-3.0.0/.editorconfig
Show inline comments
 
new file 100644
 
# editorconfig.org
 

	
 
root = true
 

	
 
[*]
 
indent_style = space
 
indent_size = 2
 
end_of_line = lf
 
charset = utf-8
 
trim_trailing_whitespace = true
 
insert_final_newline = true
bootstrap-3.0.0/.gitignore
Show inline comments
 
new file 100644
 
# Ignore compiled docs
 
_gh_pages
 
_site
 

	
 
# Numerous always-ignore extensions
 
*.diff
 
*.err
 
*.orig
 
*.log
 
*.rej
 
*.swo
 
*.swp
 
*.zip
 
*.vi
 
*~
 
*.sass-cache
 
*.ruby-version
 

	
 
# OS or Editor folders
 
.DS_Store
 
._*
 
Thumbs.db
 
.cache
 
.project
 
.settings
 
.tmproj
 
*.esproj
 
nbproject
 
*.sublime-project
 
*.sublime-workspace
 

	
 
# Komodo
 
*.komodoproject
 
.komodotools
 

	
 
# grunt-html-validation
 
validation-staus.json
 

	
 
# Folders to ignore
 
.hg
 
.svn
 
.CVS
 
.idea
 
node_modules
bootstrap-3.0.0/.travis.yml
Show inline comments
 
new file 100644
 
language: node_js
 
node_js:
 
  - 0.8
 
before_script:
 
  - gem install jekyll
 
  - npm install -g grunt-cli
 
env:
 
  global:
 
  - secure: Besg41eyU+2mfxrywQ4ydOShMdc34ImaO0S0ENP+aCOBuyNBIgP59wy5tBMmyai2/8eInYeVps4Td96mWInMMxzTe3Bar7eTLG5tWVKRSr/wc4NBPZ/ppoPAmCEsz9Y+VptRH9/FO8n7hsL9EFZ+xBKbG+C0SccGoyBDpA5j7/w=
 
  - secure: Ptiv7phCImFP3ALIz+sMQzrZg8k7C1gLZbFBhWxjnQr3g06wIfX3Ls5y9OHvxid+lOZZjISui3wzBVgpVHqwHUYf96+r0mo6/mJ+F4ffUmShZANVaIMD/JRTnXhUQJbvntGLvxn1EYWPdNM+2IHJrMipnjHxU9tkgAnlel4Zdew=
 
  - TWBS_HAVE_OWN_BROWSERSTACK_KEY: ""
bootstrap-3.0.0/CNAME
Show inline comments
 
new file 100644
 
getbootstrap.com
bootstrap-3.0.0/CONTRIBUTING.md
Show inline comments
 
new file 100644
 
# Contributing to Bootstrap
 

	
 
Looking to contribute something to Bootstrap? **Here's how you can help.**
 

	
 

	
 

	
 
## Reporting issues
 

	
 
We only accept issues that are bug reports or feature requests. Bugs must be isolated and reproducible problems that we can fix within the Bootstrap core. Please read the following guidelines before opening any issue.
 

	
 
1. **Search for existing issues.** We get a lot of duplicate issues, and you'd help us out a lot by first checking if someone else has reported the same issue. Moreover, the issue may have already been resolved with a fix available.
 
2. **Create an isolated and reproducible test case.** Be sure the problem exists in Bootstrap's code with a [reduced test case](http://css-tricks.com/reduced-test-cases/) that should be included in each bug report.
 
3. **Include a live example.** Make use of jsFiddle or jsBin to share your isolated test cases.
 
4. **Share as much information as possible.** Include operating system and version, browser and version, version of Bootstrap, customized or vanilla build, etc. where appropriate. Also include steps to reproduce the bug.
 

	
 

	
 

	
 
## Key branches
 

	
 
- `master` is the latest, deployed version.
 
- `gh-pages` is the hosted docs (not to be used for pull requests).
 
- `*-wip` is the official work in progress branch for the next release.
 

	
 

	
 

	
 
## Pull requests
 

	
 
- Try to submit pull requests against the latest `*-wip` branch for easier merging
 
- CSS changes must be done in .less files first, never just the compiled files
 
- If modifying the .less files, always recompile and commit the compiled files bootstrap.css and bootstrap.min.css
 
- Try not to pollute your pull request with unintended changes--keep them simple and small
 
- Try to share which browsers your code has been tested in before submitting a pull request
 

	
 

	
 

	
 
## Coding standards
 

	
 
### HTML
 

	
 
- Two spaces for indentation, never tabs
 
- Double quotes only, never single quotes
 
- Always use proper indentation
 
- Use tags and elements appropriate for an HTML5 doctype (e.g., self-closing tags)
 

	
 
### CSS
 

	
 
- Adhere to the [Recess CSS property order](http://markdotto.com/2011/11/29/css-property-order/)
 
- Multiple-line approach (one property and value per line)
 
- Always a space after a property's colon (.e.g, `display: block;` and not `display:block;`)
 
- End all lines with a semi-colon
 
- For multiple, comma-separated selectors, place each selector on its own line
 
- Attribute selectors, like `input[type="text"]` should always wrap the attribute's value in double quotes, for consistency and safety (see this [blog post on unquoted attribute values](http://mathiasbynens.be/notes/unquoted-attribute-values) that can lead to XSS attacks).
 

	
 
### JS
 

	
 
- No semicolons
 
- Comma first
 
- 2 spaces (no tabs)
 
- strict mode
 
- "Attractive"
 

	
 

	
 

	
 
## License
 

	
 
By contributing your code, you agree to license your contribution under the terms of the APLv2: https://github.com/twbs/bootstrap/blob/master/LICENSE
bootstrap-3.0.0/Gruntfile.js
Show inline comments
 
new file 100644
 
/* jshint node: true */
 

	
 
module.exports = function(grunt) {
 
  "use strict";
 

	
 
  // Project configuration.
 
  grunt.initConfig({
 

	
 
    // Metadata.
 
    pkg: grunt.file.readJSON('package.json'),
 
    banner: '/**\n' +
 
              '* <%= pkg.name %>.js v<%= pkg.version %> by @fat and @mdo\n' +
 
              '* Copyright <%= grunt.template.today("yyyy") %> <%= pkg.author %>\n' +
 
              '* <%= _.pluck(pkg.licenses, "url").join(", ") %>\n' +
 
              '*/\n',
 
    jqueryCheck: 'if (!jQuery) { throw new Error(\"Bootstrap requires jQuery\") }\n\n',
 

	
 
    // Task configuration.
 
    clean: {
 
      dist: ['dist']
 
    },
 

	
 
    jshint: {
 
      options: {
 
        jshintrc: 'js/.jshintrc'
 
      },
 
      gruntfile: {
 
        src: 'Gruntfile.js'
 
      },
 
      src: {
 
        src: ['js/*.js']
 
      },
 
      test: {
 
        src: ['js/tests/unit/*.js']
 
      }
 
    },
 

	
 
    concat: {
 
      options: {
 
        banner: '<%= banner %><%= jqueryCheck %>',
 
        stripBanners: false
 
      },
 
      bootstrap: {
 
        src: [
 
          'js/transition.js',
 
          'js/alert.js',
 
          'js/button.js',
 
          'js/carousel.js',
 
          'js/collapse.js',
 
          'js/dropdown.js',
 
          'js/modal.js',
 
          'js/tooltip.js',
 
          'js/popover.js',
 
          'js/scrollspy.js',
 
          'js/tab.js',
 
          'js/affix.js'
 
        ],
 
        dest: 'dist/js/<%= pkg.name %>.js'
 
      }
 
    },
 

	
 
    uglify: {
 
      options: {
 
        banner: '<%= banner %>'
 
      },
 
      bootstrap: {
 
        src: ['<%= concat.bootstrap.dest %>'],
 
        dest: 'dist/js/<%= pkg.name %>.min.js'
 
      }
 
    },
 

	
 
    recess: {
 
      options: {
 
        compile: true
 
      },
 
      bootstrap: {
 
        src: ['less/bootstrap.less'],
 
        dest: 'dist/css/<%= pkg.name %>.css'
 
      },
 
      min: {
 
        options: {
 
          compress: true
 
        },
 
        src: ['less/bootstrap.less'],
 
        dest: 'dist/css/<%= pkg.name %>.min.css'
 
      },
 
      theme: {
 
        src: ['less/theme.less'],
 
        dest: 'dist/css/<%= pkg.name %>-theme.css'
 
      },
 
      theme_min: {
 
        options: {
 
          compress: true
 
        },
 
        src: ['less/theme.less'],
 
        dest: 'dist/css/<%= pkg.name %>-theme.min.css'
 
      }
 
    },
 

	
 
    copy: {
 
      fonts: {
 
        expand: true,
 
        src: ["fonts/*"],
 
        dest: 'dist/'
 
      }
 
    },
 

	
 
    qunit: {
 
      options: {
 
        inject: 'js/tests/unit/phantom.js'
 
      },
 
      files: ['js/tests/*.html']
 
    },
 

	
 
    connect: {
 
      server: {
 
        options: {
 
          port: 3000,
 
          base: '.'
 
        }
 
      }
 
    },
 

	
 
    jekyll: {
 
      docs: {}
 
    },
 

	
 
    validation: {
 
      options: {
 
        reset: true
 
      },
 
      files: {
 
        src: ["_gh_pages/**/*.html"]
 
      }
 
    },
 

	
 
    watch: {
 
      src: {
 
        files: '<%= jshint.src.src %>',
 
        tasks: ['jshint:src', 'qunit']
 
      },
 
      test: {
 
        files: '<%= jshint.test.src %>',
 
        tasks: ['jshint:test', 'qunit']
 
      },
 
      recess: {
 
        files: 'less/*.less',
 
        tasks: ['recess']
 
      }
 
    }
 
  });
 

	
 

	
 
  // These plugins provide necessary tasks.
 
  grunt.loadNpmTasks('grunt-contrib-clean');
 
  grunt.loadNpmTasks('grunt-contrib-concat');
 
  grunt.loadNpmTasks('grunt-contrib-connect');
 
  grunt.loadNpmTasks('grunt-contrib-copy');
 
  grunt.loadNpmTasks('grunt-contrib-jshint');
 
  grunt.loadNpmTasks('grunt-contrib-qunit');
 
  grunt.loadNpmTasks('grunt-contrib-uglify');
 
  grunt.loadNpmTasks('grunt-contrib-watch');
 
  grunt.loadNpmTasks('grunt-html-validation');
 
  grunt.loadNpmTasks('grunt-jekyll');
 
  grunt.loadNpmTasks('grunt-recess');
 
  grunt.loadNpmTasks('browserstack-runner');
 

	
 
  // Docs HTML validation task
 
  grunt.registerTask('validate-html', ['jekyll', 'validation']);
 

	
 
  // Test task.
 
  var testSubtasks = ['dist-css', 'jshint', 'qunit', 'validate-html'];
 
  // Only run BrowserStack tests under Travis
 
  if (process.env.TRAVIS) {
 
    // Only run BrowserStack tests if this is a mainline commit in twbs/bootstrap, or you have your own BrowserStack key
 
    if ((process.env.TRAVIS_REPO_SLUG === 'twbs/bootstrap' && process.env.TRAVIS_PULL_REQUEST === 'false') || process.env.TWBS_HAVE_OWN_BROWSERSTACK_KEY) {
 
      testSubtasks.push('browserstack_runner');
 
    }
 
  }
 
  grunt.registerTask('test', testSubtasks);
 

	
 
  // JS distribution task.
 
  grunt.registerTask('dist-js', ['concat', 'uglify']);
 

	
 
  // CSS distribution task.
 
  grunt.registerTask('dist-css', ['recess']);
 

	
 
  // Fonts distribution task.
 
  grunt.registerTask('dist-fonts', ['copy']);
 

	
 
  // Full distribution task.
 
  grunt.registerTask('dist', ['clean', 'dist-css', 'dist-fonts', 'dist-js']);
 

	
 
  // Default task.
 
  grunt.registerTask('default', ['test', 'dist', 'build-customizer']);
 

	
 
  // task for building customizer
 
  grunt.registerTask('build-customizer', 'Add scripts/less files to customizer.', function () {
 
    var fs = require('fs')
 

	
 
    function getFiles(type) {
 
      var files = {}
 
      fs.readdirSync(type)
 
        .filter(function (path) {
 
          return type == 'fonts' ? true : new RegExp('\\.' + type + '$').test(path)
 
        })
 
        .forEach(function (path) {
 
          return files[path] = fs.readFileSync(type + '/' + path, 'utf8')
 
        })
 
      return 'var __' + type + ' = ' + JSON.stringify(files) + '\n'
 
    }
 

	
 
    var customize = fs.readFileSync('customize.html', 'utf-8')
 
    var files = getFiles('js') + getFiles('less') + getFiles('fonts')
 
    fs.writeFileSync('assets/js/raw-files.js', files)
 
  });
 
};
...
 
\ No newline at end of file
bootstrap-3.0.0/LICENSE
Show inline comments
 
new file 100644
 
                                 Apache License
 
                           Version 2.0, January 2004
 
                        http://www.apache.org/licenses/
 

	
 
   TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
 

	
 
   1. Definitions.
 

	
 
      "License" shall mean the terms and conditions for use, reproduction,
 
      and distribution as defined by Sections 1 through 9 of this document.
 

	
 
      "Licensor" shall mean the copyright owner or entity authorized by
 
      the copyright owner that is granting the License.
 

	
 
      "Legal Entity" shall mean the union of the acting entity and all
 
      other entities that control, are controlled by, or are under common
 
      control with that entity. For the purposes of this definition,
 
      "control" means (i) the power, direct or indirect, to cause the
 
      direction or management of such entity, whether by contract or
 
      otherwise, or (ii) ownership of fifty percent (50%) or more of the
 
      outstanding shares, or (iii) beneficial ownership of such entity.
 

	
 
      "You" (or "Your") shall mean an individual or Legal Entity
 
      exercising permissions granted by this License.
 

	
 
      "Source" form shall mean the preferred form for making modifications,
 
      including but not limited to software source code, documentation
 
      source, and configuration files.
 

	
 
      "Object" form shall mean any form resulting from mechanical
 
      transformation or translation of a Source form, including but
 
      not limited to compiled object code, generated documentation,
 
      and conversions to other media types.
 

	
 
      "Work" shall mean the work of authorship, whether in Source or
 
      Object form, made available under the License, as indicated by a
 
      copyright notice that is included in or attached to the work
 
      (an example is provided in the Appendix below).
 

	
 
      "Derivative Works" shall mean any work, whether in Source or Object
 
      form, that is based on (or derived from) the Work and for which the
 
      editorial revisions, annotations, elaborations, or other modifications
 
      represent, as a whole, an original work of authorship. For the purposes
 
      of this License, Derivative Works shall not include works that remain
 
      separable from, or merely link (or bind by name) to the interfaces of,
 
      the Work and Derivative Works thereof.
 

	
 
      "Contribution" shall mean any work of authorship, including
 
      the original version of the Work and any modifications or additions
 
      to that Work or Derivative Works thereof, that is intentionally
 
      submitted to Licensor for inclusion in the Work by the copyright owner
 
      or by an individual or Legal Entity authorized to submit on behalf of
 
      the copyright owner. For the purposes of this definition, "submitted"
 
      means any form of electronic, verbal, or written communication sent
 
      to the Licensor or its representatives, including but not limited to
 
      communication on electronic mailing lists, source code control systems,
 
      and issue tracking systems that are managed by, or on behalf of, the
 
      Licensor for the purpose of discussing and improving the Work, but
 
      excluding communication that is conspicuously marked or otherwise
 
      designated in writing by the copyright owner as "Not a Contribution."
 

	
 
      "Contributor" shall mean Licensor and any individual or Legal Entity
 
      on behalf of whom a Contribution has been received by Licensor and
 
      subsequently incorporated within the Work.
 

	
 
   2. Grant of Copyright License. Subject to the terms and conditions of
 
      this License, each Contributor hereby grants to You a perpetual,
 
      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
 
      copyright license to reproduce, prepare Derivative Works of,
 
      publicly display, publicly perform, sublicense, and distribute the
 
      Work and such Derivative Works in Source or Object form.
 

	
 
   3. Grant of Patent License. Subject to the terms and conditions of
 
      this License, each Contributor hereby grants to You a perpetual,
 
      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
 
      (except as stated in this section) patent license to make, have made,
 
      use, offer to sell, sell, import, and otherwise transfer the Work,
 
      where such license applies only to those patent claims licensable
 
      by such Contributor that are necessarily infringed by their
 
      Contribution(s) alone or by combination of their Contribution(s)
 
      with the Work to which such Contribution(s) was submitted. If You
 
      institute patent litigation against any entity (including a
 
      cross-claim or counterclaim in a lawsuit) alleging that the Work
 
      or a Contribution incorporated within the Work constitutes direct
 
      or contributory patent infringement, then any patent licenses
 
      granted to You under this License for that Work shall terminate
 
      as of the date such litigation is filed.
 

	
 
   4. Redistribution. You may reproduce and distribute copies of the
 
      Work or Derivative Works thereof in any medium, with or without
 
      modifications, and in Source or Object form, provided that You
 
      meet the following conditions:
 

	
 
      (a) You must give any other recipients of the Work or
 
          Derivative Works a copy of this License; and
 

	
 
      (b) You must cause any modified files to carry prominent notices
 
          stating that You changed the files; and
 

	
 
      (c) You must retain, in the Source form of any Derivative Works
 
          that You distribute, all copyright, patent, trademark, and
 
          attribution notices from the Source form of the Work,
 
          excluding those notices that do not pertain to any part of
 
          the Derivative Works; and
 

	
 
      (d) If the Work includes a "NOTICE" text file as part of its
 
          distribution, then any Derivative Works that You distribute must
 
          include a readable copy of the attribution notices contained
 
          within such NOTICE file, excluding those notices that do not
 
          pertain to any part of the Derivative Works, in at least one
 
          of the following places: within a NOTICE text file distributed
 
          as part of the Derivative Works; within the Source form or
 
          documentation, if provided along with the Derivative Works; or,
 
          within a display generated by the Derivative Works, if and
 
          wherever such third-party notices normally appear. The contents
 
          of the NOTICE file are for informational purposes only and
 
          do not modify the License. You may add Your own attribution
 
          notices within Derivative Works that You distribute, alongside
 
          or as an addendum to the NOTICE text from the Work, provided
 
          that such additional attribution notices cannot be construed
 
          as modifying the License.
 

	
 
      You may add Your own copyright statement to Your modifications and
 
      may provide additional or different license terms and conditions
 
      for use, reproduction, or distribution of Your modifications, or
 
      for any such Derivative Works as a whole, provided Your use,
 
      reproduction, and distribution of the Work otherwise complies with
 
      the conditions stated in this License.
 

	
 
   5. Submission of Contributions. Unless You explicitly state otherwise,
 
      any Contribution intentionally submitted for inclusion in the Work
 
      by You to the Licensor shall be under the terms and conditions of
 
      this License, without any additional terms or conditions.
 
      Notwithstanding the above, nothing herein shall supersede or modify
 
      the terms of any separate license agreement you may have executed
 
      with Licensor regarding such Contributions.
 

	
 
   6. Trademarks. This License does not grant permission to use the trade
 
      names, trademarks, service marks, or product names of the Licensor,
 
      except as required for reasonable and customary use in describing the
 
      origin of the Work and reproducing the content of the NOTICE file.
 

	
 
   7. Disclaimer of Warranty. Unless required by applicable law or
 
      agreed to in writing, Licensor provides the Work (and each
 
      Contributor provides its Contributions) on an "AS IS" BASIS,
 
      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
 
      implied, including, without limitation, any warranties or conditions
 
      of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
 
      PARTICULAR PURPOSE. You are solely responsible for determining the
 
      appropriateness of using or redistributing the Work and assume any
 
      risks associated with Your exercise of permissions under this License.
 

	
 
   8. Limitation of Liability. In no event and under no legal theory,
 
      whether in tort (including negligence), contract, or otherwise,
 
      unless required by applicable law (such as deliberate and grossly
 
      negligent acts) or agreed to in writing, shall any Contributor be
 
      liable to You for damages, including any direct, indirect, special,
 
      incidental, or consequential damages of any character arising as a
 
      result of this License or out of the use or inability to use the
 
      Work (including but not limited to damages for loss of goodwill,
 
      work stoppage, computer failure or malfunction, or any and all
 
      other commercial damages or losses), even if such Contributor
 
      has been advised of the possibility of such damages.
 

	
 
   9. Accepting Warranty or Additional Liability. While redistributing
 
      the Work or Derivative Works thereof, You may choose to offer,
 
      and charge a fee for, acceptance of support, warranty, indemnity,
 
      or other liability obligations and/or rights consistent with this
 
      License. However, in accepting such obligations, You may act only
 
      on Your own behalf and on Your sole responsibility, not on behalf
 
      of any other Contributor, and only if You agree to indemnify,
 
      defend, and hold each Contributor harmless for any liability
 
      incurred by, or claims asserted against, such Contributor by reason
 
      of your accepting any such warranty or additional liability.
 

	
 
   END OF TERMS AND CONDITIONS
bootstrap-3.0.0/README.md
Show inline comments
 
new file 100644
 
# [Bootstrap v3.0.0](http://getbootstrap.com) [![Build Status](https://secure.travis-ci.org/twbs/bootstrap.png)](http://travis-ci.org/twbs/bootstrap)
 

	
 
Bootstrap is a sleek, intuitive, and powerful front-end framework for faster and easier web development, created and maintained by [Mark Otto](http://twitter.com/mdo) and [Jacob Thornton](http://twitter.com/fat).
 

	
 
To get started, check out [http://getbootstrap.com](http://getbootstrap.com)!
 

	
 

	
 

	
 
## Quick start
 

	
 
Three quick start options are available:
 

	
 
* [Download the latest release](https://github.com/twbs/bootstrap/zipball/3.0.0-wip).
 
* Clone the repo: `git clone git://github.com/twbs/bootstrap.git`.
 
* Install with [Bower](http://bower.io): `bower install bootstrap`.
 

	
 
Read the [Getting Started page](http://getbootstrap.com/getting-started/) for information on the framework contents, templates and examples, and more.
 

	
 

	
 

	
 
## Bugs and feature requests
 

	
 
Have a bug or a feature request? [Please open a new issue](https://github.com/twbs/bootstrap/issues). Before opening any issue, please search for existing issues and read the [Issue Guidelines](https://github.com/necolas/issue-guidelines), written by [Nicolas Gallagher](https://github.com/necolas/).
 

	
 
You may use [this JS Bin](http://jsbin.com/aKiCIDO/1/edit) as a template for your bug reports.
 

	
 

	
 

	
 
## Documentation
 

	
 
Bootstrap's documentation, included in this repo in the root directory, is built with [Jekyll](http://jekyllrb.com) and publicly hosted on GitHub Pages at [http://getbootstrap.com](http://getbootstrap.com). The docs may also be run locally.
 

	
 
### Running documentation locally
 

	
 
1. If necessary, [install Jekyll](http://jekyllrb.com/docs/installation) (requires v1.x).
 
2. From the root `/bootstrap` directory, run `jekyll serve` in the command line.
 
  - **Windows users:** run `chcp 65001` first to change the command prompt's character encoding ([code page](http://en.wikipedia.org/wiki/Windows_code_page)) to UTF-8 so Jekyll runs without errors.
 
3. Open [http://localhost:9001](http://localhost:9001) in your browser, and voilà.
 

	
 
Learn more about using Jekyll by reading their [documentation](http://jekyllrb.com/docs/home/).
 

	
 
### Documentation for previous releases
 

	
 
Documentation for v2.3.2 has been made available for the time being at [http://getbootstrap.com/2.3.2/](http://getbootstrap.com/2.3.2/) while folks transition to Bootstrap 3.
 

	
 
[Previous releases](https://github.com/twbs/bootstrap/releases) and their documentation are also available for download.
 

	
 

	
 

	
 
## Compiling CSS and JavaScript
 

	
 
Bootstrap uses [Grunt](http://gruntjs.com/) with convenient methods for working with the framework. It's how we compile our code, run tests, and more. To use it, install the required dependencies as directed and then run some Grunt commands.
 

	
 
### Install Grunt
 

	
 
From the command line:
 

	
 
1. Install `grunt-cli` globally with `npm install -g grunt-cli`.
 
2. Install the [necessary local dependencies](package.json) via `npm install`
 

	
 
When completed, you'll be able to run the various Grunt commands provided from the command line.
 

	
 
**Unfamiliar with `npm`? Don't have node installed?** That's a-okay. npm stands for [node packaged modules](http://npmjs.org/) and is a way to manage development dependencies through node.js. [Download and install node.js](http://nodejs.org/download/) before proceeding.
 

	
 
### Available Grunt commands
 

	
 
#### Build - `grunt`
 
Run `grunt` to run tests locally and compile the CSS and JavaScript into `/dist`. **Requires [recess](https://github.com/twitter/recess) and [uglify-js](https://github.com/mishoo/UglifyJS).**
 

	
 
#### Only compile CSS and JavaScript - `grunt dist`
 
`grunt dist` creates the `/dist` directory with compiled files. **Requires [recess](https://github.com/twitter/recess) and [uglify-js](https://github.com/mishoo/UglifyJS).**
 

	
 
#### Tests - `grunt test`
 
Runs jshint and qunit tests headlessly in [phantomjs](https://github.com/ariya/phantomjs/) (used for CI). **Requires [phantomjs](https://github.com/ariya/phantomjs/).**
 

	
 
#### Watch - `grunt watch`
 
This is a convenience method for watching just Less files and automatically building them whenever you save.
 

	
 
### Troubleshooting dependencies
 

	
 
Should you encounter problems with installing dependencies or running Grunt commands, uninstall all previous dependency versions (global and local). Then, rerun `npm install`.
 

	
 

	
 

	
 
## Contributing
 

	
 
Please read through our guidelines for contributing to Bootstrap. Included are directions for opening issues, coding standards, and notes on development.
 

	
 
More over, if your pull request contains JavaScript patches or features, you must include relevant unit tests. All HTML and CSS should conform to the [Code Guide](http://github.com/mdo/code-guide), maintained by [Mark Otto](http://github.com/mdo).
 

	
 
Editor preferences are available in the [editor config](.editorconfig) for easy use in common text editors. Read more and download plugins at [http://editorconfig.org](http://editorconfig.org).
 

	
 

	
 

	
 
## Community
 

	
 
Keep track of development and community news.
 

	
 
* Follow [@twbootstrap on Twitter](http://twitter.com/twbootstrap).
 
* Read and subscribe to the [The Official Bootstrap Blog](http://blog.getbootstrap.com).
 
* Have a question that's not a feature request or bug report? [Ask on the mailing list.](http://groups.google.com/group/twitter-bootstrap)
 
* Chat with fellow Bootstrappers in IRC. On the `irc.freenode.net` server, in the `##twitter-bootstrap` channel.
 

	
 

	
 

	
 

	
 
## Versioning
 

	
 
For transparency and insight into our release cycle, and for striving to maintain backward compatibility, Bootstrap will be maintained under the Semantic Versioning guidelines as much as possible.
 

	
 
Releases will be numbered with the following format:
 

	
 
`<major>.<minor>.<patch>`
 

	
 
And constructed with the following guidelines:
 

	
 
* Breaking backward compatibility bumps the major (and resets the minor and patch)
 
* New additions without breaking backward compatibility bumps the minor (and resets the patch)
 
* Bug fixes and misc changes bumps the patch
 

	
 
For more information on SemVer, please visit [http://semver.org/](http://semver.org/).
 

	
 

	
 

	
 
## Authors
 

	
 
**Mark Otto**
 

	
 
+ [http://twitter.com/mdo](http://twitter.com/mdo)
 
+ [http://github.com/mdo](http://github.com/mdo)
 

	
 
**Jacob Thornton**
 

	
 
+ [http://twitter.com/fat](http://twitter.com/fat)
 
+ [http://github.com/fat](http://github.com/fat)
 

	
 

	
 

	
 
## Copyright and license
 

	
 
Copyright 2012 Twitter, Inc under [the Apache 2.0 license](LICENSE).
bootstrap-3.0.0/_config.yml
Show inline comments
 
new file 100644
 
# Dependencies
 
markdown:         rdiscount
 
pygments:         true
 

	
 
# Permalinks
 
permalink:        pretty
 

	
 
# Server
 
destination:      ./_gh_pages
 
exclude:          [".editorconfig", ".gitignore", ".ruby-version", "bower.json", "composer.json", "CONTRIBUTING.md", "CNAME", "LICENSE", "Gruntfile.js", "package.json", "node_modules", "README.md", "less"]
 
port:             9001
 

	
 
# Custom vars
 
repo:             https://github.com/twbs/bootstrap
 
download:         https://github.com/twbs/bootstrap/archive/v3.0.0.zip
 
download_dist:    https://github.com/twbs/bootstrap/releases/download/v3.0.0/bootstrap-3.0.0-dist.zip
 

	
 
blog:             http://blog.getbootstrap.com
 
expo:             http://expo.getbootstrap.com
 

	
 
cdn_css:          //netdna.bootstrapcdn.com/bootstrap/3.0.0/css/bootstrap.min.css
 
cdn_theme_css:    //netdna.bootstrapcdn.com/bootstrap/3.0.0/css/bootstrap-theme.min.css
 
cdn_js:           //netdna.bootstrapcdn.com/bootstrap/3.0.0/js/bootstrap.min.js
bootstrap-3.0.0/_includes/ads.html
Show inline comments
 
new file 100644
 
<div id="carbonads-container"><div class="carbonad"><div id="azcarbon"></div><script>var z = document.createElement("script"); z.async = true; z.src = "http://engine.carbonads.com/z/32341/azcarbon_2_1_0_HORIZ"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(z, s);</script></div></div>
bootstrap-3.0.0/_includes/footer.html
Show inline comments
 
new file 100644
 
<!-- Bootstrap core JavaScript
 
================================================== -->
 
<!-- Placed at the end of the document so the pages load faster -->
 
<script src="{{ page.base_url }}assets/js/jquery.js"></script>
 
<script src="{{ page.base_url }}dist/js/bootstrap.js"></script>
 

	
 
<script src="http://platform.twitter.com/widgets.js"></script>
 
<script src="{{ page.base_url }}assets/js/holder.js"></script>
 

	
 
<script src="{{ page.base_url }}assets/js/application.js"></script>
 

	
 
{% if page.slug == "customize" %}
 
<script src="{{ page.base_url }}assets/js/less.js"></script>
 
<script src="{{ page.base_url }}assets/js/jszip.js"></script>
 
<script src="{{ page.base_url }}assets/js/uglify.js"></script>
 
<script src="{{ page.base_url }}assets/js/filesaver.js"></script>
 
<script src="{{ page.base_url }}assets/js/raw-files.js"></script>
 
<script src="{{ page.base_url }}assets/js/customizer.js"></script>
 
{% endif %}
 

	
 
<!-- Analytics
 
================================================== -->
 
<script>
 
  var _gauges = _gauges || [];
 
  (function() {
 
    var t   = document.createElement('script');
 
    t.async = true;
 
    t.id    = 'gauges-tracker';
 
    t.setAttribute('data-site-id', '4f0dc9fef5a1f55508000013');
 
    t.src = '//secure.gaug.es/track.js';
 
    var s = document.getElementsByTagName('script')[0];
 
    s.parentNode.insertBefore(t, s);
 
  })();
 
</script>
bootstrap-3.0.0/_includes/header.html
Show inline comments
 
new file 100644
 
<meta charset="utf-8">
 
<meta name="viewport" content="width=device-width, initial-scale=1.0">
 
<meta name="description" content="">
 
<meta name="author" content="">
 

	
 
<title>
 
  {% if page.title == "Bootstrap" %}
 
    {{ page.title }}
 
  {% else if %}
 
    {{ page.title }} &middot; Bootstrap
 
  {% endif %}
 
</title>
 

	
 
<!-- Bootstrap core CSS -->
 
<link href="{{ page.base_url }}dist/css/bootstrap.css" rel="stylesheet">
 

	
 
<!-- Documentation extras -->
 
<link href="{{ page.base_url }}assets/css/docs.css" rel="stylesheet">
 
<link href="{{ page.base_url }}assets/css/pygments-manni.css" rel="stylesheet">
 

	
 
<!-- HTML5 shim and Respond.js IE8 support of HTML5 elements and media queries -->
 
<!--[if lt IE 9]>
 
  <script src="{{ page.base_url }}assets/js/html5shiv.js"></script>
 
  <script src="{{ page.base_url }}assets/js/respond.min.js"></script>
 
<![endif]-->
 

	
 
<!-- Favicons -->
 
<link rel="apple-touch-icon-precomposed" sizes="144x144" href="{{ page.base_url }}assets/ico/apple-touch-icon-144-precomposed.png">
 
<link rel="apple-touch-icon-precomposed" sizes="114x114" href="{{ page.base_url }}assets/ico/apple-touch-icon-114-precomposed.png">
 
  <link rel="apple-touch-icon-precomposed" sizes="72x72" href="{{ page.base_url }}assets/ico/apple-touch-icon-72-precomposed.png">
 
                <link rel="apple-touch-icon-precomposed" href="{{ page.base_url }}assets/ico/apple-touch-icon-57-precomposed.png">
 
                               <link rel="shortcut icon" href="{{ page.base_url }}assets/ico/favicon.png">
 

	
 
<script>
 
  var _gaq = _gaq || [];
 
  _gaq.push(['_setAccount', 'UA-146052-10']);
 
  _gaq.push(['_trackPageview']);
 
  (function() {
 
    var ga = document.createElement('script'); ga.async = true;
 
    ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
 
    var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
 
  })();
 
</script>
bootstrap-3.0.0/_includes/nav-components.html
Show inline comments
 
new file 100644
 
<li>
 
  <a href="#glyphicons">Glyphicons</a>
 
  <ul class="nav">
 
    <li><a href="#glyphicons-glyphs">Available glyphs</a></li>
 
    <li><a href="#glyphicons-how-to-use">How to use</a></li>
 
    <li><a href="#glyphicons-examples">Examples</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#dropdowns">Dropdowns</a>
 
  <ul class="nav">
 
    <li><a href="#dropdowns-example">Example</a></li>
 
    <li><a href="#dropdowns-alignment">Alignment options</a></li>
 
    <li><a href="#dropdowns-headers">Headers</a></li>
 
    <li><a href="#dropdowns-disabled">Disabled menu items</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#btn-groups">Button groups</a>
 
  <ul class="nav">
 
    <li><a href="#btn-groups-single">Basic example</a></li>
 
    <li><a href="#btn-groups-toolbar">Button toolbar</a></li>
 
    <li><a href="#btn-groups-sizing">Sizing</a></li>
 
    <li><a href="#btn-groups-nested">Nesting</a></li>
 
    <li><a href="#btn-groups-vertical">Vertical variation</a></li>
 
    <li><a href="#btn-groups-justified">Justified link variation</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#btn-dropdowns">Button dropdowns</a>
 
  <ul class="nav">
 
    <li><a href="#btn-dropdowns-single">Single button dropdowns</a></li>
 
    <li><a href="#btn-dropdowns-split">Split button dropdowns</a></li>
 
    <li><a href="#btn-dropdowns-sizing">Sizing</a></li>
 
    <li><a href="#btn-dropdowns-dropup">Dropup variation</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#input-groups">Input groups</a>
 
  <ul class="nav">
 
    <li><a href="#input-groups-basic">Basic example</a></li>
 
    <li><a href="#input-groups-sizing">Sizing</a></li>
 
    <li><a href="#input-groups-checkboxes-radios">Checkbox and radios addons</a></li>
 
    <li><a href="#input-groups-buttons">Button addons</a></li>
 
    <li><a href="#input-groups-buttons-dropdowns">Buttons with dropdowns</a></li>
 
    <li><a href="#input-groups-buttons-segmented">Segmented buttons</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#nav">Navs</a>
 
  <ul class="nav">
 
    <li><a href="#nav-tabs">Tabs</a></li>
 
    <li><a href="#nav-pills">Pills</a></li>
 
    <li><a href="#nav-justified">Justified nav</a></li>
 
    <li><a href="#nav-disabled-links">Disabled links</a></li>
 
    <li><a href="#nav-alignment">Alignment options</a></li>
 
    <li><a href="#nav-dropdowns">Using dropdowns</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#navbar">Navbar</a>
 
  <ul class="nav">
 
    <li><a href="#navbar-default">Default navbar</a></li>
 
    <li><a href="#navbar-buttons">Buttons</a></li>
 
    <li><a href="#navbar-text">Text</a></li>
 
    <li><a href="#navbar-links">Non-nav links</a></li>
 
    <li><a href="#navbar-component-alignment">Component alignment</a></li>
 
    <li><a href="#navbar-fixed-top">Fixed to top</a></li>
 
    <li><a href="#navbar-fixed-bottom">Fixed to bottom</a></li>
 
    <li><a href="#navbar-static-top">Static top</a></li>
 
    <li><a href="#navbar-inverted">Inverted navbar</a></li>
 
  </ul>
 
</li>
 
<li><a href="#breadcrumbs">Breadcrumbs</a></li>
 
<li>
 
  <a href="#pagination">Pagination</a>
 
  <ul class="nav">
 
    <li><a href="#pagination-default">Default pagination</a></li>
 
    <li><a href="#pagination-pager">Pager</a></li>
 
  </ul>
 
</li>
 
<li><a href="#labels">Labels</a></li>
 
<li><a href="#badges">Badges</a></li>
 
<li><a href="#jumbotron">Jumbotron</a></li>
 
<li><a href="#page-header">Page header</a></li>
 
<li>
 
  <a href="#thumbnails">Thumbnails</a>
 
  <ul class="nav">
 
    <li><a href="#thumbnails-default">Default example</a></li>
 
    <li><a href="#thumbnails-custom-content">Custom content</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#alerts">Alerts</a>
 
  <ul class="nav">
 
    <li><a href="#alerts-examples">Examples</a></li>
 
    <li><a href="#alerts-dismissable">Dismissable alerts</a></li>
 
    <li><a href="#alerts-links">Links in alerts</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#progress">Progress bars</a>
 
  <ul class="nav">
 
    <li><a href="#progress-basic">Basic example</a></li>
 
    <li><a href="#progress-alternatives">Contextual alternatives</a></li>
 
    <li><a href="#progress-striped">Striped</a></li>
 
    <li><a href="#progress-animated">Animated</a></li>
 
    <li><a href="#progress-stacked">Stacked</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#media">Media object</a>
 
  <ul class="nav">
 
    <li><a href="#media-default">Default media</a></li>
 
    <li><a href="#media-list">Media list</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#list-group">List group</a>
 
  <ul class="nav">
 
    <li><a href="#list-group-basic">Basic example</a></li>
 
    <li><a href="#list-group-badges">Badges</a></li>
 
    <li><a href="#list-group-linked">Linked items</a></li>
 
    <li><a href="#list-group-custom-content">Custom content</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#panels">Panels</a>
 
  <ul class="nav">
 
    <li><a href="#panels-basic">Basic example</a></li>
 
    <li><a href="#panels-heading">Panel with heading</a></li>
 
    <li><a href="#panels-alternatives">Contextual alternatives</a></li>
 
    <li><a href="#panels-tables">With tables</a>
 
    <li><a href="#panels-list-group">With list groups</a>
 
  </ul>
 
</li>
 
<li><a href="#wells">Wells</a></li>
bootstrap-3.0.0/_includes/nav-css.html
Show inline comments
 
new file 100644
 
<li>
 
  <a href="#overview">Overview</a>
 
  <ul class="nav">
 
    <li><a href="#overview-doctype">HTML5 doctype</a></li>
 
    <li><a href="#overview-mobile">Mobile first</a></li>
 
    <li><a href="#overview-responsive-images">Responsive images</a></li>
 
    <li><a href="#overview-type-links">Typography and links</a></li>
 
    <li><a href="#overview-normalize">Normalize</a></li>
 
    <li><a href="#overview-container">Containers</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#grid">Grid system</a>
 
  <ul class="nav">
 
    <li><a href="#grid-media-queries">Media queries</a></li>
 
    <li><a href="#grid-options">Grid options</a></li>
 
    <li><a href="#grid-example-basic">Ex: Stacked-to-horizonal</a></li>
 
    <li><a href="#grid-example-mixed">Ex: Mobile and desktops</a></li>
 
    <li><a href="#grid-example-mixed-complete">Ex: Mobile, tablet, desktops</a></li>
 
    <li><a href="#grid-responsive-resets">Responsive column resets</a></li>
 
    <li><a href="#grid-offsetting">Offsetting columns</a></li>
 
    <li><a href="#grid-nesting">Nesting columns</a></li>
 
    <li><a href="#grid-column-ordering">Column ordering</a></li>
 
    <li><a href="#grid-less">LESS mixins and variables</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#type">Typography</a>
 
  <ul class="nav">
 
    <li><a href="#type-headings">Headings</a></li>
 
    <li><a href="#type-body-copy">Body copy</a></li>
 
    <li><a href="#type-emphasis">Emphasis</a></li>
 
    <li><a href="#type-abbreviations">Abbreviations</a></li>
 
    <li><a href="#type-addresses">Addresses</a></li>
 
    <li><a href="#type-blockquotes">Blockquotes</a></li>
 
    <li><a href="#type-lists">Lists</a></li>
 
  </ul>
 
</li>
 
<li><a href="#code">Code</a></li>
 
<li>
 
  <a href="#tables">Tables</a>
 
  <ul class="nav">
 
    <li><a href="#tables-example">Basic example</a></li>
 
    <li><a href="#tables-striped">Striped rows</a></li>
 
    <li><a href="#tables-bordered">Bordered table</a></li>
 
    <li><a href="#tables-hover-rows">Hover rows</a></li>
 
    <li><a href="#tables-condensed">Condensed table</a></li>
 
    <li><a href="#tables-contextual-classes">Contextual classes</a></li>
 
    <li><a href="#tables-responsive">Responsive tables</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#forms">Forms</a>
 
  <ul class="nav">
 
    <li><a href="#forms-example">Basic example</a></li>
 
    <li><a href="#forms-inline">Inline form</a></li>
 
    <li><a href="#forms-horizontal">Horizontal form</a></li>
 
    <li><a href="#forms-controls">Supported controls</a></li>
 
    <li><a href="#forms-controls-static">Static control</a></li>
 
    <li><a href="#forms-control-states">Control states</a></li>
 
    <li><a href="#forms-control-sizes">Control sizing</a></li>
 
    <li><a href="#forms-help-text">Help text</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#buttons">Buttons</a>
 
  <ul class="nav">
 
    <li><a href="#buttons-options">Options</a></li>
 
    <li><a href="#buttons-sizes">Sizes</a></li>
 
    <li><a href="#buttons-disabled">Disabled state</a></li>
 
    <li><a href="#buttons-tags">Button tags</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#images">Images</a>
 
</li>
 
<li>
 
  <a href="#helper-classes">Helper classes</a>
 
</li>
 
<li>
 
  <a href="#responsive-utilities">Responsive utilities</a>
 
  <ul class="nav">
 
    <li><a href="#responsive-utilities-classes">Available classes</a></li>
 
    <li><a href="#responsive-utilities-print">Print classes</a></li>
 
    <li><a href="#responsive-utilities-tests">Test cases</a></li>
 
  </ul>
 
</li>
bootstrap-3.0.0/_includes/nav-customize.html
Show inline comments
 
new file 100644
 
<li>
 
  <a href="#less">LESS components</a>
 
</li>
 
<li>
 
  <a href="#plugins">jQuery plugins</a>
 
</li>
 
<li>
 
  <a href="#less-variables">LESS variables</a>
 
  <ul class="nav">
 
    <li><a href="#variables-basics">Basics</a></li>
 
    <li><a href="#variables-buttons">Buttons</a></li>
 
    <li><a href="#variables-form-states">Form states</a></li>
 
    <li><a href="#variables-alerts">Alerts</a></li>
 
    <li><a href="#variables-navbar">Navbar</a></li>
 
    <li><a href="#variables-nav">Nav</a></li>
 
    <li><a href="#variables-tables">Tables</a></li>
 
    <li><a href="#variables-forms">Forms</a></li>
 
    <li><a href="#variables-dropdowns">Dropdowns</a></li>
 
    <li><a href="#variables-panels-wells">Panels and wells</a></li>
 
    <li><a href="#variables-accordion">Accordion</a></li>
 
    <li><a href="#variables-badges">Badges</a></li>
 
    <li><a href="#variables-breadcrumbs">Breadcrumbs</a></li>
 
    <li><a href="#variables-jumbotron">Jumbotron</a></li>
 
    <li><a href="#variables-modals">Modals</a></li>
 
    <li><a href="#variables-carousel">Carousel</a></li>
 
    <li><a href="#variables-list-group">List group</a></li>
 
    <li><a href="#variables-thumbnails">Thumbnails</a></li>
 
    <li><a href="#variables-progress">Progress bars</a></li>
 
    <li><a href="#variables-pagination">Pagination</a></li>
 
    <li><a href="#variables-pager">Pager</a></li>
 
    <li><a href="#variables-labels">Labels</a></li>
 
    <li><a href="#variables-tooltips-popovers">Tooltips and popovers</a></li>
 
    <li><a href="#variables-close">Close button</a></li>
 
    <li><a href="#variables-type">Type</a></li>
 
    <li><a href="#variables-other">Other</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#download">Download</a>
 
</li>
bootstrap-3.0.0/_includes/nav-getting-started.html
Show inline comments
 
new file 100644
 
<li>
 
  <a href="#download">Download Bootstrap</a>
 
  <ul class="nav">
 
    <li><a href="#download-compiled">Compiled CSS, JS, and fonts</a></li>
 
    <li><a href="#download-additional">Additional downloads</a></li>
 
    <li><a href="#download-cdn">Bootstrap CDN</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#whats-included">What's included</a>
 
</li>
 
<li>
 
  <a href="#template">Basic template</a>
 
</li>
 
<li>
 
  <a href="#examples">Examples</a>
 
</li>
 
<li>
 
  <a href="#disable-responsive">Disabling responsiveness</a>
 
</li>
 
<li>
 
  <a href="#migration">Migrating from 2.x to 3.0</a>
 
  <ul class="nav">
 
    <li><a href="#migration-classes">Major class changes</a></li>
 
    <li><a href="#migration-new">What's new</a></li>
 
    <li><a href="#migration-dropped">What's removed</a></li>
 
    <li><a href="#migration-notes">Additional notes</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#browsers">Browser support</a>
 
</li>
 
<li>
 
  <a href="#third-parties">Third party support</a>
 
</li>
 
<li>
 
  <a href="#accessibility">Accessibility</a>
 
</li>
 
<li>
 
  <a href="#license-faqs">License FAQs</a>
 
</li>
 
<li>
 
  <a href="#customizing">Customizing Bootstrap</a>
 
</li>
bootstrap-3.0.0/_includes/nav-javascript.html
Show inline comments
 
new file 100644
 
<li>
 
  <a href="#js-overview">Overview</a>
 
  <ul class="nav">
 
    <li><a href="#js-individual-compiled">Individual or compiled</a></li>
 
    <li><a href="#js-data-attrs">Data attributes</a></li>
 
    <li><a href="#js-programmatic-api">Programmatic API</a></li>
 
    <li><a href="#js-noconflict">No conflict</a></li>
 
    <li><a href="#js-events">Events</a></li>
 
  </ul>
 
</li>
 
<li><a href="#transitions">Transitions</a></li>
 
<li>
 
  <a href="#modals">Modal</a>
 
  <ul class="nav">
 
    <li><a href="#modals-examples">Examples</a></li>
 
    <li><a href="#modals-usage">Usage</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#dropdowns">Dropdown</a>
 
  <ul class="nav">
 
    <li><a href="#dropdowns-examples">Examples</a></li>
 
    <li><a href="#dropdowns-usage">Usage</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#scrollspy">Scrollspy</a>
 
  <ul class="nav">
 
    <li><a href="#scrollspy-examples">Examples</a></li>
 
    <li><a href="#scrollspy-usage">Usage</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#tabs">Tab</a>
 
  <ul class="nav">
 
    <li><a href="#tabs-examples">Examples</a></li>
 
    <li><a href="#tabs-usage">Usage</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#tooltips">Tooltip</a>
 
  <ul class="nav">
 
    <li><a href="#tooltips-examples">Examples</a></li>
 
    <li><a href="#tooltips-usage">Usage</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#popovers">Popover</a>
 
  <ul class="nav">
 
    <li><a href="#popovers-examples">Examples</a></li>
 
    <li><a href="#popovers-usage">Usage</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#alerts">Alert</a>
 
  <ul class="nav">
 
    <li><a href="#alerts-examples">Examples</a></li>
 
    <li><a href="#alerts-usage">Usage</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#buttons">Button</a>
 
  <ul class="nav">
 
    <li><a href="#buttons-examples">Examples</a></li>
 
    <li><a href="#buttons-usage">Usage</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#collapse">Collapse</a>
 
  <ul class="nav">
 
    <li><a href="#collapse-examples">Examples</a></li>
 
    <li><a href="#collapse-usage">Usage</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#carousel">Carousel</a>
 
  <ul class="nav">
 
    <li><a href="#carousel-examples">Examples</a></li>
 
    <li><a href="#carousel-usage">Usage</a></li>
 
  </ul>
 
</li>
 
<li>
 
  <a href="#affix">Affix</a>
 
  <ul class="nav">
 
    <li><a href="#affix-examples">Examples</a></li>
 
    <li><a href="#affix-usage">Usage</a></li>
 
  </ul>
 
</li>
bootstrap-3.0.0/_includes/nav-main.html
Show inline comments
 
new file 100644
 
<header class="navbar navbar-inverse navbar-fixed-top bs-docs-nav" role="banner">
 
  <div class="container">
 
    <div class="navbar-header">
 
      <button class="navbar-toggle" type="button" data-toggle="collapse" data-target=".bs-navbar-collapse">
 
        <span class="sr-only">Toggle navigation</span>
 
        <span class="icon-bar"></span>
 
        <span class="icon-bar"></span>
 
        <span class="icon-bar"></span>
 
      </button>
 
      <a href="{{ page.base_url }}" class="navbar-brand">Bootstrap</a>
 
    </div>
 
    <nav class="collapse navbar-collapse bs-navbar-collapse" role="navigation">
 
      <ul class="nav navbar-nav">
 
        <li{% if page.slug == "getting-started" %} class="active"{% endif %}>
 
          <a href="{{ page.base_url }}getting-started">Getting started</a>
 
        </li>
 
        <li{% if page.slug == "css" %} class="active"{% endif %}>
 
          <a href="{{ page.base_url }}css">CSS</a>
 
        </li>
 
        <li{% if page.slug == "components" %} class="active"{% endif %}>
 
          <a href="{{ page.base_url }}components">Components</a>
 
        </li>
 
        <li{% if page.slug == "js" %} class="active"{% endif %}>
 
          <a href="{{ page.base_url }}javascript">JavaScript</a>
 
        </li>
 
        <li{% if page.slug == "customize" %} class="active"{% endif %}>
 
          <a href="{{ page.base_url }}customize">Customize</a>
 
        </li>
 
      </ul>
 
    </nav>
 
  </div>
 
</header>
bootstrap-3.0.0/_includes/old-bs-docs.html
Show inline comments
 
new file 100644
 
<div class="bs-old-docs">
 
  <div class="container">
 
    <strong>
 
      <a href="{{ page.base_url }}2.3.2/">Looking for Bootstrap 2.3.2 docs?</a>
 
    </strong>
 
    We've moved it to a new home while we push forward with Bootstrap 3. <a href="http://blog.getbootstrap.com/">Read the blog</a> for details.
 
  </div>
 
</div>
bootstrap-3.0.0/_includes/social-buttons.html
Show inline comments
 
new file 100644
 
<div class="bs-social">
 
  <ul class="bs-social-buttons">
 
    <li>
 
      <iframe class="github-btn" src="http://ghbtns.com/github-btn.html?user=twbs&amp;repo=bootstrap&amp;type=watch&amp;count=true" width="100" height="20" title="Star on GitHub"></iframe>
 
    </li>
 
    <li>
 
      <iframe class="github-btn" src="http://ghbtns.com/github-btn.html?user=twbs&amp;repo=bootstrap&amp;type=fork&amp;count=true" width="102" height="20" title="Fork on GitHub"></iframe>
 
    </li>
 
    <li class="follow-btn">
 
      <a href="https://twitter.com/twbootstrap" class="twitter-follow-button" data-link-color="#0069D6" data-show-count="true">Follow @twbootstrap</a>
 
    </li>
 
    <li class="tweet-btn">
 
      <a href="https://twitter.com/share" class="twitter-share-button" data-url="http://getbootstrap.com/" data-count="horizontal" data-via="twbootstrap" data-related="mdo:Creator of Twitter Bootstrap">Tweet</a>
 
    </li>
 
  </ul>
 
</div>
bootstrap-3.0.0/_layouts/default.html
Show inline comments
 
new file 100644
 
<!DOCTYPE html>
 
<html lang="en">
 
  <head>
 
    <!-- Meta, title, CSS, favicons, etc. -->
 
    {% include header.html %}
 
    <!-- Place anything custom after this. -->
 
  </head>
 
  <body>
 
    <a class="sr-only" href="#content">Skip navigation</a>
 

	
 
    <!-- Docs master nav -->
 
    {% include nav-main.html %}
 

	
 
    <!-- Docs page layout -->
 
    <div class="bs-header" id="content">
 
      <div class="container">
 
        <h1>{{ page.title }}</h1>
 
        <p>{{ page.lead }}</p>
 
        {% include ads.html %}
 
      </div>
 
    </div>
 

	
 
    <!-- Callout for the old docs link -->
 
    {% include old-bs-docs.html %}
 

	
 
    <div class="container bs-docs-container">
 
      <div class="row">
 
        <div class="col-md-3">
 
          <div class="bs-sidebar hidden-print" role="complementary">
 
            <ul class="nav bs-sidenav">
 
              {% if page.slug == "getting-started" %}
 
                {% include nav-getting-started.html %}
 
              {% elsif page.slug == "css" %}
 
                {% include nav-css.html %}
 
              {% elsif page.slug == "components" %}
 
                {% include nav-components.html %}
 
              {% elsif page.slug == "js" %}
 
                {% include nav-javascript.html %}
 
              {% elsif page.slug == "customize" %}
 
                {% include nav-customize.html %}
 
              {% endif %}
 
            </ul>
 
          </div>
 
        </div>
 
        <div class="col-md-9" role="main">
 
          {{ content }}
 
        </div>
 
      </div>
 

	
 
    </div>
 

	
 
    <!-- Footer
 
    ================================================== -->
 
    <footer class="bs-footer" role="contentinfo">
 
      <div class="container">
 
        {% include social-buttons.html %}
 

	
 
        <p>Designed and built with all the love in the world by <a href="http://twitter.com/mdo" target="_blank">@mdo</a> and <a href="http://twitter.com/fat" target="_blank">@fat</a>.</p>
 
        <p>Code licensed under <a href="http://www.apache.org/licenses/LICENSE-2.0" target="_blank">Apache License v2.0</a>, documentation under <a href="http://creativecommons.org/licenses/by/3.0/">CC BY 3.0</a>.</p>
 
        <ul class="footer-links">
 
          <li><a href="{{ page.base_url }}2.3.2/">Bootstrap 2.3.2 docs</a></li>
 
          <li class="muted">&middot;</li>
 
          <li><a href="{{ site.blog }}">Blog</a></li>
 
          <li class="muted">&middot;</li>
 
          <li><a href="{{ site.repo }}/issues?state=open">Issues</a></li>
 
          <li class="muted">&middot;</li>
 
          <li><a href="{{ site.repo }}/releases">Releases</a></li>
 
        </ul>
 
      </div>
 
    </footer>
 

	
 
    <!-- JS and analytics only. -->
 
    {% include footer.html %}
 

	
 
  </body>
 
</html>
bootstrap-3.0.0/_layouts/home.html
Show inline comments
 
new file 100644
 
<!DOCTYPE html>
 
<html lang="en">
 
  <head>
 
    <!-- Meta, title, CSS, favicons, etc. -->
 
    {% include header.html %}
 
    <!-- Place anything custom after this. -->
 
  </head>
 
  <body class="bs-docs-home">
 
    <a class="sr-only" href="#content">Skip navigation</a>
 

	
 
    <!-- Docs master nav -->
 
    {% include nav-main.html %}
 

	
 
    <!-- Page content of course! -->
 
    {{ content }}
 

	
 
    <footer class="container" role="contentinfo">
 
      {% include social-buttons.html %}
 

	
 
      <ul class="bs-masthead-links">
 
        <li class="current-version">
 
          Currently v3.0.0
 
        </li>
 
        <li>
 
          <a href="{{ page.base_url }}2.3.2/">Bootstrap 2.3.2 docs</a>
 
        </li>
 
        <li>
 
          <a href="{{ site.repo }}" onclick="_gaq.push(['_trackEvent', 'Jumbotron actions', 'Jumbotron links', 'GitHub project']);">GitHub project</a>
 
        </li>
 
        <li>
 
          <a href="{{ page.base_url }}getting-started/#examples" onclick="_gaq.push(['_trackEvent', 'Jumbotron actions', 'Jumbotron links', 'Examples']);">Examples</a>
 
        </li>
 
        <li>
 
          <a href="{{ page.base_url }}components/#glyphicons" onclick="_gaq.push(['_trackEvent', 'Jumbotron actions', 'Jumbotron links', 'Glyphicons']);">Glyphicons</a>
 
        </li>
 
        <li>
 
          <a href="{{ site.expo }}" onclick="_gaq.push(['_trackEvent', 'Jumbotron actions', 'Jumbotron links', 'Expo']);">Expo</a>
 
        </li>
 
      </ul>
 
    </footer>
 

	
 
    <!-- JS and analytics only. -->
 
    {% include footer.html %}
 

	
 
  </body>
 
</html>
bootstrap-3.0.0/assets/css/docs.css
Show inline comments
 
new file 100644
 
/*
 
 * Bootstrap Documentation
 
 * Special styles for presenting Bootstrap's documentation and code examples.
 
 *
 
 * Table of contents:
 
 *
 
 * Scaffolding
 
 * Main navigation
 
 * Footer
 
 * Social buttons
 
 * Homepage
 
 * Page headers
 
 * Old docs callout
 
 * Ads
 
 * Side navigation
 
 * Docs sections
 
 * Callouts
 
 * Grid styles
 
 * Examples
 
 * Code snippets (highlight)
 
 * Responsive tests
 
 * Glyphicons
 
 * Customizer
 
 * Miscellaneous
 
 */
 

	
 

	
 
/*
 
 * Scaffolding
 
 *
 
 * Update the basics of our documents to prep for docs content.
 
 */
 

	
 
body {
 
  position: relative; /* For scrollyspy */
 
  padding-top: 50px; /* Account for fixed navbar */
 
}
 

	
 
/* Keep code small in tables on account of limited space */
 
.table code {
 
  font-size: 13px;
 
  font-weight: normal;
 
}
 

	
 
/* Outline button for use within the docs */
 
.btn-outline {
 
  color: #563d7c;
 
  background-color: #fff;
 
  border-color: #e5e5e5;
 
}
 
.btn-outline:hover,
 
.btn-outline:focus,
 
.btn-outline:active {
 
  color: #fff;
 
  background-color: #563d7c;
 
  border-color: #563d7c;
 
}
 

	
 
/* Inverted outline button (white on dark) */
 
.btn-outline-inverse {
 
  color: #fff;
 
  background-color: transparent;
 
  border-color: #cdbfe3;
 
}
 
.btn-outline-inverse:hover,
 
.btn-outline-inverse:focus,
 
.btn-outline-inverse:active {
 
  color: #563d7c;
 
  text-shadow: none;
 
  background-color: #fff;
 
  border-color: #fff;
 
}
 

	
 

	
 
/*
 
 * Main navigation
 
 *
 
 * Turn the `.navbar` at the top of the docs purple.
 
 */
 

	
 
.bs-docs-nav {
 
  text-shadow: 0 -1px 0 rgba(0,0,0,.15);
 
  background-color: #563d7c;
 
  border-color: #463265;
 
  box-shadow: 0 1px 0 rgba(255,255,255,.1);
 
}
 
.bs-docs-nav .navbar-collapse {
 
  border-color: #463265;
 
}
 
.bs-docs-nav .navbar-brand {
 
  color: #fff;
 
}
 
.bs-docs-nav .navbar-nav > li > a {
 
  color: #cdbfe3;
 
}
 
.bs-docs-nav .navbar-nav > li > a:hover {
 
  color: #fff;
 
}
 
.bs-docs-nav .navbar-nav > .active > a,
 
.bs-docs-nav .navbar-nav > .active > a:hover {
 
  color: #fff;
 
  background-color: #463265;
 
}
 
.bs-docs-nav .navbar-toggle {
 
  border-color: #563d7c;
 
}
 
.bs-docs-nav .navbar-toggle:hover {
 
  background-color: #463265;
 
  border-color: #463265;
 
}
 

	
 

	
 
/*
 
 * Footer
 
 *
 
 * Separated section of content at the bottom of all pages, save the homepage.
 
 */
 

	
 
.bs-footer {
 
  padding-top: 40px;
 
  padding-bottom: 30px;
 
  margin-top: 100px;
 
  color: #777;
 
  text-align: center;
 
  border-top: 1px solid #e5e5e5;
 
}
 
.footer-links {
 
  margin: 10px 0;
 
  padding-left: 0;
 
}
 
.footer-links li {
 
  display: inline;
 
  padding: 0 2px;
 
}
 
.footer-links li:first-child {
 
  padding-left: 0;
 
}
 

	
 
@media (min-width: 768px) {
 
  .bs-footer {
 
    text-align: left;
 
  }
 
  .bs-footer p {
 
    margin-bottom: 0;
 
  }
 
}
 

	
 

	
 
/*
 
 * Social buttons
 
 *
 
 * Twitter and GitHub social action buttons (for homepage and footer).
 
 */
 

	
 
.bs-social {
 
  margin-top: 20px;
 
  margin-bottom: 20px;
 
  text-align: center;
 
}
 
.bs-social-buttons {
 
  display: inline-block;
 
  margin-bottom: 0;
 
  padding-left: 0;
 
  list-style: none;
 
}
 
.bs-social-buttons li {
 
  display: inline-block;
 
  line-height: 1;
 
  padding: 5px 8px;
 
}
 
.bs-social-buttons .twitter-follow-button {
 
  width: 225px !important;
 
}
 
.bs-social-buttons .twitter-share-button {
 
  width: 98px !important;
 
}
 
/* Style the GitHub buttons via CSS instead of inline attributes */
 
.github-btn {
 
  border: 0;
 
  overflow: hidden;
 
}
 

	
 
@media screen and (min-width: 768px) {
 
  .bs-social {
 
    text-align: left;
 
  }
 
  .bs-social-buttons li:first-child {
 
    padding-left: 0;
 
  }
 
}
 

	
 

	
 
/*
 
 * Topography, yo!
 
 *
 
 * Apply the map background via base64 and relevant colors where we need 'em.
 
 */
 

	
 
.bs-docs-home,
 
.bs-header {
 
  color: #cdbfe3;
 
  background-color: #563d7c;
 
  background-image: url();
 
}
 

	
 

	
 
/*
 
 * Homepage
 
 *
 
 * Tweaks to the custom homepage and the masthead (main jumbotron).
 
 */
 

	
 
 /* Masthead (headings and download button) */
 
 .bs-masthead {
 
  position: relative;
 
  padding: 30px 15px;
 
  text-align: center;
 
  text-shadow: 0 1px 0 rgba(0,0,0,.15);
 
}
 
.bs-masthead h1 {
 
  font-size: 50px;
 
  line-height: 1;
 
  color: #fff;
 
}
 
.bs-masthead .btn-outline {
 
  margin-top: 20px;
 
  margin-bottom: 20px;
 
  padding: 18px 24px;
 
  font-size: 21px;
 
}
 

	
 
/* Links to project-level content like the repo, Expo, etc */
 
.bs-masthead-links {
 
  margin-top: 20px;
 
  margin-bottom: 20px;
 
  padding: 0 15px;
 
  list-style: none;
 
  text-align: center;
 
}
 
.bs-masthead-links li {
 
  display: inline;
 
}
 
.bs-masthead-links li + li {
 
  margin-left: 20px;
 
}
 
.bs-masthead-links a {
 
  color: #fff;
 
}
 

	
 
@media screen and (min-width: 768px) {
 
  .bs-masthead {
 
    text-align: left;
 
    padding-top:    140px;
 
    padding-bottom: 140px;
 
  }
 
  .bs-masthead h1 {
 
    font-size: 100px;
 
  }
 
  .bs-masthead .lead {
 
    margin-right: 25%;
 
    font-size: 30px;
 
  }
 
  .bs-masthead-links {
 
    padding: 0;
 
    text-align: left;
 
  }
 
}
 

	
 

	
 
/*
 
 * Page headers
 
 *
 
 * Jumbotron-esque headers at the top of every page that's not the homepage.
 
 */
 

	
 

	
 
/* Page headers */
 
.bs-header {
 
  padding: 30px 15px 40px; /* side padding builds on .container 15px, so 30px */
 
  font-size: 16px;
 
  text-align: center;
 
  text-shadow: 0 1px 0 rgba(0,0,0,.15);
 
}
 
.bs-header h1 {
 
  color: #fff;
 
}
 
.bs-header p {
 
  font-weight: 300;
 
  line-height: 1.5;
 
}
 
.bs-header .container {
 
  position: relative;
 
}
 

	
 
@media screen and (min-width: 768px) {
 
  .bs-header {
 
    font-size: 21px;
 
    text-align: left;
 
  }
 
  .bs-header h1 {
 
    font-size: 60px;
 
    line-height: 1;
 
  }
 
}
 

	
 
@media screen and (min-width: 992px) {
 
  .bs-header h1,
 
  .bs-header p {
 
    margin-right: 380px;
 
  }
 
}
 

	
 

	
 
/*
 
 * Carbon ads
 
 *
 
 * Single display ad that shows on all pages (except homepage) in page headers.
 
 * The hella `!important` is required for any pre-set property.
 
 */
 

	
 
.carbonad {
 
  width: auto !important;
 
  margin: 50px -30px -40px !important;
 
  padding: 20px !important;
 
  overflow: hidden; /* clearfix */
 
  height: auto !important;
 
  font-size: 13px !important;
 
  line-height: 16px !important;
 
  text-align: left;
 
  background: #463265 !important;
 
  border: 0 !important;
 
  box-shadow: inset 0 3px 5px rgba(0,0,0,.075);
 
}
 
.carbonad-img {
 
  margin: 0 !important;
 
}
 
.carbonad-text,
 
.carbonad-tag {
 
  float: none !important;
 
  display: block !important;
 
  width: auto !important;
 
  height: auto !important;
 
  margin-left: 145px !important;
 
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif !important;
 
}
 
.carbonad-text {
 
  padding-top: 0 !important;
 
}
 
.carbonad-tag {
 
  color: #cdbfe3 !important;
 
  text-align: left !important;
 
}
 
.carbonad-text a,
 
.carbonad-tag a {
 
  color: #fff !important;
 
}
 
.carbonad #azcarbon > img {
 
  display: none; /* hide what I assume are tracking images */
 
}
 

	
 
@media screen and (min-width: 768px) {
 
  .carbonad {
 
    margin: 0 !important;
 
    border-radius: 4px;
 
    box-shadow: inset 0 3px 5px rgba(0,0,0,.075), 0 1px 0 rgba(255,255,255,.1);
 
  }
 
}
 

	
 
@media screen and (min-width: 992px) {
 
  .carbonad {
 
    position: absolute;
 
    top: 20px;
 
    right: 0;
 
    padding: 15px !important;
 
    width: 330px !important;
 
    min-height: 132px;
 
  }
 
}
 

	
 

	
 
/*
 
 * Callout for 2.3.2 docs
 
 *
 
 * Only appears below page headers (not on the homepage). The homepage gets its
 
 * own link with the masthead links.
 
 */
 

	
 
.bs-old-docs {
 
  padding: 15px 20px;
 
  color: #777;
 
  background-color: #fafafa;
 
  border-top: 1px solid #fff;
 
  border-bottom: 1px solid #e5e5e5;
 
}
 
.bs-old-docs strong {
 
  color: #555;
 
}
 

	
 

	
 
/*
 
 * Side navigation
 
 *
 
 * Scrollspy and affixed enhanced navigation to highlight sections and secondary
 
 * sections of docs content.
 
 */
 

	
 
/* By default it's not affixed in mobile views, so undo that */
 
.bs-sidebar.affix {
 
  position: static;
 
}
 

	
 
/* First level of nav */
 
.bs-sidenav {
 
  margin-top: 30px;
 
  margin-bottom: 30px;
 
  padding-top:    10px;
 
  padding-bottom: 10px;
 
  text-shadow: 0 1px 0 #fff;
 
  background-color: #f7f5fa;
 
  border-radius: 5px;
 
}
 

	
 
/* All levels of nav */
 
.bs-sidebar .nav > li > a {
 
  display: block;
 
  color: #716b7a;
 
  padding: 5px 20px;
 
}
 
.bs-sidebar .nav > li > a:hover,
 
.bs-sidebar .nav > li > a:focus {
 
  text-decoration: none;
 
  background-color: #e5e3e9;
 
  border-right: 1px solid #dbd8e0;
 
}
 
.bs-sidebar .nav > .active > a,
 
.bs-sidebar .nav > .active:hover > a,
 
.bs-sidebar .nav > .active:focus > a {
 
  font-weight: bold;
 
  color: #563d7c;
 
  background-color: transparent;
 
  border-right: 1px solid #563d7c;
 
}
 

	
 
/* Nav: second level (shown on .active) */
 
.bs-sidebar .nav .nav {
 
  display: none; /* Hide by default, but at >768px, show it */
 
  margin-bottom: 8px;
 
}
 
.bs-sidebar .nav .nav > li > a {
 
  padding-top:    3px;
 
  padding-bottom: 3px;
 
  padding-left: 30px;
 
  font-size: 90%;
 
}
 

	
 
/* Show and affix the side nav when space allows it */
 
@media screen and (min-width: 992px) {
 
  .bs-sidebar .nav > .active > ul {
 
    display: block;
 
  }
 
  /* Widen the fixed sidebar */
 
  .bs-sidebar.affix,
 
  .bs-sidebar.affix-bottom {
 
    width: 213px;
 
  }
 
  .bs-sidebar.affix {
 
    position: fixed; /* Undo the static from mobile first approach */
 
    top: 80px;
 
  }
 
  .bs-sidebar.affix-bottom {
 
    position: absolute; /* Undo the static from mobile first approach */
 
  }
 
  .bs-sidebar.affix-bottom .bs-sidenav,
 
  .bs-sidebar.affix .bs-sidenav {
 
    margin-top: 0;
 
    margin-bottom: 0;
 
  }
 
}
 
@media screen and (min-width: 1200px) {
 
  /* Widen the fixed sidebar again */
 
  .bs-sidebar.affix-bottom,
 
  .bs-sidebar.affix {
 
    width: 263px;
 
  }
 
}
 

	
 

	
 
/*
 
 * Docs sections
 
 *
 
 * Content blocks for each component or feature.
 
 */
 

	
 
/* Space things out */
 
.bs-docs-section + .bs-docs-section {
 
  padding-top: 40px;
 
}
 

	
 
/* Janky fix for preventing navbar from overlapping */
 
h1[id] {
 
  padding-top: 80px;
 
  margin-top: -45px;
 
}
 

	
 

	
 
/*
 
 * Callouts
 
 *
 
 * Not quite alerts, but custom and helpful notes for folks reading the docs.
 
 * Requires a base and modifier class.
 
 */
 

	
 
/* Common styles for all types */
 
.bs-callout {
 
  margin: 20px 0;
 
  padding: 15px 30px 15px 15px;
 
  border-left: 5px solid #eee;
 
}
 
.bs-callout h4 {
 
  margin-top: 0;
 
}
 
.bs-callout p:last-child {
 
  margin-bottom: 0;
 
}
 
.bs-callout code,
 
.bs-callout .highlight {
 
  background-color: #fff;
 
}
 

	
 
/* Variations */
 
.bs-callout-danger {
 
  background-color: #fcf2f2;
 
  border-color: #dFb5b4;
 
}
 
.bs-callout-warning {
 
  background-color: #fefbed;
 
  border-color: #f1e7bc;
 
}
 
.bs-callout-info {
 
  background-color: #f0f7fd;
 
  border-color: #d0e3f0;
 
}
 

	
 

	
 
/*
 
 * Grid examples
 
 *
 
 * Highlight the grid columns within the docs so folks can see their padding,
 
 * alignment, sizing, etc.
 
 */
 

	
 
.show-grid {
 
  margin-bottom: 15px;
 
}
 
.show-grid [class^="col-"] {
 
  padding-top: 10px;
 
  padding-bottom: 10px;
 
  background-color: #eee;
 
  border: 1px solid #ddd;
 
  background-color: rgba(86,61,124,.15);
 
  border: 1px solid rgba(86,61,124,.2);
 
}
 

	
 

	
 
/*
 
 * Examples
 
 *
 
 * Isolated sections of example content for each component or feature. Usually
 
 * followed by a code snippet.
 
 */
 

	
 
.bs-example {
 
  position: relative;
 
  padding: 45px 15px 15px;
 
  margin: 0 -15px 15px;
 
  background-color: #fafafa;
 
  box-shadow: inset 0 3px 6px rgba(0,0,0,.05);
 
  border-color: #e5e5e5 #eee #eee;
 
  border-style: solid;
 
  border-width: 1px 0;
 
}
 
/* Echo out a label for the example */
 
.bs-example:after {
 
  content: "Example";
 
  position: absolute;
 
  top:  15px;
 
  left: 15px;
 
  font-size: 12px;
 
  font-weight: bold;
 
  color: #bbb;
 
  text-transform: uppercase;
 
  letter-spacing: 1px;
 
}
 

	
 
/* Tweak display of the code snippets when following an example */
 
.bs-example + .highlight {
 
  margin: -15px -15px 15px;
 
  border-radius: 0;
 
  border-width: 0 0 1px;
 
}
 

	
 
/* Make the examples and snippets not full-width */
 
@media screen and (min-width: 768px) {
 
  .bs-example {
 
    margin-left: 0;
 
    margin-right: 0;
 
    background-color: #fff;
 
    border-width: 1px;
 
    border-color: #ddd;
 
    border-radius: 4px 4px 0 0;
 
    box-shadow: none;
 
  }
 
  .bs-example + .highlight {
 
    margin-top: -16px;
 
    margin-left: 0;
 
    margin-right: 0;
 
    border-width: 1px;
 
    border-bottom-left-radius: 4px;
 
    border-bottom-right-radius: 4px;
 
  }
 
}
 

	
 
/* Tweak content of examples for optimum awesome */
 
.bs-example > p:last-child,
 
.bs-example > ul:last-child,
 
.bs-example > ol:last-child,
 
.bs-example > blockquote:last-child,
 
.bs-example > .form-control:last-child,
 
.bs-example > .table:last-child,
 
.bs-example > .navbar:last-child,
 
.bs-example > .jumbotron:last-child,
 
.bs-example > .alert:last-child,
 
.bs-example > .panel:last-child,
 
.bs-example > .list-group:last-child,
 
.bs-example > .well:last-child,
 
.bs-example > .progress:last-child,
 
.bs-example > .table-responsive:last-child > .table {
 
  margin-bottom: 0;
 
}
 
.bs-example > p > .close {
 
  float: none;
 
}
 

	
 
/* Typography */
 
.bs-example-type .table td:last-child {
 
  color: #999;
 
  vertical-align: middle;
 
}
 
.bs-example-type .table td {
 
  padding: 15px 0;
 
  border-color: #eee;
 
}
 
.bs-example-type .table tr:first-child td {
 
  border-top: 0;
 
}
 
.bs-example-type h1,
 
.bs-example-type h2,
 
.bs-example-type h3,
 
.bs-example-type h4,
 
.bs-example-type h5,
 
.bs-example-type h6 {
 
  margin: 0;
 
}
 

	
 
/* Images */
 
.bs-example > .img-circle,
 
.bs-example > .img-rounded,
 
.bs-example > .img-thumbnail {
 
  margin: 5px;
 
}
 

	
 
/* Buttons */
 
.bs-example > .btn,
 
.bs-example > .btn-group {
 
  margin-top: 5px;
 
  margin-bottom: 5px;
 
}
 
.bs-example > .btn-toolbar + .btn-toolbar {
 
  margin-top: 10px;
 
}
 

	
 
/* Forms */
 
.bs-example-control-sizing select,
 
.bs-example-control-sizing input[type="text"] + input[type="text"] {
 
  margin-top: 10px;
 
}
 
.bs-example-form .input-group {
 
  margin-bottom: 10px;
 
}
 
.bs-example > textarea.form-control {
 
  resize: vertical;
 
}
 

	
 
/* List groups */
 
.bs-example > .list-group {
 
  max-width: 400px;
 
}
 

	
 
/* Navbars */
 
.bs-example .navbar:last-child {
 
  margin-bottom: 0;
 
}
 
.bs-navbar-top-example,
 
.bs-navbar-bottom-example {
 
  z-index: 1;
 
  padding: 0;
 
  overflow: hidden; /* cut the drop shadows off */
 
}
 
.bs-navbar-top-example .navbar-header,
 
.bs-navbar-bottom-example .navbar-header {
 
  margin-left: 0;
 
}
 
.bs-navbar-top-example .navbar-fixed-top,
 
.bs-navbar-bottom-example .navbar-fixed-bottom {
 
  position: relative;
 
  margin-left: 0;
 
  margin-right: 0;
 
}
 
.bs-navbar-top-example {
 
  padding-bottom: 45px;
 
}
 
.bs-navbar-top-example:after {
 
  top: auto;
 
  bottom: 15px;
 
}
 
.bs-navbar-top-example .navbar-fixed-top {
 
  top: -1px;
 
}
 
.bs-navbar-bottom-example {
 
  padding-top: 45px;
 
}
 
.bs-navbar-bottom-example .navbar-fixed-bottom {
 
  bottom: -1px;
 
}
 
.bs-navbar-bottom-example .navbar {
 
  margin-bottom: 0;
 
}
 
@media (min-width: 768px) {
 
  .bs-navbar-top-example .navbar-fixed-top,
 
  .bs-navbar-bottom-example .navbar-fixed-bottom {
 
    position: absolute;
 
  }
 
  .bs-navbar-top-example {
 
    border-radius: 0 0 4px 4px;
 
  }
 
  .bs-navbar-bottom-example {
 
    border-radius: 4px 4px 0 0;
 
  }
 
}
 

	
 
/* Pagination */
 
.bs-example .pagination {
 
  margin-top: 10px;
 
  margin-bottom: 10px;
 
}
 

	
 
/* Pager */
 
.bs-example > .pager {
 
  margin-top: 0;
 
}
 

	
 
/* Example modals */
 
.bs-example-modal {
 
  background-color: #f5f5f5;
 
}
 
.bs-example-modal .modal {
 
  position: relative;
 
  top: auto;
 
  right: auto;
 
  left: auto;
 
  bottom: auto;
 
  z-index: 1;
 
  display: block;
 
}
 
.bs-example-modal .modal-dialog {
 
  left: auto;
 
  margin-left: auto;
 
  margin-right: auto;
 
}
 

	
 
/* Example dropdowns */
 
.bs-example > .dropdown > .dropdown-menu {
 
  position: static;
 
  display: block;
 
  margin-bottom: 5px;
 
}
 

	
 
/* Example tabbable tabs */
 
.bs-example-tabs .nav-tabs {
 
  margin-bottom: 15px;
 
}
 

	
 
/* Tooltips */
 
.bs-example-tooltips {
 
  text-align: center;
 
}
 
.bs-example-tooltips > .btn {
 
  margin-top: 5px;
 
  margin-bottom: 5px;
 
}
 

	
 
/* Popovers */
 
.bs-example-popover {
 
  padding-bottom: 24px;
 
  background-color: #f9f9f9;
 
}
 
.bs-example-popover .popover {
 
  position: relative;
 
  display: block;
 
  float: left;
 
  width: 260px;
 
  margin: 20px;
 
}
 

	
 
/* Scrollspy demo on fixed height div */
 
.scrollspy-example {
 
  position: relative;
 
  height: 200px;
 
  margin-top: 10px;
 
  overflow: auto;
 
}
 

	
 

	
 
/*
 
 * Code snippets
 
 *
 
 * Generated via Pygments and Jekyll, these are snippets of HTML, CSS, and JS.
 
 */
 

	
 
.highlight {
 
  display: none; /* hidden by default, until >480px */
 
  padding: 9px 14px;
 
  margin-bottom: 14px;
 
  background-color: #f7f7f9;
 
  border: 1px solid #e1e1e8;
 
  border-radius: 4px;
 
}
 
.highlight pre {
 
  padding: 0;
 
  margin-top: 0;
 
  margin-bottom: 0;
 
  background-color: transparent;
 
  border: 0;
 
  white-space: nowrap;
 
}
 
.highlight pre code {
 
  font-size: inherit;
 
  color: #333; /* Effectively the base text color */
 
}
 
.highlight pre .lineno {
 
  display: inline-block;
 
  width: 22px;
 
  padding-right: 5px;
 
  margin-right: 10px;
 
  text-align: right;
 
  color: #bebec5;
 
}
 

	
 
/* Show code snippets when we have the space */
 
@media screen and (min-width: 481px) {
 
  .highlight {
 
    display: block;
 
  }
 
}
 

	
 

	
 
/*
 
 * Responsive tests
 
 *
 
 * Generate a set of tests to show the responsive utilities in action.
 
 */
 

	
 
/* Responsive (scrollable) doc tables */
 
.table-responsive .highlight pre {
 
  white-space: normal;
 
}
 

	
 
/* Utility classes table  */
 
.bs-table th small,
 
.responsive-utilities th small {
 
  display: block;
 
  font-weight: normal;
 
  color: #999;
 
}
 
.responsive-utilities tbody th {
 
  font-weight: normal;
 
}
 
.responsive-utilities td {
 
  text-align: center;
 
}
 
.responsive-utilities td.is-visible {
 
  color: #468847;
 
  background-color: #dff0d8 !important;
 
}
 
.responsive-utilities td.is-hidden {
 
  color: #ccc;
 
  background-color: #f9f9f9 !important;
 
}
 

	
 
/* Responsive tests */
 
.responsive-utilities-test {
 
  margin-top: 5px;
 
}
 
.responsive-utilities-test .col-xs-6 {
 
  margin-bottom: 10px;
 
}
 
.responsive-utilities-test span {
 
  padding: 15px 10px;
 
  font-size: 14px;
 
  font-weight: bold;
 
  line-height: 1.1;
 
  text-align: center;
 
  border-radius: 4px;
 
}
 
.visible-on .col-xs-6 .hidden-xs,
 
.visible-on .col-xs-6 .hidden-sm,
 
.visible-on .col-xs-6 .hidden-md,
 
.visible-on .col-xs-6 .hidden-lg,
 
.hidden-on .col-xs-6 .visible-xs,
 
.hidden-on .col-xs-6 .visible-sm,
 
.hidden-on .col-xs-6 .visible-md,
 
.hidden-on .col-xs-6 .visible-lg {
 
  color: #999;
 
  border: 1px solid #ddd;
 
}
 
.visible-on .col-xs-6 .visible-xs,
 
.visible-on .col-xs-6 .visible-sm,
 
.visible-on .col-xs-6 .visible-md,
 
.visible-on .col-xs-6 .visible-lg,
 
.hidden-on .col-xs-6 .hidden-xs,
 
.hidden-on .col-xs-6 .hidden-sm,
 
.hidden-on .col-xs-6 .hidden-md,
 
.hidden-on .col-xs-6 .hidden-lg {
 
  color: #468847;
 
  background-color: #dff0d8;
 
  border: 1px solid #d6e9c6;
 
}
 

	
 

	
 
/*
 
 * Glyphicons
 
 *
 
 * Special styles for displaying the icons and their classes in the docs.
 
 */
 

	
 
.bs-glyphicons {
 
  padding-left: 0;
 
  padding-bottom: 1px;
 
  margin-bottom: 20px;
 
  list-style: none;
 
  overflow: hidden;
 
}
 
.bs-glyphicons li {
 
  float: left;
 
  width: 25%;
 
  height: 115px;
 
  padding: 10px;
 
  margin: 0 -1px -1px 0;
 
  font-size: 12px;
 
  line-height: 1.4;
 
  text-align: center;
 
  border: 1px solid #ddd;
 
}
 
.bs-glyphicons .glyphicon {
 
  display: block;
 
  margin: 5px auto 10px;
 
  font-size: 24px;
 
}
 
.bs-glyphicons li:hover {
 
  background-color: rgba(86,61,124,.1);
 
}
 

	
 
@media (min-width: 768px) {
 
  .bs-glyphicons li {
 
    width: 12.5%;
 
  }
 
}
 

	
 

	
 
/*
 
 * Customizer
 
 *
 
 * Since this is so form control heavy, we have quite a few styles to customize
 
 * the display of inputs, headings, and more. Also included are all the download
 
 * buttons and actions.
 
 */
 

	
 
.bs-customizer .toggle {
 
  float: right;
 
  margin-top: 85px; /* On account of ghetto navbar fix */
 
}
 

	
 
/* Headings and form contrls */
 
.bs-customizer label {
 
  margin-top: 10px;
 
  font-weight: 500;
 
  color: #444;
 
}
 
.bs-customizer h2 {
 
  margin-top: 0;
 
  margin-bottom: 5px;
 
  padding-top: 30px;
 
}
 
.bs-customizer h4 {
 
  margin-top: 15px;
 
}
 
.bs-customizer input[type="text"] {
 
  font-family: Menlo, Monaco, Consolas, "Courier New", monospace;
 
  background-color: #fafafa;
 
}
 
.bs-customizer .help-block {
 
  font-size: 12px;
 
}
 

	
 
/* For the variables, use regular weight */
 
#less-section label {
 
  font-weight: normal;
 
}
 

	
 
/* Downloads */
 
.bs-customize-download .btn-outline {
 
  padding: 20px;
 
}
 

	
 
/* Error handling */
 
.bs-customizer-alert {
 
  position: fixed;
 
  top: 51px;
 
  left: 0;
 
  right: 0;
 
  z-index: 1030;
 
  padding: 15px 0;
 
  color: #fff;
 
  background-color: #d9534f;
 
  box-shadow: inset 0 1px 0 rgba(255,255,255,.25);
 
  border-bottom: 1px solid #b94441;
 
}
 
.bs-customizer-alert .close {
 
  margin-top: -4px;
 
  font-size: 24px;
 
}
 
.bs-customizer-alert p {
 
  margin-bottom: 0;
 
}
 
.bs-customizer-alert .glyphicon {
 
  margin-right: 5px;
 
}
 
.bs-customizer-alert pre {
 
  margin: 10px 0 0;
 
  color: #fff;
 
  background-color: #a83c3a;
 
  border-color: #973634;
 
  box-shadow: inset 0 2px 4px rgba(0,0,0,.05), 0 1px 0 rgba(255,255,255,.1);
 
}
 

	
 

	
 
/*
 
 * Miscellaneous
 
 *
 
 * Odds and ends for optimum docs display.
 
 */
 

	
 
/* Examples gallery: space out content better */
 
.bs-examples h4 {
 
  margin-bottom: 5px;
 
}
 
.bs-examples p {
 
  margin-bottom: 20px;
 
}
 

	
 
/* Pseudo :focus state for showing how it looks in the docs */
 
#focusedInput {
 
  border-color: rgba(82,168,236,.8);
 
  outline: 0;
 
  outline: thin dotted \9; /* IE6-9 */
 
  -moz-box-shadow: 0 0 8px rgba(82,168,236,.6);
 
       box-shadow: 0 0 8px rgba(82,168,236,.6);
 
}
 

	
 
/* Better spacing on download options in getting started */
 
.bs-docs-dl-options h4 {
 
  margin-top: 15px;
 
  margin-bottom: 5px;
 
}
bootstrap-3.0.0/assets/css/pygments-manni.css
Show inline comments
 
new file 100644
 
.hll { background-color: #ffffcc }
 
 /*{ background: #f0f3f3; }*/
 
.c { color: #999; } /* Comment */
 
.err { color: #AA0000; background-color: #FFAAAA } /* Error */
 
.k { color: #006699; } /* Keyword */
 
.o { color: #555555 } /* Operator */
 
.cm { color: #0099FF; font-style: italic } /* Comment.Multiline */
 
.cp { color: #009999 } /* Comment.Preproc */
 
.c1 { color: #999; } /* Comment.Single */
 
.cs { color: #999; } /* Comment.Special */
 
.gd { background-color: #FFCCCC; border: 1px solid #CC0000 } /* Generic.Deleted */
 
.ge { font-style: italic } /* Generic.Emph */
 
.gr { color: #FF0000 } /* Generic.Error */
 
.gh { color: #003300; } /* Generic.Heading */
 
.gi { background-color: #CCFFCC; border: 1px solid #00CC00 } /* Generic.Inserted */
 
.go { color: #AAAAAA } /* Generic.Output */
 
.gp { color: #000099; } /* Generic.Prompt */
 
.gs { } /* Generic.Strong */
 
.gu { color: #003300; } /* Generic.Subheading */
 
.gt { color: #99CC66 } /* Generic.Traceback */
 
.kc { color: #006699; } /* Keyword.Constant */
 
.kd { color: #006699; } /* Keyword.Declaration */
 
.kn { color: #006699; } /* Keyword.Namespace */
 
.kp { color: #006699 } /* Keyword.Pseudo */
 
.kr { color: #006699; } /* Keyword.Reserved */
 
.kt { color: #007788; } /* Keyword.Type */
 
.m { color: #FF6600 } /* Literal.Number */
 
.s { color: #d44950 } /* Literal.String */
 
.na { color: #4f9fcf } /* Name.Attribute */
 
.nb { color: #336666 } /* Name.Builtin */
 
.nc { color: #00AA88; } /* Name.Class */
 
.no { color: #336600 } /* Name.Constant */
 
.nd { color: #9999FF } /* Name.Decorator */
 
.ni { color: #999999; } /* Name.Entity */
 
.ne { color: #CC0000; } /* Name.Exception */
 
.nf { color: #CC00FF } /* Name.Function */
 
.nl { color: #9999FF } /* Name.Label */
 
.nn { color: #00CCFF; } /* Name.Namespace */
 
.nt { color: #2f6f9f; } /* Name.Tag */
 
.nv { color: #003333 } /* Name.Variable */
 
.ow { color: #000000; } /* Operator.Word */
 
.w { color: #bbbbbb } /* Text.Whitespace */
 
.mf { color: #FF6600 } /* Literal.Number.Float */
 
.mh { color: #FF6600 } /* Literal.Number.Hex */
 
.mi { color: #FF6600 } /* Literal.Number.Integer */
 
.mo { color: #FF6600 } /* Literal.Number.Oct */
 
.sb { color: #CC3300 } /* Literal.String.Backtick */
 
.sc { color: #CC3300 } /* Literal.String.Char */
 
.sd { color: #CC3300; font-style: italic } /* Literal.String.Doc */
 
.s2 { color: #CC3300 } /* Literal.String.Double */
 
.se { color: #CC3300; } /* Literal.String.Escape */
 
.sh { color: #CC3300 } /* Literal.String.Heredoc */
 
.si { color: #AA0000 } /* Literal.String.Interpol */
 
.sx { color: #CC3300 } /* Literal.String.Other */
 
.sr { color: #33AAAA } /* Literal.String.Regex */
 
.s1 { color: #CC3300 } /* Literal.String.Single */
 
.ss { color: #FFCC33 } /* Literal.String.Symbol */
 
.bp { color: #336666 } /* Name.Builtin.Pseudo */
 
.vc { color: #003333 } /* Name.Variable.Class */
 
.vg { color: #003333 } /* Name.Variable.Global */
 
.vi { color: #003333 } /* Name.Variable.Instance */
 
.il { color: #FF6600 } /* Literal.Number.Integer.Long */
 

	
 
.css .o,
 
.css .o + .nt,
 
.css .nt + .nt { color: #999; }
bootstrap-3.0.0/assets/ico/apple-touch-icon-114-precomposed.png
Show inline comments
 
new file 100644
 
binary diff not shown
Show images
bootstrap-3.0.0/assets/ico/apple-touch-icon-144-precomposed.png
Show inline comments
 
new file 100644
 
binary diff not shown
Show images
bootstrap-3.0.0/assets/ico/apple-touch-icon-57-precomposed.png
Show inline comments
 
new file 100644
 
binary diff not shown
Show images
bootstrap-3.0.0/assets/ico/apple-touch-icon-72-precomposed.png
Show inline comments
 
new file 100644
 
binary diff not shown
Show images
bootstrap-3.0.0/assets/ico/favicon.png
Show inline comments
 
new file 100644
 
binary diff not shown
Show images
bootstrap-3.0.0/assets/js/application.js
Show inline comments
 
new file 100644
 
// NOTICE!! DO NOT USE ANY OF THIS JAVASCRIPT
 
// IT'S ALL JUST JUNK FOR OUR DOCS!
 
// ++++++++++++++++++++++++++++++++++++++++++
 

	
 
!function ($) {
 

	
 
  $(function(){
 

	
 
    var $window = $(window)
 
    var $body   = $(document.body)
 

	
 
    var navHeight = $('.navbar').outerHeight(true) + 10
 

	
 
    $body.scrollspy({
 
      target: '.bs-sidebar',
 
      offset: navHeight
 
    })
 

	
 
    $window.on('load', function () {
 
      $body.scrollspy('refresh')
 
    })
 

	
 
    $('.bs-docs-container [href=#]').click(function (e) {
 
      e.preventDefault()
 
    })
 

	
 
    // back to top
 
    setTimeout(function () {
 
      var $sideBar = $('.bs-sidebar')
 

	
 
      $sideBar.affix({
 
        offset: {
 
          top: function () {
 
            var offsetTop      = $sideBar.offset().top
 
            var sideBarMargin  = parseInt($sideBar.children(0).css('margin-top'), 10)
 
            var navOuterHeight = $('.bs-docs-nav').height()
 

	
 
            return (this.top = offsetTop - navOuterHeight - sideBarMargin)
 
          }
 
        , bottom: function () {
 
            return (this.bottom = $('.bs-footer').outerHeight(true))
 
          }
 
        }
 
      })
 
    }, 100)
 

	
 
    setTimeout(function () {
 
      $('.bs-top').affix()
 
    }, 100)
 

	
 
    // tooltip demo
 
    $('.tooltip-demo').tooltip({
 
      selector: "[data-toggle=tooltip]",
 
      container: "body"
 
    })
 

	
 
    $('.tooltip-test').tooltip()
 
    $('.popover-test').popover()
 

	
 
    $('.bs-docs-navbar').tooltip({
 
      selector: "a[data-toggle=tooltip]",
 
      container: ".bs-docs-navbar .nav"
 
    })
 

	
 
    // popover demo
 
    $("[data-toggle=popover]")
 
      .popover()
 

	
 
    // button state demo
 
    $('#fat-btn')
 
      .click(function () {
 
        var btn = $(this)
 
        btn.button('loading')
 
        setTimeout(function () {
 
          btn.button('reset')
 
        }, 3000)
 
      })
 

	
 
    // carousel demo
 
    $('.bs-docs-carousel-example').carousel()
 
})
 

	
 
}(window.jQuery)
bootstrap-3.0.0/assets/js/customizer.js
Show inline comments
 
new file 100644
 
window.onload = function () { // wait for load in a dumb way because B-0
 
  var cw = '/*!\n * Bootstrap v3.0.0\n *\n * Copyright 2013 Twitter, Inc\n * Licensed under the Apache License v2.0\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Designed and built with all the love in the world @twitter by @mdo and @fat.\n */\n\n'
 

	
 
  function showError(msg, err) {
 
    $('<div id="bsCustomizerAlert" class="bs-customizer-alert">\
 
        <div class="container">\
 
          <a href="#bsCustomizerAlert" data-dismiss="alert" class="close pull-right">&times;</a>\
 
          <p class="bs-customizer-alert-text"><span class="glyphicon glyphicon-warning-sign"></span>' + msg + '</p>' +
 
          (err.extract ? '<pre class="bs-customizer-alert-extract">' + err.extract.join('\n') + '</pre>' : '') + '\
 
        </div>\
 
      </div>').appendTo('body').alert()
 
    throw err
 
  }
 

	
 
  function showCallout(msg, showUpTop) {
 
    var callout = $('<div class="bs-callout bs-callout-danger">\
 
       <h4>Attention!</h4>\
 
      <p>' + msg + '</p>\
 
    </div>')
 

	
 
    if (showUpTop) {
 
      callout.appendTo('.bs-docs-container')
 
    } else {
 
      callout.insertAfter('.bs-customize-download')
 
    }
 
  }
 

	
 
  function getQueryParam(key) {
 
    key = key.replace(/[*+?^$.\[\]{}()|\\\/]/g, "\\$&"); // escape RegEx meta chars
 
    var match = location.search.match(new RegExp("[?&]"+key+"=([^&]+)(&|$)"));
 
    return match && decodeURIComponent(match[1].replace(/\+/g, " "));
 
  }
 

	
 
  function createGist(configData) {
 
    var data = {
 
      "description": "Bootstrap Customizer Config",
 
      "public": true,
 
      "files": {
 
        "config.json": {
 
          "content": JSON.stringify(configData, null, 2)
 
        }
 
      }
 
    }
 
    $.ajax({
 
      url: 'https://api.github.com/gists',
 
      type: 'POST',
 
      dataType: 'json',
 
      data: JSON.stringify(data)
 
    })
 
    .success(function(result) {
 
      history.replaceState(false, document.title, window.location.origin + window.location.pathname + '?id=' + result.id)
 
    })
 
    .error(function(err) {
 
      showError('<strong>Ruh roh!</strong> Could not save gist file, configuration not saved.', err)
 
    })
 
  }
 

	
 
  function getCustomizerData() {
 
    var vars = {}
 

	
 
    $('#less-variables-section input')
 
        .each(function () {
 
          $(this).val() && (vars[ $(this).prev().text() ] = $(this).val())
 
        })
 

	
 
    var data = {
 
      vars: vars,
 
      css: $('#less-section input:checked')  .map(function () { return this.value }).toArray(),
 
      js:  $('#plugin-section input:checked').map(function () { return this.value }).toArray()
 
    }
 

	
 
    if ($.isEmptyObject(data.vars) && !data.css.length && !data.js.length) return
 

	
 
    return data
 
  }
 

	
 
  function parseUrl() {
 
    var id = getQueryParam('id')
 

	
 
    if (!id) return
 

	
 
    $.ajax({
 
      url: 'https://api.github.com/gists/' + id,
 
      type: 'GET',
 
      dataType: 'json'
 
    })
 
    .success(function(result) {
 
      var data = JSON.parse(result.files['config.json'].content)
 
      if (data.js) {
 
        $('#plugin-section input').each(function () {
 
          $(this).prop('checked', ~$.inArray(this.value, data.js))
 
        })
 
      }
 
      if (data.css) {
 
        $('#less-section input').each(function () {
 
          $(this).prop('checked', ~$.inArray(this.value, data.css))
 
        })
 
      }
 
      if (data.vars) {
 
        for (var i in data.vars) {
 
          $('input[data-var="' + i + '"]').val(data.vars[i])
 
        }
 
      }
 
    })
 
    .error(function(err) {
 
      showError('Error fetching bootstrap config file', err)
 
    })
 
  }
 

	
 
  function generateZip(css, js, fonts, complete) {
 
    if (!css && !js) return showError('<strong>Ruh roh!</strong> No Bootstrap files selected.', new Error('no Bootstrap'))
 

	
 
    var zip = new JSZip()
 

	
 
    if (css) {
 
      var cssFolder = zip.folder('css')
 
      for (var fileName in css) {
 
        cssFolder.file(fileName, css[fileName])
 
      }
 
    }
 

	
 
    if (js) {
 
      var jsFolder = zip.folder('js')
 
      for (var fileName in js) {
 
        jsFolder.file(fileName, js[fileName])
 
      }
 
    }
 

	
 
    if (fonts) {
 
      var fontsFolder = zip.folder('fonts')
 
      for (var fileName in fonts) {
 
        fontsFolder.file(fileName, fonts[fileName])
 
      }
 
    }
 

	
 
    var content = zip.generate({type:"blob"})
 

	
 
    complete(content)
 
  }
 

	
 
  function generateCustomCSS(vars) {
 
    var result = ''
 

	
 
    for (var key in vars) {
 
      result += key + ': ' + vars[key] + ';\n'
 
    }
 

	
 
    return result + '\n\n'
 
  }
 

	
 
  function generateFonts() {
 
    var glyphicons = $('#less-section [value="glyphicons.less"]:checked')
 
    if (glyphicons.length) {
 
      return __fonts
 
    }
 
  }
 

	
 
  function generateCSS() {
 
    var $checked = $('#less-section input:checked')
 

	
 
    if (!$checked.length) return false
 

	
 
    var result = {}
 
    var vars = {}
 
    var css = ''
 

	
 
    $('#less-variables-section input')
 
        .each(function () {
 
          $(this).val() && (vars[ $(this).prev().text() ] = $(this).val())
 
        })
 

	
 
    css += __less['variables.less']
 
    if (vars) css += generateCustomCSS(vars)
 
    css += __less['mixins.less']
 
    css += __less['normalize.less']
 
    css += __less['scaffolding.less']
 
    css += $checked
 
      .map(function () { return __less[this.value] })
 
      .toArray()
 
      .join('\n')
 

	
 
    css = css.replace(/@import[^\n]*/gi, '') //strip any imports
 

	
 
    try {
 
      var parser = new less.Parser({
 
          paths: ['variables.less', 'mixins.less']
 
        , optimization: 0
 
        , filename: 'bootstrap.css'
 
      }).parse(css, function (err, tree) {
 
        if (err) {
 
          return showError('<strong>Ruh roh!</strong> Could not parse less files.', err)
 
        }
 
        result = {
 
          'bootstrap.css'     : cw + tree.toCSS(),
 
          'bootstrap.min.css' : cw + tree.toCSS({ compress: true })
 
        }
 
      })
 
    } catch (err) {
 
      return showError('<strong>Ruh roh!</strong> Could not parse less files.', err)
 
    }
 

	
 
    return result
 
  }
 

	
 
  function generateJavascript() {
 
    var $checked = $('#plugin-section input:checked')
 
    if (!$checked.length) return false
 

	
 
    var js = $checked
 
      .map(function () { return __js[this.value] })
 
      .toArray()
 
      .join('\n')
 

	
 
    return {
 
      'bootstrap.js': js,
 
      'bootstrap.min.js': cw + uglify(js)
 
    }
 
  }
 

	
 
  var inputsComponent = $('#less-section input')
 
  var inputsPlugin    = $('#plugin-section input')
 
  var inputsVariables = $('#less-variables-section input')
 

	
 
  $('#less-section .toggle').on('click', function (e) {
 
    e.preventDefault()
 
    inputsComponent.prop('checked', !inputsComponent.is(':checked'))
 
  })
 

	
 
  $('#plugin-section .toggle').on('click', function (e) {
 
    e.preventDefault()
 
    inputsPlugin.prop('checked', !inputsPlugin.is(':checked'))
 
  })
 

	
 
  $('#less-variables-section .toggle').on('click', function (e) {
 
    e.preventDefault()
 
    inputsVariables.val('')
 
  })
 

	
 
  $('[data-dependencies]').on('click', function () {
 
    if (!$(this).is(':checked')) return
 
    var dependencies = this.getAttribute('data-dependencies')
 
    if (!dependencies) return
 
    dependencies = dependencies.split(',')
 
    for (var i = 0; i < dependencies.length; i++) {
 
      var dependency = $('[value="' + dependencies[i] + '"]')
 
      dependency && dependency.prop('checked', true)
 
    }
 
  })
 

	
 
  $('[data-dependents]').on('click', function () {
 
    if ($(this).is(':checked')) return
 
    var dependents = this.getAttribute('data-dependents')
 
    if (!dependents) return
 
    dependents = dependents.split(',')
 
    for (var i = 0; i < dependents.length; i++) {
 
      var dependent = $('[value="' + dependents[i] + '"]')
 
      dependent && dependent.prop('checked', false)
 
    }
 
  })
 

	
 
  var $compileBtn = $('#btn-compile')
 
  var $downloadBtn = $('#btn-download')
 

	
 
  $compileBtn.on('click', function (e) {
 
    e.preventDefault()
 

	
 
    $compileBtn.attr('disabled', 'disabled')
 

	
 
    generateZip(generateCSS(), generateJavascript(), generateFonts(), function (blob) {
 
      $compileBtn.removeAttr('disabled')
 
      saveAs(blob, "bootstrap.zip")
 
      createGist(getCustomizerData())
 
    })
 
  })
 

	
 
  // browser support alerts
 
  if (!window.URL && navigator.userAgent.toLowerCase().indexOf('safari') != -1) {
 
    showCallout("Looks like you're using safari, which sadly doesn't have the best support\
 
                 for HTML5 blobs. Because of this your file will be downloaded with the name <code>\"untitled\"</code>.\
 
                 However, if you check your downloads folder, just rename this <code>\"untitled\"</code> file\
 
                 to <code>\"bootstrap.zip\"</code> and you should be good to go!")
 
  } else if (!window.URL && !window.webkitURL) {
 
    $('.bs-docs-section, .bs-sidebar').css('display', 'none')
 

	
 
    showCallout("Looks like your current browser doesn't support the Bootstrap Customizer. Please take a second\
 
                to <a href=\"https://www.google.com/intl/en/chrome/browser/\"> upgrade to a more modern browser</a>.", true)
 
  }
 

	
 
  parseUrl()
 
}
bootstrap-3.0.0/assets/js/filesaver.js
Show inline comments
 
new file 100644
 
/* Blob.js
 
 * A Blob implementation.
 
 * 2013-06-20
 
 *
 
 * By Eli Grey, http://eligrey.com
 
 * By Devin Samarin, https://github.com/eboyjr
 
 * License: X11/MIT
 
 *   See LICENSE.md
 
 */
 

	
 
/*global self, unescape */
 
/*jslint bitwise: true, regexp: true, confusion: true, es5: true, vars: true, white: true,
 
  plusplus: true */
 

	
 
/*! @source http://purl.eligrey.com/github/Blob.js/blob/master/Blob.js */
 

	
 
if (typeof Blob !== "function" || typeof URL === "undefined")
 
if (typeof Blob === "function" && typeof webkitURL !== "undefined") self.URL = webkitURL;
 
else var Blob = (function (view) {
 
  "use strict";
 

	
 
  var BlobBuilder = view.BlobBuilder || view.WebKitBlobBuilder || view.MozBlobBuilder || view.MSBlobBuilder || (function(view) {
 
    var
 
        get_class = function(object) {
 
        return Object.prototype.toString.call(object).match(/^\[object\s(.*)\]$/)[1];
 
      }
 
      , FakeBlobBuilder = function BlobBuilder() {
 
        this.data = [];
 
      }
 
      , FakeBlob = function Blob(data, type, encoding) {
 
        this.data = data;
 
        this.size = data.length;
 
        this.type = type;
 
        this.encoding = encoding;
 
      }
 
      , FBB_proto = FakeBlobBuilder.prototype
 
      , FB_proto = FakeBlob.prototype
 
      , FileReaderSync = view.FileReaderSync
 
      , FileException = function(type) {
 
        this.code = this[this.name = type];
 
      }
 
      , file_ex_codes = (
 
          "NOT_FOUND_ERR SECURITY_ERR ABORT_ERR NOT_READABLE_ERR ENCODING_ERR "
 
        + "NO_MODIFICATION_ALLOWED_ERR INVALID_STATE_ERR SYNTAX_ERR"
 
      ).split(" ")
 
      , file_ex_code = file_ex_codes.length
 
      , real_URL = view.URL || view.webkitURL || view
 
      , real_create_object_URL = real_URL.createObjectURL
 
      , real_revoke_object_URL = real_URL.revokeObjectURL
 
      , URL = real_URL
 
      , btoa = view.btoa
 
      , atob = view.atob
 

	
 
      , ArrayBuffer = view.ArrayBuffer
 
      , Uint8Array = view.Uint8Array
 
    ;
 
    FakeBlob.fake = FB_proto.fake = true;
 
    while (file_ex_code--) {
 
      FileException.prototype[file_ex_codes[file_ex_code]] = file_ex_code + 1;
 
    }
 
    if (!real_URL.createObjectURL) {
 
      URL = view.URL = {};
 
    }
 
    URL.createObjectURL = function(blob) {
 
      var
 
          type = blob.type
 
        , data_URI_header
 
      ;
 
      if (type === null) {
 
        type = "application/octet-stream";
 
      }
 
      if (blob instanceof FakeBlob) {
 
        data_URI_header = "data:" + type;
 
        if (blob.encoding === "base64") {
 
          return data_URI_header + ";base64," + blob.data;
 
        } else if (blob.encoding === "URI") {
 
          return data_URI_header + "," + decodeURIComponent(blob.data);
 
        } if (btoa) {
 
          return data_URI_header + ";base64," + btoa(blob.data);
 
        } else {
 
          return data_URI_header + "," + encodeURIComponent(blob.data);
 
        }
 
      } else if (real_create_object_URL) {
 
        return real_create_object_URL.call(real_URL, blob);
 
      }
 
    };
 
    URL.revokeObjectURL = function(object_URL) {
 
      if (object_URL.substring(0, 5) !== "data:" && real_revoke_object_URL) {
 
        real_revoke_object_URL.call(real_URL, object_URL);
 
      }
 
    };
 
    FBB_proto.append = function(data/*, endings*/) {
 
      var bb = this.data;
 
      // decode data to a binary string
 
      if (Uint8Array && (data instanceof ArrayBuffer || data instanceof Uint8Array)) {
 
        var
 
            str = ""
 
          , buf = new Uint8Array(data)
 
          , i = 0
 
          , buf_len = buf.length
 
        ;
 
        for (; i < buf_len; i++) {
 
          str += String.fromCharCode(buf[i]);
 
        }
 
        bb.push(str);
 
      } else if (get_class(data) === "Blob" || get_class(data) === "File") {
 
        if (FileReaderSync) {
 
          var fr = new FileReaderSync;
 
          bb.push(fr.readAsBinaryString(data));
 
        } else {
 
          // async FileReader won't work as BlobBuilder is sync
 
          throw new FileException("NOT_READABLE_ERR");
 
        }
 
      } else if (data instanceof FakeBlob) {
 
        if (data.encoding === "base64" && atob) {
 
          bb.push(atob(data.data));
 
        } else if (data.encoding === "URI") {
 
          bb.push(decodeURIComponent(data.data));
 
        } else if (data.encoding === "raw") {
 
          bb.push(data.data);
 
        }
 
      } else {
 
        if (typeof data !== "string") {
 
          data += ""; // convert unsupported types to strings
 
        }
 
        // decode UTF-16 to binary string
 
        bb.push(unescape(encodeURIComponent(data)));
 
      }
 
    };
 
    FBB_proto.getBlob = function(type) {
 
      if (!arguments.length) {
 
        type = null;
 
      }
 
      return new FakeBlob(this.data.join(""), type, "raw");
 
    };
 
    FBB_proto.toString = function() {
 
      return "[object BlobBuilder]";
 
    };
 
    FB_proto.slice = function(start, end, type) {
 
      var args = arguments.length;
 
      if (args < 3) {
 
        type = null;
 
      }
 
      return new FakeBlob(
 
          this.data.slice(start, args > 1 ? end : this.data.length)
 
        , type
 
        , this.encoding
 
      );
 
    };
 
    FB_proto.toString = function() {
 
      return "[object Blob]";
 
    };
 
    return FakeBlobBuilder;
 
  }(view));
 

	
 
  return function Blob(blobParts, options) {
 
    var type = options ? (options.type || "") : "";
 
    var builder = new BlobBuilder();
 
    if (blobParts) {
 
      for (var i = 0, len = blobParts.length; i < len; i++) {
 
        builder.append(blobParts[i]);
 
      }
 
    }
 
    return builder.getBlob(type);
 
  };
 
}(self));
 

	
 
/*! @source http://purl.eligrey.com/github/FileSaver.js/blob/master/FileSaver.js */
 
var saveAs=saveAs||(navigator.msSaveOrOpenBlob&&navigator.msSaveOrOpenBlob.bind(navigator))||(function(h){"use strict";var r=h.document,l=function(){return h.URL||h.webkitURL||h},e=h.URL||h.webkitURL||h,n=r.createElementNS("http://www.w3.org/1999/xhtml","a"),g=!h.externalHost&&"download" in n,j=function(t){var s=r.createEvent("MouseEvents");s.initMouseEvent("click",true,false,h,0,0,0,0,0,false,false,false,false,0,null);t.dispatchEvent(s)},o=h.webkitRequestFileSystem,p=h.requestFileSystem||o||h.mozRequestFileSystem,m=function(s){(h.setImmediate||h.setTimeout)(function(){throw s},0)},c="application/octet-stream",k=0,b=[],i=function(){var t=b.length;while(t--){var s=b[t];if(typeof s==="string"){e.revokeObjectURL(s)}else{s.remove()}}b.length=0},q=function(t,s,w){s=[].concat(s);var v=s.length;while(v--){var x=t["on"+s[v]];if(typeof x==="function"){try{x.call(t,w||t)}catch(u){m(u)}}}},f=function(t,u){var v=this,B=t.type,E=false,x,w,s=function(){var F=l().createObjectURL(t);b.push(F);return F},A=function(){q(v,"writestart progress write writeend".split(" "))},D=function(){if(E||!x){x=s(t)}if(w){w.location.href=x}else{window.open(x,"_blank")}v.readyState=v.DONE;A()},z=function(F){return function(){if(v.readyState!==v.DONE){return F.apply(this,arguments)}}},y={create:true,exclusive:false},C;v.readyState=v.INIT;if(!u){u="download"}if(g){x=s(t);n.href=x;n.download=u;j(n);v.readyState=v.DONE;A();return}if(h.chrome&&B&&B!==c){C=t.slice||t.webkitSlice;t=C.call(t,0,t.size,c);E=true}if(o&&u!=="download"){u+=".download"}if(B===c||o){w=h}if(!p){D();return}k+=t.size;p(h.TEMPORARY,k,z(function(F){F.root.getDirectory("saved",y,z(function(G){var H=function(){G.getFile(u,y,z(function(I){I.createWriter(z(function(J){J.onwriteend=function(K){w.location.href=I.toURL();b.push(I);v.readyState=v.DONE;q(v,"writeend",K)};J.onerror=function(){var K=J.error;if(K.code!==K.ABORT_ERR){D()}};"writestart progress write abort".split(" ").forEach(function(K){J["on"+K]=v["on"+K]});J.write(t);v.abort=function(){J.abort();v.readyState=v.DONE};v.readyState=v.WRITING}),D)}),D)};G.getFile(u,{create:false},z(function(I){I.remove();H()}),z(function(I){if(I.code===I.NOT_FOUND_ERR){H()}else{D()}}))}),D)}),D)},d=f.prototype,a=function(s,t){return new f(s,t)};d.abort=function(){var s=this;s.readyState=s.DONE;q(s,"abort")};d.readyState=d.INIT=0;d.WRITING=1;d.DONE=2;d.error=d.onwritestart=d.onprogress=d.onwrite=d.onabort=d.onerror=d.onwriteend=null;h.addEventListener("unload",i,false);return a}(self));
...
 
\ No newline at end of file
bootstrap-3.0.0/assets/js/holder.js
Show inline comments
 
new file 100755
 
/*
 

	
 
Holder - 2.0 - client side image placeholders
 
(c) 2012-2013 Ivan Malopinsky / http://imsky.co
 

	
 
Provided under the Apache 2.0 License: http://www.apache.org/licenses/LICENSE-2.0
 
Commercial use requires attribution.
 

	
 
*/
 

	
 
var Holder = Holder || {};
 
(function (app, win) {
 

	
 
var preempted = false,
 
fallback = false,
 
canvas = document.createElement('canvas');
 

	
 
//getElementsByClassName polyfill
 
document.getElementsByClassName||(document.getElementsByClassName=function(e){var t=document,n,r,i,s=[];if(t.querySelectorAll)return t.querySelectorAll("."+e);if(t.evaluate){r=".//*[contains(concat(' ', @class, ' '), ' "+e+" ')]",n=t.evaluate(r,t,null,0,null);while(i=n.iterateNext())s.push(i)}else{n=t.getElementsByTagName("*"),r=new RegExp("(^|\\s)"+e+"(\\s|$)");for(i=0;i<n.length;i++)r.test(n[i].className)&&s.push(n[i])}return s})
 

	
 
//getComputedStyle polyfill
 
window.getComputedStyle||(window.getComputedStyle=function(e,t){return this.el=e,this.getPropertyValue=function(t){var n=/(\-([a-z]){1})/g;return t=="float"&&(t="styleFloat"),n.test(t)&&(t=t.replace(n,function(){return arguments[2].toUpperCase()})),e.currentStyle[t]?e.currentStyle[t]:null},this})
 

	
 
//http://javascript.nwbox.com/ContentLoaded by Diego Perini with modifications
 
function contentLoaded(n,t){var l="complete",s="readystatechange",u=!1,h=u,c=!0,i=n.document,a=i.documentElement,e=i.addEventListener?"addEventListener":"attachEvent",v=i.addEventListener?"removeEventListener":"detachEvent",f=i.addEventListener?"":"on",r=function(e){(e.type!=s||i.readyState==l)&&((e.type=="load"?n:i)[v](f+e.type,r,u),!h&&(h=!0)&&t.call(n,null))},o=function(){try{a.doScroll("left")}catch(n){setTimeout(o,50);return}r("poll")};if(i.readyState==l)t.call(n,"lazy");else{if(i.createEventObject&&a.doScroll){try{c=!n.frameElement}catch(y){}c&&o()}i[e](f+"DOMContentLoaded",r,u),i[e](f+s,r,u),n[e](f+"load",r,u)}};
 

	
 
//https://gist.github.com/991057 by Jed Schmidt with modifications
 
function selector(a){
 
	a=a.match(/^(\W)?(.*)/);var b=document["getElement"+(a[1]?a[1]=="#"?"ById":"sByClassName":"sByTagName")](a[2]);
 
	var ret=[];	b!=null&&(b.length?ret=b:b.length==0?ret=b:ret=[b]);	return ret;
 
}
 

	
 
//shallow object property extend
 
function extend(a,b){var c={};for(var d in a)c[d]=a[d];for(var e in b)c[e]=b[e];return c}
 

	
 
//hasOwnProperty polyfill
 
if (!Object.prototype.hasOwnProperty)
 
	Object.prototype.hasOwnProperty = function(prop) {
 
		var proto = this.__proto__ || this.constructor.prototype;
 
		return (prop in this) && (!(prop in proto) || proto[prop] !== this[prop]);
 
	}
 

	
 
function text_size(width, height, template) {
 
	height = parseInt(height,10);
 
	width = parseInt(width,10);
 
	var bigSide = Math.max(height, width)
 
	var smallSide = Math.min(height, width)
 
	var scale = 1 / 12;
 
	var newHeight = Math.min(smallSide * 0.75, 0.75 * bigSide * scale);
 
	return {
 
		height: Math.round(Math.max(template.size, newHeight))
 
	}
 
}
 

	
 
function draw(ctx, dimensions, template, ratio) {
 
	var ts = text_size(dimensions.width, dimensions.height, template);
 
	var text_height = ts.height;
 
	var width = dimensions.width * ratio,
 
		height = dimensions.height * ratio;
 
	var font = template.font ? template.font : "sans-serif";
 
	canvas.width = width;
 
	canvas.height = height;
 
	ctx.textAlign = "center";
 
	ctx.textBaseline = "middle";
 
	ctx.fillStyle = template.background;
 
	ctx.fillRect(0, 0, width, height);
 
	ctx.fillStyle = template.foreground;
 
	ctx.font = "bold " + text_height + "px " + font;
 
	var text = template.text ? template.text : (Math.floor(dimensions.width) + "x" + Math.floor(dimensions.height));
 
	var text_width = ctx.measureText(text).width;
 
	if (text_width / width >= 0.75) {
 
		text_height = Math.floor(text_height * 0.75 * (width/text_width));
 
	}
 
	//Resetting font size if necessary
 
	ctx.font = "bold " + (text_height * ratio) + "px " + font;
 
	ctx.fillText(text, (width / 2), (height / 2), width);
 
	return canvas.toDataURL("image/png");
 
}
 

	
 
function render(mode, el, holder, src) {
 
	var dimensions = holder.dimensions,
 
		theme = holder.theme,
 
		text = holder.text ? decodeURIComponent(holder.text) : holder.text;
 
	var dimensions_caption = dimensions.width + "x" + dimensions.height;
 
	theme = (text ? extend(theme, {
 
		text: text
 
	}) : theme);
 
	theme = (holder.font ? extend(theme, {
 
		font: holder.font
 
	}) : theme);
 
	if (mode == "image") {
 
		el.setAttribute("data-src", src);
 
		el.setAttribute("alt", text ? text : theme.text ? theme.text + " [" + dimensions_caption + "]" : dimensions_caption);
 
		if (fallback || !holder.auto) {
 
			el.style.width = dimensions.width + "px";
 
			el.style.height = dimensions.height + "px";
 
		}
 
		if (fallback) {
 
			el.style.backgroundColor = theme.background;
 
		} else {
 
			el.setAttribute("src", draw(ctx, dimensions, theme, ratio));
 
		}
 
	} else if (mode == "background") {
 
		if (!fallback) {
 
			el.style.backgroundImage = "url(" + draw(ctx, dimensions, theme, ratio) + ")";
 
			el.style.backgroundSize = dimensions.width + "px " + dimensions.height + "px";
 
		}
 
	} else if (mode == "fluid") {
 
		el.setAttribute("data-src", src);
 
		el.setAttribute("alt", text ? text : theme.text ? theme.text + " [" + dimensions_caption + "]" : dimensions_caption);
 
		if (dimensions.height.substr(-1) == "%") {
 
			el.style.height = dimensions.height
 
		} else {
 
			el.style.height = dimensions.height + "px"
 
		}
 
		if (dimensions.width.substr(-1) == "%") {
 
			el.style.width = dimensions.width
 
		} else {
 
			el.style.width = dimensions.width + "px"
 
		}
 
		if (el.style.display == "inline" || el.style.display == "") {
 
			el.style.display = "block";
 
		}
 
		if (fallback) {
 
			el.style.backgroundColor = theme.background;
 
		} else {
 
			el.holderData = holder;
 
			fluid_images.push(el);
 
			fluid_update(el);
 
		}
 
	}
 
};
 

	
 
function fluid_update(element) {
 
	var images;
 
	if (element.nodeType == null) {
 
		images = fluid_images;
 
	} else {
 
		images = [element]
 
	}
 
	for (i in images) {
 
		var el = images[i]
 
		if (el.holderData) {
 
			var holder = el.holderData;
 
			el.setAttribute("src", draw(ctx, {
 
				height: el.clientHeight,
 
				width: el.clientWidth
 
			}, holder.theme, ratio));
 
		}
 
	}
 
}
 

	
 
function parse_flags(flags, options) {
 

	
 
	var ret = {
 
		theme: settings.themes.gray
 
	}, render = false;
 

	
 
	for (sl = flags.length, j = 0; j < sl; j++) {
 
		var flag = flags[j];
 
		if (app.flags.dimensions.match(flag)) {
 
			render = true;
 
			ret.dimensions = app.flags.dimensions.output(flag);
 
		} else if (app.flags.fluid.match(flag)) {
 
			render = true;
 
			ret.dimensions = app.flags.fluid.output(flag);
 
			ret.fluid = true;
 
		} else if (app.flags.colors.match(flag)) {
 
			ret.theme = app.flags.colors.output(flag);
 
		} else if (options.themes[flag]) {
 
			//If a theme is specified, it will override custom colors
 
			ret.theme = options.themes[flag];
 
		} else if (app.flags.text.match(flag)) {
 
			ret.text = app.flags.text.output(flag);
 
		} else if (app.flags.font.match(flag)) {
 
			ret.font = app.flags.font.output(flag);
 
		} else if (app.flags.auto.match(flag)) {
 
			ret.auto = true;
 
		}
 
	}
 

	
 
	return render ? ret : false;
 

	
 
};
 

	
 

	
 

	
 
if (!canvas.getContext) {
 
	fallback = true;
 
} else {
 
	if (canvas.toDataURL("image/png")
 
		.indexOf("data:image/png") < 0) {
 
		//Android doesn't support data URI
 
		fallback = true;
 
	} else {
 
		var ctx = canvas.getContext("2d");
 
	}
 
}
 

	
 
var dpr = 1, bsr = 1;
 
	
 
if(!fallback){
 
    dpr = window.devicePixelRatio || 1,
 
    bsr = ctx.webkitBackingStorePixelRatio || ctx.mozBackingStorePixelRatio || ctx.msBackingStorePixelRatio || ctx.oBackingStorePixelRatio || ctx.backingStorePixelRatio || 1;
 
}
 

	
 
var ratio = dpr / bsr;
 

	
 
var fluid_images = [];
 

	
 
var settings = {
 
	domain: "holder.js",
 
	images: "img",
 
	bgnodes: ".holderjs",
 
	themes: {
 
		"gray": {
 
			background: "#eee",
 
			foreground: "#aaa",
 
			size: 12
 
		},
 
		"social": {
 
			background: "#3a5a97",
 
			foreground: "#fff",
 
			size: 12
 
		},
 
		"industrial": {
 
			background: "#434A52",
 
			foreground: "#C2F200",
 
			size: 12
 
		}
 
	},
 
	stylesheet: ".holderjs-fluid {font-size:16px;font-weight:bold;text-align:center;font-family:sans-serif;margin:0}"
 
};
 

	
 

	
 
app.flags = {
 
	dimensions: {
 
		regex: /^(\d+)x(\d+)$/,
 
		output: function (val) {
 
			var exec = this.regex.exec(val);
 
			return {
 
				width: +exec[1],
 
				height: +exec[2]
 
			}
 
		}
 
	},
 
	fluid: {
 
		regex: /^([0-9%]+)x([0-9%]+)$/,
 
		output: function (val) {
 
			var exec = this.regex.exec(val);
 
			return {
 
				width: exec[1],
 
				height: exec[2]
 
			}
 
		}
 
	},
 
	colors: {
 
		regex: /#([0-9a-f]{3,})\:#([0-9a-f]{3,})/i,
 
		output: function (val) {
 
			var exec = this.regex.exec(val);
 
			return {
 
				size: settings.themes.gray.size,
 
				foreground: "#" + exec[2],
 
				background: "#" + exec[1]
 
			}
 
		}
 
	},
 
	text: {
 
		regex: /text\:(.*)/,
 
		output: function (val) {
 
			return this.regex.exec(val)[1];
 
		}
 
	},
 
	font: {
 
		regex: /font\:(.*)/,
 
		output: function (val) {
 
			return this.regex.exec(val)[1];
 
		}
 
	},
 
	auto: {
 
		regex: /^auto$/
 
	}
 
}
 

	
 
for (var flag in app.flags) {
 
	if (!app.flags.hasOwnProperty(flag)) continue;
 
	app.flags[flag].match = function (val) {
 
		return val.match(this.regex)
 
	}
 
}
 

	
 
app.add_theme = function (name, theme) {
 
	name != null && theme != null && (settings.themes[name] = theme);
 
	return app;
 
};
 

	
 
app.add_image = function (src, el) {
 
	var node = selector(el);
 
	if (node.length) {
 
		for (var i = 0, l = node.length; i < l; i++) {
 
			var img = document.createElement("img")
 
			img.setAttribute("data-src", src);
 
			node[i].appendChild(img);
 
		}
 
	}
 
	return app;
 
};
 

	
 
app.run = function (o) {
 
	var options = extend(settings, o),
 
	    images = [], imageNodes = [], bgnodes = [];
 
	    
 
	if(typeof(options.images) == "string"){
 
	    imageNodes = selector(options.images);
 
	}
 
	else if (window.NodeList && options.images instanceof window.NodeList) {
 
		imageNodes = options.images;
 
	} else if (window.Node && options.images instanceof window.Node) {
 
		imageNodes = [options.images];
 
	}
 

	
 
	if(typeof(options.bgnodes) == "string"){
 
	    bgnodes = selector(options.bgnodes);
 
	} else if (window.NodeList && options.elements instanceof window.NodeList) {
 
		bgnodes = options.bgnodes;
 
	} else if (window.Node && options.bgnodes instanceof window.Node) {
 
		bgnodes = [options.bgnodes];
 
	}
 

	
 
	preempted = true;
 

	
 
	for (i = 0, l = imageNodes.length; i < l; i++) images.push(imageNodes[i]);
 

	
 
	var holdercss = document.getElementById("holderjs-style");
 
	if (!holdercss) {
 
		holdercss = document.createElement("style");
 
		holdercss.setAttribute("id", "holderjs-style");
 
		holdercss.type = "text/css";
 
		document.getElementsByTagName("head")[0].appendChild(holdercss);
 
	}
 
	
 
	if (!options.nocss) {
 
	    if (holdercss.styleSheet) {
 
		    holdercss.styleSheet.cssText += options.stylesheet;
 
	    } else {
 
		    holdercss.appendChild(document.createTextNode(options.stylesheet));
 
	    }
 
	}
 

	
 
	var cssregex = new RegExp(options.domain + "\/(.*?)\"?\\)");
 

	
 
	for (var l = bgnodes.length, i = 0; i < l; i++) {
 
		var src = window.getComputedStyle(bgnodes[i], null)
 
			.getPropertyValue("background-image");
 
		var flags = src.match(cssregex);
 
		var bgsrc = bgnodes[i].getAttribute("data-background-src");
 

	
 
		if (flags) {
 
			var holder = parse_flags(flags[1].split("/"), options);
 
			if (holder) {
 
				render("background", bgnodes[i], holder, src);
 
			}
 
		}
 
		else if(bgsrc != null){
 
		    var holder = parse_flags(bgsrc.substr(bgsrc.lastIndexOf(options.domain) + options.domain.length + 1)
 
				.split("/"), options);
 
		    if(holder){
 
			render("background", bgnodes[i], holder, src);
 
		    }
 
		}
 
	}
 

	
 
	for (l = images.length, i = 0; i < l; i++) {
 
	    
 
		var attr_src = attr_data_src = src = null;
 
		
 
		try{
 
		    attr_src = images[i].getAttribute("src");
 
		    attr_datasrc = images[i].getAttribute("data-src");
 
		}catch(e){}
 
				
 
		if (attr_datasrc == null && !! attr_src && attr_src.indexOf(options.domain) >= 0) {
 
			src = attr_src;
 
		} else if ( !! attr_datasrc && attr_datasrc.indexOf(options.domain) >= 0) {
 
			src = attr_datasrc;
 
		}
 
		
 
		if (src) {
 
			var holder = parse_flags(src.substr(src.lastIndexOf(options.domain) + options.domain.length + 1)
 
				.split("/"), options);
 
			if (holder) {
 
				if (holder.fluid) {
 
					render("fluid", images[i], holder, src)
 
				} else {
 
					render("image", images[i], holder, src);
 
				}
 
			}
 
		}
 
	}
 
	return app;
 
};
 

	
 
contentLoaded(win, function () {
 
	if (window.addEventListener) {
 
		window.addEventListener("resize", fluid_update, false);
 
		window.addEventListener("orientationchange", fluid_update, false);
 
	} else {
 
		window.attachEvent("onresize", fluid_update)
 
	}
 
	preempted || app.run();
 
});
 

	
 
if (typeof define === "function" && define.amd) {
 
	define("Holder", [], function () {
 
		return app;
 
	});
 
}
 

	
 
})(Holder, window);
bootstrap-3.0.0/assets/js/html5shiv.js
Show inline comments
 
new file 100644
 
/*
 
 HTML5 Shiv v3.6.2pre | @afarkas @jdalton @jon_neal @rem | MIT/GPL2 Licensed
 
*/
 
(function(l,f){function m(){var a=e.elements;return"string"==typeof a?a.split(" "):a}function i(a){var b=n[a[o]];b||(b={},h++,a[o]=h,n[h]=b);return b}function p(a,b,c){b||(b=f);if(g)return b.createElement(a);c||(c=i(b));b=c.cache[a]?c.cache[a].cloneNode():r.test(a)?(c.cache[a]=c.createElem(a)).cloneNode():c.createElem(a);return b.canHaveChildren&&!s.test(a)?c.frag.appendChild(b):b}function t(a,b){if(!b.cache)b.cache={},b.createElem=a.createElement,b.createFrag=a.createDocumentFragment,b.frag=b.createFrag();
 
a.createElement=function(c){return!e.shivMethods?b.createElem(c):p(c,a,b)};a.createDocumentFragment=Function("h,f","return function(){var n=f.cloneNode(),c=n.createElement;h.shivMethods&&("+m().join().replace(/\w+/g,function(a){b.createElem(a);b.frag.createElement(a);return'c("'+a+'")'})+");return n}")(e,b.frag)}function q(a){a||(a=f);var b=i(a);if(e.shivCSS&&!j&&!b.hasCSS){var c,d=a;c=d.createElement("p");d=d.getElementsByTagName("head")[0]||d.documentElement;c.innerHTML="x<style>article,aside,figcaption,figure,footer,header,hgroup,nav,section{display:block}mark{background:#FF0;color:#000}</style>";
 
c=d.insertBefore(c.lastChild,d.firstChild);b.hasCSS=!!c}g||t(a,b);return a}var k=l.html5||{},s=/^<|^(?:button|map|select|textarea|object|iframe|option|optgroup)$/i,r=/^(?:a|b|code|div|fieldset|h1|h2|h3|h4|h5|h6|i|label|li|ol|p|q|span|strong|style|table|tbody|td|th|tr|ul)$/i,j,o="_html5shiv",h=0,n={},g;(function(){try{var a=f.createElement("a");a.innerHTML="<xyz></xyz>";j="hidden"in a;var b;if(!(b=1==a.childNodes.length)){f.createElement("a");var c=f.createDocumentFragment();b="undefined"==typeof c.cloneNode||
 
"undefined"==typeof c.createDocumentFragment||"undefined"==typeof c.createElement}g=b}catch(d){g=j=!0}})();var e={elements:k.elements||"abbr article aside audio bdi canvas data datalist details figcaption figure footer header hgroup mark meter nav output progress section summary time video",version:"3.6.2pre",shivCSS:!1!==k.shivCSS,supportsUnknownElements:g,shivMethods:!1!==k.shivMethods,type:"default",shivDocument:q,createElement:p,createDocumentFragment:function(a,b){a||(a=f);if(g)return a.createDocumentFragment();
 
for(var b=b||i(a),c=b.frag.cloneNode(),d=0,e=m(),h=e.length;d<h;d++)c.createElement(e[d]);return c}};l.html5=e;q(f)})(this,document);

Changeset was too big and was cut off... Show full diff anyway

0 comments (0 inline, 0 general)