You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

199 lines
7.9 KiB
Python

9 years ago
#! /usr/bin/env python
# -*- coding: utf-8 -*-
import xml.etree.ElementTree as ET
import html5lib, urllib, pprint
from mmdc_modules import pandoc2html, parse_work, write_html_file, mw_cats, mw_page_imgsurl, mw_img_url, mw_page_text, mwsite, mw_page_cats, mw_page, remove_cats, find_authors, replace_video, replace_img_a_tag, index_addwork
from argparse import ArgumentParser
from random import shuffle
9 years ago
### WORKINGS ####
# * each year has its own html template in YYYY-template.html
# * the --category provides the year. I.e. 2017
#
#
#
################
7 years ago
### TO DO ######
# * [DONE] in def mw_cats(): select pages member of the years from 2015 to the indicate year
# ** [DONE] resulting in all work pages from those year being created
# ** [DONE] the creation of the index pages is missing
#
# Issues @current commit
# * index.html page contains ALL works from ALL years, not just the last
# * year.html contain none
#
# indexdict = create_page(memberpages, 'index') # X indexdict includes only set year
# and # create_index(indexdict)
# * update/create index pages:
#
# * let program define year
#
7 years ago
# * For different user categories serve different templates
# * how & why are years and works mixed??
7 years ago
#########
9 years ago
#####
# Args
####
p = ArgumentParser()
p.add_argument("--host", default="pzwiki.wdka.nl")
p.add_argument("--path", default="/mw-mediadesign/", help="nb: should end with /")
p.add_argument("--category", "-c", nargs="*", default=["2017"], help="category to query, use -c foo bar to intersect multiple categories")
9 years ago
p.add_argument("--preview", help='Preview page. Will override category querying. Use: --page "Name Of Wiki Page"')
9 years ago
9 years ago
args = p.parse_args()
print 'args', args
for i in args.category:
8 years ago
if '20' in i:
global year
8 years ago
year = i
print year
8 years ago
9 years ago
######
# DEFS: create_page create_index
######
def create_page(memberpages, mode):
page_template = open("./{}-template.html".format(year), "r") # a template for each year
9 years ago
indexdict = {} #parent dict: contains articledict instances
for member in memberpages:
print member
page = mw_page(site, member)
page_text = mw_page_text(site, page)
9 years ago
articledict = parse_work(site, member, page_text) # create dictionary
# Title, Creator, Date, Website, Thumbnail, Bio, Description, Extra
9 years ago
if len(articledict['Creator'])>0 and len(articledict['Title'])>0 and len(articledict['Thumbnail'])>0:
9 years ago
for key in articledict.keys():
9 years ago
if key in ['Extra', 'Description', 'Bio']:
articledict[key] = pandoc2html(articledict[key])
elif key in ['Creator']:
articledict[key] = articledict[key].replace(',','' )
elif key in ['Content']:
articledict[key] = remove_cats(articledict['Content'])
articledict[key] = replace_video(articledict['Content'])
9 years ago
articledict['Imgs'] = mw_page_imgsurl(site, page, articledict['Thumbnail'] )
#pprint.pprint( articledict)
9 years ago
page_tree = html5lib.parse(page_template, namespaceHTMLElements=False)
page_title = page_tree.find('.//title')
page_title.text=articledict['Title']#.decode('utf-8')
page_creator = page_tree.find('.//h2[@id="creator"]')
page_creator.text=(articledict['Creator'])
page_title_date = page_tree.find('.//p[@id="title"]')
page_title_date.text=u"{} {}".format(articledict['Title'], articledict['Date'])
page_description = page_tree.find('.//div[@id="description"]')
page_description_el = ET.fromstring('<div>'+articledict['Description'].encode('utf-8')+'</div>')
page_description.extend(page_description_el)
page_bio = page_tree.find('.//div[@id="bio"]')
page_bio_el = ET.fromstring('<div>'+articledict['Bio'].encode('utf-8')+'</div>')
page_bio.extend(page_bio_el)
page_sortArea_title = page_tree.find('.//div[@id="sortArea"]/p')
page_sortArea_title.text =articledict['Title']
page_extra = page_tree.find('.//div[@id="extra"]')
page_extra_el = ET.fromstring('<div>'+articledict['Extra'].encode('utf-8')+'</div>')
page_extra.extend(page_extra_el)
page_website = page_tree.find('.//p[@class="hightlightSidebar"]/a')
page_website.set('href', articledict['Website'])
9 years ago
page_website.text=articledict['Website']
9 years ago
page_thumb = page_tree.find('.//img[@id="thumbnail"]')
page_thumb.set('src', articledict['Thumbnail'])
#print
#print ET.tostring(page_tree)
#print
9 years ago
figures = page_tree.findall('.//figure')
images = page_tree.findall('.//img')
#print 'Number of imgs:', len(images)
9 years ago
if len(figures) > 0:
#print 'figures', figures
for figure in figures:
img = figure.find('.//img')
figcaption = figure.find('.//figcaption')
img_src = img.get('src')
#print img_src
figcaption_text = figcaption.text
if figcaption_text == img_src:# remove figcation if == src
figure.remove(figcaption)
9 years ago
src = (('File:'+img_src).capitalize()).decode('utf-8')
if src in articledict['Imgs'].keys(): #full-url
url = (articledict['Imgs'][src])
#print url
img.set('src', url)
else:
for img in images:
img_src = img.get('src')
print img_src
src = (('File:'+img_src).capitalize()).decode('utf-8')
pprint.pprint(articledict)
if src in articledict['Imgs'].keys(): #full-url
url = (articledict['Imgs'][src])
#print url
img.set('src', url)
#print ET.tostring(img)
img.set('title', (img.get('title').replace('fig:','')) )
9 years ago
# save work page
creator = articledict['Creator'].encode('ascii', 'ignore')
creator = creator.replace(' ','_')
8 years ago
work_filename = 'web/works/{}-{}.html'.format(year, creator)
9 years ago
write_html_file(page_tree, work_filename)
articledict['Path'] = work_filename[4:]
indexdict[articledict['Title']] = articledict
return indexdict
def create_index(indexdict):
index_template = open("./index-template-{}.html".format(year), "r")
9 years ago
index_tree = html5lib.parse(index_template, namespaceHTMLElements=False)
index_container = index_tree.find(".//div[@class='isotope']") #maybe id is imp
keys = indexdict.keys()
shuffle(keys)
8 years ago
for key in keys:
9 years ago
index_addwork( parent=index_container,
workid=key,
href=indexdict[key]['Path'],
title=indexdict[key]['Title'],#.decode('utf-8'),
creator=indexdict[key]['Creator'],
8 years ago
date=indexdict[key]['Date'],
thumbnail=(indexdict[key]['Thumbnail'])
9 years ago
)
#print '----', indexdict[key]['Title'],indexdict[key]['Path']
indexfile_year = './web/{}.html'.format(year)
indexfile = './web/index.html'
print indexfile_year
write_html_file(index_tree, indexfile_year)
# only for last year
write_html_file(index_tree, indexfile)
9 years ago
#####
# ACTION
#####
site = mwsite(args.host, args.path)
if args.preview is not None:
print "** Page Preview Mode**"
9 years ago
memberpages = [(args.preview).decode('utf-8')]
9 years ago
print 'memberpages:', memberpages
create_page(memberpages, 'preview')
else:
print "** New Index Mode **"
memberpages=mw_cats(site, args)
print '\n\nmemberpages:\n\n', memberpages, '\n\n********\n\n' # X memberpages includes only set year
indexdict = create_page(memberpages, 'index') # X indexdict includes only set year
9 years ago
create_index(indexdict)
print
print '******************'
print
pprint.pprint(indexdict)
9 years ago