-
Notifications
You must be signed in to change notification settings - Fork 38
/
Copy pathpage_members.html
91 lines (85 loc) · 3.26 KB
/
page_members.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
---
layout: page
title: Members
permalink: /members
---
{% assign total_members = site.data.members | size %}
{% assign members = site.data.members | sort: "last_name" %}
{% assign total_countries = site.data.members | map: "country" | join: "," | split: "," | uniq | size %}
{% assign countries = site.data.members | map: "country" | join: "," | split: "," | uniq %}
<div class="row justify-content-center mb-4 pb-5">
<div class="col-md-7 text-center heading-section ftco-animate">
<span class="subheading">The Workflows Community Initiative Currently has <strong>{{total_members}}</strong>
Members from <strong>{{total_countries}} countries</strong></span>
<h2 class="mb-4">Members</h2>
<p>
<a href="https://forms.gle/ihiyRoZJMYeWXJid6" target="_blank" class="btn btn-primary mt-3 py-3 px-5">
Become a Member <span style="font-size: 0.8em"><i>(free)</i></span>
</a>
</p>
</div>
</div>
<div id='map' style='width: 100%; height: 400px; border-radius: 0.5em; margin: 0'></div>
<script src="https://unpkg.com/@mapbox/mapbox-sdk/umd/mapbox-sdk.min.js"></script>
<script>
// mapboxgl.accessToken = 'pk.eyJ1Ijoic2lsdmFyZiIsImEiOiJjbDA2MG5wOGwwZXNsM2lvNXh4YmdwZm1oIn0.n0wDQhuZvZY_8obY5p8LlA';
mapboxgl.accessToken = 'pk.eyJ1Ijoid29ya2Zsb3dzY2kiLCJhIjoiY2xlbGxlMHo5MGNodjQzbWpyeGt0dHF3ZCJ9.PPzOg0Nmk3nWg38gxf8cow';
const mapboxClient = mapboxSdk({ accessToken: mapboxgl.accessToken });
var countries = [];
{% for country in countries %}
mapboxClient.geocoding
.forwardGeocode({
query: '{{country}}',
autocomplete: false,
countries: ['{{country}}'],
limit: 1
})
.send()
.then((response) => {
const feature = response.body.features[0];
countries.push(feature.matching_text.toString());
});
{% endfor %}
const map = new mapboxgl.Map({
container: 'map',
style: 'mapbox://styles/mapbox/light-v11',
center: [0, 20],
zoom: 0.5
});
map.addControl(new mapboxgl.FullscreenControl());
map.addControl(new mapboxgl.NavigationControl());
map.on('load', function () {
map.addLayer(
{
id: 'country-boundaries',
source: {
type: 'vector',
url: 'mapbox://mapbox.country-boundaries-v1',
},
'source-layer': 'country_boundaries',
type: 'fill',
paint: {
'fill-color': '#614385',
'fill-opacity': 0.4,
},
},
'country-label'
);
const header = ["in", "iso_3166_1"];
const filter = [...header, ...countries];
map.setFilter('country-boundaries', filter);
});
</script>
<br />
<div class="row">
{% for member in members %}
<div class="col-sm-6 col-md-4 col-lg-4 mb-5">
<a href="{{member.link}}" target="_blank" class="member">
<div class="member-contents">
{{member.first_name}} {{member.last_name}}<br />
<span style="color: #aaa; font-size: 0.8em">{{member.institution}}</span><br />
</div>
</a>
</div>
{% endfor %}
</div>