-
Notifications
You must be signed in to change notification settings - Fork 0
/
jobs.html
363 lines (363 loc) · 22.3 KB
/
jobs.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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
<!DOCTYPE html><!-- Last Published: Fri Sep 27 2024 11:36:14 GMT+0000 (Coordinated Universal Time) -->
<html data-wf-page="6552fb3037d5a3d3de283ff8" data-wf-site="65380b51b01b69a63d681e04">
<head>
<meta charset="utf-8">
<title>Jobs – AISafety.com</title>
<meta content="Jobs – AISafety.com" property="og:title">
<meta content="Jobs – AISafety.com" property="twitter:title">
<meta content="width=device-width, initial-scale=1" name="viewport">
<link href="css/normalize.css" rel="stylesheet" type="text/css">
<link href="css/webflow.css" rel="stylesheet" type="text/css">
<link href="css/sacreddesign-e06ccbb898ec7f5290b6edbfa8.webflow.css" rel="stylesheet" type="text/css">
<link href="https://fonts.googleapis.com" rel="preconnect">
<link href="https://fonts.gstatic.com" rel="preconnect" crossorigin="anonymous">
<script src="https://ajax.googleapis.com/ajax/libs/webfont/1.6.26/webfont.js" type="text/javascript"></script>
<script type="text/javascript">WebFont.load({ google: { families: ["Inter:100,200,300,regular,500,600,700,800,900"] }});</script>
<script type="text/javascript">!function(o,c){var n=c.documentElement,t=" w-mod-";n.className+=t+"js",("ontouchstart"in o||o.DocumentTouch&&c instanceof DocumentTouch)&&(n.className+=t+"touch")}(window,document);</script>
<link href="images/favicon.png" rel="shortcut icon" type="image/x-icon">
<link href="images/webclip.png" rel="apple-touch-icon"><!-- Matomo -->
<script>
var _paq = window._paq = window._paq || [];
/* tracker methods like "setCustomDimension" should be called before "trackPageView" */
_paq.push(["disableCookies"]);
_paq.push(['trackPageView']);
_paq.push(['enableLinkTracking']);
(function() {
var u="https://aisafety.matomo.cloud/";
_paq.push(['setTrackerUrl', u+'matomo.php']);
_paq.push(['setSiteId', '1']);
var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0];
g.async=true; g.src='https://cdn.matomo.cloud/aisafety.matomo.cloud/matomo.js'; s.parentNode.insertBefore(g,s);
})();
</script>
<!-- End Matomo Code -->
<!-- [Attributes by Finsweet] CMS Load -->
<script async="" src="https://cdn.jsdelivr.net/npm/@finsweet/attributes-cmsload@1/cmsload.js"></script>
</head>
<body>
<div class="w-embed">
<style>
.truncate { text-overflow: ellipsis; }
</style>
</div>
<div id="nav" data-animation="default" data-collapse="all" data-duration="400" data-easing="ease" data-easing2="ease" role="banner" class="nav w-nav">
<div class="nav-container">
<a href="index.html" class="w-inline-block">
<h2>AISafety.com</h2>
</a>
<div class="nav-container-button hover-opacity w-nav-button"><img src="images/Menu-WHITE-RESIZED.svg" loading="lazy" alt="" class="image-3"></div>
</div>
<nav role="navigation" class="nav-menu padding-top-80px w-nav-menu">
<div class="container-default padding-128px w-container">
<div class="w-layout-grid grid-4-4-4 padding-56px mobile">
<a id="w-node-_22578ad6-1bf1-a944-da59-8cf47cf10d9b-e25e99d3" href="courses.html" class="landing-resource_card_flex w-inline-block"><img src="images/book.svg" loading="lazy" id="w-node-_22578ad6-1bf1-a944-da59-8cf47cf10d9c-e25e99d3" alt="">
<div>
<p class="paragraph-large-bold padding-16px">Courses</p>
<p>Curricula and reading lists for self-led learning at all levels</p>
</div>
</a>
<a id="w-node-_22578ad6-1bf1-a944-da59-8cf47cf10da2-e25e99d3" href="communities.html" class="landing-resource_card_flex w-inline-block"><img src="images/people.svg" loading="lazy" id="w-node-_22578ad6-1bf1-a944-da59-8cf47cf10da3-e25e99d3" alt="">
<div>
<p class="paragraph-large-bold padding-16px">Communities</p>
<p>Local and online groups – including forums, Facebook, Slack, and Discord</p>
</div>
</a>
<a id="w-node-_22578ad6-1bf1-a944-da59-8cf47cf10da9-e25e99d3" href="projects.html" class="landing-resource_card_flex w-inline-block"><img src="images/building-blocks.svg" loading="lazy" id="w-node-_22578ad6-1bf1-a944-da59-8cf47cf10daa-e25e99d3" alt="">
<div>
<p class="paragraph-large-bold padding-16px">Projects</p>
<p>Online initiatives seeking your volunteer help – all skill levels welcome</p>
</div>
</a>
</div>
<div class="w-layout-grid grid-4-4-4 padding-56px mobile">
<a id="w-node-_22578ad6-1bf1-a944-da59-8cf47cf10dc7-e25e99d3" href="jobs.html" aria-current="page" class="landing-resource_card_flex w-inline-block w--current"><img src="images/briefcase.svg" loading="lazy" id="w-node-_22578ad6-1bf1-a944-da59-8cf47cf10dc8-e25e99d3" alt="">
<div>
<p class="paragraph-large-bold padding-16px">Jobs</p>
<p>A list of all current open positions in AI Safety</p>
</div>
</a>
<a id="w-node-_22578ad6-1bf1-a944-da59-8cf47cf10dce-e25e99d3" href="events-and-training.html" class="landing-resource_card_flex w-inline-block"><img src="images/calendar.svg" loading="lazy" id="w-node-_22578ad6-1bf1-a944-da59-8cf47cf10dcf-e25e99d3" alt="">
<div>
<p class="paragraph-large-bold padding-16px">Events & training</p>
<p>Gatherings and training programs, both online and in-person</p>
</div>
</a>
<a id="w-node-_22578ad6-1bf1-a944-da59-8cf47cf10dd5-e25e99d3" href="funders.html" class="landing-resource_card_flex w-inline-block"><img src="images/piggy-bank.svg" loading="lazy" id="w-node-_22578ad6-1bf1-a944-da59-8cf47cf10dd6-e25e99d3" alt="">
<div>
<p class="paragraph-large-bold padding-16px">Funders</p>
<p>Organizations providing financial support for your projects</p>
</div>
</a>
</div>
<div class="w-layout-grid grid-4-4-4 padding-80px">
<a id="w-node-_22578ad6-1bf1-a944-da59-8cf47cf10ddd-e25e99d3" href="landscape-map.html" class="landing-resource_card_flex w-inline-block"><img src="images/map.svg" loading="lazy" id="w-node-_22578ad6-1bf1-a944-da59-8cf47cf10dde-e25e99d3" alt="">
<div>
<p class="paragraph-large-bold padding-16px">Landscape map</p>
<p>An overview of the organizations, programs, and projects in the AI Safety space</p>
</div>
</a>
<a id="w-node-_22578ad6-1bf1-a944-da59-8cf47cf10de4-e25e99d3" href="https://aisafety.info/questions/9OGZ/" target="_blank" class="landing-resource_card_flex w-inline-block"><img src="images/letters.svg" loading="lazy" id="w-node-_22578ad6-1bf1-a944-da59-8cf47cf10de5-e25e99d3" alt="">
<div>
<p class="paragraph-large-bold padding-16px">AI Safety guide</p>
<p>A comprehensive introduction to AI Safety, written and curated by our team and affiliates</p>
</div>
</a>
<a id="w-node-_22578ad6-1bf1-a944-da59-8cf47cf10deb-e25e99d3" href="donation-guide.html" class="landing-resource_card_flex w-inline-block"><img src="images/hand.svg" loading="lazy" id="w-node-_22578ad6-1bf1-a944-da59-8cf47cf10dec-e25e99d3" alt="">
<div>
<p class="paragraph-large-bold padding-16px">Donation guide</p>
<p>How to donate most effectively with the funding and time you have</p>
</div>
</a>
</div>
<div class="w-layout-grid grid-4-4-4">
<div>
<p class="padding-32px">We're a global team of volunteers from various disciplines who believe AI poses a grave risk of extinction to humanity.</p>
<a href="about.html" class="paragraph-default-bold hover-opacity">Learn more about us <span class="color-grey">→</span></a>
</div>
</div>
</div>
</nav>
</div>
<div class="container-default w-container">
<h1 class="padding-80px padding-top-80px">Jobs</h1>
<div id="w-node-_8ee9fb2c-3ce6-1d79-f3c9-fae1eff07e20-de283ff8" class="hide-desktop">
<div id="Last-update" class="text-block-10">.</div>
</div>
<div class="w-layout-grid database-outer_grid padding-128px">
<div>
<div class="form-block padding-56px w-form">
<form id="wf-form-Search-bar" name="wf-form-Search-bar" data-name="Search bar" action="http://#" method="get" data-wf-page-id="6552fb3037d5a3d3de283ff8" data-wf-element-id="cb19c4f6-09cb-e55a-bffd-3dad2837fc0b"><input class="text_field w-input" maxlength="256" name="search-bar" data-name="search-bar" placeholder="Search jobs by title or description" type="text" id="search-bar"></form>
<div class="w-form-done">
<div>Thank you! Your submission has been received!</div>
</div>
<div class="w-form-fail">
<div>Oops! Something went wrong while submitting the form.</div>
</div>
</div>
<div class="w-dyn-list">
<div fs-cmsload-element="list" fs-cmsload-mode="render-all" fs-cmsload-resetix="true" role="list" class="collection_list w-dyn-items">
<div role="listitem" class="collection-item w-dyn-item">
<a href="#" class="w-inline-block">
<div data-modified="" data-widget="job-card" data-title="" data-experience="" data-description="" data-org="" data-location="" class="elevation padding-2-34vw card">
<div class="w-layout-hflex database-image_title_flex padding-24px">
<div class="database-img"><img src="https://d3e54v103j8qbb.cloudfront.net/plugins/Basic/assets/placeholder.60f9b1840c.svg" loading="lazy" alt="" class="image-7 w-dyn-bind-empty"></div>
<div>
<p data-field="title" class="paragraph-default-bold padding-4px w-dyn-bind-empty"></p>
<p data-field="status" class="paragraph-small-bold color-grey w-dyn-bind-empty"></p>
</div>
</div>
<p class="paragraph-small-bold padding-4px">Location</p>
<p data-field="status" class="paragraph-small padding-16px w-dyn-bind-empty"></p>
<p class="paragraph-small-bold padding-4px">Minimum experience</p>
<p data-field="status" class="paragraph-small w-dyn-bind-empty"></p>
</div>
</a>
</div>
</div>
<div class="w-dyn-empty">
<div>No items found.</div>
</div>
<div role="navigation" aria-label="List" class="w-pagination-wrapper">
<a href="#" aria-label="Previous Page" class="w-pagination-previous"><svg class="w-pagination-previous-icon" height="12px" width="12px" xmlns="http://www.w3.org/2000/svg" viewbox="0 0 12 12" transform="translate(0, 1)">
<path fill="none" stroke="currentColor" fill-rule="evenodd" d="M8 10L4 6l4-4"></path>
</svg>
<div class="w-inline-block">Previous</div>
</a>
<a href="#" aria-label="Next Page" class="w-pagination-next">
<div class="w-inline-block">Next</div><svg class="w-pagination-next-icon" height="12px" width="12px" xmlns="http://www.w3.org/2000/svg" viewbox="0 0 12 12" transform="translate(0, 1)">
<path fill="none" stroke="currentColor" fill-rule="evenodd" d="M4 2l4 4-4 4"></path>
</svg>
</a>
</div>
</div>
</div>
<div>
<div class="hide-mobile">
<div id="Last-update2" class="text-block-4">.</div>
<div data-widget="search-option" class="form_block padding-80px w-form">
<form id="wf-form-experience" name="wf-form-experience" data-name="experience" method="get" data-wf-page-id="6552fb3037d5a3d3de283ff8" data-wf-element-id="23209b6a-923f-cca8-eab2-674d1b8bdb8c"><label for="name-3" class="paragraph-small-bold padding-24px">Minimum experience</label><label class="w-checkbox checkbox_field padding-16px">
<div class="w-checkbox-input w-checkbox-input--inputType-custom checkbox"></div><input type="checkbox" name="Entry-level" id="Entry-level" data-name="Entry level" style="opacity:0;position:absolute;z-index:-1"><span class="paragraph-small w-form-label" for="Entry-level">Entry</span>
</label><label class="w-checkbox checkbox_field padding-16px">
<div class="w-checkbox-input w-checkbox-input--inputType-custom checkbox"></div><input type="checkbox" name="Junior-1-4-years-experience" id="Junior-1-4-years-experience" data-name="Junior (1–4 years experience)" style="opacity:0;position:absolute;z-index:-1"><span class="paragraph-small w-form-label" for="Junior-1-4-years-experience">Junior (1–4 years experience)</span>
</label><label class="w-checkbox checkbox_field padding-16px">
<div class="w-checkbox-input w-checkbox-input--inputType-custom checkbox"></div><input type="checkbox" name="Mid-5-9-years-experience" id="Mid-5-9-years-experience" data-name="Mid (5–9 years experience)" style="opacity:0;position:absolute;z-index:-1"><span class="paragraph-small w-form-label" for="Mid-5-9-years-experience">Mid (5–9 years experience)</span>
</label><label class="w-checkbox checkbox_field padding-16px">
<div class="w-checkbox-input w-checkbox-input--inputType-custom checkbox"></div><input type="checkbox" name="Senior-10-years-experience" id="Senior-10-years-experience" data-name="Senior (10+ years experience)" style="opacity:0;position:absolute;z-index:-1"><span class="paragraph-small w-form-label" for="Senior-10-years-experience">Senior (10+ years experience)</span>
</label><label class="w-checkbox checkbox_field checkbox-field">
<div class="w-checkbox-input w-checkbox-input--inputType-custom checkbox"></div><input id="Multiple-experience-levels" type="checkbox" name="Multiple-experience-levels" data-name="Multiple experience levels" style="opacity:0;position:absolute;z-index:-1"><span class="paragraph-small w-form-label" for="Multiple-experience-levels">Multiple experience levels</span>
</label></form>
<div class="w-form-done">
<div>Thank you! Your submission has been received!</div>
</div>
<div class="w-form-fail">
<div>Oops! Something went wrong while submitting the form.</div>
</div>
</div>
<p class="paragraph-small-bold padding-24px color-grey">Related resources</p>
<a href="funders.html" class="hover-opacity padding-40px w-inline-block">
<p class="paragraph-default-bold padding-16px">Funders <span class="color-grey">→</span></p>
<p>Organizations providing financial support for your projects</p>
</a>
<a href="https://jobs.80000hours.org/?refinementList%5Btags_area%5D%5B0%5D=AI%20safety%20%26%20policy" target="_blank" class="hover-opacity w-inline-block">
<div class="flex-horizontal_center">
<p class="paragraph-default-bold padding-16px">80,000 Hours job board <span class="color-grey">→</span></p>
</div>
<p class="paragraph-on-side">Regularly-updated database of fellowships, internships, jobs, and funding sources</p>
</a>
</div>
</div>
</div>
<div id="w-node-_817fb4d4-c1b5-45fc-c567-dc8efa20e6de-de283ff8" class="w-embed w-script">
<script>
let dataWidgetCard = "job-card";
const normalizeCards = () => {
document.querySelectorAll(`[data-widget="${dataWidgetCard}"]`).forEach(card => {
if (card.dataset.experience) {
card.dataset.experience = normalize(card.dataset.experience);
}
});
};
const updateLastUpdatedOn = () => {
let lastUpdated = new Date(0);
document.querySelectorAll(`[data-widget="${dataWidgetCard}"]`).forEach(card => {
if (card.dataset.modified) {
const cardDate = new Date(card.dataset.modified);
if (cardDate > lastUpdated) {
lastUpdated = cardDate;
}
}
});
const options = { day: 'numeric', month: 'long', year: 'numeric' };
const formattedDate = new Intl.DateTimeFormat('en-GB', options).format(lastUpdated);
const lastUpdateElement = document.getElementById("Last-update");
if (lastUpdateElement) {
lastUpdateElement.textContent = `Last updated on: ${formattedDate}`;
}
const lastUpdateElement2 = document.getElementById("Last-update2");
if (lastUpdateElement2) {
lastUpdateElement2.textContent = `Last updated on: ${formattedDate}`;
}
};
const connectLinks = () => {
document.querySelectorAll(`[data-widget="${dataWidgetCard}"]`).forEach(card => {
if(!!(card.dataset.vacancyPage || '').trim()) {
card.parentElement.setAttribute('href', card.dataset.vacancyPage);
}
});
};
const checkCardConsistent = (card) => {
if (!card.dataset.title || !card.dataset.experience){
console.log("Incomplete card not shown:", card);
return false;
}
return true;
};
const noExperienceFilter = (settings) => {
return !settings.experience || settings.experience.length === 0;
};
const checkExperience = (settings, card) => {
return noExperienceFilter(settings) || settings.experience.includes(card.dataset.experience);
};
const shouldCardBeShown = (settings, card) => {
return (
checkCardConsistent(card) &&
checkSearchPhrase(settings, card) &&
checkExperience(settings, card)
);
};
const checkSearchPhrase = (settings, card) => {
return (
card.dataset.title.toLowerCase().includes(settings.searchPhrase.toLowerCase()) ||
card.dataset.location.toLowerCase().includes(settings.searchPhrase.toLowerCase()) ||
card.dataset.org.toLowerCase().includes(settings.searchPhrase.toLowerCase())
);
};
// ********* CARD-SPECIFIC CODE ABOVE | GENERAL CODE BELOW *********
const filterResults = (settings) => {
if (!settings) {
console.log("No settings provided!");
return;
}
let visibleCount = 0;
let hiddenCount = 0;
document.querySelectorAll(`[data-widget="${dataWidgetCard}"]`).forEach(card => {
if (shouldCardBeShown(settings, card)) {
card.parentElement.parentElement.style.display = 'inherit';
visibleCount++;
} else {
card.parentElement.parentElement.style.display = 'none';
hiddenCount++;
}
});
console.log(`Filter Results: ${visibleCount} cards shown, ${hiddenCount} cards hidden`);
};
const normalize = (v) => v.toLowerCase().replaceAll(' ', '-').replaceAll('+', '').replaceAll('–', '-').replaceAll('(','').replaceAll(')','').trim();
const getSettings = () => Array.from(document.querySelectorAll('[data-widget="search-option"] form'))
.reduce((options, optionsBlock) => {
const name = optionsBlock.dataset.name;
options[name] = Array.from(optionsBlock.getElementsByTagName('input'))
.filter(i => i.previousSibling.classList.contains('w--redirected-checked'))
.map(i => normalize(i.name));
return options;
}, {searchPhrase: document.getElementsByName('search-bar')[0]?.value || ''});
const checkboxEventListener = (elem) => {
elem.addEventListener('click', (e) => setTimeout(() => filterResults(getSettings()), 100))
}
document.querySelectorAll('[data-widget="search-option"] form .w-checkbox-input').forEach(checkboxEventListener)
document.querySelectorAll('[data-widget="search-option"] form input').forEach(checkboxEventListener)
document.querySelector('input[name="search-bar"]').addEventListener('input', () => filterResults(getSettings()))
document.querySelector('form[data-name="Search bar"]').addEventListener('submit', (e) => e.preventDefault())
document.addEventListener('DOMContentLoaded', () => {
normalizeCards();
updateLastUpdatedOn();
filterResults(getSettings());
connectLinks();
});
</script>
</div>
</div>
<div>
<div class="div-divider margin-128px"></div>
<div class="container-narrow w-container">
<div class="w-layout-grid footer padding-128px">
<div>
<h2 class="padding-24px">AISafety.com</h2>
<p class="padding-32px">We're a global team of volunteers and professionals from various disciplines who believe AI poses a grave risk of extinction to humanity.</p>
<div class="flex-horizontal_center">
<a href="about.html" class="paragraph-default-bold hover-opacity">Learn more about us <span class="color-grey">→</span></a>
</div>
</div>
<div>
<p class="paragraph-default-bold padding-24px">Partner projects</p>
<a id="w-node-f9b61385-475d-dbea-5f27-70388aa7c4fc-8aa7c4ed" href="https://aisafety.info/" target="_blank" class="padding-8px">AISafety.info</a>
<a href="https://alignment.dev/" target="_blank">Alignment Ecosystem Development</a>
<p class="paragraph-default-bold padding-24px padding-above">Suggestions</p>
<p class="padding-32px">Please contact us <a href="https://discord.gg/WQG8FAGqun" target="_blank" class="inline color-white">via Discord</a> to propose additions, corrections, or improvements.</p>
</div>
</div>
<p class="paragraph-small centered_text padding-16px">(ɔ) 2024 · This site is released under a CC BY-SA license</p>
</div>
</div>
<a href="#nav" data-w-id="7eb0a381-c248-7943-2c08-01c173293d7b" class="up-button w-button">⌃</a>
<script src="https://d3e54v103j8qbb.cloudfront.net/js/jquery-3.5.1.min.dc5e7f18c8.js?site=65380b51b01b69a63d681e04" type="text/javascript" integrity="sha256-9/aliU8dGd2tb6OSsuzixeV4y/faTqgFtohetphbbj0=" crossorigin="anonymous"></script>
<script src="js/webflow.js" type="text/javascript"></script>
<script>
window.onload = function() {
// Get all elements with class "card"
var cards = document.querySelectorAll('.card');
// Function to set height for elements in a NodeList
function setEqualHeight(elements) {
var maxHeight = 0;
elements.forEach(function(element) {
maxHeight = Math.max(maxHeight, element.offsetHeight);
});
elements.forEach(function(element) {
element.style.height = maxHeight + 'px';
});
}
// Set equal height for cards
setEqualHeight(cards);
};
</script>
</body>
</html>