Compare commits
5 Commits
Author | SHA1 | Date | |
---|---|---|---|
76c8bdefbd | |||
3ef8f12310 | |||
a90ccf2ba1 | |||
dd1d1841e3 | |||
da954335bd |
27
.gitignore
vendored
@ -1,31 +1,4 @@
|
||||
*.log
|
||||
*.pyc
|
||||
environment
|
||||
attic
|
||||
|
||||
# gitea
|
||||
d-gitea/data/
|
||||
d-gitea/custom/
|
||||
|
||||
# mediawiki
|
||||
charlesreid1.wiki.conf
|
||||
d-mediawiki/charlesreid1-config/mediawiki/skins/Bootstrap2/Bootstrap2.php
|
||||
d-mediawiki/charlesreid1-config/mediawiki/skins/Bootstrap2/navbar.php
|
||||
d-mediawiki/mediawiki/
|
||||
|
||||
# nginx
|
||||
d-nginx-charlesreid1/conf.d/http.DOMAIN.conf
|
||||
d-nginx-charlesreid1/conf.d/https.DOMAIN.conf
|
||||
|
||||
# scripts dir
|
||||
scripts/git_*_www.py
|
||||
scripts/certbot/renew_charlesreid1_certs.sh
|
||||
*.timer
|
||||
*.service
|
||||
|
||||
# misc
|
||||
site
|
||||
root.password
|
||||
docker-compose.yml
|
||||
*.zip
|
||||
|
||||
|
20
.gitmodules
vendored
@ -1,3 +1,21 @@
|
||||
[submodule "d-mysql"]
|
||||
path = d-mysql
|
||||
url = git@github.com:charlesreid1-docker/d-mysql.git
|
||||
[submodule "d-mediawiki"]
|
||||
path = d-mediawiki
|
||||
url = git@github.com:charlesreid1-docker/d-mediawiki.git
|
||||
[submodule "d-phpmyadmin"]
|
||||
path = d-phpmyadmin
|
||||
url = git@github.com:charlesreid1-docker/d-phpmyadmin.git
|
||||
[submodule "d-nginx-charlesreid1"]
|
||||
path = d-nginx-charlesreid1
|
||||
url = git@github.com:charlesreid1-docker/d-nginx-charlesreid1.git
|
||||
[submodule "d-gitea"]
|
||||
path = d-gitea
|
||||
url = git@github.com:charlesreid1-docker/d-gitea.git
|
||||
[submodule "d-python-files"]
|
||||
path = d-python-files
|
||||
url = git@github.com:charlesreid1-docker/d-python-files.git
|
||||
[submodule "mkdocs-material"]
|
||||
path = mkdocs-material
|
||||
url = https://github.com/charlesreid1/mkdocs-material
|
||||
url = git@github.com:charlesreid1/mkdocs-material.git
|
||||
|
2
LICENSE
@ -1,4 +1,4 @@
|
||||
Copyright (c) 2018-2021 Charles Reid
|
||||
Copyright (c) 2018 Charles Reid
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
|
194
Makefile
@ -1,194 +0,0 @@
|
||||
include common.mk
|
||||
|
||||
all:
|
||||
@echo "no default make rule defined"
|
||||
|
||||
help:
|
||||
@echo ""
|
||||
@echo ""
|
||||
@echo "pod-charlesreid Makefile:"
|
||||
@echo ""
|
||||
@echo ""
|
||||
@echo "This Makefile contains rules for setting up pod-charlesreid1"
|
||||
@echo ""
|
||||
@echo "make help: Get help"
|
||||
@echo ""
|
||||
@echo "--------------------------------------------------"
|
||||
@echo " Templates:"
|
||||
@echo ""
|
||||
@echo "make templates: Render each .j2 template file in this and all subdirectories"
|
||||
@echo " (uses environment variables to populate Jinja variables)"
|
||||
@echo ""
|
||||
@echo "make list-templates: List each .j2 template file that will be rendered by a 'make template' command"
|
||||
@echo ""
|
||||
@echo "make clean-templates: Remove each rendered .j2 template"
|
||||
@echo ""
|
||||
@echo "--------------------------------------------------"
|
||||
@echo " Backups:"
|
||||
@echo ""
|
||||
@echo "make backups: Create backups of every service (wiki database, wiki files) in ~/backups"
|
||||
@echo ""
|
||||
@echo "make clean-backups: Remove files from ~/backups directory older than 30 days"
|
||||
@echo ""
|
||||
@echo "--------------------------------------------------"
|
||||
@echo " MediaWiki:"
|
||||
@echo ""
|
||||
@echo "make mw-build-extensions Build the MediaWiki extensions directory"
|
||||
@echo ""
|
||||
@echo "make mw-fix-extensions Copy the built extensions directory into the MW container"
|
||||
@echo ""
|
||||
@echo "make mw-fix-localsettings Copy the LocalSettings.php file into the MW container"
|
||||
@echo ""
|
||||
@echo "make mw-fix-skins Copy the skins directory into the MW container"
|
||||
@echo ""
|
||||
@echo "--------------------------------------------------"
|
||||
@echo " /www Directory:"
|
||||
@echo ""
|
||||
@echo "make clone-www: Create the /www directory structure for charlesreid1.com"
|
||||
@echo ""
|
||||
@echo "make pull-www: Update the contents of the /www directory structure for charlesreid1.com"
|
||||
@echo ""
|
||||
@echo "--------------------------------------------------"
|
||||
@echo " Startup Services:"
|
||||
@echo ""
|
||||
@echo "make install: Install and start systemd service to run pod-charlesreid1."
|
||||
@echo " Also install and start systemd service for pod-charlesreid1 backup services"
|
||||
@echo " for each service (mediawiki/mysql) part of pod-charlesreid1."
|
||||
@echo ""
|
||||
@echo "make uninstall: Remove all systemd startup services and timers part of pod-charlesreid1"
|
||||
@echo ""
|
||||
|
||||
# Templates
|
||||
|
||||
templates:
|
||||
@find * -name "*.service.j2" | xargs -I '{}' chmod 644 {}
|
||||
@find * -name "*.timer.j2" | xargs -I '{}' chmod 644 {}
|
||||
/home/charles/.pyenv/shims/python3 $(POD_CHARLESREID1_DIR)/scripts/apply_templates.py
|
||||
|
||||
list-templates:
|
||||
@find * -name "*.j2"
|
||||
|
||||
clean-templates:
|
||||
# sudo is required because bind-mounted gitea files end up owned by root. stupid docker.
|
||||
sudo -E /home/charles/.pyenv/shims/python3 $(POD_CHARLESREID1_DIR)/scripts/clean_templates.py
|
||||
|
||||
# Backups
|
||||
|
||||
backups:
|
||||
$(POD_CHARLESREID1_DIR)/scripts/backups/wikidb_dump.sh
|
||||
$(POD_CHARLESREID1_DIR)/scripts/backups/wikifiles_dump.sh
|
||||
|
||||
clean-backups:
|
||||
$(POD_CHARLESREID1_DIR)/scripts/clean_templates.sh
|
||||
|
||||
# MediaWiki
|
||||
|
||||
mw-build-extensions:
|
||||
$(POD_CHARLESREID1_DIR)/scripts/mw/build_extensions_dir.sh
|
||||
|
||||
mw-fix-extensions: mw-build-extensions
|
||||
$(POD_CHARLESREID1_DIR)/scripts/mw/build_extensions_dir.sh
|
||||
|
||||
mw-fix-localsettings:
|
||||
$(POD_CHARLESREID1_DIR)/scripts/mw/fix_LocalSettings.sh
|
||||
|
||||
mw-fix-skins:
|
||||
$(POD_CHARLESREID1_DIR)/scripts/mw/fix_skins.sh
|
||||
|
||||
# /www Dir
|
||||
|
||||
clone-www:
|
||||
/home/charles/.pyenv/shims/python3 $(POD_CHARLESREID1_DIR)/scripts/git_clone_www.py
|
||||
|
||||
pull-www:
|
||||
/home/charles/.pyenv/shims/python3 $(POD_CHARLESREID1_DIR)/scripts/git_pull_www.py
|
||||
|
||||
install:
|
||||
ifeq ($(shell which systemctl),)
|
||||
$(error Please run this make command on a system with systemctl installed)
|
||||
endif
|
||||
@/home/charles/.pyenv/shims/python3 -c 'import botocore' || (echo "Please install the botocore library using python3 or pip3 binary"; exit 1)
|
||||
@/home/charles/.pyenv/shims/python3 -c 'import boto3' || (echo "Please install the boto3 library using python3 or pip3 binary"; exit 1)
|
||||
|
||||
sudo cp $(POD_CHARLESREID1_DIR)/scripts/pod-charlesreid1.service /etc/systemd/system/pod-charlesreid1.service
|
||||
|
||||
sudo cp $(POD_CHARLESREID1_DIR)/scripts/backups/pod-charlesreid1-backups-aws.{service,timer} /etc/systemd/system/.
|
||||
sudo cp $(POD_CHARLESREID1_DIR)/scripts/backups/pod-charlesreid1-backups-cleanolderthan.{service,timer} /etc/systemd/system/.
|
||||
sudo cp $(POD_CHARLESREID1_DIR)/scripts/backups/pod-charlesreid1-backups-gitea.{service,timer} /etc/systemd/system/.
|
||||
sudo cp $(POD_CHARLESREID1_DIR)/scripts/backups/pod-charlesreid1-backups-wikidb.{service,timer} /etc/systemd/system/.
|
||||
sudo cp $(POD_CHARLESREID1_DIR)/scripts/backups/pod-charlesreid1-backups-wikifiles.{service,timer} /etc/systemd/system/.
|
||||
|
||||
sudo cp $(POD_CHARLESREID1_DIR)/scripts/backups/canary/pod-charlesreid1-canary.{service,timer} /etc/systemd/system/.
|
||||
sudo cp $(POD_CHARLESREID1_DIR)/scripts/certbot/pod-charlesreid1-certbot.{service,timer} /etc/systemd/system/.
|
||||
|
||||
sudo cp $(POD_CHARLESREID1_DIR)/scripts/backups/10-pod-charlesreid1-rsyslog.conf /etc/rsyslog.d/.
|
||||
|
||||
sudo chmod 664 /etc/systemd/system/pod-charlesreid1*
|
||||
sudo systemctl daemon-reload
|
||||
|
||||
sudo systemctl restart rsyslog
|
||||
|
||||
sudo systemctl enable pod-charlesreid1
|
||||
sudo systemctl enable pod-charlesreid1-backups-wikidb.timer
|
||||
sudo systemctl enable pod-charlesreid1-backups-wikifiles.timer
|
||||
sudo systemctl enable pod-charlesreid1-backups-gitea.timer
|
||||
sudo systemctl enable pod-charlesreid1-backups-aws.timer
|
||||
sudo systemctl enable pod-charlesreid1-backups-cleanolderthan.timer
|
||||
sudo systemctl enable pod-charlesreid1-canary.timer
|
||||
sudo systemctl enable pod-charlesreid1-certbot.timer
|
||||
|
||||
sudo systemctl start pod-charlesreid1-backups-wikidb.timer
|
||||
sudo systemctl start pod-charlesreid1-backups-wikifiles.timer
|
||||
sudo systemctl start pod-charlesreid1-backups-gitea.timer
|
||||
sudo systemctl start pod-charlesreid1-backups-aws.timer
|
||||
sudo systemctl start pod-charlesreid1-backups-cleanolderthan.timer
|
||||
sudo systemctl start pod-charlesreid1-canary.timer
|
||||
sudo systemctl start pod-charlesreid1-certbot.timer
|
||||
|
||||
sudo chown syslog:syslog /var/log/pod-charlesreid1-backups-aws.service.log
|
||||
sudo chown syslog:syslog /var/log/pod-charlesreid1-backups-cleanolderthan.service.log
|
||||
sudo chown syslog:syslog /var/log/pod-charlesreid1-backups-gitea.service.log
|
||||
sudo chown syslog:syslog /var/log/pod-charlesreid1-backups-wikidb.service.log
|
||||
sudo chown syslog:syslog /var/log/pod-charlesreid1-backups-wikifiles.service.log
|
||||
sudo chown syslog:syslog /var/log/pod-charlesreid1-canary.service.log
|
||||
|
||||
uninstall:
|
||||
ifeq ($(shell which systemctl),)
|
||||
$(error Please run this make command on a system with systemctl installed)
|
||||
endif
|
||||
-sudo systemctl disable pod-charlesreid1
|
||||
-sudo systemctl disable pod-charlesreid1-backups-aws.timer
|
||||
-sudo systemctl disable pod-charlesreid1-backups-cleanolderthan.timer
|
||||
-sudo systemctl disable pod-charlesreid1-backups-gitea.timer
|
||||
-sudo systemctl disable pod-charlesreid1-backups-wikidb.timer
|
||||
-sudo systemctl disable pod-charlesreid1-backups-wikifiles.timer
|
||||
-sudo systemctl disable pod-charlesreid1-canary.timer
|
||||
-sudo systemctl disable pod-charlesreid1-certbot.timer
|
||||
|
||||
# Leave the pod running!
|
||||
# -sudo systemctl stop pod-charlesreid1
|
||||
|
||||
-sudo systemctl stop pod-charlesreid1-backups-aws.timer
|
||||
-sudo systemctl stop pod-charlesreid1-backups-cleanolderthan.timer
|
||||
-sudo systemctl stop pod-charlesreid1-backups-gitea.timer
|
||||
-sudo systemctl stop pod-charlesreid1-backups-wikidb.timer
|
||||
-sudo systemctl stop pod-charlesreid1-backups-wikifiles.timer
|
||||
-sudo systemctl stop pod-charlesreid1-canary.timer
|
||||
-sudo systemctl stop pod-charlesreid1-certbot.timer
|
||||
|
||||
-sudo rm -f /etc/systemd/system/pod-charlesreid1.service
|
||||
|
||||
-sudo rm -f /etc/systemd/system/pod-charlesreid1-backups-aws.{service,timer}
|
||||
-sudo rm -f /etc/systemd/system/pod-charlesreid1-backups-cleanolderthan.{service,timer}
|
||||
-sudo rm -f /etc/systemd/system/pod-charlesreid1-backups-gitea.{service,timer}
|
||||
-sudo rm -f /etc/systemd/system/pod-charlesreid1-backups-wikidb.{service,timer}
|
||||
-sudo rm -f /etc/systemd/system/pod-charlesreid1-backups-wikifiles.{service,timer}
|
||||
-sudo rm -f /etc/systemd/system/pod-charlesreid1-canary.{service,timer}
|
||||
-sudo rm -f /etc/systemd/system/pod-charlesreid1-certbot.{service,timer}
|
||||
|
||||
sudo systemctl daemon-reload
|
||||
|
||||
-sudo rm -f /etc/rsyslog.d/10-pod-charlesreid1-rsyslog.conf
|
||||
-sudo systemctl restart rsyslog
|
||||
|
||||
.PHONY: help
|
34
TODO.md
Normal file
@ -0,0 +1,34 @@
|
||||
# TODO
|
||||
|
||||
`underscores_in_headers on;`
|
||||
|
||||
[link](https://www.nginx.com/resources/wiki/start/topics/tutorials/config_pitfalls/)
|
||||
|
||||
- nginx configurations in separate files
|
||||
- group all subdomain variations in one file
|
||||
- one place to go
|
||||
- one file = one domain, subdomain, port, etc. but group stuff easier to change
|
||||
|
||||
|
||||
- network overlay
|
||||
- nginx can't reverse proxy to 10.5.0.2 b/c doesn't see it
|
||||
- need to have two networks:
|
||||
- one virtual private network set up by docker (default)
|
||||
- one host network only connected to nginx container
|
||||
|
||||
- extras in containers:
|
||||
- fail2ban
|
||||
- log rotation
|
||||
- log backups
|
||||
- netdata on krash?
|
||||
- plugging docker-compose into netdata?
|
||||
- disk space
|
||||
- canary script
|
||||
- finer grained control and understanding of fs usage
|
||||
|
||||
- <s>rebuild and restart for slimmer python files container</s>
|
||||
- <s>logging? messages? status?
|
||||
- want to avoid a few things:
|
||||
- giant pileup of gigabytes of logs, getting bit in the ass
|
||||
- giant pileup of container stuff, completely running out of space
|
||||
- second almost happened, at 97% or so</s>
|
@ -1,19 +0,0 @@
|
||||
To get a shell in a container that has been created, before it is runnning in a pod, use `docker run`:
|
||||
|
||||
```
|
||||
docker run --rm -it --entrypoint bash <image-name-or-id>
|
||||
|
||||
|
||||
docker run --rm -it --entrypoint bash pod-charlesreid1_stormy_mediawiki
|
||||
```
|
||||
|
||||
To get a shell in a container that is running in a pod, use `docker exec`:
|
||||
|
||||
```
|
||||
docker exec -it <image-name> /bin/bash
|
||||
|
||||
docker exec -it stormy_mw /bin/bash
|
||||
```
|
||||
|
||||
Also, if no changes are picking up, and you've already tried rebuilding the container image, try editing the Dockerfile.
|
||||
|
17
common.mk
@ -1,17 +0,0 @@
|
||||
SHELL=/bin/bash
|
||||
|
||||
ifeq ($(shell echo ${POD_CHARLESREID1_DIR}),)
|
||||
$(error Environment variable POD_CHARLESREID1_DIR not defined. Please run "source environment" in the repo root directory before running make commands)
|
||||
endif
|
||||
|
||||
ifeq ($(shell test -d ${POD_CHARLESREID1_DIR} || echo "nope"), nope)
|
||||
$(error Environment variable POD_CHARLESREID1_DIR points to a non-existent directory)
|
||||
endif
|
||||
|
||||
ifeq ($(shell which python3),)
|
||||
$(error Please install python3)
|
||||
endif
|
||||
|
||||
ifeq ($(shell which aws),)
|
||||
$(error Please install aws-cli)
|
||||
endif
|
1
d-gitea
Submodule
@ -0,0 +1 @@
|
||||
Subproject commit f73c8c8258989a5eec6d119264964d20884a697a
|
@ -1,34 +0,0 @@
|
||||
# d-gitea
|
||||
|
||||
This directory contains files for the gitea docker container
|
||||
in the charlesreid1 docker pod.
|
||||
|
||||
See [pod-charlesreid1](https://git.charlesreid1.com/docker/pod-charlesreid1).
|
||||
|
||||
## Custom Directory
|
||||
|
||||
The custom directory contains the gitea configuration file, plus any other
|
||||
custom files Gitea might need.
|
||||
|
||||
The `custom` directory is bind mounted to `/data/gitea` inside the container.
|
||||
|
||||
## Data Directory
|
||||
|
||||
The data directory contains any instance-specific gitea data.
|
||||
|
||||
The data directory is bind-mounted to `/app/gitea/data` in the container.
|
||||
|
||||
## Repository Drive
|
||||
|
||||
Gitea stores all of its repositories in a separate drive that is at
|
||||
`/gitea_repositories` on the host machine.
|
||||
|
||||
The gitea repositories drive is bind-mounted to `/data/git/repositories` in the container.
|
||||
|
||||
### Rendering app.ini Template
|
||||
|
||||
The gitea configuration file is located at `custom/conf/app.ini`.
|
||||
|
||||
The app.ini configuration file is not provided, only a template is provided.
|
||||
Use the top-level pod-charlesreid1 Makefile and scripts to render templates.
|
||||
Use the top-level environment file to set variable values.
|
@ -1,108 +0,0 @@
|
||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||
;; My Amazing Gitea Config File
|
||||
;;
|
||||
;; charles reid
|
||||
;; march 2017
|
||||
;; https://github.com/go-gitea/gitea/blob/master/conf/app.ini
|
||||
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
||||
|
||||
APP_NAME = {{ pod_charlesreid1_gitea_app_name }}
|
||||
RUN_USER = git
|
||||
RUN_MODE = prod
|
||||
WORK_PATH = /data/gitea
|
||||
|
||||
[ui]
|
||||
DEFAULT_THEME = gitea-dark
|
||||
THEMES = gitea-dark
|
||||
|
||||
[database]
|
||||
DB_TYPE = sqlite3
|
||||
HOST =
|
||||
NAME =
|
||||
USER =
|
||||
PASSWD =
|
||||
SSL_MODE = disable
|
||||
PATH = /data/gitea/gitea.db
|
||||
|
||||
[repository]
|
||||
ROOT = /data/git/repositories
|
||||
PREFERRED_LICENSES = MIT License
|
||||
|
||||
; This gets rid of the HTTP option to check out repos...
|
||||
DISABLE_HTTP_GIT = false
|
||||
|
||||
[server]
|
||||
PROTOCOL = http
|
||||
DOMAIN = git.{{ pod_charlesreid1_server_name }}
|
||||
#CERT_FILE = /www/gitea/certs/cert.pem
|
||||
#KEY_FILE = /www/gitea/certs/key.pem
|
||||
SSH_DOMAIN = git.{{ pod_charlesreid1_server_name }}
|
||||
HTTP_PORT = 3000
|
||||
HTTP_ADDR = 0.0.0.0
|
||||
ROOT_URL = https://git.{{ pod_charlesreid1_server_name }}
|
||||
;ROOT_URL = %(PROTOCOL)s://%(DOMAIN)s:%(HTTP_PORT)s/
|
||||
DISABLE_SSH = false
|
||||
; port to display in clone url:
|
||||
;SSH_PORT = 222
|
||||
; port for built-in ssh server to listen on:
|
||||
SSH_LISTEN_PORT = 22
|
||||
OFFLINE_MODE = false
|
||||
|
||||
; Upper level of template and static file path
|
||||
; default is the path where Gitea is executed
|
||||
;;;;STATIC_ROOT_PATH = /www/gitea/static
|
||||
[mailer]
|
||||
ENABLED = false
|
||||
|
||||
[service]
|
||||
REGISTER_EMAIL_CONFIRM = false
|
||||
ENABLE_NOTIFY_MAIL = false
|
||||
DISABLE_REGISTRATION = true
|
||||
ENABLE_CAPTCHA = false
|
||||
REQUIRE_SIGNIN_VIEW = false
|
||||
|
||||
[picture]
|
||||
DISABLE_GRAVATAR = true
|
||||
ENABLE_FEDERATED_AVATAR = false
|
||||
AVATAR_UPLOAD_PATH = /data/gitea/avatars
|
||||
|
||||
[session]
|
||||
PROVIDER = file
|
||||
|
||||
[log]
|
||||
MODE = file
|
||||
; Either "Trace", "Debug", "Info", "Warn", "Error", "Critical", default is "Trace"
|
||||
LEVEL = Info
|
||||
ROOT_PATH = /data/gitea/log
|
||||
|
||||
; For "file" mode only
|
||||
[log.file]
|
||||
LEVEL =
|
||||
; This enables automated log rotate(switch of following options), default is true
|
||||
LOG_ROTATE = true
|
||||
; Max line number of single file, default is 1000000
|
||||
MAX_LINES = 1000000
|
||||
; Max size shift of single file, default is 28 means 1 << 28, 256MB
|
||||
MAX_SIZE_SHIFT = 28
|
||||
; Segment log daily, default is true
|
||||
DAILY_ROTATE = true
|
||||
; Expired days of log file(delete after max days), default is 7
|
||||
MAX_DAYS = 7
|
||||
|
||||
[cron.archive_cleanup]
|
||||
ENABLED = false
|
||||
|
||||
[security]
|
||||
INSTALL_LOCK = true
|
||||
SECRET_KEY = {{ pod_charlesreid1_gitea_secretkey }}
|
||||
MIN_PASSWORD_LENGTH = 6
|
||||
INTERNAL_TOKEN = {{ pod_charlesreid1_gitea_internaltoken }}
|
||||
|
||||
[other]
|
||||
SHOW_FOOTER_BRANDING = false
|
||||
; Show version information about Gitea and Go in the footer
|
||||
SHOW_FOOTER_VERSION = false
|
||||
; Show time of template execution in the footer
|
||||
SHOW_FOOTER_TEMPLATE_LOAD_TIME = false
|
||||
|
||||
|
@ -1 +0,0 @@
|
||||
<h2>hallo werld dis is de geeeeeet tea</h2>
|
@ -1,3 +0,0 @@
|
||||
<!--
|
||||
<a class="item" href="{{AppSubUrl}}/hello.html">Hello World</a>
|
||||
-->
|
@ -1,3 +0,0 @@
|
||||
{{template "base/head" .}}
|
||||
<meta http-equiv="Refresh" content="0; url=/explore/repos" />
|
||||
{{template "base/footer" .}}
|
1
d-mediawiki
Submodule
@ -0,0 +1 @@
|
||||
Subproject commit 1c765580a8c70c5e840045e2392ca1b2f79253ce
|
@ -1,64 +0,0 @@
|
||||
FROM mediawiki:1.34
|
||||
|
||||
EXPOSE 8989
|
||||
|
||||
VOLUME ["/var/www/html"]
|
||||
|
||||
# Install ImageMagick
|
||||
# and math stuff mentioned by Math extension readme
|
||||
RUN apt-get update && \
|
||||
apt-get install -y build-essential \
|
||||
dvipng \
|
||||
ocaml \
|
||||
ghostscript \
|
||||
imagemagick \
|
||||
texlive-latex-base \
|
||||
texlive-latex-extra \
|
||||
texlive-fonts-recommended \
|
||||
texlive-lang-greek \
|
||||
texlive-latex-recommended
|
||||
|
||||
# Copy skins, config files, and other particulars into container
|
||||
|
||||
# WARNING: DOCKER STUPIDITY AHEAD
|
||||
# MediaWiki needs everything, everything, to be in one folder.
|
||||
# Docker is totally incapable of mounting a file in a volume.
|
||||
# I cannot update LocalSettings.php without clearing the cache.
|
||||
# I cannot clear the cache without reinstalling all of latex.
|
||||
# I can't bind-mount the skins dir, because then it's owned by root.
|
||||
# I can't fix the fact that all bind-mounted dirs are owned by root,
|
||||
# because I can only add commands in THIS DOCKERFILE.
|
||||
# and when you run the commands in this dockerfile,
|
||||
# YOU CANNOT SEE THE BIND-MOUNTED STUFF.
|
||||
|
||||
# Extensions
|
||||
COPY charlesreid1-config/mediawiki/extensions/EmbedVideo /var/www/html/extensions/EmbedVideo
|
||||
COPY charlesreid1-config/mediawiki/extensions/Math /var/www/html/extensions/Math
|
||||
COPY charlesreid1-config/mediawiki/extensions/ParserFunctions /var/www/html/extensions/ParserFunctions
|
||||
COPY charlesreid1-config/mediawiki/extensions/SyntaxHighlight_GeSHi /var/www/html/extensions/SyntaxHighlight_GeSHi
|
||||
RUN chown -R www-data:www-data /var/www/html/*
|
||||
|
||||
# Skins
|
||||
COPY charlesreid1-config/mediawiki/skins /var/www/html/skins
|
||||
RUN chown -R www-data:www-data /var/www/html/skins
|
||||
RUN touch /var/www/html/skins
|
||||
|
||||
# Settings
|
||||
COPY charlesreid1-config/mediawiki/LocalSettings.php /var/www/html/LocalSettings.php
|
||||
RUN chown -R www-data:www-data /var/www/html/LocalSettings*
|
||||
RUN chmod 600 /var/www/html/LocalSettings.php
|
||||
|
||||
# Apache conf file
|
||||
COPY charlesreid1-config/apache/*.conf /etc/apache2/sites-enabled/
|
||||
RUN a2enmod rewrite
|
||||
RUN service apache2 restart
|
||||
|
||||
## make texvc
|
||||
#CMD cd /var/www/html/extensions/Math && make && apache2-foreground
|
||||
|
||||
# PHP conf file
|
||||
# https://hub.docker.com/_/php/
|
||||
COPY php/php.ini /usr/local/etc/php/
|
||||
|
||||
# Start
|
||||
CMD apache2-foreground
|
@ -1,97 +0,0 @@
|
||||
# d-mediawiki
|
||||
|
||||
This directory contains files used to run the MediaWiki container
|
||||
for the charlesreid1.com wiki. The MediaWiki container consists of
|
||||
a PHP-enabled Apache web server serving the MediaWiki application,
|
||||
and storing data in a MySQL database (different container).
|
||||
|
||||
See [pod-charlesreid1](https://git.charelsreid1.com/docker/pod-charlesreid1).
|
||||
|
||||
## Directory Layout
|
||||
|
||||
This directory contains `charlesreid1-config`, which has both
|
||||
MediaWiki and Apache configuration files.
|
||||
|
||||
## Creating Extensions Directory
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
## Summary
|
||||
|
||||
This directory contains a Dockerfile that modifies the
|
||||
official MediaWiki docker container. Before launching
|
||||
the container, it specifies `/var/www/html` as a mounted volume,
|
||||
and it copies `LocalSettings.php`, the MediaWiki config file,
|
||||
from this repo into the container.
|
||||
|
||||
See [d-mysql repo](https://charlesreid1.com:3000/docker/d-mysql).
|
||||
|
||||
Also see [pod-charlesreid1](https://git.charlesreid1.com/docker/pod-charlesreid1.git)
|
||||
for a working pod using this container.
|
||||
|
||||
## Docker Compose
|
||||
|
||||
To use this container as part of a pod, as with the charlesreid1.com wiki,
|
||||
see [pod-charlesreid1-wiki](https://charlesreid1.com:3000/docker/pod-charlesreid1-wiki).
|
||||
|
||||
## Troubleshooting
|
||||
|
||||
If you are seeing 404s on every page you try, it may be because
|
||||
your MediaWiki config file is set to redirect you to `/wiki/Main_Page`
|
||||
but your web server is not set up to handle it.
|
||||
|
||||
See [this lin](https://www.mediawiki.org/wiki/Manual:Short_URL)
|
||||
and the guide for [apache](https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:Short_URL/Apache)
|
||||
and [nginx](https://www.mediawiki.org/wiki/Special:MyLanguage/Manual:Short_URL/Nginx).
|
||||
|
||||
|
||||
## Updating Settings
|
||||
|
||||
The LocalSettings.php file must be copied into the
|
||||
container, because we will end up bind-mounting the
|
||||
entire MediaWiki directory when the container is run
|
||||
and we can't bind-mount a file inside a bind-mounted
|
||||
directory.
|
||||
|
||||
Thus, to update LocalSettings.php, skins, or extensions,
|
||||
you will need to re-make the Docker container.
|
||||
Use the make rules to remake the Docker container:
|
||||
|
||||
```
|
||||
make clean
|
||||
make build
|
||||
make run
|
||||
```
|
||||
|
||||
## Submodule
|
||||
|
||||
The submodule `charlesreid1-config/`
|
||||
contains configuration files for both
|
||||
MediaWiki and Apache.
|
||||
|
||||
See the [wiki/charlesreid1-config](https://git.charlesreid1.com/wiki/charlesreid1-config)
|
||||
repo for details.
|
||||
|
||||
To clone the submodule when you clone the repo,
|
||||
include the `--recursive` flag:
|
||||
|
||||
```
|
||||
git clone --recursive https://git.charlesreid1.com/docker/d-mediawiki.git
|
||||
```
|
||||
|
||||
To check out the submodule after a shallow clone:
|
||||
|
||||
```
|
||||
git submodule init
|
||||
# or
|
||||
git submodule update --init
|
||||
```
|
||||
|
||||
To fetch changes to the submodule from the submodule's remote:
|
||||
|
||||
```
|
||||
git submodule update --remote
|
||||
```
|
||||
|
@ -1,34 +0,0 @@
|
||||
To update the MediaWiki skin:
|
||||
|
||||
- See the long angry rant in the Dockerfile
|
||||
- You have to rebuild the whole container. Yup, stupid.
|
||||
- Rebuild the MW container while the docker pod is still running (won't effect the docker pod)
|
||||
- When finished rebuilding the MW container, restart the docker pod.
|
||||
|
||||
The skin currently in use is in `charlesreid1-config/mediawiki/skins/Bootstrap2`
|
||||
|
||||
To rebuild and then restart the pod:
|
||||
|
||||
```
|
||||
# switch to main pod directory
|
||||
cd ../
|
||||
|
||||
# rebuild all containers
|
||||
docker-compose build
|
||||
|
||||
# stop and start the pod
|
||||
sudo service pod-charlesreid1 stop
|
||||
sudo service pod-charlesreid1 start
|
||||
```
|
||||
|
||||
To verify that the skin has correcty been installed, you can check
|
||||
the skin file inside the container. First, get a shell in the container:
|
||||
|
||||
```
|
||||
docker exec -it stormy_mw /bin/bash
|
||||
```
|
||||
|
||||
Once inside the container, the main web directory is `/var/www/html/`,
|
||||
so the skins should be in `/var/www/html/skins/`. You can use `cat` to
|
||||
print the file to the screen and verify it is correct.
|
||||
|
@ -1,11 +0,0 @@
|
||||
# charlesreid1-config
|
||||
|
||||
Config and other site-specific files
|
||||
for the charlesreid1.com wiki.
|
||||
|
||||
The apache directory contains apache config files
|
||||
for the apache server runing mediawiki.
|
||||
|
||||
The mediawiki directory contains mediawiki
|
||||
configuration files.
|
||||
|
@ -1 +0,0 @@
|
||||
charlesreid1.wiki.conf
|
@ -1,65 +0,0 @@
|
||||
ServerName {{ pod_charlesreid1_server_name }}
|
||||
|
||||
Listen 8989
|
||||
|
||||
<VirtualHost *:8989>
|
||||
# nginx reverse proxy
|
||||
# talks to apache via 127.0.0.1
|
||||
# on port 8989
|
||||
|
||||
ServerAlias www.{{ pod_charlesreid1_server_name }}
|
||||
|
||||
LogLevel warn
|
||||
ServerAdmin {{ pod_charlesreid1_mediawiki_admin_email }}
|
||||
DirectoryIndex index.html index.cgi index.php
|
||||
|
||||
|
||||
ErrorLog ${APACHE_LOG_DIR}/error.log
|
||||
CustomLog ${APACHE_LOG_DIR}/access.log combined
|
||||
|
||||
|
||||
|
||||
AddHandler php5-script php
|
||||
# PHP module settings:
|
||||
<IfModule php5_module>
|
||||
|
||||
# Add php type handler
|
||||
AddType text/html php
|
||||
|
||||
# Make index.php a default file
|
||||
<IfModule dir_module>
|
||||
DirectoryIndex index.html index.php
|
||||
</IfModule>
|
||||
|
||||
</IfModule>
|
||||
|
||||
|
||||
|
||||
# =================
|
||||
# wiki
|
||||
|
||||
Alias /wiki /var/www/html/index.php
|
||||
Alias /w /var/www/html
|
||||
|
||||
<Directory /var/www/html>
|
||||
#
|
||||
# http://www.mediawiki.org/wiki/Manual:Short_URL/Apache
|
||||
#
|
||||
|
||||
# Enable the rewrite engine
|
||||
RewriteEngine On
|
||||
|
||||
# Short url for wiki pages
|
||||
RewriteRule ^/?wiki(/.*)?$ %{DOCUMENT_ROOT}/w/index.php [L]
|
||||
|
||||
Options FollowSymLinks
|
||||
AllowOverride None
|
||||
Require all granted
|
||||
|
||||
### # Rewrite / to main page
|
||||
### RewriteRule ^/*$ %{DOCUMENT_ROOT}/w/index.php [L]
|
||||
</Directory>
|
||||
|
||||
|
||||
</VirtualHost>
|
||||
|
@ -1,2 +0,0 @@
|
||||
LocalSettings.php
|
||||
extensions
|
@ -1,243 +0,0 @@
|
||||
<?php
|
||||
$wgSitename = "charlesreid1";
|
||||
$wgMetaNamespace = "Charlesreid1";
|
||||
|
||||
# from http://www.mediawiki.org/wiki/Manual:Short_URL#Recommended_how-to_guide_.28setup_used_on_Wikipedia.29
|
||||
$wgScriptPath = "/w"; # Path to the actual files. This should already be there
|
||||
$wgArticlePath = "/wiki/$1"; # Virtual path. This directory MUST be different from the one used in $wgScriptPath
|
||||
$wgUsePathInfo = true; # Enable use of pretty URLs
|
||||
|
||||
# Protect against web entry
|
||||
if ( !defined( 'MEDIAWIKI' ) ) {
|
||||
exit;
|
||||
}
|
||||
|
||||
## The protocol and server name to use in fully-qualified URLs
|
||||
$wgServer = 'https://{{ pod_charlesreid1_server_name }}';
|
||||
$wgCanonicalServer = 'https://{{ pod_charlesreid1_server_name }}';
|
||||
|
||||
## The URL path to static resources (images, scripts, etc.)
|
||||
$wgStylePath = "$wgScriptPath/skins";
|
||||
$wgResourceBasePath = $wgScriptPath;
|
||||
|
||||
# The URL path to the logo. Make sure you change this from the default,
|
||||
# or else you'll overwrite your logo when you upgrade!
|
||||
$wgLogo = "$wgResourceBasePath/resources/assets/wiki.png";
|
||||
|
||||
# UPO means: this is also a user preference option
|
||||
$wgEnableEmail = true;
|
||||
$wgEmergencyContact = "charles@charlesreid1.com";
|
||||
$wgPasswordSender = "charles@charlesreid1.com";
|
||||
$wgEnableUserEmail = true; # UPO
|
||||
$wgEnotifUserTalk = false; # UPO
|
||||
$wgEnotifWatchlist = false; # UPO
|
||||
$wgEmailAuthentication = true;
|
||||
|
||||
# Database settings
|
||||
$wgDBtype = "mysql";
|
||||
$wgDBserver = getenv('MYSQL_HOST');
|
||||
$wgDBname = getenv('MYSQL_DATABASE');
|
||||
$wgDBuser = getenv('MYSQL_USER');
|
||||
$wgDBpassword = getenv('MYSQL_PASSWORD');
|
||||
|
||||
# MySQL specific settings
|
||||
$wgDBprefix = "";
|
||||
$wgDBTableOptions = "ENGINE=InnoDB, DEFAULT CHARSET=binary";
|
||||
$wgDBmysql5 = true;
|
||||
|
||||
# Shared memory settings
|
||||
$wgMainCacheType = CACHE_ACCEL;
|
||||
$wgMemCachedServers = [];
|
||||
|
||||
# To enable image uploads, make sure the 'images' directory
|
||||
# is writable, then set this to true:
|
||||
$wgEnableUploads = true;
|
||||
$wgMaxUploadSize = 1024*1024*100; # 100 MB
|
||||
# also set in php.ini
|
||||
|
||||
$wgUseImageMagick = true;
|
||||
$wgImageMagickConvertCommand = "/usr/bin/convert";
|
||||
|
||||
# InstantCommons allows wiki to use images from https://commons.wikimedia.org
|
||||
$wgUseInstantCommons = false;
|
||||
|
||||
# Allow specific file extensions
|
||||
$wgStrictFileExtensions = false;
|
||||
$wgFileExtensions[] = 'pdf';
|
||||
$wgFileExtensions[] = 'svg';
|
||||
$wgFileExtensions[] = 'mm';
|
||||
$wgFileExtensions[] = 'png';
|
||||
$wgFileExtensions[] = 'jpg';
|
||||
$wgFileExtensions[] = 'JPG';
|
||||
$wgFileExtensions[] = 'jpeg';
|
||||
$wgFileExtensions[] = 'py';
|
||||
|
||||
# Allow any file extensions, but print a warning if not in $wgFileExtensions[]
|
||||
$wgCheckFileExtensions = false;
|
||||
|
||||
# do not send pingback to https://www.mediawiki.org
|
||||
$wgPingback = false;
|
||||
|
||||
# If you use ImageMagick (or any other shell command) on a
|
||||
# Linux server, this will need to be set to the name of an
|
||||
# available UTF-8 locale
|
||||
$wgShellLocale = "en_US.utf8";
|
||||
|
||||
# If you have the appropriate support software installed
|
||||
# you can enable inline LaTeX equations:
|
||||
$wgUseTeX = true;
|
||||
$wgTexvc = "$IP/extensions/Math/math/texvc";
|
||||
#$wgTexvc = '/usr/bin/texvc';
|
||||
|
||||
# Set MathML as default rendering option
|
||||
$wgDefaultUserOptions['math'] = 'mathml';
|
||||
$wgMathFullRestbaseURL = 'https://en.wikipedia.org/api/rest_';
|
||||
$wgMathMathMLUrl = 'https://mathoid-beta.wmflabs.org/';
|
||||
|
||||
# Site language code, should be one of the list in ./languages/data/Names.php
|
||||
$wgLanguageCode = "en";
|
||||
|
||||
$wgSecretKey = getenv('MEDIAWIKI_SECRETKEY');
|
||||
|
||||
# Changing this will log out all existing sessions.
|
||||
$wgAuthenticationTokenVersion = "1";
|
||||
|
||||
# Site upgrade key. Must be set to a string (default provided) to turn on the
|
||||
# web installer while LocalSettings.php is in place
|
||||
$wgUpgradeKey = "984c1d9858dabc27";
|
||||
|
||||
# No license info
|
||||
$wgRightsPage = "";
|
||||
$wgRightsUrl = "";
|
||||
$wgRightsText = "";
|
||||
$wgRightsIcon = "";
|
||||
|
||||
# Alternative:
|
||||
$wgEnableCreativeCommonsRdf = true;
|
||||
$wgRightsPage = "";
|
||||
$wgRightsUrl = "http://creativecommons.org/licenses/by-nc-nd/3.0/us/";
|
||||
$wgRightsText = "Attribution-NonCommercial-NoDerivs 3.0 United States";
|
||||
$wgRightsIcon = "/w/skins/charlesmartinreid/cc.png";
|
||||
|
||||
# Path to the GNU diff3 utility. Used for conflict resolution.
|
||||
$wgDiff3 = "/usr/bin/diff3";
|
||||
|
||||
# Boostrap2 skin:
|
||||
wfLoadSkin( 'Bootstrap2' );
|
||||
require_once "$IP/skins/Bootstrap2/Bootstrap2.php";
|
||||
$wgDefaultSkin = 'Bootstrap2';
|
||||
$wgValidSkinNames['bootstrap2'] = 'Bootstrap2';
|
||||
|
||||
# Change to true for debugging
|
||||
$wgShowExceptionDetails=false;
|
||||
|
||||
# When you make changes to this configuration file, this will make
|
||||
# sure that cached pages are cleared.
|
||||
session_save_path("tmp");
|
||||
$wgCacheEpoch = max( $wgCacheEpoch, gmdate( 'YmdHis', @filemtime( __FILE__ ) ) );
|
||||
|
||||
############################################################
|
||||
############# Charles-Modified Settings ####################
|
||||
|
||||
# Allow external images (to do this, simply insert the image's URL)
|
||||
# http://url.for/some/image.png
|
||||
# But these cannot be resized.
|
||||
$wgAllowExternalImages = true;
|
||||
|
||||
# Use ImageMagick
|
||||
$wgUseImageMagic=true;
|
||||
|
||||
# $wgAllowDisplayTitle - Allow the magic word { { DISPLAYTITLE: } } to override the title of a page.
|
||||
$wgAllowdisplayTitle=true;
|
||||
|
||||
# Log IP addresses in the recentchanges table.
|
||||
$wgPutIPinRC=true;
|
||||
|
||||
# Getting some weird "Error creating thumbnail: Invalid thumbnail parameters" messages w/ thumbnail
|
||||
# http://www.gossamer-threads.com/lists/wiki/mediawiki/169439
|
||||
$wgMaxImageArea=64000000;
|
||||
$wgMaxShellMemory=0;
|
||||
|
||||
$wgFavicon="$wgScriptPath/favicon.ico";
|
||||
|
||||
######################
|
||||
# Edit permissions
|
||||
|
||||
# only admin can edit
|
||||
$wgGroupPermissions['*']['edit'] = false;
|
||||
$wgGroupPermissions['user']['edit'] = false;
|
||||
$wgGroupPermissions['sysop']['edit'] = true;
|
||||
|
||||
# only admin can register new accounts
|
||||
$wgGroupPermissions['*']['createaccount'] = false;
|
||||
$wgGroupPermissions['user']['createaccount'] = false;
|
||||
$wgGroupPermissions['sysop']['createaccount'] = true;
|
||||
|
||||
# only admin can upload
|
||||
$wgGroupPermissions['*']['upload'] = false;
|
||||
$wgGroupPermissions['user']['upload'] = false;
|
||||
$wgGroupPermissions['sysop']['upload'] = true;
|
||||
|
||||
$wgGroupPermissions['*']['reupload'] = false;
|
||||
$wgGroupPermissions['user']['reupload'] = false;
|
||||
$wgGroupPermissions['sysop']['reupload'] = true;
|
||||
|
||||
###############################
|
||||
## GeSHi syntax highlighting/code extension
|
||||
# https://github.com/wikimedia/mediawiki-extensions-SyntaxHighlight_GeSHi.git
|
||||
|
||||
wfLoadExtension( 'SyntaxHighlight_GeSHi' );
|
||||
$wgSyntaxHighlightDefaultLang = "text";
|
||||
|
||||
##############################
|
||||
# Parser functions
|
||||
# http://www.mediawiki.org/wiki/Extension:ParserFunctions
|
||||
# http://en.wikipedia.org/wiki/Template_talk:Navbox
|
||||
|
||||
wfLoadExtension( 'ParserFunctions' );
|
||||
|
||||
##############################################
|
||||
# Embed videos extension
|
||||
# https://github.com/HydraWiki/mediawiki-embedvideo/
|
||||
# require_once("$IP/extensions/EmbedVideo/EmbedVideo.php");
|
||||
|
||||
wfLoadExtension( 'EmbedVideo' );
|
||||
|
||||
###########################################
|
||||
# Math extension
|
||||
# https://github.com/wikimedia/mediawiki-extensions-Math.git
|
||||
|
||||
require_once "$IP/extensions/Math/Math.php";
|
||||
|
||||
#############################################
|
||||
# Fix cookies crap
|
||||
|
||||
session_save_path("/tmp");
|
||||
|
||||
##############################################
|
||||
# Secure login
|
||||
|
||||
$wgServer = "https://{{ pod_charlesreid1_server_name }}";
|
||||
$wgSecureLogin = true;
|
||||
|
||||
###################################
|
||||
# Raw html
|
||||
|
||||
$wgRawHtml = true;
|
||||
|
||||
# but also keep things locked down
|
||||
$wgUseRCPatrol=true;
|
||||
$wgNewUserLog=true;
|
||||
|
||||
##################################
|
||||
# Paths
|
||||
|
||||
$wgUploadPath = "$wgScriptPath/images";
|
||||
$wgUploadDirectory = "$IP/images";
|
||||
$wgMathPath = "$wgUploadPath/math";
|
||||
$wgMathDirectory = "$wgUploadDirectory/math";
|
||||
$wgTmpDirectory = "$wgUploadDirectory/tmp";
|
||||
$wgLatexCommand = "/usr/bin/latex";
|
||||
#$wgUploadBaseUrl = false; # not sure about why this one too...
|
||||
$wgVerifyMimeType = false;
|
||||
#$wgDebugLogFile = "/var/log/apache2/wiki.log";
|
@ -1,18 +0,0 @@
|
||||
# mediawiki config files
|
||||
|
||||
In the `LocalSettings.php` file, which needs to have the MySQL
|
||||
account credentials, we have the following:
|
||||
|
||||
```
|
||||
## Database settings
|
||||
$wgDBtype = "mysql";
|
||||
$wgDBserver = getenv('MYSQL_HOST');
|
||||
$wgDBname = getenv('MYSQL_DATABASE');
|
||||
$wgDBuser = getenv('MYSQL_USER');
|
||||
$wgDBpassword = getenv('MYSQL_PASSWORD');
|
||||
```
|
||||
|
||||
This information comes from the environment. In our case,
|
||||
this comes from a MediaWiki docker container (see the
|
||||
[d-mediawiki](https://git.charlesreid1.com/docker/d-mediawiki)
|
||||
repo.)
|
@ -1,43 +0,0 @@
|
||||
import os, re, sys
|
||||
from jinja2 import Environment, FileSystemLoader, select_autoescape
|
||||
|
||||
"""
|
||||
Apply Default Values to Jinja Templates
|
||||
|
||||
|
||||
This script applies default values to
|
||||
mediawiki LocalSettings.php file.
|
||||
|
||||
The configuration templates are useful for Ansible,
|
||||
but this is useful for experiments/one-offs.
|
||||
|
||||
All configuration files are for charlesreid1.com
|
||||
docker pod, nginx, and realted infrastructure.
|
||||
"""
|
||||
|
||||
|
||||
# Where templates live
|
||||
TEMPLATEDIR = '.'
|
||||
|
||||
# Where rendered templates will go
|
||||
OUTDIR = '.'
|
||||
|
||||
# Should existing files be overwritten
|
||||
OVERWRITE = True
|
||||
|
||||
env = Environment(loader=FileSystemLoader('.'))
|
||||
|
||||
tfile = 'LocalSettings.php.j2'
|
||||
rfile = 'LocalSettings.php'
|
||||
|
||||
content = env.get_template(tfile).render({
|
||||
"server_name_default" : "charlesreid1.com"
|
||||
})
|
||||
|
||||
# Write to file
|
||||
if os.path.exists(rfile) and not OVERWRITE:
|
||||
raise Exception("Error: file %s already exists!"%(rfile))
|
||||
else:
|
||||
with open(rfile,'w') as f:
|
||||
f.write(content)
|
||||
|
@ -1,329 +0,0 @@
|
||||
<?php
|
||||
# This file was automatically generated by the MediaWiki 1.30.0
|
||||
# installer. If you make manual changes, please keep track in case you
|
||||
# need to recreate them later.
|
||||
#
|
||||
# See includes/DefaultSettings.php for all configurable settings
|
||||
# and their default values, but don't forget to make changes in _this_
|
||||
# file, not there.
|
||||
#
|
||||
# Further documentation for configuration settings may be found at:
|
||||
# https://www.mediawiki.org/wiki/Manual:Configuration_settings
|
||||
|
||||
# Protect against web entry
|
||||
if ( !defined( 'MEDIAWIKI' ) ) {
|
||||
exit;
|
||||
}
|
||||
|
||||
## Uncomment this to disable output compression
|
||||
# $wgDisableOutputCompression = true;
|
||||
|
||||
$wgSitename = "charlesreid1";
|
||||
$wgMetaNamespace = "Charlesreid1";
|
||||
|
||||
# from http://www.mediawiki.org/wiki/Manual:Short_URL#Recommended_how-to_guide_.28setup_used_on_Wikipedia.29
|
||||
$wgScriptPath = "/w"; # Path to the actual files. This should already be there
|
||||
$wgArticlePath = "/wiki/$1"; # Virtual path. This directory MUST be different from the one used in $wgScriptPath
|
||||
$wgUsePathInfo = true; # Enable use of pretty URLs
|
||||
|
||||
|
||||
## The protocol and server name to use in fully-qualified URLs
|
||||
$wgServer = 'https://';
|
||||
$wgCanonicalServer = 'https://';
|
||||
|
||||
## The URL path to static resources (images, scripts, etc.)
|
||||
$wgStylePath = "$wgScriptPath/skins";
|
||||
$wgResourceBasePath = $wgScriptPath;
|
||||
|
||||
## The URL path to the logo. Make sure you change this from the default,
|
||||
## or else you'll overwrite your logo when you upgrade!
|
||||
$wgLogo = "$wgResourceBasePath/resources/assets/wiki.png";
|
||||
|
||||
## UPO means: this is also a user preference option
|
||||
|
||||
$wgEnableEmail = true;
|
||||
$wgEnableUserEmail = true; # UPO
|
||||
|
||||
$wgEmergencyContact = "charles@charlesreid1.com";
|
||||
$wgPasswordSender = "charles@charlesreid1.com";
|
||||
|
||||
$wgEnotifUserTalk = false; # UPO
|
||||
$wgEnotifWatchlist = false; # UPO
|
||||
$wgEmailAuthentication = true;
|
||||
|
||||
## Database settings
|
||||
$wgDBtype = "mysql";
|
||||
$wgDBserver = getenv('MYSQL_HOST');
|
||||
$wgDBname = getenv('MYSQL_DATABASE');
|
||||
$wgDBuser = getenv('MYSQL_USER');
|
||||
$wgDBpassword = getenv('MYSQL_PASSWORD');
|
||||
|
||||
# MySQL specific settings
|
||||
$wgDBprefix = "";
|
||||
|
||||
# MySQL table options to use during installation or update
|
||||
$wgDBTableOptions = "ENGINE=InnoDB, DEFAULT CHARSET=binary";
|
||||
|
||||
# Experimental charset support for MySQL 5.0.
|
||||
//$wgDBmysql5 = false; // new version
|
||||
$wgDBmysql5 = true; // true on charlesreid1.com
|
||||
|
||||
## Shared memory settings
|
||||
$wgMainCacheType = CACHE_ACCEL;
|
||||
$wgMemCachedServers = [];
|
||||
|
||||
## To enable image uploads, make sure the 'images' directory
|
||||
## is writable, then set this to true:
|
||||
$wgEnableUploads = true;
|
||||
$wgMaxUploadSize = 1024*1024*100; # 100 MB
|
||||
# also set in php.ini
|
||||
|
||||
$wgUseImageMagick = true;
|
||||
$wgImageMagickConvertCommand = "/usr/bin/convert";
|
||||
|
||||
# InstantCommons allows wiki to use images from https://commons.wikimedia.org
|
||||
$wgUseInstantCommons = false;
|
||||
|
||||
# Allow specific file extensions
|
||||
$wgStrictFileExtensions = false;
|
||||
$wgFileExtensions[] = 'pdf';
|
||||
$wgFileExtensions[] = 'svg';
|
||||
$wgFileExtensions[] = 'mm';
|
||||
$wgFileExtensions[] = 'png';
|
||||
$wgFileExtensions[] = 'jpg';
|
||||
$wgFileExtensions[] = 'JPG';
|
||||
$wgFileExtensions[] = 'jpeg';
|
||||
$wgFileExtensions[] = 'py';
|
||||
|
||||
# Allow any file extensions,
|
||||
# but print a warning if its not
|
||||
# in $wgFileExtensions[]
|
||||
$wgCheckFileExtensions = false;
|
||||
|
||||
# do not send pingback to https://www.mediawiki.org
|
||||
$wgPingback = false;
|
||||
|
||||
# If you use ImageMagick (or any other shell command) on a
|
||||
# Linux server, this will need to be set to the name of an
|
||||
# available UTF-8 locale
|
||||
//$wgShellLocale = "C.UTF-8"; // modern
|
||||
$wgShellLocale = "en_US.utf8"; // charlesreid1.com version
|
||||
|
||||
## Set $wgCacheDirectory to a writable directory on the web server
|
||||
## to make your wiki go slightly faster. The directory should not
|
||||
## be publically accessible from the web.
|
||||
#$wgCacheDirectory = "$IP/cache";
|
||||
|
||||
## If you have the appropriate support software installed
|
||||
## you can enable inline LaTeX equations:
|
||||
$wgUseTeX = true;
|
||||
$wgTexvc = "$IP/extensions/Math/math/texvc";
|
||||
//$wgTexvc = '/usr/bin/texvc';
|
||||
|
||||
$wgDefaultUserOptions['math'] = 0; //Always render eqns as .pngs
|
||||
|
||||
# Site language code, should be one of the list in ./languages/data/Names.php
|
||||
$wgLanguageCode = "en";
|
||||
|
||||
$wgSecretKey = getenv('MEDIAWIKI_SECRETKEY');
|
||||
|
||||
# Changing this will log out all existing sessions.
|
||||
$wgAuthenticationTokenVersion = "1";
|
||||
|
||||
# Site upgrade key. Must be set to a string (default provided) to turn on the
|
||||
# web installer while LocalSettings.php is in place
|
||||
$wgUpgradeKey = "984c1d9858dabc27";
|
||||
|
||||
## no license info
|
||||
$wgRightsPage = "";
|
||||
$wgRightsUrl = "";
|
||||
$wgRightsText = "";
|
||||
$wgRightsIcon = "";
|
||||
|
||||
# Alternative:
|
||||
$wgEnableCreativeCommonsRdf = true;
|
||||
$wgRightsPage = ""; # Set to the title of a wiki page that describes your license/copyright
|
||||
$wgRightsUrl = "http://creativecommons.org/licenses/by-nc-nd/3.0/us/";
|
||||
$wgRightsText = "Attribution-NonCommercial-NoDerivs 3.0 United States";
|
||||
$wgRightsIcon = "/w/skins/charlesmartinreid/cc.png";
|
||||
# $wgRightsCode = "[license_code]"; # Not yet used
|
||||
#
|
||||
|
||||
# Path to the GNU diff3 utility. Used for conflict resolution.
|
||||
$wgDiff3 = "/usr/bin/diff3";
|
||||
|
||||
## Default skin: you can change the default skin. Use the internal symbolic
|
||||
## names, ie 'vector', 'monobook':
|
||||
|
||||
|
||||
|
||||
# Boostrap2 skin:
|
||||
wfLoadSkin( 'Bootstrap2' );
|
||||
require_once "$IP/skins/Bootstrap2/Bootstrap2.php";
|
||||
$wgDefaultSkin = 'Bootstrap2';
|
||||
|
||||
$wgValidSkinNames['bootstrap2'] = 'Bootstrap2';
|
||||
|
||||
|
||||
$wgShowExceptionDetails=false;
|
||||
//$wgShowExceptionDetails = true;
|
||||
//$wgShowDBErrorBacktrace = true;
|
||||
//$wgShowSQLErrors = true;
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
$wgDiff3 = "/usr/bin/diff3";
|
||||
|
||||
# When you make changes to this configuration file, this will make
|
||||
# sure that cached pages are cleared.
|
||||
session_save_path("tmp");
|
||||
$wgCacheEpoch = max( $wgCacheEpoch, gmdate( 'YmdHis', @filemtime( __FILE__ ) ) );
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
############################################################
|
||||
############# Charles-Modified Settings ####################
|
||||
|
||||
|
||||
# Allow external images:
|
||||
$wgAllowExternalImages = true;
|
||||
# to do this, simply insert the image's URL:
|
||||
#http://url.for/some/image.png
|
||||
# But these cannot be resized. It's better to just put your own version into the wiki
|
||||
|
||||
# Use ImageMagick
|
||||
$wgUseImageMagic=true;
|
||||
|
||||
# $wgAllowDisplayTitle - Allow the magic word { { DISPLAYTITLE: } } to override the title of a page.
|
||||
$wgAllowdisplayTitle=true;
|
||||
|
||||
# $wgPutIPinRC - Log IP addresses in the recentchanges table.
|
||||
$wgPutIPinRC=true;
|
||||
|
||||
# Getting some weird "Error creating thumbnail: Invalid thumbnail parameters" messages w/ thumbnail
|
||||
# http://www.gossamer-threads.com/lists/wiki/mediawiki/169439
|
||||
$wgMaxImageArea=64000000;
|
||||
$wgMaxShellMemory=0;
|
||||
# Also:
|
||||
# http://www.ipbwiki.com/forums/index.php?showtopic=812
|
||||
|
||||
$wgFavicon="$wgScriptPath/favicon.ico";
|
||||
|
||||
|
||||
|
||||
######################
|
||||
# Edit permissions
|
||||
|
||||
# only admin can edit
|
||||
$wgGroupPermissions['*']['edit'] = false;
|
||||
$wgGroupPermissions['user']['edit'] = false;
|
||||
$wgGroupPermissions['sysop']['edit'] = true;
|
||||
|
||||
# only admin can register new accounts
|
||||
$wgGroupPermissions['*']['createaccount'] = false;
|
||||
$wgGroupPermissions['user']['createaccount'] = false;
|
||||
$wgGroupPermissions['sysop']['createaccount'] = true;
|
||||
|
||||
# only admin can upload
|
||||
$wgGroupPermissions['*']['upload'] = false;
|
||||
$wgGroupPermissions['user']['upload'] = false;
|
||||
$wgGroupPermissions['sysop']['upload'] = true;
|
||||
|
||||
$wgGroupPermissions['*']['reupload'] = false;
|
||||
$wgGroupPermissions['user']['reupload'] = false;
|
||||
$wgGroupPermissions['sysop']['reupload'] = true;
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
###############################
|
||||
## GeSHi syntax highlighting/code extension
|
||||
#
|
||||
# https://github.com/wikimedia/mediawiki-extensions-SyntaxHighlight_GeSHi.git
|
||||
#
|
||||
require_once("$IP/extensions/SyntaxHighlight_GeSHi/SyntaxHighlight_GeSHi.php");
|
||||
$wgSyntaxHighlightDefaultLang = "text";
|
||||
|
||||
|
||||
|
||||
##############################
|
||||
# Parser functions
|
||||
#
|
||||
# http://www.mediawiki.org/wiki/Extension:ParserFunctions
|
||||
# http://en.wikipedia.org/wiki/Template_talk:Navbox
|
||||
require_once( "$IP/extensions/ParserFunctions/ParserFunctions.php" );
|
||||
|
||||
|
||||
|
||||
|
||||
##############################################
|
||||
# Embed videos extension
|
||||
# https://github.com/HydraWiki/mediawiki-embedvideo/
|
||||
#require_once("$IP/extensions/EmbedVideo/EmbedVideo.php");
|
||||
wfLoadExtension( 'EmbedVideo' );
|
||||
|
||||
|
||||
|
||||
###########################################
|
||||
## Math extension
|
||||
#
|
||||
# https://github.com/wikimedia/mediawiki-extensions-Math.git
|
||||
#
|
||||
require_once "$IP/extensions/Math/Math.php";
|
||||
|
||||
|
||||
|
||||
#############################################
|
||||
## Fix cookies crap
|
||||
session_save_path("/tmp");
|
||||
|
||||
##############################################
|
||||
#### secure login
|
||||
$wgServer = "https://";
|
||||
$wgSecureLogin = true;
|
||||
|
||||
###################################
|
||||
##### raw html
|
||||
$wgRawHtml = true;
|
||||
|
||||
# but also keep things locked down
|
||||
|
||||
$wgUseRCPatrol=true;
|
||||
$wgNewUserLog=true;
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
##############################################
|
||||
## Because adding a new extension for every dumb little thing you want to do is dumb
|
||||
|
||||
$wgRawHtml = true;
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
$wgUploadPath = "$wgScriptPath/images";
|
||||
$wgUploadDirectory = "$IP/images";
|
||||
$wgMathPath = "$wgUploadPath/math";
|
||||
$wgMathDirectory = "$wgUploadDirectory/math";
|
||||
$wgTmpDirectory = "$wgUploadDirectory/tmp";
|
||||
$wgLatexCommand = "/usr/bin/latex";
|
||||
#$wgUploadBaseUrl = false; #not sure about why this one too...
|
||||
$wgVerifyMimeType = false;
|
||||
|
||||
|
||||
# log
|
||||
$wgDebugLogFile = "/var/log/apache2/wiki.log";
|
||||
|
@ -1,452 +0,0 @@
|
||||
<?php
|
||||
/**
|
||||
* Bootstrap2 MediaWiki skin
|
||||
*
|
||||
* @file Bootstrap2.php
|
||||
*/
|
||||
|
||||
if( !defined( 'MEDIAWIKI' ) )
|
||||
die( -1 );
|
||||
|
||||
/**
|
||||
* Inherit main code from SkinTemplate, set the CSS and template filter.
|
||||
*/
|
||||
class SkinBootstrap2 extends SkinTemplate {
|
||||
/** Using Bootstrap2 */
|
||||
var $skinname = 'Bootstrap2',
|
||||
$stylename = 'Bootstrap2',
|
||||
// -------- Start ---------
|
||||
// making this true, to match the Dash style
|
||||
$useHeadElement = true,
|
||||
//$useHeadElement = false,
|
||||
// -------- End ---------
|
||||
// cmr 05/08/2014
|
||||
$template = 'Bootstrap2Template';
|
||||
|
||||
function setupSkinUserCss( OutputPage $out ) {
|
||||
global $wgHandheldStyle;
|
||||
|
||||
parent::setupSkinUserCss( $out );
|
||||
|
||||
// Append to the default screen common & print styles...
|
||||
$out->addStyle( 'Bootstrap2/IE50Fixes.css', 'screen', 'lt IE 5.5000' );
|
||||
$out->addStyle( 'Bootstrap2/IE55Fixes.css', 'screen', 'IE 5.5000' );
|
||||
$out->addStyle( 'Bootstrap2/IE60Fixes.css', 'screen', 'IE 6' );
|
||||
$out->addStyle( 'Bootstrap2/IE70Fixes.css', 'screen', 'IE 7' );
|
||||
|
||||
$out->addStyle( 'Bootstrap2/rtl.css', 'screen', '', 'rtl' );
|
||||
|
||||
|
||||
$out->addStyle('Bootstrap2/bootstrap.css' );
|
||||
$out->addStyle('Bootstrap2/slate.css' );
|
||||
$out->addStyle('Bootstrap2/main.css' );
|
||||
$out->addStyle('Bootstrap2/dox.css' );
|
||||
|
||||
$out->addStyle('Bootstrap2/css/font-awesome.css');
|
||||
//$out->addStyle('Bootstrap2/cmr-bootstrap-cyborg.css');
|
||||
//$out->addStyle('Bootstrap2/cmr-bootstrap-cyborg-wiki.css');
|
||||
//
|
||||
//$out->addStyle('Bootstrap2/bootstrap-cyborg.css' );
|
||||
//$out->addStyle('Bootstrap2/bootstrap-responsive-cyborg.css');
|
||||
|
||||
//$out->addStyle( 'Bootstrap2/main.css', 'screen' );
|
||||
}
|
||||
}
|
||||
|
||||
class Bootstrap2Template extends QuickTemplate {
|
||||
var $skin;
|
||||
|
||||
/**
|
||||
* Template filter callback for Bootstrap2 skin.
|
||||
* Takes an associative array of data set from a SkinTemplate-based
|
||||
* class, and a wrapper for MediaWiki's localization database, and
|
||||
* outputs a formatted page.
|
||||
*
|
||||
* @access private
|
||||
*/
|
||||
function execute() {
|
||||
global $wgRequest;
|
||||
|
||||
$this->skin = $skin = $this->data['skin'];
|
||||
$action = $wgRequest->getText( 'action' );
|
||||
|
||||
// -------- Start ------------
|
||||
// Adding the following line makes Geshi work
|
||||
$this->html( 'headelement' );
|
||||
// Left this out because the [edit] buttons were becoming right-aligned
|
||||
// Got around that behavior by changing shared.css
|
||||
// -------- End ------------
|
||||
// cmr 01-10-2014
|
||||
|
||||
|
||||
|
||||
/////////////////////////////
|
||||
// begin custom
|
||||
// bootstrap content
|
||||
|
||||
$get_override = 'True';
|
||||
$url_array = explode('/',$_SERVER['REQUEST_URI']);
|
||||
array_shift($url_array); // remove first value as it's empty
|
||||
|
||||
$p = "wiki";
|
||||
|
||||
// path, inside container
|
||||
include('/var/www/html/skins/Bootstrap2/navbar.php');
|
||||
|
||||
?>
|
||||
<!-- favicon -->
|
||||
<link rel="shortcut icon" href="/favicon.ico">
|
||||
|
||||
<div class="container">
|
||||
|
||||
<!-- Row: Navigation bar for wiki -->
|
||||
<div class="row">
|
||||
<nav class="wiki navbar navbar-default">
|
||||
|
||||
<div class="container-fixed">
|
||||
<div class="navbar-header">
|
||||
<a href="/wiki/" class="navbar-brand">
|
||||
{{ pod_charlesreid1_server_name }} wiki
|
||||
</a>
|
||||
</div>
|
||||
<div>
|
||||
<ul class="wiki nav navbar-nav">
|
||||
<?php
|
||||
|
||||
/*
|
||||
// Print debug information
|
||||
echo "\n";
|
||||
echo "<!--";
|
||||
echo "\n";
|
||||
echo print_r($this->data['content_actions']);
|
||||
echo "\n";
|
||||
echo "~~~~~~~~~";
|
||||
echo "\n";
|
||||
foreach($this->data['content_actions'] as $key => $tab) {
|
||||
echo $key;
|
||||
echo "\n";
|
||||
//echo print_r($tab);
|
||||
echo $tab['href'];
|
||||
echo "\n";
|
||||
echo "\n";
|
||||
echo "\n";
|
||||
}
|
||||
echo "\n";
|
||||
echo "-->";
|
||||
echo "\n";
|
||||
*/
|
||||
|
||||
echo "\n";
|
||||
foreach($this->data['content_actions'] as $key => $tab) {
|
||||
|
||||
if( in_array($key, array('nstab-main','edit','history','viewsource','delete','move'))) {
|
||||
|
||||
echo '<li class="wiki';
|
||||
if( $tab['class'] ) {
|
||||
echo ' ';
|
||||
echo $tab['class'];
|
||||
}
|
||||
echo '" id="' . Sanitizer::escapeId( "ca-$key" ) . '">';
|
||||
echo '<a href="';
|
||||
echo htmlspecialchars($tab['href']);
|
||||
echo '">';
|
||||
echo $tab['text'];
|
||||
echo "</a>";
|
||||
echo "</li>";
|
||||
//echo '>'.htmlspecialchars($tab['text']).'</a></li>';
|
||||
echo "\n";
|
||||
|
||||
}
|
||||
|
||||
} ?>
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</nav>
|
||||
</div>
|
||||
|
||||
|
||||
<!-- Row: Page content for wiki -->
|
||||
<div class="row">
|
||||
<div class="span10 offset1">
|
||||
|
||||
<!--
|
||||
=========================
|
||||
Begin MediaWiki content
|
||||
=========================
|
||||
-->
|
||||
|
||||
<div class="mw_content">
|
||||
|
||||
<div id="content" <?php $this->html("specialpageattributes") ?>>
|
||||
|
||||
<!-- page title -->
|
||||
<div class="page-header">
|
||||
<h1 id="firstHeading" class="firstHeading">
|
||||
<?php $this->html('title') ?>
|
||||
</h1>
|
||||
</div><!--div page-header-->
|
||||
|
||||
<!-- pre-article stuff -->
|
||||
<div id="bodyContent">
|
||||
<h3 id="siteSub"><?php $this->msg('tagline') ?></h3>
|
||||
<div id="contentSub"<?php $this->html('userlangattributes') ?>><?php $this->html('subtitle') ?>
|
||||
</div>
|
||||
<?php
|
||||
if($this->data['undelete']) { ?>
|
||||
<div id="contentSub2"><?php $this->html('undelete') ?></div>
|
||||
<?php
|
||||
}
|
||||
if($this->data['newtalk'] ) { ?>
|
||||
<div class="usermessage"><?php $this->html('newtalk') ?></div>
|
||||
<?php
|
||||
}
|
||||
?>
|
||||
|
||||
<!-- article -->
|
||||
|
||||
<!-- begin mediawiki content -->
|
||||
<?php $this->html('bodytext') ?>
|
||||
|
||||
<?php
|
||||
if($this->data['catlinks']) {
|
||||
$this->html('catlinks');
|
||||
} ?>
|
||||
</div><!-- end bodyContent -->
|
||||
|
||||
</div><!--div special page attributes-->
|
||||
|
||||
</div><!--div mw content-->
|
||||
<!--
|
||||
=========================
|
||||
End MediaWiki content
|
||||
=========================
|
||||
-->
|
||||
|
||||
</div><!--div span10 -->
|
||||
</div><!--row-->
|
||||
|
||||
<!--
|
||||
==========================================================
|
||||
====================== Begin Wiki Footer =================
|
||||
==========================================================
|
||||
-->
|
||||
|
||||
</div>
|
||||
|
||||
<?php
|
||||
include('/var/www/html/skins/Bootstrap2/footer.php');
|
||||
?>
|
||||
|
||||
<?php
|
||||
} // end of execute() method
|
||||
|
||||
/*************************************************************************************************/
|
||||
function searchBox() {
|
||||
global $wgUseTwoButtonsSearchForm;
|
||||
?>
|
||||
<div id="p-search" class="portlet">
|
||||
<div id="searchBody" class="pBody">
|
||||
<form class="navbar-search pull-left" action="<?php $this->text('wgScript') ?>" id="searchform">
|
||||
<input type='hidden' name="title" value="<?php $this->text('searchtitle') ?>"/>
|
||||
<?php
|
||||
echo Html::input( 'search',
|
||||
isset( $this->data['search'] ) ? $this->data['search'] : '', 'search',
|
||||
array(
|
||||
'id' => 'searchInput',
|
||||
'class' => 'search-query',
|
||||
'title' => $this->skin->titleAttrib( 'search' ),
|
||||
'accesskey' => $this->skin->accesskey( 'search' )
|
||||
) ); ?>
|
||||
|
||||
<!--
|
||||
<input type='submit' name="go" class="searchButton" id="searchGoButton" value="<?php $this->msg('searcharticle') ?>"<?php echo $this->skin->tooltipAndAccesskey( 'search-go' ); ?> /><?php if ($wgUseTwoButtonsSearchForm) { ?>
|
||||
-->
|
||||
<input type='submit' name="fulltext" class="btn btn-large" id="mw-searchButton" value="<?php $this->msg('searchbutton') ?>"<?php echo $this->skin->tooltipAndAccesskey( 'search-fulltext' ); ?> /><?php } else { ?>
|
||||
|
||||
<div><a href="<?php $this->text('searchaction') ?>" rel="search"><?php $this->msg('powersearch-legend') ?></a></div><?php } ?>
|
||||
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
<?php
|
||||
}
|
||||
|
||||
/*************************************************************************************************/
|
||||
function personalTools() {
|
||||
?>
|
||||
<ul class="nav nav-list">
|
||||
<li class="nav-header"><?php $this->msg('personaltools') ?></li>
|
||||
<?php
|
||||
foreach($this->data['personal_urls'] as $key => $item) {
|
||||
if( strcmp($key,"userpage") == 0
|
||||
|| strcmp($key,"preferences") == 0
|
||||
|| strcmp($key,"logout") == 0 ) { ?>
|
||||
<li> <a href="<?php
|
||||
echo htmlspecialchars($item['href']) ?>"<?php echo $skin->tooltipAndAccesskey('pt-'.$key) ?><?php
|
||||
if(!empty($item['class'])) { ?> class="<?php
|
||||
echo htmlspecialchars($item['class']) ?>"<?php } ?>><?php
|
||||
echo htmlspecialchars($item['text']) ?></a></li>
|
||||
<?php
|
||||
} else {
|
||||
}
|
||||
}
|
||||
// put a log in button
|
||||
?>
|
||||
<li><a href="/wiki/Special:UserLogin">Log in</a></li>
|
||||
<?php
|
||||
}
|
||||
|
||||
/*************************************************************************************************/
|
||||
function toolbox() {
|
||||
?>
|
||||
<!--
|
||||
<div class="portlet" id="p-tb">
|
||||
<div class="pBody">
|
||||
-->
|
||||
<ul class="nav nav-list">
|
||||
<li class="nav-header"><?php $this->msg('toolbox') ?></li>
|
||||
<?php
|
||||
/*
|
||||
if($this->data['notspecialpage']) { ?>
|
||||
<li id="t-whatlinkshere"><a href="<?php
|
||||
echo htmlspecialchars($this->data['nav_urls']['whatlinkshere']['href'])
|
||||
?>"<?php echo $this->skin->tooltipAndAccesskey('t-whatlinkshere') ?>><?php $this->msg('whatlinkshere') ?></a></li>
|
||||
<?php
|
||||
if( $this->data['nav_urls']['recentchangeslinked'] ) { ?>
|
||||
<li id="t-recentchangeslinked"><a href="<?php
|
||||
echo htmlspecialchars($this->data['nav_urls']['recentchangeslinked']['href'])
|
||||
?>"<?php echo $this->skin->tooltipAndAccesskey('t-recentchangeslinked') ?>><?php $this->msg('recentchangeslinked-toolbox') ?></a></li>
|
||||
<?php }
|
||||
|
||||
}
|
||||
|
||||
if( isset( $this->data['nav_urls']['trackbacklink'] ) && $this->data['nav_urls']['trackbacklink'] ) { ?>
|
||||
<li id="t-trackbacklink"><a href="<?php
|
||||
echo htmlspecialchars($this->data['nav_urls']['trackbacklink']['href'])
|
||||
?>"<?php echo $this->skin->tooltipAndAccesskey('t-trackbacklink') ?>><?php $this->msg('trackbacklink') ?></a></li>
|
||||
<?php }
|
||||
if($this->data['feeds']) { ?>
|
||||
<li id="feedlinks"><?php foreach($this->data['feeds'] as $key => $feed) {
|
||||
?><a id="<?php echo Sanitizer::escapeId( "feed-$key" ) ?>" href="<?php
|
||||
echo htmlspecialchars($feed['href']) ?>" rel="alternate" type="application/<?php echo $key ?>+xml" class="feedlink"<?php echo $this->skin->tooltipAndAccesskey('feed-'.$key) ?>><?php echo htmlspecialchars($feed['text'])?></a>
|
||||
<?php } ?></li><?php
|
||||
}
|
||||
*/
|
||||
|
||||
|
||||
|
||||
// Upload files, and list all files
|
||||
|
||||
if($this->data['nav_urls']['upload']) {
|
||||
?><li id="t-<?php echo 'upload'; ?>"><a href="<?php echo htmlspecialchars($this->data['nav_urls']['upload']['href'])
|
||||
?>" <?php echo $this->skin->tooltipAndAccesskey('t-upload') ?>><?php $this->msg('upload') ?></a></li>
|
||||
<?php
|
||||
}
|
||||
|
||||
|
||||
|
||||
// Special pages, and list all pages
|
||||
|
||||
if( $this->data['nav_urls']['specialpages'] ) {
|
||||
?><li id="t-<?php echo 'specialpages'; ?>"><a href="<?php echo htmlspecialchars($this->data['nav_urls']['specialpages']['href'])
|
||||
?>" <?php echo $this->skin->tooltipAndAccesskey('t-specialpages') ?>><?php $this->msg('specialpages') ?></a></li>
|
||||
<?php
|
||||
$element_name = 'all_pages';
|
||||
$element_title = 'List All Pages';
|
||||
$element_href = "/wiki/Special:AllPages";
|
||||
$this->data['nav_urls'][$element_name]['href'] = $element_href;
|
||||
?>
|
||||
<li id="t-<?php echo $element_name; ?>"><a href="<?php echo htmlspecialchars( $this->data['nav_urls'][$element_name]['href'] )
|
||||
?>" title="<?php echo $element_title ?>"><?php echo $element_title; ?></a></li>
|
||||
<?php
|
||||
}
|
||||
|
||||
|
||||
|
||||
/*
|
||||
foreach( array('contributions', 'log', 'blockip', 'emailuser') as $special ) {
|
||||
|
||||
if($this->data['nav_urls'][$special]) {
|
||||
?><li id="t-<?php echo $special ?>"><a href="<?php echo htmlspecialchars($this->data['nav_urls'][$special]['href'])
|
||||
?>"<?php echo $this->skin->tooltipAndAccesskey('t-'.$special) ?>><?php $this->msg($special) ?></a></li>
|
||||
<?php }
|
||||
}
|
||||
*/
|
||||
|
||||
/*
|
||||
if(!empty($this->data['nav_urls']['print']['href'])) { ?>
|
||||
<li id="t-print"><a href="<?php echo htmlspecialchars($this->data['nav_urls']['print']['href'])
|
||||
?>" rel="alternate"<?php echo $this->skin->tooltipAndAccesskey('t-print') ?>><?php $this->msg('printableversion') ?></a></li><?php
|
||||
}
|
||||
*/
|
||||
|
||||
if(!empty($this->data['nav_urls']['permalink']['href'])) { ?>
|
||||
<li id="t-permalink"><a href="<?php echo htmlspecialchars($this->data['nav_urls']['permalink']['href'])
|
||||
?>"<?php echo $this->skin->tooltipAndAccesskey('t-permalink') ?>><?php $this->msg('permalink') ?></a></li><?php
|
||||
} elseif ($this->data['nav_urls']['permalink']['href'] === '') { ?>
|
||||
<li id="t-ispermalink"<?php echo $this->skin->tooltip('t-ispermalink') ?>><?php $this->msg('permalink') ?></li><?php
|
||||
}
|
||||
|
||||
//wfRunHooks( 'BootstrapTemplateToolboxEnd', array( &$this ) );
|
||||
wfRunHooks( 'BootstrapTemplateToolboxEnd', array( &$this ) );
|
||||
?>
|
||||
</ul>
|
||||
<!--
|
||||
</div>
|
||||
</div>
|
||||
-->
|
||||
<?php
|
||||
}
|
||||
|
||||
/*************************************************************************************************/
|
||||
function languageBox() {
|
||||
if( $this->data['language_urls'] ) {
|
||||
?>
|
||||
<div id="p-lang" class="portlet">
|
||||
<h5<?php $this->html('userlangattributes') ?>><?php $this->msg('otherlanguages') ?></h5>
|
||||
<div class="pBody">
|
||||
<ul>
|
||||
<?php foreach($this->data['language_urls'] as $langlink) { ?>
|
||||
<li class="<?php echo htmlspecialchars($langlink['class'])?>"><?php
|
||||
?><a href="<?php echo htmlspecialchars($langlink['href']) ?>"><?php echo $langlink['text'] ?></a></li>
|
||||
<?php } ?>
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
<?php
|
||||
}
|
||||
}
|
||||
|
||||
/*************************************************************************************************/
|
||||
function customBox( $bar, $cont ) {
|
||||
?>
|
||||
<!--
|
||||
<div class='generated-sidebar portlet' id='<?php echo Sanitizer::escapeId( "p-$bar" ) ?>'<?php echo $this->skin->tooltip('p-'.$bar) ?>>
|
||||
<div class='pBody'>
|
||||
-->
|
||||
|
||||
<?php if ( is_array( $cont ) ) { ?>
|
||||
<ul class="nav nav-list">
|
||||
<li class="nav-header"><?php $out = wfMsg( $bar ); if (wfEmptyMsg($bar, $out)) echo htmlspecialchars($bar); else echo htmlspecialchars($out); ?></li>
|
||||
<?php foreach($cont as $key => $val) { ?>
|
||||
<li id="<?php echo Sanitizer::escapeId($val['id']) ?>"<?php
|
||||
if ( $val['active'] ) { ?> class="active" <?php }
|
||||
?>><a href="<?php echo htmlspecialchars($val['href']) ?>"<?php echo $this->skin->tooltipAndAccesskey($val['id']) ?>><?php echo htmlspecialchars($val['text']) ?></a></li>
|
||||
<?php } ?>
|
||||
</ul>
|
||||
<?php } else {
|
||||
# allow raw HTML block to be defined by extensions
|
||||
print $cont;
|
||||
}
|
||||
?>
|
||||
<!--
|
||||
</div>
|
||||
</div>
|
||||
-->
|
||||
<?php
|
||||
}
|
||||
} // end of class
|
||||
|
||||
|
@ -1,339 +0,0 @@
|
||||
GNU GENERAL PUBLIC LICENSE
|
||||
Version 2, June 1991
|
||||
|
||||
Copyright (C) 1989, 1991 Free Software Foundation, Inc.,
|
||||
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
Everyone is permitted to copy and distribute verbatim copies
|
||||
of this license document, but changing it is not allowed.
|
||||
|
||||
Preamble
|
||||
|
||||
The licenses for most software are designed to take away your
|
||||
freedom to share and change it. By contrast, the GNU General Public
|
||||
License is intended to guarantee your freedom to share and change free
|
||||
software--to make sure the software is free for all its users. This
|
||||
General Public License applies to most of the Free Software
|
||||
Foundation's software and to any other program whose authors commit to
|
||||
using it. (Some other Free Software Foundation software is covered by
|
||||
the GNU Lesser General Public License instead.) You can apply it to
|
||||
your programs, too.
|
||||
|
||||
When we speak of free software, we are referring to freedom, not
|
||||
price. Our General Public Licenses are designed to make sure that you
|
||||
have the freedom to distribute copies of free software (and charge for
|
||||
this service if you wish), that you receive source code or can get it
|
||||
if you want it, that you can change the software or use pieces of it
|
||||
in new free programs; and that you know you can do these things.
|
||||
|
||||
To protect your rights, we need to make restrictions that forbid
|
||||
anyone to deny you these rights or to ask you to surrender the rights.
|
||||
These restrictions translate to certain responsibilities for you if you
|
||||
distribute copies of the software, or if you modify it.
|
||||
|
||||
For example, if you distribute copies of such a program, whether
|
||||
gratis or for a fee, you must give the recipients all the rights that
|
||||
you have. You must make sure that they, too, receive or can get the
|
||||
source code. And you must show them these terms so they know their
|
||||
rights.
|
||||
|
||||
We protect your rights with two steps: (1) copyright the software, and
|
||||
(2) offer you this license which gives you legal permission to copy,
|
||||
distribute and/or modify the software.
|
||||
|
||||
Also, for each author's protection and ours, we want to make certain
|
||||
that everyone understands that there is no warranty for this free
|
||||
software. If the software is modified by someone else and passed on, we
|
||||
want its recipients to know that what they have is not the original, so
|
||||
that any problems introduced by others will not reflect on the original
|
||||
authors' reputations.
|
||||
|
||||
Finally, any free program is threatened constantly by software
|
||||
patents. We wish to avoid the danger that redistributors of a free
|
||||
program will individually obtain patent licenses, in effect making the
|
||||
program proprietary. To prevent this, we have made it clear that any
|
||||
patent must be licensed for everyone's free use or not licensed at all.
|
||||
|
||||
The precise terms and conditions for copying, distribution and
|
||||
modification follow.
|
||||
|
||||
GNU GENERAL PUBLIC LICENSE
|
||||
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
||||
|
||||
0. This License applies to any program or other work which contains
|
||||
a notice placed by the copyright holder saying it may be distributed
|
||||
under the terms of this General Public License. The "Program", below,
|
||||
refers to any such program or work, and a "work based on the Program"
|
||||
means either the Program or any derivative work under copyright law:
|
||||
that is to say, a work containing the Program or a portion of it,
|
||||
either verbatim or with modifications and/or translated into another
|
||||
language. (Hereinafter, translation is included without limitation in
|
||||
the term "modification".) Each licensee is addressed as "you".
|
||||
|
||||
Activities other than copying, distribution and modification are not
|
||||
covered by this License; they are outside its scope. The act of
|
||||
running the Program is not restricted, and the output from the Program
|
||||
is covered only if its contents constitute a work based on the
|
||||
Program (independent of having been made by running the Program).
|
||||
Whether that is true depends on what the Program does.
|
||||
|
||||
1. You may copy and distribute verbatim copies of the Program's
|
||||
source code as you receive it, in any medium, provided that you
|
||||
conspicuously and appropriately publish on each copy an appropriate
|
||||
copyright notice and disclaimer of warranty; keep intact all the
|
||||
notices that refer to this License and to the absence of any warranty;
|
||||
and give any other recipients of the Program a copy of this License
|
||||
along with the Program.
|
||||
|
||||
You may charge a fee for the physical act of transferring a copy, and
|
||||
you may at your option offer warranty protection in exchange for a fee.
|
||||
|
||||
2. You may modify your copy or copies of the Program or any portion
|
||||
of it, thus forming a work based on the Program, and copy and
|
||||
distribute such modifications or work under the terms of Section 1
|
||||
above, provided that you also meet all of these conditions:
|
||||
|
||||
a) You must cause the modified files to carry prominent notices
|
||||
stating that you changed the files and the date of any change.
|
||||
|
||||
b) You must cause any work that you distribute or publish, that in
|
||||
whole or in part contains or is derived from the Program or any
|
||||
part thereof, to be licensed as a whole at no charge to all third
|
||||
parties under the terms of this License.
|
||||
|
||||
c) If the modified program normally reads commands interactively
|
||||
when run, you must cause it, when started running for such
|
||||
interactive use in the most ordinary way, to print or display an
|
||||
announcement including an appropriate copyright notice and a
|
||||
notice that there is no warranty (or else, saying that you provide
|
||||
a warranty) and that users may redistribute the program under
|
||||
these conditions, and telling the user how to view a copy of this
|
||||
License. (Exception: if the Program itself is interactive but
|
||||
does not normally print such an announcement, your work based on
|
||||
the Program is not required to print an announcement.)
|
||||
|
||||
These requirements apply to the modified work as a whole. If
|
||||
identifiable sections of that work are not derived from the Program,
|
||||
and can be reasonably considered independent and separate works in
|
||||
themselves, then this License, and its terms, do not apply to those
|
||||
sections when you distribute them as separate works. But when you
|
||||
distribute the same sections as part of a whole which is a work based
|
||||
on the Program, the distribution of the whole must be on the terms of
|
||||
this License, whose permissions for other licensees extend to the
|
||||
entire whole, and thus to each and every part regardless of who wrote it.
|
||||
|
||||
Thus, it is not the intent of this section to claim rights or contest
|
||||
your rights to work written entirely by you; rather, the intent is to
|
||||
exercise the right to control the distribution of derivative or
|
||||
collective works based on the Program.
|
||||
|
||||
In addition, mere aggregation of another work not based on the Program
|
||||
with the Program (or with a work based on the Program) on a volume of
|
||||
a storage or distribution medium does not bring the other work under
|
||||
the scope of this License.
|
||||
|
||||
3. You may copy and distribute the Program (or a work based on it,
|
||||
under Section 2) in object code or executable form under the terms of
|
||||
Sections 1 and 2 above provided that you also do one of the following:
|
||||
|
||||
a) Accompany it with the complete corresponding machine-readable
|
||||
source code, which must be distributed under the terms of Sections
|
||||
1 and 2 above on a medium customarily used for software interchange; or,
|
||||
|
||||
b) Accompany it with a written offer, valid for at least three
|
||||
years, to give any third party, for a charge no more than your
|
||||
cost of physically performing source distribution, a complete
|
||||
machine-readable copy of the corresponding source code, to be
|
||||
distributed under the terms of Sections 1 and 2 above on a medium
|
||||
customarily used for software interchange; or,
|
||||
|
||||
c) Accompany it with the information you received as to the offer
|
||||
to distribute corresponding source code. (This alternative is
|
||||
allowed only for noncommercial distribution and only if you
|
||||
received the program in object code or executable form with such
|
||||
an offer, in accord with Subsection b above.)
|
||||
|
||||
The source code for a work means the preferred form of the work for
|
||||
making modifications to it. For an executable work, complete source
|
||||
code means all the source code for all modules it contains, plus any
|
||||
associated interface definition files, plus the scripts used to
|
||||
control compilation and installation of the executable. However, as a
|
||||
special exception, the source code distributed need not include
|
||||
anything that is normally distributed (in either source or binary
|
||||
form) with the major components (compiler, kernel, and so on) of the
|
||||
operating system on which the executable runs, unless that component
|
||||
itself accompanies the executable.
|
||||
|
||||
If distribution of executable or object code is made by offering
|
||||
access to copy from a designated place, then offering equivalent
|
||||
access to copy the source code from the same place counts as
|
||||
distribution of the source code, even though third parties are not
|
||||
compelled to copy the source along with the object code.
|
||||
|
||||
4. You may not copy, modify, sublicense, or distribute the Program
|
||||
except as expressly provided under this License. Any attempt
|
||||
otherwise to copy, modify, sublicense or distribute the Program is
|
||||
void, and will automatically terminate your rights under this License.
|
||||
However, parties who have received copies, or rights, from you under
|
||||
this License will not have their licenses terminated so long as such
|
||||
parties remain in full compliance.
|
||||
|
||||
5. You are not required to accept this License, since you have not
|
||||
signed it. However, nothing else grants you permission to modify or
|
||||
distribute the Program or its derivative works. These actions are
|
||||
prohibited by law if you do not accept this License. Therefore, by
|
||||
modifying or distributing the Program (or any work based on the
|
||||
Program), you indicate your acceptance of this License to do so, and
|
||||
all its terms and conditions for copying, distributing or modifying
|
||||
the Program or works based on it.
|
||||
|
||||
6. Each time you redistribute the Program (or any work based on the
|
||||
Program), the recipient automatically receives a license from the
|
||||
original licensor to copy, distribute or modify the Program subject to
|
||||
these terms and conditions. You may not impose any further
|
||||
restrictions on the recipients' exercise of the rights granted herein.
|
||||
You are not responsible for enforcing compliance by third parties to
|
||||
this License.
|
||||
|
||||
7. If, as a consequence of a court judgment or allegation of patent
|
||||
infringement or for any other reason (not limited to patent issues),
|
||||
conditions are imposed on you (whether by court order, agreement or
|
||||
otherwise) that contradict the conditions of this License, they do not
|
||||
excuse you from the conditions of this License. If you cannot
|
||||
distribute so as to satisfy simultaneously your obligations under this
|
||||
License and any other pertinent obligations, then as a consequence you
|
||||
may not distribute the Program at all. For example, if a patent
|
||||
license would not permit royalty-free redistribution of the Program by
|
||||
all those who receive copies directly or indirectly through you, then
|
||||
the only way you could satisfy both it and this License would be to
|
||||
refrain entirely from distribution of the Program.
|
||||
|
||||
If any portion of this section is held invalid or unenforceable under
|
||||
any particular circumstance, the balance of the section is intended to
|
||||
apply and the section as a whole is intended to apply in other
|
||||
circumstances.
|
||||
|
||||
It is not the purpose of this section to induce you to infringe any
|
||||
patents or other property right claims or to contest validity of any
|
||||
such claims; this section has the sole purpose of protecting the
|
||||
integrity of the free software distribution system, which is
|
||||
implemented by public license practices. Many people have made
|
||||
generous contributions to the wide range of software distributed
|
||||
through that system in reliance on consistent application of that
|
||||
system; it is up to the author/donor to decide if he or she is willing
|
||||
to distribute software through any other system and a licensee cannot
|
||||
impose that choice.
|
||||
|
||||
This section is intended to make thoroughly clear what is believed to
|
||||
be a consequence of the rest of this License.
|
||||
|
||||
8. If the distribution and/or use of the Program is restricted in
|
||||
certain countries either by patents or by copyrighted interfaces, the
|
||||
original copyright holder who places the Program under this License
|
||||
may add an explicit geographical distribution limitation excluding
|
||||
those countries, so that distribution is permitted only in or among
|
||||
countries not thus excluded. In such case, this License incorporates
|
||||
the limitation as if written in the body of this License.
|
||||
|
||||
9. The Free Software Foundation may publish revised and/or new versions
|
||||
of the General Public License from time to time. Such new versions will
|
||||
be similar in spirit to the present version, but may differ in detail to
|
||||
address new problems or concerns.
|
||||
|
||||
Each version is given a distinguishing version number. If the Program
|
||||
specifies a version number of this License which applies to it and "any
|
||||
later version", you have the option of following the terms and conditions
|
||||
either of that version or of any later version published by the Free
|
||||
Software Foundation. If the Program does not specify a version number of
|
||||
this License, you may choose any version ever published by the Free Software
|
||||
Foundation.
|
||||
|
||||
10. If you wish to incorporate parts of the Program into other free
|
||||
programs whose distribution conditions are different, write to the author
|
||||
to ask for permission. For software which is copyrighted by the Free
|
||||
Software Foundation, write to the Free Software Foundation; we sometimes
|
||||
make exceptions for this. Our decision will be guided by the two goals
|
||||
of preserving the free status of all derivatives of our free software and
|
||||
of promoting the sharing and reuse of software generally.
|
||||
|
||||
NO WARRANTY
|
||||
|
||||
11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
|
||||
FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
|
||||
OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
|
||||
PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
|
||||
OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
|
||||
TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
|
||||
PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
|
||||
REPAIR OR CORRECTION.
|
||||
|
||||
12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
|
||||
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
|
||||
REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
|
||||
INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
|
||||
OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
|
||||
TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
|
||||
YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
|
||||
PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
|
||||
POSSIBILITY OF SUCH DAMAGES.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
||||
|
||||
How to Apply These Terms to Your New Programs
|
||||
|
||||
If you develop a new program, and you want it to be of the greatest
|
||||
possible use to the public, the best way to achieve this is to make it
|
||||
free software which everyone can redistribute and change under these terms.
|
||||
|
||||
To do so, attach the following notices to the program. It is safest
|
||||
to attach them to the start of each source file to most effectively
|
||||
convey the exclusion of warranty; and each file should have at least
|
||||
the "copyright" line and a pointer to where the full notice is found.
|
||||
|
||||
<one line to give the program's name and a brief idea of what it does.>
|
||||
Copyright (C) <year> <name of author>
|
||||
|
||||
This program is free software; you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
the Free Software Foundation; either version 2 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License along
|
||||
with this program; if not, write to the Free Software Foundation, Inc.,
|
||||
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||
|
||||
Also add information on how to contact you by electronic and paper mail.
|
||||
|
||||
If the program is interactive, make it output a short notice like this
|
||||
when it starts in an interactive mode:
|
||||
|
||||
Gnomovision version 69, Copyright (C) year name of author
|
||||
Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
|
||||
This is free software, and you are welcome to redistribute it
|
||||
under certain conditions; type `show c' for details.
|
||||
|
||||
The hypothetical commands `show w' and `show c' should show the appropriate
|
||||
parts of the General Public License. Of course, the commands you use may
|
||||
be called something other than `show w' and `show c'; they could even be
|
||||
mouse-clicks or menu items--whatever suits your program.
|
||||
|
||||
You should also get your employer (if you work as a programmer) or your
|
||||
school, if any, to sign a "copyright disclaimer" for the program, if
|
||||
necessary. Here is a sample; alter the names:
|
||||
|
||||
Yoyodyne, Inc., hereby disclaims all copyright interest in the program
|
||||
`Gnomovision' (which makes passes at compilers) written by James Hacker.
|
||||
|
||||
<signature of Ty Coon>, 1 April 1989
|
||||
Ty Coon, President of Vice
|
||||
|
||||
This General Public License does not permit incorporating your program into
|
||||
proprietary programs. If your program is a subroutine library, you may
|
||||
consider it more useful to permit linking proprietary applications with the
|
||||
library. If this is what you want to do, use the GNU Lesser General
|
||||
Public License instead of this License.
|
@ -1,67 +0,0 @@
|
||||
/*
|
||||
** IE5.0 Fix Stylesheet
|
||||
*/
|
||||
|
||||
#column-content {
|
||||
margin: 0 !important;
|
||||
float: none;
|
||||
}
|
||||
#column-content #content {
|
||||
margin-top: 3em;
|
||||
height: 1%;
|
||||
}
|
||||
#column-one {
|
||||
position: absolute;
|
||||
overflow: visible;
|
||||
top: 0;
|
||||
left: 0;
|
||||
z-index: 3;
|
||||
}
|
||||
#footer {
|
||||
margin: 0 0 0 13.6em;
|
||||
}
|
||||
|
||||
/* IE 5 & 5.5 interpret keyword sizes one off */
|
||||
body { font-size: xx-small; }
|
||||
/*
|
||||
** the edit tabs
|
||||
*/
|
||||
#p-cactions li {
|
||||
float: left;
|
||||
padding-top: 0;
|
||||
padding-bottom: 0 !important;
|
||||
height: 0.9em;
|
||||
}
|
||||
#p-cactions li a {
|
||||
display: block;
|
||||
padding-bottom: 0.045em;
|
||||
}
|
||||
#p-cactions li.selected a {
|
||||
padding-bottom: 0.17em;
|
||||
}
|
||||
#p-cactions li a:hover {
|
||||
padding-bottom: 0.17em;
|
||||
}
|
||||
/* 5.0 doesn't like the background icon for external links and user */
|
||||
.link-external,
|
||||
.external {
|
||||
background: none;
|
||||
padding: 0;
|
||||
}
|
||||
#p-personal ul { float: right }
|
||||
#p-personal li { float: left }
|
||||
li#pt-userpage,
|
||||
li#pt-anonuserpage,
|
||||
li#pt-login,
|
||||
li#pt-logout {
|
||||
background: none;
|
||||
padding-left: none;
|
||||
}
|
||||
.visualClear {
|
||||
width: 100%;
|
||||
height: 0px;
|
||||
padding:0;
|
||||
margin: 0;
|
||||
}
|
||||
.firstHeading { margin-bottom: .3em; }
|
||||
/*div{ border:1px solid Red !important;}*/
|
@ -1,88 +0,0 @@
|
||||
/* IE5.5/win- only fixes */
|
||||
|
||||
#column-content {
|
||||
float: none;
|
||||
margin-left: 0;
|
||||
height: 1%;
|
||||
}
|
||||
#column-content #content {
|
||||
position: relative;
|
||||
z-index: 5;
|
||||
margin-left: 12.2em;
|
||||
margin-top: 3em;
|
||||
height: 1%;
|
||||
}
|
||||
#column-one {
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
z-index: 4;
|
||||
width: 100%;
|
||||
}
|
||||
#footer {
|
||||
margin-left: 13.6em;
|
||||
border-left: 1px solid #fabd23;
|
||||
}
|
||||
|
||||
/*#bodyContent div,
|
||||
#bodyContent pre { overflow: auto; }*/
|
||||
|
||||
#p-personal { padding-bottom: .1em; }
|
||||
|
||||
body { font-size: xx-small; }
|
||||
|
||||
/* WERELATE
|
||||
#p-cactions {
|
||||
width: 76% !important;
|
||||
z-index: 3 !important;
|
||||
float: none;
|
||||
}
|
||||
#p-cactions li {
|
||||
padding-bottom: 0 !important;
|
||||
border: none;
|
||||
background-color: transparent;
|
||||
cursor: default;
|
||||
float: none !important;
|
||||
}
|
||||
#p-cactions li a {
|
||||
display: inline-block !important;
|
||||
vertical-align: top;
|
||||
padding-bottom: 0;
|
||||
border: solid #aaa;
|
||||
border-width: 1px 1px 0;
|
||||
}
|
||||
#p-cactions li.selected a {
|
||||
border-color: #fabd23;
|
||||
padding-bottom: 0.17em;
|
||||
}
|
||||
#p-cactions li a:hover {
|
||||
padding-bottom: 0.17em;
|
||||
}
|
||||
*/
|
||||
|
||||
#p-navigation a {
|
||||
display: inline-block;
|
||||
width: 100%;
|
||||
}
|
||||
.portlet {
|
||||
overflow: hidden;
|
||||
}
|
||||
#bodyContent a.external {
|
||||
background: url(external.png) center right no-repeat;
|
||||
padding-right: 13px;
|
||||
}
|
||||
/* show the hand */
|
||||
#p-logo a,
|
||||
#p-logo a:hover {
|
||||
cursor: pointer;
|
||||
}
|
||||
.visualClear {
|
||||
width: 90%;
|
||||
height: 1px;
|
||||
padding: 0;
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
#editform {
|
||||
width: 100%;
|
||||
}
|
@ -1,125 +0,0 @@
|
||||
/* 6.0 - only fixes */
|
||||
/* content area */
|
||||
/* workaround for various ie float bugs */
|
||||
div#column-content {
|
||||
float: none;
|
||||
margin-left: 0;
|
||||
height: 1%;
|
||||
}
|
||||
|
||||
div#column-content .mw-body {
|
||||
margin-left: 12.2em;
|
||||
margin-top: 3em;
|
||||
height: 1%;
|
||||
}
|
||||
|
||||
.rtl div#column-content .mw-body {
|
||||
margin-right: 12.2em;
|
||||
margin-left: 0;
|
||||
}
|
||||
|
||||
div#column-one {
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
z-index: 4;
|
||||
}
|
||||
|
||||
.rtl div#column-one {
|
||||
left: auto;
|
||||
right: 0;
|
||||
}
|
||||
|
||||
div#footer {
|
||||
margin-left: 13.6em;
|
||||
border-left: 1px solid #fabd23;
|
||||
}
|
||||
|
||||
.rtl div#footer {
|
||||
margin-left: 0;
|
||||
margin-right: 13.6em;
|
||||
border-left: none;
|
||||
border-right: 1px solid #fabd23;
|
||||
}
|
||||
|
||||
/* float/negative margin brokenness */
|
||||
* html div#footer {
|
||||
margin-top: 0;
|
||||
}
|
||||
|
||||
* html div#column-content {
|
||||
display: inline;
|
||||
margin-bottom: 0;
|
||||
}
|
||||
|
||||
/* the tabs */
|
||||
|
||||
#p-cactions {
|
||||
z-index: 3;
|
||||
}
|
||||
|
||||
#p-cactions li {
|
||||
padding-bottom: 0 !important;
|
||||
border: none;
|
||||
background-color: transparent;
|
||||
cursor: default;
|
||||
float: none !important;
|
||||
}
|
||||
|
||||
#p-cactions li a {
|
||||
display: inline-block !important;
|
||||
vertical-align: top;
|
||||
padding-bottom: 0;
|
||||
border: solid #aaa;
|
||||
border-width: 1px 1px 0;
|
||||
}
|
||||
|
||||
#p-cactions li.selected a {
|
||||
border-color: #fabd23;
|
||||
padding-bottom: 0.17em;
|
||||
}
|
||||
|
||||
#p-cactions li a:hover {
|
||||
padding-bottom: 0.17em;
|
||||
}
|
||||
|
||||
#p-navigation a {
|
||||
display: inline-block;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
#portal-personaltools {
|
||||
padding-bottom: 0.1em;
|
||||
}
|
||||
|
||||
.rtl a.feedlink {
|
||||
background-position: right;
|
||||
padding-right: 0;
|
||||
padding-left: 16px;
|
||||
}
|
||||
|
||||
/* show the hand */
|
||||
#p-logo a,
|
||||
#p-logo a:hover {
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
div.visualClear {
|
||||
width: 100%;
|
||||
line-height: 0;
|
||||
}
|
||||
|
||||
textarea {
|
||||
width: 96%;
|
||||
}
|
||||
|
||||
#catlinks,
|
||||
div.tright,
|
||||
div.tleft {
|
||||
position: relative;
|
||||
}
|
||||
|
||||
/* bug 12846 */
|
||||
body.rtl #preftoc a, body.rtl #preftoc a:active {
|
||||
float: left;
|
||||
}
|
@ -1,96 +0,0 @@
|
||||
/* 7.0 - only fixes */
|
||||
/* content area */
|
||||
/* workaround for various ie float bugs */
|
||||
|
||||
/* This bit is needed to make links clickable... WTF */
|
||||
div#column-content .mw-body {
|
||||
margin-left: 12.2em;
|
||||
margin-top: 3em;
|
||||
height: 1%;
|
||||
}
|
||||
|
||||
.rtl div#column-content .mw-body {
|
||||
margin-right: 12.2em;
|
||||
margin-left: 0;
|
||||
}
|
||||
|
||||
.rtl div#column-one {
|
||||
/* For some reason it tries to inherit the padding-top into every div,
|
||||
* and I can't figure out how to get it back off.
|
||||
* Margin works correctly for this use, though.
|
||||
*/
|
||||
padding-top: 0;
|
||||
margin-top: 160px;
|
||||
}
|
||||
|
||||
/* These elements also have padding-left: 20px; in main.css, but in RTL mode this is flipped.
|
||||
* That's good in normal browsers, but in IE7 it needs to not be flipped for some daft reason.
|
||||
* Also clear the right margin (originally margin-left: 1em)
|
||||
*/
|
||||
li#pt-userpage, li#pt-anonuserpage, li#pt-login {
|
||||
padding-left: 20px;
|
||||
margin-right: 0;
|
||||
}
|
||||
|
||||
.rtl a.feedlink {
|
||||
background-position: right;
|
||||
padding-right: 0;
|
||||
padding-left: 16px;
|
||||
}
|
||||
|
||||
/* the tabs */
|
||||
|
||||
#p-cactions {
|
||||
z-index: 3;
|
||||
}
|
||||
|
||||
#p-cactions li {
|
||||
padding-bottom: 0 !important;
|
||||
border: none;
|
||||
background-color: transparent;
|
||||
cursor: default;
|
||||
float: none !important;
|
||||
}
|
||||
|
||||
#p-cactions li a {
|
||||
display: inline-block !important;
|
||||
vertical-align: top;
|
||||
padding-bottom: 0;
|
||||
border: solid #aaa;
|
||||
border-width: 1px 1px 0;
|
||||
}
|
||||
|
||||
#p-cactions li.selected a {
|
||||
border-color: #fabd23;
|
||||
padding-bottom: 0.17em;
|
||||
}
|
||||
|
||||
#p-cactions li a:hover {
|
||||
padding-bottom: 0.17em;
|
||||
}
|
||||
|
||||
#p-navigation a {
|
||||
display: inline-block;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
#portal-personaltools {
|
||||
padding-bottom: 0.1em;
|
||||
}
|
||||
|
||||
textarea {
|
||||
width: 96%;
|
||||
}
|
||||
|
||||
/*
|
||||
#catlinks,
|
||||
div.tright,
|
||||
div.tleft {
|
||||
position: relative;
|
||||
}
|
||||
*/
|
||||
|
||||
div#footer li {
|
||||
/* Work around bug with inline <li> tags with right margins and nowrap */
|
||||
margin-right: 0;
|
||||
}
|
@ -1,18 +0,0 @@
|
||||
<footer id="contentinfo" class="body">
|
||||
<hr />
|
||||
<p style="text-align: center">
|
||||
<span class="fa-stack fa-lg">
|
||||
<i class="fa fa-square fa-stack-2x"></i>
|
||||
<i class="fa fa-terminal fa-stack-1x fa-inverse"></i>
|
||||
</span>
|
||||
Made from the command line with vim by
|
||||
<a href="http://charlesreid1.com">charlesreid1</a><br />
|
||||
with help from <a href="http://d3js.org">D3.js</a>, <a href="http://angularjs.org">Angular.js</a>, and <a href="http://getpelican.com">Pelican</a>.
|
||||
</p>
|
||||
|
||||
<script type="text/javascript" src="{{ SITEURL }}/theme/js/jquery-1.11.2.js"></script>
|
||||
<script type="text/javascript" src="{{ SITEURL }}/theme/js/jquery_load_template-1.4.5.min.js"></script>
|
||||
<script type="text/javascript" src="{{ SITEURL }}/theme/js/bootstrap-3.3.4.js"></script>
|
||||
|
||||
</footer><!-- /#contentinfo -->
|
||||
|
@ -1,90 +0,0 @@
|
||||
/* ==========================================================
|
||||
* bootstrap-alert.js v2.0.4
|
||||
* http://twitter.github.com/bootstrap/javascript.html#alerts
|
||||
* ==========================================================
|
||||
* Copyright 2012 Twitter, Inc.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
* ========================================================== */
|
||||
|
||||
|
||||
!function ($) {
|
||||
|
||||
"use strict"; // jshint ;_;
|
||||
|
||||
|
||||
/* ALERT CLASS DEFINITION
|
||||
* ====================== */
|
||||
|
||||
var dismiss = '[data-dismiss="alert"]'
|
||||
, Alert = function (el) {
|
||||
$(el).on('click', dismiss, this.close)
|
||||
}
|
||||
|
||||
Alert.prototype.close = function (e) {
|
||||
var $this = $(this)
|
||||
, selector = $this.attr('data-target')
|
||||
, $parent
|
||||
|
||||
if (!selector) {
|
||||
selector = $this.attr('href')
|
||||
selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
|
||||
}
|
||||
|
||||
$parent = $(selector)
|
||||
|
||||
e && e.preventDefault()
|
||||
|
||||
$parent.length || ($parent = $this.hasClass('alert') ? $this : $this.parent())
|
||||
|
||||
$parent.trigger(e = $.Event('close'))
|
||||
|
||||
if (e.isDefaultPrevented()) return
|
||||
|
||||
$parent.removeClass('in')
|
||||
|
||||
function removeElement() {
|
||||
$parent
|
||||
.trigger('closed')
|
||||
.remove()
|
||||
}
|
||||
|
||||
$.support.transition && $parent.hasClass('fade') ?
|
||||
$parent.on($.support.transition.end, removeElement) :
|
||||
removeElement()
|
||||
}
|
||||
|
||||
|
||||
/* ALERT PLUGIN DEFINITION
|
||||
* ======================= */
|
||||
|
||||
$.fn.alert = function (option) {
|
||||
return this.each(function () {
|
||||
var $this = $(this)
|
||||
, data = $this.data('alert')
|
||||
if (!data) $this.data('alert', (data = new Alert(this)))
|
||||
if (typeof option == 'string') data[option].call($this)
|
||||
})
|
||||
}
|
||||
|
||||
$.fn.alert.Constructor = Alert
|
||||
|
||||
|
||||
/* ALERT DATA-API
|
||||
* ============== */
|
||||
|
||||
$(function () {
|
||||
$('body').on('click.alert.data-api', dismiss, Alert.prototype.close)
|
||||
})
|
||||
|
||||
}(window.jQuery);
|
@ -1,96 +0,0 @@
|
||||
/* ============================================================
|
||||
* bootstrap-button.js v2.0.4
|
||||
* http://twitter.github.com/bootstrap/javascript.html#buttons
|
||||
* ============================================================
|
||||
* Copyright 2012 Twitter, Inc.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
* ============================================================ */
|
||||
|
||||
|
||||
!function ($) {
|
||||
|
||||
"use strict"; // jshint ;_;
|
||||
|
||||
|
||||
/* BUTTON PUBLIC CLASS DEFINITION
|
||||
* ============================== */
|
||||
|
||||
var Button = function (element, options) {
|
||||
this.$element = $(element)
|
||||
this.options = $.extend({}, $.fn.button.defaults, options)
|
||||
}
|
||||
|
||||
Button.prototype.setState = function (state) {
|
||||
var d = 'disabled'
|
||||
, $el = this.$element
|
||||
, data = $el.data()
|
||||
, val = $el.is('input') ? 'val' : 'html'
|
||||
|
||||
state = state + 'Text'
|
||||
data.resetText || $el.data('resetText', $el[val]())
|
||||
|
||||
$el[val](data[state] || this.options[state])
|
||||
|
||||
// push to event loop to allow forms to submit
|
||||
setTimeout(function () {
|
||||
state == 'loadingText' ?
|
||||
$el.addClass(d).attr(d, d) :
|
||||
$el.removeClass(d).removeAttr(d)
|
||||
}, 0)
|
||||
}
|
||||
|
||||
Button.prototype.toggle = function () {
|
||||
var $parent = this.$element.parent('[data-toggle="buttons-radio"]')
|
||||
|
||||
$parent && $parent
|
||||
.find('.active')
|
||||
.removeClass('active')
|
||||
|
||||
this.$element.toggleClass('active')
|
||||
}
|
||||
|
||||
|
||||
/* BUTTON PLUGIN DEFINITION
|
||||
* ======================== */
|
||||
|
||||
$.fn.button = function (option) {
|
||||
return this.each(function () {
|
||||
var $this = $(this)
|
||||
, data = $this.data('button')
|
||||
, options = typeof option == 'object' && option
|
||||
if (!data) $this.data('button', (data = new Button(this, options)))
|
||||
if (option == 'toggle') data.toggle()
|
||||
else if (option) data.setState(option)
|
||||
})
|
||||
}
|
||||
|
||||
$.fn.button.defaults = {
|
||||
loadingText: 'loading...'
|
||||
}
|
||||
|
||||
$.fn.button.Constructor = Button
|
||||
|
||||
|
||||
/* BUTTON DATA-API
|
||||
* =============== */
|
||||
|
||||
$(function () {
|
||||
$('body').on('click.button.data-api', '[data-toggle^=button]', function ( e ) {
|
||||
var $btn = $(e.target)
|
||||
if (!$btn.hasClass('btn')) $btn = $btn.closest('.btn')
|
||||
$btn.button('toggle')
|
||||
})
|
||||
})
|
||||
|
||||
}(window.jQuery);
|
@ -1,169 +0,0 @@
|
||||
/* ==========================================================
|
||||
* bootstrap-carousel.js v2.0.4
|
||||
* http://twitter.github.com/bootstrap/javascript.html#carousel
|
||||
* ==========================================================
|
||||
* Copyright 2012 Twitter, Inc.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
* ========================================================== */
|
||||
|
||||
|
||||
!function ($) {
|
||||
|
||||
"use strict"; // jshint ;_;
|
||||
|
||||
|
||||
/* CAROUSEL CLASS DEFINITION
|
||||
* ========================= */
|
||||
|
||||
var Carousel = function (element, options) {
|
||||
this.$element = $(element)
|
||||
this.options = options
|
||||
this.options.slide && this.slide(this.options.slide)
|
||||
this.options.pause == 'hover' && this.$element
|
||||
.on('mouseenter', $.proxy(this.pause, this))
|
||||
.on('mouseleave', $.proxy(this.cycle, this))
|
||||
}
|
||||
|
||||
Carousel.prototype = {
|
||||
|
||||
cycle: function (e) {
|
||||
if (!e) this.paused = false
|
||||
this.options.interval
|
||||
&& !this.paused
|
||||
&& (this.interval = setInterval($.proxy(this.next, this), this.options.interval))
|
||||
return this
|
||||
}
|
||||
|
||||
, to: function (pos) {
|
||||
var $active = this.$element.find('.active')
|
||||
, children = $active.parent().children()
|
||||
, activePos = children.index($active)
|
||||
, that = this
|
||||
|
||||
if (pos > (children.length - 1) || pos < 0) return
|
||||
|
||||
if (this.sliding) {
|
||||
return this.$element.one('slid', function () {
|
||||
that.to(pos)
|
||||
})
|
||||
}
|
||||
|
||||
if (activePos == pos) {
|
||||
return this.pause().cycle()
|
||||
}
|
||||
|
||||
return this.slide(pos > activePos ? 'next' : 'prev', $(children[pos]))
|
||||
}
|
||||
|
||||
, pause: function (e) {
|
||||
if (!e) this.paused = true
|
||||
clearInterval(this.interval)
|
||||
this.interval = null
|
||||
return this
|
||||
}
|
||||
|
||||
, next: function () {
|
||||
if (this.sliding) return
|
||||
return this.slide('next')
|
||||
}
|
||||
|
||||
, prev: function () {
|
||||
if (this.sliding) return
|
||||
return this.slide('prev')
|
||||
}
|
||||
|
||||
, slide: function (type, next) {
|
||||
var $active = this.$element.find('.active')
|
||||
, $next = next || $active[type]()
|
||||
, isCycling = this.interval
|
||||
, direction = type == 'next' ? 'left' : 'right'
|
||||
, fallback = type == 'next' ? 'first' : 'last'
|
||||
, that = this
|
||||
, e = $.Event('slide')
|
||||
|
||||
this.sliding = true
|
||||
|
||||
isCycling && this.pause()
|
||||
|
||||
$next = $next.length ? $next : this.$element.find('.item')[fallback]()
|
||||
|
||||
if ($next.hasClass('active')) return
|
||||
|
||||
if ($.support.transition && this.$element.hasClass('slide')) {
|
||||
this.$element.trigger(e)
|
||||
if (e.isDefaultPrevented()) return
|
||||
$next.addClass(type)
|
||||
$next[0].offsetWidth // force reflow
|
||||
$active.addClass(direction)
|
||||
$next.addClass(direction)
|
||||
this.$element.one($.support.transition.end, function () {
|
||||
$next.removeClass([type, direction].join(' ')).addClass('active')
|
||||
$active.removeClass(['active', direction].join(' '))
|
||||
that.sliding = false
|
||||
setTimeout(function () { that.$element.trigger('slid') }, 0)
|
||||
})
|
||||
} else {
|
||||
this.$element.trigger(e)
|
||||
if (e.isDefaultPrevented()) return
|
||||
$active.removeClass('active')
|
||||
$next.addClass('active')
|
||||
this.sliding = false
|
||||
this.$element.trigger('slid')
|
||||
}
|
||||
|
||||
isCycling && this.cycle()
|
||||
|
||||
return this
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
/* CAROUSEL PLUGIN DEFINITION
|
||||
* ========================== */
|
||||
|
||||
$.fn.carousel = function (option) {
|
||||
return this.each(function () {
|
||||
var $this = $(this)
|
||||
, data = $this.data('carousel')
|
||||
, options = $.extend({}, $.fn.carousel.defaults, typeof option == 'object' && option)
|
||||
if (!data) $this.data('carousel', (data = new Carousel(this, options)))
|
||||
if (typeof option == 'number') data.to(option)
|
||||
else if (typeof option == 'string' || (option = options.slide)) data[option]()
|
||||
else if (options.interval) data.cycle()
|
||||
})
|
||||
}
|
||||
|
||||
$.fn.carousel.defaults = {
|
||||
interval: 5000
|
||||
, pause: 'hover'
|
||||
}
|
||||
|
||||
$.fn.carousel.Constructor = Carousel
|
||||
|
||||
|
||||
/* CAROUSEL DATA-API
|
||||
* ================= */
|
||||
|
||||
$(function () {
|
||||
$('body').on('click.carousel.data-api', '[data-slide]', function ( e ) {
|
||||
var $this = $(this), href
|
||||
, $target = $($this.attr('data-target') || (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
|
||||
, options = !$target.data('modal') && $.extend({}, $target.data(), $this.data())
|
||||
$target.carousel(options)
|
||||
e.preventDefault()
|
||||
})
|
||||
})
|
||||
|
||||
}(window.jQuery);
|
@ -1,157 +0,0 @@
|
||||
/* =============================================================
|
||||
* bootstrap-collapse.js v2.0.4
|
||||
* http://twitter.github.com/bootstrap/javascript.html#collapse
|
||||
* =============================================================
|
||||
* Copyright 2012 Twitter, Inc.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
* ============================================================ */
|
||||
|
||||
|
||||
!function ($) {
|
||||
|
||||
"use strict"; // jshint ;_;
|
||||
|
||||
|
||||
/* COLLAPSE PUBLIC CLASS DEFINITION
|
||||
* ================================ */
|
||||
|
||||
var Collapse = function (element, options) {
|
||||
this.$element = $(element)
|
||||
this.options = $.extend({}, $.fn.collapse.defaults, options)
|
||||
|
||||
if (this.options.parent) {
|
||||
this.$parent = $(this.options.parent)
|
||||
}
|
||||
|
||||
this.options.toggle && this.toggle()
|
||||
}
|
||||
|
||||
Collapse.prototype = {
|
||||
|
||||
constructor: Collapse
|
||||
|
||||
, dimension: function () {
|
||||
var hasWidth = this.$element.hasClass('width')
|
||||
return hasWidth ? 'width' : 'height'
|
||||
}
|
||||
|
||||
, show: function () {
|
||||
var dimension
|
||||
, scroll
|
||||
, actives
|
||||
, hasData
|
||||
|
||||
if (this.transitioning) return
|
||||
|
||||
dimension = this.dimension()
|
||||
scroll = $.camelCase(['scroll', dimension].join('-'))
|
||||
actives = this.$parent && this.$parent.find('> .accordion-group > .in')
|
||||
|
||||
if (actives && actives.length) {
|
||||
hasData = actives.data('collapse')
|
||||
if (hasData && hasData.transitioning) return
|
||||
actives.collapse('hide')
|
||||
hasData || actives.data('collapse', null)
|
||||
}
|
||||
|
||||
this.$element[dimension](0)
|
||||
this.transition('addClass', $.Event('show'), 'shown')
|
||||
this.$element[dimension](this.$element[0][scroll])
|
||||
}
|
||||
|
||||
, hide: function () {
|
||||
var dimension
|
||||
if (this.transitioning) return
|
||||
dimension = this.dimension()
|
||||
this.reset(this.$element[dimension]())
|
||||
this.transition('removeClass', $.Event('hide'), 'hidden')
|
||||
this.$element[dimension](0)
|
||||
}
|
||||
|
||||
, reset: function (size) {
|
||||
var dimension = this.dimension()
|
||||
|
||||
this.$element
|
||||
.removeClass('collapse')
|
||||
[dimension](size || 'auto')
|
||||
[0].offsetWidth
|
||||
|
||||
this.$element[size !== null ? 'addClass' : 'removeClass']('collapse')
|
||||
|
||||
return this
|
||||
}
|
||||
|
||||
, transition: function (method, startEvent, completeEvent) {
|
||||
var that = this
|
||||
, complete = function () {
|
||||
if (startEvent.type == 'show') that.reset()
|
||||
that.transitioning = 0
|
||||
that.$element.trigger(completeEvent)
|
||||
}
|
||||
|
||||
this.$element.trigger(startEvent)
|
||||
|
||||
if (startEvent.isDefaultPrevented()) return
|
||||
|
||||
this.transitioning = 1
|
||||
|
||||
this.$element[method]('in')
|
||||
|
||||
$.support.transition && this.$element.hasClass('collapse') ?
|
||||
this.$element.one($.support.transition.end, complete) :
|
||||
complete()
|
||||
}
|
||||
|
||||
, toggle: function () {
|
||||
this[this.$element.hasClass('in') ? 'hide' : 'show']()
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
/* COLLAPSIBLE PLUGIN DEFINITION
|
||||
* ============================== */
|
||||
|
||||
$.fn.collapse = function (option) {
|
||||
return this.each(function () {
|
||||
var $this = $(this)
|
||||
, data = $this.data('collapse')
|
||||
, options = typeof option == 'object' && option
|
||||
if (!data) $this.data('collapse', (data = new Collapse(this, options)))
|
||||
if (typeof option == 'string') data[option]()
|
||||
})
|
||||
}
|
||||
|
||||
$.fn.collapse.defaults = {
|
||||
toggle: true
|
||||
}
|
||||
|
||||
$.fn.collapse.Constructor = Collapse
|
||||
|
||||
|
||||
/* COLLAPSIBLE DATA-API
|
||||
* ==================== */
|
||||
|
||||
$(function () {
|
||||
$('body').on('click.collapse.data-api', '[data-toggle=collapse]', function ( e ) {
|
||||
var $this = $(this), href
|
||||
, target = $this.attr('data-target')
|
||||
|| e.preventDefault()
|
||||
|| (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '') //strip for ie7
|
||||
, option = $(target).data('collapse') ? 'toggle' : $this.data()
|
||||
$(target).collapse(option)
|
||||
})
|
||||
})
|
||||
|
||||
}(window.jQuery);
|
@ -1,100 +0,0 @@
|
||||
/* ============================================================
|
||||
* bootstrap-dropdown.js v2.0.4
|
||||
* http://twitter.github.com/bootstrap/javascript.html#dropdowns
|
||||
* ============================================================
|
||||
* Copyright 2012 Twitter, Inc.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
* ============================================================ */
|
||||
|
||||
|
||||
!function ($) {
|
||||
|
||||
"use strict"; // jshint ;_;
|
||||
|
||||
|
||||
/* DROPDOWN CLASS DEFINITION
|
||||
* ========================= */
|
||||
|
||||
var toggle = '[data-toggle="dropdown"]'
|
||||
, Dropdown = function (element) {
|
||||
var $el = $(element).on('click.dropdown.data-api', this.toggle)
|
||||
$('html').on('click.dropdown.data-api', function () {
|
||||
$el.parent().removeClass('open')
|
||||
})
|
||||
}
|
||||
|
||||
Dropdown.prototype = {
|
||||
|
||||
constructor: Dropdown
|
||||
|
||||
, toggle: function (e) {
|
||||
var $this = $(this)
|
||||
, $parent
|
||||
, selector
|
||||
, isActive
|
||||
|
||||
if ($this.is('.disabled, :disabled')) return
|
||||
|
||||
selector = $this.attr('data-target')
|
||||
|
||||
if (!selector) {
|
||||
selector = $this.attr('href')
|
||||
selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
|
||||
}
|
||||
|
||||
$parent = $(selector)
|
||||
$parent.length || ($parent = $this.parent())
|
||||
|
||||
isActive = $parent.hasClass('open')
|
||||
|
||||
clearMenus()
|
||||
|
||||
if (!isActive) $parent.toggleClass('open')
|
||||
|
||||
return false
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
function clearMenus() {
|
||||
$(toggle).parent().removeClass('open')
|
||||
}
|
||||
|
||||
|
||||
/* DROPDOWN PLUGIN DEFINITION
|
||||
* ========================== */
|
||||
|
||||
$.fn.dropdown = function (option) {
|
||||
return this.each(function () {
|
||||
var $this = $(this)
|
||||
, data = $this.data('dropdown')
|
||||
if (!data) $this.data('dropdown', (data = new Dropdown(this)))
|
||||
if (typeof option == 'string') data[option].call($this)
|
||||
})
|
||||
}
|
||||
|
||||
$.fn.dropdown.Constructor = Dropdown
|
||||
|
||||
|
||||
/* APPLY TO STANDARD DROPDOWN ELEMENTS
|
||||
* =================================== */
|
||||
|
||||
$(function () {
|
||||
$('html').on('click.dropdown.data-api', clearMenus)
|
||||
$('body')
|
||||
.on('click.dropdown', '.dropdown form', function (e) { e.stopPropagation() })
|
||||
.on('click.dropdown.data-api', toggle, Dropdown.prototype.toggle)
|
||||
})
|
||||
|
||||
}(window.jQuery);
|
@ -1,399 +0,0 @@
|
||||
/*
|
||||
* Bootstrap Image Gallery 2.10
|
||||
* https://github.com/blueimp/Bootstrap-Image-Gallery
|
||||
*
|
||||
* Copyright 2011, Sebastian Tschan
|
||||
* https://blueimp.net
|
||||
*
|
||||
* Licensed under the MIT license:
|
||||
* http://www.opensource.org/licenses/MIT
|
||||
*/
|
||||
|
||||
/*jslint nomen: true, regexp: true */
|
||||
/*global define, window, document, jQuery */
|
||||
|
||||
(function (factory) {
|
||||
'use strict';
|
||||
if (typeof define === 'function' && define.amd) {
|
||||
// Register as an anonymous AMD module:
|
||||
define([
|
||||
'jquery',
|
||||
'load-image',
|
||||
'bootstrap'
|
||||
], factory);
|
||||
} else {
|
||||
// Browser globals:
|
||||
factory(
|
||||
window.jQuery,
|
||||
window.loadImage
|
||||
);
|
||||
}
|
||||
}(function ($, loadImage) {
|
||||
'use strict';
|
||||
// Bootstrap Image Gallery is an extension to the Modal dialog of Twitter's
|
||||
// Bootstrap toolkit, to ease navigation between a set of gallery images.
|
||||
// It features transition effects, fullscreen mode and slideshow functionality.
|
||||
$.extend($.fn.modal.defaults, {
|
||||
// Delegate to search gallery links from, can be anything that
|
||||
// is accepted as parameter for $():
|
||||
delegate: document,
|
||||
// Selector for gallery links:
|
||||
selector: null,
|
||||
// The filter for the selected gallery links (e.g. set to ":odd" to
|
||||
// filter out label and thumbnail linking twice to the same image):
|
||||
filter: '*',
|
||||
// The index of the first gallery image to show:
|
||||
index: 0,
|
||||
// The href of the first gallery image to show (overrides index):
|
||||
href: null,
|
||||
// The range of images around the current one to preload:
|
||||
preloadRange: 2,
|
||||
// Offset of image width to viewport width:
|
||||
offsetWidth: 100,
|
||||
// Offset of image height to viewport height:
|
||||
offsetHeight: 200,
|
||||
// Set to true to display images as canvas elements:
|
||||
canvas: false,
|
||||
// Shows the next image after the given time in ms (0 = disabled):
|
||||
slideshow: 0,
|
||||
// Defines the image division for previous/next clicks:
|
||||
imageClickDivision: 0.5
|
||||
});
|
||||
var originalShow = $.fn.modal.Constructor.prototype.show,
|
||||
originalHide = $.fn.modal.Constructor.prototype.hide;
|
||||
$.extend($.fn.modal.Constructor.prototype, {
|
||||
initLinks: function () {
|
||||
var $this = this,
|
||||
options = this.options,
|
||||
selector = options.selector ||
|
||||
'a[data-target=' + options.target + ']';
|
||||
this.$links = $(options.delegate).find(selector)
|
||||
.filter(options.filter).each(function (index) {
|
||||
if ($this.getUrl(this) === options.href) {
|
||||
options.index = index;
|
||||
}
|
||||
});
|
||||
if (!this.$links[options.index]) {
|
||||
options.index = 0;
|
||||
}
|
||||
},
|
||||
getUrl: function (element) {
|
||||
return element.href || $(element).data('href');
|
||||
},
|
||||
getDownloadUrl: function (element) {
|
||||
return $(element).data('download');
|
||||
},
|
||||
startSlideShow: function () {
|
||||
var $this = this;
|
||||
if (this.options.slideshow) {
|
||||
this._slideShow = window.setTimeout(
|
||||
function () {
|
||||
$this.next();
|
||||
},
|
||||
this.options.slideshow
|
||||
);
|
||||
}
|
||||
},
|
||||
stopSlideShow: function () {
|
||||
window.clearTimeout(this._slideShow);
|
||||
},
|
||||
toggleSlideShow: function () {
|
||||
var node = this.$element.find('.modal-slideshow');
|
||||
if (this.options.slideshow) {
|
||||
this.options.slideshow = 0;
|
||||
this.stopSlideShow();
|
||||
} else {
|
||||
this.options.slideshow = node.data('slideshow') || 5000;
|
||||
this.startSlideShow();
|
||||
}
|
||||
node.find('i').toggleClass('icon-play icon-pause');
|
||||
},
|
||||
preloadImages: function () {
|
||||
var options = this.options,
|
||||
range = options.index + options.preloadRange + 1,
|
||||
link,
|
||||
i;
|
||||
for (i = options.index - options.preloadRange; i < range; i += 1) {
|
||||
link = this.$links[i];
|
||||
if (link && i !== options.index) {
|
||||
$('<img>').prop('src', this.getUrl(link));
|
||||
}
|
||||
}
|
||||
},
|
||||
loadImage: function () {
|
||||
var $this = this,
|
||||
modal = this.$element,
|
||||
index = this.options.index,
|
||||
url = this.getUrl(this.$links[index]),
|
||||
download = this.getDownloadUrl(this.$links[index]),
|
||||
oldImg;
|
||||
this.abortLoad();
|
||||
this.stopSlideShow();
|
||||
modal.trigger('beforeLoad');
|
||||
// The timeout prevents displaying a loading status,
|
||||
// if the image has already been loaded:
|
||||
this._loadingTimeout = window.setTimeout(function () {
|
||||
modal.addClass('modal-loading');
|
||||
}, 100);
|
||||
oldImg = modal.find('.modal-image').children().removeClass('in');
|
||||
// The timeout allows transition effects to finish:
|
||||
window.setTimeout(function () {
|
||||
oldImg.remove();
|
||||
}, 3000);
|
||||
modal.find('.modal-title').text(this.$links[index].title);
|
||||
modal.find('.modal-download').prop(
|
||||
'href',
|
||||
download || url
|
||||
);
|
||||
this._loadingImage = loadImage(
|
||||
url,
|
||||
function (img) {
|
||||
$this.img = img;
|
||||
window.clearTimeout($this._loadingTimeout);
|
||||
modal.removeClass('modal-loading');
|
||||
modal.trigger('load');
|
||||
$this.showImage(img);
|
||||
$this.startSlideShow();
|
||||
},
|
||||
this._loadImageOptions
|
||||
);
|
||||
this.preloadImages();
|
||||
},
|
||||
showImage: function (img) {
|
||||
var modal = this.$element,
|
||||
transition = $.support.transition && modal.hasClass('fade'),
|
||||
method = transition ? modal.animate : modal.css,
|
||||
modalImage = modal.find('.modal-image'),
|
||||
clone,
|
||||
forceReflow;
|
||||
modalImage.css({
|
||||
width: img.width,
|
||||
height: img.height
|
||||
});
|
||||
modal.find('.modal-title').css({ width: Math.max(img.width, 380) });
|
||||
if (transition) {
|
||||
clone = modal.clone().hide().appendTo(document.body);
|
||||
}
|
||||
if ($(window).width() > 767) {
|
||||
method.call(modal.stop(), {
|
||||
'margin-top': -((clone || modal).outerHeight() / 2),
|
||||
'margin-left': -((clone || modal).outerWidth() / 2)
|
||||
});
|
||||
} else {
|
||||
modal.css({
|
||||
top: ($(window).height() - (clone || modal).outerHeight()) / 2
|
||||
});
|
||||
}
|
||||
if (clone) {
|
||||
clone.remove();
|
||||
}
|
||||
modalImage.append(img);
|
||||
forceReflow = img.offsetWidth;
|
||||
modal.trigger('display');
|
||||
if (transition) {
|
||||
if (modal.is(':visible')) {
|
||||
$(img).on(
|
||||
$.support.transition.end,
|
||||
function (e) {
|
||||
// Make sure we don't respond to other transitions events
|
||||
// in the container element, e.g. from button elements:
|
||||
if (e.target === img) {
|
||||
$(img).off($.support.transition.end);
|
||||
modal.trigger('displayed');
|
||||
}
|
||||
}
|
||||
).addClass('in');
|
||||
} else {
|
||||
$(img).addClass('in');
|
||||
modal.one('shown', function () {
|
||||
modal.trigger('displayed');
|
||||
});
|
||||
}
|
||||
} else {
|
||||
$(img).addClass('in');
|
||||
modal.trigger('displayed');
|
||||
}
|
||||
},
|
||||
abortLoad: function () {
|
||||
if (this._loadingImage) {
|
||||
this._loadingImage.onload = this._loadingImage.onerror = null;
|
||||
}
|
||||
window.clearTimeout(this._loadingTimeout);
|
||||
},
|
||||
prev: function () {
|
||||
var options = this.options;
|
||||
options.index -= 1;
|
||||
if (options.index < 0) {
|
||||
options.index = this.$links.length - 1;
|
||||
}
|
||||
this.loadImage();
|
||||
},
|
||||
next: function () {
|
||||
var options = this.options;
|
||||
options.index += 1;
|
||||
if (options.index > this.$links.length - 1) {
|
||||
options.index = 0;
|
||||
}
|
||||
this.loadImage();
|
||||
},
|
||||
keyHandler: function (e) {
|
||||
switch (e.which) {
|
||||
case 37: // left
|
||||
case 38: // up
|
||||
e.preventDefault();
|
||||
this.prev();
|
||||
break;
|
||||
case 39: // right
|
||||
case 40: // down
|
||||
e.preventDefault();
|
||||
this.next();
|
||||
break;
|
||||
}
|
||||
},
|
||||
wheelHandler: function (e) {
|
||||
e.preventDefault();
|
||||
e = e.originalEvent;
|
||||
this._wheelCounter = this._wheelCounter || 0;
|
||||
this._wheelCounter += (e.wheelDelta || e.detail || 0);
|
||||
if ((e.wheelDelta && this._wheelCounter >= 120) ||
|
||||
(!e.wheelDelta && this._wheelCounter < 0)) {
|
||||
this.prev();
|
||||
this._wheelCounter = 0;
|
||||
} else if ((e.wheelDelta && this._wheelCounter <= -120) ||
|
||||
(!e.wheelDelta && this._wheelCounter > 0)) {
|
||||
this.next();
|
||||
this._wheelCounter = 0;
|
||||
}
|
||||
},
|
||||
initGalleryEvents: function () {
|
||||
var $this = this,
|
||||
modal = this.$element;
|
||||
modal.find('.modal-image').on('click.modal-gallery', function (e) {
|
||||
var modalImage = $(this);
|
||||
if ($this.$links.length === 1) {
|
||||
$this.hide();
|
||||
} else {
|
||||
if ((e.pageX - modalImage.offset().left) / modalImage.width() <
|
||||
$this.options.imageClickDivision) {
|
||||
$this.prev(e);
|
||||
} else {
|
||||
$this.next(e);
|
||||
}
|
||||
}
|
||||
});
|
||||
modal.find('.modal-prev').on('click.modal-gallery', function (e) {
|
||||
$this.prev(e);
|
||||
});
|
||||
modal.find('.modal-next').on('click.modal-gallery', function (e) {
|
||||
$this.next(e);
|
||||
});
|
||||
modal.find('.modal-slideshow').on('click.modal-gallery', function (e) {
|
||||
$this.toggleSlideShow(e);
|
||||
});
|
||||
$(document)
|
||||
.on('keydown.modal-gallery', function (e) {
|
||||
$this.keyHandler(e);
|
||||
})
|
||||
.on(
|
||||
'mousewheel.modal-gallery, DOMMouseScroll.modal-gallery',
|
||||
function (e) {
|
||||
$this.wheelHandler(e);
|
||||
}
|
||||
);
|
||||
},
|
||||
destroyGalleryEvents: function () {
|
||||
var modal = this.$element;
|
||||
this.abortLoad();
|
||||
this.stopSlideShow();
|
||||
modal.find('.modal-image, .modal-prev, .modal-next, .modal-slideshow')
|
||||
.off('click.modal-gallery');
|
||||
$(document)
|
||||
.off('keydown.modal-gallery')
|
||||
.off('mousewheel.modal-gallery, DOMMouseScroll.modal-gallery');
|
||||
},
|
||||
show: function () {
|
||||
if (!this.isShown && this.$element.hasClass('modal-gallery')) {
|
||||
var modal = this.$element,
|
||||
options = this.options,
|
||||
windowWidth = $(window).width(),
|
||||
windowHeight = $(window).height();
|
||||
if (modal.hasClass('modal-fullscreen')) {
|
||||
this._loadImageOptions = {
|
||||
maxWidth: windowWidth,
|
||||
maxHeight: windowHeight,
|
||||
canvas: options.canvas
|
||||
};
|
||||
if (modal.hasClass('modal-fullscreen-stretch')) {
|
||||
this._loadImageOptions.minWidth = windowWidth;
|
||||
this._loadImageOptions.minHeight = windowHeight;
|
||||
}
|
||||
} else {
|
||||
this._loadImageOptions = {
|
||||
maxWidth: windowWidth - options.offsetWidth,
|
||||
maxHeight: windowHeight - options.offsetHeight,
|
||||
canvas: options.canvas
|
||||
};
|
||||
}
|
||||
if (windowWidth > 767) {
|
||||
modal.css({
|
||||
'margin-top': -(modal.outerHeight() / 2),
|
||||
'margin-left': -(modal.outerWidth() / 2)
|
||||
});
|
||||
} else {
|
||||
modal.css({
|
||||
top: ($(window).height() - modal.outerHeight()) / 2
|
||||
});
|
||||
}
|
||||
this.initGalleryEvents();
|
||||
this.initLinks();
|
||||
if (this.$links.length) {
|
||||
modal.find('.modal-slideshow, .modal-prev, .modal-next')
|
||||
.toggle(this.$links.length !== 1);
|
||||
modal.toggleClass(
|
||||
'modal-single',
|
||||
this.$links.length === 1
|
||||
);
|
||||
this.loadImage();
|
||||
}
|
||||
}
|
||||
originalShow.apply(this, arguments);
|
||||
},
|
||||
hide: function () {
|
||||
if (this.isShown && this.$element.hasClass('modal-gallery')) {
|
||||
this.options.delegate = document;
|
||||
this.options.href = null;
|
||||
this.destroyGalleryEvents();
|
||||
}
|
||||
originalHide.apply(this, arguments);
|
||||
}
|
||||
});
|
||||
$(function () {
|
||||
$(document.body).on(
|
||||
'click.modal-gallery.data-api',
|
||||
'[data-toggle="modal-gallery"]',
|
||||
function (e) {
|
||||
var $this = $(this),
|
||||
options = $this.data(),
|
||||
modal = $(options.target),
|
||||
data = modal.data('modal'),
|
||||
link;
|
||||
if (!data) {
|
||||
options = $.extend(modal.data(), options);
|
||||
}
|
||||
if (!options.selector) {
|
||||
options.selector = 'a[data-gallery=gallery]';
|
||||
}
|
||||
link = $(e.target).closest(options.selector);
|
||||
if (link.length && modal.length) {
|
||||
e.preventDefault();
|
||||
options.href = link.prop('href') || link.data('href');
|
||||
options.delegate = link[0] !== this ? this : document;
|
||||
if (data) {
|
||||
$.extend(data.options, options);
|
||||
}
|
||||
modal.modal(options);
|
||||
}
|
||||
}
|
||||
);
|
||||
});
|
||||
}));
|
@ -1,218 +0,0 @@
|
||||
/* =========================================================
|
||||
* bootstrap-modal.js v2.0.4
|
||||
* http://twitter.github.com/bootstrap/javascript.html#modals
|
||||
* =========================================================
|
||||
* Copyright 2012 Twitter, Inc.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
* ========================================================= */
|
||||
|
||||
|
||||
!function ($) {
|
||||
|
||||
"use strict"; // jshint ;_;
|
||||
|
||||
|
||||
/* MODAL CLASS DEFINITION
|
||||
* ====================== */
|
||||
|
||||
var Modal = function (content, options) {
|
||||
this.options = options
|
||||
this.$element = $(content)
|
||||
.delegate('[data-dismiss="modal"]', 'click.dismiss.modal', $.proxy(this.hide, this))
|
||||
}
|
||||
|
||||
Modal.prototype = {
|
||||
|
||||
constructor: Modal
|
||||
|
||||
, toggle: function () {
|
||||
return this[!this.isShown ? 'show' : 'hide']()
|
||||
}
|
||||
|
||||
, show: function () {
|
||||
var that = this
|
||||
, e = $.Event('show')
|
||||
|
||||
this.$element.trigger(e)
|
||||
|
||||
if (this.isShown || e.isDefaultPrevented()) return
|
||||
|
||||
$('body').addClass('modal-open')
|
||||
|
||||
this.isShown = true
|
||||
|
||||
escape.call(this)
|
||||
backdrop.call(this, function () {
|
||||
var transition = $.support.transition && that.$element.hasClass('fade')
|
||||
|
||||
if (!that.$element.parent().length) {
|
||||
that.$element.appendTo(document.body) //don't move modals dom position
|
||||
}
|
||||
|
||||
that.$element
|
||||
.show()
|
||||
|
||||
if (transition) {
|
||||
that.$element[0].offsetWidth // force reflow
|
||||
}
|
||||
|
||||
that.$element.addClass('in')
|
||||
|
||||
transition ?
|
||||
that.$element.one($.support.transition.end, function () { that.$element.trigger('shown') }) :
|
||||
that.$element.trigger('shown')
|
||||
|
||||
})
|
||||
}
|
||||
|
||||
, hide: function (e) {
|
||||
e && e.preventDefault()
|
||||
|
||||
var that = this
|
||||
|
||||
e = $.Event('hide')
|
||||
|
||||
this.$element.trigger(e)
|
||||
|
||||
if (!this.isShown || e.isDefaultPrevented()) return
|
||||
|
||||
this.isShown = false
|
||||
|
||||
$('body').removeClass('modal-open')
|
||||
|
||||
escape.call(this)
|
||||
|
||||
this.$element.removeClass('in')
|
||||
|
||||
$.support.transition && this.$element.hasClass('fade') ?
|
||||
hideWithTransition.call(this) :
|
||||
hideModal.call(this)
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
/* MODAL PRIVATE METHODS
|
||||
* ===================== */
|
||||
|
||||
function hideWithTransition() {
|
||||
var that = this
|
||||
, timeout = setTimeout(function () {
|
||||
that.$element.off($.support.transition.end)
|
||||
hideModal.call(that)
|
||||
}, 500)
|
||||
|
||||
this.$element.one($.support.transition.end, function () {
|
||||
clearTimeout(timeout)
|
||||
hideModal.call(that)
|
||||
})
|
||||
}
|
||||
|
||||
function hideModal(that) {
|
||||
this.$element
|
||||
.hide()
|
||||
.trigger('hidden')
|
||||
|
||||
backdrop.call(this)
|
||||
}
|
||||
|
||||
function backdrop(callback) {
|
||||
var that = this
|
||||
, animate = this.$element.hasClass('fade') ? 'fade' : ''
|
||||
|
||||
if (this.isShown && this.options.backdrop) {
|
||||
var doAnimate = $.support.transition && animate
|
||||
|
||||
this.$backdrop = $('<div class="modal-backdrop ' + animate + '" />')
|
||||
.appendTo(document.body)
|
||||
|
||||
if (this.options.backdrop != 'static') {
|
||||
this.$backdrop.click($.proxy(this.hide, this))
|
||||
}
|
||||
|
||||
if (doAnimate) this.$backdrop[0].offsetWidth // force reflow
|
||||
|
||||
this.$backdrop.addClass('in')
|
||||
|
||||
doAnimate ?
|
||||
this.$backdrop.one($.support.transition.end, callback) :
|
||||
callback()
|
||||
|
||||
} else if (!this.isShown && this.$backdrop) {
|
||||
this.$backdrop.removeClass('in')
|
||||
|
||||
$.support.transition && this.$element.hasClass('fade')?
|
||||
this.$backdrop.one($.support.transition.end, $.proxy(removeBackdrop, this)) :
|
||||
removeBackdrop.call(this)
|
||||
|
||||
} else if (callback) {
|
||||
callback()
|
||||
}
|
||||
}
|
||||
|
||||
function removeBackdrop() {
|
||||
this.$backdrop.remove()
|
||||
this.$backdrop = null
|
||||
}
|
||||
|
||||
function escape() {
|
||||
var that = this
|
||||
if (this.isShown && this.options.keyboard) {
|
||||
$(document).on('keyup.dismiss.modal', function ( e ) {
|
||||
e.which == 27 && that.hide()
|
||||
})
|
||||
} else if (!this.isShown) {
|
||||
$(document).off('keyup.dismiss.modal')
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/* MODAL PLUGIN DEFINITION
|
||||
* ======================= */
|
||||
|
||||
$.fn.modal = function (option) {
|
||||
return this.each(function () {
|
||||
var $this = $(this)
|
||||
, data = $this.data('modal')
|
||||
, options = $.extend({}, $.fn.modal.defaults, $this.data(), typeof option == 'object' && option)
|
||||
if (!data) $this.data('modal', (data = new Modal(this, options)))
|
||||
if (typeof option == 'string') data[option]()
|
||||
else if (options.show) data.show()
|
||||
})
|
||||
}
|
||||
|
||||
$.fn.modal.defaults = {
|
||||
backdrop: true
|
||||
, keyboard: true
|
||||
, show: true
|
||||
}
|
||||
|
||||
$.fn.modal.Constructor = Modal
|
||||
|
||||
|
||||
/* MODAL DATA-API
|
||||
* ============== */
|
||||
|
||||
$(function () {
|
||||
$('body').on('click.modal.data-api', '[data-toggle="modal"]', function ( e ) {
|
||||
var $this = $(this), href
|
||||
, $target = $($this.attr('data-target') || (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
|
||||
, option = $target.data('modal') ? 'toggle' : $.extend({}, $target.data(), $this.data())
|
||||
|
||||
e.preventDefault()
|
||||
$target.modal(option)
|
||||
})
|
||||
})
|
||||
|
||||
}(window.jQuery);
|
@ -1,98 +0,0 @@
|
||||
/* ===========================================================
|
||||
* bootstrap-popover.js v2.0.4
|
||||
* http://twitter.github.com/bootstrap/javascript.html#popovers
|
||||
* ===========================================================
|
||||
* Copyright 2012 Twitter, Inc.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
* =========================================================== */
|
||||
|
||||
|
||||
!function ($) {
|
||||
|
||||
"use strict"; // jshint ;_;
|
||||
|
||||
|
||||
/* POPOVER PUBLIC CLASS DEFINITION
|
||||
* =============================== */
|
||||
|
||||
var Popover = function ( element, options ) {
|
||||
this.init('popover', element, options)
|
||||
}
|
||||
|
||||
|
||||
/* NOTE: POPOVER EXTENDS BOOTSTRAP-TOOLTIP.js
|
||||
========================================== */
|
||||
|
||||
Popover.prototype = $.extend({}, $.fn.tooltip.Constructor.prototype, {
|
||||
|
||||
constructor: Popover
|
||||
|
||||
, setContent: function () {
|
||||
var $tip = this.tip()
|
||||
, title = this.getTitle()
|
||||
, content = this.getContent()
|
||||
|
||||
$tip.find('.popover-title')[this.isHTML(title) ? 'html' : 'text'](title)
|
||||
$tip.find('.popover-content > *')[this.isHTML(content) ? 'html' : 'text'](content)
|
||||
|
||||
$tip.removeClass('fade top bottom left right in')
|
||||
}
|
||||
|
||||
, hasContent: function () {
|
||||
return this.getTitle() || this.getContent()
|
||||
}
|
||||
|
||||
, getContent: function () {
|
||||
var content
|
||||
, $e = this.$element
|
||||
, o = this.options
|
||||
|
||||
content = $e.attr('data-content')
|
||||
|| (typeof o.content == 'function' ? o.content.call($e[0]) : o.content)
|
||||
|
||||
return content
|
||||
}
|
||||
|
||||
, tip: function () {
|
||||
if (!this.$tip) {
|
||||
this.$tip = $(this.options.template)
|
||||
}
|
||||
return this.$tip
|
||||
}
|
||||
|
||||
})
|
||||
|
||||
|
||||
/* POPOVER PLUGIN DEFINITION
|
||||
* ======================= */
|
||||
|
||||
$.fn.popover = function (option) {
|
||||
return this.each(function () {
|
||||
var $this = $(this)
|
||||
, data = $this.data('popover')
|
||||
, options = typeof option == 'object' && option
|
||||
if (!data) $this.data('popover', (data = new Popover(this, options)))
|
||||
if (typeof option == 'string') data[option]()
|
||||
})
|
||||
}
|
||||
|
||||
$.fn.popover.Constructor = Popover
|
||||
|
||||
$.fn.popover.defaults = $.extend({} , $.fn.tooltip.defaults, {
|
||||
placement: 'right'
|
||||
, content: ''
|
||||
, template: '<div class="popover"><div class="arrow"></div><div class="popover-inner"><h3 class="popover-title"></h3><div class="popover-content"><p></p></div></div></div>'
|
||||
})
|
||||
|
||||
}(window.jQuery);
|
@ -1,151 +0,0 @@
|
||||
/* =============================================================
|
||||
* bootstrap-scrollspy.js v2.0.4
|
||||
* http://twitter.github.com/bootstrap/javascript.html#scrollspy
|
||||
* =============================================================
|
||||
* Copyright 2012 Twitter, Inc.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
* ============================================================== */
|
||||
|
||||
|
||||
!function ($) {
|
||||
|
||||
"use strict"; // jshint ;_;
|
||||
|
||||
|
||||
/* SCROLLSPY CLASS DEFINITION
|
||||
* ========================== */
|
||||
|
||||
function ScrollSpy( element, options) {
|
||||
var process = $.proxy(this.process, this)
|
||||
, $element = $(element).is('body') ? $(window) : $(element)
|
||||
, href
|
||||
this.options = $.extend({}, $.fn.scrollspy.defaults, options)
|
||||
this.$scrollElement = $element.on('scroll.scroll.data-api', process)
|
||||
this.selector = (this.options.target
|
||||
|| ((href = $(element).attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
|
||||
|| '') + ' .nav li > a'
|
||||
this.$body = $('body')
|
||||
this.refresh()
|
||||
this.process()
|
||||
}
|
||||
|
||||
ScrollSpy.prototype = {
|
||||
|
||||
constructor: ScrollSpy
|
||||
|
||||
, refresh: function () {
|
||||
var self = this
|
||||
, $targets
|
||||
|
||||
this.offsets = $([])
|
||||
this.targets = $([])
|
||||
|
||||
$targets = this.$body
|
||||
.find(this.selector)
|
||||
.map(function () {
|
||||
var $el = $(this)
|
||||
, href = $el.data('target') || $el.attr('href')
|
||||
, $href = /^#\w/.test(href) && $(href)
|
||||
return ( $href
|
||||
&& href.length
|
||||
&& [[ $href.position().top, href ]] ) || null
|
||||
})
|
||||
.sort(function (a, b) { return a[0] - b[0] })
|
||||
.each(function () {
|
||||
self.offsets.push(this[0])
|
||||
self.targets.push(this[1])
|
||||
})
|
||||
}
|
||||
|
||||
, process: function () {
|
||||
var scrollTop = this.$scrollElement.scrollTop() + this.options.offset
|
||||
, scrollHeight = this.$scrollElement[0].scrollHeight || this.$body[0].scrollHeight
|
||||
, maxScroll = scrollHeight - this.$scrollElement.height()
|
||||
, offsets = this.offsets
|
||||
, targets = this.targets
|
||||
, activeTarget = this.activeTarget
|
||||
, i
|
||||
|
||||
if (scrollTop >= maxScroll) {
|
||||
return activeTarget != (i = targets.last()[0])
|
||||
&& this.activate ( i )
|
||||
}
|
||||
|
||||
for (i = offsets.length; i--;) {
|
||||
activeTarget != targets[i]
|
||||
&& scrollTop >= offsets[i]
|
||||
&& (!offsets[i + 1] || scrollTop <= offsets[i + 1])
|
||||
&& this.activate( targets[i] )
|
||||
}
|
||||
}
|
||||
|
||||
, activate: function (target) {
|
||||
var active
|
||||
, selector
|
||||
|
||||
this.activeTarget = target
|
||||
|
||||
$(this.selector)
|
||||
.parent('.active')
|
||||
.removeClass('active')
|
||||
|
||||
selector = this.selector
|
||||
+ '[data-target="' + target + '"],'
|
||||
+ this.selector + '[href="' + target + '"]'
|
||||
|
||||
active = $(selector)
|
||||
.parent('li')
|
||||
.addClass('active')
|
||||
|
||||
if (active.parent('.dropdown-menu')) {
|
||||
active = active.closest('li.dropdown').addClass('active')
|
||||
}
|
||||
|
||||
active.trigger('activate')
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
/* SCROLLSPY PLUGIN DEFINITION
|
||||
* =========================== */
|
||||
|
||||
$.fn.scrollspy = function ( option ) {
|
||||
return this.each(function () {
|
||||
var $this = $(this)
|
||||
, data = $this.data('scrollspy')
|
||||
, options = typeof option == 'object' && option
|
||||
if (!data) $this.data('scrollspy', (data = new ScrollSpy(this, options)))
|
||||
if (typeof option == 'string') data[option]()
|
||||
})
|
||||
}
|
||||
|
||||
$.fn.scrollspy.Constructor = ScrollSpy
|
||||
|
||||
$.fn.scrollspy.defaults = {
|
||||
offset: 10
|
||||
}
|
||||
|
||||
|
||||
/* SCROLLSPY DATA-API
|
||||
* ================== */
|
||||
|
||||
$(function () {
|
||||
$('[data-spy="scroll"]').each(function () {
|
||||
var $spy = $(this)
|
||||
$spy.scrollspy($spy.data())
|
||||
})
|
||||
})
|
||||
|
||||
}(window.jQuery);
|
@ -1,135 +0,0 @@
|
||||
/* ========================================================
|
||||
* bootstrap-tab.js v2.0.4
|
||||
* http://twitter.github.com/bootstrap/javascript.html#tabs
|
||||
* ========================================================
|
||||
* Copyright 2012 Twitter, Inc.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
* ======================================================== */
|
||||
|
||||
|
||||
!function ($) {
|
||||
|
||||
"use strict"; // jshint ;_;
|
||||
|
||||
|
||||
/* TAB CLASS DEFINITION
|
||||
* ==================== */
|
||||
|
||||
var Tab = function ( element ) {
|
||||
this.element = $(element)
|
||||
}
|
||||
|
||||
Tab.prototype = {
|
||||
|
||||
constructor: Tab
|
||||
|
||||
, show: function () {
|
||||
var $this = this.element
|
||||
, $ul = $this.closest('ul:not(.dropdown-menu)')
|
||||
, selector = $this.attr('data-target')
|
||||
, previous
|
||||
, $target
|
||||
, e
|
||||
|
||||
if (!selector) {
|
||||
selector = $this.attr('href')
|
||||
selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
|
||||
}
|
||||
|
||||
if ( $this.parent('li').hasClass('active') ) return
|
||||
|
||||
previous = $ul.find('.active a').last()[0]
|
||||
|
||||
e = $.Event('show', {
|
||||
relatedTarget: previous
|
||||
})
|
||||
|
||||
$this.trigger(e)
|
||||
|
||||
if (e.isDefaultPrevented()) return
|
||||
|
||||
$target = $(selector)
|
||||
|
||||
this.activate($this.parent('li'), $ul)
|
||||
this.activate($target, $target.parent(), function () {
|
||||
$this.trigger({
|
||||
type: 'shown'
|
||||
, relatedTarget: previous
|
||||
})
|
||||
})
|
||||
}
|
||||
|
||||
, activate: function ( element, container, callback) {
|
||||
var $active = container.find('> .active')
|
||||
, transition = callback
|
||||
&& $.support.transition
|
||||
&& $active.hasClass('fade')
|
||||
|
||||
function next() {
|
||||
$active
|
||||
.removeClass('active')
|
||||
.find('> .dropdown-menu > .active')
|
||||
.removeClass('active')
|
||||
|
||||
element.addClass('active')
|
||||
|
||||
if (transition) {
|
||||
element[0].offsetWidth // reflow for transition
|
||||
element.addClass('in')
|
||||
} else {
|
||||
element.removeClass('fade')
|
||||
}
|
||||
|
||||
if ( element.parent('.dropdown-menu') ) {
|
||||
element.closest('li.dropdown').addClass('active')
|
||||
}
|
||||
|
||||
callback && callback()
|
||||
}
|
||||
|
||||
transition ?
|
||||
$active.one($.support.transition.end, next) :
|
||||
next()
|
||||
|
||||
$active.removeClass('in')
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/* TAB PLUGIN DEFINITION
|
||||
* ===================== */
|
||||
|
||||
$.fn.tab = function ( option ) {
|
||||
return this.each(function () {
|
||||
var $this = $(this)
|
||||
, data = $this.data('tab')
|
||||
if (!data) $this.data('tab', (data = new Tab(this)))
|
||||
if (typeof option == 'string') data[option]()
|
||||
})
|
||||
}
|
||||
|
||||
$.fn.tab.Constructor = Tab
|
||||
|
||||
|
||||
/* TAB DATA-API
|
||||
* ============ */
|
||||
|
||||
$(function () {
|
||||
$('body').on('click.tab.data-api', '[data-toggle="tab"], [data-toggle="pill"]', function (e) {
|
||||
e.preventDefault()
|
||||
$(this).tab('show')
|
||||
})
|
||||
})
|
||||
|
||||
}(window.jQuery);
|
@ -1,275 +0,0 @@
|
||||
/* ===========================================================
|
||||
* bootstrap-tooltip.js v2.0.4
|
||||
* http://twitter.github.com/bootstrap/javascript.html#tooltips
|
||||
* Inspired by the original jQuery.tipsy by Jason Frame
|
||||
* ===========================================================
|
||||
* Copyright 2012 Twitter, Inc.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
* ========================================================== */
|
||||
|
||||
|
||||
!function ($) {
|
||||
|
||||
"use strict"; // jshint ;_;
|
||||
|
||||
|
||||
/* TOOLTIP PUBLIC CLASS DEFINITION
|
||||
* =============================== */
|
||||
|
||||
var Tooltip = function (element, options) {
|
||||
this.init('tooltip', element, options)
|
||||
}
|
||||
|
||||
Tooltip.prototype = {
|
||||
|
||||
constructor: Tooltip
|
||||
|
||||
, init: function (type, element, options) {
|
||||
var eventIn
|
||||
, eventOut
|
||||
|
||||
this.type = type
|
||||
this.$element = $(element)
|
||||
this.options = this.getOptions(options)
|
||||
this.enabled = true
|
||||
|
||||
if (this.options.trigger != 'manual') {
|
||||
eventIn = this.options.trigger == 'hover' ? 'mouseenter' : 'focus'
|
||||
eventOut = this.options.trigger == 'hover' ? 'mouseleave' : 'blur'
|
||||
this.$element.on(eventIn, this.options.selector, $.proxy(this.enter, this))
|
||||
this.$element.on(eventOut, this.options.selector, $.proxy(this.leave, this))
|
||||
}
|
||||
|
||||
this.options.selector ?
|
||||
(this._options = $.extend({}, this.options, { trigger: 'manual', selector: '' })) :
|
||||
this.fixTitle()
|
||||
}
|
||||
|
||||
, getOptions: function (options) {
|
||||
options = $.extend({}, $.fn[this.type].defaults, options, this.$element.data())
|
||||
|
||||
if (options.delay && typeof options.delay == 'number') {
|
||||
options.delay = {
|
||||
show: options.delay
|
||||
, hide: options.delay
|
||||
}
|
||||
}
|
||||
|
||||
return options
|
||||
}
|
||||
|
||||
, enter: function (e) {
|
||||
var self = $(e.currentTarget)[this.type](this._options).data(this.type)
|
||||
|
||||
if (!self.options.delay || !self.options.delay.show) return self.show()
|
||||
|
||||
clearTimeout(this.timeout)
|
||||
self.hoverState = 'in'
|
||||
this.timeout = setTimeout(function() {
|
||||
if (self.hoverState == 'in') self.show()
|
||||
}, self.options.delay.show)
|
||||
}
|
||||
|
||||
, leave: function (e) {
|
||||
var self = $(e.currentTarget)[this.type](this._options).data(this.type)
|
||||
|
||||
if (this.timeout) clearTimeout(this.timeout)
|
||||
if (!self.options.delay || !self.options.delay.hide) return self.hide()
|
||||
|
||||
self.hoverState = 'out'
|
||||
this.timeout = setTimeout(function() {
|
||||
if (self.hoverState == 'out') self.hide()
|
||||
}, self.options.delay.hide)
|
||||
}
|
||||
|
||||
, show: function () {
|
||||
var $tip
|
||||
, inside
|
||||
, pos
|
||||
, actualWidth
|
||||
, actualHeight
|
||||
, placement
|
||||
, tp
|
||||
|
||||
if (this.hasContent() && this.enabled) {
|
||||
$tip = this.tip()
|
||||
this.setContent()
|
||||
|
||||
if (this.options.animation) {
|
||||
$tip.addClass('fade')
|
||||
}
|
||||
|
||||
placement = typeof this.options.placement == 'function' ?
|
||||
this.options.placement.call(this, $tip[0], this.$element[0]) :
|
||||
this.options.placement
|
||||
|
||||
inside = /in/.test(placement)
|
||||
|
||||
$tip
|
||||
.remove()
|
||||
.css({ top: 0, left: 0, display: 'block' })
|
||||
.appendTo(inside ? this.$element : document.body)
|
||||
|
||||
pos = this.getPosition(inside)
|
||||
|
||||
actualWidth = $tip[0].offsetWidth
|
||||
actualHeight = $tip[0].offsetHeight
|
||||
|
||||
switch (inside ? placement.split(' ')[1] : placement) {
|
||||
case 'bottom':
|
||||
tp = {top: pos.top + pos.height, left: pos.left + pos.width / 2 - actualWidth / 2}
|
||||
break
|
||||
case 'top':
|
||||
tp = {top: pos.top - actualHeight, left: pos.left + pos.width / 2 - actualWidth / 2}
|
||||
break
|
||||
case 'left':
|
||||
tp = {top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left - actualWidth}
|
||||
break
|
||||
case 'right':
|
||||
tp = {top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left + pos.width}
|
||||
break
|
||||
}
|
||||
|
||||
$tip
|
||||
.css(tp)
|
||||
.addClass(placement)
|
||||
.addClass('in')
|
||||
}
|
||||
}
|
||||
|
||||
, isHTML: function(text) {
|
||||
// html string detection logic adapted from jQuery
|
||||
return typeof text != 'string'
|
||||
|| ( text.charAt(0) === "<"
|
||||
&& text.charAt( text.length - 1 ) === ">"
|
||||
&& text.length >= 3
|
||||
) || /^(?:[^<]*<[\w\W]+>[^>]*$)/.exec(text)
|
||||
}
|
||||
|
||||
, setContent: function () {
|
||||
var $tip = this.tip()
|
||||
, title = this.getTitle()
|
||||
|
||||
$tip.find('.tooltip-inner')[this.isHTML(title) ? 'html' : 'text'](title)
|
||||
$tip.removeClass('fade in top bottom left right')
|
||||
}
|
||||
|
||||
, hide: function () {
|
||||
var that = this
|
||||
, $tip = this.tip()
|
||||
|
||||
$tip.removeClass('in')
|
||||
|
||||
function removeWithAnimation() {
|
||||
var timeout = setTimeout(function () {
|
||||
$tip.off($.support.transition.end).remove()
|
||||
}, 500)
|
||||
|
||||
$tip.one($.support.transition.end, function () {
|
||||
clearTimeout(timeout)
|
||||
$tip.remove()
|
||||
})
|
||||
}
|
||||
|
||||
$.support.transition && this.$tip.hasClass('fade') ?
|
||||
removeWithAnimation() :
|
||||
$tip.remove()
|
||||
}
|
||||
|
||||
, fixTitle: function () {
|
||||
var $e = this.$element
|
||||
if ($e.attr('title') || typeof($e.attr('data-original-title')) != 'string') {
|
||||
$e.attr('data-original-title', $e.attr('title') || '').removeAttr('title')
|
||||
}
|
||||
}
|
||||
|
||||
, hasContent: function () {
|
||||
return this.getTitle()
|
||||
}
|
||||
|
||||
, getPosition: function (inside) {
|
||||
return $.extend({}, (inside ? {top: 0, left: 0} : this.$element.offset()), {
|
||||
width: this.$element[0].offsetWidth
|
||||
, height: this.$element[0].offsetHeight
|
||||
})
|
||||
}
|
||||
|
||||
, getTitle: function () {
|
||||
var title
|
||||
, $e = this.$element
|
||||
, o = this.options
|
||||
|
||||
title = $e.attr('data-original-title')
|
||||
|| (typeof o.title == 'function' ? o.title.call($e[0]) : o.title)
|
||||
|
||||
return title
|
||||
}
|
||||
|
||||
, tip: function () {
|
||||
return this.$tip = this.$tip || $(this.options.template)
|
||||
}
|
||||
|
||||
, validate: function () {
|
||||
if (!this.$element[0].parentNode) {
|
||||
this.hide()
|
||||
this.$element = null
|
||||
this.options = null
|
||||
}
|
||||
}
|
||||
|
||||
, enable: function () {
|
||||
this.enabled = true
|
||||
}
|
||||
|
||||
, disable: function () {
|
||||
this.enabled = false
|
||||
}
|
||||
|
||||
, toggleEnabled: function () {
|
||||
this.enabled = !this.enabled
|
||||
}
|
||||
|
||||
, toggle: function () {
|
||||
this[this.tip().hasClass('in') ? 'hide' : 'show']()
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
/* TOOLTIP PLUGIN DEFINITION
|
||||
* ========================= */
|
||||
|
||||
$.fn.tooltip = function ( option ) {
|
||||
return this.each(function () {
|
||||
var $this = $(this)
|
||||
, data = $this.data('tooltip')
|
||||
, options = typeof option == 'object' && option
|
||||
if (!data) $this.data('tooltip', (data = new Tooltip(this, options)))
|
||||
if (typeof option == 'string') data[option]()
|
||||
})
|
||||
}
|
||||
|
||||
$.fn.tooltip.Constructor = Tooltip
|
||||
|
||||
$.fn.tooltip.defaults = {
|
||||
animation: true
|
||||
, placement: 'top'
|
||||
, selector: false
|
||||
, template: '<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>'
|
||||
, trigger: 'hover'
|
||||
, title: ''
|
||||
, delay: 0
|
||||
}
|
||||
|
||||
}(window.jQuery);
|
@ -1,61 +0,0 @@
|
||||
/* ===================================================
|
||||
* bootstrap-transition.js v2.0.4
|
||||
* http://twitter.github.com/bootstrap/javascript.html#transitions
|
||||
* ===================================================
|
||||
* Copyright 2012 Twitter, Inc.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
* ========================================================== */
|
||||
|
||||
|
||||
!function ($) {
|
||||
|
||||
$(function () {
|
||||
|
||||
"use strict"; // jshint ;_;
|
||||
|
||||
|
||||
/* CSS TRANSITION SUPPORT (http://www.modernizr.com/)
|
||||
* ======================================================= */
|
||||
|
||||
$.support.transition = (function () {
|
||||
|
||||
var transitionEnd = (function () {
|
||||
|
||||
var el = document.createElement('bootstrap')
|
||||
, transEndEventNames = {
|
||||
'WebkitTransition' : 'webkitTransitionEnd'
|
||||
, 'MozTransition' : 'transitionend'
|
||||
, 'OTransition' : 'oTransitionEnd'
|
||||
, 'msTransition' : 'MSTransitionEnd'
|
||||
, 'transition' : 'transitionend'
|
||||
}
|
||||
, name
|
||||
|
||||
for (name in transEndEventNames){
|
||||
if (el.style[name] !== undefined) {
|
||||
return transEndEventNames[name]
|
||||
}
|
||||
}
|
||||
|
||||
}())
|
||||
|
||||
return transitionEnd && {
|
||||
end: transitionEnd
|
||||
}
|
||||
|
||||
})()
|
||||
|
||||
})
|
||||
|
||||
}(window.jQuery);
|
@ -1,285 +0,0 @@
|
||||
/* =============================================================
|
||||
* bootstrap-typeahead.js v2.0.4
|
||||
* http://twitter.github.com/bootstrap/javascript.html#typeahead
|
||||
* =============================================================
|
||||
* Copyright 2012 Twitter, Inc.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
* ============================================================ */
|
||||
|
||||
|
||||
!function($){
|
||||
|
||||
"use strict"; // jshint ;_;
|
||||
|
||||
|
||||
/* TYPEAHEAD PUBLIC CLASS DEFINITION
|
||||
* ================================= */
|
||||
|
||||
var Typeahead = function (element, options) {
|
||||
this.$element = $(element)
|
||||
this.options = $.extend({}, $.fn.typeahead.defaults, options)
|
||||
this.matcher = this.options.matcher || this.matcher
|
||||
this.sorter = this.options.sorter || this.sorter
|
||||
this.highlighter = this.options.highlighter || this.highlighter
|
||||
this.updater = this.options.updater || this.updater
|
||||
this.$menu = $(this.options.menu).appendTo('body')
|
||||
this.source = this.options.source
|
||||
this.shown = false
|
||||
this.listen()
|
||||
}
|
||||
|
||||
Typeahead.prototype = {
|
||||
|
||||
constructor: Typeahead
|
||||
|
||||
, select: function () {
|
||||
var val = this.$menu.find('.active').attr('data-value')
|
||||
this.$element
|
||||
.val(this.updater(val))
|
||||
.change()
|
||||
return this.hide()
|
||||
}
|
||||
|
||||
, updater: function (item) {
|
||||
return item
|
||||
}
|
||||
|
||||
, show: function () {
|
||||
var pos = $.extend({}, this.$element.offset(), {
|
||||
height: this.$element[0].offsetHeight
|
||||
})
|
||||
|
||||
this.$menu.css({
|
||||
top: pos.top + pos.height
|
||||
, left: pos.left
|
||||
})
|
||||
|
||||
this.$menu.show()
|
||||
this.shown = true
|
||||
return this
|
||||
}
|
||||
|
||||
, hide: function () {
|
||||
this.$menu.hide()
|
||||
this.shown = false
|
||||
return this
|
||||
}
|
||||
|
||||
, lookup: function (event) {
|
||||
var that = this
|
||||
, items
|
||||
, q
|
||||
|
||||
this.query = this.$element.val()
|
||||
|
||||
if (!this.query) {
|
||||
return this.shown ? this.hide() : this
|
||||
}
|
||||
|
||||
items = $.grep(this.source, function (item) {
|
||||
return that.matcher(item)
|
||||
})
|
||||
|
||||
items = this.sorter(items)
|
||||
|
||||
if (!items.length) {
|
||||
return this.shown ? this.hide() : this
|
||||
}
|
||||
|
||||
return this.render(items.slice(0, this.options.items)).show()
|
||||
}
|
||||
|
||||
, matcher: function (item) {
|
||||
return ~item.toLowerCase().indexOf(this.query.toLowerCase())
|
||||
}
|
||||
|
||||
, sorter: function (items) {
|
||||
var beginswith = []
|
||||
, caseSensitive = []
|
||||
, caseInsensitive = []
|
||||
, item
|
||||
|
||||
while (item = items.shift()) {
|
||||
if (!item.toLowerCase().indexOf(this.query.toLowerCase())) beginswith.push(item)
|
||||
else if (~item.indexOf(this.query)) caseSensitive.push(item)
|
||||
else caseInsensitive.push(item)
|
||||
}
|
||||
|
||||
return beginswith.concat(caseSensitive, caseInsensitive)
|
||||
}
|
||||
|
||||
, highlighter: function (item) {
|
||||
var query = this.query.replace(/[\-\[\]{}()*+?.,\\\^$|#\s]/g, '\\$&')
|
||||
return item.replace(new RegExp('(' + query + ')', 'ig'), function ($1, match) {
|
||||
return '<strong>' + match + '</strong>'
|
||||
})
|
||||
}
|
||||
|
||||
, render: function (items) {
|
||||
var that = this
|
||||
|
||||
items = $(items).map(function (i, item) {
|
||||
i = $(that.options.item).attr('data-value', item)
|
||||
i.find('a').html(that.highlighter(item))
|
||||
return i[0]
|
||||
})
|
||||
|
||||
items.first().addClass('active')
|
||||
this.$menu.html(items)
|
||||
return this
|
||||
}
|
||||
|
||||
, next: function (event) {
|
||||
var active = this.$menu.find('.active').removeClass('active')
|
||||
, next = active.next()
|
||||
|
||||
if (!next.length) {
|
||||
next = $(this.$menu.find('li')[0])
|
||||
}
|
||||
|
||||
next.addClass('active')
|
||||
}
|
||||
|
||||
, prev: function (event) {
|
||||
var active = this.$menu.find('.active').removeClass('active')
|
||||
, prev = active.prev()
|
||||
|
||||
if (!prev.length) {
|
||||
prev = this.$menu.find('li').last()
|
||||
}
|
||||
|
||||
prev.addClass('active')
|
||||
}
|
||||
|
||||
, listen: function () {
|
||||
this.$element
|
||||
.on('blur', $.proxy(this.blur, this))
|
||||
.on('keypress', $.proxy(this.keypress, this))
|
||||
.on('keyup', $.proxy(this.keyup, this))
|
||||
|
||||
if ($.browser.webkit || $.browser.msie) {
|
||||
this.$element.on('keydown', $.proxy(this.keypress, this))
|
||||
}
|
||||
|
||||
this.$menu
|
||||
.on('click', $.proxy(this.click, this))
|
||||
.on('mouseenter', 'li', $.proxy(this.mouseenter, this))
|
||||
}
|
||||
|
||||
, keyup: function (e) {
|
||||
switch(e.keyCode) {
|
||||
case 40: // down arrow
|
||||
case 38: // up arrow
|
||||
break
|
||||
|
||||
case 9: // tab
|
||||
case 13: // enter
|
||||
if (!this.shown) return
|
||||
this.select()
|
||||
break
|
||||
|
||||
case 27: // escape
|
||||
if (!this.shown) return
|
||||
this.hide()
|
||||
break
|
||||
|
||||
default:
|
||||
this.lookup()
|
||||
}
|
||||
|
||||
e.stopPropagation()
|
||||
e.preventDefault()
|
||||
}
|
||||
|
||||
, keypress: function (e) {
|
||||
if (!this.shown) return
|
||||
|
||||
switch(e.keyCode) {
|
||||
case 9: // tab
|
||||
case 13: // enter
|
||||
case 27: // escape
|
||||
e.preventDefault()
|
||||
break
|
||||
|
||||
case 38: // up arrow
|
||||
if (e.type != 'keydown') break
|
||||
e.preventDefault()
|
||||
this.prev()
|
||||
break
|
||||
|
||||
case 40: // down arrow
|
||||
if (e.type != 'keydown') break
|
||||
e.preventDefault()
|
||||
this.next()
|
||||
break
|
||||
}
|
||||
|
||||
e.stopPropagation()
|
||||
}
|
||||
|
||||
, blur: function (e) {
|
||||
var that = this
|
||||
setTimeout(function () { that.hide() }, 150)
|
||||
}
|
||||
|
||||
, click: function (e) {
|
||||
e.stopPropagation()
|
||||
e.preventDefault()
|
||||
this.select()
|
||||
}
|
||||
|
||||
, mouseenter: function (e) {
|
||||
this.$menu.find('.active').removeClass('active')
|
||||
$(e.currentTarget).addClass('active')
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
/* TYPEAHEAD PLUGIN DEFINITION
|
||||
* =========================== */
|
||||
|
||||
$.fn.typeahead = function (option) {
|
||||
return this.each(function () {
|
||||
var $this = $(this)
|
||||
, data = $this.data('typeahead')
|
||||
, options = typeof option == 'object' && option
|
||||
if (!data) $this.data('typeahead', (data = new Typeahead(this, options)))
|
||||
if (typeof option == 'string') data[option]()
|
||||
})
|
||||
}
|
||||
|
||||
$.fn.typeahead.defaults = {
|
||||
source: []
|
||||
, items: 8
|
||||
, menu: '<ul class="typeahead dropdown-menu"></ul>'
|
||||
, item: '<li><a href="#"></a></li>'
|
||||
}
|
||||
|
||||
$.fn.typeahead.Constructor = Typeahead
|
||||
|
||||
|
||||
/* TYPEAHEAD DATA-API
|
||||
* ================== */
|
||||
|
||||
$(function () {
|
||||
$('body').on('focus.typeahead.data-api', '[data-provide="typeahead"]', function (e) {
|
||||
var $this = $(this)
|
||||
if ($this.data('typeahead')) return
|
||||
e.preventDefault()
|
||||
$this.typeahead($this.data())
|
||||
})
|
||||
})
|
||||
|
||||
}(window.jQuery);
|
Before Width: | Height: | Size: 50 B |
@ -1,490 +0,0 @@
|
||||
|
||||
/* BonBon Buttons 1.1 by simurai.com
|
||||
|
||||
1.1 Added unprefixed attributes, :focus style, <button> support
|
||||
1.0 Released
|
||||
|
||||
Usage:
|
||||
|
||||
Default button: <a href="" class="button">Label</a>
|
||||
More fancy with icon: <a href="" class="button orange glossy" data-icon="★">Label</a>
|
||||
|
||||
Following additional class names are supported:
|
||||
|
||||
Color: orange, pink, blue, green, transparent
|
||||
Font: serif
|
||||
Material: glossy, glass
|
||||
Size: xs, xl
|
||||
Shape: round, oval, brackets, skew, back, knife, shield, drop, morph
|
||||
Icon only: icon
|
||||
Disabled: disabled
|
||||
|
||||
*/
|
||||
|
||||
|
||||
@import url(http://fonts.googleapis.com/css?family=Droid+Sans:bold+Lobster);
|
||||
@import url(http://fonts.googleapis.com/css?family=Lobster);
|
||||
|
||||
|
||||
/* -------------- THE button -------------- */
|
||||
.button {
|
||||
|
||||
/* text */
|
||||
text-decoration: none;
|
||||
font: 24px/1em 'Droid Sans', sans-serif;
|
||||
font-weight: bold;
|
||||
text-shadow: rgba(255,255,255,.5) 0 1px 0;
|
||||
-webkit-user-select: none;
|
||||
-moz-user-select: none;
|
||||
user-select: none;
|
||||
|
||||
|
||||
/* layout */
|
||||
/*
|
||||
padding: .5em .6em .4em .6em;
|
||||
margin: .5em;
|
||||
*/
|
||||
padding: .4em .4em .4em .4em;
|
||||
margin: .3em;
|
||||
display: inline-block;
|
||||
position: relative;
|
||||
|
||||
-webkit-border-radius: 8px;
|
||||
-moz-border-radius: 8px;
|
||||
border-radius: 8px;
|
||||
|
||||
/* effects */
|
||||
border-top: 1px solid rgba(255,255,255,0.8);
|
||||
border-bottom: 1px solid rgba(0,0,0,0.1);
|
||||
|
||||
background-image: -webkit-gradient(radial, 50% 0, 100, 50% 0, 0, from( rgba(255,255,255,0) ), to( rgba(255,255,255,0.7) )), url(noise.png);
|
||||
background-image: -moz-radial-gradient(top, ellipse cover, rgba(255,255,255,0.7) 0%, rgba(255,255,255,0) 100%), url(noise.png);
|
||||
background-image: gradient(radial, 50% 0, 100, 50% 0, 0, from( rgba(255,255,255,0) ), to( rgba(255,255,255,0.7) )), url(noise.png);
|
||||
|
||||
-webkit-transition: background .4s ease-in-out;
|
||||
-moz-transition: background .4s ease-in-out;
|
||||
transition: background .4s ease-in-out;
|
||||
|
||||
/* color */
|
||||
color: hsl(0, 0%, 40%) !important;
|
||||
background-color: hsl(0, 0%, 75%);
|
||||
|
||||
-webkit-box-shadow: inset rgba(255,254,255,0.6) 0 0.3em .3em, inset rgba(0,0,0,0.15) 0 -0.1em .3em, /* inner shadow */
|
||||
hsl(0, 0%, 60%) 0 .1em 3px, hsl(0, 0%, 45%) 0 .3em 1px, /* color border */
|
||||
rgba(0,0,0,0.2) 0 .5em 5px; /* drop shadow */
|
||||
-moz-box-shadow: inset rgba(255,254,255,0.6) 0 0.3em .3em, inset rgba(0,0,0,0.15) 0 -0.1em .3em, /* inner shadow */
|
||||
hsl(0, 0%, 60%) 0 .1em 3px, hsl(0, 0%, 45%) 0 .3em 1px, /* color border */
|
||||
rgba(0,0,0,0.2) 0 .5em 5px; /* drop shadow */
|
||||
box-shadow: inset rgba(255,254,255,0.6) 0 0.3em .3em, inset rgba(0,0,0,0.15) 0 -0.1em .3em, /* inner shadow */
|
||||
hsl(0, 0%, 60%) 0 .1em 3px, hsl(0, 0%, 45%) 0 .3em 1px, /* color border */
|
||||
rgba(0,0,0,0.2) 0 .5em 5px; /* drop shadow */
|
||||
}
|
||||
|
||||
/* -------------- button (tag) -------------- */
|
||||
|
||||
button.button {
|
||||
border-left: none;
|
||||
border-right: none;
|
||||
}
|
||||
button.button:hover {
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
|
||||
/* -------------- icon -------------- */
|
||||
.button:before {
|
||||
font: 1.2em/0 sans-serif;
|
||||
content: attr(data-icon); /* gets the icon value from the custom data attribute and puts it infront of the button label */
|
||||
margin-right: 0.4em;
|
||||
}
|
||||
|
||||
|
||||
/* icon only */
|
||||
.icon {
|
||||
font-weight: normal;
|
||||
font-style: normal;
|
||||
text-indent: -999em;
|
||||
}
|
||||
.icon:before {
|
||||
margin-right: 0;
|
||||
display: block;
|
||||
height: 0;
|
||||
text-indent: 0px;
|
||||
line-height: .75em;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* -------------- colours -------------- */
|
||||
|
||||
.button.orange {
|
||||
color: hsl(39, 100%, 30%) !important;
|
||||
background-color: hsl(39, 100%, 50%);
|
||||
|
||||
-webkit-box-shadow: inset rgba(255,254,255,0.6) 0 0.3em .3em, inset rgba(0,0,0,0.15) 0 -0.1em .3em, /* inner shadow */
|
||||
hsl(39, 100%, 40%) 0 .1em 3px, hsl(39, 100%, 30%) 0 .3em 1px, /* color border */
|
||||
rgba(0,0,0,0.2) 0 .5em 5px; /* drop shadow */
|
||||
-moz-box-shadow: inset rgba(255,254,255,0.6) 0 0.3em .3em, inset rgba(0,0,0,0.15) 0 -0.1em .3em, /* inner shadow */
|
||||
hsl(39, 100%, 40%) 0 .1em 3px, hsl(39, 100%, 30%) 0 .3em 1px, /* color border */
|
||||
rgba(0,0,0,0.2) 0 .5em 5px; /* drop shadow */
|
||||
box-shadow: inset rgba(255,254,255,0.6) 0 0.3em .3em, inset rgba(0,0,0,0.15) 0 -0.1em .3em, /* inner shadow */
|
||||
hsl(39, 100%, 40%) 0 .1em 3px, hsl(39, 100%, 30%) 0 .3em 1px, /* color border */
|
||||
rgba(0,0,0,0.2) 0 .5em 5px; /* drop shadow */
|
||||
}
|
||||
.button.orange:hover { background-color: hsl(39, 100%, 65%); }
|
||||
|
||||
|
||||
.button.blue {
|
||||
color: hsl(208, 50%, 40%) !important;
|
||||
background-color: hsl(208, 100%, 75%);
|
||||
|
||||
-webkit-box-shadow: inset rgba(255,254,255,0.6) 0 0.3em .3em, inset rgba(0,0,0,0.15) 0 -0.1em .3em, /* inner shadow */
|
||||
hsl(208, 50%, 55%) 0 .1em 3px, hsl(208, 50%, 40%) 0 .3em 1px, /* color border */
|
||||
rgba(0,0,0,0.2) 0 .5em 5px; /* drop shadow */
|
||||
-moz-box-shadow: inset rgba(255,254,255,0.6) 0 0.3em .3em, inset rgba(0,0,0,0.15) 0 -0.1em .3em, /* inner shadow */
|
||||
hsl(208, 50%, 55%) 0 .1em 3px, hsl(208, 50%, 40%) 0 .3em 1px, /* color border */
|
||||
rgba(0,0,0,0.2) 0 .5em 5px; /* drop shadow */
|
||||
box-shadow: inset rgba(255,254,255,0.6) 0 0.3em .3em, inset rgba(0,0,0,0.15) 0 -0.1em .3em, /* inner shadow */
|
||||
hsl(208, 50%, 55%) 0 .1em 3px, hsl(208, 50%, 40%) 0 .3em 1px, /* color border */
|
||||
rgba(0,0,0,0.2) 0 .5em 5px; /* drop shadow */
|
||||
}
|
||||
.button.blue:hover { background-color: hsl(208, 100%, 83%); }
|
||||
|
||||
.button.green {
|
||||
color: hsl(88, 70%, 30%) !important;
|
||||
background-color: hsl(88, 70%, 60%);
|
||||
-webkit-box-shadow: inset rgba(255,254,255,0.6) 0 0.3em .3em, inset rgba(0,0,0,0.15) 0 -0.1em .3em, /* inner shadow */
|
||||
hsl(88, 70%, 40%) 0 .1em 3px, hsl(88, 70%, 30%) 0 .3em 1px, /* color border */
|
||||
rgba(0,0,0,0.2) 0 .5em 5px; /* drop shadow */
|
||||
-moz-box-shadow: inset rgba(255,254,255,0.6) 0 0.3em .3em, inset rgba(0,0,0,0.15) 0 -0.1em .3em, /* inner shadow */
|
||||
hsl(88, 70%, 40%) 0 .1em 3px, hsl(88, 70%, 30%) 0 .3em 1px, /* color border */
|
||||
rgba(0,0,0,0.2) 0 .5em 5px; /* drop shadow */
|
||||
box-shadow: inset rgba(255,254,255,0.6) 0 0.3em .3em, inset rgba(0,0,0,0.15) 0 -0.1em .3em, /* inner shadow */
|
||||
hsl(88, 70%, 40%) 0 .1em 3px, hsl(88, 70%, 30%) 0 .3em 1px, /* color border */
|
||||
rgba(0,0,0,0.2) 0 .5em 5px; /* drop shadow */
|
||||
}
|
||||
.button.green:hover { background-color: hsl(88, 70%, 75%); }
|
||||
|
||||
.button.pink {
|
||||
color: hsl(340, 100%, 30%) !important;
|
||||
background-color: hsl(340, 100%, 75%);
|
||||
-webkit-box-shadow: inset rgba(255,254,255,0.6) 0 0.3em .3em, inset rgba(0,0,0,0.15) 0 -0.1em .3em, /* inner shadow */
|
||||
hsl(340, 70%, 50%) 0 .1em 3px, hsl(340, 80%, 40%) 0 .3em 1px, /* color border */
|
||||
rgba(0,0,0,0.2) 0 .5em 5px; /* drop shadow */
|
||||
-moz-box-shadow: inset rgba(255,254,255,0.6) 0 0.3em .3em, inset rgba(0,0,0,0.15) 0 -0.1em .3em, /* inner shadow */
|
||||
hsl(340, 70%, 50%) 0 .1em 3px, hsl(340, 80%, 40%) 0 .3em 1px, /* color border */
|
||||
rgba(0,0,0,0.2) 0 .5em 5px; /* drop shadow */
|
||||
box-shadow: inset rgba(255,254,255,0.6) 0 0.3em .3em, inset rgba(0,0,0,0.15) 0 -0.1em .3em, /* inner shadow */
|
||||
hsl(340, 70%, 50%) 0 .1em 3px, hsl(340, 80%, 40%) 0 .3em 1px, /* color border */
|
||||
rgba(0,0,0,0.2) 0 .5em 5px; /* drop shadow */
|
||||
}
|
||||
.button.pink:hover { background-color: hsl(340, 100%, 83%); }
|
||||
|
||||
|
||||
|
||||
.button.transparent {
|
||||
color: rgba(0,0,0,0.5) !important;
|
||||
}
|
||||
.button.transparent, .button.transparent:hover, .button.transparent:active {
|
||||
background-color: transparent;
|
||||
background-image: none;
|
||||
}
|
||||
.button.transparent:hover {
|
||||
opacity: .9;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* -------------- States -------------- */
|
||||
|
||||
.button:hover {
|
||||
background-color: hsl(0, 0%, 83%);
|
||||
}
|
||||
|
||||
|
||||
|
||||
.button:active {
|
||||
background-image: -webkit-gradient(radial, 50% 0, 100, 50% 0, 0, from( rgba(255,255,255,0) ), to( rgba(255,255,255,0) )), url(noise.png);
|
||||
background-image: -moz-gradient(radial, 50% 0, 100, 50% 0, 0, from( rgba(255,255,255,0) ), to( rgba(255,255,255,0) )), url(noise.png);
|
||||
background-image: gradient(radial, 50% 0, 100, 50% 0, 0, from( rgba(255,255,255,0) ), to( rgba(255,255,255,0) )), url(noise.png);
|
||||
|
||||
-webkit-box-shadow: inset rgba(255,255,255,0.6) 0 0.3em .3em, inset rgba(0,0,0,0.2) 0 -0.1em .3em, /* inner shadow */
|
||||
rgba(0,0,0,0.4) 0 .1em 1px, /* border */
|
||||
rgba(0,0,0,0.2) 0 .2em 6px; /* drop shadow */
|
||||
-moz-box-shadow: inset rgba(255,255,255,0.6) 0 0.3em .3em, inset rgba(0,0,0,0.2) 0 -0.1em .3em, /* inner shadow */
|
||||
rgba(0,0,0,0.4) 0 .1em 1px, /* border */
|
||||
rgba(0,0,0,0.2) 0 .2em 6px; /* drop shadow */
|
||||
box-shadow: inset rgba(255,255,255,0.6) 0 0.3em .3em, inset rgba(0,0,0,0.2) 0 -0.1em .3em, /* inner shadow */
|
||||
rgba(0,0,0,0.4) 0 .1em 1px, /* border */
|
||||
rgba(0,0,0,0.2) 0 .2em 6px; /* drop shadow */
|
||||
|
||||
-webkit-transform: translateY(.2em);
|
||||
-moz-transform: translateY(.2em);
|
||||
transform: translateY(.2em);
|
||||
}
|
||||
|
||||
.button:focus {
|
||||
outline: none;
|
||||
color: rgba(254,255,255,0.9) !important;
|
||||
text-shadow: rgba(0,0,0,0.2) 0 1px 2px;
|
||||
}
|
||||
|
||||
|
||||
.button[disabled], .button[disabled]:hover, .button.disabled, .button.disabled:hover {
|
||||
opacity: .5;
|
||||
cursor: default;
|
||||
color: rgba(0,0,0,0.2) !important;
|
||||
text-shadow: none !important;
|
||||
background-color: rgba(0,0,0,0.05);
|
||||
background-image: none;
|
||||
border-top: none;
|
||||
|
||||
-webkit-box-shadow: inset rgba(255,254,255,0.4) 0 0.3em .3em, inset rgba(0,0,0,0.1) 0 -0.1em .3em, /* inner shadow */
|
||||
rgba(0,0,0,0.3) 0 .1em 1px, /* border */
|
||||
rgba(0,0,0,0.2) 0 .2em 6px; /* drop shadow */
|
||||
-moz-box-shadow: inset rgba(255,254,255,0.4) 0 0.3em .3em, inset rgba(0,0,0,0.1) 0 -0.1em .3em, /* inner shadow */
|
||||
rgba(0,0,0,0.3) 0 .1em 1px, /* border */
|
||||
rgba(0,0,0,0.2) 0 .2em 6px; /* drop shadow */
|
||||
box-shadow: inset rgba(255,254,255,0.4) 0 0.3em .3em, inset rgba(0,0,0,0.1) 0 -0.1em .3em, /* inner shadow */
|
||||
rgba(0,0,0,0.3) 0 .1em 1px, /* border */
|
||||
rgba(0,0,0,0.2) 0 .2em 6px; /* drop shadow */
|
||||
|
||||
-webkit-transform: translateY(5px);
|
||||
-moz-transform: translateY(5px);
|
||||
transform: translateY(5px);
|
||||
}
|
||||
|
||||
/* -------------- Fonts -------------- */
|
||||
|
||||
.serif {
|
||||
font-family: 'Lobster', serif;
|
||||
font-weight: normal;
|
||||
}
|
||||
|
||||
|
||||
/* -------------- Sizes -------------- */
|
||||
|
||||
.xs { font-size: 16px; }
|
||||
.xl { font-size: 32px; }
|
||||
|
||||
|
||||
/* -------------- Materials -------------- */
|
||||
|
||||
.button.glossy:after, .button.glass:after {
|
||||
content: "";
|
||||
position: absolute;
|
||||
width: 90%;
|
||||
height: 60%;
|
||||
top: 0;
|
||||
left: 5%;
|
||||
|
||||
-webkit-border-radius: .5em .5em 1em 1em / .5em .5em 2em 2em;
|
||||
-moz-border-radius: .5em .5em 1em 1em / .5em .5em 2em 2em;
|
||||
border-radius: .5em .5em 1em 1em / .5em .5em 2em 2em;
|
||||
|
||||
background-image: -webkit-gradient(linear, 0% 0, 100% 0, from( rgba(255,255,255,.55) ), to( rgba(255,255,255,.5) ),
|
||||
color-stop(.5, rgba(255,255,255,0)), color-stop(.8, rgba(255,255,255,0)) );
|
||||
background-image: -moz-linear-gradient(left, rgba(255,255,255,.55), rgba(255,255,255,0) 50%, rgba(255,255,255,0) 80%, rgba(255,255,255,.5) );
|
||||
background-image: gradient(linear, 0% 0, 100% 0, from( rgba(255,255,255,.55) ), to( rgba(255,255,255,.5) ),
|
||||
color-stop(.5, rgba(255,255,255,0)), color-stop(.8, rgba(255,255,255,0)) );
|
||||
}
|
||||
.button.glossy:active:after,
|
||||
.button.glass:active:after,
|
||||
.button.disabled:after,
|
||||
.button[disabled]:after
|
||||
{ opacity: .6; }
|
||||
|
||||
.button.icon.glossy:after,
|
||||
.button.icon.glass:after { height: 75% ; }
|
||||
|
||||
/* -------------- Glass + Transparent -------------- */
|
||||
.button.glass {
|
||||
text-shadow: rgba(255,255,255,.5) 0 -1px 0, rgba(0,0,0,0.18) 0 .18em .15em;
|
||||
}
|
||||
.button.glass:active {
|
||||
text-shadow: rgba(255,255,255,.3) 0 1px 0, rgba(0,0,0,0.15) 0 .18em .15em;
|
||||
}
|
||||
|
||||
|
||||
/* -------------- Shapes -------------- */
|
||||
|
||||
/* round */
|
||||
.round, .round.glossy:after, .round.glass:after {
|
||||
border-top: none;
|
||||
-webkit-border-radius: 1em;
|
||||
-moz-border-radius: 1em;
|
||||
border-radius: 1em;
|
||||
}
|
||||
|
||||
/* oval */
|
||||
.oval {
|
||||
border-top: none;
|
||||
padding-left: .8em;
|
||||
padding-right: .8em;
|
||||
-webkit-border-radius: 5em / 2em;
|
||||
-moz-border-radius: 5em / 2em;
|
||||
border-radius: 5em / 2em;
|
||||
}
|
||||
.oval.glossy:after, .oval.glass:after {
|
||||
top: 5%;
|
||||
-webkit-border-radius: 5em / 2em 2em 1em 1em;
|
||||
-moz-border-radius: 5em / 2em 2em 1em 1em;
|
||||
border-radius: 5em / 2em 2em 1em 1em;
|
||||
}
|
||||
.oval.icon {
|
||||
padding-left: .8em;
|
||||
padding-right: .8em;
|
||||
-webkit-border-radius: 1.5em / 1em;
|
||||
-moz-border-radius: 1.5em / 1em;
|
||||
border-radius: 1.5em / 1em;
|
||||
}
|
||||
.oval.icon.glossy:after, .oval.icon.glass:after {
|
||||
-webkit-border-radius: 1.5em / 1em;
|
||||
-moz-border-radius: 1.5em / 1em;
|
||||
border-radius: 1.5em / 1em;
|
||||
}
|
||||
|
||||
/* brackets */
|
||||
.brackets, .brackets.glossy:after, .brackets.glass:after {
|
||||
border-top: none;
|
||||
-webkit-border-radius: .5em / 1em;
|
||||
-moz-border-radius: .5em / 1em;
|
||||
border-radius: .5em / 1em;
|
||||
}
|
||||
|
||||
/* skew */
|
||||
.skew {
|
||||
border-top: none;
|
||||
padding-right: 1.2em;
|
||||
padding-left: 0.8em;
|
||||
-webkit-border-radius: 5em 1em / 5em 1em;
|
||||
-moz-border-radius: 5em 1em / 5em 1em;
|
||||
border-radius: 5em 1em / 5em 1em;
|
||||
}
|
||||
.skew.glossy:after, .skew.glass:after {
|
||||
left: 10%;
|
||||
-webkit-border-radius: 7em 1em / 5em 1em;
|
||||
-moz-border-radius: 7em 1em / 5em 1em;
|
||||
border-radius: 7em 1em / 5em 1em;
|
||||
}
|
||||
.skew.icon {
|
||||
padding-right: .9em;
|
||||
padding-left: .8em;
|
||||
}
|
||||
|
||||
/* back */
|
||||
.back, .back.glossy:after, .back.glass:after {
|
||||
border-top-color: rgba(255,255,255,0.5);
|
||||
-webkit-border-radius: 1.6em 1.6em 1em 1em / 4em 4em 1em 1em;
|
||||
-moz-border-radius: 1.6em 1.6em 1em 1em / 4em 4em 1em 1em;
|
||||
border-radius: 1.6em 1.6em 1em 1em / 4em 4em 1em 1em;
|
||||
}
|
||||
.back.glossy:after, .back.glass:after {
|
||||
left: 6%;
|
||||
width: 88%;
|
||||
}
|
||||
|
||||
/* knife */
|
||||
.knife {
|
||||
padding-left: 1.5em;
|
||||
-webkit-border-radius: .2em .5em .5em 8em / .2em .5em .5em 5em;
|
||||
-moz-border-radius: .2em .5em .5em 8em / .2em .5em .5em 5em;
|
||||
border-radius: .2em .5em .5em 8em / .2em .5em .5em 5em;
|
||||
}
|
||||
.knife.glossy:after, .knife.glass:after {
|
||||
left: 3%;
|
||||
width: 97%;
|
||||
-webkit-border-radius: .1em .5em .5em 8em / .1em .5em .5em 2em;
|
||||
-moz-border-radius: .1em .5em .5em 8em / .1em .5em .5em 2em;
|
||||
border-radius: .1em .5em .5em 8em / .1em .5em .5em 2em;
|
||||
}
|
||||
.knife.glossy.icon:after, .knife.glass.icon:after {
|
||||
left: 5%;
|
||||
width: 95%;
|
||||
-webkit-border-radius: .5em .5em 1em 6em / .5em .5em 1em 4em;
|
||||
-moz-border-radius: .5em .5em 1em 6em / .5em .5em 1em 4em;
|
||||
border-radius: .5em .5em 1em 6em / .5em .5em 1em 4em;
|
||||
}
|
||||
|
||||
/* shield */
|
||||
.shield, .shield.glossy:after, .shield.glass:after {
|
||||
-webkit-border-radius: .4em .4em 2em 2em / .4em .4em 3em 3em;
|
||||
-moz-border-radius: .4em .4em 2em 2em / .4em .4em 3em 3em;
|
||||
border-radius: .4em .4em 2em 2em / .4em .4em 3em 3em;
|
||||
}
|
||||
.shield {
|
||||
padding-left: .8em;
|
||||
padding-right: .8em;
|
||||
}
|
||||
.shield.icon {
|
||||
padding-left: .6em;
|
||||
padding-right: .6em;
|
||||
}
|
||||
|
||||
/* drop */
|
||||
.drop {
|
||||
border-top: none;
|
||||
-webkit-border-radius: 2em 5em 2em .6em / 2em 4em 2em .6em;
|
||||
-moz-border-radius: 2em 5em 2em .6em / 2em 4em 2em .6em;
|
||||
border-radius: 2em 5em 2em .6em / 2em 4em 2em .6em;
|
||||
}
|
||||
.drop.glossy:after, .drop.glass:after {
|
||||
left: 4%;
|
||||
-webkit-border-radius: 2em 6em 2em 1em / 2em 4em 2em 2em;
|
||||
-moz-border-radius: 2em 6em 2em 1em / 2em 4em 2em 2em;
|
||||
border-radius: 2em 6em 2em 1em / 2em 4em 2em 2em;
|
||||
}
|
||||
.drop.icon {
|
||||
padding-right: .6em;
|
||||
}
|
||||
|
||||
|
||||
/* morph */
|
||||
.morph {
|
||||
border-top: none;
|
||||
-webkit-border-radius: 5em / 2em;
|
||||
-moz-border-radius: 5em / 2em;
|
||||
border-radius: 5em / 2em;
|
||||
-webkit-transition: -webkit-border-radius .3s ease-in-out;
|
||||
-moz-transition: -moz-border-radius .3s ease-in-out;
|
||||
transition: -moz-border-radius .3s ease-in-out;
|
||||
}
|
||||
.morph:hover {
|
||||
-webkit-border-radius: .4em .4em 2em 2em / .4em .4em 3em 3em;
|
||||
-moz-border-radius: .4em .4em 2em 2em / .4em .4em 3em 3em;
|
||||
border-radius: .4em .4em 2em 2em / .4em .4em 3em 3em;
|
||||
}
|
||||
.morph:active {
|
||||
-webkit-border-radius: .3em;
|
||||
-moz-border-radius: .3em;
|
||||
border-radius: .3em;
|
||||
}
|
||||
.morph:after {
|
||||
display: none;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
/* Some ugly hacks for FF.
|
||||
Thanks to David Hund for some help - http://valuedstandards.com/static/test/buttons/ */
|
||||
@-moz-document url-prefix() {
|
||||
.button { text-align: center; }
|
||||
.icon { padding: .5em 1em; }
|
||||
.icon:before { margin-left: -.42em; float: left; }
|
||||
.social.icon:before { margin-left: -.22em; }
|
||||
|
||||
.drop.icon { padding-right: 1.1em; }
|
||||
.shield.icon { padding-left: 1.1em; padding-right: 1.1em; }
|
||||
.skew.icon { padding-right: 1.4em; padding-left: 1.3em; }
|
||||
.oval.icon { padding-left: 1.3em; padding-right: 1.3em; }
|
||||
.knife { padding-left: 2em; }
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
/* Damn, this became a fat baby.. */
|
||||
|
||||
|
||||
|
@ -1,24 +0,0 @@
|
||||
<div class="navbar-wrapper">
|
||||
<div class="container">
|
||||
|
||||
<div class="navbar navbar-default navbar-static-top" role="navigation">
|
||||
<div class="container">
|
||||
<div class="navbar-header">
|
||||
<button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse">
|
||||
<span class="icon-bar"></span>
|
||||
<span class="icon-bar"></span>
|
||||
<span class="icon-bar"></span>
|
||||
</button>
|
||||
<a class="navbar-brand" href="./index.html">ossoc</a>
|
||||
</div>
|
||||
<div class="collapse navbar-collapse">
|
||||
<ul class="nav navbar-nav navbar-right">
|
||||
<button id="loginbutton" type="button" class="btn btn-primary narbar-btn"><i class="glyphicon glyphicon-log-in"></i>Login</button>
|
||||
<button type="button" class="btn btn-success navbar-btn"><i class="glyphicon glyphicon-link"></i><a href="./register.jsp">Create account</a></button>
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
</div>
|
@ -1,124 +0,0 @@
|
||||
blockquote#quote {
|
||||
margin-top: 30px;
|
||||
margin-bottom: 30px;
|
||||
}
|
||||
|
||||
@font-face
|
||||
{
|
||||
font-family: 'GenBasI';
|
||||
src: url('/css/font/GenBasI.ttf');
|
||||
}
|
||||
|
||||
blockquote#quote p {
|
||||
/*
|
||||
font-family: "HelveticaNeue Light","Helvetica Neue Light","Helvetica Neue","Helvetica";
|
||||
*/
|
||||
font-family: 'GenBasI';
|
||||
font-weight: 100;
|
||||
font-size: 20px;
|
||||
line-height: 150%;
|
||||
}
|
||||
|
||||
img {
|
||||
/*background-color: #fff;*/
|
||||
padding: 5px;
|
||||
}
|
||||
img.tex {
|
||||
background-color: #ddd;
|
||||
}
|
||||
|
||||
body.mediawiki {
|
||||
padding-top: 0px;
|
||||
}
|
||||
|
||||
@media (min-width: 981px) {
|
||||
/*
|
||||
body.mediawiki {
|
||||
padding-top: 100px;
|
||||
}
|
||||
*/
|
||||
}
|
||||
|
||||
div.wikilink_btn a {
|
||||
color: #fff;
|
||||
font-weight: bold;
|
||||
font-size: 20px;
|
||||
}
|
||||
|
||||
.wikitable th,.wikitable td {
|
||||
border-top:1px solid #222; background: transparent;
|
||||
}
|
||||
|
||||
.wikitable th,.wikitable td{border-top:1px solid #222;}
|
||||
.wikitable tbody tr:hover th,.wikitable tbody tr:hover td{background-color:#444;}
|
||||
.wikitable tbody tr:hover td,.table tbody tr:hover th{background-color:#444;}
|
||||
.wikitable,.well,.prettyprint,input,textarea,select{-webkit-border-radius:1px;-moz-border-radius:1px;border-radius:1px;}
|
||||
.wikitable{width:100%;margin-bottom:18px;}.wikitable th,.wikitable td{padding:8px;line-height:18px;text-align:left;vertical-align:top;border-top:1px solid #dddddd;}
|
||||
.wikitable th{font-weight:bold;}
|
||||
.wikitable thead th{vertical-align:bottom;}
|
||||
.wikitable caption+thead tr:first-child th,.wikitable caption+thead tr:first-child td,.wikitable colgroup+thead tr:first-child th,.wikitable colgroup+thead tr:first-child td,.wikitable thead:first-child tr:first-child th,.wikitable thead:first-child tr:first-child td{border-top:0;}
|
||||
.wikitable tbody+tbody{border-top:2px solid #dddddd;}
|
||||
|
||||
.wikitable tbody tr:hover th,.wikitable tbody tr:hover td{background-color:#333;}
|
||||
.wikitable{width:100%;margin-bottom:18px;}.wikitable th,.wikitable td{padding:8px;line-height:18px;text-align:left;vertical-align:top;border-top:1px solid #dddddd;}
|
||||
.wikitable th{font-weight:bold;}
|
||||
.wikitable thead th{vertical-align:bottom;}
|
||||
.wikitable caption+thead tr:first-child th,.wikitable caption+thead tr:first-child td,.wikitable colgroup+thead tr:first-child th,.wikitable colgroup+thead tr:first-child td,.wikitable thead:first-child tr:first-child th,.wikitable thead:first-child tr:first-child td{border-top:0;}
|
||||
.wikitable tbody+tbody{border-top:2px solid #dddddd;}
|
||||
|
||||
table.wikitable, table.wikitable th {
|
||||
background: none repeat scroll 0 0 #222;
|
||||
}
|
||||
|
||||
/*
|
||||
ul, div {
|
||||
font-size: 18px;
|
||||
}
|
||||
*/
|
||||
|
||||
div#mw-normal-catlinks {
|
||||
font-size: 14px;
|
||||
margin-top: 20px;
|
||||
margin-bottom: 20px;
|
||||
}
|
||||
|
||||
table, table.navbox,
|
||||
table ul li, table.navbox ul li,
|
||||
table ul, table.navbox ul,
|
||||
table p, table.navbox p,
|
||||
table a, table.navbox a {
|
||||
font-size: 14px;
|
||||
}
|
||||
|
||||
h1, h2, h3, h4, h5 {
|
||||
padding-top: 20px;
|
||||
}
|
||||
|
||||
div.mw-geshi {
|
||||
font-size: 14px;
|
||||
}
|
||||
pre {
|
||||
font-size: 14px;
|
||||
}
|
||||
|
||||
div.mainarticle {
|
||||
font-size: 18px;
|
||||
}
|
||||
|
||||
a:visited {
|
||||
/*
|
||||
unvisited link color:
|
||||
color: #33b5e5;
|
||||
*/
|
||||
/*
|
||||
visited link color:
|
||||
http://www.w3schools.com/tags/ref_colorpicker.asp
|
||||
*/
|
||||
color: #2E8AE6;
|
||||
}
|
||||
|
||||
#toc, .toc,
|
||||
#catlinks, .catlinks {
|
||||
background-color: #333;
|
||||
}
|
||||
|
@ -1,81 +0,0 @@
|
||||
h1.hero {
|
||||
padding: 0px 45px;
|
||||
color: white;
|
||||
font: bold 24px/45pxHelvetica,Sans-Serif;
|
||||
letter-spacing:-1px;
|
||||
/*
|
||||
background: rgb(0,0,0);
|
||||
background: rgba(0,0,0,0.7);
|
||||
*/
|
||||
padding:10px;
|
||||
}
|
||||
|
||||
a.nav_well_title {
|
||||
font-variant: small-caps;
|
||||
}
|
||||
|
||||
.label-big{
|
||||
font-size:14px;
|
||||
line-height: 18px;
|
||||
}
|
||||
|
||||
h4.widgettitle {
|
||||
font-size: 18px;
|
||||
padding-top: 25px;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/*
|
||||
//////////////////////////////////
|
||||
make a hero unit that actually looks good with cyborg skin
|
||||
*/
|
||||
|
||||
h1.superhero {
|
||||
margin: 10px 0;
|
||||
font-family: inherit;
|
||||
font-weight: bold;
|
||||
color: #000;
|
||||
text-rendering: optimizelegibility;
|
||||
font-size: 60px;
|
||||
margin-bottom: 0;
|
||||
line-height: 1;
|
||||
letter-spacing: -1px;
|
||||
}
|
||||
|
||||
p.hero-unit {
|
||||
font-size: 18px;
|
||||
font-weight: 200;
|
||||
line-height: 30px;
|
||||
color: #333;
|
||||
}
|
||||
|
||||
.superhero td {
|
||||
padding: 30px;
|
||||
}
|
||||
|
||||
.hero-unit-no-padding {
|
||||
padding-top: 0px;
|
||||
padding-bottom: 0px;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
/*
|
||||
* use the nicest helvetica you can
|
||||
*/
|
||||
body, p {
|
||||
/*
|
||||
font-family: "HelveticaNeue-Light", "Helvetica Neue Light", "Helvetica Neue", Helvetica, "Lucida Grande", sans-serif;
|
||||
*/
|
||||
font-weight: 300;
|
||||
line-height: 150%;
|
||||
}
|
||||
|
||||
|
||||
/* give the navbar on the right more padding */
|
||||
#sidebar1{
|
||||
margin-left:20px;
|
||||
}
|
||||
|
@ -1,85 +0,0 @@
|
||||
/******** line-dot subway **********************/
|
||||
|
||||
div#subway {
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
html, body {
|
||||
/*height: 100%;*/
|
||||
}
|
||||
|
||||
path {
|
||||
stroke: #2780e3;
|
||||
stroke-width: 8px;
|
||||
|
||||
}
|
||||
|
||||
svg .data-point {
|
||||
stroke: black;
|
||||
stroke-width: 4px;
|
||||
fill: white;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
/******************************/
|
||||
|
||||
|
||||
|
||||
.vcenter {
|
||||
}
|
||||
|
||||
.col-centered{
|
||||
float: none;
|
||||
margin: 0 auto;
|
||||
}
|
||||
|
||||
.splash-img {
|
||||
width: 300px;
|
||||
height: 300px;
|
||||
}
|
||||
|
||||
h1.jumbo {
|
||||
font-size: 64px;
|
||||
}
|
||||
|
||||
h1.jumbojumbo {
|
||||
font-size: 78px;
|
||||
}
|
||||
|
||||
a.index-btn {
|
||||
width: 300px;
|
||||
margin-top: 10px;
|
||||
margin-bottom: 10px;
|
||||
margin-left: 15px;
|
||||
margin-right: 15px;
|
||||
}
|
||||
|
||||
.navbar-default {
|
||||
background-color: #000;
|
||||
border-color: #000;
|
||||
}
|
||||
|
||||
div.v300 {
|
||||
height: 300px;
|
||||
}
|
||||
|
||||
div.v200 {
|
||||
height: 200px;
|
||||
}
|
||||
|
||||
div.v150 {
|
||||
height: 150px;
|
||||
}
|
||||
|
||||
div.v50 {
|
||||
height: 50px;
|
||||
}
|
||||
|
||||
hr {
|
||||
text-align: center;
|
||||
width: 100px;
|
||||
}
|
||||
|
||||
|
Before Width: | Height: | Size: 434 KiB |
@ -1,53 +0,0 @@
|
||||
<br />
|
||||
<br />
|
||||
<center>
|
||||
<hr />
|
||||
</center>
|
||||
<footer id="contentinfo" class="body">
|
||||
<p style="text-align: center">
|
||||
<span class="fa-stack fa-lg">
|
||||
<i class="fa fa-square fa-stack-2x" style="color:#000;"></i>
|
||||
<i class="fa fa-terminal fa-stack-1x fa-inverse"></i>
|
||||
</span>
|
||||
Made from the command line with vim by
|
||||
<a href="http://charlesreid1.com">charlesreid1</a><br />
|
||||
with help from <a href="https://getbootstrap.com/">Bootstrap</a> and <a href="http://mediawiki.org">MediaWiki</a>.
|
||||
</p>
|
||||
|
||||
<p style="text-align: center">
|
||||
<a rel="license" href="http://creativecommons.org/licenses/by-nc/4.0/">
|
||||
<span class="fa-stack fa-lg">
|
||||
<i class="fa fa-square fa-stack-2x" style="color:#000;"></i>
|
||||
<i class="fa fa-creative-commons fa-stack-1x fa-inverse"></i>
|
||||
</span>
|
||||
</a>
|
||||
<br />
|
||||
Licensed under the <a rel="license" href="http://creativecommons.org/licenses/by-nc/4.0/">Creative Commons Attribution-NonCommercial 4.0 License</a>.
|
||||
</p>
|
||||
|
||||
<script type="text/javascript">
|
||||
var sc_project=11477000;
|
||||
var sc_invisible=1;
|
||||
var sc_security="d49adba3";
|
||||
var scJsHost = (("https:" == document.location.protocol) ?
|
||||
"https://secure." : "http://www.");
|
||||
document.write("<sc"+"ript type='text/javascript' src='" +
|
||||
scJsHost+
|
||||
"statcounter.com/counter/counter.js'></"+"script>");
|
||||
</script>
|
||||
<noscript><div class="statcounter"><a title="Web Analytics"
|
||||
href="http://statcounter.com/" target="_blank"><img
|
||||
class="statcounter"
|
||||
src="//c.statcounter.com/11477000/0/d49adba3/1/" alt="Web
|
||||
Analytics"></a></div></noscript>
|
||||
<!-- End of StatCounter Code for Default Guide -->
|
||||
|
||||
<script type="text/javascript" src="/w/skins/Bootstrap2/jquery-1.11.2.js"></script>
|
||||
<script type="text/javascript" src="/w/skins/Bootstrap2/bootstrap-3.3.4.js"></script>
|
||||
|
||||
</footer><!-- /#contentinfo -->
|
||||
|
||||
</body>
|
||||
</html>
|
||||
|
||||
|
Before Width: | Height: | Size: 7.7 KiB |
@ -1,19 +0,0 @@
|
||||
<!DOCTYPE html>
|
||||
<!--
|
||||
<meta content="text/html;charset=utf-8" http-equiv="Content-Type">
|
||||
<meta content="utf-8" http-equiv="encoding">
|
||||
-->
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<title>charlesreid1 - <?php echo $this->html('title'); ?></title>
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<meta name="description" content="">
|
||||
<meta name="author" content="">
|
||||
|
||||
</head>
|
||||
<body>
|
||||
|
||||
|
||||
|
||||
|
@ -1,8 +0,0 @@
|
||||
Hooks provided by the MonoBook skin.
|
||||
|
||||
'MonoBookTemplateToolboxEnd': DEPRECATED. Called by Monobook skin after toolbox
|
||||
links have been rendered (useful for adding more). Note: this is only run for
|
||||
the Monobook skin. To add items to the toolbox you should use the
|
||||
SkinTemplateToolboxEnd hook instead, which works for all "SkinTemplate"-type
|
||||
skins.
|
||||
$tools: array of tools
|
@ -1,9 +0,0 @@
|
||||
{
|
||||
"@metadata": {
|
||||
"authors": []
|
||||
},
|
||||
"skinname-monobook": "MonoBook",
|
||||
"monobook-desc": "The classic MediaWiki skin since 2004, named after the black-and-white photo of a book in the page background",
|
||||
"monobook.css": "/* CSS placed here will affect users of the MonoBook skin */",
|
||||
"monobook.js": "/* Any JavaScript here will be loaded for users using the MonoBook skin */"
|
||||
}
|
@ -1,105 +0,0 @@
|
||||
.text-heading {
|
||||
font-family: "Lucida Console";
|
||||
font-size: 24px;
|
||||
font-style: normal;
|
||||
font-weight: bold;
|
||||
text-transform: none;
|
||||
letter-spacing: 4px;
|
||||
text-indent: 10px;
|
||||
vertical-align: middle;
|
||||
color: #0066CC;
|
||||
}
|
||||
|
||||
.text {
|
||||
font-family: Verdana, Arial, Helvetica, sans-serif;
|
||||
font-size: 11px;
|
||||
padding-left: 10px;
|
||||
padding-right: 10px;
|
||||
color: #666666;
|
||||
text-align: justify;
|
||||
}
|
||||
.footer {
|
||||
font-family: Verdana, Arial, Helvetica, sans-serif;
|
||||
font-size: 10px;
|
||||
color: #666666;
|
||||
text-align: center;
|
||||
border: 1px none #6699CC;
|
||||
background-color: #0099CC;
|
||||
}
|
||||
.table2 {
|
||||
border: 1px dotted #000066;
|
||||
}
|
||||
.company {
|
||||
font-family: "Lucida Console";
|
||||
font-size: 30px;
|
||||
color: #0066CC;
|
||||
text-align: left;
|
||||
vertical-align: middle;
|
||||
letter-spacing: 8px;
|
||||
font-weight: normal;
|
||||
}
|
||||
.punchline {
|
||||
font-family: Arial, Helvetica, sans-serif;
|
||||
font-size: 11px;
|
||||
color: #003366;
|
||||
letter-spacing: 4px;
|
||||
}
|
||||
.menu {
|
||||
font-family: Verdana, Arial, Helvetica, sans-serif;
|
||||
font-size: 11px;
|
||||
color: #0066CC;
|
||||
text-align: center;
|
||||
vertical-align: middle;
|
||||
border: 1px solid #000000;
|
||||
background-color: #C7D3F1;
|
||||
}
|
||||
|
||||
.submenu {
|
||||
font-family: Verdana, Arial, Helvetica, sans-serif;
|
||||
font-size: 11px;
|
||||
font-weight: lighter;
|
||||
color: #0066CC;
|
||||
text-align: center;
|
||||
vertical-align: middle;
|
||||
background-color: #E1E8F8;
|
||||
border-top: 1px solid #000000;
|
||||
border-right: 1px none #000000;
|
||||
border-bottom: 1px solid #000000;
|
||||
border-left: 1px none #000000;
|
||||
}
|
||||
|
||||
|
||||
.headtable {
|
||||
border: 1px dotted #0066CC;
|
||||
}
|
||||
.header {
|
||||
background-image: url(../images/bk.jpg);
|
||||
border: 1px dotted #003399;
|
||||
}
|
||||
|
||||
a {
|
||||
font-family: Verdana, Arial, Helvetica, sans-serif;
|
||||
font-size: 14px;
|
||||
color: #14388B;
|
||||
text-decoration: none;
|
||||
font-weight: bold;
|
||||
}
|
||||
a:hover {
|
||||
font-family: Verdana, Arial, Helvetica, sans-serif;
|
||||
color: #333399;
|
||||
text-decoration: none;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
body {
|
||||
font-family: Verdana, Arial, Helvetica, sans-serif;
|
||||
font-size: 18px;
|
||||
color: #339;
|
||||
color: #a00;
|
||||
text-decoration: none;
|
||||
background-color: #ddd;
|
||||
}
|
||||
|
||||
p {
|
||||
font-size: 14px;
|
||||
}
|
Before Width: | Height: | Size: 4.3 KiB |
Before Width: | Height: | Size: 342 B |
Before Width: | Height: | Size: 170 B |
@ -1,747 +0,0 @@
|
||||
/*
|
||||
MediaWiki stuff
|
||||
*/
|
||||
|
||||
@import url("../common.css");
|
||||
|
||||
/* disabled for now
|
||||
blockquote {
|
||||
font-family: Times, "Times New Roman", serif;
|
||||
font-style: italic;
|
||||
}*/
|
||||
/*
|
||||
code {
|
||||
background-color: #f9f9f9;
|
||||
}
|
||||
*/
|
||||
|
||||
img {
|
||||
text-decoration: none;
|
||||
border: none;
|
||||
}
|
||||
p img {
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
#navtable table {
|
||||
border: solid 1px darkblue;
|
||||
}
|
||||
#navtable{
|
||||
font-family:"Lucida Sans Unicode", "Lucida Grande", Sans-Serif;
|
||||
font-size:12px;width:480px;
|
||||
text-align:left;
|
||||
/*
|
||||
border-collapse:collapse;
|
||||
border:1px solid #69c;
|
||||
*/
|
||||
margin:20px;
|
||||
}
|
||||
#navtable a{
|
||||
font-family:"Lucida Sans Unicode", "Lucida Grande", Sans-Serif;
|
||||
font-size:12px;
|
||||
}
|
||||
#navtable th {
|
||||
font-weight:normal;
|
||||
font-size:14px;
|
||||
color:#039;
|
||||
border-bottom:1px dashed #69c;
|
||||
padding:12px 17px;
|
||||
}
|
||||
#navtable td{
|
||||
color:#669;
|
||||
padding:7px 17px;
|
||||
}
|
||||
#navtable tbody {
|
||||
border: darkblue;
|
||||
color:#339;
|
||||
background:#d0dafd;
|
||||
}
|
||||
#navtable tbody tr:hover td{
|
||||
color:#339;
|
||||
background:#d0dafd;
|
||||
}
|
||||
|
||||
pre {
|
||||
width: auto;
|
||||
overflow: auto;
|
||||
padding: 1em;
|
||||
border: 1px dashed #2f6fab;
|
||||
color: black;
|
||||
background-color: #f9f9f9;
|
||||
line-height: 1.1em;
|
||||
/* "overflow: auto" prevent ugly horizontal page expansion... */
|
||||
/* from http://www.gossamer-threads.com/lists/wiki/mediawiki/124345 */
|
||||
}
|
||||
|
||||
/* "Zebra" table, with alternating row colors
|
||||
* to use:
|
||||
* {| class="wikitable zebra"
|
||||
* */
|
||||
.wikitable.zebra
|
||||
{
|
||||
width: auto;
|
||||
}
|
||||
.wikitable.zebra caption
|
||||
{
|
||||
/* table title */
|
||||
text-align: center;
|
||||
background: #ffffff;
|
||||
margin: 2em 2em 2em 2em;
|
||||
}
|
||||
.wikitable.zebra tr:nth-child(even)
|
||||
{
|
||||
/* 2nd row... dark */
|
||||
background-color: #ddf;
|
||||
}
|
||||
.wikitable.zebra tr:nth-child(odd)
|
||||
{
|
||||
/* 3rd row... light */
|
||||
background-color: #eef;
|
||||
}
|
||||
.wikitable.zebra td
|
||||
{
|
||||
/*
|
||||
padding: 2em;
|
||||
* */
|
||||
}
|
||||
|
||||
|
||||
/* "Pretty" table, with alternating row colors
|
||||
* to use:
|
||||
* {| class="prettytable"
|
||||
* {| class="wikitable"
|
||||
* */
|
||||
table.wikitable,
|
||||
table.prettytable {
|
||||
margin: 1em 1em 1em 0;
|
||||
background: #f9f9f9;
|
||||
border: 1px #aaa solid;
|
||||
border-collapse: collapse;
|
||||
}
|
||||
.wikitable th, .wikitable td,
|
||||
.prettytable th, .prettytable td {
|
||||
border: 1px #aaa solid;
|
||||
padding: 0.2em;
|
||||
}
|
||||
.wikitable th,
|
||||
.prettytable th {
|
||||
background: #f1f1f1;
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
.wikitable tr:nth-child(odd),
|
||||
.prettytable tr:nth-child(odd) { /* The striping is handled by the :nth-child pseudo-class, with the odd row adjusted. */
|
||||
background: #f5f5f5;
|
||||
}
|
||||
.wikitable caption,
|
||||
.prettytable caption {
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
|
||||
|
||||
/* Links for article's categories */
|
||||
.catlinks {
|
||||
border: 1px solid #aaa;
|
||||
background-color: #f9f9f9;
|
||||
padding: 5px;
|
||||
margin-top: 4em;
|
||||
clear: both;
|
||||
}
|
||||
|
||||
#siteSub {
|
||||
display: none;
|
||||
}
|
||||
#jump-to-nav {
|
||||
display: none;
|
||||
}
|
||||
|
||||
/* Table of Contents */
|
||||
#toc,
|
||||
.toc,
|
||||
.mw-warning {
|
||||
border: 1px solid #aaa;
|
||||
background-color: #f9f9f9;
|
||||
padding: 5px;
|
||||
font-size: 95%;
|
||||
}
|
||||
#toc h2,
|
||||
.toc h2 {
|
||||
display: inline;
|
||||
border: none;
|
||||
padding: 0;
|
||||
font-size: 100%;
|
||||
font-weight: bold;
|
||||
}
|
||||
#toc #toctitle,
|
||||
.toc #toctitle,
|
||||
#toc .toctitle,
|
||||
.toc .toctitle {
|
||||
text-align: center;
|
||||
}
|
||||
#toc ul,
|
||||
.toc ul {
|
||||
list-style-type: none;
|
||||
list-style-image: none;
|
||||
margin-left: 0;
|
||||
padding-left: 0;
|
||||
text-align: left;
|
||||
}
|
||||
#toc ul ul,
|
||||
.toc ul ul {
|
||||
margin: 0 0 0 2em;
|
||||
}
|
||||
#toc .toctoggle,
|
||||
.toc .toctoggle {
|
||||
font-size: 94%;
|
||||
}
|
||||
.mw-warning {
|
||||
margin-left: 50px;
|
||||
margin-right: 50px;
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
#column-content {
|
||||
/*
|
||||
width: 100%;
|
||||
margin: 0 0 .6em -12.2em;
|
||||
*/
|
||||
float: right;
|
||||
padding: 0;
|
||||
}
|
||||
#firstHeading {
|
||||
margin-bottom: .1em;
|
||||
/* These two rules hack around bug 2013 (fix for more limited bug 11325).
|
||||
When bug 2013 is fixed properly, they should be removed. */
|
||||
line-height: 1.2em;
|
||||
padding-bottom: 0;
|
||||
}
|
||||
|
||||
/* Don't display "retrieved from" text at the bottom */
|
||||
.printfooter {
|
||||
display: none;
|
||||
}
|
||||
#contentSub, #contentSub2 {
|
||||
font-size: 84%;
|
||||
line-height: 1.2em;
|
||||
margin: 0 0 1.4em 1em;
|
||||
color: #7d7d7d;
|
||||
width: auto;
|
||||
}
|
||||
.previewnote {
|
||||
color: #c00;
|
||||
margin-bottom: 1em;
|
||||
}
|
||||
/* user notification thing */
|
||||
.usermessage {
|
||||
background-color: #ffce7b;
|
||||
border: 1px solid #ffa500;
|
||||
color: black;
|
||||
font-weight: bold;
|
||||
margin: 2em 0 1em;
|
||||
padding: .5em 1em;
|
||||
vertical-align: middle;
|
||||
}
|
||||
#column-one {
|
||||
padding-top: 0px;
|
||||
}
|
||||
#p-cactions {
|
||||
/*
|
||||
position: absolute;
|
||||
top: 1.3em;
|
||||
left: 11.5em;
|
||||
margin: 0;
|
||||
line-height: 12px;
|
||||
line-height: 1.1em;
|
||||
padding-left: 1em;
|
||||
*/
|
||||
white-space: nowrap;
|
||||
width: 76%;
|
||||
overflow: visible;
|
||||
background: none;
|
||||
border-collapse: collapse;
|
||||
list-style: none;
|
||||
font-size: 95%;
|
||||
}
|
||||
#p-cactions li.selected a {
|
||||
z-index: 3;
|
||||
border: 1px solid white;
|
||||
}
|
||||
#p-cactions .pBody {
|
||||
font-size: 1em;
|
||||
border-collapse: inherit;
|
||||
border: 0;
|
||||
padding: 0;
|
||||
}
|
||||
#p-cactions .hiddenStructure {
|
||||
display: none;
|
||||
}
|
||||
#p-cactions li a:hover {
|
||||
z-index: 3;
|
||||
text-decoration: underline;
|
||||
}
|
||||
#p-cactions ul {
|
||||
list-style: none;
|
||||
}
|
||||
#p-cactions li {
|
||||
display: inline;
|
||||
/*
|
||||
border: 1px solid #aaa;
|
||||
border-bottom: none;
|
||||
*/
|
||||
padding: 0 0 .1em 0;
|
||||
margin: 0 .3em 0 0;
|
||||
overflow: visible;
|
||||
}
|
||||
#p-cactions li.selected {
|
||||
border-color: #fabd23;
|
||||
padding: 0 0 .2em 0;
|
||||
font-weight: bold;
|
||||
}
|
||||
#p-cactions li a {
|
||||
text-transform: lowercase;
|
||||
/*color: #002bb8;*/
|
||||
color: white;
|
||||
text-decoration: none;
|
||||
border: none;
|
||||
padding: 0 .8em .3em;
|
||||
position: relative;
|
||||
z-index: 0;
|
||||
margin: 0;
|
||||
}
|
||||
#p-cactions h5 {
|
||||
display: none;
|
||||
}
|
||||
#p-cactions li.istalk {
|
||||
margin-right: 0;
|
||||
}
|
||||
#p-cactions li.istalk a {
|
||||
padding-right: .5em;
|
||||
}
|
||||
#p-cactions #ca-addsection a {
|
||||
padding-left: .4em;
|
||||
padding-right: .4em;
|
||||
}
|
||||
/* offsets to distinguish the tab groups */
|
||||
li#ca-talk {
|
||||
margin-right: 1.6em;
|
||||
}
|
||||
li#ca-watch, li#ca-unwatch, li#ca-varlang-0, li#ca-print {
|
||||
margin-left: 1.6em;
|
||||
}
|
||||
#p-lang {
|
||||
position: relative;
|
||||
z-index: 3;
|
||||
}
|
||||
|
||||
|
||||
/* Override text-transform on languages where capitalization is significant */
|
||||
.capitalize-all-nouns .portlet h5,
|
||||
.capitalize-all-nouns .portlet h6,
|
||||
.capitalize-all-nouns #p-personal ul,
|
||||
.capitalize-all-nouns #p-cactions ul li a {
|
||||
text-transform: none;
|
||||
}
|
||||
|
||||
|
||||
|
||||
h1 {
|
||||
font-size: 188%;
|
||||
}
|
||||
h1 .editsection {
|
||||
font-size: 53%;
|
||||
}
|
||||
h2 {
|
||||
font-size: 150%;
|
||||
}
|
||||
h2 .editsection {
|
||||
font-size: 67%;
|
||||
}
|
||||
|
||||
h3, h4, h5, h6 {
|
||||
border-bottom: none;
|
||||
font-weight: bold;
|
||||
}
|
||||
h3 {
|
||||
font-size: 110%;
|
||||
font-style: italic;
|
||||
}
|
||||
h3 .editsection {
|
||||
font-size: 76%;
|
||||
font-weight: normal;
|
||||
}
|
||||
|
||||
h4 {
|
||||
font-size: 116%;
|
||||
}
|
||||
h4 .editsection {
|
||||
font-size: 86%;
|
||||
font-weight: normal;
|
||||
}
|
||||
|
||||
h5 {
|
||||
font-size: 100%;
|
||||
display: none;
|
||||
}
|
||||
h5 .editsection {
|
||||
font-weight: normal;
|
||||
}
|
||||
|
||||
h6 {
|
||||
font-size: 80%;
|
||||
}
|
||||
h6 .editsection {
|
||||
font-size: 125%;
|
||||
font-weight: normal;
|
||||
}
|
||||
|
||||
.editsection a {
|
||||
text-decoration: none;
|
||||
/*
|
||||
color: #a00;
|
||||
*/
|
||||
}
|
||||
|
||||
#bodyContent a.external {
|
||||
background: url(external.png) center right no-repeat;
|
||||
padding: 0px 14px;
|
||||
}
|
||||
#bodyContent h1 {
|
||||
border-bottom: thin dotted
|
||||
}
|
||||
|
||||
/* thumbnails */
|
||||
div.thumb {
|
||||
margin-bottom: .5em;
|
||||
border-style: transparent;
|
||||
/*
|
||||
border-color: white;
|
||||
*/
|
||||
width: auto;
|
||||
}
|
||||
div.thumbinner {
|
||||
border: 1px solid #ccc;
|
||||
/*
|
||||
padding: 3px !important;
|
||||
*/
|
||||
background-color: #f9f9f9;
|
||||
font-size: 94%;
|
||||
text-align: center;
|
||||
overflow: hidden;
|
||||
}
|
||||
html .thumbimage {
|
||||
border: 1px solid #f9f9f9;
|
||||
border-width: 0.5em 1.5em 0.5em 0.5em;
|
||||
}
|
||||
html .thumbcaption {
|
||||
border: none;
|
||||
text-align: left;
|
||||
line-height: 1.4em;
|
||||
padding: 3px !important;
|
||||
font-size: 94%;
|
||||
}
|
||||
div.magnify {
|
||||
float: right;
|
||||
border: none !important;
|
||||
background: none !important;
|
||||
}
|
||||
div.magnify a, div.magnify img {
|
||||
display: block;
|
||||
border: none !important;
|
||||
background: none !important;
|
||||
}
|
||||
div.tright {
|
||||
clear: right;
|
||||
float: right;
|
||||
border-width: .5em 0 .8em 1.4em;
|
||||
}
|
||||
div.tleft {
|
||||
float: left;
|
||||
clear: left;
|
||||
margin-right: .5em;
|
||||
border-width: .5em 1.4em .8em 0;
|
||||
}
|
||||
img.thumbborder {
|
||||
border: 1px solid #dddddd;
|
||||
}
|
||||
.hiddenStructure {
|
||||
display: none;
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
Icebrrg stuff
|
||||
*/
|
||||
|
||||
div.mw-geshi {
|
||||
overflow: auto;
|
||||
padding: 1em;
|
||||
border: 1px dashed #2f6fab;
|
||||
color: black;
|
||||
background-color: #f9f9f9;
|
||||
line-height: 1.1em;
|
||||
/* "overflow: auto" prevent ugly horizontal page expansion... */
|
||||
/* from http://www.gossamer-threads.com/lists/wiki/mediawiki/124345 */
|
||||
}
|
||||
|
||||
.text-heading {
|
||||
font-family: "Lucida Console";
|
||||
/*
|
||||
font-size: 24px;
|
||||
*/
|
||||
font-style: normal;
|
||||
font-weight: bold;
|
||||
text-transform: none;
|
||||
letter-spacing: 4px;
|
||||
text-indent: 10px;
|
||||
vertical-align: middle;
|
||||
color: #0066CC;
|
||||
}
|
||||
|
||||
.text {
|
||||
font-family: Verdana, Arial, Helvetica, sans-serif;
|
||||
/*
|
||||
font-size: 11px;
|
||||
padding-left: 10px;
|
||||
padding-right: 10px;
|
||||
color: #666666;
|
||||
*/
|
||||
text-align: justify;
|
||||
}
|
||||
|
||||
#footer {
|
||||
font-family: Verdana, Arial, Helvetica, sans-serif;
|
||||
font-size: 10px;
|
||||
color: #666666;
|
||||
text-align: center;
|
||||
/*
|
||||
border: 1px none #6699CC;
|
||||
background-color: #0099CC;
|
||||
*/
|
||||
}
|
||||
#footer a {
|
||||
font-size: 10px;
|
||||
color: #14388B;
|
||||
}
|
||||
|
||||
.table2 {
|
||||
border: 1px dotted #000066;
|
||||
}
|
||||
.company {
|
||||
font-family: "Lucida Console";
|
||||
/* font-size: 30px;
|
||||
*/
|
||||
color: #0066CC;
|
||||
text-align: left;
|
||||
vertical-align: middle;
|
||||
letter-spacing: 8px;
|
||||
font-weight: normal;
|
||||
}
|
||||
.punchline {
|
||||
font-family: Arial, Helvetica, sans-serif;
|
||||
/*font-size: 11px;
|
||||
*/
|
||||
color: #003366;
|
||||
letter-spacing: 4px;
|
||||
}
|
||||
.menu {
|
||||
font-family: Verdana, Arial, Helvetica, sans-serif;
|
||||
/*
|
||||
font-size: 11px;
|
||||
*/
|
||||
color: #0066CC;
|
||||
text-align: center;
|
||||
vertical-align: middle;
|
||||
border: 1px solid #000000;
|
||||
background-color: #C7D3F1;
|
||||
}
|
||||
|
||||
.submenu {
|
||||
font-family: Verdana, Arial, Helvetica, sans-serif;
|
||||
/*font-size: 11px;
|
||||
*/
|
||||
font-weight: lighter;
|
||||
color: #0066CC;
|
||||
text-align: center;
|
||||
vertical-align: middle;
|
||||
background-color: #E1E8F8;
|
||||
border-top: 1px solid #000000;
|
||||
border-right: 1px none #000000;
|
||||
border-bottom: 1px solid #000000;
|
||||
border-left: 1px none #000000;
|
||||
}
|
||||
|
||||
|
||||
.headtable {
|
||||
border: 1px dotted #0066CC;
|
||||
}
|
||||
.header {
|
||||
background-image: url(../images/bk.jpg);
|
||||
border: 1px dotted #003399;
|
||||
}
|
||||
|
||||
a.new, a.new:visited {
|
||||
color: #14388B;
|
||||
}
|
||||
|
||||
/*
|
||||
#p-cactions .new a {
|
||||
color: #14388B;
|
||||
}
|
||||
|
||||
#p-personal a.new {
|
||||
color: #14388B;
|
||||
}
|
||||
*/
|
||||
|
||||
#content a.new {
|
||||
color: #0BD;
|
||||
}
|
||||
|
||||
a {
|
||||
font-family: Verdana, Arial, Helvetica, sans-serif;
|
||||
font-size: 14px;
|
||||
color: #14388B;
|
||||
text-decoration: none;
|
||||
font-weight: bold;
|
||||
}
|
||||
a:visited {
|
||||
font-family: Verdana, Arial, Helvetica, sans-serif;
|
||||
font-size: 14px;
|
||||
color: #14388B;
|
||||
text-decoration: none;
|
||||
font-weight: bold;
|
||||
}
|
||||
a:hover {
|
||||
font-family: Verdana, Arial, Helvetica, sans-serif;
|
||||
color: #333399;
|
||||
text-decoration: none;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
body {
|
||||
font-family: Verdana, Arial, Helvetica, sans-serif;
|
||||
color: #a00;
|
||||
text-decoration: none;
|
||||
background-color: #ddd;
|
||||
/* make sure 100% width really means 100% width */
|
||||
margin:0;
|
||||
padding:0;
|
||||
}
|
||||
|
||||
.blackbg {
|
||||
position: absolute;
|
||||
top: 0px;
|
||||
width: 100%;
|
||||
background-color: #000;
|
||||
}
|
||||
|
||||
/* Style for header background image */
|
||||
.bannerimg {
|
||||
position: relative;
|
||||
width: 100%;/* for ie6 */
|
||||
}
|
||||
|
||||
.bannerimg img {
|
||||
position: absolute;
|
||||
}
|
||||
|
||||
/* Style for header banner (charlesmartinreid.com) */
|
||||
.bannerimg h2 {
|
||||
position: absolute;
|
||||
left: 0;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.bannerimg h2 span {
|
||||
color: white;
|
||||
font-face: bold;
|
||||
font-size: 38px;
|
||||
font-family:"Helvetica","Sans-Serif","Georgia";
|
||||
letter-spacing:-1px;
|
||||
background: rgb(0,0,0);/* fallback color */
|
||||
background: rgba(0,0,0,0.7);
|
||||
}
|
||||
|
||||
/* Navigation bar (top right) */
|
||||
.topright{
|
||||
display:block;
|
||||
|
||||
/* arrangement/spacing */
|
||||
position: absolute;
|
||||
top:0;
|
||||
right:0;
|
||||
width: auto;
|
||||
|
||||
/*give it some color */
|
||||
color: white;
|
||||
font-face: bold;
|
||||
font-size: 16px;
|
||||
font-family:"Helvetica","Sans-Serif","Georgia";
|
||||
background: rgb(0,0,0);/* fallback color */
|
||||
background: rgba(0,0,0,0.7);
|
||||
}
|
||||
.topright table, td, tr {
|
||||
margin: 10px;
|
||||
}
|
||||
.topright a {
|
||||
color:white;
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
/* Mediawiki navigation tabs */
|
||||
.mw_navtabs {
|
||||
display: block;
|
||||
position: absolute;
|
||||
|
||||
/* spacing */
|
||||
left: 100px;
|
||||
|
||||
vertical-align: middle;
|
||||
color: white;
|
||||
font-size: 16px;
|
||||
background: rgb(0,0,0);/* fallback color */
|
||||
background: rgba(0,0,0,0.7);
|
||||
}
|
||||
|
||||
/* Mediawiki content */
|
||||
.mw_content {
|
||||
display: block;
|
||||
/*position: absolute; */
|
||||
position: relative;
|
||||
|
||||
/* spacing */
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.mw_content table#mainbody {
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
border-collapse: collapse;
|
||||
table-layout:fixed;
|
||||
border: 0px invisible;
|
||||
}
|
||||
.mw_content table#mainbody td#margin {
|
||||
width: 8%;
|
||||
color: #a00;
|
||||
background-color: #ddd;
|
||||
text-decoration: none;
|
||||
font-family: "Verdana","Arial","Helvetica","Sans-Serif";
|
||||
}
|
||||
.mw_content table#mainbody td#center {
|
||||
color: #a00;
|
||||
background-color: #ddd;
|
||||
text-decoration: none;
|
||||
font-family: "Verdana","Arial","Helvetica","Sans-Serif";
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
@ -1,24 +0,0 @@
|
||||
<nav class="navbar navbar-default">
|
||||
<div class="container-fluid">
|
||||
<div class="navbar-header">
|
||||
<button type="button" class="navbar-toggle" data-toggle="collapse" data-target="#myNavbar">
|
||||
<span class="icon-bar"></span>
|
||||
<span class="icon-bar"></span>
|
||||
<span class="icon-bar"></span>
|
||||
</button>
|
||||
<a href="/" class="navbar-brand">{{ pod_charlesreid1_server_name }}</a>
|
||||
</div>
|
||||
<div>
|
||||
<div class="collapse navbar-collapse" id="myNavbar">
|
||||
<ul class="nav navbar-nav">
|
||||
|
||||
<li>
|
||||
<a href="https://{{ pod_charlesreid1_server_name }}/wiki">Wiki</a>
|
||||
</li>
|
||||
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</nav>
|
||||
|
@ -1,36 +0,0 @@
|
||||
<nav class="navbar navbar-default">
|
||||
<div class="container-fluid">
|
||||
<div class="navbar-header">
|
||||
<!--
|
||||
http://www.w3schools.com/bootstrap/bootstrap_case_navigation.asp
|
||||
-->
|
||||
<button type="button" class="navbar-toggle" data-toggle="collapse" data-target="#myNavbar">
|
||||
<span class="icon-bar"></span>
|
||||
<span class="icon-bar"></span>
|
||||
<span class="icon-bar"></span>
|
||||
</button>
|
||||
<a href="/" class="navbar-brand">charlesreid1.com</a>
|
||||
</div>
|
||||
<div>
|
||||
<div class="collapse navbar-collapse" id="myNavbar">
|
||||
<ul class="nav navbar-nav">
|
||||
|
||||
<li>
|
||||
<a href="{{ SITEURL }}/projects">Projects</a>
|
||||
</li>
|
||||
<li>
|
||||
<a href="{{ SITEURL }}/about">About Me</a>
|
||||
</li>
|
||||
<li>
|
||||
<a href="{{ SITEURL }}/consulting">Consulting</a>
|
||||
</li>
|
||||
<li>
|
||||
<a href="{{ SITEURL }}/writing">Writing</a>
|
||||
</li>
|
||||
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</nav>
|
||||
|
Before Width: | Height: | Size: 47 B |
@ -1,33 +0,0 @@
|
||||
{
|
||||
"name": "Bootstrap2",
|
||||
"author": [
|
||||
"Charles Reid",
|
||||
"..."
|
||||
],
|
||||
"url": "",
|
||||
"descriptionmsg": "Bootstrap2-desc",
|
||||
"namemsg": "skinname-Bootstrap2",
|
||||
"license-name": "GPL-2.0+",
|
||||
"type": "skin",
|
||||
"ValidSkinNames": {
|
||||
"Bootstrap2": "Bootstrap2"
|
||||
},
|
||||
"MessagesDirs": {
|
||||
"Bootstrap2": [
|
||||
"i18n"
|
||||
]
|
||||
},
|
||||
"ResourceModules": {
|
||||
"skins.Bootstrap2.styles": {
|
||||
"styles": {
|
||||
"main.css": {
|
||||
"media": "screen"
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
"ResourceFileModulePaths": {
|
||||
"localBasePath": "",
|
||||
"remoteSkinPath": "Bootstrap2"
|
||||
}
|
||||
}
|
@ -1,120 +0,0 @@
|
||||
{
|
||||
"link" : "https://raw.githubusercontent.com/jneug/Linus/master/skin.json",
|
||||
"name": "Linus",
|
||||
"author": [
|
||||
"Jonas Neugebauer"
|
||||
],
|
||||
"url": "https://github.com/jneug/Linus",
|
||||
"descriptionmsg": "linus-desc",
|
||||
"namemsg": "skinname-linus",
|
||||
"license-name": "GPL-2.0+",
|
||||
"version": "2.0.0",
|
||||
"type": "skin",
|
||||
"ConfigRegistry": {
|
||||
"vector": "GlobalVarConfig::newInstance"
|
||||
},
|
||||
"ValidSkinNames": {
|
||||
"linus": "Linus"
|
||||
},
|
||||
"MessagesDirs": {
|
||||
"Linus": [
|
||||
"i18n"
|
||||
]
|
||||
},
|
||||
"AutoloadClasses": {
|
||||
"SkinLinus": "SkinLinus.php",
|
||||
"LinusParser": "LinusParser.php",
|
||||
"LinusTemplate": "LinusTemplate.php",
|
||||
"LinusHooks": "LinusHooks.php",
|
||||
"ResponsiveCategory": "LinusSMW.php"
|
||||
},
|
||||
"ExtensionMessagesFiles": {
|
||||
"LinusMagic": "LinusMagic.php"
|
||||
},
|
||||
"callback": "LinusHooks::onExtensionLoad",
|
||||
"ExtensionFunctions": [
|
||||
"LinusHooks::setupSMWExtensions"
|
||||
],
|
||||
"Hooks": {
|
||||
"ParserFirstCallInit": [
|
||||
"LinusHooks::NavSetup",
|
||||
"LinusHooks::ButtonsSetup"
|
||||
],
|
||||
"ParserBeforeTidy": [
|
||||
"LinusHooks::parseMagicWords"
|
||||
],
|
||||
"OutputPageParserOutput": [
|
||||
"LinusHooks::countSections"
|
||||
],
|
||||
"EditPageBeforeEditButtons": [
|
||||
"LinusHooks::styleEditButtons"
|
||||
],
|
||||
"ArticleFromTitle": [
|
||||
"LinusHooks::onArticleFromTitle"
|
||||
]
|
||||
},
|
||||
"ResourceModules": {
|
||||
"skins.linus.styles": {
|
||||
"position": "top",
|
||||
"styles": {
|
||||
"css/bootstrap.min.css": {
|
||||
"media": "all"
|
||||
},
|
||||
"less/linus.less": {
|
||||
"media": "all"
|
||||
},
|
||||
"less/custom.less": {
|
||||
"media": "all"
|
||||
}
|
||||
}
|
||||
},
|
||||
"skins.linus.scripts": {
|
||||
"position": "top",
|
||||
"scripts": [
|
||||
"js/bootstrap.min.js",
|
||||
"js/linus.js",
|
||||
"js/custom.js"
|
||||
]
|
||||
},
|
||||
"skins.linus.fontawesome": {
|
||||
"position": "top",
|
||||
"styles": {
|
||||
"css/font-awesome.min.css": {
|
||||
"media": "all"
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
"ResourceFileModulePaths": {
|
||||
"localBasePath": "",
|
||||
"remoteSkinPath": "Linus"
|
||||
},
|
||||
"ResourceModuleSkinStyles": {
|
||||
"Linus": {
|
||||
}
|
||||
},
|
||||
"config": {
|
||||
"LinusUseSidebar": false,
|
||||
"LinusTOCInSidebar": false,
|
||||
"LinusEnableSmoothScroll": true,
|
||||
"LinusNavbarInverted": false,
|
||||
"LinusNavbarFixed": true,
|
||||
"Sitenameshort": null,
|
||||
"LinusUseFontAwesome": false,
|
||||
"LinusShowFooterLinks": false,
|
||||
"LinusUseFooterIcons": true,
|
||||
"LinusHideActionsForAnon": true,
|
||||
"LinusEnableNavTag": true,
|
||||
"LinusEnableButtonsTag": true,
|
||||
"LinusResponsiveCategories": true,
|
||||
"LinusTitlebarPage": "MediaWiki:Linus/Titlebar",
|
||||
"LinusFooterPage": "MediaWiki:Linus/Footer",
|
||||
"LinusSidebarPage": "MediaWiki:Linus/Sidebar",
|
||||
"LinusCopyrightPage": "MediaWiki:Linus/Copyright",
|
||||
"LinusHideHeader": [
|
||||
"Mainpage",
|
||||
"Hauptseite"
|
||||
]
|
||||
},
|
||||
"manifest_version": 1
|
||||
}
|
Before Width: | Height: | Size: 325 B |
Before Width: | Height: | Size: 7.8 KiB |
Before Width: | Height: | Size: 22 KiB |
@ -1,3 +0,0 @@
|
||||
post_max_size = 128M
|
||||
memory_limit = 128M
|
||||
upload_max_filesize = 100M
|
1
d-mysql
Submodule
@ -0,0 +1 @@
|
||||
Subproject commit 3f8949139e8827bbc61d3cf6ecd4001a6bd6edd2
|
@ -1,11 +0,0 @@
|
||||
FROM mysql:5.7
|
||||
MAINTAINER charles@charlesreid1.com
|
||||
|
||||
# make mysql data a volume
|
||||
VOLUME ["/var/lib/mysql"]
|
||||
|
||||
# put password in a password file
|
||||
RUN printf "[client]\nuser=root\npassword=$MYSQL_ROOT_PASSWORD" > /root/.mysql.rootpw.cnf
|
||||
RUN chmod 0600 /root/.mysql.rootpw.cnf
|
||||
|
||||
RUN chown mysql:mysql /var/lib/mysql
|
@ -1,11 +0,0 @@
|
||||
# d-mysql
|
||||
|
||||
This is the MySQL docker container used to run MySQL on charlesreid1.com.
|
||||
|
||||
See [pod-charlesreid1](https://git.charlesreid1.com/docker/pod-charlesreid1).
|
||||
|
||||
## Dockerfile
|
||||
|
||||
The Dockerfile is necessary to copy the MySQL root password into a file inside
|
||||
the container. This file is used in automated scripts when we would have problems
|
||||
getting the password via environment variables.
|
@ -1,4 +0,0 @@
|
||||
#!/bin/bash
|
||||
|
||||
docker container prune -f
|
||||
docker volume rm stormy_mysql_data
|
@ -1,4 +0,0 @@
|
||||
#!/bin/bash
|
||||
|
||||
docker container prune -f
|
||||
docker volume create stormy_mysql_data
|
1
d-nginx-charlesreid1
Submodule
@ -0,0 +1 @@
|
||||
Subproject commit ddd33967f5366c6c4be45c6892fb053760e755aa
|
@ -1,6 +0,0 @@
|
||||
# https://serverfault.com/a/525011
|
||||
server {
|
||||
server_name _;
|
||||
listen *:80 default_server deferred;
|
||||
return 444;
|
||||
}
|
@ -1 +0,0 @@
|
||||
add_header Content-Security-Policy-Report-Only "default-src 'self' 'unsafe-inline' 'unsafe-eval';";
|
@ -1 +0,0 @@
|
||||
add_header Content-Security-Policy-Report-Only "default-src 'self' 'unsafe-inline' 'unsafe-eval';";
|