Compare commits
356 Commits
new-colour
...
main
Author | SHA1 | Date | |
---|---|---|---|
40ebf3b2dc | |||
|
3259461bc5 | ||
|
6553f1bb6e | ||
|
a389f3cfc0 | ||
05682671a9 | |||
00b768c8e6 | |||
fc82723353 | |||
bd91b73082 | |||
|
bc9894ba2d | ||
|
e4b41669df | ||
|
6f996227b4 | ||
|
19b4d62ad5 | ||
|
23d56cfafd | ||
|
25d6c99fc5 | ||
23dcb08d69 | |||
85d7f33831 | |||
|
3660b76db9 | ||
475790f399 | |||
|
537ad52a33 | ||
|
4f07299e5c | ||
|
445cd7bcca | ||
a26132b1f5 | |||
|
e03735dec3 | ||
|
ccb41ee618 | ||
|
d144af2c35 | ||
|
4830f4446c | ||
|
d8cbaf464a | ||
6a8dcbbaad | |||
fc4a221d9d | |||
e19c065ba7 | |||
7e17aa9850 | |||
58f91fd36f | |||
e42749b6ab | |||
04c1f4abc6 | |||
293176f6c2 | |||
6d3a7aa06f | |||
01c7f37f42 | |||
|
08da075460 | ||
7e99afee31 | |||
fd5648f26e | |||
|
77e40903ed | ||
d9c8878f24 | |||
24f24a3972 | |||
a77f397978 | |||
ca00e889de | |||
|
b1b597d6d6 | ||
38cc2c5ec8 | |||
|
6f6a3b2e5e | ||
c338187c51 | |||
|
d27d98d3e9 | ||
|
c2a163776c | ||
d41de3cfd9 | |||
|
bd73042dd4 | ||
1e55036a21 | |||
fc59c56df8 | |||
|
332e385657 | ||
|
991e2bb332 | ||
|
98dd76b300 | ||
|
ade028c8cb | ||
e1d76ff40e | |||
|
a78c94250b | ||
|
6b6853be22 | ||
|
5891093a60 | ||
|
897ba19972 | ||
|
ce6f92aa12 | ||
|
2db78105f7 | ||
f39ea6d07d | |||
|
6b5a47d86b | ||
|
e2a43e9ad1 | ||
|
ca4d5ddb80 | ||
|
3da62d7688 | ||
|
949ea30680 | ||
fe205e1ac1 | |||
d533b5988e | |||
cc2425e1cd | |||
|
2d86a3ed56 | ||
|
308213ed9b | ||
|
e91e38a785 | ||
|
1cb687fd25 | ||
05cfeaeae3 | |||
|
ad0f285fb1 | ||
ab8b9c717e | |||
|
266b936312 | ||
|
2fce0586d8 | ||
|
b4b5d32780 | ||
|
f9452dd2c5 | ||
75db99c4e1 | |||
|
9559396132 | ||
|
dcbdf635ac | ||
|
75b63c9771 | ||
|
27194cbae5 | ||
|
8d73dd3df5 | ||
a4aa3d669f | |||
9d0e1fee73 | |||
|
21b671d945 | ||
|
158fef9027 | ||
838ec1c79c | |||
610ef2a861 | |||
e1a641a7bf | |||
c66df7c0fd | |||
9846416b36 | |||
2be7acd2c2 | |||
d1674c5402 | |||
3ceb87faca | |||
3b25b71b18 | |||
d5ebafae77 | |||
|
84e371154f | ||
2faa90b0fa | |||
|
792674d6b5 | ||
|
007646b26e | ||
|
227e84ff63 | ||
|
81d8caf946 | ||
|
d5dc6d540d | ||
|
acafb427a5 | ||
|
b3956b91f2 | ||
|
49350a1cbc | ||
|
56bafa3e84 | ||
961cf1a54d | |||
|
a3489c9aa4 | ||
2d24baa5ce | |||
|
05c26544ff | ||
|
56eaeadfcb | ||
|
fd09a12a24 | ||
864cffb9b5 | |||
|
076234aef4 | ||
|
0d4ee2b0a1 | ||
c6f5ccf4aa | |||
|
c1267c5366 | ||
cabc8efdb7 | |||
|
737b7e1edf | ||
91eca81fc6 | |||
|
911ac06b14 | ||
|
420b4da5dd | ||
210afaf16a | |||
c17eda92b5 | |||
0b5e27e0c1 | |||
|
2ae36bade9 | ||
77d85db350 | |||
43a19d64c8 | |||
7a53515307 | |||
c700c414ff | |||
|
b3bed6d48e | ||
3ae5a6e803 | |||
74949d9595 | |||
a5fe6f88a5 | |||
8037032778 | |||
bc2e8759b2 | |||
a5f62f6bdc | |||
c20ca831c6 | |||
b1217dcbcd | |||
|
e9d0088195 | ||
|
6c169e26d0 | ||
|
b6ad82d86f | ||
|
f19aa81657 | ||
|
3fded72105 | ||
|
a5740aea02 | ||
|
2a72bac756 | ||
|
78ea06871a | ||
|
9f42ecaa77 | ||
|
9a8bcdc66c | ||
|
27a36aeaaa | ||
|
0f2a7a6df1 | ||
|
558b71934d | ||
|
15c9d4a153 | ||
|
fd54672540 | ||
|
3667ee109c | ||
|
ff4617f318 | ||
|
333f000fcf | ||
|
b529e2f2e8 | ||
|
e9a1b2e369 | ||
|
351251f54f | ||
|
16339ecc2e | ||
|
d6a8259e08 | ||
|
803bf41e61 | ||
|
fa6a2e120e | ||
|
20ed2d29b1 | ||
|
188b461c58 | ||
|
b87d648a7d | ||
|
b72febc4c8 | ||
|
076a6954f4 | ||
|
a85b656af8 | ||
|
cc3066bb1d | ||
|
886fb51ed6 | ||
|
5b7ee79c5d | ||
34aca195ce | |||
87b6978506 | |||
|
5a6986db29 | ||
|
6f9bf2d4db | ||
a303c4eaec | |||
|
1eb1a0ef8c | ||
|
68a8df1fb1 | ||
|
c7579b87b5 | ||
|
9b7b8e289d | ||
|
06e53cd9bc | ||
|
a60aef66b0 | ||
|
5ff502bc72 | ||
|
3cbc9adc49 | ||
|
55c8859f07 | ||
|
9f1dd6284b | ||
|
8463aa2342 | ||
6211ec5cb4 | |||
|
a006517b8e | ||
|
1c980536a2 | ||
e0007eca54 | |||
|
27c81db722 | ||
|
e5faea080e | ||
|
8094625dbc | ||
|
8868ae08bf | ||
|
7e854e1616 | ||
|
99bf5a891f | ||
|
7a5c2d613b | ||
|
3645e21236 | ||
6623973388 | |||
|
80af40e8ff | ||
|
8ec940fac5 | ||
|
789cc39c10 | ||
|
2df37af10d | ||
|
6ebcab155e | ||
|
9105acf97c | ||
af8ca3ca38 | |||
49f3d4ed71 | |||
850da933e8 | |||
07367a85a9 | |||
|
da3a3a989c | ||
|
dcb3ada610 | ||
|
489315eb60 | ||
704a678de5 | |||
|
5a8abd8d2b | ||
|
9b906cff1a | ||
|
0afce645e0 | ||
abe8840d2a | |||
1c1e51f5d6 | |||
7bd00564f4 | |||
39d17a1e0b | |||
deeecb22b9 | |||
177cc16dde | |||
cf2c8639b1 | |||
e34352df6e | |||
e9d996b061 | |||
1ef6084a27 | |||
05527f444a | |||
|
4b31a9364d | ||
|
20c1d5bf0b | ||
|
9348b5066e | ||
|
4bef557301 | ||
|
0dc1ffadb4 | ||
|
9cfda4aa24 | ||
|
8776572f3d | ||
|
a444219ef8 | ||
|
7eeb732aca | ||
|
cb9d863f66 | ||
|
dc531455ee | ||
|
3aac13abd7 | ||
|
469906c790 | ||
|
06b82858f9 | ||
|
3da45feb42 | ||
|
6748e69a51 | ||
|
93b3c55221 | ||
|
2b489c6025 | ||
|
6323b4c2c9 | ||
|
da6b4a1c02 | ||
|
72b39ad07e | ||
|
f8e52a7381 | ||
|
8bdfe16249 | ||
|
3873d54494 | ||
|
bcaf9601e9 | ||
|
b9cdae9857 | ||
|
caa1e521ad | ||
|
741df0045b | ||
|
d00d763645 | ||
|
46732e1708 | ||
|
d88ecbcc1a | ||
|
eb5af2854f | ||
|
544cd47114 | ||
|
476df063b4 | ||
|
0e62b9e045 | ||
|
9ce17b0026 | ||
|
ff73beef10 | ||
|
5924375117 | ||
|
a3fee0493b | ||
|
a892ecf5b4 | ||
|
909554e58d | ||
|
50959f27ac | ||
|
fee2ffd1e1 | ||
|
97857a8c27 | ||
eb38c9514a | |||
|
39eef16f9e | ||
|
04c7d20a56 | ||
|
a2f5a6cbac | ||
d3ea095d2b | |||
8cdacd0901 | |||
48e654008e | |||
d72cc7389c | |||
ef18228bee | |||
13622fd105 | |||
ea3afbb4e1 | |||
13357d685a | |||
693e8c9665 | |||
30d86673c5 | |||
86a7eb0ea5 | |||
cdea7563f4 | |||
b29e79f493 | |||
4dff7a9a12 | |||
b2d8d569a6 | |||
ab31c1902e | |||
9e79cc2d24 | |||
6086c318bd | |||
ac4d46d4bf | |||
1e60a29875 | |||
5d21e5ecb3 | |||
56a73b36af | |||
0c863bb5a7 | |||
81481b23df | |||
a533060c88 | |||
5fdac7c16f | |||
510a6920cf | |||
4520bcd736 | |||
947a4b9a0a | |||
bf20dec44a | |||
287b755e3d | |||
edb3d64cca | |||
19c715c611 | |||
ef1d576244 | |||
adcd1ceec4 | |||
|
4394fdb749 | ||
|
3c27f2b74a | ||
|
5f90749d0e | ||
|
bbbd6a7134 | ||
|
d8be4eb58c | ||
|
3883a2c5b1 | ||
|
db69c2e7ea | ||
|
3887a60299 | ||
|
a643595a95 | ||
|
2521064a34 | ||
|
4d041ec7dd | ||
|
74d2dbb867 | ||
|
04f2e8eb28 | ||
|
d97b124a79 | ||
|
1ad7a4368d | ||
|
f1d93b1719 | ||
|
4aaeac1f07 | ||
|
7220ee6178 | ||
|
3fce3c1a7a | ||
|
5832ee4b12 | ||
|
4983b916c7 | ||
|
665a3690b1 | ||
7584dc796e | |||
5502122e21 | |||
|
b056420f9e | ||
|
0564bec241 | ||
|
186bc4f373 | ||
|
7d9b81b324 | ||
|
a50249fe22 | ||
|
9443912519 | ||
|
9c4166e573 | ||
|
39c391e803 |
39
.drone.yml
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
---
|
||||||
|
kind: pipeline
|
||||||
|
name: deploy to swarm.autonomic.zone
|
||||||
|
steps:
|
||||||
|
- name: bundle static
|
||||||
|
image: plugins/docker
|
||||||
|
settings:
|
||||||
|
username:
|
||||||
|
from_secret: docker_reg_username
|
||||||
|
password:
|
||||||
|
from_secret: docker_reg_passwd
|
||||||
|
repo: decentral1se/autonomic.zone
|
||||||
|
tags: latest
|
||||||
|
|
||||||
|
- name: deployment
|
||||||
|
image: decentral1se/stack-ssh-deploy:latest
|
||||||
|
settings:
|
||||||
|
stack: jekyll
|
||||||
|
compose: docker-compose.prod.yml
|
||||||
|
deploy_key:
|
||||||
|
from_secret: drone_ssh_swarm.autonomic.zone
|
||||||
|
|
||||||
|
- name: notify rocket chat
|
||||||
|
image: plugins/slack
|
||||||
|
settings:
|
||||||
|
webhook:
|
||||||
|
from_secret: rc_builds_url
|
||||||
|
username: comradebritney
|
||||||
|
channel: "internal.builds"
|
||||||
|
template: "{{repo.owner}}/{{repo.name}} build failed: {{build.link}}"
|
||||||
|
when:
|
||||||
|
status:
|
||||||
|
- failure
|
||||||
|
trigger:
|
||||||
|
branch:
|
||||||
|
- main
|
||||||
|
event:
|
||||||
|
exclude:
|
||||||
|
- pull_request
|
2
.envrc.sample
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
# The path to our pass credentials store
|
||||||
|
export PASSWORD_STORE_DIR=$(pwd)/../infrastructure/credentials/password-store
|
3
.gitignore
vendored
@ -1,5 +1,6 @@
|
|||||||
dist/
|
dist/
|
||||||
.sass-cache/
|
.sass-cache/
|
||||||
.jekyll-metadata
|
.jekyll-metadata
|
||||||
Gemfile.lock
|
.jekyll-cache
|
||||||
|
.DS_Store
|
||||||
*.gem
|
*.gem
|
||||||
|
@ -1,21 +0,0 @@
|
|||||||
image: ruby:2.4.2
|
|
||||||
|
|
||||||
stages:
|
|
||||||
- deploy
|
|
||||||
|
|
||||||
deploy:
|
|
||||||
stage: deploy
|
|
||||||
before_script:
|
|
||||||
- apt-get update -y
|
|
||||||
- apt-get -y install rsync
|
|
||||||
- gem install jekyll
|
|
||||||
- eval $(ssh-agent -s)
|
|
||||||
script:
|
|
||||||
- jekyll build -d public
|
|
||||||
- ssh-add <(echo "$SSH_PRIVATE_KEY")
|
|
||||||
- rsync -rvz --delete -e 'ssh -o StrictHostKeyChecking=no' ./public/ "$SERVER_USER"@autonomic.zone:/var/www/autonomic.zone/html/
|
|
||||||
artifacts:
|
|
||||||
paths:
|
|
||||||
- public
|
|
||||||
only:
|
|
||||||
- master
|
|
11
CHANGELOG.md
@ -3,12 +3,17 @@
|
|||||||
All notable changes to this project will be documented in this file. The format
|
All notable changes to this project will be documented in this file. The format
|
||||||
is based on [Keep a Changelog] and this project adheres to [Semantic Versioning].
|
is based on [Keep a Changelog] and this project adheres to [Semantic Versioning].
|
||||||
|
|
||||||
[Keep a Changelog]: http://keepachangelog.com/en/1.0.0/
|
[keep a changelog]: http://keepachangelog.com/en/1.0.0/
|
||||||
[Semantic Versioning]: http://semver.org/spec/v2.0.0.html
|
[semantic versioning]: http://semver.org/spec/v2.0.0.html
|
||||||
|
|
||||||
|
## [2.0.0] - 2020-03-30
|
||||||
|
|
||||||
|
- Moved website deployment to [git.autonomic.zone](https://git.autonomic.zone).
|
||||||
|
|
||||||
## [1.0.2] - 2017-11-05
|
## [1.0.2] - 2017-11-05
|
||||||
|
|
||||||
## Added
|
## Added
|
||||||
|
|
||||||
- [#18]: Add shared account email.
|
- [#18]: Add shared account email.
|
||||||
|
|
||||||
[#18]: https://gitlab.com/autonomic-cooperative/autonomic-cooperative.gitlab.io/merge_requests/18
|
[#18]: https://gitlab.com/autonomic-cooperative/autonomic-cooperative.gitlab.io/merge_requests/18
|
||||||
@ -16,9 +21,11 @@ is based on [Keep a Changelog] and this project adheres to [Semantic Versioning]
|
|||||||
## [1.0.1] - 2017-10-14
|
## [1.0.1] - 2017-10-14
|
||||||
|
|
||||||
## Added
|
## Added
|
||||||
|
|
||||||
- [#17]: Added automated Gitlab CI production builds.
|
- [#17]: Added automated Gitlab CI production builds.
|
||||||
|
|
||||||
[#17]: https://gitlab.com/autonomic-cooperative/autonomic-cooperative.gitlab.io/merge_requests/17
|
[#17]: https://gitlab.com/autonomic-cooperative/autonomic-cooperative.gitlab.io/merge_requests/17
|
||||||
|
|
||||||
## [1.0.0] - 2017-10-04
|
## [1.0.0] - 2017-10-04
|
||||||
|
|
||||||
- Initial Release
|
- Initial Release
|
||||||
|
@ -1,62 +1,53 @@
|
|||||||
# Contributing
|
# Contributing
|
||||||
|
|
||||||
# What Is Jekyll
|
## What Is Jekyll
|
||||||
|
|
||||||
For those unfamiliar with how Jekyll works, check out [jekyll.rb] for all the
|
For those unfamiliar with how Jekyll works, check out [jekyll.rb] for all the
|
||||||
details, or read up on the basics of [front matter], [writing posts] and
|
details, or read up on the basics of [front matter], [writing posts] and
|
||||||
[creating pages].
|
[creating pages]. Alternatively, just dive in and start editing! After all, the
|
||||||
|
majority of this site is configuration is just flat text, so it's easy to work
|
||||||
|
with.
|
||||||
|
|
||||||
[jekyll.rb]: https://jekyllrb.com/
|
[jekyll.rb]: https://jekyllrb.com/
|
||||||
[front matter]: https://jekyllrb.com/docs/frontmatter/
|
[front matter]: https://jekyllrb.com/docs/frontmatter/
|
||||||
[writing posts]: https://jekyllrb.com/docs/posts/
|
[writing posts]: https://jekyllrb.com/docs/posts/
|
||||||
[creating pages]: https://jekyllrb.com/docs/pages/
|
[creating pages]: https://jekyllrb.com/docs/pages/
|
||||||
|
|
||||||
# Using RVM to Manage Ruby
|
## Development
|
||||||
|
|
||||||
In order to not blow up your computer handling a system wide Ruby installation, it is
|
The prerequisites are [Docker](https://www.docker.com/) and [Docker-compose](https://docs.docker.com/compose/).
|
||||||
advised that you use [RVM](https://rvm.io/rvm/install).
|
|
||||||
|
|
||||||
Once you've got that installed and configured, get the latest version of Ruby with:
|
If you're on Debian, installing is easy.
|
||||||
|
|
||||||
|
Install Docker.
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
$ rvm install 2.4.2
|
$ curl -fsSL https://get.docker.com -o get-docker.sh # have a look if you want
|
||||||
|
$ CHANNEL=stable sh get-docker.sh
|
||||||
```
|
```
|
||||||
|
|
||||||
Select that version and then create an isolated [gemset](https://rvm.io/gemsets/basics) with:
|
Install Docker-compose.
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
$ rvm use 2.4.2
|
$ cd autonomic.zone
|
||||||
$ rvm gemset create autonomic
|
$ python3 -m venv .venv
|
||||||
$ rvm gemset use autonomic
|
$ pip3 install -r requirements.txt
|
||||||
```
|
```
|
||||||
|
|
||||||
# Install Dependencies
|
Then fire up the container with the following.
|
||||||
|
|
||||||
Then you can get your Ruby dependencies installed with:
|
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
$ gem install jekyll bundler
|
$ docker-compose up
|
||||||
```
|
```
|
||||||
|
|
||||||
# Serve Website
|
Then visit the locally running website.
|
||||||
|
|
||||||
And serve the website locally with:
|
> http://localhost:4000
|
||||||
|
|
||||||
|
Then you can edit the files as normal and reload the page.
|
||||||
|
|
||||||
|
To stop the container when you're done, you can run:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
$ make devserver
|
$ docker-compose stop
|
||||||
```
|
```
|
||||||
|
|
||||||
# Editing Content
|
|
||||||
|
|
||||||
You can edit content in the `.md` files under `src` and `src/_posts`.
|
|
||||||
|
|
||||||
# Manage Gemset
|
|
||||||
|
|
||||||
When you're hacking later on (or in a new shell), you'll need to run:
|
|
||||||
|
|
||||||
``` bash
|
|
||||||
$ rvm use 2.4.2
|
|
||||||
$ rvm gemset use autonomic
|
|
||||||
```
|
|
||||||
|
|
||||||
And then you'll have access to the environment.
|
|
||||||
|
17
Dockerfile
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
FROM ruby:2.7.4-alpine3.12
|
||||||
|
|
||||||
|
EXPOSE 4000
|
||||||
|
|
||||||
|
RUN apk --no-cache add \
|
||||||
|
bash \
|
||||||
|
curl \
|
||||||
|
g++ \
|
||||||
|
git \
|
||||||
|
make
|
||||||
|
|
||||||
|
RUN gem install bundler -v 2.1.4
|
||||||
|
RUN gem install jekyll -v 4.0.0
|
||||||
|
|
||||||
|
COPY . ${WORKDIR}
|
||||||
|
|
||||||
|
RUN bundle install
|
6
Gemfile
@ -1,3 +1,7 @@
|
|||||||
source "https://rubygems.org"
|
source "https://rubygems.org"
|
||||||
ruby '2.4.2'
|
|
||||||
|
ruby "2.7.4"
|
||||||
|
|
||||||
gemspec
|
gemspec
|
||||||
|
|
||||||
|
gem "jekyll-feed"
|
||||||
|
80
Gemfile.lock
Normal file
@ -0,0 +1,80 @@
|
|||||||
|
PATH
|
||||||
|
remote: .
|
||||||
|
specs:
|
||||||
|
autonomic (0.0.0)
|
||||||
|
|
||||||
|
GEM
|
||||||
|
remote: https://rubygems.org/
|
||||||
|
specs:
|
||||||
|
addressable (2.7.0)
|
||||||
|
public_suffix (>= 2.0.2, < 5.0)
|
||||||
|
colorator (1.1.0)
|
||||||
|
concurrent-ruby (1.1.6)
|
||||||
|
em-websocket (0.5.1)
|
||||||
|
eventmachine (>= 0.12.9)
|
||||||
|
http_parser.rb (~> 0.6.0)
|
||||||
|
eventmachine (1.2.7)
|
||||||
|
ffi (1.12.2)
|
||||||
|
forwardable-extended (2.6.0)
|
||||||
|
http_parser.rb (0.6.0)
|
||||||
|
i18n (1.8.2)
|
||||||
|
concurrent-ruby (~> 1.0)
|
||||||
|
jekyll (4.0.0)
|
||||||
|
addressable (~> 2.4)
|
||||||
|
colorator (~> 1.0)
|
||||||
|
em-websocket (~> 0.5)
|
||||||
|
i18n (>= 0.9.5, < 2)
|
||||||
|
jekyll-sass-converter (~> 2.0)
|
||||||
|
jekyll-watch (~> 2.0)
|
||||||
|
kramdown (~> 2.1)
|
||||||
|
kramdown-parser-gfm (~> 1.0)
|
||||||
|
liquid (~> 4.0)
|
||||||
|
mercenary (~> 0.3.3)
|
||||||
|
pathutil (~> 0.9)
|
||||||
|
rouge (~> 3.0)
|
||||||
|
safe_yaml (~> 1.0)
|
||||||
|
terminal-table (~> 1.8)
|
||||||
|
jekyll-feed (0.13.0)
|
||||||
|
jekyll (>= 3.7, < 5.0)
|
||||||
|
jekyll-sass-converter (2.1.0)
|
||||||
|
sassc (> 2.0.1, < 3.0)
|
||||||
|
jekyll-watch (2.2.1)
|
||||||
|
listen (~> 3.0)
|
||||||
|
kramdown (2.2.1)
|
||||||
|
rexml
|
||||||
|
kramdown-parser-gfm (1.1.0)
|
||||||
|
kramdown (~> 2.0)
|
||||||
|
liquid (4.0.3)
|
||||||
|
listen (3.2.1)
|
||||||
|
rb-fsevent (~> 0.10, >= 0.10.3)
|
||||||
|
rb-inotify (~> 0.9, >= 0.9.10)
|
||||||
|
mercenary (0.3.6)
|
||||||
|
pathutil (0.16.2)
|
||||||
|
forwardable-extended (~> 2.6)
|
||||||
|
public_suffix (4.0.4)
|
||||||
|
rb-fsevent (0.10.4)
|
||||||
|
rb-inotify (0.10.1)
|
||||||
|
ffi (~> 1.0)
|
||||||
|
rexml (3.2.3)
|
||||||
|
rouge (3.18.0)
|
||||||
|
safe_yaml (1.0.5)
|
||||||
|
sassc (2.3.0)
|
||||||
|
ffi (~> 1.9)
|
||||||
|
terminal-table (1.8.0)
|
||||||
|
unicode-display_width (~> 1.1, >= 1.1.1)
|
||||||
|
unicode-display_width (1.7.0)
|
||||||
|
|
||||||
|
PLATFORMS
|
||||||
|
ruby
|
||||||
|
|
||||||
|
DEPENDENCIES
|
||||||
|
autonomic!
|
||||||
|
bundler (>= 2.1.4)
|
||||||
|
jekyll (>= 4)
|
||||||
|
jekyll-feed
|
||||||
|
|
||||||
|
RUBY VERSION
|
||||||
|
ruby 2.7.3p183
|
||||||
|
|
||||||
|
BUNDLED WITH
|
||||||
|
2.1.4
|
6
Makefile
@ -1,6 +0,0 @@
|
|||||||
DEV_DIST_DIR:=dist
|
|
||||||
|
|
||||||
devserver:
|
|
||||||
@echo "Serving development site from $(DEV_DIST_DIR)"
|
|
||||||
@jekyll serve --watch --incremental --destination $(DEV_DIST_DIR)
|
|
||||||
.PHONY: devserver
|
|
57
README.md
@ -1,59 +1,14 @@
|
|||||||
[![pipeline status](https://gitlab.com/autonomic-cooperative/autonomic-cooperative.gitlab.io/badges/master/pipeline.svg)](https://gitlab.com/autonomic-cooperative/autonomic-cooperative.gitlab.io/commits/master)
|
# autonomic.zone
|
||||||
|
|
||||||
# autonomic-cooperative.gitlab.io
|
[![Build Status](https://drone.autonomic.zone/api/badges/autonomic-cooperative/autonomic.zone/status.svg)](https://drone.autonomic.zone/autonomic-cooperative/autonomic.zone)
|
||||||
|
|
||||||
A [Jekyll] based site for the Autonomic Cooperative.
|
> https://autonomic.zone
|
||||||
|
|
||||||
The template is based on the [spectral-jekyll-theme].
|
A [Jekyll] based site for the Autonomic Cooperative. The site is based on the [spectral-jekyll-theme] template.
|
||||||
|
|
||||||
We use [autonomic.zone] for production and [autonomic-cooperative.gitlab.io] for staging.
|
[jekyll]: https://jekyllrb.com/
|
||||||
|
|
||||||
[Jekyll]: https://jekyllrb.com/
|
|
||||||
[spectral-jekyll-theme]: https://github.com/andrewbanchich/spectral-jekyll-theme
|
[spectral-jekyll-theme]: https://github.com/andrewbanchich/spectral-jekyll-theme
|
||||||
[autonomic.zone]: https://autonomic.zone/
|
|
||||||
[autonomic-cooperative.gitlab.io]: http://autonomic-cooperative.gitlab.io/
|
|
||||||
|
|
||||||
# Contribute
|
# Contribute
|
||||||
|
|
||||||
Please see [CONTRIBUTING.md] for the juicy details.
|
Please see [CONTRIBUTING.md](./CONTRIBUTING.md) for the juicy details.
|
||||||
|
|
||||||
[CONTRIBUTING.md]: https://gitlab.com/autonomic-cooperative/autonomic-cooperative.gitlab.io/blob/master/CONTRIBUTING.md
|
|
||||||
|
|
||||||
# Make A New Release
|
|
||||||
|
|
||||||
Please add a new [change log] entry. This helps us track released changes easily.
|
|
||||||
|
|
||||||
[change log]: https://gitlab.com/autonomic-cooperative/autonomic-cooperative.gitlab.io/blob/master/CHANGELOG.md
|
|
||||||
|
|
||||||
Then, [tag a new commit] and send it upstream with:
|
|
||||||
|
|
||||||
[tag a new commit]: https://git-scm.com/book/en/v2/Git-Basics-Tagging
|
|
||||||
[semantic versioning]: http://semver.org/
|
|
||||||
|
|
||||||
```bash
|
|
||||||
$ COMMIT=$(git rev-parse HEAD)
|
|
||||||
$ TAG=6.6.6 # enter your new tag
|
|
||||||
$ git tag -a $TAG $COMMIT
|
|
||||||
$ git push upstream master --tags
|
|
||||||
```
|
|
||||||
|
|
||||||
You can also use the [Gitlab tags UI] for this.
|
|
||||||
|
|
||||||
[Gitlab tags UI]: https://gitlab.com/autonomic-cooperative/autonomic-cooperative.gitlab.io/tags
|
|
||||||
|
|
||||||
Our [deploy] CI stage will push the new site to [the production branch].
|
|
||||||
|
|
||||||
[deploy]: https://gitlab.com/autonomic-cooperative/autonomic-cooperative.gitlab.io/blob/d16aec42bd2ddd7449f55d9f06b03499cc660b22/.gitlab-ci.yml#L17
|
|
||||||
[the production branch]: https://gitlab.com/autonomic-cooperative/autonomic-cooperative.gitlab.io/tree/production
|
|
||||||
|
|
||||||
Watch the [CI/CD pipeline] to see that it builds successfully.
|
|
||||||
|
|
||||||
[CI/CD pipeline]: https://gitlab.com/autonomic-cooperative/autonomic-cooperative.gitlab.io/pipelines
|
|
||||||
|
|
||||||
Then head over to [fullyautomatedluxuryinfrastructure] and run:
|
|
||||||
|
|
||||||
[fullyautomatedluxuryinfrastructure]: https://gitlab.com/autonomic-cooperative/fullyautomatedluxuryinfrastructure
|
|
||||||
|
|
||||||
``` bash
|
|
||||||
$ ansible-playbook orgs/autonomic/gitlabpages.yml
|
|
||||||
```
|
|
||||||
|
13
_config.yml
@ -1,17 +1,18 @@
|
|||||||
|
---
|
||||||
title: Autonomic Co-operative
|
title: Autonomic Co-operative
|
||||||
email: autonomic@posteo.net
|
email: helo@autonomic.zone
|
||||||
description: Sustainability, Transparency, Privacy
|
description: Sustainability, Transparency, Privacy
|
||||||
baseurl: ""
|
baseurl: ""
|
||||||
url: ""
|
url: "https://autonomic.zone"
|
||||||
source: src
|
source: src
|
||||||
destination: dist
|
destination: dist
|
||||||
sass:
|
sass:
|
||||||
sass_dir: ./assets/styles
|
sass_dir: ./assets/styles
|
||||||
featured-image-source:
|
featured-image-source:
|
||||||
500px_url:
|
include: ["src/.well-known", "src/.nojekyll"]
|
||||||
github_url:
|
mastodon_url: https://sunbeam.city/@autonomic
|
||||||
gitlab_url: https://gitlab.com/autonomic-cooperative
|
|
||||||
twitter_url: https://twitter.com/autonomiccoop
|
twitter_url: https://twitter.com/autonomiccoop
|
||||||
|
gitea_url: https://git.autonomic.zone/autonomic-cooperative/
|
||||||
markdown: kramdown
|
markdown: kramdown
|
||||||
permalink: pretty
|
permalink: pretty
|
||||||
collections:
|
collections:
|
||||||
@ -24,3 +25,5 @@ exclude:
|
|||||||
- vendor
|
- vendor
|
||||||
- Gemfile
|
- Gemfile
|
||||||
- Gemfile.lock
|
- Gemfile.lock
|
||||||
|
plugins:
|
||||||
|
- jekyll-feed
|
||||||
|
@ -2,14 +2,14 @@
|
|||||||
|
|
||||||
Gem::Specification.new do |spec|
|
Gem::Specification.new do |spec|
|
||||||
spec.name = "autonomic"
|
spec.name = "autonomic"
|
||||||
spec.version = '0.0.0'
|
spec.version = "0.0.0"
|
||||||
spec.date = '2017-09-24'
|
spec.date = "2017-09-24"
|
||||||
spec.summary = ""
|
spec.summary = ""
|
||||||
spec.description = ""
|
spec.description = ""
|
||||||
spec.authors = ['autonomic co-operative']
|
spec.authors = ["autonomic co-operative"]
|
||||||
spec.email = 'autonomic.posteo.net'
|
spec.email = "autonomic.posteo.net"
|
||||||
spec.files = `git ls-files -z`.split("\x0").select { |f| f.match(%r{^(assets|_layouts|_includes|_sass|LICENSE|README)}i) }
|
spec.files = "README.md"
|
||||||
|
|
||||||
spec.add_development_dependency "jekyll", "~> 3.3"
|
spec.add_development_dependency "jekyll", ">= 4"
|
||||||
spec.add_development_dependency "bundler", "~> 1.12"
|
spec.add_development_dependency "bundler", ">= 2.1.4"
|
||||||
end
|
end
|
||||||
|
35
docker-compose.prod.yml
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
---
|
||||||
|
version: "3.8"
|
||||||
|
|
||||||
|
services:
|
||||||
|
jekyll:
|
||||||
|
image: decentral1se/autonomic.zone:latest
|
||||||
|
command: |
|
||||||
|
bundle exec
|
||||||
|
jekyll serve --host 0.0.0.0 --trace
|
||||||
|
environment:
|
||||||
|
JEKYLL_ENV: production
|
||||||
|
networks:
|
||||||
|
- proxy
|
||||||
|
healthcheck:
|
||||||
|
test: ["CMD", "curl", "-f", "http://localhost:4000"]
|
||||||
|
interval: 15s
|
||||||
|
timeout: 10s
|
||||||
|
retries: 10
|
||||||
|
start_period: 20s
|
||||||
|
deploy:
|
||||||
|
update_config:
|
||||||
|
failure_action: rollback
|
||||||
|
order: start-first
|
||||||
|
labels:
|
||||||
|
- "traefik.enable=true"
|
||||||
|
- "traefik.http.services.jekyll.loadbalancer.server.port=4000"
|
||||||
|
- "traefik.http.routers.jekyll.rule=Host(`old.autonomic.zone`) || Host(`www.old.autonomic.zone`)"
|
||||||
|
- "traefik.http.routers.jekyll.entrypoints=web-secure"
|
||||||
|
- "traefik.http.routers.jekyll.tls.certresolver=production"
|
||||||
|
- "traefik.http.routers.jekyll.tls.options=default@file"
|
||||||
|
- "traefik.http.routers.jekyll.middlewares=security@file"
|
||||||
|
|
||||||
|
networks:
|
||||||
|
proxy:
|
||||||
|
external: true
|
13
docker-compose.yml
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
---
|
||||||
|
version: "3.8"
|
||||||
|
|
||||||
|
services:
|
||||||
|
jekyll:
|
||||||
|
image: decentral1se/autonomic.zone:latest
|
||||||
|
command: |
|
||||||
|
bundle exec
|
||||||
|
jekyll serve --watch --host 0.0.0.0 --force_polling --trace
|
||||||
|
volumes:
|
||||||
|
- ".:/srv/jekyll"
|
||||||
|
ports:
|
||||||
|
- "4000:4000"
|
6
renovate.json
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
{
|
||||||
|
"$schema": "https://docs.renovatebot.com/renovate-schema.json",
|
||||||
|
"extends": [
|
||||||
|
"config:base"
|
||||||
|
]
|
||||||
|
}
|
1
requirements.txt
Normal file
@ -0,0 +1 @@
|
|||||||
|
docker-compose==1.29.2
|
0
src/.nojekyll
Normal file
3
src/.well-known/autonomic.zone/matrix/server
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
{
|
||||||
|
"m.server": "matrix.autonomic.zone:443"
|
||||||
|
}
|
@ -1,15 +0,0 @@
|
|||||||
<section id="two" class="wrapper alt style2">
|
|
||||||
|
|
||||||
{% for post in site.categories.values %}
|
|
||||||
|
|
||||||
<section class="spotlight">
|
|
||||||
<div class="image">{% if post.image %}<img src="{% if site.featured-image-source %}{{ post.image | prepend: site.featured-image-source | absolute_url }}{% else %}{{ "" | absolute_url }}/assets/images/{{ post.image }}{% endif %}" alt="" />{% endif %}</div>
|
|
||||||
<div class="content">
|
|
||||||
<h2><a href="{{ post.url | relative_url }}" class="link">{{ post.title }}</a></h2>
|
|
||||||
<p class="h5">{{ post.date | date: '%B %d, %Y' }}</p>
|
|
||||||
<p>{{ post.description }}</p>
|
|
||||||
</div>
|
|
||||||
</section>
|
|
||||||
{% endfor %}
|
|
||||||
|
|
||||||
</section>
|
|
@ -1,12 +1,13 @@
|
|||||||
<a class="named-anchor" name="contact"></a>
|
|
||||||
<section id="contact" class="wrapper style5 special">
|
<section id="contact" class="wrapper style5 special">
|
||||||
|
<a class="named-anchor" name="contact">
|
||||||
<header class="major">
|
<header class="major">
|
||||||
<h2>Get in Touch</h2>
|
<h2>Get in Touch</h2>
|
||||||
<p>Contact us to discuss your project's needs and arrange a consultation.</p>
|
<p>Contact us to discuss your project's needs and arrange a consultation.</p>
|
||||||
<p><a href="mailto:autonomic-coop@posteo.net">autonomic-coop@posteo.net</a></p>
|
<p><a href="mailto:helo@autonomic.zone">helo@autonomic.zone</a></p>
|
||||||
<p>
|
<p>
|
||||||
If you use encrypted email, here is our <a href="{{ "/assets/pgp/autonomic-key.asc" | relative_url }}">PGP key</a>.
|
If you use encrypted email, here is our <a href="{{ "/assets/pgp/autonomic-key.asc" | relative_url }}">PGP key</a>.
|
||||||
Our key fingerprint is: <br/><code id="fingerprint">82FC 87C5 1A71 902F DC10 2CF5 4F90 D55B B24B 1147</code>
|
Our key fingerprint is: <br/><code id="fingerprint">82FC 87C5 1A71 902F DC10 2CF5 4F90 D55B B24B 1147</code>
|
||||||
</p>
|
</p>
|
||||||
</header>
|
</header>
|
||||||
|
</a>
|
||||||
</section>
|
</section>
|
||||||
|
@ -12,15 +12,21 @@
|
|||||||
</header>
|
</header>
|
||||||
<ul class="icons major icons--flex">
|
<ul class="icons major icons--flex">
|
||||||
<li>
|
<li>
|
||||||
<span class="icon fa-leaf major style1"></span>
|
<span class="icon icon--diamond icon--style3">
|
||||||
|
<svg viewBox="0 0 1792 1792"><path d="M1280 704q0-26-19-45t-45-19q-172 0-318 50T639 824t-236 219q-19 21-19 45 0 26 19 45t45 19q24 0 45-19 27-24 74-71t67-66q137-124 269-176t313-52q26 0 45-19t19-45zm512-198q0 95-20 193-46 224-184 383t-358 268q-214 108-438 108-148 0-286-47-15-5-88-42t-96-37q-16 0-39 32t-45 70-53 70-60 32q-43 0-63-17t-46-60l-6-11-5-10-3-9q-2-6-2-14 0-35 31-73t68-66 68-56 31-48q0-4-14-38t-16-44q-9-51-9-104 0-115 44-220t119-184 170-139 204-96q55-18 145-25t180-9 178-6 164-24 113-57l30-29 29-28 27-20 37-16 43-5q39 0 71 46t47 112 24 124 8 96z" /></svg>
|
||||||
|
</span>
|
||||||
<span class="icons__title">Sustainability</span>
|
<span class="icons__title">Sustainability</span>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<span class="icon fa-eye major style1"></span>
|
<span class="icon icon--diamond icon--style3">
|
||||||
|
<svg viewBox="0 100 1792 1692"><path d="M1664 960q-152-236-381-353 61 104 61 225 0 185-131 317t-317 131-316-131-132-317q0-121 61-225-229 117-381 353 133 205 334 327t434 121 435-121 333-327zM944 576q0-20-14-34t-34-14q-125 0-214 90t-90 214q0 20 14 34t34 14 34-14 14-34q0-86 61-147t147-61q20 0 34-14t14-34zm848 384q0 34-20 69-140 230-376 369t-500 138-499-139-377-368Q0 994 0 960t20-69q140-229 377-368t499-139 500 139 376 368q20 35 20 69z" /></svg>
|
||||||
|
</span>
|
||||||
<span class="icons__title">Transparency</span>
|
<span class="icons__title">Transparency</span>
|
||||||
</li>
|
</li>
|
||||||
<li>
|
<li>
|
||||||
<span class="icon fa-lock major style1"></span>
|
<span class="icon icon--diamond icon--style3">
|
||||||
|
<svg viewBox="0 0 1792 1792"><path d="M640 768h512V576q0-106-75-181t-181-75-181 75-75 181v192zm832 96v576q0 40-28 68t-68 28H416q-40 0-68-28t-28-68V864q0-40 28-68t68-28h32V576q0-184 132-316t316-132 316 132 132 316v192h32q40 0 68 28t28 68z" /></svg>
|
||||||
|
</span>
|
||||||
<span class="icons__title">Privacy</span>
|
<span class="icons__title">Privacy</span>
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
|
@ -1,14 +1,7 @@
|
|||||||
<!-- Piwik -->
|
<!-- Scripts -->
|
||||||
<script type="text/javascript">
|
<script src="{{ "/assets/js/jquery-3.4.1.min.js" | absolute_url }}"></script>
|
||||||
var _paq = _paq || [];
|
<script src="{{ "/assets/js/jquery.scrollex.min.js" | absolute_url }}"></script>
|
||||||
_paq.push(['trackPageView']);
|
<script src="{{ "/assets/js/skel.min.js" | absolute_url }}"></script>
|
||||||
_paq.push(['enableLinkTracking']);
|
<script src="{{ "/assets/js/util.js" | absolute_url }}"></script>
|
||||||
(function() {
|
<script src="{{ "/assets/js/particles.min.js" | absolute_url }}""></script>
|
||||||
_paq.push(['setTrackerUrl', 'https://api-183ae21d2fb4215fa8fb3bbf13fbda21.autonomic.sandcats.io']);
|
<script src="{{ "/assets/js/main.js" | absolute_url }}"></script>
|
||||||
_paq.push(['setSiteId', 1]);
|
|
||||||
_paq.push(['setApiToken', '6X45HLvJ0KWNiLTlhbZ-uuhZcXfg9n3bDauHalRZMSh']);
|
|
||||||
var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0];
|
|
||||||
g.type='text/javascript'; g.async=true; g.defer=true; g.src='https://6aurs6uetbyvpubfuh5y.autonomic.sandcats.io/embed.js'; s.parentNode.insertBefore(g,s);
|
|
||||||
})();
|
|
||||||
</script>
|
|
||||||
<!-- End Piwik Code -->
|
|
@ -1,40 +1,64 @@
|
|||||||
<!-- Footer -->
|
<!-- Footer -->
|
||||||
<footer id="footer">
|
<footer id="footer">
|
||||||
<ul class="icons">
|
<div class="row">
|
||||||
{% if site.twitter_url %}
|
<div class="column">
|
||||||
<li><a href="{{ site.twitter_url }}" class="icon fa-twitter" target="_blank"><span class="label">Twitter</span></a></li>
|
<a class="named-anchor" name="contact"></a>
|
||||||
{% endif %} {% if site.500px_url %}
|
<h3>Get in Touch</h3>
|
||||||
<li><a href="{{ site.500px_url }}" class="icon fa-500px" target="_blank"><span class="label">500px</span></a></li>
|
Contact us to discuss your project's needs and arrange a consultation:</br>
|
||||||
{% endif %} {% if site.gitlab_url %}
|
<b><a href="mailto:helo@autonomic.zone">helo@autonomic.zone</a></b></br></br>
|
||||||
<li><a href="{{ site.gitlab_url }}" class="icon fa-gitlab" target="_blank"><span class="label">GitLab</span></a></li>
|
<b><a href="{{ '/assets/pgp/autonomic-key.asc' | relative_url }}">Download PGP key</a></b></br>
|
||||||
{% endif %} {% if site.github_url %}
|
<a href= "https://git.autonomic.zone/autonomic-cooperative/autonomic.zone/src/branch/main/src/assets/pgp"> Verify fingerprint:</a><code id="fingerprint">82FC 87C5 1A71 902F DC10 2CF5 4F90 D55B B24B 1147</code>
|
||||||
<li><a href="{{ site.github_url }}" class="icon fa-github" target="_blank"><span class="label">GitHub</span></a></li>
|
|
||||||
{% endif %}
|
|
||||||
</ul>
|
|
||||||
<ul class="copyright">
|
|
||||||
<li class="icon fa-creative-commons"> {{ site.title }}</li>
|
|
||||||
</ul>
|
|
||||||
|
|
||||||
<address>
|
<ul class="icons" style="margin-bottom: 0; padding-top: 1em">
|
||||||
Autonomic Co-operative</br>
|
<li>
|
||||||
1539 Pershore Road </br>
|
<a title="RSS Feed" rel="me" href="{{ '/feed.xml' | absolute_url }}" style="border-bottom: none">
|
||||||
Stirchley</br>
|
<!-- This SVG needs to be changed if you change the colour scheme as it is a massive hack. -->
|
||||||
B30 2JH
|
<img alt="rss" style="height: 2rem;color: #fff" src="{{ '/assets/svg/rss-square-solid.svg' | absolute_url }}">
|
||||||
</address>
|
</a>
|
||||||
</footer>
|
</li>
|
||||||
|
<li>
|
||||||
|
<a title="Twitter" rel="noopener" href="{{ site.twitter_url }}" style="border-bottom: none">
|
||||||
|
<img alt="twitter" style="height: 2rem;" src="{{ '/assets/svg/twitter-brands.svg' | absolute_url }}">
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<a title="Mastodon" rel="me" href="{{ site.mastodon_url }}" style="border-bottom: none">
|
||||||
|
<img alt="mastodon" style="height: 2rem;" src="{{ '/assets/svg/mastodon-brands.svg' | absolute_url }}">
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<a title="Gitea" rel="me" href="{{ site.gitea_url }}" style="border-bottom: none">
|
||||||
|
<!-- This SVG needs to be changed if you change the colour scheme as it is a massive hack. -->
|
||||||
|
<img alt="gitea" style="height: 2.3rem;" src="{{ '/assets/svg/Gitea_Logo.svg' | absolute_url }}">
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
<div class="column">
|
||||||
<!-- Scripts -->
|
<div class="copyright">
|
||||||
<script src="{{ "/assets/js/jquery.min.js" | absolute_url }}"></script>
|
</div>
|
||||||
<script src="{{ "/assets/js/jquery.scrollex.min.js" | absolute_url }}"></script>
|
<div class="cotech-box">
|
||||||
<script src="{{ "/assets/js/jquery.scrolly.min.js" | absolute_url }}"></script>
|
<a href="https://www.coops.tech/">
|
||||||
<script src="{{ "/assets/js/skel.min.js" | absolute_url }}"></script>
|
<img class="cotech-logo" src="{{ '/assets/images/CoTech-white-logo.png' | relative_url }}" alt="CoTech"/>
|
||||||
<script src="{{ "/assets/js/util.js" | absolute_url }}"></script>
|
<b><span class="cotech-text">Member of the Cotech Network</span></b>
|
||||||
<script src="//cdn.jsdelivr.net/particles.js/2.0.0/particles.min.js"></script>
|
</a>
|
||||||
<!--[if lte IE 8]><script src="{{ "/assets/js/ie/respond.min.js" | absolute_url }}"></script><![endif]-->
|
</div>
|
||||||
<script src="{{ "/assets/js/main.js" | absolute_url }}"></script>
|
<div style="vertical-align: bottom;">
|
||||||
|
<address>
|
||||||
</body>
|
Autonomic Co-operative Limited</br>
|
||||||
|
1539 Pershore Road</br>
|
||||||
</html>
|
Birmingham</br>
|
||||||
|
B30 2JH</br>
|
||||||
|
United Kingdom</br>
|
||||||
|
</address></br>
|
||||||
|
We are a Co-operative Society registered with the <a href="https://mutuals.fca.org.uk/Search/Society/30380">FCA</a>.
|
||||||
|
<b>Registration Number: 4597 </b>
|
||||||
|
</br></br>
|
||||||
|
</div>
|
||||||
|
<div style="vertical-align: bottom;">
|
||||||
|
<a href="{{ '/privacy' | relative_url }}">Privacy Policy</a> - <a href="{{ '/terms' | relative_url }}">Terms of Service</a> - <a href="{{ '/gdpr' | relative_url }}">GDPR</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</footer>
|
||||||
|
@ -1,10 +1,12 @@
|
|||||||
<head>
|
<head>
|
||||||
|
<meta charset="utf-8">
|
||||||
<title>{{ site.title }}</title>
|
<title>{{ site.title }}</title>
|
||||||
<meta charset="utf-8" />
|
|
||||||
<link rel="shortcut icon" href="{{ "/assets/images/favicon.ico" | relative_url }}" />
|
{% if page.meta_description %}
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
<meta name="description" value="{{ page.meta_description }}">
|
||||||
<!--[if lte IE 8]><script src="{{ "/assets/js/ie/html5shiv.js" | relative_url }}"></script><![endif]-->
|
{% endif %}
|
||||||
<link rel="stylesheet" href="{{ "/assets/styles/main.css" | relative_url }}" />
|
|
||||||
<!--[if lte IE 8]><link rel="stylesheet" href="{{ "/assets/css/ie8.css" | relative_url }}" /><![endif]-->
|
<link rel="shortcut icon" href="{{ "/assets/images/favicon.ico" | relative_url }}">
|
||||||
<!--[if lte IE 9]><link rel="stylesheet" href="{{ "/assets/css/ie9.css" | relative_url }}" /><![endif]-->
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
|
<link rel="stylesheet" href="{{ "/assets/styles/main.css" | relative_url }}">
|
||||||
</head>
|
</head>
|
||||||
|
@ -1,20 +1,21 @@
|
|||||||
<div id="page-wrapper">
|
<header class="header {% if page.layout == 'default' %}alt{% endif %}">
|
||||||
<header id="header" {% if page.layout == 'default' %} class="alt" {% endif %}>
|
<h1 class="header-home"><a href="{{ "/" | absolute_url }}">Autonomic</a></h1>
|
||||||
<h1><a href="{{ "/" | absolute_url }}">Autonomic</a></h1>
|
<nav>
|
||||||
<nav id="nav">
|
<ul class="header-nav">
|
||||||
<ul>
|
<li>
|
||||||
<li class="special">
|
<a class="header-link" href="{{ "/#core-values" | relative_url }}">Values</a>
|
||||||
<a href="#menu" class="menuToggle"><span>Menu</span></a>
|
</li>
|
||||||
<div id="menu">
|
<li>
|
||||||
<ul>
|
<a class="header-link" href="{{ "/#services" | relative_url }}">Services</a>
|
||||||
<li><a href="{{ "/" | relative_url }}">Home</a></li>
|
</li>
|
||||||
<li><a href="{{ "/#core-values" | relative_url }}">Our Core Values</a></li>
|
<li>
|
||||||
<li><a href="{{ "/blog" | relative_url }}">Blog</a></li>
|
<a class="header-link" href="{{ "/blog" | relative_url }}">Blog</a>
|
||||||
<li><a href="{{ "/#services" | relative_url }}">Services We Offer</a></li>
|
</li>
|
||||||
<li><a href="{{ "/#contact" | relative_url }}">Get In Touch</a></li>
|
<li>
|
||||||
</ul>
|
<a class="header-link" href="{{ "/#contact" | relative_url }}">Contact</a>
|
||||||
</div>
|
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
</nav>
|
</nav>
|
||||||
</header>
|
</header>
|
||||||
|
|
||||||
|
<div id="page-wrapper">
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
<section class="wrapper style5 special compressed">
|
<section class="wrapper style5 special compressed">
|
||||||
<a href="https://www.coops.tech/" target="_blank">
|
<a rel="noopener" href="https://www.coops.tech/">
|
||||||
<img src="/assets/images/Member-of-CoTech-logo-200.png" alt="Member of Co-Tech"/>
|
<img src="/assets/images/Member-of-CoTech-logo-200.png" alt="Member of Co-Tech"/>
|
||||||
</a>
|
</a>
|
||||||
</section>
|
</section>
|
||||||
|
@ -2,55 +2,85 @@
|
|||||||
<section id="three" class="wrapper style6 special">
|
<section id="three" class="wrapper style6 special">
|
||||||
<div class="inner">
|
<div class="inner">
|
||||||
<header class="major">
|
<header class="major">
|
||||||
<h2>Services we offer</h2>
|
<h2>Cooperative Cloud Infrastructure</h2>
|
||||||
<p>
|
<p>
|
||||||
We design integrated infrastructure tailored to your needs utilising
|
This isn't an exhaustive list. If you don't see what you need, please contact us anyway for a consultation:
|
||||||
technologies from <br/> the best free and open source software projects
|
|
||||||
available. Your data under your control.<br/> Here are some examples of
|
|
||||||
the applications we have deployed for our clients.
|
|
||||||
</p>
|
</p>
|
||||||
|
<h3><a href="mailto:helo@autonomic.zone">helo@autonomic.zone</a></h3>
|
||||||
</header>
|
</header>
|
||||||
<ul class="features">
|
<ul class="features">
|
||||||
<li class="icon fa-paper-plane-o">
|
<li class="features-item">
|
||||||
|
<svg class="features-icon" viewBox="0 0 1792 1792"><path d="M127 896q0-163 67-313l367 1005q-196-95-315-281T127 896zm1288-39l-2 39q-2 20-10 49t-12 44-17 59-18 58l-76 256-278-826q46-3 88-8 19-2 26-18t-2-31-29-14l-205 10q-75-1-202-10-12-1-20 5t-12 15-1 19 9 16 19 8l80 8 120 328-168 504-280-832q46-3 88-8 19-2 26-18t-2-31-29-14l-205 10h-23l-26-1q105-160 275-253t367-94q147 0 281 53t238 149h-10q-55 0-92 41t-37 95l2 24 4 22q2 10 8 23t9 21 12 22 13 21 14 24 14 23q63 107 63 212zM909 963l237 647q1 6 5 11-126 44-255 44-112 0-217-32zm661-436q95 174 95 369 0 209-104 386t-279 278l235-678q59-169 59-276 0-42-6-79zM896 0q182 0 348 71t286 191 191 286 71 348-71 348-191 286-286 191-348 71-348-71-286-191-191-286T0 896t71-348 191-286T548 71 896 0zm0 1751q173 0 332-68t273-182 182-273 68-332-68-331-182-273-273-183-332-68-331 68-273 183-183 273-68 331 68 332 183 273 273 182 331 68z"/></svg>
|
||||||
|
<div>
|
||||||
|
<h3>Websites</h3>
|
||||||
|
<p>
|
||||||
|
We offer <a href="https://wordpress.com/">Wordpress</a> and static sites. Either managed or unmanaged with frictionless tools for editing and publishing that empower users. <a href="https://matomo.org/">Matomo</a> provides ethical analytics to measure impact.
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
<!-- <li class="features-item">
|
||||||
|
<svg class="features-icon" viewBox="0 0 1792 1792"><path d="M1703 478q40 57 18 129l-275 906q-19 64-76 108t-123 43H324q-77 0-148-53T76 1479q-24-67-2-127l3-27 4-37q1-8-3-21t-3-20q2-11 8-21t17-23 16-24q23-38 45-91t30-92q3-10 1-30t-1-28q3-11 17-28t17-23q21-36 42-92t25-90q1-9-2-32t0-28q4-13 22-30t22-23q19-26 43-84t27-97q1-8-3-25t-2-27q2-8 9-18t18-23 17-21q8-12 17-30t15-35 16-36 19-32 27-24 36-11 47 5l-1 3q38-9 51-9h761q74 0 114 56t18 130l-274 906q-36 119-71 154t-129 34H220q-27 0-38 15-11 16-1 43 24 70 144 70h923q29 0 56-15t35-42l300-987q7-22 5-57 38 15 59 43zm-1064 2q-4 13 2 23t20 9h608q13 0 26-9t16-23l21-64q4-13-2-22t-20-10H702q-13 0-25 10t-17 22zm-83 256q-4 13 2 23t20 9h608q13 0 26-9t16-23l21-64q4-13-2-22t-20-10H619q-13 0-25 10t-17 22z"/></svg>
|
||||||
|
<div>
|
||||||
|
<h3>CRM and Case Management</h3>
|
||||||
|
<p>
|
||||||
|
For case work (e.g. housing or asylum support) we offer our own system, OpenCase. It's simple and user-friendly, perfect for small, volunteer-led groups. We will also consider CiviCRM depending on requirements.
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
</li> -->
|
||||||
|
<!-- <li class="features-item">
|
||||||
|
<svg class="features-icon" viewBox="0 0 1792 1792"><path d="M1764 11q33 24 27 64l-256 1536q-5 29-32 45-14 8-31 8-11 0-24-5l-527-215-298 327q-18 21-47 21-14 0-23-4-19-7-30-23t-11-37v-452L40 1083q-37-14-40-55-3-39 32-59L1696 9q35-21 68 2zm-342 1499l221-1323-1434 827 336 137 863-639-478 797z"/></svg>
|
||||||
|
<div>
|
||||||
<h3>Encrypted Email</h3>
|
<h3>Encrypted Email</h3>
|
||||||
<p>
|
<p>
|
||||||
Secure your email communications with state of the art transport
|
Secure your email communications with state of the art transport
|
||||||
encryption and <a href="https://0xacab.org/riseuplabs/trees">TREES</a>
|
encryption and <a href="https://0xacab.org/riseuplabs/trees">TREES</a>
|
||||||
encrypted mailbox storage.
|
encrypted mailbox storage.
|
||||||
</p>
|
</p>
|
||||||
</li>
|
</div>
|
||||||
<li class="icon fa-rocket2">
|
</li> -->
|
||||||
<h3>Text and Video Chat</h3>
|
<li class="features-item">
|
||||||
|
<svg class="features-icon" viewBox="0 0 1024 901"><g fill-rule="nonzero"><path d="M898 350zM308 38c32 18 62 40 87 64 41-7 84-11 127-11 128 0 250 34 343 95 48 32 86 70 113 112a279 279 0 010 305c-27 42-65 80-113 111-93 62-215 95-343 95-43 0-86-3-127-11-25 25-55 47-87 65-168 84-308 2-308 2s130-111 109-208c-58-59-90-131-90-207 0-75 32-147 90-207C130 146 0 36 0 36s140-82 308 2zM208 618c16 52 6 111-29 176l-5 10c30-3 61-11 92-27 24-13 46-30 65-48l36-34c48 13 101 20 157 20 225 0 408-118 408-265 0-146-183-264-408-264-226 0-409 118-409 264 0 64 35 123 93 168z"/><path d="M328 509a60 60 0 110-120 60 60 0 010 120zm194 0a60 60 0 110-120 60 60 0 010 120zm194 0a60 60 0 11-1-120 60 60 0 011 120z"/></g></svg>
|
||||||
|
<div>
|
||||||
|
<h3>Team Chat</h3>
|
||||||
<p>
|
<p>
|
||||||
Mobile friendly multi-channel team chat using <a href="https://rocket.chat/">Rocket.Chat</a>,
|
Mobile friendly multi-channel team chat using <a href="https://rocket.chat/">Rocket.Chat</a>,
|
||||||
with no artificial limits on features. Vital for remote project coordination.
|
with no artificial limits on features. Vital for remote project coordination.
|
||||||
</p>
|
</p>
|
||||||
|
</div>
|
||||||
</li>
|
</li>
|
||||||
<li class="icon fa-cloud-o">
|
<li class="features-item">
|
||||||
|
<svg class="features-icon" viewBox="0 0 2048 1792"><path d="M1984 1152q0 159-112 272t-272 112H512q-185 0-316-131T64 1088q0-132 71-241t187-164l-2-43q0-212 150-362t362-150q158 0 287 88t187 230q70-62 166-62 106 0 181 75t75 181q0 75-41 138 129 30 213 135t84 239z"/></svg>
|
||||||
|
<div>
|
||||||
<h3>Cloud Storage and Collaboration</h3>
|
<h3>Cloud Storage and Collaboration</h3>
|
||||||
<p>
|
<p>
|
||||||
<a href="https://sandstorm.io/">Sandstorm</a> is a personal "cloud
|
<a href="https://nextcloud.com/">Nextcloud</a> for file-storage, collaborative document editing, calendars. We also host <a href="https://github.com/hackmdio/codimd">CodiMD</a>, <a href="https://etherpad.org/">Etherpad</a>, <a href="https://gitea.io">Gitea</a> and <a href="https://wekan.github.io/">Wekan</a> instances.
|
||||||
in a box" , designed with the upmost security in mind. It allows you to
|
|
||||||
deploy apps for file-storage, collaborative document editing,
|
|
||||||
calendars, to-do lists and much more.
|
|
||||||
</p>
|
</p>
|
||||||
|
</div>
|
||||||
</li>
|
</li>
|
||||||
<li class="icon fa-headphones">
|
<!-- <li class="features-item">
|
||||||
|
<svg class="features-icon" viewBox="0 0 1792 1792"><path d="M1728 886q0 166-60 314l-20 49-185 33q-22 83-90 137t-157 53v32q0 14-9 23t-23 9h-64q-14 0-23-9t-9-23V928q0-14 9-23t23-9h64q14 0 23 9t9 23v32q71 0 130 36t93 95l68-12q29-95 29-193 0-148-88-279t-236-209-316-78-315 78-237 209-88 279q0 98 29 193l68 12q34-60 93-95t130-36v-32q0-14 9-23t23-9h64q14 0 23 9t9 23v576q0 14-9 23t-23 9h-64q-14 0-23-9t-9-23v-32q-88 0-156-53t-91-137l-185-33-20-49q-60-148-60-314 0-151 67-291t179-242 266-164 320-61 320 61 266 164 179 242 67 291z"/></svg>
|
||||||
|
<div>
|
||||||
<h3>Voice Conferencing</h3>
|
<h3>Voice Conferencing</h3>
|
||||||
<p>
|
<p>
|
||||||
Stable and low latency voice communications using <a href="https://wiki.mumble.info/wiki/Main_Page">Mumble</a>.
|
Stable and low latency voice communications using <a href="https://wiki.mumble.info/wiki/Main_Page">Mumble</a>.
|
||||||
Perfect for meetings, even with large groups, on mobile, or with low bandwidth.
|
Perfect for meetings, even with large groups, on mobile, or with low bandwidth.
|
||||||
</p>
|
</p>
|
||||||
</li>
|
</div>
|
||||||
<li class="icon fa-comments-o">
|
</li> -->
|
||||||
|
<li class="features-item">
|
||||||
|
<svg class="features-icon" viewBox="0 0 1792 1792"><path d="M704 384q-153 0-286 52T207 577t-79 191q0 82 53 158t149 132l97 56-35 84q34-20 62-39l44-31 53 10q78 14 153 14 153 0 286-52t212-141 78-191-78-191-212-141-286-52zm0-128q191 0 354 69t256 186 94 257-94 257-256 187-354 68q-86 0-176-16-124 88-278 128-36 9-86 16h-3q-11 0-20-8t-12-21l-1-6 1-7 2-6 2-5 4-5 4-5 4-5 4-5 23-25 26-29 23-29q15-19 25-39t20-44q-124-72-195-177T0 768q0-139 94-257t257-186 353-69zm822 1169q10 24 21 44t25 39 22 29 26 29 23 25l4 5 5 5 4 5 3 5 3 5 2 6v7l-1 6q-3 14-13 22t-22 7q-50-7-86-16-154-40-278-128-90 16-176 16-271 0-472-132 58 4 88 4 161 0 309-45t264-129q125-92 192-212t67-254q0-77-23-152 129 71 204 178t75 230q0 120-71 225t-195 176z"/></svg>
|
||||||
|
<div>
|
||||||
<h3>Forum and Mailing Lists</h3>
|
<h3>Forum and Mailing Lists</h3>
|
||||||
<p>
|
<p>
|
||||||
Build your online community with a modern and responsive forum with
|
Build your online community with a modern and responsive forum with
|
||||||
<a href="https://www.discourse.org/">Discourse</a>. An accessible
|
<a href="https://www.discourse.org/">Discourse</a>. An accessible
|
||||||
replacement for traditional mailing lists.
|
replacement for traditional mailing lists.
|
||||||
</p>
|
</p>
|
||||||
|
</div>
|
||||||
</li>
|
</li>
|
||||||
<li class="icon fa-map-o">
|
<!-- <li class="features-item">
|
||||||
|
<svg class="features-icon" viewBox="0 0 2048 1792"><path d="M2020 11q28 20 28 53v1408q0 20-11 36t-29 23l-640 256q-24 11-48 0l-616-246-616 246q-10 5-24 5-19 0-36-11-28-20-28-53V320q0-20 11-36t29-23L680 5q24-11 48 0l616 246L1960 5q32-13 60 6zM736 146v1270l576 230V376zM128 363v1270l544-217V146zm1792 1066V159l-544 217v1270z"/></svg>
|
||||||
|
<div>
|
||||||
<h3>Interactive Data and Mapping</h3>
|
<h3>Interactive Data and Mapping</h3>
|
||||||
<p>
|
<p>
|
||||||
Got some data? We can provide a variety of interactive data
|
Got some data? We can provide a variety of interactive data
|
||||||
@ -58,21 +88,27 @@
|
|||||||
and charts using <a href="https://d3js.org/">D3.js</a>. Get the most out of your
|
and charts using <a href="https://d3js.org/">D3.js</a>. Get the most out of your
|
||||||
data by presenting it in a bespoke web app.
|
data by presenting it in a bespoke web app.
|
||||||
</p>
|
</p>
|
||||||
</li>
|
</div>
|
||||||
<li class="icon fa-code">
|
</li> -->
|
||||||
|
<li class="features-item">
|
||||||
|
<svg class="features-icon" viewBox="0 0 2048 1792"><path d="M681 1399l-50 50q-10 10-23 10t-23-10L119 983q-10-10-10-23t10-23l466-466q10-10 23-10t23 10l50 50q10 10 10 23t-10 23L288 960l393 393q10 10 10 23t-10 23zm591-1067L899 1623q-4 13-15 20t-24 2l-62-17q-13-4-19-15t-3-25l373-1291q4-13 16-19t23-3l62 17q13 4 20 16t2 24zm657 651l-466 466q-10 10-23 10t-23-10l-50-50q-10-10-10-23t10-23l393-393-393-393q-10-10-10-23t10-23l50-50q10-10 23-10t23 10l466 466q10 10 10 23t-10 23z"/></svg>
|
||||||
|
<div>
|
||||||
<h3>Bespoke Development</h3>
|
<h3>Bespoke Development</h3>
|
||||||
<p>
|
<p>
|
||||||
For some problems, there may not be a pre-existing free software solution. Let
|
For some problems, there may not be a pre-existing solution. Let us guide you through the full development cycle to deliver your bespoke solution.
|
||||||
us guide you through the full development cycle to deliver your bespoke solution.
|
|
||||||
</p>
|
</p>
|
||||||
|
</div>
|
||||||
</li>
|
</li>
|
||||||
<li class="icon fa-lock">
|
<li class="features-item">
|
||||||
|
<svg class="features-icon" viewBox="0 0 1792 1792"><path d="M640 768h512V576q0-106-75-181t-181-75-181 75-75 181v192zm832 96v576q0 40-28 68t-68 28H416q-40 0-68-28t-28-68V864q0-40 28-68t68-28h32V576q0-184 132-316t316-132 316 132 132 316v192h32q40 0 68 28t28 68z"/></svg>
|
||||||
|
<div>
|
||||||
<h3>Cybersecurity Training</h3>
|
<h3>Cybersecurity Training</h3>
|
||||||
<p>
|
<p>
|
||||||
A grounded and principled understanding of the cybersecurity domain can ensure
|
A grounded and principled understanding of the cybersecurity domain can ensure
|
||||||
your organisation is not liable to any unwanted security threats. We provide
|
your organisation is not liable to any unwanted security threats. We provide
|
||||||
structured training taliored to your threat model.
|
structured training tailored to your threat model.
|
||||||
</p>
|
</p>
|
||||||
|
</div>
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
|
@ -1,15 +1,12 @@
|
|||||||
<!DOCTYPE HTML>
|
<!DOCTYPE HTML>
|
||||||
<html>
|
<html lang="en">
|
||||||
{% include head.html %}
|
{% include head.html %}
|
||||||
<body class="landing">
|
<body class="landing">
|
||||||
{% include header.html %}
|
{% include header.html %}
|
||||||
{% include banner.html %}
|
{% include banner.html %}
|
||||||
{% include core-values.html %}
|
{% include core-values.html %}
|
||||||
{% include blog.html %}
|
|
||||||
{% include services.html %}
|
{% include services.html %}
|
||||||
{% include contact.html %}
|
|
||||||
{% include footer.html %}
|
{% include footer.html %}
|
||||||
{% include membership-footer.html %}
|
|
||||||
{% include foot-scripts.html %}
|
{% include foot-scripts.html %}
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
<!DOCTYPE HTML>
|
<!DOCTYPE HTML>
|
||||||
<html>
|
<html lang="en">
|
||||||
{% include head.html %}
|
{% include head.html %}
|
||||||
|
|
||||||
<body>
|
<body>
|
||||||
@ -7,12 +7,11 @@
|
|||||||
|
|
||||||
<!-- Main -->
|
<!-- Main -->
|
||||||
<article id="main">
|
<article id="main">
|
||||||
<header>
|
<header
|
||||||
{% if page.image %}
|
{% if page.image %}
|
||||||
<div
|
style="background-image: url('{% if site.featured-image-source %}{{ page.image | prepend: site.featured-image-source | absolute_url }}{% else %}{{ "" | absolute_url }}/assets/images/{{ page.image }}{% endif %}');"
|
||||||
class="header-image"
|
|
||||||
style="background-image: url('{% if site.featured-image-source %}{{ page.image | prepend: site.featured-image-source | absolute_url }}{% else %}{{ "" | absolute_url }}/assets/images/{{ page.image }}{% endif %}');"></div>
|
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
>
|
||||||
<h2>{{ page.title }}</h2>
|
<h2>{{ page.title }}</h2>
|
||||||
<p>{{ page.description }}</p>
|
<p>{{ page.description }}</p>
|
||||||
</header>
|
</header>
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
html5up.net | @ajlkn
|
html5up.net | @ajlkn
|
||||||
Free for personal and commercial use under the CCA 3.0 license (html5up.net/license)
|
Free for personal and commercial use under the CCA 3.0 license (html5up.net/license)
|
||||||
-->
|
-->
|
||||||
<html>
|
<html lang="en">
|
||||||
|
|
||||||
{% include head.html %}
|
{% include head.html %}
|
||||||
|
|
||||||
@ -14,18 +14,17 @@
|
|||||||
|
|
||||||
<!-- Main -->
|
<!-- Main -->
|
||||||
<article id="main">
|
<article id="main">
|
||||||
<header>
|
<header
|
||||||
{% if page.image %}
|
{% if page.image %}
|
||||||
<div
|
style="background-image: url('{% if site.featured-image-source %}{{ page.image | prepend: site.featured-image-source | absolute_url }}{% else %}{{ "" | absolute_url }}/assets/images/{{ page.image }}{% endif %}');"
|
||||||
class="header-image"
|
|
||||||
style="background-image: url('{% if site.featured-image-source %}{{ page.image | prepend: site.featured-image-source | absolute_url }}{% else %}{{ "" | absolute_url }}/assets/images/{{ page.image }}{% endif %}');"></div>
|
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
>
|
||||||
<h2>{{ page.title }}</h2>
|
<h2>{{ page.title }}</h2>
|
||||||
<p>{{ page.description }}</p>
|
<p>{{ page.description }}</p>
|
||||||
<p><em>{{ page.date | date: '%B %d, %Y' }}</em></p>
|
<p><em>{{ page.date | date: '%B %d, %Y' }}</em></p>
|
||||||
</header>
|
</header>
|
||||||
<section class="wrapper style5">
|
<section class="wrapper style5">
|
||||||
<div class="inner">
|
<div class="inner inner--text">
|
||||||
|
|
||||||
{{ content }}
|
{{ content }}
|
||||||
|
|
||||||
|
@ -1,17 +1,16 @@
|
|||||||
<!DOCTYPE HTML>
|
<!DOCTYPE HTML>
|
||||||
<html>
|
<html lang="en">
|
||||||
{% include head.html %}
|
{% include head.html %}
|
||||||
|
|
||||||
<body>
|
<body>
|
||||||
{% include header.html %}
|
{% include header.html %}
|
||||||
|
|
||||||
<div id="main">
|
<div id="main">
|
||||||
<header>
|
<header
|
||||||
{% if page.image %}
|
{% if page.image %}
|
||||||
<div
|
style="background-image: url('{% if site.featured-image-source %}{{ page.image | prepend: site.featured-image-source | absolute_url }}{% else %}{{ "" | absolute_url }}/assets/images/{{ page.image }}{% endif %}');"
|
||||||
class="header-image"
|
|
||||||
style="background-image: url('{% if site.featured-image-source %}{{ page.image | prepend: site.featured-image-source | absolute_url }}{% else %}{{ "" | absolute_url }}/assets/images/{{ page.image }}{% endif %}');"></div>
|
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
>
|
||||||
<h2>{{ page.title }}</h2>
|
<h2>{{ page.title }}</h2>
|
||||||
<p>{{ page.description }}</p>
|
<p>{{ page.description }}</p>
|
||||||
</header>
|
</header>
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
layout: post
|
layout: post
|
||||||
title: Our Founding Principles
|
title: Our Founding Principles
|
||||||
description: Autonomic Co-operative And Our Core Values
|
description: Autonomic Co-operative And Our Core Values
|
||||||
image: pic01.jpg
|
image: 2016-09-23-thinkpad-keyboard.jpg
|
||||||
category: values
|
category: values
|
||||||
date: 2017-10-03
|
date: 2017-10-03
|
||||||
---
|
---
|
||||||
|
136
src/_posts/2019-08-30-civicrm-mailing-validation.md
Normal file
@ -0,0 +1,136 @@
|
|||||||
|
---
|
||||||
|
layout: post
|
||||||
|
title: CiviCRM AngularJS extension
|
||||||
|
description: Adding custom validation to the CiviCRM Mailing form
|
||||||
|
image: 2019-08-30_civicrm_validation_header.jpg
|
||||||
|
category: howto
|
||||||
|
date: 2019-08-30
|
||||||
|
---
|
||||||
|
|
||||||
|
We support [Campaign Against Arms Trade](https://caat.org.uk), a right-on group
|
||||||
|
that works to end the international arms trade, with their technology –
|
||||||
|
including [CiviCRM](https://civicrm.org/), a popular open source
|
||||||
|
"constituent relationship management" platform.
|
||||||
|
|
||||||
|
Among other things, CAAT uses CiviCRM's "Mailing" features to send out emails to
|
||||||
|
their supporters, and they told us that they're experiencing an annoying bug: if
|
||||||
|
a user sends out a mailing with the same name (not subject line, just the
|
||||||
|
internal identifier 🙄) as an existing one, it'll cause the CRM to freeze up
|
||||||
|
elsewhere.
|
||||||
|
|
||||||
|
As an added challenge, the mailing features of CiviCRM [now use
|
||||||
|
AngularJS](https://docs.civicrm.org/dev/en/latest/framework/angular/) following
|
||||||
|
a recent rebuild by the developers, and there aren't many tutorials or examples
|
||||||
|
out there to customise it. Luckily, the CiviCRM developer community was
|
||||||
|
super-helpful, and we managed to sort out some in-form validation to prevent
|
||||||
|
duplicate mailing names for our client… and now for you, too!
|
||||||
|
|
||||||
|
## Create a new extension
|
||||||
|
|
||||||
|
Using [`civix`](https://github.com/totten/civix), we set up a new CiviCRM extension for our code:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
$ civix generate:module mailing
|
||||||
|
```
|
||||||
|
|
||||||
|
(We called our extension `mailing`, because our creative director was occupied
|
||||||
|
with an Art at the time)
|
||||||
|
|
||||||
|
Our client sensibly keeps their custom CiviCRM extensions in `git`, so at this
|
||||||
|
stage we initialised a repository, added the boilerplate template code, and
|
||||||
|
pushed.
|
||||||
|
|
||||||
|
## Set up the AngularJS hook
|
||||||
|
|
||||||
|
A function called `mailing_civicrm_alterAngular()` will get executed whenever
|
||||||
|
an AngularJS page loads, and you can use a `ChangeSet` to edit an AngularJS
|
||||||
|
template. Because AngularJS templates specify form logic, this also lets you
|
||||||
|
change the validation behaviour. Our hook function looks like this:
|
||||||
|
|
||||||
|
```php
|
||||||
|
function mailing_civicrm_alterAngular($angular) {
|
||||||
|
$changeSet = \Civi\Angular\ChangeSet::create('mailing_name_unique')
|
||||||
|
->alterHtml('~/crmMailing/BlockSummary.html', function(phpQueryObject $doc) {
|
||||||
|
// name validation
|
||||||
|
$doc->find('.crm-group:has([crm-ui-id="subform.mailingName"])')->attr('ng-controller', 'NameValidateCtrl');
|
||||||
|
$doc->find('[crm-ui-id="subform.mailingName"]')->attr('ng-blur', 'validateName(mailing, \'name\')');
|
||||||
|
$doc->find('[crm-ui-id="subform.mailingName"]')->attr('crm-ui-validate', 'isValid');
|
||||||
|
});
|
||||||
|
|
||||||
|
$angular->add($changeSet);
|
||||||
|
|
||||||
|
CRM_Core_Resources::singleton()->addScriptFile('mailing', 'js/disallow-duplicate-names.js');
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
Setting `crm-ui-validate` to `validateName` directly fired the event _way_ too
|
||||||
|
many times, so instead `validateName` is only called when focus leaves the
|
||||||
|
field, `ng-blur`, which then sets the `isValid` variable that's checked by
|
||||||
|
`crm-ui-validate`.
|
||||||
|
|
||||||
|
## Create the `validateName` function
|
||||||
|
|
||||||
|
Then, the code which queries the CiviCRM API to check for mailings with
|
||||||
|
duplicate names:
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
var validating = false;
|
||||||
|
|
||||||
|
(function(angular, $) {
|
||||||
|
var crmMailing = angular.module('crmMailing');
|
||||||
|
|
||||||
|
crmMailing.controller('NameValidateCtrl', function($scope) {
|
||||||
|
$scope.isValid = false;
|
||||||
|
|
||||||
|
$scope.validateName = function(mailing, field) {
|
||||||
|
if (!validating) {
|
||||||
|
validating = true;
|
||||||
|
|
||||||
|
CRM.api3('Mailing', 'get', {
|
||||||
|
"sequential": 1,
|
||||||
|
"name": mailing[field],
|
||||||
|
"id": {"!=": mailing.id}
|
||||||
|
}).then(function(result) {
|
||||||
|
// do something with result
|
||||||
|
if (result.count > 0 ) {
|
||||||
|
$scope.isValid = false;
|
||||||
|
CRM.alert(ts('There is already a mailing with this name; sending this one will crash CiviCRM!'));
|
||||||
|
} else {
|
||||||
|
$scope.isValid = true;
|
||||||
|
}
|
||||||
|
}, function(error) {
|
||||||
|
// oops
|
||||||
|
console.log(error);
|
||||||
|
});
|
||||||
|
|
||||||
|
validating = false;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
});
|
||||||
|
})(angular, CRM.$);
|
||||||
|
```
|
||||||
|
|
||||||
|
(saved as `js/disallow-duplicate-names.js`)
|
||||||
|
|
||||||
|
## Conclusion
|
||||||
|
|
||||||
|
Activate the extension, e.g. with `cv`
|
||||||
|
|
||||||
|
```
|
||||||
|
$ cv en mailing
|
||||||
|
```
|
||||||
|
|
||||||
|
Now, open a mailing and try to give it the same name as an existing one – you
|
||||||
|
should see the field border turn red, and you'll be prevented from continuing or
|
||||||
|
sending the mailing:
|
||||||
|
|
||||||
|
!["Mailing name" field showing the field with a red border and red label](/assets/images/2019-08-30_civicrm_validation.png)
|
||||||
|
|
||||||
|
(As a bonus, the extension also sends a notification to the user using
|
||||||
|
`CRM.alert` to explain the error)
|
||||||
|
|
||||||
|
It does seem like a red border sometimes hangs around the field label even after
|
||||||
|
the value is valid again… but apart from that, the feature is working great!
|
||||||
|
|
||||||
|
Lastly, props to CAAT for being a great member of the CiviCRM community and
|
||||||
|
supporting us writing this post to share our work with y'all.
|
24
src/_posts/2020-04-02-autonomic-pandemic.md
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
---
|
||||||
|
layout: post
|
||||||
|
title: Autonomic in times of pandemic
|
||||||
|
description: Life under lockdown
|
||||||
|
image: 2020-04-02_autonomic_garden.jpg
|
||||||
|
category: updates
|
||||||
|
date: 2020-04-02
|
||||||
|
---
|
||||||
|
|
||||||
|
|
||||||
|
# Autonomic in times of pandemic
|
||||||
|
|
||||||
|
Just though we'd let everyone know that we are all doing ok during these extraordinary times. Autonomic already carries out all our work remotely so we don't have to change the way we work at all. Business as normal for us in the work realm but we know this isn't the case for many.
|
||||||
|
|
||||||
|
Most of us are involved in local mutual aid projects and we really recommend for everyone is able to get involved in their area (UK lists [here](https://covidmutualaid.org/local-groups/) and [here](https://freedomnews.org.uk/covid-19-uk-mutual-aid-groups-a-list/)). We need to stick together now more than ever. This is especially important for all those with tech skills. We have to help our communities. Tech help will be so appreciated by your local communities and help others to support those in need.
|
||||||
|
|
||||||
|
We are also concerned at the rising use of potentially authoritarian surveillance technologies. It is inevitable that under current conditions we would see these technologies deployed in a civil rather than military context. A moment of crisis is the perfect opportunity for those that seek to erode our civil liberties. As hackers, it is our responsibility to fight against repressive technologies wherever we find them for the sake of those less technical than ourselves.
|
||||||
|
|
||||||
|
If you are an organisation or collective that needs help with tech infrastructure, please reach out and we will help to the best of our abilities. This is a time for building cooperation, mutual aid and democratic structures, not only for the duration of the current crisis but also for struggles to come. There is no time to waste.
|
||||||
|
|
||||||
|
Love and solidarity
|
||||||
|
|
||||||
|
*Autonomic Co-operative*
|
||||||
|
|
52
src/_posts/2020-04-23-dat-py.md
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
---
|
||||||
|
layout: post
|
||||||
|
title: Hyperpy, the punk-to-punk protocol in Python
|
||||||
|
description: A new Python implementation of the Hypercore protocol is cooking at Autonomic
|
||||||
|
image: 2020-04-23-dat-protocol.png
|
||||||
|
category: technology, peer-to-peer, hypercore-protocol
|
||||||
|
date: 2020-04-23
|
||||||
|
---
|
||||||
|
|
||||||
|
# Hyperpy, the punk-to-punk protocol in Python
|
||||||
|
|
||||||
|
We're quite excited by the new wave of community-developed peer-to-peer
|
||||||
|
technology. [Scuttlebutt], [Cabal], [Mapeo] and [Beaker browser] are inspiring
|
||||||
|
examples of software which show that technology can be built to operate without
|
||||||
|
running on centralised commercially-owned infrastructure (e.g. WhatsApp).
|
||||||
|
|
||||||
|
One of the underlying innovations for these technologies is the [Hypercore
|
||||||
|
protocol], which is a way of describing how two computers can send information
|
||||||
|
to each other directly.
|
||||||
|
|
||||||
|
Today, the reference implementation of the Hypercore protocol is written in
|
||||||
|
Javascript. The Javascript ecosystem has proved to be remarkably flexible for
|
||||||
|
advancing this next generation of tools. Simple methods of publishing (npm
|
||||||
|
publish), well-established distribution channels (the browser) and a
|
||||||
|
[philosophy of modularity] have enabled so many to get started with building
|
||||||
|
peer-to-peer technology.
|
||||||
|
|
||||||
|
However, there is a great need for other languages and ecosystems to benefit
|
||||||
|
from the tools and concepts that are being developed based on the reference
|
||||||
|
implementation. People from all walks of life need a working implementation in
|
||||||
|
their preferred language of choice. In response to this, we are seeing projects
|
||||||
|
like [Datrs] and [Datcxx] emerge (please note, the Hypercore protocol was once
|
||||||
|
called the Dat protocol, see [this blog post] for more information).
|
||||||
|
|
||||||
|
Alongside these efforts, a member of Autonomic has begun to work on Hyperpy, a
|
||||||
|
Python-based implementation of the Hypercore protocol. The project proposes a
|
||||||
|
roadmap but offers no deadlines and receives no funding at current status.
|
||||||
|
|
||||||
|
However slowly, things are moving along. Further progress updates will be
|
||||||
|
posted on this blog as they come in. All development is taking place on
|
||||||
|
[git.autonomic.zone/hyperpy].
|
||||||
|
|
||||||
|
[scuttlebutt]: https://scuttlebutt.nz/
|
||||||
|
[cabal]: https://cabal.chat/
|
||||||
|
[mapeo]: https://www.digital-democracy.org/mapeo/
|
||||||
|
[beaker browser]: https://beakerbrowser.com/
|
||||||
|
[hypercore protocol]: https://hypercore-protocol.org/
|
||||||
|
[philosophy of modularity]: https://mafinto.sh/blog/pragmatic-modularity.html
|
||||||
|
[datrs]: https://github.com/datrs/
|
||||||
|
[datcxx]: https://datcxx.github.io/
|
||||||
|
[git.autonomic.zone/hyperpy]: https://git.autonomic.zone/hyperpy/
|
||||||
|
[this blog post]: https://blog.datproject.org/2020/05/15/dat-protocol-renamed-hypercore-protocol/
|
72
src/_posts/2021-01-25-how-we-make-decisions.md
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
---
|
||||||
|
layout: post
|
||||||
|
title: How we make decisions
|
||||||
|
description: Our collective's horizontal decision making process
|
||||||
|
image: trees.jpg
|
||||||
|
category: decision making, democracy
|
||||||
|
date: 2021-01-21
|
||||||
|
---
|
||||||
|
|
||||||
|
# How we make decisions
|
||||||
|
In Autonomic, we make decisions collectively, while also attempting to empower autonomous action by individual workers.
|
||||||
|
|
||||||
|
We designed our decision making process using decision making tools we had experienced through participation in various horizontal organisations. We hope this tool is useful to others in the struggle for a better world.
|
||||||
|
|
||||||
|
Our decisions can be split intro three categories: **Small, Medium and Large**.
|
||||||
|
|
||||||
|
## 1) Small - Get on and do the thing
|
||||||
|
- No one cares.
|
||||||
|
- Made by an individual within the co-op.
|
||||||
|
- Could be in any area.
|
||||||
|
- Up to individual co-op members to decide if they should just make the decision, or share it with the rest of the co-op to seek consensus.
|
||||||
|
|
||||||
|
## 2) Medium - Consensus pending objections
|
||||||
|
- About admin and infrastructure.
|
||||||
|
- Doesn't have an effect on the direction or operation of the co-op.
|
||||||
|
- Give a deadline: unless anyone objects or asks for more time by then, it goes ahead.
|
||||||
|
- The deadline must reasonable (a week by default).
|
||||||
|
- If any member of the co-op thinks it's a Large decision, achieve Maximum Consensus™ (see below).
|
||||||
|
|
||||||
|
## 3) Large - Maximum Consensus™
|
||||||
|
- Important decisions affecting the operation, direction, working conditions and finances of the co-op.
|
||||||
|
- Consensus voting: addressing any concerns.
|
||||||
|
- Can be requested by any member of the co-op for any decision.
|
||||||
|
- Input from every co-op member.
|
||||||
|
- Whoever proposes Large decisions is responsible for chasing up members for votes.
|
||||||
|
- Votes can be in favour, against, abstain (stand aside) or block.
|
||||||
|
- One member, one vote.
|
||||||
|
|
||||||
|
## Process
|
||||||
|
For Medium and Large decisions:
|
||||||
|
|
||||||
|
1. Write up a proposal in a [HedgeDoc pad](https://hedgedoc.org/).
|
||||||
|
2. Link to the proposal on the proposals page on our wiki.
|
||||||
|
3. Announce the decision in the #announcements channel of our internal chat.
|
||||||
|
4. List the decision on the Decisions page on our wiki.
|
||||||
|
4. Announce the result in #announcements and record it on the Decisions
|
||||||
|
page of our wiki.
|
||||||
|
|
||||||
|
## Proposal format
|
||||||
|
(For Medium and Large decisions).
|
||||||
|
|
||||||
|
- What you want to change.
|
||||||
|
- Who it affects.
|
||||||
|
- Size (Medium / Large).
|
||||||
|
- Deadline.
|
||||||
|
- What chat channel you want discussion to happen in.
|
||||||
|
|
||||||
|
## Example proposal
|
||||||
|
> @all I'd like to propose (Medium|Large) decision XXX, to write our name as
|
||||||
|
"aUtOnOmIc cöööpERATIVE" in all our public communications.
|
||||||
|
>
|
||||||
|
> Deadline for votes is DEADLINE – let me know if you need more time to vote than that.
|
||||||
|
>
|
||||||
|
> Please send absolutely any and all replies in #CHANNEL, not here 🙏
|
||||||
|
>
|
||||||
|
> 👍 this message for "enthusiastic consent", 🤷 for "stand aside" or 👎 if you need to indicate your extreme disagreement with this idea.
|
||||||
|
>
|
||||||
|
> 👇 VOTES HERE
|
||||||
|
|
||||||
|
## Further resources
|
||||||
|
Extra information about decision making processes in co-operatives can be found on the [Seeds for Change website](https://seedsforchange.org.uk/resources).
|
||||||
|
|
99
src/_posts/2021-02-16-co-op-cloud.md
Normal file
@ -0,0 +1,99 @@
|
|||||||
|
---
|
||||||
|
layout: post
|
||||||
|
title: The Co-operative Cloud
|
||||||
|
description: Libre software infrastructure without re-inventing the wheel
|
||||||
|
image: coop-cloud.png
|
||||||
|
category: coop, co-op, cloud, docker, swarm, libre-software, hosting,
|
||||||
|
date: 2021-03-01
|
||||||
|
---
|
||||||
|
|
||||||
|
Running [libre software] apps and infrastructure for ourselves and our clients is central to what we do at Autonomic. Now, after a year of work, we're stoked to share our "Co-op Cloud" project with the world. We want to make it easier for others to join the party, ditch corporate spyware, and make their tools [sustainable, transparent and private].
|
||||||
|
|
||||||
|
## Why a new tool?
|
||||||
|
|
||||||
|
We started out using [Cloudron], which provides a very simple-to-use web interface for deploying libre software apps like Nextcloud, Mediawiki, and Rocket.chat with only a few clicks.
|
||||||
|
|
||||||
|
Cloudron allowed us to radically reduce our initial and ongoing server costs. We didn't need to maintain a separate server for each service and clients apps could share computing resources whilst containerisation was still allowing us meeting their data privacy needs. Consequently, we've been able to take on many more "solidarity clients", people doing important work, but on a shoestring budget.
|
||||||
|
|
||||||
|
As time has gone on, though, we've had a few moments when we questioned our reliance on Cloudron, and whether it was a sustainable choice for us and for our clients. We came to realise:
|
||||||
|
|
||||||
|
- Core parts of the system officially [became proprietary] software. This rang alarm bells for us about its long-term future.
|
||||||
|
|
||||||
|
- The work to package the available apps is done [entirely by the Cloudron team itself] and doesn't re-use the existing rich ecosystem of libre software packaging work that's already being done. This seems like a big risk. If Cloudron UG, the company behind Cloudron, goes under, someone or some entity would need to take on that laborious, technically specific and non-transferable packaging work or we'd quickly be leaving ourselves and our clients running outdated and unmaintained software.
|
||||||
|
|
||||||
|
- Some aspects of Cloudron's architecture were causing problems. Requiring each app to be a single Docker image makes common application deployment configurations impossible (as far as we know, nobody has yet managed to get Mediawiki's visual editor working in Cloudron, for example).
|
||||||
|
|
||||||
|
- Not being able to delegate user management to specific groups has made it hard for us to use Cloudron's Single Sign On system with groups who manage their own users.
|
||||||
|
|
||||||
|
- Cloudron's central paradigm is focussed on "non-technical" users with the nice web front end for managing apps. However, we found our clients don't actually need to know what "domain name" or "storage volumes" are. That's why they pay us for support. They want it to "just work". Using an interface designed for non-technical users is not suitable for technical users and adds a lot of bloat.
|
||||||
|
|
||||||
|
- Cloudron is a bit of a [black box](https://en.wikipedia.org/wiki/Black_box). When something breaks, it breaks hard and requires technical users to respond and investigate and then fix the issues.
|
||||||
|
|
||||||
|
- Cloudron doesn't encourage collective and public collaboration on configuration files.
|
||||||
|
|
||||||
|
- We have a general fear of centralising so much of our core business on a commercial entity, which could change its prices at any time and have a massive effect on our ability to operate.
|
||||||
|
|
||||||
|
## A New Hope
|
||||||
|
|
||||||
|
So, around the end of 2019, we tried to map out a few core principles of a system which might work a lot like Cloudron, but give us more guarantees that we can depend on. We started calling the new project Co-op Cloud. Here are some of the principles we identified:
|
||||||
|
|
||||||
|
- Always be available under [copyleft licenses] to retain the shared work as part of the [commons](https://en.wikipedia.org/wiki/Commons). We shouldn't rely on creating [artificial scarcity](https://en.wikipedia.org/wiki/Artificial_scarcity) as a business model.
|
||||||
|
|
||||||
|
- Work with existing libre software communities who are already packaging and publishing their software (Nextcloud, Gitea, Mediawiki, Rocket.chat, the list goes on and on...). We want to be involved in their community spaces and build bridges between infrastructure, software development and end-users.
|
||||||
|
|
||||||
|
- Based on standardised technologies. Any new tools we write should only add a thin layer of usability on top of existing solutions.
|
||||||
|
|
||||||
|
- Place democratic governance at the core of the project. We want to collaborate as much as possible with other co-operatives to build up effective decision-making structures so we can all rely on this project far into the future.
|
||||||
|
|
||||||
|
- Focus on meeting the needs of small hosting providers with technical workers in order to provide a solid service for their clients.
|
||||||
|
|
||||||
|
- Encourage the creation of a configuration commons. Innovations based on Co-op Cloud can easily be shared and worked on collectively.
|
||||||
|
|
||||||
|
In our spare time (partly funded by income from working for our wonderful clients 😀) we've been putting the pieces together; and after a year of work (including two "back to the drawing board" moments), we're ready to launch an [alpha version](https://en.wikipedia.org/wiki/Software_release_life_cycle) of Co-op Cloud to the public.
|
||||||
|
|
||||||
|
## Co-op Cloud public alpha
|
||||||
|
|
||||||
|
Co-op Cloud is a simple packaging format using existing [open standards] to build a catalogue of apps, and a command-line client to read the catalogue and deploy those apps.
|
||||||
|
|
||||||
|
If you'd like to learn more about Co-op Cloud, please read [our documentation], where we explain the decisions we've made so far in more depth. What technologies we're using, how we fit into the existing ecosystem, ways to contribute, what apps are available and so on.
|
||||||
|
|
||||||
|
We've already been deploying Co-op Cloud as part of "dual power" strategy. We use Co-op Cloud to run some of our own and our clients' infrastructure while continuing with Cloudron and other strategies for the time being. We're seeing promising stability and it's been a joy to work with.
|
||||||
|
|
||||||
|
## Enter the configuration commons
|
||||||
|
|
||||||
|
You can also dive straight in by installing [`abra`, Co-op Cloud's command-line tool].
|
||||||
|
|
||||||
|
You can use Co-op Cloud right now to deploy any of our [30+ apps] to your own physical server or virtual server. These include [Nextcloud](https://nextcloud.com/) (for file, calendar, contacts etc) [Rocket.chat](https://rocket.chat/) for instant messaging, [Keycloak](https://www.keycloak.org/) for Single Sign-On, [Statping](https://statping.com/) for service monitoring, and websites using [Wordpress](https://wordpress.org/), [Pelican](https://blog.getpelican.com/), [Jekyll](https://jekyllrb.com/), or static HTML. See the [app catalogue](https://docs.cloud.autonomic.zone/apps/) for more.
|
||||||
|
|
||||||
|
Apps deployed via Co-op Cloud have automatic SSL certificates, and many come with pre-configured e-mail, backups, or Single Sign-On options.
|
||||||
|
|
||||||
|
See the [getting started guide](https://docs.cloud.autonomic.zone/overview/) to get moving fast.
|
||||||
|
|
||||||
|
## Packaging for Co-op Cloud
|
||||||
|
|
||||||
|
Packaging new apps for Co-op Cloud is straightforward in most cases: you can re-use an application's own Docker image (or even `docker-compose.yml` file) with minimal changes. We managed to [make a Co-op Cloud version of the Matomo web analytics platform in about 20 minutes]. This standardised architecture also means that nobody using Co-op Cloud is dependent on Autonomic for updates. When a new Wordpress update comes out, you can easily install it yourself or automatically without waiting for us to update some arcane custom Docker image.
|
||||||
|
|
||||||
|
## Next steps
|
||||||
|
|
||||||
|
At this point, we'd like to invite other worker co-operatives or democratic collectives to take a look at what we're working on and have a chat with us. We have a public matrix room at `#coopcloud:autonomic.zone`. We think a common platform for hosting libre software infrastructure could make a big difference in terms of what we're able to offer as a movement.
|
||||||
|
|
||||||
|
If you're interested in getting involved with Co-op Cloud development, or if you'd like help trying out Co-op Cloud hosted services for yourself or your organisation, please [get in touch].
|
||||||
|
|
||||||
|
## Links
|
||||||
|
|
||||||
|
- [Documentation](https://cloud.autonomic.zone/)
|
||||||
|
- [Source code](https://git.autonomic.zone/coop-cloud)
|
||||||
|
- [Public Matrix chat](https://matrix.to/#/#coopcloud:autonomic.zone?via=autonomic.zone)
|
||||||
|
|
||||||
|
[libre software]: http://wikieducator.org/Libre
|
||||||
|
[sustainable, transparent and private]: /#core-values
|
||||||
|
[cloudron]: https://cloudron.io/
|
||||||
|
[became proprietary]: https://forum.cloudron.io/topic/2862/why-not-make-cloudron-fully-open-source-again
|
||||||
|
[entirely by the cloudron team itself]: https://git.cloudron.io/cloudron
|
||||||
|
[our documentation]: https://docs.cloud.autonomic.zone
|
||||||
|
[`abra`, co-op cloud's command-line tool]: https://git.autonomic.zone/coop-cloud/abra/
|
||||||
|
[30+ apps]: https://git.autonomic.zone/coop-cloud/
|
||||||
|
[get in touch]: mailto:helo@autonomic.zone
|
||||||
|
[copyleft licenses]: https://www.gnu.org/licenses/copyleft.en.html
|
||||||
|
[open standards]: https://compose-spec.io/
|
||||||
|
[make a co-op cloud version of the matomo web analytics platform in about 20 minutes]: https://docs.cloud.autonomic.zone/package/
|
10
src/_posts/2021-07-05-new-coop-cloud-blog-and-socials.md
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
---
|
||||||
|
layout: post
|
||||||
|
title: New Co-op Cloud blog, socials and updates
|
||||||
|
description: Co-op Cloud project blog, socials and monthly updates
|
||||||
|
image: ccblog.png
|
||||||
|
category: coop, co-op, cloud, docker, swarm, libre-software, hosting,
|
||||||
|
date: 2021-07-07
|
||||||
|
---
|
||||||
|
|
||||||
|
The Co-op Cloud is starting to come into its own and we've decided to move our posts over to a dedicated [new and shiny blog](https://coopcloud.tech/blog/). We are working on opening up shared ownership of the project and want to create digital spaces where Autonomic is not implicitly having some sort of gate keeping role. We'll be writing regularly about our progress over there. We've also made new [Twitter](https://twitter.com/Coop_Cloud) and [Mastodon](https://social.coop/@coopcloud) which can you can follow along. That's all for now!
|
63
src/_posts/2021-11-25-join-us.md
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
---
|
||||||
|
layout: post
|
||||||
|
title: Come join the good ship Autonomic!
|
||||||
|
description: Hi do you want to work with the coolest anarchist tech workers co-operative?
|
||||||
|
image: robertmccall.jpg
|
||||||
|
category: decision making, democracy, meta
|
||||||
|
date: 2021-11-25
|
||||||
|
---
|
||||||
|
|
||||||
|
|
||||||
|
## Background
|
||||||
|
|
||||||
|
Autonomic is a worker-owned co-operative of queer comrade hackers dedicated to using technology to empower people making a positive difference in the world. Since 2017, we’ve been successfully delivering projects in a range of sectors including renewable energy, labour organising, independent media, feminist research, migrant solidarity activism, sustainable fashion, and arms trade abolition.
|
||||||
|
|
||||||
|
We are currently 12 worker-owners, located on four continents worldwide. We are a Co-operative Society, registered in the UK with the Financial Conduct Authority. Legally, we are a freelance consortium, which means that we operate as a group of self-employed contractors, and are responsible for our own individual income tax.
|
||||||
|
|
||||||
|
Autonomic aspires to follow the [7 co-operative principles as defined by the International Co-operative Alliance](https://www.ica.coop/en/cooperatives/cooperative-identity).
|
||||||
|
|
||||||
|
We're currently looking to build capacity in the co-op in key areas to help take us to the next level.
|
||||||
|
|
||||||
|
## Pay
|
||||||
|
|
||||||
|
We are currently paid £16 per hour for all work.
|
||||||
|
|
||||||
|
Everyone in the co-op will always be paid the same rate, which we decide on collectively and adjust according to how well we're doing.
|
||||||
|
|
||||||
|
## What we're looking for:
|
||||||
|
|
||||||
|
We are looking for folks who have expertise in the following areas:
|
||||||
|
|
||||||
|
### Required
|
||||||
|
- Care, communicatiton and compassion. Trust. Comradeship. Each according to their need.
|
||||||
|
- Available for around 10-20 hours per week **between 8am UTC and 3pm UTC**
|
||||||
|
|
||||||
|
### Skill areas
|
||||||
|
|
||||||
|
We are in need of people who have experience or interest in at least 2 of these areas:
|
||||||
|
|
||||||
|
- Project management: progress tracking and planning, budgeting and estimates.
|
||||||
|
- Client communications / relations / meeting, conflict resolution.
|
||||||
|
- Infrastrucure skills: Debian, Ansible, Git, Docker, Docker Swarm in the context of [Co-op Cloud](https://coopcloud.tech).
|
||||||
|
- Wordpress development (front end and back end): PHP, CSS, Composer, Docker.
|
||||||
|
- Finance administration: invoicing, tax, forecasting,
|
||||||
|
|
||||||
|
### Bonus/Nice to Have
|
||||||
|
|
||||||
|
- Wordpress plug-in development
|
||||||
|
- Drupal development
|
||||||
|
- New business development
|
||||||
|
|
||||||
|
## Process
|
||||||
|
|
||||||
|
People of color, women, genderqueer, non-binary and trans folks, neurodiverse and queer folks strongly encouraged to apply.
|
||||||
|
|
||||||
|
Email helo@autonomic.zone with your CV (doesn't have to be fancy, just a list of work) and a little bit about yourself and what you're looking for work wise.
|
||||||
|
|
||||||
|
If we think you might be suitable for these roles, you'll be invited for a few chats with members of the co-op who will show you more about the kinds of work we do and be able to answer any questions you have.
|
||||||
|
|
||||||
|
If we want to take you on, we'll then have a vote amongst our members and you can start working for us right away as a "potential member". After 100 hours of work you can be invited to join the co-op as a full member.
|
||||||
|
|
||||||
|
<hr>
|
||||||
|
|
||||||
|
_image by Robert McCall_
|
14
src/_posts/2022-04-14-coop-cloud-federation-proposal.md
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
---
|
||||||
|
layout: post
|
||||||
|
title: The Co-op Cloud Federation Proposal
|
||||||
|
description:
|
||||||
|
image: ccforest.jpg
|
||||||
|
category: coop cloud, decision making, democracy
|
||||||
|
date: 2022-04-14
|
||||||
|
---
|
||||||
|
|
||||||
|
Following on in [the tradition](https://autonomic.zone/blog/new-coop-cloud-blog-and-socials/) of making [short blog posts](https://autonomic.zone/blog/co-op-cloud/) about [Co-op Cloud](https://coopcloud.tech) on this blog, here comes another one!
|
||||||
|
|
||||||
|
We're delighted to announce that we have finally published the Co-op Cloud federation proposal. It's a document which aims to formalise the organisation of the project, focusing on a democratic process. It's open for comments, feedback, critique & amendments.
|
||||||
|
|
||||||
|
Autonomic has had a central role in the organising of this project until now, but we'd like to step back and open up space for others. The proposal is part of formalising that and we're excited to see who will step in! You can find out more on the [Co-op Cloud blog](https://coopcloud.tech/blog/federation-proposal/) or jump straight to [the proposal](https://pad.autonomic.zone/s/MLafJE2jC).
|
36
src/_posts/2022-05-30-ansible-roles.md
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
---
|
||||||
|
layout: post
|
||||||
|
title: Publishing our Ansible roles
|
||||||
|
description:
|
||||||
|
image: infra.jpg
|
||||||
|
category: ansible, automation, infrastructure
|
||||||
|
date: 2022-05-30
|
||||||
|
---
|
||||||
|
|
||||||
|
We're delighted to announce that we're publishing our Ansible roles
|
||||||
|
into the open under [`git.autonomic.zone/autonomic-cooperative/...`](https://git.autonomic.zone/explore/repos?q=ansible&topic=1) at long last 🥳
|
||||||
|
|
||||||
|
They've always been licensed as libre software but due to the way we managed
|
||||||
|
our internal infrastructure configurations, they were embedded in a private
|
||||||
|
repository.
|
||||||
|
|
||||||
|
The roles are currently lacking documentation and written for very specific
|
||||||
|
Autonomic needs but they might be handy as a learning resource or a base to
|
||||||
|
fork from. We'd happily accept contributions to generalise them.
|
||||||
|
|
||||||
|
In particular, we've been relying on and running
|
||||||
|
[`autonomic.new-hetzner`](https://git.autonomic.zone/autonomic-cooperative/autonomic.new-hetzner)
|
||||||
|
for years, so it is battle tested. The role bootstraps a Hetzner VPS from
|
||||||
|
scratch and provisions it with a hardened SSH configuration, firewalls, user
|
||||||
|
accounts and some basic packages and a shiny MOTD.
|
||||||
|
|
||||||
|
All roles are CI tested on every commit with [Molecule](https://molecule.readthedocs.io/en/latest/) so things don't break.
|
||||||
|
|
||||||
|
[Expanding re-use with shared infrastructure](https://community.coops.tech/t/cotech-gathering-ansible-and-shared-infrastructure-session/1107)
|
||||||
|
is someting we've always been working on at Autonomic. We have an ongoing
|
||||||
|
critique of Ansible and the pros/cons of when it is a good choice to use. This
|
||||||
|
ultimately lead us to start projects like [Co-op
|
||||||
|
Cloud](https://coopcloud.tech/). However, we still think Ansible is pretty good
|
||||||
|
at handling more complicated server provisioning needs.
|
||||||
|
|
||||||
|
Happy Infra Hacking.
|
45
src/_posts/2022-07-11-endorsing-battle-mesh-v14.md
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
---
|
||||||
|
layout: post
|
||||||
|
title: Wireless Battle of the Mesh - Building Community Networks for Fun and Non-Profit
|
||||||
|
description: Autonomic members are aiming to attend. Here is our public endorsement!
|
||||||
|
image: bmesh.png
|
||||||
|
category: community, wireless, event
|
||||||
|
date: 2022-07-11
|
||||||
|
---
|
||||||
|
|
||||||
|
Autonomic Co-op supports this year's "Wireless Battle of the Mesh - Building
|
||||||
|
Community Networks for Fun and Non-Profit".
|
||||||
|
|
||||||
|
The event aims to bring together people from across the globe who are
|
||||||
|
interested in community networks, including wireless mesh network technologies,
|
||||||
|
fiber infrastructure, Do-It-Yourself Internet Access Providers, and more
|
||||||
|
generally how to create and maintain a thriving community of people involved in
|
||||||
|
building their own networks.
|
||||||
|
|
||||||
|
We envision 4 days of expert presentations, practical workshops, hacking
|
||||||
|
sessions, and fruitful discussions: whether you are a mesh networking
|
||||||
|
enthusiast, community networking activist, protocol developer, or have an
|
||||||
|
interest in networking in general, come and join the event!
|
||||||
|
|
||||||
|
The Battlemesh is free of charge and open for all.
|
||||||
|
|
||||||
|
This year, the event will take place from Monday 19th to Wednesday 22nd
|
||||||
|
of September, 2022 in Rome, Italy! It will be followed by the RomHack
|
||||||
|
Camp on September 23-25, also in Rome.
|
||||||
|
|
||||||
|
Check out more information [here](https://www.battlemesh.org/BattleMeshV14).
|
||||||
|
|
||||||
|
We are writing this post as part of a public endorsement and support for
|
||||||
|
"Wireless Battle of the Mesh - Building Community Networks for Fun and
|
||||||
|
Non-Profit" not only for the efforts made by its community to advance the field
|
||||||
|
of wireless mesh networking and foster the development of grass-roots community
|
||||||
|
networks, but for their contribution to digital freedom rights movement,
|
||||||
|
empowerment of peoples tech/net/media competency and a free and open civil
|
||||||
|
society.
|
||||||
|
|
||||||
|
We aim to support the event by:
|
||||||
|
|
||||||
|
- helping to promote it
|
||||||
|
- making it possible for our members to join the event
|
||||||
|
|
||||||
|
See you there hopefully!
|
61
src/_posts/2022-10-10-join-us-sept-2022.md
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
---
|
||||||
|
layout: post
|
||||||
|
title: Come join the good ship Autonomic!
|
||||||
|
description: We (were) hiring again!
|
||||||
|
category: decision making, democracy, meta
|
||||||
|
date: 2022-10-10
|
||||||
|
---
|
||||||
|
|
||||||
|
> As of 8 November 2022, this round of recruitment is now closed. Thanks to those who got in touch, and stay tuned for the next time we're looking for new members.
|
||||||
|
|
||||||
|
## Background
|
||||||
|
|
||||||
|
Autonomic is a worker-owned co-operative of queer comrade hackers dedicated to using technology to empower people making a positive difference in the world. Since 2017, we’ve been successfully delivering projects in a range of sectors including renewable energy, labour organising, independent media, feminist research, migrant solidarity activism, sustainable fashion, and arms trade abolition.
|
||||||
|
|
||||||
|
We are currently 11 worker-owners, located in 6 countries. We are a Co-operative Society, registered in the UK with the Financial Conduct Authority. Legally, we are a freelance consortium, which means that we operate as a group of self-employed contractors, and are responsible for our own individual income tax.
|
||||||
|
|
||||||
|
Autonomic aspires to follow the [7 co-operative principles as defined by the International Co-operative Alliance](https://www.ica.coop/en/cooperatives/cooperative-identity).
|
||||||
|
|
||||||
|
## Pay
|
||||||
|
|
||||||
|
We are currently paid £20 per hour for all work.
|
||||||
|
|
||||||
|
Everyone in the co-op will always be paid the same rate, which we decide on collectively and adjust according to how well we’re doing.
|
||||||
|
|
||||||
|
## What we’re looking for
|
||||||
|
|
||||||
|
We are looking for folks who have expertise in the following areas:
|
||||||
|
|
||||||
|
### Required commitments
|
||||||
|
|
||||||
|
- Care, communication and compassion. Trust & responsibility. Comradeship. Each according to their need.
|
||||||
|
- Available for around 10-20 hours per week. We work in multiple timezones but mostly find that being available for at least 1-3 hours for checking in and co-working between 13:00 UTC - 15:00 UTC is the best.
|
||||||
|
|
||||||
|
### Required skills
|
||||||
|
|
||||||
|
We are in need of people who have experience or interest in front end development.
|
||||||
|
|
||||||
|
- Comfortable with front-end technologies: HTML / CSS / JS / PHP (any or all)
|
||||||
|
- Comfortable writing WordPress themes and templates and debugging obscurities
|
||||||
|
|
||||||
|
### Bonus/Nice to Have
|
||||||
|
|
||||||
|
- Wordpress plug-in development
|
||||||
|
- Experience with collective organising & consensus decision making
|
||||||
|
- Debian systems administration skills: Bash scripting, running system upgrades, handling SSH keys etc.
|
||||||
|
- Interest in collectively learning how to run a cooperative under capitalism
|
||||||
|
- Experience in running union, grassroots or community political campaigns
|
||||||
|
- New business development, chasing leads
|
||||||
|
- Finance administration: invoicing, tax, forecasting
|
||||||
|
- Client communications / relations / meeting, conflict resolution
|
||||||
|
- Project management: progress tracking and planning, budgeting and estimates
|
||||||
|
|
||||||
|
## Process
|
||||||
|
|
||||||
|
People of color, women, genderqueer, non-binary and trans folks, neurodiverse and queer folks are strongly encouraged to apply.
|
||||||
|
|
||||||
|
Email [hello@autonomic.zone](mailto:hello@autonomic.zone) with your CV (it really doesn’t have to be fancy, just a list of work) and a little bit about yourself and what you’re looking for work wise.
|
||||||
|
|
||||||
|
If we think you might be suitable for these roles, you’ll be invited for a few chats with members of the co-op who will show you more about the kinds of work we do and be able to answer any questions you have.
|
||||||
|
|
||||||
|
If we want to take you on, we’ll then have a vote amongst our members and you can start working for us right away as a “potential member”. After ~100 hours of work you can be invited to join the co-op as a full member.
|
20
src/_posts/2022-12-18-neon-digital-reforms-2022.md
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
---
|
||||||
|
layout: post
|
||||||
|
title: NEoN x Autonomic - Digital Reforms
|
||||||
|
description: A brief update about our work with NEoN in the last months.
|
||||||
|
image: letsleave.png
|
||||||
|
category: coop-cloud, neon
|
||||||
|
date: 2022-12-18
|
||||||
|
---
|
||||||
|
|
||||||
|
> This year has seen many changes at NEoN, and we will have many more next year. We are committed to exploring new ways of working that help us develop and implement new strategies that emphasise collaborative, collective, and communal approaches.
|
||||||
|
>
|
||||||
|
> As part of our ongoing work on the [Counter Cloud Action Plan](https://neondigitalarts.com/counter-cloud/), [titipi.org](http://titipi.org/) introduced us to [Autonomic](https://autonomic.zone/) and its [Cooperative Cloud Infrastructure.](https://autonomic.zone/#services) Autonomic is a cooperative that is owned and run by its workers. They build technologies and infrastructure to empower users to impact the world positively. Their services reflect their commitment to their core values - sustainability, transparency and privacy.
|
||||||
|
>
|
||||||
|
> We commissioned [Autonomic](https://autonomic.zone/) to look over NEoN's digital infrastructure and help us to find a new sustainable way of working that supports one of its goals of DeGoogle-isation. Based on discussions and their past experiences working with other initiatives such as[ lumbug.space](https://lumbung.space/), [UTAW](https://utaw.tech/about/), VREC and [Comic Gewerkschaft](https://www.comicgewerkschaft.org/Uber-Uns), Autonomic has provided us with a plan of reforms, which we are delighted to share with you.
|
||||||
|
|
||||||
|
Read the full report [here](https://neondigitalarts.com/neon-digital-reforms/)!
|
||||||
|
|
||||||
|
Much love & solidarity to the good people at NEoN!
|
||||||
|
|
||||||
|
PS. Main Image Credit: "Let's leave planet GAFAM" by David Revoy from [degooglisons-internet.org](https://degooglisons-internet.org).
|
Before Width: | Height: | Size: 668 KiB |
Before Width: | Height: | Size: 103 KiB After Width: | Height: | Size: 103 KiB |
BIN
src/assets/images/2019-08-30_civicrm_validation.png
Normal file
After Width: | Height: | Size: 2.7 KiB |
BIN
src/assets/images/2019-08-30_civicrm_validation_header.jpg
Normal file
After Width: | Height: | Size: 97 KiB |
BIN
src/assets/images/2020-04-02_autonomic_garden.jpg
Normal file
After Width: | Height: | Size: 917 KiB |
BIN
src/assets/images/2020-04-23-dat-protocol.png
Normal file
After Width: | Height: | Size: 75 KiB |
BIN
src/assets/images/CoTech-white-logo.png
Normal file
After Width: | Height: | Size: 6.4 KiB |
@ -1,265 +0,0 @@
|
|||||||
<!DOCTYPE html>
|
|
||||||
<html class="devise-layout-html">
|
|
||||||
<head prefix="og: http://ogp.me/ns#">
|
|
||||||
<meta charset="utf-8">
|
|
||||||
<meta content="IE=edge" http-equiv="X-UA-Compatible">
|
|
||||||
<meta content="object" property="og:type">
|
|
||||||
<meta content="GitLab" property="og:site_name">
|
|
||||||
<meta content="Sign in" property="og:title">
|
|
||||||
<meta content="GitLab.com" property="og:description">
|
|
||||||
<meta content="https://gitlab.com/assets/gitlab_logo-7ae504fe4f68fdebb3c2034e36621930cd36ea87924c11ff65dbcb8ed50dca58.png" property="og:image">
|
|
||||||
<meta content="64" property="og:image:width">
|
|
||||||
<meta content="64" property="og:image:height">
|
|
||||||
<meta content="https://gitlab.com/users/sign_in" property="og:url">
|
|
||||||
<meta content="summary" property="twitter:card">
|
|
||||||
<meta content="Sign in" property="twitter:title">
|
|
||||||
<meta content="GitLab.com" property="twitter:description">
|
|
||||||
<meta content="https://gitlab.com/assets/gitlab_logo-7ae504fe4f68fdebb3c2034e36621930cd36ea87924c11ff65dbcb8ed50dca58.png" property="twitter:image">
|
|
||||||
|
|
||||||
<title>Sign in · GitLab</title>
|
|
||||||
<meta content="GitLab.com" name="description">
|
|
||||||
<link rel="shortcut icon" type="image/x-icon" href="/assets/favicon-075eba76312e8421991a0c1f89a89ee81678bcde72319dd3e8047e2a47cd3a42.ico" id="favicon" />
|
|
||||||
<link rel="stylesheet" media="all" href="/assets/application-61d4cb7e100f2fac8ccaeac5e18d08f97554f0639e84004165d6f9697cfbe08c.css" />
|
|
||||||
<link rel="stylesheet" media="print" href="/assets/print-74b3d49adeaada27337e759b75a34af7cf3d80051de91d60d40570f5a382e132.css" />
|
|
||||||
|
|
||||||
|
|
||||||
<!-- / TODO: Combine these 2 stylesheets into application.scss -->
|
|
||||||
<link rel="stylesheet" media="all" href="/assets/new_nav-9dc36451d6461185b3c501b73a23f48936cda9ee5b0b8f9b1001c951ce12eabf.css" />
|
|
||||||
<link rel="stylesheet" media="all" href="/assets/new_sidebar-1f383f3cb338b8ecf8062dab06052141f414f51165f656b97a0930c0d38cd7dc.css" />
|
|
||||||
<script>
|
|
||||||
//<![CDATA[
|
|
||||||
window.gon={};gon.api_version="v4";gon.default_avatar_url="https:\/\/gitlab.com\/assets\/no_avatar-849f9c04a3a0d0cea2424ae97b27447dc64a7dbfae83c036c45b403392f0e8ba.png";gon.max_file_size=10;gon.asset_host=null;gon.webpack_public_path="\/assets\/webpack\/";gon.relative_url_root="";gon.shortcuts_path="\/help\/shortcuts";gon.user_color_scheme="white";gon.katex_css_url="\/assets\/katex-dc07578acd203b2dd73a8c78cdb8dcb79144ba11a23749d80904496b7ff8a650.css";gon.katex_js_url="\/assets\/katex-04bcf56379fcda0ee7c7a63f71d0fc15ffd2e014d017cd9d51fd6554dfccf40a.js";gon.sentry_dsn="https:\/\/526a2f38a53d44e3a8e69bfa001d1e8b@sentry.gitlap.com\/15";gon.gitlab_url="https:\/\/gitlab.com";gon.revision="235b8d5";gon.gitlab_logo="\/assets\/gitlab_logo-7ae504fe4f68fdebb3c2034e36621930cd36ea87924c11ff65dbcb8ed50dca58.png";
|
|
||||||
//]]>
|
|
||||||
</script>
|
|
||||||
<script src="/assets/webpack/webpack_runtime.294a69f1dca44b9962ff.bundle.js" defer="defer"></script>
|
|
||||||
<script src="/assets/webpack/common.c04294b903455a34f707.bundle.js" defer="defer"></script>
|
|
||||||
<script src="/assets/webpack/locale.b9a56fbc6e00d576d16c.bundle.js" defer="defer"></script>
|
|
||||||
<script src="/assets/webpack/main.78a00e6bb497a127e58c.bundle.js" defer="defer"></script>
|
|
||||||
<script src="/assets/webpack/raven.c94699aec8e665da5599.bundle.js" defer="defer"></script>
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<meta name="csrf-param" content="authenticity_token" />
|
|
||||||
<meta name="csrf-token" content="wsHK8up7MLWg48uVbcNYE7pk+TDs3OQ3y4e9l2k39xoa8OscEyQq+4SeumcbjMwNOvnHnyNl7Lod0aiJn1AEYA==" />
|
|
||||||
<meta content="origin-when-cross-origin" name="referrer">
|
|
||||||
<meta content="width=device-width, initial-scale=1, maximum-scale=1" name="viewport">
|
|
||||||
<meta content="#474D57" name="theme-color">
|
|
||||||
<link rel="apple-touch-icon" type="image/x-icon" href="/assets/touch-icon-iphone-5a9cee0e8a51212e70b90c87c12f382c428870c0ff67d1eb034d884b78d2dae7.png" />
|
|
||||||
<link rel="apple-touch-icon" type="image/x-icon" href="/assets/touch-icon-ipad-a6eec6aeb9da138e507593b464fdac213047e49d3093fc30e90d9a995df83ba3.png" sizes="76x76" />
|
|
||||||
<link rel="apple-touch-icon" type="image/x-icon" href="/assets/touch-icon-iphone-retina-72e2aadf86513a56e050e7f0f2355deaa19cc17ed97bbe5147847f2748e5a3e3.png" sizes="120x120" />
|
|
||||||
<link rel="apple-touch-icon" type="image/x-icon" href="/assets/touch-icon-ipad-retina-8ebe416f5313483d9c1bc772b5bbe03ecad52a54eba443e5215a22caed2a16a2.png" sizes="152x152" />
|
|
||||||
<link color="rgb(226, 67, 41)" href="/assets/logo-d36b5212042cebc89b96df4bf6ac24e43db316143e89926c0db839ff694d2de4.svg" rel="mask-icon">
|
|
||||||
<meta content="/assets/msapplication-tile-1196ec67452f618d39cdd85e2e3a542f76574c071051ae7effbfde01710eb17d.png" name="msapplication-TileImage">
|
|
||||||
<meta content="#30353E" name="msapplication-TileColor">
|
|
||||||
|
|
||||||
|
|
||||||
<!-- Piwik -->
|
|
||||||
<script>
|
|
||||||
var _paq = _paq || [];
|
|
||||||
_paq.push(['trackPageView']);
|
|
||||||
_paq.push(['enableLinkTracking']);
|
|
||||||
(function() {
|
|
||||||
var u="//piwik.gitlab.com/";
|
|
||||||
_paq.push(['setTrackerUrl', u+'piwik.php']);
|
|
||||||
_paq.push(['setSiteId', 1]);
|
|
||||||
var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0];
|
|
||||||
g.type='text/javascript'; g.async=true; g.defer=true; g.src=u+'piwik.js'; s.parentNode.insertBefore(g,s);
|
|
||||||
})();
|
|
||||||
</script>
|
|
||||||
<noscript><p><img src="//piwik.gitlab.com/piwik.php?idsite=1" style="border:0;" alt="" /></p></noscript>
|
|
||||||
<!-- End Piwik Code -->
|
|
||||||
|
|
||||||
|
|
||||||
</head>
|
|
||||||
|
|
||||||
<body class="ui_charcoal login-page application navless" data-page="sessions:new">
|
|
||||||
<div class="page-wrap">
|
|
||||||
<header class="navbar navbar-fixed-top navbar-empty">
|
|
||||||
<div class="container">
|
|
||||||
<div class="center-logo">
|
|
||||||
<svg width="24" height="24" class="tanuki-logo" viewBox="0 0 36 36">
|
|
||||||
<path class="tanuki-shape tanuki-left-ear" fill="#e24329" d="M2 14l9.38 9v-9l-4-12.28c-.205-.632-1.176-.632-1.38 0z"/>
|
|
||||||
<path class="tanuki-shape tanuki-right-ear" fill="#e24329" d="M34 14l-9.38 9v-9l4-12.28c.205-.632 1.176-.632 1.38 0z"/>
|
|
||||||
<path class="tanuki-shape tanuki-nose" fill="#e24329" d="M18,34.38 3,14 33,14 Z"/>
|
|
||||||
<path class="tanuki-shape tanuki-left-eye" fill="#fc6d26" d="M18,34.38 11.38,14 2,14 6,25Z"/>
|
|
||||||
<path class="tanuki-shape tanuki-right-eye" fill="#fc6d26" d="M18,34.38 24.62,14 34,14 30,25Z"/>
|
|
||||||
<path class="tanuki-shape tanuki-left-cheek" fill="#fca326" d="M2 14L.1 20.16c-.18.565 0 1.2.5 1.56l17.42 12.66z"/>
|
|
||||||
<path class="tanuki-shape tanuki-right-cheek" fill="#fca326" d="M34 14l1.9 6.16c.18.565 0 1.2-.5 1.56L18 34.38z"/>
|
|
||||||
</svg>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</header>
|
|
||||||
|
|
||||||
|
|
||||||
<div class="container navless-container">
|
|
||||||
<div class="content">
|
|
||||||
<div class="flash-container flash-container-page">
|
|
||||||
<div class="flash-alert">
|
|
||||||
<div class="container-fluid container-limited">
|
|
||||||
<span>You need to sign in or sign up before continuing.</span>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="row">
|
|
||||||
<div class="col-sm-5 pull-right new-session-forms-container">
|
|
||||||
<div>
|
|
||||||
<ul class="nav-links new-session-tabs nav-tabs" role="tablist">
|
|
||||||
<li class="active" role="presentation">
|
|
||||||
<a data-toggle="tab" href="#login-pane" role="tab">Sign in</a>
|
|
||||||
</li>
|
|
||||||
<li role="presentation">
|
|
||||||
<a data-toggle="tab" href="#register-pane" role="tab">Register</a>
|
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
|
|
||||||
<div class="tab-content">
|
|
||||||
<div class="login-box tab-pane active" id="login-pane" role="tabpanel">
|
|
||||||
<div class="login-body">
|
|
||||||
<form class="new_user gl-show-field-errors" aria-live="assertive" id="new_user" action="/users/sign_in" accept-charset="UTF-8" method="post"><input name="utf8" type="hidden" value="✓" /><input type="hidden" name="authenticity_token" value="aviQVpjjnwWyU0/d+NkgsYlxNMtli94j5+cz98Ptm/CyybG4YbyFS5YuPi+OlrSvCewKZKoy1q4xsSbpNYpoig==" /><div class="form-group">
|
|
||||||
<label for="user_login">Username or email</label>
|
|
||||||
<input class="form-control top" autofocus="autofocus" autocapitalize="off" autocorrect="off" required="required" title="This field is required." type="text" name="user[login]" id="user_login" />
|
|
||||||
</div>
|
|
||||||
<div class="form-group">
|
|
||||||
<label for="user_password">Password</label>
|
|
||||||
<input class="form-control bottom" required="required" title="This field is required." type="password" name="user[password]" id="user_password" />
|
|
||||||
</div>
|
|
||||||
<div class="remember-me checkbox">
|
|
||||||
<label for="user_remember_me">
|
|
||||||
<input name="user[remember_me]" type="hidden" value="0" /><input class="remember-me-checkbox" type="checkbox" value="1" name="user[remember_me]" id="user_remember_me" />
|
|
||||||
<span>Remember me</span>
|
|
||||||
</label>
|
|
||||||
<div class="pull-right forgot-password">
|
|
||||||
<a href="/users/password/new">Forgot your password?</a>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="submit-container move-submit-down">
|
|
||||||
<input type="submit" name="commit" value="Sign in" class="btn btn-save" />
|
|
||||||
</div>
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="tab-pane login-box" id="register-pane" role="tabpanel">
|
|
||||||
<div class="login-body">
|
|
||||||
<form class="new_new_user gl-show-field-errors" aria-live="assertive" id="new_new_user" action="/users" accept-charset="UTF-8" method="post"><input name="utf8" type="hidden" value="✓" /><input type="hidden" name="authenticity_token" value="KNVgt2nO9DZYvvt0iq8qMuVtT0aWcVKL5ZapEZ7c8Jrw5EFZkJHueHzDiob84L4sZfBx6VnIWgYzwLwPaLsD4A==" /><div class="devise-errors">
|
|
||||||
|
|
||||||
</div>
|
|
||||||
<div class="form-group">
|
|
||||||
<label for="new_user_name">Full name</label>
|
|
||||||
<input class="form-control top" required="required" title="This field is required." type="text" name="new_user[name]" id="new_user_name" />
|
|
||||||
</div>
|
|
||||||
<div class="username form-group">
|
|
||||||
<label for="new_user_username">Username</label>
|
|
||||||
<input class="form-control middle" pattern="[a-zA-Z0-9_\.][a-zA-Z0-9_\-\.]*[a-zA-Z0-9_\-]|[a-zA-Z0-9_]" required="required" title="Please create a username with only alphanumeric characters." type="text" name="new_user[username]" id="new_user_username" />
|
|
||||||
<p class="validation-error hide">Username is already taken.</p>
|
|
||||||
<p class="validation-success hide">Username is available.</p>
|
|
||||||
<p class="validation-pending hide">Checking username availability...</p>
|
|
||||||
</div>
|
|
||||||
<div class="form-group">
|
|
||||||
<label for="new_user_email">Email</label>
|
|
||||||
<input class="form-control middle" required="required" title="Please provide a valid email address." type="email" value="" name="new_user[email]" id="new_user_email" />
|
|
||||||
</div>
|
|
||||||
<div class="form-group">
|
|
||||||
<label for="new_user_email_confirmation">Email confirmation</label>
|
|
||||||
<input class="form-control middle" required="required" title="Please retype the email address." type="email" name="new_user[email_confirmation]" id="new_user_email_confirmation" />
|
|
||||||
</div>
|
|
||||||
<div class="form-group append-bottom-20" id="password-strength">
|
|
||||||
<label for="new_user_password">Password</label>
|
|
||||||
<input class="form-control bottom" required="required" pattern=".{8,}" title="Minimum length is 8 characters." type="password" name="new_user[password]" id="new_user_password" />
|
|
||||||
<p class="gl-field-hint">Minimum length is 8 characters</p>
|
|
||||||
</div>
|
|
||||||
<div class="form-group">
|
|
||||||
<input name="new_user[email_opted_in]" type="hidden" value="0" /><input type="checkbox" value="1" name="new_user[email_opted_in]" id="new_user_email_opted_in" />
|
|
||||||
<label for="new_user_email_opted_in">I'd like to receive updates via email about GitLab.</label>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div></div>
|
|
||||||
<script src="https://www.google.com/recaptcha/api.js" async defer></script>
|
|
||||||
<div class="g-recaptcha" data-sitekey="6LfAERQTAAAAAL4GYSiAMGLbcLyUIBSfPrDNJgeC"></div>
|
|
||||||
<noscript>
|
|
||||||
<div style="width: 302px; height: 352px;">
|
|
||||||
<div style="width: 302px; height: 352px; position: relative;">
|
|
||||||
<div style="width: 302px; height: 352px; position: absolute;">
|
|
||||||
<iframe
|
|
||||||
src="https://www.google.com/recaptcha/api/fallback?k=6LfAERQTAAAAAL4GYSiAMGLbcLyUIBSfPrDNJgeC"
|
|
||||||
frameborder="0" scrolling="no"
|
|
||||||
style="width: 302px; height:352px; border-style: none;">
|
|
||||||
</iframe>
|
|
||||||
</div>
|
|
||||||
<div style="width: 250px; height: 80px; position: absolute; border-style: none;
|
|
||||||
bottom: 21px; left: 25px; margin: 0px; padding: 0px; right: 25px;">
|
|
||||||
<textarea id="g-recaptcha-response" name="g-recaptcha-response"
|
|
||||||
class="g-recaptcha-response"
|
|
||||||
style="width: 250px; height: 80px; border: 1px solid #c1c1c1;
|
|
||||||
margin: 0px; padding: 0px; resize: none;" value="">
|
|
||||||
</textarea>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</noscript>
|
|
||||||
|
|
||||||
<div class="submit-container">
|
|
||||||
<input type="submit" name="commit" value="Register" class="btn-register btn" />
|
|
||||||
</div>
|
|
||||||
</form></div>
|
|
||||||
</div>
|
|
||||||
<div class="clearfix submit-container">
|
|
||||||
<p>
|
|
||||||
<span class="light">Didn't receive a confirmation email?</span>
|
|
||||||
<a href="/users/confirmation/new">Request a new one</a>.
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
<div class="clearfix">
|
|
||||||
<div class="omniauth-container">
|
|
||||||
<p>
|
|
||||||
<span class="light">
|
|
||||||
Sign in with
|
|
||||||
</span>
|
|
||||||
<span class="light">
|
|
||||||
<a class="oauth-login oauth-image-link" id="oauth-login-google_oauth2" rel="nofollow" data-method="post" href="/users/auth/google_oauth2"><img alt="Google" title="Sign in with Google" data-src="/assets/auth_buttons/google_64-37d98b7033cc7059a484199ffdd766adf69babbc6e5fc64b43006ca866629f17.png" class=" lazy" src="data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==" /></a>
|
|
||||||
</span>
|
|
||||||
<span class="light">
|
|
||||||
<a class="oauth-login oauth-image-link" id="oauth-login-twitter" rel="nofollow" data-method="post" href="/users/auth/twitter"><img alt="Twitter" title="Sign in with Twitter" data-src="/assets/auth_buttons/twitter_64-86860edb139fb2f62fc25ef62a4213a5c8b20122fd8752ab0df09e740eb53deb.png" class=" lazy" src="data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==" /></a>
|
|
||||||
</span>
|
|
||||||
<span class="light">
|
|
||||||
<a class="oauth-login oauth-image-link" id="oauth-login-github" rel="nofollow" data-method="post" href="/users/auth/github"><img alt="GitHub" title="Sign in with GitHub" data-src="/assets/auth_buttons/github_64-84041cd0ea392220da96f0fb9b9473c08485c4924b98c776be1bd33b0daab8c0.png" class=" lazy" src="data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==" /></a>
|
|
||||||
</span>
|
|
||||||
<span class="light">
|
|
||||||
<a class="oauth-login oauth-image-link" id="oauth-login-bitbucket" rel="nofollow" data-method="post" href="/users/auth/bitbucket"><img alt="Bitbucket" title="Sign in with Bitbucket" data-src="/assets/auth_buttons/bitbucket_64-eceb0f98bfa1a0bdc088138f970e1bc209114a8934c1372b596e9d137e611c21.png" class=" lazy" src="data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==" /></a>
|
|
||||||
</span>
|
|
||||||
<fieldset class="prepend-top-10">
|
|
||||||
<input type="checkbox" name="remember_me" id="remember_me" value="1" />
|
|
||||||
<label for="remember_me">Remember me</label>
|
|
||||||
</fieldset>
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</div>
|
|
||||||
<div class="col-sm-7 brand-holder pull-left">
|
|
||||||
<h1>
|
|
||||||
GitLab.com
|
|
||||||
</h1>
|
|
||||||
|
|
||||||
<p dir="auto">GitLab.com offers free unlimited (private) repositories and unlimited collaborators.</p>

<ul dir="auto">
<li>
<a href="https://gitlab.com/explore/projects/trending">Explore projects on GitLab.com</a> (no login needed)</li>
<li><a href="https://about.gitlab.com/gitlab-com/" rel="nofollow noreferrer noopener" target="_blank">More information about GitLab.com</a></li>
<li><a href="https://gitlab.com/gitlab-com/support-forum/issues">GitLab.com Support Forum</a></li>
</ul>

<p dir="auto">By signing up for and by signing in to this service you accept our:</p>

<ul dir="auto">
<li><a href="https://about.gitlab.com/privacy/" rel="nofollow noreferrer noopener" target="_blank">Privacy policy</a></li>
<li>
<a href="https://about.gitlab.com/terms/#gitlab_com" rel="nofollow noreferrer noopener" target="_blank">GitLab.com Terms</a>.</li>
</ul>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<hr class="footer-fixed">
|
|
||||||
<div class="container footer-container">
|
|
||||||
<div class="footer-links">
|
|
||||||
<a href="/explore">Explore</a>
|
|
||||||
<a href="/help">Help</a>
|
|
||||||
<a href="https://about.gitlab.com/">About GitLab</a>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</body>
|
|
||||||
</html>
|
|
BIN
src/assets/images/bmesh.png
Normal file
After Width: | Height: | Size: 60 KiB |
BIN
src/assets/images/ccblog.png
Normal file
After Width: | Height: | Size: 262 KiB |
BIN
src/assets/images/ccforest.jpg
Normal file
After Width: | Height: | Size: 189 KiB |
BIN
src/assets/images/coop-cloud.png
Normal file
After Width: | Height: | Size: 48 KiB |
BIN
src/assets/images/hiring.png
Normal file
After Width: | Height: | Size: 3.6 MiB |
BIN
src/assets/images/index.jpg
Normal file
After Width: | Height: | Size: 120 KiB |
BIN
src/assets/images/infra.jpg
Normal file
After Width: | Height: | Size: 92 KiB |
BIN
src/assets/images/letsleave.png
Normal file
After Width: | Height: | Size: 436 KiB |
BIN
src/assets/images/robertmccall.jpg
Normal file
After Width: | Height: | Size: 496 KiB |
BIN
src/assets/images/trees.jpg
Normal file
After Width: | Height: | Size: 668 KiB |
@ -1,7 +0,0 @@
|
|||||||
<component lightWeight="true">
|
|
||||||
<attach event="onpropertychange" onevent="handlePropertychange()" />
|
|
||||||
<attach event="ondetach" onevent="restore()" />
|
|
||||||
<attach event="onresize" for="window" onevent="handleResize()" />
|
|
||||||
<script type="text/javascript">
|
|
||||||
var rsrc=/url\(["']?(.*?)["']?\)/,positions={top:0,left:0,bottom:1,right:1,center:0.5},doc=element.document;init(); function init(){var b=doc.createElement("div"),a=doc.createElement("img"),c,d;b.style.position="absolute";b.style.zIndex=-1;b.style.top=0;b.style.right=0;b.style.left=0;b.style.bottom=0;b.style.overflow="hidden";a.style.position="absolute";a.style.width=a.style.width="auto";b.appendChild(a);element.insertBefore(b,element.firstChild);d=[element.currentStyle.backgroundPositionX,element.currentStyle.backgroundPositionY];element.bgsExpando=c={wrapper:b,img:a,backgroundSize:element.currentStyle["background-size"], backgroundPositionX:positions[d[0]]||parseFloat(d[0])/100,backgroundPositionY:positions[d[1]]||parseFloat(d[1])/100};"auto"==element.currentStyle.zIndex&&(element.style.zIndex=0);"static"==element.currentStyle.position&&(element.style.position="relative");refreshDisplay(element,c)&&(refreshDimensions(element,c),refreshBackgroundImage(element,c,function(){updateBackground(element,c)}))} function refreshDisplay(b,a){var c=b.currentStyle.display;c!=a.display&&(a.display=c,a.somethingChanged=!0);return"none"!=c}function refreshDimensions(b,a){var c=b.offsetWidth-(parseFloat(b.currentStyle.borderLeftWidth)||0)-(parseFloat(b.currentStyle.borderRightWidth)||0),d=b.offsetHeight-(parseFloat(b.currentStyle.borderTopWidth)||0)-(parseFloat(b.currentStyle.borderBottomWidth)||0);if(c!=a.innerWidth||d!=a.innerHeight)a.innerWidth=c,a.innerHeight=d,a.somethingChanged=!0} function refreshBackgroundImage(b,a,c){var d=a.img,e=(rsrc.exec(b.currentStyle.backgroundImage)||[])[1];if(e&&e!=a.backgroundSrc){a.backgroundSrc=e;a.somethingChanged=!0;d.onload=function(){var b=d.width,e=d.height;1==b&&1==e||(a.imgWidth=b,a.imgHeight=e,a.constrain=!1,c(),d.style.visibility="visible",d.onload=null)};d.style.visibility="hidden";d.src=a.backgroundSrc;if(d.readyState||d.complete)d.src="data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///ywAAAAAAQABAAACAUwAOw==",d.src=a.backgroundSrc;a.ignoreNextPropertyChange= !0;b.style.backgroundImage="none"}else c()} function updateBackground(b,a){if(a.somethingChanged){var c=a.img,d=a.innerWidth/a.innerHeight,e=a.imgWidth/a.imgHeight,f=a.constrain;"contain"==a.backgroundSize?e>d?(a.constrain=d="width",e=Math.floor((a.innerHeight-a.innerWidth/e)*a.backgroundPositionY),c.style.top=e+"px",d!=f&&(c.style.width="100%",c.style.height="auto",c.style.left=0)):(a.constrain=d="height",e=Math.floor((a.innerWidth-a.innerHeight*e)*a.backgroundPositionX),c.style.left=e+"px",d!=f&&(c.style.width="auto",c.style.height="100%", c.style.top=0)):"cover"==a.backgroundSize&&(e>d?(a.constrain=d="height",e=Math.floor((a.innerHeight*e-a.innerWidth)*a.backgroundPositionX),c.style.left=-e+"px",d!=f&&(c.style.width="auto",c.style.height="100%",c.style.top=0)):(a.constrain=d="width",e=Math.floor((a.innerWidth/e-a.innerHeight)*a.backgroundPositionY),c.style.top=-e+"px",d!=f&&(c.style.width="100%",c.style.height="auto",c.style.left=0)));a.somethingChanged=!1}} function handlePropertychange(){var b=element.bgsExpando;b.ignoreNextPropertyChange?b.ignoreNextPropertyChange=!1:refreshDisplay(element,b)&&(refreshDimensions(element,b),refreshBackgroundImage(element,b,function(){updateBackground(element,b)}))}function handleResize(){var b=element.bgsExpando;"none"!=b.display&&(refreshDimensions(element,b),updateBackground(element,b))} function restore(){var b=element.bgsExpando;try{element.style.backgroundImage="url('"+b.backgroundSrc+"')",element.removeChild(b.wrapper),element.bgsExpando=null}catch(a){}};
|
|
||||||
</script>
|
|
8
src/assets/js/ie/html5shiv.js
vendored
@ -1,8 +0,0 @@
|
|||||||
/*
|
|
||||||
HTML5 Shiv v3.6.2 | @afarkas @jdalton @jon_neal @rem | MIT/GPL2 Licensed
|
|
||||||
*/
|
|
||||||
(function(l,f){function m(){var a=e.elements;return"string"==typeof a?a.split(" "):a}function i(a){var b=n[a[o]];b||(b={},h++,a[o]=h,n[h]=b);return b}function p(a,b,c){b||(b=f);if(g)return b.createElement(a);c||(c=i(b));b=c.cache[a]?c.cache[a].cloneNode():r.test(a)?(c.cache[a]=c.createElem(a)).cloneNode():c.createElem(a);return b.canHaveChildren&&!s.test(a)?c.frag.appendChild(b):b}function t(a,b){if(!b.cache)b.cache={},b.createElem=a.createElement,b.createFrag=a.createDocumentFragment,b.frag=b.createFrag();
|
|
||||||
a.createElement=function(c){return!e.shivMethods?b.createElem(c):p(c,a,b)};a.createDocumentFragment=Function("h,f","return function(){var n=f.cloneNode(),c=n.createElement;h.shivMethods&&("+m().join().replace(/\w+/g,function(a){b.createElem(a);b.frag.createElement(a);return'c("'+a+'")'})+");return n}")(e,b.frag)}function q(a){a||(a=f);var b=i(a);if(e.shivCSS&&!j&&!b.hasCSS){var c,d=a;c=d.createElement("p");d=d.getElementsByTagName("head")[0]||d.documentElement;c.innerHTML="x<style>article,aside,figcaption,figure,footer,header,hgroup,main,nav,section{display:block}mark{background:#FF0;color:#000}</style>";
|
|
||||||
c=d.insertBefore(c.lastChild,d.firstChild);b.hasCSS=!!c}g||t(a,b);return a}var k=l.html5||{},s=/^<|^(?:button|map|select|textarea|object|iframe|option|optgroup)$/i,r=/^(?:a|b|code|div|fieldset|h1|h2|h3|h4|h5|h6|i|label|li|ol|p|q|span|strong|style|table|tbody|td|th|tr|ul)$/i,j,o="_html5shiv",h=0,n={},g;(function(){try{var a=f.createElement("a");a.innerHTML="<xyz></xyz>";j="hidden"in a;var b;if(!(b=1==a.childNodes.length)){f.createElement("a");var c=f.createDocumentFragment();b="undefined"==typeof c.cloneNode||
|
|
||||||
"undefined"==typeof c.createDocumentFragment||"undefined"==typeof c.createElement}g=b}catch(d){g=j=!0}})();var e={elements:k.elements||"abbr article aside audio bdi canvas data datalist details figcaption figure footer header hgroup main mark meter nav output progress section summary time video",version:"3.6.2",shivCSS:!1!==k.shivCSS,supportsUnknownElements:g,shivMethods:!1!==k.shivMethods,type:"default",shivDocument:q,createElement:p,createDocumentFragment:function(a,b){a||(a=f);if(g)return a.createDocumentFragment();
|
|
||||||
for(var b=b||i(a),c=b.frag.cloneNode(),d=0,e=m(),h=e.length;d<h;d++)c.createElement(e[d]);return c}};l.html5=e;q(f)})(this,document);
|
|
6
src/assets/js/ie/respond.min.js
vendored
@ -1,6 +0,0 @@
|
|||||||
/*! Respond.js v1.4.2: min/max-width media query polyfill
|
|
||||||
* Copyright 2014 Scott Jehl
|
|
||||||
* Licensed under MIT
|
|
||||||
* http://j.mp/respondjs */
|
|
||||||
|
|
||||||
!function(a){"use strict";a.matchMedia=a.matchMedia||function(a){var b,c=a.documentElement,d=c.firstElementChild||c.firstChild,e=a.createElement("body"),f=a.createElement("div");return f.id="mq-test-1",f.style.cssText="position:absolute;top:-100em",e.style.background="none",e.appendChild(f),function(a){return f.innerHTML='­<style media="'+a+'"> #mq-test-1 { width: 42px; }</style>',c.insertBefore(e,d),b=42===f.offsetWidth,c.removeChild(e),{matches:b,media:a}}}(a.document)}(this),function(a){"use strict";function b(){v(!0)}var c={};a.respond=c,c.update=function(){};var d=[],e=function(){var b=!1;try{b=new a.XMLHttpRequest}catch(c){b=new a.ActiveXObject("Microsoft.XMLHTTP")}return function(){return b}}(),f=function(a,b){var c=e();c&&(c.open("GET",a,!0),c.onreadystatechange=function(){4!==c.readyState||200!==c.status&&304!==c.status||b(c.responseText)},4!==c.readyState&&c.send(null))},g=function(a){return a.replace(c.regex.minmaxwh,"").match(c.regex.other)};if(c.ajax=f,c.queue=d,c.unsupportedmq=g,c.regex={media:/@media[^\{]+\{([^\{\}]*\{[^\}\{]*\})+/gi,keyframes:/@(?:\-(?:o|moz|webkit)\-)?keyframes[^\{]+\{(?:[^\{\}]*\{[^\}\{]*\})+[^\}]*\}/gi,comments:/\/\*[^*]*\*+([^/][^*]*\*+)*\//gi,urls:/(url\()['"]?([^\/\)'"][^:\)'"]+)['"]?(\))/g,findStyles:/@media *([^\{]+)\{([\S\s]+?)$/,only:/(only\s+)?([a-zA-Z]+)\s?/,minw:/\(\s*min\-width\s*:\s*(\s*[0-9\.]+)(px|em)\s*\)/,maxw:/\(\s*max\-width\s*:\s*(\s*[0-9\.]+)(px|em)\s*\)/,minmaxwh:/\(\s*m(in|ax)\-(height|width)\s*:\s*(\s*[0-9\.]+)(px|em)\s*\)/gi,other:/\([^\)]*\)/g},c.mediaQueriesSupported=a.matchMedia&&null!==a.matchMedia("only all")&&a.matchMedia("only all").matches,!c.mediaQueriesSupported){var h,i,j,k=a.document,l=k.documentElement,m=[],n=[],o=[],p={},q=30,r=k.getElementsByTagName("head")[0]||l,s=k.getElementsByTagName("base")[0],t=r.getElementsByTagName("link"),u=function(){var a,b=k.createElement("div"),c=k.body,d=l.style.fontSize,e=c&&c.style.fontSize,f=!1;return b.style.cssText="position:absolute;font-size:1em;width:1em",c||(c=f=k.createElement("body"),c.style.background="none"),l.style.fontSize="100%",c.style.fontSize="100%",c.appendChild(b),f&&l.insertBefore(c,l.firstChild),a=b.offsetWidth,f?l.removeChild(c):c.removeChild(b),l.style.fontSize=d,e&&(c.style.fontSize=e),a=j=parseFloat(a)},v=function(b){var c="clientWidth",d=l[c],e="CSS1Compat"===k.compatMode&&d||k.body[c]||d,f={},g=t[t.length-1],p=(new Date).getTime();if(b&&h&&q>p-h)return a.clearTimeout(i),i=a.setTimeout(v,q),void 0;h=p;for(var s in m)if(m.hasOwnProperty(s)){var w=m[s],x=w.minw,y=w.maxw,z=null===x,A=null===y,B="em";x&&(x=parseFloat(x)*(x.indexOf(B)>-1?j||u():1)),y&&(y=parseFloat(y)*(y.indexOf(B)>-1?j||u():1)),w.hasquery&&(z&&A||!(z||e>=x)||!(A||y>=e))||(f[w.media]||(f[w.media]=[]),f[w.media].push(n[w.rules]))}for(var C in o)o.hasOwnProperty(C)&&o[C]&&o[C].parentNode===r&&r.removeChild(o[C]);o.length=0;for(var D in f)if(f.hasOwnProperty(D)){var E=k.createElement("style"),F=f[D].join("\n");E.type="text/css",E.media=D,r.insertBefore(E,g.nextSibling),E.styleSheet?E.styleSheet.cssText=F:E.appendChild(k.createTextNode(F)),o.push(E)}},w=function(a,b,d){var e=a.replace(c.regex.comments,"").replace(c.regex.keyframes,"").match(c.regex.media),f=e&&e.length||0;b=b.substring(0,b.lastIndexOf("/"));var h=function(a){return a.replace(c.regex.urls,"$1"+b+"$2$3")},i=!f&&d;b.length&&(b+="/"),i&&(f=1);for(var j=0;f>j;j++){var k,l,o,p;i?(k=d,n.push(h(a))):(k=e[j].match(c.regex.findStyles)&&RegExp.$1,n.push(RegExp.$2&&h(RegExp.$2))),o=k.split(","),p=o.length;for(var q=0;p>q;q++)l=o[q],g(l)||m.push({media:l.split("(")[0].match(c.regex.only)&&RegExp.$2||"all",rules:n.length-1,hasquery:l.indexOf("(")>-1,minw:l.match(c.regex.minw)&&parseFloat(RegExp.$1)+(RegExp.$2||""),maxw:l.match(c.regex.maxw)&&parseFloat(RegExp.$1)+(RegExp.$2||"")})}v()},x=function(){if(d.length){var b=d.shift();f(b.href,function(c){w(c,b.href,b.media),p[b.href]=!0,a.setTimeout(function(){x()},0)})}},y=function(){for(var b=0;b<t.length;b++){var c=t[b],e=c.href,f=c.media,g=c.rel&&"stylesheet"===c.rel.toLowerCase();e&&g&&!p[e]&&(c.styleSheet&&c.styleSheet.rawCssText?(w(c.styleSheet.rawCssText,e,f),p[e]=!0):(!/^([a-zA-Z:]*\/\/)/.test(e)&&!s||e.replace(RegExp.$1,"").split("/")[0]===a.location.host)&&("//"===e.substring(0,2)&&(e=a.location.protocol+e),d.push({href:e,media:f})))}x()};y(),c.update=y,c.getEmValue=u,a.addEventListener?a.addEventListener("resize",b,!1):a.attachEvent&&a.attachEvent("onresize",b)}}(this);
|
|
2
src/assets/js/jquery-3.4.1.min.js
vendored
Normal file
5
src/assets/js/jquery.min.js
vendored
2
src/assets/js/jquery.scrolly.min.js
vendored
@ -1,2 +0,0 @@
|
|||||||
/* jquery.scrolly v1.0.0-dev | (c) @ajlkn | MIT licensed */
|
|
||||||
(function(e){function u(s,o){var u,a,f;if((u=e(s))[t]==0)return n;a=u[i]()[r];switch(o.anchor){case"middle":f=a-(e(window).height()-u.outerHeight())/2;break;default:case r:f=Math.max(a,0)}return typeof o[i]=="function"?f-=o[i]():f-=o[i],f}var t="length",n=null,r="top",i="offset",s="click.scrolly",o=e(window);e.fn.scrolly=function(i){var o,a,f,l,c=e(this);if(this[t]==0)return c;if(this[t]>1){for(o=0;o<this[t];o++)e(this[o]).scrolly(i);return c}l=n,f=c.attr("href");if(f.charAt(0)!="#"||f[t]<2)return c;a=jQuery.extend({anchor:r,easing:"swing",offset:0,parent:e("body,html"),pollOnce:!1,speed:1e3},i),a.pollOnce&&(l=u(f,a)),c.off(s).on(s,function(e){var t=l!==n?l:u(f,a);t!==n&&(e.preventDefault(),a.parent.stop().animate({scrollTop:t},a.speed,a.easing))})}})(jQuery);
|
|
@ -5,216 +5,186 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
(function($) {
|
(function($) {
|
||||||
skel
|
skel.breakpoints({
|
||||||
.breakpoints({
|
xlarge: "(max-width: 1680px)",
|
||||||
xlarge: '(max-width: 1680px)',
|
large: "(max-width: 1280px)",
|
||||||
large: '(max-width: 1280px)',
|
medium: "(max-width: 980px)",
|
||||||
medium: '(max-width: 980px)',
|
small: "(max-width: 736px)",
|
||||||
small: '(max-width: 736px)',
|
xsmall: "(max-width: 480px)"
|
||||||
xsmall: '(max-width: 480px)'
|
|
||||||
});
|
});
|
||||||
|
|
||||||
$(function() {
|
|
||||||
|
|
||||||
var $window = $(window),
|
var $window = $(window),
|
||||||
$body = $('body'),
|
$body = $("body"),
|
||||||
$wrapper = $('#page-wrapper'),
|
$wrapper = $("#page-wrapper"),
|
||||||
$banner = $('#banner'),
|
$banner = $("#banner"),
|
||||||
$header = $('#header');
|
$header = $(".header");
|
||||||
|
|
||||||
// Disable animations/transitions until the page has loaded.
|
// Disable animations/transitions until the page has loaded.
|
||||||
$body.addClass('is-loading');
|
$body.addClass("is-loading");
|
||||||
|
|
||||||
$window.on('load', function() {
|
$window.on("load", function() {
|
||||||
window.setTimeout(function() {
|
window.setTimeout(function() {
|
||||||
$body.removeClass('is-loading');
|
$body.removeClass("is-loading");
|
||||||
}, 100);
|
}, 100);
|
||||||
});
|
});
|
||||||
|
|
||||||
// Mobile?
|
// Mobile?
|
||||||
if (skel.vars.mobile)
|
if (skel.vars.mobile) {
|
||||||
$body.addClass('is-mobile');
|
$body.addClass("is-mobile");
|
||||||
else
|
} else {
|
||||||
skel
|
skel
|
||||||
.on('-medium !medium', function() {
|
.on("-medium !medium", function() {
|
||||||
$body.removeClass('is-mobile');
|
$body.removeClass("is-mobile");
|
||||||
})
|
})
|
||||||
.on('+medium', function() {
|
.on("+medium", function() {
|
||||||
$body.addClass('is-mobile');
|
$body.addClass("is-mobile");
|
||||||
});
|
});
|
||||||
|
}
|
||||||
|
|
||||||
// Fix: Placeholder polyfill.
|
// Fix: Placeholder polyfill.
|
||||||
$('form').placeholder();
|
$("form").placeholder();
|
||||||
|
|
||||||
// Prioritize "important" elements on medium.
|
// Prioritize "important" elements on medium.
|
||||||
skel.on('+medium -medium', function() {
|
skel.on("+medium -medium", function() {
|
||||||
$.prioritize(
|
$.prioritize(
|
||||||
'.important\\28 medium\\29',
|
".important\\28 medium\\29",
|
||||||
skel.breakpoint('medium').active
|
skel.breakpoint("medium").active
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
// Scrolly.
|
|
||||||
$('.scrolly')
|
|
||||||
.scrolly({
|
|
||||||
speed: 1500,
|
|
||||||
offset: $header.outerHeight()
|
|
||||||
});
|
|
||||||
|
|
||||||
$("#menu").show();
|
|
||||||
|
|
||||||
// Menu.
|
|
||||||
$('#menu')
|
|
||||||
.append('<a href="#menu" class="close"></a>')
|
|
||||||
.appendTo($body)
|
|
||||||
.panel({
|
|
||||||
delay: 500,
|
|
||||||
hideOnClick: true,
|
|
||||||
hideOnSwipe: true,
|
|
||||||
resetScroll: true,
|
|
||||||
resetForms: true,
|
|
||||||
side: 'right',
|
|
||||||
target: $body,
|
|
||||||
visibleClass: 'is-menu-visible'
|
|
||||||
});
|
|
||||||
|
|
||||||
// Header.
|
// Header.
|
||||||
if (skel.vars.IEVersion < 9)
|
if (skel.vars.IEVersion < 9) $header.removeClass("alt");
|
||||||
$header.removeClass('alt');
|
|
||||||
|
|
||||||
if ($banner.length > 0 &&
|
if ($banner.length > 0 && $header.hasClass("alt")) {
|
||||||
$header.hasClass('alt')) {
|
$window.on("resize", function() {
|
||||||
|
$window.trigger("scroll");
|
||||||
$window.on('resize', function() {
|
|
||||||
$window.trigger('scroll');
|
|
||||||
});
|
});
|
||||||
|
|
||||||
$banner.scrollex({
|
$banner.scrollex({
|
||||||
bottom: $header.outerHeight() + 1,
|
bottom: $header.outerHeight() + 1,
|
||||||
terminate: function() {
|
terminate: function() {
|
||||||
$header.removeClass('alt');
|
$header.removeClass("alt");
|
||||||
},
|
},
|
||||||
enter: function() {
|
enter: function() {
|
||||||
$header.addClass('alt');
|
$header.addClass("alt");
|
||||||
},
|
},
|
||||||
leave: function() {
|
leave: function() {
|
||||||
$header.removeClass('alt');
|
$header.removeClass("alt");
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
// Particles
|
// Particles
|
||||||
if ($(window).width() > 980) {
|
if ($(window).width() > 980) {
|
||||||
particlesJS('banner', {
|
particlesJS("banner", {
|
||||||
"particles": {
|
particles: {
|
||||||
"number": {
|
number: {
|
||||||
"value": 65,
|
value: 65,
|
||||||
"density": {
|
density: {
|
||||||
"enable": false,
|
enable: false,
|
||||||
"value_area": 800
|
value_area: 800
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"color": {
|
color: {
|
||||||
"value": "#f99081"
|
value: "#f99081"
|
||||||
},
|
},
|
||||||
"shape": {
|
shape: {
|
||||||
"type": "circle",
|
type: "circle",
|
||||||
"stroke": {
|
stroke: {
|
||||||
"width": 0,
|
width: 0,
|
||||||
"color": "#000000"
|
color: "#000000"
|
||||||
},
|
},
|
||||||
"polygon": {
|
polygon: {
|
||||||
"nb_sides": 5
|
nb_sides: 5
|
||||||
},
|
},
|
||||||
"image": {
|
image: {
|
||||||
"src": "img/github.svg",
|
src: "img/github.svg",
|
||||||
"width": 100,
|
width: 100,
|
||||||
"height": 100
|
height: 100
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"opacity": {
|
opacity: {
|
||||||
"value": 0.6,
|
value: 0.6,
|
||||||
"random": true,
|
random: true,
|
||||||
"anim": {
|
anim: {
|
||||||
"enable": false,
|
enable: false,
|
||||||
"speed": 1,
|
speed: 1,
|
||||||
"opacity_min": 0.4,
|
opacity_min: 0.4,
|
||||||
"sync": false
|
sync: false
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"size": {
|
size: {
|
||||||
"value": 14,
|
value: 14,
|
||||||
"random": true,
|
random: true,
|
||||||
"anim": {
|
anim: {
|
||||||
"enable": true,
|
enable: true,
|
||||||
"speed": 6,
|
speed: 6,
|
||||||
"size_min": 4,
|
size_min: 4,
|
||||||
"sync": false
|
sync: false
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"line_linked": {
|
line_linked: {
|
||||||
"enable": true,
|
enable: true,
|
||||||
"distance": 250,
|
distance: 250,
|
||||||
"color": "#f99081",
|
color: "#f99081",
|
||||||
"opacity": 0.8,
|
opacity: 0.8,
|
||||||
"width": 2
|
width: 2
|
||||||
},
|
},
|
||||||
"move": {
|
move: {
|
||||||
"enable": true,
|
enable: true,
|
||||||
"speed": 0.4,
|
speed: 0.4,
|
||||||
"direction": "none",
|
direction: "none",
|
||||||
"random": true,
|
random: true,
|
||||||
"straight": false,
|
straight: false,
|
||||||
"out_mode": "out",
|
out_mode: "out",
|
||||||
"bounce": false,
|
bounce: false,
|
||||||
"attract": {
|
attract: {
|
||||||
"enable": false,
|
enable: false,
|
||||||
"rotateX": 600,
|
rotateX: 600,
|
||||||
"rotateY": 1200
|
rotateY: 1200
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"interactivity": {
|
interactivity: {
|
||||||
"detect_on": "canvas",
|
detect_on: "canvas",
|
||||||
"events": {
|
events: {
|
||||||
"onhover": {
|
onhover: {
|
||||||
"enable": true,
|
enable: true,
|
||||||
"mode": "grab"
|
mode: "grab"
|
||||||
},
|
},
|
||||||
"onclick": {
|
onclick: {
|
||||||
"enable": true,
|
enable: true,
|
||||||
"mode": "push"
|
mode: "push"
|
||||||
},
|
},
|
||||||
"resize": true
|
resize: true
|
||||||
},
|
},
|
||||||
"modes": {
|
modes: {
|
||||||
"grab": {
|
grab: {
|
||||||
"distance": 200,
|
distance: 200,
|
||||||
"line_linked": {
|
line_linked: {
|
||||||
"opacity": 0.8
|
opacity: 0.8
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"bubble": {
|
bubble: {
|
||||||
"distance": 400,
|
distance: 400,
|
||||||
"size": 40,
|
size: 40,
|
||||||
"duration": 2,
|
duration: 2,
|
||||||
"opacity": 8,
|
opacity: 8,
|
||||||
"speed": 3
|
speed: 3
|
||||||
},
|
},
|
||||||
"repulse": {
|
repulse: {
|
||||||
"distance": 200,
|
distance: 200,
|
||||||
"duration": 0.4
|
duration: 0.4
|
||||||
},
|
},
|
||||||
"push": {
|
push: {
|
||||||
"particles_nb": 2
|
particles_nb: 2
|
||||||
},
|
},
|
||||||
"remove": {
|
remove: {
|
||||||
"particles_nb": 2
|
particles_nb: 2
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"retina_detect": true
|
retina_detect: true
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
|
||||||
})(jQuery);
|
})(jQuery);
|
||||||
|
9
src/assets/js/particles.min.js
vendored
Normal file
@ -1,301 +1,5 @@
|
|||||||
(function($) {
|
(function($) {
|
||||||
|
|
||||||
/**
|
|
||||||
* Generate an indented list of links from a nav. Meant for use with panel().
|
|
||||||
* @return {jQuery} jQuery object.
|
|
||||||
*/
|
|
||||||
$.fn.navList = function() {
|
|
||||||
|
|
||||||
var $this = $(this);
|
|
||||||
$a = $this.find('a'),
|
|
||||||
b = [];
|
|
||||||
|
|
||||||
$a.each(function() {
|
|
||||||
|
|
||||||
var $this = $(this),
|
|
||||||
indent = Math.max(0, $this.parents('li').length - 1),
|
|
||||||
href = $this.attr('href'),
|
|
||||||
target = $this.attr('target');
|
|
||||||
|
|
||||||
b.push(
|
|
||||||
'<a ' +
|
|
||||||
'class="link depth-' + indent + '"' +
|
|
||||||
( (typeof target !== 'undefined' && target != '') ? ' target="' + target + '"' : '') +
|
|
||||||
( (typeof href !== 'undefined' && href != '') ? ' href="' + href + '"' : '') +
|
|
||||||
'>' +
|
|
||||||
'<span class="indent-' + indent + '"></span>' +
|
|
||||||
$this.text() +
|
|
||||||
'</a>'
|
|
||||||
);
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
return b.join('');
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Panel-ify an element.
|
|
||||||
* @param {object} userConfig User config.
|
|
||||||
* @return {jQuery} jQuery object.
|
|
||||||
*/
|
|
||||||
$.fn.panel = function(userConfig) {
|
|
||||||
|
|
||||||
// No elements?
|
|
||||||
if (this.length == 0)
|
|
||||||
return $this;
|
|
||||||
|
|
||||||
// Multiple elements?
|
|
||||||
if (this.length > 1) {
|
|
||||||
|
|
||||||
for (var i=0; i < this.length; i++)
|
|
||||||
$(this[i]).panel(userConfig);
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// Vars.
|
|
||||||
var $this = $(this),
|
|
||||||
$body = $('body'),
|
|
||||||
$window = $(window),
|
|
||||||
id = $this.attr('id'),
|
|
||||||
config;
|
|
||||||
|
|
||||||
// Config.
|
|
||||||
config = $.extend({
|
|
||||||
|
|
||||||
// Delay.
|
|
||||||
delay: 0,
|
|
||||||
|
|
||||||
// Hide panel on link click.
|
|
||||||
hideOnClick: false,
|
|
||||||
|
|
||||||
// Hide panel on escape keypress.
|
|
||||||
hideOnEscape: false,
|
|
||||||
|
|
||||||
// Hide panel on swipe.
|
|
||||||
hideOnSwipe: false,
|
|
||||||
|
|
||||||
// Reset scroll position on hide.
|
|
||||||
resetScroll: false,
|
|
||||||
|
|
||||||
// Reset forms on hide.
|
|
||||||
resetForms: false,
|
|
||||||
|
|
||||||
// Side of viewport the panel will appear.
|
|
||||||
side: null,
|
|
||||||
|
|
||||||
// Target element for "class".
|
|
||||||
target: $this,
|
|
||||||
|
|
||||||
// Class to toggle.
|
|
||||||
visibleClass: 'visible'
|
|
||||||
|
|
||||||
}, userConfig);
|
|
||||||
|
|
||||||
// Expand "target" if it's not a jQuery object already.
|
|
||||||
if (typeof config.target != 'jQuery')
|
|
||||||
config.target = $(config.target);
|
|
||||||
|
|
||||||
// Panel.
|
|
||||||
|
|
||||||
// Methods.
|
|
||||||
$this._hide = function(event) {
|
|
||||||
|
|
||||||
// Already hidden? Bail.
|
|
||||||
if (!config.target.hasClass(config.visibleClass))
|
|
||||||
return;
|
|
||||||
|
|
||||||
// If an event was provided, cancel it.
|
|
||||||
if (event) {
|
|
||||||
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// Hide.
|
|
||||||
config.target.removeClass(config.visibleClass);
|
|
||||||
|
|
||||||
// Post-hide stuff.
|
|
||||||
window.setTimeout(function() {
|
|
||||||
|
|
||||||
// Reset scroll position.
|
|
||||||
if (config.resetScroll)
|
|
||||||
$this.scrollTop(0);
|
|
||||||
|
|
||||||
// Reset forms.
|
|
||||||
if (config.resetForms)
|
|
||||||
$this.find('form').each(function() {
|
|
||||||
this.reset();
|
|
||||||
});
|
|
||||||
|
|
||||||
}, config.delay);
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
// Vendor fixes.
|
|
||||||
$this
|
|
||||||
.css('-ms-overflow-style', '-ms-autohiding-scrollbar')
|
|
||||||
.css('-webkit-overflow-scrolling', 'touch');
|
|
||||||
|
|
||||||
// Hide on click.
|
|
||||||
if (config.hideOnClick) {
|
|
||||||
|
|
||||||
$this.find('a')
|
|
||||||
.css('-webkit-tap-highlight-color', 'rgba(0,0,0,0)');
|
|
||||||
|
|
||||||
$this
|
|
||||||
.on('click', 'a', function(event) {
|
|
||||||
|
|
||||||
var $a = $(this),
|
|
||||||
href = $a.attr('href'),
|
|
||||||
target = $a.attr('target');
|
|
||||||
|
|
||||||
if (!href || href == '#' || href == '' || href == '#' + id)
|
|
||||||
return;
|
|
||||||
|
|
||||||
// Cancel original event.
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
|
|
||||||
// Hide panel.
|
|
||||||
$this._hide();
|
|
||||||
|
|
||||||
// Redirect to href.
|
|
||||||
window.setTimeout(function() {
|
|
||||||
|
|
||||||
if (target == '_blank')
|
|
||||||
window.open(href);
|
|
||||||
else
|
|
||||||
window.location.href = href;
|
|
||||||
|
|
||||||
}, config.delay + 10);
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// Event: Touch stuff.
|
|
||||||
$this.on('touchstart', function(event) {
|
|
||||||
|
|
||||||
$this.touchPosX = event.originalEvent.touches[0].pageX;
|
|
||||||
$this.touchPosY = event.originalEvent.touches[0].pageY;
|
|
||||||
|
|
||||||
})
|
|
||||||
|
|
||||||
$this.on('touchmove', function(event) {
|
|
||||||
|
|
||||||
if ($this.touchPosX === null
|
|
||||||
|| $this.touchPosY === null)
|
|
||||||
return;
|
|
||||||
|
|
||||||
var diffX = $this.touchPosX - event.originalEvent.touches[0].pageX,
|
|
||||||
diffY = $this.touchPosY - event.originalEvent.touches[0].pageY,
|
|
||||||
th = $this.outerHeight(),
|
|
||||||
ts = ($this.get(0).scrollHeight - $this.scrollTop());
|
|
||||||
|
|
||||||
// Hide on swipe?
|
|
||||||
if (config.hideOnSwipe) {
|
|
||||||
|
|
||||||
var result = false,
|
|
||||||
boundary = 20,
|
|
||||||
delta = 50;
|
|
||||||
|
|
||||||
switch (config.side) {
|
|
||||||
|
|
||||||
case 'left':
|
|
||||||
result = (diffY < boundary && diffY > (-1 * boundary)) && (diffX > delta);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 'right':
|
|
||||||
result = (diffY < boundary && diffY > (-1 * boundary)) && (diffX < (-1 * delta));
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 'top':
|
|
||||||
result = (diffX < boundary && diffX > (-1 * boundary)) && (diffY > delta);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 'bottom':
|
|
||||||
result = (diffX < boundary && diffX > (-1 * boundary)) && (diffY < (-1 * delta));
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
if (result) {
|
|
||||||
|
|
||||||
$this.touchPosX = null;
|
|
||||||
$this.touchPosY = null;
|
|
||||||
$this._hide();
|
|
||||||
|
|
||||||
return false;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// Prevent vertical scrolling past the top or bottom.
|
|
||||||
if (($this.scrollTop() < 0 && diffY < 0)
|
|
||||||
|| (ts > (th - 2) && ts < (th + 2) && diffY > 0)) {
|
|
||||||
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
// Event: Prevent certain events inside the panel from bubbling.
|
|
||||||
$this.on('click touchend touchstart touchmove', function(event) {
|
|
||||||
event.stopPropagation();
|
|
||||||
});
|
|
||||||
|
|
||||||
// Event: Hide panel if a child anchor tag pointing to its ID is clicked.
|
|
||||||
$this.on('click', 'a[href="#' + id + '"]', function(event) {
|
|
||||||
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
|
|
||||||
config.target.removeClass(config.visibleClass);
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
// Body.
|
|
||||||
|
|
||||||
// Event: Hide panel on body click/tap.
|
|
||||||
$body.on('click touchend', function(event) {
|
|
||||||
$this._hide(event);
|
|
||||||
});
|
|
||||||
|
|
||||||
// Event: Toggle.
|
|
||||||
$body.on('click', 'a[href="#' + id + '"]', function(event) {
|
|
||||||
|
|
||||||
event.preventDefault();
|
|
||||||
event.stopPropagation();
|
|
||||||
|
|
||||||
config.target.toggleClass(config.visibleClass);
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
// Window.
|
|
||||||
|
|
||||||
// Event: Hide on ESC.
|
|
||||||
if (config.hideOnEscape)
|
|
||||||
$window.on('keydown', function(event) {
|
|
||||||
|
|
||||||
if (event.keyCode == 27)
|
|
||||||
$this._hide(event);
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
return $this;
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Apply "placeholder" attribute polyfill to one or more forms.
|
* Apply "placeholder" attribute polyfill to one or more forms.
|
||||||
* @return {jQuery} jQuery object.
|
* @return {jQuery} jQuery object.
|
||||||
|
@ -11,54 +11,184 @@ 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
|
||||||
fG9YVaQqGxeUSQ==
|
XcfI/kLvYknvuTvhlIRG22eCOD89Y4QEoK0L51FSHdpHKs20gEdftpZWG513dHCN
|
||||||
=OH/1
|
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
|
||||||
|
=jgXl
|
||||||
-----END PGP PUBLIC KEY BLOCK-----
|
-----END PGP PUBLIC KEY BLOCK-----
|
||||||
|
|
||||||
|
@ -19,23 +19,10 @@ body {
|
|||||||
body, input, select, textarea {
|
body, input, select, textarea {
|
||||||
color: _palette(fg);
|
color: _palette(fg);
|
||||||
font-family: _font(family);
|
font-family: _font(family);
|
||||||
font-size: 15pt;
|
font-size: 18px;
|
||||||
font-weight: _font(weight);
|
font-weight: _font(weight);
|
||||||
letter-spacing: _size(letter-spacing);
|
letter-spacing: _size(letter-spacing);
|
||||||
line-height: 1.65em;
|
line-height: 1.6;
|
||||||
|
|
||||||
@include breakpoint(xlarge) {
|
|
||||||
font-size: 13pt;
|
|
||||||
}
|
|
||||||
|
|
||||||
@include breakpoint(large) {
|
|
||||||
font-size: 12pt;
|
|
||||||
}
|
|
||||||
|
|
||||||
@include breakpoint(small) {
|
|
||||||
font-size: 11pt;
|
|
||||||
letter-spacing: _size(letter-spacing) * 0.5;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
a {
|
a {
|
||||||
|
@ -22,50 +22,26 @@
|
|||||||
|
|
||||||
/* Icon */
|
/* Icon */
|
||||||
|
|
||||||
.icon {
|
.icon--style1 { fill: _palette(bg); }
|
||||||
@include icon;
|
.icon--style2 { fill: _palette(accent2, bg); }
|
||||||
border-bottom: none;
|
.icon--style3 { fill: _palette(accent3, bg); }
|
||||||
position: relative;
|
.icon--style4 { fill: _palette(accent4, bg); }
|
||||||
|
|
||||||
> .label {
|
.icon--diamond {
|
||||||
display: none;
|
transform: rotate(-45deg);
|
||||||
}
|
|
||||||
|
|
||||||
&.major {
|
|
||||||
@include vendor('transform', 'rotate(-45deg)');
|
|
||||||
border-radius: 3px;
|
border-radius: 3px;
|
||||||
border: solid 2px _palette(border);
|
border: 2px solid #dfdfdf;
|
||||||
display: inline-block;
|
box-sizing: border-box;
|
||||||
font-size: 1.35em;
|
height: 5rem;
|
||||||
height: calc(3em + 2px);
|
width: 5rem;
|
||||||
line-height: 3em;
|
|
||||||
text-align: center;
|
|
||||||
width: calc(3em + 2px);
|
|
||||||
|
|
||||||
&:before {
|
display: inline-flex;
|
||||||
@include vendor('transform', 'rotate(45deg)');
|
justify-content: center;
|
||||||
display: inline-block;
|
align-items: center;
|
||||||
font-size: 1.5em;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@include breakpoint(small) {
|
.icon--diamond svg {
|
||||||
font-size: 1em;
|
margin: 1rem;
|
||||||
}
|
width: 2.25rem;
|
||||||
}
|
transform: rotate(45deg);
|
||||||
|
|
||||||
&.style1 {
|
|
||||||
color: _palette(bg);
|
|
||||||
}
|
|
||||||
|
|
||||||
&.style2 {
|
|
||||||
color: _palette(accent2, bg);
|
|
||||||
}
|
|
||||||
|
|
||||||
&.style3 {
|
|
||||||
color: _palette(accent3, bg);
|
|
||||||
}
|
|
||||||
|
|
||||||
&.style4 {
|
|
||||||
color: _palette(accent4, bg);
|
|
||||||
}
|
|
||||||
}
|
}
|
@ -2,17 +2,27 @@
|
|||||||
/* Features */
|
/* Features */
|
||||||
|
|
||||||
.features {
|
.features {
|
||||||
@include vendor('display', 'flex');
|
display: flex;
|
||||||
@include vendor('flex-wrap', 'wrap');
|
justify-content: center;
|
||||||
@include vendor('justify-content', 'center');
|
flex-wrap: wrap;
|
||||||
|
|
||||||
list-style: none;
|
list-style: none;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
li {
|
.features-icon {
|
||||||
@include padding(4em, 4em, (0,0,0,2em));
|
width: 100%;
|
||||||
display: block;
|
max-width: 2rem;
|
||||||
position: relative;
|
margin-right: 2rem;
|
||||||
|
fill: _palette(accent1, bg);
|
||||||
|
}
|
||||||
|
|
||||||
|
.features-item {
|
||||||
|
display: inline-flex;
|
||||||
|
align-items: start;
|
||||||
|
|
||||||
|
padding: 4rem 4rem 4rem 3rem;
|
||||||
text-align: left;
|
text-align: left;
|
||||||
width: 50%;
|
width: 50%;
|
||||||
|
|
||||||
@ -24,15 +34,6 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
&:before {
|
|
||||||
display: block;
|
|
||||||
color: _palette(accent1, bg);
|
|
||||||
position: absolute;
|
|
||||||
left: 1.75em;
|
|
||||||
top: 2.75em;
|
|
||||||
font-size: 1.5em;
|
|
||||||
}
|
|
||||||
|
|
||||||
&:nth-child(1) {
|
&:nth-child(1) {
|
||||||
border-top-left-radius: 3px;
|
border-top-left-radius: 3px;
|
||||||
}
|
}
|
||||||
@ -72,4 +73,3 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
@ -1,100 +1,37 @@
|
|||||||
|
|
||||||
/* Header */
|
/* Header */
|
||||||
|
|
||||||
#header {
|
.header {
|
||||||
@include vendor('transition', 'background-color #{_duration(transitions)} ease');
|
|
||||||
background: _palette(bg);
|
|
||||||
height: 3em;
|
|
||||||
left: 0;
|
|
||||||
line-height: 3em;
|
|
||||||
position: fixed;
|
position: fixed;
|
||||||
top: 0;
|
top: 0;
|
||||||
|
left: 0;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
|
|
||||||
|
@include vendor('transition', 'background-color #{_duration(transitions)} ease');
|
||||||
|
background: _palette(bg);
|
||||||
z-index: _misc(z-index-base);
|
z-index: _misc(z-index-base);
|
||||||
|
|
||||||
h1 {
|
height: 3em;
|
||||||
@include vendor('transition', 'opacity #{_duration(transitions)} ease');
|
line-height: 3em;
|
||||||
height: inherit;
|
|
||||||
left: 1.25em;
|
padding-left: 1.5rem;
|
||||||
line-height: inherit;
|
|
||||||
position: absolute;
|
display: flex;
|
||||||
top: 0;
|
justify-content: space-between;
|
||||||
|
align-items: center;
|
||||||
|
|
||||||
|
@include breakpoint(small) {
|
||||||
|
position: initial;
|
||||||
|
height: auto;
|
||||||
|
line-height: inherit;
|
||||||
|
|
||||||
a {
|
|
||||||
border: 0;
|
|
||||||
display: block;
|
display: block;
|
||||||
height: inherit;
|
margin: 0 auto;
|
||||||
line-height: inherit;
|
text-align: center
|
||||||
|
|
||||||
@include breakpoint(small) {
|
|
||||||
font-size: 0.8em;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
nav {
|
|
||||||
height: inherit;
|
|
||||||
line-height: inherit;
|
|
||||||
position: absolute;
|
|
||||||
right: 0;
|
|
||||||
top: 0;
|
|
||||||
|
|
||||||
> ul {
|
|
||||||
list-style: none;
|
|
||||||
margin: 0;
|
|
||||||
padding: 0;
|
|
||||||
white-space: nowrap;
|
|
||||||
|
|
||||||
> li {
|
|
||||||
display: inline-block;
|
|
||||||
padding: 0;
|
|
||||||
|
|
||||||
> a {
|
|
||||||
border: 0;
|
|
||||||
color: _palette(fg-bold);
|
|
||||||
display: block;
|
|
||||||
font-size: 0.8em;
|
|
||||||
letter-spacing: _size(letter-spacing-alt);
|
|
||||||
padding: 0 1.5em;
|
|
||||||
text-transform: uppercase;
|
|
||||||
|
|
||||||
&.menuToggle {
|
|
||||||
outline: 0;
|
|
||||||
position: relative;
|
|
||||||
|
|
||||||
&:after {
|
|
||||||
background-image: url('images/bars.svg');
|
|
||||||
background-position: right center;
|
|
||||||
background-repeat: no-repeat;
|
|
||||||
content: '';
|
|
||||||
display: inline-block;
|
|
||||||
height: 3.75em;
|
|
||||||
vertical-align: top;
|
|
||||||
width: 2em;
|
|
||||||
}
|
|
||||||
|
|
||||||
@include breakpoint(small) {
|
|
||||||
padding: 0 1.5em;
|
|
||||||
|
|
||||||
span {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@include breakpoint(small) {
|
|
||||||
padding: 0 0 0 1.5em;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
&:first-child {
|
.header.alt {
|
||||||
margin-left: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
&.alt {
|
|
||||||
background: transparent;
|
background: transparent;
|
||||||
|
|
||||||
h1 {
|
h1 {
|
||||||
@ -102,4 +39,48 @@
|
|||||||
opacity: 0;
|
opacity: 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.header-home {
|
||||||
|
@include vendor('transition', 'opacity #{_duration(transitions)} ease');
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
|
||||||
|
a {
|
||||||
|
border: 0;
|
||||||
|
display: block;
|
||||||
|
height: inherit;
|
||||||
|
line-height: inherit;
|
||||||
|
}
|
||||||
|
|
||||||
|
@include breakpoint(small) {
|
||||||
|
padding: 1rem 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.header-nav {
|
||||||
|
display: flex;
|
||||||
|
list-style: none;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
|
||||||
|
li { padding: 0; }
|
||||||
|
|
||||||
|
|
||||||
|
@include breakpoint(small) {
|
||||||
|
justify-content: space-around;
|
||||||
|
padding-bottom: 0.5rem;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.header-link {
|
||||||
|
border: 0;
|
||||||
|
color: _palette(fg-bold);
|
||||||
|
font-size: 0.8em;
|
||||||
|
letter-spacing: _size(letter-spacing-alt);
|
||||||
|
padding: 0 1.5rem;
|
||||||
|
text-transform: uppercase;
|
||||||
|
|
||||||
|
@include breakpoint(small) {
|
||||||
|
padding: 0 0.75rem;
|
||||||
|
}
|
||||||
}
|
}
|
73
src/assets/styles/components/_highlighting.scss
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
pre.highlight {
|
||||||
|
color: #93A1A1;
|
||||||
|
background-color: #002B36;
|
||||||
|
|
||||||
|
.c { color: #586E75 } /* Comment */
|
||||||
|
.err { color: #93A1A1 } /* Error */
|
||||||
|
.g { color: #93A1A1 } /* Generic */
|
||||||
|
.k { color: #859900 } /* Keyword */
|
||||||
|
.l { color: #93A1A1 } /* Literal */
|
||||||
|
.n { color: #93A1A1 } /* Name */
|
||||||
|
.o { color: #859900 } /* Operator */
|
||||||
|
.x { color: #CB4B16 } /* Other */
|
||||||
|
.p { color: #93A1A1 } /* Punctuation */
|
||||||
|
.cm { color: #586E75 } /* Comment.Multiline */
|
||||||
|
.cp { color: #859900 } /* Comment.Preproc */
|
||||||
|
.c1 { color: #586E75 } /* Comment.Single */
|
||||||
|
.cs { color: #859900 } /* Comment.Special */
|
||||||
|
.gd { color: #2AA198 } /* Generic.Deleted */
|
||||||
|
.ge { color: #93A1A1; font-style: italic } /* Generic.Emph */
|
||||||
|
.gr { color: #DC322F } /* Generic.Error */
|
||||||
|
.gh { color: #CB4B16 } /* Generic.Heading */
|
||||||
|
.gi { color: #859900 } /* Generic.Inserted */
|
||||||
|
.go { color: #93A1A1 } /* Generic.Output */
|
||||||
|
.gp { color: #93A1A1 } /* Generic.Prompt */
|
||||||
|
.gs { color: #93A1A1; font-weight: bold } /* Generic.Strong */
|
||||||
|
.gu { color: #CB4B16 } /* Generic.Subheading */
|
||||||
|
.gt { color: #93A1A1 } /* Generic.Traceback */
|
||||||
|
.kc { color: #CB4B16 } /* Keyword.Constant */
|
||||||
|
.kd { color: #268BD2 } /* Keyword.Declaration */
|
||||||
|
.kn { color: #859900 } /* Keyword.Namespace */
|
||||||
|
.kp { color: #859900 } /* Keyword.Pseudo */
|
||||||
|
.kr { color: #268BD2 } /* Keyword.Reserved */
|
||||||
|
.kt { color: #DC322F } /* Keyword.Type */
|
||||||
|
.ld { color: #93A1A1 } /* Literal.Date */
|
||||||
|
.m { color: #2AA198 } /* Literal.Number */
|
||||||
|
.s { color: #2AA198 } /* Literal.String */
|
||||||
|
.na { color: #93A1A1 } /* Name.Attribute */
|
||||||
|
.nb { color: #B58900 } /* Name.Builtin */
|
||||||
|
.nc { color: #268BD2 } /* Name.Class */
|
||||||
|
.no { color: #CB4B16 } /* Name.Constant */
|
||||||
|
.nd { color: #268BD2 } /* Name.Decorator */
|
||||||
|
.ni { color: #CB4B16 } /* Name.Entity */
|
||||||
|
.ne { color: #CB4B16 } /* Name.Exception */
|
||||||
|
.nf { color: #268BD2 } /* Name.Function */
|
||||||
|
.nl { color: #93A1A1 } /* Name.Label */
|
||||||
|
.nn { color: #93A1A1 } /* Name.Namespace */
|
||||||
|
.nx { color: #93A1A1 } /* Name.Other */
|
||||||
|
.py { color: #93A1A1 } /* Name.Property */
|
||||||
|
.nt { color: #268BD2 } /* Name.Tag */
|
||||||
|
.nv { color: #268BD2 } /* Name.Variable */
|
||||||
|
.ow { color: #859900 } /* Operator.Word */
|
||||||
|
.w { color: #93A1A1 } /* Text.Whitespace */
|
||||||
|
.mf { color: #2AA198 } /* Literal.Number.Float */
|
||||||
|
.mh { color: #2AA198 } /* Literal.Number.Hex */
|
||||||
|
.mi { color: #2AA198 } /* Literal.Number.Integer */
|
||||||
|
.mo { color: #2AA198 } /* Literal.Number.Oct */
|
||||||
|
.sb { color: #586E75 } /* Literal.String.Backtick */
|
||||||
|
.sc { color: #2AA198 } /* Literal.String.Char */
|
||||||
|
.sd { color: #93A1A1 } /* Literal.String.Doc */
|
||||||
|
.s2 { color: #2AA198 } /* Literal.String.Double */
|
||||||
|
.se { color: #CB4B16 } /* Literal.String.Escape */
|
||||||
|
.sh { color: #93A1A1 } /* Literal.String.Heredoc */
|
||||||
|
.si { color: #2AA198 } /* Literal.String.Interpol */
|
||||||
|
.sx { color: #2AA198 } /* Literal.String.Other */
|
||||||
|
.sr { color: #DC322F } /* Literal.String.Regex */
|
||||||
|
.s1 { color: #2AA198 } /* Literal.String.Single */
|
||||||
|
.ss { color: #2AA198 } /* Literal.String.Symbol */
|
||||||
|
.bp { color: #268BD2 } /* Name.Builtin.Pseudo */
|
||||||
|
.vc { color: #268BD2 } /* Name.Variable.Class */
|
||||||
|
.vg { color: #268BD2 } /* Name.Variable.Global */
|
||||||
|
.vi { color: #268BD2 } /* Name.Variable.Instance */
|
||||||
|
.il { color: #2AA198 } /* Literal.Number.Integer.Long */
|
||||||
|
}
|
@ -20,85 +20,3 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#menu {
|
|
||||||
display:none;
|
|
||||||
@include vendor('transform', 'translateX(20em)');
|
|
||||||
@include vendor('transition', 'transform #{_duration(menu)} ease');
|
|
||||||
-webkit-overflow-scrolling: touch;
|
|
||||||
background: _palette(accent1, bg);
|
|
||||||
color: _palette(accent1, fg-bold);
|
|
||||||
height: 100%;
|
|
||||||
max-width: 80%;
|
|
||||||
overflow-y: auto;
|
|
||||||
padding: 3em 2em;
|
|
||||||
position: fixed;
|
|
||||||
right: 0;
|
|
||||||
top: 0;
|
|
||||||
width: 20em;
|
|
||||||
z-index: _misc(z-index-base) + 2;
|
|
||||||
|
|
||||||
ul {
|
|
||||||
list-style: none;
|
|
||||||
padding: 0;
|
|
||||||
|
|
||||||
> li {
|
|
||||||
border-top: solid 1px _palette(accent1, border);
|
|
||||||
margin: 0.5em 0 0 0;
|
|
||||||
padding: 0.5em 0 0 0;
|
|
||||||
|
|
||||||
&:first-child {
|
|
||||||
border-top: 0 !important;
|
|
||||||
margin-top: 0 !important;
|
|
||||||
padding-top: 0 !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
> a {
|
|
||||||
border: 0;
|
|
||||||
color: black;
|
|
||||||
display: block;
|
|
||||||
font-size: 0.8em;
|
|
||||||
letter-spacing: _size(letter-spacing-alt);
|
|
||||||
outline: 0;
|
|
||||||
text-decoration: none;
|
|
||||||
text-transform: uppercase;
|
|
||||||
|
|
||||||
@include breakpoint(small) {
|
|
||||||
line-height: 3em;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.close {
|
|
||||||
background-image: url('images/close.svg');
|
|
||||||
background-position: 4.85em 1em;
|
|
||||||
background-repeat: no-repeat;
|
|
||||||
border: 0;
|
|
||||||
cursor: pointer;
|
|
||||||
display: block;
|
|
||||||
height: 3em;
|
|
||||||
position: absolute;
|
|
||||||
right: 0;
|
|
||||||
top: 0;
|
|
||||||
vertical-align: middle;
|
|
||||||
width: 7em;
|
|
||||||
}
|
|
||||||
|
|
||||||
@include breakpoint(small) {
|
|
||||||
padding: 3em 1.5em;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
body.is-menu-visible {
|
|
||||||
#page-wrapper {
|
|
||||||
opacity: 0.35;
|
|
||||||
|
|
||||||
&:before {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#menu {
|
|
||||||
@include vendor('transform', 'translateX(0)');
|
|
||||||
}
|
|
||||||
}
|
|
@ -206,6 +206,10 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
> .inner--text {
|
||||||
|
max-width: 45rem;
|
||||||
|
}
|
||||||
|
|
||||||
&.alt {
|
&.alt {
|
||||||
padding: 0;
|
padding: 0;
|
||||||
}
|
}
|
||||||
|
@ -1,117 +0,0 @@
|
|||||||
---
|
|
||||||
---
|
|
||||||
@import 'libs/vars';
|
|
||||||
@import 'libs/functions';
|
|
||||||
@import 'libs/mixins';
|
|
||||||
@import 'libs/skel';
|
|
||||||
|
|
||||||
/*
|
|
||||||
Spectral by HTML5 UP
|
|
||||||
html5up.net | @ajlkn
|
|
||||||
Free for personal and commercial use under the CCA 3.0 license (html5up.net/license)
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Icon */
|
|
||||||
|
|
||||||
.icon {
|
|
||||||
&.major {
|
|
||||||
border: none;
|
|
||||||
|
|
||||||
&:before {
|
|
||||||
font-size: 3em;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Form */
|
|
||||||
|
|
||||||
label {
|
|
||||||
color: _palette(accent2, fg-bold);
|
|
||||||
}
|
|
||||||
|
|
||||||
input[type="text"],
|
|
||||||
input[type="password"],
|
|
||||||
input[type="email"],
|
|
||||||
select,
|
|
||||||
textarea {
|
|
||||||
border: solid 1px _palette(accent2, border);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Button */
|
|
||||||
|
|
||||||
input[type="submit"],
|
|
||||||
input[type="reset"],
|
|
||||||
input[type="button"],
|
|
||||||
button,
|
|
||||||
.button {
|
|
||||||
border: solid 2px _palette(accent2, border);
|
|
||||||
|
|
||||||
&.special {
|
|
||||||
border: 0 !important;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Page Wrapper + Menu */
|
|
||||||
|
|
||||||
#menu {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
body.is-menu-visible {
|
|
||||||
#menu {
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Header */
|
|
||||||
|
|
||||||
#header {
|
|
||||||
nav {
|
|
||||||
> ul {
|
|
||||||
> li {
|
|
||||||
> a {
|
|
||||||
&.menuToggle {
|
|
||||||
&:after {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Banner + Wrapper (style4) */
|
|
||||||
|
|
||||||
#banner,
|
|
||||||
.wrapper.style4 {
|
|
||||||
-ms-behavior: url('assets/js/ie/backgroundsize.min.htc');
|
|
||||||
|
|
||||||
&:before {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Banner */
|
|
||||||
|
|
||||||
#banner {
|
|
||||||
.more {
|
|
||||||
height: 4em;
|
|
||||||
|
|
||||||
&:after {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Main */
|
|
||||||
|
|
||||||
#main {
|
|
||||||
> header {
|
|
||||||
-ms-behavior: url('assets/js/ie/backgroundsize.min.htc');
|
|
||||||
|
|
||||||
&:before {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,136 +0,0 @@
|
|||||||
---
|
|
||||||
---
|
|
||||||
@import 'libs/vars';
|
|
||||||
@import 'libs/functions';
|
|
||||||
@import 'libs/mixins';
|
|
||||||
@import 'libs/skel';
|
|
||||||
|
|
||||||
/*
|
|
||||||
Spectral by HTML5 UP
|
|
||||||
html5up.net | @ajlkn
|
|
||||||
Free for personal and commercial use under the CCA 3.0 license (html5up.net/license)
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Spotlight */
|
|
||||||
|
|
||||||
.spotlight {
|
|
||||||
display: block;
|
|
||||||
|
|
||||||
.image {
|
|
||||||
display: inline-block;
|
|
||||||
vertical-align: top;
|
|
||||||
}
|
|
||||||
|
|
||||||
.content {
|
|
||||||
@include padding(4em, 4em);
|
|
||||||
display: inline-block;
|
|
||||||
}
|
|
||||||
|
|
||||||
&:after {
|
|
||||||
clear: both;
|
|
||||||
content: '';
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Features */
|
|
||||||
|
|
||||||
.features {
|
|
||||||
display: block;
|
|
||||||
|
|
||||||
li {
|
|
||||||
float: left;
|
|
||||||
}
|
|
||||||
|
|
||||||
&:after {
|
|
||||||
content: '';
|
|
||||||
display: block;
|
|
||||||
clear: both;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Banner + Wrapper (style4) */
|
|
||||||
|
|
||||||
#banner,
|
|
||||||
.wrapper.style4 {
|
|
||||||
background-image: url("../../assets/images/banner.jpg");
|
|
||||||
background-position: center center;
|
|
||||||
background-repeat: no-repeat;
|
|
||||||
background-size: cover;
|
|
||||||
position: relative;
|
|
||||||
|
|
||||||
&:before {
|
|
||||||
background: #000000;
|
|
||||||
content: '';
|
|
||||||
height: 100%;
|
|
||||||
left: 0;
|
|
||||||
opacity: 0.5;
|
|
||||||
position: absolute;
|
|
||||||
top: 0;
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.inner {
|
|
||||||
position: relative;
|
|
||||||
z-index: 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Banner */
|
|
||||||
|
|
||||||
#banner {
|
|
||||||
@include padding(14em, 0);
|
|
||||||
height: auto;
|
|
||||||
|
|
||||||
&:after {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* CTA */
|
|
||||||
|
|
||||||
#cta {
|
|
||||||
.inner {
|
|
||||||
header {
|
|
||||||
float: left;
|
|
||||||
}
|
|
||||||
|
|
||||||
.actions {
|
|
||||||
float: left;
|
|
||||||
}
|
|
||||||
|
|
||||||
&:after {
|
|
||||||
clear: both;
|
|
||||||
content: '';
|
|
||||||
display: block;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Main */
|
|
||||||
|
|
||||||
#main {
|
|
||||||
> header {
|
|
||||||
background-image: url("../../assets/images/banner.jpg");
|
|
||||||
background-position: center center;
|
|
||||||
background-repeat: no-repeat;
|
|
||||||
background-size: cover;
|
|
||||||
position: relative;
|
|
||||||
|
|
||||||
&:before {
|
|
||||||
background: #000000;
|
|
||||||
content: '';
|
|
||||||
height: 100%;
|
|
||||||
left: 0;
|
|
||||||
opacity: 0.5;
|
|
||||||
position: absolute;
|
|
||||||
top: 0;
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
> * {
|
|
||||||
position: relative;
|
|
||||||
z-index: 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,34 +0,0 @@
|
|||||||
// Spinning Icons
|
|
||||||
// --------------------------
|
|
||||||
|
|
||||||
.#{$fa-css-prefix}-spin {
|
|
||||||
-webkit-animation: fa-spin 2s infinite linear;
|
|
||||||
animation: fa-spin 2s infinite linear;
|
|
||||||
}
|
|
||||||
|
|
||||||
.#{$fa-css-prefix}-pulse {
|
|
||||||
-webkit-animation: fa-spin 1s infinite steps(8);
|
|
||||||
animation: fa-spin 1s infinite steps(8);
|
|
||||||
}
|
|
||||||
|
|
||||||
@-webkit-keyframes fa-spin {
|
|
||||||
0% {
|
|
||||||
-webkit-transform: rotate(0deg);
|
|
||||||
transform: rotate(0deg);
|
|
||||||
}
|
|
||||||
100% {
|
|
||||||
-webkit-transform: rotate(359deg);
|
|
||||||
transform: rotate(359deg);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@keyframes fa-spin {
|
|
||||||
0% {
|
|
||||||
-webkit-transform: rotate(0deg);
|
|
||||||
transform: rotate(0deg);
|
|
||||||
}
|
|
||||||
100% {
|
|
||||||
-webkit-transform: rotate(359deg);
|
|
||||||
transform: rotate(359deg);
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,25 +0,0 @@
|
|||||||
// Bordered & Pulled
|
|
||||||
// -------------------------
|
|
||||||
|
|
||||||
.#{$fa-css-prefix}-border {
|
|
||||||
padding: .2em .25em .15em;
|
|
||||||
border: solid .08em $fa-border-color;
|
|
||||||
border-radius: .1em;
|
|
||||||
}
|
|
||||||
|
|
||||||
.#{$fa-css-prefix}-pull-left { float: left; }
|
|
||||||
.#{$fa-css-prefix}-pull-right { float: right; }
|
|
||||||
|
|
||||||
.#{$fa-css-prefix} {
|
|
||||||
&.#{$fa-css-prefix}-pull-left { margin-right: .3em; }
|
|
||||||
&.#{$fa-css-prefix}-pull-right { margin-left: .3em; }
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Deprecated as of 4.4.0 */
|
|
||||||
.pull-right { float: right; }
|
|
||||||
.pull-left { float: left; }
|
|
||||||
|
|
||||||
.#{$fa-css-prefix} {
|
|
||||||
&.pull-left { margin-right: .3em; }
|
|
||||||
&.pull-right { margin-left: .3em; }
|
|
||||||
}
|
|
@ -1,12 +0,0 @@
|
|||||||
// Base Class Definition
|
|
||||||
// -------------------------
|
|
||||||
|
|
||||||
.#{$fa-css-prefix} {
|
|
||||||
display: inline-block;
|
|
||||||
font: normal normal normal #{$fa-font-size-base}/#{$fa-line-height-base} FontAwesome; // shortening font declaration
|
|
||||||
font-size: inherit; // can't have font-size inherit on line above, so need to override
|
|
||||||
text-rendering: auto; // optimizelegibility throws things off #1094
|
|
||||||
-webkit-font-smoothing: antialiased;
|
|
||||||
-moz-osx-font-smoothing: grayscale;
|
|
||||||
|
|
||||||
}
|
|
@ -1,6 +0,0 @@
|
|||||||
// Fixed Width Icons
|
|
||||||
// -------------------------
|
|
||||||
.#{$fa-css-prefix}-fw {
|
|
||||||
width: (18em / 14);
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
@ -1,13 +0,0 @@
|
|||||||
// Icon Sizes
|
|
||||||
// -------------------------
|
|
||||||
|
|
||||||
/* makes the font 33% larger relative to the icon container */
|
|
||||||
.#{$fa-css-prefix}-lg {
|
|
||||||
font-size: (4em / 3);
|
|
||||||
line-height: (3em / 4);
|
|
||||||
vertical-align: -15%;
|
|
||||||
}
|
|
||||||
.#{$fa-css-prefix}-2x { font-size: 2em; }
|
|
||||||
.#{$fa-css-prefix}-3x { font-size: 3em; }
|
|
||||||
.#{$fa-css-prefix}-4x { font-size: 4em; }
|
|
||||||
.#{$fa-css-prefix}-5x { font-size: 5em; }
|
|
@ -1,19 +0,0 @@
|
|||||||
// List Icons
|
|
||||||
// -------------------------
|
|
||||||
|
|
||||||
.#{$fa-css-prefix}-ul {
|
|
||||||
padding-left: 0;
|
|
||||||
margin-left: $fa-li-width;
|
|
||||||
list-style-type: none;
|
|
||||||
> li { position: relative; }
|
|
||||||
}
|
|
||||||
.#{$fa-css-prefix}-li {
|
|
||||||
position: absolute;
|
|
||||||
left: -$fa-li-width;
|
|
||||||
width: $fa-li-width;
|
|
||||||
top: (2em / 14);
|
|
||||||
text-align: center;
|
|
||||||
&.#{$fa-css-prefix}-lg {
|
|
||||||
left: -$fa-li-width + (4em / 14);
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,60 +0,0 @@
|
|||||||
// Mixins
|
|
||||||
// --------------------------
|
|
||||||
|
|
||||||
@mixin fa-icon() {
|
|
||||||
display: inline-block;
|
|
||||||
font: normal normal normal #{$fa-font-size-base}/#{$fa-line-height-base} FontAwesome; // shortening font declaration
|
|
||||||
font-size: inherit; // can't have font-size inherit on line above, so need to override
|
|
||||||
text-rendering: auto; // optimizelegibility throws things off #1094
|
|
||||||
-webkit-font-smoothing: antialiased;
|
|
||||||
-moz-osx-font-smoothing: grayscale;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@mixin fa-icon-rotate($degrees, $rotation) {
|
|
||||||
-ms-filter: "progid:DXImageTransform.Microsoft.BasicImage(rotation=#{$rotation})";
|
|
||||||
-webkit-transform: rotate($degrees);
|
|
||||||
-ms-transform: rotate($degrees);
|
|
||||||
transform: rotate($degrees);
|
|
||||||
}
|
|
||||||
|
|
||||||
@mixin fa-icon-flip($horiz, $vert, $rotation) {
|
|
||||||
-ms-filter: "progid:DXImageTransform.Microsoft.BasicImage(rotation=#{$rotation}, mirror=1)";
|
|
||||||
-webkit-transform: scale($horiz, $vert);
|
|
||||||
-ms-transform: scale($horiz, $vert);
|
|
||||||
transform: scale($horiz, $vert);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// Only display content to screen readers. A la Bootstrap 4.
|
|
||||||
//
|
|
||||||
// See: http://a11yproject.com/posts/how-to-hide-content/
|
|
||||||
|
|
||||||
@mixin sr-only {
|
|
||||||
position: absolute;
|
|
||||||
width: 1px;
|
|
||||||
height: 1px;
|
|
||||||
padding: 0;
|
|
||||||
margin: -1px;
|
|
||||||
overflow: hidden;
|
|
||||||
clip: rect(0,0,0,0);
|
|
||||||
border: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Use in conjunction with .sr-only to only display content when it's focused.
|
|
||||||
//
|
|
||||||
// Useful for "Skip to main content" links; see http://www.w3.org/TR/2013/NOTE-WCAG20-TECHS-20130905/G1
|
|
||||||
//
|
|
||||||
// Credit: HTML5 Boilerplate
|
|
||||||
|
|
||||||
@mixin sr-only-focusable {
|
|
||||||
&:active,
|
|
||||||
&:focus {
|
|
||||||
position: static;
|
|
||||||
width: auto;
|
|
||||||
height: auto;
|
|
||||||
margin: 0;
|
|
||||||
overflow: visible;
|
|
||||||
clip: auto;
|
|
||||||
}
|
|
||||||
}
|
|