# -*- coding: iso-8859-1 -*-
"""
    MoinMoin - modern theme, enhanced to support ISO/FDA like review and approval

    @copyright: 2003-2005 Nir Soffer, Thomas Waldmann
    @license: GNU GPL, see COPYING for details.

    Frank Steinhauer (FST) 11.2010: 
     * added approval changes of Oliver Siemoneit 12.2006, improved a bit
     * approvePage action not written in capital letters to avoid auto matic appending to the actions menu.

"""

import os #FST
from MoinMoin.theme import ThemeBase
from MoinMoin import wikiutil

class Theme(ThemeBase):

#FST start
    name = "modern_iso"

    _showApproveLink = None

    def showApproval(self, page):
        """ This methods 
             * writes approved by xxx into the output if current version is approved
             * sets the flag that controls the "Approve" link in the Editbar 
        """

        # check whether page exists at all
        if not page.exists():
            return ""

        # don't show approval stuff when login or searching
        action = self.request.query_string
        if action.startswith('action=login') or action.startswith('action=fullsearch') or action.startswith('action=user'):
            return ""

        # check if file "approved" exists in page dir
        approvedFile = os.path.join(page.getPagePath(), "approved")
        if os.path.isfile(approvedFile):
            approvedRevision = {}
            for line in open(approvedFile).readlines():
                tmp = line.split("\t")
                approvedRevision[tmp[0]] = tmp[1]
            currentRevision = "%08d" % page.get_real_rev()
            if currentRevision in approvedRevision:
                self._showApproveLink = False
                return "approved by " + approvedRevision[currentRevision]
        if page.get_real_rev() == page.getRevList()[0]:
            self._showApproveLink = True
        else:
            self._showApproveLink = False
        return ""

    def showApprovalHistory(self, d):
        """ 
            Show box with approval message if there is are approved versions of this page
        """
        page = d['page']
        
        # check whether page exists at all
        if not page.exists():
            return ""

        approvedFile = os.path.join(page.getPagePath(), "approved")
        if os.path.isfile(approvedFile):
            action = self.request.query_string
            # Note: if (self.query_string.find('action=login') < 0) might work too...
            if not action.startswith('action=login') and not action.startswith('action=fullsearch') and not action.startswith('action=user'):
                # return the page's approval status
                return page.getApprovalMessage()
        return ""

    def approveLink(self, page):
        """ Return approve link to valid users
            Use small letters in action name to prevent adding Action to "more Actions" scrolldown list
            @rtype: unicode
            @return: approve link
        """
        _ = self.request.getText

        #if user has perms
        title = _("Approve")
        quotedname = wikiutil.quoteWikinameURL(page.page_name)
        return page.link_to(self.request, text=_('Approve', formatted=False), querystr='action=approvePage')

    def editbarItems(self, page):
        """ add our approve stuff to the list """

        links = ThemeBase.editbarItems(self,page)
        if self._showApproveLink:
            if "approve" not in self.request.cfg.actions_excluded and self.request.user.may.approve(page.page_name):
                links.append(self.approveLink(page))
        return links
#FST end

    def header(self, d, **kw):
        """ Assemble wiki header

        @param d: parameter dictionary
        @rtype: unicode
        @return: page header html
        """
        html = [
            # Pre header custom html
            self.emit_custom_html(self.cfg.page_header1),

            # Header
            u'<div id="header">',
            self.logo(),
            self.searchform(d),
            self.username(d),
            u'<div id="locationline">',
            self.interwiki(d),
            self.title(d),
            self.showApproval(d['page']), #FST
            u'</div>',
            self.trail(d),
            self.navibar(d),
            u'<div id="pageline"><hr style="display:none;"></div>',
            self.msg(d),
            self.editbar(d),
            u'</div>',

            # Post header custom html (not recommended)
            self.emit_custom_html(self.cfg.page_header2),

            self.showApprovalHistory(d), #FST

            # Start of page
            self.startPage(),
        ]
        return u'\n'.join(html)

    def editorheader(self, d, **kw):
        """ Assemble wiki header for editor

        @param d: parameter dictionary
        @rtype: unicode
        @return: page header html
        """
        html = [
            # Pre header custom html
            self.emit_custom_html(self.cfg.page_header1),

            # Header
            u'<div id="header">',
            self.title(d),
            self.msg(d),
            u'</div>',

            # Post header custom html (not recommended)
            self.emit_custom_html(self.cfg.page_header2),

            # Start of page
            self.startPage(),
        ]
        return u'\n'.join(html)

    def footer(self, d, **keywords):
        """ Assemble wiki footer

        @param d: parameter dictionary
        @keyword ...:...
        @rtype: unicode
        @return: page footer html
        """
        page = d['page']
        html = [
            # End of page
            self.pageinfo(page),
            self.endPage(),

            # Pre footer custom html (not recommended!)
            self.emit_custom_html(self.cfg.page_footer1),

            # Footer
            u'<div id="footer">',
            self.editbar(d),
            self.credits(d),
            self.showversion(d, **keywords),
            u'</div>',

            # Post footer custom html
            self.emit_custom_html(self.cfg.page_footer2),
            ]
        return u'\n'.join(html)

def execute(request):
    """
    Generate and return a theme object

    @param request: the request object
    @rtype: MoinTheme
    @return: Theme object
    """
    return Theme(request)

