mirror of
https://github.com/placeAtlas/atlas.git
synced 2025-01-19 08:32:01 +01:00
commit
ca365b8177
16 changed files with 4548 additions and 2498 deletions
BIN
.DS_Store
vendored
BIN
.DS_Store
vendored
Binary file not shown.
|
@ -1,5 +1,11 @@
|
||||||
name: Validate JSON
|
name: Validate JSON
|
||||||
on: [push, pull_request]
|
on:
|
||||||
|
push:
|
||||||
|
paths:
|
||||||
|
- web/atlas.json
|
||||||
|
pull_request:
|
||||||
|
paths:
|
||||||
|
- web/atlas.json
|
||||||
jobs:
|
jobs:
|
||||||
Validate-JSON:
|
Validate-JSON:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
2
.gitignore
vendored
2
.gitignore
vendored
|
@ -10,3 +10,5 @@ oldusers.html
|
||||||
web/_js/minified.js
|
web/_js/minified.js
|
||||||
allCharacters.txt
|
allCharacters.txt
|
||||||
combined.js
|
combined.js
|
||||||
|
*.DS_Store
|
||||||
|
.vscode/
|
|
@ -1,4 +1,4 @@
|
||||||
# The Place Atlas
|
# The 2022 Place Atlas
|
||||||
The /r/place Atlas is a project aiming to catalog all the artworks created during Reddit's 2022 /r/place event.
|
The /r/place Atlas is a project aiming to catalog all the artworks created during Reddit's 2022 /r/place event.
|
||||||
This project was created by Roland Rytz and is licensed under the GNU Affero General Public License v3.0.
|
This project was created by Roland Rytz and is licensed under the GNU Affero General Public License v3.0.
|
||||||
|
|
||||||
|
@ -12,7 +12,7 @@ If you don't know GitHub and wanted to submit new entries or request changes to
|
||||||
|
|
||||||
### Map Contributions
|
### Map Contributions
|
||||||
|
|
||||||
<h4><b>WE ONLY ACCEPT NEW CONTRIBUTIONS ON REDDIT</b></h4>
|
**WE ONLY ACCEPT NEW CONTRIBUTIONS ON REDDIT!**
|
||||||
|
|
||||||
To contribute to the map, we require a certain format for artwork region and labels. This can be generated on the [contributing page](https://place-atlas.stefanocoding.me/index.html?mode=draw) on the website.
|
To contribute to the map, we require a certain format for artwork region and labels. This can be generated on the [contributing page](https://place-atlas.stefanocoding.me/index.html?mode=draw) on the website.
|
||||||
|
|
||||||
|
@ -40,4 +40,4 @@ To contribute to the map, we require a certain format for artwork region and lab
|
||||||
|
|
||||||
### Cleaning Contributions
|
### Cleaning Contributions
|
||||||
|
|
||||||
If you spot a duplicate, please PR against `/cleanup`. To help find duplicates, run the code locally, changing line 92 of `main.js` to `overlap`.
|
If you spot a duplicate, please PR against `/cleanup`. To help find duplicates, append `?mode=overlap` to the url: [`https://place-atlas.stefanocoding.me?mode=overlap`](https://place-atlas.stefanocoding.me?mode=overlap).
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
import praw
|
import praw
|
||||||
import json
|
import json
|
||||||
import time
|
import time
|
||||||
|
import re
|
||||||
|
|
||||||
outfile = open('temp_atlas.json', 'w', encoding='utf-8')
|
outfile = open('temp_atlas.json', 'w', encoding='utf-8')
|
||||||
failfile = open('manual_atlas.json', 'w', encoding='utf-8')
|
failfile = open('manual_atlas.json', 'w', encoding='utf-8')
|
||||||
|
@ -14,8 +15,9 @@ reddit = praw.Reddit(client_id=client_id, client_secret=client_secret, user_agen
|
||||||
|
|
||||||
failcount = 0
|
failcount = 0
|
||||||
successcount = 0
|
successcount = 0
|
||||||
|
totalcount = 0
|
||||||
|
|
||||||
jsonfile = open("../web/atlas.json", "r")
|
jsonfile = open("../web/atlas.json", "r", encoding='utf-8')
|
||||||
existing = json.load(jsonfile)
|
existing = json.load(jsonfile)
|
||||||
|
|
||||||
existing_ids = []
|
existing_ids = []
|
||||||
|
@ -51,7 +53,13 @@ for submission in reddit.subreddit('placeAtlas2').new(limit=2000):
|
||||||
break
|
break
|
||||||
if(submission.link_flair_text == "New Entry"):
|
if(submission.link_flair_text == "New Entry"):
|
||||||
text = submission.selftext
|
text = submission.selftext
|
||||||
text = text.replace("\\", "")
|
#Old backslash filter:
|
||||||
|
#text = text.replace("\\", "")
|
||||||
|
#New one: One \\ escapes a backslash in python's parser
|
||||||
|
# Two escape it again in the regex parser, so \\\\ is \
|
||||||
|
# Then anything but " or n is replaced with the first capture group (anything but " or n)
|
||||||
|
# Test in repl: re.sub("\\\\([^\"n])", "\\1", "\\t < removed slash, t stays and > stays \\n \\\"")
|
||||||
|
re.sub("\\\\([^\"n])", "\\1", text)
|
||||||
try:
|
try:
|
||||||
text = text.replace("\"id\": 0,", "\"id\": 0,\n\t\t\"submitted_by\": \""+submission.author.name+"\",")
|
text = text.replace("\"id\": 0,", "\"id\": 0,\n\t\t\"submitted_by\": \""+submission.author.name+"\",")
|
||||||
except AttributeError:
|
except AttributeError:
|
||||||
|
@ -66,10 +74,11 @@ for submission in reddit.subreddit('placeAtlas2').new(limit=2000):
|
||||||
text = "\n".join(lines)
|
text = "\n".join(lines)
|
||||||
try:
|
try:
|
||||||
outfile.write(json.dumps(json.loads(text))+",\n")
|
outfile.write(json.dumps(json.loads(text))+",\n")
|
||||||
|
successcount += 1
|
||||||
except json.JSONDecodeError:
|
except json.JSONDecodeError:
|
||||||
failfile.write(text+",\n")
|
failfile.write(text+",\n")
|
||||||
failcount += 1
|
failcount += 1
|
||||||
print("written "+submission.id+" submitted "+str(round(time.time()-submission.created_utc))+" seconds ago")
|
print("written "+submission.id+" submitted "+str(round(time.time()-submission.created_utc))+" seconds ago")
|
||||||
successcount += 1
|
totalcount += 1
|
||||||
|
|
||||||
print(f"\n\nSuccess: {successcount}\nFail: {failcount}\nPlease check manual_atlas.txt for failed entries to manually resolve.")
|
print(f"\n\nSuccess: {successcount}/{totalcount}\nFail: {failcount}/{totalcount}\nPlease check manual_atlas.txt for failed entries to manually resolve.")
|
||||||
|
|
38
tools/subreddit-format.py
Normal file
38
tools/subreddit-format.py
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
#!/usr/bin/python
|
||||||
|
|
||||||
|
import re
|
||||||
|
pattern1 = re.compile(r'"subreddit": "\/r\/(.+?)/?"')
|
||||||
|
pattern2 = re.compile(r'"subreddit": "r\/(.+?)/?"')
|
||||||
|
pattern3 = re.compile(r'"subreddit": "\/?r(?!\/)(.+?)/?"')
|
||||||
|
pattern4 = re.compile(r'"subreddit": "(?:(?:https:\/\/)?www.)?reddit.com\/r\/(.+?)(/[^"]*)*"')
|
||||||
|
pattern5 = re.compile(r'"subreddit": "\[(?:(?:https:\/\/)?www.)?reddit.com\/r\/(.+?)(/[^"]*)*\]\((?:(?:https:\/\/)?www.)?reddit.com\/r\/(.+?)(/[^"]*)*\)"')
|
||||||
|
|
||||||
|
def go(path):
|
||||||
|
|
||||||
|
with open(path, "r+", encoding='UTF-8') as f1:
|
||||||
|
contents = f1.read()
|
||||||
|
|
||||||
|
for match in pattern5.finditer(contents):
|
||||||
|
contents = contents.replace(match.group(0), '"subreddit": "r/' + match.group(2) + '"', 1)
|
||||||
|
|
||||||
|
for match in pattern4.finditer(contents):
|
||||||
|
contents = contents.replace(match.group(0), '"subreddit": "r/' + match.group(1) + '"', 1)
|
||||||
|
|
||||||
|
for match in pattern1.finditer(contents):
|
||||||
|
contents = contents.replace(match.group(0), '"subreddit": "r/' + match.group(1) + '"', 1)
|
||||||
|
|
||||||
|
for match in pattern2.finditer(contents):
|
||||||
|
contents = contents.replace(match.group(0), '"subreddit": "r/' + match.group(1) + '"', 1)
|
||||||
|
|
||||||
|
for match in pattern3.finditer(contents):
|
||||||
|
contents = contents.replace(match.group(0), '"subreddit": "r/' + match.group(1) + '"', 1)
|
||||||
|
|
||||||
|
# # r/... to /r/.. (comment if not needed)
|
||||||
|
for match in pattern2.finditer(contents):
|
||||||
|
contents = contents.replace(match.group(0), '"subreddit": "/r/' + match.group(1) + '"', 1)
|
||||||
|
|
||||||
|
with open(path, "w", encoding='UTF-8') as f2:
|
||||||
|
f2.write(contents)
|
||||||
|
|
||||||
|
go("../web/atlas.json")
|
||||||
|
go("../web/atlas-before-ids-migration.json")
|
|
@ -9,6 +9,6 @@ path = "./../web/atlas.json"
|
||||||
if (len(sys.argv) > 1):
|
if (len(sys.argv) > 1):
|
||||||
path = sys.argv[1]
|
path = sys.argv[1]
|
||||||
|
|
||||||
json.load(open(path))
|
json.load(open(path, "r", encoding='utf-8'))
|
||||||
|
|
||||||
print("JSON is valid")
|
print("JSON is valid")
|
BIN
web/.DS_Store
vendored
BIN
web/.DS_Store
vendored
Binary file not shown.
|
@ -168,6 +168,10 @@ header > a:hover {
|
||||||
color: #FFAA00;
|
color: #FFAA00;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
header h1 {
|
||||||
|
font-size: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
#logo {
|
#logo {
|
||||||
padding: 5px;
|
padding: 5px;
|
||||||
/*background-color: #FFF;*/
|
/*background-color: #FFF;*/
|
||||||
|
|
|
@ -4,7 +4,7 @@ function createInfoBlock(entry) {
|
||||||
|
|
||||||
let headerElement = document.createElement("h2");
|
let headerElement = document.createElement("h2");
|
||||||
let linkElement = document.createElement("a");
|
let linkElement = document.createElement("a");
|
||||||
linkElement.href = "?" + entry.id;
|
linkElement.href = "?id=" + entry.id;
|
||||||
linkElement.innerText = entry.name;
|
linkElement.innerText = entry.name;
|
||||||
headerElement.appendChild(linkElement);
|
headerElement.appendChild(linkElement);
|
||||||
|
|
||||||
|
|
|
@ -141,7 +141,7 @@ function initOverlap(){
|
||||||
if(args){
|
if(args){
|
||||||
id = args.split("id=")[1];
|
id = args.split("id=")[1];
|
||||||
if(id){
|
if(id){
|
||||||
id = parseInt(id.split("&")[0]);
|
id = id.split("&")[0];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -267,7 +267,7 @@ function initView(){
|
||||||
if(args){
|
if(args){
|
||||||
id = args.split("id=")[1];
|
id = args.split("id=")[1];
|
||||||
if(id){
|
if(id){
|
||||||
id = parseInt(id.split("&")[0]);
|
id = id.split("&")[0];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -280,7 +280,7 @@ function initView(){
|
||||||
if (entry.length === 1){
|
if (entry.length === 1){
|
||||||
entry = entry[0];
|
entry = entry[0];
|
||||||
|
|
||||||
document.title = entry.name + " on the /r/place Atlas";
|
document.title = entry.name + " on the 2022 /r/place Atlas";
|
||||||
|
|
||||||
var infoElement = createInfoBlock(entry);
|
var infoElement = createInfoBlock(entry);
|
||||||
objectsContainer.innerHTML = "";
|
objectsContainer.innerHTML = "";
|
||||||
|
@ -703,6 +703,8 @@ function initView(){
|
||||||
});
|
});
|
||||||
|
|
||||||
container.addEventListener("touchend", function(e){
|
container.addEventListener("touchend", function(e){
|
||||||
|
e.preventDefault()
|
||||||
|
|
||||||
//console.log(e);
|
//console.log(e);
|
||||||
//console.log(e.changedTouches[0].clientX);
|
//console.log(e.changedTouches[0].clientX);
|
||||||
if(e.changedTouches.length == 1){
|
if(e.changedTouches.length == 1){
|
||||||
|
|
|
@ -24,12 +24,12 @@
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<title>The /r/place Atlas</title>
|
<title>The 2022 /r/place Atlas</title>
|
||||||
|
|
||||||
<meta name="description" content="An Atlas of Reddit's /r/place, with information to each artwork of the canvas.">
|
<meta name="description" content="An Atlas of Reddit's /r/place, with information to each artwork of the canvas.">
|
||||||
<meta name="author" content="Roland Rytz">
|
<meta name="author" content="Roland Rytz">
|
||||||
<meta name="keywords" content="reddit, /r/place, april">
|
<meta name="keywords" content="reddit, /r/place, april">
|
||||||
<meta name="application-name" content="/r/place Atlas">
|
<meta name="application-name" content="2022 /r/place Atlas">
|
||||||
<meta name="robots" content="index, follow">
|
<meta name="robots" content="index, follow">
|
||||||
|
|
||||||
<meta name="viewport" content="width=device-width, height=device-height, initial-scale=1">
|
<meta name="viewport" content="width=device-width, height=device-height, initial-scale=1">
|
||||||
|
@ -41,7 +41,7 @@
|
||||||
<header class="aboutHeader">
|
<header class="aboutHeader">
|
||||||
<a href="./">
|
<a href="./">
|
||||||
<img id="logo" src="./_img/logo-100x100.png" height="50" width="50" alt="">
|
<img id="logo" src="./_img/logo-100x100.png" height="50" width="50" alt="">
|
||||||
<h1>The /r/place Atlas</h1>
|
<h1>The 2022 /r/place Atlas</h1>
|
||||||
</a>
|
</a>
|
||||||
<!--nav>
|
<!--nav>
|
||||||
<a id="viewLink" href="./" class="current">View</a>
|
<a id="viewLink" href="./" class="current">View</a>
|
||||||
|
@ -72,7 +72,7 @@
|
||||||
<img src="https://api.netlify.com/api/v1/badges/1e7291ce-0680-45ed-9843-47a32a992bbb/deploy-status" alt="Deploys by Netlify" />
|
<img src="https://api.netlify.com/api/v1/badges/1e7291ce-0680-45ed-9843-47a32a992bbb/deploy-status" alt="Deploys by Netlify" />
|
||||||
</a>
|
</a>
|
||||||
<br>
|
<br>
|
||||||
<h2 id="abouth2">The /r/place Atlas</h2>
|
<h2 id="abouth2">The 2022 /r/place Atlas</h2>
|
||||||
<p>This is an Atlas aiming to chart all the artworks created during the <a href="https://www.reddit.com/r/place/">/r/place</a> April's fools event on <a href="https://www.reddit.com/" target="_blank">Reddit</a> in 2022.</p>
|
<p>This is an Atlas aiming to chart all the artworks created during the <a href="https://www.reddit.com/r/place/">/r/place</a> April's fools event on <a href="https://www.reddit.com/" target="_blank">Reddit</a> in 2022.</p>
|
||||||
<p>The original code was developed by <a href="/" target="_blank" rel="author">Roland Rytz</a> (<a href="mailto:roland.rytz@gmail.com" target="_blank">mail</a>, <a href="https://reddit.com/user/draemmli/" target="_blank">reddit</a>) and is available under the free <a href="https://www.gnu.org/licenses/agpl-3.0.en.html" target="_blank">AGPL license</a> on <a target="_blank" href="https://github.com/RolandR/place-atlas">GitHub</a>.</p>
|
<p>The original code was developed by <a href="/" target="_blank" rel="author">Roland Rytz</a> (<a href="mailto:roland.rytz@gmail.com" target="_blank">mail</a>, <a href="https://reddit.com/user/draemmli/" target="_blank">reddit</a>) and is available under the free <a href="https://www.gnu.org/licenses/agpl-3.0.en.html" target="_blank">AGPL license</a> on <a target="_blank" href="https://github.com/RolandR/place-atlas">GitHub</a>.</p>
|
||||||
<br>
|
<br>
|
||||||
|
|
File diff suppressed because it is too large
Load diff
4443
web/atlas.json
4443
web/atlas.json
File diff suppressed because one or more lines are too long
|
@ -24,8 +24,8 @@
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<title>The /r/place Atlas</title>
|
<title>The 2022 /r/place Atlas</title>
|
||||||
<meta name="description" content="An interactive map of Reddit's /r/place, with information to each artwork of the canvas.">
|
<meta name="description" content="An interactive map of Reddit's 2022 /r/place, with information to each artwork of the canvas.">
|
||||||
<meta name="author" content="Roland Rytz (2022 by Stefano#7366)">
|
<meta name="author" content="Roland Rytz (2022 by Stefano#7366)">
|
||||||
<meta name="keywords" content="reddit, /r/place 2022">
|
<meta name="keywords" content="reddit, /r/place 2022">
|
||||||
<meta name="application-name" content="The /r/place Atlas 2022">
|
<meta name="application-name" content="The /r/place Atlas 2022">
|
||||||
|
@ -42,7 +42,7 @@
|
||||||
{
|
{
|
||||||
"@context": "http://schema.org",
|
"@context": "http://schema.org",
|
||||||
"@type": "WebSite",
|
"@type": "WebSite",
|
||||||
"name": "The /r/place Atlas",
|
"name": "The 2022 /r/place Atlas",
|
||||||
"url": "http://place-atlas.stefanocoding.me/",
|
"url": "http://place-atlas.stefanocoding.me/",
|
||||||
"author": {
|
"author": {
|
||||||
"@type": "Person",
|
"@type": "Person",
|
||||||
|
|
Loading…
Add table
Reference in a new issue