├── _config.yml ├── .browserslistrc ├── babel.config.js ├── public ├── favicon.ico └── index.html ├── src ├── assets │ ├── logo.png │ └── utils.js ├── views │ ├── About.vue │ ├── Home.vue │ ├── mlaBook.vue │ ├── chicagoWebsite.vue │ ├── apaWebsite.vue │ ├── mlaWebsite.vue │ ├── apaBook.vue │ └── chicagoBook.vue ├── main.js ├── components │ ├── HelloWorld.vue │ ├── footer.vue │ ├── mlaBookForm.vue │ ├── chicagoBookForm.vue │ ├── chicagoWebsiteForm.vue │ ├── apaWebsiteForm.vue │ ├── apaBookForm.vue │ └── mlaWebsiteForm.vue ├── router.js ├── App.vue ├── background.js └── css │ └── pure-min.css ├── postcss.config.js ├── readme └── Biblio-Feb-03-2019.gif ├── .gitignore ├── .eslintrc.js ├── vue.config.js ├── package.json ├── LICENSE.TXT └── README.md /_config.yml: -------------------------------------------------------------------------------- 1 | theme: jekyll-theme-cayman -------------------------------------------------------------------------------- /.browserslistrc: -------------------------------------------------------------------------------- 1 | > 1% 2 | last 2 versions 3 | not ie <= 8 4 | -------------------------------------------------------------------------------- /babel.config.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | presets: [ 3 | '@vue/app' 4 | ] 5 | } 6 | -------------------------------------------------------------------------------- /public/favicon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/JoshuaManuel/biblio/HEAD/public/favicon.ico -------------------------------------------------------------------------------- /src/assets/logo.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/JoshuaManuel/biblio/HEAD/src/assets/logo.png -------------------------------------------------------------------------------- /postcss.config.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | plugins: { 3 | autoprefixer: {} 4 | } 5 | } 6 | -------------------------------------------------------------------------------- /readme/Biblio-Feb-03-2019.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/JoshuaManuel/biblio/HEAD/readme/Biblio-Feb-03-2019.gif -------------------------------------------------------------------------------- /src/views/About.vue: -------------------------------------------------------------------------------- 1 | 8 | -------------------------------------------------------------------------------- /src/main.js: -------------------------------------------------------------------------------- 1 | import Vue from 'vue' 2 | import App from './App.vue' 3 | import router from './router' 4 | 5 | Vue.config.productionTip = false 6 | 7 | new Vue({ 8 | router, 9 | render: h => h(App) 10 | }).$mount('#app') 11 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | .DS_Store 2 | node_modules 3 | /dist 4 | 5 | # local env files 6 | .env.local 7 | .env.*.local 8 | 9 | # Log files 10 | npm-debug.log* 11 | yarn-debug.log* 12 | yarn-error.log* 13 | 14 | # Editor directories and files 15 | .idea 16 | .vscode 17 | *.suo 18 | *.ntvs* 19 | *.njsproj 20 | *.sln 21 | *.sw* 22 | 23 | #Electron-builder output 24 | /dist_electron -------------------------------------------------------------------------------- /.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | root: true, 3 | env: { 4 | node: true 5 | }, 6 | 'extends': [ 7 | 'plugin:vue/essential', 8 | 'eslint:recommended' 9 | ], 10 | rules: { 11 | 'no-console': process.env.NODE_ENV === 'production' ? 'error' : 'off', 12 | 'no-debugger': process.env.NODE_ENV === 'production' ? 'error' : 'off' 13 | }, 14 | parserOptions: { 15 | parser: 'babel-eslint' 16 | } 17 | } 18 | -------------------------------------------------------------------------------- /vue.config.js: -------------------------------------------------------------------------------- 1 | //vue.config.js 2 | 3 | module.exports = { 4 | pluginOptions: { 5 | electronBuilder: { 6 | builderOptions: { 7 | // options placed here will be merged with default configuration and passed to electron-builder 8 | "appId": "com.JoshuaManuel.biblio", 9 | "icon": "./Biblio_Logo.icns", 10 | "directories": { 11 | "buildResources": "./build" 12 | }, 13 | "mac": { 14 | "category": "public.app-category.developer-tools" 15 | } 16 | } 17 | } 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /src/components/HelloWorld.vue: -------------------------------------------------------------------------------- 1 | 6 | 7 | 15 | 16 | 17 | 33 | -------------------------------------------------------------------------------- /public/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | biblio 9 | 10 | 11 | 14 |
15 | 16 | 17 | 18 | -------------------------------------------------------------------------------- /src/views/Home.vue: -------------------------------------------------------------------------------- 1 | 10 | 11 | 22 | -------------------------------------------------------------------------------- /src/views/mlaBook.vue: -------------------------------------------------------------------------------- 1 | 14 | 15 | 29 | -------------------------------------------------------------------------------- /src/views/chicagoWebsite.vue: -------------------------------------------------------------------------------- 1 | 16 | 17 | 31 | -------------------------------------------------------------------------------- /src/views/apaWebsite.vue: -------------------------------------------------------------------------------- 1 | 17 | 18 | 32 | -------------------------------------------------------------------------------- /src/views/mlaWebsite.vue: -------------------------------------------------------------------------------- 1 | 17 | 18 | 32 | -------------------------------------------------------------------------------- /src/views/apaBook.vue: -------------------------------------------------------------------------------- 1 | 17 | 18 | 33 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "biblio", 3 | "version": "1.2.0", 4 | "private": true, 5 | "scripts": { 6 | "serve": "vue-cli-service serve", 7 | "build": "vue-cli-service build", 8 | "lint": "vue-cli-service lint", 9 | "electron:build": "vue-cli-service electron:build", 10 | "electron:serve": "vue-cli-service electron:serve", 11 | "postinstall": "electron-builder install-app-deps" 12 | }, 13 | "dependencies": { 14 | "vue": "^2.5.21", 15 | "vue-router": "^3.0.1" 16 | }, 17 | "devDependencies": { 18 | "@vue/cli-plugin-babel": "^3.3.0", 19 | "@vue/cli-plugin-eslint": "^3.3.0", 20 | "@vue/cli-service": "^3.3.0", 21 | "babel-eslint": "^10.0.1", 22 | "electron": "^4.0.0", 23 | "eslint": "^5.8.0", 24 | "eslint-plugin-vue": "^5.0.0", 25 | "vue-cli-plugin-electron-builder": "^1.0.0-rc.10", 26 | "vue-template-compiler": "^2.5.21" 27 | }, 28 | "main": "background.js" 29 | } 30 | -------------------------------------------------------------------------------- /src/views/chicagoBook.vue: -------------------------------------------------------------------------------- 1 | 22 | 23 | 37 | -------------------------------------------------------------------------------- /LICENSE.TXT: -------------------------------------------------------------------------------- 1 | Copyright 2019 Joshua Manuel 2 | 3 | Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: 4 | 5 | The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. 6 | 7 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 8 | -------------------------------------------------------------------------------- /src/components/footer.vue: -------------------------------------------------------------------------------- 1 | 9 | 10 | 14 | 15 | 53 | -------------------------------------------------------------------------------- /src/assets/utils.js: -------------------------------------------------------------------------------- 1 | 2 | export function initialState() { 3 | return { 4 | lName: '', 5 | fName:'', 6 | fInitial: '', 7 | mInitial: '', 8 | Year: '', 9 | Month:'', 10 | Day: '', 11 | YearPub: '', 12 | MonthPub: '', 13 | DayPub: '', 14 | Title: '', 15 | url: '', 16 | City: '', 17 | State: '', 18 | Publisher: '', 19 | Pages: '', 20 | Website: '' 21 | } 22 | } 23 | //not needed. Make sure to delete once all the pages are in! 24 | export function resetForm() { 25 | this.lName = ''; 26 | this.fName = ''; 27 | this.fInitial = ''; 28 | this.mInitial = ''; 29 | this.Year = ''; 30 | this.Month = ''; 31 | this.Day = ''; 32 | this.Title = ''; 33 | this.url = ''; 34 | this.City = ''; 35 | this.State = ''; 36 | this.Publisher = ''; 37 | this.Pages = ''; 38 | this.Website = ''; 39 | } 40 | 41 | export function convertHtmlToRtf(html) { 42 | var header = "{\\rtf1\\ansi\\deff0\n" 43 | var footer = "}" 44 | 45 | html = html.replace("", "{\\i ") 46 | html = html.replace("", "}") 47 | 48 | console.log(header + html+ footer); 49 | //console.log(html) 50 | return header + html + footer; 51 | } 52 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | 2 | 3 | # Biblio 4 | 5 | An app to help you create APA, MLA, and Chicago-style citations quickly and easily! 6 | 7 | ## How it works: 8 | 9 | Just fill in the fields and then click on the completed citations to copy them to your clipboard! 10 | 11 | ![](readme/Biblio-Feb-03-2019.gif) 12 | 13 | ## Installation 14 | 15 | 1) Go to the **Releases** tab right above the green "clone/download" button 16 | 2) Download the most recent "biblio-X.X.X-mac.zip" file 17 | 3) Open it up and drag it to your Applications folder 18 | 19 | If you get an **error about an unidentified developer**, control-click the app and hit open. 20 | 21 | Download or clone the repo, then run "npm run electron:serve" in the directory to build and launch the program in developer mode. 22 | 23 | To build the app for your system, run "npm run electron:build" 24 | 25 | ## Built With 26 | 27 | * [Vue CLI 3](https://cli.vuejs.org/)- Command line tool for scaffolding the initial Vue project 28 | 29 | * [Electron](https://electronjs.org/) - Dependency Management 30 | 31 | * [vue-cli-plugin-electron-builder](https://github.com/nklayman/vue-cli-plugin-electron-builder) - Scaffolding Electron in Biblio 32 | 33 | * [PureCSS](https://purecss.io/) - some CSS formatting 34 | 35 | 36 | 37 | ## Authors 38 | 39 | * **Joshua Manuel** - *Initial work* - [JoshuaManuel](https://github.com/JoshuaManuel) 40 | 41 | ## License 42 | 43 | MIT 44 | -------------------------------------------------------------------------------- /src/router.js: -------------------------------------------------------------------------------- 1 | import Vue from 'vue' 2 | import Router from 'vue-router' 3 | import Home from './views/Home.vue' 4 | 5 | import apaBook from "./views/apaBook.vue" 6 | import apaWebsite from "./views/apaWebsite.vue" 7 | import chicagoBook from "./views/chicagoBook.vue" 8 | import chicagoWebsite from "./views/chicagoWebsite.vue" 9 | import mlaBook from "./views/mlaBook.vue" 10 | import mlaWebsite from "./views/mlaWebsite.vue" 11 | 12 | Vue.use(Router) 13 | 14 | export default new Router({ 15 | routes: [ 16 | { 17 | path: '/', 18 | name: 'home', 19 | component: Home 20 | }, 21 | { 22 | path: '/apaBook', 23 | name: 'APA Book', 24 | component: apaBook 25 | }, 26 | { 27 | path: '/apaWebsite', 28 | name: 'APA Website', 29 | component: apaWebsite 30 | }, 31 | { 32 | path: '/chicagoBook', 33 | name: 'Chicago Book', 34 | component: chicagoBook 35 | }, 36 | { 37 | path: '/chicagoWebsite', 38 | name: 'Chicago Website', 39 | component: chicagoWebsite 40 | }, 41 | { 42 | path: '/mlaBook', 43 | name: 'MLA Book', 44 | component: mlaBook 45 | }, 46 | { 47 | path: '/mlaWebsite', 48 | name: 'MLA Website', 49 | component: mlaWebsite 50 | }, 51 | { 52 | path: '/about', 53 | name: 'about', 54 | // route level code-splitting 55 | // this generates a separate chunk (about.[hash].js) for this route 56 | // which is lazy-loaded when the route is visited. 57 | component: () => import(/* webpackChunkName: "about" */ './views/About.vue') 58 | } 59 | ] 60 | }) 61 | -------------------------------------------------------------------------------- /src/components/mlaBookForm.vue: -------------------------------------------------------------------------------- 1 | 45 | 46 | 81 | -------------------------------------------------------------------------------- /src/App.vue: -------------------------------------------------------------------------------- 1 | 21 | 22 | 118 | -------------------------------------------------------------------------------- /src/components/chicagoBookForm.vue: -------------------------------------------------------------------------------- 1 | 52 | 53 | 88 | -------------------------------------------------------------------------------- /src/components/chicagoWebsiteForm.vue: -------------------------------------------------------------------------------- 1 | 58 | 59 | 94 | -------------------------------------------------------------------------------- /src/components/apaWebsiteForm.vue: -------------------------------------------------------------------------------- 1 | 53 | 54 | 89 | -------------------------------------------------------------------------------- /src/components/apaBookForm.vue: -------------------------------------------------------------------------------- 1 | 54 | 55 | 90 | -------------------------------------------------------------------------------- /src/components/mlaWebsiteForm.vue: -------------------------------------------------------------------------------- 1 | 70 | 71 | 106 | -------------------------------------------------------------------------------- /src/background.js: -------------------------------------------------------------------------------- 1 | 'use strict' 2 | 3 | import { app, Menu, protocol, BrowserWindow } from 'electron' 4 | import { 5 | createProtocol, 6 | installVueDevtools 7 | } from 'vue-cli-plugin-electron-builder/lib' 8 | const isDevelopment = process.env.NODE_ENV !== 'production' 9 | 10 | // Keep a global reference of the window object, if you don't, the window will 11 | // be closed automatically when the JavaScript object is garbage collected. 12 | let win 13 | 14 | // Standard scheme must be registered before the app is ready 15 | protocol.registerStandardSchemes(['app'], { secure: true }) 16 | function createWindow () { 17 | // Create the browser window. 18 | win = new BrowserWindow({ width: 800, height: 700 }) 19 | 20 | if (process.env.WEBPACK_DEV_SERVER_URL) { 21 | // Load the url of the dev server if in development mode 22 | win.loadURL(process.env.WEBPACK_DEV_SERVER_URL) 23 | if (!process.env.IS_TEST) win.webContents.openDevTools() 24 | } else { 25 | createProtocol('app') 26 | // Load the index.html when not in development 27 | win.loadURL('app://./index.html') 28 | } 29 | 30 | const template = [ 31 | { 32 | label: 'Edit', 33 | submenu: [ 34 | { role: 'undo' }, 35 | { role: 'redo' }, 36 | { type: 'separator' }, 37 | { role: 'cut' }, 38 | { role: 'copy' }, 39 | 40 | 41 | { role: 'paste' }, 42 | { role: 'pasteandmatchstyle' }, 43 | { role: 'delete' }, 44 | { role: 'selectall' } 45 | ] 46 | }, 47 | { 48 | label: 'View', 49 | submenu: [ 50 | { role: 'reload' }, 51 | { role: 'forcereload' }, 52 | { role: 'toggledevtools' }, 53 | { type: 'separator' }, 54 | { role: 'resetzoom' }, 55 | { role: 'zoomin' }, 56 | { role: 'zoomout' }, 57 | { type: 'separator' }, 58 | { role: 'togglefullscreen' } 59 | ] 60 | }, 61 | { 62 | role: 'window', 63 | submenu: [ 64 | { role: 'minimize' }, 65 | { role: 'close' } 66 | ] 67 | }, 68 | { 69 | role: 'help', 70 | submenu: [ 71 | { 72 | label: 'Learn More', 73 | click () { require('electron').shell.openExternal('https://github.com/JoshuaManuel/biblio') } 74 | }, 75 | { 76 | label: 'Check for Updates', 77 | click () { require('electron').shell.openExternal('https://github.com/JoshuaManuel/biblio/releases') } 78 | } 79 | ] 80 | } 81 | ] 82 | 83 | if (process.platform === 'darwin') { 84 | template.unshift({ 85 | label: app.getName(), 86 | submenu: [ 87 | { role: 'about' }, 88 | { type: 'separator' }, 89 | { role: 'services' }, 90 | { type: 'separator' }, 91 | { role: 'hide' }, 92 | { role: 'hideothers' }, 93 | { role: 'unhide' }, 94 | { type: 'separator' }, 95 | { role: 'quit' } 96 | ] 97 | }) 98 | 99 | // Edit menu 100 | template[1].submenu.push( 101 | { type: 'separator' }, 102 | { 103 | label: 'Speech', 104 | submenu: [ 105 | { role: 'startspeaking' }, 106 | { role: 'stopspeaking' } 107 | ] 108 | } 109 | ) 110 | 111 | // Window menu 112 | template[3].submenu = [ 113 | { role: 'close' }, 114 | { role: 'minimize' }, 115 | { role: 'zoom' }, 116 | { type: 'separator' }, 117 | { role: 'front' } 118 | ] 119 | } 120 | 121 | const menu = Menu.buildFromTemplate(template) 122 | Menu.setApplicationMenu(menu) 123 | 124 | win.on('closed', () => { 125 | win = null 126 | }) 127 | } 128 | 129 | // Quit when all windows are closed. 130 | app.on('window-all-closed', () => { 131 | // On macOS it is common for applications and their menu bar 132 | // to stay active until the user quits explicitly with Cmd + Q 133 | if (process.platform !== 'darwin') { 134 | app.quit() 135 | } 136 | }) 137 | 138 | app.on('activate', () => { 139 | // On macOS it's common to re-create a window in the app when the 140 | // dock icon is clicked and there are no other windows open. 141 | if (win === null) { 142 | createWindow() 143 | } 144 | }) 145 | 146 | // This method will be called when Electron has finished 147 | // initialization and is ready to create browser windows. 148 | // Some APIs can only be used after this event occurs. 149 | app.on('ready', async () => { 150 | if (isDevelopment && !process.env.IS_TEST) { 151 | // Install Vue Devtools 152 | await installVueDevtools() 153 | } 154 | createWindow() 155 | }) 156 | 157 | // Exit cleanly on request from parent process in development mode. 158 | if (isDevelopment) { 159 | if (process.platform === 'win32') { 160 | process.on('message', data => { 161 | if (data === 'graceful-exit') { 162 | app.quit() 163 | } 164 | }) 165 | } else { 166 | process.on('SIGTERM', () => { 167 | app.quit() 168 | }) 169 | } 170 | } 171 | -------------------------------------------------------------------------------- /src/css/pure-min.css: -------------------------------------------------------------------------------- 1 | /*! 2 | Pure v1.0.0 3 | Copyright 2013 Yahoo! 4 | Licensed under the BSD License. 5 | https://github.com/yahoo/pure/blob/master/LICENSE.md 6 | */ 7 | /*! 8 | normalize.css v^3.0 | MIT License | git.io/normalize 9 | Copyright (c) Nicolas Gallagher and Jonathan Neal 10 | */ 11 | /*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */.pure-button:focus,a:active,a:hover{outline:0}.pure-table,table{border-collapse:collapse;border-spacing:0}html{font-family:sans-serif;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0}article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary{display:block}audio,canvas,progress,video{display:inline-block;vertical-align:baseline}audio:not([controls]){display:none;height:0}[hidden],template{display:none}a{background-color:transparent}abbr[title]{border-bottom:1px dotted}b,optgroup,strong{font-weight:700}dfn{font-style:italic}h1{font-size:2em;margin:.67em 0}mark{background:#ff0;color:#000}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sup{top:-.5em}sub{bottom:-.25em}img{border:0}svg:not(:root){overflow:hidden}figure{margin:1em 40px}hr{box-sizing:content-box;height:0}pre,textarea{overflow:auto}code,kbd,pre,samp{font-family:monospace,monospace;font-size:1em}button,input,optgroup,select,textarea{color:inherit;font:inherit;margin:0}.pure-button,input{line-height:normal}button{overflow:visible}button,select{text-transform:none}button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer}button[disabled],html input[disabled]{cursor:default}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}input[type=checkbox],input[type=radio]{box-sizing:border-box;padding:0}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{height:auto}input[type=search]{-webkit-appearance:textfield;box-sizing:content-box}.pure-button,.pure-form input:not([type]),.pure-menu{box-sizing:border-box}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}legend,td,th{padding:0}legend{border:0}.hidden,[hidden]{display:none!important}.pure-img{max-width:100%;height:auto;display:block}.pure-g{letter-spacing:-.31em;text-rendering:optimizespeed;font-family:FreeSans,Arimo,"Droid Sans",Helvetica,Arial,sans-serif;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-flow:row wrap;-ms-flex-flow:row wrap;flex-flow:row wrap;-webkit-align-content:flex-start;-ms-flex-line-pack:start;align-content:flex-start}@media all and (-ms-high-contrast:none),(-ms-high-contrast:active){table .pure-g{display:block}}.opera-only :-o-prefocus,.pure-g{word-spacing:-.43em}.pure-u,.pure-u-1,.pure-u-1-1,.pure-u-1-12,.pure-u-1-2,.pure-u-1-24,.pure-u-1-3,.pure-u-1-4,.pure-u-1-5,.pure-u-1-6,.pure-u-1-8,.pure-u-10-24,.pure-u-11-12,.pure-u-11-24,.pure-u-12-24,.pure-u-13-24,.pure-u-14-24,.pure-u-15-24,.pure-u-16-24,.pure-u-17-24,.pure-u-18-24,.pure-u-19-24,.pure-u-2-24,.pure-u-2-3,.pure-u-2-5,.pure-u-20-24,.pure-u-21-24,.pure-u-22-24,.pure-u-23-24,.pure-u-24-24,.pure-u-3-24,.pure-u-3-4,.pure-u-3-5,.pure-u-3-8,.pure-u-4-24,.pure-u-4-5,.pure-u-5-12,.pure-u-5-24,.pure-u-5-5,.pure-u-5-6,.pure-u-5-8,.pure-u-6-24,.pure-u-7-12,.pure-u-7-24,.pure-u-7-8,.pure-u-8-24,.pure-u-9-24{letter-spacing:normal;word-spacing:normal;vertical-align:top;text-rendering:auto;display:inline-block;zoom:1}.pure-g [class*=pure-u]{font-family:sans-serif}.pure-u-1-24{width:4.1667%}.pure-u-1-12,.pure-u-2-24{width:8.3333%}.pure-u-1-8,.pure-u-3-24{width:12.5%}.pure-u-1-6,.pure-u-4-24{width:16.6667%}.pure-u-1-5{width:20%}.pure-u-5-24{width:20.8333%}.pure-u-1-4,.pure-u-6-24{width:25%}.pure-u-7-24{width:29.1667%}.pure-u-1-3,.pure-u-8-24{width:33.3333%}.pure-u-3-8,.pure-u-9-24{width:37.5%}.pure-u-2-5{width:40%}.pure-u-10-24,.pure-u-5-12{width:41.6667%}.pure-u-11-24{width:45.8333%}.pure-u-1-2,.pure-u-12-24{width:50%}.pure-u-13-24{width:54.1667%}.pure-u-14-24,.pure-u-7-12{width:58.3333%}.pure-u-3-5{width:60%}.pure-u-15-24,.pure-u-5-8{width:62.5%}.pure-u-16-24,.pure-u-2-3{width:66.6667%}.pure-u-17-24{width:70.8333%}.pure-u-18-24,.pure-u-3-4{width:75%}.pure-u-19-24{width:79.1667%}.pure-u-4-5{width:80%}.pure-u-20-24,.pure-u-5-6{width:83.3333%}.pure-u-21-24,.pure-u-7-8{width:87.5%}.pure-u-11-12,.pure-u-22-24{width:91.6667%}.pure-u-23-24{width:95.8333%}.pure-u-1,.pure-u-1-1,.pure-u-24-24,.pure-u-5-5{width:100%}.pure-button{display:inline-block;zoom:1;white-space:nowrap;vertical-align:middle;text-align:center;cursor:pointer;-webkit-user-drag:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.pure-button::-moz-focus-inner{padding:0;border:0}.pure-button-group{letter-spacing:-.31em;text-rendering:optimizespeed}.opera-only :-o-prefocus,.pure-button-group{word-spacing:-.43em}.pure-button{font-family:inherit;font-size:100%;padding:.5em 1em;color:#444;color:rgba(0,0,0,.8);border:1px solid #999;border:transparent;background-color:#E6E6E6;text-decoration:none;border-radius:2px}.pure-button-hover,.pure-button:focus,.pure-button:hover{filter:alpha(opacity=90);background-image:-webkit-linear-gradient(transparent,rgba(0,0,0,.05) 40%,rgba(0,0,0,.1));background-image:linear-gradient(transparent,rgba(0,0,0,.05) 40%,rgba(0,0,0,.1))}.pure-button-active,.pure-button:active{box-shadow:0 0 0 1px rgba(0,0,0,.15) inset,0 0 6px rgba(0,0,0,.2) inset;border-color:#000\9}.pure-button-disabled,.pure-button-disabled:active,.pure-button-disabled:focus,.pure-button-disabled:hover,.pure-button[disabled]{border:none;background-image:none;filter:alpha(opacity=40);opacity:.4;cursor:not-allowed;box-shadow:none;pointer-events:none}.pure-button-hidden{display:none}.pure-button-primary,.pure-button-selected,a.pure-button-primary,a.pure-button-selected{background-color:#0078e7;color:#fff}.pure-button-group .pure-button{letter-spacing:normal;word-spacing:normal;vertical-align:top;text-rendering:auto;margin:0;border-radius:0;border-right:1px solid #111;border-right:1px solid rgba(0,0,0,.2)}.pure-button-group .pure-button:first-child{border-top-left-radius:2px;border-bottom-left-radius:2px}.pure-button-group .pure-button:last-child{border-top-right-radius:2px;border-bottom-right-radius:2px;border-right:none}.pure-form input[type=password],.pure-form input[type=email],.pure-form input[type=url],.pure-form input[type=date],.pure-form input[type=month],.pure-form input[type=time],.pure-form input[type=datetime],.pure-form input[type=datetime-local],.pure-form input[type=week],.pure-form input[type=tel],.pure-form input[type=color],.pure-form input[type=number],.pure-form input[type=search],.pure-form input[type=text],.pure-form select,.pure-form textarea{padding:.5em .6em;display:inline-block;border:1px solid #ccc;box-shadow:inset 0 1px 3px #ddd;border-radius:4px;vertical-align:middle;box-sizing:border-box}.pure-form input:not([type]){padding:.5em .6em;display:inline-block;border:1px solid #ccc;box-shadow:inset 0 1px 3px #ddd;border-radius:4px}.pure-form input[type=color]{padding:.2em .5em}.pure-form input:not([type]):focus,.pure-form input[type=password]:focus,.pure-form input[type=email]:focus,.pure-form input[type=url]:focus,.pure-form input[type=date]:focus,.pure-form input[type=month]:focus,.pure-form input[type=time]:focus,.pure-form input[type=datetime]:focus,.pure-form input[type=datetime-local]:focus,.pure-form input[type=week]:focus,.pure-form input[type=tel]:focus,.pure-form input[type=color]:focus,.pure-form input[type=number]:focus,.pure-form input[type=search]:focus,.pure-form input[type=text]:focus,.pure-form select:focus,.pure-form textarea:focus{outline:0;border-color:#129FEA}.pure-form input[type=file]:focus,.pure-form input[type=checkbox]:focus,.pure-form input[type=radio]:focus{outline:#129FEA auto 1px}.pure-form .pure-checkbox,.pure-form .pure-radio{margin:.5em 0;display:block}.pure-form input:not([type])[disabled],.pure-form input[type=password][disabled],.pure-form input[type=email][disabled],.pure-form input[type=url][disabled],.pure-form input[type=date][disabled],.pure-form input[type=month][disabled],.pure-form input[type=time][disabled],.pure-form input[type=datetime][disabled],.pure-form input[type=datetime-local][disabled],.pure-form input[type=week][disabled],.pure-form input[type=tel][disabled],.pure-form input[type=color][disabled],.pure-form input[type=number][disabled],.pure-form input[type=search][disabled],.pure-form input[type=text][disabled],.pure-form select[disabled],.pure-form textarea[disabled]{cursor:not-allowed;background-color:#eaeded;color:#cad2d3}.pure-form input[readonly],.pure-form select[readonly],.pure-form textarea[readonly]{background-color:#eee;color:#777;border-color:#ccc}.pure-form input:focus:invalid,.pure-form select:focus:invalid,.pure-form textarea:focus:invalid{color:#b94a48;border-color:#e9322d}.pure-form input[type=file]:focus:invalid:focus,.pure-form input[type=checkbox]:focus:invalid:focus,.pure-form input[type=radio]:focus:invalid:focus{outline-color:#e9322d}.pure-form select{height:2.25em;border:1px solid #ccc;background-color:#fff}.pure-form select[multiple]{height:auto}.pure-form label{margin:.5em 0 .2em}.pure-form fieldset{margin:0;padding:.35em 0 .75em;border:0}.pure-form legend{display:block;width:100%;padding:.3em 0;margin-bottom:.3em;color:#333;border-bottom:1px solid #e5e5e5}.pure-form-stacked input:not([type]),.pure-form-stacked input[type=password],.pure-form-stacked input[type=email],.pure-form-stacked input[type=url],.pure-form-stacked input[type=date],.pure-form-stacked input[type=month],.pure-form-stacked input[type=time],.pure-form-stacked input[type=datetime],.pure-form-stacked input[type=datetime-local],.pure-form-stacked input[type=week],.pure-form-stacked input[type=tel],.pure-form-stacked input[type=color],.pure-form-stacked input[type=file],.pure-form-stacked input[type=number],.pure-form-stacked input[type=search],.pure-form-stacked input[type=text],.pure-form-stacked label,.pure-form-stacked select,.pure-form-stacked textarea{display:block;margin:.25em 0}.pure-form-aligned .pure-help-inline,.pure-form-aligned input,.pure-form-aligned select,.pure-form-aligned textarea,.pure-form-message-inline{display:inline-block;vertical-align:middle}.pure-form-aligned textarea{vertical-align:top}.pure-form-aligned .pure-control-group{margin-bottom:.5em}.pure-form-aligned .pure-control-group label{text-align:right;display:inline-block;vertical-align:middle;width:10em;margin:0 1em 0 0}.pure-form-aligned .pure-controls{margin:1.5em 0 0 11em}.pure-form .pure-input-rounded,.pure-form input.pure-input-rounded{border-radius:2em;padding:.5em 1em}.pure-form .pure-group fieldset{margin-bottom:10px}.pure-form .pure-group input,.pure-form .pure-group textarea{display:block;padding:10px;margin:0 0 -1px;border-radius:0;position:relative;top:-1px}.pure-form .pure-group input:focus,.pure-form .pure-group textarea:focus{z-index:3}.pure-form .pure-group input:first-child,.pure-form .pure-group textarea:first-child{top:1px;border-radius:4px 4px 0 0;margin:0}.pure-form .pure-group input:first-child:last-child,.pure-form .pure-group textarea:first-child:last-child{top:1px;border-radius:4px;margin:0}.pure-form .pure-group input:last-child,.pure-form .pure-group textarea:last-child{top:-2px;border-radius:0 0 4px 4px;margin:0}.pure-form .pure-group button{margin:.35em 0}.pure-form .pure-input-1{width:100%}.pure-form .pure-input-3-4{width:75%}.pure-form .pure-input-2-3{width:66%}.pure-form .pure-input-1-2{width:50%}.pure-form .pure-input-1-3{width:33%}.pure-form .pure-input-1-4{width:25%}.pure-form .pure-help-inline,.pure-form-message-inline{display:inline-block;padding-left:.3em;color:#666;vertical-align:middle;font-size:.875em}.pure-form-message{display:block;color:#666;font-size:.875em}@media only screen and (max-width :480px){.pure-form button[type=submit]{margin:.7em 0 0}.pure-form input:not([type]),.pure-form input[type=password],.pure-form input[type=email],.pure-form input[type=url],.pure-form input[type=date],.pure-form input[type=month],.pure-form input[type=time],.pure-form input[type=datetime],.pure-form input[type=datetime-local],.pure-form input[type=week],.pure-form input[type=tel],.pure-form input[type=color],.pure-form input[type=number],.pure-form input[type=search],.pure-form input[type=text],.pure-form label{margin-bottom:.3em;display:block}.pure-group input:not([type]),.pure-group input[type=password],.pure-group input[type=email],.pure-group input[type=url],.pure-group input[type=date],.pure-group input[type=month],.pure-group input[type=time],.pure-group input[type=datetime],.pure-group input[type=datetime-local],.pure-group input[type=week],.pure-group input[type=tel],.pure-group input[type=color],.pure-group input[type=number],.pure-group input[type=search],.pure-group input[type=text]{margin-bottom:0}.pure-form-aligned .pure-control-group label{margin-bottom:.3em;text-align:left;display:block;width:100%}.pure-form-aligned .pure-controls{margin:1.5em 0 0}.pure-form .pure-help-inline,.pure-form-message,.pure-form-message-inline{display:block;font-size:.75em;padding:.2em 0 .8em}}.pure-menu-fixed{position:fixed;left:0;top:0;z-index:3}.pure-menu-item,.pure-menu-list{position:relative}.pure-menu-list{list-style:none;margin:0;padding:0}.pure-menu-item{padding:0;margin:0;height:100%}.pure-menu-heading,.pure-menu-link{display:block;text-decoration:none;white-space:nowrap}.pure-menu-horizontal{width:100%;white-space:nowrap}.pure-menu-horizontal .pure-menu-list{display:inline-block}.pure-menu-horizontal .pure-menu-heading,.pure-menu-horizontal .pure-menu-item,.pure-menu-horizontal .pure-menu-separator{display:inline-block;zoom:1;vertical-align:middle}.pure-menu-item .pure-menu-item{display:block}.pure-menu-children{display:none;position:absolute;left:100%;top:0;margin:0;padding:0;z-index:3}.pure-menu-horizontal .pure-menu-children{left:0;top:auto;width:inherit}.pure-menu-active>.pure-menu-children,.pure-menu-allow-hover:hover>.pure-menu-children{display:block;position:absolute}.pure-menu-has-children>.pure-menu-link:after{padding-left:.5em;content:"\25B8";font-size:small}.pure-menu-horizontal .pure-menu-has-children>.pure-menu-link:after{content:"\25BE"}.pure-menu-scrollable{overflow-y:scroll;overflow-x:hidden}.pure-menu-scrollable .pure-menu-list{display:block}.pure-menu-horizontal.pure-menu-scrollable .pure-menu-list{display:inline-block}.pure-menu-horizontal.pure-menu-scrollable{white-space:nowrap;overflow-y:hidden;overflow-x:auto;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;padding:.5em 0}.pure-menu-horizontal.pure-menu-scrollable::-webkit-scrollbar{display:none}.pure-menu-horizontal .pure-menu-children .pure-menu-separator,.pure-menu-separator{background-color:#ccc;height:1px;margin:.3em 0}.pure-menu-horizontal .pure-menu-separator{width:1px;height:1.3em;margin:0 .3em}.pure-menu-horizontal .pure-menu-children .pure-menu-separator{display:block;width:auto}.pure-menu-heading{text-transform:uppercase;color:#565d64}.pure-menu-link{color:#777}.pure-menu-children{background-color:#fff}.pure-menu-disabled,.pure-menu-heading,.pure-menu-link{padding:.5em 1em}.pure-menu-disabled{opacity:.5}.pure-menu-disabled .pure-menu-link:hover{background-color:transparent}.pure-menu-active>.pure-menu-link,.pure-menu-link:focus,.pure-menu-link:hover{background-color:#eee}.pure-menu-selected .pure-menu-link,.pure-menu-selected .pure-menu-link:visited{color:#000}.pure-table{empty-cells:show;border:1px solid #cbcbcb}.pure-table caption{color:#000;font:italic 85%/1 arial,sans-serif;padding:1em 0;text-align:center}.pure-table td,.pure-table th{border-left:1px solid #cbcbcb;border-width:0 0 0 1px;font-size:inherit;margin:0;overflow:visible;padding:.5em 1em}.pure-table td:first-child,.pure-table th:first-child{border-left-width:0}.pure-table thead{background-color:#e0e0e0;color:#000;text-align:left;vertical-align:bottom}.pure-table td{background-color:transparent}.pure-table-odd td,.pure-table-striped tr:nth-child(2n-1) td{background-color:#f2f2f2}.pure-table-bordered td{border-bottom:1px solid #cbcbcb}.pure-table-bordered tbody>tr:last-child>td{border-bottom-width:0}.pure-table-horizontal td,.pure-table-horizontal th{border-width:0 0 1px;border-bottom:1px solid #cbcbcb}.pure-table-horizontal tbody>tr:last-child>td{border-bottom-width:0} --------------------------------------------------------------------------------