weboob-devel/modules/champslibres/pages.py
2012-03-16 00:49:48 +01:00

71 lines
2.1 KiB
Python

# -*- coding: utf-8 -*-
# Copyright(C) 2012 Florent Fourcot
#
# This file is part of weboob.
#
# weboob is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# weboob is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from datetime import date
from weboob.capabilities.library import Book
from weboob.tools.browser import BasePage
class SkipPage(BasePage):
pass
class HomePage(BasePage):
def on_loaded(self):
link = self.document.find('//a[@id="patronRSSFeedLinkComponent"]')
self.id = link.attrib['href'].split('/')[4]
def get_id(self):
return self.id
def txt2date(s):
split = s.split('-')
return date(int(split[2]) + 2000, int(split[1]), int(split[0]))
class RentedPage(BasePage):
def get_list(self):
for tr in self.document.getroot().xpath('//tr[@class="patFuncEntry"]'):
id = tr.xpath('td/input')[0].attrib["value"]
book = Book(id)
bigtitle = tr.xpath('td[@class="patFuncTitle"]/label/a')[0].text
book.name = bigtitle.split('/')[0]
book.author = bigtitle.split('/')[1]
date = tr.xpath('td[@class="patFuncStatus"]')[0].text
book.date = txt2date(date.replace('RETOUR', ''))
yield book
class HistoryPage(BasePage):
pass
class BookedPage(BasePage):
# TODO: book some books...
pass
class LoginPage(BasePage):
def login(self, login, passwd):
self.browser.select_form(nr=0)
self.browser.form.set_all_readonly(False)
self.browser['code'] = login
self.browser['pin'] = passwd
self.browser.submit()