Compare commits
	
		
			76 Commits
		
	
	
		
			dev
			...
			c972430ef4
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | c972430ef4 | ||
|  | 6d0187ee0a | ||
|  | 00500ecc33 | ||
|  | 848c86327a | ||
|  | d4be0d6471 | ||
|  | c99828dbad | ||
|  | 217f052e63 | ||
|  | 4e93bf23fb | ||
|  | 02899b3b75 | ||
|  | bcc7d60fd3 | ||
|  | df4afeafc6 | ||
|  | 1d891ea734 | ||
|  | 3447b2e0e6 | ||
|  | e7d1cc7bc9 | ||
|  | 47fff0e1ee | ||
|  | cca89a60d8 | ||
|  | a56ade5b08 | ||
|  | 39f9a16fff | ||
|  | 6740200a33 | ||
|  | e4fae23623 | ||
|  | 56d4664d0d | ||
|  | d349fb8328 | ||
|  | 09cccf1983 | ||
|  | 97e7b011d9 | ||
|  | fc1f3f81fe | ||
|  | 9c4fff7913 | ||
|  | b0eee636b5 | ||
|  | 2861042485 | ||
|  | 1005913c0b | ||
|  | c8033588dd | ||
|  | bcb31e9af5 | ||
|  | 596e57eaf0 | ||
|  | d91b0735fd | ||
|  | 71f909fb76 | ||
|  | a44bca204c | ||
|  | 7c15427b3d | ||
|  | ed4a5e5291 | ||
|  | c11f1b1b6f | ||
|  | 0b5675e000 | ||
|  | 9309ea0821 | ||
|  | 5975ab6d68 | ||
|  | 3d6e527e3a | ||
|  | 88a0c7b26a | ||
|  | 1b14a8fd31 | ||
|  | 4cc6014581 | ||
|  | 196224d0b8 | ||
|  | 795f1b7d76 | ||
|  | 1600bd132c | ||
|  | 2a379f8a4e | ||
|  | 3ed26bcc03 | ||
|  | 282cbfe7bc | ||
|  | b50aecdfca | ||
|  | 98f4695739 | ||
|  | 984ac6ccff | ||
|  | f63c0c0d60 | ||
|  | a478cbe11c | ||
|  | 99b69c234f | ||
|  | f0b6d7b85e | ||
|  | 596703a963 | ||
|  | 21f606b480 | ||
|  | b961a69a91 | ||
|  | 8d3762e106 | ||
|  | b2f241dbba | ||
|  | 8833a213a7 | ||
|  | f833845452 | ||
|  | 05152cd5a4 | ||
|  | cf3289aac6 | ||
|  | acf72ca67e | ||
|  | 7f93925f74 | ||
|  | d2c1dedffb | ||
|  | 003c7e32b1 | ||
|  | de646cf1de | ||
|  | 2828cc9462 | ||
|  | f99d6ed430 | ||
|  | 4216c1825e | ||
|  | 8d07a8e11a | 
							
								
								
									
										2
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -6,4 +6,4 @@ pids | ||||
| *.pid | ||||
| *.seed | ||||
| *.pid.lock | ||||
|  | ||||
| .env | ||||
|   | ||||
							
								
								
									
										62
									
								
								applyProdDatabaseToDev.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						| @@ -0,0 +1,62 @@ | ||||
| #!/bin/bash | ||||
|  | ||||
| echo '-------' | ||||
| echo 'Starting Database Restore' | ||||
| echo '-------' | ||||
|  | ||||
| #get Latest database backup | ||||
|  | ||||
| # Unzip File | ||||
| # gzip -dk file.gz | ||||
|  | ||||
| BACKUPDIR="/home/mab/databaseBackupSolidScribe" | ||||
| #DEVDBPASS="Crama!Lama*Jamma###88383!!!!!345345956245i" | ||||
| DEVDBPASS="RootPass1234!" | ||||
| # LazaLinga&33Can't!Do!That34 | ||||
|  | ||||
| cd $BACKUPDIR | ||||
|  | ||||
| # -t sort by modification time, newest first | ||||
| # -A --almost-all, do not list implied . and .. | ||||
| LASTZIPPEDFILE=$(ls -At *.gz | head -n1) | ||||
|  | ||||
| # -k keep file after unzip | ||||
| # -d Decompress | ||||
| # -v verbose | ||||
| echo "Unzipping $LASTZIPPEDFILE" | ||||
| gunzip -dkv $LASTZIPPEDFILE | ||||
|  | ||||
| BACKUPFILE=$(ls -At *.sql | head -n1) | ||||
|  | ||||
| #Fix to replace incompatible DB type | ||||
| echo "Updating table name in -> $BACKUPFILE" | ||||
| #sed -i $BACKUPFILE -e 's/utf8mb4_0900_ai_ci/utf8mb4_unicode_ci/g' | ||||
|  | ||||
| #Fix encoding for dev DB and exclude system tables | ||||
| sed -i 's/utf8mb4_0900_ai_ci/utf8mb4_general_ci/g' $BACKUPFILE | ||||
| sed -r '/INSERT INTO `(sys|mysql)`/d' $BACKUPFILE > $BACKUPFILE | ||||
|  | ||||
| echo "Removing and syncing static files" | ||||
| rm -r /home/mab/ss/staticFiles/* | ||||
| rsync -e 'ssh -p 13328' -hazC --update mab@solidscribe.com:/home/mab/pi/staticFiles /home/mab/ss/ | ||||
|  | ||||
| echo "Updating Database" | ||||
| mysql -u root --password="$DEVDBPASS" < $BACKUPFILE | ||||
|  | ||||
| ## Optimize Database Tables | ||||
| # mysqlcheck --all-databases | ||||
| mysqlcheck --all-databases -o -u root --password="$DEVDBPASS" --silent | ||||
| # mysqlcheck --all-databases --auto-repair | ||||
| # mysqlcheck --all-databases --analyze | ||||
|  | ||||
| # Fix an issues with DB after messing around with it | ||||
| mysql_upgrade -u root --password="$DEVDBPASS" | ||||
|  | ||||
| #clean up extracted and modified SQL dumps | ||||
| rm *.sql | ||||
|  | ||||
|  | ||||
|  | ||||
| echo '-------' | ||||
| echo "Applied Prod database to Dev. LastFile: $BACKUPFILE" | ||||
| echo '-------' | ||||
							
								
								
									
										28
									
								
								backupDatabase.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						| @@ -0,0 +1,28 @@ | ||||
| #!/bin/bash | ||||
|  | ||||
| BACKUPDIR="/home/mab/databaseBackupSolidScribe" | ||||
|  | ||||
| mkdir -p $BACKUPDIR | ||||
| cd $BACKUPDIR | ||||
|  | ||||
| NOW=$(date +"%Y-%m-%d_%H-%M") | ||||
| ssh mab@solidscribe.com -p 13328 "mysqldump --all-databases --single-transaction --user root -pRootPass1234!" > "backup-$NOW.sql" | ||||
| gzip "backup-$NOW.sql" | ||||
|  | ||||
| # cp "backup-$NOW.sql" "/mnt/Windows Data/DatabaseBackups/backup-$NOW.sql" | ||||
|  | ||||
| echo "Database Backup Complete on $NOW" | ||||
|  | ||||
| ##  | ||||
| # Restore DB | ||||
| ## | ||||
|  | ||||
| # copy file over, run restore | ||||
| # scp -P 13328 backup-2019-12-04_03-00.sql mab@avidhabit.com:/home/mab | ||||
| # mysql -u root -p < backup-2019-12-04_03-00.sql | ||||
|  | ||||
| ## | ||||
| # Crontab setup | ||||
| ## | ||||
|  | ||||
| # 0 2 * * * /bin/bash /home/mab/ss/backupDatabase.sh 1> /home/mab/databaseBackupLog.txt | ||||
| @@ -5,30 +5,27 @@ | ||||
| # Push built release files to production server | ||||
| # | ||||
|  | ||||
| echo -e "\e[32m\nStarting Build, hold onto your parts... \n\e[0m" | ||||
| echo -e "\e[32m\nStarting Build. \n\e[0m" | ||||
|  | ||||
| # Build out new release | ||||
| cd client | ||||
| npm run build | ||||
| cd .. | ||||
|  | ||||
| # Remove old releases | ||||
| rm release.tar.gz | ||||
|  | ||||
| # only compress client/dist and server with node_modules | ||||
| echo -e "\e[32m\nCompressing client and server code... \n\e[0m" | ||||
| tar -czf release.tar.gz server node_modules client/dist package.json | ||||
| tar -czf release.tar.gz server node_modules client/dist staticFiles/assets | ||||
|  | ||||
| #send compressed release to remote machine | ||||
| echo -e "\e[32m\nMoving compressed release to production... \n\e[0m" | ||||
| rsync -e 'ssh -p 13328' -havzC --update release.tar.gz mab@avidhabit.com:/home/mab/pi/ | ||||
| rsync -e 'ssh -p 13328' -havzC --update release.tar.gz mab@solidscribe.com:/home/mab/pi/ | ||||
|  | ||||
| # Remove Release from local after its been uploaded | ||||
| rm release.tar.gz | ||||
|  | ||||
| #uncompress release on server | ||||
| echo -e "\e[32m\nExtracting release on production... \n\e[0m" | ||||
| ssh mab@avidhabit.com -p 13328 "cd /home/mab/pi/; rm -r server node_modules client; tar -xzf *.tar.gz; rm *.tar.gz; pm2 reload all" | ||||
| ssh mab@solidscribe.com -p 13328 "cd /home/mab/pi/; rm -r server node_modules client; tar -xzf *.tar.gz --overwrite; rm *.tar.gz; pm2 reload all" | ||||
|  | ||||
| #Congratulate how awesome you are | ||||
| echo -e "\e[32m\nRelease Complete! Nice Work! \n\e[0m" | ||||
| @@ -1,12 +0,0 @@ | ||||
| { | ||||
|   "presets": [ | ||||
|     ["env", { | ||||
|       "modules": false, | ||||
|       "targets": { | ||||
|         "browsers": ["> 1%", "last 2 versions", "not ie <= 8"] | ||||
|       } | ||||
|     }], | ||||
|     "stage-2" | ||||
|   ], | ||||
|   "plugins": ["transform-vue-jsx", "transform-runtime"] | ||||
| } | ||||
| @@ -1,9 +0,0 @@ | ||||
| root = true | ||||
|  | ||||
| [*] | ||||
| charset = utf-8 | ||||
| indent_style = space | ||||
| indent_size = 2 | ||||
| end_of_line = lf | ||||
| insert_final_newline = true | ||||
| trim_trailing_whitespace = true | ||||
							
								
								
									
										13
									
								
								client/.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -1,9 +1,17 @@ | ||||
| .DS_Store | ||||
| node_modules/ | ||||
| /dist/ | ||||
| node_modules | ||||
| /dist | ||||
|  | ||||
|  | ||||
| # local env files | ||||
| .env.local | ||||
| .env.*.local | ||||
|  | ||||
| # Log files | ||||
| npm-debug.log* | ||||
| yarn-debug.log* | ||||
| yarn-error.log* | ||||
| pnpm-debug.log* | ||||
|  | ||||
| # Editor directories and files | ||||
| .idea | ||||
| @@ -12,3 +20,4 @@ yarn-error.log* | ||||
| *.ntvs* | ||||
| *.njsproj | ||||
| *.sln | ||||
| *.sw? | ||||
|   | ||||
| @@ -1,10 +0,0 @@ | ||||
| // https://github.com/michael-ciniawsky/postcss-load-config | ||||
|  | ||||
| module.exports = { | ||||
|   "plugins": { | ||||
|     "postcss-import": {}, | ||||
|     "postcss-url": {}, | ||||
|     // to edit target browsers: use "browserslist" field in package.json | ||||
|     "autoprefixer": {} | ||||
|   } | ||||
| } | ||||
| @@ -1,21 +1 @@ | ||||
| # client | ||||
|  | ||||
| > A Vue.js project | ||||
|  | ||||
| ## Build Setup | ||||
|  | ||||
| ``` bash | ||||
| # install dependencies | ||||
| npm install | ||||
|  | ||||
| # serve with hot reload at localhost:8080 | ||||
| npm run dev | ||||
|  | ||||
| # build for production with minification | ||||
| npm run build | ||||
|  | ||||
| # build for production and view the bundle analyzer report | ||||
| npm run build --report | ||||
| ``` | ||||
|  | ||||
| For a detailed explanation on how things work, check out the [guide](http://vuejs-templates.github.io/webpack/) and [docs for vue-loader](http://vuejs.github.io/vue-loader). | ||||
| # Solid Scribe | ||||
							
								
								
									
										5
									
								
								client/babel.config.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,5 @@ | ||||
| module.exports = { | ||||
|   presets: [ | ||||
|     '@vue/cli-plugin-babel/preset' | ||||
|   ] | ||||
| } | ||||
| @@ -1,41 +0,0 @@ | ||||
| 'use strict' | ||||
| require('./check-versions')() | ||||
|  | ||||
| process.env.NODE_ENV = 'production' | ||||
|  | ||||
| const ora = require('ora') | ||||
| const rm = require('rimraf') | ||||
| const path = require('path') | ||||
| const chalk = require('chalk') | ||||
| const webpack = require('webpack') | ||||
| const config = require('../config') | ||||
| const webpackConfig = require('./webpack.prod.conf') | ||||
|  | ||||
| const spinner = ora('building for production...') | ||||
| spinner.start() | ||||
|  | ||||
| rm(path.join(config.build.assetsRoot, config.build.assetsSubDirectory), err => { | ||||
|   if (err) throw err | ||||
|   webpack(webpackConfig, (err, stats) => { | ||||
|     spinner.stop() | ||||
|     if (err) throw err | ||||
|     process.stdout.write(stats.toString({ | ||||
|       colors: true, | ||||
|       modules: false, | ||||
|       children: false, // If you are using ts-loader, setting this to true will make TypeScript errors show up during build. | ||||
|       chunks: false, | ||||
|       chunkModules: false | ||||
|     }) + '\n\n') | ||||
|  | ||||
|     if (stats.hasErrors()) { | ||||
|       console.log(chalk.red('  Build failed with errors.\n')) | ||||
|       process.exit(1) | ||||
|     } | ||||
|  | ||||
|     console.log(chalk.cyan('  Build complete.\n')) | ||||
|     console.log(chalk.yellow( | ||||
|       '  Tip: built files are meant to be served over an HTTP server.\n' + | ||||
|       '  Opening index.html over file:// won\'t work.\n' | ||||
|     )) | ||||
|   }) | ||||
| }) | ||||
| @@ -1,54 +0,0 @@ | ||||
| 'use strict' | ||||
| const chalk = require('chalk') | ||||
| const semver = require('semver') | ||||
| const packageConfig = require('../package.json') | ||||
| const shell = require('shelljs') | ||||
|  | ||||
| function exec (cmd) { | ||||
|   return require('child_process').execSync(cmd).toString().trim() | ||||
| } | ||||
|  | ||||
| const versionRequirements = [ | ||||
|   { | ||||
|     name: 'node', | ||||
|     currentVersion: semver.clean(process.version), | ||||
|     versionRequirement: packageConfig.engines.node | ||||
|   } | ||||
| ] | ||||
|  | ||||
| if (shell.which('npm')) { | ||||
|   versionRequirements.push({ | ||||
|     name: 'npm', | ||||
|     currentVersion: exec('npm --version'), | ||||
|     versionRequirement: packageConfig.engines.npm | ||||
|   }) | ||||
| } | ||||
|  | ||||
| module.exports = function () { | ||||
|   const warnings = [] | ||||
|  | ||||
|   for (let i = 0; i < versionRequirements.length; i++) { | ||||
|     const mod = versionRequirements[i] | ||||
|  | ||||
|     if (!semver.satisfies(mod.currentVersion, mod.versionRequirement)) { | ||||
|       warnings.push(mod.name + ': ' + | ||||
|         chalk.red(mod.currentVersion) + ' should be ' + | ||||
|         chalk.green(mod.versionRequirement) | ||||
|       ) | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   if (warnings.length) { | ||||
|     console.log('') | ||||
|     console.log(chalk.yellow('To use this template, you must update following to modules:')) | ||||
|     console.log() | ||||
|  | ||||
|     for (let i = 0; i < warnings.length; i++) { | ||||
|       const warning = warnings[i] | ||||
|       console.log('  ' + warning) | ||||
|     } | ||||
|  | ||||
|     console.log() | ||||
|     process.exit(1) | ||||
|   } | ||||
| } | ||||
| Before Width: | Height: | Size: 6.7 KiB | 
| @@ -1,101 +0,0 @@ | ||||
| 'use strict' | ||||
| const path = require('path') | ||||
| const config = require('../config') | ||||
| const ExtractTextPlugin = require('extract-text-webpack-plugin') | ||||
| const packageConfig = require('../package.json') | ||||
|  | ||||
| exports.assetsPath = function (_path) { | ||||
|   const assetsSubDirectory = process.env.NODE_ENV === 'production' | ||||
|     ? config.build.assetsSubDirectory | ||||
|     : config.dev.assetsSubDirectory | ||||
|  | ||||
|   return path.posix.join(assetsSubDirectory, _path) | ||||
| } | ||||
|  | ||||
| exports.cssLoaders = function (options) { | ||||
|   options = options || {} | ||||
|  | ||||
|   const cssLoader = { | ||||
|     loader: 'css-loader', | ||||
|     options: { | ||||
|       sourceMap: options.sourceMap | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   const postcssLoader = { | ||||
|     loader: 'postcss-loader', | ||||
|     options: { | ||||
|       sourceMap: options.sourceMap | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   // generate loader string to be used with extract text plugin | ||||
|   function generateLoaders (loader, loaderOptions) { | ||||
|     const loaders = options.usePostCSS ? [cssLoader, postcssLoader] : [cssLoader] | ||||
|  | ||||
|     if (loader) { | ||||
|       loaders.push({ | ||||
|         loader: loader + '-loader', | ||||
|         options: Object.assign({}, loaderOptions, { | ||||
|           sourceMap: options.sourceMap | ||||
|         }) | ||||
|       }) | ||||
|     } | ||||
|  | ||||
|     // Extract CSS when that option is specified | ||||
|     // (which is the case during production build) | ||||
|     if (options.extract) { | ||||
|       return ExtractTextPlugin.extract({ | ||||
|         use: loaders, | ||||
|         fallback: 'vue-style-loader' | ||||
|       }) | ||||
|     } else { | ||||
|       return ['vue-style-loader'].concat(loaders) | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   // https://vue-loader.vuejs.org/en/configurations/extract-css.html | ||||
|   return { | ||||
|     css: generateLoaders(), | ||||
|     postcss: generateLoaders(), | ||||
|     less: generateLoaders('less'), | ||||
|     sass: generateLoaders('sass', { indentedSyntax: true }), | ||||
|     scss: generateLoaders('sass'), | ||||
|     stylus: generateLoaders('stylus'), | ||||
|     styl: generateLoaders('stylus') | ||||
|   } | ||||
| } | ||||
|  | ||||
| // Generate loaders for standalone style files (outside of .vue) | ||||
| exports.styleLoaders = function (options) { | ||||
|   const output = [] | ||||
|   const loaders = exports.cssLoaders(options) | ||||
|  | ||||
|   for (const extension in loaders) { | ||||
|     const loader = loaders[extension] | ||||
|     output.push({ | ||||
|       test: new RegExp('\\.' + extension + '$'), | ||||
|       use: loader | ||||
|     }) | ||||
|   } | ||||
|  | ||||
|   return output | ||||
| } | ||||
|  | ||||
| exports.createNotifierCallback = () => { | ||||
|   const notifier = require('node-notifier') | ||||
|  | ||||
|   return (severity, errors) => { | ||||
|     if (severity !== 'error') return | ||||
|  | ||||
|     const error = errors[0] | ||||
|     const filename = error.file && error.file.split('!').pop() | ||||
|  | ||||
|     notifier.notify({ | ||||
|       title: packageConfig.name, | ||||
|       message: severity + ': ' + error.name, | ||||
|       subtitle: filename || '', | ||||
|       icon: path.join(__dirname, 'logo.png') | ||||
|     }) | ||||
|   } | ||||
| } | ||||
| @@ -1,22 +0,0 @@ | ||||
| 'use strict' | ||||
| const utils = require('./utils') | ||||
| const config = require('../config') | ||||
| const isProduction = process.env.NODE_ENV === 'production' | ||||
| const sourceMapEnabled = isProduction | ||||
|   ? config.build.productionSourceMap | ||||
|   : config.dev.cssSourceMap | ||||
|  | ||||
| module.exports = { | ||||
|   loaders: utils.cssLoaders({ | ||||
|     sourceMap: sourceMapEnabled, | ||||
|     extract: isProduction | ||||
|   }), | ||||
|   cssSourceMap: sourceMapEnabled, | ||||
|   cacheBusting: config.dev.cacheBusting, | ||||
|   transformToRequire: { | ||||
|     video: ['src', 'poster'], | ||||
|     source: 'src', | ||||
|     img: 'src', | ||||
|     image: 'xlink:href' | ||||
|   } | ||||
| } | ||||
| @@ -1,82 +0,0 @@ | ||||
| 'use strict' | ||||
| const path = require('path') | ||||
| const utils = require('./utils') | ||||
| const config = require('../config') | ||||
| const vueLoaderConfig = require('./vue-loader.conf') | ||||
|  | ||||
| function resolve (dir) { | ||||
|   return path.join(__dirname, '..', dir) | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| module.exports = { | ||||
|   context: path.resolve(__dirname, '../'), | ||||
|   entry: { | ||||
|     app: './src/main.js' | ||||
|   }, | ||||
|   output: { | ||||
|     path: config.build.assetsRoot, | ||||
|     filename: '[name].js', | ||||
|     publicPath: process.env.NODE_ENV === 'production' | ||||
|       ? config.build.assetsPublicPath | ||||
|       : config.dev.assetsPublicPath | ||||
|   }, | ||||
|   resolve: { | ||||
|     extensions: ['.js', '.vue', '.json'], | ||||
|     alias: { | ||||
|       'vue$': 'vue/dist/vue.esm.js', | ||||
|       '@': resolve('src'), | ||||
|     } | ||||
|   }, | ||||
|   module: { | ||||
|     rules: [ | ||||
|       { | ||||
|         test: /\.vue$/, | ||||
|         loader: 'vue-loader', | ||||
|         options: vueLoaderConfig | ||||
|       }, | ||||
|       { | ||||
|         test: /\.js$/, | ||||
|         loader: 'babel-loader', | ||||
|         include: [resolve('src'), resolve('test'), resolve('node_modules/webpack-dev-server/client')] | ||||
|       }, | ||||
|       { | ||||
|         test: /\.(png|jpe?g|gif|svg)(\?.*)?$/, | ||||
|         loader: 'url-loader', | ||||
|         options: { | ||||
|           limit: 10000, | ||||
|           name: utils.assetsPath('img/[name].[hash:7].[ext]') | ||||
|         } | ||||
|       }, | ||||
|       { | ||||
|         test: /\.(mp4|webm|ogg|mp3|wav|flac|aac)(\?.*)?$/, | ||||
|         loader: 'url-loader', | ||||
|         options: { | ||||
|           limit: 10000, | ||||
|           name: utils.assetsPath('media/[name].[hash:7].[ext]') | ||||
|         } | ||||
|       }, | ||||
|       { | ||||
|         test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/, | ||||
|         loader: 'url-loader', | ||||
|         options: { | ||||
|           limit: 10000, | ||||
|           name: utils.assetsPath('fonts/[name].[hash:7].[ext]') | ||||
|         } | ||||
|       } | ||||
|     ] | ||||
|   }, | ||||
|   node: { | ||||
|     // prevent webpack from injecting useless setImmediate polyfill because Vue | ||||
|     // source contains it (although only uses it if it's native). | ||||
|     setImmediate: false, | ||||
|     // prevent webpack from injecting mocks to Node native modules | ||||
|     // that does not make sense for the client | ||||
|     dgram: 'empty', | ||||
|     fs: 'empty', | ||||
|     net: 'empty', | ||||
|     tls: 'empty', | ||||
|     child_process: 'empty' | ||||
|   } | ||||
| } | ||||
| @@ -1,96 +0,0 @@ | ||||
| 'use strict' | ||||
| const utils = require('./utils') | ||||
| const webpack = require('webpack') | ||||
| const config = require('../config') | ||||
| const merge = require('webpack-merge') | ||||
| const path = require('path') | ||||
| const baseWebpackConfig = require('./webpack.base.conf') | ||||
| const CopyWebpackPlugin = require('copy-webpack-plugin') | ||||
| const HtmlWebpackPlugin = require('html-webpack-plugin') | ||||
| const FriendlyErrorsPlugin = require('friendly-errors-webpack-plugin') | ||||
| const portfinder = require('portfinder') | ||||
|  | ||||
| const HOST = process.env.HOST | ||||
| const PORT = process.env.PORT && Number(process.env.PORT) | ||||
|  | ||||
| const devWebpackConfig = merge(baseWebpackConfig, { | ||||
|   module: { | ||||
|     rules: utils.styleLoaders({ sourceMap: config.dev.cssSourceMap, usePostCSS: true }) | ||||
|   }, | ||||
|   // cheap-module-eval-source-map is faster for development | ||||
|   devtool: config.dev.devtool, | ||||
|  | ||||
|   // these devServer options should be customized in /config/index.js | ||||
|   devServer: { | ||||
|     clientLogLevel: 'warning', | ||||
|     historyApiFallback: { | ||||
|       rewrites: [ | ||||
|         { from: /.*/, to: path.posix.join(config.dev.assetsPublicPath, 'index.html') }, | ||||
|       ], | ||||
|     }, | ||||
|     // hot: true, | ||||
|     contentBase: false, // since we use CopyWebpackPlugin. | ||||
|     compress: true, | ||||
|     host: HOST || config.dev.host, | ||||
|     port: PORT || config.dev.port, | ||||
|     open: config.dev.autoOpenBrowser, | ||||
|     overlay: config.dev.errorOverlay | ||||
|       ? { warnings: false, errors: true } | ||||
|       : false, | ||||
|     publicPath: config.dev.assetsPublicPath, | ||||
|     proxy: config.dev.proxyTable, | ||||
|     quiet: true, // necessary for FriendlyErrorsPlugin | ||||
|     disableHostCheck: true, | ||||
|     watchOptions: { | ||||
|       poll: config.dev.poll, | ||||
|     } | ||||
|   }, | ||||
|   plugins: [ | ||||
|     new webpack.DefinePlugin({ | ||||
|       'process.env': require('../config/dev.env') | ||||
|     }), | ||||
|     new webpack.HotModuleReplacementPlugin(), | ||||
|     new webpack.NamedModulesPlugin(), // HMR shows correct file names in console on update. | ||||
|     new webpack.NoEmitOnErrorsPlugin(), | ||||
|     // https://github.com/ampedandwired/html-webpack-plugin | ||||
|     new HtmlWebpackPlugin({ | ||||
|       filename: 'index.html', | ||||
|       template: 'index.html', | ||||
|       inject: true | ||||
|     }), | ||||
|     // copy custom static assets | ||||
|     new CopyWebpackPlugin([ | ||||
|       { | ||||
|         from: path.resolve(__dirname, '../static'), | ||||
|         to: config.dev.assetsSubDirectory, | ||||
|         ignore: ['.*'] | ||||
|       } | ||||
|     ]) | ||||
|   ] | ||||
| }) | ||||
|  | ||||
| module.exports = new Promise((resolve, reject) => { | ||||
|   portfinder.basePort = process.env.PORT || config.dev.port | ||||
|   portfinder.getPort((err, port) => { | ||||
|     if (err) { | ||||
|       reject(err) | ||||
|     } else { | ||||
|       // publish the new Port, necessary for e2e tests | ||||
|       process.env.PORT = port | ||||
|       // add port to devServer config | ||||
|       devWebpackConfig.devServer.port = port | ||||
|  | ||||
|       // Add FriendlyErrorsPlugin | ||||
|       devWebpackConfig.plugins.push(new FriendlyErrorsPlugin({ | ||||
|         compilationSuccessInfo: { | ||||
|           messages: [`Your application is running here: http://${devWebpackConfig.devServer.host}:${port}`], | ||||
|         }, | ||||
|         onErrors: config.dev.notifyOnErrors | ||||
|         ? utils.createNotifierCallback() | ||||
|         : undefined | ||||
|       })) | ||||
|  | ||||
|       resolve(devWebpackConfig) | ||||
|     } | ||||
|   }) | ||||
| }) | ||||
| @@ -1,145 +0,0 @@ | ||||
| 'use strict' | ||||
| const path = require('path') | ||||
| const utils = require('./utils') | ||||
| const webpack = require('webpack') | ||||
| const config = require('../config') | ||||
| const merge = require('webpack-merge') | ||||
| const baseWebpackConfig = require('./webpack.base.conf') | ||||
| const CopyWebpackPlugin = require('copy-webpack-plugin') | ||||
| const HtmlWebpackPlugin = require('html-webpack-plugin') | ||||
| const ExtractTextPlugin = require('extract-text-webpack-plugin') | ||||
| const OptimizeCSSPlugin = require('optimize-css-assets-webpack-plugin') | ||||
| const UglifyJsPlugin = require('uglifyjs-webpack-plugin') | ||||
|  | ||||
| const env = require('../config/prod.env') | ||||
|  | ||||
| const webpackConfig = merge(baseWebpackConfig, { | ||||
|   module: { | ||||
|     rules: utils.styleLoaders({ | ||||
|       sourceMap: config.build.productionSourceMap, | ||||
|       extract: true, | ||||
|       usePostCSS: true | ||||
|     }) | ||||
|   }, | ||||
|   devtool: config.build.productionSourceMap ? config.build.devtool : false, | ||||
|   output: { | ||||
|     path: config.build.assetsRoot, | ||||
|     filename: utils.assetsPath('js/[name].[chunkhash].js'), | ||||
|     chunkFilename: utils.assetsPath('js/[id].[chunkhash].js') | ||||
|   }, | ||||
|   plugins: [ | ||||
|     // http://vuejs.github.io/vue-loader/en/workflow/production.html | ||||
|     new webpack.DefinePlugin({ | ||||
|       'process.env': env | ||||
|     }), | ||||
|     new UglifyJsPlugin({ | ||||
|       uglifyOptions: { | ||||
|         compress: { | ||||
|           warnings: false | ||||
|         } | ||||
|       }, | ||||
|       sourceMap: config.build.productionSourceMap, | ||||
|       parallel: true | ||||
|     }), | ||||
|     // extract css into its own file | ||||
|     new ExtractTextPlugin({ | ||||
|       filename: utils.assetsPath('css/[name].[contenthash].css'), | ||||
|       // Setting the following option to `false` will not extract CSS from codesplit chunks. | ||||
|       // Their CSS will instead be inserted dynamically with style-loader when the codesplit chunk has been loaded by webpack. | ||||
|       // It's currently set to `true` because we are seeing that sourcemaps are included in the codesplit bundle as well when it's `false`,  | ||||
|       // increasing file size: https://github.com/vuejs-templates/webpack/issues/1110 | ||||
|       allChunks: true, | ||||
|     }), | ||||
|     // Compress extracted CSS. We are using this plugin so that possible | ||||
|     // duplicated CSS from different components can be deduped. | ||||
|     new OptimizeCSSPlugin({ | ||||
|       cssProcessorOptions: config.build.productionSourceMap | ||||
|         ? { safe: true, map: { inline: false } } | ||||
|         : { safe: true } | ||||
|     }), | ||||
|     // generate dist index.html with correct asset hash for caching. | ||||
|     // you can customize output by editing /index.html | ||||
|     // see https://github.com/ampedandwired/html-webpack-plugin | ||||
|     new HtmlWebpackPlugin({ | ||||
|       filename: config.build.index, | ||||
|       template: 'index.html', | ||||
|       inject: true, | ||||
|       minify: { | ||||
|         removeComments: true, | ||||
|         collapseWhitespace: true, | ||||
|         removeAttributeQuotes: true | ||||
|         // more options: | ||||
|         // https://github.com/kangax/html-minifier#options-quick-reference | ||||
|       }, | ||||
|       // necessary to consistently work with multiple chunks via CommonsChunkPlugin | ||||
|       chunksSortMode: 'dependency' | ||||
|     }), | ||||
|     // keep module.id stable when vendor modules does not change | ||||
|     new webpack.HashedModuleIdsPlugin(), | ||||
|     // enable scope hoisting | ||||
|     new webpack.optimize.ModuleConcatenationPlugin(), | ||||
|     // split vendor js into its own file | ||||
|     new webpack.optimize.CommonsChunkPlugin({ | ||||
|       name: 'vendor', | ||||
|       minChunks (module) { | ||||
|         // any required modules inside node_modules are extracted to vendor | ||||
|         return ( | ||||
|           module.resource && | ||||
|           /\.js$/.test(module.resource) && | ||||
|           module.resource.indexOf( | ||||
|             path.join(__dirname, '../node_modules') | ||||
|           ) === 0 | ||||
|         ) | ||||
|       } | ||||
|     }), | ||||
|     // extract webpack runtime and module manifest to its own file in order to | ||||
|     // prevent vendor hash from being updated whenever app bundle is updated | ||||
|     new webpack.optimize.CommonsChunkPlugin({ | ||||
|       name: 'manifest', | ||||
|       minChunks: Infinity | ||||
|     }), | ||||
|     // This instance extracts shared chunks from code splitted chunks and bundles them | ||||
|     // in a separate chunk, similar to the vendor chunk | ||||
|     // see: https://webpack.js.org/plugins/commons-chunk-plugin/#extra-async-commons-chunk | ||||
|     new webpack.optimize.CommonsChunkPlugin({ | ||||
|       name: 'app', | ||||
|       async: 'vendor-async', | ||||
|       children: true, | ||||
|       minChunks: 3 | ||||
|     }), | ||||
|  | ||||
|     // copy custom static assets | ||||
|     new CopyWebpackPlugin([ | ||||
|       { | ||||
|         from: path.resolve(__dirname, '../static'), | ||||
|         to: config.build.assetsSubDirectory, | ||||
|         ignore: ['.*'] | ||||
|       } | ||||
|     ]) | ||||
|   ] | ||||
| }) | ||||
|  | ||||
| if (config.build.productionGzip) { | ||||
|   const CompressionWebpackPlugin = require('compression-webpack-plugin') | ||||
|  | ||||
|   webpackConfig.plugins.push( | ||||
|     new CompressionWebpackPlugin({ | ||||
|       asset: '[path].gz[query]', | ||||
|       algorithm: 'gzip', | ||||
|       test: new RegExp( | ||||
|         '\\.(' + | ||||
|         config.build.productionGzipExtensions.join('|') + | ||||
|         ')$' | ||||
|       ), | ||||
|       threshold: 10240, | ||||
|       minRatio: 0.8 | ||||
|     }) | ||||
|   ) | ||||
| } | ||||
|  | ||||
| if (config.build.bundleAnalyzerReport) { | ||||
|   const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin | ||||
|   webpackConfig.plugins.push(new BundleAnalyzerPlugin()) | ||||
| } | ||||
|  | ||||
| module.exports = webpackConfig | ||||
| @@ -1,7 +0,0 @@ | ||||
| 'use strict' | ||||
| const merge = require('webpack-merge') | ||||
| const prodEnv = require('./prod.env') | ||||
|  | ||||
| module.exports = merge(prodEnv, { | ||||
|   NODE_ENV: '"development"' | ||||
| }) | ||||
| @@ -1,69 +0,0 @@ | ||||
| 'use strict' | ||||
| // Template version: 1.3.1 | ||||
| // see http://vuejs-templates.github.io/webpack for documentation. | ||||
|  | ||||
| const path = require('path') | ||||
|  | ||||
| module.exports = { | ||||
|   dev: { | ||||
|  | ||||
|     // Paths | ||||
|     assetsSubDirectory: 'static', | ||||
|     assetsPublicPath: '/', | ||||
|     proxyTable: {}, | ||||
|  | ||||
|     // Various Dev Server settings | ||||
|     host: 'localhost', // can be overwritten by process.env.HOST | ||||
|     port: 8444, // can be overwritten by process.env.PORT, if port is in use, a free one will be determined | ||||
|     autoOpenBrowser: false, | ||||
|     errorOverlay: true, | ||||
|     notifyOnErrors: true, | ||||
|     poll: false, // https://webpack.js.org/configuration/dev-server/#devserver-watchoptions- | ||||
|  | ||||
|      | ||||
|     /** | ||||
|      * Source Maps | ||||
|      */ | ||||
|  | ||||
|     // https://webpack.js.org/configuration/devtool/#development | ||||
|     devtool: 'cheap-module-eval-source-map', | ||||
|  | ||||
|     // If you have problems debugging vue-files in devtools, | ||||
|     // set this to false - it *may* help | ||||
|     // https://vue-loader.vuejs.org/en/options.html#cachebusting | ||||
|     cacheBusting: true, | ||||
|  | ||||
|     cssSourceMap: true | ||||
|   }, | ||||
|  | ||||
|   build: { | ||||
|     // Template for index.html | ||||
|     index: path.resolve(__dirname, '../dist/index.html'), | ||||
|  | ||||
|     // Paths | ||||
|     assetsRoot: path.resolve(__dirname, '../dist'), | ||||
|     assetsSubDirectory: 'static', | ||||
|     assetsPublicPath: '/', | ||||
|  | ||||
|     /** | ||||
|      * Source Maps | ||||
|      */ | ||||
|  | ||||
|     productionSourceMap: true, | ||||
|     // https://webpack.js.org/configuration/devtool/#production | ||||
|     devtool: '#source-map', | ||||
|  | ||||
|     // Gzip off by default as many popular static hosts such as | ||||
|     // Surge or Netlify already gzip all static assets for you. | ||||
|     // Before setting to `true`, make sure to: | ||||
|     // npm install --save-dev compression-webpack-plugin | ||||
|     productionGzip: false, | ||||
|     productionGzipExtensions: ['js', 'css'], | ||||
|  | ||||
|     // Run the build command with an extra argument to | ||||
|     // View the bundle analyzer report after build finishes: | ||||
|     // `npm run build --report` | ||||
|     // Set to `true` or `false` to always turn it on or off | ||||
|     bundleAnalyzerReport: process.env.npm_config_report | ||||
|   } | ||||
| } | ||||
| @@ -1,4 +0,0 @@ | ||||
| 'use strict' | ||||
| module.exports = { | ||||
|   NODE_ENV: '"production"' | ||||
| } | ||||
| @@ -1,12 +0,0 @@ | ||||
| <!DOCTYPE html> | ||||
| <html> | ||||
|   <head> | ||||
|     <meta charset="utf-8"> | ||||
|     <meta name="viewport" content="width=device-width,initial-scale=1.0"> | ||||
|     <title>client</title> | ||||
|   </head> | ||||
|   <body> | ||||
|     <div id="app"></div> | ||||
|     <!-- built files will be auto injected --> | ||||
|   </body> | ||||
| </html> | ||||
							
								
								
									
										11980
									
								
								client/package-lock.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						| @@ -1,78 +1,32 @@ | ||||
| { | ||||
|   "name": "client", | ||||
|   "version": "1.0.0", | ||||
|   "description": "A Vue.js project", | ||||
|   "author": "Max G <admin@internet.com>", | ||||
|   "name": "solidscribe", | ||||
|   "version": "0.1.0", | ||||
|   "private": true, | ||||
|   "scripts": { | ||||
|     "dev": "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js", | ||||
|     "watch": "webpack-dev-server --watch --inline --progress --config build/webpack.dev.conf.js", | ||||
|     "start": "npm run dev", | ||||
|     "build": "node build/build.js" | ||||
|     "serve": "vue-cli-service serve", | ||||
|     "build": "vue-cli-service build" | ||||
|   }, | ||||
|   "dependencies": { | ||||
|     "@ckeditor/ckeditor5-build-classic": "^12.3.1", | ||||
|     "@ckeditor/ckeditor5-build-decoupled-document": "^12.3.1", | ||||
|     "@ckeditor/ckeditor5-dev-utils": "^12.0.2", | ||||
|     "@ckeditor/ckeditor5-dev-webpack-plugin": "^8.0.2", | ||||
|     "@ckeditor/ckeditor5-indent": "^10.0.1", | ||||
|     "@ckeditor/ckeditor5-paragraph": "^11.0.4", | ||||
|     "@ckeditor/ckeditor5-theme-lark": "^14.1.1", | ||||
|     "@ckeditor/ckeditor5-vue": "^1.0.0-beta.2", | ||||
|     "axios": "^0.18.0", | ||||
|     "ckeditor5-indent-text": "^1.0.8", | ||||
|     "es6-promise": "^4.2.6", | ||||
|     "postcss-loader": "^2.1.6", | ||||
|     "raw-loader": "^0.5.1", | ||||
|     "semantic-ui": "^2.4.2", | ||||
|     "vue": "^2.5.2", | ||||
|     "vue-router": "^3.0.1", | ||||
|     "vuex": "^3.1.0" | ||||
|     "axios": "^0.20.0", | ||||
|     "core-js": "^3.6.5", | ||||
|     "es6-promise": "^4.2.8", | ||||
|     "fomantic-ui-css": "^2.8.7", | ||||
|     "vue": "^2.6.11", | ||||
|     "vue-router": "^3.2.0", | ||||
|     "vuex": "^3.4.0" | ||||
|   }, | ||||
|   "devDependencies": { | ||||
|     "autoprefixer": "^7.1.2", | ||||
|     "babel-core": "^6.22.1", | ||||
|     "babel-helper-vue-jsx-merge-props": "^2.0.3", | ||||
|     "babel-loader": "^7.1.1", | ||||
|     "babel-plugin-syntax-jsx": "^6.18.0", | ||||
|     "babel-plugin-transform-runtime": "^6.22.0", | ||||
|     "babel-plugin-transform-vue-jsx": "^3.5.0", | ||||
|     "babel-preset-env": "^1.3.2", | ||||
|     "babel-preset-stage-2": "^6.22.0", | ||||
|     "chalk": "^2.0.1", | ||||
|     "copy-webpack-plugin": "^4.0.1", | ||||
|     "css-loader": "^0.28.0", | ||||
|     "extract-text-webpack-plugin": "^3.0.0", | ||||
|     "file-loader": "^1.1.4", | ||||
|     "friendly-errors-webpack-plugin": "^1.6.1", | ||||
|     "html-webpack-plugin": "^2.30.1", | ||||
|     "node-notifier": "^5.1.2", | ||||
|     "optimize-css-assets-webpack-plugin": "^3.2.0", | ||||
|     "ora": "^1.2.0", | ||||
|     "portfinder": "^1.0.13", | ||||
|     "postcss-import": "^11.0.0", | ||||
|     "postcss-loader": "^2.0.8", | ||||
|     "postcss-url": "^7.2.1", | ||||
|     "rimraf": "^2.6.0", | ||||
|     "semver": "^5.3.0", | ||||
|     "shelljs": "^0.7.6", | ||||
|     "uglifyjs-webpack-plugin": "^1.1.1", | ||||
|     "url-loader": "^0.5.8", | ||||
|     "vue-loader": "^13.3.0", | ||||
|     "vue-style-loader": "^3.0.1", | ||||
|     "vue-template-compiler": "^2.5.2", | ||||
|     "webpack": "^3.6.0", | ||||
|     "webpack-bundle-analyzer": "^2.9.0", | ||||
|     "webpack-dev-server": "^2.9.1", | ||||
|     "webpack-merge": "^4.1.0" | ||||
|   }, | ||||
|   "engines": { | ||||
|     "node": ">= 6.0.0", | ||||
|     "npm": ">= 3.0.0" | ||||
|     "@vue/cli-plugin-babel": "~4.5.0", | ||||
|     "@vue/cli-plugin-router": "~4.5.0", | ||||
|     "@vue/cli-plugin-vuex": "~4.5.0", | ||||
|     "@vue/cli-service": "~4.5.0", | ||||
|     "node-sass": "^4.12.0", | ||||
|     "sass-loader": "^8.0.2", | ||||
|     "vue-template-compiler": "^2.6.11" | ||||
|   }, | ||||
|   "browserslist": [ | ||||
|     "> 1%", | ||||
|     "last 2 versions", | ||||
|     "not ie <= 8" | ||||
|     "not dead" | ||||
|   ] | ||||
| } | ||||
|   | ||||
							
								
								
									
										
											BIN
										
									
								
								client/public/img/icons/android-chrome-192x192.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 9.2 KiB | 
							
								
								
									
										
											BIN
										
									
								
								client/public/img/icons/android-chrome-512x512.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 29 KiB | 
							
								
								
									
										
											BIN
										
									
								
								client/public/img/icons/android-chrome-maskable-192x192.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 6.3 KiB | 
							
								
								
									
										
											BIN
										
									
								
								client/public/img/icons/android-chrome-maskable-512x512.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 22 KiB | 
							
								
								
									
										
											BIN
										
									
								
								client/public/img/icons/apple-touch-icon-120x120.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 3.3 KiB | 
							
								
								
									
										
											BIN
										
									
								
								client/public/img/icons/apple-touch-icon-152x152.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 4.0 KiB | 
							
								
								
									
										
											BIN
										
									
								
								client/public/img/icons/apple-touch-icon-180x180.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 4.6 KiB | 
							
								
								
									
										
											BIN
										
									
								
								client/public/img/icons/apple-touch-icon-60x60.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 1.5 KiB | 
							
								
								
									
										
											BIN
										
									
								
								client/public/img/icons/apple-touch-icon-76x76.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 1.8 KiB | 
							
								
								
									
										
											BIN
										
									
								
								client/public/img/icons/apple-touch-icon.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 4.6 KiB | 
							
								
								
									
										
											BIN
										
									
								
								client/public/img/icons/favicon-16x16.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 799 B | 
							
								
								
									
										
											BIN
										
									
								
								client/public/img/icons/favicon-32x32.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 1.2 KiB | 
							
								
								
									
										
											BIN
										
									
								
								client/public/img/icons/msapplication-icon-144x144.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 1.1 KiB | 
							
								
								
									
										
											BIN
										
									
								
								client/public/img/icons/mstile-150x150.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 4.2 KiB | 
							
								
								
									
										3
									
								
								client/public/img/icons/safari-pinned-tab.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,3 @@ | ||||
| <svg width="16" height="16" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg"> | ||||
| <path d="M8.00251 14.9297L0 1.07422H6.14651L8.00251 4.27503L9.84583 1.07422H16L8.00251 14.9297Z" fill="black"/> | ||||
| </svg> | ||||
| After Width: | Height: | Size: 215 B | 
							
								
								
									
										64
									
								
								client/public/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,64 @@ | ||||
| <!DOCTYPE html> | ||||
| <html lang="en"> | ||||
|   <head> | ||||
|     <meta charset="utf-8"> | ||||
|     <meta name="viewport" content="width=device-width,initial-scale=1.0"> | ||||
|     <meta http-equiv="X-UA-Compatible" content="IE=edge"> | ||||
|  | ||||
|     <link rel="icon" href="/api/static/assets/favicon.ico" type="image/ico"/> | ||||
|     <link rel="shortcut icon" href="/api/static/assets/favicon.ico" type="image/x-icon"/> | ||||
|  | ||||
|     <meta name="theme-color" content="#000" /> | ||||
|     <link rel="manifest" href="/api/static/assets/manifest.json"> | ||||
|  | ||||
|     <title>Solid Scribe - An easy, encrypted Note App</title> | ||||
|     <!-- <title><%= htmlWebpackPlugin.options.title %></title> --> | ||||
|   </head> | ||||
|   <body> | ||||
|     <div id="app"> | ||||
|       <!-- placeholder data for scrapers with no JS --> | ||||
|       <style> | ||||
|         body { | ||||
|           background-color: #212221; | ||||
|           color: #aeaeae; | ||||
|         } | ||||
|         .centered { | ||||
|           position: fixed; | ||||
|           top: 50%; | ||||
|           left: 50%; | ||||
|           transform: translate(-50%, -50%); | ||||
|           text-align: center; | ||||
|           font-family: Arial, Helvetica, sans-serif; | ||||
|         } | ||||
|         .logo { | ||||
|           width: 200px; | ||||
|           height: auto; | ||||
|         } | ||||
|         .scrape-info { | ||||
|           opacity: 0; | ||||
|         } | ||||
|       </style> | ||||
|      | ||||
|       <div class="centered"> | ||||
|         <img class="logo" src="/api/static/assets/logo.svg" alt="Solid Scribe Logo - if you can read this your connection is really slow"> | ||||
|         <h1>Solid Scribe</h1> | ||||
|         <h3>An easy, encrypted Note App</h3> | ||||
|         <h4>Loading...</h4> | ||||
|       </div> | ||||
|  | ||||
|       <div class="scrape-info"> | ||||
|         <h1>Solid Scribe</h1> | ||||
|         <h2>A note application that respects your privacy.</h2> | ||||
|         <p>Take notes with a clean editor that works on desktop or mobile.</p> | ||||
|         <p>Search notes, links and files to find what you need.</p> | ||||
|         <p>Accessable everywhere.</p> | ||||
|         <p>Categorize notes with tags.</p> | ||||
|         <p>Share data with fellow users.</p> | ||||
|         <p>Encrypt notes for additional security.</p> | ||||
|         <b>This site requires Javascipt to run.</b> | ||||
|       </div> | ||||
|  | ||||
|     </div> | ||||
|     <!-- built files will be auto injected --> | ||||
|   </body> | ||||
| </html> | ||||
							
								
								
									
										2
									
								
								client/public/robots.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,2 @@ | ||||
| User-agent: * | ||||
| Disallow: | ||||
| @@ -1,22 +0,0 @@ | ||||
| { | ||||
|   "base": "semantic/", | ||||
|   "paths": { | ||||
|     "source": { | ||||
|       "config": "src/theme.config", | ||||
|       "definitions": "src/definitions/", | ||||
|       "site": "src/site/", | ||||
|       "themes": "src/themes/" | ||||
|     }, | ||||
|     "output": { | ||||
|       "packaged": "dist/", | ||||
|       "uncompressed": "dist/components/", | ||||
|       "compressed": "dist/components/", | ||||
|       "themes": "dist/themes/" | ||||
|     }, | ||||
|     "clean": "dist/" | ||||
|   }, | ||||
|   "permission": false, | ||||
|   "autoInstall": false, | ||||
|   "rtl": false, | ||||
|   "version": "2.4.2" | ||||
| } | ||||
| @@ -1,72 +0,0 @@ | ||||
| /******************************* | ||||
|             Set-up | ||||
| *******************************/ | ||||
|  | ||||
| var | ||||
|   gulp         = require('gulp-help')(require('gulp')), | ||||
|  | ||||
|   // read user config to know what task to load | ||||
|   config       = require('./tasks/config/user'), | ||||
|  | ||||
|   // watch changes | ||||
|   watch        = require('./tasks/watch'), | ||||
|  | ||||
|   // build all files | ||||
|   build        = require('./tasks/build'), | ||||
|   buildJS      = require('./tasks/build/javascript'), | ||||
|   buildCSS     = require('./tasks/build/css'), | ||||
|   buildAssets  = require('./tasks/build/assets'), | ||||
|  | ||||
|   // utility | ||||
|   clean        = require('./tasks/clean'), | ||||
|   version      = require('./tasks/version'), | ||||
|  | ||||
|   // docs tasks | ||||
|   serveDocs    = require('./tasks/docs/serve'), | ||||
|   buildDocs    = require('./tasks/docs/build'), | ||||
|  | ||||
|   // rtl | ||||
|   buildRTL     = require('./tasks/rtl/build'), | ||||
|   watchRTL     = require('./tasks/rtl/watch') | ||||
| ; | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|              Tasks | ||||
| *******************************/ | ||||
|  | ||||
| gulp.task('default', false, [ | ||||
|   'watch' | ||||
| ]); | ||||
|  | ||||
| gulp.task('watch', 'Watch for site/theme changes', watch); | ||||
|  | ||||
| gulp.task('build', 'Builds all files from source', build); | ||||
| gulp.task('build-javascript', 'Builds all javascript from source', buildJS); | ||||
| gulp.task('build-css', 'Builds all css from source', buildCSS); | ||||
| gulp.task('build-assets', 'Copies all assets from source', buildAssets); | ||||
|  | ||||
| gulp.task('clean', 'Clean dist folder', clean); | ||||
| gulp.task('version', 'Displays current version of Semantic', version); | ||||
|  | ||||
| /*-------------- | ||||
|       Docs | ||||
| ---------------*/ | ||||
|  | ||||
| /* | ||||
|   Lets you serve files to a local documentation instance | ||||
|   https://github.com/Semantic-Org/Semantic-UI-Docs/ | ||||
| */ | ||||
|  | ||||
| gulp.task('serve-docs', 'Serve file changes to SUI Docs', serveDocs); | ||||
| gulp.task('build-docs', 'Build all files and add to SUI Docs', buildDocs); | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|       RTL | ||||
| ---------------*/ | ||||
|  | ||||
| if(config.rtl) { | ||||
|   gulp.task('watch-rtl', 'Watch files as RTL', watchRTL); | ||||
|   gulp.task('build-rtl', 'Build all files as RTL', buildRTL); | ||||
| } | ||||
| @@ -1,122 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Breadcrumb | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'collection'; | ||||
| @element : 'breadcrumb'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|            Breadcrumb | ||||
| *******************************/ | ||||
|  | ||||
| .ui.breadcrumb { | ||||
|   line-height: 1; | ||||
|   display: @display; | ||||
|   margin: @verticalMargin 0em; | ||||
|   vertical-align: @verticalAlign; | ||||
| } | ||||
| .ui.breadcrumb:first-child { | ||||
|   margin-top: 0em; | ||||
| } | ||||
| .ui.breadcrumb:last-child { | ||||
|   margin-bottom: 0em; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|           Content | ||||
| *******************************/ | ||||
|  | ||||
| /* Divider */ | ||||
| .ui.breadcrumb .divider { | ||||
|   display: inline-block; | ||||
|   opacity: @dividerOpacity; | ||||
|   margin: 0em @dividerSpacing 0em; | ||||
|  | ||||
|   font-size: @dividerSize; | ||||
|   color: @dividerColor; | ||||
|   vertical-align: @dividerVerticalAlign; | ||||
| } | ||||
|  | ||||
| /* Link */ | ||||
| .ui.breadcrumb a { | ||||
|   color: @linkColor; | ||||
| } | ||||
| .ui.breadcrumb a:hover { | ||||
|   color: @linkHoverColor; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Icon Divider */ | ||||
| .ui.breadcrumb .icon.divider { | ||||
|   font-size: @iconDividerSize; | ||||
|   vertical-align: @iconDividerVerticalAlign; | ||||
| } | ||||
|  | ||||
| /* Section */ | ||||
| .ui.breadcrumb a.section { | ||||
|   cursor: pointer; | ||||
| } | ||||
| .ui.breadcrumb .section { | ||||
|   display: inline-block; | ||||
|   margin: @sectionMargin; | ||||
|   padding: @sectionPadding; | ||||
| } | ||||
|  | ||||
| /* Loose Coupling */ | ||||
| .ui.breadcrumb.segment { | ||||
|   display: inline-block; | ||||
|   padding: @segmentPadding; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|             States | ||||
| *******************************/ | ||||
|  | ||||
| .ui.breadcrumb .active.section { | ||||
|   font-weight: @activeFontWeight; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|            Variations | ||||
| *******************************/ | ||||
|  | ||||
| .ui.mini.breadcrumb { | ||||
|   font-size: @mini; | ||||
| } | ||||
| .ui.tiny.breadcrumb { | ||||
|   font-size: @tiny; | ||||
| } | ||||
| .ui.small.breadcrumb { | ||||
|   font-size: @small; | ||||
| } | ||||
| .ui.breadcrumb { | ||||
|   font-size: @medium; | ||||
| } | ||||
| .ui.large.breadcrumb { | ||||
|   font-size: @large; | ||||
| } | ||||
| .ui.big.breadcrumb { | ||||
|   font-size: @big; | ||||
| } | ||||
| .ui.huge.breadcrumb { | ||||
|   font-size: @huge; | ||||
| } | ||||
| .ui.massive.breadcrumb { | ||||
|   font-size: @massive; | ||||
| } | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,481 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Message | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'collection'; | ||||
| @element : 'message'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|             Message | ||||
| *******************************/ | ||||
|  | ||||
| .ui.message { | ||||
|   position: relative; | ||||
|   min-height: 1em; | ||||
|   margin: @verticalMargin 0em; | ||||
|   background: @background; | ||||
|   padding: @padding; | ||||
|   line-height: @lineHeight; | ||||
|   color: @textColor; | ||||
|   transition: @transition; | ||||
|   border-radius: @borderRadius; | ||||
|   box-shadow: @boxShadow; | ||||
| } | ||||
|  | ||||
| .ui.message:first-child { | ||||
|   margin-top: 0em; | ||||
| } | ||||
| .ui.message:last-child { | ||||
|   margin-bottom: 0em; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|      Content | ||||
| ---------------*/ | ||||
|  | ||||
| /* Header */ | ||||
| .ui.message .header { | ||||
|   display: @headerDisplay; | ||||
|   font-family: @headerFont; | ||||
|   font-weight: @headerFontWeight; | ||||
|   margin: @headerMargin; | ||||
| } | ||||
|  | ||||
| /* Default font size */ | ||||
| .ui.message .header:not(.ui) { | ||||
|   font-size: @headerFontSize; | ||||
| } | ||||
|  | ||||
| /* Paragraph */ | ||||
| .ui.message p { | ||||
|   opacity: @messageTextOpacity; | ||||
|   margin: @messageParagraphMargin 0em; | ||||
| } | ||||
| .ui.message p:first-child { | ||||
|   margin-top: 0em; | ||||
| } | ||||
| .ui.message p:last-child { | ||||
|   margin-bottom: 0em; | ||||
| } | ||||
| .ui.message .header + p { | ||||
|   margin-top: @headerParagraphDistance; | ||||
| } | ||||
|  | ||||
| /* List */ | ||||
| .ui.message .list:not(.ui) { | ||||
|   text-align: left; | ||||
|   padding: 0em; | ||||
|   opacity: @listOpacity; | ||||
|   list-style-position: @listStylePosition; | ||||
|   margin: @listMargin 0em 0em; | ||||
| } | ||||
| .ui.message .list:not(.ui):first-child { | ||||
|   margin-top: 0em; | ||||
| } | ||||
| .ui.message .list:not(.ui):last-child { | ||||
|   margin-bottom: 0em; | ||||
| } | ||||
| .ui.message .list:not(.ui) li { | ||||
|   position: relative; | ||||
|   list-style-type: none; | ||||
|   margin: 0em 0em @listItemMargin @listItemIndent; | ||||
|   padding: 0em; | ||||
| } | ||||
| .ui.message .list:not(.ui) li:before { | ||||
|   position: absolute; | ||||
|   content: '•'; | ||||
|   left: -1em; | ||||
|   height: 100%; | ||||
|   vertical-align: baseline; | ||||
| } | ||||
| .ui.message .list:not(.ui) li:last-child { | ||||
|   margin-bottom: 0em; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Icon */ | ||||
| .ui.message > .icon { | ||||
|   margin-right: @iconDistance; | ||||
| } | ||||
|  | ||||
| /* Close Icon */ | ||||
| .ui.message > .close.icon { | ||||
|   cursor: pointer; | ||||
|   position: absolute; | ||||
|   margin: 0em; | ||||
|   top: @closeTopDistance; | ||||
|   right: @closeRightDistance; | ||||
|   opacity: @closeOpacity; | ||||
|   transition: @closeTransition; | ||||
| } | ||||
| .ui.message > .close.icon:hover { | ||||
|   opacity: 1; | ||||
| } | ||||
|  | ||||
| /* First / Last Element */ | ||||
| .ui.message > :first-child { | ||||
|   margin-top: 0em; | ||||
| } | ||||
| .ui.message > :last-child { | ||||
|   margin-bottom: 0em; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|             Coupling | ||||
| *******************************/ | ||||
|  | ||||
| .ui.dropdown .menu > .message { | ||||
|   margin: 0px -@borderWidth; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|             States | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|     Visible | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.visible.visible.visible.visible.message { | ||||
|   display: block; | ||||
| } | ||||
|  | ||||
| .ui.icon.visible.visible.visible.visible.message { | ||||
|   display: flex; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Hidden | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.hidden.hidden.hidden.hidden.message { | ||||
|   display: none; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Variations | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|     Compact | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.compact.message { | ||||
|   display: inline-block; | ||||
| } | ||||
| .ui.compact.icon.message { | ||||
|   display: inline-flex; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|     Attached | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.attached.message { | ||||
|   margin-bottom: @attachedYOffset; | ||||
|   border-radius: @borderRadius @borderRadius 0em 0em; | ||||
|   box-shadow: @attachedBoxShadow; | ||||
|   margin-left: @attachedXOffset; | ||||
|   margin-right: @attachedXOffset; | ||||
| } | ||||
| .ui.attached + .ui.attached.message:not(.top):not(.bottom) { | ||||
|   margin-top: @attachedYOffset; | ||||
|   border-radius: 0em; | ||||
| } | ||||
| .ui.bottom.attached.message { | ||||
|   margin-top: @attachedYOffset; | ||||
|   border-radius: 0em 0em @borderRadius @borderRadius; | ||||
|   box-shadow: @attachedBottomBoxShadow; | ||||
| } | ||||
| .ui.bottom.attached.message:not(:last-child) { | ||||
|   margin-bottom: @verticalMargin; | ||||
| } | ||||
| .ui.attached.icon.message { | ||||
|   width: auto; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|       Icon | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.icon.message { | ||||
|   display: flex; | ||||
|   width: 100%; | ||||
|   align-items: center; | ||||
| } | ||||
| .ui.icon.message > .icon:not(.close) { | ||||
|   display: block; | ||||
|   flex: 0 0 auto; | ||||
|   width: auto; | ||||
|   line-height: 1; | ||||
|   vertical-align: @iconVerticalAlign; | ||||
|   font-size: @iconSize; | ||||
|   opacity: @iconOpacity; | ||||
| } | ||||
| .ui.icon.message > .content { | ||||
|   display: block; | ||||
|   flex: 1 1 auto; | ||||
|   vertical-align: @iconVerticalAlign; | ||||
| } | ||||
|  | ||||
|  | ||||
| .ui.icon.message .icon:not(.close) + .content { | ||||
|   padding-left: @iconContentDistance; | ||||
| } | ||||
| .ui.icon.message .circular.icon { | ||||
|   width: 1em; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Floating | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.floating.message { | ||||
|   box-shadow: @floatingBoxShadow; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|      Colors | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.black.message { | ||||
|   background-color: @black; | ||||
|   color: @invertedTextColor; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Types | ||||
| ---------------*/ | ||||
|  | ||||
| /* Positive */ | ||||
| .ui.positive.message { | ||||
|   background-color: @positiveBackgroundColor; | ||||
|   color: @positiveTextColor; | ||||
| } | ||||
| .ui.positive.message, | ||||
| .ui.attached.positive.message { | ||||
|   box-shadow: @positiveBoxShadow; | ||||
| } | ||||
| .ui.positive.message .header { | ||||
|   color: @positiveHeaderColor; | ||||
| } | ||||
|  | ||||
| /* Negative */ | ||||
| .ui.negative.message { | ||||
|   background-color: @negativeBackgroundColor; | ||||
|   color: @negativeTextColor; | ||||
| } | ||||
| .ui.negative.message, | ||||
| .ui.attached.negative.message { | ||||
|   box-shadow: @negativeBoxShadow; | ||||
| } | ||||
| .ui.negative.message .header { | ||||
|   color: @negativeHeaderColor; | ||||
| } | ||||
|  | ||||
| /* Info */ | ||||
| .ui.info.message { | ||||
|   background-color: @infoBackgroundColor; | ||||
|   color: @infoTextColor; | ||||
| } | ||||
| .ui.info.message, | ||||
| .ui.attached.info.message { | ||||
|   box-shadow: @infoBoxShadow; | ||||
| } | ||||
| .ui.info.message .header { | ||||
|   color: @infoHeaderColor; | ||||
| } | ||||
|  | ||||
| /* Warning */ | ||||
| .ui.warning.message { | ||||
|   background-color: @warningBackgroundColor; | ||||
|   color: @warningTextColor; | ||||
| } | ||||
| .ui.warning.message, | ||||
| .ui.attached.warning.message { | ||||
|   box-shadow: @warningBoxShadow; | ||||
| } | ||||
| .ui.warning.message .header { | ||||
|   color: @warningHeaderColor; | ||||
| } | ||||
|  | ||||
| /* Error */ | ||||
| .ui.error.message { | ||||
|   background-color: @errorBackgroundColor; | ||||
|   color: @errorTextColor; | ||||
| } | ||||
| .ui.error.message, | ||||
| .ui.attached.error.message { | ||||
|   box-shadow: @errorBoxShadow; | ||||
| } | ||||
| .ui.error.message .header { | ||||
|   color: @errorHeaderColor; | ||||
| } | ||||
|  | ||||
| /* Success */ | ||||
| .ui.success.message { | ||||
|   background-color: @successBackgroundColor; | ||||
|   color: @successTextColor; | ||||
| } | ||||
| .ui.success.message, | ||||
| .ui.attached.success.message { | ||||
|   box-shadow: @successBoxShadow; | ||||
| } | ||||
| .ui.success.message .header { | ||||
|   color: @successHeaderColor; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Colors */ | ||||
| .ui.inverted.message, | ||||
| .ui.black.message { | ||||
|   background-color: @black; | ||||
|   color: @invertedTextColor; | ||||
| } | ||||
|  | ||||
| .ui.red.message { | ||||
|   background-color: @redBackground; | ||||
|   color: @redTextColor; | ||||
|   box-shadow: @redBoxShadow; | ||||
| } | ||||
| .ui.red.message .header { | ||||
|   color: @redHeaderColor; | ||||
| } | ||||
|  | ||||
| .ui.orange.message { | ||||
|   background-color: @orangeBackground; | ||||
|   color: @orangeTextColor; | ||||
|   box-shadow: @orangeBoxShadow; | ||||
| } | ||||
| .ui.orange.message .header { | ||||
|   color: @orangeHeaderColor; | ||||
| } | ||||
|  | ||||
| .ui.yellow.message { | ||||
|   background-color: @yellowBackground; | ||||
|   color: @yellowTextColor; | ||||
|   box-shadow: @yellowBoxShadow; | ||||
| } | ||||
| .ui.yellow.message .header { | ||||
|   color: @yellowHeaderColor; | ||||
| } | ||||
|  | ||||
| .ui.olive.message { | ||||
|   background-color: @oliveBackground; | ||||
|   color: @oliveTextColor; | ||||
|   box-shadow: @oliveBoxShadow; | ||||
| } | ||||
| .ui.olive.message .header { | ||||
|   color: @oliveHeaderColor; | ||||
| } | ||||
|  | ||||
| .ui.green.message { | ||||
|   background-color: @greenBackground; | ||||
|   color: @greenTextColor; | ||||
|   box-shadow: @greenBoxShadow; | ||||
| } | ||||
| .ui.green.message .header { | ||||
|   color: @greenHeaderColor; | ||||
| } | ||||
|  | ||||
| .ui.teal.message { | ||||
|   background-color: @tealBackground; | ||||
|   color: @tealTextColor; | ||||
|   box-shadow: @tealBoxShadow; | ||||
| } | ||||
| .ui.teal.message .header { | ||||
|   color: @tealHeaderColor; | ||||
| } | ||||
|  | ||||
| .ui.blue.message { | ||||
|   background-color: @blueBackground; | ||||
|   color: @blueTextColor; | ||||
|   box-shadow: @blueBoxShadow; | ||||
| } | ||||
| .ui.blue.message .header { | ||||
|   color: @blueHeaderColor; | ||||
| } | ||||
|  | ||||
| .ui.violet.message { | ||||
|   background-color: @violetBackground; | ||||
|   color: @violetTextColor; | ||||
|   box-shadow: @violetBoxShadow; | ||||
| } | ||||
| .ui.violet.message .header { | ||||
|   color: @violetHeaderColor; | ||||
| } | ||||
|  | ||||
| .ui.purple.message { | ||||
|   background-color: @purpleBackground; | ||||
|   color: @purpleTextColor; | ||||
|   box-shadow: @purpleBoxShadow; | ||||
| } | ||||
| .ui.purple.message .header { | ||||
|   color: @purpleHeaderColor; | ||||
| } | ||||
|  | ||||
| .ui.pink.message { | ||||
|   background-color: @pinkBackground; | ||||
|   color: @pinkTextColor; | ||||
|   box-shadow: @pinkBoxShadow; | ||||
| } | ||||
| .ui.pink.message .header { | ||||
|   color: @pinkHeaderColor; | ||||
| } | ||||
|  | ||||
| .ui.brown.message { | ||||
|   background-color: @brownBackground; | ||||
|   color: @brownTextColor; | ||||
|   box-shadow: @brownBoxShadow; | ||||
| } | ||||
| .ui.brown.message .header { | ||||
|   color: @brownHeaderColor; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Sizes | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.mini.message { | ||||
|   font-size: @relativeMini; | ||||
| } | ||||
| .ui.tiny.message { | ||||
|   font-size: @relativeTiny; | ||||
| } | ||||
| .ui.small.message { | ||||
|   font-size: @relativeSmall; | ||||
| } | ||||
| .ui.message { | ||||
|   font-size: @relativeMedium; | ||||
| } | ||||
| .ui.large.message { | ||||
|   font-size: @relativeLarge; | ||||
| } | ||||
| .ui.big.message { | ||||
|   font-size: @relativeBig; | ||||
| } | ||||
| .ui.huge.message { | ||||
|   font-size: @relativeHuge; | ||||
| } | ||||
| .ui.massive.message { | ||||
|   font-size: @relativeMassive; | ||||
| } | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,143 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Container | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'element'; | ||||
| @element : 'container'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|             Container | ||||
| *******************************/ | ||||
|  | ||||
| /* All Sizes */ | ||||
| .ui.container { | ||||
|   display: block; | ||||
|   max-width: @maxWidth !important; | ||||
| } | ||||
|  | ||||
| /* Mobile */ | ||||
| @media only screen and (max-width: @largestMobileScreen) { | ||||
|   .ui.container { | ||||
|     width: @mobileWidth !important; | ||||
|     margin-left: @mobileGutter !important; | ||||
|     margin-right: @mobileGutter !important; | ||||
|   } | ||||
|   .ui.grid.container { | ||||
|     width: @mobileGridWidth !important; | ||||
|   } | ||||
|   .ui.relaxed.grid.container { | ||||
|     width: @mobileRelaxedGridWidth !important; | ||||
|   } | ||||
|   .ui.very.relaxed.grid.container { | ||||
|     width: @mobileVeryRelaxedGridWidth !important; | ||||
|   } | ||||
| } | ||||
|  | ||||
| /* Tablet */ | ||||
| @media only screen and (min-width: @tabletBreakpoint) and (max-width: @largestTabletScreen) { | ||||
|   .ui.container { | ||||
|     width: @tabletWidth; | ||||
|     margin-left: @tabletGutter !important; | ||||
|     margin-right: @tabletGutter !important; | ||||
|   } | ||||
|   .ui.grid.container { | ||||
|     width: @tabletGridWidth !important; | ||||
|   } | ||||
|   .ui.relaxed.grid.container { | ||||
|     width: @tabletRelaxedGridWidth !important; | ||||
|   } | ||||
|   .ui.very.relaxed.grid.container { | ||||
|     width: @tabletVeryRelaxedGridWidth !important; | ||||
|   } | ||||
| } | ||||
|  | ||||
| /* Small Monitor */ | ||||
| @media only screen and (min-width: @computerBreakpoint) and (max-width: @largestSmallMonitor) { | ||||
|   .ui.container { | ||||
|     width: @computerWidth; | ||||
|     margin-left: @computerGutter !important; | ||||
|     margin-right: @computerGutter !important; | ||||
|   } | ||||
|   .ui.grid.container { | ||||
|     width: @computerGridWidth !important; | ||||
|   } | ||||
|   .ui.relaxed.grid.container { | ||||
|     width: @computerRelaxedGridWidth !important; | ||||
|   } | ||||
|   .ui.very.relaxed.grid.container { | ||||
|     width: @computerVeryRelaxedGridWidth !important; | ||||
|   } | ||||
| } | ||||
|  | ||||
| /* Large Monitor */ | ||||
| @media only screen and (min-width: @largeMonitorBreakpoint) { | ||||
|   .ui.container { | ||||
|     width: @largeMonitorWidth; | ||||
|     margin-left: @largeMonitorGutter !important; | ||||
|     margin-right: @largeMonitorGutter !important; | ||||
|   } | ||||
|   .ui.grid.container { | ||||
|     width: @largeMonitorGridWidth !important; | ||||
|   } | ||||
|   .ui.relaxed.grid.container { | ||||
|     width: @largeMonitorRelaxedGridWidth !important; | ||||
|   } | ||||
|   .ui.very.relaxed.grid.container { | ||||
|     width: @largeMonitorVeryRelaxedGridWidth !important; | ||||
|   } | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|              Types | ||||
| *******************************/ | ||||
|  | ||||
|  | ||||
| /* Text Container */ | ||||
| .ui.text.container { | ||||
|   font-family: @textFontFamily; | ||||
|   max-width: @textWidth !important; | ||||
|   line-height: @textLineHeight; | ||||
| } | ||||
|  | ||||
| .ui.text.container { | ||||
|   font-size: @textSize; | ||||
| } | ||||
|  | ||||
| /* Fluid */ | ||||
| .ui.fluid.container { | ||||
|   width: 100%; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|            Variations | ||||
| *******************************/ | ||||
|  | ||||
| .ui[class*="left aligned"].container { | ||||
|   text-align: left; | ||||
| } | ||||
| .ui[class*="center aligned"].container { | ||||
|   text-align: center; | ||||
| } | ||||
| .ui[class*="right aligned"].container { | ||||
|   text-align: right; | ||||
| } | ||||
| .ui.justified.container { | ||||
|   text-align: justify; | ||||
|   hyphens: auto; | ||||
| } | ||||
|  | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,255 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Divider | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'element'; | ||||
| @element : 'divider'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Divider | ||||
| *******************************/ | ||||
|  | ||||
| .ui.divider { | ||||
|   margin: @margin; | ||||
|  | ||||
|   line-height: 1; | ||||
|   height: 0em; | ||||
|  | ||||
|   font-weight: @fontWeight; | ||||
|   text-transform: @textTransform; | ||||
|   letter-spacing: @letterSpacing; | ||||
|   color: @color; | ||||
|  | ||||
|   user-select: none; | ||||
|   -webkit-tap-highlight-color: rgba(0, 0, 0, 0); | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|       Basic | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.divider:not(.vertical):not(.horizontal) { | ||||
|   border-top: @shadowWidth solid @shadowColor; | ||||
|   border-bottom: @highlightWidth solid @highlightColor; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Coupling | ||||
| ---------------*/ | ||||
|  | ||||
| /* Allow divider between each column row */ | ||||
| .ui.grid > .column + .divider, | ||||
| .ui.grid > .row > .column + .divider { | ||||
|   left: auto; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|    Horizontal | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.horizontal.divider { | ||||
|   display: table; | ||||
|   white-space: nowrap; | ||||
|  | ||||
|   height: auto; | ||||
|   margin: @horizontalMargin; | ||||
|   line-height: 1; | ||||
|   text-align: center; | ||||
| } | ||||
|  | ||||
| .ui.horizontal.divider:before, | ||||
| .ui.horizontal.divider:after { | ||||
|   content: ''; | ||||
|   display: table-cell; | ||||
|   position: relative; | ||||
|   top: 50%; | ||||
|   width: 50%; | ||||
|   background-repeat: no-repeat; | ||||
| } | ||||
|  | ||||
| .ui.horizontal.divider:before { | ||||
|   background-position: right @horizontalDividerMargin top 50%; | ||||
| } | ||||
| .ui.horizontal.divider:after { | ||||
|   background-position: left @horizontalDividerMargin top 50%; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Vertical | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.vertical.divider { | ||||
|   position: absolute; | ||||
|   z-index: 2; | ||||
|   top: 50%; | ||||
|   left: 50%; | ||||
|  | ||||
|   margin: 0rem; | ||||
|   padding: 0em; | ||||
|   width: auto; | ||||
|   height: 50%; | ||||
|  | ||||
|   line-height: 0em; | ||||
|   text-align: center; | ||||
|   transform: translateX(-50%); | ||||
| } | ||||
|  | ||||
| .ui.vertical.divider:before, | ||||
| .ui.vertical.divider:after { | ||||
|   position: absolute; | ||||
|   left: 50%; | ||||
|   content: ''; | ||||
|   z-index: 3; | ||||
|  | ||||
|   border-left: @shadowWidth solid @shadowColor; | ||||
|   border-right: @highlightWidth solid @highlightColor; | ||||
|  | ||||
|   width: 0%; | ||||
|   height: @verticalDividerHeight; | ||||
| } | ||||
|  | ||||
| .ui.vertical.divider:before { | ||||
|   top: -100%; | ||||
| } | ||||
| .ui.vertical.divider:after { | ||||
|   top: auto; | ||||
|   bottom: 0px; | ||||
| } | ||||
|  | ||||
| /* Inside grid */ | ||||
| @media only screen and (max-width : @largestMobileScreen) { | ||||
|  | ||||
|   .ui.stackable.grid .ui.vertical.divider, | ||||
|   .ui.grid .stackable.row .ui.vertical.divider { | ||||
|     display: table; | ||||
|     white-space: nowrap; | ||||
|     height: auto; | ||||
|     margin: @horizontalMargin; | ||||
|     overflow: hidden; | ||||
|     line-height: 1; | ||||
|     text-align: center; | ||||
|     position: static; | ||||
|     top: 0; | ||||
|     left: 0; | ||||
|     transform: none; | ||||
|   } | ||||
|  | ||||
|   .ui.stackable.grid .ui.vertical.divider:before, | ||||
|   .ui.grid .stackable.row .ui.vertical.divider:before, | ||||
|   .ui.stackable.grid .ui.vertical.divider:after, | ||||
|   .ui.grid .stackable.row .ui.vertical.divider:after { | ||||
|     position: static; | ||||
|     left: 0; | ||||
|     border-left: none; | ||||
|     border-right: none; | ||||
|     content: ''; | ||||
|     display: table-cell; | ||||
|     position: relative; | ||||
|     top: 50%; | ||||
|     width: 50%; | ||||
|     background-repeat: no-repeat; | ||||
|   } | ||||
|  | ||||
|   .ui.stackable.grid .ui.vertical.divider:before, | ||||
|   .ui.grid .stackable.row .ui.vertical.divider:before { | ||||
|     background-position: right @horizontalDividerMargin top 50%; | ||||
|   } | ||||
|   .ui.stackable.grid .ui.vertical.divider:after, | ||||
|   .ui.grid .stackable.row .ui.vertical.divider:after { | ||||
|     background-position: left @horizontalDividerMargin top 50%; | ||||
|   } | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|       Icon | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.divider > .icon { | ||||
|   margin: @dividerIconMargin; | ||||
|   font-size: @dividerIconSize; | ||||
|   height: 1em; | ||||
|   vertical-align: middle; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|           Variations | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|     Hidden | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.hidden.divider { | ||||
|   border-color: transparent !important; | ||||
| } | ||||
| .ui.hidden.divider:before, | ||||
| .ui.hidden.divider:after { | ||||
|   display: none; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Inverted | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.divider.inverted, | ||||
| .ui.vertical.inverted.divider, | ||||
| .ui.horizontal.inverted.divider { | ||||
|   color: @invertedTextColor; | ||||
| } | ||||
| .ui.divider.inverted, | ||||
| .ui.divider.inverted:after, | ||||
| .ui.divider.inverted:before { | ||||
|   border-top-color: @invertedShadowColor !important; | ||||
|   border-left-color: @invertedShadowColor !important; | ||||
|   border-bottom-color: @invertedHighlightColor !important; | ||||
|   border-right-color: @invertedHighlightColor !important; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Fitted | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.fitted.divider { | ||||
|   margin: 0em; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Clearing | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.clearing.divider { | ||||
|   clear: both; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Section | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.section.divider { | ||||
|   margin-top: @sectionMargin; | ||||
|   margin-bottom: @sectionMargin; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Sizes | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.divider { | ||||
|   font-size: @medium; | ||||
| } | ||||
|  | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,52 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Flag | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'element'; | ||||
| @element : 'flag'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|              Flag | ||||
| *******************************/ | ||||
|  | ||||
| i.flag:not(.icon) { | ||||
|   display: inline-block; | ||||
|  | ||||
|   width: @width; | ||||
|   height: @height; | ||||
|  | ||||
|   line-height: @height; | ||||
|   vertical-align: @verticalAlign; | ||||
|   margin: 0em @margin 0em 0em; | ||||
|  | ||||
|   text-decoration: inherit; | ||||
|  | ||||
|   speak: none; | ||||
|   font-smoothing: antialiased; | ||||
|   backface-visibility: hidden; | ||||
| } | ||||
|  | ||||
| /* Sprite */ | ||||
| i.flag:not(.icon):before { | ||||
|   display: inline-block; | ||||
|   content: ''; | ||||
|   background: url(@spritePath) no-repeat -108px -1976px; | ||||
|   width: @width; | ||||
|   height: @height; | ||||
| } | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,708 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Header | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'element'; | ||||
| @element : 'header'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Header | ||||
| *******************************/ | ||||
|  | ||||
| /* Standard */ | ||||
| .ui.header { | ||||
|   border: none; | ||||
|   margin: @margin; | ||||
|   padding: @verticalPadding @horizontalPadding; | ||||
|   font-family: @fontFamily; | ||||
|   font-weight: @fontWeight; | ||||
|   line-height: @lineHeight; | ||||
|   text-transform: @textTransform; | ||||
|   color: @textColor; | ||||
| } | ||||
|  | ||||
| .ui.header:first-child { | ||||
|   margin-top: @firstMargin; | ||||
| } | ||||
| .ui.header:last-child { | ||||
|   margin-bottom: @lastMargin; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|    Sub Header | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.header .sub.header { | ||||
|   display: block; | ||||
|   font-weight: @normal; | ||||
|   padding: 0em; | ||||
|   margin: @subHeaderMargin; | ||||
|   font-size: @subHeaderFontSize; | ||||
|   line-height: @subHeaderLineHeight; | ||||
|   color: @subHeaderColor; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|       Icon | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.header > .icon { | ||||
|   display: table-cell; | ||||
|   opacity: @iconOpacity; | ||||
|   font-size: @iconSize; | ||||
|   padding-top: @iconOffset; | ||||
|   vertical-align: @iconAlignment; | ||||
| } | ||||
|  | ||||
| /* With Text Node */ | ||||
| .ui.header .icon:only-child { | ||||
|   display: inline-block; | ||||
|   padding: 0em; | ||||
|   margin-right: @iconMargin; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|         Image | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.header > .image:not(.icon), | ||||
| .ui.header > img { | ||||
|   display: inline-block; | ||||
|   margin-top: @imageOffset; | ||||
|   width: @imageWidth; | ||||
|   height: @imageHeight; | ||||
|   vertical-align: @imageAlignment; | ||||
| } | ||||
| .ui.header > .image:not(.icon):only-child, | ||||
| .ui.header > img:only-child { | ||||
|   margin-right: @imageMargin; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Content | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.header .content { | ||||
|   display: inline-block; | ||||
|   vertical-align: @contentAlignment; | ||||
| } | ||||
|  | ||||
| /* After Image */ | ||||
| .ui.header > img + .content, | ||||
| .ui.header > .image + .content { | ||||
|   padding-left: @imageMargin; | ||||
|   vertical-align: @contentImageAlignment; | ||||
| } | ||||
|  | ||||
| /* After Icon */ | ||||
| .ui.header > .icon + .content { | ||||
|   padding-left: @iconMargin; | ||||
|   display: table-cell; | ||||
|   vertical-align: @contentIconAlignment; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|  Loose Coupling | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.header .ui.label { | ||||
|   font-size: @labelSize; | ||||
|   margin-left: @labelDistance; | ||||
|   vertical-align: @labelVerticalAlign; | ||||
| } | ||||
|  | ||||
| /* Positioning */ | ||||
| .ui.header + p { | ||||
|   margin-top: @nextParagraphDistance; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Types | ||||
| *******************************/ | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|      Page | ||||
| ---------------*/ | ||||
|  | ||||
| h1.ui.header { | ||||
|   font-size: @h1; | ||||
| } | ||||
| h2.ui.header { | ||||
|   font-size: @h2; | ||||
| } | ||||
| h3.ui.header { | ||||
|   font-size: @h3; | ||||
| } | ||||
| h4.ui.header { | ||||
|   font-size: @h4; | ||||
| } | ||||
| h5.ui.header { | ||||
|   font-size: @h5; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Sub Header */ | ||||
| h1.ui.header .sub.header { | ||||
|   font-size: @h1SubHeaderFontSize; | ||||
| } | ||||
| h2.ui.header .sub.header { | ||||
|   font-size: @h2SubHeaderFontSize; | ||||
| } | ||||
| h3.ui.header .sub.header { | ||||
|   font-size: @h3SubHeaderFontSize; | ||||
| } | ||||
| h4.ui.header .sub.header { | ||||
|   font-size: @h4SubHeaderFontSize; | ||||
| } | ||||
| h5.ui.header .sub.header { | ||||
|   font-size: @h5SubHeaderFontSize; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|  Content Heading | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.huge.header { | ||||
|   min-height: 1em; | ||||
|   font-size: @hugeFontSize; | ||||
| } | ||||
| .ui.large.header { | ||||
|   font-size: @largeFontSize; | ||||
| } | ||||
| .ui.medium.header { | ||||
|   font-size: @mediumFontSize; | ||||
| } | ||||
| .ui.small.header { | ||||
|   font-size: @smallFontSize; | ||||
| } | ||||
| .ui.tiny.header { | ||||
|   font-size: @tinyFontSize; | ||||
| } | ||||
|  | ||||
| /* Sub Header */ | ||||
| .ui.huge.header .sub.header { | ||||
|   font-size: @hugeSubHeaderFontSize; | ||||
| } | ||||
| .ui.large.header .sub.header { | ||||
|   font-size: @hugeSubHeaderFontSize; | ||||
| } | ||||
| .ui.header .sub.header { | ||||
|   font-size: @subHeaderFontSize; | ||||
| } | ||||
| .ui.small.header .sub.header { | ||||
|   font-size: @smallSubHeaderFontSize; | ||||
| } | ||||
| .ui.tiny.header .sub.header { | ||||
|   font-size: @tinySubHeaderFontSize; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|    Sub Heading | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.sub.header { | ||||
|   padding: 0em; | ||||
|   margin-bottom: @subHeadingDistance; | ||||
|   font-weight: @subHeadingFontWeight; | ||||
|   font-size: @subHeadingFontSize; | ||||
|   text-transform: @subHeadingTextTransform; | ||||
|   color: @subHeadingColor; | ||||
| } | ||||
|  | ||||
| .ui.small.sub.header { | ||||
|   font-size: @smallSubHeadingSize; | ||||
| } | ||||
| .ui.sub.header { | ||||
|   font-size: @subHeadingFontSize; | ||||
| } | ||||
| .ui.large.sub.header { | ||||
|   font-size: @largeSubHeadingSize; | ||||
| } | ||||
| .ui.huge.sub.header { | ||||
|   font-size: @hugeSubHeadingSize; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|         Icon | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.icon.header { | ||||
|   display: inline-block; | ||||
|   text-align: center; | ||||
|   margin: @iconHeaderTopMargin 0em @iconHeaderBottomMargin; | ||||
| } | ||||
| .ui.icon.header:after { | ||||
|   content: ''; | ||||
|   display: block; | ||||
|   height: 0px; | ||||
|   clear: both; | ||||
|   visibility: hidden; | ||||
| } | ||||
|  | ||||
| .ui.icon.header:first-child { | ||||
|   margin-top: @iconHeaderFirstMargin; | ||||
| } | ||||
| .ui.icon.header .icon { | ||||
|   float: none; | ||||
|   display: block; | ||||
|   width: auto; | ||||
|   height: auto; | ||||
|   line-height: 1; | ||||
|   padding: 0em; | ||||
|   font-size: @iconHeaderSize; | ||||
|   margin: 0em auto @iconHeaderMargin; | ||||
|   opacity: @iconHeaderOpacity; | ||||
| } | ||||
| .ui.icon.header .content { | ||||
|   display: block; | ||||
|   padding: 0em; | ||||
| } | ||||
| .ui.icon.header .circular.icon { | ||||
|   font-size: @circularHeaderIconSize; | ||||
| } | ||||
| .ui.icon.header .square.icon { | ||||
|   font-size: @squareHeaderIconSize; | ||||
| } | ||||
| .ui.block.icon.header .icon { | ||||
|   margin-bottom: 0em; | ||||
| } | ||||
| .ui.icon.header.aligned { | ||||
|   margin-left: auto; | ||||
|   margin-right: auto; | ||||
|   display: block; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|             States | ||||
| *******************************/ | ||||
|  | ||||
| .ui.disabled.header { | ||||
|   opacity: @disabledOpacity; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|            Variations | ||||
| *******************************/ | ||||
|  | ||||
| /*------------------- | ||||
|       Inverted | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.inverted.header { | ||||
|   color: @invertedColor; | ||||
| } | ||||
| .ui.inverted.header .sub.header { | ||||
|   color: @invertedSubHeaderColor; | ||||
| } | ||||
| .ui.inverted.attached.header { | ||||
|   background: @invertedAttachedBackground; | ||||
|   box-shadow: none; | ||||
|   border-color: transparent; | ||||
| } | ||||
| .ui.inverted.block.header { | ||||
|   background: @invertedBlockBackground; | ||||
|   box-shadow: none; | ||||
| } | ||||
| .ui.inverted.block.header { | ||||
|   border-bottom: none; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|        Colors | ||||
| --------------------*/ | ||||
|  | ||||
| /*--- Red ---*/ | ||||
| .ui.red.header { | ||||
|   color: @red !important; | ||||
| } | ||||
| a.ui.red.header:hover { | ||||
|   color: @redHover !important; | ||||
| } | ||||
| .ui.red.dividing.header { | ||||
|   border-bottom: @dividedColoredBorderWidth solid @red; | ||||
| } | ||||
|  | ||||
| /* Inverted */ | ||||
| .ui.inverted.red.header { | ||||
|   color: @lightRed !important; | ||||
| } | ||||
| a.ui.inverted.red.header:hover { | ||||
|   color: @lightRedHover !important; | ||||
| } | ||||
|  | ||||
| /*--- Orange ---*/ | ||||
| .ui.orange.header { | ||||
|   color: @orange !important; | ||||
| } | ||||
| a.ui.orange.header:hover { | ||||
|   color: @orangeHover !important; | ||||
| } | ||||
| .ui.orange.dividing.header { | ||||
|   border-bottom: @dividedColoredBorderWidth solid @orange; | ||||
| } | ||||
| /* Inverted */ | ||||
| .ui.inverted.orange.header { | ||||
|   color: @lightOrange !important; | ||||
| } | ||||
| a.ui.inverted.orange.header:hover { | ||||
|   color: @lightOrangeHover !important; | ||||
| } | ||||
|  | ||||
| /*--- Olive ---*/ | ||||
| .ui.olive.header { | ||||
|   color: @olive !important; | ||||
| } | ||||
| a.ui.olive.header:hover { | ||||
|   color: @oliveHover !important; | ||||
| } | ||||
| .ui.olive.dividing.header { | ||||
|   border-bottom: @dividedColoredBorderWidth solid @olive; | ||||
| } | ||||
| /* Inverted */ | ||||
| .ui.inverted.olive.header { | ||||
|   color: @lightOlive !important; | ||||
| } | ||||
| a.ui.inverted.olive.header:hover { | ||||
|   color: @lightOliveHover !important; | ||||
| } | ||||
|  | ||||
| /*--- Yellow ---*/ | ||||
| .ui.yellow.header { | ||||
|   color: @yellow !important; | ||||
| } | ||||
| a.ui.yellow.header:hover { | ||||
|   color: @yellowHover !important; | ||||
| } | ||||
| .ui.yellow.dividing.header { | ||||
|   border-bottom: @dividedColoredBorderWidth solid @yellow; | ||||
| } | ||||
| /* Inverted */ | ||||
| .ui.inverted.yellow.header { | ||||
|   color: @lightYellow !important; | ||||
| } | ||||
| a.ui.inverted.yellow.header:hover { | ||||
|   color: @lightYellowHover !important; | ||||
| } | ||||
|  | ||||
| /*--- Green ---*/ | ||||
| .ui.green.header { | ||||
|   color: @green !important; | ||||
| } | ||||
| a.ui.green.header:hover { | ||||
|   color: @greenHover !important; | ||||
| } | ||||
| .ui.green.dividing.header { | ||||
|   border-bottom: @dividedColoredBorderWidth solid @green; | ||||
| } | ||||
| /* Inverted */ | ||||
| .ui.inverted.green.header { | ||||
|   color: @lightGreen !important; | ||||
| } | ||||
| a.ui.inverted.green.header:hover { | ||||
|   color: @lightGreenHover !important; | ||||
| } | ||||
|  | ||||
| /*--- Teal ---*/ | ||||
| .ui.teal.header { | ||||
|   color: @teal !important; | ||||
| } | ||||
| a.ui.teal.header:hover { | ||||
|   color: @tealHover !important; | ||||
| } | ||||
| .ui.teal.dividing.header { | ||||
|   border-bottom: @dividedColoredBorderWidth solid @teal; | ||||
| } | ||||
| /* Inverted */ | ||||
| .ui.inverted.teal.header { | ||||
|   color: @lightTeal !important; | ||||
| } | ||||
| a.ui.inverted.teal.header:hover { | ||||
|   color: @lightTealHover !important; | ||||
| } | ||||
|  | ||||
| /*--- Blue ---*/ | ||||
| .ui.blue.header { | ||||
|   color: @blue !important; | ||||
| } | ||||
| a.ui.blue.header:hover { | ||||
|   color: @blueHover !important; | ||||
| } | ||||
| .ui.blue.dividing.header { | ||||
|   border-bottom: @dividedColoredBorderWidth solid @blue; | ||||
| } | ||||
| /* Inverted */ | ||||
| .ui.inverted.blue.header { | ||||
|   color: @lightBlue !important; | ||||
| } | ||||
| a.ui.inverted.blue.header:hover { | ||||
|   color: @lightBlueHover !important; | ||||
| } | ||||
|  | ||||
| /*--- Violet ---*/ | ||||
| .ui.violet.header { | ||||
|   color: @violet !important; | ||||
| } | ||||
| a.ui.violet.header:hover { | ||||
|   color: @violetHover !important; | ||||
| } | ||||
| .ui.violet.dividing.header { | ||||
|   border-bottom: @dividedColoredBorderWidth solid @violet; | ||||
| } | ||||
| /* Inverted */ | ||||
| .ui.inverted.violet.header { | ||||
|   color: @lightViolet !important; | ||||
| } | ||||
| a.ui.inverted.violet.header:hover { | ||||
|   color: @lightVioletHover !important; | ||||
| } | ||||
|  | ||||
| /*--- Purple ---*/ | ||||
| .ui.purple.header { | ||||
|   color: @purple !important; | ||||
| } | ||||
| a.ui.purple.header:hover { | ||||
|   color: @purpleHover !important; | ||||
| } | ||||
| .ui.purple.dividing.header { | ||||
|   border-bottom: @dividedColoredBorderWidth solid @purple; | ||||
| } | ||||
| /* Inverted */ | ||||
| .ui.inverted.purple.header { | ||||
|   color: @lightPurple !important; | ||||
| } | ||||
| a.ui.inverted.purple.header:hover { | ||||
|   color: @lightPurpleHover !important; | ||||
| } | ||||
|  | ||||
| /*--- Pink ---*/ | ||||
| .ui.pink.header { | ||||
|   color: @pink !important; | ||||
| } | ||||
| a.ui.pink.header:hover { | ||||
|   color: @pinkHover !important; | ||||
| } | ||||
| .ui.pink.dividing.header { | ||||
|   border-bottom: @dividedColoredBorderWidth solid @pink; | ||||
| } | ||||
| /* Inverted */ | ||||
| .ui.inverted.pink.header { | ||||
|   color: @lightPink !important; | ||||
| } | ||||
| a.ui.inverted.pink.header:hover { | ||||
|   color: @lightPinkHover !important; | ||||
| } | ||||
|  | ||||
| /*--- Brown ---*/ | ||||
| .ui.brown.header { | ||||
|   color: @brown !important; | ||||
| } | ||||
| a.ui.brown.header:hover { | ||||
|   color: @brownHover !important; | ||||
| } | ||||
| .ui.brown.dividing.header { | ||||
|   border-bottom: @dividedColoredBorderWidth solid @brown; | ||||
| } | ||||
| /* Inverted */ | ||||
| .ui.inverted.brown.header { | ||||
|   color: @lightBrown !important; | ||||
| } | ||||
| a.ui.inverted.brown.header:hover { | ||||
|   color: @lightBrownHover !important; | ||||
| } | ||||
|  | ||||
| /*--- Grey ---*/ | ||||
| .ui.grey.header { | ||||
|   color: @grey !important; | ||||
| } | ||||
| a.ui.grey.header:hover { | ||||
|   color: @greyHover !important; | ||||
| } | ||||
| .ui.grey.dividing.header { | ||||
|   border-bottom: @dividedColoredBorderWidth solid @grey; | ||||
| } | ||||
| /* Inverted */ | ||||
| .ui.inverted.grey.header { | ||||
|   color: @lightGrey !important; | ||||
| } | ||||
| a.ui.inverted.grey.header:hover { | ||||
|   color: @lightGreyHover !important; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|        Aligned | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.left.aligned.header { | ||||
|   text-align: left; | ||||
| } | ||||
| .ui.right.aligned.header { | ||||
|   text-align: right; | ||||
| } | ||||
| .ui.centered.header, | ||||
| .ui.center.aligned.header { | ||||
|   text-align: center; | ||||
| } | ||||
| .ui.justified.header { | ||||
|   text-align: justify; | ||||
| } | ||||
| .ui.justified.header:after { | ||||
|   display: inline-block; | ||||
|   content: ''; | ||||
|   width: 100%; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Floated | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.floated.header, | ||||
| .ui[class*="left floated"].header { | ||||
|   float: left; | ||||
|   margin-top: 0em; | ||||
|   margin-right: @floatedMargin; | ||||
| } | ||||
| .ui[class*="right floated"].header { | ||||
|   float: right; | ||||
|   margin-top: 0em; | ||||
|   margin-left: @floatedMargin; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Fitted | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.fitted.header { | ||||
|   padding: 0em; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|       Dividing | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.dividing.header { | ||||
|   padding-bottom: @dividedBorderPadding; | ||||
|   border-bottom: @dividedBorder; | ||||
| } | ||||
| .ui.dividing.header .sub.header { | ||||
|   padding-bottom: @dividedSubHeaderPadding; | ||||
| } | ||||
| .ui.dividing.header .icon { | ||||
|   margin-bottom: @dividedIconPadding; | ||||
| } | ||||
|  | ||||
| .ui.inverted.dividing.header { | ||||
|   border-bottom-color: @invertedDividedBorderColor; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|         Block | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.block.header { | ||||
|   background: @blockBackground; | ||||
|   padding: @blockVerticalPadding @blockHorizontalPadding; | ||||
|   box-shadow: @blockBoxShadow; | ||||
|   border: @blockBorder; | ||||
|   border-radius: @blockBorderRadius; | ||||
| } | ||||
|  | ||||
| .ui.tiny.block.header { | ||||
|   font-size: @tinyBlock; | ||||
| } | ||||
| .ui.small.block.header { | ||||
|   font-size: @smallBlock; | ||||
| } | ||||
| .ui.block.header:not(h1):not(h2):not(h3):not(h4):not(h5):not(h6) { | ||||
|   font-size: @mediumBlock; | ||||
| } | ||||
| .ui.large.block.header { | ||||
|   font-size: @largeBlock; | ||||
| } | ||||
| .ui.huge.block.header { | ||||
|   font-size: @hugeBlock; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Attached | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.attached.header { | ||||
|   background: @attachedBackground; | ||||
|   padding: @attachedVerticalPadding @attachedHorizontalPadding; | ||||
|   margin-left: @attachedOffset; | ||||
|   margin-right: @attachedOffset; | ||||
|   box-shadow: @attachedBoxShadow; | ||||
|   border: @attachedBorder; | ||||
| } | ||||
| .ui.attached.block.header { | ||||
|   background: @blockBackground; | ||||
| } | ||||
|  | ||||
| .ui.attached:not(.top):not(.bottom).header { | ||||
|   margin-top: 0em; | ||||
|   margin-bottom: 0em; | ||||
|   border-top: none; | ||||
|   border-radius: 0em; | ||||
| } | ||||
| .ui.top.attached.header { | ||||
|   margin-bottom: 0em; | ||||
|   border-radius: @attachedBorderRadius @attachedBorderRadius 0em 0em; | ||||
| } | ||||
| .ui.bottom.attached.header { | ||||
|   margin-top: 0em; | ||||
|   border-top: none; | ||||
|   border-radius: 0em 0em @attachedBorderRadius @attachedBorderRadius; | ||||
| } | ||||
|  | ||||
| /* Attached Sizes */ | ||||
| .ui.tiny.attached.header { | ||||
|   font-size: @tinyAttachedSize; | ||||
| } | ||||
| .ui.small.attached.header { | ||||
|   font-size: @smallAttachedSize; | ||||
| } | ||||
| .ui.attached.header:not(h1):not(h2):not(h3):not(h4):not(h5):not(h6) { | ||||
|   font-size: @mediumAttachedSize; | ||||
| } | ||||
| .ui.large.attached.header { | ||||
|   font-size: @largeAttachedSize; | ||||
| } | ||||
| .ui.huge.attached.header { | ||||
|   font-size: @hugeAttachedSize; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|         Sizing | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.header:not(h1):not(h2):not(h3):not(h4):not(h5):not(h6) { | ||||
|   font-size: @mediumFontSize; | ||||
| } | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,501 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Icon | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'element'; | ||||
| @element : 'icon'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|              Icon | ||||
| *******************************/ | ||||
|  | ||||
| @font-face { | ||||
|   font-family: 'Icons'; | ||||
|   src: @fallbackSRC; | ||||
|   src: @src; | ||||
|   font-style: normal; | ||||
|   font-weight: @normal; | ||||
|   font-variant: normal; | ||||
|   text-decoration: inherit; | ||||
|   text-transform: none; | ||||
| } | ||||
|  | ||||
| i.icon { | ||||
|   display: inline-block; | ||||
|   opacity: @opacity; | ||||
|  | ||||
|   margin: 0em @distanceFromText 0em 0em; | ||||
|  | ||||
|   width: @width; | ||||
|   height: @height; | ||||
|  | ||||
|   font-family: 'Icons'; | ||||
|   font-style: normal; | ||||
|   font-weight: @normal; | ||||
|   text-decoration: inherit; | ||||
|   text-align: center; | ||||
|  | ||||
|   speak: none; | ||||
|   font-smoothing: antialiased; | ||||
|   -moz-osx-font-smoothing: grayscale; | ||||
|   -webkit-font-smoothing: antialiased; | ||||
|   backface-visibility: hidden; | ||||
| } | ||||
|  | ||||
| i.icon:before { | ||||
|   background: none !important; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|              Types | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|     Loading | ||||
| ---------------*/ | ||||
|  | ||||
| i.icon.loading { | ||||
|   height: 1em; | ||||
|   line-height: 1; | ||||
|   animation: icon-loading @loadingDuration linear infinite; | ||||
| } | ||||
| @keyframes icon-loading { | ||||
|  from { | ||||
|     transform: rotate(0deg); | ||||
|  } | ||||
|  to { | ||||
|     transform: rotate(360deg); | ||||
|  } | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|              States | ||||
| *******************************/ | ||||
|  | ||||
| i.icon.hover { | ||||
|   opacity: 1 !important; | ||||
| } | ||||
|  | ||||
| i.icon.active { | ||||
|   opacity: 1 !important; | ||||
| } | ||||
|  | ||||
| i.emphasized.icon { | ||||
|   opacity: 1 !important; | ||||
| } | ||||
|  | ||||
| i.disabled.icon { | ||||
|   opacity: @disabledOpacity !important; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|            Variations | ||||
| *******************************/ | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|         Fitted | ||||
| --------------------*/ | ||||
|  | ||||
| i.fitted.icon { | ||||
|   width: auto; | ||||
|   margin: 0em !important; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|          Link | ||||
| --------------------*/ | ||||
|  | ||||
| i.link.icon, i.link.icons { | ||||
|   cursor: pointer; | ||||
|   opacity: @linkOpacity; | ||||
|   transition: opacity @defaultDuration @defaultEasing; | ||||
| } | ||||
| i.link.icon:hover, i.link.icons:hover { | ||||
|   opacity: 1 !important; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|       Circular | ||||
| --------------------*/ | ||||
|  | ||||
| i.circular.icon { | ||||
|   border-radius: 500em !important; | ||||
|   line-height: 1 !important; | ||||
|  | ||||
|   padding: @circularPadding !important; | ||||
|   box-shadow: @circularShadow; | ||||
|  | ||||
|   width: @circularSize !important; | ||||
|   height: @circularSize !important; | ||||
| } | ||||
| i.circular.inverted.icon { | ||||
|   border: none; | ||||
|   box-shadow: none; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|       Flipped | ||||
| --------------------*/ | ||||
|  | ||||
| i.flipped.icon, | ||||
| i.horizontally.flipped.icon { | ||||
|   transform: scale(-1, 1); | ||||
| } | ||||
| i.vertically.flipped.icon { | ||||
|   transform: scale(1, -1); | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|       Rotated | ||||
| --------------------*/ | ||||
|  | ||||
| i.rotated.icon, | ||||
| i.right.rotated.icon, | ||||
| i.clockwise.rotated.icon { | ||||
|   transform: rotate(90deg); | ||||
| } | ||||
|  | ||||
| i.left.rotated.icon, | ||||
| i.counterclockwise.rotated.icon { | ||||
|   transform: rotate(-90deg); | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|       Bordered | ||||
| --------------------*/ | ||||
|  | ||||
| i.bordered.icon { | ||||
|   line-height: 1; | ||||
|   vertical-align: baseline; | ||||
|  | ||||
|   width: @borderedSize; | ||||
|   height: @borderedSize; | ||||
|   padding: @borderedVerticalPadding @borderedHorizontalPadding !important; | ||||
|   box-shadow: @borderedShadow; | ||||
| } | ||||
| i.bordered.inverted.icon { | ||||
|   border: none; | ||||
|   box-shadow: none; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|       Inverted | ||||
| --------------------*/ | ||||
|  | ||||
| /* Inverted Shapes */ | ||||
| i.inverted.bordered.icon, | ||||
| i.inverted.circular.icon { | ||||
|   background-color: @black !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| i.inverted.icon { | ||||
|   color: @white; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|        Colors | ||||
| --------------------*/ | ||||
|  | ||||
| /* Red */ | ||||
| i.red.icon { | ||||
|   color: @red !important; | ||||
| } | ||||
| i.inverted.red.icon { | ||||
|   color: @lightRed !important; | ||||
| } | ||||
| i.inverted.bordered.red.icon, | ||||
| i.inverted.circular.red.icon { | ||||
|   background-color: @red !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Orange */ | ||||
| i.orange.icon { | ||||
|   color: @orange !important; | ||||
| } | ||||
| i.inverted.orange.icon { | ||||
|   color: @lightOrange !important; | ||||
| } | ||||
| i.inverted.bordered.orange.icon, | ||||
| i.inverted.circular.orange.icon { | ||||
|   background-color: @orange !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Yellow */ | ||||
| i.yellow.icon { | ||||
|   color: @yellow !important; | ||||
| } | ||||
| i.inverted.yellow.icon { | ||||
|   color: @lightYellow !important; | ||||
| } | ||||
| i.inverted.bordered.yellow.icon, | ||||
| i.inverted.circular.yellow.icon { | ||||
|   background-color: @yellow !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Olive */ | ||||
| i.olive.icon { | ||||
|   color: @olive !important; | ||||
| } | ||||
| i.inverted.olive.icon { | ||||
|   color: @lightOlive !important; | ||||
| } | ||||
| i.inverted.bordered.olive.icon, | ||||
| i.inverted.circular.olive.icon { | ||||
|   background-color: @olive !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Green */ | ||||
| i.green.icon { | ||||
|   color: @green !important; | ||||
| } | ||||
| i.inverted.green.icon { | ||||
|   color: @lightGreen !important; | ||||
| } | ||||
| i.inverted.bordered.green.icon, | ||||
| i.inverted.circular.green.icon { | ||||
|   background-color: @green !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Teal */ | ||||
| i.teal.icon { | ||||
|   color: @teal !important; | ||||
| } | ||||
| i.inverted.teal.icon { | ||||
|   color: @lightTeal !important; | ||||
| } | ||||
| i.inverted.bordered.teal.icon, | ||||
| i.inverted.circular.teal.icon { | ||||
|   background-color: @teal !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Blue */ | ||||
| i.blue.icon { | ||||
|   color: @blue !important; | ||||
| } | ||||
| i.inverted.blue.icon { | ||||
|   color: @lightBlue !important; | ||||
| } | ||||
| i.inverted.bordered.blue.icon, | ||||
| i.inverted.circular.blue.icon { | ||||
|   background-color: @blue !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Violet */ | ||||
| i.violet.icon { | ||||
|   color: @violet !important; | ||||
| } | ||||
| i.inverted.violet.icon { | ||||
|   color: @lightViolet !important; | ||||
| } | ||||
| i.inverted.bordered.violet.icon, | ||||
| i.inverted.circular.violet.icon { | ||||
|   background-color: @violet !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Purple */ | ||||
| i.purple.icon { | ||||
|   color: @purple !important; | ||||
| } | ||||
| i.inverted.purple.icon { | ||||
|   color: @lightPurple !important; | ||||
| } | ||||
| i.inverted.bordered.purple.icon, | ||||
| i.inverted.circular.purple.icon { | ||||
|   background-color: @purple !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Pink */ | ||||
| i.pink.icon { | ||||
|   color: @pink !important; | ||||
| } | ||||
| i.inverted.pink.icon { | ||||
|   color: @lightPink !important; | ||||
| } | ||||
| i.inverted.bordered.pink.icon, | ||||
| i.inverted.circular.pink.icon { | ||||
|   background-color: @pink !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Brown */ | ||||
| i.brown.icon { | ||||
|   color: @brown !important; | ||||
| } | ||||
| i.inverted.brown.icon { | ||||
|   color: @lightBrown !important; | ||||
| } | ||||
| i.inverted.bordered.brown.icon, | ||||
| i.inverted.circular.brown.icon { | ||||
|   background-color: @brown !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Grey */ | ||||
| i.grey.icon { | ||||
|   color: @grey !important; | ||||
| } | ||||
| i.inverted.grey.icon { | ||||
|   color: @lightGrey !important; | ||||
| } | ||||
| i.inverted.bordered.grey.icon, | ||||
| i.inverted.circular.grey.icon { | ||||
|   background-color: @grey !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Black */ | ||||
| i.black.icon { | ||||
|   color: @black !important; | ||||
| } | ||||
| i.inverted.black.icon { | ||||
|   color: @lightBlack !important; | ||||
| } | ||||
| i.inverted.bordered.black.icon, | ||||
| i.inverted.circular.black.icon { | ||||
|   background-color: @black !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|         Sizes | ||||
| --------------------*/ | ||||
|  | ||||
| i.mini.icon, | ||||
| i.mini.icons { | ||||
|   line-height: 1; | ||||
|   font-size: @mini; | ||||
| } | ||||
| i.tiny.icon, | ||||
| i.tiny.icons { | ||||
|   line-height: 1; | ||||
|   font-size: @tiny; | ||||
| } | ||||
| i.small.icon, | ||||
| i.small.icons { | ||||
|   line-height: 1; | ||||
|   font-size: @small; | ||||
| } | ||||
| i.icon, | ||||
| i.icons { | ||||
|   font-size: @medium; | ||||
| } | ||||
| i.large.icon, | ||||
| i.large.icons { | ||||
|   line-height: 1; | ||||
|   vertical-align: middle; | ||||
|   font-size: @large; | ||||
| } | ||||
| i.big.icon, | ||||
| i.big.icons { | ||||
|   line-height: 1; | ||||
|   vertical-align: middle; | ||||
|   font-size: @big; | ||||
| } | ||||
| i.huge.icon, | ||||
| i.huge.icons { | ||||
|   line-height: 1; | ||||
|   vertical-align: middle; | ||||
|   font-size: @huge; | ||||
| } | ||||
| i.massive.icon, | ||||
| i.massive.icons { | ||||
|   line-height: 1; | ||||
|   vertical-align: middle; | ||||
|   font-size: @massive; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|             Groups | ||||
| *******************************/ | ||||
|  | ||||
| i.icons { | ||||
|   display: inline-block; | ||||
|   position: relative; | ||||
|   line-height: 1; | ||||
| } | ||||
|  | ||||
| i.icons .icon { | ||||
|   position: absolute; | ||||
|   top: 50%; | ||||
|   left: 50%; | ||||
|   transform: translateX(-50%) translateY(-50%); | ||||
|   margin: 0em; | ||||
|   margin: 0; | ||||
| } | ||||
|  | ||||
| i.icons .icon:first-child { | ||||
|   position: static; | ||||
|   width: auto; | ||||
|   height: auto; | ||||
|   vertical-align: top; | ||||
|   transform: none; | ||||
|   margin-right: @distanceFromText; | ||||
| } | ||||
|  | ||||
| /* Corner Icon */ | ||||
| i.icons .corner.icon { | ||||
|   top: auto; | ||||
|   left: auto; | ||||
|   right: 0; | ||||
|   bottom: 0; | ||||
|   transform: none; | ||||
|   font-size: @cornerIconSize; | ||||
|   text-shadow: @cornerIconShadow; | ||||
| } | ||||
| i.icons .top.right.corner.icon { | ||||
|   top: 0; | ||||
|   left: auto; | ||||
|   right: 0; | ||||
|   bottom: auto; | ||||
| } | ||||
| i.icons .top.left.corner.icon { | ||||
|   top: 0; | ||||
|   left: 0; | ||||
|   right: auto; | ||||
|   bottom: auto; | ||||
| } | ||||
| i.icons .bottom.left.corner.icon { | ||||
|   top: auto; | ||||
|   left: 0; | ||||
|   right: auto; | ||||
|   bottom: 0; | ||||
| } | ||||
| i.icons .bottom.right.corner.icon { | ||||
|   top: auto; | ||||
|   left: auto; | ||||
|   right: 0; | ||||
|   bottom: 0; | ||||
| } | ||||
|  | ||||
| i.icons .inverted.corner.icon { | ||||
|   text-shadow: @cornerIconInvertedShadow; | ||||
| } | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,328 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Image | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'element'; | ||||
| @element : 'image'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|              Image | ||||
| *******************************/ | ||||
|  | ||||
| .ui.image { | ||||
|   position: relative; | ||||
|   display: inline-block; | ||||
|   vertical-align: middle; | ||||
|   max-width: 100%; | ||||
|   background-color: @placeholderColor; | ||||
| } | ||||
|  | ||||
| img.ui.image { | ||||
|   display: block; | ||||
| } | ||||
|  | ||||
| .ui.image svg, | ||||
| .ui.image img { | ||||
|   display: block; | ||||
|   max-width: 100%; | ||||
|   height: auto; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             States | ||||
| *******************************/ | ||||
|  | ||||
| .ui.hidden.images, | ||||
| .ui.hidden.image { | ||||
|   display: none; | ||||
| } | ||||
| .ui.hidden.transition.images, | ||||
| .ui.hidden.transition.image { | ||||
|   display: block; | ||||
|   visibility: hidden; | ||||
| } | ||||
| .ui.images > .hidden.transition { | ||||
|   display: inline-block; | ||||
|   visibility: hidden; | ||||
| } | ||||
|  | ||||
|  | ||||
| .ui.disabled.images, | ||||
| .ui.disabled.image { | ||||
|   cursor: default; | ||||
|   opacity: @disabledOpacity; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|           Variations | ||||
| *******************************/ | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|      Inline | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.inline.image, | ||||
| .ui.inline.image svg, | ||||
| .ui.inline.image img { | ||||
|   display: inline-block; | ||||
| } | ||||
|  | ||||
| /*------------------ | ||||
|   Vertical Aligned | ||||
| -------------------*/ | ||||
|  | ||||
| .ui.top.aligned.images .image, | ||||
| .ui.top.aligned.image, | ||||
| .ui.top.aligned.image svg, | ||||
| .ui.top.aligned.image img { | ||||
|   display: inline-block; | ||||
|   vertical-align: top; | ||||
| } | ||||
| .ui.middle.aligned.images .image, | ||||
| .ui.middle.aligned.image, | ||||
| .ui.middle.aligned.image svg, | ||||
| .ui.middle.aligned.image img { | ||||
|   display: inline-block; | ||||
|   vertical-align: middle; | ||||
| } | ||||
| .ui.bottom.aligned.images .image, | ||||
| .ui.bottom.aligned.image, | ||||
| .ui.bottom.aligned.image svg, | ||||
| .ui.bottom.aligned.image img { | ||||
|   display: inline-block; | ||||
|   vertical-align: bottom; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Rounded | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.rounded.images .image, | ||||
| .ui.rounded.image, | ||||
| .ui.rounded.images .image > *, | ||||
| .ui.rounded.image > * { | ||||
|   border-radius: @roundedBorderRadius; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Bordered | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.bordered.images .image, | ||||
| .ui.bordered.images img, | ||||
| .ui.bordered.images svg, | ||||
| .ui.bordered.image img, | ||||
| .ui.bordered.image svg, | ||||
| img.ui.bordered.image { | ||||
|   border: @imageBorder; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Circular | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.circular.images, | ||||
| .ui.circular.image { | ||||
|   overflow: hidden; | ||||
| } | ||||
|  | ||||
| .ui.circular.images .image, | ||||
| .ui.circular.image, | ||||
| .ui.circular.images .image > *, | ||||
| .ui.circular.image > * { | ||||
|   -webkit-border-radius: @circularRadius; | ||||
|   -moz-border-radius: @circularRadius; | ||||
|   border-radius: @circularRadius; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Fluid | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.fluid.images, | ||||
| .ui.fluid.image, | ||||
| .ui.fluid.images img, | ||||
| .ui.fluid.images svg, | ||||
| .ui.fluid.image svg, | ||||
| .ui.fluid.image img { | ||||
|   display: block; | ||||
|   width: 100%; | ||||
|   height: auto; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|      Avatar | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.avatar.images .image, | ||||
| .ui.avatar.images img, | ||||
| .ui.avatar.images svg, | ||||
| .ui.avatar.image img, | ||||
| .ui.avatar.image svg, | ||||
| .ui.avatar.image { | ||||
|   margin-right: @avatarMargin; | ||||
|  | ||||
|   display: inline-block; | ||||
|   width: @avatarSize; | ||||
|   height: @avatarSize; | ||||
|  | ||||
|   -webkit-border-radius: @circularRadius; | ||||
|   -moz-border-radius: @circularRadius; | ||||
|   border-radius: @circularRadius; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Spaced | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.spaced.image { | ||||
|   display: inline-block !important; | ||||
|   margin-left: @spacedDistance; | ||||
|   margin-right: @spacedDistance; | ||||
| } | ||||
|  | ||||
| .ui[class*="left spaced"].image { | ||||
|   margin-left: @spacedDistance; | ||||
|   margin-right: 0em; | ||||
| } | ||||
|  | ||||
| .ui[class*="right spaced"].image { | ||||
|   margin-left: 0em; | ||||
|   margin-right: @spacedDistance; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Floated | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.floated.image, | ||||
| .ui.floated.images { | ||||
|   float: left; | ||||
|   margin-right: @floatedHorizontalMargin; | ||||
|   margin-bottom: @floatedVerticalMargin; | ||||
| } | ||||
| .ui.right.floated.images, | ||||
| .ui.right.floated.image { | ||||
|   float: right; | ||||
|   margin-right: 0em; | ||||
|   margin-bottom: @floatedVerticalMargin; | ||||
|   margin-left: @floatedHorizontalMargin; | ||||
| } | ||||
|  | ||||
| .ui.floated.images:last-child, | ||||
| .ui.floated.image:last-child { | ||||
|   margin-bottom: 0em; | ||||
| } | ||||
|  | ||||
|  | ||||
| .ui.centered.images, | ||||
| .ui.centered.image { | ||||
|   margin-left: auto; | ||||
|   margin-right: auto; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Sizes | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.mini.images .image, | ||||
| .ui.mini.images img, | ||||
| .ui.mini.images svg, | ||||
| .ui.mini.image { | ||||
|   width: @miniWidth; | ||||
|   height: auto; | ||||
|   font-size: @mini; | ||||
| } | ||||
| .ui.tiny.images .image, | ||||
| .ui.tiny.images img, | ||||
| .ui.tiny.images svg, | ||||
| .ui.tiny.image { | ||||
|   width: @tinyWidth; | ||||
|   height: auto; | ||||
|   font-size: @tiny; | ||||
| } | ||||
| .ui.small.images .image, | ||||
| .ui.small.images img, | ||||
| .ui.small.images svg, | ||||
| .ui.small.image { | ||||
|   width: @smallWidth; | ||||
|   height: auto; | ||||
|   font-size: @small; | ||||
| } | ||||
| .ui.medium.images .image, | ||||
| .ui.medium.images img, | ||||
| .ui.medium.images svg, | ||||
| .ui.medium.image { | ||||
|   width: @mediumWidth; | ||||
|   height: auto; | ||||
|   font-size: @medium; | ||||
| } | ||||
| .ui.large.images .image, | ||||
| .ui.large.images img, | ||||
| .ui.large.images svg, | ||||
| .ui.large.image { | ||||
|   width: @largeWidth; | ||||
|   height: auto; | ||||
|   font-size: @large; | ||||
| } | ||||
| .ui.big.images .image, | ||||
| .ui.big.images img, | ||||
| .ui.big.images svg, | ||||
| .ui.big.image { | ||||
|   width: @bigWidth; | ||||
|   height: auto; | ||||
|   font-size: @big; | ||||
| } | ||||
| .ui.huge.images .image, | ||||
| .ui.huge.images img, | ||||
| .ui.huge.images svg, | ||||
| .ui.huge.image { | ||||
|   width: @hugeWidth; | ||||
|   height: auto; | ||||
|   font-size: @huge; | ||||
| } | ||||
| .ui.massive.images .image, | ||||
| .ui.massive.images img, | ||||
| .ui.massive.images svg, | ||||
| .ui.massive.image { | ||||
|   width: @massiveWidth; | ||||
|   height: auto; | ||||
|   font-size: @massive; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|               Groups | ||||
| *******************************/ | ||||
|  | ||||
| .ui.images { | ||||
|   font-size: 0em; | ||||
|   margin: 0em -@imageHorizontalMargin 0rem; | ||||
| } | ||||
|  | ||||
| .ui.images .image, | ||||
| .ui.images > img, | ||||
| .ui.images > svg { | ||||
|   display: inline-block; | ||||
|   margin: 0em @imageHorizontalMargin @imageVerticalMargin; | ||||
| } | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,508 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Input | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'element'; | ||||
| @element : 'input'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|            Standard | ||||
| *******************************/ | ||||
|  | ||||
|  | ||||
| /*-------------------- | ||||
|         Inputs | ||||
| ---------------------*/ | ||||
|  | ||||
| .ui.input { | ||||
|   position: relative; | ||||
|   font-weight: @normal; | ||||
|   font-style: normal; | ||||
|   display: inline-flex; | ||||
|   color: @inputColor; | ||||
| } | ||||
| .ui.input > input { | ||||
|   margin: 0em; | ||||
|   max-width: 100%; | ||||
|   flex: 1 0 auto; | ||||
|   outline: none; | ||||
|   -webkit-tap-highlight-color: rgba(255, 255, 255, 0); | ||||
|   text-align: @textAlign; | ||||
|   line-height: @lineHeight; | ||||
|  | ||||
|   font-family: @inputFont; | ||||
|   padding: @padding; | ||||
|  | ||||
|   background: @background; | ||||
|   border: @border; | ||||
|   color: @inputColor; | ||||
|   border-radius: @borderRadius; | ||||
|   transition: @transition; | ||||
|  | ||||
|   box-shadow: @boxShadow; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------------- | ||||
|       Placeholder | ||||
| ---------------------*/ | ||||
|  | ||||
| /* browsers require these rules separate */ | ||||
|  | ||||
| .ui.input > input::-webkit-input-placeholder { | ||||
|   color: @placeholderColor; | ||||
| } | ||||
| .ui.input > input::-moz-placeholder { | ||||
|   color: @placeholderColor; | ||||
| } | ||||
| .ui.input > input:-ms-input-placeholder { | ||||
|   color: @placeholderColor; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             States | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------------- | ||||
|         Disabled | ||||
| ---------------------*/ | ||||
|  | ||||
| .ui.disabled.input, | ||||
| .ui.input:not(.disabled) input[disabled] { | ||||
|   opacity: @disabledOpacity; | ||||
| } | ||||
|  | ||||
| .ui.disabled.input > input, | ||||
| .ui.input:not(.disabled) input[disabled] { | ||||
|   pointer-events: none; | ||||
| } | ||||
|  | ||||
| /*-------------------- | ||||
|         Active | ||||
| ---------------------*/ | ||||
|  | ||||
| .ui.input > input:active, | ||||
| .ui.input.down input { | ||||
|   border-color: @downBorderColor; | ||||
|   background: @downBackground; | ||||
|   color: @downColor; | ||||
|   box-shadow: @downBoxShadow; | ||||
| } | ||||
|  | ||||
| /*-------------------- | ||||
|        Loading | ||||
| ---------------------*/ | ||||
|  | ||||
| .ui.loading.loading.input > i.icon:before { | ||||
|   position: absolute; | ||||
|   content: ''; | ||||
|   top: 50%; | ||||
|   left: 50%; | ||||
|  | ||||
|   margin: @loaderMargin; | ||||
|   width: @loaderSize; | ||||
|   height: @loaderSize; | ||||
|  | ||||
|   border-radius: @circularRadius; | ||||
|   border: @loaderLineWidth solid @loaderFillColor; | ||||
| } | ||||
| .ui.loading.loading.input > i.icon:after { | ||||
|   position: absolute; | ||||
|   content: ''; | ||||
|   top: 50%; | ||||
|   left: 50%; | ||||
|  | ||||
|   margin: @loaderMargin; | ||||
|   width: @loaderSize; | ||||
|   height: @loaderSize; | ||||
|  | ||||
|   animation: button-spin @loaderSpeed linear; | ||||
|   animation-iteration-count: infinite; | ||||
|  | ||||
|   border-radius: @circularRadius; | ||||
|  | ||||
|   border-color: @loaderLineColor transparent transparent; | ||||
|   border-style: solid; | ||||
|   border-width: @loaderLineWidth; | ||||
|  | ||||
|   box-shadow: 0px 0px 0px 1px transparent; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------------- | ||||
|         Focus | ||||
| ---------------------*/ | ||||
|  | ||||
| .ui.input.focus > input, | ||||
| .ui.input > input:focus  { | ||||
|   border-color: @focusBorderColor; | ||||
|   background: @focusBackground; | ||||
|   color: @focusColor; | ||||
|   box-shadow: @focusBoxShadow; | ||||
| } | ||||
| .ui.input.focus > input::-webkit-input-placeholder, | ||||
| .ui.input > input:focus::-webkit-input-placeholder { | ||||
|   color: @placeholderFocusColor; | ||||
| } | ||||
| .ui.input.focus > input::-moz-placeholder, | ||||
| .ui.input > input:focus::-moz-placeholder { | ||||
|   color: @placeholderFocusColor; | ||||
| } | ||||
| .ui.input.focus > input:-ms-input-placeholder, | ||||
| .ui.input > input:focus:-ms-input-placeholder { | ||||
|   color: @placeholderFocusColor; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| /*-------------------- | ||||
|         Error | ||||
| ---------------------*/ | ||||
|  | ||||
| .ui.input.error > input { | ||||
|   background-color: @errorBackground; | ||||
|   border-color: @errorBorder; | ||||
|   color: @errorColor; | ||||
|   box-shadow: @errorBoxShadow; | ||||
| } | ||||
|  | ||||
| /* Error Placeholder */ | ||||
| .ui.input.error > input::-webkit-input-placeholder { | ||||
|   color: @placeholderErrorColor; | ||||
| } | ||||
| .ui.input.error > input::-moz-placeholder { | ||||
|   color: @placeholderErrorColor; | ||||
| } | ||||
| .ui.input.error > input:-ms-input-placeholder { | ||||
|   color: @placeholderErrorColor !important; | ||||
| } | ||||
|  | ||||
| /* Focused Error Placeholder */ | ||||
| .ui.input.error > input:focus::-webkit-input-placeholder { | ||||
|   color: @placeholderErrorFocusColor; | ||||
| } | ||||
| .ui.input.error > input:focus::-moz-placeholder { | ||||
|   color: @placeholderErrorFocusColor; | ||||
| } | ||||
| .ui.input.error > input:focus:-ms-input-placeholder { | ||||
|   color: @placeholderErrorFocusColor !important; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|            Variations | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------------- | ||||
|       Transparent | ||||
| ---------------------*/ | ||||
|  | ||||
|  | ||||
| .ui.transparent.input > input { | ||||
|   border-color: transparent !important; | ||||
|   background-color: transparent !important; | ||||
|   padding: 0em !important; | ||||
|   box-shadow: none !important; | ||||
|   border-radius: 0px !important; | ||||
| } | ||||
|  | ||||
| /* Transparent Icon */ | ||||
| .ui.transparent.icon.input > i.icon { | ||||
|   width: @transparentIconWidth; | ||||
| } | ||||
| .ui.transparent.icon.input > input { | ||||
|   padding-left: 0em !important; | ||||
|   padding-right: @transparentIconMargin !important; | ||||
| } | ||||
| .ui.transparent[class*="left icon"].input > input { | ||||
|   padding-left: @transparentIconMargin !important; | ||||
|   padding-right: 0em !important; | ||||
| } | ||||
|  | ||||
| /* Transparent Inverted */ | ||||
| .ui.transparent.inverted.input { | ||||
|   color: @transparentInvertedColor; | ||||
| } | ||||
| .ui.transparent.inverted.input > input { | ||||
|   color: inherit; | ||||
| } | ||||
|  | ||||
| .ui.transparent.inverted.input > input::-webkit-input-placeholder { | ||||
|   color: @transparentInvertedPlaceholderColor; | ||||
| } | ||||
| .ui.transparent.inverted.input > input::-moz-placeholder { | ||||
|   color: @transparentInvertedPlaceholderColor; | ||||
| } | ||||
| .ui.transparent.inverted.input > input:-ms-input-placeholder { | ||||
|   color: @transparentInvertedPlaceholderColor; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------------- | ||||
|          Icon | ||||
| ---------------------*/ | ||||
|  | ||||
| .ui.icon.input > i.icon { | ||||
|   cursor: default; | ||||
|   position: absolute; | ||||
|   line-height: 1; | ||||
|   text-align: center; | ||||
|   top: 0px; | ||||
|   right: 0px; | ||||
|   margin: 0em; | ||||
|   height: 100%; | ||||
|  | ||||
|   width: @iconWidth; | ||||
|   opacity: @iconOpacity; | ||||
|   border-radius: 0em @borderRadius @borderRadius 0em; | ||||
|   transition: @iconTransition; | ||||
| } | ||||
| .ui.icon.input > i.icon:not(.link) { | ||||
|   pointer-events: none; | ||||
| } | ||||
| .ui.icon.input > input { | ||||
|   padding-right: @iconMargin !important; | ||||
| } | ||||
|  | ||||
| .ui.icon.input > i.icon:before, | ||||
| .ui.icon.input > i.icon:after { | ||||
|   left: 0; | ||||
|   position: absolute; | ||||
|   text-align: center; | ||||
|   top: 50%; | ||||
|   width: 100%; | ||||
|   margin-top: @iconOffset; | ||||
| } | ||||
| .ui.icon.input > i.link.icon { | ||||
|   cursor: pointer; | ||||
| } | ||||
| .ui.icon.input > i.circular.icon { | ||||
|   top: @circularIconVerticalOffset; | ||||
|   right: @circularIconHorizontalOffset; | ||||
| } | ||||
|  | ||||
| /* Left Icon Input */ | ||||
| .ui[class*="left icon"].input > i.icon { | ||||
|   right: auto; | ||||
|   left: @borderWidth; | ||||
|   border-radius: @borderRadius 0em 0em @borderRadius; | ||||
| } | ||||
| .ui[class*="left icon"].input > i.circular.icon { | ||||
|   right: auto; | ||||
|   left: @circularIconHorizontalOffset; | ||||
| } | ||||
| .ui[class*="left icon"].input > input { | ||||
|   padding-left: @iconMargin !important; | ||||
|   padding-right: @horizontalPadding !important; | ||||
| } | ||||
|  | ||||
| /* Focus */ | ||||
| .ui.icon.input > input:focus ~ i.icon { | ||||
|   opacity: 1; | ||||
| } | ||||
|  | ||||
| /*-------------------- | ||||
|         Labeled | ||||
| ---------------------*/ | ||||
|  | ||||
| /* Adjacent Label */ | ||||
| .ui.labeled.input > .label { | ||||
|   flex: 0 0 auto; | ||||
|   margin: 0; | ||||
|   font-size: @relativeMedium; | ||||
| } | ||||
| .ui.labeled.input > .label:not(.corner) { | ||||
|   padding-top: @verticalPadding; | ||||
|   padding-bottom: @verticalPadding; | ||||
| } | ||||
|  | ||||
| /* Regular Label on Left */ | ||||
| .ui.labeled.input:not([class*="corner labeled"]) .label:first-child { | ||||
|   border-top-right-radius: 0px; | ||||
|   border-bottom-right-radius: 0px; | ||||
| } | ||||
| .ui.labeled.input:not([class*="corner labeled"]) .label:first-child + input { | ||||
|   border-top-left-radius: 0px; | ||||
|   border-bottom-left-radius: 0px; | ||||
|   border-left-color: transparent; | ||||
| } | ||||
| .ui.labeled.input:not([class*="corner labeled"]) .label:first-child + input:focus { | ||||
|   border-left-color: @focusBorderColor; | ||||
| } | ||||
|  | ||||
| /* Regular Label on Right */ | ||||
| .ui[class*="right labeled"].input > input { | ||||
|   border-top-right-radius: 0px !important; | ||||
|   border-bottom-right-radius: 0px !important; | ||||
|   border-right-color: transparent !important; | ||||
| } | ||||
| .ui[class*="right labeled"].input > input + .label { | ||||
|   border-top-left-radius: 0px; | ||||
|   border-bottom-left-radius: 0px; | ||||
| } | ||||
|  | ||||
| .ui[class*="right labeled"].input > input:focus { | ||||
|   border-right-color: @focusBorderColor !important; | ||||
| } | ||||
|  | ||||
| /* Corner Label */ | ||||
| .ui.labeled.input .corner.label { | ||||
|   top: @labelCornerTop; | ||||
|   right: @labelCornerRight; | ||||
|   font-size: @labelCornerSize; | ||||
|   border-radius: 0em @borderRadius 0em 0em; | ||||
| } | ||||
|  | ||||
| /* Spacing with corner label */ | ||||
| .ui[class*="corner labeled"]:not([class*="left corner labeled"]).labeled.input > input { | ||||
|   padding-right: @labeledMargin !important; | ||||
| } | ||||
| .ui[class*="corner labeled"].icon.input:not([class*="left corner labeled"]) > input { | ||||
|   padding-right: @labeledIconInputMargin !important; | ||||
| } | ||||
| .ui[class*="corner labeled"].icon.input:not([class*="left corner labeled"]) > .icon { | ||||
|   margin-right: @labeledIconMargin; | ||||
| } | ||||
|  | ||||
| /* Left Labeled */ | ||||
| .ui[class*="left corner labeled"].labeled.input > input { | ||||
|   padding-left: @labeledMargin !important; | ||||
| } | ||||
| .ui[class*="left corner labeled"].icon.input > input { | ||||
|   padding-left: @labeledIconInputMargin !important; | ||||
| } | ||||
| .ui[class*="left corner labeled"].icon.input > .icon { | ||||
|   margin-left: @labeledIconMargin; | ||||
| } | ||||
|  | ||||
| /* Corner Label Position  */ | ||||
| .ui.input > .ui.corner.label { | ||||
|   top: @borderWidth; | ||||
|   right: @borderWidth; | ||||
| } | ||||
| .ui.input > .ui.left.corner.label { | ||||
|   right: auto; | ||||
|   left: @borderWidth; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------------- | ||||
|         Action | ||||
| ---------------------*/ | ||||
|  | ||||
| .ui.action.input > .button, | ||||
| .ui.action.input > .buttons { | ||||
|   display: flex; | ||||
|   align-items: center; | ||||
|   flex: 0 0 auto; | ||||
| } | ||||
| .ui.action.input > .button, | ||||
| .ui.action.input > .buttons > .button { | ||||
|   padding-top: @verticalPadding; | ||||
|   padding-bottom: @verticalPadding; | ||||
|   margin: 0; | ||||
| } | ||||
|  | ||||
| /* Button on Right */ | ||||
| .ui.action.input:not([class*="left action"]) > input { | ||||
|   border-top-right-radius: 0px !important; | ||||
|   border-bottom-right-radius: 0px !important; | ||||
|   border-right-color: transparent !important; | ||||
| } | ||||
| .ui.action.input:not([class*="left action"]) > .dropdown:not(:first-child), | ||||
| .ui.action.input:not([class*="left action"]) > .button:not(:first-child), | ||||
| .ui.action.input:not([class*="left action"]) > .buttons:not(:first-child) > .button { | ||||
|   border-radius: 0px; | ||||
| } | ||||
| .ui.action.input:not([class*="left action"]) > .dropdown:last-child, | ||||
| .ui.action.input:not([class*="left action"]) > .button:last-child, | ||||
| .ui.action.input:not([class*="left action"]) > .buttons:last-child > .button { | ||||
|   border-radius: 0px @borderRadius @borderRadius 0px; | ||||
| } | ||||
|  | ||||
| /* Input Focus */ | ||||
| .ui.action.input:not([class*="left action"]) > input:focus { | ||||
|   border-right-color: @focusBorderColor !important; | ||||
| } | ||||
|  | ||||
| /* Button on Left */ | ||||
| .ui[class*="left action"].input > input { | ||||
|   border-top-left-radius: 0px !important; | ||||
|   border-bottom-left-radius: 0px !important; | ||||
|   border-left-color: transparent !important; | ||||
| } | ||||
| .ui[class*="left action"].input > .dropdown, | ||||
| .ui[class*="left action"].input > .button, | ||||
| .ui[class*="left action"].input > .buttons > .button { | ||||
|   border-radius: 0px; | ||||
| } | ||||
| .ui[class*="left action"].input > .dropdown:first-child, | ||||
| .ui[class*="left action"].input > .button:first-child, | ||||
| .ui[class*="left action"].input > .buttons:first-child > .button { | ||||
|   border-radius: @borderRadius 0px 0px @borderRadius; | ||||
| } | ||||
| /* Input Focus */ | ||||
| .ui[class*="left action"].input > input:focus { | ||||
|   border-left-color: @focusBorderColor !important; | ||||
| } | ||||
|  | ||||
| /*-------------------- | ||||
|        Inverted | ||||
| ---------------------*/ | ||||
|  | ||||
| /* Standard */ | ||||
| .ui.inverted.input > input { | ||||
|   border: none; | ||||
| } | ||||
|  | ||||
| /*-------------------- | ||||
|         Fluid | ||||
| ---------------------*/ | ||||
|  | ||||
| .ui.fluid.input { | ||||
|   display: flex; | ||||
| } | ||||
| .ui.fluid.input > input { | ||||
|   width: 0px !important; | ||||
| } | ||||
|  | ||||
| /*-------------------- | ||||
|         Size | ||||
| ---------------------*/ | ||||
|  | ||||
| .ui.mini.input { | ||||
|   font-size: @relativeMini; | ||||
| } | ||||
| .ui.small.input { | ||||
|   font-size: @relativeSmall; | ||||
| } | ||||
| .ui.input { | ||||
|   font-size: @relativeMedium; | ||||
| } | ||||
| .ui.large.input { | ||||
|   font-size: @relativeLarge; | ||||
| } | ||||
| .ui.big.input { | ||||
|   font-size: @relativeBig; | ||||
| } | ||||
| .ui.huge.input { | ||||
|   font-size: @relativeHuge; | ||||
| } | ||||
| .ui.massive.input { | ||||
|   font-size: @relativeMassive; | ||||
| } | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,953 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - List | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'element'; | ||||
| @element : 'list'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|             List | ||||
| *******************************/ | ||||
|  | ||||
| ul.ui.list, | ||||
| ol.ui.list, | ||||
| .ui.list { | ||||
|   list-style-type: @listStyleType; | ||||
|   margin: @margin; | ||||
|   padding: @verticalPadding @horizontalPadding; | ||||
| } | ||||
|  | ||||
| ul.ui.list:first-child, | ||||
| ol.ui.list:first-child, | ||||
| .ui.list:first-child { | ||||
|   margin-top: 0em; | ||||
|   padding-top: 0em; | ||||
| } | ||||
|  | ||||
| ul.ui.list:last-child, | ||||
| ol.ui.list:last-child, | ||||
| .ui.list:last-child { | ||||
|   margin-bottom: 0em; | ||||
|   padding-bottom: 0em; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|             Content | ||||
| *******************************/ | ||||
|  | ||||
| /* List Item */ | ||||
| ul.ui.list li, | ||||
| ol.ui.list li, | ||||
| .ui.list > .item, | ||||
| .ui.list .list > .item { | ||||
|   display: list-item; | ||||
|   table-layout: fixed; | ||||
|   list-style-type: @listStyleType; | ||||
|   list-style-position: @listStylePosition; | ||||
|  | ||||
|   padding: @itemPadding; | ||||
|   line-height: @itemLineHeight; | ||||
| } | ||||
|  | ||||
| ul.ui.list > li:first-child:after, | ||||
| ol.ui.list > li:first-child:after, | ||||
| .ui.list > .list > .item, | ||||
| .ui.list > .item:after { | ||||
|   content: ''; | ||||
|   display: block; | ||||
|   height: 0; | ||||
|   clear: both; | ||||
|   visibility: hidden; | ||||
| } | ||||
|  | ||||
| ul.ui.list li:first-child, | ||||
| ol.ui.list li:first-child, | ||||
| .ui.list .list > .item:first-child, | ||||
| .ui.list > .item:first-child { | ||||
|   padding-top: 0em; | ||||
| } | ||||
| ul.ui.list li:last-child, | ||||
| ol.ui.list li:last-child, | ||||
| .ui.list .list > .item:last-child, | ||||
| .ui.list > .item:last-child { | ||||
|   padding-bottom: 0em; | ||||
| } | ||||
|  | ||||
| /* Child List */ | ||||
| ul.ui.list ul, | ||||
| ol.ui.list ol, | ||||
| .ui.list .list { | ||||
|   clear: both; | ||||
|   margin: 0em; | ||||
|   padding: @childListPadding; | ||||
| } | ||||
|  | ||||
| /* Child Item */ | ||||
| ul.ui.list ul li, | ||||
| ol.ui.list ol li, | ||||
| .ui.list .list > .item { | ||||
|   padding: @childItemPadding; | ||||
|   line-height: @childItemLineHeight; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Icon */ | ||||
| .ui.list .list > .item > i.icon, | ||||
| .ui.list > .item > i.icon { | ||||
|   display: table-cell; | ||||
|   margin: 0em; | ||||
|   padding-top: @iconOffset; | ||||
|   padding-right: @iconDistance; | ||||
|   vertical-align: @iconContentVerticalAlign; | ||||
|   transition: @iconTransition; | ||||
| } | ||||
| .ui.list .list > .item > i.icon:only-child, | ||||
| .ui.list > .item > i.icon:only-child { | ||||
|   display: inline-block; | ||||
|   vertical-align: @iconVerticalAlign; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Image */ | ||||
| .ui.list .list > .item > .image, | ||||
| .ui.list > .item > .image { | ||||
|   display: table-cell; | ||||
|   background-color: transparent; | ||||
|   margin: 0em; | ||||
|   vertical-align: @imageAlign; | ||||
| } | ||||
| .ui.list .list > .item > .image:not(:only-child):not(img), | ||||
| .ui.list > .item > .image:not(:only-child):not(img) { | ||||
|   padding-right: @imageDistance; | ||||
| } | ||||
| .ui.list .list > .item > .image img, | ||||
| .ui.list > .item > .image img { | ||||
|   vertical-align: @imageAlign; | ||||
| } | ||||
|  | ||||
| .ui.list .list > .item > img.image, | ||||
| .ui.list .list > .item > .image:only-child, | ||||
| .ui.list > .item > img.image, | ||||
| .ui.list > .item > .image:only-child { | ||||
|   display: inline-block; | ||||
| } | ||||
|  | ||||
| /* Content */ | ||||
| .ui.list .list > .item > .content, | ||||
| .ui.list > .item > .content { | ||||
|   line-height: @contentLineHeight; | ||||
| } | ||||
| .ui.list .list > .item > .image + .content, | ||||
| .ui.list .list > .item > .icon + .content, | ||||
| .ui.list > .item > .image + .content, | ||||
| .ui.list > .item > .icon + .content { | ||||
|   display: table-cell; | ||||
|   width: 100%; | ||||
|   padding: 0em 0em 0em @contentDistance; | ||||
|   vertical-align: @contentVerticalAlign; | ||||
| } | ||||
| .ui.list .list > .item > img.image + .content, | ||||
| .ui.list > .item > img.image + .content { | ||||
|   display: inline-block; | ||||
|   width: auto; | ||||
| } | ||||
| .ui.list .list > .item > .content > .list, | ||||
| .ui.list > .item > .content > .list { | ||||
|   margin-left: 0em; | ||||
|   padding-left: 0em; | ||||
| } | ||||
|  | ||||
| /* Header */ | ||||
| .ui.list .list > .item .header, | ||||
| .ui.list > .item .header { | ||||
|   display: block; | ||||
|   margin: 0em; | ||||
|   font-family: @itemHeaderFontFamily; | ||||
|   font-weight: @itemHeaderFontWeight; | ||||
|   color: @itemHeaderColor; | ||||
| } | ||||
|  | ||||
| /* Description */ | ||||
| .ui.list .list > .item .description, | ||||
| .ui.list > .item .description { | ||||
|   display: block; | ||||
|   color: @itemDescriptionColor; | ||||
| } | ||||
|  | ||||
| /* Child Link */ | ||||
| .ui.list > .item a, | ||||
| .ui.list .list > .item a { | ||||
|   cursor: pointer; | ||||
| } | ||||
|  | ||||
| /* Linking Item */ | ||||
| .ui.list .list > a.item, | ||||
| .ui.list > a.item { | ||||
|   cursor: pointer; | ||||
|   color: @itemLinkColor; | ||||
| } | ||||
| .ui.list .list > a.item:hover, | ||||
| .ui.list > a.item:hover { | ||||
|   color: @itemLinkHoverColor; | ||||
| } | ||||
|  | ||||
| /* Linked Item Icons */ | ||||
| .ui.list .list > a.item i.icon, | ||||
| .ui.list > a.item i.icon { | ||||
|   color: @itemLinkIconColor; | ||||
| } | ||||
|  | ||||
| /* Header Link */ | ||||
| .ui.list .list > .item a.header, | ||||
| .ui.list > .item a.header { | ||||
|   cursor: pointer; | ||||
|   color: @itemHeaderLinkColor !important; | ||||
| } | ||||
| .ui.list .list > .item a.header:hover, | ||||
| .ui.list > .item a.header:hover { | ||||
|   color: @itemHeaderLinkHoverColor !important; | ||||
| } | ||||
|  | ||||
| /* Floated Content */ | ||||
| .ui[class*="left floated"].list { | ||||
|   float: left; | ||||
| } | ||||
| .ui[class*="right floated"].list { | ||||
|   float: right; | ||||
| } | ||||
|  | ||||
| .ui.list .list > .item [class*="left floated"], | ||||
| .ui.list > .item [class*="left floated"] { | ||||
|   float: left; | ||||
|   margin: @leftFloatMargin; | ||||
| } | ||||
| .ui.list .list > .item [class*="right floated"], | ||||
| .ui.list > .item [class*="right floated"] { | ||||
|   float: right; | ||||
|   margin: @rightFloatMargin; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|             Coupling | ||||
| *******************************/ | ||||
|  | ||||
| .ui.menu .ui.list > .item, | ||||
| .ui.menu .ui.list .list > .item { | ||||
|   display: list-item; | ||||
|   table-layout: fixed; | ||||
|   background-color: transparent; | ||||
|  | ||||
|   list-style-type: @listStyleType; | ||||
|   list-style-position: @listStylePosition; | ||||
|  | ||||
|   padding: @itemVerticalPadding @itemHorizontalPadding; | ||||
|   line-height: @itemLineHeight; | ||||
| } | ||||
| .ui.menu .ui.list .list > .item:before, | ||||
| .ui.menu .ui.list > .item:before { | ||||
|   border: none; | ||||
|   background: none; | ||||
| } | ||||
| .ui.menu .ui.list .list > .item:first-child, | ||||
| .ui.menu .ui.list > .item:first-child { | ||||
|   padding-top: 0em; | ||||
| } | ||||
| .ui.menu .ui.list .list > .item:last-child, | ||||
| .ui.menu .ui.list > .item:last-child { | ||||
|   padding-bottom: 0em; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Types | ||||
| *******************************/ | ||||
|  | ||||
| /*------------------- | ||||
|       Horizontal | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.horizontal.list { | ||||
|   display: inline-block; | ||||
|   font-size: 0em; | ||||
| } | ||||
| .ui.horizontal.list > .item { | ||||
|   display: inline-block; | ||||
|   margin-left: @horizontalSpacing; | ||||
|   font-size: 1rem; | ||||
| } | ||||
| .ui.horizontal.list:not(.celled) > .item:first-child { | ||||
|   margin-left: 0em !important; | ||||
|   padding-left: 0em !important; | ||||
| } | ||||
| .ui.horizontal.list .list { | ||||
|   padding-left: 0em; | ||||
|   padding-bottom: 0em; | ||||
| } | ||||
|  | ||||
| .ui.horizontal.list > .item > .image, | ||||
| .ui.horizontal.list .list > .item > .image, | ||||
| .ui.horizontal.list > .item > .icon, | ||||
| .ui.horizontal.list .list > .item > .icon, | ||||
| .ui.horizontal.list > .item > .content, | ||||
| .ui.horizontal.list .list > .item > .content { | ||||
|   vertical-align: @horizontalVerticalAlign; | ||||
| } | ||||
|  | ||||
| /* Padding on all elements */ | ||||
| .ui.horizontal.list > .item:first-child, | ||||
| .ui.horizontal.list > .item:last-child { | ||||
|   padding-top: @itemVerticalPadding; | ||||
|   padding-bottom: @itemVerticalPadding; | ||||
| } | ||||
|  | ||||
| /* Horizontal List */ | ||||
| .ui.horizontal.list > .item > i.icon { | ||||
|   margin: 0em; | ||||
|   padding: 0em @horizontalIconDistance 0em 0em; | ||||
| } | ||||
| .ui.horizontal.list > .item > .icon, | ||||
| .ui.horizontal.list > .item > .icon + .content { | ||||
|   float: none; | ||||
|   display: inline-block; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|              States | ||||
| *******************************/ | ||||
|  | ||||
| /*------------------- | ||||
|        Disabled | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.list .list > .disabled.item, | ||||
| .ui.list > .disabled.item { | ||||
|   pointer-events: none; | ||||
|   color: @disabledColor !important; | ||||
| } | ||||
| .ui.inverted.list .list > .disabled.item, | ||||
| .ui.inverted.list > .disabled.item { | ||||
|   color: @invertedDisabledColor !important; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|         Hover | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.list .list > a.item:hover .icon, | ||||
| .ui.list > a.item:hover .icon { | ||||
|   color: @itemLinkIconHoverColor; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|            Variations | ||||
| *******************************/ | ||||
|  | ||||
| /*------------------- | ||||
|        Inverted | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.inverted.list .list > a.item > .icon, | ||||
| .ui.inverted.list > a.item > .icon { | ||||
|   color: @invertedIconLinkColor; | ||||
| } | ||||
| .ui.inverted.list .list > .item .header, | ||||
| .ui.inverted.list > .item .header { | ||||
|   color: @invertedHeaderColor; | ||||
| } | ||||
| .ui.inverted.list .list > .item .description, | ||||
| .ui.inverted.list > .item .description { | ||||
|   color: @invertedDescriptionColor; | ||||
| } | ||||
|  | ||||
| /* Item Link */ | ||||
| .ui.inverted.list .list > a.item, | ||||
| .ui.inverted.list > a.item { | ||||
|   cursor: pointer; | ||||
|   color: @invertedItemLinkColor; | ||||
| } | ||||
| .ui.inverted.list .list > a.item:hover, | ||||
| .ui.inverted.list > a.item:hover { | ||||
|   color: @invertedItemLinkHoverColor; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Linking Content */ | ||||
| .ui.inverted.list .item a:not(.ui) { | ||||
|   color: @invertedItemLinkColor !important; | ||||
| } | ||||
| .ui.inverted.list .item a:not(.ui):hover { | ||||
|   color: @invertedItemLinkHoverColor !important; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Aligned | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.list[class*="top aligned"] .image, | ||||
| .ui.list[class*="top aligned"] .content, | ||||
| .ui.list [class*="top aligned"] { | ||||
|   vertical-align: top !important; | ||||
| } | ||||
| .ui.list[class*="middle aligned"] .image, | ||||
| .ui.list[class*="middle aligned"] .content, | ||||
| .ui.list [class*="middle aligned"] { | ||||
|   vertical-align: middle !important; | ||||
| } | ||||
| .ui.list[class*="bottom aligned"] .image, | ||||
| .ui.list[class*="bottom aligned"] .content, | ||||
| .ui.list [class*="bottom aligned"] { | ||||
|   vertical-align: bottom !important; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Link | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.link.list .item, | ||||
| .ui.link.list a.item, | ||||
| .ui.link.list .item a:not(.ui) { | ||||
|   color: @linkListItemColor; | ||||
|   transition: @linkListTransition; | ||||
| } | ||||
| .ui.link.list.list a.item:hover, | ||||
| .ui.link.list.list .item a:not(.ui):hover { | ||||
|   color: @linkListItemHoverColor; | ||||
| } | ||||
| .ui.link.list.list a.item:active, | ||||
| .ui.link.list.list .item a:not(.ui):active { | ||||
|   color: @linkListItemDownColor; | ||||
| } | ||||
| .ui.link.list.list .active.item, | ||||
| .ui.link.list.list .active.item a:not(.ui) { | ||||
|   color: @linkListItemActiveColor; | ||||
| } | ||||
|  | ||||
| /* Inverted */ | ||||
| .ui.inverted.link.list .item, | ||||
| .ui.inverted.link.list a.item, | ||||
| .ui.inverted.link.list .item a:not(.ui) { | ||||
|   color: @invertedLinkListItemColor; | ||||
| } | ||||
| .ui.inverted.link.list.list a.item:hover, | ||||
| .ui.inverted.link.list.list .item a:not(.ui):hover { | ||||
|   color: @invertedLinkListItemHoverColor; | ||||
| } | ||||
| .ui.inverted.link.list.list a.item:active, | ||||
| .ui.inverted.link.list.list .item a:not(.ui):active { | ||||
|   color: @invertedLinkListItemDownColor; | ||||
| } | ||||
| .ui.inverted.link.list.list a.active.item, | ||||
| .ui.inverted.link.list.list .active.item a:not(.ui) { | ||||
|   color: @invertedLinkListItemActiveColor; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|       Selection | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.selection.list .list > .item, | ||||
| .ui.selection.list > .item { | ||||
|   cursor: pointer; | ||||
|   background: @selectionListBackground; | ||||
|   padding: @selectionListItemVerticalPadding @selectionListItemHorizontalPadding; | ||||
|   margin: @selectionListItemMargin; | ||||
|   color: @selectionListColor; | ||||
|   border-radius: @selectionListItemBorderRadius; | ||||
|   transition: @selectionListTransition; | ||||
| } | ||||
| .ui.selection.list .list > .item:last-child, | ||||
| .ui.selection.list > .item:last-child { | ||||
|   margin-bottom: 0em; | ||||
| } | ||||
| .ui.selection.list.list > .item:hover, | ||||
| .ui.selection.list > .item:hover { | ||||
|   background: @selectionListHoverBackground; | ||||
|   color: @selectionListHoverColor; | ||||
| } | ||||
| .ui.selection.list .list > .item:active, | ||||
| .ui.selection.list > .item:active { | ||||
|   background: @selectionListDownBackground; | ||||
|   color: @selectionListDownColor; | ||||
| } | ||||
| .ui.selection.list .list > .item.active, | ||||
| .ui.selection.list > .item.active { | ||||
|   background: @selectionListActiveBackground; | ||||
|   color: @selectionListActiveColor; | ||||
| } | ||||
|  | ||||
| /* Inverted */ | ||||
| .ui.inverted.selection.list > .item, | ||||
| .ui.inverted.selection.list > .item { | ||||
|   background: @invertedSelectionListBackground; | ||||
|   color: @invertedSelectionListColor; | ||||
| } | ||||
| .ui.inverted.selection.list > .item:hover, | ||||
| .ui.inverted.selection.list > .item:hover { | ||||
|   background: @invertedSelectionListHoverBackground; | ||||
|   color: @invertedSelectionListHoverColor; | ||||
| } | ||||
| .ui.inverted.selection.list > .item:active, | ||||
| .ui.inverted.selection.list > .item:active { | ||||
|   background: @invertedSelectionListDownBackground; | ||||
|   color: @invertedSelectionListDownColor; | ||||
| } | ||||
| .ui.inverted.selection.list > .item.active, | ||||
| .ui.inverted.selection.list > .item.active { | ||||
|   background: @invertedSelectionListActiveBackground; | ||||
|   color: @invertedSelectionListActiveColor; | ||||
| } | ||||
|  | ||||
| /* Celled / Divided Selection List */ | ||||
| .ui.celled.selection.list .list > .item, | ||||
| .ui.divided.selection.list .list > .item, | ||||
| .ui.celled.selection.list > .item, | ||||
| .ui.divided.selection.list > .item { | ||||
|   border-radius: 0em; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Animated | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.animated.list > .item { | ||||
|   transition: @animatedListTransition; | ||||
| } | ||||
| .ui.animated.list:not(.horizontal) > .item:hover { | ||||
|   padding-left: @animatedListIndent; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Fitted | ||||
| --------------------*/ | ||||
| .ui.fitted.list:not(.selection) .list > .item, | ||||
| .ui.fitted.list:not(.selection) > .item { | ||||
|   padding-left: 0em; | ||||
|   padding-right: 0em; | ||||
| } | ||||
| .ui.fitted.selection.list .list > .item, | ||||
| .ui.fitted.selection.list > .item { | ||||
|   margin-left: -@selectionListItemHorizontalPadding; | ||||
|   margin-right: -@selectionListItemHorizontalPadding; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|       Bulleted | ||||
| --------------------*/ | ||||
|  | ||||
| ul.ui.list, | ||||
| .ui.bulleted.list { | ||||
|   margin-left: @bulletDistance; | ||||
| } | ||||
| ul.ui.list li, | ||||
| .ui.bulleted.list .list > .item, | ||||
| .ui.bulleted.list > .item { | ||||
|   position: relative; | ||||
| } | ||||
| ul.ui.list li:before, | ||||
| .ui.bulleted.list .list > .item:before, | ||||
| .ui.bulleted.list > .item:before { | ||||
|   user-select: none; | ||||
|   pointer-events: none; | ||||
|   position: absolute; | ||||
|   top: auto; | ||||
|   left: auto; | ||||
|   font-weight: @normal; | ||||
|   margin-left: @bulletOffset; | ||||
|   content: @bulletCharacter; | ||||
|   opacity: @bulletOpacity; | ||||
|   color: @bulletColor; | ||||
|   vertical-align: @bulletVerticalAlign; | ||||
| } | ||||
|  | ||||
| ul.ui.list li:before, | ||||
| .ui.bulleted.list .list > a.item:before, | ||||
| .ui.bulleted.list > a.item:before { | ||||
|   color: @bulletLinkColor; | ||||
| } | ||||
|  | ||||
| ul.ui.list ul, | ||||
| .ui.bulleted.list .list { | ||||
|   padding-left: @bulletChildDistance; | ||||
| } | ||||
|  | ||||
| /* Horizontal Bulleted */ | ||||
| ul.ui.horizontal.bulleted.list, | ||||
| .ui.horizontal.bulleted.list { | ||||
|   margin-left: 0em; | ||||
| } | ||||
| ul.ui.horizontal.bulleted.list li, | ||||
| .ui.horizontal.bulleted.list > .item { | ||||
|   margin-left: @horizontalBulletSpacing; | ||||
| } | ||||
| ul.ui.horizontal.bulleted.list li:first-child, | ||||
| .ui.horizontal.bulleted.list > .item:first-child { | ||||
|   margin-left: 0em; | ||||
| } | ||||
| ul.ui.horizontal.bulleted.list li::before, | ||||
| .ui.horizontal.bulleted.list > .item::before { | ||||
|   color: @horizontalBulletColor; | ||||
| } | ||||
| ul.ui.horizontal.bulleted.list li:first-child::before, | ||||
| .ui.horizontal.bulleted.list > .item:first-child::before { | ||||
|   display: none; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Ordered | ||||
| --------------------*/ | ||||
|  | ||||
| ol.ui.list, | ||||
| .ui.ordered.list, | ||||
| .ui.ordered.list .list, | ||||
| ol.ui.list ol { | ||||
|   counter-reset: ordered; | ||||
|   margin-left: @orderedCountDistance; | ||||
|   list-style-type: none; | ||||
| } | ||||
| ol.ui.list li, | ||||
| .ui.ordered.list .list > .item, | ||||
| .ui.ordered.list > .item { | ||||
|   list-style-type: none; | ||||
|   position: relative; | ||||
| } | ||||
| ol.ui.list li:before, | ||||
| .ui.ordered.list .list > .item:before, | ||||
| .ui.ordered.list > .item:before { | ||||
|   position: absolute; | ||||
|   top: auto; | ||||
|   left: auto; | ||||
|   user-select: none; | ||||
|   pointer-events: none; | ||||
|   margin-left: -(@orderedCountDistance); | ||||
|   counter-increment: @orderedCountName; | ||||
|   content: @orderedCountContent; | ||||
|   text-align: @orderedCountTextAlign; | ||||
|   color: @orderedCountColor; | ||||
|   vertical-align: @orderedCountVerticalAlign; | ||||
|   opacity: @orderedCountOpacity; | ||||
| } | ||||
|  | ||||
| ol.ui.inverted.list li:before, | ||||
| .ui.ordered.inverted.list .list > .item:before, | ||||
| .ui.ordered.inverted.list > .item:before { | ||||
|   color: @orderedInvertedCountColor; | ||||
| } | ||||
|  | ||||
| /* Value */ | ||||
| .ui.ordered.list > .list > .item[data-value], | ||||
| .ui.ordered.list > .item[data-value] { | ||||
|   content: attr(data-value); | ||||
| } | ||||
| ol.ui.list li[value]:before { | ||||
|   content: attr(value); | ||||
| } | ||||
|  | ||||
| /* Child Lists */ | ||||
| ol.ui.list ol, | ||||
| .ui.ordered.list .list { | ||||
|   margin-left: @orderedChildCountDistance; | ||||
| } | ||||
| ol.ui.list ol li:before, | ||||
| .ui.ordered.list .list > .item:before { | ||||
|   margin-left: @orderedChildCountOffset; | ||||
| } | ||||
|  | ||||
| /* Horizontal Ordered */ | ||||
| ol.ui.horizontal.list, | ||||
| .ui.ordered.horizontal.list { | ||||
|   margin-left: 0em; | ||||
| } | ||||
| ol.ui.horizontal.list li:before, | ||||
| .ui.ordered.horizontal.list .list > .item:before, | ||||
| .ui.ordered.horizontal.list > .item:before { | ||||
|   position: static; | ||||
|   margin: 0em @horizontalOrderedCountDistance 0em 0em; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Divided | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.divided.list > .item { | ||||
|   border-top: @dividedBorder; | ||||
| } | ||||
| .ui.divided.list .list > .item { | ||||
|   border-top: @dividedChildListBorder; | ||||
| } | ||||
| .ui.divided.list .item .list > .item { | ||||
|   border-top: @dividedChildItemBorder; | ||||
| } | ||||
| .ui.divided.list .list > .item:first-child, | ||||
| .ui.divided.list > .item:first-child { | ||||
|   border-top: none; | ||||
| } | ||||
|  | ||||
| /* Sub Menu */ | ||||
| .ui.divided.list:not(.horizontal) .list > .item:first-child { | ||||
|   border-top-width: @dividedBorderWidth; | ||||
| } | ||||
|  | ||||
| /* Divided bulleted */ | ||||
| .ui.divided.bulleted.list:not(.horizontal), | ||||
| .ui.divided.bulleted.list .list { | ||||
|   margin-left: 0em; | ||||
|   padding-left: 0em; | ||||
| } | ||||
| .ui.divided.bulleted.list > .item:not(.horizontal) { | ||||
|   padding-left: @bulletDistance; | ||||
| } | ||||
|  | ||||
| /* Divided Ordered */ | ||||
| .ui.divided.ordered.list { | ||||
|   margin-left: 0em; | ||||
| } | ||||
| .ui.divided.ordered.list .list > .item, | ||||
| .ui.divided.ordered.list > .item { | ||||
|   padding-left: @orderedCountDistance; | ||||
| } | ||||
| .ui.divided.ordered.list .item .list { | ||||
|   margin-left: 0em; | ||||
|   margin-right: 0em; | ||||
|   padding-bottom: @itemVerticalPadding; | ||||
| } | ||||
| .ui.divided.ordered.list .item .list > .item { | ||||
|   padding-left: @orderedChildCountDistance; | ||||
| } | ||||
|  | ||||
| /* Divided Selection */ | ||||
| .ui.divided.selection.list .list > .item, | ||||
| .ui.divided.selection.list > .item { | ||||
|   margin: 0em; | ||||
|   border-radius: 0em; | ||||
| } | ||||
|  | ||||
| /* Divided horizontal */ | ||||
| .ui.divided.horizontal.list { | ||||
|   margin-left: 0em; | ||||
| } | ||||
| .ui.divided.horizontal.list > .item:not(:first-child) { | ||||
|   padding-left: @horizontalDividedSpacing; | ||||
| } | ||||
| .ui.divided.horizontal.list > .item:not(:last-child) { | ||||
|   padding-right: @horizontalDividedSpacing; | ||||
| } | ||||
| .ui.divided.horizontal.list > .item { | ||||
|   border-top: none; | ||||
|   border-left: @dividedBorder; | ||||
|   margin: 0em; | ||||
|   line-height: @horizontalDividedLineHeight; | ||||
| } | ||||
| .ui.horizontal.divided.list > .item:first-child { | ||||
|   border-left: none; | ||||
| } | ||||
| /* Inverted */ | ||||
| .ui.divided.inverted.list > .item, | ||||
| .ui.divided.inverted.list > .list, | ||||
| .ui.divided.inverted.horizontal.list > .item { | ||||
|   border-color: @dividedInvertedBorderColor; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|         Celled | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.celled.list > .item, | ||||
| .ui.celled.list > .list { | ||||
|   border-top: @celledBorder; | ||||
|   padding-left: @celledHorizontalPadding; | ||||
|   padding-right: @celledHorizontalPadding; | ||||
| } | ||||
| .ui.celled.list > .item:last-child { | ||||
|   border-bottom: @celledBorder; | ||||
| } | ||||
|  | ||||
| /* Padding on all elements */ | ||||
| .ui.celled.list > .item:first-child, | ||||
| .ui.celled.list > .item:last-child { | ||||
|   padding-top: @itemVerticalPadding; | ||||
|   padding-bottom: @itemVerticalPadding; | ||||
| } | ||||
|  | ||||
| /* Sub Menu */ | ||||
| .ui.celled.list .item .list > .item { | ||||
|   border-width: 0px; | ||||
| } | ||||
| .ui.celled.list .list > .item:first-child { | ||||
|   border-top-width: 0px; | ||||
| } | ||||
|  | ||||
| /* Celled Bulleted */ | ||||
| .ui.celled.bulleted.list { | ||||
|   margin-left: 0em; | ||||
| } | ||||
| .ui.celled.bulleted.list .list > .item, | ||||
| .ui.celled.bulleted.list > .item { | ||||
|   padding-left: (@bulletDistance); | ||||
| } | ||||
| .ui.celled.bulleted.list .item .list { | ||||
|   margin-left: -(@bulletDistance); | ||||
|   margin-right: -(@bulletDistance); | ||||
|   padding-bottom: @itemVerticalPadding; | ||||
| } | ||||
|  | ||||
| /* Celled Ordered */ | ||||
| .ui.celled.ordered.list { | ||||
|   margin-left: 0em; | ||||
| } | ||||
| .ui.celled.ordered.list .list > .item, | ||||
| .ui.celled.ordered.list > .item { | ||||
|   padding-left: @orderedCountDistance; | ||||
| } | ||||
| .ui.celled.ordered.list .item .list { | ||||
|   margin-left: 0em; | ||||
|   margin-right: 0em; | ||||
|   padding-bottom: @itemVerticalPadding; | ||||
| } | ||||
| .ui.celled.ordered.list .list > .item { | ||||
|   padding-left: @orderedChildCountDistance; | ||||
| } | ||||
|  | ||||
| /* Celled Horizontal */ | ||||
| .ui.horizontal.celled.list { | ||||
|   margin-left: 0em; | ||||
| } | ||||
| .ui.horizontal.celled.list .list > .item, | ||||
| .ui.horizontal.celled.list > .item { | ||||
|   border-top: none; | ||||
|   border-left: @celledBorder; | ||||
|   margin: 0em; | ||||
|   padding-left: @horizontalCelledSpacing; | ||||
|   padding-right: @horizontalCelledSpacing; | ||||
|  | ||||
|   line-height: @horizontalCelledLineHeight; | ||||
| } | ||||
| .ui.horizontal.celled.list .list > .item:last-child, | ||||
| .ui.horizontal.celled.list > .item:last-child { | ||||
|   border-bottom: none; | ||||
|   border-right: @celledBorder; | ||||
| } | ||||
|  | ||||
| /* Inverted */ | ||||
| .ui.celled.inverted.list > .item, | ||||
| .ui.celled.inverted.list > .list { | ||||
|   border-color: @celledInvertedBorder; | ||||
| } | ||||
| .ui.celled.inverted.horizontal.list .list > .item, | ||||
| .ui.celled.inverted.horizontal.list > .item { | ||||
|   border-color: @celledInvertedBorder; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Relaxed | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.relaxed.list:not(.horizontal) > .item:not(:first-child) { | ||||
|   padding-top: @relaxedItemVerticalPadding; | ||||
| } | ||||
| .ui.relaxed.list:not(.horizontal) > .item:not(:last-child) { | ||||
|   padding-bottom: @relaxedItemVerticalPadding; | ||||
| } | ||||
| .ui.horizontal.relaxed.list .list > .item:not(:first-child), | ||||
| .ui.horizontal.relaxed.list > .item:not(:first-child) { | ||||
|   padding-left: @relaxedHorizontalPadding; | ||||
| } | ||||
| .ui.horizontal.relaxed.list .list > .item:not(:last-child), | ||||
| .ui.horizontal.relaxed.list > .item:not(:last-child) { | ||||
|   padding-right: @relaxedHorizontalPadding; | ||||
| } | ||||
|  | ||||
| /* Very Relaxed */ | ||||
| .ui[class*="very relaxed"].list:not(.horizontal) > .item:not(:first-child) { | ||||
|   padding-top: @veryRelaxedItemVerticalPadding; | ||||
| } | ||||
| .ui[class*="very relaxed"].list:not(.horizontal) > .item:not(:last-child) { | ||||
|   padding-bottom: @veryRelaxedItemVerticalPadding; | ||||
| } | ||||
| .ui.horizontal[class*="very relaxed"].list .list > .item:not(:first-child), | ||||
| .ui.horizontal[class*="very relaxed"].list > .item:not(:first-child) { | ||||
|   padding-left: @veryRelaxedHorizontalPadding; | ||||
| } | ||||
| .ui.horizontal[class*="very relaxed"].list .list > .item:not(:last-child), | ||||
| .ui.horizontal[class*="very relaxed"].list > .item:not(:last-child) { | ||||
|   padding-right: @veryRelaxedHorizontalPadding; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|       Sizes | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.mini.list { | ||||
|   font-size: @relativeMini; | ||||
| } | ||||
| .ui.tiny.list { | ||||
|   font-size: @relativeTiny; | ||||
| } | ||||
| .ui.small.list { | ||||
|   font-size: @relativeSmall; | ||||
| } | ||||
| .ui.list { | ||||
|   font-size: @relativeMedium; | ||||
| } | ||||
| .ui.large.list { | ||||
|   font-size: @relativeLarge; | ||||
| } | ||||
| .ui.big.list { | ||||
|   font-size: @relativeBig; | ||||
| } | ||||
| .ui.huge.list { | ||||
|   font-size: @relativeHuge; | ||||
| } | ||||
| .ui.massive.list { | ||||
|   font-size: @relativeMassive; | ||||
| } | ||||
|  | ||||
| .ui.mini.horizontal.list .list > .item, | ||||
| .ui.mini.horizontal.list > .item { | ||||
|   font-size: @mini; | ||||
| } | ||||
| .ui.tiny.horizontal.list .list > .item, | ||||
| .ui.tiny.horizontal.list > .item { | ||||
|   font-size: @tiny; | ||||
| } | ||||
| .ui.small.horizontal.list .list > .item, | ||||
| .ui.small.horizontal.list > .item { | ||||
|   font-size: @small; | ||||
| } | ||||
| .ui.horizontal.list .list > .item, | ||||
| .ui.horizontal.list > .item { | ||||
|   font-size: @medium; | ||||
| } | ||||
| .ui.large.horizontal.list .list > .item, | ||||
| .ui.large.horizontal.list > .item { | ||||
|   font-size: @large; | ||||
| } | ||||
| .ui.big.horizontal.list .list > .item, | ||||
| .ui.big.horizontal.list > .item { | ||||
|   font-size: @big; | ||||
| } | ||||
| .ui.huge.horizontal.list .list > .item, | ||||
| .ui.huge.horizontal.list > .item { | ||||
|   font-size: @huge; | ||||
| } | ||||
| .ui.massive.horizontal.list .list > .item, | ||||
| .ui.massive.horizontal.list > .item { | ||||
|   font-size: @massive; | ||||
| } | ||||
|  | ||||
| .loadUIOverrides(); | ||||
|  | ||||
| @@ -1,331 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Loader | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'element'; | ||||
| @element : 'loader'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|             Loader | ||||
| *******************************/ | ||||
|  | ||||
|  | ||||
| /* Standard Size */ | ||||
| .ui.loader { | ||||
|   display: none; | ||||
|   position: absolute; | ||||
|   top: @loaderTopOffset; | ||||
|   left: @loaderLeftOffset; | ||||
|   margin: 0px; | ||||
|   text-align: center; | ||||
|   z-index: 1000; | ||||
|   transform: translateX(-50%) translateY(-50%); | ||||
| } | ||||
|  | ||||
| /* Static Shape */ | ||||
| .ui.loader:before { | ||||
|   position: absolute; | ||||
|   content: ''; | ||||
|   top: 0%; | ||||
|   left: 50%; | ||||
|   width: 100%; | ||||
|   height: 100%; | ||||
|  | ||||
|   border-radius: @circularRadius; | ||||
|   border: @loaderLineWidth solid @loaderFillColor; | ||||
| } | ||||
|  | ||||
| /* Active Shape */ | ||||
| .ui.loader:after { | ||||
|   position: absolute; | ||||
|   content: ''; | ||||
|   top: 0%; | ||||
|   left: 50%; | ||||
|   width: 100%; | ||||
|   height: 100%; | ||||
|  | ||||
|   animation: loader @loaderSpeed linear; | ||||
|   animation-iteration-count: infinite; | ||||
|  | ||||
|   border-radius: @circularRadius; | ||||
|  | ||||
|   border-color: @shapeBorderColor; | ||||
|   border-style: solid; | ||||
|   border-width: @loaderLineWidth; | ||||
|  | ||||
|   box-shadow: 0px 0px 0px 1px transparent; | ||||
| } | ||||
|  | ||||
| /* Active Animation */ | ||||
| @keyframes loader { | ||||
|   from { | ||||
|     transform: rotate(0deg); | ||||
|   } | ||||
|   to { | ||||
|     transform: rotate(360deg); | ||||
|   } | ||||
| } | ||||
|  | ||||
| /* Sizes */ | ||||
| .ui.mini.loader:before, | ||||
| .ui.mini.loader:after { | ||||
|   width: @mini; | ||||
|   height: @mini; | ||||
|   margin: @miniOffset; | ||||
| } | ||||
| .ui.tiny.loader:before, | ||||
| .ui.tiny.loader:after { | ||||
|   width: @tiny; | ||||
|   height: @tiny; | ||||
|   margin: @tinyOffset; | ||||
| } | ||||
| .ui.small.loader:before, | ||||
| .ui.small.loader:after { | ||||
|   width: @small; | ||||
|   height: @small; | ||||
|   margin: @smallOffset; | ||||
| } | ||||
| .ui.loader:before, | ||||
| .ui.loader:after { | ||||
|   width: @medium; | ||||
|   height: @medium; | ||||
|   margin: @mediumOffset; | ||||
| } | ||||
| .ui.large.loader:before, | ||||
| .ui.large.loader:after { | ||||
|   width: @large; | ||||
|   height: @large; | ||||
|   margin: @largeOffset; | ||||
| } | ||||
| .ui.big.loader:before, | ||||
| .ui.big.loader:after { | ||||
|   width: @big; | ||||
|   height: @big; | ||||
|   margin: @bigOffset; | ||||
| } | ||||
| .ui.huge.loader:before, | ||||
| .ui.huge.loader:after { | ||||
|   width: @huge; | ||||
|   height: @huge; | ||||
|   margin: @hugeOffset; | ||||
| } | ||||
| .ui.massive.loader:before, | ||||
| .ui.massive.loader:after { | ||||
|   width: @massive; | ||||
|   height: @massive; | ||||
|   margin: @massiveOffset; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|       Coupling | ||||
| --------------------*/ | ||||
|  | ||||
| /* Show inside active dimmer */ | ||||
| .ui.dimmer .loader { | ||||
|   display: block; | ||||
| } | ||||
|  | ||||
| /* Black Dimmer */ | ||||
| .ui.dimmer .ui.loader { | ||||
|   color: @invertedLoaderTextColor; | ||||
| } | ||||
| .ui.dimmer .ui.loader:before { | ||||
|   border-color: @invertedLoaderFillColor; | ||||
| } | ||||
| .ui.dimmer .ui.loader:after { | ||||
|   border-color: @invertedShapeBorderColor; | ||||
| } | ||||
|  | ||||
| /* White Dimmer (Inverted) */ | ||||
| .ui.inverted.dimmer .ui.loader { | ||||
|   color: @loaderTextColor; | ||||
| } | ||||
| .ui.inverted.dimmer .ui.loader:before { | ||||
|   border-color: @loaderFillColor; | ||||
| } | ||||
| .ui.inverted.dimmer .ui.loader:after { | ||||
|   border-color: @shapeBorderColor; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|              Types | ||||
| *******************************/ | ||||
|  | ||||
| /*------------------- | ||||
|         Text | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.text.loader { | ||||
|   width: auto !important; | ||||
|   height: auto !important; | ||||
|   text-align: center; | ||||
|   font-style: normal; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             States | ||||
| *******************************/ | ||||
|  | ||||
| .ui.indeterminate.loader:after { | ||||
|   animation-direction: @indeterminateDirection; | ||||
|   animation-duration: @indeterminateSpeed; | ||||
| } | ||||
|  | ||||
| .ui.loader.active, | ||||
| .ui.loader.visible { | ||||
|   display: block; | ||||
| } | ||||
| .ui.loader.disabled, | ||||
| .ui.loader.hidden { | ||||
|   display: none; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|             Variations | ||||
| *******************************/ | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|         Sizes | ||||
| --------------------*/ | ||||
|  | ||||
|  | ||||
| /* Loader */ | ||||
| .ui.inverted.dimmer .ui.mini.loader, | ||||
| .ui.mini.loader { | ||||
|   width: @mini; | ||||
|   height: @mini; | ||||
|   font-size: @miniFontSize; | ||||
| } | ||||
| .ui.inverted.dimmer .ui.tiny.loader, | ||||
| .ui.tiny.loader { | ||||
|   width: @tiny; | ||||
|   height: @tiny; | ||||
|   font-size: @tinyFontSize; | ||||
| } | ||||
| .ui.inverted.dimmer .ui.small.loader, | ||||
| .ui.small.loader { | ||||
|   width: @small; | ||||
|   height: @small; | ||||
|   font-size: @smallFontSize; | ||||
| } | ||||
| .ui.inverted.dimmer .ui.loader, | ||||
| .ui.loader { | ||||
|   width: @medium; | ||||
|   height: @medium; | ||||
|   font-size: @mediumFontSize; | ||||
| } | ||||
| .ui.inverted.dimmer .ui.large.loader, | ||||
| .ui.large.loader { | ||||
|   width: @large; | ||||
|   height: @large; | ||||
|   font-size: @largeFontSize; | ||||
| } | ||||
| .ui.inverted.dimmer .ui.big.loader, | ||||
| .ui.big.loader { | ||||
|   width: @big; | ||||
|   height: @big; | ||||
|   font-size: @bigFontSize; | ||||
| } | ||||
| .ui.inverted.dimmer .ui.huge.loader, | ||||
| .ui.huge.loader { | ||||
|   width: @huge; | ||||
|   height: @huge; | ||||
|   font-size: @hugeFontSize; | ||||
| } | ||||
| .ui.inverted.dimmer .ui.massive.loader, | ||||
| .ui.massive.loader { | ||||
|   width: @massive; | ||||
|   height: @massive; | ||||
|   font-size: @massiveFontSize; | ||||
| } | ||||
|  | ||||
| /* Text Loader */ | ||||
| .ui.mini.text.loader { | ||||
|   min-width: @mini; | ||||
|   padding-top: (@mini + @textDistance); | ||||
| } | ||||
| .ui.tiny.text.loader { | ||||
|   min-width: @tiny; | ||||
|   padding-top: (@tiny + @textDistance); | ||||
| } | ||||
| .ui.small.text.loader { | ||||
|   min-width: @small; | ||||
|   padding-top: (@small + @textDistance); | ||||
| } | ||||
| .ui.text.loader { | ||||
|   min-width: @medium; | ||||
|   padding-top: (@medium + @textDistance); | ||||
| } | ||||
| .ui.large.text.loader { | ||||
|   min-width: @large; | ||||
|   padding-top: (@large + @textDistance); | ||||
| } | ||||
| .ui.big.text.loader { | ||||
|   min-width: @big; | ||||
|   padding-top: (@big + @textDistance); | ||||
| } | ||||
| .ui.huge.text.loader { | ||||
|   min-width: @huge; | ||||
|   padding-top: (@huge + @textDistance); | ||||
| } | ||||
| .ui.massive.text.loader { | ||||
|   min-width: @massive; | ||||
|   padding-top: (@massive + @textDistance); | ||||
| } | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|        Inverted | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.inverted.loader { | ||||
|   color: @invertedLoaderTextColor | ||||
| } | ||||
| .ui.inverted.loader:before { | ||||
|   border-color: @invertedLoaderFillColor; | ||||
| } | ||||
| .ui.inverted.loader:after { | ||||
|   border-top-color: @invertedLoaderLineColor; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Inline | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.inline.loader { | ||||
|   position: relative; | ||||
|   vertical-align: @inlineVerticalAlign; | ||||
|   margin: @inlineMargin; | ||||
|   left: 0em; | ||||
|   top: 0em; | ||||
|   transform: none; | ||||
| } | ||||
|  | ||||
| .ui.inline.loader.active, | ||||
| .ui.inline.loader.visible { | ||||
|   display: inline-block; | ||||
| } | ||||
|  | ||||
| /* Centered Inline */ | ||||
| .ui.centered.inline.loader.active, | ||||
| .ui.centered.inline.loader.visible { | ||||
|   display: block; | ||||
|   margin-left: auto; | ||||
|   margin-right: auto; | ||||
| } | ||||
|  | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,232 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Loader | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'element'; | ||||
| @element : 'placeholder'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /*------------------- | ||||
|       Content | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.placeholder { | ||||
|   position: static; | ||||
|   overflow: hidden; | ||||
|   animation: placeholderShimmer @placeholderLoadingAnimationDuration linear; | ||||
|   animation-iteration-count: infinite; | ||||
|   background-color: @white; | ||||
|   background-image: @placeholderLoadingGradient; | ||||
|   background-size: @placeholderLoadingGradientWidth 100%; | ||||
|   max-width: @placeholderMaxWidth; | ||||
| } | ||||
|  | ||||
| @keyframes placeholderShimmer{ | ||||
|   0% { | ||||
|     background-position: -@placeholderLoadingGradientWidth 0 | ||||
|   } | ||||
|   100% { | ||||
|     background-position: @placeholderLoadingGradientWidth 0 | ||||
|   } | ||||
| } | ||||
|  | ||||
| .ui.placeholder + .ui.placeholder { | ||||
|   margin-top: @consecutivePlaceholderSpacing; | ||||
| } | ||||
| .ui.placeholder + .ui.placeholder { | ||||
|   animation-delay: @placeholderAnimationInterval; | ||||
| } | ||||
| .ui.placeholder + .ui.placeholder + .ui.placeholder { | ||||
|   animation-delay: (@placeholderAnimationInterval * 2); | ||||
| } | ||||
| .ui.placeholder + .ui.placeholder + .ui.placeholder + .ui.placeholder { | ||||
|   animation-delay: (@placeholderAnimationInterval * 3); | ||||
| } | ||||
| .ui.placeholder + .ui.placeholder + .ui.placeholder + .ui.placeholder + .ui.placeholder { | ||||
|   animation-delay: (@placeholderAnimationInterval * 4); | ||||
| } | ||||
|  | ||||
| .ui.placeholder, | ||||
| .ui.placeholder > :before, | ||||
| .ui.placeholder .image.header:after, | ||||
| .ui.placeholder .line, | ||||
| .ui.placeholder .line:after { | ||||
|   background-color: @white; | ||||
| } | ||||
|  | ||||
| /* Image */ | ||||
| .ui.placeholder .image:not(.header):not(.ui) { | ||||
|   height: @placeholderImageHeight; | ||||
| } | ||||
| .ui.placeholder .square.image:not(.header) { | ||||
|   height: 0px; | ||||
|   overflow: hidden; | ||||
|   /* 1/1 aspect ratio */ | ||||
|   padding-top: 100%; | ||||
| } | ||||
| .ui.placeholder .rectangular.image:not(.header) { | ||||
|   height: 0px; | ||||
|   overflow: hidden; | ||||
|   /* 4/3 aspect ratio */ | ||||
|   padding-top: 75%; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Lines */ | ||||
| .ui.placeholder .line { | ||||
|   position: relative; | ||||
|   height: @placeholderLineMargin; | ||||
| } | ||||
| .ui.placeholder .line:before, | ||||
| .ui.placeholder .line:after { | ||||
|   top: 100%; | ||||
|   position: absolute; | ||||
|   content: ''; | ||||
|   background-color: inherit; | ||||
| } | ||||
| .ui.placeholder .line:before { | ||||
|   left: 0px; | ||||
| } | ||||
| .ui.placeholder .line:after { | ||||
|   right: 0px; | ||||
| } | ||||
|  | ||||
| /* Any Lines */ | ||||
| .ui.placeholder .line { | ||||
|   margin-bottom: @placeholderLineHeight; | ||||
| } | ||||
| .ui.placeholder .line:before, | ||||
| .ui.placeholder .line:after { | ||||
|   height: @placeholderLineHeight; | ||||
| } | ||||
| .ui.placeholder .line:not(:first-child) { | ||||
|   margin-top: @placeholderLineHeight; | ||||
| } | ||||
|  | ||||
| /* Header Image + 2 Lines */ | ||||
| .ui.placeholder .header { | ||||
|   position: relative; | ||||
|   overflow: hidden; | ||||
| } | ||||
|  | ||||
| /* Line Outdent */ | ||||
| .ui.placeholder .line:nth-child(1):after { | ||||
|   width: @placeholderLineOneOutdent; | ||||
| } | ||||
| .ui.placeholder .line:nth-child(2):after { | ||||
|   width: @placeholderLineTwoOutdent; | ||||
| } | ||||
| .ui.placeholder .line:nth-child(3):after { | ||||
|   width: @placeholderLineThreeOutdent; | ||||
| } | ||||
| .ui.placeholder .line:nth-child(4):after { | ||||
|   width: @placeholderLineFourOutdent; | ||||
| } | ||||
| .ui.placeholder .line:nth-child(5):after { | ||||
|   width: @placeholderLineFiveOutdent; | ||||
| } | ||||
|  | ||||
| /* Header Line 1 & 2*/ | ||||
| .ui.placeholder .header .line { | ||||
|   margin-bottom: @placeholderHeaderLineHeight; | ||||
| } | ||||
| .ui.placeholder .header .line:before, | ||||
| .ui.placeholder .header .line:after { | ||||
|   height: @placeholderHeaderLineHeight; | ||||
| } | ||||
| .ui.placeholder .header .line:not(:first-child) { | ||||
|   margin-top: @placeholderHeaderLineHeight; | ||||
| } | ||||
| .ui.placeholder .header .line:after { | ||||
|   width: @placeholderHeaderLineOneOutdent; | ||||
| } | ||||
| .ui.placeholder .header .line:nth-child(2):after { | ||||
|   width: @placeholderHeaderLineTwoOutdent; | ||||
| } | ||||
|  | ||||
| /* Image Header */ | ||||
| .ui.placeholder .image.header .line { | ||||
|   margin-left: @placeholderImageWidth; | ||||
| } | ||||
| .ui.placeholder .image.header .line:before { | ||||
|   width: @placeholderImageTextIndent; | ||||
| } | ||||
| .ui.placeholder .image.header:after { | ||||
|   display: block; | ||||
|   height: @placeholderLineMargin; | ||||
|   content: ''; | ||||
|   margin-left: @placeholderImageWidth; | ||||
| } | ||||
|  | ||||
| /* Spacing */ | ||||
| .ui.placeholder .image .line:first-child, | ||||
| .ui.placeholder .paragraph .line:first-child, | ||||
| .ui.placeholder .header .line:first-child { | ||||
|   height: 0.01px; | ||||
| } | ||||
| .ui.placeholder .image:not(:first-child):before, | ||||
| .ui.placeholder .paragraph:not(:first-child):before, | ||||
| .ui.placeholder .header:not(:first-child):before { | ||||
|   height: @placeholderSpacing; | ||||
|   content: ''; | ||||
|   display: block; | ||||
| } | ||||
|  | ||||
| /* Inverted Content Loader */ | ||||
| .ui.inverted.placeholder { | ||||
|   background-image: @placeholderInvertedLoadingGradient; | ||||
| } | ||||
| .ui.inverted.placeholder, | ||||
| .ui.inverted.placeholder > :before, | ||||
| .ui.inverted.placeholder .image.header:after, | ||||
| .ui.inverted.placeholder .line, | ||||
| .ui.inverted.placeholder .line:after { | ||||
|   background-color: @black; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|             Variations | ||||
| *******************************/ | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|         Sizes | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.placeholder .full.line.line.line:after { | ||||
|   width: @placeholderFullLineOutdent; | ||||
| } | ||||
| .ui.placeholder .very.long.line.line.line:after { | ||||
|   width: @placeholderVeryLongLineOutdent; | ||||
| } | ||||
| .ui.placeholder .long.line.line.line:after { | ||||
|   width: @placeholderLongLineOutdent; | ||||
| } | ||||
| .ui.placeholder .medium.line.line.line:after { | ||||
|   width: @placeholderMediumLineOutdent; | ||||
| } | ||||
| .ui.placeholder .short.line.line.line:after { | ||||
|   width: @placeholderShortLineOutdent; | ||||
| } | ||||
| .ui.placeholder .very.short.line.line.line:after { | ||||
|   width: @placeholderVeryShortLineOutdent; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|         Fluid | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.fluid.placeholder { | ||||
|   max-width: none; | ||||
| } | ||||
| @@ -1,154 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Rail | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'element'; | ||||
| @element : 'rail'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|              Rails | ||||
| *******************************/ | ||||
|  | ||||
| .ui.rail { | ||||
|   position: absolute; | ||||
|   top: 0%; | ||||
|   width: @width; | ||||
|   height: @height; | ||||
| } | ||||
|  | ||||
| .ui.left.rail { | ||||
|   left: auto; | ||||
|   right: 100%; | ||||
|   padding: 0em @splitDistance 0em 0em; | ||||
|   margin: 0em @splitDistance 0em 0em; | ||||
| } | ||||
|  | ||||
| .ui.right.rail { | ||||
|   left: 100%; | ||||
|   right: auto; | ||||
|   padding: 0em 0em 0em @splitDistance; | ||||
|   margin: 0em 0em 0em @splitDistance; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|            Variations | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|      Internal | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.left.internal.rail { | ||||
|   left: 0%; | ||||
|   right: auto; | ||||
|   padding: 0em 0em 0em @splitDistance; | ||||
|   margin: 0em 0em 0em @splitDistance; | ||||
| } | ||||
|  | ||||
| .ui.right.internal.rail { | ||||
|   left: auto; | ||||
|   right: 0%; | ||||
|   padding: 0em @splitDistance 0em 0em; | ||||
|   margin: 0em @splitDistance 0em 0em; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|     Dividing | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.dividing.rail { | ||||
|   width: @dividingWidth; | ||||
| } | ||||
| .ui.left.dividing.rail { | ||||
|   padding: 0em @splitDividingDistance 0em 0em; | ||||
|   margin: 0em @splitDividingDistance 0em 0em; | ||||
|   border-right: @dividingBorder; | ||||
| } | ||||
| .ui.right.dividing.rail { | ||||
|   border-left: @dividingBorder; | ||||
|   padding: 0em 0em 0em @splitDividingDistance; | ||||
|   margin: 0em 0em 0em @splitDividingDistance; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Distance | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.close.rail { | ||||
|   width: @closeWidth; | ||||
| } | ||||
| .ui.close.left.rail { | ||||
|   padding: 0em @splitCloseDistance 0em 0em; | ||||
|   margin: 0em @splitCloseDistance 0em 0em; | ||||
| } | ||||
| .ui.close.right.rail { | ||||
|   padding: 0em 0em 0em @splitCloseDistance; | ||||
|   margin: 0em 0em 0em @splitCloseDistance; | ||||
| } | ||||
|  | ||||
| .ui.very.close.rail { | ||||
|   width: @veryCloseWidth; | ||||
| } | ||||
| .ui.very.close.left.rail { | ||||
|   padding: 0em @splitVeryCloseDistance 0em 0em; | ||||
|   margin: 0em @splitVeryCloseDistance 0em 0em; | ||||
| } | ||||
| .ui.very.close.right.rail { | ||||
|   padding: 0em 0em 0em @splitVeryCloseDistance; | ||||
|   margin: 0em 0em 0em @splitVeryCloseDistance; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Attached | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.attached.left.rail, | ||||
| .ui.attached.right.rail { | ||||
|   padding: 0em; | ||||
|   margin: 0em; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Sizing | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.mini.rail { | ||||
|   font-size: @mini; | ||||
| } | ||||
| .ui.tiny.rail { | ||||
|   font-size: @tiny; | ||||
| } | ||||
| .ui.small.rail { | ||||
|   font-size: @small; | ||||
| } | ||||
| .ui.rail { | ||||
|   font-size: @medium; | ||||
| } | ||||
| .ui.large.rail { | ||||
|   font-size: @large; | ||||
| } | ||||
| .ui.big.rail { | ||||
|   font-size: @big; | ||||
| } | ||||
| .ui.huge.rail { | ||||
|   font-size: @huge; | ||||
| } | ||||
| .ui.massive.rail { | ||||
|   font-size: @massive; | ||||
| } | ||||
|  | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,275 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Reveal | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'element'; | ||||
| @element : 'reveal'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|             Reveal | ||||
| *******************************/ | ||||
|  | ||||
| .ui.reveal  { | ||||
|   display: inherit; | ||||
|   position: relative !important; | ||||
|   font-size: 0em !important; | ||||
| } | ||||
|  | ||||
| .ui.reveal > .visible.content { | ||||
|   position: absolute !important; | ||||
|   top: 0em !important; | ||||
|   left: 0em !important; | ||||
|   z-index: @topZIndex !important; | ||||
|   transition: @transition; | ||||
| } | ||||
| .ui.reveal > .hidden.content { | ||||
|   position: relative !important; | ||||
|   z-index: @bottomZIndex !important; | ||||
| } | ||||
|  | ||||
| /* Make sure hovered element is on top of other reveal */ | ||||
| .ui.active.reveal .visible.content, | ||||
| .ui.reveal:hover .visible.content { | ||||
|   z-index: @activeZIndex !important; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|               Types | ||||
| *******************************/ | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|       Slide | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.slide.reveal { | ||||
|   position: relative !important; | ||||
|   overflow: hidden !important; | ||||
|   white-space: nowrap; | ||||
| } | ||||
|  | ||||
| .ui.slide.reveal > .content { | ||||
|   display: block; | ||||
|   width: 100%; | ||||
|   white-space: normal; | ||||
|   float: left; | ||||
|  | ||||
|   margin: 0em; | ||||
|   transition: @slideTransition; | ||||
| } | ||||
|  | ||||
| .ui.slide.reveal > .visible.content { | ||||
|   position: relative !important; | ||||
| } | ||||
| .ui.slide.reveal > .hidden.content { | ||||
|   position: absolute !important; | ||||
|   left: 0% !important; | ||||
|   width: 100% !important; | ||||
|   transform: translateX(100%) !important; | ||||
| } | ||||
| .ui.slide.active.reveal > .visible.content, | ||||
| .ui.slide.reveal:hover > .visible.content { | ||||
|   transform: translateX(-100%) !important; | ||||
| } | ||||
| .ui.slide.active.reveal > .hidden.content, | ||||
| .ui.slide.reveal:hover > .hidden.content { | ||||
|   transform: translateX(0%) !important; | ||||
| } | ||||
|  | ||||
| .ui.slide.right.reveal > .visible.content { | ||||
|   transform: translateX(0%) !important; | ||||
| } | ||||
| .ui.slide.right.reveal > .hidden.content { | ||||
|   transform: translateX(-100%) !important; | ||||
| } | ||||
| .ui.slide.right.active.reveal > .visible.content, | ||||
| .ui.slide.right.reveal:hover > .visible.content { | ||||
|   transform: translateX(100%) !important; | ||||
| } | ||||
| .ui.slide.right.active.reveal > .hidden.content, | ||||
| .ui.slide.right.reveal:hover > .hidden.content { | ||||
|   transform: translateX(0%) !important; | ||||
| } | ||||
|  | ||||
| .ui.slide.up.reveal > .hidden.content { | ||||
|   transform: translateY(100%) !important; | ||||
| } | ||||
| .ui.slide.up.active.reveal > .visible.content, | ||||
| .ui.slide.up.reveal:hover > .visible.content { | ||||
|   transform: translateY(-100%) !important; | ||||
| } | ||||
| .ui.slide.up.active.reveal > .hidden.content, | ||||
| .ui.slide.up.reveal:hover > .hidden.content { | ||||
|   transform: translateY(0%) !important; | ||||
| } | ||||
|  | ||||
| .ui.slide.down.reveal > .hidden.content { | ||||
|   transform: translateY(-100%) !important; | ||||
| } | ||||
| .ui.slide.down.active.reveal > .visible.content, | ||||
| .ui.slide.down.reveal:hover > .visible.content { | ||||
|   transform: translateY(100%) !important; | ||||
| } | ||||
| .ui.slide.down.active.reveal > .hidden.content, | ||||
| .ui.slide.down.reveal:hover > .hidden.content { | ||||
|   transform: translateY(0%) !important; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|       Fade | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.fade.reveal > .visible.content { | ||||
|   opacity: 1; | ||||
| } | ||||
| .ui.fade.active.reveal > .visible.content, | ||||
| .ui.fade.reveal:hover > .visible.content { | ||||
|   opacity: 0; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|       Move | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.move.reveal { | ||||
|   position: relative !important; | ||||
|   overflow: hidden !important; | ||||
|   white-space: nowrap; | ||||
| } | ||||
|  | ||||
| .ui.move.reveal > .content { | ||||
|   display: block; | ||||
|   float: left; | ||||
|   white-space: normal; | ||||
|  | ||||
|   margin: 0em; | ||||
|   transition: @moveTransition; | ||||
| } | ||||
|  | ||||
| .ui.move.reveal > .visible.content { | ||||
|   position: relative !important; | ||||
| } | ||||
| .ui.move.reveal > .hidden.content { | ||||
|   position: absolute !important; | ||||
|   left: 0% !important; | ||||
|   width: 100% !important; | ||||
| } | ||||
| .ui.move.active.reveal > .visible.content, | ||||
| .ui.move.reveal:hover > .visible.content { | ||||
|   transform: translateX(-100%) !important; | ||||
| } | ||||
| .ui.move.right.active.reveal > .visible.content, | ||||
| .ui.move.right.reveal:hover > .visible.content { | ||||
|   transform: translateX(100%) !important; | ||||
| } | ||||
| .ui.move.up.active.reveal > .visible.content, | ||||
| .ui.move.up.reveal:hover > .visible.content { | ||||
|   transform: translateY(-100%) !important; | ||||
| } | ||||
| .ui.move.down.active.reveal > .visible.content, | ||||
| .ui.move.down.reveal:hover > .visible.content { | ||||
|   transform: translateY(100%) !important; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|      Rotate | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.rotate.reveal > .visible.content { | ||||
|   transition-duration: @transitionDuration; | ||||
|   transform: rotate(0deg); | ||||
| } | ||||
|  | ||||
| .ui.rotate.reveal > .visible.content, | ||||
| .ui.rotate.right.reveal > .visible.content { | ||||
|   transform-origin: bottom right; | ||||
| } | ||||
| .ui.rotate.active.reveal > .visible.content, | ||||
| .ui.rotate.reveal:hover > .visible.content, | ||||
| .ui.rotate.right.active.reveal > .visible.content, | ||||
| .ui.rotate.right.reveal:hover > .visible.content { | ||||
|   transform: rotate(@rotateDegrees); | ||||
| } | ||||
|  | ||||
| .ui.rotate.left.reveal > .visible.content { | ||||
|   transform-origin: bottom left; | ||||
| } | ||||
| .ui.rotate.left.active.reveal > .visible.content, | ||||
| .ui.rotate.left.reveal:hover > .visible.content { | ||||
|   transform: rotate(-@rotateDegrees); | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|               States | ||||
| *******************************/ | ||||
|  | ||||
| .ui.disabled.reveal:hover > .visible.visible.content { | ||||
|   position: static !important; | ||||
|   display: block !important; | ||||
|   opacity: 1 !important; | ||||
|   top: 0 !important; | ||||
|   left: 0 !important; | ||||
|   right: auto !important; | ||||
|   bottom: auto !important; | ||||
|   transform: none !important; | ||||
| } | ||||
| .ui.disabled.reveal:hover > .hidden.hidden.content { | ||||
|   display: none !important; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|            Coupling | ||||
| *******************************/ | ||||
|  | ||||
| .ui.reveal > .ui.ribbon.label { | ||||
|   z-index: @overlayZIndex; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|            Variations | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|      Visible | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.visible.reveal { | ||||
|   overflow: visible; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Instant | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.instant.reveal > .content { | ||||
|   transition-delay: 0s !important; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|      Sizing | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.reveal > .content { | ||||
|   font-size: @medium !important; | ||||
| } | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,829 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Segment | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'element'; | ||||
| @element : 'segment'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|             Segment | ||||
| *******************************/ | ||||
|  | ||||
| .ui.segment { | ||||
|   position: relative; | ||||
|   background: @background; | ||||
|   box-shadow: @boxShadow; | ||||
|   margin: @margin; | ||||
|   padding: @padding; | ||||
|   border-radius: @borderRadius; | ||||
|   border: @border; | ||||
| } | ||||
|  | ||||
| .ui.segment:first-child { | ||||
|   margin-top: 0em; | ||||
| } | ||||
| .ui.segment:last-child { | ||||
|   margin-bottom: 0em; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Vertical */ | ||||
| .ui.vertical.segment { | ||||
|   margin: 0em; | ||||
|   padding-left: 0em; | ||||
|   padding-right: 0em; | ||||
|  | ||||
|   background: none transparent; | ||||
|   border-radius: 0px; | ||||
|   box-shadow: none; | ||||
|   border: none; | ||||
|   border-bottom: @borderWidth solid @borderColor; | ||||
| } | ||||
| .ui.vertical.segment:last-child { | ||||
|   border-bottom: none; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|     Loose Coupling | ||||
| --------------------*/ | ||||
|  | ||||
| /* Header */ | ||||
| .ui.inverted.segment > .ui.header { | ||||
|   color: @white; | ||||
| } | ||||
|  | ||||
| /* Label */ | ||||
| .ui[class*="bottom attached"].segment > [class*="top attached"].label { | ||||
|   border-top-left-radius: 0em; | ||||
|   border-top-right-radius: 0em; | ||||
| } | ||||
| .ui[class*="top attached"].segment > [class*="bottom attached"].label { | ||||
|   border-bottom-left-radius: 0em; | ||||
|   border-bottom-right-radius: 0em; | ||||
| } | ||||
| .ui.attached.segment:not(.top):not(.bottom) > [class*="top attached"].label { | ||||
|   border-top-left-radius: 0em; | ||||
|   border-top-right-radius: 0em; | ||||
| } | ||||
| .ui.attached.segment:not(.top):not(.bottom) > [class*="bottom attached"].label { | ||||
|   border-bottom-left-radius: 0em; | ||||
|   border-bottom-right-radius: 0em; | ||||
| } | ||||
|  | ||||
| /* Grid */ | ||||
| .ui.page.grid.segment, | ||||
| .ui.grid > .row > .ui.segment.column, | ||||
| .ui.grid > .ui.segment.column { | ||||
|   padding-top: @pageGridMargin; | ||||
|   padding-bottom: @pageGridMargin; | ||||
| } | ||||
| .ui.grid.segment { | ||||
|   margin: @margin; | ||||
|   border-radius: @borderRadius; | ||||
| } | ||||
|  | ||||
| /* Table */ | ||||
| .ui.basic.table.segment { | ||||
|   background: @background; | ||||
|   border: @border; | ||||
|   box-shadow: @boxShadow; | ||||
| } | ||||
| .ui[class*="very basic"].table.segment { | ||||
|   padding: @padding; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|              Types | ||||
| *******************************/ | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|      Placeholder | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.placeholder.segment { | ||||
|   display: flex; | ||||
|   flex-direction: column; | ||||
|   justify-content: center; | ||||
|   align-items: stretch; | ||||
|   max-width: initial; | ||||
|   animation: none; | ||||
|   overflow: visible; | ||||
|   padding: @placeholderPadding; | ||||
|   min-height: @placeholderMinHeight; | ||||
|   background: @placeholderBackground; | ||||
|   border-color: @placeholderBorderColor; | ||||
|   box-shadow: @placeholderBoxShadow; | ||||
| } | ||||
|  | ||||
| .ui.placeholder.segment .button, | ||||
| .ui.placeholder.segment textarea { | ||||
|   display: block; | ||||
| } | ||||
| .ui.placeholder.segment .field, | ||||
| .ui.placeholder.segment textarea, | ||||
| .ui.placeholder.segment > .ui.input, | ||||
| .ui.placeholder.segment .button { | ||||
|   max-width: @placeholderContentMaxWidth; | ||||
|   margin-left: auto; | ||||
|   margin-right: auto; | ||||
| } | ||||
| .ui.placeholder.segment .column .button, | ||||
| .ui.placeholder.segment .column .field, | ||||
| .ui.placeholder.segment .column textarea, | ||||
| .ui.placeholder.segment .column > .ui.input { | ||||
|   max-width: @placeholderContentMaxWidth; | ||||
|   margin-left: auto; | ||||
|   margin-right: auto; | ||||
| } | ||||
|  | ||||
| .ui.placeholder.segment > .inline  { | ||||
|   align-self: center; | ||||
| } | ||||
| .ui.placeholder.segment > .inline > .button { | ||||
|   display: inline-block; | ||||
|   width: auto; | ||||
|   margin: @placeholderContentInlineButtonMargin; | ||||
| } | ||||
| .ui.placeholder.segment > .inline > .button:last-child { | ||||
|   margin-right: 0px; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|         Piled | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.piled.segments, | ||||
| .ui.piled.segment { | ||||
|   margin: @piledMargin 0em; | ||||
|   box-shadow: @piledBoxShadow; | ||||
|   z-index: @piledZIndex; | ||||
| } | ||||
| .ui.piled.segment:first-child { | ||||
|   margin-top: 0em; | ||||
| } | ||||
| .ui.piled.segment:last-child { | ||||
|   margin-bottom: 0em; | ||||
| } | ||||
| .ui.piled.segments:after, | ||||
| .ui.piled.segments:before, | ||||
| .ui.piled.segment:after, | ||||
| .ui.piled.segment:before { | ||||
|   background-color: @white; | ||||
|   visibility: visible; | ||||
|   content: ''; | ||||
|   display: block; | ||||
|   height: 100%; | ||||
|   left: 0px; | ||||
|   position: absolute; | ||||
|   width: 100%; | ||||
|   border: @piledBorder; | ||||
|   box-shadow: @piledBoxShadow; | ||||
| } | ||||
| .ui.piled.segments:before, | ||||
| .ui.piled.segment:before { | ||||
|   transform: rotate(-@piledDegrees); | ||||
|   top: 0; | ||||
|   z-index: -2; | ||||
| } | ||||
| .ui.piled.segments:after, | ||||
| .ui.piled.segment:after { | ||||
|   transform: rotate(@piledDegrees); | ||||
|   top: 0; | ||||
|   z-index: -1; | ||||
| } | ||||
|  | ||||
| /* Piled Attached */ | ||||
| .ui[class*="top attached"].piled.segment { | ||||
|   margin-top: @piledMargin; | ||||
|   margin-bottom: 0em; | ||||
| } | ||||
| .ui.piled.segment[class*="top attached"]:first-child { | ||||
|   margin-top: 0em; | ||||
| } | ||||
| .ui.piled.segment[class*="bottom attached"] { | ||||
|   margin-top: 0em; | ||||
|   margin-bottom: @piledMargin; | ||||
| } | ||||
| .ui.piled.segment[class*="bottom attached"]:last-child { | ||||
|   margin-bottom: 0em; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Stacked | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.stacked.segment { | ||||
|   padding-bottom: @stackedPadding; | ||||
| } | ||||
| .ui.stacked.segments:before, | ||||
| .ui.stacked.segments:after, | ||||
| .ui.stacked.segment:before, | ||||
| .ui.stacked.segment:after { | ||||
|   content: ''; | ||||
|   position: absolute; | ||||
|   bottom: -(@stackedHeight / 2); | ||||
|   left: 0%; | ||||
|  | ||||
|   border-top: 1px solid @borderColor; | ||||
|   background: @stackedPageBackground; | ||||
|  | ||||
|   width: 100%; | ||||
|   height: @stackedHeight; | ||||
|   visibility: visible; | ||||
| } | ||||
| .ui.stacked.segments:before, | ||||
| .ui.stacked.segment:before { | ||||
|   display: none; | ||||
| } | ||||
|  | ||||
| /* Add additional page */ | ||||
| .ui.tall.stacked.segments:before, | ||||
| .ui.tall.stacked.segment:before { | ||||
|   display: block; | ||||
|   bottom: 0px; | ||||
| } | ||||
|  | ||||
| /* Inverted */ | ||||
| .ui.stacked.inverted.segments:before, | ||||
| .ui.stacked.inverted.segments:after, | ||||
| .ui.stacked.inverted.segment:before, | ||||
| .ui.stacked.inverted.segment:after { | ||||
|   background-color: @subtleTransparentBlack; | ||||
|   border-top: 1px solid @selectedBorderColor; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Padded | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.padded.segment { | ||||
|   padding: @paddedSegmentPadding; | ||||
| } | ||||
|  | ||||
| .ui[class*="very padded"].segment { | ||||
|   padding: @veryPaddedSegmentPadding; | ||||
| } | ||||
|  | ||||
| /* Padded vertical */ | ||||
| .ui.padded.segment.vertical.segment, | ||||
| .ui[class*="very padded"].vertical.segment { | ||||
|   padding-left: 0px; | ||||
|   padding-right: 0px; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Compact | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.compact.segment { | ||||
|   display: table; | ||||
| } | ||||
|  | ||||
| /* Compact Group */ | ||||
| .ui.compact.segments { | ||||
|   display: inline-flex; | ||||
| } | ||||
| .ui.compact.segments .segment, | ||||
| .ui.segments .compact.segment { | ||||
|   display: block; | ||||
|   flex: 0 1 auto; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Circular | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.circular.segment { | ||||
|   display: table-cell; | ||||
|   padding: @circularPadding; | ||||
|   text-align: center; | ||||
|   vertical-align: middle; | ||||
|   border-radius: 500em; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Raised | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.raised.segments, | ||||
| .ui.raised.segment { | ||||
|   box-shadow: @raisedBoxShadow; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Groups | ||||
| *******************************/ | ||||
|  | ||||
| /* Group */ | ||||
| .ui.segments { | ||||
|   flex-direction: column; | ||||
|   position: relative; | ||||
|   margin: @groupedMargin; | ||||
|   border: @groupedBorder; | ||||
|   box-shadow: @groupedBoxShadow; | ||||
|   border-radius: @groupedBorderRadius; | ||||
| } | ||||
| .ui.segments:first-child { | ||||
|   margin-top: 0em; | ||||
| } | ||||
| .ui.segments:last-child { | ||||
|   margin-bottom: 0em; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Nested Segment */ | ||||
| .ui.segments > .segment { | ||||
|   top: 0px; | ||||
|   bottom: 0px; | ||||
|   border-radius: 0px; | ||||
|   margin: @groupedSegmentMargin; | ||||
|   width: @groupedSegmentWidth; | ||||
|   box-shadow: @groupedSegmentBoxShadow; | ||||
|   border: @groupedSegmentBorder; | ||||
|   border-top: @groupedSegmentDivider; | ||||
| } | ||||
|  | ||||
| .ui.segments:not(.horizontal) > .segment:first-child { | ||||
|   top: @attachedTopOffset; | ||||
|   bottom: 0px; | ||||
|   border-top: none; | ||||
|   margin-top: 0em; | ||||
|   bottom: 0px; | ||||
|   margin-bottom: 0em; | ||||
|   top: @attachedTopOffset; | ||||
|   border-radius: @borderRadius @borderRadius 0em 0em; | ||||
| } | ||||
|  | ||||
| /* Bottom */ | ||||
| .ui.segments:not(.horizontal) > .segment:last-child { | ||||
|   top: @attachedBottomOffset; | ||||
|   bottom: 0px; | ||||
|   margin-top: 0em; | ||||
|   margin-bottom: 0em; | ||||
|   box-shadow: @attachedBottomBoxShadow; | ||||
|   border-radius: 0em 0em @borderRadius @borderRadius; | ||||
| } | ||||
|  | ||||
| /* Only */ | ||||
| .ui.segments:not(.horizontal) > .segment:only-child { | ||||
|   border-radius: @borderRadius; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Nested Group */ | ||||
| .ui.segments > .ui.segments { | ||||
|   border-top: @groupedSegmentDivider; | ||||
|   margin: @nestedGroupMargin; | ||||
| } | ||||
| .ui.segments > .segments:first-child { | ||||
|   border-top: none; | ||||
| } | ||||
| .ui.segments > .segment + .segments:not(.horizontal) { | ||||
|   margin-top: 0em; | ||||
| } | ||||
|  | ||||
| /* Horizontal Group */ | ||||
| .ui.horizontal.segments { | ||||
|   display: flex; | ||||
|   flex-direction: row; | ||||
|   background-color: transparent; | ||||
|   border-radius: 0px; | ||||
|   padding: 0em; | ||||
|   background-color: @background; | ||||
|   box-shadow: @boxShadow; | ||||
|   margin: @margin; | ||||
|   border-radius: @borderRadius; | ||||
|   border: @border; | ||||
| } | ||||
|  | ||||
| /* Nested Horizontal Group */ | ||||
| .ui.segments > .horizontal.segments { | ||||
|   margin: 0em; | ||||
|   background-color: transparent; | ||||
|   border-radius: 0px; | ||||
|   border: none; | ||||
|   box-shadow: none; | ||||
|   border-top: @groupedSegmentDivider; | ||||
| } | ||||
|  | ||||
| /* Horizontal Segment */ | ||||
| .ui.horizontal.segments > .segment { | ||||
|   flex: 1 1 auto; | ||||
|   -ms-flex: 1 1 0px; /* Solves #2550 MS Flex */ | ||||
|   margin: 0em; | ||||
|   min-width: 0px; | ||||
|   background-color: transparent; | ||||
|   border-radius: 0px; | ||||
|   border: none; | ||||
|   box-shadow: none; | ||||
|   border-left: @borderWidth solid @borderColor; | ||||
| } | ||||
|  | ||||
| /* Border Fixes */ | ||||
| .ui.segments > .horizontal.segments:first-child { | ||||
|   border-top: none; | ||||
| } | ||||
| .ui.horizontal.segments > .segment:first-child { | ||||
|   border-left: none; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             States | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|     Disabled | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.disabled.segment { | ||||
|   opacity: @disabledOpacity; | ||||
|   color: @disabledTextColor; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Loading | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.loading.segment { | ||||
|   position: relative; | ||||
|   cursor: default; | ||||
|   pointer-events: none; | ||||
|   text-shadow: none !important; | ||||
|   color: transparent !important; | ||||
|   transition: all 0s linear; | ||||
| } | ||||
| .ui.loading.segment:before { | ||||
|   position: absolute; | ||||
|   content: ''; | ||||
|   top: 0%; | ||||
|   left: 0%; | ||||
|   background: @loaderDimmerColor; | ||||
|   width: 100%; | ||||
|   height: 100%; | ||||
|   border-radius: @borderRadius; | ||||
|   z-index: @loaderDimmerZIndex; | ||||
| } | ||||
| .ui.loading.segment:after { | ||||
|   position: absolute; | ||||
|   content: ''; | ||||
|   top: 50%; | ||||
|   left: 50%; | ||||
|  | ||||
|   margin: @loaderMargin; | ||||
|   width: @loaderSize; | ||||
|   height: @loaderSize; | ||||
|  | ||||
|   animation: segment-spin @loaderSpeed linear; | ||||
|   animation-iteration-count: infinite; | ||||
|  | ||||
|   border-radius: @circularRadius; | ||||
|  | ||||
|   border-color: @loaderLineColor @loaderFillColor @loaderFillColor @loaderFillColor; | ||||
|   border-style: solid; | ||||
|   border-width: @loaderLineWidth; | ||||
|  | ||||
|   box-shadow: 0px 0px 0px 1px transparent; | ||||
|   visibility: visible; | ||||
|   z-index: @loaderLineZIndex; | ||||
| } | ||||
|  | ||||
| @keyframes segment-spin { | ||||
|   from { | ||||
|     transform: rotate(0deg); | ||||
|   } | ||||
|   to { | ||||
|     transform: rotate(360deg); | ||||
|   } | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|            Variations | ||||
| *******************************/ | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|        Basic | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.basic.segment { | ||||
|   background: @basicBackground; | ||||
|   box-shadow: @basicBoxShadow; | ||||
|   border: @basicBorder; | ||||
|   border-radius: @basicBorderRadius; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Clearing | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.clearing.segment:after { | ||||
|   content: "."; | ||||
|   display: block; | ||||
|   height: 0; | ||||
|   clear: both; | ||||
|   visibility: hidden; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Colors | ||||
| --------------------*/ | ||||
|  | ||||
| /* Red */ | ||||
| .ui.red.segment:not(.inverted) { | ||||
|   border-top: @coloredBorderSize solid @red !important; | ||||
| } | ||||
| .ui.inverted.red.segment { | ||||
|   background-color: @red !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Orange */ | ||||
| .ui.orange.segment:not(.inverted) { | ||||
|   border-top: @coloredBorderSize solid @orange !important; | ||||
| } | ||||
| .ui.inverted.orange.segment { | ||||
|   background-color: @orange !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Yellow */ | ||||
| .ui.yellow.segment:not(.inverted) { | ||||
|   border-top: @coloredBorderSize solid @yellow !important; | ||||
| } | ||||
| .ui.inverted.yellow.segment { | ||||
|   background-color: @yellow !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Olive */ | ||||
| .ui.olive.segment:not(.inverted) { | ||||
|   border-top: @coloredBorderSize solid @olive !important; | ||||
| } | ||||
| .ui.inverted.olive.segment { | ||||
|   background-color: @olive !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Green */ | ||||
| .ui.green.segment:not(.inverted) { | ||||
|   border-top: @coloredBorderSize solid @green !important; | ||||
| } | ||||
| .ui.inverted.green.segment { | ||||
|   background-color: @green !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Teal */ | ||||
| .ui.teal.segment:not(.inverted) { | ||||
|   border-top: @coloredBorderSize solid @teal !important; | ||||
| } | ||||
| .ui.inverted.teal.segment { | ||||
|   background-color: @teal !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Blue */ | ||||
| .ui.blue.segment:not(.inverted) { | ||||
|   border-top: @coloredBorderSize solid @blue !important; | ||||
| } | ||||
| .ui.inverted.blue.segment { | ||||
|   background-color: @blue !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Violet */ | ||||
| .ui.violet.segment:not(.inverted) { | ||||
|   border-top: @coloredBorderSize solid @violet !important; | ||||
| } | ||||
| .ui.inverted.violet.segment { | ||||
|   background-color: @violet !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Purple */ | ||||
| .ui.purple.segment:not(.inverted) { | ||||
|   border-top: @coloredBorderSize solid @purple !important; | ||||
| } | ||||
| .ui.inverted.purple.segment { | ||||
|   background-color: @purple !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Pink */ | ||||
| .ui.pink.segment:not(.inverted) { | ||||
|   border-top: @coloredBorderSize solid @pink !important; | ||||
| } | ||||
| .ui.inverted.pink.segment { | ||||
|   background-color: @pink !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Brown */ | ||||
| .ui.brown.segment:not(.inverted) { | ||||
|   border-top: @coloredBorderSize solid @brown !important; | ||||
| } | ||||
| .ui.inverted.brown.segment { | ||||
|   background-color: @brown !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Grey */ | ||||
| .ui.grey.segment:not(.inverted) { | ||||
|   border-top: @coloredBorderSize solid @grey !important; | ||||
| } | ||||
| .ui.inverted.grey.segment { | ||||
|   background-color: @grey !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /* Black */ | ||||
| .ui.black.segment:not(.inverted) { | ||||
|   border-top: @coloredBorderSize solid @black !important; | ||||
| } | ||||
| .ui.inverted.black.segment { | ||||
|   background-color: @black !important; | ||||
|   color: @white !important; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Aligned | ||||
| --------------------*/ | ||||
|  | ||||
| .ui[class*="left aligned"].segment { | ||||
|   text-align: left; | ||||
| } | ||||
| .ui[class*="right aligned"].segment { | ||||
|   text-align: right; | ||||
| } | ||||
| .ui[class*="center aligned"].segment { | ||||
|   text-align: center; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Floated | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.floated.segment, | ||||
| .ui[class*="left floated"].segment { | ||||
|   float: left; | ||||
|   margin-right: @floatedDistance; | ||||
| } | ||||
| .ui[class*="right floated"].segment { | ||||
|   float: right; | ||||
|   margin-left: @floatedDistance; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|       Inverted | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.inverted.segment { | ||||
|   border: none; | ||||
|   box-shadow: none; | ||||
| } | ||||
| .ui.inverted.segment, | ||||
| .ui.primary.inverted.segment { | ||||
|   background: @invertedBackground; | ||||
|   color: @invertedTextColor; | ||||
| } | ||||
|  | ||||
| /* Nested */ | ||||
| .ui.inverted.segment .segment { | ||||
|   color: @textColor; | ||||
| } | ||||
| .ui.inverted.segment .inverted.segment { | ||||
|   color: @invertedTextColor; | ||||
| } | ||||
|  | ||||
| /* Attached */ | ||||
| .ui.inverted.attached.segment { | ||||
|   border-color: @solidWhiteBorderColor; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|      Emphasis | ||||
| --------------------*/ | ||||
|  | ||||
| /* Secondary */ | ||||
| .ui.secondary.segment { | ||||
|   background: @secondaryBackground; | ||||
|   color: @secondaryColor; | ||||
| } | ||||
| .ui.secondary.inverted.segment { | ||||
|   background: @secondaryInvertedBackground; | ||||
|   color: @secondaryInvertedColor; | ||||
| } | ||||
|  | ||||
| /* Tertiary */ | ||||
| .ui.tertiary.segment { | ||||
|   background: @tertiaryBackground; | ||||
|   color: @tertiaryColor; | ||||
| } | ||||
| .ui.tertiary.inverted.segment { | ||||
|   background: @tertiaryInvertedBackground; | ||||
|   color: @tertiaryInvertedColor; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|       Attached | ||||
| --------------------*/ | ||||
|  | ||||
| /* Middle */ | ||||
| .ui.attached.segment { | ||||
|   top: 0px; | ||||
|   bottom: 0px; | ||||
|   border-radius: 0px; | ||||
|   margin: 0em @attachedHorizontalOffset; | ||||
|   width: @attachedWidth; | ||||
|   max-width: @attachedWidth; | ||||
|   box-shadow: @attachedBoxShadow; | ||||
|   border: @attachedBorder; | ||||
| } | ||||
| .ui.attached:not(.message) + .ui.attached.segment:not(.top) { | ||||
|   border-top: none; | ||||
| } | ||||
|  | ||||
| /* Top */ | ||||
| .ui[class*="top attached"].segment { | ||||
|   bottom: 0px; | ||||
|   margin-bottom: 0em; | ||||
|   top: @attachedTopOffset; | ||||
|   margin-top: @verticalMargin; | ||||
|   border-radius: @borderRadius @borderRadius 0em 0em; | ||||
| } | ||||
| .ui.segment[class*="top attached"]:first-child { | ||||
|   margin-top: 0em; | ||||
| } | ||||
|  | ||||
| /* Bottom */ | ||||
| .ui.segment[class*="bottom attached"] { | ||||
|   bottom: 0px; | ||||
|   margin-top: 0em; | ||||
|   top: @attachedBottomOffset; | ||||
|   margin-bottom: @verticalMargin; | ||||
|   box-shadow: @attachedBottomBoxShadow; | ||||
|   border-radius: 0em 0em @borderRadius @borderRadius; | ||||
| } | ||||
| .ui.segment[class*="bottom attached"]:last-child { | ||||
|   margin-bottom: 0em; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|         Size | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.mini.segments .segment, | ||||
| .ui.mini.segment { | ||||
|   font-size: @mini; | ||||
| } | ||||
| .ui.tiny.segments .segment, | ||||
| .ui.tiny.segment { | ||||
|   font-size: @tiny; | ||||
| } | ||||
| .ui.small.segments .segment, | ||||
| .ui.small.segment { | ||||
|   font-size: @small; | ||||
| } | ||||
| .ui.segments .segment, | ||||
| .ui.segment { | ||||
|   font-size: @medium; | ||||
| } | ||||
| .ui.large.segments .segment, | ||||
| .ui.large.segment { | ||||
|   font-size: @large; | ||||
| } | ||||
| .ui.big.segments .segment, | ||||
| .ui.big.segment { | ||||
|   font-size: @big; | ||||
| } | ||||
| .ui.huge.segments .segment, | ||||
| .ui.huge.segment { | ||||
|   font-size: @huge; | ||||
| } | ||||
| .ui.massive.segments .segment, | ||||
| .ui.massive.segment { | ||||
|   font-size: @massive; | ||||
| } | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,562 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Step | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|              Step | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|    Load Theme | ||||
| ---------------*/ | ||||
|  | ||||
| @type    : 'element'; | ||||
| @element : 'step'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|             Plural | ||||
| *******************************/ | ||||
|  | ||||
| .ui.steps { | ||||
|   display: inline-flex; | ||||
|   flex-direction: row; | ||||
|   align-items: stretch; | ||||
|   margin: @stepMargin; | ||||
|   background: @stepsBackground; | ||||
|   box-shadow: @stepsBoxShadow; | ||||
|   line-height: @lineHeight; | ||||
|   border-radius: @stepsBorderRadius; | ||||
|   border: @stepsBorder; | ||||
| } | ||||
|  | ||||
| /* First Steps */ | ||||
| .ui.steps:first-child { | ||||
|   margin-top: 0em; | ||||
| } | ||||
|  | ||||
| /* Last Steps */ | ||||
| .ui.steps:last-child { | ||||
|   margin-bottom: 0em; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|            Singular | ||||
| *******************************/ | ||||
|  | ||||
| .ui.steps .step { | ||||
|   position: relative; | ||||
|   display: flex; | ||||
|   flex: 1 0 auto; | ||||
|   flex-wrap: wrap; | ||||
|   flex-direction: row; | ||||
|   vertical-align: middle; | ||||
|   align-items: center; | ||||
|   justify-content: @justifyContent; | ||||
|  | ||||
|   margin: @verticalMargin @horizontalMargin; | ||||
|   padding: @verticalPadding @horizontalPadding; | ||||
|   background: @background; | ||||
|   color: @textColor; | ||||
|   box-shadow: @boxShadow; | ||||
|   border-radius: @borderRadius; | ||||
|   border: @border; | ||||
|   border-right: @divider; | ||||
|   transition: @transition; | ||||
| } | ||||
|  | ||||
| /* Arrow */ | ||||
| .ui.steps .step:after { | ||||
|   display: none; | ||||
|   position: absolute; | ||||
|   z-index: 2; | ||||
|   content: ''; | ||||
|   top: @arrowTopOffset; | ||||
|   right: @arrowRightOffset; | ||||
|   border: medium none; | ||||
|   background-color: @arrowBackgroundColor; | ||||
|   width: @arrowSize; | ||||
|   height: @arrowSize; | ||||
|  | ||||
|   border-style: solid; | ||||
|   border-color: @borderColor; | ||||
|   border-width: @arrowBorderWidth; | ||||
|  | ||||
|   transition: @transition; | ||||
|   transform: translateY(-50%) translateX(50%) rotate(-45deg); | ||||
| } | ||||
|  | ||||
| /* First Step */ | ||||
| .ui.steps .step:first-child { | ||||
|   padding-left: @horizontalPadding; | ||||
|   border-radius: @stepsBorderRadius 0em 0em @stepsBorderRadius; | ||||
| } | ||||
|  | ||||
| /* Last Step */ | ||||
| .ui.steps .step:last-child { | ||||
|   border-radius: 0em @stepsBorderRadius @stepsBorderRadius 0em; | ||||
| } | ||||
| .ui.steps .step:last-child { | ||||
|   border-right: none; | ||||
|   margin-right: 0em; | ||||
| } | ||||
|  | ||||
| /* Only Step */ | ||||
| .ui.steps .step:only-child { | ||||
|   border-radius: @stepsBorderRadius; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Content | ||||
| *******************************/ | ||||
|  | ||||
| /* Title */ | ||||
| .ui.steps .step .title { | ||||
|   font-family: @titleFontFamily; | ||||
|   font-size: @titleFontSize; | ||||
|   font-weight: @titleFontWeight; | ||||
| } | ||||
| .ui.steps .step > .title { | ||||
|   width: 100%; | ||||
| } | ||||
|  | ||||
| /* Description */ | ||||
| .ui.steps .step .description { | ||||
|   font-weight: @descriptionFontWeight; | ||||
|   font-size: @descriptionFontSize; | ||||
|   color: @descriptionColor; | ||||
| } | ||||
| .ui.steps .step > .description { | ||||
|   width: 100%; | ||||
| } | ||||
| .ui.steps .step .title ~ .description { | ||||
|   margin-top: @descriptionDistance; | ||||
| } | ||||
|  | ||||
| /* Icon */ | ||||
| .ui.steps .step > .icon { | ||||
|   line-height: 1; | ||||
|   font-size: @iconSize; | ||||
|   margin: 0em @iconDistance 0em 0em; | ||||
| } | ||||
| .ui.steps .step > .icon, | ||||
| .ui.steps .step > .icon ~ .content { | ||||
|   display: block; | ||||
|   flex: 0 1 auto; | ||||
|   align-self: @iconAlign; | ||||
| } | ||||
| .ui.steps .step > .icon ~ .content { | ||||
|   flex-grow: 1 0 auto; | ||||
| } | ||||
|  | ||||
| /* Horizontal Icon */ | ||||
| .ui.steps:not(.vertical) .step > .icon { | ||||
|   width: auto; | ||||
| } | ||||
|  | ||||
| /* Link */ | ||||
| .ui.steps .link.step, | ||||
| .ui.steps a.step { | ||||
|   cursor: pointer; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|             Types | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|      Ordered | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.ordered.steps { | ||||
|   counter-reset: ordered; | ||||
| } | ||||
| .ui.ordered.steps .step:before { | ||||
|   display: block; | ||||
|   position: static; | ||||
|   text-align: center; | ||||
|   content: counters(ordered, "."); | ||||
|   align-self: @iconAlign; | ||||
|   margin-right: @iconDistance; | ||||
|   font-size: @iconSize; | ||||
|   counter-increment: ordered; | ||||
|   font-family: @orderedFontFamily; | ||||
|   font-weight: @orderedFontWeight; | ||||
| } | ||||
|  | ||||
| .ui.ordered.steps .step > * { | ||||
|   display: block; | ||||
|   align-self: @iconAlign; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|     Vertical | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.vertical.steps { | ||||
|   display: inline-flex; | ||||
|   flex-direction: column; | ||||
|   overflow: visible; | ||||
| } | ||||
| .ui.vertical.steps .step { | ||||
|   justify-content: flex-start; | ||||
|   border-radius: @borderRadius; | ||||
|   padding: @verticalPadding @horizontalPadding; | ||||
|   border-right: none; | ||||
|   border-bottom: @verticalDivider; | ||||
| } | ||||
| .ui.vertical.steps .step:first-child { | ||||
|   padding: @verticalPadding @horizontalPadding; | ||||
|   border-radius: @stepsBorderRadius @stepsBorderRadius 0em 0em; | ||||
| } | ||||
| .ui.vertical.steps .step:last-child { | ||||
|   border-bottom: none; | ||||
|   border-radius: 0em 0em @stepsBorderRadius @stepsBorderRadius; | ||||
| } | ||||
| .ui.vertical.steps .step:only-child { | ||||
|   border-radius: @stepsBorderRadius; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Arrow */ | ||||
| .ui.vertical.steps .step:after { | ||||
|   display: none; | ||||
| } | ||||
| .ui.vertical.steps .step:after { | ||||
|   top: @verticalArrowTopOffset; | ||||
|   right: @verticalArrowRightOffset; | ||||
|   border-width: @verticalArrowBorderWidth; | ||||
| } | ||||
|  | ||||
| .ui.vertical.steps .step:after { | ||||
|   display: @verticalArrowDisplay; | ||||
| } | ||||
| .ui.vertical.steps .active.step:after { | ||||
|   display: @verticalActiveArrowDisplay; | ||||
| } | ||||
| .ui.vertical.steps .step:last-child:after { | ||||
|   display: @verticalLastArrowDisplay; | ||||
| } | ||||
| .ui.vertical.steps .active.step:last-child:after { | ||||
|   display: @verticalActiveLastArrowDisplay; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*--------------- | ||||
|     Responsive | ||||
| ----------------*/ | ||||
|  | ||||
| /* Mobile (Default) */ | ||||
| @media only screen and (max-width: (@largestMobileScreen)) { | ||||
|  | ||||
|   .ui.steps:not(.unstackable) { | ||||
|     display: inline-flex; | ||||
|     overflow: visible; | ||||
|     flex-direction: column; | ||||
|   } | ||||
|   .ui.steps:not(.unstackable) .step { | ||||
|     width: 100% !important; | ||||
|     flex-direction: column; | ||||
|     border-radius: @borderRadius; | ||||
|     padding: @verticalPadding @horizontalPadding; | ||||
|   } | ||||
|   .ui.steps:not(.unstackable) .step:first-child { | ||||
|     padding: @verticalPadding @horizontalPadding; | ||||
|     border-radius: @stepsBorderRadius @stepsBorderRadius 0em 0em; | ||||
|   } | ||||
|   .ui.steps:not(.unstackable) .step:last-child { | ||||
|     border-radius: 0em 0em @stepsBorderRadius @stepsBorderRadius; | ||||
|   } | ||||
|  | ||||
|   /* Arrow */ | ||||
|   .ui.steps:not(.unstackable) .step:after { | ||||
|     display: none !important; | ||||
|   } | ||||
|  | ||||
|   /* Content */ | ||||
|   .ui.steps:not(.unstackable) .step .content { | ||||
|     text-align: center; | ||||
|   } | ||||
|  | ||||
|   /* Icon */ | ||||
|   .ui.steps:not(.unstackable) .step > .icon, | ||||
|   .ui.ordered.steps:not(.unstackable) .step:before { | ||||
|     margin: 0em 0em @mobileIconDistance 0em; | ||||
|   } | ||||
|  | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|              States | ||||
| *******************************/ | ||||
|  | ||||
| /* Link Hover */ | ||||
| .ui.steps .link.step:hover::after, | ||||
| .ui.steps .link.step:hover, | ||||
| .ui.steps a.step:hover::after, | ||||
| .ui.steps a.step:hover { | ||||
|   background: @hoverBackground; | ||||
|   color: @hoverColor; | ||||
| } | ||||
|  | ||||
| /* Link Down */ | ||||
| .ui.steps .link.step:active::after, | ||||
| .ui.steps .link.step:active, | ||||
| .ui.steps a.step:active::after, | ||||
| .ui.steps a.step:active { | ||||
|   background: @downBackground; | ||||
|   color: @downColor; | ||||
| } | ||||
|  | ||||
| /* Active */ | ||||
| .ui.steps .step.active { | ||||
|   cursor: auto; | ||||
|   background: @activeBackground; | ||||
| } | ||||
| .ui.steps .step.active:after { | ||||
|   background: @activeBackground; | ||||
| } | ||||
| .ui.steps .step.active .title { | ||||
|   color: @activeColor; | ||||
| } | ||||
| .ui.ordered.steps .step.active:before, | ||||
| .ui.steps .active.step .icon { | ||||
|   color: @activeIconColor; | ||||
| } | ||||
|  | ||||
| /* Active Arrow */ | ||||
| .ui.steps .step:after { | ||||
|   display: @arrowDisplay; | ||||
| } | ||||
| .ui.steps .active.step:after { | ||||
|   display: @activeArrowDisplay; | ||||
| } | ||||
| .ui.steps .step:last-child:after { | ||||
|   display: @lastArrowDisplay; | ||||
| } | ||||
| .ui.steps .active.step:last-child:after { | ||||
|   display: @activeLastArrowDisplay; | ||||
| } | ||||
|  | ||||
| /* Active Hover */ | ||||
| .ui.steps .link.active.step:hover::after, | ||||
| .ui.steps .link.active.step:hover, | ||||
| .ui.steps a.active.step:hover::after, | ||||
| .ui.steps a.active.step:hover { | ||||
|   cursor: pointer; | ||||
|   background: @activeHoverBackground; | ||||
|   color: @activeHoverColor; | ||||
| } | ||||
|  | ||||
| /* Completed */ | ||||
| .ui.steps .step.completed > .icon:before, | ||||
| .ui.ordered.steps .step.completed:before { | ||||
|   color: @completedColor; | ||||
| } | ||||
|  | ||||
| /* Disabled */ | ||||
| .ui.steps .disabled.step { | ||||
|   cursor: auto; | ||||
|   background: @disabledBackground; | ||||
|   pointer-events: none; | ||||
| } | ||||
| .ui.steps .disabled.step, | ||||
| .ui.steps .disabled.step .title, | ||||
| .ui.steps .disabled.step .description { | ||||
|   color: @disabledColor; | ||||
| } | ||||
| .ui.steps .disabled.step:after { | ||||
|   background: @disabledBackground; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|            Variations | ||||
| *******************************/ | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|    Stackable | ||||
| ---------------*/ | ||||
|  | ||||
| /* Tablet Or Below */ | ||||
| @media only screen and (max-width: @largestTabletScreen) { | ||||
|  | ||||
| .ui[class*="tablet stackable"].steps { | ||||
|   display: inline-flex; | ||||
|   overflow: visible; | ||||
|   flex-direction: column; | ||||
| } | ||||
|  | ||||
| /* Steps */ | ||||
| .ui[class*="tablet stackable"].steps .step { | ||||
|   flex-direction: column; | ||||
|   border-radius: @borderRadius; | ||||
|   padding: @verticalPadding @horizontalPadding; | ||||
| } | ||||
| .ui[class*="tablet stackable"].steps .step:first-child { | ||||
|   padding: @verticalPadding @horizontalPadding; | ||||
|   border-radius: @stepsBorderRadius @stepsBorderRadius 0em 0em; | ||||
| } | ||||
| .ui[class*="tablet stackable"].steps .step:last-child { | ||||
|   border-radius: 0em 0em @stepsBorderRadius @stepsBorderRadius; | ||||
| } | ||||
|  | ||||
| /* Arrow */ | ||||
| .ui[class*="tablet stackable"].steps .step:after { | ||||
|   display: none !important; | ||||
| } | ||||
|  | ||||
| /* Content */ | ||||
| .ui[class*="tablet stackable"].steps .step .content { | ||||
|   text-align: center; | ||||
| } | ||||
|  | ||||
| /* Icon */ | ||||
| .ui[class*="tablet stackable"].steps .step > .icon, | ||||
| .ui[class*="tablet stackable"].ordered.steps .step:before { | ||||
|   margin: 0em 0em @mobileIconDistance 0em; | ||||
| } | ||||
|  | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|       Fluid | ||||
| ---------------*/ | ||||
|  | ||||
| /* Fluid */ | ||||
| .ui.fluid.steps { | ||||
|   display: flex; | ||||
|   width: 100%; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Attached | ||||
| ---------------*/ | ||||
|  | ||||
| /* Top */ | ||||
| .ui.attached.steps { | ||||
|   width: @attachedWidth !important; | ||||
|   margin: 0em @attachedHorizontalOffset @attachedVerticalOffset; | ||||
|   max-width: @attachedWidth; | ||||
|   border-radius: @stepsBorderRadius @stepsBorderRadius 0em 0em; | ||||
| } | ||||
| .ui.attached.steps .step:first-child { | ||||
|   border-radius: @stepsBorderRadius 0em 0em 0em; | ||||
| } | ||||
| .ui.attached.steps .step:last-child { | ||||
|   border-radius: 0em @stepsBorderRadius 0em 0em; | ||||
| } | ||||
|  | ||||
| /* Bottom */ | ||||
| .ui.bottom.attached.steps { | ||||
|   margin: @attachedVerticalOffset @attachedHorizontalOffset 0em; | ||||
|   border-radius: 0em 0em @stepsBorderRadius @stepsBorderRadius; | ||||
| } | ||||
| .ui.bottom.attached.steps .step:first-child { | ||||
|   border-radius: 0em 0em 0em @stepsBorderRadius; | ||||
| } | ||||
| .ui.bottom.attached.steps .step:last-child { | ||||
|   border-radius: 0em 0em @stepsBorderRadius 0em; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|     Evenly Divided | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.one.steps, | ||||
| .ui.two.steps, | ||||
| .ui.three.steps, | ||||
| .ui.four.steps, | ||||
| .ui.five.steps, | ||||
| .ui.six.steps, | ||||
| .ui.seven.steps, | ||||
| .ui.eight.steps { | ||||
|   width: 100%; | ||||
| } | ||||
| .ui.one.steps > .step, | ||||
| .ui.two.steps > .step, | ||||
| .ui.three.steps > .step, | ||||
| .ui.four.steps > .step, | ||||
| .ui.five.steps > .step, | ||||
| .ui.six.steps > .step, | ||||
| .ui.seven.steps > .step, | ||||
| .ui.eight.steps > .step { | ||||
|   flex-wrap: nowrap; | ||||
| } | ||||
| .ui.one.steps > .step { | ||||
|   width: 100%; | ||||
| } | ||||
| .ui.two.steps > .step { | ||||
|   width: 50%; | ||||
| } | ||||
| .ui.three.steps > .step { | ||||
|   width: 33.333%; | ||||
| } | ||||
| .ui.four.steps > .step { | ||||
|   width: 25%; | ||||
| } | ||||
| .ui.five.steps > .step { | ||||
|   width: 20%; | ||||
| } | ||||
| .ui.six.steps > .step { | ||||
|   width: 16.666%; | ||||
| } | ||||
| .ui.seven.steps > .step { | ||||
|   width: 14.285%; | ||||
| } | ||||
| .ui.eight.steps > .step { | ||||
|   width: 12.500%; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Sizes | ||||
| --------------------*/ | ||||
|  | ||||
|  | ||||
| .ui.mini.steps .step, | ||||
| .ui.mini.step { | ||||
|   font-size: @mini; | ||||
| } | ||||
| .ui.tiny.steps .step, | ||||
| .ui.tiny.step { | ||||
|   font-size: @tiny; | ||||
| } | ||||
| .ui.small.steps .step, | ||||
| .ui.small.step { | ||||
|   font-size: @small; | ||||
| } | ||||
| .ui.steps .step, | ||||
| .ui.step { | ||||
|   font-size: @medium; | ||||
| } | ||||
| .ui.large.steps .step, | ||||
| .ui.large.step { | ||||
|   font-size: @large; | ||||
| } | ||||
| .ui.big.steps .step, | ||||
| .ui.big.step { | ||||
|   font-size: @big; | ||||
| } | ||||
| .ui.huge.steps .step, | ||||
| .ui.huge.step { | ||||
|   font-size: @huge; | ||||
| } | ||||
| .ui.massive.steps .step, | ||||
| .ui.massive.step { | ||||
|   font-size: @massive; | ||||
| } | ||||
|  | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,40 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Reset | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'global'; | ||||
| @element : 'reset'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|              Reset | ||||
| *******************************/ | ||||
|  | ||||
| /* Border-Box */ | ||||
| *, | ||||
| *:before, | ||||
| *:after { | ||||
|   box-sizing: inherit; | ||||
| } | ||||
| html { | ||||
|   box-sizing: border-box; | ||||
| } | ||||
|  | ||||
| /* iPad Input Shadows */ | ||||
| input[type="text"], input[type="email"], input[type="search"], input[type="password"] { | ||||
|   -webkit-appearance: none; | ||||
|   -moz-appearance: none; /* mobile firefox too! */ | ||||
| } | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,487 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Site | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| ;(function ($, window, document, undefined) { | ||||
|  | ||||
| $.site = $.fn.site = function(parameters) { | ||||
|   var | ||||
|     time           = new Date().getTime(), | ||||
|     performance    = [], | ||||
|  | ||||
|     query          = arguments[0], | ||||
|     methodInvoked  = (typeof query == 'string'), | ||||
|     queryArguments = [].slice.call(arguments, 1), | ||||
|  | ||||
|     settings        = ( $.isPlainObject(parameters) ) | ||||
|       ? $.extend(true, {}, $.site.settings, parameters) | ||||
|       : $.extend({}, $.site.settings), | ||||
|  | ||||
|     namespace       = settings.namespace, | ||||
|     error           = settings.error, | ||||
|  | ||||
|     eventNamespace  = '.' + namespace, | ||||
|     moduleNamespace = 'module-' + namespace, | ||||
|  | ||||
|     $document       = $(document), | ||||
|     $module         = $document, | ||||
|     element         = this, | ||||
|     instance        = $module.data(moduleNamespace), | ||||
|  | ||||
|     module, | ||||
|     returnedValue | ||||
|   ; | ||||
|   module = { | ||||
|  | ||||
|     initialize: function() { | ||||
|       module.instantiate(); | ||||
|     }, | ||||
|  | ||||
|     instantiate: function() { | ||||
|       module.verbose('Storing instance of site', module); | ||||
|       instance = module; | ||||
|       $module | ||||
|         .data(moduleNamespace, module) | ||||
|       ; | ||||
|     }, | ||||
|  | ||||
|     normalize: function() { | ||||
|       module.fix.console(); | ||||
|       module.fix.requestAnimationFrame(); | ||||
|     }, | ||||
|  | ||||
|     fix: { | ||||
|       console: function() { | ||||
|         module.debug('Normalizing window.console'); | ||||
|         if (console === undefined || console.log === undefined) { | ||||
|           module.verbose('Console not available, normalizing events'); | ||||
|           module.disable.console(); | ||||
|         } | ||||
|         if (typeof console.group == 'undefined' || typeof console.groupEnd == 'undefined' || typeof console.groupCollapsed == 'undefined') { | ||||
|           module.verbose('Console group not available, normalizing events'); | ||||
|           window.console.group = function() {}; | ||||
|           window.console.groupEnd = function() {}; | ||||
|           window.console.groupCollapsed = function() {}; | ||||
|         } | ||||
|         if (typeof console.markTimeline == 'undefined') { | ||||
|           module.verbose('Mark timeline not available, normalizing events'); | ||||
|           window.console.markTimeline = function() {}; | ||||
|         } | ||||
|       }, | ||||
|       consoleClear: function() { | ||||
|         module.debug('Disabling programmatic console clearing'); | ||||
|         window.console.clear = function() {}; | ||||
|       }, | ||||
|       requestAnimationFrame: function() { | ||||
|         module.debug('Normalizing requestAnimationFrame'); | ||||
|         if(window.requestAnimationFrame === undefined) { | ||||
|           module.debug('RequestAnimationFrame not available, normalizing event'); | ||||
|           window.requestAnimationFrame = window.requestAnimationFrame | ||||
|             || window.mozRequestAnimationFrame | ||||
|             || window.webkitRequestAnimationFrame | ||||
|             || window.msRequestAnimationFrame | ||||
|             || function(callback) { setTimeout(callback, 0); } | ||||
|           ; | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|  | ||||
|     moduleExists: function(name) { | ||||
|       return ($.fn[name] !== undefined && $.fn[name].settings !== undefined); | ||||
|     }, | ||||
|  | ||||
|     enabled: { | ||||
|       modules: function(modules) { | ||||
|         var | ||||
|           enabledModules = [] | ||||
|         ; | ||||
|         modules = modules || settings.modules; | ||||
|         $.each(modules, function(index, name) { | ||||
|           if(module.moduleExists(name)) { | ||||
|             enabledModules.push(name); | ||||
|           } | ||||
|         }); | ||||
|         return enabledModules; | ||||
|       } | ||||
|     }, | ||||
|  | ||||
|     disabled: { | ||||
|       modules: function(modules) { | ||||
|         var | ||||
|           disabledModules = [] | ||||
|         ; | ||||
|         modules = modules || settings.modules; | ||||
|         $.each(modules, function(index, name) { | ||||
|           if(!module.moduleExists(name)) { | ||||
|             disabledModules.push(name); | ||||
|           } | ||||
|         }); | ||||
|         return disabledModules; | ||||
|       } | ||||
|     }, | ||||
|  | ||||
|     change: { | ||||
|       setting: function(setting, value, modules, modifyExisting) { | ||||
|         modules = (typeof modules === 'string') | ||||
|           ? (modules === 'all') | ||||
|             ? settings.modules | ||||
|             : [modules] | ||||
|           : modules || settings.modules | ||||
|         ; | ||||
|         modifyExisting = (modifyExisting !== undefined) | ||||
|           ? modifyExisting | ||||
|           : true | ||||
|         ; | ||||
|         $.each(modules, function(index, name) { | ||||
|           var | ||||
|             namespace = (module.moduleExists(name)) | ||||
|               ? $.fn[name].settings.namespace || false | ||||
|               : true, | ||||
|             $existingModules | ||||
|           ; | ||||
|           if(module.moduleExists(name)) { | ||||
|             module.verbose('Changing default setting', setting, value, name); | ||||
|             $.fn[name].settings[setting] = value; | ||||
|             if(modifyExisting && namespace) { | ||||
|               $existingModules = $(':data(module-' + namespace + ')'); | ||||
|               if($existingModules.length > 0) { | ||||
|                 module.verbose('Modifying existing settings', $existingModules); | ||||
|                 $existingModules[name]('setting', setting, value); | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|         }); | ||||
|       }, | ||||
|       settings: function(newSettings, modules, modifyExisting) { | ||||
|         modules = (typeof modules === 'string') | ||||
|           ? [modules] | ||||
|           : modules || settings.modules | ||||
|         ; | ||||
|         modifyExisting = (modifyExisting !== undefined) | ||||
|           ? modifyExisting | ||||
|           : true | ||||
|         ; | ||||
|         $.each(modules, function(index, name) { | ||||
|           var | ||||
|             $existingModules | ||||
|           ; | ||||
|           if(module.moduleExists(name)) { | ||||
|             module.verbose('Changing default setting', newSettings, name); | ||||
|             $.extend(true, $.fn[name].settings, newSettings); | ||||
|             if(modifyExisting && namespace) { | ||||
|               $existingModules = $(':data(module-' + namespace + ')'); | ||||
|               if($existingModules.length > 0) { | ||||
|                 module.verbose('Modifying existing settings', $existingModules); | ||||
|                 $existingModules[name]('setting', newSettings); | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|         }); | ||||
|       } | ||||
|     }, | ||||
|  | ||||
|     enable: { | ||||
|       console: function() { | ||||
|         module.console(true); | ||||
|       }, | ||||
|       debug: function(modules, modifyExisting) { | ||||
|         modules = modules || settings.modules; | ||||
|         module.debug('Enabling debug for modules', modules); | ||||
|         module.change.setting('debug', true, modules, modifyExisting); | ||||
|       }, | ||||
|       verbose: function(modules, modifyExisting) { | ||||
|         modules = modules || settings.modules; | ||||
|         module.debug('Enabling verbose debug for modules', modules); | ||||
|         module.change.setting('verbose', true, modules, modifyExisting); | ||||
|       } | ||||
|     }, | ||||
|     disable: { | ||||
|       console: function() { | ||||
|         module.console(false); | ||||
|       }, | ||||
|       debug: function(modules, modifyExisting) { | ||||
|         modules = modules || settings.modules; | ||||
|         module.debug('Disabling debug for modules', modules); | ||||
|         module.change.setting('debug', false, modules, modifyExisting); | ||||
|       }, | ||||
|       verbose: function(modules, modifyExisting) { | ||||
|         modules = modules || settings.modules; | ||||
|         module.debug('Disabling verbose debug for modules', modules); | ||||
|         module.change.setting('verbose', false, modules, modifyExisting); | ||||
|       } | ||||
|     }, | ||||
|  | ||||
|     console: function(enable) { | ||||
|       if(enable) { | ||||
|         if(instance.cache.console === undefined) { | ||||
|           module.error(error.console); | ||||
|           return; | ||||
|         } | ||||
|         module.debug('Restoring console function'); | ||||
|         window.console = instance.cache.console; | ||||
|       } | ||||
|       else { | ||||
|         module.debug('Disabling console function'); | ||||
|         instance.cache.console = window.console; | ||||
|         window.console = { | ||||
|           clear          : function(){}, | ||||
|           error          : function(){}, | ||||
|           group          : function(){}, | ||||
|           groupCollapsed : function(){}, | ||||
|           groupEnd       : function(){}, | ||||
|           info           : function(){}, | ||||
|           log            : function(){}, | ||||
|           markTimeline   : function(){}, | ||||
|           warn           : function(){} | ||||
|         }; | ||||
|       } | ||||
|     }, | ||||
|  | ||||
|     destroy: function() { | ||||
|       module.verbose('Destroying previous site for', $module); | ||||
|       $module | ||||
|         .removeData(moduleNamespace) | ||||
|       ; | ||||
|     }, | ||||
|  | ||||
|     cache: {}, | ||||
|  | ||||
|     setting: function(name, value) { | ||||
|       if( $.isPlainObject(name) ) { | ||||
|         $.extend(true, settings, name); | ||||
|       } | ||||
|       else if(value !== undefined) { | ||||
|         settings[name] = value; | ||||
|       } | ||||
|       else { | ||||
|         return settings[name]; | ||||
|       } | ||||
|     }, | ||||
|     internal: function(name, value) { | ||||
|       if( $.isPlainObject(name) ) { | ||||
|         $.extend(true, module, name); | ||||
|       } | ||||
|       else if(value !== undefined) { | ||||
|         module[name] = value; | ||||
|       } | ||||
|       else { | ||||
|         return module[name]; | ||||
|       } | ||||
|     }, | ||||
|     debug: function() { | ||||
|       if(settings.debug) { | ||||
|         if(settings.performance) { | ||||
|           module.performance.log(arguments); | ||||
|         } | ||||
|         else { | ||||
|           module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|           module.debug.apply(console, arguments); | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     verbose: function() { | ||||
|       if(settings.verbose && settings.debug) { | ||||
|         if(settings.performance) { | ||||
|           module.performance.log(arguments); | ||||
|         } | ||||
|         else { | ||||
|           module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|           module.verbose.apply(console, arguments); | ||||
|         } | ||||
|       } | ||||
|     }, | ||||
|     error: function() { | ||||
|       module.error = Function.prototype.bind.call(console.error, console, settings.name + ':'); | ||||
|       module.error.apply(console, arguments); | ||||
|     }, | ||||
|     performance: { | ||||
|       log: function(message) { | ||||
|         var | ||||
|           currentTime, | ||||
|           executionTime, | ||||
|           previousTime | ||||
|         ; | ||||
|         if(settings.performance) { | ||||
|           currentTime   = new Date().getTime(); | ||||
|           previousTime  = time || currentTime; | ||||
|           executionTime = currentTime - previousTime; | ||||
|           time          = currentTime; | ||||
|           performance.push({ | ||||
|             'Element'        : element, | ||||
|             'Name'           : message[0], | ||||
|             'Arguments'      : [].slice.call(message, 1) || '', | ||||
|             'Execution Time' : executionTime | ||||
|           }); | ||||
|         } | ||||
|         clearTimeout(module.performance.timer); | ||||
|         module.performance.timer = setTimeout(module.performance.display, 500); | ||||
|       }, | ||||
|       display: function() { | ||||
|         var | ||||
|           title = settings.name + ':', | ||||
|           totalTime = 0 | ||||
|         ; | ||||
|         time = false; | ||||
|         clearTimeout(module.performance.timer); | ||||
|         $.each(performance, function(index, data) { | ||||
|           totalTime += data['Execution Time']; | ||||
|         }); | ||||
|         title += ' ' + totalTime + 'ms'; | ||||
|         if( (console.group !== undefined || console.table !== undefined) && performance.length > 0) { | ||||
|           console.groupCollapsed(title); | ||||
|           if(console.table) { | ||||
|             console.table(performance); | ||||
|           } | ||||
|           else { | ||||
|             $.each(performance, function(index, data) { | ||||
|               console.log(data['Name'] + ': ' + data['Execution Time']+'ms'); | ||||
|             }); | ||||
|           } | ||||
|           console.groupEnd(); | ||||
|         } | ||||
|         performance = []; | ||||
|       } | ||||
|     }, | ||||
|     invoke: function(query, passedArguments, context) { | ||||
|       var | ||||
|         object = instance, | ||||
|         maxDepth, | ||||
|         found, | ||||
|         response | ||||
|       ; | ||||
|       passedArguments = passedArguments || queryArguments; | ||||
|       context         = element         || context; | ||||
|       if(typeof query == 'string' && object !== undefined) { | ||||
|         query    = query.split(/[\. ]/); | ||||
|         maxDepth = query.length - 1; | ||||
|         $.each(query, function(depth, value) { | ||||
|           var camelCaseValue = (depth != maxDepth) | ||||
|             ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1) | ||||
|             : query | ||||
|           ; | ||||
|           if( $.isPlainObject( object[camelCaseValue] ) && (depth != maxDepth) ) { | ||||
|             object = object[camelCaseValue]; | ||||
|           } | ||||
|           else if( object[camelCaseValue] !== undefined ) { | ||||
|             found = object[camelCaseValue]; | ||||
|             return false; | ||||
|           } | ||||
|           else if( $.isPlainObject( object[value] ) && (depth != maxDepth) ) { | ||||
|             object = object[value]; | ||||
|           } | ||||
|           else if( object[value] !== undefined ) { | ||||
|             found = object[value]; | ||||
|             return false; | ||||
|           } | ||||
|           else { | ||||
|             module.error(error.method, query); | ||||
|             return false; | ||||
|           } | ||||
|         }); | ||||
|       } | ||||
|       if ( $.isFunction( found ) ) { | ||||
|         response = found.apply(context, passedArguments); | ||||
|       } | ||||
|       else if(found !== undefined) { | ||||
|         response = found; | ||||
|       } | ||||
|       if($.isArray(returnedValue)) { | ||||
|         returnedValue.push(response); | ||||
|       } | ||||
|       else if(returnedValue !== undefined) { | ||||
|         returnedValue = [returnedValue, response]; | ||||
|       } | ||||
|       else if(response !== undefined) { | ||||
|         returnedValue = response; | ||||
|       } | ||||
|       return found; | ||||
|     } | ||||
|   }; | ||||
|  | ||||
|   if(methodInvoked) { | ||||
|     if(instance === undefined) { | ||||
|       module.initialize(); | ||||
|     } | ||||
|     module.invoke(query); | ||||
|   } | ||||
|   else { | ||||
|     if(instance !== undefined) { | ||||
|       module.destroy(); | ||||
|     } | ||||
|     module.initialize(); | ||||
|   } | ||||
|   return (returnedValue !== undefined) | ||||
|     ? returnedValue | ||||
|     : this | ||||
|   ; | ||||
| }; | ||||
|  | ||||
| $.site.settings = { | ||||
|  | ||||
|   name        : 'Site', | ||||
|   namespace   : 'site', | ||||
|  | ||||
|   error : { | ||||
|     console : 'Console cannot be restored, most likely it was overwritten outside of module', | ||||
|     method : 'The method you called is not defined.' | ||||
|   }, | ||||
|  | ||||
|   debug       : false, | ||||
|   verbose     : false, | ||||
|   performance : true, | ||||
|  | ||||
|   modules: [ | ||||
|     'accordion', | ||||
|     'api', | ||||
|     'checkbox', | ||||
|     'dimmer', | ||||
|     'dropdown', | ||||
|     'embed', | ||||
|     'form', | ||||
|     'modal', | ||||
|     'nag', | ||||
|     'popup', | ||||
|     'rating', | ||||
|     'shape', | ||||
|     'sidebar', | ||||
|     'state', | ||||
|     'sticky', | ||||
|     'tab', | ||||
|     'transition', | ||||
|     'visit', | ||||
|     'visibility' | ||||
|   ], | ||||
|  | ||||
|   siteNamespace   : 'site', | ||||
|   namespaceStub   : { | ||||
|     cache     : {}, | ||||
|     config    : {}, | ||||
|     sections  : {}, | ||||
|     section   : {}, | ||||
|     utilities : {} | ||||
|   } | ||||
|  | ||||
| }; | ||||
|  | ||||
| // allows for selection of elements with data attributes | ||||
| $.extend($.expr[ ":" ], { | ||||
|   data: ($.expr.createPseudo) | ||||
|     ? $.expr.createPseudo(function(dataName) { | ||||
|         return function(elem) { | ||||
|           return !!$.data(elem, dataName); | ||||
|         }; | ||||
|       }) | ||||
|     : function(elem, i, match) { | ||||
|       // support: jQuery < 1.8 | ||||
|       return !!$.data(elem, match[ 3 ]); | ||||
|     } | ||||
| }); | ||||
|  | ||||
|  | ||||
| })( jQuery, window, document ); | ||||
| @@ -1,208 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Site | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'global'; | ||||
| @element : 'site'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|              Page | ||||
| *******************************/ | ||||
|  | ||||
| .loadFonts(); | ||||
|  | ||||
| html, | ||||
| body { | ||||
|   height: 100%; | ||||
| } | ||||
|  | ||||
| html { | ||||
|   font-size: @emSize; | ||||
| } | ||||
|  | ||||
| body { | ||||
|   margin: 0px; | ||||
|   padding: 0px; | ||||
|   overflow-x: @pageOverflowX; | ||||
|   min-width: @pageMinWidth; | ||||
|   background: @pageBackground; | ||||
|   font-family: @pageFont; | ||||
|   font-size: @fontSize; | ||||
|   line-height: @lineHeight; | ||||
|   color: @textColor; | ||||
|   font-smoothing: @fontSmoothing; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|              Headers | ||||
| *******************************/ | ||||
|  | ||||
| h1, | ||||
| h2, | ||||
| h3, | ||||
| h4, | ||||
| h5 { | ||||
|   font-family: @headerFont; | ||||
|   line-height: @headerLineHeight; | ||||
|   margin: @headerMargin; | ||||
|   font-weight: @headerFontWeight; | ||||
|   padding: 0em; | ||||
| } | ||||
|  | ||||
| h1 { | ||||
|   min-height: 1rem; | ||||
|   font-size: @h1; | ||||
| } | ||||
| h2 { | ||||
|   font-size: @h2; | ||||
| } | ||||
| h3 { | ||||
|   font-size: @h3; | ||||
| } | ||||
| h4 { | ||||
|   font-size: @h4; | ||||
| } | ||||
| h5 { | ||||
|   font-size: @h5; | ||||
| } | ||||
|  | ||||
| h1:first-child, | ||||
| h2:first-child, | ||||
| h3:first-child, | ||||
| h4:first-child, | ||||
| h5:first-child { | ||||
|   margin-top: 0em; | ||||
| } | ||||
|  | ||||
| h1:last-child, | ||||
| h2:last-child, | ||||
| h3:last-child, | ||||
| h4:last-child, | ||||
| h5:last-child { | ||||
|   margin-bottom: 0em; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|              Text | ||||
| *******************************/ | ||||
|  | ||||
| p { | ||||
|   margin: @paragraphMargin; | ||||
|   line-height: @paragraphLineHeight; | ||||
| } | ||||
| p:first-child { | ||||
|   margin-top: 0em; | ||||
| } | ||||
| p:last-child { | ||||
|   margin-bottom: 0em; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|         Links | ||||
| --------------------*/ | ||||
|  | ||||
| a { | ||||
|   color: @linkColor; | ||||
|   text-decoration: @linkUnderline; | ||||
| } | ||||
| a:hover { | ||||
|   color: @linkHoverColor; | ||||
|   text-decoration: @linkHoverUnderline; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|          Scrollbars | ||||
| *******************************/ | ||||
|  | ||||
| .addScrollbars() when (@useCustomScrollbars) { | ||||
|  | ||||
|   /* Force Simple Scrollbars */ | ||||
|   body ::-webkit-scrollbar { | ||||
|     -webkit-appearance: none; | ||||
|     width: @customScrollbarWidth; | ||||
|     height: @customScrollbarHeight; | ||||
|   } | ||||
|   body ::-webkit-scrollbar-track { | ||||
|     background: @trackBackground; | ||||
|     border-radius: @trackBorderRadius; | ||||
|   } | ||||
|   body ::-webkit-scrollbar-thumb { | ||||
|     cursor: pointer; | ||||
|     border-radius: @thumbBorderRadius; | ||||
|     background: @thumbBackground; | ||||
|     transition: @thumbTransition; | ||||
|   } | ||||
|   body ::-webkit-scrollbar-thumb:window-inactive { | ||||
|     background: @thumbInactiveBackground; | ||||
|   } | ||||
|   body ::-webkit-scrollbar-thumb:hover { | ||||
|     background: @thumbHoverBackground; | ||||
|   } | ||||
|  | ||||
|   /* Inverted UI */ | ||||
|   body .ui.inverted::-webkit-scrollbar-track { | ||||
|     background: @trackInvertedBackground; | ||||
|   } | ||||
|   body .ui.inverted::-webkit-scrollbar-thumb { | ||||
|     background: @thumbInvertedBackground; | ||||
|   } | ||||
|   body .ui.inverted::-webkit-scrollbar-thumb:window-inactive { | ||||
|     background: @thumbInvertedInactiveBackground; | ||||
|   } | ||||
|   body .ui.inverted::-webkit-scrollbar-thumb:hover { | ||||
|     background: @thumbInvertedHoverBackground; | ||||
|   } | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|           Highlighting | ||||
| *******************************/ | ||||
|  | ||||
| /* Site */ | ||||
| ::-webkit-selection { | ||||
|   background-color: @highlightBackground; | ||||
|   color: @highlightColor; | ||||
| } | ||||
| ::-moz-selection { | ||||
|   background-color: @highlightBackground; | ||||
|   color: @highlightColor; | ||||
| } | ||||
| ::selection { | ||||
|   background-color: @highlightBackground; | ||||
|   color: @highlightColor; | ||||
| } | ||||
|  | ||||
| /* Form */ | ||||
| textarea::-webkit-selection, | ||||
| input::-webkit-selection { | ||||
|   background-color: @inputHighlightBackground; | ||||
|   color: @inputHighlightColor; | ||||
| } | ||||
| textarea::-moz-selection, | ||||
| input::-moz-selection { | ||||
|   background-color: @inputHighlightBackground; | ||||
|   color: @inputHighlightColor; | ||||
| } | ||||
| textarea::selection, | ||||
| input::selection { | ||||
|   background-color: @inputHighlightBackground; | ||||
|   color: @inputHighlightColor; | ||||
| } | ||||
|  | ||||
| .addScrollbars(); | ||||
| .loadUIOverrides(); | ||||
| @@ -1,613 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Accordion | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| ;(function ($, window, document, undefined) { | ||||
|  | ||||
| 'use strict'; | ||||
|  | ||||
| window = (typeof window != 'undefined' && window.Math == Math) | ||||
|   ? window | ||||
|   : (typeof self != 'undefined' && self.Math == Math) | ||||
|     ? self | ||||
|     : Function('return this')() | ||||
| ; | ||||
|  | ||||
| $.fn.accordion = function(parameters) { | ||||
|   var | ||||
|     $allModules     = $(this), | ||||
|  | ||||
|     time            = new Date().getTime(), | ||||
|     performance     = [], | ||||
|  | ||||
|     query           = arguments[0], | ||||
|     methodInvoked   = (typeof query == 'string'), | ||||
|     queryArguments  = [].slice.call(arguments, 1), | ||||
|  | ||||
|     requestAnimationFrame = window.requestAnimationFrame | ||||
|       || window.mozRequestAnimationFrame | ||||
|       || window.webkitRequestAnimationFrame | ||||
|       || window.msRequestAnimationFrame | ||||
|       || function(callback) { setTimeout(callback, 0); }, | ||||
|  | ||||
|     returnedValue | ||||
|   ; | ||||
|   $allModules | ||||
|     .each(function() { | ||||
|       var | ||||
|         settings        = ( $.isPlainObject(parameters) ) | ||||
|           ? $.extend(true, {}, $.fn.accordion.settings, parameters) | ||||
|           : $.extend({}, $.fn.accordion.settings), | ||||
|  | ||||
|         className       = settings.className, | ||||
|         namespace       = settings.namespace, | ||||
|         selector        = settings.selector, | ||||
|         error           = settings.error, | ||||
|  | ||||
|         eventNamespace  = '.' + namespace, | ||||
|         moduleNamespace = 'module-' + namespace, | ||||
|         moduleSelector  = $allModules.selector || '', | ||||
|  | ||||
|         $module  = $(this), | ||||
|         $title   = $module.find(selector.title), | ||||
|         $content = $module.find(selector.content), | ||||
|  | ||||
|         element  = this, | ||||
|         instance = $module.data(moduleNamespace), | ||||
|         observer, | ||||
|         module | ||||
|       ; | ||||
|  | ||||
|       module = { | ||||
|  | ||||
|         initialize: function() { | ||||
|           module.debug('Initializing', $module); | ||||
|           module.bind.events(); | ||||
|           if(settings.observeChanges) { | ||||
|             module.observeChanges(); | ||||
|           } | ||||
|           module.instantiate(); | ||||
|         }, | ||||
|  | ||||
|         instantiate: function() { | ||||
|           instance = module; | ||||
|           $module | ||||
|             .data(moduleNamespace, module) | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         destroy: function() { | ||||
|           module.debug('Destroying previous instance', $module); | ||||
|           $module | ||||
|             .off(eventNamespace) | ||||
|             .removeData(moduleNamespace) | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         refresh: function() { | ||||
|           $title   = $module.find(selector.title); | ||||
|           $content = $module.find(selector.content); | ||||
|         }, | ||||
|  | ||||
|         observeChanges: function() { | ||||
|           if('MutationObserver' in window) { | ||||
|             observer = new MutationObserver(function(mutations) { | ||||
|               module.debug('DOM tree modified, updating selector cache'); | ||||
|               module.refresh(); | ||||
|             }); | ||||
|             observer.observe(element, { | ||||
|               childList : true, | ||||
|               subtree   : true | ||||
|             }); | ||||
|             module.debug('Setting up mutation observer', observer); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         bind: { | ||||
|           events: function() { | ||||
|             module.debug('Binding delegated events'); | ||||
|             $module | ||||
|               .on(settings.on + eventNamespace, selector.trigger, module.event.click) | ||||
|             ; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         event: { | ||||
|           click: function() { | ||||
|             module.toggle.call(this); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         toggle: function(query) { | ||||
|           var | ||||
|             $activeTitle = (query !== undefined) | ||||
|               ? (typeof query === 'number') | ||||
|                 ? $title.eq(query) | ||||
|                 : $(query).closest(selector.title) | ||||
|               : $(this).closest(selector.title), | ||||
|             $activeContent = $activeTitle.next($content), | ||||
|             isAnimating = $activeContent.hasClass(className.animating), | ||||
|             isActive    = $activeContent.hasClass(className.active), | ||||
|             isOpen      = (isActive && !isAnimating), | ||||
|             isOpening   = (!isActive && isAnimating) | ||||
|           ; | ||||
|           module.debug('Toggling visibility of content', $activeTitle); | ||||
|           if(isOpen || isOpening) { | ||||
|             if(settings.collapsible) { | ||||
|               module.close.call($activeTitle); | ||||
|             } | ||||
|             else { | ||||
|               module.debug('Cannot close accordion content collapsing is disabled'); | ||||
|             } | ||||
|           } | ||||
|           else { | ||||
|             module.open.call($activeTitle); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         open: function(query) { | ||||
|           var | ||||
|             $activeTitle = (query !== undefined) | ||||
|               ? (typeof query === 'number') | ||||
|                 ? $title.eq(query) | ||||
|                 : $(query).closest(selector.title) | ||||
|               : $(this).closest(selector.title), | ||||
|             $activeContent = $activeTitle.next($content), | ||||
|             isAnimating = $activeContent.hasClass(className.animating), | ||||
|             isActive    = $activeContent.hasClass(className.active), | ||||
|             isOpen      = (isActive || isAnimating) | ||||
|           ; | ||||
|           if(isOpen) { | ||||
|             module.debug('Accordion already open, skipping', $activeContent); | ||||
|             return; | ||||
|           } | ||||
|           module.debug('Opening accordion content', $activeTitle); | ||||
|           settings.onOpening.call($activeContent); | ||||
|           settings.onChanging.call($activeContent); | ||||
|           if(settings.exclusive) { | ||||
|             module.closeOthers.call($activeTitle); | ||||
|           } | ||||
|           $activeTitle | ||||
|             .addClass(className.active) | ||||
|           ; | ||||
|           $activeContent | ||||
|             .stop(true, true) | ||||
|             .addClass(className.animating) | ||||
|           ; | ||||
|           if(settings.animateChildren) { | ||||
|             if($.fn.transition !== undefined && $module.transition('is supported')) { | ||||
|               $activeContent | ||||
|                 .children() | ||||
|                   .transition({ | ||||
|                     animation   : 'fade in', | ||||
|                     queue       : false, | ||||
|                     useFailSafe : true, | ||||
|                     debug       : settings.debug, | ||||
|                     verbose     : settings.verbose, | ||||
|                     duration    : settings.duration | ||||
|                   }) | ||||
|               ; | ||||
|             } | ||||
|             else { | ||||
|               $activeContent | ||||
|                 .children() | ||||
|                   .stop(true, true) | ||||
|                   .animate({ | ||||
|                     opacity: 1 | ||||
|                   }, settings.duration, module.resetOpacity) | ||||
|               ; | ||||
|             } | ||||
|           } | ||||
|           $activeContent | ||||
|             .slideDown(settings.duration, settings.easing, function() { | ||||
|               $activeContent | ||||
|                 .removeClass(className.animating) | ||||
|                 .addClass(className.active) | ||||
|               ; | ||||
|               module.reset.display.call(this); | ||||
|               settings.onOpen.call(this); | ||||
|               settings.onChange.call(this); | ||||
|             }) | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         close: function(query) { | ||||
|           var | ||||
|             $activeTitle = (query !== undefined) | ||||
|               ? (typeof query === 'number') | ||||
|                 ? $title.eq(query) | ||||
|                 : $(query).closest(selector.title) | ||||
|               : $(this).closest(selector.title), | ||||
|             $activeContent = $activeTitle.next($content), | ||||
|             isAnimating    = $activeContent.hasClass(className.animating), | ||||
|             isActive       = $activeContent.hasClass(className.active), | ||||
|             isOpening      = (!isActive && isAnimating), | ||||
|             isClosing      = (isActive && isAnimating) | ||||
|           ; | ||||
|           if((isActive || isOpening) && !isClosing) { | ||||
|             module.debug('Closing accordion content', $activeContent); | ||||
|             settings.onClosing.call($activeContent); | ||||
|             settings.onChanging.call($activeContent); | ||||
|             $activeTitle | ||||
|               .removeClass(className.active) | ||||
|             ; | ||||
|             $activeContent | ||||
|               .stop(true, true) | ||||
|               .addClass(className.animating) | ||||
|             ; | ||||
|             if(settings.animateChildren) { | ||||
|               if($.fn.transition !== undefined && $module.transition('is supported')) { | ||||
|                 $activeContent | ||||
|                   .children() | ||||
|                     .transition({ | ||||
|                       animation   : 'fade out', | ||||
|                       queue       : false, | ||||
|                       useFailSafe : true, | ||||
|                       debug       : settings.debug, | ||||
|                       verbose     : settings.verbose, | ||||
|                       duration    : settings.duration | ||||
|                     }) | ||||
|                 ; | ||||
|               } | ||||
|               else { | ||||
|                 $activeContent | ||||
|                   .children() | ||||
|                     .stop(true, true) | ||||
|                     .animate({ | ||||
|                       opacity: 0 | ||||
|                     }, settings.duration, module.resetOpacity) | ||||
|                 ; | ||||
|               } | ||||
|             } | ||||
|             $activeContent | ||||
|               .slideUp(settings.duration, settings.easing, function() { | ||||
|                 $activeContent | ||||
|                   .removeClass(className.animating) | ||||
|                   .removeClass(className.active) | ||||
|                 ; | ||||
|                 module.reset.display.call(this); | ||||
|                 settings.onClose.call(this); | ||||
|                 settings.onChange.call(this); | ||||
|               }) | ||||
|             ; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         closeOthers: function(index) { | ||||
|           var | ||||
|             $activeTitle = (index !== undefined) | ||||
|               ? $title.eq(index) | ||||
|               : $(this).closest(selector.title), | ||||
|             $parentTitles    = $activeTitle.parents(selector.content).prev(selector.title), | ||||
|             $activeAccordion = $activeTitle.closest(selector.accordion), | ||||
|             activeSelector   = selector.title + '.' + className.active + ':visible', | ||||
|             activeContent    = selector.content + '.' + className.active + ':visible', | ||||
|             $openTitles, | ||||
|             $nestedTitles, | ||||
|             $openContents | ||||
|           ; | ||||
|           if(settings.closeNested) { | ||||
|             $openTitles   = $activeAccordion.find(activeSelector).not($parentTitles); | ||||
|             $openContents = $openTitles.next($content); | ||||
|           } | ||||
|           else { | ||||
|             $openTitles   = $activeAccordion.find(activeSelector).not($parentTitles); | ||||
|             $nestedTitles = $activeAccordion.find(activeContent).find(activeSelector).not($parentTitles); | ||||
|             $openTitles   = $openTitles.not($nestedTitles); | ||||
|             $openContents = $openTitles.next($content); | ||||
|           } | ||||
|           if( ($openTitles.length > 0) ) { | ||||
|             module.debug('Exclusive enabled, closing other content', $openTitles); | ||||
|             $openTitles | ||||
|               .removeClass(className.active) | ||||
|             ; | ||||
|             $openContents | ||||
|               .removeClass(className.animating) | ||||
|               .stop(true, true) | ||||
|             ; | ||||
|             if(settings.animateChildren) { | ||||
|               if($.fn.transition !== undefined && $module.transition('is supported')) { | ||||
|                 $openContents | ||||
|                   .children() | ||||
|                     .transition({ | ||||
|                       animation   : 'fade out', | ||||
|                       useFailSafe : true, | ||||
|                       debug       : settings.debug, | ||||
|                       verbose     : settings.verbose, | ||||
|                       duration    : settings.duration | ||||
|                     }) | ||||
|                 ; | ||||
|               } | ||||
|               else { | ||||
|                 $openContents | ||||
|                   .children() | ||||
|                     .stop(true, true) | ||||
|                     .animate({ | ||||
|                       opacity: 0 | ||||
|                     }, settings.duration, module.resetOpacity) | ||||
|                 ; | ||||
|               } | ||||
|             } | ||||
|             $openContents | ||||
|               .slideUp(settings.duration , settings.easing, function() { | ||||
|                 $(this).removeClass(className.active); | ||||
|                 module.reset.display.call(this); | ||||
|               }) | ||||
|             ; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         reset: { | ||||
|  | ||||
|           display: function() { | ||||
|             module.verbose('Removing inline display from element', this); | ||||
|             $(this).css('display', ''); | ||||
|             if( $(this).attr('style') === '') { | ||||
|               $(this) | ||||
|                 .attr('style', '') | ||||
|                 .removeAttr('style') | ||||
|               ; | ||||
|             } | ||||
|           }, | ||||
|  | ||||
|           opacity: function() { | ||||
|             module.verbose('Removing inline opacity from element', this); | ||||
|             $(this).css('opacity', ''); | ||||
|             if( $(this).attr('style') === '') { | ||||
|               $(this) | ||||
|                 .attr('style', '') | ||||
|                 .removeAttr('style') | ||||
|               ; | ||||
|             } | ||||
|           }, | ||||
|  | ||||
|         }, | ||||
|  | ||||
|         setting: function(name, value) { | ||||
|           module.debug('Changing setting', name, value); | ||||
|           if( $.isPlainObject(name) ) { | ||||
|             $.extend(true, settings, name); | ||||
|           } | ||||
|           else if(value !== undefined) { | ||||
|             if($.isPlainObject(settings[name])) { | ||||
|               $.extend(true, settings[name], value); | ||||
|             } | ||||
|             else { | ||||
|               settings[name] = value; | ||||
|             } | ||||
|           } | ||||
|           else { | ||||
|             return settings[name]; | ||||
|           } | ||||
|         }, | ||||
|         internal: function(name, value) { | ||||
|           module.debug('Changing internal', name, value); | ||||
|           if(value !== undefined) { | ||||
|             if( $.isPlainObject(name) ) { | ||||
|               $.extend(true, module, name); | ||||
|             } | ||||
|             else { | ||||
|               module[name] = value; | ||||
|             } | ||||
|           } | ||||
|           else { | ||||
|             return module[name]; | ||||
|           } | ||||
|         }, | ||||
|         debug: function() { | ||||
|           if(!settings.silent && settings.debug) { | ||||
|             if(settings.performance) { | ||||
|               module.performance.log(arguments); | ||||
|             } | ||||
|             else { | ||||
|               module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|               module.debug.apply(console, arguments); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         verbose: function() { | ||||
|           if(!settings.silent && settings.verbose && settings.debug) { | ||||
|             if(settings.performance) { | ||||
|               module.performance.log(arguments); | ||||
|             } | ||||
|             else { | ||||
|               module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|               module.verbose.apply(console, arguments); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         error: function() { | ||||
|           if(!settings.silent) { | ||||
|             module.error = Function.prototype.bind.call(console.error, console, settings.name + ':'); | ||||
|             module.error.apply(console, arguments); | ||||
|           } | ||||
|         }, | ||||
|         performance: { | ||||
|           log: function(message) { | ||||
|             var | ||||
|               currentTime, | ||||
|               executionTime, | ||||
|               previousTime | ||||
|             ; | ||||
|             if(settings.performance) { | ||||
|               currentTime   = new Date().getTime(); | ||||
|               previousTime  = time || currentTime; | ||||
|               executionTime = currentTime - previousTime; | ||||
|               time          = currentTime; | ||||
|               performance.push({ | ||||
|                 'Name'           : message[0], | ||||
|                 'Arguments'      : [].slice.call(message, 1) || '', | ||||
|                 'Element'        : element, | ||||
|                 'Execution Time' : executionTime | ||||
|               }); | ||||
|             } | ||||
|             clearTimeout(module.performance.timer); | ||||
|             module.performance.timer = setTimeout(module.performance.display, 500); | ||||
|           }, | ||||
|           display: function() { | ||||
|             var | ||||
|               title = settings.name + ':', | ||||
|               totalTime = 0 | ||||
|             ; | ||||
|             time = false; | ||||
|             clearTimeout(module.performance.timer); | ||||
|             $.each(performance, function(index, data) { | ||||
|               totalTime += data['Execution Time']; | ||||
|             }); | ||||
|             title += ' ' + totalTime + 'ms'; | ||||
|             if(moduleSelector) { | ||||
|               title += ' \'' + moduleSelector + '\''; | ||||
|             } | ||||
|             if( (console.group !== undefined || console.table !== undefined) && performance.length > 0) { | ||||
|               console.groupCollapsed(title); | ||||
|               if(console.table) { | ||||
|                 console.table(performance); | ||||
|               } | ||||
|               else { | ||||
|                 $.each(performance, function(index, data) { | ||||
|                   console.log(data['Name'] + ': ' + data['Execution Time']+'ms'); | ||||
|                 }); | ||||
|               } | ||||
|               console.groupEnd(); | ||||
|             } | ||||
|             performance = []; | ||||
|           } | ||||
|         }, | ||||
|         invoke: function(query, passedArguments, context) { | ||||
|           var | ||||
|             object = instance, | ||||
|             maxDepth, | ||||
|             found, | ||||
|             response | ||||
|           ; | ||||
|           passedArguments = passedArguments || queryArguments; | ||||
|           context         = element         || context; | ||||
|           if(typeof query == 'string' && object !== undefined) { | ||||
|             query    = query.split(/[\. ]/); | ||||
|             maxDepth = query.length - 1; | ||||
|             $.each(query, function(depth, value) { | ||||
|               var camelCaseValue = (depth != maxDepth) | ||||
|                 ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1) | ||||
|                 : query | ||||
|               ; | ||||
|               if( $.isPlainObject( object[camelCaseValue] ) && (depth != maxDepth) ) { | ||||
|                 object = object[camelCaseValue]; | ||||
|               } | ||||
|               else if( object[camelCaseValue] !== undefined ) { | ||||
|                 found = object[camelCaseValue]; | ||||
|                 return false; | ||||
|               } | ||||
|               else if( $.isPlainObject( object[value] ) && (depth != maxDepth) ) { | ||||
|                 object = object[value]; | ||||
|               } | ||||
|               else if( object[value] !== undefined ) { | ||||
|                 found = object[value]; | ||||
|                 return false; | ||||
|               } | ||||
|               else { | ||||
|                 module.error(error.method, query); | ||||
|                 return false; | ||||
|               } | ||||
|             }); | ||||
|           } | ||||
|           if ( $.isFunction( found ) ) { | ||||
|             response = found.apply(context, passedArguments); | ||||
|           } | ||||
|           else if(found !== undefined) { | ||||
|             response = found; | ||||
|           } | ||||
|           if($.isArray(returnedValue)) { | ||||
|             returnedValue.push(response); | ||||
|           } | ||||
|           else if(returnedValue !== undefined) { | ||||
|             returnedValue = [returnedValue, response]; | ||||
|           } | ||||
|           else if(response !== undefined) { | ||||
|             returnedValue = response; | ||||
|           } | ||||
|           return found; | ||||
|         } | ||||
|       }; | ||||
|       if(methodInvoked) { | ||||
|         if(instance === undefined) { | ||||
|           module.initialize(); | ||||
|         } | ||||
|         module.invoke(query); | ||||
|       } | ||||
|       else { | ||||
|         if(instance !== undefined) { | ||||
|           instance.invoke('destroy'); | ||||
|         } | ||||
|         module.initialize(); | ||||
|       } | ||||
|     }) | ||||
|   ; | ||||
|   return (returnedValue !== undefined) | ||||
|     ? returnedValue | ||||
|     : this | ||||
|   ; | ||||
| }; | ||||
|  | ||||
| $.fn.accordion.settings = { | ||||
|  | ||||
|   name            : 'Accordion', | ||||
|   namespace       : 'accordion', | ||||
|  | ||||
|   silent          : false, | ||||
|   debug           : false, | ||||
|   verbose         : false, | ||||
|   performance     : true, | ||||
|  | ||||
|   on              : 'click', // event on title that opens accordion | ||||
|  | ||||
|   observeChanges  : true,  // whether accordion should automatically refresh on DOM insertion | ||||
|  | ||||
|   exclusive       : true,  // whether a single accordion content panel should be open at once | ||||
|   collapsible     : true,  // whether accordion content can be closed | ||||
|   closeNested     : false, // whether nested content should be closed when a panel is closed | ||||
|   animateChildren : true,  // whether children opacity should be animated | ||||
|  | ||||
|   duration        : 350, // duration of animation | ||||
|   easing          : 'easeOutQuad', // easing equation for animation | ||||
|  | ||||
|   onOpening       : function(){}, // callback before open animation | ||||
|   onClosing       : function(){}, // callback before closing animation | ||||
|   onChanging      : function(){}, // callback before closing or opening animation | ||||
|  | ||||
|   onOpen          : function(){}, // callback after open animation | ||||
|   onClose         : function(){}, // callback after closing animation | ||||
|   onChange        : function(){}, // callback after closing or opening animation | ||||
|  | ||||
|   error: { | ||||
|     method : 'The method you called is not defined' | ||||
|   }, | ||||
|  | ||||
|   className   : { | ||||
|     active    : 'active', | ||||
|     animating : 'animating' | ||||
|   }, | ||||
|  | ||||
|   selector    : { | ||||
|     accordion : '.accordion', | ||||
|     title     : '.title', | ||||
|     trigger   : '.title', | ||||
|     content   : '.content' | ||||
|   } | ||||
|  | ||||
| }; | ||||
|  | ||||
| // Adds easing | ||||
| $.extend( $.easing, { | ||||
|   easeOutQuad: function (x, t, b, c, d) { | ||||
|     return -c *(t/=d)*(t-2) + b; | ||||
|   } | ||||
| }); | ||||
|  | ||||
| })( jQuery, window, document ); | ||||
|  | ||||
| @@ -1,219 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Accordion | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'module'; | ||||
| @element : 'accordion'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|             Accordion | ||||
| *******************************/ | ||||
|  | ||||
| .ui.accordion, | ||||
| .ui.accordion .accordion { | ||||
|   max-width: 100%; | ||||
| } | ||||
| .ui.accordion .accordion { | ||||
|   margin: @childAccordionMargin; | ||||
|   padding: @childAccordionPadding; | ||||
| } | ||||
|  | ||||
| /* Title */ | ||||
| .ui.accordion .title, | ||||
| .ui.accordion .accordion .title { | ||||
|   cursor: pointer; | ||||
| } | ||||
|  | ||||
| /* Default Styling */ | ||||
| .ui.accordion .title:not(.ui) { | ||||
|   padding: @titlePadding; | ||||
|   font-family: @titleFont; | ||||
|   font-size: @titleFontSize; | ||||
|   color: @titleColor; | ||||
| } | ||||
|  | ||||
| /* Content */ | ||||
| .ui.accordion .title ~ .content, | ||||
| .ui.accordion .accordion .title ~ .content { | ||||
|   display: none; | ||||
| } | ||||
|  | ||||
| /* Default Styling */ | ||||
| .ui.accordion:not(.styled) .title ~ .content:not(.ui), | ||||
| .ui.accordion:not(.styled) .accordion .title ~ .content:not(.ui) { | ||||
|   margin: @contentMargin; | ||||
|   padding: @contentPadding; | ||||
| } | ||||
| .ui.accordion:not(.styled) .title ~ .content:not(.ui):last-child { | ||||
|   padding-bottom: 0em; | ||||
| } | ||||
|  | ||||
| /* Arrow */ | ||||
| .ui.accordion .title .dropdown.icon, | ||||
| .ui.accordion .accordion .title .dropdown.icon { | ||||
|   display: @iconDisplay; | ||||
|   float: @iconFloat; | ||||
|   opacity: @iconOpacity; | ||||
|   width: @iconWidth; | ||||
|   height: @iconHeight; | ||||
|   margin: @iconMargin; | ||||
|   padding: @iconPadding; | ||||
|   font-size: @iconFontSize; | ||||
|   transition: @iconTransition; | ||||
|   vertical-align: @iconVerticalAlign; | ||||
|   transform: @iconTransform; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Coupling | ||||
| ---------------*/ | ||||
|  | ||||
| /* Menu */ | ||||
| .ui.accordion.menu .item .title { | ||||
|   display: block; | ||||
|   padding: @menuTitlePadding; | ||||
| } | ||||
| .ui.accordion.menu .item .title > .dropdown.icon { | ||||
|   float: @menuIconFloat; | ||||
|   margin: @menuIconMargin; | ||||
|   transform: @menuIconTransform; | ||||
| } | ||||
|  | ||||
| /* Header */ | ||||
| .ui.accordion .ui.header .dropdown.icon { | ||||
|   font-size: @iconFontSize; | ||||
|   margin: @iconMargin; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|             States | ||||
| *******************************/ | ||||
|  | ||||
| .ui.accordion .active.title .dropdown.icon, | ||||
| .ui.accordion .accordion .active.title .dropdown.icon { | ||||
|   transform: @activeIconTransform; | ||||
| } | ||||
|  | ||||
| .ui.accordion.menu .item .active.title > .dropdown.icon { | ||||
|   transform: @activeIconTransform; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|             Types | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|      Styled | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.styled.accordion { | ||||
|   width: @styledWidth; | ||||
| } | ||||
|  | ||||
| .ui.styled.accordion, | ||||
| .ui.styled.accordion .accordion { | ||||
|   border-radius: @styledBorderRadius; | ||||
|   background: @styledBackground; | ||||
|   box-shadow: @styledBoxShadow; | ||||
| } | ||||
| .ui.styled.accordion .title, | ||||
| .ui.styled.accordion .accordion .title { | ||||
|   margin: @styledTitleMargin; | ||||
|   padding: @styledTitlePadding; | ||||
|   color: @styledTitleColor; | ||||
|   font-weight: @styledTitleFontWeight; | ||||
|   border-top: @styledTitleBorder; | ||||
|   transition: @styledTitleTransition; | ||||
| } | ||||
| .ui.styled.accordion > .title:first-child, | ||||
| .ui.styled.accordion .accordion .title:first-child { | ||||
|   border-top: none; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Content */ | ||||
| .ui.styled.accordion .content, | ||||
| .ui.styled.accordion .accordion .content { | ||||
|   margin: @styledContentMargin; | ||||
|   padding: @styledContentPadding; | ||||
| } | ||||
| .ui.styled.accordion .accordion .content { | ||||
|   padding: @styledChildContentMargin; | ||||
|   padding: @styledChildContentPadding; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Hover */ | ||||
| .ui.styled.accordion .title:hover, | ||||
| .ui.styled.accordion .active.title, | ||||
| .ui.styled.accordion .accordion .title:hover, | ||||
| .ui.styled.accordion .accordion .active.title { | ||||
|   background: @styledTitleHoverBackground; | ||||
|   color: @styledTitleHoverColor; | ||||
| } | ||||
| .ui.styled.accordion .accordion .title:hover, | ||||
| .ui.styled.accordion .accordion .active.title { | ||||
|   background: @styledHoverChildTitleBackground; | ||||
|   color: @styledHoverChildTitleColor; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Active */ | ||||
| .ui.styled.accordion .active.title { | ||||
|   background: @styledActiveTitleBackground; | ||||
|   color: @styledActiveTitleColor; | ||||
| } | ||||
| .ui.styled.accordion .accordion .active.title { | ||||
|   background: @styledActiveChildTitleBackground; | ||||
|   color: @styledActiveChildTitleColor; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             States | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|      Active | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.accordion .active.content, | ||||
| .ui.accordion .accordion .active.content { | ||||
|   display: block; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|            Variations | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|      Fluid | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.fluid.accordion, | ||||
| .ui.fluid.accordion .accordion { | ||||
|   width: 100%; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Inverted | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.inverted.accordion .title:not(.ui) { | ||||
|   color: @invertedTitleColor; | ||||
| } | ||||
|  | ||||
| .loadUIOverrides(); | ||||
|  | ||||
| @@ -1,831 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Checkbox | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| ;(function ($, window, document, undefined) { | ||||
|  | ||||
| 'use strict'; | ||||
|  | ||||
| window = (typeof window != 'undefined' && window.Math == Math) | ||||
|   ? window | ||||
|   : (typeof self != 'undefined' && self.Math == Math) | ||||
|     ? self | ||||
|     : Function('return this')() | ||||
| ; | ||||
|  | ||||
| $.fn.checkbox = function(parameters) { | ||||
|   var | ||||
|     $allModules    = $(this), | ||||
|     moduleSelector = $allModules.selector || '', | ||||
|  | ||||
|     time           = new Date().getTime(), | ||||
|     performance    = [], | ||||
|  | ||||
|     query          = arguments[0], | ||||
|     methodInvoked  = (typeof query == 'string'), | ||||
|     queryArguments = [].slice.call(arguments, 1), | ||||
|     returnedValue | ||||
|   ; | ||||
|  | ||||
|   $allModules | ||||
|     .each(function() { | ||||
|       var | ||||
|         settings        = $.extend(true, {}, $.fn.checkbox.settings, parameters), | ||||
|  | ||||
|         className       = settings.className, | ||||
|         namespace       = settings.namespace, | ||||
|         selector        = settings.selector, | ||||
|         error           = settings.error, | ||||
|  | ||||
|         eventNamespace  = '.' + namespace, | ||||
|         moduleNamespace = 'module-' + namespace, | ||||
|  | ||||
|         $module         = $(this), | ||||
|         $label          = $(this).children(selector.label), | ||||
|         $input          = $(this).children(selector.input), | ||||
|         input           = $input[0], | ||||
|  | ||||
|         initialLoad     = false, | ||||
|         shortcutPressed = false, | ||||
|         instance        = $module.data(moduleNamespace), | ||||
|  | ||||
|         observer, | ||||
|         element         = this, | ||||
|         module | ||||
|       ; | ||||
|  | ||||
|       module      = { | ||||
|  | ||||
|         initialize: function() { | ||||
|           module.verbose('Initializing checkbox', settings); | ||||
|  | ||||
|           module.create.label(); | ||||
|           module.bind.events(); | ||||
|  | ||||
|           module.set.tabbable(); | ||||
|           module.hide.input(); | ||||
|  | ||||
|           module.observeChanges(); | ||||
|           module.instantiate(); | ||||
|           module.setup(); | ||||
|         }, | ||||
|  | ||||
|         instantiate: function() { | ||||
|           module.verbose('Storing instance of module', module); | ||||
|           instance = module; | ||||
|           $module | ||||
|             .data(moduleNamespace, module) | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         destroy: function() { | ||||
|           module.verbose('Destroying module'); | ||||
|           module.unbind.events(); | ||||
|           module.show.input(); | ||||
|           $module.removeData(moduleNamespace); | ||||
|         }, | ||||
|  | ||||
|         fix: { | ||||
|           reference: function() { | ||||
|             if( $module.is(selector.input) ) { | ||||
|               module.debug('Behavior called on <input> adjusting invoked element'); | ||||
|               $module = $module.closest(selector.checkbox); | ||||
|               module.refresh(); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         setup: function() { | ||||
|           module.set.initialLoad(); | ||||
|           if( module.is.indeterminate() ) { | ||||
|             module.debug('Initial value is indeterminate'); | ||||
|             module.indeterminate(); | ||||
|           } | ||||
|           else if( module.is.checked() ) { | ||||
|             module.debug('Initial value is checked'); | ||||
|             module.check(); | ||||
|           } | ||||
|           else { | ||||
|             module.debug('Initial value is unchecked'); | ||||
|             module.uncheck(); | ||||
|           } | ||||
|           module.remove.initialLoad(); | ||||
|         }, | ||||
|  | ||||
|         refresh: function() { | ||||
|           $label = $module.children(selector.label); | ||||
|           $input = $module.children(selector.input); | ||||
|           input  = $input[0]; | ||||
|         }, | ||||
|  | ||||
|         hide: { | ||||
|           input: function() { | ||||
|             module.verbose('Modifying <input> z-index to be unselectable'); | ||||
|             $input.addClass(className.hidden); | ||||
|           } | ||||
|         }, | ||||
|         show: { | ||||
|           input: function() { | ||||
|             module.verbose('Modifying <input> z-index to be selectable'); | ||||
|             $input.removeClass(className.hidden); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         observeChanges: function() { | ||||
|           if('MutationObserver' in window) { | ||||
|             observer = new MutationObserver(function(mutations) { | ||||
|               module.debug('DOM tree modified, updating selector cache'); | ||||
|               module.refresh(); | ||||
|             }); | ||||
|             observer.observe(element, { | ||||
|               childList : true, | ||||
|               subtree   : true | ||||
|             }); | ||||
|             module.debug('Setting up mutation observer', observer); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         attachEvents: function(selector, event) { | ||||
|           var | ||||
|             $element = $(selector) | ||||
|           ; | ||||
|           event = $.isFunction(module[event]) | ||||
|             ? module[event] | ||||
|             : module.toggle | ||||
|           ; | ||||
|           if($element.length > 0) { | ||||
|             module.debug('Attaching checkbox events to element', selector, event); | ||||
|             $element | ||||
|               .on('click' + eventNamespace, event) | ||||
|             ; | ||||
|           } | ||||
|           else { | ||||
|             module.error(error.notFound); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         event: { | ||||
|           click: function(event) { | ||||
|             var | ||||
|               $target = $(event.target) | ||||
|             ; | ||||
|             if( $target.is(selector.input) ) { | ||||
|               module.verbose('Using default check action on initialized checkbox'); | ||||
|               return; | ||||
|             } | ||||
|             if( $target.is(selector.link) ) { | ||||
|               module.debug('Clicking link inside checkbox, skipping toggle'); | ||||
|               return; | ||||
|             } | ||||
|             module.toggle(); | ||||
|             $input.focus(); | ||||
|             event.preventDefault(); | ||||
|           }, | ||||
|           keydown: function(event) { | ||||
|             var | ||||
|               key     = event.which, | ||||
|               keyCode = { | ||||
|                 enter  : 13, | ||||
|                 space  : 32, | ||||
|                 escape : 27 | ||||
|               } | ||||
|             ; | ||||
|             if(key == keyCode.escape) { | ||||
|               module.verbose('Escape key pressed blurring field'); | ||||
|               $input.blur(); | ||||
|               shortcutPressed = true; | ||||
|             } | ||||
|             else if(!event.ctrlKey && ( key == keyCode.space || key == keyCode.enter) ) { | ||||
|               module.verbose('Enter/space key pressed, toggling checkbox'); | ||||
|               module.toggle(); | ||||
|               shortcutPressed = true; | ||||
|             } | ||||
|             else { | ||||
|               shortcutPressed = false; | ||||
|             } | ||||
|           }, | ||||
|           keyup: function(event) { | ||||
|             if(shortcutPressed) { | ||||
|               event.preventDefault(); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         check: function() { | ||||
|           if( !module.should.allowCheck() ) { | ||||
|             return; | ||||
|           } | ||||
|           module.debug('Checking checkbox', $input); | ||||
|           module.set.checked(); | ||||
|           if( !module.should.ignoreCallbacks() ) { | ||||
|             settings.onChecked.call(input); | ||||
|             settings.onChange.call(input); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         uncheck: function() { | ||||
|           if( !module.should.allowUncheck() ) { | ||||
|             return; | ||||
|           } | ||||
|           module.debug('Unchecking checkbox'); | ||||
|           module.set.unchecked(); | ||||
|           if( !module.should.ignoreCallbacks() ) { | ||||
|             settings.onUnchecked.call(input); | ||||
|             settings.onChange.call(input); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         indeterminate: function() { | ||||
|           if( module.should.allowIndeterminate() ) { | ||||
|             module.debug('Checkbox is already indeterminate'); | ||||
|             return; | ||||
|           } | ||||
|           module.debug('Making checkbox indeterminate'); | ||||
|           module.set.indeterminate(); | ||||
|           if( !module.should.ignoreCallbacks() ) { | ||||
|             settings.onIndeterminate.call(input); | ||||
|             settings.onChange.call(input); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         determinate: function() { | ||||
|           if( module.should.allowDeterminate() ) { | ||||
|             module.debug('Checkbox is already determinate'); | ||||
|             return; | ||||
|           } | ||||
|           module.debug('Making checkbox determinate'); | ||||
|           module.set.determinate(); | ||||
|           if( !module.should.ignoreCallbacks() ) { | ||||
|             settings.onDeterminate.call(input); | ||||
|             settings.onChange.call(input); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         enable: function() { | ||||
|           if( module.is.enabled() ) { | ||||
|             module.debug('Checkbox is already enabled'); | ||||
|             return; | ||||
|           } | ||||
|           module.debug('Enabling checkbox'); | ||||
|           module.set.enabled(); | ||||
|           settings.onEnable.call(input); | ||||
|           // preserve legacy callbacks | ||||
|           settings.onEnabled.call(input); | ||||
|         }, | ||||
|  | ||||
|         disable: function() { | ||||
|           if( module.is.disabled() ) { | ||||
|             module.debug('Checkbox is already disabled'); | ||||
|             return; | ||||
|           } | ||||
|           module.debug('Disabling checkbox'); | ||||
|           module.set.disabled(); | ||||
|           settings.onDisable.call(input); | ||||
|           // preserve legacy callbacks | ||||
|           settings.onDisabled.call(input); | ||||
|         }, | ||||
|  | ||||
|         get: { | ||||
|           radios: function() { | ||||
|             var | ||||
|               name = module.get.name() | ||||
|             ; | ||||
|             return $('input[name="' + name + '"]').closest(selector.checkbox); | ||||
|           }, | ||||
|           otherRadios: function() { | ||||
|             return module.get.radios().not($module); | ||||
|           }, | ||||
|           name: function() { | ||||
|             return $input.attr('name'); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         is: { | ||||
|           initialLoad: function() { | ||||
|             return initialLoad; | ||||
|           }, | ||||
|           radio: function() { | ||||
|             return ($input.hasClass(className.radio) || $input.attr('type') == 'radio'); | ||||
|           }, | ||||
|           indeterminate: function() { | ||||
|             return $input.prop('indeterminate') !== undefined && $input.prop('indeterminate'); | ||||
|           }, | ||||
|           checked: function() { | ||||
|             return $input.prop('checked') !== undefined && $input.prop('checked'); | ||||
|           }, | ||||
|           disabled: function() { | ||||
|             return $input.prop('disabled') !== undefined && $input.prop('disabled'); | ||||
|           }, | ||||
|           enabled: function() { | ||||
|             return !module.is.disabled(); | ||||
|           }, | ||||
|           determinate: function() { | ||||
|             return !module.is.indeterminate(); | ||||
|           }, | ||||
|           unchecked: function() { | ||||
|             return !module.is.checked(); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         should: { | ||||
|           allowCheck: function() { | ||||
|             if(module.is.determinate() && module.is.checked() && !module.should.forceCallbacks() ) { | ||||
|               module.debug('Should not allow check, checkbox is already checked'); | ||||
|               return false; | ||||
|             } | ||||
|             if(settings.beforeChecked.apply(input) === false) { | ||||
|               module.debug('Should not allow check, beforeChecked cancelled'); | ||||
|               return false; | ||||
|             } | ||||
|             return true; | ||||
|           }, | ||||
|           allowUncheck: function() { | ||||
|             if(module.is.determinate() && module.is.unchecked() && !module.should.forceCallbacks() ) { | ||||
|               module.debug('Should not allow uncheck, checkbox is already unchecked'); | ||||
|               return false; | ||||
|             } | ||||
|             if(settings.beforeUnchecked.apply(input) === false) { | ||||
|               module.debug('Should not allow uncheck, beforeUnchecked cancelled'); | ||||
|               return false; | ||||
|             } | ||||
|             return true; | ||||
|           }, | ||||
|           allowIndeterminate: function() { | ||||
|             if(module.is.indeterminate() && !module.should.forceCallbacks() ) { | ||||
|               module.debug('Should not allow indeterminate, checkbox is already indeterminate'); | ||||
|               return false; | ||||
|             } | ||||
|             if(settings.beforeIndeterminate.apply(input) === false) { | ||||
|               module.debug('Should not allow indeterminate, beforeIndeterminate cancelled'); | ||||
|               return false; | ||||
|             } | ||||
|             return true; | ||||
|           }, | ||||
|           allowDeterminate: function() { | ||||
|             if(module.is.determinate() && !module.should.forceCallbacks() ) { | ||||
|               module.debug('Should not allow determinate, checkbox is already determinate'); | ||||
|               return false; | ||||
|             } | ||||
|             if(settings.beforeDeterminate.apply(input) === false) { | ||||
|               module.debug('Should not allow determinate, beforeDeterminate cancelled'); | ||||
|               return false; | ||||
|             } | ||||
|             return true; | ||||
|           }, | ||||
|           forceCallbacks: function() { | ||||
|             return (module.is.initialLoad() && settings.fireOnInit); | ||||
|           }, | ||||
|           ignoreCallbacks: function() { | ||||
|             return (initialLoad && !settings.fireOnInit); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         can: { | ||||
|           change: function() { | ||||
|             return !( $module.hasClass(className.disabled) || $module.hasClass(className.readOnly) || $input.prop('disabled') || $input.prop('readonly') ); | ||||
|           }, | ||||
|           uncheck: function() { | ||||
|             return (typeof settings.uncheckable === 'boolean') | ||||
|               ? settings.uncheckable | ||||
|               : !module.is.radio() | ||||
|             ; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         set: { | ||||
|           initialLoad: function() { | ||||
|             initialLoad = true; | ||||
|           }, | ||||
|           checked: function() { | ||||
|             module.verbose('Setting class to checked'); | ||||
|             $module | ||||
|               .removeClass(className.indeterminate) | ||||
|               .addClass(className.checked) | ||||
|             ; | ||||
|             if( module.is.radio() ) { | ||||
|               module.uncheckOthers(); | ||||
|             } | ||||
|             if(!module.is.indeterminate() && module.is.checked()) { | ||||
|               module.debug('Input is already checked, skipping input property change'); | ||||
|               return; | ||||
|             } | ||||
|             module.verbose('Setting state to checked', input); | ||||
|             $input | ||||
|               .prop('indeterminate', false) | ||||
|               .prop('checked', true) | ||||
|             ; | ||||
|             module.trigger.change(); | ||||
|           }, | ||||
|           unchecked: function() { | ||||
|             module.verbose('Removing checked class'); | ||||
|             $module | ||||
|               .removeClass(className.indeterminate) | ||||
|               .removeClass(className.checked) | ||||
|             ; | ||||
|             if(!module.is.indeterminate() &&  module.is.unchecked() ) { | ||||
|               module.debug('Input is already unchecked'); | ||||
|               return; | ||||
|             } | ||||
|             module.debug('Setting state to unchecked'); | ||||
|             $input | ||||
|               .prop('indeterminate', false) | ||||
|               .prop('checked', false) | ||||
|             ; | ||||
|             module.trigger.change(); | ||||
|           }, | ||||
|           indeterminate: function() { | ||||
|             module.verbose('Setting class to indeterminate'); | ||||
|             $module | ||||
|               .addClass(className.indeterminate) | ||||
|             ; | ||||
|             if( module.is.indeterminate() ) { | ||||
|               module.debug('Input is already indeterminate, skipping input property change'); | ||||
|               return; | ||||
|             } | ||||
|             module.debug('Setting state to indeterminate'); | ||||
|             $input | ||||
|               .prop('indeterminate', true) | ||||
|             ; | ||||
|             module.trigger.change(); | ||||
|           }, | ||||
|           determinate: function() { | ||||
|             module.verbose('Removing indeterminate class'); | ||||
|             $module | ||||
|               .removeClass(className.indeterminate) | ||||
|             ; | ||||
|             if( module.is.determinate() ) { | ||||
|               module.debug('Input is already determinate, skipping input property change'); | ||||
|               return; | ||||
|             } | ||||
|             module.debug('Setting state to determinate'); | ||||
|             $input | ||||
|               .prop('indeterminate', false) | ||||
|             ; | ||||
|           }, | ||||
|           disabled: function() { | ||||
|             module.verbose('Setting class to disabled'); | ||||
|             $module | ||||
|               .addClass(className.disabled) | ||||
|             ; | ||||
|             if( module.is.disabled() ) { | ||||
|               module.debug('Input is already disabled, skipping input property change'); | ||||
|               return; | ||||
|             } | ||||
|             module.debug('Setting state to disabled'); | ||||
|             $input | ||||
|               .prop('disabled', 'disabled') | ||||
|             ; | ||||
|             module.trigger.change(); | ||||
|           }, | ||||
|           enabled: function() { | ||||
|             module.verbose('Removing disabled class'); | ||||
|             $module.removeClass(className.disabled); | ||||
|             if( module.is.enabled() ) { | ||||
|               module.debug('Input is already enabled, skipping input property change'); | ||||
|               return; | ||||
|             } | ||||
|             module.debug('Setting state to enabled'); | ||||
|             $input | ||||
|               .prop('disabled', false) | ||||
|             ; | ||||
|             module.trigger.change(); | ||||
|           }, | ||||
|           tabbable: function() { | ||||
|             module.verbose('Adding tabindex to checkbox'); | ||||
|             if( $input.attr('tabindex') === undefined) { | ||||
|               $input.attr('tabindex', 0); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         remove: { | ||||
|           initialLoad: function() { | ||||
|             initialLoad = false; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         trigger: { | ||||
|           change: function() { | ||||
|             var | ||||
|               events       = document.createEvent('HTMLEvents'), | ||||
|               inputElement = $input[0] | ||||
|             ; | ||||
|             if(inputElement) { | ||||
|               module.verbose('Triggering native change event'); | ||||
|               events.initEvent('change', true, false); | ||||
|               inputElement.dispatchEvent(events); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|  | ||||
|         create: { | ||||
|           label: function() { | ||||
|             if($input.prevAll(selector.label).length > 0) { | ||||
|               $input.prev(selector.label).detach().insertAfter($input); | ||||
|               module.debug('Moving existing label', $label); | ||||
|             } | ||||
|             else if( !module.has.label() ) { | ||||
|               $label = $('<label>').insertAfter($input); | ||||
|               module.debug('Creating label', $label); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         has: { | ||||
|           label: function() { | ||||
|             return ($label.length > 0); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         bind: { | ||||
|           events: function() { | ||||
|             module.verbose('Attaching checkbox events'); | ||||
|             $module | ||||
|               .on('click'   + eventNamespace, module.event.click) | ||||
|               .on('keydown' + eventNamespace, selector.input, module.event.keydown) | ||||
|               .on('keyup'   + eventNamespace, selector.input, module.event.keyup) | ||||
|             ; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         unbind: { | ||||
|           events: function() { | ||||
|             module.debug('Removing events'); | ||||
|             $module | ||||
|               .off(eventNamespace) | ||||
|             ; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         uncheckOthers: function() { | ||||
|           var | ||||
|             $radios = module.get.otherRadios() | ||||
|           ; | ||||
|           module.debug('Unchecking other radios', $radios); | ||||
|           $radios.removeClass(className.checked); | ||||
|         }, | ||||
|  | ||||
|         toggle: function() { | ||||
|           if( !module.can.change() ) { | ||||
|             if(!module.is.radio()) { | ||||
|               module.debug('Checkbox is read-only or disabled, ignoring toggle'); | ||||
|             } | ||||
|             return; | ||||
|           } | ||||
|           if( module.is.indeterminate() || module.is.unchecked() ) { | ||||
|             module.debug('Currently unchecked'); | ||||
|             module.check(); | ||||
|           } | ||||
|           else if( module.is.checked() && module.can.uncheck() ) { | ||||
|             module.debug('Currently checked'); | ||||
|             module.uncheck(); | ||||
|           } | ||||
|         }, | ||||
|         setting: function(name, value) { | ||||
|           module.debug('Changing setting', name, value); | ||||
|           if( $.isPlainObject(name) ) { | ||||
|             $.extend(true, settings, name); | ||||
|           } | ||||
|           else if(value !== undefined) { | ||||
|             if($.isPlainObject(settings[name])) { | ||||
|               $.extend(true, settings[name], value); | ||||
|             } | ||||
|             else { | ||||
|               settings[name] = value; | ||||
|             } | ||||
|           } | ||||
|           else { | ||||
|             return settings[name]; | ||||
|           } | ||||
|         }, | ||||
|         internal: function(name, value) { | ||||
|           if( $.isPlainObject(name) ) { | ||||
|             $.extend(true, module, name); | ||||
|           } | ||||
|           else if(value !== undefined) { | ||||
|             module[name] = value; | ||||
|           } | ||||
|           else { | ||||
|             return module[name]; | ||||
|           } | ||||
|         }, | ||||
|         debug: function() { | ||||
|           if(!settings.silent && settings.debug) { | ||||
|             if(settings.performance) { | ||||
|               module.performance.log(arguments); | ||||
|             } | ||||
|             else { | ||||
|               module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|               module.debug.apply(console, arguments); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         verbose: function() { | ||||
|           if(!settings.silent && settings.verbose && settings.debug) { | ||||
|             if(settings.performance) { | ||||
|               module.performance.log(arguments); | ||||
|             } | ||||
|             else { | ||||
|               module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|               module.verbose.apply(console, arguments); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         error: function() { | ||||
|           if(!settings.silent) { | ||||
|             module.error = Function.prototype.bind.call(console.error, console, settings.name + ':'); | ||||
|             module.error.apply(console, arguments); | ||||
|           } | ||||
|         }, | ||||
|         performance: { | ||||
|           log: function(message) { | ||||
|             var | ||||
|               currentTime, | ||||
|               executionTime, | ||||
|               previousTime | ||||
|             ; | ||||
|             if(settings.performance) { | ||||
|               currentTime   = new Date().getTime(); | ||||
|               previousTime  = time || currentTime; | ||||
|               executionTime = currentTime - previousTime; | ||||
|               time          = currentTime; | ||||
|               performance.push({ | ||||
|                 'Name'           : message[0], | ||||
|                 'Arguments'      : [].slice.call(message, 1) || '', | ||||
|                 'Element'        : element, | ||||
|                 'Execution Time' : executionTime | ||||
|               }); | ||||
|             } | ||||
|             clearTimeout(module.performance.timer); | ||||
|             module.performance.timer = setTimeout(module.performance.display, 500); | ||||
|           }, | ||||
|           display: function() { | ||||
|             var | ||||
|               title = settings.name + ':', | ||||
|               totalTime = 0 | ||||
|             ; | ||||
|             time = false; | ||||
|             clearTimeout(module.performance.timer); | ||||
|             $.each(performance, function(index, data) { | ||||
|               totalTime += data['Execution Time']; | ||||
|             }); | ||||
|             title += ' ' + totalTime + 'ms'; | ||||
|             if(moduleSelector) { | ||||
|               title += ' \'' + moduleSelector + '\''; | ||||
|             } | ||||
|             if( (console.group !== undefined || console.table !== undefined) && performance.length > 0) { | ||||
|               console.groupCollapsed(title); | ||||
|               if(console.table) { | ||||
|                 console.table(performance); | ||||
|               } | ||||
|               else { | ||||
|                 $.each(performance, function(index, data) { | ||||
|                   console.log(data['Name'] + ': ' + data['Execution Time']+'ms'); | ||||
|                 }); | ||||
|               } | ||||
|               console.groupEnd(); | ||||
|             } | ||||
|             performance = []; | ||||
|           } | ||||
|         }, | ||||
|         invoke: function(query, passedArguments, context) { | ||||
|           var | ||||
|             object = instance, | ||||
|             maxDepth, | ||||
|             found, | ||||
|             response | ||||
|           ; | ||||
|           passedArguments = passedArguments || queryArguments; | ||||
|           context         = element         || context; | ||||
|           if(typeof query == 'string' && object !== undefined) { | ||||
|             query    = query.split(/[\. ]/); | ||||
|             maxDepth = query.length - 1; | ||||
|             $.each(query, function(depth, value) { | ||||
|               var camelCaseValue = (depth != maxDepth) | ||||
|                 ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1) | ||||
|                 : query | ||||
|               ; | ||||
|               if( $.isPlainObject( object[camelCaseValue] ) && (depth != maxDepth) ) { | ||||
|                 object = object[camelCaseValue]; | ||||
|               } | ||||
|               else if( object[camelCaseValue] !== undefined ) { | ||||
|                 found = object[camelCaseValue]; | ||||
|                 return false; | ||||
|               } | ||||
|               else if( $.isPlainObject( object[value] ) && (depth != maxDepth) ) { | ||||
|                 object = object[value]; | ||||
|               } | ||||
|               else if( object[value] !== undefined ) { | ||||
|                 found = object[value]; | ||||
|                 return false; | ||||
|               } | ||||
|               else { | ||||
|                 module.error(error.method, query); | ||||
|                 return false; | ||||
|               } | ||||
|             }); | ||||
|           } | ||||
|           if ( $.isFunction( found ) ) { | ||||
|             response = found.apply(context, passedArguments); | ||||
|           } | ||||
|           else if(found !== undefined) { | ||||
|             response = found; | ||||
|           } | ||||
|           if($.isArray(returnedValue)) { | ||||
|             returnedValue.push(response); | ||||
|           } | ||||
|           else if(returnedValue !== undefined) { | ||||
|             returnedValue = [returnedValue, response]; | ||||
|           } | ||||
|           else if(response !== undefined) { | ||||
|             returnedValue = response; | ||||
|           } | ||||
|           return found; | ||||
|         } | ||||
|       }; | ||||
|  | ||||
|       if(methodInvoked) { | ||||
|         if(instance === undefined) { | ||||
|           module.initialize(); | ||||
|         } | ||||
|         module.invoke(query); | ||||
|       } | ||||
|       else { | ||||
|         if(instance !== undefined) { | ||||
|           instance.invoke('destroy'); | ||||
|         } | ||||
|         module.initialize(); | ||||
|       } | ||||
|     }) | ||||
|   ; | ||||
|  | ||||
|   return (returnedValue !== undefined) | ||||
|     ? returnedValue | ||||
|     : this | ||||
|   ; | ||||
| }; | ||||
|  | ||||
| $.fn.checkbox.settings = { | ||||
|  | ||||
|   name                : 'Checkbox', | ||||
|   namespace           : 'checkbox', | ||||
|  | ||||
|   silent              : false, | ||||
|   debug               : false, | ||||
|   verbose             : true, | ||||
|   performance         : true, | ||||
|  | ||||
|   // delegated event context | ||||
|   uncheckable         : 'auto', | ||||
|   fireOnInit          : false, | ||||
|  | ||||
|   onChange            : function(){}, | ||||
|  | ||||
|   beforeChecked       : function(){}, | ||||
|   beforeUnchecked     : function(){}, | ||||
|   beforeDeterminate   : function(){}, | ||||
|   beforeIndeterminate : function(){}, | ||||
|  | ||||
|   onChecked           : function(){}, | ||||
|   onUnchecked         : function(){}, | ||||
|  | ||||
|   onDeterminate       : function() {}, | ||||
|   onIndeterminate     : function() {}, | ||||
|  | ||||
|   onEnable            : function(){}, | ||||
|   onDisable           : function(){}, | ||||
|  | ||||
|   // preserve misspelled callbacks (will be removed in 3.0) | ||||
|   onEnabled           : function(){}, | ||||
|   onDisabled          : function(){}, | ||||
|  | ||||
|   className       : { | ||||
|     checked       : 'checked', | ||||
|     indeterminate : 'indeterminate', | ||||
|     disabled      : 'disabled', | ||||
|     hidden        : 'hidden', | ||||
|     radio         : 'radio', | ||||
|     readOnly      : 'read-only' | ||||
|   }, | ||||
|  | ||||
|   error     : { | ||||
|     method       : 'The method you called is not defined' | ||||
|   }, | ||||
|  | ||||
|   selector : { | ||||
|     checkbox : '.ui.checkbox', | ||||
|     label    : 'label, .box', | ||||
|     input    : 'input[type="checkbox"], input[type="radio"]', | ||||
|     link     : 'a[href]' | ||||
|   } | ||||
|  | ||||
| }; | ||||
|  | ||||
| })( jQuery, window, document ); | ||||
| @@ -1,598 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Checkbox | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'module'; | ||||
| @element : 'checkbox'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|            Checkbox | ||||
| *******************************/ | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|     Content | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.checkbox { | ||||
|   position: relative; | ||||
|   display: inline-block; | ||||
|   backface-visibility: hidden; | ||||
|   outline: none; | ||||
|   vertical-align: baseline; | ||||
|   font-style: normal; | ||||
|  | ||||
|   min-height: @checkboxSize; | ||||
|   font-size: @medium; | ||||
|   line-height: @checkboxLineHeight; | ||||
|   min-width: @checkboxSize; | ||||
| } | ||||
|  | ||||
| /* HTML Checkbox */ | ||||
| .ui.checkbox input[type="checkbox"], | ||||
| .ui.checkbox input[type="radio"] { | ||||
|   cursor: pointer; | ||||
|   position: absolute; | ||||
|   top: 0px; | ||||
|   left: 0px; | ||||
|   opacity: 0 !important; | ||||
|   outline: none; | ||||
|   z-index: 3; | ||||
|   width: @checkboxSize; | ||||
|   height: @checkboxSize; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|       Box | ||||
| ---------------*/ | ||||
|  | ||||
|  | ||||
| .ui.checkbox .box, | ||||
| .ui.checkbox label { | ||||
|   cursor: auto; | ||||
|   position: relative; | ||||
|   display: block; | ||||
|   padding-left: @labelDistance; | ||||
|   outline: none; | ||||
|   font-size: @labelFontSize; | ||||
| } | ||||
|  | ||||
| .ui.checkbox .box:before, | ||||
| .ui.checkbox label:before { | ||||
|   position: absolute; | ||||
|   top: 0px; | ||||
|   left: 0px; | ||||
|  | ||||
|   width: @checkboxSize; | ||||
|   height: @checkboxSize; | ||||
|   content: ''; | ||||
|  | ||||
|   background: @checkboxBackground; | ||||
|   border-radius: @checkboxBorderRadius; | ||||
|  | ||||
|   transition: @checkboxTransition; | ||||
|   border: @checkboxBorder; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Checkmark | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.checkbox .box:after, | ||||
| .ui.checkbox label:after { | ||||
|   position: absolute; | ||||
|   font-size: @checkboxCheckFontSize; | ||||
|   top: @checkboxCheckTop; | ||||
|   left: @checkboxCheckLeft; | ||||
|   width: @checkboxCheckSize; | ||||
|   height: @checkboxCheckSize; | ||||
|   text-align: center; | ||||
|  | ||||
|   opacity: 0; | ||||
|   color: @checkboxColor; | ||||
|   transition: @checkboxTransition; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|       Label | ||||
| ---------------*/ | ||||
|  | ||||
| /* Inside */ | ||||
| .ui.checkbox label, | ||||
| .ui.checkbox + label { | ||||
|   color: @labelColor; | ||||
|   transition: @labelTransition; | ||||
| } | ||||
|  | ||||
| /* Outside */ | ||||
| .ui.checkbox + label { | ||||
|   vertical-align: middle; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|            States | ||||
| *******************************/ | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|       Hover | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.checkbox .box:hover::before, | ||||
| .ui.checkbox label:hover::before { | ||||
|   background: @checkboxHoverBackground; | ||||
|   border-color: @checkboxHoverBorderColor; | ||||
| } | ||||
| .ui.checkbox label:hover, | ||||
| .ui.checkbox + label:hover { | ||||
|   color: @labelHoverColor; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|       Down | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.checkbox .box:active::before, | ||||
| .ui.checkbox label:active::before { | ||||
|   background: @checkboxPressedBackground; | ||||
|   border-color: @checkboxPressedBorderColor; | ||||
| } | ||||
| .ui.checkbox .box:active::after, | ||||
| .ui.checkbox label:active::after { | ||||
|   color: @checkboxPressedColor; | ||||
| } | ||||
| .ui.checkbox input:active ~ label { | ||||
|   color: @labelPressedColor; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Focus | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.checkbox input:focus ~ .box:before, | ||||
| .ui.checkbox input:focus ~ label:before { | ||||
|   background: @checkboxFocusBackground; | ||||
|   border-color: @checkboxFocusBorderColor; | ||||
| } | ||||
| .ui.checkbox input:focus ~ .box:after, | ||||
| .ui.checkbox input:focus ~ label:after { | ||||
|   color: @checkboxFocusCheckColor; | ||||
| } | ||||
| .ui.checkbox input:focus ~ label { | ||||
|   color: @labelFocusColor; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Active | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.checkbox input:checked ~ .box:before, | ||||
| .ui.checkbox input:checked ~ label:before { | ||||
|   background: @checkboxActiveBackground; | ||||
|   border-color: @checkboxActiveBorderColor; | ||||
| } | ||||
| .ui.checkbox input:checked ~ .box:after, | ||||
| .ui.checkbox input:checked ~ label:after { | ||||
|   opacity: @checkboxActiveCheckOpacity; | ||||
|   color: @checkboxActiveCheckColor; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|   Indeterminate | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.checkbox input:not([type=radio]):indeterminate ~ .box:before, | ||||
| .ui.checkbox input:not([type=radio]):indeterminate ~ label:before { | ||||
|   background: @checkboxIndeterminateBackground; | ||||
|   border-color: @checkboxIndeterminateBorderColor; | ||||
| } | ||||
| .ui.checkbox input:not([type=radio]):indeterminate ~ .box:after, | ||||
| .ui.checkbox input:not([type=radio]):indeterminate ~ label:after { | ||||
|   opacity: @checkboxIndeterminateCheckOpacity; | ||||
|   color: @checkboxIndeterminateCheckColor; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|   Active Focus | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.checkbox input:not([type=radio]):indeterminate:focus ~ .box:before, | ||||
| .ui.checkbox input:not([type=radio]):indeterminate:focus ~ label:before, | ||||
| .ui.checkbox input:checked:focus ~ .box:before, | ||||
| .ui.checkbox input:checked:focus ~ label:before  { | ||||
|   background: @checkboxActiveFocusBackground; | ||||
|   border-color: @checkboxActiveFocusBorderColor; | ||||
| } | ||||
| .ui.checkbox input:not([type=radio]):indeterminate:focus ~ .box:after, | ||||
| .ui.checkbox input:not([type=radio]):indeterminate:focus ~ label:after, | ||||
| .ui.checkbox input:checked:focus ~ .box:after, | ||||
| .ui.checkbox input:checked:focus ~ label:after { | ||||
|   color: @checkboxActiveFocusCheckColor; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|     Read-Only | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.read-only.checkbox, | ||||
| .ui.read-only.checkbox label { | ||||
|   cursor: default; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|      Disabled | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.disabled.checkbox .box:after, | ||||
| .ui.disabled.checkbox label, | ||||
| .ui.checkbox input[disabled] ~ .box:after, | ||||
| .ui.checkbox input[disabled] ~ label { | ||||
|   cursor: default !important; | ||||
|   opacity: @disabledCheckboxOpacity; | ||||
|   color: @disabledCheckboxLabelColor; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Hidden | ||||
| ---------------*/ | ||||
|  | ||||
| /* Initialized checkbox moves input below element | ||||
|  to prevent manually triggering */ | ||||
| .ui.checkbox input.hidden { | ||||
|   z-index: -1; | ||||
| } | ||||
|  | ||||
| /* Selectable Label */ | ||||
| .ui.checkbox input.hidden + label { | ||||
|   cursor: pointer; | ||||
|   user-select: none; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|              Types | ||||
| *******************************/ | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|      Radio | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.radio.checkbox { | ||||
|   min-height: @radioSize; | ||||
| } | ||||
|  | ||||
| .ui.radio.checkbox .box, | ||||
| .ui.radio.checkbox label { | ||||
|   padding-left: @radioLabelDistance; | ||||
| } | ||||
|  | ||||
| /* Box */ | ||||
| .ui.radio.checkbox .box:before, | ||||
| .ui.radio.checkbox label:before { | ||||
|   content: ''; | ||||
|   transform: none; | ||||
|  | ||||
|   width: @radioSize; | ||||
|   height: @radioSize; | ||||
|   border-radius: @circularRadius; | ||||
|   top: @radioTop; | ||||
|   left: @radioLeft; | ||||
| } | ||||
|  | ||||
| /* Bullet */ | ||||
| .ui.radio.checkbox .box:after, | ||||
| .ui.radio.checkbox label:after { | ||||
|   border: none; | ||||
|   content: '' !important; | ||||
|   width: @radioSize; | ||||
|   height: @radioSize; | ||||
|   line-height: @radioSize; | ||||
| } | ||||
|  | ||||
| /* Radio Checkbox */ | ||||
| .ui.radio.checkbox .box:after, | ||||
| .ui.radio.checkbox label:after { | ||||
|   top: @bulletTop; | ||||
|   left: @bulletLeft; | ||||
|   width: @radioSize; | ||||
|   height: @radioSize; | ||||
|   border-radius: @bulletRadius; | ||||
|   transform: scale(@bulletScale); | ||||
|   background-color: @bulletColor; | ||||
| } | ||||
|  | ||||
| /* Focus */ | ||||
| .ui.radio.checkbox input:focus ~ .box:before, | ||||
| .ui.radio.checkbox input:focus ~ label:before { | ||||
|   background-color: @radioFocusBackground; | ||||
| } | ||||
| .ui.radio.checkbox input:focus ~ .box:after, | ||||
| .ui.radio.checkbox input:focus ~ label:after { | ||||
|   background-color: @radioFocusBulletColor; | ||||
| } | ||||
|  | ||||
| /* Indeterminate */ | ||||
| .ui.radio.checkbox input:indeterminate ~ .box:after, | ||||
| .ui.radio.checkbox input:indeterminate ~ label:after { | ||||
|   opacity: 0; | ||||
| } | ||||
|  | ||||
| /* Active */ | ||||
| .ui.radio.checkbox input:checked ~ .box:before, | ||||
| .ui.radio.checkbox input:checked ~ label:before { | ||||
|   background-color: @radioActiveBackground; | ||||
| } | ||||
| .ui.radio.checkbox input:checked ~ .box:after, | ||||
| .ui.radio.checkbox input:checked ~ label:after { | ||||
|   background-color: @radioActiveBulletColor; | ||||
| } | ||||
|  | ||||
| /* Active Focus */ | ||||
| .ui.radio.checkbox input:focus:checked ~ .box:before, | ||||
| .ui.radio.checkbox input:focus:checked ~ label:before { | ||||
|   background-color: @radioActiveFocusBackground; | ||||
| } | ||||
| .ui.radio.checkbox input:focus:checked ~ .box:after, | ||||
| .ui.radio.checkbox input:focus:checked ~ label:after { | ||||
|   background-color: @radioActiveFocusBulletColor; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Slider | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.slider.checkbox { | ||||
|   min-height: @sliderHeight; | ||||
| } | ||||
|  | ||||
| /* Input */ | ||||
| .ui.slider.checkbox input { | ||||
|   width: @sliderWidth; | ||||
|   height: @sliderHeight; | ||||
| } | ||||
|  | ||||
| /* Label */ | ||||
| .ui.slider.checkbox .box, | ||||
| .ui.slider.checkbox label { | ||||
|   padding-left: @sliderLabelDistance; | ||||
|   line-height: @sliderLabelLineHeight; | ||||
|   color: @sliderOffLabelColor; | ||||
| } | ||||
|  | ||||
| /* Line */ | ||||
| .ui.slider.checkbox .box:before, | ||||
| .ui.slider.checkbox label:before { | ||||
|   display: block; | ||||
|   position: absolute; | ||||
|   content: ''; | ||||
|   transform: none; | ||||
|   border: none !important; | ||||
|   left: 0em; | ||||
|   z-index: 1; | ||||
|  | ||||
|   top: @sliderLineVerticalOffset; | ||||
|  | ||||
|   background-color: @sliderLineColor; | ||||
|   width: @sliderLineWidth; | ||||
|   height: @sliderLineHeight; | ||||
|  | ||||
|   transform: none; | ||||
|   border-radius: @sliderLineRadius; | ||||
|   transition: @sliderLineTransition; | ||||
|  | ||||
| } | ||||
|  | ||||
| /* Handle */ | ||||
| .ui.slider.checkbox .box:after, | ||||
| .ui.slider.checkbox label:after { | ||||
|   background: @handleBackground; | ||||
|   position: absolute; | ||||
|   content: '' !important; | ||||
|   opacity: 1; | ||||
|   z-index: 2; | ||||
|  | ||||
|   border: none; | ||||
|   box-shadow: @handleBoxShadow; | ||||
|   width: @sliderHandleSize; | ||||
|   height: @sliderHandleSize; | ||||
|   top: @sliderHandleOffset; | ||||
|   left: 0em; | ||||
|   transform: none; | ||||
|  | ||||
|   border-radius: @circularRadius; | ||||
|   transition: @sliderHandleTransition; | ||||
| } | ||||
|  | ||||
| /* Focus */ | ||||
| .ui.slider.checkbox input:focus ~ .box:before, | ||||
| .ui.slider.checkbox input:focus ~ label:before { | ||||
|   background-color: @toggleFocusColor; | ||||
|   border: none; | ||||
| } | ||||
|  | ||||
| /* Hover */ | ||||
| .ui.slider.checkbox .box:hover, | ||||
| .ui.slider.checkbox label:hover { | ||||
|   color: @sliderHoverLabelColor; | ||||
| } | ||||
| .ui.slider.checkbox .box:hover::before, | ||||
| .ui.slider.checkbox label:hover::before { | ||||
|   background: @sliderHoverLaneBackground; | ||||
| } | ||||
|  | ||||
| /* Active */ | ||||
| .ui.slider.checkbox input:checked ~ .box, | ||||
| .ui.slider.checkbox input:checked ~ label { | ||||
|   color: @sliderOnLabelColor !important; | ||||
| } | ||||
| .ui.slider.checkbox input:checked ~ .box:before, | ||||
| .ui.slider.checkbox input:checked ~ label:before { | ||||
|   background-color: @sliderOnLineColor !important; | ||||
| } | ||||
| .ui.slider.checkbox input:checked ~ .box:after, | ||||
| .ui.slider.checkbox input:checked ~ label:after { | ||||
|   left: @sliderTravelDistance; | ||||
| } | ||||
|  | ||||
| /* Active Focus */ | ||||
| .ui.slider.checkbox input:focus:checked ~ .box, | ||||
| .ui.slider.checkbox input:focus:checked ~ label { | ||||
|   color: @sliderOnFocusLabelColor !important; | ||||
| } | ||||
| .ui.slider.checkbox input:focus:checked ~ .box:before, | ||||
| .ui.slider.checkbox input:focus:checked ~ label:before { | ||||
|   background-color: @sliderOnFocusLineColor !important; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|      Toggle | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.toggle.checkbox { | ||||
|   min-height: @toggleHeight; | ||||
| } | ||||
|  | ||||
| /* Input */ | ||||
| .ui.toggle.checkbox input { | ||||
|   width: @toggleWidth; | ||||
|   height: @toggleHeight; | ||||
| } | ||||
|  | ||||
| /* Label */ | ||||
| .ui.toggle.checkbox .box, | ||||
| .ui.toggle.checkbox label { | ||||
|   min-height: @toggleHandleSize; | ||||
|   padding-left: @toggleLabelDistance; | ||||
|   color: @toggleOffLabelColor; | ||||
| } | ||||
| .ui.toggle.checkbox label { | ||||
|   padding-top: @toggleLabelOffset; | ||||
| } | ||||
|  | ||||
| /* Switch */ | ||||
| .ui.toggle.checkbox .box:before, | ||||
| .ui.toggle.checkbox label:before { | ||||
|   display: block; | ||||
|   position: absolute; | ||||
|   content: ''; | ||||
|   z-index: 1; | ||||
|   transform: none; | ||||
|   border: none; | ||||
|  | ||||
|   top: @toggleLaneVerticalOffset; | ||||
|  | ||||
|   background: @toggleLaneBackground; | ||||
|   box-shadow: @toggleLaneBoxShadow; | ||||
|   width: @toggleLaneWidth; | ||||
|   height: @toggleLaneHeight; | ||||
|   border-radius: @toggleHandleRadius; | ||||
| } | ||||
|  | ||||
| /* Handle */ | ||||
| .ui.toggle.checkbox .box:after, | ||||
| .ui.toggle.checkbox label:after { | ||||
|   background: @handleBackground; | ||||
|   position: absolute; | ||||
|   content: '' !important; | ||||
|   opacity: 1; | ||||
|   z-index: 2; | ||||
|  | ||||
|   border: none; | ||||
|   box-shadow: @handleBoxShadow; | ||||
|   width: @toggleHandleSize; | ||||
|   height: @toggleHandleSize; | ||||
|   top: @toggleHandleOffset; | ||||
|   left: 0em; | ||||
|  | ||||
|   border-radius: @circularRadius; | ||||
|   transition: @toggleHandleTransition; | ||||
| } | ||||
|  | ||||
| .ui.toggle.checkbox input ~ .box:after, | ||||
| .ui.toggle.checkbox input ~ label:after { | ||||
|   left: @toggleOffOffset; | ||||
|   box-shadow: @toggleOffHandleBoxShadow; | ||||
| } | ||||
|  | ||||
| /* Focus */ | ||||
| .ui.toggle.checkbox input:focus ~ .box:before, | ||||
| .ui.toggle.checkbox input:focus ~ label:before { | ||||
|   background-color: @toggleFocusColor; | ||||
|   border: none; | ||||
| } | ||||
|  | ||||
| /* Hover */ | ||||
| .ui.toggle.checkbox .box:hover::before, | ||||
| .ui.toggle.checkbox label:hover::before { | ||||
|   background-color: @toggleHoverColor; | ||||
|   border: none; | ||||
| } | ||||
|  | ||||
| /* Active */ | ||||
| .ui.toggle.checkbox input:checked ~ .box, | ||||
| .ui.toggle.checkbox input:checked ~ label { | ||||
|   color: @toggleOnLabelColor !important; | ||||
| } | ||||
| .ui.toggle.checkbox input:checked ~ .box:before, | ||||
| .ui.toggle.checkbox input:checked ~ label:before { | ||||
|   background-color: @toggleOnLaneColor !important; | ||||
| } | ||||
| .ui.toggle.checkbox input:checked ~ .box:after, | ||||
| .ui.toggle.checkbox input:checked ~ label:after { | ||||
|   left: @toggleOnOffset; | ||||
|   box-shadow: @toggleOnHandleBoxShadow; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Active Focus */ | ||||
| .ui.toggle.checkbox input:focus:checked ~ .box, | ||||
| .ui.toggle.checkbox input:focus:checked ~ label { | ||||
|   color: @toggleOnFocusLabelColor !important; | ||||
| } | ||||
| .ui.toggle.checkbox input:focus:checked ~ .box:before, | ||||
| .ui.toggle.checkbox input:focus:checked ~ label:before { | ||||
|   background-color: @toggleOnFocusLaneColor !important; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|             Variations | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|      Fitted | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.fitted.checkbox .box, | ||||
| .ui.fitted.checkbox label { | ||||
|   padding-left: 0em !important; | ||||
| } | ||||
|  | ||||
| .ui.fitted.toggle.checkbox, | ||||
| .ui.fitted.toggle.checkbox { | ||||
|   width: @toggleWidth; | ||||
| } | ||||
|  | ||||
| .ui.fitted.slider.checkbox, | ||||
| .ui.fitted.slider.checkbox { | ||||
|   width: @sliderWidth; | ||||
| } | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,733 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Dimmer | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| ;(function ($, window, document, undefined) { | ||||
|  | ||||
| 'use strict'; | ||||
|  | ||||
| window = (typeof window != 'undefined' && window.Math == Math) | ||||
|   ? window | ||||
|   : (typeof self != 'undefined' && self.Math == Math) | ||||
|     ? self | ||||
|     : Function('return this')() | ||||
| ; | ||||
|  | ||||
| $.fn.dimmer = function(parameters) { | ||||
|   var | ||||
|     $allModules     = $(this), | ||||
|  | ||||
|     time            = new Date().getTime(), | ||||
|     performance     = [], | ||||
|  | ||||
|     query           = arguments[0], | ||||
|     methodInvoked   = (typeof query == 'string'), | ||||
|     queryArguments  = [].slice.call(arguments, 1), | ||||
|  | ||||
|     returnedValue | ||||
|   ; | ||||
|  | ||||
|   $allModules | ||||
|     .each(function() { | ||||
|       var | ||||
|         settings        = ( $.isPlainObject(parameters) ) | ||||
|           ? $.extend(true, {}, $.fn.dimmer.settings, parameters) | ||||
|           : $.extend({}, $.fn.dimmer.settings), | ||||
|  | ||||
|         selector        = settings.selector, | ||||
|         namespace       = settings.namespace, | ||||
|         className       = settings.className, | ||||
|         error           = settings.error, | ||||
|  | ||||
|         eventNamespace  = '.' + namespace, | ||||
|         moduleNamespace = 'module-' + namespace, | ||||
|         moduleSelector  = $allModules.selector || '', | ||||
|  | ||||
|         clickEvent      = ('ontouchstart' in document.documentElement) | ||||
|           ? 'touchstart' | ||||
|           : 'click', | ||||
|  | ||||
|         $module = $(this), | ||||
|         $dimmer, | ||||
|         $dimmable, | ||||
|  | ||||
|         element   = this, | ||||
|         instance  = $module.data(moduleNamespace), | ||||
|         module | ||||
|       ; | ||||
|  | ||||
|       module = { | ||||
|  | ||||
|         preinitialize: function() { | ||||
|           if( module.is.dimmer() ) { | ||||
|  | ||||
|             $dimmable = $module.parent(); | ||||
|             $dimmer   = $module; | ||||
|           } | ||||
|           else { | ||||
|             $dimmable = $module; | ||||
|             if( module.has.dimmer() ) { | ||||
|               if(settings.dimmerName) { | ||||
|                 $dimmer = $dimmable.find(selector.dimmer).filter('.' + settings.dimmerName); | ||||
|               } | ||||
|               else { | ||||
|                 $dimmer = $dimmable.find(selector.dimmer); | ||||
|               } | ||||
|             } | ||||
|             else { | ||||
|               $dimmer = module.create(); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         initialize: function() { | ||||
|           module.debug('Initializing dimmer', settings); | ||||
|  | ||||
|           module.bind.events(); | ||||
|           module.set.dimmable(); | ||||
|           module.instantiate(); | ||||
|         }, | ||||
|  | ||||
|         instantiate: function() { | ||||
|           module.verbose('Storing instance of module', module); | ||||
|           instance = module; | ||||
|           $module | ||||
|             .data(moduleNamespace, instance) | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         destroy: function() { | ||||
|           module.verbose('Destroying previous module', $dimmer); | ||||
|           module.unbind.events(); | ||||
|           module.remove.variation(); | ||||
|           $dimmable | ||||
|             .off(eventNamespace) | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         bind: { | ||||
|           events: function() { | ||||
|             if(settings.on == 'hover') { | ||||
|               $dimmable | ||||
|                 .on('mouseenter' + eventNamespace, module.show) | ||||
|                 .on('mouseleave' + eventNamespace, module.hide) | ||||
|               ; | ||||
|             } | ||||
|             else if(settings.on == 'click') { | ||||
|               $dimmable | ||||
|                 .on(clickEvent + eventNamespace, module.toggle) | ||||
|               ; | ||||
|             } | ||||
|             if( module.is.page() ) { | ||||
|               module.debug('Setting as a page dimmer', $dimmable); | ||||
|               module.set.pageDimmer(); | ||||
|             } | ||||
|  | ||||
|             if( module.is.closable() ) { | ||||
|               module.verbose('Adding dimmer close event', $dimmer); | ||||
|               $dimmable | ||||
|                 .on(clickEvent + eventNamespace, selector.dimmer, module.event.click) | ||||
|               ; | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         unbind: { | ||||
|           events: function() { | ||||
|             $module | ||||
|               .removeData(moduleNamespace) | ||||
|             ; | ||||
|             $dimmable | ||||
|               .off(eventNamespace) | ||||
|             ; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         event: { | ||||
|           click: function(event) { | ||||
|             module.verbose('Determining if event occured on dimmer', event); | ||||
|             if( $dimmer.find(event.target).length === 0 || $(event.target).is(selector.content) ) { | ||||
|               module.hide(); | ||||
|               event.stopImmediatePropagation(); | ||||
|             } | ||||
|           }, | ||||
|         }, | ||||
|  | ||||
|         addContent: function(element) { | ||||
|           var | ||||
|             $content = $(element) | ||||
|           ; | ||||
|           module.debug('Add content to dimmer', $content); | ||||
|           if($content.parent()[0] !== $dimmer[0]) { | ||||
|             $content.detach().appendTo($dimmer); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         create: function() { | ||||
|           var | ||||
|             $element = $( settings.template.dimmer() ) | ||||
|           ; | ||||
|           if(settings.dimmerName) { | ||||
|             module.debug('Creating named dimmer', settings.dimmerName); | ||||
|             $element.addClass(settings.dimmerName); | ||||
|           } | ||||
|           $element | ||||
|             .appendTo($dimmable) | ||||
|           ; | ||||
|           return $element; | ||||
|         }, | ||||
|  | ||||
|         show: function(callback) { | ||||
|           callback = $.isFunction(callback) | ||||
|             ? callback | ||||
|             : function(){} | ||||
|           ; | ||||
|           module.debug('Showing dimmer', $dimmer, settings); | ||||
|           module.set.variation(); | ||||
|           if( (!module.is.dimmed() || module.is.animating()) && module.is.enabled() ) { | ||||
|             module.animate.show(callback); | ||||
|             settings.onShow.call(element); | ||||
|             settings.onChange.call(element); | ||||
|           } | ||||
|           else { | ||||
|             module.debug('Dimmer is already shown or disabled'); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         hide: function(callback) { | ||||
|           callback = $.isFunction(callback) | ||||
|             ? callback | ||||
|             : function(){} | ||||
|           ; | ||||
|           if( module.is.dimmed() || module.is.animating() ) { | ||||
|             module.debug('Hiding dimmer', $dimmer); | ||||
|             module.animate.hide(callback); | ||||
|             settings.onHide.call(element); | ||||
|             settings.onChange.call(element); | ||||
|           } | ||||
|           else { | ||||
|             module.debug('Dimmer is not visible'); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         toggle: function() { | ||||
|           module.verbose('Toggling dimmer visibility', $dimmer); | ||||
|           if( !module.is.dimmed() ) { | ||||
|             module.show(); | ||||
|           } | ||||
|           else { | ||||
|             module.hide(); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         animate: { | ||||
|           show: function(callback) { | ||||
|             callback = $.isFunction(callback) | ||||
|               ? callback | ||||
|               : function(){} | ||||
|             ; | ||||
|             if(settings.useCSS && $.fn.transition !== undefined && $dimmer.transition('is supported')) { | ||||
|               if(settings.useFlex) { | ||||
|                 module.debug('Using flex dimmer'); | ||||
|                 module.remove.legacy(); | ||||
|               } | ||||
|               else { | ||||
|                 module.debug('Using legacy non-flex dimmer'); | ||||
|                 module.set.legacy(); | ||||
|               } | ||||
|               if(settings.opacity !== 'auto') { | ||||
|                 module.set.opacity(); | ||||
|               } | ||||
|               $dimmer | ||||
|                 .transition({ | ||||
|                   displayType : settings.useFlex | ||||
|                     ? 'flex' | ||||
|                     : 'block', | ||||
|                   animation   : settings.transition + ' in', | ||||
|                   queue       : false, | ||||
|                   duration    : module.get.duration(), | ||||
|                   useFailSafe : true, | ||||
|                   onStart     : function() { | ||||
|                     module.set.dimmed(); | ||||
|                   }, | ||||
|                   onComplete  : function() { | ||||
|                     module.set.active(); | ||||
|                     callback(); | ||||
|                   } | ||||
|                 }) | ||||
|               ; | ||||
|             } | ||||
|             else { | ||||
|               module.verbose('Showing dimmer animation with javascript'); | ||||
|               module.set.dimmed(); | ||||
|               if(settings.opacity == 'auto') { | ||||
|                 settings.opacity = 0.8; | ||||
|               } | ||||
|               $dimmer | ||||
|                 .stop() | ||||
|                 .css({ | ||||
|                   opacity : 0, | ||||
|                   width   : '100%', | ||||
|                   height  : '100%' | ||||
|                 }) | ||||
|                 .fadeTo(module.get.duration(), settings.opacity, function() { | ||||
|                   $dimmer.removeAttr('style'); | ||||
|                   module.set.active(); | ||||
|                   callback(); | ||||
|                 }) | ||||
|               ; | ||||
|             } | ||||
|           }, | ||||
|           hide: function(callback) { | ||||
|             callback = $.isFunction(callback) | ||||
|               ? callback | ||||
|               : function(){} | ||||
|             ; | ||||
|             if(settings.useCSS && $.fn.transition !== undefined && $dimmer.transition('is supported')) { | ||||
|               module.verbose('Hiding dimmer with css'); | ||||
|               $dimmer | ||||
|                 .transition({ | ||||
|                   displayType : settings.useFlex | ||||
|                     ? 'flex' | ||||
|                     : 'block', | ||||
|                   animation   : settings.transition + ' out', | ||||
|                   queue       : false, | ||||
|                   duration    : module.get.duration(), | ||||
|                   useFailSafe : true, | ||||
|                   onStart     : function() { | ||||
|                     module.remove.dimmed(); | ||||
|                   }, | ||||
|                   onComplete  : function() { | ||||
|                     module.remove.variation(); | ||||
|                     module.remove.active(); | ||||
|                     callback(); | ||||
|                   } | ||||
|                 }) | ||||
|               ; | ||||
|             } | ||||
|             else { | ||||
|               module.verbose('Hiding dimmer with javascript'); | ||||
|               module.remove.dimmed(); | ||||
|               $dimmer | ||||
|                 .stop() | ||||
|                 .fadeOut(module.get.duration(), function() { | ||||
|                   module.remove.active(); | ||||
|                   $dimmer.removeAttr('style'); | ||||
|                   callback(); | ||||
|                 }) | ||||
|               ; | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         get: { | ||||
|           dimmer: function() { | ||||
|             return $dimmer; | ||||
|           }, | ||||
|           duration: function() { | ||||
|             if(typeof settings.duration == 'object') { | ||||
|               if( module.is.active() ) { | ||||
|                 return settings.duration.hide; | ||||
|               } | ||||
|               else { | ||||
|                 return settings.duration.show; | ||||
|               } | ||||
|             } | ||||
|             return settings.duration; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         has: { | ||||
|           dimmer: function() { | ||||
|             if(settings.dimmerName) { | ||||
|               return ($module.find(selector.dimmer).filter('.' + settings.dimmerName).length > 0); | ||||
|             } | ||||
|             else { | ||||
|               return ( $module.find(selector.dimmer).length > 0 ); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         is: { | ||||
|           active: function() { | ||||
|             return $dimmer.hasClass(className.active); | ||||
|           }, | ||||
|           animating: function() { | ||||
|             return ( $dimmer.is(':animated') || $dimmer.hasClass(className.animating) ); | ||||
|           }, | ||||
|           closable: function() { | ||||
|             if(settings.closable == 'auto') { | ||||
|               if(settings.on == 'hover') { | ||||
|                 return false; | ||||
|               } | ||||
|               return true; | ||||
|             } | ||||
|             return settings.closable; | ||||
|           }, | ||||
|           dimmer: function() { | ||||
|             return $module.hasClass(className.dimmer); | ||||
|           }, | ||||
|           dimmable: function() { | ||||
|             return $module.hasClass(className.dimmable); | ||||
|           }, | ||||
|           dimmed: function() { | ||||
|             return $dimmable.hasClass(className.dimmed); | ||||
|           }, | ||||
|           disabled: function() { | ||||
|             return $dimmable.hasClass(className.disabled); | ||||
|           }, | ||||
|           enabled: function() { | ||||
|             return !module.is.disabled(); | ||||
|           }, | ||||
|           page: function () { | ||||
|             return $dimmable.is('body'); | ||||
|           }, | ||||
|           pageDimmer: function() { | ||||
|             return $dimmer.hasClass(className.pageDimmer); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         can: { | ||||
|           show: function() { | ||||
|             return !$dimmer.hasClass(className.disabled); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         set: { | ||||
|           opacity: function(opacity) { | ||||
|             var | ||||
|               color      = $dimmer.css('background-color'), | ||||
|               colorArray = color.split(','), | ||||
|               isRGB      = (colorArray && colorArray.length == 3), | ||||
|               isRGBA     = (colorArray && colorArray.length == 4) | ||||
|             ; | ||||
|             opacity    = settings.opacity === 0 ? 0 : settings.opacity || opacity; | ||||
|             if(isRGB || isRGBA) { | ||||
|               colorArray[3] = opacity + ')'; | ||||
|               color         = colorArray.join(','); | ||||
|             } | ||||
|             else { | ||||
|               color = 'rgba(0, 0, 0, ' + opacity + ')'; | ||||
|             } | ||||
|             module.debug('Setting opacity to', opacity); | ||||
|             $dimmer.css('background-color', color); | ||||
|           }, | ||||
|           legacy: function() { | ||||
|             $dimmer.addClass(className.legacy); | ||||
|           }, | ||||
|           active: function() { | ||||
|             $dimmer.addClass(className.active); | ||||
|           }, | ||||
|           dimmable: function() { | ||||
|             $dimmable.addClass(className.dimmable); | ||||
|           }, | ||||
|           dimmed: function() { | ||||
|             $dimmable.addClass(className.dimmed); | ||||
|           }, | ||||
|           pageDimmer: function() { | ||||
|             $dimmer.addClass(className.pageDimmer); | ||||
|           }, | ||||
|           disabled: function() { | ||||
|             $dimmer.addClass(className.disabled); | ||||
|           }, | ||||
|           variation: function(variation) { | ||||
|             variation = variation || settings.variation; | ||||
|             if(variation) { | ||||
|               $dimmer.addClass(variation); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         remove: { | ||||
|           active: function() { | ||||
|             $dimmer | ||||
|               .removeClass(className.active) | ||||
|             ; | ||||
|           }, | ||||
|           legacy: function() { | ||||
|             $dimmer.removeClass(className.legacy); | ||||
|           }, | ||||
|           dimmed: function() { | ||||
|             $dimmable.removeClass(className.dimmed); | ||||
|           }, | ||||
|           disabled: function() { | ||||
|             $dimmer.removeClass(className.disabled); | ||||
|           }, | ||||
|           variation: function(variation) { | ||||
|             variation = variation || settings.variation; | ||||
|             if(variation) { | ||||
|               $dimmer.removeClass(variation); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         setting: function(name, value) { | ||||
|           module.debug('Changing setting', name, value); | ||||
|           if( $.isPlainObject(name) ) { | ||||
|             $.extend(true, settings, name); | ||||
|           } | ||||
|           else if(value !== undefined) { | ||||
|             if($.isPlainObject(settings[name])) { | ||||
|               $.extend(true, settings[name], value); | ||||
|             } | ||||
|             else { | ||||
|               settings[name] = value; | ||||
|             } | ||||
|           } | ||||
|           else { | ||||
|             return settings[name]; | ||||
|           } | ||||
|         }, | ||||
|         internal: function(name, value) { | ||||
|           if( $.isPlainObject(name) ) { | ||||
|             $.extend(true, module, name); | ||||
|           } | ||||
|           else if(value !== undefined) { | ||||
|             module[name] = value; | ||||
|           } | ||||
|           else { | ||||
|             return module[name]; | ||||
|           } | ||||
|         }, | ||||
|         debug: function() { | ||||
|           if(!settings.silent && settings.debug) { | ||||
|             if(settings.performance) { | ||||
|               module.performance.log(arguments); | ||||
|             } | ||||
|             else { | ||||
|               module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|               module.debug.apply(console, arguments); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         verbose: function() { | ||||
|           if(!settings.silent && settings.verbose && settings.debug) { | ||||
|             if(settings.performance) { | ||||
|               module.performance.log(arguments); | ||||
|             } | ||||
|             else { | ||||
|               module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|               module.verbose.apply(console, arguments); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         error: function() { | ||||
|           if(!settings.silent) { | ||||
|             module.error = Function.prototype.bind.call(console.error, console, settings.name + ':'); | ||||
|             module.error.apply(console, arguments); | ||||
|           } | ||||
|         }, | ||||
|         performance: { | ||||
|           log: function(message) { | ||||
|             var | ||||
|               currentTime, | ||||
|               executionTime, | ||||
|               previousTime | ||||
|             ; | ||||
|             if(settings.performance) { | ||||
|               currentTime   = new Date().getTime(); | ||||
|               previousTime  = time || currentTime; | ||||
|               executionTime = currentTime - previousTime; | ||||
|               time          = currentTime; | ||||
|               performance.push({ | ||||
|                 'Name'           : message[0], | ||||
|                 'Arguments'      : [].slice.call(message, 1) || '', | ||||
|                 'Element'        : element, | ||||
|                 'Execution Time' : executionTime | ||||
|               }); | ||||
|             } | ||||
|             clearTimeout(module.performance.timer); | ||||
|             module.performance.timer = setTimeout(module.performance.display, 500); | ||||
|           }, | ||||
|           display: function() { | ||||
|             var | ||||
|               title = settings.name + ':', | ||||
|               totalTime = 0 | ||||
|             ; | ||||
|             time = false; | ||||
|             clearTimeout(module.performance.timer); | ||||
|             $.each(performance, function(index, data) { | ||||
|               totalTime += data['Execution Time']; | ||||
|             }); | ||||
|             title += ' ' + totalTime + 'ms'; | ||||
|             if(moduleSelector) { | ||||
|               title += ' \'' + moduleSelector + '\''; | ||||
|             } | ||||
|             if($allModules.length > 1) { | ||||
|               title += ' ' + '(' + $allModules.length + ')'; | ||||
|             } | ||||
|             if( (console.group !== undefined || console.table !== undefined) && performance.length > 0) { | ||||
|               console.groupCollapsed(title); | ||||
|               if(console.table) { | ||||
|                 console.table(performance); | ||||
|               } | ||||
|               else { | ||||
|                 $.each(performance, function(index, data) { | ||||
|                   console.log(data['Name'] + ': ' + data['Execution Time']+'ms'); | ||||
|                 }); | ||||
|               } | ||||
|               console.groupEnd(); | ||||
|             } | ||||
|             performance = []; | ||||
|           } | ||||
|         }, | ||||
|         invoke: function(query, passedArguments, context) { | ||||
|           var | ||||
|             object = instance, | ||||
|             maxDepth, | ||||
|             found, | ||||
|             response | ||||
|           ; | ||||
|           passedArguments = passedArguments || queryArguments; | ||||
|           context         = element         || context; | ||||
|           if(typeof query == 'string' && object !== undefined) { | ||||
|             query    = query.split(/[\. ]/); | ||||
|             maxDepth = query.length - 1; | ||||
|             $.each(query, function(depth, value) { | ||||
|               var camelCaseValue = (depth != maxDepth) | ||||
|                 ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1) | ||||
|                 : query | ||||
|               ; | ||||
|               if( $.isPlainObject( object[camelCaseValue] ) && (depth != maxDepth) ) { | ||||
|                 object = object[camelCaseValue]; | ||||
|               } | ||||
|               else if( object[camelCaseValue] !== undefined ) { | ||||
|                 found = object[camelCaseValue]; | ||||
|                 return false; | ||||
|               } | ||||
|               else if( $.isPlainObject( object[value] ) && (depth != maxDepth) ) { | ||||
|                 object = object[value]; | ||||
|               } | ||||
|               else if( object[value] !== undefined ) { | ||||
|                 found = object[value]; | ||||
|                 return false; | ||||
|               } | ||||
|               else { | ||||
|                 module.error(error.method, query); | ||||
|                 return false; | ||||
|               } | ||||
|             }); | ||||
|           } | ||||
|           if ( $.isFunction( found ) ) { | ||||
|             response = found.apply(context, passedArguments); | ||||
|           } | ||||
|           else if(found !== undefined) { | ||||
|             response = found; | ||||
|           } | ||||
|           if($.isArray(returnedValue)) { | ||||
|             returnedValue.push(response); | ||||
|           } | ||||
|           else if(returnedValue !== undefined) { | ||||
|             returnedValue = [returnedValue, response]; | ||||
|           } | ||||
|           else if(response !== undefined) { | ||||
|             returnedValue = response; | ||||
|           } | ||||
|           return found; | ||||
|         } | ||||
|       }; | ||||
|  | ||||
|       module.preinitialize(); | ||||
|  | ||||
|       if(methodInvoked) { | ||||
|         if(instance === undefined) { | ||||
|           module.initialize(); | ||||
|         } | ||||
|         module.invoke(query); | ||||
|       } | ||||
|       else { | ||||
|         if(instance !== undefined) { | ||||
|           instance.invoke('destroy'); | ||||
|         } | ||||
|         module.initialize(); | ||||
|       } | ||||
|     }) | ||||
|   ; | ||||
|  | ||||
|   return (returnedValue !== undefined) | ||||
|     ? returnedValue | ||||
|     : this | ||||
|   ; | ||||
| }; | ||||
|  | ||||
| $.fn.dimmer.settings = { | ||||
|  | ||||
|   name        : 'Dimmer', | ||||
|   namespace   : 'dimmer', | ||||
|  | ||||
|   silent      : false, | ||||
|   debug       : false, | ||||
|   verbose     : false, | ||||
|   performance : true, | ||||
|  | ||||
|   // whether should use flex layout | ||||
|   useFlex     : true, | ||||
|  | ||||
|   // name to distinguish between multiple dimmers in context | ||||
|   dimmerName  : false, | ||||
|  | ||||
|   // whether to add a variation type | ||||
|   variation   : false, | ||||
|  | ||||
|   // whether to bind close events | ||||
|   closable    : 'auto', | ||||
|  | ||||
|   // whether to use css animations | ||||
|   useCSS      : true, | ||||
|  | ||||
|   // css animation to use | ||||
|   transition  : 'fade', | ||||
|  | ||||
|   // event to bind to | ||||
|   on          : false, | ||||
|  | ||||
|   // overriding opacity value | ||||
|   opacity     : 'auto', | ||||
|  | ||||
|   // transition durations | ||||
|   duration    : { | ||||
|     show : 500, | ||||
|     hide : 500 | ||||
|   }, | ||||
|  | ||||
|   onChange    : function(){}, | ||||
|   onShow      : function(){}, | ||||
|   onHide      : function(){}, | ||||
|  | ||||
|   error   : { | ||||
|     method   : 'The method you called is not defined.' | ||||
|   }, | ||||
|  | ||||
|   className : { | ||||
|     active     : 'active', | ||||
|     animating  : 'animating', | ||||
|     dimmable   : 'dimmable', | ||||
|     dimmed     : 'dimmed', | ||||
|     dimmer     : 'dimmer', | ||||
|     disabled   : 'disabled', | ||||
|     hide       : 'hide', | ||||
|     legacy     : 'legacy', | ||||
|     pageDimmer : 'page', | ||||
|     show       : 'show' | ||||
|   }, | ||||
|  | ||||
|   selector: { | ||||
|     dimmer   : '> .ui.dimmer', | ||||
|     content  : '.ui.dimmer > .content, .ui.dimmer > .content > .center' | ||||
|   }, | ||||
|  | ||||
|   template: { | ||||
|     dimmer: function() { | ||||
|      return $('<div />').attr('class', 'ui dimmer'); | ||||
|     } | ||||
|   } | ||||
|  | ||||
| }; | ||||
|  | ||||
| })( jQuery, window, document ); | ||||
| @@ -1,231 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Dimmer | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'module'; | ||||
| @element : 'dimmer'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|             Dimmer | ||||
| *******************************/ | ||||
|  | ||||
| .dimmable:not(body) { | ||||
|   position: @dimmablePosition; | ||||
| } | ||||
|  | ||||
| .ui.dimmer { | ||||
|   display: none; | ||||
|   position: @dimmerPosition; | ||||
|   top: 0em !important; | ||||
|   left: 0em !important; | ||||
|  | ||||
|   width: 100%; | ||||
|   height: 100%; | ||||
|  | ||||
|   text-align: @textAlign; | ||||
|   vertical-align: @verticalAlign; | ||||
|   padding: @padding; | ||||
|  | ||||
|   background-color: @backgroundColor; | ||||
|   opacity: @hiddenOpacity; | ||||
|   line-height: @lineHeight; | ||||
|  | ||||
|   animation-fill-mode: both; | ||||
|   animation-duration: @duration; | ||||
|   transition: @transition; | ||||
|  | ||||
|   flex-direction: column; | ||||
|   align-items: center; | ||||
|   justify-content: center; | ||||
|  | ||||
|   user-select: none; | ||||
|   will-change: opacity; | ||||
|   z-index: @zIndex; | ||||
| } | ||||
|  | ||||
| /* Dimmer Content */ | ||||
| .ui.dimmer > .content { | ||||
|   user-select: text; | ||||
|   color: @textColor; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Loose Coupling */ | ||||
| .ui.segment > .ui.dimmer { | ||||
|   border-radius: inherit !important; | ||||
| } | ||||
|  | ||||
| /* Scrollbars */ | ||||
| .addScrollbars() when (@useCustomScrollbars) { | ||||
|   .ui.dimmer:not(.inverted)::-webkit-scrollbar-track { | ||||
|     background: @trackInvertedBackground; | ||||
|   } | ||||
|   .ui.dimmer:not(.inverted)::-webkit-scrollbar-thumb { | ||||
|     background: @thumbInvertedBackground; | ||||
|   } | ||||
|   .ui.dimmer:not(.inverted)::-webkit-scrollbar-thumb:window-inactive { | ||||
|     background: @thumbInvertedInactiveBackground; | ||||
|   } | ||||
|   .ui.dimmer:not(.inverted)::-webkit-scrollbar-thumb:hover { | ||||
|     background: @thumbInvertedHoverBackground; | ||||
|   } | ||||
| } | ||||
| .addScrollbars(); | ||||
|  | ||||
| /******************************* | ||||
|             States | ||||
| *******************************/ | ||||
|  | ||||
| /* Animating */ | ||||
| .animating.dimmable:not(body), | ||||
| .dimmed.dimmable:not(body) { | ||||
|   overflow: @overflow; | ||||
| } | ||||
|  | ||||
| /* Animating / Active / Visible */ | ||||
| .dimmed.dimmable > .ui.animating.dimmer, | ||||
| .dimmed.dimmable > .ui.visible.dimmer, | ||||
| .ui.active.dimmer { | ||||
|   display: flex; | ||||
|   opacity: @visibleOpacity; | ||||
| } | ||||
|  | ||||
| /* Disabled */ | ||||
| .ui.disabled.dimmer { | ||||
|   width: 0 !important; | ||||
|   height: 0 !important; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|            Variations | ||||
| *******************************/ | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|     Legacy | ||||
| ---------------*/ | ||||
|  | ||||
| /* Animating / Active / Visible */ | ||||
| .dimmed.dimmable > .ui.animating.legacy.dimmer, | ||||
| .dimmed.dimmable > .ui.visible.legacy.dimmer, | ||||
| .ui.active.legacy.dimmer { | ||||
|   display: block; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Alignment | ||||
| ---------------*/ | ||||
|  | ||||
| .ui[class*="top aligned"].dimmer { | ||||
|   justify-content: flex-start; | ||||
| } | ||||
| .ui[class*="bottom aligned"].dimmer { | ||||
|   justify-content: flex-end; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|       Page | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.page.dimmer { | ||||
|   position: @pageDimmerPosition; | ||||
|   transform-style: @transformStyle; | ||||
|   perspective: @perspective; | ||||
|   transform-origin: center center; | ||||
| } | ||||
|  | ||||
| body.animating.in.dimmable, | ||||
| body.dimmed.dimmable { | ||||
|   overflow: hidden; | ||||
| } | ||||
|  | ||||
| body.dimmable > .dimmer { | ||||
|   position: fixed; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Blurring | ||||
| ---------------*/ | ||||
|  | ||||
| .blurring.dimmable > :not(.dimmer) { | ||||
|   filter: @blurredStartFilter; | ||||
|   transition: @blurredTransition; | ||||
| } | ||||
| .blurring.dimmed.dimmable > :not(.dimmer) { | ||||
|   filter: @blurredEndFilter; | ||||
| } | ||||
|  | ||||
| /* Dimmer Color */ | ||||
| .blurring.dimmable > .dimmer { | ||||
|   background-color: @blurredBackgroundColor; | ||||
| } | ||||
| .blurring.dimmable > .inverted.dimmer { | ||||
|   background-color: @blurredInvertedBackgroundColor; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Aligned | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.dimmer > .top.aligned.content > * { | ||||
|   vertical-align: top; | ||||
| } | ||||
| .ui.dimmer > .bottom.aligned.content > * { | ||||
|   vertical-align: bottom; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Inverted | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.inverted.dimmer { | ||||
|   background-color: @invertedBackgroundColor; | ||||
| } | ||||
| .ui.inverted.dimmer > .content > * { | ||||
|   color: @invertedTextColor; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Simple | ||||
| ---------------*/ | ||||
|  | ||||
| /* Displays without javascript */ | ||||
| .ui.simple.dimmer { | ||||
|   display: block; | ||||
|   overflow: hidden; | ||||
|   opacity: 1; | ||||
|   width: 0%; | ||||
|   height: 0%; | ||||
|   z-index: -100; | ||||
|   background-color: @simpleStartBackgroundColor; | ||||
| } | ||||
| .dimmed.dimmable > .ui.simple.dimmer { | ||||
|   overflow: visible; | ||||
|   opacity: 1; | ||||
|   width: 100%; | ||||
|   height: 100%; | ||||
|   background-color: @simpleEndBackgroundColor; | ||||
|   z-index: @simpleZIndex; | ||||
| } | ||||
|  | ||||
| .ui.simple.inverted.dimmer { | ||||
|   background-color: @simpleInvertedStartBackgroundColor; | ||||
| } | ||||
| .dimmed.dimmable > .ui.simple.inverted.dimmer { | ||||
|   background-color: @simpleInvertedEndBackgroundColor; | ||||
| } | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,706 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Embed | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| ;(function ($, window, document, undefined) { | ||||
|  | ||||
| "use strict"; | ||||
|  | ||||
| window = (typeof window != 'undefined' && window.Math == Math) | ||||
|   ? window | ||||
|   : (typeof self != 'undefined' && self.Math == Math) | ||||
|     ? self | ||||
|     : Function('return this')() | ||||
| ; | ||||
|  | ||||
| $.fn.embed = function(parameters) { | ||||
|  | ||||
|   var | ||||
|     $allModules     = $(this), | ||||
|  | ||||
|     moduleSelector  = $allModules.selector || '', | ||||
|  | ||||
|     time            = new Date().getTime(), | ||||
|     performance     = [], | ||||
|  | ||||
|     query           = arguments[0], | ||||
|     methodInvoked   = (typeof query == 'string'), | ||||
|     queryArguments  = [].slice.call(arguments, 1), | ||||
|  | ||||
|     returnedValue | ||||
|   ; | ||||
|  | ||||
|   $allModules | ||||
|     .each(function() { | ||||
|       var | ||||
|         settings        = ( $.isPlainObject(parameters) ) | ||||
|           ? $.extend(true, {}, $.fn.embed.settings, parameters) | ||||
|           : $.extend({}, $.fn.embed.settings), | ||||
|  | ||||
|         selector        = settings.selector, | ||||
|         className       = settings.className, | ||||
|         sources         = settings.sources, | ||||
|         error           = settings.error, | ||||
|         metadata        = settings.metadata, | ||||
|         namespace       = settings.namespace, | ||||
|         templates       = settings.templates, | ||||
|  | ||||
|         eventNamespace  = '.' + namespace, | ||||
|         moduleNamespace = 'module-' + namespace, | ||||
|  | ||||
|         $window         = $(window), | ||||
|         $module         = $(this), | ||||
|         $placeholder    = $module.find(selector.placeholder), | ||||
|         $icon           = $module.find(selector.icon), | ||||
|         $embed          = $module.find(selector.embed), | ||||
|  | ||||
|         element         = this, | ||||
|         instance        = $module.data(moduleNamespace), | ||||
|         module | ||||
|       ; | ||||
|  | ||||
|       module = { | ||||
|  | ||||
|         initialize: function() { | ||||
|           module.debug('Initializing embed'); | ||||
|           module.determine.autoplay(); | ||||
|           module.create(); | ||||
|           module.bind.events(); | ||||
|           module.instantiate(); | ||||
|         }, | ||||
|  | ||||
|         instantiate: function() { | ||||
|           module.verbose('Storing instance of module', module); | ||||
|           instance = module; | ||||
|           $module | ||||
|             .data(moduleNamespace, module) | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         destroy: function() { | ||||
|           module.verbose('Destroying previous instance of embed'); | ||||
|           module.reset(); | ||||
|           $module | ||||
|             .removeData(moduleNamespace) | ||||
|             .off(eventNamespace) | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         refresh: function() { | ||||
|           module.verbose('Refreshing selector cache'); | ||||
|           $placeholder = $module.find(selector.placeholder); | ||||
|           $icon        = $module.find(selector.icon); | ||||
|           $embed       = $module.find(selector.embed); | ||||
|         }, | ||||
|  | ||||
|         bind: { | ||||
|           events: function() { | ||||
|             if( module.has.placeholder() ) { | ||||
|               module.debug('Adding placeholder events'); | ||||
|               $module | ||||
|                 .on('click' + eventNamespace, selector.placeholder, module.createAndShow) | ||||
|                 .on('click' + eventNamespace, selector.icon, module.createAndShow) | ||||
|               ; | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         create: function() { | ||||
|           var | ||||
|             placeholder = module.get.placeholder() | ||||
|           ; | ||||
|           if(placeholder) { | ||||
|             module.createPlaceholder(); | ||||
|           } | ||||
|           else { | ||||
|             module.createAndShow(); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         createPlaceholder: function(placeholder) { | ||||
|           var | ||||
|             icon  = module.get.icon(), | ||||
|             url   = module.get.url(), | ||||
|             embed = module.generate.embed(url) | ||||
|           ; | ||||
|           placeholder = placeholder || module.get.placeholder(); | ||||
|           $module.html( templates.placeholder(placeholder, icon) ); | ||||
|           module.debug('Creating placeholder for embed', placeholder, icon); | ||||
|         }, | ||||
|  | ||||
|         createEmbed: function(url) { | ||||
|           module.refresh(); | ||||
|           url = url || module.get.url(); | ||||
|           $embed = $('<div/>') | ||||
|             .addClass(className.embed) | ||||
|             .html( module.generate.embed(url) ) | ||||
|             .appendTo($module) | ||||
|           ; | ||||
|           settings.onCreate.call(element, url); | ||||
|           module.debug('Creating embed object', $embed); | ||||
|         }, | ||||
|  | ||||
|         changeEmbed: function(url) { | ||||
|           $embed | ||||
|             .html( module.generate.embed(url) ) | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         createAndShow: function() { | ||||
|           module.createEmbed(); | ||||
|           module.show(); | ||||
|         }, | ||||
|  | ||||
|         // sets new embed | ||||
|         change: function(source, id, url) { | ||||
|           module.debug('Changing video to ', source, id, url); | ||||
|           $module | ||||
|             .data(metadata.source, source) | ||||
|             .data(metadata.id, id) | ||||
|           ; | ||||
|           if(url) { | ||||
|             $module.data(metadata.url, url); | ||||
|           } | ||||
|           else { | ||||
|             $module.removeData(metadata.url); | ||||
|           } | ||||
|           if(module.has.embed()) { | ||||
|             module.changeEmbed(); | ||||
|           } | ||||
|           else { | ||||
|             module.create(); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         // clears embed | ||||
|         reset: function() { | ||||
|           module.debug('Clearing embed and showing placeholder'); | ||||
|           module.remove.data(); | ||||
|           module.remove.active(); | ||||
|           module.remove.embed(); | ||||
|           module.showPlaceholder(); | ||||
|           settings.onReset.call(element); | ||||
|         }, | ||||
|  | ||||
|         // shows current embed | ||||
|         show: function() { | ||||
|           module.debug('Showing embed'); | ||||
|           module.set.active(); | ||||
|           settings.onDisplay.call(element); | ||||
|         }, | ||||
|  | ||||
|         hide: function() { | ||||
|           module.debug('Hiding embed'); | ||||
|           module.showPlaceholder(); | ||||
|         }, | ||||
|  | ||||
|         showPlaceholder: function() { | ||||
|           module.debug('Showing placeholder image'); | ||||
|           module.remove.active(); | ||||
|           settings.onPlaceholderDisplay.call(element); | ||||
|         }, | ||||
|  | ||||
|         get: { | ||||
|           id: function() { | ||||
|             return settings.id || $module.data(metadata.id); | ||||
|           }, | ||||
|           placeholder: function() { | ||||
|             return settings.placeholder || $module.data(metadata.placeholder); | ||||
|           }, | ||||
|           icon: function() { | ||||
|             return (settings.icon) | ||||
|               ? settings.icon | ||||
|               : ($module.data(metadata.icon) !== undefined) | ||||
|                 ? $module.data(metadata.icon) | ||||
|                 : module.determine.icon() | ||||
|             ; | ||||
|           }, | ||||
|           source: function(url) { | ||||
|             return (settings.source) | ||||
|               ? settings.source | ||||
|               : ($module.data(metadata.source) !== undefined) | ||||
|                 ? $module.data(metadata.source) | ||||
|                 : module.determine.source() | ||||
|             ; | ||||
|           }, | ||||
|           type: function() { | ||||
|             var source = module.get.source(); | ||||
|             return (sources[source] !== undefined) | ||||
|               ? sources[source].type | ||||
|               : false | ||||
|             ; | ||||
|           }, | ||||
|           url: function() { | ||||
|             return (settings.url) | ||||
|               ? settings.url | ||||
|               : ($module.data(metadata.url) !== undefined) | ||||
|                 ? $module.data(metadata.url) | ||||
|                 : module.determine.url() | ||||
|             ; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         determine: { | ||||
|           autoplay: function() { | ||||
|             if(module.should.autoplay()) { | ||||
|               settings.autoplay = true; | ||||
|             } | ||||
|           }, | ||||
|           source: function(url) { | ||||
|             var | ||||
|               matchedSource = false | ||||
|             ; | ||||
|             url = url || module.get.url(); | ||||
|             if(url) { | ||||
|               $.each(sources, function(name, source) { | ||||
|                 if(url.search(source.domain) !== -1) { | ||||
|                   matchedSource = name; | ||||
|                   return false; | ||||
|                 } | ||||
|               }); | ||||
|             } | ||||
|             return matchedSource; | ||||
|           }, | ||||
|           icon: function() { | ||||
|             var | ||||
|               source = module.get.source() | ||||
|             ; | ||||
|             return (sources[source] !== undefined) | ||||
|               ? sources[source].icon | ||||
|               : false | ||||
|             ; | ||||
|           }, | ||||
|           url: function() { | ||||
|             var | ||||
|               id     = settings.id     || $module.data(metadata.id), | ||||
|               source = settings.source || $module.data(metadata.source), | ||||
|               url | ||||
|             ; | ||||
|             url = (sources[source] !== undefined) | ||||
|               ? sources[source].url.replace('{id}', id) | ||||
|               : false | ||||
|             ; | ||||
|             if(url) { | ||||
|               $module.data(metadata.url, url); | ||||
|             } | ||||
|             return url; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|  | ||||
|         set: { | ||||
|           active: function() { | ||||
|             $module.addClass(className.active); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         remove: { | ||||
|           data: function() { | ||||
|             $module | ||||
|               .removeData(metadata.id) | ||||
|               .removeData(metadata.icon) | ||||
|               .removeData(metadata.placeholder) | ||||
|               .removeData(metadata.source) | ||||
|               .removeData(metadata.url) | ||||
|             ; | ||||
|           }, | ||||
|           active: function() { | ||||
|             $module.removeClass(className.active); | ||||
|           }, | ||||
|           embed: function() { | ||||
|             $embed.empty(); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         encode: { | ||||
|           parameters: function(parameters) { | ||||
|             var | ||||
|               urlString = [], | ||||
|               index | ||||
|             ; | ||||
|             for (index in parameters) { | ||||
|               urlString.push( encodeURIComponent(index) + '=' + encodeURIComponent( parameters[index] ) ); | ||||
|             } | ||||
|             return urlString.join('&'); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         generate: { | ||||
|           embed: function(url) { | ||||
|             module.debug('Generating embed html'); | ||||
|             var | ||||
|               source = module.get.source(), | ||||
|               html, | ||||
|               parameters | ||||
|             ; | ||||
|             url = module.get.url(url); | ||||
|             if(url) { | ||||
|               parameters = module.generate.parameters(source); | ||||
|               html       = templates.iframe(url, parameters); | ||||
|             } | ||||
|             else { | ||||
|               module.error(error.noURL, $module); | ||||
|             } | ||||
|             return html; | ||||
|           }, | ||||
|           parameters: function(source, extraParameters) { | ||||
|             var | ||||
|               parameters = (sources[source] && sources[source].parameters !== undefined) | ||||
|                 ? sources[source].parameters(settings) | ||||
|                 : {} | ||||
|             ; | ||||
|             extraParameters = extraParameters || settings.parameters; | ||||
|             if(extraParameters) { | ||||
|               parameters = $.extend({}, parameters, extraParameters); | ||||
|             } | ||||
|             parameters = settings.onEmbed(parameters); | ||||
|             return module.encode.parameters(parameters); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         has: { | ||||
|           embed: function() { | ||||
|             return ($embed.length > 0); | ||||
|           }, | ||||
|           placeholder: function() { | ||||
|             return settings.placeholder || $module.data(metadata.placeholder); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         should: { | ||||
|           autoplay: function() { | ||||
|             return (settings.autoplay === 'auto') | ||||
|               ? (settings.placeholder || $module.data(metadata.placeholder) !== undefined) | ||||
|               : settings.autoplay | ||||
|             ; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         is: { | ||||
|           video: function() { | ||||
|             return module.get.type() == 'video'; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         setting: function(name, value) { | ||||
|           module.debug('Changing setting', name, value); | ||||
|           if( $.isPlainObject(name) ) { | ||||
|             $.extend(true, settings, name); | ||||
|           } | ||||
|           else if(value !== undefined) { | ||||
|             if($.isPlainObject(settings[name])) { | ||||
|               $.extend(true, settings[name], value); | ||||
|             } | ||||
|             else { | ||||
|               settings[name] = value; | ||||
|             } | ||||
|           } | ||||
|           else { | ||||
|             return settings[name]; | ||||
|           } | ||||
|         }, | ||||
|         internal: function(name, value) { | ||||
|           if( $.isPlainObject(name) ) { | ||||
|             $.extend(true, module, name); | ||||
|           } | ||||
|           else if(value !== undefined) { | ||||
|             module[name] = value; | ||||
|           } | ||||
|           else { | ||||
|             return module[name]; | ||||
|           } | ||||
|         }, | ||||
|         debug: function() { | ||||
|           if(!settings.silent && settings.debug) { | ||||
|             if(settings.performance) { | ||||
|               module.performance.log(arguments); | ||||
|             } | ||||
|             else { | ||||
|               module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|               module.debug.apply(console, arguments); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         verbose: function() { | ||||
|           if(!settings.silent && settings.verbose && settings.debug) { | ||||
|             if(settings.performance) { | ||||
|               module.performance.log(arguments); | ||||
|             } | ||||
|             else { | ||||
|               module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|               module.verbose.apply(console, arguments); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         error: function() { | ||||
|           if(!settings.silent) { | ||||
|             module.error = Function.prototype.bind.call(console.error, console, settings.name + ':'); | ||||
|             module.error.apply(console, arguments); | ||||
|           } | ||||
|         }, | ||||
|         performance: { | ||||
|           log: function(message) { | ||||
|             var | ||||
|               currentTime, | ||||
|               executionTime, | ||||
|               previousTime | ||||
|             ; | ||||
|             if(settings.performance) { | ||||
|               currentTime   = new Date().getTime(); | ||||
|               previousTime  = time || currentTime; | ||||
|               executionTime = currentTime - previousTime; | ||||
|               time          = currentTime; | ||||
|               performance.push({ | ||||
|                 'Name'           : message[0], | ||||
|                 'Arguments'      : [].slice.call(message, 1) || '', | ||||
|                 'Element'        : element, | ||||
|                 'Execution Time' : executionTime | ||||
|               }); | ||||
|             } | ||||
|             clearTimeout(module.performance.timer); | ||||
|             module.performance.timer = setTimeout(module.performance.display, 500); | ||||
|           }, | ||||
|           display: function() { | ||||
|             var | ||||
|               title = settings.name + ':', | ||||
|               totalTime = 0 | ||||
|             ; | ||||
|             time = false; | ||||
|             clearTimeout(module.performance.timer); | ||||
|             $.each(performance, function(index, data) { | ||||
|               totalTime += data['Execution Time']; | ||||
|             }); | ||||
|             title += ' ' + totalTime + 'ms'; | ||||
|             if(moduleSelector) { | ||||
|               title += ' \'' + moduleSelector + '\''; | ||||
|             } | ||||
|             if($allModules.length > 1) { | ||||
|               title += ' ' + '(' + $allModules.length + ')'; | ||||
|             } | ||||
|             if( (console.group !== undefined || console.table !== undefined) && performance.length > 0) { | ||||
|               console.groupCollapsed(title); | ||||
|               if(console.table) { | ||||
|                 console.table(performance); | ||||
|               } | ||||
|               else { | ||||
|                 $.each(performance, function(index, data) { | ||||
|                   console.log(data['Name'] + ': ' + data['Execution Time']+'ms'); | ||||
|                 }); | ||||
|               } | ||||
|               console.groupEnd(); | ||||
|             } | ||||
|             performance = []; | ||||
|           } | ||||
|         }, | ||||
|         invoke: function(query, passedArguments, context) { | ||||
|           var | ||||
|             object = instance, | ||||
|             maxDepth, | ||||
|             found, | ||||
|             response | ||||
|           ; | ||||
|           passedArguments = passedArguments || queryArguments; | ||||
|           context         = element         || context; | ||||
|           if(typeof query == 'string' && object !== undefined) { | ||||
|             query    = query.split(/[\. ]/); | ||||
|             maxDepth = query.length - 1; | ||||
|             $.each(query, function(depth, value) { | ||||
|               var camelCaseValue = (depth != maxDepth) | ||||
|                 ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1) | ||||
|                 : query | ||||
|               ; | ||||
|               if( $.isPlainObject( object[camelCaseValue] ) && (depth != maxDepth) ) { | ||||
|                 object = object[camelCaseValue]; | ||||
|               } | ||||
|               else if( object[camelCaseValue] !== undefined ) { | ||||
|                 found = object[camelCaseValue]; | ||||
|                 return false; | ||||
|               } | ||||
|               else if( $.isPlainObject( object[value] ) && (depth != maxDepth) ) { | ||||
|                 object = object[value]; | ||||
|               } | ||||
|               else if( object[value] !== undefined ) { | ||||
|                 found = object[value]; | ||||
|                 return false; | ||||
|               } | ||||
|               else { | ||||
|                 module.error(error.method, query); | ||||
|                 return false; | ||||
|               } | ||||
|             }); | ||||
|           } | ||||
|           if ( $.isFunction( found ) ) { | ||||
|             response = found.apply(context, passedArguments); | ||||
|           } | ||||
|           else if(found !== undefined) { | ||||
|             response = found; | ||||
|           } | ||||
|           if($.isArray(returnedValue)) { | ||||
|             returnedValue.push(response); | ||||
|           } | ||||
|           else if(returnedValue !== undefined) { | ||||
|             returnedValue = [returnedValue, response]; | ||||
|           } | ||||
|           else if(response !== undefined) { | ||||
|             returnedValue = response; | ||||
|           } | ||||
|           return found; | ||||
|         } | ||||
|       }; | ||||
|  | ||||
|       if(methodInvoked) { | ||||
|         if(instance === undefined) { | ||||
|           module.initialize(); | ||||
|         } | ||||
|         module.invoke(query); | ||||
|       } | ||||
|       else { | ||||
|         if(instance !== undefined) { | ||||
|           instance.invoke('destroy'); | ||||
|         } | ||||
|         module.initialize(); | ||||
|       } | ||||
|     }) | ||||
|   ; | ||||
|   return (returnedValue !== undefined) | ||||
|     ? returnedValue | ||||
|     : this | ||||
|   ; | ||||
| }; | ||||
|  | ||||
| $.fn.embed.settings = { | ||||
|  | ||||
|   name        : 'Embed', | ||||
|   namespace   : 'embed', | ||||
|  | ||||
|   silent      : false, | ||||
|   debug       : false, | ||||
|   verbose     : false, | ||||
|   performance : true, | ||||
|  | ||||
|   icon     : false, | ||||
|   source   : false, | ||||
|   url      : false, | ||||
|   id       : false, | ||||
|  | ||||
|   // standard video settings | ||||
|   autoplay  : 'auto', | ||||
|   color     : '#444444', | ||||
|   hd        : true, | ||||
|   brandedUI : false, | ||||
|  | ||||
|   // additional parameters to include with the embed | ||||
|   parameters: false, | ||||
|  | ||||
|   onDisplay            : function() {}, | ||||
|   onPlaceholderDisplay : function() {}, | ||||
|   onReset              : function() {}, | ||||
|   onCreate             : function(url) {}, | ||||
|   onEmbed              : function(parameters) { | ||||
|     return parameters; | ||||
|   }, | ||||
|  | ||||
|   metadata    : { | ||||
|     id          : 'id', | ||||
|     icon        : 'icon', | ||||
|     placeholder : 'placeholder', | ||||
|     source      : 'source', | ||||
|     url         : 'url' | ||||
|   }, | ||||
|  | ||||
|   error : { | ||||
|     noURL  : 'No URL specified', | ||||
|     method : 'The method you called is not defined' | ||||
|   }, | ||||
|  | ||||
|   className : { | ||||
|     active : 'active', | ||||
|     embed  : 'embed' | ||||
|   }, | ||||
|  | ||||
|   selector : { | ||||
|     embed       : '.embed', | ||||
|     placeholder : '.placeholder', | ||||
|     icon        : '.icon' | ||||
|   }, | ||||
|  | ||||
|   sources: { | ||||
|     youtube: { | ||||
|       name   : 'youtube', | ||||
|       type   : 'video', | ||||
|       icon   : 'video play', | ||||
|       domain : 'youtube.com', | ||||
|       url    : '//www.youtube.com/embed/{id}', | ||||
|       parameters: function(settings) { | ||||
|         return { | ||||
|           autohide       : !settings.brandedUI, | ||||
|           autoplay       : settings.autoplay, | ||||
|           color          : settings.color || undefined, | ||||
|           hq             : settings.hd, | ||||
|           jsapi          : settings.api, | ||||
|           modestbranding : !settings.brandedUI | ||||
|         }; | ||||
|       } | ||||
|     }, | ||||
|     vimeo: { | ||||
|       name   : 'vimeo', | ||||
|       type   : 'video', | ||||
|       icon   : 'video play', | ||||
|       domain : 'vimeo.com', | ||||
|       url    : '//player.vimeo.com/video/{id}', | ||||
|       parameters: function(settings) { | ||||
|         return { | ||||
|           api      : settings.api, | ||||
|           autoplay : settings.autoplay, | ||||
|           byline   : settings.brandedUI, | ||||
|           color    : settings.color || undefined, | ||||
|           portrait : settings.brandedUI, | ||||
|           title    : settings.brandedUI | ||||
|         }; | ||||
|       } | ||||
|     } | ||||
|   }, | ||||
|  | ||||
|   templates: { | ||||
|     iframe : function(url, parameters) { | ||||
|       var src = url; | ||||
|       if (parameters) { | ||||
|           src += '?' + parameters; | ||||
|       } | ||||
|       return '' | ||||
|         + '<iframe src="' + src + '"' | ||||
|         + ' width="100%" height="100%"' | ||||
|         + ' frameborder="0" scrolling="no" webkitAllowFullScreen mozallowfullscreen allowFullScreen></iframe>' | ||||
|       ; | ||||
|     }, | ||||
|     placeholder : function(image, icon) { | ||||
|       var | ||||
|         html = '' | ||||
|       ; | ||||
|       if(icon) { | ||||
|         html += '<i class="' + icon + ' icon"></i>'; | ||||
|       } | ||||
|       if(image) { | ||||
|         html += '<img class="placeholder" src="' + image + '">'; | ||||
|       } | ||||
|       return html; | ||||
|     } | ||||
|   }, | ||||
|  | ||||
|   // NOT YET IMPLEMENTED | ||||
|   api     : false, | ||||
|   onPause : function() {}, | ||||
|   onPlay  : function() {}, | ||||
|   onStop  : function() {} | ||||
|  | ||||
| }; | ||||
|  | ||||
|  | ||||
|  | ||||
| })( jQuery, window, document ); | ||||
| @@ -1,163 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Video | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'module'; | ||||
| @element : 'embed'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|             Types | ||||
| *******************************/ | ||||
|  | ||||
| .ui.embed { | ||||
|   position: relative; | ||||
|   position: relative; | ||||
|   max-width: 100%; | ||||
|   height: 0px; | ||||
|   overflow: hidden; | ||||
|   background: @background; | ||||
|   padding-bottom: @widescreenRatio; | ||||
| } | ||||
|  | ||||
| /*----------------- | ||||
|   Embedded Content | ||||
| ------------------*/ | ||||
|  | ||||
| .ui.embed iframe, | ||||
| .ui.embed embed, | ||||
| .ui.embed object { | ||||
|   position: absolute; | ||||
|   border: none; | ||||
|   width: 100%; | ||||
|   height: 100%; | ||||
|   top: 0px; | ||||
|   left: 0px; | ||||
|   margin: 0em; | ||||
|   padding: 0em; | ||||
| } | ||||
|  | ||||
| /*----------------- | ||||
|       Embed | ||||
| ------------------*/ | ||||
|  | ||||
| .ui.embed > .embed { | ||||
|   display: none; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|    Placeholder | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.embed > .placeholder { | ||||
|   position: absolute; | ||||
|   cursor: pointer; | ||||
|   top: 0px; | ||||
|   left: 0px; | ||||
|   display: block; | ||||
|   width: 100%; | ||||
|   height: 100%; | ||||
|   background-color: @placeholderBackground; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|       Icon | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.embed > .icon { | ||||
|   cursor: pointer; | ||||
|   position: absolute; | ||||
|   top: 0px; | ||||
|   left: 0px; | ||||
|   width: 100%; | ||||
|   height: 100%; | ||||
|   z-index: 2; | ||||
| } | ||||
| .ui.embed > .icon:after { | ||||
|   position: absolute; | ||||
|   top: 0%; | ||||
|   left: 0%; | ||||
|   width: 100%; | ||||
|   height: 100%; | ||||
|   z-index: 3; | ||||
|   content: ''; | ||||
|   background: @placeholderBackground; | ||||
|   opacity: @placeholderBackgroundOpacity; | ||||
|   transition: @placeholderBackgroundTransition; | ||||
| } | ||||
| .ui.embed > .icon:before { | ||||
|   position: absolute; | ||||
|   top: 50%; | ||||
|   left: 50%; | ||||
|   z-index: 4; | ||||
|   transform: translateX(-50%) translateY(-50%); | ||||
|  | ||||
|   color: @iconColor; | ||||
|   font-size: @iconSize; | ||||
|   text-shadow: @iconShadow; | ||||
|   transition: @iconTransition; | ||||
|   z-index: @iconZIndex; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|             States | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|      Hover | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.embed .icon:hover:after { | ||||
|   background: @hoverPlaceholderBackground; | ||||
|   opacity: @hoverPlaceholderBackgroundOpacity; | ||||
| } | ||||
| .ui.embed .icon:hover:before { | ||||
|   color: @hoverIconColor; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Active | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.active.embed > .icon, | ||||
| .ui.active.embed > .placeholder { | ||||
|   display: none; | ||||
| } | ||||
| .ui.active.embed > .embed { | ||||
|   display: block; | ||||
| } | ||||
|  | ||||
| .loadUIOverrides(); | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|           Variations | ||||
| *******************************/ | ||||
|  | ||||
| .ui.square.embed { | ||||
|   padding-bottom: @squareRatio; | ||||
| } | ||||
| .ui[class*="4:3"].embed { | ||||
|   padding-bottom: @standardRatio; | ||||
| } | ||||
| .ui[class*="16:9"].embed { | ||||
|   padding-bottom: @widescreenRatio; | ||||
| } | ||||
| .ui[class*="21:9"].embed { | ||||
|   padding-bottom: @ultraWidescreenRatio; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| @@ -1,591 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Modal | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'module'; | ||||
| @element : 'modal'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|              Modal | ||||
| *******************************/ | ||||
|  | ||||
| .ui.modal { | ||||
|   position: absolute; | ||||
|   display: none; | ||||
|   z-index: @zIndex; | ||||
|   text-align: left; | ||||
|  | ||||
|   background: @background; | ||||
|   border: @border; | ||||
|   box-shadow: @boxShadow; | ||||
|   transform-origin: @transformOrigin; | ||||
|  | ||||
|   flex: 0 0 auto; | ||||
|  | ||||
|   border-radius: @borderRadius; | ||||
|   user-select: text; | ||||
|   will-change: top, left, margin, transform, opacity; | ||||
| } | ||||
|  | ||||
| .ui.modal > :first-child:not(.icon), | ||||
| .ui.modal > .icon:first-child + * { | ||||
|   border-top-left-radius: @borderRadius; | ||||
|   border-top-right-radius: @borderRadius; | ||||
| } | ||||
|  | ||||
| .ui.modal > :last-child { | ||||
|   border-bottom-left-radius: @borderRadius; | ||||
|   border-bottom-right-radius: @borderRadius; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|             Content | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|      Close | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.modal > .close { | ||||
|   cursor: pointer; | ||||
|   position: absolute; | ||||
|   top: @closeTop; | ||||
|   right: @closeRight; | ||||
|   z-index: 1; | ||||
|  | ||||
|   opacity: @closeOpacity; | ||||
|   font-size: @closeSize; | ||||
|   color: @closeColor; | ||||
|  | ||||
|   width: @closeHitbox; | ||||
|   height: @closeHitbox; | ||||
|   padding: @closePadding; | ||||
| } | ||||
| .ui.modal > .close:hover { | ||||
|   opacity: 1; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Header | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.modal > .header { | ||||
|   display: block; | ||||
|   font-family: @headerFontFamily; | ||||
|   background: @headerBackground; | ||||
|   margin: @headerMargin; | ||||
|   padding: @headerPadding; | ||||
|   box-shadow: @headerBoxShadow; | ||||
|  | ||||
|   color: @headerColor; | ||||
|   border-bottom: @headerBorder; | ||||
| } | ||||
| .ui.modal > .header:not(.ui) { | ||||
|   font-size: @headerFontSize; | ||||
|   line-height: @headerLineHeight; | ||||
|   font-weight: @headerFontWeight; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Content | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.modal > .content { | ||||
|   display: block; | ||||
|   width: 100%; | ||||
|   font-size: @contentFontSize; | ||||
|   line-height: @contentLineHeight; | ||||
|   padding: @contentPadding; | ||||
|   background: @contentBackground; | ||||
| } | ||||
| .ui.modal > .image.content { | ||||
|   display: flex; | ||||
|   flex-direction: row; | ||||
| } | ||||
|  | ||||
| /* Image */ | ||||
| .ui.modal > .content > .image { | ||||
|   display: block; | ||||
|   flex: 0 1 auto; | ||||
|   width: @imageWidth; | ||||
|   align-self: @imageVerticalAlign; | ||||
| } | ||||
| .ui.modal > [class*="top aligned"] { | ||||
|   align-self: top; | ||||
| } | ||||
| .ui.modal > [class*="middle aligned"] { | ||||
|   align-self: middle; | ||||
| } | ||||
| .ui.modal > [class*="stretched"] { | ||||
|   align-self: stretch; | ||||
| } | ||||
|  | ||||
| /* Description */ | ||||
| .ui.modal > .content > .description { | ||||
|   display: block; | ||||
|   flex: 1 0 auto; | ||||
|   min-width: 0px; | ||||
|   align-self: @descriptionVerticalAlign; | ||||
| } | ||||
|  | ||||
| .ui.modal > .content > .icon + .description, | ||||
| .ui.modal > .content > .image + .description { | ||||
|   flex: 0 1 auto; | ||||
|   min-width: @descriptionMinWidth; | ||||
|   width: @descriptionWidth; | ||||
|   padding-left: @descriptionDistance; | ||||
| } | ||||
|  | ||||
| /*rtl:ignore*/ | ||||
| .ui.modal > .content > .image > i.icon { | ||||
|   margin: 0em; | ||||
|   opacity: 1; | ||||
|   width: auto; | ||||
|   line-height: 1; | ||||
|   font-size: @imageIconSize; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Actions | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.modal > .actions { | ||||
|   background: @actionBackground; | ||||
|   padding: @actionPadding; | ||||
|   border-top: @actionBorder; | ||||
|   text-align: @actionAlign; | ||||
| } | ||||
| .ui.modal .actions > .button { | ||||
|   margin-left: @buttonDistance; | ||||
| } | ||||
|  | ||||
| /*------------------- | ||||
|        Responsive | ||||
| --------------------*/ | ||||
|  | ||||
| /* Modal Width */ | ||||
| @media only screen and (max-width : @largestMobileScreen) { | ||||
|   .ui.modal { | ||||
|     width: @mobileWidth; | ||||
|     margin: @mobileMargin; | ||||
|   } | ||||
| } | ||||
| @media only screen and (min-width : @tabletBreakpoint) { | ||||
|   .ui.modal { | ||||
|     width: @tabletWidth; | ||||
|     margin: @tabletMargin; | ||||
|   } | ||||
| } | ||||
| @media only screen and (min-width : @computerBreakpoint) { | ||||
|   .ui.modal { | ||||
|     width: @computerWidth; | ||||
|     margin: @computerMargin; | ||||
|   } | ||||
| } | ||||
| @media only screen and (min-width : @largeMonitorBreakpoint) { | ||||
|   .ui.modal { | ||||
|     width: @largeMonitorWidth; | ||||
|     margin: @largeMonitorMargin; | ||||
|   } | ||||
| } | ||||
| @media only screen and (min-width : @widescreenMonitorBreakpoint) { | ||||
|   .ui.modal { | ||||
|     width: @widescreenMonitorWidth; | ||||
|     margin: @widescreenMonitorMargin; | ||||
|   } | ||||
| } | ||||
|  | ||||
| /* Tablet and Mobile */ | ||||
| @media only screen and (max-width : @largestTabletScreen) { | ||||
|   .ui.modal > .header { | ||||
|     padding-right: @closeHitbox; | ||||
|   } | ||||
|   .ui.modal > .close { | ||||
|     top: @innerCloseTop; | ||||
|     right: @innerCloseRight; | ||||
|     color: @innerCloseColor; | ||||
|   } | ||||
| } | ||||
|  | ||||
| /* Mobile */ | ||||
| @media only screen and (max-width : @largestMobileScreen) { | ||||
|  | ||||
|   .ui.modal > .header { | ||||
|     padding: @mobileHeaderPadding !important; | ||||
|     padding-right: @closeHitbox !important; | ||||
|   } | ||||
|   .ui.modal > .content { | ||||
|     display: block; | ||||
|     padding: @mobileContentPadding !important; | ||||
|   } | ||||
|   .ui.modal > .close { | ||||
|     top: @mobileCloseTop !important; | ||||
|     right: @mobileCloseRight !important; | ||||
|   } | ||||
|  | ||||
|   /*rtl:ignore*/ | ||||
|   .ui.modal .image.content { | ||||
|     flex-direction: column; | ||||
|   } | ||||
|   .ui.modal .content > .image { | ||||
|     display: block; | ||||
|     max-width: 100%; | ||||
|     margin: 0em auto !important; | ||||
|     text-align: center; | ||||
|     padding: @mobileImagePadding !important; | ||||
|   } | ||||
|   .ui.modal > .content > .image > i.icon { | ||||
|     font-size: @mobileImageIconSize; | ||||
|     text-align: center; | ||||
|   } | ||||
|  | ||||
|   /*rtl:ignore*/ | ||||
|   .ui.modal .content > .description { | ||||
|     display: block; | ||||
|     width: 100% !important; | ||||
|     margin: 0em !important; | ||||
|     padding: @mobileDescriptionPadding !important; | ||||
|     box-shadow: none; | ||||
|   } | ||||
|  | ||||
|   /* Let Buttons Stack */ | ||||
|   .ui.modal > .actions { | ||||
|     padding: @mobileActionPadding !important; | ||||
|   } | ||||
|   .ui.modal .actions > .buttons, | ||||
|   .ui.modal .actions > .button { | ||||
|     margin-bottom: @mobileButtonDistance; | ||||
|   } | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Coupling | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.inverted.dimmer > .ui.modal { | ||||
|   box-shadow: @invertedBoxShadow; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|              Types | ||||
| *******************************/ | ||||
|  | ||||
| .ui.basic.modal { | ||||
|   background-color: transparent; | ||||
|   border: none; | ||||
|   border-radius: 0em; | ||||
|   box-shadow: none !important; | ||||
|   color: @basicModalColor; | ||||
| } | ||||
| .ui.basic.modal > .header, | ||||
| .ui.basic.modal > .content, | ||||
| .ui.basic.modal > .actions { | ||||
|   background-color: transparent; | ||||
| } | ||||
| .ui.basic.modal > .header { | ||||
|   color: @basicModalHeaderColor; | ||||
| } | ||||
| .ui.basic.modal > .close { | ||||
|   top: @basicModalCloseTop; | ||||
|   right: @basicModalCloseRight; | ||||
| } | ||||
|  | ||||
| .ui.inverted.dimmer > .basic.modal { | ||||
|   color: @basicInvertedModalColor; | ||||
| } | ||||
| .ui.inverted.dimmer > .ui.basic.modal > .header { | ||||
|   color: @basicInvertedModalHeaderColor; | ||||
| } | ||||
|  | ||||
| /* Resort to margin positioning if legacy */ | ||||
| .ui.legacy.modal, | ||||
| .ui.legacy.page.dimmer > .ui.modal { | ||||
|   top: 50%; | ||||
|   left: 50%; | ||||
| } | ||||
|  | ||||
| .ui.legacy.page.dimmer > .ui.scrolling.modal, | ||||
| .ui.page.dimmer > .ui.scrolling.legacy.modal, | ||||
| .ui.top.aligned.legacy.page.dimmer > .ui.modal, | ||||
| .ui.top.aligned.dimmer > .ui.legacy.modal { | ||||
|   top: auto; | ||||
| } | ||||
|  | ||||
| /* Tablet and Mobile */ | ||||
| @media only screen and (max-width : @largestTabletScreen) { | ||||
|   .ui.basic.modal > .close { | ||||
|     color: @basicInnerCloseColor; | ||||
|   } | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|              States | ||||
| *******************************/ | ||||
|  | ||||
| .ui.loading.modal { | ||||
|   display: block; | ||||
|   visibility: hidden; | ||||
|   z-index: @loadingZIndex; | ||||
| } | ||||
|  | ||||
| .ui.active.modal { | ||||
|   display: block; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|            Variations | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|    Top Aligned | ||||
| ---------------*/ | ||||
|  | ||||
| /* Top Aligned Modal */ | ||||
| .modals.dimmer[class*="top aligned"] .modal { | ||||
|   margin: @topAlignedMargin auto; | ||||
| } | ||||
| @media only screen and (max-width : @largestMobileScreen) { | ||||
|   .modals.dimmer[class*="top aligned"] .modal { | ||||
|     margin: @mobileTopAlignedMargin auto; | ||||
|   } | ||||
| } | ||||
| /* Legacy Top Aligned */ | ||||
| .legacy.modals.dimmer[class*="top aligned"] { | ||||
|   padding-top: @topAlignedMargin; | ||||
| } | ||||
| @media only screen and (max-width : @largestMobileScreen) { | ||||
|   .legacy.modals.dimmer[class*="top aligned"] { | ||||
|     padding-top: @mobileTopAlignedMargin; | ||||
|   } | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Scrolling | ||||
| ---------------*/ | ||||
|  | ||||
| /* Scrolling Dimmer */ | ||||
| .scrolling.dimmable.dimmed { | ||||
|   overflow: hidden; | ||||
| } | ||||
| .scrolling.dimmable > .dimmer { | ||||
|   justify-content: flex-start; | ||||
| } | ||||
| .scrolling.dimmable.dimmed > .dimmer { | ||||
|   overflow: auto; | ||||
|   -webkit-overflow-scrolling: touch; | ||||
| } | ||||
| .scrolling.dimmable > .dimmer { | ||||
|   position: fixed; | ||||
| } | ||||
| .modals.dimmer .ui.scrolling.modal { | ||||
|   margin: @scrollingMargin auto; | ||||
| } | ||||
|  | ||||
| /* Undetached Scrolling */ | ||||
| .scrolling.undetached.dimmable.dimmed { | ||||
|   overflow: auto; | ||||
|   -webkit-overflow-scrolling: touch; | ||||
| } | ||||
| .scrolling.undetached.dimmable.dimmed > .dimmer { | ||||
|   overflow: hidden; | ||||
| } | ||||
| .scrolling.undetached.dimmable .ui.scrolling.modal { | ||||
|   position: absolute; | ||||
|   left: 50%; | ||||
|   margin-top: @scrollingMargin !important; | ||||
| } | ||||
|  | ||||
| /* Scrolling Content */ | ||||
| .ui.modal .scrolling.content { | ||||
|   max-height: @scrollingContentMaxHeight; | ||||
|   overflow: auto; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|    Full Screen | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.fullscreen.modal { | ||||
|   width: @fullScreenWidth !important; | ||||
|   margin: @fullScreenMargin; | ||||
| } | ||||
| .ui.fullscreen.modal > .header { | ||||
|   padding-right: @closeHitbox; | ||||
| } | ||||
| .ui.fullscreen.modal > .close { | ||||
|   top: @innerCloseTop; | ||||
|   right: @innerCloseRight; | ||||
|   color: @innerCloseColor; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|       Size | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.modal { | ||||
|   font-size: @medium; | ||||
| } | ||||
|  | ||||
| /* Mini */ | ||||
| .ui.mini.modal > .header:not(.ui) { | ||||
|   font-size: @miniHeaderSize; | ||||
| } | ||||
|  | ||||
| /* Mini Modal Width */ | ||||
| @media only screen and (max-width : @largestMobileScreen) { | ||||
|   .ui.mini.modal { | ||||
|     width: @miniMobileWidth; | ||||
|     margin: @miniMobileMargin; | ||||
|   } | ||||
| } | ||||
| @media only screen and (min-width : @tabletBreakpoint) { | ||||
|   .ui.mini.modal { | ||||
|     width: @miniTabletWidth; | ||||
|     margin: @miniTabletMargin; | ||||
|   } | ||||
| } | ||||
| @media only screen and (min-width : @computerBreakpoint) { | ||||
|   .ui.mini.modal { | ||||
|     width: @miniComputerWidth; | ||||
|     margin: @miniComputerMargin; | ||||
|   } | ||||
| } | ||||
| @media only screen and (min-width : @largeMonitorBreakpoint) { | ||||
|   .ui.mini.modal { | ||||
|     width: @miniLargeMonitorWidth; | ||||
|     margin: @miniLargeMonitorMargin; | ||||
|   } | ||||
| } | ||||
| @media only screen and (min-width : @widescreenMonitorBreakpoint) { | ||||
|   .ui.mini.modal { | ||||
|     width: @miniWidescreenMonitorWidth; | ||||
|     margin: @miniWidescreenMonitorMargin; | ||||
|   } | ||||
| } | ||||
|  | ||||
| /* mini */ | ||||
| .ui.small.modal > .header:not(.ui) { | ||||
|   font-size: @miniHeaderSize; | ||||
| } | ||||
|  | ||||
| /* Tiny Modal Width */ | ||||
| @media only screen and (max-width : @largestMobileScreen) { | ||||
|   .ui.tiny.modal { | ||||
|     width: @tinyMobileWidth; | ||||
|     margin: @tinyMobileMargin; | ||||
|   } | ||||
| } | ||||
| @media only screen and (min-width : @tabletBreakpoint) { | ||||
|   .ui.tiny.modal { | ||||
|     width: @tinyTabletWidth; | ||||
|     margin: @tinyTabletMargin; | ||||
|   } | ||||
| } | ||||
| @media only screen and (min-width : @computerBreakpoint) { | ||||
|   .ui.tiny.modal { | ||||
|     width: @tinyComputerWidth; | ||||
|     margin: @tinyComputerMargin; | ||||
|   } | ||||
| } | ||||
| @media only screen and (min-width : @largeMonitorBreakpoint) { | ||||
|   .ui.tiny.modal { | ||||
|     width: @tinyLargeMonitorWidth; | ||||
|     margin: @tinyLargeMonitorMargin; | ||||
|   } | ||||
| } | ||||
| @media only screen and (min-width : @widescreenMonitorBreakpoint) { | ||||
|   .ui.tiny.modal { | ||||
|     width: @tinyWidescreenMonitorWidth; | ||||
|     margin: @tinyWidescreenMonitorMargin; | ||||
|   } | ||||
| } | ||||
|  | ||||
| /* Small */ | ||||
| .ui.small.modal > .header:not(.ui) { | ||||
|   font-size: @smallHeaderSize; | ||||
| } | ||||
|  | ||||
| /* Small Modal Width */ | ||||
| @media only screen and (max-width : @largestMobileScreen) { | ||||
|   .ui.small.modal { | ||||
|     width: @smallMobileWidth; | ||||
|     margin: @smallMobileMargin; | ||||
|   } | ||||
| } | ||||
| @media only screen and (min-width : @tabletBreakpoint) { | ||||
|   .ui.small.modal { | ||||
|     width: @smallTabletWidth; | ||||
|     margin: @smallTabletMargin; | ||||
|   } | ||||
| } | ||||
| @media only screen and (min-width : @computerBreakpoint) { | ||||
|   .ui.small.modal { | ||||
|     width: @smallComputerWidth; | ||||
|     margin: @smallComputerMargin; | ||||
|   } | ||||
| } | ||||
| @media only screen and (min-width : @largeMonitorBreakpoint) { | ||||
|   .ui.small.modal { | ||||
|     width: @smallLargeMonitorWidth; | ||||
|     margin: @smallLargeMonitorMargin; | ||||
|   } | ||||
| } | ||||
| @media only screen and (min-width : @widescreenMonitorBreakpoint) { | ||||
|   .ui.small.modal { | ||||
|     width: @smallWidescreenMonitorWidth; | ||||
|     margin: @smallWidescreenMonitorMargin; | ||||
|   } | ||||
| } | ||||
|  | ||||
| /* Large Modal Width */ | ||||
| .ui.large.modal > .header { | ||||
|   font-size: @largeHeaderSize; | ||||
| } | ||||
| @media only screen and (max-width : @largestMobileScreen) { | ||||
|   .ui.large.modal { | ||||
|     width: @largeMobileWidth; | ||||
|     margin: @largeMobileMargin; | ||||
|   } | ||||
| } | ||||
| @media only screen and (min-width : @tabletBreakpoint) { | ||||
|   .ui.large.modal { | ||||
|     width: @largeTabletWidth; | ||||
|     margin: @largeTabletMargin; | ||||
|   } | ||||
| } | ||||
| @media only screen and (min-width : @computerBreakpoint) { | ||||
|   .ui.large.modal { | ||||
|     width: @largeComputerWidth; | ||||
|     margin: @largeComputerMargin; | ||||
|   } | ||||
| } | ||||
| @media only screen and (min-width : @largeMonitorBreakpoint) { | ||||
|   .ui.large.modal { | ||||
|     width: @largeLargeMonitorWidth; | ||||
|     margin: @largeLargeMonitorMargin; | ||||
|   } | ||||
| } | ||||
| @media only screen and (min-width : @widescreenMonitorBreakpoint) { | ||||
|   .ui.large.modal { | ||||
|     width: @largeWidescreenMonitorWidth; | ||||
|     margin: @largeWidescreenMonitorMargin; | ||||
|   } | ||||
| } | ||||
|  | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,507 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Nag | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| ;(function ($, window, document, undefined) { | ||||
|  | ||||
| 'use strict'; | ||||
|  | ||||
| window = (typeof window != 'undefined' && window.Math == Math) | ||||
|   ? window | ||||
|   : (typeof self != 'undefined' && self.Math == Math) | ||||
|     ? self | ||||
|     : Function('return this')() | ||||
| ; | ||||
|  | ||||
| $.fn.nag = function(parameters) { | ||||
|   var | ||||
|     $allModules    = $(this), | ||||
|     moduleSelector = $allModules.selector || '', | ||||
|  | ||||
|     time           = new Date().getTime(), | ||||
|     performance    = [], | ||||
|  | ||||
|     query          = arguments[0], | ||||
|     methodInvoked  = (typeof query == 'string'), | ||||
|     queryArguments = [].slice.call(arguments, 1), | ||||
|     returnedValue | ||||
|   ; | ||||
|   $allModules | ||||
|     .each(function() { | ||||
|       var | ||||
|         settings          = ( $.isPlainObject(parameters) ) | ||||
|           ? $.extend(true, {}, $.fn.nag.settings, parameters) | ||||
|           : $.extend({}, $.fn.nag.settings), | ||||
|  | ||||
|         className       = settings.className, | ||||
|         selector        = settings.selector, | ||||
|         error           = settings.error, | ||||
|         namespace       = settings.namespace, | ||||
|  | ||||
|         eventNamespace  = '.' + namespace, | ||||
|         moduleNamespace = namespace + '-module', | ||||
|  | ||||
|         $module         = $(this), | ||||
|  | ||||
|         $close          = $module.find(selector.close), | ||||
|         $context        = (settings.context) | ||||
|           ? $(settings.context) | ||||
|           : $('body'), | ||||
|  | ||||
|         element         = this, | ||||
|         instance        = $module.data(moduleNamespace), | ||||
|  | ||||
|         moduleOffset, | ||||
|         moduleHeight, | ||||
|  | ||||
|         contextWidth, | ||||
|         contextHeight, | ||||
|         contextOffset, | ||||
|  | ||||
|         yOffset, | ||||
|         yPosition, | ||||
|  | ||||
|         timer, | ||||
|         module, | ||||
|  | ||||
|         requestAnimationFrame = window.requestAnimationFrame | ||||
|           || window.mozRequestAnimationFrame | ||||
|           || window.webkitRequestAnimationFrame | ||||
|           || window.msRequestAnimationFrame | ||||
|           || function(callback) { setTimeout(callback, 0); } | ||||
|       ; | ||||
|       module = { | ||||
|  | ||||
|         initialize: function() { | ||||
|           module.verbose('Initializing element'); | ||||
|  | ||||
|           $module | ||||
|             .on('click' + eventNamespace, selector.close, module.dismiss) | ||||
|             .data(moduleNamespace, module) | ||||
|           ; | ||||
|  | ||||
|           if(settings.detachable && $module.parent()[0] !== $context[0]) { | ||||
|             $module | ||||
|               .detach() | ||||
|               .prependTo($context) | ||||
|             ; | ||||
|           } | ||||
|  | ||||
|           if(settings.displayTime > 0) { | ||||
|             setTimeout(module.hide, settings.displayTime); | ||||
|           } | ||||
|           module.show(); | ||||
|         }, | ||||
|  | ||||
|         destroy: function() { | ||||
|           module.verbose('Destroying instance'); | ||||
|           $module | ||||
|             .removeData(moduleNamespace) | ||||
|             .off(eventNamespace) | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         show: function() { | ||||
|           if( module.should.show() && !$module.is(':visible') ) { | ||||
|             module.debug('Showing nag', settings.animation.show); | ||||
|             if(settings.animation.show == 'fade') { | ||||
|               $module | ||||
|                 .fadeIn(settings.duration, settings.easing) | ||||
|               ; | ||||
|             } | ||||
|             else { | ||||
|               $module | ||||
|                 .slideDown(settings.duration, settings.easing) | ||||
|               ; | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         hide: function() { | ||||
|           module.debug('Showing nag', settings.animation.hide); | ||||
|           if(settings.animation.show == 'fade') { | ||||
|             $module | ||||
|               .fadeIn(settings.duration, settings.easing) | ||||
|             ; | ||||
|           } | ||||
|           else { | ||||
|             $module | ||||
|               .slideUp(settings.duration, settings.easing) | ||||
|             ; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         onHide: function() { | ||||
|           module.debug('Removing nag', settings.animation.hide); | ||||
|           $module.remove(); | ||||
|           if (settings.onHide) { | ||||
|             settings.onHide(); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         dismiss: function(event) { | ||||
|           if(settings.storageMethod) { | ||||
|             module.storage.set(settings.key, settings.value); | ||||
|           } | ||||
|           module.hide(); | ||||
|           event.stopImmediatePropagation(); | ||||
|           event.preventDefault(); | ||||
|         }, | ||||
|  | ||||
|         should: { | ||||
|           show: function() { | ||||
|             if(settings.persist) { | ||||
|               module.debug('Persistent nag is set, can show nag'); | ||||
|               return true; | ||||
|             } | ||||
|             if( module.storage.get(settings.key) != settings.value.toString() ) { | ||||
|               module.debug('Stored value is not set, can show nag', module.storage.get(settings.key)); | ||||
|               return true; | ||||
|             } | ||||
|             module.debug('Stored value is set, cannot show nag', module.storage.get(settings.key)); | ||||
|             return false; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         get: { | ||||
|           storageOptions: function() { | ||||
|             var | ||||
|               options = {} | ||||
|             ; | ||||
|             if(settings.expires) { | ||||
|               options.expires = settings.expires; | ||||
|             } | ||||
|             if(settings.domain) { | ||||
|               options.domain = settings.domain; | ||||
|             } | ||||
|             if(settings.path) { | ||||
|               options.path = settings.path; | ||||
|             } | ||||
|             return options; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         clear: function() { | ||||
|           module.storage.remove(settings.key); | ||||
|         }, | ||||
|  | ||||
|         storage: { | ||||
|           set: function(key, value) { | ||||
|             var | ||||
|               options = module.get.storageOptions() | ||||
|             ; | ||||
|             if(settings.storageMethod == 'localstorage' && window.localStorage !== undefined) { | ||||
|               window.localStorage.setItem(key, value); | ||||
|               module.debug('Value stored using local storage', key, value); | ||||
|             } | ||||
|             else if(settings.storageMethod == 'sessionstorage' && window.sessionStorage !== undefined) { | ||||
|               window.sessionStorage.setItem(key, value); | ||||
|               module.debug('Value stored using session storage', key, value); | ||||
|             } | ||||
|             else if($.cookie !== undefined) { | ||||
|               $.cookie(key, value, options); | ||||
|               module.debug('Value stored using cookie', key, value, options); | ||||
|             } | ||||
|             else { | ||||
|               module.error(error.noCookieStorage); | ||||
|               return; | ||||
|             } | ||||
|           }, | ||||
|           get: function(key, value) { | ||||
|             var | ||||
|               storedValue | ||||
|             ; | ||||
|             if(settings.storageMethod == 'localstorage' && window.localStorage !== undefined) { | ||||
|               storedValue = window.localStorage.getItem(key); | ||||
|             } | ||||
|             else if(settings.storageMethod == 'sessionstorage' && window.sessionStorage !== undefined) { | ||||
|               storedValue = window.sessionStorage.getItem(key); | ||||
|             } | ||||
|             // get by cookie | ||||
|             else if($.cookie !== undefined) { | ||||
|               storedValue = $.cookie(key); | ||||
|             } | ||||
|             else { | ||||
|               module.error(error.noCookieStorage); | ||||
|             } | ||||
|             if(storedValue == 'undefined' || storedValue == 'null' || storedValue === undefined || storedValue === null) { | ||||
|               storedValue = undefined; | ||||
|             } | ||||
|             return storedValue; | ||||
|           }, | ||||
|           remove: function(key) { | ||||
|             var | ||||
|               options = module.get.storageOptions() | ||||
|             ; | ||||
|             if(settings.storageMethod == 'localstorage' && window.localStorage !== undefined) { | ||||
|               window.localStorage.removeItem(key); | ||||
|             } | ||||
|             else if(settings.storageMethod == 'sessionstorage' && window.sessionStorage !== undefined) { | ||||
|               window.sessionStorage.removeItem(key); | ||||
|             } | ||||
|             // store by cookie | ||||
|             else if($.cookie !== undefined) { | ||||
|               $.removeCookie(key, options); | ||||
|             } | ||||
|             else { | ||||
|               module.error(error.noStorage); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         setting: function(name, value) { | ||||
|           module.debug('Changing setting', name, value); | ||||
|           if( $.isPlainObject(name) ) { | ||||
|             $.extend(true, settings, name); | ||||
|           } | ||||
|           else if(value !== undefined) { | ||||
|             if($.isPlainObject(settings[name])) { | ||||
|               $.extend(true, settings[name], value); | ||||
|             } | ||||
|             else { | ||||
|               settings[name] = value; | ||||
|             } | ||||
|           } | ||||
|           else { | ||||
|             return settings[name]; | ||||
|           } | ||||
|         }, | ||||
|         internal: function(name, value) { | ||||
|           if( $.isPlainObject(name) ) { | ||||
|             $.extend(true, module, name); | ||||
|           } | ||||
|           else if(value !== undefined) { | ||||
|             module[name] = value; | ||||
|           } | ||||
|           else { | ||||
|             return module[name]; | ||||
|           } | ||||
|         }, | ||||
|         debug: function() { | ||||
|           if(!settings.silent && settings.debug) { | ||||
|             if(settings.performance) { | ||||
|               module.performance.log(arguments); | ||||
|             } | ||||
|             else { | ||||
|               module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|               module.debug.apply(console, arguments); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         verbose: function() { | ||||
|           if(!settings.silent && settings.verbose && settings.debug) { | ||||
|             if(settings.performance) { | ||||
|               module.performance.log(arguments); | ||||
|             } | ||||
|             else { | ||||
|               module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|               module.verbose.apply(console, arguments); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         error: function() { | ||||
|           if(!settings.silent) { | ||||
|             module.error = Function.prototype.bind.call(console.error, console, settings.name + ':'); | ||||
|             module.error.apply(console, arguments); | ||||
|           } | ||||
|         }, | ||||
|         performance: { | ||||
|           log: function(message) { | ||||
|             var | ||||
|               currentTime, | ||||
|               executionTime, | ||||
|               previousTime | ||||
|             ; | ||||
|             if(settings.performance) { | ||||
|               currentTime   = new Date().getTime(); | ||||
|               previousTime  = time || currentTime; | ||||
|               executionTime = currentTime - previousTime; | ||||
|               time          = currentTime; | ||||
|               performance.push({ | ||||
|                 'Name'           : message[0], | ||||
|                 'Arguments'      : [].slice.call(message, 1) || '', | ||||
|                 'Element'        : element, | ||||
|                 'Execution Time' : executionTime | ||||
|               }); | ||||
|             } | ||||
|             clearTimeout(module.performance.timer); | ||||
|             module.performance.timer = setTimeout(module.performance.display, 500); | ||||
|           }, | ||||
|           display: function() { | ||||
|             var | ||||
|               title = settings.name + ':', | ||||
|               totalTime = 0 | ||||
|             ; | ||||
|             time = false; | ||||
|             clearTimeout(module.performance.timer); | ||||
|             $.each(performance, function(index, data) { | ||||
|               totalTime += data['Execution Time']; | ||||
|             }); | ||||
|             title += ' ' + totalTime + 'ms'; | ||||
|             if(moduleSelector) { | ||||
|               title += ' \'' + moduleSelector + '\''; | ||||
|             } | ||||
|             if( (console.group !== undefined || console.table !== undefined) && performance.length > 0) { | ||||
|               console.groupCollapsed(title); | ||||
|               if(console.table) { | ||||
|                 console.table(performance); | ||||
|               } | ||||
|               else { | ||||
|                 $.each(performance, function(index, data) { | ||||
|                   console.log(data['Name'] + ': ' + data['Execution Time']+'ms'); | ||||
|                 }); | ||||
|               } | ||||
|               console.groupEnd(); | ||||
|             } | ||||
|             performance = []; | ||||
|           } | ||||
|         }, | ||||
|         invoke: function(query, passedArguments, context) { | ||||
|           var | ||||
|             object = instance, | ||||
|             maxDepth, | ||||
|             found, | ||||
|             response | ||||
|           ; | ||||
|           passedArguments = passedArguments || queryArguments; | ||||
|           context         = element         || context; | ||||
|           if(typeof query == 'string' && object !== undefined) { | ||||
|             query    = query.split(/[\. ]/); | ||||
|             maxDepth = query.length - 1; | ||||
|             $.each(query, function(depth, value) { | ||||
|               var camelCaseValue = (depth != maxDepth) | ||||
|                 ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1) | ||||
|                 : query | ||||
|               ; | ||||
|               if( $.isPlainObject( object[camelCaseValue] ) && (depth != maxDepth) ) { | ||||
|                 object = object[camelCaseValue]; | ||||
|               } | ||||
|               else if( object[camelCaseValue] !== undefined ) { | ||||
|                 found = object[camelCaseValue]; | ||||
|                 return false; | ||||
|               } | ||||
|               else if( $.isPlainObject( object[value] ) && (depth != maxDepth) ) { | ||||
|                 object = object[value]; | ||||
|               } | ||||
|               else if( object[value] !== undefined ) { | ||||
|                 found = object[value]; | ||||
|                 return false; | ||||
|               } | ||||
|               else { | ||||
|                 module.error(error.method, query); | ||||
|                 return false; | ||||
|               } | ||||
|             }); | ||||
|           } | ||||
|           if ( $.isFunction( found ) ) { | ||||
|             response = found.apply(context, passedArguments); | ||||
|           } | ||||
|           else if(found !== undefined) { | ||||
|             response = found; | ||||
|           } | ||||
|           if($.isArray(returnedValue)) { | ||||
|             returnedValue.push(response); | ||||
|           } | ||||
|           else if(returnedValue !== undefined) { | ||||
|             returnedValue = [returnedValue, response]; | ||||
|           } | ||||
|           else if(response !== undefined) { | ||||
|             returnedValue = response; | ||||
|           } | ||||
|           return found; | ||||
|         } | ||||
|       }; | ||||
|  | ||||
|       if(methodInvoked) { | ||||
|         if(instance === undefined) { | ||||
|           module.initialize(); | ||||
|         } | ||||
|         module.invoke(query); | ||||
|       } | ||||
|       else { | ||||
|         if(instance !== undefined) { | ||||
|           instance.invoke('destroy'); | ||||
|         } | ||||
|         module.initialize(); | ||||
|       } | ||||
|     }) | ||||
|   ; | ||||
|  | ||||
|   return (returnedValue !== undefined) | ||||
|     ? returnedValue | ||||
|     : this | ||||
|   ; | ||||
| }; | ||||
|  | ||||
| $.fn.nag.settings = { | ||||
|  | ||||
|   name        : 'Nag', | ||||
|  | ||||
|   silent      : false, | ||||
|   debug       : false, | ||||
|   verbose     : false, | ||||
|   performance : true, | ||||
|  | ||||
|   namespace   : 'Nag', | ||||
|  | ||||
|   // allows cookie to be overridden | ||||
|   persist     : false, | ||||
|  | ||||
|   // set to zero to require manually dismissal, otherwise hides on its own | ||||
|   displayTime : 0, | ||||
|  | ||||
|   animation   : { | ||||
|     show : 'slide', | ||||
|     hide : 'slide' | ||||
|   }, | ||||
|  | ||||
|   context       : false, | ||||
|   detachable    : false, | ||||
|  | ||||
|   expires       : 30, | ||||
|   domain        : false, | ||||
|   path          : '/', | ||||
|  | ||||
|   // type of storage to use | ||||
|   storageMethod : 'cookie', | ||||
|  | ||||
|   // value to store in dismissed localstorage/cookie | ||||
|   key           : 'nag', | ||||
|   value         : 'dismiss', | ||||
|  | ||||
|   error: { | ||||
|     noCookieStorage : '$.cookie is not included. A storage solution is required.', | ||||
|     noStorage       : 'Neither $.cookie or store is defined. A storage solution is required for storing state', | ||||
|     method          : 'The method you called is not defined.' | ||||
|   }, | ||||
|  | ||||
|   className     : { | ||||
|     bottom : 'bottom', | ||||
|     fixed  : 'fixed' | ||||
|   }, | ||||
|  | ||||
|   selector      : { | ||||
|     close : '.close.icon' | ||||
|   }, | ||||
|  | ||||
|   speed         : 500, | ||||
|   easing        : 'easeOutQuad', | ||||
|  | ||||
|   onHide: function() {} | ||||
|  | ||||
| }; | ||||
|  | ||||
| // Adds easing | ||||
| $.extend( $.easing, { | ||||
|   easeOutQuad: function (x, t, b, c, d) { | ||||
|     return -c *(t/=d)*(t-2) + b; | ||||
|   } | ||||
| }); | ||||
|  | ||||
| })( jQuery, window, document ); | ||||
| @@ -1,158 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Nag | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'module'; | ||||
| @element : 'nag'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|              Nag | ||||
| *******************************/ | ||||
|  | ||||
| .ui.nag { | ||||
|   display: none; | ||||
|   opacity: @opacity; | ||||
|   position: @position; | ||||
|  | ||||
|   top: @top; | ||||
|   left: 0px; | ||||
|   z-index: @zIndex; | ||||
|  | ||||
|   min-height: @minHeight; | ||||
|   width: @width; | ||||
|  | ||||
|   margin: @margin; | ||||
|   padding: @padding; | ||||
|  | ||||
|   background: @background; | ||||
|   box-shadow: @boxShadow; | ||||
|  | ||||
|   font-size: @fontSize; | ||||
|   text-align: @textAlign; | ||||
|   color: @color; | ||||
|  | ||||
|   border-radius: @topBorderRadius; | ||||
|   transition: @transition; | ||||
| } | ||||
|  | ||||
| a.ui.nag { | ||||
|   cursor: pointer; | ||||
| } | ||||
|  | ||||
| .ui.nag > .title { | ||||
|   display: inline-block; | ||||
|   margin: @titleMargin; | ||||
|   color: @titleColor; | ||||
| } | ||||
|  | ||||
|  | ||||
| .ui.nag > .close.icon { | ||||
|   cursor: pointer; | ||||
|   opacity: @closeOpacity; | ||||
|  | ||||
|   position: absolute; | ||||
|   top: @closeTop; | ||||
|   right: @closeRight; | ||||
|  | ||||
|   font-size: @closeSize; | ||||
|  | ||||
|   margin: @closeMargin; | ||||
|   color: @closeColor; | ||||
|   transition: @closeTransition; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|              States | ||||
| *******************************/ | ||||
|  | ||||
| /* Hover */ | ||||
| .ui.nag:hover { | ||||
|   background: @nagHoverBackground; | ||||
|   opacity: @nagHoverOpacity; | ||||
| } | ||||
|  | ||||
| .ui.nag .close:hover { | ||||
|   opacity: @closeHoverOpacity; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|            Variations | ||||
| *******************************/ | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|      Static | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.overlay.nag { | ||||
|   position: absolute; | ||||
|   display: block; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Fixed | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.fixed.nag { | ||||
|   position: fixed; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Bottom | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.bottom.nags, | ||||
| .ui.bottom.nag { | ||||
|   border-radius: @bottomBorderRadius; | ||||
|   top: auto; | ||||
|   bottom: @bottom; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      White | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.inverted.nags .nag, | ||||
| .ui.inverted.nag { | ||||
|   background-color: @invertedBackground; | ||||
|   color: @darkTextColor; | ||||
| } | ||||
| .ui.inverted.nags .nag .close, | ||||
| .ui.inverted.nags .nag .title, | ||||
| .ui.inverted.nag .close, | ||||
| .ui.inverted.nag .title { | ||||
|   color: @lightTextColor; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|            Groups | ||||
| *******************************/ | ||||
|  | ||||
| .ui.nags .nag { | ||||
|   border-radius: @groupedBorderRadius !important; | ||||
| } | ||||
| .ui.nags .nag:last-child { | ||||
|   border-radius: @topBorderRadius; | ||||
| } | ||||
| .ui.bottom.nags .nag:last-child { | ||||
|   border-radius: @bottomBorderRadius; | ||||
| } | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,712 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Popup | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'module'; | ||||
| @element : 'popup'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Popup | ||||
| *******************************/ | ||||
|  | ||||
| .ui.popup { | ||||
|   display: none; | ||||
|   position: absolute; | ||||
|   top: 0px; | ||||
|   right: 0px; | ||||
|  | ||||
|   /* Fixes content being squished when inline (moz only) */ | ||||
|   min-width: min-content; | ||||
|   z-index: @zIndex; | ||||
|  | ||||
|   border: @border; | ||||
|   line-height: @lineHeight; | ||||
|   max-width: @maxWidth; | ||||
|   background: @background; | ||||
|  | ||||
|   padding: @verticalPadding @horizontalPadding; | ||||
|   font-weight: @fontWeight; | ||||
|   font-style: @fontStyle; | ||||
|   color: @color; | ||||
|  | ||||
|   border-radius: @borderRadius; | ||||
|   box-shadow: @boxShadow; | ||||
| } | ||||
| .ui.popup > .header { | ||||
|   padding: 0em; | ||||
|  | ||||
|   font-family: @headerFont; | ||||
|   font-size: @headerFontSize; | ||||
|   line-height: @headerLineHeight; | ||||
|   font-weight: @headerFontWeight; | ||||
| } | ||||
| .ui.popup > .header + .content { | ||||
|   padding-top: @headerDistance; | ||||
| } | ||||
|  | ||||
| .ui.popup:before { | ||||
|   position: absolute; | ||||
|   content: ''; | ||||
|   width: @arrowSize; | ||||
|   height: @arrowSize; | ||||
|  | ||||
|   background: @arrowBackground; | ||||
|   transform: rotate(45deg); | ||||
|  | ||||
|   z-index: @arrowZIndex; | ||||
|   box-shadow: @arrowBoxShadow; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|             Types | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|     Tooltip | ||||
| ---------------*/ | ||||
|  | ||||
| /* Content */ | ||||
| [data-tooltip] { | ||||
|   position: relative; | ||||
| } | ||||
|  | ||||
| /* Arrow */ | ||||
| [data-tooltip]:before { | ||||
|   pointer-events: none; | ||||
|   position: absolute; | ||||
|   content: ''; | ||||
|   font-size: @medium; | ||||
|   width: @arrowSize; | ||||
|   height: @arrowSize; | ||||
|  | ||||
|   background: @tooltipArrowBackground; | ||||
|   transform: rotate(45deg); | ||||
|  | ||||
|   z-index: @arrowZIndex; | ||||
|   box-shadow: @tooltipArrowBoxShadow; | ||||
| } | ||||
|  | ||||
| /* Popup */ | ||||
| [data-tooltip]:after { | ||||
|   pointer-events: none; | ||||
|   content: attr(data-tooltip); | ||||
|   position: absolute; | ||||
|   text-transform: none; | ||||
|   text-align: left; | ||||
|   white-space: nowrap; | ||||
|  | ||||
|   font-size: @tooltipFontSize; | ||||
|  | ||||
|   border: @tooltipBorder; | ||||
|   line-height: @tooltipLineHeight; | ||||
|   max-width: @tooltipMaxWidth; | ||||
|   background: @tooltipBackground; | ||||
|  | ||||
|   padding: @tooltipPadding; | ||||
|   font-weight: @tooltipFontWeight; | ||||
|   font-style: @tooltipFontStyle; | ||||
|   color: @tooltipColor; | ||||
|  | ||||
|   border-radius: @tooltipBorderRadius; | ||||
|   box-shadow: @tooltipBoxShadow; | ||||
|   z-index: @tooltipZIndex; | ||||
| } | ||||
|  | ||||
| /* Default Position (Top Center) */ | ||||
| [data-tooltip]:not([data-position]):before { | ||||
|   top: auto; | ||||
|   right: auto; | ||||
|   bottom: 100%; | ||||
|   left: 50%; | ||||
|   background: @tooltipArrowBottomBackground; | ||||
|   margin-left: @tooltipArrowHorizontalOffset; | ||||
|   margin-bottom: -@tooltipArrowVerticalOffset; | ||||
| } | ||||
| [data-tooltip]:not([data-position]):after { | ||||
|   left: 50%; | ||||
|   transform: translateX(-50%); | ||||
|   bottom: 100%; | ||||
|   margin-bottom: @tooltipDistanceAway; | ||||
| } | ||||
|  | ||||
| /* Animation */ | ||||
| [data-tooltip]:before, | ||||
| [data-tooltip]:after { | ||||
|   pointer-events: none; | ||||
|   visibility: hidden; | ||||
| } | ||||
| [data-tooltip]:before { | ||||
|   opacity: 0; | ||||
|   transform: rotate(45deg) scale(0) !important; | ||||
|   transform-origin: center top; | ||||
|   transition: | ||||
|     all @tooltipDuration @tooltipEasing | ||||
|   ; | ||||
| } | ||||
| [data-tooltip]:after { | ||||
|   opacity: 1; | ||||
|   transform-origin: center bottom; | ||||
|   transition: | ||||
|     all @tooltipDuration @tooltipEasing | ||||
|   ; | ||||
| } | ||||
| [data-tooltip]:hover:before, | ||||
| [data-tooltip]:hover:after { | ||||
|   visibility: visible; | ||||
|   pointer-events: auto; | ||||
| } | ||||
| [data-tooltip]:hover:before { | ||||
|   transform: rotate(45deg) scale(1) !important; | ||||
|   opacity: 1; | ||||
| } | ||||
|  | ||||
| /* Animation Position */ | ||||
| [data-tooltip]:after, | ||||
| [data-tooltip][data-position="top center"]:after, | ||||
| [data-tooltip][data-position="bottom center"]:after { | ||||
|   transform: translateX(-50%) scale(0) !important; | ||||
| } | ||||
| [data-tooltip]:hover:after, | ||||
| [data-tooltip][data-position="bottom center"]:hover:after { | ||||
|   transform: translateX(-50%) scale(1) !important; | ||||
| } | ||||
| [data-tooltip][data-position="left center"]:after, | ||||
| [data-tooltip][data-position="right center"]:after { | ||||
|   transform: translateY(-50%) scale(0) !important; | ||||
| } | ||||
| [data-tooltip][data-position="left center"]:hover:after, | ||||
| [data-tooltip][data-position="right center"]:hover:after { | ||||
|   transform: translateY(-50%) scale(1) !important; | ||||
| } | ||||
| [data-tooltip][data-position="top left"]:after, | ||||
| [data-tooltip][data-position="top right"]:after, | ||||
| [data-tooltip][data-position="bottom left"]:after, | ||||
| [data-tooltip][data-position="bottom right"]:after { | ||||
|   transform: scale(0) !important; | ||||
| } | ||||
| [data-tooltip][data-position="top left"]:hover:after, | ||||
| [data-tooltip][data-position="top right"]:hover:after, | ||||
| [data-tooltip][data-position="bottom left"]:hover:after, | ||||
| [data-tooltip][data-position="bottom right"]:hover:after { | ||||
|   transform: scale(1) !important; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|     Inverted | ||||
| ---------------*/ | ||||
|  | ||||
| /* Arrow */ | ||||
| [data-tooltip][data-inverted]:before { | ||||
|   box-shadow: none !important; | ||||
| } | ||||
|  | ||||
| /* Arrow Position */ | ||||
| [data-tooltip][data-inverted]:before { | ||||
|   background: @invertedArrowBottomBackground; | ||||
| } | ||||
|  | ||||
| /* Popup  */ | ||||
| [data-tooltip][data-inverted]:after { | ||||
|   background: @tooltipInvertedBackground; | ||||
|   color: @tooltipInvertedColor; | ||||
|   border: @tooltipInvertedBorder; | ||||
|   box-shadow: @tooltipInvertedBoxShadow; | ||||
| } | ||||
| [data-tooltip][data-inverted]:after .header { | ||||
|   background-color: @tooltipInvertedHeaderBackground; | ||||
|   color: @tooltipInvertedHeaderColor; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Position | ||||
| ---------------*/ | ||||
|  | ||||
| /* Top Center */ | ||||
| [data-position="top center"][data-tooltip]:after { | ||||
|   top: auto; | ||||
|   right: auto; | ||||
|   left: 50%; | ||||
|   bottom: 100%; | ||||
|   transform: translateX(-50%); | ||||
|   margin-bottom: @tooltipDistanceAway; | ||||
| } | ||||
| [data-position="top center"][data-tooltip]:before { | ||||
|   top: auto; | ||||
|   right: auto; | ||||
|   bottom: 100%; | ||||
|   left: 50%; | ||||
|   background: @tooltipArrowTopBackground; | ||||
|   margin-left: @tooltipArrowHorizontalOffset; | ||||
|   margin-bottom: -@tooltipArrowVerticalOffset; | ||||
| } | ||||
|  | ||||
| /* Top Left */ | ||||
| [data-position="top left"][data-tooltip]:after { | ||||
|   top: auto; | ||||
|   right: auto; | ||||
|   left: 0; | ||||
|   bottom: 100%; | ||||
|   margin-bottom: @tooltipDistanceAway; | ||||
| } | ||||
| [data-position="top left"][data-tooltip]:before { | ||||
|   top: auto; | ||||
|   right: auto; | ||||
|   bottom: 100%; | ||||
|   left: @arrowDistanceFromEdge; | ||||
|   margin-left: @tooltipArrowHorizontalOffset; | ||||
|   margin-bottom: -@tooltipArrowVerticalOffset; | ||||
| } | ||||
|  | ||||
| /* Top Right */ | ||||
| [data-position="top right"][data-tooltip]:after { | ||||
|   top: auto; | ||||
|   left: auto; | ||||
|   right: 0; | ||||
|   bottom: 100%; | ||||
|   margin-bottom: @tooltipDistanceAway; | ||||
| } | ||||
| [data-position="top right"][data-tooltip]:before { | ||||
|   top: auto; | ||||
|   left: auto; | ||||
|   bottom: 100%; | ||||
|   right: @arrowDistanceFromEdge; | ||||
|   margin-left: @tooltipArrowHorizontalOffset; | ||||
|   margin-bottom: -@tooltipArrowVerticalOffset; | ||||
| } | ||||
|  | ||||
|  | ||||
| /* Bottom Center */ | ||||
| [data-position="bottom center"][data-tooltip]:after { | ||||
|   bottom: auto; | ||||
|   right: auto; | ||||
|   left: 50%; | ||||
|   top: 100%; | ||||
|   transform: translateX(-50%); | ||||
|   margin-top: @tooltipDistanceAway; | ||||
| } | ||||
| [data-position="bottom center"][data-tooltip]:before { | ||||
|   bottom: auto; | ||||
|   right: auto; | ||||
|   top: 100%; | ||||
|   left: 50%; | ||||
|   margin-left: @tooltipArrowHorizontalOffset; | ||||
|   margin-top: -@tooltipArrowVerticalOffset; | ||||
| } | ||||
|  | ||||
| /* Bottom Left */ | ||||
| [data-position="bottom left"][data-tooltip]:after { | ||||
|   left: 0; | ||||
|   top: 100%; | ||||
|   margin-top: @tooltipDistanceAway; | ||||
| } | ||||
| [data-position="bottom left"][data-tooltip]:before { | ||||
|   bottom: auto; | ||||
|   right: auto; | ||||
|   top: 100%; | ||||
|   left: @arrowDistanceFromEdge; | ||||
|   margin-left: @tooltipArrowHorizontalOffset; | ||||
|   margin-top: -@tooltipArrowVerticalOffset; | ||||
| } | ||||
|  | ||||
| /* Bottom Right */ | ||||
| [data-position="bottom right"][data-tooltip]:after { | ||||
|   right: 0; | ||||
|   top: 100%; | ||||
|   margin-top: @tooltipDistanceAway; | ||||
| } | ||||
| [data-position="bottom right"][data-tooltip]:before { | ||||
|   bottom: auto; | ||||
|   left: auto; | ||||
|   top: 100%; | ||||
|   right: @arrowDistanceFromEdge; | ||||
|   margin-left: @tooltipArrowVerticalOffset; | ||||
|   margin-top: -@tooltipArrowHorizontalOffset; | ||||
| } | ||||
|  | ||||
| /* Left Center */ | ||||
| [data-position="left center"][data-tooltip]:after { | ||||
|   right: 100%; | ||||
|   top: 50%; | ||||
|   margin-right: @tooltipDistanceAway; | ||||
|   transform: translateY(-50%); | ||||
| } | ||||
| [data-position="left center"][data-tooltip]:before { | ||||
|   right: 100%; | ||||
|   top: 50%; | ||||
|   margin-top: @tooltipArrowVerticalOffset; | ||||
|   margin-right: @tooltipArrowHorizontalOffset; | ||||
| } | ||||
|  | ||||
| /* Right Center */ | ||||
| [data-position="right center"][data-tooltip]:after { | ||||
|   left: 100%; | ||||
|   top: 50%; | ||||
|   margin-left: @tooltipDistanceAway; | ||||
|   transform: translateY(-50%); | ||||
| } | ||||
| [data-position="right center"][data-tooltip]:before { | ||||
|   left: 100%; | ||||
|   top: 50%; | ||||
|   margin-top: @tooltipArrowHorizontalOffset; | ||||
|   margin-left: -@tooltipArrowVerticalOffset; | ||||
| } | ||||
|  | ||||
| /* Arrow */ | ||||
| [data-position~="bottom"][data-tooltip]:before { | ||||
|   background: @arrowTopBackground; | ||||
|   box-shadow: @bottomArrowBoxShadow; | ||||
| } | ||||
| [data-position="left center"][data-tooltip]:before { | ||||
|   background: @arrowCenterBackground; | ||||
|   box-shadow: @leftArrowBoxShadow; | ||||
| } | ||||
| [data-position="right center"][data-tooltip]:before { | ||||
|   background: @arrowCenterBackground; | ||||
|   box-shadow: @rightArrowBoxShadow; | ||||
| } | ||||
| [data-position~="top"][data-tooltip]:before { | ||||
|   background: @arrowBottomBackground; | ||||
| } | ||||
|  | ||||
| /* Inverted Arrow Color */ | ||||
| [data-inverted][data-position~="bottom"][data-tooltip]:before { | ||||
|   background: @invertedArrowTopBackground; | ||||
|   box-shadow: @bottomArrowBoxShadow; | ||||
| } | ||||
| [data-inverted][data-position="left center"][data-tooltip]:before { | ||||
|   background: @invertedArrowCenterBackground; | ||||
|   box-shadow: @leftArrowBoxShadow; | ||||
| } | ||||
| [data-inverted][data-position="right center"][data-tooltip]:before { | ||||
|   background: @invertedArrowCenterBackground; | ||||
|   box-shadow: @rightArrowBoxShadow; | ||||
| } | ||||
| [data-inverted][data-position~="top"][data-tooltip]:before { | ||||
|   background: @invertedArrowBottomBackground; | ||||
| } | ||||
|  | ||||
| [data-position~="bottom"][data-tooltip]:before { | ||||
|   transform-origin: center bottom; | ||||
| } | ||||
| [data-position~="bottom"][data-tooltip]:after { | ||||
|   transform-origin: center top; | ||||
| } | ||||
| [data-position="left center"][data-tooltip]:before { | ||||
|   transform-origin: top center; | ||||
| } | ||||
| [data-position="left center"][data-tooltip]:after { | ||||
|   transform-origin: right center; | ||||
| } | ||||
| [data-position="right center"][data-tooltip]:before { | ||||
|   transform-origin: right center; | ||||
| } | ||||
| [data-position="right center"][data-tooltip]:after { | ||||
|   transform-origin: left center; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Spacing | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.popup { | ||||
|   margin: 0em; | ||||
| } | ||||
|  | ||||
| /* Extending from Top */ | ||||
| .ui.top.popup { | ||||
|   margin: 0em 0em @popupDistanceAway; | ||||
| } | ||||
| .ui.top.left.popup { | ||||
|   transform-origin: left bottom; | ||||
| } | ||||
| .ui.top.center.popup { | ||||
|   transform-origin: center bottom; | ||||
| } | ||||
| .ui.top.right.popup { | ||||
|   transform-origin: right bottom; | ||||
| } | ||||
|  | ||||
| /* Extending from Vertical Center */ | ||||
| .ui.left.center.popup { | ||||
|   margin: 0em @popupDistanceAway 0em 0em; | ||||
|   transform-origin: right 50%; | ||||
| } | ||||
| .ui.right.center.popup { | ||||
|   margin: 0em 0em 0em @popupDistanceAway; | ||||
|   transform-origin: left 50%; | ||||
| } | ||||
|  | ||||
| /* Extending from Bottom */ | ||||
| .ui.bottom.popup { | ||||
|   margin: @popupDistanceAway 0em 0em; | ||||
| } | ||||
| .ui.bottom.left.popup { | ||||
|   transform-origin: left top; | ||||
| } | ||||
| .ui.bottom.center.popup { | ||||
|   transform-origin: center top; | ||||
| } | ||||
| .ui.bottom.right.popup { | ||||
|   transform-origin: right top; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Pointer | ||||
| ---------------*/ | ||||
|  | ||||
| /*--- Below ---*/ | ||||
| .ui.bottom.center.popup:before { | ||||
|   margin-left: @arrowOffset; | ||||
|   top: @arrowOffset; | ||||
|   left: 50%; | ||||
|   right: auto; | ||||
|   bottom: auto; | ||||
|   box-shadow: @bottomArrowBoxShadow; | ||||
| } | ||||
|  | ||||
| .ui.bottom.left.popup { | ||||
|   margin-left: @boxArrowOffset; | ||||
| } | ||||
| /*rtl:rename*/ | ||||
| .ui.bottom.left.popup:before { | ||||
|   top: @arrowOffset; | ||||
|   left: @arrowDistanceFromEdge; | ||||
|   right: auto; | ||||
|   bottom: auto; | ||||
|   margin-left: 0em; | ||||
|   box-shadow: @bottomArrowBoxShadow; | ||||
| } | ||||
|  | ||||
| .ui.bottom.right.popup { | ||||
|   margin-right: @boxArrowOffset; | ||||
| } | ||||
| /*rtl:rename*/ | ||||
| .ui.bottom.right.popup:before { | ||||
|   top: @arrowOffset; | ||||
|   right: @arrowDistanceFromEdge; | ||||
|   bottom: auto; | ||||
|   left: auto; | ||||
|   margin-left: 0em; | ||||
|   box-shadow: @bottomArrowBoxShadow; | ||||
| } | ||||
|  | ||||
| /*--- Above ---*/ | ||||
| .ui.top.center.popup:before { | ||||
|   top: auto; | ||||
|   right: auto; | ||||
|   bottom: @arrowOffset; | ||||
|   left: 50%; | ||||
|   margin-left: @arrowOffset; | ||||
| } | ||||
| .ui.top.left.popup { | ||||
|   margin-left: @boxArrowOffset; | ||||
| } | ||||
| /*rtl:rename*/ | ||||
| .ui.top.left.popup:before { | ||||
|   bottom: @arrowOffset; | ||||
|   left: @arrowDistanceFromEdge; | ||||
|   top: auto; | ||||
|   right: auto; | ||||
|   margin-left: 0em; | ||||
| } | ||||
| .ui.top.right.popup { | ||||
|   margin-right: @boxArrowOffset; | ||||
| } | ||||
| /*rtl:rename*/ | ||||
| .ui.top.right.popup:before { | ||||
|   bottom: @arrowOffset; | ||||
|   right: @arrowDistanceFromEdge; | ||||
|   top: auto; | ||||
|   left: auto; | ||||
|   margin-left: 0em; | ||||
| } | ||||
|  | ||||
| /*--- Left Center ---*/ | ||||
| /*rtl:rename*/ | ||||
| .ui.left.center.popup:before { | ||||
|   top: 50%; | ||||
|   right: @arrowOffset; | ||||
|   bottom: auto; | ||||
|   left: auto; | ||||
|   margin-top: @arrowOffset; | ||||
|   box-shadow: @leftArrowBoxShadow; | ||||
| } | ||||
|  | ||||
| /*--- Right Center  ---*/ | ||||
| /*rtl:rename*/ | ||||
| .ui.right.center.popup:before { | ||||
|   top: 50%; | ||||
|   left: @arrowOffset; | ||||
|   bottom: auto; | ||||
|   right: auto; | ||||
|   margin-top: @arrowOffset; | ||||
|   box-shadow: @rightArrowBoxShadow; | ||||
| } | ||||
|  | ||||
| /* Arrow Color By Location */ | ||||
| .ui.bottom.popup:before { | ||||
|   background: @arrowTopBackground; | ||||
| } | ||||
| .ui.right.center.popup:before, | ||||
| .ui.left.center.popup:before { | ||||
|   background: @arrowCenterBackground; | ||||
| } | ||||
| .ui.top.popup:before { | ||||
|   background: @arrowBottomBackground; | ||||
| } | ||||
|  | ||||
| /* Inverted Arrow Color */ | ||||
| .ui.inverted.bottom.popup:before { | ||||
|   background: @invertedArrowTopBackground; | ||||
| } | ||||
| .ui.inverted.right.center.popup:before, | ||||
| .ui.inverted.left.center.popup:before { | ||||
|   background: @invertedArrowCenterBackground; | ||||
| } | ||||
| .ui.inverted.top.popup:before { | ||||
|   background: @invertedArrowBottomBackground; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Coupling | ||||
| *******************************/ | ||||
|  | ||||
| /* Immediate Nested Grid */ | ||||
| .ui.popup > .ui.grid:not(.padded) { | ||||
|   width: @nestedGridWidth; | ||||
|   margin: @nestedGridMargin; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|             States | ||||
| *******************************/ | ||||
|  | ||||
| .ui.loading.popup { | ||||
|   display: block; | ||||
|   visibility: hidden; | ||||
|   z-index: @loadingZIndex; | ||||
| } | ||||
|  | ||||
| .ui.animating.popup, | ||||
| .ui.visible.popup { | ||||
|   display: block; | ||||
| } | ||||
|  | ||||
| .ui.visible.popup { | ||||
|   transform: translateZ(0px); | ||||
|   backface-visibility: hidden; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Variations | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|      Basic | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.basic.popup:before { | ||||
|   display: none; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|      Wide | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.wide.popup { | ||||
|   max-width: @wideWidth; | ||||
| } | ||||
| .ui[class*="very wide"].popup { | ||||
|   max-width: @veryWideWidth; | ||||
| } | ||||
|  | ||||
| @media only screen and (max-width: @largestMobileScreen) { | ||||
|   .ui.wide.popup, | ||||
|   .ui[class*="very wide"].popup { | ||||
|     max-width: @maxWidth; | ||||
|   } | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|      Fluid | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.fluid.popup { | ||||
|   width: 100%; | ||||
|   max-width: none; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|      Colors | ||||
| ---------------*/ | ||||
|  | ||||
| /* Inverted colors  */ | ||||
| .ui.inverted.popup { | ||||
|   background: @invertedBackground; | ||||
|   color: @invertedColor; | ||||
|   border: @invertedBorder; | ||||
|   box-shadow: @invertedBoxShadow; | ||||
| } | ||||
| .ui.inverted.popup .header { | ||||
|   background-color: @invertedHeaderBackground; | ||||
|   color: @invertedHeaderColor; | ||||
| } | ||||
| .ui.inverted.popup:before { | ||||
|   background-color: @invertedArrowColor; | ||||
|   box-shadow: none !important; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Flowing | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.flowing.popup { | ||||
|   max-width: none; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|      Sizes | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.mini.popup { | ||||
|   font-size: @mini; | ||||
| } | ||||
| .ui.tiny.popup { | ||||
|   font-size: @tiny; | ||||
| } | ||||
| .ui.small.popup { | ||||
|   font-size: @small; | ||||
| } | ||||
| .ui.popup { | ||||
|   font-size: @medium; | ||||
| } | ||||
| .ui.large.popup { | ||||
|   font-size: @large; | ||||
| } | ||||
| .ui.huge.popup { | ||||
|   font-size: @huge; | ||||
| } | ||||
|  | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,931 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Progress | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| ;(function ($, window, document, undefined) { | ||||
|  | ||||
| 'use strict'; | ||||
|  | ||||
| window = (typeof window != 'undefined' && window.Math == Math) | ||||
|   ? window | ||||
|   : (typeof self != 'undefined' && self.Math == Math) | ||||
|     ? self | ||||
|     : Function('return this')() | ||||
| ; | ||||
|  | ||||
| var | ||||
|   global = (typeof window != 'undefined' && window.Math == Math) | ||||
|     ? window | ||||
|     : (typeof self != 'undefined' && self.Math == Math) | ||||
|       ? self | ||||
|       : Function('return this')() | ||||
| ; | ||||
|  | ||||
| $.fn.progress = function(parameters) { | ||||
|   var | ||||
|     $allModules    = $(this), | ||||
|  | ||||
|     moduleSelector = $allModules.selector || '', | ||||
|  | ||||
|     time           = new Date().getTime(), | ||||
|     performance    = [], | ||||
|  | ||||
|     query          = arguments[0], | ||||
|     methodInvoked  = (typeof query == 'string'), | ||||
|     queryArguments = [].slice.call(arguments, 1), | ||||
|  | ||||
|     returnedValue | ||||
|   ; | ||||
|  | ||||
|   $allModules | ||||
|     .each(function() { | ||||
|       var | ||||
|         settings          = ( $.isPlainObject(parameters) ) | ||||
|           ? $.extend(true, {}, $.fn.progress.settings, parameters) | ||||
|           : $.extend({}, $.fn.progress.settings), | ||||
|  | ||||
|         className       = settings.className, | ||||
|         metadata        = settings.metadata, | ||||
|         namespace       = settings.namespace, | ||||
|         selector        = settings.selector, | ||||
|         error           = settings.error, | ||||
|  | ||||
|         eventNamespace  = '.' + namespace, | ||||
|         moduleNamespace = 'module-' + namespace, | ||||
|  | ||||
|         $module         = $(this), | ||||
|         $bar            = $(this).find(selector.bar), | ||||
|         $progress       = $(this).find(selector.progress), | ||||
|         $label          = $(this).find(selector.label), | ||||
|  | ||||
|         element         = this, | ||||
|         instance        = $module.data(moduleNamespace), | ||||
|  | ||||
|         animating = false, | ||||
|         transitionEnd, | ||||
|         module | ||||
|       ; | ||||
|  | ||||
|       module = { | ||||
|  | ||||
|         initialize: function() { | ||||
|           module.debug('Initializing progress bar', settings); | ||||
|  | ||||
|           module.set.duration(); | ||||
|           module.set.transitionEvent(); | ||||
|  | ||||
|           module.read.metadata(); | ||||
|           module.read.settings(); | ||||
|  | ||||
|           module.instantiate(); | ||||
|         }, | ||||
|  | ||||
|         instantiate: function() { | ||||
|           module.verbose('Storing instance of progress', module); | ||||
|           instance = module; | ||||
|           $module | ||||
|             .data(moduleNamespace, module) | ||||
|           ; | ||||
|         }, | ||||
|         destroy: function() { | ||||
|           module.verbose('Destroying previous progress for', $module); | ||||
|           clearInterval(instance.interval); | ||||
|           module.remove.state(); | ||||
|           $module.removeData(moduleNamespace); | ||||
|           instance = undefined; | ||||
|         }, | ||||
|  | ||||
|         reset: function() { | ||||
|           module.remove.nextValue(); | ||||
|           module.update.progress(0); | ||||
|         }, | ||||
|  | ||||
|         complete: function() { | ||||
|           if(module.percent === undefined || module.percent < 100) { | ||||
|             module.remove.progressPoll(); | ||||
|             module.set.percent(100); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         read: { | ||||
|           metadata: function() { | ||||
|             var | ||||
|               data = { | ||||
|                 percent : $module.data(metadata.percent), | ||||
|                 total   : $module.data(metadata.total), | ||||
|                 value   : $module.data(metadata.value) | ||||
|               } | ||||
|             ; | ||||
|             if(data.percent) { | ||||
|               module.debug('Current percent value set from metadata', data.percent); | ||||
|               module.set.percent(data.percent); | ||||
|             } | ||||
|             if(data.total) { | ||||
|               module.debug('Total value set from metadata', data.total); | ||||
|               module.set.total(data.total); | ||||
|             } | ||||
|             if(data.value) { | ||||
|               module.debug('Current value set from metadata', data.value); | ||||
|               module.set.value(data.value); | ||||
|               module.set.progress(data.value); | ||||
|             } | ||||
|           }, | ||||
|           settings: function() { | ||||
|             if(settings.total !== false) { | ||||
|               module.debug('Current total set in settings', settings.total); | ||||
|               module.set.total(settings.total); | ||||
|             } | ||||
|             if(settings.value !== false) { | ||||
|               module.debug('Current value set in settings', settings.value); | ||||
|               module.set.value(settings.value); | ||||
|               module.set.progress(module.value); | ||||
|             } | ||||
|             if(settings.percent !== false) { | ||||
|               module.debug('Current percent set in settings', settings.percent); | ||||
|               module.set.percent(settings.percent); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         bind: { | ||||
|           transitionEnd: function(callback) { | ||||
|             var | ||||
|               transitionEnd = module.get.transitionEnd() | ||||
|             ; | ||||
|             $bar | ||||
|               .one(transitionEnd + eventNamespace, function(event) { | ||||
|                 clearTimeout(module.failSafeTimer); | ||||
|                 callback.call(this, event); | ||||
|               }) | ||||
|             ; | ||||
|             module.failSafeTimer = setTimeout(function() { | ||||
|               $bar.triggerHandler(transitionEnd); | ||||
|             }, settings.duration + settings.failSafeDelay); | ||||
|             module.verbose('Adding fail safe timer', module.timer); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         increment: function(incrementValue) { | ||||
|           var | ||||
|             maxValue, | ||||
|             startValue, | ||||
|             newValue | ||||
|           ; | ||||
|           if( module.has.total() ) { | ||||
|             startValue     = module.get.value(); | ||||
|             incrementValue = incrementValue || 1; | ||||
|             newValue       = startValue + incrementValue; | ||||
|           } | ||||
|           else { | ||||
|             startValue     = module.get.percent(); | ||||
|             incrementValue = incrementValue || module.get.randomValue(); | ||||
|  | ||||
|             newValue       = startValue + incrementValue; | ||||
|             maxValue       = 100; | ||||
|             module.debug('Incrementing percentage by', startValue, newValue); | ||||
|           } | ||||
|           newValue = module.get.normalizedValue(newValue); | ||||
|           module.set.progress(newValue); | ||||
|         }, | ||||
|         decrement: function(decrementValue) { | ||||
|           var | ||||
|             total     = module.get.total(), | ||||
|             startValue, | ||||
|             newValue | ||||
|           ; | ||||
|           if(total) { | ||||
|             startValue     =  module.get.value(); | ||||
|             decrementValue =  decrementValue || 1; | ||||
|             newValue       =  startValue - decrementValue; | ||||
|             module.debug('Decrementing value by', decrementValue, startValue); | ||||
|           } | ||||
|           else { | ||||
|             startValue     =  module.get.percent(); | ||||
|             decrementValue =  decrementValue || module.get.randomValue(); | ||||
|             newValue       =  startValue - decrementValue; | ||||
|             module.debug('Decrementing percentage by', decrementValue, startValue); | ||||
|           } | ||||
|           newValue = module.get.normalizedValue(newValue); | ||||
|           module.set.progress(newValue); | ||||
|         }, | ||||
|  | ||||
|         has: { | ||||
|           progressPoll: function() { | ||||
|             return module.progressPoll; | ||||
|           }, | ||||
|           total: function() { | ||||
|             return (module.get.total() !== false); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         get: { | ||||
|           text: function(templateText) { | ||||
|             var | ||||
|               value   = module.value                || 0, | ||||
|               total   = module.total                || 0, | ||||
|               percent = (animating) | ||||
|                 ? module.get.displayPercent() | ||||
|                 : module.percent || 0, | ||||
|               left = (module.total > 0) | ||||
|                 ? (total - value) | ||||
|                 : (100 - percent) | ||||
|             ; | ||||
|             templateText = templateText || ''; | ||||
|             templateText = templateText | ||||
|               .replace('{value}', value) | ||||
|               .replace('{total}', total) | ||||
|               .replace('{left}', left) | ||||
|               .replace('{percent}', percent) | ||||
|             ; | ||||
|             module.verbose('Adding variables to progress bar text', templateText); | ||||
|             return templateText; | ||||
|           }, | ||||
|  | ||||
|           normalizedValue: function(value) { | ||||
|             if(value < 0) { | ||||
|               module.debug('Value cannot decrement below 0'); | ||||
|               return 0; | ||||
|             } | ||||
|             if(module.has.total()) { | ||||
|               if(value > module.total) { | ||||
|                 module.debug('Value cannot increment above total', module.total); | ||||
|                 return module.total; | ||||
|               } | ||||
|             } | ||||
|             else if(value > 100 ) { | ||||
|               module.debug('Value cannot increment above 100 percent'); | ||||
|               return 100; | ||||
|             } | ||||
|             return value; | ||||
|           }, | ||||
|  | ||||
|           updateInterval: function() { | ||||
|             if(settings.updateInterval == 'auto') { | ||||
|               return settings.duration; | ||||
|             } | ||||
|             return settings.updateInterval; | ||||
|           }, | ||||
|  | ||||
|           randomValue: function() { | ||||
|             module.debug('Generating random increment percentage'); | ||||
|             return Math.floor((Math.random() * settings.random.max) + settings.random.min); | ||||
|           }, | ||||
|  | ||||
|           numericValue: function(value) { | ||||
|             return (typeof value === 'string') | ||||
|               ? (value.replace(/[^\d.]/g, '') !== '') | ||||
|                 ? +(value.replace(/[^\d.]/g, '')) | ||||
|                 : false | ||||
|               : value | ||||
|             ; | ||||
|           }, | ||||
|  | ||||
|           transitionEnd: function() { | ||||
|             var | ||||
|               element     = document.createElement('element'), | ||||
|               transitions = { | ||||
|                 'transition'       :'transitionend', | ||||
|                 'OTransition'      :'oTransitionEnd', | ||||
|                 'MozTransition'    :'transitionend', | ||||
|                 'WebkitTransition' :'webkitTransitionEnd' | ||||
|               }, | ||||
|               transition | ||||
|             ; | ||||
|             for(transition in transitions){ | ||||
|               if( element.style[transition] !== undefined ){ | ||||
|                 return transitions[transition]; | ||||
|               } | ||||
|             } | ||||
|           }, | ||||
|  | ||||
|           // gets current displayed percentage (if animating values this is the intermediary value) | ||||
|           displayPercent: function() { | ||||
|             var | ||||
|               barWidth       = $bar.width(), | ||||
|               totalWidth     = $module.width(), | ||||
|               minDisplay     = parseInt($bar.css('min-width'), 10), | ||||
|               displayPercent = (barWidth > minDisplay) | ||||
|                 ? (barWidth / totalWidth * 100) | ||||
|                 : module.percent | ||||
|             ; | ||||
|             return (settings.precision > 0) | ||||
|               ? Math.round(displayPercent * (10 * settings.precision)) / (10 * settings.precision) | ||||
|               : Math.round(displayPercent) | ||||
|             ; | ||||
|           }, | ||||
|  | ||||
|           percent: function() { | ||||
|             return module.percent || 0; | ||||
|           }, | ||||
|           value: function() { | ||||
|             return module.nextValue || module.value || 0; | ||||
|           }, | ||||
|           total: function() { | ||||
|             return module.total || false; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         create: { | ||||
|           progressPoll: function() { | ||||
|             module.progressPoll = setTimeout(function() { | ||||
|               module.update.toNextValue(); | ||||
|               module.remove.progressPoll(); | ||||
|             }, module.get.updateInterval()); | ||||
|           }, | ||||
|         }, | ||||
|  | ||||
|         is: { | ||||
|           complete: function() { | ||||
|             return module.is.success() || module.is.warning() || module.is.error(); | ||||
|           }, | ||||
|           success: function() { | ||||
|             return $module.hasClass(className.success); | ||||
|           }, | ||||
|           warning: function() { | ||||
|             return $module.hasClass(className.warning); | ||||
|           }, | ||||
|           error: function() { | ||||
|             return $module.hasClass(className.error); | ||||
|           }, | ||||
|           active: function() { | ||||
|             return $module.hasClass(className.active); | ||||
|           }, | ||||
|           visible: function() { | ||||
|             return $module.is(':visible'); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         remove: { | ||||
|           progressPoll: function() { | ||||
|             module.verbose('Removing progress poll timer'); | ||||
|             if(module.progressPoll) { | ||||
|               clearTimeout(module.progressPoll); | ||||
|               delete module.progressPoll; | ||||
|             } | ||||
|           }, | ||||
|           nextValue: function() { | ||||
|             module.verbose('Removing progress value stored for next update'); | ||||
|             delete module.nextValue; | ||||
|           }, | ||||
|           state: function() { | ||||
|             module.verbose('Removing stored state'); | ||||
|             delete module.total; | ||||
|             delete module.percent; | ||||
|             delete module.value; | ||||
|           }, | ||||
|           active: function() { | ||||
|             module.verbose('Removing active state'); | ||||
|             $module.removeClass(className.active); | ||||
|           }, | ||||
|           success: function() { | ||||
|             module.verbose('Removing success state'); | ||||
|             $module.removeClass(className.success); | ||||
|           }, | ||||
|           warning: function() { | ||||
|             module.verbose('Removing warning state'); | ||||
|             $module.removeClass(className.warning); | ||||
|           }, | ||||
|           error: function() { | ||||
|             module.verbose('Removing error state'); | ||||
|             $module.removeClass(className.error); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         set: { | ||||
|           barWidth: function(value) { | ||||
|             if(value > 100) { | ||||
|               module.error(error.tooHigh, value); | ||||
|             } | ||||
|             else if (value < 0) { | ||||
|               module.error(error.tooLow, value); | ||||
|             } | ||||
|             else { | ||||
|               $bar | ||||
|                 .css('width', value + '%') | ||||
|               ; | ||||
|               $module | ||||
|                 .attr('data-percent', parseInt(value, 10)) | ||||
|               ; | ||||
|             } | ||||
|           }, | ||||
|           duration: function(duration) { | ||||
|             duration = duration || settings.duration; | ||||
|             duration = (typeof duration == 'number') | ||||
|               ? duration + 'ms' | ||||
|               : duration | ||||
|             ; | ||||
|             module.verbose('Setting progress bar transition duration', duration); | ||||
|             $bar | ||||
|               .css({ | ||||
|                 'transition-duration':  duration | ||||
|               }) | ||||
|             ; | ||||
|           }, | ||||
|           percent: function(percent) { | ||||
|             percent = (typeof percent == 'string') | ||||
|               ? +(percent.replace('%', '')) | ||||
|               : percent | ||||
|             ; | ||||
|             // round display percentage | ||||
|             percent = (settings.precision > 0) | ||||
|               ? Math.round(percent * (10 * settings.precision)) / (10 * settings.precision) | ||||
|               : Math.round(percent) | ||||
|             ; | ||||
|             module.percent = percent; | ||||
|             if( !module.has.total() ) { | ||||
|               module.value = (settings.precision > 0) | ||||
|                 ? Math.round( (percent / 100) * module.total * (10 * settings.precision)) / (10 * settings.precision) | ||||
|                 : Math.round( (percent / 100) * module.total * 10) / 10 | ||||
|               ; | ||||
|               if(settings.limitValues) { | ||||
|                 module.value = (module.value > 100) | ||||
|                   ? 100 | ||||
|                   : (module.value < 0) | ||||
|                     ? 0 | ||||
|                     : module.value | ||||
|                 ; | ||||
|               } | ||||
|             } | ||||
|             module.set.barWidth(percent); | ||||
|             module.set.labelInterval(); | ||||
|             module.set.labels(); | ||||
|             settings.onChange.call(element, percent, module.value, module.total); | ||||
|           }, | ||||
|           labelInterval: function() { | ||||
|             var | ||||
|               animationCallback = function() { | ||||
|                 module.verbose('Bar finished animating, removing continuous label updates'); | ||||
|                 clearInterval(module.interval); | ||||
|                 animating = false; | ||||
|                 module.set.labels(); | ||||
|               } | ||||
|             ; | ||||
|             clearInterval(module.interval); | ||||
|             module.bind.transitionEnd(animationCallback); | ||||
|             animating = true; | ||||
|             module.interval = setInterval(function() { | ||||
|               var | ||||
|                 isInDOM = $.contains(document.documentElement, element) | ||||
|               ; | ||||
|               if(!isInDOM) { | ||||
|                 clearInterval(module.interval); | ||||
|                 animating = false; | ||||
|               } | ||||
|               module.set.labels(); | ||||
|             }, settings.framerate); | ||||
|           }, | ||||
|           labels: function() { | ||||
|             module.verbose('Setting both bar progress and outer label text'); | ||||
|             module.set.barLabel(); | ||||
|             module.set.state(); | ||||
|           }, | ||||
|           label: function(text) { | ||||
|             text = text || ''; | ||||
|             if(text) { | ||||
|               text = module.get.text(text); | ||||
|               module.verbose('Setting label to text', text); | ||||
|               $label.text(text); | ||||
|             } | ||||
|           }, | ||||
|           state: function(percent) { | ||||
|             percent = (percent !== undefined) | ||||
|               ? percent | ||||
|               : module.percent | ||||
|             ; | ||||
|             if(percent === 100) { | ||||
|               if(settings.autoSuccess && !(module.is.warning() || module.is.error() || module.is.success())) { | ||||
|                 module.set.success(); | ||||
|                 module.debug('Automatically triggering success at 100%'); | ||||
|               } | ||||
|               else { | ||||
|                 module.verbose('Reached 100% removing active state'); | ||||
|                 module.remove.active(); | ||||
|                 module.remove.progressPoll(); | ||||
|               } | ||||
|             } | ||||
|             else if(percent > 0) { | ||||
|               module.verbose('Adjusting active progress bar label', percent); | ||||
|               module.set.active(); | ||||
|             } | ||||
|             else { | ||||
|               module.remove.active(); | ||||
|               module.set.label(settings.text.active); | ||||
|             } | ||||
|           }, | ||||
|           barLabel: function(text) { | ||||
|             if(text !== undefined) { | ||||
|               $progress.text( module.get.text(text) ); | ||||
|             } | ||||
|             else if(settings.label == 'ratio' && module.total) { | ||||
|               module.verbose('Adding ratio to bar label'); | ||||
|               $progress.text( module.get.text(settings.text.ratio) ); | ||||
|             } | ||||
|             else if(settings.label == 'percent') { | ||||
|               module.verbose('Adding percentage to bar label'); | ||||
|               $progress.text( module.get.text(settings.text.percent) ); | ||||
|             } | ||||
|           }, | ||||
|           active: function(text) { | ||||
|             text = text || settings.text.active; | ||||
|             module.debug('Setting active state'); | ||||
|             if(settings.showActivity && !module.is.active() ) { | ||||
|               $module.addClass(className.active); | ||||
|             } | ||||
|             module.remove.warning(); | ||||
|             module.remove.error(); | ||||
|             module.remove.success(); | ||||
|             text = settings.onLabelUpdate('active', text, module.value, module.total); | ||||
|             if(text) { | ||||
|               module.set.label(text); | ||||
|             } | ||||
|             module.bind.transitionEnd(function() { | ||||
|               settings.onActive.call(element, module.value, module.total); | ||||
|             }); | ||||
|           }, | ||||
|           success : function(text) { | ||||
|             text = text || settings.text.success || settings.text.active; | ||||
|             module.debug('Setting success state'); | ||||
|             $module.addClass(className.success); | ||||
|             module.remove.active(); | ||||
|             module.remove.warning(); | ||||
|             module.remove.error(); | ||||
|             module.complete(); | ||||
|             if(settings.text.success) { | ||||
|               text = settings.onLabelUpdate('success', text, module.value, module.total); | ||||
|               module.set.label(text); | ||||
|             } | ||||
|             else { | ||||
|               text = settings.onLabelUpdate('active', text, module.value, module.total); | ||||
|               module.set.label(text); | ||||
|             } | ||||
|             module.bind.transitionEnd(function() { | ||||
|               settings.onSuccess.call(element, module.total); | ||||
|             }); | ||||
|           }, | ||||
|           warning : function(text) { | ||||
|             text = text || settings.text.warning; | ||||
|             module.debug('Setting warning state'); | ||||
|             $module.addClass(className.warning); | ||||
|             module.remove.active(); | ||||
|             module.remove.success(); | ||||
|             module.remove.error(); | ||||
|             module.complete(); | ||||
|             text = settings.onLabelUpdate('warning', text, module.value, module.total); | ||||
|             if(text) { | ||||
|               module.set.label(text); | ||||
|             } | ||||
|             module.bind.transitionEnd(function() { | ||||
|               settings.onWarning.call(element, module.value, module.total); | ||||
|             }); | ||||
|           }, | ||||
|           error : function(text) { | ||||
|             text = text || settings.text.error; | ||||
|             module.debug('Setting error state'); | ||||
|             $module.addClass(className.error); | ||||
|             module.remove.active(); | ||||
|             module.remove.success(); | ||||
|             module.remove.warning(); | ||||
|             module.complete(); | ||||
|             text = settings.onLabelUpdate('error', text, module.value, module.total); | ||||
|             if(text) { | ||||
|               module.set.label(text); | ||||
|             } | ||||
|             module.bind.transitionEnd(function() { | ||||
|               settings.onError.call(element, module.value, module.total); | ||||
|             }); | ||||
|           }, | ||||
|           transitionEvent: function() { | ||||
|             transitionEnd = module.get.transitionEnd(); | ||||
|           }, | ||||
|           total: function(totalValue) { | ||||
|             module.total = totalValue; | ||||
|           }, | ||||
|           value: function(value) { | ||||
|             module.value = value; | ||||
|           }, | ||||
|           progress: function(value) { | ||||
|             if(!module.has.progressPoll()) { | ||||
|               module.debug('First update in progress update interval, immediately updating', value); | ||||
|               module.update.progress(value); | ||||
|               module.create.progressPoll(); | ||||
|             } | ||||
|             else { | ||||
|               module.debug('Updated within interval, setting next update to use new value', value); | ||||
|               module.set.nextValue(value); | ||||
|             } | ||||
|           }, | ||||
|           nextValue: function(value) { | ||||
|             module.nextValue = value; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         update: { | ||||
|           toNextValue: function() { | ||||
|             var | ||||
|               nextValue = module.nextValue | ||||
|             ; | ||||
|             if(nextValue) { | ||||
|               module.debug('Update interval complete using last updated value', nextValue); | ||||
|               module.update.progress(nextValue); | ||||
|               module.remove.nextValue(); | ||||
|             } | ||||
|           }, | ||||
|           progress: function(value) { | ||||
|             var | ||||
|               percentComplete | ||||
|             ; | ||||
|             value = module.get.numericValue(value); | ||||
|             if(value === false) { | ||||
|               module.error(error.nonNumeric, value); | ||||
|             } | ||||
|             value = module.get.normalizedValue(value); | ||||
|             if( module.has.total() ) { | ||||
|               module.set.value(value); | ||||
|               percentComplete = (value / module.total) * 100; | ||||
|               module.debug('Calculating percent complete from total', percentComplete); | ||||
|               module.set.percent( percentComplete ); | ||||
|             } | ||||
|             else { | ||||
|               percentComplete = value; | ||||
|               module.debug('Setting value to exact percentage value', percentComplete); | ||||
|               module.set.percent( percentComplete ); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         setting: function(name, value) { | ||||
|           module.debug('Changing setting', name, value); | ||||
|           if( $.isPlainObject(name) ) { | ||||
|             $.extend(true, settings, name); | ||||
|           } | ||||
|           else if(value !== undefined) { | ||||
|             if($.isPlainObject(settings[name])) { | ||||
|               $.extend(true, settings[name], value); | ||||
|             } | ||||
|             else { | ||||
|               settings[name] = value; | ||||
|             } | ||||
|           } | ||||
|           else { | ||||
|             return settings[name]; | ||||
|           } | ||||
|         }, | ||||
|         internal: function(name, value) { | ||||
|           if( $.isPlainObject(name) ) { | ||||
|             $.extend(true, module, name); | ||||
|           } | ||||
|           else if(value !== undefined) { | ||||
|             module[name] = value; | ||||
|           } | ||||
|           else { | ||||
|             return module[name]; | ||||
|           } | ||||
|         }, | ||||
|         debug: function() { | ||||
|           if(!settings.silent && settings.debug) { | ||||
|             if(settings.performance) { | ||||
|               module.performance.log(arguments); | ||||
|             } | ||||
|             else { | ||||
|               module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|               module.debug.apply(console, arguments); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         verbose: function() { | ||||
|           if(!settings.silent && settings.verbose && settings.debug) { | ||||
|             if(settings.performance) { | ||||
|               module.performance.log(arguments); | ||||
|             } | ||||
|             else { | ||||
|               module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|               module.verbose.apply(console, arguments); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         error: function() { | ||||
|           if(!settings.silent) { | ||||
|             module.error = Function.prototype.bind.call(console.error, console, settings.name + ':'); | ||||
|             module.error.apply(console, arguments); | ||||
|           } | ||||
|         }, | ||||
|         performance: { | ||||
|           log: function(message) { | ||||
|             var | ||||
|               currentTime, | ||||
|               executionTime, | ||||
|               previousTime | ||||
|             ; | ||||
|             if(settings.performance) { | ||||
|               currentTime   = new Date().getTime(); | ||||
|               previousTime  = time || currentTime; | ||||
|               executionTime = currentTime - previousTime; | ||||
|               time          = currentTime; | ||||
|               performance.push({ | ||||
|                 'Name'           : message[0], | ||||
|                 'Arguments'      : [].slice.call(message, 1) || '', | ||||
|                 'Element'        : element, | ||||
|                 'Execution Time' : executionTime | ||||
|               }); | ||||
|             } | ||||
|             clearTimeout(module.performance.timer); | ||||
|             module.performance.timer = setTimeout(module.performance.display, 500); | ||||
|           }, | ||||
|           display: function() { | ||||
|             var | ||||
|               title = settings.name + ':', | ||||
|               totalTime = 0 | ||||
|             ; | ||||
|             time = false; | ||||
|             clearTimeout(module.performance.timer); | ||||
|             $.each(performance, function(index, data) { | ||||
|               totalTime += data['Execution Time']; | ||||
|             }); | ||||
|             title += ' ' + totalTime + 'ms'; | ||||
|             if(moduleSelector) { | ||||
|               title += ' \'' + moduleSelector + '\''; | ||||
|             } | ||||
|             if( (console.group !== undefined || console.table !== undefined) && performance.length > 0) { | ||||
|               console.groupCollapsed(title); | ||||
|               if(console.table) { | ||||
|                 console.table(performance); | ||||
|               } | ||||
|               else { | ||||
|                 $.each(performance, function(index, data) { | ||||
|                   console.log(data['Name'] + ': ' + data['Execution Time']+'ms'); | ||||
|                 }); | ||||
|               } | ||||
|               console.groupEnd(); | ||||
|             } | ||||
|             performance = []; | ||||
|           } | ||||
|         }, | ||||
|         invoke: function(query, passedArguments, context) { | ||||
|           var | ||||
|             object = instance, | ||||
|             maxDepth, | ||||
|             found, | ||||
|             response | ||||
|           ; | ||||
|           passedArguments = passedArguments || queryArguments; | ||||
|           context         = element         || context; | ||||
|           if(typeof query == 'string' && object !== undefined) { | ||||
|             query    = query.split(/[\. ]/); | ||||
|             maxDepth = query.length - 1; | ||||
|             $.each(query, function(depth, value) { | ||||
|               var camelCaseValue = (depth != maxDepth) | ||||
|                 ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1) | ||||
|                 : query | ||||
|               ; | ||||
|               if( $.isPlainObject( object[camelCaseValue] ) && (depth != maxDepth) ) { | ||||
|                 object = object[camelCaseValue]; | ||||
|               } | ||||
|               else if( object[camelCaseValue] !== undefined ) { | ||||
|                 found = object[camelCaseValue]; | ||||
|                 return false; | ||||
|               } | ||||
|               else if( $.isPlainObject( object[value] ) && (depth != maxDepth) ) { | ||||
|                 object = object[value]; | ||||
|               } | ||||
|               else if( object[value] !== undefined ) { | ||||
|                 found = object[value]; | ||||
|                 return false; | ||||
|               } | ||||
|               else { | ||||
|                 module.error(error.method, query); | ||||
|                 return false; | ||||
|               } | ||||
|             }); | ||||
|           } | ||||
|           if ( $.isFunction( found ) ) { | ||||
|             response = found.apply(context, passedArguments); | ||||
|           } | ||||
|           else if(found !== undefined) { | ||||
|             response = found; | ||||
|           } | ||||
|           if($.isArray(returnedValue)) { | ||||
|             returnedValue.push(response); | ||||
|           } | ||||
|           else if(returnedValue !== undefined) { | ||||
|             returnedValue = [returnedValue, response]; | ||||
|           } | ||||
|           else if(response !== undefined) { | ||||
|             returnedValue = response; | ||||
|           } | ||||
|           return found; | ||||
|         } | ||||
|       }; | ||||
|  | ||||
|       if(methodInvoked) { | ||||
|         if(instance === undefined) { | ||||
|           module.initialize(); | ||||
|         } | ||||
|         module.invoke(query); | ||||
|       } | ||||
|       else { | ||||
|         if(instance !== undefined) { | ||||
|           instance.invoke('destroy'); | ||||
|         } | ||||
|         module.initialize(); | ||||
|       } | ||||
|     }) | ||||
|   ; | ||||
|  | ||||
|   return (returnedValue !== undefined) | ||||
|     ? returnedValue | ||||
|     : this | ||||
|   ; | ||||
| }; | ||||
|  | ||||
| $.fn.progress.settings = { | ||||
|  | ||||
|   name         : 'Progress', | ||||
|   namespace    : 'progress', | ||||
|  | ||||
|   silent       : false, | ||||
|   debug        : false, | ||||
|   verbose      : false, | ||||
|   performance  : true, | ||||
|  | ||||
|   random       : { | ||||
|     min : 2, | ||||
|     max : 5 | ||||
|   }, | ||||
|  | ||||
|   duration       : 300, | ||||
|  | ||||
|   updateInterval : 'auto', | ||||
|  | ||||
|   autoSuccess    : true, | ||||
|   showActivity   : true, | ||||
|   limitValues    : true, | ||||
|  | ||||
|   label          : 'percent', | ||||
|   precision      : 0, | ||||
|   framerate      : (1000 / 30), /// 30 fps | ||||
|  | ||||
|   percent        : false, | ||||
|   total          : false, | ||||
|   value          : false, | ||||
|  | ||||
|   // delay in ms for fail safe animation callback | ||||
|   failSafeDelay : 100, | ||||
|  | ||||
|   onLabelUpdate : function(state, text, value, total){ | ||||
|     return text; | ||||
|   }, | ||||
|   onChange      : function(percent, value, total){}, | ||||
|   onSuccess     : function(total){}, | ||||
|   onActive      : function(value, total){}, | ||||
|   onError       : function(value, total){}, | ||||
|   onWarning     : function(value, total){}, | ||||
|  | ||||
|   error    : { | ||||
|     method     : 'The method you called is not defined.', | ||||
|     nonNumeric : 'Progress value is non numeric', | ||||
|     tooHigh    : 'Value specified is above 100%', | ||||
|     tooLow     : 'Value specified is below 0%' | ||||
|   }, | ||||
|  | ||||
|   regExp: { | ||||
|     variable: /\{\$*[A-z0-9]+\}/g | ||||
|   }, | ||||
|  | ||||
|   metadata: { | ||||
|     percent : 'percent', | ||||
|     total   : 'total', | ||||
|     value   : 'value' | ||||
|   }, | ||||
|  | ||||
|   selector : { | ||||
|     bar      : '> .bar', | ||||
|     label    : '> .label', | ||||
|     progress : '.bar > .progress' | ||||
|   }, | ||||
|  | ||||
|   text : { | ||||
|     active  : false, | ||||
|     error   : false, | ||||
|     success : false, | ||||
|     warning : false, | ||||
|     percent : '{percent}%', | ||||
|     ratio   : '{value} of {total}' | ||||
|   }, | ||||
|  | ||||
|   className : { | ||||
|     active  : 'active', | ||||
|     error   : 'error', | ||||
|     success : 'success', | ||||
|     warning : 'warning' | ||||
|   } | ||||
|  | ||||
| }; | ||||
|  | ||||
|  | ||||
| })( jQuery, window, document ); | ||||
| @@ -1,503 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Progress Bar | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'module'; | ||||
| @element : 'progress'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|             Progress | ||||
| *******************************/ | ||||
|  | ||||
| .ui.progress { | ||||
|   position: relative; | ||||
|   display: block; | ||||
|   max-width: 100%; | ||||
|   border: @border; | ||||
|   margin: @margin; | ||||
|   box-shadow: @boxShadow; | ||||
|   background: @background; | ||||
|   padding: @padding; | ||||
|   border-radius: @borderRadius; | ||||
| } | ||||
|  | ||||
| .ui.progress:first-child { | ||||
|   margin: @firstMargin; | ||||
| } | ||||
| .ui.progress:last-child { | ||||
|   margin: @lastMargin; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|             Content | ||||
| *******************************/ | ||||
|  | ||||
| /* Activity Bar */ | ||||
| .ui.progress .bar { | ||||
|   display: block; | ||||
|   line-height: 1; | ||||
|   position: @barPosition; | ||||
|   width: @barInitialWidth; | ||||
|   min-width: @barMinWidth; | ||||
|   background: @barBackground; | ||||
|   border-radius: @barBorderRadius; | ||||
|   transition: @barTransition; | ||||
| } | ||||
|  | ||||
| /* Percent Complete */ | ||||
| .ui.progress .bar > .progress { | ||||
|   white-space: nowrap; | ||||
|   position: @progressPosition; | ||||
|   width: @progressWidth; | ||||
|   font-size: @progressSize; | ||||
|   top: @progressTop; | ||||
|   right: @progressRight; | ||||
|   left: @progressLeft; | ||||
|   bottom: @progressBottom; | ||||
|   color: @progressColor; | ||||
|   text-shadow: @progressTextShadow; | ||||
|   margin-top: @progressOffset; | ||||
|   font-weight: @progressFontWeight; | ||||
|   text-align: @progressTextAlign; | ||||
| } | ||||
|  | ||||
| /* Label */ | ||||
| .ui.progress > .label { | ||||
|   position: absolute; | ||||
|   width: @labelWidth; | ||||
|   font-size: @labelSize; | ||||
|   top: @labelTop; | ||||
|   right: @labelRight; | ||||
|   left: @labelLeft; | ||||
|   bottom: @labelBottom; | ||||
|   color: @labelColor; | ||||
|   font-weight: @labelFontWeight; | ||||
|   text-shadow: @labelTextShadow; | ||||
|   margin-top: @labelOffset; | ||||
|   text-align: @labelTextAlign; | ||||
|   transition: @labelTransition; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Types | ||||
| *******************************/ | ||||
|  | ||||
|  | ||||
| /* Indicating */ | ||||
| .ui.indicating.progress[data-percent^="1"] .bar, | ||||
| .ui.indicating.progress[data-percent^="2"] .bar { | ||||
|   background-color: @indicatingFirstColor; | ||||
| } | ||||
| .ui.indicating.progress[data-percent^="3"] .bar { | ||||
|   background-color: @indicatingSecondColor; | ||||
| } | ||||
| .ui.indicating.progress[data-percent^="4"] .bar, | ||||
| .ui.indicating.progress[data-percent^="5"] .bar { | ||||
|   background-color: @indicatingThirdColor; | ||||
| } | ||||
| .ui.indicating.progress[data-percent^="6"] .bar { | ||||
|   background-color: @indicatingFourthColor; | ||||
| } | ||||
| .ui.indicating.progress[data-percent^="7"] .bar, | ||||
| .ui.indicating.progress[data-percent^="8"] .bar { | ||||
|   background-color: @indicatingFifthColor; | ||||
| } | ||||
| .ui.indicating.progress[data-percent^="9"] .bar, | ||||
| .ui.indicating.progress[data-percent^="100"] .bar { | ||||
|   background-color: @indicatingSixthColor; | ||||
| } | ||||
|  | ||||
| /* Indicating Label */ | ||||
| .ui.indicating.progress[data-percent^="1"] .label, | ||||
| .ui.indicating.progress[data-percent^="2"] .label { | ||||
|   color: @indicatingFirstLabelColor; | ||||
| } | ||||
| .ui.indicating.progress[data-percent^="3"] .label { | ||||
|   color: @indicatingSecondLabelColor; | ||||
| } | ||||
| .ui.indicating.progress[data-percent^="4"] .label, | ||||
| .ui.indicating.progress[data-percent^="5"] .label { | ||||
|   color: @indicatingThirdLabelColor; | ||||
| } | ||||
| .ui.indicating.progress[data-percent^="6"] .label { | ||||
|   color: @indicatingFourthLabelColor; | ||||
| } | ||||
| .ui.indicating.progress[data-percent^="7"] .label, | ||||
| .ui.indicating.progress[data-percent^="8"] .label { | ||||
|   color: @indicatingFifthLabelColor; | ||||
| } | ||||
| .ui.indicating.progress[data-percent^="9"] .label, | ||||
| .ui.indicating.progress[data-percent^="100"] .label { | ||||
|   color: @indicatingSixthLabelColor; | ||||
| } | ||||
|  | ||||
| /* Single Digits */ | ||||
| .ui.indicating.progress[data-percent="1"] .bar, | ||||
| .ui.indicating.progress[data-percent="2"] .bar, | ||||
| .ui.indicating.progress[data-percent="3"] .bar, | ||||
| .ui.indicating.progress[data-percent="4"] .bar, | ||||
| .ui.indicating.progress[data-percent="5"] .bar, | ||||
| .ui.indicating.progress[data-percent="6"] .bar, | ||||
| .ui.indicating.progress[data-percent="7"] .bar, | ||||
| .ui.indicating.progress[data-percent="8"] .bar, | ||||
| .ui.indicating.progress[data-percent="9"] .bar { | ||||
|   background-color: @indicatingFirstColor; | ||||
| } | ||||
| .ui.indicating.progress[data-percent="1"] .label, | ||||
| .ui.indicating.progress[data-percent="2"] .label, | ||||
| .ui.indicating.progress[data-percent="3"] .label, | ||||
| .ui.indicating.progress[data-percent="4"] .label, | ||||
| .ui.indicating.progress[data-percent="5"] .label, | ||||
| .ui.indicating.progress[data-percent="6"] .label, | ||||
| .ui.indicating.progress[data-percent="7"] .label, | ||||
| .ui.indicating.progress[data-percent="8"] .label, | ||||
| .ui.indicating.progress[data-percent="9"] .label { | ||||
|   color: @indicatingFirstLabelColor; | ||||
| } | ||||
|  | ||||
| /* Indicating Success */ | ||||
| .ui.indicating.progress.success .label { | ||||
|   color: @successHeaderColor; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|              States | ||||
| *******************************/ | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|      Success | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.progress.success .bar { | ||||
|   background-color: @successColor !important; | ||||
| } | ||||
| .ui.progress.success .bar, | ||||
| .ui.progress.success .bar::after { | ||||
|   animation: none !important; | ||||
| } | ||||
| .ui.progress.success > .label { | ||||
|   color: @successHeaderColor; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Warning | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.progress.warning .bar { | ||||
|   background-color: @warningColor !important; | ||||
| } | ||||
| .ui.progress.warning .bar, | ||||
| .ui.progress.warning .bar::after { | ||||
|   animation: none !important; | ||||
| } | ||||
| .ui.progress.warning > .label { | ||||
|   color: @warningHeaderColor; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Error | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.progress.error .bar { | ||||
|   background-color: @errorColor !important; | ||||
| } | ||||
| .ui.progress.error .bar, | ||||
| .ui.progress.error .bar::after { | ||||
|   animation: none !important; | ||||
| } | ||||
| .ui.progress.error > .label { | ||||
|   color: @errorHeaderColor; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Active | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.active.progress .bar { | ||||
|   position: relative; | ||||
|   min-width: @activeMinWidth; | ||||
| } | ||||
| .ui.active.progress .bar::after { | ||||
|   content: ''; | ||||
|   opacity: 0; | ||||
|  | ||||
|   position: absolute; | ||||
|   top: 0px; | ||||
|   left: 0px; | ||||
|   right: 0px; | ||||
|   bottom: 0px; | ||||
|   background: @activePulseColor; | ||||
|  | ||||
|   border-radius: @barBorderRadius; | ||||
|  | ||||
|   animation: progress-active @activePulseDuration @defaultEasing infinite; | ||||
| } | ||||
| @keyframes progress-active { | ||||
|   0% { | ||||
|     opacity: @activePulseMaxOpacity; | ||||
|     width: 0; | ||||
|   } | ||||
|   90% { | ||||
|   } | ||||
|   100% { | ||||
|     opacity: 0; | ||||
|     width: 100%; | ||||
|   } | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Disabled | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.disabled.progress { | ||||
|   opacity: 0.35; | ||||
| } | ||||
| .ui.disabled.progress .bar, | ||||
| .ui.disabled.progress .bar::after { | ||||
|   animation: none !important; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|            Variations | ||||
| *******************************/ | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|     Inverted | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.inverted.progress { | ||||
|   background: @invertedBackground; | ||||
|   border: @invertedBorder; | ||||
| } | ||||
| .ui.inverted.progress .bar { | ||||
|   background: @invertedBarBackground; | ||||
| } | ||||
| .ui.inverted.progress .bar > .progress { | ||||
|   color: @invertedProgressColor; | ||||
| } | ||||
| .ui.inverted.progress > .label { | ||||
|   color: @invertedLabelColor; | ||||
| } | ||||
| .ui.inverted.progress.success > .label { | ||||
|   color: @successColor; | ||||
| } | ||||
| .ui.inverted.progress.warning > .label { | ||||
|   color: @warningColor; | ||||
| } | ||||
| .ui.inverted.progress.error > .label { | ||||
|   color: @errorColor; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Attached | ||||
| ---------------*/ | ||||
|  | ||||
| /* bottom attached */ | ||||
| .ui.progress.attached { | ||||
|   background: @attachedBackground; | ||||
|   position: relative; | ||||
|   border: none; | ||||
|   margin: 0em; | ||||
| } | ||||
| .ui.progress.attached, | ||||
| .ui.progress.attached .bar { | ||||
|   display: block; | ||||
|   height: @attachedHeight; | ||||
|   padding: 0px; | ||||
|   overflow: hidden; | ||||
|   border-radius: 0em 0em @attachedBorderRadius @attachedBorderRadius; | ||||
| } | ||||
| .ui.progress.attached .bar { | ||||
|   border-radius: 0em; | ||||
| } | ||||
|  | ||||
| /* top attached */ | ||||
| .ui.progress.top.attached, | ||||
| .ui.progress.top.attached .bar { | ||||
|   top: 0px; | ||||
|   border-radius: @attachedBorderRadius @attachedBorderRadius 0em 0em; | ||||
| } | ||||
| .ui.progress.top.attached .bar { | ||||
|   border-radius: 0em; | ||||
| } | ||||
|  | ||||
| /* Coupling */ | ||||
| .ui.segment > .ui.attached.progress, | ||||
| .ui.card > .ui.attached.progress { | ||||
|   position: absolute; | ||||
|   top: auto; | ||||
|   left: 0; | ||||
|   bottom: 100%; | ||||
|   width: 100%; | ||||
| } | ||||
| .ui.segment > .ui.bottom.attached.progress, | ||||
| .ui.card > .ui.bottom.attached.progress { | ||||
|   top: 100%; | ||||
|   bottom: auto; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Colors | ||||
| ---------------*/ | ||||
|  | ||||
| /* Red */ | ||||
| .ui.red.progress .bar { | ||||
|   background-color: @red; | ||||
| } | ||||
| .ui.red.inverted.progress .bar { | ||||
|   background-color: @lightRed; | ||||
| } | ||||
|  | ||||
| /* Orange */ | ||||
| .ui.orange.progress .bar { | ||||
|   background-color: @orange; | ||||
| } | ||||
| .ui.orange.inverted.progress .bar { | ||||
|   background-color: @lightOrange; | ||||
| } | ||||
|  | ||||
| /* Yellow */ | ||||
| .ui.yellow.progress .bar { | ||||
|   background-color: @yellow; | ||||
| } | ||||
| .ui.yellow.inverted.progress .bar { | ||||
|   background-color: @lightYellow; | ||||
| } | ||||
|  | ||||
| /* Olive */ | ||||
| .ui.olive.progress .bar { | ||||
|   background-color: @olive; | ||||
| } | ||||
| .ui.olive.inverted.progress .bar { | ||||
|   background-color: @lightOlive; | ||||
| } | ||||
|  | ||||
| /* Green */ | ||||
| .ui.green.progress .bar { | ||||
|   background-color: @green; | ||||
| } | ||||
| .ui.green.inverted.progress .bar { | ||||
|   background-color: @lightGreen; | ||||
| } | ||||
|  | ||||
| /* Teal */ | ||||
| .ui.teal.progress .bar { | ||||
|   background-color: @teal; | ||||
| } | ||||
| .ui.teal.inverted.progress .bar { | ||||
|   background-color: @lightTeal; | ||||
| } | ||||
|  | ||||
| /* Blue */ | ||||
| .ui.blue.progress .bar { | ||||
|   background-color: @blue; | ||||
| } | ||||
| .ui.blue.inverted.progress .bar { | ||||
|   background-color: @lightBlue; | ||||
| } | ||||
|  | ||||
| /* Violet */ | ||||
| .ui.violet.progress .bar { | ||||
|   background-color: @violet; | ||||
| } | ||||
| .ui.violet.inverted.progress .bar { | ||||
|   background-color: @lightViolet; | ||||
| } | ||||
|  | ||||
| /* Purple */ | ||||
| .ui.purple.progress .bar { | ||||
|   background-color: @purple; | ||||
| } | ||||
| .ui.purple.inverted.progress .bar { | ||||
|   background-color: @lightPurple; | ||||
| } | ||||
|  | ||||
| /* Pink */ | ||||
| .ui.pink.progress .bar { | ||||
|   background-color: @pink; | ||||
| } | ||||
| .ui.pink.inverted.progress .bar { | ||||
|   background-color: @lightPink; | ||||
| } | ||||
|  | ||||
| /* Brown */ | ||||
| .ui.brown.progress .bar { | ||||
|   background-color: @brown; | ||||
| } | ||||
| .ui.brown.inverted.progress .bar { | ||||
|   background-color: @lightBrown; | ||||
| } | ||||
|  | ||||
| /* Grey */ | ||||
| .ui.grey.progress .bar { | ||||
|   background-color: @grey; | ||||
| } | ||||
| .ui.grey.inverted.progress .bar { | ||||
|   background-color: @lightGrey; | ||||
| } | ||||
|  | ||||
| /* Black */ | ||||
| .ui.black.progress .bar { | ||||
|   background-color: @black; | ||||
| } | ||||
| .ui.black.inverted.progress .bar { | ||||
|   background-color: @lightBlack; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Sizes | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.tiny.progress { | ||||
|   font-size: @tiny; | ||||
| } | ||||
| .ui.tiny.progress .bar { | ||||
|   height: @tinyBarHeight; | ||||
| } | ||||
|  | ||||
| .ui.small.progress { | ||||
|   font-size: @small; | ||||
| } | ||||
| .ui.small.progress .bar { | ||||
|   height: @smallBarHeight; | ||||
| } | ||||
|  | ||||
| .ui.progress { | ||||
|   font-size: @medium; | ||||
| } | ||||
| .ui.progress .bar { | ||||
|   height: @barHeight; | ||||
| } | ||||
|  | ||||
| .ui.large.progress { | ||||
|   font-size: @large; | ||||
| } | ||||
| .ui.large.progress .bar { | ||||
|   height: @largeBarHeight; | ||||
| } | ||||
|  | ||||
| .ui.big.progress { | ||||
|   font-size: @big; | ||||
| } | ||||
| .ui.big.progress .bar { | ||||
|   height: @bigBarHeight; | ||||
| } | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,508 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Rating | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| ;(function ($, window, document, undefined) { | ||||
|  | ||||
| 'use strict'; | ||||
|  | ||||
| window = (typeof window != 'undefined' && window.Math == Math) | ||||
|   ? window | ||||
|   : (typeof self != 'undefined' && self.Math == Math) | ||||
|     ? self | ||||
|     : Function('return this')() | ||||
| ; | ||||
|  | ||||
| $.fn.rating = function(parameters) { | ||||
|   var | ||||
|     $allModules     = $(this), | ||||
|     moduleSelector  = $allModules.selector || '', | ||||
|  | ||||
|     time            = new Date().getTime(), | ||||
|     performance     = [], | ||||
|  | ||||
|     query           = arguments[0], | ||||
|     methodInvoked   = (typeof query == 'string'), | ||||
|     queryArguments  = [].slice.call(arguments, 1), | ||||
|     returnedValue | ||||
|   ; | ||||
|   $allModules | ||||
|     .each(function() { | ||||
|       var | ||||
|         settings        = ( $.isPlainObject(parameters) ) | ||||
|           ? $.extend(true, {}, $.fn.rating.settings, parameters) | ||||
|           : $.extend({}, $.fn.rating.settings), | ||||
|  | ||||
|         namespace       = settings.namespace, | ||||
|         className       = settings.className, | ||||
|         metadata        = settings.metadata, | ||||
|         selector        = settings.selector, | ||||
|         error           = settings.error, | ||||
|  | ||||
|         eventNamespace  = '.' + namespace, | ||||
|         moduleNamespace = 'module-' + namespace, | ||||
|  | ||||
|         element         = this, | ||||
|         instance        = $(this).data(moduleNamespace), | ||||
|  | ||||
|         $module         = $(this), | ||||
|         $icon           = $module.find(selector.icon), | ||||
|  | ||||
|         initialLoad, | ||||
|         module | ||||
|       ; | ||||
|  | ||||
|       module = { | ||||
|  | ||||
|         initialize: function() { | ||||
|           module.verbose('Initializing rating module', settings); | ||||
|  | ||||
|           if($icon.length === 0) { | ||||
|             module.setup.layout(); | ||||
|           } | ||||
|  | ||||
|           if(settings.interactive) { | ||||
|             module.enable(); | ||||
|           } | ||||
|           else { | ||||
|             module.disable(); | ||||
|           } | ||||
|           module.set.initialLoad(); | ||||
|           module.set.rating( module.get.initialRating() ); | ||||
|           module.remove.initialLoad(); | ||||
|           module.instantiate(); | ||||
|         }, | ||||
|  | ||||
|         instantiate: function() { | ||||
|           module.verbose('Instantiating module', settings); | ||||
|           instance = module; | ||||
|           $module | ||||
|             .data(moduleNamespace, module) | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         destroy: function() { | ||||
|           module.verbose('Destroying previous instance', instance); | ||||
|           module.remove.events(); | ||||
|           $module | ||||
|             .removeData(moduleNamespace) | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         refresh: function() { | ||||
|           $icon   = $module.find(selector.icon); | ||||
|         }, | ||||
|  | ||||
|         setup: { | ||||
|           layout: function() { | ||||
|             var | ||||
|               maxRating = module.get.maxRating(), | ||||
|               html      = $.fn.rating.settings.templates.icon(maxRating) | ||||
|             ; | ||||
|             module.debug('Generating icon html dynamically'); | ||||
|             $module | ||||
|               .html(html) | ||||
|             ; | ||||
|             module.refresh(); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         event: { | ||||
|           mouseenter: function() { | ||||
|             var | ||||
|               $activeIcon = $(this) | ||||
|             ; | ||||
|             $activeIcon | ||||
|               .nextAll() | ||||
|                 .removeClass(className.selected) | ||||
|             ; | ||||
|             $module | ||||
|               .addClass(className.selected) | ||||
|             ; | ||||
|             $activeIcon | ||||
|               .addClass(className.selected) | ||||
|                 .prevAll() | ||||
|                 .addClass(className.selected) | ||||
|             ; | ||||
|           }, | ||||
|           mouseleave: function() { | ||||
|             $module | ||||
|               .removeClass(className.selected) | ||||
|             ; | ||||
|             $icon | ||||
|               .removeClass(className.selected) | ||||
|             ; | ||||
|           }, | ||||
|           click: function() { | ||||
|             var | ||||
|               $activeIcon   = $(this), | ||||
|               currentRating = module.get.rating(), | ||||
|               rating        = $icon.index($activeIcon) + 1, | ||||
|               canClear      = (settings.clearable == 'auto') | ||||
|                ? ($icon.length === 1) | ||||
|                : settings.clearable | ||||
|             ; | ||||
|             if(canClear && currentRating == rating) { | ||||
|               module.clearRating(); | ||||
|             } | ||||
|             else { | ||||
|               module.set.rating( rating ); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         clearRating: function() { | ||||
|           module.debug('Clearing current rating'); | ||||
|           module.set.rating(0); | ||||
|         }, | ||||
|  | ||||
|         bind: { | ||||
|           events: function() { | ||||
|             module.verbose('Binding events'); | ||||
|             $module | ||||
|               .on('mouseenter' + eventNamespace, selector.icon, module.event.mouseenter) | ||||
|               .on('mouseleave' + eventNamespace, selector.icon, module.event.mouseleave) | ||||
|               .on('click'      + eventNamespace, selector.icon, module.event.click) | ||||
|             ; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         remove: { | ||||
|           events: function() { | ||||
|             module.verbose('Removing events'); | ||||
|             $module | ||||
|               .off(eventNamespace) | ||||
|             ; | ||||
|           }, | ||||
|           initialLoad: function() { | ||||
|             initialLoad = false; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         enable: function() { | ||||
|           module.debug('Setting rating to interactive mode'); | ||||
|           module.bind.events(); | ||||
|           $module | ||||
|             .removeClass(className.disabled) | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         disable: function() { | ||||
|           module.debug('Setting rating to read-only mode'); | ||||
|           module.remove.events(); | ||||
|           $module | ||||
|             .addClass(className.disabled) | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         is: { | ||||
|           initialLoad: function() { | ||||
|             return initialLoad; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         get: { | ||||
|           initialRating: function() { | ||||
|             if($module.data(metadata.rating) !== undefined) { | ||||
|               $module.removeData(metadata.rating); | ||||
|               return $module.data(metadata.rating); | ||||
|             } | ||||
|             return settings.initialRating; | ||||
|           }, | ||||
|           maxRating: function() { | ||||
|             if($module.data(metadata.maxRating) !== undefined) { | ||||
|               $module.removeData(metadata.maxRating); | ||||
|               return $module.data(metadata.maxRating); | ||||
|             } | ||||
|             return settings.maxRating; | ||||
|           }, | ||||
|           rating: function() { | ||||
|             var | ||||
|               currentRating = $icon.filter('.' + className.active).length | ||||
|             ; | ||||
|             module.verbose('Current rating retrieved', currentRating); | ||||
|             return currentRating; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         set: { | ||||
|           rating: function(rating) { | ||||
|             var | ||||
|               ratingIndex = (rating - 1 >= 0) | ||||
|                 ? (rating - 1) | ||||
|                 : 0, | ||||
|               $activeIcon = $icon.eq(ratingIndex) | ||||
|             ; | ||||
|             $module | ||||
|               .removeClass(className.selected) | ||||
|             ; | ||||
|             $icon | ||||
|               .removeClass(className.selected) | ||||
|               .removeClass(className.active) | ||||
|             ; | ||||
|             if(rating > 0) { | ||||
|               module.verbose('Setting current rating to', rating); | ||||
|               $activeIcon | ||||
|                 .prevAll() | ||||
|                 .addBack() | ||||
|                   .addClass(className.active) | ||||
|               ; | ||||
|             } | ||||
|             if(!module.is.initialLoad()) { | ||||
|               settings.onRate.call(element, rating); | ||||
|             } | ||||
|           }, | ||||
|           initialLoad: function() { | ||||
|             initialLoad = true; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         setting: function(name, value) { | ||||
|           module.debug('Changing setting', name, value); | ||||
|           if( $.isPlainObject(name) ) { | ||||
|             $.extend(true, settings, name); | ||||
|           } | ||||
|           else if(value !== undefined) { | ||||
|             if($.isPlainObject(settings[name])) { | ||||
|               $.extend(true, settings[name], value); | ||||
|             } | ||||
|             else { | ||||
|               settings[name] = value; | ||||
|             } | ||||
|           } | ||||
|           else { | ||||
|             return settings[name]; | ||||
|           } | ||||
|         }, | ||||
|         internal: function(name, value) { | ||||
|           if( $.isPlainObject(name) ) { | ||||
|             $.extend(true, module, name); | ||||
|           } | ||||
|           else if(value !== undefined) { | ||||
|             module[name] = value; | ||||
|           } | ||||
|           else { | ||||
|             return module[name]; | ||||
|           } | ||||
|         }, | ||||
|         debug: function() { | ||||
|           if(!settings.silent && settings.debug) { | ||||
|             if(settings.performance) { | ||||
|               module.performance.log(arguments); | ||||
|             } | ||||
|             else { | ||||
|               module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|               module.debug.apply(console, arguments); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         verbose: function() { | ||||
|           if(!settings.silent && settings.verbose && settings.debug) { | ||||
|             if(settings.performance) { | ||||
|               module.performance.log(arguments); | ||||
|             } | ||||
|             else { | ||||
|               module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|               module.verbose.apply(console, arguments); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         error: function() { | ||||
|           if(!settings.silent) { | ||||
|             module.error = Function.prototype.bind.call(console.error, console, settings.name + ':'); | ||||
|             module.error.apply(console, arguments); | ||||
|           } | ||||
|         }, | ||||
|         performance: { | ||||
|           log: function(message) { | ||||
|             var | ||||
|               currentTime, | ||||
|               executionTime, | ||||
|               previousTime | ||||
|             ; | ||||
|             if(settings.performance) { | ||||
|               currentTime   = new Date().getTime(); | ||||
|               previousTime  = time || currentTime; | ||||
|               executionTime = currentTime - previousTime; | ||||
|               time          = currentTime; | ||||
|               performance.push({ | ||||
|                 'Name'           : message[0], | ||||
|                 'Arguments'      : [].slice.call(message, 1) || '', | ||||
|                 'Element'        : element, | ||||
|                 'Execution Time' : executionTime | ||||
|               }); | ||||
|             } | ||||
|             clearTimeout(module.performance.timer); | ||||
|             module.performance.timer = setTimeout(module.performance.display, 500); | ||||
|           }, | ||||
|           display: function() { | ||||
|             var | ||||
|               title = settings.name + ':', | ||||
|               totalTime = 0 | ||||
|             ; | ||||
|             time = false; | ||||
|             clearTimeout(module.performance.timer); | ||||
|             $.each(performance, function(index, data) { | ||||
|               totalTime += data['Execution Time']; | ||||
|             }); | ||||
|             title += ' ' + totalTime + 'ms'; | ||||
|             if(moduleSelector) { | ||||
|               title += ' \'' + moduleSelector + '\''; | ||||
|             } | ||||
|             if($allModules.length > 1) { | ||||
|               title += ' ' + '(' + $allModules.length + ')'; | ||||
|             } | ||||
|             if( (console.group !== undefined || console.table !== undefined) && performance.length > 0) { | ||||
|               console.groupCollapsed(title); | ||||
|               if(console.table) { | ||||
|                 console.table(performance); | ||||
|               } | ||||
|               else { | ||||
|                 $.each(performance, function(index, data) { | ||||
|                   console.log(data['Name'] + ': ' + data['Execution Time']+'ms'); | ||||
|                 }); | ||||
|               } | ||||
|               console.groupEnd(); | ||||
|             } | ||||
|             performance = []; | ||||
|           } | ||||
|         }, | ||||
|         invoke: function(query, passedArguments, context) { | ||||
|           var | ||||
|             object = instance, | ||||
|             maxDepth, | ||||
|             found, | ||||
|             response | ||||
|           ; | ||||
|           passedArguments = passedArguments || queryArguments; | ||||
|           context         = element         || context; | ||||
|           if(typeof query == 'string' && object !== undefined) { | ||||
|             query    = query.split(/[\. ]/); | ||||
|             maxDepth = query.length - 1; | ||||
|             $.each(query, function(depth, value) { | ||||
|               var camelCaseValue = (depth != maxDepth) | ||||
|                 ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1) | ||||
|                 : query | ||||
|               ; | ||||
|               if( $.isPlainObject( object[camelCaseValue] ) && (depth != maxDepth) ) { | ||||
|                 object = object[camelCaseValue]; | ||||
|               } | ||||
|               else if( object[camelCaseValue] !== undefined ) { | ||||
|                 found = object[camelCaseValue]; | ||||
|                 return false; | ||||
|               } | ||||
|               else if( $.isPlainObject( object[value] ) && (depth != maxDepth) ) { | ||||
|                 object = object[value]; | ||||
|               } | ||||
|               else if( object[value] !== undefined ) { | ||||
|                 found = object[value]; | ||||
|                 return false; | ||||
|               } | ||||
|               else { | ||||
|                 return false; | ||||
|               } | ||||
|             }); | ||||
|           } | ||||
|           if ( $.isFunction( found ) ) { | ||||
|             response = found.apply(context, passedArguments); | ||||
|           } | ||||
|           else if(found !== undefined) { | ||||
|             response = found; | ||||
|           } | ||||
|           if($.isArray(returnedValue)) { | ||||
|             returnedValue.push(response); | ||||
|           } | ||||
|           else if(returnedValue !== undefined) { | ||||
|             returnedValue = [returnedValue, response]; | ||||
|           } | ||||
|           else if(response !== undefined) { | ||||
|             returnedValue = response; | ||||
|           } | ||||
|           return found; | ||||
|         } | ||||
|       }; | ||||
|       if(methodInvoked) { | ||||
|         if(instance === undefined) { | ||||
|           module.initialize(); | ||||
|         } | ||||
|         module.invoke(query); | ||||
|       } | ||||
|       else { | ||||
|         if(instance !== undefined) { | ||||
|           instance.invoke('destroy'); | ||||
|         } | ||||
|         module.initialize(); | ||||
|       } | ||||
|     }) | ||||
|   ; | ||||
|  | ||||
|   return (returnedValue !== undefined) | ||||
|     ? returnedValue | ||||
|     : this | ||||
|   ; | ||||
| }; | ||||
|  | ||||
| $.fn.rating.settings = { | ||||
|  | ||||
|   name          : 'Rating', | ||||
|   namespace     : 'rating', | ||||
|  | ||||
|   slent         : false, | ||||
|   debug         : false, | ||||
|   verbose       : false, | ||||
|   performance   : true, | ||||
|  | ||||
|   initialRating : 0, | ||||
|   interactive   : true, | ||||
|   maxRating     : 4, | ||||
|   clearable     : 'auto', | ||||
|  | ||||
|   fireOnInit    : false, | ||||
|  | ||||
|   onRate        : function(rating){}, | ||||
|  | ||||
|   error         : { | ||||
|     method    : 'The method you called is not defined', | ||||
|     noMaximum : 'No maximum rating specified. Cannot generate HTML automatically' | ||||
|   }, | ||||
|  | ||||
|  | ||||
|   metadata: { | ||||
|     rating    : 'rating', | ||||
|     maxRating : 'maxRating' | ||||
|   }, | ||||
|  | ||||
|   className : { | ||||
|     active   : 'active', | ||||
|     disabled : 'disabled', | ||||
|     selected : 'selected', | ||||
|     loading  : 'loading' | ||||
|   }, | ||||
|  | ||||
|   selector  : { | ||||
|     icon : '.icon' | ||||
|   }, | ||||
|  | ||||
|   templates: { | ||||
|     icon: function(maxRating) { | ||||
|       var | ||||
|         icon = 1, | ||||
|         html = '' | ||||
|       ; | ||||
|       while(icon <= maxRating) { | ||||
|         html += '<i class="icon"></i>'; | ||||
|         icon++; | ||||
|       } | ||||
|       return html; | ||||
|     } | ||||
|   } | ||||
|  | ||||
| }; | ||||
|  | ||||
| })( jQuery, window, document ); | ||||
| @@ -1,191 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Rating | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'module'; | ||||
| @element : 'rating'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|            Rating | ||||
| *******************************/ | ||||
|  | ||||
| .ui.rating { | ||||
|   display: inline-flex; | ||||
|   white-space: @whiteSpace; | ||||
|   vertical-align: @verticalAlign; | ||||
| } | ||||
| .ui.rating:last-child { | ||||
|   margin-right: 0em; | ||||
| } | ||||
|  | ||||
| /* Icon */ | ||||
| .ui.rating .icon { | ||||
|   padding: 0em; | ||||
|   margin: 0em; | ||||
|   text-align: center; | ||||
|   font-weight: @normal; | ||||
|   font-style: normal; | ||||
|   flex: 1 0 auto; | ||||
|   cursor: @iconCursor; | ||||
|   width: @iconWidth; | ||||
|   height: @iconHeight; | ||||
|   transition: @iconTransition; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|              Types | ||||
| *******************************/ | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|       Standard | ||||
| --------------------*/ | ||||
|  | ||||
| /* Inactive Icon */ | ||||
| .ui.rating .icon { | ||||
|   background: @inactiveBackground; | ||||
|   color: @inactiveColor; | ||||
| } | ||||
|  | ||||
| /* Active Icon */ | ||||
| .ui.rating .active.icon { | ||||
|   background: @activeBackground; | ||||
|   color: @activeColor; | ||||
| } | ||||
|  | ||||
| /* Selected Icon */ | ||||
| .ui.rating .icon.selected, | ||||
| .ui.rating .icon.selected.active { | ||||
|   background: @selectedBackground; | ||||
|   color: @selectedColor; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|         Star | ||||
| --------------------*/ | ||||
|  | ||||
| /* Inactive */ | ||||
| .ui.star.rating .icon { | ||||
|   width: @starIconWidth; | ||||
|   height: @starIconHeight; | ||||
|   background: @starInactiveBackground; | ||||
|   color: @starInactiveColor; | ||||
|   text-shadow: @starInactiveTextShadow; | ||||
| } | ||||
|  | ||||
| /* Active Star */ | ||||
| .ui.star.rating .active.icon { | ||||
|   background: @starActiveBackground !important; | ||||
|   color: @starActiveColor !important; | ||||
|   text-shadow: @starActiveTextShadow !important; | ||||
| } | ||||
|  | ||||
| /* Selected Star */ | ||||
| .ui.star.rating .icon.selected, | ||||
| .ui.star.rating .icon.selected.active { | ||||
|   background: @starSelectedBackground !important; | ||||
|   color: @starSelectedColor !important; | ||||
|   text-shadow: @starSelectedTextShadow !important; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|         Heart | ||||
| --------------------*/ | ||||
|  | ||||
| .ui.heart.rating .icon { | ||||
|   width: @heartIconWidth; | ||||
|   height: @heartIconHeight; | ||||
|   background: @heartInactiveBackground; | ||||
|   color: @heartInactiveColor; | ||||
|   text-shadow: @heartInactiveTextShadow !important; | ||||
| } | ||||
|  | ||||
| /* Active Heart */ | ||||
| .ui.heart.rating .active.icon { | ||||
|   background: @heartActiveBackground !important; | ||||
|   color: @heartActiveColor !important; | ||||
|   text-shadow: @heartActiveTextShadow !important; | ||||
| } | ||||
|  | ||||
| /* Selected Heart */ | ||||
| .ui.heart.rating .icon.selected, | ||||
| .ui.heart.rating .icon.selected.active { | ||||
|   background: @heartSelectedBackground !important; | ||||
|   color: @heartSelectedColor !important; | ||||
|   text-shadow: @heartSelectedTextShadow !important; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|              States | ||||
| *******************************/ | ||||
|  | ||||
| /*------------------- | ||||
|        Disabled | ||||
| --------------------*/ | ||||
|  | ||||
| /* disabled rating */ | ||||
| .ui.disabled.rating .icon { | ||||
|   cursor: default; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*------------------- | ||||
|    User Interactive | ||||
| --------------------*/ | ||||
|  | ||||
| /* Selected Rating */ | ||||
| .ui.rating.selected .active.icon { | ||||
|   opacity: @interactiveActiveIconOpacity; | ||||
| } | ||||
| .ui.rating.selected .icon.selected, | ||||
| .ui.rating .icon.selected { | ||||
|   opacity: @interactiveSelectedIconOpacity; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|           Variations | ||||
| *******************************/ | ||||
|  | ||||
| .ui.mini.rating { | ||||
|   font-size: @mini; | ||||
| } | ||||
| .ui.tiny.rating { | ||||
|   font-size: @tiny; | ||||
| } | ||||
| .ui.small.rating { | ||||
|   font-size: @small; | ||||
| } | ||||
| .ui.rating { | ||||
|   font-size: @medium; | ||||
| } | ||||
| .ui.large.rating { | ||||
|   font-size: @large; | ||||
| } | ||||
| .ui.huge.rating { | ||||
|   font-size: @huge; | ||||
| } | ||||
| .ui.massive.rating { | ||||
|   font-size: @massive; | ||||
| } | ||||
|  | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,448 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Search | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'module'; | ||||
| @element : 'search'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|              Search | ||||
| *******************************/ | ||||
|  | ||||
| .ui.search { | ||||
|   position: relative; | ||||
| } | ||||
|  | ||||
| .ui.search > .prompt { | ||||
|   margin: 0em; | ||||
|   outline: none; | ||||
|   -webkit-appearance: none; | ||||
|   -webkit-tap-highlight-color:  rgba(255, 255, 255, 0); | ||||
|  | ||||
|   text-shadow: none; | ||||
|   font-style: normal; | ||||
|   font-weight: @normal; | ||||
|  | ||||
|   line-height: @promptLineHeight; | ||||
|   padding: @promptPadding; | ||||
|   font-size: @promptFontSize; | ||||
|  | ||||
|   background: @promptBackground; | ||||
|   border: @promptBorder; | ||||
|   color: @promptColor; | ||||
|   box-shadow: @promptBoxShadow; | ||||
|   transition: @promptTransition; | ||||
| } | ||||
|  | ||||
| .ui.search .prompt { | ||||
|   border-radius: @promptBorderRadius; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|      Icon | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.search .prompt ~ .search.icon { | ||||
|   cursor: pointer; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Results | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.search > .results { | ||||
|   display: none; | ||||
|  | ||||
|   position: absolute; | ||||
|   top: 100%; | ||||
|   left: 0%; | ||||
|   transform-origin: center top; | ||||
|   white-space: normal; | ||||
|   text-align: left; | ||||
|   text-transform: none; | ||||
|  | ||||
|   background: @resultsBackground; | ||||
|  | ||||
|   margin-top: @resultsDistance; | ||||
|   width: @resultsWidth; | ||||
|  | ||||
|   border-radius: @resultsBorderRadius; | ||||
|   box-shadow: @resultsBoxShadow; | ||||
|   border: @resultsBorder; | ||||
|   z-index: @resultsZIndex; | ||||
| } | ||||
| .ui.search > .results > :first-child { | ||||
|   border-radius: @resultsBorderRadius @resultsBorderRadius 0em 0em; | ||||
| } | ||||
| .ui.search > .results > :last-child { | ||||
|   border-radius: 0em 0em @resultsBorderRadius @resultsBorderRadius; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Result | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.search > .results .result { | ||||
|   cursor: pointer; | ||||
|   display: block; | ||||
|   overflow: hidden; | ||||
|   font-size: @resultFontSize; | ||||
|   padding: @resultPadding; | ||||
|   color: @resultTextColor; | ||||
|   line-height: @resultLineHeight; | ||||
|   border-bottom: @resultDivider; | ||||
| } | ||||
| .ui.search > .results .result:last-child { | ||||
|   border-bottom: @resultLastDivider !important; | ||||
| } | ||||
|  | ||||
| /* Image */ | ||||
| .ui.search > .results .result .image { | ||||
|   float: @resultImageFloat; | ||||
|   overflow: hidden; | ||||
|   background: @resultImageBackground; | ||||
|   width: @resultImageWidth; | ||||
|   height: @resultImageHeight; | ||||
|   border-radius: @resultImageBorderRadius; | ||||
| } | ||||
| .ui.search > .results .result .image img { | ||||
|   display: block; | ||||
|   width: auto; | ||||
|   height: 100%; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|       Info | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.search > .results .result .image + .content { | ||||
|   margin: @resultImageMargin; | ||||
| } | ||||
|  | ||||
| .ui.search > .results .result .title { | ||||
|   margin: @resultTitleMargin; | ||||
|   font-family: @resultTitleFont; | ||||
|   font-weight: @resultTitleFontWeight; | ||||
|   font-size: @resultTitleFontSize; | ||||
|   color: @resultTitleColor; | ||||
| } | ||||
| .ui.search > .results .result .description { | ||||
|   margin-top: @resultDescriptionDistance; | ||||
|   font-size: @resultDescriptionFontSize; | ||||
|   color: @resultDescriptionColor; | ||||
| } | ||||
| .ui.search > .results .result .price { | ||||
|   float: @resultPriceFloat; | ||||
|   color: @resultPriceColor; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Message | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.search > .results > .message { | ||||
|   padding: @messageVerticalPadding @messageHorizontalPadding; | ||||
| } | ||||
| .ui.search > .results > .message .header { | ||||
|   font-family: @headerFont; | ||||
|   font-size: @messageHeaderFontSize; | ||||
|   font-weight: @messageHeaderFontWeight; | ||||
|   color: @messageHeaderColor; | ||||
| } | ||||
| .ui.search > .results > .message .description { | ||||
|   margin-top: @messageDescriptionDistance; | ||||
|   font-size: @messageDescriptionFontSize; | ||||
|   color: @messageDescriptionColor; | ||||
| } | ||||
|  | ||||
| /* View All Results */ | ||||
| .ui.search > .results > .action { | ||||
|   display: block; | ||||
|   border-top: @actionBorder; | ||||
|   background: @actionBackground; | ||||
|   padding: @actionPadding; | ||||
|   color: @actionColor; | ||||
|   font-weight: @actionFontWeight; | ||||
|   text-align: @actionAlign; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             States | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------------- | ||||
|        Focus | ||||
| ---------------------*/ | ||||
|  | ||||
| .ui.search > .prompt:focus { | ||||
|   border-color: @promptFocusBorderColor; | ||||
|   background: @promptFocusBackground; | ||||
|   color: @promptFocusColor; | ||||
| } | ||||
|  | ||||
| /*-------------------- | ||||
|        Loading | ||||
| ---------------------*/ | ||||
|  | ||||
| .ui.loading.search .input > i.icon:before { | ||||
|   position: absolute; | ||||
|   content: ''; | ||||
|   top: 50%; | ||||
|   left: 50%; | ||||
|  | ||||
|   margin: @loaderMargin; | ||||
|   width: @loaderSize; | ||||
|   height: @loaderSize; | ||||
|  | ||||
|   border-radius: @circularRadius; | ||||
|   border: @loaderLineWidth solid @loaderFillColor; | ||||
| } | ||||
| .ui.loading.search .input > i.icon:after { | ||||
|   position: absolute; | ||||
|   content: ''; | ||||
|   top: 50%; | ||||
|   left: 50%; | ||||
|  | ||||
|   margin: @loaderMargin; | ||||
|   width: @loaderSize; | ||||
|   height: @loaderSize; | ||||
|  | ||||
|   animation: button-spin @loaderSpeed linear; | ||||
|   animation-iteration-count: infinite; | ||||
|  | ||||
|   border-radius: @circularRadius; | ||||
|  | ||||
|   border-color: @loaderLineColor transparent transparent; | ||||
|   border-style: solid; | ||||
|   border-width: @loaderLineWidth; | ||||
|  | ||||
|   box-shadow: 0px 0px 0px 1px transparent; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|       Hover | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.search > .results .result:hover, | ||||
| .ui.category.search > .results .category .result:hover { | ||||
|   background: @resultHoverBackground; | ||||
| } | ||||
| .ui.search .action:hover { | ||||
|   background: @actionHoverBackground; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|       Active | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.category.search > .results .category.active { | ||||
|   background: @categoryActiveBackground; | ||||
| } | ||||
| .ui.category.search > .results .category.active > .name { | ||||
|   color: @categoryNameActiveColor; | ||||
| } | ||||
|  | ||||
| .ui.search > .results .result.active, | ||||
| .ui.category.search > .results .category .result.active { | ||||
|   position: relative; | ||||
|   border-left-color: @resultActiveBorderLeft; | ||||
|   background: @resultActiveBackground; | ||||
|   box-shadow: @resultActiveBoxShadow; | ||||
| } | ||||
| .ui.search > .results .result.active .title { | ||||
|   color: @resultActiveTitleColor; | ||||
| } | ||||
| .ui.search > .results .result.active .description { | ||||
|   color: @resultActiveDescriptionColor; | ||||
| } | ||||
|  | ||||
| /*-------------------- | ||||
|         Disabled | ||||
| ----------------------*/ | ||||
|  | ||||
| /* Disabled */ | ||||
| .ui.disabled.search { | ||||
|   cursor: default; | ||||
|   pointer-events: none; | ||||
|   opacity: @disabledOpacity; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|            Types | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|     Selection | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.search.selection .prompt { | ||||
|   border-radius: @selectionPromptBorderRadius; | ||||
| } | ||||
|  | ||||
| /* Remove input */ | ||||
| .ui.search.selection > .icon.input > .remove.icon { | ||||
|   pointer-events: none; | ||||
|   position: absolute; | ||||
|   left: auto; | ||||
|   opacity: 0; | ||||
|   color: @selectionCloseIconColor; | ||||
|   top: @selectionCloseTop; | ||||
|   right: @selectionCloseRight; | ||||
|   transition: @selectionCloseTransition; | ||||
| } | ||||
| .ui.search.selection > .icon.input > .active.remove.icon { | ||||
|   cursor: pointer; | ||||
|   opacity: @selectionCloseIconOpacity; | ||||
|   pointer-events: auto; | ||||
| } | ||||
| .ui.search.selection > .icon.input:not([class*="left icon"]) > .icon ~ .remove.icon { | ||||
|   right: @selectionCloseIconInputRight; | ||||
| } | ||||
| .ui.search.selection > .icon.input > .remove.icon:hover { | ||||
|   opacity: @selectionCloseIconHoverOpacity; | ||||
|   color: @selectionCloseIconHoverColor; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|     Category | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.category.search .results { | ||||
|   width: @categoryResultsWidth; | ||||
| } | ||||
|  | ||||
| .ui.category.search .results.animating, | ||||
| .ui.category.search .results.visible { | ||||
|   display: table; | ||||
| } | ||||
|  | ||||
| /* Category */ | ||||
| .ui.category.search > .results .category { | ||||
|   display: table-row; | ||||
|   background: @categoryBackground; | ||||
|   box-shadow: @categoryBoxShadow; | ||||
|   transition: @categoryTransition; | ||||
| } | ||||
|  | ||||
| /* Last Category */ | ||||
| .ui.category.search > .results .category:last-child { | ||||
|   border-bottom: none; | ||||
| } | ||||
|  | ||||
| /* First / Last */ | ||||
| .ui.category.search > .results .category:first-child .name + .result { | ||||
|   border-radius: 0em @resultsBorderRadius 0em 0em; | ||||
| } | ||||
| .ui.category.search > .results .category:last-child .result:last-child { | ||||
|   border-radius: 0em 0em @resultsBorderRadius 0em; | ||||
| } | ||||
|  | ||||
| /* Category Result Name */ | ||||
| .ui.category.search > .results .category > .name { | ||||
|   display: table-cell; | ||||
|   text-overflow: ellipsis; | ||||
|   width: @categoryNameWidth; | ||||
|   white-space: @categoryNameWhitespace; | ||||
|   background: @categoryNameBackground; | ||||
|   font-family: @categoryNameFont; | ||||
|   font-size: @categoryNameFontSize; | ||||
|   padding: @categoryNamePadding; | ||||
|   font-weight: @categoryNameFontWeight; | ||||
|   color: @categoryNameColor; | ||||
|   border-bottom: @categoryDivider; | ||||
| } | ||||
|  | ||||
| /* Category Result */ | ||||
| .ui.category.search > .results .category .results { | ||||
|   display: table-cell; | ||||
|   background: @categoryResultBackground; | ||||
|   border-left: @categoryResultLeftBorder; | ||||
|   border-bottom: @categoryDivider; | ||||
| } | ||||
| .ui.category.search > .results .category .result { | ||||
|   border-bottom: @categoryResultDivider; | ||||
|   transition: @categoryResultTransition; | ||||
|   padding: @categoryResultPadding; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|            Variations | ||||
| *******************************/ | ||||
|  | ||||
| /*------------------- | ||||
|      Left / Right | ||||
| --------------------*/ | ||||
|  | ||||
| .ui[class*="left aligned"].search > .results { | ||||
|   right: auto; | ||||
|   left: 0%; | ||||
| } | ||||
| .ui[class*="right aligned"].search > .results { | ||||
|   right: 0%; | ||||
|   left: auto; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Fluid | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.fluid.search .results { | ||||
|   width: 100%; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|       Sizes | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.mini.search { | ||||
|   font-size: @relativeMini; | ||||
| } | ||||
| .ui.small.search { | ||||
|   font-size: @relativeSmall; | ||||
| } | ||||
| .ui.search { | ||||
|   font-size: @relativeMedium; | ||||
| } | ||||
| .ui.large.search { | ||||
|   font-size: @relativeLarge; | ||||
| } | ||||
| .ui.big.search { | ||||
|   font-size: @relativeBig; | ||||
| } | ||||
| .ui.huge.search { | ||||
|   font-size: @relativeHuge; | ||||
| } | ||||
| .ui.massive.search { | ||||
|   font-size: @relativeMassive; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|       Mobile | ||||
| ---------------*/ | ||||
|  | ||||
| @media only screen and (max-width: @largestMobileScreen) { | ||||
|   .ui.search .results { | ||||
|     max-width: @mobileMaxWidth; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,921 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Shape | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| ;(function ($, window, document, undefined) { | ||||
|  | ||||
| 'use strict'; | ||||
|  | ||||
| window = (typeof window != 'undefined' && window.Math == Math) | ||||
|   ? window | ||||
|   : (typeof self != 'undefined' && self.Math == Math) | ||||
|     ? self | ||||
|     : Function('return this')() | ||||
| ; | ||||
|  | ||||
| $.fn.shape = function(parameters) { | ||||
|   var | ||||
|     $allModules     = $(this), | ||||
|     $body           = $('body'), | ||||
|  | ||||
|     time            = new Date().getTime(), | ||||
|     performance     = [], | ||||
|  | ||||
|     query           = arguments[0], | ||||
|     methodInvoked   = (typeof query == 'string'), | ||||
|     queryArguments  = [].slice.call(arguments, 1), | ||||
|  | ||||
|     requestAnimationFrame = window.requestAnimationFrame | ||||
|       || window.mozRequestAnimationFrame | ||||
|       || window.webkitRequestAnimationFrame | ||||
|       || window.msRequestAnimationFrame | ||||
|       || function(callback) { setTimeout(callback, 0); }, | ||||
|  | ||||
|     returnedValue | ||||
|   ; | ||||
|  | ||||
|   $allModules | ||||
|     .each(function() { | ||||
|       var | ||||
|         moduleSelector = $allModules.selector || '', | ||||
|         settings       = ( $.isPlainObject(parameters) ) | ||||
|           ? $.extend(true, {}, $.fn.shape.settings, parameters) | ||||
|           : $.extend({}, $.fn.shape.settings), | ||||
|  | ||||
|         // internal aliases | ||||
|         namespace     = settings.namespace, | ||||
|         selector      = settings.selector, | ||||
|         error         = settings.error, | ||||
|         className     = settings.className, | ||||
|  | ||||
|         // define namespaces for modules | ||||
|         eventNamespace  = '.' + namespace, | ||||
|         moduleNamespace = 'module-' + namespace, | ||||
|  | ||||
|         // selector cache | ||||
|         $module       = $(this), | ||||
|         $sides        = $module.find(selector.sides), | ||||
|         $side         = $module.find(selector.side), | ||||
|  | ||||
|         // private variables | ||||
|         nextIndex = false, | ||||
|         $activeSide, | ||||
|         $nextSide, | ||||
|  | ||||
|         // standard module | ||||
|         element       = this, | ||||
|         instance      = $module.data(moduleNamespace), | ||||
|         module | ||||
|       ; | ||||
|  | ||||
|       module = { | ||||
|  | ||||
|         initialize: function() { | ||||
|           module.verbose('Initializing module for', element); | ||||
|           module.set.defaultSide(); | ||||
|           module.instantiate(); | ||||
|         }, | ||||
|  | ||||
|         instantiate: function() { | ||||
|           module.verbose('Storing instance of module', module); | ||||
|           instance = module; | ||||
|           $module | ||||
|             .data(moduleNamespace, instance) | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         destroy: function() { | ||||
|           module.verbose('Destroying previous module for', element); | ||||
|           $module | ||||
|             .removeData(moduleNamespace) | ||||
|             .off(eventNamespace) | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         refresh: function() { | ||||
|           module.verbose('Refreshing selector cache for', element); | ||||
|           $module = $(element); | ||||
|           $sides  = $(this).find(selector.shape); | ||||
|           $side   = $(this).find(selector.side); | ||||
|         }, | ||||
|  | ||||
|         repaint: function() { | ||||
|           module.verbose('Forcing repaint event'); | ||||
|           var | ||||
|             shape          = $sides[0] || document.createElement('div'), | ||||
|             fakeAssignment = shape.offsetWidth | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         animate: function(propertyObject, callback) { | ||||
|           module.verbose('Animating box with properties', propertyObject); | ||||
|           callback = callback || function(event) { | ||||
|             module.verbose('Executing animation callback'); | ||||
|             if(event !== undefined) { | ||||
|               event.stopPropagation(); | ||||
|             } | ||||
|             module.reset(); | ||||
|             module.set.active(); | ||||
|           }; | ||||
|           settings.beforeChange.call($nextSide[0]); | ||||
|           if(module.get.transitionEvent()) { | ||||
|             module.verbose('Starting CSS animation'); | ||||
|             $module | ||||
|               .addClass(className.animating) | ||||
|             ; | ||||
|             $sides | ||||
|               .css(propertyObject) | ||||
|               .one(module.get.transitionEvent(), callback) | ||||
|             ; | ||||
|             module.set.duration(settings.duration); | ||||
|             requestAnimationFrame(function() { | ||||
|               $module | ||||
|                 .addClass(className.animating) | ||||
|               ; | ||||
|               $activeSide | ||||
|                 .addClass(className.hidden) | ||||
|               ; | ||||
|             }); | ||||
|           } | ||||
|           else { | ||||
|             callback(); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         queue: function(method) { | ||||
|           module.debug('Queueing animation of', method); | ||||
|           $sides | ||||
|             .one(module.get.transitionEvent(), function() { | ||||
|               module.debug('Executing queued animation'); | ||||
|               setTimeout(function(){ | ||||
|                 $module.shape(method); | ||||
|               }, 0); | ||||
|             }) | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         reset: function() { | ||||
|           module.verbose('Animating states reset'); | ||||
|           $module | ||||
|             .removeClass(className.animating) | ||||
|             .attr('style', '') | ||||
|             .removeAttr('style') | ||||
|           ; | ||||
|           // removeAttr style does not consistently work in safari | ||||
|           $sides | ||||
|             .attr('style', '') | ||||
|             .removeAttr('style') | ||||
|           ; | ||||
|           $side | ||||
|             .attr('style', '') | ||||
|             .removeAttr('style') | ||||
|             .removeClass(className.hidden) | ||||
|           ; | ||||
|           $nextSide | ||||
|             .removeClass(className.animating) | ||||
|             .attr('style', '') | ||||
|             .removeAttr('style') | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         is: { | ||||
|           complete: function() { | ||||
|             return ($side.filter('.' + className.active)[0] == $nextSide[0]); | ||||
|           }, | ||||
|           animating: function() { | ||||
|             return $module.hasClass(className.animating); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         set: { | ||||
|  | ||||
|           defaultSide: function() { | ||||
|             $activeSide = $module.find('.' + settings.className.active); | ||||
|             $nextSide   = ( $activeSide.next(selector.side).length > 0 ) | ||||
|               ? $activeSide.next(selector.side) | ||||
|               : $module.find(selector.side).first() | ||||
|             ; | ||||
|             nextIndex = false; | ||||
|             module.verbose('Active side set to', $activeSide); | ||||
|             module.verbose('Next side set to', $nextSide); | ||||
|           }, | ||||
|  | ||||
|           duration: function(duration) { | ||||
|             duration = duration || settings.duration; | ||||
|             duration = (typeof duration == 'number') | ||||
|               ? duration + 'ms' | ||||
|               : duration | ||||
|             ; | ||||
|             module.verbose('Setting animation duration', duration); | ||||
|             if(settings.duration || settings.duration === 0) { | ||||
|               $sides.add($side) | ||||
|                 .css({ | ||||
|                   '-webkit-transition-duration': duration, | ||||
|                   '-moz-transition-duration': duration, | ||||
|                   '-ms-transition-duration': duration, | ||||
|                   '-o-transition-duration': duration, | ||||
|                   'transition-duration': duration | ||||
|                 }) | ||||
|               ; | ||||
|             } | ||||
|           }, | ||||
|  | ||||
|           currentStageSize: function() { | ||||
|             var | ||||
|               $activeSide = $module.find('.' + settings.className.active), | ||||
|               width       = $activeSide.outerWidth(true), | ||||
|               height      = $activeSide.outerHeight(true) | ||||
|             ; | ||||
|             $module | ||||
|               .css({ | ||||
|                 width: width, | ||||
|                 height: height | ||||
|               }) | ||||
|             ; | ||||
|           }, | ||||
|  | ||||
|           stageSize: function() { | ||||
|             var | ||||
|               $clone      = $module.clone().addClass(className.loading), | ||||
|               $activeSide = $clone.find('.' + settings.className.active), | ||||
|               $nextSide   = (nextIndex) | ||||
|                 ? $clone.find(selector.side).eq(nextIndex) | ||||
|                 : ( $activeSide.next(selector.side).length > 0 ) | ||||
|                   ? $activeSide.next(selector.side) | ||||
|                   : $clone.find(selector.side).first(), | ||||
|               newWidth    = (settings.width == 'next') | ||||
|                 ? $nextSide.outerWidth(true) | ||||
|                 : (settings.width == 'initial') | ||||
|                   ? $module.width() | ||||
|                   : settings.width, | ||||
|               newHeight    = (settings.height == 'next') | ||||
|                 ? $nextSide.outerHeight(true) | ||||
|                 : (settings.height == 'initial') | ||||
|                   ? $module.height() | ||||
|                   : settings.height | ||||
|             ; | ||||
|             $activeSide.removeClass(className.active); | ||||
|             $nextSide.addClass(className.active); | ||||
|             $clone.insertAfter($module); | ||||
|             $clone.remove(); | ||||
|             if(settings.width != 'auto') { | ||||
|               $module.css('width', newWidth + settings.jitter); | ||||
|               module.verbose('Specifying width during animation', newWidth); | ||||
|             } | ||||
|             if(settings.height != 'auto') { | ||||
|               $module.css('height', newHeight + settings.jitter); | ||||
|               module.verbose('Specifying height during animation', newHeight); | ||||
|             } | ||||
|           }, | ||||
|  | ||||
|           nextSide: function(selector) { | ||||
|             nextIndex = selector; | ||||
|             $nextSide = $side.filter(selector); | ||||
|             nextIndex = $side.index($nextSide); | ||||
|             if($nextSide.length === 0) { | ||||
|               module.set.defaultSide(); | ||||
|               module.error(error.side); | ||||
|             } | ||||
|             module.verbose('Next side manually set to', $nextSide); | ||||
|           }, | ||||
|  | ||||
|           active: function() { | ||||
|             module.verbose('Setting new side to active', $nextSide); | ||||
|             $side | ||||
|               .removeClass(className.active) | ||||
|             ; | ||||
|             $nextSide | ||||
|               .addClass(className.active) | ||||
|             ; | ||||
|             settings.onChange.call($nextSide[0]); | ||||
|             module.set.defaultSide(); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         flip: { | ||||
|  | ||||
|           up: function() { | ||||
|             if(module.is.complete() && !module.is.animating() && !settings.allowRepeats) { | ||||
|               module.debug('Side already visible', $nextSide); | ||||
|               return; | ||||
|             } | ||||
|             if( !module.is.animating()) { | ||||
|               module.debug('Flipping up', $nextSide); | ||||
|               var | ||||
|                 transform = module.get.transform.up() | ||||
|               ; | ||||
|               module.set.stageSize(); | ||||
|               module.stage.above(); | ||||
|               module.animate(transform); | ||||
|             } | ||||
|             else { | ||||
|               module.queue('flip up'); | ||||
|             } | ||||
|           }, | ||||
|  | ||||
|           down: function() { | ||||
|             if(module.is.complete() && !module.is.animating() && !settings.allowRepeats) { | ||||
|               module.debug('Side already visible', $nextSide); | ||||
|               return; | ||||
|             } | ||||
|             if( !module.is.animating()) { | ||||
|               module.debug('Flipping down', $nextSide); | ||||
|               var | ||||
|                 transform = module.get.transform.down() | ||||
|               ; | ||||
|               module.set.stageSize(); | ||||
|               module.stage.below(); | ||||
|               module.animate(transform); | ||||
|             } | ||||
|             else { | ||||
|               module.queue('flip down'); | ||||
|             } | ||||
|           }, | ||||
|  | ||||
|           left: function() { | ||||
|             if(module.is.complete() && !module.is.animating() && !settings.allowRepeats) { | ||||
|               module.debug('Side already visible', $nextSide); | ||||
|               return; | ||||
|             } | ||||
|             if( !module.is.animating()) { | ||||
|               module.debug('Flipping left', $nextSide); | ||||
|               var | ||||
|                 transform = module.get.transform.left() | ||||
|               ; | ||||
|               module.set.stageSize(); | ||||
|               module.stage.left(); | ||||
|               module.animate(transform); | ||||
|             } | ||||
|             else { | ||||
|               module.queue('flip left'); | ||||
|             } | ||||
|           }, | ||||
|  | ||||
|           right: function() { | ||||
|             if(module.is.complete() && !module.is.animating() && !settings.allowRepeats) { | ||||
|               module.debug('Side already visible', $nextSide); | ||||
|               return; | ||||
|             } | ||||
|             if( !module.is.animating()) { | ||||
|               module.debug('Flipping right', $nextSide); | ||||
|               var | ||||
|                 transform = module.get.transform.right() | ||||
|               ; | ||||
|               module.set.stageSize(); | ||||
|               module.stage.right(); | ||||
|               module.animate(transform); | ||||
|             } | ||||
|             else { | ||||
|               module.queue('flip right'); | ||||
|             } | ||||
|           }, | ||||
|  | ||||
|           over: function() { | ||||
|             if(module.is.complete() && !module.is.animating() && !settings.allowRepeats) { | ||||
|               module.debug('Side already visible', $nextSide); | ||||
|               return; | ||||
|             } | ||||
|             if( !module.is.animating()) { | ||||
|               module.debug('Flipping over', $nextSide); | ||||
|               module.set.stageSize(); | ||||
|               module.stage.behind(); | ||||
|               module.animate(module.get.transform.over() ); | ||||
|             } | ||||
|             else { | ||||
|               module.queue('flip over'); | ||||
|             } | ||||
|           }, | ||||
|  | ||||
|           back: function() { | ||||
|             if(module.is.complete() && !module.is.animating() && !settings.allowRepeats) { | ||||
|               module.debug('Side already visible', $nextSide); | ||||
|               return; | ||||
|             } | ||||
|             if( !module.is.animating()) { | ||||
|               module.debug('Flipping back', $nextSide); | ||||
|               module.set.stageSize(); | ||||
|               module.stage.behind(); | ||||
|               module.animate(module.get.transform.back() ); | ||||
|             } | ||||
|             else { | ||||
|               module.queue('flip back'); | ||||
|             } | ||||
|           } | ||||
|  | ||||
|         }, | ||||
|  | ||||
|         get: { | ||||
|  | ||||
|           transform: { | ||||
|             up: function() { | ||||
|               var | ||||
|                 translate = { | ||||
|                   y: -(($activeSide.outerHeight(true) - $nextSide.outerHeight(true)) / 2), | ||||
|                   z: -($activeSide.outerHeight(true) / 2) | ||||
|                 } | ||||
|               ; | ||||
|               return { | ||||
|                 transform: 'translateY(' + translate.y + 'px) translateZ('+ translate.z + 'px) rotateX(-90deg)' | ||||
|               }; | ||||
|             }, | ||||
|  | ||||
|             down: function() { | ||||
|               var | ||||
|                 translate = { | ||||
|                   y: -(($activeSide.outerHeight(true) - $nextSide.outerHeight(true)) / 2), | ||||
|                   z: -($activeSide.outerHeight(true) / 2) | ||||
|                 } | ||||
|               ; | ||||
|               return { | ||||
|                 transform: 'translateY(' + translate.y + 'px) translateZ('+ translate.z + 'px) rotateX(90deg)' | ||||
|               }; | ||||
|             }, | ||||
|  | ||||
|             left: function() { | ||||
|               var | ||||
|                 translate = { | ||||
|                   x : -(($activeSide.outerWidth(true) - $nextSide.outerWidth(true)) / 2), | ||||
|                   z : -($activeSide.outerWidth(true) / 2) | ||||
|                 } | ||||
|               ; | ||||
|               return { | ||||
|                 transform: 'translateX(' + translate.x + 'px) translateZ(' + translate.z + 'px) rotateY(90deg)' | ||||
|               }; | ||||
|             }, | ||||
|  | ||||
|             right: function() { | ||||
|               var | ||||
|                 translate = { | ||||
|                   x : -(($activeSide.outerWidth(true) - $nextSide.outerWidth(true)) / 2), | ||||
|                   z : -($activeSide.outerWidth(true) / 2) | ||||
|                 } | ||||
|               ; | ||||
|               return { | ||||
|                 transform: 'translateX(' + translate.x + 'px) translateZ(' + translate.z + 'px) rotateY(-90deg)' | ||||
|               }; | ||||
|             }, | ||||
|  | ||||
|             over: function() { | ||||
|               var | ||||
|                 translate = { | ||||
|                   x : -(($activeSide.outerWidth(true) - $nextSide.outerWidth(true)) / 2) | ||||
|                 } | ||||
|               ; | ||||
|               return { | ||||
|                 transform: 'translateX(' + translate.x + 'px) rotateY(180deg)' | ||||
|               }; | ||||
|             }, | ||||
|  | ||||
|             back: function() { | ||||
|               var | ||||
|                 translate = { | ||||
|                   x : -(($activeSide.outerWidth(true) - $nextSide.outerWidth(true)) / 2) | ||||
|                 } | ||||
|               ; | ||||
|               return { | ||||
|                 transform: 'translateX(' + translate.x + 'px) rotateY(-180deg)' | ||||
|               }; | ||||
|             } | ||||
|           }, | ||||
|  | ||||
|           transitionEvent: function() { | ||||
|             var | ||||
|               element     = document.createElement('element'), | ||||
|               transitions = { | ||||
|                 'transition'       :'transitionend', | ||||
|                 'OTransition'      :'oTransitionEnd', | ||||
|                 'MozTransition'    :'transitionend', | ||||
|                 'WebkitTransition' :'webkitTransitionEnd' | ||||
|               }, | ||||
|               transition | ||||
|             ; | ||||
|             for(transition in transitions){ | ||||
|               if( element.style[transition] !== undefined ){ | ||||
|                 return transitions[transition]; | ||||
|               } | ||||
|             } | ||||
|           }, | ||||
|  | ||||
|           nextSide: function() { | ||||
|             return ( $activeSide.next(selector.side).length > 0 ) | ||||
|               ? $activeSide.next(selector.side) | ||||
|               : $module.find(selector.side).first() | ||||
|             ; | ||||
|           } | ||||
|  | ||||
|         }, | ||||
|  | ||||
|         stage: { | ||||
|  | ||||
|           above: function() { | ||||
|             var | ||||
|               box = { | ||||
|                 origin : (($activeSide.outerHeight(true) - $nextSide.outerHeight(true)) / 2), | ||||
|                 depth  : { | ||||
|                   active : ($nextSide.outerHeight(true) / 2), | ||||
|                   next   : ($activeSide.outerHeight(true) / 2) | ||||
|                 } | ||||
|               } | ||||
|             ; | ||||
|             module.verbose('Setting the initial animation position as above', $nextSide, box); | ||||
|             $sides | ||||
|               .css({ | ||||
|                 'transform' : 'translateZ(-' + box.depth.active + 'px)' | ||||
|               }) | ||||
|             ; | ||||
|             $activeSide | ||||
|               .css({ | ||||
|                 'transform' : 'rotateY(0deg) translateZ(' + box.depth.active + 'px)' | ||||
|               }) | ||||
|             ; | ||||
|             $nextSide | ||||
|               .addClass(className.animating) | ||||
|               .css({ | ||||
|                 'top'       : box.origin + 'px', | ||||
|                 'transform' : 'rotateX(90deg) translateZ(' + box.depth.next + 'px)' | ||||
|               }) | ||||
|             ; | ||||
|           }, | ||||
|  | ||||
|           below: function() { | ||||
|             var | ||||
|               box = { | ||||
|                 origin : (($activeSide.outerHeight(true) - $nextSide.outerHeight(true)) / 2), | ||||
|                 depth  : { | ||||
|                   active : ($nextSide.outerHeight(true) / 2), | ||||
|                   next   : ($activeSide.outerHeight(true) / 2) | ||||
|                 } | ||||
|               } | ||||
|             ; | ||||
|             module.verbose('Setting the initial animation position as below', $nextSide, box); | ||||
|             $sides | ||||
|               .css({ | ||||
|                 'transform' : 'translateZ(-' + box.depth.active + 'px)' | ||||
|               }) | ||||
|             ; | ||||
|             $activeSide | ||||
|               .css({ | ||||
|                 'transform' : 'rotateY(0deg) translateZ(' + box.depth.active + 'px)' | ||||
|               }) | ||||
|             ; | ||||
|             $nextSide | ||||
|               .addClass(className.animating) | ||||
|               .css({ | ||||
|                 'top'       : box.origin + 'px', | ||||
|                 'transform' : 'rotateX(-90deg) translateZ(' + box.depth.next + 'px)' | ||||
|               }) | ||||
|             ; | ||||
|           }, | ||||
|  | ||||
|           left: function() { | ||||
|             var | ||||
|               height = { | ||||
|                 active : $activeSide.outerWidth(true), | ||||
|                 next   : $nextSide.outerWidth(true) | ||||
|               }, | ||||
|               box = { | ||||
|                 origin : ( ( height.active - height.next ) / 2), | ||||
|                 depth  : { | ||||
|                   active : (height.next / 2), | ||||
|                   next   : (height.active / 2) | ||||
|                 } | ||||
|               } | ||||
|             ; | ||||
|             module.verbose('Setting the initial animation position as left', $nextSide, box); | ||||
|             $sides | ||||
|               .css({ | ||||
|                 'transform' : 'translateZ(-' + box.depth.active + 'px)' | ||||
|               }) | ||||
|             ; | ||||
|             $activeSide | ||||
|               .css({ | ||||
|                 'transform' : 'rotateY(0deg) translateZ(' + box.depth.active + 'px)' | ||||
|               }) | ||||
|             ; | ||||
|             $nextSide | ||||
|               .addClass(className.animating) | ||||
|               .css({ | ||||
|                 'left'      : box.origin + 'px', | ||||
|                 'transform' : 'rotateY(-90deg) translateZ(' + box.depth.next + 'px)' | ||||
|               }) | ||||
|             ; | ||||
|           }, | ||||
|  | ||||
|           right: function() { | ||||
|             var | ||||
|               height = { | ||||
|                 active : $activeSide.outerWidth(true), | ||||
|                 next   : $nextSide.outerWidth(true) | ||||
|               }, | ||||
|               box = { | ||||
|                 origin : ( ( height.active - height.next ) / 2), | ||||
|                 depth  : { | ||||
|                   active : (height.next / 2), | ||||
|                   next   : (height.active / 2) | ||||
|                 } | ||||
|               } | ||||
|             ; | ||||
|             module.verbose('Setting the initial animation position as left', $nextSide, box); | ||||
|             $sides | ||||
|               .css({ | ||||
|                 'transform' : 'translateZ(-' + box.depth.active + 'px)' | ||||
|               }) | ||||
|             ; | ||||
|             $activeSide | ||||
|               .css({ | ||||
|                 'transform' : 'rotateY(0deg) translateZ(' + box.depth.active + 'px)' | ||||
|               }) | ||||
|             ; | ||||
|             $nextSide | ||||
|               .addClass(className.animating) | ||||
|               .css({ | ||||
|                 'left'      : box.origin + 'px', | ||||
|                 'transform' : 'rotateY(90deg) translateZ(' + box.depth.next + 'px)' | ||||
|               }) | ||||
|             ; | ||||
|           }, | ||||
|  | ||||
|           behind: function() { | ||||
|             var | ||||
|               height = { | ||||
|                 active : $activeSide.outerWidth(true), | ||||
|                 next   : $nextSide.outerWidth(true) | ||||
|               }, | ||||
|               box = { | ||||
|                 origin : ( ( height.active - height.next ) / 2), | ||||
|                 depth  : { | ||||
|                   active : (height.next / 2), | ||||
|                   next   : (height.active / 2) | ||||
|                 } | ||||
|               } | ||||
|             ; | ||||
|             module.verbose('Setting the initial animation position as behind', $nextSide, box); | ||||
|             $activeSide | ||||
|               .css({ | ||||
|                 'transform' : 'rotateY(0deg)' | ||||
|               }) | ||||
|             ; | ||||
|             $nextSide | ||||
|               .addClass(className.animating) | ||||
|               .css({ | ||||
|                 'left'      : box.origin + 'px', | ||||
|                 'transform' : 'rotateY(-180deg)' | ||||
|               }) | ||||
|             ; | ||||
|           } | ||||
|         }, | ||||
|         setting: function(name, value) { | ||||
|           module.debug('Changing setting', name, value); | ||||
|           if( $.isPlainObject(name) ) { | ||||
|             $.extend(true, settings, name); | ||||
|           } | ||||
|           else if(value !== undefined) { | ||||
|             if($.isPlainObject(settings[name])) { | ||||
|               $.extend(true, settings[name], value); | ||||
|             } | ||||
|             else { | ||||
|               settings[name] = value; | ||||
|             } | ||||
|           } | ||||
|           else { | ||||
|             return settings[name]; | ||||
|           } | ||||
|         }, | ||||
|         internal: function(name, value) { | ||||
|           if( $.isPlainObject(name) ) { | ||||
|             $.extend(true, module, name); | ||||
|           } | ||||
|           else if(value !== undefined) { | ||||
|             module[name] = value; | ||||
|           } | ||||
|           else { | ||||
|             return module[name]; | ||||
|           } | ||||
|         }, | ||||
|         debug: function() { | ||||
|           if(!settings.silent && settings.debug) { | ||||
|             if(settings.performance) { | ||||
|               module.performance.log(arguments); | ||||
|             } | ||||
|             else { | ||||
|               module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|               module.debug.apply(console, arguments); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         verbose: function() { | ||||
|           if(!settings.silent && settings.verbose && settings.debug) { | ||||
|             if(settings.performance) { | ||||
|               module.performance.log(arguments); | ||||
|             } | ||||
|             else { | ||||
|               module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|               module.verbose.apply(console, arguments); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         error: function() { | ||||
|           if(!settings.silent) { | ||||
|             module.error = Function.prototype.bind.call(console.error, console, settings.name + ':'); | ||||
|             module.error.apply(console, arguments); | ||||
|           } | ||||
|         }, | ||||
|         performance: { | ||||
|           log: function(message) { | ||||
|             var | ||||
|               currentTime, | ||||
|               executionTime, | ||||
|               previousTime | ||||
|             ; | ||||
|             if(settings.performance) { | ||||
|               currentTime   = new Date().getTime(); | ||||
|               previousTime  = time || currentTime; | ||||
|               executionTime = currentTime - previousTime; | ||||
|               time          = currentTime; | ||||
|               performance.push({ | ||||
|                 'Name'           : message[0], | ||||
|                 'Arguments'      : [].slice.call(message, 1) || '', | ||||
|                 'Element'        : element, | ||||
|                 'Execution Time' : executionTime | ||||
|               }); | ||||
|             } | ||||
|             clearTimeout(module.performance.timer); | ||||
|             module.performance.timer = setTimeout(module.performance.display, 500); | ||||
|           }, | ||||
|           display: function() { | ||||
|             var | ||||
|               title = settings.name + ':', | ||||
|               totalTime = 0 | ||||
|             ; | ||||
|             time = false; | ||||
|             clearTimeout(module.performance.timer); | ||||
|             $.each(performance, function(index, data) { | ||||
|               totalTime += data['Execution Time']; | ||||
|             }); | ||||
|             title += ' ' + totalTime + 'ms'; | ||||
|             if(moduleSelector) { | ||||
|               title += ' \'' + moduleSelector + '\''; | ||||
|             } | ||||
|             if($allModules.length > 1) { | ||||
|               title += ' ' + '(' + $allModules.length + ')'; | ||||
|             } | ||||
|             if( (console.group !== undefined || console.table !== undefined) && performance.length > 0) { | ||||
|               console.groupCollapsed(title); | ||||
|               if(console.table) { | ||||
|                 console.table(performance); | ||||
|               } | ||||
|               else { | ||||
|                 $.each(performance, function(index, data) { | ||||
|                   console.log(data['Name'] + ': ' + data['Execution Time']+'ms'); | ||||
|                 }); | ||||
|               } | ||||
|               console.groupEnd(); | ||||
|             } | ||||
|             performance = []; | ||||
|           } | ||||
|         }, | ||||
|         invoke: function(query, passedArguments, context) { | ||||
|           var | ||||
|             object = instance, | ||||
|             maxDepth, | ||||
|             found, | ||||
|             response | ||||
|           ; | ||||
|           passedArguments = passedArguments || queryArguments; | ||||
|           context         = element         || context; | ||||
|           if(typeof query == 'string' && object !== undefined) { | ||||
|             query    = query.split(/[\. ]/); | ||||
|             maxDepth = query.length - 1; | ||||
|             $.each(query, function(depth, value) { | ||||
|               var camelCaseValue = (depth != maxDepth) | ||||
|                 ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1) | ||||
|                 : query | ||||
|               ; | ||||
|               if( $.isPlainObject( object[camelCaseValue] ) && (depth != maxDepth) ) { | ||||
|                 object = object[camelCaseValue]; | ||||
|               } | ||||
|               else if( object[camelCaseValue] !== undefined ) { | ||||
|                 found = object[camelCaseValue]; | ||||
|                 return false; | ||||
|               } | ||||
|               else if( $.isPlainObject( object[value] ) && (depth != maxDepth) ) { | ||||
|                 object = object[value]; | ||||
|               } | ||||
|               else if( object[value] !== undefined ) { | ||||
|                 found = object[value]; | ||||
|                 return false; | ||||
|               } | ||||
|               else { | ||||
|                 return false; | ||||
|               } | ||||
|             }); | ||||
|           } | ||||
|           if ( $.isFunction( found ) ) { | ||||
|             response = found.apply(context, passedArguments); | ||||
|           } | ||||
|           else if(found !== undefined) { | ||||
|             response = found; | ||||
|           } | ||||
|           if($.isArray(returnedValue)) { | ||||
|             returnedValue.push(response); | ||||
|           } | ||||
|           else if(returnedValue !== undefined) { | ||||
|             returnedValue = [returnedValue, response]; | ||||
|           } | ||||
|           else if(response !== undefined) { | ||||
|             returnedValue = response; | ||||
|           } | ||||
|           return found; | ||||
|         } | ||||
|       }; | ||||
|  | ||||
|       if(methodInvoked) { | ||||
|         if(instance === undefined) { | ||||
|           module.initialize(); | ||||
|         } | ||||
|         module.invoke(query); | ||||
|       } | ||||
|       else { | ||||
|         if(instance !== undefined) { | ||||
|           instance.invoke('destroy'); | ||||
|         } | ||||
|         module.initialize(); | ||||
|       } | ||||
|     }) | ||||
|   ; | ||||
|  | ||||
|   return (returnedValue !== undefined) | ||||
|     ? returnedValue | ||||
|     : this | ||||
|   ; | ||||
| }; | ||||
|  | ||||
| $.fn.shape.settings = { | ||||
|  | ||||
|   // module info | ||||
|   name : 'Shape', | ||||
|  | ||||
|   // hide all debug content | ||||
|   silent     : false, | ||||
|  | ||||
|   // debug content outputted to console | ||||
|   debug      : false, | ||||
|  | ||||
|   // verbose debug output | ||||
|   verbose    : false, | ||||
|  | ||||
|   // fudge factor in pixels when swapping from 2d to 3d (can be useful to correct rounding errors) | ||||
|   jitter     : 0, | ||||
|  | ||||
|   // performance data output | ||||
|   performance: true, | ||||
|  | ||||
|   // event namespace | ||||
|   namespace  : 'shape', | ||||
|  | ||||
|   // width during animation, can be set to 'auto', initial', 'next' or pixel amount | ||||
|   width: 'initial', | ||||
|  | ||||
|   // height during animation, can be set to 'auto', 'initial', 'next' or pixel amount | ||||
|   height: 'initial', | ||||
|  | ||||
|   // callback occurs on side change | ||||
|   beforeChange : function() {}, | ||||
|   onChange     : function() {}, | ||||
|  | ||||
|   // allow animation to same side | ||||
|   allowRepeats: false, | ||||
|  | ||||
|   // animation duration | ||||
|   duration   : false, | ||||
|  | ||||
|   // possible errors | ||||
|   error: { | ||||
|     side   : 'You tried to switch to a side that does not exist.', | ||||
|     method : 'The method you called is not defined' | ||||
|   }, | ||||
|  | ||||
|   // classnames used | ||||
|   className   : { | ||||
|     animating : 'animating', | ||||
|     hidden    : 'hidden', | ||||
|     loading   : 'loading', | ||||
|     active    : 'active' | ||||
|   }, | ||||
|  | ||||
|   // selectors used | ||||
|   selector    : { | ||||
|     sides : '.sides', | ||||
|     side  : '.side' | ||||
|   } | ||||
|  | ||||
| }; | ||||
|  | ||||
|  | ||||
| })( jQuery, window, document ); | ||||
| @@ -1,150 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Shape | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'module'; | ||||
| @element : 'shape'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|               Shape | ||||
| *******************************/ | ||||
|  | ||||
| .ui.shape { | ||||
|   position: relative; | ||||
|   vertical-align: top; | ||||
|   display: @display; | ||||
|   perspective: @perspective; | ||||
|   transition: @transition; | ||||
| } | ||||
|  | ||||
| .ui.shape .sides { | ||||
|   transform-style: preserve-3d; | ||||
| } | ||||
|  | ||||
| .ui.shape .side { | ||||
|   opacity: 1; | ||||
|   width: 100%; | ||||
|  | ||||
|   margin: @sideMargin !important; | ||||
|   backface-visibility: @backfaceVisibility; | ||||
| } | ||||
|  | ||||
| .ui.shape .side { | ||||
|   display: none; | ||||
| } | ||||
|  | ||||
| .ui.shape .side * { | ||||
|   backface-visibility: visible !important; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|              Types | ||||
| *******************************/ | ||||
|  | ||||
| .ui.cube.shape .side { | ||||
|   min-width: @cubeSize; | ||||
|   height: @cubeSize; | ||||
|  | ||||
|   padding: @cubePadding; | ||||
|  | ||||
|   background-color: @cubeBackground; | ||||
|   color: @cubeTextColor; | ||||
|   box-shadow: @cubeBoxShadow; | ||||
| } | ||||
| .ui.cube.shape .side > .content { | ||||
|   width: 100%; | ||||
|   height: 100%; | ||||
|   display: table; | ||||
|  | ||||
|   text-align: @cubeTextAlign; | ||||
|   user-select: text; | ||||
| } | ||||
| .ui.cube.shape .side > .content > div { | ||||
|   display: table-cell; | ||||
|   vertical-align: middle; | ||||
|   font-size: @cubeFontSize; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|           Variations | ||||
| *******************************/ | ||||
|  | ||||
| .ui.text.shape.animating .sides { | ||||
|   position: static; | ||||
| } | ||||
| .ui.text.shape .side { | ||||
|   white-space: nowrap; | ||||
| } | ||||
| .ui.text.shape .side > * { | ||||
|   white-space: normal; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|              States | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|     Loading | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.loading.shape { | ||||
|   position: absolute; | ||||
|   top: -9999px; | ||||
|   left: -9999px; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|     Animating | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.shape .animating.side { | ||||
|   position: absolute; | ||||
|   top: 0px; | ||||
|   left: 0px; | ||||
|   display: block; | ||||
|   z-index: @animatingZIndex; | ||||
| } | ||||
| .ui.shape .hidden.side { | ||||
|   opacity: @hiddenSideOpacity; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|       CSS | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.shape.animating .sides { | ||||
|   position: absolute; | ||||
| } | ||||
| .ui.shape.animating .sides { | ||||
|   transition: @transition; | ||||
| } | ||||
| .ui.shape.animating .side { | ||||
|   transition: @sideTransition; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Active | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.shape .active.side { | ||||
|   display: block; | ||||
| } | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,538 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Sidebar | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'module'; | ||||
| @element : 'sidebar'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|             Sidebar | ||||
| *******************************/ | ||||
|  | ||||
| /* Sidebar Menu */ | ||||
| .ui.sidebar { | ||||
|   position: fixed; | ||||
|   top: 0; | ||||
|   left: 0; | ||||
|  | ||||
|   backface-visibility: hidden; | ||||
|   transition: none; | ||||
|   will-change: transform; | ||||
|   transform: translate3d(0, 0, 0); | ||||
|   visibility: hidden; | ||||
|   -webkit-overflow-scrolling: touch; | ||||
|  | ||||
|   height: 100% !important; | ||||
|   max-height: 100%; | ||||
|   border-radius: 0em !important; | ||||
|   margin: 0em !important; | ||||
|   overflow-y: auto !important; | ||||
|   z-index: @topLayer; | ||||
| } | ||||
|  | ||||
| /* GPU Layers for Child Elements */ | ||||
| .ui.sidebar > * { | ||||
|   backface-visibility: hidden; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|    Direction | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.left.sidebar { | ||||
|   right: auto; | ||||
|   left: 0px; | ||||
|   transform: translate3d(-100%, 0, 0); | ||||
| } | ||||
| .ui.right.sidebar { | ||||
|   right: 0px !important; | ||||
|   left: auto !important; | ||||
|   transform: translate3d(100%, 0%, 0); | ||||
| } | ||||
|  | ||||
| .ui.top.sidebar, | ||||
| .ui.bottom.sidebar { | ||||
|   width: 100% !important; | ||||
|   height: auto !important; | ||||
| } | ||||
| .ui.top.sidebar { | ||||
|   top: 0px !important; | ||||
|   bottom: auto !important; | ||||
|   transform: translate3d(0, -100%, 0); | ||||
| } | ||||
| .ui.bottom.sidebar { | ||||
|   top: auto !important; | ||||
|   bottom: 0px !important; | ||||
|   transform: translate3d(0, 100%, 0); | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|      Pushable | ||||
| ---------------*/ | ||||
|  | ||||
| .pushable { | ||||
|   height: 100%; | ||||
|   overflow-x: hidden; | ||||
|   padding: 0em !important; | ||||
| } | ||||
|  | ||||
| /* Whole Page */ | ||||
| body.pushable { | ||||
|   background: @canvasBackground !important; | ||||
| } | ||||
|  | ||||
| /* Page Context */ | ||||
| .pushable:not(body) { | ||||
|   transform: translate3d(0, 0, 0); | ||||
| } | ||||
| .pushable:not(body) > .ui.sidebar, | ||||
| .pushable:not(body) > .fixed, | ||||
| .pushable:not(body) > .pusher:after { | ||||
|   position: absolute; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|      Fixed | ||||
| ---------------*/ | ||||
|  | ||||
| .pushable > .fixed { | ||||
|   position: fixed; | ||||
|   backface-visibility: hidden; | ||||
|  | ||||
|   transition: transform @duration @easing; | ||||
|   will-change: transform; | ||||
|   z-index: @fixedLayer; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Page | ||||
| ---------------*/ | ||||
|  | ||||
| .pushable > .pusher { | ||||
|   position: relative; | ||||
|   backface-visibility: hidden; | ||||
|   overflow: hidden; | ||||
|   min-height: 100%; | ||||
|   transition: transform @duration @easing; | ||||
|   z-index: @middleLayer; | ||||
| } | ||||
|  | ||||
| body.pushable > .pusher { | ||||
|   background: @pageBackground; | ||||
| } | ||||
|  | ||||
| /* Pusher should inherit background from context */ | ||||
| .pushable > .pusher { | ||||
|   background: inherit; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Dimmer | ||||
| ---------------*/ | ||||
|  | ||||
| .pushable > .pusher:after { | ||||
|   position: fixed; | ||||
|   top: 0px; | ||||
|   right: 0px; | ||||
|   content: ''; | ||||
|   background-color: @dimmerColor; | ||||
|   overflow: hidden; | ||||
|   opacity: 0; | ||||
|   transition: @dimmerTransition; | ||||
|   will-change: opacity; | ||||
|   z-index: @dimmerLayer; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Coupling | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.sidebar.menu .item { | ||||
|   border-radius: 0em !important; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|             States | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|      Dimmed | ||||
| ---------------*/ | ||||
|  | ||||
| .pushable > .pusher.dimmed:after { | ||||
|   width: 100% !important; | ||||
|   height: 100% !important; | ||||
|   opacity: 1 !important; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|     Animating | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.animating.sidebar { | ||||
|   visibility: visible; | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|      Visible | ||||
| ---------------*/ | ||||
|  | ||||
| .ui.visible.sidebar { | ||||
|   visibility: visible; | ||||
|   transform: translate3d(0, 0, 0); | ||||
| } | ||||
|  | ||||
| /* Shadow Direction */ | ||||
| .ui.left.visible.sidebar, | ||||
| .ui.right.visible.sidebar { | ||||
|   box-shadow: @horizontalBoxShadow; | ||||
| } | ||||
| .ui.top.visible.sidebar, | ||||
| .ui.bottom.visible.sidebar { | ||||
|   box-shadow: @verticalBoxShadow; | ||||
| } | ||||
|  | ||||
| /* Visible On Load */ | ||||
| .ui.visible.left.sidebar ~ .fixed, | ||||
| .ui.visible.left.sidebar ~ .pusher { | ||||
|   transform: translate3d(@width, 0, 0); | ||||
| } | ||||
| .ui.visible.right.sidebar ~ .fixed, | ||||
| .ui.visible.right.sidebar ~ .pusher { | ||||
|   transform: translate3d(-@width, 0, 0); | ||||
| } | ||||
| .ui.visible.top.sidebar ~ .fixed, | ||||
| .ui.visible.top.sidebar ~ .pusher { | ||||
|   transform: translate3d(0, @height, 0); | ||||
| } | ||||
| .ui.visible.bottom.sidebar ~ .fixed, | ||||
| .ui.visible.bottom.sidebar ~ .pusher { | ||||
|   transform: translate3d(0, -@height, 0); | ||||
| } | ||||
|  | ||||
| /* opposite sides visible forces content overlay */ | ||||
| .ui.visible.left.sidebar ~ .ui.visible.right.sidebar ~ .fixed, | ||||
| .ui.visible.left.sidebar ~ .ui.visible.right.sidebar ~ .pusher, | ||||
| .ui.visible.right.sidebar ~ .ui.visible.left.sidebar ~ .fixed, | ||||
| .ui.visible.right.sidebar ~ .ui.visible.left.sidebar ~ .pusher { | ||||
|   transform: translate3d(0, 0, 0); | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|        iOS | ||||
| ---------------*/ | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|           Variations | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|      Width | ||||
| ---------------*/ | ||||
|  | ||||
| /* Left / Right */ | ||||
| .ui.thin.left.sidebar, | ||||
| .ui.thin.right.sidebar { | ||||
|   width: @thinWidth; | ||||
| } | ||||
| .ui[class*="very thin"].left.sidebar, | ||||
| .ui[class*="very thin"].right.sidebar { | ||||
|   width: @veryThinWidth; | ||||
| } | ||||
| .ui.left.sidebar, | ||||
| .ui.right.sidebar { | ||||
|   width: @width; | ||||
| } | ||||
| .ui.wide.left.sidebar, | ||||
| .ui.wide.right.sidebar { | ||||
|   width: @wideWidth; | ||||
| } | ||||
| .ui[class*="very wide"].left.sidebar, | ||||
| .ui[class*="very wide"].right.sidebar { | ||||
|   width: @veryWideWidth; | ||||
| } | ||||
|  | ||||
| /* Left Visible */ | ||||
| .ui.visible.thin.left.sidebar ~ .fixed, | ||||
| .ui.visible.thin.left.sidebar ~ .pusher { | ||||
|   transform: translate3d(@thinWidth, 0, 0); | ||||
| } | ||||
| .ui.visible[class*="very thin"].left.sidebar ~ .fixed, | ||||
| .ui.visible[class*="very thin"].left.sidebar ~ .pusher { | ||||
|   transform: translate3d(@veryThinWidth, 0, 0); | ||||
| } | ||||
| .ui.visible.wide.left.sidebar ~ .fixed, | ||||
| .ui.visible.wide.left.sidebar ~ .pusher { | ||||
|   transform: translate3d(@wideWidth, 0, 0); | ||||
| } | ||||
| .ui.visible[class*="very wide"].left.sidebar ~ .fixed, | ||||
| .ui.visible[class*="very wide"].left.sidebar ~ .pusher { | ||||
|   transform: translate3d(@veryWideWidth, 0, 0); | ||||
| } | ||||
|  | ||||
| /* Right Visible */ | ||||
| .ui.visible.thin.right.sidebar ~ .fixed, | ||||
| .ui.visible.thin.right.sidebar ~ .pusher { | ||||
|   transform: translate3d(-@thinWidth, 0, 0); | ||||
| } | ||||
| .ui.visible[class*="very thin"].right.sidebar ~ .fixed, | ||||
| .ui.visible[class*="very thin"].right.sidebar ~ .pusher { | ||||
|   transform: translate3d(-@veryThinWidth, 0, 0); | ||||
| } | ||||
| .ui.visible.wide.right.sidebar ~ .fixed, | ||||
| .ui.visible.wide.right.sidebar ~ .pusher { | ||||
|   transform: translate3d(-@wideWidth, 0, 0); | ||||
| } | ||||
| .ui.visible[class*="very wide"].right.sidebar ~ .fixed, | ||||
| .ui.visible[class*="very wide"].right.sidebar ~ .pusher { | ||||
|   transform: translate3d(-@veryWideWidth, 0, 0); | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|           Animations | ||||
| *******************************/ | ||||
|  | ||||
| /*-------------- | ||||
|     Overlay | ||||
| ---------------*/ | ||||
|  | ||||
| /* Set-up */ | ||||
| .ui.overlay.sidebar { | ||||
|   z-index: @topLayer; | ||||
| } | ||||
|  | ||||
| /* Initial */ | ||||
| .ui.left.overlay.sidebar { | ||||
|   transform: translate3d(-100%, 0%, 0); | ||||
| } | ||||
| .ui.right.overlay.sidebar { | ||||
|   transform: translate3d(100%, 0%, 0); | ||||
| } | ||||
| .ui.top.overlay.sidebar { | ||||
|   transform: translate3d(0%, -100%, 0); | ||||
| } | ||||
| .ui.bottom.overlay.sidebar { | ||||
|   transform: translate3d(0%, 100%, 0); | ||||
| } | ||||
|  | ||||
| /* Animation */ | ||||
| .animating.ui.overlay.sidebar, | ||||
| .ui.visible.overlay.sidebar { | ||||
|   transition: transform @duration @easing; | ||||
| } | ||||
|  | ||||
| /* End - Sidebar */ | ||||
| .ui.visible.left.overlay.sidebar { | ||||
|   transform: translate3d(0%, 0%, 0); | ||||
| } | ||||
| .ui.visible.right.overlay.sidebar { | ||||
|   transform: translate3d(0%, 0%, 0); | ||||
| } | ||||
| .ui.visible.top.overlay.sidebar { | ||||
|   transform: translate3d(0%, 0%, 0); | ||||
| } | ||||
| .ui.visible.bottom.overlay.sidebar { | ||||
|   transform: translate3d(0%, 0%, 0); | ||||
| } | ||||
|  | ||||
| /* End - Pusher */ | ||||
| .ui.visible.overlay.sidebar ~ .fixed, | ||||
| .ui.visible.overlay.sidebar ~ .pusher { | ||||
|   transform: none !important; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|       Push | ||||
| ---------------*/ | ||||
|  | ||||
| /* Initial */ | ||||
| .ui.push.sidebar { | ||||
|   transition: transform @duration @easing; | ||||
|   z-index: @topLayer; | ||||
| } | ||||
|  | ||||
| /* Sidebar - Initial */ | ||||
| .ui.left.push.sidebar { | ||||
|   transform: translate3d(-100%, 0, 0); | ||||
| } | ||||
| .ui.right.push.sidebar { | ||||
|   transform: translate3d(100%, 0, 0); | ||||
| } | ||||
| .ui.top.push.sidebar { | ||||
|   transform: translate3d(0%, -100%, 0); | ||||
| } | ||||
| .ui.bottom.push.sidebar { | ||||
|   transform: translate3d(0%, 100%, 0); | ||||
| } | ||||
|  | ||||
| /* End */ | ||||
| .ui.visible.push.sidebar { | ||||
|   transform: translate3d(0%, 0, 0); | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|     Uncover | ||||
| ---------------*/ | ||||
|  | ||||
| /* Initial */ | ||||
| .ui.uncover.sidebar { | ||||
|   transform: translate3d(0, 0, 0); | ||||
|   z-index: @bottomLayer; | ||||
| } | ||||
|  | ||||
| /* End */ | ||||
| .ui.visible.uncover.sidebar { | ||||
|   transform: translate3d(0, 0, 0); | ||||
|   transition: transform @duration @easing; | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|    Slide Along | ||||
| ---------------*/ | ||||
|  | ||||
| /* Initial */ | ||||
| .ui.slide.along.sidebar { | ||||
|   z-index: @bottomLayer; | ||||
| } | ||||
|  | ||||
| /* Sidebar - Initial */ | ||||
| .ui.left.slide.along.sidebar { | ||||
|   transform: translate3d(-50%, 0, 0); | ||||
| } | ||||
| .ui.right.slide.along.sidebar { | ||||
|   transform: translate3d(50%, 0, 0); | ||||
| } | ||||
| .ui.top.slide.along.sidebar { | ||||
|   transform: translate3d(0, -50%, 0); | ||||
| } | ||||
| .ui.bottom.slide.along.sidebar { | ||||
|   transform: translate3d(0%, 50%, 0); | ||||
| } | ||||
|  | ||||
| /* Animation */ | ||||
| .ui.animating.slide.along.sidebar { | ||||
|   transition: transform @duration @easing; | ||||
| } | ||||
|  | ||||
| /* End */ | ||||
| .ui.visible.slide.along.sidebar { | ||||
|   transform: translate3d(0%, 0, 0); | ||||
| } | ||||
|  | ||||
|  | ||||
| /*-------------- | ||||
|    Slide Out | ||||
| ---------------*/ | ||||
|  | ||||
| /* Initial */ | ||||
| .ui.slide.out.sidebar { | ||||
|   z-index: @bottomLayer; | ||||
| } | ||||
|  | ||||
| /* Sidebar - Initial */ | ||||
| .ui.left.slide.out.sidebar { | ||||
|   transform: translate3d(50%, 0, 0); | ||||
| } | ||||
| .ui.right.slide.out.sidebar { | ||||
|   transform: translate3d(-50%, 0, 0); | ||||
| } | ||||
| .ui.top.slide.out.sidebar { | ||||
|   transform: translate3d(0%, 50%, 0); | ||||
| } | ||||
| .ui.bottom.slide.out.sidebar { | ||||
|   transform: translate3d(0%, -50%, 0); | ||||
| } | ||||
|  | ||||
| /* Animation */ | ||||
| .ui.animating.slide.out.sidebar { | ||||
|   transition: transform @duration @easing; | ||||
| } | ||||
|  | ||||
| /* End */ | ||||
| .ui.visible.slide.out.sidebar { | ||||
|   transform: translate3d(0%, 0, 0); | ||||
| } | ||||
|  | ||||
| /*-------------- | ||||
|    Scale Down | ||||
| ---------------*/ | ||||
|  | ||||
| /* Initial */ | ||||
| .ui.scale.down.sidebar { | ||||
|   transition: transform @duration @easing; | ||||
|   z-index: @topLayer; | ||||
| } | ||||
|  | ||||
| /* Sidebar - Initial  */ | ||||
| .ui.left.scale.down.sidebar { | ||||
|   transform: translate3d(-100%, 0, 0); | ||||
| } | ||||
| .ui.right.scale.down.sidebar { | ||||
|   transform: translate3d(100%, 0, 0); | ||||
| } | ||||
| .ui.top.scale.down.sidebar { | ||||
|   transform: translate3d(0%, -100%, 0); | ||||
| } | ||||
| .ui.bottom.scale.down.sidebar { | ||||
|   transform: translate3d(0%, 100%, 0); | ||||
| } | ||||
|  | ||||
| /* Pusher - Initial */ | ||||
| .ui.scale.down.left.sidebar ~ .pusher { | ||||
|   transform-origin: 75% 50%; | ||||
| } | ||||
| .ui.scale.down.right.sidebar ~ .pusher { | ||||
|   transform-origin: 25% 50%; | ||||
| } | ||||
| .ui.scale.down.top.sidebar ~ .pusher { | ||||
|   transform-origin: 50% 75%; | ||||
| } | ||||
| .ui.scale.down.bottom.sidebar ~ .pusher { | ||||
|   transform-origin: 50% 25%; | ||||
| } | ||||
|  | ||||
| /* Animation */ | ||||
| .ui.animating.scale.down > .visible.ui.sidebar { | ||||
|   transition: transform @duration @easing; | ||||
| } | ||||
| .ui.visible.scale.down.sidebar ~ .pusher, | ||||
| .ui.animating.scale.down.sidebar ~ .pusher { | ||||
|   display: block !important; | ||||
|   width: 100%; | ||||
|   height: 100%; | ||||
|   overflow: hidden !important; | ||||
| } | ||||
|  | ||||
| /* End */ | ||||
| .ui.visible.scale.down.sidebar { | ||||
|   transform: translate3d(0, 0, 0); | ||||
| } | ||||
| .ui.visible.scale.down.sidebar ~ .pusher { | ||||
|   transform: scale(0.75); | ||||
| } | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,959 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Sticky | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| ;(function ($, window, document, undefined) { | ||||
|  | ||||
| 'use strict'; | ||||
|  | ||||
| window = (typeof window != 'undefined' && window.Math == Math) | ||||
|   ? window | ||||
|   : (typeof self != 'undefined' && self.Math == Math) | ||||
|     ? self | ||||
|     : Function('return this')() | ||||
| ; | ||||
|  | ||||
| $.fn.sticky = function(parameters) { | ||||
|   var | ||||
|     $allModules    = $(this), | ||||
|     moduleSelector = $allModules.selector || '', | ||||
|  | ||||
|     time           = new Date().getTime(), | ||||
|     performance    = [], | ||||
|  | ||||
|     query          = arguments[0], | ||||
|     methodInvoked  = (typeof query == 'string'), | ||||
|     queryArguments = [].slice.call(arguments, 1), | ||||
|     returnedValue | ||||
|   ; | ||||
|  | ||||
|   $allModules | ||||
|     .each(function() { | ||||
|       var | ||||
|         settings              = ( $.isPlainObject(parameters) ) | ||||
|           ? $.extend(true, {}, $.fn.sticky.settings, parameters) | ||||
|           : $.extend({}, $.fn.sticky.settings), | ||||
|  | ||||
|         className             = settings.className, | ||||
|         namespace             = settings.namespace, | ||||
|         error                 = settings.error, | ||||
|  | ||||
|         eventNamespace        = '.' + namespace, | ||||
|         moduleNamespace       = 'module-' + namespace, | ||||
|  | ||||
|         $module               = $(this), | ||||
|         $window               = $(window), | ||||
|         $scroll               = $(settings.scrollContext), | ||||
|         $container, | ||||
|         $context, | ||||
|  | ||||
|         selector              = $module.selector || '', | ||||
|         instance              = $module.data(moduleNamespace), | ||||
|  | ||||
|         requestAnimationFrame = window.requestAnimationFrame | ||||
|           || window.mozRequestAnimationFrame | ||||
|           || window.webkitRequestAnimationFrame | ||||
|           || window.msRequestAnimationFrame | ||||
|           || function(callback) { setTimeout(callback, 0); }, | ||||
|  | ||||
|         element         = this, | ||||
|  | ||||
|         documentObserver, | ||||
|         observer, | ||||
|         module | ||||
|       ; | ||||
|  | ||||
|       module      = { | ||||
|  | ||||
|         initialize: function() { | ||||
|  | ||||
|           module.determineContainer(); | ||||
|           module.determineContext(); | ||||
|           module.verbose('Initializing sticky', settings, $container); | ||||
|  | ||||
|           module.save.positions(); | ||||
|           module.checkErrors(); | ||||
|           module.bind.events(); | ||||
|  | ||||
|           if(settings.observeChanges) { | ||||
|             module.observeChanges(); | ||||
|           } | ||||
|           module.instantiate(); | ||||
|         }, | ||||
|  | ||||
|         instantiate: function() { | ||||
|           module.verbose('Storing instance of module', module); | ||||
|           instance = module; | ||||
|           $module | ||||
|             .data(moduleNamespace, module) | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         destroy: function() { | ||||
|           module.verbose('Destroying previous instance'); | ||||
|           module.reset(); | ||||
|           if(documentObserver) { | ||||
|             documentObserver.disconnect(); | ||||
|           } | ||||
|           if(observer) { | ||||
|             observer.disconnect(); | ||||
|           } | ||||
|           $window | ||||
|             .off('load' + eventNamespace, module.event.load) | ||||
|             .off('resize' + eventNamespace, module.event.resize) | ||||
|           ; | ||||
|           $scroll | ||||
|             .off('scrollchange' + eventNamespace, module.event.scrollchange) | ||||
|           ; | ||||
|           $module.removeData(moduleNamespace); | ||||
|         }, | ||||
|  | ||||
|         observeChanges: function() { | ||||
|           if('MutationObserver' in window) { | ||||
|             documentObserver = new MutationObserver(module.event.documentChanged); | ||||
|             observer         = new MutationObserver(module.event.changed); | ||||
|             documentObserver.observe(document, { | ||||
|               childList : true, | ||||
|               subtree   : true | ||||
|             }); | ||||
|             observer.observe(element, { | ||||
|               childList : true, | ||||
|               subtree   : true | ||||
|             }); | ||||
|             observer.observe($context[0], { | ||||
|               childList : true, | ||||
|               subtree   : true | ||||
|             }); | ||||
|             module.debug('Setting up mutation observer', observer); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         determineContainer: function() { | ||||
|           if(settings.container) { | ||||
|             $container = $(settings.container); | ||||
|           } | ||||
|           else { | ||||
|             $container = $module.offsetParent(); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         determineContext: function() { | ||||
|           if(settings.context) { | ||||
|             $context = $(settings.context); | ||||
|           } | ||||
|           else { | ||||
|             $context = $container; | ||||
|           } | ||||
|           if($context.length === 0) { | ||||
|             module.error(error.invalidContext, settings.context, $module); | ||||
|             return; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         checkErrors: function() { | ||||
|           if( module.is.hidden() ) { | ||||
|             module.error(error.visible, $module); | ||||
|           } | ||||
|           if(module.cache.element.height > module.cache.context.height) { | ||||
|             module.reset(); | ||||
|             module.error(error.elementSize, $module); | ||||
|             return; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         bind: { | ||||
|           events: function() { | ||||
|             $window | ||||
|               .on('load' + eventNamespace, module.event.load) | ||||
|               .on('resize' + eventNamespace, module.event.resize) | ||||
|             ; | ||||
|             // pub/sub pattern | ||||
|             $scroll | ||||
|               .off('scroll' + eventNamespace) | ||||
|               .on('scroll' + eventNamespace, module.event.scroll) | ||||
|               .on('scrollchange' + eventNamespace, module.event.scrollchange) | ||||
|             ; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         event: { | ||||
|           changed: function(mutations) { | ||||
|             clearTimeout(module.timer); | ||||
|             module.timer = setTimeout(function() { | ||||
|               module.verbose('DOM tree modified, updating sticky menu', mutations); | ||||
|               module.refresh(); | ||||
|             }, 100); | ||||
|           }, | ||||
|           documentChanged: function(mutations) { | ||||
|             [].forEach.call(mutations, function(mutation) { | ||||
|               if(mutation.removedNodes) { | ||||
|                 [].forEach.call(mutation.removedNodes, function(node) { | ||||
|                   if(node == element || $(node).find(element).length > 0) { | ||||
|                     module.debug('Element removed from DOM, tearing down events'); | ||||
|                     module.destroy(); | ||||
|                   } | ||||
|                 }); | ||||
|               } | ||||
|             }); | ||||
|           }, | ||||
|           load: function() { | ||||
|             module.verbose('Page contents finished loading'); | ||||
|             requestAnimationFrame(module.refresh); | ||||
|           }, | ||||
|           resize: function() { | ||||
|             module.verbose('Window resized'); | ||||
|             requestAnimationFrame(module.refresh); | ||||
|           }, | ||||
|           scroll: function() { | ||||
|             requestAnimationFrame(function() { | ||||
|               $scroll.triggerHandler('scrollchange' + eventNamespace, $scroll.scrollTop() ); | ||||
|             }); | ||||
|           }, | ||||
|           scrollchange: function(event, scrollPosition) { | ||||
|             module.stick(scrollPosition); | ||||
|             settings.onScroll.call(element); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         refresh: function(hardRefresh) { | ||||
|           module.reset(); | ||||
|           if(!settings.context) { | ||||
|             module.determineContext(); | ||||
|           } | ||||
|           if(hardRefresh) { | ||||
|             module.determineContainer(); | ||||
|           } | ||||
|           module.save.positions(); | ||||
|           module.stick(); | ||||
|           settings.onReposition.call(element); | ||||
|         }, | ||||
|  | ||||
|         supports: { | ||||
|           sticky: function() { | ||||
|             var | ||||
|               $element = $('<div/>'), | ||||
|               element = $element[0] | ||||
|             ; | ||||
|             $element.addClass(className.supported); | ||||
|             return($element.css('position').match('sticky')); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         save: { | ||||
|           lastScroll: function(scroll) { | ||||
|             module.lastScroll = scroll; | ||||
|           }, | ||||
|           elementScroll: function(scroll) { | ||||
|             module.elementScroll = scroll; | ||||
|           }, | ||||
|           positions: function() { | ||||
|             var | ||||
|               scrollContext = { | ||||
|                 height : $scroll.height() | ||||
|               }, | ||||
|               element = { | ||||
|                 margin: { | ||||
|                   top    : parseInt($module.css('margin-top'), 10), | ||||
|                   bottom : parseInt($module.css('margin-bottom'), 10), | ||||
|                 }, | ||||
|                 offset : $module.offset(), | ||||
|                 width  : $module.outerWidth(), | ||||
|                 height : $module.outerHeight() | ||||
|               }, | ||||
|               context = { | ||||
|                 offset : $context.offset(), | ||||
|                 height : $context.outerHeight() | ||||
|               }, | ||||
|               container = { | ||||
|                 height: $container.outerHeight() | ||||
|               } | ||||
|             ; | ||||
|             if( !module.is.standardScroll() ) { | ||||
|               module.debug('Non-standard scroll. Removing scroll offset from element offset'); | ||||
|  | ||||
|               scrollContext.top  = $scroll.scrollTop(); | ||||
|               scrollContext.left = $scroll.scrollLeft(); | ||||
|  | ||||
|               element.offset.top  += scrollContext.top; | ||||
|               context.offset.top  += scrollContext.top; | ||||
|               element.offset.left += scrollContext.left; | ||||
|               context.offset.left += scrollContext.left; | ||||
|             } | ||||
|             module.cache = { | ||||
|               fits          : ( (element.height + settings.offset) <= scrollContext.height), | ||||
|               sameHeight    : (element.height == context.height), | ||||
|               scrollContext : { | ||||
|                 height : scrollContext.height | ||||
|               }, | ||||
|               element: { | ||||
|                 margin : element.margin, | ||||
|                 top    : element.offset.top - element.margin.top, | ||||
|                 left   : element.offset.left, | ||||
|                 width  : element.width, | ||||
|                 height : element.height, | ||||
|                 bottom : element.offset.top + element.height | ||||
|               }, | ||||
|               context: { | ||||
|                 top           : context.offset.top, | ||||
|                 height        : context.height, | ||||
|                 bottom        : context.offset.top + context.height | ||||
|               } | ||||
|             }; | ||||
|             module.set.containerSize(); | ||||
|  | ||||
|             module.stick(); | ||||
|             module.debug('Caching element positions', module.cache); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         get: { | ||||
|           direction: function(scroll) { | ||||
|             var | ||||
|               direction = 'down' | ||||
|             ; | ||||
|             scroll = scroll || $scroll.scrollTop(); | ||||
|             if(module.lastScroll !== undefined) { | ||||
|               if(module.lastScroll < scroll) { | ||||
|                 direction = 'down'; | ||||
|               } | ||||
|               else if(module.lastScroll > scroll) { | ||||
|                 direction = 'up'; | ||||
|               } | ||||
|             } | ||||
|             return direction; | ||||
|           }, | ||||
|           scrollChange: function(scroll) { | ||||
|             scroll = scroll || $scroll.scrollTop(); | ||||
|             return (module.lastScroll) | ||||
|               ? (scroll - module.lastScroll) | ||||
|               : 0 | ||||
|             ; | ||||
|           }, | ||||
|           currentElementScroll: function() { | ||||
|             if(module.elementScroll) { | ||||
|               return module.elementScroll; | ||||
|             } | ||||
|             return ( module.is.top() ) | ||||
|               ? Math.abs(parseInt($module.css('top'), 10))    || 0 | ||||
|               : Math.abs(parseInt($module.css('bottom'), 10)) || 0 | ||||
|             ; | ||||
|           }, | ||||
|  | ||||
|           elementScroll: function(scroll) { | ||||
|             scroll = scroll || $scroll.scrollTop(); | ||||
|             var | ||||
|               element        = module.cache.element, | ||||
|               scrollContext  = module.cache.scrollContext, | ||||
|               delta          = module.get.scrollChange(scroll), | ||||
|               maxScroll      = (element.height - scrollContext.height + settings.offset), | ||||
|               elementScroll  = module.get.currentElementScroll(), | ||||
|               possibleScroll = (elementScroll + delta) | ||||
|             ; | ||||
|             if(module.cache.fits || possibleScroll < 0) { | ||||
|               elementScroll = 0; | ||||
|             } | ||||
|             else if(possibleScroll > maxScroll ) { | ||||
|               elementScroll = maxScroll; | ||||
|             } | ||||
|             else { | ||||
|               elementScroll = possibleScroll; | ||||
|             } | ||||
|             return elementScroll; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         remove: { | ||||
|           lastScroll: function() { | ||||
|             delete module.lastScroll; | ||||
|           }, | ||||
|           elementScroll: function(scroll) { | ||||
|             delete module.elementScroll; | ||||
|           }, | ||||
|           minimumSize: function() { | ||||
|             $container | ||||
|               .css('min-height', '') | ||||
|             ; | ||||
|           }, | ||||
|           offset: function() { | ||||
|             $module.css('margin-top', ''); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         set: { | ||||
|           offset: function() { | ||||
|             module.verbose('Setting offset on element', settings.offset); | ||||
|             $module | ||||
|               .css('margin-top', settings.offset) | ||||
|             ; | ||||
|           }, | ||||
|           containerSize: function() { | ||||
|             var | ||||
|               tagName = $container.get(0).tagName | ||||
|             ; | ||||
|             if(tagName === 'HTML' || tagName == 'body') { | ||||
|               // this can trigger for too many reasons | ||||
|               //module.error(error.container, tagName, $module); | ||||
|               module.determineContainer(); | ||||
|             } | ||||
|             else { | ||||
|               if( Math.abs($container.outerHeight() - module.cache.context.height) > settings.jitter) { | ||||
|                 module.debug('Context has padding, specifying exact height for container', module.cache.context.height); | ||||
|                 $container.css({ | ||||
|                   height: module.cache.context.height | ||||
|                 }); | ||||
|               } | ||||
|             } | ||||
|           }, | ||||
|           minimumSize: function() { | ||||
|             var | ||||
|               element   = module.cache.element | ||||
|             ; | ||||
|             $container | ||||
|               .css('min-height', element.height) | ||||
|             ; | ||||
|           }, | ||||
|           scroll: function(scroll) { | ||||
|             module.debug('Setting scroll on element', scroll); | ||||
|             if(module.elementScroll == scroll) { | ||||
|               return; | ||||
|             } | ||||
|             if( module.is.top() ) { | ||||
|               $module | ||||
|                 .css('bottom', '') | ||||
|                 .css('top', -scroll) | ||||
|               ; | ||||
|             } | ||||
|             if( module.is.bottom() ) { | ||||
|               $module | ||||
|                 .css('top', '') | ||||
|                 .css('bottom', scroll) | ||||
|               ; | ||||
|             } | ||||
|           }, | ||||
|           size: function() { | ||||
|             if(module.cache.element.height !== 0 && module.cache.element.width !== 0) { | ||||
|               element.style.setProperty('width',  module.cache.element.width  + 'px', 'important'); | ||||
|               element.style.setProperty('height', module.cache.element.height + 'px', 'important'); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         is: { | ||||
|           standardScroll: function() { | ||||
|             return ($scroll[0] == window); | ||||
|           }, | ||||
|           top: function() { | ||||
|             return $module.hasClass(className.top); | ||||
|           }, | ||||
|           bottom: function() { | ||||
|             return $module.hasClass(className.bottom); | ||||
|           }, | ||||
|           initialPosition: function() { | ||||
|             return (!module.is.fixed() && !module.is.bound()); | ||||
|           }, | ||||
|           hidden: function() { | ||||
|             return (!$module.is(':visible')); | ||||
|           }, | ||||
|           bound: function() { | ||||
|             return $module.hasClass(className.bound); | ||||
|           }, | ||||
|           fixed: function() { | ||||
|             return $module.hasClass(className.fixed); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         stick: function(scroll) { | ||||
|           var | ||||
|             cachedPosition = scroll || $scroll.scrollTop(), | ||||
|             cache          = module.cache, | ||||
|             fits           = cache.fits, | ||||
|             sameHeight     = cache.sameHeight, | ||||
|             element        = cache.element, | ||||
|             scrollContext  = cache.scrollContext, | ||||
|             context        = cache.context, | ||||
|             offset         = (module.is.bottom() && settings.pushing) | ||||
|               ? settings.bottomOffset | ||||
|               : settings.offset, | ||||
|             scroll         = { | ||||
|               top    : cachedPosition + offset, | ||||
|               bottom : cachedPosition + offset + scrollContext.height | ||||
|             }, | ||||
|             direction      = module.get.direction(scroll.top), | ||||
|             elementScroll  = (fits) | ||||
|               ? 0 | ||||
|               : module.get.elementScroll(scroll.top), | ||||
|  | ||||
|             // shorthand | ||||
|             doesntFit      = !fits, | ||||
|             elementVisible = (element.height !== 0) | ||||
|           ; | ||||
|           if(elementVisible && !sameHeight) { | ||||
|  | ||||
|             if( module.is.initialPosition() ) { | ||||
|               if(scroll.top >= context.bottom) { | ||||
|                 module.debug('Initial element position is bottom of container'); | ||||
|                 module.bindBottom(); | ||||
|               } | ||||
|               else if(scroll.top > element.top) { | ||||
|                 if( (element.height + scroll.top - elementScroll) >= context.bottom ) { | ||||
|                   module.debug('Initial element position is bottom of container'); | ||||
|                   module.bindBottom(); | ||||
|                 } | ||||
|                 else { | ||||
|                   module.debug('Initial element position is fixed'); | ||||
|                   module.fixTop(); | ||||
|                 } | ||||
|               } | ||||
|  | ||||
|             } | ||||
|             else if( module.is.fixed() ) { | ||||
|  | ||||
|               // currently fixed top | ||||
|               if( module.is.top() ) { | ||||
|                 if( scroll.top <= element.top ) { | ||||
|                   module.debug('Fixed element reached top of container'); | ||||
|                   module.setInitialPosition(); | ||||
|                 } | ||||
|                 else if( (element.height + scroll.top - elementScroll) >= context.bottom ) { | ||||
|                   module.debug('Fixed element reached bottom of container'); | ||||
|                   module.bindBottom(); | ||||
|                 } | ||||
|                 // scroll element if larger than screen | ||||
|                 else if(doesntFit) { | ||||
|                   module.set.scroll(elementScroll); | ||||
|                   module.save.lastScroll(scroll.top); | ||||
|                   module.save.elementScroll(elementScroll); | ||||
|                 } | ||||
|               } | ||||
|  | ||||
|               // currently fixed bottom | ||||
|               else if(module.is.bottom() ) { | ||||
|  | ||||
|                 // top edge | ||||
|                 if( (scroll.bottom - element.height) <= element.top) { | ||||
|                   module.debug('Bottom fixed rail has reached top of container'); | ||||
|                   module.setInitialPosition(); | ||||
|                 } | ||||
|                 // bottom edge | ||||
|                 else if(scroll.bottom >= context.bottom) { | ||||
|                   module.debug('Bottom fixed rail has reached bottom of container'); | ||||
|                   module.bindBottom(); | ||||
|                 } | ||||
|                 // scroll element if larger than screen | ||||
|                 else if(doesntFit) { | ||||
|                   module.set.scroll(elementScroll); | ||||
|                   module.save.lastScroll(scroll.top); | ||||
|                   module.save.elementScroll(elementScroll); | ||||
|                 } | ||||
|  | ||||
|               } | ||||
|             } | ||||
|             else if( module.is.bottom() ) { | ||||
|               if( scroll.top <= element.top ) { | ||||
|                 module.debug('Jumped from bottom fixed to top fixed, most likely used home/end button'); | ||||
|                 module.setInitialPosition(); | ||||
|               } | ||||
|               else { | ||||
|                 if(settings.pushing) { | ||||
|                   if(module.is.bound() && scroll.bottom <= context.bottom ) { | ||||
|                     module.debug('Fixing bottom attached element to bottom of browser.'); | ||||
|                     module.fixBottom(); | ||||
|                   } | ||||
|                 } | ||||
|                 else { | ||||
|                   if(module.is.bound() && (scroll.top <= context.bottom - element.height) ) { | ||||
|                     module.debug('Fixing bottom attached element to top of browser.'); | ||||
|                     module.fixTop(); | ||||
|                   } | ||||
|                 } | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         bindTop: function() { | ||||
|           module.debug('Binding element to top of parent container'); | ||||
|           module.remove.offset(); | ||||
|           $module | ||||
|             .css({ | ||||
|               left         : '', | ||||
|               top          : '', | ||||
|               marginBottom : '' | ||||
|             }) | ||||
|             .removeClass(className.fixed) | ||||
|             .removeClass(className.bottom) | ||||
|             .addClass(className.bound) | ||||
|             .addClass(className.top) | ||||
|           ; | ||||
|           settings.onTop.call(element); | ||||
|           settings.onUnstick.call(element); | ||||
|         }, | ||||
|         bindBottom: function() { | ||||
|           module.debug('Binding element to bottom of parent container'); | ||||
|           module.remove.offset(); | ||||
|           $module | ||||
|             .css({ | ||||
|               left         : '', | ||||
|               top          : '' | ||||
|             }) | ||||
|             .removeClass(className.fixed) | ||||
|             .removeClass(className.top) | ||||
|             .addClass(className.bound) | ||||
|             .addClass(className.bottom) | ||||
|           ; | ||||
|           settings.onBottom.call(element); | ||||
|           settings.onUnstick.call(element); | ||||
|         }, | ||||
|  | ||||
|         setInitialPosition: function() { | ||||
|           module.debug('Returning to initial position'); | ||||
|           module.unfix(); | ||||
|           module.unbind(); | ||||
|         }, | ||||
|  | ||||
|  | ||||
|         fixTop: function() { | ||||
|           module.debug('Fixing element to top of page'); | ||||
|           if(settings.setSize) { | ||||
|             module.set.size(); | ||||
|           } | ||||
|           module.set.minimumSize(); | ||||
|           module.set.offset(); | ||||
|           $module | ||||
|             .css({ | ||||
|               left         : module.cache.element.left, | ||||
|               bottom       : '', | ||||
|               marginBottom : '' | ||||
|             }) | ||||
|             .removeClass(className.bound) | ||||
|             .removeClass(className.bottom) | ||||
|             .addClass(className.fixed) | ||||
|             .addClass(className.top) | ||||
|           ; | ||||
|           settings.onStick.call(element); | ||||
|         }, | ||||
|  | ||||
|         fixBottom: function() { | ||||
|           module.debug('Sticking element to bottom of page'); | ||||
|           if(settings.setSize) { | ||||
|             module.set.size(); | ||||
|           } | ||||
|           module.set.minimumSize(); | ||||
|           module.set.offset(); | ||||
|           $module | ||||
|             .css({ | ||||
|               left         : module.cache.element.left, | ||||
|               bottom       : '', | ||||
|               marginBottom : '' | ||||
|             }) | ||||
|             .removeClass(className.bound) | ||||
|             .removeClass(className.top) | ||||
|             .addClass(className.fixed) | ||||
|             .addClass(className.bottom) | ||||
|           ; | ||||
|           settings.onStick.call(element); | ||||
|         }, | ||||
|  | ||||
|         unbind: function() { | ||||
|           if( module.is.bound() ) { | ||||
|             module.debug('Removing container bound position on element'); | ||||
|             module.remove.offset(); | ||||
|             $module | ||||
|               .removeClass(className.bound) | ||||
|               .removeClass(className.top) | ||||
|               .removeClass(className.bottom) | ||||
|             ; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         unfix: function() { | ||||
|           if( module.is.fixed() ) { | ||||
|             module.debug('Removing fixed position on element'); | ||||
|             module.remove.minimumSize(); | ||||
|             module.remove.offset(); | ||||
|             $module | ||||
|               .removeClass(className.fixed) | ||||
|               .removeClass(className.top) | ||||
|               .removeClass(className.bottom) | ||||
|             ; | ||||
|             settings.onUnstick.call(element); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         reset: function() { | ||||
|           module.debug('Resetting elements position'); | ||||
|           module.unbind(); | ||||
|           module.unfix(); | ||||
|           module.resetCSS(); | ||||
|           module.remove.offset(); | ||||
|           module.remove.lastScroll(); | ||||
|         }, | ||||
|  | ||||
|         resetCSS: function() { | ||||
|           $module | ||||
|             .css({ | ||||
|               width  : '', | ||||
|               height : '' | ||||
|             }) | ||||
|           ; | ||||
|           $container | ||||
|             .css({ | ||||
|               height: '' | ||||
|             }) | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         setting: function(name, value) { | ||||
|           if( $.isPlainObject(name) ) { | ||||
|             $.extend(true, settings, name); | ||||
|           } | ||||
|           else if(value !== undefined) { | ||||
|             settings[name] = value; | ||||
|           } | ||||
|           else { | ||||
|             return settings[name]; | ||||
|           } | ||||
|         }, | ||||
|         internal: function(name, value) { | ||||
|           if( $.isPlainObject(name) ) { | ||||
|             $.extend(true, module, name); | ||||
|           } | ||||
|           else if(value !== undefined) { | ||||
|             module[name] = value; | ||||
|           } | ||||
|           else { | ||||
|             return module[name]; | ||||
|           } | ||||
|         }, | ||||
|         debug: function() { | ||||
|           if(!settings.silent && settings.debug) { | ||||
|             if(settings.performance) { | ||||
|               module.performance.log(arguments); | ||||
|             } | ||||
|             else { | ||||
|               module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|               module.debug.apply(console, arguments); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         verbose: function() { | ||||
|           if(!settings.silent && settings.verbose && settings.debug) { | ||||
|             if(settings.performance) { | ||||
|               module.performance.log(arguments); | ||||
|             } | ||||
|             else { | ||||
|               module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|               module.verbose.apply(console, arguments); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         error: function() { | ||||
|           if(!settings.silent) { | ||||
|             module.error = Function.prototype.bind.call(console.error, console, settings.name + ':'); | ||||
|             module.error.apply(console, arguments); | ||||
|           } | ||||
|         }, | ||||
|         performance: { | ||||
|           log: function(message) { | ||||
|             var | ||||
|               currentTime, | ||||
|               executionTime, | ||||
|               previousTime | ||||
|             ; | ||||
|             if(settings.performance) { | ||||
|               currentTime   = new Date().getTime(); | ||||
|               previousTime  = time || currentTime; | ||||
|               executionTime = currentTime - previousTime; | ||||
|               time          = currentTime; | ||||
|               performance.push({ | ||||
|                 'Name'           : message[0], | ||||
|                 'Arguments'      : [].slice.call(message, 1) || '', | ||||
|                 'Element'        : element, | ||||
|                 'Execution Time' : executionTime | ||||
|               }); | ||||
|             } | ||||
|             clearTimeout(module.performance.timer); | ||||
|             module.performance.timer = setTimeout(module.performance.display, 0); | ||||
|           }, | ||||
|           display: function() { | ||||
|             var | ||||
|               title = settings.name + ':', | ||||
|               totalTime = 0 | ||||
|             ; | ||||
|             time = false; | ||||
|             clearTimeout(module.performance.timer); | ||||
|             $.each(performance, function(index, data) { | ||||
|               totalTime += data['Execution Time']; | ||||
|             }); | ||||
|             title += ' ' + totalTime + 'ms'; | ||||
|             if(moduleSelector) { | ||||
|               title += ' \'' + moduleSelector + '\''; | ||||
|             } | ||||
|             if( (console.group !== undefined || console.table !== undefined) && performance.length > 0) { | ||||
|               console.groupCollapsed(title); | ||||
|               if(console.table) { | ||||
|                 console.table(performance); | ||||
|               } | ||||
|               else { | ||||
|                 $.each(performance, function(index, data) { | ||||
|                   console.log(data['Name'] + ': ' + data['Execution Time']+'ms'); | ||||
|                 }); | ||||
|               } | ||||
|               console.groupEnd(); | ||||
|             } | ||||
|             performance = []; | ||||
|           } | ||||
|         }, | ||||
|         invoke: function(query, passedArguments, context) { | ||||
|           var | ||||
|             object = instance, | ||||
|             maxDepth, | ||||
|             found, | ||||
|             response | ||||
|           ; | ||||
|           passedArguments = passedArguments || queryArguments; | ||||
|           context         = element         || context; | ||||
|           if(typeof query == 'string' && object !== undefined) { | ||||
|             query    = query.split(/[\. ]/); | ||||
|             maxDepth = query.length - 1; | ||||
|             $.each(query, function(depth, value) { | ||||
|               var camelCaseValue = (depth != maxDepth) | ||||
|                 ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1) | ||||
|                 : query | ||||
|               ; | ||||
|               if( $.isPlainObject( object[camelCaseValue] ) && (depth != maxDepth) ) { | ||||
|                 object = object[camelCaseValue]; | ||||
|               } | ||||
|               else if( object[camelCaseValue] !== undefined ) { | ||||
|                 found = object[camelCaseValue]; | ||||
|                 return false; | ||||
|               } | ||||
|               else if( $.isPlainObject( object[value] ) && (depth != maxDepth) ) { | ||||
|                 object = object[value]; | ||||
|               } | ||||
|               else if( object[value] !== undefined ) { | ||||
|                 found = object[value]; | ||||
|                 return false; | ||||
|               } | ||||
|               else { | ||||
|                 return false; | ||||
|               } | ||||
|             }); | ||||
|           } | ||||
|           if ( $.isFunction( found ) ) { | ||||
|             response = found.apply(context, passedArguments); | ||||
|           } | ||||
|           else if(found !== undefined) { | ||||
|             response = found; | ||||
|           } | ||||
|           if($.isArray(returnedValue)) { | ||||
|             returnedValue.push(response); | ||||
|           } | ||||
|           else if(returnedValue !== undefined) { | ||||
|             returnedValue = [returnedValue, response]; | ||||
|           } | ||||
|           else if(response !== undefined) { | ||||
|             returnedValue = response; | ||||
|           } | ||||
|           return found; | ||||
|         } | ||||
|       }; | ||||
|  | ||||
|       if(methodInvoked) { | ||||
|         if(instance === undefined) { | ||||
|           module.initialize(); | ||||
|         } | ||||
|         module.invoke(query); | ||||
|       } | ||||
|       else { | ||||
|         if(instance !== undefined) { | ||||
|           instance.invoke('destroy'); | ||||
|         } | ||||
|         module.initialize(); | ||||
|       } | ||||
|     }) | ||||
|   ; | ||||
|  | ||||
|   return (returnedValue !== undefined) | ||||
|     ? returnedValue | ||||
|     : this | ||||
|   ; | ||||
| }; | ||||
|  | ||||
| $.fn.sticky.settings = { | ||||
|  | ||||
|   name           : 'Sticky', | ||||
|   namespace      : 'sticky', | ||||
|  | ||||
|   silent         : false, | ||||
|   debug          : false, | ||||
|   verbose        : true, | ||||
|   performance    : true, | ||||
|  | ||||
|   // whether to stick in the opposite direction on scroll up | ||||
|   pushing        : false, | ||||
|  | ||||
|   context        : false, | ||||
|   container      : false, | ||||
|  | ||||
|   // Context to watch scroll events | ||||
|   scrollContext  : window, | ||||
|  | ||||
|   // Offset to adjust scroll | ||||
|   offset         : 0, | ||||
|  | ||||
|   // Offset to adjust scroll when attached to bottom of screen | ||||
|   bottomOffset   : 0, | ||||
|  | ||||
|   // will only set container height if difference between context and container is larger than this number | ||||
|   jitter         : 5, | ||||
|  | ||||
|   // set width of sticky element when it is fixed to page (used to make sure 100% width is maintained if no fixed size set) | ||||
|   setSize        : true, | ||||
|  | ||||
|   // Whether to automatically observe changes with Mutation Observers | ||||
|   observeChanges : false, | ||||
|  | ||||
|   // Called when position is recalculated | ||||
|   onReposition   : function(){}, | ||||
|  | ||||
|   // Called on each scroll | ||||
|   onScroll       : function(){}, | ||||
|  | ||||
|   // Called when element is stuck to viewport | ||||
|   onStick        : function(){}, | ||||
|  | ||||
|   // Called when element is unstuck from viewport | ||||
|   onUnstick      : function(){}, | ||||
|  | ||||
|   // Called when element reaches top of context | ||||
|   onTop          : function(){}, | ||||
|  | ||||
|   // Called when element reaches bottom of context | ||||
|   onBottom       : function(){}, | ||||
|  | ||||
|   error         : { | ||||
|     container      : 'Sticky element must be inside a relative container', | ||||
|     visible        : 'Element is hidden, you must call refresh after element becomes visible. Use silent setting to surpress this warning in production.', | ||||
|     method         : 'The method you called is not defined.', | ||||
|     invalidContext : 'Context specified does not exist', | ||||
|     elementSize    : 'Sticky element is larger than its container, cannot create sticky.' | ||||
|   }, | ||||
|  | ||||
|   className : { | ||||
|     bound     : 'bound', | ||||
|     fixed     : 'fixed', | ||||
|     supported : 'native', | ||||
|     top       : 'top', | ||||
|     bottom    : 'bottom' | ||||
|   } | ||||
|  | ||||
| }; | ||||
|  | ||||
| })( jQuery, window, document ); | ||||
| @@ -1,74 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Sticky | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Theme | ||||
| *******************************/ | ||||
|  | ||||
| @type    : 'module'; | ||||
| @element : 'sticky'; | ||||
|  | ||||
| @import (multiple) '../../theme.config'; | ||||
|  | ||||
| /******************************* | ||||
|             Sticky | ||||
| *******************************/ | ||||
|  | ||||
| .ui.sticky { | ||||
|   position: static; | ||||
|   transition: @transition; | ||||
|   z-index: @zIndex; | ||||
| } | ||||
|  | ||||
| /******************************* | ||||
|             States | ||||
| *******************************/ | ||||
|  | ||||
| /* Bound */ | ||||
| .ui.sticky.bound { | ||||
|   position: absolute; | ||||
|   left: auto; | ||||
|   right: auto; | ||||
| } | ||||
|  | ||||
| /* Fixed */ | ||||
| .ui.sticky.fixed { | ||||
|   position: fixed; | ||||
|   left: auto; | ||||
|   right: auto; | ||||
| } | ||||
|  | ||||
| /* Bound/Fixed Position */ | ||||
| .ui.sticky.bound.top, | ||||
| .ui.sticky.fixed.top { | ||||
|   top: 0px; | ||||
|   bottom: auto; | ||||
| } | ||||
| .ui.sticky.bound.bottom, | ||||
| .ui.sticky.fixed.bottom { | ||||
|   top: auto; | ||||
|   bottom: 0px; | ||||
| } | ||||
|  | ||||
|  | ||||
| /******************************* | ||||
|             Types | ||||
| *******************************/ | ||||
|  | ||||
| .ui.native.sticky { | ||||
|   position: -webkit-sticky; | ||||
|   position: -moz-sticky; | ||||
|   position: -ms-sticky; | ||||
|   position: -o-sticky; | ||||
|   position: sticky; | ||||
| } | ||||
|  | ||||
| .loadUIOverrides(); | ||||
| @@ -1,952 +0,0 @@ | ||||
| /*! | ||||
|  * # Semantic UI - Tab | ||||
|  * http://github.com/semantic-org/semantic-ui/ | ||||
|  * | ||||
|  * | ||||
|  * Released under the MIT license | ||||
|  * http://opensource.org/licenses/MIT | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| ;(function ($, window, document, undefined) { | ||||
|  | ||||
| 'use strict'; | ||||
|  | ||||
| window = (typeof window != 'undefined' && window.Math == Math) | ||||
|   ? window | ||||
|   : (typeof self != 'undefined' && self.Math == Math) | ||||
|     ? self | ||||
|     : Function('return this')() | ||||
| ; | ||||
|  | ||||
| $.fn.tab = function(parameters) { | ||||
|  | ||||
|   var | ||||
|     // use window context if none specified | ||||
|     $allModules     = $.isFunction(this) | ||||
|         ? $(window) | ||||
|         : $(this), | ||||
|  | ||||
|     moduleSelector  = $allModules.selector || '', | ||||
|     time            = new Date().getTime(), | ||||
|     performance     = [], | ||||
|  | ||||
|     query           = arguments[0], | ||||
|     methodInvoked   = (typeof query == 'string'), | ||||
|     queryArguments  = [].slice.call(arguments, 1), | ||||
|  | ||||
|     initializedHistory = false, | ||||
|     returnedValue | ||||
|   ; | ||||
|  | ||||
|   $allModules | ||||
|     .each(function() { | ||||
|       var | ||||
|  | ||||
|         settings        = ( $.isPlainObject(parameters) ) | ||||
|           ? $.extend(true, {}, $.fn.tab.settings, parameters) | ||||
|           : $.extend({}, $.fn.tab.settings), | ||||
|  | ||||
|         className       = settings.className, | ||||
|         metadata        = settings.metadata, | ||||
|         selector        = settings.selector, | ||||
|         error           = settings.error, | ||||
|  | ||||
|         eventNamespace  = '.' + settings.namespace, | ||||
|         moduleNamespace = 'module-' + settings.namespace, | ||||
|  | ||||
|         $module         = $(this), | ||||
|         $context, | ||||
|         $tabs, | ||||
|  | ||||
|         cache           = {}, | ||||
|         firstLoad       = true, | ||||
|         recursionDepth  = 0, | ||||
|         element         = this, | ||||
|         instance        = $module.data(moduleNamespace), | ||||
|  | ||||
|         activeTabPath, | ||||
|         parameterArray, | ||||
|         module, | ||||
|  | ||||
|         historyEvent | ||||
|  | ||||
|       ; | ||||
|  | ||||
|       module = { | ||||
|  | ||||
|         initialize: function() { | ||||
|           module.debug('Initializing tab menu item', $module); | ||||
|           module.fix.callbacks(); | ||||
|           module.determineTabs(); | ||||
|  | ||||
|           module.debug('Determining tabs', settings.context, $tabs); | ||||
|           // set up automatic routing | ||||
|           if(settings.auto) { | ||||
|             module.set.auto(); | ||||
|           } | ||||
|           module.bind.events(); | ||||
|  | ||||
|           if(settings.history && !initializedHistory) { | ||||
|             module.initializeHistory(); | ||||
|             initializedHistory = true; | ||||
|           } | ||||
|  | ||||
|           module.instantiate(); | ||||
|         }, | ||||
|  | ||||
|         instantiate: function () { | ||||
|           module.verbose('Storing instance of module', module); | ||||
|           instance = module; | ||||
|           $module | ||||
|             .data(moduleNamespace, module) | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         destroy: function() { | ||||
|           module.debug('Destroying tabs', $module); | ||||
|           $module | ||||
|             .removeData(moduleNamespace) | ||||
|             .off(eventNamespace) | ||||
|           ; | ||||
|         }, | ||||
|  | ||||
|         bind: { | ||||
|           events: function() { | ||||
|             // if using $.tab don't add events | ||||
|             if( !$.isWindow( element ) ) { | ||||
|               module.debug('Attaching tab activation events to element', $module); | ||||
|               $module | ||||
|                 .on('click' + eventNamespace, module.event.click) | ||||
|               ; | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         determineTabs: function() { | ||||
|           var | ||||
|             $reference | ||||
|           ; | ||||
|  | ||||
|           // determine tab context | ||||
|           if(settings.context === 'parent') { | ||||
|             if($module.closest(selector.ui).length > 0) { | ||||
|               $reference = $module.closest(selector.ui); | ||||
|               module.verbose('Using closest UI element as parent', $reference); | ||||
|             } | ||||
|             else { | ||||
|               $reference = $module; | ||||
|             } | ||||
|             $context = $reference.parent(); | ||||
|             module.verbose('Determined parent element for creating context', $context); | ||||
|           } | ||||
|           else if(settings.context) { | ||||
|             $context = $(settings.context); | ||||
|             module.verbose('Using selector for tab context', settings.context, $context); | ||||
|           } | ||||
|           else { | ||||
|             $context = $('body'); | ||||
|           } | ||||
|           // find tabs | ||||
|           if(settings.childrenOnly) { | ||||
|             $tabs = $context.children(selector.tabs); | ||||
|             module.debug('Searching tab context children for tabs', $context, $tabs); | ||||
|           } | ||||
|           else { | ||||
|             $tabs = $context.find(selector.tabs); | ||||
|             module.debug('Searching tab context for tabs', $context, $tabs); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         fix: { | ||||
|           callbacks: function() { | ||||
|             if( $.isPlainObject(parameters) && (parameters.onTabLoad || parameters.onTabInit) ) { | ||||
|               if(parameters.onTabLoad) { | ||||
|                 parameters.onLoad = parameters.onTabLoad; | ||||
|                 delete parameters.onTabLoad; | ||||
|                 module.error(error.legacyLoad, parameters.onLoad); | ||||
|               } | ||||
|               if(parameters.onTabInit) { | ||||
|                 parameters.onFirstLoad = parameters.onTabInit; | ||||
|                 delete parameters.onTabInit; | ||||
|                 module.error(error.legacyInit, parameters.onFirstLoad); | ||||
|               } | ||||
|               settings = $.extend(true, {}, $.fn.tab.settings, parameters); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         initializeHistory: function() { | ||||
|           module.debug('Initializing page state'); | ||||
|           if( $.address === undefined ) { | ||||
|             module.error(error.state); | ||||
|             return false; | ||||
|           } | ||||
|           else { | ||||
|             if(settings.historyType == 'state') { | ||||
|               module.debug('Using HTML5 to manage state'); | ||||
|               if(settings.path !== false) { | ||||
|                 $.address | ||||
|                   .history(true) | ||||
|                   .state(settings.path) | ||||
|                 ; | ||||
|               } | ||||
|               else { | ||||
|                 module.error(error.path); | ||||
|                 return false; | ||||
|               } | ||||
|             } | ||||
|             $.address | ||||
|               .bind('change', module.event.history.change) | ||||
|             ; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         event: { | ||||
|           click: function(event) { | ||||
|             var | ||||
|               tabPath = $(this).data(metadata.tab) | ||||
|             ; | ||||
|             if(tabPath !== undefined) { | ||||
|               if(settings.history) { | ||||
|                 module.verbose('Updating page state', event); | ||||
|                 $.address.value(tabPath); | ||||
|               } | ||||
|               else { | ||||
|                 module.verbose('Changing tab', event); | ||||
|                 module.changeTab(tabPath); | ||||
|               } | ||||
|               event.preventDefault(); | ||||
|             } | ||||
|             else { | ||||
|               module.debug('No tab specified'); | ||||
|             } | ||||
|           }, | ||||
|           history: { | ||||
|             change: function(event) { | ||||
|               var | ||||
|                 tabPath   = event.pathNames.join('/') || module.get.initialPath(), | ||||
|                 pageTitle = settings.templates.determineTitle(tabPath) || false | ||||
|               ; | ||||
|               module.performance.display(); | ||||
|               module.debug('History change event', tabPath, event); | ||||
|               historyEvent = event; | ||||
|               if(tabPath !== undefined) { | ||||
|                 module.changeTab(tabPath); | ||||
|               } | ||||
|               if(pageTitle) { | ||||
|                 $.address.title(pageTitle); | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         refresh: function() { | ||||
|           if(activeTabPath) { | ||||
|             module.debug('Refreshing tab', activeTabPath); | ||||
|             module.changeTab(activeTabPath); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         cache: { | ||||
|  | ||||
|           read: function(cacheKey) { | ||||
|             return (cacheKey !== undefined) | ||||
|               ? cache[cacheKey] | ||||
|               : false | ||||
|             ; | ||||
|           }, | ||||
|           add: function(cacheKey, content) { | ||||
|             cacheKey = cacheKey || activeTabPath; | ||||
|             module.debug('Adding cached content for', cacheKey); | ||||
|             cache[cacheKey] = content; | ||||
|           }, | ||||
|           remove: function(cacheKey) { | ||||
|             cacheKey = cacheKey || activeTabPath; | ||||
|             module.debug('Removing cached content for', cacheKey); | ||||
|             delete cache[cacheKey]; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         set: { | ||||
|           auto: function() { | ||||
|             var | ||||
|               url = (typeof settings.path == 'string') | ||||
|                 ? settings.path.replace(/\/$/, '') + '/{$tab}' | ||||
|                 : '/{$tab}' | ||||
|             ; | ||||
|             module.verbose('Setting up automatic tab retrieval from server', url); | ||||
|             if($.isPlainObject(settings.apiSettings)) { | ||||
|               settings.apiSettings.url = url; | ||||
|             } | ||||
|             else { | ||||
|               settings.apiSettings = { | ||||
|                 url: url | ||||
|               }; | ||||
|             } | ||||
|           }, | ||||
|           loading: function(tabPath) { | ||||
|             var | ||||
|               $tab      = module.get.tabElement(tabPath), | ||||
|               isLoading = $tab.hasClass(className.loading) | ||||
|             ; | ||||
|             if(!isLoading) { | ||||
|               module.verbose('Setting loading state for', $tab); | ||||
|               $tab | ||||
|                 .addClass(className.loading) | ||||
|                 .siblings($tabs) | ||||
|                   .removeClass(className.active + ' ' + className.loading) | ||||
|               ; | ||||
|               if($tab.length > 0) { | ||||
|                 settings.onRequest.call($tab[0], tabPath); | ||||
|               } | ||||
|             } | ||||
|           }, | ||||
|           state: function(state) { | ||||
|             $.address.value(state); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         changeTab: function(tabPath) { | ||||
|           var | ||||
|             pushStateAvailable = (window.history && window.history.pushState), | ||||
|             shouldIgnoreLoad   = (pushStateAvailable && settings.ignoreFirstLoad && firstLoad), | ||||
|             remoteContent      = (settings.auto || $.isPlainObject(settings.apiSettings) ), | ||||
|             // only add default path if not remote content | ||||
|             pathArray = (remoteContent && !shouldIgnoreLoad) | ||||
|               ? module.utilities.pathToArray(tabPath) | ||||
|               : module.get.defaultPathArray(tabPath) | ||||
|           ; | ||||
|           tabPath = module.utilities.arrayToPath(pathArray); | ||||
|           $.each(pathArray, function(index, tab) { | ||||
|             var | ||||
|               currentPathArray   = pathArray.slice(0, index + 1), | ||||
|               currentPath        = module.utilities.arrayToPath(currentPathArray), | ||||
|  | ||||
|               isTab              = module.is.tab(currentPath), | ||||
|               isLastIndex        = (index + 1 == pathArray.length), | ||||
|  | ||||
|               $tab               = module.get.tabElement(currentPath), | ||||
|               $anchor, | ||||
|               nextPathArray, | ||||
|               nextPath, | ||||
|               isLastTab | ||||
|             ; | ||||
|             module.verbose('Looking for tab', tab); | ||||
|             if(isTab) { | ||||
|               module.verbose('Tab was found', tab); | ||||
|               // scope up | ||||
|               activeTabPath  = currentPath; | ||||
|               parameterArray = module.utilities.filterArray(pathArray, currentPathArray); | ||||
|  | ||||
|               if(isLastIndex) { | ||||
|                 isLastTab = true; | ||||
|               } | ||||
|               else { | ||||
|                 nextPathArray = pathArray.slice(0, index + 2); | ||||
|                 nextPath      = module.utilities.arrayToPath(nextPathArray); | ||||
|                 isLastTab     = ( !module.is.tab(nextPath) ); | ||||
|                 if(isLastTab) { | ||||
|                   module.verbose('Tab parameters found', nextPathArray); | ||||
|                 } | ||||
|               } | ||||
|               if(isLastTab && remoteContent) { | ||||
|                 if(!shouldIgnoreLoad) { | ||||
|                   module.activate.navigation(currentPath); | ||||
|                   module.fetch.content(currentPath, tabPath); | ||||
|                 } | ||||
|                 else { | ||||
|                   module.debug('Ignoring remote content on first tab load', currentPath); | ||||
|                   firstLoad = false; | ||||
|                   module.cache.add(tabPath, $tab.html()); | ||||
|                   module.activate.all(currentPath); | ||||
|                   settings.onFirstLoad.call($tab[0], currentPath, parameterArray, historyEvent); | ||||
|                   settings.onLoad.call($tab[0], currentPath, parameterArray, historyEvent); | ||||
|                 } | ||||
|                 return false; | ||||
|               } | ||||
|               else { | ||||
|                 module.debug('Opened local tab', currentPath); | ||||
|                 module.activate.all(currentPath); | ||||
|                 if( !module.cache.read(currentPath) ) { | ||||
|                   module.cache.add(currentPath, true); | ||||
|                   module.debug('First time tab loaded calling tab init'); | ||||
|                   settings.onFirstLoad.call($tab[0], currentPath, parameterArray, historyEvent); | ||||
|                 } | ||||
|                 settings.onLoad.call($tab[0], currentPath, parameterArray, historyEvent); | ||||
|               } | ||||
|  | ||||
|             } | ||||
|             else if(tabPath.search('/') == -1 && tabPath !== '') { | ||||
|               // look for in page anchor | ||||
|               $anchor     = $('#' + tabPath + ', a[name="' + tabPath + '"]'); | ||||
|               currentPath = $anchor.closest('[data-tab]').data(metadata.tab); | ||||
|               $tab        = module.get.tabElement(currentPath); | ||||
|               // if anchor exists use parent tab | ||||
|               if($anchor && $anchor.length > 0 && currentPath) { | ||||
|                 module.debug('Anchor link used, opening parent tab', $tab, $anchor); | ||||
|                 if( !$tab.hasClass(className.active) ) { | ||||
|                   setTimeout(function() { | ||||
|                     module.scrollTo($anchor); | ||||
|                   }, 0); | ||||
|                 } | ||||
|                 module.activate.all(currentPath); | ||||
|                 if( !module.cache.read(currentPath) ) { | ||||
|                   module.cache.add(currentPath, true); | ||||
|                   module.debug('First time tab loaded calling tab init'); | ||||
|                   settings.onFirstLoad.call($tab[0], currentPath, parameterArray, historyEvent); | ||||
|                 } | ||||
|                 settings.onLoad.call($tab[0], currentPath, parameterArray, historyEvent); | ||||
|                 return false; | ||||
|               } | ||||
|             } | ||||
|             else { | ||||
|               module.error(error.missingTab, $module, $context, currentPath); | ||||
|               return false; | ||||
|             } | ||||
|           }); | ||||
|         }, | ||||
|  | ||||
|         scrollTo: function($element) { | ||||
|           var | ||||
|             scrollOffset = ($element && $element.length > 0) | ||||
|               ? $element.offset().top | ||||
|               : false | ||||
|           ; | ||||
|           if(scrollOffset !== false) { | ||||
|             module.debug('Forcing scroll to an in-page link in a hidden tab', scrollOffset, $element); | ||||
|             $(document).scrollTop(scrollOffset); | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         update: { | ||||
|           content: function(tabPath, html, evaluateScripts) { | ||||
|             var | ||||
|               $tab = module.get.tabElement(tabPath), | ||||
|               tab  = $tab[0] | ||||
|             ; | ||||
|             evaluateScripts = (evaluateScripts !== undefined) | ||||
|               ? evaluateScripts | ||||
|               : settings.evaluateScripts | ||||
|             ; | ||||
|             if(typeof settings.cacheType == 'string' && settings.cacheType.toLowerCase() == 'dom' && typeof html !== 'string') { | ||||
|               $tab | ||||
|                 .empty() | ||||
|                 .append($(html).clone(true)) | ||||
|               ; | ||||
|             } | ||||
|             else { | ||||
|               if(evaluateScripts) { | ||||
|                 module.debug('Updating HTML and evaluating inline scripts', tabPath, html); | ||||
|                 $tab.html(html); | ||||
|               } | ||||
|               else { | ||||
|                 module.debug('Updating HTML', tabPath, html); | ||||
|                 tab.innerHTML = html; | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         fetch: { | ||||
|  | ||||
|           content: function(tabPath, fullTabPath) { | ||||
|             var | ||||
|               $tab        = module.get.tabElement(tabPath), | ||||
|               apiSettings = { | ||||
|                 dataType         : 'html', | ||||
|                 encodeParameters : false, | ||||
|                 on               : 'now', | ||||
|                 cache            : settings.alwaysRefresh, | ||||
|                 headers          : { | ||||
|                   'X-Remote': true | ||||
|                 }, | ||||
|                 onSuccess : function(response) { | ||||
|                   if(settings.cacheType == 'response') { | ||||
|                     module.cache.add(fullTabPath, response); | ||||
|                   } | ||||
|                   module.update.content(tabPath, response); | ||||
|                   if(tabPath == activeTabPath) { | ||||
|                     module.debug('Content loaded', tabPath); | ||||
|                     module.activate.tab(tabPath); | ||||
|                   } | ||||
|                   else { | ||||
|                     module.debug('Content loaded in background', tabPath); | ||||
|                   } | ||||
|                   settings.onFirstLoad.call($tab[0], tabPath, parameterArray, historyEvent); | ||||
|                   settings.onLoad.call($tab[0], tabPath, parameterArray, historyEvent); | ||||
|  | ||||
|                   if(settings.loadOnce) { | ||||
|                     module.cache.add(fullTabPath, true); | ||||
|                   } | ||||
|                   else if(typeof settings.cacheType == 'string' && settings.cacheType.toLowerCase() == 'dom' && $tab.children().length > 0) { | ||||
|                     setTimeout(function() { | ||||
|                       var | ||||
|                         $clone = $tab.children().clone(true) | ||||
|                       ; | ||||
|                       $clone = $clone.not('script'); | ||||
|                       module.cache.add(fullTabPath, $clone); | ||||
|                     }, 0); | ||||
|                   } | ||||
|                   else { | ||||
|                     module.cache.add(fullTabPath, $tab.html()); | ||||
|                   } | ||||
|                 }, | ||||
|                 urlData: { | ||||
|                   tab: fullTabPath | ||||
|                 } | ||||
|               }, | ||||
|               request         = $tab.api('get request') || false, | ||||
|               existingRequest = ( request && request.state() === 'pending' ), | ||||
|               requestSettings, | ||||
|               cachedContent | ||||
|             ; | ||||
|  | ||||
|             fullTabPath   = fullTabPath || tabPath; | ||||
|             cachedContent = module.cache.read(fullTabPath); | ||||
|  | ||||
|  | ||||
|             if(settings.cache && cachedContent) { | ||||
|               module.activate.tab(tabPath); | ||||
|               module.debug('Adding cached content', fullTabPath); | ||||
|               if(!settings.loadOnce) { | ||||
|                 if(settings.evaluateScripts == 'once') { | ||||
|                   module.update.content(tabPath, cachedContent, false); | ||||
|                 } | ||||
|                 else { | ||||
|                   module.update.content(tabPath, cachedContent); | ||||
|                 } | ||||
|               } | ||||
|               settings.onLoad.call($tab[0], tabPath, parameterArray, historyEvent); | ||||
|             } | ||||
|             else if(existingRequest) { | ||||
|               module.set.loading(tabPath); | ||||
|               module.debug('Content is already loading', fullTabPath); | ||||
|             } | ||||
|             else if($.api !== undefined) { | ||||
|               requestSettings = $.extend(true, {}, settings.apiSettings, apiSettings); | ||||
|               module.debug('Retrieving remote content', fullTabPath, requestSettings); | ||||
|               module.set.loading(tabPath); | ||||
|               $tab.api(requestSettings); | ||||
|             } | ||||
|             else { | ||||
|               module.error(error.api); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         activate: { | ||||
|           all: function(tabPath) { | ||||
|             module.activate.tab(tabPath); | ||||
|             module.activate.navigation(tabPath); | ||||
|           }, | ||||
|           tab: function(tabPath) { | ||||
|             var | ||||
|               $tab          = module.get.tabElement(tabPath), | ||||
|               $deactiveTabs = (settings.deactivate == 'siblings') | ||||
|                 ? $tab.siblings($tabs) | ||||
|                 : $tabs.not($tab), | ||||
|               isActive      = $tab.hasClass(className.active) | ||||
|             ; | ||||
|             module.verbose('Showing tab content for', $tab); | ||||
|             if(!isActive) { | ||||
|               $tab | ||||
|                 .addClass(className.active) | ||||
|               ; | ||||
|               $deactiveTabs | ||||
|                 .removeClass(className.active + ' ' + className.loading) | ||||
|               ; | ||||
|               if($tab.length > 0) { | ||||
|                 settings.onVisible.call($tab[0], tabPath); | ||||
|               } | ||||
|             } | ||||
|           }, | ||||
|           navigation: function(tabPath) { | ||||
|             var | ||||
|               $navigation         = module.get.navElement(tabPath), | ||||
|               $deactiveNavigation = (settings.deactivate == 'siblings') | ||||
|                 ? $navigation.siblings($allModules) | ||||
|                 : $allModules.not($navigation), | ||||
|               isActive    = $navigation.hasClass(className.active) | ||||
|             ; | ||||
|             module.verbose('Activating tab navigation for', $navigation, tabPath); | ||||
|             if(!isActive) { | ||||
|               $navigation | ||||
|                 .addClass(className.active) | ||||
|               ; | ||||
|               $deactiveNavigation | ||||
|                 .removeClass(className.active + ' ' + className.loading) | ||||
|               ; | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         deactivate: { | ||||
|           all: function() { | ||||
|             module.deactivate.navigation(); | ||||
|             module.deactivate.tabs(); | ||||
|           }, | ||||
|           navigation: function() { | ||||
|             $allModules | ||||
|               .removeClass(className.active) | ||||
|             ; | ||||
|           }, | ||||
|           tabs: function() { | ||||
|             $tabs | ||||
|               .removeClass(className.active + ' ' + className.loading) | ||||
|             ; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         is: { | ||||
|           tab: function(tabName) { | ||||
|             return (tabName !== undefined) | ||||
|               ? ( module.get.tabElement(tabName).length > 0 ) | ||||
|               : false | ||||
|             ; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         get: { | ||||
|           initialPath: function() { | ||||
|             return $allModules.eq(0).data(metadata.tab) || $tabs.eq(0).data(metadata.tab); | ||||
|           }, | ||||
|           path: function() { | ||||
|             return $.address.value(); | ||||
|           }, | ||||
|           // adds default tabs to tab path | ||||
|           defaultPathArray: function(tabPath) { | ||||
|             return module.utilities.pathToArray( module.get.defaultPath(tabPath) ); | ||||
|           }, | ||||
|           defaultPath: function(tabPath) { | ||||
|             var | ||||
|               $defaultNav = $allModules.filter('[data-' + metadata.tab + '^="' + tabPath + '/"]').eq(0), | ||||
|               defaultTab  = $defaultNav.data(metadata.tab) || false | ||||
|             ; | ||||
|             if( defaultTab ) { | ||||
|               module.debug('Found default tab', defaultTab); | ||||
|               if(recursionDepth < settings.maxDepth) { | ||||
|                 recursionDepth++; | ||||
|                 return module.get.defaultPath(defaultTab); | ||||
|               } | ||||
|               module.error(error.recursion); | ||||
|             } | ||||
|             else { | ||||
|               module.debug('No default tabs found for', tabPath, $tabs); | ||||
|             } | ||||
|             recursionDepth = 0; | ||||
|             return tabPath; | ||||
|           }, | ||||
|           navElement: function(tabPath) { | ||||
|             tabPath = tabPath || activeTabPath; | ||||
|             return $allModules.filter('[data-' + metadata.tab + '="' + tabPath + '"]'); | ||||
|           }, | ||||
|           tabElement: function(tabPath) { | ||||
|             var | ||||
|               $fullPathTab, | ||||
|               $simplePathTab, | ||||
|               tabPathArray, | ||||
|               lastTab | ||||
|             ; | ||||
|             tabPath        = tabPath || activeTabPath; | ||||
|             tabPathArray   = module.utilities.pathToArray(tabPath); | ||||
|             lastTab        = module.utilities.last(tabPathArray); | ||||
|             $fullPathTab   = $tabs.filter('[data-' + metadata.tab + '="' + tabPath + '"]'); | ||||
|             $simplePathTab = $tabs.filter('[data-' + metadata.tab + '="' + lastTab + '"]'); | ||||
|             return ($fullPathTab.length > 0) | ||||
|               ? $fullPathTab | ||||
|               : $simplePathTab | ||||
|             ; | ||||
|           }, | ||||
|           tab: function() { | ||||
|             return activeTabPath; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         utilities: { | ||||
|           filterArray: function(keepArray, removeArray) { | ||||
|             return $.grep(keepArray, function(keepValue) { | ||||
|               return ( $.inArray(keepValue, removeArray) == -1); | ||||
|             }); | ||||
|           }, | ||||
|           last: function(array) { | ||||
|             return $.isArray(array) | ||||
|               ? array[ array.length - 1] | ||||
|               : false | ||||
|             ; | ||||
|           }, | ||||
|           pathToArray: function(pathName) { | ||||
|             if(pathName === undefined) { | ||||
|               pathName = activeTabPath; | ||||
|             } | ||||
|             return typeof pathName == 'string' | ||||
|               ? pathName.split('/') | ||||
|               : [pathName] | ||||
|             ; | ||||
|           }, | ||||
|           arrayToPath: function(pathArray) { | ||||
|             return $.isArray(pathArray) | ||||
|               ? pathArray.join('/') | ||||
|               : false | ||||
|             ; | ||||
|           } | ||||
|         }, | ||||
|  | ||||
|         setting: function(name, value) { | ||||
|           module.debug('Changing setting', name, value); | ||||
|           if( $.isPlainObject(name) ) { | ||||
|             $.extend(true, settings, name); | ||||
|           } | ||||
|           else if(value !== undefined) { | ||||
|             if($.isPlainObject(settings[name])) { | ||||
|               $.extend(true, settings[name], value); | ||||
|             } | ||||
|             else { | ||||
|               settings[name] = value; | ||||
|             } | ||||
|           } | ||||
|           else { | ||||
|             return settings[name]; | ||||
|           } | ||||
|         }, | ||||
|         internal: function(name, value) { | ||||
|           if( $.isPlainObject(name) ) { | ||||
|             $.extend(true, module, name); | ||||
|           } | ||||
|           else if(value !== undefined) { | ||||
|             module[name] = value; | ||||
|           } | ||||
|           else { | ||||
|             return module[name]; | ||||
|           } | ||||
|         }, | ||||
|         debug: function() { | ||||
|           if(!settings.silent && settings.debug) { | ||||
|             if(settings.performance) { | ||||
|               module.performance.log(arguments); | ||||
|             } | ||||
|             else { | ||||
|               module.debug = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|               module.debug.apply(console, arguments); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         verbose: function() { | ||||
|           if(!settings.silent && settings.verbose && settings.debug) { | ||||
|             if(settings.performance) { | ||||
|               module.performance.log(arguments); | ||||
|             } | ||||
|             else { | ||||
|               module.verbose = Function.prototype.bind.call(console.info, console, settings.name + ':'); | ||||
|               module.verbose.apply(console, arguments); | ||||
|             } | ||||
|           } | ||||
|         }, | ||||
|         error: function() { | ||||
|           if(!settings.silent) { | ||||
|             module.error = Function.prototype.bind.call(console.error, console, settings.name + ':'); | ||||
|             module.error.apply(console, arguments); | ||||
|           } | ||||
|         }, | ||||
|         performance: { | ||||
|           log: function(message) { | ||||
|             var | ||||
|               currentTime, | ||||
|               executionTime, | ||||
|               previousTime | ||||
|             ; | ||||
|             if(settings.performance) { | ||||
|               currentTime   = new Date().getTime(); | ||||
|               previousTime  = time || currentTime; | ||||
|               executionTime = currentTime - previousTime; | ||||
|               time          = currentTime; | ||||
|               performance.push({ | ||||
|                 'Name'           : message[0], | ||||
|                 'Arguments'      : [].slice.call(message, 1) || '', | ||||
|                 'Element'        : element, | ||||
|                 'Execution Time' : executionTime | ||||
|               }); | ||||
|             } | ||||
|             clearTimeout(module.performance.timer); | ||||
|             module.performance.timer = setTimeout(module.performance.display, 500); | ||||
|           }, | ||||
|           display: function() { | ||||
|             var | ||||
|               title = settings.name + ':', | ||||
|               totalTime = 0 | ||||
|             ; | ||||
|             time = false; | ||||
|             clearTimeout(module.performance.timer); | ||||
|             $.each(performance, function(index, data) { | ||||
|               totalTime += data['Execution Time']; | ||||
|             }); | ||||
|             title += ' ' + totalTime + 'ms'; | ||||
|             if(moduleSelector) { | ||||
|               title += ' \'' + moduleSelector + '\''; | ||||
|             } | ||||
|             if( (console.group !== undefined || console.table !== undefined) && performance.length > 0) { | ||||
|               console.groupCollapsed(title); | ||||
|               if(console.table) { | ||||
|                 console.table(performance); | ||||
|               } | ||||
|               else { | ||||
|                 $.each(performance, function(index, data) { | ||||
|                   console.log(data['Name'] + ': ' + data['Execution Time']+'ms'); | ||||
|                 }); | ||||
|               } | ||||
|               console.groupEnd(); | ||||
|             } | ||||
|             performance = []; | ||||
|           } | ||||
|         }, | ||||
|         invoke: function(query, passedArguments, context) { | ||||
|           var | ||||
|             object = instance, | ||||
|             maxDepth, | ||||
|             found, | ||||
|             response | ||||
|           ; | ||||
|           passedArguments = passedArguments || queryArguments; | ||||
|           context         = element         || context; | ||||
|           if(typeof query == 'string' && object !== undefined) { | ||||
|             query    = query.split(/[\. ]/); | ||||
|             maxDepth = query.length - 1; | ||||
|             $.each(query, function(depth, value) { | ||||
|               var camelCaseValue = (depth != maxDepth) | ||||
|                 ? value + query[depth + 1].charAt(0).toUpperCase() + query[depth + 1].slice(1) | ||||
|                 : query | ||||
|               ; | ||||
|               if( $.isPlainObject( object[camelCaseValue] ) && (depth != maxDepth) ) { | ||||
|                 object = object[camelCaseValue]; | ||||
|               } | ||||
|               else if( object[camelCaseValue] !== undefined ) { | ||||
|                 found = object[camelCaseValue]; | ||||
|                 return false; | ||||
|               } | ||||
|               else if( $.isPlainObject( object[value] ) && (depth != maxDepth) ) { | ||||
|                 object = object[value]; | ||||
|               } | ||||
|               else if( object[value] !== undefined ) { | ||||
|                 found = object[value]; | ||||
|                 return false; | ||||
|               } | ||||
|               else { | ||||
|                 module.error(error.method, query); | ||||
|                 return false; | ||||
|               } | ||||
|             }); | ||||
|           } | ||||
|           if ( $.isFunction( found ) ) { | ||||
|             response = found.apply(context, passedArguments); | ||||
|           } | ||||
|           else if(found !== undefined) { | ||||
|             response = found; | ||||
|           } | ||||
|           if($.isArray(returnedValue)) { | ||||
|             returnedValue.push(response); | ||||
|           } | ||||
|           else if(returnedValue !== undefined) { | ||||
|             returnedValue = [returnedValue, response]; | ||||
|           } | ||||
|           else if(response !== undefined) { | ||||
|             returnedValue = response; | ||||
|           } | ||||
|           return found; | ||||
|         } | ||||
|       }; | ||||
|       if(methodInvoked) { | ||||
|         if(instance === undefined) { | ||||
|           module.initialize(); | ||||
|         } | ||||
|         module.invoke(query); | ||||
|       } | ||||
|       else { | ||||
|         if(instance !== undefined) { | ||||
|           instance.invoke('destroy'); | ||||
|         } | ||||
|         module.initialize(); | ||||
|       } | ||||
|     }) | ||||
|   ; | ||||
|   return (returnedValue !== undefined) | ||||
|     ? returnedValue | ||||
|     : this | ||||
|   ; | ||||
|  | ||||
| }; | ||||
|  | ||||
| // shortcut for tabbed content with no defined navigation | ||||
| $.tab = function() { | ||||
|   $(window).tab.apply(this, arguments); | ||||
| }; | ||||
|  | ||||
| $.fn.tab.settings = { | ||||
|  | ||||
|   name            : 'Tab', | ||||
|   namespace       : 'tab', | ||||
|  | ||||
|   silent          : false, | ||||
|   debug           : false, | ||||
|   verbose         : false, | ||||
|   performance     : true, | ||||
|  | ||||
|   auto            : false,      // uses pjax style endpoints fetching content from same url with remote-content headers | ||||
|   history         : false,      // use browser history | ||||
|   historyType     : 'hash',     // #/ or html5 state | ||||
|   path            : false,      // base path of url | ||||
|  | ||||
|   context         : false,      // specify a context that tabs must appear inside | ||||
|   childrenOnly    : false,      // use only tabs that are children of context | ||||
|   maxDepth        : 25,         // max depth a tab can be nested | ||||
|  | ||||
|   deactivate      : 'siblings', // whether tabs should deactivate sibling menu elements or all elements initialized together | ||||
|  | ||||
|   alwaysRefresh   : false,      // load tab content new every tab click | ||||
|   cache           : true,       // cache the content requests to pull locally | ||||
|   loadOnce        : false,      // Whether tab data should only be loaded once when using remote content | ||||
|   cacheType       : 'response', // Whether to cache exact response, or to html cache contents after scripts execute | ||||
|   ignoreFirstLoad : false,      // don't load remote content on first load | ||||
|  | ||||
|   apiSettings     : false,      // settings for api call | ||||
|   evaluateScripts : 'once',     // whether inline scripts should be parsed (true/false/once). Once will not re-evaluate on cached content | ||||
|  | ||||
|   onFirstLoad : function(tabPath, parameterArray, historyEvent) {}, // called first time loaded | ||||
|   onLoad      : function(tabPath, parameterArray, historyEvent) {}, // called on every load | ||||
|   onVisible   : function(tabPath, parameterArray, historyEvent) {}, // called every time tab visible | ||||
|   onRequest   : function(tabPath, parameterArray, historyEvent) {}, // called ever time a tab beings loading remote content | ||||
|  | ||||
|   templates : { | ||||
|     determineTitle: function(tabArray) {} // returns page title for path | ||||
|   }, | ||||
|  | ||||
|   error: { | ||||
|     api        : 'You attempted to load content without API module', | ||||
|     method     : 'The method you called is not defined', | ||||
|     missingTab : 'Activated tab cannot be found. Tabs are case-sensitive.', | ||||
|     noContent  : 'The tab you specified is missing a content url.', | ||||
|     path       : 'History enabled, but no path was specified', | ||||
|     recursion  : 'Max recursive depth reached', | ||||
|     legacyInit : 'onTabInit has been renamed to onFirstLoad in 2.0, please adjust your code.', | ||||
|     legacyLoad : 'onTabLoad has been renamed to onLoad in 2.0. Please adjust your code', | ||||
|     state      : 'History requires Asual\'s Address library <https://github.com/asual/jquery-address>' | ||||
|   }, | ||||
|  | ||||
|   metadata : { | ||||
|     tab    : 'tab', | ||||
|     loaded : 'loaded', | ||||
|     promise: 'promise' | ||||
|   }, | ||||
|  | ||||
|   className   : { | ||||
|     loading : 'loading', | ||||
|     active  : 'active' | ||||
|   }, | ||||
|  | ||||
|   selector    : { | ||||
|     tabs : '.ui.tab', | ||||
|     ui   : '.ui' | ||||
|   } | ||||
|  | ||||
| }; | ||||
|  | ||||
| })( jQuery, window, document ); | ||||