mirror of
https://github.com/codeninjasllc/codecombat.git
synced 2024-11-27 09:35:39 -05:00
Starting work on simple recruitment listings. Moved Treema and the JS parts of Bootstrap to bower.
This commit is contained in:
parent
8fe568d3a4
commit
5c8c7fff1d
33 changed files with 250 additions and 5754 deletions
|
@ -616,7 +616,7 @@ module.exports = nativeDescription: "English", englishDescription: "English", tr
|
||||||
bad_input: "Bad input."
|
bad_input: "Bad input."
|
||||||
server_error: "Server error."
|
server_error: "Server error."
|
||||||
unknown: "Unknown error."
|
unknown: "Unknown error."
|
||||||
|
|
||||||
resources:
|
resources:
|
||||||
your_sessions: "Your Sessions"
|
your_sessions: "Your Sessions"
|
||||||
level: "Level"
|
level: "Level"
|
||||||
|
@ -626,4 +626,5 @@ module.exports = nativeDescription: "English", englishDescription: "English", tr
|
||||||
facebook_friend_sessions: "Facebook Friend Sessions"
|
facebook_friend_sessions: "Facebook Friend Sessions"
|
||||||
gplus_friends: "G+ Friends"
|
gplus_friends: "G+ Friends"
|
||||||
gplus_friend_sessions: "G+ Friend Sessions"
|
gplus_friend_sessions: "G+ Friend Sessions"
|
||||||
leaderboard: 'leaderboard'
|
leaderboard: "Leaderboard"
|
||||||
|
user_schema: "User Schema"
|
||||||
|
|
|
@ -37,4 +37,7 @@
|
||||||
font-size: 12px
|
font-size: 12px
|
||||||
|
|
||||||
.form
|
.form
|
||||||
max-width: 600px
|
max-width: 600px
|
||||||
|
|
||||||
|
#job-profile-treema
|
||||||
|
background-color: white
|
||||||
|
|
15
app/styles/employers.sass
Normal file
15
app/styles/employers.sass
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
#employers-view
|
||||||
|
.tablesorter
|
||||||
|
//img
|
||||||
|
// display: none
|
||||||
|
|
||||||
|
.tablesorter-header
|
||||||
|
cursor: pointer
|
||||||
|
&:hover
|
||||||
|
color: black
|
||||||
|
|
||||||
|
.tablesorter-headerAsc
|
||||||
|
background-color: #cfc
|
||||||
|
|
||||||
|
.tablesorter-headerDesc
|
||||||
|
background-color: #ccf
|
8
app/templates/account/job_profile.jade
Normal file
8
app/templates/account/job_profile.jade
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
h3(data-i18n="account_settings.job_profile") Job Profile
|
||||||
|
|
||||||
|
if me.get('jobProfileApproved')
|
||||||
|
p.lead(data-i18n="account_settings.job_profile_approved") Your job profile has been approved by CodeCombat.
|
||||||
|
else
|
||||||
|
p.lead(data-i18n="account_settings.job_profile_explanation") Fill this out, and we will try to find you a job, and stuff.
|
||||||
|
|
||||||
|
#job-profile-treema
|
|
@ -21,6 +21,9 @@ block content
|
||||||
a(href="#password-pane", data-toggle="tab", data-i18n="account_settings.password_tab") Password
|
a(href="#password-pane", data-toggle="tab", data-i18n="account_settings.password_tab") Password
|
||||||
li
|
li
|
||||||
a(href="#email-pane", data-toggle="tab", data-i18n="account_settings.emails_tab") Emails
|
a(href="#email-pane", data-toggle="tab", data-i18n="account_settings.emails_tab") Emails
|
||||||
|
if me.isAdmin()
|
||||||
|
li
|
||||||
|
a(href="#job-profile-pane", data-toggle="tab", data-i18n="account_settings.job_profile_tab") Job Profile
|
||||||
|
|
||||||
.tab-content#settings-panes
|
.tab-content#settings-panes
|
||||||
#general-pane.tab-pane
|
#general-pane.tab-pane
|
||||||
|
@ -153,3 +156,6 @@ block content
|
||||||
span(data-i18n="contribute.ambassador_subscribe_desc").help-block Get emails on support updates and multiplayer developments.
|
span(data-i18n="contribute.ambassador_subscribe_desc").help-block Get emails on support updates and multiplayer developments.
|
||||||
|
|
||||||
button.btn#toggle-all-button(data-i18n="account_settings.email_toggle") Toggle All
|
button.btn#toggle-all-button(data-i18n="account_settings.email_toggle") Toggle All
|
||||||
|
|
||||||
|
#job-profile-pane.tab-pane
|
||||||
|
#job-profile-view
|
||||||
|
|
|
@ -32,3 +32,29 @@ block content
|
||||||
h4 Skill: from interns and entry level to senior developers and management
|
h4 Skill: from interns and entry level to senior developers and management
|
||||||
h4 Technologies: just about everything
|
h4 Technologies: just about everything
|
||||||
h4 Countries: USA, Canada, Australia, and many more
|
h4 Countries: USA, Canada, Australia, and many more
|
||||||
|
|
||||||
|
p If you click on a profile, you can see:
|
||||||
|
ul
|
||||||
|
li extra links
|
||||||
|
li extra skill tags
|
||||||
|
li self description
|
||||||
|
li work experience description: list of company name, job title, dates
|
||||||
|
li educational experience: list of school name, degree & major, dates
|
||||||
|
li our notes
|
||||||
|
li links to CodeCombat code in action
|
||||||
|
li contact modal link
|
||||||
|
li visa needs
|
||||||
|
li more location
|
||||||
|
li projects: list of pic, name, description, link (like http://www.folyo.me/designers/stanislav-udotov)
|
||||||
|
|
||||||
|
table.table.table-condensed.table-hover.table-responsive.tablesorter
|
||||||
|
thead
|
||||||
|
tr
|
||||||
|
th Name
|
||||||
|
th Location
|
||||||
|
th Looking For
|
||||||
|
// Remote, Full-time, Part-time, Contracting, Internship
|
||||||
|
th Top 5 Skills
|
||||||
|
th Yrs Exp
|
||||||
|
th Last Updated
|
||||||
|
th Current Job
|
||||||
|
|
53
app/views/account/job_profile_view.coffee
Normal file
53
app/views/account/job_profile_view.coffee
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
CocoView = require 'views/kinds/CocoView'
|
||||||
|
template = require 'templates/account/job_profile'
|
||||||
|
{me} = require('lib/auth')
|
||||||
|
|
||||||
|
module.exports = class JobProfileView extends CocoView
|
||||||
|
id: 'job-profile-view'
|
||||||
|
template: template
|
||||||
|
|
||||||
|
editableSettings: [
|
||||||
|
'lookingFor', 'active', 'name', 'city', 'country', 'skills', 'experience', 'shortDescription', 'longDescription',
|
||||||
|
'work', 'education', 'visa', 'projects', 'links'
|
||||||
|
]
|
||||||
|
readOnlySettings: [
|
||||||
|
'updated'
|
||||||
|
]
|
||||||
|
|
||||||
|
constructor: (options) ->
|
||||||
|
super options
|
||||||
|
unless me.schema().loaded
|
||||||
|
@addSomethingToLoad("user_schema")
|
||||||
|
@listenToOnce me, 'schema-loaded', => @somethingLoaded 'user_schema'
|
||||||
|
|
||||||
|
afterRender: ->
|
||||||
|
super()
|
||||||
|
return if @loading()
|
||||||
|
@buildJobProfileTreema()
|
||||||
|
|
||||||
|
buildJobProfileTreema: ->
|
||||||
|
visibleSettings = @editableSettings.concat @readOnlySettings
|
||||||
|
data = _.pick (me.get('jobProfile') ? {}), (value, key) => key in visibleSettings
|
||||||
|
data.name ?= (me.get('firstName') + ' ' + me.get('lastName')).trim() if me.get('firstName')
|
||||||
|
schema = _.cloneDeep me.schema().get('properties').jobProfile
|
||||||
|
schema.properties = _.pick schema.properties, (value, key) => key in visibleSettings
|
||||||
|
schema.required = _.intersection schema.required, visibleSettings
|
||||||
|
for prop in @readOnlySettings
|
||||||
|
schema.properties[prop].readOnly = true
|
||||||
|
treemaOptions =
|
||||||
|
filePath: "db/user/#{me.id}"
|
||||||
|
schema: schema
|
||||||
|
data: data
|
||||||
|
callbacks: {change: @onJobProfileChanged}
|
||||||
|
|
||||||
|
@jobProfileTreema = @$el.find('#job-profile-treema').treema treemaOptions
|
||||||
|
@jobProfileTreema.build()
|
||||||
|
@jobProfileTreema.open()
|
||||||
|
|
||||||
|
onJobProfileChanged: (e) =>
|
||||||
|
@hasEditedProfile = true
|
||||||
|
@trigger 'change'
|
||||||
|
|
||||||
|
getData: ->
|
||||||
|
return {} unless me.get('jobProfile') or @hasEditedProfile
|
||||||
|
_.pick @jobProfileTreema.data, (value, key) => key in @editableSettings
|
|
@ -5,6 +5,7 @@ forms = require('lib/forms')
|
||||||
User = require('models/User')
|
User = require('models/User')
|
||||||
|
|
||||||
WizardSettingsView = require './wizard_settings_view'
|
WizardSettingsView = require './wizard_settings_view'
|
||||||
|
JobProfileView = require './job_profile_view'
|
||||||
|
|
||||||
module.exports = class SettingsView extends View
|
module.exports = class SettingsView extends View
|
||||||
id: 'account-settings-view'
|
id: 'account-settings-view'
|
||||||
|
@ -45,9 +46,14 @@ module.exports = class SettingsView extends View
|
||||||
)
|
)
|
||||||
|
|
||||||
@chooseTab(location.hash.replace('#',''))
|
@chooseTab(location.hash.replace('#',''))
|
||||||
WizardSettingsView = new WizardSettingsView()
|
|
||||||
@listenTo(WizardSettingsView, 'change', @save)
|
wizardSettingsView = new WizardSettingsView()
|
||||||
@insertSubView WizardSettingsView
|
@listenTo wizardSettingsView, 'change', @save
|
||||||
|
@insertSubView wizardSettingsView
|
||||||
|
|
||||||
|
@jobProfileView = new JobProfileView()
|
||||||
|
@listenTo @jobProfileView, 'change', @save
|
||||||
|
@insertSubView @jobProfileView
|
||||||
|
|
||||||
chooseTab: (category) ->
|
chooseTab: (category) ->
|
||||||
id = "##{category}-pane"
|
id = "##{category}-pane"
|
||||||
|
@ -129,3 +135,12 @@ module.exports = class SettingsView extends View
|
||||||
permissions = []
|
permissions = []
|
||||||
permissions.push 'admin' if adminCheckbox.prop('checked')
|
permissions.push 'admin' if adminCheckbox.prop('checked')
|
||||||
me.set('permissions', permissions)
|
me.set('permissions', permissions)
|
||||||
|
|
||||||
|
jobProfile = me.get('jobProfile') ? {}
|
||||||
|
updated = false
|
||||||
|
for key, val of @jobProfileView.getData()
|
||||||
|
updated = updated or jobProfile[key] isnt val
|
||||||
|
jobProfile[key] = val
|
||||||
|
if updated
|
||||||
|
jobProfile.updated = new Date() # doesn't work
|
||||||
|
me.set 'jobProfile', jobProfile
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
SearchView = require 'views/kinds/SearchView'
|
SearchView = require 'views/kinds/SearchView'
|
||||||
|
|
||||||
module.exports = class ThangTypeHomeView extends SearchView
|
module.exports = class EditorSearchView extends SearchView
|
||||||
id: "editor-level-home-view"
|
id: "editor-level-home-view"
|
||||||
modelLabel: 'Level'
|
modelLabel: 'Level'
|
||||||
model: require 'models/Level'
|
model: require 'models/Level'
|
||||||
modelURL: '/db/level'
|
modelURL: '/db/level'
|
||||||
tableTemplate: require 'templates/editor/level/table'
|
tableTemplate: require 'templates/editor/level/table'
|
||||||
|
|
|
@ -4,3 +4,49 @@ template = require 'templates/employers'
|
||||||
module.exports = class EmployersView extends View
|
module.exports = class EmployersView extends View
|
||||||
id: "employers-view"
|
id: "employers-view"
|
||||||
template: template
|
template: template
|
||||||
|
|
||||||
|
afterRender: ->
|
||||||
|
@sortTable()
|
||||||
|
super()
|
||||||
|
|
||||||
|
sortTable: ->
|
||||||
|
# http://mottie.github.io/tablesorter/docs/example-widget-bootstrap-theme.html
|
||||||
|
$.extend $.tablesorter.themes.bootstrap,
|
||||||
|
# these classes are added to the table. To see other table classes available,
|
||||||
|
# look here: http://twitter.github.com/bootstrap/base-css.html#tables
|
||||||
|
table: "table table-bordered"
|
||||||
|
caption: "caption"
|
||||||
|
header: "bootstrap-header" # give the header a gradient background
|
||||||
|
footerRow: ""
|
||||||
|
footerCells: ""
|
||||||
|
icons: "" # add "icon-white" to make them white; this icon class is added to the <i> in the header
|
||||||
|
sortNone: "bootstrap-icon-unsorted"
|
||||||
|
sortAsc: "icon-chevron-up" # glyphicon glyphicon-chevron-up" # we are still using v2 icons
|
||||||
|
sortDesc: "icon-chevron-down" # glyphicon-chevron-down" # we are still using v2 icons
|
||||||
|
active: "" # applied when column is sorted
|
||||||
|
hover: "" # use custom css here - bootstrap class may not override it
|
||||||
|
filterRow: "" # filter row class
|
||||||
|
even: "" # odd row zebra striping
|
||||||
|
odd: "" # even row zebra striping
|
||||||
|
|
||||||
|
# call the tablesorter plugin and apply the uitheme widget
|
||||||
|
@$el.find(".tablesorter").tablesorter(
|
||||||
|
theme: "bootstrap"
|
||||||
|
widthFixed: true
|
||||||
|
headerTemplate: "{content} {icon}"
|
||||||
|
# widget code contained in the jquery.tablesorter.widgets.js file
|
||||||
|
# use the zebra stripe widget if you plan on hiding any rows (filter widget)
|
||||||
|
widgets: [
|
||||||
|
"uitheme"
|
||||||
|
"zebra"
|
||||||
|
]
|
||||||
|
widgetOptions:
|
||||||
|
# using the default zebra striping class name, so it actually isn't included in the theme variable above
|
||||||
|
# this is ONLY needed for bootstrap theming if you are using the filter widget, because rows are hidden
|
||||||
|
zebra: [
|
||||||
|
"even"
|
||||||
|
"odd"
|
||||||
|
]
|
||||||
|
# reset filters button
|
||||||
|
filter_reset: ".reset"
|
||||||
|
)
|
||||||
|
|
|
@ -8,7 +8,7 @@ class SearchCollection extends Backbone.Collection
|
||||||
@url = "#{modelURL}/search?project=true"
|
@url = "#{modelURL}/search?project=true"
|
||||||
@url += "&term=#{term}" if @term
|
@url += "&term=#{term}" if @term
|
||||||
|
|
||||||
module.exports = class ThangTypeHomeView extends View
|
module.exports = class SearchView extends View
|
||||||
template: template
|
template: template
|
||||||
className: 'search-view'
|
className: 'search-view'
|
||||||
|
|
||||||
|
|
24
bower.json
24
bower.json
|
@ -36,7 +36,10 @@
|
||||||
"underscore.string": "~2.3.3",
|
"underscore.string": "~2.3.3",
|
||||||
"firebase": "~1.0.2",
|
"firebase": "~1.0.2",
|
||||||
"catiline": "~2.9.3",
|
"catiline": "~2.9.3",
|
||||||
"d3": "~3.4.4"
|
"d3": "~3.4.4",
|
||||||
|
"jquery.tablesorter": "~2.15.13",
|
||||||
|
"treema": "~0.0.1",
|
||||||
|
"bootstrap": "~3.1.1"
|
||||||
},
|
},
|
||||||
"overrides": {
|
"overrides": {
|
||||||
"backbone": {
|
"backbone": {
|
||||||
|
@ -50,6 +53,25 @@
|
||||||
},
|
},
|
||||||
"underscore.string": {
|
"underscore.string": {
|
||||||
"main": "lib/underscore.string.js"
|
"main": "lib/underscore.string.js"
|
||||||
|
},
|
||||||
|
"jquery.tablesorter": {
|
||||||
|
"main": [
|
||||||
|
"js/jquery.tablesorter.js",
|
||||||
|
"js/jquery.tablesorter.widgets.js",
|
||||||
|
"css/theme.bootstrap.css"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"bootstrap": {
|
||||||
|
"main": [
|
||||||
|
"./dist/js/bootstrap.js",
|
||||||
|
"./dist/fonts/glyphicons-halflings-regular.eot",
|
||||||
|
"./dist/fonts/glyphicons-halflings-regular.svg",
|
||||||
|
"./dist/fonts/glyphicons-halflings-regular.ttf",
|
||||||
|
"./dist/fonts/glyphicons-halflings-regular.woff"
|
||||||
|
]
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"resolutions": {
|
||||||
|
"jquery": "~2.0.3"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,17 +45,7 @@ exports.config =
|
||||||
'bower_components/lodash/dist/lodash.js'
|
'bower_components/lodash/dist/lodash.js'
|
||||||
'bower_components/backbone/backbone.js'
|
'bower_components/backbone/backbone.js'
|
||||||
# Twitter Bootstrap jquery plugins
|
# Twitter Bootstrap jquery plugins
|
||||||
'vendor/scripts/bootstrap/transition.js'
|
'bower_components/bootstrap/dist/bootstrap.js'
|
||||||
'vendor/scripts/bootstrap/affix.js'
|
|
||||||
'vendor/scripts/bootstrap/alert.js'
|
|
||||||
'vendor/scripts/bootstrap/button.js'
|
|
||||||
'vendor/scripts/bootstrap/carousel.js'
|
|
||||||
'vendor/scripts/bootstrap/collapse.js'
|
|
||||||
'vendor/scripts/bootstrap/dropdown.js'
|
|
||||||
'vendor/scripts/bootstrap/modal.js'
|
|
||||||
'vendor/scripts/bootstrap/scrollspy.js'
|
|
||||||
'vendor/scripts/bootstrap/tab.js'
|
|
||||||
'vendor/scripts/bootstrap/tooltip.js'
|
|
||||||
# CreateJS dependencies
|
# CreateJS dependencies
|
||||||
'vendor/scripts/easeljs-NEXT.combined.js'
|
'vendor/scripts/easeljs-NEXT.combined.js'
|
||||||
'vendor/scripts/preloadjs-NEXT.combined.js'
|
'vendor/scripts/preloadjs-NEXT.combined.js'
|
||||||
|
@ -70,7 +60,7 @@ exports.config =
|
||||||
stylesheets:
|
stylesheets:
|
||||||
defaultExtension: 'sass'
|
defaultExtension: 'sass'
|
||||||
joinTo:
|
joinTo:
|
||||||
'stylesheets/app.css': /^(app|vendor)/
|
'stylesheets/app.css': /^(app|vendor|bower_components)/
|
||||||
order:
|
order:
|
||||||
before: ['app/styles/bootstrap.scss']
|
before: ['app/styles/bootstrap.scss']
|
||||||
templates:
|
templates:
|
||||||
|
|
|
@ -73,7 +73,6 @@
|
||||||
"css-brunch": "> 1.0 < 1.8",
|
"css-brunch": "> 1.0 < 1.8",
|
||||||
"jade-brunch": "> 1.0 < 1.8",
|
"jade-brunch": "> 1.0 < 1.8",
|
||||||
"uglify-js-brunch": "~1.7.4",
|
"uglify-js-brunch": "~1.7.4",
|
||||||
"clean-css-brunch": "> 1.0 < 1.8",
|
|
||||||
"auto-reload-brunch": "> 1.0 < 1.8",
|
"auto-reload-brunch": "> 1.0 < 1.8",
|
||||||
"brunch": "~1.7.4",
|
"brunch": "~1.7.4",
|
||||||
"jasmine-node": "1.13.x",
|
"jasmine-node": "1.13.x",
|
||||||
|
|
|
@ -8,6 +8,8 @@ combine = (base, ext) ->
|
||||||
return base unless ext?
|
return base unless ext?
|
||||||
return _.extend(base, ext)
|
return _.extend(base, ext)
|
||||||
|
|
||||||
|
urlPattern = '^(ht|f)tp(s?)\:\/\/[0-9a-zA-Z]([-.\w]*[0-9a-zA-Z])*(:(0-9)*)*(\/?)([a-zA-Z0-9\-\.\?\,\'\/\\\+&%\$#_]*)?$'
|
||||||
|
|
||||||
# Common schema properties
|
# Common schema properties
|
||||||
me.object = (ext, props) -> combine {type: 'object', additionalProperties: false, properties: props or {}}, ext
|
me.object = (ext, props) -> combine {type: 'object', additionalProperties: false, properties: props or {}}, ext
|
||||||
me.array = (ext, items) -> combine {type: 'array', items: items or {}}, ext
|
me.array = (ext, items) -> combine {type: 'array', items: items or {}}, ext
|
||||||
|
@ -16,6 +18,7 @@ me.pct = (ext) -> combine({type: 'number', maximum: 1.0, minimum: 0.0}, ext)
|
||||||
me.date = (ext) -> combine({type: 'string', format: 'date-time'}, ext)
|
me.date = (ext) -> combine({type: 'string', format: 'date-time'}, ext)
|
||||||
# should just be string (Mongo ID), but sometimes mongoose turns them into objects representing those, so we are lenient
|
# should just be string (Mongo ID), but sometimes mongoose turns them into objects representing those, so we are lenient
|
||||||
me.objectId = (ext) -> schema = combine({type: ['object', 'string'] }, ext)
|
me.objectId = (ext) -> schema = combine({type: ['object', 'string'] }, ext)
|
||||||
|
me.url = (ext) -> combine({type: 'string', format: 'url', pattern: urlPattern}, ext)
|
||||||
|
|
||||||
PointSchema = me.object {title: "Point", description: "An {x, y} coordinate point.", format: "point2d", required: ["x", "y"]},
|
PointSchema = me.object {title: "Point", description: "An {x, y} coordinate point.", format: "point2d", required: ["x", "y"]},
|
||||||
x: {title: "x", description: "The x coordinate.", type: "number", "default": 15}
|
x: {title: "x", description: "The x coordinate.", type: "number", "default": 15}
|
||||||
|
|
|
@ -13,7 +13,7 @@ LevelSession = require('../levels/sessions/LevelSession')
|
||||||
serverProperties = ['passwordHash', 'emailLower', 'nameLower', 'passwordReset']
|
serverProperties = ['passwordHash', 'emailLower', 'nameLower', 'passwordReset']
|
||||||
privateProperties = [
|
privateProperties = [
|
||||||
'permissions', 'email', 'firstName', 'lastName', 'gender', 'facebookID',
|
'permissions', 'email', 'firstName', 'lastName', 'gender', 'facebookID',
|
||||||
'gplusID', 'music', 'volume', 'aceConfig'
|
'gplusID', 'music', 'volume', 'aceConfig', 'jobProfile', 'jobProfileApproved'
|
||||||
]
|
]
|
||||||
|
|
||||||
UserHandler = class UserHandler extends Handler
|
UserHandler = class UserHandler extends Handler
|
||||||
|
@ -23,7 +23,7 @@ UserHandler = class UserHandler extends Handler
|
||||||
'name', 'photoURL', 'password', 'anonymous', 'wizardColor1', 'volume',
|
'name', 'photoURL', 'password', 'anonymous', 'wizardColor1', 'volume',
|
||||||
'firstName', 'lastName', 'gender', 'facebookID', 'gplusID', 'emailSubscriptions',
|
'firstName', 'lastName', 'gender', 'facebookID', 'gplusID', 'emailSubscriptions',
|
||||||
'testGroupNumber', 'music', 'hourOfCode', 'hourOfCodeComplete', 'preferredLanguage',
|
'testGroupNumber', 'music', 'hourOfCode', 'hourOfCodeComplete', 'preferredLanguage',
|
||||||
'wizard', 'aceConfig', 'autocastDelay', 'lastLevel'
|
'wizard', 'aceConfig', 'autocastDelay', 'lastLevel', 'jobProfile'
|
||||||
]
|
]
|
||||||
|
|
||||||
jsonSchema: schema
|
jsonSchema: schema
|
||||||
|
|
|
@ -56,6 +56,41 @@ UserSchema = c.object {},
|
||||||
simulatedBy: {type: 'integer', minimum: 0, default: 0}
|
simulatedBy: {type: 'integer', minimum: 0, default: 0}
|
||||||
simulatedFor: {type: 'integer', minimum: 0, default: 0}
|
simulatedFor: {type: 'integer', minimum: 0, default: 0}
|
||||||
|
|
||||||
|
jobProfile: c.object {title: 'Job Profile', required: ['lookingFor', 'active', 'name', 'city', 'country', 'skills', 'experience', 'shortDescription', 'longDescription', 'visa', 'work', 'education', 'projects', 'links']},
|
||||||
|
lookingFor: {title: 'Looking For', type: 'string', enum: ['Full-time', 'Part-time', 'Remote', 'Contracting', 'Internship'], default: 'Full-time', description: 'What kind of developer position do you want?'}
|
||||||
|
active: {title: 'Active', type: 'boolean', description: 'Want interview offers right now?'}
|
||||||
|
updated: c.date {title: 'Last Updated', description: 'How fresh your profile appears to employers. The fresher, the better. Profiles go inactive after 30 days.'}
|
||||||
|
name: c.shortString {title: 'Name', description: 'Name you want employers to see, like "Nick Winter".'}
|
||||||
|
city: c.shortString {title: 'City', description: 'City you want to work in (or live in now), like "San Francisco" or "Lubbock, TX".', default: 'Defaultsville, CA'}
|
||||||
|
country: c.shortString {title: 'Country', description: 'Country you want to work in (or live in now), like "USA" or "France".', default: 'USA'}
|
||||||
|
skills: c.array {title: 'Skills', description: 'Tag relevant developer skills in order of proficiency. Employers will see the first five at a glance.', default: ['javascript'], minItems: 1, maxItems: 30, uniqueItems: true},
|
||||||
|
{type: 'string', minLength: 1, maxLength: 20, description: 'Ex.: "objective-c", "mongodb", "rails", "android", "javascript"'}
|
||||||
|
experience: {type: 'integer', title: 'Years of Experience', minimum: 0, description: 'How many years of professional experience (getting paid) developing software do you have?'}
|
||||||
|
shortDescription: {type: 'string', maxLength: 140, title: 'Short Description', description: 'Who are you, and what are you looking for? 140 characters max.', default: 'Programmer seeking to build great software.'}
|
||||||
|
longDescription: {type: 'string', maxLength: 2000, title: 'Long Description', description: 'Give employeers more details. Highlight your stunning personality. Markdown okay. 2000 characters max.', format: 'markdown', default: '* I write great code.\n* You need great code?\n* Great!'}
|
||||||
|
visa: c.shortString {title: 'US Work Status', description: 'Are you authorized to work in the US, or do you need visa sponsorship?', enum: ['Authorized to work in the US', 'Need visa sponsorship'], default: 'Authorized to work in the US'}
|
||||||
|
work: c.array {title: 'Work Experience', description: 'List your relevant work experience.'},
|
||||||
|
c.object {title: 'Job', description: 'Some work experience you had.', required: ['employer', 'role', 'duration']},
|
||||||
|
employer: c.shortString {title: 'Employer', description: 'Name of your employer.'}
|
||||||
|
role: c.shortString {title: 'Job Title', description: 'What was your job title or role?'}
|
||||||
|
duration: c.shortString {title: 'Duration', description: 'When did you hold this gig? Ex.: "Feb 2013 - present".'}
|
||||||
|
education: c.array {title: 'Education', description: 'List your academic ordeals.'},
|
||||||
|
c.object {title: 'Ordeal', description: 'Some education that befell you.', required: ['school', 'degree', 'duration']},
|
||||||
|
school: c.shortString {title: 'School', description: 'Name of your school.'}
|
||||||
|
degree: c.shortString {title: 'Degree', description: 'What was your degree and field of study? Ex. Ph.D. Human-Computer Interaction (incomplete)'}
|
||||||
|
duration: c.shortString {title: 'Duration', description: 'When? Ex.: "Aug 2004 - May 2008".'}
|
||||||
|
projects: c.array {title: 'Projects', description: 'Highlight your projects to amaze employers.'},
|
||||||
|
c.object {title: 'Project', description: 'A project you created.', required: ['name', 'description', 'picture', 'link']},
|
||||||
|
name: c.shortString {title: 'Project Name', description: 'What was the project called?'}
|
||||||
|
description: {type: 'string', title: 'Description', description: 'Briefly describe the project.', maxLength: 400, format: 'markdown'}
|
||||||
|
picture: {type: 'string', title: 'Picture', format: 'image-file', description: 'Upload a 300x225px or larger image showing off the project.'}
|
||||||
|
link: c.url {title: 'Link', description: 'Link to the project.', default: 'http://codecombat.com'}
|
||||||
|
links: c.array {title: 'Links', description: 'Link any other sites or profiles you want to highlight, like your GitHub, your LinkedIn, or your blog.'},
|
||||||
|
c.object {title: 'Link', description: 'A link to another site you want to highlight, like your GitHub, your LinkedIn, or your blog.', required: ['name', 'link']},
|
||||||
|
name: {type: 'string', maxLength: 30, title: 'Link Name', description: 'What are you linking to? Ex: "Personal Website", "Twitter"'}
|
||||||
|
link: c.url {title: 'Link', description: 'The URL.', default: 'http://codecombat.com'}
|
||||||
|
jobProfileApproved: {title: 'Job Profile Approved', type: 'boolean', description: 'Whether your profile has been approved by CodeCombat.'}
|
||||||
|
|
||||||
c.extendBasicProperties UserSchema, 'user'
|
c.extendBasicProperties UserSchema, 'user'
|
||||||
|
|
||||||
module.exports = UserSchema
|
module.exports = UserSchema
|
||||||
|
|
|
@ -3,6 +3,7 @@ path = require 'path'
|
||||||
authentication = require 'passport'
|
authentication = require 'passport'
|
||||||
useragent = require 'express-useragent'
|
useragent = require 'express-useragent'
|
||||||
fs = require 'graceful-fs'
|
fs = require 'graceful-fs'
|
||||||
|
log = require('winston')
|
||||||
|
|
||||||
database = require './server/commons/database'
|
database = require './server/commons/database'
|
||||||
baseRoute = require './server/routes/base'
|
baseRoute = require './server/routes/base'
|
||||||
|
@ -96,7 +97,8 @@ setupFallbackRouteToIndex = (app) ->
|
||||||
auth.loginUser(req, res, user, false, next)
|
auth.loginUser(req, res, user, false, next)
|
||||||
|
|
||||||
sendMain = (req, res) ->
|
sendMain = (req, res) ->
|
||||||
fs.readFile path.join(__dirname, 'public', 'main.html'), 'utf8', (err,data) ->
|
fs.readFile path.join(__dirname, 'public', 'main.html'), 'utf8', (err, data) ->
|
||||||
|
log.error "Error modifying main.html: #{err}" if err
|
||||||
# insert the user object directly into the html so the application can have it immediately
|
# insert the user object directly into the html so the application can have it immediately
|
||||||
data = data.replace('"userObjectTag"', JSON.stringify(UserHandler.formatEntity(req, req.user)))
|
data = data.replace('"userObjectTag"', JSON.stringify(UserHandler.formatEntity(req, req.user)))
|
||||||
res.send data
|
res.send data
|
||||||
|
|
126
vendor/scripts/bootstrap/affix.js
vendored
126
vendor/scripts/bootstrap/affix.js
vendored
|
@ -1,126 +0,0 @@
|
||||||
/* ========================================================================
|
|
||||||
* Bootstrap: affix.js v3.0.3
|
|
||||||
* http://getbootstrap.com/javascript/#affix
|
|
||||||
* ========================================================================
|
|
||||||
* Copyright 2013 Twitter, Inc.
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
* ======================================================================== */
|
|
||||||
|
|
||||||
|
|
||||||
+function ($) { "use strict";
|
|
||||||
|
|
||||||
// AFFIX CLASS DEFINITION
|
|
||||||
// ======================
|
|
||||||
|
|
||||||
var Affix = function (element, options) {
|
|
||||||
this.options = $.extend({}, Affix.DEFAULTS, options)
|
|
||||||
this.$window = $(window)
|
|
||||||
.on('scroll.bs.affix.data-api', $.proxy(this.checkPosition, this))
|
|
||||||
.on('click.bs.affix.data-api', $.proxy(this.checkPositionWithEventLoop, this))
|
|
||||||
|
|
||||||
this.$element = $(element)
|
|
||||||
this.affixed =
|
|
||||||
this.unpin = null
|
|
||||||
|
|
||||||
this.checkPosition()
|
|
||||||
}
|
|
||||||
|
|
||||||
Affix.RESET = 'affix affix-top affix-bottom'
|
|
||||||
|
|
||||||
Affix.DEFAULTS = {
|
|
||||||
offset: 0
|
|
||||||
}
|
|
||||||
|
|
||||||
Affix.prototype.checkPositionWithEventLoop = function () {
|
|
||||||
setTimeout($.proxy(this.checkPosition, this), 1)
|
|
||||||
}
|
|
||||||
|
|
||||||
Affix.prototype.checkPosition = function () {
|
|
||||||
if (!this.$element.is(':visible')) return
|
|
||||||
|
|
||||||
var scrollHeight = $(document).height()
|
|
||||||
var scrollTop = this.$window.scrollTop()
|
|
||||||
var position = this.$element.offset()
|
|
||||||
var offset = this.options.offset
|
|
||||||
var offsetTop = offset.top
|
|
||||||
var offsetBottom = offset.bottom
|
|
||||||
|
|
||||||
if (typeof offset != 'object') offsetBottom = offsetTop = offset
|
|
||||||
if (typeof offsetTop == 'function') offsetTop = offset.top()
|
|
||||||
if (typeof offsetBottom == 'function') offsetBottom = offset.bottom()
|
|
||||||
|
|
||||||
var affix = this.unpin != null && (scrollTop + this.unpin <= position.top) ? false :
|
|
||||||
offsetBottom != null && (position.top + this.$element.height() >= scrollHeight - offsetBottom) ? 'bottom' :
|
|
||||||
offsetTop != null && (scrollTop <= offsetTop) ? 'top' : false
|
|
||||||
|
|
||||||
if (this.affixed === affix) return
|
|
||||||
if (this.unpin) this.$element.css('top', '')
|
|
||||||
|
|
||||||
this.affixed = affix
|
|
||||||
this.unpin = affix == 'bottom' ? position.top - scrollTop : null
|
|
||||||
|
|
||||||
this.$element.removeClass(Affix.RESET).addClass('affix' + (affix ? '-' + affix : ''))
|
|
||||||
|
|
||||||
if (affix == 'bottom') {
|
|
||||||
this.$element.offset({ top: document.body.offsetHeight - offsetBottom - this.$element.height() })
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// AFFIX PLUGIN DEFINITION
|
|
||||||
// =======================
|
|
||||||
|
|
||||||
var old = $.fn.affix
|
|
||||||
|
|
||||||
$.fn.affix = function (option) {
|
|
||||||
return this.each(function () {
|
|
||||||
var $this = $(this)
|
|
||||||
var data = $this.data('bs.affix')
|
|
||||||
var options = typeof option == 'object' && option
|
|
||||||
|
|
||||||
if (!data) $this.data('bs.affix', (data = new Affix(this, options)))
|
|
||||||
if (typeof option == 'string') data[option]()
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
$.fn.affix.Constructor = Affix
|
|
||||||
|
|
||||||
|
|
||||||
// AFFIX NO CONFLICT
|
|
||||||
// =================
|
|
||||||
|
|
||||||
$.fn.affix.noConflict = function () {
|
|
||||||
$.fn.affix = old
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// AFFIX DATA-API
|
|
||||||
// ==============
|
|
||||||
|
|
||||||
$(window).on('load', function () {
|
|
||||||
$('[data-spy="affix"]').each(function () {
|
|
||||||
var $spy = $(this)
|
|
||||||
var data = $spy.data()
|
|
||||||
|
|
||||||
data.offset = data.offset || {}
|
|
||||||
|
|
||||||
if (data.offsetBottom) data.offset.bottom = data.offsetBottom
|
|
||||||
if (data.offsetTop) data.offset.top = data.offsetTop
|
|
||||||
|
|
||||||
$spy.affix(data)
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
}(jQuery);
|
|
98
vendor/scripts/bootstrap/alert.js
vendored
98
vendor/scripts/bootstrap/alert.js
vendored
|
@ -1,98 +0,0 @@
|
||||||
/* ========================================================================
|
|
||||||
* Bootstrap: alert.js v3.0.3
|
|
||||||
* http://getbootstrap.com/javascript/#alerts
|
|
||||||
* ========================================================================
|
|
||||||
* Copyright 2013 Twitter, Inc.
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
* ======================================================================== */
|
|
||||||
|
|
||||||
|
|
||||||
+function ($) { "use strict";
|
|
||||||
|
|
||||||
// ALERT CLASS DEFINITION
|
|
||||||
// ======================
|
|
||||||
|
|
||||||
var dismiss = '[data-dismiss="alert"]'
|
|
||||||
var Alert = function (el) {
|
|
||||||
$(el).on('click', dismiss, this.close)
|
|
||||||
}
|
|
||||||
|
|
||||||
Alert.prototype.close = function (e) {
|
|
||||||
var $this = $(this)
|
|
||||||
var selector = $this.attr('data-target')
|
|
||||||
|
|
||||||
if (!selector) {
|
|
||||||
selector = $this.attr('href')
|
|
||||||
selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') // strip for ie7
|
|
||||||
}
|
|
||||||
|
|
||||||
var $parent = $(selector)
|
|
||||||
|
|
||||||
if (e) e.preventDefault()
|
|
||||||
|
|
||||||
if (!$parent.length) {
|
|
||||||
$parent = $this.hasClass('alert') ? $this : $this.parent()
|
|
||||||
}
|
|
||||||
|
|
||||||
$parent.trigger(e = $.Event('close.bs.alert'))
|
|
||||||
|
|
||||||
if (e.isDefaultPrevented()) return
|
|
||||||
|
|
||||||
$parent.removeClass('in')
|
|
||||||
|
|
||||||
function removeElement() {
|
|
||||||
$parent.trigger('closed.bs.alert').remove()
|
|
||||||
}
|
|
||||||
|
|
||||||
$.support.transition && $parent.hasClass('fade') ?
|
|
||||||
$parent
|
|
||||||
.one($.support.transition.end, removeElement)
|
|
||||||
.emulateTransitionEnd(150) :
|
|
||||||
removeElement()
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// ALERT PLUGIN DEFINITION
|
|
||||||
// =======================
|
|
||||||
|
|
||||||
var old = $.fn.alert
|
|
||||||
|
|
||||||
$.fn.alert = function (option) {
|
|
||||||
return this.each(function () {
|
|
||||||
var $this = $(this)
|
|
||||||
var data = $this.data('bs.alert')
|
|
||||||
|
|
||||||
if (!data) $this.data('bs.alert', (data = new Alert(this)))
|
|
||||||
if (typeof option == 'string') data[option].call($this)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
$.fn.alert.Constructor = Alert
|
|
||||||
|
|
||||||
|
|
||||||
// ALERT NO CONFLICT
|
|
||||||
// =================
|
|
||||||
|
|
||||||
$.fn.alert.noConflict = function () {
|
|
||||||
$.fn.alert = old
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// ALERT DATA-API
|
|
||||||
// ==============
|
|
||||||
|
|
||||||
$(document).on('click.bs.alert.data-api', dismiss, Alert.prototype.close)
|
|
||||||
|
|
||||||
}(jQuery);
|
|
12
vendor/scripts/bootstrap/bootstrap.js
vendored
12
vendor/scripts/bootstrap/bootstrap.js
vendored
|
@ -1,12 +0,0 @@
|
||||||
//= require affix
|
|
||||||
//= require alert
|
|
||||||
//= require button
|
|
||||||
//= require carousel
|
|
||||||
//= require collapse
|
|
||||||
//= require dropdown
|
|
||||||
//= require tab
|
|
||||||
//= require transition
|
|
||||||
//= require scrollspy
|
|
||||||
//= require modal
|
|
||||||
//= require tooltip
|
|
||||||
//= require popover
|
|
115
vendor/scripts/bootstrap/button.js
vendored
115
vendor/scripts/bootstrap/button.js
vendored
|
@ -1,115 +0,0 @@
|
||||||
/* ========================================================================
|
|
||||||
* Bootstrap: button.js v3.0.3
|
|
||||||
* http://getbootstrap.com/javascript/#buttons
|
|
||||||
* ========================================================================
|
|
||||||
* Copyright 2013 Twitter, Inc.
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
* ======================================================================== */
|
|
||||||
|
|
||||||
|
|
||||||
+function ($) { "use strict";
|
|
||||||
|
|
||||||
// BUTTON PUBLIC CLASS DEFINITION
|
|
||||||
// ==============================
|
|
||||||
|
|
||||||
var Button = function (element, options) {
|
|
||||||
this.$element = $(element)
|
|
||||||
this.options = $.extend({}, Button.DEFAULTS, options)
|
|
||||||
}
|
|
||||||
|
|
||||||
Button.DEFAULTS = {
|
|
||||||
loadingText: 'loading...'
|
|
||||||
}
|
|
||||||
|
|
||||||
Button.prototype.setState = function (state) {
|
|
||||||
var d = 'disabled'
|
|
||||||
var $el = this.$element
|
|
||||||
var val = $el.is('input') ? 'val' : 'html'
|
|
||||||
var data = $el.data()
|
|
||||||
|
|
||||||
state = state + 'Text'
|
|
||||||
|
|
||||||
if (!data.resetText) $el.data('resetText', $el[val]())
|
|
||||||
|
|
||||||
$el[val](data[state] || this.options[state])
|
|
||||||
|
|
||||||
// push to event loop to allow forms to submit
|
|
||||||
setTimeout(function () {
|
|
||||||
state == 'loadingText' ?
|
|
||||||
$el.addClass(d).attr(d, d) :
|
|
||||||
$el.removeClass(d).removeAttr(d);
|
|
||||||
}, 0)
|
|
||||||
}
|
|
||||||
|
|
||||||
Button.prototype.toggle = function () {
|
|
||||||
var $parent = this.$element.closest('[data-toggle="buttons"]')
|
|
||||||
var changed = true
|
|
||||||
|
|
||||||
if ($parent.length) {
|
|
||||||
var $input = this.$element.find('input')
|
|
||||||
if ($input.prop('type') === 'radio') {
|
|
||||||
// see if clicking on current one
|
|
||||||
if ($input.prop('checked') && this.$element.hasClass('active'))
|
|
||||||
changed = false
|
|
||||||
else
|
|
||||||
$parent.find('.active').removeClass('active')
|
|
||||||
}
|
|
||||||
if (changed) $input.prop('checked', !this.$element.hasClass('active')).trigger('change')
|
|
||||||
}
|
|
||||||
|
|
||||||
if (changed) this.$element.toggleClass('active')
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// BUTTON PLUGIN DEFINITION
|
|
||||||
// ========================
|
|
||||||
|
|
||||||
var old = $.fn.button
|
|
||||||
|
|
||||||
$.fn.button = function (option) {
|
|
||||||
return this.each(function () {
|
|
||||||
var $this = $(this)
|
|
||||||
var data = $this.data('bs.button')
|
|
||||||
var options = typeof option == 'object' && option
|
|
||||||
|
|
||||||
if (!data) $this.data('bs.button', (data = new Button(this, options)))
|
|
||||||
|
|
||||||
if (option == 'toggle') data.toggle()
|
|
||||||
else if (option) data.setState(option)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
$.fn.button.Constructor = Button
|
|
||||||
|
|
||||||
|
|
||||||
// BUTTON NO CONFLICT
|
|
||||||
// ==================
|
|
||||||
|
|
||||||
$.fn.button.noConflict = function () {
|
|
||||||
$.fn.button = old
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// BUTTON DATA-API
|
|
||||||
// ===============
|
|
||||||
|
|
||||||
$(document).on('click.bs.button.data-api', '[data-toggle^=button]', function (e) {
|
|
||||||
var $btn = $(e.target)
|
|
||||||
if (!$btn.hasClass('btn')) $btn = $btn.closest('.btn')
|
|
||||||
$btn.button('toggle')
|
|
||||||
e.preventDefault()
|
|
||||||
})
|
|
||||||
|
|
||||||
}(jQuery);
|
|
217
vendor/scripts/bootstrap/carousel.js
vendored
217
vendor/scripts/bootstrap/carousel.js
vendored
|
@ -1,217 +0,0 @@
|
||||||
/* ========================================================================
|
|
||||||
* Bootstrap: carousel.js v3.0.3
|
|
||||||
* http://getbootstrap.com/javascript/#carousel
|
|
||||||
* ========================================================================
|
|
||||||
* Copyright 2013 Twitter, Inc.
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
* ======================================================================== */
|
|
||||||
|
|
||||||
|
|
||||||
+function ($) { "use strict";
|
|
||||||
|
|
||||||
// CAROUSEL CLASS DEFINITION
|
|
||||||
// =========================
|
|
||||||
|
|
||||||
var Carousel = function (element, options) {
|
|
||||||
this.$element = $(element)
|
|
||||||
this.$indicators = this.$element.find('.carousel-indicators')
|
|
||||||
this.options = options
|
|
||||||
this.paused =
|
|
||||||
this.sliding =
|
|
||||||
this.interval =
|
|
||||||
this.$active =
|
|
||||||
this.$items = null
|
|
||||||
|
|
||||||
this.options.pause == 'hover' && this.$element
|
|
||||||
.on('mouseenter', $.proxy(this.pause, this))
|
|
||||||
.on('mouseleave', $.proxy(this.cycle, this))
|
|
||||||
}
|
|
||||||
|
|
||||||
Carousel.DEFAULTS = {
|
|
||||||
interval: 5000
|
|
||||||
, pause: 'hover'
|
|
||||||
, wrap: true
|
|
||||||
}
|
|
||||||
|
|
||||||
Carousel.prototype.cycle = function (e) {
|
|
||||||
e || (this.paused = false)
|
|
||||||
|
|
||||||
this.interval && clearInterval(this.interval)
|
|
||||||
|
|
||||||
this.options.interval
|
|
||||||
&& !this.paused
|
|
||||||
&& (this.interval = setInterval($.proxy(this.next, this), this.options.interval))
|
|
||||||
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
Carousel.prototype.getActiveIndex = function () {
|
|
||||||
this.$active = this.$element.find('.item.active')
|
|
||||||
this.$items = this.$active.parent().children()
|
|
||||||
|
|
||||||
return this.$items.index(this.$active)
|
|
||||||
}
|
|
||||||
|
|
||||||
Carousel.prototype.to = function (pos) {
|
|
||||||
var that = this
|
|
||||||
var activeIndex = this.getActiveIndex()
|
|
||||||
|
|
||||||
if (pos > (this.$items.length - 1) || pos < 0) return
|
|
||||||
|
|
||||||
if (this.sliding) return this.$element.one('slid.bs.carousel', function () { that.to(pos) })
|
|
||||||
if (activeIndex == pos) return this.pause().cycle()
|
|
||||||
|
|
||||||
return this.slide(pos > activeIndex ? 'next' : 'prev', $(this.$items[pos]))
|
|
||||||
}
|
|
||||||
|
|
||||||
Carousel.prototype.pause = function (e) {
|
|
||||||
e || (this.paused = true)
|
|
||||||
|
|
||||||
if (this.$element.find('.next, .prev').length && $.support.transition.end) {
|
|
||||||
this.$element.trigger($.support.transition.end)
|
|
||||||
this.cycle(true)
|
|
||||||
}
|
|
||||||
|
|
||||||
this.interval = clearInterval(this.interval)
|
|
||||||
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
Carousel.prototype.next = function () {
|
|
||||||
if (this.sliding) return
|
|
||||||
return this.slide('next')
|
|
||||||
}
|
|
||||||
|
|
||||||
Carousel.prototype.prev = function () {
|
|
||||||
if (this.sliding) return
|
|
||||||
return this.slide('prev')
|
|
||||||
}
|
|
||||||
|
|
||||||
Carousel.prototype.slide = function (type, next) {
|
|
||||||
var $active = this.$element.find('.item.active')
|
|
||||||
var $next = next || $active[type]()
|
|
||||||
var isCycling = this.interval
|
|
||||||
var direction = type == 'next' ? 'left' : 'right'
|
|
||||||
var fallback = type == 'next' ? 'first' : 'last'
|
|
||||||
var that = this
|
|
||||||
|
|
||||||
if (!$next.length) {
|
|
||||||
if (!this.options.wrap) return
|
|
||||||
$next = this.$element.find('.item')[fallback]()
|
|
||||||
}
|
|
||||||
|
|
||||||
this.sliding = true
|
|
||||||
|
|
||||||
isCycling && this.pause()
|
|
||||||
|
|
||||||
var e = $.Event('slide.bs.carousel', { relatedTarget: $next[0], direction: direction })
|
|
||||||
|
|
||||||
if ($next.hasClass('active')) return
|
|
||||||
|
|
||||||
if (this.$indicators.length) {
|
|
||||||
this.$indicators.find('.active').removeClass('active')
|
|
||||||
this.$element.one('slid.bs.carousel', function () {
|
|
||||||
var $nextIndicator = $(that.$indicators.children()[that.getActiveIndex()])
|
|
||||||
$nextIndicator && $nextIndicator.addClass('active')
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($.support.transition && this.$element.hasClass('slide')) {
|
|
||||||
this.$element.trigger(e)
|
|
||||||
if (e.isDefaultPrevented()) return
|
|
||||||
$next.addClass(type)
|
|
||||||
$next[0].offsetWidth // force reflow
|
|
||||||
$active.addClass(direction)
|
|
||||||
$next.addClass(direction)
|
|
||||||
$active
|
|
||||||
.one($.support.transition.end, function () {
|
|
||||||
$next.removeClass([type, direction].join(' ')).addClass('active')
|
|
||||||
$active.removeClass(['active', direction].join(' '))
|
|
||||||
that.sliding = false
|
|
||||||
setTimeout(function () { that.$element.trigger('slid.bs.carousel') }, 0)
|
|
||||||
})
|
|
||||||
.emulateTransitionEnd(600)
|
|
||||||
} else {
|
|
||||||
this.$element.trigger(e)
|
|
||||||
if (e.isDefaultPrevented()) return
|
|
||||||
$active.removeClass('active')
|
|
||||||
$next.addClass('active')
|
|
||||||
this.sliding = false
|
|
||||||
this.$element.trigger('slid.bs.carousel')
|
|
||||||
}
|
|
||||||
|
|
||||||
isCycling && this.cycle()
|
|
||||||
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// CAROUSEL PLUGIN DEFINITION
|
|
||||||
// ==========================
|
|
||||||
|
|
||||||
var old = $.fn.carousel
|
|
||||||
|
|
||||||
$.fn.carousel = function (option) {
|
|
||||||
return this.each(function () {
|
|
||||||
var $this = $(this)
|
|
||||||
var data = $this.data('bs.carousel')
|
|
||||||
var options = $.extend({}, Carousel.DEFAULTS, $this.data(), typeof option == 'object' && option)
|
|
||||||
var action = typeof option == 'string' ? option : options.slide
|
|
||||||
|
|
||||||
if (!data) $this.data('bs.carousel', (data = new Carousel(this, options)))
|
|
||||||
if (typeof option == 'number') data.to(option)
|
|
||||||
else if (action) data[action]()
|
|
||||||
else if (options.interval) data.pause().cycle()
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
$.fn.carousel.Constructor = Carousel
|
|
||||||
|
|
||||||
|
|
||||||
// CAROUSEL NO CONFLICT
|
|
||||||
// ====================
|
|
||||||
|
|
||||||
$.fn.carousel.noConflict = function () {
|
|
||||||
$.fn.carousel = old
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// CAROUSEL DATA-API
|
|
||||||
// =================
|
|
||||||
|
|
||||||
$(document).on('click.bs.carousel.data-api', '[data-slide], [data-slide-to]', function (e) {
|
|
||||||
var $this = $(this), href
|
|
||||||
var $target = $($this.attr('data-target') || (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
|
|
||||||
var options = $.extend({}, $target.data(), $this.data())
|
|
||||||
var slideIndex = $this.attr('data-slide-to')
|
|
||||||
if (slideIndex) options.interval = false
|
|
||||||
|
|
||||||
$target.carousel(options)
|
|
||||||
|
|
||||||
if (slideIndex = $this.attr('data-slide-to')) {
|
|
||||||
$target.data('bs.carousel').to(slideIndex)
|
|
||||||
}
|
|
||||||
|
|
||||||
e.preventDefault()
|
|
||||||
})
|
|
||||||
|
|
||||||
$(window).on('load', function () {
|
|
||||||
$('[data-ride="carousel"]').each(function () {
|
|
||||||
var $carousel = $(this)
|
|
||||||
$carousel.carousel($carousel.data())
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
}(jQuery);
|
|
179
vendor/scripts/bootstrap/collapse.js
vendored
179
vendor/scripts/bootstrap/collapse.js
vendored
|
@ -1,179 +0,0 @@
|
||||||
/* ========================================================================
|
|
||||||
* Bootstrap: collapse.js v3.0.3
|
|
||||||
* http://getbootstrap.com/javascript/#collapse
|
|
||||||
* ========================================================================
|
|
||||||
* Copyright 2013 Twitter, Inc.
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
* ======================================================================== */
|
|
||||||
|
|
||||||
|
|
||||||
+function ($) { "use strict";
|
|
||||||
|
|
||||||
// COLLAPSE PUBLIC CLASS DEFINITION
|
|
||||||
// ================================
|
|
||||||
|
|
||||||
var Collapse = function (element, options) {
|
|
||||||
this.$element = $(element)
|
|
||||||
this.options = $.extend({}, Collapse.DEFAULTS, options)
|
|
||||||
this.transitioning = null
|
|
||||||
|
|
||||||
if (this.options.parent) this.$parent = $(this.options.parent)
|
|
||||||
if (this.options.toggle) this.toggle()
|
|
||||||
}
|
|
||||||
|
|
||||||
Collapse.DEFAULTS = {
|
|
||||||
toggle: true
|
|
||||||
}
|
|
||||||
|
|
||||||
Collapse.prototype.dimension = function () {
|
|
||||||
var hasWidth = this.$element.hasClass('width')
|
|
||||||
return hasWidth ? 'width' : 'height'
|
|
||||||
}
|
|
||||||
|
|
||||||
Collapse.prototype.show = function () {
|
|
||||||
if (this.transitioning || this.$element.hasClass('in')) return
|
|
||||||
|
|
||||||
var startEvent = $.Event('show.bs.collapse')
|
|
||||||
this.$element.trigger(startEvent)
|
|
||||||
if (startEvent.isDefaultPrevented()) return
|
|
||||||
|
|
||||||
var actives = this.$parent && this.$parent.find('> .panel > .in')
|
|
||||||
|
|
||||||
if (actives && actives.length) {
|
|
||||||
var hasData = actives.data('bs.collapse')
|
|
||||||
if (hasData && hasData.transitioning) return
|
|
||||||
actives.collapse('hide')
|
|
||||||
hasData || actives.data('bs.collapse', null)
|
|
||||||
}
|
|
||||||
|
|
||||||
var dimension = this.dimension()
|
|
||||||
|
|
||||||
this.$element
|
|
||||||
.removeClass('collapse')
|
|
||||||
.addClass('collapsing')
|
|
||||||
[dimension](0)
|
|
||||||
|
|
||||||
this.transitioning = 1
|
|
||||||
|
|
||||||
var complete = function () {
|
|
||||||
this.$element
|
|
||||||
.removeClass('collapsing')
|
|
||||||
.addClass('in')
|
|
||||||
[dimension]('auto')
|
|
||||||
this.transitioning = 0
|
|
||||||
this.$element.trigger('shown.bs.collapse')
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!$.support.transition) return complete.call(this)
|
|
||||||
|
|
||||||
var scrollSize = $.camelCase(['scroll', dimension].join('-'))
|
|
||||||
|
|
||||||
this.$element
|
|
||||||
.one($.support.transition.end, $.proxy(complete, this))
|
|
||||||
.emulateTransitionEnd(350)
|
|
||||||
[dimension](this.$element[0][scrollSize])
|
|
||||||
}
|
|
||||||
|
|
||||||
Collapse.prototype.hide = function () {
|
|
||||||
if (this.transitioning || !this.$element.hasClass('in')) return
|
|
||||||
|
|
||||||
var startEvent = $.Event('hide.bs.collapse')
|
|
||||||
this.$element.trigger(startEvent)
|
|
||||||
if (startEvent.isDefaultPrevented()) return
|
|
||||||
|
|
||||||
var dimension = this.dimension()
|
|
||||||
|
|
||||||
this.$element
|
|
||||||
[dimension](this.$element[dimension]())
|
|
||||||
[0].offsetHeight
|
|
||||||
|
|
||||||
this.$element
|
|
||||||
.addClass('collapsing')
|
|
||||||
.removeClass('collapse')
|
|
||||||
.removeClass('in')
|
|
||||||
|
|
||||||
this.transitioning = 1
|
|
||||||
|
|
||||||
var complete = function () {
|
|
||||||
this.transitioning = 0
|
|
||||||
this.$element
|
|
||||||
.trigger('hidden.bs.collapse')
|
|
||||||
.removeClass('collapsing')
|
|
||||||
.addClass('collapse')
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!$.support.transition) return complete.call(this)
|
|
||||||
|
|
||||||
this.$element
|
|
||||||
[dimension](0)
|
|
||||||
.one($.support.transition.end, $.proxy(complete, this))
|
|
||||||
.emulateTransitionEnd(350)
|
|
||||||
}
|
|
||||||
|
|
||||||
Collapse.prototype.toggle = function () {
|
|
||||||
this[this.$element.hasClass('in') ? 'hide' : 'show']()
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// COLLAPSE PLUGIN DEFINITION
|
|
||||||
// ==========================
|
|
||||||
|
|
||||||
var old = $.fn.collapse
|
|
||||||
|
|
||||||
$.fn.collapse = function (option) {
|
|
||||||
return this.each(function () {
|
|
||||||
var $this = $(this)
|
|
||||||
var data = $this.data('bs.collapse')
|
|
||||||
var options = $.extend({}, Collapse.DEFAULTS, $this.data(), typeof option == 'object' && option)
|
|
||||||
|
|
||||||
if (!data) $this.data('bs.collapse', (data = new Collapse(this, options)))
|
|
||||||
if (typeof option == 'string') data[option]()
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
$.fn.collapse.Constructor = Collapse
|
|
||||||
|
|
||||||
|
|
||||||
// COLLAPSE NO CONFLICT
|
|
||||||
// ====================
|
|
||||||
|
|
||||||
$.fn.collapse.noConflict = function () {
|
|
||||||
$.fn.collapse = old
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// COLLAPSE DATA-API
|
|
||||||
// =================
|
|
||||||
|
|
||||||
$(document).on('click.bs.collapse.data-api', '[data-toggle=collapse]', function (e) {
|
|
||||||
var $this = $(this), href
|
|
||||||
var target = $this.attr('data-target')
|
|
||||||
|| e.preventDefault()
|
|
||||||
|| (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '') //strip for ie7
|
|
||||||
var $target = $(target)
|
|
||||||
var data = $target.data('bs.collapse')
|
|
||||||
var option = data ? 'toggle' : $this.data()
|
|
||||||
var parent = $this.attr('data-parent')
|
|
||||||
var $parent = parent && $(parent)
|
|
||||||
|
|
||||||
if (!data || !data.transitioning) {
|
|
||||||
if ($parent) $parent.find('[data-toggle=collapse][data-parent="' + parent + '"]').not($this).addClass('collapsed')
|
|
||||||
$this[$target.hasClass('in') ? 'addClass' : 'removeClass']('collapsed')
|
|
||||||
}
|
|
||||||
|
|
||||||
$target.collapse(option)
|
|
||||||
})
|
|
||||||
|
|
||||||
}(jQuery);
|
|
154
vendor/scripts/bootstrap/dropdown.js
vendored
154
vendor/scripts/bootstrap/dropdown.js
vendored
|
@ -1,154 +0,0 @@
|
||||||
/* ========================================================================
|
|
||||||
* Bootstrap: dropdown.js v3.0.3
|
|
||||||
* http://getbootstrap.com/javascript/#dropdowns
|
|
||||||
* ========================================================================
|
|
||||||
* Copyright 2013 Twitter, Inc.
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
* ======================================================================== */
|
|
||||||
|
|
||||||
|
|
||||||
+function ($) { "use strict";
|
|
||||||
|
|
||||||
// DROPDOWN CLASS DEFINITION
|
|
||||||
// =========================
|
|
||||||
|
|
||||||
var backdrop = '.dropdown-backdrop'
|
|
||||||
var toggle = '[data-toggle=dropdown]'
|
|
||||||
var Dropdown = function (element) {
|
|
||||||
$(element).on('click.bs.dropdown', this.toggle)
|
|
||||||
}
|
|
||||||
|
|
||||||
Dropdown.prototype.toggle = function (e) {
|
|
||||||
var $this = $(this)
|
|
||||||
|
|
||||||
if ($this.is('.disabled, :disabled')) return
|
|
||||||
|
|
||||||
var $parent = getParent($this)
|
|
||||||
var isActive = $parent.hasClass('open')
|
|
||||||
|
|
||||||
clearMenus()
|
|
||||||
|
|
||||||
if (!isActive) {
|
|
||||||
if ('ontouchstart' in document.documentElement && !$parent.closest('.navbar-nav').length) {
|
|
||||||
// if mobile we use a backdrop because click events don't delegate
|
|
||||||
$('<div class="dropdown-backdrop"/>').insertAfter($(this)).on('click', clearMenus)
|
|
||||||
}
|
|
||||||
|
|
||||||
$parent.trigger(e = $.Event('show.bs.dropdown'))
|
|
||||||
|
|
||||||
if (e.isDefaultPrevented()) return
|
|
||||||
|
|
||||||
$parent
|
|
||||||
.toggleClass('open')
|
|
||||||
.trigger('shown.bs.dropdown')
|
|
||||||
|
|
||||||
$this.focus()
|
|
||||||
}
|
|
||||||
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
Dropdown.prototype.keydown = function (e) {
|
|
||||||
if (!/(38|40|27)/.test(e.keyCode)) return
|
|
||||||
|
|
||||||
var $this = $(this)
|
|
||||||
|
|
||||||
e.preventDefault()
|
|
||||||
e.stopPropagation()
|
|
||||||
|
|
||||||
if ($this.is('.disabled, :disabled')) return
|
|
||||||
|
|
||||||
var $parent = getParent($this)
|
|
||||||
var isActive = $parent.hasClass('open')
|
|
||||||
|
|
||||||
if (!isActive || (isActive && e.keyCode == 27)) {
|
|
||||||
if (e.which == 27) $parent.find(toggle).focus()
|
|
||||||
return $this.click()
|
|
||||||
}
|
|
||||||
|
|
||||||
var $items = $('[role=menu] li:not(.divider):visible a', $parent)
|
|
||||||
|
|
||||||
if (!$items.length) return
|
|
||||||
|
|
||||||
var index = $items.index($items.filter(':focus'))
|
|
||||||
|
|
||||||
if (e.keyCode == 38 && index > 0) index-- // up
|
|
||||||
if (e.keyCode == 40 && index < $items.length - 1) index++ // down
|
|
||||||
if (!~index) index=0
|
|
||||||
|
|
||||||
$items.eq(index).focus()
|
|
||||||
}
|
|
||||||
|
|
||||||
function clearMenus() {
|
|
||||||
$(backdrop).remove()
|
|
||||||
$(toggle).each(function (e) {
|
|
||||||
var $parent = getParent($(this))
|
|
||||||
if (!$parent.hasClass('open')) return
|
|
||||||
$parent.trigger(e = $.Event('hide.bs.dropdown'))
|
|
||||||
if (e.isDefaultPrevented()) return
|
|
||||||
$parent.removeClass('open').trigger('hidden.bs.dropdown')
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
function getParent($this) {
|
|
||||||
var selector = $this.attr('data-target')
|
|
||||||
|
|
||||||
if (!selector) {
|
|
||||||
selector = $this.attr('href')
|
|
||||||
selector = selector && /#/.test(selector) && selector.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
|
|
||||||
}
|
|
||||||
|
|
||||||
var $parent = selector && $(selector)
|
|
||||||
|
|
||||||
return $parent && $parent.length ? $parent : $this.parent()
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// DROPDOWN PLUGIN DEFINITION
|
|
||||||
// ==========================
|
|
||||||
|
|
||||||
var old = $.fn.dropdown
|
|
||||||
|
|
||||||
$.fn.dropdown = function (option) {
|
|
||||||
return this.each(function () {
|
|
||||||
var $this = $(this)
|
|
||||||
var data = $this.data('bs.dropdown')
|
|
||||||
|
|
||||||
if (!data) $this.data('bs.dropdown', (data = new Dropdown(this)))
|
|
||||||
if (typeof option == 'string') data[option].call($this)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
$.fn.dropdown.Constructor = Dropdown
|
|
||||||
|
|
||||||
|
|
||||||
// DROPDOWN NO CONFLICT
|
|
||||||
// ====================
|
|
||||||
|
|
||||||
$.fn.dropdown.noConflict = function () {
|
|
||||||
$.fn.dropdown = old
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// APPLY TO STANDARD DROPDOWN ELEMENTS
|
|
||||||
// ===================================
|
|
||||||
|
|
||||||
$(document)
|
|
||||||
.on('click.bs.dropdown.data-api', clearMenus)
|
|
||||||
.on('click.bs.dropdown.data-api', '.dropdown form', function (e) { e.stopPropagation() })
|
|
||||||
.on('click.bs.dropdown.data-api' , toggle, Dropdown.prototype.toggle)
|
|
||||||
.on('keydown.bs.dropdown.data-api', toggle + ', [role=menu]' , Dropdown.prototype.keydown)
|
|
||||||
|
|
||||||
}(jQuery);
|
|
246
vendor/scripts/bootstrap/modal.js
vendored
246
vendor/scripts/bootstrap/modal.js
vendored
|
@ -1,246 +0,0 @@
|
||||||
/* ========================================================================
|
|
||||||
* Bootstrap: modal.js v3.0.3
|
|
||||||
* http://getbootstrap.com/javascript/#modals
|
|
||||||
* ========================================================================
|
|
||||||
* Copyright 2013 Twitter, Inc.
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
* ======================================================================== */
|
|
||||||
|
|
||||||
|
|
||||||
+function ($) { "use strict";
|
|
||||||
|
|
||||||
// MODAL CLASS DEFINITION
|
|
||||||
// ======================
|
|
||||||
|
|
||||||
var Modal = function (element, options) {
|
|
||||||
this.options = options
|
|
||||||
this.$element = $(element)
|
|
||||||
this.$backdrop =
|
|
||||||
this.isShown = null
|
|
||||||
|
|
||||||
if (this.options.remote) this.$element.load(this.options.remote)
|
|
||||||
}
|
|
||||||
|
|
||||||
Modal.DEFAULTS = {
|
|
||||||
backdrop: true
|
|
||||||
, keyboard: true
|
|
||||||
, show: true
|
|
||||||
}
|
|
||||||
|
|
||||||
Modal.prototype.toggle = function (_relatedTarget) {
|
|
||||||
return this[!this.isShown ? 'show' : 'hide'](_relatedTarget)
|
|
||||||
}
|
|
||||||
|
|
||||||
Modal.prototype.show = function (_relatedTarget) {
|
|
||||||
var that = this
|
|
||||||
var e = $.Event('show.bs.modal', { relatedTarget: _relatedTarget })
|
|
||||||
|
|
||||||
this.$element.trigger(e)
|
|
||||||
|
|
||||||
if (this.isShown || e.isDefaultPrevented()) return
|
|
||||||
|
|
||||||
this.isShown = true
|
|
||||||
|
|
||||||
this.escape()
|
|
||||||
|
|
||||||
this.$element.on('click.dismiss.modal', '[data-dismiss="modal"]', $.proxy(this.hide, this))
|
|
||||||
|
|
||||||
this.backdrop(function () {
|
|
||||||
var transition = $.support.transition && that.$element.hasClass('fade')
|
|
||||||
|
|
||||||
if (!that.$element.parent().length) {
|
|
||||||
that.$element.appendTo(document.body) // don't move modals dom position
|
|
||||||
}
|
|
||||||
|
|
||||||
that.$element.show()
|
|
||||||
|
|
||||||
if (transition) {
|
|
||||||
that.$element[0].offsetWidth // force reflow
|
|
||||||
}
|
|
||||||
|
|
||||||
that.$element
|
|
||||||
.addClass('in')
|
|
||||||
.attr('aria-hidden', false)
|
|
||||||
|
|
||||||
that.enforceFocus()
|
|
||||||
|
|
||||||
var e = $.Event('shown.bs.modal', { relatedTarget: _relatedTarget })
|
|
||||||
|
|
||||||
transition ?
|
|
||||||
that.$element.find('.modal-dialog') // wait for modal to slide in
|
|
||||||
.one($.support.transition.end, function () {
|
|
||||||
that.$element.focus().trigger(e)
|
|
||||||
})
|
|
||||||
.emulateTransitionEnd(300) :
|
|
||||||
that.$element.focus().trigger(e)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
Modal.prototype.hide = function (e) {
|
|
||||||
if (e) e.preventDefault()
|
|
||||||
|
|
||||||
e = $.Event('hide.bs.modal')
|
|
||||||
|
|
||||||
this.$element.trigger(e)
|
|
||||||
|
|
||||||
if (!this.isShown || e.isDefaultPrevented()) return
|
|
||||||
|
|
||||||
this.isShown = false
|
|
||||||
|
|
||||||
this.escape()
|
|
||||||
|
|
||||||
$(document).off('focusin.bs.modal')
|
|
||||||
|
|
||||||
this.$element
|
|
||||||
.removeClass('in')
|
|
||||||
.attr('aria-hidden', true)
|
|
||||||
.off('click.dismiss.modal')
|
|
||||||
|
|
||||||
$.support.transition && this.$element.hasClass('fade') ?
|
|
||||||
this.$element
|
|
||||||
.one($.support.transition.end, $.proxy(this.hideModal, this))
|
|
||||||
.emulateTransitionEnd(300) :
|
|
||||||
this.hideModal()
|
|
||||||
}
|
|
||||||
|
|
||||||
Modal.prototype.enforceFocus = function () {
|
|
||||||
$(document)
|
|
||||||
.off('focusin.bs.modal') // guard against infinite focus loop
|
|
||||||
.on('focusin.bs.modal', $.proxy(function (e) {
|
|
||||||
if (this.$element[0] !== e.target && !this.$element.has(e.target).length) {
|
|
||||||
this.$element.focus()
|
|
||||||
}
|
|
||||||
}, this))
|
|
||||||
}
|
|
||||||
|
|
||||||
Modal.prototype.escape = function () {
|
|
||||||
if (this.isShown && this.options.keyboard) {
|
|
||||||
this.$element.on('keyup.dismiss.bs.modal', $.proxy(function (e) {
|
|
||||||
e.which == 27 && this.hide()
|
|
||||||
}, this))
|
|
||||||
} else if (!this.isShown) {
|
|
||||||
this.$element.off('keyup.dismiss.bs.modal')
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Modal.prototype.hideModal = function () {
|
|
||||||
var that = this
|
|
||||||
this.$element.hide()
|
|
||||||
this.backdrop(function () {
|
|
||||||
that.removeBackdrop()
|
|
||||||
that.$element.trigger('hidden.bs.modal')
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
Modal.prototype.removeBackdrop = function () {
|
|
||||||
this.$backdrop && this.$backdrop.remove()
|
|
||||||
this.$backdrop = null
|
|
||||||
}
|
|
||||||
|
|
||||||
Modal.prototype.backdrop = function (callback) {
|
|
||||||
var that = this
|
|
||||||
var animate = this.$element.hasClass('fade') ? 'fade' : ''
|
|
||||||
|
|
||||||
if (this.isShown && this.options.backdrop) {
|
|
||||||
var doAnimate = $.support.transition && animate
|
|
||||||
|
|
||||||
this.$backdrop = $('<div class="modal-backdrop ' + animate + '" />')
|
|
||||||
.appendTo(document.body)
|
|
||||||
|
|
||||||
this.$element.on('click.dismiss.modal', $.proxy(function (e) {
|
|
||||||
if (e.target !== e.currentTarget) return
|
|
||||||
this.options.backdrop == 'static'
|
|
||||||
? this.$element[0].focus.call(this.$element[0])
|
|
||||||
: this.hide.call(this)
|
|
||||||
}, this))
|
|
||||||
|
|
||||||
if (doAnimate) this.$backdrop[0].offsetWidth // force reflow
|
|
||||||
|
|
||||||
this.$backdrop.addClass('in')
|
|
||||||
|
|
||||||
if (!callback) return
|
|
||||||
|
|
||||||
doAnimate ?
|
|
||||||
this.$backdrop
|
|
||||||
.one($.support.transition.end, callback)
|
|
||||||
.emulateTransitionEnd(150) :
|
|
||||||
callback()
|
|
||||||
|
|
||||||
} else if (!this.isShown && this.$backdrop) {
|
|
||||||
this.$backdrop.removeClass('in')
|
|
||||||
|
|
||||||
$.support.transition && this.$element.hasClass('fade')?
|
|
||||||
this.$backdrop
|
|
||||||
.one($.support.transition.end, callback)
|
|
||||||
.emulateTransitionEnd(150) :
|
|
||||||
callback()
|
|
||||||
|
|
||||||
} else if (callback) {
|
|
||||||
callback()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// MODAL PLUGIN DEFINITION
|
|
||||||
// =======================
|
|
||||||
|
|
||||||
var old = $.fn.modal
|
|
||||||
|
|
||||||
$.fn.modal = function (option, _relatedTarget) {
|
|
||||||
return this.each(function () {
|
|
||||||
var $this = $(this)
|
|
||||||
var data = $this.data('bs.modal')
|
|
||||||
var options = $.extend({}, Modal.DEFAULTS, $this.data(), typeof option == 'object' && option)
|
|
||||||
|
|
||||||
if (!data) $this.data('bs.modal', (data = new Modal(this, options)))
|
|
||||||
if (typeof option == 'string') data[option](_relatedTarget)
|
|
||||||
else if (options.show) data.show(_relatedTarget)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
$.fn.modal.Constructor = Modal
|
|
||||||
|
|
||||||
|
|
||||||
// MODAL NO CONFLICT
|
|
||||||
// =================
|
|
||||||
|
|
||||||
$.fn.modal.noConflict = function () {
|
|
||||||
$.fn.modal = old
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// MODAL DATA-API
|
|
||||||
// ==============
|
|
||||||
|
|
||||||
$(document).on('click.bs.modal.data-api', '[data-toggle="modal"]', function (e) {
|
|
||||||
var $this = $(this)
|
|
||||||
var href = $this.attr('href')
|
|
||||||
var $target = $($this.attr('data-target') || (href && href.replace(/.*(?=#[^\s]+$)/, ''))) //strip for ie7
|
|
||||||
var option = $target.data('modal') ? 'toggle' : $.extend({ remote: !/#/.test(href) && href }, $target.data(), $this.data())
|
|
||||||
|
|
||||||
e.preventDefault()
|
|
||||||
|
|
||||||
$target
|
|
||||||
.modal(option, this)
|
|
||||||
.one('hide', function () {
|
|
||||||
$this.is(':visible') && $this.focus()
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
$(document)
|
|
||||||
.on('show.bs.modal', '.modal', function () { $(document.body).addClass('modal-open') })
|
|
||||||
.on('hidden.bs.modal', '.modal', function () { $(document.body).removeClass('modal-open') })
|
|
||||||
|
|
||||||
}(jQuery);
|
|
117
vendor/scripts/bootstrap/popover.js
vendored
117
vendor/scripts/bootstrap/popover.js
vendored
|
@ -1,117 +0,0 @@
|
||||||
/* ========================================================================
|
|
||||||
* Bootstrap: popover.js v3.0.3
|
|
||||||
* http://getbootstrap.com/javascript/#popovers
|
|
||||||
* ========================================================================
|
|
||||||
* Copyright 2013 Twitter, Inc.
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
* ======================================================================== */
|
|
||||||
|
|
||||||
|
|
||||||
+function ($) { "use strict";
|
|
||||||
|
|
||||||
// POPOVER PUBLIC CLASS DEFINITION
|
|
||||||
// ===============================
|
|
||||||
|
|
||||||
var Popover = function (element, options) {
|
|
||||||
this.init('popover', element, options)
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!$.fn.tooltip) throw new Error('Popover requires tooltip.js')
|
|
||||||
|
|
||||||
Popover.DEFAULTS = $.extend({} , $.fn.tooltip.Constructor.DEFAULTS, {
|
|
||||||
placement: 'right'
|
|
||||||
, trigger: 'click'
|
|
||||||
, content: ''
|
|
||||||
, template: '<div class="popover"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'
|
|
||||||
})
|
|
||||||
|
|
||||||
|
|
||||||
// NOTE: POPOVER EXTENDS tooltip.js
|
|
||||||
// ================================
|
|
||||||
|
|
||||||
Popover.prototype = $.extend({}, $.fn.tooltip.Constructor.prototype)
|
|
||||||
|
|
||||||
Popover.prototype.constructor = Popover
|
|
||||||
|
|
||||||
Popover.prototype.getDefaults = function () {
|
|
||||||
return Popover.DEFAULTS
|
|
||||||
}
|
|
||||||
|
|
||||||
Popover.prototype.setContent = function () {
|
|
||||||
var $tip = this.tip()
|
|
||||||
var title = this.getTitle()
|
|
||||||
var content = this.getContent()
|
|
||||||
|
|
||||||
$tip.find('.popover-title')[this.options.html ? 'html' : 'text'](title)
|
|
||||||
$tip.find('.popover-content')[this.options.html ? 'html' : 'text'](content)
|
|
||||||
|
|
||||||
$tip.removeClass('fade top bottom left right in')
|
|
||||||
|
|
||||||
// IE8 doesn't accept hiding via the `:empty` pseudo selector, we have to do
|
|
||||||
// this manually by checking the contents.
|
|
||||||
if (!$tip.find('.popover-title').html()) $tip.find('.popover-title').hide()
|
|
||||||
}
|
|
||||||
|
|
||||||
Popover.prototype.hasContent = function () {
|
|
||||||
return this.getTitle() || this.getContent()
|
|
||||||
}
|
|
||||||
|
|
||||||
Popover.prototype.getContent = function () {
|
|
||||||
var $e = this.$element
|
|
||||||
var o = this.options
|
|
||||||
|
|
||||||
return $e.attr('data-content')
|
|
||||||
|| (typeof o.content == 'function' ?
|
|
||||||
o.content.call($e[0]) :
|
|
||||||
o.content)
|
|
||||||
}
|
|
||||||
|
|
||||||
Popover.prototype.arrow = function () {
|
|
||||||
return this.$arrow = this.$arrow || this.tip().find('.arrow')
|
|
||||||
}
|
|
||||||
|
|
||||||
Popover.prototype.tip = function () {
|
|
||||||
if (!this.$tip) this.$tip = $(this.options.template)
|
|
||||||
return this.$tip
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// POPOVER PLUGIN DEFINITION
|
|
||||||
// =========================
|
|
||||||
|
|
||||||
var old = $.fn.popover
|
|
||||||
|
|
||||||
$.fn.popover = function (option) {
|
|
||||||
return this.each(function () {
|
|
||||||
var $this = $(this)
|
|
||||||
var data = $this.data('bs.popover')
|
|
||||||
var options = typeof option == 'object' && option
|
|
||||||
|
|
||||||
if (!data) $this.data('bs.popover', (data = new Popover(this, options)))
|
|
||||||
if (typeof option == 'string') data[option]()
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
$.fn.popover.Constructor = Popover
|
|
||||||
|
|
||||||
|
|
||||||
// POPOVER NO CONFLICT
|
|
||||||
// ===================
|
|
||||||
|
|
||||||
$.fn.popover.noConflict = function () {
|
|
||||||
$.fn.popover = old
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
}(jQuery);
|
|
158
vendor/scripts/bootstrap/scrollspy.js
vendored
158
vendor/scripts/bootstrap/scrollspy.js
vendored
|
@ -1,158 +0,0 @@
|
||||||
/* ========================================================================
|
|
||||||
* Bootstrap: scrollspy.js v3.0.3
|
|
||||||
* http://getbootstrap.com/javascript/#scrollspy
|
|
||||||
* ========================================================================
|
|
||||||
* Copyright 2013 Twitter, Inc.
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
* ======================================================================== */
|
|
||||||
|
|
||||||
|
|
||||||
+function ($) { "use strict";
|
|
||||||
|
|
||||||
// SCROLLSPY CLASS DEFINITION
|
|
||||||
// ==========================
|
|
||||||
|
|
||||||
function ScrollSpy(element, options) {
|
|
||||||
var href
|
|
||||||
var process = $.proxy(this.process, this)
|
|
||||||
|
|
||||||
this.$element = $(element).is('body') ? $(window) : $(element)
|
|
||||||
this.$body = $('body')
|
|
||||||
this.$scrollElement = this.$element.on('scroll.bs.scroll-spy.data-api', process)
|
|
||||||
this.options = $.extend({}, ScrollSpy.DEFAULTS, options)
|
|
||||||
this.selector = (this.options.target
|
|
||||||
|| ((href = $(element).attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
|
|
||||||
|| '') + ' .nav li > a'
|
|
||||||
this.offsets = $([])
|
|
||||||
this.targets = $([])
|
|
||||||
this.activeTarget = null
|
|
||||||
|
|
||||||
this.refresh()
|
|
||||||
this.process()
|
|
||||||
}
|
|
||||||
|
|
||||||
ScrollSpy.DEFAULTS = {
|
|
||||||
offset: 10
|
|
||||||
}
|
|
||||||
|
|
||||||
ScrollSpy.prototype.refresh = function () {
|
|
||||||
var offsetMethod = this.$element[0] == window ? 'offset' : 'position'
|
|
||||||
|
|
||||||
this.offsets = $([])
|
|
||||||
this.targets = $([])
|
|
||||||
|
|
||||||
var self = this
|
|
||||||
var $targets = this.$body
|
|
||||||
.find(this.selector)
|
|
||||||
.map(function () {
|
|
||||||
var $el = $(this)
|
|
||||||
var href = $el.data('target') || $el.attr('href')
|
|
||||||
var $href = /^#\w/.test(href) && $(href)
|
|
||||||
|
|
||||||
return ($href
|
|
||||||
&& $href.length
|
|
||||||
&& [[ $href[offsetMethod]().top + (!$.isWindow(self.$scrollElement.get(0)) && self.$scrollElement.scrollTop()), href ]]) || null
|
|
||||||
})
|
|
||||||
.sort(function (a, b) { return a[0] - b[0] })
|
|
||||||
.each(function () {
|
|
||||||
self.offsets.push(this[0])
|
|
||||||
self.targets.push(this[1])
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
ScrollSpy.prototype.process = function () {
|
|
||||||
var scrollTop = this.$scrollElement.scrollTop() + this.options.offset
|
|
||||||
var scrollHeight = this.$scrollElement[0].scrollHeight || this.$body[0].scrollHeight
|
|
||||||
var maxScroll = scrollHeight - this.$scrollElement.height()
|
|
||||||
var offsets = this.offsets
|
|
||||||
var targets = this.targets
|
|
||||||
var activeTarget = this.activeTarget
|
|
||||||
var i
|
|
||||||
|
|
||||||
if (scrollTop >= maxScroll) {
|
|
||||||
return activeTarget != (i = targets.last()[0]) && this.activate(i)
|
|
||||||
}
|
|
||||||
|
|
||||||
for (i = offsets.length; i--;) {
|
|
||||||
activeTarget != targets[i]
|
|
||||||
&& scrollTop >= offsets[i]
|
|
||||||
&& (!offsets[i + 1] || scrollTop <= offsets[i + 1])
|
|
||||||
&& this.activate( targets[i] )
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
ScrollSpy.prototype.activate = function (target) {
|
|
||||||
this.activeTarget = target
|
|
||||||
|
|
||||||
$(this.selector)
|
|
||||||
.parents('.active')
|
|
||||||
.removeClass('active')
|
|
||||||
|
|
||||||
var selector = this.selector
|
|
||||||
+ '[data-target="' + target + '"],'
|
|
||||||
+ this.selector + '[href="' + target + '"]'
|
|
||||||
|
|
||||||
var active = $(selector)
|
|
||||||
.parents('li')
|
|
||||||
.addClass('active')
|
|
||||||
|
|
||||||
if (active.parent('.dropdown-menu').length) {
|
|
||||||
active = active
|
|
||||||
.closest('li.dropdown')
|
|
||||||
.addClass('active')
|
|
||||||
}
|
|
||||||
|
|
||||||
active.trigger('activate.bs.scrollspy')
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// SCROLLSPY PLUGIN DEFINITION
|
|
||||||
// ===========================
|
|
||||||
|
|
||||||
var old = $.fn.scrollspy
|
|
||||||
|
|
||||||
$.fn.scrollspy = function (option) {
|
|
||||||
return this.each(function () {
|
|
||||||
var $this = $(this)
|
|
||||||
var data = $this.data('bs.scrollspy')
|
|
||||||
var options = typeof option == 'object' && option
|
|
||||||
|
|
||||||
if (!data) $this.data('bs.scrollspy', (data = new ScrollSpy(this, options)))
|
|
||||||
if (typeof option == 'string') data[option]()
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
$.fn.scrollspy.Constructor = ScrollSpy
|
|
||||||
|
|
||||||
|
|
||||||
// SCROLLSPY NO CONFLICT
|
|
||||||
// =====================
|
|
||||||
|
|
||||||
$.fn.scrollspy.noConflict = function () {
|
|
||||||
$.fn.scrollspy = old
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// SCROLLSPY DATA-API
|
|
||||||
// ==================
|
|
||||||
|
|
||||||
$(window).on('load', function () {
|
|
||||||
$('[data-spy="scroll"]').each(function () {
|
|
||||||
var $spy = $(this)
|
|
||||||
$spy.scrollspy($spy.data())
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
}(jQuery);
|
|
135
vendor/scripts/bootstrap/tab.js
vendored
135
vendor/scripts/bootstrap/tab.js
vendored
|
@ -1,135 +0,0 @@
|
||||||
/* ========================================================================
|
|
||||||
* Bootstrap: tab.js v3.0.3
|
|
||||||
* http://getbootstrap.com/javascript/#tabs
|
|
||||||
* ========================================================================
|
|
||||||
* Copyright 2013 Twitter, Inc.
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
* ======================================================================== */
|
|
||||||
|
|
||||||
|
|
||||||
+function ($) { "use strict";
|
|
||||||
|
|
||||||
// TAB CLASS DEFINITION
|
|
||||||
// ====================
|
|
||||||
|
|
||||||
var Tab = function (element) {
|
|
||||||
this.element = $(element)
|
|
||||||
}
|
|
||||||
|
|
||||||
Tab.prototype.show = function () {
|
|
||||||
var $this = this.element
|
|
||||||
var $ul = $this.closest('ul:not(.dropdown-menu)')
|
|
||||||
var selector = $this.data('target')
|
|
||||||
|
|
||||||
if (!selector) {
|
|
||||||
selector = $this.attr('href')
|
|
||||||
selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($this.parent('li').hasClass('active')) return
|
|
||||||
|
|
||||||
var previous = $ul.find('.active:last a')[0]
|
|
||||||
var e = $.Event('show.bs.tab', {
|
|
||||||
relatedTarget: previous
|
|
||||||
})
|
|
||||||
|
|
||||||
$this.trigger(e)
|
|
||||||
|
|
||||||
if (e.isDefaultPrevented()) return
|
|
||||||
|
|
||||||
var $target = $(selector)
|
|
||||||
|
|
||||||
this.activate($this.parent('li'), $ul)
|
|
||||||
this.activate($target, $target.parent(), function () {
|
|
||||||
$this.trigger({
|
|
||||||
type: 'shown.bs.tab'
|
|
||||||
, relatedTarget: previous
|
|
||||||
})
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
Tab.prototype.activate = function (element, container, callback) {
|
|
||||||
var $active = container.find('> .active')
|
|
||||||
var transition = callback
|
|
||||||
&& $.support.transition
|
|
||||||
&& $active.hasClass('fade')
|
|
||||||
|
|
||||||
function next() {
|
|
||||||
$active
|
|
||||||
.removeClass('active')
|
|
||||||
.find('> .dropdown-menu > .active')
|
|
||||||
.removeClass('active')
|
|
||||||
|
|
||||||
element.addClass('active')
|
|
||||||
|
|
||||||
if (transition) {
|
|
||||||
element[0].offsetWidth // reflow for transition
|
|
||||||
element.addClass('in')
|
|
||||||
} else {
|
|
||||||
element.removeClass('fade')
|
|
||||||
}
|
|
||||||
|
|
||||||
if (element.parent('.dropdown-menu')) {
|
|
||||||
element.closest('li.dropdown').addClass('active')
|
|
||||||
}
|
|
||||||
|
|
||||||
callback && callback()
|
|
||||||
}
|
|
||||||
|
|
||||||
transition ?
|
|
||||||
$active
|
|
||||||
.one($.support.transition.end, next)
|
|
||||||
.emulateTransitionEnd(150) :
|
|
||||||
next()
|
|
||||||
|
|
||||||
$active.removeClass('in')
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// TAB PLUGIN DEFINITION
|
|
||||||
// =====================
|
|
||||||
|
|
||||||
var old = $.fn.tab
|
|
||||||
|
|
||||||
$.fn.tab = function ( option ) {
|
|
||||||
return this.each(function () {
|
|
||||||
var $this = $(this)
|
|
||||||
var data = $this.data('bs.tab')
|
|
||||||
|
|
||||||
if (!data) $this.data('bs.tab', (data = new Tab(this)))
|
|
||||||
if (typeof option == 'string') data[option]()
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
$.fn.tab.Constructor = Tab
|
|
||||||
|
|
||||||
|
|
||||||
// TAB NO CONFLICT
|
|
||||||
// ===============
|
|
||||||
|
|
||||||
$.fn.tab.noConflict = function () {
|
|
||||||
$.fn.tab = old
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// TAB DATA-API
|
|
||||||
// ============
|
|
||||||
|
|
||||||
$(document).on('click.bs.tab.data-api', '[data-toggle="tab"], [data-toggle="pill"]', function (e) {
|
|
||||||
e.preventDefault()
|
|
||||||
$(this).tab('show')
|
|
||||||
})
|
|
||||||
|
|
||||||
}(jQuery);
|
|
386
vendor/scripts/bootstrap/tooltip.js
vendored
386
vendor/scripts/bootstrap/tooltip.js
vendored
|
@ -1,386 +0,0 @@
|
||||||
/* ========================================================================
|
|
||||||
* Bootstrap: tooltip.js v3.0.3
|
|
||||||
* http://getbootstrap.com/javascript/#tooltip
|
|
||||||
* Inspired by the original jQuery.tipsy by Jason Frame
|
|
||||||
* ========================================================================
|
|
||||||
* Copyright 2013 Twitter, Inc.
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
* ======================================================================== */
|
|
||||||
|
|
||||||
|
|
||||||
+function ($) { "use strict";
|
|
||||||
|
|
||||||
// TOOLTIP PUBLIC CLASS DEFINITION
|
|
||||||
// ===============================
|
|
||||||
|
|
||||||
var Tooltip = function (element, options) {
|
|
||||||
this.type =
|
|
||||||
this.options =
|
|
||||||
this.enabled =
|
|
||||||
this.timeout =
|
|
||||||
this.hoverState =
|
|
||||||
this.$element = null
|
|
||||||
|
|
||||||
this.init('tooltip', element, options)
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.DEFAULTS = {
|
|
||||||
animation: true
|
|
||||||
, placement: 'top'
|
|
||||||
, selector: false
|
|
||||||
, template: '<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>'
|
|
||||||
, trigger: 'hover focus'
|
|
||||||
, title: ''
|
|
||||||
, delay: 0
|
|
||||||
, html: false
|
|
||||||
, container: false
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.init = function (type, element, options) {
|
|
||||||
this.enabled = true
|
|
||||||
this.type = type
|
|
||||||
this.$element = $(element)
|
|
||||||
this.options = this.getOptions(options)
|
|
||||||
|
|
||||||
var triggers = this.options.trigger.split(' ')
|
|
||||||
|
|
||||||
for (var i = triggers.length; i--;) {
|
|
||||||
var trigger = triggers[i]
|
|
||||||
|
|
||||||
if (trigger == 'click') {
|
|
||||||
this.$element.on('click.' + this.type, this.options.selector, $.proxy(this.toggle, this))
|
|
||||||
} else if (trigger != 'manual') {
|
|
||||||
var eventIn = trigger == 'hover' ? 'mouseenter' : 'focus'
|
|
||||||
var eventOut = trigger == 'hover' ? 'mouseleave' : 'blur'
|
|
||||||
|
|
||||||
this.$element.on(eventIn + '.' + this.type, this.options.selector, $.proxy(this.enter, this))
|
|
||||||
this.$element.on(eventOut + '.' + this.type, this.options.selector, $.proxy(this.leave, this))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
this.options.selector ?
|
|
||||||
(this._options = $.extend({}, this.options, { trigger: 'manual', selector: '' })) :
|
|
||||||
this.fixTitle()
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.getDefaults = function () {
|
|
||||||
return Tooltip.DEFAULTS
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.getOptions = function (options) {
|
|
||||||
options = $.extend({}, this.getDefaults(), this.$element.data(), options)
|
|
||||||
|
|
||||||
if (options.delay && typeof options.delay == 'number') {
|
|
||||||
options.delay = {
|
|
||||||
show: options.delay
|
|
||||||
, hide: options.delay
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return options
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.getDelegateOptions = function () {
|
|
||||||
var options = {}
|
|
||||||
var defaults = this.getDefaults()
|
|
||||||
|
|
||||||
this._options && $.each(this._options, function (key, value) {
|
|
||||||
if (defaults[key] != value) options[key] = value
|
|
||||||
})
|
|
||||||
|
|
||||||
return options
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.enter = function (obj) {
|
|
||||||
var self = obj instanceof this.constructor ?
|
|
||||||
obj : $(obj.currentTarget)[this.type](this.getDelegateOptions()).data('bs.' + this.type)
|
|
||||||
|
|
||||||
clearTimeout(self.timeout)
|
|
||||||
|
|
||||||
self.hoverState = 'in'
|
|
||||||
|
|
||||||
if (!self.options.delay || !self.options.delay.show) return self.show()
|
|
||||||
|
|
||||||
self.timeout = setTimeout(function () {
|
|
||||||
if (self.hoverState == 'in') self.show()
|
|
||||||
}, self.options.delay.show)
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.leave = function (obj) {
|
|
||||||
var self = obj instanceof this.constructor ?
|
|
||||||
obj : $(obj.currentTarget)[this.type](this.getDelegateOptions()).data('bs.' + this.type)
|
|
||||||
|
|
||||||
clearTimeout(self.timeout)
|
|
||||||
|
|
||||||
self.hoverState = 'out'
|
|
||||||
|
|
||||||
if (!self.options.delay || !self.options.delay.hide) return self.hide()
|
|
||||||
|
|
||||||
self.timeout = setTimeout(function () {
|
|
||||||
if (self.hoverState == 'out') self.hide()
|
|
||||||
}, self.options.delay.hide)
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.show = function () {
|
|
||||||
var e = $.Event('show.bs.'+ this.type)
|
|
||||||
|
|
||||||
if (this.hasContent() && this.enabled) {
|
|
||||||
this.$element.trigger(e)
|
|
||||||
|
|
||||||
if (e.isDefaultPrevented()) return
|
|
||||||
|
|
||||||
var $tip = this.tip()
|
|
||||||
|
|
||||||
this.setContent()
|
|
||||||
|
|
||||||
if (this.options.animation) $tip.addClass('fade')
|
|
||||||
|
|
||||||
var placement = typeof this.options.placement == 'function' ?
|
|
||||||
this.options.placement.call(this, $tip[0], this.$element[0]) :
|
|
||||||
this.options.placement
|
|
||||||
|
|
||||||
var autoToken = /\s?auto?\s?/i
|
|
||||||
var autoPlace = autoToken.test(placement)
|
|
||||||
if (autoPlace) placement = placement.replace(autoToken, '') || 'top'
|
|
||||||
|
|
||||||
$tip
|
|
||||||
.detach()
|
|
||||||
.css({ top: 0, left: 0, display: 'block' })
|
|
||||||
.addClass(placement)
|
|
||||||
|
|
||||||
this.options.container ? $tip.appendTo(this.options.container) : $tip.insertAfter(this.$element)
|
|
||||||
|
|
||||||
var pos = this.getPosition()
|
|
||||||
var actualWidth = $tip[0].offsetWidth
|
|
||||||
var actualHeight = $tip[0].offsetHeight
|
|
||||||
|
|
||||||
if (autoPlace) {
|
|
||||||
var $parent = this.$element.parent()
|
|
||||||
|
|
||||||
var orgPlacement = placement
|
|
||||||
var docScroll = document.documentElement.scrollTop || document.body.scrollTop
|
|
||||||
var parentWidth = this.options.container == 'body' ? window.innerWidth : $parent.outerWidth()
|
|
||||||
var parentHeight = this.options.container == 'body' ? window.innerHeight : $parent.outerHeight()
|
|
||||||
var parentLeft = this.options.container == 'body' ? 0 : $parent.offset().left
|
|
||||||
|
|
||||||
placement = placement == 'bottom' && pos.top + pos.height + actualHeight - docScroll > parentHeight ? 'top' :
|
|
||||||
placement == 'top' && pos.top - docScroll - actualHeight < 0 ? 'bottom' :
|
|
||||||
placement == 'right' && pos.right + actualWidth > parentWidth ? 'left' :
|
|
||||||
placement == 'left' && pos.left - actualWidth < parentLeft ? 'right' :
|
|
||||||
placement
|
|
||||||
|
|
||||||
$tip
|
|
||||||
.removeClass(orgPlacement)
|
|
||||||
.addClass(placement)
|
|
||||||
}
|
|
||||||
|
|
||||||
var calculatedOffset = this.getCalculatedOffset(placement, pos, actualWidth, actualHeight)
|
|
||||||
|
|
||||||
this.applyPlacement(calculatedOffset, placement)
|
|
||||||
this.$element.trigger('shown.bs.' + this.type)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.applyPlacement = function(offset, placement) {
|
|
||||||
var replace
|
|
||||||
var $tip = this.tip()
|
|
||||||
var width = $tip[0].offsetWidth
|
|
||||||
var height = $tip[0].offsetHeight
|
|
||||||
|
|
||||||
// manually read margins because getBoundingClientRect includes difference
|
|
||||||
var marginTop = parseInt($tip.css('margin-top'), 10)
|
|
||||||
var marginLeft = parseInt($tip.css('margin-left'), 10)
|
|
||||||
|
|
||||||
// we must check for NaN for ie 8/9
|
|
||||||
if (isNaN(marginTop)) marginTop = 0
|
|
||||||
if (isNaN(marginLeft)) marginLeft = 0
|
|
||||||
|
|
||||||
offset.top = offset.top + marginTop
|
|
||||||
offset.left = offset.left + marginLeft
|
|
||||||
|
|
||||||
$tip
|
|
||||||
.offset(offset)
|
|
||||||
.addClass('in')
|
|
||||||
|
|
||||||
// check to see if placing tip in new offset caused the tip to resize itself
|
|
||||||
var actualWidth = $tip[0].offsetWidth
|
|
||||||
var actualHeight = $tip[0].offsetHeight
|
|
||||||
|
|
||||||
if (placement == 'top' && actualHeight != height) {
|
|
||||||
replace = true
|
|
||||||
offset.top = offset.top + height - actualHeight
|
|
||||||
}
|
|
||||||
|
|
||||||
if (/bottom|top/.test(placement)) {
|
|
||||||
var delta = 0
|
|
||||||
|
|
||||||
if (offset.left < 0) {
|
|
||||||
delta = offset.left * -2
|
|
||||||
offset.left = 0
|
|
||||||
|
|
||||||
$tip.offset(offset)
|
|
||||||
|
|
||||||
actualWidth = $tip[0].offsetWidth
|
|
||||||
actualHeight = $tip[0].offsetHeight
|
|
||||||
}
|
|
||||||
|
|
||||||
this.replaceArrow(delta - width + actualWidth, actualWidth, 'left')
|
|
||||||
} else {
|
|
||||||
this.replaceArrow(actualHeight - height, actualHeight, 'top')
|
|
||||||
}
|
|
||||||
|
|
||||||
if (replace) $tip.offset(offset)
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.replaceArrow = function(delta, dimension, position) {
|
|
||||||
this.arrow().css(position, delta ? (50 * (1 - delta / dimension) + "%") : '')
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.setContent = function () {
|
|
||||||
var $tip = this.tip()
|
|
||||||
var title = this.getTitle()
|
|
||||||
|
|
||||||
$tip.find('.tooltip-inner')[this.options.html ? 'html' : 'text'](title)
|
|
||||||
$tip.removeClass('fade in top bottom left right')
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.hide = function () {
|
|
||||||
var that = this
|
|
||||||
var $tip = this.tip()
|
|
||||||
var e = $.Event('hide.bs.' + this.type)
|
|
||||||
|
|
||||||
function complete() {
|
|
||||||
if (that.hoverState != 'in') $tip.detach()
|
|
||||||
}
|
|
||||||
|
|
||||||
this.$element.trigger(e)
|
|
||||||
|
|
||||||
if (e.isDefaultPrevented()) return
|
|
||||||
|
|
||||||
$tip.removeClass('in')
|
|
||||||
|
|
||||||
$.support.transition && this.$tip.hasClass('fade') ?
|
|
||||||
$tip
|
|
||||||
.one($.support.transition.end, complete)
|
|
||||||
.emulateTransitionEnd(150) :
|
|
||||||
complete()
|
|
||||||
|
|
||||||
this.$element.trigger('hidden.bs.' + this.type)
|
|
||||||
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.fixTitle = function () {
|
|
||||||
var $e = this.$element
|
|
||||||
if ($e.attr('title') || typeof($e.attr('data-original-title')) != 'string') {
|
|
||||||
$e.attr('data-original-title', $e.attr('title') || '').attr('title', '')
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.hasContent = function () {
|
|
||||||
return this.getTitle()
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.getPosition = function () {
|
|
||||||
var el = this.$element[0]
|
|
||||||
return $.extend({}, (typeof el.getBoundingClientRect == 'function') ? el.getBoundingClientRect() : {
|
|
||||||
width: el.offsetWidth
|
|
||||||
, height: el.offsetHeight
|
|
||||||
}, this.$element.offset())
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.getCalculatedOffset = function (placement, pos, actualWidth, actualHeight) {
|
|
||||||
return placement == 'bottom' ? { top: pos.top + pos.height, left: pos.left + pos.width / 2 - actualWidth / 2 } :
|
|
||||||
placement == 'top' ? { top: pos.top - actualHeight, left: pos.left + pos.width / 2 - actualWidth / 2 } :
|
|
||||||
placement == 'left' ? { top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left - actualWidth } :
|
|
||||||
/* placement == 'right' */ { top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left + pos.width }
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.getTitle = function () {
|
|
||||||
var title
|
|
||||||
var $e = this.$element
|
|
||||||
var o = this.options
|
|
||||||
|
|
||||||
title = $e.attr('data-original-title')
|
|
||||||
|| (typeof o.title == 'function' ? o.title.call($e[0]) : o.title)
|
|
||||||
|
|
||||||
return title
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.tip = function () {
|
|
||||||
return this.$tip = this.$tip || $(this.options.template)
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.arrow = function () {
|
|
||||||
return this.$arrow = this.$arrow || this.tip().find('.tooltip-arrow')
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.validate = function () {
|
|
||||||
if (!this.$element[0].parentNode) {
|
|
||||||
this.hide()
|
|
||||||
this.$element = null
|
|
||||||
this.options = null
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.enable = function () {
|
|
||||||
this.enabled = true
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.disable = function () {
|
|
||||||
this.enabled = false
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.toggleEnabled = function () {
|
|
||||||
this.enabled = !this.enabled
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.toggle = function (e) {
|
|
||||||
var self = e ? $(e.currentTarget)[this.type](this.getDelegateOptions()).data('bs.' + this.type) : this
|
|
||||||
self.tip().hasClass('in') ? self.leave(self) : self.enter(self)
|
|
||||||
}
|
|
||||||
|
|
||||||
Tooltip.prototype.destroy = function () {
|
|
||||||
this.hide().$element.off('.' + this.type).removeData('bs.' + this.type)
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// TOOLTIP PLUGIN DEFINITION
|
|
||||||
// =========================
|
|
||||||
|
|
||||||
var old = $.fn.tooltip
|
|
||||||
|
|
||||||
$.fn.tooltip = function (option) {
|
|
||||||
return this.each(function () {
|
|
||||||
var $this = $(this)
|
|
||||||
var data = $this.data('bs.tooltip')
|
|
||||||
var options = typeof option == 'object' && option
|
|
||||||
|
|
||||||
if (!data) $this.data('bs.tooltip', (data = new Tooltip(this, options)))
|
|
||||||
if (typeof option == 'string') data[option]()
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
$.fn.tooltip.Constructor = Tooltip
|
|
||||||
|
|
||||||
|
|
||||||
// TOOLTIP NO CONFLICT
|
|
||||||
// ===================
|
|
||||||
|
|
||||||
$.fn.tooltip.noConflict = function () {
|
|
||||||
$.fn.tooltip = old
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
}(jQuery);
|
|
56
vendor/scripts/bootstrap/transition.js
vendored
56
vendor/scripts/bootstrap/transition.js
vendored
|
@ -1,56 +0,0 @@
|
||||||
/* ========================================================================
|
|
||||||
* Bootstrap: transition.js v3.0.3
|
|
||||||
* http://getbootstrap.com/javascript/#transitions
|
|
||||||
* ========================================================================
|
|
||||||
* Copyright 2013 Twitter, Inc.
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
* ======================================================================== */
|
|
||||||
|
|
||||||
|
|
||||||
+function ($) { "use strict";
|
|
||||||
|
|
||||||
// CSS TRANSITION SUPPORT (Shoutout: http://www.modernizr.com/)
|
|
||||||
// ============================================================
|
|
||||||
|
|
||||||
function transitionEnd() {
|
|
||||||
var el = document.createElement('bootstrap')
|
|
||||||
|
|
||||||
var transEndEventNames = {
|
|
||||||
'WebkitTransition' : 'webkitTransitionEnd'
|
|
||||||
, 'MozTransition' : 'transitionend'
|
|
||||||
, 'OTransition' : 'oTransitionEnd otransitionend'
|
|
||||||
, 'transition' : 'transitionend'
|
|
||||||
}
|
|
||||||
|
|
||||||
for (var name in transEndEventNames) {
|
|
||||||
if (el.style[name] !== undefined) {
|
|
||||||
return { end: transEndEventNames[name] }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// http://blog.alexmaccaw.com/css-transitions
|
|
||||||
$.fn.emulateTransitionEnd = function (duration) {
|
|
||||||
var called = false, $el = this
|
|
||||||
$(this).one($.support.transition.end, function () { called = true })
|
|
||||||
var callback = function () { if (!called) $($el).trigger($.support.transition.end) }
|
|
||||||
setTimeout(callback, duration)
|
|
||||||
return this
|
|
||||||
}
|
|
||||||
|
|
||||||
$(function () {
|
|
||||||
$.support.transition = transitionEnd()
|
|
||||||
})
|
|
||||||
|
|
||||||
}(jQuery);
|
|
3430
vendor/scripts/treema.js
vendored
3430
vendor/scripts/treema.js
vendored
File diff suppressed because it is too large
Load diff
299
vendor/styles/treema.css
vendored
299
vendor/styles/treema.css
vendored
|
@ -1,299 +0,0 @@
|
||||||
@media -sass-debug-info{filename{}line{font-family:\000033}}
|
|
||||||
.treema-node {
|
|
||||||
user-select: none;
|
|
||||||
-webkit-user-select: none;
|
|
||||||
-moz-user-select: none;
|
|
||||||
position: relative;
|
|
||||||
font-family: Helvetica;
|
|
||||||
clear: both;
|
|
||||||
border-bottom: 1px solid #cccccc;
|
|
||||||
font-size: 13px;
|
|
||||||
cursor: pointer; }
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000315}}
|
|
||||||
.treema-node.treema-root > .treema-row .treema-value {
|
|
||||||
display: none; }
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000318}}
|
|
||||||
.treema-node.treema-open > .treema-children {
|
|
||||||
padding-top: 1px; }
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000321}}
|
|
||||||
.treema-node.treema-root {
|
|
||||||
outline: none; }
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000325}}
|
|
||||||
.treema-node input, .treema-node select {
|
|
||||||
font-size: 13px;
|
|
||||||
font-family: Helvetica; }
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000328}}
|
|
||||||
.treema-node input {
|
|
||||||
margin: -3px 0;
|
|
||||||
width: 200px; }
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000331}}
|
|
||||||
.treema-node select {
|
|
||||||
height: inherit;
|
|
||||||
margin: 0;
|
|
||||||
width: inherit; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000336}}
|
|
||||||
.treema-type-select-container, .treema-schema-select-container {
|
|
||||||
display: block;
|
|
||||||
position: relative;
|
|
||||||
margin-right: 5px;
|
|
||||||
top: 1px;
|
|
||||||
float: left; }
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000343}}
|
|
||||||
.treema-type-select-container select, .treema-schema-select-container select {
|
|
||||||
position: absolute;
|
|
||||||
left: 0;
|
|
||||||
right: 0;
|
|
||||||
top: 0;
|
|
||||||
bottom: 0;
|
|
||||||
opacity: 0.01;
|
|
||||||
width: inherit !important; }
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000354}}
|
|
||||||
.treema-type-select-container button, .treema-schema-select-container button {
|
|
||||||
font-size: 10px;
|
|
||||||
padding: 0 3px;
|
|
||||||
width: 19px; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000359}}
|
|
||||||
.treema-children {
|
|
||||||
margin-left: 15px;
|
|
||||||
clear: both; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000363}}
|
|
||||||
.treema-add-child {
|
|
||||||
background-color: #eeeeff;
|
|
||||||
border: 1px solid #aaaaff;
|
|
||||||
cursor: pointer;
|
|
||||||
display: inline-block;
|
|
||||||
margin: 3px 0 10px;
|
|
||||||
padding: 0px 5px;
|
|
||||||
font-weight: bold;
|
|
||||||
position: relative;
|
|
||||||
left: -10px; }
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000374}}
|
|
||||||
.treema-add-child:hover {
|
|
||||||
background-color: #ccccff; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000377}}
|
|
||||||
.treema-full > .treema-children > .treema-add-child {
|
|
||||||
display: none; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000380}}
|
|
||||||
.treema-full.treema-open > .treema-children {
|
|
||||||
margin-bottom: 5px; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000383}}
|
|
||||||
.treema-row {
|
|
||||||
padding: 2px 3px 2px 3px; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000386}}
|
|
||||||
.treema-value {
|
|
||||||
cursor: text;
|
|
||||||
display: block;
|
|
||||||
float: left;
|
|
||||||
max-width: 100%; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000392}}
|
|
||||||
.treema-key {
|
|
||||||
color: #5353ac;
|
|
||||||
float: left;
|
|
||||||
display: block;
|
|
||||||
cursor: pointer;
|
|
||||||
margin-right: 5px; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000399}}
|
|
||||||
.treema-backdrop {
|
|
||||||
position: absolute;
|
|
||||||
top: 0;
|
|
||||||
left: 0;
|
|
||||||
height: 25px;
|
|
||||||
background-color: rgba(64, 128, 255, 0);
|
|
||||||
pointer-events: none;
|
|
||||||
width: 100%;
|
|
||||||
cursor: pointer; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\00003109}}
|
|
||||||
.treema-description {
|
|
||||||
float: right;
|
|
||||||
opacity: 0.8;
|
|
||||||
font-size: 11px;
|
|
||||||
line-height: 13px;
|
|
||||||
min-width: 200px;
|
|
||||||
text-align: right;
|
|
||||||
display: none; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\00003118}}
|
|
||||||
.treema-selected > .treema-row > .treema-description {
|
|
||||||
display: inline; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\00003121}}
|
|
||||||
.treema-edit + .treema-description {
|
|
||||||
display: inline; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\00003124}}
|
|
||||||
.treema-selected > .treema-row {
|
|
||||||
background-color: rgba(64, 128, 255, 0.25); }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\00003129}}
|
|
||||||
.treema-error {
|
|
||||||
float: right;
|
|
||||||
color: darkred;
|
|
||||||
margin: 2px 10px; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\00003134}}
|
|
||||||
.treema-has-error {
|
|
||||||
background-color: lightpink;
|
|
||||||
border: 1px solid darkred; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\00003138}}
|
|
||||||
.treema-temp-error {
|
|
||||||
background-color: lightpink;
|
|
||||||
padding: 2px 3px;
|
|
||||||
color: darkred;
|
|
||||||
margin: 0 5px;
|
|
||||||
border: 1px solid darkred; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\00003148}}
|
|
||||||
.treema-toggle-hit-area {
|
|
||||||
cursor: pointer;
|
|
||||||
width: 15px;
|
|
||||||
float: left;
|
|
||||||
position: absolute;
|
|
||||||
left: -15px;
|
|
||||||
top: 0;
|
|
||||||
bottom: 0; }
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\00003157}}
|
|
||||||
.treema-toggle-hit-area:hover {
|
|
||||||
background-color: rgba(128, 128, 128, 0.1); }
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\00003159}}
|
|
||||||
.treema-toggle-hit-area:hover .treema-toggle {
|
|
||||||
opacity: 1; }
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\00003162}}
|
|
||||||
.treema-toggle-hit-area .treema-toggle {
|
|
||||||
width: 0;
|
|
||||||
height: 0;
|
|
||||||
opacity: 0.7;
|
|
||||||
position: absolute; }
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\00003168}}
|
|
||||||
.treema-closed > .treema-toggle-hit-area .treema-toggle {
|
|
||||||
border-top: 6px solid transparent;
|
|
||||||
border-bottom: 6px solid transparent;
|
|
||||||
border-left: 8px solid #666666;
|
|
||||||
top: 5px;
|
|
||||||
left: 5px; }
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\00003175}}
|
|
||||||
.treema-open > .treema-toggle-hit-area .treema-toggle {
|
|
||||||
border-left: 6px solid transparent;
|
|
||||||
border-right: 6px solid transparent;
|
|
||||||
border-top: 8px solid #666666;
|
|
||||||
top: 7px;
|
|
||||||
left: 3px; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\00003183}}
|
|
||||||
.treema-clearfix:after {
|
|
||||||
content: ".";
|
|
||||||
display: block;
|
|
||||||
height: 0;
|
|
||||||
clear: both;
|
|
||||||
visibility: hidden; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\00003190}}
|
|
||||||
.treema-shortened {
|
|
||||||
overflow: hidden;
|
|
||||||
text-overflow: ellipsis;
|
|
||||||
white-space: nowrap; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\00003195}}
|
|
||||||
.treema-multiline {
|
|
||||||
width: inherit;
|
|
||||||
margin-top: 20px;
|
|
||||||
float: none !important; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\00003201}}
|
|
||||||
.treema-clipboard-container {
|
|
||||||
position: fixed;
|
|
||||||
left: 0px;
|
|
||||||
top: 0px;
|
|
||||||
width: 0px;
|
|
||||||
height: 0px;
|
|
||||||
z-index: 100;
|
|
||||||
display: none;
|
|
||||||
opacity: 0; }
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\00003211}}
|
|
||||||
.treema-clipboard-container .treema-clipboard {
|
|
||||||
width: 1px;
|
|
||||||
height: 1px;
|
|
||||||
padding: 0px; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\000033}}
|
|
||||||
.treema-string {
|
|
||||||
color: #998500; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\000036}}
|
|
||||||
.treema-number {
|
|
||||||
color: #699900; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\000039}}
|
|
||||||
.treema-null {
|
|
||||||
color: #524059;
|
|
||||||
font-weight: bold; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000313}}
|
|
||||||
.treema-array {
|
|
||||||
color: #009905;
|
|
||||||
cursor: row-resize; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000317}}
|
|
||||||
.treema-object {
|
|
||||||
color: #008799;
|
|
||||||
cursor: row-resize; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000321}}
|
|
||||||
.treema-boolean {
|
|
||||||
color: #140099;
|
|
||||||
cursor: pointer; }
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000324}}
|
|
||||||
.treema-boolean.treema-edit {
|
|
||||||
background-color: rgba(64, 128, 255, 0.25); }
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000326}}
|
|
||||||
.treema-boolean input {
|
|
||||||
opacity: 0; }
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000329}}
|
|
||||||
.treema-boolean:hover + .treema-description {
|
|
||||||
display: inline; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\000034}}
|
|
||||||
.treema-point2d input, .treema-point3d input {
|
|
||||||
width: 40px; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\000037}}
|
|
||||||
.treema-search-results {
|
|
||||||
width: 500px;
|
|
||||||
margin-top: 10px;
|
|
||||||
cursor: pointer; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000312}}
|
|
||||||
.treema-search-result-row:hover {
|
|
||||||
background-color: rgba(166, 196, 255, 0.25); }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000315}}
|
|
||||||
.treema-search-selected {
|
|
||||||
background-color: rgba(64, 128, 255, 0.25) !important; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000318}}
|
|
||||||
.treema-ace.treema-display .treema-shortened {
|
|
||||||
font-family: monospace; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000321}}
|
|
||||||
.treema-ace.treema-edit .ace_editor {
|
|
||||||
width: 100%;
|
|
||||||
height: 300px;
|
|
||||||
border: 1px solid gray; }
|
|
||||||
|
|
||||||
@media -sass-debug-info{filename{}line{font-family:\0000327}}
|
|
||||||
.treema-long-string textarea {
|
|
||||||
width: 100%;
|
|
||||||
height: 300px; }
|
|
||||||
|
|
||||||
|
|
||||||
/*@ sourceMappingURL=treema.css.map*/
|
|
Loading…
Reference in a new issue