コード例 #1
0
 def exportFit(self, fitID):
     fit = eos.db.getFit(fitID)
     return Port.exportEft(fit)
コード例 #2
0
 def clipboardEft(self):
     fit = db_getFit(self.getActiveFit())
     toClipboard(Port.exportEft(fit))
コード例 #3
0
    def generateFullHTML(self, sMkt, sFit, dnaUrl):
        """ Generate the complete HTML with styling and javascript """
        timestamp = time.localtime(time.time())
        localDate = "%d/%02d/%02d %02d:%02d" % (timestamp[0], timestamp[1], timestamp[2], timestamp[3], timestamp[4])

        HTML = """
<!DOCTYPE html>
<html>
  <head>
  <title>Pyfa Fittings</title>
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <meta charset="utf-8" />
  <link rel="stylesheet" href="https://code.jquery.com/mobile/1.4.2/jquery.mobile-1.4.2.min.css" />
  <script src="https://code.jquery.com/jquery-1.11.0.min.js"></script>
  <script>
//http://stackoverflow.com/questions/32453806/uncaught-securityerror-failed-to-execute-replacestate-on-history-cannot-be
    $(document).bind('mobileinit',function(){
        $.mobile.changePage.defaults.changeHash = false;
        $.mobile.hashListeningEnabled = false;
        $.mobile.pushStateEnabled = false;
    });
  </script>
  <script src="https://code.jquery.com/mobile/1.4.2/jquery.mobile-1.4.2.min.js"></script>
  <style>
    /* Basic settings */
    .ui-li-static.ui-collapsible {
        padding: 0;
    }
    .ui-li-static.ui-collapsible > .ui-collapsible-content > .ui-listview,
    .ui-li-static.ui-collapsible > .ui-collapsible-heading {
        margin: 0;
    }
    .ui-li-static.ui-collapsible > .ui-collapsible-content {
        padding-top: 0;
        padding-bottom: 0;
        padding-right: 0;
        border-bottom-width: 0;
    }
    /* collapse vertical borders */
    .ui-li-static.ui-collapsible > .ui-collapsible-content > .ui-listview > li.ui-last-child,
    .ui-li-static.ui-collapsible.ui-collapsible-collapsed > .ui-collapsible-heading > a.ui-btn {
        border-bottom-width: 0;
    }
    .ui-li-static.ui-collapsible > .ui-collapsible-content > .ui-listview > li.ui-first-child,
    .ui-li-static.ui-collapsible > .ui-collapsible-content > .ui-listview > li.ui-first-child > a.ui-btn,
    .ui-li-static.ui-collapsible > .ui-collapsible-heading > a.ui-btn {
        border-top-width: 0;
    }
    /* Remove right borders */
    .ui-li-static.ui-collapsible > .ui-collapsible-heading > a.ui-btn,
    .ui-li-static.ui-collapsible > .ui-collapsible-content > .ui-listview > .ui-li-static,
    .ui-li-static.ui-collapsible > .ui-collapsible-content > .ui-listview > li > a.ui-btn,
    .ui-li-static.ui-collapsible > .ui-collapsible-content {
        border-right-width: 0;
    }
    /* Remove left borders */
    /* Here, we need class ui-listview-outer to identify the outermost listview */
    .ui-listview-outer > .ui-li-static.ui-collapsible .ui-li-static.ui-collapsible.ui-collapsible,
    .ui-listview-outer > .ui-li-static.ui-collapsible > .ui-collapsible-heading > a.ui-btn,
    .ui-li-static.ui-collapsible > .ui-collapsible-content {
        border-left-width: 0;
    }
    .ui-content { max-width: 800px !important; margin: 0 auto !important;  }
    .ui-listview > .ui-li-static.ui-li-has-count { padding-right: 0px }
  </style>

  <script>
    $(document).ready(function() {
      var start = new Date(%d * 1000);

      setInterval(function() {
        var diff = (new Date - start) / 1000;

        var days = Math.floor((diff %% 31536000) / 86400);
        var hours = Math.floor(((diff %% 31536000) %% 86400) / 3600);
        var minutes = Math.floor((((diff %% 31536000) %% 86400) %% 3600) / 60);
        var seconds = Math.floor(((diff %% 31536000) %% 86400) %% 3600) %% 60;

        $('.timer').text(days+":"+hours+":"+minutes+":"+seconds+" ago");
      }, 1000);

      $('a[data-dna]').each(function( index ) {
        var dna = $(this).data('dna');
        if (typeof CCPEVE !== 'undefined') { // inside IGB
          $(this).attr('href', 'javascript:CCPEVE.showFitting("'+dna+'");');}
        else {                               // outside IGB
          $(this).attr('href', '%s'+dna); }
      });
    });
  </script>
</head>
<body>
<div  id="canvas" data-role="page">
  <div data-role="header">
    <h1>Pyfa fits</h1>
  </div>
  <div data-role="content">
  <div style="text-align: center;"><strong>Last updated:</strong> %s <small>(<span class="timer"></span>)</small></div>

""" % (time.time(), dnaUrl, localDate)
        HTML += '  <ul data-role="listview" class="ui-listview-outer" data-inset="true" data-filter="true">\n'
        categoryList = list(sMkt.getShipRoot())
        categoryList.sort(key=lambda _ship: _ship.name)

        count = 0

        for group in categoryList:
            # init market group string to give ships something to attach to
            HTMLgroup = ''

            ships = list(sMkt.getShipList(group.ID))
            ships.sort(key=lambda _ship: _ship.name)

            # Keep track of how many ships per group
            groupFits = 0
            for ship in ships:
                fits = sFit.getFitsWithShip(ship.ID)

                if len(fits) > 0:
                    groupFits += len(fits)
                    HTMLship = (
                        '        <li data-role="collapsible" data-iconpos="right" data-shadow="false" '
                        'data-corners="false">\n'
                        '        <h2>' + ship.name + ' <span class="ui-li-count">' + str(
                            len(fits)) + '</span></h2>\n'
                                         '          <ul data-role="listview" data-shadow="false" data-inset="true" '
                                         'data-corners="false">\n'
                    )

                    for fit in fits:
                        if self.stopRunning:
                            return
                        try:
                            eftFit = Port.exportEft(getFit(fit[0]))
                            print(eftFit)

                            HTMLfit = (
                                    '           <li data-role="collapsible" data-iconpos="right" data-shadow="false" '
                                    'data-corners="false">\n'
                                    '           <h2>' + fit[1] + '</h2>\n'
                                    '               <ul data-role="listview" data-shadow="false" data-inset="true" '
                                                                 'data-corners="false">\n'
                            )

                            HTMLfit += '                   <li><pre>' + eftFit + '\n                   </pre></li>\n'

                            HTMLfit += '              </ul>\n          </li>\n'
                            HTMLship += HTMLfit
                        except:
                            pyfalog.warning("Failed to export line")
                            continue
                        finally:
                            if self.callback:
                                wx.CallAfter(self.callback, count)
                            count += 1
                    HTMLgroup += HTMLship + ('          </ul>\n'
                                             '        </li>\n')

            if groupFits > 0:
                # Market group header
                HTML += (
                    '    <li data-role="collapsible" data-iconpos="right" data-shadow="false" data-corners="false">\n'
                    '      <h2>' + group.groupName + ' <span class="ui-li-count">' + str(groupFits) + '</span></h2>\n'
                    '      <ul data-role="listview" data-shadow="false" data-inset="true" data-corners="false">\n' +
                    HTMLgroup +
                    '      </ul>\n'
                    '    </li>'
                )

        HTML += """
  </ul>
 </div>
</div>
</body>
</html>"""

        return HTML
コード例 #4
0
 def exportEft(self, options, callback):
     fit = getFit(self.mainFrame.getActiveFit())
     Port.exportEft(fit, options, callback)
コード例 #5
0
ファイル: fit.py プロジェクト: SpeakerJunk/Pyfa
 def exportFit(self, fitID):
     fit = eos.db.getFit(fitID)
     return Port.exportEft(fit)
コード例 #6
0
ファイル: copySelectDialog.py プロジェクト: pyfa-org/Pyfa
 def exportEft(self, options, callback):
     fit = getFit(self.mainFrame.getActiveFit())
     Port.exportEft(fit, options, callback)
コード例 #7
0
 def clipboardEft(self, options):
     fit = db_getFit(self.getActiveFit())
     toClipboard(Port.exportEft(fit, options))
コード例 #8
0
 def exportFit(self, fitID):
     return Port.exportEft(fitID)
コード例 #9
0
ファイル: mainFrame.py プロジェクト: copyliu/Pyfa
 def clipboardEft(self):
     fit = db_getFit(self.getActiveFit())
     toClipboard(Port.exportEft(fit))
コード例 #10
0
ファイル: fit.py プロジェクト: Dekadara/Pyfa
 def exportFit(self, fitID):
     return Port.exportEft(fitID)